---
num_clients: 100
num_epochs: 5
batch_size: 64
clients_per_round: 10
learning_rate: 0.01
num_rounds: 200
partitioning: "dirichlet"
dataset_name: "cifar10"
dataset_seed: 42
alpha: 0.5
labels_per_client: 2 # only used when partitioning is label quantity
momentum: 0.9
weight_decay: 0.00001
approach: "FedAvg"
sparsify_by: 1.0
path: "sapef"
save_path: "${path}/${approach}.csv"
wandb_name: "FedAvg"
wandb: False
model_type: "cnn"

client_fn:
  _target_: client_fedavg.gen_client_fn
  _recursive_: False
  num_epochs: ${num_epochs}
  learning_rate: ${learning_rate}
  momentum: ${momentum}
  weight_decay: ${weight_decay}

dataset:
  # dataset config
  name: ${dataset_name}
  partitioning: ${partitioning}
  batch_size: ${batch_size} # batch_size = batch_size_ratio * total_local_data_size
  val_split: 0.0
  seed: ${dataset_seed}
  alpha: ${alpha}
  labels_per_client: ${labels_per_client}
  model_type: ${model_type}

model:
  # _target_: models.make_resnet
  # model_name: resnet34
  # num_classes: 200
  # pretrained: False
  # _target_: models.ResNet18
  # in_channels: 3
  # num_classes: 100
  _target_: models.ResNet9
  input_dim: 3
  hidden_dims: []
  num_classes: 10

strategy:
  _target_: strategy_fedavg.FedAvg 
  fraction_fit: 0.00001 # because we want the number of clients to sample on each round to be solely defined by min_fit_clients
  fraction_evaluate: 0.0
  min_fit_clients: ${clients_per_round}
  min_available_clients: ${clients_per_round}
  min_evaluate_clients: 0

client:
  # client config

server_device: cuda:0

client_resources:
  num_cpus: 4
  num_gpus: 0.07
