《论文阅读》BALM: Bundle Adjustment for Lidar Mapping

news2024/10/1 17:27:46

留个笔记自用

BALM: Bundle Adjustment for Lidar Mapping

做什么

首先是最基础的,Structure-from-Motion(SFM),SFM可以简单翻译成运动估计,是一种基于dui8序列图片进行三维重建的算法。简单来说就是是从运动中不同角度拍摄一个物体,这样就有多张物体不同时间的照片,使用这种照片来恢复物体的三维结构。跟SLAM里的visual odometry一样,需要估计出每帧图片到世界坐标系的R,t,然后根据图片重建点云。
在这里插入图片描述
算法的关键是就是特征匹配,求两张图片之间的R,T,然后反投影得到物体的三维点,最后将多个稀疏点云融合在一起。
然后是SFM常用的一种算法Bundle Adjustment(BA),光束调整,也就是这篇文章所做的
在这里插入图片描述
在这里插入图片描述
省去复杂的公式,BA做的也是特征匹配的工作,在不同视角的图像中选取特征点,然后将这些特征点之间进行匹配,理论上来说,在整个空间上,这些匹配点如果投影到世界坐标系应该尽可能的接近,比如两张图片中的特征点都是某个桌子的左下角,那么就算在图片上位置不同,经过R,t转回去也应该在空间上位置接近。这就是重投影误差,使用这种方式来优化R,t,同时也会优化特征点的位置。
BA往往做的是精细化建图(空间建图)的工作。

做了什么

在这里插入图片描述
传统的BA都是在视觉领域去使用的,因为如果是在点云领域,稀疏的点会很影响特征的提取,而导致特征匹配效果不佳,在这篇文章中,将BA公式从重投影误差转换成最小化从特征点到其匹配边缘或平面的距离。简单来说,视觉BA是希望重投影的空间点在距离上相近,而雷达BA则是希望投影点是在一个平面上,这种想法和激光雷达的遮挡性有关。

怎么做

在这里插入图片描述
这里的Rsi和tsi表示的是第i帧scan点云的pose,p则是点云中的点,pfi指的是第i个特征点,pi是点在世界坐标系下的坐标(用pose得到的那个)
在这里插入图片描述
这张图就能看到前面的那个意思,pfi是一个集合,表示都是一个特征(平面、边缘)的特征点(可能来自于不同的点云),q是特征平面上的点,而n是特征平面的法向量
所以说,BA的思路就像前面说的转变成了
在这里插入图片描述
第一行这里的p就是前面的那个全局点坐标(投影到世界坐标系的特征点),然后最小化他们之间的距离。就是前面所说的,利用pose投影之后,最小化在同一个世界平面或世界边缘上的点之间的距离,有用到法向量。
然后,这里将要最小化的这个距离写成了λ,表示A矩阵的第三个最大特征值,u表示的是对应的特征向量
在这里插入图片描述
上式中的p是所有投影点p的均值,A是所有点与均值点的距离矩阵,这就是平面特征的优化,这里写的感觉挺复杂的,很数学,简单来说就是这样的,对于投影到同一个平面的所有点p,计算这些点的平均点,然后计算这些点p到平均点的距离矩阵,从这个矩阵中抽几个最大值去最小化。
然后是边缘特征,这里的方式跟平面特征差不多
在这里插入图片描述
在这里插入图片描述
这里的所有标识都和上面一样,很好理解了,就是最小化每个特征点p的投影到边缘代表点q的距离,这里因为是边缘差异,所以构造了一个秩Tr计算平均距离。
总的来说,BA就是最小化这个最大特征值
在这里插入图片描述
接下来就是为了给出了优化这个的过程,首先列了两个定理
在这里插入图片描述
对于一组特征点p,它的协方差矩阵具有可解的特征向量和对应的特征值
然后是第二个定理
在这里插入图片描述
对于一组点和它的协方差矩阵A,它的特征值和特征向量满足上述式子。
总的来说,这里就是列了两个定理去进行关于λ的一阶导和二阶导的推导,为了后面的优化求解,公式确实很复杂,还是看后面推导的简化结果吧
有了这里的一阶导和二阶导结果,就可以把前面的λ改写
在这里插入图片描述
这其实跟传统的BA的推导流程很相似了,J是雅各比矩阵,H是海瑟矩阵
然后是再进一步变化这里的p,已知
在这里插入图片描述
T就是pose,这里就是把T的一阶导差值也加上
然后就可以把对点p的投影(原来是用R,t)改写成
在这里插入图片描述
为了简化体现,定义一个代号D为点pose关于T的一阶导矩阵
在这里插入图片描述
最后就可以将整个式子改写成
在这里插入图片描述
在这里插入图片描述
这里涉及到的数学分析有点复杂,虽然大致的意思是最小化特征点到平面和边缘的距离,但实现起来确实不容易,这篇文章有开源代码,有机会的话可以去理解一下
除了对LiDAR BA的设计外,这篇文章还提出了一个自适应体素化的方法,主要是为了解决一个问题,前面说的所有方法都需要找到特征点,并且是属于同一个平面或者边缘的特征点。简单来说,这里的方法就是,首先对所有点云用一个初始值的voxel进行体素化,如果当前voxel中的所有特征点都位于平面或者边缘上,就将voxel八分化,然后检查这8个小voxel,直到存在非特征点。
在这里插入图片描述

