NVIDIA Jetson TX1 系列开发教程之五:CAFFE安装与NVIDIA多媒体例程测试

本文主要是介绍NVIDIA Jetson TX1 系列开发教程之五:CAFFE安装与NVIDIA多媒体例程测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

NVIDIA Jetson TX1 系列开发教程之五:CAFFE安装与NVIDIA多媒体例程测试


  • 转载请注明作者和出处:http://blog.csdn.net/u011475210
  • 嵌入式平台:NVIDIA Jetson TX1
  • 嵌入式系统:Ubuntu16.04
  • 虚拟机系统:Ubuntu14.04
  • 编者: WordZzzz

写在前面的前面:
之前就已经在实验室的深度学习服务器上安装过CAFFE/SSD,由于当时深度学习服务器管理不佳,多人混用造成好多依赖环境删删减减,经常会出现今天装的CAFFE/SSD明天就不能用的情况,所以难免多折腾几次。因此,博主对他们的安装还是颇有研究的。
大家用NVIDIA Jetson TX1,无非就是看上了它的计算能力,能跑深度学习框架。由于NVIDIA Jetson TX1容量有限,所以建议大家需要哪个就安装哪个。偏向于学习,就安装纯版本的CAFFE,偏向于应用测试,就安装各个基于CAFFE的升级版,比如SSD。

写在前面:
本博文原打算以CAFFE/SSD为例,介绍如何在NVIDIA Jetson TX1上安装CAFFE/SSD,但是最近自己又安装了一遍,发现本博文的步骤不全面,导致python大部分依赖环境都没装上,这样的结果就是jupyter notebook这种工具用不了。所以本篇博文在此只介绍CAFFE安装和基于CAFFE的NVIDIA多媒体例程测试。

安装过程:

1.用以下命令安装依赖包:

$ sudo add-apt-repository universe
$ sudo add-apt-repository multiverse
$ sudo apt-get update
$ sudo apt-get install libboost-all-dev libprotobuf-dev libleveldb-dev libsnappy-dev
$ sudo apt-get install libhdf5-serial-dev protobuf-compiler libgflags-dev libgoogle-glog-dev
$ sudo apt-get install liblmdb-dev libblas-dev libatlas-base-dev

2.下载CAFFE源码安装包从如下网站:

CAFFE:https://github.com/BVLC/caffe.git

$ git clone https://github.com/BVLC/caffe.git

3设置路径并解压:
a.如果在步骤2中选择自己从网页手动下载zip文件,则进行如下操作:
CAFFE:

$ mkdir -pv $HOME/Work/caffe
$ cp caffe-master.zip $HOME/Work/caffe/
$ cd $HOME/Work/caffe/ && unzip caffe-master.zip

b.如果在步骤2中直接git得到caffe文件,则进行如下操作:

$ mv caffe $HOME/Work/caffe/caffe-master

4.编译CAFFE源码:
CAFFE:

$ cd $HOME/Work/caffe/caffe-master
$ cp Makefile.config.example Makefile.config
$ vi Makefile.config

去掉下面该行代码的注释:

USE_CUDNN := 1

重点来了,在Makefile.config中找到下面这几行:

CUDA_ARCH := -gencode arch=compute_30,code=sm_30 \-gencode arch=compute_35,code=sm_35 \
        -gencode arch=compute_50,code=sm_50 \
        -gencode arch=compute_52,code=sm_52 \
        -gencode arch=compute_60,code=sm_60 \
        -gencode arch=compute_61,code=sm_61 \
        -gencode arch=compute_61,code=compute_61

更改为:

CUDA_ARCH := -gencode arch=compute_53,code=sm_53

这里的后缀数字53是TX1的计算能力,在其他平台上编译CAFFE也是同样的道理,要把计算能力改成对应的值,否则有可能会报错。关于计算能力如何确定,CUDA例程里面有测试程序,跑一下就可以输出GPU性能指标。

声明下面这两行路径,保存后退出:

INCLUDE_DIRS := $(PYTHON_INCLUDE) /usr/local/include /usr/include/hdf5/serial
LIBRARY_DIRS := $(PYTHON_LIB) /usr/local/lib /usr/lib /usr/lib/aarch64-linux-gnu/hdf5/serial
$ make -j4

完成后在build/lib目录下会出现库文件libcaffe.so。

$ make all -j4
$ make runtest -j4
$ make pycaffe -j4

5.编译opencv用户库
这个库是CAFFE所必需的。而且只能在目标板上编译。

$ cd ~/tegra_multimedia_api/samples/11_camera_object_identification/opencv_consumer_lib

检查并确保正确设置makefile以下变量:

CUDA_DIR:=/usr/local/cuda
CAFFE_DIR:=$HOME/Work/caffe/caffe-master

编译:

$ make

