本文图片均出自论文截图,除dilated convolution部分的图片出自:
1、https://gist.github.com/abidrahmank/4613153147922803f8dd7b7ce5b74429
2、见图片水印
涉及的方法or文章有:
[overfeat](http://arxiv.org/abs/1312.6229)
[RCNN](http://arxiv.org/abs/1311.2524)
[SPP-Net](http://arxiv.org/pdf/1406.4729.pdf)
[Fast-RCNN](http://arxiv.org/abs/1504.08083)
[Faster-RCNN](http://arxiv.org/abs/1506.01497)
[YOLO](http://arxiv.org/abs/1506.02640)
[SSD](http://arxiv.org/pdf/1512.02325v1.pdf)
[HyperNet](https://www.arxiv.org/abs/1604.00600)
[MR-CNN](http://arxiv.org/abs/1505.01749)
[Inside-Outside Net]
(http://120.52.73.9/www.cvfoundation.org/openaccess/content_cvpr_2016/papers/Bell_Inside-Outside_Net_Detecting_CVPR_2016_paper.pdf)
[R-FCN](http://arxiv.org/abs/1605.06409)
上述方法大致提供了两种物体检测框架,下面分别来介绍。
核心点
feature map上的一个点可以对应到原图中的一个区域;在feature map上做滑动窗口代替在原图做滑动窗口。
feature map上的一个点可以对应到原图中的一个区域(也是后面框架的基础)。因此可以通过在feature map上做sliding window代替在原图做,避免原图每一个窗口都要单独计算CNN。当然带来的问题是这样得到的框不一定有在原图做sliding window准确。
此框架将detection问题分解为classification问题和localization问题。
classification:一张图片经过fully convolutional层及pool5后得到mxn的pool5 feature map。使用固定大小的filter(3x3)在pool5 feature map上做滑动窗口。此处的滑动窗口与一般的不同,总共要做9次,从(0,0), (0,1), (0,2), (1,0), (1,1)...处分别开始滑动。得到的feature map分别经过最后三层FC层,得到特征,然后再拼接起来得到最终的特征,用来分类。
localization:1-5层作为特征提取层和分类问题完全一样,后面接两个全连接层,组成 regressor network。训练时,前面5层的参数由classification network给定,只需要训练后面的两个全连接层。这个regressor network的输出就是一个bounding box,也就是说,如果将一幅图像或者一个图像块送到这个regressor network中,那么,这个regressor network输出一个相对于这个图像或者图像块的区域,这个区域中包含感兴趣物体的框。这个regressor network的最后一层是class specific的,也就是说,对于每一个class,都需要训练单独最后一层。这样,假设类别数有1000,则这个regressor network输出1000个bounding box,每一个 bounding box对应一类。
合并多余框的方法
令Cs为top-k(例如5)标准中每个scale下找到的可能类别。
令Bs为Cs中这些类别的预测框。而B集合是Bs的并集。
找B集合里面两个框的中心距离和相交面积之和最小的一对,如果他们的和大于给定阈值t,则结束,否则从B中删去两个框,合并这一对用他们的均值构成新的一个框,加入B
trick
1、multi-scale:将图片放缩到多个分辨率,然后把最后的特征or概率结合起来。
基于region,通过分类region达到识别的目的,结合Bbox对region进行修正。
核心点
使用selective search产生图中候选region,使用CNN提取region的特征,用SVM分类。
基本流程如下图,即:通过SelectiveSearch在原图中得到所有候选区域(即可能存在物体的region),然后对这些region依次提取特征,将得到的特征用SVM进行分类。
Bbox regression
用pool5提取到的特征来回归出一个偏移量,使得原框附加此偏移后更加接近ground truth。
有N对训练pairs , 其中 , 分别代表原始region框的中心点坐标以及宽高,P表示proposal。G代表ground truth框,同样由四元组构成。
使用四个线性回归函数 , 应用四个函数后得到的预测框为:
令 表示由pool5的feature。目标函数为:
则
回归的目标,即label为:
trick
1、在region放缩到CNN输入大小前,将region向周围扩大16个像素来获取context信息
2、非极大值抑制(NMS)
3、在ImageNet上预训练,在特定领域fine-tuning
4、分类的时候需要分N+1类,因为存在非物体类,即背景
5、选择负样本时,与ground truth的IOU小于0.3的为负样本。通过cross validation得出。
6、没有fine-tuning的情况下,pool5层提取到的特征与FC6,FC7的特征效果相当。CNN的大部分表示能力来自于conv层。
经过fine-tuning之后,从各个层提取的特征效果均有提升,FC6,FC7提升效果最大。说明pool5层的特征更加general,fine-tuning的提升大部分来自后面的FC层。
7、使用pool5得到的特征做bounding-box regression,closed form方法。
核心点
设计了Spatial Pyramid Pooling层,支持任意大小图片作为CNN的输入而不影响网络的FC层。整幅图片只需要计算一次网络SPP前面的layers。
conv层并不需要输入的图片是固定大小的,之所以限制输入图片固定大小,是因为conv层之后接了FC层,而FC层需要保证前一层的元素数目不变。
针对CNN中图片必须放缩到固定大小输入,从而导致信息损失的问题,此文提出了Spatial Pyramid Pooling来解决这一问题。
不同大小的图片经过conv层后得到的feature map大小也不同,预先设定要从此feature map获取的bin的数量,由feature map大小确定pooling窗口滑动的步长。这样经过SPP得到的特征长度就一样了。
SPP还可以应用多尺度的方法,在conv后的特征图上按照输出的bin数量构成金字塔型multi-scale。然后把得到的特征拼接。如下图所示。
受overfeat启发,一张图只做一次conv计算,在conv后的feature map上做SPP
trick
1、使用图片的不同分辨率来训练,对于准确率有提升。例如本文训练时使用了224与180,测试时可以是任意尺寸
2、多尺度SPP可以提升准确率
3、使用不同初始化训练同一个模型,detection之后,对两个模型的输出窗口的交集,将置信度高的一个作为系统最终的输出。
核心点
共享计算,减少冗余,统一框架。RCNN需要每一个region都跑一次整个网络,而现在只有FC层以后的部分需要每个region单独跑。用softmax代替了SVM,同时也将Bbox regression纳入了整个框架。
基本流程如下图:
与RCNN类似,先用SelectiveSearch找出候选框,但是不把每一个候选框都过一次CNN。而是像overfeat和SPP-Net那样整张图过一次CNN,然后用ROI-Pooling(即单层SPP-Net),将对应候选框的部分做pooling,得到相同长度的特征,又经过两层FC之后得到最终的特征。接着产生两个分支,一个分支给此特征分类,另一个分支回归此特征的候选框偏移(即RCNN中Bbox regression的部分)。fast-rcnn将分类和Bbox-regression何在了一起。
为了同时训练好分类器和框回归,本文提出了一种多任务目标函数,即:
其中:
表示当该ROI为前景图时为1,否则为0.
是标准交叉熵损失函数。
训练的时候一个batch从两张图片中提取128个samples。每张图片取64个samples。正样本为与ground truth的IOU大于0.5的,负样本为IOU在0.1到0.5之间的。
trick
1、FC层的计算可以使用SVD来加速。将一个FC层变成两个FC层,其中没有非线性变换,分别计算SVD的前半部分和后半部分。
2、训练的时候并不一定需要把整个网络全部fine-tune,因为较前的层表示的特征都比较通用,fine-tune与否关系不大。比如VGG16在conv3_1以后的层对结果的影响才比较大。此外全部用来fine-tune耗时会比较大。
3、single-scale的accuracy较multi-scale低一点,但是速度要快很多。
核心点
共享计算,减少冗余。基于fast-rcnn,设计了Region Proposal Network,将region的生成也纳入到CNN的计算中来。
faster-rcnn是对fast-rcnn的改进,速度得到了进一步提升。整个流程见下图。
fast-rcnn中使用SelectiveSearch得到候选框,花费了很长时间。faster-rcnn中将找候选框的功能结合到了rcnn框架中,使用一个叫做region proposal network(RPN)的神经网络并行产生候选框。
与fast-rcnn类似,faster-rcnn先将整幅图forward 到最后一层conv层,在pool5层分出两支。一支后面接RPN,另一只接ROI Pooling,等待从RPN得到的框。
RPN在最后的conv层上做滑动窗口,每一个窗口产生256维的向量,根据这一个向量又分出两支,分别用于分类和回归框。如图所示。
此外,针对每一个窗口,文中还提出了使用anchor,即大小、比例不同的原始框作为回归的起点,而非整个窗口大小。这样假设有k种anchor,那么RPN最终的分类有2k个输出,回归有4k个输出。
在最后的conv层的feature map上滑窗,feat_stride为conv1到conv5所有步长的乘积。ZF-Net为16.以feat_stride x feat_stride为base,进行scale和ratio变换,得到9个anchor。在conv 5的feature map的每一个点为中心的anchors,对应到原图上绝对坐标,由此可得anchor与ground truth的IOU,从而选取正负样本。
一个batch从所有anchor选取256个样本。正负样本1:1.
为了使RPN与fast-rcnn共享权值,减少计算,faster-rcnn使用了四阶段训练的方法:
1、训练RPN
2、使用1中产生的proposals训练faster-rcnn做detection
3、用fast-rcnn与RPN共享的部分初始化RPN,只训练RPN独有的层。
4、固定conv层,只训练fast-rcnn独有的层。
trick
1、训练的时候对于跨过边界的anchor,不加入训练样本。这样可能会导致不收敛。存疑
核心点
结合region本身的特征,region周围采样的特征和图像分割的特征来提高识别率。
MR-CNN流程图如下:
MR-CNN将detection问题分解为classification和localization两部分。
分为两部分,即Multi-Region CNN Model和Semantic Segmentation-Aware CNN Model。
Multi-Region CNN Model
一幅图片经过NN的最后一层conv后得到feature map
图中候选框由SelectiveSearch得到。对于每一个region,取10个区域分别提取特征后拼接。这样可以强制网络捕捉物体的不同方面,同时可以增强网络对于定位不准确的敏感性。区域的选取如下图:
所谓adaptive max pooling即ROI max pooling
Segmentation-Aware CNN Model
经验上来说segmentation对于detection有帮助。
使用Fully Convolutional Network(FCN)来做Segmentation。不使用pixel-level的标签,仅需要使用image-level的标签即可,即此图是哪一类。
训练好FCN后,去掉最后的classification layer,取剩下的最后一层作为feature layer,与上述Multi-Region CNN Model
产生的feature拼接作为最后的feature。
MR-CNN使用了3种方法来精确定位。
1、Bbox regression
在Multi-Region CNN Model
中整幅图经过NN的最后一层conv后,接一个Bbox regression layer,与RPN不同,此处的regression layer是两层FC以及一层prediction layer。为了防止SelectiveSearch得到的框过于贴近物体而导致无法很好的框定物体,将候选框扩大为原来的1.3倍再做。
2、Iterative Localization
初始的框是SelectiveSearch得到的框,然后用已有的classification模型对框做出估值,低于给定阈值的框被筛掉,剩下的框用1中的regression network来调整大小。重复上述过程。文章重复了2次。
3、Bounding box voting
首先对经过2处理后的框应用NMS, IoU = 0.3,得到detection的结果 。 然后对于每一个框,用每一个和他同一类的而且IoU大于0.5的框(经过2筛选的),来加权坐标,得到最后的框。每一个框的权值是 ,加权公式为:
其中, 表示第i个框是c类的置信度。 表示属于c类的第i个框。
trick
1、MR-CNN的三种定位方法
2、多个region提供position sensitive的信息
核心点
结合多个layer提取的特征,即multi-level。
HyperNet结合了CNN中多个layer的特征,达到了一种multi-level的效果。而且从较前层获取的精细特征可以减少对于小物体检测的缺陷。本质上是对faster-rcnn的改进。
如上图,一幅图经过CNN后,只保留conv1到conv5的layer。
以conv3为基准,feature map大于它的用max pooling来降维,小于它的用deconv来扩增,使得到的所有特征维度相等,然后经过LRN正则化之后堆叠在一起,形成Hyper Feature maps。因为不同层的特征量纲不同,直接拼接会导致量纲不同的特征互相抑制。
得到Hyper feature之后,接一个region proposal generation module。包括一个ROI pooling层,一个conv层,一个FC层以及经典的sibling classification®ression layers。但是输入这个module之前如何产生30k个初始box论文并没有讲,可能是随机选取。然后对于每一个box,ROI pooling产生13X13的输出,后面的layer进行框的预测和回归,保留框置信度最高的N个送到最后的一部分。
最后一部分对每个框分别判别之前,多加了一个conv层来降维并增加网络深度。最后得出结果。
trick
1、multi-level feature, 不要从相邻层提取,因为相邻层强关联。
核心点
在faster-rcnn的基础上,解决了网络FC层每个region需要独立计算的问题。
解决了faster-rcnn由于ROI-Pooling层后面的结构需要对每一个region跑一次而耗时比较大的问题。整个框架变为了fully convolutional, 引入了position-sensitive score maps来解决对于图片分类的平移不变性和对于物体检测的平移变化性。
网络的整体结构与faster-rcnn类似,不同的是RPN得到候选框后传给了position-sensitive ROI pooling层,而非ROI pooling层。
最后一层conv层后面紧接着的就是position-sensitive ROI pooling层,对于每一类物体,它有k x k层,本文中k=3, 这9层分别代表一个九宫格的左上角,上边,右上角,……,右下角,一个格子的大小为 。那么position-sensitive ROI pooling 层共有 个channel。更具体来讲,每一个channel,例如代表左上角的channel,是从最后一层conv层做滑动窗口,每一个点处的窗口取其左上角做pooling。
在第(i,j)个格子里,position-sensitive ROI pooling只在该格子中做pool操作。
其中, 表示在网络参数为 的情况下,(i,j)这个bin的第c类物体的pool值。
表示 个score map中的一个。
表示当前ROI的左上角坐标。
n是feature map的当前bin中点的个数。
决定此ROI是哪一类的时候,只需要取各个bin的得分均值,然后用softmax分类。即 ,
整个算法流程如下图:
trick
1、训练的时候采用OHEM(online hard example mining),即反向传导的时候仅选择loss最大的几项来计算。
简单来说, ,即dilated convolution,是对于conv过程的一种改进。相关介绍的文章见multi-scale context aggregation by dilated convolutions。原理见下图。
caffe中是通过im2col实现的
核心点
引入了不同layer的特征,即multi-levle or multi-scale,以及context的特征。
大部分物体检测算法的缺陷之一在于提取的特征不够精细。这篇文章针对这一个问题进行了改进。利用物体的multi-scale信息(信息的精细度)和context信息(信息的广度),提高识别率。
基于VGG network,使用SelectiveSearch一类的proposal生成算法生成reigon,作为ROI。一次过一张图,保留conv1到conv5,其后跟两个4-direction IRNN,再接一个conv得到context特征。然后将conv3、conv4、conv5以及context特征拼接起来,正则化后分类并回归框。
4-direction IRNN的结构如下图所示。即将feature map分块,分别按照4个方向排列从而形成序列,经过IRNN处理后形成的feature map堆叠到一起传入下一个单元。最后使用deconv层还原图像,用semantic segmentation的loss来监督学习。
trick
1、对特征使用L2 norm:对于一个d维输入 公式: ,其中, .为了不让特征数值上而过小导致难以训练,需要给特征乘以一个放缩因子,可以固定,也可以学习一个参数。
2、提取全局context特征可以使用global average pooling、堆叠CNN、RNN等方法,区别如下图所示。
堆叠CNN可能获得更好的效果,但是堆叠RNN并不一定。
3、测试的时候可以将图片左右翻转测两次,然后取均值。
等效于将原图划分为n个区域,然后分别在各个区域中回归框同时分类框。
核心点
将原图分块,每一块分类和回归一起做
流程图如下:
YOLO将原图划分为SxS个区域。如果一个物体的中心在某个区域,那么该区域就负责此物体的定位和识别。每个区域会回归B个框(x,y,w,h)以及其对应的置信度(conf)。置信度用 表示。即给定某个预测时(特征以及预测框),第一项表示该区域存在物体的概率,后一项表示该预测的准确度,即预测框与ground truth的重叠面积。每个区域还会预测C个条件概率 ,C为类别数。
在test阶段,我们将条件概率和置信度相乘就得到了某个区域中存在某物体的概率以及其准确度。即:
YOLO的缺陷:受限于每个区域对于每个类只预测两个框,导致某个区域附近临近的小物体或物体集群(例如鸟群)无法被检测到。
因为是在区域中直接回归框,因此物体的长宽比比较特殊而且训练中没有出现时,难以识别。
提取的特征过于粗糙,因为经过了很多次降采样,不够精细。
loss function对于同样大小的错误在大框和小框上的惩罚应该不同。
主要错误在于定位不准。
trick
1、做detection要求精细的特征,因此将输入图片的大小适当扩大会有比较好的效果。例如YOLO讲原GoogleNet的输入大小由224改为了448
2、使用平方和误差损失函数的度量方法,应该能反应:细小的误差对于大框的影响要远小于对于小框的影响。因此预测的是框w和h的平方根,而不是其本身。提高灵敏度。
3、通常来说,一幅图片中包含物体的区域远小于不含物体的区域。在训练时,这种情况会导致没有物体的区域产生的loss严重影响正常区域的loss(因为每个区域都要产生预测的框,但是没有物体存在的区域并没有ground truth,此时该区域仍然会产生loss)。因此,需要给不同区域的loss加权。全局loss公式如下:
其中 表示在区域i中预测的第j个框负责这个区域的预测。 表示区域i中是否存在物体。
4、数据扩增:在HSV颜色空间随机调整曝光率和饱和度;随机放缩和平移。
核心点
在YOLO的基础上,引入了anchor以及多层特征,即multi-scale,并结合了众多trick
针对YOLO选取的特征不精细,对小物体和集群物体无法很好识别的问题做了改进。
与YOLO类似,也是相当于把图片划分为n个区域,然后直接在这些区域上判断类别并回归框。
区别在于:
1、使用了多个layer不同精细程度的feature拼接。
2、每一层提取特征的layer都会对feature map上的每个点得出每个类的置信度以及框的四个值(x,y,w,h)来拼接。
3、feature map上每一个点引入了类似faster-rcnn的anchor。在确定正负样本的时候,只要anchor与ground truth的IOU大于0.5即为正样本。即一个anchor可以对应多个物体,不必强迫其选择出一个。
4、loss function:
其中N是匹配到的anchor的数量。 是Smooth L1 loss。c是多类的confidence, 设置为1.
缺点:对小物体识别效果差于大物体。部分原因是物体过于小,导致后面的layer基本没有信息。
tricks
1、hard negative mining:负样本:正样本=3:1
2、data augmentation:1>初始图片 2>选择patch使得与物体的IoU分别为0.1,0.3,0.5,0.7,0.9,patch的大小为初始图片的[0.1,1],长宽比为原图的1/2,2倍。 3> 2中得到的patch resize到固定大小,然后以0.5的概率翻转。
3、使用更多的feature map可以提升准确率
4、使用较多的anchor可以提高准确率
5、 算法,即dilated convolution,见2.7
下表中+++表示训练数据为VOC07+VOC12+MS COCO
其余方法的训练数据均为VOC07 for VOC07 test,VOC07+VOC12 for VOC12test, MS COCO for MS COCO test
方法 | 检测耗时 | VOC07 | VOC12 | MS COCO |
---|---|---|---|---|
overfeat | ---- | ---- | ---- | ---- |
RCNN | 13s | 66.0 | 53.3 | ---- |
SPP-Net | 0.29s | 59.2 | ---- | ---- |
fast-rcnn | 0.32s | 70.0 | 68.0 | 19.7 |
faster-rcnn+++ | 140ms | 85.6 | 83.8 | 21.9 |
HyperNet | 1140ms | 76.3 | 71.4 | ---- |
MR-CNN | 30s | 78.2 | 73.9 | ---- |
R-FCN+++ | 0.17s | 83.6 | 82.0 | 29.9 |
ION | 0.8s | 79.2 | 76.4 | 33.1 |
实时算法 | -- | -- | -- | -- |
YOLO | 45FPS | 63.4 | 57.9 | ---- |
Fast YOLO | 155FPS | 52.7 | ---- | ---- |
SSD300 | 58FPS | 72.1 | 70.3 | 20.8 |
SSD500 | 23FPS | 75.1 | 73.1 | 24.4 |