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

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

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

如何用Ubuntu14.04搭建GPU版本的Apollo3.5平臺

YB7m_Apollo_Dev ? 來源:lp ? 2019-03-08 11:05 ? 次閱讀

Ubuntu基于Linux的免費開源桌面PC操作系統(tǒng),支持x86、64位和ppc架構。

由于Apollo項目是在Docker中運行,因此不能直接在Ubuntu 14.04系統(tǒng)中直接生成核心轉儲文件并使用GDB對其進行調(diào)試,所有的工作必須在Docker中完成。

開發(fā)者還需要GLFW(圖形庫框架)3.2及更高版本,它支持EGL和運行時上下文創(chuàng)建API選擇。

本文由社區(qū)開發(fā)者「朗拓科技-楊鴻城」撰寫。為大家詳細講述了如何用Ubuntu14.04搭建GPU版本的Apollo3.5平臺。

Apollo 3.5 歷史版本的跨越式升級,使自動駕駛不光整體提升了駕駛能力和安全性,從而可以“媲美”人類老司機,更為自動駕駛全行業(yè)在向全面落地的進發(fā)過程中提供了更優(yōu)質、更全方位的技術支持。Apollo 3.5將繼續(xù)為開發(fā)者們節(jié)省造輪子的時間。

希望本文能為開發(fā)者們帶來更多幫助。

以下,ENJOY

安裝Ubuntu14.04

安裝Git-LFS

添加SSH密鑰(可選)

下載Apollo鏡像

設置Docker環(huán)境

安裝ROS-Indigo(可選)

安裝Apollo預編譯的內(nèi)核

編譯CPU版本的Apollo

運行Apollo Demo 演示

編譯GPU版本的Apollo(可選)

可參考:

*《安裝Windows10,Ubuntu雙系統(tǒng)14.04LTS記錄》

https://www.cnblogs.com/arcsinw/p/5303615.html

1.安裝Curl

1sudoapt-getupdate2sudoapt-getupgrade3sudoapt-getinstallcurl

2.添加地址

1#RequiredforUbuntu14.04/16.04.2curl-shttps://packagecloud.io/install/repositories/github/git-lfs/script.deb.sh|sudobash

3.安裝Git-LFS

1#Ubuntu14.04/16.04/18.04.2sudoapt-getinstall-ygit-lfs

PS:若未安裝Git,需先執(zhí)行 sudo apt-get install git .

寫在前面:用SSH方式下載Apollo鏡像需要秘鑰,用HTTP方式 下載則可以跳過此步驟。

1.首先注冊一個GitHub賬號

2.參考:

https://blog.csdn.net/qq_34446663/article/details/81106018

或者

https://www.cnblogs.com/qcwblog/p/5709720.html

添加秘鑰

最后實現(xiàn)效果如圖:

1.從GitHub源代碼下載Apollo源代碼并查看正確的分支:

1gitlfsclonehttps://github.com/ApolloAuto/apollo2cdapollo3gitcheckoutmaster4echo"exportAPOLLO_HOME=$(pwd)">>~/.bashrc&&source~/.bashrc

#文件下載大概1.8G,這里的APOLLO_HOME應該替換為Apollo文件夾所在根目錄。

如果你過去安裝過其他版本的Docker,先刪掉:

1sudoapt-getremovedockerdocker-enginedocker.io

首先安裝依賴:

1sudoapt-getinstallapt-transport-httpsca-certificatescurlgnupg2software-properties-common

信任Docker的GPG公鑰:

1curl-fsSLhttps://download.docker.com/linux/ubuntu/gpg|sudoapt-keyadd-

對于Amd64架構的計算機,添加軟件倉庫:

1sudoadd-apt-repository2"deb[arch=amd64]https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/ubuntu3$(lsb_release-cs)4stable"

如果你是樹莓派或其它ARM架構計算機,請運行:

