无人驾驶那么难,个人应该如何研究?

简介:
本文来自AI新媒体量子位(QbitAI)

作为一个在公司义务给应届生和实习生培训的“小师”,结合我自己学习的经历,从操作手册的角度,手把手教你“无人驾驶”从入门转行

前言

先看看无人驾驶基本的硬件构造及其成本。

看完图,就会发现一个十分尴尬的问题——除了超声波雷达以外,剩下的设备都买不起。所以个人做无人驾驶研究,在没有大资金支持的情况下,就不要考虑基于实车做研究了。断了从硬件方面着手做研究的念头,我们直接看看软件方面。

软件方面可以做的工作就很多了,掌握其中某一项或多项技能,对你在该领域的发展都大有裨益。

操作系统安装

必学指数:
易学指数:

既然是做软件,首先得有个操作系统。常见的操作系统Windows/Linux/Mac…(打…的操作系统我也没用过),考虑到社区支持、开发效率,推荐使用 Linux 作为无人驾驶研究的操作系统。

大部分做无人驾驶的团队都用的 Linux,跟着大趋势走,可以省很多事。

Linux 又分为很多版本,最常用且普及率很高的当属 Ubuntu 系列。虽然 Ubuntu 已更新至 17.04,但从稳定性上,推荐安装 14.04 版本。

推荐用一块单独的SSD安装Linux,或者使用虚拟机安装,最不推荐装双系统(不太稳定)
奉上 Linux Ubuntu 14.04 安装包 + 虚拟机安装方法——

百度网盘地址:

https://pan.baidu.com/share/init?surl=jIJNIPg

密码:147y

Linux基本指令

必学指数:
易学指数:

作为Linux的核心——命令行操作不仅对开发大有帮助,而且是装X利器。另一个好处是使用指令 apt-get install,可以快捷地完成很多软件的安装,不用像Windows那样,在网上四处寻觅适配的安装包。

Linux的指令很多,而且比较杂,使用起来需要多学,多用。

有道云笔记-Linux基本指令介绍:

http://note.youdao.com/share/?id=36c07917f8d3e6437c1e764c3516a3f2&type=note#/

开发环境安装

必学指数:
易学指数:

开发环境会涉及很多实际使用的库,不同的程序员处理相同的问题,可能使用不同的库。
下面通过安装我在工作和学习中经常使用到的库,抛砖引玉,将开发者”引进门”。

搭建环境所需安装包地址:

http://pan.baidu.com/s/1sllta5v 密码:eyc8

详细的安装方法见笔记:

http://note.youdao.com/share/?id=19256058d87f47346ed761dec80999a3&type=note#/

开发环境介绍

必学指数:
易学指数:

集成开发环境IDE

前面安装了一款开源的IDE qt,目前 qt 在 Linux 中的地位,就和 Visual Studio 在 Windows 中的地位一样。除非是不使用 IDE 开发的高玩,大部分在 Linux 下做开发的团队还是会选择用 qt 开发的。

qt 的主要作用是做交互式的界面,比如在界面中显示当前传感器采集到的各种信息。界面交互会明显加快开发者调试程序和标定参数的过程。

Tips:

熟悉 qt 可以网上找教程,我更推荐系统地学习,比如买一本 Qt 的书。

买书或者去图书馆借书,注意看写书的日期,越新越好,太老的书,相应的版本也很旧。

OpenCV

OpenCV是一个非常强大的库,其中封装了大量的可应用于无人驾驶研究的函数,包括各种滤波器算法、特征点提取、矩阵运算、投影坐标转换、机器学习算法等。

当然最重要的是,它在计算机视觉领域的影响力,相机标定,目标检测、识别、跟踪的接口使用起来十分方便。使用OpenCV库完全可以做出这张图展现的效果。

Tips:

请至少购买版本为2.4以上的教程学习OpenCV,但目前市面上买得到的OpenCV中文教程都讲的太浅,甚至连经典的Kalman Filter都不介绍。我推荐直接学习英文版的 Learning OpenCV3。
奉上电子版,讲解很详细,每次打印一章阅读,循序渐进。

