# **ASAT: Adaptive Scoring and Thresholding with Human Feedback for Robust Out-of-Distribution Detection**

This repository contains the code for the paper *"ASAT: Adaptive Scoring and Thresholding with Human Feedback for Robust Out-of-Distribution Detection"*. The framework proposed in this work enables adaptive scoring functions and thresholds to maintain controlled false positive rates (FPR) during the deployment phase while integrating human feedback for robust OOD detection.

## **Repository Structure**
- `src/`: the implementation of the main methods and algorithms.
- `exp/`: scripts to reproduce the experiments reported in the paper.
- `scripts/`: documentation and additional resources.
- `configs/`: configurations of the experiments, such as hyper-parameters and constants

For the main implementation of the ASAT algorithm, please refer to `src/estimator.py`.
  
## **Excluded Directories**
Due to the large size of the data and result directories, we have excluded the following folders from this submission:
- `data/`: the original datasets used in the experiments. The datasets can be obtained by following the instructions provided below.
- `results/`: our results from running the experiments. 

## **Obtaining Datasets**
Our datasets include extracted features from CIFAR-10, CIFAR-100, Tiny-ImageNet, MNIST, Places365, SVHN, and Texture, along with corresponding scores from Open-OOD benchmarks (https://github.com/Jingkang50/OpenOOD). To access the datasets used in our experiments, please contact us.

You can also generate the features and scores by following the tutorial in the Open-OOD GitHub repository. The data should be stored as separate `.npz` files (with array name `arr_0`) in the structure shown below:


```
├── data
│    │── features
│    │     │── model_name (e.g. Resnet18)
│    │     ...    │── CIFAR-10 (npz)
│    │            │── MNIST          
│    │── scores
│          │── scoring_function_name (e.g. EBO)
...        ...    │── scores (npz)
```

## Running Experiments
After obtaining the data as instructed above, you can run the experiments using the provided `run_stationary.sh` or `run_distr_shft.sh` scripts:

```
cd scripts
chmod +x run_stationary.sh
./run_stationary.sh
```

### Citation
Yang, et al. "[Openood:Benchmarking generalized out-of-distribution detection.](https://github.com/Jingkang50/OpenOOD)" Advances in Neural Information Processing Systems 35 (2022)