Skip to content

AxisCommunications/axis-model-zoo

Copyright (C) 2023, Axis Communications AB, Lund, Sweden. All Rights Reserved.

Axis Model Zoo

Axis network cameras can be used for computer vision applications and can run machine learning models to make inferences. The model to use will depend on your device and your application. This repository contains a collection of different models compatible with Axis cameras and some performance measures (accuracy and speed). Our goal is to keep updating this collection with models for different applications, like object detection or pose estimation. For easy reproduction, we mostly use models that are public and we also share tools to benchmark the models. We have linked the model files and, in case they are public, the ckpt files to continue the training. The values of speed and accuracy are going to be updated with every AXIS OS release.

Note : These are not production-quality models, they are off-the-shelf models used for comparative and demonstration purposes only.

Guides

Models

Image classification

Platform Model TF version Speed Accuracy
ARTPEC-7 (Q1615 Mk III) MobilenetV2 (ckpt) 1 4.56 ms Top 1: 68.9%
Top 5: 88.2%
ARTPEC-7 (Q1615 Mk III) MobilenetV2 2 4.52 ms Top 1: 69.6%
Top 5: 89.1%
ARTPEC-7 (Q1615 Mk III) MobilenetV3 2 4.72 ms Top 1: 72.7%
Top 5: 91.1%
ARTPEC-8 (P1465-LE) MobilenetV2 (ckpt) 1 9.83 ms Top 1: 68.8%
Top 5: 88.9%
ARTPEC-8 (Q1656-LE) MobilenetV2 (ckpt) 1 5.36 ms Top 1: 68.8%
Top 5: 88.9%
ARTPEC-9 (Q1728) MobilenetV2 (ckpt) 1 2.54 ms Top 1: 68.8%
Top 5: 88.9%
CV25 (M3085-V) MobilenetV2 (ckpt) 1 5.56 ms Top 1: 66.7%
Top 5: 87.1%
CV25 (M3085-V) EfficientNet-Lite0 (ckpt) 1 6.96 ms Top 1: 71.2%
Top 5: 90.3%

Object detection

Platform Model Speed Accuracy
ARTPEC-7 (Q1615 Mk III) SSD MobileNet v2 17.68 ms mAP: 25.6%
ARTPEC-7 (Q1615 Mk III) SSDLite MobileDet 30.56 ms mAP: 32.9%
ARTPEC-8 (P1465-LE) SSD MobilenetV2 29.30 ms mAP: 25.6%
ARTPEC-8 (P1465-LE) SSDLite MobileDet 41.30 ms mAP: 32.9%
ARTPEC-8 (P1465-LE) Yolov5n-Artpec8 (ckpt) 100.00 ms mAP: 23.5%
ARTPEC-8 (Q1656-LE) SSD MobilenetV2 18.82 ms mAP: 25.6%
ARTPEC-8 (Q1656-LE) SSDLite MobileDet 31.19 ms mAP: 32.9%
ARTPEC-8 (Q1656-LE) Yolov5n-Artpec8 (ckpt) 54.71 ms mAP: 23.5%
ARTPEC-8 (Q1656-LE) Yolov5s-Artpec8 (ckpt) 69.42 ms mAP: 32.3%
ARTPEC-8 (Q1656-LE) Yolov5m-Artpec8 (ckpt) 94.67 ms mAP: 37.9%
ARTPEC-9 (Q1728) SSD MobilenetV2 13.23 ms mAP: 25.6%
ARTPEC-9 (Q1728) SSDLite MobileDet 25.42 ms mAP: 32.9%
ARTPEC-9 (Q1728) Yolov5n-Artpec9 (ckpt) 41.83 ms mAP: 23.3%
ARTPEC-9 (Q1728) Yolov5s-Artpec9 (ckpt) 45.06 ms mAP: 32.2%
ARTPEC-9 (Q1728) Yolov5m-Artpec9 (ckpt) 53.19 ms mAP: 38.1%

Values for AXIS OS 12.2.52.

How are the measures calculated?

The auto-test-framework directory holds the code for measuring the speed numbers and automating their update in the repository. For now, the accuracy measures are not included in this pipeline. Apart from that, in the accuracy-test there is the code to measure the accuracy and model_performance_tester.py is a script to measure the speed.

Speed measure

In the case of the automated test framework, the test is done by installing and running an ACAP application on the Axis camera. To know more about how it works, see the larod-test directory.

To get speed measures more easily, you can use the code in model_performance_tester.py. This script connects to the Axis camera via SSH and uses the larod-client to run inferences. It then parses the output, which will be the mean of time the Axis camera spent on the inferences. These inferences are done on randomly generated images. See below how to use the script:

python3 ./scripts/model_performance_tester.py \
        --model_path <MODEL_PATH> --test_duration <DURATION> \
        --chip <CHIP> --device_ip <IP> --device_credentials <USER> <PASS> --device_port <SSH_PORT>
  • <MODEL_PATH> is the path to your .tflite or .bin model.
  • <DURATION> is the number of inferences to run.
  • <CHIP> is the larod device to use; CPU, A9-DLPU, A8-DLPU, A7-GPU, A7-TPU, CV25.
  • <IP> is the IP of the device.
  • <USER>, <PASS> are the device credentials.
  • <SSH_PORT> is the device port for ssh, default is port 22.

Accuracy measure

This test is done by installing and running an ACAP application on the Axis camera. To know more about how it works, see the accuracy-test directory.

License

Apache 2.0