博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
NVIDIA DIGITS 学习笔记(NVIDIA DIGITS-2.0 + Ubuntu 14.04 + CUDA 7.0 + cuDNN 7.0 + Caffe 0.13.0)...
阅读量:5042 次
发布时间:2019-06-12

本文共 8799 字,大约阅读时间需要 29 分钟。

NVIDIA DIGITS 学习笔记(NVIDIA DIGITS-2.0 + Ubuntu 14.04 + CUDA 7.0 + cuDNN 7.0 + Caffe 0.13.0)

2015-09-02 75

NVIDIA DIGITS-2.0 + Ubuntu 14.04 + CUDA 7.0 + cuDNN 7.0 + Caffe 0.13.0环境配置



引言

DIGITS简介

: Deep Learning GPU Training System,是由()公司开发的第一个交互式深度学习GPU训练系统。目的在于整合现有的Deep Learning开发工具,实现深度神经网络(Deep Neural Network,DNN)设计、训练和可视化等任务变得简单化。DIGITS是基于浏览器的接口,因而通过实时的网络行为的可视化,可以快速设计最优的DNN。DIGITS是开源软件,,因而开发人员可以扩展和自定义DIGITS。

DIGITS控制台

DIGITS特性

  • 提供了友好的用户界面,只需简单的点击即完成DNNs的训练。DIGITS是一个Web应用,用浏览器访问,上图是典型的工作流程图。

  • DIGITS用户接口提供了DNN优化工具。主控制台列出了现有的数据库和机器上可用的先前训练好的网络模型以及正在进行的训练活动。

  • DIGITS使可视化网络和快速对比精度变得简单。你选择一个模型,DIGITS显示训练状态和精度,并提供在网络训练时或训练完毕后加载和分类图像的选项。

  • 由于DIGITS运行在一个web服务器上,团队用户可以很方便地分享数据库和网络配置,以及测试和分享结果。

  • DIGITS集成了流行的,并支持使用进行GPU加速。

资源信息

  1. 在百度里搜索:
  2. 软件首页(DIGITS):
  3. 硬件平台(英伟达搭建的环境,NVIDIA® DIGITS™ DevBox):
  4. 相关文档

登陆,注册后下载DIGITS(注意到注册邮箱里点击激活链接),也可以下载(基于Python)安装。

参考资料

  1. ,原文链接:

  2. ,原文链接:

说明

  1. 如官方所述,DIGITS现在仅支持Ubuntu,当然也在其它Linux系统上测试成功,未见有在Windows上配置的案例;
  2. DIGITS尝试囊括更多的开源Deep Learning 框架,当前(digits-2.0)仅包括:, , , and .

DIGITS安装

,官网说DIGITS的安装相当方便:1)访问注册并下载安装器安装;或者2)上获取源代码安装。实际上,对于新手来说并非如此,下面介绍采用源码的安装方式。

说明1:本人将采用源码安装的软件的安装根目录为:/home/liu/sfw,即~/sfw,本文中记为yourpath。这样Caffe的安装路径:/home/liu/sfw/caffe,DIGITS的安装路径:/home/liu/sfw/digits;而CUDA默认安装根目录为/usr/local

说明2:每个软件的安装方法可以查看官网的在线帮助,也可以查看源码中的文档。对于后者,多为“.md”即markdown文件,可以安装查看,如下图为预览的Caffe的“installation.md”文件。

使用ReText查看installation.md

软硬件环境

硬件环境

笔记本× 1、CPU(Intel® Core™ i5-3210M CPU @ 2.50GHz × 4 )× 1、GPU(GeForce GT 635M/PCIe/SSE2 + IntelGMAHD3000)× 1。

软件环境

环境简介及下载链接:

  1. 操作系统:()
  2. CUDA:(cuda-repo-ubuntu1404-7-0-local_7.0-28_amd64.deb),
  3. cuDNN:(cudnn-7.0-linux-x64-v3.0-rc.tgz)
  4. Caffe:(,必须是,原因)
  5. DIGITS:(源码安装,)

操作系统安装

具体安装方法参见:。

DIGITS安装前准备

采用源码安装DIGITS前,事先要安装CUDA(必须)、cuDNN(用于GPU加速,建议安装),Caffe(运行DIGITS至少要有一个Deep Learning framework,也可以安装Theano,这里不介绍)。

安装CUDA7.0(“.deb”方式)

在Linux下的安装步骤参见官网手册:,其中提及了“.run”、“.deb”等安装文件的安装方法,本人选择”deb”包的格式,因为它比较简单。

