# Latent-Causal-Discovery

This supplement contains the MATLAB and Python codes used for experiments in the paper "On Theoretical Identifiability of Binary Latent Causal Graphical Models". The codes estimate the observed-to-latent bipartite graph and the latent causal graph. The main algorithm in this code is based on Algorithm 1 in the paper by Ma, Ouyang & Xu (2023) (https://link.springer.com/article/10.1007/s11336-022-09867-5).

### For simulations:
To run the main simulation (in the paragraph **Experiments under varying latent structures**), go to the folder `simulations` and run the `simulation_main.m` file. The simulation settings such as the true graphical structures and conditional probabilities can be changed within the script. To estimate the latent DAG $\Lambda$, run the `estimate_lambda.py` file (in Python).

To run the supplementary simulation (in Section E.3), go to the folder `simulations` and run the `simulation_select_K.m` file.

### Additional codes:
The folder `utilities` contains helper functions required to implement the main algorithms. We recommend adding this folder using the `add path 'utilities'` command in MATLAB.

### Dependencies:
MATLAB
- 9.13.0.2126072 (R2022b)

Python
- numpy 1.26.2
- pandas 2.2.2
- ges 1.1.1
