win10+tensorflow faster-RCNN 训练自己的数据集

首先,感谢博客上各路大佬的无私奉献!但是也不得不吐槽下,大佬些写博客的时候能尽量写的对小白友好一点吗?期间遇到各种坑,说多了都是泪啊!话不多说,上正题!

环境:win10+anaconda3+tensorflow1.2.1+python3.6,CPU版本。

源码地址:https://github.com/dBeker/Faster-RCNN-TensorFlow-Python3.5

一 下载源码以及源码环境准备

  1. 肯定是下载源码,配置好相应的环境!anaconda prompt下激活tensorflow环境,包括但不限于安装python包(cython,python-opencv,easydict),反正就是提示缺少什么,就install什么就对了!
  2. GitHub上源码提示有“Checkout this branch”这一步,但我没懂什么意思!没照做,但是也训练成功了,有懂得老哥帮忙解释一下!
  3. setup.py文件修改

        在第16行加入以下代码,(别问我为什么,我只是代码的搬运工)

 

    Extension('lib.utils.cython_bbox', sources=['E:/python/tensorflow/Faster-RCNN-TensorFlow-Python3.5-master/lib/utils/bbox.c','E:/python/tensorflow/Faster-RCNN-TensorFlow-Python3.5-master/lib/utils/bbox.pyx'],include_dirs = [np.get_include(), 'E:/python/tensorflow/Faster-RCNN-TensorFlow-Python3.5-master/lib/utils'],extra_compile_args=[])
  1. 承接步骤1,进入到源码的路径下(cd 自己的路径\Faster-RCNN-TensorFlow-Python3.5-master\data\coco\PythonAPI);分别执行下列命令:
    python setup.py build_ext --inplace
    python setup.py build_ext install

    提示:安装VS2015的库,否则会报错 “error: Unable to find vcvarsall.bat”

  2. 用VS2015编译python3.6代码:这一步对于不是python3.5的小伙伴很关键,因为源码是基于python3.5编译,而在python3.6下运行就会报错,所以必须在python3.6环境下重新编译。编译步骤如下:

        1)打开VS2015 X64 本机工具命令提示符;

         

         2)同样激活tensorflow环境(activate tensorflow),进入到源码的路径下(cd 自己的路径\Faster-RCNN-TensorFlow-Python3.5-master\data\coco\PythonAPI),运行:

python setup.py build_ext --inplace;

              会在 “***\Faster-RCNN-TensorFlow-Python3.5-master\data\coco\PythonAPI\lib\utils”目录下生成cython_bbox.cp36-win_amd64.pyd文件,将该文件复制到“***\Faster-RCNN-TensorFlow-Python3.5-master\lib\utils”下。

        5. 这里下载模型VGG16 ,放入“***\Faster-RCNN-TensorFlow-Python3.5-master\data \ imagenet_weights \ vgg16.ckpt”,记得把文件名从“VGG_16”更改为“VGG16”,这儿坑了我不少时间。再次感谢博主---douminan

二 准备训练集

1.labelimg标注数据

labelimg的使用:https://cloud.tencent.com/developer/news/325876

注意:注意标注的时候一定不要用大写,不要有空格,建议全部用小写字母和数字,感谢博主--beyond_xnsx

2.将自己的数据制作成VOC2007的格式

批量命名文件:https://blog.csdn.net/u011574296/article/details/72956446

制作训练集:https://blog.csdn.net/gaohuazhao/article/details/60871886

注意:VOC2007的格式生成如下图所示:

三 源码修改

