理论沉淀:RANSAC算法

1.解决问题:

当一组样本数据中含有(较小波动的)正常数据(inliers)和(较大波动的)异常数据(outliers)且异常数据的量还不小于正常数据的量时,用最小二乘法将难以获得期望的直线(即能拟合正常数据的直线),随机抽样一致(RandomSAmple Consensus, RANSAC)算法就可以用来代替最小二乘法算出期望的直线参数。这里为便于讨论局限于直线模型,但RANSAC算法适用任何模型。

如下图所示,RANSAC算法的目的就是从数据集中剔除红色的点,得到一条能拟合蓝色点的直线。

2.算法描述:

S:样本点集

M:数学模型(y=ax+b)

N:计算模型M的参数所需的最少点数

K:算法迭代次数

T:判断一点是否适用于模型M的阀值误差

D:判定模型M是否适用于样本点集S的最少样本点数

(1)从样本点集S中随机抽取一个子样本P(P所含点数不小于N)来计算模型M的参数

(2)将余集S*=S-P中的每个点代入模型M,若所得误差小于设定阀值T则将此点加入P,否则抛弃

(3)若P中点的数量小于设定值D则抛弃模型M,否则用最小二乘法和点集P重新计算模型M的参数和点集P在新模型上的误差E

(4)将(1)~(3)迭代执行K次,每次产生的模型仅当P中点的数量大于D且误差比当前模型的误差小时才替代当前模型,否则抛弃

3.优化策略:

(1)若发现一种足够好的模型(正常点数量达到D且误差足够小)可跳出循环从而加速算法

(2)根据样本点集的特征有约束地随机选取子样本并规定正常点数量达到D且误差足够小就跳出循环从而加速算法

时间: 2024-10-27 11:55:56

理论沉淀:RANSAC算法的相关文章

Random Sample Consensus(RANSAC)算法介绍

转眼间2012年过了三个月了,最近在做目标跟踪,需要利用ransac算法进行图像匹配,使用Opencv+vs进行实现.终于初见成效啊,很激动也很兴奋,在这里mark一下,以备查用 !这里就不贴源码了,想想都是泪啊! RANSAC是"RANdom SAmple Consensus(随机抽样一致)"的缩写.它可以从一组包含"局外点"的观测数据集中,通过迭代方式估计数学模型的参数.它是一种不确定的算法--它有一定的概率得出一个合理的结果:为了提高概率必须提高迭代次数.该算

图像配准建立仿射变换模型并用RANSAC算法评估

当初选方向时就因为从小几何就不好.缺乏空间想像能力才没有选择摄影测量方向而是选择了GIS.昨天同学找我帮他做图像匹配,这我哪里懂啊,无奈我是一个别人有求于我,总是不好意思开口拒绝的人.于是乎就看着他给的一章节内容开始写程序了,今天总算给他完成了.做的比较简单,中间也遇到了不少问题,尤其是计算量大的问题,由于老师给的数据是粗配准过的数据, RANSAC算法评估时就简化了下. 理论内容: 第5章 图像配准建立几何变换模型 特征点建立匹配关系之后,下一步就是求解图像之间的变换关系.仿射变换能够很好的表

【特征匹配】RANSAC算法原理与源码解析

转载请注明出处:http://blog.csdn.net/luoshixian099/article/details/50217655 随机抽样一致性(RANSAC)算法,可以在一组包含"外点"的数据集中,采用不断迭代的方法,寻找最优参数模型,不符合最优模型的点,被定义为"外点".在图像配准以及拼接上得到广泛的应用,本文将对RANSAC算法在OpenCV中角点误匹配对的检测中进行解析. 1.RANSAC原理 OpenCV中滤除误匹配对采用RANSAC算法寻找一个最佳

理论沉淀:隐马尔可夫模型(Hidden Markov Model, HMM)

理论沉淀:隐马尔可夫模型(Hidden Markov Model, HMM) 参考链接:http://www.zhihu.com/question/20962240 参考链接:http://blog.csdn.net/ppn029012/article/details/8923501 本博文链接:http://www.cnblogs.com/dzyBK/p/5011727.html 1 题设 假设有n个骰子(从1~n编号),每个骰子有m面,每面标有一个数字且不重复,数字取值限制在[1,m].(1

openCV中的findHomography函数分析以及RANSAC算法的详解

本文将openCV中的RANSAC代码全部挑选出来,进行分析和讲解,以便大家更好的理解RANSAC算法.代码我都试过,可以直接运行. 在计算机视觉和图像处理等很多领域,都需要用到RANSAC算法.openCV中也有封装好的RANSAC算法,以便于人们使用.关于RANSAC算法的一些应用,可以看我的另一篇博客: 利用SIFT和RANSAC算法(openCV框架)实现物体的检测与定位,并求出变换矩阵(findFundamentalMat和findHomography的比较) 但是前几天师弟在使用op

视觉SLAM之RANSAC算法用于消除图像误匹配的原理

在基于特征点的视觉SLAM中,通常情况下,在特征匹配过程中往往会存在误匹配信息,使得计算获取的位姿精度低,易产生位姿估计失败的问题,因此,剔除这些错配点有很大的必要性.常会用到RANSAC算法进行消除两两匹配图像的误匹配点,如果只停留在应用的层面上很简单,直接调用opencv函数就行,看到效果时,感觉好神奇,到底怎么实现的啊,以前一直也没弄太明白,与图像结合的博客也比较少,在查阅了一些资料后,笔者似乎明白了一点,希望笔者的总结会对您的理解有帮助. 首先先介绍一下RANSAC算法(RANdom S

理解图像配准中的LMeds、M-estimators与RANSAC算法

图像配准对于运动平台(无人机,移动机器人)上的视觉处理有着极其重要的作用.配准算法的第一步通常是找到两幅图像中一一对应的匹配点对(特征点提取.描述.点对匹配),然后通过匹配点对求取变换矩阵.在图像特征点匹配之KD-Tree一文中讲了配准中第一步中的点对匹配方法,本文将集中讨论配准第二步.在获得匹配点对后,我们需要从中选取一定的匹配正确的点对计算变换矩阵,对于透射变换,需要选取4组点对,对于仿射变换,需要选取3组.但现在的问题是,我们获得的匹配点对中不能保证所有的匹配都是正确的,如何从中选取正确的

RANSAC算法笔记

最近在做平面拟合,待处理的数据中有部分噪点需要去除,很多论文中提到可以使用Ransac方法来去除噪点. 之前在做图像配准时,用到了Ransac算法,但是没有去仔细研究,现在好好研究一番. 参考: http://download.csdn.net/detail/tuoxie2046/6012333#comment http://grunt1223.iteye.com/blog/961063 http://www.cnblogs.com/tiandsp/archive/2013/06/03/3115

RANSAC算法详解

原帖地址:http://grunt1223.iteye.com/blog/961063 另参考:http://www.cnblogs.com/xrwang/archive/2011/03/09/ransac-1.html 给定两个点p1与p2的坐标,确定这两点所构成的直线,要求对于输入的任意点p3,都可以判断它是否在该直线上.初中解析几何知识告诉我们,判断一个点在直线上,只需其与直线上任意两点点斜率都相同即可.实际操作当中,往往会先根据已知的两点算出直线的表达式(点斜式.截距式等等),然后通过向