# Unpaired IV Experiments

This repo reproduces the simulation and the causal chamber experiments from the accompanying paper on unpaired two‑sample IV. The code is split into a small estimator library and an experiments package.

## Package layout

- **`unpaired_iv`**: estimator implementations + internal utilities used by estimators.
- **`unpaired_iv_experiments`**: DGPs, experiment configs/runners, plotting, caching.
- **`scripts/`**: entrypoints that generate the figures.
- **`causal_chambers/`**: causal chambers experiment.

## Estimators (paper)

- **TS‑2SLS**: two‑sample 2SLS baseline.
- **TS‑IV**: two‑sample IV baseline.
- **UP‑GMM**: unpaired GMM with optimal weighting (optionally L1).
- **SplitUP**: corresponds to **UP‑GMM‑HS in code**, implemented as `UPGMMHDAnalytic` and `UPGMMHD`.

## Figure mapping

- **Figure 1** → `scripts/heatmaps.py`
- **Figure 3, 4, 8, 9** → `scripts/synthetic_experiments_categorical.py`
- **Figure 5** → `causal_chambers/causal_chambers_exp.py`
- **Figure 10, 11, 12** → `scripts/synthetic_experiments_continuous.py`

Outputs are written to `results_current/` (and `results_causal_chambers/` for the real‑world study).

## Installation

Create and activate a virtual environment, then install in editable mode:

```bash
python -m venv .venv
source .venv/bin/activate        # macOS/Linux
# .venv\Scripts\activate         # Windows PowerShell

pip install -U pip
pip install -e .
```

Run scripts as modules from the repo root, e.g.:

```bash
python -m scripts.synthetic_experiments_categorical
```

## ToDos

- Data dependent lambda choice for upgamm and upgmm_hd.
