SLAM基础知识:前端和后端

在SLAM中前端和后端是被经常提到的一个概念。但是对于前端和后端的理解有着不同的看法,我的理解是:

**前端:**前端负责处理传感器数据,特征提取,进行状态估计和地图构建的初步步骤。

**后端:**后端接受不同时刻的里程计信息,以及回环检测信息,对它们进行优化,得到全局一致的轨迹和地图。

也就是说前端 一般是为了得到当前帧 的一个粗糙的位姿估计,而后端 则是一个规模更大(多帧之间的约束、回环、IMU等其他约束)的优化系统。

以LOAM系列为例:

特征提取、匹配、scan-to-map中利用高斯牛顿求解ICP问题进行状态估计,这些都属于前端部分;回环检测、因子图优化部分则属于后端。

以Fast-LIO系列为例:

在基于滤波的SLAM算法中,使用迭代卡尔曼滤波(Iterative Kalman Filtering)来求解当前帧状态量的步骤通常属于SLAM系统的前端部分。

如果我们把后端看做是一个全局优化或者多个时刻的里程计优化的话,那么因为Fast-LIO系列没有回环,则认为没有后端只有前端。

以ORB-SLAM系列为例:

ORB-SLAM2主要有3大线程,分别是跟踪线程,局部建图线程以及回环检测线程。跟踪线程仅优化当前帧位姿,属于前端视觉里程计部分;局部建图线程会一起优化当前帧及其共视关键帧的位姿和地图点,属于后端优化部分;回环检测线程会优化全局位姿也属于后端优化部分。

相关推荐
满分观察网友z2 分钟前
从UI噩梦到导航之梦:一道LeetCode经典题如何拯救了我的项目(116. 填充每个节点的下一个右侧节点指针)
算法
DoraBigHead1 小时前
小哆啦解题记——两数失踪事件
前端·算法·面试
不太可爱的大白1 小时前
Mysql分片:一致性哈希算法
数据库·mysql·算法·哈希算法
Tiandaren5 小时前
Selenium 4 教程:自动化 WebDriver 管理与 Cookie 提取 || 用于解决chromedriver版本不匹配问题
selenium·测试工具·算法·自动化
岁忧6 小时前
(LeetCode 面试经典 150 题 ) 11. 盛最多水的容器 (贪心+双指针)
java·c++·算法·leetcode·面试·go
chao_7896 小时前
二分查找篇——搜索旋转排序数组【LeetCode】两次二分查找
开发语言·数据结构·python·算法·leetcode
cnbestec7 小时前
协作机器人UR7e与UR12e:轻量化设计与高负载能力助力“小而美”智造升级
人工智能·机器人·协作机器人·ur协作机器人·ur7e·ur12e
秋说8 小时前
【PTA数据结构 | C语言版】一元多项式求导
c语言·数据结构·算法
Maybyy8 小时前
力扣61.旋转链表
算法·leetcode·链表
卡卡卡卡罗特10 小时前
每日mysql
数据结构·算法