热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

StarNet模型

StarNet模型1.背景民以食为天,如何提升超大规模配送网络的整体配送效率,改善数亿消费者在”吃“方面的体验,是一项极具挑战的技术难

StarNet模型

1.背景

民以食为天,如何提升超大规模配送网络的整体配送效率,改善数亿消费者在”吃“方面的体验,是一项极具挑战的技术难题。面向未来,美团正在积极研发无人配送机器人,建立无人配送开放平台,与产学研各方共建无人配送创新生态,希望能在一个场景相对简单、操作高度重复的物流配送中,提高物流配送效率。在此过程中,美团无人配送团队也取得了一些技术层面的突破,比如基于神经网络StarNet的行人轨迹交互预测算法,论文已发表在IROS 2019。IROS 的全称是IEEE/RSJ International Conference on Intelligent Robots and Systems,IEEE智能机器人与系统国际会议,它和ICRA、RSS并称为机器人领域三大国际顶会。

在这项研究中,研究人员提出了一种新的检测器模型,通过在三维 LiDAR数据的背景下重新检查目标检测系统的设计,从而来更好地匹配数据形态和自动驾驶汽车感知的需求。他们首先指出一个事实,即三维区域的提议本质上是不同的,地面上的每个反射点都必须属于一个对象。

他们还表明,点云上的有效采样方案(零学习参数)足以生成区域提议。采样是因为它计算成本低,并且具有通过匹配场景的数据分布来间接利用数据稀疏性的特点。

研究人员随后在没有整体环境或共享信息的情况下处理每个提议的区域。最后,它们完全避免了任何离散化过程,并在其位置上使用本地点云分类和回归对象的边界框位置。通过重新审视当前技术的一些设计假设,他们在没有训练提议,也没有全局环境的情况下得到了一个非卷积的、基于点的对象检测器模型。

在使用KITTI和Waymo开放数据集进行评估时,这一StarNet检测器模型能在较低的推理成本下达到与现有技术一样的精确度,在类似的推理成本下甚至能做到更精确。

该模型不会浪费对空区域的计算。并且,该模型不使用全局语境,完全基于点,并且可以在推理时动态地改变提议的数量与每个提议的点数。由于每个区域都是完全独立的,因此可以在运行时根据环境选择分配区域提议的位置。简单来说,StarNet可用于定位空间位置,不需要重新训练,也不会牺牲预测质量。

原文链接:https://arxiv.org/abs/1908.11069v1

1.1 行人轨迹预测的意义
在无人车行驶过程中,它需要对周围的行人进行轨迹预测,这能帮助无人车更加安全平稳地行驶。我们可以用图1来说明预测周围行人的运动轨迹对于无人车行驶的重要性。

img

图1 主车规划轨迹跳变问题

图1中蓝色方块代表无人车,白色代表行人。上半部分描述的是在不带行人轨迹预测功能情况下无人车的行为。这种情况下,无人车会把行人当做静态物体,但由于每个时刻行人都会运动,导致无人车规划出来的行驶轨迹会随着时间不停地变化,加大了控制的难度,同时还可能产生碰撞的风险,这样违背了安全平稳行驶的目标。下半部分是有了行人轨迹预测功能情况下的无人车行为。这种情况下,无人车会预测周围行人的行驶轨迹,因此在规划自身行驶时会考虑到未来时刻是否会与行人碰撞,最终规划出来的轨迹更具有“预见性”,所以避免了不必要的轨迹变化和碰撞风险。

1.2 行人轨迹预测的难点
总体而言,行人轨迹预测的难点主要有两个:
第一,行人运动灵活,预测难度大。本身精确预测未来的运动轨迹是一个几乎不可能完成的任务,但是通过观察某个障碍物历史时刻的运动轨迹,可以根据一些算法来大致估计出未来的运动轨迹(最简单的是匀速直线运动)。在实际中,相比于自行车、汽车等模型,行人运动更加灵活,很难对行人建立合理的动力学模型(因为行人可以随时转弯、停止、运动等),这加剧了行人预测的难度。
第二,行人之间的交互,复杂又抽象。在实际场景中,某一行人未来的运动不仅受自己意图支配,同样也受周围行人的影响(例如避障)。这种交互非常抽象,在算法中往往很难精确地建模出来。目前,大部分算法都是用相对空间关系来进行建模,例如相对位置、相对朝向、相对速度大小等。

1.3 相关工作介绍
传统算法在做预测工作时会使用一些跟踪的算法,最常见的是各类时序模型,例如卡尔曼滤波(Kalman Filter, KF)、隐马尔可夫(Hidden Markov Model, HMM)、高斯过程(Gaussian Process, GP)等。这类方法都有一个很明显的特点,就是根据历史时序数据,建立时序递推数学公式:
img
因为这类方法具有严格的数学证明和假设,也能处理一些常规的问题,但是对于一些复杂的问题就变得“束手无策”了。这是因为这些算法中都会引入一些先验假设,例如隐变量服从高斯分布,线性的状态转换方程以及观测方程等,而最终这些假设也限制了算法的整体性能。神经网络一般不需要假设固定的数学模型,凭借大规模的数据集促使网络学习更加合理的映射关系。本文我们主要介绍一些基于神经网络的行人预测算法。

