0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

樹莓派自動駕駛:使用 Keras 與 Tensorflow 構(gòu)建車道跟蹤自動汽車

基于樹莓派的自動駕駛 ? 2018-10-07 17:59 ? 次閱讀

無人駕駛雖然入門門檻很高,但是還是可以通過一些簡化的模型迅速上手。例如比較有名的DonkeyCar,其實就是一個簡單低成本的玩具車,基于樹莓派Python,利用Keras深度學(xué)習框架實現(xiàn)自動駕駛。即使沒有實車,也可以在Donkey Car官網(wǎng)下載模擬器,用程序控制模擬器中的小車。感興趣的同學(xué)可以看看社區(qū)和文檔

目前還有一些比賽也在使用donkey car幫助大家低門檻地進入自動駕駛領(lǐng)域。例如中國人工智能學(xué)會主辦的2018模擬駕駛比賽,比賽提供了一些獎金,還為進入決賽的選手免費提供donkeycar實車線下比拼。此外,中國人工智能學(xué)會還會頒發(fā)證書,所以可以向想要入門自動駕駛,想保研、申請獎學(xué)金的同學(xué)推薦一下。此外,網(wǎng)上還有不少簡單的攻略,例如下面是一篇來自github的自動駕駛相關(guān)研究,我對這篇文章進行了編譯并在此發(fā)布,希望能幫助更多感興趣的朋友上手自動駕駛。

歡迎大家相互交流,項目地址:https://biendata.com/kernel/detail/427

導(dǎo)入相關(guān)庫

步驟1:獲取駕駛數(shù)據(jù)

數(shù)據(jù)集由 ~7900 個圖像和手動開車時收集的轉(zhuǎn)向角組成。大約三分之二的圖像與線之間的汽車。另外三分之一的車開始偏離航線,并且駛回線路之間。

路徑是

數(shù)據(jù)集由 2 個 pickled 數(shù)組組成。X 是圖像陣列,Y 是相應(yīng)轉(zhuǎn)向角度的陣列。

結(jié)果:

步驟2:拆分數(shù)據(jù)

在這里,我們將洗牌(shuffle)我們的數(shù)據(jù),并將數(shù)據(jù)分成三部分。訓(xùn)練數(shù)據(jù)將用于訓(xùn)練我們的駕駛模型,使用驗證數(shù)據(jù)避免過度擬合模型,測試數(shù)據(jù)用于測試我們的模型是否學(xué)到了什么。

輸出:7892

輸出:7892

步驟3:增強訓(xùn)練數(shù)據(jù)

為了加倍我們的訓(xùn)練數(shù)據(jù)并防止轉(zhuǎn)向偏差,我們翻轉(zhuǎn)每個圖像和轉(zhuǎn)向角并將其添加到數(shù)據(jù)集中。還有其他的方法來增加使用翻譯和假陰影駕駛數(shù)據(jù),但我沒有使用這些自動駕駛儀。

結(jié)果:12626

步驟4:建立駕駛模式

這種駕駛模式將是一個端到端的神經(jīng)網(wǎng)絡(luò),接受圖像陣列作為輸入,并輸出-90(左)和90(右)之間的轉(zhuǎn)向角。 要做到這一點,我們將使用一個完全連接圖層的3層卷積網(wǎng)絡(luò)。該模型基于 Otavio 的 Carputer,但不產(chǎn)生油門值輸出,不使用過去的轉(zhuǎn)向值作為模型的輸入,并且使用較少的卷積層。

使用 TensorFlow 后端

輸出:

步驟5:訓(xùn)練模型

我已經(jīng)學(xué)會了很難的方法,即使這一切都是完美的,如果你沒有正確地訓(xùn)練,你的自動駕駛儀將無法工作。我遇到的最大的問題是過度適應(yīng)模型,以至于在很少的情況下都不能正常工作。 這里是 2 個 Keras回調(diào),將節(jié)省您的時間。

警告 -如果僅使用CPU,則需要很長時間(3小時)

我在沒有 CUDA 兼容 GPU 的 Dell XPS 筆記本電腦上運行,因此速度非常慢,并且凍結(jié)。為了加速訓(xùn)練,您可以使用帶有 GPU 的 EC2 實例。Keras 和 Tensorflow 已經(jīng)加載了幾個實例圖像。

