opencv-python图像配准(匹配和叠加)的实现


Posted in Python onJune 23, 2021

图像配准需是指对不同条件下得到的两幅或多幅图像进行匹配、叠加的过程。最简单的做法就是求得原图像到目标图像之间的透视变换矩阵,将原图像按照矩阵进行变换,就可以得到和目标图像相似的效果。透视变换是将成像投影到一个新的视平面,也称作投影映射。

opencv-python图像配准(匹配和叠加)的实现

透视变换实质上是将二维的图片变换到三维的坐标系中之后再变换到另一个二维坐标系,与仿射变换相比透视变换实现的效果要多一些。求解精确矩阵和透视变换可以很容易地在opencv-python中实现。

import cv2 as cv
import numpy as np
import matplotlib.pyplot as plt
original_image = cv.imread("Image A.jpg")
target_image = cv.imread("Image B.jpg")
# 生成透视矩阵
src_points = np.array([[957, 1655], [2177, 1170], [2676, 24], [2487, 1931]], dtype=np.float32)
den_points = np.array([[687, 1150], [2000, 996], [2757, 18], [2098, 1819]], dtype=np.float32)
# getPerspectiveTransform可以得到从点集src_points到点集den_points的透视变换矩阵
T = cv.getPerspectiveTransform(src_points, den_points)
# 进行透视变换
# 注意透视变换第三个参数为变换后图片大小,格式为(高度,宽度)
warp_imgae = cv.warpPerspective(original_image, T, (target_image.shape[1], target_image.shape[0]))
plt.imshow(warp_imgae)
plt.show()

进行四点变换前后的结果为

opencv-python图像配准(匹配和叠加)的实现

opencv-python也可以计算超过四个点的两数组点之间的变换矩阵。对原图像选择7个点进行透视变换的结果为

# 设置原始和目标特征点
src_more_point = np.float32([[957, 1655], [2177, 1170], [620, 2586], [1280, 2316], [2487, 1931], [937, 758], [2676, 24]]).reshape(-1, 1, 2)
den_more_point = np.float32([[687, 1150], [2000, 996], [121, 1974], [927, 1886], [2098, 1819], [899, 280], [2757, 18]]).reshape(-1, 1, 2)
# 调用库函数计算特征矩阵
# cv.findHomography第三个参数为计算单位矩阵所用的方法,0为常规算法,cv.RANSAC为基于RANSAC的鲁棒算法,cv.LMEDS为最小中值
# 鲁棒算法,cv.RHO基于PROSAC的鲁棒算法.第四个参数取值范围在1到10,绝一个点对的阈值。原图像的点经过变换后点与目标图像上对应
# 点的误差.返回值中H为变换矩阵.mask是掩模,在线的点.
H, status = cv.findHomography(src_more_point, den_more_point, cv.RANSAC, 5.0)
# 进行透视变换
warped_more_point_image = cv.warpPerspective(original_image, H, (target_image.shape[1], target_image.shape[0]))

对4个点、7个点和opencv-python函数库自动匹配的效果对比如下

opencv-python图像配准(匹配和叠加)的实现

可以看出如果匹配点选择恰当,三种方法的效果并没有太大区别。

调用库函数的图像自动匹配代码如下

# 用AKAZE库函数进行自动特征检测,AKAZE与SIFT等属于相似的 特征检测,但是有一些不同
akaze = cv.AKAZE_create()
# Find the keypoints and descriptors with SIFT
kp1, des1 = akaze.detectAndCompute(original_image_gray, None)
kp2, des2 = akaze.detectAndCompute(target_image_gray, None)

bf = cv.BFMatcher()
matches = bf.knnMatch(des1, des2, k=2)
good_matches = []
for m, n in matches:
    if m.distance < 0.75 * n.distance:
        good_matches.append([m])

# 画出符合条件的匹配点的连线
img3 = cv.drawMatchesKnn(original_image_gray, kp1, target_image_gray, kp2, good_matches, None, flags=cv.DrawMatchesFlags_NOT_DRAW_SINGLE_POINTS)
cv.imwrite('matches.jpg', img3)


src_automatic_points = np.float32([kp1[m[0].queryIdx].pt for m in good_matches]).reshape(-1, 1, 2)
den_automatic_points = np.float32([kp2[m[0].trainIdx].pt for m in good_matches]).reshape(-1, 1, 2)

