OpenCV特征匹配

1、OpenCV Brute-Force匹配器

Brute-Force匹配器的匹配方法非常简单,输入两张图像对应的特征(特征点坐标与特征点域对应的描述子),循环遍历两幅图像中的特征,计算第一幅图像与第二幅图像之间每个特征之间的距离,然后返回距离最近的特征点对或者返回距离最近的k个特征点对。OpenCV中的Brute-Force特征匹配一般用cv2.BFMatcher类实现,类构建方法定义如下:

cpp 复制代码
cv2.BFMatcher(normType, crossCheck)

normType参数用于指定特征比对的范式,常见的可选的类型与所适应的主要特征检测与描述算法如下:

cs 复制代码
# SIFT、SURF等
normType = cv2.NORM_L2
normType = cv2.NORM_L1

# BRISK、ORB等
normType = cv2.NORM_HAMMING

crossCheck参数为交叉检验参数,约束输出结果的默认的类型为False。若记输出的一对特征点对为(p1,p2),(p1,p2)所对应的特征对为(feature1,feature2),当参数为False时,匹配对(p1,p2)所对应的特征只需要满足下述的条件①;当默认类型调整为True时,则匹配输出的匹配对会更加严格,匹配对(p1,p2)所对应的特征则需要同时满足下述的条件①与条件②。

①第一幅图像中的特征feature1与第二幅图像中的所有的特征比较后与feature2距离最近;

②第二幅图像中的特征feature2与第一幅图像中的所有的特征比较后与feature1距离最近。

下图将两幅图像之间的每个特征点之间的匹配分数做下可视化,横竖分别表示第一幅图与第二幅图,颜色越红则表示距离越近。则条件①表示只需满足一行中颜色最红即可,如匹配对(27,8);而条件①②则表示行列中均满足颜色最红,如匹配对(16,36)。

2、cv2.BFMatcher的两种比对方法

2.1、match方法

match方法输出结果为距离最近的特征点对,输出结果中第一幅图像中每个特征点在第二幅中只有唯一的一个匹配特征点结果。

2.2、knnMatch方法

knnMatch方法输出结果为距离最近的1~k个特征点对,常见的设置为k=2,输出结果中第一幅图像中每个特征点在第二幅图像中可以有1~k个匹配结果。输出的k个匹配对需要进一步处理,从而确定一个特征点对是否是更加可靠的、更加具有特征性的,一般处理方式为比较k个特征点对之间的距离,若距离相近则说明第一幅图像中的对应特征点在第二幅图像中有多个相近的特征点,则说明该对特征点不太能确定这多个相近的特征点中那个才是正确匹配,说明该特征点对不可靠,反之则说明该特征点对匹配结果为更加可靠,可以暂定k对中距离最近的匹配对为正确匹配。

具体的匹配可视化示例如下图所示:

相关推荐
nenchoumi31191 小时前
AirSim/Cosys-AirSim 游戏开发(一)XBox 手柄 Windows + python 连接与读取
windows·python·xbox
GoodStudyAndDayDayUp1 小时前
初入 python Django 框架总结
数据库·python·django
星辰大海的精灵1 小时前
基于Dify+MCP实现通过微信发送天气信息给好友
人工智能·后端·python
精灵vector1 小时前
Agent短期记忆的几种持久化存储方式
人工智能·python
北京_宏哥1 小时前
🔥Python零基础从入门到精通详细教程4-数据类型的转换- 上篇
前端·python·面试
乾巫宇宙国监察特使1 小时前
Python的设计模式
python·测试
Hockor2 小时前
写给前端的 Python 教程四(列表/元组)
前端·后端·python
这里有鱼汤2 小时前
熟练掌握MACD这8种形态,让你少走三年弯路(附Python量化代码)| 建议收藏
后端·python
404.Not Found2 小时前
Day46 Python打卡训练营
开发语言·python
love530love2 小时前
【PyCharm必会基础】正确移除解释器及虚拟环境(以 Poetry 为例 )
开发语言·ide·windows·笔记·python·pycharm