Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/frgfm/sdcnd-p3-traffic-sign-classification
Traffic sign classification project of Udacity Self-Driving Car Engineer Nanodegree
https://github.com/frgfm/sdcnd-p3-traffic-sign-classification
deep-learning image-classification keras python self-driving-car tensorflow traffic-sign-classification
Last synced: 13 days ago
JSON representation
Traffic sign classification project of Udacity Self-Driving Car Engineer Nanodegree
- Host: GitHub
- URL: https://github.com/frgfm/sdcnd-p3-traffic-sign-classification
- Owner: frgfm
- License: mit
- Created: 2020-02-16T14:58:49.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2020-02-23T16:45:48.000Z (almost 5 years ago)
- Last Synced: 2024-12-05T17:48:29.185Z (about 1 month ago)
- Topics: deep-learning, image-classification, keras, python, self-driving-car, tensorflow, traffic-sign-classification
- Language: Python
- Size: 183 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Traffic Sign Classification
[![License](https://img.shields.io/badge/License-MIT-brightgreen.svg)](LICENSE)[![Codacy Badge](https://api.codacy.com/project/badge/Grade/da9c53f13c5f4cd5b318d510d9f4676f)](https://www.codacy.com/manual/frgfm/sdcnd-p3-traffic-sign-classification?utm_source=github.com&utm_medium=referral&utm_content=frgfm/sdcnd-p3-traffic-sign-classification&utm_campaign=Badge_Grade) [![CircleCI](https://circleci.com/gh/frgfm/sdcnd-p3-traffic-sign-classification.svg?style=shield)](https://circleci.com/gh/frgfm/sdcnd-p3-traffic-sign-classification) [![codecov](https://codecov.io/gh/frgfm/sdcnd-p3-traffic-sign-classification/branch/master/graph/badge.svg)](https://codecov.io/gh/frgfm/sdcnd-p3-traffic-sign-classification)
This repository is an implementation of an image classification pipeline for the traffic sign classification of Udacity Self-Driving Car Nanodegree (cf. [repo]()).
![test_sample05](static/images/test_sample05.png)
## Table of Contents
- [Getting Started](#getting-started)
- [Prerequisites](#prerequisites)
- [Installation](#installation)
- [Usage](#usage)
- [Approach](#Approach)
- [Credits](#credits)
- [License](#license)## Getting started
### Prerequisites
- Python 3.6 (or more recent)
- [pip](https://pip.pypa.io/en/stable/)### Installation
You can install the project requirements as follows:
```shell
git clone https://github.com/frgfm/sdcnd-p3-traffic-sign-classification.git
cd sdcnd-p3-traffic-sign-classification
pip install -r requirements.txt
mkdir data
```Get the German Traffic Dataset from [here](https://s3-us-west-1.amazonaws.com/udacity-selfdrivingcar/traffic-signs-data.zip) and extract its content in the `data` folder to be able to train. Download the class [labels](https://raw.githubusercontent.com/udacity/CarND-Traffic-Sign-Classifier-Project/master/signnames.csv) and put them in the same folder.
You can download the trained [model](https://github.com/frgfm/sdcnd-p3-traffic-sign-classification/releases/download/v0.1.0/model.h5) (put the checkpoint in the `./data` folder) and the testing [images](https://github.com/frgfm/sdcnd-p3-traffic-sign-classification/releases/download/v0.1.0/test_images.zip) (extract it to a `test_images` folder) from the latest release.
*Note: if you wish to use CPU only, replace the `tensorflow-gpu` dependencies with `tensorflow`*
## Usage
### Training
A training script is available to train an image classifier on the training dataset.
```
usage: train.py [-h] [--folder FOLDER] [--batch-size BATCH_SIZE] [--lr LR]
[--distribution]
epochsTraffic sign classification training
positional arguments:
epochs Number of epochs to trainoptional arguments:
-h, --help show this help message and exit
--folder FOLDER Path to data folder (default: ./data)
--batch-size BATCH_SIZE
Batch size (default: 128)
--lr LR Learning rate (default: 0.001)
--distribution Should the class distribution be displayed (default:
False)
```### Test
An inference script is available for you to test out your trained model or the one from th release.
```
usage: test.py [-h] [--folder FOLDER] [--model MODEL] imgfolderTraffic sign classification training
positional arguments:
imgfolder Path to image folderoptional arguments:
-h, --help show this help message and exit
--folder FOLDER Images to test (default: ./data)
--model MODEL Path to model checkpoint (default: ./data/model.h5)```
### Activation visualization
Finally you can check the activation on specific layers of your trained model.
```
usage: visualize.py [-h] [--layer LAYER] [--folder FOLDER] [--model MODEL] imgTraffic sign classification activation visualization
positional arguments:
img Path to imageoptional arguments:
-h, --help show this help message and exit
--layer LAYER Layer name (options: conv2d, max_pooling2d, conv2d_1,
max_pooling2d_1) (default: conv2d)
--folder FOLDER Images to test (default: ./data)
--model MODEL Path to model checkpoint (default: ./data/model.h5)
```## Approach
### Dataset
The dataset has 34799 training examples, 4410 validation examples and 12630 testing examples Each sample is an RGB image of shape: (32, 32, 3). Labels include 43 classes of traffic signs.
![class_distribution](static/images/class_distribution.png)
The class distribution is imbalanced as shown above. The data preprocessing will include:
- conversion to grayscale: to reduce the number of channels *(data dimensionality)*
- normalization: feeding normalized data to the model even on new data distribution *(with the mean and standard deviation of the training set)*.### Architecture
As suggested by the default repository, the [LeNet5](http://yann.lecun.com/exdb/publis/pdf/lecun-01a.pdf) architecture was used for image classification. This architecture has already shown great results on small grayscale images (cf. [MNIST](http://yann.lecun.com/exdb/mnist/)), despite its small size, which is a similar problem in terms of number of classes *(a few dozens)*, input size *(32x32)*, number of channels *(grayscale)* and learned task *(digit classification, traffic sign classification)*.
![lenet5]()
*Source: Gradient-based learning applied to document recognition (1998)*
Picking a light architecture like LeNet5 is expected to prevent overfitting and to ease the training convergence, thanks to the small number of learnable parameters (compared to a [VGG](https://arxiv.org/abs/1409.1556) or [ResNet](https://arxiv.org/abs/1512.03385) architecture for instance).
By implementing the architecture from the paper and introducing [dropout](http://jmlr.org/papers/volume15/srivastava14a/srivastava14a.pdf) in the fully connected layers, we get our final model:
```shell
Model: "sequential"
_________________________________________________________________
Layer (type) Output Shape Param #
=================================================================
conv2d (Conv2D) (None, 28, 28, 6) 156
_________________________________________________________________
max_pooling2d (MaxPooling2D) (None, 14, 14, 6) 0
_________________________________________________________________
conv2d_1 (Conv2D) (None, 10, 10, 16) 2416
_________________________________________________________________
max_pooling2d_1 (MaxPooling2 (None, 5, 5, 16) 0
_________________________________________________________________
flatten (Flatten) (None, 400) 0
_________________________________________________________________
dense (Dense) (None, 120) 48120
_________________________________________________________________
dense_1 (Dense) (None, 84) 10164
_________________________________________________________________
dropout (Dropout) (None, 84) 0
_________________________________________________________________
dense_2 (Dense) (None, 43) 3655
=================================================================
Total params: 64,511
Trainable params: 64,511
Non-trainable params: 0
```### Training sequence
The training sequence is handled by the `train.py` script as follows:
- optimizer: [Adam](https://arxiv.org/abs/1412.6980) *(commonly used for image classification)*
- batch size: 128 *(selected based on GPU RAM capacity)*
- epochs: 10
- learning rate scheduler: flat (constant)
- learning rate: 1e-3
- Dropout rate: 0.2 *(reduces overfitting without extending the number of epochs too much)*The training procedure yields very positive results with a final validation accuracy of 95.92%.
![training_monitoring](static/images/training_monitoring.png)
The accuracy over the testing set reaches 92.52%, which shows a good generalization capacity of the model, without any apparent overfitting. The model parameters' values were saved [here](https://github.com/frgfm/sdcnd-p3-traffic-sign-classification/releases/download/v0.1.0/model.h5).
### Evaluation on new images
Eight [images](https://github.com/frgfm/sdcnd-p3-traffic-sign-classification/releases/download/v0.1.0/test_images.zip) were selected on the Web for testing purposes *(their resized version is shown below)*:
![all_samples](static/images/all_samples.png)
The difference in resolution and size may have detrimental effects on the model performances for these images. Other visual deformations would also have an influence but the set was manually selected to avoid those.
Using the `test.py` script, we can inspect the predictions of the trained model over the test images. Feel free to use your own.
![test_sample01](static/images/test_sample01.png)
![test_sample02](static/images/test_sample02.png)
![test_sample03](static/images/test_sample03.png)
![test_sample04](static/images/test_sample04.png)
![test_sample05](static/images/test_sample05.png)
With this limited dataset, the aggregated accuracy of the model is 62.50%. The results for the first 5 samples of the dataset are shown above. A larger dataset would confirm potential ideas to improve the architecture and training procedure.
### Feature visualization
Finally, by passing data through the trained model, we can visualize the activation of specific feature layers for a given image. Below are examples of different layers for a sample image.
1st convolution layer
![activ_conv2d](static/images/activ_conv2d.png)
1st maxpooling layer
![activ_maxpool2d](static/images/activ_maxpool2d.png)
2nd convolution layer
![activ_conv2d_1](static/images/activ_conv2d_1.png)
2nd maxpooling layer
![activ_maxpool2d_1](static/images/activ_maxpool2d_1.png)
## Credits
This implementation is vastly based on the following methods:
- [Gradient-based Learning Applied to Document Recognition](http://yann.lecun.com/exdb/publis/pdf/lecun-01a.pdf)
- [Dropout: A Simple Way to Prevent Neural Networks from Overfitting](http://jmlr.org/papers/volume15/srivastava14a/srivastava14a.pdf)## License
Distributed under the MIT License. See `LICENSE` for more information.