深度学习相关VO梳理

2023-10-27

相关论文

基于学习的VO 相关:
DeepVO Towards End-to-End Visual Odometry with Deep Recurrent Convolutional Neural Networks(ICRA,2017)
TartanVO: A Generalizable Learning-based VO(CoRL2021)
SimVODIS: Simultaneous Visual Odometry ,Object Detection, and Instance Segmentation(PAMI,2022)

基于学习的SLAM:
DROID-SLAM: Deep Visual SLAM for Monocular,Stereo, and RGB-D Cameras
NICE-SLAM: Neural Implicit Scalable Encoding for SLAM(CVPR,2022)
NeRF-SLAM: Real-Time Dense Monocular SLAM with Neural Radiance Fields(arXiv,2022)

对Dynamic的处理:
DytanVO:Joint Refinement of Visual Odometry and Motion Segmentation in Dynamic Environments(ICRA2023)

SimVODIS++: Neural Semantic Visual Odometry in Dynamic Environments(RAL,2022)
MaskVO: Self-Supervised Visual Odometry with a Learnable Dynamic Mask(SII,2022)

GeoNet: Unsupervised Learning of Dense Depth, Optical Flow and Camera Pose(CVPR,2018)
Competitive Collaboration: Joint Unsupervised Learning of Depth, Camera Motion, Optical Flow and Motion Segmentation(CVPR,2019)

背景

传统方法

基于几何的VO方法在实际中不够鲁棒

传统SLAM方法容易特征缺失、优化算法发散、误差累计

基于学习的方法

基于学习的方法的VO在并没有表现出强大的性能,当前表现甚至不如几何的方法:
a.现有的VO模型训练多样性不足
b.大多数基于学习的VO模型没有关注到问题的一些基本性质

动态环境

基于学习的视觉里程计在动态、人口稠密的环境中容易失败

基于无监督和自监督方式的VO泛化性不行

基于语义方式的问题:1.漏报 2.无法区分实际运动和静态但能运动

Tartanvo

提出了第一个基于学习的视觉里程计(VO)模型,该模型可以推广到多个数据集和现实场景:

  1. 我们通过比较不同数量的训练数据的性能来证明数据多样性对 VO 模型泛化能力的关键影响。
  2. 我们设计了一个尺度损失函数(up-to-scale loss function)来处理单目 VO 的尺度模糊性。
  3. 我们在 VO 模型中创建一个本征层 (IL,instrinsics layer),以实现跨不同相机的泛化。

整体结构

匹配模块+位姿模块
input:相邻帧图像
output:相对相机运动(T|R)
在这里插入图片描述

多样化训练

利用异常丰富的大规模数据集TartanAir

我们在任务中利用单目图像序列 { I t } \{I_t\} {It}、光流标签 { F t t + 1 } \{F ^{t+1}_t \} {Ftt+1} 和地面实况相机运动 { δ t t + 1 } \{δ^{t+1}_t\} {δtt+1}。我们的目标是共同最小化光流损耗 L f L_f Lf 和相机运动损耗 L p L_p Lp。端到端损耗定义为:
在这里插入图片描述

尺度损失函数

尺度模糊度只影响平移 T T T ,我们为 T T T 设计了一个新的损失函数,并保持旋转 R R R 的损失不变。我们为 L P L_P LP 提出了两个大规模损失函数:余弦相似度损失 L p c o s L^{cos}_p Lpcos 和归一化距离损失 L p n o r m L^{norm}_p Lpnorm L p c o s L^{cos}_p Lpcos 由估计的 T ^ \hat{T} T^ 和标签 T T T 之间的余弦角定义:
在这里插入图片描述

相机差异的统一

1. 使用instrinsics layer
我们设计了一个新的姿态网络 P ϕ ( F t t + 1 , K ) P_\phi(F^{t+1}_t , K) Pϕ(Ftt+1,K),而不是仅从特征匹配 F t t + 1 F^{t+1}_t Ftt+1 中恢复相机运动 T t t + 1 T^{t+1}_t Ttt+1 ,该网络也取决于相机内在参数 K = { f x , f y , o x , o y } K = \{f_x ,f_y,o_x,o_y\} K={fx,fy,ox,oy},其中 f x f_x fx f y f_y fy是焦距, o x o_x ox o y o_y oy表示主点的位置。
在这里插入图片描述
2. 将数据裁剪为不同内参的数据
TartanAir 只有一组相机内在函数,其中 f x = f y = 320 、 o x = 320 f_x = f_y = 320、o_x = 320 fx=fy=320ox=320 o y = 240 o_y = 240 oy=240。我们通过随机裁剪和调整 (RCR,Randomly cropping and resizing) 输入图像大小来模拟各种内在函数。

