OpenCV 之 模版匹配多个对象、图片旋转 综合应用

引言

在图像处理和计算机视觉中,模板匹配是一种常用的技术,用于在一幅较大的图像中查找与给定模板图像相似的部分。然而,在实际应用中,目标物体可能会出现在不同的角度,这就需要我们在匹配之前对模板进行旋转处理。本文将介绍如何使用 OpenCV 进行模板匹配,并演示如何处理旋转模板。

模板匹配原理

模板匹配是通过比较模板图像与目标图像中的每一个可能位置来完成的。OpenCV 提供了多种模板匹配的方法,其中 cv2.matchTemplate 是一个常用函数,它可以计算模板与目标图像之间的相似度。常见的匹配方法包括:

  • cv2.TM_SQDIFF:平方差匹配。
  • cv2.TM_CCORR:相关匹配。
  • cv2.TM_CCOEFF:相关系数匹配。
  • cv2.TM_CCOEFF_NORMED:归一化相关系数匹配。

在本文中,我们将使用 cv2.TM_CCOEFF_NORMED 方法进行模板匹配。

实验素材

代码讲解
  1. 读取图像和转换为灰度图

    import cv2
    import numpy as npimg_rgb = cv2.imread('picture_video/image.jpg')
    img_gray = cv2.cvtColor(img_rgb, cv2.COLOR_BGR2GRAY)
    template = cv2.imread('picture_video/res.jpg', 0)

    解释:

    • 使用 cv2.imread 读取原始图像和模板图像。
    • 将原始图像转换为灰度图 img_gray,因为模板匹配通常在灰度图上进行。
  2. 旋转模板图像

    # 旋转 90 度,k=-1 表示顺时针旋转 90 度
    rotated_image1 = np.rot90(template, k=-1)
    # 旋转 90 度,k=1 表示逆时针旋转 90 度
    rotated_image2 = np.rot90(template, k=1)

    解释:

    • 使用 np.rot90 函数旋转模板图像。k=-1 表示顺时针旋转 90 度,k=1 表示逆时针旋转 90 度。
  3. 获取模板图像的尺寸

    h, w = template.shape[:2]

    解释:

    • 获取模板图像的高度 h 和宽度 w
  4. 使用模板匹配方法 cv2.matchTemplate 进行模板匹配

    res = cv2.matchTemplate(img_gray, template, cv2.TM_CCOEFF_NORMED)
    res1 = cv2.matchTemplate(img_gray, rotated_image1, cv2.TM_CCOEFF_NORMED)
    res2 = cv2.matchTemplate(img_gray, rotated_image2, cv2.TM_CCOEFF_NORMED)

    解释:

    • 使用 cv2.matchTemplate 函数进行模板匹配,cv2.TM_CCOEFF_NORMED 方法用于计算归一化的相关系数。
  5. 设定匹配阈值并获取匹配结果

    threshold = 0.9
    loc = np.where(res >= threshold)
    loc1 = np.where(res1 >= threshold)
    loc2 = np.where(res2 >= threshold)

    解释:

    • 设定匹配阈值 threshold,只有匹配分数大于等于这个阈值的区域才会被认为是匹配成功的位置。
    • 使用 np.where 函数获取所有匹配分数大于等于阈值的点的坐标。
  6. 在原图上绘制匹配区域的矩形框

    for pt in zip(*loc[::-1]):cv2.rectangle(img_rgb, pt, (pt[0] + w, pt[1] + h), (0, 0, 255), 1)for pt in zip(*loc1[::-1]):cv2.rectangle(img_rgb, pt, (pt[0] + w, pt[1] + h), (0, 0, 255), 1)for pt in zip(*loc2[::-1]):cv2.rectangle(img_rgb, pt, (pt[0] + w, pt[1] + h), (0, 0, 255), 1)

    解释:

    • 使用 cv2.rectangle 函数在原图 img_rgb 上绘制矩形框,标出匹配成功的区域。
    • 矩形框的颜色为红色 (0, 0, 255),线宽为 1
  7. 显示结果图像

    cv2.imshow('res.jpg', img_rgb)
    cv2.waitKey(0)

    解释:

    • 使用 cv2.imshow 显示带有匹配区域的图像。
    • 使用 cv2.waitKey(0) 等待用户按键关闭窗口。
  8. 输出结果:

