Python计算机视觉编程_03

本文介绍了全景图像拼接的过程,涉及单应性变换、RANSAC算法以及Multi-Band Blending策略。通过匹配特征点,使用RANSAC优化求解映射关系,减少错误匹配的影响。接着,利用Multi-Band Blending策略解决拼接缝问题,实现平滑过渡。最后,提供了代码实现的说明。
摘要由CSDN通过智能技术生成

前言

什么是全景拼接?简单来说就是将两幅或多幅具有重叠区域的图像,合并成一张大图
在这里插入图片描述
如图所示,7张不同的图像最后拼接成一幅大图,那么问题很明显,如何拼接呢?

1.单应性变换

如果是最简单图像拼接,很明显,我们只需要对其进行平移,将重叠区域叠加,很轻松的就能得到一幅拼接图像。但实际上两幅图像之间有很多种关系,包括但不限于平移,旋转,尺度变换,仿射,透视映射,桶状映射等等。
在这里插入图片描述
在这里插入图片描述
左边的图像由右边两幅图像拼接而成,很明显,右边两幅图像之间不仅有平移,还有旋转,还有拉伸等等,我们将右边的两幅图像转换成我们想要的平面图像,这个过程就是单应性变换。
在这里插入图片描述
上面这个表格显示了不同变换方式所带的未知参数个数,我们以平移为例子,两幅具有平移关系的图像,我们如何拼接呢?
在这里插入图片描述
如图所示,两幅图像之间的映射关系如何得到呢,很明显,理论上来说如果匹配的特征点完全正确,我们只需要一个匹配对就可以得到映射关系,比如这对匹配对为(25,25)和(50,50),那么右图先与左图重叠,再将右图往左移动25像素点,然后再向下移动25个像素点,就可以将两幅图像拼接了。
当然,完全正确的匹配点一般只存在于理论当中,所以我们需要一个误差函数来判断每个映射关系的好坏,通过这个误差函数来选择最合适的映射关系。而这个误差函数采用的方法就是我们熟悉的最小二乘法。这里就不对最小二乘法展开讲了,有兴趣的可以自行百度搜索,很多大佬讲的都很清晰。
而对于单应性变换,我们有以下公式
在这里插入图片描述
很显然,8个位置参数,我们需要4个匹配特征才能得出一种映射关系,如果将每种可能性都进行计算,所需要的资源量是非常巨大的,所以我们使用RANSAC(RAndom SAmple Consensus)算法来对其进行优化求解。

2.RANSAC算法

RANSAC解决了计算量过大的问题,通过采用缩小匹配点范围来进一步优化映射函数,流程如下
1.随机选择四对匹配特征
2.根据直接线性变换解法DLT计算单应矩阵H(唯一解)
3.对所有匹配点,计算映射误差ε=||pi’, Hpi|| ,比如A和B两幅图像融合,A的a经过H变换后为a’,与B图的对应匹配点b相减,得到对应匹配对的误差。
4.根据误差阈值,确定inliers(例如3-5像素),比如xa’-xb<5且ya’-yb<5则认为映射正确,将原来的a点加入inliers集合并令该集合统计数+1
5.针对最大inliers集合,重新计算单应矩阵H
比如我们的匹配对有一半正确和一半错误,那么一次性就能得到正确的映射关系的可能性为1/16,而实际操作中正确:错误的比例往往是10:1甚至更高,也就是说一次性得到正确的映射关系的概率为65%

3.Multi-Band Blending策略

尽管可以通过RANSAC算法快速得到正确的映射策略,但在进行图像融合的时候还是可以很明显的看出不同图像之间的界限,这个界限也就是我们说的拼接缝,拼接缝的产生原因有很多,但总结起来基本上都是一个原因,光照。因为时间与空间的不同,不同图像的光照程度也不一样,从而导致拼接缝十分明显。
Multi-Band Blending的流程如下:
1.建立两幅图像的拉普拉斯金字塔
2.求高斯金字塔(掩模金字塔-为了拼接左右两幅图像)因为其具有尺度不变性
3. 进行拼接blendLapPyrs() ; 在每一层上将左右laplacian图像直接拼起来得结果金字塔resultLapPyr
4.重建图像: 从最高层结果图
将左右laplacian图像拼成的resultLapPyr金字塔中每一层,从上到下插值放大并和下一层相加,即得blend图像结果(reconstructImgFromLapPyramid)
我们可以将拉普拉斯金字塔理解为高斯金字塔的逆形式。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4.代码实现

from pylab import *
from numpy import *
from PIL import Image

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值