ubuntu18.04下跑通maskrcnn_benchmark基于cuda10.1+cudnn7.6+anaconda+pytorch_ubuntu深度学习cnn-程序员宅基地

技术标签: deep learning  ubuntu18.04  anaconda  pytorch  maskrcnn_benchmark  cuda10.1  

ubuntu18.04 配置cuda10.1+cudnn7.6+anaconda+pytorch跑通maskrcnn_benchmark

最近在用anaconda配置ubuntu系统下的深度学习环境,终于跑通了maskrcnn_benchmark,真的是踩了很多坑。。把配置过程记录下来,欢迎交流探讨。

目录

  1. 安装显卡驱动
  2. 安装anaconda
  3. 安装cuda10.1
  4. 安装cudnn7.6
  5. 进行maskrcnn_benchmark环境配置

1、安装nvidia驱动

装好显卡驱动,本人显卡驱动版本430.26
方法参考网址:https://www.linuxidc.com/Linux/2019-02/157170.htm
就不仔细说了。

2、安装anaconda并在base环境下配置好python,pytorch等

1)在清华镜像源网站下载anaconda并安装。https://mirrors.tuna.tsinghua.edu.cn/help/anaconda/
记得更改环境变量。安装完成后重新打开终端,命令行前面会出现(base),即在anaconda环境下。可通过conda deactivate退出。

2)输入以下指令添加清华源。

conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/free/
conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main/
conda config --set show_channel_urls yes

3)可以运用conda指令安装python等包。也可以通过pip安装opencv-python等包。(此pip是conda中的,可通过pip --ersion查看版本)

4)根据pytorch官网提示选择合适的版本,复制粘贴官网给的终端命令进行安装。

3、安装cuda10.1

1)根据显卡驱动版本,在nvidia官网下载对应的cuda版本,在http://developer.nvidia.com/cuda-downloads上下载安装包。

2)根据官网提示的信息输入sudo sh cuda版本.run

3)输入accept

4)在cuda installer界面不勾选driver,其他都选中。回车进行安装。

5)安装完成后添加环境变量
输入sudo gedit ~/.bashrc
在文件末尾添加

export CUDA_HOME=/usr/local/cuda
export PATH="/usr/local/cuda/bin:$PATH"
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/usr/local/cuda/lib64"
export LIBRARY_PATH="$LIBRARY_PATH:/usr/local/cuda/lib64"

保存后 输入source ~/.bashrc使其生效

6)在终端输入

cd /usr/local/cuda-10.1/samples/1_Utilities/deviceQuery
sudo make
./deviceQuery

验证安装是否成功 出现Result = PASS则表示安装成功通过
也可通过输入nvcc --version查看cuda版本

4、安装cudnn7.6

1)在官网注册登陆后下载对应的cudnn版本。
网址:https://developer.nvidia.com/rdp/cudnn-download
本人下载版本为:libcudnn7_7.6.2.24-1+cuda10.1_amd64.deb
libcudnn7-dev_7.6.2.24-1+cuda10.1_amd64.deb

2)在终端中进入安装包所在目录,用指令sudo dpkg -i libcudnn7_7.6.2.24-1+cuda10.1_amd64.deb
sudo dpkg -i libcudnn7-dev_7.6.2.24-1+cuda10.1_amd64.deb

3)安装成功后在终端进入python命令行,用以下代码测试cudnn安装成功。(通过查找cuda文件夹下的cudnn文件是找不到的,因为我们用的是deb的安装方法,不是原来的解压并挪位置的方法。)

import torch
#测试cuda能否使用,能使用则返回True
print(torch.cuda.is_available())
True
#测试cuDNN是否正常,正常返回True
from torch.backends import cudnn
a = torch.tensor(1.)
cudnn.is_acceptable(a.cuda())

5、创建新的anaconda环境进行maskrcnn环境配置

根据maskrcnn_benchmark的github官方安装教程稍作修改。https://github.com/facebookresearch/maskrcnn-benchmark/blob/master/INSTALL.md
终端指令步骤:

conda create --name maskrcnn_benchmark python=3.6   #python得设置为3.6版本,否则pip安装opencv会失败。
conda activate maskrcnn_benchmark   #conda中激活新的虚拟环境maskrcnn_benchmark
conda install ipython
pip install ninja yacs cython matplotlib tqdm opencv-python

