《Point Localization: Real-Time,Environmentally-Robust3D LiDAR Localization》2019 港科Ming Liu, Rui Fan

本文提出了一种利用3D激光雷达和GPS进行UGV长期定位的新方法。首先创建地图,然后将其分割进行点云配准,提高鲁棒性并减少时间。PointLocalization技术融合不同类型的里程计,优化定位准确性和频率。在UGV上测试表明,该算法能在180度FOV中实现20Hz以上的定位,精度可达10cm,并能处理过时地图,适合在变化的环境中使用。
摘要由CSDN通过智能技术生成

摘要:

        定位或位置修正是机器人技术研究中的一个重要问题。在本文中,我们提出了一种利用三维激光雷达在不断变化的环境中进行长期定位的新方法。

        我们首先使用GPS和激光雷达创建一个真实环境的地图。然后,我们将地图划分为几个小部分作为点云配准的目标,这不仅提高了鲁棒性,而且还减少了配准时间。Point Localization定位技术使我们能够融合不同类型的里程计,这可以优化定位结果的准确性频率。我们使用激光雷达和轮式里程计在无人地面车辆(UGV)上评估了我们的算法,并获得了融合后20 Hz以上的定位结果。该算法还可以在180度视场角(FOV)中定位UGV。利用六个月前捕获的过时地图,该算法显示出了很强的鲁棒性,测试结果表明,该算法可以达到10 cm的精度。Point Localization已经在一个拥挤的工厂进行了6个多月的测试。

I. I NTRODUCTION

        自2009年谷歌首次推出其自动驾驶汽车项目以来,自动驾驶汽车的部署一直在迅速增加。机器人技术研究的一个关键方面是定位,特别是在自动驾驶和无人地面车辆(UGVs)[3]的应用中,车辆在特殊领域运行。车辆的定位很重要,因此路径规划模块可以向其发送导航命令。定位是导航的基础。根据Paul [4]的说法,导航模块包含两部分:位置修正,包括比较当前位置的特征,如地标、路点和地图;航迹推算,即测量位置或速度的变化,如视觉里程计和车轮里程计。

        UGV沿着某条路线行驶,比如行李投递,并在工厂和采矿地点导航。在这些情况下,我们可以使用地图来指导车辆沿途行驶。许多不同类型的传感器可以用于定位[5]。当定位固定用于导航时,全球定位系统(GPS)是最常见的传感器之一,它可以定位世界上几乎任何位置。然而,它高度依赖卫星,这意味着它在信号可能受阻的城市中工作不佳。为了克服这一不足,GPS可以与一个惯性导航系统(INS)通过使用卡尔曼滤波器进行结合。这提高了准确性和鲁棒性。但是,该系统的成本很高,当GPS信号丢失时,它只能运行一分钟左右

        激光雷达或照相机的定位或定位修正需要一个固定的地图或地标。同步定位和映射(SLAM)可以获得固定的地图,它在许多场景中有广泛的应用,如清扫机器人。定向快速和旋转简报式(ORB-SLAM)[6]是一种基于相机的SLAM框架,在姿态估计方面具有很强的鲁棒性。它还提供了一个定位功能。然而,ORB的特征在光的变化期间发生变化,这种变化可能会导致失败,例如,建图发生在早上,而定位发生在晚上。当我们使用相机导航一个固定的地图时,很难用其他的位置固定系统,如GPS来取代ORB-SLAM。该方法在视觉里程计方面具有较高的精度,定位功能在工业领域也有很大的应用潜力。

        激光雷达最近已经成为自动驾驶的基本传感器,因为它通过照亮目标来测量到目标的距离。它不像照相机那样,并不依赖于光线。Zhang [7]提出了一种名为激光雷达测程和映射(LOAM)的方法,该方法利用激光雷达得到点云图,并利用角点和平面点的距离来优化LM方法的目标。LOAM显示了实时建图和最先进的精度。但是,这种方法不能消除累积误差,我们无法使用地图进行定位。Thrun [8]使用激光雷达的反射率来构建一个地图,该方法显示了大约10厘米的精度。然而,这种方法仅在地面上有足够数量的地标,且受到雨雪的影响时才有效。

        为了解决上述挑战,我们建立了一个点云图来消除光照变化,并使用GPS来约束我们的地图。这一步减少了在长距离上的漂移。为了使定位更加鲁棒性,我们使用其他类型的里程计来预测地图上的对应点,并且里程计也实现了比激光雷达更快的更新速度。

        本文的其余部分的结构如下。第二节说明了相关的工作,并将其他方法与我们的方法联系起来。第三节介绍了传感器和平台,我们介绍使用,以及一种基于图优化的建图方法。第四节介绍了点定位的方法。第五节讨论了在KITTI数据集上的结果和真实环境中的结果。第六节说明了实验结果,并概述了未来的工作。

