Opencv (C++)系列学习---模板匹配

这篇具有很好参考价值的文章主要介绍了Opencv (C++)系列学习---模板匹配。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1.模板匹配的定义

2.API介绍

3.寻找最优匹配位置(匹配后的配套操作)

4.具体代码


1.模板匹配的定义

        模板匹配就是在整个图像区域发现与给定子图像匹配的小块区域,该匹配方法并不是基于直方图,而是使用一个图像块在输入图像上进行“”滑动“”。(也就是在图像上按照模板大小一块一块比对)

2.API介绍

void cv::matchTemplate(
cv::InputArray image //需要匹配的图像
cv::InputArray temp  //模板图像
cv::OutArray  result //存储的计算得到的结果
int           method  //匹配的方法
)

对于该算子需要注意的有两点:

1.result是存储匹配的结果,对于它的定义为单通道的大小为(image.width-temp.width+1,image.height-temp.height+1),也就是原图的大小裁去temple模板的宽高,不过其定义rows和cols需要交换位置(正常图像Mat定义先rows后cols),同时数据类型可以是CV_8UC1或者CV_32FC1。具体定义如下:

Mat result(image.cols-temp.cols+1,image.rows-temp.rows+1,CV_32FC1)

2.匹配方法介绍

cv::TM_SQDIFF==0(方差匹配法)

cv::TM_SQDIFF_NORMED==1(归一方差匹配法)

cv::TM_CCORR==2(相关性匹配方法)

cv::TM_CCORR_NORMED==3(归一化的互相关匹配法)

cv::TM_CCOEFF==4(相关系数匹配法)

cv::TM_CCOEFF_NORMED==5(归一化相关系数匹配方法)

对于前两种方差匹配方法0和1,完全匹配后值为0,不匹配值很大(值越小,匹配效果越好)。

对于中间两种相关匹配方法2和3,完全匹配后值很大,不匹配时值很小,接近于0。(值越大,匹配效果越好)。

对于最后两种相关系数匹配方法4和5,完全匹配会得到1,完全误匹配会得到-1。(分值介于-1-1,值越大,匹配效果越好)。

3.寻找最优匹配位置(匹配后的配套操作)

1.cv::normalize 归一化,在同样的代码中选择不同的匹配方法,其result值的结果也不一致,通过归一化算子中cv::NORM_MINMAX方向可以将各点的匹配结果线性映射到0-1之间。

2.cv::minMaxLoc()最小和最大点查找,通过该算子可以将result中结果进行查找,找到分数最小最大值和其在result中的位置。

4.具体代码

#include<iostream>
#include<opencv2\opencv.hpp>
#include<opencv2\highgui\highgui.hpp>
#include<opencv2\imgproc\imgproc.hpp>

using namespace std;
using namespace cv;

#define WINDOW_NAME1 "【原始图片】"
#define WINDOW_NAME2 "【效果窗口】"

//定义全局变量
Mat g_srcImage, g_templateImage, g_resultImage;
int g_nMatchmethod;
int g_nMatTrackbarNum = 5;

//定义全局函数
void on_Matching(int, void*);

int main(int argc,char** argv)
{
	//【1】载入原图像和模块板
	g_srcImage = imread("E:\\进度\\11-16\\模板匹配\\1.jpg",1);
	g_templateImage = imread("E:\\进度\\11-16\\模板匹配\\2.jpg",1);

	//【2】创建窗口
	namedWindow(WINDOW_NAME1,WINDOW_AUTOSIZE);
	namedWindow(WINDOW_NAME2, WINDOW_AUTOSIZE);

	//【3】创建滑动条并进行初始化
	createTrackbar("方法",WINDOW_NAME1,&g_nMatchmethod,g_nMatTrackbarNum,on_Matching);
	on_Matching(0,0);

	waitKey(0);
	return 0;

}

//回调函数
void on_Matching(int, void*)
{
	//【1】 给局部变量初始化
	Mat srcImage;
	g_srcImage.copyTo(srcImage);

	//【2】初始化用于结果输出的矩阵
	int resultImage_cols = g_srcImage.cols - g_templateImage.cols + 1;
	int resultImage_rows = g_srcImage.rows - g_templateImage.rows + 1;

	g_resultImage.create(resultImage_cols,resultImage_rows,CV_32FC1);

	//【3】进行模板匹配
	matchTemplate(g_srcImage,g_templateImage,g_resultImage,g_nMatchmethod);
	normalize(g_resultImage,g_resultImage,0,1,NORM_MINMAX);

	//【4】通过函数minMaxLoc 定位最匹配的位置
	double minvalue, maxValue;
	Point minLocation, maxLocation, MatLocation;
	minMaxLoc(g_resultImage,&minvalue,&maxValue,&minLocation,&maxLocation);
	

	//【5】对于方法SQDIFF和SQDIFF_NORMED越小值有着更高的匹配结果,而其余的方法,数值越大匹配效果越好。
	if (g_nMatchmethod == TM_SQDIFF || g_nMatchmethod == TM_SQDIFF_NORMED)
	{
		MatLocation = minLocation;
	}
	else
	{
		MatLocation = maxLocation;
	}

	//【6】绘制出矩阵,并显示最终结果
	rectangle(srcImage, MatLocation, Point(MatLocation.x + g_templateImage.cols, MatLocation.y + g_templateImage.rows), Scalar(0, 0, 255), 2, 16);
	rectangle(g_resultImage, MatLocation, Point(MatLocation.x + g_templateImage.cols, MatLocation.y + g_templateImage.rows), Scalar(0, 0, 255), 2, 16);

	imshow(WINDOW_NAME1,srcImage);
	imshow(WINDOW_NAME2,g_resultImage);

}

