VAE理解までの道のり #3

公開:
機械学習 #VAE

Variational Autoencoder(VAE)を理解するまでの道のりの第 3 回目のブログです。内容が重複する部分もありますが、復習も兼ねて議論していきたいと思います。

VAE

生成モデル(generative models)とは、対象ドメイン(画像、音声、etc)のデータを生成できるモデルのことです。データを用いて対象ドメインの分布 pθ(x)p_\theta(x) を学習することで、そこからのサンプリングによって

xpθ(x)x \sim p_\theta(x)

新しいデータを生成することができるようになります。生成モデルのうちここでは、隠れ変数 zz をもつモデル pθ(x,z)p_\theta(x, z) について考えます。

モデルの学習(パラメータ θ\theta の決定)には一般的には最尤法を用いることができます、潜在変数を持つモデルでは確率分布が計算不能(intractability)であることから一筋縄では学習することができないという問題があります。当該の生成モデルの周辺確立は

pθ(x)=pθ(x,z)dzp_\theta(x) = \int p_\theta(x, z) dz

と計算することができ、実際の生成の際には pθ(x)p_\theta(x) からのサンプリングが必要になります。しかし、

pθ(x,z)=pθ(zx)pθ(x)p_\theta(x, z) = p_\theta(z|x)p_\theta(x)

において posterior probability pθ(zx)p_\theta(z|x) が intractable であることから周辺確率 pθ(x)p_\theta(x) も intractable な性質を持つことになります。そのため直接的に最尤法を用いて

logpθ(x)\log p_\theta(x)

を計算して学習することは不可能であり、この問題をどのように解決するかによって各手法が提案されています。

Evidence Lower Bound (ELBO)

前提

ここでの問題は、潜在変数 zz をもつモデルの学習を行いたいが logpθ(x)\log p_\theta(x) を直接計算することができないという点です。そのため一般的な変分推論の枠組みでは logpθ(x)\log p_\theta(x) の下限値(evidence lower bound; ELBO)を導出することで、ELBO の最適化問題に置き換えて考え行く手法が採られます。

潜在変数に関する任意の確率分布 q(z)q(z) を用いることで、対数尤度は次のように変形できます。

logpθ(x)=q(z)logpθ(x,z)q(z)dz+q(z)logq(z)pθ(zx)dz=L(q(z),θ)+DKL(q(z)p(zx))\begin{aligned} \log p_\theta(x) &= \int q(z) \log \frac{p_\theta(x, z)}{q(z)}dz + \int q(z) \log \frac{q(z)}{p_\theta(z|x)} dz \\\\ &= L(q(z), \theta) + D_{KL}(q(z)||p(z|x)) \end{aligned}

第二項はカルバック・ライブラー情報量であり非負の値であることから

logpθ(x)=L(q(z),θ)\begin{aligned} \log p_\theta(x) \geq &= L(q(z), \theta) \end{aligned}

の関係式が導出でき、このことから L(q(z),θ)L(q(z), \theta) が evidence lower bound と呼ばれます。

EM アルゴリズムにおける ELBO について

EM アルゴリズムは潜在変数を持つモデルの学習手法のひとつで、上述の

logpθ(x)=L(q(z),θ)+DKL(q(z)p(zx))\log p_\theta(x) = L(q(z), \theta) + D_{KL}(q(z)||p(z|x))

の関係式を使って逐次的に最適化を行う手法です。以下に簡単に概要をまとめておきます。

E ステップ

まず、パラメータ θ\theta をある値 θold\theta^{\rm{old}} に初期化し、q(z)q(z) に関して L(q,θold)L(q, \theta^{\rm{old}}) を最大化します。logpθ(x)\log p_\theta(x)q(z)q(z) に依存しないため定数となり、

logpθold(x)=Cost.=L(q(z),θold)+DKL(q(z)pθold(zx))\log p_{\theta^{\rm{old}}}(x) = Cost. = L(q(z), \theta^{\rm{old}}) + D_{KL}(q(z)||p_{\theta^{\rm{old}}}(z|x))

の関係から、LL が最大となるためには DKL(q(z)p(zx))=0D_{KL}(q(z)||p(z|x)) = 0 となればいいことが分かります。カルバック・ライブラー情報量の性質から

q(z)=pθold(zx)q(z) = p_{\theta^{\rm{old}}}(z|x)

