# SaTeen: Learning Structural Alignment for Continual Test-Time Adaptation

Method: **S**tructural **A**lignment-based **Te**st-Tim**e** Adaptatio**n** (**SaTeen**) 
  
### Requirements
- SaTeen depends on:
  - CUDA 11.8
  - Python 3.9
  - Pytorch = 2.3.1 + cu118
  - Pillow = 11.0.0

- Create a new environment:
  ```bash
  conda create -n recap python=3.9 -y

  pip install torch==2.3.1 torchvision==0.18.1 torchaudio==2.3.1 --index-url https://download.pytorch.org/whl/cu118

  pip install pycm matplotlib einops timm
  ```

### Data preparation

This repository contains code for evaluation on [ImageNet-C 🔗](https://arxiv.org/abs/1903.12261) with ResNet-50 and VitBase. But feel free to use your own data and models!

- Step 1: Download [ImageNet-C 🔗](https://github.com/hendrycks/robustness) dataset from [here 🔗](https://zenodo.org/record/2235448#.YpCSLxNBxAc). 

- Step 2: Put IamgeNet-C at "--data_corruption".

## Example: Sateen on ImageNet-C under single and continual Scenes.

```
python main.py --data_corruption /path/to/imagenet-c --exp_type [normal/mix_shifts/label_shiftsbs1/] --method [no_adapt/tent/eata/sar/deyo/recap_plpd/sateen] --model [resnet50_gn_timm/vitbase_timm] --output /output/dir
```

'--exp_type' is choosen from:

- 'normal' means standard TTA setting 

- 'mix_shifts' conducts exps over the mixture of 15 corruption types in ImageNet-C

- 'label_shifts' means exps under online imbalanced label distribution shifts. Moreover, imbalance_ratio indicates the imbalance extent

- 'bs1' means single sample adaptation, only one sample comes each time-step

### 🔧

  ```
  python main.py --exp_type normal --method sateen --model resnet50_gn_timm
  
  python main.py --exp_type normal --method sateen --model vitbase_timm
  
  python main.py --exp_type mix_shifts --method sateen --model resnet50_gn_timm
  
  python main.py --exp_type mix_shifts --method sateen --model vitbase_timm
  
  python main.py --exp_type label_shifts --method sateen --model resnet50_gn_timm
  
  python main.py --exp_type label_shifts --method sateen --model vitbase_timm
  
  python main_c.py --exp_type normal --method sateen --model resnet50_gn_timm
  
  python main_c.py --exp_type normal --method sateen --model vitbase_timm
  
  python main_c.py --exp_type label_shifts --method sateen --model resnet50_gn_timm
  
  python main_c.py --exp_type label_shifts --method sateen --model vitbase_timm
  
  ```

## Acknowledgment 
This repository is built using the [SAR] and [DeYO] and [ReCAP] repository. Thanks for their excellent projects!