II. R ELATED W ORK

        如前所述,ORB-SLAM [6]提供了一种定位方法,使用ORB特征[9]来计算视觉里程,但它对环境中亮度和特征的变化很敏感。为了解决这个问题,[10]首先使用激光雷达基于激光雷达地图几何信息构建了之前的地图,并提出了一个混合bundle adjustment框架来修正当前的姿态。沃尔科特和尤斯蒂斯[11]也使用激光雷达地图作为环境的先验知识;然而,它使用激光雷达生成的地面地图来匹配相机的结果。[12] [13]提出了另一种使用相机定位的方法,提出了一种使用无监督算法的在线地标选择方法,根据这些地标的可能性对分布式长期视觉定位系统进行选择。他们还提出了一种长期终身定位的地图管理系统。对于自动驾驶来说,定位仍然是工业应用中的一个具有挑战性的问题,因为它高度依赖于相机的特性,如动态范围和光敏性等,这可能会影响不同条件下视觉定位的鲁棒性 。

        Koide等人[14]使用图形SLAM来融合激光雷达和GPS信息。他们使用正态分布变换(NDT)[15]算法来扫描匹配,并使用GPS作为位姿图的约束。他们还将NDT配准算法与激光雷达提供的角速度数据相结合,使用无迹卡尔曼滤波器(UKF)进行定位。Pfrunder和Egger [16],[17]提出了一种新的SLAM方法,称为CSIRO SLAM(C-SLAM),它使用了IMU和LiDAR。它通过激光雷达的空间关系计算曲面,并将surfels匹配的变换误差和IMU的加速度和旋转数据最小化,从而得到当前姿态。他们还提供了一种定位方法,称为CSIRO定位(C-LOC),它也使用surfel匹配并融合来自IMU的数据来获得当前的定位结果。

       定位的一个问题是如何获得一个高质量的预建地图。许多研究者使用闭环检测方法来减少地图生成过程中的漂移。LEGO-LOAM[18]利用轨迹估计环路闭合,然后计算当前激光雷达帧和关键帧之间的均方根误差,这是过去获得的环路闭合条件。ORB-SLAM还使用闭环来减少累积错误。它检测单词袋(BOW)[19],它描述了在某一帧中的对象的类型作为特征向量,以及如果轨迹的相机转到同一个地方,将显示相同的矢量值。在使用激光雷达进行定位时出现的另一个问题是实时性能。例如,一个64光束的激光雷达每秒将产生220万个点,这使得很难实时计算结果。

        本文提出了一种基于GPS的无漂移地图构建方法。在映射部分,我们使用LOAM作为传感器轨迹的估计,并建立了一个姿态映射来减少累积误差。在提出的地图部分,我们添加了一个GPS约束和环闭包约束,得到了一个无漂移的地图,该基于GPS的建图方法算法可以实现实时性能。

III.实验设备

 A. Sensor Settings  

