论文链接:IS-Fusion: Instance-Scene Collaborative Fusion for Multimodal 3D Object Detection

代码链接https://github.com/yinjunbo/IS-Fusion

作者:Junbo Yin, Jianbing Shen, Runnan Chen, Wei Li, Ruigang Yang, Pascal Frossard, Wenguan Wang

发表单位:北京理工大学、澳门大学、香港大学、嬴彻科技、洛桑联邦理工学院、浙江大学

会议/期刊:CVPR2024

一、研究背景

3D目标检测在自动驾驶和机器人等应用中是一个关键任务。尽管点云提供了关于3D空间的宝贵几何信息,但通常缺乏详细的纹理描述且分布稀疏,特别是在远距离场景中。为了克服这些限制,近期的趋势是通过融合点云和多视角图像的信息进行多模态3D目标检测。图像模态提供了详细的纹理和密集的语义信息,补充了稀疏的点云,从而增强了3D感知能力。

现有方法通常在统一的鸟瞰图(BEV)空间中进行特征对齐和融合,但这种全局场景级别的融合忽略了前景实例和背景区域之间的差异,可能会影响性能。例如,BEV中的对象实例通常比自然图像中的对象实例尺寸更小,且前景实例占据的网格单元显著少于背景样本,导致前景和背景样本之间的严重不平衡。因此,上述方法难以捕获对象实例周围的本地上下文(Deepinteraction),或者在解码阶段很大程度上依赖于额外的网络来迭代地细化检测(Transfusion)。

一些方法(如Sparsefusion)旨在执行对象级编码,但它们忽略了场景和实例特征之间的潜在协作。例如,场景中的漏报对象可以通过与共享相似语义信息的实例交互来增强其特征来潜在地纠正。因此,如何同时制定实例级和场景级上下文,并利用多模态融合来优雅地集成它们,仍然是一个悬而未决的问题。

IS-Fusion 的动机: (a) 以前的方法通常侧重于多模态编码期间整个场景级别的融合。 (b)相比之下,IS-Fusion更加强调实例层面的融合,并探索实例到场景的协作以增强整体表征。

如图1所示,IS-Fusion探索了实例级和场景级融合,并鼓励实例和场景特征之间的交互以加强整体表示。它由两个关键组件组成:层次场景融合(HSF)模块和实例引导融合(IGF)模块。 HSF 旨在通过利用点到网格和网格到区域转换器来捕获各种粒度的场景特征。这还能够生成对 IGF 至关重要的高质量实例级特征。在IGF中,前景候选实例由场景特征的热图分数确定;同时,采用实例间自注意力来捕获实例关系。然后,这些实例通过可变形注意力从多模态上下文中聚合基本语义信息。此外,结合了实例到场景转换器的注意力,以强制局部实例特征与全局场景特征协作。这会产生增强的 BEV 表示,更适合 3D 对象检测等实例感知任务。

本文贡献:

  1. 提出IS-FUSION框架:本文提出了一种新的多模态融合框架IS-FUSION,旨在联合捕捉实例和场景级别的上下文信息,以提高3D目标检测性能。

  2. 设计分层场景融合(HSF)、实例引导融合(IGF)模块、实例到场景变压器注意机制:设计了点到网格和网格到区域的变压器,在不同粒度上捕捉多模态场景上下文,实现高质量的实例级特征生成。通过实例候选选择和自注意机制,挖掘实例关系,并聚合多模态上下文信息,增强场景特征。引入实例到场景的变压器注意机制,促进局部实例特征与全局场景特征的协作,生成更适合实例感知任务的BEV表示。

  3. 实验结果验证:在nuScenes基准测试中,IS-FUSION在所有已发布的多模态工作中表现最佳(它在 nuScenes 验证集上实现了 72.8% mAP,比现有技术 BEVFusion高出 4.3% mAP。它还比 CMT和 SparseFusion等同期工作分别高出 2.5% 和 1.8% mAP),显著提高了3D目标检测的性能,证明了所提方法的有效性和优越性。

二、整体框架

IS-Fusion 框架概述

