基於樹莓派與YOLOv3模型的人體目標檢測小車(一)
- 2020 年 3 月 31 日
- 筆記
項目介紹:
本科畢業選的深度學習的畢設,一開始只是學習了一下YOLOv3模型, 按照作者的指示在官網上下載下來權重,配好環境跑出來Demo,後來想著只是跑模型會不會太單薄,於是想了能不能做出來個比較實用的東西(因為模型優化做不了)。於是乎做一個可以檢測人體的可操控移動小車的想法就誕生了。
實現的功能:1. 控制小車行進,並實時檢測人體目標。
2. 作為家庭監控,可以將出現在攝影機中的人體目標通過微信發到手機上,並可以人為決定是否通過蜂鳴器發出警報。
大致的工作包括:1. YOLOv3 tiny 模型的訓練
2. Darknet模型到tensorflow模型再到NCS(神經計算加速棒)模型的兩次轉化
3. 小車控制以及影片流直播程式
4. 微信報警程式
一 、環境搭建
一、安裝NVIDIA顯示卡驅動
1.刪除舊的驅動。
原來Linux默認安裝的顯示卡驅動不是NVIDIA 的驅動,所以先把舊得驅動刪除掉。
sudo apt-get purge nvidia*
2.禁止自帶的nouveau nvidia驅動。
2.1 打開配置文件:
sudo gedit /etc/modprobe.d/blacklist-nouveau.conf
2.2填寫禁止配置的內容:
blacklist nouveau``options nouveau modeset=0
2.3更新配置文件:
sudo update-initramfs -u
重啟電腦!
2.4檢查設置
(因為禁止了顯示卡的驅動,這時你的電腦解析度會變成800*600,圖標格式將會很不和諧,當然通過這個可以看出,是否完成這上面的操作)
lsmod | grep nouveau
*如果螢幕沒有輸出則禁用nouveau成功
3 正式安裝
法一:ppa源安裝(原生安裝)
1.添加Graphic Drivers PPA
sudo add-apt-repository ppa:graphics-drivers/ppa``sudo apt-get update
2.查看合適的驅動版本:
ubuntu-drivers devices
3.在這裡我選擇合適的396版本:
sudo apt-get install nvidia-driver-396
重啟電腦!
4.安裝成功檢查:
sudo nvidia-smi``sudo nvidia-settings
*最直接的方法是進入到系統的「軟體和更新」,點擊進入到「附加驅動」,選擇你需要安裝的NVIDIA 驅動,然後點擊「應用更改」,便能進行安裝了。注意的是這個方法適合網速較好的環境下進行。
二、安裝CUDA
1、官網下載:https://developer.nvidia.com/cuda-90-download-archive
我的如下:
2、安裝依賴庫
sudo apt-get install freeglut3-dev build-essential libx11-dev libxmu-dev libxi-dev libgl1-mesa-glx libglu1-mesa libglu1-mesa-dev
否則將會報錯:
3、注意C++G++版本
CUDA9.0要求GCC版本是5.x或者6.x,其他版本不可以,需要自己進行配置,通過以下命令才對gcc版本進行修改。
查看版本:
g++ --version
版本安裝:
sudo apt-get install gcc-5 sudo apt-get install g++-5
通過命令替換掉之前的版本:
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-5 50 sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-5 50
最後記得再次查看版本是否修改成功。
4、運行run文件
sudo sh cuda_9.0.176_384.81_linux.run
安裝協議可以直接按q跳到最末尾,注意一項:
Install NVIDIA Accelerated Graphics Driver for Linux-x86_64 384.81? (y)es/(n)o/(q)uit: n # 安裝NVIDIA加速圖形驅動程式,這裡選擇n
5、添加環境變數
進行環境的配置,打開環境變數配置文件
sudo gedit ~/.bashrc
在末尾把以下配置寫入並保存:
#CUDA export PATH=/usr/local/cuda-9.0/bin${PATH:+:${PATH}} export LD_LIBRARY_PATH=/usr/local/cuda-9.0/lib64${LD_LIBRARY_PATH:+:${LD_LIBRARY_PATH}}
最後執行:
source ~/.bashrc
6、安裝測試
在安裝的時候也也相應安裝了一些cuda的一些例子,可以進入例子的文件夾然後使用make命令執行。
例一:
1.進入例子文件
cd /usr/local/cuda-8.0/samples/1_Utilities/deviceQuery
2.執行make命令
sudo make
3. 第三步
./deviceQuery
如果結果有GPU的資訊,說明安裝成功。
例二:
1. 進入例子對應的文件夾
cd NVIDIA_CUDA-9.0_Samples/5_Simulations/fluidsGL
2.執行make
make clean && make
3. 運行
./fluidsGL
當執行這個例子,我們會看到流動的圖,剛開始可能看不到黑洞,需要等待一小段時間。不過記得用滑鼠點擊下綠色的畫面。
三、安裝cuDNN
1、官網下載:https://developer.nvidia.com/rdp/form/cudnn-download-survey
這個需要註冊帳號,拿自己的郵箱註冊即可。
只需下載下面3個安裝包即可
2、順序執行下面3個安裝命令:
sudo dpkg -i libcudnn7_7.0.3.11-1+cuda9.0_amd64.deb``sudo dpkg -i libcudnn7-dev_7.0.3.11-1+cuda9.0_amd64.deb``sudo dpkg -i libcudnn7-doc_7.0.3.11-1+cuda9.0_amd64.deb
3、安裝測試
輸入以下命令:
cp -r /usr/src/cudnn_samples_v7/ $HOME``cd $HOME/cudnn_samples_v7/mnistCUDNN``make clean && make``./mnistCUDNN
最終如果有提示資訊:「Test passed! 」,則說明安裝成功!
四、安裝TensorFlow
1.pip直接安裝
pip install tensorflow_gpu-1.9.0
五、安裝darknet
打開YOLOv3官網,https://pjreddie.com/darknet/,按著教程一步一步的照做。
-
把項目克隆到本地,編譯
git clone https://github.com/pjreddie/darknet cd darknet make
-
下載已經訓練好的yolov3權重,或者直接wget,如果下載速度太慢可以去百度找一下。
wget https://pjreddie.com/media/files/yolov3.weights
-
下載完之後就可以使用權重模型來進行測試了。
./darknet detect cfg/yolov3.cfg yolov3.weights data/dog.jpg
這裡不會彈出來檢測的圖片是因為沒有安裝OpenCV,檢測的結果會在項目文件夾下生成predictions.png.
-
如果你有攝影機,你也可以直接通過影片測試模型
./darknet detector demo cfg/coco.data cfg/yolov3.cfg yolov3.weights
六、總結
至此已完成了,模型訓練端的環境搭建,下一篇文章將介紹如何利用YOLOv3模型訓練自己的數據集。