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

OpenCV 的模板匹配

OpenCV中的模板匹配

模板匹配(Template Matching)是计算机视觉中的一种技术,用于在大图像中找到与小图像(模板)相匹配的部分。OpenCV提供了多种模板匹配的方法,主要包括基于相关性和基于平方差的匹配方法。

1. 基本原理

模板匹配的基本原理是通过滑动模板图像(template)在源图像(source)上,计算每个位置的匹配得分,从而找到最匹配的位置。

2. 函数接口

在OpenCV中,模板匹配主要通过cv2.matchTemplate()函数来实现。其基本用法如下:

result = cv2.matchTemplate(image, template, method)
  • image: 源图像(在其中搜索匹配区域)。
  • template: 模板图像(需要匹配的图像部分)。
  • method: 匹配方法,常用的方法有:
    • cv2.TM_SQDIFF: 平方差匹配。
    • cv2.TM_SQDIFF_NORMED: 归一化平方差匹配。
    • cv2.TM_CCORR: 相关匹配。
    • cv2.TM_CCORR_NORMED: 归一化相关匹配。
    • cv2.TM_CCOEFF: 相关系数匹配。
    • cv2.TM_CCOEFF_NORMED: 归一化相关系数匹配。
3. 方法选择

不同的方法适用于不同的应用场景:

  • cv2.TM_SQDIFFcv2.TM_SQDIFF_NORMED: 适用于模板和图像之间的匹配误差较小时。
  • cv2.TM_CCORRcv2.TM_CCORR_NORMED: 适用于图像亮度变化不大的场景。
  • cv2.TM_CCOEFFcv2.TM_CCOEFF_NORMED: 适用于图像中存在线性亮度变化的情况。
4. 性能优化

模板匹配的计算复杂度较高,对于大图像和模板,计算时间可能较长。可以通过以下方法进行优化:

  • 调整模板图像的大小。
  • 使用多尺度匹配(Multi-Scale Matching),即在不同尺度下进行匹配。
  • 使用图像金字塔(Image Pyramid)技术减少计算量。

通过合理选择匹配方法和优化策略,可以有效提高模板匹配的效率和准确性。

以下是详细介绍模板匹配的相关内容:

基本步骤
  1. 读取图像和模板:
    使用 cv2.imread 函数读取原始图像和模板图像。

  2. 转换为灰度图像:
    使用 cv2.cvtColor 将图像转换为灰度图像。模板匹配通常在灰度图像上进行,以减少计算复杂度。

  3. 执行模板匹配:
    使用 cv2.matchTemplate 函数在原图像中搜索模板图像,并返回匹配结果。

  4. 设置阈值并找到匹配位置:
    使用 numpy 函数找到匹配结果中大于或等于阈值的位置。

  5. 绘制矩形框标记匹配区域:
    使用 cv2.rectangle 函数在原图像中绘制矩形框标记匹配区域。

  6. 显示结果:
    使用 matplotlib 或 OpenCV 显示结果图像。

详细代码示例
import cv2
import numpy as np
from matplotlib import pyplot as plt# Load the images
original_img = cv2.imread('images/test.png')
template_img = cv2.imread('images/test_target.jpg')# Convert to grayscale
original_gray = cv2.cvtColor(original_img, cv2.COLOR_BGR2GRAY)
template_gray = cv2.cvtColor(template_img, cv2.COLOR_BGR2GRAY)# Perform template matching
result = cv2.matchTemplate(original_gray, template_gray, cv2.TM_CCOEFF_NORMED)# Define threshold and find locations above the threshold
threshold = 0.8
loc = np.where(result >= threshold)# Draw rectangles around detected matches
for pt in zip(*loc[::-1]):cv2.rectangle(original_img, pt, (pt[0] + template_gray.shape[1], pt[1] + template_gray.shape[0]), (0, 0, 255), 2)# Display the result
plt.figure(figsize=(10, 10))
plt.imshow(cv2.cvtColor(original_img, cv2.COLOR_BGR2RGB))
plt.title('Detected Matches')
plt.axis('off')
plt.show()

