IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> CubeSLAM论文阅读 -> 正文阅读

[人工智能]CubeSLAM论文阅读

CubeSLAM: Monocular 3-D Object SLAM

Shichao Yang and Sebastian Scherer

摘要

In this paper, we present a method for single image three-dimensional (3-D) cuboid object detection and multiview object simultaneous localization and mapping in both static and dynamic environments, and demonstrate that the two parts can improve each other. First, for single image object detection, we generate high-quality cuboid proposals from two-dimensional (2-D) bounding boxes and vanishing points sampling. The proposals are further scored and selected based on the alignment with image edges. Second, multiview bundle adjustment with new object measurements is proposed to jointly optimize poses of cameras, objects, and points. Objects can provide long-range geometric and scale constraints to improve camera pose estimation and reduce monocular drift. Instead of treating dynamic regions as outliers, we utilize object representation and motion model constraints to improve the camera pose estimation. The 3-D detection experiments on SUN RGBD and KITTI show better accuracy and robustness over existing approaches. On the public TUM, KITTI odometry and our own collected datasets, our SLAM method achieves the state-of-the-art monocular camera pose estimation and at the same time, improves the 3-D object detection accuracy.

引言

? Object SLAM:作为SLAM路标的目标也可以提供额外的语义和几何约束来提高相机的位姿估计。本文提出了CubeSLAM,联合2D和3D目标检测和SLAM位姿估计,在静态和动态环境中,如下图所示。

在这里插入图片描述

? 首先假设3D框在投影后会紧紧的落在2D包围框上。给定一个2D框,通过消失点(VP)采样,生成很多3D框proposal。然后通过多视图BA对所选的3D框proposal进行点和相机的优化。目标的作用两个:为BA提供几何和尺度约束;为难以三角化的点提供初始深度信息。SLAM中估计的相机位姿也用于单视角目标检测。最后,在动态情况下,基于动态点观测和运动模型约束共同优化相机和目标的轨迹,而不是将运动目标作为离群值。论文的贡献:

  • An efficient, accurate, and robust single image 3-D cuboid detection approach without requiring prior object models.
  • An object SLAM method with novel measurements between cameras, objects, and points, that achieves better pose estimation on many datasets, including KITTI benchmark.
  • Results demonstrating that object detection and SLAM benefit each other.
  • A method to utilize moving objects to improve pose estimation in dynamic scenarios.

3D目标检测

A. 3D Box Proposal Generation

(1) 原理

? 而不是在3D空间中随机的采样,本文利用检测得到的2D包围框生成3D proposal。一个3D包围框可以由9个参数表示:3DoF的位置 t = [ t x , t y , t z ] \bold{t} = [t_x,t_y,t_z] t=[tx?,ty?,tz?] ,3DoF的旋转 R R R ,和3DoF的大小 d = [ d x , d y , d z ] \bold{d}=[d_x,d_y,d_z] d=[dx?,dy?,dz?] 。3D包围框的物体坐标系被定义在框的中心,与其主轴对齐。

? 已知相机的内参 K K K ,基于这个假设:3D包围框的角点被投影到图像后,应该与2D检测框贴合。但这样仅有4个约束对应到2D框的4条边,因此无法完全约束9个参数,需要知道其它信息。本文利用VP来减少回归参数。

? VP是平行线投影到投影图后的交点。一个3D包围框有3个正交轴,根据物体关于相机坐标系的旋转矩阵和相机内参矩阵K,可以得到3个VP:
V P i = K R col ( i ) , i ∈ { 1 , 2 , 3 } (1) VP_i = K R_{\text{col}(i)} , i \in \{1,2,3\} \tag{1} VPi?=KRcol(i)?,i{1,2,3}(1)
? 其中 R col ( i ) R_{\text{col}(i)} Rcol(i)? R R R 的第i列。

(2) 从VP获得2D角点

? 这里描述如何跟踪VP来获得8个3D框投影到图像的角点。由于最多可以同时观测到3D包围框的3面,可以根据图2所示的可观测面数量将3D框构型分为三个常见类别。每种构型都可以是左右对称的。

在这里插入图片描述

