这对于直接方法是特别有益的:众所周知直接图像对准是非凸的,并且只有在足够准确的初始估计可用时才能预期收敛。虽然在实践中像粗到精跟踪这样的技术会增加收敛半径,但是紧密的惯性积分可以更有效地解决这个问题,因为附加的误差项和先前的结果确保即使对于快速运动也能收敛。我们表明它甚至允许在没有视觉信息的情况下通过短间隔进行跟踪,例如 将相机对准白墙造成的。此外,惯性测量可以观察到全局滚转和俯仰,减少了平移3D运动和偏航旋转的全局漂移。

IMU通常以比相机的帧速率高得多的频率操作,并且可以测量重力方向并消除滚动和俯仰角度的漂移。然而,IMU的缺点是它们仅通过旋转速度和线性加速度间接测量相对姿势。它们噪声很大,需要积分并补偿重力,这在很大程度上取决于姿态估计的准确性。测量带有未知的漂移偏差,需要使用外部参考(如视觉)进行估算。虽然IMU信息是递增的,但是任何图像可以彼此对齐并且具有足够的重叠。这允许在不是直接时间序列的图像之间结合相对姿势测量 - 使得能够进行更一致的轨迹估计。

A. Direct Semi-Dense Stereo Odometry

我们基于Stereo LSD-SLAM进行视觉跟踪[5]:

我们跟踪摄像机朝向地图中的参考关键帧的运动。如果相机距离现有关键帧太远,我们会创建新的关键帧。

我们根据静态和时间双目提示估计当前参考关键帧中的半密集深度图。对于静态立体声,我们利用双目配置中的一对相机之间的固定基线。基于跟踪的运动,从参考关键帧中的像素对应关系向后续图像估计时间立体声。

在跟踪和建图框架中,使用时间立体补充静态有几个好处。静态立体声使重建比例可观察。它也独立于相机移动,但受限于恒定基线,这将静态立体声限制在有效的操作范围内。时间立体声需要非简并的相机移动,但不受[4]中所示的特定范围的约束。该方法可以同时重建非常小和非常大的环境。最后,通过静态与时间立体声的组合,可获得多个基线方向:静态立体声通常具有水平基线 - 其不允许沿水平边缘估计深度,时间立体声允许通过提供其他运动方向来完成深度图。

1)直接图像对准:通过最小化光度残差来估计两个图像I 1和I 2之间的姿势

其中ρ是Huber规范。 使用迭代重新加权的Levenberg-Marquardt算法最小化该目标。

2)深度估计:针对具有高图像梯度的关键帧的像素估计场景几何,因为它们提供稳定的视差估计。

B. IMU Integration

我们的IMU误差函数项的基础是以下非线性动力学模型。

IMU测量通常以比相机帧高得多的频率到达。我们不为每个单独的IMU测量添加独立残差,而是将测量结果集成到图像帧之间的压缩IMU测量中。如果姿势或偏差估计在优化期间发生变化,为了避免频繁重新积分,我们遵循[22]和[14]中提出的预积分方法。我们在IMU坐标系中的时间戳i和j之间积分IMU测量值并获得伪测量值Δpi→j,Δvi→j和R i→j。

我们用Δpi→i = 0,Δvi→i = 0,R i→i = I初始化伪测量,假设IMU测量之间的时间是Δt,我们积分原始测量值:

给定初始状态和综合测量,可以预测下一个时间步的状态:

对于先前状态s i-1和IMU测量帧i和i-1之间的i-1,ωi-1,该方法产生预测

C. Optimization

方程中的误差函数(3)可以写成

权重使用迭代重加权最小二乘法对光度残差r I实现Huber范数,或者对应于IMU残差r IMU的逆协方差(等式(16))。我们使用Levenberg-Marquardt方法优化了这个目标。线性化当前状态周围的残差

误差函数E(s)可以用二次函数近似在当前状态s周围

D. Partial Marginalization

