Note: this repo is implemented in a sequentially running manner. We are working on a parallel implementation with the Flower framework.
FedLAP-DP: Federated Learning by Sharing Differentially Private Loss Approximations (PoPETS 2024)
Hui-Po Wang, Dingfan Chen, Raouf Kerkouche, Mario Fritz
A novel federated optimization approach overcoming privacy and non-IID challenges via gradient approximation
Follow the instructions below to reproduce the main result of our work quickly.
-
Modify the
--data-path
argument inmain.py
andmain_baseline.py
accordingly (or specify it in the console) -
Set up the environment
pip install -r requirements.txt
- Run the following scripts
- FedAvg on CIFAR-10 in non-DP settings
bash script-fed/baseline-nondp.sh
- FedLAP on CIFAR-10 in non-DP settings
bash script-fed/fedlap-nondp.sh
- FedAvg on CIFAR-10 in DP settings
bash script-fed/baseline-dp.sh
- FedLAP on CIFAR-10 in DP settings
bash script-fed/fedlap-dp.sh
The ablation studies in the paper can be reproduced by the following instructions, which have been provided in the scripts, e.g., script-fed/fedlap-nondp.sh
.
- Radius selection strategies
python -W ignore main.py -cfg settings-fed/fedlap/cifar10-fedlap-median.yaml
python -W ignore main.py -cfg settings-fed/fedlap/cifar10-fedlap-max.yaml
python -W ignore main.py -cfg settings-fed/fedlap/cifar10-fedlap-fixed.yaml
We provide the environment setup we tested here. This repo might be downward compatible but opacus
must be 0.15.0.
- Pytorch >= 2.3.1
- torchvision >= 0.18.1
- opacus==0.15.0
@article{wang2023fedlap,
title={FedLAP-DP: Federated Learning by Sharing Differentially Private Loss Approximations},
author={Wang, Hui-Po and Chen, Dingfan and Kerkouche, Raouf and Fritz, Mario},
journal={Proc. Priv. Enhancing Technol.}
year={2024}
}
This project is partially built upon PrivateSet and Dataset Condensation