当前位置: 首页 > article >正文

面对配分函数 - 噪扰对比估计(NCE)篇

序言

配分函数(也叫归一化因子)在概率分布和统计模型的计算中扮演着至关重要的角色。然而,在许多实际应用中,特别是自然语言处理和图像处理领域,配分函数的计算往往异常复杂且难以直接实现。为了解决这一难题,噪音对比估计( Noise Contrastive Estimation,NCE \text{Noise Contrastive Estimation,NCE} Noise Contrastive EstimationNCE)应运而生。NCE是一种巧妙的统计模型估计方法,它能够在无法直接计算配分函数的情况下,估算出概率分布的参数。

噪扰对比估计(NCE)

  • 具有难求解的配分函数的大多数模型估计都没有估计配分函数。 SML \text{SML} SML CD \text{CD} CD只估计对数配分函数的梯度,而不是估计配分函数本身。 得分匹配和伪似然避免了和配分函数相关的计算。

  • 噪扰对比估计 noise-contrastive estimation, NCE \text{noise-contrastive estimation, NCE} noise-contrastive estimation NCE) ( Gutmann and Hyvarinen, 2010 \text{Gutmann and Hyvarinen, 2010} Gutmann and Hyvarinen, 2010) 采取了一种不同的策略。在这种方法中,模型估计的概率分布被明确表示为:
    log ⁡ p model ( x ) = log ⁡ p ~ model ( x ; θ ) + c \log p_{\text{model}}(\textbf{x})=\log\tilde{p}_{\text{model}}(\textbf{x};\boldsymbol{\theta})+c logpmodel(x)=logp~model(x;θ)+c — 公式1 \quad\textbf{---\footnotesize{公式1}} 公式1

  • 其中 c c c − log ⁡ Z ( θ ) − \log Z(\boldsymbol{\theta}) logZ(θ) 的近似。不仅仅估计 θ \boldsymbol{\theta} θ, 噪扰对比估计过程将 c c c 视为另一参数,使用相同的算法同时估计 θ \boldsymbol{\theta} θ c c c。因此,所得到的 log ⁡ p model ( x ) \log p_{\text{model}}(\textbf{x}) logpmodel(x) 可能不完全对应有效的概率分布,但随着 c c c 估计的改进,它将变得越来越接近 有效 值 注 1 有效值^{注1} 有效1

  • 这种方法不可能使用最大似然作为估计的标准。最大似然标准可以设置 c c c 为任意大的值,而不是设置 c c c 以创建一个有效的概率分布。

  • NCE \text{NCE} NCE将估计 p ( x ) p(\textbf{x}) p(x) 的无监督学习问题转化为学习一个概率二元分类器,其中一个类别对应模型生成的数据。该监督学习问题中的最大似然学习定义了原始问题的渐近一致估计。

  • 具体来说,我们引入第二个分布, 噪扰分布 ( noise distribution \text{noise distribution} noise distribution) p noise ( x ) p_{\text{noise}}(\textbf{x}) pnoise(x)。 噪扰分布应该易于估计和从中取样。我们现在可以构造一个联合 x \textbf{x} x 和新二元变量 y y y 的模型。在新的联合模型中,我们指定:
    p joint ( y = 1 ) = 1 2 p_{\text{joint}}(y=1)=\displaystyle\frac{1}{2} pjoint(y=1)=21 — 公式2 \quad\textbf{---\footnotesize{公式2}} 公式2
    p joint ( x ∣ y = 1 ) = p model ( x ) p_{\text{joint}}(\textbf{x}\mid y=1)=p_{\text{model}}(\textbf{x}) pjoint(xy=1)=pmodel(x) — 公式3 \quad\textbf{---\footnotesize{公式3}} 公式3

    p joint ( x ∣ y = 0 ) = p noise ( x ) p_{\text{joint}}(\textbf{x}\mid y=0)=p_{\text{noise}}(\textbf{x}) pjoint(xy=0)=pnoise(x) — 公式4 \quad\textbf{---\footnotesize{公式4}} 公式4

  • 换言之, y y y 是一个决定我们从模型还是从噪扰分布中生成 x \textbf{x} x 的开关变量。

  • 我们可以在训练数据上构造一个类似的联合模型。

    • 在这种情况下,开关变量决定是从数据还是从噪扰分布中抽取 x \textbf{x} x
    • 形式地, p train ( y = 1 ) = 1 2 p_{\text{train}}(y = 1) =\displaystyle\frac{1}{2} ptrain(y=1)=21 p train ( x ∣ y = 1 ) = p data ( x ) p_{\text{train}}(\textbf{x} \mid y = 1) =p_{\text{data}}(\textbf{x}) ptrain(xy=1)=pdata(x),和 p train ( x ∣ y = 0 ) = p noise ( x ) p_{\text{train}}(\textbf{x} \mid y = 0) = p_{\text{noise}}(\textbf{x}) ptrain(xy=0)=pnoise(x)

