mmdetection之pipeline

这里的pipeline指的是从dataset类中加载数据时,对数据做的一系列流水线操作。

调用顺序

首先来分析一下涉及到的一系列函数的调用顺序。
CustomDataset类是mmdetection中所有dataset类的基类,继承了pytorch中的Dataset类。继承Dataset类时,我们需要重写__getitem__函数,用于从磁盘中加载数据。
CustomDataset类中的__getitem__函数根据是否为test_mode,来决定调用prepare_test_img()还是prepare_train_img(),这两个函数分别用来准备测试数据和训练数据,关于dataset部分会单独讲解,这里就不过多介绍了。
prepare_train_img()函数中,我们注意返回值语句。

return self.pipeline(results)

从这里开始,就正式进入了pipeline的流程。
pipeline中的各个操作需要在dataset的配置文件中进行定义。

train_pipeline = [
    dict(type='LoadImageFromFile'),
    dict(type='LoadAnnotations', with_bbox=True),
    dict(type='Resize', img_scale=(1000, 600), keep_ratio=True),
    dict(type='RandomFlip', flip_ratio=0.5),
    dict(type='Normalize', **img_norm_cfg),
    dict(type='Pad', size_divisor=32),
    dict(type='DefaultFormatBundle'),
    dict(type='Collect', keys=['img', 'gt_bboxes', 'gt_labels']),
]
dataset=dict(
    type='VOCDataset',
    pipeline=train_pipeline))

mmdetection中自己实现了一个Compose类,用于组合pipeline,Compose类的本质也是一个transform,在其__call__函数中做的是使用循依次调用pipeline中的各个操作函数对数据进行处理。
Compose将会按照定义的顺序调用pipeline。

results

下面是result在经过pipeline时字段的变化情况。
在这里插入图片描述

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
mmdetection中,有多种方法可以进行数据集增强。一种方法是在送入机器学习之前,对数据集进行转换。这可以通过执行一系列的转换操作来实现,这些转换操作可以增强数据集的大小。另一种方法是在小批量(mini-batch)上执行这些转换。这样可以减少内存的占用,并且可以提高训练的效率。 在mmdetection中,有一些内置的方法可以用来进行数据集增强。其中包括ClassBalancedDataset、ConcatDataset和RepeatDataset等方法。这些方法可以根据需要进行选择,以实现数据集的增强效果。 如果需要自定义新的数据增强方法,可以在mmdetection的代码中新建一个augment.py文件,然后在其中编写自己的数据增强类。在初始化的声明中添加这个新的数据增强类,然后就可以在训练管道中使用它了。例如,在train_pipeline中添加一个dict(type='augment'),即可使用新的数据增强方法。 在mmdetection中,还有许多其他的数据增强方法可以使用,包括Compose、to_tensor、ToTensor、ImageToTensor、ToDataContainer、Transpose、Collect、DefaultFormatBundle、LoadAnnotations、LoadImageFromFile等。此外,还有Resize、RandomFlip、Pad、RandomCrop、Normalize、SegRescale、MinIoURandomCrop、Expand、PhotoMetricDistortion、Albu、InstaBoost、RandomCenterCropPad、AutoAugment、CutOut、Shear、Rotate、ColorTransform、EqualizeTransform、BrightnessTransform、ContrastTransform、Translate、RandomShift等方法。这些方法可以根据不同的需求选择使用,以实现不同的数据增强效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [mmdetection中的数据增强方法(慢慢写, 会很长)](https://blog.csdn.net/liuqiangaliuv/article/details/119682448)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值