の場合であることが分かり、E ステップを終えます。

図の説明

M ステップ

続いて M ステップでは

q(z)=pθold(zx)q(z) = p_{\theta^{\rm{old}}}(z|x)

と固定した状態で L(q(z),θ)L(q(z), \theta)θ\theta に関して最大化し、θnew\theta^{\rm{new}} を求めます。このとき

DKL(q(z)pθnew(zx))0D_{KL}(q(z)||p_{\theta^{\rm{new}}}(z|x)) \neq 0

となるので、再度 E ステップを実行することになります。

図の説明

VAE における ELBO について

EM アルゴリズムでは逐次的に ELBO の最適化問題を解くことで、θ\theta を求めていきました。その一方で VAE では、学習可能なパラメーター ϕ\phi を持った近似分布

qϕ(zx)pθ(zx)q_\phi(z|x) \simeq p_\theta(z|x)

を導入し、これを用いて ELBO の最適化を行います。

それではまず、ELBO を導出してみます。以下の導出は qϕ(zx)q(z)q_\phi(z|x) \to q(z) と置き換えることで、一般的な ELBO の導出過程と等しくなることに留意して下さい。

logpθ(x)=qϕ(zx)logpθ(x)dz=qϕ(zx)logpθ(x,z)pθ(zx)dz=qϕ(zx)logpθ(x,z)qϕ(zx)qϕ(zx)pθ(zx)dz=qϕ(zx)logpθ(x,z)qϕ(zx)dz+qϕ(zx)logqϕ(zx)pθ(zx)dz\begin{aligned} \log p_\theta(x) &= \int q_\phi(z|x) \log p_\theta(x) dz \\\\ &= \int q_\phi(z|x) \log \frac{p_\theta(x, z)}{p_\theta(z|x)} dz \\\\ &= \int q_\phi(z|x) \log \frac{p_\theta(x, z)}{q_\phi(z|x)}\frac{q_\phi(z|x)}{p_\theta(z|x)} dz \\\\ &= \int q_\phi(z|x) \log \frac{p_\theta(x, z)}{q_\phi(z|x)}dz + \int q_\phi(z|x) \log \frac{q_\phi(z|x)}{p_\theta(z|x)} dz \\\\ \end{aligned}

一行目は qϕ(zx) dz=1\int q_\phi(z|x)~dz = 1 を、二行目はベイズの定理を用いています。

第二項目は

DKL(qϕ(zx)pθ(zx))=qϕ(zx)logqϕ(zx)pθ(zx)0D_{KL}(q_\phi(z|x)|| p_\theta(z|x)) = \int q_\phi(z|x) \log \frac{q_\phi(z|x)}{p_\theta(z|x)} \geq 0

カルバック・ライブラー情報量と呼ばれる “距離” に関するものです。真の事後確率分布 pθ(zx)p_\theta(z|x) と、近似分 q 布 qϕ(zx)q_\phi(z|x) との近さの度合いを表しています。非負の値であることから対数尤度は、

logpθ(x)qϕ(zx)logpθ(x,z)qϕ(zx)dzLθ,ϕ(x)\log p_\theta(x) \geq \int q_\phi(z|x) \log \frac{p_\theta(x, z)}{q_\phi(z|x)}dz \equiv L_{\theta,\phi}(x)

第一項を下限値に取ることが分かります。この項こそ Evidence Lower Bound(ELBO)と呼ばれる量で、一般的に変分推論で解析不能な対数尤度の代わりに用いられるものです(上記の導出はその他にイェンセンの不等式を用いる方法もあります)。

また以下の様な式変形をしておきます。

Lθ,ϕ(x)=logpθ(x)DKL(qϕ(zx)pθ(zx))L_{\theta,\phi}(x) = \log p_\theta(x) - D_{KL}(q_\phi(z|x)|| p_\theta(z|x))

これらの関係式を眺めつつ、ELBO を最適化(最大化)することで次のことが言えます。

  1. ELBO は logpθ(x)\log p_\theta(x) の下限値であることから、ELBO を最大化すると(間接的に)対数尤度の最大化に繋がり、モデルパラメータが決まります
  2. ELBO を最大化すると logpθ(x)DKL(qϕ(zx)pθ(zx))\log p_\theta(x) - D_{KL}(q_\phi(z|x)|| p_\theta(z|x)) においてカルバック・ライブラー情報量が小さくなることが分かり、qϕ(zx)pθ(zx)q_\phi(z|x) \simeq p_\theta(z|x) のように近似精度が上がっていきます

