LeNet-5 (65K params)
The LeNet-5 architecture (LeCun, 1998) and is still very widely used. 5 is simply the version number. LeNet-5 has 7 layers.
- Input layer are 32x32 grayscale images. MNIST images are originally 28x28, but here they are padded to 32x32.
- The next 4 layers are CNN layers without padding. Each CNN is attached to an Average Pooling layer. Nowadays, we usually use Max Pooling Layers
- The 6th layer is a FCN that connects to each output pixel of the last CNN. Activation is Sigmoid.
- The 7th layer is another FCN layer with 10 neurons that uses a non-popular classifier (Euclidean Radial Basis Function, RBF). Nowadays, we use Softmax.
Other architectural aspects:
- Activation functions were Sigmoid and Tanh, rather than ReLU (ReLU came out with AlexNet).
- Nowadays, a CNN layer would have
f x f x c
for each output channel, wheref
is the filter size,c
is the number of input channels. But LeNet-5 creates filters of different sizes for different channels for the small compute it had. - LeNet-5 attaches a non-linear activation function after a CNN.
- Nowadays, we often use max pooling instead of average pooling.
AlexNet (65M Params, Alex Krizhevsky 2012)
Input: 227x227x3
. From the image net dataset
- 1st layer: CNN with 11x11, stride = 4. Output:
55x55x96
- 2nd layer: Maxpooling layer with 3x3 kernel size, stride=2. Output
27x27x96
- 3nd layer: CNN with Same Cross-Correlation. Output:
27x27x256
- 4th layer: Maxpooling Layer with kernel size 3x3, stride = 2
- 5th, 6th, 7th are CNN layers with Same Cross-Correlation
- 8th layer is a maxpooling layer with a kernel size 3x3, stride = 2
- 9th layer is a flattening layer
- 10th and 11th layer is A FCN. Output are
4096 x 1
- 12th layer is a FCN layer with 1000 output classes. Its outputs are then fed into a softmax
Highlights include:
- Trained on a much larger network than LeNet-5
- Use of ReLU
Historical Constraints:
- Back then GPU was slower, and the training of layers were split on 2 GPUs.
- Local Response Normalization: normalize the same patch of a layer across channels to avoid high activation values. But Later people didn’t find it universally helpful
AlexNet paper is relatively easy to read. And it’s a milestone that drew people’s serious attention in neuralnetwork.
VGG-16 (138M parameters)
There are 16 layers that have parameters. The architecture of VGG 16 is realitively simpler.
Upside is the architecture is quite simple. Downside is it’s large even by modern standard
One-by-One Convolutions
An 1x1 filter is mainly used to shrink (summarize) or expand the number of channels, while the height and width of the feature maps remain the same (nxnxm
-> nxnxc
). This technique is also called “pointwise convolution”. An 1x1 convolution is effectively a weighted sum across all feature maps, and is also called a “feature pooler”.
So if we have pxqxm
input, we would have an 1x1xc
filter. Each output channel of the filter has a 1x1xm
kernel. Elements across all channels at the same [x,y]
would sum up and multiply by the value at channel n
of the filter. That’s the output value at channel n
is determined.
In one-by-one convolutions, ‘same’ and ‘valid’ give the same result as no padding is needed on the input images.
Winner of ImageNet Large Scale Visual Recognition Challenge (ILSVRC), GoogleNet(2014), ResNet and SqueezeNet all use one-by-one convolution as a major part of the network.
ResNet-50 (25M, Kaiming He et al. 2015)
Deeper neuralnets in general are favourable: they are able to learn highly non-linear decision boundaries. When building deep neuralnets, Deep Network suffer from exploding and vanishing gradients. In the work Deep Residual Learning for Image Recognition, Kaiming He et al. introduced ResNet. ResNet-50 has in total 50 learnable layers. Compared to “plain networks”, ResNet created the notion of Residual Blocks that makes uses of “skip connection” or “short circuits” (ResNet-34):
Code of PyTorch Implementation in Torch Vision
\[\begin{gather*} a_l -> z_{l+1} = w^T a_l + b-> a_{l+1} = g(z_l+1) -> z_{l+2} = w^T a_{l+1} -> a_{l+2} = g(z_{l+1} + a_{l}) \end{gather*}\]The difference is that we add a_{l}
to the non linear activation function of a_{l+2}
.
This residual block basically “boosts” the original signal. In reality, deep plain networks suffer from two difficulties:
- It will witness an increase in training errors without resnet. This might be due to vanishing / exploding gradients
- Optimization difficulties
In order to have skip connections, we need to make sure the input and outputs of the two blocks have the same dimension, with th e same number of channels. in_channels == out_channels
and stride == 1
Another highlight in He et al.’s work is “bottleneck building block” architecture (ResNet-50):
The bottleneck building block is to
- reduce the number of layers (dimensionality)
- conduct regular convolution
- increase the number of layers back. The 1x1 conv layers reduce / increase channel dimensions, so the actual 3x3 conv layer has smaller dimensions to work with.
There are two types of blocks in ResNet:
- Identity Block: input and output have the same dimension. Here, the first Conv 2D is 1x1 conv, the second Conv2D is a custom
fxf
‘same’ convolution. The third one is also a ‘valid’ 1x1 conv. The Batch Normalization layer independently normalizes each feature map. - Convolutional Block: input and output do not have the same dimension. Here, a Conv2D is added to the short cut. It’s 1x1 convolution, but with a stride=2
Overall, there are 50 trainable layers in ResNet-50. Stage 1: 1 conv layer. Stage 2-stage 5: 3 x 16 = 48
, stage 6: 1 FC layer.
Why ResNet Works
-
ResNet is able to learn “identity” when it’s optimal to do so. That is, a residual block’s $w$ and $b$ could be both zeros. So the final result will be no worse than that of a plain network. This requires the input & output dimensions to match
- The original paper proposed “projection shortcut” as well, which is used when input & output dimensions do not match $H(x) = F(x) + W_sX$. However, this seems to be performing worse than the identity shortcut $H(x)=F(x)+X$ in the bottleneck building blocks.
-
Each residual block’s parameters are smaller, and the learned function is simpler. Given input $x$, in a plain network, a layer will learn an entire transformation $H(x)$. However in a residual block, it will learn $F(x)$ where $H(x) = X+F(x)$. There is a chance that the residual $F(x)$ is close to zero. Hence the parameters are smaller (note, not fewer). This is especially true when “identity” is the optimal transform $H(x)$.
-
Gradient flow can reach deeper. With skip connections, the input to a layer $x$ has more influence on the final output with less layers to go though $W_1W_2…x$. So gradients will be correspondingly higher and the vanishing gradient problem is mitigated.
Inception Network (Szegedy et al. 2014, Google, Going deeper with convolutions)
Motivation
When hand-picking conv nets, we need to specify filter dimensions by hand. Inception network allows a combo of conv and pooling layers. Then, outputs in different output channels (depth) are stacked together. E.g., one can append 64 output layers from 1x1 conv, and 128 layers from 3x3 (convolution with same
padding) together. The name “inception” was adopted by the GoogleNet team in 2014 to pay homage to the movie “inception” we need to go DEEPER.
How Padding in ‘Same’ Max Pooling Works
In the Inception Network, we need to retain the same output dimension. The trick is to pad the input first, then apply max pooling with the specified stride. E.g., given an input
\[\begin{gather*} \begin{bmatrix} 1 & 3 & 2 & 1 \\ 4 & 6 & 5 & 7 \\ 2 & 1 & 4 & 9 \\ 1 & 3 & 7 & 6 \end{bmatrix} \end{gather*}\]If we apply maxpooling with stride = 1, kernel 2x2
, the padded input would be:
The maxpooling result would be:
\[\begin{gather*} 1 & 3 & 3 & 7 \\ 6 & 6 & 5 & 7 \\ 6 & 7 & 9 & 9 \\ 3 & 7 & 7 & 9 \end{gather*}\]Problem With Covolution Layer
Convolution is expensive. Below network has (5x5x28x28)x192x32=120422400
times of multiplication in its forward prop (product of dimensions of input and output).
1x1 conv can effectively reduce the number of multiplications: 28x28x192x16 + 28x28x16x5x5x32=12443648
multiplications.
The layer is called “bottleneck layer” because of the shape of the 1x1 layer compared to other larger layers.
Max pool layer itself will output the same num of channels. So we need 1x1 conv to shrink down
Inception Network Architecture
Inception Block
The first step is dimensionality reduction using 1x1 Conv to shrink (or summarize) the outputs from each conv sub-layer. This is to reduce the computations followed by 3x3
and 5x5
conv layers. Since 3x3
and 5x5
conv layers operate on a reduced number of layers after 1x1
conv layers, this is to emulate a “sparse” architecture where direct dense connections from input channels to outputs of the conv layers could be close to 0.
Overal Architecture
Szegedy et al. proposed GoogLeNet
, an Inception Network. The first few layers are regular convolutional layers, followed by inception modules.
There are two side branches with two softmax outputs. Each side branch is called an auxilary classifier. Instead of training separately, they are trained together with the main output. During back-propagation, the connected layers will be updated with the combined gradient from the main and auxilary branches. This is to compensate for the vanishing gradient problem, so intermediate layers won’t be too bad. This is only in GoogLeNet v1 though.
Putting everything together:
Remarks About Inception Network
-
Szegedy et al state that “the main idea of the inception architecture is based on finding out how an optimal local sparse structure in a convolutional vision network can be approximated and covered by readily available dense components.” -
-
Each inception block creates an “Ensemble-Like” effect. Ensembles are trained separately, like stacking. An Inception Network is trained as a whole, so it’s not an ensemble per se. But it stacks the ouptuts from parallel conv blocks - that’s similar to ensembles.
-
Slight regularization effects:
- 1x1 conv reduces the parameter volume = reduces chances of overfitting.
MobileNet (Howard et al.)
Mobilenet v1: MobileNets: Efficient Convolutional Neural Networks for Mobile Vision Applications
Depthwise Separable Convolution
If you have an input of size a×b×3 and a regular convolution filter of size 3×3×3x5, you would have 3×3×3 filters for each of the 5 output channels. The output would be a×b×5, after summing across input channels.
In a depthwise convolution, you would have 3 filters of size 3×3 (one for each input channel). Each input channel is independently convolved with its filter, so the output would remain a×b×3a×b×3 (same number of channels as the input).
Point-wise convolution is just another term for one-by-one multiplication
The combination of Depthwise convolution and pointwise convolution is called “depthwise separable convolution”. That reduces the number of multiplications by quite a bit. E.g., when our input is 6x6x3
, we want our output is 4x4x5
- In normal convolution, this would take 5
3x3x3
filters. In total we need3x3x3x4x4x5=2160
multiplications. - Using depthwise separable convolution, we first have 1
3x3x3
filters, then we have 51x1x3
filters. That in total we have4x4x3x3x3 + 4x4x3x5=672
. The ratio of the number of multiplications between mobile net and regular convolution is:
where $m$ is the number of output channels, $f$ is the filter size. In some applications, $m$ is much larger, so the ratio is slightly larger than $\frac{1}{f^2}$
Implementation - Using Grouped Convolution (分组卷积)
Grouped Convolution is to separate input channels, conduct convolution, then concatenate them together
- In PyTorch,
groups
basically havegroups
conv layers side by side. Make sureinput channels % group = 0
,output channels % group = 0
, Then, the group in the output hasoutput_channels / groups
feature maps.
1
nn.Conv2d( ... groups=dimension)
To implement depthwise convolution, we just make sure output_channels = groups = input_channels
.
General Advice
- Sometimes it’s hard for PhD students at top universities to replicate work from published papers. Fortunately, we can take a look at the opensource implementations.
- When you get a large neuralnet, especially in computer vision, always try transfer learning first. You can freeze certain layers, modify the later layers, and train those. Those pre-trained networks have been trained on millions of images, which could take days or even weeks on your machine.
- If the training datasets are small, we can choose to freeze most layers, and only train a very small number of layers.
- Data augmentation: almost in all computer vision domains, the more data the better.
- Distortions: mirroring, random cropping parts of the images, rotation, shearing, local warping are common.
- Color shifting: e.g., adding and subtracting certain values from R,G,B values. In AlexNet, PCA color augmentation keeps the overall color variation in an image.
- Data augmentation can be done simultaneously while training takes place
- State of Computer Vision: Historically, computer vision has been very “hand-engineered” and very theory-based.
- At test time, do a 10-crop on test images. That is, generate 10 cropped images from an original image and average results.
References
[1] Szegedy, C., Liu, W., Jia, Y., Sermanet, P., Reed, S., Anguelov, D., Erhan, D., Vanhoucke, V., & Rabinovich, A. (2015). Going Deeper with Convolutions. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR) (pp. 1-9).