效果

在这里插入图片描述
LIVOX数据集上作为LOAM后处理所修生的全局偏移
在这里插入图片描述

总结

1.将BA从视觉领域扩展到了雷达领域,用一系列复杂的数学公式阐述了方法,从最小化特征点投影的距离改成了最小化投影点到特征平面和边缘的距离
2.提出了一种自适应体素化的方法,但其实就是设个大值然后遍历,这种方法的效率比较低但也算实用,这也能看出在LiDAR中voxel的设置是个很大的问题

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

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

相关文章

12月2日第壹简报,星期五,农历十一月初九

12月2日第壹简报,星期五,农历十一月初九1. 银保监会:2023年1月起在北京、上海、江苏、浙江、福建、广东等10个省市开展商业养老金业务试点。2. 国家首批未来产业科技园试点名单出炉:空天科技未来产业科技园、未来能源与智能机器人…

2022-12-02 编译Android平台OpenCV,用到读取视频时报错:AMediaXXX

文章目录编译Android平台OpenCV,用到读取视频时报错:解决参考编译Android平台OpenCV,用到读取视频时报错: ld: error: undefined symbol: AMediaExtractor_new ld: error: undefined symbol: AMediaExtractor_setDataSourceFd ld…

PyQt5的安装

0. 准备工作 Anaconda3-5.2.0-Windows-x86_64pycharm-professional-2018.2.4PyQt5 5.8.1 1. 如何正确安装PyQt5? 1.1 安装PyQt5 pip install PyQt5 -i https://pypi.douban.com/simple- i表示指定安装源,表示国内源 https://pypi.douban.com/simple …

创建一个SpringCloud项目