链接:http://pan.baidu.com/s/1dE5eom9

密码:n2dn

libQGLViewer

libQGLViewer是大名鼎鼎的 OpenGL 适配 qt 的一个库,编程接口及方法与 OpenGL 大同小异,我们经常在各大无人驾驶公司宣传画上看到的环境感知信息的显示,就完全可以用 QGL 做出来。

Tips:

学习 libQGLViewer 不需要购买任何教材,官网及压缩包内的 example 就是最好的老师,按照官网的tutorial,把每个例子实现一遍,就基本入门了。

官网地址:

http://libqglviewer.com/examples/index.html

Boost

Boost库是有着“C++准标准库”之称。这个库里面有大量的”轮子“,对于C++开发者来说,方便直接调用,避免重造”轮子”。

Tips:

Boost是基于标准C++开发,其构造用尽精巧手法,不要贸然费时研读,找一份和 Boost 库相关的(电子或纸质)书,把目录读一遍,大致知道里面有哪些功能即可,需要时就某一个点,花时间做研究。

QCustomplot

除了上面提到的libQGLViewer外,还可以通过平面图的形式显示车载传感器的信息。鉴于 qt 内部只提供了基本的直线、圆等绘图工具,使用起来并不是很方便,因此QCustomplot诞生了。

简单地调用API,然后把想要显示的数据作为参数输入进去,就可以绘制出下面这些很棒的图形。而且可以很方便地拖动和缩放。

下面是我在实际开发过程中,使用 QCustomplot 显示的部分传感器信息。

Tips:

官网提供了该库的源码下载,你只需要在你的工程中导入 .cpp 和 .h 文件即可。跟着官网提供的 tutorials 学习,可以快速上手。对照着example中的例程写代码,可以快速把自己的数据变成可视化图像。

官网tutorials地址:

http://www.qcustomplot.com/index.php/tutorials/settingup

LCM(Lightweight Communications and Marshalling)

团队开发软件必然存在程序(多进程)的通信问题,多进程通信的方式很多,也各有优缺点,使用起来就见仁见智了。2014年12月MIT公布了他们在美国DARPA机器人挑战赛中使用到的信号传输机制LCM,出处:http://carnegierobotics.com/news/2014/12/5/mit-releases-lcm-driver-for-multisense-sl。

LCM含多种语言如java,c++等专门针对实时系统在高带宽和低的延迟的情况下进行消息发送和数据封送处理。它提供了一个发布/订阅消息模型、自动封装/解封代码生成工具含多种编程语言版本。这个模式和 ROS 现在节点间的通信方式很类似。

Tips:

LCM两个进程间通信的demo官网上有源代码,按照官网上的tutorial就能快速建立属于你自己的LCM通信机制。

Git & Github

Git是团队开发不可缺少的版本控制工具,大家在写论文时肯定每天一个版本,如果没有特别标注每个版本改了些什么时间久了就会忘记。写代码更是如此。

使用Git可以极大地提高多人开发的效率,而且版本管理规范,代码追溯起来十分方便。
Github在软件开发领域如雷贯耳,需要某些代码时,直接上去搜索即可。

Tips:

目前世面上介绍Git的书,让人看起来十分吃力,而且对细枝末节的东西介绍地太过深入,让人无法快速上手。

于是我要强烈推荐Git入门的教程:廖雪峰的Git教程,浅显易懂,而且还配合图文+视频,简直良心。

以上基本介绍完了开发所需要的东西,掌握好这些东西,就可以来我司面试了。

现在有了自动驾驶开发的工具,那么再掌握一些自动驾驶开发的流程就如虎添翼了。

下面开始介绍做自动驾驶开发过程需要了解的基础知识。

自动驾驶开发流程

必学指数:
易学指数:

先分享某创业公司公开的一份PPT地址:

http://pan.baidu.com/s/1qYoJcUo 密码:o3wx