ここまでは通常の変分推論に関する概要で、ELBO Lθ,ϕ(x)L_{\theta,\phi}(x) をどのように最大化するかによって各手法へと分岐していきます。

用語について

符号理論(coding theory)の観点から、観測されない変数である潜在変数 zz は latent representation もしくは code と呼ばれます。そのため、VAE の論文では

qϕ(zx)q_\phi(z|x)

を、データ xx を code である zz へと変換するという意味合いで確率的なエンコーダ(encoder)と定義しています。また、潜在変数 zz からデータ xx を予測するという意味で

pθ(xz)p_\theta(x|z)

を確率的なデコーダー(decoder)と呼んでいます。

VAE

目標は事後分布である

pθ(zx)p_\theta(z|x)

を推定することなのですが、これまで見てきたように通常解析的には求まらないため近似計算手法を導入するというストーリになります。VAE では

  1. 変分下界(Evidence Lower Bound; ELBO)
  2. 償却推論(Amortized inference)
  3. 再パラメータ化トリック(Reparametrization trick)

の3つのアイデアを元に、近似事後分布の計算を行います。

償却変分推論 (amortized variational inference)

事後分布を求めるための近似手法の一つとして、変分推論(variational inference)という手法があります。これはパラメータ化された分布

qϕ(zx)pθ(zx)q_\phi(z|x) \simeq p_\theta(z|x)

を近似事後分布として導入し、パラメータ ϕ\phi を最適化することで分布の形を求めるというものです。分布そのものを “変数” として求めるため、変分という名称が使用されています。

近似事後分布の求め方の一つに平均場近似と呼ばれる手法があります。この手法では近似分布がいくつかの分布の積で表すことができるという仮定のもとで

pθ(zx)q(zϕ)=i=1Nq(ziϕi)p_\theta(z|x) \simeq q(z|\phi) = \prod_{i=1}^N q(z_i|\phi_i)

とすることで近似計算を行っていきます。ここでは潜在変数 z=z1,z2,...,zNz=\\{z_1,z_2,...,z_N\\} に対して変分パラメータ ϕ=ϕ1,ϕ2,...,ϕN\phi =\\{\phi_1, \phi_2,...,\phi_N\\} が対応しているとしています。ただし変分パラメータは事前にデータ点に対して最適な値を求めているため、直接データ xx に対する条件付き確率となっていないことに留意して下さい。また、zz に対して ϕ\phi の個数は一致している必要はなく、例えば q()q(\cdot) にガウス分布を使用する場合であれば潜在変数 zz 一つに対して、ϕ=μ,σ\phi=\mu, \sigma の二つの変分パラメータが対応することになります。

上記の定義から分かるように、典型的な変分推論(ex. 平均場近似)ではデータ点 xix_i ごとに変分パラメータ ϕi\phi_i の最適化が必要となるため、大規模なデータセットや新しいデータセットの推論が取り扱いにくいという問題がありました[1]

そこで償却変分推論ではデータ点ごとに変分パラメータを求めるのではなく、観測空間 X\Chi から確率密度関数空間 PP に写像するパラメトリックな関数 fϕf_\phi を導入することでこの問題に対処していきます[2]

まず、以下の平均場近似を考えます。

qϕ(zx)=i=1Nqϕ(zixi)q_\phi(z|x) = \prod_{i=1}^N q_\phi(z_i|x_i)

このときに一般的には多変量ガウス分布を用いて

qϕ(zixi)=N(ziμ(xi),σ2(xi)I)q_\phi(z_i|x_i) = N(z_i| \mu(x_i), \sigma^2(x_i)I)

のように定義します。ここで μ,σ\mu, \sigma はデータ点 xix_i をそれぞれガウス分布の平均値、分散に変換する非線形写像です。つまり償却変分推論とは、ニューラルネットワークなどのパラメトリックな関数を用いて変分パラメータを求め、それらを用いて事後分布を近似する手法です。


脚注

  1. Advances in Variational Inference ↩︎
  2. 集合を扱う償却変分推論 ↩︎