Deep Learning - AD3501 - Notes - Unit 1 - Deep Networks Basics
Deep Learning - AD3501 - Notes - Unit 1 - Deep Networks Basics
4th Semester
2nd Semester
Deep Learning -
AD3501
Embedded Systems
Data and Information Human Values and
and IoT - CS3691
5th Semester
7th Semester
8th Semester
Open Elective-1
Distributed Computing Open Elective 2
- CS3551 Project Work /
Elective-3
Open Elective 3 Intership
Big Data Analytics - Elective-4
CCS334 Open Elective 4
Elective-5
Elective 1 Management Elective
Elective-6
Elective 2
All Computer Engg Subjects - [ B.E., M.E., ] (Click on Subjects to enter)
Programming in C Computer Networks Operating Systems
Programming and Data Programming and Data Problem Solving and Python
Structures I Structure II Programming
Database Management Systems Computer Architecture Analog and Digital
Communication
Design and Analysis of Microprocessors and Object Oriented Analysis
Algorithms Microcontrollers and Design
Software Engineering Discrete Mathematics Internet Programming
Theory of Computation Computer Graphics Distributed Systems
Mobile Computing Compiler Design Digital Signal Processing
Artificial Intelligence Software Testing Grid and Cloud Computing
Data Ware Housing and Data Cryptography and Resource Management
Mining Network Security Techniques
Service Oriented Architecture Embedded and Real Time Multi - Core Architectures
Systems and Programming
Probability and Queueing Theory Physics for Information Transforms and Partial
Science Differential Equations
Technical English Engineering Physics Engineering Chemistry
Engineering Graphics Total Quality Professional Ethics in
Management Engineering
Basic Electrical and Electronics Problem Solving and Environmental Science and
and Measurement Engineering Python Programming Engineering
lOMoARcPSD|45374298
www.BrainKart.com
1. Introduction:
Today, artificial intelligence (AI) is a thriving field with many practical applications and active research
topics. We look to intelligent software to automate routine labor, understand speech or images, make
diagnoses in medicine and support basic scientific research. In the early days of artificial intelligence, the
field rapidly tackled and solved problems that are intellectually difficult for human beings but relatively
straightforward for computers—problems that can be described by a list of formal, mathematical rules. The
true challenge of AI lies in solving more intuitive problems. The solution is to allow computers to learn
from experience and understand the world in terms of a hierarchy of concepts, with each concept defined in
terms of its relation to simpler concepts. By gathering knowledge from experience, this approach avoids the
need for human operators to formally specify all of the knowledge that the computer needs. The hierarchy
of concepts allows the computer to learn complicated concepts by building them out of simpler ones. If one
draws a graph showing how these concepts are built on top of each other, the graph is deep, with many
layers. For this reason, this approach is called as deep learning.
A computer can reason about statements in these formal languages automatically using logical inference
rules. This is known as the knowledge base approach to artificial intelligence. The difficulties faced by
systems relying on hard-coded knowledge suggest that AI systems need the ability to acquire their own
knowledge, by extracting patterns from raw data. This capability is known as machine learning. The
introduction of machine learning allowed computers to tackle problems involving knowledge of the real
world and make decisions that appear subjective. A simple machine learning algorithm called logistic
regression can determine whether to recommend cesarean delivery. A simple machine learning algorithm
called naive Bayes can separate legitimate e-mail from spam e-mail.
The performance of these simple machine learning algorithms depends heavily on the representation of the
data they are given. For example, when logistic regression is used to recommend cesarean delivery, the AI
system does not examine the patient directly. Instead, the doctor tells the system several pieces of relevant
information, such as the presence or absence of a uterine scar. Each piece of information included in the
representation of the patient is known as a feature. Logistic regression learns how each of these features of
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
the patient correlates with various outcomes. However, it cannot influence the way that the features are
defined in any way. If logistic regression was given an MRI scan of the patient, rather than the doctor‘s
formalized report, it would not be able to make useful predictions. Individual pixels in an MRI scan have
negligible correlation with any complications that might occur during delivery.
This dependence on representations is a general phenomenon that appears throughout computer science and
even daily life. In computer science, operations such as searching a collection of data can proceed
exponentially faster if the collection is structured and indexed intelligently. People can easily perform
arithmetic on Arabic numerals, but find arithmetic on Roman numerals much more time-consuming. It is
not surprising that the choice of representation has an enormous effect on the performance of machine
learning algorithms. Many artificial intelligence tasks can be solved by designing the right set of features to
extract for that task, then providing these features to a simple machine learning algorithm. However, for
many tasks, it is difficult to know what features should be extracted. For example, suppose that we would
like to write a program to detect cars in photographs. We know that cars have wheels, so we might like to
use the presence of a wheel as a feature. Unfortunately, it is difficult to describe exactly what a wheel looks
like in terms of pixel values.
One solution to this problem is to use machine learning to discover not only the mapping from
representation to output but also the representation itself. This approach is known as representation
learning. Learned representations often result in much better performance than can be obtained with hand-
designed representations. They also allow AI systems to rapidly adapt to new tasks, with minimal human
intervention. A representation learning algorithm can discover a good set of features for a simple task in
minutes, or a complex task in hours to months.
The quintessential example of a representation learning algorithm is the autoencoder. An autoencoder is the
combination of an encoder function that converts the input data into a different representation, and a
decoder function that converts the new representation back into the original format. Autoencoders are
trained to preserve as much information as possible when an input is run through the encoder and then the
decoder, but are also trained to make the new representation have various nice properties. Different kinds of
autoencoders aim to achieve different kinds of properties. When designing features or algorithms for
learning features, our goal is usually to separate the factors of variation that explain the observed data. A
major source of difficulty in many real-world artificial intelligence applications is that many of the factors
of variation influence every single piece of data we are able to observe. The individual pixels in an image of
a red car might be very close to black at night. The shape of the car‘s silhouette depends on the viewing
angle. It can be very difficult to extract such high-level, abstract features from raw data. Deep learning
solves this central problem in representation learning by introducing representations that are expressed in
terms of other, simpler representations.
Deep learning allows the computer to build complex concepts out of simpler concepts. Fig. 1.1 shows how a
deep learning system can represent the concept of an image of a person by combining simpler concepts,
such as corners and contours, which are in turn defined in terms of edges. The quintessential example of a
deep learning model is the feedforward deep network or multilayer perceptron (MLP). A multilayer
perceptron is just a mathematical function mapping some set of input values to output values. The function
is formed by composing many simpler functions. The idea of learning the right representation for the data
provides one perspective on deep learning. Another perspective on deep learning is that depth allows the
computer to learn a multi-step computer program. Each layer of the representation can be thought of as the
state of the computer‘s memory after executing another set of instructions in parallel. Networks with greater
DCE | By: Dr. K. Revathi & Mrs. R. Selvi / AIDS 2
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
depth can execute more instructions in sequence. Sequential instructions offer great power because later
instructions can refer back to the results of earlier instructions.
The input is presented at the, so named because it contains visible layer the variables that we are able to
observe. Then a series of hidden layers extracts increasingly abstract features from the image. These layers
are called ―hidden‖ because their values are not given in the data; instead the model must determine which
concepts are useful for explaining the relationships in the observed data. The images here are visualizations
of the kind of feature represented by each hidden unit. Given the pixels, the first layer can easily identify
edges, by comparing the brightness of neighboring pixels. Given the first hidden layer‘s description of the
edges, the second hidden layer can easily search for corners and extended contours, which are recognizable
as collections of edges. Given the second hidden layer‘s description of the image in terms of corners and
contours, the third hidden layer can detect entire parts of specific objects, by finding specific collections of
contours and corners. Finally, this description of the image in terms of the object parts it contains can be
used to recognize the objects present in the image.
There are two main ways of measuring the depth of a model. The first view is based on the number of
sequential instructions that must be executed to evaluate the architecture. Another approach, used by deep
probabilistic models, regards the depth of a model as being not the depth of the computational graph but the
depth of the graph describing how concepts are related to each other. Machine learning is the only viable
approach to building AI systems that can operate in complicated, real-world environments. Deep learning is
a particular kind of machine learning that achieves great power and flexibility by learning to represent the
world as a nested hierarchy of concepts, with each concept defined in relation to simpler concepts, and more
abstract representations computed in terms of less abstract ones. Fig. 1.2 illustrates the relationship between
these different AI disciplines. Fig. 1.3 gives a high-level schematic of how each works.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
AI is basically the study of training your machine (computers) to mimic a human brain and its
thinking capabilities. AI focuses on three major aspects (skills): learning, reasoning, and self-
correction to obtain the maximum efficiency possible. Machine Learning (ML) is an application or
subset of AI. The major aim of ML is to allow the systems to learn by themselves through experience
without any kind of human intervention or assistance. Deep Learning (DL) is basically a sub-part of the
broader family of Machine Learning which makes use of Neural Networks (similar to the neurons working
in our brain) to mimic human brain-like behavior. DL algorithms focus on information processing
patterns mechanism to possibly identify the patterns just like our human brain does and classifies the
information accordingly. DL works on larger sets of data when compared to ML and the prediction
mechanism is self-administered by machines. The differences between AI, ML and DL are presented as
Table 1 as below.
Table 1. Difference between Artificial Intelligence, Machine Learning & Deep Learning
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
Artificial Intelligence Machine Learning Deep Learning
Three broad categories/types Of AI Three broad categories/types of DL can be considered as neural
are: Artificial Narrow Intelligence ML are: Supervised Learning, networks with a large number
(ANI), Artificial General Intelligence Unsupervised Learning and of parameters layers lying in
(AGI) and Artificial Super Intelligence Reinforcement Learning one of the four fundamental
(ASI) network architectures:
Unsupervised Pre-trained
Networks, Convolutional
Neural Networks, Recurrent
Neural Networks and Recursive
Neural Networks
Examples of AI applications include: Examples of ML applications Examples of DL applications
Google‘s AI-Powered Predictions, include: Virtual Personal include: Sentiment based news
Ridesharing Apps Like Uber and Lyft, Assistants: Siri, Alexa, Google, aggregation, Image analysis and
Commercial Flights Use an AI etc., Email Spam and Malware caption generation, etc.
Autopilot, etc. Filtering.
2. Linear Algebra:
A good understanding of linear algebra is essential for understanding and working with many machine
learning algorithms, especially deep learning algorithms.
2.1 Scalars, Vectors, Matrices and Tensors
The study of linear algebra involves several types of mathematical objects:
● Scalars: A scalar is just a single number, in contrast to most of the other objects studied in linear algebra,
which are usually arrays of multiple numbers. We write scalars in italics. We usually give scalars lower-
case variable names. When we introduce them, we specify what kind of number they are. For example, we
might say ―Let s ∈ R be the slope of the line,‖ while defining a real-valued scalar, or ―Let n ∈ N be the
number of units,‖ while defining a natural number scalar.
● Vectors: A vector is an array of numbers. The numbers are arranged in order. We can identify each individual
number by its index in that ordering. Typically we give vectors lower case names written in bold typeface,
such as x. The elements of the vector are identified by writing its name in italic typeface, with a subscript.
The first element of x is x1, the second element is x2 and so on. We also need to say what kinds of numbers
are stored in the vector. If each element is in R, and the vector has n elements, then the vector lies in the set
formed by taking the Cartesian product of R n times, denoted as Rn. When we need to explicitly identify the
elements of a vector, we write them as a column enclosed in square brackets:
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
We can think of vectors as identifying points in space, with each element giving the coordinate along a
different axis. Sometimes we need to index a set of elements of a vector. In this case, we define a set
containing the indices and write the set as a subscript. For example, to access x1, x3 and x6 , we define the
set S = {1, 3, 6} and write xS . We use the − sign to index the complement of a set. For example x −1 is the
vector containing all elements of x except for x1, and x−S is the vector containing all of the elements of x
except for x1, x3 and x6.
● Matrices: A matrix is a 2-D array of numbers, so each element is identified by two indices instead of just one.
We usually give matrices upper-case variable names with bold typeface, such as A. If a real-valued matrix
A has a height of m and a width of n, then we say that A ∈ Rm×n. We usually identify the elements of a
matrix using its name in italic but not bold font, and the indices are listed with separating commas. For
example, A1,1 is the upper left entry of A and Am,n is the bottom right entry. We can identify all of the
numbers with vertical coordinate i by writing a ―:‖ for the horizontal coordinate. For example, A i,: denotes
the horizontal cross section of A with vertical coordinate i. This is known as the i-th row of A. Likewise, A:,i
is the i-th column of A. When we need to explicitly identify the elements of a matrix, we write them as an
array enclosed in square brackets:
Sometimes we may need to index matrix-valued expressions that are not just a single letter. In this case, we
use subscripts after the expression, but do not convert anything to lower case. For example, f (A)i,j gives
element (i, j) of the matrix computed by applying the function f to A.
● Tensors: In some cases we will need an array with more than two axes. In the general case, an array of
numbers arranged on a regular grid with a variable number of axes is known as a tensor. We denote a tensor
named ―A‖ with this typeface: A. We identify the element of A at coordinates (i, j, k) by writing Ai,j,k. One
important operation on matrices is the transpose. The transpose of a matrix is the mirror image of the matrix
across a diagonal line, called the main diagonal, running down and to the right, starting from its upper left
corner. See Fig. 2.1 for a graphical depiction of this operation. We denote the transpose of a matrix A as AT,
and it is defined such that
Vectors can be thought of as matrices that contain only one column. The transpose of a vector is therefore a
matrix with only one row. Sometimes we define a vector by writing out its elements in the text inline as a
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
row matrix, then using the transpose operator to turn it into a standard column vector, e.g., x = [x1, x2, x3
]T.
A scalar can be thought of as a matrix with only a single entry. From this, we can see that a scalar is its own
transpose: a = aT. We can add matrices to each other, as long as they have the same shape, just by adding
their corresponding elements: C = A +B where Ci,j = Ai,j + Bi,j.We can also add a scalar to a matrix or
multiply a matrix by a scalar, just by performing that operation on each element of a matrix: D = a · B + c
where Di,j = a · Bi,j + c.
In the context of deep learning, we also use some less conventional notation. We allow the addition of
matrix and a vector, yielding another matrix: C = A + b, where Ci,j = Ai,j + bj. In other words, the vector b is
added to each row of the matrix. This shorthand eliminates the need to define a matrix with b copied into
each row before doing the addition. This implicit copying of b to many locations is called broadcasting.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
x X , 0 ≤ P(x) ≤ 1. An impossible event has probability 0 and no state can be less
probable than that. Likewise, an event that is guaranteed to happen has probability 1, and no
state can have a greater chance of occurring.
x X
P( x) 1
.We refers to this property as being normalized. Without this property, we
could obtain probabilities greater than one by computing the probability of one of many
events occurring.
For example, consider a single discrete random variable x with k different states. We can place a uniform
distribution on x—that is, make each of its states equally likely—by setting its probability mass function to
1
for all i. We can see that this fits the requirements for a probability mass function. The value k is positive
because k is a positive integer. We also see that
so the distribution is properly normalized. Let‘s discuss few discrete probability distributions as follows:
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
3.3.1.2 Bernoulli's Distribution
The Bernoulli distribution is a variant of the Binomial distribution in which only one experiment is
conducted, resulting in a single observation. As a result, the Bernoulli distribution describes events that have
exactly two outcomes.
Here‘s a Python Code to show Bernoulli distribution:
The Bernoulli random variable's expected value is p, which is also known as the Bernoulli distribution's
parameter.
The experiment's outcome can be a value of 0 or 1. Bernoulli random variables can have values of 0 or 1.
The pmf function is used to calculate the probability of various random variable values.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
The Python code below shows a simple example of Poisson distribution. It has two parameters:
1. Lam: Known number of occurrences
2. Size: The shape of the returned array
The below-given Python code generates the 1x100 distribution for occurrence 5.
For an example of a probability density function corresponding to a specific probability density over a
continuous random variable, consider a uniform distribution on an interval of the real numbers. We can do
this with a function u(x; a, b), where a and b are the endpoints of the interval, with b > a. The ―;‖ notation
means ―parametrized by‖; we consider x to be the argument of the function, while a and b are parameters
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
that define the function. To ensure that there is no probability mass outside the interval, we say u(x;a, b) = 0
1
for all x [a, b]. Within [a, b], u(x; a, b) = . We can see that this is nonnegative everywhere.
ba
Additionally, it integrates to 1. We often denote that x follows the uniform distribution on [a, b] by writing x
~ U(a, b).
.
3.3.2.1 Normal Distribution
Normal Distribution is one of the most basic continuous distribution types. Gaussian distribution is another
name for it. Around its mean value, this probability distribution is symmetrical. It also demonstrates that
data close to the mean occurs more frequently than data far from it. Here, the mean is 0, and the variance is
a finite value.
In the example, you generated 100 random variables ranging from 1 to 50. After that, you created a function
to define the normal distribution formula to calculate the probability density function. Then, you have
plotted the data points and probability density function against X-axis and Y-axis, respectively.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
3.3.2.4 Exponential Distribution
In a Poisson process, an exponential distribution is a continuous probability distribution that describes the
time between events (success, failure, arrival, etc.).
You can see in the below example how to get random samples of exponential distribution and return Numpy
array samples by using the numpy.random.exponential() method.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
4.1 Role of an Optimization
As discussed above, optimizers update the parameters of neural networks such as weights and learning rate
to minimize the loss function. Here, the loss function acts as a guide to the terrain telling optimizer if it is
moving in the right direction to reach the bottom of the valley, the global minimum.
4.2 The Intuition behind Optimization
Let us imagine a climber hiking down the hill with no sense of direction. He doesn‘t know the right way to
reach the valley in the hills, but, he can understand whether he is moving closer (going downhill) or further
away (uphill) from his final destination. If he keeps taking steps in the correct direction, he will reach to his
aim i.,e the valley.
Exactly, this is the intuition behind optimization- to reach a global minimum concerning the loss function.
4.3 Instances of Gradient-Based Optimizers
Different instances of Gradient descent based Optimizers are as follows:
Batch Gradient Descent or Vanilla Gradient Descent or Gradient Descent (GD)
Stochastic Gradient Descent (SGD)
Mini batch Gradient Descent (MB-GD)
4.3.1 Batch Gradient Descent
Gradient descent algorithm is an optimization algorithm which is used to minimize the function. The
function which is set to be minimized is called as an objective function. For machine learning,
the objective function is also termed as the cost function or loss function. It is the loss function which is
optimized (minimized) and gradient descent is used to find the most optimal value of parameters / weights
which minimizes the loss function. Loss function, simply speaking, is the measure of the squared
difference between actual values and predictions. In order to minimize the objective function, the most
optimal value of the parameters of the function from large or infinite parameter space are found.
Gradient of a function at any point is the direction of steepest increase or ascent of the function at
that point.
Based on above, the gradient descent of a function at any point, thus, represent the direction of
steepest decrease or descent of function at that point.
In order to find the gradient of the function with respect to x dimension, take the derivative of
the function with respect to x , then substitute the x-coordinate of the point of interest in for the x values in
the derivative. Once gradient of the function at any point is calculated, the gradient descent can be
calculated by multiplying the gradient with -1. Here are the steps of finding minimum of the function using
gradient descent:
Calculate the gradient by taking the derivative of the function with respect to the specific
parameter. In case, there are multiple parameters, take the partial derivatives with respect to
different parameters.
Calculate the descent value for different parameters by multiplying the value of derivatives with
learning or descent rate (step size) and -1.
Update the value of parameter by adding up the existing value of parameter and the descent
value. The diagram below represents the updation of parameter [latex]\theta[/latex] with the
value of gradient in the opposite direction while taking small steps.
Gradient descent is an optimization algorithm that‘s used when training deep learning models. It‘s based on
a convex function and updates its parameters iteratively to minimize a given function to its local minimum.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
Our aim is to reach at the bottom of the graph (Cost vs weight), or to a point where we can no longer move
downhill–a local minimum.
Role of Gradient
In general, Gradient represents the slope of the equation while gradients are partial derivatives and they
describe the change reflected in the loss function with respect to the small change in parameters of the
function. Now, this slight change in loss functions can tell us about the next step to reduce the output of the
loss function.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
As we discussed, the gradient represents the direction of increase. But our aim is to find the minimum point
in the valley so we have to go in the opposite direction of the gradient. Therefore, we update parameters in
the negative gradient direction to minimize the loss.
Algorithm: θ=θ−α⋅∇J(θ)
In code, Batch Gradient Descent looks something like this:
for x in range(epochs):
params_gradient = find_gradient(loss_function, data, parameters)
parameters = parameters - learning_rate * params_gradient
Advantages of Batch Gradient Descent
Easy computation
Easy to implement
Easy to understand
Disadvantages of Batch Gradient Descent
May trap at local minima
Weights are changed after calculating the gradient on the whole dataset. So, if the dataset is too
large then this may take years to converge to the minima
Requires large memory to calculate gradient on the whole dataset
4.3.2 Stochastic Gradient Descent
To overcome some of the disadvantages of the GD algorithm, the SGD algorithm comes into the picture as
an extension of the Gradient Descent. One of the disadvantages of the Gradient Descent algorithm is that it
requires a lot of memory to load the entire dataset at a time to compute the derivative of the loss function.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
So, In the SGD algorithm, we compute the derivative by taking one data point at a time i.e, tries to update
the model‘s parameters more frequently. Therefore, the model parameters are updated after the computation
of loss on each training example.
So, let‘s have a dataset that contains 1000 rows, and when we apply SGD it will update the model
parameters 1000 times in one complete cycle of a dataset instead of one time as in Gradient Descent.
Algorithm: θ=θ−α⋅∇J (θ;x(i);y(i)) , where {x(i),y(i)} are the training examples
We want the training, even more, faster, so we take a Gradient Descent step for each training example. Let‘s
see the implications in the image below:
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
Even after achieving global minima, it may overshoots
To reach the same convergence as that of gradient descent, we need to slowly reduce the value
of the learning rate
4.3.3 Mini-Batch Gradient Descent
To overcome the problem of large time complexity in the case of the SGD algorithm. MB-GD algorithm
comes into the picture as an extension of the SGD algorithm. It‘s not all but it also overcomes the problem
of Gradient descent. Therefore, It‘s considered the best among all the variations of gradient descent
algorithms. MB-GD algorithm takes a batch of points or subset of points from the dataset to compute
derivate.
It is observed that the derivative of the loss function for MB-GD is almost the same as a derivate of the loss
function for GD after some number of iterations. But the number of iterations to achieve minima is large for
MB-GD compared to GD and the cost of computation is also large.
Therefore, the weight updation is dependent on the derivate of loss for a batch of points. The updates in the
case of MB-GD are much noisy because the derivative is not always towards minima.
It updates the model parameters after every batch. So, this algorithm divides the dataset into various batches
and after every batch, it updates the parameters.
Algorithm: θ=θ−α⋅∇J (θ; B(i)), where {B(i)} are the batches of training examples
n the code snippet, instead of iterating over examples, we now iterate over mini-batches of size 30:
for x in range(epochs):
np.random.shuffle(data)
for batch in get_batches(data, batch_size=30):
params_gradient = find_gradient(loss_function, batch, parameters)
parameters = parameters - learning_rate * params_gradient
Advantages of Mini Batch Gradient Descent
Updates the model parameters frequently and also has less variance
Requires not less or high amount of memory i.e requires a medium amount of memory
Disadvantages of Mini Batch Gradient Descent
The parameter updating in MB-SGD is much noisy compared to the weight updating in the GD
algorithm
Compared to the GD algorithm, it takes a longer time to converge
May get stuck at local minima
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
4.3.5 Challenges with all types of Gradient-based Optimizers
Optimum Learning Rate: If we choose the learning rate as a too-small value, then gradient descent may
take a very long time to converge. For more about this challenge, refer to the above section of Learning Rate
which we discussed in the Gradient Descent Algorithm.
Constant Learning Rate: For all the parameters, they have a constant learning rate but there may be some
parameters that we may not want to change at the same rate.
Local minimum: May get stuck at local minima i.e., not reach up to the local minimum.
5. Basics in Machine Learning
5.1 Need for machine learning:
Machine learning is important because it allows computers to learn from data and improve thei r
performance on specific tasks without being explicitly programmed. This ability to learn from data and
adapt to new situations makes machine learning particularly useful for tasks that involve large amounts
of data, complex decision-making, and dynamic environments.
Here are some specific areas where machine learning is being used:
Predictive modeling: Machine learning can be used to build predictive models that can help
businesses make better decisions. For example, machine learning can be used to predict which
customers are most likely to buy a particular product, or which patients are most likely to develop
a certain disease.
Natural language processing: Machine learning is used to build systems that can understand and
interpret human language. This is important for applications such as voice recognition, chatbots,
and language translation.
Computer vision: Machine learning is used to build systems that can recognize and interpret
images and videos. This is important for applications such as self-driving cars, surveillance
systems, and medical imaging.
Fraud detection: Machine learning can be used to detect fraudulent behavior in financial
transactions, online advertising, and other areas.
Recommendation systems: Machine learning can be used to build recommendation systems that
suggest products, services, or content to users based on their past behavior and preferences.
Overall, machine learning has become an essential tool for many businesses and industries, as it enables
them to make better use of data, improve their decision-making processes, and deliver more personalized
experiences to their customers.
5.2 Definition and Workflow:
Machine Learning is a branch of artificial intelligence that develops algorithms by learning the hidden
patterns of the datasets used it to make predictions on new similar type data, without being explicitly
programmed for each task.
Machine Learning works in the following manner.
Forward Pass: In the Forward Pass, the machine learning algorithm takes in input data and
produces an output. Depending on the model algorithm it computes the predictions.
Loss Function: The loss function, also known as the error or cost function, is used to evaluate the
accuracy of the predictions made by the model. The function compares the predicted output of the
model to the actual output and calculates the difference between them. This difference i s known
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
as error or loss. The goal of the model is to minimize the error or loss function by adjusting its
internal parameters.
Model Optimization Process: The model optimization process is the iterative process of adjusting
the internal parameters of the model to minimize the error or loss function. This is done using an
optimization algorithm, such as gradient descent. The optimization algorithm calculates the
gradient of the error function with respect to the model‘s parameters and uses this information to
adjust the parameters to reduce the error. The algorithm repeats this process until the error is
minimized to a satisfactory level.
Once the model has been trained and optimized on the training data, it can be used to make predictions
on new, unseen data. The accuracy of the model‘s predictions can be evaluated using various
performance metrics, such as accuracy, precision, recall, and F1-score.
5.3 Machine Learning lifecycle:
The lifecycle of a machine learning project involves a series of steps that include:
1. Study the Problems: The first step is to study the problem. This step involves understanding the
business problem and defining the objectives of the model.
2. Data Collection: When the problem is well-defined, we can collect the relevant data required for
the model. The data could come from various sources such as databases, APIs, or web scraping.
3. Data Preparation: When our problem-related data is collected. then it is a good idea to check the
data properly and make it in the desired format so that it can be used by the model to find the
hidden patterns. This can be done in the following steps:
Data cleaning
Data Transformation
Explanatory Data Analysis and Feature Engineering
Split the dataset for training and testing.
4. Model Selection: The next step is to select the appropriate machine learning algorithm that is
suitable for our problem. This step requires knowledge of the strengths and weaknesses of
different algorithms. Sometimes we use multiple models and compare their results and select the
best model as per our requirements.
5. Model building and Training: After selecting the algorithm, we have to build the model.
a. In the case of traditional machine learning building mode is easy it is just a few
hyperparameter tunings.
b. In the case of deep learning, we have to define layer-wise architecture along with input and
output size, number of nodes in each layer, loss function, gradient descent optimizer, etc.
c. After that model is trained using the preprocessed dataset.
6. Model Evaluation: Once the model is trained, it can be evaluated on the test dataset to determine
its accuracy and performance using different techniques like classification report, F1 score,
precision, recall, ROC Curve, Mean Square error, absolute error, etc.
7. Model Tuning: Based on the evaluation results, the model may need to be tuned or optimized to
improve its performance. This involves tweaking the hyperparameters of the model.
8. Deployment: Once the model is trained and tuned, it can be deployed in a production
environment to make predictions on new data. This step requires integrating the model into an
existing software system or creating a new system for the model.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
9. Monitoring and Maintenance: Finally, it is essential to monitor the model‘s performance in the
production environment and perform maintenance tasks as required. This involves monitoring for
data drift, retraining the model as needed, and updating the model as new data becomes available.
5.4 Types of Machine Learning
The types are as follows:
1. Supervised Machine Learning
2. Unsupervised Machine Learning
3. Reinforcement Machine Learning
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
5.4.2 Unsupervised Machine Learning:
Unsupervised learning is a type of machine learning where the algorithm learns to recognize patterns in
data without being explicitly trained using labeled examples. The goal of unsupervised learning is to
discover the underlying structure or distribution in the data.
There are two main types of unsupervised learning:
Clustering: Clustering algorithms group similar data points together based on their characteristics.
The goal is to identify groups, or clusters, of data points that are similar to each other, while
being distinct from other groups. Some popular clustering algorithms include K-means,
Hierarchical clustering, and DBSCAN.
Dimensionality reduction: Dimensionality reduction algorithms reduce the number of input
variables in a dataset while preserving as much of the original information as possible. This is
useful for reducing the complexity of a dataset and making it easier to visualize and analyze.
Some popular dimensionality reduction algorithms include Principal Component Analysis (PCA),
t-SNE, and Autoencoders.
5.4.3 Reinforcement Machine Learning
Reinforcement learning is a type of machine learning where an agent learns to interact with an
environment by performing actions and receiving rewards or penalties based on its actions. The goal of
reinforcement learning is to learn a policy, which is a mapping from states to actions, that maximizes the
expected cumulative reward over time.
There are two main types of reinforcement learning:
Model-based reinforcement learning: In model-based reinforcement learning, the agent learns a
model of the environment, including the transition probabilities between states and the rewards
associated with each state-action pair. The agent then uses this model to plan its actions in order
to maximize its expected reward. Some popular model-based reinforcement learning algorithms
include Value Iteration and Policy Iteration.
Model-free reinforcement learning: In model-free reinforcement learning, the agent learns a
policy directly from experience without explicitly building a model of the environment. The
agent interacts with the environment and updates its policy based on the rewards it receives.
Some popular model-free reinforcement learning algorithms include Q-Learning, SARSA, and
Deep Reinforcement Learning.
5.5 Capacity
The capacity of a network refers to the range of the types of functions that the model can approximate.
Informally, a model‘s capacity is its ability to fit a wide variety of functions. A model with less capacity
may not be able to sufficiently learn the training dataset.
A model with more capacity can model more different types of functions and may be able to learn a
function to sufficiently map inputs to outputs in the training dataset. Whereas a model with too much
capacity may memorize the training dataset and fail to generalize or get lost or stuck in the search for a
suitable mapping function. Generally, we can think of model capacity as a control over whether the model is
likely to underfit or overfit a training dataset.
The capacity of a neural network can be controlled by two aspects of the model:
Number of Nodes
Number of Layers
A model with more nodes or more layers has a greater capacity and, in turn, is potentially capable of
learning a larger set of mapping functions. A model with more layers and more hidden units per layer has
higher representational capacity; it is capable of representing more complicated functions.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
The number of nodes in a layer is referred to as the width and the number of layers in a model is referred to
as its depth. Increasing the depth increases the capacity of the model. Training deep models, e.g. those with
many hidden layers, can be computationally more efficient than training a single layer network with a vast
number of nodes.
5.6 Over-fitting and under-fitting
Over-fitting and under-fitting are two crucial concepts in machine learning and are the prevalent causes for
the poor performance of a machine learning model. In this topic we will explore over-fitting and under-
fitting in machine learning.
Over-fitting
When a model performs very well for training data but has poor performance with test data (new data), it is
known as over-fitting. In this case, the machine learning model learns the details and noise in the training
data such that it negatively affects the performance of the model on test data. Over-fitting can happen due to
low bias and high variance.
Under-fitting
When a model has not learned the patterns in the training data well and is unable to generalize well on the
new data, it is known as under-fitting. An under-fit model has poor performance on the training data and
will result in unreliable predictions. Under-fitting occurs due to high bias and low variance.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
5.7 Hyper-parameter
Hyper-parameters are defined as the parameters that are explicitly defined by the user to control the
learning process. The value of the Hyper-parameter is selected and set by the machine learning engineer
before the learning algorithm begins training the model. These parameters are tunable and can directly
affect how well a model trains. Hence, these are external to the model, and their values cannot be
changed during the training process. Some examples of hyper-parameters in machine learning:
Learning Rate
Number of Epochs
Momentum
Regularization constant
Number of branches in a decision tree
Number of clusters in a clustering algorithm (like k-means)
5.7.1 Model Parameters:
Model parameters are configuration variables that are internal to the model, and a model learns them on its
own. For example, Weights or Coefficients of dependent variables in the linear regression model.
Weights or Coefficients of independent variables in SVM, weight, and biases of a neural network,
cluster centroid in clustering. Some key points for model parameters are as follows:
They are used by the model for making predictions
They are learned by the model from the data itself
These are usually not set manually
These are the part of the model and key to a machine learning algorithm
5.7.2 Model Hyper-parameters:
Hyper-parameters are those parameters that are explicitly defined by the user to control the learning
process. Some key points for model parameters are as follows:
These are usually defined manually by the machine learning engineer.
One cannot know the exact best value for hyper-parameters for the given problem. The best value can
be determined either by the rule of thumb or by trial and error.
Some examples of Hyper-parameters are the learning rate for training a neural network, K in the
KNN algorithm
5.7.3 Difference between Model and Hyper parameters
The difference is as tabulated below.
MODEL PARAMETERS HYPER-PARAMETERS
They are required for estimating the model
They are required for making predictions
parameters
They are estimated by optimization
They are estimated by hyperparameter tuning
algorithms(Gradient Descent, Adam, Adagrad)
They are not set manually They are set manually
The choice of hyperparameters decide how
The final parameters found after training will efficient the training is. In gradient descent the
decide how the model will perform on unseen learning rate decide how efficient and accurate
data the optimization process is in estimating the
parameters
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
5.7.4 Categories of Hyper-parameters
Broadly hyper-parameters can be divided into two categories, which are given below:
Hyper-parameter for Optimization
Hyper-parameter for Specific Models
5.7.4.1 Hyper-parameter for optimization
The process of selecting the best hyper-parameters to use is known as hyper-parameter tuning, and the
tuning process is also known as hyper-parameter optimization. Optimization parameters are used for
optimizing the model.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
5.8 Validation Sets
A validation set is a set of data used to train artificial intelligence (AI) with the goal of finding and
optimizing the best model to solve a given problem. Validation sets are also known as dev sets. A
supervised AI is trained on a corpus of training data.
Training, tuning, model selection and testing are performed with three different datasets: the training set, the
validation set and the testing set. Validation sets are used to select and tune the final AI model.
Training sets make up the majority of the total data, averaging 60%. Most of the training data sets are
collected from several resources and then pre-processed and organized to provide proper performance of
the model. Type of training data sets determines the ability of the model to generalize .i.e. the better the
quality and diversity of training data sets, the better will be the performance of the model.
Validation set makes up about 20% of the bulk of data used. The validation set contrasts with training sets
and test sets is an intermediate phase used for choosing the best model and optimizing it. Validation is
sometimes considered a part of the training phase. In this phase that parameter tuning occurs for optimizing
the selected model. Over-fitting is checked and avoided in the validation set to eliminate errors that can be
caused for future predictions and observations to a specific dataset.
Testing sets make up 20% of the bulk of the data. These sets are ideal data and results with which to verify
correct operation of an AI. The test set is ensured to be the input data grouped together with verified correct
outputs, generally by human verification. This ideal set is used to test results and assess the performance of
the final model.
5.8.1 Cross Validation
Cross-validation is a technique for validating the model efficiency by training it on the subset of input data
and testing on previously unseen subset of the input data. Hence the basic steps of cross-validations are:
o Reserve a subset of the dataset as a validation set.
o Provide the training to the model using the training dataset.
o Now, evaluate model performance using the validation set. If the model performs well with the
validation set, perform the further step, else check for the issues.
5.8.2 Methods used for Cross-Validation
There are some common methods that are used for cross-validation. These methods are given below:
1. Validation Set Approach
2. Leave-P-out cross-validation
3. Leave one out cross-validation
4. K-fold cross-validation
5. Stratified k-fold cross-validation
5.8.2.1 Validation Set Approach
We divide our input dataset into a training set and test or validation set in the validation set approach. Both
the subsets are given 50% of the dataset.
But it has one of the big disadvantages that we are just using a 50% dataset to train our model, so the model
may miss out to capture important information of the dataset. It also tends to give the underfitted model.
5.8.2.2 Leave-P-out cross-validation
In this approach, the p datasets are left out of the training data. It means, if there are total n datapoints in the
original input dataset, then n-p data points will be used as the training dataset and the p data points as the
validation set. This complete process is repeated for all the samples, and the average error is calculated to
know the effectiveness of the model.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
There is a disadvantage of this technique; that is, it can be computationally difficult for the large p.
5.8.2.3 Leave one out cross-validation
This method is similar to the leave-p-out cross-validation, but instead of p, we need to take 1 dataset out of
training. It means, in this approach, for each learning set, only one datapoint is reserved, and the remaining
dataset is used to train the model. This process repeats for each datapoint. Hence for n samples, we get n
different training set and n test set. It has the following features:
In this approach, the bias is minimum as all the data points are used.
The process is executed for n times; hence execution time is high.
This approach leads to high variation in testing the effectiveness of the model as we iteratively
check against one data point.
5.8.2.4 K-Fold Cross-Validation
K-fold cross-validation approach divides the input dataset into K groups of samples of equal sizes. These
samples are called folds. For each learning set, the prediction function uses k-1 folds, and the rest of the
folds are used for the test set. This approach is a very popular CV approach because it is easy to understand,
and the output is less biased than other methods.
The steps for k-fold cross-validation are:
Split the input dataset into K groups
For each group:
Take one group as the reserve or test data set.
Use remaining groups as the training dataset
Fit the model on the training set and evaluate the performance of the model using the test set.
Let's take an example of 5-folds cross-validation. So, the dataset is grouped into 5 folds. On 1st iteration, the
first fold is reserved for test the model, and rest are used to train the model. On 2nd iteration, the second fold
is used to test the model, and rest are used to train the model. This process will continue until each fold is
not used for the test fold.
Consider the below diagram:
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
5.8.2.6 Holdout Method
This method is the simplest cross-validation technique among all. In this method, we need to remove a
subset of the training data and use it to get prediction results by training it on the rest part of the dataset.
The error that occurs in this process tells how well our model will perform with the unknown dataset.
Although this approach is simple to perform, it still faces the issue of high variance, and it also produces
misleading results sometimes.
5.8.3 Comparison of Cross-validation to train/test split in Machine Learning
Train/test split: The input data is divided into two parts, that are training set and test set on a
ratio of 70:30, 80:20, etc. It provides a high variance, which is one of the biggest disadvantages.
Training Data: The training data is used to train the model, and the dependent variable is
known.
Test Data: The test data is used to make the predictions from the model that is already trained
on the training data. This has the same features as training data but not the part of that.
Cross-Validation dataset: It is used to overcome the disadvantage of train/test split by splitting
the dataset into groups of train/test splits, and averaging the result. It can be used if we want to
optimize our model that has been trained on the training dataset for the best performance. It is
more efficient as compared to train/test split as every observation is used for the training and
testing both.
5.8.4 Limitations of Cross-Validation
There are some limitations of the cross-validation technique, which are given below:
For the ideal conditions, it provides the optimum output. But for the inconsistent data, it may
produce a drastic result. So, it is one of the big disadvantages of cross-validation, as there is no
certainty of the type of data in machine learning.
In predictive modeling, the data evolves over a period, due to which, it may face the differences
between the training set and validation sets. Such as if we create a model for the prediction of
stock market values, and the data is trained on the previous 5 years stock values, but the realistic
future values for the next 5 years may drastically different, so it is difficult to expect the correct
output for such situations.
5.8.5 Applications of Cross-Validation
This technique can be used to compare the performance of different predictive modeling
methods.
It has great scope in the medical research field.
It can also be used for the meta-analysis, as it is already being used by the data scientists in the
field of medical statistics.
5.9 Estimators
In machine learning, an estimator is an equation for picking the ―best,‖ or most likely accurate, data
model based upon observations in realty. The estimator is the formula that evaluates a given quantity and
generates an estimate. This estimate is then inserted into the deep learning classifier system to determine
what action to take. Estimation is a statistical term for finding some estimate of unknown parameter, given
somedata. Point Estimation is the attempt to provide the single best prediction of some quantity ofinterest.
Quantity of interest can be:
A single parameter
A vector of parameters — e.g., weights in linear regression
A whole function
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
Point estimator
To distinguish estimates of parameters from their true value, a point estimate of a parameter θ is represented
by θˆ. Let {x(1) , x(2) ,..x(m)} be m independent and identically distributed data points. Then a point
estimator is any function of the data:
This definition of a point estimator is very general and allows the designer of an estimator great flexibility.
While almost any function thus qualifies as an estimator, a good estimator is a function whose output is
close to the true underlying θ that generated the training data.
Point estimation can also refer to estimation of relationship between input and target variables referred to as
function estimation.
Function Estimator
Here we are trying to predict a variable y given an input vector x. We assume that there is a function f(x)
that describes the approximate relationship between y and x. For example,
we may assume that y = f(x) + ε, where ε stands for the part of y that is not predictable from x. In function
estimation, we are interested in approximating f with a model or estimate fˆ. Function estimation is really
just the same as estimating a parameter θ; the function estimator fˆ is simply a point estimator in function
space. Ex: in polynomial regression we are either estimating a parameter w or estimating a function
mapping from x to y.
5.9.1 Uses of Estimators
By quantifying guesses, estimators are how machine learning in theory is implemented in practice. Without
the ability to estimate the parameters of a dataset (such as the layers in a neural network or the bandwidth in
a kernel), there would be no way for an AI system to ―learn.‖
A simple example of estimators and estimation in practice is the so-called ―German Tank Problem‖ from
World War Two. The Allies had no way to know for sure how many tanks the Germans were building every
month. By counting the serial numbers of captured or destroyed tanks, allied statisticians created an
estimator rule. This equation calculated the maximum possible number of tanks based upon the sequential
serial numbers, and applies minimum variance analysis to generate the most likely estimate for how many
new tanks German was building.
5.9.2 Types of Estimators
Estimators come in two broad categories, point and interval. Point equations generate single value results,
such as standard deviation, that can be plugged into a deep learning algorithm‘s classifier functions. Interval
equations generate a range of likely values, such as a confidence interval, for analysis.
In addition, each estimator rule can be tailored to generate different types of estimates:
Biased: Either an overestimate or an underestimate.
Efficient: Smallest variance analysis. The smallest possible variance is referred to as the ―best‖
estimate.
Invariant: Less flexible estimates that aren‘t easily changed by data transformations.
Shrinkage: An unprocessed estimate that‘s combined with other variables to create complex
estimates.
Sufficient: Estimating the total population‘s parameter from a limited dataset.
Unbiased: An exact-match estimate value that neither underestimates nor overestimates.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
The difference between a classifier, model and estimator is as follows:
An estimator is a predictor found from regression algorithm
A classifier is a predictor found from a classification algorithm
A model can be both an estimator or a classifier
5.9.3 Bias and Variance
5.9.3.1 Errors in Machine Learning
In machine learning, an error is a measure of how accurately an algorithm can make predictions for the
previously unknown dataset. On the basis of these errors, the machine learning model is selected that can
perform best on the particular dataset. There are mainly two types of errors in machine learning, which are:
Reducible errors: These errors can be reduced to improve the model accuracy. Such errors can further be
classified into bias and Variance.
Irreducible errors: These errors will always be present in the model regardless of which algorithm has
been used. The cause of these errors is unknown variables whose value can't be reduced.
5.9.3.2 Bias
In general, a machine learning model analyses the data, find patterns in it and make predictions. While
training, the model learns these patterns in the dataset and applies them to test data for prediction. While
making predictions, a difference occurs between prediction values made by the model and actual
values/expected values, and this difference is known as bias errors or Errors due to bias. It can be
defined as an inability of machine learning algorithms such as Linear Regression to capture the true
relationship between the data points. Each algorithm begins with some amount of bias because bias occurs
from assumptions in the model, which makes the target function simple to learn. A model has either:
Low Bias: A low bias model will make fewer assumptions about the form of the target
function.
High Bias: A model with a high bias makes more assumptions, and the model becomes unable
to capture the important features of our dataset. A high bias model also cannot perform well
on new data.
Generally, a linear algorithm has a high bias, as it makes them learn fast. The simpler the algorithm, the
higher the bias it has likely to be introduced. Whereas a nonlinear algorithm often has low bias.
Some examples of machine learning algorithms with low bias are Decision Trees, k-Nearest Neighbours
and Support Vector Machines. At the same time, an algorithm with high bias is Linear Regression,
Linear Discriminant Analysis and Logistic Regression.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
Ways to reduce High Bias:
High bias mainly occurs due to a much simple model. Below are some ways to reduce the high bias:
Increase the input features as the model is under-fitted.
Decrease the regularization term.
Use more complex models, such as including some polynomial features.
5.9.3.3 Variance
The variance would specify the amount of variation in the prediction if the different training data was used.
In simple words, variance tells that how much a random variable is different from its expected
value. Ideally, a model should not vary too much from one training dataset to another, which means the
algorithm should be good in understanding the hidden mapping between inputs and output variables.
Variance errors are either of low variance or high variance.
Low variance means there is a small variation in the prediction of the target function with
changes in the training data set.
High variance shows a large variation in the prediction of the target function with changes in
the training dataset.
A model that shows high variance learns a lot and performs well with the training dataset, and does not
generalize well with the unseen dataset. As a result, such a model gives good results with the training
dataset but shows high error rates on the test dataset.
Since, with high variance, the model learns too much from the dataset, it leads to over-fitting of the model.
A model with high variance has the below problems:
A high variance model leads to over-fitting.
Increase model complexities.
Usually, nonlinear algorithms have a lot of flexibility to fit the model, have high variance.
Some examples of machine learning algorithms with low variance are, Linear Regression, Logistic
Regression, and Linear discriminant analysis. At the same time, algorithms with high variance
are decision tree, Support Vector Machine, and K-nearest neighbours.
Ways to Reduce High Variance:
Reduce the input features or number of parameters as a model is overfitted.
Do not use a much complex model.
Increase the training data.
Increase the Regularization term.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
5.9.3.4 Different Combinations of Bias-Variance
There are four possible combinations of bias and variances, which are represented by the below diagram:
1. Low-Bias, Low-Variance: The combination of low bias and low variance shows an ideal
machine learning model. However, it is not possible practically.
2. Low-Bias, High-Variance: With low bias and high variance, model predictions are
inconsistent and accurate on average. This case occurs when the model learns with a large
number of parameters and hence leads to an over-fitting
3. High-Bias, Low-Variance: With High bias and low variance, predictions are consistent but
inaccurate on average. This case occurs when a model does not learn well with the training
dataset or uses few numbers of the parameter. It leads to under-fitting problems in the model.
4. High-Bias, High-Variance: With high bias and high variance, predictions are inconsistent
and also inaccurate on average.
High variance can be identified if the model has:
Low training error and high test error.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
high variance and low bias. So, it is required to make a balance between bias and variance errors, and this
balance between the bias error and variance error is known as the Bias-Variance trade-off.
For an accurate prediction of the model, algorithms need a low variance and low bias. But this is not
possible because bias and variance are related to each other:
If we decrease the variance, it will increase the bias
If we decrease the bias, it will increase the variance
Bias-Variance trade-off is a central issue in supervised learning. Ideally, we need a model that accurately
captures the regularities in training data and simultaneously generalizes well with the unseen dataset.
Unfortunately, doing this is not possible simultaneously. Because a high variance algorithm may perform
well with training data, but it may lead to over-fitting to noisy data. Whereas, high bias algorithm generates
a much simple model that may not even capture important regularities in the data. So, we need to find a
sweet spot between bias and variance to make an optimal model.
Hence, the Bias-Variance trade-off is about finding the sweet spot to make a balance between bias and
variance errors.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
One of the main challenges of Deep Learning derived from this is being able to deliver great performances
with a lot less training data. As we will see later, recent advances like transfer learning or semi-supervised
learning are already taking steps in this direction, but still it is not enough.
2. Coping with data from outside the training distribution
Data is dynamic, it changes through different drivers like time, location, and many other conditions.
However, Machine Learning models, including Deep Learning ones, are built using a defined set of data
(the training set) and perform well as long as the data that is later used to make predictions once the system
is built comes from the same distribution as the data the system was built with.
This makes them perform poorly when data that is not entirely different, but that does have some variations
from the training data is fed to them. Another challenge of Deep Learning in the future will be to overcome
this problem, and still perform reasonably well when data that does not exactly match the training data is fed
to them.
3. Incorporating Logic
Incorporating some sort of rule based knowledge, so that logical procedures can be implemented and
sequential reasoning used to formalize knowledge.
While these cases can be covered in code, Machine Learning algorithms don‘t usually incorporate sets or
rules into their knowledge. Kind of like a prior data distribution used in Bayesian learning, sets of pre-
defined rules could assist Deep Learning systems in their reasoning and live side by side with the ‗learning
from data‘ based approach.
4. The Need for less data and higher efficiency
Although we kind of covered this in our first two sections, this point is really worth highlighting.
The success of Deep Learning comes from the possibility to incorporate many layers into our models,
allowing them to try an insane number of linear and non-linear parameter combinations. However, with
more layers comes more model complexity and we need more data for this model to function correctly.
When the amount of data that we have is effectively smaller than the complexity of the neural network then
we need to resort to a different approach like the aforementioned Transfer Learning.
Also, too big Deep Learning models, aside from needing crazy amounts of data to be trained on, use a lot of
computational resources and can take a very long while to train. Advances on the field should also be
oriented towards making the training process more efficient and cost effective
6. Deep Neural Network
Deep neural networks (DNN) is a class of machine learning algorithms similar to the artificial neural
network and aims to mimic the information processing of the brain. Deep neural networks, or deep learning
networks, have several hidden layers with millions of artificial neurons linked together. A number, called
weight, represents the connections between one node and another. The weight is a positive number if one
node excites another, or negative if one node suppresses the other.
6.1 Feed-Forward Neural Network
In its most basic form, a Feed-Forward Neural Network is a single layer perceptron. A sequence of
inputs enter the layer and are multiplied by the weights in this model. The weighted input values are then
summed together to form a total. If the sum of the values is more than a predetermined threshold, which is
normally set at zero, the output value is usually 1, and if the sum is less than the threshold, the output value
is usually -1. The single-layer perceptron is a popular feed-forward neural network model that is frequently
used for classification. Single-layer perceptrons can also contain machine learning features.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
The neural network can compare the outputs of its nodes with the desired values using a property known
as the delta rule, allowing the network to alter its weights through training to create more accurate
output values. This training and learning procedure results in gradient descent. The technique of updating
weights in multi-layered perceptrons is virtually the same, however, the process is referred to as back-
propagation. In such circumstances, the output values provided by the final layer are used to alter each
hidden layer inside the network.
6.1.1 Work Strategy
The function of each neuron in the network is similar to that of linear regression. The neuron also has
an activation function at the end, and each neuron has its weight vector.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
What if activation functions were not used in neural networks?
Suppose if neural networks didn‘t have an activation function, they‘d just be a huge linear unit that a single
linear regression model could easily replace.
a = m*x + d
Z= k*a + t => k*(m*x+d) + t => k*m*x + k*d + t => (k*m)*x + (k*c+t)
6.1.3 Applications of the Feed Forward Neural Networks
A Feed Forward Neural Network is an artificial neural network in which the nodes are connected
circularly. A feed-forward neural network, in which some routes are cycled, is the polar opposite of a
recurrent neural network. The feed-forward model is the simplest type of neural network because the input
is only processed in one direction. The data always flows in one direction and never backwards, regardless
of how many buried nodes it passes through.
6.2 Regularization in Machine Learning
Regularization is one of the most important concepts of machine learning. It is a technique to prevent the
model from overfitting by adding extra information to it.
Sometimes the machine learning model performs well with the training data but does not perform well with
the test data. It means the model is not able to predict the output when deals with unseen data by introducing
noise in the output, and hence the model is called overfitted. This problem can be deal with the help of a
regularization technique.
This technique can be used in such a way that it will allow to maintain all variables or features in the model
by reducing the magnitude of the variables. Hence, it maintains accuracy as well as a generalization of the
model.
It mainly regularizes or reduces the coefficient of features toward zero. In simple words, "In regularization
technique, we reduce the magnitude of the features by keeping the same number of features."
How does Regularization Work?
Regularization works by adding a penalty or complexity term to the complex model. Let's consider the
simple linear regression equation:
y= β0+β1x1+β2x2+β3x3+⋯+βnxn +b
In the above equation, Y represents the value to be predicted
X1, X2, …Xn are the features for Y.
β0,β1,…..βn are the weights or magnitude attached to the features, respectively. Here represents the bias of
the model, and b represents the intercept.
Linear regression models try to optimize the β0 and b to minimize the cost function. The equation for the
cost function for the linear model is given below:
Now, we will add a loss function and optimize parameter to make the model that can predict the accurate
value of Y. The loss function for the linear regression is called as RSS or Residual sum of squares.
Techniques of Regularization
There are mainly two types of regularization techniques, which are given below:
o Ridge Regression
o Lasso Regression
6.2.1 Ridge Regression
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
Ridge regression is one of the types of linear regression in which a small amount of bias is introduced so
that we can get better long-term predictions.
Ridge regression is a regularization technique, which is used to reduce the complexity of the model. It is
also called as L2 regularization.
In this technique, the cost function is altered by adding the penalty term to it. The amount of bias added to
the model is called Ridge Regression penalty. We can calculate it by multiplying with the lambda to the
squared weight of each individual feature.
The equation for the cost function in ridge regression will be:
In the above equation, the penalty term regularizes the coefficients of the model, and hence ridge regression
reduces the amplitudes of the coefficients that decreases the complexity of the model.
As we can see from the above equation, if the values of λ tend to zero, the equation becomes the cost
function of the linear regression model. Hence, for the minimum value of λ, the model will resemble the
linear regression model.
A general linear or polynomial regression will fail if there is high collinearity between the independent
variables, so to solve such problems, Ridge regression can be used.
It helps to solve the problems if we have more parameters than samples.
6.2.2 Lasso Regression
Lasso regression is another regularization technique to reduce the complexity of the model. It stands
for Least Absolute and Selection Operator.
It is similar to the Ridge Regression except that the penalty term contains only the absolute weights instead
of a square of weights.
Since it takes absolute values, hence, it can shrink the slope to 0, whereas Ridge Regression can only shrink
it near to 0.
It is also called as L1 regularization. The equation for the cost function of Lasso regression will be:
Some of the features in this technique are completely neglected for model evaluation.
Hence, the Lasso regression can help us to reduce the overfitting in the model as well as the feature
selection.
Key Difference between Ridge Regression and Lasso Regression
Ridge regression is mostly used to reduce the overfitting in the model, and it includes all the features
present in the model. It reduces the complexity of the model by shrinking the coefficients.
Lasso regression helps to reduce the overfitting in the model as well as feature selection.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
6.3 Optimization in Machine Learning
In machine learning, optimization is the procedure of identifying the ideal set of model parameters that
minimize a loss function. For a particular set of inputs, the loss function calculates the discrepancy between
the predicted and actual outputs. For the model to successfully forecast the output for fresh inputs,
optimization seeks to minimize the loss function.
A method for finding a function's minimum or maximum is called an optimization algorithm, which is used
in optimization. Up until the minimum or maximum of the loss function is reached, the optimization
algorithm iteratively modifies the model parameters. Gradient descent, stochastic gradient descent, Adam,
Adagrad, and RMSProp are a few optimization methods that can be utilised in machine learning.
Gradient Descent
In machine learning, gradient descent is a popular optimization approach. It is a first-order
optimization algorithm that works by repeatedly changing the model's parameters in the opposite
direction of the loss function's negative gradient. The loss function lowers most quickly in that
direction because the negative gradient leads in the direction of the greatest descent.
The gradient descent algorithm operates by computing the gradient of the loss function with respect
to each parameter starting with an initial set of parameters. The partial derivatives of the loss
function with respect to each parameter are contained in a vector known as the gradient. After that,
the algorithm modifies the parameters by deducting a small multiple of the gradient from their
existing values.
Stochastic Gradient Descent
A part of the training data is randomly chosen for each iteration of the stochastic gradient descent
process, which is a variant on the gradient descent technique. This makes the algorithm's
computations simpler and speeds up its convergence. For big datasets when it is not practical to
compute the gradient of the loss function for all of the training data, stochastic gradient descent is
especially helpful.
The primary distinction between stochastic gradient descent and gradient descent is that stochastic
gradient descent changes the parameters based on the gradient obtained for a single example rather
than the full dataset. Due to the stochasticity introduced by this, each iteration of the algorithm may
result in a different local minimum.
Adam
Adam is an optimization algorithm that combines the advantages of momentum-based techniques
and stochastic gradient descent. The learning rate during training is adaptively adjusted using the
first and second moments of the gradient. Adam is frequently used in deep learning since it is known
to converge more quickly than other optimization techniques.
Adagrad
An optimization algorithm called Adagrad adjusts the learning rate for each parameter based on
previous gradient data. It is especially beneficial for sparse datasets with sporadic occurrences of
specific attributes. Adagrad can converge more quickly than other optimization methods because it
uses separate learning rates for each parameter.
RMSProp
An optimization method called RMSProp deals with the issue of deep neural network gradients that
vanish and explode. It employs the moving average of the squared gradient to normalize the learning
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
lOMoARcPSD|45374298
www.BrainKart.com
rate for each parameter. Popular deep learning optimization algorithm RMSProp is well known for
converging more quickly than some other optimization algorithms.
6.3.1 Importance of Optimization in Machine Learning
Machine learning depends heavily on optimization since it gives the model the ability to learn from data
and generate precise predictions. Model parameters are estimated using machine learning techniques using
the observed data. Finding the parameters' ideal values to minimize the discrepancy between the predicted
and actual results for a given set of inputs is the process of optimization. Without optimization, the model's
parameters would be chosen at random, making it impossible to correctly forecast the outcome for brand-
new inputs.
Optimization is highly valued in deep learning models, which have multiple levels of layers and millions of
parameters. Deep neural networks need a lot of data to be trained, and optimizing the parameters of the
model in which they are used requires a lot of processing power. The optimization algorithm chosen can
have a big impact on the training process's accuracy and speed.
New machine learning algorithms are also implemented solely through optimization. Researchers are
constantly looking for novel optimization techniques to boost the accuracy and speed of machine learning
systems. These techniques include normalization, optimization strategies that account for knowledge of the
underlying structure of the data, and adaptive learning rates.
6.3.2Challenges in Optimization
There are difficulties with machine learning optimization. One of the most difficult issues is overfitting,
which happens when the model learns the training data too well and is unable to generalize to new data.
When the model is overly intricate or the training set is insufficient, overfitting might happen.
When the optimization process converges to a local minimum rather than the global optimum, it poses the
problem of local minima, which is another obstacle in optimization. Deep neural networks, which contain
many parameters and may have multiple local minima, are highly prone to local minima.
https://play.google.com/store/apps/details?id=info.therithal.brainkart.annauniversitynotes
Click on Subject/Paper under Semester to enter.
Professional English Discrete Mathematics Environmental Sciences
Professional English - - II - HS3252 - MA3354 and Sustainability -
I - HS3152 GE3451
Digital Principles and
Statistics and Probability and
Computer Organization
Matrices and Calculus Numerical Methods - Statistics - MA3391
- CS3351
- MA3151 MA3251
3rd Semester
1st Semester
4th Semester
2nd Semester
Deep Learning -
AD3501
Embedded Systems
Data and Information Human Values and
and IoT - CS3691
5th Semester
7th Semester
8th Semester
Open Elective-1
Distributed Computing Open Elective 2
- CS3551 Project Work /
Elective-3
Open Elective 3 Intership
Big Data Analytics - Elective-4
CCS334 Open Elective 4
Elective-5
Elective 1 Management Elective
Elective-6
Elective 2
All Computer Engg Subjects - [ B.E., M.E., ] (Click on Subjects to enter)
Programming in C Computer Networks Operating Systems
Programming and Data Programming and Data Problem Solving and Python
Structures I Structure II Programming
Database Management Systems Computer Architecture Analog and Digital
Communication
Design and Analysis of Microprocessors and Object Oriented Analysis
Algorithms Microcontrollers and Design
Software Engineering Discrete Mathematics Internet Programming
Theory of Computation Computer Graphics Distributed Systems
Mobile Computing Compiler Design Digital Signal Processing
Artificial Intelligence Software Testing Grid and Cloud Computing
Data Ware Housing and Data Cryptography and Resource Management
Mining Network Security Techniques
Service Oriented Architecture Embedded and Real Time Multi - Core Architectures
Systems and Programming
Probability and Queueing Theory Physics for Information Transforms and Partial
Science Differential Equations
Technical English Engineering Physics Engineering Chemistry
Engineering Graphics Total Quality Professional Ethics in
Management Engineering
Basic Electrical and Electronics Problem Solving and Environmental Science and
and Measurement Engineering Python Programming Engineering