Diffusion Model 学习笔记

发布时间:2023年12月26日

论文链接:Denoising Diffusion Probabilistic Models

Diffusion Model 分为两部分,前向扩散过程和后向生成过程,前向扩散过程从一张原始图像逐步加噪声变为一张纯噪声图像,后向生成过程则从随机噪声来逐步恢复出原图像。

贝叶斯公式角度

在这里插入图片描述

这里的符号 X T \mathbf{X}_T XT?表示经过 T \mathbf{T} T步生成的纯噪声图像, X 0 \mathbf{X}_0 X0?表示原始图像, Z t \mathbf{Z}_t Zt?表示 t t t 时刻随机采样的高斯噪声。设我们有系数 α t \alpha_t αt? β t \beta_t βt?,其中满足关系 α t + β t = 1 \alpha_t+\beta_t=1 αt?+βt?=1,生成过程可以表示为:
X t = α t X t ? 1 + 1 ? α t Z t X t ? 1 = α t ? 1 X t ? 2 + 1 ? α t ? 1 Z t ? 1 . . . \begin{align} \mathbf{X}_t&=\sqrt{\alpha_t}\mathbf{X}_{t-1}+\sqrt{1-\alpha_t}\mathbf{Z}_t\\ \mathbf{X}_{t-1}&=\sqrt{\alpha_{t-1}}\mathbf{X}_{t-2}+\sqrt{1-\alpha_{t-1}}\mathbf{Z}_{t-1}\\ ... \end{align} Xt?Xt?1?...?=αt? ?Xt?1?+1?αt? ?Zt?=αt?1? ?Xt?2?+1?αt?1? ?Zt?1???将上面的两个公式联合求解消除 X t ? 1 \mathbf{X}_{t-1} Xt?1?
X t = α t ( α t ? 1 X t ? 2 + 1 ? α t ? 1 Z t ? 1 ) + 1 ? α t Z t = α t α t ? 1 X t ? 2 + α t ( 1 ? α t ? 1 ) Z t ? 1 + 1 ? α t Z t \begin{align} \mathbf{X}_t&=\sqrt{\alpha_t}(\sqrt{\alpha_{t-1}}\mathbf{X}_{t-2}+\sqrt{1-\alpha_{t-1}}\mathbf{Z}_{t-1})+\sqrt{1-\alpha_t}\mathbf{Z}_t\\ &=\sqrt{\alpha_t\alpha_{t-1}}\mathbf{X}_{t-2}+\sqrt{\alpha_t(1-\alpha_{t-1})}\mathbf{Z}_{t-1}+\sqrt{1-\alpha_t}\mathbf{Z}_t \end{align} Xt??=αt? ?(αt?1? ?Xt?2?+1?αt?1? ?Zt?1?)+1?αt? ?Zt?=αt?αt?1? ?Xt?2?+αt?(1?αt?1?) ?Zt?1?+1?αt? ?Zt???其中都服从标准高斯分布,即:
Z ~ N ( 0 , 1 ) α t ( 1 ? α t ? 1 ) Z t ? 1 ~ N ( 0 , α t ( 1 ? α t ? 1 ) ) 1 ? α t Z t ~ N ( 0 , 1 ? α t ) \begin{align} \mathbf{Z}&\sim\mathcal{N}(0,1)\\ \sqrt{\alpha_t(1-\alpha_{t-1})}\mathbf{Z}_{t-1}&\sim\mathcal{N}(0,\alpha_t(1-\alpha_{t-1}))\\ \sqrt{1-\alpha_t}\mathbf{Z}_t&\sim\mathcal{N}(0,1-\alpha_t)\\ \end{align} Zαt?(1?αt?1?) ?Zt?1?1?αt? ?Zt??N(0,1)N(0,αt?(1?αt?1?))N(0,1?αt?)??根据高斯分布的相加性质,有:
α t ( 1 ? α t ? 1 ) Z t ? 1 + 1 ? α t Z t ~ N ( 0 , 1 ? α t α t ? 1 ) \sqrt{\alpha_t(1-\alpha_{t-1})}\mathbf{Z}_{t-1}+\sqrt{1-\alpha_t}\mathbf{Z}_t\sim\mathcal{N}(0,1-\alpha_t\alpha_{t-1}) αt?(1?αt?1?) ?Zt?1?+1?αt? ?Zt?N(0,1?αt?αt?1?)由此可得:
X t = α t α t ? 1 X t ? 2 + ( 1 ? α t α t ? 1 ) Z ˉ t ? 1 \mathbf{X}_t=\sqrt{\alpha_t\alpha_{t-1}}\mathbf{X}_{t-2}+\sqrt{(1-\alpha_t\alpha_{t-1})}\mathbf{\bar{Z}}_{t-1} Xt?=αt?αt?1? ?Xt?2?+(1?αt?αt?1?) ?Zˉt?1?如果继续往下求解,我们可以得到:
X t = α ˉ t X 0 + 1 ? α ˉ t Z ˉ 1 \mathbf{X}_t=\sqrt{\bar{\alpha}_t}\mathbf{X}_{0}+\sqrt{1-\bar{\alpha}_t}\mathbf{\bar{Z}_1} Xt?=αˉt? ?X0?+1?αˉt? ?Zˉ1?其中符号
α ˉ t = ∏ i = 1 t α i \bar{\alpha}_t=\prod_{i=1}^{t} \alpha_i αˉt?=i=1t?αi?由此可以看出,我们可以通过一步扩散能够生成任意时刻的噪声的图像,但我们的问题是如果从噪声图像恢复原始图像?能不能像上面一样一步生成,即求 p ( X 0 ∣ X t ) p(\mathbf{X}_0|\mathbf{X}_t) p(X0?Xt?) ,答案显然是否定的,降低难度,我们能不能一步一步从噪声图像恢复到原始图像?即求 p ( X t ? 1 ∣ X t ) p(\mathbf{X}_{t-1}|\mathbf{X}_t) p(Xt?1?Xt?) ,或许可以尝试一下,根据贝叶斯公式,有:
p ( X t ? 1 ∣ X t ) = p ( X t ∣ X t ? 1 ) p ( X t ) p ( X t ? 1 ) p(\mathbf{X}_{t-1}|\mathbf{X}_t)=p(\mathbf{X}_{t}|\mathbf{X}_{t-1})\frac{p(\mathbf{X}_{t})}{p(\mathbf{X}_{t-1})} p(Xt?1?Xt?)=p(Xt?Xt?1?)p(Xt?1?)p(Xt?)?等号右边第一项我们是知道的,但分式上下的概率我们是未知的,因此我们考虑引入参数 X 0 \mathbf{X}_0 X0?,则等式变为:
p ( X t ? 1 ∣ X t , X 0 ) = p ( X t ∣ X t ? 1 , X 0 ) p ( X t ∣ X 0 ) p ( X t ? 1 ∣ X 0 ) p(\mathbf{X}_{t-1}|\mathbf{X}_t,\mathbf{X}_0)=p(\mathbf{X}_{t}|\mathbf{X}_{t-1},\mathbf{X}_0)\frac{p(\mathbf{X}_{t}|\mathbf{X}_0)}{p(\mathbf{X}_{t-1}|\mathbf{X}_0)} p(Xt?1?Xt?,X0?)=p(Xt?Xt?1?,X0?)p(Xt?1?X0?)p(Xt?X0?)?这个式子便可以用到上面推导的结论。其中
p ( X t ∣ X t ? 1 , X 0 ) = α t X t ? 1 + 1 ? α t Z t ~ N ( α t X t ? 1 , 1 ? α t ) p ( X t ∣ X 0 ) = α ˉ t X 0 + 1 ? α ˉ t Z ˉ ~ N ( α ˉ t X 0 , 1 ? α ˉ t ) p ( X t ? 1 ∣ X 0 ) = α ˉ t ? 1 X 0 + 1 ? α ˉ t ? 1 Z ˉ ~ N ( α ˉ t ? 1 X 0 , 1 ? α ˉ t ? 1 ) \begin{align} p(\mathbf{X}_{t}|\mathbf{X}_{t-1},\mathbf{X}_0)&=\sqrt{\alpha_t}\mathbf{X}_{t-1}+\sqrt{1-\alpha_t}\mathbf{Z}_t\sim\mathcal{N}(\sqrt{\alpha_t}\mathbf{X}_{t-1}, 1-\alpha_t)\\ p(\mathbf{X}_{t}|\mathbf{X}_0)&=\sqrt{\bar{\alpha}_t}\mathbf{X}_{0}+\sqrt{1-\bar{\alpha}_t}\mathbf{\bar{Z}}\sim\mathcal{N}(\sqrt{\bar{\alpha}_t}\mathbf{X}_{0}, 1-\bar{\alpha}_t)\\ p(\mathbf{X}_{t-1}|\mathbf{X}_0)&=\sqrt{\bar{\alpha}_{t-1}}\mathbf{X}_{0}+\sqrt{1-\bar{\alpha}_{t-1}}\mathbf{\bar{Z}}\sim\mathcal{N}(\sqrt{\bar{\alpha}_{t-1}}\mathbf{X}_{0}, 1-\bar{\alpha}_{t-1}) \end{align} p(Xt?Xt?1?,X0?)p(Xt?X0?)p(Xt?1?X0?)?=αt? ?Xt?1?+1?αt? ?Zt?N(αt? ?Xt?1?,1?αt?)=αˉt? ?X0?+1?αˉt? ?ZˉN(αˉt? ?X0?,1?αˉt?)=αˉt?1? ?X0?+1?αˉt?1? ?ZˉN(αˉt?1? ?X0?,1?αˉt?1?)??根据高斯分布的表达式,既有:
p ( X t ? 1 ∣ X t , X 0 ) ∝ e x p { ? 1 2 ( ( X t ? α t X t ? 1 ) 2 1 ? α t + ( X t ? α ˉ t X 0 ) 2 1 ? α ˉ t ? ( X t ? 1 ? α ˉ t ? 1 X 0 ) 2 1 ? α ˉ t ? 1 ) } ∝ e x p { ? 1 2 ( ( α t β t + 1 1 ? α ˉ t ? 1 ) X t ? 1 2 ? ( 2 α t β t x t + 2 α ˉ t ? 1 1 ? α ˉ t ? 1 X 0 ) X t ? 1 + C ( X t , X 0 ) ) } \begin{align} p(\mathbf{X}_{t-1}|\mathbf{X}_t,\mathbf{X}_0)&\propto \mathbf{exp}\{-\frac{1}{2}\left(\frac{(\mathbf{X}_t-\sqrt{\alpha_t}\mathbf{X}_{t-1})^2}{1-\alpha_t}+\frac{(\mathbf{X}_{t}-\sqrt{\bar{\alpha}_{t}}\mathbf{X}_{0})^2}{1-\bar{\alpha}_{t}}-\frac{(\mathbf{X}_{t-1}-\sqrt{\bar{\alpha}_{t-1}}\mathbf{X}_{0})^2}{1-\bar{\alpha}_{t-1}}\right)\}\\ &\propto \mathbf{exp}\{-\frac{1}{2}\left(\left(\frac{\alpha_t}{\beta_t}+\frac{1}{1-\bar{\alpha}_{t-1}}\right)\mathbf{X}_{t-1}^2-\left(\frac{2\sqrt{\alpha_t}}{\beta_t}\mathbf{x}_t+\frac{2\sqrt{\bar{\alpha}_{t-1}}}{1-\bar{\alpha}_{t-1}}\mathbf{X}_0 \right)\mathbf{X}_{t-1}+\mathbf{C}(\mathbf{X}_t,\mathbf{X}_0) \right)\} \end{align} p(Xt?1?Xt?,X0?)?exp{?21?(1?αt?(Xt??αt? ?Xt?1?)2?+1?αˉt?(Xt??αˉt? ?X0?)2??1?αˉt?1?(Xt?1??αˉt?1? ?X0?)2?)}exp{?21?((βt?αt??+1?αˉt?1?1?)Xt?12??(βt?2αt? ??xt?+1?αˉt?1?2αˉt?1? ??X0?)Xt?1?+C(Xt?,X0?))}??高斯分布的的指数项为:
e x p { ? 1 2 ( 1 σ 2 x 2 ? 2 μ σ 2 x + μ 2 σ 2 ) } , \mathbf{exp}\{-\frac{1}{2}\left( \frac{1}{\sigma_2}x^2-\frac{2\mu}{\sigma^2}x+\frac{\mu^2}{\sigma^2}\right)\}, exp{?21?(σ2?1?x2?σ22μ?x+σ2μ2?)}由此可以反解出对应的均值和方差,方差 σ \sigma σ 中的参数都是已知的,但均值 μ \mu μ X 0 \mathbf{X}_0 X0? X t \mathbf{X}_t Xt? 有关系,但图 X 0 \mathbf{X}_0 X0? 正是我们需要求解的,因此我们用一步扩散公式使用 X t \mathbf{X}_t Xt?代替 X 0 \mathbf{X}_0 X0?,反解得到:
σ 2 = 1 α t β t + 1 1 ? α ˉ t ? 1 μ = 1 α t ( X t ? β t 1 ? α ˉ t Z ˉ t ) \begin{align} \sigma^2 &= \frac{1}{\frac{\alpha_t}{\beta_t}+\frac{1}{1-\bar{\alpha}_{t-1}}}\\ \mu&=\frac{1}{\sqrt{\alpha_t}}(\mathbf{X}_t-\frac{\beta_t}{\sqrt{1-\bar{\alpha}_t}}\mathbf{\bar{Z}}_t) \end{align} σ2μ?=βt?αt??+1?αˉt?1?1?1?=αt? ?1?(Xt??1?αˉt? ?βt??Zˉt?)??
现在均值和方差中只有参数 Z ˉ t \bar{Z}_t Zˉt? 是未知的,因此我们需要用神经网络来进行预测。下面是算法伪代码:

在这里插入图片描述
仔细看伪代码,训练过程中学的是什么?学习的就是从原始图像 X 0 \mathbf{X}_0 X0? 一步扩散得到第 t t t 时刻加噪声图像所加的噪声 Z ˉ t \mathbf{\bar{Z}}_t Zˉt?

文章来源:https://blog.csdn.net/weixin_50232758/article/details/135214619
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。