# 1D Hemodynamic CFD Simulator

A JAX-based pulse-wave simulator for arterial networks with hierarchical parameter inference via tokenised flow-matching posterior estimation (FMPE).

## Overview

Simulates blood flow in large arteries using 1D conservation laws with:
- Lax–Wendroff scheme for mass and momentum transport
- Compliant vessel walls (pressure-area law)
- RCR (Windkessel) terminal boundary conditions
- Junction handling for branching networks

## Quick Start

```bash
python main.py \
  --stage1_full_sims 20 \
  --stage2_full_sims 20 \
  --N_t 50 \
  --outdir artifacts
```

**Outputs:**
- `artifacts/figs/`: Flow and pressure waveforms, diagnostics
- `artifacts/datasets/`: Stage-1 (local) and Stage-2 (joint) training data
- `artifacts/sanity_metrics.json`: Physiological validation metrics

## Network Topology

Five-vessel aortic arch:
- **Inlet:** Aortic root (periodic inflow)
- **Outlets:** Innominate, left common carotid, left subclavian, descending aorta

## Parameters

**Globals (θ_g):**
- `β_scale`: Arterial stiffness multiplier ~ LogNormal(log 2×10⁶, 0.3)
- `μ`: Blood viscosity ~ LogNormal(log 0.004, 0.2) Pa·s
- `Q_in`: Inflow amplitude ~ LogNormal(log 85, 0.2) mL/s

**Locals per terminal (θ_ℓ[s]):**
- `R_T`: Terminal resistance ~ LogNormal(log R_ref, 0.4) Pa·s/m³
- `C_T`: Terminal compliance ~ LogNormal(log C_ref, 0.4) m³/Pa

## Observations

- **Flow traces:** 4 sites × N_t samples (default 50/cycle)
- **Brachial proxy:** Systolic/diastolic pressures (mmHg)
- **Noise model:** 5% heteroscedastic + 2.5 mmHg pressure error

## Requirements

```
jax[cpu]
numpy
matplotlib
tqdm
```