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
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值