首页 > 其他分享 >R语言Stan贝叶斯回归置信区间后验分布可视化模型检验|附数据代码

R语言Stan贝叶斯回归置信区间后验分布可视化模型检验|附数据代码

时间:2024-04-15 22:56:14浏览次数:33  
标签:置信区间 后验 family 模型 贝叶斯 线性 Stan 回归

全文链接:https://tecdat.cn/?p=35899

原文出处:拓端数据部落公众号

贝叶斯回归是一种统计方法,它使用贝叶斯定理来估计回归模型的参数。与传统的频率派回归方法不同,贝叶斯回归提供了参数的后验分布,而不仅仅是点估计。这意味着我们可以得到参数的不确定性度量,而不仅仅是单一的估计值。

R语言用于拟合贝叶斯广义线性模型。我们可以方便地帮助客户拟合贝叶斯线性回归、逻辑回归、多项式回归等各种模型。

Stan

你可以运行大多数回归。

  • 由于广义线性模型(GLMs)涵盖了线性回归、probit、logit、Poisson、二项式、指数等模型,

glm

Family(可能还需要一个link参数)定义了你想要的回归类型:

  • 线性回归:family = gaussian
  • Logit:family = binomial(link = "logit")
  • Probit:family = binomial(link = "probit")
  • Poisson:family = poisson

先验分布:

  • 无信息先验可以通过使用prior = NULL来设置

  • 弱信息先验可以通过使用prior =与以下之一来指定:

    • normal, student_t, cauchy, laplace以及更多,可以在这里找到

使用rstanarm的泰坦尼克号生存示例

   


	# 重构Class列  

	Titanic$class <- str_extract(Titanic$PClass, "[0-9]")  


	# 显示模型摘要  

	summary(TitanicLinear)

在实践中,对于二元目标变量,通常会选择逻辑回归(例如,使用family = binomial(link = "logit"))。模型的摘要会提供有关模型拟合的详细信息,包括每个预测变量的系数和它们的置信区间。

image.png

image.png

可信区间

打印置信区间。

图形化可信区间

绘制后验分布

在R中,你还可以轻松地绘制参数的后验分布。后验分布反映了在给定数据后,你对模型参数的信念。你可以使用各种可视化技术来展示这些分布,如直方图、密度图或箱线图。

   


ggplot(Titanic_poste
ss)) + 
  geom_histogram()

先验和后验的比较

模型检验

模型检验基础

执行贝叶斯回归后,有多种回归诊断方法可以帮助推断模型是否收敛、表现如何,甚至比较不同模型。

图形化后验预测分析

要检查后验分布的预测准确性,它会将后验分布模拟的y值与实际的y值进行比较并绘制图形。

正则化与预测准确性

在贝叶斯和频率派估计中,一个关键问题是如何平衡预测准确性与简约性。换句话说,研究人员应该关注如何在不过度拟合数据的同时创建具有说服力的模型。

WAIC 示例

留一交叉验证

除了WAIC之外,另一种比较样本外预测能力的方法是应用留一交叉验证(LOO)。

  • LOO通过迭代地将数据划分为训练集和预测集来评估后验模拟的预测能力。

LOO 示例

模型比较

   
复制代码
	Titanic_probit <- 
        

	    data = Titanic, family = binomial(link=probit))  

	Loo_probit <- loo(Titanic_probit)  

	  



	    data = Titanic, family = binomial(link=logit))  

	Loo_logit <- loo(Titanic_logit)  

	  

	# ELPD_diff>0 表示第二个模型更受支持  

在上面的代码中,我们拟合两个贝叶斯广义线性模型,分别使用了probit和logit链接函数。

image.png


what-is-digital-transformation-1459532837-standard-1536x1536.webp

最受欢迎的见解

1.matlab使用贝叶斯优化的深度学习

2.matlab贝叶斯隐马尔可夫hmm模型实现

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

4.R语言中的block Gibbs吉布斯采样贝叶斯多元线性回归

5.R语言中的Stan概率编程MCMC采样的贝叶斯模型

6.R语言贝叶斯Poisson泊松-正态分布模型分析职业足球比赛进球数

7.R语言使用贝叶斯 层次模型进行空间数据分析

