R语言Gibbs抽样的贝叶斯简单线性回归仿真分析
  TEZNKK3IfmPf 2023年11月15日 19 0

贝叶斯分析的许多介绍都使用了相对简单的教学实例(例如根据伯努利数据给出成功概率的推理)。虽然这可以很好地介绍贝叶斯原理,但是将这些原理扩展到回归并不是直接的。

这篇文章将概述这些原理如何扩展到简单的线性回归。我将导出感兴趣参数的后验条件分布,给出用于实现Gibbs采样器的R代码,并提出所谓的网格方法。

 

贝叶斯模型

假设我们观察数据R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_R语言

对于我们的模型R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_R语言_02

 

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_R语言_03

有趣的是推断R语言Gibbs抽样的贝叶斯简单线性回归仿真分析R语言Gibbs抽样的贝叶斯简单线性回归仿真分析。如果我们将正态先验放在系数上,将反伽玛先验放在方差项上,则此数据的完整贝叶斯模型可以写为:

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析

假设超参数R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_R语言_07是已知的,后验可以被写入到一个比例常数,

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析

括号中的项是是数据的联合分布或概率。其他项包括参数的联合先验分布。

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_R语言_09

R代码从指定的“真实”参数模型生成数据。我们稍后将用这个数据估计贝叶斯回归模型来检查是否可以恢复这些真实的参数。

tphi<-rinvgamma(1, shape=a, rate=g)
tb0<-rnorm(1, m0, sqrt(t0) )
tb1<-rnorm(1, m1, sqrt(t1) )
tphi; tb0; tb1;

y<-rnorm(n, tb0 + tb1*x, sqrt(tphi))

 

吉布斯采样器

要从这种后验分布中得出,我们可以使用Gibbs采样算法。吉布斯采样是一种迭代算法,从每个感兴趣的参数的后验分布生成样本。它通过以下方式从每个参数的条件后验分布依次得出的:

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_R语言_10

可以看出,剩下的1,000个样本是从后验分布中抽取的。这些样本不是独立的。每个步骤都取决于先前的位置。

条件后验分布

要使用Gibbs,我们需要确定每个参数的条件后验。

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_编程开发_11

为了找到参数的条件后验,我们简单地删除不包含参数后验的所有项。例如,常数项条件后验:

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析

相似地,

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析

条件后验可以被认为是另一个逆伽马分布。

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_编程开发_14

条件后验R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_编程开发_15不那么容易识别。但是如果使用网格方法,我们不需要通过代数方法。

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_编程开发_17。所以我们可以评估密度R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_编程开发_18值。在R中,可以是grid = seq(-10,10,by = .001)。这个序列是点的“网格”。

那么在每个网格点评估的条件后验分布告诉我们这个抽样的相对概率。

然后,我们可以使用R中的sample()函数从这些网格中抽取,抽样概率与网格处的密度评估成比例。



  for(i in 1:length(p) ){
    p[i]<- (-(1/(2*phi))*sum( (y - (grid[i]+b1*x))^2 ))  + ( -(1/(2*t0))*(grid[i] - m0)^2)
  }
  

  draw<-sample(grid, size = 1, prob = exp(1-p/max(p)))

这在R代码的第一部分的函数rb0cond()和rb1cond()中实现。

使用网格方法时遇到数值问题是很常见的。由于我们在评估网格中未标准化的后验,因此结果可能会变得相当大或很小。可能会在R中产生Inf和-Inf值。

例如,在函数rb0cond()和rb1cond()中,我实际上评估了条件后验分布的对数。然后,我进行归一化和对数化。

我们不需要使用网格方法来从后验条件抽样,因为它来自已知的分布R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_R语言_19

请注意,这种网格方法有一些缺点。

首先,这在计算上是复杂的。通过代数,希望得到一个已知的后验分布,从而在计算上更有效率。

其次,网格方法需要指定网格点的区域。如果条件后验在我们指定的[-10,10]的网格区间之外具有显着的密度,在这种情况下,我们不会从条件后验得到准确的样本。并且需要广泛的网格区间进行实验。所以,我们需要灵活地处理数字问题,例如在R中接近Inf和-Inf值的数字。

 

仿真结果

现在我们可以从每个参数的条件后验进行采样,我们可以实现Gibbs采样器。

iter<-1000
burnin<-101
phi<-b0<-b1<-numeric(iter)
phi[1]<-b0[1]<-b1[1]<-6

结果很好。下图显示了1000个吉布斯(Gibbs)样本的序列。红线表示我们模拟数据的真实参数值。第四幅图显示了截距和斜率项的后验联合分布,红线表示等高线。

z <- kde2d(b0, b1, n=50)
plot(b0,b1, pch=19, cex=.4)
contour(z, drawlabels=FALSE, nlevels=10, col='red', add=TRUE)

R语言Gibbs抽样的贝叶斯简单线性回归仿真分析_R语言_20

总结一下,我们首先推导了一个表达式,用于参数的联合分布。然后我们概述了从后验抽取样本的Gibbs算法。在这个过程中,我们认识到Gibbs方法依赖于每个参数的条件后验分布,这是容易识别的已知的分布。对于斜率和截距项,我们决定用网格方法来规避代数方法。这样做的好处是我们可以绕开很多代数运算。代价是增加了计算复杂性。


【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月15日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2023年11月15日   35   0   0 R语言
TEZNKK3IfmPf