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/fed_openset
save_name: ours_openset_lb240_alpha03_seed0_z1_0913_01_aiot_emafeat
use_wandb: True
wandb_entity: name

##### Dataset #####
Dataset:
  dataset: cifar10_openset
  base_dir: ../../../data
  data_dir: ../../../data
  clients_path: ../../../data/cifar10_openset/lb240_seed0/non-iid_clients100_alpha0.3.pkl
  num_classes: 6
  num_labels: 240

  # fed setting
  num_clients: 100
  iid: False
  alpha: 0.3
  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

  ## OpenNet
  cls_hidden: 128
  proj_hidden: 128
  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.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

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

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


  Client:
    optim: 'SGD'
    
    lr: 0.01
    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: 1
    p_cutoff: 0.95
    in_cutoff: 0.9
    neg_cutoff: 0.05
    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: 2
seed: 0