PC:Intel Core i7 7700 CPU (3.6 GHz) and a 16  GB of RAM
Ubuntu 16.04 with a Robot operating system (ROS)

 3D Lidar RS-LiDAR-16  10 Hz

Encoder:  在我们的测试车辆上,我们使用霍尔效应传感器作为我们的车轮速度传感器,用来测量磁场的大小。我们建立了一个36T的齿轮,可以旋转车轮。当车辆向前移动时,霍尔效应传感器将根据旋转齿轮产生的磁场变化产生一个电信号。我们通过计算来自霍尔效应传感器的脉冲量来计算行程距离。我们还根据左右车轮产生的不同电信号得到了偏航角。

         本文将左右车轮之间的距离定义为L. d为车轮的行驶距离。我们可以得到车轮中心的行驶距离。简言之就是双差速的轮式里程计运动模型:

 B. G-LOAM

         在本节中,我们将介绍带有GPS约束的基于图的SLAM方法,这称为G-LOAM。首先,在使用激光雷达进行建图时,必须使用不同的点云配准方法作为前端。通过这一步,我们就可以得到激光雷达的里程计。研究人员通常使用迭代最近点(ICP)[20]或NDT作为前端配准方法。由于NDT不需要准确的初始位置,且具有稳定的时间消耗,因此被广泛使用。

        提出了一种基于载荷的配准部分的建图方法。LOAM更准确,也更不耗时。因为它只匹配这些特征,而不是整个激光雷达扫描。此外,通常采用环闭包法对地图进行优化,并采用ICP作为环闭包约束。我们在环路闭合约束中加入了一个GPS约束,以消除LOAM的累积误差。图优化的一般框架(G2o)[21]是解决我们的问题的基本框架。

        基于图的方法[22]是解决SLAM问题最成功的方法之一。在图中,我们使用该边来表示不同的约束条件,如GPS对激光雷达姿态的测量。该图的目标是最小化所有测量值的误差。

        设pk为激光雷达节点,其中Zk Hk分别表示pk约束的平均值和pk当前约束的信息矩阵。我们也可以定义pk和观测值之间的误差函数ek(pk,Zk),用边来表示它。我们可以使用一个等式2来描述这个优化问题:

 

         请遵循“等式”2,我们选择了莱文伯格-马夸特(LM)算法来解决这个问题。LM算法比高斯-牛顿算法更有效,因为LM算法建立了一个信任区域,其中非线性逼近是有效的。

        图1显示了我们的图的结构,我们将Gk设置为由GPS数据生成的固定节点,Pk表示SE (3)中的激光雷达位姿。该图有3个约束条件:激光雷达里程计产生的里程计约束、激光雷达与GPS天线之间的静态变换给出的GPS约束、ICP算法给出的环路闭包约束。图2显示了使用该算法得到的地图。

 

IV. POINTLOCALZATION

         点定位算法需要两个传感器输入。第一个是激光雷达,它可以给我们当前周围的环境。有了这些信息,我们就可以减少累积误差。另一种传感器可以提供任何类型的里程计。我们使用霍尔效应传感器来提供轮式;然而,它可以使用任何其他有更新超过10Hz的里程计。传感器应保持稳定,不受环境变化的影响。

