模板匹配应用(opencv的妙用)

news/2024/9/18 13:38:56/ 标签: opencv, 人工智能, 计算机视觉

在图像处理领域,模板匹配是一种常用的技术,用于在一幅大图中寻找与给定模板最匹配的区域。OpenCV作为一个强大的计算机视觉库,提供了cv2.matchTemplate()函数来实现模板匹配功能。本文将详细介绍OpenCV中的模板匹配技术,包括其原理、使用方法以及实际应用场景。

目录

模板匹配原理

匹配方法

使用方法

加载图像

模板匹配

查找匹配位置

绘制匹配结果


模板匹配原理

模板匹配的基本思想是将模板图像在目标图像上滑动,并计算每个位置的相似度。通过比较模板图像与目标图像对应区域的相似度,找到相似度最高的位置即为匹配位置。模板匹配的计算方法有多种,OpenCV中提供了六种不同的匹配方法。

匹配方法

  1. TM_SQDIFF:计算平方差,值越小表示越相关。
  2. TM_SQDIFF_NORMED:归一化平方差匹配,值越接近0表示越相关。
  3. TM_CCORR:计算相关性,值越大表示越相关。
  4. TM_CCORR_NORMED:归一化相关性匹配,值越接近1表示越相关。
  5. TM_CCOEFF:计算相关系数,值越大表示越相关。
  6. TM_CCOEFF_NORMED:归一化相关系数匹配,值越接近1表示越相关。

使用方法

加载图像

首先,需要加载目标图像和模板图像。使用cv2.imread()函数读取图像文件。

import cv2  # 加载目标图像和模板图像  
target_img = cv2.imread('target.jpg')  
template_img = cv2.imread('template.jpg')

模板匹配

然后,使用cv2.matchTemplate()函数进行模板匹配。该函数会返回一个匹配结果矩阵,矩阵中的每个元素表示模板图像在目标图像上对应位置的匹配程度。

# 使用平方差匹配算法  
result = cv2.matchTemplate(target_img, template_img, cv2.TM_SQDIFF)

查找匹配位置

通过cv2.minMaxLoc()函数在匹配结果矩阵中找到最小值(对于平方差匹配)或最大值(对于其他匹配方法)的位置,即为匹配位置。

# 查找最小值及其位置  
min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result)  # 对于平方差匹配,取最小值位置  
top_left = min_loc  # 计算匹配区域的右下角坐标  
bottom_right = (top_left[0] + template_img.shape[1], top_left[1] + template_img.shape[0])

绘制匹配结果

最后,在目标图像上绘制矩形框来表示匹配位置。

# 绘制矩形框  
cv2.rectangle(target_img, top_left, bottom_right, (0, 255, 0), 2)  # 显示结果图像  
cv2.imshow('Result', target_img)  
cv2.waitKey(0)  
cv2.destroyAllWindows()

实例:

import cv2
import numpy as npimg_rgb = cv2.imread('example.jpg')
img_gray = cv2.cvtColor(img_rgb, cv2.COLOR_BGR2GRAY)
tem = cv2.imread('jiant.jpg', 0)
for i in [0, 1, 2, 3]:#通过循环,使用 np.rot90(tem, i) 对模板图像进行旋转,其中 i 的值从0到3变#化,分别对应0度、90度、180度、270度的旋转。template = np.rot90(tem, i)h, w = template.shape[:2]res = cv2.matchTemplate(img_gray, template, cv2.TM_CCOEFF_NORMED)#对每次旋转后的模板图像,使用 cv2.matchTemplate() 函数在 img_gray(灰度目标图像)上进行模板匹
#配。这里使用的是 cv2.TM_CCOEFF_NORMED 方法,它计算归一化相关系数,值越接近1表示匹配度越高。threshold = 0.9#通过设置阈值 threshold = 0.9,筛选出匹配度大于或等于该阈值的所有位置。loc = np.where(res >= threshold)
#使用 np.where(res >= threshold) 找到这些位置,并使用 zip(*loc[::-1]) 转换坐标格式,因为 loc 返#回的是 (y, x) 坐标,而 OpenCV 中的图像坐标是 (x, y)。for pt in zip(*loc[::-1]):cv2.rectangle(img_rgb, pt, (pt[0] + w, pt[1] + h), (0, 0, 255), 1)
#使用 cv2.imshow('res', img_rgb) 显示标记了匹配区域的图像。
cv2.imshow('res', img_rgb)
cv2.waitKey(0)
cv2.destroyAllWindows()

