server:
  class: src.server.Server
  client_manager:
    class: src.server.client_managers.SimpleClientManager
    args: {}
  strategy:
    class: src.server.strategies.ScaleFLFedAvg
    args:
      min_fit_clients: 10 # clients_per_round

data:
  class: src.data.Cifar100Dataset
  args:
    path_to_data: ./datasets
    dataset_fl_root: ./datasets/FL/cifar100
    lda_alpha: 10.0 # must be defined
    train_alpha: null
    test_alpha: null
    val_ratio: 0.05
    reset: False
models:
  net:
    class: src.models.exit_resnet_template
    args:
      no_of_exits: 4
      ee_layer_locations: [30, 38, 46]
      num_classes: 100
      adapter: null
      freeze_base_model: False
      last_exit_only: False
    optimizer:
      class: torch.optim.SGD
      args:
        momentum: 0.9
        weight_decay: 0.0005
        nesterov: True
app:
  class: src.apps.ScaleFLClassificationApp
  args: 
    mode: multi_tier # multi_tier, maximum
    send_full_local_state: True
    save_log_file: test.pkl
  on_fit:
    cos_lr_decay: True
    start_lr: 0.05
    min_lr: 0.005
  on_evaluate:
    finetune_epochs: [1,2,3,4,5]
    lr: 0.01 # to be tuned for personalized performance
  eval_fn:
    batch_size: 16 # batch size for centralized evaluation
  run:
    num_rounds: 500
    test_every_n: 20 # global_eval_every_n_rounds
    save_every_n: null # save every n rounds
  client:
    class: src.apps.clients.ScaleFLClassificationClient
    args: 
      local_epochs : 5
      batch_size : 16
      kl_loss: ''
      kl_consistency_weight: 300
simulation:
  num_clients: 100
  max_concurrent_clients: 5
  client_resources:
    num_cpus: 1
  ray_init_args:
    num_gpus: 1
    include_dashboard: false
wandb_args:
  # name is defined in top-level.
  entity: test
  project: 'snowfl'
