# ascend-yolov9-sample **Repository Path**: cumt/ascend-yolov9-sample ## Basic Information - **Project Name**: ascend-yolov9-sample - **Description**: 华为昇腾 Ascend YOLOV8 推理示例 C++ , 基于Ascend Sample官方示例中的sampleYOLOV7进行的YOLOV9适配。 - **Primary Language**: C++ - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 4 - **Forks**: 2 - **Created**: 2024-03-14 - **Last Updated**: 2025-04-17 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Ascend YOLOV9 Sample #### 介绍 华为昇腾 Ascend YOLOV9 推理示例 C++ , 基于Ascend Sample官方示例中的[sampleYOLOV7](https://gitee.com/ascend/samples/tree/master/inference/modelInference/sampleYOLOV7)进行的YOLOV9适配。YOLOV7输出为[1,25200,85],而YOLOV9和YOLOV8输出格式为[1,84,8400],主要差异在于后处理的算法上。 #### 安装教程 1. 硬件为华为Atlas 500 Pro 服务器。 2. 在服务器上安装Ubuntu 20.04操作系统,并正确安装固件、驱动和CANN等依赖性,具体可以参考华为官网,npu-smi info 可以打印相关的NPU信息。 3. 下载官方Ascend Sample官方示例项目[samples](https://gitee.com/ascend/samples),并正确编译和安装ACLLITE库。具体可以参考[sampleYOLOV7](https://gitee.com/ascend/samples/tree/master/inference/modelInference/sampleYOLOV7)中的安装步骤。 yolov9-c-converted.pt模型(https://github.com/WongKinYiu/yolov9/releases/download/v0.1/yolov9-c-converted.pt)转换如下: 在windows操作系统上可以安装YOLOV9环境,并执行如下python脚本将.pt模型转化成.onnx模型: ```python #从base环境创建新的环境yolov9 conda create -n yolov9 --clone base #激活虚拟环境yolov9 conda activate yolov9 #克隆yolov9代码 git clone https://github.com/WongKinYiu/yolov9 # 安装yolov9项目的依赖 (yolov9) I:\yolov9-main>pip install -r requirements.txt # 模型转换导出onnx (yolov9) I:\yolov9-main>python export.py --weights yolov9-c-converted.pt --include onnx ``` 输出如下所示: ```bash (yolov9) I:\yolov9-main>python export.py --weights yolov9-c-converted.pt --include onnx export: data=I:\yolov9-main\data\coco.yaml, weights=['yolov9-c-converted.pt'], imgsz=[640, 640], batch_size=1, device=cpu, half=False, inplace=False, keras=False, optimize=False, int8=False, dynamic=False, simplify=False, opset=12, verbose=False, workspace=4, nms=False, agnostic_nms=False, topk_per_class=100, topk_all=100, iou_thres=0.45, conf_thres=0.25, include=['onnx'] YOLO 2024-3-13 Python-3.11.5 torch-2.1.2 CPU Fusing layers... gelan-c summary: 387 layers, 25288768 parameters, 64944 gradients, 102.1 GFLOPs PyTorch: starting from yolov9-c-converted.pt with output shape (1, 84, 8400) (49.1 MB) ONNX: starting export with onnx 1.15.0... ONNX: export success 2.9s, saved as yolov9-c-converted.onnx (96.8 MB) Export complete (4.4s) Results saved to I:\yolov9-main Detect: python detect.py --weights yolov9-c-converted.onnx Validate: python val.py --weights yolov9-c-converted.onnx PyTorch Hub: model = torch.hub.load('ultralytics/yolov5', 'custom', 'yolov9-c-converted.onnx') Visualize: https://netron.app ``` 查看onnx模型的网格结构,执行如下命令: ```bash (yolov9) I:\yolov9-main>netron yolov9-c-converted.onnx Serving 'yolov9-c-converted.onnx' at http://localhost:8080 ``` 浏览器打开http://localhost:8080,可以查看网络结构的输入和输出,输入为[1,3,640,640],输出为[1,84,8400]. ![yolov9_inputoutput]() 将yolov9-c-converted.onnx模型上传到Atlas 500 Pro服务器上,在ascend-yolov9-sample-master/model目录下执行如下命令进行模型转换: ```bash atc --model=yolov9-c-converted.onnx --framework=5 --output=yolov9-c-converted --input_shape="images:1,3,640,640" --soc_version=Ascend310P3 --insert_op_conf=aipp.cfg ``` 其中的: --soc_version=Ascend310P3可以通过npu-smi info命令进行查看,我这里打印的是 310P3 则,--soc_version 为 Ascend前缀加上310P3,即Ascend310P3。 --input_shape="images:1,3,640,640" 表示NCHW,即批处理为1,通道为3,图片大小为640x640 。 --insert_op_conf=aipp.cfg 中的aipp.cfg来自官网[sampleYOLOV7](https://gitee.com/ascend/samples/tree/master/inference/modelInference/sampleYOLOV7)示例。 #### 使用说明 1. SSH登录服务器,切换到root用户 2. 进入Ascend YOLOV9 Sample项目目录,如果是压缩包,可以用unzip 进行解压: ```bash ascend-yolov9-sample-master.zip -d ./kztech cd ascend-yolov9-sample-master/src ``` 模型转化按上述方式进行。 3. 编译执行 ```bash # src目录下 cmake . make #如果正确执行,则会在../out目录中生成 sampleYOLOV9 可执行文件,在src目录中运行示例 ../out/sampleYOLOV9 #如果报如下错误: ../out/sampleYOLOV9: error while loading shared libraries: libswresample.so.3: cannot open shared object file: No such file or directory 则尝试设置如下环境变量后重试: export LD_LIBRARY_PATH=/usr/local/Ascend/thirdpart/aarch64/lib:$LD_LIBRARY_PATH #正确执行后,会在当前目录中生成out_0.jpg文件 ``` 执行成功,控制台打印如下信息: ```bash root@atlas500ai:/home/kztech/ascend-yolov9-sample-master/src# ../out/sampleYOLOV9 [INFO] Acl init ok [INFO] Open device 0 ok [INFO] Use default context currently [INFO] dvpp init resource ok [INFO] Load model ../model/yolov9-c-converted.om success [INFO] Create model description success [INFO] Create model(../model/yolov9-c-converted.om) output success [INFO] Init model ../model/yolov9-c-converted.om success [INFO] filter boxes by confidence threshold > 0.350000 success, boxes size is 10 [INFO] filter boxes by NMS threshold > 0.450000 success, result size is 1 [INFO] object detect [0.954102:dog] success [INFO] Inference elapsed time : 0.049535 s , fps is 20.187815 [INFO] Unload model ../model/yolov9-c-converted.om success [INFO] destroy context ok [INFO] Reset device 0 ok [INFO] Finalize acl ok ``` out_0.jpg输出结果如下: ![out_0.jpg](./src/out_0.jpg) #### 参与贡献 1. Fork 本仓库 2. 提交代码 3. 新建 Pull Request