如图3所示,我们首先在随机位置以随机大小裁剪图像。接下来,我们将裁剪后的图像调整为原始大小。
在这里插入图片描述

DytanVO

• 引入了一种新颖的基于学习的VO,以利用相机自我运动、光流和运动分割之间的相互依赖性。

• 我们引入了一个迭代框架,其中自我运动估计和运动分割可以在实时应用的时间限制内快速收敛。

• 在基于学习的 VO 解决方案中,我们的方法无需微调即可在现实动态场景中实现最先进的性能。此外,我们的方法的性能甚至可以与优化后端轨迹的视觉 SLAM 解决方案相媲美。

Architecture

在这里插入图片描述
我们的框架由三个子模块组成:匹配网络、运动分割网络和姿态估计网络

Interactive refine camera motion

在这里插入图片描述
在这里插入图片描述

在实践中,我们发现 3 次迭代足以细化相机运动和分割。为了消除任何歧义,1 次迭代过程由一次 M θ M_θ Mθ 前向过程和一次具有随机掩码的 P ϕ P_{\phi} Pϕ 前向过程组成,而 3 次迭代过程由一次 Mθ 前向过程、两次 U γ U_γ Uγ 前向过程和 3 个 P ϕ P_{\phi} Pϕ 前向过程组成。

Supervision

我们在相机运动损失 LP 上监督我们的网络。

在单目设置下,我们只能恢复最大尺度的相机运动。我们按照[5],在计算到地面实况的距离之前对平移向量进行归一化。给定地面真实运动 R ∣ T R|T RT:
在这里插入图片描述
我们的框架也可以以端到端的方式进行训练,在这种情况下,目标变成光流损失 L M L_M LM 、相机运动损失 L P L_P LP 和运动分割损失 L U L_U LU 的聚合损失,其中 L M L_M LM 是之间的 L1 范数预测流和地面真实流,而 L U L_U LU 是预测概率和分割标签之间的二元交叉熵损失。
在这里插入图片描述

SimVODIS

Architeture

在这里插入图片描述
图3描述了所提出的SimVODIS网络的概念化架构。我们基于以下思想设计了SimVODIS网络:
1)Mask RCNN为语义和几何任务提取通用特征,如区域建议、类标记、边界框回归和掩码提取;
2)我们可以使用这些丰富的特征来估计相对姿态和预测深度图,因为提取的特征对语义和几何工作都有用。

对于SimVODIS,我们设计了两个网络分支:姿态分支和深度分支。姿态分支使用来自特征金字塔网络(FPN)的丰富特征来估计三个连续图像序列之间的相对姿态。

Loss

在这里插入图片描述

SimVODIS++

在这里插入图片描述
我们基于以下推理设计了SimVODIS++网络:
(1)用于语义分支(对象检测和实例分割)的特征金字塔网络(FPN)提取能够执行语义和几何任务的一般特征;
(2)我们可以利用这些丰富的特征来执行位姿估计和深度图预测。对于SimVODIS++,与SimVODIS[10]相比,我们设计了两个新功能:姿态估计和相机校准。我们进行专注的姿态估计以去除动态对象,并进行相机校准以提高VO性能。由于所提出的姿态估计和相机校准导致的参数总量的增加是最小的。

Attention Pose Estimation(比较质疑)

在这里插入图片描述
图2描述了在动态环境中用于鲁棒性能的所提出的注意姿态估计的架构。

Conv. Block 从FPN接收特征,调整输入特征以进行自注意,并通过自注意进行动态特征选择。对于自我注意,我们使用CBAM模块[37]。在训练过程中,CBAM模块让姿势分支学会专注于具有相关特征的区域,并尽量减少对动态对象的关注。

在这里插入图片描述

MaskVO

这项工作的目的是提出一种自监督学习系统,从未标记的图像序列中重建尺度一致的自我运动。
在这里插入图片描述

如图 2 所示,两个未标记的 RGB 图像 I a I_a Ia I b I_b Ib 堆叠在一起并输入到特征提取器中。
I a I_a Ia I b I_b Ib 是源图像和目标图像。与[6]、[12]不同,我们使用图像序列来利用视觉运动的时间依赖性。
特征时间建模模块提取图像序列的时间信息,由循环神经网络组成。
然后,6-DoF 位姿 P a b P_{ab} Pab 由位姿网络生成。同时,输入图像的深度图由深度网络生成。

