123 lines
7.5 KiB
Markdown
Raw Normal View History

# 数据集
- [数据集](#数据集)
- [数据集](#数据集-1)
- [重构个人数据集](#重构个人数据集)
- [在个人 Config 中调用 OpenMMLab 其他代码库的数据集](#在个人-config-中调用-openmmlab-其他代码库的数据集)
- [采样器](#采样器)
- [数据变换](#数据变换)
`mmselfsup` 算法库中的 `datasets` 文件夹包罗了各种与数据加载相关的模块文件。
此文件夹主要分为如下三个部分:
- 自定义数据集,用于图像读取与加载
- 自定义数据集采样器,用于图像加载之前进行索引的读取
- 数据变换工具,用于在数据输入模型之前进行数据增强,如 `RandomResizedCrop`
在本教程中,我们将对三个部分依次进行较为详尽的解释。
## 数据集
OpenMMLab 开源算法体系为用户提供了海量开箱即用的数据集,这些数据集都与 [BaseDataset](https://github.com/open-mmlab/mmengine/blob/429bb27972bee1a9f3095a4d5f6ac5c0b88ccf54/mmengine/dataset/base_dataset.py#L116) 一脉相承,
并在 [MMEngine](https://github.com/open-mmlab/mmengine) 中得以实现。 如想进一步了解 `BaseDataset` 中的各项功能,感兴趣的用户可以参考 [MMEngine](https://mmengine.readthedocs.io/en/latest/advanced_tutorials/basedataset.html) 中的文档。对于 `MMSelfSup` `ImageNet``ADE20KDataset``CocoDataset` 是三个较为常用的数据集。 在起步之前,用户需要对文件夹进行一些前置的重构工作,具体指南如下所述。
### 重构个人数据集
万事俱备,只欠东风。使用准备好的这些数据集,用户需要将数据集重构为如下格式。
```
mmselfsup
├── mmselfsup
├── tools
├── configs
├── docs
├── data
│ ├── imagenet
│ │ ├── meta
│ │ ├── train
│ │ ├── val
│ │
│ │── ade
│ │ ├── ADEChallengeData2016
│ │ │ ├── annotations
│ │ │ │ ├── training
│ │ │ │ ├── validation
│ │ │ ├── images
│ │ │ │ ├── training
│ │ │ │ ├── validation
│ │
│ │── coco
│ │ ├── annotations
│ │ ├── train2017
│ │ ├── val2017
│ │ ├── test2017
```
更为详尽的注释文件以及各子文件夹的结构,可以参考 OpenMMLab 的其他代码库,如 [MMClassfication](https://github.com/open-mmlab/mmclassification),
[MMSegmentation](https://github.com/open-mmlab/mmsegmentation) 和 [MMDetection](https://github.com/open-mmlab/mmdetection).
### 在个人 Config 中调用 OpenMMLab 其他代码库的数据集
```python
# 调用 MMClassification 中的 ImageNet 数据集
# 在数据加载器中调用 ImageNet
# 为简单起见,我们只提供与从 MMClassification 导入 ImageNet 的相关 config
# 而不是数据加载器的全量的 config
# ``mmcls`` 前缀传达给 ``Registry`` 需要在 MMClassification 中搜索 ``ImageNet``
train_dataloader=dict(dataset=dict(type='mmcls.ImageNet', ...), ...)
```
```python
# 调用 MMSegmentation 中的 ADE20KDataset 数据集
# 在数据加载器中使用 ADE20KDataset
# 为简单起见,我们只提供与从 MMSegmentation 导入 ADE20KDataset 的相关 config
# 而不是数据加载器的全量的 config
# ``mmseg`` 前缀传达给 ``Registry`` 需要在 MMSegmentation 中搜索 ``ADE20KDataset``
train_dataloader=dict(dataset=dict(type='mmseg.ADE20KDataset', ...), ...)
```
```python
# 在数据加载器中调用 CocoDataset
# 为简单起见,我们只提供与从 MMDetection 导入 CocoDataset 的相关 config
# 而不是数据加载器的全量的 config
# ``mmdet`` 前缀传达给 ``Registry`` 需要在 MMDetection 中搜索 ``CocoDataset``
train_dataloader=dict(dataset=dict(type='mmdet.CocoDataset', ...), ...)
```
```python
# 在 MMSelfSup 中调用数据集,如 ``DeepClusterImageNet``
train_dataloader=dict(dataset=dict(type='DeepClusterImageNet', ...), ...)
```
通过上文,我们介绍了调用数据集的两个关键的步骤,希望用户可以掌握如何在 MMSelfSup 中使用数据集的相关基本概念。 如果用户有创建自定义数据集的意愿,可参考文档 [add_datasets](./add_datasets.md)。
## 采样器
在 pytorch 中,`Sampler` 用于在加载之前对数据的索引进行采样。 `MMEngine` 中已经实现和开源了 `DefaultSampler`
`InfiniteSampler`。 大多数情况下,我们可以直接调用,无需手动去实现自定义采样器。 然而 `DeepClusterSampler` 是一个值得一提的特例,因为其中纳入了进行唯一索引采样的逻辑, 因此,如果用户想对此采样器的相关信息一览无遗,则可进一步参考我们的 API 文档。 如果你有自行实现自定义采样器的更进一步的想法,同样可以参考 `DeepClusterSampler``samplers` 文件夹进行实现。
## 数据变换
简而言之,`transform` 是指 `MM-repos` 中的数据变换模块,我们将一系列的 transform 组合成了一个列表,即 `pipeline`
`MMCV` 中已经完善了一些涵盖大多数场景的变换, 此外,每个 `MM-repo` 也都遵循 MMCV 中的 [用户指南](https://github.com/open-mmlab/mmcv/blob/dev-2.x/docs/zh_cn/understand_mmcv/data_transform.md) 定义了自己的变换。 实操而言每个自定义的数据集需要i) 继承 [BaseTransform](https://github.com/open-mmlab/mmcv/blob/19a024155a0b710568c2faeae07dead2a5550392/mmcv/transforms/base.py#L6)
ii) 覆盖 `transform` 函数并在其中实现自行设计的关键逻辑。 在 MMSelfSup 中,我们已经实现了如下这些变换:
| class |
| :-------------------------------------------------------------------------------------------------------------: |
| [`PackSelfSupInputs`](mmselfsup.datasets.PackSelfSupInputs) |
| [`BEiTMaskGenerator`](mmselfsup.datasets.BEiTMaskGenerator) |
| [`SimMIMMaskGenerator`](mmselfsup.datasets.SimMIMMaskGenerator) |
| [`ColorJitter`](mmselfsup.datasets.ColorJitter) |
| [`RandomCrop`](mmselfsup.datasets.RandomCrop) |
| [`RandomGaussianBlur`](mmselfsup.datasets.RandomGaussianBlur) |
| [`RandomResizedCrop`](mmselfsup.datasets.RandomResizedCrop) |
| [`RandomResizedCropAndInterpolationWithTwoPic`](mmselfsup.datasets.RandomResizedCropAndInterpolationWithTwoPic) |
| [`RandomSolarize`](mmselfsup.datasets.RandomSolarize) |
| [`RotationWithLabels`](mmselfsup.datasets.RotationWithLabels) |
| [`RandomPatchWithLabels`](mmselfsup.datasets.RandomPatchWithLabels) |
| [`RandomRotation`](mmselfsup.datasets.RandomRotation) |
对于感兴趣的社区用户,可以参考 API 文档以更为全面了解这些转换。目前为止, 我们已经初步介绍了关于转换的基本概念,
若想进一步了解如何在个人的 config 中使用它们或实现自定义转换,
可以参考文档 [transforms](./transforms.md) 和 [add_transforms](./add_transforms.md).