Skip to content

A repository and benchmark for online test-time adaptation.

License

Notifications You must be signed in to change notification settings

ShunyaYamagami/test-time-adaptation

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

55 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Online Test-time Adaptation

This is an open source online test-time adaptation repository based on PyTorch. It is joint work by Robert A. Marsden and Mario Döbler. It is also the official repository for the work Introducing Intermediate Domains for Effective Self-Training during Test-Time and Robust Mean Teacher for Continual and Gradual Test-Time Adaptation (CVPR2023).

Prerequisites

To use the repository, we provide a conda environment.

conda update conda
conda env create -f environment.yml
conda activate tta 

Classification

Features

This repository allows to study a wide range of different datasets, models, settings, and methods. A quick overview is given below:

  • Datasets

  • Models

    • For adapting to ImageNet variations, all pre-trained models available in Torchvision or timm can be used.
    • For the corruption benchmarks, pre-trained models from RobustBench can be used.
    • For the DomainNet-126 benchmark, there is a pre-trained model for each domain.
    • Further models include ResNet-26 GN.
  • Settings

    • reset_each_shift Reset the model state after the adaptation to a domain.
    • continual Train the model on a sequence of domains without knowing when a domain shift occurs.
    • gradual Train the model on a sequence of gradually increasing/decreasing domain shifts without knowing when a domain shift occurs.
    • mixed_domains Train the model on one long test sequence where consecutive test samples are likely to originate from different domains.
    • correlated Same as the continual setting but the samples of each domain are further sorted by class label.
    • mixed_domains_correlated Mixed domains and sorted by class label.
    • Combinations like gradual_correlated or reset_each_shift_correlated are also possible.
  • Methods

  • Modular Design

    • Adding new methods should be rather simple, thanks to the modular design.

Get Started

To run one of the following benchmarks, the corresponding datasets need to be downloaded.

  • CIFAR10-to-CIFAR10-C: the data is automatically downloaded.
  • CIFAR100-to-CIFAR100-C: the data is automatically downloaded.
  • ImageNet-to-ImageNet-C: for non source-free methods, download ImageNet and ImageNet-C.
  • ImageNet-to-ImageNet-A: for non source-free methods, download ImageNet and ImageNet-A.
  • ImageNet-to-ImageNet-R: for non source-free methods, download ImageNet and ImageNet-R.
  • ImageNet-to-ImageNet-Sketch: for non source-free methods, download ImageNet and ImageNet-Sketch.
  • ImageNet-to-ImageNet-D: for non source-free methods, download ImageNet. For ImageNet-D, see the download instructions for DomainNet-126 below. ImageNet-D is created by symlinks, which are set up at the first use.
  • ImageNet-to-ImageNet-D109: see instructions for DomainNet-126 below.
  • DomainNet-126: download the 6 splits of the cleaned version. Following MME, DomainNet-126 only uses a subset that contains 126 classes from 4 domains.

Next, specify the root folder for all datasets _C.DATA_DIR = "./data" in the file conf.py. For the individual datasets, the directory names are specified in conf.py as a dictionary (see function complete_data_dir_path). In case your directory names deviate from the ones specified in the mapping dictionary, you can simply modify them.

Run Experiments

We provide config files for all experiments and methods. Simply run the following Python file with the corresponding config file.

python test_time.py --cfg cfgs/[cifar10_c/cifar100_c/imagenet_c/imagenet_others/domainnet126]/[source/norm_test/norm_alpha/tent/memo/eta/eata/cotta/adacontrast/lame/sar/rotta/gtta/rmt].yaml

For imagenet_others, the argument CORRUPTION.DATASET has to be passed:

python test_time.py --cfg cfgs/imagenet_others/[source/norm_test/norm_alpha/tent/memo/eta/eata/cotta/adacontrast/lame/sar/rotta/gtta/rmt].yaml CORRUPTION.DATASET [imagenet_a/imagenet_r/imagenet_k/imagenet_d109]

E.g., to run RMT for the ImageNet-to-ImageNet-R benchmark, run the following command.

python test_time.py --cfg cfgs/imagenet_others/rmt.yaml CORRUPTION.DATASET imagenet_r

To run the different continual DomainNet-126 sequences, you have to pass the CKPT_PATH argument. When not specifying a CKPT_PATH, the sequence using the real domain as the source domain will be used. The checkpoints are provided by AdaContrast and can be downloaded here. Structurally, it is best to download them into the directory ./ckpt/domainnet126.

python test_time.py --cfg cfgs/domainnet126/rmt.yaml CKPT_PATH ./ckpt/domainnet126/best_clipart_2020.pth

For GTTA, we provide checkpoint files for the style transfer network. The checkpoints are provided on Google-Drive (download); extract the zip-file within the classification subdirectory.

Changing Configurations

Changing the evaluation configuration is extremely easy. For example, to run TENT on ImageNet-to-ImageNet-C in the reset_each_shift setting with a ResNet-50 and the IMAGENET1K_V1 initialization, the arguments below have to be passed. Further models and initializations can be found here (torchvision) or here (timm).

python test_time.py --cfg cfgs/imagenet_c/tent.yaml MODEL.ARCH resnet50 MODEL.WEIGHTS IMAGENET1K_V1 SETTING reset_each_shift

Acknowledgements

Segmentation

For running the experiments based on CarlaTTA, you first have to download the dataset splits as provided below. Again, you probably have to change the data directory _C.DATA_DIR = "./data" in conf.py. Further, you have to download the pre-trained source checkpoints (download) and extract the zip-file within the segmentation subdirectory.

E.g., to run GTTA, use the config file provided in the directory cfgs and run:

python test_time.py --cfg cfgs/gtta.yaml

You can also change the test sequences by setting LIST_NAME_TEST to:

  • day2night: day_night_1200.txt
  • clear2fog: clear_fog_1200.txt
  • clear2rain: clear_rain_1200.txt
  • dynamic: dynamic_1200.txt
  • highway: town04_dynamic_1200.txt

If you choose highway as the test sequence, you have to change the source list and the corresponding checkpoint paths.

python test_time.py --cfg cfgs/gtta.yaml LIST_NAME_SRC clear_highway_train.txt LIST_NAME_TEST town04_dynamic_1200.txt CKPT_PATH_SEG ./ckpt/clear_highway/ckpt_seg.pth CKPT_PATH_ADAIN_DEC = ./ckpt/clear_highway/ckpt_adain.pth

CarlaTTA

We provide the different datasets of CarlaTTA as individual zip-files on Google-Drive:

If you find our dataset CarlaTTA useful, please cite our work.

@article{marsden2022introducing,
  title={Introducing Intermediate Domains for Effective Self-Training during Test-Time},
  author={Marsden, Robert A and D{\"o}bler, Mario and Yang, Bin},
  journal={arXiv preprint arXiv:2208.07736},
  year={2022}
}

Acknowledgements

About

A repository and benchmark for online test-time adaptation.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.5%
  • Jinja 0.5%