结果:


http://www.ppmy.cn/news/1524950.html

相关文章

qmt量化交易策略小白学习笔记第64期【qmt编程之获取获取期权全推数据--code_list全推tick数据】

qmt编程之获取期权数据 qmt更加详细的教程方法,会持续慢慢梳理。 也可找寻博主的历史文章,搜索关键词查看解决方案 ! 获取期权全推数据 获取全推tick数据的函数是用户主动调用的工具。所谓"全推tick数据",指的是以t…

Android 应用使用theme处理全局焦点框

背景 我的应用有个需求,要求处理keycode事件,进行焦点移动处理,必须定制指定的焦点框。而系统的焦点框是固定了,为了保证平台的一致性,没办法直接修改。 问题 经过沟通,大部分都是自行修改了自己的backg…

ARM base instruction -- cset

CSET Conditional Set sets the destination register to 1 if the condition is TRUE, and otherwise sets it to 0. 如果条件为TRUE&#xff0c;则条件集将目标寄存器设置为1&#xff0c;否则设置为0。 32-bit variant Applies when sf 0. CSET <Wd>, <…

Spark MLlib模型训练—推荐算法 ALS(Alternative Least Squares)

Spark MLlib模型训练—推荐算法 ALS(Alternative Least Squares) 如果你平时爱刷抖音,或者热衷看电影,不知道有没有过这样的体验:这类影视 App 你用得越久,它就好像会读心术一样,总能给你推荐对胃口的内容。其实这种迎合用户喜好的推荐,离不开机器学习中的推荐算法。 在…

SimPO

添加链接描述 优化点两个&#xff1a; gamma长度正则 gamma 原始DPO把两部分母拿出来是 − l o g π r e f ( w i n ) π r e f ( l o s e ) -log \frac{\pi_{ref}(win)}{\pi_{ref}(lose)} −logπref​(lose)πref​(win)​ 由于构建数据集时常常把不满意的大模型输出作为…

操作系统 ---- 调度算法【先来先服务(FCFS)、最短作业优先(SJF)、最高响应比优先(HRRN)】

目录 一、常见的调度算法 1. 先来先服务&#xff08;FCFS, First-Come, First-Served&#xff09; 2. 最短作业优先&#xff08;SJF, Shortest Job First&#xff09; 3. 优先级调度&#xff08;Priority Scheduling algorithm&#xff0c;PSA&#xff09; 4. 轮转调度&am…

python 函数 封装

封装 函数的参数是&#xff1a;变量 def 函数(参数):print(参数)if __name__ __main__:函数(参数)函数(参数2)函数的参数是&#xff1a; 字典 import requests# 定义一个字典 data {} 地址 "https://webdriveruniversity.com/" 请求方法 getdata["url"…

Hi3519DV500_Uboot环境变量的编译和烧录

Hi3519DV500_Uboot环境变量的编译和烧录 U-Boot 环境变量在嵌入式系统的引导加载程序中扮演着重要的角色。它们用于存储系统启动时所需的配置信息&#xff0c;如启动命令、内核和根文件系统的位置、串口波特率等。以下是一些常用的 U-Boot 环境变量及其用途&#xff1a; bootde…

安宝特案例 | AR如何大幅提升IC封装厂检测效率?

前言&#xff1a;如何提升IC封装厂检测效率&#xff1f; 在现代电子产品的制造过程中&#xff0c;IC封装作为核心环节&#xff0c;涉及到复杂处理流程和严格质量检测。这是一家专注于IC封装的厂商&#xff0c;负责将来自IC制造商的晶圆进行保护、散热和导通处理。整个制程繁琐…

使用vuex模仿el-table

