Python+OpenCV系列:模版匹配

文章目录

        • 1. 模板匹配基本原理
        • 2. `cv2.matchTemplate()` 函数
          • 函数原型:
        • 3. 模板匹配步骤
        • 4. 单目标模板匹配示例
        • 5. 多目标模板匹配
          • 多目标模板匹配示例
          • 代码解析:
        • 6. 多模板匹配
          • 多模板匹配示例
          • 代码解析
        • 7. 总结

模板匹配是一种在图像中寻找模板的位置的方法。在计算机视觉中,模板匹配广泛应用于目标识别、物体跟踪、缺陷检测等领域。OpenCV 提供了强大的模板匹配功能,可以非常方便地在目标图像中找到与模板图像相似的区域。本文将详细讲解如何使用 Python 和 OpenCV 进行单目标和多目标模板匹配,包含多模板匹配的技巧。


1. 模板匹配基本原理

模板匹配的基本思想是将模板图像滑动到目标图像的不同位置,计算每个位置的匹配度,选择匹配度最高的位置。匹配度通常是通过计算模板图像与目标区域的相似度来评估的。常见的匹配方法包括:

  • 平方差(SSD)
  • 相关性(CCOEFF)
  • 归一化互相关(CCOEFF_NORMED)
  • 平方差归一化(SQDIFF_NORMED)

这些方法通过不同的计算方式,适应不同的图像匹配需求。


2. cv2.matchTemplate() 函数

OpenCV 提供的 cv2.matchTemplate() 函数用于执行模板匹配。它接收目标图像和模板图像作为输入,并返回一个结果图像,该图像的每个像素值表示模板在该位置的匹配度。

函数原型:
result = cv2.matchTemplate(image, template, method)
  • image:目标图像(通常是灰度图像)。
  • template:模板图像(通常是灰度图像)。
  • method:匹配方法,常见方法有:
    • cv2.TM_CCOEFF
    • cv2.TM_CCOEFF_NORMED
    • cv2.TM_SQDIFF
    • cv2.TM_SQDIFF_NORMED
3. 模板匹配步骤
  1. 读取图像和模板:读取目标图像和模板图像。
  2. 转换为灰度图像:模板匹配通常在灰度图像上进行。
  3. 使用模板匹配:调用 cv2.matchTemplate() 执行匹配操作。
  4. 获取匹配结果:使用 cv2.minMaxLoc() 获取匹配结果的位置和相似度。
  5. 绘制矩形框:标记模板在目标图像中的匹配区域。

