5

呼んでいます:

Imgproc.matchTemplate(image, templ, result, 0);

一致の結果はMatインスタンスにあります。このクラスのドキュメントが見つかりませんでした。私が正しく理解していれば、結果には確率の行列が含まれています。確率の最大値を見つけるにはどうすればよいですか?Matインスタンスがどのように表示され、何が含まれているのかさえ理解できません。

ありがとうEyal

4

2 に答える 2

8

lena.png:

ここに画像の説明を入力してください

pattern.png:

ここに画像の説明を入力してください

class MatchingDemo {
    public void run(String inFile, String templateFile, String outFile,
            int match_method) {
        System.out.println("\nRunning Template Matching");

        Mat img = Highgui.imread(inFile);
        Mat templ = Highgui.imread(templateFile);

        // / Create the result matrix
        int result_cols = img.cols() - templ.cols() + 1;
        int result_rows = img.rows() - templ.rows() + 1;
        Mat result = new Mat(result_rows, result_cols, CvType.CV_32FC1);

        // / Do the Matching and Normalize
        Imgproc.matchTemplate(img, templ, result, match_method);
        Core.normalize(result, result, 0, 1, Core.NORM_MINMAX, -1, new Mat());
        Highgui.imwrite("out2.png", result);

        // / Localizing the best match with minMaxLoc
        MinMaxLocResult mmr = Core.minMaxLoc(result);

        Point matchLoc;
        if (match_method == Imgproc.TM_SQDIFF
                || match_method == Imgproc.TM_SQDIFF_NORMED) {
            matchLoc = mmr.minLoc;
            System.out.println(mmr.minVal);
        } else {
            matchLoc = mmr.maxLoc;
            System.out.println(mmr.maxVal);
        }

        // / Show me what you got
        Core.rectangle(img, matchLoc, new Point(matchLoc.x + templ.cols(),
                matchLoc.y + templ.rows()), new Scalar(0, 255, 0));

        // Save the visualized detection.
        System.out.println("Writing " + outFile);
        Highgui.imwrite(outFile, img);

    }
}

public class TemplateMatching {
    public static void main(String[] args) {
        System.loadLibrary("opencv_java249");
        new MatchingDemo().run("lena.png", "pattern.png", "output.png", Imgproc.TM_CCOEFF);
    }
}
于 2014-10-17T06:25:11.883 に答える
3

結果をテストするには、Coreクラス内にある関数minMaxLocを使用する必要があります。このメソッドはMinMaxLocResultのインスタンスを返し、内部に多くのオプションがあります。

于 2012-03-13T18:32:36.957 に答える