阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

基于双目视觉的自动驾驶技术

  • 2019-08-29
  • 本文字数:3372 字

    阅读完需:约 11 分钟

基于双目视觉的自动驾驶技术

单目视觉是 Mobileye(ME)的看家法宝,其实当年它也考虑过双目,最终选择放弃。


单目的测距和 3-D 估计靠什么?是检测目标的 Bounding Box(BB),如果无法检测的障碍物,该系统就无法估计其距离和 3-D 姿态/朝向。没有深度学习的时候,ME 主要是基于 BB,摄像头标定得到的姿态和高度以及路面平直的假设估算距离。


有了深度学习,可以根据 3-D 的 ground truth 来训练 NN 模型,得到 3D 大小和姿态估计,距离是基于平行线原理(single view metrology)得到的。不久前百度 Apollo 公布的单目 L3 解决方案讲的比较清楚了,参考论文是“3D Bounding Box Estimation by Deep Learning and Geometry"。


双目当然可以算视差和深度了,即使没有检测出障碍物(因为有附加的深度信息,检测器会比单目好),也会报警。问题是,双目视觉系统估计视差没那么容易,立体匹配是计算机视觉典型的难题,基线宽得到远目标测距准,而基线短得到近目标测距结果好,这里是存在折衷的。


目前市场上 ADAS 存在的双目视觉系统就是 Subaru EyeSight,据说性能还行。



百度推出的阿波龙 L4 摆渡车量产 100 台,就安装了双目系统。还有欧盟自主泊车项目 V-Charge 也采用了前向双目视觉系统,另外自动驾驶研发系统 Berta Benz 也是,而且和雷达系统后融合,其中双目匹配的障碍物检测算法 Stixel 很出名。以前 Bosch 和 Conti 这些 Tier-1 公司也研制过双目视觉解决方案,但没有在市场上产生影响力,据说被砍掉了。


谈到双目系统的难点,除了立体匹配,还有标定。标定后的系统会出现“漂移”的,所以在线标定是必须具有的。单目也是一样,因为轮胎变形和车体颠簸都会影响摄像头外参数变化,必须在线做标定修正一些参数,比如仰角(pitch angle)和偏角(yaw angle)。


双目在线标定就更复杂些,因为双目匹配尽量简化成 1-D 搜索,所以需要通过 stereo rectification 将两个镜头光轴方向平行并和基线垂直。所以针对获得的 gain 相比,增加的复杂度和成本,如果不划算商家就会放弃。


最近重提双目视觉,是因为硅谷芯片公司安霸(Ambarella)在 2014 年收购意大利帕尔马大学的 Vis Lab,研制了双目的 ADAS 和自动驾驶芯片,去年 CES 之后就开始进军车企和 Tier-1。而且,安霸目前正在继续研究提升该系统的性能。


下图就是它在车顶安装 6 对立体视觉系统的示意图,其中它们的基线宽度可以不一样的,相应地有效检测距离也就不同。笔者曾坐过它的自动驾驶车,远处可以看到 200 米,近处 20-30 米。它确实可以做在线标定,随时调整一些双目视觉的参数。



先说立体匹配,即视差/深度估计。如图假设左右摄像头焦距 f,基线(两个光心连线)宽 B,3-D 点 X 的深度 z,而其视差(投影到左右图像的 2-D 点,其坐标差)即



可见视差能够反算深度值。但是这里最难的就是左右镜头看到的图像如何确定是同一个目标,即匹配问题。


匹配方法分两种,全局法和局部法,双目匹配的四个步骤:


匹配成本(matching cost)计算;成本聚集(aggregation);视差(disparity)计算/优化;视差修正(refinement)。


最著名的局部法就是 SGM(semi-global matching),很多产品在用的方法都是基于此的改进,不少视觉芯片都采用这种算法。


SGM 就是把一个全局优化近似成多个局部优化的问题组合,如下公式是 2-D 匹配的优化目标函数,SGM 实现成为多个 1-D 优化路径之和。



下图是沿着水平方向的路径优化函数:



Census Transform 是将 8/24 比特的像素变成一个 2 进制序列,另外一个 2 值特征叫 LBP(local binary pattern)和它相似。立体匹配算法就是基于这个变换将匹配变成一个 Hamming 距离的最小化搜索。Intel 的 RealSense 当年就是收购了一个成立于 1994 年基于该技术的双目视觉创业公司,还收购另外几个小公司把他们合在一起做出来的。


下图是 CS 变换的示意图:



