python+opencv图像模板匹配—单模板匹配

python+opencv图像模板匹配—单模板匹配

一、模板匹配

模板匹配目标在于在A图像中寻找B图像最相似的部分,A为输入图像,B为模板图像。其原理将模板图像B在图像A上滑动,遍历所有像素完成匹配
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

二、单模板匹配

在opnencv中利用函数cv2.matchTemplate函数实现:

result=cv2.matchTemplate(image,templ,method[,mask])
其中:
result为匹配返回结果,格式为矩阵
image为输入图像
templ为模板图像,必须小于或等于输入图像,图像类型必须相同

method为匹配方法,现阶段有6中方法:
cv2.TM_SQDIFF/cv2.TM_SQDIFF_NORMED/
cv2.TM_CCORR/cv2.TM_CCORR_NORMED
cv2.TM_CCOEFF/cv2.TM_CCOEFF_NORMED

mask为模板掩模,需要和图像模板templ具有相同类型和大小,一般为默认,只有在SQDIFF和CCORR_NORMED中支持

由于不同模板匹配方法不同,选用cv2.TM_SQDIFF函数进行匹配
利用cv2.minMaxLoc( )寻找结果中最大值,最小值,最大值位置,最小值位置
所得到的结果也实验代码如下

import cv2
import numpy as np
from matplotlib import pyplot as plt
#读取图像为灰度图像
img=cv2.imread('C:/Users/wp/Desktop/five/5.jpg',0)
#读取模板图像
template=cv2.imread('C:/Users/wp/Desktop/five/7.jpg',0)
#模板图像尺寸
th,tw=template.shape[::]
print(th,tw)

#进行模板匹配:匹配方式为SQDIFF,result的值为0表示匹配度越好,反之越差
rv=cv2.matchTemplate(img,template,cv2.TM_SQDIFF)
print(rv)
#归一化,将矩阵结果归一到0到1的范围内
cv2.normalize(rv, rv, 0, 1, cv2.NORM_MINMAX, -1 )
print(rv)

minVal,maxVal,minLoc,maxLoc=cv2.minMaxLoc(rv)
#相似度最小值
print("相似度最小值",minVal)
#相似度最大值
print("相似度最大值",maxVal)


#左上顶点坐标
topLeft=minLoc
#右下顶点坐标
bottomRight=(topLeft[0]+tw,topLeft[1]+th)

#画图,左上顶点,和右下顶点,白色255,宽度为2
cv2.rectangle(img,topLeft,bottomRight,255,2)

cv2.imshow("Matching Result", rv)
cv2.imshow("Detected Point", img)
cv2.waitKey()
cv2.destroyAllWindows()

结果:

280 89
[[1.5662291e+08 1.5261354e+08 1.4868202e+08 ... 1.7876922e+08
  1.7973040e+08 1.8063094e+08]
 [1.5570419e+08 1.5167946e+08 1.4771798e+08 ... 1.7974778e+08
  1.8073296e+08 1.8166957e+08]
 [1.5488346e+08 1.5082822e+08 1.4682650e+08 ... 1.8087574e+08
  1.8187194e+08 1.8283654e+08]
 ...
 [2.4001792e+08 2.3657427e+08 2.3339872e+08 ... 2.5952496e+08
  2.6294157e+08 2.6638003e+08]
 [2.4198950e+08 2.3858016e+08 2.3543363e+08 ... 2.6101248e+08
  2.6439066e+08 2.6780973e+08]
 [2.4398931e+08 2.4063030e+08 2.3747517e+08 ... 2.6249709e+08
  2.6586096e+08 2.6926288e+08]]
