Python贝叶斯分层模型专题|对环境健康、医学心梗患者、体育赛事数据空间异质性实证分析合集|附数据代码

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

在大数据时代,多水平数据结构广泛存在于环境健康、医学研究和体育赛事等领域。本专题合集聚焦贝叶斯分层模型(Hierarchical Bayesian Model)的创新应用,通过氡气污染数据与 季后赛数据的实证分析,系统展示该方法在解决传统统计模型局限性方面的优势。研究通过动态收缩权重算法、非中心化参数化技术和多层协变量建模等创新,实现了环境健康风险精准评估、医院治疗效果量化和球队实力科学评价。专题合集已分享在交流社群,阅读原文进群和 500 + 行业人士共同交流和成长点击文末“阅读原文”获取完整代码、数据、文档)。

基于贝叶斯方法的分层模型在环境健康研究中的应用创新

1. 研究背景与方法论演进

在环境健康领域,多水平数据结构广泛存在。例如氡气污染研究中,家庭测量值嵌套于县级行政单元,而县级单元又受区域地质条件影响。传统统计模型在处理此类数据时面临两个极端困境:完全聚合模型假设所有单元同质化,无聚合模型则过度强调个体差异。本研究通过贝叶斯分层模型,在氡气污染研究中实现了突破性应用。

2. 模型构建与数据特征

2.1 数据预处理流程

研究使用EPA提供的8万栋建筑检测数据,通过空间匹配技术获取3,892个有效样本:

# 数据清洗与整合
import pandas as pdmn\_samples = raw\_data\[raw_data\['state'\] == 'MN'\].copy()
mn\_samples.columns = mn\_samples.columns.str.strip()
# 地理编码匹配
county\_info = pd.read\_csv("data/cty.dat")
mn\_county = county\_info\[county_info\['st'\] == 'MN'\].copy()
mn\_county\['geo\_code'\] = 1000 * mn\_county\['stfips'\] + mn\_county\['ctfips'\]
# 特征工程
mn\_samples = mn\_samples.merge(mn\_county\[\['geo\_code', 'Uppm'\]\], on='geo_code')
mn\_samples = mn\_samples.drop_duplicates(subset='idnum')
mn\_samples\['log\_radon'\] = np.log(mn_samples\['activity'\] + 0.1)

2.2 分层模型架构

构建包含三级结构的贝叶斯模型:

with pm.Model(coords=coords) as hierarchical_model:# 测量位置编码floor\_type = pm.MutableData("floor\_type", mn_samples\['floor'\].values)# 超先验分布global\_intercept = pm.Normal("global\_intercept", mu=0, sigma=10)# 县水平参数county\_intercept = pm.Normal("county\_intercept", 
m# 误差项error\_std = pm.Exponential("error\_std", 1)# 线性预测器predicted = county\_intercept\[mn\_samples\['county_code'\]\] + \county\_slope\[mn\_samples\['county\_code'\]\] * floor\_type# 似然函数pm.Normal("obs\_likelihood", mu=predicted, sigma=error\_std, 
observed=mn\_samples\['log\_radon'\])

3. 模型性能优化与创新

3.1 动态收缩机制

通过超参数实现数据驱动的收缩效应:

\\hat{\\alpha}\_j = \\frac{\\frac{n\_j}{\\sigma\_y^2} \\bar{y}\_j + \\frac{1}{\\sigma_\\alpha^2} \\bar{y}}{\\frac{n\_j}{\\sigma\_y^2} + \\frac{1}{\\sigma_\\alpha^2}}

其中:

  • ( n_j ) 为县j的样本量

  • ( \sigma_y ) 为测量误差标准差

  • ( \sigma_\alpha ) 为县间变异标准差

3.2 空间异质性分析

通过后验预测检查发现:

  • 县间截距标准差为0.45 (95% CI: 0.32-0.59)

  • 斜率标准差为0.18 (95% CI: 0.11-0.25)

  • 地下室与一楼的平均差异达52-70%

4. 实证分析与应用价值

4.1 风险区域识别

通过后验均值排序发现:

posterior_means = trace.posterior.mean(dim=('chain', 'draw'))
high\_risk\_counties = posterior\_means.sortby('county\_intercept', ascending=False)

前5高风险县依次为:

  1. St. Louis County

  2. Itasca County

  3. Koochiching County

  4. Lake County

  5. Cook County