总结

通过上述代码演示,我们展示了如何在 OpenCV 中进行模板匹配,并处理旋转模板。模板匹配是一种基本的图像处理技术,广泛应用于目标检测、图像识别等领域。通过旋转模板,我们可以提高匹配的鲁棒性,即使目标物体在图像中处于不同的角度,也能准确地识别出来。这种方法在实际应用中非常有用,特别是在需要检测旋转目标物体的情况下。

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

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

相关文章

仿某皮影狸app官网源码 不错的APP下载官网单页源码 HTML源码

分享一款不错的APP下载官网单页源码,直接修改index.html即可 源码下载:https://download.csdn.net/download/m0_66047725/89731228 更多资源下载:关注我。

Python(PyTorch和TensorFlow)图像分割卷积网络导图(生物医学)

🎯要点 语义分割图像三层分割椭圆图像脑肿瘤图像分割动物图像分割皮肤病变分割多模态医学图像多尺度特征生物医学肖像多类和医学分割通用图像分割模板腹部胰腺图像分割分类注意力网络病灶边界分割气胸图像分割 Python生物医学图像卷积网络 该网络由收缩路径和扩…

回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测+交叉验证

回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测交叉验证 目录 回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测交叉验证效果一览基本介绍程序设计参考资料 效果一览 基本介绍 Matlab实现基于贝叶…

AI大模型精准升级!揭秘高级RAG架构,让回答更精准、更可靠!

什么是 RAG? 当然,本文依然会讲解一部分 RAG 的基础知识,让你能够对文章的上下文有个初步了解。 “检索增强生成” (Retrieval Augmented Generation),简称 RAG,这一概念首次出现在 2020 年 Meta 发布的一项学术研究…

中国《人工智能安全治理框架》1.0版正式发布 规范各类AI、算法

今日,全国网络安全标准化技术委员会发布《人工智能安全治理框架》1.0版。《框架》提出了包容审慎、确保安全,风险导向、敏捷治理,技管结合、协同应对,开放合作、共治共享等人工智能安全治理的原则。 针对模型算法安全、数据安全和…

RK3576芯片在智能家居里中型智慧屏产品的应用方案分析

智能家居在近年来得到了快速发展,AI技术不断发展,人机交互十分成熟,各种家电也都迎来了智能化浪潮,智能家居为人们提供了优秀的产品体验,受到主流消费者的青睐,智能家居里的中型智慧屏产品也随之兴起。 瑞芯…

2414. Length of the Longest Alphabetical Continuous Substring

2414. Length of the Longest Alphabetical Continuous Substring class Solution:def longestContinuousSubstring(self, s: str) -> int:ans1tansansfor i in range(1,len(s)):if ord(s[i])ord(s[i-1])1:tans1ansmax(ans,tans)else:tans1return ans

RedisTemplate操作String的API

文章目录 1 String 介绍2 命令3 对应 RedisTemplate API❄️❄️ 3.1 添加缓存❄️❄️ 3.2 设置过期时间(单独设置)❄️❄️ 3.3 获取缓存值❄️❄️ 3.4 删除key❄️❄️ 3.5 顺序递增❄️❄️ 3.6 顺序递减 ⛄4 以下是一些常用的API⛄5 应用场景 1 String 介绍 String 类型…

anaconda启动jupyter notebook

1.在Windows搜索框搜索anaconda prompt点击打开 2.然后输入命令jupyter notebook 3.在这个页面编写你的程序

MATLAB实现PID参数自动整定

目录 1、项目说明 2、文件说明 1、项目说明 本项目旨在通过 MATLAB 语言实现 PID 参数的自动整定,并设计了一个直观易用的 GUI 界面。该系统特别适用于实验室环境下的 PID 参数自整定任务。整定的核心原则在于优化系统性能,使系统的衰减比尽可能接近理…