? 以 图2(a) 为例。假设3个VP点和位于2D框顶部的角点 p 1 p_1 p1? 已知,且设 × \times × 表示两条直线的交点,则:
p 2 = ( V P 1 , p 1 )  ̄ × ( B , C )  ̄ p 4 = ( V P 2 , p 1 )  ̄ × ( A , D )  ̄ p 3 = ( V P 1 , p 4 )  ̄ × ( V P 2 , p 2 )  ̄ p 5 = ( V P 3 , p 3 )  ̄ × ( C , D )  ̄ p_2 = \overline{ (VP_1 ,p_1) } \times \overline{ (B,C) } \\ p_4 = \overline{ (VP_2 ,p_1) } \times \overline{ (A,D) } \\ p_3 = \overline{ (VP_1 ,p_4) } \times \overline{ (VP_2,p_2) } \\ p_5 = \overline{ (VP_3 ,p_3) } \times \overline{ (C,D) } p2?=(VP1?,p1?)?×(B,C)?p4?=(VP2?,p1?)?×(A,D)?p3?=(VP1?,p4?)?×(VP2?,p2?)?p5?=(VP3?,p3?)?×(C,D)?
? 其它点同理。

(3) 从2D角点中获得3D Box 位姿

? 在获得2D图像上的3D框角点之后,需要估计3D框的3D角点和位姿。将3D划分为两种物体:

任意位姿的物体

? 由于单目尺度的不确定性,使用PnP求解器求解3D框的3D位置和尺度因子。从数学上说,3D框的8个角点在物体坐标系的坐标为 [ ± d x , ± d y , ± d z ] / 2 [\pm d_x,\pm d_y,\pm d_z]/2 [±dx?,±dy?,±dz?]/2 ,在相机坐标系为 R [ ± d x , ± d y , ± d z ] / 2 + t R[\pm d_x,\pm d_y,\pm d_z]/2 + \bold{t} R[±dx?,±dy?,±dz?]/2+t 。如图2(a)所示,可以选择四个相邻的角点,如1、2、4、7,这四个角点可以从上述的3D 角点投影得到;例如; 对于角点1:
p 1 = π ( R [ d x , d y , d z ] / 2 + t ) (2) p_1 = \pi ( R[d_x,d_y,d_z]/2 + \bold{t} ) \tag{2} p1?=π(R[dx?,dy?,dz?]/2+t)(2)
? 其中 π \pi π 是相机的投影函数, p i , ( i = 1 , 2 , ? ? , 8 ) p_i,(i=1,2,\cdots,8) pi?,(i=1,2,?,8) 是8个2D角点中的其中一个。每个角点提供两个约束,因此4个角点可以对 物体位姿(9DOF)除了尺度之外的完整约束。

地面上的物体:

? 对于在地面上物体,可以简化上面的过程。在地面上建立世界坐标系,然后物体的roll/pitch角为零。与前一节类似,从VP得到8个二维角。不使用(2)中PnP求解器,而是直接将地面上的角点像素坐标反投影到3D地平面上,然后计算其他角点,形成一个3D框。这种方法非常有效,并具有解析表达式。

? 3D地面可以表示为 [ n , m ] [\bold{n},m] [n,m] n \bold{n} n 是在相机坐标系的法向量,m是距离。 对于角点5,对应的3D角点 P 5 \bold{P}_5 P5? 可以表示反向投影射线 K ? 1 p 5 K^{-1} p_5 K?1p5? 与地面的交点:
P 5 = ? m n ? ( K ? 1 p 5 ) (3) \bold{P}_5 = \frac{-m}{ \bold{n}^\top (K^{-1} p_5) } \tag{3} P5?=n?(K?1p5?)?m?(3)
? 这个尺度通过在投影过程中的相机高度确定。

(4) 采样VP

? 根据前两节的分析,box估计的问题变成了如何得到3个VP和一个顶部的2d角,在得到VP之后,可以使用Section III-A2来计算2d角,然后使用Section III-A3来计算3d框。

? 从(1)中,VP由目标旋转矩阵 R R R 确定。虽然可以使用深度学习通过大量的数据训练直接预测,但这里选择人工对其进行采样,然后对其进行打分(排序),以达到更好的泛化性能。

