# Risk-Optimal Conformal Prediction

This repository contains the implementation for Risk-Optimal Conformal Prediction (ROCP).

## Data Pre-processing

The data pre-processing scripts must be run before evaluation. These scripts generate the necessary scores, probabilities, and labels for each dataset.

- **BDD**: The `BDD/build_npz.py` script processes BDD100K images using a YOLO model to compute hazard bit scores and true labels. It requires BDD100K dataset images and labels JSON files.

  ```bash
  python BDD/build_npz.py \
    --labels-json /path/to/your/bdd100k/labels/bdd100k_labels_images_val.json \
    --images-root /path/to/your/bdd100k/images/100k/val \
    --out-npz BDD/outputs/raw_bits.npz \
    --model yolo11l.pt
  ```

- **COVID-19**: The `data/train_multiple_seeds.py` script loads the COVID-19 Radiography Dataset, fine-tunes an InceptionV3 model, and extracts probabilities and labels for calibration and test sets.

  ```bash
  python data/train_multiple_seeds.py \
    --dataset covid \
    --data_dir /path/to/your/covid19-radiography-database/COVID-19_Radiography_Dataset 
  ```

## Running ROCP and Baseline Methods

After obtaining the pre-processed data files, you can run the evaluation scripts to compare ROCP with baseline methods (RAC, LAS, APS, SOCOP, Best Response).

### BDD Dataset

```bash
python evaluation_bdd.py --npz BDD/outputs/raw_bits.npz
```

### COVID-19 Dataset

```bash
python evaluation.py --dataset covid
```
