首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Python用PyMC3实现贝叶斯线性回归模型

Python用PyMC3实现贝叶斯线性回归模型

作者头像
拓端
发布2026-06-24 19:05:09
发布2026-06-24 19:05:09
1140
举报
文章被收录于专栏:拓端tecdat拓端tecdat

在本文中,我们将在贝叶斯框架中引入回归建模,并使用PyMC3 MCMC库进行推理

相关视频

我们将首先回顾经典频率论的多重线性回归方法。然后讨论贝叶斯如何考虑线性回归。

用PyMC3进行贝叶斯线性回归

在本节中,我们将对统计实例进行一种经典的方法,即模拟一些我们知道的属性的数据,然后拟合一个模型来推算这些原始属性。

什么是广义线性模型?

在我们开始讨论贝叶斯线性回归之前,我想简要地概述广义线性模型(GLM)的概念,因为我们将使用它们来在PyMC3中建立我们的模型。

广义线性模型是将普通线性回归扩展到更一般形式的回归的灵活方法,包括逻辑回归(分类)和泊松回归(用于计数数据)以及线性回归本身。

GLM允许具有除正态分布以外的误差分布的因变量。

用PyMC3模拟数据并拟合模型

在我们使用PyMC3来指定和采样贝叶斯模型之前,我们需要模拟一些噪声线性数据。

输出如下图所示:

通过Numpy,pandas和seaborn模拟噪声线性数据


点击标题查阅往期内容

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

01

02

03

04

现在我们已经进行了模拟,我们想要对数据拟合贝叶斯线性回归。这是glm方法。

然后我们将找到MCMC采样器的最大后验概率(MAP)估计值。最后,我们将使用No-U-Turn Sampler(NUTS)来进行实际推理,然后绘制模型的曲线,将前500个样本丢弃为“burn in”预烧过程。

Kaizong Ye

拓端分析师

traceplot如下图所示:

使用PyMC3将贝叶斯GLM线性回归模型拟合到模拟数据

首先我们使用seaborn lmplot方法,fit_reg参数设置False,不绘制频数回归曲线。然后我们绘制100个采样的后验预测回归线。最后,我们绘制使用原始的“真实”回归线和β1=2的参数。

我们可以在下图中看到回归线的抽样范围:


本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2026-06-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 拓端数据部落 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 用PyMC3进行贝叶斯线性回归
  • 什么是广义线性模型?
  • 用PyMC3模拟数据并拟合模型
  • 使用PyMC3将贝叶斯GLM线性回归模型拟合到模拟数据
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档