1、vuex 在main.js引入 import Vue from vue; import Vuex from vuex;Vue.use(Vuex);const store new Vuex.Store({state: {// 定义要传递的数据datas: []},mutations: {// 定义修改数据的 mutationSET_DATAS(state, newDatas) {state.datas newDatas;}},actions: {// 定义…

Java面试篇基础部分-Java的类加载机制

JVM的类加载 JVM在运行Java文件的时候,类加载分为5个阶段:加载、验证、准备、解析、初始化。在类初始化加载完成之后,就可以使用这个类的信息了。当这个类不需要使用的时候,就可以从JVM进行卸载。 加载 加载是指JVM读取Class文件的操作,并且根据Class的文件描述创建对应的…

聚鼎科技:现在做装饰画是靠谱的吗

在生活的各个角落&#xff0c;艺术以多种形式存在着&#xff0c;而装饰画作为其中的一种&#xff0c;一直以其独特的魅力填充着我们的世界。但在这个快速变化的时代&#xff0c;许多人会问&#xff1a;现在做装饰画还是一个靠谱的选择吗? 装饰画的市场依旧充满生机。随着人们对…

Java ssm超市订单管理系统(详细文档)

学生选课系统论文 摘要 随着互联网趋势的到来&#xff0c;各行各业都在考虑利用互联网将自己推广出去&#xff0c;最好方式就是建立自己的互联网系统&#xff0c;并对其进行维护和管理。在现实运用中&#xff0c;应用软件的工作规则和开发步骤&#xff0c;采用Java技术建设小…

Linux从入门到开发实战(C/C++)Day10-线程

1.概念&#xff1a; 线程是一个函数&#xff0c;是os调度的基本单位 Linux内核在2.2版本之前&#xff0c;是没有线程的概念&#xff0c;只有有限个进程&#xff08;4096&#xff09; 在2.4版本中&#xff0c;有了线程的概念&#xff0c;而且可…

安全工具 | 使用Burp Suite的10个小tips

Burp Suite 应用程序中有用功能的集合 img Burp Suite 是一款出色的分析工具&#xff0c;用于测试 Web 应用程序和系统的安全漏洞。它有很多很棒的功能可以在渗透测试中使用。您使用它的次数越多&#xff0c;您就越发现它的便利功能。 本文内容是我在测试期间学到并经常的主要…

配环境时的一些记录

连centos&#xff1a;正常连就好&#xff08;密码验证码&#xff09;连rocky&#xff1a;需要在centos上连&#xff0c;终端里直接ssh [rocky_ip]&#xff1b;在vscode中需要&#xff1a; 修改配置文件&#xff1a;打开命令面板&#xff08;ctrlshiftp&#xff09; -> 输入并…

Android命令行查看CPU频率和温度

在 Android 设备上&#xff0c;你可以通过命令行工具 adb 来查看 CPU 温度和 CPU 频率&#xff0c;并确定是否有降频情况。以下是具体步骤&#xff1a; 1. 查看 CPU 频率 你可以使用以下命令来查看 CPU 各个核心的当前频率&#xff1a; adb shell cat /sys/devices/system/c…

基于Spring Boot的旧物置换网站

构建一个基于Spring Boot的旧物置换网站是一个很好的项目&#xff0c;可以帮助你学习如何设计和实现一个完整的Web应用程序。以下是一个简化版的示例&#xff0c;展示了如何搭建这样一个系统的框架。 1. 创建Spring Boot项目 首先&#xff0c;你需要创建一个新的Spring Boot项…

VUE,element-ui,优化tabs组件每次点击,所有子页面都重新渲染问题

1.在data中定义每个子组件相应的值&#xff0c;ture为加载&#xff0c;false为不加载。 2.在子组件中使用v-if来判断是否渲染当前页面 3.在函数中对子组件的值进行切换。 handleClick(){if(this.activeNamefirst){this.pageOne truethis.pageTwo false}else if(this.active…

如何识别和防范跨站请求伪造(CSRF)?

识别和防范跨站请求伪造&#xff08;CSRF&#xff09;的关键在于理解其攻击原理并采取相应的措施。以下是一些识别和防范CSRF的方法&#xff1a; 识别CSRF的方法&#xff1a; 异常请求&#xff1a;留意网站中是否有意外的GET或POST请求&#xff0c;尤其是那些涉及到敏感操作&a…