8.R语言随机搜索变量选择SSVS估计贝叶斯向量自回归(BVAR)模型

9.matlab贝叶斯隐马尔可夫hmm模型实现

标签:置信区间,后验,family,模型,贝叶斯,线性,Stan,回归
From: https://www.cnblogs.com/tecdat/p/18137104

相关文章

  • 变量、常量(constant)
    java是一个强类型语言,每个变量都必须声明其类型;变量要素包含:变量名、变量类型、作用域typevarname=[=value][{,varname[=value]}];变量命名规范:所有的变量,方法,类名(见名知意)类成员变量:首字母小写,驼峰原则,eg:lastName类名,方法名,局部变量:首字母小写,驼峰原则常量:大写字母和......
  • Understanding the linux kernel Chapter 7 Process Scheduling
    SchedulingPolicyLinuxschedulingisbasedonthetimesharingtechnique:severalprocessesrunin“timemultiplexing”becausetheCPUtimeisdividedintoslices(called,quantum),oneforeachrunnableprocess.Analternativeclassificationdistinguis......
  • Cisco Nexus 9000 Series Switches, NX-OS Standalone 10.4(3)F and ACI Mode 16.0(5h
    CiscoNexus9000SeriesSwitches,NX-OSStandalone10.4(3)FandACIMode16.0(5h)includeApplicationPolicyInfrastructureController(APIC)Release6.0(5h)请访问原文链接:CiscoNexus9000SeriesSwitches,NX-OSStandalone10.4(3)FandACIMode16.0(5h),查看最......
  • HCL AppScan Standard v10.5.0 (Windows) - Web 应用程序安全测试
    HCLAppScanStandardv10.5.0(Windows)-Web应用程序安全测试HCLAppScanStandardv10forWindowsMultilingual请访问原文链接:HCLAppScanStandardv10.5.0(Windows)-Web应用程序安全测试,查看最新版。原创作品,转载请保留出处。作者主页:sysin.org市场领先的应用程......
  • 「Over-Distance」观察栏目开启
    「我已经触碰过『天空』」QIANYAN——前言所以……为什么会写这个呢?这也是一个谜。大概是我不满意当今的「环境」吧,被黑夜遮盖的天空也不会有繁星。也许是疲倦了,人们纷纷拉上窗帘,不愿直视黑黝黝的夜空。那里已经被「毁灭」了。这是逃不掉的命运。JIESHAO——介绍「Ov......
  • 难道AI不知道tnsnames.ora的instance_name配置吗?
    事情是这样,给某客户培训构建hands-on实验环境时,因测试环境有限,在同一环境做了一套ADG环境;数据库是单实例,版本19.21,使用了多租户选件;其中一个测试的PDB,名为demo1,其中建好测试用户jingyu,遇到的问题是:使用sqlplus连接时,会随机连接到主库或者备库。排查定位也很简单,因为这样的环境......
  • 难道AI不知道tnsnames.ora的instance_name配置吗?
    事情是这样,给某客户培训构建hands-on实验环境时,因测试环境有限,在同一环境做了一套ADG环境;数据库是单实例,版本19.21,使用了多租户选件;其中一个测试的PDB,名为demo1,其中建好测试用户jingyu,遇到的问题是:使用sqlplus连接时,会随机连接到主库或者备库。排查定位也很简单,因为这样的环境......
  • WPF instantiate class instance as resource
    //xaml<Windowx:Class="WpfApp42.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.mic......
  • JAVA学习-类型信息.instanceof与Class的等价性
    Java中的类型信息主要通过instanceof和Class来实现。1.instanceof:instanceof是Java关键字,用于判断某个对象是否是指定类型或其子类型的实例。它的语法如下:objectinstanceoftype其中object表示要判断的对象,type表示要判断的类型。如果object是type类型或其子类型的实例,则......
  • Batch、Layer、Instance、Group四种Norm
    归一化NormalizationBatchNorm的初衷是解决InternalCovariateShift问题。尽可能将mini-batch归一化到标准正态分布,使得网络层的输出分布趋于稳定。InternalCovariateShift问题简单来说,是网络学习更新权重后可能会改变输出的分布,导致下一层总是迟一步适应这次的分布。......