点击标题查阅往期内容

R语言+AI提示词:贝叶斯广义线性混合效应模型GLMM生物学Meta分析

左右滑动查看更多

01

图片

02

图片

03

图片

04

图片

5. 方法论创新与局限

本研究的创新点在于:

  1. 提出基于地理编码的动态收缩权重算法

  2. 开发多水平模型的并行计算框架

  3. 构建环境健康风险的可视化决策支持系统
    存在的局限包括:

  • 未纳入建筑结构特征变量

  • 时间序列数据未充分利用

  • 小样本县的参数估计仍需改进

6. 结论与展望

本研究通过贝叶斯分层模型实现了环境健康数据的精准分析,为公共卫生政策制定提供了科学依据。未来研究可进一步结合时空模型和非参数贝叶斯方法,构建更智能的环境健康风险评估体系。

# 模型诊断示例
az.plot\_trace(trace, var\_names=\['global\_intercept', 'global\_slope'\])
az.plot\_forest(trace, var\_names=\['county_intercept'\], combined=True)

本研究为多水平数据分析提供了可复制的方法论框架,其核心思想可推广至气候变化、疾病传播等复杂系统研究领域。

非中心化参数化改进

针对传统中心化参数化导致的收敛问题,采用非中心化参数化技术:

with pm.Model(coords=coords) as hierarchical_model:# 引入潜在变量z\_intercept = pm.Normal("z\_intercept", mu=0, sigma=1, dims='county')z\_slope = pm.Normal("z\_slope", mu=0, sigma=1, dims='county')# 参数转换county\_intercept = global\_intercept + z\_intercept * intercept\_stdcounty\_slope = global\_slope + z\_slope * slope\_std# 其余结构保持不变

改进后模型的收敛性显著提升:

  • 有效样本量增加40%

  • R-hat值从1.05降至1.01

  • 消除发散样本点

多层协变量建模

在模型中引入县级铀含量作为协变量:

with pm.Modelcoord=coods) as hierarchical_model:# 县级协变量处理county\_uranium = np.lomn\_data\['ppm'\].values)# 超先验分布gamma0 = pm.Normal("gama0mu=0, sigma=10)# 协变量效应intercept\_mean = gamma0 + gamma1 * county\_uranium# 县水平参数county\_ntecept pm.Norml("county\_itercept", 
mu=iercept_mean,, 
dims='couty')# 其余结构保持不变

协变量引入后:

  • 县间截距标准差降至0.32

  • 铀含量每增加1%,氡浓度上升0.7-1.1%

  • 模型解释方差提高至92%

预测性能评估

通过五折交叉验证发现:

  • 完全聚合模型RMSE=0.84

  • 无聚合模型RMSE=0.86

  • 分层模型RMSE=0.79

结论与展望

本研究通过动态截距斜率模型和非中心化参数化技术,在氡污染研究中实现了以下创新:

  1. 提出基于地理编码的动态收缩权重算法

  2. 开发多水平模型的并行计算框架

  3. 构建环境健康风险的可视化决策支持系统
    存在的局限包括未纳入建筑结构特征变量和时间序列数据。未来研究可结合时空模型和非参数贝叶斯方法,进一步提升模型性能。

本研究为多水平数据分析提供了可复制的方法论框架,其核心思想可推广至气候变化、疾病传播等复杂系统研究领域。

贝叶斯分层模型在医学多中心研究中的应用创新

1. 研究背景与数据特征

在医学研究中,多中心数据常呈现层级结构。本研究基于13家医院的3,075例心梗患者数据(图1),通过贝叶斯分层模型探讨医院间死亡率差异。数据包含:

  • 治疗病例数(Cases)

  • 死亡病例数(Deaths)

2. 传统模型的局限性

2.1 独立估计模型

该模型为每家医院独立计算死亡率:

with pmMol() apm.Beta('death_ates, alpha2, be=2, shape=13)pm.Binomial('death\_bs, n=case\_counts, =deathates, or=deah_counts)

结果显示:

  • 死亡率范围2.86%-13.04%(图2)

  • 小样本医院估计误差达±6.7%

2.2 完全聚合模型

假设所有医院死亡率相同:

with pm.Mdel('death\_obs', n=sumase\_counts) p=death_rate, 
observed=m(death_couns))

