We derive the Fokker-Planck equation (forward equation) and the backward equation. FPE is central in diffusion models to guarantee the correctness of image generation algorithm. Despite its extensive use in diffusion literature, the FPE background is not often presented in details.
This writeup derives the operator for Kolmogorov Forward the Backward Equations. The forward equation is known as the Fokker-Planck equation (FPE).
It is introduced to the diffusion model literature by Song et al., 2021 to show that the distribution induced by the learned image denoiser exactly matches the distribution by adding noise to data. FPE provides a guarantee that solving the backward diffusion ODE / SDE would lead us back to the image manifold. The role of Fokker-Planck equation is discussed extensively in diffusion literature e.g. EDM (Karras et al., 2022). But the derivation of FPE itself is seldom presented. This article makes an attempt hopefully without too many gaps.
1. Feller Generator / Semigroup of Diffusion
This material in this section is rehashed mostly from the notes by Prof. Lawler, and his 235 lectures (chapter 3) discusses the infinitesimal generator for discrete markov chains.
Let ut(x)=∫f(y)pt(y∣x)dy, where f is some benign test function. In plain words, u is the expected value of f after time t rollout starting at x. We want to find operator L for the PDE
∂tut(x)=Lxut(x).
Since u is an integral over dummy y, we can move both of the the operators ∂t and L inside the integral, and obtain a PDE on the transition kernel pt(y∣x)
Note that when t+s is split, t goes to the 2nd segment y→z and s is assigned to 1st segment x→y. Otherwise we won't be able to form an expression for u(⋅,t) cuz f is integrated over z. This gives these steps a "backward-going" flavor i.e. we have u(y,x) and then extend backward by s to form ut+s(x).
Not right. Left t right 0. Some logic is missing. For an alternative proof, directly apply Ito v2 on ut(x), and since ut(x) is a conditional expectation, the terms on dt is 0. This way you get the PDE. This is much quicker.
2. Kolmogorov Forward Backward Operator Duality
The material in this section is based on the notes by Miranda Holmes-Cerfon,
with influence from the notes by Jonathan Goodman. I remembered reading Goodman's claim that operator duality is the only legitimate way to derive the FPE / forward equation. I cannot find that webpage now.
To relate forward and backward PDEs, we consider a test function f integrated over the end-of-time marginal distribution pT. We further break pT into integrals of transition kernels pT−t(⋅∣⋅) and pt(⋅∣⋅),
This is the Kolmogorov Forward / Fokker-Planck equation. Eqn. 14 is true for both continuous and discrete Markov processes.
[Adjoints of operators] To write down the expression for the adjoint, we use the following integration by parts identities
⟨h(x)∂xa,b⟩⟨l(x)∂xxa,b⟩=∫xh(x)∂xa(x)⋅b(x)dx=∫x∂xa(x)⋅[h(x)b(x)]dx=∫xa(x)⋅−∂x[h(x)b(x)]dx=⟨a,−∂x[h(x)⋅b]⟩=∫xl(x)∂xxa(x)⋅b(x)dx=∫x∂xxa(x)⋅[l(x)b(x)]dx=∫xa(x)⋅∂xx[l(x)b(x)]dx=⟨a,∂xx[l(x)⋅b]⟩int by parts twice.
The probability density p(x,t) induced by a deterministic ODE dtdx=v(x,t) is described by the (noiseless) Fokker Planck equation. Expand it using product rule of divergence:
For a neural ODE e.g. a diffusion at inference time, to compute the density at a data point x, we integrate the divergence of velocity term over time. Evaluating divergence i.e. trace of jacobian of a neural net feedforward pass is costly cuz it's expensive to materialize the full jacobian. FFjord (Grathwohl et al., 2019) proposes to use hutchinson trace estimator tr(∂x∂vθ(x,t))=Eϵ∼N(0,I)ϵT∂x∂vθ(x,t)ϵ since vector-jacobian product is very manageable.
This recipe is first popularized in ML community by Neural ODE (Chen et al., 2018). Their derivation in appendix A.2 is essentially what I wrote here. I have learned from someone working in fluid dynamics that they call it the "material derivative" . So it's not exactly a new result.
References
Ricky TQ Chen, Yulia Rubanova, Jesse Bettencourt, and David K Duvenaud. Neural ordinary differential equations. Advances in neural information processing systems, 2018.
Will Grathwohl, Ricky T. Q. Chen, Jesse Bettencourt, and David Duvenaud. Scalable reversible generative models with free-form continuous dynamics. In International Conference on Learning Representations. 2019. URL: https://openreview.net/forum?id=rJxgknCcK7.
Tero Karras, Miika Aittala, Timo Aila, and Samuli Laine. Elucidating the design space of diffusion-based generative models. In Adv. Neural Inform. Process. Syst. 2022.
Yang Song, Jascha Sohl-Dickstein, Diederik P Kingma, Abhishek Kumar, Stefano Ermon, and Ben Poole. Score-based generative modeling through stochastic differential equations. In Int. Conf. Learn. Represent. 2021.
Last updated on 2024-12-31. Design inspired by distill.