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

一、测量预处理部分(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. poj 3130 How I Mathematician Wonder What You Are! 【半平面交】

    求多边形的核,直接把所有边求半平面交判断有无即可 #include<iostream> #include<cstdio> #include<algorithm> # ...

  2. NOIp2013 货车运输 By cellur925

    题目传送门 A 国有 n 座城市,编号从 1 到 n ,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重. 现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下 ...

  3. 【原创】《从0开始学Elasticsearch》—集群健康和索引管理

    内容目录 1.搭建Kibana2.集群健康3.索引操作 1.搭建Kibana 正如<Kibana 用户手册>中所介绍,Kibana 是一款开源的数据分析和可视化平台,因此我们可以借助 Ki ...

  4. linux 查看进程和端口

    1.进程查看 #ps aux | grep java 2.查看系统与内核相关信息 #uname [-asrmpi] 查看系统位数 # uname -m 3.查看端口 #netstat [-aatunl ...

  5. [POI2012]Vouchers

    Description 考虑正整数集合,现在有n组人依次来取数,假设第i组来了x人,他们每个取的数一定是x的倍数,并且是还剩下的最小的x个. 正整数中有m个数被标成了幸运数,问有哪些人取到了幸运数. ...

  6. Poj 2112 Optimal Milking (多重匹配+传递闭包+二分)

    题目链接: Poj 2112 Optimal Milking 题目描述: 有k个挤奶机,c头牛,每台挤奶机每天最多可以给m头奶牛挤奶.挤奶机编号从1到k,奶牛编号从k+1到k+c,给出(k+c)*(k ...

  7. 题解报告:poj 2299 Ultra-QuickSort(BIT求逆序数)

    Description In this problem, you have to analyze a particular sorting algorithm. The algorithm proce ...

  8. 首先定义一个5X8的二维数组,然后使用随机数填充满。借助Arrays的方法对二维数组进行排序。

    package day02; import java.util.Arrays; import java.util.Random; public class Test01 { public static ...

  9. leaflet在地图上加载本地图片

    <link href="~/Scripts/Leaflet/leaflet.css" rel="stylesheet" /><script s ...

  10. composer Failed to decode zlib stream 无法解码zlib流

    Win7 中安装 Composer (PHP) 国内有些网络不能访问美国的Composer官网,可访问 Composer 中文网 学习. 目标 可以在任何目录下的项目中执行 PHP composer. ...