# Distance-Aware Temperature Scaling (DATS)

The repository contains the code to reproduce the results of our paper. 

### Structure of the repo
- `utils` contains all the utilities to preprocess and save the data, to run the experiments, and to save the results.
- `configs` contains the hyperparameters (dataset, backbone architecture, seed) to run our experiments.

### Run the experiments
Before evaluating our approach, run `train_backbone.py` to save the model checkpoints used for post-hoc re-calibration.

The current version of the configuration file (`configuration/config_jup.py`) enables running an experiment on CIFAR10 with SlimResNet as backbone architecture and seed=1. All the parameters can be changed as desired in the `dats_calibration.ipynb` file.
The most important hyperparameters are the followings.

For the continual learning part:
- `MODEL`: select the backbone of the trained model (slimresnet, resnet32).
- `DATASET`: name of the dataset to evaluate (cifar10, cifar100, tinyimagenet, bloodmnist, dermamnist)
- `THRESHOLD`: coverage threshold for filtering out class assignment at test-time (default=0.6)