运行结果如下图:

Opencv (C++)系列学习---模板匹配

通过对匹配方法的各个结果对比发现,归一化的匹配方法(2和3)在大多数情况下都会有好的结果,特别是室外环境的图像。相关系数方法的匹配效果更好,但是计算时间代价高。在实际的应用中,尤其是通过摄像头进行自动部件的检测或者特征跟踪,应该尝试使用所有的方法,从中找到一个同时兼顾效率和准确率的方法。文章来源地址https://www.toymoban.com/news/detail-478681.html

到了这里,关于Opencv (C++)系列学习---模板匹配的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Opencv——图像模板匹配

    什么是模板匹配呢? 看到这里大家是否会觉得很熟悉的感觉涌上心头!在人脸识别是不是也会看见 等等。 模板匹配可以看作是对象检测的一种非常基本的形式。使用模板匹配,我们可以使用包含要检测对象的“模板”来检测输入图像中的对象。 参数:(img: 原始图像、

    2024年02月16日
    浏览(30)
  • OpenCV 模板匹配 matchTemplate

    模板匹配是一项在一副图像中寻找与另一幅模板图像最匹配(相似)部分的技术。模板匹配不是基于直方图的,而是通过在输入图像上滑动图像块(模板)同时对比相似度,来对模板和输入图像进行匹配的一种方法。 应用: (1)目标查找定位 (2)运动物体跟踪 image:待搜

    2024年02月04日
    浏览(49)
  • OpenCV(十九):模板匹配

    1.模板匹配:      OpenCV提供了一个模板匹配函数,用于在图像中寻找给定模板的匹配位置。 2.图像模板匹配函数matchTemplate  void matchTemplate( InputArray image, InputArray templ, OutputArray result, int method, InputArray mask = noArray() ); image:待模板匹配的原图像,图像数据类型为CV 8U和CV 32F两者中

    2024年02月09日
    浏览(30)
  • 用OpenCV进行模板匹配

    今天我们来研究一种传统图像处理领域中对象检测和跟踪不可或缺的方法——模板匹配,其主要目的是为了在图像上找到我们需要的图案,这听起来十分令人兴奋。 所以,事不宜迟,让我们直接开始吧! 模板匹配的算法的核心十分简单:它将模板与源图像中的每个部分进行

    2024年02月10日
    浏览(34)
  • opencv#27模板匹配

         例如给定一张图片,如上图大矩阵所示,然后给定一张模板图像,如上图小矩阵。      我们在大图像中去搜索与小图像中相同的部分或者是最为相似的内容。比如我们在图像中以灰色区域给出一个与模板图像尺寸大小一致的区域,通过比较灰色区域中的内容与模板中

    2024年01月23日
    浏览(33)
  • opencv 多角度模板匹配

    总结一下实现多角度模板匹配踩的坑 一 、多角度匹配涉及到要使用mask,首先opencv matchTemplateMask自带的源码如下: 可以看到使用用了四次dft来计算卷积,目标图像要与mask卷三次,来计算目标图像在模板区域内的和,平方和。其中最后一次CCorr(I, mask2)可以省略掉,它跟CCorr(I

    2024年02月07日
    浏览(35)
  • OpenCV(11):模板匹配实例讲解

    在OpenCV中,模板匹配是一种图像处理技术,用于在一个大的图像中查找和定位一个小的目标图像(也称为模板)。 通俗而言,就是通过一张图片找到和另一张图片相似的部分。 从此章开始,opencv系列所有的之后更新的博客都会更注重实际应用,而不是仅仅简单讲解一个小方

    2024年02月04日
    浏览(30)
  • OPENCV C++(十二)模板匹配

    正常模板匹配函数  这里0代表的是方法,一般默认为0就ok  img是输入图像 templatee是模板 resultmat是输出 对于输出的说明: 就是说result图像中的每一个点的值代表了一次相似度比较结果。  如图可知,模板在待测图像上每次在横向或是纵向上移动一个像素,并作一次比较计算

    2024年02月13日
    浏览(29)
  • 008 OpenCV matchTemplate 模板匹配

    目录 一、环境 二、模板匹配算法原理 三、代码演示 本文使用环境为: Windows10 Python 3.9.17 opencv-python 4.8.0.74 cv.matchTemplate 是OpenCV库中的一个函数,用于在图像中查找与模板匹配的特征。它的主要应用场景是在图像处理、计算机视觉和模式识别等领域。 算法原理: cv.matchTempl

    2024年02月05日
    浏览(33)
  • 【OpenCV】第十五章: 模板匹配

    第十五章: 模板匹配 模板匹配就是在给定的图片中查找和模板最相似的区域。 实现的方法是:将模板在图片上滑动(从左向右,从上向下),遍历所有滑窗,计算匹配度,将所有计算结果保存在一个矩阵种,并将矩阵中匹配度最高的值作为匹配结果。 一、单模板匹配 1、匹配函

    2024年02月02日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包