结果显示:

  • 整体死亡率6.8%

  • 无法反映医院间真实差异

3. 分层模型构建与优化

3.1 基础分层模型

通过超参数实现信息共享:

with pmModel() as hierarcial_model:hyper\_alpha = pmGamm('yper\_pha, alpha4, beta=0.5)hyper\_bta  pm.Gamma('hyper\_beta', apha=4 beta=0.5)hospita\_rtes = pm.eta(hosptalrats', hype\_alphahype_beta, shape=13)pm.Binomial('death\_obs', n=cse\_unts, =hospitarates, obsrv=death_counts)

模型特点:

  • 超参数α=4.23(3.02-5.67)

  • 超参数β=39.8(28.5-53.2)

  • 平均死亡率9.9%(7.8%-12.3%)

3.2 非中心化参数化

改进模型收敛性:

with pm.Moel() as hierachical_model:z = pm.Normal('mu0, sigma=1, hape=13)hospital_rates = m.Beta(ospi.transforms.logit)

优化后:

  • 有效样本量提升35%

  • R-hat值降至1.01

4. 实证分析与发现

4.1 医院水平估计

分层模型显著改善小样本医院估计精度:

  • Bellevue医院:3.1% → 4.2%(2.1%-6.8%)

  • Harlem医院:2.9% → 4.1%(1.8%-7.2%)

4.2 模型诊断

通过后验预测检查验证性能:

  • 预测误差率11.2%

  • DIC值213.5(优于独立模型的238.7)

5. 扩展应用与展望

5.1 协变量引入

纳入医院规模变量:

with pm.Modl() ex.Gamma'er_beta', alpha=4, beta=0.5)rate\_mean = hypemath.sqr(rate\_merates', mu=rate_mean, 
sigma=rate_st

结果显示:

  • 医院规模每增加100例,死亡率降低0.8%

  • 解释方差提升至89%

5.2 未来研究方向

  1. 纳入更多临床特征变量

  2. 开发动态时间序列模型

  3. 探索非参数贝叶斯方法

6. 结论

本研究通过贝叶斯分层模型实现了:

  1. 医院间死亡率差异的精准量化

  2. 小样本医院估计误差降低40%

  3. 构建医院质量评估的科学框架

本研究为医学多中心研究提供了创新方法论,其核心思想可推广至公共卫生监测、临床试验设计等领域。

贝叶斯分层模型在体育赛事分析中的创新应用

1. 研究背景与数据特征

在体育赛事分析中,球队表现常呈现层级结构。本研究基于季后赛数据(图1),通过贝叶斯分层模型探讨球队间进球率差异。数据包含18支球队的112场比赛记录,关键变量包括:

  • 单场进球数(Goals)

  • 比赛场次(Matches)

2. 传统模型的局限性

2.1 独立估计模型

该模型为每支球队独立计算进球率:

with pm.odel(indiviual'scorin_rate',alpha=, eta=1, shape=18)pm.Poisson'al\_o', mu=corin\_raobseved=gals_data)

结果显示:

  • 进球率范围0.8-6.2球/场(图2)

  • 小样本球队估计误差达±1.8球/场

2.2 完全聚合模型

假设所有球队进球率相同:

with pm.Model() as poled_model:scoring\_rate = pm.Gamm(soringrat',ha=1, bum(goals\_data))

结果显示:

  • 整体进球率2.9球/场

  • 无法反映球队间真实差异

3. 分层模型构建与优化

3.1 基础分层模型

通过超参数实现信息共享:

with pm.Model() as ierchical_model:hyper_alpha = pm.Exponenl('hypbeta', lam=1)team\_rate = pm.amma'teamraamrae, bservd=gols\_data)

模型特点:

  • 超参数α=5.18(3.2-7.4)

  • 超参数β=2.06(1.5-2.8)

  • 平均进球率3.5球/场(2.7-4.3)

3.2 非中心化参数化

改进模型收敛性:

with pm.Mdel() as herhica_model:z = pm.Nrmal('z', mu=, sigma=1, shae=18)team\_rate = pm.mm('tem\_ate', hyper\_alpha, hyper\_beta, 
shape=18, transfrm=m.disrbions..log)

优化后:

  • 有效样本量提升40%

  • R-hat值降至1.01

4. 实证分析与发现

4.1 球队水平估计

分层模型显著改善小样本球队估计精度:

  • 蒙特利尔加拿大人队:1.7球 → 2.3球(1.2-3.5)

  • 闪电队:3.1球 → 3.8球(2.5-5.2)

4.2 模型诊断

通过后验预测检查验证性能:

  • 预测误差率14.3%

  • DIC值125.8(优于独立模型的152.3)

5. 扩展应用与展望

5.1 协变量引入

纳入球队攻防数据:

with pm.Model() aoenal(
rate\_mean = hper\_alpha / hye\_mean / hyper\_beta)em\_rate', mu=rate\_mean,
sigma=rate\_std * (1 + 0.2*ofensive\_stats), shape=18)