PatchMatch 是一个加速图像模版匹配的算法,被用在光流计算和视差估计上。之前微软研究院曾经做过一个基于单目手机相机 3-D 重建的项目,仿造以前成功的基于 RGB-D 算法 KinectFusion,名字也类似 MonoFusion,其中深度图估计就是采用一个修正的 PatchMatch 方法。


其基本思想就是对视差和平面参数随机初始化,然后通过邻域像素之间信息传播更新估计。PM 算法分五个步骤:


1) 空间传播(Spatial propagation): 每个像素检查左边和上边邻居视差和平面参数,如果匹配成本变小就取代当前估计;


2) 视角传播(View propagation): 其他视角的像素做变换,检查其对应图像的估计,如果变小就取代;


3) 时域传播(Temporal propagation): 前后帧考虑对应像素的估计;


4) 平面细化(Plane refinement): 随机产生样本,如果估计使匹配成本下降,更新。


5) 后处理(Post-processing): 左右一致性和加权中值滤波器去除出格点(outliers)。


下图是 PM 的示意图:



再说在线标定。


这是一个利用路上标志线(斑马线)的标定方法:已知斑马线的平行线模式,检测斑马线并提取角点,计算斑马线模式和路面实现匹配的单映性变换(Homography)参数,得到标定参数。



另外一个方法基于 VO 和 SLAM,比较复杂,不过可以同时做基于地图的定位。采用 SLAM 做在线标定,不适合高频率操作,下图是其算法的流程图: 1-4 步, 通过立体视觉 SLAM 获取全局连续地图;第 5 步给出双目相机变换初始估计,第 6 步把所有立体相机的地图聚合成一个地图;7-8 步获取多个相机之间的姿态。



和单目方法类似,采用车道线平行和路平面这个假设可以快速完成在线标定,即消失点(vanishing point)理论:假设一个平坦的道路模型,清晰的纵向车道线,没有其他目标的边缘和它们平行;要求驾驶车辆速度慢,车道线连续,左右相机的双目配置要左摄像头相对路面的仰角/斜角(yaw/roll angles)比较小;这样跟初始化的消失点(与线下标定相关)比较可以算出双目外参数的漂移量(图 5-269),其算法就是从消失点估计摄像头仰角/斜角。



下面介绍几个典型的双目自动驾驶系统:


Berta Benz 采用的障碍物检测算法 Stixel 基于以下假设:场景中的目标描述为列,重心的原因目标是站立在地面上,每个目标上的上部比下部的深度大。下图(a-d) 介绍了 SGM 视差结果如何生成 Stixel 分割结果:



下图是 Stixels 计算的示意图:(a)基于动态规划的自由驾驶空间计算 (b) 高度分割中的属性值 © 成本图像 (灰度值反过来) (d) 高度分割。



这是他们加上深度学习做视差融合之后再做 Stixel 的框图和新结果:




介绍一个 VisLab 早期双目障碍物的算法,Generic Obstacle and Lane Detection system (GOLD)。基于 IPM(Inverse Perspective Mapping),检测车道线,根据左右图像的差计算路上障碍物:



(a) Left. (b) Right © Remapped left. (d) Remapped right. (e) Thresholded and filtered difference between remapped views. (f) In light gray, the road area visible from both cameras.



GOLD system architecture


这是 VisLab 参加自动驾驶比赛 VIAC (VisLab Intercontinental Autonomous Challenge)的车辆,除了双目摄像头以外,车上还有激光雷达作为道路分类的辅助。



这是其双目障碍物检测流程图:视差估计利用了 SGM 算法和基于 SAD 的相关算法。



后处理中加了两个 DSI(Disparity Space Image)空间的滤波器,见图 5-274,一个是平滑处理,另一个是基于惯导(IMU)的运动轨迹处理。



障碍物检测算法采用了 JPL 的方法,基于空间布置特性以及车辆的物理特性聚类得到障碍物。物理特性包括最大的高度(车辆),最小高度(障碍物)和最大道路可通过范围,这些约束定义了一个空间截断锥(truncated cone), 如图所示,那么在聚类过程中凡是落在截断锥内的点划为障碍物。



为加速视差估计算法,采用了划分 DSI 的方法:



另外一种经典的方法是根据路面方程(立体视觉)得到路面视差,基于此计算出路面的障碍物:




总的看,双目检测障碍物的方法基本基于视差图,基于路面视差的方法较多。也许随着深度学习发展的突飞猛进,加上计算平台的增强,双目自动驾驶系统也会普及起来。

作者介绍