基于神经网络的预测算法(主要以长短期记忆神经网络Long Short Term Memory,LSTM为主)在最近5年都比较流行,预测效果确实比传统算法好很多。在CVPR(IEEE Conference on Computer Vision and Pattern Recognition) 2019上,仅行人预测算法的论文就有10篇左右。这里我们简单介绍2篇经典的行人预测算法思路,如果对这方面感兴趣的同学,可以通过文末的参考文献深入了解一下。第一篇是CVPR 2016斯坦福大学的工作Social-LSTM,也是最经典的工作之一。Social-LSTM为每个行人都配备一个LSTM网络预测其运动轨迹,同时提出了一个Social Pooling Layer的模块来计算周围其他行人对其的影响。具体的计算思路是将该行人周围的区域划分成NxN个网格,每个网络都是相同的大小,落入这些网格中的行人将会参与交互的计算。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eMQouvrn-1618891523551)(https://www.aboutyun.com/data/attachment/forum/201912/17/180721l2mmxpkm2m8o0ow0.jpg)]

第二篇是CVPR 2019卡耐基梅隆大学&谷歌&斯坦福大学的工作,他们的工作同样使用LSTM来接收历史信息并预测行人的未来轨迹。不同于其他算法的地方在于,这个模型不仅接收待预测行人的历史位置信息,同时也提取行人外观、人体骨架、周围场景布局以及周围行人位置关系,通过增加输入信息提升预测性能。除了预测具体的轨迹,算法还会做粗粒度预测(决策预测),输出行人未来时刻可能所在的区域。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BdQ96r9k-1618891523553)(https://www.aboutyun.com/data/attachment/forum/201912/17/180831iyggxggyzqrxjbxx.jpg)]

其他的相关工作,还包括基于语义图像/占有网格(Occupancy Grid Map, OGM)的预测算法,基于信息传递(Message Passing, MP)的预测算法,基于图网络(Graph Neural Network, GNN)的预测算法(GCN/GAT等)等等。
2. StarNet介绍
目前,现有的轨迹预测算法主要还是聚焦在对行人之间交互的建模,轨迹预测通常只使用LSTM预测即可。如下图4左,现有关于轨迹预测的相关工作基本都是考虑行人之间两两交互,很少有考虑所有行人之间的全局交互(即使是GCN,也需要设计对应的相似矩阵来构造拉普拉斯矩阵,这也是一个难点)。我们可以举一个例子来说明现有其他算法预测的流程:

假设感知模块检测到当前N个行人的位置,如何计算第一个行人下一时刻的位置?

Step 1计算其他人对于第一个行人的交互影响。将第i个行人在第t时刻的位置记为(一般是坐标x和y)。可以通过以下公式计算第一个行人的交互向量:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vtDzL5mZ-1618891523554)(https://www.aboutyun.com/data/attachment/forum/201912/17/180942vulohtxdjbbttlsd.jpg)]

img
图4 算法思路对比图 左:传统算法 右:StarNet

两两交互的方式存在两个问题:

(1) 障碍物2和3确实会影响障碍物1的运动,但是障碍物2和3之间同样也存在相互影响,因此不能直接将其他障碍物对待预测障碍物的影响单独剥离出来考虑,这与实际情况不相符。
(2) 两两计算消耗的资源大,如果有N个障碍物,那么两两交互就需要N的平方次计算,随着N的变大,计算量呈平方倍增长。我们希望障碍物之间的交互能否只计算1次而非N次,所有障碍物的轨迹预测都共享这个全局交互那就更好了。

基于上述两个问题,我们提出了一种新的模型,该模型旨在高效解决计算全局交互的问题。因为传统算法普遍存在计算两两交互的问题(即使是基于Attention注意力机制的Message Passing也很难考虑到全局的交互),本文想尝试通过一些更加简单直观的方式来考虑所有障碍物之间的全局交互,我们的算法大致思路如下:
每个时刻所有障碍物的位置可以构成一张静态的“地图”,随着时间的变化,这些静态地图就变成了一张带有时序信息的动态图。这张动态图中记录了每个区域内的障碍物运动信息,其中运动信息是由所有障碍物一起影响得到的,而非单独地两两交互形成。对于每个障碍物的预测阶段,只要根据该障碍物的位置,就可以在这张时序地图中查询该区域在历史时刻的障碍物运动信息(例如这个区域在历史时刻中,障碍物1、2、4、5都有其运动的轨迹)。通过“共享全局交互地图+个体查询”的方式,就可以做到计算全局交互以及压缩计算开销。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gouI9Agw-1618891523557)(https://www.aboutyun.com/data/attachment/forum/201912/17/181106lomt1gakomtka11p.jpg)]

我们的算法结构如上图5所示,Host Network是基于LSTM的轨迹预测网络;Hub Network是基于LSTM的全局时序交互计算网络。在论文具体的实现中,首先Hub Network的静态地图模块是通过接受所有障碍物同一时刻的位置信息、全连接网络和最大池化操作得到一个定长的特征向量;然后动态地图模块使用LSTM网络对上述的特征向量进行时序编码,最终得到一个全局交互向量。Host Network首先根据行人(假设要预测第一个行人下时刻的位置)的位置 img 去动态地图中查询自己当前位置区域内的交互 img ,具体我们采用简单的点乘操作(类似于Attention机制)。最终自己的位置 img 和交互 img 一起输入LSTM网络预测下时刻的的位置 img
实验阶段,我们与4种经典的算法作比较,使用的数据集为UCYÐ数据集,这两个数据集包含4个子场景,分别为ZARA-1/ZARA-2、UNIV、ETH、HOTEL。在预测过程中,所有算法根据每个行人过去3.2秒的运动轨迹,预测出它在未来3.2秒的轨迹。每0.4秒采样一个离散点,因此3.2秒的轨迹可以用8个轨迹离散点表示。对比的指标有:

(a)平均距离差ADE(Average Displacement Error):用算法预测出的轨迹到真实轨迹所有8个点之间的平均距离差。

(b)终点距离差FDE(Final Displacement Error):用算法预测出的轨迹与真实轨迹最后一个终点之间的距离差。

(c)前向预测时间以及参数量。
最终的实验结果如下表:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-b3gMOth2-1618891523561)(https://www.aboutyun.com/data/attachment/forum/201912/17/181415mj25bj7h7ijh26y7.jpg)]

从实验结果可以看到,我们的算法在80%的场景下都优于其他算法,且实时性高(表中LSTM的推理时间为0.029秒,最快速是由于该算法不计算交互,因此速度最快参数也最少,但是性能较差)。
总结一下,我们提出算法StarNet的优势主要包括以下两点:


  • 使用全局动态地图的形式来描述行人之间在时间和空间上的相互影响,更加合理,也更加准确。
  • Hub Network全局共享的特征提升了整个算法的计算效率。

3.未来工作

首先,我们会进一步探索新的模型结构。虽然我们的算法在数据集上取得了不错的效果,但这是我们的第一次尝试,模型设计也比较简单,如果提升模型结构,相信可以取得更好的结果。
其次,我们会提升预测的可解释性。同现有算法一样,目前的模型对计算到的交互缺乏可解释性,仍然依赖于数据驱动。在今后的工作中,我们将通过对交互的可解释建模来提升预测的准确性。
最后,在构建时序的动态地图过程中,引入对于每个障碍物的跟踪信息。换句话说,我们知道每块区域在各个时间点障碍物的位置,但目前算法没有对障碍物在时序上做跟踪(例如时刻1有三个障碍物,时刻2三个障碍物运动了得到新的位置,网络输入为三个障碍物的位置信息,但是网络无法理解两个时刻中障碍物的对应关系,这降低了交互的性能),这点在以后的工作中还需要继续改进。


推荐阅读
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • HTML学习02 图像标签的使用和属性
    本文介绍了HTML中图像标签的使用和属性,包括定义图像、定义图像地图、使用源属性和替换文本属性。同时提供了相关实例和注意事项,帮助读者更好地理解和应用图像标签。 ... [详细]
  • Week04面向对象设计与继承学习总结及作业要求
    本文总结了Week04面向对象设计与继承的重要知识点,包括对象、类、封装性、静态属性、静态方法、重载、继承和多态等。同时,还介绍了私有构造函数在类外部无法被调用、static不能访问非静态属性以及该类实例可以共享类里的static属性等内容。此外,还提到了作业要求,包括讲述一个在网上商城购物或在班级博客进行学习的故事,并使用Markdown的加粗标记和语句块标记标注关键名词和动词。最后,还提到了参考资料中关于UML类图如何绘制的范例。 ... [详细]
  • 本文介绍了Python语言程序设计中文件和数据格式化的操作,包括使用np.savetext保存文本文件,对文本文件和二进制文件进行统一的操作步骤,以及使用Numpy模块进行数据可视化编程的指南。同时还提供了一些关于Python的测试题。 ... [详细]
  • 1Lock与ReadWriteLock1.1LockpublicinterfaceLock{voidlock();voidlockInterruptibl ... [详细]
  • 移动传感器扫描覆盖摘要:关于传感器网络中的地址覆盖问题,已经做过很多尝试。他们通常归为两类,全覆盖和栅栏覆盖,统称为静态覆盖 ... [详细]
  • 人脸检测 pyqt+opencv+dlib
    一、实验目标绘制PyQT界面,调用摄像头显示人脸信息。在界面中,用户通过点击不同的按键可以实现多种功能:打开和关闭摄像头, ... [详细]
  • 马尔可夫决策过程Markov Decision Process,MDPKintoki
    Originalurl:http:www.tuicool.comarticlesb6BjAva1.马尔可夫模型的几类子模型我想大家一定听说过马尔科夫链(MarkovChain)& ... [详细]
  • 热点追踪深度探讨实地探访商务合作当一个哲学家遇到大数据分析会发生什么?如果告诉你,这个组合曾帮助美国“猎杀拉登”,你是否会惊讶到瞪眼睛。在 ... [详细]
  • 本文介绍了[从头学数学]中第101节关于比例的相关问题的研究和修炼过程。主要内容包括[机器小伟]和[工程师阿伟]一起研究比例的相关问题,并给出了一个求比例的函数scale的实现。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
author-avatar
艾特PONYO
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有