This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
| products:sbc:vim4:npu:demos:retinaface [2023/09/18 01:43] sravan [Retinaface Pytorch VIM4 Demo - 5] | products:sbc:vim4:npu:demos:retinaface [2025/06/11 21:51] (current) louis | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| - | ~~tag> NPU Retinaface | + | ~~tag> NPU RetinaFace | 
| - | ====== | + | **Doc for version ddk-3.4.7.7** | 
| + | |||
| + | ====== | ||
| {{indexmenu_n> | {{indexmenu_n> | ||
| + | |||
| + | ===== Introduction ===== | ||
| + | |||
| + | RetinaFace is a face detection model. It can draw five key points on each face, including two eyes, nose and two corners of mouth. | ||
| + | |||
| + | Inference results on VIM4. | ||
| + | |||
| + | {{: | ||
| + | |||
| + | **Inference speed test**: USB camera about **78ms** per frame. | ||
| + | |||
| ===== Get source code ===== | ===== Get source code ===== | ||
| + | |||
| + | [[gh> | ||
| ```shell | ```shell | ||
| Line 32: | Line 47: | ||
| Follow Docker official documentation to install Docker: [[https:// | Follow Docker official documentation to install Docker: [[https:// | ||
| - | Then fetch the prebuilt NPU Docker | + | Follow | 
| ```shell | ```shell | ||
| - | $ docker pull yanwyb/npu:v1 | + | docker pull numbqq/npu-vim4 | 
| - | $ docker run -it --name | + | |
| - | -v / | + | |
| - | -v / | + | |
| - | yanwyb/ | + | |
| ``` | ``` | ||
| - | ==== Get conversion tool ==== | + | ==== Get Convert Tool ==== | 
| - | Download Tool from [[gl> | + | Download Tool from [[gh> | 
| ```shell | ```shell | ||
| - | $ git clone https://gitlab.com/ | + | $ git lfs install | 
| + | $ git lfs clone https://github.com/ | ||
| + | $ cd vim4_npu_sdk | ||
| + | $ ls | ||
| + | adla-toolkit-binary | ||
| ``` | ``` | ||
| + | |||
| + | * '' | ||
| + | * '' | ||
| + | * '' | ||
| + | |||
| + | <WRAP important> | ||
| + | If your kernel is older than 241129, please use branch npu-ddk-1.7.5.5. | ||
| + | </ | ||
| ==== Convert ==== | ==== Convert ==== | ||
| - | After training the model, we should convert the Pytorch | + | After training the model, we should convert the PyTorch | 
| ```python export.py | ```python export.py | ||
| Line 89: | Line 112: | ||
| --dtypes " | --dtypes " | ||
| --inference-input-type float32 \ | --inference-input-type float32 \ | ||
| - | --inference-output-type float32 \ | + | --inference-output-type float32 \ | 
| --quantize-dtype int8 --outdir onnx_output | --quantize-dtype int8 --outdir onnx_output | ||
| --channel-mean-value " | --channel-mean-value " | ||
| Line 98: | Line 121: | ||
| ``` | ``` | ||
| - | Run '' | + | Run '' | 
| ```shell | ```shell | ||
| Line 113: | Line 136: | ||
| $ git clone https:// | $ git clone https:// | ||
| ``` | ``` | ||
| + | |||
| + | <WRAP important> | ||
| + | If your kernel is older than 241129, please use version before tag ddk-3.4.7.7. | ||
| + | </ | ||
| ==== Install dependencies ==== | ==== Install dependencies ==== | ||
| Line 136: | Line 163: | ||
| # Run | # Run | ||
| - | $ sudo ./ | + | $ ./ | 
| ``` | ``` | ||
| Line 142: | Line 169: | ||
| Put '' | Put '' | ||
| + | |||
| + | == Compile == | ||
| ```shell | ```shell | ||
| - | # Compile | + | $ cd vim4_npu_applications/ | 
| - | $ cd vim4_npu_applications/ | + | |
| $ mkdir build | $ mkdir build | ||
| $ cd build | $ cd build | ||
| $ cmake .. | $ cmake .. | ||
| $ make | $ make | ||
| + | ``` | ||
| - | # Run | + | == Run== | 
| - | $ sudo ./ | + | |
| + | **MIPI Camera** | ||
| + | |||
| + | ``` | ||
| + | $ ./ | ||
| + | ``` | ||
| + | |||
| + | **USB Camera** | ||
| + | ``` | ||
| + | $ cd build | ||
| + | $ ./ | ||
| ``` | ``` | ||
| - | '' | + | **TIP**: Replace 0 as the number for your camera device. Such as '' |