0.检查你的电脑是否支持CUDA

检查GPU是否支持:输入如下命令,如果输出的GPU型号是NVIDIA的,并且在此列表内,则支持。

lspci | grep -i nvidia

1.下载安装文件:可以直接访问上面给出的官网链接下载,也可以在终端窗口输入如下命令下载。

# downloading the (currently) most recent version of CUDA 7sudo wget http://developer.download.nvidia.com/compute/cuda/repos/ubuntu1404/x86_64/cuda-repo-ubuntu1404_7.0.28_amd64.deb

2.安装依赖工具:需要连网。

# installation of required toolssudo apt-get install -y gcc g++ gfortran build-essential \  git wget linux-image-generic libopenblas-dev python-dev \  python-pip python-nose python-numpy python-scipy

3.安装CUDA

# installing CUDAsudo dpkg -i cuda-repo-ubuntu1404-7-0-local_7.0-28_amd64.debsudo apt-get updatesudo apt-get install cuda

4.设置环境变量

注意:此环境变量为64位系统下的,32位的把lib64改成lib即可。

方式1,仅修改用户变量

# setting the environment variables so CUDA will be foundecho "\nexport PATH=/usr/local/cuda-7.0/bin:$PATH" >> ~/.bashrcecho "\nexport LD_LIBRARY_PATH=/usr/local/cuda-7.0/lib64:$LD_LIBRARY_PATH" >> ~/.bashrc

方式2,修改所有用户变量

先使用sudo gedit /etc/profile打开“profile”文件,或者sudo gedit ~/.bashrc打开“./bashrc”文件,然后在打开的文件的末尾添加如下代码并保存

# setting the environment variables so CUDA will be found# After open profile, Add follow code at the end of fileexport PATH=/usr/local/cuda-7.0/bin:$PATHexport LD_LIBRARY_PATH=/usr/local/cuda-7.0/lib64:$LD_LIBRARY_PATH

5.加载新的环境变量:添加好环境变量后,需要加载新的环境变量,才能应用于系统。

加载更新环境变量source ~/.bashrc(方式1),source /etc/profilesource ~/.bashrc(方式2)。

=====重启系统!重启系统!重启系统!=======

sudo reboot

6.安装samples并检查CPU:samples被默认安装在/home/liu下:

# installing the samples and checking the GPUcuda-install-samples-7.0.sh ~/cd NVIDIA_CUDA-7.0_Samples/1_Utilities/deviceQuerymake  ./deviceQuery

执行完./deviceQuery命令,终端输出如下类似信息,有GPU型号、驱动版本和运行版本、计算能力……诸多信息:

GPU设备信息

至此CUDA安装成功。

显卡切换

如果你用的是具有双显卡的PC机,比如本人的Intel集成显卡+NVIDIA的独立显卡,可以使用nvidia-prime来切换使用哪个显卡。双击/usr/share/applications/NVIDIA X Server Settings启动NVIDIA X Server 设置,如下图,但不像网上说的有nvidia-prime那一项:

NVIDIA X Server Settings

于是自己安装NVIDIA-prime指示器,命令如下:

sudo add-apt-repository ppa:nilarimogard/webupd8sudo apt-get updatesudo apt-get install prime-indicatorsudo reboot

重启系统后,在右上方托盘区可见NVIDIA或Intel的图标,点击即可切换。

安装cuDNN7.0

cuDNN的安装很简单:

1.解压:进入“cudnn-7.0-linux-x64-v3.0-rc.tgz”所在目录,将文件解压,如下:

#注意修改成你的目录cd /home/liu/sfw#解压gzip -d cudnn-7.0-linux-x64-v3.0-rc.tgztar xf cudnn-7.0-linux-x64-v3.0-rc.tar

2.copy文件至CUDA安装目录:解压后,在你的目录下生成一个“cuda”文件夹,对于cuDNN6.5的版本解压后生成“cudnn-6.5-linux-x64-v2”文件。使用如下命令copy,注意第二个有个-a参数,否则,拷贝过去的文件失去了链接。

# copy the library files into CUDA's include and lib folderssudo cp cuda/include/cudnn.h /usr/local/cuda/includesudo cp -a cuda/lib64/libcudnn* /usr/local/cuda/lib64

cuDNN安装完成。

安装Caffe-0.13.0

官网的安装方法:。

下载好Caffe-0.13.0后,解压文件caffe-master.zip生成“caffe-master”文件夹,并将其重命名为“caffe”,放在yourpath根目录下下,如:/home/liu/sfw

