要点初见:从零开始进行妙算manifold、Jetson TK1环境配置
此文初写于2017.3.12,因为当时反复对妙算Manifold、Jetson TK1刷机因此总结出了一套套路……嗯,如今年末整理一波。
妙算是大疆无人机上的机载miniPC,其中的核心板是NVIDIA的嵌入式视觉板Jetson Tegra K1。网上关于妙算环境配置的博文特别少,TK1的比较多,本文中关于妙算的配置部分是笔者在参考网上TK1的配置方法摸索总结出来的。Jetson Tegra K1的环境安装有两种方法,一种是在一台装有Linux系统的X86电脑(不能在ARM平台)上运行对应Jetson TK1版本的Jetpack,将电脑与TK1连接到同一联网的路由器上,进行自动安装;另一种是在ubuntu中用命令手动安装配置这些环境。也许在TK1快过时,大疆半放弃manifold,大家都换装Jetson TX2的当下,TK1与manifold的配置不受关注,但笔者还是打算记录一下半年前的这套顺畅的两小时配置流程。
一、安装主要项
1、CUDA6.5
2、OpenCV3.1.0
3、ROS-Indigo
4、codeblocks和CUDA的nvcc编译器
二、环境配置须知
1、这是经过四台妙算和一台Jetson Tegra K1环境配置后得到的通用环境配置方法,大部分操作都可原样复制;
2、若出现此处未提到的问题,可通过简单的百度直接解决;
3、若遇到的问题较复杂,可猜测这台妙算(或Jetson TK1)之前进行过一些操作,考虑重新刷机后重新用此处的方法进行配置:
妙算刷机包官方下载链接:https://dl.djicdn.com/downloads/manifold/manifold_image_v1.0.tar.gz
Jetson TK1刷机包:用Jetpack3.0(推荐,注意不要用更新的版本的jetpack,因为里面不包含TK1)或者按这位博主写的操作:http://blog.csdn.net/deyili/article/details/51011836;
4、文件放到妙算或Jetson上后其中的中文很可能是乱码,火狐浏览器自带的必应搜索大概率提供国外论坛,所以还是学好英语(嗯……并使用百度网页翻译)最重要;
三、刷机流程
(需联网,熟练后时间大概只需两个小时)
1、更换妙算或Jetson中自带的更新源(自带的源居然不是ARM源,若更新会出错,更换成国内的ARM源后速度飞快):(1)在“终端”中输入:sudo gedit /etc/apt/sources.list
因为使用了sudo,系统会要求输入密码,妙算或Jetson的初始密码是ubuntu,输入密码的时候linux系统不会显示你输入了什么,仿佛什么都没输入一样。
如果保守也可以先 sudo cp /etc/apt/sources.list /etc/apt/sources.list.backup来备份原来的更新源;不想用gedit简单地编辑文本的话,也可用sudo vi /etc/apt/sources.list通过VIM编辑文本。(此处需自学Linux中vim的使用,之后的修改环境变量处也要用到;简单说就是光标移到需要修改的地方,按下o或者a进行修改,修改后按esc,再输入:wq完成保存退出返回到命令窗口)
(2)把打开的窗口中所有的内容删去,并替换成:
deb http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty main multiverse restricted universe
deb http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty-backports main multiverse restricted universe
deb http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty-proposed main multiverse restricted universe
deb http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty-security main multiverse restricted universe
deb http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty-updates main multiverse restricted universe
deb-src http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty main multiverse restricted universe
deb-src http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty-backports main multiverse restricted universe
deb-src http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty-proposed main multiverse restricted universe
deb-src http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty-security main multiverse restricted universe
deb-src http://mirrors.ustc.edu.cn/ubuntu-ports/ trusty-updates main multiverse restricted universe
保存并关闭窗口,回到命令窗口。
(3)在“终端”中输入:sudo apt-get update
2、在“终端”中输入:sudo apt-get install build-essential cmake,在执行后输入y,回车(下文中类同)
3、输入sudo apt-get install codeblocks codeblocks-contrib geany
(1)其中codeblocks(以上操作下载到的版本截至2017.3.12为13.12)是妙算编程中不得不使用的一个自动补全有BUG,添加编译器需要用sudo codeblocks打开并修改否则关闭后配置就无效的IDE(修改注释的颜色后,注释能够折叠;通过右键左侧项目名,选择build option来进行第三方库路径的添加(比如opencv));若想用QT,需要编译非常长的时间,同时也会被占用了非常大的空间,而且运行相同的程序速度比codeblocks要慢,环境变量不易输入。eclipse则没用过,也没见网上有人在arm上用过;
(2)codeblocks-contrib是codeblocks的扩展功能包,其中双击变量名或者API能够同时标红所有同名内容的功能特别好用;
(3)geany是仿造编译器文本的txt文档管理器,方便用codeblocks编程时查看其他的.cpp内容(codeblocks里同时打开两个codeblocks项目会很混乱)。
4、 安装CUDA6.5(20分钟)
++先介绍一个快速cd到某目录的简易方法:输入cd空格后,将对应目录的文件夹拖动到终端中,回车。妙算和jetson外的系统不一定有这个功能(比如笔者虚拟机里的ubuntu)
(1)cd到CUDA6.5下载包所在目录,在终端执行命令:sudo dpkg -i cuda-repo-l4t-r21.2-6-5-prod_6.5-34_armhf.deb(后部可按Tab自动补全,此功能妙算、Jetson自带);
(2)在终端执行命令:sudo apt-get update,若无此步,后几步很可能会出现谜之问题;
(3)在终端执行命令:sudo apt-get install cuda-toolkit-6-5(此步需要下载1G文件,请确保有足够空间且网络畅通)
在终端执行如下命令:sudo usermod -a -G video $USER
vi ~/.bashrc(此步用sudo gedit ~/.bashrc更方便)
在环境变量文件~/.bashrc末按O加入:
# Add CUDA bin & library paths:
export PATH=/usr/local/cuda/bin:$PATH
export LD_LIBRARY_PATH=/usr/local/cuda/lib:$LD_LIBRARY_PATH
按esc输入:wq退出后,在终端执行如下命令:
source ~/.bashrc
(此处可能会出现某cuda-toolkit文件下载安装失败的error,可使用wget + (该文件下载链接), dpkg -i 该.dev文件名, sudo apt-get install 该.dev文件名 来进行解决)
(4)在终端输入nvcc -V(注意此处V为大写),若显示CUDA版本信息则表示编译成功。
5、 安装OpenCV3.1.0(40分钟)
OpenCV是一个当下非常火热的开源视觉库,大量地应用于工业领域。近来随着大数据、人工智能的火热,更是成为视觉算法的掌上明珠。
TK1可以使用Jetpack提供的TK1专用的OpenCV4Tegra2.4.10.2,但需要用Jetpack自动安装(且需勾选Jetpack中的所有选项),若自行用命令行安装OpenCV4Tegra,则会出现一修改摄像头分辨率就报错,且无法修改默认的640*480分辨率的问题(因为OpenCV4Tegra没有交叉编译V4L);
OpenCV3.0.0太原始且安装出错问题多;更高版本的OpenCV没试过。具体操作如下:
(1)在终端中输入:
sudo apt-get update(养成及时更新的好习惯)sudo apt-get install git checkinstall pkg-config libtiff4-dev libjpeg-dev libjasper-dev libavcodec-dev libavformat-dev libswscale-dev libv4l-dev libv4l-0 python-numpy libgtk2.0-dev v4l-utils libeigen3-dev libdc1394-22-dev(注意千万别在此处下载TBB的包,会出现无法自动添加IT的迷之问题,需要-Wa之类至今没搞懂,只有英文论坛资料的解决方法)
(2)漫长的编译时间
在终端中输入:mkdir release
cd release
sudo apt-get install cmake-qt-gui(安装cmake-gui)
cmake-gui(千万别sudo cmake-gui,不然cmake的全部文件都会带上权限……你会哭出来的)
无论如何,先勾选CUBLAS和CUDA_FAST_MATH;确保WITH_V4L的勾勾上;
如果你要使用TBB来加速自己的OpenCV(把#define HAVE_TBB加在你程序所有OpenCV的include的最前面,加后面无效),勾选BUILD_TBB, WITH_TBB(此处会自动下载不会出错的TBB包);如果你不需要且没有安装过FFMPEG,取消掉FFMPEG的勾;VTK的勾可去掉。
点击下方左侧左边的configure,读条后若主框中有显示为红色的条目,则需要对条目进行修改。
若无红色条目,点击下方左侧右边的generate,检查cmake的输出,确认CUDA和CUBLAS等将被安装(不然……你OpenCV的GPU编程可能就不见了):
-- Use Cuda: YES (ver 6.5)
-- Use OpenCL: YES
--
-- NVIDIA CUDA
-- Use CUFFT: YES
-- Use CUBLAS: YES
-- USE NVCUVID: NO
-- NVIDIA GPU arch: 32
-- NVIDIA PTX archs:
-- Use fast math: YES
若是万事俱备,在终端中输入:
make -j4(妙算或Jetson TK1就四核CPU,若输入make -j,你的ARM很可能会自动关机;此处需要至少30分钟)sudo make install (此处可能很快)
如果使用pkgconfig,需要修改环境变量,在终端输入(其实可以直接Ctrl+C,在终端里右键粘贴╮(╯▽╰)╭):
echo '/usr/local/lib' | sudo tee -a /etc/ld.so.conf.d/opencv.conf
sudo ldconfig
printf '# OpenCV\nPKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/lib/pkgconfig\nexport PKG_CONFIG_PATH\n' >> ~/.bashrc
source ~/.bashrc
6、安装ros-indigo
ROS是一个用于集成传感器信息的机器人系统,当下机器人、无人机、无人驾驶都会用到该系统,甚至深度学习的python模型也可以通过ROS实现与C++的关联,从而移交OpenCV进行后续处理。
此处主要参考http://www.jianshu.com/p/997ede860d74中所述的方式(绝不能照搬):
(1)在终端中输入:
sudo apt-get install gitgit clone https://github.com/jetsonhacks/installROS.git
cd installROS
(2)复制一份installROS.sh,并命名为installROSModified.sh。打开installROSModified.sh,千万不要更改源,仍使用默认源。在Environment Setup中添加:
#Using RVIZecho "unset GTK_IM_MODULE" >> ~/.bashrc
添加在source ~/.bashrc前一行,保存关闭。
(3)在终端中的该目录下输入:./installROSModified.sh,若出现Pemission Denied的问题,则输入sudo chmod a+x installROSModified.sh给予权限后,./installROSModified.sh。(其他地方出现./*权限不足时也可用该方法解决)
(4)最后新打开一个终端(在终端上右键,New Teminal),输入roscore,若显示版本则表示安装成功。若显示Command no found,则说明你的内心不够虔诚……在~/.bashrc末行输入source /opt/ros/indigo/setup.bash,保存关闭source ~/.bashrc后再来一次roscore。
如果你的内心足够虔诚,你可以选择在ROS安装成功后,在终端中再输入sudo apt-get install ros-indigo-urdf ros-indigo-urdf-parser-plugin ros-indigo-urdf-tutorial ros-indigo-urdfdom-py ros-indigo-navigation ros-indigo-navigation-layers ros-indigo-depthimage-to-laserscan ros-indigo-openni* ros-indigo-kobuki* ros-indigo-turtlebot-bringup ros-indigo-turtlebot-create,绝对会有某三个库出错的,可惜笔者内心不够虔诚,,就一直没去找解决方法……
(5)ROS真的对你那么好?你输入sudo apt-get update也许就能发现 ROS可能破坏了你的更新源,那么你需要在终端中输入:sudo rm /var/lib/apt/lists/* -vf
sudo apt-get update
7、设置codeblocks和CUDA的nvcc编译器
方法主要源自http://blog.csdn.net/fdqw_sph/article/details/53787658,本文此处大部分搬运自原文。
请在sudo codeblocks下操作,否则你创建的新编译器活不过你下一次的codeblocks启动!(这一点全网一个字都没提到过,是某位大神的探索成果,配置者也如淋甘霖)
(1)点击CodeBlocks 菜单栏上的Settings --> Compiler and debugger
在上方的Selected compiler中,确定“GNU GCC Compiler”被选中,然后点击下面的Copy按钮,以新建一个编译器配置
输入编译器名字,比如"NVIDIA NVCC CUDA Compiler"
弹出的窗口全部点击“Yes”等,然后选择下面的Toolchain executables标签页,如果看不到,点一下向右的箭头
输入nvcc的安装路径,比如/opt/local/cuda
再下面的C compiler输入:nvcc
C++ compiler: nvcc
Linker for dynamic libs: nvcc
Likner for static libs: nvcc
Debugger: cuda-gdb?(没有试过,配置者是保持原样)
点击Search directories标签页,在Compiler box中加入usr/local中cuda和cuda6.5的include文件夹
在Linker box中加入 cuda6.5中lib的cudart.so 和 cuda中lib的curand.so(怀疑这两库像opencv2/opencv.hpp一样包括了所有CUDA库)
点击标签栏旁边的向右箭头,直到滚动到Other settings
点击下面的Advanced options按钮,在弹出的警告窗口中点击Yes
在Commands标签页中选择Compile single file to object file,然后把Command line macro中的内容替换成:
$compiler --compiler-options "$options" $includes -c $file -o $object
在Output parsing标签页中选择Instantiated from info,然后把Regular expression中的内容替换成:
([][{}() #%$~A-Za-z0-9_:+//.-]+)[(:]([0-9]+)/)?:[ ]+([iI]nstantiated from .*)
选择Compiler warning,然后把regular expression中的内容替换成:
([][{}() #%$~A-Za-z0-9_:+//.-]+)[(:]([0-9]+)/)?:[ ]([Ww]arning:[ ].*)
选择Compiler error,然后把regular expression中的内容替换成:
([][{}() #%$~A-Za-z0-9_:+//.-]+)[(:]([0-9]+)/)?:[ ](.*)
(2)下面让CodeBlocks 能够认出CUDA的源代码文件:*.cu :
在菜单上点击Project --> Project tree --> Edit file types & categories
点击Add按钮
输入类别名,如“CUDA Sources”
在下面的fire masks中输入: *.cu;
(3)接下来,还需要作一些小设定,使得cu源代码文件能够被编译器所编译链接:
*注意:只能对需要编译的.cu文件进行以下步骤,而那些被其他文件所include的头文件不需要做这些设定
在左边项目文件关系树的.cu文件上点击右键,然后点击Propertiies
在Build标签页中,选中Compile file 和 Link file
Ok,所有设置完成,现在便可以在CodeBlocks 中编写CUDA应用,然后直接按F9或点击按钮进行Build了。
注意,SDK的例子中,很多需要链接cutil库,记得要在Project --> Build options里面的Link libraries中加入这个库,当然,也可以在gblobal compiler settings里面加入。(不过编译者没这么做似乎还没遇到问题)
译注: CodeBlocks 是一个十分优秀的开源跨平台IDE,现在用户越来越多,经过上述配置,Linux环境下我们不用每次在command line中输入nvcc ........这样来编译项目,同时,也可以很方便的将CUDA引入原有项目中进行整合,编译。
注意: 项目的Build Options中,一定要把编译器选择为新建的CUDA NVCC Compiler,否则将还是使用普通的C/C++编译器来编译项目。修改后,整个项目的所有代码将首先通过nvcc编译器,nvcc会作出判断该文件是C/C++文件还是cu文件,如果是C/C++代码文件,nvcc会自动将该文件转交给GCC处理,如果是cu文件,nvcc会按照nvcc编译规则,分离其中的host和device代码,然后进行编译。如果对nvcc编译过程的细则感兴趣,请参考NVIDIA的 《nvcc_版本号.pdf》,该文档在NVIDIA CUDA网站 有下载,也可以在安装的CUDA路径中的doc文件夹中找到。
如果在Linux环境下,使用上述配置方法不能成功生成CUDA项目,请检查GCC编译器以及CUDA Toolkit和CUDA SDK是否正确安装和配置。
若CUDA库不被系统所默认搜索,输入:sudo ldconfig /usr/local/cuda-6.5/lib,将CUDA库设为动态链接库。
8、以上为全套配置方法,参考的博客不限于:
http://blog.csdn.net/deyili/article/details/51011959
http://blog.csdn.net/fdqw_sph/article/details/53787658
等等。
欢迎指正!
更多推荐
所有评论(0)