# Explainable Mixture Modelsthrough Differentiable Rule Learning

This repository contains the source code for the paper "Explainable Mixture Models through Differentiable Rule Learning".
It also contains scripts to easily replicate the experiments.

## Requirements

* Tested with Python 3.10
* Cuda for GPU acceleration

## Setup

1.  **Create and activate a virtual environment:**
    ```bash
    python3 -m venv venv
    source venv/bin/activate
    ```

2.  **Install required packages:**
    All dependencies are listed in `requirements.txt`.
    ```bash
    pip install -r requirements.txt
    ```

3.  **Install the project package:**
    To install the project code in editable mode, run:
    ```bash
    pip install -e .
    ```

## Usage

Once the setup is complete, you can use the method and run the experiments.

* **Navigate to experiments directory:**
    ```bash
    cd experiments
    ```

* **To generate the synthetic data:**
    ```bash
    python synthetic_datasets.py
    ```

* **To run full evaluation on the generated data:**
    ```bash
    python synthetic_eval.py
    ```
* **To run a specific experiment and method:**
    ```bash
    python synthetic_eval.py --method emm_gmm --experiment_names scaling5
    ```
* **To run the real data experiments:**
    ```bash
    python real_datasets.py
    ```


## Example notebook

We also provide an example jupyter notebook `example.ipnyb` to illustrate usage of the model.
* **Install Jupyter and add kernel:**
    ```bash
    pip install notebook
    python -m ipykernel install --user --name emm --display-name "Python (Emm)"
    ```
