DA-MergeLoRA: Hypernetwork-Based LoRA Merging for Few-Shot Test-Time Domain Adaptation

Overview: 
Few-shot Test-Time Domain Adaptation (FSTT-DA) seeks to adapt models to novel domains using only a handful of unlabeled target samples. In our approach, separate LoRA modules are fine-tuned on CLIP’s vision encoder for each source domain. Since LoRA modifies only a small fraction of the model’s parameters, it retains the base model’s generalized knowledge while internally learning domain-specific features. To adapt the learned knowledge to a specific target domain, we propose a hypernetwork trained via meta-learning that generates per-column merging factors to combine LoRA modules. Given a small batch of target images, the hypernetwork produces merging weights that fuse source LoRA modules into a single adapted representation. 

Datasets: 
We evaluate on three WILDS benchmark classification datasets: iWildCam, FMoW, and Camelyon17. These datasets consist of real-world data with distribution shift. We use the official WILDS evaluation metrics for each dataset (average accuracy, F1-score, and worst-case (WC) accuracy) and the official train/test splits. We also evaluate on DomainNet, which contains roughly 600k images from 345 classes across six domains. We use the standard leave-one-out protocol for DomainNet, selecting one domain for testing and the remainder as source domains. 
 
This project contains four experiments from the paper: 
- source_lora: Trains a single universal LoRA model with all source data combined. 
- source_lora_per_domain: Trains a separate LoRA on each source domain.
- target_baselines: Tests simple methods for combining the source LoRA modules (simple parameter avgeraging, entropy-weighted averaging).
- hypernet: Trains a hypernetwork to generate merge weights to combine LoRA modules to adapt to the target domain.

To reproduce an experiment, simply run the command:
PYTHONPATH=. python3 experiments/main.py experiment=experiment_name dataset=dataset_name
where,
- experiment_name = source_lora, source_lora_per_domain, target_baselines, or hypernet
- dataset_name = fmow, camelyon17, iwildcam, or domainnet
- Note: You must run source_lora_per_domain before running hypernet or target_baselines, to generate the per-domain LoRA modules. 

To select the hypernet architecture you want to test, you can also specify:
- experiment.hypernet_type=ca_model, ca_layer, ca_column, or mlp (default=ca_column)
- "ca" means the cross-attention hypernetwork
- Model/layer/column selects whether the hypernetwork generates per-model, per-layer, or per-column merge weights

For the target_baselines experiment, you can specify:
- experiment.strategy=avg_combination or weighted_combination (default=avg_combination)
- avg_combination uses simple parameter averaging
- weighted_combination uses entropy-weighted averaging 

To install all dependencies, run:
pip install -r requirements.txt

To download datasets:
- The DomainNet dataset can be downloaded from: https://ai.bu.edu/M3SDA/#dataset
- WILDS datasets will download automatically when the code is run, if not already downloaded.

To cluster the IWildCam train domains into 10 clusters as done in the paper, run the command: 
PYTHONPATH=. python3 datasets/cluster_iwildcam.py
