目标检测主流方法有两大类

two-stage,以rcnn系列为主,采用建议框的方式对目标进行预测,过程首先要经过网络生成候选框,分类背景前景与进行第一次回归,之后再进行一次精细回归。

优点是准确率高,但速度较one-stage慢

one-stage,以yolo 、sdd等为主,通过事先制定先验框(对图像均匀进行选取先验框),直接回归出目标的坐标来检测。

优点是速度快,但精度稍微低(均匀的密集采样的一个重要缺点是训练比较困难,这主要是因为正样本与负样本(背景)极其不均衡,导致模型准确度稍低)

SSD的主要特点:

1.采用多尺度预测,对图像的整体信息提取的比较完整

2.速度与精确度都比较高;

3.利用卷积进行检测;

4.设置先验框,这个与yolo的先验框类似但不同;类似fast rcnn中的anchor机制,尺度与长宽比不同。

另外,再yolo3中已经对先验框的设置进行了改进,采用了ssd的多尺度方法,设置了9中先验框,最后达到的准确率与速度都是比较好的。

SSD的网络结构

下面这张图是ssd的网络结构,网络的基础cnn网络是用vgg16_atros版本,在vgg16的基础上进行了改进,首先是使用卷积层来代替全连接层,对应图中的Conv6,Conv7,原来是FC6和FC7,

改为卷积是因为后面还需要添加新的卷积层;

第二个改进是采用deeplab中的带洞卷积(不增加参数与模型复杂度的条件下指数级扩大卷积的视野,代替pooling操作,可以使特征图的大小保持不变)的操作,使卷积核的感受野变大,在池化的同时对图片信息没有丧失很多信息。

可以看出,检测过程不仅在填加特征图(conv8_2, conv9_2, conv_10_2, pool_11)上进行,为了保证网络对小目标有很好检测效果,检测过程也在基础网络特征图(conv4_3, conv_7)上进行。小物体在高层特征图上保留很少的信息,

通过增加输入图像的尺寸能够解决对小物体检测效果。

对于每个特征图有不同的先验框,先验框的设置,包括尺度(或者说大小)和长宽比两个方面。其遵守一个线性递增规则:随着特征图大小降低,先验框尺度线性增加。

对于第一个特征图Conv4_3,因为比较大,所以后面加了一个l2 normlization,这个与batch normlization有所不同,l2 normlization仅仅对每个像素点在channels维度上进行归一化,batch normlization是在(batch_size,wight,height )上同时进行

归一化的。

接下来是卷积检测的过程,对应图中的倒数第二个框(Detectiongs:8732 class)  ,8732指的是所有特征图得到的先验框个数;不同的特征图所对应的先验框的个数也不一样;

每个特征图对应的框数如下:

38×38×4+19×19×6+10×10×6+5×5×6+3×3×4+1×1×4=8732

一般情况下,每个单元会设置多个先验框,其尺度和长宽比存在差异

SSD训练的过程

对于每个ground truth来说,第一个原则是选取一个先验框与之iou最大的来匹配,但是这种方法会使得正负样本变得不均衡,所以需要第二种原则,

第二种原则即:对于剩下的先验框,若iou大于某个阈值(0.5),也将之与ground truth匹配,因为一个ground truth可以匹配多个先验框,但是一个

先验框只能匹配一个ground truth,

即使这样,负样本还是很多,为了保证正负样本尽量平衡,SSD采用了hard negative mining,就是对负样本进行抽样,

抽样时按照置信度误差(预测背景的置信度越小,误差越大)进行降序排列,选取误差的较大的top-k作为训练的负样本,以保证正负样本比例接近1:3。

训练的损失函数:

损失函数有两部分构成:定位的损失,以及置信度函数的损失;

N是样本个数,xij这个值是一个指示参数,代表的是第i个先验框与第j个ground truth关于类别k是否匹配,值为0和1;

Lloc是位置的损失函数,位置损失函数采用smmothl1来计算,

Lconf是置信度损失函数,前半部分是关于类别p匹配的概率预测,后半部分是背景概率预测;计算采用softmax loss;

图片转自:https://www.cnblogs.com/fariver/p/7347197.html

SSD的预测过程:

预测过程首先根据类别置信度确定其类别,过滤掉背景的先验框,然后根据置信度值过滤低于阈值的先验框,

对于这些先验框计算其位置信息,

再把置信度按降序排列,通过NMS,最后得出预测目标框。