# follow PyTorch installation in https://pytorch.org/get-started/locally/
# 在官网版本选择中,虽然我们装的cuda是10.1,但此处cuda没有10.1,我们选择10.0即可,不会有问题。根据官网指令在终端输入,记得去掉 -c,才能用清华源,否则很慢。
conda install pytorch cudatoolkit=10.0 pytorch-nightly
# 此处指令还缺少我们需要的pytorchvision,故使用以下指令安装pytorchvision
conda pytorchvision
# 可以用python命令行import pytorchvision验证安装情况。

# 接下来要编译一些依赖包,可在home下新建一个文件夹用于存储。我创建了文件夹github。
# install pycocotools
cd ~/github
git clone https://github.com/cocodataset/cocoapi.git
cd cocoapi/PythonAPI
python setup.py build_ext install

# install apex
cd $INSTALL_DIR
git clone https://github.com/NVIDIA/apex.git
cd apex
python setup.py install --cuda_ext --cpp_ext  
#此步骤可能会编译错误,由于我们cuda版本10.1高于cuda10.0。解决办法如下:
打开setup.py文件,注释以下部分:
if (bare_metal_major != torch_binary_major) or (bare_metal_minor != torch_binary_minor):
        raise RuntimeError("Cuda extensions are being compiled with a version of Cuda that does " +
                           "not match the version used to compile Pytorch binaries.  " +
                           "Pytorch binaries were compiled with Cuda {}.\n".format(torch.version.cuda) +
                           "In some cases, a minor-version mismatch will not cause later errors:  " +
                           "https://github.com/NVIDIA/apex/pull/323#discussion_r287021798.  "
                           "You can try commenting out this check (at your own risk).")
再次编译即可。

# install PyTorch Detection
cd $INSTALL_DIR
git clone https://github.com/facebookresearch/maskrcnn-benchmark.git
cd maskrcnn-benchmark

python setup.py build develop    #若对上面的文件有所修改,要重新build此步骤。

#接下来就可以跑demo了。
cd demo
#by default, it runs on the GPU
#for best results, use min-image-size 800
python webcam.py --min-image-size 800
#会自动下载一个文件后打开摄像头进行实时检测。

大坑提示:

1、直接create新的conda环境,python是3.7版本的,此时pip install opencv-python失败。我也不知道为啥。用python3.6就可以。
2、建议安装的时候装最新版本的cuda,cudnn,只要系统环境的cuda版本等于或高于conda下的,就可以用!不要去降级cuda,gcc啥的。当然是建立在和系统版本匹配的基础上。
3、虽然conda环境下有装cudatoolkit和cudnn,不代表系统里不需要装!不然功能会不全容易出错。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_43548860/article/details/99632226

智能推荐

zabbix短信告警oracle,zabbix 实现短信告警-程序员宅基地

文章浏览阅读402次。之前一直调用飞信接口发送告警信息,最近购买了第三方短信接口。所以准备使用接口发送告警。短信接口是基于https的摘要认证。https认证还是自己做的,调用接口的时候还需要load证书。感觉超级难用,不管那么多,先让它跑起来再说。废话不多说,先上代码。#!/usr/bin/envpython#coding:utf-8importrequestsfromrequests.authimport..._zabbix实现短信告警

soapui中文操作手册(四)----MOCK服务_soapui设置成中文-程序员宅基地

文章浏览阅读6.8k次,点赞2次,收藏12次。转载地址:http://www.cnblogs.com/zerotest/p/4670005.htmlWeb Service Mocking是武器库一个非常有用的工具。这是解决“如果没有Web服务如何创建针对性的Web服务测试”问题的办法。Web Service Mocking将在这里派上用场。它允许你实际的Web服务产生之前,创建近似或模拟的Web Service。在本教_soapui设置成中文

Swift 包管理器 (SPM):管理 iOS 中的依赖关系_ios spm-程序员宅基地

文章浏览阅读845次,点赞29次,收藏7次。Swift 包管理器 (SPM):管理 iOS 中的依赖关系_ios spm

SCI论文润色真有必要吗?-程序员宅基地

文章浏览阅读381次,点赞10次,收藏7次。总的来说,sci论文润色虽然不会改变论文的学术内容和贡献,但它能够显著的提升论文的质量和可读性,从而增加论文被接受和引用的机会。在论文投稿前都是需要润色的,特别是英文论文投稿,一定得靠谱。但如果是一些小问题,比如语法语句错误,专业言论不恰当,那么你的文章会在投稿过程中外审评定完以后,也会给你返修意见和修改机会。如果是新作者,或者是对自己的语言能力不那么自信,那么是很有必要的。其他人的视角可能会发现你忽略的错误或不清晰的表达,同时也可以提供有关论文结构和逻辑的反馈意见。关于SCI论文润色的常见方法。