上图包括点云和多视图图像的多模态输入,首先由模态特定的编码器处理以获得初始特征。然后,配备点到网格和网格到区域转换器的 HSF 模块利用这些特征生成具有分层上下文的场景级特征。此外,IGF 模块识别最显着的实例并聚合每个实例的多模式上下文。最后,实例到场景转换器使用这些实例将有价值的信息传播到场景,从而生成具有改进的实例感知的最终 BEV 表示。

如上图所示,每个场景都由 LiDAR 点云P表示,以及由N个相机捕获的同步 RGB 图像I=\{I_1,I_2,...,I_N\}, 这些图像使用 LiDAR 传感器进行校准。目标是设计一个能够在给定多模态输入(P, I)的情况下生成精确的 3D 边界框Y的检测模型。所提议的 IS-Fusion 模型定义为:

Y=f_{\mathrm{~dec}}(f_{\mathrm{~enc}}(f_{\mathrm{~point}}(P),f_{\mathrm{~img}}(I))),

其中fpoint⁢(⋅)和fimg⁢(⋅)作为输入编码模块,fenc⁢(⋅)表示多模态编码器(由HSF和IGF组成),fdec⁢(⋅)是解码器。

多模态输入编码:为了处理来自异构模态的输入,首先利用模态特定的编码器来获取它们各自的初始表示,即 B_\mathrm{P}=f_\mathrm{~point}(P) , F_\mathrm{I}=f_\mathrm{~img}(I)。对于点云数据,使用VoxelNet,对于图像数据使用Swin-Transformer。这会产生点云 BEV 特征B p和图像透视视图 (PV) 特征F I。特别地, B_{\mathbb{P}}\in\mathbb{R}^{W\times H\times C}是通过压缩3D体素特征的高度尺寸获得的,其中W和H是BEV网格的数量沿x和y轴的单元格,C表示通道维度。

多模态编码器:多模态编码器f enc⁢(⋅)在B p和F I之间进行跨模态特征融合,以产生融合的 BEV 特征 \hat{B}_{\mathrm{F}}\in\mathbb{R}^{W\times H\times C}与之前仅关注整个场景级别的融合的多模态编码器相比,作者开发了实例级和场景级表示。为此,设计了使用两个模块的f enc⁢(⋅),即HSF模块f HSF⁢(⋅)和IGF模块f IGF⁢(⋅):

\hat{B}_\mathrm{F}=f_\mathrm{~enc}(B_\mathrm{P},F_\mathrm{I})=f_\mathrm{~IGF}(f_\mathrm{~HSF}(B_\mathrm{P},F_\mathrm{I})),

其中f HSF⁢(⋅)生成多粒度场景特征,而f IGF⁢(⋅)进一步集成有关前景实例的关键信息。

多模态解码器:多模态解码器的目标是根据 \boldsymbol{Y}=f_{\mathrm{~dec}}(\hat{\boldsymbol{B}}_{\mathrm{F}})给出的 BEV 表示 \hat{\boldsymbol{B}}_{\mathrm{F}}生成最终的 3D 检测Y。在本文工作中,f dec⁢(⋅)是建立在Transformer架构的基础上的(参考DETR3D的工作),它包含几个注意力层和一个用作检测头的前馈网络。在训练过程中,应用匈牙利算法来匹配预测边界框和GT边界框。同时,Focal loss 和L1 loss 分别用于分类和 3D 边界框回归。

具体过程总结如下。

a. 输入编码:

  • 点云编码:使用VoxelNet将LiDAR点云编码成鸟瞰图(BEV)特征。

  • 图像编码:使用Swin Transformer将多视角图像编码成透视视角(PV)特征。

b. 分层场景融合(HSF)模块:

  • 点到网格变压器:将点云特征投影到图像特征图上,并聚合成BEV网格特征。这一步通过多头自注意机制处理每个网格内的点特征。

  • 网格到区域变压器:在网格和区域之间交换信息,捕捉全局场景上下文。通过分组的多头注意机制在不同的BEV网格区域间传递信息。

c. 实例引导融合(IGF)模块:

  • 实例候选选择:通过热图分数确定前景实例候选,并用线性层嵌入每个实例特征。

  • 上下文聚合:通过自注意机制探讨实例间关系,并通过变形注意机制聚合每个实例的多模态上下文信息。

  • 实例到场景变压器:使用跨注意机制,将实例特征传递到BEV场景特征中,增强整体场景特征。

