DBN---RBM简介

2024-05-25 22:48
文章标签 简介 rbm dbn

本文主要是介绍DBN---RBM简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

RBM

上图即是RBM(受限玻尔兹曼机)的网络结构图,与玻尔兹曼机的区别就在于没有层内连接,其中 v 为可见层,h为隐藏层,可见层用于输入数据和获取结果,隐藏层则表示状态的变化,另外
v=(v1,v2,...,vnv) 表示可见层神经元的状态,
h=(h1,h2,...,hnh) 表示隐藏层神经元的状态,
a=(a1,a2,...,anv) 表示可见层神经元的偏置,
b=(b1,b2,...,bnh) 表示隐藏层神经元的偏置,
W 则是层间连接权值矩阵


RBM是基于能量的模型(EBM),定义了一个能量函数,能量最小时,模型达到最优,

Eθ(v,h)=i=1nvaivii=1nhbihii=1nvj=1nhwi,jhjviθ={a,b,W}

由此 v,h 间的联合概率分布可以得到,
Pθ(v,h)=1ZθeEθ(v,h),Zθ=v,heEθ(v,h)

Zθ 是相当于一个归一化因子的存在,还能得到
Pθ(v)=hPθ(v,h)Pθ(h)=vPθ(v,h)

对于后面得到更新规则, P(vi|h)orP(hi|v) 这个条件概率很重要.
bk(h)=ak+j=1nhwk,jhjβ(h,vvkV)=i=1,iknvaivi+i=1nhbihi+i=1nvj=1,jknhwi,jhivj

因此
Eθ(v,h)=β(h,vvkV)vkbk(h)

那么
P(vk=1|h)=P(vk=1|vi,ik,h)=P(vk=1,vi,ik,h)P(vi,ik,h)=P(vk=1,vi,ik,h)P(vk=1,vi,ik,h)+P(vk=0,vi,ik,h)=1ZeE(vk=1,vi,ik,h)1ZeE(vk=1,vi,ik,h)+1ZeE(vk=0,vi,ik,h)=11+eE(vk=1,vi,ik,h)E(vk=0,vi,ik,h)=11+e[β(h,vi,ik)+0bk(h)]+[β(h,vi,ik)1bk(h)]=11+ebk(h)=sigmoid(bk+j=1nhwk,jhj)

由此得到
P(v|h)=i=1nvP(vi|h)

RBM常用CD(Contrastive Divergence,对比散度)进行训练,这在后文在总结.

知识共享许可协议
本作品采用知识共享署名-相同方式共享 4.0 国际许可协议进行许可。

这篇关于DBN---RBM简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1002839

相关文章

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

Python库 Django 的简介、安装、用法入门教程

《Python库Django的简介、安装、用法入门教程》Django是Python最流行的Web框架之一,它帮助开发者快速、高效地构建功能强大的Web应用程序,接下来我们将从简介、安装到用法详解,... 目录一、Django 简介 二、Django 的安装教程 1. 创建虚拟环境2. 安装Django三、创

MySQL 索引简介及常见的索引类型有哪些

《MySQL索引简介及常见的索引类型有哪些》MySQL索引是加速数据检索的特殊结构,用于存储列值与位置信息,常见的索引类型包括:主键索引、唯一索引、普通索引、复合索引、全文索引和空间索引等,本文介绍... 目录什么是 mysql 的索引?常见的索引类型有哪些?总结性回答详细解释1. MySQL 索引的概念2

Qt QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

rust 中的 EBNF简介举例

《rust中的EBNF简介举例》:本文主要介绍rust中的EBNF简介举例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 什么是 EBNF?2. 核心概念3. EBNF 语法符号详解4. 如何阅读 EBNF 规则5. 示例示例 1:简单的电子邮件地址

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe