视觉感知系统主要以摄像头作为传感器输入,经过一系列的计算和处理,对自车周围的环境信息做精确感知。目的在于为上层智驾融合层提供丰富的信息,包括被检测物体的类别、距离信息、速度信息、朝向信息,同时也能够给出抽象层面的语义信息。所以针对交通场景的分析主要包括以下三个方面:

  1. 大目标检测(车辆、行人和非机动车)
  2. 小目标分类(交通标志和红绿灯)
  3. 可行驶区域的分割(道路和车道线)

这三类任务如果通过一个深度神经网络的前向传播完成,不仅可以提高系统的检测速度,减少计算参数,而且可以通过增加主干网络的层数的方式提高检测和分割精度。如图可以将ADAS的任务分解成目标检测与识别、图像分割、摄像机成像目标跟踪、图像分割。




nuscenes环视相机 环视摄像头图片_机器学习


传感器组件

1、周视线性相机:视角较小,一般为50°到120°之间,主要用来感知距离较远的场景;通常前视感知功能使用的摄像头会使用52°或者100°或者多个不同FOV的相机做区域覆盖。环视感知功能使用的摄像头会使用100°的广角相机。


nuscenes环视相机 环视摄像头图片_nuscenes环视相机_02


2、环视鱼眼相机:环视鱼眼相机视角较大,可以达到180°以上,对近距离的感知较好,通常用于APA,AVP等泊车场景,安装于车辆左右后视镜下方以及前后车牌下方等4个位置做图像的拼接、车位检测、可视化等功能。


nuscenes环视相机 环视摄像头图片_nuscenes环视相机_03


摄像头标定

对相机做内外参标定,直接影响测距的精度;通常得到的内参矩阵用于做图像的畸变校正,外参矩阵常用于统一多个传感器,将各自的坐标原点移动到车辆后轴中心处。无人驾驶中对摄像头进行标定一般不直接使用标定板,而是构建一个场地用于车辆出厂时标定,如下图所示:


nuscenes环视相机 环视摄像头图片_计算机视觉_04


同时考虑到车辆运行一段时间或者在颠簸的过程中摄像头位置的偏移,感知系统中也有在线标定的模型,常利用消失点等检测得到的信息实时更新俯仰角的变化。

数据采集标注

采集大量的实车数据用来标注,包括所有感知系统需要检测的类别全部需要进行标注;
目标级标注如下图:


nuscenes环视相机 环视摄像头图片_计算机视觉_05


像素级标注如下图:


nuscenes环视相机 环视摄像头图片_算法_06


由于感知系统中的检测和分割任务常采用深度学习的方式实现,而深度学习是一项数据驱动的技术,所以需要大量的数据和标注信息进行迭代。为了提高标注的效率,可以采用半自动的标注方式,通过在标注工具中嵌入一个神经网络用于提供一份初始标注,然后人工修正。并且在一段时间加载新增数据和标签

感知功能模块

多目标检测跟踪:对车辆(轿车、卡车、电动车、自行车)、行人等动态物体的识别,输出被检测物的类别和3D信息并对帧间信息做匹配,确保检测框输出的稳定和预测物体的运行轨迹。神经网络直接做3D回归准确度不高,通常会对车辆拆分成车头,车身,车尾,轮胎多个部位的检测拼成3D框。


nuscenes环视相机 环视摄像头图片_nuscenes环视相机_07


检测的难点在于:

  • 遮挡情况情况较多,heading朝向的问题,测距精准度;
  • 行人、车辆类型种类较多,难以覆盖,容易误检(集装箱vs卡车、树干vs行人);
  • 多目标追踪,id切换的问题。

对于多目标检测,最后需要结合激光雷达的结果进行融合,在夜间、雨雪天气,视觉无法处理;同时有激光雷达信息,对于车辆的朝向信息判断更准确,仅凭一个摄像头去做检测、去做heading、去做精准的距离判断,难度太大。

目标检测方案:

多目标的检测尤其是车辆的检测,是需要给出车辆的3D bounding box的(给出一个伪3D也是可以的),所以在神经网络的训练打标签时与普通的2D检测有区别,3D的好处在于能给出车的一个朝向角信息,以及车的高度信息。车辆及行人都要给出对应的id号,要加入多目标跟踪算法,遮挡情况下的id难以维持,这是一个难点。另外神经网络提取特征能力再强大,也不能覆盖掉所有的动态物体检测,可以依据现实场景增加一些几何约束条件(如汽车的长宽比例固定,卡车的长宽比例固定,车辆的距离不可能突变,行人的高度有限等),增加几何约束的好处是提高检测率,降低误检率,如轿车不可能误检为卡车。可以训练一个3D检测模型(或者2.5D模型)再配合后端多目标追踪优化以及基于单目视觉几何的测距方法完成功能模块。

多目标测距:根据多目标检测的输出借助地面等先验知识从2D的平面图像计算车辆等动态障碍物的距离信息、速度信息等或者通过NN网络直接回归出现世界坐标系中的物体位置;


nuscenes环视相机 环视摄像头图片_nuscenes环视相机_08


单目测距的难点在于:如何从缺乏深度信息的单目系统中计算出Z方向上的物体距离。那么我们需要弄清楚以下几个问题:

  1. 有什么样的需求
  2. 有什么样的先验
  3. 有什么样的地图
  4. 需要做到什么样的精度
  5. 能够提供什么样的精力

如果大量依赖模式识别技术来弥补深度的不足。那么模式识别是否足够健壮能满足串行生产产品的严格检测精度要求?

常规测距方案:

其一,就是通过光学几何模型(即小孔成像模型)建立测试对象世界坐标与图像像素坐标间的几何关系,结合摄像头内、外参的标定结果,便可以得到与前方车辆或障碍物间的距离;
其二,就是在通过采集的图像样本,直接回归得到图像像素坐标与车距间的函数关系,这种方法缺少必要的理论支撑,是纯粹的数据拟合方法,因此受限于拟合参数的提取精度,鲁棒性相对较差。

可通行区域:对车辆行驶的可行驶区域进行划分,主要对车辆、普通路边沿、侧石边沿、没有障碍物可见的边界、未知边界进行划分,最后输出自车可以通行的安全区域。


nuscenes环视相机 环视摄像头图片_机器学习_09


分割的难点在于:

  • 复杂环境场景时,边界形状复杂多样,导致泛化难度较大。不同于其它的检测有明确的检测类型(如车辆、行人、交通灯),通行空间需要把本车的行驶安全区域划分出来,需要对凡是影响本车前行的障碍物边界全部划分出来,如平常不常见的水马、锥桶、坑洼路面、非水泥路面、绿化带、花砖型路面边界、十字路口、T字路口等进行划分。
  • 标定参数校正;在车辆加减速、路面颠簸、上下坡道时,会导致相机俯仰角发生变化,原有的相机标定参数不再准确,投影到世界坐标系后会出现较大的测距误差,通行空间边界会出现收缩或开放的问题。
  • 边界点的取点策略和后处理;通行空间考虑更多的是边缘处,所以边缘处的毛刺,抖动需要进行滤波处理,使边缘处更平滑。障碍物侧面边界点易被错误投影到世界坐标系,导致前车隔壁可通行的车道被认定为不可通行区域,如下图:


nuscenes环视相机 环视摄像头图片_大数据_10


常规的分割方案:

相机标定(若能在线标定最好,精度可能会打折扣),若不能实现实时在线标定功能,增加读取车辆的IMU信息,利用车辆IMU信息获得的俯仰角自适应地调整标定参数;选取轻量级合适的语义分割网络,对需要分割的类别打标签,场景覆盖尽可能的广;描点操作(极坐标的取点方式),边缘点平滑后处理操作(滤波算法)。

车道线检测:对各类单侧/双侧车道线、实线、虚线、双线检测,线型的颜色(白色/黄色/蓝色)和特殊的车道线(汇流线、减速线等)检测。


nuscenes环视相机 环视摄像头图片_计算机视觉_11