文章目录1.首先在**SpringCloud官网**中查看依赖版本号2.创建主Maven项目:在pom文件中引入依赖3.再在这个Maven项目中创建子模块(子模块也是Maven)(1)创建一个数据库db01和表dept(2)创建实体类dept(注意:**每个实体类都…

导包问题解决--ImportError: DLL load failed while importing _path: 找不到指定的模块

一、问题反馈 在运行某个Python程序时,需要导入numpy和matplotlib包如下: import numpy as np import matplotlib.pyplot as plt运行程序时会报错“ImportError: DLL load failed while importing _path: 找不到指定的模块”: 二、问题解决…

信号发生器的电路构成及工作原理

一、信号发生器的电路构成 信号发生器的电路组成有多种形式,一般包括以下几个环节: 基本波形产生电路:波形产生可以由RC振荡器、文丘里电桥振荡器或压控振荡器产生。 波形转换电路:基本波形由正弦波、方波、三角波经过矩形波整形电路、正弦波整形电路、三角波整形电…

经众多Nature文章使用认证!艾美捷抗酒石酸酸性磷酸酶TRAP染色试剂盒

抗酒石酸酸性磷酸酶(TRAP,tartrate-resistant acid phosphatase)为破骨细胞的标志酶,特异地分布于破骨细胞中,为破骨细胞所特有。通常作为鉴别破骨细胞的重要标志物,使破骨细胞呈红色。Kamiya艾美捷抗酒石酸…

Java单表实现评论回复功能

Java单表实现评论回复功能1.简介2.功能实现图3.数据库设计4.实体类5.实现思路6.功能实现6.1 Sql入手6.2 业务实现7.前端实现8.最终成果1.简介 最近在写毕业设计的时候发现需要实现一个评论功能,然后看了一下掘金和csdn的评论区,如何实现评论功能&#xf…

【已解决】nginx x-cache: MISS

nginx x-cache: MISS 今天在使用nginx的时候发生了巨无语的一件事,明明我已经配置了代理缓存proxy_cache,但是一直未生效,于是我不断进行排错、nginx -s reload,问题始终没有解决。后来我尝试在另一台服务器上使用相同的配置&…

Docker的数据管理(数据卷、容器互联)

Docker的数据管理Docker的数据管理(数据卷、容器互联)一、数据卷(容器与宿主机之间数据共享)创建数据卷容器写入数据宿主机写入数据容器只有读的权限二、数据卷容器(容器与容器之间数据共享)创建两个数据卷…

yocs_velocity_smoother速度平滑库知识

一.C &#xff08;1&#xff09;nth_element()用法 头文件&#xff1a;#include<algorithm> nth_element:在数组或容器中将第几大或小的元素放到该放的位置上。&#xff08;默认第几小&#xff0c;可以用cmp自定义为第几大&#xff09; 如&#xff1a;nth_element(a,…

一篇文章搞懂:词法作用域、动态作用域、回调函数及闭包

前言 把以前一直只限于知道&#xff0c;却不清晰理解的这几个概念完完整整地梳理了一番。内容参考自wiki页面&#xff0c;然后加上自己一些理解。 词法作用域和动态作用域 不管什么语言&#xff0c;我们总要学习作用域(或生命周期)的概念&#xff0c;比如常见的称呼&#xf…

Flutter ーー logger 组件记录日志

Flutter ーー logger 组件记录日志 原文 https://medium.com/simbu/flutter-logging-with-logger-6227308ca199 前言 是时候添加一些日志记录了&#xff0c;我希望能够检查发生的网络请求和关键操作&#xff0c;在应用程序和后端之间的交互变得越来越复杂的情况下&#xff0c;给…

vue2自定义指令及钩子函数

目录​​​​​​​ 一、自定义指令的生命周期 二、局部自定义指令 三、全局自定义指令 1.定义自定义指令 2. index.js install方法安装自定义指令 3. main.js 全局挂载自定义指令 4.使用全局自定义指令 一、自定义指令的生命周期 在Vue中&#xff0c;自定义指令的生命…

晶振不仅仅是可以振荡就够了

晶振相当于人的心脏&#xff0c;能跳动&#xff0c;整个系统才是“活的”。晶振常见有有源晶振、无源晶振。有源晶振比较贵&#xff0c;但是需要外围电路少&#xff0c;供个电就能工作。无源晶振价格便宜&#xff0c;匹配电路复杂些。以无源晶振进行分析&#xff0c;以下是无源…

华为IdeaHub与华为云会议:软硬结合,天生一对

伴随数字化进程&#xff0c;传统视频会议终端存在着配置成本高昂、操作繁琐、组网复杂、需专业维护等问题&#xff0c;已无法满足企业数字化转型的需求&#xff0c;而会议软件使用便捷&#xff0c;但仍存在着与设备兼容性差、画面清晰度低、稳定性及信息安全等问题。面对市场上…

【疑难攻关】——文件包含漏洞

作者名&#xff1a;Demo不是emo 主页面链接&#xff1a;主页传送门 创作初心&#xff1a;舞台再大&#xff0c;你不上台&#xff0c;永远是观众&#xff0c;没人会关心你努不努力&#xff0c;摔的痛不痛&#xff0c;他们只会看你最后站在什么位置&#xff0c;然后羡慕或鄙夷座…

线性回归实现原理

一.定义 回归是监督学习的一个重要问题&#xff0c;回归用于预测输入变量和输出变量之间的关系&#xff0c;特别是当输入变量的值发生变化时&#xff0c;输出变量的值也随之发生变化。回归模型正是表示从输入变量到输出变量之间映射的函数 回归的目的是预测数组型的目标值。 …

并查集的学习

并查集是一种树型的数据结构&#xff0c;并查集可以高效地进行如下操作&#xff1a; 1、查询元素p和元素q是否属于同一组 2、合并元素p和元素q所在地组 并查集结构&#xff1a; 是一种树型结构&#xff0c;这棵树地要求比较简单 1、每个元素都唯一对应一个节点 2、每一组数…

iOS打包错误The operation couldn’t be completed. (AppThinning.StubError error 1.)

1、iOS打包错误 iOS打包报错&#xff1a;The operation couldn’t be completed. (AppThinning.StubError error 1.) 操作流程&#xff1a;archive之后选择Distribute App&#xff0c;在如上图步骤选择 Ad Hoc&#xff0c;然后出现The operation couldn’t be completed. (Ap…