? 对于一般的目标,需要采样完整旋转矩阵R;而对于地面上的目标,相机的roll/pitch角加上采样物体的yaw角,即可计算 R R R

? 在SUN RGBD或KITTI等数据集中,已经提供了相机的roll/pitch角。对于多视角视频数据,使用SLAM来估计相机位姿。从而大大减小了采样空间,提高了采样精度。在本文的实验中只考虑了地面上的物体。

B. Proposal Scoring

? 在采样得到很多3D proposals后,定义一个代价函数来评估这些proposal。现在有很多不同的评分方法,比如基于语义分割的、边缘距离的、HOG特征点。这里使用对齐图像边缘特征来定义代价函数。由于VP和鲁棒边缘滤波的限制,这种方法最适合于“有清晰边缘的方框” 目标。

? 首先记图像为 I I I ,3D框为 O = { R , t , d } O = \{ R,\bold{t},\bold{d} \} O={R,t,d},定义代价函数为:
E ( O ∣ I ) = ? dist ( O , I ) + w 1 ? angle ( O , I ) + w 2 ? shape ( O ) (4) E(O \vert I) = \phi_{\text{dist}} ( O,I ) +w_1 \phi_{\text{angle}} (O,I) + w_2 \phi_{\text{shape}} (O) \tag{4} E(OI)=?dist?(O,I)+w1??angle?(O,I)+w2??shape?(O)(4)
? 其中 ? dist , ? angle , ? shape \phi_{\text{dist}},\phi_{\text{angle}},\phi_{\text{shape}} ?dist?,?angle?,?shape? 三种代价函数,将在下面定义。 w 1 , w 2 w_1,w_2 w1?,w2? 是权重,这里设置 w 1 = 0.8 , w 2 = 1.5 w_1=0.8 , w_2 = 1.5 w1?=0.8,w2?=1.5

(1) 距离误差

? 距离误差 ? dist ( O , I ) \phi_{\text{dist}}(O,I) ?dist?(O,I) :2D包围框的边缘应该匹配实际的图像边缘。首先检测Canny边缘,基于这些边缘构建一个距离变换图。对于每个可见的包围框边缘(如图2中蓝色实线),从每条线均匀的采样10个点,然后将距离值求和,并除以2D框的对角线。这类似于Chamfer距离。

(2) 角度对齐误差

? 角度对齐误差 $\phi_{\text{angle}}(O,I) $: 距离误差对false positive边缘(如物体表面纹理)很敏感。因此,这里检测较长的线段(如图3中的绿色线所示),并测量其角度是否与VP一致。

在这里插入图片描述

? 基于点-线支持关系,这些线首先与三个VP中的一个相关联。然后对于每个 VP i \text{VP}_i VPi? ,可以找出斜率最小和最大的两条最外侧线段,记为 ? l i _ m s , l i _ m t ? \langle l_{i\_ms}, l_{i\_mt} \rangle ?li_ms?,li_mt?? ? l i _ n s , l i _ n t ? \langle l_{i\_ns}, l_{i\_nt} \rangle ?li_ns?,li_nt?? ? a , b ? \langle a, b \rangle ?a,b? 表示以两个端点 a , b a,b a,b 表示的线的斜率。因此,角度对齐误差为:
? angle ( O , I ) = ∑ i = 1 : 3 ∥ ? l i _ m s , l i _ m t ? ? ? VP i , l i _ m t ? ∥ + ∥ ? l i _ n s , l i _ n t ? ? ? VP i , l i _ n t ? ∥ (5) \phi_{\text{angle}}(O,I) = \sum_{i=1:3} { \Vert \langle l_{i\_ms}, l_{i\_mt} \rangle - \langle \text{VP}_i, l_{i\_mt} \rangle \Vert + \Vert \langle l_{i\_ns}, l_{i\_nt} \rangle - \langle \text{VP}_i, l_{i\_nt} \rangle \Vert } \tag{5} ?angle?(O,I)=i=1:3??li_ms?,li_mt????VPi?,li_mt??+?li_ns?,li_nt????VPi?,li_nt??(5)

(3) 形状误差 ? shape ( O ) \phi_{\text{shape}}(O) ?shape?(O)

