zoukankan      html  css  js  c++  java
  • Going Deeper with Convolutions(Inception v1)笔记

    Abstract

    该网络结构可以在增加网络宽度和深度的同时保持计算预算不变。结构的选择基于Hebbian原理和多尺度处理的直觉。

    Introduction

    First of All

    • 图像识别和对象检测方面的进步,不但来源于更强的硬件、更大的数据集和更大的模型,而且主要是因为新的思路、算法和改进之后的网路结构。
      例如Girshick大神的R-CNN,不是只利用深层网路或更大的模型,而是要结合深层结构和经典计算机视觉算法。
    • 移动和嵌入式计算使得算法(CNN)的效率越来越重要。

    Inception
    "We need to go deeper"(盗梦空间里的台词)

    Depth

    • 一个新的组织水平(Inception module)
    • 网络深度的增加
    1. 在大的数据集上,趋势是增加层数和层的size,同时使用dropout解决过拟合问题
    2. 多尺度:一种类似灵长类视觉皮层的机制(primate visual cortex),但是Inception结构有所不同(Arora的论文)
      • Inception是学习得到的
      • Inception会在网络中重复多次
    3. NIN:1x1的卷积可以降低维度,限制网络的大小
    4. R-CNN:两步检测,本文提出了类似的pipeline,但是有改进
      • 多边框(multi-box)
      • 更好的候选框

    Motivation and High Level Considerations

    增加网络的深度和宽度会带来两个问题

    • 过拟合
    • 所需计算资源的暴增(二次方)

    解决思路

    • 使用稀疏连接结构
      • Arora的开创性工作:根据特征和输出聚类之间的相关性逐层进行学习,得到最优网络结构
      • Hebbian原理:neurons that fire together, wire together

    不利因素

    • 现今的计算架构对非均匀(non-uniform)稀疏数据结构的数值计算十分低效
      • 即使算数运算减少100倍,计算稀疏矩阵也不一定能成功
      • 当使用充分改进、精心调整、尽可能利用底层CPU和GPU硬件细节,使得密集矩阵(dense matrix)的乘法速度极快的数值运算库时,差距会进一步增大
      • 目前面向视觉的机器学习系统中实现空间域稀疏性的方式是使用卷积
        • 传统上(LeNet5)使用随机的稀疏连接表,以打破对称性,改进学习能力
        • 从AlexNet开始又回到全连接方式,以便更好的优化并行计算
        • 结构上的均一性、大量的滤波器和更大的batch size允许使用高效的密集计算(dense computation)

    解决方法

    • 是否存在一种网络结构,可以通过计算密集矩阵充分挖掘目前的硬件性能,从而利用额外的稀疏性,甚至是在滤波器层面
      • 文献:聚类
      • 具有可行性(It dose not seem far-fetched)

    Starting

    • 第一作者(C.Szegedy)评估一个复杂的网络拓扑结构构建算法的假设输出,该网络试图逼近Arora提出的稀疏结构
      • 尽管有很大的推测性,但仅仅两轮迭代之后,就看到了不错的结果(modest gains),最终建立起了Inception结构

    注意

    • 结果的改善是否归因于Inception结构的设计原则是值得深究的
      • 这些原则在其他领域是否可以构建更好的网络

    Architecture Details

    The Main Idea

    • 在卷积视觉网络中如何逼近最优局部稀疏结构,并由现有的密集计算工具(卷积)实现

    Inception

    • Figure2.a(可以进一步参考Arora的论文和NIN)
      • 用1x1的卷积对局部区域的相关单元(理解为像素???)进行聚类
      • 用3x3和5x5的卷积对空间上分散的相关单元进行聚类
      • 池化是CNN中必要的结构
    • Figure2.b
      • 直接使用a结构,越到后面堆积的层越多,参数越多,非常低效
      • 使用维度下降和投影
      • 先卷积后降维会破坏特征图的稀疏性,因为降维是一个压缩过程,是一种密集性的信息表达方式,更难以去建模(先池化后降维???)
    • 前几层为传统的卷积操作
      • 现有架构计算效率的原因
    • 优势
      • 增加计算单元不会导致计算复杂度爆表
      • 符合视觉信息的多尺度处理方式
    • 实践
      • 建立精度稍低,但是计算成本更低的版本

    GoogLeNet

    • 224x224,减均值
    • 所有降维和投影之后都使用ReLU
    • 22个有参数的层(卷积层),总层数大约100
    • 使用平均池化代替全连接层
    • dropout
    • 网络中间层产生的特征或许具有非常高的可区分性
      • 添加辅助分类输出(相当于小网络)
        • 增强底层分类器的可discrimination
        • 增加梯度信号
        • 提供额外的正则化
        • 训练时loss的权重为0.3

    Training Methodology

    说不清那个trick更有用,太乱

    • DistBelief
    • SGD with 0.9 momentum
    • 学习率每8个epoch降低4%
    • Polyak averaging
    • 随机crop,大小8%-100%,高宽比3/4或4/3
    • photometric distortions
    • random interpolation methods
  • 相关阅读:
    2018-2019-1 20189221 《从问题到程序》第 6 周学习总结
    2018-2019-1 20189221 《Linux内核原理与分析》第七周作业
    《文献管理与信息分析》第 2 周学习总结
    2018-2019-1 20189221 《从问题到程序》第 5 周学习总结
    2018-2019-1 20189221 《Linux内核原理与分析》第六周作业
    2018-2019-1 20189206 《深入理解计算机系统》第一章学习笔记
    2018-2019-1 20189206 《从问题到程序》速读
    2018-2019-1 20189206 《深入理解计算机系统》速读
    2018-2019-1 20189206 《构建之法》速读
    2018-2019-1 20189206 《Linux内核原理与分析》第二周作业
  • 原文地址:https://www.cnblogs.com/whenyd/p/8378245.html
Copyright © 2011-2022 走看看