SlideShare una empresa de Scribd logo
1 de 18
Internship Report
On
“MNIST Handwritten Digit Classification Challenge”
Submitted by:
Raghunandan J
(ECK5441143C@eckovation.com)
Internship carried out at
“Eckovation”
Under the guidance of
Mr Ritesh Singh
Mentor,
Eckovation
1
Mr Priyanshu Pandey
Mentor,
Eckovation
2
Index
Sl. No Contents Page Number
1 Abstract 03
2 Introduction 04
3 Introduction(Contd) 05-06
4 Layers 07-17
5 Applications 18
3
Abstract
Artificial Intelligence has been witnessing a monumental
growth in bridging the gap between the capabilities of humans
and machines. Researchers and enthusiasts alike, work on
numerous aspects of the field to make amazing things happen.
One of many such areas is the domain of Computer Vision.
The agenda for this field is to enable machines to view the world
as humans do, perceive it in a similar manner and even use the
knowledge for a multitude of tasks such as Image & Video
recognition, Image Analysis & Classification, Media Recreation,
Recommendation Systems, Natural Language Processing, etc.
The advancements in Computer Vision with Deep Learning has
been constructed and perfected with time, primarily over one
particular algorithm — a Convolutional Neural Network.
4
Introduction
A Convolutional Neural Network (ConvNet/CNN) is a
Deep Learning algorithm which can take in an input image,
assign importance (learnable weights and biases) to various
aspects/objects in the image and be able to differentiate one
from the other. The pre-processing required in a ConvNet is
much lower as compared to other classification algorithms.
While in primitive methods filters are hand-engineered, with
enough training, ConvNets have the ability to learn these
filters/characteristics.
The architecture of a ConvNet is analogous to that of the
connectivity pattern of Neurons in the Human Brain and was
inspired by the organization of the Visual Cortex. Individual
neurons respond to stimuli only in a restricted region of the
visual field known as the Receptive Field. A collection of such
fields overlap to cover the entire visual area.
An example of a general convolutional neural network is shown
below….
It consists of the following layers:
● Input Image
● Convolution Layer - The Kernel
● Pooling Layer
● Padding layers
● Classification - Fully Connected Layer (FC)
5
Why ConvNets over Feed-Forward Neural Nets?
An image is nothing but a matrix of pixel values. So why not
just flatten the image (e.g. 3x3 image matrix into a 9x1 vector)
and feed it to a Multi-Level Perceptron for classification
purposes? In cases of extremely basic binary images, the
method might show an average precision score while
performing prediction of classes but would have little to no
accuracy when it comes to complex images having pixel
dependencies throughout.
A ConvNet is able to successfully capture the Spatial and
Temporal dependencies in an image through the
application of relevant filters. The architecture performs a
better fitting to the image dataset due to the reduction in the
6
number of parameters involved and reusability of weights. In
other words, the network can be trained to understand the
sophistication of the image better.
Explanation of each Layer
Input Image:
In the figure, we have an RGB image which has been separated
by its three color planes--Red, Green, Blue. There are a number
of such color spaces in which images exist-- Grayscale, RGB,
HSV, CMYK, etc.
7
For images reaching high dimensions such as 8K (7680×4320) ,
we can see that it gets very computationally intensive.
The role of the ConvNet is to reduce the images into a form
which is easier to process, without losing features which are
critical for getting a good prediction.
Convolutional Layer - The Kernel
mage Dimensions = 5 (Height) x 5 (Breadth) x 1 (Number of
channels, eg. RGB)
In the above demonstration, the green section resembles our
5x5x1 input image, I. The element involved in carrying out
8
9
the convolution operation in the first part of a Convolutional
Layer is called the Kernel/Filter, K, represented in the color
yellow. We have selected K as a 3x3x1 matrix.
Kernel/Filter, K =
1 0 1
0 1 0
1 0 1
The Kernel shifts 9 times because of Stride Length = 1
(Non-Strided), every time performing a matrix
multiplication operation between K and the portion P
of the image over which the kernel is hovering.
The filter moves to the right with a certain Stride Value till it
parses the complete width. Moving on, it hops down to the
beginning (left) of the image with the same Stride Value and
repeats the process until the entire image is traversed.
10
In the case of images with multiple channels (e.g. RGB), the
Kernel has the same depth as that of the input image. Matrix
Multiplication is performed between Kn and In stack ([K1, I1];
[K2, I2]; [K3, I3]) and all the results are summed with the bias
to give us a squashed one-depth channel Convoluted Feature
Output.
The objective of the Convolution Operation is to extract the
high-level featuressuch as edges, from the input image.
ConvNets need not be limited to only one Convolutional Layer.
Conventionally, the first ConvLayer is responsible for capturing
the Low-Level features such as edges, color, gradient
11
orientation, etc. With added layers, the architecture adapts to
the High-Level features as well, giving us a network which has
the wholesome understanding of images in the dataset, similar
to how we would.
There are two types of results to the operation — one in which
the convolved feature is reduced in dimensionality as compared
to the input, and the other in which the dimensionality is either
increased or remains the same. This is done by applying Valid
Padding in case of the former, or Same Padding in the case
of the latter.
12
When we augment the 5x5x1 image into a 6x6x1 image and then
apply the 3x3x1 kernel over it, we find that the convolved
matrix turns out to be of dimensions 5x5x1. Hence the name —
Same Padding.
On the other hand, if we perform the same operation without
padding, we are presented with a matrix which has dimensions
of the Kernel (3x3x1) itself — Valid Padding.
The following repository houses many such GIFs which would
help you get a better understanding of how Padding and Stride
Length work together to achieve results relevant to our needs.
Pooling Layer
13
14
Similar to the Convolutional Layer, the Pooling layer is
responsible for reducing the spatial size of the Convolved
Feature. This is to decrease the computational power
required to process the datathrough dimensionality
reduction. Furthermore, it is useful for extracting dominant
features which are rotational and positional invariant, thus
maintaining the process of effectively training of the model.
There are two types of Pooling: Max Pooling and Average
Pooling. Max Pooling returns the maximum value from the
portion of the image covered by the Kernel. On the other hand,
Average Pooling returns the average of all the values
from the portion of the image covered by the Kernel.
Max Pooling also performs as a Noise Suppressant. It
discards the noisy activations altogether and also performs
de-noising along with dimensionality reduction. On the other
hand, Average Pooling simply performs dimensionality
reduction as a noise suppressing mechanism. Hence, we can say
that Max Pooling performs a lot better than Average
Pooling.
The Convolutional Layer and the Pooling Layer, together form
the i-th layer of a Convolutional Neural Network. Depending on
the complexities in the images, the number of such layers may
be increased for capturing low-levels details even further, but at
the cost of more computational power.
After going through the above process, we have successfully
enabled the model to understand the features. Moving on, we
are going to flatten the final output and feed it to a regular
Neural Network for classification purposes.
Classification - Fully Connected Layer (FC)
15
Adding a Fully-Connected layer is a (usually) cheap way of
learning non-linear combinations of the high-level features as
represented by the output of the convolutional layer. The
Fully-Connected layer is learning a possibly non-linear function
in that space.
Now that we have converted our input image into a suitable
form for our Multi-Level Perceptron, we shall flatten the image
into a column vector. The flattened output is fed to a
feed-forward neural network and backpropagation applied to
every iteration of training. Over a series of epochs, the model is
able to distinguish between dominating and certain low-level
features in images and classify them using the Softmax
Classification technique.
16
17
There are various architectures of CNNs available which have been key in
building algorithms which power and shall power AI as a whole in the
foreseeable future. Some of them have been listed below:
1. LeNet
2. AlexNet
3. VGGNet
4. GoogLeNet
5. ResNet
6. ZFNet
Real world applications of artificial neural
networks:
Today most of the modern intelligent application uses ANN model as a
main approach to solve complicated problems. For example -the
direction feature of Google Maps, search for an image with Google
Images, the way we give voice instructions to Amazon Alexa, all these
products exploit artificial neural network model. Artificial neural
networks have broad applications in robotics, computer vision, pattern
recognition, natural language processing, self-driving cars and countless
other applications.
To sum up the blog we can say that neural networks are arguably that
technological development which has a good potential currently on the
18
horizon. And scientist are still working over it, discovering the
possibilities of this technology and we hope to see more advancement of
artificial neural network in the coming future.
---END---

