Professional Documents
Culture Documents
Lec 02
Lec 02
John Canny
Fall 2016
Lecture 2: Computer Vision and Image Classification
A data-driven approach?
Computer Vision – Invariant Features
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Computer Vision – Bag-of-words
Sivic and Zisserman (2003) “Video Google”
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Computer Vision – Challenge Datasets
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Computer Vision – Deep Networks
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Computer Vision – Deep Networks
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Computer Vision – Deep Networks
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Administrivia
cat
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
The problem:semantic gap
E.g.
300 x 100 x 3
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Challenges: Viewpoint Variation
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Challenges: Illumination
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Challenges: Deformation
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Challenges: Occlusion
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Challenges: Background clutter
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Challenges: Intraclass variation
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
An image classifier
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Classifying using constraints? ?
???
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Data-driven approach:
1. Collect a dataset of images and labels
2. Use Machine Learning to train an image classifier
3. Evaluate the classifier on a withheld set of test images
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
First classifier: Nearest Neighbor Classifier
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Example dataset: CIFAR-10
10 labels
50,000 training images, each image is tiny: 32x32
10,000 test images.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Example dataset: CIFAR-10
10 labels For every test image (first column),
50,000 training images examples of nearest neighbors in rows
10,000 test images.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
How do we compare the images?
What is the distance metric?
L1 distance:
add
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Nearest Neighbor classifier
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Nearest Neighbor classifier
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Nearest Neighbor classifier
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Nearest Neighbor classifier
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Nearest Neighbor classifier
This is backwards:
- test time performance
is usually much more
important in practice.
- CNNs flip this:
expensive training,
cheap test evaluation
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Aside: Approximate Nearest Neighbor
find approximate nearest neighbors quickly
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
The choice of distance is a hyperparameter
common choices:
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
k-Nearest Neighbor
find the k nearest images, have them vote on the label
http://en.wikipedia.org/wiki/K-nearest_neighbors_algorithm
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Example dataset: CIFAR-10
10 labels For every test image (first column),
50,000 training images examples of nearest neighbors in rows
10,000 test images.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
the data NN classifier 5-NN classifier
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
the data NN classifier 5-NN classifier
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Hyperparameter tuning:
What is the best distance to use?
What is the best value of k to use?
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Bias and Variance
Recall from statistics (or ML), given a true function y=f(x)
(mapping an input x to a label y), a machine learning
algorithm is a statistical estimator gD(x). Here D is a data
sample.
Estimators have:
Bias: ?
Variance: ?
Bias and Variance
Increasing k in the kNN algorithm should have what effect
on:
Variance: ?
Bias
f(x) 5 neighbors
Aggregate is systematically
Biased down
Bias and Variance
Increasing k in the kNN algorithm should have what effect
on:
5 neighbors
f(x)
Bias: ?
Variance:?
Bias and Variance Rule of Thumb
Compared to simpler (fewer parameters), complex models
have what kind of Bias and Variance?:
Variance:?
Bias and Variance Rule of Thumb
Compared to simpler (fewer parameters), complex models
have what kind of Bias and Variance?:
Very problem-dependent.
Must try them all out and see what works best.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Try out what hyperparameters work best on test set.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Trying out what hyperparameters work best on test set:
Very bad idea. The test set is a proxy for the generalization performance!
Use only VERY SPARINGLY, at the end.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Validation Set:
Validation data
use to tune hyperparameters
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Validation Set:
Cross-validation
cycle through the choice of which fold
is the validation fold, average results.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Hyperparameter tuning:
Example of
5-fold cross-validation
for the value of k.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
k-Nearest Neighbor on images never used.
• terrible performance at test time
• distance metrics on level of whole images can be
very unintuitive
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson
Summary
• Image Classification: given a Training Set of labeled
images, predict labels on Test Set. Common to report the
Accuracy of predictions (fraction of correct predictions)
• We introduced the k-Nearest Neighbor Classifier, which
predicts labels based on nearest images in the training set
• We saw that the choice of distance and the value of k are
hyperparameters that are tuned using a validation set, or
through cross-validation if the size of the data is small.
• Once the best set of hyperparameters is chosen, the
classifier is evaluated once on the test set, and reported as
the performance of kNN on that data.
Slides based on cs231n by Fei-Fei Li & Andrej Karpathy & Justin Johnson