? 前两个误差仅在2D图像空间上计算,然而相同的2D角点可能会生成不同的3D框。42
? shape ( O ) = max ? ( s ? σ , 0 ) (6) \phi_{\text{shape}}(O) = \max (s- \sigma,0) \tag{6} ?shape?(O)=max(s?σ,0)(6)
? 其中 s = max ? d x / d y , d y / d x s=\max{d_x / d_y, d_y / d_x} s=maxdx?/dy?,dy?/dx? 是宽高比, σ \sigma σ 是一个阈值,被设置为1。如果 s < σ s < \sigma s<σ ,则不会应用这个惩罚项。

Object SLAM

? 将前面单图像3D目标检测拓展到多视图object-SLAM,来优化物体的位姿和相机的位姿。这一块基于ORB SLAM2。ORB SLAM2包括用于相机跟踪的前端和用于BA的后端。这里主要修改了其BA部分,将物体、点、相机位姿一起进行优化。

A. BA的形式

? BA是联合优化各种地图组件的过程,例如相机的位姿和点。这里用到了点,因为光物体不能完全约束相机的位姿。记相机位姿的集合为 C = { C i } C=\{ C_i \} C={Ci?} ,3D物体框的集合为 O = { O j } O=\{ O_j \} O={Oj?} ,点集合为 P = { P k } P=\{P_k \} P={Pk?} ,则BA的形式为如下的非线性最小二乘问题:
C ? , O ? , P ? = arg?min { C , O , P } ∑ C i , O j , P k ∥ e ( c i , o j ) ∥ Σ j k 2 + ∥ e ( c i , p k ) ∥ Σ i k 2 + ∥ e ( o j , p k ) ∥ Σ j k 2 (7) C^*, O^*, P^* = \mathop{\text{arg min}}_{\{ C,O,P \}} \sum_{C_i,O_j,P_k}{ \Vert \bold{e}(c_i,o_j) \Vert ^2_{\Sigma_{jk}} + \Vert \bold{e}(c_i,p_k) \Vert ^2_{\Sigma_{ik}} + \Vert \bold{e}(o_j,p_k) \Vert ^2_{\Sigma_{jk}} } \tag{7} C?,O?,P?=arg?min{C,O,P}?Ci?,Oj?,Pk??e(ci?,oj?)Σjk?2?+e(ci?,pk?)Σik?2?+e(oj?,pk?)Σjk?2?(7)
? 其中 e ( c , o ) \bold{e}(c,o) e(c,o) e ( c , p ) \bold{e}(c,p) e(c,p) e ( o , p ) \bold{e}(o,p) e(o,p) 分别表示camera object、camera point、object point的测量误差。 Σ j k \Sigma_{jk} Σjk? 是协方差矩阵。然后使用GN和LM算法在g2o或iSAM框架下求解该问题。

? object SLAM的框架如下:

在这里插入图片描述

记号

? 相机位姿通过 T c ∈ S E ( 3 ) T_c \in SE(3) Tc?SE(3) 表示,点通过 P ∈ R 3 P \in \mathbb{R}^3 PR3 表示。

? 3D包围框可以通过9自由度的参数表示: O = { T o , d } O = \{ T_o,\bold{d} \} O={To?,d} ,其中 T o = [ R , t ] ∈ S E ( 3 ) T_o=[R,\bold{t}] \in SE(3) To?=[R,t]SE(3) 是6DOF的位姿, d ∈ R 3 \bold{d} \in \mathbb{R}^3 dR3 是包围框的大小。在KITTI中,也可以使用数据集提供的目标大小,此时 d \bold{d} d 就不需要进行优化。下标 m m m 表示测量。

B. 测量误差

(1) Camera-Object测量

? 在物体和相机之间使用两种测量误差:

(a) 3D测量