Más contenido relacionado

La actualidad más candente

La actualidad más candente (20)

Cnn
CnnCnn
Cnn
 
Regularization in deep learning
Regularization in deep learningRegularization in deep learning
Regularization in deep learning
 
Introduction to CNN
Introduction to CNNIntroduction to CNN
Introduction to CNN
 
Convolutional Neural Network (CNN)
Convolutional Neural Network (CNN)Convolutional Neural Network (CNN)
Convolutional Neural Network (CNN)
 
Resnet
ResnetResnet
Resnet
 
Convolutional Neural Network Models - Deep Learning
Convolutional Neural Network Models - Deep LearningConvolutional Neural Network Models - Deep Learning
Convolutional Neural Network Models - Deep Learning
 
Deep Learning - RNN and CNN
Deep Learning - RNN and CNNDeep Learning - RNN and CNN
Deep Learning - RNN and CNN
 
CNN Tutorial
CNN TutorialCNN Tutorial
CNN Tutorial
 
Deep Learning - Convolutional Neural Networks
Deep Learning - Convolutional Neural NetworksDeep Learning - Convolutional Neural Networks
Deep Learning - Convolutional Neural Networks
 
Convolutional Neural Network and Its Applications
Convolutional Neural Network and Its ApplicationsConvolutional Neural Network and Its Applications
Convolutional Neural Network and Its Applications
 
