---
pretrain_config_path: config/defense/simclr/SIG/mnist.yaml
pretrain_checkpoint: epoch200.pdmodel
prefetch: False  # turn on prefetch mode will speedup io
transform:
  pre: 
    to_numpy: True
  train:
    primary:
      random_crop:
        size: 28
        padding: 4
        padding_mode: reflect
      random_horizontal_flip:
        prob: 0.5
    remaining:
      to_tensor: True
      normalize:
        mean: [0.5]
        std: [0.5]
  test:
    primary: null
    remaining:
      to_tensor: True
      normalize:
        mean: [0.5]
        std: [0.5]
network:
  mnist:
    num_classes: 10
warmup:
  loader:
    batch_size: 128
    num_workers: 6
  criterion:
    sce:
      alpha: 0.1
      beta: 1
      num_classes: 10
  num_epochs: 10
semi:
  epsilon: 0.5
  loader:
    batch_size: 128
    num_workers: 6
  criterion:
    mixmatch:
      lambda_u: 15  # 75*(200/1024)~=15
      # gradually increasing lambda_u in the whole training process
      # seems to lead to better results.
      rampup_length: 50  # same as num_epochs or 16 (in the official implementation)
  mixmatch:
    train_iteration: 1024
    temperature: 0.5
    alpha: 0.75
    num_classes: 10
  num_epochs: 50
optimizer:
  learning_rate: 0.002
  Adam:
    beta1: 0.9
    beta2: 0.999
lr_scheduler: null