CNN-SVO 论文阅读

论文链接

CNN-SVO: Improving the Mapping in Semi-Direct Visual Odometry Using Single-Image Depth Prediction


0. Abstract

与现有的VO和V-SLAM算法相比,半直接视觉里程计(SVO)具有两个主要优势,可以实现最先进的帧速率相机运动估计:直接像素对应和概率映射方法的高效实现

  • 根据单图像深度预测网络的深度预测,对特征位置深度的均值和方差进行初始化,从而改进了SVO映射
  • 通过显著降低初始化地图点的深度不确定性(即,以深度预测为中心的小方差)

其好处是双重的:视图之间的可靠特征对应关系和快速收敛到真实深度以创建新的地图点


1. Intro

当前帧和前帧之间的匹配特征是解决视觉里程计 (VO) 和视觉同步定位和映射 (V-SLAM) 的最重要步骤之一。主要有两种特征匹配方法

  • 间接方法:需要特征提取、特征描述和特征匹配。这些方法依赖于匹配中间特征(例如描述符),并且在具有弱梯度和无纹理表面的图像中表现不佳,其中描述符无法匹配
  • 直接方法:不需要特征描述,它们直接对像素强度进行操作;因此,可以对任意像素(例如,角落、边缘或整个图像)进行采样和匹配,即使在纹理较差的图像中也能实现可靠的特征匹配

半直接视觉里程计(SVO)是一种混合方法,它结合了直接和间接方法的优点来求解结构和运动,提供了一种有效的概率映射方法,为直接相机运动估计提供可靠的映射点。但 SVO 的一个主要限制是地图点初始化时具有较大的深度不确定性

Fig. 1 (a) 由于沿极点线的搜索范围较大,SVO对具有较大深度不确定性的地图点进行初始化会导致错误的特征对应关系

本文工作

  • 从单图像深度预测神经网络[7]初始化具有深度先验的新地图点(即以预测深度为中心的小方差),从而大大降低识别相应特征的不确定性

    Fig. 1 (b) CNN-SVO 示意图

  • 改进的SVO映射,本文称之为CNN-SVO,能够处理具有挑战性的照明条件,这要归功于估计深度图的照明不变性

Fig. 2 CNN-SVO: HDR环境下的摄像机运动估计。(左)单图像深度预测模型展示了估计深度图时的光照不变性,在连续五帧的样本序列上用颜色编码的重投影地图点显示了重投影地图点到那些用于相机运动估计的帧上(最好以颜色观看)。注意CNN-SVO只预测关键帧的深度图。(右)由CNN-SVO1生成的相机轨迹(用线表示)和洋红地图点


2. Methods

2.1 SVO 算法简述

首先解释本文其余部分使用的术语。特征是FAST角点检测器提取的图像中的一个二维点将特征对应称为图像小块的匹配。地图点是从深度已知的特征位置投影出来的3D点

SVO 包含两个并行运行的线程:跟踪线程和映射线程

  • 跟踪线程:通过最小化参考图像补丁(地图点的反向投影)与新帧中以重投影位置为中心的图像补丁之间的光度残差来获得新帧的相机姿态
  • 映射线程:通过两个过程创建新的地图点:初始化具有大深度不确定性的新地图点使用深度过滤器更新地图点的深度不确定性;如果地图点的深度不确定度较小,则在地图中插入一个新的地图点

给定两帧(其中一帧为关键帧)的相机姿态,通过在非关键帧中沿极线查找特征对应,然后通过三角剖分恢复深度,可以获得特征的深度

由于离群点匹配的发生是不可避免的,因此将深度滤波器建模为二维分布:第一维描述深度的概率分布,第二维建模为先验概率

在本文中着重于改进 SVO 中的映射

2.2 改进了SVO映射中映射点的初始化

SVO映射在具有较大不确定性的参考关键帧中初始化新的地图点,并将其平均深度设置为参考帧中的平均场景深度

在主要深度信息存在的地方,深度的不确定性很大,限制了映射确定地图点的真实深度的能力,其中地图点的深度变化很大。特别是,深度不确定性大带来了两个问题:在附近的帧中沿极线可能存在错误的特征对应,以及需要大量的深度测量才能收敛到真实深度

Fig. 3 CNN-SVO管道。我们的工作用CNN深度估计模块(绿色标记)增强了SVO管道,以改善SVO中的映射

添加了CNN深度估计模块(以绿色标记),以便在选择关键帧时在地图点初始化过程中提供强深度先验-深度滤波器的初始化

