Skip to content

Commit ce0a6dd

Browse files
author
wz
committed
add readme
1 parent d1a165f commit ce0a6dd

File tree

1 file changed

+101
-0
lines changed

1 file changed

+101
-0
lines changed

pytorch_keypoint/HRNet/README.md

Lines changed: 101 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,101 @@
1+
# HRNet
2+
3+
## 该项目主要参考以下仓库
4+
* https://github.com/leoxiaobin/deep-high-resolution-net.pytorch
5+
* https://github.com/stefanopini/simple-HRNet
6+
7+
## 环境配置:
8+
* Python3.6/3.7/3.8
9+
* Pytorch1.10或以上
10+
* pycocotools(Linux:`pip install pycocotools`; Windows:`pip install pycocotools-windows`(不需要额外安装vs))
11+
* Ubuntu或Centos(不建议Windows)
12+
* 最好使用GPU训练
13+
* 详细环境配置见`requirements.txt`
14+
15+
## 文件结构:
16+
```
17+
├── model: 搭建HRNet相关代码
18+
├── train_utils: 训练验证相关模块(包括coco验证相关)
19+
├── my_dataset_coco.py: 自定义dataset用于读取COCO2017数据集
20+
├── train.py: 单GPU/CPU训练脚本
21+
├── train_multi_GPU.py: 针对使用多GPU的用户使用
22+
├── predict.py: 简易的预测脚本,使用训练好的权重进行预测
23+
├── validation.py: 利用训练好的权重验证/测试数据的COCO指标,并生成record_mAP.txt文件
24+
└── transforms.py: 数据增强相关
25+
```
26+
27+
## 预训练权重下载地址(下载后放入当前文件夹中):
28+
由于原作者提供的预训练权重(Imagenet和COCO)是放在GoogleDrive和OneDrive上的,国内无法正常访问。所有我提前将权重文件全部下载并放在百度网盘中,
29+
需要的可以自行下载,链接:https://pan.baidu.com/s/1Lu6mMAWfm_8GGykttFMpVw 提取码:f43o
30+
31+
下载后的目录结构如下:
32+
```
33+
├── pytorch
34+
├── pose_mpii
35+
├── pose_coco
36+
│ ├── pose_resnet_50_384x288.pth
37+
│ ├── pose_resnet_50_256x192.pth
38+
│ ├── pose_resnet_101_384x288.pth
39+
│ ├── pose_resnet_101_256x192.pth
40+
│ ├── pose_hrnet_w32_384x288.pth
41+
│ └── pose_hrnet_w32_256x192.pth
42+
└── imagenet
43+
├── resnet50-19c8e357.pth
44+
├── resnet152-b121ed2d.pth
45+
├── resnet101-5d3b4d8f.pth
46+
└── hrnet_w32-36af842e.pth
47+
```
48+
如果要直接使用在COCO数据集上预训练好的权重进行预测,下载pose_coco下的`pose_hrnet_w32_256x192.pth`使用即可。
49+
如果要从头训练网络,下载imagenet下的`hrnet_w32-36af842e.pth`文件,并重命名为`hrnet_w32.pth`即可。
50+
51+
除此之外,还有一个`person_detection_results`文件,存储的是论文中提到的人体检测器的检测结果,如果需要使用可以下载,但个人建议直接使用COCO val中GT信息即可。
52+
链接: https://pan.baidu.com/s/19Z4mmNHUD934GQ9QYcF5iw 密码: i08q
53+
54+
## 数据集,本例程使用的是COCO2017数据集
55+
* COCO官网地址:https://cocodataset.org/
56+
* 对数据集不了解的可以看下我写的博文:https://blog.csdn.net/qq_37541097/article/details/113247318
57+
* 这里以下载coco2017数据集为例,主要下载三个文件:
58+
* `2017 Train images [118K/18GB]`:训练过程中使用到的所有图像文件
59+
* `2017 Val images [5K/1GB]`:验证过程中使用到的所有图像文件
60+
* `2017 Train/Val annotations [241MB]`:对应训练集和验证集的标注json文件
61+
* 都解压到`coco2017`文件夹下,可得到如下文件夹结构:
62+
```
63+
├── coco2017: 数据集根目录
64+
├── train2017: 所有训练图像文件夹(118287张)
65+
├── val2017: 所有验证图像文件夹(5000张)
66+
└── annotations: 对应标注文件夹
67+
├── instances_train2017.json: 对应目标检测、分割任务的训练集标注文件
68+
├── instances_val2017.json: 对应目标检测、分割任务的验证集标注文件
69+
├── captions_train2017.json: 对应图像描述的训练集标注文件
70+
├── captions_val2017.json: 对应图像描述的验证集标注文件
71+
├── person_keypoints_train2017.json: 对应人体关键点检测的训练集标注文件
72+
└── person_keypoints_val2017.json: 对应人体关键点检测的验证集标注文件夹
73+
```
74+
75+
## 训练方法
76+
* 注:该项目从头训练HRNet在MS COCO2017的val上的mAP[@0.50:0.95]为76.1,利用原作者提供的权重在val上的mAP[@0.50:0.95]为76.6,相差0.5个点,
77+
暂时没有找到原因。由于训练该网络需要迭代210个epoch(按照论文中的数据),训练时间很长,建议直接使用原作者提供训练好的权重。另外,在训练过程中发现GPU的利用率
78+
并不高(在20%~60%之间浮动),暂时猜测是网络结构的原因。
79+
* 确保提前准备好数据集
80+
* 确保提前下载好对应预训练模型权重
81+
* 确保设置好`--num-joints`(对于人体检测的关键点个数,COCO是17个点)、`fixed-size`(输入目标图像的高宽,默认[256, 192])和`--data-path`(指向`coco2017`目录)
82+
* 若要使用单GPU训练直接使用train.py训练脚本
83+
* 若要使用多GPU训练,使用`torchrun --nproc_per_node=8 train_multi_GPU.py`指令,`nproc_per_node`参数为使用GPU数量
84+
* 如果想指定使用哪些GPU设备可在指令前加上`CUDA_VISIBLE_DEVICES=0,3`(例如我只要使用设备中的第1块和第4块GPU设备)
85+
* `CUDA_VISIBLE_DEVICES=0,3 torchrun --nproc_per_node=2 train_multi_GPU.py`
86+
87+
## 注意事项
88+
1. 在使用训练脚本时,注意要将`--data-path`设置为自己存放数据集的**根目录**
89+
假设要使用COCO数据集,启用自定义数据集读取CocoDetection并将数据集解压到成/data/coco2017目录下
90+
```
91+
python train.py --data-path /data/coco2017
92+
```
93+
2. 训练过程中保存的`key_results.txt`是每个epoch在验证集上的COCO指标,前10个值是COCO指标,后面两个值是训练平均损失以及学习率
94+
3. 在使用预测脚本时,如果要读取自己训练好的权重要将`weights_path`设置为你自己生成的权重路径。
95+
96+
97+
## 如果对Mask RCNN原理不是很理解可参考我的bilibili
98+
https://www.bilibili.com/video/BV1bB4y1y7qP
99+
100+
## HRNet网络结构图
101+
![HRNet.png](HRNet.png)

0 commit comments

Comments
 (0)