? 当3D目标检测精确时使用的方法。从单图像目标检测中检测到的物体位姿 O m = ( T o m , d m ) O_m = (T_{om},\bold{d}_m) Om?=(Tom?,dm?) 作为从图像坐标系的物体测量。为了计算它的测量误差,将gt物体路标变换到相机坐标系,并比较它和物体测量的误差:
e c o _ 3 D = [ log ? ( ( T c ? 1 T o ) T o m ? 1 ) s e 3 ∨ d ? d m ] (8) e_{co\_3D} = [\log{\big( ( T_c^{-1} T_o ) T_{om}^{-1} \big)}_{ \mathfrak{se}_3 }^{\vee} \quad \bold{d}- \bold{d}_m] \tag{8} eco_3D?=[log((Tc?1?To?)Tom?1?)se3??d?dm?](8)
? 其中 log ? \log log S E 3 SE3 SE3 误差映射到6DOF正切向量空间,因此 e c o _ 3 D ∈ R 9 e_{co\_3D} \in \mathbb{R}^9 eco_3D?R9 。此外,还使用了Huber核函数来提高鲁棒性。

? 需要注意的是,如果没有先验的物体模型,基于图像的包围框检测无法区分物体的正面或背面。例如,即使旋转物体坐标系90?和交换长度与宽度,也能表示相同的包围框。因此,需要沿着高度方向旋转 0 , ± 9 0 ° , 18 0 ° 0,\pm 90 ^ \circ,180^\circ 0,±90°,180° 来找到上式的最小误差。

(b) 2D测量

? 对于2D测量,将gt物体路标投影到图像平面,得到2D gt 包围框,然后将其与检测到的2D包围框相比较。如下图所示:

在这里插入图片描述

? 具体实现上,将3D包围框的8个角点投影到图像,然后找到这些投影点的最大和最小值,组成一个矩形:
[ u , v ] min = min { π ( R [ ± d x , ± d y , ± d z ] / 2 + t ) } [ u , v ] max = max { π ( R [ ± d x , ± d y , ± d z ] / 2 + t ) } c = ( [ u , v ] min + [ u , v ] max ) / 2 s = [ u , v ] max ? [ u , v ] min (9) [u,v]_{\text{min}} = \text{min} \{ \pi ( R[\pm d_x,\pm d_y,\pm d_z] /2 + \bold{t} ) \} \\ [u,v]_{\text{max}} = \text{max} \{ \pi ( R[\pm d_x,\pm d_y,\pm d_z] /2 + \bold{t} ) \} \\ \bold{c} = ( [u,v]_{\text{min}} + [u,v]_{\text{max}} ) /2 \\ \bold{s} = [u,v]_{\text{max}} - [u,v]_{\text{min}} \tag{9} [u,v]min?=min{π(R[±dx?,±dy?,±dz?]/2+t)}[u,v]max?=max{π(R[±dx?,±dy?,±dz?]/2+t)}c=([u,v]min?+[u,v]max?)/2s=[u,v]max??[u,v]min?(9)
? 其中 [ u , v ] min,max [u,v]_{\text{min,max}} [u,v]min,max? 表示8个投影角点的最小/最大的xy坐标值,即投影得到的矩形的的左上角和右下角。 c \bold{c} c s \bold{s} s 是计算得到的2D gt包围框中心和大小,两个都是2D向量,因此 [ c , s ] ∈ R 4 [\bold{c},\bold{s}] \in \mathbb{R}^4 [c,s]R4 。则4D的矩形误差定义为:
e c o _ 2 D = [ c , s ] ? [ c m , s m ] (10) e_{co\_2D} = [\bold{c},\bold{s}] - [\bold{c}_m,\bold{s}_m] \tag{10} eco_2D?=[c,s]?[cm?,sm?](10)
? 这个测量误差与3D误差 (8) 相比,不确定性更小,这是因为2D物体检测比3D检测更精确。这个投影过程类似于重投影误差。然而,由于许多不同的3-D包围框可以投影到同一个2D矩形上,因此需要更多的观测来完全约束相机位姿和3D包围框,因此投影后也会丢失信息。

? 由于复杂的检测过程,无法直接建模和估计误差协方差矩阵 Σ \Sigma Σ 或hessian矩阵 W。因此,这里简单的对语义置信度相近或几何上相近的物体更多的权重。假设cuboid-camera距离为 d d d ,物体的2D检测概率为 p p p ,在KITTI数据集上,定义权重为 w = p × max ? ( 70 ? d , 0 ) / 50 w=p \times \max (70-d,0)/50 w=p×max(70?d,0)/50 ,其中70m是截断距离,参数随着不同数据集而变化。