检测的难点在于:

  • 线型种类多,不规则路面检测车道线难度大;如遇地面积水、无效标识、修补路面、阴影情况下的车道线容易误检、漏检。
  • 上下坡、颠簸路面,车辆启停时,容易拟合出梯形、倒梯形的车道线。
  • 弯曲的车道线、远端的车道线、环岛的车道线,车道线的拟合难度较大,检测结果易闪烁;

车道线检测方案:

其一,传统的图像处理算法需经过摄像头的畸变校正,对每帧图片做透视变换,将相机拍摄的照片转到鸟瞰图视角,再通过特征算子或颜色空间来提取车道线的特征点,使用直方图、滑动窗口来做车道线曲线的拟合,传统算法最大的弊端在于场景的适应性不好。

其二,采用神经网络的方法进行车道线的检测跟通行空间检测类似,选取合适的轻量级网络,打好标签;车道线的难点在于车道线的拟合(三次方程、四次方程),所以在后处理上可以结合车辆信息(速度、加速度、转向)和传感器信息做航位推算,尽可能的使车道线拟合结果更佳。

静态物体检测:用于对交通红绿灯、交通标志等静态物体的检测识别


nuscenes环视相机 环视摄像头图片_机器学习_12


静态物体检测难点在于:

  • 红绿灯、交通标识属于小物体检测,在图像中所占的像素比极少,尤其远距离的路口,识别难度更大。如下图红绿灯在1920*1208的像素层面上占据的像素大小仅为18*45pixel左右,在强光照的情况下,人眼都难以辨别,而停在路口的斑马线前的汽车,需要对红绿灯进行正确的识别才能做下一步的判断。
  • 交通标识种类众多;采集到的数据易出现数量不均匀的情况。
  • 交通灯易受光照的影响,在不同光照条件下颜色难以区分(红灯与黄灯),且到夜晚时,红灯与路灯、商店的灯颜色相近,易造成误检;

静态物检测方案:

通过感知去识别红绿灯,有一种舍身取义的感觉,效果一般,适应性差,条件允许的话(如固定园区限定场景),该装V2X就装V2X,多个备份冗余,V2X > 高精度地图 > 感知识别。若碰上GPS信号弱的时候,感知识别可以出场了,大部分情况,V2X足以Cover掉大部分的场景。感知方案的具体实现参照文章,主要为红绿灯数据集采集,标签处理,检测模型训练,算法部署,追踪后端优化,接口开发;

感知算法共性问题:

(1)真值的来源。定义,校准,分析比对,绝不是看检测结果的map或帧率,需要以激光的数据或者RTK的数据作为真值来验证测距结果在不同工况(白天、雨天、遮挡等情况下)的准确性;

(2)硬件帧率、资源消耗。多个网络共存,多个相机共用都是要消耗cpu、gpu资源的,如何处理好这些网络的分配,多个网络的前向推理可能共用一些卷积层,能否复用;引入线程、进程的思想来处理各个模块,更高效的处理协调各个功能块;在多相机读取这一块,做到多目输入的同时不损失帧率,在相机码流的编解码上做些工作。

(3)多目融合的问题。一般在汽车上会配备4个(前、后、左、右)四个相机,对于同一物体从汽车的后方移动到前方,即后视相机可以看到,再移至侧视相机能看到,最后移至前视相机能看到,在这个过程中,物体的id应保持不变(同一个物体,不因相机观测的变化而改变)、距离信息跳变不宜过大(切换到不同相机,给出的距离偏差不宜太大,)

(4)多场景的定义。针对不同的感知模块,需要对数据集即场景定义做明确的划分,这样在做算法验证的时候针对性更强;如对于动态物体检测,可以划分车辆静止时的检测场景和车辆运动时的场景。对于交通灯的检测,可以进一步细分为左转红绿灯场景、直行红绿灯、掉头红绿灯等特定场景。公用数据集与专有数据集的验证。