运行结果如下:
在这里插入图片描述

下面是详细的中文解释:

import cv2
import numpy as np
from matplotlib import pyplot as plt

导入库

  • cv2:OpenCV库的Python接口,用于图像处理和计算机视觉。
  • numpy:数值计算库,用于处理多维数组。
  • pyplot:matplotlib库的一个子库,用于绘图和数据可视化。
# Load the images
original_img = cv2.imread('images/test.png')
template_img = cv2.imread('images/test_target.jpg')

加载图像

  • 使用 cv2.imread 函数读取图像文件,将原始图像保存到 original_img 变量中,将模板图像保存到 template_img 变量中。
  • 需要根据实际文件路径替换 ‘images/test.png’ 和 ‘images/test_target.jpg’。
# Convert to grayscale
original_gray = cv2.cvtColor(original_img, cv2.COLOR_BGR2GRAY)
template_gray = cv2.cvtColor(template_img, cv2.COLOR_BGR2GRAY)

转换为灰度图

  • 使用 cv2.cvtColor 函数将原始图像和模板图像从 BGR 色彩空间转换为灰度图,以简化后续的计算。
# Perform template matching
result = cv2.matchTemplate(original_gray, template_gray, cv2.TM_CCOEFF_NORMED)

执行模板匹配

  • 使用 cv2.matchTemplate 函数在灰度原图中搜索模板图像。
  • cv2.TM_CCOEFF_NORMED 是一种匹配方法,表示归一化的相关系数匹配。
# Define threshold and find locations above the threshold
threshold = 0.8
loc = np.where(result >= threshold)

定义阈值并找到匹配位置

  • 设置匹配结果的阈值 threshold 为 0.8,表示只有相关系数大于或等于 0.8 的位置才被认为是匹配的。
  • 使用 np.where 函数找到匹配结果矩阵中所有大于或等于阈值的位置,返回这些位置的坐标。
# Draw rectangles around detected matches
for pt in zip(*loc[::-1]):cv2.rectangle(original_img, pt, (pt[0] + template_gray.shape[1], pt[1] + template_gray.shape[0]), (0, 0, 255), 2)

绘制矩形框

  • 遍历所有检测到的匹配位置,并在原图上绘制矩形框。
  • zip(*loc[::-1]) 将匹配位置的坐标转换为 (x, y) 对,以便在图像上绘制矩形框。
  • cv2.rectangle 函数用于绘制矩形框:
    • 第一个参数是图像。
    • 第二个参数是矩形的左上角坐标。
    • 第三个参数是矩形的右下角坐标。
    • 第四个参数是矩形框的颜色,这里是红色 (0, 0, 255)
    • 第五个参数是矩形框的粗细,这里设置为 2。
# Display the result
plt.figure(figsize=(10, 10))
plt.imshow(cv2.cvtColor(original_img, cv2.COLOR_BGR2RGB))
plt.title('Detected Matches')
plt.axis('off')
plt.show()

显示结果

  • 使用 matplotlib 库显示带有矩形框的原图。
  • plt.figure 设置显示窗口的大小,这里是 10x10 英寸。
  • plt.imshow 显示图像,并将图像从 BGR 色彩空间转换为 RGB,以便正确显示颜色。
  • plt.title 设置图像的标题,这里是 ‘Detected Matches’。
  • plt.axis('off') 隐藏坐标轴,以便更好地显示图像。
  • plt.show 显示图像。

运行上述代码后,你会看到原始图像中标记出所有匹配模板的位置,每个匹配位置都会用红色矩形框标记出来。

模板匹配方法

