64 lines
1.9 KiB
Markdown
64 lines
1.9 KiB
Markdown
---
|
||
title: "Flow Matching"
|
||
created: 2026-05-13
|
||
updated: 2026-05-13
|
||
type: concept
|
||
tags: [generative-modeling, diffusion, continuous-time, ODE]
|
||
sources:
|
||
- https://arxiv.org/abs/2210.02747
|
||
---
|
||
|
||
# Flow Matching
|
||
|
||
Flow Matching 是一种连续时间生成建模框架,通过学习速度场(velocity field)来定义从噪声到数据的连续变换路径。
|
||
|
||
## 核心公式
|
||
|
||
给定数据分布 p_data(x) 和噪声分布 p_noise(ε)(通常 ε ~ N(0,I)),定义**线性插值路径**([[rectified-flows]]):
|
||
|
||
```
|
||
z_t = t·x + (1-t)·ε, t ∈ [0,1]
|
||
```
|
||
|
||
速度场定义为 z_t 对时间的导数:
|
||
|
||
```
|
||
v = dz/dt = x - ε
|
||
```
|
||
|
||
训练目标是最小化预测速度与真实速度的 MSE:
|
||
|
||
```
|
||
L_MSE = E_{t,x,ε} ||v_θ(z_t, t) - v||²
|
||
```
|
||
|
||
## x-prediction vs v-prediction
|
||
|
||
由于 v = (x - z_t)/(1-t),网络可以直接预测 x([[x-prediction-parameterization]])而非 v:
|
||
|
||
```
|
||
x_θ = net_θ(z_t, t)
|
||
v_θ = (x_θ - z_t) / (1-t)
|
||
```
|
||
|
||
x-prediction 在 [[embedded-language-flows|ELF]] 中至关重要:它与解码任务(预测干净离散 token)的语义一致,使得共享权重设计可行。
|
||
|
||
## 推理
|
||
|
||
通过求解 ODE `dz_t/dt = v_θ(z_t, t)` 从 z_0 ~ N(0,I) 逐步推进到 z_1 ≈ x。可使用欧拉求解器或更高级的数值方法。
|
||
|
||
## 与其他框架的关系
|
||
|
||
- **DDPM**:离散时间步,高斯前向过程 + 去噪后向过程
|
||
- **Score-based models**:通过 score function ∇log p_t(z) 参数化;Flow Matching 可统一在此框架下
|
||
- **Rectified Flows**:Flow Matching 的特例,使用直线插值路径
|
||
|
||
## 在语言建模中的应用
|
||
|
||
[[embedded-language-flows|ELF]] 将 Flow Matching 应用于语言生成:离散 token → T5 编码 → 连续嵌入空间 → Flow Matching 去噪 → 最后一步解码回 token。
|
||
|
||
## 参考
|
||
|
||
- Lipman et al., "Flow Matching for Generative Modeling", ICLR 2023
|
||
- Albergo & Vanden-Eijnden, "Stochastic Interpolants", JMLR 2025
|