This example shows how to classify digits using HOG features and a multiclass SVM classifier.
Object classification is an important task in many computer vision applications, including surveillance, automotive safety, and image retrieval. For example, in an automotive safety application, you may need to classify nearby objects as pedestrians or vehicles. Regardless of the type of object being classified, the basic procedure for creating an object classifier is:
Acquire a labeled data set with images of the desired object.
Partition the data set into a training set and a test set.
Train the classifier using features extracted from the training set.
Test the classifier using features extracted from the test set.
To illustrate, this example shows how to classify numerical digits using HOG (Histogram of Oriented Gradient) features [1] and a multiclass SVM (Support Vector Machine) classifier. This type of classification is often used in many Optical Character Recognition (OCR) applications.
The example uses the fitcecoc
function from the Statistics and Machine Learning Toolbox™ and the extractHOGFeatures
function from the Computer Vision System Toolbox™.
Digit Data Set
Synthetic digit images are used for training. The training images each contain a digit surrounded by other digits, which mimics how digits are normally seen together. Using synthetic images is convenient and it enables the creation of a variety of training samples without having to manually collect them. For testing, scans of handwritten digits are used to validate how well the classifier performs on data that is different than the training data. Although this is not the most representative data set, there is enough data to train and test a classifier, and show the feasibility of the approach.
Use countEachLabel
to tabulate the number of images associated with each label. In this example, the training set consists of 101 images for each of the 10 digits. The test set consists of 12 images per digit.
Show a few of the training and test images
Prior to training and testing a classifier, a pre-processing step is applied to remove noise artifacts introduced while collecting the image samples. This provides better feature vectors for training the classifier.
Using HOG Features
The data used to train the classifier are HOG feature vectors extracted from the training images. Therefore, it is important to make sure the HOG feature vector encodes the right amount of information about the object. The extractHOGFeatures
function returns a visualization output that can help form some intuition about just what the "right amount of information" means. By varying the HOG cell size parameter and visualizing the result, you can see the effect the cell size parameter has on the amount of shape information encoded in the feature vector:
The visualization shows that a cell size of [8 8] does not encode much shape information, while a cell size of [2 2] encodes a lot of shape information but increases the dimensionality of the HOG feature vector significantly. A good compromise is a 4-by-4 cell size. This size setting encodes enough spatial information to visually identify a digit shape while limiting the number of dimensions in the HOG feature vector, which helps speed up training. In practice, the HOG parameters should be varied with repeated classifier training and testing to identify the optimal parameter settings.
Train a Digit Classifier
Digit classification is a multiclass classification problem, where you have to classify an image into one out of the ten possible digit classes. In this example, the fitcecoc
function from the Statistics and Machine Learning Toolbox™ is used to create a multiclass classifier using binary SVMs.
Start by extracting HOG features from the training set. These features will be used to train the classifier.
Next, train a classifier using the extracted features.
Evaluate the Digit Classifier
Evaluate the digit classifier using images from the test set, and generate a confusion matrix to quantify the classifier accuracy.
As in the training step, first extract HOG features from the test images. These features will be used to make predictions using the trained classifier.
The table shows the confusion matrix in percentage form. The columns of the matrix represent the predicted labels, while the rows represent the known labels. For this test set, digit 0 is often misclassified as 6, most likely due to their similar shapes. Similar errors are seen for 9 and 3. Training with a more representative data set like MNIST [2] or SVHN [3], which contain thousands of handwritten characters, is likely to produce a better classifier compared with the one created using this synthetic data set.
Summary
This example illustrated the basic procedure for creating a multiclass object classifier using the extractHOGfeatures
function from the Computer Vision System Toolbox and the fitcecoc
function from the Statistics and Machine Learning Toolbox™. Although HOG features and an ECOC classifier were used here, other features and machine learning algorithms can be used in the same way. For instance, you can explore using different feature types for training the classifier; or you can see the effect of using other machine learning algorithms available in the Statistics and Machine Learning Toolbox™ such as k-nearest neighbors.
References
[1] N. Dalal and B. Triggs, "Histograms of Oriented Gradients for Human Detection", Proc. IEEE Conf. Computer Vision and Pattern Recognition, vol. 1, pp. 886-893, 2005.
[2] LeCun, Y., Bottou, L., Bengio, Y., and Haffner, P. (1998). Gradient-based learning applied to document recognition. Proceedings of the IEEE, 86, 2278-2324.
[3] Y. Netzer, T. Wang, A. Coates, A. Bissacco, B. Wu, A.Y. Ng, Reading Digits in Natural Images with Unsupervised Feature Learning NIPS Workshop on Deep Learning and Unsupervised Feature Learning 2011.
'Data Mining & R' 카테고리의 다른 글
R에서 try(), tryCatch() 함수 (R 예러처리) (1) | 2017.04.05 |
---|---|
Netflix Prize 및 프로덕션 머신 러닝 시스템 PDF (0) | 2017.03.31 |
Classification in the Presence of Missing Data (0) | 2017.03.31 |
kNN(k Nearest Neighbors) 알고리즘 소개 및 R 구현 (0) | 2017.03.13 |
Supervised Learning, Unsupervised Learning (0) | 2017.03.13 |