实现一个智能驾驶系统,会有几个层级:感知层 → 融合层 → 规划层 → 控制层;更具体一点为:传感器层 → 驱动层 → 信息融合层 → 决策规划层 → 底层控制层。各个层级之间都需要编写代码,去实现信息的转化。

最基本的层级有以下几类:采集及预处理、坐标转换、信息融合

采集

传感器跟我们的PC或者嵌入式模块通信时,会有不同的传输方式。

比如我们采集来自摄像机的图像信息,有的是通过千兆网卡实现的通信,也有的是直接通过视频线进行通信的。再比如某些毫米波雷达是通过CAN总线给下游发送信息的,因此我们必须编写解析CAN信息的代码。

不同的传输介质,需要使用不同的协议去解析这些信息,这就是上文提到的“驱动层”。通俗地讲就是把传感器采集到的信息全部拿到,并且编码成团队可以使用的数据。

预处理

传感器的信息拿到后会发现不是所有信息都是有用的。传感器层将数据以一帧一帧、固定频率发送给下游,但下游是无法拿每一帧的数据去进行决策或者融合的。为什么?

因为传感器的状态不是100%有效的,如果仅根据某一帧的信号去判定前方是否有障碍物(有可能是传感器误检了),对下游决策来说是极不负责任的。因此上游需要对信息做预处理,以保证车辆前方的障碍物在时间维度上是一直存在的,而不是一闪而过。

这里就会使用到智能驾驶领域经常使用到的一个算法——卡尔曼滤波。

坐标转换

坐标转换在智能驾驶领域十分重要。

传感器是安装在不同地方的,比如毫米波(上图中紫色区域)是布置在车辆前方的;当车辆前方有一个障碍物,距离这个超声波雷达有50米,那么我们就认为这个障碍物距离汽车有50米吗?

不是的!因为决策控制层做车辆运动规划时,是在车体坐标系下完成的(车体坐标系一般以后轴中心为O点),因此毫米波雷达检测到的50米,转换到自车坐标系下,还需要加上传感器到后轴的距离。

最终所有传感器的信息,都是需要转移到自车坐标系下的,这样所有传感器信息才能统一,供规划决策使用。

同理,摄像机一般安装在挡风玻璃下面,拿到的数据也是基于摄像机坐标系的,给下游的数据,同样需要转换到自车坐标系下。

自车坐标系:拿出你的右手,以大拇指 → 食指 → 中指 的顺序开始念 X、Y、Z,然后把手握成如下形状:

把三个轴的交点(食指根部)放在汽车后轴中心,Z轴指向车顶,X轴指向车辆前进方向。
各个团队可能定义的坐标系方向不一致,只要开发团队内部统一即可。

信息融合

信息融合是指把相同属性的信息进行多合一操作。

比如摄像机检测到了车辆正前方有一个障碍物,毫米波也检测到车辆前方有一个障碍物,激光雷达也检测到前方有一个障碍物,而实际上前方只有一个障碍物,所以我们要做的是把多传感器下这辆车的信息进行一次融合,以此告诉下游,前面有一辆车,而不是三辆车。

当然,信息融合中还涉及时延的补偿,这些细节内容等达到50赞,再细聊。

决策规划

这一层次主要设计的是拿到融合数据后,如何正确做规划。规划包含纵向控制和横向控制。

纵向控制即速度控制,表现为 什么时候加速,什么时候制动;横向控制即行为控制,表现为 什么时候换道,什么时候超车等。个人对这一块不是很了解,不敢妄作评论。


点击左下角“阅读原文”,可查看带各种资源链接的文章原文:)

还可以直接参与讨论~

量子位特约稿件,转载请联系原作者。