1echo"deb[arch=armhf]https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/ubuntu2$(lsb_release-cs)stable"|3sudotee/etc/apt/sources.list.d/docker.list

最后安裝

1sudoapt-getupdate2sudoapt-getinstalldocker-ce

把當前用戶加到Docker用戶組中:

添加Docker用戶組

1sudogroupadddocker

把自己加到Docker用戶組中

1sudogpasswd-amyusernamedocker

Myusername是指你的用戶名

重啟Docker后臺服務

1sudoservicedockerrestart

切換當前用戶到新Group

1newgrp-docker

確認Docker可以非sudo運行

1dockerps

寫在前面:Apollo3.5可不用安裝Ros,但Apollo很多驅動都是從Ros移植過來的,安裝Ros仍有研究價值。

1、執(zhí)行

1sudosh-c'echo"debhttp://packages.ros.org/ros/ubuntutrustymain">/etc/apt/sources.list.d/ros-latest.list'

2、執(zhí)行

1wgethttp://packages.ros.org/ros.key-O-|sudoapt-keyadd-

3、更新源

1sudoapt-getupdate

4、安裝ros-indigo-desktop-full

1sudoapt-getinstallros-indigo-desktop-full

大概需要半個小時左右

5、執(zhí)行代碼初始化ROS

1sudorosdepinit

若提示Rosdep update 則執(zhí)行Rosdep update

6、設置環(huán)境變量

1echo"source/opt/ros/indigo/setup.bash">>~/.bashrc2source~/.bashrc

以上的這個設置是永久性的,不需要每次打開一個終端都需要進行一次設置。到此ROS安裝完成,終端執(zhí)行Roscore進行測試即可。

7、下載Apollo-Platform并解壓:

https://github.com/ApolloAuto/apollo-platform/releases

將文件夾中的Ros拷貝到Apollo工程中:

1rsync-avros/~/apollo/third_party/ros_x86_642cdapollo3source./third_party/ros_x86_64/setup.bash

*注:如果只是用于「學習研究」用途可以不安裝「內(nèi)核」,用于「真實駕駛」則必須安裝「內(nèi)核」。

寫在前面:在安裝Apollo內(nèi)核之前先卸載 NVIDIA顯卡驅動(參考編譯GPU版本的Apollo(可選)第1步),因為Apollo內(nèi)核是實時系統(tǒng),而默認安裝的NVIDIA驅動內(nèi)核不支持實時系統(tǒng)(會造成循環(huán)登錄),如果只是用于學習研究用途可以不安裝內(nèi)核,用于真實駕駛則必須安裝內(nèi)核。

安裝Apollo內(nèi)核后,再安裝NVIDIA 驅動時必須加上 --no-kernel-module 參數(shù)(參考編譯GPU版本的Apollo(可選)第6步)。

1.從GitHub上的發(fā)布部分下載發(fā)行包:

https://github.com/ApolloAuto/apollo-kernel/releases

2.下載發(fā)布包后安裝內(nèi)核:

1tarzxvflinux-4.4.32-apollo-1.5.0.tar.gz2cdinstall3sudobashinstall_kernel.sh4sudoreboot

1.設置Docker環(huán)境

1cdapollo2bashdocker/scripts/dev_start.sh-C#-C表示從中國鏡像服務器下載,速度較快3bashdocker/scripts/dev_into.sh

2.編譯Apollo

1bashapollo.shbuild#若提示權限不足,則sudosu

3.啟動人機交互界面(HMI)

1bashscripts/bootstrap.sh

打開Chrome瀏覽器,輸入地址“l(fā)ocalhost:8888”即可訪問Dreamview。

參考:

https://github.com/ApolloAuto/apollo/blob/master/docs/demo_guide/README.md

或者

在Docker中執(zhí)行

1bash scripts/bootstrap.sh2python docs/demo_guide/rosbag_helper.py demo_3.5.bag cyber_recorder play -f docs/demo_guide/demo_3.5.record --loop

