~~tag> NPU RetinaFace VIM4 PyTorch~~
**Doc for version ddk-3.4.7.7**
====== RetinaFace PyTorch VIM4 Demo - 5 ======
{{indexmenu_n>5}}
===== Get source code =====
[[gh>bubbliiiing/retinaface-pytorch]]
```shell
$ git clone https://github.com/bubbliiiing/retinaface-pytorch
```
Before training, modify ''retinaface-pytorch/utils/utils.py'' as follows.
```diff
diff --git a/utils/utils.py b/utils/utils.py
index 87bb528..4a22f2a 100644
--- a/utils/utils.py
+++ b/utils/utils.py
@@ -25,5 +25,6 @@ def get_lr(optimizer):
return param_group['lr']
def preprocess_input(image):
- image -= np.array((104, 117, 123),np.float32)
+ image = image / 255.0
return image
```
===== Convert the model =====
==== Build virtual environment ====
Follow Docker official documentation to install Docker: [[https://docs.docker.com/engine/install/ubuntu/|Install Docker Engine on Ubuntu]].
Follow the script below to get Docker image:
```shell
docker pull numbqq/npu-vim4
```
==== Get Convert Tool ====
Download Tool from [[gh>khadas/vim4_npu_sdk]].
```shell
$ git lfs install
$ git lfs clone https://github.com/khadas/vim4_npu_sdk
$ cd vim4_npu_sdk
$ ls
adla-toolkit-binary adla-toolkit-binary-3.1.7.4 convert-in-docker.sh Dockerfile docs README.md
```
* ''adla-toolkit-binary/docs'' - SDK documentations
* ''adla-toolkit-binary/bin'' - SDK tools required for model conversion
* ''adla-toolkit-binary/demo'' - Conversion examples
If your kernel is older than 241129, please use branch npu-ddk-1.7.5.5.
==== Convert ====
After training the model, we should convert the PyTorch model into an ONNX model. Create the Python conversion script as follows and run.
```python export.py
import torch
import numpy as np
from nets.retinaface import RetinaFace
from utils.config import cfg_mnet, cfg_re50
model_path = "logs/Epoch150-Total_Loss6.2802.pth"
net = RetinaFace(cfg=cfg_mnet, mode='eval').eval()
device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')
net.load_state_dict(torch.load(model_path, map_location=device))
img = torch.zeros(1, 3, 640, 640)
torch.onnx.export(net, img, "./retinaface.onnx", verbose=False, opset_version=12, input_names=['images'])
```
Enter ''vim4_npu_sdk/demo'' and modify ''convert_adla.sh'' as follows.
```bash convert_adla.sh
#!/bin/bash
ACUITY_PATH=../bin/
#ACUITY_PATH=../python/tvm/
adla_convert=${ACUITY_PATH}adla_convert
if [ ! -e "$adla_convert" ]; then
adla_convert=${ACUITY_PATH}adla_convert.py
fi
$adla_convert --model-type onnx \
--model ./model_source/retinaface/retinaface.onnx \
--inputs "images" \
--input-shapes "3,640,640" \
--dtypes "float32" \
--inference-input-type float32 \
--inference-output-type float32 \
--quantize-dtype int8 --outdir onnx_output \
--channel-mean-value "0,0,0,255" \
--source-file ./retinaface_dataset.txt \
--iterations 500 \
--disable-per-channel False \
--batch-size 1 --target-platform PRODUCT_PID0XA003
```
Run ''convert_adla.sh'' to generate the VIM4 model. The converted model is ''xxx.adla'' in ''onnx_output''.
```shell
$ bash convert_adla.sh
```
===== Run inference on the NPU =====
==== Get source code ====
Clone the source code [[gh>khadas/vim4_npu_applications]].
```shell
$ git clone https://github.com/khadas/vim4_npu_applications
```
If your kernel is older than 241129, please use version before tag ddk-3.4.7.7.
==== Install dependencies ====
```shell
$ sudo apt update
$ sudo apt install libopencv-dev python3-opencv cmake
```
==== Compile and run ====
=== Picture input demo ===
Put ''retinaface_int8.adla'' in ''vim4_npu_applications/retinaface/data/''.
```shell
# Compile
$ cd vim4_npu_applications/retinaface
$ mkdir build
$ cd build
$ cmake ..
$ make
# Run
$ ./retinaface -m ../data/retinaface_int8.adla -p ../data/timg.jpg
```
{{:products:sbc:vim4:npu:demos:retinaface-demo-output.webp?800|}}
=== Camera input demo ===
Put ''retinaface_int8.adla'' in ''vim4_npu_applications/retinaface_cap/data/''.
== Compile ==
```shell
$ cd vim4_npu_applications/face_recognition_cap
$ mkdir build
$ cd build
$ cmake ..
$ make
```
== Run==
**MIPI Camera**
```
$ ./retinaface_cap -m ../data/retinaface_int8.adla -t mipi
```
**USB Camera**
```
$ cd build
$ ./retinaface_cap -m ../data/retinaface_int8.adla -t usb -d 0
```
**TIP**: Replace 0 as the number for your camera device. Such as ''/dev/video5'', it should be ''-d 5''.