SSD:Single Shot Multibox Detector:第一部分-论文阅读

作 者: 心有宝宝人自圆

声 明: 欢迎转载本文中的图片或文字,请说明出处

写在前面

受到前辈们的启发,决定应该写些文章记录一下学习的内容了

之前也读过一些文章、写过一些代码,以后再慢慢填坑吧 😀

现在把最近读的学习与大家分享一下

本人初入江湖,分享一下自己的理解和心得,如有错误或理解不当敬请指出 😀

SSD

论文地址:SSD: Single Shot MultiBox Detector

SSD是一个one-stage目标检测方法,不同于R-CNN系列的方法(two-stage),能够又快有准确的进行目标检测

目标检测嘛,就是我们常看到的那种用一个个方框框圈出检测目标

Object detection

接下来就和大家分享一下我对论文的理解 (这一部分主要是思路和总体上的把握) 😀

接下来还有代码实现部分(细节实现)正在填坑,请多多关注*

代码实现部分(细节实现):SSD:Single Shot Multibox Detector:第二部分-代码与细节实现(来就来全家桶,有些这篇文章没有讲清楚的内容、或令人困惑的地方都写在里面了,欢迎围观😀)

Abstract

​ 本文提出仅使用一个深度神经网络进行目标检测的方法,将输出空间的边界框离散化为以aspect ratios(长宽比)和scales参数确定形状和大小、基于每个特征图生成的一系列固定的锚框。网络连接了从不同特征图生成的不同分辨率的预测,很自然的能够处理不同的目标尺寸。SSD生成的锚框类似于目标提议方法,但SSD消除了提议区域生成和后续像素或特征重采样阶段,并把这些过程封装在了一个网络里。

Introduction

之前的目标检测方法基本都是如下方法的变种(two-stage)-文中作者很形象的形容为pipeline

  • pipeline:假设提议区域,并对每个提议区域进行重采样 ➡ 使用分类器对提议区域分类

  • 该方法存在的最大缺点:准确率和计算资源消耗(速度)的权衡

SSD则是一种single-shot的目标检测方法(YOLO也是single-shot)

  • 使用小卷积核预测目标类别和边界框的偏移量(高层特征图的感受野大,是小卷积核就能处理到大尺度特征)
  • 使用独立的预测器(filter)处理不同长宽比的检测,这些滤波器作用于多层特征图以检测不同尺度的特征
    • 这些滤波器卷积核的设计使卷积过后的特征图的大小不发生变化,相当于对每一原始特征图的每一像素块进行了预测
    • 我觉得这里的设计与锚框的设计是有一致性的,等到了介绍锚框的部分可以再来回顾一下😀

summarize their contributions(先总结一下SSD的贡献)

  • 核心操作:使用一组固定的边界框(类似R-CNN锚框,也称作锚框)、作用于特征图的独立卷积核
  • 准确率提升操作:边界框显式使用不同长宽比,对不同尺度的特征图产生不同尺度的预测
  • end-to-end:特征的提取由网络学习完成,...妈妈再也不用担心如何选特征参数了🐷(当然他的固定的边界框也是人为定的,对训练有重要影响)
  • 任意输入形状:往往最后的分类器限制了输入的形状,SSD把预测器改为了卷积层(当然训练的时候一般固定输入形状)

SSD的实现介绍

1. 模型

