SSD物体检测算法详解

作者: 轻墨lightink | 来源:发表于2019-04-09 10:14 被阅读1次

物体检测算法,按算法结构,可以分为one-stage和two-stage两类。

two-stage经典算法主要是R-CNN族,以准确度见长,速度稍慢,一般不如one-stage。

one-stage算法主要包括YOLO、SSD、CornerNet等,以速度快见长,准确度一般不如two-stage。本文分享的SSD就是经典的one-stage算法。

上图是物体检测算法整个演化坐标轴,可以看出SSD的发布,是在Faster R-CNN和YOLO v1之后。YOLO v1是one-stage检测算法的开山之作,速度碾压Faster R-CNN,但准确性远不如Faster R-CNN。SSD沿用了YOLO v1的基本思路,糅合了Faster R-CNN的anchor-box,又开创性的提出了多分辨率预测,最终达到了极快又准,如下表。

SSD单一scale的检测原理

这里先直接给出具体的模型计算方法,后面再解释原理,否则原理解释起来非常晦涩难懂。

1)模型

a) 输入图片经过特征提取器(SSD采用VGG16做特征提取器),得到H x W x Channel的Extracted Feature Map。

b) 将上述Extracted Feature Map,经过3 x 3 x (25 x num_default_box)的卷积核,卷积成H x W x (25 x num_default_box)的feature map作为物体检测的predict。如下图(图中num_default_box=4):

上述两步,就已经完成了物体检测的predict。足够简单

2)原理解释

由卷积的特性可知,从输入图片到HxW分辨率的预测,相当于将原分辨率的输入图片进行HxW等分,如下图(这里h=2,w=2):

为了更准确的预测物体bounding box,SSD借鉴了faster rcnn中的default box思想。

先假设,每一个cell中已经存在多个default box,default box的长宽固定,位于每一个cell正中。

以下图为例,每一个cell中有四个固定大小的default box。


那么在predict时,每一个cell就会有4个预测,每一个预测对应一个default box。如下图:


具体到一个default box的预测,分为两个部分,如上图中的default box 1,

  1. P_i(i=background, c1, …, c20),代表的是这个default box的物体类别。P_background代表是背景的概率,P_ci代表是类别ci的概率(这里采用的VOC数据集,共有20个物体类别),所有概率值之和为1,取概率值最大的类作为default box的类别预测值。

  2. Δcx, Δcy, Δw, Δh代表default box内的物体目标框与default box的位置之间的偏差。Δcx, Δcy代表中心点的偏差,Δw, Δh代表宽高的偏差。具体的含义可以参考Loss计算章节。

所以一个default box会有25个预测结果,4个default box就有100个。这就是上文模型部分predict中的100的意义。

3)Loss计算

根据上述分析可知,每个cell都有4个default box,HxW的分辨率,则会有4HW个预测结果。对于监督学习,需要知道每个default box对应的标签Ground Truth。SSD对于真实GT物体框的分配策略是,首先将GT分配给IoU最大的default box,然后将GT分配给IoU大于0.5的default box,也即同一个GT会分配给不同的default box,不同的default box对应的GT可能是同一个。

如上图,红色框是dog的真实位置,那么绿色箭指向的两个default box的GT都是红色框,其他两个default box的GT是背景即没有物体。

对于正例,即default box有GT框的,loss分为类别损失和位置损失。

对于反例,即default box没有GT框的,loss只有类别损失(类别是背景)。

Loss是confidence loss和location loss加权之和。

location loss计算如下:

其中,y是预测值,yhat是预测值的label。对于cx,cy,w,h的yhat采用下式计算:

g是ground truth值,d是default box的先验值。可以看出,中心点坐标就是ground truth值与default box先验值得相对差,w和h是ground truth值与default box先验值比值的对数。

其实这样处理都是尽量减小y^hat值变化幅度,减少学习难度。

confidence loss计算如下:

都是cross entropy loss。

以上就是单一scale的SSD原理。

SSD多scale的检测原理

SSD的主要贡献有两点

1)引入了上文所述的default box

2)多scale预测

上文的单scale预测,是取整个特征提过程的某一个feature map做预测。多scale预测,就是取整个特征提取过程中的不同分辨率的feature map均做预测。

由上图可以看出,SSD做了6个scale的预测。

Loss也是每个scale的Loss之和。

Tricks

1)data augmentation

数据增强是模型训练非常重要的一环,毕竟数据获取太难了。

SSD每一张训练图片由如下方法随机产生:

原图片

截取一部分图片,保证截取框与物体框的最小IoU是0.1,03,0.5,0.7,或者0.9

随机截取一部分图片

随机截取图片的大小是[0.1,1]原图片大小,aspect ratio是0.5~2。

2)default box

default box由scale和aspect ratio控制。

scale最小为0.2,最大0.9。假如总共选取了m个scale,则各个scale的scale值按下式计算:

aspect ratio选取为:


aspect ratio为1时,再增加一个scale,取值为:


所以每一个scale的每一个cell共有6个default box。

3)hard negative mining

因为绝大部分default box都是负样本,导致正负样本严重失衡,如果计入所有负样本的损失,训练非常不稳定,收敛性非常慢,所以负样本只计入损失最大的几个负样本,并且要保持正负样本比例为1:3。

试验结果

1)普通技巧的消融试验结果


可以看出数据增强的影响非常大

2)多scale预测的消融试验

可以看出多scale可以显著提高准确性

3)COCO数据集结果对比

相关文章

  • SSD物体检测算法详解

    物体检测算法,按算法结构,可以分为one-stage和two-stage两类。 two-stage经典算法主要是R...

  • SSD代码阅读

    1.CNN目标检测(三):SSD详解 - 浩瀚之水的专栏 - CSDN博客 2.深度学习笔记(七)SSD 论文阅读...

  • yolo9000

    这篇文章发表晚于ssd,因此文章涉及到和ssd的比较。 一、概述 通用目标检测存在的问题 小物体检测存在问题 物品...

  • texbox++_2018_华科白翔

    旋转文本检测,基于ssd 1、ssd目标检测算法 backboneVGG16,输入是固定大小的图像,输出是下采样的...

  • 物体检测之SSD

    先上一个物体检测算法时间轴:!()[https://upload-images.jianshu.io/upload...

  • RCNN,Fast RCNN and Faster RCNN

    找到了三篇很好的文章,贴链接如下,留作自读: - 【目标检测】RCNN算法详解:【目标检测】RCNN算法详解 - ...

  • 搞定目标检测(SSD篇)(下)

    搞定目标检测(SSD篇)(上)主要分析了目标检测的基本原理和技术局限,本文将继续上集的未尽事宜,详解如何使用SSD...

  • 深度学习

    谁可以推荐几本关于ssd目标检测算法的书籍呀?

  • [转]【SSD 算法】史上最全代码解析-数据篇

    原文地址 【SSD 算法】史上最全代码解析-数据篇 前言 SSD 代码详解数据篇,旨在全方位介绍数据从下载到数据增...

  • 目标检测|实战总结

    1.实现ssd-keras实时目标检测算法,并制作十张图片的测试集。效果一般。ssd算法是继faster-rcnn...

网友评论

    本文标题:SSD物体检测算法详解

    本文链接:https://www.haomeiwen.com/subject/qtgviqtx.html