順利執(zhí)行后,打開網(wǎng)頁localhost:8888,便可以看到小車運動起來。效果如圖:

這一步官方教程寫得較為簡略,故安裝容易出錯。

1.由于官方推薦安裝NVIDIA-375版本的驅動,故先卸載原有驅動。

1sudoapt-get--purgeremovenvidia-*2sudoapt-getautoremove

若之前禁用了Nouveau,需要重新啟用Nouveau,在Blacklist中將Nouveau注釋掉。

1sudogedit/etc/modprobe.d/blacklist.conf2sudoupdate-initramfs-u3sudoreboot

開機后要確保NVIDIA驅動已經(jīng)被刪掉了,進入了低分辨率顯示。

可用lsmod | grep nouveau檢查Nouveau 是否正在運行。

2.在apollo/docker/scripts 目錄中,有一個dev_start.sh 文件,大概在它的305行加入兩條語句:

1-v/usr/src:/usr/src2-v/lib/modules:/lib/modules

效果如圖:

3.安裝NVIDIA驅動有Ppa、Run和Deb三種方式,本文推薦Ppa安裝,簡單且不容易出錯。

寫在前面,首先在NVIDIA官網(wǎng)上確定自己顯卡可以安裝的驅動版本,如RTX2080顯卡只能安裝410以上驅動。

a. 在主機里安裝NVIDIA驅動

1sudoadd-apt-repositoryppa:graphics-drivers/ppa2sudoaptsearchnvidia-3843sudoapt-getinstallnvidia-384

b. 在Docker中安裝NVIDIA驅動

1sudoadd-apt-repositoryppa:graphics-drivers/ppa2sudoaptsearchnvidia-3843sudoapt-getinstallnvidia-384

注意:Docker中NVIDIA驅動和主機中NVIDIA驅動的細分版本號(如384.130)必須保持完全一致,否則安裝失敗。

成功安裝NVIDIA驅動后,需要重新禁用nouveau。

注意:通過ppa成功安裝NVIDIA驅動后,不用再執(zhí)行第4-8點步驟。

4.這是官方推薦用run文件安裝驅動的方式:若按第3點已經(jīng)成功安裝驅動,則不用執(zhí)行4-8點步驟。

下載官方Nvidia驅動程序安裝文件,Apollo官方推薦375.39的版本

1wgethttp://us.download.nvidia.com/XFree86/Linux-x86_64/375.39/NVIDIA-Linux-x86_64-375.39.run

下載后默認放在/apollo 目錄下。

5.在終端命令行中打開啟動Docker:

按住CTRL+ALT+F1進入終端命令行 ,輸入用戶名和密碼登錄。

這一步會進入不帶圖形界面的命令行,在關閉圖形界面前,可以按CTRL+ALT+F7 在圖形界面間來回切換。

在F1的命令行中執(zhí)行:

1cdapollo2./docker/scripts/dev_start.sh3dockerexec-itapollo_dev/bin/bash

若第三步報錯,則執(zhí)行docker exec -it apollo_dev_username /bin/bash ,這里的Username指你的用戶名。

PS:在命令行中啟動Docker是為了后面關閉 圖形界面。

6.在F1的命令行Docker中安裝NVIDIA驅動程序,這一步是重中之重,很容易出錯,必須按照以下順序一步一步進行。

1source/apollo/scripts/install_gcc.sh2ln-s/usr/bin/cc/usr/bin/cc13chmod+x./NVIDIA-Linux-x86_64-375.39.run4sudo./NVIDIA-Linux-x86_64-375.39.run--no-opengl-files-a-s--no-kernel-module5source/apollo/scripts/recover_gcc.sh6rm/usr/bin/cc1

a. Apollo自帶gcc為4.8.4版本,而安裝NVIDIA驅動需要gcc4.9版本,故先執(zhí)行 install_gcc.sh 安裝gcc4.9 。

