论文原文
https://arxiv.org/abs/1512.02325
摘要
本文呈现了一种仅需要单个深度神经网络的目标检测方法之一SSD。SSD将物体边框的输出空间离散化为一组在每个特征图位置不同大小和形状的默认框。预测时,网络对位于每个默认框类的物体类别进行打分,并修正默认框位置来更好的匹配物体的位置。此外,SSD网络在不同分辨率的特征图预测,这样就可以处理大小不同的物体。SSD比那些需要搜索物体候选框的算法简单,因为它完全去除了proposal生成和随后的特征再筛选的过程,把所有的计算封装在一个网络里面。这使得SSD训练起来很容易,可以直接加入到检测系统里面。在PASCAL VOC,COCO,和ILSVRC数据集上的实验也证明,与那些需要object proposal的算法相比,SSD在保证准确性的同时,速度更快。SSD只需一个完整的框架来训练和测试。在NVIDIA Titan X对于一个大小是300 × 300的输入图像,SSD在VOC2007测试上的MAP是74.3%,速度是59FPS。对于512 × 512的输入,SSD的MAP是76.9%,比Faster RCNN更准。和其他单阶段的方法比,即便是输入较小的图像,SSD的准确性也会更高。
介绍
目前,目标检测系统基本采用以下的流程:假设物体边框,对每个边框内进行特征再采样,最后使用分类器进行分类。这个流程比较流行,基于Faster-RCNN的方法通过选择性搜索在PASCAL VOC, COCO和ILSVRC上检测效果都很好。但是这些方法对于嵌入式设备来说计算量过大,甚至需要高端硬件的支持,对于实时系统来说太慢。最快的检测器-Faster RCNN的检测速度也只能到7FPS。人们尝试了很多其他方法来构建更快的检测器,但是增加速度大多以损失检测精度为代价。
本文提出了基于目标检测器的网络(object detector),它不需要为边框进行搜索,但是精度却不降反升。此方法实现了高精度和高速度,在VOC2007 上的测试速度是59FPS,mAP是74.3%;而Faster R-CNN的mAP是73.2%,速度是7FPS;YOLO的mAP是63.4%,速度的是45FPS。速度的提升得益于去除了边框提议和随后的特征再采样。使用了一个小卷积滤波器来预测目标分类和边框位置的偏移,对于不同横纵比检测使用不同的滤波器去处理,然后把这些滤波器应用在后面网络阶段的特征图上,这是为了用检测器检测不同比例的图片,这样我们再相对低分辨率的图像上也能获得高精度的输出,还提升了检测速度。本文的贡献如下:
- 提出了SSD—多类别 single shot 检测器, 要比其它的 single shot 检测器(YOLO)快,而且更准确;
- SSD的核心部分是,在特征图上应用小卷积滤波器,预测分类得分和一个固定集合的默认边界框的偏移;
- 为了实现高检测精度,在不同比例的特征图上产生不同的预测,通过纵横比来分开预测;
- 以上的设计可以端到端训练,精度还高,甚至在低分辨率的图像上效果也不错;
- 关于速度和精度的试验,主要在PASCAL VOC, COCO 和 ILSVRC数据集上进行,与其它方法进行比较。
SSD
模型
SSD基于前馈式卷积神经网络,针对那些方框里的目标检测实例,产生一个固定大小边界框集合和分数,紧接着是一个非极大值抑制步骤来产生最后的检测。网络前半部分是个标准结构(用于高质量图片分类),成为基网络。然后对网络增加了辅助结构来实现以下特征:
- 多比例特征图检测:在基网络后增加卷积特征层,这些层按大小减少的次序连接,能够进行多尺度预测。
- 卷积检测预测器:通过一个卷积滤波器几何,每个新增的特征层可以产生一个固定集合的检测预测。假设特征层大小为 m×n, p个通道,预测参数的基本单元是一个 3×3×p的小核,它要么产生一个类别的得分,要么产生一个相对于默认方框左边的形状偏移。核一共要应用在 m×n个位置上,在每个位置上它都有一个输出值。边界框的偏移输出值是相对于默认的位置的。
对于图片里面的一些细节可以查看一下:https://www.jianshu.com/p/e13792628bac 这篇文章写得很详细。 - 默认方框和纵横比:将每个特征图单元(cell) 与默认边界框的集合关联起来,这是对于网络顶层的多特征图来说的。默认方框用卷积的方式覆盖特征图,这样,每个方框对应的单元(cell) 是固定的。在每个特征映射单元上,我们预测相对于默认方框形状的偏移,以及每一类别的分数(表明每一个方框中一个类的出现)。在给定的位置有kk个框,对于其中的每一个,计算cc类别的分数,和相对于原来默认方框形状的44个偏移。这就一共有(c+4)k(c+4)k个滤波器应用到特征图的每个位置上;对于 m×n的特征图,产生 (c+4)kmn个输出。默认方框跟Faster R-CNN中的 anchor 方框类似,但是作者将它们应用到不同分辨率的特征图上时,由于在一些特征图上有不同的默认方框形状,这使得我们能高效地计算出离散化可能输出方框形状的空间。
SSD 在训练中只需一张输入图像和每个目标的 ground truth 边界框。在卷积操作中,我们评估一个默认方框的集合,这些方框在每个位置有不同的纵横比,在一些特征图中有不同的比例(如(b)中的8×8和4×4)。对于每个默认方框,预测它形状的偏移和所有物体分类的置信度( c1,c2,c3,...,cp)。训练时,首先将这些默认方框和 ground truth 边界框对应上。就像图中,作者匹配了2个默认方框,一个是猫,一个是狗,它们被认定为positive, 其余部分被认定为 negative. 模型损失函数是 localization loss(smooth L1) 和 confidence loss(Softmax) 的加权之和。
训练
训练SSD和训练其他使用区域提议检测器的主要区别是,ground truth信息在固定检测器输出的情况下需要指定到特定的输出。这样,损失函数和反向传播就可以端到端的应用。训练需要选择默认方框的集合,检测比例,以及hard negative mining(也就是不存在目标的样本集合)和数据增强策略。
- Matching strategy, 在训练中,需要决定哪个默认框匹配一个 ground truth,由此来训练网络。对于每个从默认方框(不同位置,不同纵横比,不同比例上)中选择的 ground truth 边界框,开始时,根据最高的 jaccard overlap 来匹配 ground truth 边界框和默认方框(与MultiBox一样)。实际操作中,与 MultiBox 不同,当它们的 jaccard overlap高于阈值0.5时,作者就将默认方框认为 ground truth。这简化了学习问题,使得网络可以对多个重叠的默认方框预测得到高分,而不是仅挑选一个重合度最高的方框。
- Training objective,SSD的训练目标来自于MultiBox,但是作者将之扩展成可处理多目标分类的问题。 xijp=1,0表示匹配第 i个默认方框和 p类别第 j个ground truth边界框。这种匹配策略会出现 ∑ixi,jp>=1。整体的目标损失函数是定位损失加分类损失:
L(x,c,l,g)=N1(Lconf(x,c)+αLloc(x,l,g)),其中 N是匹配默认框的个数,如果 N=0,loss设为0。定位损失是预测边界框 l和真值边界框 g参数的Smooth L1 loss。与Faster R-CNN类似,对默认边界框 d中心 (cx,cy)的偏移量进行回归, w是宽, h是高。
Confidence loss 是多个类别置信度的 softmax loss:
α在交叉验证中设为1。 - Choosing scales and aspect ratio for default boxes,为了处理不同的目标比例,有些方法是把图片处理成不同的大小,然后结合不同大小图片的结果。但是在一个网络中利用多个不同层产生的特征图来预测也能产生类似的结果,所有比例的目标还可以共享参数。前面的研究已经证明使用底层的特征图可以提升语义分割质量,因为底层能捕捉到输入图像中的细节信息。受这些方法启发,本文使用了特征图中的高层和底层特征来进行目标检测。
网络中不同层级的特征图会有不同的感受野,在SSD中,默认框不一定要和每层中的实际感受野对应。作者设计默认框的铺设,这样特定的特征图能对特定物体的尺度做出响应。假设我们要用 m个特征图来预测,每个特征图的默认框尺度计算如下:
sk=smin+m−1smax−smin(k−1,k∈[1,m]),其中 smin是0.2, smax是0.9,意味着最低的层的尺度是0.2,最高的层的尺度是0.9,有的中间层正常间隔分布。对于默认框,使用不同的高宽比, ar∈1,2,3,21,31。可以计算每个默认框的宽度 wka=skar和高度 hka=sj/(ar)。对于宽高比是1的情况,增加一个尺度是 sk‘=sksk+1的默认框,这样就在每个特征图位置有6个默认框。将框的中心设为 (∣fk∣i+0.5,∣fk∣j+0.5),其中 ∣fk∣是第 k个正方形特征图的大小。
结合诸多特征图不同位置下所有不同尺度和高宽比的默认框,就有了一个预测结果的集合,覆盖不同大小和形状的输入对象。例如图一中,那条狗与 4×4特征图中的默认框匹配,但是不和任何 8×8特征图中的默认框匹配,因为这些默认框有着不同的尺度,与狗的默认框不匹配,因此在训练中被认为是negative。 - Hard Negative Mining ,匹配步骤后,默认框中的大多数都是negative, 尤其是候选框个数众多的时候。这就导致positive 和 negative 训练样本不平衡。这些negative 样本不全用,而是对于每一个默认框,通过最高置信度损失来对它们进行排序,选择最高的几个,这样negative 和 positive的比例最多是3:1。这样训练更稳定也更快。
- Data augmentation,为了让模型对不同的输入大小和形状更鲁棒,每个训练图片都通过以下步骤随机选择:(1)使用整张原始输入图片;(2)选择图片中的一块,与物体最低的 jaccard overlap 值为0.1, 0.3, 0.5, 0.7, 0.9;(3)随机采样某一块。采样区块的大小在原图片[0.1,1]之间,高宽比介于0.5和2之间。保留真值边界框中的重叠部分,如果它的中心在采样区块内。在采样步骤后,每个采样区块缩放到固定大小,以0.5的概率来水平翻转。
实验
可以直接参考论文给出的数据
代码
caffe版本:https://github.com/weiliu89/caffe/tree/ssd
参考文章
https://blog.csdn.net/calvinpaean/article/details/84301031
https://www.jianshu.com/p/e13792628bac