OpenCV 提供了几种不同的模板匹配方法,可以通过 cv2.matchTemplate 函数的第三个参数指定:

  1. cv2.TM_SQDIFF: 平方差匹配法,计算平方差。数值越小越匹配。
  2. cv2.TM_SQDIFF_NORMED: 归一化平方差匹配法。
  3. cv2.TM_CCORR: 相关系数匹配法,计算相关系数。数值越大越匹配。
  4. cv2.TM_CCORR_NORMED: 归一化相关系数匹配法。
  5. cv2.TM_CCOEFF: 相关匹配法,计算相关值。数值越大越匹配。
  6. cv2.TM_CCOEFF_NORMED: 归一化相关匹配法。
示例中的关键函数
  • cv2.imread(filename, flags): 读取图像。
  • cv2.cvtColor(src, code): 转换颜色空间。
  • cv2.matchTemplate(image, templ, method): 执行模板匹配。
  • np.where(condition): 返回满足条件的数组索引。
  • cv2.rectangle(img, pt1, pt2, color, thickness): 绘制矩形框。
注意事项
  • 模板匹配是一个计算密集型任务,对于较大的图像和模板,计算时间会显著增加。
  • 匹配结果受图像噪声、旋转、缩放等因素的影响,因此在实际应用中,可能需要预处理图像或结合其他方法(如特征匹配)来提高准确性。
实际应用

模板匹配广泛应用于图像识别、物体检测等领域,例如:

  • 在游戏中检测特定图案或标志。
  • 在工业视觉系统中检测缺陷或零部件位置。
  • 在医学图像中检测特定器官或病变。

相关文章:

OpenCV 的模板匹配

OpenCV中的模板匹配 模板匹配(Template Matching)是计算机视觉中的一种技术,用于在大图像中找到与小图像(模板)相匹配的部分。OpenCV提供了多种模板匹配的方法,主要包括基于相关性和基于平方差的匹配方法。…...

26.0 Http协议

1. http协议简介 HTTP(Hypertext Transfer Protocol, 超文本传输协议): 是万维网(WWW: World Wide Web)中用于在服务器与客户端(通常是本地浏览器)之间传输超文本的协议.作为一个应用层的协议, HTTP以其简洁, 高效的特点, 在分布式超媒体信息系统中扮演着核心角色. 自1990年提…...

IO流打印流

打印流 IO流打印流是Java中用来将数据打印到输出流的工具。打印流提供了方便的方法来格式化和输出数据,可以用于将数据输出到控制台、文件或网络连接。 分类:打印流一般是指:PrintStream,PrintWriter两个类 特点1:打印流只操作文件目的地,…...

Cohere reranker 一致的排序器

这本notebook展示了如何在检索器中使用 Cohere 的重排端点。这是在 ContextualCompressionRetriever 的想法基础上构建的。 %pip install --upgrade --quiet cohere %pip install --upgrade --quiet faiss# OR (depending on Python version)%pip install --upgrade --quiet…...

MySQL系列-语法说明以及基本操作(二)

1、MySQL数据表的约束 1.1、MySQL主键 “主键(PRIMARY KEY)”的完整称呼是“主键约束”。 MySQL 主键约束是一个列或者列的组合,其值能唯一地标识表中的每一行。这样的一列或多列称为表的主键,通过它可以强制表的实体完整性。 …...

【STM32】步进电机及其驱动

设计和实现基于STM32微控制器的步进电机驱动系统是一个涉及硬件设计、固件编程和电机控制算法的复杂任务。以下是一个概要设计,包括一些基本的代码示例。 1. 硬件设计 1.1 微控制器选择 选择STM32系列微控制器,因为它提供了丰富的GPIO端口和足够的处理…...

Excel自定义排序和求和

概览 excel作为办公的常备工具,好记性不如烂笔头,在此梳理记录下,此篇文章主要是记录excel的自定义排序和求和 一. 自定义排序 举个例子 1. 填充自定义排序选项 实现步骤: 选定目标排序值;文件->选项->自定…...

若依RuoYi-Vue分离版—免登录直接访问

若依RuoYi-Vue分离版—免登录直接访问 如何不登录直接访问前端:后端:方法1:在SecurityConfig.java中设置httpSecurity配置匿名访问方法2:在对应的方法或类上面使用Anonymous注解。 如何不登录直接访问 官网有说明:如何不登录直接…...

