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:yolov7-tiny [2023/09/17 23:01] sravan [Train the model] | products:sbc:vim4:npu:demos:yolov7-tiny [2025/06/12 05:39] (current) louis | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| ~~tag> NPU YOLO OpenCV VIM4 ~~ | ~~tag> NPU YOLO OpenCV VIM4 ~~ | ||
| - | ====== YOLOv7 | + | **Doc for version ddk-3.4.7.7** | 
| + | |||
| + | ====== YOLOv7-tiny VIM4 Demo - 1 ====== | ||
| {{indexmenu_n> | {{indexmenu_n> | ||
| + | |||
| + | ===== Introduction ===== | ||
| + | |||
| + | YOLOv7-Tiny is an object detection model. It uses bounding boxes to precisely draw each object in image. | ||
| + | |||
| + | Inference results on VIM4. | ||
| + | |||
| + | {{: | ||
| + | |||
| + | **Inference speed test**: USB camera about **126ms** per frame. | ||
| ===== Train the model ===== | ===== Train the model ===== | ||
| - | Download the yolov7 | + | Download the YOLOv7 | 
| ```shell | ```shell | ||
| Line 13: | Line 25: | ||
| ``` | ``` | ||
| - | Refer '' | + | Refer '' | 
| ===== Convert the model ===== | ===== Convert the model ===== | ||
| Line 20: | Line 32: | ||
| 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 the conversion tool ==== | ==== Get the conversion tool ==== | ||
| - | Download The conversion tool from [[gl> | + | Download The conversion 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 model, modify '' | + | After training | 
| ```diff | ```diff | ||
| Line 57: | Line 77: | ||
| ``` | ``` | ||
| - | Then, run '' | + | <WRAP important> | 
| + | yolo.py has many forward. Right place is class **IDetect** function **fuseforward**. | ||
| + | </ | ||
| + | |||
| + | Then, run '' | ||
| ```shell | ```shell | ||
| Line 84: | Line 108: | ||
| --quantize-dtype int8 --outdir onnx_output | --quantize-dtype int8 --outdir onnx_output | ||
| --channel-mean-value " | --channel-mean-value " | ||
| + | --inference-input-type " | ||
| + | --inference-output-type " | ||
| --source-file dataset.txt | --source-file dataset.txt | ||
| --batch-size 1 --target-platform PRODUCT_PID0XA003 | --batch-size 1 --target-platform PRODUCT_PID0XA003 | ||
| ``` | ``` | ||
| - | Run '' | + | Run '' | 
| ```shell | ```shell | ||
| Line 104: | Line 130: | ||
| ``` | ``` | ||
| + | |||
| + | <WRAP important> | ||
| + | If your kernel is older than 241129, please use version before tag ddk-3.4.7.7. | ||
| + | </ | ||
| ==== Install dependencies ==== | ==== Install dependencies ==== | ||
| Line 127: | Line 157: | ||
| # Run | # Run | ||
| - | $ sudo ./ | + | $ ./ | 
| ``` | ``` | ||
| Line 143: | Line 173: | ||
| # Run | # Run | ||
| - | $ sudo ./ | + | $ ./ | 
| ``` | ``` | ||
| - | '' | + | '' | 
| <WRAP tip > | <WRAP tip > | ||
| - | If your **yolov7_tiny** model classes | + | If your **YOLOv7-tiny** model classes | 
| </ | </ | ||