Coursera, Deep Learning 4, Convolutional Neural Networks, week3, Object detection

学习目标

 

  • Understand the challenges of Object Localization, Object Detection and Landmark Finding
  • Understand and implement non-max suppression
  • Understand and implement intersection over union
  • Understand how we label a dataset for an object detection application
  • Remember the vocabulary of object detection (landmark, anchor, bounding box, grid, ...)

 

Objective Localization

分类,分类加定位,检测。前两种问题都是针对一个object, detection 是针对多个object

  

 在classification with localization 问题中,就是在output 的 softmax 输出的基础上在加了4个参数来定位bounding box.

  

 

 

  

 

Landmark detection

  

 

 

Object detection

   

 

  

Sliding windown detection 算法最大的缺点是computational cost. 在早期人们用简单的线性分类器去分类的时候还好,现在用conv net 去分类尤其在stride 很小的情况下就cost太高了。幸运的是这个问题有办法解决. 接着往下看

 

Convolutional implementation of Sliding Windows

 

下图表示了怎么把fully connected layer 转化为convolutional layer.

  

 

下面显示4次计算高度重复,下图第二行演示了使用第一行训练出来的filter parameter 去预测label,这样可以图像的share的重合的部分,极大提高计算效率。Convolutional 实现可以一次性求出结果而不是循环很多次.

现在还剩一个问题就是只考虑了分类问题没有考虑定位localization问题. 那么怎么定位呢,我们很容易想到前面介绍的classification+localization, 请继续往下看。

   

 

 

下图演示了用3x3的分割来做分类和定位,实际工作中会更细的分割,比如19x19。 

一个对象的midpoint在哪个cell里,就说这个对象属于哪个cell.

 

YOLO 算法

YOLO 算法就是前面介绍的知识点的集成,对每一个小方框使用了classification+localization, 然后对整个9个小方框并没有循环,而是使用了convolutional 实现一次性计算。

YOLO 算法能更精确的预测bounding box. 因为解决了不能正好框住object的问题.

   

 

bounding box 的encoding. bh, bw 是和小框边长的比例,可以>1.

   

 

IoU (Intersection over Union)

  

 

Non-max suppression

解决同一个对象被多次检测到的情况, 去除那些可能性小的bounding box 只留下最可能的

  

 

  

 

 

 Anchor Boxes

Anchor Boxes 是干什么的?- 使得可以检测多个Object.

为什么之前讲的就是一个cell 只能检测一个Object呢?因为一个y 向量里面只有一个bounding box.

 

学习过程了产生了一个问题,为什么一定要预定义一些Anchor Box呢?直接像只处理单个Object那样测量一个bounding box, 只不过对多个object的情况测量多个bounding box 不就行了吗? 这里加一些个人理解,我觉得测量多个bounding box这样做也可以,本质上来说Anchor Box 就是bounding box, 只是Anchor Box 尺寸固定更加容易对input 图片标注. 纯属个人理解,希望有人看到这里指教一下.

  

 

  

 

  

 

 

怎么选Anchor box呢?

人们一般手动选择5-10个可以cover 待检测对象的box. 更好的做法是用K-means算法来归类待检测对象,然后自动选出anchor box.

 

YOLO Algorithm

前面讲了核心的 YOLO算法,然后又讲了一个特殊情况的处理,已经一个对象多次被检测到的情况就需要 non-max suppression, 多个对象共同属于一个cell的情况就需要 Anchor Box. 所以这里集成了完整的YOLO算法.

  

  

 

  

  

 R-CNN 

Region CNN - 忽略一些明显没有用的grid cell

 

转载于:https://www.cnblogs.com/mashuai-191/p/8763067.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值