B. PointLocalization Algorithm

         在引入PointLocalization之前,我们应该完成由G-LOAM生成的点云的稀疏化。我们使用一个体素栅格滤波器来减少我们的地图的大小和重叠区域。经过稀疏化步骤,我们可以得到一个访问速度更快、更小存储大小的地图;对于500米×0500米的地图,存储大小只有8 MB。在我们接收到来自激光雷达和里程计的信息后,我们计算最后一个激光雷达定位结果Tk L−1和当前接收到的里程计TkO之间的转换。我们把它命名为Tk I。

        如果我们接收到一个激光雷达输入,Tk I将是我们当前姿态Tk L的一个预测(使用外部里程计做预测)。我们也使用另一种方法来预测我们的姿态,这看作是我们的激光雷达动量(Tk L−1)T×Tk L−2。在这一步中,我们可以得到一个关于Tk L的粗略预测,即Tk I和(Tk L−1)T×Tk L−2。然后,我们使用(Tk L)的粗略预测来得到我们之前获得的地图上的感兴趣区域(ROI)。我们在地图上的最小ROI半径设置为1米,这一步可以帮助我们提高激光雷达扫描点与地图匹配的速度。

        在最后一步中,我们得到目标点云(ROI映射)和源点云(LiDAR扫描)。我们可以用ICP来计算激光雷达的姿态,并表示这个问题如下:

         ei是激光雷达点(pi)和地图中的ROI点(p‘i)之间的误差,R是当前的旋转,t是当前的变换。在这一步中,我们设置了一个阈值δ,以防止由动态物体造成的影响,如卡车或行人。等式4是ICP算法中得到激光雷达当前姿态的目标函数,其中需要调整R和t,确保当前姿态估计具有最小的J。

最后一步是将里程计结果和激光雷达结果融合,得到高频的定位结果。通常,EKF方法只能从考虑当前状态,这是延迟测量的问题。在这一部分中,我们使用EKF(SSKF)[23]的稳态近似。假设协方差为常数。在该方法中,我们可以得到EKF精度和SSKF运行时之间的延迟测量的权衡;该方法将解决ICP算法导致的计算时间长的问题。

v.实验结果

         我们在KITTI数据集上测试了G-LOAM和点定位。本实验是在前面提到的IPC上进行的。我们选择第一个数据集来测试我们的算法。在建图部分,我们将地面真实值转换为映射的GPS约束,得到一个漂移较小的地图。当运行点定位算法时,我们使用16束64线激光雷达来实现与我们的测试车辆相同的标准。我们还使用激光雷达里程计来代替霍尔效应传感器,因为KITTI没有车里程计法用于测试。

        从这两个图中,我们可以得出该算法在20-50 km/h速度范围内工作良好。图3(c)和图3(d)显示了随路径长度和速度变化的平移误差。我们可以发现,这种定位方法没有由里程计引起的累积误差,在约20km/h的速度下,它表现出良好的性能。这适用于在市区工作的车辆。表1显示了在KITTI 00上的总误差结果。这表明,在城市环境中,点定位可以达到分米定位精度。

A. Test Result on Real Data

 

         我们在我们的操作环境中使用一个设计速度为25 km/h的电动UGV来测试这个算法。该试验是在一个有许多卡车和人的工业区进行的。在这个工业区中,为了验证环境的稳健性,我们使用了六个月前,即2019年1月拍摄的一张地图。为了测试尽可能多的情况,我们记录了一周内的数据。计算结果如图5所示。然后,我们特别选择了上午和下午的数据记录,因为它们是庄园最繁忙的时期。图5 (a)-(e)为RTK-GPS路线和点定位路线。从图5 (b)、(d)和(e)中可以看出,RTK-GPS存在一些故障情况,由路线周围的蓝点表示。这些在测试中失败的原因是

通信:我们选择使用一个连续运行的参考站(CORS)系统,它使用一个固定的站来计算错误消息。由于我们可能会丢失通信不稳定导致的错误消息,我们得到的位置也是不稳定的。

•信号阻塞和多路径传输。我们的车辆在这里工作的环境中有许多高层建筑和卡车。建筑物会造成信号障碍物,位于天线附近的金属物体会引起信号反射。这些元素可能会导致GPS在我们的测试中失败。

在这些实验中,我们还使用RTK-GPS作为地面真值来验证我们的算法的准确性。(f)是我们与状态4下的RTK-GPS进行比较的误差,RMS(66.7%)小于2 cm。误差的计算形式为:e(t)=pex(t)2+(t)2。ex (t)和ey (t)分别是在x轴和y轴上的RTK-GPS和点定位之间的误差。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值