## Overview

This repository contains code for experimenting with several causal discovery algorithms on interventional data generated from acyclic directed mixed graphs (ADMGs). In particular, the main algorithms of interest here are:

- **IFCI** (base IFCI / soft FCI variant)
- **fast_soft_fci** (a fast local variant with extra orientation rules)
- **complete_soft_fci** (a completion stage that enumerates MAGs and applies IMAG constraints)

All three are implemented in `soft_fci.py`, and the corresponding experiment drivers live in:

- `run_IFCI.py`
- `run_fast_soft_fci.py`
- `run_complete_soft_fci.py`


## Environment setup

- **Python**: recommended Python ≥ 3.9.
- **Suggested workflow**: create and activate a virtual environment or conda environment.


### Required Python packages

- **Core numerical / scientific stack**
  - `numpy`
  - `scipy`

- **Graphical models / BN sampling**
  - `pyagrum`


## Running IFCI Example

```bash
python run_complete_soft_fci.py
```

## Notes

- **Metrics**:
  - **ACC**: accuracy on revealed endpoint marks (excluding unknowns and no-edges).
  - **DIS**: normalized edit distance on endpoint marks of true edges.
  - **CNT**: coverage of revealed marks relative to the number of true endpoint marks.

- All three runner scripts (`run_IFCI.py`, `run_fast_soft_fci.py`, `run_complete_soft_fci.py`) are intended to be self-contained entry points for comparing variants under a consistent simulation setup.