對于這個筆記本,我只會訓(xùn)練模型 4 個時代(epochs)。

輸出:

步驟6:評估性能

我們可以通過繪制預(yù)測值和實際值來檢查我們的模型預(yù)測是否合理。第一個圖表顯示我們的測試數(shù)據(jù)中存在一個學(xué)習的關(guān)系(在訓(xùn)練期間模型沒有看到)。

第二張圖,使用包含訓(xùn)練數(shù)據(jù)的非混洗(unshuffled)數(shù)據(jù),來顯示預(yù)測角度緊跟實際轉(zhuǎn)向角度。

輸出:

下一步

改善模型,這個模型是純粹(navie)的,因為它不使用過去的值來幫助預(yù)測未來。我們可以通過將過去的轉(zhuǎn)向角度作為模型的輸入來進行試驗,添加一個遞歸層,或者只是改變卷積層的結(jié)構(gòu)。

添加更多數(shù)據(jù),隨著我們添加更多駕駛數(shù)據(jù),此模型將會得到改進。預(yù)測油門,輸出目前自動駕駛儀只能轉(zhuǎn)向并保持恒定的速度。一個更復(fù)雜的模型將加速在直路上,并在路緣之前放緩。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 人工智能
    +關(guān)注

    關(guān)注

    1804

    文章

    48721

    瀏覽量

    246555
  • 機器學(xué)習
    +關(guān)注

    關(guān)注

    66

    文章

    8492

    瀏覽量

    134098
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4825

    瀏覽量

    86197
  • 自動駕駛
    +關(guān)注

    關(guān)注

    788

    文章

    14202

    瀏覽量

    169557
  • 樹莓派
    +關(guān)注

    關(guān)注

    121

    文章

    1946

    瀏覽量

    106989
  • tensorflow
    +關(guān)注

    關(guān)注

    13

    文章

    330

    瀏覽量

    61033
  • keras
    +關(guān)注

    關(guān)注

    2

    文章

    20

    瀏覽量

    6170
