0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

搭建一个开源ADAS项目的步骤流程

智能汽车电子与软件 来源:车端 2023-04-14 17:18 次阅读

一、项目范围

该项目是一个高级驾驶辅助系统的原型,专注于感知算法(目标检测、车道线分割和交通标志分类)。它提供了3个主要功能:

前方碰撞警告

车道偏离警告

交通标志检测及超速预警

它还提供了「有限的」虚拟硬件访问权限,作为迈向商业产品的一步:

通过 LAN 中的 GPS 源的 GPS 读取器

一个 CAN 读取器,用于从虚拟 can 总线读取车速和转向信号

但是,可以使用 GPS 模块或 CAN 转 USB 电缆收集 GPS 和 CAN 信号。我将提供一些关于如何设置这些设备的说明。

二。硬件设置

30b0433c-daa3-11ed-bfe3-dac502259ad0.png

处理该项目所有输入的中心组件是中央处理器。这台计算机接收两个输入:(i) 来自相机的图像,以及 (ii) 汽车底盘数据,例如汽车速度和转向信号。中央处理负责处理这些输入以在需要时发出警告。在这个项目的范围内,由于实验条件有限,我们实施了一个模拟模块来提供相机和传感器读取器输入的替代方案」。在商业产品中,传感器读取器模块可以通过 GPS 模块和 CAN 总线读取器(例如 CAN 转 USB 电缆)来实现;可以使用 USB 摄像头提供摄像头输入。

「硬件清单:」

Jetson Nano 开发者套件

Sandisk Ultra 64GB class-10 SD

Wareshare 5寸液晶触摸屏

Wareshare 8Ω 5W 喇叭

Jetson Nano 2寸5V散热风扇

透明外壳。

1.如何获取汽车传感器(速度,转向灯)

使用 GPS 模块

「出于开发和教育目的:」

从您的手机共享 GPS:

从 Google Play 商店下载「共享 GPS应用程序。」

设置您的手机局域网地址,src/sensors/car_gps_reader.cpp并使用此应用程序与您的 Jetson Nano 共享 GPS 信息。这样,我们就可以获取GPS信号,估计车速。

使用 USB GPS 接收器

「对于商业产品:」

查看此模块精度:< 3m。

如何设置CAN总线以读取车速和转向信号

「基本信息」

在这个项目中,我们没有在真车上设置物理 CAN 总线(只是一个使用 socket CAN 的仿真系统)。但是,它可以通过使用 CAN 转 USB 电缆来实现。

CAN总线的一些信息:

一般信息

如何侵入您的车辆?:hacking-can-bus.pdf

开源 CAN 电缆:CANtact。这将支持您将 CAN 总线连接到 linux 套接字,「我的 ADAS 源代码已经支持该套接字」

硬件设计

固件:

在韩国

您还需要 OBD-II 到 DB9 电缆来连接汽车 OBD-II

一旦 CANtact 设备处理了来自车辆的 CAN 消息,它们就会通过 USB B 型端口输出。因此,这需要 USB-B 到 USB-A 电缆:https://www.amazon.com/AmazonBasics-USB-2-0-Cable-Male/dp/B00NH11KIK

「我们在哪里可以找到要连接的 CAN 总线?」

在这个项目中,我们只使用虚拟 CAN 总线,因此项目源代码仍然不支持与汽车 CAN 总线的真实连接。不幸的是,虽然 CAN 总线是汽车行业的标准,但如果您想找到您的 can 线在哪里,您通常需要查看汽车电气图才能找到内部 CAN 总线。自 1996 年以来,有一个名为 OBD2 的汽车标准,可以提供一种方便的方式连接到 CAN 总线。

「OBD2接口在哪里?」

OBD-II 端口通常位于仪表板下方,方向盘柱下方(下图中的 1 - 3)。如果端口不在转向柱下方,请在数字 4 - 9 指示的区域中寻找端口。

30c60780-daa3-11ed-bfe3-dac502259ad0.png

「我怎样才能反转CAN工程并读取速度?」

您可以使用 Wireshark 或 candump 查找车速和转向灯在哪里。CAN总线是没有加密的,大家可以根据下面的说明尝试查找。

