0. 简介

对于深度学习而言,NeRF一定是最近两年最火的工作之一了,**NeRF(Neural Radiance Fields)**是最早在2020年ECCV会议上的Best Paper,其将隐式表达推上了一个新的高度,仅用 2D 的 posed images 作为监督,即可表示复杂的三维场景。NeRF迅速发展也已经被应用到了多个技术方向,例如新视点合成、三维重建等等,都取得非常好的效果。之前我们在《经典文献阅读之–NeRF-SLAM(单目稠密重建)》中给大家提到了NeRF的技术原理下面我们就根据NICE-SLAM作为核心,来给各位介绍一下现有NeRF的缺点以及发展

1. 缺点以及发展

NeRF最大的贡献,是实现了神经场(Neural Field)与图形学组件Volume rendering的有效结合。通过将2D位置与3D空间坐标通过NLP神经网络去隐式地学习一个三维场景。首先值得我们注意的是NeRF的问题,主要的问题有:速度慢、只针对静态场景、泛化性差、需要大量视角等问题。我们分别找了几个文章来做简要的分析,来看不同文章的改进方向。下一节我们将会来侧重着讲如何将NeRF应用到SLAM上。我们来根据NICE-SLAM来详细分析。

1.1 Neural Sparse Voxel Fields

在这项工作中,我们介绍了神经稀疏体素场 (NSVF),这是一种用于快速和高质量自由视点渲染的新神经场景表示。NSVF 定义了一组以稀疏体素八叉树组织的体素有界隐式字段,以对每个单元中的局部属性进行建模。我们仅从一组姿势的 RGB 图像中通过可区分的光线行进操作逐步学习底层体素结构。使用稀疏体素八叉树结构,可以通过跳过不包含相关场景内容的体素来加速渲染新颖的视图。

1.2 Mip-NeRF

Mip-NeRF 使用称为圆锥截头体的几何形状来渲染每个像素,而不是射线,这可以减少混叠,可以显示图像中的精细细节,并将错误率降低 17-60%。该模型也比 NeRF 快 7%。

1.3 NeRF-SR

NERF-SR,一种用于高分辨率(HR)新型视图合成的解决方案,主要是低分辨率(LR)输入。该方法是基于神经辐射场(NERF)的内置,其预测每点密度和颜色,具有多层的射击。在在任意尺度上产生图像时,NERF与超越观察图像的分辨率努力。NERF-SR可以通过改进网络进一步提高超级采样的性能,该细化网络利用估计的深度来实现HR参考图像上的相关补丁的幻觉。

1.4 KiloNeRF

KiloNeRF 解决了 NeRF 中渲染缓慢的问题,这主要与需要数百万次查询深度 MLP 网络有关。 KiloNeRF 将工作负载分离到数千个小型 MLP 中,而不是一个需要多次查询的大型 MLP。每个小型 MLP 都代表一个场景的一部分,可实现 3 倍的性能提升,同时降低存储要求和可比的视觉质量。

1.5 Plenoxels

Plenoxels 将 NeRF 中心的 MLP 替换为稀疏的 3D 网格。每个查询点都是从其周围的体素插入的。因此,无需运行神经网络即可渲染新的 2D 视图,这大大降低了复杂性和计算要求。Plenoxels 提供与 NeRF 相似的视觉质量,同时速度快两个数量级。

1.6 RegNeRF

虽然NERF可以在许多输入视图可用时产生看不见的观点的光静观渲染,但是当该数量减少时,其性能显着下降。我们观察到,稀疏输入方案中的大多数伪像是由估计场景几何中的错误引起的,并且在训练开始时通过不同的行为引起。我们通过规范从未观察的视点呈现的修补程序的几何和外观来解决这一点,并在训练期间退火光线采样空间。我们还使用规范化的流模型来规范未观察的视点的颜色。我们的车型不仅优于优化单个场景的其他方法,而是在许多情况下,还有条件模型,这些模型在大型多视图数据集上广泛预先培训。

1.7 Neural Deformable Voxel Grid for Fast Optimization of Dynamic View Synthesis

