defaults:
  - _self_

random_seed: 5
device: cuda

# dataset
dataset: CIFAR10
dataset_fraction: 10
min_samples_per_client: 1000
distribution_type: "niid"
batch_size: 128
train_fraction: 1.0
validation_fraction: 0.3
test_fraction: 0.3
num_classes: 10

# training
num_rounds: 1200
num_clients_per_round: 10
learning_rate: 1e-1
epochs_per_round: 1
batches_per_round: null
same_train_test_clients: True
method: "FATS"

# unlearning
unlearning: true
unlearning_rounds: [300,600,900]
unlearning_clients: [1,2,3]
unlearning_samples: None

results_dir_path: "./results/CIFAR_FATS"


federated:
    algorithm: "FedAvg"
    train_client_size: 1000
    eval_client_size: 300
    noniid_ratio: 0.2
    log_frequency: 30
    num_clients: 10
    num_rounds: 300
    evaluation_strategy: "fixed"


local:
    loss: "CrossEntropyLoss"
    optimizer: "SGD"
    num_epochs: 1
    lr: 0.0005      # 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