This is the repository for our paper "Principled Federated Domain Adaptation: Gradient Projection and Auto-Weighting"
Federated Domain Adaptation (FDA) describes the federated learning (FL) setting where source clients and a server work collaboratively to improve the performance of a target client where limited data is available. The domain shift between the source and target domains, coupled with limited data of the target client, makes FDA a challenging problem, e.g., common techniques such as federated averaging and fine-tuning fail due to domain shift and data scarcity. To theoretically understand the problem, we introduce new metrics that characterize the FDA setting and a theoretical framework with novel theorems for analyzing the performance of server aggregation rules. Further, we propose a novel lightweight aggregation rule, Federated Gradient Projection (FedGP), which significantly improves the target performance with domain shift and data scarcity. Moreover, our theory suggests an auto-weighting scheme that finds the optimal combinations of the source and target gradients. This scheme improves both FedGP and a simpler heuristic aggregation rule. Extensive experiments verify the theoretical insights and illustrate the effectiveness of the proposed methods in practice.
- Installation
- FedDA and FedGP
- Auto-weighted versions of FedDA and FedGP
- Other baselines
- Contributors
- How to cite?
- Credits
To install requirements, one can run:
pip install -r requirements.txt
For the synthetic experiment used in the paper, please refer to synthetic_exp.
We provide scripts to run FedDA and FedGP experiments, for both the non-iid and domainbed datasets. One can run run_fedda_0.5.sh
and run_fedgp_0.5.sh
in scripts/noniid_exp
and scripts/domainbed_exp
folders.
Additionally, we provide scripts to run FedDA and FedGP experiments of their auto versions, for both the non-iid and domainbed datasets. One can run run_fedda_auto.sh
and run_fedgp_auto.sh
in scripts/noniid_exp
and scripts/domainbed_exp
folders.
One can run run_fedavg.sh
, run_target_only.sh
, or run_oracle.sh
in scripts/noniid_exp
and scripts/domainbed_exp
folders, to reproduce results of source-only, target-only, and upper bound baselines.
- Enyi Jiang - enyij2@illinois.edu
- Yibo Jacky Zhang - yiboz@stanford.edu
- Sanmi Koyejo - sanmi@cs.stanford.edu
Thanks for your interest in our work. If you find it useful, please cite our paper as follows.
@inproceedings{
jiang2024principled,
title={Principled Federated Domain Adaptation: Gradient Projection and Auto-Weighting},
author={Enyi Jiang and Yibo Jacky Zhang and Sanmi Koyejo},
booktitle={The Twelfth International Conference on Learning Representations},
year={2024},
url={https://openreview.net/forum?id=6J3ehSUrMU}
}
Parts of the code in this repo is based on