• VINS中的重力-尺度-速度初始化(2)


    VINS中的重力-尺度-速度初始化(2)

    细化重力

    上一篇文章中得到的 g 一般是存在误差的。因为在实际应用中,当地的重力向量的模一般是已知固定大小的(所以只有两个自由度未知),而我们在前面求解时并没有利用这个条件,因此最后计算出来的重力向量很难刚好满足这个条件。于是,在vins的初始化中,还会对得到的重力向量进行修正。

    首先,作者对重力向量进行参数化:

    g^=gg^+w1b1+w2b2=gg^+b3×2w2×1

    其中,g^是上一步中估计得到的重力向量方向的单位向量,b1b2是另外两个单位向量,是g^切平面上的两个互相垂直的单位向量,获得方式如下:

    此时我们可以从上面的式子知道,原本三维的优化变量 gc0 已经可以使用两维的 w2×1 替代。参考上一节的推导,待优化变量变成了

    [vbkbkvbk+1bk+1w2×1s]

    最后得到的观测方程也变为了

    [IΔtk012Rc0bkΔtk2bRc0bk(pck+1c0pckc0)IRc0bkRbk+1c0Rc0bkΔtkb0][vbkbkvbk+1bk+1ws]=[αbk+1bk+Rc0bkRbk+1c0pcbpcb12Rc0bcΔtk2gg^^βbk+1bkRc0bkΔtkgg^]

    基于新得到的观测方程(可以使用LDLT分解求解),我们可以通过重力约束不断地对初始化结果进行修正,迭代对其 进行求解(vins中迭代了4次),最后得到一个修正后的初始化结果。

    与世界坐标系对齐

    这一步一般是最后一步,一般世界坐标系选择的是东北天坐标系。则这个对齐操作就是得到将重力向量旋转到Z轴上的旋转矩阵,这个旋转矩阵就是将原本坐标变换到世界坐标系(东北天坐标系)的变换矩阵。

    找到这个变换矩阵后,接下来就是使用这个变换矩阵将位姿,速度等状态信息都变换到世界坐标系下。

    加速度计bias

    通过上面的阅读,我们会发现在vins的初始化中并没有对加速度计的bias进行估计,感觉对于超定的方程,多计算一个加速度计的bias好像也不是什么难事,,而且建模应该会更准确。在这个初始化工作的论文中其实有解释原因:

    1. 通过仿真实验证明,如果运动不剧烈,加速度计的bias很难被观测出来;
    2. 忽略加速计的bias对估计其他初始值的影响不大;
    3. 加速度计的bias是可以通过之后的VIO紧耦合优化,慢慢估计出来的;

    参考资料

  • 相关阅读:
    编写高质量代码改善程序的157个建议:使用Dynamic来简化反射的实现
    Redis之性能指标、监控方式
    如何使用C/C++刷新在终端上已经打印的内容
    约数及约数个数,约数乘积的计算
    RT Preempt linux学习笔记
    AJAX(一):初识AJAX、http协议、配置环境、发送AJAX请求、请求时的问题
    数据结构与算法:链式二叉树
    冒泡排序给cpu干懵了 哈哈 还有希尔排序 算法补充(学习笔记)
    django-rest-framework 基础四 过滤、排序、分页、异常处理
    【无标题】
  • 原文地址:https://www.cnblogs.com/weihao-ysgs/p/vins-init-g.html