Convolutional Neural Networks (CNN)
Convolutional Neural Networks (CNN)
Convolutional Neural Networks (CNN)
Introduction
A convolutional neural network (CNN), is a network architecture for deep learning which learns
directly from data. CNNs are particularly useful for finding patterns in images to recognize objects.
They can also be quite effective for classifying non-image data such as audio, time series, and signal
data.
Computers read images as pixels and it is expressed as a matrix (NxNx3) — (height by width by
depth). Images make use of three channels (RGB), so that is why we have a depth of 3.
The Convolutional Layer makes use of a set of learnable filters. A filter is used to detect the presence
of specific features or patterns present in the original image (input). It is usually expressed as a
matrix (MxMx3), with a smaller dimension but the same depth as the input file.
This filter is convolved (slided) across the width and height of the input file, and a dot product is
computed to give an activation map.
Different filters which detect different features are convolved on the input file and a set of activation
maps is outputted which is passed to the next layer in the CNN.
Padding
Padding is a term relevant to convolutional neural networks as it refers to the number of pixels
added to an image when it is being processed by the kernel of a CNN. For example, if the padding
in a CNN is set to zero, then every pixel value that is added will be of value zero. When we use the
filter or Kernel to scan the image, the size of the image will go smaller. We have to avoid that
because we wanna preserve the original size of the image to extract some low-level features.
Therefore, we will add some extra pixels outside the image.
Formula =[i-k+2p/s]+1
i -> Size of input , K-> Size of kernel, S-> Stride, p->Padding
Pooling
Pooling in convolutional neural networks is a technique for generalizing features extracted by
convolutional filters and helping the network recognize features independent of their location in the
image.
Flatten
Flattening is used to convert all the resultant 2-Dimensional arrays from pooled feature maps into
a single long continuous linear vector. The flattened matrix is fed as input to the fully connected
layer to classify the image.
Layers used to build CNN
Convolutional neural networks are distinguished from other neural networks by their superior
performance with image, speech, or audio signal inputs. They have three main types of layers,
which are:
• Convolutional layer
• Pooling layer
• Fully-connected (FC) layer
Convolutional layer
This layer is the first layer that is used to extract the various features from the input images. In this
layer, We use a filter or Kernel method to extract features from the input image.
Pooling layer
The primary aim of this layer is to decrease the size of the convolved feature map to reduce
computational costs. This is performed by decreasing the connections between layers and
independently operating on each feature map. Depending upon the method used, there are several
types of Pooling operations. We have Max pooling and average pooling.
Fully-connected layer
The Fully Connected (FC) layer consists of the weights and biases along with the neurons and is
used to connect the neurons between two different layers. These layers are usually placed before
the output layer and form the last few layers of a CNN Architecture.
Dropout
Another typical characteristic of CNNs is a Dropout layer. The Dropout layer is a mask that nullifies
the contribution of some neurons towards the next layer and leaves unmodified all others.
Activation Function
The activation function is the non linear transformation that we do over the input signal. This
transformed output is then sent to the next layer of neurons as input.
An Activation Function decides whether a neuron should be activated or not. This means that it will
decide whether the neuron’s input to the network is important or not in the process of prediction.
There are several commonly used activation functions such as the ReLU, Softmax, tanH, and the
Sigmoid functions. Each of these functions has a specific usage.
Sigmoid — For a binary classification in the CNN model
tanH - The tanh function is very similar to the sigmoid function. The only difference is that it is
symmetric around the origin. The range of values, in this case, is from -1 to 1.
Softmax- It is used in multinomial logistic regression and is often used as the last activation
function of a neural network to normalize the output of a network to a probability distribution over
predicted output classes.
RelU- the main advantage of using the ReLU function over other activation functions is that it does
not activate all the neurons at the same time.
LeNet-5 CNN Architecture
In 1998, the LeNet-5 architecture was introduced in a research paper titled “Gradient-Based
Learning Applied to Document Recognition” by Yann LeCun, Leon Bottou, Yoshua Bengio, and
Patrick Haffner. It is one of the earliest and most basic CNN architecture.
It consists of 7 layers. The first layer consists of an input image with dimensions of 32×32. It is
convolved with 6 filters of size 5×5 resulting in dimension of 28x28x6. The second layer is a
Pooling operation which filter size 2×2 and stride of 2. Hence the resulting image dimension will
be 14x14x6.
Similarly, the third layer also involves in a convolution operation with 16 filters of size 5×5
followed by a fourth pooling layer with similar filter size of 2×2 and stride of 2. Thus, the resulting
image dimension will be reduced to 5x5x16.
Once the image dimension is reduced, the fifth layer is a fully connected convolutional layer with
120 filters each of size 5×5. In this layer, each of the 120 units in this layer will be connected to
the 400 (5x5x16) units from the previous layers. The sixth layer is also a fully connected layer
with 84 units.
The final seventh layer will be a softmax output layer with ‘n’ possible classes depending upon
the number of classes in the dataset.
Below are the snapshots of the Python code to build a LeNet-5 CNN architecture using keras
library with TensorFlow framework
In Python Programming, the model type that is most commonly used is the Sequential type. It is
the easiest way to build a CNN model in keras. It permits us to build a model layer by layer. The
‘add()’ function is used to add layers to the model. As explained above, for the LeNet-5
architecture, there are two Convolution and Pooling pairs followed by a Flatten layer which is
usually used as a connection between Convolution and the Dense layers.
The Dense layers are the ones that are mostly used for the output layers. The activation used is the
‘Softmax’ which gives a probability for each class and they sum up totally to 1. The model will
make it’s prediction based on the class with highest probability.