2. 如何标定相机

将 USB 摄像头连接到 Jetson Nano 板后,我们需要运行 OpenADAS 软件来校准摄像头。校准实际上是基于透视变换的距离估计。这是为距离计算校准相机的便捷方式。

变换参数包括从真实世界距离到鸟瞰图像空间的米到像素映射,以及鸟瞰图像到相机图像之间的透视变换矩阵。为了计算这些参数,我们使用以下解决方案:在汽车前面放一块红地毯,测量距离 W1、W2、L1、L2。地毯应该足够大,并且必须对称地放置在汽车的长轴上。

30ccd4e8-daa3-11ed-bfe3-dac502259ad0.png

单击设置按钮以打开相机校准。

在 UI 中输入 L1、L2、W1、W2。

30ddf9ee-daa3-11ed-bfe3-dac502259ad0.png

之后,通过单击「重新拍摄照片」选择 4 个点,选择一个点并移动滑块。这些点必须以正确的顺序拾取。相机标定后,标定文件将被保存data/camera_calib.txt并在每次启动程序时加载回来。

三、感知模型和算法

1. 物体检测与交通标志分类模型

该物体检测模块负责检测前方障碍物物体,如其他车辆或行人,以及交通标志。这些结果可用于前方碰撞预警和超速预警。为了提供这些功能,该模块包含两个主要组件:基于 CenterNet 的对象检测神经网络和基于 ResNet-18 的交通标志分类网络。因此,我们将在下图中看到 2 个深度学习模型。

30e79670-daa3-11ed-bfe3-dac502259ad0.png

1.1.使用 CenterNet 进行目标检测

CenterNet 是一种简单但高效的对象检测模型。与其他流行的目标检测模型相比,CenterNet 可以非常有效地适应速度-精度权衡。与其他流行的基于锚框的对象检测网络不同,CenterNet 依靠关键点检测器来检测对象的中心,然后回归其他属性。

30ecf43a-daa3-11ed-bfe3-dac502259ad0.png

CenterNet管道 「论文:」作为点的对象 - Xingyi Zhou、Dequan Wang、Philipp Krähenbühlhttps://arxiv.org/abs/1904.07850。

「训练」

我使用 CenterNet 作者的官方存储库来训练对象检测器(进行了一些修改)。请阅读此处的安装步骤以安装培训所需的环境。

「笔记:」

我建议使用 Anaconda 或 Miniconda 为每个任务创建一个虚拟环境。不要混合你的环境,因为我们必须使用不同的 Python 和包版本。

「必须使用」PyTorch v0.4.1 并将其设置为此处的说明:https://github.com/xingyizhou/CenterNet/blob/master/readme/INSTALL.md。不保证其他版本有效。

