利用Fast RCNN训练自己的数据做无人机检测(一)

2024-05-30 05:58

本文主要是介绍利用Fast RCNN训练自己的数据做无人机检测(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

学习计算机视觉,深度学习快一年了,第一次写博客,想记录自己学习的过程,深度学习作目标检测的模型已经有很多,包括RCNN, Fast RCNN, YOLO, SSD等,本次实验室利用Fast RCNN做目标检测,数据集是采集的大疆四旋翼无人机,后面会继续对其他模型进行训练,先给出实验检测的效果。

这里写图片描述
这里写图片描述

一. Fast RCNN模型特点

  1. 去除了R-CNN中冗余的特征提取,将整张图像输入神经网络进行一次特征提取:用ROI pooling层取代最后一个max pooling层,同时引入bbox 回归层,提取相应的建议proposal特征。
  2. Fast RCNN网络末尾采用的是并行的两个连接层,cls score层和bbox score层,可同时输出分类结果和回归结果,第一次实现了end -to -end的多任务训练。
  3. 下面给出Fast RCNN的网络结构
    这里写图片描述
    二. Fast RCNN模型下载
  4. 从GitHub上下载fast_rcnn的python代码,https://github.com/rbgirshick/fast-rcnn
  5. 由于我是在自己笔记本上(windows下)跑的,因此需要首先利用vs生成pycaffe库,windows版本的caffe没有编译roi pooling layer库,需要在libcaffe.vcxproj中手动添加。
  6. 生成cython_bbox.pyd和cython_nms.pyd库
    用文本编辑器打开 fast_rcnn_root/lib/utils/nms.pyx,将第25行的np.int_t修改为np.intp_t
    用文本编辑器打开 fast_rcnn_root/lib/setup.py,将第18行和第23行的 “-Wno-cpp”,’’-Wno-unused-function’'指令删除,只留下空的中括号[ ]即可。
    打开cmd,定位至fast_rcnn_root_lib,执行python setup.py install
    如果提示Unable to find vcvarsall.bat 的话,执行下列指令:
    SET VS90COMNTOOLS=%VS110COMNTOOLS%
    setup.py安装完成后,到python_root/Lib/site-package/utils中可以找到两个文件
    cython_bbox.pyd和cython_nms.pyd,把这两个文件复制到fast_rcnn_root/lib/utils中
  7. 要是想运行fast_rcnn自带的model,需要下载相应的训练好的caffemodel,具体方法参见文件夹中的README.md或其他人的博客。

三. 准备训练数据
1.我的训练数据文件夹如下图所示
这里写图片描述

其中label/label.txt里面为Imageset中对应的图片信息,包括roi的bbox位置以及图片名字和所属类别(bird,UAV,plane)三类,每个bbox对应一行,如果一个训练图片中有多个roi,那么此处就有多行,如第5、6行所示
这里写图片描述

2.selective search为每张训练图片提取建议框,我是用c++写的,提取出来的每张图片的bboxes 直接写入了txt文本框中,首先给出bboxes的格式,分别对应【xmin, ymin, xmax, ymax】
这里写图片描述

3.然后给出利用label.txt读取图片信息,生成bboxes的代码:

vector<string> read_imagepath(string label_path, string image_rootpath){vector<string> filepath_array;ifstream fin(label_path.c_str());string line;getline(fin, line);string previous_line;while (getline(fin, line)){string filepath = image_rootpath;int end = line.find_last_of(' ');int begin = line.substr(0, end - 1).find_last_of(' ');string current_line = line.substr(begin + 1, end - begin);if (current_line != previous_line){filepath.append(current_line);filepath_array.push_back(filepath);}previous_line = current_line;}fin.close();  //关闭文件return filepath_array;
}
	float sigma = 0.8;       //高斯滤波float k = 100;   //控制合并后的区域大小int min_size = 40;  //用于后处理参数,当区域内像素个数小于min_size时,选择与其差异最小的C合并string filepath = "F:\\GitHub\\UAV_data\\label\\label4.txt";string imagepath = "F:\\GitHub\\UAV_data\\Imageset\\";vector<string> filepath_array = read_imagepath(filepath, imagepath);for (int i = 0; i < filepath_array.size(); i++){int end = filepath_array[i].find(".");int begin = filepath_array[i].find_last_of("\\");string boundingboxname = filepath_array[i].substr(begin + 1, end - begin - 1);string bboxesname = string("BoundingBoxes\\") + boundingboxname+string("bboxes.txt");Mat img = imread(filepath_array[i]);image<rgb>* imginput = matToImage(img);  //将矩阵转成image类int region_nums;//得到选择搜索区域的包围框的边界信息,左上和右下顶点xy值int* BB = generate_bounding_boxes(imginput, sigma, k, min_size, &region_nums);FILE* f;f = fopen(bboxesname.c_str(), "w");for (int i = 0; i < region_nums; i++){fprintf(f, "%d %d %d %d \n", BB[4 * i + 0], BB[4 * i + 1], BB[4 * i + 2], BB[4 * i + 3]);}fclose(f);

4.通过ss的提取,生成了每张图片的建议框信息,放在selective_search文件夹中

这里写图片描述
数据分享链接链接:https://pan.baidu.com/s/1AIRjXBuC-S7FAhnhJLJuQA
提取码:bovx

这篇关于利用Fast RCNN训练自己的数据做无人机检测(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

【服务器运维】MySQL数据存储至数据盘

查看磁盘及分区 [root@MySQL tmp]# fdisk -lDisk /dev/sda: 21.5 GB, 21474836480 bytes255 heads, 63 sectors/track, 2610 cylindersUnits = cylinders of 16065 * 512 = 8225280 bytesSector size (logical/physical)

SQL Server中,查询数据库中有多少个表,以及数据库其余类型数据统计查询

sqlserver查询数据库中有多少个表 sql server 数表:select count(1) from sysobjects where xtype='U'数视图:select count(1) from sysobjects where xtype='V'数存储过程select count(1) from sysobjects where xtype='P' SE

基于CTPN(tensorflow)+CRNN(pytorch)+CTC的不定长文本检测和识别

转发来源:https://swift.ctolib.com/ooooverflow-chinese-ocr.html chinese-ocr 基于CTPN(tensorflow)+CRNN(pytorch)+CTC的不定长文本检测和识别 环境部署 sh setup.sh 使用环境: python 3.6 + tensorflow 1.10 +pytorch 0.4.1 注:CPU环境

YOLO v3 训练速度慢的问题

一天一夜出了两个模型,仅仅迭代了200次   原因:编译之前没有将Makefile 文件里的GPU设置为1,编译的是CPU版本,必须训练慢   解决方案: make clean  vim Makefile make   再次训练 速度快了,5分钟迭代了500次

数据时代的数字企业

1.写在前面 讨论数据治理在数字企业中的影响和必要性,并介绍数据治理的核心内容和实践方法。作者强调了数据质量、数据安全、数据隐私和数据合规等方面是数据治理的核心内容,并介绍了具体的实践措施和案例分析。企业需要重视这些方面以实现数字化转型和业务增长。 数字化转型行业小伙伴可以加入我的星球,初衷成为各位数字化转型参考库,星球内容每周更新 个人工作经验资料全部放在这里,包含数据治理、数据要

如何在Java中处理JSON数据?

如何在Java中处理JSON数据? 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将探讨在Java中如何处理JSON数据。JSON(JavaScript Object Notation)作为一种轻量级的数据交换格式,在现代应用程序中被广泛使用。Java通过多种库和API提供了处理JSON的能力,我们将深入了解其用法和最佳

将一维机械振动信号构造为训练集和测试集(Python)

从如下链接中下载轴承数据集。 https://www.sciencedirect.com/science/article/pii/S2352340918314124 import numpy as npimport scipy.io as sioimport matplotlib.pyplot as pltimport statistics as statsimport pandas

两个基因相关性CPTAC蛋白组数据

目录 蛋白数据下载 ①蛋白数据下载 1,TCGA-选择泛癌数据  2,TCGA-TCPA 3,CPTAC(非TCGA) ②蛋白相关性分析 1,数据整理 2,蛋白相关性分析 PCAS在线分析 蛋白数据下载 CPTAC蛋白组学数据库介绍及数据下载分析 – 王进的个人网站 (jingege.wang) ①蛋白数据下载 可以下载泛癌蛋白数据:UCSC Xena (xena

中国341城市生态系统服务价值数据集(2000-2020年)

生态系统服务反映了人类直接或者间接从自然生态系统中获得的各种惠益,对支撑和维持人类生存和福祉起着重要基础作用。目前针对全国城市尺度的生态系统服务价值的长期评估还相对较少。我们在Xie等(2017)的静态生态系统服务当量因子表基础上,选取净初级生产力,降水量,生物迁移阻力,土壤侵蚀度和道路密度五个变量,对生态系统供给服务、调节服务、支持服务和文化服务共4大类和11小类的当量因子进行了时空调整,计算了

【计算机网络篇】数据链路层(12)交换机式以太网___以太网交换机

文章目录 🍔交换式以太网🛸以太网交换机 🍔交换式以太网 仅使用交换机(不使用集线器)的以太网就是交换式以太网 🛸以太网交换机 以太网交换机本质上就是一个多接口的网桥: 交换机的每个接口考研连接计算机,也可以理解集线器或另一个交换机 当交换机的接口与计算机或交换机连接时,可以工作在全双工方式,并能在自身内部同时连通多对接口,使每一对相互通信的计算机都能像