安裝完驅動后需切換回4.8.4版本,故執(zhí)行recover_gcc.sh 刪掉 gcc 4.9。

b. --no-opengl-files 這個參數(shù)非常非常重要,安裝時必須加上。

c. 在執(zhí)行NVIDIA安裝程序時應該會出現(xiàn)

‘’ X.Org X server is running ‘’ 之類的錯誤提示,出現(xiàn)之后說明我們需要關閉 圖形界面。

1sudoservicelightdmstop

執(zhí)行之后再按CTRL+ALT+F7 應該看不到圖形界面了。若在F1 的docker中關不掉圖形界面,可按CTRL+ALT+F2 后再關閉圖形界面。

d. 如果在執(zhí)行NVIDIA安裝程序時出現(xiàn)‘‘An NVIDIA kernel module ‘nvidia-drm’ appears to already be loaded in your kernel.’’之類的提示,說明之前NVIDIA驅動未卸載干凈。

e. 關閉掉圖形界面之后,再執(zhí)行

1sudo./NVIDIA-Linux-x86_64-375.39.run--no-opengl-files-a-s--no-kernel-module

可以在Docker中成功安裝驅動。

安裝完成可用

1whereisnvidia

檢查是否安裝成功。

1nvidia:/usr/src/nvidia-375.39/nvidia/usr/share/nvidia

若顯示有這兩個目錄則安裝成功,否則失敗。

7.確保成功完成以上每個步驟之后,再在主機中安裝NVIDIA 驅動。打開一個新終端:

1cdapollo2sudo./NVIDIA-Linux-x86_64-375.39.run--no-opengl-files-a-s--no-kernel-module

8.安裝好NVIDIA驅動后,執(zhí)行

1sudoservicelightdmstart

可重新啟動圖形界面。

9.在Docker中安裝好NVIDIA驅動后,千萬不能關閉正在運行的Docker,否則剛做的改動全部沒有保存。

此時在主機中新打開一個終端,執(zhí)行:

1dockerps#查看正在運行的docker2dockerimages#查看主機上的鏡像文件

此時我們需要將剛剛改動過的Docker,保存為新的鏡像文件

1dockercommitCONTAINER_IDapolloauto/apollo:NEW_DOCKER_IMAGE_TAG

其中,CONTAINER_ID為docker ps查看到的第二行第一列信息,NEW_DOCKER_IMAGE_TAG 為我們自定義保存新鏡像的名稱 ,對應于Docker Images 的第二行第二列信息。

我們按照它的命名規(guī)則對新TAG進行命名,以筆者為例,正在運行Docker的TAG 為 dev-x86_64-20181216_1500 ,命名為dev-x86_64-20181217_1500,執(zhí)行

1dockercommite5dfeb8a0b2fapolloauto/apollo:dev-x86_64-20181217_1500

則將剛剛的改動保存為新的鏡像文件,可通過Docker Images 查看新的鏡像文件。

在主機與Docker中均成功安裝NVIDIA驅動后,重啟Ubuntu。

10.新打開一個終端,進入剛剛保存的新鏡像:

1cdapollo2/docker/scripts/dev_start.sh-l-tNEW_DOCKER_IMAGE_TAG3./docker/scripts/dev_into.sh

其中,NEW_DOCKER_IMAGE_TAG為 剛剛為新鏡像取的名稱。

若啟動Docker過程中 若出現(xiàn)NVIDIA Not Found 等提示,則說明主機NVIDIA驅動未成功安裝。

11.在新鏡像中使用GPU選項構建Apollo

在正式Build之前,可用幾條指令檢查環(huán)境是否齊備:

1whereisnvidia2cat/usr/local/cuda/version.txt3dpkg-l|greplibcudnn74cat/usr/include/cudnn.h|grepCUDNN_MAJOR-A2

在主機的終端中執(zhí)行nvidia-smi 確認驅動是否正確安裝。