1.首先安装一些依赖库:CUDA(已安装)、BLAS 、Boost、OpenCV等等,见官网的安装方法:,或自述文件(installation.md)。

sudo apt-get install libprotobuf-dev libleveldb-dev \  libsnappy-dev libopencv-dev libboost-all-dev libhdf5-serial-dev \  libgflags-dev libgoogle-glog-dev liblmdb-dev protobuf-compiler \  libatlas-base-dev

2.安装其它的依赖库:查看“requirements.txt”文件,请注意将下面的路径替换为你的路径。

cd ~/sfw/caffe/pythonfor req in $(cat requirements.txt); do sudo pip install $req; done

2.修改配置文件并编译:终端进入“caffe”文件夹,复制一份Makefile.config文件,然后修改Makefile.config文件,如不使用GPU,可以去掉#GPU_ONLY=1的注释符:#,请根据需要自行修改,这里采用默认值,不做修改。然后进行编译:

cd ~/sfw/caffecp Makefile.config.example Makefile.config# for a faster build, compile in parallel by doing make all -j8 where 8 is the number of parallel threads for compilation (a good choice for the number of threads is the number of cores in your machine).make allmake pymake testmake runtest

编译时间比较漫长,可以使用多线程,需要知道你的电脑的线程数,下面这样会快好多:

make all -j4  make py -j4make test -j4  make runtest -j4

编译中没有错误提示,说明正确。

3.添加环境变量:方法同CUDA(),只是环境变量名称及路径需要变化,如:

# Add environmentecho -e "\nexport CAFFE_HOME=/home/liu/sfw/caffe" >> ~/.bashrc# load the new environmental variablessource ~/.bashrc

或者:

# Add environmentsudo gedit /etc/profile# After open profile, Add follow code at the end# Set Caffe environmentexport CAFFE_HOME="/home/liu/sfw/caffe"# load the new environmental variablessource /etc/profile

这样caffe就安装好了!如果在make runtest时提示“Core dumped”,现象截图及解决办法见。

安装DIGITS

1.解压文件:终于可以安装DIGITS了,解压下载好的文件生成“DIGITS-master”文件夹,将其重命名为“digits”,并copy到你的目录yourpath,如/home/liu/sfw下面。

2.安装DIGITS:命令如下,注意修改路径。

cd /home/liu/sfw/digitssudo apt-get install graphviz gunicornfor req in $(cat requirements.txt); do sudo pip install $req; done

如果网络不好,或软件源服务关闭等等可能造成某些依赖库无法下载和安装,终端会有大片红色文字,请更改软件源确认网络连接正常,重新执行上述命令。

启动DIGITS

进入digits文件夹,给文件“./digits-devserver”赋予可执行权限,然后./digits-devserver运行digits:

cd ~/sfw/digitschmod +x ./digits-devserver./digits-devserver

第一次运行会提示输入caffe的安装路径:

输入caffe的安装路径

运行时可能会提示启动失败:$ImportError: /usr/lib/liblapack.so.3: undefined symbol: ATL_chemv

在,命令如下:

sudo apt-get remove libopenblas-base

然后在终端输入./digits-devserver,即可成功启动:

启动digits server

久违的界面终于出来了:

digits server

配置DIGITS

上述步骤,是按默认配置启动digits,如果你想自定义配置,可以在启动前输入:

Most values are set silently by default. If you need more control over your configuration, try one of these commands:# Set more options before starting the server./digits-devserver --config# Advanced usagepython -m digits.config.edit --verbose

使用DIGITS

digits官方自带例子(MNIST)

参见或源码包中的“GettingStarted.md”文件。

下载MNIST数据集

DIGITS提供了下载数据集和的工具,在/digits/tools/download_data目录下,包含如下文件:

数据集下载工具

执行其中的main.py程序即可:

赋予执行权限
下载数据集

主要代码如下:

#首次使用赋予执行权限chmod +x *.py#查看帮助./main.py -h#创建一个目录用于存放MNIST数据集mkdir -p /home/liu/sfw/digits/data/mnist#下载数据集至上述目录./main.py -c mnist ~/sfw/digits/data/mnist

执行后,可以在/digits/data/mnist目录下看到下载好的数据集,如下图:

下载的MNIST数据集

在DIGITS server上创建数据集

这里按照“GettingStarted.md”文件中所述,创建数据集为分类数据集:在digits server首页的DataSets区域点击Images,选择Classfication,在弹出的窗口填写训练数据集信息,这里为60000个样本(“GettingStarted.md”里的例子样本数为10k),信息见下图:

