windows10下编译 fast rcnn_windows fast rcnn-程序员宅基地

技术标签: C++  机器学习  caffe  深度学习  fast rcnn  

Windows下训练fast rcnn

一.准备

1.     caffe-master:windows的caffe安装包。https://github.com/Microsoft/caffe

这个模型对caffe有要求,需要roi_pooling这个层,所以你的去caffe/src/caffe/layers看下是否有着两个文件。如果没有这两个文件,后面会遇到错误,如图:


2.     我的caffe是配置的无GPU的,caffe配置可以看下我的博客。

http://blog.csdn.net/qq_34220460/article/details/59112649

3.     fast r-cnn:https://github.com/rbgirshick/fast-rcnn

4.     下载模型文件,也就是fast rcnn训练完后的模型文件。其实在fast rcnn文件中有脚本下载,但那是linux下的脚本,我们是在windows下。我给个别人的链接:http://pan.baidu.com/s/1kTzQYgR。下载完成后,请将3个文件夹放置在fast_rcnn/data中。

5.     然后是配置python接口,这个自己去配置下吧!

6.     打开cmd,输入sudo pip install cython和 sudo pipinstall easydict来安装cython和easydict,如果你使用的是Anaconda,cython默认是安装上了的。 
如果提示安装失败,可能是由于你的pip的版本过低,请先使用 
pip install pip --upgrade 
升级你的pip。

7.     还得再去安装opencv,去opencv官网下载并安装windows下的版本,链接:https://sourceforge.net/projects/opencvlibrary/files/opencv-win/3.2.0/opencv-3.2.0-vc14.exe/download

还要配置opencv的环境,将opencv的bin添加到系统环境变量中,最好看下链接,因为还有其他的要配置:http://jingyan.baidu.com/article/c45ad29c3e0e2d051753e204.html


不知这个,我们还要将opencv/build/python/2.7/x64 下的从cv2.pyd复制到python/libs/site-packages下,因为我们后面需要cv2这个模块,否则会报错,说no modules named cv2.

 

二.编译

  1.将caffe_master/Build/x64/Relase/pycaffe目录下的caffe ,复制到fast_rcnn/caffe-fast-rcnn中。

 2.用文本编辑器打开fast_rcnn/lib/utils/nms.pyx,将第25行的np.int_t修改为np.intp_t。

 3. 用文本编辑器打开fast_rcnn/lib/setup.py,将第18行和23行的 
"-Wno-cpp", "-Wno-unused-function"指令删除,只留下空的中括号[]即可。

4.  打开cmd,定位至fast_rcnn/lib目录中,执行pythonsetup.py install。 
如果提示Unable to find vcvarsall.bat的话,请输入以下指令: 
VS2012:SET VS90COMNTOOLS=%VS110COMNTOOLS% 
VS2013:SET VS90COMNTOOLS=%VS120COMNTOOLS% 
setup.py安装完成后,到python_root/Lib/site-packages/utils中可以找到两个文件cython_bbox.pyd和cython_nms.pyd,把这两个文件复制到fast_rcnn_root/lib/utils中。

5. 定位至fast_rcnn,执行python tools/demo.py,等待demo的结果吧!

 

三.问题解决

看似就上面这一点步骤,其实我们也是经过许多错误之后才总结出来的,我们也是有努力的。

1.     编译过程中,曾经遇到 no module named cython esaydict and cv2

这个就是上面你没有安装这些依赖包,在opecv的环境变量配置好了,可以到opencv\build\python\2.7\x64目录下看到cv2,如图:


2.     在此之后,就是上面所讲的错误。

如果提示Unable to find vcvarsall.bat的话,请输入以下指令: 
VS2012:SET VS90COMNTOOLS=%VS110COMNTOOLS% 
VS2013:SET VS90COMNTOOLS=%VS120COMNTOOLS% 

3.     就是遇到Check failed: registry.count(type) == 1 (0 vs. 1) Unknownlayer type: ROIPooling,如图:


,这个就有了前面为啥必须要有那两个文件,因为在windows下那两个文件没有被编译,所以我们需要把它加入到libcaffe下,cpp文件加入到src,。cu 文件加入到cu下去,还有就是加入头文件,把caffe目录下include/caffe/layers/roi_pooling_layer.hpp加入到include下,如图:


4.如果是no module named cv2, 请按照我们将的配置opencv那样配置,ok!!!

最后再把所有项目进行重新编译。

或许有的人做到了这一步,还是出错了,为什么呢?

或许你跟我一样,被当初的python配置坑了,当时测试python是否成功,不是有import caffe吗?import caffe成功就说明python接口配置成功,我当时是按照网上的一个办法,把这个 caffe master/build/x64/release/pycaffe下的caffe文件复制到了Python安装路径的Libs/site-packages下了,这样importcaffe成功了,但是没有想到的是后面加入了两个文件了,导致编译后的caffe 比之前的caffe多了roi_pooling layer,所以我们要重新把caffe复制到python安装路径的Libs/site-packages下,更新原来的caffe.  如图:


这个时候等结果吧!

结果:

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

智能推荐

oracle 12c 集群安装后的检查_12c查看crs状态-程序员宅基地

文章浏览阅读1.6k次。安装配置gi、安装数据库软件、dbca建库见下:http://blog.csdn.net/kadwf123/article/details/784299611、检查集群节点及状态:[root@rac2 ~]# olsnodes -srac1 Activerac2 Activerac3 Activerac4 Active[root@rac2 ~]_12c查看crs状态

