# Rectified Flows for Fast Multiscale Fluid Flow Modeling - Supplementary Material

This repository contains the supplementary code and materials for the ICLR 2026 submission on rectified flows for predicting multiscale fluid dynamics. The codebase implements a deterministic transport framework that replaces SDE-based diffusion sampling with learnable straight ODEs for fast and accurate turbulent flow prediction.

## Overview

Our method, based on rectified flows, provides a deterministic alternative to diffusion models like GenCFD while maintaining high-frequency spectral accuracy. The approach learns to transport data distributions using vector fields trained to approximate posterior conditional distributions, offering significant speedup over traditional stochastic sampling methods.

## Repository Structure

```plaintext
├── train.py                  # Main training script
├── compute_eval_stats.py     # Evaluation and statistics computation
├── data_visualizer.py        # Dataset visualization tool
├── configs.py                # Dataset configurations and metadata
├── datasets/                 # Dataset loading utilities
├── rectified_flow_pytorch/   # Core rectified flow implementation
├── model_utils.py            # Model utilities and architectures
├── stats_utils.py            # Statistical analysis tools
└── data/                     # Dataset and checkpoint storage (see below)
```

## Data Access

The datasets and pre-trained checkpoints are hosted on Globus and can be accessed at:
**https://app.globus.org/file-manager?origin_id=82341aed-ad6c-449c-88fc-430fc5b00ba6&origin_path=%2F**

The data folder contains:
- Training datasets for various fluid dynamics problems
- Pre-trained model checkpoints
- Evaluation datasets with micro-perturbations
- Normalization statistics (mean/std files)

## Available Datasets

The repository includes three challenging fluid dynamics datasets:

### 1. CloudShock2D
- **Physics**: Compressible Euler equations
- **Problem**: Cloud-shock interaction with supersonic shock wave hitting high-density cloud
- **Variables**: `['rho', 'm_x', 'm_y', 'E']` (density, momentum components, energy)
- **Resolution**: 128 × 128
- **Channels**: 4 input, 4 output

### 2. ShearLayer2D  
- **Physics**: Incompressible Navier-Stokes equations
- **Problem**: 2D shear layer instability leading to vortex formation
- **Variables**: `['u_x', 'u_y']` (velocity components)
- **Resolution**: 128 × 128
- **Channels**: 2 input, 2 output

### 3. RichtmyerMeshkov2D
- **Physics**: Compressible fluid dynamics
- **Problem**: Richtmyer-Meshkov instability with interface acceleration
- **Variables**: `['rho', 'E', 'mx', 'my']` (density, energy, momentum components)
- **Resolution**: 128 × 128
- **Channels**: 4 input, 4 output

## Quick Start

### Environment Setup
Create and activate the conda environment using the provided specification:
```bash
conda env create -f environment.yml
conda activate rectified-flows
```

### Dataset Visualization Tool

The `data_visualizer.py` script (dataset visualizer) allows you to explore and visualize the structure and content of the fluid dynamics datasets. This tool helps understand the data format, variable ranges, and physical phenomena before training or evaluation.

#### How to Run

```bash
python data_visualizer.py --dataset-name DATASET_NAME [OPTIONS]

```
### Training a Model

Train a rectified flow model on a specific dataset:

```bash
python train.py --dataset-name CloudShock2D
python train.py --dataset-name ShearLayer2D
python train.py --dataset-name RichtmyerMeshkov2D
```

### Evaluation and Statistics Computation

The `compute_eval_stats.py` script provides comprehensive evaluation of trained rectified flow models against ground truth data. It computes statistical metrics and generates visualizations to assess model performance. For simplicity, it already contains a hardcoded path pointing to a checkpoint.

#### How to Run

```bash
python compute_eval_stats.py
