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_SQDIFF
和cv2.TM_SQDIFF_NORMED
: 适用于模板和图像之间的匹配误差较小时。cv2.TM_CCORR
和cv2.TM_CCORR_NORMED
: 适用于图像亮度变化不大的场景。cv2.TM_CCOEFF
和cv2.TM_CCOEFF_NORMED
: 适用于图像中存在线性亮度变化的情况。
4. 性能优化
模板匹配的计算复杂度较高,对于大图像和模板,计算时间可能较长。可以通过以下方法进行优化:
- 调整模板图像的大小。
- 使用多尺度匹配(Multi-Scale Matching),即在不同尺度下进行匹配。
- 使用图像金字塔(Image Pyramid)技术减少计算量。
通过合理选择匹配方法和优化策略,可以有效提高模板匹配的效率和准确性。
以下是详细介绍模板匹配的相关内容:
基本步骤
-
读取图像和模板:
使用cv2.imread
函数读取原始图像和模板图像。 -
转换为灰度图像:
使用cv2.cvtColor
将图像转换为灰度图像。模板匹配通常在灰度图像上进行,以减少计算复杂度。 -
执行模板匹配:
使用cv2.matchTemplate
函数在原图像中搜索模板图像,并返回匹配结果。 -
设置阈值并找到匹配位置:
使用numpy
函数找到匹配结果中大于或等于阈值的位置。 -
绘制矩形框标记匹配区域:
使用cv2.rectangle
函数在原图像中绘制矩形框标记匹配区域。 -
显示结果:
使用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
函数的第三个参数指定:
- cv2.TM_SQDIFF: 平方差匹配法,计算平方差。数值越小越匹配。
- cv2.TM_SQDIFF_NORMED: 归一化平方差匹配法。
- cv2.TM_CCORR: 相关系数匹配法,计算相关系数。数值越大越匹配。
- cv2.TM_CCORR_NORMED: 归一化相关系数匹配法。
- cv2.TM_CCOEFF: 相关匹配法,计算相关值。数值越大越匹配。
- 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 ,按照它的方法启动 推荐用adb 启动( 电脑连手机 ,使用Qtscrcpy最简洁) 一条指令解决 shell sh /storage/emulated/0/Android/data/moe.shizuku.privileged.ap…...
C#、C++、Java、Python 选择哪个好?
选择哪种编程语言取决于你的需求和偏好,以及你打算做什么类型的项目。我这里有一套编程入门教程,不仅包含了详细的视频 讲解,项目实战。如果你渴望学习编程,不妨点个关注,给个评论222,私信22,我…...
爬虫补环境,ES6 Class在环境模拟中的应用与优势
相比于使用传统的Object实现补环境框架结构,使用 ES6 的 Class 具有以下优势: 代码维护更方便:Class的语法更简洁直观,方便开发者阅读和维护。组织结构更清晰:Class提供了明确的层次结构,有助于代码的模块…...
linuxcentos将本地库JAR/arr批量导入到Nexus3.x
背景 我们现在要搞一个私服maven来管理对应的依赖包,需要上传包。用nexus只能单个文件搞,批量导入不行,而且还要单独配置groupID什么的。不多BB,上教程 建脚本 vi mavenimport.sh内容是这个 #!/bin/bash # copy and run this script to t…...
js之操作元素属性和定时器以及相关案例倒计时
这里写目录标题 一级目录二级目录三级目录 Web APIs01四、操作元素属性1.操作元素常用属性2.操作元素样式属性通过style属性操作css1.修改样式通过style属性引出2.如果属性有-连接符,需要转换为小驼峰命名法3.赋值的时候,需要的时候不要忘记加css单位 通…...
高考计算机专业 热门专业方向
人工智能(AI):随着技术进步,人工智能成为计算机技术的新方向,涵盖自动驾驶、智能机器人、语音识别等应用。该领域对人才的需求持续增长,是计算机专业的一个热门方向。数据科学与大数据分析:随大…...
《web应用技术》第十一次作业
1、验证过滤器进行权限验证的原理。 代码展示: 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温度信息上传
任务描述:DS18B20测量温度,单片机采集温度数据转换显示代码,并通过串行口发送到上位机显示。 底层文件: /********************************************* ds18b20底层函数:能完成一次温度数据读取 ***************************…...
前端 JS 经典:统一 Vite 中图片转换逻辑
在 Vue Vite 项目中有这样一段代码如下,引入了两个图片,一大一小。然后 console 出来引入结果。 import bigImg from "./assets/big.png"; import smallImg from "./assets/small.png";console.log(bigImg); console.log(smallImg…...
DOM-获取元素
获取元素的方法: 方法一:根据id获取元素document.getElementById <div id"time">2024-6-4</div> 在script标签中:注意getElementById括号里面必须要有引号,获得的是对象类型 var timer document.getEle…...
【安装笔记-20240612-Linux-内网穿透服务之cpolar极点云】
安装笔记-系列文章目录 安装笔记-20240612-Linux-内网穿透服务之 cpolar 极点云 文章目录 安装笔记-系列文章目录安装笔记-20240612-Linux-内网穿透服务之 cpolar 极点云 前言一、软件介绍名称:cpolar极点云主页官方介绍 二、安装步骤测试版本:openwrt-…...
Java 泛型与集合的深入解析:原理、应用与实践
泛型的基本原理 为什么需要泛型 在Java 5之前,Java的集合类只能存储Object类型的对象。这意味着,存储在集合中的对象在取出时需要进行类型转换,这不仅繁琐,而且容易出错。泛型通过在编译时进行类型检查,确保类型安全…...
Oracle 数据库的自动化工具:AWR 和 ASM
Oracle 数据库提供了一系列工具和技术,以提高数据库管理的效率和性能。其中,AWR和 ASM是两个关键组件。本文将详细介绍 AWR 和 ASM 的功能及其在数据库管理中的重要性。 AWR AWR 是 Oracle 数据库的一个核心部分,用于收集、处理和维护数据库…...
java技术专家面试指南50问【java学习+面试宝典】(五)
Dubbo需要 Web 容器吗? 不需要,如果硬要用 Web 容器,只会增加复杂性,也浪费资源。 一个字符串类型的值能存储最大容量是多少? 512M 什么是Kubectl? Kubectl是一个平台,您可以使用该平台将命…...
Elasticsearch之深入聚合查询
1、正排索引 1.1 正排索引(doc values )和倒排索引 概念:从广义来说,doc values 本质上是一个序列化的 列式存储 。列式存储 适用于聚合、排序、脚本等操作,所有的数字、地理坐标、日期、IP 和不分词( no…...
大模型:分本分割模型
目录 一、文本分割 二、BERT文本分割模型 三、部署模型 3.1 下载模型 3.2 安装依赖 3.3 部署模型 3.4 运行服务 四、测试模型 一、文本分割 文本分割是自然语言处理中的一项基础任务,目标是将连续的文本切分成有意义的片段,这些片段可以是句子、…...
数据预处理 #数据挖掘 #python
数据分析中的预处理步骤是数据分析流程中的重要环节,它的目的是清洗、转换和整理原始数据,以便后续的分析能够准确、有效。预处理通常包括以下几个关键步骤: 数据收集:确定数据来源,可能是数据库、文件、API或网络抓取…...
VS2022 使用C++访问 mariadb 数据库
首先,下载 MariaDB Connector/C++ 库 MariaDB Products & Tools Downloads | MariaDB 第二步,安装后 第三步,写代码 #include <iostream> #include <cstring> #include <memory> #include <windows.h>#include <mariadb/conncpp.hpp>…...
kotlin 语法糖
Use of “when” Expression Instead of “switch” fun getDayOfWeek(day: Int): String {return when (day) {1 -> "Monday"2 -> "Tuesday"3 -> "Wednesday"4 -> "Thursday"5 -> "Friday"6 -> "Sa…...
哪些做图形推理的网站/有什么好的网站吗
请以尽量高效的方法用”*”打印出一个空心正方形,num为边长。 void print_square(int num); #include <stdio.h>int main() {int x,y,num;printf("please input the num:\n");scanf("%d",&num);for(x 0; x < num; x){for(y 0 ;…...
重庆景点排名前十/seo推广软件费用
《Oracle PL/SQL实战》基本信息作者: (英)比林顿(Billington,A)等著,卢涛 [作译者介绍]出版社:人民邮电出版社ISBN:9787115294852上架时间:2012-10-27出版日期:2012 年11月开本:16开页码&#x…...
做vip视频网站侵权/百度人工客服电话
思路: for example: [1,1,3,1] 1.用一个fast和slow指针分别指向表头, 1->1->3->1 sf指针2.快速移动fast指针到表尾,slow指针到表中 1->1->3->1->nulls f 3.用fast指针指向表头,在反转slow开始指向…...
如何找到能够建设网站的人/西安疫情最新消息
最近非常忙,所以没坚持看书。这样下去这本书怕是又要专门的时间收尾了,今天午睡醒的早,三四节才有课就快速得把基本概念过一下。其实这些类似背景现状的东西,平时大抵是不看的,但因为IMS对我而言是个全新的概念&#x…...
地产公司做网站维护写代码么/北京seo技术交流
1.在solaris 10中,用户密码文件存在在哪个文件中?/etc/passwd/etc/shadow/etc/security/passwd/etc/password2.安装IIS的系统上,IWAM_前缀的用户名默认隶属于哪个用户组?administratorsIisusersusersguests3.下面对Oracle的密码规…...
网站建设素材网页/2021年10月新闻摘抄
怎么个图论法??这题一读完题一直没有思路,不知道和图论有什么关系,倒是一开始就想到了暴力,但是见数据的规模,怕暴力会超时所以就没写一直歇了两天,没思路去找解题保报告,看了几下&a…...