Faster-RCNN-TensorFlow-Python3.5-master\lib\datasets\pascal_voc.py文件中,将以下代码中的类别替换为自己数据集的类别,如下图所示。至于某些博客说不能删除类别总数,但是经实际测试,删除了也不影响。

        self._classes = ('__background__',  # always index 0'bird','flower', 'horse')

注意:不要更改'__background__',这个是本身自有的,即你有N类检测目标,实际是N+1,多出来的1类就是背景,所以不能删除'__background__'。

Faster-RCNN-TensorFlow-Python3.5-master\lib\config\config.py中修改训练参数,根据自己情况更改哈,博主也是小白,无法作任何指导。

四 训练

哈哈,终于到激动人心的一刻,成功还是继续躺坑里就看这一步了!

继续在anaconda prompt里,激活tensorflow环境,进入到Faster-RCNN-TensorFlow-Python3.5-master根目录下(跟上述一样,用“cd”命令进入哈,根目录就是能看到一个train.py的文件),执行

python train.py

一般不报错进入到训练环节就是对的哈,训练如下所示。

五 后续测试

由于没有训练结束,所以等待后续更新。。。

由于工作方面不再接触这类事件,所以没有后续了。。。抱歉!

 

主要引用下列博客,再次感谢博客大佬们的无私奉献。

https://blog.csdn.net/beyond_xnsx/article/details/79771690

https://blog.csdn.net/weixin_38124357/article/details/80816288

https://blog.csdn.net/douminan/article/details/82223619

https://blog.csdn.net/gaohuazhao/article/details/60871886

https://blog.csdn.net/u011574296/article/details/72956446

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/256581.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

matlab simulnk笔记07——模块(接地模块group、终止模块terminal、信号合并mux与分解模块demux)

1.接地模块group 2.终止模块terminal 3.信号合并mux 注意:合并仅仅指的是物理上的合并,数学上真正意义上的合并,只是将多个信号放在同一个管道上统一传输给显示终端,但是每个信号之间互不影响,是相

二叉搜索树的插入与删除图解

一、二叉搜索树(BSTree)的概念 二叉搜索树又被称为二叉排序树,那么它本身也是一棵二叉树,那么满足以下性质的二叉树就是二叉搜索树:1、若左子树不为空,则左子树上左右节点的值都小于根节点的值2、若它的右子…

AlienVault Ossim各版本镜像下载地址

AlienVault Ossim各版本镜像下载地址 OSSIM V5.0.3 ISO网盘下载地址 了解Ossim的架构、工作原理和使用方法可以参考我的新书以及http://edu.51cto.com/course/course_id-1186.html 这里提供的视频教程。 本文转自 李晨光 51CTO博客,原文链接:http://blo…

面试总结

lru算法:最近最少使用  1.新数据插入到链表头部;  2.每当缓存命中(即缓存数据被访问),则将数据移到链表头部;  3.当链表满的时候,将链表尾部的数据丢弃。 自定义控件: 1.measu…

win10+anaconda安装tensorflow和keras遇到的坑小结

win10下利用anaconda安装tensorflow和keras的教程都大同小异(针对CPU版本,我的gpu是1050TI的MAX-Q,不知为啥一直没安装成功),下面简单说下步骤。 一 Anaconda安装 一般来说,python选择3.6的,目…

rman备份恢复命令之switch

一 switch 命令 1 switch命令用途 更新数据文件名为rman下镜像拷贝时指定的数据文件名 更新数据文件名为 set newname 命令指定的名字。 2 switch 命令使用前提条件 rman 必须连接到目标数据库 当switch tablespaces、datafiles、tempfiles时,这些文件必须离线 当…

服务核心 - 工具类

虽然类名称为CWHService,我理解更多的是工具函数。 主要接口功能有: 1)SetClipboardString设置字符串到windows剪贴板 2)GetMachineID获取机器标识,网卡地址MD5加密; 3)GetMachineIDEx获取机器标…

现代制造工程课堂笔记07——应力应变分析(考点应力莫尔圆)

目录 选择判断题,简单计算在莫尔圆那里出 一、单向拉伸中的应力应变 手写笔记 选择判断题,简单计算在莫尔圆那里出 一、单向拉伸中的应力应变 、 手写笔记

win10+tensorflow CPU 部署CTPN环境

刚弄明白CTPN部署的时候,CTPN作者刚更新了简易代码版本,看介绍是把代码优化了不需要多的配置。。。感觉好忧伤! 源码地址:https://github.com/eragonruan/text-detection-ctpn/tree/master 新版本地址:https://githu…

css如何实现背景透明,文字不透明?

之前做了个半透明弹层,但设置背景半透明时,子元素包含的字体及其它元素也都变成了半透明。对opacity这个属性认识的不透彻,在这里做一些总结,方便以后使用。 背景透明,文字不透明的解决方法:为元素添加一个…

SQL Server 使用OPENROWSET访问ORACLE遇到的各种坑总结

在SQL Server中使用OPENROWSET访问ORACLE数据库时,你可能会遇到各种坑,下面一一梳理一下你会遇到的一些坑。 1:数据库没有开启"Ad Hoc Distributed Queries"选项,那么你就会遇到下面坑。 SELECT TOP 10 * FROM OPENROWS…

matlab——FFT傅里叶快速变换

目录 一、自身的理解与补充 二、其他参考链接 一、转载:https://blog.csdn.net/u013215903/article/details/48091359 FFT是Fast Fourier Transform(快速傅里叶变换)的简称,这种算法可以减少计算DFT(离散傅里叶变换,关于此更详细的说明见后文)的时间,大大提高了运算效…

win10+tensorflow import cv2 bug解决

https://blog.csdn.net/sinat_21591675/article/details/82595812

设计理念 : popup login 在前后台

popup 意思是一个遮罩层顶在整个网页最前方,在前台设计是这样的,当用户想在那个界面登入时,就可以有一个遮罩层出现。 在employer或admin(后台)操作界面是同个理念,在所有的界面都是有control panel为根节点…

input和raw_input

12345678910python 2#!/usr/bin/env python#coding:utf-8nameraw_input("plese input you name") print namepython3#!/usr/bin/env python#coding:utf-8nameinput("plese input you name") print name本文转自 小小三郎1 51CTO博客,原文链接…

MAATLAB GUI——回调函数的设置(Callbacks)

目录 1.回调函数创建步骤 1)命令窗口中输入guide,创建一个新的GUI界面窗口

是什么时候开始学习gulp了

转自:http://www.ydcss.com/archives/18 简介: gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器;她不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成&#xff1…

011——数组(十一)array_merge array_merge_recursive array_change_key_case

<?php /***/ //array_merge() 将多个数组合并&#xff0c;生成新数组。当键名相同时&#xff0c;后者覆盖前者 /*$array1array(weburl>"bbs.blog.com",webname>"博客"); $array2array(db_hot>"localhost",db_user>"root&qu…