目标检测算法系列:faster RCNN实现|附python源码!
off999 2024-10-10 07:50 17 浏览 0 评论
目标检测一直是计算机视觉中比较热门的研究领域,有一些常用且成熟的算法得到业内公认水平,比如RCNN系列算法、SSD以及YOLO等。如果你是从事这一行业的话,你会使用哪种算法进行目标检测任务呢?在我寻求在最短的时间内构建最精确的模型时,我尝试了其中的R-CNN系列算法,如果读者们对这方面的算法还不太了解的话,建议阅读 《目标检测算法图解:一文看懂RCNN系列算法》 。在掌握基本原理后,下面进入实战部分。
本文将使用一个非常酷且有用的数据集来实现faster R-CNN,这些数据集具有潜在的真实应用场景。
私信菜鸟007即可获取惊喜大礼包!嘻嘻嘻
问题陈述
数据来源于医疗相关数据集,目的是解决血细胞检测问题。任务是通过显微图像读数来检测每张图像中的所有红细胞(RBC)、白细胞(WBC)以及血小板。最终预测效果应如下所示:
选择该数据集的原因是我们血液中RBC、WBC和血小板的密度提供了大量关于免疫系统和血红蛋白的信息,这些信息可以帮助我们初步地识别一个人是否健康,如果在其血液中发现了任何差异,我们就可以迅速采取行动来进行下一步的诊断。
通过显微镜手动查看样品是一个繁琐的过程,这也是深度学习模式能够发挥重要作用的地方,一些算法可以从显微图像中分类和检测血细胞,并且达到很高的精确度。
本文采用的血细胞检测数据集可以从 这里下载,本文稍微修改了一些数据:
- 边界框已从给定的.xml格式转换为.csv格式;
- 随机划分数据集,得到训练集和测试集;
这里使用流行的Keras框架构建本文模型。
系统设置
在真正进入模型构建阶段之前,需要确保系统已安装正确的库和相应的框架。运行此项目需要以下库:
- pandas
- matplotlib
- tensorflow
- keras – 2.0.3
- numpy
- opencv-python
- sklearn
- h5py
对于已经安装了Anaconda和Jupyter的电脑而言,上述这些库大多数已经安装好了。建议从 此链接下载 requirements.txt文件,并使用它来安装剩余的库。在终端中键入以下命令来执行此操作:
pip install -r requirement.txt
系统设置好后,下一步是进行数据处理。
数据探索
首先探索所拥有的数据总是一个好开始(坦率地说,这是一个强制性的步骤)。对数据熟悉有助于挖掘隐藏的模式,还可以获得对整体的洞察力。本文从整个数据集中创建了三个文件,分别是:
train_images test_images train.csv
读取 .csv 文件并打印出前几行:
# importing required libraries import pandas as pd import matplotlib.pyplot as plt %matplotlib inline from matplotlib import patches # read the csv file using read_csv function of pandas train = pd.read_csv(‘train.csv’) train.head()
训练文件中总共有6列,其中每列代表的内容如下:
image_names cell_type xmin xmax ymin ymax
下面打印出一张图片来展示正在处理的图像:
# reading single image using imread function of matplotlib image = plt.imread('images/1.jpg') plt.imshow(image)
上图就是血细胞图像的样子,其中,蓝色部分代表WBC,略带红色的部分代表RBC。下面看看整个训练集中总共有多少张图像和不同类型的数量。
# Number of classes train['cell_type'].value_counts()
结果显示训练集有254张图像。
# Number of classes train['cell_type'].value_counts()
结果显示有三种不同类型的细胞,即RBC,WBC和血小板。最后,看一下检测到的对象的图像是怎样的:
fig = plt.figure() #add axes to the image ax = fig.add_axes([0,0,1,1]) # read and plot the image image = plt.imread('images/1.jpg') plt.imshow(image) # iterating over the image for different objects for _,row in train[train.image_names == "1.jpg"].iterrows(): xmin = row.xmin xmax = row.xmax ymin = row.ymin ymax = row.ymax width = xmax - xmin height = ymax - ymin # assign different color to different classes of objects if row.cell_type == 'RBC': edgecolor = 'r' ax.annotate('RBC', xy=(xmax-40,ymin+20)) elif row.cell_type == 'WBC': edgecolor = 'b' ax.annotate('WBC', xy=(xmax-40,ymin+20)) elif row.cell_type == 'Platelets': edgecolor = 'g' ax.annotate('Platelets', xy=(xmax-40,ymin+20)) # add bounding boxes to the image rect = patches.Rectangle((xmin,ymin), width, height, edgecolor = edgecolor, facecolor = 'none') ax.add_patch(rect)
上图就是训练样本示例,从中可以看到,细胞有不同的类及其相应的边界框。下面进行模型训练,本文使用 keras_frcnn库来训练搭建的模型以及对测试图像进行预测。
faster R-CNN实现
为了实现 faster R-CNN算法,本文遵循 此Github存储库 中提到的步骤。因此,首先请确保克隆好此存储库。打开一个新的终端窗口并键入以下内容以执行此操作:
git clone https://github.com/kbardool/keras-frcnn.git
并将 train_images 和 test_images 文件夹以及 train.csv 文件移动到该存储库目录下。为了在新数据集上训练模型,输入的格式应为:
filepath,x1,y1,x2,y2,class_name
其中:
- filepath是训练图像的路径;
- x1是边界框的xmin坐标;
- y1是边界框的ymin坐标;
- x2是边界框的xmax坐标;
- y2是边界框的ymax坐标;
- class_name是该边界框中类的名称;
这里需要将 .csv 格式转换为 .txt 文件,该文件具有与上述相同的格式。创建一个新的数据帧,按照格式将所有值填入该数据帧,然后将其另存为 .txt 文件。
data = pd.DataFrame() data['format'] = train['image_names'] # as the images are in train_images folder, add train_images before the image name for i in range(data.shape[0]): data['format'][i] = 'train_images/' + data['format'][i] # add xmin, ymin, xmax, ymax and class as per the format required for i in range(data.shape[0]): data['format'][i] = data['format'][i] + ',' + str(train['xmin'][i]) + ',' + str(train['ymin'][i]) + ',' + str(train['xmax'][i]) + ',' + str(train['ymax'][i]) + ',' + train['cell_type'][i] data.to_csv('annotate.txt', header=None, index=None, sep=' ')
下一步进行模型训练,使用 train_frcnn.py 文件来训练模型。
cd keras-frcnn python train_frcnn.py -o simple -p annotate.txt
由于数据集较大,需要一段时间来训练模型。如果条件满足的话,可以使用GPU来加快训练过程。同样也可以尝试减少 num_epochs 参数来加快训练过程。
模型每训练好一次(有改进时),该特定时刻的权重将保存在与“model_frcnn.hdf5”相同的目录中。当对测试集进行预测时,将使用到这些权重。
根据机器的配置,可能需要花费大量时间来训练模型并获得权重。建议使用本文训练大约500个时期的权重作为初始化。可以从 这里 下载这些权重,并设置好相应的路径。
因此,当模型训练好并保存好权重后,下面进行预测。 Keras_frcnn 对新图像进行预测并将其保存在新文件夹中,这里只需在 test_frcnn.py 文件中进行两处更改即可保存图像:
- 从该文件的最后一行删除注释:
- cv2.imwrite('./ results_imgs / {}。png'.format(idx),img);
- 在此文件的倒数第二行和第三行添加注释:
- #cv2.imshow('img',img) ;
- #cv2.waitKey(0);
使用下面的代码进行图像预测:
python test_frcnn.py -p test_images
最后,检测到对象的图像将保存在“results_imgs”文件夹中。以下是本文实现faster R-CNN后预测几个样本获得的结果:
结果1
结果2
结果3
结果4
总结
R-CNN算法确实是用于对象检测任务的变革者,改变了传统的做法,并开创了深度学习算法。近年来,计算机视觉应用的数量突然出现飙升,而R-CNN系列算法仍然是其中大多数应用的核心。
Keras_frcnn 也被证明是一个很好的对象检测工具库,在本系列的下一篇文章中,将专注于更先进的技术,如YOLO,SSD等。
相关推荐
- 真的没想到这个python装饰器还能这么写,见也没见过!
-
引言众所周知,python中,装饰器是非常好玩的,你能够在很多场景中看到它。有很多人可能经常会使用他人设计的装饰器,自己却很少设计过几个装饰器。当然也不乏有的大神非常善于设计装饰器。但不管如何,装饰...
- Python 开发必知的 30 款工具(python语言的开发工具)
-
全面解析开发者在Python开发各个阶段可使用的核心工具热门开源工具Python开发涉及多个阶段,因此需要多种工具来管理:依赖管理:pip、Conda和Poetry是常见的选择。性能分析:...
- 快到飞起的Python包管理工具UV:从环境创建到PyPI发布的终极指南
-
尊敬的诸位!我是一名专注于嵌入式开发的物联网工程师。关注我,持续分享最新物联网与AI资讯和开发实战。期望与您携手探寻物联网与AI的无尽可能。"又在等pip安装包?配置国内镜像源也解决不了的...
- Python输出语句print()(python输出语句print(3+5))
-
Python中的输出语句主要通过内置函数print()实现,它可以灵活输出文本、变量、表达式结果等内容到控制台或其他文件。以下是详细介绍及示例:一、print()基本语法print(*object...
- Python range 函数实用指南(python range函数的用法)
-
对话实录小白:(抓狂)我写了foriinrange(5):,为什么只到4?专家:(推眼镜)range是左闭右开区间!记住:包含起点,不包含终点!基础用法三连击1.标准用法#生成0-4p...
- 3个实用的Pycharm小技巧(pycharm新手教程)
-
前言当我们用Pycharm来编写python代码的时候,你是否留意过以下三个技巧,接下来分享给大家。1.技巧一:Pycharm添加addsourcefolder操作1.1需求:我有一个项目,是...
- python从入门到脱坑 输入与输出——print()函数
-
大家好今天开始系统的讲解一些入门课程,遇到不会的也不用想太多,跟着写一遍,学习到新内容是你就会明白.以下是针对Python初学者的print()函数详解,从基础到实用技巧,配合清晰示例:一、最基础用法...
- Python进阶-day11:并发编程基础(python处理高并发)
-
一、学习目标理解线程和进程的区别及其应用场景。掌握Python中threading模块的基本用法。能够编写一个多线程下载器,应用并发编程知识。二、学习内容与时间安排上午(2小时):理论学习1....
- Excel合并100个表格要1小时?Python3秒搞定!附代码
-
###**Python3秒合并100个Excel表格(附完整代码)****别再手动复制粘贴了!用Python一键批量合并,效率提升1200倍!**---####**适用场景**-每月汇...
- GIL锁也拦不住!这个多进程方案让python速度提升400%
-
引言"你的python程序怎么卡死了?"当产品经理第3次拍我桌子时,我终于意识到——在200万行的数据清洗任务面前,GIL锁正在把我的8核CPU变成单核计算器...提前准备为了查看核心...
- Python之进度条模块tqdm使用方法(python制作进度条可运行的代码)
-
tqdm是一个进度条模块,可以很好的描述一个任务的执行过程,并且使用起来也非常方便首先介绍tqdm常用参数:desc-进度条标题total-迭代总次数ncols-进度条总长度ascii-使用A...
- Python 中制作神奇的动态进度条(python编写进度条)
-
在本教程中,我们将学习使用三个用于在Python中创建进度条的流行库:TQDM、alive-progress、progressbar。进度条可以在视觉上为用户提供有关任务进度的反馈,如文件下载、数...
- 用Python编制模拟简单的进度条(python2 进度条)
-
模拟实现进度条很多人经常在各种视频软件里面看到进度条对比,尤其是我们很多技术、数据走在世界的前列,通过这种展示出来,很是振奋、很激动、很有成就感。很多工具都能实现的,我们今天用python模拟看看。...
- 一日一技:python中的string.encode()方法
-
string.encode()方法string.encode()方法返回给定字符串的编码形式,从Python3.0开始,字符串以Unicode格式存储,即字符串中的每个字符都由一个代码点表示。因此...
- python中字符串的操作(python字符串的基本处理)
-
字符串:英文str。表现形式有4种:‘xs’、“xs”、“”“xsxs”“”、‘’‘‘xxx’’’,三引号有个特殊功能,表示注释,跟#一样的功能,(如果字符串本身就有单则不可用单定义...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 真的没想到这个python装饰器还能这么写,见也没见过!
- Python 开发必知的 30 款工具(python语言的开发工具)
- 快到飞起的Python包管理工具UV:从环境创建到PyPI发布的终极指南
- Python输出语句print()(python输出语句print(3+5))
- Python range 函数实用指南(python range函数的用法)
- 3个实用的Pycharm小技巧(pycharm新手教程)
- python从入门到脱坑 输入与输出——print()函数
- Python进阶-day11:并发编程基础(python处理高并发)
- Excel合并100个表格要1小时?Python3秒搞定!附代码
- GIL锁也拦不住!这个多进程方案让python速度提升400%
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python自定义函数 (53)
- python进度条 (67)
- python的for循环 (56)
- python串口编程 (60)
- python写入txt (51)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python qt (52)
- python人脸识别 (54)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- centos7安装python (53)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)