java opencv 模板匹配算法_浅谈opencv模板匹配算法原理

本文介绍了OpenCV中的模板匹配原理,通过匹配模板在图像中寻找相似区域。利用cv2.matchTemplate()函数进行匹配,并讲解了平方差匹配法和相关匹配法。还探讨了cv2.minMaxLoc()在确定最佳匹配位置中的应用。最后,提到了OpenCV提供的不同匹配算法选项和相关API的使用。
摘要由CSDN通过智能技术生成

1、什么是模板匹配

简单来说模板匹配就是通过现有的模板去与图片进行比较找出图中所匹配的图像

例如网红脸傻傻分不清,可以用模板匹配来特定的网红,如见下图。检测的图片模板

opencv官网对模板匹配的解释是:模板匹配是一种用于在较大图像中搜索和查找模板图像位置的方法。为此,OpenCV带有一个函数cv2.matchTemplate()。它只是将模板图​​像滑动到输入图像上(就像在2D卷积中一样),然后在模板图像下比较模板和输入图像的补丁。OpenCV中实现了几种比较方法。(您可以检查文档以了解更多详细信息)。它返回一个灰度图像,其中每个像素表示该像素的邻域与模板匹配多少。

如果输入图像的大小(WxH)和模板图像的大小(wxh),则输出图像的大小将为(W-w + 1,H-h + 1)。获得结果后,可以使用cv2.minMaxLoc()函数查找最大/最小值在哪里。将其作为矩形的左上角,并以(w,h)作为矩形的宽度和高度。该矩形是您模板的区域。

我的理解就是:模板在待检测的图像上从左至右,从上至下的滑动(我做了一个简陋的gif示意动画,如图),模板从源图像左上角开始每次以模板的左上角像素点为单位从左至右,从上至下移动,每到达一个像素点,就会以这个像素点为左上角顶点从源图像中截取出与模板一样大小的图像与模板进行像素比较运算

模板滑动与源图像匹配过程中,将模板和当前截取的图像的比较计算结果存储在一个矩阵

equation?tex=R%EF%BC%88x%2Cy%EF%BC%89 中(大小为W-w + 1,H-h + 1,如图)。R中每一个位置(x, y)的值都表示以这个点为左上角顶点截取的图像与模板像素计算后的计算结果。在OpenCV中提供了6种匹配度量方法。(我只介绍两种,另外的运用了归一化的方法,我将在下篇博客里提到)

2、模板匹配算法

设得到的矩阵为

equation?tex=R%28x%2Cy%29 ,模板图像矩阵为

equation?tex=T%28x%27%2Cy%27%29 ,源图像矩阵为

equation?tex=I%28x%2Cy%29

equation?tex=%281%29 平方差匹配法CV_TM_SQDIFF

equation?tex=R%28x%2Cy%29%3D%5Csum_%7Bx%27%2Cy%27%7D%28T%28x%27%2Cy%27%29-I%28x%2Bx%27%2Cy%2By%27%29%29%5E2

即模板图像像素减去覆盖的源图像像素的差的平方和为对应矩阵的点的值。

如果值越接近0,说明匹配程度越高。

示例代码

import cv2

import numpy as np

img=cv2.imread('./src/img.png',cv2.IMREAD_COLOR)

imgGray=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

template=cv2.imread('./src/template.png',cv2.IMREAD_GRAYSCALE)

height,width=template.shape[:2]

#print(height,width)

res=cv2.matchTemplate(imgGray,template,cv2.TM_SQDIFF)

thresthold=0.1

loc = np.where(res <= thresthold)

for pt in zip(*loc[::-1]):

right_bottom = (pt[0] + width, pt[1] + height)

cv2.rectangle(img, pt, right_bottom, (0, 0, 255), 2)

cv2.imshow('src',img)

cv2.imshow('template',template)

cv2.imshow('result',res)

cv2.waitKey(0)

equation?tex=%EF%BC%882%EF%BC%89 相关匹配法CV_TM_CCORR

equation?tex=R%28x%2Cy%29%3D%5Csum_%7Bx%27%2Cy%27%7D%28T%28x%27%2Cy%27%29%5Ccdot+I%28x%2Bx%27%2Cy%2By%27%29%29

即模板和图像间的乘法操作,所以较大的数表示匹配程度较高,0标识最坏的匹配效果.

示例代码

将上文代码第八行改为

res=cv2.matchTemplate(imgGray,template,cv2.TM_CCORR)

3、介绍opencv相关api

1、cv2.matchTemplate

cv2.matchTemplate(image,template,result,method)

#或者result=cv2.matchTemplate(image,template,method)

#image输入的检测图像

#template模板图像

#输出的矩阵图像

#采用的算法,如上文介绍的两种,还有CV_TM_SQDIFF_NORMED、CV_TM_SQDIFF_NORMED、CV_TM_CCOEFF、CV_TM_CCOEFF_NORMED

2、cv2.minMaxLoc

min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result)

#min_val、max_val都是输入的矩阵中的最小值和最大值

#min_loc、 max_loc都是最小值 最大值所对应的坐标元组

4、参考链接

python-opencv模板匹配文档​opencv-python-tutroals.readthedocs.io模板匹配文档​docs.opencv.org

如果有任何问题,欢迎评论区留言,大家一起交流,共同学习。

我是一名爱好计算机软件,想要成为计算机视觉大牛的大二学生,希望你能关注我的专栏,我会不定期更新一些自己的学习记录,欢迎指点和共同学习。点关注,不迷路哟,亲!

参考^这里我查了许多资料都觉得没讲清楚,例如如果源图是255的白色,那么即使模板与之不匹配,其积也会很高

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值