给定一组三角深度测量值,使用深度滤波器的目的是将好的测量值与坏的测量值分离开来

  • 好的测量值在真实深度周围正态分布,坏的测量值在区间 [ ρ i min ⁡ , ρ i max ⁡ ] [ρ^{\min}_i,ρ^{\max}_i] [ρimin,ρimax] 内均匀分布

  • 具体给定一组对应相同特征的三角剖分反演深度测量值 ρ i 1 , ρ i 2 , . . . , ρ i N ρ^1_i,ρ^2_i,...,ρ^N_i ρi1,ρi2,...,ρiN,测量值 ρ i N ρ^N_i ρiN 在SVO中采用高斯+均匀混合模型建模
    p ( ρ i n ∣ ρ i , γ i ) = γ i N ( ρ i n ∣ ρ i , τ i 2 ) + ( 1 − γ i ) U ( ρ i n ∣ ρ i min ⁡ , ρ i max ⁡ ) (1) p(ρ^n_i |ρ_i,γ_i) = γ_i\mathcal{N}(ρ^n_i |ρ_i,τ^2_i) + (1-γ_i)\mathcal{U}(ρ^n_i |ρ^{\min}_i,ρ^{\max}_ i) \tag{1} p(ρinρi,γi)=γiN(ρinρi,τi2)+(1γi)U(ρinρimin,ρimax)(1)
    其中 ρ i ρ_i ρi 为真实逆深度, τ i 2 τ^2_i τi2为逆深度方差, γ i γ_i γi 为内比值。假设深度逆测量值 ρ i 1 , ρ i 2 , ⋅ ⋅ ⋅ , ρ i N ρ^1_i,ρ^2_i,···,ρ^N_i ρi1,ρi2,⋅⋅⋅,ρiN 是独立的,真实深度逆后验的近似值可以由深度的高斯分布与内氏比的Beta分布的乘积增量计算得到:
    q ( ρ i , γ i ∣ a n , b n , µ n , σ n 2 ) = B e t a ( γ i ∣ a n , b n ) N ( ρ i ∣ µ n , σ n 2 ) (2) q(ρ_i, γ_i|a_n, b_n, µ_n, σ^2_n) = Beta(γ_i|a_n, b_n)\mathcal{N}(ρ_i|µ_n, σ^2_n)\tag{2} q(ρi,γian,bn,µn,σn2)=Beta(γian,bn)N(ρiµn,σn2)(2)
    其中 a n a_n an b n b_n bn 为Beta分布中的参数, µ n µ_n µn σ n 2 σ^2_n σn2 为高斯深度估计的均值和方差,当 σ n 2 σ^2_n σn2 小于某个阈值时,深度滤波器收敛到真实深度

Tab. 1 SVO算法与CNN-SVO算法参数初始化的比较。参数由场景的先验知识定义,其中 d a v g d_{avg} davg 为参考关键帧的平均场景深度, d C N N d_{CNN} dCNN 为单图像深度预测网络的深度预测, d min ⁡ d_{\min} dmin 为参考关键帧的最小场景深度

关键的区别在于CNN-SVO使用学习到的场景深度来初始化特征的均值和方差,而不是使用参考关键帧中的平均和最小场景深度。我们的经验发现,将深度方差设置为 1 ( 6 d C N N ) 2 \frac{1}{(6d_{CNN})^2} (6dCNN)21,为带噪深度预测提供了足够的收敛空间;如果深度方差很大(例如,用一个更大的数字代替6),我们将失去绝对尺度,因为测量中存在更多的不确定性
ρ i min ⁡ = μ n + σ n 2 (3) \rho^{\min}_i=\mu_n+\sqrt{\sigma^2_n} \tag{3} ρimin=μn+σn2 (3)

$$
\rho =
\begin{cases}
0.00000001,\ \ \ \ &if\ \mu_n-\sqrt{\sigma^2_n}<0 \
\mu_n-\sqrt{\sigma^2_n},\ \ \ &otherwise
\end{cases}

\tag{4}
$$
通过单幅图像深度预测网络获得强深度先验,其好处是双重的:识别特征对应的不确定性更小,地图点收敛速度更快

Fig. 4 改进的映射策略能够提供更快的映射点收敛。洋红色线的长度表示深度不确定度。(a)初始化深度滤波器,其中SVO采用大间隔来模拟每个初始地图点的不确定性,而CNN-SVO采用短间隔;(b)三次更新后深度滤波器对地图点的深度估计;©深度过滤器在5次更新后对地图点的深度估计


3. Evaluation

将我们的方法与最先进的直接和间接方法进行了比较,即直接稀疏里程法(DSO),半直接视觉里程法(SVO) 和无闭环的 ORB-SLAM。使用绝对轨迹误差(ATE)作为上述论文中使用的性能度量。此外,用“X”表示由于序列中间丢失跟踪而无法完成序列的方法

为了在CNN-SVO的地图点初始化中提供深度预测,我们采用了的编码器-解码器架构的Resnet50变体,该架构已经在Cityscape数据集上进行了训练