解决jupyter notebook无法找到虚拟环境的问题_jupyter没有pytorch环境-程序员宅基地

文章浏览阅读1.3w次,点赞45次,收藏99次。我个人用的是anaconda3的一个python集成环境,自带jupyter notebook,但在我打开jupyter notebook界面后,却找不到对应的虚拟环境,原来是jupyter notebook只是通用于下载anaconda时自带的环境,其他环境要想使用必须手动下载一些库:1.首先进入到自己创建的虚拟环境(pytorch是虚拟环境的名字)activate pytorch2.在该环境下下载这个库conda install ipykernelconda install nb__jupyter没有pytorch环境

国内安装scoop的保姆教程_scoop-cn-程序员宅基地

文章浏览阅读5.2k次,点赞19次,收藏28次。选择scoop纯属意外,也是无奈,因为电脑用户被锁了管理员权限,所有exe安装程序都无法安装,只可以用绿色软件,最后被我发现scoop,省去了到处下载XXX绿色版的烦恼,当然scoop里需要管理员权限的软件也跟我无缘了(譬如everything)。推荐添加dorado这个bucket镜像,里面很多中文软件,但是部分国外的软件下载地址在github,可能无法下载。以上两个是官方bucket的国内镜像,所有软件建议优先从这里下载。上面可以看到很多bucket以及软件数。如果官网登陆不了可以试一下以下方式。_scoop-cn

Element ui colorpicker在Vue中的使用_vue el-color-picker-程序员宅基地

文章浏览阅读4.5k次,点赞2次,收藏3次。首先要有一个color-picker组件 <el-color-picker v-model="headcolor"></el-color-picker>在data里面data() { return {headcolor: ’ #278add ’ //这里可以选择一个默认的颜色} }然后在你想要改变颜色的地方用v-bind绑定就好了,例如:这里的:sty..._vue el-color-picker

迅为iTOP-4412精英版之烧写内核移植后的镜像_exynos 4412 刷机-程序员宅基地

文章浏览阅读640次。基于芯片日益增长的问题,所以内核开发者们引入了新的方法,就是在内核中只保留函数,而数据则不包含,由用户(应用程序员)自己把数据按照规定的格式编写,并放在约定的地方,为了不占用过多的内存,还要求数据以根精简的方式编写。boot启动时,传参给内核,告诉内核设备树文件和kernel的位置,内核启动时根据地址去找到设备树文件,再利用专用的编译器去反编译dtb文件,将dtb还原成数据结构,以供驱动的函数去调用。firmware是三星的一个固件的设备信息,因为找不到固件,所以内核启动不成功。_exynos 4412 刷机

Linux系统配置jdk_linux配置jdk-程序员宅基地

文章浏览阅读2w次,点赞24次,收藏42次。Linux系统配置jdkLinux学习教程,Linux入门教程(超详细)_linux配置jdk

随便推点

matlab(4):特殊符号的输入_matlab微米怎么输入-程序员宅基地

文章浏览阅读3.3k次,点赞5次,收藏19次。xlabel('\delta');ylabel('AUC');具体符号的对照表参照下图:_matlab微米怎么输入

C语言程序设计-文件(打开与关闭、顺序、二进制读写)-程序员宅基地

文章浏览阅读119次。顺序读写指的是按照文件中数据的顺序进行读取或写入。对于文本文件,可以使用fgets、fputs、fscanf、fprintf等函数进行顺序读写。在C语言中,对文件的操作通常涉及文件的打开、读写以及关闭。文件的打开使用fopen函数,而关闭则使用fclose函数。在C语言中,可以使用fread和fwrite函数进行二进制读写。‍ Biaoge 于2024-03-09 23:51发布 阅读量:7 ️文章类型:【 C语言程序设计 】在C语言中,用于打开文件的函数是____,用于关闭文件的函数是____。

Touchdesigner自学笔记之三_touchdesigner怎么让一个模型跟着鼠标移动-程序员宅基地

文章浏览阅读3.4k次,点赞2次,收藏13次。跟随鼠标移动的粒子以grid(SOP)为partical(SOP)的资源模板,调整后连接【Geo组合+point spirit(MAT)】,在连接【feedback组合】适当调整。影响粒子动态的节点【metaball(SOP)+force(SOP)】添加mouse in(CHOP)鼠标位置到metaball的坐标,实现鼠标影响。..._touchdesigner怎么让一个模型跟着鼠标移动

【附源码】基于java的校园停车场管理系统的设计与实现61m0e9计算机毕设SSM_基于java技术的停车场管理系统实现与设计-程序员宅基地

文章浏览阅读178次。项目运行环境配置:Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。项目技术:Springboot + mybatis + Maven +mysql5.7或8.0+html+css+js等等组成,B/S模式 + Maven管理等等。环境需要1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。_基于java技术的停车场管理系统实现与设计

Android系统播放器MediaPlayer源码分析_android多媒体播放源码分析 时序图-程序员宅基地

文章浏览阅读3.5k次。前言对于MediaPlayer播放器的源码分析内容相对来说比较多,会从Java-&amp;amp;gt;Jni-&amp;amp;gt;C/C++慢慢分析,后面会慢慢更新。另外,博客只作为自己学习记录的一种方式,对于其他的不过多的评论。MediaPlayerDemopublic class MainActivity extends AppCompatActivity implements SurfaceHolder.Cal..._android多媒体播放源码分析 时序图

java 数据结构与算法 ——快速排序法-程序员宅基地

文章浏览阅读2.4k次,点赞41次,收藏13次。java 数据结构与算法 ——快速排序法_快速排序法