黄浴,奇点汽车美研中心总裁和自动驾驶首席科学家,上海大学兼职教授。曾在百度美研自动驾驶组、英特尔公司总部、三星美研数字媒体研究中心、华为美研媒体网络实验室,和法国汤姆逊多媒体公司普林斯顿研究所等工作。发表国际期刊和会议论文 30 余篇,申请 30 余个专利,其中 13 个获批准。

原文链接

注:本文源自黄浴的知乎:https://zhuanlan.zhihu.com/p/56236308


公众号推荐:

2024 年 1 月,InfoQ 研究中心重磅发布《大语言模型综合能力测评报告 2024》,揭示了 10 个大模型在语义理解、文学创作、知识问答等领域的卓越表现。ChatGPT-4、文心一言等领先模型在编程、逻辑推理等方面展现出惊人的进步,预示着大模型将在 2024 年迎来更广泛的应用和创新。关注公众号「AI 前线」,回复「大模型报告」免费获取电子版研究报告。

AI 前线公众号
2019-08-29 23:106715

评论

发布
暂无评论
发现更多内容

信号量的无序竞争和有序竞争

eng八戒

c Linux Kenel 信号量 C++

AngularJS进阶(十五)Cookie ‘data‘ possibly not set or overflowed because it was too large

No Silver Bullet

Cookie AngularJS 12月月更

8年程序员年初被迫毕业,前后面试30家公司,如今终于拿到Offer!

程序员小毕

程序员 面试 程序人生 后端 架构师

思路一转,春暖花开!动动手指,这段程序性能又双叒提升2s~15s

靠谱的程序员

MySQL MyBatisPlus Mybatis-Plus

刨析一下C++构造析构函数能不能声明为虚函数的背后机理?

eng八戒

继承 纯虚函数 C++

cmake 入门笔记

eng八戒

c makefile 工程管理 cmake C++

3月寒窗!啃透美团保姆级分布式进阶技术手册,4月终入美团定L8

程序知音

Java 分布式 java架构 后端技术

AngularJS进阶(十六)脏值检查及语音识别集成

No Silver Bullet

语音识别 AngularJS 12月月更 脏值检查

使用CSS实现图片的磨砂玻璃效果

山河已无恙

12月月更

下次面试再一上来就问我线程有哪些状态,我上去就是给他一 jio

钟奕礼

Java 程序员 java面试 java编程

MySQL锁,锁的到底是什么?

Java永远的神

MySQL 数据库 程序员 面试 后端

面向场景级的业务资产沉淀和开放

原力在线

架构 DDD 场景 业务资产

Linux 定时器介绍

eng八戒

c 定时器 Linux Kenel C++

AngularJS进阶(十四)AngularJS路由问题分析

No Silver Bullet

路由 AngularJS 12月月更

架构实战-模块1作业

mm

架构实战营 10期

面对当下最热的多模态,为什么这些业界和学界专家说“不必追热点”

小红书技术REDtech

“算法考核没过,老板找我聊了3个小时”:离职程序员重刷数学题

钟奕礼

Java 程序员 java面试 java编程

Apache NiFi + MatrixDB 20行代码实现数据实时入库!

YMatrix 超融合数据库

三一重工 超融合数据库 YMatrix apachenifi nifi

模块一作业

闲人Eric

架构实战营

防治“虚假种草”,小红书技术团队干了这几件大事

小红书技术REDtech

亚马逊 CTO Werner Vogels:2023 年及未来五大技术趋势预测

亚马逊云科技 (Amazon Web Services)

人工智能 大数据 亚马逊云科技

架构实战营模块1第2课 - 如何画出优秀的架构图

净意

程序员:平安Java岗面试耗尽了我毕生所学,想了想,还是去阿里吧

钟奕礼

Java 程序员 java面试 java编程

极客时间运维进阶训练营第五周作业

老曹

Nginx动静分离、缓存配置、性能调优、集群配置

C++后台开发

nginx 中间件 性能调优 后端开发 C++开发

关于Linux中作业调度 crond 和 systemd.timer 使用场景

山河已无恙

Linux Kenel 12月月更

C语言怎么给函数添加形参的默认值

eng八戒

c 函数 参数默认值

看完这篇,还不懂JAVA内存模型(JMM)算我输

JAVA旭阳

Java 并发

迎战大厂!“金九银十”和秋招通过率达95%的Java面试要点集锦

钟奕礼

Java 程序员 java面试 java编程

100页6W字的Java面试题,去过大厂面试的程序员都说被问到过

钟奕礼

Java 程序员 java面试 java编程

关于K8s中资源配置范围管理(LimitRange)的一些笔记

山河已无恙

12月月更

基于双目视觉的自动驾驶技术_AI&大模型_黄浴_InfoQ精选文章