(5)回放工具验证,感知输出的离线数据分析。肉眼观察视觉感知的效果是不可靠的,需要将视觉检测的结果,激光的结果,RTK的结果都统一在回放工具上,对视觉检测的结果进行离线分析,包括距离误差的分析、检测效果与距离的分析、曲线拟合的分析等等,完成这些工作需要统一时间戳,同时输出视觉检测结果的类别信息,距离信息和作为真值传感器的输出信息,进行分析对比,以此验证视觉感知结果的好坏。

Apollo的感知方案

目前开源的感知框架Apollo和Autoware,不少研究人员或者中小公司的感知系统开发会借鉴其中的思想,所以在这里介绍一下Apollo感知系统的模块组成。

相机输入-->图像的预处理-->神经网络-->多个分支(红绿灯识别、车道线识别、2D物体识别转3D)-->后处理-->输出结果(输出物体类型、距离、速度代表被检测物的朝向)
即输入摄像头的数据,以每帧信息为基础进行检测(detection)、分类(classification)、分割(segmentation)等计算,最后利用多帧信息进行多目标跟踪,输出相关结果。


nuscenes环视相机 环视摄像头图片_算法_13


上述核心环节仍是神经网络算法,它的精度、速度、硬件资源利用率都是需要衡量考虑的指标,哪一个环节做好都不容易,物体检测最容易误检或漏检、车道线检测拟合4次方程曲线不容易、红绿灯这类小物体检测难度大(现有路口长度动则50米以上),通行空间的边界点要求高

应用场景

园区场景:低速(小于20km/h),主要起作用的感知系统为环视鱼眼相机,针对近距离物体的感知,近距离需要视角较大,所以采用广角更大,畸变较大的鱼眼相机。感知的内容包括动态物体检测、库位检测以及通行空间(可通行区域)。

城市场景:正常车速(30km/h-80km/h),对算法的实时性要求很高,举个例子,汽车以60km/h(=16.6m/s)的速度前行,若检测结果有一眨眼的延迟(假设0.5s的延迟),汽车就已往前开出接近10m远,0.5s内10米范围内的物体没有被感知系统检测出来的话,就直接撞上去了。

高速场景:高速(80km/h-120km/h),同样对对算法的实时性要求很高。


nuscenes环视相机 环视摄像头图片_nuscenes环视相机_14


感知的挑战

1.没有车规级的代码,和与之匹配的硬件
现在的视觉感知系统都是基于深度学习框架做开发,视觉供应商们对汽车功能安全的标准考虑不足,Demo车居多,能上量产车的代码难上加难;支持深度学习框架的硬件平台现在默认的是Nvidia支持的好,无论是图森、Momenta还是主机厂等众多厂商,首选都是NV的硬件平台。虽然地平线的J3或者TI的TDA4宣称的计算性能都很高,但是抛开硬件性能来说,它们配套的软件或者工具链比较单一并缺少可修改性,在真正使用中如果直接使用硬件厂商提供的SDK,会导致PC端的模型很慢部署上去。

2.实际情况复杂,感知难以做到100%;
神经网络或者机器学习,很多方法都是基于概率得到结果。而且像深度学习这样有监督的喂大量数据去覆盖可能遇到的场景,没有一个终点。一旦在某个特定的场景遇到特定的状态很可能判断出错。所以我们很难确保推出的智能驾驶系统100%安全。虽然说特斯拉的跟车、刹车、高速巡线都是做的极好的,较为复杂的cut in/cut out,特斯拉也是不安全的,要切换变道时,对于左、右后方来车的距离判断,加速判断,还是没有老司机稳,偶尔会出现一些很紧急危险的状况发生。感知系统要做到能够每时每刻处理大量的数据,百分之百的检测和召回率,非常高的精度,实在是太难。

3.高效出Demo,后端优化是关键;
让一个视觉感知团队几个月的时间,复现产出一版能上车的demo版感知系统是没问题的,cover掉一些场景也是没问题的。更高的要求在于一些特例或极端情况的处理,一些长得很像人的小树(误识别),夜晚来临时商店的夜灯与红绿灯类似,雨雾天气的识别。深度学习太依赖数据,其训练模型的泛化能力是未来急需攻克的,以增强神经网络的可拓展性。