深度学习中的结构化概率模型 - 结构化概率模型的深度学习方法篇

序言

在深度学习的广阔领域中,结构化概率模型( Structured Probabilistic Model \text{Structured Probabilistic Model} Structured Probabilistic Model)扮演着至关重要的角色。这类模型利用图论中的图结构来表示概率分布中随机变量之间的复杂关系,为处理高维、结构丰富的数据(如图像、语音、文本等)提供了强有力的工具。结构化概率模型不仅降低了表示概率分布所需的参数数量,还显著提升了模型的学习与推断效率,成为深度学习研究中的关键组成部分。

结构化概率模型的深度学习方法

  • 深度学习实践者通常使用与从事结构化概率模型研究的其它机器学习研究者相同的基本计算工具。然而,在深度学习中,我们通常对如何组合这些工具做出不同的设计,导致总体算法、模型与更传统的图模型具有非常不同的风格。

  • 深度学习并不总是涉及特别深的图模型知识。

    • 在图模型中,我们可以根据图模型的图而不是计算图来定义模型的深度。
    • 如果从潜变量 h i h_i hi 到可观察变量的最短路径是 j j j 步,我们可以认为潜变量 h j h_j hj 处于深度 j j j
    • 我们通常将模型的深度描述为任何这样的 h j h_j hj 的最大深度。
    • 这种深度不同于由计算图定义的深度。
    • 用于深度学习的许多生成模型没有潜变量或只有一层潜变量,但使用深度计算图来定义模型中的条件分布。
  • 深度学习基本上总是利用分布式表示的思想。即使是用于深度学习目的的浅层模型(例如预训练浅层模型,稍后将形成深层模型),也几乎总是具有单个大的潜变量层。 深度学习模型通常具有比可观察变量更多的潜变量。变量之间复杂的非线性相互作用通过多个潜变量的间接连接来实现。

  • 相比之下,传统的图模型通常包含至少是偶尔观察到的变量,即使一些训练样本中的许多变量随机地丢失。传统模型大多使用高阶项和结构学习来捕获变量之间复杂的非线性相互作用。如果有潜变量,它们通常数量很少。

  • 潜变量的设计方式在深度学习中也有所不同。

    • 深度学习实践者通常不希望潜变量提前包含了任何特定的含义——训练算法可以自由地开发对特定数据集建模所需要的概念。
    • 在事后解释潜变量通常是很困难的,但是可视化技术可以得到它们表示的一些粗略表征。
    • 当潜变量在传统图模型中使用时,它们通常被赋予具有一些特定含义——比如文档的主题、学生的智力、导致患者症状的疾病等。
    • 这些模型通常由研究者解释,并且通常具有更多的理论保证,但是不能扩展到复杂的问题,并且不能像深度模型一样在许多不同背景中重复使用。
  • 另一个明显的区别是深度学习方法中经常使用的连接类型。

    • 深度图模型通常具有大的与其他单元组全连接的单元组,使得两个组之间的相互作用可以由单个矩阵描述。
    • 传统的图模型具有非常少的连接,并且每个变量的连接选择可以单独设计。
    • 模型结构的设计与推断算法的选择紧密相关。
    • 图模型的传统方法通常旨在保持精确推断的可追踪性。
    • 当这个约束太强的时候,我们可以采用一种流行的被称为是环状信念传播 ( loopy belief propagation \text{loopy belief propagation} loopy belief propagation) 的近似推断算法。
    • 这两种方法通常在稀疏连通图上有很好的效果。
    • 相比之下,在深度学习中使用的模型倾向于将每个可见单元 v i \text{v}_i vi 连接到非常多的隐藏单元 h j \text{h}_j hj 上,从而使得 h \textbf{h} h 可以获得一个 v i \text{v}_i vi 的分布式表示(也可能是其他几个可观察变量)。
    • 分布式表示具有许多优点,但是从图模型和计算复杂性的观点来看,分布式表示有一个缺点就是对于精确推断和环状信念传播等传统技术来说很难使用不够稀疏的图。
    • 结果,大尺度图模型和深度图模型最大的区别之一就是深度学习中几乎从来不会使用环状信念传播。
    • 相反的,许多深度学习模型可以用来加速 Gibbs \text{Gibbs} Gibbs 采样或者变分推断。
    • 此外,深度学习模型包含了大量的潜变量,使得高效的数值计算代码显得格外重要。
    • 除了选择高级推断算法之外,这提供了另外的动机,用于将结点分组成层,相邻两层之间用一个矩阵来描述相互作用。
    • 这要求实现算法的单个步骤可以实现高效的矩阵乘积运算,或者专门适用于稀疏连接的操作,例如块对角矩阵乘积或卷积。
  • 最后,图模型的深度学习方法的一个主要特征在于对未知量的较高容忍度。

    • 与简化模型直到它的每一个量都可以被精确计算不同的是,我们仅仅直接使用数据运行或者是训练,以增强模型的威力。
    • 我们一般使用边缘分布不能计算但是可以简单从中采样的模型。
    • 我们经常训练具有难以处理的目标函数的模型,我们甚至不能在合理的时间内近似,但是如果我们能够高效地获得这样一个函数的梯度估计,我们仍然能够近似训练模型。
    • 深度学习方法通常是找出我们绝对需要的最小量信息,然后找出如何尽快得到该信息的合理近似。

