# Supplementary Material

This repository contains the **official JAX implementation** for the experiments presented in our paper. The code enables full replication of the main results, including performance comparisons and ablation studies for the proposed **FlexDOME** algorithm.


## Requirements

- **Python**: 3.9+
- **Key libraries**
  - `jax==0.4.13`
  - `jaxlib` (compatible with your CUDA/CPU setup)
  - `scipy==1.11.1`
  - `matplotlib==3.7.2`
  - `seaborn==0.12.2`
  - `numpy` (latest compatible with above)

Install dependencies (recommended in a fresh virtual environment):

```bash
pip install numpy scipy jax jaxlib matplotlib seaborn
```

> If you use CUDA, please install the matching `jaxlib` wheel from the official JAX instructions for your CUDA version.

---

## Reproducing the Main Results

All experiments can be reproduced by running the single Jupyter notebook **`FlexDOME.ipynb`** from top to bottom.

### Steps

1. Launch the notebook:
   ```bash
   jupyter notebook FlexDOME.ipynb
   ```

2. In the notebook UI, select **Cell → Run All**.

The notebook is fully automated and performs the following:

- Runs **three sets of experiments**: stochastic threshold, fixed threshold, and ablation study.
- Uses **5 random seeds** per setting.
- Saves raw simulation data to **`simulation_results_all.pkl`**.
- Loads and processes the saved data to compute **means and standard errors**.
- Generates the final composite figure **`FlexDOME_experiment_results.pdf`**, corresponding to **Figure 1** in the paper.

---

## Code Structure (within `FlexDOME.ipynb`)

- **Part 1 — Imports and Definitions**  
  Library imports, global constants, and core functions for the CMDP environment and algorithm updates (e.g., `setup_environment`, `generic_update`).

- **Part 2 — Main Execution Loop**  
  Orchestrates the experiments across all random seeds and the three experimental groups.

- **Part 3 — Save, Load, and Process Results**  
  Persists raw results to a `.pkl` file and then loads/processes them to compute summary statistics.

- **Part 4 — Plotting**  
  Generates the main three-row figure (`FlexDOME_experiment_results.pdf`).