4. 单目标模板匹配示例
import cv2
import numpy as np# 读取图像和模板
img = cv2.imread('image.jpg', cv2.IMREAD_GRAYSCALE)
template = cv2.imread('template.jpg', cv2.IMREAD_GRAYSCALE)# 执行模板匹配
result = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)# 获取匹配结果的最小值、最大值和位置
min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result)# 绘制矩形框标记最佳匹配位置
top_left = max_loc
h, w = template.shape
bottom_right = (top_left[0] + w, top_left[1] + h)
cv2.rectangle(img, top_left, bottom_right, (0, 255, 0), 2)# 显示匹配结果
cv2.imshow('Matched Image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
5. 多目标模板匹配

在实际应用中,常常需要在图像中寻找多个模板或多个目标。这时可以通过遍历匹配结果来定位多个匹配位置。

多目标匹配的实现步骤

  1. 使用 cv2.matchTemplate() 对目标图像和模板进行匹配。
  2. 使用 cv2.threshold() 设定一个阈值,从结果图像中筛选出匹配度较高的区域。
  3. 通过遍历匹配结果,提取出多个匹配区域的位置。
多目标模板匹配示例
import cv2
import numpy as np# 读取图像和模板
img = cv2.imread('image.jpg', cv2.IMREAD_GRAYSCALE)
template = cv2.imread('template.jpg', cv2.IMREAD_GRAYSCALE)# 执行模板匹配
result = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)# 设置匹配的阈值
threshold = 0.8
locations = np.where(result >= threshold)# 遍历所有匹配的位置,绘制矩形框
w, h = template.shape[::-1]
for pt in zip(*locations[::-1]):cv2.rectangle(img, pt, (pt[0] + w, pt[1] + h), (0, 255, 0), 2)# 显示匹配结果
cv2.imshow('Multiple Matched Image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
代码解析:
  • np.where(result >= threshold):找到所有匹配度大于等于设定阈值的匹配位置。
  • zip(*locations[::-1]):将结果数组的位置反转,以便于绘制矩形框。
  • cv2.rectangle():在每个匹配位置绘制矩形框。

6. 多模板匹配

当我们有多个模板需要在图像中进行匹配时,可以通过循环处理每个模板进行匹配。每次循环都使用 cv2.matchTemplate() 对图像进行模板匹配,找出所有匹配的区域。

多模板匹配示例
import cv2
import numpy as np# 读取图像
img = cv2.imread('image.jpg', cv2.IMREAD_GRAYSCALE)# 模板列表
templates = ['template1.jpg', 'template2.jpg', 'template3.jpg']# 循环处理每个模板
for template_path in templates:# 读取当前模板template = cv2.imread(template_path, cv2.IMREAD_GRAYSCALE)# 执行模板匹配result = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)# 设置匹配的阈值threshold = 0.8locations = np.where(result >= threshold)# 遍历所有匹配的位置,绘制矩形框w, h = template.shape[::-1]for pt in zip(*locations[::-1]):cv2.rectangle(img, pt, (pt[0] + w, pt[1] + h), (0, 255, 0), 2)# 显示匹配结果
cv2.imshow('Multiple Templates Matched', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
代码解析
  • templates:多个模板文件的路径列表。
  • 每次循环读取不同的模板并进行模板匹配。
  • 对每个模板的匹配结果,使用 np.where() 提取所有匹配位置。

7. 总结

模板匹配是图像处理中非常基础且有效的技术,常用于目标检测、物体跟踪等任务。使用 OpenCV 中的 cv2.matchTemplate() 函数,我们能够在图像中找到与模板图像相似的区域。通过设置合适的匹配阈值和选择适当的匹配方法,我们可以实现多目标模板匹配和多模板匹配。在复杂场景中,模板匹配可能会受到图像旋转、尺度变化等因素的影响,因此在实际应用中,通常需要结合其他技术进行改进。

  • 单目标模板匹配:寻找图像中最匹配的一个模板位置。
  • 多目标模板匹配:在图像中找到多个匹配的区域。
  • 多模板匹配:针对多个模板同时进行匹配。

模板匹配是图像处理中重要的一环,在一些简单、规则的场景下非常有效,但对于复杂背景和变化大的情况,可能需要结合其他计算机视觉技术来提高匹配精度。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/62983.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于IEEE 802.1Qci的时间敏感网络(TSN)主干架构安全分析及异常检测系统设计

中文标题:基于IEEE 802.1Qci的时间敏感网络(TSN)主干架构安全分析及异常检测系统设计 英文标题:Security Analysis of the TSN Backbone Architecture and Anomaly Detection System Design Based on IEEE 802.1Qci 作者信息&…

怎样提升企业网络的性能?

企业网络的稳定性和高效性直接影响员工的工作效率。以下从多维度分析了一些有效策略,帮助公司提升网络性能,营造更高效的办公环境。 1. 升级网络设备 采用性能更高的网络硬件是优化网络体验的重要基础。选择支持高吞吐量、低延迟的设备(如企业…

scala基础_数据类型概览

Scala 数据类型 下表列出了 Scala 支持的数据类型: 类型类别数据类型描述Scala标准库中的实际类基本类型Byte8位有符号整数,数值范围为 -128 到 127scala.Byte基本类型Short16位有符号整数,数值范围为 -32768 到 32767scala.Short基本类型I…

力扣239.滑动窗口最大值

文章目录 一、前言二、单调队列 一、前言 力扣239.滑动窗口最大值 滑动窗口最大值,这道题给定一个数组,以及一个窗口的长度,这个窗口会往后滑动,直到数组最后一个元素。 要求每个滑动窗口的中的最大值。对于这道题,我…

mac 安装CosyVoice (cpu版本)

CosyVoice 介绍 CosyVoice 是阿里研发的一个tts大模型 官方项目地址:https://github.com/FunAudioLLM/CosyVoice.git 下载项目(非官方) git clone --recursive https://github.com/v3ucn/CosyVoice_for_MacOs.git 进入项目 cd CosyVoic…

电脑插件修复工具

DirectX修复工具 链接:夸克网盘分享

Maven 安装配置(详细教程)

文章目录 一、Maven 简介二、下载 Maven三、配置 Maven3.1 配置环境变量3.2 Maven 配置3.3 IDEA 配置 四、结语 一、Maven 简介 Maven 是一个基于项目对象模型(POM)的项目管理和自动化构建工具。它主要服务于 Java 平台,但也支持其他编程语言…

Scala中的泛型特质

代码如下: package test41 //泛型特质 object test3 { //定义一个日志//泛型特质,X是泛型名称,可以更改。trait Logger[X] {val content: Xdef show():Unit }class FileLogger extends Logger[String] {override val content: String "…

前端三大框架 Vue、React 和 Angular 的市场占比分析

一、引言 ?? 随着前端技术的迅速发展,Vue.js、React 和 Angular 已成为全球最受欢迎的三大前端框架。在国内外,不同的框架在市场中的占比和流行程度存在显著差异。本文将从全球和中国市场的角度,对这三大框架的市场占比进行分析&#xff0…

vue3+echarts+websocket分时图与K线图实时推送

一、父组件代码&#xff1a; <template> <div class"chart-box" v-loading"loading"> <!-- tab导航栏 --> <div class"tab-box"> <div class"tab-list"> <div v-for"(item, index) in tabList…

用python的flask写的一个MQTT中转功能,http的方式发送数据和接收数据

需求背景 给一个客户对接人脸识别的设备&#xff0c;最后需要通知服务端进行一些消息推送。 简单例子 # 作者 陈老师 # https://v.iiar.cn import json import paho.mqtt.client as mqtt import requests from flask import Flask, requestapp Flask(__name__)# MQTT配置 mq…

ASP.NET |日常开发中读写XML详解

ASP.NET &#xff5c;日常开发中读写XML详解 前言一、XML 概述1.1 定义和结构1.2 应用场景 二、读取 XML 文件2.1 使用XmlDocument类&#xff08;DOM 方式&#xff09;2.2 使用XmlReader类&#xff08;流方式&#xff09; 三、写入 XML 文件3.1 使用XmlDocument类3.2 使用XmlWr…

分布式 Paxos算法 总结

前言 相关系列 《分布式 & 目录》《分布式 & Paxos算法 & 总结》《分布式 & Paxos算法 & 问题》 参考文献 《图解超难理解的 Paxos 算法&#xff08;含伪代码&#xff09;》《【超详细】分布式一致性协议 - Paxos》 Basic-Paxos 基础帕克索斯算法…

Git-基础操作命令

目录 Git基础操作命令 case *查看提交日志 log 版本回退 get add . Git基础操作命令 我们创建并且初始化这个仓库以后&#xff0c;我们就要在里面进行操作。 Git 对于文件的增删改查存在几个状态&#xff0c;这些修改状态会随着我们执行Git的命令而发生变化。 untracked、…

Spring Boot 实战:构建一个社交平台 API

在这篇博客中&#xff0c;我们将继续深入 Spring Boot 的开发实践&#xff0c;通过构建一个简单的社交平台 API&#xff0c;帮助大家理解如何使用 Spring Boot 高效地开发一个具有注册、登录、个人资料管理、帖子发布与评论、点赞等功能的社交平台。在开发过程中&#xff0c;我…

配置mysqld(读取选项内容,基本配置),数据目录(配置的必要性,目录下的内容,具体文件介绍,修改配置)

目录 配置mysqld 读取选项内容 介绍 启动脚本 基本配置 内容 端口号 数据目录的路径 配置的必要性 配置路径 mysql数据目录 具体文件 修改配置时 权限问题 配置mysqld 读取选项内容 介绍 会从[mysqld] / [server] 节点中读取选项内容 优先读取[server] 虽然服务…

智能家居WTR096-16S录放音芯片方案,实现语音播报提示及录音留言功能

前言&#xff1a; 在当今社会的高速运转之下&#xff0c;夜幕低垂之时&#xff0c;许多辛勤工作的父母尚未归家。对于肩负家庭责任的他们而言&#xff0c;确保孩童按时用餐与居家安全成为心头大事。此时&#xff0c;家居留言录音提示功能应运而生&#xff0c;恰似家中的一位无形…

Java 编程基础:开启编程世界的大门

一、Java 环境搭建 在开始编写 Java 代码之前&#xff0c;我们需要先搭建 Java 开发环境。 1. 安装 JDK&#xff08;Java Development Kit&#xff09; JDK 是 Java 开发的核心工具包&#xff0c;它包含了编译 Java 源文件所需的编译器&#xff08;javac&#xff09;以及运行…

pytorch bilstm crf的教程,注意 这里不支持批处理,要支持批处理 用torchcrf这个。

### Bi-LSTM Conditional Random Field ### pytorch tutorials https://pytorch.org/tutorials/beginner/nlp/advanced_tutorial.html ### 模型主要结构&#xff1a; ![title](sources/bilstm.png) pytorch bilstm crf的教程&#xff0c;注意 这里不支持批处理 Python version…

【SickOs1.1靶场渗透】

文章目录 一、基础信息 二、信息收集 三、反弹shell 四、提权 一、基础信息 Kali IP&#xff1a;192.168.20.146 靶机IP&#xff1a;192.168.20.150 二、信息收集 端口扫描 nmap -sS -sV -p- -A 192.168.20.150 开放了22、3128端口&#xff0c;8080端口显示关闭 22端…