# A Rashomon Perspective on the Robustness–Privacy Trade-off for Interpretable Models

This repository contains the official code for reproducing all experiments from our paper. The code is organized into separate directories corresponding to different sections and experiments in the paper.

## Repository Structure

```
rashomon_dual/
├── kl_div_synthetic_simulation/  # Synthetic simulation experiments (Figure 5)
├── reconstruction/                # Privacy/reconstruction experiments (§6.2, §6.3, Appendix D.1)
├── robustness_tree/              # Tree-based robustness experiments (§6.1, Appendix D.2)
├── robustness_nn/                # Neural network robustness experiments (Appendix D.3)
└── rob_priv_nn/                  # Neural network robustness-privacy experiments (Appendix D.4)
```

Each directory contains its own README with detailed instructions for running the specific experiments.

## Requirements

### Installation

To install all required dependencies:

```bash
pip install -r requirements.txt
```

### Key Dependencies

- Python 3.8+
- numpy, pandas, scikit-learn
- gurobipy (for optimization-based experiments)
- Additional dependencies listed in `requirements.txt`

## Quick Start

### 1. Synthetic Simulation Experiments (Figure 1)

```bash
cd kl_div_synthetic_simulation
python simu_run.py
python simu_plot.py
```

### 2. Privacy Reconstruction Experiments (§6.2, §6.3, Appendix D.1)

```bash
cd reconstruction
python data_extraction_from_rf_experiments.py --expe_id <config_id>
python plot_results.py
```

Each configuration has a unique ID for easy parallel execution. See [reconstruction/README.md](reconstruction/README.md) for details.

### 3. Robustness Experiments (§6.1, Appendix D.2)

```bash
cd robustness_tree
python run_exp.py \
  --dataset compas \
  --encoder threshold_guess \
  --metrics_config config/metrics_0_1.yaml \
  --output_dir out/ \
  --skip_confirm \
  --random_state 10 \
  --retrain \
  --reset_results \
  --fold 0 \
  RSET \
  --rset_eps 0.03
```

To evaluate and generate results:

```bash
python run_result.py --output_dir out/ --dataset_list compas,fico
```

### 4. Neural Network Robustness Experiments (Appendix D.3)

```bash
cd robustness_nn
python run_experiment.py
python plot.py
```

See [robustness_nn/README.md](robustness_nn/README.md) for more details on neural network experiments.

## Datasets

The experiments use the following datasets (included in each experiment directory's `data/` folder):
- Adult Income
- COMPAS Recidivism
- FICO Credit Scoring
- Default Credit
- Diabetes
- Bank Marketing


## Acknowledgments

The privacy reconstruction experiments are adapted from the [DRAFT repository](https://github.com/vidalt/DRAFT) with significant modifications for our experimental setup.