d. 多模态解码器:

  • 最终的3D检测结果是基于增强后的BEV表示生成的。解码器使用了一系列注意力层和前馈网络来生成最终的3D边界框。

三、核心方法

3.1 Hierarchical Scene Fusion

给定的点云BEV特征Bp,和图像PV特征F1,使用分层场景融合HSF模块来融合得到场景表示B_{\mathrm{F}}{\in}\mathbb{R}^{W\times H\times C} ,这个模块实际上包含了Point-to-Grid(点到网格) transformer f P2G⁢(⋅)and Grid-to-Region(网格到区域) transformer f G2R⁢(⋅):

B_\mathrm{F}=f_\mathrm{~HSF}(F_\mathrm{I},B_\mathrm{P})=f_\mathrm{~G2R}(f_\mathrm{~P2G}(F_\mathrm{I}),B_\mathrm{P}).

这里,f P2G⁢(⋅)考虑每个BEV网格中的点/像素间相关性,而f G2R⁢(⋅)进一步挖掘网格间和区域间多模态场景上下文。直觉是不同的特征粒度捕获不同级别的场景上下文。例如,在点级别,每个元素提供有关对象的特定组件的详细信息。相比之下,网格/区域级别的特征能够捕获更广泛的场景结构和对象的分布。因此,HSF 充分利用了各种表示粒度。

HSF 模块示意图。它首先使用点到网格变压器将点级特征聚合为网格级特征,然后通过网格到区域变压器探索网格间和区域间特征的交互。

点到网格Transformer:

首先, G=\{\mathbf{g}_{\mathrm{grid}}^{1},\mathbf{g}_{\mathrm{grid}}^{2},...,\mathbf{g}_{\mathrm{grid}}^{W\times H}\}表示将点云场景P离散化为voxel而获得的BEV网格,每个网格单元g_{\mathrm{grid}}\in G 都是一个包含L点 \{p_{\mathrm{point}}^1,p_{\mathrm{point}}^2,...,p_{\mathrm{point}}^L\}的柱子。点到网格Transformer为每个点分配其相应的图像特征,并聚合成BEV特征。

其实这里就是将[p_{\mathrm{point}}^1,p_{\mathrm{point}}^2,...,p_{\mathrm{point}}^L]{\in}\mathbb{R}^{L\times3} 内的L点投影到图像特征F1上面,并检索其像素级特征。

\begin{aligned}&[u^{1},u^{2},\cdots,u^{L}]=f_{\mathrm{proj}}([p_{\mathrm{point}}^{1},p_{\mathrm{point}}^{2},...,p_{\mathrm{point}}^{L}]),\\&[p_{\mathrm{point}}^{1},p_{\mathrm{point}}^{2},...,p_{\mathrm{point}}^{L}]=f_{\mathrm{interp}}(F_{\mathrm{I}},[u^{1},u^{2},\cdots,u^{L}]),\end{aligned}

其中,f proj⁢(⋅)表示从点云到多视图像的投影过程,在图像平面产生二维坐标[u^1,u^2,\cdotp\cdotp\cdotp,u^L] ,f interp⁢(⋅)是双线性插值函数计算非整数坐标处的特征。这样,就得到了逐点特征[p_{\mathrm{point}}^1,p_{\mathrm{point}}^2,...,p_{\mathrm{point}}^L]\in\mathbb{R}^{L\times C}

为了处理激光雷达和相机之间潜在的校准噪声,会对网格Transformer会比较柱内的所有点。这使得每个点能够考虑更大的感受野并隐式地纠正噪声点。然后,将逐点信息与最大池化操作f max⁢(⋅)合并:

g_{\mathrm{grid}}=f_{\max}(f_{\mathrm{MSA}}([p_{\mathrm{point}}^1,p_{\mathrm{point}}^2,...,p_{\mathrm{point}}^L]))\in\mathbb{R}^{1\times C},

