You are on page 1of 162

CSC 411: Lecture 10: Neural Networks I

Richard Zemel, Raquel Urtasun and Sanja Fidler

University of Toronto

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 1 / 62


Today

Multi-layer Perceptron
Forward propagation
Backward propagation

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 2 / 62


Motivating Examples

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 3 / 62


Are You Excited about Deep Learning?

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 4 / 62


Limitations of Linear Classifiers

Linear classifiers (e.g., logistic regression) classify inputs based on linear


combinations of features xi

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 5 / 62


Limitations of Linear Classifiers

Linear classifiers (e.g., logistic regression) classify inputs based on linear


combinations of features xi
Many decisions involve non-linear functions of the input

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 5 / 62


Limitations of Linear Classifiers

Linear classifiers (e.g., logistic regression) classify inputs based on linear


combinations of features xi
Many decisions involve non-linear functions of the input
Canonical example: do 2 input elements have the same value?

0,1 1,1

outpu
t
outpu =1
t =0

0,0 1,0

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 5 / 62


Limitations of Linear Classifiers

Linear classifiers (e.g., logistic regression) classify inputs based on linear


combinations of features xi
Many decisions involve non-linear functions of the input
Canonical example: do 2 input elements have the same value?

0,1 1,1

outpu
t
outpu =1
t =0

0,0 1,0

The positive and negative cases cannot be separated by a plane

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 5 / 62


Limitations of Linear Classifiers

Linear classifiers (e.g., logistic regression) classify inputs based on linear


combinations of features xi
Many decisions involve non-linear functions of the input
Canonical example: do 2 input elements have the same value?

0,1 1,1

outpu
t
outpu =1
t =0

0,0 1,0

The positive and negative cases cannot be separated by a plane


What can we do?
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 5 / 62
How to Construct Nonlinear Classifiers?

We would like to construct non-linear discriminative classifiers that utilize


functions of input variables

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 6 / 62


How to Construct Nonlinear Classifiers?

We would like to construct non-linear discriminative classifiers that utilize


functions of input variables
Use a large number of simpler functions

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 6 / 62


How to Construct Nonlinear Classifiers?

We would like to construct non-linear discriminative classifiers that utilize


functions of input variables
Use a large number of simpler functions
I If these functions are fixed (Gaussian, sigmoid, polynomial basis
functions), then optimization still involves linear combinations of (fixed
functions of) the inputs

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 6 / 62


How to Construct Nonlinear Classifiers?

We would like to construct non-linear discriminative classifiers that utilize


functions of input variables
Use a large number of simpler functions
I If these functions are fixed (Gaussian, sigmoid, polynomial basis
functions), then optimization still involves linear combinations of (fixed
functions of) the inputs
I Or we can make these functions depend on additional parameters →
need an efficient method of training extra parameters

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 6 / 62


Inspiration: The Brain

Many machine learning methods inspired by biology, e.g., the (human) brain
Our brain has ∼ 1011 neurons, each of which communicates (is connected)
to ∼ 104 other neurons

Figure : The basic computational unit of the brain: Neuron

