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

    浏览量

    10243
  • CAN
    CAN
    +关注

    关注

    57

    文章

    2715

    浏览量

    463335
  • ADAS系统
    +关注

    关注

    4

    文章

    226

    浏览量

    25675
  • 读取器
    +关注

    关注

    0

    文章

    45

    浏览量

    5233

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

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

收藏 人收藏

    评论

    相关推荐

    凌蒙派OpenHarmony开源项目荣获本期Gitee官方推荐

    近日,我司凌蒙派OpenHarmony开源项目荣获本期Gitee官方推荐。本期Gitee官方推荐不仅是对凌蒙派OpenHarmony开源项目的高度认可,也是对我司在推动
    的头像 发表于 11-20 01:04 99次阅读
    凌蒙派OpenHarmony<b class='flag-5'>开源</b><b class='flag-5'>项目</b>荣获本期Gitee官方推荐

    搭建开源大语言模型服务的方法

    本文我们将总结5种搭建开源大语言模型服务的方法,每种都附带详细的操作步骤,以及各自的优缺点。
    的头像 发表于 10-29 09:17 125次阅读

    MXoptiCal-简化精密测量-只需几个步骤即可实现致的目标测量#ADAS

    adas
    北汇信息POLELINK
    发布于 :2024年09月20日 10:16:32

    Matepad pro12.2 已上市半个月,但是还没有在开源网站看到该项目的开源信息,违背开源精神

    Matepad pro12.2 已上市半个月,本人自己也购买了同款12+256的pad,想要同步学习下这款pad的些体验还不错的功能点,但是目前为止还没有在开源网站看到该项目的开源
    发表于 08-27 17:25

    ADAS系统组成简介#ADAS

    adas
    北汇信息POLELINK
    发布于 :2024年08月03日 20:05:37

    pytorch环境搭建详细步骤

    PyTorch作为广泛使用的深度学习框架,其环境搭建对于从事机器学习和深度学习研究及开发的人员来说至关重要。以下将介绍PyTorch环境搭建的详细
    的头像 发表于 08-01 15:38 684次阅读

    在PyTorch中搭建最简单的模型

    在PyTorch中搭建最简单的模型通常涉及几个关键步骤:定义模型结构、加载数据、设置损失函数和优化器,以及进行模型训练和评估。
    的头像 发表于 07-16 18:09 1774次阅读

    性能测试的流程步骤有哪些

    性能测试是软件测试的重要环节,主要目的是评估软件在不同负载条件下的性能表现,以确保软件能够满足用户的需求。本文将详细介绍性能测试的流程步骤
    的头像 发表于 05-29 16:00 678次阅读

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

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

    次平台开发工程师的“热辣滚烫”:爱星物联使用流程

    hello,我是名平台开发工程师小王,近期了解到爱星物联平台的开源版即将发布,有点小期待,不过平时我都是用公版平台完成系统搭建和产品控制的,来看看我是如何进行这“热辣滚烫”的新
    的头像 发表于 02-26 11:44 427次阅读
    <b class='flag-5'>一</b>次平台开发工程师的“热辣滚烫”:爱星物联使用<b class='flag-5'>流程</b>

    ADAS1000晶振不起振的原因?

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

    pcb设计流程步骤

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

    如何自己搭建服务器?

    如何自己搭建服务器?自己搭建服务器涉及到硬件和软件两
    的头像 发表于 12-12 16:52 3746次阅读

    搭建ftp服务器的步骤

    搭建ftp服务器的步骤  搭建FTP服务器是项需要定技术知识的任务,但是只要按照以下步骤进行
    的头像 发表于 12-07 16:32 1115次阅读

    搭建ssm框架的详细流程

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