Fast-RCNN阅读笔记

Fast-RCNN是一种改进的目标检测算法,它通过整合分类和回归任务到单一深度学习框架中,提高了检测速度和精度。系统架构包括CNN特征提取、候选框提取、RoIPooling层等关键组件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

公式渲染完整版请移步个人博客

系统架构

7241055-0604990f2705d392.png
structure.png

由于RCNN存在流水线过长,检测速度慢的问题,Fast-RCNN几乎将整个过程置于深度学习的框架下,因此带来了准确率和速度的提升,该系统主要组成部分如上图所示,有:

  • CNN特征提取器:与RCNN不同,该网络的输入为整张图片,输出为特征张量
  • 候选框提取:与RCNN相同使用Selective Search提取候选框,只是候选框通过大小变换后作用于CNN提取出的特征张量中,而不直接作用于图片
  • RoI Pooling层:该层次用于将不同大小的候选框归一化到同一个大小上,然后通过全连接层计算出固定长度的特征向量
  • 分类器:根据特征向量对物品进行分类,列表包括物品类别和背景
  • 回归器:根据特征向量微调候选框位置和大小,最终生成针对候选框的调整因子

该系统对于待识别图片,首先将其使用Selective Search处理获得一系列候选框,随后将其归一化到固定大小,送入CNN网络中提取特征。对于提取出的特征张量,假设其保留了原图片的空间位置信息,将候选框做对应变换后映射到特征张量上,提取出大小不同的候选区域的特征张量。对于每个候选区域的特征张量,使用RoI pooling层将其大小归一化,随后使用全连接层提取固定长度的特征向量。对于该特征向量,分别使用全连接层+softmax和全连接层+回归判断类别并计算原候选框的调整因子。

候选框提取

候选框的提取与RCNN相同,使用Selective Search算法,该算法会提供一系列候选区域框,而不是遍历各种大小的子图,所以速度快于滑动框,Selective Search的具体说明参看RCNN笔记。需要指出的是,该部分是整个网络的速度瓶颈。

CNN特征提取

网络的基本结构是VGG-16网络,相对于原网络,做了以下调整:

  • 最后一个最大值池化层用RoI池化层代替,该池化层可将不同大小的输入池化为统一大小输出。
  • 最后一层全连接层使用两个分裂的全连接层代替,一个用于计算分类,一个用于计算候选框的调整因子
  • 输入改为两个,分别为原图和Selective Search产生的候选框坐标

RoI池化层

RoI池化层用于将不同大小的输入张量池化为固定大小,RoI池化层指定池化窗口的数量为W \times H,每个池化窗口的大小是根据池化区域变化的,例如一张图片的尺寸为w \times h,则每个窗口的大小为\frac{w}{W} \times \frac{h}{H},假设W=4,H=4,有以下例子:

7241055-22759d18c790a66c.png
roi.png

如图左右各有一个大小不同的RoI区域,划分为W \times H个池化窗口,每个池化窗口的大小因原RoI区域尺寸不同而不同,经过RoI池化尺寸变为相同的W \times H

分类器与回归器

分类器和回归器的输入为RoI池化输出的固定大小向量经过两层全连接层后产生的特征向量,分类器用于判断物品属于哪一类(类别+背景),回归器用于计算4个调整因子,调整因子部分内容见RCNN笔记。

模型训练

模型的训练过程与RCNN不同,Fast-RCNN将分类器和回归器的训练统一到深度学习的框架下,在Selective Search提取出候选区域RoI后,所有的训练均在深度学习框架下进行。

批处理

训练使用SGD算法,因此需要提取batch进行训练。batch的提取基于N张图片,每个batch提取\cfrac{R}{N}个区域,每个batch共R个数据。当N较小时,这种提取方法充分的使用了数据局部性,能提高训练速度。在本论文中,有R=128,N=2,即每个batch的数据来自两张图片,共128个RoI数据,其中要求25%的RoI为包含物体的(IoU>0.5),这些RoI被标记为对应类别,剩下的75%的RoI要求IoU在0.1~0.5之间,标记为背景。

多任务代价函数

该网络的输入有两个:

  • 分类结果p=(p_0,p1,...,p_K),共K+1个类别,包括K个物品和背景
  • 调整因子t_k=(t_x^k,t_y^k,t_w^k,t_h^k),调整的方式与RCNN相同

因此,代价函数必须考虑以上两种输出的代价,最终代价函数如下所示:
L(p,u.t_u,v) = L_{cls}(p,u) + \lambda[u \geq 1]L_{loc}(t^u,v)
第一个部分L_{cls}为分类部分的代价函数,使用交叉熵函数,公式如下,其中u为该RoI区域的标记类别,p为神经网络输出的分类向量:
L_{cls}(p,u) = -log(p_u)
第二个部分L_{loc}为调整因子的代价函数,[u \geq 1]表示仅当当前位置不是背景时才考虑该部分代价, 超参数\lambda表示两个部分之间的权重,论文中取1。L_{loc}如下所示,其中t为网络输出的调整因子,v为目标调整因子。

$$
L_{loc}(t^u,v) = \sum\limits_{i \in \{x,y,w,h\}}smooth_{L_1}(t^u_i-v_i) \\
smooth_{L_1}=\begin{cases}0.5x^2 & |x| <1 \\ |x|-0.5&otherwise\end{cases}
$$

训练过程

由上,可以归纳Fast_RCNN的训练过程:

  1. 获取预训练模型
  2. 取N=2张图片前向传播,按批处理部分所述进行前向传播,并计算代价函数
  3. 根据代价函数反向传播更新权值跳转到2

其中,RoI pooling层的反向传播与Pool层相同,详情见CNN的反向传播,不同RoI的反向传播结果对应位置相加后再反向传播到前一层。为了达成尺寸不变性,还在训练中使用了图像金字塔和数据增强的方法。

Faster R-CNN和Mask R-CNN都是基于卷积神经网络(CNN)的目标检测方法。 Faster R-CNN是RPN(Region Proposal Network)和Fast R-CNN的结合,其中RPN用于在特征图上生成候选框,然后通过Fast R-CNN进行具体的分类和回归。Mask R-CNNFaster R-CNN的基础上增加了一个Mask Prediction Branch,用于预测目标的精确分割掩码。 Faster R-CNN的工作流程是先使用RPN生成候选框,然后通过ROI Pooling将每个候选框内的特征提取出来,最后使用分类器和回归器对提取的特征进行分类和位置修正。而Mask R-CNN在这个基础上引入了ROI Align操作,可以更精确地对候选框进行特征提取,然后通过Mask Prediction Branch生成每个目标的精确分割掩码。 要理解Faster R-CNN和Mask R-CNN,可以从R-CNN开始学习。R-CNN是目标检测领域的开山之作,它通过选择性搜索(Selective Search)算法提取候选框,并使用CNN对这些候选框进行分类和位置修正。Fast R-CNN是对R-CNN的改进,将选择性搜索替换为ROI Pooling操作,提高了检测速度和准确性。Faster R-CNN进一步将RPN引入Fast R-CNN中,用于生成候选框,提高了检测的效率。 因此,可以说Faster R-CNN是RPN和Fast R-CNN的组合,而Mask R-CNN是在Faster R-CNN的基础上增加了一个Mask Prediction Branch和ROI Align操作,用于更精确地进行目标的分割。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [神经网络学习笔记7——目标检测,语义分割和实例分割中的RCNNFast RCNNFaster RCNN、FCN和Mask RCNN](https://blog.youkuaiyun.com/qq_45848817/article/details/127965649)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值