mmyolo/docs/zh_cn/recommended_topics/dataset_preparation.md

145 lines
4.6 KiB
Markdown
Raw Normal View History

# 数据集格式准备和说明
## DOTA 数据集
### 下载 DOTA 数据集
数据集可以从 DOTA 数据集的主页 [DOTA](https://captain-whu.github.io/DOTA/dataset.html)
或 [OpenDataLab](https://opendatalab.org.cn/DOTA_V1.0) 下载。
我们推荐使用 [OpenDataLab](https://opendatalab.org.cn/DOTA_V1.0) 下载,其中的文件夹结构已经按照需要排列好了,只需要解压即可,不需要费心去调整文件夹结构。
下载后解压数据集,并按如下文件夹结构存放。
```none
${DATA_ROOT}
├── train
│ ├── images
│ │ ├── P0000.png
│ │ ├── ...
│ ├── labelTxt-v1.0
│ │ ├── labelTxt
│ │ │ ├── P0000.txt
│ │ │ ├── ...
│ │ ├── trainset_reclabelTxt
│ │ │ ├── P0000.txt
│ │ │ ├── ...
├── val
│ ├── images
│ │ ├── P0003.png
│ │ ├── ...
│ ├── labelTxt-v1.0
│ │ ├── labelTxt
│ │ │ ├── P0003.txt
│ │ │ ├── ...
│ │ ├── valset_reclabelTxt
│ │ │ ├── P0003.txt
│ │ │ ├── ...
├── test
│ ├── images
│ │ ├── P0006.png
│ │ ├── ...
```
其中,以 `reclabelTxt` 为结尾的文件夹存放了水平检测框的标注,目前仅使用了 `labelTxt-v1.0` 中旋转框的标注。
### 数据集切片
我们提供了 `tools/dataset_converters/dota/dota_split.py` 脚本用于 DOTA 数据集的准备和切片。
```shell
python tools/dataset_converters/dota/dota_split.py \
[--splt-config ${SPLIT_CONFIG}] \
[--data-root ${DATA_ROOT}] \
[--out-dir ${OUT_DIR}] \
[--ann-subdir ${ANN_SUBDIR}] \
[--phase ${DATASET_PHASE}] \
[--nproc ${NPROC}] \
[--save-ext ${SAVE_EXT}] \
[--overwrite]
```
脚本依赖于 shapely 包,请先通过 `pip install shapely` 安装 shapely。
**参数说明**
- `--splt-config` : 切片参数的配置文件。
- `--data-root`: DOTA 数据集的存放位置。
- `--out-dir`: 切片后的输出位置。
- `--ann-subdir`: 标注文件夹的名字。 默认为 `labelTxt-v1.0`
- `--phase`: 数据集的阶段。默认为 `trainval test`
- `--nproc`: 进程数量。 默认为 8 。
- `--save-ext`: 输出图像的扩展名,如置空则与原图保持一致。 默认为 `None`
- `--overwrite`: 如果目标文件夹已存在,是否允许覆盖。
基于 DOTA 数据集论文中提供的配置,我们提供了两种切片配置。
`./split_config/single_scale.json` 用于单尺度 `single-scale` 切片
`./split_config/multi_scale.json` 用于多尺度 `multi-scale` 切片
DOTA 数据集通常使用 `trainval` 集进行训练,然后使用 `test` 集进行在线验证,大多数论文提供的也是在线验证的精度。
如果你需要进行本地验证,可以准备 `train` 集和 `val` 集进行训练和测试。
示例:
使用单尺度切片配置准备 `trainval``test`
```shell
python tools/dataset_converters/dota/dota_split.py
--split-config 'tools/dataset_converters/dota/split_config/single_scale.json'
--data-root ${DATA_ROOT} \
--out-dir ${OUT_DIR}
```
准备 DOTA-v1.5 数据集,它的标注文件夹名字是 `labelTxt-v1.5`
```shell
python tools/dataset_converters/dota/dota_split.py
--split-config 'tools/dataset_converters/dota/split_config/single_scale.json'
--data-root ${DATA_ROOT} \
--out-dir ${OUT_DIR} \
--ann-subdir 'labelTxt-v1.5'
```
使用单尺度切片配置准备 `train``val`
```shell
python tools/dataset_converters/dota/dota_split.py
--split-config 'tools/dataset_converters/dota/split_config/single_scale.json'
--data-root ${DATA_ROOT} \
--phase train val \
--out-dir ${OUT_DIR}
```
使用多尺度切片配置准备 `trainval``test`
```shell
python tools/dataset_converters/dota/dota_split.py
--split-config 'tools/dataset_converters/dota/split_config/multi_scale.json'
--data-root ${DATA_ROOT} \
--out-dir ${OUT_DIR}
```
在运行完成后,输出的结构如下:
```none
${OUT_DIR}
├── trainval
│ ├── images
│ │ ├── P0000__1024__0___0.png
│ │ ├── ...
│ ├── annfiles
│ │ ├── P0000__1024__0___0.txt
│ │ ├── ...
├── test
│ ├── images
│ │ ├── P0006__1024__0___0.png
│ │ ├── ...
│ ├── annfiles
│ │ ├── P0006__1024__0___0.txt
│ │ ├── ...
```
此时将配置文件中的 `data_root` 修改为 ${OUT_DIR} 即可开始使用 DOTA 数据集训练。