投影图像 I a ′ I_{a}^{\prime} Ia 使用 D a 、 I b D_a、I_b DaIb和6-DoF位姿 P a b P_{ab} Pab通过等式5生成。

引入掩模网络将学习到的空间信息合并到框架中,减少场景动态的影响。真实图像 I a I_{a} Ia和合成 I a ′ I_{a}^{\prime} Ia 之间的差异可以用作自监督信号来构造光度损失。它可以约束并强制系统根据不同的输入图像序列估计姿态和深度。

GeoNet

GeoNet,这是一种联合无监督学习框架,用于视频中的单目深度、光流和自我运动估计

这三个组件通过 3D 场景几何的性质耦合在一起,由我们的框架以端到端的方式共同学习。具体来说,根据各个模块的预测提取几何关系,然后将其组合为图像重建损失,分别对静态和动态场景部分进行推理。

此外,我们提出了一种自适应几何一致性损失,以提高对异常值和非朗伯区域的鲁棒性,从而有效地解决遮挡和纹理模糊问题。

我们的 GeoNet 的概述如图 2 所示。
在这里插入图片描述

它包含两个阶段,刚性结构推理阶段和非刚性运动细化阶段。

推断场景布局的第一阶段由两个子网络组成,即 DepthNet 和 PoseNet。深度图和相机位姿分别回归并融合以产生刚性流。

第二阶段由 ResFlowNet 完成以处理动态对象。 ResFlowNet 学习到的残余非刚性流与刚性流相结合,得出我们最终的流预测。由于我们的每个子网络都针对特定的子任务,因此复杂的场景几何理解目标被分解为一些更简单的目标。不同阶段的视图合成是我们无监督学习范式的基本监督。

最后但并非最不重要的一点是,我们在训练期间进行几何一致性检查,这显着增强了我们预测的一致性并取得了令人印象深刻的性能

Competitive Collaboration

我们在本文中考虑了四个这样的问题:单视图深度预测、相机运动估计、光流和运动分割。之前的工作已经使用真实数据[5]和合成数据[4]通过监督来解决这些问题。然而,合成数据与真实数据之间始终存在现实差距,并且真实数据有限或不准确。

在这里插入图片描述

如图 2 所示,我们在框架中引入了两个参与者,即静态场景重建器 R = ( D , C ) R = (D, C) R=(D,C),它使用深度 D 和相机运动 C 来推理静态场景像素;以及运动区域重建器 F,其推理独立运动区域中的像素。这两个玩家通过推理图像序列中的静态场景和移动区域像素来竞争训练数据。比赛由运动分割网络 M 主持,该网络分割静态场景和运动区域,并将训练数据分发给选手。不过,主持人也需要培训,以保证公平竞争。因此,玩家 R 和 F 合作训练主持人 M,使其在训练周期的交替阶段正确分类静态和移动区域。这个通用框架在本质上与期望最大化 (EM) 类似,但专为神经网络训练而制定。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

深度学习相关VO梳理 的相关文章