Prometheus监控数据格式的学习-程序员宅基地

文章浏览阅读1.1k次,点赞33次,收藏9次。Prometheus 指标(metrics)的数据形式是一种简单的文本格式(容易通过 HTTP 协议被 Prometheus 服务器拉取)。每一行包含了一个指标的数据,通常包括指标名称、可选的一组标签以及指标的值。Prometheus 的指标数据可以有不同类型,如 Counter、Gauge、Histogram 和 Summary,它们的表示形式会有所不同。

数字图像处理(10): OpenCV 图像阈值化处理_binarization threshold-程序员宅基地

文章浏览阅读5.6k次,点赞26次,收藏43次。目录1 什么是阈值化-threshold()2 二进制阈值化3 反二进制阈值化4 截断阈值化5 反阈值化为06 阈值化为07 小结参考资料1 什么是阈值化-threshold()图像的二值化或阈值化 (Binarization)旨在提取图像中的目标物体,将背景以及噪声区分开来。通常会设定一个阈值,通过阈值将图像的像素划分为两类:大于阈值的..._binarization threshold

随便推点

使用安卓模拟器时提示关闭hyper-v_hyperv影响 模拟器-程序员宅基地

文章浏览阅读1.6w次。本电脑是宏碁传奇X,cpu是r7 5800u,显卡rtx3050;使用了雷电、mumu两款安卓模拟器,雷电启动报错g_bGuestPowerOff fastpipeapi.cpp:1161,使用了网上的所有方案都不行,包括开启VT(amd开启SVM),命令关闭hyper-v服务等;尝试mumu模拟器,安装时支持vt项检测不通过,后来发现mumu模拟器在amd的cpu上只支持32位版,换装32位版检测通过,但是只要打开模拟器就提示需要关闭hyper-v,我已经确认关闭后,启动依旧这样提示,查找了网上很_hyperv影响 模拟器

【大厂秘籍】系列 - Mysql索引详解-程序员宅基地

文章浏览阅读564次。MySQL官方对索引定义:是存储引擎用于快速查找记录的一种数据结构。需要额外开辟空间和数据维护工作。● 索引是物理数据页存储,在数据文件中(InnoDB,ibd文件),利用数据页(page)存储。● 索引可以加快检索速度,但是同时也会降低增删改操作速度,索引维护需要代价。

CSS实现当鼠标停留在一个元素上时,使得两个元素的样式发生改变_css鼠标悬浮修改其他元素样式-程序员宅基地

文章浏览阅读825次。使用兄弟选择器实现同时改变两个元素的样式_css鼠标悬浮修改其他元素样式

文献学习-40-基于可迁移性引导的多源模型自适应医学图像分割-程序员宅基地

文章浏览阅读4.8k次,点赞32次,收藏43次。香港中文大学袁奕萱教授团队提出了一种名为多源模型自适应 (MSMA) 的新型无监督域适应方法。MSMA 旨在仅利用预训练的源模型(而非源数据)将知识迁移到未标记的目标域,从而实现对目标域的有效分割。

(4)FPGA开发工具介绍(第1天)-程序员宅基地

文章浏览阅读8.8k次。(4)FPGA开发工具介绍(第1天)1 文章目录1)文章目录2)FPGA初级课程介绍3)FPGA初级课程架构4)FPGA开发工具介绍(第1天)5)技术交流6)参考资料2 FPGA初级课程介绍1)FPGA初级就业课程共100篇文章,目的是为了让想学FPGA的小伙伴快速入门。2)FPGA初级就业课程包括FPGA简介、Verilog HDL基本语法、Verilog HDL 入门实例、FPGA入门实例、Xilinx FPGA IP core设计、Xilinx FPGA原语与U_fpga开发工具

js中的定时器如何使用_js定时器用法-程序员宅基地

文章浏览阅读1.4k次。JS提供了一些原生方法来实现延时去执行某一段代码,下面来简单介绍一下setTiemout、setInterval、setImmediate、requestAnimationFrame。首先,我们先来了解一下什么是定时器:JS提供了一些原生方法来实现延时去执行某一段代码下面来简单介绍一下setTimeout() :在指定的毫秒数后调用函数或计算表达式。setTimeout(code,millisec,lang)参数 描述code 必需。要调用的函数后要执行的 JavaScript 代码串。_js定时器用法

推荐文章

热门文章

相关标签