feed-forward卷积神经网络

  • 使用截断了全连接层的image classification network
  • 产生一系列固定大小的边界框(不同的aspect ratios 和 scales,作用于不同特征图,未来的ground truth
  • 预测边界框内不同目标的类别得分、实际的边框的偏移(预测器产生的结果,预测值
  • 非极大值抑制得到最终的检测结果(留下信度最高的预测边界框)
SSD和YOLO的网络结构

auxiliary structure(辅助结构,一些模型重要部分的介绍)

  • 多尺度特征图的检测:

    多尺度特征图的检测

    • 将指定feature map传入独立的predictor预测offset和class,并将这些预测结果加到截断的base net之后
    • 这些特征图逐层减小,能检测到不同尺度的特征(就是之前说的特征图减小后每个像素的感受野就很大,小卷积核就能捕获大特征)
  • 卷积预测器:

    • 上面每个指定feature map传入的predictor,以卷积的方式实现

    • predictor分为预测offset和class,每个卷积核的大小均为3x3,stride为1,通道维为P(之后用作特征维,设计理念类似于1x1卷积层)

  • 默认锚框和长宽比:

    • 每个特征图对用一组默认锚框(不同aspect ratios,scales参数),假设特征图为m x n,<u>锚框是以每个像素块为中心生成的</u>,每个像素生成k个锚框(可以先认为锚框是人为选定目标区域,但其与ground truth不完全一致,还需要进行处理才能变成训练用的ground truth,这是后面的部分了......大概能知道锚框是按像素块生成的,所以predictor的结果也是要按像素生成的)
    • predictor计算c个类别得分和4个offset,每个像素产生(c+4)k个预测,每个特征图产生(c+4)kmn个预测
    • 多个特征图上不同形状的锚框有效的离散化了输出空间边界框的形状
不同特征图上的锚框

2. 训练

锚框与ground truth匹配策略:(终于可以将锚框转换为ground truth了 (_),然而锚框的组成参数还要往下...... )

  • 训练中我们需要为锚框分配ground truth信息,判断指标:jaccard overlap(交并比)

    以一个ground truth图像的锚框分配为例:

    • 锚框与ground truth各个类别分别计算 jaccard overlap:shape ->(k\*m\*n,num_class))

    • 为每个ground truth边框分配一个固定锚框(这些锚框拥有不同位置(像素)、aspect ratios、scales)(先把交并比最大的锚框分给该类,把output之中该行给去除,最后得到了新输出为:shape ->(k\*m\*n-num_class,num_class)的未分配锚框)

    • 剩余未分配的固定锚框,以jaccard overlap>阈值(0.5)来分配ground truth信息(每个未分配锚框找出交并比最大值以及对应目标类别,若交并比大于阈值,则为该锚框分配该目标类别)

      以上分类为POSITIVE

    • jaccard overlap<=阈值的锚框被分为背景类,NEGATIVE

训练目标(损失函数):

3.PNG
  • 位置损失函数:针对offset,使用Smooth L1函数(实际offset的四个指标已经被编码)
4.PNG
  • 信度损失函数:针对分类,使用Cross Entropy Loss
5.PNG
  • 针对offset的编码

    从上面 不同特征图上的锚框 图片中可以看出锚框的offset标识为(\Delta cx,\Delta cy,\Delta w,\Delta h),然而在计算LOSS的时候使用了如下转换:

    \hat{cx}=\frac{cx-cx_{anchor}}{width_{anchor}},\hat{cy}=\frac{cy-cy_{anchor}}{height_{anchor}},\hat{w}=log(\frac{w}{w_{anchor}}),\hat{h}=log(\frac{h}{h_{anchor}}) (1)

    其中(cx,cy,w,h)是ground truth的真实位置信息,(cx_{anchor},cy_{anchor},w_{anchor},h_{anchor})是锚框的真实位置信息

    这个时候会有如下的问题存在(个人理解😀):

    • ground truth信息是基于原始输入图像的大小,锚框大小基于特征图的大小,所以两者尺度存在不一致性
    • 即使同一特征图内,大的锚框可能会导致的offset偏大,使LOSS增加

    于是我们采取如下操作(个人理解😀):

    • 真实位置信息(cx,cy,w,h)使用相对大小表示(\frac{真实位置信息}{特征图scale}),这样ground truth信息和锚框的大小在尺度上就一致了(由于网络正向传播是采样过程,原始图像和特征图的相对位置在空间上具有一致性,简单说就是等比例缩小......)
    • 之后把不同offset做如(1)式的变换,消除了锚框各个锚框差异的影响

为锚框选择scales和aspect ratios参数(作者使用的锚框参数):

实际操作中,两组参数的选择是自己指定的,要让锚框尽可能平铺在特征图上,这里作者给出了他的选择

  • 类比语义分割:网络低层捕获到更细节的信息,有利于提高语言分割准确率;global context pooled能够帮助平滑语义分割结果

  • 不同层的特征图有不同的感受野,SSD将固定锚框平铺在特征图上,特定特征图上的predictor只用去学习响应该特定尺度下的目标(这个时候需要数据增广了来扩充训练集来增加各个尺度的目标)

  • 计算公式:aspect ratio -> a_k, scales -> s_k

    W_{anchor}\times H_{anchor}= s_k^2, \frac{W_{anchor}}{H_{anchor}}=a_k \Rightarrow W_{anchor}=s_k\sqrt a_k , H_{anchor}=\frac{s_k}{\sqrt a_k}

    a \in [1,2,3,\frac{1}{2},\frac{1}{3}],

    s_k=s_{min}+\frac{s_{max}-s{min}}{m-1}(k-1), k \in [1,m], s_{min}=0.2,s_{max}=0.9

    此外当 a_k=1时,会额外引入scale=\sqrt {s_ks_{k+1}}的锚框

    一般高层的特征图选用更大的scale来捕获更广的感受野,低层的特征图则使用小scale来捕获更为细节的信息

原始输入图像的锚框(只显示了第(250,250)像素点的,否则太过于凌乱)
高层特征图的锚框,将其按相对位置还原到原始输入空间

Hard negative mining:

  • 大部分锚框都是negative类别(背景类),尤其当锚框很多的时候,这样会导致训练数据正负类的不平衡
  • 当实际计算损失,将负类按信度损失排序,只选择信度损失最高的部分负类,使负类:正类最大为3:1

Data augmentation数据增广

  • 目的:增强对不同尺度、形状的输入图片的鲁棒性
  • 随机采样的选择:
    • 使用最原始的输入图片
    • 对原始图片采样,使的与检测目标最小jaccard overlap 分别为0.1,0.3,0.5,0.7或0.9
    • 随机采样一个patch

实验结果

更新一下:这部分的内容在SSD:Single Shot Multibox Detector:第二部分-代码与细节实现中有我个人的理解和代码的实现,欢迎围观😜

这一部分基本上是在使用不同的数据集、不同控制处理条件、不同网络结构的情况下,对实验所产生最终目标检测结果做了一次全面的测评.......

总得来说就是又快又准,blablabla...... 特别好,谁用谁知道😀

作者还总结了一些训练要点简要和大家分享一下:

  • 数据增广很重要,能大幅提升训练的效果,增强模型的鲁棒性,之前也提到过数据增广的必要性
  • 锚框的形状越多越好:锚框是用来生成训练用的ground truth label的,需要多种多样的形状来覆盖不同尺度的目标
  • Atrous算法:还没有研究过......溜了溜了😀
    细节实现的模型部分有我自己的理解
  • 不同分辨率的各输出层能使模型更好:不同的特征图主要负责各自尺度的目标,随着层数的升高,细节信息被丢弃的越多,所以小目标的检测需要更低层输出的特征图,SSD在尺度大的目标检测上比小目标的检测效果更好

总结

模型的关键特点
  • 不同的特征图上,锚框with不同的aspect ratios和scales (之前差不多一大半的篇幅都是锚框的生成处理过程.......)
  • 使用独立的小卷积核的卷积predictor来对选定的特征图对目标边界框做出预测
  • 适当的训练策略(实验结果部分给定的要点)使模型更优秀😀
8.PNG

新人上路,请多多关注😀,纯手动不易,欢迎讨论

转载请说明出处。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容