algorithm: scomatch_fl
server_alg: scomatch
client_alg: scomatch
strategy: FedAvg_finetune
strategy_args:
  fraction_fit: 0.1
  min_fit_clients: 5
  fraction_evaluate: 0.0
  evaluate_fn: null
client_pseudo: True  # False for supervised

save_dir: ../../../saved_models/fed_openset_sco
save_name: scomatch_openset_cifar10_lb240_seed0_iid
use_wandb: True
wandb_entity: name

##### Dataset #####
Dataset:
  dataset: cifar10_openset
  base_dir: ../../../data
  data_dir: ../../../data
  clients_path: ../../../data/cifar10_openset/lb240_seed0/iid_clients100.pkl
  num_classes: 6
  num_labels: 240

  # fed setting
  num_clients: 100
  iid: True 
  alpha: null
  num_k: null

  # augmentation
  image_size: 32
  crop_ratio: 0.875

  # loader
  Server:
    train_bs: 30
    test_bs: 200
    num_workers: 1
    data_sampler: null
  Client:
    bs: 32
    f_bs: 10
    num_workers: 1
  seed: 0


##### Model #####
Model:
  net: wrn_28_2_sco
  net_from_name: False
  use_pretrain: False
  pretrain_path: null

  # ema
  use_ema: False
  ema_m: 0.9


##### Training #####
Training:
  use_scheduler: True
  static_bn: True
  clip: 10
  start_fix: 0
  total_round: 2500

  Strategy:

  Server:
    optim: 'SGD'
    
    warmup_epochs: 500
    warmup_eval_epoch: 50
    warmup_lr: 0.01
    warmup_momentum: 0.9
    warmup_weight_decay: 0.0005

    finetune_epochs: 3
    finetune_lr: 0.01
    finetune_momentum: 0.9
    finetune_weight_decay: 0.0005

    first_cycle_step: 3000
    cycle_mult: 1
    min_lr: 0.001
    warmup_steps: 0
    lr_gamma: 0.5

  Client:
    optim: 'SGD'
    
    lr: 0.01
    momentum: 0.9
    weight_decay: 0.0005
    local_epochs: 5

    use_ema_pseudo: False
    start_ema_pseudo: null
    use_pmask: False

    ## semisupervised
    T: 1
    p_cutoff: 0.95
    use_mask_only: False

    #scomatch
    threshold: 0.95
    ood_threshold: 0.95
    mu: 2
    Km: 1

    filtered_weight: False
gpu: 0
seed: 0