注1: NCE \text{NCE} NCE也适用于具有易于处理的,不需要引入额外参数 c c c 的配分函数的问题。它已经是最令人感兴趣的,估计具有复杂配分函数模型的方法。


  • 现在我们可以应用标准的最大似然学习拟合 p joint p_{\text{joint}} pjoint p train p_{\text{train}} ptrain 的监督学习问题:
    θ , c = arg max ⁡ θ , c E x , y ∼   p train log ⁡ p joint ( y ∣ x ) \boldsymbol{\theta},c=\argmax\limits_{\boldsymbol{\theta},c} \mathbb{E}_{\textbf{x},\text{y}\sim\ p_{\text{train}}} \log p_{\text{joint}}(y\mid\textbf{x}) θ,c=θ,cargmaxEx,y ptrainlogpjoint(yx) — 公式5 \quad\textbf{---\footnotesize{公式5}} 公式5

  • 分布 p joint p_{\text{joint}} pjoint 本质上是将逻辑回归模型应用于模型和噪扰分布之间的对数概率之差:
    { p joint ( y = 1 ∣ x ) = p model ( x ) p model ( x ) + p noise ( x ) — 公式6 = 1 1 + p noise ( x ) p model ( x ) — 公式7 = 1 1 + e log ⁡ p noise ( x ) p model ( x ) — 公式8 = σ ( − log ⁡ p noise ( x ) p model ( x ) ) — 公式9 = σ ( log ⁡ p model ( x ) − log ⁡ p noise ( x ) ) — 公式10 \begin{cases} \begin{aligned} p_{\text{joint}}(y=1\mid\textbf{x})&=\frac{p_{\text{model}}(\textbf{x})}{p_{\text{model}}(\textbf{x})+p_{\text{noise}}(\textbf{x})} &\quad\textbf{---\footnotesize{公式6}}\\\\ &=\frac{1}{1+\displaystyle\frac{p_{\text{noise}}(\textbf{x})}{p_{\text{model}}(\textbf{x})}} &\quad\textbf{---\footnotesize{公式7}}\\\\ &=\displaystyle\frac{1}{1+ e^{\log \displaystyle\frac{p_{\text{noise}}(\textbf{x})}{p_{\text{model}}(\textbf{x})}}} &\quad\textbf{---\footnotesize{公式8}}\\\\ &=\sigma\left(-\log \displaystyle\frac{p_{\text{noise}}(\textbf{x})}{p_{\text{model}}(\textbf{x})}\right) &\quad\textbf{---\footnotesize{公式9}}\\\\ &=\sigma\left( \log p_{\text{model}}(\textbf{x})-\log p_{\text{noise}}(\textbf{x}) \right) &\quad\textbf{---\footnotesize{公式10}} \end{aligned} \end{cases} pjoint(y=1x)=pmodel(x)+pnoise(x)pmodel(x)=1+pmodel(x)pnoise(x)1=1+elogpmodel(x)pnoise(x)1=σ(logpmodel(x)pnoise(x))=σ(logpmodel(x)logpnoise(x))公式6公式7公式8公式9公式10

  • 因此,只要 log ⁡ p ~ model \log \tilde{p}_{\text{model}} logp~model 易于反向传播,并且如上所述, p noise p_{\text{noise}} pnoise 应易于估计(以便评估 p joint p_{\text{joint}} pjoint)和抽样(以生成训练数据),那么 NCE \text{NCE} NCE就易于使用。

  • NCE \text{NCE} NCE能够非常成功地应用于随机变量较少的问题,即使这些随机变量取到很大的值,它也很有效。

    • 例如,它已经成功地应用于给定单词上下文建模单词的条件分布 ( Mnih and Kavukcuoglu, 2013 \text{Mnih and Kavukcuoglu, 2013} Mnih and Kavukcuoglu, 2013)。
    • 虽然单词可以采样自一个很大的词汇表,但是只能采样一个单词。
  • NCE \text{NCE} NCE应用于具有许多随机变量的问题时,其效率会变得较低。

    • 当逻辑回归分类器发现某个变量的取值不大可能时,它会拒绝这个噪扰样本。
    • 这意味着在 p model p_{\text{model}} pmodel学习了基本的边缘统计之后,学习速率会大大减慢。
    • 想象一个使用非结构化高斯噪扰作为 p noise p_{\text{noise}} pnoise 来学习面部图像的模型。
    • 如果 p model p_{\text{model}} pmodel 学习了眼睛,而没有学习任何其他面部特征,如嘴,它会拒绝几乎所有的非结构化噪扰样本。
  • p noise p_{\text{noise}} pnoise必须是易于估计和采样的约束可能是过度的限制。当 p noise p_{\text{noise}} pnoise 比较简单时,大多数采样可能与数据有着明显不同,而不会迫使 p model p_{\text{model}} pmodel 进行显著改进。

  • 类似于得分匹配和伪似然,如果 p p p 只有下界,那么 NCE \text{NCE} NCE不会有效。

    • 这样的下界能够用于构建 p joint ( y = 1 ∣ x ) p_{\text{joint}}(y = 1 \mid \textbf{x}) pjoint(y=1x) 的下界,但是它只能用于构建 p joint ( y = 0 ∣ x ) p_{\text{joint}}(y = 0 \mid \textbf{x}) pjoint(y=0x)(出现在一般的 NCE \text{NCE} NCE对象中)的上界。
    • 同样地, p noise p_{\text{noise}} pnoise 的下界也没有用,因为它只提供了 p joint ( y = 1 ∣ x ) p_{\text{joint}}(y = 1 \mid \textbf{x}) pjoint(y=1x) 的上界。
  • 当在每个梯度步骤之前,模型分布被复制来定义新的噪扰分布时, NCE \text{NCE} NCE定义了一个被称为自对比估计的过程,其梯度期望等价于最大似然的梯度期望 ( Goodfellow, 2014 \text{Goodfellow, 2014} Goodfellow, 2014)。特殊情况的 NCE \text{NCE} NCE( 噪扰采样由模型生成)表明最大似然可以被解释为使模型不断学习以将现实与自身发展的信念区分的过程,而噪扰对比估计通过让模型区分现实和固定的基准( 噪扰模型),降低了计算成本。

  • 在训练样本和生成样本(使用模型能量函数定义分类器)之间进行分类以得到模型的梯度的方法,已经在更早的时候以各种形式提出来 ( Welling et al., 2003b; Bengio, 2009 \text{Welling et al., 2003b; Bengio, 2009} Welling et al., 2003b; Bengio, 2009)。

  • 噪扰对比估计是基于良好生成模型应该能够区分数据和噪扰的想法。一个密切相关的想法是,良好的生成模型能够生成分类器没法将其与数据区分的采样。这个想法诞生了生成式对抗网络。

总结

噪音对比估计( NCE \text{NCE} NCE)作为一种创新的统计模型估计方法,为解决配分函数难以计算的问题提供了有效的策略。通过将多分类问题转化为二分类问题, NCE \text{NCE} NCE不仅简化了计算过程,还提高了模型的训练效率。在自然语言处理和图像处理等复杂任务中, NCE \text{NCE} NCE展现了其出色的性能和广泛的应用前景。

具体而言, NCE \text{NCE} NCE通过对比真实数据和噪声样本,学习一个分类器以区分两者,从而实现对数据分布的有效估计。这种方法避免了直接计算配分函数的困难,转而通过优化二分类问题的损失函数来间接估算概率分布的参数。在实际应用中, NCE \text{NCE} NCE不仅降低了计算量,还提高了模型的泛化能力。

综上所述,噪音对比估计为配分函数的计算提供了一种新的思路和方法,它在解决复杂计算问题和提高模型性能方面具有显著的优势。随着研究的深入和应用的拓展, NCE \text{NCE} NCE有望在更多领域发挥重要作用,推动机器学习和统计模型的发展。

往期内容回顾

面对配分函数 - 引言篇


http://www.kler.cn/news/355825.html

相关文章:

  • windows的CMD命令提示符
  • 用 Python 构建高级配对交易策略
  • C++算法练习-day7——707.设计链表
  • 【Git】将其它分支的单个改动复制到当前分支
  • 基于ESP32的便携式游戏机
  • Elasticsearch Inference API 增加对阿里云 AI 的支持
  • 021_Thermal_Transient_in_Matlab统一偏微分框架之热传导问题
  • Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
  • 【2D/3D-Lidar-SLAM】 Cartographer详细解读
  • PCDN 技术如何优化网络延迟(壹)
  • 如何快速学会盲打
  • c++流的异常捕获
  • 使用 surya-ocr 进行文字识别
  • Python 连接和操作 PostgreSQL 数据库的详解
  • Python——判定变量是空还是非空的有效方法
  • 【MySQL 数据库】之--基础知识
  • C++面试速通宝典——27
  • 使用big.js处理js精度缺失的问题
  • Linux发展与基础
  • C++《string的模拟实现》