<div align="center"> <h1>LoGDIFF: Logical Guidance for the Exact Composition of Diffusion Models</h1> </div>

LoGDIFF provides a framework for the exact composition of diffusion models using logical guidance. This repository contains the official implementation for training, inference, and evaluation for the ColoredMNIST, Shapes3D and CelebA datasets.


### Installation
Set up your environment using Conda:

```bash
conda env create -f environment.yml
conda activate LoGDIFF
```
### Datasets

The project supports three primary benchmarks. Update your local paths in the `configs/datasets/*.yaml` files to match your local environment.

#### Setup Instructions

1. **Automatic Downloads:** For **ColoredMNIST** and **Shapes3D**, no manual action is required. The datasets will be downloaded and processed automatically the first time you initiate training.

2. **CelebA (Manual):**
   * Download the dataset from the [Official CelebA Repository](http://mmlab.ie.cuhk.edu.hk/projects/CelebA.html).
   * Extract the files to your preferred local directory and update the config.
   * Update `configs/datasets/celeba.yaml`.
   * Pre-compute latents once before training with the following script.

```bash
CUDA_VISIBLE_DEVICES=0 torchrun --master_port=25670 \
  logdiff/scripts/save_latent.py \
  --encoder=vae \
  --image-size=128 \
  --dataset=celeba \
  --data-path=/path/to/celeba \
  --features-path=data/celeba
```

## Training

### Classifier Training
We train two different classifier: one trained on noisy $x_t$​ for probability estimation and one on clean images to asses conformity scores.
```bash
python logdiff/cs_classifier/train.py --config-name=cs_cmnist
python logdiff/cs_classifier/train.py --config-name=cs_cmnist_composition
```

### Diffusion Model Training
Train the diffusion model using the provided Hydra configurations:
```bash
python logdiff/train.py --config-name=cmnist
```

### Evaluation
All evaluation scripts are located in the evaluate/ folder. Use these to calculate Conformity Score (CS), Entropy, and FID.
```bash
python logdiff/evaluate/evaluation_cmnist.py
```
Results will be saved in a created folder outputs including images and a results.csv.


## Acknowledgments

This project also builds upon code and insights from:

* [CoInd](https://github.com/sachit3022/compositional-generation/) (Compositional Generation)
* HuggingFace, lucidrains, Hydra, fast-DiT and PyTorch Lightning.