[[0.5814756  0.5665784  0.5519705  ... 0.66376233 0.66733366 0.67067975]
 [0.57806206 0.5631077  0.54838854 ... 0.6673982  0.6710588  0.67453885]
 [0.5750125  0.5599449  0.54507613 ... 0.6715893  0.67529076 0.67887485]
 ...
 [0.89133763 0.8785424  0.8667434  ... 0.9638179  0.9765126  0.9892885 ]
 [0.8986632  0.8859955  0.8743043  ... 0.9693449  0.9818968  0.9946007 ]
 [0.9060937  0.893613   0.88188976 ... 0.9748611  0.9873599  1.        ]]
相似度最小值 0.0
相似度最大值 1.0

在这里插入图片描述
在这里插入图片描述

三、参考文献及书籍

Opencv轻松入门,面向python,电子工业出版社,李立宗著

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114566.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Lisp语言简介_c++是什么语言

    Lisp语言简介_c++是什么语言摘自维基百科,原链接为:http://zh.wikipedia.org/zh/LISP因为Clojure是Lisp的一种的方言,所以我们可以先来了解一下Lisp这个比较小众的编程到底是什么~—–

    2022年8月3日
    10
  • OCX制作CAB,数字签名制作

    OCX制作CAB,数字签名制作从网上找了些相关的资料,最终制作成功,做个小的总结:首先准备好必须的工具如下:制作工具:iexpress.exe和makecab.exe,签名工具:cert2spc.exe,makecert.exe,signcode.exe下面我具体说如何使用他们来帮助我们制作需要的cab包。下面是我引用网上的资料信息.1.将ocx文件以及第三方dll文件打包成…

    2022年7月14日
    23
  • Python 引用全局变量提示:local variable referenced before assignment. 问题解决办法,global使用方法介绍

    Python 引用全局变量提示:local variable referenced before assignment. 问题解决办法,global使用方法介绍Python技术篇-引用全局变量提示:localvariablereferencedbeforeassignment.问题解决办法。可能的情况一般有两种:情况一:变量没有被赋值直接引用了。情况二:函数引用全局变量的时候没有声明。就是说函数里想引用全局变量的话,函数前面要告诉函数这个变量是全局的,不然默认就是函数里能使用的局部变量。

    2025年6月13日
    4
  • python加入中小学课程_浙江中小学信息技术科9月换新教材,课程新增Python、PPT、H5………

    python加入中小学课程_浙江中小学信息技术科9月换新教材,课程新增Python、PPT、H5………今年9月新学期,浙江省三到九年级的信息技术课将替换新教材。与老教材相比,新版教材更接地气,以后小学生就要学会做PPT、H5,开始接触算法、大数据等。据悉,这次教材的修订,是自2017年教育部发布高中信息技术新课标后,浙江省教研室组织省内教研员、骨干教师精心修撰的成果。近段时间,浙江省教研室组织小学和初中信息技术课老师,进行三到九年级新修订教材的培训。记者翻阅新教材大纲发现,从小学三年级一直到九…

    2022年5月16日
    56
  • 修改 css变量,通过CSS变量修改样式的方法示例

    修改 css变量,通过CSS变量修改样式的方法示例问题 js 怎么去修改 css 伪类样式呢 但是 js 并没有伪类选择器 那么该怎么办呢 网上有不少方法 比如通过切换元素的类 在 style 中动态插入新的样式等 那么这里再来一种方法 设置 css 变量 var 通过 js 去改变这个变量来实现 示例 改变 div 的 hover 背景色 root divHoverColo red div width 100px height 100px backgrou

    2025年9月23日
    3
  • 腾讯云— LAMP 架构个人实践分享

    腾讯云— LAMP 架构个人实践分享LAMP环境通常指Linux环境下,由Apache+MySQL/MariaDB+PHP以及其它相关组件组成的网站服务器架构。目前以LAMP组成的Web应用程序平台广泛被应用,70%以上的访问流量由LAMP提供,所以我们也认同LAMP是最强大的网站解决方案。关于LAMP的环境部署文档随处可搜,腾讯官网环境部署介绍可参阅:手动搭建LAMP环境:https://cloud.tencent.com/document/product/213/38402镜像部署LAMP环境:https://cl

    2022年10月16日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号