受限玻尔兹曼机实例



  • RBM \text{RBM} RBM结构的限制产生了好的属性:
    p ( h ∣ v ) = ∏ i p ( h i ∣ v ) p(\textbf{h}\mid\textbf{v})=\prod\limits_i p(\text{h}_i\mid\text{v}) p(hv)=ip(hiv) — 公式2 \quad\textbf{---\footnotesize{公式2}} 2

  • 以及: p ( v ∣ h ) = ∏ i p ( v i ∣ h ) p(\textbf{v}\mid\textbf{h})= \prod\limits_i p(\text{v}_i\mid\textbf{h}) p(vh)=ip(vih) — 公式3 \quad\textbf{---\footnotesize{公式3}} 3

  • 独立的条件分布很容易计算。对于二元的受限玻尔兹曼机,我们可以得到:
    { p ( h i = 1 ∣ v ) = σ ( v ⊤ W : , i + b i ) — 公式4 p ( h i = 0 ∣ v ) = 1 − σ ( v ⊤ W : , i + b i ) — 公式5 \begin{cases}\begin{aligned} p(\text{h}_i=1\mid\textbf{v})&=\sigma(\textbf{v}^\top\boldsymbol{W}_{:,i}+b_i) &\quad\textbf{---\footnotesize{公式4}}\\ p(\text{h}_i=0\mid\textbf{v})&=1-\sigma(\textbf{v}^\top\boldsymbol{W}_{:,i}+b_i) &\quad\textbf{---\footnotesize{公式5}} \end{aligned} \end{cases} {p(hi=1v)p(hi=0v)=σ(vW:,i+bi)=1σ(vW:,i+bi)45

  • 结合这些属性可以得到高效的块吉布斯采样 ( block Gibbs Sampling \text{block Gibbs Sampling} block Gibbs Sampling),它在同时采样所有 h \boldsymbol{h} h 和同时采样所有 v \boldsymbol{v} v 之间交替。

    • RBM \text{RBM} RBM模型通过 Gibbs \text{Gibbs} Gibbs 采样产生的样本在图例2中。

  • 图例2: 训练好的 RBM \text{RBM} RBM样本及其权重。
    • 训练好的 RBM \text{RBM} RBM样本及其权重
      在这里插入图片描述

    • 说明:

      • (左)
        • MNIST \text{MNIST} MNIST 训练模型,然后用 Gibbs \text{Gibbs} Gibbs 采样进行采样。
        • 每一列是一个单独的 Gibbs \text{Gibbs} Gibbs 采样过程。
        • 每一行表示另一个 1000 步后 Gibbs \text{Gibbs} Gibbs 采样的输出。
        • 连续的样本之间彼此高度相关。
      • (右)
        • 对应的权重向量。
        • 将本图结果与线性因子模型 - 稀疏编码篇 - 图例1中描述的线性因子模型的样本和权重相比。
        • 由于 RBM \text{RBM} RBM的先验 p ( h ) p(\boldsymbol{h}) p(h) 没有限制为因子,这里的样本表现得更好。
        • 采样时 RBM \text{RBM} RBM能够学习到哪些特征需要一起出现。
        • 另一方面说, RBM \text{RBM} RBM后验 p ( h ∣ v ) p(\boldsymbol{h} \mid \boldsymbol{v}) p(hv) 是因子的,而稀疏编码的后验并不是,所以在特征提取上稀疏编码模型表现得更好。
        • 其他的模型可以使用非因子的 p ( h ) p(\boldsymbol{h}) p(h) 和非因子的 p ( h ∣ h ) p(\boldsymbol{h} \mid \boldsymbol{h}) p(hh)
        • 图片的复制经过 LISA (2008) \text{LISA (2008)} LISA (2008) 的允许。

  • 由于能量函数本身只是参数的线性函数,很容易获取能量函数的导数。例如,
    ∂ ∂ W i , j E ( v , h ) = − v i h j \frac{\partial}{\partial W_{i,j}}E(\textbf{v},\textbf{h})=-\text{v}_i\text{h}_j Wi,jE(v,h)=vihj — 公式6 \quad\textbf{---\footnotesize{公式6}} 6
  • 这两个属性,高效的 Gibbs \text{Gibbs} Gibbs 采样和导数计算,使训练过程非常方便。在后续篇章:面对配分函数中,我们将看到,可以通过计算应用于这种来自模型样本的导数来训练无向模型。
  • 训练模型可以得到数据 v \boldsymbol{v} v 的表示 h \boldsymbol{h} h。我们可以经常使用 E h ∼ p ( h ∣ v ) [ h ] \mathbb{E}_{\textbf{h}\sim p(\textbf{h}\mid\boldsymbol{v})}[\boldsymbol{h}] Ehp(hv)[h] 作为一组描述 v \boldsymbol{v} v 的特征。
  • 总的来说, RBM \text{RBM} RBM展示了典型的图模型深度学习方法:结合由矩阵参数化的层之间的高效相互作用通过多层潜变量完成表示学习。
  • 图模型的语言为描述概率模型提供了一种优雅、灵活、清晰的语言。在前面的章节中,我们使用这种语言,以其他视角来描述各种各样的深概率模型。

总结

深度学习中的结构化概率模型深度学习方法,通过构建复杂的图结构来捕捉变量间的非线性相互作用。这些方法不仅利用分布式表示的思想,还通过引入大量潜变量来增强模型的表达能力。与传统的图模型相比,深度学习模型在设计上更加灵活,能够处理更加复杂的问题。在深度学习中,模型的深度并非仅由计算图决定,而是根据图模型中潜变量到可观察变量的最短路径来定义。此外,深度学习模型还采用了高效的数值计算技术和优化算法,以加速模型的训练和推断过程。通过这些深度学习方法,结构化概率模型在图像识别、语音识别、自然语言处理等多个领域取得了显著进展,为人工智能的发展注入了新的活力。

往期内容回顾

应用数学与机器学习基础 - 概率与信息论篇
深度学习中的结构化概率模型 - 从图模型中采样篇
线性因子模型 - 稀疏编码篇

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1555551.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

精品WordPress主题/响应式个人博客主题Kratos

Kratos 是一款专注于用户阅读体验的响应式 WordPress 主题,整体布局简洁大方,针对资源加载进行了优化。 Kratos主题基于Bootstrap和Font Awesome的WordPress一个干净,简单且响应迅速的博客主题,Vtrois创建和维护, 主…

Markdown实用语法汇总

说明: 本来只展示本人常用的、markdown特有优势的一些语法。表格输入markdown的弱项,不作介绍,借助软件创建即可。引用图片、音频、视频等,虽然很方便,但是内容集成度不高,需要上传发布的时候很不方便&…

学习C语言(23)

整理今天的学习内容 1.文件的概念 使用文件是为了将数据永久化地保存 按照文件功能,在程序设计中一般把文件分成两类: 每个文件都有一个唯一的文字标识,文字标识常被称为文件名,文件名包含文件路径,文件名主干和文件…

Apollo9.0 Planning2.0决策规划算法代码详细解析 (4): PlanningComponent::Proc()

🌟 面向自动驾驶规划算法工程师的专属指南 🌟 欢迎来到《Apollo9.0 Planning2.0决策规划算法代码详细解析》专栏!本专栏专为自动驾驶规划算法工程师量身打造,旨在通过深入剖析Apollo9.0开源自动驾驶软件栈中的Planning2.0模块&am…

vAPI靶场

前言 自行去搭建vAPI靶场,配合postman使用 vapi1 创建用户 第一个用户 {"username": "shi","name": "shi1","course": "nihao","id": 10 } 第二个用户 {"username": "hui…

论文理解【LLM-CV】—— 【MAE】Masked Autoencoders Are Scalable Vision Learners

文章链接:Masked Autoencoders Are Scalable Vision Learners代码:GitHub - facebookresearch/mae发表:CVPR 2022领域:LLM CV一句话总结:本文提出的 MAE 是一种将 Transformer 模型用作 CV backbone 的方法&#xff0c…

制作一个流水灯,控制发光二极管由上至下再由下至上反复循环点亮显示,每次点亮一个发光二级管(Proteus 与Keil uVision联合仿真)

一、代码编写 (1)编写程序来控制发光二极管由上至下的反复循环流水点亮,每次点亮一个发光二极管。 #define uchar unsigned char // 定义uchar为unsigned char类型uchar tab[] {0xfe, 0xfd, 0xfb, 0xf7, 0xef, 0xdf, 0xbf, 0x7f, 0x7f, 0x…

一个不错的 SQL 编码风格的指南

前言 SQL语句的编写对于我们后端开发者而言是一个必备的技巧,在日常工作中,SQL语言编写的质量不仅仅会影响到团队的合作效率与项目的可维护性,还直接关系到数据库的性能优化与数据安全。今天大姚给大家分享一个不错的 SQL 编码风格的指南&am…

【Qt】控件概述(4)—— 输出类控件

输出类控件 1. QLineEdit——单行输入框2. QTextEdit——多行输入框3. QComboBox——下拉框4. QSpinBox——微调框5. QDateEdit && QTimeEdit && QDateTimeEdit6 QDial——旋钮7. QSlider——滑动条 1. QLineEdit——单行输入框 QLineEdit是一个单行的输入框&…

定时器实验(Proteus 与Keil uVision联合仿真)

一、 (1)设置TMOD寄存器 T0工作在方式1,应使TMOD寄存器的M1、M001;应设置C/T*0,为定时器模式;对T0的运行控制仅由TR0来控制,应使相应的GATE位为0。定时器T1不使用,各相关位均设为…

执行路径带空格的服务漏洞

原理 当系统管理员配置Windows服务时,必须指定要执行的命令,或者运行可执行文件的路径。 当Windows服务运行时,会发生以下两种情况之一。 1、如果给出了可执行文件,并且引用了完整路径,则系统会按字面解释它并执行 …

Listen1 0.8.2| 免费无广告,整合多平台音乐,界面简洁,操作便捷。

Listen 1 是一款开源且免费的跨平台音乐播放器,它能够整合多个主流音乐平台的资源,让你在一个应用中就能听到来自不同平台的歌曲。无论你是网易云音乐、QQ音乐还是虾米音乐的用户,你都可以通过 Listen 1 来享受无缝的音乐体验。它支持网易云音…

【每天学个新注解】Day 16 Lombok注解简解(十五)—@FieldNameConstants

FieldNameConstants 根据属性名生成常量类的常量。 1、如何使用 加在需要根据属性名生成常量的属性上。 2、代码示例 例: FieldNameConstants public class Test {private String iAmAField;private int andSoAmI;FieldNameConstants.Exclude private int asA…

【机器学习(十一)】糖尿病数据集分类预测案例分析—XGBoost分类算法—Sentosa_DSML社区版

文章目录 一、XGBoost算法二、Python代码和Sentosa_DSML社区版算法实现对比(一) 数据读入和统计分析(二)数据预处理(三)模型训练与评估(四)模型可视化 三、总结 一、XGBoost算法 关于集成学习中的XGBoost算法原理,已经进行了介绍与总结,相关内容可参考【…

openEuler 24.03 (LTS) 部署 K8s(v1.31.1) 高可用集群(Kubespray Ansible 方式)

写在前面 实验需要一个 CNI 为 flannel 的 K8s 集群之前有一个 calico 的版本有些旧了,所以国庆部署了一个v1.31.1 版本 3 * master 5 * work时间关系直接用的工具 kubespray博文内容为部署过程以及一些躺坑分享需要科学上网理解不足小伙伴帮忙指正 😃,生活加油 99…

第二百六十九节 JPA教程 - JPA查询OrderBy两个属性示例

JPA教程 - JPA查询OrderBy两个属性示例 以下代码显示如何按两个属性排序,一个升序,另一个降序。 List l em.createQuery("SELECT e FROM Professor e " "JOIN e.department d ORDER BY d.name, e.name DESC").getResultList();例子…

数据结构实验二 顺序表的应用

数据结构实验二 顺序表的应用 一、实验目的 1、掌握建立顺序表的基本方法。 2、掌握顺序表的插入、删除算法的思想和实现,并能灵活运用 二、实验内容 用顺序表实现病历信息的管理与查询功能。具体要求如下: 1.利用教材中定义顺序表类型存储病人病历信息(病历号…

什么是高斯积分,以及如何求它的值(error function)

文章目录 什么是高斯积分高斯积分与误差函数的关系求值证明过程技巧1 两个相互独立的积分的乘积转为双重积分技巧2 富比尼定理技巧3 坐标系转换总结 什么是高斯积分 高斯积分的公式如下: 高斯积分与误差函数的关系 参考wiki,误差函数的定义如下&…

SQL自用小结

推荐一下这个知识点总结 《数据库系统概论》第五版 学习笔记总目录 1. SQL概述 SQL(Structured Query Language,结构化查询语言)是一种用于定义、查询、更新和控制关系数据库的标准化语言。 它包含了数据定义语言(DDL&#xff0…

Unity MVC框架演示 1-1 理论分析

本文仅作学习笔记分享与交流,不做任何商业用途,该课程资源来源于唐老狮 1.一般的图解MVC 什么是MVC我就不说了,老生常谈,网上有大量的介绍,想看看这三层都起到什么职责?那就直接上图吧 2.我举一个栗子 我有…