神经辐射场(NERF)正在彻底改变新型视图合成(NVS)的卓越性能。但是,NERF及其变体通常需要进行冗长的每场训练程序,其中将多层感知器(MLP)拟合到捕获的图像中。为了解决挑战,已经提出了体素网格表示,以显着加快训练的速度。但是,这些现有方法只能处理静态场景。如何开发有效,准确的动态视图合成方法仍然是一个开放的问题。将静态场景的方法扩展到动态场景并不简单,因为场景几何形状和外观随时间变化。在本文中,基于素素网格优化的最新进展,我们提出了一种快速变形的辐射场方法来处理动态场景。我们的方法由两个模块组成。第一个模块采用变形网格来存储3D动态功能,以及使用插值功能将观测空间中的3D点映射到规范空间的变形的轻巧MLP。第二个模块包含密度和颜色网格,以建模场景的几何形状和密度。明确对阻塞进行了建模,以进一步提高渲染质量。实验结果表明,我们的方法仅使用20分钟的训练就可以实现与D-NERF相当的性能,该训练比D-NERF快70倍以上,这清楚地证明了我们提出的方法的效率。

2. NICE-SLAM具体贡献

NICE-SLAM是一个密集的SLAM系统,通过引入分层的场景表示,纳入了多层次的本地信息。用预先训练好的几何先验来优化这个表示,可以在大的室内场景中进行详细的重建。与最近的神经隐含SLAM系统相比,我们的方法更具可扩展性、效率和鲁棒性。

  1. 我们提出了NICE-SLAM,一个密集的RGB-D SLAM系统,它具有实时性、可扩展性、预测性和对各种挑战性场景的鲁棒性。

  2. NICE-SLAM的核心是一个分层的、基于网格的神经隐式编码。与全局神经场景编码相比,这种表示法允许局部更新,这是大规模方法的一个先决条件。

  3. 我们在各种数据集上进行了广泛的评估,证明了在映射和跟踪方面具有竞争力的性能。

3. 整体框架

文章在图2中提供了我们的方法的概述。我们使用四个特征网格和相应的解码器来表示场景几何和外观(3.1节)。我们使用估计的相机校准跟踪每个像素的观察光线。通过沿着观察光线对点进行采样并查询网络,我们可以渲染这条光线的深度和颜色值(3.2节)。通过最小化深度和颜色的重新渲染损失,我们能够在交替的方式中优化相机姿态和场景几何(3.3节),以便选择关键帧(3.4节)。

4. 层次化的场景表示

我们现在介绍了我们的分层场景表示,它结合了多级网格特征和预训练的解码器来预测占用。几何形状被编码到三个特征网格 ϕ θ l ϕ^l_θ ϕθl​和它们相应的MLP解码器 f l f^l fl 中,其中 l ∈ 0 , 1 , 2 l∈ {0,1,2} l∈0,1,2指粗略、中等和细致的场景细节。另外,我们还有一个单独的特征网格 ψ ω ψ_ω ψω​和解码器 g ω g_ω gω​来模拟场景外观。这里 θ θ θ和 ω ω ω表示几何和颜色的可优化参数,即网格中的特征和颜色解码器中的权重。

4.1 中级和细级场景几何表示

在中级和细级场景几何表示中,观察到的场景几何用中级和细级特征网格表示。在重建过程中,我们使用这两个网格采用粗到细的方法,其中几何先由中级特征网格优化重建,然后用细级网格进行细化。在实现中,我们使用体素网格,其侧长为32厘米和16厘米,除了TUM RGBD [46],我们使用16厘米和8厘米。对于中级特征网格,使用相关的MLP f 1 f^1 f1将特征直接解码为占有率值。对于任意点 p ∈ R 3 p∈\mathbb{R}^3 p∈R3,我们得到占用值为

在上面的公式中, ϕ θ 1 ( p ) ϕ^1_θ(p) ϕθ1​(p)表示在点 p p p处三线性插值的特征网格。相对较低的分辨率允许我们有效地优化网格特征以适应观察。为了捕捉场景几何中的较小的高频细节,我们以残差的方式加入细级特征。细级特征解码器将相应的中级特征和细级特征作为输入,并输出中级占用率的偏移量。

