在計算機視覺和深度學(xué)習(xí)領(lǐng)域,NCNN(Netural Network Computer Vision)是一個輕量級的神經(jīng)網(wǎng)絡(luò)計算框架,被廣泛應(yīng)用于各類嵌入式設(shè)備和移動平臺。今天,讓我們一同跟隨共創(chuàng)社團隊的步伐,揭秘他們?nèi)绾芜M行NCNN的交叉編譯,并在ELF 1開發(fā)板上演繹實踐,以此驗證模型推理性能。
1、從GitHub下載NCNN源碼:https://github.com/Tencent/ncnn
2、將ncnn-master.zip拷貝到開發(fā)環(huán)境的/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
將下面的內(nèi)容添加到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開發(fā)板上,拷貝壓縮包到/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
觀察結(jié)果顯示,絕大部分模型均已成功運行,其中所展示的數(shù)字指標代表了各自的執(zhí)行耗時。需注意,數(shù)值越小,意味著推理過程的完成速度越快。
通過這次實踐,共創(chuàng)社不僅展示了NCNN在嵌入式設(shè)備上的靈活性與強大性能,還向我們揭示了深度學(xué)習(xí)嵌入式技術(shù)落地的無限可能,更激勵著每一位嵌入式探索者:無論面對何種挑戰(zhàn),只要勇于探索、精于實踐,便能在嵌入式技術(shù)的海洋中乘風(fēng)破浪,開辟出一片屬于自己的天地。
-
單片機
+關(guān)注
關(guān)注
6032文章
44525瀏覽量
633245 -
嵌入式
+關(guān)注
關(guān)注
5071文章
19026瀏覽量
303494 -
移植
+關(guān)注
關(guān)注
1文章
377瀏覽量
28111 -
開發(fā)板
+關(guān)注
關(guān)注
25文章
4959瀏覽量
97214
發(fā)布評論請先 登錄
相關(guān)推薦
評論