收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    自動駕駛安全基石:ODD

    電子發(fā)燒友網(wǎng)綜合報道 自動駕駛ODD(Operational Design Domain)即設(shè)計運行域,是指自動駕駛系統(tǒng)被設(shè)計為安全、有效運行的具體條件范圍。它定義了自動駕駛汽車在哪些
    的頭像 發(fā)表于 05-19 03:52 ?4761次閱讀

    樹莓也能實現(xiàn)海上自動駕駛?

    全員登船,共赴樹莓之旅生活中有些問題,用樹莓派來解決會更有樂趣。今天,我們要與航海愛好者們分享一個由創(chuàng)客TommyJoad打造的巧妙項目。Joad是一位帆船船長,對現(xiàn)代自動駕駛系統(tǒng)了
    的頭像 發(fā)表于 04-24 16:04 ?192次閱讀
    <b class='flag-5'>樹莓</b><b class='flag-5'>派</b>也能實現(xiàn)海上<b class='flag-5'>自動</b>化<b class='flag-5'>駕駛</b>?

    NVIDIA Halos自動駕駛汽車安全系統(tǒng)發(fā)布

    自動駕駛汽車的開發(fā)。正確的技術(shù)與框架對確保自動駕駛汽車駕駛員、乘客和行人的安全至關(guān)重要。 因此,NVIDIA 推出了NVIDIA Halos綜合安全系統(tǒng),將 NVIDIA 的
    的頭像 發(fā)表于 03-25 14:51 ?492次閱讀

    理想汽車推出全新自動駕駛架構(gòu)

    2025年3月18日,理想汽車自動駕駛技術(shù)研發(fā)負責人賈鵬在NVIDIA GTC 2025發(fā)表主題演講《VLA:邁向自動駕駛物理智能體的關(guān)鍵一步》,分享了理想汽車對于下一代
    的頭像 發(fā)表于 03-19 14:12 ?416次閱讀

    【實戰(zhàn)】Python+OpenCV車道線檢測識別項目:實現(xiàn)L2級別自動駕駛必備(配套課程+平臺實踐)

    的一個必備技能——車道線檢測。本文將詳細介紹一個車道線檢測項目的過程,從圖像采集到車道線的準確識別,看看在L2自動駕駛中,如何通過圖像處理技術(shù),讓
    的頭像 發(fā)表于 12-16 15:42 ?932次閱讀
    【實戰(zhàn)】Python+OpenCV<b class='flag-5'>車道</b>線檢測識別項目:實現(xiàn)L2級別<b class='flag-5'>自動駕駛</b>必備(配套課程+平臺實踐)

    MEMS技術(shù)在自動駕駛汽車中的應(yīng)用

    MEMS技術(shù)在自動駕駛汽車中的應(yīng)用主要體現(xiàn)在傳感器方面,這些傳感器為自動駕駛汽車提供了關(guān)鍵的環(huán)境感知和數(shù)據(jù)采集能力。以下是對MEMS技術(shù)在自動駕駛
    的頭像 發(fā)表于 11-20 10:19 ?1306次閱讀

    自動駕駛汽車安全嗎?

    隨著未來汽車變得更加互聯(lián),汽車逐漸變得更加依賴技術(shù),并且逐漸變得更加自動化——最終實現(xiàn)自動駕駛,了解自動駕駛
    的頭像 發(fā)表于 10-29 13:42 ?974次閱讀
    <b class='flag-5'>自動駕駛</b><b class='flag-5'>汽車</b>安全嗎?

    使用STT全面提升自動駕駛中的多目標跟蹤

    3D多目標跟蹤(3D MOT)在各種機器人應(yīng)用中發(fā)揮著關(guān)鍵作用,例如自動駕駛車輛。為了在駕駛時避免碰撞,機器人汽車必須可靠地跟蹤道路上的物體
    的頭像 發(fā)表于 10-28 10:07 ?596次閱讀
    使用STT全面提升<b class='flag-5'>自動駕駛</b>中的多目標<b class='flag-5'>跟蹤</b>

    自動駕駛技術(shù)的典型應(yīng)用 自動駕駛技術(shù)涉及到哪些技術(shù)

    自動駕駛技術(shù)的典型應(yīng)用 自動駕駛技術(shù)是一種依賴計算機、無人駕駛設(shè)備以及各種傳感器,實現(xiàn)汽車自主行駛的技術(shù)。它通過使用人工智能、視覺計算、雷達、監(jiān)控裝置和全球定位系統(tǒng)等技術(shù),使
    的頭像 發(fā)表于 10-18 17:31 ?1731次閱讀

    FPGA在自動駕駛領(lǐng)域有哪些優(yōu)勢?

    FPGA(Field-Programmable Gate Array,現(xiàn)場可編程門陣列)在自動駕駛領(lǐng)域具有顯著的優(yōu)勢,這些優(yōu)勢使得FPGA成為自動駕駛技術(shù)中不可或缺的一部分。以下是FPGA在自動駕駛
    發(fā)表于 07-29 17:11

    FPGA在自動駕駛領(lǐng)域有哪些應(yīng)用?

    低,適合用于實現(xiàn)高效的圖像算法,如車道線檢測、交通標志識別等。 雷達和LiDAR處理:自動駕駛汽車通常會使用雷達和LiDAR(激光雷達)等多種傳感器來獲取環(huán)境信息。FPGA能夠協(xié)助完成這些傳感器
    發(fā)表于 07-29 17:09

    自動駕駛汽車如何識別障礙物

    自動駕駛汽車識別障礙物是一個復(fù)雜而關(guān)鍵的過程,它依賴于多種傳感器和技術(shù)的協(xié)同工作。這些傳感器主要包括激光雷達(LiDAR)、雷達、攝像頭以及超聲波雷達等,它們各自具有不同的工作原理和優(yōu)勢,共同為自動駕駛
    的頭像 發(fā)表于 07-23 16:40 ?2490次閱讀

    自動駕駛汽車傳感器有哪些

    自動駕駛汽車傳感器是實現(xiàn)自動駕駛功能的關(guān)鍵組件,它們通過采集和處理車輛周圍環(huán)境的信息,為自動駕駛系統(tǒng)提供必要的感知和決策依據(jù)。以下是對自動駕駛
    的頭像 發(fā)表于 07-23 16:00 ?3057次閱讀

    keras模型轉(zhuǎn)tensorflow session

    在這篇文章中,我們將討論如何將Keras模型轉(zhuǎn)換為TensorFlow session。 KerasTensorFlow簡介 Keras
    的頭像 發(fā)表于 07-05 09:36 ?805次閱讀