点的最终占用率是

需要注意的是,我们固定预先训练好的解码器 f 1 f^1 f1和 f 2 f^2 f2,在整个优化过程中只优化特征网格 ϕ θ 1 ϕ^1_θ ϕθ1​和 ϕ θ 2 ϕ^2_θ ϕθ2​。我们证明这有助于稳定优化并学习一致的几何形状。

4.2 粗粒度层次

在粗粒度层次中,我们使用一个特征网格来捕捉场景的高级几何特征(例如墙壁、地板等),并且与中级和细级层次独立进行优化。粗网格的目的是能够预测观察几何体以外的近似占用值(在中/细级层次中编码),即使每个粗体素只被部分观察到。因此,我们在实现中使用了非常低的分辨率,边长为2米。与中级网格类似,我们通过插值特征并通过MLP f 0 f^0 f0直接解码成占用值,即:

在跟踪过程中,粗略层次的占用值仅用于预测以前未观察到的场景部分。这种预测出的几何形状允许我们在当前图像的大部分部分之前未见过的情况下进行跟踪。

4.3 预训练特征解码器

我们的框架中使用了三个不同的固定 MLP 来解码网格特征成为占据值。粗糙和中级级别的解码器是作为 ConvONet [38] 的一部分预先训练的,其包括 CNN 编码器和 MLP 解码器。我们使用二元交叉熵损失在预测值和地面真值之间训练编码器/解码器,与 [38] 中相同。训练后,我们只使用解码器 MLP,因为我们将直接优化特征以适应观察结果。这样,预先训练的解码器可以利用从训练集中学习的分辨率特定先验,在解码我们优化的特征时,同样的策略用于预训练细级别解码器。除了在输入到解码器之前,我们只是将中层的特征 ϕ θ 1 ( p ) ϕ^1_θ (p) ϕθ1​(p)与细层的特征 ϕ θ 2 ( p ) ϕ^2_θ(p) ϕθ2​(p)连接起来进行输入,其余的都需要考虑粗粒度信息。

4.4 色彩表示

我们主要关注场景几何,但我们还编码了颜色信息,允许我们呈现RGB图像,为跟踪提供额外的信号。 为了在场景中编码颜色,我们应用另一个特征网格 ψ ω ψ_ω ψω​和解码器 g ω g_ω gω​

其中 ω ω ω表示优化期间的可学习参数。 与具有强烈先验知识的几何不同,我们凭经验发现,联合优化颜色特征 ψ ω ψ_ω ψω​和解码器 g ω g_ω gω​可以提高跟踪性能。注意,与iMAP [47]类似,这可能会导致遗忘问题,并且颜色只是局部一致的。如果我们想要可视化整个场景的颜色,可以作为后处理步骤全局优化。

4.5 网络设计

对于所有 MLP 解码器,我们使用 32 维隐藏特征维度和 5 个完全连接的块。除了粗粒度几何表示之外,我们在 MLP 解码器的输入之前对 p 应用可学习的高斯位置编码 [47,50],这样可以发现几何和外貌的高频细节。

5. 深度和色彩渲染

受NeRF中体积渲染的最新成功启发,我们提出使用可微渲染过程,该过程将第3.1节中的预测占用率和颜色整合到场景表示中。

…详情请参照古月居