为了约束优化问题的大小,我们执行部分边缘化并将优化状态集保持在小的常量大小。为了约束优化问题的大小,我们执行部分边缘化并将优化状态集保持在小的常量大小。具体地,我们仅针对当前帧状态s i,前一帧s i-1的状态以及用于跟踪的参考帧的状态s ref进行优化。如果我们将状态空间s分成sλ和sμ,其中sλ是我们想要保持在优化中的状态变量,并且sμ是我们想要边缘化的状态的部分,我们可以重写更新 步骤如下

我们发现将Schur补集应用于系统的上半部分

它表示E *(sλ)的系统,其中状态sμ被边缘化。 图3显示了在将每个新帧添加到图形之后应用边缘化过程的图形演变。

E. Changing the Linearization Point

部分边际化固定了sλ的线性化点,用于涉及方程中的sμ和sλ的量。(25)。然而,进一步的优化改变了线性化点,从而需要重新线性化。我们使用一阶近似避免了繁琐的显式重新线性化。如果我们用旧的线性化点sλ和增量Δsλ表示新的线性化点s0λ,

我们可以改变当前E *的二次近似的线性化点

只有当Δsλ和δsλ都很小时才进行近似 - 因为两者都代表状态的更新,这是一个有效的假设。然后我们可以近似在s0λ附近线性化的误差函数:

F. Statistical Consistency

VII. C ONCLUSION

我们提出了一种直接,紧密集成的视觉惯性测距法的新方法。它结合了完全直接的结构和运动方法 - 基于每像素深度而不是单独的关键点观察 - 采用紧密的,基于最小化的IMU集成。我们展示了两个传感器源在理想情况下相互补充:立体视觉允许系统补偿长期IMU偏差漂移,而短期IMU约束有助于克服光度跟踪配方中的非凸性,允许跟踪大型 帧间运动或没有视觉信息的间隔。我们的方法可以在跟踪精度方面优于现有的基于特征的方法,同时提供准确的半密集3D环境重建,同时在标准笔记本电脑CPU上实时运行。

