# Overclocking Electrostatic Generative Models


This repository contains the implementation of the proposed **Inverse Poisson Flow Matching (IPFM)**, our distillation method for PFGM++ electrostatic generative models.

## Contents
- `training/ipfm_loss.py`: IPFM training objective
- `training/ipfm_training_loop.py`: IPFM training procedure
- `ipfm_sampler.py`: IPFM multistep sampler
- `pfgmpp_kernel.py`: PFGM++ perturbation kernel for different auxiliary dimensions D
- `pyproject.toml`: Python dependencies specification

## Installation

This project uses [uv](https://docs.astral.sh/uv/) for dependency management.

```bash
# Install uv if not already installed
curl -LsSf https://astral.sh/uv/install.sh | sh

# Set up environment
uv sync
source .venv/bin/activate  # Unix/macOS
```

### Dataset Preparation

Follow the instructions detailed in the [EDM codebase](https://github.com/NVlabs/edm/tree/main?tab=readme-ov-file#preparing-datasets) to prepare the training datasets.
Place the prepared files in the `datasets/` folder:

- `cifar10-32x32.zip`
- `ffhq-64x64.zip`

**Note:** Although a training dataset is not necessary for distilling the pretrained EDM model, it is used in our code to calculate evaluation metrics such as FID and Inception Score. Optionally, you can create a dummy dataset and either disable the evaluation code if you wish to run the IPFM distillation code without these metrics, or provide an npz file of the training dataset if you need to compute these metrics.

### Loading PFGM++ Checkpoints

In our work we tested our IPFM distillation on all [models](https://github.com/Newbeeer/pfgmpp?tab=readme-ov-file#checkpoints) provided by PFGM++ authors for unconditional generation tasks.
Here is an example of downloading of PFGM++ model for unconditional CIFAR-10 and auxiliary dimension D=128 given a share google drive link:

```bash
uv run python download_pfgmpp_checkpoint.py \
	https://drive.google.com/file/d/1SFDpDgax0-G2lWwwqShWqh7lNrFzdxwU/view?usp=share_link \
	cifar10_ncsnpp_D_128
```

The result of this command is the checkpoint under the `downloads/pfgmpp_ckpts/cifar10_ncsnpp_D_128.pkl` path.

## Usage Examples

### Training

```bash
uv run bash run_ipfm.sh cifar10-uncond-D128-alpha10-nfe2
```
Adjust the GPU parameters (number of GPUs and batch size per GPU) within `run_ipfm.sh` file according to your GPU memory limitations.

### Sampling

```bash
uv run python ipfm_generate.py \
    --outdir=image_experiment/out \
    --seeds=0-32 \
    --batch=32 \
    --network=<path_to_checkpoint> \
    --ref='https://nvlabs-fi-cdn.nvidia.com/edm/fid-refs/cifar10-32x32.npz' \
    --aug_dim=128 \
    --n_generator_steps=2 \
    --single_batch=True

```

This script will generate a image for every seed in range 0-32 considering `network` as a 2-step IPFM generator for PFGM++ with D=128.

## Outline
Our implementation is build upon [SiD](https://github.com/mingyuanzhou/SiD?tab=readme-ov-file) repository.