随机推荐

  • h264-运动估计和运动补偿理论

    定义 运动补偿是通过先前的局部图像来预测 补偿当前的局部图像 它是减少帧序列冗余信息的有效方法 MPEG 4采用I VOP P VOP B VOP三种帧格式来表征不同的运动补偿类型 它采用了H 263中的半像素搜索 half pixel s
  • LINUX如何用ls -l显示出文件的详细的年-月-日 时-分-秒?

    1 给出命令 ls l time style full iso 取值可以是 full iso long iso iso locale等 2 给出命令 ls l full time3 给出命令 ls l time style Y m d H
  • System real conversion functions

    原文链接 https www hdlworks com hdl corner verilog ref items SystemRealConversionFuncs htm System real conversion functions
  • colab数据的加载方式

    1 colab挂载google硬盘 最方便 第一种方式 from google colab import drive drive mount content gdrive 2 第二种方式 通过代码进行文件的上传或者下载 第二种方式 可以进行
  • 【数码管识别】感兴趣区域提取和缩放的顺序问题

    在之前调试的数码管的时候 通过调节镜头和仪表的距离 就可以使镜头正好拍到仪表的数字部分 现在由于摄像头是固定的 不能调节镜头和仪表的距离 而且仪表的尺寸也比较多 所以就用到了感兴趣区域的提取 之前调试程序的过程中 没有注意感兴趣区域提取和图
  • echarts实现复合饼图

    Echart 复合饼图 要实现如Excel中一样的复合饼图 但发现echarts中并没有相关样例 故根据配置项自行实现 实现思路 利用echarts中的嵌套环形图进行修改 1 1 将中间内圆进行平移 构成复合饼图的详细子图 通过media
  • PHP数据类型转换

    http www blogjava net zuofei bie archive 2010 03 31 317092 html PHP数据类型转换 PHP的数据类型转换属于强制转换 允许转换的PHP数据类型有 int integer 转换成
  • NeRF与三维重建专栏(三)nerf_pl源码部分解读与colmap、cuda算子使用

    前言 上一章中我们介绍了NeRF原理 传统体渲染方法以及两者之间的联系 本章中我们将讲解colmap的安装以及使用 部分nerf pl源码 同时在开发过程中 由于部分操作python torch不支持 我们需要自己造轮子 且在后续的专栏中我
  • tdr 定位公式_TDR在农业上的应用

    TDR 摘要 由于农业科技的发展 在很多方面都实现的自动化控制农业生产 而土壤含水量也成为农业生产中用于土壤的一大要素 采用时域反射技术可以快速的测出土壤的容积含水量 为农业生产上做出很大的贡献 引言 土壤水分是作物生长的要素之一 对于作物
  • 【Qt串口调试助手】1.5 - 发送/接收字节数量统计

    对发送 接收的字节数目计数 显示到底部状态栏中 GitHub源码 Qt串口调试助手下载 接收字节数计数 1 在 mainwindow h文件中创建 收发数属性 再创建两个 标签指针 用于显示收发数目 2 mainwindow c 构造函数中
  • 【学习笔记】李宏毅2020ML&DL课程 13_1 Unsupervised Learning

    Clustering 选择适当的cluster 有比较empirical的方法 最常用的方法K means 假设要把X分成K个clusters 找center 要K个clusters就需要K个center 可以随即找K个vector作为K个
  • 【elementplus】body使用zoom导致el-dropdown组件的下拉菜单错位的解决方案

    问题原因 百分百是zoom导致的 百分百不建议项目使用zoom做适配 对elementplus的影响很大 反而element没有这些问题 解决方法 Ele3 的 el dropdown 组件是按照滚动容器做的改变上下展开 dropdown有
  • resultMap实现一对一,一对多,多对多的查询

    第一种 resultMap实现一对一的查询 1 1 1 使用resultMap映射的思路 使用resultMap将查询结果中的订单信息映射到Orders对象中 在orders类中添加User属性 将关联查询出来的用户信息映射到orders对
  • dubbo处理自定义异常问题

    最近在项目上遇到一个有关dubbo的问题 项目分为两层 下层是一些基础服务 上层是业务服务调用下层的基础服务 上层服务的有一个全局的异常拦截器来拦截异常 ControllerAdvice Slf4j public class Excepti
  • ModuleNotFoundError: No module named '_tkinter'

    目前添加上面两句话后没有报错 具体原因不知道
  • VS Code统计代码、注释、空格行数插件 统计前端代码 VUE代码

    VS Code Counter是一款统计代码 注释 空格行数插件 你可以统计单个文件 文件夹或者是工作空间 网址引用 http www duocaichajian com plugin 63 html 首先在插件市场搜索并安装VS Code
  • 微服务基本概念汇总

    1 什么是微服务 单个轻量级服务一般为一个单独微服务 微服务讲究的是 专注某个功能的实现 比如登录系统只专注于用户登录方面功能的实现 讲究的是职责单一 开箱即用 可以独立运行 微服务架构系统是一个分布式的系统 按照业务进行划分服务单元模块
  • Dynamics CRM 自动生成实体关系图(ER Model)

    有时候业务需要查看CRM实体与实体之间的关系 但是会发现在解决方案里面查看会很慢 不能很清楚的展现出来 这时候我们可以使用SDK里面的一个解决方案 可以自动生成关系图 首先打开我们的解决方案SDK SampleCode CS Metadat
  • MySQL数据库总结 之 约束(restraint) & 外键约束

    前三篇关于MySQL的博客 地址如下 1 MySQL数据库 SQL语言命令总结 数据类型 运算符和聚合函数汇总 Flying Bulldog的博客 CSDN博客 2 从0到1 关于MySQL的数据库和表 Flying Bulldog的博客
  • 深度学习相关VO梳理

    相关论文 基于学习的VO 相关 DeepVO Towards End to End Visual Odometry with Deep Recurrent Convolutional Neural Networks ICRA 2017 Ta