创建数据集

数据集创建过程:

digits server正在创建数据集

digits创建的数据集信息

点击左上角的“DIGITS”返回查看创建好的MNIST train 60k数据集:

查看创建好的数据集

在DIGITS server上创建深度网络模型并训练

如上图,在Models区域点击Images,选择Classfication。在弹出的页面填写信息,数据集选择:MNIST train 60k,模型命名为:LeNet on MNIST 60k,如下图:

创建网络模型为LeNet

点击蓝色按钮“Create”后,任务即开始执行!

一个小问题(Caffe&cuDNN)

原以为可以兴奋地看到结果,然而失望了,报出了错误:

ERROR: Check failed: status == CUDNN_STATUS_SUCCESS (6 vs. 0) CUDNN_STATUS_ARCH_MISMATCH

如下图:

出错啦

其实,在安装Caffe时,当运行make runtest时就有个小问题,报出了“Check failure”,不过让我直接忽略了,没想到又回来了,哈哈。

Chek failure

这是因为笔记本上的GT635M的计算能力CUDA Capability是2.1,而官方的cuDNN加速是不支持3.0以下的版本的,因此只能在Makefile.config中注释掉USE_CUDNN这行,重新执行以下编译。

make clean  make all -j4  make test -j4  make runtest -j4

:访问查看GPU的计算能力,在页面选择GPU的型号,如Geforce GT 635M,如下图:

GPU的计算能力信息

编译完成后,删除之前建的LetNet on MNIST 60k任务,然后仿造上述步骤,重新新建一个任务,执行后,如下图:

运行界面

运行过程,网络的训练状态,GPU的状态等信息会实时显示:

运行状态

学习率与训练代数关系

学习率与训练代数关系图

使用DIGITS server 进行分类操作(MNIST)

训练结束后,可以对手写体数字图像进行分类,可以对单个图像分类,也可以同时分类多幅图像,这里以上述步骤中生成的“MNIST train 60k”数据集中的验证集为例。

在“Upload Image List”区域点击选择文件按钮,选择验证集的 list文件val.txt:

选择val.txt

选择好后,点击Classify Many Images按钮,即可对多幅图像分类,这时,界面上没有显示进度,在终端中显示,如下图:

分类进程

对所选图像分类完成后,弹出分类结果页面:

分类结果

可视化分类结果:

可视化分类结果

结语

本文记录了本人安装配置NVIDIA DIGITS步骤与方法,软件环境为Ubuntu 14.04 + CUDA 7.0 + cuDNN 7.0 + Caffe 0.13.0 + DIGITS 2.0。并以DIGITS自述文件中的例子为例,简单介绍了DIGITS的用法。

可见,DIGITS的源码安装方式还是有一定难度,特别是对Linux不熟悉的使用者。DIGITS的使用很方便,只需进行简单的点击操作,即可完成数据集创建、网络模型创建、网络训练、网络训练状态的实时显示、用训练好的网络进行图像分类等任务,使得不熟悉深度学习的人员也可以在深度学习的大海中轻而易举地航行,这正式DIGITS的设计目的所在。

DIGITS除了支持Caffe,还支持Theano,本文并未介绍Theano,不过会陆续补充,关于Theano的一些信息,也可以在本人的其它博客里找到。




转载于:https://www.cnblogs.com/shishupeng/p/5770449.html

你可能感兴趣的文章
Android BroadcastReceiver 的简单实现
查看>>
关于一些基础的Java问题的解答(三)
查看>>
C++学习之const整理总结
查看>>
玩转modulesim_001 新建一个工程
查看>>
Maven中的SnapShot版本和Release版本
查看>>
淘宝技术发展
查看>>
am335x ar8031 双网口配置记录
查看>>
nodejs之入门
查看>>
ios中的三种弹框《转》
查看>>
Weakness and Poorness CodeForces - 578C
查看>>
2873=老--质价比
查看>>
Oracle 存储过程简单语法
查看>>
JAVA中List、Map、Set的区别与选用
查看>>
bat-- .bat 文件启动服务 和 启动Tomcat
查看>>
org.springframework.web.bind.annotation重定向的问题
查看>>
程序员必须软件
查看>>
关于message pack as3 版本的一些修改。
查看>>
[G]java反射获得泛型参数getGenericSuperclass()
查看>>
【bzoj4443 scoi2015】小凸玩矩阵
查看>>
网页设计该做什么和不该做什么?
查看>>