从零入门激光SLAM(十四)——简单有效的激光里程计KISS-ICP

2024-05-15 18:52

本文主要是介绍从零入门激光SLAM(十四)——简单有效的激光里程计KISS-ICP,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

KISS-ICP: In Defense of Point-to-Point ICP Simple, Accurate, and Robust Registration If Done the Right Way
论文地址:KISS-ICP: In Defense of Point-to-Point ICP – Simple, Accurate, and Robust Registration If Done the Right Way | IEEE Journals & Magazine | IEEE Xplore
代码:https://github.com/PRBonn/kiss-icp

一、文章概述

1.问题导向

SLAM系统经过长久的发展,系统变得越来越复杂,拥有许多参数需要调整,同时新型的激光雷达使得很多里程计不再适用。

2.目标

我们的设计既不使用复杂的特征提取技术、学习方法,也不使用循环闭合。相同的参数集适用于各种具有挑战性的场景。专注于激光里程计的本质。

3.摘要

机器人平台的稳健和准确的位姿估计,即所谓的基于传感器的里程计,是许多机器人应用的重要组成部分。虽然许多传感器里程计系统通过增加运动估计过程的复杂性而取得了进展,但我们却朝着相反的方向前进。通过去掉大部分部件并聚焦于核心元件,我们获得了一个令人惊讶的有效系统,该系统易于实现,并且可以使用不同的激光雷达传感器在各种环境条件下运行。我们的里程计估计方法依赖于点对点ICP结合自适应阈值进行对应匹配、稳健的核、简单但广泛适用的运动补偿方法以及点云分采样策略。这产生了一个只有几个参数的系统,在大多数情况下,这些参数甚至不需要调整到特定的激光雷达传感器。我们的系统使用相同的参数,在使用不同平台的各种操作条件下与最先进的方法性能相当:汽车平台、基于无人机的操作、赛格威等车辆或手持激光雷达。我们不需要集成IMU信息,仅依赖从各种3D LiDAR传感器获得的3D点云数据,从而实现了不同应用和操作条件的广泛范围。我们的开源系统在所有提供的数据集中的运行速度都快于传感器帧速率,并且是为真实世界场景而设计的。

4.贡献

提出一种简单而高效的方法来构建激光雷达里程计系统,该系统可以在机器人通过环境导航时准确地在线计算机器人的姿态。
我们表明,通过正确使用基于系统物理和传感器数据性质的基本推理的ICP,我们可以获得有竞争力的里程计。
除了运动预测、空间扫描下采样和鲁棒的核之外,我们在机器人运动估计的背景下引入了用于ICP的自适应阈值方法,这使得我们的方法有效,同时易于推广。

5.不足

不能够自适应下采样,不适用空间尺度多变的场景
轨迹不够鲁棒,不够平滑

二、方法解析

2.1 系统pipeline

 

输入:点云
输出:位姿与点云地图

  1. 运动预测与点云去畸变
  2. 点云下采样
  3. 在局部地图中寻找最邻近对应点
  4. 自适应ICP迭代优化
    这项工作旨在通过顺序注册扫描仪记录的点云来增量计算移动的激光雷达传感器的轨迹。我们将元件减少到构建有效、精确、稳定且相当简单的激光雷达里程计系统所需的最少数量。对于以局部的、以自我为中心的点云的形式的每个3D扫描,我们执行以下四个步骤来获得在时间t的全局姿态估计TT∈SE(3)。首先,我们应用传感器运动预测和运动补偿(通常称为去扭斜)来消除扫描期间由传感器运动引起的3D数据失真。其次,我们对当前扫描进行二次采样。第三,我们估计输入点云和参考点云之间的对应关系,我们称之为局部地图。我们使用自适应阈值方案进行对应估计,限制可能的数据关联并过滤掉潜在的异常值。第四,我们使用鲁棒的点到点ICP算法将输入点云配准到局部地图。最后,我们用配准扫描的下采样版本更新局部地图。在以下部分中,我们将详细描述这些组件。

详情请转...

从零入门激光SLAM(十四)——简单有效的激光里程计KISS-ICP - 古月居 (guyuehome.com)

这篇关于从零入门激光SLAM(十四)——简单有效的激光里程计KISS-ICP的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/992636

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>