_base_ = [
    '../_base_/models/acdc.py.py', '../_base_/datasets/pascal_context.py',
    '../_base_/default_runtime.py', '../_base_/schedules/schedule_80k.py'
]
crop_size = (480, 480)
data_preprocessor = dict(size=crop_size)
norm_cfg = dict(type='SyncBN', requires_grad=True)
model = dict(
    type='ACDC',
    data_preprocessor=data_preprocessor,
    segmentor_d=dict(
        pretrained='open-mmlab://msra/hrnetv2_w48',
        backbone=dict(
            frozen_stages=4,
            extra=dict(
                stage2=dict(num_channels=(48, 96)),
                stage3=dict(num_channels=(48, 96, 192)),
                stage4=dict(num_channels=(48, 96, 192, 384)))),
        decode_head=dict(
            in_channels=[48, 96, 192, 384],
            channels=sum([48, 96, 192, 384]),
            num_classes=60,
            freeze=True,
        ),
        init_cfg=dict(
            type='Pretrained',
            checkpoint='../../work_dirs/ckpt/hrnet/fcn_hr48_480x480_80k_pascal_context.pth',
        ),
    ),
    segmentor_c=dict(
        _delete_=True,
        type='EncoderDecoder',
        pretrained=None,
        backbone=dict(
            type='MixVisionTransformer',
            in_channels=3,
            embed_dims=64,
            num_stages=4,
            num_heads=[1, 2, 5, 8],
            num_layers=[3, 6, 40, 3],
            patch_sizes=[7, 3, 3, 3],
            sr_ratios=[8, 4, 2, 1],
            out_indices=(0, 1, 2, 3),
            mlp_ratio=4,
            qkv_bias=True,
            drop_rate=0.0,
            attn_drop_rate=0.0,
            drop_path_rate=0.1,
            freeze=True,
            init_cfg=dict(type='Pretrained',
                          checkpoint="https://download.openmmlab.com/mmsegmentation/v0.5/pretrain/segformer/mit_b0_20220624-7e0fe6dd.pth"),
        ),
        decode_head=dict(
            type='SegformerHead',
            in_channels=[64, 128, 320, 512],
            in_index=[0, 1, 2, 3],
            channels=256,
            dropout_ratio=0.1,
            num_classes=60,
            align_corners=False,
            norm_cfg=norm_cfg,
            freeze=True,
            loss_decode=dict(
                type='CrossEntropyLoss', use_sigmoid=False, loss_weight=1.0)
        ),
        init_cfg=dict(
            type='Pretrained',
            checkpoint='../../work_dirs/ckpt/segformer/segformer_mit-b5_480x480_160k_pascal-context.pth',
        ),
        # model training and testing settings
        train_cfg=dict(),
        test_cfg=dict(mode='slide', crop_size=(480, 480), stride=(320, 320))
    ),
    refiner=dict(
        _delete_=True,
        type='MinkUNet2D',
        data_preprocessor=dict(
            type='SegDataPreProcessor',
            mean=[123.675, 116.28, 103.53],
            std=[58.395, 57.12, 57.375],
            bgr_to_rgb=True,
            pad_val=0,
            seg_pad_val=255,
            size=crop_size
        ),
        backbone=dict(
            type='MinkUNetBackbone',
            in_channels=3,
            num_stages=4,
            base_channels=32,
            encoder_channels=[32, 64, 128, 256],
            decoder_channels=[256, 128, 64, 32],
            encoder_blocks=[2, 2, 2, 2, 2],
            decoder_blocks=[2, 2, 2, 2],
            block_type='basic',
            sparseconv_backend='torchsparse'
        ),
        decode_head=dict(
            type='MinkUNetHead2D',
            in_channels=32,
            channels=32,
            num_classes=60,
            dropout_ratio=0,
            loss_decode=dict(
                type='CrossEntropyLoss', use_sigmoid=False, loss_weight=1.0),
        ),
    ),
    uncer_detector=dict(
        checkpoint="../../work_dirs/ckpt/uncertain_detector/hr48_detector_params_context.pt",
        lbd=0.5,
        temperature=1
    ),
    entropy_threshold=1,
    cloud_threshold=2.6,
    scale=(260, 260),
    upsample_percent=0.4,
)
fp16 = dict()
train_cfg = dict(val_interval=8000)

scale = (520, 520)
test_pipeline = [
    dict(type='LoadImageFromFile'),
    dict(type='Resize', scale=scale, keep_ratio=True),
    # add loading annotation after ``Resize`` because ground truth
    # does not need to do resize data transform
    dict(type='LoadAnnotations'),
    dict(type='PackSegInputs')
]
val_dataloader = dict(dataset=dict(pipeline=test_pipeline))
test_dataloader = val_dataloader

train_dataloader = dict(
    batch_size=4,
    num_workers=4,
)

default_hooks = dict(logger=dict(type='LoggerHook', interval=50, log_metric_by_epoch=False))
randomness = dict(seed=0)