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

一、测量预处理部分(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. 【HAOI 2008】 硬币购物

    [题目链接] 点击打开链接 [算法] 此题是一道好题! 首先,我们发现 : 付款方法数 = 不受限制的方法数 - 受限制的方法数 那么,我们怎么求呢? 我们用dp求出不受限制的方法数(f[i]表示买i ...

  2. Swift4 基础

    创建: 2018/02/17 完成: 2018/02/19 更新: 2018/02/25 补充参照型只有类的实例和闭包 更新: 2018/03/03 加红加粗for-in注意事项, 常量不用也不能声明 ...

  3. 【WIP】外汇与证券交易29个技术指标

    创建: 2017/05/16   更新: 2017/05/30 更新: 2017/10/14 标题加上[WIP],增加创建时间  指标名称  函数原型(prototype)  参考与分析 (refer ...

  4. GIT 初始化 user.name user.email

    git config --global user.name "username" git config --global user.email "email"

  5. bzoj 1079: [SCOI2008]着色方案【记忆化搜索】

    本来打算把每个颜色剩下的压起来存map来记忆化,写一半发现自己zz了 考虑当前都能涂x次的油漆本质是一样的. 直接存五个变量分别是剩下12345个格子的油漆数,然后直接开数组把这个和步数存起来,记忆化 ...

  6. bzoj 3270: 博物馆【dp+高斯消元】

    好像是高斯消元解互相推(?)的dp的例子 首先考虑dp,设f[i][j]为一人在i一人在j的概率,点i答案显然就是f[i][i]: 然后根据题意,得到转移是 \[ f[i][j]=f[i][j]*p_ ...

  7. 洛谷 P4016 负载平衡问题 【最小费用最大流】

    求出平均数sum,对于大于sum的点连接(s,i,a[i]-sum,0),表示这个点可以流出多余的部分,对于小于sum的点连接(i,t,sum-a[i],0)表示这个点可以接受少的部分,然后每个点向相 ...

  8. bzoj 2257[Jsoi2009]瓶子和燃料 数论/裴蜀定理

    题目 Description jyy就一直想着尽快回地球,可惜他飞船的燃料不够了. 有一天他又去向火星人要燃料,这次火星人答应了,要jyy用飞船上的瓶子来换.jyy 的飞船上共有 N个瓶子(1< ...

  9. Intellij IDEA 快捷键整理(史上最全)

    [常规] Ctrl+Shift + Enter,语句完成 “!”,否定完成,输入表达式时按 “!”键 Ctrl+E,最近的文件 Ctrl+Shift+E,最近更改的文件 Shift+Click,可以关 ...

  10. 在myeclipse中maven遇见的问题

    An internal error occurred during: "Retrieving archetypes:". Java heap space 表示你的myeclipse ...