一、項(xiàng)目范圍
該項(xiàng)目是一個(gè)高級(jí)駕駛輔助系統(tǒng)的原型,專注于感知算法(目標(biāo)檢測(cè)、車道線分割和交通標(biāo)志分類)。它提供了3個(gè)主要功能:
前方碰撞警告
車道偏離警告
交通標(biāo)志檢測(cè)及超速預(yù)警
它還提供了「有限的」虛擬硬件訪問(wèn)權(quán)限,作為邁向商業(yè)產(chǎn)品的一步:
通過(guò) LAN 中的 GPS 源的 GPS 讀取器
一個(gè) CAN 讀取器,用于從虛擬 can 總線讀取車速和轉(zhuǎn)向信號(hào)
但是,可以使用 GPS 模塊或 CAN 轉(zhuǎn) USB 電纜收集 GPS 和 CAN 信號(hào)。我將提供一些關(guān)于如何設(shè)置這些設(shè)備的說(shuō)明。
二。硬件設(shè)置
處理該項(xiàng)目所有輸入的中心組件是中央處理器。這臺(tái)計(jì)算機(jī)接收兩個(gè)輸入:(i) 來(lái)自相機(jī)的圖像,以及 (ii) 汽車底盤數(shù)據(jù),例如汽車速度和轉(zhuǎn)向信號(hào)。中央處理負(fù)責(zé)處理這些輸入以在需要時(shí)發(fā)出警告。在這個(gè)項(xiàng)目的范圍內(nèi),由于實(shí)驗(yàn)條件有限,我們實(shí)施了一個(gè)「模擬模塊來(lái)提供相機(jī)和傳感器讀取器輸入的替代方案」。在商業(yè)產(chǎn)品中,傳感器讀取器模塊可以通過(guò) GPS 模塊和 CAN 總線讀取器(例如 CAN 轉(zhuǎn) USB 電纜)來(lái)實(shí)現(xiàn);可以使用 USB 攝像頭提供攝像頭輸入。
「硬件清單:」
Jetson Nano 開(kāi)發(fā)者套件
Sandisk Ultra 64GB class-10 SD 卡
Wareshare 5寸液晶觸摸屏
Wareshare 8Ω 5W 喇叭
Jetson Nano 2寸5V散熱風(fēng)扇
透明外殼。
1.如何獲取汽車傳感器(速度,轉(zhuǎn)向燈)
使用 GPS 模塊
「出于開(kāi)發(fā)和教育目的:」
從您的手機(jī)共享 GPS:
從 Google Play 商店下載「共享 GPS應(yīng)用程序?!?/strong>
設(shè)置您的手機(jī)局域網(wǎng)地址,src/sensors/car_gps_reader.cpp并使用此應(yīng)用程序與您的 Jetson Nano 共享 GPS 信息。這樣,我們就可以獲取GPS信號(hào),估計(jì)車速。
使用 USB GPS 接收器
「對(duì)于商業(yè)產(chǎn)品:」
查看此模塊精度:< 3m。
如何設(shè)置CAN總線以讀取車速和轉(zhuǎn)向信號(hào)
「基本信息」
在這個(gè)項(xiàng)目中,我們沒(méi)有在真車上設(shè)置物理 CAN 總線(只是一個(gè)使用 socket CAN 的仿真系統(tǒng))。但是,它可以通過(guò)使用 CAN 轉(zhuǎn) USB 電纜來(lái)實(shí)現(xiàn)。
CAN總線的一些信息:
一般信息
如何侵入您的車輛?:hacking-can-bus.pdf
開(kāi)源 CAN 電纜:CANtact。這將支持您將 CAN 總線連接到 linux 套接字,「我的 ADAS 源代碼已經(jīng)支持該套接字」。
硬件設(shè)計(jì)
固件:
在韓國(guó)
您還需要 OBD-II 到 DB9 電纜來(lái)連接汽車 OBD-II
一旦 CANtact 設(shè)備處理了來(lái)自車輛的 CAN 消息,它們就會(huì)通過(guò) USB B 型端口輸出。因此,這需要 USB-B 到 USB-A 電纜:https://www.amazon.com/AmazonBasics-USB-2-0-Cable-Male/dp/B00NH11KIK
「我們?cè)谀睦锟梢哉业揭B接的 CAN 總線?」
在這個(gè)項(xiàng)目中,我們只使用虛擬 CAN 總線,因此項(xiàng)目源代碼仍然不支持與汽車 CAN 總線的真實(shí)連接。不幸的是,雖然 CAN 總線是汽車行業(yè)的標(biāo)準(zhǔn),但如果您想找到您的 can 線在哪里,您通常需要查看汽車電氣圖才能找到內(nèi)部 CAN 總線。自 1996 年以來(lái),有一個(gè)名為 OBD2 的汽車標(biāo)準(zhǔn),可以提供一種方便的方式連接到 CAN 總線。
「OBD2接口在哪里?」
OBD-II 端口通常位于儀表板下方,方向盤柱下方(下圖中的 1 - 3)。如果端口不在轉(zhuǎn)向柱下方,請(qǐng)?jiān)跀?shù)字 4 - 9 指示的區(qū)域中尋找端口。
「我怎樣才能反轉(zhuǎn)CAN工程并讀取速度?」
您可以使用 Wireshark 或 candump 查找車速和轉(zhuǎn)向燈在哪里。CAN總線是沒(méi)有加密的,大家可以根據(jù)下面的說(shuō)明嘗試查找。
2. 如何標(biāo)定相機(jī)
將 USB 攝像頭連接到 Jetson Nano 板后,我們需要運(yùn)行 OpenADAS 軟件來(lái)校準(zhǔn)攝像頭。校準(zhǔn)實(shí)際上是基于透視變換的距離估計(jì)。這是為距離計(jì)算校準(zhǔn)相機(jī)的便捷方式。
變換參數(shù)包括從真實(shí)世界距離到鳥瞰圖像空間的米到像素映射,以及鳥瞰圖像到相機(jī)圖像之間的透視變換矩陣。為了計(jì)算這些參數(shù),我們使用以下解決方案:在汽車前面放一塊紅地毯,測(cè)量距離 W1、W2、L1、L2。地毯應(yīng)該足夠大,并且必須對(duì)稱地放置在汽車的長(zhǎng)軸上。
單擊設(shè)置按鈕以打開(kāi)相機(jī)校準(zhǔn)。
在 UI 中輸入 L1、L2、W1、W2。
之后,通過(guò)單擊「重新拍攝照片」選擇 4 個(gè)點(diǎn),選擇一個(gè)點(diǎn)并移動(dòng)滑塊。這些點(diǎn)必須以正確的順序拾取。相機(jī)標(biāo)定后,標(biāo)定文件將被保存data/camera_calib.txt并在每次啟動(dòng)程序時(shí)加載回來(lái)。
三、感知模型和算法
1. 物體檢測(cè)與交通標(biāo)志分類模型
該物體檢測(cè)模塊負(fù)責(zé)檢測(cè)前方障礙物物體,如其他車輛或行人,以及交通標(biāo)志。這些結(jié)果可用于前方碰撞預(yù)警和超速預(yù)警。為了提供這些功能,該模塊包含兩個(gè)主要組件:基于 CenterNet 的對(duì)象檢測(cè)神經(jīng)網(wǎng)絡(luò)和基于 ResNet-18 的交通標(biāo)志分類網(wǎng)絡(luò)。因此,我們將在下圖中看到 2 個(gè)深度學(xué)習(xí)模型。
1.1.使用 CenterNet 進(jìn)行目標(biāo)檢測(cè)
CenterNet 是一種簡(jiǎn)單但高效的對(duì)象檢測(cè)模型。與其他流行的目標(biāo)檢測(cè)模型相比,CenterNet 可以非常有效地適應(yīng)速度-精度權(quán)衡。與其他流行的基于錨框的對(duì)象檢測(cè)網(wǎng)絡(luò)不同,CenterNet 依靠關(guān)鍵點(diǎn)檢測(cè)器來(lái)檢測(cè)對(duì)象的中心,然后回歸其他屬性。
CenterNet管道 「論文:」作為點(diǎn)的對(duì)象 - Xingyi Zhou、Dequan Wang、Philipp Kr?henbühlhttps://arxiv.org/abs/1904.07850。
「訓(xùn)練」
我使用 CenterNet 作者的官方存儲(chǔ)庫(kù)來(lái)訓(xùn)練對(duì)象檢測(cè)器(進(jìn)行了一些修改)。請(qǐng)閱讀此處的安裝步驟以安裝培訓(xùn)所需的環(huán)境。
「筆記:」
我建議使用 Anaconda 或 Miniconda 為每個(gè)任務(wù)創(chuàng)建一個(gè)虛擬環(huán)境。不要混合你的環(huán)境,因?yàn)槲覀儽仨毷褂貌煌?Python 和包版本。
您「必須使用」PyTorch v0.4.1 并將其設(shè)置為此處的說(shuō)明:https://github.com/xingyizhou/CenterNet/blob/master/readme/INSTALL.md。不保證其他版本有效。
我修改了官方存儲(chǔ)庫(kù)以使用 Berkeley DeepDrive (BDD) 數(shù)據(jù)集](https://bdd-data.berkeley.edu/)。您可以在此處克隆源代碼以開(kāi)始訓(xùn)練。在我的存儲(chǔ)庫(kù)中,我用10個(gè)類訓(xùn)練了 CenterNet:person、、、、、、、、、和。ridercarbustruckbikemotortraffic lighttraffic signtrain
「使用 TensorRT 進(jìn)行模型優(yōu)化」
使用 PyTorch 框架訓(xùn)練 CenterNet 后,我們獲得 PyTorch 模型格式(.pth)的模型文件。為了優(yōu)化 NVIDIA Jetson Nano 上的推理速度,我們需要將這些模型轉(zhuǎn)換為 TensorRT 引擎文件。轉(zhuǎn)換是通過(guò)稱為 ONNX(開(kāi)放式神經(jīng)網(wǎng)絡(luò)交換)的中間格式完成的。首先使用 PyTorch ONNX 模塊將 PyTorch 模型轉(zhuǎn)換為 ONNX 格式(步驟 1)。
之后,我們將 ONNX 模型轉(zhuǎn)換為每個(gè)推理平臺(tái)的 TensorRT 引擎(步驟 2)。因?yàn)閺腛NNX到TensorRT引擎的轉(zhuǎn)換時(shí)間比較長(zhǎng),所以在我的實(shí)現(xiàn)中,我將TensorRT引擎轉(zhuǎn)換后序列化到硬盤,每次程序啟動(dòng)時(shí)加載。在此步驟中,我們必須注意 TensorRT 引擎在不同計(jì)算機(jī)硬件上的構(gòu)建方式不同。所以,
使用此存儲(chǔ)庫(kù)將預(yù)訓(xùn)練模型轉(zhuǎn)換為 ONNX 格式
「筆記:」
創(chuàng)建另一個(gè)虛擬環(huán)境,這與培訓(xùn)不同。這個(gè)新的 Python 環(huán)境應(yīng)該使用 Pytorch v1.0 或 v1.1。我為上面的這個(gè)轉(zhuǎn)換任務(wù)準(zhǔn)備了一個(gè)存儲(chǔ)庫(kù)。您可以使用此處的說(shuō)明來(lái)設(shè)置您自己的環(huán)境。
您可以從該文件夾convert_to_onnx_mobilenet.py中閱讀(對(duì)于 MobileNetv2 主干)和convert_to_onnx_rescdn18.py(對(duì)于 ResNet-18 主干)中的一些轉(zhuǎn)換示例源代碼。
擁有 ONNX 模型后,轉(zhuǎn)到 OpenADAS 以更新配置文件中新對(duì)象檢測(cè)模型的路徑:src/configs/config_object_detection.h.您還可以使用此存儲(chǔ)庫(kù)進(jìn)行轉(zhuǎn)換。
1.2.交通標(biāo)志分類
由于「BDD 數(shù)據(jù)集」的限制——它只包含 1 類交通標(biāo)志(未指定標(biāo)志類型),我不得不訓(xùn)練另一個(gè)神經(jīng)網(wǎng)絡(luò)來(lái)識(shí)別標(biāo)志類型。由于速度和準(zhǔn)確性高,因此也選擇了「ResNet-18來(lái)完成這項(xiàng)任務(wù)。」我使用 Tensorflow 和 Keras 框架訓(xùn)練了模型。
「數(shù)據(jù)集」
在這個(gè)項(xiàng)目中,我只設(shè)計(jì)了對(duì)最大速度標(biāo)志進(jìn)行分類的系統(tǒng),并將每個(gè)速度級(jí)別視為一個(gè)單獨(dú)的對(duì)象類。為了收集足夠的訓(xùn)練數(shù)據(jù),我使用了 2 個(gè)數(shù)據(jù)集:Mapillary Traffic Sign Dataset (MTSD) 和 German Traffic Sign Recognition (GRSRB) 數(shù)據(jù)集。由于 MTSD 是一個(gè)交通標(biāo)志檢測(cè)數(shù)據(jù)集,我使用標(biāo)志邊界框來(lái)裁剪它們以進(jìn)行分類任務(wù)。裁剪后,我合并了 2 個(gè)數(shù)據(jù)集,得到 18,581 個(gè)最高限速交通標(biāo)志圖像分為 13 個(gè)類別,以及 879 個(gè)末端限速標(biāo)志(將所有末端限速標(biāo)志僅視為 1 類)。
此外,我使用來(lái)自其他交通標(biāo)志和物體的 20,000 張裁剪圖像作為“未知”類別。該數(shù)據(jù)集中共有 15 個(gè)類別:最大速度標(biāo)志(5km/h、10km/h、20km/h、30km/h、40km/h、50km/h、60km/h、70km/h、80km/h , 90 公里/小時(shí), 100 公里/小時(shí), 110km/h、120km/h)、限速終點(diǎn)(EOSL)等標(biāo)志(OTHER)。之后,這個(gè)數(shù)據(jù)集被分成 3 個(gè)子集:訓(xùn)練集(80%)、驗(yàn)證集(10%)和測(cè)試集(10%)。每個(gè)交通標(biāo)志類別的分布是隨機(jī)的。
「訓(xùn)練步驟」
使用此存儲(chǔ)庫(kù)中的源代碼來(lái)訓(xùn)練交通標(biāo)志分類器
「第一步:初始化環(huán)境」
創(chuàng)建anaconda環(huán)境:
conda create --name
激活創(chuàng)建的環(huán)境并安裝所有要求:
pip install requirements.txt
「第 2 步:訓(xùn)練模型」
準(zhǔn)備如下結(jié)構(gòu)的數(shù)據(jù)集:
使用以下命令訓(xùn)練模型:
pythontrain.py
「使用 TensorRT 進(jìn)行模型優(yōu)化」
轉(zhuǎn)換為 UFF
convert_h5_to_pb.py修改和中的模型路徑convert_pb_to_uff.py。
將.h5模型轉(zhuǎn)換為.pb, 最后.uff:
pipinstallrequirements-h5-to-uff.txt pythonconvert_h5_to_pb.py pythonconvert_pb_to_uff.py
擁有 ONNX 模型后,轉(zhuǎn)到 OpenADAS 以更新配置文件中新交通標(biāo)志分類模型的路徑:src/configs/config_sign_classification.h.
2.車道線分割模型
車道線檢測(cè)模塊負(fù)責(zé)檢測(cè)車道線和車道偏離情況。然后將該結(jié)果用于車道偏離警告。我使用深度神經(jīng)網(wǎng)絡(luò)和霍夫變換線檢測(cè)器進(jìn)行車道線檢測(cè)。下面介紹車道線檢測(cè)的流程。
車道線檢測(cè)流水線
用于車道線分割的 U-Net 模型
U-Net 是一種在生物醫(yī)學(xué)圖像分割中表現(xiàn)良好的全卷積網(wǎng)絡(luò),它可以用較少的訓(xùn)練圖像數(shù)據(jù)展示高精度的分割結(jié)果。我將 U-Net 應(yīng)用于車道線分割問(wèn)題,并結(jié)合霍夫變換以線方程的形式找到車道線。
U網(wǎng)模型
為了在嵌入式硬件上運(yùn)行輕量級(jí)分割模型,我對(duì)原始 U-Net 模型進(jìn)行了兩次修改:
(1) 將decoder filters的數(shù)量調(diào)整為128, 64, 32, 16, 8個(gè)filters,從decoder的頂部到網(wǎng)絡(luò)的輸出;
(2) 用 ResNet-18 主干替換原來(lái)的主干。
這些修改減少了 U-Net 中的參數(shù)數(shù)量,并為我們提供了一個(gè)可以超過(guò) 200 幀每秒 (FPS) 運(yùn)行的輕量級(jí)模型(模型 U-Net ResNet-18 輸入大小 384x382,RTX 2070 GPU 上的 TensorRT float 16 ).
數(shù)據(jù)集
數(shù)據(jù)集是從Mapillary Vista 數(shù)據(jù)集準(zhǔn)備的,并進(jìn)行了一些修改。原始數(shù)據(jù)集包含訓(xùn)練集中約 18000 張圖像和驗(yàn)證集中約 2000 張圖像。我合并這些集合,刪除一些不包含車道線或有太多噪音的圖像。最終數(shù)據(jù)集有 15303 張圖像。我將這個(gè)集合隨機(jī)分成三個(gè)子集:10712 張圖像用于訓(xùn)練(~70%),2296 張圖像用于驗(yàn)證(~15%)和 2295 張圖像用于測(cè)試(~15%)。因?yàn)?Mapillary Vista 的標(biāo)簽包含很多對(duì)象類,所以我只保留車道線類來(lái)生成二值分割掩碼作為新標(biāo)簽。
Mapillary Vistas 數(shù)據(jù)集預(yù)處理——圖像 A、B 來(lái)自 Mapillary Vitas
訓(xùn)練
使用我的存儲(chǔ)庫(kù)訓(xùn)練 U-Net 進(jìn)行車道線分割
「第一步:初始化環(huán)境」
創(chuàng)建anaconda環(huán)境:
conda create --name
激活創(chuàng)建的環(huán)境并安裝所有要求:
pip install requirements.txt
「第 2 步:訓(xùn)練模型」
在目錄中創(chuàng)建新的配置文件list_config請(qǐng)不要修改舊的配置文件,以便我們更好地觀察,模型和訓(xùn)練歷史將自動(dòng)保存到saved_models文件夾中。
對(duì)于培訓(xùn),只需運(yùn)行:
python model/train.py
或者
./train.sh
使用 TensorRT 進(jìn)行模型優(yōu)化
轉(zhuǎn)換為 UFF
為此任務(wù)創(chuàng)建另一個(gè)虛擬環(huán)境。
convert_h5_to_pb.py修改和中的模型路徑convert_pb_to_uff.py。
.h5將模型轉(zhuǎn)換為.pb,并最終使用這些命令(請(qǐng)更新和.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 模型后,轉(zhuǎn)到 OpenADAS 以在車道檢測(cè)配置文件中更新該新模型的路徑:src/configs/config_lane_detection.h.
使用霍夫變換進(jìn)行車道線檢測(cè)
霍夫變換是一種在圖像處理中非常有效的線檢測(cè)算法。該算法的總體思想是創(chuàng)建從圖像空間(A)到新空間(B)的映射,空間(A)中的每條線對(duì)應(yīng)空間中的一個(gè)點(diǎn)(B),空間中的每個(gè)點(diǎn)(A)對(duì)應(yīng)空間中的正弦曲線 (B)。將 (A) 中的所有點(diǎn)投影到空間 (B) 中的正弦曲線后,我們找到交點(diǎn)密度最高的地方。然后將這些位置投影到 (A) 成線。通過(guò)這種方式,霍夫線變換算法可以在圖像空間(A)中找到線。
尋找候選車道線的過(guò)程如下圖所示。從線分割網(wǎng)絡(luò)產(chǎn)生的分割掩碼,車道線檢測(cè)模塊使用概率霍夫變換來(lái)檢測(cè)原始線段(1)。之后,使用由 Bernard A. Galler 和 Michael J. Fischer 在 1964 年反轉(zhuǎn)的不相交集/聯(lián)合查找森林算法將這些線劃分為組。我們使用線之間的空間距離和角度差將屬于一個(gè)線段分組同一條線。經(jīng)過(guò)步驟(2),我們可以看到不同的線組被繪制成不同的顏色。步驟 (3) 接收這些線組作為輸入,并使用具有 L2 距離的最大似然估計(jì)在每個(gè)組中擬合一條線。
線候選檢測(cè)
該系統(tǒng)將車道分割模型與上述車道檢測(cè)算法相結(jié)合,可以檢測(cè)不同環(huán)境下的車道線,判斷車道偏離情況。它為車道偏離警告模塊創(chuàng)建可靠的輸入。
4.警告規(guī)則
該系統(tǒng)使用基于規(guī)則的警告算法。
審核編輯:劉清
-
GPS技術(shù)
+關(guān)注
關(guān)注
0文章
26瀏覽量
10278 -
CAN
+關(guān)注
關(guān)注
57文章
2756瀏覽量
463891 -
ADAS系統(tǒng)
+關(guān)注
關(guān)注
4文章
226瀏覽量
25725 -
讀取器
+關(guān)注
關(guān)注
0文章
47瀏覽量
5285
原文標(biāo)題:如何搭建一個(gè)開(kāi)源ADAS項(xiàng)目
文章出處:【微信號(hào):智能汽車電子與軟件,微信公眾號(hào):智能汽車電子與軟件】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論