2025考公最新视频免费分享花生十三、齐麟、葛欣、阿里木江、龙飞、袁东、飞扬、李梦娇等

🎉备战公考不用愁,我的小程序为你助力🎉 这里汇聚了花生十三、齐麟、葛欣、阿里木江、龙飞、彬彬、袁东、飞扬、李梦娇、高照等几十位公考名师。他们的视频课程精彩纷呈,搭配详细讲义,让你轻松掌握公考要点。 作为一…

Java | Leetcode Java题解之第395题至少有K个重复字符的最长子串

题目&#xff1a; 题解&#xff1a; class Solution {public int longestSubstring(String s, int k) {int ret 0;int n s.length();for (int t 1; t < 26; t) {int l 0, r 0;int[] cnt new int[26];int tot 0;int less 0;while (r < n) {cnt[s.charAt(r) - a];…

python使用selenium,实现简单爬虫功能

目录 前言 环境 代码 前言 有个朋友想爬取一些数据&#xff0c;让我帮忙搞下&#xff0c;我也比较菜&#xff0c;不怎么用python就随便搜了点资料尝试下。 环境 idea&#xff0c;python3.1.0 edge浏览器&#xff08;谷歌也可以&#xff09;&#xff0c;都需要在python的…

自然语言处理系列六十一》分布式深度学习实战》TensorFlow深度学习框架

注&#xff1a;此文章内容均节选自充电了么创始人&#xff0c;CEO兼CTO陈敬雷老师的新书《自然语言处理原理与实战》&#xff08;人工智能科学与技术丛书&#xff09;【陈敬雷编著】【清华大学出版社】 文章目录 自然语言处理系列六十一分布式深度学习实战》TensorFlow深度学习…

linux定时监听ssh服务是否启动-------麒麟操作系统永久关闭swap

linux监听ssh服务是否启动 1、监听脚本2、定时任务3、麒麟操作系统&#xff0c;永久关闭swap 1、监听脚本 #在/usr/local/bin目录下新建脚本文件 cd /usr/local/bin touch check_sshd.sh #给可执行权限 chmod x /usr/local/bin/check_sshd.sh脚本内容如下&#xff1a; #!/…

回溯算法day24| 491.递增子序列、46. 全排列、47. 全排列 II

回溯算法day24| 491.递增子序列、46. 全排列、47. 全排列 II 491.递增子序列[46. 全排列](https://leetcode.cn/problems/permutations/)[47. 全排列 II](https://leetcode.cn/problems/permutations-ii/) 491.递增子序列 给你一个整数数组 nums &#xff0c;找出并返回所有该…

SpringBoot2:请求处理原理分析-接口参数的常用注解

1、PathVariable 作用说明&#xff1a;获取路径参数 案例&#xff1a; 接口收参形式&#xff1a; GetMapping("/car/{id}/owner/{username}")public Map<String,Object> getCar(PathVariable("id") Integer id,PathVariable("username")…

element-ui单元格点击后进入编辑模式的功能

实现一个单元格点击后进入编辑模式的功能。可以通过动态切换组件来实现。 为了在el-table-column中实现单元格单击后变为可编辑的功能&#xff0c;可以使用v-if和v-else来判断当前单元格是否处于编辑状态&#xff0c;并配合数据绑定和事件处理。 代码示例 <el-table-colum…

【uml】graph_legend中的类图怎么看

上图中的方框具有以下含义&#xff1a; 实心灰色方框表示生成图表的结构或类。 带黑色边框的方框表示已记录的结构或类。 带灰色边框的方框表示未记录的结构或类。 带红色边框的方框表示未显示所有继承/包含关系的已记录的结构或类。如果图表不适合指定的边界&#xff0c;则图…

雷电9模拟器安装magisk和lsposed

模拟器环境配置 1、开启root 2、开启System.vmdk可写入 安装magisk 1、新建模拟器、开启root权限、并安装debug版magisk 下载地址去上面吾爱论坛作者文章下载吧&#xff01;支持他一下&#xff01; 2、打开magisk的app&#xff0c;点击安装 如果弹出获取权限&#xff0c;直接…