Windows10+cuda9.0+cudnn7.3+vs2013+caffe安装时遇到的一些问题汇总

2024-01-21 12:40

本文主要是介绍Windows10+cuda9.0+cudnn7.3+vs2013+caffe安装时遇到的一些问题汇总,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

现在编译caffe比以前要方便点了,官网提供的caffe安装包在你打开项目编译libcaffe时会自动为你下载第三方依赖库,而且自动编译识别。这里把自动编译过程中的遇到的问题汇总一下,单独搜这些也是可以搜到的。

关于cuda,cudnn,vs2013的安装都很简单,这里不再多说,其中cudnn的版本根据自己的情况选吧,也可以是7.0

caffe可以去官网下载,也可以用下面的链接

链接:https://pan.baidu.com/s/1SroFPA7AxxZoq_7p2VFPKw 
提取码:1h1d 

第三方依赖库集合NugetPackages是自动下载的,如果下载不了就用下面的链接

链接:https://pan.baidu.com/s/1yny9O2W5Gt87BtqYR7Qmkg 
提取码:cfrc 
注意这个文件是和caffe-master在同级目录

编译前先更改配置文件CommonSettings.props.example为CommonSettings.props

自动编译时可能遇到下面的错误:

最开始可能遇到的错误我直接在别的博客截一下图把,这个问题我再回去操作一遍太麻烦了

0.

一开始应该会遇到这个错误,就是需要把下面cuda的路径里的那几个文件拷贝到系统能识别的那个路径,类似下面这张图的操作,不管你是cuda什么版本都会对应找到下面的路径

1.

D:\NugetPackages\OpenCV.2.4.10\build\native\OpenCV.targets(772,5): error MSB4062: 未能从程序集 D:\NugetPNugetPackages\OpenCV.2.4.10\build\native\private\coapp.NuGetNativeMSBuildTasks.dll 加载任务“NuGetPackageOverlay”。未能加载文件或程序集“file:///E:\NugetPackages\OpenCV.2.4.10\build\native\private\coapp.NuGetNativeMSBuildTasks.dll”或它的某一个依赖项。系统找不到指定的文件

搜到的解决方式:libcaffe右击以后按下面来:

管理NuGet程序包->更新,此时可以看到opencv后面有更新的按钮,点击更新为opencv2.4.11,这时项目已经在对应的配置文件更改了相关内容,原博客说需要先卸载libcaffe项目然后到D:\caffe-master\windows\libcaffe\libcaffe.vcxproj中修改opencv版本,但是我发现其实不用,这个是自动更新,你可以关闭VS去确认一下。

2.

error: too few arguments in function call  双击错误的地方定位到具体的代码行,报错函数   cudnnSetConvolution2dDescriptor,在参数列表末尾补充一个参数 CUDNN_DATA_FLOAT 或CUDNN_DATA_DOUBLE即可这个错误借用了一下原博客的图,我忘了截图了。

3.

error C1083: 无法打开包括文件: “pyconfig.h”: No such file or directory (..\..\src\caffe\layer_factory.cpp)  D:\NugetPackages\boost.1.59.0.0\lib\native\include\boost\python\detail\wrap_python.hpp 

这个错误是因为在CommonSettings.props中你的python路径没给对或者没给。我配置文件里的路径是python3,python3不行你改成python2试试。

4.

C:\Program Files (x86)\MSBuild\Microsoft.Cpp\v4.0\V120\Microsoft.CppCommon.targets(132,5): error MSB3073: :VCEnd”已退出,代码为 1

这个错误右击项目,然后在属性里面 配置属性-后期生成事件-在生成中使用 这里 把  是  改成  否

 

在libcaffe编译没有问题以后就可以编译caffe了,正常情况下应该不会报错,我就没有报错,然后其他的就基本不会有什么问题了。

pycaffe 编译完需要把相关文件即pycaffe下面的caffe拷贝到python中site-packages下面,具体如下:

 

接下来你在python中import caffe时可能遇到protobuf相关的错误即ImportError: No module named google.protobuf.internal,具体情况及解决办法如下(反正就是直接pip install protobuf就行了):

 

这篇关于Windows10+cuda9.0+cudnn7.3+vs2013+caffe安装时遇到的一些问题汇总的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/629569

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)