3

我正在尝试使用 OpenCV (java) 进行模板匹配并使用最大最小值来确定是否找到了对象。

我正在使用以下 java/opencv 代码,但问题是它为最佳匹配以及未找到匹配的场景返回 0.0 的最小值。

所以这个模板匹配似乎不可靠地确定对象是否找到。我在这段代码中做错了什么还是我需要采用任何其他技术?

提前致谢。

    int templateMatchMethod = Imgproc.TM_SQDIFF_NORMED;
    Mat largeImage = Highgui.imread(largeUrl);
    Mat smallImage = Highgui.imread(smallUrl);

    boolean isMaxTypleMethod = true;

    double TEMPLATE_MATCH_THRESHOLD = 0.8;

    int result_cols = largeImage.cols() - smallImage.cols() + 1;
    int result_rows = largeImage.rows() - smallImage.rows() + 1;
    Mat result = new Mat(result_rows, result_cols, CvType.CV_8U);

    Imgproc.matchTemplate(largeImage, smallImage, result, templateMatchMethod);
    Core.normalize(result, result, 0, 1, Core.NORM_MINMAX, -1, new Mat());

    MinMaxLocResult mmr = Core.minMaxLoc(result);

    Point matchLoc;
    double minMaxValue = 1;
    if (templateMatchMethod == Imgproc.TM_SQDIFF || templateMatchMethod == Imgproc.TM_SQDIFF_NORMED)
    {
        matchLoc = mmr.minLoc;
        isMaxTypleMethod = false;
        TEMPLATE_MATCH_THRESHOLD = 0.4;
        minMaxValue = mmr.minVal;
    }
    else
    {
        matchLoc = mmr.maxLoc;
        minMaxValue = mmr.maxVal;
    }

    Core.rectangle(largeImage, matchLoc, new Point(matchLoc.x + smallImage.cols(),
            matchLoc.y + smallImage.rows()), new Scalar(0, 255, 0));

    System.out.println("minMaxValue : "+minMaxValue);
    if(isMaxTypleMethod && TEMPLATE_MATCH_THRESHOLD < minMaxValue)
    {
        System.out.println("Match found");
    }
    else if (!isMaxTypleMethod && TEMPLATE_MATCH_THRESHOLD > minMaxValue)
    {
        System.out.println("Match found");
    }
4

2 回答 2

4

这看起来很可疑:

Mat result = new Mat(result_rows, result_cols, CvType.CV_8U);  // better use CvType.CV_32F here

Imgproc.matchTemplate(largeImage, smallImage, result, templateMatchMethod);
Core.normalize(result, result, 0, 1, Core.NORM_MINMAX, -1, new Mat());   // normalizing a uchar mat into [0..1] can only result in garbage.

同样,如果您使用浮点类型作为结果并跳过规范化,它会更好地工作

于 2013-07-27T07:21:40.000 回答
0

不要规范化结果,我的意思是从你的代码中删除这一行,

    Core.normalize(result, result, 0, 1, Core.NORM_MINMAX, -1, new Mat());   // normalizing a uchar mat into 

这会很好,会给你正确的最小值最大值,

于 2013-12-17T07:25:19.750 回答