pytorch_object_detection/retinaNet/README.md
pip install pycocotools; Windows:pip install pycocotools-windows(不需要额外安装vs))requirements.txt ├── backbone: 特征提取网络(ResNet50+FPN)
├── network_files: RetinaNet网络
├── train_utils: 训练验证相关模块(包括cocotools)
├── my_dataset.py: 自定义dataset用于读取VOC数据集
├── train.py: 以resnet50+FPN做为backbone进行训练
├── train_multi_GPU.py: 针对使用多GPU的用户使用
├── predict.py: 简易的预测脚本,使用训练好的权重进行预测测试
├── validation.py: 利用训练好的权重验证/测试数据的COCO指标,并生成record_mAP.txt文件
└── pascal_voc_classes.json: pascal_voc标签文件(注意索引从0开始,不包括背景)
retinanet_resnet50_fpn_coco.pth文件,
不是retinanet_resnet50_fpn_coco-eeacb38b.pth Average Precision (AP) @[ IoU=0.50:0.95 | area= all | maxDets=100 ] = 0.563
Average Precision (AP) @[ IoU=0.50 | area= all | maxDets=100 ] = 0.798
Average Precision (AP) @[ IoU=0.75 | area= all | maxDets=100 ] = 0.616
Average Precision (AP) @[ IoU=0.50:0.95 | area= small | maxDets=100 ] = 0.236
Average Precision (AP) @[ IoU=0.50:0.95 | area=medium | maxDets=100 ] = 0.434
Average Precision (AP) @[ IoU=0.50:0.95 | area= large | maxDets=100 ] = 0.626
Average Recall (AR) @[ IoU=0.50:0.95 | area= all | maxDets= 1 ] = 0.486
Average Recall (AR) @[ IoU=0.50:0.95 | area= all | maxDets= 10 ] = 0.688
Average Recall (AR) @[ IoU=0.50:0.95 | area= all | maxDets=100 ] = 0.707
Average Recall (AR) @[ IoU=0.50:0.95 | area= small | maxDets=100 ] = 0.421
Average Recall (AR) @[ IoU=0.50:0.95 | area=medium | maxDets=100 ] = 0.604
Average Recall (AR) @[ IoU=0.50:0.95 | area= large | maxDets=100 ] = 0.758
python -m torch.distributed.launch --nproc_per_node=8 --use_env train_multi_GPU.py指令,nproc_per_node参数为使用GPU数量CUDA_VISIBLE_DEVICES=0,3(例如我只要使用设备中的第1块和第4块GPU设备)CUDA_VISIBLE_DEVICES=0,3 python -m torch.distributed.launch --nproc_per_node=2 --use_env train_multi_GPU.py--data-path(VOC_root)设置为自己存放VOCdevkit文件夹所在的根目录results.txt是每个epoch在验证集上的COCO指标,前12个值是COCO指标,后面两个值是训练平均损失以及学习率weights_path设置为你自己生成的权重路径。--num-classes、--data-path和--weights-path即可,其他代码尽量不要改动