其中f MSA⁢(⋅)是多头自注意力,g grid是一个网格特征,将分配给图像BEV特征 B_{\mathrm{I}}\in\mathbb{R}^{W\times H\times C}。然后,通过将B I与点云 BEV 特征 B_{\mathrm{P}}\in\mathbb{R}^{W\times H\times C}相结合来计算多模态 BEV 特征B F:

B_\mathrm{F}=f_\mathrm{~conv}([B_\mathrm{I},B_\mathrm{P}])\in\mathbb{R}^{W\times H\times C},

其中[⋅,⋅]表示串联,f conv⁢(⋅)由3个×3卷积层实现。

网格到区域Transformer:

除了对点间依赖关系进行建模的点到网格Transformer之外,还通过网格到区域转换器进一步探索网格间和区域间关系,以捕获全局场景上下文。这可以表示为\boldsymbol{B}_\mathrm{F}^{^{\prime}}=f_\mathrm{G2R}(\boldsymbol{B}_\mathrm{F}) ,其中BF′是增强的 BEV 特征。

直观上,f G2R⁢(⋅)可以通过将全局自注意力应用于所有网格特征 \{\mathbf{g}_{\mathrm{grid}}^1,\mathbf{g}_{\mathrm{grid}}^2,\cdots,\mathbf{g}_{\mathrm{grid}}^{W\times H}\}\boldsymbol{\in}\boldsymbol{B}_{\mathrm{F}}来实现。然而,由于网格单元数量众多,这在计算上可能会很昂贵。因此,选择将这些网格特征分组到不同的区域。每个区域都是由M×M网格单元 \{\mathbf{g}_{​{\mathrm{grid}}}^{1},\mathbf{g}_{​{\mathrm{grid}}}^{2},\cdots,\mathbf{g}_{​{\mathrm{grid}}}^{​{M^{2}}}\}描述的子集。接下来,将每个区域视为一个整体,并通过网格间注意力在区域内的网格之间交换信息。这是通过在一组网格特征 [\mathbf{g}_{​{\mathrm{grid}}}^{1},\mathbf{g}_{​{\mathrm{grid}}}^{2},\cdotp\cdotp\cdotp,\mathbf{g}_{​{\mathrm{grid}}}^{​{M^{2}}}]\in\mathbb{R}^{​{M^{2}\times C}}上运行的多头注意力f MSA⁢(⋅)来实现的:

[\tilde{\mathbf{g}}_{\mathrm{grid}}^1,\tilde{\mathbf{g}}_{\mathrm{grid}}^2,\cdots,\tilde{\mathbf{g}}_{\mathrm{grid}}^{M^2}]=f_{\mathrm{MSA}}([\mathbf{g}_{\mathrm{grid}}^1,\mathbf{g}_{\mathrm{grid}}^2,\cdots,\mathbf{g}_{\mathrm{grid}}^{M^2}]),

[\tilde{\mathbf{g}}_{​{\mathrm{grid}}}^{1},\tilde{\mathbf{g}}_{​{\mathrm{grid}}}^{2},\cdotp\cdotp\cdotp,\tilde{\mathbf{g}}_{​{\mathrm{grid}}}^{​{M^{2}}}]是attention得到的网格单元。

通过,区域间注意力捕获不同区域之间的相互作用。为此,将每个区域移动(M/2,M/2)个网格单元,并对每个包含M×M网格特征的移动区域进行自注意力(如有必要,使用填充)。这是由下式给出的:

