博客
关于我
ORB-SLAM2代码详解08: 局部建图线程LocalMapping
阅读量:725 次
发布时间:2019-03-15

本文共 1391 字,大约阅读时间需要 4 分钟。

ORB-SLAM2代码详解08: 局部建图线程LocalMapping

本文详细介绍了ORB-SLAM2库中LocalMapping线程的实现,重点分析其核心功能和工作原理。


1. 成员函数/变量解析

1.1 核心缓冲队列

  • mlNewKeyFrames (protected): 由Tracking线程插入的关键帧缓冲队列。
  • InsertKeyFrame (public): 向缓冲队列插入新关键帧。
  • CheckNewKeyFrames (protected): 检查缓冲队列中是否有新关键帧。
  • KeyframesInQueue (public): 查询缓冲队列中关键帧数量。
  • mbAcceptKeyFrames (protected): 表示LocalMapping线程是否愿意接收新关键帧。
  • AcceptKeyFrames (public): 获取mbAcceptKeyFrames值。
  • SetAcceptKeyFrames (public): 设置mbAcceptKeyFrames值。

2. 局部建图主函数: Run()

  • LocalMapping线程的主循环,每3ms检查一次缓冲队列。
  • 当前线程设置为不接受新关键帧(SetAcceptKeyFrames(false))。
  • 检查缓冲队列,若有新关键帧,执行以下步骤:
  • 处理新关键帧。
  • 剔除劣质地图点。
  • 创建新地图点。
  • 将当前关键帧与共视关键帧融合。
  • 局部BA优化。
  • 剔除冗余关键帧。
  • 将关键帧加入闭环检测。
  • 设置当前线程为接受新关键帧(SetAcceptKeyFrames(true)),暂停3ms后重复循环。

3. 处理新关键帧: ProcessNewKeyFrame()

  • 取出队列头的关键帧。
  • 计算关键帧的词向量。
  • 判断地图点是否为新生成的:
    • 若地图点是共视关键帧匹配得到的,添加当前关键帧观测。
    • 若地图点是新生成的,加入临时存储容器mlpRecentAddedMapPoints
  • 更新地图点共视关系。
  • 将关键帧添加到地图中。

4. 剔除劣质地图点: MapPointCulling()

  • 标准1:召回率(mnFound / mnVisible)< 0.25。
  • 标准2:3帧内观测数目少于2(双目为3)。
  • 若地图点未通过3帧考验,标记为坏地图点。

5. 创建新地图点: CreateNewMapPoints()

  • 与共视程度最高的前10帧(单目20帧)进行特征匹配。
  • 双目相机可通过视差恢复地图点或三角化生成地图点。

6. 融合当前关键帧: SearchInNeighbors()

  • 正向融合:将当前帧地图点融合到共视帧。
  • 反向融合:将共视帧地图点融合到当前帧。
  • 更新当前帧地图点信息。

7. 局部BA优化: Optimizer::LocalBundleAdjustment()

  • 优化当前帧局部地图:
    • 一级共视关键帧位姿优化。
    • 二级共视关键帧位姿不变。
    • 所有局部地图点位姿优化。

8. 剔除冗余关键帧: KeyFrameCulling()

  • 若90%以上地图点被超过3个其他关键帧观测到,标记为冗余关键帧。

总结

本文对ORB-SLAM2库中LocalMapping线程的实现进行了详细分析,涵盖了关键帧处理、地图点优化、局部BA优化等核心功能。通过理解这些实现细节,可以更好地掌握ORB-SLAM2在实时定位和建图中的优势。

转载地址:http://szhlz.baihongyu.com/

你可能感兴趣的文章
oracle 创建字段自增长——两种实现方式汇总
查看>>
Oracle 升级10.2.0.5.4 OPatch 报错Patch 12419392 Optional component(s) missing 解决方法
查看>>
oracle 可传输的表空间:rman
查看>>
Oracle 启动监听命令
查看>>
Oracle 在Drop表时的Cascade Constraints
查看>>
Oracle 在Sqlplus 执行sql脚本文件。
查看>>
Oracle 如何处理CLOB字段
查看>>
oracle 学习
查看>>
oracle 定义双重循环例子
查看>>
ORACLE 客户端工具连接oracle 12504
查看>>
Oracle 客户端连接时报ORA-01019错误总结
查看>>
Oracle 常用命令
查看>>
Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
查看>>
Oracle 排序中使用nulls first 或者nulls last 语法
查看>>
oracle 插入date日期类型的数据、插入从表中查出的数据,使用表中的默认数据
查看>>
oracle 数据库dg搭建规范1
查看>>
oracle 时间转化函数及常见函数 .
查看>>
Oracle 权限(grant、revoke)
查看>>
oracle 查询clob
查看>>
Oracle 比较 B-tree 和 Bitmap 索引
查看>>