Custom object detectors are lightweight object detection models that have been pre-trained on MS COCO object detection dataset. It is assumed that one will use these pre-trained models as starting points in order to train specific object detection models (e.g. 'cat' and 'dog' detection). NOTE There was no goal to train top-scoring lightweight 80 class (MS COCO classes) detectors here, but rather provide pre-trained checkpoints for further fine-tuning on a target dataset.
Model Name | Complexity (GFLOPs) | Size (Mp) | AP @ [IoU=0.50:0.95] (%) | Links | GPU_NUM |
---|---|---|---|---|---|
mobilenet_v2-2s_ssd-256x256 | 0.86 | 1.99 | 11.3 | snapshot, model template | 3 |
mobilenet_v2-2s_ssd-384x384 | 1.92 | 1.99 | 13.3 | snapshot, model template | 3 |
mobilenet_v2-2s_ssd-512x512 | 3.42 | 1.99 | 12.7 | snapshot, model template | 3 |
Average Precision (AP) is defined as an area under the precision/recall curve.
cd models/object_detection
If You have not created virtual environment yet:
./init_venv.sh
Activate virtual environment:
source venv/bin/activate
export MODEL_TEMPLATE=`realpath ./model_templates/custom-object-detection/mobilenet_v2-2s_ssd-256x256/template.yaml`
export WORK_DIR=/tmp/my_model
python ../../tools/instantiate_template.py ${MODEL_TEMPLATE} ${WORK_DIR}
You can train a model on existing toy dataset training_extensions/data/airport
. Obviously such dataset is not sufficient for training good enough model.
The existing toy dataset has annotation in the Common Objects in Context (COCO) format so it is enough to get started.
export OBJ_DET_DIR=`pwd`
export TRAIN_ANN_FILE="${OBJ_DET_DIR}/../../data/airport/annotation_example_train.json"
export TRAIN_IMG_ROOT="${OBJ_DET_DIR}/../../data/airport/train"
export VAL_ANN_FILE="${OBJ_DET_DIR}/../../data/airport/annotation_example_val.json"
export VAL_IMG_ROOT="${OBJ_DET_DIR}/../../data/airport/val"
cd ${WORK_DIR}
Since custom detection model templates rather than ready-to-use models (though technically one can use them as they are) are provided it is needed to define classes
.
export CLASSES="vehicle,person,non-vehicle"
To start training from pre-trained weights use --load-weights
pararmeter.
python train.py \
--load-weights ${WORK_DIR}/snapshot.pth \
--train-ann-files ${TRAIN_ANN_FILE} \
--train-data-roots ${TRAIN_IMG_ROOT} \
--val-ann-files ${VAL_ANN_FILE} \
--val-data-roots ${VAL_IMG_ROOT} \
--save-checkpoints-to ${WORK_DIR}/outputs \
--classes ${CLASSES}
Also you can use parameters such as --epochs
, --batch-size
, --gpu-num
, --base-learning-rate
, otherwise default values will be loaded from ${MODEL_TEMPLATE}
.
Evaluation procedure allows us to get quality metrics values and complexity numbers such as number of parameters and FLOPs.
To compute MS-COCO metrics and save computed values to ${WORK_DIR}/metrics.yaml
run:
python eval.py \
--load-weights ${WORK_DIR}/outputs/latest.pth \
--test-ann-files ${VAL_ANN_FILE} \
--test-data-roots ${VAL_IMG_ROOT} \
--save-metrics-to ${WORK_DIR}/metrics.yaml \
--classes ${CLASSES}
You can also save images with predicted bounding boxes using --save-output-to
parameter.
python eval.py \
--load-weights ${WORK_DIR}/outputs/latest.pth \
--test-ann-files ${VAL_ANN_FILE} \
--test-data-roots ${VAL_IMG_ROOT} \
--save-metrics-to ${WORK_DIR}/metrics.yaml \
--save-output-to ${WORK_DIR}/output_images \
--classes ${CLASSES}
To convert PyTorch* model to the OpenVINO™ IR format run the export.py
script:
python export.py \
--load-weights ${WORK_DIR}/outputs/latest.pth \
--save-model-to ${WORK_DIR}/export
This produces model model.xml
and weights model.bin
in single-precision floating-point format
(FP32). The obtained model expects normalized image in planar BGR format.
For SSD networks an alternative OpenVINO™ representation is saved automatically to ${WORK_DIR}/export/alt_ssd_export
folder.
SSD model exported in such way will produce a bit different results (non-significant in most cases),
but it also might be faster than the default one. As a rule SSD models in Open Model Zoo are exported using this option.
Instead of passing snapshot.pth
you need to pass path to model.bin
.
python eval.py \
--load-weights ${WORK_DIR}/export/model.bin \
--test-ann-files ${VAL_ANN_FILE} \
--test-data-roots ${VAL_IMG_ROOT} \
--save-metrics-to ${WORK_DIR}/metrics.yaml \
--classes ${CLASSES}