Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create 2_new_data_model.md #6476

Merged
merged 2 commits into from
Feb 13, 2022
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 11 additions & 9 deletions docs/zh_cn/2_new_data_model.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,17 +4,17 @@

基本步骤如下:

1. 准备自定义数据集
2. 准备配置文件
3. 在自定义数据集上进行训练,测试和推理。
1. 准备自定义数据集
2. 准备配置文件
3. 在自定义数据集上进行训练,测试和推理。

## 准备自定义数据集

MMDetection 一共支持三种形式应用新数据集:

1. 将数据集重新组织为 COCO 格式。
2. 将数据集重新组织为一个中间格式。
3. 实现一个新的数据集。
1. 将数据集重新组织为 COCO 格式。
2. 将数据集重新组织为一个中间格式。
3. 实现一个新的数据集。

我们通常建议使用前面两种方法,因为它们通常来说比第三种方法要简单。

Expand All @@ -27,6 +27,7 @@ MMDetection 一共支持三种形式应用新数据集:
### COCO标注格式

用于实例分割的 COCO 数据集格式如下所示,其中的键(key)都是必要的,参考[这里](https://cocodataset.org/#format-data)来获取更多细节。

```json
{
"images": [image],
Expand Down Expand Up @@ -58,6 +59,7 @@ categories = [{
"supercategory": str,
}]
```

现在假设我们使用 balloon dataset。

下载了数据集之后,我们需要实现一个函数将标注格式转化为 COCO 格式。然后我们就可以使用已经实现的 `COCODataset` 类来加载数据并进行训练以及评测。
Expand Down Expand Up @@ -147,6 +149,7 @@ categories = [{
'name': 'polygon'}}},
'size': 1115004}
```

标注文件时是 JSON 格式的,其中所有键(key)组成了一张图片的所有标注。

其中将 balloon dataset 转化为 COCO 格式的代码如下所示。
Expand Down Expand Up @@ -204,14 +207,13 @@ def convert_balloon_to_coco(ann_file, out_file, image_prefix):
annotations=annotations,
categories=[{'id':0, 'name': 'balloon'}])
mmcv.dump(coco_format_json, out_file)

```

使用如上的函数,用户可以成功将标注文件转化为 JSON 格式,之后可以使用 `CocoDataset` 对模型进行训练和评测。

## 准备配置文件

第二步需要准备一个配置文件来成功加载数据集。假设我们想要用 balloon dataset 来训练配备了 FPN 的 Mask R-CNN ,如下是我们的配置文件。假设配置文件命名为 `mask_rcnn_r50_caffe_fpn_mstrain-poly_1x_balloon.py`,相应保存路径为 `configs/ballon/`,配置文件内容如下所示。
第二步需要准备一个配置文件来成功加载数据集。假设我们想要用 balloon dataset 来训练配备了 FPN 的 Mask R-CNN ,如下是我们的配置文件。假设配置文件命名为 `mask_rcnn_r50_caffe_fpn_mstrain-poly_1x_balloon.py`,相应保存路径为 `configs/balloon/`,配置文件内容如下所示。

```python
# 这个新的配置文件继承自一个原始配置文件,只需要突出必要的修改部分即可
Expand All @@ -224,7 +226,7 @@ model = dict(
mask_head=dict(num_classes=1)))

# 修改数据集相关设置
dataset_type = 'COCODataset'
dataset_type = 'CocoDataset'
classes = ('balloon',)
data = dict(
train=dict(
Expand Down