SSD的理解,为PyramidBox做准备的更多相关文章

  1. SSD论文理解

    SSD论文贡献: 1. 引入了一种单阶段的检测器,比以前的算法YOLO更准更快,并没有使用RPN和Pooling操作: 2. 使用一个小的卷积滤波器应用在不同的feature map层从而预测BB的类 ...

  2. 反射学习总结 --为理解SpringMVC底层做准备

    反射是什么? 通俗理解 - 照X光. java:一个类在反射面前就像照X光,清清楚楚明明白白. 应用:我们的ide中,能够"."一下就知道类中的所有方法就是通过反射实现的. XML ...

  3. Servlet学习总结,为理解SpringMVC底层做准备

    Servlet 一句话概括 :处理web浏览器,其他HTTP客户端与服务器上数据库或其他应用交互的中间层 Servlet 生命周期 : 1.类加载, 2.实例化并调用init()方法初始化该 Serv ...

  4. 对QT的理解——能在公司里不做Java,不做很偏门的产品,不使用偏门的语言,还有钱挣,要有感恩的心

    我的理解: QT做应用软件可以很强大,界面足够漂亮(最有意思的是QSS,让我刮目相看),应该是足够了.同时QT也提供了源码,不过超级复杂,难以理解,所以还是无法深入底层.另外它提供了一个额外的好处,就 ...

  5. SSD -----TLC MLC SLC

    SLC缓存什么鬼?TLC评测造假要持续多久 2016.5.5来源:中关村在线 TLC的廉价真的将SSD引入了全面普及的高速公路上,谈到TLC我们更多的理解是TLC的P/E(Program/Erase ...

  6. SSD 为什么顺序写比随机写性能更好?

    SSD以Page为单位做读写,以Block为单位做垃圾回收,Page一般有16KB大小,Block一般有几十MB大小,SSD写数据的逻辑是: 1)将该块数据所在的Page读出 2)修改该Page中该块 ...

  7. SSD回归类物体检测

    本宝宝最近心情不会,反正这篇也是搬用别人博客的了:(SSD就是YOLO+anchor(不同feature map 作为input)) 引言 这篇文章是在YOLO[1]之后的一篇文章,这篇文章目前是一篇 ...

  8. 原 CNN--卷积神经网络从R-CNN到Faster R-CNN的理解(CIFAR10分类代码)

    1. 什么是CNN 卷积神经网络(Convolutional Neural Networks, CNN)是一类包含卷积计算且具有深度结构的前馈神经网络(Feedforward Neural Netwo ...

  9. SSD检测几个小细节

    目录 一. 抛砖引玉的Faster-RCNN 1.1 候选框的作用 1.2 下采样问题 二. SSD细节理解 2.1 六个LOSS 2.2 Anchor生成细节 2.3 Encode&& ...

随机推荐

  1. JVM、JRE、JDK的区别

    什么是Java虚拟机(JVM)?为什么Java被称作是"平台无关的编程语言"? Java虚拟机是一个可以执行Java字节码的虚拟机进程.Java源文件被编译成能被Java虚拟机执行 ...

  2. mysql创建数据库用户

    连接mysql cmd--> mysql -hlocalhost -uroot -pmypassword 退出mysql mysql> quit 也可用exit或者 \q ======== ...

  3. Java的Object几个重写的方法

    1:toString(); 只是简单的列出对象的状态(也就是重要的实例变量的当前值). package jicheng;public class Animal { public static void ...

  4. Codeforces 803E--Roma and Poker (DP)

    原题链接:http://codeforces.com/problemset/problem/803/E 题意:给一个n长度的字符串,其中'?'可以替换成'D'.'W'.'L'中的任意一种,'D'等价于 ...

  5. Javac编译找不到符号,报错

    Javac编译找不到符号 报错 找不到符号 如果是两个.java有调用关系,需要同时编译 首先我检查了下代码,发现并没有问题,然后将A.java文件的内容复制到D.java中,发现程序能正常运行,而之 ...

  6. flex布局滚动问题,子元素无法全部显示的解决办法

    flex布局使用起来非常方便,对于水平垂直居中的需求,很容易就能实现.但是前不久,在做全屏弹窗遮罩登录的时候,遇到了flex布局滚动的一个问题,在此记录一下. 问题重现 理想情况下,当然是下面的状态, ...

  7. vim中 E212:无法打开并写入文件 的解决办法

    因为centos7刚安装的时候是无法上网的,所以,需要去配置一下ifcfg-ens33文件,但实际上这个文件是只读的文件,root也无法去更改内容,这时候保存的时候需要使用 w ! sudo tee ...

  8. MVC路由解析---IgnoreRoute

    MVC路由解析---IgnoreRoute   文章引导 MVC路由解析---IgnoreRoute MVC路由解析---MapRoute MVC路由解析---UrlRoutingModule Are ...

  9. 时间复杂度为n^2的排序

    时间复杂度为n^2的排序 冒泡排序和选择排序的共同点:每次都是在找剩下元素中最小(大)的元素 不同点:冒泡排序存在多次交换,而选择排序每次只存在一次交换序号 #include<iostream& ...

  10. .NET/VB.NET: solving the error “The system cannot find the file specified.” “\Temp\.NETFramework,Version=v4.0.AssemblyAttributes.vb”

    Source Link Bumped into this error a while ago in Visual Studio 2010: Kind Error Number 80 Descripti ...