OpenCV--图像查找

news/2024/12/17 4:24:13/

OpenCV--图像查找

  • 代码和笔记

代码和笔记

import cv2
import numpy as np"""
图像查找--特征匹配的应用,通过特征匹配和单应性矩阵
单应性变换:描述物体在世界坐标系(原图)和像素坐标系(对比图)之间的位置映射关系,对应的变换矩阵成为单应性矩阵
应用-图像摆正、图片替换
"""
# 在小图中找大图
img1 = cv2.imread('./img/ca2.jpeg')
img2 = cv2.imread('./img/cat.jpeg')gary1 = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY)
gary2 = cv2.cvtColor(img2, cv2.COLOR_BGR2GRAY)# 创建特征检测器
sift = cv2.SIFT_create()# 计算描述子
kp1, des1 = sift.detectAndCompute(gary1, None)
kp2, des2 = sift.detectAndCompute(gary2, None)# 创建特征匹配器
bf = cv2.BFMatcher(cv2.NORM_L1)# 进行匹配
match = bf.match(des1, des2)# 找到第一幅图的位置(点)对应在第二幅的位置(点),根据这些点计算单应性矩阵
# 计算单应性矩阵至少需要四个点--矩形的四个角类似
if len(match) >= 4:# src_points:源平面中点的坐标矩阵。 dst_points:目标平面中点的坐标矩阵# queryIdx:kp1的描述子Index。 trainIdx:kp2的描述子Index# .pt表示获取坐标。OpenCV里面点的类型要求为(1,1,2)第一个1是点的个数,-1表示自动匹配# 第二个1是每个 (x, y) 坐标对将被放置在一个单独的“行”中# 第三个2是指数组的第三个维度的大小,对应于每个 (x, y) 坐标对的两个元素# 用np.float32将列表转化为ndarray类型,再用reshape变成点类型src_points = np.float32([kp1[m.queryIdx].pt for m in match]).reshape(-1, 1, 2)dst_points = np.float32([kp2[m.trainIdx].pt for m in match]).reshape(-1, 1, 2)# 根据匹配的点计算单应性矩阵。findHomography返回矩阵和mask# 计算单应性矩阵的方法:cv2.RANSAC,表示随机抽样一致性。# 最大允许重投影错误阈值 5H, _ = cv2.findHomography(src_points, dst_points, cv2.RANSAC, 5)# 通过单应性矩阵,计算小图(img1)在大图中的对应位置# 拿出img1的行和列,也就是长和宽 彩色图像的shape为行、列和通道数,[:2]取前两个元素h, w = img1.shape[:2]# 逆时针四个角pts = np.float32([[0, 0], [0, h-1], [w-1, h-1], [w-1, 0]]).reshape(-1, 1, 2)# 对图片进行透视变换 perspectiveTransform是向量的用法,之前的warpPerspective是对图片而言dst = cv2.perspectiveTransform(pts, H)# 在大图中画出dst来,这里dst为小数,要转化一下。 True:是否闭合。2为粗细cv2.polylines(img2, [np.int32(dst)], True, (0, 0, 255), 2)
else:exit()# 画出匹配特征点
ret = cv2.drawMatches(img1, kp1, img2, kp2, match, None)
cv2.imshow('ret', ret)
cv2.waitKey(0)
cv2.destroyAllWindows()

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

相关文章

手机膜介绍

因为自己开店的原因,现在每天都在对不同的货进行对比,一直在发库存,库存的文章基本也都发没了,所以开始分享开店过程中遇到的事,来给大家介绍一下手机膜。 手机钢化膜、水凝膜、软膜和UV膜是四种常见的手机屏幕保护膜…

Docker-Dockerfile、registry

Dockerfile 一、概述 1、commit的局限 很容易制作简单的镜像,但碰到复杂的情况就十分不方便,例如碰到下面的情况: 需要设置默认的启动命令需要设置环境变量需要指定镜像开放某些特定的端口 2、Dockerfile是什么 Dockerfile是一种更强大的镜…

设置HP条UI

概述 设置常见的生命值条, 实现过程 设置UI/image作为形状 设置UI/Image作为背景 设置UI/image(healthfill)作为填充图片,层数低于背景 设置heathfill的imagetype为filled fillmethod为horizontal [SerializeField] private Im…

Artec Leo与Ray打造工厂数字孪生,提升生产线加工效率【沪敖3D】

挑战:勘测一条漏水的陈旧豌豆生产线,以便在该位置上安装全新改良系统,能提高新鲜农产品的利用比例 解决方案:Artec Leo、Artec Ray、Artec Studio、SOLIDWORKS(带Mesh2Surface插件) 效果:利用…

2023蓝桥杯题解 仅C、D

2023蓝桥杯题解 洛谷2023蓝桥杯C题 洛谷2023蓝桥杯D题 C题 [蓝桥杯 2023 省 A] 平方差 题目描述 给定 L , R L,R L,R,问 L ≤ x ≤ R L \leq x \leq R L≤x≤R 中有多少个数 x x x 满足存在整数 y , z y,z y,z 使得 x y 2 − z 2 xy^2-z^2 xy2−z2。 输入…

Guava库 学习入门--概览与入门

Guava库的介绍 Guava库是由Google开发的Java开源库,它的主要目的是简化常见的编程任务,提供高效的数据处理方法。Guava库中的功能覆盖了从集合操作、缓存、函数式编程、并发编程以及其他诸多实用的工具类。 Guava的安装与依赖配置 Guava库可以通过Mav…

shell编程入门之提取字符并设置rtc时间

awk用法 awk是一款文本处理工具,通常在Unix和Linux操作系统中使用,用于以行为单位对文本进行处理和操作。它可以读取输入文本,对其进行处理,生成报表、统计信息等,并将结果输出到标准输出设备中。 它主要有以下特点&…

c++总复习

C 中多态性在实际项目中的应用场景 图形绘制系统 描述:在一个图形绘制软件中,可能有多种图形,如圆形、矩形、三角形等。这些图形都有一个共同的操作,比如绘制(draw)。通过多态性,可以定义一个基…