本文作者:陈光
原文发布时间:2017-09-11 
相关文章
|
4月前
|
机器学习/深度学习 传感器 自动驾驶
自动驾驶技术中的模仿学习
自动驾驶中的模仿学习是一种关键技术,用于使自动驾驶系统能够学习和模仿人类驾驶行为。通过模仿驾驶员的操作,自动驾驶车辆可以在复杂的道路环境中实现类似人类的驾驶决策和操作,从而提升安全性、舒适性和可靠性。
83 3
|
1月前
|
机器学习/深度学习 传感器 边缘计算
深度强化学习在自动驾驶汽车中的应用与挑战###
本文探讨了深度强化学习(Deep Reinforcement Learning, DRL)技术在自动驾驶汽车领域的应用现状、关键技术路径及面临的主要挑战。通过分析当前自动驾驶系统的局限性,阐述了引入DRL的必要性与优势,特别是在环境感知、决策制定和控制优化等方面的潜力。文章还概述了几种主流的DRL算法在自动驾驶模拟环境中的成功案例,并讨论了实现大规模部署前需解决的关键问题,如数据效率、安全性验证及伦理考量。最后,展望了DRL与其他先进技术融合的未来趋势,为推动自动驾驶技术的成熟与发展提供了新的视角。 ###
|
6月前
|
机器学习/深度学习 传感器 自动驾驶
探讨深度学习在自动驾驶中的应用,以及它如何推动自动驾驶技术的发展
【6月更文挑战第13天】本文探讨了深度学习在自动驾驶汽车中的核心应用,涉及环境感知、决策规划和控制执行。深度学习通过模拟神经元工作方式处理传感器数据,如使用CNN和RNN识别图像和雷达信息。此外,它助力智能决策规划和精确控制执行。然而,数据需求、可解释性和实时性是当前挑战,可通过数据增强、规则方法、模型压缩等手段解决。随着技术发展,深度学习将进一步提升自动驾驶性能,并应对安全和隐私挑战。
236 5
|
1月前
|
机器学习/深度学习 自动驾驶 算法
深度学习在自动驾驶汽车中的应用
深度学习在自动驾驶汽车中的应用
|
3月前
|
机器学习/深度学习 自动驾驶 PyTorch
“深度学习遇上自动驾驶:图像识别如何成为智能驾驶的‘超强大脑’?一场技术革命,带你领略未来出行的奇迹!”
随着科技的进步,自动驾驶成为汽车行业热点。图像识别技术,尤其是深度学习中的卷积神经网络(CNN),在自动驾驶系统中扮演了关键角色,负责从摄像头捕捉的图像中提取车辆、行人等信息。其应用涵盖目标检测、语义分割及行为预测等方面,为系统决策提供依据。尽管已取得显著进展,但面对复杂环境和极端天气等挑战,仍需不断研究优化。
60 0
|
传感器 人工智能 自动驾驶
无人驾驶技术:当汽车遇上人工智能
随着人工智能的迅猛发展,无人驾驶汽车成为了当今科技领域的一个热门话题。无人驾驶技术将汽车与人工智能相结合,使得汽车能够自主感知、决策和操作,实现自动驾驶。这项技术不仅在改变交通方式,还将对交通安全、环境保护以及城市规划等方面产生深远的影响。
189 0
|
传感器 机器学习/深度学习 人工智能
受蝗虫启发!自动驾驶避险出现新思路
受蝗虫启发!自动驾驶避险出现新思路
116 0
|
机器学习/深度学习 人工智能 自动驾驶
自动驾驶为什么需要“新物种”?
自动驾驶为什么需要“新物种”?
149 0
|
机器学习/深度学习 人工智能 监控
大脑如何学会搭乘地铁?这对人工智能研究很重要
在机器学习中,程序员或许可以设计出一种人工智能,它能计算出某个行动所引发的所有可能后果。但是,人类可没有这样的本领;我们不得不有效制定、执行计划。大脑可以创造出不同的“层次”来组织行动,而不是考虑一个个单独步骤,可以说,大脑在进行更高层次的思考。
212 0
大脑如何学会搭乘地铁?这对人工智能研究很重要
|
人工智能 自动驾驶 定位技术
2019年上半年收集到的人工智能自动驾驶方向干货文章
2019年上半年收集到的人工智能自动驾驶方向干货文章
下一篇
DataWorks