蒙特卡洛法(三)马尔科夫链蒙特卡洛法

article/2025/9/17 8:53:37

马尔科夫链蒙特卡洛法适合于随机变量是多元的、密度函数是非标准形式的随机变量各分量不独立的情况。如何构建具体的马尔科夫链是这个方法的关键,离散变量的时候,需要定义转移矩阵,构建可逆马尔科夫链,保证遍历定理成立。常用的马尔科夫链蒙特卡洛法有Metropolis-Hasting算法,吉布斯抽样。

1 基本步骤

1)首先,在随机变量x的状态空间S上构造一个满足遍历定理的马尔科夫链,使其平稳分布为目标分布p(x);

2)从状态空间的某一点x0出发,用构造的马尔科夫链进行随机游走,产生样本序列x0,x1,x2..,xt,..。

3)应用马尔科夫链遍历定理,确定正整数m、n,得到样本集合x_{m+1},x_{m+2},...,x_{t},...求得函数f(x)的均值(遍历均值)

E_{f}=\frac{1}{n-m}\sum_{i=m+1}^{n}f(x_{i})

       满足遍历定理的马尔科夫链时间趋于无穷时马尔科夫链的状态分布趋于平稳分布,随机变量的函数的样本均值以概率1收敛于该函数的数学期望

Metropolis-Hastings算法

1 基本原理

1.1 马尔科夫链

假设要抽样的概率分布为p(x),MH算法采用转移核为p(x,x')的马尔科夫链:

p(x,x')=q(x,x')a(x,x')

其中q(x,x')和a(x,x')分别称为建议分布和接受分布,建议分布为另一个马尔科夫链的转移核,而接受分布a(x,x')是

a(x,x')=min\left \{ 1,\frac{p(x,x')q(x,x')}{p(x)q(x,x')} \right \}

如果在时刻(t-1)处于状态x,即xt-1=x,则先按照建议分布q(x,x')抽样产生一个候选状态x’,然后按照接受分布a(x,x')抽样决定是否接受状态x',以概率a(x,x')决定接受x',时刻t状态转移到x’,以概率(1-a(x,x'))拒绝x’,决定时刻t仍停留在状态x,

也就是说从(0,1)上的均匀分布中抽取一个随机数u,决定t时刻的状态。

x_{t}=x',u\leqslant a(x,x') |x_{t}=x,u\geqslant a(x,x')

1.2 建议分布

介绍两种建议分布q(x,x')的常用形式。

第一种形式,假设分布是对称的,即对任意的x和x’有q(x,x')=q(x',x),这样的建议分布称为Metropolis选择,Metropolis选择的特点是当x'与x接近时,q(x,x')的概率值高,否则q(x,x')的概率值低。状态转移在附近点的可能性更大。

第二种形式称为独立抽样,假设建议分布q(x,x')与当前状态无关即q(x,x')=q(x')。建议分布的计算按照q(x')独立抽样进行,独立抽样实现简单,但收敛速度较慢,通常选择接近目标分布p(x)的分布作为建议分布

1.3 算法步骤

输入;抽样的目标分布的密度函数p(x),函数f(x);

输出:p(x)的随机样本x_{m+1},x_{m+2},...,x_{t},...,函数样本均值fmn;

参数:收敛步数m,迭代步数n。

1)任意选择一个初始值x0

2)对i=1到n执行循环

     (a)设状态x_{i-1}=x,按照建议分布q(x,x')随机选取候选状态x’

     (b)计算接受概率a(x,x')=min\left \{ 1,\frac{p(x')q(x',x)}{p(x)q(x,x')} \right \}

     (c)从区间(0,1)中按均匀分布随机抽取一个数u。若u\leqslant a(x,x'),则状态xi=x’;否则状态 xi=x。

3)得到样本集合x_{m+1},x_{m+2},...,x_{t},...。计算

 f_{mn}=\frac{1}{n-m}\sum_{i=m+1}^{n}f(x_{i}))

 