我修改了官方存储库以使用 Berkeley DeepDrive (BDD) 数据集](https://bdd-data.berkeley.edu/)。您可以在此处克隆源代码以开始训练。在我的存储库中,我用10个类训练了 CenterNet:person、、、、、、、、、和。ridercarbustruckbikemotortraffic lighttraffic signtrain

「使用 TensorRT 进行模型优化」

使用 PyTorch 框架训练 CenterNet 后,我们获得 PyTorch 模型格式(.pth)的模型文件。为了优化 NVIDIA Jetson Nano 上的推理速度,我们需要将这些模型转换为 TensorRT 引擎文件。转换是通过称为 ONNX(开放式神经网络交换)的中间格式完成的。首先使用 PyTorch ONNX 模块将 PyTorch 模型转换为 ONNX 格式(步骤 1)。

之后,我们将 ONNX 模型转换为每个推理平台的 TensorRT 引擎(步骤 2)。因为从ONNX到TensorRT引擎的转换时间比较长,所以在我的实现中,我将TensorRT引擎转换后序列化到硬盘,每次程序启动时加载。在此步骤中,我们必须注意 TensorRT 引擎在不同计算机硬件上的构建方式不同。所以,

30f9eb5e-daa3-11ed-bfe3-dac502259ad0.png

使用此存储库将预训练模型转换为 ONNX 格式

「笔记:」

创建另一个虚拟环境,这与培训不同。这个新的 Python 环境应该使用 Pytorch v1.0 或 v1.1。我为上面的这个转换任务准备了一个存储库。您可以使用此处的说明来设置您自己的环境。

您可以从该文件夹convert_to_onnx_mobilenet.py中阅读(对于 MobileNetv2 主干)和convert_to_onnx_rescdn18.py(对于 ResNet-18 主干)中的一些转换示例源代码。

拥有 ONNX 模型后,转到 OpenADAS 以更新配置文件中新对象检测模型的路径:src/configs/config_object_detection.h.您还可以使用此存储库进行转换。

1.2.交通标志分类

由于「BDD 数据集」的限制——它只包含 1 类交通标志(未指定标志类型),我不得不训练另一个神经网络来识别标志类型。由于速度和准确性高,因此也选择了「ResNet-18来完成这项任务。」我使用 Tensorflow 和 Keras 框架训练了模型。

「数据集」

在这个项目中,我只设计了对最大速度标志进行分类的系统,并将每个速度级别视为一个单独的对象类。为了收集足够的训练数据,我使用了 2 个数据集:Mapillary Traffic Sign Dataset (MTSD) 和 German Traffic Sign Recognition (GRSRB) 数据集。由于 MTSD 是一个交通标志检测数据集,我使用标志边界框来裁剪它们以进行分类任务。裁剪后,我合并了 2 个数据集,得到 18,581 个最高限速交通标志图像分为 13 个类别,以及 879 个末端限速标志(将所有末端限速标志仅视为 1 类)。

此外,我使用来自其他交通标志和物体的 20,000 张裁剪图像作为“未知”类别。该数据集中共有 15 个类别:最大速度标志(5km/h、10km/h、20km/h、30km/h、40km/h、50km/h、60km/h、70km/h、80km/h , 90 公里/小时, 100 公里/小时, 110km/h、120km/h)、限速终点(EOSL)等标志(OTHER)。之后,这个数据集被分成 3 个子集:训练集(80%)、验证集(10%)和测试集(10%)。每个交通标志类别的分布是随机的。

「训练步骤」

使用此存储库中的源代码来训练交通标志分类器

「第一步:初始化环境」

创建anaconda环境:

conda create --name python=3.6

激活创建的环境并安装所有要求:

pip install requirements.txt

「第 2 步:训练模型」

准备如下结构的数据集:

3106392c-daa3-11ed-bfe3-dac502259ad0.png

使用以下命令训练模型:

pythontrain.py

「使用 TensorRT 进行模型优化」

转换为 UFF

convert_h5_to_pb.py修改和中的模型路径convert_pb_to_uff.py。

将.h5模型转换为.pb, 最后.uff:

pipinstallrequirements-h5-to-uff.txt
pythonconvert_h5_to_pb.py
pythonconvert_pb_to_uff.py

拥有 ONNX 模型后,转到 OpenADAS 以更新配置文件中新交通标志分类模型的路径:src/configs/config_sign_classification.h.

2.车道线分割模型

车道线检测模块负责检测车道线和车道偏离情况。然后将该结果用于车道偏离警告。我使用深度神经网络和霍夫变换线检测器进行车道线检测。下面介绍车道线检测的流程。

31100150-daa3-11ed-bfe3-dac502259ad0.png

车道线检测流水线

用于车道线分割的 U-Net 模型

U-Net 是一种在生物医学图像分割中表现良好的全卷积网络,它可以用较少的训练图像数据展示高精度的分割结果。我将 U-Net 应用于车道线分割问题,并结合霍夫变换以线方程的形式找到车道线。

3121f6ee-daa3-11ed-bfe3-dac502259ad0.png

U网模型

为了在嵌入式硬件上运行轻量级分割模型,我对原始 U-Net 模型进行了两次修改:

(1) 将decoder filters的数量调整为128, 64, 32, 16, 8个filters,从decoder的顶部到网络的输出;

(2) 用 ResNet-18 主干替换原来的主干。

这些修改减少了 U-Net 中的参数数量,并为我们提供了一个可以超过 200 帧每秒 (FPS) 运行的轻量级模型(模型 U-Net ResNet-18 输入大小 384x382,RTX 2070 GPU 上的 TensorRT float 16 ).

数据集

数据集是从Mapillary Vista 数据集准备的,并进行了一些修改。原始数据集包含训练集中约 18000 张图像和验证集中约 2000 张图像。我合并这些集合,删除一些不包含车道线或有太多噪音的图像。最终数据集有 15303 张图像。我将这个集合随机分成三个子集:10712 张图像用于训练(~70%),2296 张图像用于验证(~15%)和 2295 张图像用于测试(~15%)。因为 Mapillary Vista 的标签包含很多对象类,所以我只保留车道线类来生成二值分割掩码作为新标签。

312c315e-daa3-11ed-bfe3-dac502259ad0.png

Mapillary Vistas 数据集预处理——图像 A、B 来自 Mapillary Vitas

训练

使用我的存储库训练 U-Net 进行车道线分割

「第一步:初始化环境」

创建anaconda环境:

conda create --name python=3.6

激活创建的环境并安装所有要求:

pip install requirements.txt

「第 2 步:训练模型」

在目录中创建新的配置文件list_config请不要修改旧的配置文件,以便我们更好地观察,模型和训练历史将自动保存到saved_models文件夹中。

对于培训,只需运行:

python model/train.py

或者

./train.sh

使用 TensorRT 进行模型优化

转换为 UFF

为此任务创建另一个虚拟环境。

convert_h5_to_pb.py修改和中的模型路径convert_pb_to_uff.py。

.h5将模型转换为.pb,并最终使用这些命令(请更新和.uff中模型的正确路径)convert_h5_to_pb.pyconvert_pb_to_uff.py

pipinstallrequirements-h5-to-uff.txt
pythonconvert_h5_to_pb.py
pythonconvert_pb_to_uff.py

拥有 UFF 模型后,转到 OpenADAS 以在车道检测配置文件中更新该新模型的路径:src/configs/config_lane_detection.h.

使用霍夫变换进行车道线检测

霍夫变换是一种在图像处理中非常有效的线检测算法。该算法的总体思想是创建从图像空间(A)到新空间(B)的映射,空间(A)中的每条线对应空间中的一个点(B),空间中的每个点(A)对应空间中的正弦曲线 (B)。将 (A) 中的所有点投影到空间 (B) 中的正弦曲线后,我们找到交点密度最高的地方。然后将这些位置投影到 (A) 成线。通过这种方式,霍夫线变换算法可以在图像空间(A)中找到线。

寻找候选车道线的过程如下图所示。从线分割网络产生的分割掩码,车道线检测模块使用概率霍夫变换来检测原始线段(1)。之后,使用由 Bernard A. Galler 和 Michael J. Fischer 在 1964 年反转的不相交集/联合查找森林算法将这些线划分为组。我们使用线之间的空间距离和角度差将属于一个线段分组同一条线。经过步骤(2),我们可以看到不同的线组被绘制成不同的颜色。步骤 (3) 接收这些线组作为输入,并使用具有 L2 距离的最大似然估计在每个组中拟合一条线。

313b71e6-daa3-11ed-bfe3-dac502259ad0.png

线候选检测

该系统将车道分割模型与上述车道检测算法相结合,可以检测不同环境下的车道线,判断车道偏离情况。它为车道偏离警告模块创建可靠的输入。

4.警告规则

该系统使用基于规则的警告算法。





审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • GPS技术
    +关注

    关注

    0

    文章

    26

    浏览量

    10174
  • CAN
    CAN
    +关注

    关注

    56

    文章

    2471

    浏览量

    459328
  • ADAS系统
    +关注

    关注

    4

    文章

    202

    浏览量

    25567
  • 读取器
    +关注

    关注

    0

    文章

    43

    浏览量

    5176

原文标题:如何搭建一个开源ADAS项目

文章出处:【微信号:智能汽车电子与软件,微信公众号:智能汽车电子与软件】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    开源项目】用ESP32做一个数字沙漏

    沙漏用来形象地显示时间的流逝,现在市面上很难找到大型沙漏了,常见的只有厨房用的小沙漏,大概能显示3到5分钟。 在这个项目里,作者制作了完整流程正好为
    发表于 04-28 11:44

     海外云服务器搭建pi节点详细步骤

     海外云服务器搭建pi节点简单吗?海外云服务器搭建pi节点步骤有哪些?小编为您整理发布海外云服务器搭建pi节点相关内容。
    的头像 发表于 02-21 10:16 254次阅读

    开源FPGA项目有哪些

    请问开源FPGA项目有哪些?
    发表于 12-26 12:09

    ADAS1000输出的数据范围是多少?

    您好, 最近在用贵公司的ADAS1000做心电采集的项目,按照芯片手册的说明,ADAS1000输出的数据是24位的有效数据,请问,可否
    发表于 12-19 06:52

    ADAS1000晶振不起振的原因?

    现有问题想请教下,我使用ADAS1000-3搭配STM32进行单导心电电路的搭建,对ADAS
    发表于 12-19 06:12

    ADAS1000为什么检测不到数据?

    您好,我最近在使用ADAS1000做心电采集的项目,按照数据手册的配置,现在已经可以输出数据了,输出的数据和数据手册描述的致,但是问题是,ADAS1000接上电极后检测不到信号,得到
    发表于 12-19 06:10

    pcb设计一般流程步骤

    pcb设计一般流程步骤
    的头像 发表于 12-13 17:30 2079次阅读

    搭建ftp服务器的步骤

    搭建ftp服务器的步骤  搭建FTP服务器是一项需要一定技术知识的任务,但是只要按照以下步骤进行操作,您就能成功搭建自己的FTP服务器。 1
    的头像 发表于 12-07 16:32 750次阅读

    搭建ssm框架的详细流程

    有效地集成和利用这些开源框架,提高开发效率,并且具有良好的可扩展性和可维护性。 本文将详细介绍搭建SSM框架的流程,包括环境搭建、创建项目
    的头像 发表于 12-03 14:52 1212次阅读

    开源项目专访 | XuperCore——让信任的链接更加便捷

    近年来,开源软件的力量日益凸显,而开源软件、开源项目的快速发展离不开开源基金会的支持,从资金支持、法务协助到运营治理、社区文化等方面,
    的头像 发表于 09-25 14:48 270次阅读
    <b class='flag-5'>开源</b><b class='flag-5'>项目</b>专访 | XuperCore——让信任的链接更加便捷

    开源项目专访 | XuperCore——让信任的链接更加便捷

    近年来,开源软件的力量日益凸显,而开源软件、开源项目的快速发展离不开开源基金会的支持,从资金支持、法务协助到运营治理、社区文化等方面,
    的头像 发表于 09-20 18:40 353次阅读

    分享几个不错的嵌入式开源项目

    于是,我就自己根据需求写了简单的日志库,通过这几年项目的验证,大问题没有,后面维护项目时,发现了这个开源项目,又给我提供了一些思路。这里也分享给大家。
    的头像 发表于 07-04 09:09 3029次阅读
    分享几个不错的嵌入式<b class='flag-5'>开源</b><b class='flag-5'>项目</b>

    Singularity—生信流程搭建的幸运儿

    怎么样高效的搭建分析流程且能保证分析流程稳定运行的使用效果呢?目前主流的是conda和容器技术(container)。
    的头像 发表于 05-22 14:46 1970次阅读
    Singularity—生信<b class='flag-5'>流程</b><b class='flag-5'>搭建</b>的幸运儿

    舞台已搭好,中国开源未来发展峰会开源项目路演来了!

    也代表了开源项目想脱颖而出的难度加大。开源项目的成功往往需要两方面的实力,一是技术,二是社区生态。在项目健康发展的情况下,二者可以相辅相成,
    的头像 发表于 05-11 10:51 363次阅读
    舞台已搭好,中国<b class='flag-5'>开源</b>未来发展峰会<b class='flag-5'>开源</b><b class='flag-5'>项目</b>路演来了!

    C#上位机系列(1)—项目的建立

    本文是讲解C#.net平台的Winform框架下的第一个内容,手把手介绍项目的创建方式以及一些写软件时常用的功能。之前写过一篇关于示波器的比较抽象,本文讲解从零开始的每一个步骤
    发表于 05-10 10:38 0次下载
    C#上位机系列(1)—<b class='flag-5'>项目的</b>建立