zoukankan      html  css  js  c++  java
  • 从R-CNN到FAST-RCNN再到Faster R-CNN

    (Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks)

     

    R-CNN:

    (1)输入测试图像;

    (2)利用selective search 算法在图像中从上到下提取2000个左右的Region Proposal

    (3)将每个Region Proposal缩放(warp)成227*227的大小并输入到CNN,将CNN的fc7层的输出作为特征;

    (4)将每个Region Proposal提取的CNN特征输入到SVM进行分类;

    (5)对于SVM分好类的Region Proposal做边框回归,用Bounding box回归值校正原来的建议窗口,生成预测窗口坐标.

    缺陷:

    (1)     训练分为多个阶段,步骤繁琐:微调网络+训练SVM+训练边框回归器;

    (2)     训练耗时,占用磁盘空间大;5000张图像产生几百G的特征文件;

    (3)     速度慢:使用GPU,VGG16模型处理一张图像需要47s;

    (4)     测试速度慢:每个候选区域需要运行整个前向CNN计算;

    (5)     SVM和回归是事后操作,在SVM和回归过程中CNN特征没有被学习更新.

    FAST-RCNN:

    (1)输入测试图像;

    (2)利用selective search 算法在图像中从上到下提取2000个左右的建议窗口(Region Proposal);

    (3)将整张图片输入CNN,进行特征提取;

    (4)把建议窗口映射到CNN的最后一层卷积feature map上;

    (5)通过RoI pooling层使每个建议窗口生成固定尺寸的feature map;

    (6)利用Softmax Loss(探测分类概率) 和Smooth L1 Loss(探测边框回归)对分类概率和边框回归(Bounding box regression)联合训练.

    相比R-CNN,主要两处不同:

    (1)最后一层卷积层后加了一个ROI pooling layer;

    (2)损失函数使用了多任务损失函数(multi-task loss),将边框回归直接加入到CNN网络中训练

    改进:

    (1)     测试时速度慢:R-CNN把一张图像分解成大量的proposal,每个proposal拉伸形成的图像都会单独通过CNN提取特征,这相当于对一张图像进行了2000次的提取特征和分类的过程!实际上这些建议框之间大量重叠,(这2000个proposal都是图像的一部分!)特征值之间完全可以共享,造成了运算能力的浪费.

    SO  我们完全可以对图像提一次卷积层特征,然后只需要将Region Proposal在原图的位置映射到CNN最后一层的卷积层特征图上,这样对于一张图像我们只需要提一次卷积层特征,然后将每个Region Proposal的卷积层特征输入到全连接层做后续操作.(对于CNN来说,大部分运算都耗在卷积操作上,这样做可以节省大量时间).

    (2)     训练时速度慢:R-CNN在训练时,是在采用SVM分类之前,把通过CNN提取的特征存储在硬盘上.这种方法造成了训练性能低下,因为在硬盘上大量的读写数据会造成训练速度缓慢.

    FAST-RCNN在训练时,只需要将一张图像送入网络,每张图像一次性地提取CNN特征和建议区域,训练数据在GPU内存里直接进Loss层,这样候选区域的前几层特征不需要再重复计算且不再需要把大量数据存储在硬盘上.

    (3)     训练所需空间大:R-CNN中独立的SVM分类器和回归器需要大量特征作为训练样本,需要大量的硬盘空间.FAST-RCNN把类别判断和位置回归统一用深度网络实现,不再需要额外存储.

    FASTER -RCNN:

    (1)输入测试图像;

    (2)将整张图片输入CNN,进行特征提取;

    (3)用RPN生成建议窗口(proposals),每张图片生成300个建议窗口;

    (4)把建议窗口映射到CNN的最后一层卷积feature map上;

    (5)通过RoI pooling层使每个RoI生成固定尺寸的feature map;

    (6)利用Softmax Loss(探测分类概率) 和Smooth L1 Loss(探测边框回归)对分类概率和边框回归(Bounding box regression)联合训练.

     

    (RPN的输入是任意大小的图像,输出是一组打过分的候选框(object proposals)。在卷积的最后一层feature map上使用固定大小的窗口滑动,每个窗口会输出固定大小维度的特征(图中256),每一个窗口对候选的9个box进行回归坐标和分类(这里的分类表示box中是一个object,而不是具体的类别)。)

    相比FASTER-RCNN,主要两处不同:

    (1)使用RPN(Region Proposal Network)代替原来的Selective Search方法产生建议窗口;

    (2)产生建议窗口的CNN和目标检测的CNN共享

    改进:

    (1)     如何高效快速产生建议框?

    FASTER-RCNN创造性地采用卷积网络自行产生建议框,并且和目标检测网络共享卷积网络,使得建议框数目从原有的约2000个减少为300个,且建议框的质量也有本质的提高.

    Bounding box regression:

    1.IOU

    (2)   为什么要做Bounding-box regression?

    如上图所示,绿色的框为飞机的Ground Truth,红色的框是提取的Region Proposal.那么即便红色的框被分类器识别为飞机,但是由于红色的框定位不准(IoU<0.5),那么这张图相当于没有正确的检测出飞机.如果我们能对红色的框进行微调,使得经过微调后的窗口跟Ground Truth更接近,这样岂不是定位会更准确.确实,Bounding-box regression 就是用来微调这个窗口的.

    (3)   回归/微调的对象是什么?

    RPN原理介绍:

    RPN的实现方式:在conv5-3的卷积feature map上用一个n*n的滑窗(论文中作者选用了n=3,即3*3的滑窗)生成一个长度为256(对应于ZF网络)或512(对应于VGG网络)维长度的全连接特征.然后在这个256维或512维的特征后产生两个分支的全连接层:

    (1)reg-layer,用于预测proposal的中心锚点对应的proposal的坐标x,y和宽高w,h;

    (2)cls-layer,用于判定该proposal是前景还是背景.sliding window的处理方式保证reg-layer和cls-layer关联了conv5-3的全部特征空间.事实上,作者用全连接层实现方式介绍RPN层实现容易帮助我们理解这一过程,但在实现时作者选用了卷积层实现全连接层的功能.

    (3)个人理解:全连接层本来就是特殊的卷积层,如果产生256或512维的fc特征,事实上可以用Num_out=256或512, kernel_size=3*3, stride=1的卷积层实现conv5-3到第一个全连接特征的映射.然后再用两个Num_out分别为2*9=18和4*9=36,kernel_size=1*1,stride=1的卷积层实现上一层特征到两个分支cls层和reg层的特征映射.

    (4)注意:这里2*9中的2指cls层的分类结果包括前后背景两类,4*9的4表示一个Proposal的中心点坐标x,y和宽高w,h四个参数.采用卷积的方式实现全连接处理并不会减少参数的数量,但是使得输入图像的尺寸可以更加灵活.在RPN网络中,我们需要重点理解其中的anchors概念,Loss fucntions计算方式和RPN层训练数据生成的具体细节.

    Anchors:字面上可以理解为锚点,位于之前提到的n*n的sliding window的中心处.对于一个sliding window,我们可以同时预测多个proposal,假定有k个.k个proposal即k个reference boxes,每一个reference box又可以用一个scale,一个aspect_ratio和sliding window中的锚点唯一确定.所以,我们在后面说一个anchor,你就理解成一个anchor box 或一个reference box.作者在论文中定义k=9,即3种scales和3种aspect_ratio确定出当前sliding window位置处对应的9个reference boxes, 4*k个reg-layer的输出和2*k个cls-layer的score输出.对于一幅W*H的feature map,对应W*H*k个锚点.所有的锚点都具有尺度不变性.

    Loss functions:

    在计算Loss值之前,作者设置了anchors的标定方法.正样本标定规则:

    1)   如果Anchor对应的reference box与ground truth的IoU值最大,标记为正样本;

    2)   如果Anchor对应的reference box与ground truth的IoU>0.7,标记为正样本.事实上,采用第2个规则基本上可以找到足够的正样本,但是对于一些极端情况,例如所有的Anchor对应的reference box与groud truth的IoU不大于0.7,可以采用第一种规则生成.

    3)   负样本标定规则:如果Anchor对应的reference box与ground truth的IoU<0.3,标记为负样本.

    4)   剩下的既不是正样本也不是负样本,不用于最终训练.

    5)   训练RPN的Loss是有classification loss (即softmax loss)和regression loss (即L1 loss)按一定比重组成的.

    计算softmax loss需要的是anchors对应的groundtruth标定结果和预测结果,计算regression loss需要三组信息:

       i.     预测框,即RPN网络预测出的proposal的中心位置坐标x,y和宽高w,h;

     ii.      锚点reference box:

            之前的9个锚点对应9个不同scale和aspect_ratio的reference boxes,每一个reference boxes都有一个中心点位置坐标x_a,y_a和宽高w_a,h_a;

    iii.  ground truth:标定的框也对应一个中心点位置坐标x*,y*和宽高w*,h*.因此计算regression loss和总Loss方式如下:

    RoI Pooling

    在测试(inference)的时候,ROI Pooling从RPN网络得到候选的roi列表,通过conv5拿到所有的特征,进行后面的分类和回归。

    在训练的时候,如果还是只使用RPN预测的roi可能会训练速度很慢或者loss就不收敛。这里需要对拿到的roi列表数据进行一些改造。

    1. 将ground-truth box加入到rpn_roi
    2. 通过rpn_roi和ground-truth box对比,调整覆盖覆盖比例

    比较巧妙的一点是R-CNN的分类label生成和bbox的label生成,方法就是训练的时候根据每次生成的rpn_roi和gt对比,生成相应的标注信息,反向传播的时候只将目标类别的loss权重不为0,达到反向传播的时候只考虑正确的分类。

    smooth L1 Loss
     
    http://pages.cs.wisc.edu/~gfung/GeneralL1/L1_approx_bounds.pdf

    使用的方法本质上就是滑动窗口。RPN的设计比较巧妙,RPN只需在最后的卷积层上滑动一遍,因为anchor机制边框回归可以得到多尺度多长宽比的region proposal:

    3*3滑窗对应的每个特征区域同时预测输入图像3种尺度(128,256,512),3种长宽比(1:1,1:2,2:1)的region proposal,这种映射的机制称为anchor

  • 相关阅读:
    java中的线程是如何工作的。
    springcloud 负载均衡之 ribbon。
    eureka 集群的实现方式?
    eureka的简单介绍,eureka单节点版的实现?eureka的自我保护?eureka的AP性,和CP性?
    docker常用命令、镜像命令、容器命令、数据卷,使用dockerFile创建镜像,dockefile的语法规则。
    关于自动化测试框架的思想和考虑
    Web应用程序压力测试步骤
    自动化测试工具的选择
    软件测试用例的认识误区
    如何评估软件产品的质量?
  • 原文地址:https://www.cnblogs.com/nkh222/p/7652490.html
Copyright © 2011-2022 走看看