# 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. **DN4IL** indices can be downloaded from [github-DN4IL](https://github.com/NeurAI-Lab/DN4IL-dataset)
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).