👷 [Add] more pre-commit, yaml-check & nbsripout
Browse files- .gitignore +1 -1
- .pre-commit-config.yaml +13 -1
- README.md +3 -3
- docs/CONTRIBUTING.md +0 -2
- docs/HOWTO.md +4 -4
- pyproject.toml +1 -1
- requirements.txt +1 -1
- yolo/config/config.yaml +0 -1
- yolo/config/dataset/coco.yaml +2 -2
- yolo/config/dataset/dev.yaml +1 -1
- yolo/config/general.yaml +1 -1
- yolo/config/model/v7-base.yaml +107 -107
- yolo/config/model/v9-c.yaml +8 -8
- yolo/config/task/inference.yaml +1 -1
- yolo/config/task/train.yaml +2 -2
- yolo/config/task/validation.yaml +1 -1
- yolo/utils/logging_utils.py +3 -3
.gitignore
CHANGED
@@ -145,4 +145,4 @@ runs
|
|
145 |
node_modules/
|
146 |
|
147 |
# Not ignore image for demo
|
148 |
-
!demo/images/inference/*
|
|
|
145 |
node_modules/
|
146 |
|
147 |
# Not ignore image for demo
|
148 |
+
!demo/images/inference/*
|
.pre-commit-config.yaml
CHANGED
@@ -6,9 +6,21 @@ repos:
|
|
6 |
language_version: python3 # Specify the Python version
|
7 |
exclude: '.*\.yaml$' # Regex pattern to exclude all YAML files
|
8 |
args: ["--line-length", "120"] # Set max line length to 100 characters
|
9 |
-
|
10 |
- repo: https://github.com/pre-commit/mirrors-isort
|
11 |
rev: v5.10.1 # Use the appropriate version or "stable" for the latest stable release
|
12 |
hooks:
|
13 |
- id: isort
|
14 |
args: ["--profile", "black"]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
6 |
language_version: python3 # Specify the Python version
|
7 |
exclude: '.*\.yaml$' # Regex pattern to exclude all YAML files
|
8 |
args: ["--line-length", "120"] # Set max line length to 100 characters
|
9 |
+
|
10 |
- repo: https://github.com/pre-commit/mirrors-isort
|
11 |
rev: v5.10.1 # Use the appropriate version or "stable" for the latest stable release
|
12 |
hooks:
|
13 |
- id: isort
|
14 |
args: ["--profile", "black"]
|
15 |
+
|
16 |
+
- repo: https://github.com/pre-commit/pre-commit-hooks
|
17 |
+
rev: v3.4.0
|
18 |
+
hooks:
|
19 |
+
- id: trailing-whitespace
|
20 |
+
- id: end-of-file-fixer
|
21 |
+
- id: check-yaml
|
22 |
+
|
23 |
+
- repo: https://github.com/kynan/nbstripout
|
24 |
+
rev: 0.5.0
|
25 |
+
hooks:
|
26 |
+
- id: nbstripout
|
README.md
CHANGED
@@ -3,7 +3,7 @@
|
|
3 |

|
4 |
> [!IMPORTANT]
|
5 |
> This project is currently a Work In Progress and may undergo significant changes. It is not recommended for use in production environments until further notice. Please check back regularly for updates.
|
6 |
-
>
|
7 |
> Use of this code is at your own risk and discretion. It is advisable to consult with the project owner before deploying or integrating into any critical systems.
|
8 |
|
9 |
Welcome to the official implementation of YOLOv7 and YOLOv9. This repository will contains the complete codebase, pre-trained models, and detailed instructions for training and deploying YOLOv9.
|
@@ -80,11 +80,11 @@ Contributions to the YOLOv9 project are welcome! See [CONTRIBUTING](docs/CONTRIB
|
|
80 |
## Citations
|
81 |
```
|
82 |
@misc{wang2024yolov9,
|
83 |
-
title={YOLOv9: Learning What You Want to Learn Using Programmable Gradient Information},
|
84 |
author={Chien-Yao Wang and I-Hau Yeh and Hong-Yuan Mark Liao},
|
85 |
year={2024},
|
86 |
eprint={2402.13616},
|
87 |
archivePrefix={arXiv},
|
88 |
primaryClass={cs.CV}
|
89 |
}
|
90 |
-
```
|
|
|
3 |

|
4 |
> [!IMPORTANT]
|
5 |
> This project is currently a Work In Progress and may undergo significant changes. It is not recommended for use in production environments until further notice. Please check back regularly for updates.
|
6 |
+
>
|
7 |
> Use of this code is at your own risk and discretion. It is advisable to consult with the project owner before deploying or integrating into any critical systems.
|
8 |
|
9 |
Welcome to the official implementation of YOLOv7 and YOLOv9. This repository will contains the complete codebase, pre-trained models, and detailed instructions for training and deploying YOLOv9.
|
|
|
80 |
## Citations
|
81 |
```
|
82 |
@misc{wang2024yolov9,
|
83 |
+
title={YOLOv9: Learning What You Want to Learn Using Programmable Gradient Information},
|
84 |
author={Chien-Yao Wang and I-Hau Yeh and Hong-Yuan Mark Liao},
|
85 |
year={2024},
|
86 |
eprint={2402.13616},
|
87 |
archivePrefix={arXiv},
|
88 |
primaryClass={cs.CV}
|
89 |
}
|
90 |
+
```
|
docs/CONTRIBUTING.md
CHANGED
@@ -40,5 +40,3 @@ Once you submit a PR, maintainers will review your work, suggest changes if nece
|
|
40 |
Your contributions are greatly appreciated and vital to the project's success!
|
41 |
|
42 |
Please feel free to contact [[email protected]](mailto:[email protected])!
|
43 |
-
|
44 |
-
|
|
|
40 |
Your contributions are greatly appreciated and vital to the project's success!
|
41 |
|
42 |
Please feel free to contact [[email protected]](mailto:[email protected])!
|
|
|
|
docs/HOWTO.md
CHANGED
@@ -7,7 +7,7 @@ To facilitate easy customization of the YOLO model, we've structured the codebas
|
|
7 |
You can change the model architecture simply by modifying the YAML configuration file. Here's how:
|
8 |
|
9 |
1. **Modify Architecture in Config:**
|
10 |
-
|
11 |
Navigate to your model's configuration file (typically formate like `yolo/config/model/v9-c.yaml`).
|
12 |
- Adjust the architecture settings under the `architecture` section. Ensure that every module you reference exists in `module.py`, or refer to the next section on how to add new modules.
|
13 |
|
@@ -40,7 +40,7 @@ To add or modify a block in the model:
|
|
40 |
1. **Create a New Module:**
|
41 |
|
42 |
Define a new class in `module.py` that inherits from `nn.Module`.
|
43 |
-
|
44 |
The constructor should accept `in_channels` as a parameter. Make sure to calculate `out_channels` based on your model's requirements or configure it through the YAML file using `args`.
|
45 |
|
46 |
```python
|
@@ -49,7 +49,7 @@ To add or modify a block in the model:
|
|
49 |
super().__init__()
|
50 |
self.module = # conv, bool, ...
|
51 |
def forward(self, x):
|
52 |
-
return self.module(x)
|
53 |
```
|
54 |
|
55 |
2. **Reference in Config:**
|
@@ -145,4 +145,4 @@ Custom transformations should be designed to accept an image and its bounding bo
|
|
145 |
- **loss**
|
146 |
- `class` BoxLoss: a Custom Loss for bounding box
|
147 |
- `class` YOLOLoss: a implementation of yolov9 loss
|
148 |
-
- `class` DualLoss: a implementation of yolov9 loss with auxiliary detection head
|
|
|
7 |
You can change the model architecture simply by modifying the YAML configuration file. Here's how:
|
8 |
|
9 |
1. **Modify Architecture in Config:**
|
10 |
+
|
11 |
Navigate to your model's configuration file (typically formate like `yolo/config/model/v9-c.yaml`).
|
12 |
- Adjust the architecture settings under the `architecture` section. Ensure that every module you reference exists in `module.py`, or refer to the next section on how to add new modules.
|
13 |
|
|
|
40 |
1. **Create a New Module:**
|
41 |
|
42 |
Define a new class in `module.py` that inherits from `nn.Module`.
|
43 |
+
|
44 |
The constructor should accept `in_channels` as a parameter. Make sure to calculate `out_channels` based on your model's requirements or configure it through the YAML file using `args`.
|
45 |
|
46 |
```python
|
|
|
49 |
super().__init__()
|
50 |
self.module = # conv, bool, ...
|
51 |
def forward(self, x):
|
52 |
+
return self.module(x)
|
53 |
```
|
54 |
|
55 |
2. **Reference in Config:**
|
|
|
145 |
- **loss**
|
146 |
- `class` BoxLoss: a Custom Loss for bounding box
|
147 |
- `class` YOLOLoss: a implementation of yolov9 loss
|
148 |
+
- `class` DualLoss: a implementation of yolov9 loss with auxiliary detection head
|
pyproject.toml
CHANGED
@@ -31,4 +31,4 @@ requires = [
|
|
31 |
]
|
32 |
|
33 |
[project.scripts]
|
34 |
-
yolo = "yolo.lazy:main"
|
|
|
31 |
]
|
32 |
|
33 |
[project.scripts]
|
34 |
+
yolo = "yolo.lazy:main"
|
requirements.txt
CHANGED
@@ -12,4 +12,4 @@ rich
|
|
12 |
torch
|
13 |
torchvision
|
14 |
tqdm
|
15 |
-
wandb
|
|
|
12 |
torch
|
13 |
torchvision
|
14 |
tqdm
|
15 |
+
wandb
|
yolo/config/config.yaml
CHANGED
@@ -10,4 +10,3 @@ defaults:
|
|
10 |
- dataset: coco
|
11 |
- model: v9-c
|
12 |
- general
|
13 |
-
|
|
|
10 |
- dataset: coco
|
11 |
- model: v9-c
|
12 |
- general
|
|
yolo/config/dataset/coco.yaml
CHANGED
@@ -8,7 +8,7 @@ auto_download:
|
|
8 |
train2017:
|
9 |
file_name: train2017
|
10 |
file_num: 118287
|
11 |
-
val2017:
|
12 |
file_name: val2017
|
13 |
file_num: 5000
|
14 |
test2017:
|
@@ -17,4 +17,4 @@ auto_download:
|
|
17 |
annotations:
|
18 |
base_url: http://images.cocodataset.org/annotations/
|
19 |
annotations:
|
20 |
-
file_name: annotations_trainval2017
|
|
|
8 |
train2017:
|
9 |
file_name: train2017
|
10 |
file_num: 118287
|
11 |
+
val2017:
|
12 |
file_name: val2017
|
13 |
file_num: 5000
|
14 |
test2017:
|
|
|
17 |
annotations:
|
18 |
base_url: http://images.cocodataset.org/annotations/
|
19 |
annotations:
|
20 |
+
file_name: annotations_trainval2017
|
yolo/config/dataset/dev.yaml
CHANGED
@@ -2,4 +2,4 @@ path: data/dev
|
|
2 |
train: train
|
3 |
validation: test
|
4 |
|
5 |
-
auto_download:
|
|
|
2 |
train: train
|
3 |
validation: test
|
4 |
|
5 |
+
auto_download:
|
yolo/config/general.yaml
CHANGED
@@ -12,4 +12,4 @@ lucky_number: 10
|
|
12 |
use_wandb: False
|
13 |
use_TensorBoard: False
|
14 |
|
15 |
-
weight: weights/v9-c.pt
|
|
|
12 |
use_wandb: False
|
13 |
use_TensorBoard: False
|
14 |
|
15 |
+
weight: weights/v9-c.pt
|
yolo/config/model/v7-base.yaml
CHANGED
@@ -4,243 +4,243 @@ anchor:
|
|
4 |
|
5 |
model:
|
6 |
backbone:
|
7 |
-
- Conv:
|
8 |
args: {out_channels: 32, kernel_size: 3}
|
9 |
-
- Conv:
|
10 |
args: {out_channels: 64, kernel_size: 3, stride: 2}
|
11 |
-
- Conv:
|
12 |
args: {out_channels: 64, kernel_size: 3}
|
13 |
-
- Conv:
|
14 |
args: {out_channels: 128, kernel_size: 3, stride: 2}
|
15 |
-
- Conv:
|
16 |
args: {out_channels: 64, kernel_size: 1}
|
17 |
-
- Conv:
|
18 |
args: {out_channels: 64, kernel_size: 1}
|
19 |
source: -2
|
20 |
-
- Conv:
|
21 |
args: {out_channels: 64, kernel_size: 3}
|
22 |
-
- Conv:
|
23 |
args: {out_channels: 64, kernel_size: 3}
|
24 |
-
- Conv:
|
25 |
args: {out_channels: 64, kernel_size: 3}
|
26 |
-
- Conv:
|
27 |
args: {out_channels: 64, kernel_size: 3}
|
28 |
-
- Concat:
|
29 |
source: [-1, -3, -5, -6]
|
30 |
-
- Conv:
|
31 |
args: {out_channels: 256, kernel_size: 1}
|
32 |
-
- Pool:
|
33 |
args: {padding: 0}
|
34 |
-
- Conv:
|
35 |
args: {out_channels: 128, kernel_size: 1}
|
36 |
-
- Conv:
|
37 |
args: {out_channels: 128, kernel_size: 1}
|
38 |
source: -3
|
39 |
-
- Conv:
|
40 |
args: {out_channels: 128, kernel_size: 3, stride: 2}
|
41 |
-
- Concat:
|
42 |
source: [-1, -3]
|
43 |
-
- Conv:
|
44 |
args: {out_channels: 128, kernel_size: 1}
|
45 |
-
- Conv:
|
46 |
args: {out_channels: 128, kernel_size: 1}
|
47 |
source: -2
|
48 |
-
- Conv:
|
49 |
args: {out_channels: 128, kernel_size: 3}
|
50 |
-
- Conv:
|
51 |
args: {out_channels: 128, kernel_size: 3}
|
52 |
-
- Conv:
|
53 |
args: {out_channels: 128, kernel_size: 3}
|
54 |
-
- Conv:
|
55 |
args: {out_channels: 128, kernel_size: 3}
|
56 |
-
- Concat:
|
57 |
source: [-1, -3, -5, -6]
|
58 |
tags: 8x
|
59 |
-
- Conv:
|
60 |
args: {out_channels: 512, kernel_size: 1}
|
61 |
-
- Pool:
|
62 |
args: {padding: 0}
|
63 |
-
- Conv:
|
64 |
args: {out_channels: 256, kernel_size: 1}
|
65 |
-
- Conv:
|
66 |
args: {out_channels: 256, kernel_size: 1}
|
67 |
source: -3
|
68 |
-
- Conv:
|
69 |
args: {out_channels: 256, kernel_size: 3, stride: 2}
|
70 |
-
- Concat:
|
71 |
source: [-1, -3]
|
72 |
-
- Conv:
|
73 |
args: {out_channels: 256, kernel_size: 1}
|
74 |
-
- Conv:
|
75 |
args: {out_channels: 256, kernel_size: 1}
|
76 |
source: -2
|
77 |
-
- Conv:
|
78 |
args: {out_channels: 256, kernel_size: 3}
|
79 |
-
- Conv:
|
80 |
args: {out_channels: 256, kernel_size: 3}
|
81 |
-
- Conv:
|
82 |
args: {out_channels: 256, kernel_size: 3}
|
83 |
-
- Conv:
|
84 |
args: {out_channels: 256, kernel_size: 3}
|
85 |
-
- Concat:
|
86 |
source: [-1, -3, -5, -6]
|
87 |
-
- Conv:
|
88 |
args: {out_channels: 1024, kernel_size: 1}
|
89 |
tags: 16x
|
90 |
-
- Pool:
|
91 |
args: {padding: 0}
|
92 |
-
- Conv:
|
93 |
args: {out_channels: 512, kernel_size: 1}
|
94 |
-
- Conv:
|
95 |
args: {out_channels: 512, kernel_size: 1}
|
96 |
source: -3
|
97 |
-
- Conv:
|
98 |
args: {out_channels: 512, kernel_size: 3, stride: 2}
|
99 |
-
- Concat:
|
100 |
source: [-1, -3]
|
101 |
-
- Conv:
|
102 |
args: {out_channels: 256, kernel_size: 1}
|
103 |
-
- Conv:
|
104 |
args: {out_channels: 256, kernel_size: 1}
|
105 |
source: -2
|
106 |
-
- Conv:
|
107 |
args: {out_channels: 256, kernel_size: 3}
|
108 |
-
- Conv:
|
109 |
args: {out_channels: 256, kernel_size: 3}
|
110 |
-
- Conv:
|
111 |
args: {out_channels: 256, kernel_size: 3}
|
112 |
-
- Conv:
|
113 |
args: {out_channels: 256, kernel_size: 3}
|
114 |
-
- Concat:
|
115 |
source: [-1, -3, -5, -6]
|
116 |
-
- Conv:
|
117 |
args: {out_channels: 1024, kernel_size: 1}
|
118 |
tags: 32x
|
119 |
head:
|
120 |
-
- SPPCSPConv:
|
121 |
args: {out_channels: 512}
|
122 |
-
- Conv:
|
123 |
args: {out_channels: 256, kernel_size: 1}
|
124 |
-
- UpSample:
|
125 |
args: {scale_factor: 2}
|
126 |
-
- Conv:
|
127 |
args: {out_channels: 256, kernel_size: 1}
|
128 |
source: 16x
|
129 |
-
- Concat:
|
130 |
source: [-1, -2]
|
131 |
-
- Conv:
|
132 |
args: {out_channels: 256, kernel_size: 1}
|
133 |
-
- Conv:
|
134 |
args: {out_channels: 256, kernel_size: 1}
|
135 |
source: -2
|
136 |
-
- Conv:
|
137 |
args: {out_channels: 128, kernel_size: 3}
|
138 |
-
- Conv:
|
139 |
args: {out_channels: 128, kernel_size: 3}
|
140 |
-
- Conv:
|
141 |
args: {out_channels: 128, kernel_size: 3}
|
142 |
-
- Conv:
|
143 |
args: {out_channels: 128, kernel_size: 3}
|
144 |
-
- Concat:
|
145 |
source: [-1, -2, -3, -4, -5, -6]
|
146 |
-
- Conv:
|
147 |
args: {out_channels: 256, kernel_size: 1}
|
148 |
-
- Conv:
|
149 |
args: {out_channels: 128, kernel_size: 1}
|
150 |
-
- UpSample:
|
151 |
args: {scale_factor: 2}
|
152 |
-
- Conv:
|
153 |
args: {out_channels: 128, kernel_size: 1}
|
154 |
source: 8x
|
155 |
-
- Concat:
|
156 |
source: [-1, -2]
|
157 |
-
- Conv:
|
158 |
args: {out_channels: 128, kernel_size: 1}
|
159 |
-
- Conv:
|
160 |
args: {out_channels: 128, kernel_size: 1}
|
161 |
source: -2
|
162 |
-
- Conv:
|
163 |
args: {out_channels: 64, kernel_size: 3}
|
164 |
-
- Conv:
|
165 |
args: {out_channels: 64, kernel_size: 3}
|
166 |
-
- Conv:
|
167 |
args: {out_channels: 64, kernel_size: 3}
|
168 |
-
- Conv:
|
169 |
args: {out_channels: 64, kernel_size: 3}
|
170 |
-
- Concat:
|
171 |
source: [-1, -2, -3, -4, -5, -6]
|
172 |
-
- Conv:
|
173 |
args: {out_channels: 128, kernel_size: 1}
|
174 |
-
- Pool:
|
175 |
args: {padding: 0}
|
176 |
-
- Conv:
|
177 |
args: {out_channels: 128, kernel_size: 1}
|
178 |
-
- Conv:
|
179 |
args: {out_channels: 128, kernel_size: 1}
|
180 |
source: -3
|
181 |
-
- Conv:
|
182 |
args: {out_channels: 128, kernel_size: 3, stride: 2}
|
183 |
-
- Concat:
|
184 |
source: [-1, -3, 63]
|
185 |
-
- Conv:
|
186 |
args: {out_channels: 256, kernel_size: 1}
|
187 |
-
- Conv:
|
188 |
args: {out_channels: 256, kernel_size: 1}
|
189 |
source: -2
|
190 |
-
- Conv:
|
191 |
args: {out_channels: 128, kernel_size: 3}
|
192 |
-
- Conv:
|
193 |
args: {out_channels: 128, kernel_size: 3}
|
194 |
-
- Conv:
|
195 |
args: {out_channels: 128, kernel_size: 3}
|
196 |
-
- Conv:
|
197 |
args: {out_channels: 128, kernel_size: 3}
|
198 |
-
- Concat:
|
199 |
source: [-1, -2, -3, -4, -5, -6]
|
200 |
-
- Conv:
|
201 |
args: {out_channels: 256, kernel_size: 1}
|
202 |
-
- Pool:
|
203 |
args: {padding: 0}
|
204 |
-
- Conv:
|
205 |
args: {out_channels: 256, kernel_size: 1}
|
206 |
-
- Conv:
|
207 |
args: {out_channels: 256, kernel_size: 1}
|
208 |
source: -3
|
209 |
-
- Conv:
|
210 |
args: {out_channels: 256, kernel_size: 3, stride: 2}
|
211 |
-
- Concat:
|
212 |
source: [-1, -3, 51]
|
213 |
-
- Conv:
|
214 |
args: {out_channels: 512, kernel_size: 1}
|
215 |
-
- Conv:
|
216 |
args: {out_channels: 512, kernel_size: 1}
|
217 |
source: -2
|
218 |
-
- Conv:
|
219 |
args: {out_channels: 256, kernel_size: 3}
|
220 |
-
- Conv:
|
221 |
args: {out_channels: 256, kernel_size: 3}
|
222 |
-
- Conv:
|
223 |
args: {out_channels: 256, kernel_size: 3}
|
224 |
-
- Conv:
|
225 |
args: {out_channels: 256, kernel_size: 3}
|
226 |
-
- Concat:
|
227 |
source: [-1, -2, -3, -4, -5, -6]
|
228 |
-
- Conv:
|
229 |
args: {out_channels: 512, kernel_size: 1}
|
230 |
-
- RepConv:
|
231 |
args: {out_channels: 256}
|
232 |
source: 75
|
233 |
-
- RepConv:
|
234 |
args: {out_channels: 512}
|
235 |
source: 88
|
236 |
-
- RepConv:
|
237 |
args: {out_channels: 1024}
|
238 |
source: 101
|
239 |
-
- IDetect:
|
240 |
args:
|
241 |
anchors:
|
242 |
- [12,16, 19,36, 40,28] # P3/8
|
243 |
- [36,75, 76,55, 72,146] # P4/16
|
244 |
- [142,110, 192,243, 459,401] # P5/32
|
245 |
source: [102, 103, 104]
|
246 |
-
output: True
|
|
|
4 |
|
5 |
model:
|
6 |
backbone:
|
7 |
+
- Conv:
|
8 |
args: {out_channels: 32, kernel_size: 3}
|
9 |
+
- Conv:
|
10 |
args: {out_channels: 64, kernel_size: 3, stride: 2}
|
11 |
+
- Conv:
|
12 |
args: {out_channels: 64, kernel_size: 3}
|
13 |
+
- Conv:
|
14 |
args: {out_channels: 128, kernel_size: 3, stride: 2}
|
15 |
+
- Conv:
|
16 |
args: {out_channels: 64, kernel_size: 1}
|
17 |
+
- Conv:
|
18 |
args: {out_channels: 64, kernel_size: 1}
|
19 |
source: -2
|
20 |
+
- Conv:
|
21 |
args: {out_channels: 64, kernel_size: 3}
|
22 |
+
- Conv:
|
23 |
args: {out_channels: 64, kernel_size: 3}
|
24 |
+
- Conv:
|
25 |
args: {out_channels: 64, kernel_size: 3}
|
26 |
+
- Conv:
|
27 |
args: {out_channels: 64, kernel_size: 3}
|
28 |
+
- Concat:
|
29 |
source: [-1, -3, -5, -6]
|
30 |
+
- Conv:
|
31 |
args: {out_channels: 256, kernel_size: 1}
|
32 |
+
- Pool:
|
33 |
args: {padding: 0}
|
34 |
+
- Conv:
|
35 |
args: {out_channels: 128, kernel_size: 1}
|
36 |
+
- Conv:
|
37 |
args: {out_channels: 128, kernel_size: 1}
|
38 |
source: -3
|
39 |
+
- Conv:
|
40 |
args: {out_channels: 128, kernel_size: 3, stride: 2}
|
41 |
+
- Concat:
|
42 |
source: [-1, -3]
|
43 |
+
- Conv:
|
44 |
args: {out_channels: 128, kernel_size: 1}
|
45 |
+
- Conv:
|
46 |
args: {out_channels: 128, kernel_size: 1}
|
47 |
source: -2
|
48 |
+
- Conv:
|
49 |
args: {out_channels: 128, kernel_size: 3}
|
50 |
+
- Conv:
|
51 |
args: {out_channels: 128, kernel_size: 3}
|
52 |
+
- Conv:
|
53 |
args: {out_channels: 128, kernel_size: 3}
|
54 |
+
- Conv:
|
55 |
args: {out_channels: 128, kernel_size: 3}
|
56 |
+
- Concat:
|
57 |
source: [-1, -3, -5, -6]
|
58 |
tags: 8x
|
59 |
+
- Conv:
|
60 |
args: {out_channels: 512, kernel_size: 1}
|
61 |
+
- Pool:
|
62 |
args: {padding: 0}
|
63 |
+
- Conv:
|
64 |
args: {out_channels: 256, kernel_size: 1}
|
65 |
+
- Conv:
|
66 |
args: {out_channels: 256, kernel_size: 1}
|
67 |
source: -3
|
68 |
+
- Conv:
|
69 |
args: {out_channels: 256, kernel_size: 3, stride: 2}
|
70 |
+
- Concat:
|
71 |
source: [-1, -3]
|
72 |
+
- Conv:
|
73 |
args: {out_channels: 256, kernel_size: 1}
|
74 |
+
- Conv:
|
75 |
args: {out_channels: 256, kernel_size: 1}
|
76 |
source: -2
|
77 |
+
- Conv:
|
78 |
args: {out_channels: 256, kernel_size: 3}
|
79 |
+
- Conv:
|
80 |
args: {out_channels: 256, kernel_size: 3}
|
81 |
+
- Conv:
|
82 |
args: {out_channels: 256, kernel_size: 3}
|
83 |
+
- Conv:
|
84 |
args: {out_channels: 256, kernel_size: 3}
|
85 |
+
- Concat:
|
86 |
source: [-1, -3, -5, -6]
|
87 |
+
- Conv:
|
88 |
args: {out_channels: 1024, kernel_size: 1}
|
89 |
tags: 16x
|
90 |
+
- Pool:
|
91 |
args: {padding: 0}
|
92 |
+
- Conv:
|
93 |
args: {out_channels: 512, kernel_size: 1}
|
94 |
+
- Conv:
|
95 |
args: {out_channels: 512, kernel_size: 1}
|
96 |
source: -3
|
97 |
+
- Conv:
|
98 |
args: {out_channels: 512, kernel_size: 3, stride: 2}
|
99 |
+
- Concat:
|
100 |
source: [-1, -3]
|
101 |
+
- Conv:
|
102 |
args: {out_channels: 256, kernel_size: 1}
|
103 |
+
- Conv:
|
104 |
args: {out_channels: 256, kernel_size: 1}
|
105 |
source: -2
|
106 |
+
- Conv:
|
107 |
args: {out_channels: 256, kernel_size: 3}
|
108 |
+
- Conv:
|
109 |
args: {out_channels: 256, kernel_size: 3}
|
110 |
+
- Conv:
|
111 |
args: {out_channels: 256, kernel_size: 3}
|
112 |
+
- Conv:
|
113 |
args: {out_channels: 256, kernel_size: 3}
|
114 |
+
- Concat:
|
115 |
source: [-1, -3, -5, -6]
|
116 |
+
- Conv:
|
117 |
args: {out_channels: 1024, kernel_size: 1}
|
118 |
tags: 32x
|
119 |
head:
|
120 |
+
- SPPCSPConv:
|
121 |
args: {out_channels: 512}
|
122 |
+
- Conv:
|
123 |
args: {out_channels: 256, kernel_size: 1}
|
124 |
+
- UpSample:
|
125 |
args: {scale_factor: 2}
|
126 |
+
- Conv:
|
127 |
args: {out_channels: 256, kernel_size: 1}
|
128 |
source: 16x
|
129 |
+
- Concat:
|
130 |
source: [-1, -2]
|
131 |
+
- Conv:
|
132 |
args: {out_channels: 256, kernel_size: 1}
|
133 |
+
- Conv:
|
134 |
args: {out_channels: 256, kernel_size: 1}
|
135 |
source: -2
|
136 |
+
- Conv:
|
137 |
args: {out_channels: 128, kernel_size: 3}
|
138 |
+
- Conv:
|
139 |
args: {out_channels: 128, kernel_size: 3}
|
140 |
+
- Conv:
|
141 |
args: {out_channels: 128, kernel_size: 3}
|
142 |
+
- Conv:
|
143 |
args: {out_channels: 128, kernel_size: 3}
|
144 |
+
- Concat:
|
145 |
source: [-1, -2, -3, -4, -5, -6]
|
146 |
+
- Conv:
|
147 |
args: {out_channels: 256, kernel_size: 1}
|
148 |
+
- Conv:
|
149 |
args: {out_channels: 128, kernel_size: 1}
|
150 |
+
- UpSample:
|
151 |
args: {scale_factor: 2}
|
152 |
+
- Conv:
|
153 |
args: {out_channels: 128, kernel_size: 1}
|
154 |
source: 8x
|
155 |
+
- Concat:
|
156 |
source: [-1, -2]
|
157 |
+
- Conv:
|
158 |
args: {out_channels: 128, kernel_size: 1}
|
159 |
+
- Conv:
|
160 |
args: {out_channels: 128, kernel_size: 1}
|
161 |
source: -2
|
162 |
+
- Conv:
|
163 |
args: {out_channels: 64, kernel_size: 3}
|
164 |
+
- Conv:
|
165 |
args: {out_channels: 64, kernel_size: 3}
|
166 |
+
- Conv:
|
167 |
args: {out_channels: 64, kernel_size: 3}
|
168 |
+
- Conv:
|
169 |
args: {out_channels: 64, kernel_size: 3}
|
170 |
+
- Concat:
|
171 |
source: [-1, -2, -3, -4, -5, -6]
|
172 |
+
- Conv:
|
173 |
args: {out_channels: 128, kernel_size: 1}
|
174 |
+
- Pool:
|
175 |
args: {padding: 0}
|
176 |
+
- Conv:
|
177 |
args: {out_channels: 128, kernel_size: 1}
|
178 |
+
- Conv:
|
179 |
args: {out_channels: 128, kernel_size: 1}
|
180 |
source: -3
|
181 |
+
- Conv:
|
182 |
args: {out_channels: 128, kernel_size: 3, stride: 2}
|
183 |
+
- Concat:
|
184 |
source: [-1, -3, 63]
|
185 |
+
- Conv:
|
186 |
args: {out_channels: 256, kernel_size: 1}
|
187 |
+
- Conv:
|
188 |
args: {out_channels: 256, kernel_size: 1}
|
189 |
source: -2
|
190 |
+
- Conv:
|
191 |
args: {out_channels: 128, kernel_size: 3}
|
192 |
+
- Conv:
|
193 |
args: {out_channels: 128, kernel_size: 3}
|
194 |
+
- Conv:
|
195 |
args: {out_channels: 128, kernel_size: 3}
|
196 |
+
- Conv:
|
197 |
args: {out_channels: 128, kernel_size: 3}
|
198 |
+
- Concat:
|
199 |
source: [-1, -2, -3, -4, -5, -6]
|
200 |
+
- Conv:
|
201 |
args: {out_channels: 256, kernel_size: 1}
|
202 |
+
- Pool:
|
203 |
args: {padding: 0}
|
204 |
+
- Conv:
|
205 |
args: {out_channels: 256, kernel_size: 1}
|
206 |
+
- Conv:
|
207 |
args: {out_channels: 256, kernel_size: 1}
|
208 |
source: -3
|
209 |
+
- Conv:
|
210 |
args: {out_channels: 256, kernel_size: 3, stride: 2}
|
211 |
+
- Concat:
|
212 |
source: [-1, -3, 51]
|
213 |
+
- Conv:
|
214 |
args: {out_channels: 512, kernel_size: 1}
|
215 |
+
- Conv:
|
216 |
args: {out_channels: 512, kernel_size: 1}
|
217 |
source: -2
|
218 |
+
- Conv:
|
219 |
args: {out_channels: 256, kernel_size: 3}
|
220 |
+
- Conv:
|
221 |
args: {out_channels: 256, kernel_size: 3}
|
222 |
+
- Conv:
|
223 |
args: {out_channels: 256, kernel_size: 3}
|
224 |
+
- Conv:
|
225 |
args: {out_channels: 256, kernel_size: 3}
|
226 |
+
- Concat:
|
227 |
source: [-1, -2, -3, -4, -5, -6]
|
228 |
+
- Conv:
|
229 |
args: {out_channels: 512, kernel_size: 1}
|
230 |
+
- RepConv:
|
231 |
args: {out_channels: 256}
|
232 |
source: 75
|
233 |
+
- RepConv:
|
234 |
args: {out_channels: 512}
|
235 |
source: 88
|
236 |
+
- RepConv:
|
237 |
args: {out_channels: 1024}
|
238 |
source: 101
|
239 |
+
- IDetect:
|
240 |
args:
|
241 |
anchors:
|
242 |
- [12,16, 19,36, 40,28] # P3/8
|
243 |
- [36,75, 76,55, 72,146] # P4/16
|
244 |
- [142,110, 192,243, 459,401] # P5/32
|
245 |
source: [102, 103, 104]
|
246 |
+
output: True
|
yolo/config/model/v9-c.yaml
CHANGED
@@ -13,7 +13,7 @@ model:
|
|
13 |
args: {out_channels: 128, kernel_size: 3, stride: 2}
|
14 |
- RepNCSPELAN:
|
15 |
args: {out_channels: 256, part_channels: 128}
|
16 |
-
|
17 |
- ADown:
|
18 |
args: {out_channels: 256}
|
19 |
- RepNCSPELAN:
|
@@ -25,13 +25,13 @@ model:
|
|
25 |
- RepNCSPELAN:
|
26 |
args: {out_channels: 512, part_channels: 512}
|
27 |
tags: B4
|
28 |
-
|
29 |
- ADown:
|
30 |
args: {out_channels: 512}
|
31 |
- RepNCSPELAN:
|
32 |
args: {out_channels: 512, part_channels: 512}
|
33 |
tags: B5
|
34 |
-
|
35 |
neck:
|
36 |
- SPPELAN:
|
37 |
args: {out_channels: 512}
|
@@ -49,12 +49,12 @@ model:
|
|
49 |
args: {scale_factor: 2, mode: nearest}
|
50 |
- Concat:
|
51 |
source: [-1, B3]
|
52 |
-
|
53 |
head:
|
54 |
- RepNCSPELAN:
|
55 |
args: {out_channels: 256, part_channels: 256}
|
56 |
tags: P3
|
57 |
-
|
58 |
- ADown:
|
59 |
args: {out_channels: 256}
|
60 |
- Concat:
|
@@ -70,7 +70,7 @@ model:
|
|
70 |
- RepNCSPELAN:
|
71 |
args: {out_channels: 512, part_channels: 512}
|
72 |
tags: P5
|
73 |
-
|
74 |
auxiliary:
|
75 |
- CBLinear:
|
76 |
source: B3
|
@@ -84,7 +84,7 @@ model:
|
|
84 |
source: B5
|
85 |
args: {out_channels: [256, 512, 512]}
|
86 |
tags: R5
|
87 |
-
|
88 |
- Conv:
|
89 |
args: {out_channels: 64, kernel_size: 3, stride: 2}
|
90 |
source: 0
|
@@ -122,4 +122,4 @@ model:
|
|
122 |
|
123 |
- MultiheadDetection:
|
124 |
source: [A3, A4, A5, P3, P4, P5]
|
125 |
-
output: True
|
|
|
13 |
args: {out_channels: 128, kernel_size: 3, stride: 2}
|
14 |
- RepNCSPELAN:
|
15 |
args: {out_channels: 256, part_channels: 128}
|
16 |
+
|
17 |
- ADown:
|
18 |
args: {out_channels: 256}
|
19 |
- RepNCSPELAN:
|
|
|
25 |
- RepNCSPELAN:
|
26 |
args: {out_channels: 512, part_channels: 512}
|
27 |
tags: B4
|
28 |
+
|
29 |
- ADown:
|
30 |
args: {out_channels: 512}
|
31 |
- RepNCSPELAN:
|
32 |
args: {out_channels: 512, part_channels: 512}
|
33 |
tags: B5
|
34 |
+
|
35 |
neck:
|
36 |
- SPPELAN:
|
37 |
args: {out_channels: 512}
|
|
|
49 |
args: {scale_factor: 2, mode: nearest}
|
50 |
- Concat:
|
51 |
source: [-1, B3]
|
52 |
+
|
53 |
head:
|
54 |
- RepNCSPELAN:
|
55 |
args: {out_channels: 256, part_channels: 256}
|
56 |
tags: P3
|
57 |
+
|
58 |
- ADown:
|
59 |
args: {out_channels: 256}
|
60 |
- Concat:
|
|
|
70 |
- RepNCSPELAN:
|
71 |
args: {out_channels: 512, part_channels: 512}
|
72 |
tags: P5
|
73 |
+
|
74 |
auxiliary:
|
75 |
- CBLinear:
|
76 |
source: B3
|
|
|
84 |
source: B5
|
85 |
args: {out_channels: [256, 512, 512]}
|
86 |
tags: R5
|
87 |
+
|
88 |
- Conv:
|
89 |
args: {out_channels: 64, kernel_size: 3, stride: 2}
|
90 |
source: 0
|
|
|
122 |
|
123 |
- MultiheadDetection:
|
124 |
source: [A3, A4, A5, P3, P4, P5]
|
125 |
+
output: True
|
yolo/config/task/inference.yaml
CHANGED
@@ -7,4 +7,4 @@ data:
|
|
7 |
data_augment: {}
|
8 |
nms:
|
9 |
min_confidence: 0.5
|
10 |
-
min_iou: 0.5
|
|
|
7 |
data_augment: {}
|
8 |
nms:
|
9 |
min_confidence: 0.5
|
10 |
+
min_iou: 0.5
|
yolo/config/task/train.yaml
CHANGED
@@ -6,7 +6,7 @@ defaults:
|
|
6 |
epoch: 500
|
7 |
|
8 |
data:
|
9 |
-
batch_size: 16
|
10 |
image_size: ${image_size}
|
11 |
cpu_num: ${cpu_num}
|
12 |
shuffle: True
|
@@ -26,7 +26,7 @@ optimizer:
|
|
26 |
loss:
|
27 |
objective:
|
28 |
BCELoss: 0.5
|
29 |
-
BoxLoss: 7.5
|
30 |
DFLoss: 1.5
|
31 |
aux:
|
32 |
0.25
|
|
|
6 |
epoch: 500
|
7 |
|
8 |
data:
|
9 |
+
batch_size: 16
|
10 |
image_size: ${image_size}
|
11 |
cpu_num: ${cpu_num}
|
12 |
shuffle: True
|
|
|
26 |
loss:
|
27 |
objective:
|
28 |
BCELoss: 0.5
|
29 |
+
BoxLoss: 7.5
|
30 |
DFLoss: 1.5
|
31 |
aux:
|
32 |
0.25
|
yolo/config/task/validation.yaml
CHANGED
@@ -9,4 +9,4 @@ data:
|
|
9 |
data_augment: {}
|
10 |
nms:
|
11 |
min_confidence: 0.001
|
12 |
-
min_iou: 0.7
|
|
|
9 |
data_augment: {}
|
10 |
nms:
|
11 |
min_confidence: 0.001
|
12 |
+
min_iou: 0.7
|
yolo/utils/logging_utils.py
CHANGED
@@ -1,9 +1,9 @@
|
|
1 |
"""
|
2 |
-
Module for initializing logging tools used in machine learning and data processing.
|
3 |
-
Supports integration with Weights & Biases (wandb), Loguru, TensorBoard, and other
|
4 |
logging frameworks as needed.
|
5 |
|
6 |
-
This setup ensures consistent logging across various platforms, facilitating
|
7 |
effective monitoring and debugging.
|
8 |
|
9 |
Example:
|
|
|
1 |
"""
|
2 |
+
Module for initializing logging tools used in machine learning and data processing.
|
3 |
+
Supports integration with Weights & Biases (wandb), Loguru, TensorBoard, and other
|
4 |
logging frameworks as needed.
|
5 |
|
6 |
+
This setup ensures consistent logging across various platforms, facilitating
|
7 |
effective monitoring and debugging.
|
8 |
|
9 |
Example:
|