[Pic credit: http://cs231n.github.io/neural-networks-1/]


Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 7 / 62
Mathematical Model of a Neuron
Neural networks define functions of the inputs (hidden features), computed
by neurons
Artificial neurons are called units

Figure : A mathematical model of the neuron in a neural network

[Pic credit: http://cs231n.github.io/neural-networks-1/]


Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 8 / 62
Activation Functions

Most commonly used activation functions:

1
Sigmoid: σ(z) = 1+exp(−z)

exp(z)−exp(−z)
Tanh: tanh(z) = exp(z)+exp(−z)

ReLU (Rectified Linear Unit): ReLU(z) = max(0, z)

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 9 / 62


Neuron in Python

Example in Python of a neuron with a sigmoid activation function

Figure : Example code for computing the activation of a single neuron

[http://cs231n.github.io/neural-networks-1/]

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 10 / 62


Neural Network Architecture (Multi-Layer Perceptron)

Network with one layer of four hidden units:

output units

input units
Figure : Two different visualizations of a 2-layer neural network. In this example: 3
input units, 4 hidden units and 2 output units

Each unit computes its value based on linear combination of values of units
that point into it, and an activation function

[http://cs231n.github.io/neural-networks-1/]

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 11 / 62


Neural Network Architecture (Multi-Layer Perceptron)
Network with one layer of four hidden units:

output units

input units
Figure : Two different visualizations of a 2-layer neural network. In this example: 3
input units, 4 hidden units and 2 output units

Naming conventions; a 2-layer neural network:


I One layer of hidden units
I One output layer

(we do not count the inputs as a layer)


[http://cs231n.github.io/neural-networks-1/]
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 12 / 62
Neural Network Architecture (Multi-Layer Perceptron)

Going deeper: a 3-layer neural network with two layers of hidden units

Figure : A 3-layer neural net with 3 input units, 4 hidden units in the first and second
hidden layer and 1 output unit

Naming conventions; a N-layer neural network:


I N − 1 layers of hidden units
I One output layer

[http://cs231n.github.io/neural-networks-1/]
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 13 / 62
Representational Power
Neural network with at least one hidden layer is a universal approximator
(can represent any function).
Proof in: Approximation by Superpositions of Sigmoidal Function, Cybenko, paper

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 14 / 62


Representational Power
Neural network with at least one hidden layer is a universal approximator
(can represent any function).
Proof in: Approximation by Superpositions of Sigmoidal Function, Cybenko, paper

The capacity of the network increases with more hidden units and more
hidden layers

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 14 / 62


Representational Power
Neural network with at least one hidden layer is a universal approximator
(can represent any function).
Proof in: Approximation by Superpositions of Sigmoidal Function, Cybenko, paper

The capacity of the network increases with more hidden units and more
hidden layers
Why go deeper? Read e.g.,: Do Deep Nets Really Need to be Deep? Jimmy Ba,
Rich Caruana, Paper: paper]
[http://cs231n.github.io/neural-networks-1/]
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 14 / 62
Neural Networks

We only need to know two algorithms


I Forward pass: performs inference
I Backward pass: performs learning

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 15 / 62


Forward Pass: What does the Network Compute?

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 16 / 62


Forward Pass: What does the Network Compute?

Output of the network can be written as:


D
X
hj (x) = f (vj0 + xi vji )
i=1

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 16 / 62


Forward Pass: What does the Network Compute?

Output of the network can be written as:


D
X
hj (x) = f (vj0 + xi vji )
i=1
J
X
ok (x) = g (wk0 + hj (x)wkj )
j=1

(j indexing hidden units, k indexing the output units, D number of inputs)

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 16 / 62


Forward Pass: What does the Network Compute?

Output of the network can be written as:


D
X
hj (x) = f (vj0 + xi vji )
i=1
J
X
ok (x) = g (wk0 + hj (x)wkj )
j=1

(j indexing hidden units, k indexing the output units, D number of inputs)


Activation functions f , g : sigmoid/logistic, tanh, or rectified linear (ReLU)
1 exp(z) − exp(−z)
σ(z) = , tanh(z) = , ReLU(z) = max(0, z)
1 + exp(−z) exp(z) + exp(−z)

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 16 / 62


Forward Pass in Python
Example code for a forward pass for a 3-layer network in Python:

Can be implemented efficiently using matrix operations

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 17 / 62


Forward Pass in Python
Example code for a forward pass for a 3-layer network in Python:

Can be implemented efficiently using matrix operations


Example above: W1 is matrix of size 4 × 3, W2 is 4 × 4. What about biases
and W3 ?
[http://cs231n.github.io/neural-networks-1/]
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 17 / 62
Special Case
What is a single layer (no hiddens) network with a sigmoid act. function?

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 18 / 62


Special Case
What is a single layer (no hiddens) network with a sigmoid act. function?

Network: 1
ok (x) =
1 + exp(−zk )
J
X
zk = wk0 + xj wkj
j=1

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 18 / 62


Special Case
What is a single layer (no hiddens) network with a sigmoid act. function?

Network: 1
ok (x) =
1 + exp(−zk )
J
X
zk = wk0 + xj wkj
j=1

Logistic regression!
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 18 / 62
Example Application

Classify image of handwritten digit (32x32 pixels): 4 vs non-4

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 19 / 62


Example Application

Classify image of handwritten digit (32x32 pixels): 4 vs non-4

How would you build your network?

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 19 / 62


Example Application

Classify image of handwritten digit (32x32 pixels): 4 vs non-4

How would you build your network?


For example, use one hidden layer and the sigmoid activation function:
1
ok (x) =
1 + exp(−zk )
J
X
zk = wk0 + hj (x)wkj
j=1

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 19 / 62


Example Application

Classify image of handwritten digit (32x32 pixels): 4 vs non-4

How would you build your network?


For example, use one hidden layer and the sigmoid activation function:
1
ok (x) =
1 + exp(−zk )
J
X
zk = wk0 + hj (x)wkj
j=1

How can we train the network, that is, adjust all the parameters w?

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 19 / 62


Training Neural Networks

Find weights:
N
X
w∗ = argmin loss(o(n) , t(n) )
w
n=1

where o = f (x; w) is the output of a neural network

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 20 / 62


Training Neural Networks

Find weights:
N
X
w∗ = argmin loss(o(n) , t(n) )
w
n=1

where o = f (x; w) is the output of a neural network


Define a loss function, eg:
P 1 (n) (n) 2
k 2 (ok − tk )
I Squared loss:
P (n) (n)
I Cross-entropy loss: −
k tk log ok

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 20 / 62


Training Neural Networks

Find weights:
N
X
w∗ = argmin loss(o(n) , t(n) )
w
n=1

where o = f (x; w) is the output of a neural network


Define a loss function, eg:
P 1 (n) (n) 2
k 2 (ok − tk )
I Squared loss:
P (n) (n)
I Cross-entropy loss: −
k tk log ok

Gradient descent:
∂E
wt+1 = wt − η
∂wt
where η is the learning rate (and E is error/loss)

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 20 / 62


Useful Derivatives

name function derivative


1
Sigmoid σ(z) = 1+exp(−z) σ(z) · (1 − σ(z))
exp(z)−exp(−z)
Tanh tanh(z) = exp(z)+exp(−z) 1/ cosh2 (z)
(
1, if z > 0
ReLU ReLU(z) = max(0, z)
0, if z ≤ 0

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 21 / 62


Training Neural Networks: Back-propagation

Back-propagation: an efficient method for computing gradients needed to


perform gradient-based optimization of the weights in a multi-layer network

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 22 / 62


Training Neural Networks: Back-propagation

Back-propagation: an efficient method for computing gradients needed to


perform gradient-based optimization of the weights in a multi-layer network

Training neural nets:


Loop until convergence:
I for each example n
1. Given input x(n) , propagate activity forward (x(n) → h(n) → o (n) )
(forward pass)
2. Propagate gradients backward (backward pass)
3. Update each weight (via gradient descent)

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 22 / 62


Training Neural Networks: Back-propagation

Back-propagation: an efficient method for computing gradients needed to


perform gradient-based optimization of the weights in a multi-layer network

Training neural nets:


Loop until convergence:
I for each example n
1. Given input x(n) , propagate activity forward (x(n) → h(n) → o (n) )
(forward pass)
2. Propagate gradients backward (backward pass)
3. Update each weight (via gradient descent)

Given any error function E, activation functions g () and f (), just need to
derive gradients

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 22 / 62


Key Idea behind Backpropagation

We don’t have targets for a hidden unit, but we can compute how fast the
error changes as we change its activity

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 23 / 62


Key Idea behind Backpropagation

We don’t have targets for a hidden unit, but we can compute how fast the
error changes as we change its activity
I Instead of using desired activities to train the hidden units, use error
derivatives w.r.t. hidden activities

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 23 / 62


Key Idea behind Backpropagation

We don’t have targets for a hidden unit, but we can compute how fast the
error changes as we change its activity
I Instead of using desired activities to train the hidden units, use error
derivatives w.r.t. hidden activities
I Each hidden activity can affect many output units and can therefore
have many separate effects on the error. These effects must be
combined

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 23 / 62


Key Idea behind Backpropagation

We don’t have targets for a hidden unit, but we can compute how fast the
error changes as we change its activity
I Instead of using desired activities to train the hidden units, use error
derivatives w.r.t. hidden activities
I Each hidden activity can affect many output units and can therefore
have many separate effects on the error. These effects must be
combined
I We can compute error derivatives for all the hidden units efficiently

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 23 / 62


Key Idea behind Backpropagation

We don’t have targets for a hidden unit, but we can compute how fast the
error changes as we change its activity
I Instead of using desired activities to train the hidden units, use error
derivatives w.r.t. hidden activities
I Each hidden activity can affect many output units and can therefore
have many separate effects on the error. These effects must be
combined
I We can compute error derivatives for all the hidden units efficiently
I Once we have the error derivatives for the hidden activities, its easy to
get the error derivatives for the weights going into a hidden unit

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 23 / 62


Key Idea behind Backpropagation

We don’t have targets for a hidden unit, but we can compute how fast the
error changes as we change its activity
I Instead of using desired activities to train the hidden units, use error
derivatives w.r.t. hidden activities
I Each hidden activity can affect many output units and can therefore
have many separate effects on the error. These effects must be
combined
I We can compute error derivatives for all the hidden units efficiently
I Once we have the error derivatives for the hidden activities, its easy to
get the error derivatives for the weights going into a hidden unit
This is just the chain rule!

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 23 / 62


Computing Gradients: Single Layer Network
Let’s take a single layer network

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 24 / 62


Computing Gradients: Single Layer Network
Let’s take a single layer network and draw it a bit differently

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 24 / 62


Computing Gradients: Single Layer Network

Error gradients for single layer network:


∂E
=
∂wki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 25 / 62


Computing Gradients: Single Layer Network

Error gradients for single layer network:


∂E ∂E ∂ok ∂zk
=
∂wki ∂ok ∂zk ∂wki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 25 / 62


Computing Gradients: Single Layer Network

Error gradients for single layer network:


∂E ∂E ∂ok ∂zk
=
∂wki ∂ok ∂zk ∂wki

Error gradient is computable for any continuous activation function g (), and
any continuous error function
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 25 / 62
Computing Gradients: Single Layer Network

Error gradients for single layer network:

∂E ∂E ∂ok ∂zk
=
∂wki ∂ok ∂zk ∂wki
|{z}
δko

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 26 / 62


Computing Gradients: Single Layer Network

Error gradients for single layer network:

∂E ∂E ∂ok ∂zk ∂ok ∂zk


= = δko
∂wki ∂ok ∂zk ∂wki ∂zk ∂wki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 27 / 62


Computing Gradients: Single Layer Network

Error gradients for single layer network:

∂E ∂E ∂ok ∂zk ∂ok ∂zk


= = δko ·
∂wki ∂ok ∂zk ∂wki ∂z ∂wki
| {z k}
δkz

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 28 / 62


Computing Gradients: Single Layer Network

Error gradients for single layer network:

∂E ∂E ∂ok ∂zk ∂zk


= = δkz = δkz · xi
∂wki ∂ok ∂zk ∂wki ∂wki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 29 / 62


Gradient Descent for Single Layer Network
Assuming the error function is mean-squared error (MSE), on a single
training example n, we have
∂E (n) (n)
(n)
= ok − tk := δko
∂ok

Using logistic activation functions:

g (zk ) = (1 + exp(−zk ))−1


(n) (n) (n)
ok =
(n)
∂ok (n) (n)
(n)
= ok (1 − ok )
∂zk

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 30 / 62


Gradient Descent for Single Layer Network
Assuming the error function is mean-squared error (MSE), on a single
training example n, we have
∂E (n) (n)
(n)
= ok − tk := δko
∂ok

Using logistic activation functions:

g (zk ) = (1 + exp(−zk ))−1


(n) (n) (n)
ok =
(n)
∂ok (n) (n)
(n)
= ok (1 − ok )
∂zk

The error gradient is then:


∂E
=
∂wki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 30 / 62


Gradient Descent for Single Layer Network
Assuming the error function is mean-squared error (MSE), on a single
training example n, we have
∂E (n) (n)
(n)
= ok − tk := δko
∂ok

Using logistic activation functions:

g (zk ) = (1 + exp(−zk ))−1


(n) (n) (n)
ok =
(n)
∂ok (n) (n)
(n)
= ok (1 − ok )
∂zk

The error gradient is then:


N (n) (n)
∂E X ∂E ∂ok ∂zk
= (n) (n) ∂w
=
∂wki n=1 ∂ok ∂zk
ki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 30 / 62


Gradient Descent for Single Layer Network
Assuming the error function is mean-squared error (MSE), on a single
training example n, we have
∂E (n) (n)
(n)
= ok − tk := δko
∂ok

Using logistic activation functions:

g (zk ) = (1 + exp(−zk ))−1


(n) (n) (n)
ok =
(n)
∂ok (n) (n)
(n)
= ok (1 − ok )
∂zk

The error gradient is then:


N (n) (n) N
∂E X ∂E ∂ok ∂zk X (n) (n) (n) (n) (n)
= (n) (n) ∂w
= (ok − tk )ok (1 − ok )xi
∂wki n=1 ∂o ∂z ki
n=1
k k

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 30 / 62


Gradient Descent for Single Layer Network
Assuming the error function is mean-squared error (MSE), on a single
training example n, we have
∂E (n) (n)
(n)
= ok − tk := δko
∂ok

Using logistic activation functions:

g (zk ) = (1 + exp(−zk ))−1


(n) (n) (n)
ok =
(n)
∂ok (n) (n)
(n)
= ok (1 − ok )
∂zk

The error gradient is then:


N (n) (n) N
∂E X ∂E ∂ok ∂zk X (n) (n) (n) (n) (n)
= (n) (n) ∂w
= (ok − tk )ok (1 − ok )xi
∂wki n=1 ∂o ∂z ki
n=1
k k

The gradient descent update rule is given by:


∂E
wki ← wki − η =
∂wki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 30 / 62


Gradient Descent for Single Layer Network
Assuming the error function is mean-squared error (MSE), on a single
training example n, we have
∂E (n) (n)
(n)
= ok − tk := δko
∂ok

Using logistic activation functions:

g (zk ) = (1 + exp(−zk ))−1


(n) (n) (n)
ok =
(n)
∂ok (n) (n)
(n)
= ok (1 − ok )
∂zk

The error gradient is then:


N (n) (n) N
∂E X ∂E ∂ok ∂zk X (n) (n) (n) (n) (n)
= (n) (n) ∂w
= (ok − tk )ok (1 − ok )xi
∂wki n=1 ∂o ∂z ki
n=1
k k

The gradient descent update rule is given by:


N
∂E X (n) (n) (n) (n) (n)
wki ← wki − η = wki − η (ok − tk )ok (1 − ok )xi
∂wki n=1

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 30 / 62


Multi-layer Neural Network

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 31 / 62


Back-propagation: Sketch on One Training Case

Convert discrepancy between each output and its target value into an error
derivative
1X ∂E
E= (ok − tk )2 ; = ok − tk
2 ∂ok
k

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 32 / 62


Back-propagation: Sketch on One Training Case

Convert discrepancy between each output and its target value into an error
derivative
1X ∂E
E= (ok − tk )2 ; = ok − tk
2 ∂ok
k

Compute error derivatives in each hidden layer from error derivatives in layer
above. [assign blame for error at k to each unit j according to its influence
on k (depends on wkj )]

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 32 / 62


Back-propagation: Sketch on One Training Case

Convert discrepancy between each output and its target value into an error
derivative
1X ∂E
E= (ok − tk )2 ; = ok − tk
2 ∂ok
k

Compute error derivatives in each hidden layer from error derivatives in layer
above. [assign blame for error at k to each unit j according to its influence
on k (depends on wkj )]

Use error derivatives w.r.t. activities to get error derivatives w.r.t. the
weights.
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 32 / 62
Gradient Descent for Multi-layer Network

The output weight gradients for a


multi-layer network are the same as for a
single layer network
N
X ∂E ∂o ∂z (n) (n) N
∂E k k
X z,(n) (n)
= (n) (n)
= δk hj
∂wkj n=1 ∂ok ∂zk
∂wkj n=1

where δk is the error w.r.t. the net input


for unit k

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 33 / 62


Gradient Descent for Multi-layer Network

The output weight gradients for a


multi-layer network are the same as for a
single layer network
N
X ∂E ∂o ∂z (n) (n) N
∂E k k
X z,(n) (n)
= (n) (n)
= δk hj
∂wkj n=1 ∂ok ∂zk
∂wkj n=1

where δk is the error w.r.t. the net input


for unit k

Hidden weight gradients are then computed via back-prop:


∂E
(n)
=
∂hj

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 33 / 62


Gradient Descent for Multi-layer Network

The output weight gradients for a


multi-layer network are the same as for a
single layer network
N
X ∂E ∂o ∂z (n) (n) N
∂E k k
X z,(n) (n)
= (n) (n) ∂w
= δk hj
∂wkj n=1 ∂ok ∂zk
kj
n=1

where δk is the error w.r.t. the net input


for unit k

Hidden weight gradients are then computed via back-prop:

∂E X ∂E ∂o (n) ∂z (n)
k k
(n)
= (n) (n) (n)
=
∂hj k ∂ok ∂zk ∂hj

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 34 / 62


Gradient Descent for Multi-layer Network

The output weight gradients for a


multi-layer network are the same as for a
single layer network
N
X ∂E ∂o ∂z (n) (n) N
∂E k k
X z,(n) (n)
= (n) (n) ∂w
= δk hj
∂wkj n=1 ∂ok ∂zk
kj
n=1

where δk is the error w.r.t. the net input


for unit k

Hidden weight gradients are then computed via back-prop:

∂E X ∂E ∂o (n) ∂z (n) X z,(n) h,(n)


k k
(n)
= (n) (n) (n)
= δk wkj := δj
∂hj k ∂ok ∂zk ∂hj k

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 34 / 62


Gradient Descent for Multi-layer Network
The output weight gradients for a
multi-layer network are the same as for a
single layer network
N
X ∂E ∂o ∂z (n) (n) N
∂E k k
X z,(n) (n)
= (n) (n) ∂w
= δk hj
∂wkj n=1 ∂ok ∂zk
kj
n=1

where δk is the error w.r.t. the net input


for unit k

Hidden weight gradients are then computed via back-prop:

∂E X ∂E ∂o (n) ∂z (n) X z,(n) h,(n)


k k
(n)
= (n) (n) (n)
= δk wkj := δj
∂hj k ∂ok ∂zk ∂hj k

N (n) (n)
∂E X ∂E ∂hj ∂uj
= (n) (n)
=
∂vji n=1 ∂hj ∂uj ∂vji

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 35 / 62


Gradient Descent for Multi-layer Network
The output weight gradients for a
multi-layer network are the same as for a
single layer network
N
X ∂E ∂o ∂z (n) (n) N
∂E k k
X z,(n) (n)
= (n) (n) ∂w
= δk hj
∂wkj n=1 ∂ok ∂zk
kj
n=1

where δk is the error w.r.t. the net input


for unit k

Hidden weight gradients are then computed via back-prop:

∂E X ∂E ∂o (n) ∂z (n) X z,(n) h,(n)


k k
(n)
= (n) (n) (n)
= δk wkj := δj
∂hj k ∂ok ∂zk ∂hj k

N (n) (n) N (n)


∂E X ∂E ∂hj ∂uj X h,(n) 0 (n) ∂uj
= (n) (n)
= δj f (uj ) =
∂vji n=1 ∂hj ∂uj ∂vji n=1
∂vji

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 35 / 62


Gradient Descent for Multi-layer Network
The output weight gradients for a
multi-layer network are the same as for a
single layer network
N
X ∂E ∂o ∂z (n) (n) N
∂E k k
X z,(n) (n)
= (n) (n) ∂w
= δk hj
∂wkj n=1 ∂ok ∂zk
kj
n=1

where δk is the error w.r.t. the net input


for unit k

Hidden weight gradients are then computed via back-prop:

∂E X ∂E ∂o (n) ∂z (n) X z,(n) h,(n)


k k
(n)
= (n) (n) (n)
= δk wkj := δj
∂hj k ∂ok ∂zk ∂hj k

N (n)
N (n) N (n)
∂E X ∂E ∂hj ∂uj X h,(n) 0 (n) ∂uj
X u,(n) (n)
= (n) (n)
= δj f (uj ) = δj xi
∂vji n=1 ∂hj ∂uj ∂vji n=1
∂vji n=1

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 36 / 62


Choosing Activation and Loss Functions
When using a neural network for regression, sigmoid activation and MSE as
the loss function work well

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 37 / 62


Choosing Activation and Loss Functions
When using a neural network for regression, sigmoid activation and MSE as
the loss function work well
For classification, if it is a binary (2-class) problem, then cross-entropy error
function often does better (as we saw with logistic regression)
N
X
E =− t (n) log o (n) + (1 − t (n) ) log(1 − o (n) )
n=1

o (n) = (1 + exp(−z (n) )−1

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 37 / 62


Choosing Activation and Loss Functions
When using a neural network for regression, sigmoid activation and MSE as
the loss function work well
For classification, if it is a binary (2-class) problem, then cross-entropy error
function often does better (as we saw with logistic regression)
N
X
E =− t (n) log o (n) + (1 − t (n) ) log(1 − o (n) )
n=1

o (n) = (1 + exp(−z (n) )−1

We can then compute via the chain rule


∂E
= (o − t)/(o(1 − o))
∂o
∂o
= o(1 − o)
∂z
∂E ∂E ∂o
= = (o − t)
∂z ∂o ∂z
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 37 / 62
Multi-class Classification

For multi-class classification problems, use


cross-entropy as loss and the softmax
activation function
XX (n) (n)
E =− tk log ok
n k
(n)
(n) exp(zk )
ok = P (n)
j exp(zj )

And the derivatives become


∂ok
= ok (1 − ok )
∂zk
∂E X ∂E ∂oj
= = (ok − tk )ok (1 − ok )
∂zk j
∂oj ∂zk

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 38 / 62


Example Application

Now trying to classify image of


handwritten digit: 32x32 pixels
10 output units, 1 per digit
Use the softmax function:

exp(zk )
ok = P
j exp(zj )
J
X
zk = wk0 + hj (x)wkj
j=1

What is J ?

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 39 / 62


Ways to Use Weight Derivatives

How often to update

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 40 / 62


Ways to Use Weight Derivatives

How often to update


I after a full sweep through the training data (batch gradient descent)
N
∂E X ∂E (o(n) , t(n) ; w)
wki ← wki − η = wki − η
∂wki n=1
∂wki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 40 / 62


Ways to Use Weight Derivatives

How often to update


I after a full sweep through the training data (batch gradient descent)
N
∂E X ∂E (o(n) , t(n) ; w)
wki ← wki − η = wki − η
∂wki n=1
∂wki

I after each training case (stochastic gradient descent)

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 40 / 62


Ways to Use Weight Derivatives

How often to update


I after a full sweep through the training data (batch gradient descent)
N
∂E X ∂E (o(n) , t(n) ; w)
wki ← wki − η = wki − η
∂wki n=1
∂wki

I after each training case (stochastic gradient descent)


I after a mini-batch of training cases

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 40 / 62


Ways to Use Weight Derivatives

How often to update


I after a full sweep through the training data (batch gradient descent)
N
∂E X ∂E (o(n) , t(n) ; w)
wki ← wki − η = wki − η
∂wki n=1
∂wki

I after each training case (stochastic gradient descent)


I after a mini-batch of training cases
How much to update

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 40 / 62


Ways to Use Weight Derivatives

How often to update


I after a full sweep through the training data (batch gradient descent)
N
∂E X ∂E (o(n) , t(n) ; w)
wki ← wki − η = wki − η
∂wki n=1
∂wki

I after each training case (stochastic gradient descent)


I after a mini-batch of training cases
How much to update
I Use a fixed learning rate

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 40 / 62


Ways to Use Weight Derivatives

How often to update


I after a full sweep through the training data (batch gradient descent)
N
∂E X ∂E (o(n) , t(n) ; w)
wki ← wki − η = wki − η
∂wki n=1
∂wki

I after each training case (stochastic gradient descent)


I after a mini-batch of training cases
How much to update
I Use a fixed learning rate
I Adapt the learning rate

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 40 / 62


Ways to Use Weight Derivatives

How often to update


I after a full sweep through the training data (batch gradient descent)
N
∂E X ∂E (o(n) , t(n) ; w)
wki ← wki − η = wki − η
∂wki n=1
∂wki

I after each training case (stochastic gradient descent)


I after a mini-batch of training cases
How much to update
I Use a fixed learning rate
I Adapt the learning rate
I Add momentum

wki ← wki − v
∂E
v ← γv + η
∂wki

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 40 / 62


Comparing Optimization Methods

[http://cs231n.github.io/neural-networks-3/, Alec Radford]

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 41 / 62


Monitor Loss During Training
Check how your loss behaves during training, to spot wrong
hyperparameters, bugs, etc

Figure : Left: Good vs bad parameter choices, Right: How a real loss might look
like during training. What are the bumps caused by? How could we get a more
smooth loss?
Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 42 / 62
Monitor Accuracy on Train/Validation During Training

Check how your desired performance metrics behaves during training

[http://cs231n.github.io/neural-networks-3/]

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 43 / 62


Why ”Deep”?

Supervised Learning: Examples


Classification

on
at i
“dog”
sific
c las

Denoising
n
sio
r es
reg

OCR
red
u ctu ion
“2 3 4 5” r
st dict
e
pr 3

Ranzato

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 44 / 62


Why ”Deep”?

Supervised Learning: Examples


Classification

on
at i
“dog”
sific
c las

Denoising
n
sio
r es
Supervised Deep Learning reg
Classification

OCR
“dog”
red
u ctu ion
“2 3 4 5” r
st dict
e
pr 3
Denoising
[Picture from M. Ranzato] Ranzato

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 44 / 62


Neural Networks

Deep learning uses composite of simple functions (e.g., ReLU, sigmoid, tanh,
max) to create complex non-linear functions

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 45 / 62


Neural Networks

Deep learning uses composite of simple functions (e.g., ReLU, sigmoid, tanh,
max) to create complex non-linear functions
Note: a composite of linear functions is linear!

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 45 / 62


Neural Networks

Deep learning uses composite of simple functions (e.g., ReLU, sigmoid, tanh,
max) to create complex non-linear functions
Note: a composite of linear functions is linear!
Example: 2 hidden layer NNet (now matrix and vector form!) with ReLU as
nonlinearity

h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 45 / 62


Neural Networks

Deep learning uses composite of simple functions (e.g., ReLU, sigmoid, tanh,
max) to create complex non-linear functions
Note: a composite of linear functions is linear!
Example: 2 hidden layer NNet (now matrix and vector form!) with ReLU as
nonlinearity

h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

I x is the input

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 45 / 62


Neural Networks

Deep learning uses composite of simple functions (e.g., ReLU, sigmoid, tanh,
max) to create complex non-linear functions
Note: a composite of linear functions is linear!
Example: 2 hidden layer NNet (now matrix and vector form!) with ReLU as
nonlinearity

h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

I x is the input
I y is the output (what we want to predict)

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 45 / 62


Neural Networks

Deep learning uses composite of simple functions (e.g., ReLU, sigmoid, tanh,
max) to create complex non-linear functions
Note: a composite of linear functions is linear!
Example: 2 hidden layer NNet (now matrix and vector form!) with ReLU as
nonlinearity

h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

I x is the input
I y is the output (what we want to predict)
I hi is the i-th hidden layer

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 45 / 62


Neural Networks

Deep learning uses composite of simple functions (e.g., ReLU, sigmoid, tanh,
max) to create complex non-linear functions
Note: a composite of linear functions is linear!
Example: 2 hidden layer NNet (now matrix and vector form!) with ReLU as
nonlinearity

h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

I x is the input
I y is the output (what we want to predict)
I hi is the i-th hidden layer
I Wi are the parameters of the i-th layer

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 45 / 62


Evaluating the Function

Assume we have learn the weights and we want to do inference


Forward Propagation: compute the output given the input
h1 h2
x max(0, W1T x + b1 ) max(0, W2T h1 + b2 ) W3T h2 + b 3 y

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 46 / 62


Evaluating the Function

Assume we have learn the weights and we want to do inference


Forward Propagation: compute the output given the input
h1 h2
x max(0, W1T x + b1 ) max(0, W2T h1 + b2 ) W3T h2 + b 3 y

Do it in a compositional way,

h1 = max(0, W1T x + b 1 )

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 46 / 62


Evaluating the Function

Assume we have learn the weights and we want to do inference


Forward Propagation: compute the output given the input
h1 h2
x max(0, W1T x + b1 ) max(0, W2T h1 + b2 ) W3T h2 + b 3 y

Do it in a compositional way

h1 = max(0, W1T x + b1 )
h2 = max(0, W2T h1 + b2 )

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 47 / 62


Evaluating the Function

Assume we have learn the weights and we want to do inference


Forward Propagation: compute the output given the input
h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

Do it in a compositional way

h1 = max(0, W1T x + b1 )
h2 = max(0, W2T h1 + b2 )
y = W3T h2 + b3

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 48 / 62


Learning

h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We want to estimate the parameters, biases and hyper-parameters (e.g.,


number of layers, number of units) such that we do good predictions
Collect a training set of input-output pairs {x(n) , t(n) }

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 49 / 62


Learning

h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We want to estimate the parameters, biases and hyper-parameters (e.g.,


number of layers, number of units) such that we do good predictions
Collect a training set of input-output pairs {x(n) , t(n) }
For classification: Encode the output with 1-K encoding t = [0, .., 1, .., 0]

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 49 / 62


Learning

h1 h2
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We want to estimate the parameters, biases and hyper-parameters (e.g.,


number of layers, number of units) such that we do good predictions
Collect a training set of input-output pairs {x(n) , t(n) }
For classification: Encode the output with 1-K encoding t = [0, .., 1, .., 0]
Define a loss per training example and minimize the empirical risk
1 X
L(w) = `(w, x(n) , t(n) )
N n

with N number of examplesand w contains all parameters

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 49 / 62


Loss Function: Classification

1 X
L(w) = `(w, x(n) , t(n) )
N n

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 50 / 62


Loss Function: Classification

1 X
L(w) = `(w, x(n) , t(n) )
N n

Probability of class k given input (softmax):


exp(yk )
p(ck = 1|x) = PC
j=1 exp(yj )

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 50 / 62


Loss Function: Classification

1 X
L(w) = `(w, x(n) , t(n) )
N n

Probability of class k given input (softmax):


exp(yk )
p(ck = 1|x) = PC
j=1 exp(yj )

Cross entropy is the most used loss function for classification


X (n)
`(w, x(n) , t(n) ) = − tk log p(ck |x)
k

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 50 / 62


Loss Function: Classification

1 X
L(w) = `(w, x(n) , t(n) )
N n

Probability of class k given input (softmax):


exp(yk )
p(ck = 1|x) = PC
j=1 exp(yj )

Cross entropy is the most used loss function for classification


X (n)
`(w, x(n) , t(n) ) = − tk log p(ck |x)
k

Use gradient descent to train the network


1 X
min `(w, x(n) , t(n) )
w N n

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 50 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂`
h1 h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 51 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂`
h1 h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

exp(yk )
p(ck = 1|x) = PC
j=1 exp(yj )

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 51 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂`
h1 h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

exp(yk )
p(ck = 1|x) = PC
j=1 exp(yj )
X (n)
`(x(n) , t(n) , w) = − tk log p(ck |x)
k

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 51 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂`
h1 h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

exp(yk )
p(ck = 1|x) = PC
j=1 exp(yj )
X (n)
`(x(n) , t(n) , w) = − tk log p(ck |x)
k

Compute the derivative of loss w.r.t. the output


∂`
= p(c|x) − t
∂y

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 51 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂`
h1 h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

exp(yk )
p(ck = 1|x) = PC
j=1 exp(yj )
X (n)
`(x(n) , t(n) , w) = − tk log p(ck |x)
k

Compute the derivative of loss w.r.t. the output


∂`
= p(c|x) − t
∂y

∂`
Note that the forward pass is necessary to compute ∂y

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 51 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

∂`
Given ∂y if we can compute the Jacobian of each module

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

∂`
Given ∂y if we can compute the Jacobian of each module
∂`
=
∂W3

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

∂`
Given ∂y if we can compute the Jacobian of each module
∂` ∂` ∂y
= =
∂W3 ∂y ∂W3

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

∂`
Given ∂y if we can compute the Jacobian of each module
∂` ∂` ∂y
= = (p(c|x) − t)(h2 )T
∂W3 ∂y ∂W3

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

∂`
Given ∂y if we can compute the Jacobian of each module
∂` ∂` ∂y
= = (p(c|x) − t)(h2 )T
∂W3 ∂y ∂W3
∂`
=
∂h2

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

∂`
Given ∂y if we can compute the Jacobian of each module
∂` ∂` ∂y
= = (p(c|x) − t)(h2 )T
∂W3 ∂y ∂W3
∂` ∂` ∂y
= =
∂h2 ∂y ∂h2

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

∂`
Given ∂y if we can compute the Jacobian of each module
∂` ∂` ∂y
= = (p(c|x) − t)(h2 )T
∂W3 ∂y ∂W3
∂` ∂` ∂y
= = (W3 )T (p(c|x) − t)
∂h2 ∂y ∂h2

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62


Backpropagation
Efficient computation of the gradients by applying the chain rule
∂` ∂`
h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

We have computed the derivative of loss w.r.t the output


∂`
= p(c|x) − t
∂y

∂`
Given ∂y if we can compute the Jacobian of each module
∂` ∂` ∂y
= = (p(c|x) − t)(h2 )T
∂W3 ∂y ∂W3
∂` ∂` ∂y
= = (W3 )T (p(c|x) − t)
∂h2 ∂y ∂h2

Need to compute gradient w.r.t. inputs and parameters in each layer


Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 52 / 62
Backpropagation

Efficient computation of the gradients by applying the chain rule


∂` ∂` ∂`
∂h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

∂` ∂` ∂y
= = (W3 )T (p(c|x) − t)
∂h2 ∂y ∂h2

∂`
Given ∂h2 if we can compute the Jacobian of each module

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 53 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂` ∂` ∂`
∂h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

∂` ∂` ∂y
= = (W3 )T (p(c|x) − t)
∂h2 ∂y ∂h2

∂`
Given ∂h2 if we can compute the Jacobian of each module

∂`
=
∂W2

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 53 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂` ∂` ∂`
∂h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

∂` ∂` ∂y
= = (W3 )T (p(c|x) − t)
∂h2 ∂y ∂h2

∂`
Given ∂h2 if we can compute the Jacobian of each module

∂` ∂` ∂h2
=
∂W2 ∂h2 ∂W2

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 53 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂` ∂` ∂`
∂h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

∂` ∂` ∂y
= = (W3 )T (p(c|x) − t)
∂h2 ∂y ∂h2

∂`
Given ∂h2 if we can compute the Jacobian of each module

∂` ∂` ∂h2
=
∂W2 ∂h2 ∂W2

∂`
=
∂h1

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 53 / 62


Backpropagation

Efficient computation of the gradients by applying the chain rule


∂` ∂` ∂`
∂h1 ∂h2 ∂y
x max(0, W1T x + b 1 ) max(0, W2T h1 + b 2 ) W3T h2 + b 3 y

∂` ∂` ∂y
= = (W3 )T (p(c|x) − t)
∂h2 ∂y ∂h2

∂`
Given ∂h2 if we can compute the Jacobian of each module

∂` ∂` ∂h2
=
∂W2 ∂h2 ∂W2

∂` ∂` ∂h2
1
=
∂h ∂h2 ∂h1

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 53 / 62


Toy Code (Matlab): Neural Net Trainer
% F-PROP
for i = 1 : nr_layers - 1
[h{i} jac{i}] = nonlinearity(W{i} * h{i-1} + b{i});
end
h{nr_layers-1} = W{nr_layers-1} * h{nr_layers-2} + b{nr_layers-1};
prediction = softmax(h{l-1});

% CROSS ENTROPY LOSS


loss = - sum(sum(log(prediction) .* target)) / batch_size;

% B-PROP
dh{l-1} = prediction - target;
for i = nr_layers – 1 : -1 : 1
Wgrad{i} = dh{i} * h{i-1}';
bgrad{i} = sum(dh{i}, 2);
dh{i-1} = (W{i}' * dh{i}) .* jac{i-1};
end

% UPDATE
for i = 1 : nr_layers - 1
W{i} = W{i} – (lr / batch_size) * Wgrad{i};
b{i} = b{i} – (lr / batch_size) * bgrad{i};
end 28

This code has a few bugs with indices... Ranzato


Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 54 / 62
Overfitting

The training data contains information about the regularities in the mapping
from input to output. But it also contains noise

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 55 / 62


Overfitting

The training data contains information about the regularities in the mapping
from input to output. But it also contains noise
I The target values may be unreliable.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 55 / 62


Overfitting

The training data contains information about the regularities in the mapping
from input to output. But it also contains noise
I The target values may be unreliable.
I There is sampling error: There will be accidental regularities just
because of the particular training cases that were chosen

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 55 / 62


Overfitting

The training data contains information about the regularities in the mapping
from input to output. But it also contains noise
I The target values may be unreliable.
I There is sampling error: There will be accidental regularities just
because of the particular training cases that were chosen
When we fit the model, it cannot tell which regularities are real and which
are caused by sampling error.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 55 / 62


Overfitting

The training data contains information about the regularities in the mapping
from input to output. But it also contains noise
I The target values may be unreliable.
I There is sampling error: There will be accidental regularities just
because of the particular training cases that were chosen
When we fit the model, it cannot tell which regularities are real and which
are caused by sampling error.
I So it fits both kinds of regularity.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 55 / 62


Overfitting

The training data contains information about the regularities in the mapping
from input to output. But it also contains noise
I The target values may be unreliable.
I There is sampling error: There will be accidental regularities just
because of the particular training cases that were chosen
When we fit the model, it cannot tell which regularities are real and which
are caused by sampling error.
I So it fits both kinds of regularity.
I If the model is very flexible it can model the sampling error really well.
This is a disaster.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 55 / 62


Preventing Overfitting

Use a model that has the right capacity:

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 56 / 62


Preventing Overfitting

Use a model that has the right capacity:


I enough to model the true regularities

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 56 / 62


Preventing Overfitting

Use a model that has the right capacity:


I enough to model the true regularities
I not enough to also model the spurious regularities (assuming they are
weaker)

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 56 / 62


Preventing Overfitting

Use a model that has the right capacity:


I enough to model the true regularities
I not enough to also model the spurious regularities (assuming they are
weaker)
Standard ways to limit the capacity of a neural net:

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 56 / 62


Preventing Overfitting

Use a model that has the right capacity:


I enough to model the true regularities
I not enough to also model the spurious regularities (assuming they are
weaker)
Standard ways to limit the capacity of a neural net:
I Limit the number of hidden units.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 56 / 62


Preventing Overfitting

Use a model that has the right capacity:


I enough to model the true regularities
I not enough to also model the spurious regularities (assuming they are
weaker)
Standard ways to limit the capacity of a neural net:
I Limit the number of hidden units.
I Limit the norm of the weights.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 56 / 62


Preventing Overfitting

Use a model that has the right capacity:


I enough to model the true regularities
I not enough to also model the spurious regularities (assuming they are
weaker)
Standard ways to limit the capacity of a neural net:
I Limit the number of hidden units.
I Limit the norm of the weights.
I Stop the learning before it has time to overfit.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 56 / 62


Limiting the size of the Weights

Weight-decay involves adding an extra term to the cost function that


penalizes the squared weights.
λX 2
C =`+ wi
2
i

Keeps weights small unless they have big error derivatives.


∂C ∂`
= + λwi
∂wi ∂wi

C ∂C 1 ∂`
when = 0, wi = −
∂wi λ ∂wi
w

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 57 / 62


The Effect of Weight-decay

It prevents the network from using weights that it does not need

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 58 / 62


The Effect of Weight-decay

It prevents the network from using weights that it does not need
I This can often improve generalization a lot.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 58 / 62


The Effect of Weight-decay

It prevents the network from using weights that it does not need
I This can often improve generalization a lot.
I It helps to stop it from fitting the sampling error.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 58 / 62


The Effect of Weight-decay

It prevents the network from using weights that it does not need
I This can often improve generalization a lot.
I It helps to stop it from fitting the sampling error.
I It makes a smoother model in which the output changes more slowly as
the input changes.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 58 / 62


The Effect of Weight-decay

It prevents the network from using weights that it does not need
I This can often improve generalization a lot.
I It helps to stop it from fitting the sampling error.
I It makes a smoother model in which the output changes more slowly as
the input changes.
But, if the network has two very similar inputs it prefers to put half the
weight on each rather than all the weight on one → other form of weight
decay?

w/2 w/2 w 0

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 58 / 62


Deciding How Much to Restrict the Capacity

How do we decide which regularizer to use and how strong to make it?

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 59 / 62


Deciding How Much to Restrict the Capacity

How do we decide which regularizer to use and how strong to make it?
So use a separate validation set to do model selection.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 59 / 62


Using a Validation Set

Divide the total dataset into three subsets:

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 60 / 62


Using a Validation Set

Divide the total dataset into three subsets:


I Training data is used for learning the parameters of the model.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 60 / 62


Using a Validation Set

Divide the total dataset into three subsets:


I Training data is used for learning the parameters of the model.
I Validation data is not used for learning but is used for deciding what
type of model and what amount of regularization works best

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 60 / 62


Using a Validation Set

Divide the total dataset into three subsets:


I Training data is used for learning the parameters of the model.
I Validation data is not used for learning but is used for deciding what
type of model and what amount of regularization works best
I Test data is used to get a final, unbiased estimate of how well the
network works. We expect this estimate to be worse than on the
validation data

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 60 / 62


Using a Validation Set

Divide the total dataset into three subsets:


I Training data is used for learning the parameters of the model.
I Validation data is not used for learning but is used for deciding what
type of model and what amount of regularization works best
I Test data is used to get a final, unbiased estimate of how well the
network works. We expect this estimate to be worse than on the
validation data
We could then re-divide the total dataset to get another unbiased estimate
of the true error rate.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 60 / 62


Preventing Overfitting by Early Stopping

If we have lots of data and a big model, its very expensive to keep
re-training it with different amounts of weight decay

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 61 / 62


Preventing Overfitting by Early Stopping

If we have lots of data and a big model, its very expensive to keep
re-training it with different amounts of weight decay
It is much cheaper to start with very small weights and let them grow until
the performance on the validation set starts getting worse

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 61 / 62


Preventing Overfitting by Early Stopping

If we have lots of data and a big model, its very expensive to keep
re-training it with different amounts of weight decay
It is much cheaper to start with very small weights and let them grow until
the performance on the validation set starts getting worse
The capacity of the model is limited because the weights have not had time
to grow big.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 61 / 62


Why Early Stopping Works

When the weights are very small, every


hidden unit is in its linear range.
outputs
I So a net with a large layer of hidden
units is linear.
I It has no more capacity than a linear
net in which the inputs are directly
connected to the outputs!
As the weights grow, the hidden units
inputs
start using their non-linear ranges so the
capacity grows.

Zemel, Urtasun, Fidler (UofT) CSC 411: 10-Neural Networks I 62 / 62

You might also like