# Federated Unlearning Workflow

This repository is the CODE of FU-DWS, which demonstrates a typical cross-silo workflow for removing a domain from a federated well-generalization model after training with backdoored data. 

The main entry point is `test4unlearning_main.py`.

## 1. Learning Stage

Start by training a model that includes backdoor examples:

```bash
python3 test4unlearning_main.py \
    --target learning \
    --dataset office-caltech10 \
    --model vit \
    --domain_split_factor 1 \
    --epochs 10 \
    --unlearn_epoch 10 \
    --unlearning_client 0 \
    --backdoor_client_idx 0 \
    --verify backdoor
```

This command trains a ViT model on the Office-Caltech10 dataset. The backdoor is injected during the learning phase by setting `--verify backdoor` and specifying the target client with `--backdoor_client_idx`.

To enable prototype-regularized local updates during the learning stage (and subsequent unlearning baselines), set `--proto True`. The default `--proto False` keeps the original averaging-based local training behaviour.

## 2. Unlearning Baselines

After the learning stage finishes, different unlearning methods can be applied. Select the desired baseline via the `--target` argument. For example:

```bash
python3 test4unlearning_main.py --target retrain --verify backdoor --unlearning_client 0 --backdoor_client_idx 0
```

Other options for `--target` include `rapid_retrain`, `federaser`, `increase_loss`, and `class_pruning`. The `federaser` baseline reconstructs the global model by re-averaging the stored client models while excluding the designated clients. All baselines reuse the checkpoints produced in the learning stage to evaluate how well the backdoor is removed.

## Checkpoint Directory Layout

Both the learning stage and the `class_pruning` baseline expect checkpoints to follow a shared directory structure:

```
./save/test/{dataset}/learning/{save}/dsf_{domain_split_factor}/{backdoor_clients}/
    weight_global.pth
    weight_local.pth
```

The `{save}` tag, split factor, and backdoor client indices must match between the learning and unlearning runs. `class_pruning` will raise an error if either `weight_global.pth` or `weight_local.pth` is missing from this directory.

