当前位置: 首页 > news >正文

python学opencv|读取图像(五十二)使用cv.matchTemplate()函数实现最佳图像匹配

【1】引言

前序学习了图像的常规读取和基本按位操作技巧,相关文章包括且不限于:

python学opencv|读取图像-CSDN博客

python学opencv|读取图像(四十九)原理探究:使用cv2.bitwise()系列函数实现图像按位运算-CSDN博客

实际上都还是简单的图像操作,在此基础上,我们尝试对图像进行识别。比如在一堆图像里,找出和模板图像最相似的目标图像,这就是本次文章想要学习的目标: cv.matchTemplate()函数。

【2】官网教程

点击下方链接,直达cv.matchTemplate()函数的官网教程:

OpenCV: Object Detection

官网对cv.matchTemplate()函数的解释为:

图1 cv.matchTemplate()函数的官网教程 

官网对cv.matchTemplate()函数的参数解释为:

void cv::matchTemplate     (    

        InputArray     image,                    #供匹配的图像
        InputArray     templ,                     #匹配参照的模板
        OutputArray     result,                  #匹配结果
        int     method,                              #匹配方法
        InputArray     mask = noArray() ) #掩模矩阵,默认即可,不是此次重点

为对匹配效果进行标记,还需要读取匹配结果,使用cv2.minMaxLoc()函数,点击下方链接可以直达官网说明页面:

OpenCV: Operations on arrays

官网对cv2.minMaxLoc()函数说明页面的相关解释为:

图2 cv.minMaxLoc()函数的官网教程 

 官网对cv.matchTemplate()函数的参数解释为:

void cv::minMaxLoc     (    

        const SparseMat &     a,   #输入数据
        double *     minVal,           #最小值
        double *     maxVal,          #最大值
        int *     minIdx = 0,            #最小坐标
        int *     maxIdx = 0 )          #最大坐标

【3】代码测试

首先引入相关模块和图像:

import cv2 as cv # 引入CV模块
import numpy as np #引入numpy模块# 读取图片
srcm = cv.imread('srcm.png') #读取图像srcx.png
srcg = cv.imread('srcg.png') #读取图像srcp.png
srcc = cv.imread('srcc.png') #读取图像srcp.png
rows,cols,cans=srcg.shape #读取图像属性
rowsc,colsc,cansc=srcc.shape #读取图像属性

在这里,以srcm为待匹配图像,srcg和srcc为模板图像,也就是需要匹配两个。

然后进行图像匹配操作:

#匹配结果
results=cv.matchTemplate(srcm,srcg,cv.TM_CCORR_NORMED)
results1=cv.matchTemplate(srcm,srcc,cv.TM_CCORR_NORMED)

之后读取匹配结果以备做标记:

#取值
minValue,maxValue,minLoc,maxLoc=cv.minMaxLoc(results)
minValuec,maxValuec,minLocc,maxLocc=cv.minMaxLoc(results1)

做标记一般用方框,所以需要调用cv2.rectangle()函数。相关文章的学习链接为:python学opencv|读取图像(十九)使用cv2.rectangle()绘制矩形-CSDN博客

这个函数要两个坐标点,所以还需要自定义新的坐标点:

#取最大坐标
resultPoint1=maxLoc
print("resultPoint1=",resultPoint1)#取最大坐标
resultPoint2=maxLocc
print("resultPoint2=",resultPoint2)#定义新坐标
resultPoint3=(resultPoint1[0]+cols,resultPoint1[1]+rows)
print("resultPoint3=",resultPoint3)#定义新坐标
resultPoint4=(resultPoint2[0]+colsc,resultPoint2[1]+rowsc)
print("resultPoint3=",resultPoint3)

之后及时做标记、显示匹配效果:

#作标记
cv.circle(srcm,(250,250),30,(0,255,0))
cv.rectangle(srcm,resultPoint1,resultPoint3,(0,255,0),2)
cv.rectangle(srcm,resultPoint2,resultPoint4,(200,180,55),2)# 显示结果
cv.imshow('srcm ', srcm)
cv.imshow('srcg ', srcg)
cv.imshow('srcc ', srcc)#窗口控制
cv.waitKey()  # 图像不关闭
cv.destroyAllWindows()  # 释放所有窗口

程序运行相关的图像有:

图3 srcm.png

图4 模板srcg.png 

图5 模板srcc.png 

图6 匹配效果srcgc.png

图6为程序运行后的匹配效果,可见猫猫头和女孩都匹配成功了。

【4】细节说明

图6中给猫猫头增加了一个圆圈标记,是为了增强对照,增加圆圈标记的相关文章链接为:

python学opencv|读取图像(二十一)使用cv2.circle()绘制圆形进阶_opencv circle-CSDN博客

【5】总结

掌握了python+opencv实现使用cv.matchTemplate()函数实现最佳图像匹配的技巧。

 

http://www.lryc.cn/news/530933.html

相关文章:

  • 通信方式、点对点通信、集合通信
  • TCP编程
  • OpenAI 实战进阶教程 - 第七节: 与数据库集成 - 生成 SQL 查询与优化
  • Apache Iceberg数据湖技术在海量实时数据处理、实时特征工程和模型训练的应用技术方案和具体实施步骤及代码
  • QT交叉编译环境搭建(Cmake和qmake)
  • Turing Complete-成对的麻烦
  • 寒假刷题Day20
  • deepseek 本地化部署和小模型微调
  • 【Java异步编程】基于任务类型创建不同的线程池
  • makailio-alias_db模块详解
  • 文字显示省略号
  • [LeetCode] 字符串完整版 — 双指针法 | KMP
  • 从零开始部署Dify:后端与前端服务完整指南
  • springboot中路径默认配置与重定向/转发所存在的域对象
  • 二叉树——429,515,116
  • Leetcode 3444. Minimum Increments for Target Multiples in an Array
  • 分享半导体Fab 缺陷查看系统,平替klarity defect系统
  • Java基础——分层解耦——IOC和DI入门
  • DeepSeek-R1 本地部署教程(超简版)
  • Vue3学习笔记-模板语法和属性绑定-2
  • csapp笔记3.6节——控制(1)
  • PYH与MAC的桥梁MII/MIIM
  • 国内flutter环境部署(记录篇)
  • 选择排序_75. 颜色分类
  • C++ Primer 标准库vector
  • C# 数组和列表的基本知识及 LINQ 查询
  • 大厂面试题备份20250201
  • w191教师工作量管理系统的设计与实现
  • Git 版本控制:基础介绍与常用操作
  • 讲清逻辑回归算法,剖析其作为广义线性模型的原因