algorithm: ours
server_alg: ours
client_alg: ours
strategy: FedOurs_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/fedopenset_cifar100_55
save_name: ours_openset_lb2200_alpha01_seed1_f4_0922_01_o3
use_wandb: True
wandb_entity: name

##### Dataset #####
Dataset:
  dataset: cifar100_openset
  base_dir: ../../../data
  data_dir: ../../../data
  clients_path: ../../../data/cifar100_openset/lb2200_seed1/non-iid_clients100_alpha0.1.pkl
  num_classes: 55
  num_labels: 2200

  # fed setting
  num_clients: 100
  iid: False
  alpha: 0.1
  num_k: null

  # augmentation
  image_size: 32
  crop_ratio: 0.875

  # loader
  Server:
    train_bs: 100
    test_bs: 256  
    num_workers: 1
    data_sampler: null
  Client:
    bs: 64
    f_bs: 10
    num_workers: 1
  seed: 1


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

  # ema
  use_ema: True
  ema_m: 0.9

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


##### Training #####
Training:
  static_bn: True
  use_scheduler: True
  clip: 10

  total_round: 2500

  Strategy:

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

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

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

    ## openmatch
    lambda_ova: 1.0
    ova_w_neg_ratio: 1.0
    hard_neg: False

    ## ours
    ema_feat_round: 1500  # not used
    cont_T: 0.5
    fm_it: 8


  Client:
    optim: 'SGD'
    
    lr: 0.03
    momentum: 0.9
    weight_decay: 0.0005
    local_epochs: 5
    local_filtered_epochs: 0  # not used
    start_filtered_epochs_round: 3000  # not used

    use_ema_pseudo: False
    start_ema_pseudo: 3000  # not used

    use_pmask: True
    
    ## semisupervised
    T: 0.5
    p_cutoff: 0.99
    in_cutoff: 0.95
    neg_cutoff: 0.01
    use_mask_only: False

    lambda_oem: 0.1
    lambda_socr: 0.5
    lambda_neg: 1
    
    lambda_cont: 0.001

    filtered_weight: True

    cont_T: 0.5
    start_cont_rnd: 500

    cls_lr_factor: 1
    
gpu: 3
seed: 1