当前位置:   article > 正文

15- OpenCV:模板匹配(cv::matchTemplate)_opencv模板匹配

opencv模板匹配

目录

1、模板匹配介绍

2、cv::matchTemplate

3、模板匹配的方法(算法)

4、代码演示


1、模板匹配介绍

模板匹配就是在整个图像区域发现与给定子图像匹配的小块区域。

它可以在一幅图像中寻找与给定模板最相似的部分。

模板匹配的步骤:

(1)首先需要一个模板图像T(给定的子图像);

(2)另外需要一个待检测的图像-源图像S;

(3)工作方法:在带检测图像上,从左到右,从上向下计算模板图像与重叠子图像的匹配度,匹配程度越大,两者相同的可能性越大。

需要注意的是:matchTemplate函数可以用于在图像中进行目标检测、模式识别等应用,但需要注意模板的大小和比例与输入图像的匹配程度,以及选择合适的匹配方法来获取准确的匹配结果

2、cv::matchTemplate

void cv::matchTemplate(

InputArray image,// 源图像,必须是8-bit或者32-bit浮点数图像

InputArray templ,// 模板图像,类型与输入图像一致

OutputArray result,// 输出结果,必须是单通道32位浮点数,假设源图像WxH,模板图像wxh,                  则结果必须为W-w+1, H-h+1的大小。

int method,//使用的匹配方法

InputArray mask=noArray() //(optional) 可选的掩码图像,用于指定要处理的区域。

)

3、模板匹配的方法(算法)

enum TemplateMatchModes {
    TM_SQDIFF                    = 0,  // 计算平方不同
    TM_SQDIFF_NORMED  = 1,  // 计算归一化平方不同
    TM_CCORR                    = 2,  // 计算相关性
    TM_CCORR_NORMED  = 3,  // 计算归一化相关性
    TM_CCOEFF                   = 4,  // 计算相关系数
    TM_CCOEFF_NORMED = 5   // 计算归一化相关系数
};

相关的公式表示:

4、代码演示
  1. #include<opencv2\opencv.hpp>
  2. #include<iostream>
  3. #include <math.h>
  4. using namespace cv;
  5. using namespace std;
  6. // 模板匹配
  7. Mat src, temp, dst;
  8. int match_method = TM_SQDIFF;
  9. int max_track = 5;
  10. const char* INPUT_T = "input image";
  11. const char* OUTPUT_T = "result image";
  12. const char* match_t = "template match-demo";
  13. void Match_Demo(int, void*);
  14. int main(int argc, char** argv)
  15. {
  16. // 待检测图像
  17. src = imread("cat.png");
  18. // 模板图像
  19. temp = imread("ear.png");
  20. if (src.empty() || temp.empty())
  21. {
  22. printf("could not load image...\n");
  23. return -1;
  24. }
  25. namedWindow(INPUT_T, CV_WINDOW_AUTOSIZE);
  26. namedWindow(OUTPUT_T, CV_WINDOW_NORMAL);
  27. namedWindow(match_t, CV_WINDOW_AUTOSIZE);
  28. imshow(INPUT_T, temp);
  29. const char* trackbar_title = "Match Algo Type:";
  30. createTrackbar(trackbar_title, OUTPUT_T, &match_method, max_track, Match_Demo);
  31. Match_Demo(0, 0);
  32. waitKey(0);
  33. return 0;
  34. }
  35. void Match_Demo(int, void*)
  36. {
  37. int width = src.cols - temp.cols + 1;
  38. int height = src.rows - temp.rows + 1;
  39. Mat result(width, height, CV_32FC1);//32位浮点数,单通道
  40. matchTemplate(src, temp, result, match_method, Mat());
  41. normalize(result, result, 0, 1, NORM_MINMAX, -1, Mat());
  42. Point minLoc;
  43. Point maxLoc;
  44. double min, max;
  45. src.copyTo(dst);
  46. Point temLoc;
  47. // 用于在给定矩阵中找到最小值、最大值及其对应的位置。
  48. minMaxLoc(result, &min, &max, &minLoc, &maxLoc, Mat());
  49. if (match_method == TM_SQDIFF || match_method == TM_SQDIFF_NORMED)
  50. temLoc = minLoc;
  51. else
  52. temLoc = maxLoc;
  53. // 绘制矩形
  54. rectangle(dst, Rect(temLoc.x, temLoc.y, temp.cols, temp.rows), Scalar(0, 0, 255), 2, 8);
  55. rectangle(result, Rect(temLoc.x, temLoc.y, temp.cols, temp.rows), Scalar(0, 0, 255), 2, 8);
  56. imshow(OUTPUT_T, result);
  57. imshow(match_t, dst);
  58. }
  59. // 简易版例子
  60. #if 0
  61. int main()
  62. {
  63. // 读取输入图像和模板图像
  64. cv::Mat image = cv::imread("cat.png", cv::IMREAD_COLOR);
  65. cv::Mat templ = cv::imread("ear.png", cv::IMREAD_COLOR);
  66. // 创建结果矩阵
  67. cv::Mat result;
  68. // 进行模板匹配
  69. cv::matchTemplate(image, templ, result, cv::TM_CCOEFF_NORMED);
  70. // 寻找最大匹配值和对应位置
  71. double minVal, maxVal;
  72. cv::Point minLoc, maxLoc;
  73. cv::minMaxLoc(result, &minVal, &maxVal, &minLoc, &maxLoc);
  74. // 绘制矩形框标记匹配位置
  75. cv::rectangle(image, maxLoc, cv::Point(maxLoc.x + templ.cols, maxLoc.y + templ.rows), cv::Scalar(0, 255, 0), 2);
  76. // 显示结果图像
  77. cv::imshow("Result", image);
  78. cv::waitKey(0);
  79. return 0;
  80. }
  81. #endif

效果展示:

注意:当选择2的时候,有可能找不到,原因在于我们选择的模板有关,有可能存在失真的效果。所以对于模板如何选择也很关键。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/658644
推荐阅读
相关标签
  

闽ICP备14008679号