data:
    name: "MNIST"

federated:
    algorithm: "FedAvg"
    train_client_size: 150 
    eval_client_size: 100
    noniid_ratio: 0.01
    log_frequency: 20   # log after a number of rounds
    num_clients: 8
    num_rounds: 99     # 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: 64
    out_size: 8

local:
    loss: "CrossEntropyLoss"
    optimizer: "SGD"
    num_epochs: 3
    lr: 0.01
    weight_decay: 0.0
    lr_scheduler: null
    train_batch_size: 5
    eval_batch_size: 64
    grad_clip: 10.0

oneshot_unlearning:
    client_id: 4

sequential_unlearning:
    order: [0,2,4,6]

continual_unlearning:
    requests: [
        {"request_type": "train", "num_rounds": 99},
        {"request_type": "leave", "client_id": 0},
        {"request_type": "train", "num_rounds": 49},
        {"request_type": "join", "client_id": 6, "attach_to": 11},
        {"request_type": "train", "num_rounds": 49},
        {"request_type": "leave", "client_id": 1},
        {"request_type": "train", "num_rounds": 49},
        {"request_type": "join", "client_id": 7, "attach_to": 11},
        {"request_type": "train", "num_rounds": 49},
        {"request_type": "leave", "client_id": 2},
        {"request_type": "train", "num_rounds": 99}
    ]