ORB-SLAM中的RANSAC算法解析

news2025/1/11 22:49:24

RANSAC算法解析

RANSAC是一种在具有噪声的模型中去估计最优的一个算法,其核心思想是采用不断迭代的方法去选择一组全是内点的集合,并采用该集合进行模型估计的一种方法,可以提高模型估计的鲁棒性。

RANSAC算法流程

假设目前有 K K K组采集到的数据,但是数据中的一些点是噪声点,如何使用RANSAC去根据这些有噪声的数据去估计一个比较好的模型呢?

  1. 选择任意一种能够根据当前采集的数据进行模型评估的方法。
  2. 使用有放回抽样的方式抽取 S i S_i Si个数据,使用上述方法进行模型评估。
  3. 根据当前模型,进行数据点的回代
  4. 根据计算误差的自由度和置信区间查卡方检验表== χ 2 \chi^2 χ2和指定的方差的乘积==作为阈值 t t t
  5. 使用阈值 t t t设置内点标识,统计内点数目 K i n K_{in} Kin
  6. 根据给定的内点百分比 ω \omega ω和数据总数 K K K乘积为阈值 T T T,判断这次RANSAC迭代的模型是否有效。
  7. 根据计算得出的迭代次数 N N N

1 外点阈值 t t t

  1. RANSAC算法的模型估计后,进行数据回代判断内点时,所使用到的参数。
  2. 这个参数的选择是根据模型误差计算的自由度和置信区间查卡方检验表确定的。
  3. 在卡方检验中,假设误差符合高斯分布, e 2 < k 2 e^2<k^2 e2<k2的概率为 P ( k 2 ) = ∫ 0 k 2 χ m 2 ( ξ ) d ξ P(k^2)=\int_{0}^{k^2}{\chi^2_m(\xi) d\xi} P(k2)=0k2χm2(ξ)dξ,其中 e e e为误差, χ 2 \chi^2 χ2为高斯分布的平方表示, ξ \xi ξ为置信区间, m m m为高斯分布的自由度, t = k 2 = P − 1 ( ξ ) σ 2 t=k^2=P^{-1}(\xi)\sigma^2 t=k2=P1(ξ)σ2,其中 σ \sigma σ为高斯分布标准差。
  4. 在这一部分,一般是需要95%的置信区间,也就是说如果满足假设的高斯分布的话,我需要去掉5%的离群点,但是往往并不是这样,这是因为误差往往都是不满足高斯分布的。
  5. 这里计算阈值 t t t时,也需要确定方差的 σ 2 \sigma^2 σ2的大小,这就需要一定的先验内容了,在ORB-SLAM中,以金字塔层级的缩放因子的平方作为误差分布的先验方差,金字塔层级越高,认定的方差越大,所对应的误差阈值越大。

2 模型合格阈值 T T T

  1. 在判断这次RANSAC算法是否合格时,需要的阈值 T T T
  2. 这个 T T T能接受数据中最少内点的内点个数,是人为定义的一个数值,但是这个数值一般不少于采集数据总数的50%。

3 迭代次数 N N N

当RANSAC进行N次抽样时,至少有一次全为内点。或者说至少有一次全为内点的概率是 P P P。确定迭代次数的方式主要有两种:

  1. 假设采集到的数据中,内点的比例为 ω \omega ω,则进行 N N N次抽样时,至少有一次全为内点的概率计算公式为 P = 1 − ( 1 − ω s i ) N P=1-(1-\omega^{s_i})^N P=1(1ωsi)N
    1. 进行 s i s_i si次有放回抽样,抽到全是内点的概率为 ω s i \omega^{s_i} ωsi,则抽不到全是内点的概率为 1 − ω s i 1-\omega^{s_i} 1ωsi
    2. 进行N次上述抽样,抽不到全是内点的概率为 ( 1 − ω s i ) N (1-\omega^{s_i})^N (1ωsi)N,则至少有一次全是内点的概率为 P = 1 − ( 1 − ω s i ) N P=1-(1-\omega^{s_i})^N P=1(1ωsi)N
    3. 这种计算方式计算的迭代次数比较粗糙,在很大程度上依赖于内点占比的假设,在ORB-SLAM中也是用的这种方法。
  2. 使用迭代的方式进行迭代次数N的确定
    1. 迭代次数N是用于设置迭代终止条件的,因此重要的并不是求迭代次数N是多少,而是需要一个RANSAC迭代停止的条件
    2. 在RANSAC进行数据回代时,会统计一个内点的占比 ω i \omega_i ωi,可以根据 ω i \omega_i ωi来动态的计算和更新迭代次数 N N N
    3. 若当前更新的迭代次数 N N N小于目前真实的迭代次数,那么退出迭代即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1414676.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

