从0开始学习R语言--Day37--CMH检验

对于有多个特征的数据,我们一般的处理方式是构建特征函数,计算每个特征向量的系数,从而将其影响纳入到研究量中,但对于简单的问题,也这样做的话未免有点小题大做。这时我们可以考虑用CMH来分析变量在每个特征下的影响,这个方法可以通过分层控制不同的无关特征和变量,凸显变量真实的关联关系。

以下是一个例子:

R 复制代码
set.seed(123)
n <- 500  # 增大样本量
Age <- sample(c("Young", "Middle", "Old"), n, replace = TRUE, prob = c(0.3, 0.4, 0.3))
Drug <- sample(c("A", "B"), n, replace = TRUE)

# 改进:药物B在Old组更可能有效,但允许例外
Effect <- ifelse(
  (Drug == "B" & Age == "Old" & runif(n) > 0.2) |  # 80% 有效
    (Drug == "A" & Age == "Young" & runif(n) > 0.3) | # 70% 有效
    (Age == "Middle" & Drug == "B" & runif(n) > 0.6) | # Middle组B药40%有效
    (runif(n) > 0.9),  # 10% 的全局随机有效
  "Improved", 
  "Not Improved"
)
df <- data.frame(Age, Drug, Effect)
head(df)

# 三维列联表(Age × Drug × Effect)
table_array <- table(df$Drug, df$Effect, df$Age)
table_array

# 使用mantelhaen.test()
result <- mantelhaen.test(table_array)
result


library(ggplot2)
ggplot(df, aes(x = Drug, fill = Effect)) +
  geom_bar(position = "fill") +
  facet_wrap(~ Age) +
  labs(y = "Proportion") +
  theme_minimal()

输出:

R 复制代码
, ,  = Middle

   
    Improved Not Improved
  A       15           84
  B       51           59

, ,  = Old

   
    Improved Not Improved
  A        7           63
  B       60           18

, ,  = Young

   
    Improved Not Improved
  A       52           24
  B        5           62 
	Mantel-Haenszel chi-squared test with continuity correction

data:  table_array
Mantel-Haenszel X-squared = 12.072, df = 1, p-value = 0.000512
alternative hypothesis: true common odds ratio is not equal to 1
95 percent confidence interval:
 0.4232736 0.8208328
sample estimates:
common odds ratio 
        0.5894378

从输出可以看到,在Middle和Old组药物B更有效,Young组则是药物A,而检验的结果p为0.0005,说明在调查年龄分组后,药物与疗效的关系十分显著,而公共比值则意味着使用药物B的患者获得改善的几率是药物A的0.59倍。

相关推荐
拥抱AGI1 分钟前
Qwen3.5开源矩阵震撼发布!从0.8B到397B,不同规模模型性能、显存、速度深度对比与选型指南来了!
人工智能·学习·程序员·开源·大模型·大模型训练·qwen3.5
sp_fyf_202423 分钟前
【大语言模型】从失败中学习:在微调大型语言模型作为智能体时整合负例
人工智能·深度学习·学习·机器学习·语言模型·自然语言处理
秋雨梧桐叶落莳40 分钟前
【iOS】 AutoLayout初步学习
学习·macos·ios·objective-c·cocoa·xcode
for_ever_love__1 小时前
Objective-C学习UI 的初步了解(2)
学习·ui·objective-c
m0_716765231 小时前
数据结构--顺序表的插入、删除、查找详解
c语言·开发语言·数据结构·c++·学习·算法·visual studio
我要成为嵌入式大佬1 小时前
学习linux的部分疑惑与解答(非专业)
学习
Дерек的学习记录1 小时前
Unreal Eangie 5:蓝图编程
开发语言·学习·ue5
AI科技星1 小时前
基于v≡c第一性原理:密度的本质与时空动力学
人工智能·学习·算法·机器学习·数据挖掘
Orange_sparkle1 小时前
learn claude code学习记录-S01
学习·claude code
想你依然心痛1 小时前
HarmonyOS 5.0教育科技开发实战:构建AI个性化学习与分布式协同教育系统
人工智能·学习·harmonyos