微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

深度学习番外篇---WIN10+PyTorch0.4.0+CUDA9.1环境配置

不久前PyTorch0.4.0官方支持了Windows,可谓是感天动地,于是乘比较空闲的时间搭搭环境,顺便做下记录。

一.下载和安装CUDA9.1+cudnn-9.1库(注意下载的时候选择好配套的版本)

CUDA 地址如下:

https://developer.nvidia.com/cuda-downloads?target_os=Windows&target_arch=x86_64&target_version=10&target_type=exelocal

cudnn 地址如下:

https://developer.nvidia.com/cudnn

安装过程比较简单,可以参考如下的文章

https://blog.csdn.net/qq_33993942/article/details/79149669

遇坑一:

本人之前已经安装了VS2017的社区版,在安装CUDA9.1的时候总是安装失败,画面大致如下(这个图是本人网上找的,因为解决之前忘了截图,又不想再搞一次,见谅见谅):

查了一圈发现跟“visual studio integration”这一项有关,因为本人后面只是在PyTorch中用到CUDA,因此在安装中选择“自定义”然后取消了该项的选择,这样就能正确安装了。

这个问题怀疑跟VS的版本有关系,VS2015或者VS2017的其他版本可能就没这个问题,后面有需要再做验证,如果有老哥试了麻烦留个言。

装完了可以cd到“C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v9.1\extras\demo_suite\”文件夹运行“bandwidthTest.exe”和“deviceQuery.exe”测试下是否成功安装了。

二.装Python 3.6

遇坑二:本人一开始是到官网下载的“python-3.6.5.exe”,安装一直无事发生,感觉良好。但后面PyTorch死活装不上去,才发现这个安装包是32位的。。。后面下了“python-3.6.5-amd64.exe”就好了。

另外记得安装的Python版本要在PyTorch支持之内,具体见官网首页的这张图,本人最开始下的是PYTHON 3.7,后面跑回去改成3.6。。。

三.装PyTorch

在官网选择对应的版本,如下:

可以看到最下面两条语句,在控制台运行下就可以了。

到此全部安装完成,完成后,可按照如下方法测试环境是否正常。

在python中,输入“import torch”

遇坑三(这个坑相当深!!!):出现如下错误

问题是少了“intel-openmp”相关的链接文件解决办法是下载相关的文件包,解压出来后把“bin”放到环境变量中,重启,问题解决。(这里可以直接把里面的dll拷贝到已经在环境变量中的路径,这样就可以不用重启)。

需要注意,如果没有“VC++ 2017”的运行库似乎同样也会出现这个问题,本人没试过,有老哥试了上面的还不行可以关注一下。

到此全部的坑填完,安装完成。。。

在python中,输入“import torch”

“print(torch.cuda.is_available())”

可以看到你想要的!

当然,相信还有无数的坑,只是本人运气好避开了,whatever,以后遇到再说吧!

另外写文章累人,写代码掉头发,如果觉得文章有帮助,哈哈哈

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Windows注册表操作基础代码 Windows下对注册表进行操作使用的一段基础代码Reg.h:#pragmaonce#include<assert.h>#include<windows.h>classReg{HKEYhkey;public:voidopen(HKEYroot
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的内容,在Windows环境下的黑客必须熟练掌握底层API编程。为了使读者对黑客常用的Windows API有个更全面的了解以及方便日后使用API方法的查询,特将这些常用的API按照7大分类进行整理如下,希望对大家的学习有所帮助。一
一个简单的Windows Socket可复用框架说起网络编程,无非是建立连接,发送数据,接收数据,关闭连接。曾经学习网络编程的时候用Java写了一些小的聊天程序,Java对网络接口函数的封装还是很简单实用的,但是在Windows下网络编程使用的Socket就显得稍微有点繁琐。这里介绍一个自己封装的一
Windows文件操作基础代码 Windows下对文件进行操作使用的一段基础代码File.h,首先是File类定义:#pragmaonce#include<Windows.h>#include<assert.h>classFile{HANDLEhFile;//文件句柄publ
Winpcap基础代码 使用Winpcap进行网络数据的截获和发送都需要的一段代码:#include<PCAP.H>#pragmacomment(lib,"wpcap.lib")//#pragmacomment(lib,"ws2_32.lib")#
使用vbs脚本进行批量编码转换 最近需要使用SourceInsight查看分析在Linux系统下开发的项目代码,我们知道Linux系统中文本文件默认编码格式是UTF-8,而Windows中文系统中的默认编码格式是Gb2312。系统内的编码格式有所区别倒无伤大雅,关键的是SourceInsigh...
缓冲区溢出攻击缓冲区溢出(Buffer Overflow)是计算机安全领域内既经典而又古老的话题。随着计算机系统安全性的加强,传统的缓冲区溢出攻击方式可能变得不再奏效,相应的介绍缓冲区溢出原理的资料也变得“大众化”起来。其中看雪的《0day安全:软件漏洞分析技术》一书将缓冲区溢出攻击的原理阐述得简洁
Windows字符集的统一与转换一、字符集的历史渊源在Windows编程时经常会遇到编码转换的问题,一直以来让刚接触的人摸不着头脑。其实只要弄清Win32程序使用的字符编码方式就清楚了,图1展示了一个Win32控制台项目的属性中的字符集选项。这里有两个不同的字符集:一个是Unicode字符集,另一个
远程线程注入引出的问题一、远程线程注入基本原理远程线程注入——相信对Windows底层编程和系统安全熟悉的人并不陌生,其主要核心在于一个Windows API函数CreateRemoteThread,通过它可以在另外一个进程中注入一个线程并执行。在提供便利的同时,正是因为如此,使得系统内部出现了安全
windows系统启动项怎么打开