Widows下Faster R-CNN的MATALB配置(GPU)
说在前面,这篇是关于Windows下Faster R-CNN的MATLAB配置,GPU版本;CPU版本见:Widows下Faster R-CNN的MATALB配置(CPU);
相比较来说,CPU版本相对容易一些,因为涉及到GPU的计算,还需要配置CUDA以及CuDNN;
下面将分成三个部分进行介绍:
- 准备工作:下载caffe、faster rcnn源码、安装cuda、cudnn;
- VS2013编译caffe: 编译支持matlab接口的caffe;
- Faster R-CNN的MATLAB源码测试:
环境配置:
Windows 10
VS 2013
CUDA 7.5, CuDNN V5
MATLAB 2018a
1. 准备工作
1.1 安装CUDA、CuDNN
有关安装CUDA的过程见:Windows下安装CUDA8.0;该文章记录的是安装CUDA 8.0的过程以及在VS上的使用;
附加说明:
建议使用CUDA 7.5,CuDNN V5;
注意:将CuDNN压缩包解压到与下面的caffe与faster rcnn位于同级目录;
1.2 Faster R-CNN的MATLAB源码
下载faster_rcnn的matlab源码:下载地址;
得到./faster_rcnn文件夹;
打开matlab,定位到./faster_rnn/,目录结构如下图所示;
部分文件夹介绍:
experiment/:主要是用于testing/training的脚本;
external/:主要存放成功编译的提供matlab接口的caffe;(后面将花费很多时间在这个上面)
fetch_data/:作者提供的一些用于下载的脚本文件;
其中的都是一些依赖方法,大家可以去看一下;
1.3 Microsoft-Caffe
下载Microsoft提供的caffe:下载地址;
解压得到./caffe文件夹;
目前,我们得到两个文件夹;
1.4 matlab指定C/C++编译器
打开matlab,执行:
mex -setup
选择 Microsoft Visual C++ 2013 (C) 进行C语言编译,如下图:
2. VS2013编译Caffe
2.1 CommonSettings.props
打开./caffe/windows/
,找到CommonSettings.props.example
文件,复制后,将名称改为CommonSettings.props
,如下图:
使用Notepad打开·./caffe/windows/CommonSettings.props
,根据自己的配置,做如下修改:
- 第一处红框:使用CUDA加速计算、仅使用CPU计算,两者选其一;由于我们配置GPU,CUDA版本7.5,因此配置如图;
- 第二处红框:提供matlab接口;
- 第三处红框:指定CuDNN V5的路径,我的配置路径如图所示;也就是说将下载好的CuDNN压缩包解压到
G:\ObjectDetection\Faster R-CNN\Faster R-CNN_GPU
中; - 第四处红框:修改两个位置,一个是MATLAB的安装路径,另一个如图;
补充说明:
有关<CudaArchitecture>compute_35,sm_35;compute_52,sm_52</CudaArchitecture>
,可以修改为与自己显卡相对应的计算能力,提示说可以减少编译时间;
有关显卡的计算能力查询,见:英伟达GPU显卡计算能力评估(深度学习);
2.2 项目-属性配置
修改完成,使用VS2013打开./caffe/windows/Caffe.sln
,双击即可;
打开之后,将Debug模式调成Release模式;(在调试的过程中,可能会重新加载项目,注意需要调整成Release)
之后,
libcaffe项目右键—> 属性—>配置属性—> C/C++ —> 常规,将将警告视为错误修改为否;
否则,编译libcaffe时会报下面的错误;
提示出现:error C2220:...,表示alt_sstream_impl.hpp文件编码格式错误;解决方法是:双击错误信息,弹出错误提示信息,确定后打开一个alt_sstream_impl.hpp文件,然后Ctrl+S进行保存即可;
2.3 添加roi_pooling_layer
打开解决方案资源管理器,
在项目libcaffe中添加roi_pooling_layer.cu
, roi_pooling_layer.cpp
, roi_pooling_layer.hpp
:
libcaffe/cu/layers/
右键—>添加—>现有项,添加./caffe/src/caffe/layers/roi_pooling_layers.cu
文件;libcaffe/include/layers/
右键—>添加—>现有项,添加加./caffe/include/caffe/layers/roi_pooling_layers.hpp
文件;libcaffe/src/layers/
右键—>添加—>现有项,添加./caffe/src/caffe/layers/roi_pooling_layers.cpp
文件;
2.4 编译libcaffe
选中项目libcaff,右键—> 重新生成;
首先会自动还原NuGet包,然后生成成功;
======== 全部重新生成: 成功 1 个,失败 0 个,跳过 0 个 ==========
(如果出现错误(不包含警告),仔细检查上面配置是否正确;)
2. 5 编译matcaffe
如果上面幸运的话,没出什么错,那这里也不会遇到什么麻烦了;
类似重新生成libcaffe,以同样的方式,选择matcaffe,右键—> 生成;
成功后,输出:
========== 生成: 成功 2 个,失败 0 个,最新 1 个,跳过 0 个 ==========
到目前为止,我们已经有了四个文件夹,如下图所示:
./caffe/
:表示microsoft提供的caffe;./cuda/
:表示CuDNN V5的文件,解压到该处;./faster_rcnn/
:表示faster r-cnn的matlab源码;./NugetPackages/
:就是在编译libcaffe时还原出来的NuGet包;- 另外,
./caffe/Build/x64/Release/
下就是得到caffe;
其中,./caffe/Build/文件夹就是编译caffe得到文件;
如果在./caffe/Build/x64/Release/matcaffe+caffe/private/文件夹下,有caffe_.mexw64文件表明caffe的matlab接口编译正确;
3. Faster R-CNN的MATLAB源码测试
3.1 external
在Faster R-CNN的源码中,我们看到有./faster_rcnn/external/caffe/
文件夹,该文件夹是为了存放编译好的caffe;
而在这里,并不打算将编译好的caffe复制到该文件夹下,而是通过设置系统环境变量和添加matlab搜索路径;
具体步骤如下:
- 将
./caffe/Build/x64/Release/
添加到系统变量的path中; - 将
./caffe/Build/x64/Release/matcaffe/
添加到matlab的搜索路径中; - 将
./caffe/matlab/+caffe/
文件夹(不包含子文件夹)下的所有.m
文件拷贝到/caffe/Build/x64/Release/matcaffe/+caffe/
文件夹下; - 重启电脑,完成caffe在matlab中的配置;
3.2 Preparation for Testing
- Run
fetch_data/fetch_caffe_mex_windows_vs2013_cuda65.m
to download a compiled Caffe mex (for Windows only).- Run
faster_rcnn_build.m
- Run
startup.m
其中,
- 第0步:表示下载作者提供的编译好的caffe,因为我们已经编译好了,这里不需要执行;
- 第1步:执行
faster_rcnn_build.m
;
打开faster_rcnn_build.m
后,修改nvmex.m
文件,如下图:
- 按照VS的安装位置修改红框内的路径;
- 第二个红框注意修改CUDA版本;
- 其他变量都是通过系统变量来获取得到的;
补充说明:
在使用Matlab 2018a执行faster_rcnn_build.m
时,总是报错:
LIBCMT.lib(crt0dat.obj) : error LNK2005: _amsg_exit 已经在 MSVCRT.lib(MSVCR120.dll) 中定义
LIBCMT.lib(crt0dat.obj) : error LNK2005: _initterm_e 已经在 MSVCRT.lib(MSVCR120.dll) 中定义
...
不知道怎么解决,幸好没有将之前安装matlab 2016a卸载,使用matlab2016a再执行,就成功通过了;
第2步:执行
start_up.m
文件;这是因为,我们没有将编译好的caffe放在
./external/caffe/
文件夹下;因此,根据错误提示,需要在
./external/caffe/
文件夹下新建一个空白名为matlab
的文件夹;然后,再执行
start_up.m
,就不会报错了;
3.2 Testing Demo
- Run
fetch_data/fetch_faster_rcnn_final_model.m
to download our trained models.- Run
experiments/script_faster_rcnn_demo.m
to test a single demo image.
其中,
第0步:下载作者提供的训练好的模型文件;
其中下载链接好像需要翻墙,如果有需要的话,可以从这里下载:下载地址,提取码:62n6;
下载完成后,解压到./faster_rcnn/中,覆盖原来的./faster_rcnn/output/文件夹,以及多出了五张图片;
第1步:执行脚本文件
experiments/script_faster_rcnn_demo.m
,测试;当然该脚本中的参数,可以适当调整;
由于我的笔记本不行,即使换成ZF-Net也跑步了,检测的结果了,结果应该和Widows下Faster R-CNN的MATALB配置(CPU)是一致;
Widows下Faster R-CNN的MATALB配置(GPU)的更多相关文章
- Widows下Faster R-CNN的MATALB配置(CPU)
目录 1. 准备工作 2. VS2013编译Caffe 3. Faster R-CNN的MATLAB源码测试 说实话,费了很大的劲,在调试的过程中,遇到了很多的问题: 幸运的是,最终还是解决了问题: ...
- widows下 python环境变量配置
widows下 python环境变量配置 便于cmd命令行操作,例如:直接进入Python解释器环境.使用pip安装模块等.
- ubuntu下升级R版本
ubuntu下升级R版本 在测试<机器学习 实用案例解析>一书的邮件分类代码时,windows系统下rstudio中无法读取特殊字符,在ubuntu下可以.在ubuntu虚拟机下安装t ...
- CentOS下通过yum安装svn及配置
CentOS下通过yum安装svn及配置 1.环境centos5.5 2.安装svnyum -y install subversion 3.配置 建立版本库目录mkdir /www/svndata s ...
- Linux下oracle11gR2系统安装到数据库建立配置及最后oracle的dmp文件导入一站式操作记录
简介 之前也在linux下安装过oralce,可每次都是迷迷糊糊的,因为大脑一片空白,网上随便看见一个文档就直接复制,最后搞了乱七八糟,虽然装上了,却乱得很,现在记录下来,希望能给其他网上朋友遇到问题 ...
- CentOS 6.3下rsync服务器的安装与配置[转]
CentOS 6.3下rsync服务器的安装与配置 一.rsync 简介 Rsync(remote synchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件,也 ...
- CentOS下Samba文件服务器的安装与配置
CentOS下Samba文件服务器的安装与配置 http://blog.csdn.net/limingzhong198/article/details/22064801 一.安装配置 1. 安装sam ...
- Linux 下的权限改变与目录配置
Linux 下的权限改变与目录配置 ./代表本目录的意思. (1):用户与用户组, 1:文件所有者,文件被某一用户所有 2:用户组: 对文件给与一个或者多个用户权限配置 3:其它人: (2):l ...
- r.js合并实践 --项目中用到require.js做生产时模块开发 r.js build.js配置详解
本文所用源代码已上传,需要的朋友自行下载:点我下载 第一步: 全局安装 npm install -g requirejs 第二步: 1.以下例子主要实现功能, 1)引用jq库获取dom中元素文本, ...
随机推荐
- Linux就该这么学--Shell脚本条件语句(二)
1.for条件语句 先读取多个不同的变量值,然后逐一执行同一组命令. 从列表文件中读取主机地址,逐个测试是否在线. 从ipadds.txt中读取主机地址后赋值给HLIST变量后逐个ping列表中的主机 ...
- global 全局变量的用法
说明:i 和foo()都为全局变量,i 是在模块文件顶层注册的,所以为全局变量,他能够在函数内部进行引用而不需要再特意声明是全局变量,且foo()函数也是全局变量 1.当没有局部变量时,print(i ...
- Mac root Operation not permitted
在mac下sudo 拷贝和删除文件时提醒Operation not permitted. 网上查了一些资料,需要执行 chflags nouchg /path/to/item 命令. 赶紧照做, ...
- jxl java工具类,导出excel,导入数据库
1: 引入jxl jar 我使用的为maven管理, <!--Excel工具--> <dependency> <groupId>net.sourceforge.je ...
- HTML5_CSS3仿Google Play垂直菜单
在线演示 本地下载
- STM32 Flash Download failed
笔者使用Keil开发环境对STM32L Discovery进行开发,更新一次firmware后就不能连接目标板了,报错Internal command error Flash download fai ...
- HTML5 拖放:在相册中对照片进行排序
1. [代码]index.html <div class="albums"> <div class="album" id=&qu ...
- JavaScript(3)
var a=90; switch(a){ case "890": window.alert("ok"); break; case 90: window.aler ...
- hdu-2169 Computer(树形dp+树的直径)
题目链接: Computer Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- linux网络编程 inet_aton(); inet_aton; inet_addr;
. inet_aton()是一个改进的方法来将一个字符串IP地址转换为一个32位的网络序列IP地址. . inet_ntoa() 本函数将一个用in参数所表示的Internet地址结构转换成以“.” ...