# Server-Proximal Efficient Continual Aggregation for Learning
The implementation of algorithm **SPECIAL** and other baselines.

## Requirements
The needed libraries are in **requirements.txt**.

## Dataset preparation:
The required datasets include Digit-10, VLCS, and PACS.

1. **Digit-10** consists of MNIST, EMNIST, USPS, and SVHN. The four datasets can be downloaded with ```torchvision.datasets```.
2. **VLCS** can be downloaded from [kaggle-vlcs](https://www.kaggle.com/datasets/iamjanvijay/vlcsdataset).

3. **PACS** can be downloaded from [kaggle-pacs](https://www.kaggle.com/datasets/nickfratto/pacs-dataset).

4. The original files of VLCS and PACS do not include train-test splits, and we provide the split algorithms in the folder `data split`.

5. The roots of datasets in ```utils\data.py``` should be revised in your address for every dataset.

## Experiments
To run **SPECIAL** on Digit-10, excute:

      python main.py


To run **SPECIAL** on VLCS, excute:

      python main.py --dirichlet_coef 0.3 --lambda_reg 0.40 --dataset_list 'VLCS'


To run **SPECIAL** on PACS, excute:

      python main.py --dirichlet_coef 0.3 --lambda_reg 0.05 --dataset_list 'PACS'

We provide a little example to run other baselines. For example, please run the following commands to test **FedCIL** on VLCS:

      python main.py --dirichlet_coef 0.3 --dataset_list 'VLCS' --method 'FedCIL'



## Reference
The code of **FedCIL** is based on the code in [FedCIL](https://github.com/daiqing98/FedCIL).

The code of **MFCL** is based on the code in [MFCL](https://github.com/SaraBabakN/MFCL-NeurIPS23).