data:
    name: "MNIST"

federated:
    algorithm: "FedAvg"
    train_client_size: 200
    eval_client_size: 100
    noniid_ratio: 0.02
    log_frequency: 20   # log after a number of rounds
    num_clients: 10
    num_rounds: 100     # will be overloaded in continual unlearning
    evaluation_strategy: "fixed"   # whether to use fixed dataset or remaining client's test set

model:
    type: "MLP"
    input_size: 784
    hidden: 30
    out_size: 10

local:
    loss: "CrossEntropyLoss"
    optimizer: "SGD"
    num_epochs: 1
    lr: 0.01
    weight_decay: 0.1
    lr_scheduler: null
    train_batch_size: 20
    eval_batch_size: 64
    grad_clip: 10.0

continual_unlearning:
    requests: [
        {"request_type": "train", "num_rounds": 100},
        {"request_type": "leave", "client_id": 0},
        {"request_type": "train", "num_rounds": 10},
        {"request_type": "join", "client_id": 9, "attach_to": 20},
        {"request_type": "train", "num_rounds": 90},
        {"request_type": "leave", "client_id": 1},
        {"request_type": "train", "num_rounds": 10},
        {"request_type": "join", "client_id": 8, "attach_to": 20},
        {"request_type": "train", "num_rounds": 100}
    ]