Convolutional neural network
Convolutional neural networkConvolutional neural network
Convolutional neural network
 
Convolutional Neural Network
Convolutional Neural NetworkConvolutional Neural Network
Convolutional Neural Network
 
Machine Learning - Convolutional Neural Network
Machine Learning - Convolutional Neural NetworkMachine Learning - Convolutional Neural Network
Machine Learning - Convolutional Neural Network
 
Cnn
CnnCnn
Cnn
 
Artificial neural network
Artificial neural networkArtificial neural network
Artificial neural network
 
Image classification with Deep Neural Networks
Image classification with Deep Neural NetworksImage classification with Deep Neural Networks
Image classification with Deep Neural Networks
 
Deep learning
Deep learningDeep learning
Deep learning
 
Deep Learning With Neural Networks
Deep Learning With Neural NetworksDeep Learning With Neural Networks
Deep Learning With Neural Networks
 
Deep learning
Deep learningDeep learning
Deep learning
 
Deep Learning Tutorial
Deep Learning TutorialDeep Learning Tutorial
Deep Learning Tutorial
 

Similar a Mnist report ppt

Saptashwa_Mitra_Sitakanta_Mishra_Final_Project_Report
Saptashwa_Mitra_Sitakanta_Mishra_Final_Project_ReportSaptashwa_Mitra_Sitakanta_Mishra_Final_Project_Report
Saptashwa_Mitra_Sitakanta_Mishra_Final_Project_Report
Sitakanta Mishra
 
Deep Neural Network DNN.docx
Deep Neural Network DNN.docxDeep Neural Network DNN.docx
Deep Neural Network DNN.docx
jaffarbikat
 
International Journal of Computational Engineering Research(IJCER)
International Journal of Computational Engineering Research(IJCER)International Journal of Computational Engineering Research(IJCER)
International Journal of Computational Engineering Research(IJCER)
ijceronline
 
Deep Learning
Deep LearningDeep Learning
Deep Learning
Pierre de Lacaze
 

Similar a Mnist report ppt (20)

Mnist report
Mnist reportMnist report
Mnist report
 
A Pointing Gesture-based Signal to Text Communication System Using OpenCV in ...
A Pointing Gesture-based Signal to Text Communication System Using OpenCV in ...A Pointing Gesture-based Signal to Text Communication System Using OpenCV in ...
A Pointing Gesture-based Signal to Text Communication System Using OpenCV in ...
 
