# Scale-Invariant Evidential Fusion (SAEF)

This repository contains the **official PyTorch implementation** of the scale sensitivity analysis presented in our ICML submission: *"Beyond Magnitude: Scale-Invariant Evidential Fusion for Multi-View Classification"*.

To facilitate **immediate and lightweight verification** of our core claims, we provide a minimal, self-contained **Inference Demo** on the AVE dataset.

Specifically, this code reproduces the **Asymmetric View Scaling** experiment (corresponding to **Figure 3** in the paper), demonstrating how SAEF maintains robustness while baselines collapse when one view is perturbed by a scale factor $T$.

## 📂 Repository Structure

```text
.
├── data/
│   └── test_set.json           # Test set indices (for deterministic evaluation)
│   └── ave_processed.pkl       # Pre-processed features (Visual + Audio) -> Enables lightweight reproduction
├── kfold_checkpoints/          # Pre-trained fixed backbones (Shared across all methods)
│   └── ave_fold1_best.pth      
│   └── ...      
│   └── ave_fold5_best.pth      
├── model.py                    # Multi-view backbone architecture
├── fusion.py                   # Core Implementation of SAEF, DS, Sum, Mean, and Weighted Fusion
├── dataset.py                  # Dataset loader for the pre-processed features
├── test.py                     # Main evaluation script for Scale Sensitivity Analysis
└── README.md
.
```

## 🚀 Getting Started

1. Prerequisites

The code is implemented in PyTorch. Install dependencies using:

**pip install torch torchvision numpy scikit-learn tqdm**

2. Run Scale Sensitivity Analysis (Figure 3)

Run the evaluation script to verify robustness against asymmetric scaling (where View 1 is scaled by $1/T$ while View 2 remains fixed):

**python test.py**


## 📊 Expected Output

The script will iterate through scale factors $T \in [0.01, 100]$ and print a summary table. You should observe the "Inverted-V" collapse for baselines and Invariance for SAEF.Sample Output (AVE Dataset)

==============================================================================================================
ACCURACY (%) Results - AVE (Asymmetric Scaling)
==============================================================================================================
0.01       | 72.0±2.4      | 72.0±2.4      | 72.5±2.3      | 72.0±2.4      | 82.8±1.8      | 
0.05       | 73.3±2.6      | 73.3±2.6      | 74.0±2.7      | 73.0±2.6      | 82.8±1.8      | 
0.1        | 76.1±2.7      | 76.1±2.7      | 76.4±2.6      | 75.1±2.5      | 82.8±1.8      | 
0.5        | 82.0±1.6      | 82.0±1.6      | 82.3±1.5      | 81.8±1.4      | 82.8±1.8      | 
1          | 82.6±1.8      | 82.6±1.8      | 82.6±1.8      | 82.6±1.6      | 82.8±1.8      | 
5          | 75.8±2.0      | 75.8±2.0      | 75.8±2.2      | 78.1±2.1      | 82.8±1.8      | 
10         | 72.1±2.8      | 72.1±2.8      | 72.2±2.9      | 74.4±3.4      | 82.8±1.8      | 
50         | 66.7±3.4      | 66.7±3.4      | 66.8±3.4      | 68.2±3.6      | 82.8±1.8      | 
1e+02      | 65.8±3.3      | 65.8±3.3      | 65.8±3.3      | 66.7±3.4      | 82.9±1.6      |
==============================================================================================================

**T < 1 (Amplification)**: Baselines degrade as the inflated view hijacks the prediction.

**T > 1 (Suppression)**: Baselines collapse due to information loss from the scaled view.

**SAEF (Ours)**: Remains invariant, validating **Theorem 5.2**.