Ubuntu 16.04 安装 Tensorflow Gpu版本

原文地址:https://blogof33.com/post/2/
Tensorflow有Pip,Docker, Virtualenv, Anaconda 或 源码编译的方法安装 ,本文中采用Pip安装。

因为国内中文教程中有关Pip安装的很少,官方中文文档也有一些顺序上的错误,语义的模糊,按照上面的来很容易出错。所以我就在这里写一篇教程吧。

注:建议 Ubuntu 16.04版本

配置:

Linux Distribution: Ubuntu 16.04 64位

Cpu: Intel Core i5 6300HQ

Gpu:GTX 960M

Python:2.7

因为笔者是装的双系统,用UEFI引导的没有关Security Boot(安全启动),所以出了一点问题。

1.开机进入Bios,关闭Security Boot

2.系统设置(setting)->软件和更新->附加驱动

  • 先打开terminal输入:

    sudo apt-get update

  • 然后将显卡驱动选择为NVIDIA的显卡驱动(更改以后需要等待一段时间。)

3.安装CUDA8

  • cuda toolkit 8.0下载,如图,选择deb(local)安装,网上有些说神马一定要选runfile,其实deb也很简单。
  • 注:cuda 7.5只有ubuntu15.04和14.04版本,所以要用cuda 8.0

[图片上传失败...(image-5d8b27-1529399633042)]

  • 下载成功以后按照图中的命令操作即可安装完成。
    安装完成以后,cuda默认安装在了/usr/local/cuda-8.0/目录处,然后:
    vim ~/.profile
    注:很多其他发行版是打开.bash_profile,ubuntu没有这个,而是.profile
    设置环境变量(加在文件末尾,每次登陆后自动生效):
    export PATH="$PATH:/usr/local/cuda-8.0"
    export LD_LIBRARY_PATH="/usr/local/cuda-8.0/lib64"
    保存以后,继续在terminal中输入::
    source ~/.profile #使更改的环境变量立即生效
    nvidia-smi #测试是否配置成功
    结果出现以下相识输出说明配置成功:
    [图片上传失败...(image-b3923c-1529399633042)]

4.降低gcc版本

因为ubuntu的gcc编译器是5.4.0,然而cuda8.0不支持5.0以上的编译器,因此需要降级,把编译器版本降到4.9:

  sudo apt-get install g++-4.9
  sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.9 20
  sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-5 10
  sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.9 20
  sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-5 10
  sudo update-alternatives --install /usr/bin/cc cc /usr/bin/gcc 30
  sudo update-alternatives --set cc /usr/bin/gcc
  sudo update-alternatives --install /usr/bin/c++ c++ /usr/bin/g++ 30
  sudo update-alternatives --set c++ /usr/bin/g++
  gcc --version

如果版本显示出来是4.9就成功了

5.安装深度学习库cuDNN

一定要下载<font color=#0099ff face="微软雅黑">cuDNN5.1</font>!!!!**,至少现在下载6.0版本后面是有问题的,我之前下载的6.0版本,后面导入tensorflow时一直报错,在gaythub上看见有人说6.0“don not work”而5.1可以,不得已退回到5.1,然后便成功了。

  • 下载之前要注册一个NVIDA DEVELOPER帐号,然后填三个问题就可以啦。如图选择cuDNN v5.1 Library for Linux:
    [图片上传失败...(image-8c75d-1529399633042)]

  • 下载完成以后,解压并拷贝 CUDNN 文件到 Cuda Toolkit 8.0安装路径下. 假设 Cuda Toolkit 8.0 安装在 /usr/local/cud-8.0(默认路径), 执行以下命令(若/usr/local/cuda-8.0/include目录不存在,先创建一个include目录):

      tar xvzf cudnn-8.0-linux-x64-v5.1.tgz
      sudo cp cuda/include/cudnn.h /usr/local/cuda-8.0/include
      sudo cp cuda/lib64/libcudnn* /usr/local/cuda-8.0/lib64
      sudo chmod a+r /usr/local/cuda-8.0/include/cudnn.h /usr/local/cuda-8.0/lib64/libcudnn*

6.Install and upgrade PIP

  • 首先要确保安装和更新pip:
     sudo apt-get install python-pip python-dev
     pip install --upgrade pip

7.安装 Tensorflow Gpu enable python 2.7 版本