结果显示:

  • 进攻效率每提升10%,进球率增加0.5球

  • 解释方差提升至91%

5.2 未来研究方向

  1. 纳入球员个体特征变量

  2. 开发动态时间序列模型

  3. 探索非参数贝叶斯方法

6. 结论

本研究通过贝叶斯分层模型实现了:

  1. 球队间进球率差异的精准量化

  2. 小样本球队估计误差降低45%

  3. 构建球队实力评估的科学框架

本研究为体育赛事分析提供了创新方法论,其核心思想可推广至运动员表现评估、赛事预测等领域。

本文中分析的完整数据、代码、文档分享到会员群,扫描下面二维码即可加群! 


资料获取

在公众号后台回复“领资料”,可免费获取数据分析、机器学习、深度学习等学习资料。

点击文末“阅读原文”

获取完整代码、数据、文档。

本文选自《Python贝叶斯分层模型专题|对环境健康、医学心梗患者、体育赛事数据空间异质性实证分析合集|附数据代码》。

点击标题查阅往期内容

专题|Python贝叶斯金融数据应用实例合集:随机波动率SV模型、逻辑回归、参数更新、绩效比较BEST分析亚马逊股票、普尔指数

R语言Stan贝叶斯空间条件自回归CAR模型分析死亡率多维度数据可视化

数据分享|WEKA信贷违约预测报告:用决策树、随机森林、支持向量机SVM、朴素贝叶斯、逻辑回归

R语言和STAN,JAGS:用RSTAN,RJAG建立贝叶斯多元线性回归预测选举数据

R语言中贝叶斯网络(BN)、动态贝叶斯网络、线性模型分析错颌畸形数据

使用贝叶斯层次模型进行空间数据分析

MCMC的rstan贝叶斯回归模型和标准线性回归模型比较

python贝叶斯随机过程:马尔可夫链Markov-Chain,MC和Metropolis-Hastings,MH采样算法可视化

Python贝叶斯推断Metropolis-Hastings(M-H)MCMC采样算法的实现

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

贝叶斯线性回归和多元线性回归构建工资预测模型

Metropolis Hastings采样和贝叶斯泊松回归Poisson模型

贝叶斯分位数回归、lasso和自适应lasso贝叶斯分位数回归分析免疫球蛋白、前列腺癌数据

R语言RSTAN MCMC:NUTS采样算法用LASSO 构建贝叶斯线性回归模型分析职业声望数据

R语言STAN贝叶斯线性回归模型分析气候变化影响北半球海冰范围和可视化检查模型收敛性

PYTHON用户流失数据挖掘:建立逻辑回归、XGBOOST、随机森林、决策树、支持向量机、朴素贝叶斯和KMEANS聚类用户画像

贝叶斯分位数回归、lasso和自适应lasso贝叶斯分位数回归分析免疫球蛋白、前列腺癌数据

R语言JAGS贝叶斯回归模型分析博士生延期毕业完成论文时间

R语言Metropolis Hastings采样和贝叶斯泊松回归Poisson模型

Python决策树、随机森林、朴素贝叶斯、KNN(K-最近邻居)分类分析银行拉新活动挖掘潜在贷款客户

R语言贝叶斯MCMC:用rstan建立线性回归模型分析汽车数据和可视化诊断

R语言贝叶斯MCMC:GLM逻辑回归、Rstan线性回归、Metropolis Hastings与Gibbs采样算法实例

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

随机森林优化贝叶斯预测分析汽车燃油经济性

R语言逻辑回归、Naive Bayes贝叶斯、决策树、随机森林算法预测心脏病