Review-image-segmentation-by-deep-learning
Review-image-segmentation-by-deep-learningReview-image-segmentation-by-deep-learning
Review-image-segmentation-by-deep-learning
 
Saptashwa_Mitra_Sitakanta_Mishra_Final_Project_Report
Saptashwa_Mitra_Sitakanta_Mishra_Final_Project_ReportSaptashwa_Mitra_Sitakanta_Mishra_Final_Project_Report
Saptashwa_Mitra_Sitakanta_Mishra_Final_Project_Report
 
Deep Neural Network DNN.docx
Deep Neural Network DNN.docxDeep Neural Network DNN.docx
Deep Neural Network DNN.docx
 
Conception_et_realisation_dun_site_Web_d.pdf
Conception_et_realisation_dun_site_Web_d.pdfConception_et_realisation_dun_site_Web_d.pdf
Conception_et_realisation_dun_site_Web_d.pdf
 
Classification of Images Using CNN Model and its Variants
Classification of Images Using CNN Model and its VariantsClassification of Images Using CNN Model and its Variants
Classification of Images Using CNN Model and its Variants
 
Introduction to Convolutional Neural Networks
Introduction to Convolutional Neural NetworksIntroduction to Convolutional Neural Networks
Introduction to Convolutional Neural Networks
 
A survey on the layers of convolutional Neural Network
A survey on the layers of convolutional Neural NetworkA survey on the layers of convolutional Neural Network
A survey on the layers of convolutional Neural Network
 
RunPool: A Dynamic Pooling Layer for Convolution Neural Network
RunPool: A Dynamic Pooling Layer for Convolution Neural NetworkRunPool: A Dynamic Pooling Layer for Convolution Neural Network
RunPool: A Dynamic Pooling Layer for Convolution Neural Network
 
ImageNet Classification with Deep Convolutional Neural Networks
ImageNet Classification with Deep Convolutional Neural NetworksImageNet Classification with Deep Convolutional Neural Networks
ImageNet Classification with Deep Convolutional Neural Networks
 
International Journal of Computational Engineering Research(IJCER)
International Journal of Computational Engineering Research(IJCER)International Journal of Computational Engineering Research(IJCER)
International Journal of Computational Engineering Research(IJCER)
 
CNN.pptx
CNN.pptxCNN.pptx
CNN.pptx
 
M017427985
M017427985M017427985
M017427985
 
International Journal of Computational Engineering Research(IJCER)
International Journal of Computational Engineering Research(IJCER)International Journal of Computational Engineering Research(IJCER)
International Journal of Computational Engineering Research(IJCER)
 
Handwritten Digit Recognition using Convolutional Neural Networks
Handwritten Digit Recognition using Convolutional Neural  NetworksHandwritten Digit Recognition using Convolutional Neural  Networks
Handwritten Digit Recognition using Convolutional Neural Networks
 
Deep Learning
Deep LearningDeep Learning
Deep Learning
 
Overview of Convolutional Neural Networks
Overview of Convolutional Neural NetworksOverview of Convolutional Neural Networks
Overview of Convolutional Neural Networks
 
11_Saloni Malhotra_SummerTraining_PPT.pptx
11_Saloni Malhotra_SummerTraining_PPT.pptx11_Saloni Malhotra_SummerTraining_PPT.pptx
11_Saloni Malhotra_SummerTraining_PPT.pptx
 
Log polar coordinates
Log polar coordinatesLog polar coordinates
Log polar coordinates
 

Último

Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
Joaquim Jorge
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
giselly40
 
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptxEIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
Earley Information Science
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
vu2urc
 

Último (20)

04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonets
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
 
Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organization
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
 
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptxEIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
EIS-Webinar-Prompt-Knowledge-Eng-2024-04-08.pptx
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)
 
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
 
What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?
 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024
 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men
 
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfThe Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day Presentation
 
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUnderstanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
 