[\mathbf{g}_{\mathrm{grid}}^{'\triangle_1},\mathbf{g}_{\mathrm{grid}}^{'\triangle_2},\cdots,\mathbf{g}_{\mathrm{grid}}^{'\triangle_{M^2}}]=f_{\mathrm{S-MSA}}([\mathbf{\tilde{g}}_{\mathrm{grid}}^{\triangle_1},\mathbf{\tilde{g}}_{\mathrm{grid}}^{\triangle_2},\cdots,\mathbf{\tilde{g}}_{\mathrm{grid}}^{\triangle_{M^2}}]),

其中 f S-MSA⁢(⋅) 表示滑动窗口自注意力,\{\triangle_1,\triangle_2,\cdots,\triangle_{M^2}\} 表示移位后的新网格索引。这允许每个网格在滑动之前与来自不同区域的网格进行交互,从而捕获远程依赖关系。然后,重新排列所有注意网格特征\{\mathbf{g}_{​{\mathrm{grid}}}^{​{^{\prime}1}},\mathbf{g}_{​{\mathrm{grid}}}^{​{^{\prime}2}},\cdots,\mathbf{g}_{​{\mathrm{grid}}}^{​{^{\prime}W\times H}}\} 以获得丰富的 BEV 特征图 B_{\mathrm{F}}^{\prime}\in\mathbb{R}^{W\times H\times C}

通过利用分层表示,HSF 能够将信息从各个点传播到不同的 BEV 区域。这有利于局部和全局多模式场景上下文的集成。

该模块总结如下:

a. 点到网格Transformer(Point-to-Grid Transformer)

功能:将点云特征投影到图像特征图上,并聚合成鸟瞰图(BEV)网格特征。

步骤:

  1. 点投影:将点云中的每个点投影到图像平面上,获取对应的图像像素特征。这一步通过一个投影函数来实现,将3D点坐标转换为图像上的2D坐标。

  2. 特征插值:使用双线性插值方法从图像特征图中提取对应点的特征,形成点特征矩阵。

  3. 多头自注意:在每个BEV网格内应用多头自注意机制,使每个点能够考虑其周围点的信息,增强特征表达。

  4. 特征聚合:通过最大池化操作将点特征聚合为网格特征,形成初步的BEV特征图。

b. 网格到区域Transformer(Grid-to-Region Transformer)

功能:捕捉网格之间和区域之间的全局场景上下文。

步骤:

  1. 网格分组:将BEV特征图划分为多个区域,每个区域包含一定数量的网格单元。

  2. 区域内自注意:在每个区域内应用多头自注意机制,捕捉区域内网格之间的关系,增强局部特征。

  3. 区域间自注意:通过偏移窗口操作,将每个区域向内偏移一个固定距离(例如M/2网格单元),并在偏移后的区域间应用自注意机制。这一步通过shifted-window自注意机制实现,使每个网格能够与更大范围内的其他网格交互,捕捉长距离依赖关系。

c. 特征融合

  1. 特征组合:将点到网格变压器生成的BEV网格特征与原始点云BEV特征进行通道维度上的连接(concat),形成一个多模态特征图。

  2. 卷积融合:通过3×3卷积操作,将连接后的多模态特征图进一步处理,生成融合后的BEV特征图。

3.2 Instance-Guided Fusion

IGF 的基本思想是挖掘每个对象实例周围的多模态上下文(例如车辆旁边的车道),同时将必要的实例级信息集成到场景特征中。例如,如果某个对象被错误地分类为场景特征中背景的一部分,可以通过将其与所有相关实例进行比较来纠正这一问题。形式上,给定 HSF 生成的场景特征B F′,式中的f IGF⁢(⋅):

\begin{aligned}\text{instance selection:}&\boldsymbol{Q}=f_{\mathrm{sel}}(\boldsymbol{B}_{\mathrm{F}}^{\prime})\in\mathbb{R}^{K\times C},\\\text{context aggregation:}&\tilde{\boldsymbol{Q}}=f_{\mathrm{agg}}(\boldsymbol{Q},\boldsymbol{B}_{\mathrm{F}}^{\prime})\in\mathbb{R}^{K\times C},\\\text{instance-to-scene:}&\hat{\boldsymbol{B}}_{\mathrm{F}}=f_{\mathrm{I2S}}(\boldsymbol{B}_{\mathrm{F}}^{\prime},\tilde{\boldsymbol{Q}})\in\mathbb{R}^{W\times H\times C},\end{aligned}

其中f sel⁢(⋅)选择top-𝐾显着实例特征Q=[q_{\mathrm{ins}}^1,q_{\mathrm{ins}}^2,...,q_{\mathrm{ins}}^K] ,f agg⁢(⋅)聚合每个实例的多模式上下文,f I2S⁢(⋅)合并到 BEV 场景特征BF′。下图中展示了IGF的整体流程,并解释f sel⁢(⋅)、f agg⁢(⋅)和f I2S⁢(⋅)如下。

IGF 模块示意图。首先根据 BVE 热图初始化候选实例。然后,对这些实例进行推理,同时从图像特征中聚合丰富的语义上下文。最后,这些实例通过实例到场景转换器注意机制将上下文信息传输到 BEV 场景特征。

实例候选选择。为了有效地生成实例特征,按照CenterPoint3D实现了f sel⁢(⋅),在场景特征BF′上应用关键点检测头来预测实例的中心。在训练过程中,为每个实例定义一个 2D 高斯分布作为目标,峰值位置由地面实况 3D 中心的 BEV 投影确定。采用Focal Loss来优化该预测头。在推理过程中,保留中心度分数最高的 top-K对象来表示相应的实例。同时,采用额外的线性层来嵌入每个实例,产生一组实例特征 \{\boldsymbol{q}_\mathrm{ins}^1,\boldsymbol{q}_\mathrm{ins}^2,...,\boldsymbol{q}_\mathrm{ins}^K\}

实例上下文聚合。设计f agg⁢(⋅)来计算实例到实例和实例到上下文的交互。在典型的驾驶场景中,经常观察到行人往往成群出现,车辆通常并存于路边。因此,研究实例之间的相关性至关重要。为此,在所选实例 [\boldsymbol{q}_\mathrm{ins}^1,\boldsymbol{q}_\mathrm{ins}^2,...,\boldsymbol{q}_\mathrm{ins}^K]\boldsymbol{\in}\mathbb{R}^{K\times C}上使用自注意力f MSA⁢(⋅):

[q_{\mathrm{ins}}^{'_1},q_{\mathrm{ins}}^{'_2},...,q_{\mathrm{ins}}^{'_K}]=f_{\mathrm{~MSA}}([q_{\mathrm{ins}}^1,q_{\mathrm{ins}}^2,...,q_{\mathrm{ins}}^K]),

此外,目标是挖掘每个实例的语义上下文。这是通过比较每个实例q ins′和多模态特征B F′中的相应部分来实现的。具体来说,只有在q ins′周围的一小组相邻位置(例如,D网格单元)被认为可以节省计算成本,遵循Deformable DETR中的可变形注意:

\tilde{\boldsymbol{q}}_{\mathrm{ins}}=f_{\text{ DeformAtt}}(\boldsymbol{q}_{\mathrm{ins}}^{\prime},f_{\mathrm{~conv}}(\boldsymbol{B}_{\mathrm{F}}^{\prime})),

其中f conv⁢(⋅)是3×3卷积运算,用于对齐q ins′和B F′之间的特征空间,以及 \tilde{\boldsymbol{q}}_{\mathrm{ins}}\in\{\tilde{\boldsymbol{q}}_{\mathrm{ins}}^1,\tilde{\boldsymbol{q}}_{\mathrm{ins}}^2,...,\tilde{\boldsymbol{q}}_{\mathrm{ins}}^K\}是丰富的实例特征。

实例到场景转换器。最后,f I2S⁢(⋅)使每个 BEV 网格特征能够从潜在相关实例中获取有价值的信息。为此,构建了具有变压器交叉注意机制的f I2S⁢(⋅)。具体来说,在将 B_{\mathrm{F}}^{'}\in\mathbb{R}^{W\times H\times C}展平为一组网格特征 \{\mathbf{g}_{\mathrm{grid}}^{​{^{\prime}1}},\mathbf{g}_{\mathrm{grid}}^{​{^{\prime}2}},...,\mathbf{g}_{\mathrm{grid}}^{​{^{\prime}W\times H}}\}后,使用每个网格g grid′作为查询来处理实例级特征 [\tilde{\boldsymbol{q}}_{\mathrm{ins}}^1,\tilde{\boldsymbol{q}}_{\mathrm{ins}}^2,...,\tilde{\boldsymbol{q}}_{\mathrm{ins}}^K]\in\mathbb{R}^{K\times C}

\hat{\mathbf{g}}_{\mathrm{grid}}=f_{\mathrm{MCA}}(\mathbf{g}_{\mathrm{grid}}^{\prime},[\tilde{\boldsymbol{q}}_{\mathrm{ins}}^1,\tilde{\boldsymbol{q}}_{\mathrm{ins}}^1,...,\tilde{\boldsymbol{q}}_{\mathrm{ins}}^K]),

其中f MCA⁢(⋅)表示多头交叉注意力, \hat{g}_{\mathrm{grid}}是注意力网格单元。在所有网格单元上应用f MCA⁢(⋅)后,将获得的网格特征 \{\hat{\mathbf{g}}_{\mathrm{grid}}^1,\hat{\mathbf{g}}_{\mathrm{grid}}^2,...,\hat{\mathbf{g}}_{\mathrm{grid}}^{W\times H}\}重新排列回 BEV 特征 \hat{\boldsymbol{B}}_{\mathrm{F}}\boldsymbol{\in}\mathbb{R}^{W\times H\times C},该特征将在后续解码阶段使用产生最终的 3D 检测。

总结如下:

a. 实例候选选择(Instance Candidates Selection)

功能:从场景特征中选择前景实例候选,以便在后续步骤中进行详细的特征聚合。

步骤:

  • 热图生成:使用一个关键点检测头在场景特征图上预测实例的中心位置热图。这个热图的目标是在每个实例的中心生成一个高分值。

  • 实例选择:在训练过程中,为每个实例定义一个2D高斯分布作为目标,热图峰值对应于3D实例中心在BEV中的投影位置。使用Focal Loss来优化这个检测头。在推理过程中,选择热图中得分最高的前K个实例作为实例候选。

  • 实例嵌入:通过一个线性层对每个选择的实例进行特征嵌入,生成一组实例特征。

b. 上下文聚合(Instance Context Aggregation)

功能:为每个实例聚合多模态上下文信息,并捕捉实例间的关系。

步骤:

  • 实例间自注意:对选定的实例特征应用多头自注意机制,探讨实例之间的关系。这一步使得每个实例能够考虑其他实例的信息。

  • 上下文聚合:利用变形注意机制,在实例周围的局部区域内聚合多模态上下文信息。具体步骤包括:

  • 特征对齐:通过一个3×3卷积操作对场景特征进行空间对齐。

  • 变形注意:在每个实例的邻域内(例如D个网格单元)执行变形注意操作,聚合局部多模态上下文信息。

c. 实例到场景变压器(Instance-to-Scene Transformer)

功能:将聚合的实例特征传递回全局场景特征,以增强整体场景特征表示。

步骤:

  • 跨注意机制:将BEV特征图展平为一组网格特征,并使用每个网格特征作为查询,对实例特征进行跨注意操作。这一步使得每个网格能够从相关实例中获取有价值的信息。

  • 特征重组:将增强后的网格特征重新组合为一个BEV特征图,为后续的3D检测解码提供输入。

四、实验结果

nuScenes 测试集上的 3D 对象检测性能。

“L”是激光雷达,“C”表示相机。 “C.V.”、“T.L.”、“B.R.”、“M.T.”、“Ped.”和“T.C.”分别表示施工车辆、拖车、障碍物、摩托车、行人和交通锥。 “†”表示具有测试时间增强和模型集成技术的模型。每列中的最佳结果以粗体标记。与所有其他已发布的 3D 检测工作相比,IS-Fusion 实现了卓越的性能。

nuScenes 验证集上的 3D 对象检测示例。

在多视图图像中用橙色、蓝色和红色可视化汽车、行人和自行车的 3D 边界框。在点云中,预测为灰色,GT 为绿色。

nuScenes 验证集上的性能比较。IS-Fusion 实现了卓越的 3D 检测性能,同时保持了相当的推理速度。

IS-Fusion 中每个模块在 nuScenes 验证集上的消融研究。 Baseline-L 表示仅使用 LiDAR 的基线,而 Baseline-LC 是指不使用 HSF 或 IGF 模块的 IS-Fusion 的简单变体。

IS-Fusion 的设计选择。探讨了 HSF 中各种成分的影响以及 IGF 中的最佳超参数。

包括了不同图像编码器的选择,HSF的逐成分消融和IGF中实例和top-K的选择。

在具有交通锥的挑战性场景中 BEV 特征的可视化们展示了带和不带 IGF 的模型的 BEV 特性。它表明 IGF 可以产生具有更高响应和更完整模式的实例表示。

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