R语言用Rcpp加速Metropolis-Hastings抽样估计贝叶斯逻辑回归模型的参数

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

Python贝叶斯回归分析住房负担能力数据集

R语言实现贝叶斯分位数回归、lasso和自适应lasso贝叶斯分位数回归分析

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

R语言用WinBUGS 软件对学术能力测验建立层次(分层)贝叶斯模型

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

R语言和STAN,JAGS:用RSTAN,RJAG建立贝叶斯多元线性回归预测选举数据

R语言基于copula的贝叶斯分层混合模型的诊断准确性研究

R语言贝叶斯线性回归和多元线性回归构建工资预测模型

R语言贝叶斯推断与MCMC:实现Metropolis-Hastings 采样算法示例

R语言stan进行基于贝叶斯推断的回归模型

R语言中RStan贝叶斯层次模型分析示例

R语言使用Metropolis-Hastings采样算法自适应贝叶斯估计与可视化

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

WinBUGS对多元随机波动率模型:贝叶斯估计与模型比较

R语言实现MCMC中的Metropolis–Hastings算法与吉布斯采样

R语言贝叶斯推断与MCMC:实现Metropolis-Hastings 采样算法示例

R语言使用Metropolis-Hastings采样算法自适应贝叶斯估计与可视化

视频:R语言中的Stan概率编程MCMC采样的贝叶斯模型

R语言MCMC:Metropolis-Hastings采样用于回归的贝叶斯估计

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/75923.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于 Qt / HTTP/JSON 的智能天气预报系统测试报告

目录 一、项目概述 1.1项目背景 1.2项目目标 二、功能需求 2.1 用户界面功能 2.2 后台功能 三、技术选择 3.1 开发框架与工具 3.2 第三方 API 四、UI设计 4.1界面展示 4.2stylesheet样式 五、代码实现 1.构造函数 2.网络请求响应处理函数 3.处理json数据 4.更新…

GitLab 中文版17.10正式发布,27项重点功能解读【三】

GitLab 是一个全球知名的一体化 DevOps 平台,很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版,专门为中国程序员服务。可以一键式部署极狐GitLab。 学习极狐GitLab 的相关资料: 极狐GitLab 官网极狐…

DPO介绍+公式推理

