CRFL
CRFL copied to clipboard
CRFL: Certifiably Robust Federated Learning against Backdoor Attacks (ICML 2021)
CRFL
In this repository, code is for our ICML 2021 paper CRFL: Certifiably Robust Federated Learning against Backdoor Attacks
Installation
-
Create a virtual environment via
conda.conda create -n crfl python=3.6 source activate crfl -
Install
torchandtorchvisionaccording to your CUDA Version and the instructions at PyTorch. For example,conda install pytorch cudatoolkit=10.1 torchvision -c pytorch -
Install requirements.
pip install -r requirements.txt
Dataset
-
MNIST and EMNIST: MNIST and EMNIST datasets will be automatically downloaded into the dir
./dataduring training or testing. -
LOAN: Download the raw dataset
loan.csvfrom Google Drive into the dir./data.
Runpython utils/loan_preprocess.pyWe will get 51 csv files in
./data/loan/.
Get Started
- First, we training the FL models on the three datasets:
python main.py --params configs/mnist_params.yaml
python main.py --params configs/emnist_params.yaml
python main.py --params configs/loan_params.yaml
Hyperparameters can be changed according to the comments in those yaml files (configs/mnist_params.yaml,configs/emnist_params.yaml, configs/loan_params.yaml) to reproduce our experiments.
- Second, we perform parameter smoothing for the global models on the three datasets:
python smooth_mnist.py
python smooth_emnist.py
python smooth_loan.py
The filepaths of models can be changed in those yaml files (configs/mnist_smooth_params.yaml,configs/emnist_smooth_params.yaml, configs/loan_smooth_params.yaml) .
- Third, we plot the certified accuracy and certified rate for the three datasets:
python certify_mnist.py
python certify_emnist.py
python certify_loan.py
Citation
If you find our work useful in your research, please consider citing:
@InProceedings{pmlr-v139-xie21a,
title = {CRFL: Certifiably Robust Federated Learning against Backdoor Attacks},
author = {Xie, Chulin and Chen, Minghao and Chen, Pin-Yu and Li, Bo},
booktitle = {Proceedings of the 38th International Conference on Machine Learning},
pages = {11372--11382},
year = {2021},
volume = {139},
series = {Proceedings of Machine Learning Research},
month = {18--24 Jul},
publisher = {PMLR},
pdf = {http://proceedings.mlr.press/v139/xie21a/xie21a.pdf},
url = {http://proceedings.mlr.press/v139/xie21a.html},
}