---
num_clients: 100
num_epochs: 5
batch_size: 64
clients_per_round: 10
learning_rate: 0.01
num_rounds: 10
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: "random"
sparsify_by: 0.01
path: "sapef"
save_path: "${path}/${approach}.csv"
wandb_name: "cser"
wandb: False
comp_type: "topk"
alpha_r: 0.5
H: 5
reset_frac: 0.10

client_fn:
  _target_: client_cser.gen_client_fn
  _recursive_: False
  num_epochs: ${num_epochs}
  learning_rate: ${learning_rate}
  momentum: ${momentum}
  weight_decay: ${weight_decay}
  approach: ${approach}
  sparsify_by: ${sparsify_by}
  comp_type: ${comp_type}
  H: ${H}
  reset_frac: ${reset_frac}

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

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

strategy:
  _target_: Spars_strategy_cser.CSER
  fraction_fit: 0.0000001 # 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
  approach: ${approach}
  H: ${H}
  comp_type: ${comp_type}
  sparsify_by: ${sparsify_by}
  partitioning: ${partitioning}
  clients_per_round: ${clients_per_round}
  num_clients: ${num_clients}
client:
  # client config

server_device: cuda:0

client_resources:
  num_cpus: 4
  num_gpus: 0.07