手把手教你搓一个最小系统板【画PCB-->布线 -->制版-->焊接】

文章目录 一、基础电路1. 晶振电路2. 稳压电路3. 复位/按键电路4. BOOT电路5. SWD接口6. 滤波电容7. LED电路8. 拓展引脚设计总览 二、布局布线三、制版四、焊接 在大学嵌入式相关专业&#xff0c;有许多同学是更偏向软件上的设计&#xff0c;并不懂硬件上的实现&#xff0c;而…

CMake构建Qt工程

在https://blog.csdn.net/fengbingchun/category_12172633.html 上有直接通过vs2022建的Console、Widgets、Quick三个工程&#xff0c;这里增加通过CMake构建。 build.sh内容如下&#xff1a; #! /bin/bashif [ $# ! 1 ]; thenecho "Error: requires one parameter: Rele…

(八)springboot实战——springboot3下的webflux项目全局异常处理

前言 在webflux响应式编程中&#xff0c;如何处理系统运行时异常是本节的主要内容。在传统的Servlet阻塞式web项目中主要通过HandlerExceptionResolver处理器来处理&#xff0c;而在webflux响应式web项目中&#xff0c;则是通过DispatchExceptionHandler异常处理器来处理异常。…

vue模拟聊天页面列表:滚动到底部,滚动到顶部触发加载更多

先看下效果&#xff1a; 代码&#xff1a; <template><div><div style"text-align: center"><button click"scrollTop">滚动到顶部</button><button click"scrollBottom">滚动到底部</button></d…

R12.2 EBS 修改 APPS 密码 详细步骤

目录 前言准备修改步骤1.关闭应用层2.FNDCPASS 修改密码3. 运行 autoconfig4.单独启动 webLogic 服务5.登录weblogic&#xff0c;更新apps密码6.启动应用层7.验证 结尾 前言 本文的目的是修改 apps 密码&#xff0c;主要参考官方文档 metalink 1674462.1&#xff0c;请注意本文…

go语言(十九)---- channel

channel的使用 //1. 发送value到channelchannel <- value //2. 接收并将其丢弃<- channel //3. 从channel中接收数据&#xff0c;并将其赋值给x x : <- channel 例子 package mainimport "fmt"func main() {//定义一个channelc : make(chan int)go func…

如何在Shopee平台上进行宠物类目的选品丨shopee宠物选品

在Shopee平台上进行宠物类目的选品是一个重要的任务&#xff0c;它直接关系到卖家的销售业绩和市场竞争力。为了成功选择适合的宠物用品&#xff0c;在选品过程中&#xff0c;卖家可以遵循以下策略&#xff1a; 先给大家推荐一款shopee知虾数据运营工具知虾免费体验地址&#…

【C语言/数据结构】排序(直接插入排序|希尔排序)

&#x1f308;个人主页&#xff1a;秦jh__https://blog.csdn.net/qinjh_?spm1010.2135.3001.5343&#x1f525; 系列专栏&#xff1a;《数据结构》https://blog.csdn.net/qinjh_/category_12536791.html?spm1001.2014.3001.5482 ​​​​ 目录 插入排序 直接插入排序&…

网站服务器中毒或是被入侵该怎么办?

随着互联网的普及和发展&#xff0c;网站服务器已经成为了企业和个人存储数据、展示信息的重要平台。然而&#xff0c;网络安全问题也日益突出&#xff0c;其中网站服务器中毒或被入侵的事件时有发生。一旦发生这种情况&#xff0c;不仅会导致网站无法正常运行&#xff0c;还可…

大数据期望最大化(EM)算法:从理论到实战全解析

文章目录 大数据期望最大化&#xff08;EM&#xff09;算法&#xff1a;从理论到实战全解析一、引言概率模型与隐变量极大似然估计&#xff08;MLE&#xff09;Jensen不等式 二、基础数学原理条件概率与联合概率似然函数Kullback-Leibler散度贝叶斯推断 三、EM算法的核心思想期…

Scratch:启蒙少儿编程的图形化魔法

在当今这个数字化时代&#xff0c;编程已经成为了一项重要的基础技能。就像学习阅读和写作一样&#xff0c;掌握编程能够打开通往未来世界的大门。对于孩子们来说&#xff0c;Scratch作为一种图形化编程语言&#xff0c;不仅简单有趣&#xff0c;而且非常适合作为编程学习的入门…

蓝桥杯——每日一练(简单题)

题目 问题描述   123321是一个非常特殊的数&#xff0c;它从左边读和从右边读是一样的。   输入一个正整数n&#xff0c; 编程求所有这样的五位和六位十进制数&#xff0c;满足各位数字之和等于n 。 输入格式   输入一行&#xff0c;包含一个正整数n。 输出格式   按从…

SpringBoot系列之JPA实现按年月日查询

SpringBoot系列之JPA实现按年月日查询 通过例子的方式介绍Springboot集成Spring Data JPA的方法&#xff0c;进行实验&#xff0c;要先创建一个Initializer工程&#xff0c;如图&#xff1a; 选择&#xff0c;需要的jdk版本&#xff0c;maven项目 选择需要的maven配置&#x…

最小二乘3D圆拟合(高斯牛顿法)

欢迎关注更多精彩 关注我&#xff0c;学习常用算法与数据结构&#xff0c;一题多解&#xff0c;降维打击。 本期话题&#xff1a;最小二乘3D圆拟合 相关背景资料 点击前往 3D圆拟合输入和输出要求 输入 8到50个点&#xff0c;全部采样自3D圆上。每个点3个坐标&#xff0c;坐…

pom文件首行报错问题处理

项目开发过程中&#xff0c;有时候在田间某个以来的时&#xff0c;会遇到pom文件首行报错&#xff0c;如下图所示 1、将鼠标移动到首行报错位置&#xff0c;点击红色❌&#xff0c;便会显示报错原因&#xff0c;这个项目遇到报错原因为“Missing artifact jdk.tools:jdk.tools:…

两个让你心跳加速的网站,赶紧收藏吧

1、方小童在线工具集 网址&#xff1a; 方小童 该网站是一款在线工具集合的网站&#xff0c;目前包含PDF文件在线转换、随机生成美女图片、精美壁纸等功能&#xff0c;喜欢的可以赶紧去试试&#xff01; 2、电子书搜索 网址&#xff1a;https://libstc.cc 很强大一个网站&a…

搭建nginx图片服务器

&#xff08;1&#xff09;将图片存储于/home/data/images目录&#xff1b; &#xff08;2&#xff09;配置nginx.conf user nginx; worker_processes 4;error_log /var/log/nginx/error.log notice; pid /var/run/nginx.pid;events {worker_connections 10000; }ht…

架构师的36项修炼-08系统的安全架构设计

本课时讲解系统的安全架构。 本节课主要讲 Web 的攻击与防护、信息的加解密与反垃圾。其中 Web 攻击方式包括 XSS 跨站点脚本攻击、SQL 注入攻击和 CSRF 跨站点请求伪造攻击&#xff1b;防护手段主要有消毒过滤、SQL 参数绑定、验证码和防火墙&#xff1b;加密手段&#xff0c…

「研发部」GitFlow规范-升级版(二)

前言 上一篇文章简单整理过一次产研团队的GitFlow《Git 分支管理及Code Review 流程 (一)》 GitFlow是一种流行的Git分支管理策略&#xff0c;它提供了一种结构化的方式来管理项目的开发和发布流程。以下是GitFlow规范的主要组成部分&#xff1a; 主要分支&#xff1a; mast…

计算机毕业设计 | SpringBoot 求职招聘管理系统(附源码)

1&#xff0c;绪论 1.1 开发背景 高学历人群是网络求职者的主体&#xff0c;且结构趋向固定。而在疫情肆虐的今日&#xff0c;线上招聘成了越来越多企业和个人选择的方式。在疫情期间线下招聘转为线上招聘&#xff0c;是疫情防控的需要。不能否定的是新的招聘模式的出现一定会…