在KITTI原始数据(不包括KITTI Odometry Sequence 00-10)中对50个epoch的立体图像进行网络微调

为了产生一致的结构信息,即使在过度曝光或曝光不足的图像上,图像的亮度在整个训练过程中都是随机调整的,产生照明变化的效果

为了对其他数据集的深度预测进行缩放,可以将推断的深度流乘以当前焦距流与训练焦距流的比值,即缩放后的深度流
d c u r r e n t = f c u r r e n t f t r a i n e d d t r a i n e d (5) d_{current}=\frac{f_{current}}{f_{trained}}d_{trained}\tag{5} dcurrent=ftrainedfcurrentdtrained(5)
将一帧中跟踪特征的最大和最小数量分别设置为 200 和 100。关于深度滤波器,我们修改 SVO 以使用 5 个先前关键帧来增加深度滤波器中的测量数量。还在评估过程中启用捆绑调整

3.1 准确率评估

Tab. 2 KITTI 数据集上的绝对关键帧轨迹 RMSE(以米为单位)

Tab. 3 Oxford Robotcar 数据集上的绝对关键帧轨迹 RMSE(以米为单位)

本文的系统能够跟踪除 KITTI Sequence 01 之外的所有序列,因为无法准确匹配具有重复结构的场景中的特征。

将 CNN-SVO 的稳健跟踪归因于其将连续帧中的特征与附加深度信息进行匹配的能力,即使图像曝光过度或曝光不足也是如此

Fig. 5 ORB-SLAM(无回环)、DSO 和 CNN-SVO 生成的相机轨迹的定性比较。 (a) KITTI 序列 00 和 08; (b) 牛津机器人汽车序列 2014-05-06-12-54-54 和 2014-06-25-16-22-15。 SVO 未包含在该图中,因为它由于跟踪和建图失败而无法完成轨迹

在图5(b)中,CNN-SVO在序列2014-05-06-12-54-54中的轨迹末端附近产生了一条S状曲线,这是由摄像机前面移动的汽车引起的

3.2 运行时间评估

局部 BA(约 29 毫秒)和单图像深度预测(约 37 毫秒)是管道中要求最高的过程,但这两个过程仅在创建新关键帧时才需要

尽管有计算需求,我们通过实验发现 CNN-SVO 在 Oxford Robotcar 数据集上以 16 FPS 的速度运行,比在 KITTI 数据集上以 10 FPS 的速度运行得更快

这是由于高帧率序列中帧之间的距离很近,因此相对于序列中的帧总数而言,选择的关键帧较少。因此,可以实现实时计算

3.3 缩放评估

由于网络是在已知基线的校正立体图像上进行训练的,因此我们根据网络的预测深度检查里程计的缩放

Tab. 4 CNN-SVO 的 VO 输出中相对于绝对比例的比例

表IV(a)显示,由于训练图像主要来自KITTI数据集,里程计的比例尺接近KITTI数据集中的绝对比例尺。对于 Oxford Robotcar 数据集,我们使用等式缩放深度预测。 VO的尺度在0.9和0.97之间

对于里程表尺度不一致,我们提供两种可能的解释。首先,正如Oxford Robotcar数据集文档中提到的,提供的地面真值姿态不准确,原因如下:

  • GPS信号不一致和大比例尺地图中的尺度漂移
  • 单图像深度预测网络尚未在Oxford Robotcar数据集中的图像上进行训练,因此无法保证绝对尺度的恢复

4. Conclusion

通过初始化具有低不确定性的地图点和从单图像深度预测神经网络获得的平均深度来改进 SVO 映射,称为 CNN-SVO

主要有点

  • 假设相机位姿已知,可以通过限制附近视图中沿极线的搜索范围来有效匹配特征
  • 地图点以较低的深度不确定性进行初始化,因此他们能够更快地收敛到真正的深度

由于单图像深度预测网络中的光照不变性,从曝光过度或曝光不足的图像生成的深度图仍然可以用于促进视图之间的特征对应,克服了原始 SVO 的关键限制

解决一些缺点

  • 增加地图点不确定性的阈值,以允许插入具有较大不确定性的地图点进行相机运动跟踪
  • 虽然网络能够从曝光过度的图像生成深度图,但它仍然无法使用空白图像(即完全曝光过度的图像)生成有用的深度图
  • 通过限制附近帧中沿极线的相应特征的搜索空间来促进特征匹配。这种特征匹配策略确实增加了光照变化的容忍度,但它并没有解决直接方法中光度恒定性假设的固有问题

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/510009.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

5、lxmcms1.40代码审计

一、RCE 1、RCE代码执行 代码 搜索代码执行关键字&#xff0c;找到函数里存在变量的文件跟踪一下$temdata[data] $data是从$temdata赋值的&#xff0c;$temdata从314行过来的&#xff0c;有个caijiDataOne函数接收的$_GET[cid]&#xff0c;也没有对变量做处理。已知查询的数…