java基础知识漏洞记录一

下面是我在阅读JavaGuide面试资料时遇到的不熟悉的知识点总结 JDK9中JRE与JDK新关系 从 JDK 9 开始,就不需要区分 JDK 和 JRE 的关系了,取而代之的是模块系统(JDK 被重新组织成 94 个模块) jlink 工具 (随 Java 9 一起发布的新命…...

html的网页制作代码分享

<!-- prj_8_2.html --> <!DOCTYPE html> <html lang "EN"><head><meta charset"utf-8" /><title>页面布局设计</title><style type "text/css">*{padding: 0px;margin:0px;}#header{back…...

【PIXEL】2024年 Pixel 解除 4G限制

首先在谷歌商店下载 Shizuku 和 pixel IMS 两个app 然后打开shizuku &#xff0c;按照它的方法启动 推荐用adb 启动&#xff08; 电脑连手机 &#xff0c;使用Qtscrcpy最简洁&#xff09; 一条指令解决 shell sh /storage/emulated/0/Android/data/moe.shizuku.privileged.ap…...

C#、C++、Java、Python 选择哪个好?

选择哪种编程语言取决于你的需求和偏好&#xff0c;以及你打算做什么类型的项目。我这里有一套编程入门教程&#xff0c;不仅包含了详细的视频 讲解&#xff0c;项目实战。如果你渴望学习编程&#xff0c;不妨点个关注&#xff0c;给个评论222&#xff0c;私信22&#xff0c;我…...

爬虫补环境,ES6 Class在环境模拟中的应用与优势

相比于使用传统的Object实现补环境框架结构&#xff0c;使用 ES6 的 Class 具有以下优势&#xff1a; 代码维护更方便&#xff1a;Class的语法更简洁直观&#xff0c;方便开发者阅读和维护。组织结构更清晰&#xff1a;Class提供了明确的层次结构&#xff0c;有助于代码的模块…...

linuxcentos将本地库JAR/arr批量导入到Nexus3.x

背景 我们现在要搞一个私服maven来管理对应的依赖包&#xff0c;需要上传包。用nexus只能单个文件搞&#xff0c;批量导入不行&#xff0c;而且还要单独配置groupID什么的。不多BB,上教程 建脚本 vi mavenimport.sh内容是这个 #!/bin/bash # copy and run this script to t…...

js之操作元素属性和定时器以及相关案例倒计时

这里写目录标题 一级目录二级目录三级目录 Web APIs01四、操作元素属性1.操作元素常用属性2.操作元素样式属性通过style属性操作css1.修改样式通过style属性引出2.如果属性有-连接符&#xff0c;需要转换为小驼峰命名法3.赋值的时候&#xff0c;需要的时候不要忘记加css单位 通…...

高考计算机专业 热门专业方向

人工智能&#xff08;AI&#xff09;&#xff1a;随着技术进步&#xff0c;人工智能成为计算机技术的新方向&#xff0c;涵盖自动驾驶、智能机器人、语音识别等应用。该领域对人才的需求持续增长&#xff0c;是计算机专业的一个热门方向。数据科学与大数据分析&#xff1a;随大…...

《web应用技术》第十一次作业

1、验证过滤器进行权限验证的原理。 代码展示&#xff1a; Slf4j WebFilter(urlPatterns "/*") public class LoginCheckFilter implements Filter { Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) thro…...

Scala学习笔记11: 操作符

目录 第十一章 操作符1- 标识符2- 中置操作符3- 一元操作符4- 赋值操作符5- 操作符的优先级6- 结合性7- apply和update方法8- 提取器end 第十一章 操作符 在Scala中, 操作符是用来执行特定操作的符号或符号组合 ; Scala允许开发人员自定义操作符, 这些操作符可以是字母、数字…...

项目五串行通信系统 任务5-3温度信息上传

任务描述&#xff1a;DS18B20测量温度&#xff0c;单片机采集温度数据转换显示代码&#xff0c;并通过串行口发送到上位机显示。 底层文件&#xff1a; /********************************************* ds18b20底层函数:能完成一次温度数据读取 ***************************…...

前端 JS 经典:统一 Vite 中图片转换逻辑

在 Vue Vite 项目中有这样一段代码如下&#xff0c;引入了两个图片&#xff0c;一大一小。然后 console 出来引入结果。 import bigImg from "./assets/big.png"; import smallImg from "./assets/small.png";console.log(bigImg); console.log(smallImg…...

在HarmonyOS ArkTS ArkUI-X 5.0及以上版本中,手势开发全攻略:

在 HarmonyOS 应用开发中&#xff0c;手势交互是连接用户与设备的核心纽带。ArkTS 框架提供了丰富的手势处理能力&#xff0c;既支持点击、长按、拖拽等基础单一手势的精细控制&#xff0c;也能通过多种绑定策略解决父子组件的手势竞争问题。本文将结合官方开发文档&#xff0c…...

MFC内存泄露

1、泄露代码示例 void X::SetApplicationBtn() {CMFCRibbonApplicationButton* pBtn GetApplicationButton();// 获取 Ribbon Bar 指针// 创建自定义按钮CCustomRibbonAppButton* pCustomButton new CCustomRibbonAppButton();pCustomButton->SetImage(IDB_BITMAP_Jdp26)…...

uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖

在前面的练习中&#xff0c;每个页面需要使用ref&#xff0c;onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入&#xff0c;需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...

微服务商城-商品微服务

数据表 CREATE TABLE product (id bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 商品id,cateid smallint(6) UNSIGNED NOT NULL DEFAULT 0 COMMENT 类别Id,name varchar(100) NOT NULL DEFAULT COMMENT 商品名称,subtitle varchar(200) NOT NULL DEFAULT COMMENT 商…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)

Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败&#xff0c;具体原因是客户端发送了密码认证请求&#xff0c;但Redis服务器未设置密码 1.为Redis设置密码&#xff08;匹配客户端配置&#xff09; 步骤&#xff1a; 1&#xff09;.修…...

HarmonyOS运动开发:如何用mpchart绘制运动配速图表

##鸿蒙核心技术##运动开发##Sensor Service Kit&#xff08;传感器服务&#xff09;# 前言 在运动类应用中&#xff0c;运动数据的可视化是提升用户体验的重要环节。通过直观的图表展示运动过程中的关键数据&#xff0c;如配速、距离、卡路里消耗等&#xff0c;用户可以更清晰…...

智能AI电话机器人系统的识别能力现状与发展水平

一、引言 随着人工智能技术的飞速发展&#xff0c;AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术&#xff0c;在客户服务、营销推广、信息查询等领域发挥着越来越重要…...

【JVM】Java虚拟机(二)——垃圾回收

目录 一、如何判断对象可以回收 &#xff08;一&#xff09;引用计数法 &#xff08;二&#xff09;可达性分析算法 二、垃圾回收算法 &#xff08;一&#xff09;标记清除 &#xff08;二&#xff09;标记整理 &#xff08;三&#xff09;复制 &#xff08;四&#xff…...

uniapp 字符包含的相关方法

在uniapp中&#xff0c;如果你想检查一个字符串是否包含另一个子字符串&#xff0c;你可以使用JavaScript中的includes()方法或者indexOf()方法。这两种方法都可以达到目的&#xff0c;但它们在处理方式和返回值上有所不同。 使用includes()方法 includes()方法用于判断一个字…...

系统掌握PyTorch:图解张量、Autograd、DataLoader、nn.Module与实战模型

本文较长&#xff0c;建议点赞收藏&#xff0c;以免遗失。更多AI大模型应用开发学习视频及资料&#xff0c;尽在聚客AI学院。 本文通过代码驱动的方式&#xff0c;系统讲解PyTorch核心概念和实战技巧&#xff0c;涵盖张量操作、自动微分、数据加载、模型构建和训练全流程&#…...