在計算機視覺和深度學習領域,NCNN(Netural Network Computer Vision)是一個輕量級的神經網絡計算框架,被廣泛應用于各類嵌入式設備和移動平臺。今天,讓我們一同跟隨共創社團隊的步伐,揭秘他們如何進行NCNN的交叉編譯,并在ELF 1開發板上演繹實踐,以此驗證模型推理性能。
1、從GitHub下載NCNN源碼:https://github.com/Tencent/ncnn
2、將ncnn-master.zip拷貝到開發環境的/home/elf/work目錄下并解壓:
elf@ubuntu:~/work$ unzip ncnn-master.zip
3、配置CMake:
elf@ubuntu:~/work$ cd ncnn-master/toolchains/ elf@ubuntu:~/work/ncnn-master/toolchains$ vi arm-poky-linux-gnueabi.cmake
將下面的內容添加到arm-poky-linux-gnueabi.cmake文件中:
set(CMAKE_SYSTEM_NAME Linux) set(CMAKE_SYSTEM_PROCESSOR arm) set(CMAKE_C_COMPILER "arm-poky-linux-gnueabi-gcc") set(CMAKE_CXX_COMPILER "arm-poky-linux-gnueabi-g++") set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) set(CMAKE_C_FLAGS "-march=armv7-a -mfloat-abi=hard --sysroot=/opt/fsl-imx-x11/4.1.15-2.0.0/sysroots/cortexa7hf-neon-poky-linux-gnueabi") set(CMAKE_CXX_FLAGS "-march=armv7-a -mfloat-abi=hard --sysroot=/opt/fsl-imx-x11/4.1.15-2.0.0/sysroots/cortexa7hf-neon-poky-linux-gnueabi") # cache flags set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS}" CACHE STRING "c flags") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}" CACHE STRING "c++ flags")
4、編譯:
elf@ubuntu:~/work/ncnn-master$ mkdir build elf@ubuntu:~/work/ncnn-master$ cd build/ elf@ubuntu:~/work/ncnn-master/build$ . /opt/fsl-imx-x11/4.1.15-2.0.0/environment-setup-cortexa7hf-neon-poky-linux-gnueabi elf@ubuntu:~/work/ncnn-master/build$ cmake -DCMAKE_TOOLCHAIN_FILE=../toolchains/arm-poky-linux-gnueabi.cmake -DNCNN_SIMPLEOCV=ON -DNCNN_BUILD_EXAMPLES=ON -DCMAKE_BUILD_TYPE=Release .. elf@ubuntu:~/work/ncnn-master/build$ make
5、將編譯完成得到的benchmark文件夾(build目錄下)和項目文件夾下的benchmark文件夾打包并放到U盤里:
elf@ubuntu:~/work/ncnn-master/build$ tar cvjf benchmark.tar.bz2 benchmark/ ../benchmark/
6、將U盤插入到ELF 1開發板上,拷貝壓縮包到/home/root路徑下并解壓:
root@ELF1:~# cp /run/media/sda1/benchmark.tar.bz2 . root@ELF1:~# tar xvf benchmark.tar.bz2
7、測試:
root@ELF1:~# cd benchmark/ root@ELF1:~/benchmark# ./benchncnn
觀察結果顯示,絕大部分模型均已成功運行,其中所展示的數字指標代表了各自的執行耗時。需注意,數值越小,意味著推理過程的完成速度越快。
通過這次實踐,共創社不僅展示了NCNN在嵌入式設備上的靈活性與強大性能,還向我們揭示了深度學習嵌入式技術落地的無限可能,更激勵著每一位嵌入式探索者:無論面對何種挑戰,只要勇于探索、精于實踐,便能在嵌入式技術的海洋中乘風破浪,開辟出一片屬于自己的天地。
-
單片機
+關注
關注
6037文章
44563瀏覽量
635846 -
嵌入式
+關注
關注
5085文章
19137瀏覽量
305670 -
移植
+關注
關注
1文章
379瀏覽量
28144 -
開發板
+關注
關注
25文章
5067瀏覽量
97588
發布評論請先 登錄
相關推薦
評論