计算机视觉——全景图像拼接

本文介绍了RANSAC算法在全景图像拼接中的应用,详细阐述了RANSAC的基本原理和算法步骤。实验结果展示了固定点拼接和同一场景下不同情况的拼接效果,分析了出现的问题,如拼接分界线、重影和图像模糊,并提出了相应的解决方案。文章总结了室内室外拼接的挑战和改进方向。
摘要由CSDN通过智能技术生成

1. RANSAC

1.1 概述

RANSAC 是“RANdom SAmple Consensus”(随机一致性采样)的缩写。该方法是用来找到正确模型来拟合带有噪声数据的迭代方法。给定一个模型,例如点集之间的单应性矩阵,RANSAC 基本的思想是,数据中包含正确的点和噪声点,合理的模型应该能够在描述正确数据点的同时摒弃噪声点。

1.2 示例

一个简单的例子是从一组观测数据中找出合适的2维直线。假设观测数据中包含局内点和局外点,其中局内点近似的被直线所通过,而局外点远离于直线。简单的最小二乘法不能找到适应于局内点的直线,原因是最小二乘法尽量去适应包括局外点在内的所有点。相反,RANSAC能得出一个仅仅用局内点计算出模型,并且概率还足够高。但是,RANSAC并不能保证结果一定正确,为了保证算法有足够高的合理概率,我们必须小心的选择算法的参数。
在这里插入图片描述

1.3 原理

OpenCV中滤除误匹配对采用RANSAC算法寻找一个最佳单应性矩阵H,矩阵大小为3×3。RANSAC目的是找到最优的参数矩阵使得满足该矩阵的数据点个数最多,通常令h33=1h33=1来归一化矩阵。由于单应性矩阵有8个未知参数,至少需要8个线性方程求解,对应到点位置信息上,一组点对可以列出两个方程,则至少包含4组匹配点对。
在这里插入图片描述
其中(x,y)表示目标图像角点位置,(x’,y’)为场景图像角点位置,s为尺度参数。

RANSAC算法从匹配数据集中随机抽出4个样本并保证这4个样本之间不共线,计算出单应性矩阵,然后利用这个模型测试所有数据,并计算满足这个模型数据点的个数与投影误差(即代价函数),若此模型为最优模型,则对应的代价函数最小。
在这里插入图片描述

1.4 算法步骤

  1. 随机从数据集中随机抽出4个样本数据 (此4个样本之间不能共线),计算出变换矩阵H,记为模型M;

  2. 计算数据集中所有数据与模型M的投影误差,若误差小于阈值,加入内点集 I ;

  3. 如果当前内点集 I 元素个数大于最优内点集 I_best , 则更新 I_best = I,同时更新迭代次数k ;

  4. 如果迭代次数大于k,则退出 ; 否则迭代次数加1,并重复上述步骤;

2. 实验结果与分析

2.1 固定点拼接

2.1.1 远景

在这里插入图片描述

2.1.2 结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.1.2 分析

  1. 第一次是直接用原图拼接的,每个图片的大小在5.0MB左右,运行时间非常久但是效果看起来大约是还可以的,左侧看起来毕竟自然,但是右侧有一条非常明显的分界线。我发现算法进行拼接的顺序应是从右往左排,所以图片的顺序也应5该是从右往左。
  2. 在室外场景的拼接没有出现跟室内一样的重影现象,但是出现了新的问题就是拼接分界线。而最左边的图片出现了扭曲是因为APAP算法对每个小格左单应性变换,从单个小ge看是没有特征的,所以出现了扭曲。

2.2 同一场景

2.2.1 室内近景

在这里插入图片描述

2.2.2 结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.2.3 分析

  1. 室内的近景图片进行拼接的话可以看出:出现了重影问题,两个花盆两个桌子,所拍摄的桌子与相机之间隔着一个花盆,所以在移动拍摄角度的时候物体和目标之间与相机的偏差产生了变化,从而导致重影现象。我觉得是因为拍摄距离太近导致全景拼接时图片需要过分拉伸所以近景图片拼接效果不如远景好,近景图片产生的重影问题可以通过最大流最小割。

3. 实现代码

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

# If you have PCV installed, these imports should work
from PCV.geometry import homography, warp
from PCV.localdescriptors import sift

"""
This is the panorama example from section 3.3.
"""

# set paths to data folder
featname = ['E:/python/picture/a' + str
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值