πππ: Our new work on source-free universal domain adaptation has been accepted by CVPR-2024! The paper "LEAD: Learning Decomposition for Source-free Universal Domain Adaptation" is available at https://arxiv.org/abs/2403.03421. The code has been made public at https://github.com/ispc-lab/LEAD.
β¨β¨β¨: We provide a substantial extension to this paper. "GLC++: Source-Free Universal Domain Adaptation through Global-Local Clustering and Contrastive Affinity Learning" is available at https://arxiv.org/abs/2403.14410. The code has been made public at https://github.com/ispc-lab/GLC-plus.
Deep neural networks (DNNs) often perform poorly in the presence of domain shift and category shift. To address this, in this paper, we explore the Source-free Universal Domain Adaptation (SF-UniDA). SF-UniDA is appealing in view that universal model adaptation can be resolved only on the basis of a standard pre-trained closed-set model, i.e., without source raw data and dedicated model architecture. To achieve this, we develop a generic global and local clustering technique (GLC). GLC equips with an inovative one-vs-all global pseudo-labeling strategy to realize "known" and "unknown" data samples separation under various category-shift. Remarkably, in the most challenging open-partial-set DA scenario, GLC outperforms UMAD by 14.8% on the VisDA benchmark.
- python3, pytorch, numpy, PIL, scipy, sklearn, tqdm, etc.
- We have presented the our conda environment file in
./environment.yml
.
We have conducted extensive expeirments on four datasets with three category shift scenario, i.e., Partial-set DA (PDA), Open-set DA (OSDA), and Open-partial DA (OPDA). The following is the details of class split for each scenario. Here,
Datasets | Class Split | ||
---|---|---|---|
OPDA | OSDA | PDA | |
Office-31 | 10/10/11 | 10/0/11 | 10/21/0 |
Office-Home | 10/5/50 | 25/0/40 | 25/40/0 |
VisDA-C | 6/3/3 | 6/0/6 | 6/6/0 |
DomainNet | 150/50/145 |
Please manually download these datasets from the official websites, and unzip them to the ./data
folder. To ease your implementation, we have provide the image_unida_list.txt
for each dataset subdomains.
./data
βββ Office
β βββ Amazon
| βββ ...
β βββ image_unida_list.txt
β βββ Dslr
| βββ ...
β βββ image_unida_list.txt
β βββ Webcam
| βββ ...
β βββ image_unida_list.txt
βββ OfficeHome
β βββ ...
βββ VisDA
β βββ ...
- Open-partial Domain Adaptation (OPDA) on Office, OfficeHome, and VisDA
# Source Model Preparing
bash ./scripts/train_source_OPDA.sh
# Target Model Adaptation
bash ./scripts/train_target_OPDA.sh
- Open-set Domain Adaptation (OSDA) on Office, OfficeHome, and VisDA
# Source Model Preparing
bash ./scripts/train_source_OSDA.sh
# Target Model Adaptation
bash ./scripts/train_target_OSDA.sh
- Partial-set Domain Adaptation (PDA) on Office, OfficeHome, and VisDA
# Source Model Preparing
bash ./scripts/train_source_PDA.sh
# Target Model Adaptation
bash ./scripts/train_target_PDA.sh
If you find our codebase helpful, please star our project and cite our paper:
@inproceedings{sanqing2023GLC,
title={Upcycling Models under Domain and Category Shift},
author={Qu, Sanqing and Zou, Tianpei and RΓΆhrbein, Florian and Lu, Cewu and Chen, Guang and Tao, Dacheng and Jiang, Changjun},
booktitle={CVPR},
year={2023},
}
@inproceedings{sanqing2022BMD,
title={BMD: A general class-balanced multicentric dynamic prototype strategy for source-free domain adaptation},
author={Qu, Sanqing and Chen, Guang and Zhang, Jing and Li, Zhijun and He, Wei and Tao, Dacheng},
booktitle={ECCV},
year={2022}
}