(2) Object-Point测量

? 点和物体互相约束。如果点 P P P 属于一个物体,则该点在3D包围框里面。所以首先将点转换为物体坐标系,然后比较物体点到物体表面的距离:
e o p = max ? ( ∣ T o ? 1 P ∣ ? d m , 0 ) (11) e_{op} = \max(\vert T_o^{-1} P \vert - \bold{d}_m,\bold{0}) \tag{11} eop?=max(To?1?P?dm?,0)(11)
? 使用 max ? \max max 算子是因为这里仅仅鼓励点落在3D包围框里面,而不是仅落在表面上。

(3) Camera-Point测量

? 使用基于特征点SLAM中标准的3D点重投影误差:
e c p = π ( T c ? 1 P ) ? z m (12) e_{cp} = \pi ( T_c^{-1} P ) - z_m \tag{12} ecp?=π(Tc?1?P)?zm?(12)
? 其中 z m z_m zm? 3D点 P P P 的像素。

C. 数据关联

? 跨帧数据关联是SLAM的另一个重要组成部分。与点匹配相比,目标关联更容易,因为它包含了更多的纹理信息,可以使用许多二维目标跟踪或模板匹配方法。甚至在一些简单的场景中,可以直接使用2D框的IoU来进行匹配。但是,如图5所示,当存在严重的目标遮挡时,这些方法都不具有鲁棒性。此外,当前SLAM优化中需要检测和去除动态目标,但标准的目标跟踪方法无法区分其是否是静态的,除非使用特定的运动分割。

? 因此,本文提出了一种基于特征点匹配的物体关联方法。对于基于点的SLAM方法,通过描述子匹配和对极几何检查,可以有效地匹配不同视图中的特征点。因此,如果在二维物体包围框中至少观测到两帧的点,且这些点到3D框中心的3D距离小于 1 m,首先将特征点与它们对应的目标关联起来。例如在图5中,特征点与其关联目标具有相同的颜色。注意,在(11)中的BA计算目标点测量误差时,也使用了这种目标点关联。最后,在不同帧中,如果两个目标之间共享的特征点数量最多,且数量也超过一定的阈值(默认为10个),则对两个目标进行匹配。

? 根据实验,这种方法对于宽基线匹配、重复目标、遮挡的效果很好。由于运动目标的动态特征点不能满足极线约束,因此将其丢弃。因此,将关联特征点较少的目标视为动态目标,如图5中的前青色汽车。

在这里插入图片描述

?

动态SLAM

? 上一节处理的是静态物体SLAM,而在本节提出联合相机位姿和动态物体轨迹。这里对目标做了一些假设,以减少未知量的数量并使问题可解决。常用的两种假设是:目标物体是刚体,并且遵循物理上可行的运动模型。

? 刚体假设表明,一个点在其关联物体上的位置不随时间而改变。这可以通过标准的3D地图点重投影误差来优化它的位置。

? 对于运动模型,最简单的形式是匀速恒速运动模型。对于某些特定的目标,如车辆,额外地约束遵循非完整的车轮模型(有一些侧滑)。

A. 记号

? 对于动态物体 O j O^j Oj ,需要估计它相对于被观测坐标系 j j j 的位姿 j O i ^jO^i jOi 。使用“动态点”来表示这些移动物体上的特征点。对于在运动物体 O i O^i Oi 上的动态点 P k P^k Pk ,表示它相对于物体坐标系的位置为 i P k ^iP^k iPk,基于刚体假设,这是固定不变的。而这些点的世界坐标系的位置会随着时间改变,因此不适合用做SLAM优化。

B. SLAM优化

? 动态物体估计的因子图如图6所示。蓝色的节点是SLAM的静态元素,红色的节点是动态物体、点和运动速度,绿色的节点表示测量因子,包括(10)中的camera-object因子,(14)中的object-velocity因子,(15)中的point-camera-object因子。通过这些因子,相机位姿也可以通过动态元素来约束。

在这里插入图片描述

(1)物体运动模型

