Skip to content

Latest commit

 

History

History
41 lines (20 loc) · 1.54 KB

README.md

File metadata and controls

41 lines (20 loc) · 1.54 KB

FedExP: Speeding up Federated Averaging via Extrapolation

Code to reproduce experiments in ICLR 2023 paper https://arxiv.org/abs/2301.09604.

Requirements

Requirements can be found in the requirements.txt file.

Instructions

  • An example command to run an experiment is as follows:
python main.py --seed 0 --algorithm "fedavg" --dataset "CIFAR10" --model "resnet18" --num_clients 100 --num_participating_clients 5 --num_rounds 500 --alpha 0.5                   

Explanation of arguments:

  1. seed: Choice of seed to fix randomness in experiment.

  2. algorithm: Choice of algorithm. Possible options are fedavg, fedexp,scaffold, scaffold(exp), fedprox, fedprox(exp), fedadam, fedadagrad, fedavgm, fedavgm(exp).

  3. dataset: Choice of dataset. Possible options are CIFAR10,CIFAR100,CINIC10.

  4. model: Choice of neural network model. Possible options are resnet18, CNN (for CIFAR dataset), EMNIST_CNN (for EMNIST dataset).

  5. num_clients: Total number of clients in FL system.

  6. num_participating_clients: Number of clients that participate in each round of FL training.

  7. num_rounds: Number of rounds of FL training

  8. alpha: Choice of alpha parameter for the Dirichlet distribution used to create heterogeneity in the client datasets for CIFAR and CINIC datasets.

Details of these arguments to reproduce our experiments can be found in Section 6 of the paper and Appendices D.2 and D.3.

Code for the synthetic linear regression experiment can be found in linear_regression.ipynb