若所有條件均已達成,則開始編譯:

1./apollo.shbuild_gpu

若第一次使用GPU編譯,需要等待較久的時間。

13.編譯完成后,可執(zhí)行一個Demo檢查是否成功編譯GPU版本的APOLLO。

1./bazel-bin/modules/perception/camera/test/camera_lib_obstacle_detector_yolo_region_output_test

若出現(xiàn)

error while loading shared libraries: libcuda.so.1: cannot open shared object file: No such file or directory ,之類的錯誤提示,則說明Docker 或者主機的NVIDIA驅動未正確安裝。

或者直接運行所有測試

1./apollo.shtest

如果出現(xiàn)PASSED,恭喜你已經(jīng)成功編譯GPU版本的APOLLO!

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

    關注

    28

    文章

    4768

    瀏覽量

    129257
  • Ubuntu
    +關注

    關注

    5

    文章

    566

    瀏覽量

    29965
  • 自動駕駛
    +關注

    關注

    784

    文章

    13924

    瀏覽量

    166871
  • Apollo
    +關注

    關注

    5

    文章

    342

    瀏覽量

    18496

原文標題:開發(fā)者說 | Ubuntu14.04搭建GPU版本的Apollo3.5平臺

文章出處:【微信號:Apollo_Developers,微信公眾號:Apollo開發(fā)者社區(qū)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    何用mac電腦搭建云存儲,怎么用Mac電腦搭建云存儲呢?

    都能提供強大的支持。那么,如何用Mac電腦搭建云存儲呢?接下來,讓我們一同開啟這場探索之旅。 ? ?1、準備工作 ? ?硬件檢查:確保Mac電腦的硬件性能良好。處理器性能會影響數(shù)據(jù)傳輸速度,建議選擇性能較好的處理器;內(nèi)存要充足,
    的頭像 發(fā)表于 01-17 14:15 ?98次閱讀
    如<b class='flag-5'>何用</b>mac電腦<b class='flag-5'>搭建</b>云存儲,怎么用Mac電腦<b class='flag-5'>搭建</b>云存儲呢?

    超級干貨!本地搭建代碼托管平臺Gitea

    ,運行時對CPU和內(nèi)存的需求較小,適用于個人或小型團隊協(xié)作開發(fā),適合在個人電腦或資源受限的服務器上使用。2Gitea的本地搭建本次搭建環(huán)境演示系統(tǒng)為Ubuntu18
    的頭像 發(fā)表于 12-19 19:33 ?305次閱讀
    超級干貨!本地<b class='flag-5'>搭建</b>代碼托管<b class='flag-5'>平臺</b>Gitea

    百度Apollo開放平臺10.0正式發(fā)布

    12月4日,百度正式發(fā)布Apollo開放平臺的全新升級版本——Apollo開放平臺10.0,基于自動駕駛大模型ADFM設計重構算法,助力全球
    的頭像 發(fā)表于 12-04 16:20 ?439次閱讀

    企業(yè)云服務器平臺設計與搭建

    企業(yè)云服務器平臺的設計與搭建是一個復雜但系統(tǒng)的過程,涉及多個環(huán)節(jié)和因素。主機推薦小編為您整理發(fā)布企業(yè)云服務器平臺設計與搭建這一過程的詳細闡述。
    的頭像 發(fā)表于 12-04 09:51 ?135次閱讀

    GPU加速計算平臺是什么

    GPU加速計算平臺,簡而言之,是利用圖形處理器(GPU)的強大并行計算能力來加速科學計算、數(shù)據(jù)分析、機器學習等復雜計算任務的軟硬件結合系統(tǒng)。
    的頭像 發(fā)表于 10-25 09:23 ?285次閱讀

    GPU算力租用平臺是什么

    GPU算力租用平臺是一種基于云計算的服務模式,它允許用戶通過互聯(lián)網(wǎng)按需租用高性能GPU資源,而無需自行購買、部署和維護這些硬件。
    的頭像 發(fā)表于 10-16 10:15 ?290次閱讀

    Jtti:美國服務器Ubuntu系統(tǒng)中Clang的版本管理

    美國服務器在Ubuntu系統(tǒng)中,Clang的版本管理可以通過多種方式來實現(xiàn)。
    的頭像 發(fā)表于 09-21 11:28 ?294次閱讀

    嵌入式學習-搭建自己的ubuntu系統(tǒng)之ubuntu系統(tǒng)安裝

    ubuntu-18.04.5-desktop-amd64.iso”這個版本。我們已經(jīng)提供了下載好的鏡像,路徑:ELF 1開發(fā)板資料包\\06-常用工具\\06-2 環(huán)境搭建工具\\ubunt
    發(fā)表于 08-10 14:01

    搭建自己的ubuntu系統(tǒng)之ubuntu系統(tǒng)安裝

    ubuntu-18.04.5-desktop-amd64.iso”這個版本。我們已經(jīng)提供了下載好的鏡像,路徑:ELF 1開發(fā)板資料包\\06-常用工具\\06-2 環(huán)境搭建工具\\ubunt
    發(fā)表于 08-10 09:25

    嵌入式學習-搭建自己的ubuntu系統(tǒng)之創(chuàng)建ubuntu虛擬機

    搭建系統(tǒng)建議安裝英文版的ubuntu,在實際使用中編譯等操作都會遇到一些報錯,中文版存在翻譯不嚴謹,報錯信息不好搜索解決方法的問題。此外linux相關開發(fā)更多的是英文資料,建議在初學的時候就養(yǎng)成看
    發(fā)表于 08-09 15:43

    華為發(fā)布全球首個基于R18 的5G-A商用版本Apollo

    [土耳其,伊斯坦布爾,2024年7月5日] ?2024年華為用戶大會期間,華為無線網(wǎng)絡研發(fā)總裁孫銳發(fā)布了全球首個基于3GPP R18標準的5G-A商用版本Apollo。R18為5G-A提供了第一個
    的頭像 發(fā)表于 07-06 17:53 ?1944次閱讀
    華為發(fā)布全球首個基于R18 的5G-A商用<b class='flag-5'>版本</b><b class='flag-5'>Apollo</b>

    適用于 Intel? Apollo Lake 平臺的 TPS65094 PMIC數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《適用于 Intel? Apollo Lake 平臺的 TPS65094 PMIC數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 03-07 10:38 ?0次下載
    適用于 Intel? <b class='flag-5'>Apollo</b> Lake <b class='flag-5'>平臺</b>的 TPS65094 PMIC數(shù)據(jù)表

    能在Meteor Lake平臺上使用SDK 3.5嗎?

    SDK 是 3.6 版,不支持 CYPD6127 部件。 那么,我能在 Meteor Lake 平臺上使用 SDK 3.5 嗎? SDK 3.5 - 平臺選擇有"MTL&q
    發(fā)表于 03-04 06:32

    DLP3010EVM通過CY7C65215進行控制,在Ubuntu14.04和petalinux下編譯好cyusbserial SDK生成so庫文件調(diào)用API會出錯的原因?

    和訪問,但是在Ubuntu14.04和petalinux下編譯好cyusbserial SDK生成so庫文件,調(diào)用API會出錯。 我一開始編譯cyusbserial SDK使用了libusb版本
    發(fā)表于 02-28 06:27

    Ubuntu 24.04 LTS選用Linux 6.8為默認內(nèi)核

    關于Ubuntu 24.04 LTS使用何種內(nèi)核版本,一直備受關注。Canonical工程師Andrea Righi昨日宣布,Ubuntu 24.04將默認搭載Linux 6.8內(nèi)核。
    的頭像 發(fā)表于 01-29 11:27 ?1216次閱讀