VIO外参标定方法总结

2024-04-26 20:20
文章标签 总结 方法 vio 标定 外参

本文主要是介绍VIO外参标定方法总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、前言

VIO外参标定是指相机和IMU之间的转移矩阵的确定,包括3×3的旋转矩阵和3维平移向量。整体上分为离线标定和在线标定两类方法,这篇文章做一个总结,主要是经典的方法,记录其思想。

二、博文链接

1、离线标定方法

最基本的当然就是人工手动标定了,但这样不仅费力,并且误差大不够准确,作为初始猜测还可以。

VIO最知名的离线标定工具就是Kalibr了。

GitHub - ethz-asl/kalibr: The Kalibr visual-inertial calibration toolboxThe Kalibr visual-inertial calibration toolbox. Contribute to ethz-asl/kalibr development by creating an account on GitHub.icon-default.png?t=N7T8https://github.com/ethz-asl/kalibrKalibr标定的基本原理

https://www.cnblogs.com/mybrave/p/9675936.htmlicon-default.png?t=N7T8https://www.cnblogs.com/mybrave/p/9675936.html

camera-imu内外参标定 - 知乎在vio系统中,camera-imu间内外参精确与否对整个定位精度起着重要的作用。所以良好的标定结果是定位系统的前提工作。 目前标定算法主要分为离线和在线标定,离线标定以kalibr为代表,能够标定camera内参、camera-i…icon-default.png?t=N7T8https://zhuanlan.zhihu.com/p/68863677Camera-IMU联合标定原理 | AI技术聚合Camera-IMU联合标定原理一.相机投影模型二.IMU 模型三.Camera-IMU标定模型(一) 相机-IMU旋转(二) 相机-IMU平移(三) 视觉惯性代价函数四. camera-imu联合标定(一) 粗略估计camera与imu之间时间延时(二) 获取imu-camera之间初始旋转,还有一些必要的初始值:重…icon-default.png?t=N7T8https://aitechtogether.com/python/142928.html手眼标定

机器人视觉标定(二)手眼标定 - 知乎在(一)中已经介绍了线结构光标定,通过线结构光可以得到物体被照射激光部分的相机三维坐标。当机械手臂安装了线结构光传感器后,相当于被安装了眼睛,得到相机三维坐标相当于眼睛看到了物体的位置,这时就需要眼睛…icon-default.png?t=N7T8https://zhuanlan.zhihu.com/p/78855930

2、在线标定方法

VINS-mono外参标定原理
https://zhuanlan.zhihu.com/p/413096765icon-default.png?t=N7T8https://zhuanlan.zhihu.com/p/413096765解放双手|教你进行相机与IMU外参的在线标定 - 计算机视觉life的文章 - 知乎
https://zhuanlan.zhihu.com/p/70760958icon-default.png?t=N7T8https://zhuanlan.zhihu.com/p/70760958

三、VIO在线外参标定典型方法详解

1、自动标定:

单目相机通过对极几何和随机采样一致性确定两帧图像之间的相对旋转,IMU可以得到自己坐标系下的前后两帧图像之间相对旋转,根据手眼标定方法,结合多帧数据,可以得到关于旋转的超定方程,利用优化方法则可以得到相机和IMU之间的旋转外参。

2、在线估计:

求外参残差关于位移和旋转的雅可比

四、VINS-mono的外参标定

VINS-mono上使用的外参自动标定与在线标定算法,来自Monocular_VisualInertial_State_Estimation_With_Online_Initialization_and_CameraIMU_Extrinsic_Calibration这篇论文。整体的流程方法如下:

手眼标定原理:

结合上图, 相邻Camera关键帧对应pose可以由两种方式(为后面构建方程铺垫):

a.八点法算法(solveRelativeR)

b.Imu预积分并与结合

标定转换

红色线蓝色线得到的变换值理论上应该相同,则可通过假设从Camera坐标系到Imu坐标系相对旋转量为即q和R ,进一步可构建方程并求解(vins-mono使用SVD求解方法)

根据手眼标定原理与上述原理,得到(4),转换成四元数格式,经过整理得到形如Ax=0的(7)式。

在求解过程中,因为上面在求解帧间的R、T变换时是用对极约束算法,该方法避免不了有错误的匹配等(outlier),因此对Ax=0中A矩阵加权计算从而增加在线标定结果鲁棒性,加权的计算方式(近似the Huber norm计算方式)参考作者引用的标定论文中的式8、9,如下

为什么奇异值大于0.25才认为标定成功?

代码中ric_cov(1) > 0.25,为倒数第二小的奇异值。最小的奇异值接近0(奇异值大于0,且通常前面几个大的奇异值总和能占所有奇异值总和的一大部分),这里给了个阈值,看其是否足够大,每个奇异值大小可以理解为分方向的力度大小。这边用0.25来限定倒数第二小的奇异值,是判断不为0的奇异解中,最终求解的奇异值是否是只有一个接近于0,最优解只有一个,如果有多个接近0,都很小的话,那么该最小奇异解很可能不是最优,从而间接可以判断在标定过程中是否有充足的旋转等。

速度,姿态,特征深度和相机- IMU平移的线性初始化:一旦相机- IMU旋转固定,我们可以估计相机- IMU的平移,同时初始化速度,姿态和特征深度,以及IMU相对于初始参考帧的姿态。线性初始化通过最小化滑动窗口内IMU和单目相机所有测量误差的马氏范数之和进行最大似然估计。

值得注意的是,在这个线性初始化阶段,我们重用了用于相机- IMU旋转标定的传感器测量值,但

固定为常数。我们还直接使用陀螺仪测量值短期积分得到的增量和相对旋转。由于这种线性初始化通常只能在几秒内完成,直接使用IMU旋转不会造成明显的漂移。

进一步细化:

VINS-Mono在获得旋转变换之后,在进行VIO的过程中,将相机与IMU外参作为优化参数在整个算法运行过程中进行矫正,从而保证外参的准确性。

在状态初始化和获得相机- IMU标定后,进行了滑动窗口非线性估计器,以进行高精度的状态估计和标定优化。这是文献[ 7 ]和文献[ 8 ]的扩展,将相机- IMU标定纳入非线性优化中。由于非线性优化中的大量参数与线性初始化中的参数具有相同的物理意义,这里我们通过重用符号来表示状态向量( X )、雅克比矩阵( H、F、G)、协方差矩阵( P , Q)和信息矩阵( A ),从而引入了符号的轻微滥用。

全状态的定义类似于线性情况,除了全6 - DOF相机- IMU变换包含在状态向量中。同样将重力矢量替换为四元数,对IMU平动和转动(转置再次被忽略)进行联合优化,我们最小化所有测量残差的马氏范数之和以获得最大后验估计。

我们使用误差状态表示法[ 6 ]将非线性系统( 23 )线性化,并使用具有Huber范数的Gauss - Newton算法[ 30 ]求解,以实现鲁棒的异常值剔除。位置、速度和特征深度等线性分量的残差可以很容易地定义为最新状态估计的补充。

这篇关于VIO外参标定方法总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

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

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

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

二分最大匹配总结

HDU 2444  黑白染色 ,二分图判定 const int maxn = 208 ;vector<int> g[maxn] ;int n ;bool vis[maxn] ;int match[maxn] ;;int color[maxn] ;int setcolor(int u , int c){color[u] = c ;for(vector<int>::iter

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000