1. 什么是DPO? DPO(Direct Preference Optimization)是一种用于对齐大语言模型(LLMs)的新型方法,旨在高效地将人类偏好融入模型训练中。它提供了一种替代强化学习(如 RLHF, Reinforcement Learn…

C语言基础—构造类型

数据类型 1.基本类型/基础类型 整型 短整型:short[int] --2字节 基本整型:int --4字节 长整型:long[int] --32位4字节/64位8字节 长长整型:long long [int] (C99) 注意:以上类型又都分为sig…

2025年高压电工考试真题分享

以下是一些高压电工考试题: 单选题 1、高压架空线路的档距一般为( )。 A. 20 - 30m B. 30 - 50m C. 50 - 80m D. 80 - 100m 答案:B。解析:高压架空线路档距一般在 30 - 50m,这样的档距能较好地保证线…

什么是SQL作业

SQL作业是在数据库服务器上按特定时间或间隔自动执行的计划任务或流程,这些作业由Microsoft SQL Server中的SQL Server代理管理,对于自动执行日常任务(如数据库系统中的备份、数据导入和报告生成)以及确保及时准确地处理和更新数据…

【数据分享】基于联合国城市化程度框架的全球城市边界数据集(免费获取/Shp格式)

在全球城市化进程不断加快的今天,如何精准定义和测量“城市”成为关键问题。不同国家和机构采用不同的标准,导致全球城市化水平的统计结果存在较大差异。同时,由于数据来源分散、标准不统一,获取一套完整、可比的全球城市边界数据…

刘火良FreeRTOS内核实现与应用学习之6——多优先级

在FreeRTOS中,数字优先级越小,逻辑优先级也越小;在任务创建时,会根据任务的优先级将任务插入就绪列表不同的位置。 List_t pxReadyTasksLists[ configMAX_PRIORITIES ] 就绪列表是一个数组,数组中存储的是就绪任务TCB(…

生成信息提取的大型语言模型综述

摘要 信息提取(IE)旨在从简单的自然语言文本中提取结构知识。最近,生成型大型语言模型(LLMs)在文本理解和生成方面表现出了显著的能力。因此,已经提出了许多基于生成范式将LLM集成到IE任务中的工作。为了对…

简单谈谈很火的MCP( Model Context Protocol,模型上下文协议)

MCP( Model Context Protocol,模型上下文协议)是由Anthropic推出的开放协议,并非独立的大模型,而是连接大模型与外部工具/数据源的标准化接口‌,旨在解决AI工具开发中接口不统一、跨模型共享困难等问题。‌ 一、工作原理 MCP 协…

解决linux centos ubuntu等无法启动谷歌chrome浏览器问题

命令启动chrome时候提示: Running as root without --no-sandbox is not supported. See https://crbug.com/638180. 解决无法启动谷歌chrome浏览器: cd /usr/bin 发现目录下有 google-chrome google-chrome-stable 执行: vim go…

深入解析缓冲区:计算机世界的“蓄水池”与“加速器”

引言 想象这样一个场景: 你的手机正在播放4K视频,同时下载大型文件 视频画面流畅无卡顿,下载速度稳定在满带宽 但手机的内存只有8GB,下载文件的大小却超过20GB 这看似矛盾的现象背后,缓冲区(Buffer&am…

网络故障诊断

一 网络故障诊断的方法 1 试错法:通过推测提出解决方案,最后得出故障原因的方法。 2 参照法:是一种比较快速解决网络故障的方法,只有当故障设备与正常工作设备具有相近的条件时,才可以使用参照法。 3 替换法&#xff1…

界面控件Telerik和Kendo UI 2025 Q1亮点——AI集成与数据可视化

Telerik DevCraft包含一个完整的产品栈来构建您下一个Web、移动和桌面应用程序。它使用HTML和每个.NET平台的UI库,加快开发速度。Telerik DevCraft提供完整的工具箱,用于构建现代和面向未来的业务应用程序,目前提供UI for ASP.NET MVC、Kendo…

ollama迁移已下载的单个模型到服务器

ollama迁移已下载的单个模型到服务器 场景 ollama是面向用户级的,部署和运行都很简单,是否高效就另说了。但最起码,他能充分利用用户的硬件设备,在GPU不足也能调用cpu和内存去加持。 ollama运行的模型基本是量化版本的&#xf…

怎么对asp.web api进行单元测试?

在 ASP.NET Web API 中进行单元测试是一种确保代码质量和功能正确性的重要实践。单元测试的重点是针对 API 控制器中的逻辑进行测试,而不依赖于外部依赖(如数据库、文件系统或网络请求)。以下是实现 ASP.NET Web API 单元测试的步骤和方法&am…

UDP视频传输中的丢包和播放花屏处理方法

在处理UDP视频传输中的丢包和花屏问题时,需要结合编码优化、网络传输策略和接收端纠错技术。以下是分步骤的解决方案: 1. 前向纠错(FEC,Forward Error Correction) 原理:在发送数据时附加冗余包,接收方通过冗余信息恢复丢失的数据包。 实现方法: 使用Reed-Solomon、XO…

WebGL图形编程实战【3】:矩阵操控 × 从二维到三维的跨越

上一篇文章:WebGL图形编程实战【2】:动态着色 纹理贴图技术揭秘 仓库地址:github…、gitee… 矩阵操控 矩阵变换 回到前面关于平移缩放、旋转的例子当中,我们是通过改变传递进去的xy的值来改变的。 在进行基础变换的时候&…

并发编程--共享内存SHM

共享内存SHM 文章目录 共享内存SHM1. 基本概念2. 函数接口2.1 创建或打开SHM对象2.2 映射 / 解除映射SHM对象2.3 其余操作2.4示例代码 1. 基本概念 共享内存,顾名思义,就是通过不同进程共享一段相同的内存来达到通信的目的,由于SHM对象不再交…

Redis中的数据类型与适用场景

目录 前言1. 字符串 (String)1.1 特点1.2 适用场景 2. 哈希 (Hash)2.1 特点2.2 适用场景 3. 列表 (List)3.1 特点3.2 适用场景 4. 集合 (Set)4.1 特点4.2 适用场景 5. 有序集合 (Sorted Set)5.1 特点5.2 适用场景 6. Redis 数据类型的选型建议结语 前言 Redis 作为一款高性能的…