# DenFlow

This GitHub repository contains the code for our submission "The generation phases of Flow Matching: a denoising perspective"

## 1. Getting started
### 1.1. Requirements

- torch 1.13.1 (or later)
- torchvision
- tqdm
- numpy
- pandas
- pyyaml
- scipy
- torchdiffeq
- deepinv

### 1.2. Download datasets and pretrained models

We provide a script to download datasets used in Denflow. The datasets and network checkpoints will be downloaded and stored in the `data` and `model` directories, respectively.

<b>CelebA.</b> To download the [CelebA](https://www.kaggle.com/datasets/jessicali9530/celeba-dataset) dataset and the pre-trained OT FM network (U-Net), run the following commands:
```bash
bash download.sh celeba-dataset
bash download.sh pretrained-network-celeba
```
Our pretrained models (about 16 for each dataset) will be made public after acceptance.

## 2. Training

You can use the code to train your own denoisers.

You can modify the config options directly in the main_config.yaml file located in ```config/```. Alternatively, config keys can be given as options directly in the command line.

For example, to train the generative flow matching model (here, the U-net is the velocity) on CelebA, run:
```python
python main.py --opts dataset celeba64 loss_type FM class_object shifted train True batch_size 128 num_epoch 300
```
At each 5 epochs, the model is saved in ```./model/celeba/gaussian/ot```. Generated samples are saved in ```./results/celeba/gaussian/ot```.

## 3. Computing generative models metrics

After the training, the final model is loaded and can be used for both generating samples / solving inverse problems.

### 3.1 Computing FID and saving samples
```
python main.py --opts dataset ${dataset} eval_split ${eval_split} \
    max_batch ${max_batch} batch_size_ip ${batch_size_ip} \
    loss_type ${loss_type} class_object ${class_object} \
    run_id ${run_id} model_fold ${model_fold} \
    application sampling method basic_sampler
```

### 3.2 Computing PSNR
```
python main.py --opts dataset ${dataset} eval_split ${eval_split} \
    max_batch ${max_batch} batch_size_ip ${batch_size_ip} \
    loss_type ${loss_type} class_object ${class_object} \
    run_id ${run_id} model_fold ${model_fold} \
    application inverse_problems method basic_psnr
```

### 3.3 Solving inverse problems

The available inverse problems are:
- Denoising --> set ```problem: 'denoising'```
- Gaussian deblurring --> set ```problem: 'gaussian_deblurring'```
- Super-resolution --> set ```problem: 'superresolution'```
- Box inpainting --> set ```problem: 'inpainting'```
- Random inpainting --> set ```problem: 'random_inpainting'```

The parameters of the inverse problems (e.g., noise level) can be adjusted manually in the ```main.py``` file.

The only available method is for the moment ```pnp_flow_denoiser```.

