How to train your own object detection models using the TensorFlow Object Detection API (2020 Update)
This started as a summary of this nice tutorial, but has since then become its own thing.
- Prerequisites
- Annotating images and serializing the dataset
- Choosing a neural network and preparing the training pipeline
- Training the network
- Final Tips
-
Choose a TensorFlow installation. TensorFlow 1 and 2 have different different neural networks avaliable, so check here and here to make your choice.
- Tip: if you opt for one of the TF1 models, please note that the Ojbect detection API is only officialy compatible with TF 1.15.O, which works only with CUDA 10.0 (unless you compile from source). From personal experience, I know that all versions of TF from 1.12 and backwards do not work with the Object Detection API anymore.
-
Download the TensorFlow models repository and install the Object Detection API [TF1] [TF2].
For these steps, I'll recommend a collection of script I mase, which are available in this repository. All of the scripts mentioned in this section receive arguments from the command line and have help messages through the -h/--help
flags. Also check the README from the repo they come from to get more details, if needed.
-
Install labelImg. This is a Python package, which means you can install it via pip, but the one from GitHub is better.
-
Annotate your dataset using labelImg. Each image you annotate will have its annotations saved to an individual XML file with the name of the original image file and the
.xml
extension. -
Use this script to convert the XML files generated by labelImg into a single CSV file.
- Optional: Use this script
to separate the CSV file into two, one with training examples and
one with evaluation examples. Let's call them
train.csv
andeval.csv
. Images will be selected randomly and there are options to stratify examples by class, making sure that objects from all classes are present in both datasets. The usual proportions are 75% to 80% of the annotated objects used for training and the rest for the evaluation dataset.
- Optional: Use this script
to separate the CSV file into two, one with training examples and
one with evaluation examples. Let's call them
-
Create a "label map" for your classes. You can check some examples to understand what they look like. You can also generate one from your original CSV file with this script.
-
Use this script to convert each of your CSV files into two TFRecord files (eg.
train.record
andeval.record
), a serialized data format that TensorFlow is most familiar with. You'll need to point to the directory where the image files are stored and to the label map generated in the previous step.- Tip: if you notice mistakes during the creation of these files, you can check their contents and compare to the ones in these examples.
-
Download your the neural network model of choice from either the Detection Model Zoo [TF1][TF2] or from the models trained for classification available here and here. This is the step in which your choice of TensorFlow version will make a difference. From my experience, many of the classification models work with TF 1.15, but I am not aware if they work with TF 2.
-
Provide a training pipeline, which is a file with
.config
extension that describes the training procedure. The models provided in the Detection Zoo come with their own pipelines inside their.tar.gz
file, but the classification models do not. In this situation, your options are to:- download one that is close enough from here (I have succesfully done that to train classification MobileNets V1, V2 and V3 for detection).
- create your own, by following this tutorial.
The pipeline config file has some fields that must be adjusted before training is started. The first thing you'll definitely want to keep an eye on is the
num_classes
attribute, which you'll need to change to the number of classes in your personal dataset.Other importants fields are the ones with the
PATH_TO_BE_CONFIGURED
string. In these fields, you'll need to point to the files they ask for, such as the label map, the training and evaluation TFRecords and the neural network checkpoint, which is a file with an extension like.ckpt
or.ckpt.data-####-of-####
. This file also comes with the.tar.gz
file.In case you are using a model from the Detection Zoo, set the
fine_tune_checkpoint_type
field to"detection"
, otherwise, set it to"classification"
.There are additional parameters that may affect how much RAM is consumed by the training process, as well as the quality of the training. Things like the batch size or how many batches TensorFlow can prefetch and keep in memory may considerably increase the amount of RAM necessary, but I won't go over those here as there is too much trial and error in adjusting those.
-
Train the model. To do it locally, follow the steps available here: [TF1][TF2]. Optional: in order to check training progress, TensorBoard can be started pointing its
--logdir
to the--model_dir
of object_detection/model_main.py. -
Export the network, like this.
-
Use the exported
.pb
in your object detector.
In the data augmentation section of the training pipeline, some options can be added or removed to try and make the training better. Some of the options are listed here.
Hi everyone, I've just updated the tutorial, mentioning a few scripts I created to help separate the main CSV into train and evaluation datasets, as well as generating the label map from the main CSV file. Since I've been the only one who tested these scripts, any issues or PRs in their repo are welcome.