java opencv 模板匹配算法_浅谈opencv模板匹配算法原理
1、什么是模板匹配
简单来说模板匹配就是通过现有的模板去与图片进行比较找出图中所匹配的图像
例如网红脸傻傻分不清,可以用模板匹配来特定的网红,如见下图。检测的图片模板
opencv官网对模板匹配的解释是:模板匹配是一种用于在较大图像中搜索和查找模板图像位置的方法。为此,OpenCV带有一个函数cv2.matchTemplate()。它只是将模板图像滑动到输入图像上(就像在2D卷积中一样),然后在模板图像下比较模板和输入图像的补丁。OpenCV中实现了几种比较方法。(您可以检查文档以了解更多详细信息)。它返回一个灰度图像,其中每个像素表示该像素的邻域与模板匹配多少。
如果输入图像的大小(WxH)和模板图像的大小(wxh),则输出图像的大小将为(W-w + 1,H-h + 1)。获得结果后,可以使用cv2.minMaxLoc()函数查找最大/最小值在哪里。将其作为矩形的左上角,并以(w,h)作为矩形的宽度和高度。该矩形是您模板的区域。
我的理解就是:模板在待检测的图像上从左至右,从上至下的滑动(我做了一个简陋的gif示意动画,如图),模板从源图像左上角开始每次以模板的左上角像素点为单位从左至右,从上至下移动,每到达一个像素点,就会以这个像素点为左上角顶点从源图像中截取出与模板一样大小的图像与模板进行像素比较运算
模板滑动与源图像匹配过程中,将模板和当前截取的图像的比较计算结果存储在一个矩阵
中(大小为W-w + 1,H-h + 1,如图)。R中每一个位置(x, y)的值都表示以这个点为左上角顶点截取的图像与模板像素计算后的计算结果。在OpenCV中提供了6种匹配度量方法。(我只介绍两种,另外的运用了归一化的方法,我将在下篇博客里提到)
2、模板匹配算法
设得到的矩阵为
,模板图像矩阵为
,源图像矩阵为
平方差匹配法CV_TM_SQDIFF
即模板图像像素减去覆盖的源图像像素的差的平方和为对应矩阵的点的值。
如果值越接近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)
相关匹配法CV_TM_CCORR
即模板和图像间的乘法操作,所以较大的数表示匹配程度较高,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的白色,那么即使模板与之不匹配,其积也会很高
java opencv 模板匹配算法_浅谈opencv模板匹配算法原理相关推荐
- laytpl语法_浅谈laytpl 模板空值显示null的解决方法及简单的js表达式
浅谈laytpl 模板空值显示null的解决方法及简单的js表达式 laytpl 模板语法 {{ d.field }} 输出一个普通字段,不转义html 官方的说明 但d.field 为空时会显示nu ...
- 动态磅是怎么原理_浅谈动态地磅的原理及未来发展方向
浅谈动态地磅的原理及未来发展方向: 文章介绍了动态地磅的结构和工作原理,针对动态地磅的分类做了全面的概述,分别对不同的动态地磅做了对比及详细的阐述,说明选择和使用动态地磅器的注意事项,凸显了轴组式动态 ...
- 伺服驱动器生产文件_浅谈伺服驱动器的工作原理
原标题:浅谈伺服驱动器的工作原理 目前,主流的伺服驱动器均采用数字信号处理器(DSP)作为控制核心,可以实现比较复杂的控制算法,实现数字化.网络化和智能化.功率器件普遍采用以智能功率模块(IPM)为核 ...
- java 中的单元测试_浅谈Java 中的单元测试
单元测试编写 Junit 单元测试框架 对于Java语言而言,其单元测试框架,有Junit和TestNG这两种, 下面是一个典型的JUnit测试类的结构 package com.example.dem ...
- java编程double相乘_浅谈Java double 相乘的结果偏差小问题
看下面的一段代码的运行结果: public class TestDouble { public static void main(String[] args) { double d =538.8; S ...
- java dao service实例_浅谈Action+Service +Dao 功能
1. Action/Service/DAO简介: Action是管理业务(Service)调度和管理跳转的. Service是管理具体的功能的. Action只负责管理,而Service负责实施. D ...
- java变量命名规则_浅谈JAVA开发规范与开发细节(上)
开发团队在开发过程中,由于每个人的开发习惯,以及对于技术的理解深浅程度不一,往往一个项目在开发过程中,代码的质量,代码的风格都不尽相似,所以有一份适合团队的代码规范是非常有必要的,而一个团队的代码规范 ...
- java布尔类型比较器_浅谈Java中几种常见的比较器的实现方法
在java中经常会涉及到对象数组的排序问题,那么就涉及到对象之间的比较问题. 通常对象之间的比较可以从两个方面去看: 第一个方面:对象的地址是否一样,也就是是否引用自同一个对象.这种方式可以直接使用& ...
- java null什么意思_浅谈java中null是什么,以及使用中要注意的事项
1.null既不是对象也不是一种类型,它仅是一种特殊的值,你可以将其赋予任何引用类型,你也可以将null转化成任何类型,例如: Integer i=null; Float f=null; String ...
- java 定时任务怎么关闭_浅谈springboot项目中定时任务如何优雅退出
在一个springboot项目中需要跑定时任务处理批数据时,突然有个Kill命令或者一个Ctrl+C的命令,此时我们需要当批数据处理完毕后才允许定时任务关闭,也就是当定时任务结束时才允许Kill命令生 ...
最新文章
- datatables增删改查php,jQuery+datatables插件实现Ajax加载数据与增删改查功能示例_白峰_前端开发者...
- linux df命令参数详解
- PC端创业真的已死?我不这么认为
- Python:基础操作(2)
- 四则运算(可怜的二柱子)2
- python 3.9.0a0_Python 3.9.0 稳定版发布
- MySQL自动备份shell脚本
- python%20是什么东西
- Android studio中单项选择,Android studio单选按钮、复选按钮
- android真实项目教程(一)——App应用框架搭建_by_CJJ
- 空间变量php,PHP名称空间可以包含变量吗?
- Java中的编译、反编译和反编译工具全家桶分享
- 群晖3617可以有几个网卡_一步到位,购入群晖920+和它的小伙伴们
- ESP-8266wifi模块获取网络实时时间
- Hcse 交换知识点-4
- 有关USGS下载landsat 8影像的方法
- python股票接口_在Python中使用股票接口
- wifi ip地址租约处理
- 人工智能,落地为王!深圳人工智能企业百强榜超七成为应用层
- C语言-飞机航班订票系统
热门文章
- iOS/Android开发人脸识别SDK列表
- 基于ssm的超市进销存管理系统
- 统一认证 ldap mysql_ZABBIX 对接 LDAP实现用户登陆统一认证
- Mac新手必看教程,苹果电脑基本使用操作,苹果电脑基本操作
- 589页22万字城市智慧应急指挥中心大数据信息化系统整体设计方案
- 常见反爬虫方法及其应对策略
- 安防综合管理平台/视频资源汇聚平台
- linux测试硬盘速度命令,如何测试Linux磁盘的读写速度
- 油猴插件/脚本还不会使用?看这篇文章就够了, 各种实用的插件/脚本使用技巧
- 如何修复苹果Mac中的快速视频播放错误