经典文献阅读之--NICE-SLAM(SLAM的神经隐含可扩展编码)相关推荐

  1. 货运服务网络设计:经典文献阅读笔记(3)复现Netplan

    **货运服务网络设计:经典文献阅读笔记(2)**提到说要把Crainic T G(1984年)文献使用的模型复现一下,但是文章给出的通用框架还是太笼统,在尝试后决定使用Jacques Roy & ...

  2. 经典文献阅读之--Swin Transformer

    0. 简介 Transfomer最近几年已经霸榜了各个领域,之前我们在<经典文献阅读之–Deformable DETR>这篇博客中对DETR这个系列进行了梳理,但是想着既然写了图像处理领域 ...

  3. 经典文献阅读之--PL-SLAM(点线SLAM)

    0. 简介 之前作者基本都在围绕着特征点提取的路径在学习,最近看到了最近点云PCL推送的<Structure PLP-SLAM: Efficient Sparse Mapping and Loc ...

  4. 经典文献阅读之--OV2SLAM(高速视觉slam)

    0. 简介 视觉里程计最近几年越来越受到学术界以及工业界的认可,以ORB和VINS为代表的视觉SLAM已经可以满足绝大多数场景,而OV2SLAM在其他VSLAM中脱颖而出,其实时性以及具体的回环性能在 ...

  5. 经典文献阅读之--Lifelong SLAM(变化环境中Lifelong定位建图)

    0. 简介 商场.超市等大多数现实场景的环境随时都在变化.不考虑这些变化的预建地图很容易变得过时.因此,有必要拥有一个最新的环境模型,以促进机器人的长期运行.为此<A General Frame ...

  6. 经典文献阅读之--SuMa++

    0. 简介 作为一名技术博主,最主要的还是需要不断地学习新的知识,而最好的学习就是不断地阅读新的文章,并不断地学习和总结前人的思路和方法.所以博主打算开一个新的系列来介绍.这里主要来介绍一下<S ...

  7. 经典文献阅读之--Globally Consistent and Tightly Coupled 3D LiDAR Inertial Mapping(紧耦合3D激光雷达)

    0. 简介 传统的地图生成方法一般是依靠Lidar和IMU结合的,但是问题在于,目前Lidar和IMU的紧耦合主要集中在前端里程计,基本没有涉及到后端全局优化以及建图的融合.为此文章<Globa ...

  8. 经典文献阅读之--On Degeneracy of Optimization-based State Estimation Problems(防止非线性优化退化)

    0. 简介 对于激光和视觉里程计而言,我们在面试和日常工作中会经常听到,在长时间在平坦道路上直行会导致维度的退化.定位的退化主要是因为约束的减少,比如NDT需要三个正交方向的约束才能很好的匹配,但若在 ...

  9. 经典文献阅读之--DLO

    0. 简介 这篇SLAM论文<Direct LiDAR Odometry: Fast Localization with Dense Point Clouds>作为NASA喷气推进实验室C ...

最新文章

  1. encodeURI 和 encodeURIComponent
  2. OpenCV2学习笔记(一)
  3. 使用7zip压解各种文件的经常使用命令
  4. 50佳设计独特的名片设计欣赏(上篇)
  5. 每天一道LeetCode-----将数组/链表后k个元素移动到前面
  6. 跟着太白老师学python day11 可迭代对象和迭代器
  7. ctfshow-WEB-web10( with rollup注入绕过)
  8. Modular Inverse(zoj3609+欧几里德)
  9. C++day02 学习笔记
  10. ffmpeg 推流FLV文件,采用rtmp协议
  11. 接口配置锦囊妙计之三----端口自协商
  12. 计算机录像怎么操作,电脑屏幕录制怎么操作?
  13. 基于ansys命令流的水池静力学分析
  14. 机器学习的应用方面,主要有哪些?
  15. git push解决办法: ! [remote rejected] master -> master (pre-receive hook declined)
  16. 4.8 期货每日早盘操作建议
  17. windows性能监视器API .
  18. 机器学习实战之决策树(一)构造决策树
  19. 勒索软件攻击创新高,邮件安全需警惕
  20. 化工行业供应商协同管理系统:助力企业打造良好营商环境,提升运营效率

热门文章

  1. 计算机指令集以及对比
  2. 大模型入门(一)—— LLaMa/Alpaca/Vicuna
  3. composer syntax error, unexpected ‘|‘
  4. 计算机专业有必要数学竞赛吗,竞赛党必读,五大竞赛学科各有利弊,到底哪科最适合你呢...
  5. 【C语言】3天速刷C语言(初识)
  6. 我的难题(基于分析泰坦尼克号事件)
  7. 初次使用,用 欢迎使用CSDN-markdown编辑器 做个实验
  8. 计算机应用基础毕业论文摘要,(毕业论文计算机应用基础.doc
  9. Node.js和Javascript的异同
  10. 【轨迹挖掘】经纬度精度与实际位置精度的关系