Mnist report ppt

  • 1. Internship Report On “MNIST Handwritten Digit Classification Challenge” Submitted by: Raghunandan J (ECK5441143C@eckovation.com) Internship carried out at “Eckovation” Under the guidance of Mr Ritesh Singh Mentor, Eckovation 1 Mr Priyanshu Pandey Mentor, Eckovation
  • 2. 2 Index Sl. No Contents Page Number 1 Abstract 03 2 Introduction 04 3 Introduction(Contd) 05-06 4 Layers 07-17 5 Applications 18
  • 3. 3 Abstract Artificial Intelligence has been witnessing a monumental growth in bridging the gap between the capabilities of humans and machines. Researchers and enthusiasts alike, work on numerous aspects of the field to make amazing things happen. One of many such areas is the domain of Computer Vision. The agenda for this field is to enable machines to view the world as humans do, perceive it in a similar manner and even use the knowledge for a multitude of tasks such as Image & Video recognition, Image Analysis & Classification, Media Recreation, Recommendation Systems, Natural Language Processing, etc. The advancements in Computer Vision with Deep Learning has been constructed and perfected with time, primarily over one particular algorithm — a Convolutional Neural Network.
  • 4. 4 Introduction A Convolutional Neural Network (ConvNet/CNN) is a Deep Learning algorithm which can take in an input image, assign importance (learnable weights and biases) to various aspects/objects in the image and be able to differentiate one from the other. The pre-processing required in a ConvNet is much lower as compared to other classification algorithms. While in primitive methods filters are hand-engineered, with enough training, ConvNets have the ability to learn these filters/characteristics. The architecture of a ConvNet is analogous to that of the connectivity pattern of Neurons in the Human Brain and was inspired by the organization of the Visual Cortex. Individual neurons respond to stimuli only in a restricted region of the visual field known as the Receptive Field. A collection of such fields overlap to cover the entire visual area.
  • 5. An example of a general convolutional neural network is shown below…. It consists of the following layers: ● Input Image ● Convolution Layer - The Kernel ● Pooling Layer ● Padding layers ● Classification - Fully Connected Layer (FC) 5
  • 6. Why ConvNets over Feed-Forward Neural Nets? An image is nothing but a matrix of pixel values. So why not just flatten the image (e.g. 3x3 image matrix into a 9x1 vector) and feed it to a Multi-Level Perceptron for classification purposes? In cases of extremely basic binary images, the method might show an average precision score while performing prediction of classes but would have little to no accuracy when it comes to complex images having pixel dependencies throughout. A ConvNet is able to successfully capture the Spatial and Temporal dependencies in an image through the application of relevant filters. The architecture performs a better fitting to the image dataset due to the reduction in the 6
  • 7. number of parameters involved and reusability of weights. In other words, the network can be trained to understand the sophistication of the image better. Explanation of each Layer Input Image: In the figure, we have an RGB image which has been separated by its three color planes--Red, Green, Blue. There are a number of such color spaces in which images exist-- Grayscale, RGB, HSV, CMYK, etc. 7
  • 8. For images reaching high dimensions such as 8K (7680×4320) , we can see that it gets very computationally intensive. The role of the ConvNet is to reduce the images into a form which is easier to process, without losing features which are critical for getting a good prediction. Convolutional Layer - The Kernel mage Dimensions = 5 (Height) x 5 (Breadth) x 1 (Number of channels, eg. RGB) In the above demonstration, the green section resembles our 5x5x1 input image, I. The element involved in carrying out 8
  • 9. 9 the convolution operation in the first part of a Convolutional Layer is called the Kernel/Filter, K, represented in the color yellow. We have selected K as a 3x3x1 matrix. Kernel/Filter, K = 1 0 1 0 1 0 1 0 1 The Kernel shifts 9 times because of Stride Length = 1 (Non-Strided), every time performing a matrix multiplication operation between K and the portion P of the image over which the kernel is hovering.
  • 10. The filter moves to the right with a certain Stride Value till it parses the complete width. Moving on, it hops down to the beginning (left) of the image with the same Stride Value and repeats the process until the entire image is traversed. 10
  • 11. In the case of images with multiple channels (e.g. RGB), the Kernel has the same depth as that of the input image. Matrix Multiplication is performed between Kn and In stack ([K1, I1]; [K2, I2]; [K3, I3]) and all the results are summed with the bias to give us a squashed one-depth channel Convoluted Feature Output. The objective of the Convolution Operation is to extract the high-level featuressuch as edges, from the input image. ConvNets need not be limited to only one Convolutional Layer. Conventionally, the first ConvLayer is responsible for capturing the Low-Level features such as edges, color, gradient 11
  • 12. orientation, etc. With added layers, the architecture adapts to the High-Level features as well, giving us a network which has the wholesome understanding of images in the dataset, similar to how we would. There are two types of results to the operation — one in which the convolved feature is reduced in dimensionality as compared to the input, and the other in which the dimensionality is either increased or remains the same. This is done by applying Valid Padding in case of the former, or Same Padding in the case of the latter. 12
  • 13. When we augment the 5x5x1 image into a 6x6x1 image and then apply the 3x3x1 kernel over it, we find that the convolved matrix turns out to be of dimensions 5x5x1. Hence the name — Same Padding. On the other hand, if we perform the same operation without padding, we are presented with a matrix which has dimensions of the Kernel (3x3x1) itself — Valid Padding. The following repository houses many such GIFs which would help you get a better understanding of how Padding and Stride Length work together to achieve results relevant to our needs. Pooling Layer 13
  • 14. 14 Similar to the Convolutional Layer, the Pooling layer is responsible for reducing the spatial size of the Convolved Feature. This is to decrease the computational power required to process the datathrough dimensionality reduction. Furthermore, it is useful for extracting dominant features which are rotational and positional invariant, thus maintaining the process of effectively training of the model. There are two types of Pooling: Max Pooling and Average Pooling. Max Pooling returns the maximum value from the portion of the image covered by the Kernel. On the other hand, Average Pooling returns the average of all the values from the portion of the image covered by the Kernel. Max Pooling also performs as a Noise Suppressant. It discards the noisy activations altogether and also performs de-noising along with dimensionality reduction. On the other hand, Average Pooling simply performs dimensionality reduction as a noise suppressing mechanism. Hence, we can say that Max Pooling performs a lot better than Average Pooling.
  • 15. The Convolutional Layer and the Pooling Layer, together form the i-th layer of a Convolutional Neural Network. Depending on the complexities in the images, the number of such layers may be increased for capturing low-levels details even further, but at the cost of more computational power. After going through the above process, we have successfully enabled the model to understand the features. Moving on, we are going to flatten the final output and feed it to a regular Neural Network for classification purposes. Classification - Fully Connected Layer (FC) 15
  • 16. Adding a Fully-Connected layer is a (usually) cheap way of learning non-linear combinations of the high-level features as represented by the output of the convolutional layer. The Fully-Connected layer is learning a possibly non-linear function in that space. Now that we have converted our input image into a suitable form for our Multi-Level Perceptron, we shall flatten the image into a column vector. The flattened output is fed to a feed-forward neural network and backpropagation applied to every iteration of training. Over a series of epochs, the model is able to distinguish between dominating and certain low-level features in images and classify them using the Softmax Classification technique. 16
  • 17. 17 There are various architectures of CNNs available which have been key in building algorithms which power and shall power AI as a whole in the foreseeable future. Some of them have been listed below: 1. LeNet 2. AlexNet 3. VGGNet 4. GoogLeNet 5. ResNet 6. ZFNet Real world applications of artificial neural networks: Today most of the modern intelligent application uses ANN model as a main approach to solve complicated problems. For example -the direction feature of Google Maps, search for an image with Google Images, the way we give voice instructions to Amazon Alexa, all these products exploit artificial neural network model. Artificial neural networks have broad applications in robotics, computer vision, pattern recognition, natural language processing, self-driving cars and countless other applications. To sum up the blog we can say that neural networks are arguably that technological development which has a good potential currently on the
  • 18. 18 horizon. And scientist are still working over it, discovering the possibilities of this technology and we hope to see more advancement of artificial neural network in the coming future. ---END---