# Evidential Deep Learning Implementation

### Dependencies:
Here we list our used requirements and dependencies.
Theoretically, the specific versions of dependencies should not affect the performance of the method.
 - GPU: RTX A6000
 - Python: 3.10.18
 - PyTorch: 1.13.1

### Installation:
Install the required packages:
```bash
pip install -r requirements.txt
```

### Data preparation:
The required datasets (CIFAR-10/CIFAR-100/SVHN/GTSRB/Places365/Food101) will be automatically downloaded if your server has an Internet connection.

### Pre-trained models:
The pre-trained models of EDL, I-EDL, R-EDL, and Re-EDL can be downloaded from [Google Disk](https://drive.google.com/file/d/1kaqxdDH30UZ47uuYfPZS798AUBn-yekw/view?usp=sharing) provided by Re-EDL. 

They need to be unzipped and put in the directory './saved_models/'.

### Test pre-trained models:
Just run:
   ```
   python main.py --configid "2_cifar10/cifar10-{method-name}-test" --suffix test
   ```
where "method-name" should be replaced by "edl", "iedl", "redl", or "reedl".

### Train from scratch:
   
Just run:
   ```
   python main.py --configid "2_cifar10/cifar10-{method-name}-train" --suffix test

   python main.py --configid "2_cifar10/cifar10-edl-train-exp-uce" --suffix test
   python main.py --configid "3_cifar100/cifar100-edl-train-exp-uce" --suffix test
   ```

### Uncertainty Visualization:

The `uncertainty_comparison_visualization.py` script provides t-SNE based visualization to compare uncertainty distributions with class/OOD distributions:

**Features:**
- Side-by-side t-SNE plots: uncertainty values (left) vs class/OOD labels (right)
- Support for multiple uncertainty types: max_prob, max_alpha, alpha0, differential_entropy, mutual_information, edl_mpu
- Configurable visualization parameters (point size, transparency, figure size)
- Performance optimization for large datasets

**Usage:**
   ```bash
   python uncertainty_comparison_visualization.py
   ```

**Configuration:**
Edit the script to modify visualization parameters:
- `results_dir`: Path to experimental results
- `config_id`: Model configuration ID (e.g., "cifar10-edl-exp-uce-test")
- `id_dataset`: ID dataset name (e.g., "CIFAR10")
- `selected_classes`: List of classes to visualize (e.g., [0, 1, 2])
- `ood_datasets`: List of OOD datasets (e.g., ["SVHN", "CIFAR100"])
- `uncertainty_types`: Types of uncertainty to visualize
- `perplexity`, `learning_rate`, `n_iter`: t-SNE parameters

**Available Uncertainty Types:**
- `alpha0`: Sum of alpha values (similar to Vacuity of Evidence) 
- `differential_entropy`: Differential entropy
- `mutual_information`: Mutual information 
- `edl_mpu`: The proposed margin-aware predictive uncertainty 

## Acknowledgment

This code is based on the open-source implementation from the TPAMI 2025 paper "Revisiting Essential and Nonessential Settings of Evidential Deep Learning" by Mengyuan Chen, Junyu Gao, and Changsheng Xu from the Institute of Automation, Chinese Academy of Sciences. 