64 位世界中的 WinForms – 我们的未来战略

作者&#xff1a;Klaus Loeffelmann 排版&#xff1a;Alan Wang 作为一个依靠创新和发展而蓬勃发展的社区的一部分&#xff0c;WinForms 开发人员经常突破界限来创造新的可能性。我们的开发人员还负责维护业务软件的关键任务线&#xff0c;这通常需要十年以上的时间。我们重视您…

自动化神器 Playwright 的 Web 自动化测试解决方案!

Playwright认识 3. Playwright环境搭建 Playwright简介&#xff1a; 2020年&#xff0c;微软&#xff08;Microsoft&#xff09;开源了一个名为Playwright的工具&#xff0c;与Selenium一样入门简单&#xff0c;支持多语言&#xff08;Python、Java、Node.js、.NET&#xff0…

Python爬虫——Urllib库-1

这几天都在为了蓝桥杯做准备&#xff0c;一直在刷算法题&#xff0c;确实刷算法题的过程是及其的枯燥且枯燥的。于是我还是决定给自己找点成就感出来&#xff0c;那么Python的爬虫就这样开始学习了。 注&#xff1a;文章源于观看尚硅谷爬虫视频后笔记 目录 Urllib库 基本使…

MybatisPlus的使用(一)--基本配置与无条件查询

创建测试用的数据库 CREATE DATABASE mybatis_plus /*!40100 DEFAULT CHARACTER SET utf8mb4 */; use mybatis_plus; CREATE TABLE user ( id bigint(20) NOT NULL COMMENT 主键ID, name varchar(30) DEFAULT NULL COMMENT 姓名 , age int(11) DEFAULT NULL COMMENT 年龄 , em…

W5300驱动说明

W5300是一款带有硬件协议栈的网络芯片&#xff0c;内部拥有128K的缓存&#xff0c;最大支持8路socket通信&#xff0c;与MCU之间通过16位数据总线通信&#xff0c;通信速度远超W5500之类以SPI作为通信接口的网络芯片&#xff0c;特别适合对高速网络传输有需求的应用。 本次使用…

thymeleaf 一个莫名其妙的错误提示 org.attoparser.ParseException

thymeleaf 一个莫名其妙的错误提示 介绍 开发过程中遇到一个莫名奇妙的错误&#xff0c;一时竟然不知道怎么解决&#xff0c;找官网也没有找到 问题 页面显示 错误日志 org.attoparser.ParseException: (Line 96, Column 5) Malformed markup: Attribute “}” appears m…

深入理解快速排序算法:从原理到实现

目录 1. 引言 2. 快速排序算法原理 3. 快速排序的时间复杂度分析 4. 快速排序的应用场景 5. 快速排序的优缺点分析 5.1 优点&#xff1a; 5.2 缺点&#xff1a; 6. Java、JavaScript 和 Python 实现快速排序算法 6.1 Java 实现&#xff1a; 6.2 JavaScript 实现&#…

如何在 Windows 上安装 ONLYOFFICE 文档 8.0

使用社区版&#xff0c;您可以在本地服务器上安装 ONLYOFFICE 文档&#xff0c;并将在线编辑器与 ONLYOFFICE 协作平台或其他热门系统集成在一起。 ONLYOFFICE 文档是什么 ONLYOFFICE 文档是一个功能强大的文档编辑器&#xff0c;支持处理文本文档、电子表格、演示文稿、可填写…

【计算机学习】-- 电脑的组装和外设

系列文章目录 文章目录 系列文章目录前言一、电脑的组装1.CPU2.主板3.显卡4.硬盘5.内存6.散热器7.电源8.机箱 二、电脑外设选用1.显示器2.鼠标3.键盘4.音响 总结 前言 一、电脑的组装 1.CPU 返回目录 认识CPU CPU&#xff0c;即中央处理器&#xff0c;负责电脑资源的调度安…

Kubernetes 学习总结(46)—— Pod 不停重启问题分析与解决

我们在做性能测试的时候&#xff0c;往往会发现我们的pod服务&#xff0c;频繁重启&#xff0c;通过kubectl get pods 命令&#xff0c;我们来逐步定位问题。 现象:running的pod&#xff0c;短时间内重启次数太多。 定位问题方法:查看pod日志 kubectl get event …

Golang pprof 分析程序的使用内存和执行时间

一、分析程序执行的内存情况 package mainimport ("os""runtime/pprof" )func main() {// ... 你的程序逻辑 ...// 将 HeapProfile 写入文件f, err : os.Create("heap.prof")if err ! nil {panic(err)}defer f.Close()pprof.WriteHeapProfile(f…