这是整篇论文的架构,下面针对每一部分进行自己的详细理解。(数学公式的问题没在博客里面解决,都是论文中的截图,尽可能美观==)

一、测量预处理部分(MEASUREMENT PREPROCESSING)

这部分做了两件事情(1)视觉前端处理(2)IMU预积分

(1)首先使用KLT稀疏光流法跟踪图片中的特征点,检测器通过设置两个相邻特征之间的像素的最小分离来执行均匀的特征分布,每张图片的特征点数目在100-300。检测出来的2D特征点经过F矩阵的RANSAC去除外点,然后投影到一个单位球面。

  同时,该阶段选择关键帧,关键帧的选择有2个条件。①平均视差。②特征点的数量。注意:平均视差是由平移和旋转引起的,但是纯旋转是没有办法进行三角化的,为了弥补这一部分采用IMU短期预积分;另外特征点数量低于阈值的时候,可能会完全丢失特征点,故选出来做关键帧。

(2)IMU预积分是这部分的重点。

原始IMU的测量值为:

假设噪声服从高斯分布:

由于加速度偏差和陀螺仪的偏差为随机游走建模,所以他们的导数也服从高斯分布。即:

我们的估计器是需要估计位置p,速度v和旋转q的,它们满足下面的迭代式:

从式子(3)中可以看出来,当前时刻的状态可以通过上一时刻状态来迭代求得,这个式子包含积分,表示t时刻世界坐标系下的旋转,是一个需要估计的量。这个估计的量是需要不断地更新变化,如果按照式子(3)进行计算,那么每次进行变化都需要重新积分,这很消耗计算资源。故在(3)中左右同时乘以一个旋转矩阵Rw->bk,这样就把坐标系转换到了bk下,当状态量变化的时候,可以通过矩阵乘法把相对变化量变成绝对变化量。(可以这么理解:绝对变化量是不变的,相对变化量是变化的。所以这样做是为了较少计算负担)当然这样做的目的如下:

1. 相对k帧的IMU进行积分,不会有累积误差;

2. 即使后面调整了位姿,相对位置不变;

3. 这个旋转矩阵为单位矩阵E,后面每出现一个IMU数据,都可以用任何一种数值积分的方法计算;同时可以将重力加速度提取到积分号外面不参加积分,相当于在重力参考系中积分,计算量也会减少。

于是,得到(5)式:

离散时间的计算:

论文中使用的是Euler积分方式,代码中使用的是中值积分。

当变化量是较小的时候,可以使用一阶近似求得α,β和γ;如果变化比较大,再重新计算。

对于离散时间的估计量的计算式(7):(假设噪声项为0)

得到当前需要优化的变量的雅可比矩阵J和协方差矩阵P,最后得到从k到k+1的测量量,用当前的状态两计算出来的就是估计,相减就是残差。观测方程:

IMU积分后,会全部给后端ceres做优化。

VINS-Mono论文笔记(未完)的更多相关文章

  1. Go web编程学习笔记——未完待续

    1. 1).GOPATH设置 先设置自己的GOPATH,可以在本机中运行$PATH进行查看: userdeMacBook-Pro:~ user$ $GOPATH -bash: /Users/user/ ...

  2. jQuery 学习笔记(未完待续)

    一.jQuery概述    宗旨: Write Less, Do More.    基础知识:        1.符号$代替document.getElementById()函数        2.使 ...

  3. linux学习笔记---未完待续,缓慢更新

    做为linux菜鸟,由于work的需要,慢慢的开始接触学习linux. <鸟哥的linux私房菜>学习笔记. 一.基础命令操作 1.显示日期的命令 date 执行date命令后,显示结果为 ...

  4. oracle-绑定变量学习笔记(未完待续)

    --定义变量SQL> var a number; --给绑定变量赋值SQL> exec :a :=123; PL/SQL procedure successfully completed. ...

  5. Java学习笔记(未完待续)

    变量的作用域(scope)是指变量可以在程序中引用的范围.在方法中定义的变量称为局部变量(local variable).局部变量的作用域从声明变量的地方开始,直到包含该变量的块结束为止.局部变量都必 ...

  6. JavaScript设计模式:读书笔记(未完)

    该篇随我读书的进度持续更新阅读书目:<JavaScript设计模式> 2016/3/30 2016/3/31 2016/4/8 2016/3/30: 模式是一种可复用的解决方案,可用于解决 ...

  7. Hbase客户端API基础小结笔记(未完)

    客户端API:基础 HBase的主要客户端接口是由org.apache.hadoop.hbase.client包中的HTable类提供的,通过这个类,用户可以完成向HBase存储和检索数据,以及删除无 ...

  8. Greys学习笔记(未完待续)

    Greys介绍 greys-anatomy是一个Java线上诊断工具,取名来自美剧<实习医生格雷>,由菜鸟-杜琨同学开发维护.比我们常用的脚本工具btrace提供更多的功能,greys采用 ...

  9. Java并发笔记-未完待续待详解

    为什么需要并行? – 业务要求 – 性能 并行计算还出于业务模型的需要 – 并不是为了提高系统性能,而是确实在业务上需要多个执行单元. – 比如HTTP服务器,为每一个Socket连接新建一个处理线程 ...

  10. cordforce Educational Codeforces Round 47 补题笔记 <未完>

    题目链接 http://codeforces.com/contest/1009 A. Game Shopping 直接模拟即可,用了一个队列来存储账单 #include <iostream> ...

随机推荐

  1. Ubuntu 搭建 LAMP 服务器

    /******************************************************************** * Ubuntu 搭建 LAMP 服务器 * 说明: * 想 ...

  2. Watir: element_by_xpath 的使用

    b =Watir::IE.new b.goto'http://www.google.com/' txt =b.element_by_xpath("//*[@name='q']") ...

  3. Ruby的一些常用全局变量

    $! latesterror message $@ locationof error $_ stringlast read by gets $. linenumber last read by int ...

  4. python的for...in...if...语句

    Python中,for...[if]...语句一种简洁的构建List的方法,从for给定的List中选择出满足if条件的元素组成新的List,其中if是可以省略的.下面举几个简单的例子进行说明. &g ...

  5. 异常处理:Cannot attach the file as database 'membership'.

    Cannot attach the file 'D:\GitHome\cae\CAE\App_Data\membership.mdf' as database 'membership'. 说明: 执行 ...

  6. E20180309-hm-xa

    conformance   n. 顺应,一致; symmetric   adj. 相称性的,均衡的; raw  adj. 生的,未加工的; 无经验的; 新近完成的; 发炎的,疼痛的; exceed  ...

  7. CCF2016.4 - B题

    思路:创建两个bool数组来模拟下落过程,一个存放面板状态,一个存放下落的格子.检测格子和面板对应位置是否同时为True,如果是则有冲突,不能继续下落,否则增加行号.为了统一处理,我们把面板最下面加一 ...

  8. Luogu P3619 魔法 【贪心/微扰证明】

    题目描述 cjwssb知道是误会之后,跟你道了歉.你为了逗笑他,准备和他一起开始魔法.不过你的时间不多了,但是更惨的是你还需要完成n个魔法任务.假设你当前的时间为T,每个任务需要有一定的限制ti表示只 ...

  9. _bzoj1026 [SCOI2009]windy数【数位dp】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1026 数位dp果断记忆化搜索,代码量少~ 程序里我用11代表前导零. #include &l ...

  10. hihoOffer收割练习20题目1

    题目1 : 无根数变有根树 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定一棵包含 N 个节点的无根树,小Hi想知道如果指定其中某个节点 K 为根,那么每个节点的父 ...