# 调用库函数计算特征矩阵
H, status = cv.findHomography(src_more_point, den_more_point, cv.RANSAC, 5.0)
# 进行透视变换
warped_automatic_image = cv.warpPerspective(original_image, H, (target_image.shape[1], target_image.shape[0]))

# 绘制图像
my_draw(warped_automatic_image, tip='automatic')

到此这篇关于opencv-python图像配准的实现的文章就介绍到这了,更多相关opencv-python图像配准内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
跟老齐学Python之有容乃大的list(1)
Sep 14 Python
Python中使用Inotify监控文件实例
Feb 14 Python
Python的__builtin__模块中的一些要点知识
May 02 Python
通过数据库对Django进行删除字段和删除模型的操作
Jul 21 Python
解决Python字典写入文件出行首行有空格的问题
Sep 27 Python
解决Scrapy安装错误:Microsoft Visual C++ 14.0 is required...
Oct 01 Python
django的ORM操作 删除和编辑实现详解
Jul 24 Python
在pytorch中对非叶节点的变量计算梯度实例
Jan 10 Python
Python中if有多个条件处理方法
Feb 26 Python
python中使用paramiko模块并实现远程连接服务器执行上传下载功能
Feb 29 Python
Python 随机生成测试数据的模块:faker基本使用方法详解
Apr 09 Python
python json.dumps() json.dump()的区别详解
Jul 14 Python
Python初学者必备的文件读写指南
Jun 23 #Python
总结Python连接CS2000的详细步骤
python图片灰度化处理的几种方法
详解Python中的进程和线程
详解Go语言运用广度优先搜索走迷宫
常用的Python代码调试工具总结
Django+Celery实现定时任务的示例
You might like
收音机怀古---春雷3P7图片欣赏
2021/03/02 无线电
第七节--类的静态成员
2006/11/16 PHP
WINXP下apache+php4+mysql
2006/11/25 PHP
PHP Token(令牌)设计
2008/03/15 PHP
php visitFile()遍历指定文件夹函数
2010/08/21 PHP
PHP学习笔记(三):数据类型转换与常量介绍
2015/04/17 PHP
PHP多维数组转一维数组的简单实现方法
2015/12/23 PHP
PHP自定义图片缩放函数实现等比例不失真缩放的方法
2016/08/19 PHP
laravel 判断查询数据库返回值的例子
2019/10/11 PHP
asp.net下利用js实现返回上一页的实现方法小集
2009/11/24 Javascript
js实现杯子倒水问题自动求解程序
2013/03/25 Javascript
实用框架(iframe)操作代码
2014/10/23 Javascript
详解jQuery uploadify文件上传插件的使用方法
2016/12/16 Javascript
js实现按座位号抽奖
2017/04/05 Javascript
AngularJs 常用的过滤器
2017/05/15 Javascript
基于js中style.width与offsetWidth的区别(详解)
2017/11/12 Javascript
JavaScript实现的文本框placeholder提示文字功能示例
2018/07/25 Javascript
Element-ui之ElScrollBar组件滚动条的使用方法
2018/09/14 Javascript
JQuery获取可视区尺寸和文档尺寸及制作悬浮菜单示例
2019/05/14 jQuery
Layui之table中的radio在切换分页时无法记住选中状态的解决方法
2019/09/02 Javascript
使用layer弹窗提交表单时判断表单是否输入为空的例子
2019/09/26 Javascript
Javascript中Math.max和Math.max.apply的区别和用法详解
2020/08/24 Javascript
Python实现求数列和的方法示例
2018/01/12 Python
python-opencv 将连续图片写成视频格式的方法
2019/01/08 Python
Django Rest framework认证组件详细用法
2019/07/25 Python
python__name__原理及用法详解
2019/11/02 Python
python获取依赖包和安装依赖包教程
2020/02/13 Python
浙江文明网签名寄语
2014/01/18 职场文书
《小草和大树》教学反思
2014/02/16 职场文书
销售求职信范文
2014/05/26 职场文书
门卫岗位职责说明书
2014/08/18 职场文书
转学证明范本
2015/06/19 职场文书
庆元旦主持词
2015/07/06 职场文书
SpringBoot整合Mybatis Generator自动生成代码
2021/08/23 Java/Android
Nginx禁止ip访问或非法域名访问
2022/04/07 Servers
详解Mysql事务并发(脏读、不可重复读、幻读)
2022/04/29 MySQL