Direct Visual-Inertial Odometry with Stereo Cameras的更多相关文章

  1. 视觉惯性里程计Visual–Inertial Odometry(VIO)概述

    周围很多朋友开始做vio了,之前在知乎上也和胖爷讨论过这个问题,本文主要来自于知乎的讨论. 来自https://www.zhihu.com/question/53571648/answer/13772 ...

  2. Trifo-VIO:Roubst and Efficient Stero Visual Inertial Odometry using Points and Lines论文笔记

    这是2018-IROS上的一篇文章,亮点是作者提出了Lines特征的VIO方案,还有就是提出一个新颖的回环检测,不是用传统的基于优化的方法或者BA,另外作者还发布了一个新的用于VIO的数据集.亮点主要 ...

  3. 论文阅读——Visual inertial odometry using coupled nonlinear optimization

    简介:论文提出一种新的视觉里程计算法,其直接利用带噪声的IMU数据和视觉特征位置来优化相机位姿.不同于对IMU和视觉数据运行分离的滤波器,这种算法将它们纳入联合的非线性优化框架中.视觉特征的透视重投影 ...

  4. Omnidirectional DSO: Direct Sparse Odometry with Fisheye Cameras 论文摘要

    1. Abstract 通过一种Unified Omnidirectional Model作为投影方程. 这种方式可以使用图像的所有内容包括有强畸变的区域,而现存的视觉里程计方案只能修正或者切掉来使用 ...

  5. Direct Line Guidance Odometry论文阅读笔记

    摘要: 本文特色:使用线引导关键点的选择.本文提出这个的论点是:线上的点比图像的其他部分的点更好,而且线上存在更好的关键点.选择线上的点可以筛选过滤掉不太明显的点,从而提高效率. 点和线: 系统使用点 ...

  6. Paper Reading: Stereo DSO

    开篇第一篇就写一个paper reading吧,用markdown+vim写东西切换中英文挺麻烦的,有些就偷懒都用英文写了. Stereo DSO: Large-Scale Direct Sparse ...

  7. 三维重建7:Visual SLAM算法笔记

    VSLAM研究了几十年,新的东西不是很多,三维重建的VSLAM方法可以用一篇文章总结一下. 此文是一个好的视觉SLAM综述,对视觉SLAM总结比较全面,是SLAM那本书的很好的补充.介绍了基于滤波器的 ...

  8. Monocular Visual-Inertial Odometry单目视觉惯性里程计

    Monocular Visual-Inertial Odometry:https://www.qualcomm.com/invention/research 单目视觉-惯性里程计 INDOOR POS ...

  9. A Benchmark Comparsion of Monocular Visual-Inertial Odometry Algorithms for Flying Robots论文笔记

    摘要: 本文主要比较单目VIO的算法在飞行机器人上运行的性能,测试使用统一数据集为EuRoC.其中评价指标为:姿态估计精度.每帧处理时间以及CPU和内存负载使用率,同时还有RMSE(运行轨迹与真实轨迹 ...

随机推荐

  1. OpenCV 学习笔记 05 人脸检测和识别 AttributeError: module 'cv2' has no attribute 'face'

    1 环境设置: win10 python 3.6.8 opencv 4.0.1 2 尝试的方法 在学习人脸识别中,遇到了没有 cv2 中没有 face 属性.在网上找了几个方法,均没有成功解决掉该问题 ...

  2. 【Vegas原创】SQL Server 只安装客户端的方法

    只安装管理工具

  3. Sql2008中添加程序集(转)

    一.示例演示 1.用C# 建立数据库 CRL 项目 public partial class MyClr{    [Microsoft.SqlServer.Server.SqlFunction]    ...

  4. 1.揭开消息中间件RabbitMQ的神秘面纱

    当你看到这篇博文的时候,相信你至少已经知道RabbitMQ 是一个非常优秀的消息中间件,它使用专门处理高并发的Erlang 语言编写而成的消息中间件产品. 当然如果你不知道也没关系,读完本篇你将Get ...

  5. ECMAScript 6 入门之let和const的用法

    1.let的用法 1. //查看js的引入路径是否正确 console.log("1:",1) 2. var a=1; let b=2; console.log("a:& ...

  6. netbeans增加yii的代码提示

    在NetBeans中创建PHP项目 NetBeans目前还没有直接支持Yii Framework或Yii相关的插件,但是可以通过其他方式来实现Yii的代码自动提示. 首先,打开新建项目向导,创建一个“ ...

  7. golang_elasticsearch 多精确值匹配

    问题 比如要查找属于两种类型的物品,这个时候,term查询就不行了,需要采用terms查询. golang中的用法 看了一下,olivere/elastic 包提供了一个 terms查询,于是高兴的直 ...

  8. 【九天教您南方cass 9.1】 06 绘制方格网

    同学们大家好,欢迎收看由老王测量上班记出品的cass9.1视频课程 我是本节课主讲老师九天. 我们讲课的教程附件也是共享的,请注意索取测量空间中. [点击索取cass教程]5元立得 (给客服说暗号:“ ...

  9. 【iCore4 双核心板_ARM】例程六:IWDG看门狗实验——复位ARM

    实验原理: STM32内部包含独立看门狗,通过看门狗可以监控程序远行,程序运行错误时, 未在规定时间内喂狗,自动复位ARM.本实验通过按键按下,停止喂狗,制造程序运行 错误,从而产生复位. 核心代码: ...

  10. Pwnium CTF2014 – MatterOfCombination writeup

    这道题是虽然只有75分,但是做出来的队伍却很少,我们队伍也没有做出来,这次是看到了0xAWES0ME 的解题思路后才有了这篇文章.原文地址可以点击看这里,英文的. 题目就是一张图片: 在网上可以找到这 ...