OMSCS-DL课程笔记06-Convolutional Neural Network Architectures
这个系列是Gatech OMSCS 深度学习课程(CS 7643: Deep Learning)的同步课程笔记。课程内容涉及深度学习的基本理论方法以及它在计算机视觉、自然语言处理以及决策理论等领域中的应用,本节主要介绍卷积神经网络的结构。
Backwards Pass for Convolution Layer
在上一节中我们介绍过卷积层的定义以及前向传播过程,而对于神经网络来说只知道前向传播是不够的,我们还需要了解卷积层的反向传播过程。首先我们来回忆一下卷积的前向传播,对于输出特征图上的每一点\(y[r, c]\)我们提取输入图像上的窗口\(x[r:r+k_1, c:c+k_2]\)然后和卷积核\(k\)进行内积计算作为卷积的输出值。
data:image/s3,"s3://crabby-images/584d6/584d6250b49552bdd6ef46d4208cd6005e25e354" alt=""
data:image/s3,"s3://crabby-images/a3d4a/a3d4a738890d42712c69957682493d8ac9c04ee6" alt=""
因此对于输出特征图上的每一点\(y[r, c]\)它只包含线性运算。当我们已知损失函数对于输出层的导数\(\frac{\partial L}{\partial y}\)时,就可以利用线性运算的反向传播公式来计算损失函数\(L\)关于输入\(x\)和卷积核\(k\)的导数。
data:image/s3,"s3://crabby-images/ae730/ae730ec228be6e0c584854d9fa13018cfeaea5c0" alt=""
Gradient for Convolution Layer
首先来考虑输出特征图关于卷积核的导数。由于特征图\(y\)上每一个像素都是使用同一个卷积核\(k\)进行计算得到,我们需要计算\(y\)上每个像素关于卷积核的导数\(\frac{\partial y[r, c]}{\partial k}\)并把它们加起来作为卷积核的导数。
data:image/s3,"s3://crabby-images/77841/778417fdea33464c9ed320009dcec78b7a8554aa" alt=""
具体来说,损失函数关于卷积核的导数\(\frac{\partial L}{\partial k}\)可通过上游的导数\(\frac{\partial L}{\partial y[r, c]}\)以及局部导数\(\frac{\partial y[r, c]}{\partial k}\)相乘来获得。由于卷积核\(k\)参与了\(y\)上所有像素值的计算,我们还需要再对\(y\)上的所有像素求和才能得到最终的导数。
data:image/s3,"s3://crabby-images/ecd0c/ecd0c7b5821e98b0393175a994df2d6dcdc4311d" alt=""
由于卷积是线性变换,我们可以进一步把局部导数\(\frac{\partial y[r, c]}{\partial k}\)代换为输入图像对应位置的像素值。这样不难发现损失函数关于卷积核的导数等于上游导数与输入图像的卷积(相关)。
data:image/s3,"s3://crabby-images/084c2/084c25c6d80072cb4c13266995070cc415690c95" alt=""
data:image/s3,"s3://crabby-images/12c8c/12c8c81bb6695f237cbba45369819a969830a97c" alt=""
接下来考虑输出特征图关于输入特征图的导数。类似于计算卷积核导数的过程,我们同样需要对输出特征图上的导数进行求和,不过对于输入特征图上的像素\(x[r, c]\)我们只需要考虑它的邻域即可。
data:image/s3,"s3://crabby-images/d222b/d222b6f649ed655b27ecf43a67a105972b83a6e0" alt=""
data:image/s3,"s3://crabby-images/aeb82/aeb82a60c61e99f21c4e45b791e8592d1a1bf45e" alt=""
data:image/s3,"s3://crabby-images/fa62e/fa62efd6248548677781c87c92ff3a3b400b6f1c" alt=""
我们同样对求和公式进行变形,可以发现损失函数关于输入特征图的导数等于上游导数与卷积核的卷积。
data:image/s3,"s3://crabby-images/2a60b/2a60b59841d65127b29be28af06dc997e3ef4c49" alt=""
data:image/s3,"s3://crabby-images/9a013/9a013ee6f0e678d0eb8c47f57c023efa0599b8c8" alt=""
data:image/s3,"s3://crabby-images/1f95b/1f95bab0f8e7b9548e34d36ebd867cfec8dd4c81" alt=""
Simple Convolutional Neural Networks
Combining Convolution & Pooling Layers
我们把卷积层和池化层也加进神经网络中就得到了卷积神经网络(convolutional neural networks, CNN)。
data:image/s3,"s3://crabby-images/6e113/6e1138e850c418636175d7725b34a0dca4735e50" alt=""
典型的CNN通常还包括全连接层(fully connected layers)作为最终的分类器,这样整个网络可以理解为将图像输入到卷积层中提取特征然后利用全连接层对提取到的特征进行分类。
data:image/s3,"s3://crabby-images/e61ef/e61ef5822cfee92e0ea22223fc1a287302b72706" alt=""
data:image/s3,"s3://crabby-images/7efdd/7efdd9dfb98cfa84af1d5eef71dde574fc1cf5fb" alt=""
CNN中一个常见的概念是感受野(receptive fields)。随着卷积层和池化层的增加特征图的长和宽尺寸会不但减少,因此特征图上每一个像素对应输入图像的区域会不断增加。这个对应的区域称为”感受野”。
data:image/s3,"s3://crabby-images/65144/65144a2e7d75e95589836ac40509ce39aca876f9" alt=""
LeNet Architecture
这样的网络结构可以追溯到80年代的LeNet,当时研究人员就提出了这种结构的CNN来进行手写数字和字母的识别。
data:image/s3,"s3://crabby-images/d4d03/d4d037b0e5386ee35d18fcd51fe20c42978b83a8" alt=""
data:image/s3,"s3://crabby-images/aadae/aadae838b9033cb56eb91d59ed82dac9362d1817" alt=""
由于CNN具有平移不变性和一定程度的旋转不变性,LeNet对于输入图片的几何变换都有比较好的适应性。
data:image/s3,"s3://crabby-images/9cddd/9cddda88053a277f7ad2aefd2ef3bde7051fec60" alt=""
data:image/s3,"s3://crabby-images/eb83e/eb83e81a4321f1f3472aead2e4349cc267e22642" alt=""
data:image/s3,"s3://crabby-images/8e9ae/8e9ae9b00dc64e59097188d97c2c0b252b3e70a0" alt=""
Advanced Convolutional Networks
AlexNet
现代CNN的流行始于2012年,当时AlexNet以巨大优势击败了传统人工特征+分类器的图像识别方法,从此基于CNN的模型成为了计算机视觉和图像识别领域的主流方法。
data:image/s3,"s3://crabby-images/8680f/8680f0fe0219c86719031c90920c3b36b92a7854" alt=""
整体来看AlexNet与LeNet在结构上的差异不大,但AlexNet使用了更加先进的激活函数以及一些现代的正则化方法,同时在大规模训练数据以及数据增强技术的加持下AlexNet超越了所有的传统图像识别方法。
data:image/s3,"s3://crabby-images/96e10/96e10c38548bd7a54f380b52401bafa436548439" alt=""
VGG
在AlexNet基础上人们还提出了各种各样的网络结构,比较经典的是VGG网络。和AlexNet相比,VGG包含更多的层数也因此有着更好的性能。
data:image/s3,"s3://crabby-images/0f1a5/0f1a539bd4db1310284323e5890f52d5ad03903d" alt=""
data:image/s3,"s3://crabby-images/dd156/dd1560c4fa78c995e29eca9925af27f9f014baa9" alt=""
data:image/s3,"s3://crabby-images/edce0/edce086d3877c5da38251236cd391fd6b5f4148b" alt=""
Inception Architecture
同时人们还发现一味增加网络深度有时并不会提高模型的性能,因此在GoogLeNet中提出了inception module这样的单元来提取图像特征。inception module的核心是在一个层中包含多个不同尺寸的卷积核,这样就可以提取到同一输入下不同尺度上的特征并加以融合。
data:image/s3,"s3://crabby-images/51b89/51b8982c690d08f516890923fca3a87a2a7b7de3" alt=""
data:image/s3,"s3://crabby-images/79e71/79e71e97ffd1d4caf954674dced20cc2b1c3ccba" alt=""
Residual Blocks and Skip Connections
为了解决训练深层网络十分困难的问题,人们提出了残差连接这样的结构形式。它的核心是在卷积后将输出特征图像与输入特征图像相加,这样使得输入特征总是可以得到来自输出特征的导数,从而避免了梯度消失的问题。
data:image/s3,"s3://crabby-images/09552/09552de1984e1a65c28de6fde01f439e38fb88b9" alt=""
Evolving Architectures and AutoML
近年来还涌现了一些基于进化算法以及强化学习的自动化网络设计方法,一些研究指出这类自动化网络设计方法可以超越以往的人工设计网络。除了寻找性能更好的网络结构外,一些研究还试图在保证性能的基础上减少模型的复杂度从而得到更高效的网络结构形式。
data:image/s3,"s3://crabby-images/caf6c/caf6c60a0c0dcbcc92ea07fcc7ce4b86d438c334" alt=""
data:image/s3,"s3://crabby-images/5d121/5d12111a6232f84ab23eb7c212a09bec37a4a7d9" alt=""
Transfer Learning & Generalization
Generalization
模型的泛化能力(generalization)是机器学习最关心的指标。当我们训练好模型并应用在使用真实的数据上时误差的来源包括一下三个部分:
- optimization error: 模型的训练过程中可能无法保证完全没有误差
- estimation error: 即使模型在训练数据上完全没有误差,模型可能会发生过拟合
- modeling error: 模型学习到的假设可能不适用于真实的数据
对于比较简单的模型,optimization error和estimation error一般都会比较小;但此时模型的表达能力有限可能无法学习到合适的假设,进而导致比较大的modeling error。
data:image/s3,"s3://crabby-images/23d23/23d23eacb464e5ff5ab45f773c20161e86f4f366" alt=""
而对于更加复杂的模型,充分训练后往往可以学习到足够好的假设使得modeling error会比较小;但相对地模型的训练会更加困难,也更容易发生过拟合的现象。
data:image/s3,"s3://crabby-images/efbad/efbadc1510f3837cbaf7195e127de61698a207c6" alt=""
data:image/s3,"s3://crabby-images/c14cb/c14cbbb3d3e5823fdb913784dbf9a3acf1f4894b" alt=""
Transfer Learning
很多现实中的机器学习任务都没有大量标注的数据,在这样的情况下可以考虑使用迁移学习(transfer learning)的方式来训练模型。迁移学习的基本思想是使用在大规模数据集上训练好的模型来进行初始化,然后在给定的数据集上进行微调从而加速模型的训练过程。常用的迁移学习方法是使用预训练的模型参数,然后将网络的最后一层换成一个新的全连接层,最后在训练模型时对模型进行微调或是固定卷积层的参数只对最后的全连接层进行更新。
data:image/s3,"s3://crabby-images/6d8cd/6d8cdf2cc774a483420d8b4cda99a0362e53fe31" alt=""
data:image/s3,"s3://crabby-images/ad166/ad16644472481db55c4f45818050cc672e545354" alt=""
data:image/s3,"s3://crabby-images/3fbe4/3fbe4483c32b81173af21d9bef8e4b396be74b03" alt=""
目前已经有大量的实践证明了这种预训练模型的有效性,而且人们还发现这样预训练出来的模型参数不仅可以提升图像识别的效率,对于一些其它的视觉任务也有很大的帮助。
data:image/s3,"s3://crabby-images/effe1/effe1c44d721e9190a6c1f84a963661d57f27fea" alt=""
当然这种迁移学习的方法也不是万能的。如果训练数据集和预训练的数据集相差太多迁移学习的效果就不会很好,而如果训练数据集上有足够多的数据迁移学习则可以加速模型的收敛过程。
data:image/s3,"s3://crabby-images/1f327/1f327c9e5488bb1578d53f65c68a85cc9f6a4ad3" alt=""
目前深度学习中还有很多相关的领域去研究如何解决缺少数据标注的问题。
data:image/s3,"s3://crabby-images/440a1/440a11a502e1648cbc4aa9d8beea4fd184c1c66f" alt=""