jounery-d commited on
Commit
413201e
·
verified ·
1 Parent(s): 1934440

Upload 2 files

Browse files
Files changed (2) hide show
  1. models/readme.txt +61 -0
  2. models/yolov8n.onnx +3 -0
models/readme.txt ADDED
@@ -0,0 +1,61 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ #模型修改说明:
2
+ 为了适配5x系列NPU,Yolo系列模型结构需要做一些修改,这里以ultralytics项目的YoloV8检测模型为例,需要修改如下:
3
+ 项目官方位置:
4
+ ```
5
+ https://github.com/ultralytics/ultralytics
6
+ ```
7
+
8
+ ### 1、修改激活函数:
9
+ 5x系列NPU不支持silu算子,因此激活函数需要修改act为leaky relu或relu算子,修改的文件如下:
10
+ ```
11
+ https://github.com/ultralytics/ultralytics/blob/main/ultralytics/nn/modules/conv.py
12
+ ```
13
+ 将第50行修改为:
14
+ ```
15
+ default_act = nn.LeakyReLU() # default activation
16
+ ```
17
+ 或者:
18
+ ```
19
+ default_act = nn.ReLU() # default activation
20
+ ```
21
+
22
+ ### 2、模型最大channel数限制:
23
+ 5x系列NPU支持最大的channel数为:1024,如果模型结构的某一层的channel数大于1024,需要将该层的channel数修改为<=1024;
24
+ channel数可以再模型yaml描述文件中进行修改,yolov8.yaml文件位置:
25
+ ```
26
+ https://github.com/ultralytics/ultralytics/blob/main/ultralytics/cfg/models/v8/yolov8.yaml
27
+ ```
28
+
29
+ ### 3、模型重训练及onnx导出
30
+ 基于上述2处修改完成后,对模型进行重训练,生成训练模型:yolov8n.pt,然后进行onnx导出;
31
+
32
+ ultralytics导出yolov8模型onnx的代码如下:
33
+ ```
34
+ from ultralytics import YOLO
35
+ model = YOLO("yolov8n.pt")
36
+ path = model.export(format="onnx", imgsz=640, opset=11) # 返回导出模型的路径
37
+ ```
38
+ *注意:opset需设置为11,imgsz根据需要进行设置
39
+
40
+ 但是直接导出的onnx会将模型head部分的decode_bboxes算子带上,导致工具转换无法通过,decode_bboxes算子5x系列npu无法支持,需要通过cpu进行实现,
41
+ 所以导出onnx不能带上decode_bboxes部分,需要进行修改:
42
+ 修改文件:
43
+ ```
44
+ https://github.com/ultralytics/ultralytics/blob/main/ultralytics/nn/modules/head.py
45
+ ```
46
+ 将125行代码:
47
+ ```
48
+ y = self._inference(x)
49
+ ```
50
+ 修改为:
51
+ ```
52
+ if self.export:
53
+ y = x
54
+ else:
55
+ y = self._inference(x)
56
+ ```
57
+
58
+ 或者使用第三方工具手动裁剪onnx
59
+
60
+ ### 模型转换生成axmodel及上板测试
61
+ 参考:
models/yolov8n.onnx ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:e2f09e6e00fe63c38e5066128696d959d3fd532eb305f29736dc1c8e29472823
3
+ size 12641024