defaults:
  - _self_

random_seed: 5
device: cuda

# dataset
dataset: MNIST
dataset_fraction: 10
min_samples_per_client: 100
distribution_type: "niid"
batch_size: 20
train_fraction: 1.0
validation_fraction: 0.1
test_fraction: 1.0
num_classes: 10

# training
num_rounds: 40
num_clients_per_round: 10
learning_rate: 0.01
epochs_per_round: 2
batches_per_round: null
same_train_test_clients: True
method: "FATS"

# unlearning
unlearning: true
unlearning_rounds: [10,20,30]
unlearning_clients: [1,2,3]
unlearning_samples: None

results_dir_path: "./results/leaf_mnist_FATS"


federated:
    algorithm: "FedAvg"
    train_client_size: 200 
    eval_client_size: 200
    noniid_ratio: 0.02                # (C_min/C_max) where C_min, C_max are size of the least/most biggest class
    log_frequency: 20               # log after a number of rounds
    num_clients: 10                  # chosen to be 2^k (compatible to MMT structure)
    num_rounds: 100                  # will be overloaded in continual unlearning
    evaluation_strategy: "fixed"    # whether to use fixed dataset or remaining client's test set

local:
    loss: "CrossEntropyLoss"
    optimizer: "SGD"
    num_epochs: 1
    lr: 0.01       # Lessons: smaller LR seems to have less weird observations
    weight_decay: 0.1
    lr_scheduler: null
    train_batch_size: 20
    eval_batch_size: 64
    grad_clip: 10.0