Convolutional Neural Networks (CNNs / ConvNets)
Convolutional Neural Networks are very similar to ordinary Neural Networks from the previous chapter: they are made up of neurons that have learnable weights and biases. Each neuron receives some inputs, performs a dot product and optionally follows it with a non-linearity. The whole network still expresses a single differentiable score function: from the raw image pixels on one end to class scores at the other. And they still have a loss function (e.g. SVM/Softmax) on the last (fully-connected) layer and all the tips/tricks we developed for learning regular Neural Networks still apply.
卷积神经网络与前一章中的普通神经网络(注:参见吴恩达机器学习)非常相似:它们是由具有可学习的权重和偏差的神经元组成。每一个神经元都是接收一些输入然后执行一次点积,通过非线性选择性地跟随它。整个网络仍然表达了一个单一可区分地评分函数:从一个原始图像像素到另一端地类别分数。并且,它们在最后一(全连接)层仍然具有损失函数(SVM:支持向量机;Softmax:归一化指数函数,与Sigmoid类似,对数组操作),我们为学习常规神经网络而开发的所有提示技巧仍然试用。
So what changes? ConvNet architectures make the explicit assumption that the inputs are images, which allows us to encode certain properties into the architecture. These then make the forward function more efficient to implement and vastly reduce the amount of parameters in the network.
那么,什么改变了?卷积神经网络体系结构明确假定输入是图像,这使我们能够将一些属性编码到体系结构中。这样可以提高前向函数的传播效率并大大减少网络中的参数量
Architecture Overview
Recall: Regular Neural Nets. As we saw in the previous chapter, Neural Networks receive an input (a single vector), and transform it through a series of hidden layers. Each hidden layer is made up of a set of neurons, where each neuron is fully connected to all neurons in the previous layer, and where neurons in a single layer function completely independently and do not share any connections. The last fully-connected layer is called the “output layer” and in classification settings it represents the class scores.
回忆:常规神经网络,正如我们在前一章看到的,神经网络接收到一个输入(单个向量),然后经过一系列隐藏层对其进行转化。每一个隐藏层由一组神经元组成,这里每一个神经元都与上一层完全连接;但是,一层中的神经元都是完全独立工作,不分享任何连接。最后一层全连接层被称为输出层,在分类设置中它表现为分类评分。
Regular Neural Nets don’t scale well to full images. In CIFAR-10, images are only of size 32x32x3 (32 wide, 32 high, 3 color channels), so a single fully-connected neuron in a first hidden layer of a regular Neural Network would have 32323 = 3072 weights. This amount still seems manageable, but clearly this fully-connected structure does not scale to larger images. For example, an image of more respectable size, e.g. 200x200x3, would lead to neurons that have 2002003 = 120,000 weights. Moreover, we would almost certainly want to have several such neurons, so the parameters would add up quickly! Clearly, this full connectivity is wasteful and the huge number of parameters would quickly lead to overfitting.
常规神经网络并不能很好的测量完整的图像。在CIFAR-10(图像数据集)中,图像的大小仅为32x32x3 (宽 32, 高 32, 颜色通道 3),所以一个常规神经网络在第一个隐藏层的全连接神经元将会拥有32323 = 3072 权重。这个数量看起来是可控的,但是,很明显这种全连接结构并不能扩展到更大的图像。例如,一个更加可观的图像(如200x200x3)将会导致神经元有2002003 = 120,000 个权重。此外,我们肯定希望有几个这样的神经元,所以参数会迅速增加。显然,这种全连接是不必要的,而且大量的参数很快就会导致过拟合。
3D volumes of neurons. Convolutional Neural Networks take advantage of the fact that the input consists of images and they constrain the architecture in a more sensible way. In particular, unlike a regular Neural Network, the layers of a ConvNet have neurons arranged in 3 dimensions: width, height, depth. (Note that the word depth here refers to the third dimension of an activation volume, not to the depth of a full Neural Network, which can refer to the total number of layers in a network.) For example, the input images in CIFAR-10 are an input volume of activations, and the volume has dimensions 32x32x3 (width, height, depth respectively). As we will soon see, the neurons in a layer will only be connected to a small region of the layer before it, instead of all of the neurons in a fully-connected manner. Moreover, the final output layer would for CIFAR-10 have dimensions 1x1x10, because by the end of the ConvNet architecture we will reduce the full image into a single vector of class scores, arranged along the depth dimension. Here is a visualization:
神经元的3D体积。卷积神经网络利用输入由图像组成的事实, 以更合理的方式约束体系结构。特别地,与常规神经网络不同的是,卷积神经网络的各层拥有排列在三个维度的神经元:宽度、高度、深度(请注意, 此处的“深度”一词指的是激活卷的第三个维度, 而不是整个神经网络的深度, 它可以指网络中的图层总数)。例如,CIFAR-10中的输入图像是激活的输入卷,该卷的尺寸维度是32x32x3。正如我们将会看到的,一层的神经元仅被连接到前一层的一个小区域,而不是以全连接的方式。此外,CIFAR-10最终的输出层具有1x1x10的维度,因为在卷积神经网络的末尾,我们将把一个完整的图像缩减到一个由类别分数组成按深度排列的一维向量。
Left: A regular 3-layer Neural Network. Right: A ConvNet arranges its neurons in three dimensions (width, height, depth), as visualized in one of the layers. Every layer of a ConvNet transforms the 3D input volume to a 3D output volume of neuron activations. In this example, the red input layer holds the image, so its width and height would be the dimensions of the image, and the depth would be 3 (Red, Green, Blue channels).
A ConvNet is made up of Layers. Every Layer has a simple API: It transforms an input 3D volume to an output 3D volume with some differentiable function that may or may not have parameters.
一个卷积神经网络由多个网络层组成,每一层都有一个简单的API(它通过一些可能具有或可能没有参数的不同的功能,把3D体输入转化为3D体输出)
Layers used to build ConvNets
构建卷积神经网络的图层
As we described above, a simple ConvNet is a sequence of layers, and every layer of a ConvNet transforms one volume of activations to another through a differentiable function. We use three main types of layers to build ConvNet architectures: Convolutional Layer, Pooling Layer, and Fully-Connected Layer (exactly as seen in regular Neural Networks). We will stack these layers to form a full ConvNet architecture.
正如之前描述的,一个简单的卷积神经网络是一组层序列,网络的每一层都通过不同的功能把一个激活体转化为另一个激活体。我们使三种用不同的层来构建卷积神经网络体系结构,卷积层、池化层和全连接层(常规神经网络所用到的)。我们把这些层堆叠起来,构建一个完整的卷积神经网络结构。
Example Architecture: Overview. We will go into more details below, but a simple ConvNet for CIFAR-10 classification could have the architecture [INPUT - CONV - RELU - POOL - FC]. In more detail:
结构示例,概述:下面我们将仔细介绍,但是一个应用于CIFAR-10分类的简单卷积神经网络可能有这样的结构[输入-卷积-激活函数-池化-全连接]
• INPUT [32x32x3] will hold the raw pixel values of the image, in this case an image of width 32, height 32, and with three color channels R,G,B.
输入[32x32x3]将会保持图片的原始像素值,本例中图像宽32,高32,有三个颜色通道RGB
• CONV layer will compute the output of neurons that are connected to local regions in the input, each computing a dot product between their weights and a small region they are connected to in the input volume. This may result in volume such as [32x32x12] if we decided to use 12 filters.
卷积层会计算神经元(连接了输入层的局部区域)的输出,每一个神经元都会计算权值和输入卷一部分区域的点积。如果我们使用12个卷积核,可能会生成[32x32x12]这样体积的卷
• RELU layer will apply an elementwise activation function, such as the max(0,x) thresholding at zero. This leaves the size of the volume unchanged ([32x32x12]).
RELU(线性整流函数)层会使用一个元素位的激活函数,如max(0,x)阈值为0.这使得卷的体积大小不变。
• POOL layer will perform a downsampling operation along the spatial dimensions (width, height), resulting in volume such as [16x16x12].
池化层将沿空间维度进行下采样操作,将卷变成[16x16x12].
• FC (i.e. fully-connected) layer will compute the class scores, resulting in volume of size [1x1x10], where each of the 10 numbers correspond to a class score, such as among the 10 categories of CIFAR-10. As with ordinary Neural Networks and as the name implies, each neuron in this layer will be connected to all the numbers in the previous volume.
全连接层将会计算类分数,最终卷的体积大小为[1x1x10],是个数字中每一个对应一个类分数,例如CIFAR-10的十个类别。和普通神经网络,也是它名字暗示的那样,这层每一个的神经元都会连接到前一个卷的每个数字。
In this way, ConvNets transform the original image layer by layer from the original pixel values to the final class scores. Note that some layers contain parameters and other don’t. In particular, the CONV/FC layers perform transformations that are a function of not only the activations in the input volume, but also of the parameters (the weights and biases of the neurons). On the other hand, the RELU/POOL layers will implement a fixed function. The parameters in the CONV/FC layers will be trained with gradient descent so that the class scores that the ConvNet computes are consistent with the labels in the training set for each image.
这样卷积神经网络通过各层把原始图像从原来的像素转化为最终的类分数。注意,有些层包含参数,有些层不包含。特别地,卷积层和全连接层(CONV/FC)执行地转换不仅包括输入卷地激活函数,还有包含参数(神经元的权重和偏差)的函数。另一方面,线性整流层和池化层会实现一个固定的功能。CONV/FC中的参数通过梯度下降来训练,以便卷积神经网络计算的类分数与训练集中每张图片的标签相一致。
In summary:总结
• A ConvNet architecture is in the simplest case a list of Layers that transform the image volume into an output volume (e.g. holding the class scores)
• There are a few distinct types of Layers (e.g. CONV/FC/RELU/POOL are by far the most popular)
• Each Layer accepts an input 3D volume and transforms it to an output 3D volume through a differentiable function
• Each Layer may or may not have parameters (e.g. CONV/FC do, RELU/POOL don’t)
• Each Layer may or may not have additional hyperparameters (e.g. CONV/FC/POOL do, RELU doesn’t)
• 一个卷积神经网络的结构最简单的情况下是一个将图像卷转化为输出卷(例,保存的类分数)的层序列
• 有几个不同类型的层
• 每一层通过不同的函数接受一个3D输入卷转化成一个3D输出卷
• 每一层可能有可能没有参数(CONV/FC 有, RELU/POOL 没有)
• 每一层可能有可能没有额外的超参数(CONV/FC/POOL 有, RELU 没有)
超参数hyperparameters ----根据经验进行设定,影响到权重和偏置的大小,比如迭代次数、隐藏层的层数、每层神经元的个数、学习速率等
The activations of an example ConvNet architecture. The initial volume stores the raw image pixels (left) and the last volume stores the class scores (right). Each volume of activations along the processing path is shown as a column. Since it’s difficult to visualize 3D volumes, we lay out each volume’s slices in rows. The last layer volume holds the scores for each class, but here we only visualize the sorted top 5 scores, and print the labels of each one. The full web-based demo is shown in the header of our website. The architecture shown here is a tiny VGG Net, which we will discuss later.
We now describe the individual layers and the details of their hyperparameters and their connectivities.
接下来将描述各层及其超参数和连接关系的细节。
Convolutional Layer
The Conv layer is the core building block of a Convolutional Network that does most of the computational heavy lifting.
卷积层是卷积神经网络的核心构件,它承担的大部分的计算量
Overview and intuition without brain stuff. Let’s first discuss what the CONV layer computes without brain/neuron analogies. The CONV layer’s parameters consist of a set of learnable filters. Every filter is small spatially (along width and height), but extends through the full depth of the input volume. For example, a typical filter on a first layer of a ConvNet might have size 5x5x3 (i.e. 5 pixels width and height, and 3 because images have depth 3, the color channels). During the forward pass, we slide (more precisely, convolve) each filter across the width and height of the input volume and compute dot products between the entries of the filter and the input at any position. As we slide the filter over the width and height of the input volume we will produce a 2-dimensional activation map that gives the responses of that filter at every spatial position. Intuitively, the network will learn filters that activate when they see some type of visual feature such as an edge of some orientation or a blotch of some color on the first layer, or eventually entire honeycomb or wheel-like patterns on higher layers of the network. Now, we will have an entire set of filters in each CONV layer (e.g. 12 filters), and each of them will produce a separate 2-dimensional activation map. We will stack these activation maps along the depth dimension and produce the output volume.
没有大脑的概述和直觉。让我们首先来讨论,没有大脑还神经元的类推,卷积层在计算什么?卷积层的参数由一系列可学习的卷积核构成。每一个卷积核在空间上都比较小(沿着宽度和高度),但是却贯穿了整个深度。例如,一个在卷积神经网络第一层的典型的卷积核可能拥有5x5x3的大小。在前向传递的过程中,我们在输入卷的宽度和高度上滑动(更准确的说,卷积)一个卷积核,并计算出卷积核条目和在任何位置的输入的点积。当我们沿着宽和高在输入卷上滑动卷积核,我们会生成一个2维激活映射,它会给出卷积核在任何空间上的响应。直观地说,网络会学习卷积核,当他们看到某种视觉特征时卷积核就会被激活,例如第一层上某个方向的边缘或某个颜色斑点,或最终在网络的较高层上看到整个蜂窝状或轮状图案。现在我们在每一个卷积层上都有一套完整的卷积核,并且它们中的每一个都会生成一个单独的2维激活映射。我们会沿着宽度和深度堆叠这些映射并生成一个输出卷。
The brain view. If you’re a fan of the brain/neuron analogies, every entry in the 3D output volume can also be interpreted as an output of a neuron that looks at only a small region in the input and shares parameters with all neurons to the left and right spatially (since these numbers all result from applying the same filter). We now discuss the details of the neuron connectivities, their arrangement in space, and their parameter sharing scheme.
大脑视图。如果你是大脑/神经元类比的粉丝,3D输入卷中的每一条输入都可以理解成一个神经元输出,这些神经元只关注输入的一小部分并在空间上和左侧或右侧的所有神经元分享参数。我们现在会讨论神经元连接的细节,它们在空间上的排布和参数共享的方案。
Local Connectivity. When dealing with high-dimensional inputs such as images, as we saw above it is impractical to connect neurons to all neurons in the previous volume. Instead, we will connect each neuron to only a local region of the input volume. The spatial extent of this connectivity is a hyperparameter called the receptive field of the neuron (equivalently this is the filter size). The extent of the connectivity along the depth axis is always equal to the depth of the input volume. It is important to emphasize again this asymmetry in how we treat the spatial dimensions (width and height) and the depth dimension: The connections are local in space (along width and height), but always full along the entire depth of the input volume.
本地连接。当我们在处理像图像这样的高维输入时,正如之前所看到的,将一个神经元连接到前一卷的所有神经元是不切实际的。相反,我们只将神经元连接到输入卷的局部区域。这个连接的空间范围叫做神经元的感受野(相当于卷积核的大小)。在深度上,连接的范围总书等于输入卷的深度。在处理空间维度(宽和高)和深度维度时,需要再次强调这样的不对称性:连接在空间(宽、高)上是局部的,但是在深度上总是沿着整个输入卷。
Example 1. For example, suppose that the input volume has size [32x32x3], (e.g. an RGB CIFAR-10 image). If the receptive field (or the filter size) is 5x5, then each neuron in the Conv Layer will have weights to a [5x5x3] region in the input volume, for a total of 553 = 75 weights (and +1 bias parameter). Notice that the extent of the connectivity along the depth axis must be 3, since this is the depth of the input volume.
例1,假设一个输入卷体积[32x32x3]。如果感受野的大小(或者卷积核的大小)是5x5,然后在卷积层中的每一个神经元在输入卷中将会有[5x5x3]区域的权值,总共75个参数(外加1个偏置参数)。注意沿着深度方向上连接的长度必须是3,因为这是输入卷的深度。
Example 2. Suppose an input volume had size [16x16x20]. Then using an example receptive field size of 3x3, every neuron in the Conv Layer would now have a total of 3320 = 180 connections to the input volume. Notice that, again, the connectivity is local in space (e.g. 3x3), but full along the input depth (20).
例2,假设一个输入卷体积[16x16x20],然后使用一个感受野为3x3的卷积核,在卷积层的每一个神经元与输入卷之间的连接将会有3320 = 180。再次注意,在平面上,这些连接是局部的,但是完全跟随输入的深度大小
Left: An example input volume in red (e.g. a 32x32x3 CIFAR-10 image), and an example volume of neurons in the first Convolutional layer. Each neuron in the convolutional layer is connected only to a local region in the input volume spatially, but to the full depth (i.e. all color channels). Note, there are multiple neurons (5 in this example) along the depth, all looking at the same region in the input - see discussion of depth columns in text below.
红色的输入卷和第一个卷积层的一组神经元如图所示。卷积层的每一个神经元在平面上空间仅与输入卷的一部分区域相连,但是深度上全部连接。注意,这里在深度上有多个神经元,它们都查看相同的输入区域。
Right: The neurons from the Neural Network chapter remain unchanged: They still compute a dot product of their weights with the input followed by a non-linearity, but their connectivity is now restricted to be local spatially.
神经网络章节的神经元保持不变,它们仍然计算权重和输入之间的点积,然后金国一个非线性激活函数,但是它们的连接在平面上还是局部的。
Spatial arrangement. We have explained the connectivity of each neuron in the Conv Layer to the input volume, but we haven’t yet discussed how many neurons there are in the output volume or how they are arranged. Three hyperparameters control the size of the output volume: the depth, stride and zero-padding. We discuss these next:
空间排布:我们已经解释了卷积层中每一个神经元到输入卷的连接性问题,但是我们还没有讨论在输出卷中由多少个神经元还有怎么排布。三个超参数控制输出卷的大小(深度、步长和零填充)
First, the depth of the output volume is a hyperparameter: it corresponds to the number of filters we would like to use, each learning to look for something different in the input. For example, if the first Convolutional Layer takes as input the raw image, then different neurons along the depth dimension may activate in presence of various oriented edges, or blobs of color. We will refer to a set of neurons that are all looking at the same region of the input as a depth column (some people also prefer the term fibre).
首先,输出卷的深度是一个超参数:它对应于我们想使用的卷积核的数量,每一个过滤器都在输入中学习查找不同的内容。例如,如果第一个卷积层把原始图像作为输入,那么沿着深度上不同的神经元可能被不同特定方向上的边缘或色块激活。我们倾向于把一组查找相同输入区域的神经元称为深度列(也有人叫“纤维”)
Second, we must specify the stride with which we slide the filter. When the stride is 1 then we move the filters one pixel at a time. When the stride is 2 (or uncommonly 3 or more, though this is rare in practice) then the filters jump 2 pixels at a time as we slide them around. This will produce smaller output volumes spatially.
其次,我们必须指定滑动卷积核的步长。当步长为1时,卷积核每次滑动一个像素。当步长为2(或者不常见的3或更多,尽管并不常见)时,卷积核滑动一次移动两个像素(跳过一个)。这会导致在空间上产生更小的输出卷。
As we will soon see, sometimes it will be convenient to pad the input volume with zeros around the border. The size of this zero-padding is a hyperparameter. The nice feature of zero padding is that it will allow us to control the spatial size of the output volumes (most commonly as we’ll see soon we will use it to exactly preserve the spatial size of the input volume so the input and output width and height are the same).
我们很快会看到,有时输入卷进行0填充会非常方便。补0的大小是一个超参数。补0的好处就是可以让我们控制输出卷平面上的大小(我们很快会看到,最常见的我们用补0来保持输入卷在平面上的大小,以使宽度和高度保持相同)
We can compute the spatial size of the output volume as a function of the input volume size (W), the receptive field size of the Conv Layer neurons (F), the stride with which they are applied (S), and the amount of zero padding used § on the border. You can convince yourself that the correct formula for calculating how many neurons “fit” is given by (W−F+2P)/S+1. For example for a 7x7 input and a 3x3 filter with stride 1 and pad 0 we would get a 5x5 output. With stride 2 we would get a 3x3 output. Let’s also see one more graphical example:
根据输入卷的大小(W)、卷积层神经元的感受野大小(F)和它们的步长(S)、边界0填充§的数量,我们能计算出输出卷的大小。你可以使自己相信这个正确的公式(W−F+2P)/S+1能计算多少神经元合适。例如,一个7x7的输入和3x3的卷积核且步长为1不补0,会有一个5x5的输出。步长为2时,输出为3x3。再看一个图形化的例子
Illustration of spatial arrangement. In this example there is only one spatial dimension (x-axis), one neuron with a receptive field size of F = 3, the input size is W = 5, and there is zero padding of P = 1. Left: The neuron strided across the input in stride of S = 1, giving output of size (5 - 3 + 2)/1+1 = 5. Right: The neuron uses stride of S = 2, giving output of size (5 - 3 + 2)/2+1 = 3. Notice that stride S = 3 could not be used since it wouldn’t fit neatly across the volume. In terms of the equation, this can be determined since (5 - 3 + 2) = 4 is not divisible by 3.
空间布局示意图。在本例中,空间上只有一个维度,神经元感受野F=3,输入W=5,0填充为P=1.左图:神经元的步长S=1,输出5;右图:神经元的步长为2,输出3.注意,步长不能为3。因为在这个计算式中不能被3整除。
The neuron weights are in this example [1,0,-1] (shown on very right), and its bias is zero. These weights are shared across all yellow neurons (see parameter sharing below).
本例中神经元权值为[1,0,-1],其偏差为0.这些权重在黄色神经元中共享。
Use of zero-padding. In the example above on left, note that the input dimension was 5 and the output dimension was equal: also 5. This worked out so because our receptive fields were 3 and we used zero padding of 1. If there was no zero-padding used, then the output volume would have had spatial dimension of only 3, because that it is how many neurons would have “fit” across the original input. In general, setting zero padding to be P=(F−1)/2 when the stride is S=1 ensures that the input volume and output volume will have the same size spatially. It is very common to use zero-padding in this way and we will discuss the full reasons when we talk more about ConvNet architectures.
使用0填充。在之前左侧的示例中,注意到输入和输出维度都是5. 这样计算出,因为我们的感受野是3,然后使用一个0填充。如果这里没有使用0填充,那么输出卷的空间维度将只有3,因为神经元的数量与原始输入对应。通常,在步长为1时,我们设置0填充为P=(F−1)/2,这样可以保证输入卷和输入卷在空间上有相同的大小。以这种方式使用0填充非常常见,我们会在讲述卷积神经网络结构时讨论全部原因。
Constraints on strides. Note again that the spatial arrangement hyperparameters have mutual constraints. For example, when the input has size W=10, no zero-padding is used P=0, and the filter size is F=3, then it would be impossible to use stride S=2, since (W−F+2P)/S+1=(10−3+0)/2+1=4.5, i.e. not an integer, indicating that the neurons don’t “fit” neatly and symmetrically across the input. Therefore, this setting of the hyperparameters is considered to be invalid, and a ConvNet library could throw an exception or zero pad the rest to make it fit, or crop the input to make it fit, or something. As we will see in the ConvNet architectures section, sizing the ConvNets appropriately so that all the dimensions “work out” can be a real headache, which the use of zero-padding and some design guidelines will significantly alleviate.
步长的限制。再关注一下空间排布的超参数是有相互约束的。例如,当输入大小为W=10时,0填充P=0,那么使用2的步长是不可能的,因为(W−F+2P)/S+1= (10−3+0)/2+1=4.5,不是整数,表明神经元在整个输入中没有准确对称的拟合。因此,这个超参数的设置是无效的,一个卷积神经网络库可以抛出一个异常,或者使用0填充或裁剪输入使它拟合,诸如此类。我们将在卷积神经网络架构中看到,设置合适的卷积神经网络大小,使所有的维度都合适是一个真正让人头痛的问题,而零填充和一些设计指南可以显著的缓解
Real-world example. The Krizhevsky et al. architecture that won the ImageNet challenge in 2012 accepted images of size [227x227x3]. On the first Convolutional Layer, it used neurons with receptive field size F=11, stride S=4 and no zero padding P=0. Since (227 - 11)/4 + 1 = 55, and since the Conv layer had a depth of K=96, the Conv layer output volume had size [55x55x96]. Each of the 555596 neurons in this volume was connected to a region of size [11x11x3] in the input volume. Moreover, all 96 neurons in each depth column are connected to the same [11x11x3] region of the input, but of course with different weights. As a fun aside, if you read the actual paper it claims that the input images were 224x224, which is surely incorrect because (224 - 11)/4 + 1 is quite clearly not an integer. This has confused many people in the history of ConvNets and little is known about what happened. My own best guess is that Alex used zero-padding of 3 extra pixels that he does not mention in the paper.
现实的例子。2012年赢得ImageNet挑战赛的Krizhevsky等人的网络结构接受了尺寸为[227x227x3]的图像。在第一个卷积层上,使用了感受野大小为F=11、步长S=4、无补零P=0的神经元。由于(227-11)/4+1=55,由于卷积层深度K=96,所以卷积层输出卷的大小为[55x55x96]。这个卷中的555596个神经元,每一个都连接到输入卷中的一个大小为[11x11x3]的区域。此外,每个深度列中的96个神经元都连接到输入卷相同的大小为[11x11x3]的区域,当然权重不同。有趣的是,如果你阅读实际的论文,它声称输入图像是224x224,这肯定是不正确的,因为(224-11)/4+1显然不是一个整数。这让很多人对卷积神经网络的历史感到困惑,不知道发生了什么。我自己最好的猜测是Alex使用了额外的3个像素的零填充,他在论文中没有提到。
Parameter Sharing. Parameter sharing scheme is used in Convolutional Layers to control the number of parameters. Using the real-world example above, we see that there are 555596 = 290,400 neurons in the first Conv Layer, and each has 11113 = 363 weights and 1 bias. Together, this adds up to 290400 * 364 = 105,705,600 parameters on the first layer of the ConvNet alone. Clearly, this number is very high.
参数共享。在卷积层中,参数共享机制被用来控制参数的数量。使用上面的实际的例子,我们看到第一个卷积层有290,400个神经元,每一个神经元又363的权重外加1个偏差。两者合起来,仅在第一个卷积层就有105,705,600个参数,很明显数量非常大。
It turns out that we can dramatically reduce the number of parameters by making one reasonable assumption: That if one feature is useful to compute at some spatial position (x,y), then it should also be useful to compute at a different position (x2,y2). In other words, denoting a single 2-dimensional slice of depth as a depth slice (e.g. a volume of size [55x55x96] has 96 depth slices, each of size [55x55]), we are going to constrain the neurons in each depth slice to use the same weights and bias. With this parameter sharing scheme, the first Conv Layer in our example would now have only 96 unique set of weights (one for each depth slice), for a total of 9611113 = 34,848 unique weights, or 34,944 parameters (+96 biases). Alternatively, all 5555 neurons in each depth slice will now be using the same parameters. In practice during back-propagation, every neuron in the volume will compute the gradient for its weights, but these gradients will be added up across each depth slice and only update a single set of weights per slice.
事实证明,我们可以通过一个合理的假设来显著减少参数的数量:如果一个特征在一个空间位置(x,y)上的计算是有用的,那么它在另一个位置(x2,y2)的计算应该也是有用的。换句话,在深度上,将一个简单的2维切片作为一个深度切片(例,一个体积为[55x55x96]的卷有96个深度切片,每一个体积为[55x55]),我们会强制在同一个深度切片的神经元使用相同的权重和偏差。通过这个参数共享方案,示例中的第一个卷积层现在将只会拥有96组不同的权重(每个深度切片一组),总共9611113 = 34,848个权重,或34,944个参数(加上96个偏置)。另外,每一个深度切片上5555个神经元将会使用相同的参数。在实际的反向传播中,卷的每一个神经元都会计算权重的梯度,但是这些梯度将会在每一个深度切片上相加,并且每个切片只更新一组权值。
Notice that if all neurons in a single depth slice are using the same weight vector, then the forward pass of the CONV layer can in each depth slice be computed as a convolution of the neuron’s weights with the input volume (Hence the name: Convolutional Layer). This is why it is common to refer to the sets of weights as a filter (or a kernel), that is convolved with the input.
注意,如果每个切片中的所有神经元都使用相同的权重向量,那么,卷积层的前向传播在每一个深度切片中都可以被计算成神经元权重和输入卷的卷积(因此得名:卷积层)。这就是为什么通常将一组权重称为卷积核,它是和输入进行卷积。
Example filters learned by Krizhevsky et al. Each of the 96 filters shown here is of size [11x11x3], and each one is shared by the 5555 neurons in one depth slice. Notice that the parameter sharing assumption is relatively reasonable: If detecting a horizontal edge is important at some location in the image, it should intuitively be useful at some other location as well due to the translationally-invariant structure of images. There is therefore no need to relearn to detect a horizontal edge at every one of the 5555 distinct locations in the Conv layer output volume.
Note that sometimes the parameter sharing assumption may not make sense. This is especially the case when the input images to a ConvNet have some specific centered structure, where we should expect, for example, that completely different features should be learned on one side of the image than another. One practical example is when the input are faces that have been centered in the image. You might expect that different eye-specific or hair-specific features could (and should) be learned in different spatial locations. In that case it is common to relax the parameter sharing scheme, and instead simply call the layer a Locally-Connected Layer.
注意,有时参数共享的方案可能并没有意义。当一个输入到卷积神经网络的图像拥有特定的中心结构时,情况尤其如此,例如,我们需要从一边学习到一个与另一边完全不同的特征。一个实际的例子,当输入的是图像焦点的人脸时,你可能期望在不同的空间区域学习到不同的眼部或头发的特征。在这种情况下,通常会放松参数共享方案,而把这层称为本地连接层。
Numpy examples. To make the discussion above more concrete, lets express the same ideas but in code and with a specific example. Suppose that the input volume is a numpy array X. Then:
以Numpy为例。为了使上面的讨论更具体,让我们用代码和一个具体的例子来表达相同的想法。假设输入卷是一个Numpy数组X。
• A depth column (or a fibre) at position (x,y) would be the activations X[x,y,:].
在(x,y)位置的一个深度列(或纤维),X[x,y,:]
• A depth slice, or equivalently an activation map at depth d would be the activations X[:,:,d].
一个深度切片,或者相当于在d深度的激活映射,X[:,:,d]
Conv Layer Example. Suppose that the input volume X has shape X.shape: (11,11,4). Suppose further that we use no zero padding (P=0), that the filter size is F=5, and that the stride is S=2. The output volume would therefore have spatial size (11-5)/2+1 = 4, giving a volume with width and height of 4. The activation map in the output volume (call it V), would then look as follows (only some of the elements are computed in this example):
卷积层样例。假设输入卷X的体积有(11,11,4)。进一步假设,我们不使用0填充,卷积核大小为5,步长为2.输出卷因此有(11-5)/2+1 = 4的空间体积,得到一个宽和高都为4的卷。输出卷的激活映射如下所示。
• V[0,0,0] = np.sum(X[:5,:5,:] * W0) + b0
• V[1,0,0] = np.sum(X[2:7,:5,:] * W0) + b0
• V[2,0,0] = np.sum(X[4:9,:5,:] * W0) + b0
• V[3,0,0] = np.sum(X[6:11,:5,:] * W0) + b0
np.sum(数组)代表将数组所有元素相加。
Remember that in numpy, the operation * above denotes elementwise multiplication between the arrays. Notice also that the weight vector W0 is the weight vector of that neuron and b0 is the bias. Here, W0 is assumed to be of shape W0.shape: (5,5,4), since the filter size is 5 and the depth of the input volume is 4. Notice that at each point, we are computing the dot product as seen before in ordinary neural networks. Also, we see that we are using the same weight and bias (due to parameter sharing), and where the dimensions along the width are increasing in steps of 2 (i.e. the stride). To construct a second activation map in the output volume, we would have:
在numpy中*运算代表将数组按元素相乘。同时注意到,权重向量W0是神经元的权重向量,b0是偏移量。W0的体积应被假设为(5,5,4),因为卷积核的大小为5、输入卷深度为4。请注意,在每一点,我们都像在之前的典型神经网络见到的那样,都计算点积。同样,我们看到都使用了相同的权重和偏移量(权值共享),并且沿着宽度,尺寸每次增长2个位移。为了构建输出卷的第二个激活映射,我们有:
• V[0,0,1] = np.sum(X[:5,:5,:] * W1) + b1
• V[1,0,1] = np.sum(X[2:7,:5,:] * W1) + b1
• V[2,0,1] = np.sum(X[4:9,:5,:] * W1) + b1
• V[3,0,1] = np.sum(X[6:11,:5,:] * W1) + b1
• V[0,1,1] = np.sum(X[:5,2:7,:] * W1) + b1 (example of going along y)
• V[2,3,1] = np.sum(X[4:9,6:11,:] * W1) + b1 (or along both)
where we see that we are indexing into the second depth dimension in V (at index 1) because we are computing the second activation map, and that a different set of parameters (W1) is now used. In the example above, we are for brevity leaving out some of the other operations the Conv Layer would perform to fill the other parts of the output array V. Additionally, recall that these activation maps are often followed elementwise through an activation function such as ReLU, but this is not shown here.
这里我们看到,在V中,我们正索引到第二个深度维度,因为我们正计算第二个深度映射,并且使用了一组不同的参数。在上面的样例中,我们为了简洁略去了一些卷积层将会填充数组V其他部分的一些操作。此外,这些激活映射通常接连着就是按元素通过激活函数例如ReLU(线性整流函数),但是这里并没有展现。
Summary. To summarize, the Conv Layer:
• Accepts a volume of size W1×H1×D1
• Requires four hyperparameters:
o Number of filters K,
o their spatial extent F,
o the stride S,
o the amount of zero padding P.
• Produces a volume of size W2×H2×D2 where:
o W2=(W1−F+2P)/S+1
o H2=(H1−F+2P)/S+1 (i.e. width and height are computed equally by symmetry)
o D2=K
• With parameter sharing, it introduces F⋅F⋅D1 weights per filter, for a total of (F⋅F⋅D1)⋅K weights and K biases.
• In the output volume, the d-th depth slice (of size W2×H2) is the result of performing a valid convolution of the d-th filter over the input volume with a stride of S, and then offset by d-th bias.
卷积层总结
• 输入卷体积为W1×H1×D1
• 需要四个超参数
o 卷积核的数量K
o 卷积核空间范围(感受野)F
o 卷积核步长S
o 0填充的数量P
• 生成一个输出卷的体积W2×H2×D2
o W2=(W1−F+2P)/S+1
o H2=(H1−F+2P)/S+1 (i.e. 因为堆成宽和高是相同的)
o D2=K
• 通过参数共享,每一个卷积核有F⋅F⋅D1个参数,所以总共有(F⋅F⋅D1)⋅K个权值和K个偏移量。
• 在输出卷中,第d个深度切片(大小为W2×H2)是在步长为S的情况下在输入卷上执行第d个卷积核的有效卷积,然后在第d个偏置处偏移的结果。
A common setting of the hyperparameters is F=3,S=1,P=1. However, there are common conventions and rules of thumb that motivate these hyperparameters. See the ConvNet architectures section below.
超参数通产设置为F=3,S=1,P=1。但是,有一些共同的惯例和经验法则可以激发这些超参数。
Convolution Demo. Below is a running demo of a CONV layer. Since 3D volumes are hard to visualize, all the volumes (the input volume (in blue), the weight volumes (in red), the output volume (in green)) are visualized with each depth slice stacked in rows. The input volume is of size W1=5,H1=5,D1=3, and the CONV layer parameters are K=2,F=3,S=2,P=1. That is, we have two filters of size 3×3, and they are applied with a stride of 2. Therefore, the output volume size has spatial size (5 - 3 + 2)/2 + 1 = 3. Moreover, notice that a padding of P=1 is applied to the input volume, making the outer border of the input volume zero. The visualization below iterates over the output activations (green), and shows that each element is computed by elementwise multiplying the highlighted input (blue) with the filter (red), summing it up, and then offsetting the result by the bias.
卷积层示例。
Implementation as Matrix Multiplication. Note that the convolution operation essentially performs dot products between the filters and local regions of the input. A common implementation pattern of the CONV layer is to take advantage of this fact and formulate the forward pass of a convolutional layer as one big matrix multiply as follows:
矩阵乘法的实现。
This approach has the downside that it can use a lot of memory, since some values in the input volume are replicated multiple times in X_col. However, the benefit is that there are many very efficient implementations of Matrix Multiplication that we can take advantage of (for example, in the commonly used BLAS API). Moreover, the same im2col idea can be reused to perform the pooling operation, which we discuss next.
这种方法的缺点是使用了大量内存,因为输入卷的某些值在X_col中被多次复制。但优点就是,我们有许多有效的矩阵乘法应用可以利用。此外,im2col的方法可以在池化层中使用。
Backpropagation. The backward pass for a convolution operation (for both the data and the weights) is also a convolution (but with spatially-flipped filters). This is easy to derive in the 1-dimensional case with a toy example (not expanded on for now).
反向传播。卷积运算的反向传播(对于数据和权重)同样也是卷积运算(但是有空间反转卷积核)。这很容易在上面简单示例的一维情况下得出(暂时没有扩展)。
1x1 convolution. As an aside, several papers use 1x1 convolutions, as first investigated by Network in Network. Some people are at first confused to see 1x1 convolutions especially when they come from signal processing background. Normally signals are 2-dimensional so 1x1 convolutions do not make sense (it’s just pointwise scaling). However, in ConvNets this is not the case because one must remember that we operate over 3-dimensional volumes, and that the filters always extend through the full depth of the input volume. For example, if the input is [32x32x3] then doing 1x1 convolutions would effectively be doing 3-dimensional dot products (since the input depth is 3 channels).
11卷积。几篇使用11卷积的文章首先发表在Network in Network。有些人第一次看到11卷积可能会疑惑特别是有着信号处理背景。通常信号的二维的所以11卷积不能起作用(它只是逐点缩放)。但是在卷积神经网络中并不是这样,因为必须要记得一点,我们处理的是超过3维的卷,并且卷积核始终能拓展输入卷的整个深度。例如,如果输入是[32x32x3],然后进行1*1卷积将会有效的进行三维点乘运算(因为输入时三通道)
Dilated convolutions. A recent development (e.g. see paper by Fisher Yu and Vladlen Koltun) is to introduce one more hyperparameter to the CONV layer called the dilation. So far we’ve only discussed CONV filters that are contiguous. However, it’s possible to have filters that have spaces between each cell, called dilation. As an example, in one dimension a filter w of size 3 would compute over input x the following: w[0]*x[0] + w[1]*x[1] + w[2]*x[2]. This is dilation of 0. For dilation 1 the filter would instead compute w[0]*x[0] + w[1]*x[2] + w[2]*x[4]; In other words there is a gap of 1 between the applications. This can be very useful in some settings to use in conjunction with 0-dilated filters because it allows you to merge spatial information across the inputs much more agressively with fewer layers. For example, if you stack two 3x3 CONV layers on top of each other then you can convince yourself that the neurons on the 2nd layer are a function of a 5x5 patch of the input (we would say that the effective receptive field of these neurons is 5x5). If we use dilated convolutions then this effective receptive field would grow much quicker.
扩张卷积。最近的一项发展(paper by Fisher Yu and Vladlen Koltun)是在卷积层引入另一个称为扩张的超参数。到目前为止,我们只讨论了连续的卷积核。但是,可以使每个单元格之间有空格的过滤器称为扩张。例如,在一个维度中,大小为3的卷积核w将在输入x上计算以下:w[0]*x[0]+w[1]*x[1]+w[2]*x[2]。这是0的扩张。对于扩张1,卷积核将改为计算w[0]*x[0]+w[1]*x[2]+w[2]*x[4];换句话说,采集点之间存在1的距离。这在某些设置中非常有用,可以与0扩展卷积核结合使用,因为它允许您使用更少的层更加积极地合并输入中的空间信息。例如,如果你将两个3x3 CONV层堆叠在一起,那么你可以说服自己第二层的神经元是输入的5x5补丁的函数(我们可以说这些神经元的有效感受域是5×5)。如果我们使用扩张卷积,那么这个有效的感受野会增长得更快(2-dilated两层的感受野就有7)。
Pooling Layer
It is common to periodically insert a Pooling layer in-between successive Conv layers in a ConvNet architecture. Its function is to progressively reduce the spatial size of the representation to reduce the amount of parameters and computation in the network, and hence to also control overfitting. The Pooling Layer operates independently on every depth slice of the input and resizes it spatially, using the MAX operation. The most common form is a pooling layer with filters of size 2x2 applied with a stride of 2 downsamples every depth slice in the input by 2 along both width and height, discarding 75% of the activations. Every MAX operation would in this case be taking a max over 4 numbers (little 2x2 region in some depth slice). The depth dimension remains unchanged. More generally, the pooling layer:
通常在卷积神经网络架构中的连续卷积层之间周期性插入池化层。 其功能是逐步减小表示的空间大小,以减少网络中的参数和计算量,从而控制过度拟合。池化层在输入的每个深度切片上独立运行,并使用MAX运算调整空间大小。 最常见的形式是一个池化层,其中大小为2x2的下采样过滤器的步长2,输入中的每个深度切片沿宽度和高度均为2,丢弃了75%的激活。 在这种情况下,每个MAX操作将采用最多超过4个数字(在某个深度切片中的小2x2区域)。 深度维度保持不变。 更具体地说,池化层:
• Accepts a volume of size W1×H1×D1
• 输入卷大小为W1×H1×D1
• Requires two hyperparameters:
o their spatial extent F,
o the stride S,
• 需要两个超参数
o 空间范围F
o 步长S
• Produces a volume of size W2×H2×D2 where:
o W2=(W1−F)/S+1
o H2=(H1−F)/S+1
o D2=D1
• 输出卷大小W2×H2×D2
o W2=(W1−F)/S+1
o H2=(H1−F)/S+1
o D2=D1
• Introduces zero parameters since it computes a fixed function of the input
• 因为输入中使用固定函数,所以没有引入参数
• For Pooling layers, it is not common to pad the input using zero-padding.
It is worth noting that there are only two commonly seen variations of the max pooling layer found in practice: A pooling layer with F=3,S=2 (also called overlapping pooling), and more commonly F=2,S=2. Pooling sizes with larger receptive fields are too destructive.
对于池化层,使用零填充补充输入并不常见。值得注意的是,在实际中只有两个常见的最大池化变体:F=3,S=2的池化层(也称为重叠池),更常见的是F=2,S=2。具有较大感受野的池大小太具破坏性。
General pooling. In addition to max pooling, the pooling units can also perform other functions, such as average pooling or even L2-norm pooling. Average pooling was often used historically but has recently fallen out of favor compared to the max pooling operation, which has been shown to work better in practice.
一般池化。除了最大池化,池化单元还可以执行其他功能,例如平均池化甚至L2标准池化。平均池化在过去经常使用,但最近与最大池化操作相比已落于下风,最大池化证明在实际中效果更好。
Pooling layer downsamples the volume spatially, independently in each depth slice of the input volume. Left: In this example, the input volume of size [224x224x64] is pooled with filter size 2, stride 2 into output volume of size [112x112x64]. Notice that the volume depth is preserved. Right: The most common downsampling operation is max, giving rise to max pooling, here shown with a stride of 2. That is, each max is taken over 4 numbers (little 2x2 square).
Backpropagation. Recall from the backpropagation chapter that the backward pass for a max(x, y) operation has a simple interpretation as only routing the gradient to the input that had the highest value in the forward pass. Hence, during the forward pass of a pooling layer it is common to keep track of the index of the max activation (sometimes also called the switches) so that gradient routing is efficient during backpropagation.
反向传播。回想一下反向传播章节,max(x,y)操作的后向传递可以简单解释为,引向前向传播中最高值的输入变化率。因此,在池化层的前向传播期间,通常跟踪最大激活的索引(有时也称为开关),使得梯度路由在反向传播期间是有效的。
Getting rid of pooling. Many people dislike the pooling operation and think that we can get away without it. For example, Striving for Simplicity: The All Convolutional Net proposes to discard the pooling layer in favor of architecture that only consists of repeated CONV layers. To reduce the size of the representation they suggest using larger stride in CONV layer once in a while. Discarding pooling layers has also been found to be important in training good generative models, such as variational autoencoders (VAEs) or generative adversarial networks (GANs). It seems likely that future architectures will feature very few to no pooling layers.
摆脱池化层。许多人不喜欢池化操作,并认为可以摆脱池化层。例如,Striving for Simplicity: The All Convolutional Net 建议删去池化层,转而使用仅包含重复卷积层的体系结构。为了减小表示的大小,他们建议偶尔在CONV层中使用更大的步长。还发现在训练良好的生成模型中去掉池化层很重要,例如变分自动编码器(VAE)或生成性对抗网络(GAN)。未来的架构很可能只有很少甚至没有池化层。
Normalization Layer
Many types of normalization layers have been proposed for use in ConvNet architectures, sometimes with the intentions of implementing inhibition schemes observed in the biological brain. However, these layers have since fallen out of favor because in practice their contribution has been shown to be minimal, if any. For various types of normalizations, see the discussion in Alex Krizhevsky’s cuda-convnet library API.
用于ConvNet架构的许多类型的归一化层已经被提出,有些意图实现在生物脑中观察到的抑制方案。 然而,这些层次已经弃用,因为在实践中它们的贡献已被证明是最小的,如果有的话。 有关各种类型的规范化,请参阅Alex Krizhevsky的cuda-convnet library API.
Fully-connected layer
Neurons in a fully connected layer have full connections to all activations in the previous layer, as seen in regular Neural Networks. Their activations can hence be computed with a matrix multiplication followed by a bias offset. See the Neural Network section of the notes for more information.
全连接层中的神经元与前一层中的所有激活具有完全连接,如常规神经网络中所示。 因此,可以通过矩阵乘法后跟偏置偏移来计算它们的激活。 有关详细信息,请参阅注释的“神经网络”部分。
Converting FC layers to CONV layers
It is worth noting that the only difference between FC and CONV layers is that the neurons in the CONV layer are connected only to a local region in the input, and that many of the neurons in a CONV volume share parameters. However, the neurons in both layers still compute dot products, so their functional form is identical. Therefore, it turns out that it’s possible to convert between FC and CONV layers:
值得注意的是,全连接和卷积层之间的唯一区别是卷积层中的神经元仅连接到输入中的局部区域,并且CONV卷中的许多神经元共享参数。然而,两层中的神经元仍然计算点积,因此它们的功能形式是相同的。因此,事实证明,FC和CONV层之间进行转换是可行的:
• For any CONV layer there is an FC layer that implements the same forward function. The weight matrix would be a large matrix that is mostly zero except for at certain blocks (due to local connectivity) where the weights in many of the blocks are equal (due to parameter sharing).
• 对于任何CONV层,都有一个实现相同前向功能的FC层。权重矩阵将是一个除了在某些块(由于本地连接)之外,其他大部分为零的大矩阵,其中许多块中的权重相等(由于参数共享)。
• Conversely, any FC layer can be converted to a CONV layer. For example, an FC layer with K=4096 that is looking at some input volume of size 7×7×512 can be equivalently expressed as a CONV layer with F=7, P=0, S=1, K=4096. In other words, we are setting the filter size to be exactly the size of the input volume, and hence the output will simply be 1×1×4096 since only a single depth column “fits” across the input volume, giving identical result as the initial FC layer.
• 相反,任何FC层都可以转换为CONV层。例如,观察一些尺寸为7×7×512的输入体积的K = 4096的FC层可以等效地表示为具有感受野F=7,零填充P=0,补偿S=1,卷积核数量K=4096的CONV层。换句话说,我们将滤波器大小设置为输入卷的大小,因此输出将只是1×1×4096,因为只有一个深度列“适合”输入卷,从而得到相同的结果 最初的FC层。
FC->CONV conversion. Of these two conversions, the ability to convert an FC layer to a CONV layer is particularly useful in practice. Consider a ConvNet architecture that takes a 224x224x3 image, and then uses a series of CONV layers and POOL layers to reduce the image to an activations volume of size 7x7x512 (in an AlexNet architecture that we’ll see later, this is done by use of 5 pooling layers that downsample the input spatially by a factor of two each time, making the final spatial size 224/2/2/2/2/2 = 7). From there, an AlexNet uses two FC layers of size 4096 and finally the last FC layers with 1000 neurons that compute the class scores. We can convert each of these three FC layers to CONV layers as described above:
FC-> CONV转换。 在这两次转换中,将FC层转换为CONV层的能力在实践中特别有用。 考虑采用224x224x3图像的ConvNet架构,然后使用一系列CONV层和POOL层将图像缩小为7x7x512的特征图(在我们稍后将看到的AlexNet架构中,这是通过使用 5个池化层,每次在空间上对输入进行下采样,使最终空间大小为224/2/2/2/2/2 = 7)。 从那里开始,AlexNet使用两个大小为4096的FC层(7x7x512的特征图全连接连向4096个神经元,4096再连向4096),最后使用1000个神经元来计算类别得分。 我们可以将这三个FC层中的每一个转换为CONV层,如上所述:
• Replace the first FC layer that looks at [7x7x512] volume with a CONV layer that uses filter size F=7, giving output volume [1x1x4096].
• 通过卷积核感受野为7,特征图为[1x1x4096]的卷积层取代计算输入特征图为[7x7x512]的全连接层
• Replace the second FC layer with a CONV layer that uses filter size F=1, giving output volume [1x1x4096]
• 使用卷积核F = 1的CONV层替换第二个FC层,给出输出特征图[1x1x4096]
• Replace the last FC layer similarly, with F=1, giving final output [1x1x1000]
• 类似地替换最后一个FC层,F = 1,给出最终输出[1x1x1000]
Each of these conversions could in practice involve manipulating (e.g. reshaping) the weight matrix W in each FC layer into CONV layer filters. It turns out that this conversion allows us to “slide” the original ConvNet very efficiently across many spatial positions in a larger image, in a single forward pass.
实际上,这些转换中的每一个都可以涉及将每个FC层中的权重矩阵W操纵(例如,重新整形)成CONV层卷积核。事实证明,这种转换允许我们在单个前向传递中非常有效地把原始ConvNet在更大图像中的许多空间位置上“滑动”。
For example, if 224x224 image gives a volume of size [7x7x512] - i.e. a reduction by 32, then forwarding an image of size 384x384 through the converted architecture would give the equivalent volume in size [12x12x512], since 384/32 = 12. Following through with the next 3 CONV layers that we just converted from FC layers would now give the final volume of size [6x6x1000], since (12 - 7)/1 + 1 = 6. Note that instead of a single vector of class scores of size [1x1x1000], we’re now getting an entire 6x6 array of class scores across the 384x384 image.
例如,如果224x224图像给出的特征图大小为[7x7x512] - 即减少32倍,那么通过转换的体系结构转发大小为384x384的图像将得到相等的体积[12x12x512],因为384/32=12。接下来FC层转换的3个 CONV层将给出最终的体积特征图大小为[6x6x1000],因为(12-7)/1+1=6。注意,并不是单个分类向量大小[1x1x1000],现在,我们在384x384图像上得到整个6x6类别的分数。
Evaluating the original ConvNet (with FC layers) independently across 224x224 crops of the 384x384 image in strides of 32 pixels gives an identical result to forwarding the converted ConvNet one time.
原始ConvNet(具有FC层),横过384x384图像在步长为32像素下的224x224特征的结果,和一次性发送进转换过的ConvNet结果是一样的。
Naturally, forwarding the converted ConvNet a single time is much more efficient than iterating the original ConvNet over all those 36 locations, since the 36 evaluations share computation. This trick is often used in practice to get better performance, where for example, it is common to resize an image to make it bigger, use a converted ConvNet to evaluate the class scores at many spatial positions and then average the class scores.
自然地,一次性输入转换后的ConvNet比在所有这36个位置上迭代原始ConvNet要有效得多,因为36次评估共享计算资源。在实践中这个技巧通常用于获得更好的性能。例如,通常调整图像大小以使其更大,使用转换后的ConvNet评估许多空间位置的类别分数,然后计算平均类别分数。
Lastly, what if we wanted to efficiently apply the original ConvNet over the image but at a stride smaller than 32 pixels? We could achieve this with multiple forward passes. For example, note that if we wanted to use a stride of 16 pixels we could do so by combining the volumes received by forwarding the converted ConvNet twice: First over the original image and second over the image but with the image shifted spatially by 16 pixels along both width and height.
最后,如果我们想要在图像上有效地应用原始ConvNet但是步长小于32像素怎么办?我们可以通过多次前进传球实现这一点。例如,请注意,如果我们想要使用16像素的步幅,我们可以通过将转换后的ConvNet转发两次来收集的特征图组合起来:首先是原始图像,第二个是沿着宽度和高度在空间上移动了16个像素的图像。
• An IPython Notebook on Net Surgery shows how to perform the conversion in practice, in code (using Caffe)
ConvNet Architectures
We have seen that Convolutional Networks are commonly made up of only three layer types: CONV, POOL (we assume Max pool unless stated otherwise) and FC (short for fully-connected). We will also explicitly write the RELU activation function as a layer, which applies elementwise non-linearity. In this section we discuss how these are commonly stacked together to form entire ConvNets.
我们已经看到,卷积网络通常只由三种层类型组成:CONV,POOL(我们假设Max池除非另有说明)和FC(完全连接的简称)。我们还将RELU激活函数明确地写为一个层,它应用元素非线性。在本节中,我们将讨论如何将这些通常堆叠在一起以形成整个ConvNets。
Layer Patterns
The most common form of a ConvNet architecture stacks a few CONV-RELU layers, follows them with POOL layers, and repeats this pattern until the image has been merged spatially to a small size. At some point, it is common to transition to fully-connected layers. The last fully-connected layer holds the output, such as the class scores. In other words, the most common ConvNet architecture follows the pattern:
ConvNet架构最常见的形式是堆叠一些CONV-RELU层,随后跟随POOL层,并重复此模式,直到图像在空间上合并为小尺寸。 在某些时候,过渡到完全连接的层是很常见的。 最后一个完全连接的层保存输出,例如类分数。 换句话说,最常见的ConvNet架构遵循以下模式:
INPUT -> [[CONV -> RELU]*N -> POOL?]*M -> [FC -> RELU]*K -> FC
输入 多个CONV-RELU层 池化层 多个FC-RELU 全连接层
where the * indicates repetition, and the POOL? indicates an optional pooling layer. Moreover, N >= 0 (and usually N <= 3), M >= 0, K >= 0 (and usually K < 3). For example, here are some common ConvNet architectures you may see that follow this pattern:
TOTAL memory: 24M * 4 bytes ~= 93MB / image (only forward! ~*2 for bwd)
TOTAL params: 138M parameters
As is common with Convolutional Networks, notice that most of the memory (and also compute time) is used in the early CONV layers, and that most of the parameters are in the last FC layers. In this particular case, the first FC layer contains 100M weights, out of a total of 140M.
与Convolutional Networks一样,请注意大多数内存(以及计算时间)都用在前面的CONV层中,并且大多数参数都在最后的FC层中。在这种特殊情况下,第一个FC层包含100M权重,总共140M。
Computational Considerations
The largest bottleneck to be aware of when constructing ConvNet architectures is the memory bottleneck. Many modern GPUs have a limit of 3/4/6GB memory, with the best GPUs having about 12GB of memory. There are three major sources of memory to keep track of:
构建ConvNet架构时要注意的最大瓶颈是内存瓶颈。许多现代GPU的内存限制为3/4/6GB,最好的GPU具有大约12GB的内存。有三种主要的内存来源可以跟踪:
• From the intermediate volume sizes: These are the raw number of activations at every layer of the ConvNet, and also their gradients (of equal size). Usually, most of the activations are on the earlier layers of a ConvNet (i.e. first Conv Layers). These are kept around because they are needed for backpropagation, but a clever implementation that runs a ConvNet only at test time could in principle reduce this by a huge amount, by only storing the current activations at any layer and discarding the previous activations on layers below.
• 从中间体积大小:这些是ConvNet每层激活的原始数量,以及它们的梯度(相同大小)。通常,大多数激活都在ConvNet的初始层上(即第一个Conv层)。这些都被保留,因为它们是反向传播所需要的,但是有一个更聪明的实现方式,那就是仅在测试是运行卷积网络,原则上这样可以大量减少中间体积,只需储存任意层的当前激活并丢弃下一层的先前激活。
• From the parameter sizes: These are the numbers that hold the net-work parameters, their gradients during backpropagation, and commonly also a step cache if the optimization is using momentum, Adagrad, or RMSProp. Therefore, the memory to store the parameter vector alone must usually be multiplied by a factor of at least 3 or so.
• 参数大小:这些数字包括网络中的参数,反向传播的参数,如使用了momentum, Adagrad或RMSProp通常还有一级高速缓存。因此,单独存储参数向量的存储器通常必须乘以至少3左右的因子。
• Every ConvNet implementation has to maintain miscellaneous memory, such as the image data batches, perhaps their augmented versions, etc.
• 每个ConvNet实现都必须维护各种内存,例如图像数据批量,可能是它们的增强版本等。
Once you have a rough estimate of the total number of values (for activations, gradients, and misc), the number should be converted to size in GB. Take the number of values, multiply by 4 to get the raw number of bytes (since every floating point is 4 bytes, or maybe by 8 for double precision), and then divide by 1024 multiple times to get the amount of memory in KB, MB, and finally GB. If your network doesn’t fit, a common heuristic to “make it fit” is to decrease the batch size, since most of the memory is usually consumed by the activations.
一旦粗略估计了值的总数(对于激活,渐变和misc),该参数量的单位会转换为GB。用值的数量乘以4得到原始字节数(因为每个浮点数为4个字节,或者双精度可能为8),然后除以1024多次以获得以KB为单位的内存量,MB,最后是GB。 如果您的网络不适合,“使其适合”的常见启发式方法是减小批量大小,因为大多数内存通常由激活消耗。
Additional Resources
Table of Contents:
• Architecture Overview
• ConvNet Layers
o Convolutional Layer
o Pooling Layer
o Normalization Layer
o Fully-Connected Layer
o Converting Fully-Connected Layers to Convolutional Layers
• ConvNet Architectures
o Layer Patterns
o Layer Sizing Patterns
o Case Studies (LeNet / AlexNet / ZFNet / GoogLeNet / VGGNet)
o Computational Considerations
• Additional References
Additional resources related to implementation:
• Soumith benchmarks for CONV performance
• ConvNetJS CIFAR-10 demo allows you to play with ConvNet architectures and see the results and computations in real time, in the browser.
• Caffe, one of the popular ConvNet libraries.
• State of the art ResNets in Torch7
• cs231n
• cs231n
• [email protected]