├── utils
├── __init__.py
├── aws
│ ├── __init__.py
│ ├── mime.sh
│ ├── resume.py
│ └── userdata.sh
├── wandb_logging
│ ├── __init__.py
│ ├── __pycache__
│ │ ├── __init__.cpython-38.pyc
│ │ └── wandb_utils.cpython-38.pyc
│ └── log_dataset.py
├── __pycache__
│ ├── loss.cpython-38.pyc
│ ├── plots.cpython-38.pyc
│ ├── __init__.cpython-38.pyc
│ ├── datasets.cpython-38.pyc
│ ├── general.cpython-38.pyc
│ ├── metrics.cpython-38.pyc
│ ├── autoanchor.cpython-38.pyc
│ ├── torch_utils.cpython-38.pyc
│ └── google_utils.cpython-38.pyc
├── google_app_engine
│ ├── additional_requirements.txt
│ ├── app.yaml
│ └── Dockerfile
├── activations.py
├── google_utils.py
├── add_nms.py
├── autoanchor.py
└── metrics.py
├── models
├── __init__.py
├── __pycache__
│ ├── yolo.cpython-38.pyc
│ ├── __init__.cpython-38.pyc
│ ├── common.cpython-38.pyc
│ └── experimental.cpython-38.pyc
└── experimental.py
├── figure
├── mask.png
├── pose.png
├── performance.png
└── horses_prediction.jpg
├── inference
└── images
│ └── horses.jpg
├── VOCdevkit
└── VOC2007
│ ├── JPEGImages
│ ├── 000011.jpg
│ ├── 000018.jpg
│ ├── 000028.jpg
│ ├── 000029.jpg
│ ├── 000037.jpg
│ ├── 000049.jpg
│ ├── 000075.jpg
│ ├── 000079.jpg
│ ├── 000108.jpg
│ └── 000292.jpg
│ └── Annotations
│ ├── 000037.xml
│ ├── 000018.xml
│ ├── 000028.xml
│ ├── 000049.xml
│ ├── 000075.xml
│ ├── 000079.xml
│ ├── 000011.xml
│ ├── 000029.xml
│ ├── 000292.xml
│ └── 000108.xml
├── README.md
├── scripts
└── get_coco.sh
├── requirements.txt
├── data
├── voc.yaml
├── hyp.scratch.custom.yaml
├── hyp.scratch.p5.yaml
├── hyp.scratch.p6.yaml
├── hyp.scratch.tiny.yaml
└── coco.yaml
├── cfg
├── baseline
│ ├── r50-csp.yaml
│ ├── x50-csp.yaml
│ ├── yolov3.yaml
│ ├── yolov3-spp.yaml
│ ├── yolor-csp.yaml
│ ├── yolov4-csp.yaml
│ ├── yolor-csp-x.yaml
│ ├── yolor-e6.yaml
│ ├── yolor-d6.yaml
│ ├── yolor-p6.yaml
│ └── yolor-w6.yaml
├── deploy
│ ├── yolov7-tiny-silu.yaml
│ ├── yolov7.yaml
│ ├── yolov7-tiny.yaml
│ ├── yolov7x.yaml
│ ├── yolov7-w6.yaml
│ ├── yolov7-e6.yaml
│ ├── yolov7-d6.yaml
│ └── yolov7-e6e.yaml
└── training
│ ├── yolov7.yaml
│ ├── yolov7-tiny.yaml
│ ├── yolov7x.yaml
│ ├── yolov7-w6.yaml
│ ├── yolov7-e6.yaml
│ ├── yolov7-d6.yaml
│ └── yolov7-e6e.yaml
├── hubconf.py
├── voc_to_yolo.py
├── export.py
└── detect.py
/utils/__init__.py:
--------------------------------------------------------------------------------
1 | # init
--------------------------------------------------------------------------------
/models/__init__.py:
--------------------------------------------------------------------------------
1 | # init
--------------------------------------------------------------------------------
/utils/aws/__init__.py:
--------------------------------------------------------------------------------
1 | #init
--------------------------------------------------------------------------------
/utils/wandb_logging/__init__.py:
--------------------------------------------------------------------------------
1 | # init
--------------------------------------------------------------------------------
/figure/mask.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/figure/mask.png
--------------------------------------------------------------------------------
/figure/pose.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/figure/pose.png
--------------------------------------------------------------------------------
/figure/performance.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/figure/performance.png
--------------------------------------------------------------------------------
/inference/images/horses.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/inference/images/horses.jpg
--------------------------------------------------------------------------------
/figure/horses_prediction.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/figure/horses_prediction.jpg
--------------------------------------------------------------------------------
/utils/__pycache__/loss.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/loss.cpython-38.pyc
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000011.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000011.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000018.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000018.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000028.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000028.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000029.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000029.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000037.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000037.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000049.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000049.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000075.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000075.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000079.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000079.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000108.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000108.jpg
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/JPEGImages/000292.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/VOCdevkit/VOC2007/JPEGImages/000292.jpg
--------------------------------------------------------------------------------
/models/__pycache__/yolo.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/models/__pycache__/yolo.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/__pycache__/plots.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/plots.cpython-38.pyc
--------------------------------------------------------------------------------
/models/__pycache__/__init__.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/models/__pycache__/__init__.cpython-38.pyc
--------------------------------------------------------------------------------
/models/__pycache__/common.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/models/__pycache__/common.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/__pycache__/__init__.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/__init__.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/__pycache__/datasets.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/datasets.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/__pycache__/general.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/general.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/__pycache__/metrics.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/metrics.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/__pycache__/autoanchor.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/autoanchor.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/__pycache__/torch_utils.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/torch_utils.cpython-38.pyc
--------------------------------------------------------------------------------
/models/__pycache__/experimental.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/models/__pycache__/experimental.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/__pycache__/google_utils.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/__pycache__/google_utils.cpython-38.pyc
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # pytorch-yolov7
2 | 使用yolov7训练自己的数据集
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 | 参考:https://github.com/WongKinYiu/yolov7
14 |
--------------------------------------------------------------------------------
/utils/google_app_engine/additional_requirements.txt:
--------------------------------------------------------------------------------
1 | # add these requirements in your app on top of the existing ones
2 | pip==18.1
3 | Flask==1.0.2
4 | gunicorn==19.9.0
5 |
--------------------------------------------------------------------------------
/utils/wandb_logging/__pycache__/__init__.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/wandb_logging/__pycache__/__init__.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/wandb_logging/__pycache__/wandb_utils.cpython-38.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/qiaofengsheng/pytorch-yolov7/HEAD/utils/wandb_logging/__pycache__/wandb_utils.cpython-38.pyc
--------------------------------------------------------------------------------
/utils/google_app_engine/app.yaml:
--------------------------------------------------------------------------------
1 | runtime: custom
2 | env: flex
3 |
4 | service: yolorapp
5 |
6 | liveness_check:
7 | initial_delay_sec: 600
8 |
9 | manual_scaling:
10 | instances: 1
11 | resources:
12 | cpu: 1
13 | memory_gb: 4
14 | disk_size_gb: 20
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000037.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000037.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 338124795
9 |
10 |
11 | seudolog
12 | ?
13 |
14 |
15 | 500
16 | 375
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000018.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000018.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 340537267
9 |
10 |
11 | Kathy Stern
12 | Kathy Stern
13 |
14 |
15 | 380
16 | 285
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000028.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000028.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 341641838
9 |
10 |
11 | jennisner
12 | Jennifer
13 |
14 |
15 | 375
16 | 500
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000049.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000049.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 330722552
9 |
10 |
11 | thekevinmonster
12 | ?
13 |
14 |
15 | 500
16 | 356
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000075.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000075.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 333455958
9 |
10 |
11 | ohchicken
12 | anne mccarthy
13 |
14 |
15 | 332
16 | 500
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000079.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000079.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 323967561
9 |
10 |
11 | Miss Plum
12 | addie plum
13 |
14 |
15 | 500
16 | 357
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000011.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000011.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 329605697
9 |
10 |
11 | dale5446
12 | Dale Peeples
13 |
14 |
15 | 500
16 | 324
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000029.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000029.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 263839604
9 |
10 |
11 | Andy(Shotage)
12 | Andy Newson
13 |
14 |
15 | 500
16 | 331
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000292.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000292.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 339303272
9 |
10 |
11 | Rev. Voodoo
12 | Reverend Voodoo
13 |
14 |
15 | 500
16 | 375
17 | 3
18 |
19 | 0
20 |
32 |
33 |
--------------------------------------------------------------------------------
/utils/aws/mime.sh:
--------------------------------------------------------------------------------
1 | # AWS EC2 instance startup 'MIME' script https://aws.amazon.com/premiumsupport/knowledge-center/execute-user-data-ec2/
2 | # This script will run on every instance restart, not only on first start
3 | # --- DO NOT COPY ABOVE COMMENTS WHEN PASTING INTO USERDATA ---
4 |
5 | Content-Type: multipart/mixed; boundary="//"
6 | MIME-Version: 1.0
7 |
8 | --//
9 | Content-Type: text/cloud-config; charset="us-ascii"
10 | MIME-Version: 1.0
11 | Content-Transfer-Encoding: 7bit
12 | Content-Disposition: attachment; filename="cloud-config.txt"
13 |
14 | #cloud-config
15 | cloud_final_modules:
16 | - [scripts-user, always]
17 |
18 | --//
19 | Content-Type: text/x-shellscript; charset="us-ascii"
20 | MIME-Version: 1.0
21 | Content-Transfer-Encoding: 7bit
22 | Content-Disposition: attachment; filename="userdata.txt"
23 |
24 | #!/bin/bash
25 | # --- paste contents of userdata.sh here ---
26 | --//
27 |
--------------------------------------------------------------------------------
/scripts/get_coco.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 | # COCO 2017 dataset http://cocodataset.org
3 | # Download command: bash ./scripts/get_coco.sh
4 |
5 | # Download/unzip labels
6 | d='./' # unzip directory
7 | url=https://github.com/ultralytics/yolov5/releases/download/v1.0/
8 | f='coco2017labels-segments.zip' # or 'coco2017labels.zip', 68 MB
9 | echo 'Downloading' $url$f ' ...'
10 | curl -L $url$f -o $f && unzip -q $f -d $d && rm $f & # download, unzip, remove in background
11 |
12 | # Download/unzip images
13 | d='./coco/images' # unzip directory
14 | url=http://images.cocodataset.org/zips/
15 | f1='train2017.zip' # 19G, 118k images
16 | f2='val2017.zip' # 1G, 5k images
17 | f3='test2017.zip' # 7G, 41k images (optional)
18 | for f in $f1 $f2 $f3; do
19 | echo 'Downloading' $url$f '...'
20 | curl -L $url$f -o $f && unzip -q $f -d $d && rm $f & # download, unzip, remove in background
21 | done
22 | wait # finish background tasks
23 |
--------------------------------------------------------------------------------
/utils/wandb_logging/log_dataset.py:
--------------------------------------------------------------------------------
1 | import argparse
2 |
3 | import yaml
4 |
5 | from wandb_utils import WandbLogger
6 |
7 | WANDB_ARTIFACT_PREFIX = 'wandb-artifact://'
8 |
9 |
10 | def create_dataset_artifact(opt):
11 | with open(opt.data) as f:
12 | data = yaml.load(f, Loader=yaml.SafeLoader) # data dict
13 | logger = WandbLogger(opt, '', None, data, job_type='Dataset Creation')
14 |
15 |
16 | if __name__ == '__main__':
17 | parser = argparse.ArgumentParser()
18 | parser.add_argument('--data', type=str, default='data/coco.yaml', help='data.yaml path')
19 | parser.add_argument('--single-cls', action='store_true', help='train as single-class dataset')
20 | parser.add_argument('--project', type=str, default='YOLOR', help='name of W&B Project')
21 | opt = parser.parse_args()
22 | opt.resume = False # Explicitly disallow resume check for dataset upload job
23 |
24 | create_dataset_artifact(opt)
25 |
--------------------------------------------------------------------------------
/utils/google_app_engine/Dockerfile:
--------------------------------------------------------------------------------
1 | FROM gcr.io/google-appengine/python
2 |
3 | # Create a virtualenv for dependencies. This isolates these packages from
4 | # system-level packages.
5 | # Use -p python3 or -p python3.7 to select python version. Default is version 2.
6 | RUN virtualenv /env -p python3
7 |
8 | # Setting these environment variables are the same as running
9 | # source /env/bin/activate.
10 | ENV VIRTUAL_ENV /env
11 | ENV PATH /env/bin:$PATH
12 |
13 | RUN apt-get update && apt-get install -y python-opencv
14 |
15 | # Copy the application's requirements.txt and run pip to install all
16 | # dependencies into the virtualenv.
17 | ADD requirements.txt /app/requirements.txt
18 | RUN pip install -r /app/requirements.txt
19 |
20 | # Add the application source code.
21 | ADD . /app
22 |
23 | # Run a WSGI server to serve the application. gunicorn must be declared as
24 | # a dependency in requirements.txt.
25 | CMD gunicorn -b :$PORT main:app
26 |
--------------------------------------------------------------------------------
/requirements.txt:
--------------------------------------------------------------------------------
1 | # Usage: pip install -r requirements.txt
2 |
3 | # Base ----------------------------------------
4 | matplotlib>=3.2.2
5 | numpy>=1.18.5
6 | opencv-python>=4.1.1
7 | Pillow>=7.1.2
8 | PyYAML>=5.3.1
9 | requests>=2.23.0
10 | scipy>=1.4.1
11 | torch>=1.7.0,!=1.12.0
12 | torchvision>=0.8.1,!=0.13.0
13 | tqdm>=4.41.0
14 | protobuf<4.21.3
15 |
16 | # Logging -------------------------------------
17 | tensorboard>=2.4.1
18 | # wandb
19 |
20 | # Plotting ------------------------------------
21 | pandas>=1.1.4
22 | seaborn>=0.11.0
23 |
24 | # Export --------------------------------------
25 | # coremltools>=4.1 # CoreML export
26 | # onnx>=1.9.0 # ONNX export
27 | # onnx-simplifier>=0.3.6 # ONNX simplifier
28 | # scikit-learn==0.19.2 # CoreML quantization
29 | # tensorflow>=2.4.1 # TFLite export
30 | # tensorflowjs>=3.9.0 # TF.js export
31 | # openvino-dev # OpenVINO export
32 |
33 | # Extras --------------------------------------
34 | ipython # interactive notebook
35 | psutil # system utilization
36 | thop # FLOPs computation
37 | # albumentations>=1.0.3
38 | # pycocotools>=2.0 # COCO mAP
39 | # roboflow
40 |
--------------------------------------------------------------------------------
/utils/aws/resume.py:
--------------------------------------------------------------------------------
1 | # Resume all interrupted trainings in yolor/ dir including DDP trainings
2 | # Usage: $ python utils/aws/resume.py
3 |
4 | import os
5 | import sys
6 | from pathlib import Path
7 |
8 | import torch
9 | import yaml
10 |
11 | sys.path.append('./') # to run '$ python *.py' files in subdirectories
12 |
13 | port = 0 # --master_port
14 | path = Path('').resolve()
15 | for last in path.rglob('*/**/last.pt'):
16 | ckpt = torch.load(last)
17 | if ckpt['optimizer'] is None:
18 | continue
19 |
20 | # Load opt.yaml
21 | with open(last.parent.parent / 'opt.yaml') as f:
22 | opt = yaml.load(f, Loader=yaml.SafeLoader)
23 |
24 | # Get device count
25 | d = opt['device'].split(',') # devices
26 | nd = len(d) # number of devices
27 | ddp = nd > 1 or (nd == 0 and torch.cuda.device_count() > 1) # distributed data parallel
28 |
29 | if ddp: # multi-GPU
30 | port += 1
31 | cmd = f'python -m torch.distributed.launch --nproc_per_node {nd} --master_port {port} train.py --resume {last}'
32 | else: # single-GPU
33 | cmd = f'python train.py --resume {last}'
34 |
35 | cmd += ' > /dev/null 2>&1 &' # redirect output to dev/null and run in daemon thread
36 | print(cmd)
37 | os.system(cmd)
38 |
--------------------------------------------------------------------------------
/data/voc.yaml:
--------------------------------------------------------------------------------
1 | # train and val data as 1) directory: path/images/, 2) file: path/images.txt, or 3) list: [path1/images/, path2/images/]
2 | train: E:/PythonDemoSpace/study/yolov7/VOCdevkit/images/train # 118287 images
3 | val: E:/PythonDemoSpace/study/yolov7/VOCdevkit/images/val # 5000 images
4 | # number of classes
5 | nc: 2
6 |
7 | # class names
8 | # names: [ 'person', 'bicycle', 'car', 'motorcycle', 'airplane', 'bus', 'train', 'truck', 'boat', 'traffic light',
9 | # 'fire hydrant', 'stop sign', 'parking meter', 'bench', 'bird', 'cat', 'dog', 'horse', 'sheep', 'cow',
10 | # 'elephant', 'bear', 'zebra', 'giraffe', 'backpack', 'umbrella', 'handbag', 'tie', 'suitcase', 'frisbee',
11 | # 'skis', 'snowboard', 'sports ball', 'kite', 'baseball bat', 'baseball glove', 'skateboard', 'surfboard',
12 | # 'tennis racket', 'bottle', 'wine glass', 'cup', 'fork', 'knife', 'spoon', 'bowl', 'banana', 'apple',
13 | # 'sandwich', 'orange', 'broccoli', 'carrot', 'hot dog', 'pizza', 'donut', 'cake', 'chair', 'couch',
14 | # 'potted plant', 'bed', 'dining table', 'toilet', 'tv', 'laptop', 'mouse', 'remote', 'keyboard', 'cell phone',
15 | # 'microwave', 'oven', 'toaster', 'sink', 'refrigerator', 'book', 'clock', 'vase', 'scissors', 'teddy bear',
16 | # 'hair drier', 'toothbrush' ]
17 | names: ['dog','cat']
18 |
--------------------------------------------------------------------------------
/utils/aws/userdata.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 | # AWS EC2 instance startup script https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/user-data.html
3 | # This script will run only once on first instance start (for a re-start script see mime.sh)
4 | # /home/ubuntu (ubuntu) or /home/ec2-user (amazon-linux) is working dir
5 | # Use >300 GB SSD
6 |
7 | cd home/ubuntu
8 | if [ ! -d yolor ]; then
9 | echo "Running first-time script." # install dependencies, download COCO, pull Docker
10 | git clone -b paper https://github.com/WongKinYiu/yolor && sudo chmod -R 777 yolor
11 | cd yolor
12 | bash data/scripts/get_coco.sh && echo "Data done." &
13 | sudo docker pull nvcr.io/nvidia/pytorch:21.08-py3 && echo "Docker done." &
14 | python -m pip install --upgrade pip && pip install -r requirements.txt && python detect.py && echo "Requirements done." &
15 | wait && echo "All tasks done." # finish background tasks
16 | else
17 | echo "Running re-start script." # resume interrupted runs
18 | i=0
19 | list=$(sudo docker ps -qa) # container list i.e. $'one\ntwo\nthree\nfour'
20 | while IFS= read -r id; do
21 | ((i++))
22 | echo "restarting container $i: $id"
23 | sudo docker start $id
24 | # sudo docker exec -it $id python train.py --resume # single-GPU
25 | sudo docker exec -d $id python utils/aws/resume.py # multi-scenario
26 | done <<<"$list"
27 | fi
28 |
--------------------------------------------------------------------------------
/VOCdevkit/VOC2007/Annotations/000108.xml:
--------------------------------------------------------------------------------
1 |
2 | VOC2007
3 | 000108.jpg
4 |
5 | The VOC2007 Database
6 | PASCAL VOC2007
7 | flickr
8 | 320075022
9 |
10 |
11 | loxosceles
12 | Beth
13 |
14 |
15 | 500
16 | 375
17 | 3
18 |
19 | 0
20 |
32 |
44 |
56 |
57 |
--------------------------------------------------------------------------------
/data/hyp.scratch.custom.yaml:
--------------------------------------------------------------------------------
1 | lr0: 0.01 # initial learning rate (SGD=1E-2, Adam=1E-3)
2 | lrf: 0.1 # final OneCycleLR learning rate (lr0 * lrf)
3 | momentum: 0.937 # SGD momentum/Adam beta1
4 | weight_decay: 0.0005 # optimizer weight decay 5e-4
5 | warmup_epochs: 3.0 # warmup epochs (fractions ok)
6 | warmup_momentum: 0.8 # warmup initial momentum
7 | warmup_bias_lr: 0.1 # warmup initial bias lr
8 | box: 0.05 # box loss gain
9 | cls: 0.3 # cls loss gain
10 | cls_pw: 1.0 # cls BCELoss positive_weight
11 | obj: 0.7 # obj loss gain (scale with pixels)
12 | obj_pw: 1.0 # obj BCELoss positive_weight
13 | iou_t: 0.20 # IoU training threshold
14 | anchor_t: 4.0 # anchor-multiple threshold
15 | fl_gamma: 0.0 # focal loss gamma (efficientDet default gamma=1.5)
16 | hsv_h: 0.015 # image HSV-Hue augmentation (fraction)
17 | hsv_s: 0.7 # image HSV-Saturation augmentation (fraction)
18 | hsv_v: 0.4 # image HSV-Value augmentation (fraction)
19 | degrees: 0.0 # image rotation (+/- deg)
20 | translate: 0.2 # image translation (+/- fraction)
21 | scale: 0.5 # image scale (+/- gain)
22 | shear: 0.0 # image shear (+/- deg)
23 | perspective: 0.0 # image perspective (+/- fraction), range 0-0.001
24 | flipud: 0.0 # image flip up-down (probability)
25 | fliplr: 0.5 # image flip left-right (probability)
26 | mosaic: 1.0 # image mosaic (probability)
27 | mixup: 0.0 # image mixup (probability)
28 | copy_paste: 0.0 # image copy paste (probability)
29 | paste_in: 0.0 # image copy paste (probability)
30 |
--------------------------------------------------------------------------------
/data/hyp.scratch.p5.yaml:
--------------------------------------------------------------------------------
1 | lr0: 0.01 # initial learning rate (SGD=1E-2, Adam=1E-3)
2 | lrf: 0.1 # final OneCycleLR learning rate (lr0 * lrf)
3 | momentum: 0.937 # SGD momentum/Adam beta1
4 | weight_decay: 0.0005 # optimizer weight decay 5e-4
5 | warmup_epochs: 3.0 # warmup epochs (fractions ok)
6 | warmup_momentum: 0.8 # warmup initial momentum
7 | warmup_bias_lr: 0.1 # warmup initial bias lr
8 | box: 0.05 # box loss gain
9 | cls: 0.3 # cls loss gain
10 | cls_pw: 1.0 # cls BCELoss positive_weight
11 | obj: 0.7 # obj loss gain (scale with pixels)
12 | obj_pw: 1.0 # obj BCELoss positive_weight
13 | iou_t: 0.20 # IoU training threshold
14 | anchor_t: 4.0 # anchor-multiple threshold
15 | fl_gamma: 0.0 # focal loss gamma (efficientDet default gamma=1.5)
16 | hsv_h: 0.015 # image HSV-Hue augmentation (fraction)
17 | hsv_s: 0.7 # image HSV-Saturation augmentation (fraction)
18 | hsv_v: 0.4 # image HSV-Value augmentation (fraction)
19 | degrees: 0.0 # image rotation (+/- deg)
20 | translate: 0.2 # image translation (+/- fraction)
21 | scale: 0.9 # image scale (+/- gain)
22 | shear: 0.0 # image shear (+/- deg)
23 | perspective: 0.0 # image perspective (+/- fraction), range 0-0.001
24 | flipud: 0.0 # image flip up-down (probability)
25 | fliplr: 0.5 # image flip left-right (probability)
26 | mosaic: 1.0 # image mosaic (probability)
27 | mixup: 0.15 # image mixup (probability)
28 | copy_paste: 0.0 # image copy paste (probability)
29 | paste_in: 0.15 # image copy paste (probability)
30 |
--------------------------------------------------------------------------------
/data/hyp.scratch.p6.yaml:
--------------------------------------------------------------------------------
1 | lr0: 0.01 # initial learning rate (SGD=1E-2, Adam=1E-3)
2 | lrf: 0.2 # final OneCycleLR learning rate (lr0 * lrf)
3 | momentum: 0.937 # SGD momentum/Adam beta1
4 | weight_decay: 0.0005 # optimizer weight decay 5e-4
5 | warmup_epochs: 3.0 # warmup epochs (fractions ok)
6 | warmup_momentum: 0.8 # warmup initial momentum
7 | warmup_bias_lr: 0.1 # warmup initial bias lr
8 | box: 0.05 # box loss gain
9 | cls: 0.3 # cls loss gain
10 | cls_pw: 1.0 # cls BCELoss positive_weight
11 | obj: 0.7 # obj loss gain (scale with pixels)
12 | obj_pw: 1.0 # obj BCELoss positive_weight
13 | iou_t: 0.20 # IoU training threshold
14 | anchor_t: 4.0 # anchor-multiple threshold
15 | fl_gamma: 0.0 # focal loss gamma (efficientDet default gamma=1.5)
16 | hsv_h: 0.015 # image HSV-Hue augmentation (fraction)
17 | hsv_s: 0.7 # image HSV-Saturation augmentation (fraction)
18 | hsv_v: 0.4 # image HSV-Value augmentation (fraction)
19 | degrees: 0.0 # image rotation (+/- deg)
20 | translate: 0.2 # image translation (+/- fraction)
21 | scale: 0.9 # image scale (+/- gain)
22 | shear: 0.0 # image shear (+/- deg)
23 | perspective: 0.0 # image perspective (+/- fraction), range 0-0.001
24 | flipud: 0.0 # image flip up-down (probability)
25 | fliplr: 0.5 # image flip left-right (probability)
26 | mosaic: 1.0 # image mosaic (probability)
27 | mixup: 0.15 # image mixup (probability)
28 | copy_paste: 0.0 # image copy paste (probability)
29 | paste_in: 0.15 # image copy paste (probability)
30 |
--------------------------------------------------------------------------------
/data/hyp.scratch.tiny.yaml:
--------------------------------------------------------------------------------
1 | lr0: 0.01 # initial learning rate (SGD=1E-2, Adam=1E-3)
2 | lrf: 0.01 # final OneCycleLR learning rate (lr0 * lrf)
3 | momentum: 0.937 # SGD momentum/Adam beta1
4 | weight_decay: 0.0005 # optimizer weight decay 5e-4
5 | warmup_epochs: 3.0 # warmup epochs (fractions ok)
6 | warmup_momentum: 0.8 # warmup initial momentum
7 | warmup_bias_lr: 0.1 # warmup initial bias lr
8 | box: 0.05 # box loss gain
9 | cls: 0.5 # cls loss gain
10 | cls_pw: 1.0 # cls BCELoss positive_weight
11 | obj: 1.0 # obj loss gain (scale with pixels)
12 | obj_pw: 1.0 # obj BCELoss positive_weight
13 | iou_t: 0.20 # IoU training threshold
14 | anchor_t: 4.0 # anchor-multiple threshold
15 | fl_gamma: 0.0 # focal loss gamma (efficientDet default gamma=1.5)
16 | hsv_h: 0.015 # image HSV-Hue augmentation (fraction)
17 | hsv_s: 0.7 # image HSV-Saturation augmentation (fraction)
18 | hsv_v: 0.4 # image HSV-Value augmentation (fraction)
19 | degrees: 0.0 # image rotation (+/- deg)
20 | translate: 0.1 # image translation (+/- fraction)
21 | scale: 0.5 # image scale (+/- gain)
22 | shear: 0.0 # image shear (+/- deg)
23 | perspective: 0.0 # image perspective (+/- fraction), range 0-0.001
24 | flipud: 0.0 # image flip up-down (probability)
25 | fliplr: 0.5 # image flip left-right (probability)
26 | mosaic: 1.0 # image mosaic (probability)
27 | mixup: 0.05 # image mixup (probability)
28 | copy_paste: 0.0 # image copy paste (probability)
29 | paste_in: 0.05 # image copy paste (probability)
30 |
--------------------------------------------------------------------------------
/data/coco.yaml:
--------------------------------------------------------------------------------
1 | # COCO 2017 dataset http://cocodataset.org
2 |
3 | # download command/URL (optional)
4 | download: bash ./scripts/get_coco.sh
5 |
6 | # train and val data as 1) directory: path/images/, 2) file: path/images.txt, or 3) list: [path1/images/, path2/images/]
7 | train: ./coco/train2017.txt # 118287 images
8 | val: ./coco/val2017.txt # 5000 images
9 | test: ./coco/test-dev2017.txt # 20288 of 40670 images, submit to https://competitions.codalab.org/competitions/20794
10 |
11 | # number of classes
12 | nc: 80
13 |
14 | # class names
15 | names: [ 'person', 'bicycle', 'car', 'motorcycle', 'airplane', 'bus', 'train', 'truck', 'boat', 'traffic light',
16 | 'fire hydrant', 'stop sign', 'parking meter', 'bench', 'bird', 'cat', 'dog', 'horse', 'sheep', 'cow',
17 | 'elephant', 'bear', 'zebra', 'giraffe', 'backpack', 'umbrella', 'handbag', 'tie', 'suitcase', 'frisbee',
18 | 'skis', 'snowboard', 'sports ball', 'kite', 'baseball bat', 'baseball glove', 'skateboard', 'surfboard',
19 | 'tennis racket', 'bottle', 'wine glass', 'cup', 'fork', 'knife', 'spoon', 'bowl', 'banana', 'apple',
20 | 'sandwich', 'orange', 'broccoli', 'carrot', 'hot dog', 'pizza', 'donut', 'cake', 'chair', 'couch',
21 | 'potted plant', 'bed', 'dining table', 'toilet', 'tv', 'laptop', 'mouse', 'remote', 'keyboard', 'cell phone',
22 | 'microwave', 'oven', 'toaster', 'sink', 'refrigerator', 'book', 'clock', 'vase', 'scissors', 'teddy bear',
23 | 'hair drier', 'toothbrush' ]
24 |
--------------------------------------------------------------------------------
/cfg/baseline/r50-csp.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # CSP-ResNet backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Stem, [128]], # 0-P1/2
16 | [-1, 3, ResCSPC, [128]],
17 | [-1, 1, Conv, [256, 3, 2]], # 2-P3/8
18 | [-1, 4, ResCSPC, [256]],
19 | [-1, 1, Conv, [512, 3, 2]], # 4-P3/8
20 | [-1, 6, ResCSPC, [512]],
21 | [-1, 1, Conv, [1024, 3, 2]], # 6-P3/8
22 | [-1, 3, ResCSPC, [1024]], # 7
23 | ]
24 |
25 | # CSP-Res-PAN head
26 | head:
27 | [[-1, 1, SPPCSPC, [512]], # 8
28 | [-1, 1, Conv, [256, 1, 1]],
29 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
30 | [5, 1, Conv, [256, 1, 1]], # route backbone P4
31 | [[-1, -2], 1, Concat, [1]],
32 | [-1, 2, ResCSPB, [256]], # 13
33 | [-1, 1, Conv, [128, 1, 1]],
34 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
35 | [3, 1, Conv, [128, 1, 1]], # route backbone P3
36 | [[-1, -2], 1, Concat, [1]],
37 | [-1, 2, ResCSPB, [128]], # 18
38 | [-1, 1, Conv, [256, 3, 1]],
39 | [-2, 1, Conv, [256, 3, 2]],
40 | [[-1, 13], 1, Concat, [1]], # cat
41 | [-1, 2, ResCSPB, [256]], # 22
42 | [-1, 1, Conv, [512, 3, 1]],
43 | [-2, 1, Conv, [512, 3, 2]],
44 | [[-1, 8], 1, Concat, [1]], # cat
45 | [-1, 2, ResCSPB, [512]], # 26
46 | [-1, 1, Conv, [1024, 3, 1]],
47 |
48 | [[19,23,27], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5)
49 | ]
50 |
--------------------------------------------------------------------------------
/cfg/baseline/x50-csp.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # CSP-ResNeXt backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Stem, [128]], # 0-P1/2
16 | [-1, 3, ResXCSPC, [128]],
17 | [-1, 1, Conv, [256, 3, 2]], # 2-P3/8
18 | [-1, 4, ResXCSPC, [256]],
19 | [-1, 1, Conv, [512, 3, 2]], # 4-P3/8
20 | [-1, 6, ResXCSPC, [512]],
21 | [-1, 1, Conv, [1024, 3, 2]], # 6-P3/8
22 | [-1, 3, ResXCSPC, [1024]], # 7
23 | ]
24 |
25 | # CSP-ResX-PAN head
26 | head:
27 | [[-1, 1, SPPCSPC, [512]], # 8
28 | [-1, 1, Conv, [256, 1, 1]],
29 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
30 | [5, 1, Conv, [256, 1, 1]], # route backbone P4
31 | [[-1, -2], 1, Concat, [1]],
32 | [-1, 2, ResXCSPB, [256]], # 13
33 | [-1, 1, Conv, [128, 1, 1]],
34 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
35 | [3, 1, Conv, [128, 1, 1]], # route backbone P3
36 | [[-1, -2], 1, Concat, [1]],
37 | [-1, 2, ResXCSPB, [128]], # 18
38 | [-1, 1, Conv, [256, 3, 1]],
39 | [-2, 1, Conv, [256, 3, 2]],
40 | [[-1, 13], 1, Concat, [1]], # cat
41 | [-1, 2, ResXCSPB, [256]], # 22
42 | [-1, 1, Conv, [512, 3, 1]],
43 | [-2, 1, Conv, [512, 3, 2]],
44 | [[-1, 8], 1, Concat, [1]], # cat
45 | [-1, 2, ResXCSPB, [512]], # 26
46 | [-1, 1, Conv, [1024, 3, 1]],
47 |
48 | [[19,23,27], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5)
49 | ]
50 |
--------------------------------------------------------------------------------
/cfg/baseline/yolov3.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [10,13, 16,30, 33,23] # P3/8
9 | - [30,61, 62,45, 59,119] # P4/16
10 | - [116,90, 156,198, 373,326] # P5/32
11 |
12 | # darknet53 backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [32, 3, 1]], # 0
16 | [-1, 1, Conv, [64, 3, 2]], # 1-P1/2
17 | [-1, 1, Bottleneck, [64]],
18 | [-1, 1, Conv, [128, 3, 2]], # 3-P2/4
19 | [-1, 2, Bottleneck, [128]],
20 | [-1, 1, Conv, [256, 3, 2]], # 5-P3/8
21 | [-1, 8, Bottleneck, [256]],
22 | [-1, 1, Conv, [512, 3, 2]], # 7-P4/16
23 | [-1, 8, Bottleneck, [512]],
24 | [-1, 1, Conv, [1024, 3, 2]], # 9-P5/32
25 | [-1, 4, Bottleneck, [1024]], # 10
26 | ]
27 |
28 | # YOLOv3 head
29 | head:
30 | [[-1, 1, Bottleneck, [1024, False]],
31 | [-1, 1, Conv, [512, [1, 1]]],
32 | [-1, 1, Conv, [1024, 3, 1]],
33 | [-1, 1, Conv, [512, 1, 1]],
34 | [-1, 1, Conv, [1024, 3, 1]], # 15 (P5/32-large)
35 |
36 | [-2, 1, Conv, [256, 1, 1]],
37 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
38 | [[-1, 8], 1, Concat, [1]], # cat backbone P4
39 | [-1, 1, Bottleneck, [512, False]],
40 | [-1, 1, Bottleneck, [512, False]],
41 | [-1, 1, Conv, [256, 1, 1]],
42 | [-1, 1, Conv, [512, 3, 1]], # 22 (P4/16-medium)
43 |
44 | [-2, 1, Conv, [128, 1, 1]],
45 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
46 | [[-1, 6], 1, Concat, [1]], # cat backbone P3
47 | [-1, 1, Bottleneck, [256, False]],
48 | [-1, 2, Bottleneck, [256, False]], # 27 (P3/8-small)
49 |
50 | [[27, 22, 15], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
51 | ]
52 |
--------------------------------------------------------------------------------
/cfg/baseline/yolov3-spp.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [10,13, 16,30, 33,23] # P3/8
9 | - [30,61, 62,45, 59,119] # P4/16
10 | - [116,90, 156,198, 373,326] # P5/32
11 |
12 | # darknet53 backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [32, 3, 1]], # 0
16 | [-1, 1, Conv, [64, 3, 2]], # 1-P1/2
17 | [-1, 1, Bottleneck, [64]],
18 | [-1, 1, Conv, [128, 3, 2]], # 3-P2/4
19 | [-1, 2, Bottleneck, [128]],
20 | [-1, 1, Conv, [256, 3, 2]], # 5-P3/8
21 | [-1, 8, Bottleneck, [256]],
22 | [-1, 1, Conv, [512, 3, 2]], # 7-P4/16
23 | [-1, 8, Bottleneck, [512]],
24 | [-1, 1, Conv, [1024, 3, 2]], # 9-P5/32
25 | [-1, 4, Bottleneck, [1024]], # 10
26 | ]
27 |
28 | # YOLOv3-SPP head
29 | head:
30 | [[-1, 1, Bottleneck, [1024, False]],
31 | [-1, 1, SPP, [512, [5, 9, 13]]],
32 | [-1, 1, Conv, [1024, 3, 1]],
33 | [-1, 1, Conv, [512, 1, 1]],
34 | [-1, 1, Conv, [1024, 3, 1]], # 15 (P5/32-large)
35 |
36 | [-2, 1, Conv, [256, 1, 1]],
37 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
38 | [[-1, 8], 1, Concat, [1]], # cat backbone P4
39 | [-1, 1, Bottleneck, [512, False]],
40 | [-1, 1, Bottleneck, [512, False]],
41 | [-1, 1, Conv, [256, 1, 1]],
42 | [-1, 1, Conv, [512, 3, 1]], # 22 (P4/16-medium)
43 |
44 | [-2, 1, Conv, [128, 1, 1]],
45 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
46 | [[-1, 6], 1, Concat, [1]], # cat backbone P3
47 | [-1, 1, Bottleneck, [256, False]],
48 | [-1, 2, Bottleneck, [256, False]], # 27 (P3/8-small)
49 |
50 | [[27, 22, 15], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
51 | ]
52 |
--------------------------------------------------------------------------------
/cfg/baseline/yolor-csp.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # CSP-Darknet backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [32, 3, 1]], # 0
16 | [-1, 1, Conv, [64, 3, 2]], # 1-P1/2
17 | [-1, 1, Bottleneck, [64]],
18 | [-1, 1, Conv, [128, 3, 2]], # 3-P2/4
19 | [-1, 2, BottleneckCSPC, [128]],
20 | [-1, 1, Conv, [256, 3, 2]], # 5-P3/8
21 | [-1, 8, BottleneckCSPC, [256]],
22 | [-1, 1, Conv, [512, 3, 2]], # 7-P4/16
23 | [-1, 8, BottleneckCSPC, [512]],
24 | [-1, 1, Conv, [1024, 3, 2]], # 9-P5/32
25 | [-1, 4, BottleneckCSPC, [1024]], # 10
26 | ]
27 |
28 | # CSP-Dark-PAN head
29 | head:
30 | [[-1, 1, SPPCSPC, [512]], # 11
31 | [-1, 1, Conv, [256, 1, 1]],
32 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
33 | [8, 1, Conv, [256, 1, 1]], # route backbone P4
34 | [[-1, -2], 1, Concat, [1]],
35 | [-1, 2, BottleneckCSPB, [256]], # 16
36 | [-1, 1, Conv, [128, 1, 1]],
37 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
38 | [6, 1, Conv, [128, 1, 1]], # route backbone P3
39 | [[-1, -2], 1, Concat, [1]],
40 | [-1, 2, BottleneckCSPB, [128]], # 21
41 | [-1, 1, Conv, [256, 3, 1]],
42 | [-2, 1, Conv, [256, 3, 2]],
43 | [[-1, 16], 1, Concat, [1]], # cat
44 | [-1, 2, BottleneckCSPB, [256]], # 25
45 | [-1, 1, Conv, [512, 3, 1]],
46 | [-2, 1, Conv, [512, 3, 2]],
47 | [[-1, 11], 1, Concat, [1]], # cat
48 | [-1, 2, BottleneckCSPB, [512]], # 29
49 | [-1, 1, Conv, [1024, 3, 1]],
50 |
51 | [[22,26,30], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5)
52 | ]
53 |
--------------------------------------------------------------------------------
/cfg/baseline/yolov4-csp.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # CSP-Darknet backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [32, 3, 1]], # 0
16 | [-1, 1, Conv, [64, 3, 2]], # 1-P1/2
17 | [-1, 1, Bottleneck, [64]],
18 | [-1, 1, Conv, [128, 3, 2]], # 3-P2/4
19 | [-1, 2, BottleneckCSPC, [128]],
20 | [-1, 1, Conv, [256, 3, 2]], # 5-P3/8
21 | [-1, 8, BottleneckCSPC, [256]],
22 | [-1, 1, Conv, [512, 3, 2]], # 7-P4/16
23 | [-1, 8, BottleneckCSPC, [512]],
24 | [-1, 1, Conv, [1024, 3, 2]], # 9-P5/32
25 | [-1, 4, BottleneckCSPC, [1024]], # 10
26 | ]
27 |
28 | # CSP-Dark-PAN head
29 | head:
30 | [[-1, 1, SPPCSPC, [512]], # 11
31 | [-1, 1, Conv, [256, 1, 1]],
32 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
33 | [8, 1, Conv, [256, 1, 1]], # route backbone P4
34 | [[-1, -2], 1, Concat, [1]],
35 | [-1, 2, BottleneckCSPB, [256]], # 16
36 | [-1, 1, Conv, [128, 1, 1]],
37 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
38 | [6, 1, Conv, [128, 1, 1]], # route backbone P3
39 | [[-1, -2], 1, Concat, [1]],
40 | [-1, 2, BottleneckCSPB, [128]], # 21
41 | [-1, 1, Conv, [256, 3, 1]],
42 | [-2, 1, Conv, [256, 3, 2]],
43 | [[-1, 16], 1, Concat, [1]], # cat
44 | [-1, 2, BottleneckCSPB, [256]], # 25
45 | [-1, 1, Conv, [512, 3, 1]],
46 | [-2, 1, Conv, [512, 3, 2]],
47 | [[-1, 11], 1, Concat, [1]], # cat
48 | [-1, 2, BottleneckCSPB, [512]], # 29
49 | [-1, 1, Conv, [1024, 3, 1]],
50 |
51 | [[22,26,30], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
52 | ]
53 |
--------------------------------------------------------------------------------
/cfg/baseline/yolor-csp-x.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.33 # model depth multiple
4 | width_multiple: 1.25 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # CSP-Darknet backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [32, 3, 1]], # 0
16 | [-1, 1, Conv, [64, 3, 2]], # 1-P1/2
17 | [-1, 1, Bottleneck, [64]],
18 | [-1, 1, Conv, [128, 3, 2]], # 3-P2/4
19 | [-1, 2, BottleneckCSPC, [128]],
20 | [-1, 1, Conv, [256, 3, 2]], # 5-P3/8
21 | [-1, 8, BottleneckCSPC, [256]],
22 | [-1, 1, Conv, [512, 3, 2]], # 7-P4/16
23 | [-1, 8, BottleneckCSPC, [512]],
24 | [-1, 1, Conv, [1024, 3, 2]], # 9-P5/32
25 | [-1, 4, BottleneckCSPC, [1024]], # 10
26 | ]
27 |
28 | # CSP-Dark-PAN head
29 | head:
30 | [[-1, 1, SPPCSPC, [512]], # 11
31 | [-1, 1, Conv, [256, 1, 1]],
32 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
33 | [8, 1, Conv, [256, 1, 1]], # route backbone P4
34 | [[-1, -2], 1, Concat, [1]],
35 | [-1, 2, BottleneckCSPB, [256]], # 16
36 | [-1, 1, Conv, [128, 1, 1]],
37 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
38 | [6, 1, Conv, [128, 1, 1]], # route backbone P3
39 | [[-1, -2], 1, Concat, [1]],
40 | [-1, 2, BottleneckCSPB, [128]], # 21
41 | [-1, 1, Conv, [256, 3, 1]],
42 | [-2, 1, Conv, [256, 3, 2]],
43 | [[-1, 16], 1, Concat, [1]], # cat
44 | [-1, 2, BottleneckCSPB, [256]], # 25
45 | [-1, 1, Conv, [512, 3, 1]],
46 | [-2, 1, Conv, [512, 3, 2]],
47 | [[-1, 11], 1, Concat, [1]], # cat
48 | [-1, 2, BottleneckCSPB, [512]], # 29
49 | [-1, 1, Conv, [1024, 3, 1]],
50 |
51 | [[22,26,30], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5)
52 | ]
53 |
--------------------------------------------------------------------------------
/cfg/baseline/yolor-e6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # expand model depth
4 | width_multiple: 1.25 # expand layer channels
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # CSP-Darknet backbone
14 | backbone:
15 | # [from, number, module, args]
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [64, 3, 1]], # 1-P1/2
18 | [-1, 1, DownC, [128]], # 2-P2/4
19 | [-1, 3, BottleneckCSPA, [128]],
20 | [-1, 1, DownC, [256]], # 4-P3/8
21 | [-1, 7, BottleneckCSPA, [256]],
22 | [-1, 1, DownC, [512]], # 6-P4/16
23 | [-1, 7, BottleneckCSPA, [512]],
24 | [-1, 1, DownC, [768]], # 8-P5/32
25 | [-1, 3, BottleneckCSPA, [768]],
26 | [-1, 1, DownC, [1024]], # 10-P6/64
27 | [-1, 3, BottleneckCSPA, [1024]], # 11
28 | ]
29 |
30 | # CSP-Dark-PAN head
31 | head:
32 | [[-1, 1, SPPCSPC, [512]], # 12
33 | [-1, 1, Conv, [384, 1, 1]],
34 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
35 | [-6, 1, Conv, [384, 1, 1]], # route backbone P5
36 | [[-1, -2], 1, Concat, [1]],
37 | [-1, 3, BottleneckCSPB, [384]], # 17
38 | [-1, 1, Conv, [256, 1, 1]],
39 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
40 | [-13, 1, Conv, [256, 1, 1]], # route backbone P4
41 | [[-1, -2], 1, Concat, [1]],
42 | [-1, 3, BottleneckCSPB, [256]], # 22
43 | [-1, 1, Conv, [128, 1, 1]],
44 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
45 | [-20, 1, Conv, [128, 1, 1]], # route backbone P3
46 | [[-1, -2], 1, Concat, [1]],
47 | [-1, 3, BottleneckCSPB, [128]], # 27
48 | [-1, 1, Conv, [256, 3, 1]],
49 | [-2, 1, DownC, [256]],
50 | [[-1, 22], 1, Concat, [1]], # cat
51 | [-1, 3, BottleneckCSPB, [256]], # 31
52 | [-1, 1, Conv, [512, 3, 1]],
53 | [-2, 1, DownC, [384]],
54 | [[-1, 17], 1, Concat, [1]], # cat
55 | [-1, 3, BottleneckCSPB, [384]], # 35
56 | [-1, 1, Conv, [768, 3, 1]],
57 | [-2, 1, DownC, [512]],
58 | [[-1, 12], 1, Concat, [1]], # cat
59 | [-1, 3, BottleneckCSPB, [512]], # 39
60 | [-1, 1, Conv, [1024, 3, 1]],
61 |
62 | [[28,32,36,40], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5, P6)
63 | ]
--------------------------------------------------------------------------------
/cfg/baseline/yolor-d6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # expand model depth
4 | width_multiple: 1.25 # expand layer channels
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # CSP-Darknet backbone
14 | backbone:
15 | # [from, number, module, args]
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [64, 3, 1]], # 1-P1/2
18 | [-1, 1, DownC, [128]], # 2-P2/4
19 | [-1, 3, BottleneckCSPA, [128]],
20 | [-1, 1, DownC, [256]], # 4-P3/8
21 | [-1, 15, BottleneckCSPA, [256]],
22 | [-1, 1, DownC, [512]], # 6-P4/16
23 | [-1, 15, BottleneckCSPA, [512]],
24 | [-1, 1, DownC, [768]], # 8-P5/32
25 | [-1, 7, BottleneckCSPA, [768]],
26 | [-1, 1, DownC, [1024]], # 10-P6/64
27 | [-1, 7, BottleneckCSPA, [1024]], # 11
28 | ]
29 |
30 | # CSP-Dark-PAN head
31 | head:
32 | [[-1, 1, SPPCSPC, [512]], # 12
33 | [-1, 1, Conv, [384, 1, 1]],
34 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
35 | [-6, 1, Conv, [384, 1, 1]], # route backbone P5
36 | [[-1, -2], 1, Concat, [1]],
37 | [-1, 3, BottleneckCSPB, [384]], # 17
38 | [-1, 1, Conv, [256, 1, 1]],
39 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
40 | [-13, 1, Conv, [256, 1, 1]], # route backbone P4
41 | [[-1, -2], 1, Concat, [1]],
42 | [-1, 3, BottleneckCSPB, [256]], # 22
43 | [-1, 1, Conv, [128, 1, 1]],
44 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
45 | [-20, 1, Conv, [128, 1, 1]], # route backbone P3
46 | [[-1, -2], 1, Concat, [1]],
47 | [-1, 3, BottleneckCSPB, [128]], # 27
48 | [-1, 1, Conv, [256, 3, 1]],
49 | [-2, 1, DownC, [256]],
50 | [[-1, 22], 1, Concat, [1]], # cat
51 | [-1, 3, BottleneckCSPB, [256]], # 31
52 | [-1, 1, Conv, [512, 3, 1]],
53 | [-2, 1, DownC, [384]],
54 | [[-1, 17], 1, Concat, [1]], # cat
55 | [-1, 3, BottleneckCSPB, [384]], # 35
56 | [-1, 1, Conv, [768, 3, 1]],
57 | [-2, 1, DownC, [512]],
58 | [[-1, 12], 1, Concat, [1]], # cat
59 | [-1, 3, BottleneckCSPB, [512]], # 39
60 | [-1, 1, Conv, [1024, 3, 1]],
61 |
62 | [[28,32,36,40], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5, P6)
63 | ]
--------------------------------------------------------------------------------
/cfg/baseline/yolor-p6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # expand model depth
4 | width_multiple: 1.0 # expand layer channels
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # CSP-Darknet backbone
14 | backbone:
15 | # [from, number, module, args]
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [64, 3, 1]], # 1-P1/2
18 | [-1, 1, Conv, [128, 3, 2]], # 2-P2/4
19 | [-1, 3, BottleneckCSPA, [128]],
20 | [-1, 1, Conv, [256, 3, 2]], # 4-P3/8
21 | [-1, 7, BottleneckCSPA, [256]],
22 | [-1, 1, Conv, [384, 3, 2]], # 6-P4/16
23 | [-1, 7, BottleneckCSPA, [384]],
24 | [-1, 1, Conv, [512, 3, 2]], # 8-P5/32
25 | [-1, 3, BottleneckCSPA, [512]],
26 | [-1, 1, Conv, [640, 3, 2]], # 10-P6/64
27 | [-1, 3, BottleneckCSPA, [640]], # 11
28 | ]
29 |
30 | # CSP-Dark-PAN head
31 | head:
32 | [[-1, 1, SPPCSPC, [320]], # 12
33 | [-1, 1, Conv, [256, 1, 1]],
34 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
35 | [-6, 1, Conv, [256, 1, 1]], # route backbone P5
36 | [[-1, -2], 1, Concat, [1]],
37 | [-1, 3, BottleneckCSPB, [256]], # 17
38 | [-1, 1, Conv, [192, 1, 1]],
39 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
40 | [-13, 1, Conv, [192, 1, 1]], # route backbone P4
41 | [[-1, -2], 1, Concat, [1]],
42 | [-1, 3, BottleneckCSPB, [192]], # 22
43 | [-1, 1, Conv, [128, 1, 1]],
44 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
45 | [-20, 1, Conv, [128, 1, 1]], # route backbone P3
46 | [[-1, -2], 1, Concat, [1]],
47 | [-1, 3, BottleneckCSPB, [128]], # 27
48 | [-1, 1, Conv, [256, 3, 1]],
49 | [-2, 1, Conv, [192, 3, 2]],
50 | [[-1, 22], 1, Concat, [1]], # cat
51 | [-1, 3, BottleneckCSPB, [192]], # 31
52 | [-1, 1, Conv, [384, 3, 1]],
53 | [-2, 1, Conv, [256, 3, 2]],
54 | [[-1, 17], 1, Concat, [1]], # cat
55 | [-1, 3, BottleneckCSPB, [256]], # 35
56 | [-1, 1, Conv, [512, 3, 1]],
57 | [-2, 1, Conv, [320, 3, 2]],
58 | [[-1, 12], 1, Concat, [1]], # cat
59 | [-1, 3, BottleneckCSPB, [320]], # 39
60 | [-1, 1, Conv, [640, 3, 1]],
61 |
62 | [[28,32,36,40], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5, P6)
63 | ]
--------------------------------------------------------------------------------
/cfg/baseline/yolor-w6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # expand model depth
4 | width_multiple: 1.0 # expand layer channels
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # CSP-Darknet backbone
14 | backbone:
15 | # [from, number, module, args]
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [64, 3, 1]], # 1-P1/2
18 | [-1, 1, Conv, [128, 3, 2]], # 2-P2/4
19 | [-1, 3, BottleneckCSPA, [128]],
20 | [-1, 1, Conv, [256, 3, 2]], # 4-P3/8
21 | [-1, 7, BottleneckCSPA, [256]],
22 | [-1, 1, Conv, [512, 3, 2]], # 6-P4/16
23 | [-1, 7, BottleneckCSPA, [512]],
24 | [-1, 1, Conv, [768, 3, 2]], # 8-P5/32
25 | [-1, 3, BottleneckCSPA, [768]],
26 | [-1, 1, Conv, [1024, 3, 2]], # 10-P6/64
27 | [-1, 3, BottleneckCSPA, [1024]], # 11
28 | ]
29 |
30 | # CSP-Dark-PAN head
31 | head:
32 | [[-1, 1, SPPCSPC, [512]], # 12
33 | [-1, 1, Conv, [384, 1, 1]],
34 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
35 | [-6, 1, Conv, [384, 1, 1]], # route backbone P5
36 | [[-1, -2], 1, Concat, [1]],
37 | [-1, 3, BottleneckCSPB, [384]], # 17
38 | [-1, 1, Conv, [256, 1, 1]],
39 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
40 | [-13, 1, Conv, [256, 1, 1]], # route backbone P4
41 | [[-1, -2], 1, Concat, [1]],
42 | [-1, 3, BottleneckCSPB, [256]], # 22
43 | [-1, 1, Conv, [128, 1, 1]],
44 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
45 | [-20, 1, Conv, [128, 1, 1]], # route backbone P3
46 | [[-1, -2], 1, Concat, [1]],
47 | [-1, 3, BottleneckCSPB, [128]], # 27
48 | [-1, 1, Conv, [256, 3, 1]],
49 | [-2, 1, Conv, [256, 3, 2]],
50 | [[-1, 22], 1, Concat, [1]], # cat
51 | [-1, 3, BottleneckCSPB, [256]], # 31
52 | [-1, 1, Conv, [512, 3, 1]],
53 | [-2, 1, Conv, [384, 3, 2]],
54 | [[-1, 17], 1, Concat, [1]], # cat
55 | [-1, 3, BottleneckCSPB, [384]], # 35
56 | [-1, 1, Conv, [768, 3, 1]],
57 | [-2, 1, Conv, [512, 3, 2]],
58 | [[-1, 12], 1, Concat, [1]], # cat
59 | [-1, 3, BottleneckCSPB, [512]], # 39
60 | [-1, 1, Conv, [1024, 3, 1]],
61 |
62 | [[28,32,36,40], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5, P6)
63 | ]
--------------------------------------------------------------------------------
/utils/activations.py:
--------------------------------------------------------------------------------
1 | # Activation functions
2 |
3 | import torch
4 | import torch.nn as nn
5 | import torch.nn.functional as F
6 |
7 |
8 | # SiLU https://arxiv.org/pdf/1606.08415.pdf ----------------------------------------------------------------------------
9 | class SiLU(nn.Module): # export-friendly version of nn.SiLU()
10 | @staticmethod
11 | def forward(x):
12 | return x * torch.sigmoid(x)
13 |
14 |
15 | class Hardswish(nn.Module): # export-friendly version of nn.Hardswish()
16 | @staticmethod
17 | def forward(x):
18 | # return x * F.hardsigmoid(x) # for torchscript and CoreML
19 | return x * F.hardtanh(x + 3, 0., 6.) / 6. # for torchscript, CoreML and ONNX
20 |
21 |
22 | class MemoryEfficientSwish(nn.Module):
23 | class F(torch.autograd.Function):
24 | @staticmethod
25 | def forward(ctx, x):
26 | ctx.save_for_backward(x)
27 | return x * torch.sigmoid(x)
28 |
29 | @staticmethod
30 | def backward(ctx, grad_output):
31 | x = ctx.saved_tensors[0]
32 | sx = torch.sigmoid(x)
33 | return grad_output * (sx * (1 + x * (1 - sx)))
34 |
35 | def forward(self, x):
36 | return self.F.apply(x)
37 |
38 |
39 | # Mish https://github.com/digantamisra98/Mish --------------------------------------------------------------------------
40 | class Mish(nn.Module):
41 | @staticmethod
42 | def forward(x):
43 | return x * F.softplus(x).tanh()
44 |
45 |
46 | class MemoryEfficientMish(nn.Module):
47 | class F(torch.autograd.Function):
48 | @staticmethod
49 | def forward(ctx, x):
50 | ctx.save_for_backward(x)
51 | return x.mul(torch.tanh(F.softplus(x))) # x * tanh(ln(1 + exp(x)))
52 |
53 | @staticmethod
54 | def backward(ctx, grad_output):
55 | x = ctx.saved_tensors[0]
56 | sx = torch.sigmoid(x)
57 | fx = F.softplus(x).tanh()
58 | return grad_output * (fx + x * sx * (1 - fx * fx))
59 |
60 | def forward(self, x):
61 | return self.F.apply(x)
62 |
63 |
64 | # FReLU https://arxiv.org/abs/2007.11824 -------------------------------------------------------------------------------
65 | class FReLU(nn.Module):
66 | def __init__(self, c1, k=3): # ch_in, kernel
67 | super().__init__()
68 | self.conv = nn.Conv2d(c1, c1, k, 1, 1, groups=c1, bias=False)
69 | self.bn = nn.BatchNorm2d(c1)
70 |
71 | def forward(self, x):
72 | return torch.max(x, self.bn(self.conv(x)))
73 |
--------------------------------------------------------------------------------
/cfg/deploy/yolov7-tiny-silu.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [10,13, 16,30, 33,23] # P3/8
9 | - [30,61, 62,45, 59,119] # P4/16
10 | - [116,90, 156,198, 373,326] # P5/32
11 |
12 | # YOLOv7-tiny backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [32, 3, 2]], # 0-P1/2
16 |
17 | [-1, 1, Conv, [64, 3, 2]], # 1-P2/4
18 |
19 | [-1, 1, Conv, [32, 1, 1]],
20 | [-2, 1, Conv, [32, 1, 1]],
21 | [-1, 1, Conv, [32, 3, 1]],
22 | [-1, 1, Conv, [32, 3, 1]],
23 | [[-1, -2, -3, -4], 1, Concat, [1]],
24 | [-1, 1, Conv, [64, 1, 1]], # 7
25 |
26 | [-1, 1, MP, []], # 8-P3/8
27 | [-1, 1, Conv, [64, 1, 1]],
28 | [-2, 1, Conv, [64, 1, 1]],
29 | [-1, 1, Conv, [64, 3, 1]],
30 | [-1, 1, Conv, [64, 3, 1]],
31 | [[-1, -2, -3, -4], 1, Concat, [1]],
32 | [-1, 1, Conv, [128, 1, 1]], # 14
33 |
34 | [-1, 1, MP, []], # 15-P4/16
35 | [-1, 1, Conv, [128, 1, 1]],
36 | [-2, 1, Conv, [128, 1, 1]],
37 | [-1, 1, Conv, [128, 3, 1]],
38 | [-1, 1, Conv, [128, 3, 1]],
39 | [[-1, -2, -3, -4], 1, Concat, [1]],
40 | [-1, 1, Conv, [256, 1, 1]], # 21
41 |
42 | [-1, 1, MP, []], # 22-P5/32
43 | [-1, 1, Conv, [256, 1, 1]],
44 | [-2, 1, Conv, [256, 1, 1]],
45 | [-1, 1, Conv, [256, 3, 1]],
46 | [-1, 1, Conv, [256, 3, 1]],
47 | [[-1, -2, -3, -4], 1, Concat, [1]],
48 | [-1, 1, Conv, [512, 1, 1]], # 28
49 | ]
50 |
51 | # YOLOv7-tiny head
52 | head:
53 | [[-1, 1, Conv, [256, 1, 1]],
54 | [-2, 1, Conv, [256, 1, 1]],
55 | [-1, 1, SP, [5]],
56 | [-2, 1, SP, [9]],
57 | [-3, 1, SP, [13]],
58 | [[-1, -2, -3, -4], 1, Concat, [1]],
59 | [-1, 1, Conv, [256, 1, 1]],
60 | [[-1, -7], 1, Concat, [1]],
61 | [-1, 1, Conv, [256, 1, 1]], # 37
62 |
63 | [-1, 1, Conv, [128, 1, 1]],
64 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
65 | [21, 1, Conv, [128, 1, 1]], # route backbone P4
66 | [[-1, -2], 1, Concat, [1]],
67 |
68 | [-1, 1, Conv, [64, 1, 1]],
69 | [-2, 1, Conv, [64, 1, 1]],
70 | [-1, 1, Conv, [64, 3, 1]],
71 | [-1, 1, Conv, [64, 3, 1]],
72 | [[-1, -2, -3, -4], 1, Concat, [1]],
73 | [-1, 1, Conv, [128, 1, 1]], # 47
74 |
75 | [-1, 1, Conv, [64, 1, 1]],
76 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
77 | [14, 1, Conv, [64, 1, 1]], # route backbone P3
78 | [[-1, -2], 1, Concat, [1]],
79 |
80 | [-1, 1, Conv, [32, 1, 1]],
81 | [-2, 1, Conv, [32, 1, 1]],
82 | [-1, 1, Conv, [32, 3, 1]],
83 | [-1, 1, Conv, [32, 3, 1]],
84 | [[-1, -2, -3, -4], 1, Concat, [1]],
85 | [-1, 1, Conv, [64, 1, 1]], # 57
86 |
87 | [-1, 1, Conv, [128, 3, 2]],
88 | [[-1, 47], 1, Concat, [1]],
89 |
90 | [-1, 1, Conv, [64, 1, 1]],
91 | [-2, 1, Conv, [64, 1, 1]],
92 | [-1, 1, Conv, [64, 3, 1]],
93 | [-1, 1, Conv, [64, 3, 1]],
94 | [[-1, -2, -3, -4], 1, Concat, [1]],
95 | [-1, 1, Conv, [128, 1, 1]], # 65
96 |
97 | [-1, 1, Conv, [256, 3, 2]],
98 | [[-1, 37], 1, Concat, [1]],
99 |
100 | [-1, 1, Conv, [128, 1, 1]],
101 | [-2, 1, Conv, [128, 1, 1]],
102 | [-1, 1, Conv, [128, 3, 1]],
103 | [-1, 1, Conv, [128, 3, 1]],
104 | [[-1, -2, -3, -4], 1, Concat, [1]],
105 | [-1, 1, Conv, [256, 1, 1]], # 73
106 |
107 | [57, 1, Conv, [128, 3, 1]],
108 | [65, 1, Conv, [256, 3, 1]],
109 | [73, 1, Conv, [512, 3, 1]],
110 |
111 | [[74,75,76], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
112 | ]
113 |
--------------------------------------------------------------------------------
/hubconf.py:
--------------------------------------------------------------------------------
1 | """PyTorch Hub models
2 |
3 | Usage:
4 | import torch
5 | model = torch.hub.load('repo', 'model')
6 | """
7 |
8 | from pathlib import Path
9 |
10 | import torch
11 |
12 | from models.yolo import Model
13 | from utils.general import check_requirements, set_logging
14 | from utils.google_utils import attempt_download
15 | from utils.torch_utils import select_device
16 |
17 | dependencies = ['torch', 'yaml']
18 | check_requirements(Path(__file__).parent / 'requirements.txt', exclude=('pycocotools', 'thop'))
19 | set_logging()
20 |
21 |
22 | def create(name, pretrained, channels, classes, autoshape):
23 | """Creates a specified model
24 |
25 | Arguments:
26 | name (str): name of model, i.e. 'yolov7'
27 | pretrained (bool): load pretrained weights into the model
28 | channels (int): number of input channels
29 | classes (int): number of model classes
30 |
31 | Returns:
32 | pytorch model
33 | """
34 | try:
35 | cfg = list((Path(__file__).parent / 'cfg').rglob(f'{name}.yaml'))[0] # model.yaml path
36 | model = Model(cfg, channels, classes)
37 | if pretrained:
38 | fname = f'{name}.pt' # checkpoint filename
39 | attempt_download(fname) # download if not found locally
40 | ckpt = torch.load(fname, map_location=torch.device('cpu')) # load
41 | msd = model.state_dict() # model state_dict
42 | csd = ckpt['model'].float().state_dict() # checkpoint state_dict as FP32
43 | csd = {k: v for k, v in csd.items() if msd[k].shape == v.shape} # filter
44 | model.load_state_dict(csd, strict=False) # load
45 | if len(ckpt['model'].names) == classes:
46 | model.names = ckpt['model'].names # set class names attribute
47 | if autoshape:
48 | model = model.autoshape() # for file/URI/PIL/cv2/np inputs and NMS
49 | device = select_device('0' if torch.cuda.is_available() else 'cpu') # default to GPU if available
50 | return model.to(device)
51 |
52 | except Exception as e:
53 | s = 'Cache maybe be out of date, try force_reload=True.'
54 | raise Exception(s) from e
55 |
56 |
57 | def custom(path_or_model='path/to/model.pt', autoshape=True):
58 | """custom mode
59 |
60 | Arguments (3 options):
61 | path_or_model (str): 'path/to/model.pt'
62 | path_or_model (dict): torch.load('path/to/model.pt')
63 | path_or_model (nn.Module): torch.load('path/to/model.pt')['model']
64 |
65 | Returns:
66 | pytorch model
67 | """
68 | model = torch.load(path_or_model) if isinstance(path_or_model, str) else path_or_model # load checkpoint
69 | if isinstance(model, dict):
70 | model = model['ema' if model.get('ema') else 'model'] # load model
71 |
72 | hub_model = Model(model.yaml).to(next(model.parameters()).device) # create
73 | hub_model.load_state_dict(model.float().state_dict()) # load state_dict
74 | hub_model.names = model.names # class names
75 | if autoshape:
76 | hub_model = hub_model.autoshape() # for file/URI/PIL/cv2/np inputs and NMS
77 | device = select_device('0' if torch.cuda.is_available() else 'cpu') # default to GPU if available
78 | return hub_model.to(device)
79 |
80 |
81 | def yolov7(pretrained=True, channels=3, classes=80, autoshape=True):
82 | return create('yolov7', pretrained, channels, classes, autoshape)
83 |
84 |
85 | if __name__ == '__main__':
86 | model = custom(path_or_model='yolov7.pt') # custom example
87 | # model = create(name='yolov7', pretrained=True, channels=3, classes=80, autoshape=True) # pretrained example
88 |
89 | # Verify inference
90 | import numpy as np
91 | from PIL import Image
92 |
93 | imgs = [np.zeros((640, 480, 3))]
94 |
95 | results = model(imgs) # batched inference
96 | results.print()
97 | results.save()
98 |
--------------------------------------------------------------------------------
/cfg/deploy/yolov7.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 2 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # yolov7 backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [32, 3, 1]], # 0
16 |
17 | [-1, 1, Conv, [64, 3, 2]], # 1-P1/2
18 | [-1, 1, Conv, [64, 3, 1]],
19 |
20 | [-1, 1, Conv, [128, 3, 2]], # 3-P2/4
21 | [-1, 1, Conv, [64, 1, 1]],
22 | [-2, 1, Conv, [64, 1, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [[-1, -3, -5, -6], 1, Concat, [1]],
28 | [-1, 1, Conv, [256, 1, 1]], # 11
29 |
30 | [-1, 1, MP, []],
31 | [-1, 1, Conv, [128, 1, 1]],
32 | [-3, 1, Conv, [128, 1, 1]],
33 | [-1, 1, Conv, [128, 3, 2]],
34 | [[-1, -3], 1, Concat, [1]], # 16-P3/8
35 | [-1, 1, Conv, [128, 1, 1]],
36 | [-2, 1, Conv, [128, 1, 1]],
37 | [-1, 1, Conv, [128, 3, 1]],
38 | [-1, 1, Conv, [128, 3, 1]],
39 | [-1, 1, Conv, [128, 3, 1]],
40 | [-1, 1, Conv, [128, 3, 1]],
41 | [[-1, -3, -5, -6], 1, Concat, [1]],
42 | [-1, 1, Conv, [512, 1, 1]], # 24
43 |
44 | [-1, 1, MP, []],
45 | [-1, 1, Conv, [256, 1, 1]],
46 | [-3, 1, Conv, [256, 1, 1]],
47 | [-1, 1, Conv, [256, 3, 2]],
48 | [[-1, -3], 1, Concat, [1]], # 29-P4/16
49 | [-1, 1, Conv, [256, 1, 1]],
50 | [-2, 1, Conv, [256, 1, 1]],
51 | [-1, 1, Conv, [256, 3, 1]],
52 | [-1, 1, Conv, [256, 3, 1]],
53 | [-1, 1, Conv, [256, 3, 1]],
54 | [-1, 1, Conv, [256, 3, 1]],
55 | [[-1, -3, -5, -6], 1, Concat, [1]],
56 | [-1, 1, Conv, [1024, 1, 1]], # 37
57 |
58 | [-1, 1, MP, []],
59 | [-1, 1, Conv, [512, 1, 1]],
60 | [-3, 1, Conv, [512, 1, 1]],
61 | [-1, 1, Conv, [512, 3, 2]],
62 | [[-1, -3], 1, Concat, [1]], # 42-P5/32
63 | [-1, 1, Conv, [256, 1, 1]],
64 | [-2, 1, Conv, [256, 1, 1]],
65 | [-1, 1, Conv, [256, 3, 1]],
66 | [-1, 1, Conv, [256, 3, 1]],
67 | [-1, 1, Conv, [256, 3, 1]],
68 | [-1, 1, Conv, [256, 3, 1]],
69 | [[-1, -3, -5, -6], 1, Concat, [1]],
70 | [-1, 1, Conv, [1024, 1, 1]], # 50
71 | ]
72 |
73 | # yolov7 head
74 | head:
75 | [[-1, 1, SPPCSPC, [512]], # 51
76 |
77 | [-1, 1, Conv, [256, 1, 1]],
78 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
79 | [37, 1, Conv, [256, 1, 1]], # route backbone P4
80 | [[-1, -2], 1, Concat, [1]],
81 |
82 | [-1, 1, Conv, [256, 1, 1]],
83 | [-2, 1, Conv, [256, 1, 1]],
84 | [-1, 1, Conv, [128, 3, 1]],
85 | [-1, 1, Conv, [128, 3, 1]],
86 | [-1, 1, Conv, [128, 3, 1]],
87 | [-1, 1, Conv, [128, 3, 1]],
88 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
89 | [-1, 1, Conv, [256, 1, 1]], # 63
90 |
91 | [-1, 1, Conv, [128, 1, 1]],
92 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
93 | [24, 1, Conv, [128, 1, 1]], # route backbone P3
94 | [[-1, -2], 1, Concat, [1]],
95 |
96 | [-1, 1, Conv, [128, 1, 1]],
97 | [-2, 1, Conv, [128, 1, 1]],
98 | [-1, 1, Conv, [64, 3, 1]],
99 | [-1, 1, Conv, [64, 3, 1]],
100 | [-1, 1, Conv, [64, 3, 1]],
101 | [-1, 1, Conv, [64, 3, 1]],
102 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
103 | [-1, 1, Conv, [128, 1, 1]], # 75
104 |
105 | [-1, 1, MP, []],
106 | [-1, 1, Conv, [128, 1, 1]],
107 | [-3, 1, Conv, [128, 1, 1]],
108 | [-1, 1, Conv, [128, 3, 2]],
109 | [[-1, -3, 63], 1, Concat, [1]],
110 |
111 | [-1, 1, Conv, [256, 1, 1]],
112 | [-2, 1, Conv, [256, 1, 1]],
113 | [-1, 1, Conv, [128, 3, 1]],
114 | [-1, 1, Conv, [128, 3, 1]],
115 | [-1, 1, Conv, [128, 3, 1]],
116 | [-1, 1, Conv, [128, 3, 1]],
117 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
118 | [-1, 1, Conv, [256, 1, 1]], # 88
119 |
120 | [-1, 1, MP, []],
121 | [-1, 1, Conv, [256, 1, 1]],
122 | [-3, 1, Conv, [256, 1, 1]],
123 | [-1, 1, Conv, [256, 3, 2]],
124 | [[-1, -3, 51], 1, Concat, [1]],
125 |
126 | [-1, 1, Conv, [512, 1, 1]],
127 | [-2, 1, Conv, [512, 1, 1]],
128 | [-1, 1, Conv, [256, 3, 1]],
129 | [-1, 1, Conv, [256, 3, 1]],
130 | [-1, 1, Conv, [256, 3, 1]],
131 | [-1, 1, Conv, [256, 3, 1]],
132 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
133 | [-1, 1, Conv, [512, 1, 1]], # 101
134 |
135 | [75, 1, RepConv, [256, 3, 1]],
136 | [88, 1, RepConv, [512, 3, 1]],
137 | [101, 1, RepConv, [1024, 3, 1]],
138 |
139 | [[102,103,104], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
140 | ]
141 |
--------------------------------------------------------------------------------
/cfg/training/yolov7.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # yolov7 backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [32, 3, 1]], # 0
16 |
17 | [-1, 1, Conv, [64, 3, 2]], # 1-P1/2
18 | [-1, 1, Conv, [64, 3, 1]],
19 |
20 | [-1, 1, Conv, [128, 3, 2]], # 3-P2/4
21 | [-1, 1, Conv, [64, 1, 1]],
22 | [-2, 1, Conv, [64, 1, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [[-1, -3, -5, -6], 1, Concat, [1]],
28 | [-1, 1, Conv, [256, 1, 1]], # 11
29 |
30 | [-1, 1, MP, []],
31 | [-1, 1, Conv, [128, 1, 1]],
32 | [-3, 1, Conv, [128, 1, 1]],
33 | [-1, 1, Conv, [128, 3, 2]],
34 | [[-1, -3], 1, Concat, [1]], # 16-P3/8
35 | [-1, 1, Conv, [128, 1, 1]],
36 | [-2, 1, Conv, [128, 1, 1]],
37 | [-1, 1, Conv, [128, 3, 1]],
38 | [-1, 1, Conv, [128, 3, 1]],
39 | [-1, 1, Conv, [128, 3, 1]],
40 | [-1, 1, Conv, [128, 3, 1]],
41 | [[-1, -3, -5, -6], 1, Concat, [1]],
42 | [-1, 1, Conv, [512, 1, 1]], # 24
43 |
44 | [-1, 1, MP, []],
45 | [-1, 1, Conv, [256, 1, 1]],
46 | [-3, 1, Conv, [256, 1, 1]],
47 | [-1, 1, Conv, [256, 3, 2]],
48 | [[-1, -3], 1, Concat, [1]], # 29-P4/16
49 | [-1, 1, Conv, [256, 1, 1]],
50 | [-2, 1, Conv, [256, 1, 1]],
51 | [-1, 1, Conv, [256, 3, 1]],
52 | [-1, 1, Conv, [256, 3, 1]],
53 | [-1, 1, Conv, [256, 3, 1]],
54 | [-1, 1, Conv, [256, 3, 1]],
55 | [[-1, -3, -5, -6], 1, Concat, [1]],
56 | [-1, 1, Conv, [1024, 1, 1]], # 37
57 |
58 | [-1, 1, MP, []],
59 | [-1, 1, Conv, [512, 1, 1]],
60 | [-3, 1, Conv, [512, 1, 1]],
61 | [-1, 1, Conv, [512, 3, 2]],
62 | [[-1, -3], 1, Concat, [1]], # 42-P5/32
63 | [-1, 1, Conv, [256, 1, 1]],
64 | [-2, 1, Conv, [256, 1, 1]],
65 | [-1, 1, Conv, [256, 3, 1]],
66 | [-1, 1, Conv, [256, 3, 1]],
67 | [-1, 1, Conv, [256, 3, 1]],
68 | [-1, 1, Conv, [256, 3, 1]],
69 | [[-1, -3, -5, -6], 1, Concat, [1]],
70 | [-1, 1, Conv, [1024, 1, 1]], # 50
71 | ]
72 |
73 | # yolov7 head
74 | head:
75 | [[-1, 1, SPPCSPC, [512]], # 51
76 |
77 | [-1, 1, Conv, [256, 1, 1]],
78 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
79 | [37, 1, Conv, [256, 1, 1]], # route backbone P4
80 | [[-1, -2], 1, Concat, [1]],
81 |
82 | [-1, 1, Conv, [256, 1, 1]],
83 | [-2, 1, Conv, [256, 1, 1]],
84 | [-1, 1, Conv, [128, 3, 1]],
85 | [-1, 1, Conv, [128, 3, 1]],
86 | [-1, 1, Conv, [128, 3, 1]],
87 | [-1, 1, Conv, [128, 3, 1]],
88 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
89 | [-1, 1, Conv, [256, 1, 1]], # 63
90 |
91 | [-1, 1, Conv, [128, 1, 1]],
92 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
93 | [24, 1, Conv, [128, 1, 1]], # route backbone P3
94 | [[-1, -2], 1, Concat, [1]],
95 |
96 | [-1, 1, Conv, [128, 1, 1]],
97 | [-2, 1, Conv, [128, 1, 1]],
98 | [-1, 1, Conv, [64, 3, 1]],
99 | [-1, 1, Conv, [64, 3, 1]],
100 | [-1, 1, Conv, [64, 3, 1]],
101 | [-1, 1, Conv, [64, 3, 1]],
102 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
103 | [-1, 1, Conv, [128, 1, 1]], # 75
104 |
105 | [-1, 1, MP, []],
106 | [-1, 1, Conv, [128, 1, 1]],
107 | [-3, 1, Conv, [128, 1, 1]],
108 | [-1, 1, Conv, [128, 3, 2]],
109 | [[-1, -3, 63], 1, Concat, [1]],
110 |
111 | [-1, 1, Conv, [256, 1, 1]],
112 | [-2, 1, Conv, [256, 1, 1]],
113 | [-1, 1, Conv, [128, 3, 1]],
114 | [-1, 1, Conv, [128, 3, 1]],
115 | [-1, 1, Conv, [128, 3, 1]],
116 | [-1, 1, Conv, [128, 3, 1]],
117 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
118 | [-1, 1, Conv, [256, 1, 1]], # 88
119 |
120 | [-1, 1, MP, []],
121 | [-1, 1, Conv, [256, 1, 1]],
122 | [-3, 1, Conv, [256, 1, 1]],
123 | [-1, 1, Conv, [256, 3, 2]],
124 | [[-1, -3, 51], 1, Concat, [1]],
125 |
126 | [-1, 1, Conv, [512, 1, 1]],
127 | [-2, 1, Conv, [512, 1, 1]],
128 | [-1, 1, Conv, [256, 3, 1]],
129 | [-1, 1, Conv, [256, 3, 1]],
130 | [-1, 1, Conv, [256, 3, 1]],
131 | [-1, 1, Conv, [256, 3, 1]],
132 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
133 | [-1, 1, Conv, [512, 1, 1]], # 101
134 |
135 | [75, 1, RepConv, [256, 3, 1]],
136 | [88, 1, RepConv, [512, 3, 1]],
137 | [101, 1, RepConv, [1024, 3, 1]],
138 |
139 | [[102,103,104], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5)
140 | ]
141 |
--------------------------------------------------------------------------------
/cfg/deploy/yolov7-tiny.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [10,13, 16,30, 33,23] # P3/8
9 | - [30,61, 62,45, 59,119] # P4/16
10 | - [116,90, 156,198, 373,326] # P5/32
11 |
12 | # yolov7-tiny backbone
13 | backbone:
14 | # [from, number, module, args] c2, k=1, s=1, p=None, g=1, act=True
15 | [[-1, 1, Conv, [32, 3, 2, None, 1, nn.LeakyReLU(0.1)]], # 0-P1/2
16 |
17 | [-1, 1, Conv, [64, 3, 2, None, 1, nn.LeakyReLU(0.1)]], # 1-P2/4
18 |
19 | [-1, 1, Conv, [32, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
20 | [-2, 1, Conv, [32, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
21 | [-1, 1, Conv, [32, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
22 | [-1, 1, Conv, [32, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
23 | [[-1, -2, -3, -4], 1, Concat, [1]],
24 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 7
25 |
26 | [-1, 1, MP, []], # 8-P3/8
27 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
28 | [-2, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
29 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
30 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
31 | [[-1, -2, -3, -4], 1, Concat, [1]],
32 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 14
33 |
34 | [-1, 1, MP, []], # 15-P4/16
35 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
36 | [-2, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
37 | [-1, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
38 | [-1, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
39 | [[-1, -2, -3, -4], 1, Concat, [1]],
40 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 21
41 |
42 | [-1, 1, MP, []], # 22-P5/32
43 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
44 | [-2, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
45 | [-1, 1, Conv, [256, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
46 | [-1, 1, Conv, [256, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
47 | [[-1, -2, -3, -4], 1, Concat, [1]],
48 | [-1, 1, Conv, [512, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 28
49 | ]
50 |
51 | # yolov7-tiny head
52 | head:
53 | [[-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
54 | [-2, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
55 | [-1, 1, SP, [5]],
56 | [-2, 1, SP, [9]],
57 | [-3, 1, SP, [13]],
58 | [[-1, -2, -3, -4], 1, Concat, [1]],
59 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
60 | [[-1, -7], 1, Concat, [1]],
61 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 37
62 |
63 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
64 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
65 | [21, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # route backbone P4
66 | [[-1, -2], 1, Concat, [1]],
67 |
68 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
69 | [-2, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
70 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
71 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
72 | [[-1, -2, -3, -4], 1, Concat, [1]],
73 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 47
74 |
75 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
76 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
77 | [14, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # route backbone P3
78 | [[-1, -2], 1, Concat, [1]],
79 |
80 | [-1, 1, Conv, [32, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
81 | [-2, 1, Conv, [32, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
82 | [-1, 1, Conv, [32, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
83 | [-1, 1, Conv, [32, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
84 | [[-1, -2, -3, -4], 1, Concat, [1]],
85 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 57
86 |
87 | [-1, 1, Conv, [128, 3, 2, None, 1, nn.LeakyReLU(0.1)]],
88 | [[-1, 47], 1, Concat, [1]],
89 |
90 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
91 | [-2, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
92 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
93 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
94 | [[-1, -2, -3, -4], 1, Concat, [1]],
95 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 65
96 |
97 | [-1, 1, Conv, [256, 3, 2, None, 1, nn.LeakyReLU(0.1)]],
98 | [[-1, 37], 1, Concat, [1]],
99 |
100 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
101 | [-2, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
102 | [-1, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
103 | [-1, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
104 | [[-1, -2, -3, -4], 1, Concat, [1]],
105 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 73
106 |
107 | [57, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
108 | [65, 1, Conv, [256, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
109 | [73, 1, Conv, [512, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
110 |
111 | [[74,75,76], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
112 | ]
113 |
--------------------------------------------------------------------------------
/cfg/training/yolov7-tiny.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [10,13, 16,30, 33,23] # P3/8
9 | - [30,61, 62,45, 59,119] # P4/16
10 | - [116,90, 156,198, 373,326] # P5/32
11 |
12 | # yolov7-tiny backbone
13 | backbone:
14 | # [from, number, module, args] c2, k=1, s=1, p=None, g=1, act=True
15 | [[-1, 1, Conv, [32, 3, 2, None, 1, nn.LeakyReLU(0.1)]], # 0-P1/2
16 |
17 | [-1, 1, Conv, [64, 3, 2, None, 1, nn.LeakyReLU(0.1)]], # 1-P2/4
18 |
19 | [-1, 1, Conv, [32, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
20 | [-2, 1, Conv, [32, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
21 | [-1, 1, Conv, [32, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
22 | [-1, 1, Conv, [32, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
23 | [[-1, -2, -3, -4], 1, Concat, [1]],
24 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 7
25 |
26 | [-1, 1, MP, []], # 8-P3/8
27 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
28 | [-2, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
29 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
30 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
31 | [[-1, -2, -3, -4], 1, Concat, [1]],
32 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 14
33 |
34 | [-1, 1, MP, []], # 15-P4/16
35 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
36 | [-2, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
37 | [-1, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
38 | [-1, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
39 | [[-1, -2, -3, -4], 1, Concat, [1]],
40 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 21
41 |
42 | [-1, 1, MP, []], # 22-P5/32
43 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
44 | [-2, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
45 | [-1, 1, Conv, [256, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
46 | [-1, 1, Conv, [256, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
47 | [[-1, -2, -3, -4], 1, Concat, [1]],
48 | [-1, 1, Conv, [512, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 28
49 | ]
50 |
51 | # yolov7-tiny head
52 | head:
53 | [[-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
54 | [-2, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
55 | [-1, 1, SP, [5]],
56 | [-2, 1, SP, [9]],
57 | [-3, 1, SP, [13]],
58 | [[-1, -2, -3, -4], 1, Concat, [1]],
59 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
60 | [[-1, -7], 1, Concat, [1]],
61 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 37
62 |
63 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
64 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
65 | [21, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # route backbone P4
66 | [[-1, -2], 1, Concat, [1]],
67 |
68 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
69 | [-2, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
70 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
71 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
72 | [[-1, -2, -3, -4], 1, Concat, [1]],
73 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 47
74 |
75 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
76 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
77 | [14, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # route backbone P3
78 | [[-1, -2], 1, Concat, [1]],
79 |
80 | [-1, 1, Conv, [32, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
81 | [-2, 1, Conv, [32, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
82 | [-1, 1, Conv, [32, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
83 | [-1, 1, Conv, [32, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
84 | [[-1, -2, -3, -4], 1, Concat, [1]],
85 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 57
86 |
87 | [-1, 1, Conv, [128, 3, 2, None, 1, nn.LeakyReLU(0.1)]],
88 | [[-1, 47], 1, Concat, [1]],
89 |
90 | [-1, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
91 | [-2, 1, Conv, [64, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
92 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
93 | [-1, 1, Conv, [64, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
94 | [[-1, -2, -3, -4], 1, Concat, [1]],
95 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 65
96 |
97 | [-1, 1, Conv, [256, 3, 2, None, 1, nn.LeakyReLU(0.1)]],
98 | [[-1, 37], 1, Concat, [1]],
99 |
100 | [-1, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
101 | [-2, 1, Conv, [128, 1, 1, None, 1, nn.LeakyReLU(0.1)]],
102 | [-1, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
103 | [-1, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
104 | [[-1, -2, -3, -4], 1, Concat, [1]],
105 | [-1, 1, Conv, [256, 1, 1, None, 1, nn.LeakyReLU(0.1)]], # 73
106 |
107 | [57, 1, Conv, [128, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
108 | [65, 1, Conv, [256, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
109 | [73, 1, Conv, [512, 3, 1, None, 1, nn.LeakyReLU(0.1)]],
110 |
111 | [[74,75,76], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5)
112 | ]
113 |
--------------------------------------------------------------------------------
/cfg/deploy/yolov7x.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # yolov7x backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [40, 3, 1]], # 0
16 |
17 | [-1, 1, Conv, [80, 3, 2]], # 1-P1/2
18 | [-1, 1, Conv, [80, 3, 1]],
19 |
20 | [-1, 1, Conv, [160, 3, 2]], # 3-P2/4
21 | [-1, 1, Conv, [64, 1, 1]],
22 | [-2, 1, Conv, [64, 1, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [-1, 1, Conv, [64, 3, 1]],
28 | [-1, 1, Conv, [64, 3, 1]],
29 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
30 | [-1, 1, Conv, [320, 1, 1]], # 13
31 |
32 | [-1, 1, MP, []],
33 | [-1, 1, Conv, [160, 1, 1]],
34 | [-3, 1, Conv, [160, 1, 1]],
35 | [-1, 1, Conv, [160, 3, 2]],
36 | [[-1, -3], 1, Concat, [1]], # 18-P3/8
37 | [-1, 1, Conv, [128, 1, 1]],
38 | [-2, 1, Conv, [128, 1, 1]],
39 | [-1, 1, Conv, [128, 3, 1]],
40 | [-1, 1, Conv, [128, 3, 1]],
41 | [-1, 1, Conv, [128, 3, 1]],
42 | [-1, 1, Conv, [128, 3, 1]],
43 | [-1, 1, Conv, [128, 3, 1]],
44 | [-1, 1, Conv, [128, 3, 1]],
45 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
46 | [-1, 1, Conv, [640, 1, 1]], # 28
47 |
48 | [-1, 1, MP, []],
49 | [-1, 1, Conv, [320, 1, 1]],
50 | [-3, 1, Conv, [320, 1, 1]],
51 | [-1, 1, Conv, [320, 3, 2]],
52 | [[-1, -3], 1, Concat, [1]], # 33-P4/16
53 | [-1, 1, Conv, [256, 1, 1]],
54 | [-2, 1, Conv, [256, 1, 1]],
55 | [-1, 1, Conv, [256, 3, 1]],
56 | [-1, 1, Conv, [256, 3, 1]],
57 | [-1, 1, Conv, [256, 3, 1]],
58 | [-1, 1, Conv, [256, 3, 1]],
59 | [-1, 1, Conv, [256, 3, 1]],
60 | [-1, 1, Conv, [256, 3, 1]],
61 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
62 | [-1, 1, Conv, [1280, 1, 1]], # 43
63 |
64 | [-1, 1, MP, []],
65 | [-1, 1, Conv, [640, 1, 1]],
66 | [-3, 1, Conv, [640, 1, 1]],
67 | [-1, 1, Conv, [640, 3, 2]],
68 | [[-1, -3], 1, Concat, [1]], # 48-P5/32
69 | [-1, 1, Conv, [256, 1, 1]],
70 | [-2, 1, Conv, [256, 1, 1]],
71 | [-1, 1, Conv, [256, 3, 1]],
72 | [-1, 1, Conv, [256, 3, 1]],
73 | [-1, 1, Conv, [256, 3, 1]],
74 | [-1, 1, Conv, [256, 3, 1]],
75 | [-1, 1, Conv, [256, 3, 1]],
76 | [-1, 1, Conv, [256, 3, 1]],
77 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
78 | [-1, 1, Conv, [1280, 1, 1]], # 58
79 | ]
80 |
81 | # yolov7x head
82 | head:
83 | [[-1, 1, SPPCSPC, [640]], # 59
84 |
85 | [-1, 1, Conv, [320, 1, 1]],
86 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
87 | [43, 1, Conv, [320, 1, 1]], # route backbone P4
88 | [[-1, -2], 1, Concat, [1]],
89 |
90 | [-1, 1, Conv, [256, 1, 1]],
91 | [-2, 1, Conv, [256, 1, 1]],
92 | [-1, 1, Conv, [256, 3, 1]],
93 | [-1, 1, Conv, [256, 3, 1]],
94 | [-1, 1, Conv, [256, 3, 1]],
95 | [-1, 1, Conv, [256, 3, 1]],
96 | [-1, 1, Conv, [256, 3, 1]],
97 | [-1, 1, Conv, [256, 3, 1]],
98 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
99 | [-1, 1, Conv, [320, 1, 1]], # 73
100 |
101 | [-1, 1, Conv, [160, 1, 1]],
102 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
103 | [28, 1, Conv, [160, 1, 1]], # route backbone P3
104 | [[-1, -2], 1, Concat, [1]],
105 |
106 | [-1, 1, Conv, [128, 1, 1]],
107 | [-2, 1, Conv, [128, 1, 1]],
108 | [-1, 1, Conv, [128, 3, 1]],
109 | [-1, 1, Conv, [128, 3, 1]],
110 | [-1, 1, Conv, [128, 3, 1]],
111 | [-1, 1, Conv, [128, 3, 1]],
112 | [-1, 1, Conv, [128, 3, 1]],
113 | [-1, 1, Conv, [128, 3, 1]],
114 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
115 | [-1, 1, Conv, [160, 1, 1]], # 87
116 |
117 | [-1, 1, MP, []],
118 | [-1, 1, Conv, [160, 1, 1]],
119 | [-3, 1, Conv, [160, 1, 1]],
120 | [-1, 1, Conv, [160, 3, 2]],
121 | [[-1, -3, 73], 1, Concat, [1]],
122 |
123 | [-1, 1, Conv, [256, 1, 1]],
124 | [-2, 1, Conv, [256, 1, 1]],
125 | [-1, 1, Conv, [256, 3, 1]],
126 | [-1, 1, Conv, [256, 3, 1]],
127 | [-1, 1, Conv, [256, 3, 1]],
128 | [-1, 1, Conv, [256, 3, 1]],
129 | [-1, 1, Conv, [256, 3, 1]],
130 | [-1, 1, Conv, [256, 3, 1]],
131 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
132 | [-1, 1, Conv, [320, 1, 1]], # 102
133 |
134 | [-1, 1, MP, []],
135 | [-1, 1, Conv, [320, 1, 1]],
136 | [-3, 1, Conv, [320, 1, 1]],
137 | [-1, 1, Conv, [320, 3, 2]],
138 | [[-1, -3, 59], 1, Concat, [1]],
139 |
140 | [-1, 1, Conv, [512, 1, 1]],
141 | [-2, 1, Conv, [512, 1, 1]],
142 | [-1, 1, Conv, [512, 3, 1]],
143 | [-1, 1, Conv, [512, 3, 1]],
144 | [-1, 1, Conv, [512, 3, 1]],
145 | [-1, 1, Conv, [512, 3, 1]],
146 | [-1, 1, Conv, [512, 3, 1]],
147 | [-1, 1, Conv, [512, 3, 1]],
148 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
149 | [-1, 1, Conv, [640, 1, 1]], # 117
150 |
151 | [87, 1, Conv, [320, 3, 1]],
152 | [102, 1, Conv, [640, 3, 1]],
153 | [117, 1, Conv, [1280, 3, 1]],
154 |
155 | [[118,119,120], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
156 | ]
157 |
--------------------------------------------------------------------------------
/cfg/training/yolov7x.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [12,16, 19,36, 40,28] # P3/8
9 | - [36,75, 76,55, 72,146] # P4/16
10 | - [142,110, 192,243, 459,401] # P5/32
11 |
12 | # yolov7 backbone
13 | backbone:
14 | # [from, number, module, args]
15 | [[-1, 1, Conv, [40, 3, 1]], # 0
16 |
17 | [-1, 1, Conv, [80, 3, 2]], # 1-P1/2
18 | [-1, 1, Conv, [80, 3, 1]],
19 |
20 | [-1, 1, Conv, [160, 3, 2]], # 3-P2/4
21 | [-1, 1, Conv, [64, 1, 1]],
22 | [-2, 1, Conv, [64, 1, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [-1, 1, Conv, [64, 3, 1]],
28 | [-1, 1, Conv, [64, 3, 1]],
29 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
30 | [-1, 1, Conv, [320, 1, 1]], # 13
31 |
32 | [-1, 1, MP, []],
33 | [-1, 1, Conv, [160, 1, 1]],
34 | [-3, 1, Conv, [160, 1, 1]],
35 | [-1, 1, Conv, [160, 3, 2]],
36 | [[-1, -3], 1, Concat, [1]], # 18-P3/8
37 | [-1, 1, Conv, [128, 1, 1]],
38 | [-2, 1, Conv, [128, 1, 1]],
39 | [-1, 1, Conv, [128, 3, 1]],
40 | [-1, 1, Conv, [128, 3, 1]],
41 | [-1, 1, Conv, [128, 3, 1]],
42 | [-1, 1, Conv, [128, 3, 1]],
43 | [-1, 1, Conv, [128, 3, 1]],
44 | [-1, 1, Conv, [128, 3, 1]],
45 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
46 | [-1, 1, Conv, [640, 1, 1]], # 28
47 |
48 | [-1, 1, MP, []],
49 | [-1, 1, Conv, [320, 1, 1]],
50 | [-3, 1, Conv, [320, 1, 1]],
51 | [-1, 1, Conv, [320, 3, 2]],
52 | [[-1, -3], 1, Concat, [1]], # 33-P4/16
53 | [-1, 1, Conv, [256, 1, 1]],
54 | [-2, 1, Conv, [256, 1, 1]],
55 | [-1, 1, Conv, [256, 3, 1]],
56 | [-1, 1, Conv, [256, 3, 1]],
57 | [-1, 1, Conv, [256, 3, 1]],
58 | [-1, 1, Conv, [256, 3, 1]],
59 | [-1, 1, Conv, [256, 3, 1]],
60 | [-1, 1, Conv, [256, 3, 1]],
61 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
62 | [-1, 1, Conv, [1280, 1, 1]], # 43
63 |
64 | [-1, 1, MP, []],
65 | [-1, 1, Conv, [640, 1, 1]],
66 | [-3, 1, Conv, [640, 1, 1]],
67 | [-1, 1, Conv, [640, 3, 2]],
68 | [[-1, -3], 1, Concat, [1]], # 48-P5/32
69 | [-1, 1, Conv, [256, 1, 1]],
70 | [-2, 1, Conv, [256, 1, 1]],
71 | [-1, 1, Conv, [256, 3, 1]],
72 | [-1, 1, Conv, [256, 3, 1]],
73 | [-1, 1, Conv, [256, 3, 1]],
74 | [-1, 1, Conv, [256, 3, 1]],
75 | [-1, 1, Conv, [256, 3, 1]],
76 | [-1, 1, Conv, [256, 3, 1]],
77 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
78 | [-1, 1, Conv, [1280, 1, 1]], # 58
79 | ]
80 |
81 | # yolov7 head
82 | head:
83 | [[-1, 1, SPPCSPC, [640]], # 59
84 |
85 | [-1, 1, Conv, [320, 1, 1]],
86 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
87 | [43, 1, Conv, [320, 1, 1]], # route backbone P4
88 | [[-1, -2], 1, Concat, [1]],
89 |
90 | [-1, 1, Conv, [256, 1, 1]],
91 | [-2, 1, Conv, [256, 1, 1]],
92 | [-1, 1, Conv, [256, 3, 1]],
93 | [-1, 1, Conv, [256, 3, 1]],
94 | [-1, 1, Conv, [256, 3, 1]],
95 | [-1, 1, Conv, [256, 3, 1]],
96 | [-1, 1, Conv, [256, 3, 1]],
97 | [-1, 1, Conv, [256, 3, 1]],
98 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
99 | [-1, 1, Conv, [320, 1, 1]], # 73
100 |
101 | [-1, 1, Conv, [160, 1, 1]],
102 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
103 | [28, 1, Conv, [160, 1, 1]], # route backbone P3
104 | [[-1, -2], 1, Concat, [1]],
105 |
106 | [-1, 1, Conv, [128, 1, 1]],
107 | [-2, 1, Conv, [128, 1, 1]],
108 | [-1, 1, Conv, [128, 3, 1]],
109 | [-1, 1, Conv, [128, 3, 1]],
110 | [-1, 1, Conv, [128, 3, 1]],
111 | [-1, 1, Conv, [128, 3, 1]],
112 | [-1, 1, Conv, [128, 3, 1]],
113 | [-1, 1, Conv, [128, 3, 1]],
114 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
115 | [-1, 1, Conv, [160, 1, 1]], # 87
116 |
117 | [-1, 1, MP, []],
118 | [-1, 1, Conv, [160, 1, 1]],
119 | [-3, 1, Conv, [160, 1, 1]],
120 | [-1, 1, Conv, [160, 3, 2]],
121 | [[-1, -3, 73], 1, Concat, [1]],
122 |
123 | [-1, 1, Conv, [256, 1, 1]],
124 | [-2, 1, Conv, [256, 1, 1]],
125 | [-1, 1, Conv, [256, 3, 1]],
126 | [-1, 1, Conv, [256, 3, 1]],
127 | [-1, 1, Conv, [256, 3, 1]],
128 | [-1, 1, Conv, [256, 3, 1]],
129 | [-1, 1, Conv, [256, 3, 1]],
130 | [-1, 1, Conv, [256, 3, 1]],
131 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
132 | [-1, 1, Conv, [320, 1, 1]], # 102
133 |
134 | [-1, 1, MP, []],
135 | [-1, 1, Conv, [320, 1, 1]],
136 | [-3, 1, Conv, [320, 1, 1]],
137 | [-1, 1, Conv, [320, 3, 2]],
138 | [[-1, -3, 59], 1, Concat, [1]],
139 |
140 | [-1, 1, Conv, [512, 1, 1]],
141 | [-2, 1, Conv, [512, 1, 1]],
142 | [-1, 1, Conv, [512, 3, 1]],
143 | [-1, 1, Conv, [512, 3, 1]],
144 | [-1, 1, Conv, [512, 3, 1]],
145 | [-1, 1, Conv, [512, 3, 1]],
146 | [-1, 1, Conv, [512, 3, 1]],
147 | [-1, 1, Conv, [512, 3, 1]],
148 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
149 | [-1, 1, Conv, [640, 1, 1]], # 117
150 |
151 | [87, 1, Conv, [320, 3, 1]],
152 | [102, 1, Conv, [640, 3, 1]],
153 | [117, 1, Conv, [1280, 3, 1]],
154 |
155 | [[118,119,120], 1, IDetect, [nc, anchors]], # Detect(P3, P4, P5)
156 | ]
157 |
--------------------------------------------------------------------------------
/cfg/deploy/yolov7-w6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # yolov7-w6 backbone
14 | backbone:
15 | # [from, number, module, args]
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [64, 3, 1]], # 1-P1/2
18 |
19 | [-1, 1, Conv, [128, 3, 2]], # 2-P2/4
20 | [-1, 1, Conv, [64, 1, 1]],
21 | [-2, 1, Conv, [64, 1, 1]],
22 | [-1, 1, Conv, [64, 3, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [[-1, -3, -5, -6], 1, Concat, [1]],
27 | [-1, 1, Conv, [128, 1, 1]], # 10
28 |
29 | [-1, 1, Conv, [256, 3, 2]], # 11-P3/8
30 | [-1, 1, Conv, [128, 1, 1]],
31 | [-2, 1, Conv, [128, 1, 1]],
32 | [-1, 1, Conv, [128, 3, 1]],
33 | [-1, 1, Conv, [128, 3, 1]],
34 | [-1, 1, Conv, [128, 3, 1]],
35 | [-1, 1, Conv, [128, 3, 1]],
36 | [[-1, -3, -5, -6], 1, Concat, [1]],
37 | [-1, 1, Conv, [256, 1, 1]], # 19
38 |
39 | [-1, 1, Conv, [512, 3, 2]], # 20-P4/16
40 | [-1, 1, Conv, [256, 1, 1]],
41 | [-2, 1, Conv, [256, 1, 1]],
42 | [-1, 1, Conv, [256, 3, 1]],
43 | [-1, 1, Conv, [256, 3, 1]],
44 | [-1, 1, Conv, [256, 3, 1]],
45 | [-1, 1, Conv, [256, 3, 1]],
46 | [[-1, -3, -5, -6], 1, Concat, [1]],
47 | [-1, 1, Conv, [512, 1, 1]], # 28
48 |
49 | [-1, 1, Conv, [768, 3, 2]], # 29-P5/32
50 | [-1, 1, Conv, [384, 1, 1]],
51 | [-2, 1, Conv, [384, 1, 1]],
52 | [-1, 1, Conv, [384, 3, 1]],
53 | [-1, 1, Conv, [384, 3, 1]],
54 | [-1, 1, Conv, [384, 3, 1]],
55 | [-1, 1, Conv, [384, 3, 1]],
56 | [[-1, -3, -5, -6], 1, Concat, [1]],
57 | [-1, 1, Conv, [768, 1, 1]], # 37
58 |
59 | [-1, 1, Conv, [1024, 3, 2]], # 38-P6/64
60 | [-1, 1, Conv, [512, 1, 1]],
61 | [-2, 1, Conv, [512, 1, 1]],
62 | [-1, 1, Conv, [512, 3, 1]],
63 | [-1, 1, Conv, [512, 3, 1]],
64 | [-1, 1, Conv, [512, 3, 1]],
65 | [-1, 1, Conv, [512, 3, 1]],
66 | [[-1, -3, -5, -6], 1, Concat, [1]],
67 | [-1, 1, Conv, [1024, 1, 1]], # 46
68 | ]
69 |
70 | # yolov7-w6 head
71 | head:
72 | [[-1, 1, SPPCSPC, [512]], # 47
73 |
74 | [-1, 1, Conv, [384, 1, 1]],
75 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
76 | [37, 1, Conv, [384, 1, 1]], # route backbone P5
77 | [[-1, -2], 1, Concat, [1]],
78 |
79 | [-1, 1, Conv, [384, 1, 1]],
80 | [-2, 1, Conv, [384, 1, 1]],
81 | [-1, 1, Conv, [192, 3, 1]],
82 | [-1, 1, Conv, [192, 3, 1]],
83 | [-1, 1, Conv, [192, 3, 1]],
84 | [-1, 1, Conv, [192, 3, 1]],
85 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
86 | [-1, 1, Conv, [384, 1, 1]], # 59
87 |
88 | [-1, 1, Conv, [256, 1, 1]],
89 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
90 | [28, 1, Conv, [256, 1, 1]], # route backbone P4
91 | [[-1, -2], 1, Concat, [1]],
92 |
93 | [-1, 1, Conv, [256, 1, 1]],
94 | [-2, 1, Conv, [256, 1, 1]],
95 | [-1, 1, Conv, [128, 3, 1]],
96 | [-1, 1, Conv, [128, 3, 1]],
97 | [-1, 1, Conv, [128, 3, 1]],
98 | [-1, 1, Conv, [128, 3, 1]],
99 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
100 | [-1, 1, Conv, [256, 1, 1]], # 71
101 |
102 | [-1, 1, Conv, [128, 1, 1]],
103 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
104 | [19, 1, Conv, [128, 1, 1]], # route backbone P3
105 | [[-1, -2], 1, Concat, [1]],
106 |
107 | [-1, 1, Conv, [128, 1, 1]],
108 | [-2, 1, Conv, [128, 1, 1]],
109 | [-1, 1, Conv, [64, 3, 1]],
110 | [-1, 1, Conv, [64, 3, 1]],
111 | [-1, 1, Conv, [64, 3, 1]],
112 | [-1, 1, Conv, [64, 3, 1]],
113 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
114 | [-1, 1, Conv, [128, 1, 1]], # 83
115 |
116 | [-1, 1, Conv, [256, 3, 2]],
117 | [[-1, 71], 1, Concat, [1]], # cat
118 |
119 | [-1, 1, Conv, [256, 1, 1]],
120 | [-2, 1, Conv, [256, 1, 1]],
121 | [-1, 1, Conv, [128, 3, 1]],
122 | [-1, 1, Conv, [128, 3, 1]],
123 | [-1, 1, Conv, [128, 3, 1]],
124 | [-1, 1, Conv, [128, 3, 1]],
125 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
126 | [-1, 1, Conv, [256, 1, 1]], # 93
127 |
128 | [-1, 1, Conv, [384, 3, 2]],
129 | [[-1, 59], 1, Concat, [1]], # cat
130 |
131 | [-1, 1, Conv, [384, 1, 1]],
132 | [-2, 1, Conv, [384, 1, 1]],
133 | [-1, 1, Conv, [192, 3, 1]],
134 | [-1, 1, Conv, [192, 3, 1]],
135 | [-1, 1, Conv, [192, 3, 1]],
136 | [-1, 1, Conv, [192, 3, 1]],
137 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
138 | [-1, 1, Conv, [384, 1, 1]], # 103
139 |
140 | [-1, 1, Conv, [512, 3, 2]],
141 | [[-1, 47], 1, Concat, [1]], # cat
142 |
143 | [-1, 1, Conv, [512, 1, 1]],
144 | [-2, 1, Conv, [512, 1, 1]],
145 | [-1, 1, Conv, [256, 3, 1]],
146 | [-1, 1, Conv, [256, 3, 1]],
147 | [-1, 1, Conv, [256, 3, 1]],
148 | [-1, 1, Conv, [256, 3, 1]],
149 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
150 | [-1, 1, Conv, [512, 1, 1]], # 113
151 |
152 | [83, 1, Conv, [256, 3, 1]],
153 | [93, 1, Conv, [512, 3, 1]],
154 | [103, 1, Conv, [768, 3, 1]],
155 | [113, 1, Conv, [1024, 3, 1]],
156 |
157 | [[114,115,116,117], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5, P6)
158 | ]
159 |
--------------------------------------------------------------------------------
/utils/google_utils.py:
--------------------------------------------------------------------------------
1 | # Google utils: https://cloud.google.com/storage/docs/reference/libraries
2 |
3 | import os
4 | import platform
5 | import subprocess
6 | import time
7 | from pathlib import Path
8 |
9 | import requests
10 | import torch
11 |
12 |
13 | def gsutil_getsize(url=''):
14 | # gs://bucket/file size https://cloud.google.com/storage/docs/gsutil/commands/du
15 | s = subprocess.check_output(f'gsutil du {url}', shell=True).decode('utf-8')
16 | return eval(s.split(' ')[0]) if len(s) else 0 # bytes
17 |
18 |
19 | def attempt_download(file, repo='WongKinYiu/yolov7'):
20 | # Attempt file download if does not exist
21 | file = Path(str(file).strip().replace("'", '').lower())
22 |
23 | if not file.exists():
24 | try:
25 | response = requests.get(f'https://api.github.com/repos/{repo}/releases/latest').json() # github api
26 | assets = [x['name'] for x in response['assets']] # release assets
27 | tag = response['tag_name'] # i.e. 'v1.0'
28 | except: # fallback plan
29 | assets = ['yolov7.pt']
30 | # tag = subprocess.check_output('git tag', shell=True).decode(encoding='gbk').split()
31 | # print(tag)
32 | # tag = subprocess.check_output('git tag', shell=True).decode(encoding='gbk').split()[-1]
33 |
34 | name = file.name
35 | if name in assets:
36 | msg = f'{file} missing, try downloading from https://github.com/{repo}/releases/'
37 | redundant = False # second download option
38 | try: # GitHub
39 | url = f'https://github.com/{repo}/releases/download/{tag}/{name}'
40 | print(f'Downloading {url} to {file}...')
41 | torch.hub.download_url_to_file(url, file)
42 | assert file.exists() and file.stat().st_size > 1E6 # check
43 | except Exception as e: # GCP
44 | print(f'Download error: {e}')
45 | assert redundant, 'No secondary mirror'
46 | url = f'https://storage.googleapis.com/{repo}/ckpt/{name}'
47 | print(f'Downloading {url} to {file}...')
48 | os.system(f'curl -L {url} -o {file}') # torch.hub.download_url_to_file(url, weights)
49 | finally:
50 | if not file.exists() or file.stat().st_size < 1E6: # check
51 | file.unlink(missing_ok=True) # remove partial downloads
52 | print(f'ERROR: Download failure: {msg}')
53 | print('')
54 | return
55 |
56 |
57 | def gdrive_download(id='', file='tmp.zip'):
58 | # Downloads a file from Google Drive. from yolov7.utils.google_utils import *; gdrive_download()
59 | t = time.time()
60 | file = Path(file)
61 | cookie = Path('cookie') # gdrive cookie
62 | print(f'Downloading https://drive.google.com/uc?export=download&id={id} as {file}... ', end='')
63 | file.unlink(missing_ok=True) # remove existing file
64 | cookie.unlink(missing_ok=True) # remove existing cookie
65 |
66 | # Attempt file download
67 | out = "NUL" if platform.system() == "Windows" else "/dev/null"
68 | os.system(f'curl -c ./cookie -s -L "drive.google.com/uc?export=download&id={id}" > {out}')
69 | if os.path.exists('cookie'): # large file
70 | s = f'curl -Lb ./cookie "drive.google.com/uc?export=download&confirm={get_token()}&id={id}" -o {file}'
71 | else: # small file
72 | s = f'curl -s -L -o {file} "drive.google.com/uc?export=download&id={id}"'
73 | r = os.system(s) # execute, capture return
74 | cookie.unlink(missing_ok=True) # remove existing cookie
75 |
76 | # Error check
77 | if r != 0:
78 | file.unlink(missing_ok=True) # remove partial
79 | print('Download error ') # raise Exception('Download error')
80 | return r
81 |
82 | # Unzip if archive
83 | if file.suffix == '.zip':
84 | print('unzipping... ', end='')
85 | os.system(f'unzip -q {file}') # unzip
86 | file.unlink() # remove zip to free space
87 |
88 | print(f'Done ({time.time() - t:.1f}s)')
89 | return r
90 |
91 |
92 | def get_token(cookie="./cookie"):
93 | with open(cookie) as f:
94 | for line in f:
95 | if "download" in line:
96 | return line.split()[-1]
97 | return ""
98 |
99 | # def upload_blob(bucket_name, source_file_name, destination_blob_name):
100 | # # Uploads a file to a bucket
101 | # # https://cloud.google.com/storage/docs/uploading-objects#storage-upload-object-python
102 | #
103 | # storage_client = storage.Client()
104 | # bucket = storage_client.get_bucket(bucket_name)
105 | # blob = bucket.blob(destination_blob_name)
106 | #
107 | # blob.upload_from_filename(source_file_name)
108 | #
109 | # print('File {} uploaded to {}.'.format(
110 | # source_file_name,
111 | # destination_blob_name))
112 | #
113 | #
114 | # def download_blob(bucket_name, source_blob_name, destination_file_name):
115 | # # Uploads a blob from a bucket
116 | # storage_client = storage.Client()
117 | # bucket = storage_client.get_bucket(bucket_name)
118 | # blob = bucket.blob(source_blob_name)
119 | #
120 | # blob.download_to_filename(destination_file_name)
121 | #
122 | # print('Blob {} downloaded to {}.'.format(
123 | # source_blob_name,
124 | # destination_file_name))
125 |
--------------------------------------------------------------------------------
/cfg/training/yolov7-w6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # yolov7 backbone
14 | backbone:
15 | # [from, number, module, args]
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [64, 3, 1]], # 1-P1/2
18 |
19 | [-1, 1, Conv, [128, 3, 2]], # 2-P2/4
20 | [-1, 1, Conv, [64, 1, 1]],
21 | [-2, 1, Conv, [64, 1, 1]],
22 | [-1, 1, Conv, [64, 3, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [[-1, -3, -5, -6], 1, Concat, [1]],
27 | [-1, 1, Conv, [128, 1, 1]], # 10
28 |
29 | [-1, 1, Conv, [256, 3, 2]], # 11-P3/8
30 | [-1, 1, Conv, [128, 1, 1]],
31 | [-2, 1, Conv, [128, 1, 1]],
32 | [-1, 1, Conv, [128, 3, 1]],
33 | [-1, 1, Conv, [128, 3, 1]],
34 | [-1, 1, Conv, [128, 3, 1]],
35 | [-1, 1, Conv, [128, 3, 1]],
36 | [[-1, -3, -5, -6], 1, Concat, [1]],
37 | [-1, 1, Conv, [256, 1, 1]], # 19
38 |
39 | [-1, 1, Conv, [512, 3, 2]], # 20-P4/16
40 | [-1, 1, Conv, [256, 1, 1]],
41 | [-2, 1, Conv, [256, 1, 1]],
42 | [-1, 1, Conv, [256, 3, 1]],
43 | [-1, 1, Conv, [256, 3, 1]],
44 | [-1, 1, Conv, [256, 3, 1]],
45 | [-1, 1, Conv, [256, 3, 1]],
46 | [[-1, -3, -5, -6], 1, Concat, [1]],
47 | [-1, 1, Conv, [512, 1, 1]], # 28
48 |
49 | [-1, 1, Conv, [768, 3, 2]], # 29-P5/32
50 | [-1, 1, Conv, [384, 1, 1]],
51 | [-2, 1, Conv, [384, 1, 1]],
52 | [-1, 1, Conv, [384, 3, 1]],
53 | [-1, 1, Conv, [384, 3, 1]],
54 | [-1, 1, Conv, [384, 3, 1]],
55 | [-1, 1, Conv, [384, 3, 1]],
56 | [[-1, -3, -5, -6], 1, Concat, [1]],
57 | [-1, 1, Conv, [768, 1, 1]], # 37
58 |
59 | [-1, 1, Conv, [1024, 3, 2]], # 38-P6/64
60 | [-1, 1, Conv, [512, 1, 1]],
61 | [-2, 1, Conv, [512, 1, 1]],
62 | [-1, 1, Conv, [512, 3, 1]],
63 | [-1, 1, Conv, [512, 3, 1]],
64 | [-1, 1, Conv, [512, 3, 1]],
65 | [-1, 1, Conv, [512, 3, 1]],
66 | [[-1, -3, -5, -6], 1, Concat, [1]],
67 | [-1, 1, Conv, [1024, 1, 1]], # 46
68 | ]
69 |
70 | # yolov7 head
71 | head:
72 | [[-1, 1, SPPCSPC, [512]], # 47
73 |
74 | [-1, 1, Conv, [384, 1, 1]],
75 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
76 | [37, 1, Conv, [384, 1, 1]], # route backbone P5
77 | [[-1, -2], 1, Concat, [1]],
78 |
79 | [-1, 1, Conv, [384, 1, 1]],
80 | [-2, 1, Conv, [384, 1, 1]],
81 | [-1, 1, Conv, [192, 3, 1]],
82 | [-1, 1, Conv, [192, 3, 1]],
83 | [-1, 1, Conv, [192, 3, 1]],
84 | [-1, 1, Conv, [192, 3, 1]],
85 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
86 | [-1, 1, Conv, [384, 1, 1]], # 59
87 |
88 | [-1, 1, Conv, [256, 1, 1]],
89 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
90 | [28, 1, Conv, [256, 1, 1]], # route backbone P4
91 | [[-1, -2], 1, Concat, [1]],
92 |
93 | [-1, 1, Conv, [256, 1, 1]],
94 | [-2, 1, Conv, [256, 1, 1]],
95 | [-1, 1, Conv, [128, 3, 1]],
96 | [-1, 1, Conv, [128, 3, 1]],
97 | [-1, 1, Conv, [128, 3, 1]],
98 | [-1, 1, Conv, [128, 3, 1]],
99 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
100 | [-1, 1, Conv, [256, 1, 1]], # 71
101 |
102 | [-1, 1, Conv, [128, 1, 1]],
103 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
104 | [19, 1, Conv, [128, 1, 1]], # route backbone P3
105 | [[-1, -2], 1, Concat, [1]],
106 |
107 | [-1, 1, Conv, [128, 1, 1]],
108 | [-2, 1, Conv, [128, 1, 1]],
109 | [-1, 1, Conv, [64, 3, 1]],
110 | [-1, 1, Conv, [64, 3, 1]],
111 | [-1, 1, Conv, [64, 3, 1]],
112 | [-1, 1, Conv, [64, 3, 1]],
113 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
114 | [-1, 1, Conv, [128, 1, 1]], # 83
115 |
116 | [-1, 1, Conv, [256, 3, 2]],
117 | [[-1, 71], 1, Concat, [1]], # cat
118 |
119 | [-1, 1, Conv, [256, 1, 1]],
120 | [-2, 1, Conv, [256, 1, 1]],
121 | [-1, 1, Conv, [128, 3, 1]],
122 | [-1, 1, Conv, [128, 3, 1]],
123 | [-1, 1, Conv, [128, 3, 1]],
124 | [-1, 1, Conv, [128, 3, 1]],
125 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
126 | [-1, 1, Conv, [256, 1, 1]], # 93
127 |
128 | [-1, 1, Conv, [384, 3, 2]],
129 | [[-1, 59], 1, Concat, [1]], # cat
130 |
131 | [-1, 1, Conv, [384, 1, 1]],
132 | [-2, 1, Conv, [384, 1, 1]],
133 | [-1, 1, Conv, [192, 3, 1]],
134 | [-1, 1, Conv, [192, 3, 1]],
135 | [-1, 1, Conv, [192, 3, 1]],
136 | [-1, 1, Conv, [192, 3, 1]],
137 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
138 | [-1, 1, Conv, [384, 1, 1]], # 103
139 |
140 | [-1, 1, Conv, [512, 3, 2]],
141 | [[-1, 47], 1, Concat, [1]], # cat
142 |
143 | [-1, 1, Conv, [512, 1, 1]],
144 | [-2, 1, Conv, [512, 1, 1]],
145 | [-1, 1, Conv, [256, 3, 1]],
146 | [-1, 1, Conv, [256, 3, 1]],
147 | [-1, 1, Conv, [256, 3, 1]],
148 | [-1, 1, Conv, [256, 3, 1]],
149 | [[-1, -2, -3, -4, -5, -6], 1, Concat, [1]],
150 | [-1, 1, Conv, [512, 1, 1]], # 113
151 |
152 | [83, 1, Conv, [256, 3, 1]],
153 | [93, 1, Conv, [512, 3, 1]],
154 | [103, 1, Conv, [768, 3, 1]],
155 | [113, 1, Conv, [1024, 3, 1]],
156 |
157 | [83, 1, Conv, [320, 3, 1]],
158 | [71, 1, Conv, [640, 3, 1]],
159 | [59, 1, Conv, [960, 3, 1]],
160 | [47, 1, Conv, [1280, 3, 1]],
161 |
162 | [[114,115,116,117,118,119,120,121], 1, IAuxDetect, [nc, anchors]], # Detect(P3, P4, P5, P6)
163 | ]
164 |
--------------------------------------------------------------------------------
/voc_to_yolo.py:
--------------------------------------------------------------------------------
1 | import xml.etree.ElementTree as ET
2 | import pickle
3 | import os
4 | from os import listdir, getcwd
5 | from os.path import join
6 | import random
7 | from shutil import copyfile
8 |
9 | classes = ["dog","cat"]
10 | # classes=["ball"]
11 |
12 | TRAIN_RATIO = 50
13 |
14 |
15 | def clear_hidden_files(path):
16 | dir_list = os.listdir(path)
17 | for i in dir_list:
18 | abspath = os.path.join(os.path.abspath(path), i)
19 | if os.path.isfile(abspath):
20 | if i.startswith("._"):
21 | os.remove(abspath)
22 | else:
23 | clear_hidden_files(abspath)
24 |
25 |
26 | def convert(size, box):
27 | dw = 1. / size[0]
28 | dh = 1. / size[1]
29 | x = (box[0] + box[1]) / 2.0
30 | y = (box[2] + box[3]) / 2.0
31 | w = box[1] - box[0]
32 | h = box[3] - box[2]
33 | x = x * dw
34 | w = w * dw
35 | y = y * dh
36 | h = h * dh
37 | return (x, y, w, h)
38 |
39 |
40 | def convert_annotation(image_id):
41 | in_file = open('VOCdevkit/VOC2007/Annotations/%s.xml' % image_id)
42 | out_file = open('VOCdevkit/VOC2007/YOLOLabels/%s.txt' % image_id, 'w')
43 | tree = ET.parse(in_file)
44 | root = tree.getroot()
45 | size = root.find('size')
46 | w = int(size.find('width').text)
47 | h = int(size.find('height').text)
48 |
49 | for obj in root.iter('object'):
50 | # difficult = obj.find('difficult').text
51 | cls = obj.find('name').text
52 | if cls not in classes:
53 | continue
54 | cls_id = classes.index(cls)
55 | xmlbox = obj.find('bndbox')
56 | b = (float(xmlbox.find('xmin').text), float(xmlbox.find('xmax').text), float(xmlbox.find('ymin').text),
57 | float(xmlbox.find('ymax').text))
58 | bb = convert((w, h), b)
59 | out_file.write(str(cls_id) + " " + " ".join([str(a) for a in bb]) + '\n')
60 | in_file.close()
61 | out_file.close()
62 |
63 |
64 | wd = os.getcwd()
65 | wd = os.getcwd()
66 | data_base_dir = os.path.join(wd, "VOCdevkit/")
67 | if not os.path.isdir(data_base_dir):
68 | os.mkdir(data_base_dir)
69 | work_sapce_dir = os.path.join(data_base_dir, "VOC2007/")
70 | if not os.path.isdir(work_sapce_dir):
71 | os.mkdir(work_sapce_dir)
72 | annotation_dir = os.path.join(work_sapce_dir, "Annotations/")
73 | if not os.path.isdir(annotation_dir):
74 | os.mkdir(annotation_dir)
75 | clear_hidden_files(annotation_dir)
76 | image_dir = os.path.join(work_sapce_dir, "JPEGImages/")
77 | if not os.path.isdir(image_dir):
78 | os.mkdir(image_dir)
79 | clear_hidden_files(image_dir)
80 | yolo_labels_dir = os.path.join(work_sapce_dir, "YOLOLabels/")
81 | if not os.path.isdir(yolo_labels_dir):
82 | os.mkdir(yolo_labels_dir)
83 | clear_hidden_files(yolo_labels_dir)
84 | yolov5_images_dir = os.path.join(data_base_dir, "images/")
85 | if not os.path.isdir(yolov5_images_dir):
86 | os.mkdir(yolov5_images_dir)
87 | clear_hidden_files(yolov5_images_dir)
88 | yolov5_labels_dir = os.path.join(data_base_dir, "labels/")
89 | if not os.path.isdir(yolov5_labels_dir):
90 | os.mkdir(yolov5_labels_dir)
91 | clear_hidden_files(yolov5_labels_dir)
92 | yolov5_images_train_dir = os.path.join(yolov5_images_dir, "train/")
93 | if not os.path.isdir(yolov5_images_train_dir):
94 | os.mkdir(yolov5_images_train_dir)
95 | clear_hidden_files(yolov5_images_train_dir)
96 | yolov5_images_test_dir = os.path.join(yolov5_images_dir, "val/")
97 | if not os.path.isdir(yolov5_images_test_dir):
98 | os.mkdir(yolov5_images_test_dir)
99 | clear_hidden_files(yolov5_images_test_dir)
100 | yolov5_labels_train_dir = os.path.join(yolov5_labels_dir, "train/")
101 | if not os.path.isdir(yolov5_labels_train_dir):
102 | os.mkdir(yolov5_labels_train_dir)
103 | clear_hidden_files(yolov5_labels_train_dir)
104 | yolov5_labels_test_dir = os.path.join(yolov5_labels_dir, "val/")
105 | if not os.path.isdir(yolov5_labels_test_dir):
106 | os.mkdir(yolov5_labels_test_dir)
107 | clear_hidden_files(yolov5_labels_test_dir)
108 |
109 | train_file = open(os.path.join(wd, "yolov7_train.txt"), 'w')
110 | test_file = open(os.path.join(wd, "yolov7_val.txt"), 'w')
111 | train_file.close()
112 | test_file.close()
113 | train_file = open(os.path.join(wd, "yolov7_train.txt"), 'a')
114 | test_file = open(os.path.join(wd, "yolov7_val.txt"), 'a')
115 | list_imgs = os.listdir(image_dir) # list image files
116 | prob = random.randint(1, 100)
117 | print("Probability: %d" % prob)
118 | for i in range(0, len(list_imgs)):
119 | path = os.path.join(image_dir, list_imgs[i])
120 | if os.path.isfile(path):
121 | image_path = image_dir + list_imgs[i]
122 | voc_path = list_imgs[i]
123 | (nameWithoutExtention, extention) = os.path.splitext(os.path.basename(image_path))
124 | (voc_nameWithoutExtention, voc_extention) = os.path.splitext(os.path.basename(voc_path))
125 | annotation_name = nameWithoutExtention + '.xml'
126 | annotation_path = os.path.join(annotation_dir, annotation_name)
127 | label_name = nameWithoutExtention + '.txt'
128 | label_path = os.path.join(yolo_labels_dir, label_name)
129 | prob = random.randint(1, 100)
130 | print("Probability: %d" % prob)
131 | if (prob < TRAIN_RATIO): # train dataset
132 | if os.path.exists(annotation_path):
133 | train_file.write(image_path + '\n')
134 | convert_annotation(nameWithoutExtention) # convert label
135 | copyfile(image_path, yolov5_images_train_dir + voc_path)
136 | copyfile(label_path, yolov5_labels_train_dir + label_name)
137 | else: # test dataset
138 | if os.path.exists(annotation_path):
139 | test_file.write(image_path + '\n')
140 | convert_annotation(nameWithoutExtention) # convert label
141 | copyfile(image_path, yolov5_images_test_dir + voc_path)
142 | copyfile(label_path, yolov5_labels_test_dir + label_name)
143 | train_file.close()
144 | test_file.close()
--------------------------------------------------------------------------------
/cfg/deploy/yolov7-e6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # yolov7-e6 backbone
14 | backbone:
15 | # [from, number, module, args],
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [80, 3, 1]], # 1-P1/2
18 |
19 | [-1, 1, DownC, [160]], # 2-P2/4
20 | [-1, 1, Conv, [64, 1, 1]],
21 | [-2, 1, Conv, [64, 1, 1]],
22 | [-1, 1, Conv, [64, 3, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [-1, 1, Conv, [64, 3, 1]],
28 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
29 | [-1, 1, Conv, [160, 1, 1]], # 12
30 |
31 | [-1, 1, DownC, [320]], # 13-P3/8
32 | [-1, 1, Conv, [128, 1, 1]],
33 | [-2, 1, Conv, [128, 1, 1]],
34 | [-1, 1, Conv, [128, 3, 1]],
35 | [-1, 1, Conv, [128, 3, 1]],
36 | [-1, 1, Conv, [128, 3, 1]],
37 | [-1, 1, Conv, [128, 3, 1]],
38 | [-1, 1, Conv, [128, 3, 1]],
39 | [-1, 1, Conv, [128, 3, 1]],
40 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
41 | [-1, 1, Conv, [320, 1, 1]], # 23
42 |
43 | [-1, 1, DownC, [640]], # 24-P4/16
44 | [-1, 1, Conv, [256, 1, 1]],
45 | [-2, 1, Conv, [256, 1, 1]],
46 | [-1, 1, Conv, [256, 3, 1]],
47 | [-1, 1, Conv, [256, 3, 1]],
48 | [-1, 1, Conv, [256, 3, 1]],
49 | [-1, 1, Conv, [256, 3, 1]],
50 | [-1, 1, Conv, [256, 3, 1]],
51 | [-1, 1, Conv, [256, 3, 1]],
52 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
53 | [-1, 1, Conv, [640, 1, 1]], # 34
54 |
55 | [-1, 1, DownC, [960]], # 35-P5/32
56 | [-1, 1, Conv, [384, 1, 1]],
57 | [-2, 1, Conv, [384, 1, 1]],
58 | [-1, 1, Conv, [384, 3, 1]],
59 | [-1, 1, Conv, [384, 3, 1]],
60 | [-1, 1, Conv, [384, 3, 1]],
61 | [-1, 1, Conv, [384, 3, 1]],
62 | [-1, 1, Conv, [384, 3, 1]],
63 | [-1, 1, Conv, [384, 3, 1]],
64 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
65 | [-1, 1, Conv, [960, 1, 1]], # 45
66 |
67 | [-1, 1, DownC, [1280]], # 46-P6/64
68 | [-1, 1, Conv, [512, 1, 1]],
69 | [-2, 1, Conv, [512, 1, 1]],
70 | [-1, 1, Conv, [512, 3, 1]],
71 | [-1, 1, Conv, [512, 3, 1]],
72 | [-1, 1, Conv, [512, 3, 1]],
73 | [-1, 1, Conv, [512, 3, 1]],
74 | [-1, 1, Conv, [512, 3, 1]],
75 | [-1, 1, Conv, [512, 3, 1]],
76 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
77 | [-1, 1, Conv, [1280, 1, 1]], # 56
78 | ]
79 |
80 | # yolov7-e6 head
81 | head:
82 | [[-1, 1, SPPCSPC, [640]], # 57
83 |
84 | [-1, 1, Conv, [480, 1, 1]],
85 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
86 | [45, 1, Conv, [480, 1, 1]], # route backbone P5
87 | [[-1, -2], 1, Concat, [1]],
88 |
89 | [-1, 1, Conv, [384, 1, 1]],
90 | [-2, 1, Conv, [384, 1, 1]],
91 | [-1, 1, Conv, [192, 3, 1]],
92 | [-1, 1, Conv, [192, 3, 1]],
93 | [-1, 1, Conv, [192, 3, 1]],
94 | [-1, 1, Conv, [192, 3, 1]],
95 | [-1, 1, Conv, [192, 3, 1]],
96 | [-1, 1, Conv, [192, 3, 1]],
97 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
98 | [-1, 1, Conv, [480, 1, 1]], # 71
99 |
100 | [-1, 1, Conv, [320, 1, 1]],
101 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
102 | [34, 1, Conv, [320, 1, 1]], # route backbone P4
103 | [[-1, -2], 1, Concat, [1]],
104 |
105 | [-1, 1, Conv, [256, 1, 1]],
106 | [-2, 1, Conv, [256, 1, 1]],
107 | [-1, 1, Conv, [128, 3, 1]],
108 | [-1, 1, Conv, [128, 3, 1]],
109 | [-1, 1, Conv, [128, 3, 1]],
110 | [-1, 1, Conv, [128, 3, 1]],
111 | [-1, 1, Conv, [128, 3, 1]],
112 | [-1, 1, Conv, [128, 3, 1]],
113 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
114 | [-1, 1, Conv, [320, 1, 1]], # 85
115 |
116 | [-1, 1, Conv, [160, 1, 1]],
117 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
118 | [23, 1, Conv, [160, 1, 1]], # route backbone P3
119 | [[-1, -2], 1, Concat, [1]],
120 |
121 | [-1, 1, Conv, [128, 1, 1]],
122 | [-2, 1, Conv, [128, 1, 1]],
123 | [-1, 1, Conv, [64, 3, 1]],
124 | [-1, 1, Conv, [64, 3, 1]],
125 | [-1, 1, Conv, [64, 3, 1]],
126 | [-1, 1, Conv, [64, 3, 1]],
127 | [-1, 1, Conv, [64, 3, 1]],
128 | [-1, 1, Conv, [64, 3, 1]],
129 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
130 | [-1, 1, Conv, [160, 1, 1]], # 99
131 |
132 | [-1, 1, DownC, [320]],
133 | [[-1, 85], 1, Concat, [1]],
134 |
135 | [-1, 1, Conv, [256, 1, 1]],
136 | [-2, 1, Conv, [256, 1, 1]],
137 | [-1, 1, Conv, [128, 3, 1]],
138 | [-1, 1, Conv, [128, 3, 1]],
139 | [-1, 1, Conv, [128, 3, 1]],
140 | [-1, 1, Conv, [128, 3, 1]],
141 | [-1, 1, Conv, [128, 3, 1]],
142 | [-1, 1, Conv, [128, 3, 1]],
143 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
144 | [-1, 1, Conv, [320, 1, 1]], # 111
145 |
146 | [-1, 1, DownC, [480]],
147 | [[-1, 71], 1, Concat, [1]],
148 |
149 | [-1, 1, Conv, [384, 1, 1]],
150 | [-2, 1, Conv, [384, 1, 1]],
151 | [-1, 1, Conv, [192, 3, 1]],
152 | [-1, 1, Conv, [192, 3, 1]],
153 | [-1, 1, Conv, [192, 3, 1]],
154 | [-1, 1, Conv, [192, 3, 1]],
155 | [-1, 1, Conv, [192, 3, 1]],
156 | [-1, 1, Conv, [192, 3, 1]],
157 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
158 | [-1, 1, Conv, [480, 1, 1]], # 123
159 |
160 | [-1, 1, DownC, [640]],
161 | [[-1, 57], 1, Concat, [1]],
162 |
163 | [-1, 1, Conv, [512, 1, 1]],
164 | [-2, 1, Conv, [512, 1, 1]],
165 | [-1, 1, Conv, [256, 3, 1]],
166 | [-1, 1, Conv, [256, 3, 1]],
167 | [-1, 1, Conv, [256, 3, 1]],
168 | [-1, 1, Conv, [256, 3, 1]],
169 | [-1, 1, Conv, [256, 3, 1]],
170 | [-1, 1, Conv, [256, 3, 1]],
171 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
172 | [-1, 1, Conv, [640, 1, 1]], # 135
173 |
174 | [99, 1, Conv, [320, 3, 1]],
175 | [111, 1, Conv, [640, 3, 1]],
176 | [123, 1, Conv, [960, 3, 1]],
177 | [135, 1, Conv, [1280, 3, 1]],
178 |
179 | [[136,137,138,139], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5, P6)
180 | ]
181 |
--------------------------------------------------------------------------------
/utils/add_nms.py:
--------------------------------------------------------------------------------
1 | import numpy as np
2 | import onnx
3 | from onnx import shape_inference
4 | try:
5 | import onnx_graphsurgeon as gs
6 | except Exception as e:
7 | print('Import onnx_graphsurgeon failure: %s' % e)
8 |
9 | import logging
10 |
11 | LOGGER = logging.getLogger(__name__)
12 |
13 | class RegisterNMS(object):
14 | def __init__(
15 | self,
16 | onnx_model_path: str,
17 | precision: str = "fp32",
18 | ):
19 |
20 | self.graph = gs.import_onnx(onnx.load(onnx_model_path))
21 | assert self.graph
22 | LOGGER.info("ONNX graph created successfully")
23 | # Fold constants via ONNX-GS that PyTorch2ONNX may have missed
24 | self.graph.fold_constants()
25 | self.precision = precision
26 | self.batch_size = 1
27 | def infer(self):
28 | """
29 | Sanitize the graph by cleaning any unconnected nodes, do a topological resort,
30 | and fold constant inputs values. When possible, run shape inference on the
31 | ONNX graph to determine tensor shapes.
32 | """
33 | for _ in range(3):
34 | count_before = len(self.graph.nodes)
35 |
36 | self.graph.cleanup().toposort()
37 | try:
38 | for node in self.graph.nodes:
39 | for o in node.outputs:
40 | o.shape = None
41 | model = gs.export_onnx(self.graph)
42 | model = shape_inference.infer_shapes(model)
43 | self.graph = gs.import_onnx(model)
44 | except Exception as e:
45 | LOGGER.info(f"Shape inference could not be performed at this time:\n{e}")
46 | try:
47 | self.graph.fold_constants(fold_shapes=True)
48 | except TypeError as e:
49 | LOGGER.error(
50 | "This version of ONNX GraphSurgeon does not support folding shapes, "
51 | f"please upgrade your onnx_graphsurgeon module. Error:\n{e}"
52 | )
53 | raise
54 |
55 | count_after = len(self.graph.nodes)
56 | if count_before == count_after:
57 | # No new folding occurred in this iteration, so we can stop for now.
58 | break
59 |
60 | def save(self, output_path):
61 | """
62 | Save the ONNX model to the given location.
63 | Args:
64 | output_path: Path pointing to the location where to write
65 | out the updated ONNX model.
66 | """
67 | self.graph.cleanup().toposort()
68 | model = gs.export_onnx(self.graph)
69 | onnx.save(model, output_path)
70 | LOGGER.info(f"Saved ONNX model to {output_path}")
71 |
72 | def register_nms(
73 | self,
74 | *,
75 | score_thresh: float = 0.25,
76 | nms_thresh: float = 0.45,
77 | detections_per_img: int = 100,
78 | ):
79 | """
80 | Register the ``EfficientNMS_TRT`` plugin node.
81 | NMS expects these shapes for its input tensors:
82 | - box_net: [batch_size, number_boxes, 4]
83 | - class_net: [batch_size, number_boxes, number_labels]
84 | Args:
85 | score_thresh (float): The scalar threshold for score (low scoring boxes are removed).
86 | nms_thresh (float): The scalar threshold for IOU (new boxes that have high IOU
87 | overlap with previously selected boxes are removed).
88 | detections_per_img (int): Number of best detections to keep after NMS.
89 | """
90 |
91 | self.infer()
92 | # Find the concat node at the end of the network
93 | op_inputs = self.graph.outputs
94 | op = "EfficientNMS_TRT"
95 | attrs = {
96 | "plugin_version": "1",
97 | "background_class": -1, # no background class
98 | "max_output_boxes": detections_per_img,
99 | "score_threshold": score_thresh,
100 | "iou_threshold": nms_thresh,
101 | "score_activation": False,
102 | "box_coding": 0,
103 | }
104 |
105 | if self.precision == "fp32":
106 | dtype_output = np.float32
107 | elif self.precision == "fp16":
108 | dtype_output = np.float16
109 | else:
110 | raise NotImplementedError(f"Currently not supports precision: {self.precision}")
111 |
112 | # NMS Outputs
113 | output_num_detections = gs.Variable(
114 | name="num_detections",
115 | dtype=np.int32,
116 | shape=[self.batch_size, 1],
117 | ) # A scalar indicating the number of valid detections per batch image.
118 | output_boxes = gs.Variable(
119 | name="detection_boxes",
120 | dtype=dtype_output,
121 | shape=[self.batch_size, detections_per_img, 4],
122 | )
123 | output_scores = gs.Variable(
124 | name="detection_scores",
125 | dtype=dtype_output,
126 | shape=[self.batch_size, detections_per_img],
127 | )
128 | output_labels = gs.Variable(
129 | name="detection_classes",
130 | dtype=np.int32,
131 | shape=[self.batch_size, detections_per_img],
132 | )
133 |
134 | op_outputs = [output_num_detections, output_boxes, output_scores, output_labels]
135 |
136 | # Create the NMS Plugin node with the selected inputs. The outputs of the node will also
137 | # become the final outputs of the graph.
138 | self.graph.layer(op=op, name="batched_nms", inputs=op_inputs, outputs=op_outputs, attrs=attrs)
139 | LOGGER.info(f"Created NMS plugin '{op}' with attributes: {attrs}")
140 |
141 | self.graph.outputs = op_outputs
142 |
143 | self.infer()
144 |
145 | def save(self, output_path):
146 | """
147 | Save the ONNX model to the given location.
148 | Args:
149 | output_path: Path pointing to the location where to write
150 | out the updated ONNX model.
151 | """
152 | self.graph.cleanup().toposort()
153 | model = gs.export_onnx(self.graph)
154 | onnx.save(model, output_path)
155 | LOGGER.info(f"Saved ONNX model to {output_path}")
156 |
--------------------------------------------------------------------------------
/cfg/training/yolov7-e6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # yolov7 backbone
14 | backbone:
15 | # [from, number, module, args],
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [80, 3, 1]], # 1-P1/2
18 |
19 | [-1, 1, DownC, [160]], # 2-P2/4
20 | [-1, 1, Conv, [64, 1, 1]],
21 | [-2, 1, Conv, [64, 1, 1]],
22 | [-1, 1, Conv, [64, 3, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [-1, 1, Conv, [64, 3, 1]],
28 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
29 | [-1, 1, Conv, [160, 1, 1]], # 12
30 |
31 | [-1, 1, DownC, [320]], # 13-P3/8
32 | [-1, 1, Conv, [128, 1, 1]],
33 | [-2, 1, Conv, [128, 1, 1]],
34 | [-1, 1, Conv, [128, 3, 1]],
35 | [-1, 1, Conv, [128, 3, 1]],
36 | [-1, 1, Conv, [128, 3, 1]],
37 | [-1, 1, Conv, [128, 3, 1]],
38 | [-1, 1, Conv, [128, 3, 1]],
39 | [-1, 1, Conv, [128, 3, 1]],
40 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
41 | [-1, 1, Conv, [320, 1, 1]], # 23
42 |
43 | [-1, 1, DownC, [640]], # 24-P4/16
44 | [-1, 1, Conv, [256, 1, 1]],
45 | [-2, 1, Conv, [256, 1, 1]],
46 | [-1, 1, Conv, [256, 3, 1]],
47 | [-1, 1, Conv, [256, 3, 1]],
48 | [-1, 1, Conv, [256, 3, 1]],
49 | [-1, 1, Conv, [256, 3, 1]],
50 | [-1, 1, Conv, [256, 3, 1]],
51 | [-1, 1, Conv, [256, 3, 1]],
52 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
53 | [-1, 1, Conv, [640, 1, 1]], # 34
54 |
55 | [-1, 1, DownC, [960]], # 35-P5/32
56 | [-1, 1, Conv, [384, 1, 1]],
57 | [-2, 1, Conv, [384, 1, 1]],
58 | [-1, 1, Conv, [384, 3, 1]],
59 | [-1, 1, Conv, [384, 3, 1]],
60 | [-1, 1, Conv, [384, 3, 1]],
61 | [-1, 1, Conv, [384, 3, 1]],
62 | [-1, 1, Conv, [384, 3, 1]],
63 | [-1, 1, Conv, [384, 3, 1]],
64 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
65 | [-1, 1, Conv, [960, 1, 1]], # 45
66 |
67 | [-1, 1, DownC, [1280]], # 46-P6/64
68 | [-1, 1, Conv, [512, 1, 1]],
69 | [-2, 1, Conv, [512, 1, 1]],
70 | [-1, 1, Conv, [512, 3, 1]],
71 | [-1, 1, Conv, [512, 3, 1]],
72 | [-1, 1, Conv, [512, 3, 1]],
73 | [-1, 1, Conv, [512, 3, 1]],
74 | [-1, 1, Conv, [512, 3, 1]],
75 | [-1, 1, Conv, [512, 3, 1]],
76 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
77 | [-1, 1, Conv, [1280, 1, 1]], # 56
78 | ]
79 |
80 | # yolov7 head
81 | head:
82 | [[-1, 1, SPPCSPC, [640]], # 57
83 |
84 | [-1, 1, Conv, [480, 1, 1]],
85 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
86 | [45, 1, Conv, [480, 1, 1]], # route backbone P5
87 | [[-1, -2], 1, Concat, [1]],
88 |
89 | [-1, 1, Conv, [384, 1, 1]],
90 | [-2, 1, Conv, [384, 1, 1]],
91 | [-1, 1, Conv, [192, 3, 1]],
92 | [-1, 1, Conv, [192, 3, 1]],
93 | [-1, 1, Conv, [192, 3, 1]],
94 | [-1, 1, Conv, [192, 3, 1]],
95 | [-1, 1, Conv, [192, 3, 1]],
96 | [-1, 1, Conv, [192, 3, 1]],
97 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
98 | [-1, 1, Conv, [480, 1, 1]], # 71
99 |
100 | [-1, 1, Conv, [320, 1, 1]],
101 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
102 | [34, 1, Conv, [320, 1, 1]], # route backbone P4
103 | [[-1, -2], 1, Concat, [1]],
104 |
105 | [-1, 1, Conv, [256, 1, 1]],
106 | [-2, 1, Conv, [256, 1, 1]],
107 | [-1, 1, Conv, [128, 3, 1]],
108 | [-1, 1, Conv, [128, 3, 1]],
109 | [-1, 1, Conv, [128, 3, 1]],
110 | [-1, 1, Conv, [128, 3, 1]],
111 | [-1, 1, Conv, [128, 3, 1]],
112 | [-1, 1, Conv, [128, 3, 1]],
113 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
114 | [-1, 1, Conv, [320, 1, 1]], # 85
115 |
116 | [-1, 1, Conv, [160, 1, 1]],
117 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
118 | [23, 1, Conv, [160, 1, 1]], # route backbone P3
119 | [[-1, -2], 1, Concat, [1]],
120 |
121 | [-1, 1, Conv, [128, 1, 1]],
122 | [-2, 1, Conv, [128, 1, 1]],
123 | [-1, 1, Conv, [64, 3, 1]],
124 | [-1, 1, Conv, [64, 3, 1]],
125 | [-1, 1, Conv, [64, 3, 1]],
126 | [-1, 1, Conv, [64, 3, 1]],
127 | [-1, 1, Conv, [64, 3, 1]],
128 | [-1, 1, Conv, [64, 3, 1]],
129 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
130 | [-1, 1, Conv, [160, 1, 1]], # 99
131 |
132 | [-1, 1, DownC, [320]],
133 | [[-1, 85], 1, Concat, [1]],
134 |
135 | [-1, 1, Conv, [256, 1, 1]],
136 | [-2, 1, Conv, [256, 1, 1]],
137 | [-1, 1, Conv, [128, 3, 1]],
138 | [-1, 1, Conv, [128, 3, 1]],
139 | [-1, 1, Conv, [128, 3, 1]],
140 | [-1, 1, Conv, [128, 3, 1]],
141 | [-1, 1, Conv, [128, 3, 1]],
142 | [-1, 1, Conv, [128, 3, 1]],
143 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
144 | [-1, 1, Conv, [320, 1, 1]], # 111
145 |
146 | [-1, 1, DownC, [480]],
147 | [[-1, 71], 1, Concat, [1]],
148 |
149 | [-1, 1, Conv, [384, 1, 1]],
150 | [-2, 1, Conv, [384, 1, 1]],
151 | [-1, 1, Conv, [192, 3, 1]],
152 | [-1, 1, Conv, [192, 3, 1]],
153 | [-1, 1, Conv, [192, 3, 1]],
154 | [-1, 1, Conv, [192, 3, 1]],
155 | [-1, 1, Conv, [192, 3, 1]],
156 | [-1, 1, Conv, [192, 3, 1]],
157 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
158 | [-1, 1, Conv, [480, 1, 1]], # 123
159 |
160 | [-1, 1, DownC, [640]],
161 | [[-1, 57], 1, Concat, [1]],
162 |
163 | [-1, 1, Conv, [512, 1, 1]],
164 | [-2, 1, Conv, [512, 1, 1]],
165 | [-1, 1, Conv, [256, 3, 1]],
166 | [-1, 1, Conv, [256, 3, 1]],
167 | [-1, 1, Conv, [256, 3, 1]],
168 | [-1, 1, Conv, [256, 3, 1]],
169 | [-1, 1, Conv, [256, 3, 1]],
170 | [-1, 1, Conv, [256, 3, 1]],
171 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
172 | [-1, 1, Conv, [640, 1, 1]], # 135
173 |
174 | [99, 1, Conv, [320, 3, 1]],
175 | [111, 1, Conv, [640, 3, 1]],
176 | [123, 1, Conv, [960, 3, 1]],
177 | [135, 1, Conv, [1280, 3, 1]],
178 |
179 | [99, 1, Conv, [320, 3, 1]],
180 | [85, 1, Conv, [640, 3, 1]],
181 | [71, 1, Conv, [960, 3, 1]],
182 | [57, 1, Conv, [1280, 3, 1]],
183 |
184 | [[136,137,138,139,140,141,142,143], 1, IAuxDetect, [nc, anchors]], # Detect(P3, P4, P5, P6)
185 | ]
186 |
--------------------------------------------------------------------------------
/cfg/deploy/yolov7-d6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # yolov7-d6 backbone
14 | backbone:
15 | # [from, number, module, args],
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [96, 3, 1]], # 1-P1/2
18 |
19 | [-1, 1, DownC, [192]], # 2-P2/4
20 | [-1, 1, Conv, [64, 1, 1]],
21 | [-2, 1, Conv, [64, 1, 1]],
22 | [-1, 1, Conv, [64, 3, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [-1, 1, Conv, [64, 3, 1]],
28 | [-1, 1, Conv, [64, 3, 1]],
29 | [-1, 1, Conv, [64, 3, 1]],
30 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
31 | [-1, 1, Conv, [192, 1, 1]], # 14
32 |
33 | [-1, 1, DownC, [384]], # 15-P3/8
34 | [-1, 1, Conv, [128, 1, 1]],
35 | [-2, 1, Conv, [128, 1, 1]],
36 | [-1, 1, Conv, [128, 3, 1]],
37 | [-1, 1, Conv, [128, 3, 1]],
38 | [-1, 1, Conv, [128, 3, 1]],
39 | [-1, 1, Conv, [128, 3, 1]],
40 | [-1, 1, Conv, [128, 3, 1]],
41 | [-1, 1, Conv, [128, 3, 1]],
42 | [-1, 1, Conv, [128, 3, 1]],
43 | [-1, 1, Conv, [128, 3, 1]],
44 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
45 | [-1, 1, Conv, [384, 1, 1]], # 27
46 |
47 | [-1, 1, DownC, [768]], # 28-P4/16
48 | [-1, 1, Conv, [256, 1, 1]],
49 | [-2, 1, Conv, [256, 1, 1]],
50 | [-1, 1, Conv, [256, 3, 1]],
51 | [-1, 1, Conv, [256, 3, 1]],
52 | [-1, 1, Conv, [256, 3, 1]],
53 | [-1, 1, Conv, [256, 3, 1]],
54 | [-1, 1, Conv, [256, 3, 1]],
55 | [-1, 1, Conv, [256, 3, 1]],
56 | [-1, 1, Conv, [256, 3, 1]],
57 | [-1, 1, Conv, [256, 3, 1]],
58 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
59 | [-1, 1, Conv, [768, 1, 1]], # 40
60 |
61 | [-1, 1, DownC, [1152]], # 41-P5/32
62 | [-1, 1, Conv, [384, 1, 1]],
63 | [-2, 1, Conv, [384, 1, 1]],
64 | [-1, 1, Conv, [384, 3, 1]],
65 | [-1, 1, Conv, [384, 3, 1]],
66 | [-1, 1, Conv, [384, 3, 1]],
67 | [-1, 1, Conv, [384, 3, 1]],
68 | [-1, 1, Conv, [384, 3, 1]],
69 | [-1, 1, Conv, [384, 3, 1]],
70 | [-1, 1, Conv, [384, 3, 1]],
71 | [-1, 1, Conv, [384, 3, 1]],
72 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
73 | [-1, 1, Conv, [1152, 1, 1]], # 53
74 |
75 | [-1, 1, DownC, [1536]], # 54-P6/64
76 | [-1, 1, Conv, [512, 1, 1]],
77 | [-2, 1, Conv, [512, 1, 1]],
78 | [-1, 1, Conv, [512, 3, 1]],
79 | [-1, 1, Conv, [512, 3, 1]],
80 | [-1, 1, Conv, [512, 3, 1]],
81 | [-1, 1, Conv, [512, 3, 1]],
82 | [-1, 1, Conv, [512, 3, 1]],
83 | [-1, 1, Conv, [512, 3, 1]],
84 | [-1, 1, Conv, [512, 3, 1]],
85 | [-1, 1, Conv, [512, 3, 1]],
86 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
87 | [-1, 1, Conv, [1536, 1, 1]], # 66
88 | ]
89 |
90 | # yolov7-d6 head
91 | head:
92 | [[-1, 1, SPPCSPC, [768]], # 67
93 |
94 | [-1, 1, Conv, [576, 1, 1]],
95 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
96 | [53, 1, Conv, [576, 1, 1]], # route backbone P5
97 | [[-1, -2], 1, Concat, [1]],
98 |
99 | [-1, 1, Conv, [384, 1, 1]],
100 | [-2, 1, Conv, [384, 1, 1]],
101 | [-1, 1, Conv, [192, 3, 1]],
102 | [-1, 1, Conv, [192, 3, 1]],
103 | [-1, 1, Conv, [192, 3, 1]],
104 | [-1, 1, Conv, [192, 3, 1]],
105 | [-1, 1, Conv, [192, 3, 1]],
106 | [-1, 1, Conv, [192, 3, 1]],
107 | [-1, 1, Conv, [192, 3, 1]],
108 | [-1, 1, Conv, [192, 3, 1]],
109 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
110 | [-1, 1, Conv, [576, 1, 1]], # 83
111 |
112 | [-1, 1, Conv, [384, 1, 1]],
113 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
114 | [40, 1, Conv, [384, 1, 1]], # route backbone P4
115 | [[-1, -2], 1, Concat, [1]],
116 |
117 | [-1, 1, Conv, [256, 1, 1]],
118 | [-2, 1, Conv, [256, 1, 1]],
119 | [-1, 1, Conv, [128, 3, 1]],
120 | [-1, 1, Conv, [128, 3, 1]],
121 | [-1, 1, Conv, [128, 3, 1]],
122 | [-1, 1, Conv, [128, 3, 1]],
123 | [-1, 1, Conv, [128, 3, 1]],
124 | [-1, 1, Conv, [128, 3, 1]],
125 | [-1, 1, Conv, [128, 3, 1]],
126 | [-1, 1, Conv, [128, 3, 1]],
127 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
128 | [-1, 1, Conv, [384, 1, 1]], # 99
129 |
130 | [-1, 1, Conv, [192, 1, 1]],
131 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
132 | [27, 1, Conv, [192, 1, 1]], # route backbone P3
133 | [[-1, -2], 1, Concat, [1]],
134 |
135 | [-1, 1, Conv, [128, 1, 1]],
136 | [-2, 1, Conv, [128, 1, 1]],
137 | [-1, 1, Conv, [64, 3, 1]],
138 | [-1, 1, Conv, [64, 3, 1]],
139 | [-1, 1, Conv, [64, 3, 1]],
140 | [-1, 1, Conv, [64, 3, 1]],
141 | [-1, 1, Conv, [64, 3, 1]],
142 | [-1, 1, Conv, [64, 3, 1]],
143 | [-1, 1, Conv, [64, 3, 1]],
144 | [-1, 1, Conv, [64, 3, 1]],
145 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
146 | [-1, 1, Conv, [192, 1, 1]], # 115
147 |
148 | [-1, 1, DownC, [384]],
149 | [[-1, 99], 1, Concat, [1]],
150 |
151 | [-1, 1, Conv, [256, 1, 1]],
152 | [-2, 1, Conv, [256, 1, 1]],
153 | [-1, 1, Conv, [128, 3, 1]],
154 | [-1, 1, Conv, [128, 3, 1]],
155 | [-1, 1, Conv, [128, 3, 1]],
156 | [-1, 1, Conv, [128, 3, 1]],
157 | [-1, 1, Conv, [128, 3, 1]],
158 | [-1, 1, Conv, [128, 3, 1]],
159 | [-1, 1, Conv, [128, 3, 1]],
160 | [-1, 1, Conv, [128, 3, 1]],
161 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
162 | [-1, 1, Conv, [384, 1, 1]], # 129
163 |
164 | [-1, 1, DownC, [576]],
165 | [[-1, 83], 1, Concat, [1]],
166 |
167 | [-1, 1, Conv, [384, 1, 1]],
168 | [-2, 1, Conv, [384, 1, 1]],
169 | [-1, 1, Conv, [192, 3, 1]],
170 | [-1, 1, Conv, [192, 3, 1]],
171 | [-1, 1, Conv, [192, 3, 1]],
172 | [-1, 1, Conv, [192, 3, 1]],
173 | [-1, 1, Conv, [192, 3, 1]],
174 | [-1, 1, Conv, [192, 3, 1]],
175 | [-1, 1, Conv, [192, 3, 1]],
176 | [-1, 1, Conv, [192, 3, 1]],
177 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
178 | [-1, 1, Conv, [576, 1, 1]], # 143
179 |
180 | [-1, 1, DownC, [768]],
181 | [[-1, 67], 1, Concat, [1]],
182 |
183 | [-1, 1, Conv, [512, 1, 1]],
184 | [-2, 1, Conv, [512, 1, 1]],
185 | [-1, 1, Conv, [256, 3, 1]],
186 | [-1, 1, Conv, [256, 3, 1]],
187 | [-1, 1, Conv, [256, 3, 1]],
188 | [-1, 1, Conv, [256, 3, 1]],
189 | [-1, 1, Conv, [256, 3, 1]],
190 | [-1, 1, Conv, [256, 3, 1]],
191 | [-1, 1, Conv, [256, 3, 1]],
192 | [-1, 1, Conv, [256, 3, 1]],
193 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
194 | [-1, 1, Conv, [768, 1, 1]], # 157
195 |
196 | [115, 1, Conv, [384, 3, 1]],
197 | [129, 1, Conv, [768, 3, 1]],
198 | [143, 1, Conv, [1152, 3, 1]],
199 | [157, 1, Conv, [1536, 3, 1]],
200 |
201 | [[158,159,160,161], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5, P6)
202 | ]
203 |
--------------------------------------------------------------------------------
/cfg/training/yolov7-d6.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # yolov7 backbone
14 | backbone:
15 | # [from, number, module, args],
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [96, 3, 1]], # 1-P1/2
18 |
19 | [-1, 1, DownC, [192]], # 2-P2/4
20 | [-1, 1, Conv, [64, 1, 1]],
21 | [-2, 1, Conv, [64, 1, 1]],
22 | [-1, 1, Conv, [64, 3, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [-1, 1, Conv, [64, 3, 1]],
28 | [-1, 1, Conv, [64, 3, 1]],
29 | [-1, 1, Conv, [64, 3, 1]],
30 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
31 | [-1, 1, Conv, [192, 1, 1]], # 14
32 |
33 | [-1, 1, DownC, [384]], # 15-P3/8
34 | [-1, 1, Conv, [128, 1, 1]],
35 | [-2, 1, Conv, [128, 1, 1]],
36 | [-1, 1, Conv, [128, 3, 1]],
37 | [-1, 1, Conv, [128, 3, 1]],
38 | [-1, 1, Conv, [128, 3, 1]],
39 | [-1, 1, Conv, [128, 3, 1]],
40 | [-1, 1, Conv, [128, 3, 1]],
41 | [-1, 1, Conv, [128, 3, 1]],
42 | [-1, 1, Conv, [128, 3, 1]],
43 | [-1, 1, Conv, [128, 3, 1]],
44 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
45 | [-1, 1, Conv, [384, 1, 1]], # 27
46 |
47 | [-1, 1, DownC, [768]], # 28-P4/16
48 | [-1, 1, Conv, [256, 1, 1]],
49 | [-2, 1, Conv, [256, 1, 1]],
50 | [-1, 1, Conv, [256, 3, 1]],
51 | [-1, 1, Conv, [256, 3, 1]],
52 | [-1, 1, Conv, [256, 3, 1]],
53 | [-1, 1, Conv, [256, 3, 1]],
54 | [-1, 1, Conv, [256, 3, 1]],
55 | [-1, 1, Conv, [256, 3, 1]],
56 | [-1, 1, Conv, [256, 3, 1]],
57 | [-1, 1, Conv, [256, 3, 1]],
58 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
59 | [-1, 1, Conv, [768, 1, 1]], # 40
60 |
61 | [-1, 1, DownC, [1152]], # 41-P5/32
62 | [-1, 1, Conv, [384, 1, 1]],
63 | [-2, 1, Conv, [384, 1, 1]],
64 | [-1, 1, Conv, [384, 3, 1]],
65 | [-1, 1, Conv, [384, 3, 1]],
66 | [-1, 1, Conv, [384, 3, 1]],
67 | [-1, 1, Conv, [384, 3, 1]],
68 | [-1, 1, Conv, [384, 3, 1]],
69 | [-1, 1, Conv, [384, 3, 1]],
70 | [-1, 1, Conv, [384, 3, 1]],
71 | [-1, 1, Conv, [384, 3, 1]],
72 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
73 | [-1, 1, Conv, [1152, 1, 1]], # 53
74 |
75 | [-1, 1, DownC, [1536]], # 54-P6/64
76 | [-1, 1, Conv, [512, 1, 1]],
77 | [-2, 1, Conv, [512, 1, 1]],
78 | [-1, 1, Conv, [512, 3, 1]],
79 | [-1, 1, Conv, [512, 3, 1]],
80 | [-1, 1, Conv, [512, 3, 1]],
81 | [-1, 1, Conv, [512, 3, 1]],
82 | [-1, 1, Conv, [512, 3, 1]],
83 | [-1, 1, Conv, [512, 3, 1]],
84 | [-1, 1, Conv, [512, 3, 1]],
85 | [-1, 1, Conv, [512, 3, 1]],
86 | [[-1, -3, -5, -7, -9, -10], 1, Concat, [1]],
87 | [-1, 1, Conv, [1536, 1, 1]], # 66
88 | ]
89 |
90 | # yolov7 head
91 | head:
92 | [[-1, 1, SPPCSPC, [768]], # 67
93 |
94 | [-1, 1, Conv, [576, 1, 1]],
95 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
96 | [53, 1, Conv, [576, 1, 1]], # route backbone P5
97 | [[-1, -2], 1, Concat, [1]],
98 |
99 | [-1, 1, Conv, [384, 1, 1]],
100 | [-2, 1, Conv, [384, 1, 1]],
101 | [-1, 1, Conv, [192, 3, 1]],
102 | [-1, 1, Conv, [192, 3, 1]],
103 | [-1, 1, Conv, [192, 3, 1]],
104 | [-1, 1, Conv, [192, 3, 1]],
105 | [-1, 1, Conv, [192, 3, 1]],
106 | [-1, 1, Conv, [192, 3, 1]],
107 | [-1, 1, Conv, [192, 3, 1]],
108 | [-1, 1, Conv, [192, 3, 1]],
109 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
110 | [-1, 1, Conv, [576, 1, 1]], # 83
111 |
112 | [-1, 1, Conv, [384, 1, 1]],
113 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
114 | [40, 1, Conv, [384, 1, 1]], # route backbone P4
115 | [[-1, -2], 1, Concat, [1]],
116 |
117 | [-1, 1, Conv, [256, 1, 1]],
118 | [-2, 1, Conv, [256, 1, 1]],
119 | [-1, 1, Conv, [128, 3, 1]],
120 | [-1, 1, Conv, [128, 3, 1]],
121 | [-1, 1, Conv, [128, 3, 1]],
122 | [-1, 1, Conv, [128, 3, 1]],
123 | [-1, 1, Conv, [128, 3, 1]],
124 | [-1, 1, Conv, [128, 3, 1]],
125 | [-1, 1, Conv, [128, 3, 1]],
126 | [-1, 1, Conv, [128, 3, 1]],
127 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
128 | [-1, 1, Conv, [384, 1, 1]], # 99
129 |
130 | [-1, 1, Conv, [192, 1, 1]],
131 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
132 | [27, 1, Conv, [192, 1, 1]], # route backbone P3
133 | [[-1, -2], 1, Concat, [1]],
134 |
135 | [-1, 1, Conv, [128, 1, 1]],
136 | [-2, 1, Conv, [128, 1, 1]],
137 | [-1, 1, Conv, [64, 3, 1]],
138 | [-1, 1, Conv, [64, 3, 1]],
139 | [-1, 1, Conv, [64, 3, 1]],
140 | [-1, 1, Conv, [64, 3, 1]],
141 | [-1, 1, Conv, [64, 3, 1]],
142 | [-1, 1, Conv, [64, 3, 1]],
143 | [-1, 1, Conv, [64, 3, 1]],
144 | [-1, 1, Conv, [64, 3, 1]],
145 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
146 | [-1, 1, Conv, [192, 1, 1]], # 115
147 |
148 | [-1, 1, DownC, [384]],
149 | [[-1, 99], 1, Concat, [1]],
150 |
151 | [-1, 1, Conv, [256, 1, 1]],
152 | [-2, 1, Conv, [256, 1, 1]],
153 | [-1, 1, Conv, [128, 3, 1]],
154 | [-1, 1, Conv, [128, 3, 1]],
155 | [-1, 1, Conv, [128, 3, 1]],
156 | [-1, 1, Conv, [128, 3, 1]],
157 | [-1, 1, Conv, [128, 3, 1]],
158 | [-1, 1, Conv, [128, 3, 1]],
159 | [-1, 1, Conv, [128, 3, 1]],
160 | [-1, 1, Conv, [128, 3, 1]],
161 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
162 | [-1, 1, Conv, [384, 1, 1]], # 129
163 |
164 | [-1, 1, DownC, [576]],
165 | [[-1, 83], 1, Concat, [1]],
166 |
167 | [-1, 1, Conv, [384, 1, 1]],
168 | [-2, 1, Conv, [384, 1, 1]],
169 | [-1, 1, Conv, [192, 3, 1]],
170 | [-1, 1, Conv, [192, 3, 1]],
171 | [-1, 1, Conv, [192, 3, 1]],
172 | [-1, 1, Conv, [192, 3, 1]],
173 | [-1, 1, Conv, [192, 3, 1]],
174 | [-1, 1, Conv, [192, 3, 1]],
175 | [-1, 1, Conv, [192, 3, 1]],
176 | [-1, 1, Conv, [192, 3, 1]],
177 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
178 | [-1, 1, Conv, [576, 1, 1]], # 143
179 |
180 | [-1, 1, DownC, [768]],
181 | [[-1, 67], 1, Concat, [1]],
182 |
183 | [-1, 1, Conv, [512, 1, 1]],
184 | [-2, 1, Conv, [512, 1, 1]],
185 | [-1, 1, Conv, [256, 3, 1]],
186 | [-1, 1, Conv, [256, 3, 1]],
187 | [-1, 1, Conv, [256, 3, 1]],
188 | [-1, 1, Conv, [256, 3, 1]],
189 | [-1, 1, Conv, [256, 3, 1]],
190 | [-1, 1, Conv, [256, 3, 1]],
191 | [-1, 1, Conv, [256, 3, 1]],
192 | [-1, 1, Conv, [256, 3, 1]],
193 | [[-1, -2, -3, -4, -5, -6, -7, -8, -9, -10], 1, Concat, [1]],
194 | [-1, 1, Conv, [768, 1, 1]], # 157
195 |
196 | [115, 1, Conv, [384, 3, 1]],
197 | [129, 1, Conv, [768, 3, 1]],
198 | [143, 1, Conv, [1152, 3, 1]],
199 | [157, 1, Conv, [1536, 3, 1]],
200 |
201 | [115, 1, Conv, [384, 3, 1]],
202 | [99, 1, Conv, [768, 3, 1]],
203 | [83, 1, Conv, [1152, 3, 1]],
204 | [67, 1, Conv, [1536, 3, 1]],
205 |
206 | [[158,159,160,161,162,163,164,165], 1, IAuxDetect, [nc, anchors]], # Detect(P3, P4, P5, P6)
207 | ]
208 |
--------------------------------------------------------------------------------
/export.py:
--------------------------------------------------------------------------------
1 | import argparse
2 | import sys
3 | import time
4 |
5 | sys.path.append('./') # to run '$ python *.py' files in subdirectories
6 |
7 | import torch
8 | import torch.nn as nn
9 |
10 | import models
11 | from models.experimental import attempt_load, End2End
12 | from utils.activations import Hardswish, SiLU
13 | from utils.general import set_logging, check_img_size
14 | from utils.torch_utils import select_device
15 | from utils.add_nms import RegisterNMS
16 |
17 | if __name__ == '__main__':
18 | parser = argparse.ArgumentParser()
19 | parser.add_argument('--weights', type=str, default='./yolor-csp-c.pt', help='weights path')
20 | parser.add_argument('--img-size', nargs='+', type=int, default=[640, 640], help='image size') # height, width
21 | parser.add_argument('--batch-size', type=int, default=1, help='batch size')
22 | parser.add_argument('--dynamic', action='store_true', help='dynamic ONNX axes')
23 | parser.add_argument('--grid', action='store_true', help='export Detect() layer grid')
24 | parser.add_argument('--end2end', action='store_true', help='export end2end onnx')
25 | parser.add_argument('--max-wh', type=int, default=None, help='None for tensorrt nms, int value for onnx-runtime nms')
26 | parser.add_argument('--topk-all', type=int, default=100, help='topk objects for every images')
27 | parser.add_argument('--iou-thres', type=float, default=0.45, help='iou threshold for NMS')
28 | parser.add_argument('--conf-thres', type=float, default=0.25, help='conf threshold for NMS')
29 | parser.add_argument('--device', default='cpu', help='cuda device, i.e. 0 or 0,1,2,3 or cpu')
30 | parser.add_argument('--simplify', action='store_true', help='simplify onnx model')
31 | parser.add_argument('--include-nms', action='store_true', help='export end2end onnx')
32 | opt = parser.parse_args()
33 | opt.img_size *= 2 if len(opt.img_size) == 1 else 1 # expand
34 | print(opt)
35 | set_logging()
36 | t = time.time()
37 |
38 | # Load PyTorch model
39 | device = select_device(opt.device)
40 | model = attempt_load(opt.weights, map_location=device) # load FP32 model
41 | labels = model.names
42 |
43 | # Checks
44 | gs = int(max(model.stride)) # grid size (max stride)
45 | opt.img_size = [check_img_size(x, gs) for x in opt.img_size] # verify img_size are gs-multiples
46 |
47 | # Input
48 | img = torch.zeros(opt.batch_size, 3, *opt.img_size).to(device) # image size(1,3,320,192) iDetection
49 |
50 | # Update model
51 | for k, m in model.named_modules():
52 | m._non_persistent_buffers_set = set() # pytorch 1.6.0 compatibility
53 | if isinstance(m, models.common.Conv): # assign export-friendly activations
54 | if isinstance(m.act, nn.Hardswish):
55 | m.act = Hardswish()
56 | elif isinstance(m.act, nn.SiLU):
57 | m.act = SiLU()
58 | # elif isinstance(m, models.yolo.Detect):
59 | # m.forward = m.forward_export # assign forward (optional)
60 | model.model[-1].export = not opt.grid # set Detect() layer grid export
61 | y = model(img) # dry run
62 | if opt.include_nms:
63 | model.model[-1].include_nms = True
64 | y = None
65 | # TorchScript export
66 | try:
67 | print('\nStarting TorchScript export with torch %s...' % torch.__version__)
68 | f = opt.weights.replace('.pt', '.torchscript.pt') # filename
69 | ts = torch.jit.trace(model, img, strict=False)
70 | ts.save(f)
71 | print('TorchScript export success, saved as %s' % f)
72 | except Exception as e:
73 | print('TorchScript export failure: %s' % e)
74 |
75 | # ONNX export
76 | try:
77 | import onnx
78 |
79 | print('\nStarting ONNX export with onnx %s...' % onnx.__version__)
80 | f = opt.weights.replace('.pt', '.onnx') # filename
81 | model.eval()
82 | output_names = ['classes', 'boxes'] if y is None else ['output']
83 | if opt.grid and opt.end2end:
84 | print('\nStarting export end2end onnx model for %s...' % 'TensorRT' if opt.max_wh is None else 'onnxruntime')
85 | model = End2End(model,opt.topk_all,opt.iou_thres,opt.conf_thres,opt.max_wh,device)
86 | if opt.end2end and opt.max_wh is None:
87 | output_names = ['num_dets', 'det_boxes', 'det_scores', 'det_classes']
88 | shapes = [opt.batch_size, 1, opt.batch_size, opt.topk_all, 4,
89 | opt.batch_size, opt.topk_all, opt.batch_size, opt.topk_all]
90 | else:
91 | output_names = ['output']
92 |
93 | torch.onnx.export(model, img, f, verbose=False, opset_version=12, input_names=['images'],
94 | output_names=output_names,
95 | dynamic_axes={'images': {0: 'batch', 2: 'height', 3: 'width'}, # size(1,3,640,640)
96 | 'output': {0: 'batch', 2: 'y', 3: 'x'}} if opt.dynamic and not opt.end2end else None)
97 |
98 | # Checks
99 | onnx_model = onnx.load(f) # load onnx model
100 | onnx.checker.check_model(onnx_model) # check onnx model
101 |
102 | if opt.end2end and opt.max_wh is None:
103 | for i in onnx_model.graph.output:
104 | for j in i.type.tensor_type.shape.dim:
105 | j.dim_param = str(shapes.pop(0))
106 |
107 | # print(onnx.helper.printable_graph(onnx_model.graph)) # print a human readable model
108 |
109 | # # Metadata
110 | # d = {'stride': int(max(model.stride))}
111 | # for k, v in d.items():
112 | # meta = onnx_model.metadata_props.add()
113 | # meta.key, meta.value = k, str(v)
114 | # onnx.save(onnx_model, f)
115 |
116 | if opt.simplify:
117 | try:
118 | import onnxsim
119 |
120 | print('\nStarting to simplify ONNX...')
121 | onnx_model, check = onnxsim.simplify(onnx_model)
122 | assert check, 'assert check failed'
123 | except Exception as e:
124 | print(f'Simplifier failure: {e}')
125 |
126 | # print(onnx.helper.printable_graph(onnx_model.graph)) # print a human readable model
127 | onnx.save(onnx_model,f)
128 | print('ONNX export success, saved as %s' % f)
129 |
130 | if opt.include_nms:
131 | print('Registering NMS plugin for ONNX...')
132 | mo = RegisterNMS(f)
133 | mo.register_nms()
134 | mo.save(f)
135 |
136 | except Exception as e:
137 | print('ONNX export failure: %s' % e)
138 | # CoreML export
139 | try:
140 | import coremltools as ct
141 |
142 | print('\nStarting CoreML export with coremltools %s...' % ct.__version__)
143 | # convert model from torchscript and apply pixel scaling as per detect.py
144 | model = ct.convert(ts, inputs=[ct.ImageType(name='image', shape=img.shape, scale=1 / 255.0, bias=[0, 0, 0])])
145 | f = opt.weights.replace('.pt', '.mlmodel') # filename
146 | model.save(f)
147 | print('CoreML export success, saved as %s' % f)
148 | except Exception as e:
149 | print('CoreML export failure: %s' % e)
150 |
151 | # Finish
152 | print('\nExport complete (%.2fs). Visualize with https://github.com/lutzroeder/netron.' % (time.time() - t))
153 |
--------------------------------------------------------------------------------
/utils/autoanchor.py:
--------------------------------------------------------------------------------
1 | # Auto-anchor utils
2 |
3 | import numpy as np
4 | import torch
5 | import yaml
6 | from scipy.cluster.vq import kmeans
7 | from tqdm import tqdm
8 |
9 | from utils.general import colorstr
10 |
11 |
12 | def check_anchor_order(m):
13 | # Check anchor order against stride order for YOLO Detect() module m, and correct if necessary
14 | a = m.anchor_grid.prod(-1).view(-1) # anchor area
15 | da = a[-1] - a[0] # delta a
16 | ds = m.stride[-1] - m.stride[0] # delta s
17 | if da.sign() != ds.sign(): # same order
18 | print('Reversing anchor order')
19 | m.anchors[:] = m.anchors.flip(0)
20 | m.anchor_grid[:] = m.anchor_grid.flip(0)
21 |
22 |
23 | def check_anchors(dataset, model, thr=4.0, imgsz=640):
24 | # Check anchor fit to data, recompute if necessary
25 | prefix = colorstr('autoanchor: ')
26 | print(f'\n{prefix}Analyzing anchors... ', end='')
27 | m = model.module.model[-1] if hasattr(model, 'module') else model.model[-1] # Detect()
28 | shapes = imgsz * dataset.shapes / dataset.shapes.max(1, keepdims=True)
29 | scale = np.random.uniform(0.9, 1.1, size=(shapes.shape[0], 1)) # augment scale
30 | wh = torch.tensor(np.concatenate([l[:, 3:5] * s for s, l in zip(shapes * scale, dataset.labels)])).float() # wh
31 |
32 | def metric(k): # compute metric
33 | r = wh[:, None] / k[None]
34 | x = torch.min(r, 1. / r).min(2)[0] # ratio metric
35 | best = x.max(1)[0] # best_x
36 | aat = (x > 1. / thr).float().sum(1).mean() # anchors above threshold
37 | bpr = (best > 1. / thr).float().mean() # best possible recall
38 | return bpr, aat
39 |
40 | anchors = m.anchor_grid.clone().cpu().view(-1, 2) # current anchors
41 | bpr, aat = metric(anchors)
42 | print(f'anchors/target = {aat:.2f}, Best Possible Recall (BPR) = {bpr:.4f}', end='')
43 | if bpr < 0.98: # threshold to recompute
44 | print('. Attempting to improve anchors, please wait...')
45 | na = m.anchor_grid.numel() // 2 # number of anchors
46 | try:
47 | anchors = kmean_anchors(dataset, n=na, img_size=imgsz, thr=thr, gen=1000, verbose=False)
48 | except Exception as e:
49 | print(f'{prefix}ERROR: {e}')
50 | new_bpr = metric(anchors)[0]
51 | if new_bpr > bpr: # replace anchors
52 | anchors = torch.tensor(anchors, device=m.anchors.device).type_as(m.anchors)
53 | m.anchor_grid[:] = anchors.clone().view_as(m.anchor_grid) # for inference
54 | m.anchors[:] = anchors.clone().view_as(m.anchors) / m.stride.to(m.anchors.device).view(-1, 1, 1) # loss
55 | check_anchor_order(m)
56 | print(f'{prefix}New anchors saved to model. Update model *.yaml to use these anchors in the future.')
57 | else:
58 | print(f'{prefix}Original anchors better than new anchors. Proceeding with original anchors.')
59 | print('') # newline
60 |
61 |
62 | def kmean_anchors(path='./data/coco.yaml', n=9, img_size=640, thr=4.0, gen=1000, verbose=True):
63 | """ Creates kmeans-evolved anchors from training dataset
64 |
65 | Arguments:
66 | path: path to dataset *.yaml, or a loaded dataset
67 | n: number of anchors
68 | img_size: image size used for training
69 | thr: anchor-label wh ratio threshold hyperparameter hyp['anchor_t'] used for training, default=4.0
70 | gen: generations to evolve anchors using genetic algorithm
71 | verbose: print all results
72 |
73 | Return:
74 | k: kmeans evolved anchors
75 |
76 | Usage:
77 | from utils.autoanchor import *; _ = kmean_anchors()
78 | """
79 | thr = 1. / thr
80 | prefix = colorstr('autoanchor: ')
81 |
82 | def metric(k, wh): # compute metrics
83 | r = wh[:, None] / k[None]
84 | x = torch.min(r, 1. / r).min(2)[0] # ratio metric
85 | # x = wh_iou(wh, torch.tensor(k)) # iou metric
86 | return x, x.max(1)[0] # x, best_x
87 |
88 | def anchor_fitness(k): # mutation fitness
89 | _, best = metric(torch.tensor(k, dtype=torch.float32), wh)
90 | return (best * (best > thr).float()).mean() # fitness
91 |
92 | def print_results(k):
93 | k = k[np.argsort(k.prod(1))] # sort small to large
94 | x, best = metric(k, wh0)
95 | bpr, aat = (best > thr).float().mean(), (x > thr).float().mean() * n # best possible recall, anch > thr
96 | print(f'{prefix}thr={thr:.2f}: {bpr:.4f} best possible recall, {aat:.2f} anchors past thr')
97 | print(f'{prefix}n={n}, img_size={img_size}, metric_all={x.mean():.3f}/{best.mean():.3f}-mean/best, '
98 | f'past_thr={x[x > thr].mean():.3f}-mean: ', end='')
99 | for i, x in enumerate(k):
100 | print('%i,%i' % (round(x[0]), round(x[1])), end=', ' if i < len(k) - 1 else '\n') # use in *.cfg
101 | return k
102 |
103 | if isinstance(path, str): # *.yaml file
104 | with open(path) as f:
105 | data_dict = yaml.load(f, Loader=yaml.SafeLoader) # model dict
106 | from utils.datasets import LoadImagesAndLabels
107 | dataset = LoadImagesAndLabels(data_dict['train'], augment=True, rect=True)
108 | else:
109 | dataset = path # dataset
110 |
111 | # Get label wh
112 | shapes = img_size * dataset.shapes / dataset.shapes.max(1, keepdims=True)
113 | wh0 = np.concatenate([l[:, 3:5] * s for s, l in zip(shapes, dataset.labels)]) # wh
114 |
115 | # Filter
116 | i = (wh0 < 3.0).any(1).sum()
117 | if i:
118 | print(f'{prefix}WARNING: Extremely small objects found. {i} of {len(wh0)} labels are < 3 pixels in size.')
119 | wh = wh0[(wh0 >= 2.0).any(1)] # filter > 2 pixels
120 | # wh = wh * (np.random.rand(wh.shape[0], 1) * 0.9 + 0.1) # multiply by random scale 0-1
121 |
122 | # Kmeans calculation
123 | print(f'{prefix}Running kmeans for {n} anchors on {len(wh)} points...')
124 | s = wh.std(0) # sigmas for whitening
125 | k, dist = kmeans(wh / s, n, iter=30) # points, mean distance
126 | assert len(k) == n, print(f'{prefix}ERROR: scipy.cluster.vq.kmeans requested {n} points but returned only {len(k)}')
127 | k *= s
128 | wh = torch.tensor(wh, dtype=torch.float32) # filtered
129 | wh0 = torch.tensor(wh0, dtype=torch.float32) # unfiltered
130 | k = print_results(k)
131 |
132 | # Plot
133 | # k, d = [None] * 20, [None] * 20
134 | # for i in tqdm(range(1, 21)):
135 | # k[i-1], d[i-1] = kmeans(wh / s, i) # points, mean distance
136 | # fig, ax = plt.subplots(1, 2, figsize=(14, 7), tight_layout=True)
137 | # ax = ax.ravel()
138 | # ax[0].plot(np.arange(1, 21), np.array(d) ** 2, marker='.')
139 | # fig, ax = plt.subplots(1, 2, figsize=(14, 7)) # plot wh
140 | # ax[0].hist(wh[wh[:, 0]<100, 0],400)
141 | # ax[1].hist(wh[wh[:, 1]<100, 1],400)
142 | # fig.savefig('wh.png', dpi=200)
143 |
144 | # Evolve
145 | npr = np.random
146 | f, sh, mp, s = anchor_fitness(k), k.shape, 0.9, 0.1 # fitness, generations, mutation prob, sigma
147 | pbar = tqdm(range(gen), desc=f'{prefix}Evolving anchors with Genetic Algorithm:') # progress bar
148 | for _ in pbar:
149 | v = np.ones(sh)
150 | while (v == 1).all(): # mutate until a change occurs (prevent duplicates)
151 | v = ((npr.random(sh) < mp) * npr.random() * npr.randn(*sh) * s + 1).clip(0.3, 3.0)
152 | kg = (k.copy() * v).clip(min=2.0)
153 | fg = anchor_fitness(kg)
154 | if fg > f:
155 | f, k = fg, kg.copy()
156 | pbar.desc = f'{prefix}Evolving anchors with Genetic Algorithm: fitness = {f:.4f}'
157 | if verbose:
158 | print_results(k)
159 |
160 | return print_results(k)
161 |
--------------------------------------------------------------------------------
/detect.py:
--------------------------------------------------------------------------------
1 | import argparse
2 | import time
3 | from pathlib import Path
4 |
5 | import cv2
6 | import torch
7 | import torch.backends.cudnn as cudnn
8 | from numpy import random
9 |
10 | from models.experimental import attempt_load
11 | from utils.datasets import LoadStreams, LoadImages
12 | from utils.general import check_img_size, check_requirements, check_imshow, non_max_suppression, apply_classifier, \
13 | scale_coords, xyxy2xywh, strip_optimizer, set_logging, increment_path
14 | from utils.plots import plot_one_box
15 | from utils.torch_utils import select_device, load_classifier, time_synchronized, TracedModel
16 |
17 |
18 | def detect(save_img=False):
19 | source, weights, view_img, save_txt, imgsz, trace = opt.source, opt.weights, opt.view_img, opt.save_txt, opt.img_size, not opt.no_trace
20 | save_img = not opt.nosave and not source.endswith('.txt') # save inference images
21 | webcam = source.isnumeric() or source.endswith('.txt') or source.lower().startswith(
22 | ('rtsp://', 'rtmp://', 'http://', 'https://'))
23 |
24 | # Directories
25 | save_dir = Path(increment_path(Path(opt.project) / opt.name, exist_ok=opt.exist_ok)) # increment run
26 | (save_dir / 'labels' if save_txt else save_dir).mkdir(parents=True, exist_ok=True) # make dir
27 |
28 | # Initialize
29 | set_logging()
30 | device = select_device(opt.device)
31 | half = device.type != 'cpu' # half precision only supported on CUDA
32 |
33 | # Load model
34 | model = attempt_load(weights, map_location=device) # load FP32 model
35 | stride = int(model.stride.max()) # model stride
36 | imgsz = check_img_size(imgsz, s=stride) # check img_size
37 |
38 | if trace:
39 | model = TracedModel(model, device, opt.img_size)
40 |
41 | if half:
42 | model.half() # to FP16
43 |
44 | # Second-stage classifier
45 | classify = False
46 | if classify:
47 | modelc = load_classifier(name='resnet101', n=2) # initialize
48 | modelc.load_state_dict(torch.load('weights/resnet101.pt', map_location=device)['model']).to(device).eval()
49 |
50 | # Set Dataloader
51 | vid_path, vid_writer = None, None
52 | if webcam:
53 | view_img = check_imshow()
54 | cudnn.benchmark = True # set True to speed up constant image size inference
55 | dataset = LoadStreams(source, img_size=imgsz, stride=stride)
56 | else:
57 | dataset = LoadImages(source, img_size=imgsz, stride=stride)
58 |
59 | # Get names and colors
60 | names = model.module.names if hasattr(model, 'module') else model.names
61 | colors = [[random.randint(0, 255) for _ in range(3)] for _ in names]
62 |
63 | # Run inference
64 | if device.type != 'cpu':
65 | model(torch.zeros(1, 3, imgsz, imgsz).to(device).type_as(next(model.parameters()))) # run once
66 | t0 = time.time()
67 | for path, img, im0s, vid_cap in dataset:
68 | img = torch.from_numpy(img).to(device)
69 | img = img.half() if half else img.float() # uint8 to fp16/32
70 | img /= 255.0 # 0 - 255 to 0.0 - 1.0
71 | if img.ndimension() == 3:
72 | img = img.unsqueeze(0)
73 |
74 | # Inference
75 | t1 = time_synchronized()
76 | pred = model(img, augment=opt.augment)[0]
77 |
78 | # Apply NMS
79 | pred = non_max_suppression(pred, opt.conf_thres, opt.iou_thres, classes=opt.classes, agnostic=opt.agnostic_nms)
80 | t2 = time_synchronized()
81 |
82 | # Apply Classifier
83 | if classify:
84 | pred = apply_classifier(pred, modelc, img, im0s)
85 |
86 | # Process detections
87 | for i, det in enumerate(pred): # detections per image
88 | if webcam: # batch_size >= 1
89 | p, s, im0, frame = path[i], '%g: ' % i, im0s[i].copy(), dataset.count
90 | else:
91 | p, s, im0, frame = path, '', im0s, getattr(dataset, 'frame', 0)
92 |
93 | p = Path(p) # to Path
94 | save_path = str(save_dir / p.name) # img.jpg
95 | txt_path = str(save_dir / 'labels' / p.stem) + ('' if dataset.mode == 'image' else f'_{frame}') # img.txt
96 | s += '%gx%g ' % img.shape[2:] # print string
97 | gn = torch.tensor(im0.shape)[[1, 0, 1, 0]] # normalization gain whwh
98 | if len(det):
99 | # Rescale boxes from img_size to im0 size
100 | det[:, :4] = scale_coords(img.shape[2:], det[:, :4], im0.shape).round()
101 |
102 | # Print results
103 | for c in det[:, -1].unique():
104 | n = (det[:, -1] == c).sum() # detections per class
105 | s += f"{n} {names[int(c)]}{'s' * (n > 1)}, " # add to string
106 |
107 | # Write results
108 | for *xyxy, conf, cls in reversed(det):
109 | if save_txt: # Write to file
110 | xywh = (xyxy2xywh(torch.tensor(xyxy).view(1, 4)) / gn).view(-1).tolist() # normalized xywh
111 | line = (cls, *xywh, conf) if opt.save_conf else (cls, *xywh) # label format
112 | with open(txt_path + '.txt', 'a') as f:
113 | f.write(('%g ' * len(line)).rstrip() % line + '\n')
114 |
115 | if save_img or view_img: # Add bbox to image
116 | label = f'{names[int(cls)]} {conf:.2f}'
117 | plot_one_box(xyxy, im0, label=label, color=colors[int(cls)], line_thickness=3)
118 |
119 | # Print time (inference + NMS)
120 | #print(f'{s}Done. ({t2 - t1:.3f}s)')
121 |
122 | # Stream results
123 | if view_img:
124 | cv2.imshow(str(p), im0)
125 | cv2.waitKey(1) # 1 millisecond
126 |
127 | # Save results (image with detections)
128 | if save_img:
129 | if dataset.mode == 'image':
130 | cv2.imwrite(save_path, im0)
131 | print(f" The image with the result is saved in: {save_path}")
132 | else: # 'video' or 'stream'
133 | if vid_path != save_path: # new video
134 | vid_path = save_path
135 | if isinstance(vid_writer, cv2.VideoWriter):
136 | vid_writer.release() # release previous video writer
137 | if vid_cap: # video
138 | fps = vid_cap.get(cv2.CAP_PROP_FPS)
139 | w = int(vid_cap.get(cv2.CAP_PROP_FRAME_WIDTH))
140 | h = int(vid_cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
141 | else: # stream
142 | fps, w, h = 30, im0.shape[1], im0.shape[0]
143 | save_path += '.mp4'
144 | vid_writer = cv2.VideoWriter(save_path, cv2.VideoWriter_fourcc(*'mp4v'), fps, (w, h))
145 | vid_writer.write(im0)
146 |
147 | if save_txt or save_img:
148 | s = f"\n{len(list(save_dir.glob('labels/*.txt')))} labels saved to {save_dir / 'labels'}" if save_txt else ''
149 | #print(f"Results saved to {save_dir}{s}")
150 |
151 | print(f'Done. ({time.time() - t0:.3f}s)')
152 |
153 |
154 | if __name__ == '__main__':
155 | parser = argparse.ArgumentParser()
156 | parser.add_argument('--weights', nargs='+', type=str, default='yolov7.pt', help='model.pt path(s)')
157 | parser.add_argument('--source', type=str, default='inference/images', help='source') # file/folder, 0 for webcam
158 | parser.add_argument('--img-size', type=int, default=640, help='inference size (pixels)')
159 | parser.add_argument('--conf-thres', type=float, default=0.25, help='object confidence threshold')
160 | parser.add_argument('--iou-thres', type=float, default=0.45, help='IOU threshold for NMS')
161 | parser.add_argument('--device', default='', help='cuda device, i.e. 0 or 0,1,2,3 or cpu')
162 | parser.add_argument('--view-img', action='store_true', help='display results')
163 | parser.add_argument('--save-txt', action='store_true', help='save results to *.txt')
164 | parser.add_argument('--save-conf', action='store_true', help='save confidences in --save-txt labels')
165 | parser.add_argument('--nosave', action='store_true', help='do not save images/videos')
166 | parser.add_argument('--classes', nargs='+', type=int, help='filter by class: --class 0, or --class 0 2 3')
167 | parser.add_argument('--agnostic-nms', action='store_true', help='class-agnostic NMS')
168 | parser.add_argument('--augment', action='store_true', help='augmented inference')
169 | parser.add_argument('--update', action='store_true', help='update all models')
170 | parser.add_argument('--project', default='runs/detect', help='save results to project/name')
171 | parser.add_argument('--name', default='exp', help='save results to project/name')
172 | parser.add_argument('--exist-ok', action='store_true', help='existing project/name ok, do not increment')
173 | parser.add_argument('--no-trace', action='store_true', help='don`t trace model')
174 | opt = parser.parse_args()
175 | print(opt)
176 | #check_requirements(exclude=('pycocotools', 'thop'))
177 |
178 | with torch.no_grad():
179 | if opt.update: # update all models (to fix SourceChangeWarning)
180 | for opt.weights in ['yolov7.pt']:
181 | detect()
182 | strip_optimizer(opt.weights)
183 | else:
184 | detect()
185 |
--------------------------------------------------------------------------------
/utils/metrics.py:
--------------------------------------------------------------------------------
1 | # Model validation metrics
2 |
3 | from pathlib import Path
4 |
5 | import matplotlib.pyplot as plt
6 | import numpy as np
7 | import torch
8 |
9 | from . import general
10 |
11 |
12 | def fitness(x):
13 | # Model fitness as a weighted combination of metrics
14 | w = [0.0, 0.0, 0.1, 0.9] # weights for [P, R, mAP@0.5, mAP@0.5:0.95]
15 | return (x[:, :4] * w).sum(1)
16 |
17 |
18 | def ap_per_class(tp, conf, pred_cls, target_cls, plot=False, save_dir='.', names=()):
19 | """ Compute the average precision, given the recall and precision curves.
20 | Source: https://github.com/rafaelpadilla/Object-Detection-Metrics.
21 | # Arguments
22 | tp: True positives (nparray, nx1 or nx10).
23 | conf: Objectness value from 0-1 (nparray).
24 | pred_cls: Predicted object classes (nparray).
25 | target_cls: True object classes (nparray).
26 | plot: Plot precision-recall curve at mAP@0.5
27 | save_dir: Plot save directory
28 | # Returns
29 | The average precision as computed in py-faster-rcnn.
30 | """
31 |
32 | # Sort by objectness
33 | i = np.argsort(-conf)
34 | tp, conf, pred_cls = tp[i], conf[i], pred_cls[i]
35 |
36 | # Find unique classes
37 | unique_classes = np.unique(target_cls)
38 | nc = unique_classes.shape[0] # number of classes, number of detections
39 |
40 | # Create Precision-Recall curve and compute AP for each class
41 | px, py = np.linspace(0, 1, 1000), [] # for plotting
42 | ap, p, r = np.zeros((nc, tp.shape[1])), np.zeros((nc, 1000)), np.zeros((nc, 1000))
43 | for ci, c in enumerate(unique_classes):
44 | i = pred_cls == c
45 | n_l = (target_cls == c).sum() # number of labels
46 | n_p = i.sum() # number of predictions
47 |
48 | if n_p == 0 or n_l == 0:
49 | continue
50 | else:
51 | # Accumulate FPs and TPs
52 | fpc = (1 - tp[i]).cumsum(0)
53 | tpc = tp[i].cumsum(0)
54 |
55 | # Recall
56 | recall = tpc / (n_l + 1e-16) # recall curve
57 | r[ci] = np.interp(-px, -conf[i], recall[:, 0], left=0) # negative x, xp because xp decreases
58 |
59 | # Precision
60 | precision = tpc / (tpc + fpc) # precision curve
61 | p[ci] = np.interp(-px, -conf[i], precision[:, 0], left=1) # p at pr_score
62 |
63 | # AP from recall-precision curve
64 | for j in range(tp.shape[1]):
65 | ap[ci, j], mpre, mrec = compute_ap(recall[:, j], precision[:, j])
66 | if plot and j == 0:
67 | py.append(np.interp(px, mrec, mpre)) # precision at mAP@0.5
68 |
69 | # Compute F1 (harmonic mean of precision and recall)
70 | f1 = 2 * p * r / (p + r + 1e-16)
71 | if plot:
72 | plot_pr_curve(px, py, ap, Path(save_dir) / 'PR_curve.png', names)
73 | plot_mc_curve(px, f1, Path(save_dir) / 'F1_curve.png', names, ylabel='F1')
74 | plot_mc_curve(px, p, Path(save_dir) / 'P_curve.png', names, ylabel='Precision')
75 | plot_mc_curve(px, r, Path(save_dir) / 'R_curve.png', names, ylabel='Recall')
76 |
77 | i = f1.mean(0).argmax() # max F1 index
78 | return p[:, i], r[:, i], ap, f1[:, i], unique_classes.astype('int32')
79 |
80 |
81 | def compute_ap(recall, precision):
82 | """ Compute the average precision, given the recall and precision curves
83 | # Arguments
84 | recall: The recall curve (list)
85 | precision: The precision curve (list)
86 | # Returns
87 | Average precision, precision curve, recall curve
88 | """
89 |
90 | # Append sentinel values to beginning and end
91 | mrec = np.concatenate(([0.], recall, [recall[-1] + 0.01]))
92 | mpre = np.concatenate(([1.], precision, [0.]))
93 |
94 | # Compute the precision envelope
95 | mpre = np.flip(np.maximum.accumulate(np.flip(mpre)))
96 |
97 | # Integrate area under curve
98 | method = 'interp' # methods: 'continuous', 'interp'
99 | if method == 'interp':
100 | x = np.linspace(0, 1, 101) # 101-point interp (COCO)
101 | ap = np.trapz(np.interp(x, mrec, mpre), x) # integrate
102 | else: # 'continuous'
103 | i = np.where(mrec[1:] != mrec[:-1])[0] # points where x axis (recall) changes
104 | ap = np.sum((mrec[i + 1] - mrec[i]) * mpre[i + 1]) # area under curve
105 |
106 | return ap, mpre, mrec
107 |
108 |
109 | class ConfusionMatrix:
110 | # Updated version of https://github.com/kaanakan/object_detection_confusion_matrix
111 | def __init__(self, nc, conf=0.25, iou_thres=0.45):
112 | self.matrix = np.zeros((nc + 1, nc + 1))
113 | self.nc = nc # number of classes
114 | self.conf = conf
115 | self.iou_thres = iou_thres
116 |
117 | def process_batch(self, detections, labels):
118 | """
119 | Return intersection-over-union (Jaccard index) of boxes.
120 | Both sets of boxes are expected to be in (x1, y1, x2, y2) format.
121 | Arguments:
122 | detections (Array[N, 6]), x1, y1, x2, y2, conf, class
123 | labels (Array[M, 5]), class, x1, y1, x2, y2
124 | Returns:
125 | None, updates confusion matrix accordingly
126 | """
127 | detections = detections[detections[:, 4] > self.conf]
128 | gt_classes = labels[:, 0].int()
129 | detection_classes = detections[:, 5].int()
130 | iou = general.box_iou(labels[:, 1:], detections[:, :4])
131 |
132 | x = torch.where(iou > self.iou_thres)
133 | if x[0].shape[0]:
134 | matches = torch.cat((torch.stack(x, 1), iou[x[0], x[1]][:, None]), 1).cpu().numpy()
135 | if x[0].shape[0] > 1:
136 | matches = matches[matches[:, 2].argsort()[::-1]]
137 | matches = matches[np.unique(matches[:, 1], return_index=True)[1]]
138 | matches = matches[matches[:, 2].argsort()[::-1]]
139 | matches = matches[np.unique(matches[:, 0], return_index=True)[1]]
140 | else:
141 | matches = np.zeros((0, 3))
142 |
143 | n = matches.shape[0] > 0
144 | m0, m1, _ = matches.transpose().astype(np.int16)
145 | for i, gc in enumerate(gt_classes):
146 | j = m0 == i
147 | if n and sum(j) == 1:
148 | self.matrix[gc, detection_classes[m1[j]]] += 1 # correct
149 | else:
150 | self.matrix[self.nc, gc] += 1 # background FP
151 |
152 | if n:
153 | for i, dc in enumerate(detection_classes):
154 | if not any(m1 == i):
155 | self.matrix[dc, self.nc] += 1 # background FN
156 |
157 | def matrix(self):
158 | return self.matrix
159 |
160 | def plot(self, save_dir='', names=()):
161 | try:
162 | import seaborn as sn
163 |
164 | array = self.matrix / (self.matrix.sum(0).reshape(1, self.nc + 1) + 1E-6) # normalize
165 | array[array < 0.005] = np.nan # don't annotate (would appear as 0.00)
166 |
167 | fig = plt.figure(figsize=(12, 9), tight_layout=True)
168 | sn.set(font_scale=1.0 if self.nc < 50 else 0.8) # for label size
169 | labels = (0 < len(names) < 99) and len(names) == self.nc # apply names to ticklabels
170 | sn.heatmap(array, annot=self.nc < 30, annot_kws={"size": 8}, cmap='Blues', fmt='.2f', square=True,
171 | xticklabels=names + ['background FP'] if labels else "auto",
172 | yticklabels=names + ['background FN'] if labels else "auto").set_facecolor((1, 1, 1))
173 | fig.axes[0].set_xlabel('True')
174 | fig.axes[0].set_ylabel('Predicted')
175 | fig.savefig(Path(save_dir) / 'confusion_matrix.png', dpi=250)
176 | except Exception as e:
177 | pass
178 |
179 | def print(self):
180 | for i in range(self.nc + 1):
181 | print(' '.join(map(str, self.matrix[i])))
182 |
183 |
184 | # Plots ----------------------------------------------------------------------------------------------------------------
185 |
186 | def plot_pr_curve(px, py, ap, save_dir='pr_curve.png', names=()):
187 | # Precision-recall curve
188 | fig, ax = plt.subplots(1, 1, figsize=(9, 6), tight_layout=True)
189 | py = np.stack(py, axis=1)
190 |
191 | if 0 < len(names) < 21: # display per-class legend if < 21 classes
192 | for i, y in enumerate(py.T):
193 | ax.plot(px, y, linewidth=1, label=f'{names[i]} {ap[i, 0]:.3f}') # plot(recall, precision)
194 | else:
195 | ax.plot(px, py, linewidth=1, color='grey') # plot(recall, precision)
196 |
197 | ax.plot(px, py.mean(1), linewidth=3, color='blue', label='all classes %.3f mAP@0.5' % ap[:, 0].mean())
198 | ax.set_xlabel('Recall')
199 | ax.set_ylabel('Precision')
200 | ax.set_xlim(0, 1)
201 | ax.set_ylim(0, 1)
202 | plt.legend(bbox_to_anchor=(1.04, 1), loc="upper left")
203 | fig.savefig(Path(save_dir), dpi=250)
204 |
205 |
206 | def plot_mc_curve(px, py, save_dir='mc_curve.png', names=(), xlabel='Confidence', ylabel='Metric'):
207 | # Metric-confidence curve
208 | fig, ax = plt.subplots(1, 1, figsize=(9, 6), tight_layout=True)
209 |
210 | if 0 < len(names) < 21: # display per-class legend if < 21 classes
211 | for i, y in enumerate(py):
212 | ax.plot(px, y, linewidth=1, label=f'{names[i]}') # plot(confidence, metric)
213 | else:
214 | ax.plot(px, py.T, linewidth=1, color='grey') # plot(confidence, metric)
215 |
216 | y = py.mean(0)
217 | ax.plot(px, y, linewidth=3, color='blue', label=f'all classes {y.max():.2f} at {px[y.argmax()]:.3f}')
218 | ax.set_xlabel(xlabel)
219 | ax.set_ylabel(ylabel)
220 | ax.set_xlim(0, 1)
221 | ax.set_ylim(0, 1)
222 | plt.legend(bbox_to_anchor=(1.04, 1), loc="upper left")
223 | fig.savefig(Path(save_dir), dpi=250)
224 |
--------------------------------------------------------------------------------
/cfg/deploy/yolov7-e6e.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # yolov7-e6e backbone
14 | backbone:
15 | # [from, number, module, args],
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [80, 3, 1]], # 1-P1/2
18 |
19 | [-1, 1, DownC, [160]], # 2-P2/4
20 | [-1, 1, Conv, [64, 1, 1]],
21 | [-2, 1, Conv, [64, 1, 1]],
22 | [-1, 1, Conv, [64, 3, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [-1, 1, Conv, [64, 3, 1]],
28 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
29 | [-1, 1, Conv, [160, 1, 1]], # 12
30 | [-11, 1, Conv, [64, 1, 1]],
31 | [-12, 1, Conv, [64, 1, 1]],
32 | [-1, 1, Conv, [64, 3, 1]],
33 | [-1, 1, Conv, [64, 3, 1]],
34 | [-1, 1, Conv, [64, 3, 1]],
35 | [-1, 1, Conv, [64, 3, 1]],
36 | [-1, 1, Conv, [64, 3, 1]],
37 | [-1, 1, Conv, [64, 3, 1]],
38 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
39 | [-1, 1, Conv, [160, 1, 1]], # 22
40 | [[-1, -11], 1, Shortcut, [1]], # 23
41 |
42 | [-1, 1, DownC, [320]], # 24-P3/8
43 | [-1, 1, Conv, [128, 1, 1]],
44 | [-2, 1, Conv, [128, 1, 1]],
45 | [-1, 1, Conv, [128, 3, 1]],
46 | [-1, 1, Conv, [128, 3, 1]],
47 | [-1, 1, Conv, [128, 3, 1]],
48 | [-1, 1, Conv, [128, 3, 1]],
49 | [-1, 1, Conv, [128, 3, 1]],
50 | [-1, 1, Conv, [128, 3, 1]],
51 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
52 | [-1, 1, Conv, [320, 1, 1]], # 34
53 | [-11, 1, Conv, [128, 1, 1]],
54 | [-12, 1, Conv, [128, 1, 1]],
55 | [-1, 1, Conv, [128, 3, 1]],
56 | [-1, 1, Conv, [128, 3, 1]],
57 | [-1, 1, Conv, [128, 3, 1]],
58 | [-1, 1, Conv, [128, 3, 1]],
59 | [-1, 1, Conv, [128, 3, 1]],
60 | [-1, 1, Conv, [128, 3, 1]],
61 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
62 | [-1, 1, Conv, [320, 1, 1]], # 44
63 | [[-1, -11], 1, Shortcut, [1]], # 45
64 |
65 | [-1, 1, DownC, [640]], # 46-P4/16
66 | [-1, 1, Conv, [256, 1, 1]],
67 | [-2, 1, Conv, [256, 1, 1]],
68 | [-1, 1, Conv, [256, 3, 1]],
69 | [-1, 1, Conv, [256, 3, 1]],
70 | [-1, 1, Conv, [256, 3, 1]],
71 | [-1, 1, Conv, [256, 3, 1]],
72 | [-1, 1, Conv, [256, 3, 1]],
73 | [-1, 1, Conv, [256, 3, 1]],
74 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
75 | [-1, 1, Conv, [640, 1, 1]], # 56
76 | [-11, 1, Conv, [256, 1, 1]],
77 | [-12, 1, Conv, [256, 1, 1]],
78 | [-1, 1, Conv, [256, 3, 1]],
79 | [-1, 1, Conv, [256, 3, 1]],
80 | [-1, 1, Conv, [256, 3, 1]],
81 | [-1, 1, Conv, [256, 3, 1]],
82 | [-1, 1, Conv, [256, 3, 1]],
83 | [-1, 1, Conv, [256, 3, 1]],
84 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
85 | [-1, 1, Conv, [640, 1, 1]], # 66
86 | [[-1, -11], 1, Shortcut, [1]], # 67
87 |
88 | [-1, 1, DownC, [960]], # 68-P5/32
89 | [-1, 1, Conv, [384, 1, 1]],
90 | [-2, 1, Conv, [384, 1, 1]],
91 | [-1, 1, Conv, [384, 3, 1]],
92 | [-1, 1, Conv, [384, 3, 1]],
93 | [-1, 1, Conv, [384, 3, 1]],
94 | [-1, 1, Conv, [384, 3, 1]],
95 | [-1, 1, Conv, [384, 3, 1]],
96 | [-1, 1, Conv, [384, 3, 1]],
97 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
98 | [-1, 1, Conv, [960, 1, 1]], # 78
99 | [-11, 1, Conv, [384, 1, 1]],
100 | [-12, 1, Conv, [384, 1, 1]],
101 | [-1, 1, Conv, [384, 3, 1]],
102 | [-1, 1, Conv, [384, 3, 1]],
103 | [-1, 1, Conv, [384, 3, 1]],
104 | [-1, 1, Conv, [384, 3, 1]],
105 | [-1, 1, Conv, [384, 3, 1]],
106 | [-1, 1, Conv, [384, 3, 1]],
107 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
108 | [-1, 1, Conv, [960, 1, 1]], # 88
109 | [[-1, -11], 1, Shortcut, [1]], # 89
110 |
111 | [-1, 1, DownC, [1280]], # 90-P6/64
112 | [-1, 1, Conv, [512, 1, 1]],
113 | [-2, 1, Conv, [512, 1, 1]],
114 | [-1, 1, Conv, [512, 3, 1]],
115 | [-1, 1, Conv, [512, 3, 1]],
116 | [-1, 1, Conv, [512, 3, 1]],
117 | [-1, 1, Conv, [512, 3, 1]],
118 | [-1, 1, Conv, [512, 3, 1]],
119 | [-1, 1, Conv, [512, 3, 1]],
120 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
121 | [-1, 1, Conv, [1280, 1, 1]], # 100
122 | [-11, 1, Conv, [512, 1, 1]],
123 | [-12, 1, Conv, [512, 1, 1]],
124 | [-1, 1, Conv, [512, 3, 1]],
125 | [-1, 1, Conv, [512, 3, 1]],
126 | [-1, 1, Conv, [512, 3, 1]],
127 | [-1, 1, Conv, [512, 3, 1]],
128 | [-1, 1, Conv, [512, 3, 1]],
129 | [-1, 1, Conv, [512, 3, 1]],
130 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
131 | [-1, 1, Conv, [1280, 1, 1]], # 110
132 | [[-1, -11], 1, Shortcut, [1]], # 111
133 | ]
134 |
135 | # yolov7-e6e head
136 | head:
137 | [[-1, 1, SPPCSPC, [640]], # 112
138 |
139 | [-1, 1, Conv, [480, 1, 1]],
140 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
141 | [89, 1, Conv, [480, 1, 1]], # route backbone P5
142 | [[-1, -2], 1, Concat, [1]],
143 |
144 | [-1, 1, Conv, [384, 1, 1]],
145 | [-2, 1, Conv, [384, 1, 1]],
146 | [-1, 1, Conv, [192, 3, 1]],
147 | [-1, 1, Conv, [192, 3, 1]],
148 | [-1, 1, Conv, [192, 3, 1]],
149 | [-1, 1, Conv, [192, 3, 1]],
150 | [-1, 1, Conv, [192, 3, 1]],
151 | [-1, 1, Conv, [192, 3, 1]],
152 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
153 | [-1, 1, Conv, [480, 1, 1]], # 126
154 | [-11, 1, Conv, [384, 1, 1]],
155 | [-12, 1, Conv, [384, 1, 1]],
156 | [-1, 1, Conv, [192, 3, 1]],
157 | [-1, 1, Conv, [192, 3, 1]],
158 | [-1, 1, Conv, [192, 3, 1]],
159 | [-1, 1, Conv, [192, 3, 1]],
160 | [-1, 1, Conv, [192, 3, 1]],
161 | [-1, 1, Conv, [192, 3, 1]],
162 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
163 | [-1, 1, Conv, [480, 1, 1]], # 136
164 | [[-1, -11], 1, Shortcut, [1]], # 137
165 |
166 | [-1, 1, Conv, [320, 1, 1]],
167 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
168 | [67, 1, Conv, [320, 1, 1]], # route backbone P4
169 | [[-1, -2], 1, Concat, [1]],
170 |
171 | [-1, 1, Conv, [256, 1, 1]],
172 | [-2, 1, Conv, [256, 1, 1]],
173 | [-1, 1, Conv, [128, 3, 1]],
174 | [-1, 1, Conv, [128, 3, 1]],
175 | [-1, 1, Conv, [128, 3, 1]],
176 | [-1, 1, Conv, [128, 3, 1]],
177 | [-1, 1, Conv, [128, 3, 1]],
178 | [-1, 1, Conv, [128, 3, 1]],
179 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
180 | [-1, 1, Conv, [320, 1, 1]], # 151
181 | [-11, 1, Conv, [256, 1, 1]],
182 | [-12, 1, Conv, [256, 1, 1]],
183 | [-1, 1, Conv, [128, 3, 1]],
184 | [-1, 1, Conv, [128, 3, 1]],
185 | [-1, 1, Conv, [128, 3, 1]],
186 | [-1, 1, Conv, [128, 3, 1]],
187 | [-1, 1, Conv, [128, 3, 1]],
188 | [-1, 1, Conv, [128, 3, 1]],
189 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
190 | [-1, 1, Conv, [320, 1, 1]], # 161
191 | [[-1, -11], 1, Shortcut, [1]], # 162
192 |
193 | [-1, 1, Conv, [160, 1, 1]],
194 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
195 | [45, 1, Conv, [160, 1, 1]], # route backbone P3
196 | [[-1, -2], 1, Concat, [1]],
197 |
198 | [-1, 1, Conv, [128, 1, 1]],
199 | [-2, 1, Conv, [128, 1, 1]],
200 | [-1, 1, Conv, [64, 3, 1]],
201 | [-1, 1, Conv, [64, 3, 1]],
202 | [-1, 1, Conv, [64, 3, 1]],
203 | [-1, 1, Conv, [64, 3, 1]],
204 | [-1, 1, Conv, [64, 3, 1]],
205 | [-1, 1, Conv, [64, 3, 1]],
206 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
207 | [-1, 1, Conv, [160, 1, 1]], # 176
208 | [-11, 1, Conv, [128, 1, 1]],
209 | [-12, 1, Conv, [128, 1, 1]],
210 | [-1, 1, Conv, [64, 3, 1]],
211 | [-1, 1, Conv, [64, 3, 1]],
212 | [-1, 1, Conv, [64, 3, 1]],
213 | [-1, 1, Conv, [64, 3, 1]],
214 | [-1, 1, Conv, [64, 3, 1]],
215 | [-1, 1, Conv, [64, 3, 1]],
216 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
217 | [-1, 1, Conv, [160, 1, 1]], # 186
218 | [[-1, -11], 1, Shortcut, [1]], # 187
219 |
220 | [-1, 1, DownC, [320]],
221 | [[-1, 162], 1, Concat, [1]],
222 |
223 | [-1, 1, Conv, [256, 1, 1]],
224 | [-2, 1, Conv, [256, 1, 1]],
225 | [-1, 1, Conv, [128, 3, 1]],
226 | [-1, 1, Conv, [128, 3, 1]],
227 | [-1, 1, Conv, [128, 3, 1]],
228 | [-1, 1, Conv, [128, 3, 1]],
229 | [-1, 1, Conv, [128, 3, 1]],
230 | [-1, 1, Conv, [128, 3, 1]],
231 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
232 | [-1, 1, Conv, [320, 1, 1]], # 199
233 | [-11, 1, Conv, [256, 1, 1]],
234 | [-12, 1, Conv, [256, 1, 1]],
235 | [-1, 1, Conv, [128, 3, 1]],
236 | [-1, 1, Conv, [128, 3, 1]],
237 | [-1, 1, Conv, [128, 3, 1]],
238 | [-1, 1, Conv, [128, 3, 1]],
239 | [-1, 1, Conv, [128, 3, 1]],
240 | [-1, 1, Conv, [128, 3, 1]],
241 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
242 | [-1, 1, Conv, [320, 1, 1]], # 209
243 | [[-1, -11], 1, Shortcut, [1]], # 210
244 |
245 | [-1, 1, DownC, [480]],
246 | [[-1, 137], 1, Concat, [1]],
247 |
248 | [-1, 1, Conv, [384, 1, 1]],
249 | [-2, 1, Conv, [384, 1, 1]],
250 | [-1, 1, Conv, [192, 3, 1]],
251 | [-1, 1, Conv, [192, 3, 1]],
252 | [-1, 1, Conv, [192, 3, 1]],
253 | [-1, 1, Conv, [192, 3, 1]],
254 | [-1, 1, Conv, [192, 3, 1]],
255 | [-1, 1, Conv, [192, 3, 1]],
256 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
257 | [-1, 1, Conv, [480, 1, 1]], # 222
258 | [-11, 1, Conv, [384, 1, 1]],
259 | [-12, 1, Conv, [384, 1, 1]],
260 | [-1, 1, Conv, [192, 3, 1]],
261 | [-1, 1, Conv, [192, 3, 1]],
262 | [-1, 1, Conv, [192, 3, 1]],
263 | [-1, 1, Conv, [192, 3, 1]],
264 | [-1, 1, Conv, [192, 3, 1]],
265 | [-1, 1, Conv, [192, 3, 1]],
266 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
267 | [-1, 1, Conv, [480, 1, 1]], # 232
268 | [[-1, -11], 1, Shortcut, [1]], # 233
269 |
270 | [-1, 1, DownC, [640]],
271 | [[-1, 112], 1, Concat, [1]],
272 |
273 | [-1, 1, Conv, [512, 1, 1]],
274 | [-2, 1, Conv, [512, 1, 1]],
275 | [-1, 1, Conv, [256, 3, 1]],
276 | [-1, 1, Conv, [256, 3, 1]],
277 | [-1, 1, Conv, [256, 3, 1]],
278 | [-1, 1, Conv, [256, 3, 1]],
279 | [-1, 1, Conv, [256, 3, 1]],
280 | [-1, 1, Conv, [256, 3, 1]],
281 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
282 | [-1, 1, Conv, [640, 1, 1]], # 245
283 | [-11, 1, Conv, [512, 1, 1]],
284 | [-12, 1, Conv, [512, 1, 1]],
285 | [-1, 1, Conv, [256, 3, 1]],
286 | [-1, 1, Conv, [256, 3, 1]],
287 | [-1, 1, Conv, [256, 3, 1]],
288 | [-1, 1, Conv, [256, 3, 1]],
289 | [-1, 1, Conv, [256, 3, 1]],
290 | [-1, 1, Conv, [256, 3, 1]],
291 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
292 | [-1, 1, Conv, [640, 1, 1]], # 255
293 | [[-1, -11], 1, Shortcut, [1]], # 256
294 |
295 | [187, 1, Conv, [320, 3, 1]],
296 | [210, 1, Conv, [640, 3, 1]],
297 | [233, 1, Conv, [960, 3, 1]],
298 | [256, 1, Conv, [1280, 3, 1]],
299 |
300 | [[257,258,259,260], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5, P6)
301 | ]
302 |
--------------------------------------------------------------------------------
/cfg/training/yolov7-e6e.yaml:
--------------------------------------------------------------------------------
1 | # parameters
2 | nc: 80 # number of classes
3 | depth_multiple: 1.0 # model depth multiple
4 | width_multiple: 1.0 # layer channel multiple
5 |
6 | # anchors
7 | anchors:
8 | - [ 19,27, 44,40, 38,94 ] # P3/8
9 | - [ 96,68, 86,152, 180,137 ] # P4/16
10 | - [ 140,301, 303,264, 238,542 ] # P5/32
11 | - [ 436,615, 739,380, 925,792 ] # P6/64
12 |
13 | # yolov7 backbone
14 | backbone:
15 | # [from, number, module, args],
16 | [[-1, 1, ReOrg, []], # 0
17 | [-1, 1, Conv, [80, 3, 1]], # 1-P1/2
18 |
19 | [-1, 1, DownC, [160]], # 2-P2/4
20 | [-1, 1, Conv, [64, 1, 1]],
21 | [-2, 1, Conv, [64, 1, 1]],
22 | [-1, 1, Conv, [64, 3, 1]],
23 | [-1, 1, Conv, [64, 3, 1]],
24 | [-1, 1, Conv, [64, 3, 1]],
25 | [-1, 1, Conv, [64, 3, 1]],
26 | [-1, 1, Conv, [64, 3, 1]],
27 | [-1, 1, Conv, [64, 3, 1]],
28 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
29 | [-1, 1, Conv, [160, 1, 1]], # 12
30 | [-11, 1, Conv, [64, 1, 1]],
31 | [-12, 1, Conv, [64, 1, 1]],
32 | [-1, 1, Conv, [64, 3, 1]],
33 | [-1, 1, Conv, [64, 3, 1]],
34 | [-1, 1, Conv, [64, 3, 1]],
35 | [-1, 1, Conv, [64, 3, 1]],
36 | [-1, 1, Conv, [64, 3, 1]],
37 | [-1, 1, Conv, [64, 3, 1]],
38 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
39 | [-1, 1, Conv, [160, 1, 1]], # 22
40 | [[-1, -11], 1, Shortcut, [1]], # 23
41 |
42 | [-1, 1, DownC, [320]], # 24-P3/8
43 | [-1, 1, Conv, [128, 1, 1]],
44 | [-2, 1, Conv, [128, 1, 1]],
45 | [-1, 1, Conv, [128, 3, 1]],
46 | [-1, 1, Conv, [128, 3, 1]],
47 | [-1, 1, Conv, [128, 3, 1]],
48 | [-1, 1, Conv, [128, 3, 1]],
49 | [-1, 1, Conv, [128, 3, 1]],
50 | [-1, 1, Conv, [128, 3, 1]],
51 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
52 | [-1, 1, Conv, [320, 1, 1]], # 34
53 | [-11, 1, Conv, [128, 1, 1]],
54 | [-12, 1, Conv, [128, 1, 1]],
55 | [-1, 1, Conv, [128, 3, 1]],
56 | [-1, 1, Conv, [128, 3, 1]],
57 | [-1, 1, Conv, [128, 3, 1]],
58 | [-1, 1, Conv, [128, 3, 1]],
59 | [-1, 1, Conv, [128, 3, 1]],
60 | [-1, 1, Conv, [128, 3, 1]],
61 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
62 | [-1, 1, Conv, [320, 1, 1]], # 44
63 | [[-1, -11], 1, Shortcut, [1]], # 45
64 |
65 | [-1, 1, DownC, [640]], # 46-P4/16
66 | [-1, 1, Conv, [256, 1, 1]],
67 | [-2, 1, Conv, [256, 1, 1]],
68 | [-1, 1, Conv, [256, 3, 1]],
69 | [-1, 1, Conv, [256, 3, 1]],
70 | [-1, 1, Conv, [256, 3, 1]],
71 | [-1, 1, Conv, [256, 3, 1]],
72 | [-1, 1, Conv, [256, 3, 1]],
73 | [-1, 1, Conv, [256, 3, 1]],
74 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
75 | [-1, 1, Conv, [640, 1, 1]], # 56
76 | [-11, 1, Conv, [256, 1, 1]],
77 | [-12, 1, Conv, [256, 1, 1]],
78 | [-1, 1, Conv, [256, 3, 1]],
79 | [-1, 1, Conv, [256, 3, 1]],
80 | [-1, 1, Conv, [256, 3, 1]],
81 | [-1, 1, Conv, [256, 3, 1]],
82 | [-1, 1, Conv, [256, 3, 1]],
83 | [-1, 1, Conv, [256, 3, 1]],
84 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
85 | [-1, 1, Conv, [640, 1, 1]], # 66
86 | [[-1, -11], 1, Shortcut, [1]], # 67
87 |
88 | [-1, 1, DownC, [960]], # 68-P5/32
89 | [-1, 1, Conv, [384, 1, 1]],
90 | [-2, 1, Conv, [384, 1, 1]],
91 | [-1, 1, Conv, [384, 3, 1]],
92 | [-1, 1, Conv, [384, 3, 1]],
93 | [-1, 1, Conv, [384, 3, 1]],
94 | [-1, 1, Conv, [384, 3, 1]],
95 | [-1, 1, Conv, [384, 3, 1]],
96 | [-1, 1, Conv, [384, 3, 1]],
97 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
98 | [-1, 1, Conv, [960, 1, 1]], # 78
99 | [-11, 1, Conv, [384, 1, 1]],
100 | [-12, 1, Conv, [384, 1, 1]],
101 | [-1, 1, Conv, [384, 3, 1]],
102 | [-1, 1, Conv, [384, 3, 1]],
103 | [-1, 1, Conv, [384, 3, 1]],
104 | [-1, 1, Conv, [384, 3, 1]],
105 | [-1, 1, Conv, [384, 3, 1]],
106 | [-1, 1, Conv, [384, 3, 1]],
107 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
108 | [-1, 1, Conv, [960, 1, 1]], # 88
109 | [[-1, -11], 1, Shortcut, [1]], # 89
110 |
111 | [-1, 1, DownC, [1280]], # 90-P6/64
112 | [-1, 1, Conv, [512, 1, 1]],
113 | [-2, 1, Conv, [512, 1, 1]],
114 | [-1, 1, Conv, [512, 3, 1]],
115 | [-1, 1, Conv, [512, 3, 1]],
116 | [-1, 1, Conv, [512, 3, 1]],
117 | [-1, 1, Conv, [512, 3, 1]],
118 | [-1, 1, Conv, [512, 3, 1]],
119 | [-1, 1, Conv, [512, 3, 1]],
120 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
121 | [-1, 1, Conv, [1280, 1, 1]], # 100
122 | [-11, 1, Conv, [512, 1, 1]],
123 | [-12, 1, Conv, [512, 1, 1]],
124 | [-1, 1, Conv, [512, 3, 1]],
125 | [-1, 1, Conv, [512, 3, 1]],
126 | [-1, 1, Conv, [512, 3, 1]],
127 | [-1, 1, Conv, [512, 3, 1]],
128 | [-1, 1, Conv, [512, 3, 1]],
129 | [-1, 1, Conv, [512, 3, 1]],
130 | [[-1, -3, -5, -7, -8], 1, Concat, [1]],
131 | [-1, 1, Conv, [1280, 1, 1]], # 110
132 | [[-1, -11], 1, Shortcut, [1]], # 111
133 | ]
134 |
135 | # yolov7 head
136 | head:
137 | [[-1, 1, SPPCSPC, [640]], # 112
138 |
139 | [-1, 1, Conv, [480, 1, 1]],
140 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
141 | [89, 1, Conv, [480, 1, 1]], # route backbone P5
142 | [[-1, -2], 1, Concat, [1]],
143 |
144 | [-1, 1, Conv, [384, 1, 1]],
145 | [-2, 1, Conv, [384, 1, 1]],
146 | [-1, 1, Conv, [192, 3, 1]],
147 | [-1, 1, Conv, [192, 3, 1]],
148 | [-1, 1, Conv, [192, 3, 1]],
149 | [-1, 1, Conv, [192, 3, 1]],
150 | [-1, 1, Conv, [192, 3, 1]],
151 | [-1, 1, Conv, [192, 3, 1]],
152 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
153 | [-1, 1, Conv, [480, 1, 1]], # 126
154 | [-11, 1, Conv, [384, 1, 1]],
155 | [-12, 1, Conv, [384, 1, 1]],
156 | [-1, 1, Conv, [192, 3, 1]],
157 | [-1, 1, Conv, [192, 3, 1]],
158 | [-1, 1, Conv, [192, 3, 1]],
159 | [-1, 1, Conv, [192, 3, 1]],
160 | [-1, 1, Conv, [192, 3, 1]],
161 | [-1, 1, Conv, [192, 3, 1]],
162 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
163 | [-1, 1, Conv, [480, 1, 1]], # 136
164 | [[-1, -11], 1, Shortcut, [1]], # 137
165 |
166 | [-1, 1, Conv, [320, 1, 1]],
167 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
168 | [67, 1, Conv, [320, 1, 1]], # route backbone P4
169 | [[-1, -2], 1, Concat, [1]],
170 |
171 | [-1, 1, Conv, [256, 1, 1]],
172 | [-2, 1, Conv, [256, 1, 1]],
173 | [-1, 1, Conv, [128, 3, 1]],
174 | [-1, 1, Conv, [128, 3, 1]],
175 | [-1, 1, Conv, [128, 3, 1]],
176 | [-1, 1, Conv, [128, 3, 1]],
177 | [-1, 1, Conv, [128, 3, 1]],
178 | [-1, 1, Conv, [128, 3, 1]],
179 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
180 | [-1, 1, Conv, [320, 1, 1]], # 151
181 | [-11, 1, Conv, [256, 1, 1]],
182 | [-12, 1, Conv, [256, 1, 1]],
183 | [-1, 1, Conv, [128, 3, 1]],
184 | [-1, 1, Conv, [128, 3, 1]],
185 | [-1, 1, Conv, [128, 3, 1]],
186 | [-1, 1, Conv, [128, 3, 1]],
187 | [-1, 1, Conv, [128, 3, 1]],
188 | [-1, 1, Conv, [128, 3, 1]],
189 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
190 | [-1, 1, Conv, [320, 1, 1]], # 161
191 | [[-1, -11], 1, Shortcut, [1]], # 162
192 |
193 | [-1, 1, Conv, [160, 1, 1]],
194 | [-1, 1, nn.Upsample, [None, 2, 'nearest']],
195 | [45, 1, Conv, [160, 1, 1]], # route backbone P3
196 | [[-1, -2], 1, Concat, [1]],
197 |
198 | [-1, 1, Conv, [128, 1, 1]],
199 | [-2, 1, Conv, [128, 1, 1]],
200 | [-1, 1, Conv, [64, 3, 1]],
201 | [-1, 1, Conv, [64, 3, 1]],
202 | [-1, 1, Conv, [64, 3, 1]],
203 | [-1, 1, Conv, [64, 3, 1]],
204 | [-1, 1, Conv, [64, 3, 1]],
205 | [-1, 1, Conv, [64, 3, 1]],
206 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
207 | [-1, 1, Conv, [160, 1, 1]], # 176
208 | [-11, 1, Conv, [128, 1, 1]],
209 | [-12, 1, Conv, [128, 1, 1]],
210 | [-1, 1, Conv, [64, 3, 1]],
211 | [-1, 1, Conv, [64, 3, 1]],
212 | [-1, 1, Conv, [64, 3, 1]],
213 | [-1, 1, Conv, [64, 3, 1]],
214 | [-1, 1, Conv, [64, 3, 1]],
215 | [-1, 1, Conv, [64, 3, 1]],
216 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
217 | [-1, 1, Conv, [160, 1, 1]], # 186
218 | [[-1, -11], 1, Shortcut, [1]], # 187
219 |
220 | [-1, 1, DownC, [320]],
221 | [[-1, 162], 1, Concat, [1]],
222 |
223 | [-1, 1, Conv, [256, 1, 1]],
224 | [-2, 1, Conv, [256, 1, 1]],
225 | [-1, 1, Conv, [128, 3, 1]],
226 | [-1, 1, Conv, [128, 3, 1]],
227 | [-1, 1, Conv, [128, 3, 1]],
228 | [-1, 1, Conv, [128, 3, 1]],
229 | [-1, 1, Conv, [128, 3, 1]],
230 | [-1, 1, Conv, [128, 3, 1]],
231 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
232 | [-1, 1, Conv, [320, 1, 1]], # 199
233 | [-11, 1, Conv, [256, 1, 1]],
234 | [-12, 1, Conv, [256, 1, 1]],
235 | [-1, 1, Conv, [128, 3, 1]],
236 | [-1, 1, Conv, [128, 3, 1]],
237 | [-1, 1, Conv, [128, 3, 1]],
238 | [-1, 1, Conv, [128, 3, 1]],
239 | [-1, 1, Conv, [128, 3, 1]],
240 | [-1, 1, Conv, [128, 3, 1]],
241 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
242 | [-1, 1, Conv, [320, 1, 1]], # 209
243 | [[-1, -11], 1, Shortcut, [1]], # 210
244 |
245 | [-1, 1, DownC, [480]],
246 | [[-1, 137], 1, Concat, [1]],
247 |
248 | [-1, 1, Conv, [384, 1, 1]],
249 | [-2, 1, Conv, [384, 1, 1]],
250 | [-1, 1, Conv, [192, 3, 1]],
251 | [-1, 1, Conv, [192, 3, 1]],
252 | [-1, 1, Conv, [192, 3, 1]],
253 | [-1, 1, Conv, [192, 3, 1]],
254 | [-1, 1, Conv, [192, 3, 1]],
255 | [-1, 1, Conv, [192, 3, 1]],
256 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
257 | [-1, 1, Conv, [480, 1, 1]], # 222
258 | [-11, 1, Conv, [384, 1, 1]],
259 | [-12, 1, Conv, [384, 1, 1]],
260 | [-1, 1, Conv, [192, 3, 1]],
261 | [-1, 1, Conv, [192, 3, 1]],
262 | [-1, 1, Conv, [192, 3, 1]],
263 | [-1, 1, Conv, [192, 3, 1]],
264 | [-1, 1, Conv, [192, 3, 1]],
265 | [-1, 1, Conv, [192, 3, 1]],
266 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
267 | [-1, 1, Conv, [480, 1, 1]], # 232
268 | [[-1, -11], 1, Shortcut, [1]], # 233
269 |
270 | [-1, 1, DownC, [640]],
271 | [[-1, 112], 1, Concat, [1]],
272 |
273 | [-1, 1, Conv, [512, 1, 1]],
274 | [-2, 1, Conv, [512, 1, 1]],
275 | [-1, 1, Conv, [256, 3, 1]],
276 | [-1, 1, Conv, [256, 3, 1]],
277 | [-1, 1, Conv, [256, 3, 1]],
278 | [-1, 1, Conv, [256, 3, 1]],
279 | [-1, 1, Conv, [256, 3, 1]],
280 | [-1, 1, Conv, [256, 3, 1]],
281 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
282 | [-1, 1, Conv, [640, 1, 1]], # 245
283 | [-11, 1, Conv, [512, 1, 1]],
284 | [-12, 1, Conv, [512, 1, 1]],
285 | [-1, 1, Conv, [256, 3, 1]],
286 | [-1, 1, Conv, [256, 3, 1]],
287 | [-1, 1, Conv, [256, 3, 1]],
288 | [-1, 1, Conv, [256, 3, 1]],
289 | [-1, 1, Conv, [256, 3, 1]],
290 | [-1, 1, Conv, [256, 3, 1]],
291 | [[-1, -2, -3, -4, -5, -6, -7, -8], 1, Concat, [1]],
292 | [-1, 1, Conv, [640, 1, 1]], # 255
293 | [[-1, -11], 1, Shortcut, [1]], # 256
294 |
295 | [187, 1, Conv, [320, 3, 1]],
296 | [210, 1, Conv, [640, 3, 1]],
297 | [233, 1, Conv, [960, 3, 1]],
298 | [256, 1, Conv, [1280, 3, 1]],
299 |
300 | [186, 1, Conv, [320, 3, 1]],
301 | [161, 1, Conv, [640, 3, 1]],
302 | [136, 1, Conv, [960, 3, 1]],
303 | [112, 1, Conv, [1280, 3, 1]],
304 |
305 | [[257,258,259,260,261,262,263,264], 1, IAuxDetect, [nc, anchors]], # Detect(P3, P4, P5, P6)
306 | ]
307 |
--------------------------------------------------------------------------------
/models/experimental.py:
--------------------------------------------------------------------------------
1 | import numpy as np
2 | import random
3 | import torch
4 | import torch.nn as nn
5 |
6 | from models.common import Conv, DWConv
7 | from utils.google_utils import attempt_download
8 |
9 |
10 | class CrossConv(nn.Module):
11 | # Cross Convolution Downsample
12 | def __init__(self, c1, c2, k=3, s=1, g=1, e=1.0, shortcut=False):
13 | # ch_in, ch_out, kernel, stride, groups, expansion, shortcut
14 | super(CrossConv, self).__init__()
15 | c_ = int(c2 * e) # hidden channels
16 | self.cv1 = Conv(c1, c_, (1, k), (1, s))
17 | self.cv2 = Conv(c_, c2, (k, 1), (s, 1), g=g)
18 | self.add = shortcut and c1 == c2
19 |
20 | def forward(self, x):
21 | return x + self.cv2(self.cv1(x)) if self.add else self.cv2(self.cv1(x))
22 |
23 |
24 | class Sum(nn.Module):
25 | # Weighted sum of 2 or more layers https://arxiv.org/abs/1911.09070
26 | def __init__(self, n, weight=False): # n: number of inputs
27 | super(Sum, self).__init__()
28 | self.weight = weight # apply weights boolean
29 | self.iter = range(n - 1) # iter object
30 | if weight:
31 | self.w = nn.Parameter(-torch.arange(1., n) / 2, requires_grad=True) # layer weights
32 |
33 | def forward(self, x):
34 | y = x[0] # no weight
35 | if self.weight:
36 | w = torch.sigmoid(self.w) * 2
37 | for i in self.iter:
38 | y = y + x[i + 1] * w[i]
39 | else:
40 | for i in self.iter:
41 | y = y + x[i + 1]
42 | return y
43 |
44 |
45 | class MixConv2d(nn.Module):
46 | # Mixed Depthwise Conv https://arxiv.org/abs/1907.09595
47 | def __init__(self, c1, c2, k=(1, 3), s=1, equal_ch=True):
48 | super(MixConv2d, self).__init__()
49 | groups = len(k)
50 | if equal_ch: # equal c_ per group
51 | i = torch.linspace(0, groups - 1E-6, c2).floor() # c2 indices
52 | c_ = [(i == g).sum() for g in range(groups)] # intermediate channels
53 | else: # equal weight.numel() per group
54 | b = [c2] + [0] * groups
55 | a = np.eye(groups + 1, groups, k=-1)
56 | a -= np.roll(a, 1, axis=1)
57 | a *= np.array(k) ** 2
58 | a[0] = 1
59 | c_ = np.linalg.lstsq(a, b, rcond=None)[0].round() # solve for equal weight indices, ax = b
60 |
61 | self.m = nn.ModuleList([nn.Conv2d(c1, int(c_[g]), k[g], s, k[g] // 2, bias=False) for g in range(groups)])
62 | self.bn = nn.BatchNorm2d(c2)
63 | self.act = nn.LeakyReLU(0.1, inplace=True)
64 |
65 | def forward(self, x):
66 | return x + self.act(self.bn(torch.cat([m(x) for m in self.m], 1)))
67 |
68 |
69 | class Ensemble(nn.ModuleList):
70 | # Ensemble of models
71 | def __init__(self):
72 | super(Ensemble, self).__init__()
73 |
74 | def forward(self, x, augment=False):
75 | y = []
76 | for module in self:
77 | y.append(module(x, augment)[0])
78 | # y = torch.stack(y).max(0)[0] # max ensemble
79 | # y = torch.stack(y).mean(0) # mean ensemble
80 | y = torch.cat(y, 1) # nms ensemble
81 | return y, None # inference, train output
82 |
83 |
84 |
85 |
86 |
87 | class ORT_NMS(torch.autograd.Function):
88 | '''ONNX-Runtime NMS operation'''
89 | @staticmethod
90 | def forward(ctx,
91 | boxes,
92 | scores,
93 | max_output_boxes_per_class=torch.tensor([100]),
94 | iou_threshold=torch.tensor([0.45]),
95 | score_threshold=torch.tensor([0.25])):
96 | device = boxes.device
97 | batch = scores.shape[0]
98 | num_det = random.randint(0, 100)
99 | batches = torch.randint(0, batch, (num_det,)).sort()[0].to(device)
100 | idxs = torch.arange(100, 100 + num_det).to(device)
101 | zeros = torch.zeros((num_det,), dtype=torch.int64).to(device)
102 | selected_indices = torch.cat([batches[None], zeros[None], idxs[None]], 0).T.contiguous()
103 | selected_indices = selected_indices.to(torch.int64)
104 | return selected_indices
105 |
106 | @staticmethod
107 | def symbolic(g, boxes, scores, max_output_boxes_per_class, iou_threshold, score_threshold):
108 | return g.op("NonMaxSuppression", boxes, scores, max_output_boxes_per_class, iou_threshold, score_threshold)
109 |
110 |
111 | class TRT_NMS(torch.autograd.Function):
112 | '''TensorRT NMS operation'''
113 | @staticmethod
114 | def forward(
115 | ctx,
116 | boxes,
117 | scores,
118 | background_class=-1,
119 | box_coding=1,
120 | iou_threshold=0.45,
121 | max_output_boxes=100,
122 | plugin_version="1",
123 | score_activation=0,
124 | score_threshold=0.25,
125 | ):
126 | batch_size, num_boxes, num_classes = scores.shape
127 | num_det = torch.randint(0, max_output_boxes, (batch_size, 1), dtype=torch.int32)
128 | det_boxes = torch.randn(batch_size, max_output_boxes, 4)
129 | det_scores = torch.randn(batch_size, max_output_boxes)
130 | det_classes = torch.randint(0, num_classes, (batch_size, max_output_boxes), dtype=torch.int32)
131 | return num_det, det_boxes, det_scores, det_classes
132 |
133 | @staticmethod
134 | def symbolic(g,
135 | boxes,
136 | scores,
137 | background_class=-1,
138 | box_coding=1,
139 | iou_threshold=0.45,
140 | max_output_boxes=100,
141 | plugin_version="1",
142 | score_activation=0,
143 | score_threshold=0.25):
144 | out = g.op("TRT::EfficientNMS_TRT",
145 | boxes,
146 | scores,
147 | background_class_i=background_class,
148 | box_coding_i=box_coding,
149 | iou_threshold_f=iou_threshold,
150 | max_output_boxes_i=max_output_boxes,
151 | plugin_version_s=plugin_version,
152 | score_activation_i=score_activation,
153 | score_threshold_f=score_threshold,
154 | outputs=4)
155 | nums, boxes, scores, classes = out
156 | return nums, boxes, scores, classes
157 |
158 |
159 | class ONNX_ORT(nn.Module):
160 | '''onnx module with ONNX-Runtime NMS operation.'''
161 | def __init__(self, max_obj=100, iou_thres=0.45, score_thres=0.25, max_wh=640, device=None):
162 | super().__init__()
163 | self.device = device if device else torch.device("cpu")
164 | self.max_obj = torch.tensor([max_obj]).to(device)
165 | self.iou_threshold = torch.tensor([iou_thres]).to(device)
166 | self.score_threshold = torch.tensor([score_thres]).to(device)
167 | self.max_wh = max_wh # if max_wh != 0 : non-agnostic else : agnostic
168 | self.convert_matrix = torch.tensor([[1, 0, 1, 0], [0, 1, 0, 1], [-0.5, 0, 0.5, 0], [0, -0.5, 0, 0.5]],
169 | dtype=torch.float32,
170 | device=self.device)
171 |
172 | def forward(self, x):
173 | boxes = x[:, :, :4]
174 | conf = x[:, :, 4:5]
175 | scores = x[:, :, 5:]
176 | scores *= conf
177 | boxes @= self.convert_matrix
178 | max_score, category_id = scores.max(2, keepdim=True)
179 | dis = category_id.float() * self.max_wh
180 | nmsbox = boxes + dis
181 | max_score_tp = max_score.transpose(1, 2).contiguous()
182 | selected_indices = ORT_NMS.apply(nmsbox, max_score_tp, self.max_obj, self.iou_threshold, self.score_threshold)
183 | X, Y = selected_indices[:, 0], selected_indices[:, 2]
184 | selected_boxes = boxes[X, Y, :]
185 | selected_categories = category_id[X, Y, :].float()
186 | selected_scores = max_score[X, Y, :]
187 | X = X.unsqueeze(1).float()
188 | return torch.cat([X, selected_boxes, selected_categories, selected_scores], 1)
189 |
190 | class ONNX_TRT(nn.Module):
191 | '''onnx module with TensorRT NMS operation.'''
192 | def __init__(self, max_obj=100, iou_thres=0.45, score_thres=0.25, max_wh=None ,device=None):
193 | super().__init__()
194 | assert max_wh is None
195 | self.device = device if device else torch.device('cpu')
196 | self.background_class = -1,
197 | self.box_coding = 1,
198 | self.iou_threshold = iou_thres
199 | self.max_obj = max_obj
200 | self.plugin_version = '1'
201 | self.score_activation = 0
202 | self.score_threshold = score_thres
203 |
204 | def forward(self, x):
205 | boxes = x[:, :, :4]
206 | conf = x[:, :, 4:5]
207 | scores = x[:, :, 5:]
208 | scores *= conf
209 | num_det, det_boxes, det_scores, det_classes = TRT_NMS.apply(boxes, scores, self.background_class, self.box_coding,
210 | self.iou_threshold, self.max_obj,
211 | self.plugin_version, self.score_activation,
212 | self.score_threshold)
213 | return num_det, det_boxes, det_scores, det_classes
214 |
215 |
216 | class End2End(nn.Module):
217 | '''export onnx or tensorrt model with NMS operation.'''
218 | def __init__(self, model, max_obj=100, iou_thres=0.45, score_thres=0.25, max_wh=None, device=None):
219 | super().__init__()
220 | device = device if device else torch.device('cpu')
221 | assert isinstance(max_wh,(int)) or max_wh is None
222 | self.model = model.to(device)
223 | self.model.model[-1].end2end = True
224 | self.patch_model = ONNX_TRT if max_wh is None else ONNX_ORT
225 | self.end2end = self.patch_model(max_obj, iou_thres, score_thres, max_wh, device)
226 | self.end2end.eval()
227 |
228 | def forward(self, x):
229 | x = self.model(x)
230 | x = self.end2end(x)
231 | return x
232 |
233 |
234 |
235 |
236 |
237 | def attempt_load(weights, map_location=None):
238 | # Loads an ensemble of models weights=[a,b,c] or a single model weights=[a] or weights=a
239 | model = Ensemble()
240 | for w in weights if isinstance(weights, list) else [weights]:
241 | attempt_download(w)
242 | ckpt = torch.load(w, map_location=map_location) # load
243 | model.append(ckpt['ema' if ckpt.get('ema') else 'model'].float().fuse().eval()) # FP32 model
244 |
245 | # Compatibility updates
246 | for m in model.modules():
247 | if type(m) in [nn.Hardswish, nn.LeakyReLU, nn.ReLU, nn.ReLU6, nn.SiLU]:
248 | m.inplace = True # pytorch 1.7.0 compatibility
249 | elif type(m) is nn.Upsample:
250 | m.recompute_scale_factor = None # torch 1.11.0 compatibility
251 | elif type(m) is Conv:
252 | m._non_persistent_buffers_set = set() # pytorch 1.6.0 compatibility
253 |
254 | if len(model) == 1:
255 | return model[-1] # return model
256 | else:
257 | print('Ensemble created with %s\n' % weights)
258 | for k in ['names', 'stride']:
259 | setattr(model, k, getattr(model[-1], k))
260 | return model # return ensemble
261 |
262 |
263 |
--------------------------------------------------------------------------------