? 通用的3D物体运动可由位姿变换矩阵 T ∈ S E ( 3 ) T \in SE(3) TSE(3) 表示。可以将T与之前的位姿做变换,预测当前的位姿,并与当前估计的位姿得到位姿误差。这里采用受限非完整车轮模型(restricted nonholonmic wheel model),这个模型也在其它车辆跟踪工作上使用。车辆的运动可以由线速度 v v v 和转向角度 ? \phi ? 表示。假设车辆在一个局部近似平面上运动,物体的 roll/pitch=0,在z轴上的平移 t z = 0 t_z = 0 tz?=0 。仅仅使用 t x , t y , θ ? ( y a w ) t_x,t_y,\theta \ (yaw) tx?,ty?,θ?(yaw) 就可以表示完整的正态 T o = [ R ( θ ) [ t x , t y , 0 ] ′ ] T_o = [ R(\theta) [t_x,t_y,0]' ] To?=[R(θ)[tx?,ty?,0]] 。从速度预测的状态为:
[ t x ′ t y ′ θ ′ ] = [ t x t y θ ] + v Δ t [ cos ? ( θ ) sin ? ( θ ) tan ? ( ? ) / L ] (13) \begin{bmatrix} t'_x\\ t'_y\\ \theta ' \\ \end{bmatrix} = \begin{bmatrix} t_x\\ t_y\\ \theta\\ \end{bmatrix} + v \Delta t \begin{bmatrix} \cos(\theta)\\ \sin(\theta)\\ \tan(\phi)/L \\ \end{bmatrix} \tag{13} ???tx?ty?θ????=???tx?ty?θ????+vΔt???cos(θ)sin(θ)tan(?)/L????(13)
? 其中 L 是前后轮中心之间的距离。注意,这个模型要求 x , y , θ x,y,\theta x,y,θ 定义在后轮中心,而物体坐标系定义在车辆中心。这两个坐标系之间有 L / 2 L/2 L/2 的偏移。最后,运动模型误差为:
e mo = [ t x ′ , t y ′ , θ ′ ] ? [ t x , t y , θ ] (14) e_{\text{mo}} = [t'_x, t'_y, \theta '] - [t_x,t_y,\theta] \tag{14} emo?=[tx?,ty?,θ]?[tx?,ty?,θ](14)

(2) 动态点观测

? 如上面所说的那样,动态点被固定在其所在的物体上,因此它首先需要被转换到世界坐标系,然后投影到相机坐标系。假设第i个物体的第k个点的局部位置是 i P k ^iP^k iPk ,第j个图像的物体位姿是 j T o i ^j T _o^i jToi? ,点的重投影误差为:
e d p = π ( j T o i i P k , T c j ) ? z k , j (15) e_{dp} = \pi \big( {^jT_o^{ii}} P^k , T_c^j \big) - z_{k,j} \tag{15} edp?=π(jToii?Pk,Tcj?)?zk,j?(15)
? 其中 T c j T_c^j Tcj? 是第 j 相机位姿, z k , j z_{k,j} zk,j? 是该点观测到的像素。

C. 动态数据关联

? 通过实验,发现前面的静态环境关联方法不适合动态情况,因为动态点特征匹配存在困难。跟踪特征点的典型方法是预测其投影位置,搜索其描述子的附近的特征,然后检查对极几何约束。然而,在单目动态情况下,很难准确预测物体和点的运动,当物体运动不准确时,对极几何也不准确。

? 因此,这里对点的数据关联和物体的数据关联设计了不同的方法。特征点通过2D KLT稀疏光流来直接跟踪,这不需要点的3D位置。像素跟踪之后,动态特征的3D点通过三角化得到,这种三角化考虑了物体的运动。

? 数学上说,假设两帧的投影矩阵为 M 1 M_1 M1? M 2 M_2 M2? ,两帧中3D点的位置为 P 1 , P 2 P_1,P_2 P1?,P2? ,对应的像素为 z 1 , z 2 z_1,z_2 z1?,z2? 。两帧之间物体运动的变换矩阵为 Δ T \Delta T ΔT ,然后可以推导得 $P_2 = \Delta T P_1 $ 。基于这个投影规则,有:
M 1 P 1 = z 1 M 2 Δ T P 1 = z 2 (16) M_1 P_1 = z_1 \\ M_2 \Delta T P_1 = z_2 \tag{16} M1?P1?=z1?M2?ΔTP1?=z2?(16)
? 将 M 2 Δ T M_2 \Delta T M2?ΔT 为补偿物体运动后的修改的相机位姿,上面的等式是标准的两视图三角化问题,可以通过SVD来求解。

? 当像素位移较大时,例如,当另一辆车接近并朝向摄像机时,KLT跟踪仍然可能失败。因此,对于动态物体跟踪,不使用前面object slam中提到的特征点匹配方法,而是使用 KCF目标跟踪算法来跟踪。跟踪目标的二维包围框并根据前一帧预测其位置,然后与当前帧中重叠比例最大的检测到的包围框进行匹配。

实现

A. 目标检测

? 对于二维物体检测,对于室内场景,使用概率阈值为0.25的YOLO算法,而对于室外场景(KITTI),使用概率阈值为0.5MS-CNN。两者都在GPU上实时运行。

? 如果一个精确的相机位姿是已知的,例如,在SUN RGBD数据集中,只需要采样物体的yaw角来计算VPs。如IV-B1节所述,在yaw角90?范围内的物体的15个采样被生成为可以旋转的包围框。

? 然后在2-D包围框的上边缘上采样10个点,作为p1点。注意,并不是所有的采样都能生成有效的3D框proposal,因为一些框的角点可能位于2D框之外。

? 在没有gt相机位姿提供的场景中,在初始估计角度的20范围内采样相机的滚动/俯仰。对于没有先验信息的单一图像,简单地估计相机是平行于地面的。对于多视图场景,SLAM用于估计相机位姿。本方法的一个优点是,它不需要大量的训练数据,因为我们只需要调整(4)中的两个成本权值。它也可以实时运行,包括二维目标检测和边缘检测。

B. Object SLAM

? 整个SLAM算法的流程下图所示。系统是基于ORB-SLAM2的,但是没有改变相机跟踪和关键帧创建模块。

在这里插入图片描述

? 对于新创建的关键帧,检测3D包围框,并进行帧间数据关联,然后与相机的位姿和点执行BA。

? 对于动态物体,根据不同的任务选择重建或忽略它们。对于双目基线或视差角小于阈值时难以进行三角化的特征点,利用3D包围框对其深度进行初始化。实验证明,这可以在一些具有挑战性的场景中提高鲁棒性,如大的相机旋转。由于目标的数量远远少于点,目标关联和BA优化是实时高效运行的。为了得到单目SLAM的绝对地图尺度,该方法提供了初始帧的相机高度来对地图进行缩放。

? object SLAM也可以在没有点的情况下独立工作。在一些特征点较少的具有挑战性的环境中,ORB SLAM无法工作,但该算法仍然可以仅使用 物体-相机测量 来估计相机位姿。

? 优化过程中存在不同的代价函数,有些代价在像素空间中,如(10),有些代价在欧氏空间中,如(8)和(11),因此有必要调优它们之间的权值。由于3D框检测的不确定度难以分析,因此主要通过检测测量的数量和大小来手工调整物体代价权重,使不同类型的测量贡献大致相同。例如,与点相比,只有很少的物体,但它们在(10)中的重投影误差要比点大得多。从实验来看,物体相机和点相机的测量具有相似的权重。

C. 动态物体

? 动态物体的实现与上一节类似。恒定运动模型的假设可能不适用于实际数据集,因为物体可能会加速或减速(如图13所示)。通过对gt物体速度的分析,我们发现速度在5 s左右基本保持不变。因此,在SLAM中,运动模型约束只应用于最近5 s的观测。

实验-3D目标检测

A. Proposal Recall

在这里插入图片描述

B. Final Detection

在这里插入图片描述

在这里插入图片描述

实验-Object SLAM

A. TUM RGBD and ICL-NUIM Dataset

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

B. Collected Chair Dataset

在这里插入图片描述

C. KITTI Dataset

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

D. Dynamic Object

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

E. Time Analysis

在这里插入图片描述

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-05-13 11:44:22  更:2022-05-13 11:45:11 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/1 22:25:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码