# PROTEUS: Provably accurate, parameter-free task retrieval framework for continual fine-tuning systems

### Environment Setup:
- To set up the required environment, refer to the provided ./environment.yml file.

### Running the Code:

Use the following command to run the main training script with a specified configuration file:

```python main.py --cfg {config file}```

Ex: python main.py --cfg configs/imgn-r.yml

### Supported Datasets
Download the datasets from the links below:
- [CIFAR-100](https://www.cs.toronto.edu/~kriz/cifar-100-python.tar.gz)
- [ImageNet-R](https://people.eecs.berkeley.edu/~hendrycks/imagenet-r.tar)
- [ImageNet-A](https://drive.google.com/file/d/19l52ua_vvTtttgVRziCZJjal0TPE9f2p/view?usp=sharing)
- [VTAB5T-Small](https://drive.google.com/file/d/1xUiwlnx4k0oDhYi26KL5KwrCAya-mvJ_/view?usp=sharing)
- [VTAB5T-Large](https://github.com/google-research/task_adaptation)
- [VTAB-Sim50](https://github.com/google-research/task_adaptation)

#### VTAB-Sim50

The `VTAB-Sim50` dataset includes preprocessed `data loaders` and `class masks`. These are stored in the `datasets` directory. Ensure the VTAB-Sim50 folder is placed alongside other VTAB5T dataset folders.

Alternatively, you can regenerate VTAB-Sim50 using the following command:

```python vtab_sim50.py --cfg configs/vtab-large-seed-45.yml```