完成后当前目录下会出现库文件 libopencv_consumer.so

  1. 通过下面的命令下载CAFFE模型二进制文件:
$ sudo apt-get install python-pip
$ sudo pip install pyyaml
$ cd $HOME/Work/caffe/caffe-master
$ ./scripts/download_model_binary.py models/bvlc_reference_caffenet/

用下面的命令获得ImageNet标签文件:

$ ./data/ilsvrc12/get_ilsvrc_aux.sh
  1. 使用下列命令生成和运行示例:
$ cd ~/tegra_multimedia_api/samples/11_camera_object_identification
$ export TEGRA_ARMABI=aarch64-linux-gnu
$ export DISPLAY=:0
$ make
$ export LD_LIBRARY_PATH=$HOME/Work/caffe/caffe-master/build/lib:/usr/local/cuda/lib64
$ ./camera_caffe -width 1920 -height 1080 \-lib opencv_consumer_lib/libopencv_consumer.so \-model $HOME/Work/caffe/caffe-master/models/bvlc_reference_caffenet/deploy.prototxt \-trained $HOME/Work/caffe/caffe-master/models/bvlc_reference_caffenet/bvlc_reference_caffenet.caffemodel \-mean $HOME/Work/caffe/caffe-master/data/ilsvrc12/imagenet_mean.binaryproto \-label $HOME/Work/caffe/caffe-master/data/ilsvrc12/synset_words.txt

8、环境变量设置
1.在终端执行如下指令:

sudo vim ~/.bashrc

2.在最后一行添加caffe的python路径

export PYTHONPATH=$HOME/Work/caffe/caffe-master/python:$PYTHONPATH

然后加上之前声明的环境变量,这样就不用每次make或者运行的时候再次声明环境变量了。

export TEGRA_ARMABI=aarch64-linux-gnu
export DISPLAY=:0
export LD_LIBRARY_PATH=$HOME/Work/caffe/caffe-master/build/lib:/usr/local/cuda/lib64

3.source环境变量,在终端执行如下命令:

source ~/.bashrc

系列教程持续发布中,欢迎订阅、关注、收藏、评论、点赞哦~~( ̄▽ ̄~)~

完的汪(∪。∪)。。。zzz

这篇关于NVIDIA Jetson TX1 系列开发教程之五:CAFFE安装与NVIDIA多媒体例程测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1044761

相关文章

Java中的登录技术保姆级详细教程

《Java中的登录技术保姆级详细教程》:本文主要介绍Java中登录技术保姆级详细教程的相关资料,在Java中我们可以使用各种技术和框架来实现这些功能,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录1.登录思路2.登录标记1.会话技术2.会话跟踪1.Cookie技术2.Session技术3.令牌技

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优

conda安装GPU版pytorch默认却是cpu版本

《conda安装GPU版pytorch默认却是cpu版本》本文主要介绍了遇到Conda安装PyTorchGPU版本却默认安装CPU的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、问题描述二、网上解决方案罗列【此节为反面方案罗列!!!】三、发现的根本原因[独家]3.1 p

Java Spring 中的监听器Listener详解与实战教程

《JavaSpring中的监听器Listener详解与实战教程》Spring提供了多种监听器机制,可以用于监听应用生命周期、会话生命周期和请求处理过程中的事件,:本文主要介绍JavaSprin... 目录一、监听器的作用1.1 应用生命周期管理1.2 会话管理1.3 请求处理监控二、创建监听器2.1 Ser

windows系统上如何进行maven安装和配置方式

《windows系统上如何进行maven安装和配置方式》:本文主要介绍windows系统上如何进行maven安装和配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. Maven 简介2. maven的下载与安装2.1 下载 Maven2.2 Maven安装2.

Redis指南及6.2.x版本安装过程

《Redis指南及6.2.x版本安装过程》Redis是完全开源免费的,遵守BSD协议,是一个高性能(NOSQL)的key-value数据库,Redis是一个开源的使用ANSIC语言编写、支持网络、... 目录概述Redis特点Redis应用场景缓存缓存分布式会话分布式锁社交网络最新列表Redis各版本介绍旧

Linux下安装Anaconda3全过程

《Linux下安装Anaconda3全过程》:本文主要介绍Linux下安装Anaconda3全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录简介环境下载安装一、找到下载好的文件名为Anaconda3-2018.12-linux-x86_64的安装包二、或者通

MySQL 安装配置超完整教程

《MySQL安装配置超完整教程》MySQL是一款广泛使用的开源关系型数据库管理系统(RDBMS),由瑞典MySQLAB公司开发,目前属于Oracle公司旗下产品,:本文主要介绍MySQL安装配置... 目录一、mysql 简介二、下载 MySQL三、安装 MySQL四、配置环境变量五、配置 MySQL5.1