pip install --upgrade tensorflow-gpu

测试一下:

       $python 
       Python 2.7.12 (default, Nov 19 2016, 06:48:10) 
       [GCC 5.4.0 20160609] on linux2
       Type "help", "copyright", "credits" or "license" for more information.
       >>> import tensorflow as tf
       >>> hello = tf.constant('Hello, TensorFlow!')
       >>> sess = tf.Session()
       2017-08-25 14:34:54.825013: W tensorflow/core/platform/cpu_feature_guard.cc:45] The 
       TensorFlow library wasn't compiled to use SSE4.1 instructions, but these are available on your 
       machine and could speed up CPU computations.
       2017-08-25 14:34:54.825065: W tensorflow/core/platform/cpu_feature_guard.cc:45] The 
       TensorFlow library wasn't compiled to use SSE4.2 instructions, but these are available on your 
       machine and could speed up CPU computations.
       2017-08-25 14:34:54.825081: W tensorflow/core/platform/cpu_feature_guard.cc:45] The 
       TensorFlow library wasn't compiled to use AVX instructions, but these are available on your 
       machine and could speed up CPU computations.
       2017-08-25 14:34:54.825093: W tensorflow/core/platform/cpu_feature_guard.cc:45] The 
       TensorFlow library wasn't compiled to use AVX2 instructions, but these are available on your 
       machine and could speed up CPU computations.
       2017-08-25 14:34:54.825105: W tensorflow/core/platform/cpu_feature_guard.cc:45] The 
       TensorFlow library wasn't compiled to use FMA instructions, but these are available on your 
       machine and could speed up CPU computations.
       2017-08-25 14:34:55.071951: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:893] 
       successful NUMA node read from SysFS had negative value (-1), but there must be at least one 
       NUMA node, so returning NUMA node zero
       2017-08-25 14:34:55.072542: I tensorflow/core/common_runtime/gpu/gpu_device.cc:940] Found 
       device 0 with properties: 
       name: GeForce GTX 960M
       major: 5 minor: 0 memoryClockRate (GHz) 1.176
       pciBusID 0000:01:00.0
       Total memory: 1.95GiB
       Free memory: 1.31GiB
       2017-08-25 14:34:55.072632: I tensorflow/core/common_runtime/gpu/gpu_device.cc:961] DMA: 
       0 
       2017-08-25 14:34:55.072695: I tensorflow/core/common_runtime/gpu/gpu_device.cc:971] 0:   Y 
       2017-08-25 14:34:55.072730: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1030] 
       Creating TensorFlow device (/gpu:0) -> (device: 0, name: GeForce GTX 960M, pci bus id: 
       0000:01:00.0)
       >>> print(sess.run(hello))
       Hello, TensorFlow!

 
查看一下GPU开启情况:
   - "/cpu:0": The CPU of your machine.
   - "/gpu:0": The GPU of your machine, if you have one.
   - "/gpu:1": The second GPU of your machine, etc.


    >>> import tensorflow as tf
    >>> a = tf.constant([1.0, 2.0, 3.0, 4.0, 5.0, 6.0], shape=[2, 3], name='a')
    >>> b = tf.constant([1.0, 2.0, 3.0, 4.0, 5.0, 6.0], shape=[3, 2], name='b')
    >>> c = tf.matmul(a, b)
    >>> sess = tf.Session(config=tf.ConfigProto(log_device_placement=True))
    >>> print(sess.run(c))
    MatMul: (MatMul): /job:localhost/replica:0/task:0/gpu:0
    2017-08-09 09:47:39.461702: I tensorflow/core/common_runtime/simple_placer.cc:847] MatMul: (MatMul)/job:localhost/replica:0/task:0/gpu:0
    b: (Const): /job:localhost/replica:0/task:0/gpu:0
    2017-08-09 09:47:39.461942: I tensorflow/core/common_runtime/simple_placer.cc:847] b: (Const)/job:localhost/replica:0/task:0/gpu:0
    a: (Const): /job:localhost/replica:0/task:0/gpu:0
    2017-08-09 09:47:39.461976: I tensorflow/core/common_runtime/simple_placer.cc:847] a: (Const)/job:localhost/replica:0/task:0/gpu:0
    [[ 22.  28.]
     [ 49.  64.]] 

至此,Tensorflow安装成功。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容