algorithm: fixmatch_prosub
server_alg: prosub
client_alg: prosub
strategy: FedProSub_finetune
strategy_args:
  fraction_fit: 0.1
  min_fit_clients: 5
  fraction_evaluate: 0.0
  evaluate_fn: null
client_pseudo: True

save_dir: ../../../saved_models/fed_openset_prosub
save_name: Cifar10_6_prosub_lb240_seed0_iid
use_wandb: True
wandb_entity: name

##### Dataset #####
# seed: 0
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
  net_from_name: False
  use_pretrain: False
  pretrain_path: null

  # ema
  use_ema: True
  ema_m: 0.9
  use_ema_pseudo: False

  ## OpenNet
  cls_hidden: 128
  proj_hidden: 128
  proj_size: 128
  out_hidden: 1024


##### Training #####
Training:
  static_bn: True
  use_scheduler: True
  clip: 10  # FixMatch와 동일하게 증가
  pi : 0.5
  alpha1 : 10.0
  alpha2 : 2.0
  beta1 : 2.0
  beta2 : 10.0
  prototype_ema_decay : 0.99
  beta_ema_decay : 0.99
  uratio : 7

  total_round: 2500

  Strategy:
  Server:
    optim: 'SGD'
    use_ema_feat: True
    
    warmup_epochs: 500
    warmup_eval_epoch: 50 #50
    warmup_lr: 0.01
    warmup_momentum: 0.9
    warmup_weight_decay: 0.0005

    finetune_epochs: 3 #10
    finetune_eval_epoch: 1 #5
    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

    ## openmatch
    lambda_ova: 1
    ova_w_neg_ratio: 0.5

    ## magmatch
    use_ema_feat: True
    cont_T: 0.5
    fm_it: 16
    start_cont: 20

    lambda_cont: 0.005
    lambda_cont_sup: 1
    lambda_cont_l: 1
    wd : 0.0005


  Client:
    optim: 'SGD'
    
    lr: 0.01
    momentum: 0.9
    weight_decay: 0.0005
    use_ema_pseudo: False # 추가
    start_ema_pseudo: 0 # 추가
    local_epochs: 5  # FixMatch와 동일하게 증가

    ## semisupervised
    T: 1  # FixMatch와 동일하게 변경 (0.5 → 1)
    p_cutoff: 0.95
    in_cutoff: 0.5
    neg_cutoff: 0.05
    use_mask_only: False
    use_pmask: False  # FixMatch와 동일하게 변경

    ulb_ova: True
    lambda_oem: 0.1
    lambda_socr: 0.5
    lambda_neg: 0.1
    tau: 0.95  # T값과 일치하도록 조정

    filtered_weight: False  # FixMatch와 동일하게 변경

    cont_T: 0.5
    lambda_cont_u: 0.5
    wpl : 1.0
    ws : 5.0
    wsub : 1.0
    wd : 0.0005

gpu: 0
seed: 0