http://chatgpt.dhexx.cn/article/M4OF9UEV.shtml

相关文章

蒙特卡洛法简述

蒙特卡洛法简述 一.简介: 1.蒙特卡洛方法又称随机模拟法,随机抽样技术,是一种随机模拟方法。 蒙特卡洛法使用随机数(伪随机数)以概率和统计理论方法为基础,将所要求解的问题同一定的概率模型相互联系&am…

蒙特卡洛法模拟计算圆周率π

一、蒙特卡洛法介绍 蒙特卡罗方法(Monte Carlo method),也称统计模拟方法,是一种以概率统计理论为基础的数值计算方法,常用于特定条件下的概率计算问题。蒙特卡罗是摩纳哥的著名赌城,该法为表明其随机抽样的…

蒙特卡洛法之MATLAB实现

by WC 1.7.2016蒙特卡洛法(随机取样法)也称为计算机随机模拟方法,它源于世界著名的赌城——Monte Carlo。它是基于对大量事件的统计结果来实现一些确定性问题的计算。使用蒙特卡洛法必须使用计算机生成相关分布的随机数。 eg: y…

C语言文件打开关闭和读写

文件在进行读写操作之前要先打开,使用完毕要关闭。在C语言中,文件操作都是由库函数来完成的。在本节内将介绍主要的文件操作函数。 文件的打开(fopen函数) fopen函数用来打开一个文件,其调用的一般形式为: 文件指针名 fopen( 文…

C语言文件详解(一)文件介绍,文件打开和关闭

文章目录 一、文件介绍1.1为什么使用文件1.2什么是文件1.3文件名 二、文件的打开和关闭2.1文件指针2.2文件的打开和关闭 一、文件介绍 1.1为什么使用文件 文件属于文件的一种,与普通文件载体不同,文件是以硬盘为载体存储在计算机上的信息集合。那么为什…

C语言fopen打开文件失败了,原来是这个原因~~~~

大家好&#xff0c;我是疯狂的比特&#xff0c;一个每天在互联网上种菜和砍柴的程序员 今天给大家分享一个C语言初学者常见的一个问题。 问题 经常有人问我&#xff0c;我的C语言代码好好的&#xff0c;怎么就打开文件失败了呢&#xff1f; 我们先来看看代码吧 #include <s…

【C】C语言打开,读取文件

文章目录 C语言打开&#xff0c;读取文件一、明明白白我的心二、代码飞起来三、过程不重要&#xff0c;重点看结果 C语言打开&#xff0c;读取文件 一、明明白白我的心 1、gcc编译C语言代码 2、winds10操作系统 3、VS Code编辑器(强推&#xff0c;最近博主用这个…

C语言<文件的打开与关闭>

目录 一.为什么使用文件 二.什么是文件 1.程序文件 2.数据文件 3.文件名 三.文件的打开与关闭 1.文件指针 2.文件的打开与关闭 结语 一.为什么使用文件 我们前面学习结构体时&#xff0c;写了通讯录的程序&#xff0c;当通讯录运行起来的时候&#xff0c;可以给通讯录…

C语言文件打开方式

使用文件的方式共有12种&#xff0c;下面给出了它们的符号和意义。 文件打开方式 意义 rt 只读打开一个文本文件&#xff0c;只允许读数据 wt 只写打开或建立一个文本文件&#xff0c;只允许写数据 at 追加打开一个文本文件&#xff0c;并在文件末尾写数据 rb 只…

C语言————文件的打开(知识点总结+举例)

fopen函数用来打开一个文件&#xff0c;其调用的一般形式为&#xff1a; 文件指针名fopen(文件名,使用文件方式); 其中&#xff1a; “文件指针名”必须是被说明为FILE 类型的指针变量&#xff1b; “文件名”是被打开文件的文件名&#xff1b; “使用文件方式”是指文件的类型…

【C语言】文件的打开和关闭,文件的顺序读写

文章目录 1、为什么使用文件 2、什么是文件 3、文件的打开和关闭 文件的打开 文件的关闭 4、文件的顺序读写 4.1文件读写的特点 4.2fputc、fgetc函数 4.3fgets、fputs函数 4.4fscanf、fprintf函数 5、标准输入输出流stdin、stdout 1、为什么使用文件 在编写例如通讯…

C语言-文件操作

当程序的生命周期结束&#xff0c;在内存中存放的数据就会随着内存的释放而清除&#xff0c;这并不满足我们日常生活中的记录需求&#xff0c;所以C语言开发了文件操作模式&#xff0c;通过将数据存放在硬盘&#xff0c;数据库等方式&#xff0c;实现数据的持久化。 文件存在于…

C语言打开文件详解

C语言中操作文件之前必须先打开文件&#xff1b;所谓“打开文件”&#xff0c;就是让程序和文件建立连接的过程。 打开文件之后&#xff0c;程序可以得到文件的相关信息&#xff0c;例如大小、类型、权限、创建者、更新时间等。在后续读写文件的过程中&#xff0c;程序还可以记…

一 形参与实参

1 实际参数&#xff08;实参&#xff09; 真实传给函数的参数&#xff0c;叫实参。即在函数调用时写入的实际参数。 实参可以是&#xff1a;常量、变量、表达式、函数等。无论实参是何种类型的量&#xff0c;在进行函数调用时&#xff0c;它们必须有确定的值&#xff0c;以便把…

【C语言函数参数详解】——实际参数(实参)形式参数(形参)

文章目录 一.什么是实际参数&#xff08;实参&#xff09;二.什么是形式参数&#xff08;形参&#xff09;三.形参与实参的关系 这篇文章我们一起学习一下函数的参数&#xff0c;函数的参数分为实参和形参。 一.什么是实际参数&#xff08;实参&#xff09; 首先我们来学习实…

java 静态工厂_高效Java第一条考虑用静态工厂代替构造函数

获得类的实例&#xff1a; 1.提供一个公有的构造函数&#xff1b; 2.提供一个公有的静态工厂方法&#xff0c;该方法只是一个返回类的实例的静态方法。 静态工厂方法与设计模式中的工厂方法模式不同。 提供静态工厂方法的优势——静态工厂方法与构造函数不同的第一大优势在于&a…

【算法之高效求素数】浅析求素数算法

注意: 如果没有特殊说明, 以下讨论的都是针对n为素数时的时间复杂度 1. 根据概念判断: 如果一个正整数只有两个因子, 1和p&#xff0c;则称p为素数. 代码: bool isPrime(int n) {if(n < 2) return false;for(int i 2; i < n; i)if(n%i 0) return false;return true;…

求素数算法

注意: 如果没有特殊说明, 以下讨论的都是针对n为素数时的时间复杂度 1. 根据概念判断: 如果一个正整数只有两个因子, 1和p&#xff0c;则称p为素数. 代码: bool isPrime(int n) {if(n < 2) return false;for(int i 2; i < n; i)if(n%i 0) return false;return true;…

求素数算法-网摘

摘自&#xff1a;http://www.cnblogs.com/luluping/archive/2010/03/03/1677552.html 浅析求素数算法注意: 如果没有特殊说明, 以下讨论的都是针对n为素数时的时间复杂度1. 根据概念判断:如果一个正整数只有两个因子, 1和p&#xff0c;则称p为素数. 代码: bool isPrime(int n) …

用JAVA编写50以内的素数_java求50以内的素数

java求50以内的素数 [2021-02-01 12:46:22] 简介: python求100内的所有素数的方法&#xff1a;使用判断该数除了1和它本身以外不再有其他因数即可&#xff0c;代码为【i2 for i in range(2,100): if(i%j0):break else:num.append(i)】。相关免费学 php去除nbsp的方法&#xff…