1.ORB-SLAM3 源码剖析:IMU 预积分
2.ORB-SLAM3-同步阅读及实践(二):高屋建瓴弄懂跟踪线程
3.视觉SLAMORB-SLAM:让人Orz的码解SLAM
4.[ORB-SLAM2] ORB-SLAM中的ORB特征(提取)
5.ORB-SLAM3整体流程详解
6.深度科普:ORB-SLAM3论文重点导读及整体算法流程梳理
ORB-SLAM3 源码剖析:IMU 预积分
IMU的数据结构在ORB-SLAM3中用于表示机体坐标系中的测量值。在特定时刻,码解加速度计测量线加速度和陀螺仪测量角速度。码解假设这些测量值包含高斯白噪声,码解且偏置建模为随机游走,码解其导数也是码解c 画图工具源码高斯白噪声。将重力转换到机体坐标系后,码解得到连续视觉帧间的码解IMU预积分结果。这些预积分包括旋转、码解速度和位置测量,码解以及整个测量向量的码解协方差矩阵。
在ORB-SLAM3中,码解每帧的码解IMU预积分在tracking线程中计算,具体由Tracking::PreintegrateIMU()函数执行。码解每帧间的码解IMU测量通过src/ImuTypes.cc中的Preintegrated::IntegrateNewMeasurement()进行积分。主要步骤如下:首先进行偏置校正,然后计算位置、速度的增量,接着计算旋转的增量。旋转变化量以李代数中的旋转向量表示,并通过指数映射转换为旋转矩阵。旋转矩阵按旋转顺序右乘。最后,更新协方差矩阵,并调整与偏置修正相关的位置、速度和旋转雅可比。
IMU的偏置校正、测量、标定和预积分类定义在include/ImuTypes.h文件中。
值得注意的是,对于初学者,了解GDB调试方法是提高ORB-SLAM3源码理解效率的重要步骤。GDB提供了一系列功能,允许开发者在运行程序时设置断点、查看变量值、追踪程序执行流程等,从而深入分析代码行为和潜在问题。
ORB-SLAM3-同步阅读及实践(二):高屋建瓴弄懂跟踪线程
前言:本文旨在对ORB-SLAM3跟踪线程的核心功能进行概述,以构建对整个模块工作原理的宏观理解,然后逐步深入至代码细节。团队小程序源码研究过程中,常因代码的复杂性和细节深入而迷失,因此本文旨在先理清模块的整体逻辑,再探讨其实现细节,以保持思路的清晰。代码逻辑同样遵循这一思路,从整体流程出发,再深入至具体函数的实现。
论文描述:跟踪线程负责对每帧图像进行相机定位,并判断何时插入新的关键帧。首先,执行与前一帧图像的初始特征匹配,然后进行仅运动的BA优化来确定位姿。在跟踪丢失(如因遮挡或突然运动导致)的情况下,由位置识别模块进行全局重定位。一旦获得最初的相机位姿估计和特征匹配,使用系统维护的关键帧的共视图提取局部可视化地图。接着,通过重投影方法搜索当前帧与局部地图点的匹配,并利用所有匹配点优化当前相机位姿。最后,决定是否插入新的关键帧。
代码概述:在系统初始化后,mState状态置位。下一帧到来时,首先检查上一帧的地图点是否需要替换。由于刚初始化,相机无速度,使用参考关键帧进行跟踪。重定位后也需使用参考关键帧。在正常情况下,系统采用恒速模型进行跟踪。若恒速模型失败,则使用参考关键帧,若参考关键帧也失败,则系统进行重定位。关键帧数量过少时,系统重新初始化,从头开始。8字android源码
跟踪模式主要处理当前帧和上一关键帧的特征点和地图点信息,不涉及共视图等概念。
代码实现流程:
2. 对于初始化成功的系统,进行跟踪有三种模式选择(由mbOnlyTracking判断):
(1) 仅进行跟踪不建图
(2) 同时跟踪和建图:初始化后ORB-SLAM有三种跟踪模型可供选择进行跟踪计算位姿。
步骤如下:
TrackReferenceKeyFrame(); - 使用参考关键帧进行跟踪
关键帧模型:BoW搜索当前帧与参考帧匹配点,将上一帧位姿作为当前帧初始值,优化3D-2D重投影误差获得位姿。
使用参考关键帧跟踪当前帧情况:将当前普通帧描述子转化为BoW向量,使用词袋加速匹配。若匹配特征点少于个,认为跟踪失败。若大于个,将上一帧位姿作为当前帧初始值,优化位姿。去除外点,统计内点数量。判断匹配超过个,认为跟踪成功。
计算位姿为当前帧相对于世界坐标系的Tcw。
SearchByBoW - 搜索匹配过程
步骤2.1.1 - 2.1.5 - 关键帧地图点、词袋特征向量等声明与匹配搜索。
TrackWithMotionModel(); - 运动模型跟踪
使用恒速模型估计位姿,根据运动模型对地图点跟踪,优化位姿。
重定位跟踪 - 计算BoW向量,检测候选关键帧,通过BoW匹配进行PnP位姿估计,优化。
局部地图跟踪 - 在得到初始位姿后,搜索局部关键帧、地图点,进行投影匹配,优化位姿。
后面涉及过程包括更新图像、特征点、地图点等信息,根据条件判断是否插入关键帧,并记录位姿信息。
知识星球链接:免费提供相关资料供学习讨论
参考资料:
视觉SLAMORB-SLAM:让人Orz的SLAM
ORB-SLAM,在视觉SLAM领域享有盛誉,其源码在GitHub上已有4.4K+Star,充分彰显了西班牙小哥的出色贡献。近期深入研究其论文并结合源码,体验了一番酸爽,发现它在SLAM领域确实有着独特的魅力与贡献。
ORB-SLAM的核心框架由三个并发进程组成:跟踪、局部建图和回环检测,系统结构清晰,功能分明。跟踪是主进程,负责定位和跟踪相机运动,通过特征匹配实现定位与优化。局部建图则负责关键帧与地图点的插入、删除及局部优化。回环检测则通过搜索回环关键帧,实现位姿图优化,确保系统鲁棒性。
特征提取是ORB-SLAM的关键之一,它采用ORB特征,兼顾性能与效率。与SURF、SIFT等相比,ORB提取速度快,每张仅需.3ms,适用于实时操作。ORB在FAST角点基础上加入方向信息,使BRIEF描述子旋转不变,同时利用图像金字塔和灰度质心法提取特征,实现尺度不变性。此外,通过网格划分与四叉树结构,ORB-SLAM确保特征点分布均匀,即使特征点不足,也可通过调整FAST阈值增加。
单目初始化是ORB-SLAM的另一大亮点,它通过特征点匹配计算基础矩阵和单应矩阵,自动判断场景类型,开源码怎么套用无需人工设定模型。共视图与本质图结构则加强了关键帧间的联系,实现高效回环检测。相机重定位策略确保了系统在跟踪失败时能快速恢复,关键帧与地图点的删增策略则优化了系统性能。
ORB-SLAM提供多样化的Bundle Adjustment方式,包括初始化阶段的全BA、跟踪过程的运动BA及局部建图阶段的局部BA,适应不同场景需求。整个系统庞大复杂,通过总结主要特性,虽有其精髓,但仍需深入研究,以充分理解其工作原理与优化策略。
总之,ORB-SLAM在视觉SLAM领域展现出了其独特魅力与贡献,从其高效的特征提取到灵活的系统框架,再到多样化的优化策略,无不体现其在SLAM技术中的卓越地位。向所有SLAM领域的先驱者致以崇高的敬意。
[ORB-SLAM2] ORB-SLAM中的ORB特征(提取)
ORB-SLAM中的特征构建以其使用统一的ORB(Oriented FAST and Rotated BRIEF)为核心创新点,使得系统构建更为简洁稳定。本文旨在深入探讨ORB特征的提取流程及对ORB特征的优化改良,以提供直观解答。
提取流程概览如下:
第一步:构造金字塔。
金字塔的构建是理解关键点分布的基础,它通过不同尺度的图像层次化表示,以便在多尺度上寻找特征。金字塔的层级数量与特征的分配直接相关,每层图像面积的减小导致特征点数量的减少,分配策略需确保各层特征点的均衡。
第二步:提取FAST角点。
FAST(Features from Accelerated Segment Test)算法基于中心像素与周围像素的灰度对比,高效快速地识别关键点。通过设定阈值,判断像素是否为角点,FAST算法在每个像素点上执行,产生大量角点,再经过非极大值抑制处理以去除冗余点。
第三步:计算角度。
通过灰度质心与圆心的向量角度,ORB特征不仅提取了角点,还计算出了每个角点相对于坐标系的角度,这有助于确保每次描述子计算的方向一致性,实现了角度不变性。
第四步:计算旋转感知的BRIEF描述子。
BRIEF(Binary Robust Independent Elementary Features)描述子是一个二进制描述子,以其高速匹配速度著称。通过选定的点对对块内的像素进行比较,形成描述子序列。Steered BRIEF根据角点方向旋转描述子坐标点对位置,实现了旋转不变性。
最后一步:提升抗噪能力。
ORB在计算描述子时使用周围5×5的patch灰度信息,进行滤波处理,提高了描述子的抗噪性。
ORB-SLAM的改进主要集中在FAST角点提取步骤。该系统通过动态调整阈值、利用四叉树划分图像等方法,提高了特征分布的均匀性,有效避免了特征扎堆现象。此策略有助于提升SLAM精度、闭环识别性能,并确保全图特征量满足需求,避免了丢失追踪问题。
ORB-SLAM3整体流程详解
ORB-SLAM3是一个先进的SLAM系统,支持视觉、视觉加惯导和混合地图,并能在单目、双目和RGB-D相机上运行,具备针孔或鱼眼模型。相较于ORB-SLAM2,它在处理大视差和长时间未观测场景时表现更佳,提供更准确的帧间运动估计和更快的处理速度。ORB-SLAM3还支持更多传感器,包括RGB-D摄像头和车载LIDAR,并且代码结构更为简洁,易于理解与扩展。 ORB-SLAM3的主要贡献包括:单目和双目视觉惯导SLAM系统,依赖MAP(最终后验概率估计),即使在IMU初始化时也是如此。
高召回率的场景重识别算法,优化了数据关联,提升地图准确性,同时考虑计算成本。
首个完整的混合地图SLAM系统,允许在单目或双目系统中构建Atlas,包含场景重识别、相机重定位、闭环检测和精确地图融合。
抽象的相机表示,使其与所使用的相机模型无关,并允许添加新模型。
在改进和扩展方面,ORB-SLAM2与ORB-SLAM3之间的常见扩展包括:添加稠密点云地图。
引入密集循环闭合地图模型。
使用SVO中直接法进行跟踪,保持精度的同时,提高原始ORB-SLAM2的速度。
双目VIO版本,集成LK光流和滑动窗口BA优化。
支持鱼眼相机,无需矫正或裁剪输入图像。
添加保存和导入地图功能。
添加地图可视化。
线特征基SLAM,基于著名ORB-SLAM2进行修改。
以上改进与扩展旨在提升ORB-SLAM3的性能与应用范围,使其在视觉SLAM领域更具竞争力。深度科普:ORB-SLAM3论文重点导读及整体算法流程梳理
本文将深入解读ORB-SLAM3的关键特点和整体算法流程,它革新了视觉和视觉惯性SLAM系统。首先,ORB-SLAM3作为首个实现短期、中期、长期数据关联的单目和双目系统,显著优于同类技术,尤其在实时性和准确性方面,其性能是其他方法的2-倍。通过几何和局部一致性检查,召回率提高,地图准确性增强。
使用Atlas结构表示断开地图,实现位置识别、相机重定位等操作时的无缝拼合。
抽象的相机表示允许灵活支持不同相机模型,只需提供投影、非投影和雅可比函数。
ORB-SLAM3系统由几个核心组件组成,包括活跃地图的跟踪线程、局部建图线程以及回环和地图合并线程。系统利用ORB-SLAM2和ORB-SLAM-VI作为基础,通过IMU初始化技术,支持单目和立体惯性SLAM。跟踪线程负责实时定位和建图,利用视觉和惯性信息进行优化。
局部建图线程在关键帧区域进行地图构建和优化,利用IMU参数进行最大后验估计。
回环和地图合并线程通过因子图处理地图的融合和回环检测,确保地图的精度和一致性。
在视觉-惯导SLAM中,系统不仅估计相机位姿,还涉及速度、惯性传感器偏置等。通过将视觉和惯性信息结合,形成一个最小化问题,通过因子图表示优化过程。 ORB-SLAM3的源码解析和实际应用将随后进行,对视觉惯性导航和多地图SLAM有兴趣的读者不容错过。ORBSLAM系列|ORB-SLAM论文带读(一)(划重点)
本文介绍了一种名为ORB-SLAM的新型单目SLAM系统,该系统在各种环境条件下都能实时运行。ORB-SLAM具有鲁棒性,支持宽基线回环和重定位,并且提供全自动初始化。系统的核心设计是基于相同的特征用于跟踪、建图、重定位和回环,这使得系统高效、简单且可靠。ORB特征因其对视角和光照变化的鲁棒性而被采用,允许在不依赖GPU的情况下实现实时性能。系统在大环境下的实时运行能力归功于共视图的使用,跟踪和建图着重于局部共视区域,与全局地图尺寸无关。实时回环检测通过基于位姿图(本质图)的优化实现,而实时重定位则支持从跟踪失败中恢复位姿,并增强地图重用性。系统还引入了一种新的基于模型选择的自动且鲁棒的初始化过程,允许创建平面和非平面场景的初始化地图。一种针对地图点和关键帧选择的适者生存策略提高了跟踪的鲁棒性,并且减少了冗余关键帧,增强了长时间运行的能力。
ORB-SLAM在广泛评估中证明了其优越性,特别是在室内和室外环境的主流公开数据集上的评估。与最先进的单目SLAM方法相比,ORB-SLAM实现了前所未有的性能。系统被设计为完整且可靠,提供了一种最高效、精确且易于实施的解决方案。出于造福SLAM社区的目的,源代码已公开,以便其他研究者和开发者能够利用和改进这一系统。演示视频和代码可以在项目网页上找到。
ORB-SLAM2源码系列--局部建图线程(MapPointCulling和KeyFrameCulling)
ORB-SLAM2源码系列--局部建图线程详解
MapPointCulling模块负责筛选新加入的地图点,确保地图质量。在ProcessNewKeyFrame函数中,新点被暂存于mlpRecentAddedMapPoints。筛选过程包括:根据相机类型设定不同的观测阈值
遍历新点,若点已标记为坏点则直接从队列中移除
若点的观察帧数少于预期值的%,或者观察相机数量少于阈值cnThObs,即使过了两个关键帧也会被删除
只有经过三个关键帧且未被剔除的点,才会被认定为高质量点,仅从队列移除
另一方面,KeyFrameCulling则针对共视图中的关键帧进行冗余检测。步骤如下:提取当前关键帧的共视关键帧,并遍历它们
对于每个共视关键帧,检查其地图点:若至少有3个其他关键帧观测到,被认为是冗余点
对于双目或RGB-D,仅考虑近距离且深度值大于零的地图点
若关键帧%以上的有效地图点被判断为冗余,该关键帧将被标记为冗余并删除
这样的筛选机制确保了地图数据的准确性和效率。ORB_SLAM灰度质心法学习笔记
灰度质心法,其核心原理是基于像素灰度值来确定关键点的位置。公式[公式]描绘了像素坐标与灰度值之间的关系,其中[公式]代表像素坐标,[公式]则表示该像素的灰度值。
在编程实现中,以图像块[公式]为例进行解释。这个块由像素值[公式]组成,关键点的灰度值位于块的中心,记作[公式]。为了保证关键点的旋转不变性,我们通常选择圆形区域而非矩形。圆形块不论以圆心为中心如何旋转,其内部像素分布保持不变,从而确保了方向角计算的准确性。
编程思路如下:通过公式[公式]计算像素的x坐标,公式[公式]处理y坐标,采用双重循环结构。外层循环遍历整个图像块,内层循环逐个像素处理。通过这些计算,我们可以得到[公式]和[公式],进而利用公式[公式]求得关键点的方向角[公式]。在此过程中,需要注意的是像素坐标[公式]与行、列的顺序相反。