news 2026/4/21 13:17:25

R语言绘制复杂加权数据(nhanes数据)多模型生存分析决策曲线

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
R语言绘制复杂加权数据(nhanes数据)多模型生存分析决策曲线

决策曲线分析(Decision Curve Analysis, DCA)是一种用于评估、比较和优化诊断试验、预测模型或分子标志物临床实用性的统计方法。它由Andrew J. Vickers和Eugene B. Elkin于2006年提出,旨在弥补传统统计指标(如灵敏度、特异度、ROC曲线下面积)在评估模型临床价值方面的不足。


在既往文章,本人介绍了我的ggscidca包,可以用于逻辑回归,生存分析等各种决策曲线绘制,但是据我所知,目前还没有R包能支持复杂加权数据(nhanes数据)生存分析决策曲线,在上篇文章《R语言绘制复杂加权数据(nhanes数据)生存分析决策曲线》我已经介绍了R语言绘制复杂加权数据(nhanes数据)生存分析决策曲线,目前我继续升级了ggscidca包,使得它能进一步支持nhanes多模型生存分析决策曲线,

下面我来演示一下,先导入数据和R包

library(survey)library(ggscidca)library(scinhanes)bc<-read.csv("E:/r/test/nahnesme.csv",sep=',',header=TRUE)bc<-na.omit(bc)


我介绍一下数据,SEQN:序列号,RIAGENDR, # 性别, RIDAGEYR, # 年龄,RIDRETH1, # 种族,DMDMARTL, # 婚姻状况,WTINT2YR,WTMEC2YR, # 权重,SDMVPSU, # psu,SDMVSTRA,# strata,LBDGLUSI, #血糖mmol表示,LBDINSI, #胰岛素( pmmol/L),PHAFSTHR #餐后血糖,LBXGH #糖化血红蛋白,SPXNFEV1, #FEV1:第一秒用力呼气量,SPXNFVC #FVC:用力肺活量,ml(估计肺容量),LBDGLTSI #餐后2小时血糖,factor.FVC是我把肺活量分为了2分类,方便用于测试。

把分类变量转成因子

bc$DMDMARTL<-ifelse(bc$DMDMARTL==1,1,0)bc$RIAGENDR<-as.factor(bc$RIAGENDR)bc$RIDRETH1<-as.factor(bc$RIDRETH1)bc$DMDMARTL<-as.factor(bc$DMDMARTL)bc$oGTT2<-as.factor(bc$oGTT2)

如果做预测模型要拆分成建模集和验证集。我这里拆分一下

set.seed(123)tr1<-sample(nrow(bc),0.7*nrow(bc))##随机无放抽取bc_train<-bc[tr1,]#70%数据集bc_test<-bc[-tr1,]#30%数据集

建立抽样调查函数

bcSvy2<-svydesign(ids=~SDMVPSU,strata=~SDMVSTRA,weights=~WTMEC2YR,nest=TRUE,data=bc_train)

建立生存分析模型

svyfit<-svycoxph(Surv(time,factor.FVC)~RIDAGEYR+RIAGENDR+LBDINSI+RIDRETH1,x=TRUE,design=bcSvy2)

复习一下单个决策曲线模型的内容,绘制复杂加权数据(nhanes数据)决策曲线一共需要2步:

  1. 第一步,把模型变成ggscidca包能够识别的类型
fit<-scisvycoxphmodel(svyfit,username=username,token=token)
  1. 绘制决策曲线
scidca(fit)


绘制多模型的决策曲线其实就是复制单个决策曲线的过程,由两种情况:

  1. 就是同一个模型多个时间点的
fit1<-scisvycoxphmodel(fit=svyfit,timepoint=300,username=username,token=token)fit2<-scisvycoxphmodel(fit=svyfit,timepoint=500,username=username,token=token)fit3<-scisvycoxphmodel(fit=svyfit,timepoint=700,username=username,token=token)

制作数据列表的绘图,如果你既往使用过ggscidca包,是一模一样的,上手0困难

newdat<-list(bc_train,bc_train,bc_train)cox.tcdca(fit1,fit2,fit3,newdata=newdat,timepoint=c(300,500,700))


2. 第二个情况就是多个模型同一个时间点的
###多个模型一个时间点

svyfit1<-svycoxph(Surv(time,factor.FVC)~RIDAGEYR,x=TRUE,design=bcSvy2)svyfit2<-svycoxph(Surv(time,factor.FVC)~RIDAGEYR+RIAGENDR,x=TRUE,design=bcSvy2)svyfit3<-svycoxph(Surv(time,factor.FVC)~RIDAGEYR+RIAGENDR+LBDINSI+RIDRETH1,x=TRUE,design=bcSvy2)

因为模型不同,都要转换一遍

###转换模型fit1<-scisvycoxphmodel(svyfit1,username=username,token=token)fit2<-scisvycoxphmodel(svyfit2,username=username,token=token)fit3<-scisvycoxphmodel(svyfit3,username=username,token=token)

绘图

newdat<-list(bc_train,bc_train,bc_train)cox.tcdca(fit1,fit2,fit3,newdata=newdat,timepoint=c(300))


支持自定义颜色

cox.tcdca(fit1,fit2,fit3,newdata=newdat,timepoint=c(300),lincol=c("#E41A1C","#377EB8","#4DAF4A","#984EA3","#FF7F00"))

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 3:28:40

EmotiVoice社区生态崛起:插件、工具与二次开发案例汇总

EmotiVoice社区生态崛起&#xff1a;插件、工具与二次开发案例汇总 在虚拟主播深夜直播带货、AI老师为学生定制朗读课文、游戏NPC因剧情转折突然语气颤抖的今天&#xff0c;语音合成早已不再满足于“把字念出来”。用户期待的是能传递情绪、具备个性、甚至带有“人格”的声音。…

作者头像 李华
网站建设 2026/4/20 15:44:23

方才的系分架构训练营升级啦!别错过!

Hello&#xff0c;我是方才。先做个简单的自我介绍&#xff0c;认识下&#xff1a;【城市】重庆【职业|经验】在职15人研发leader 7年【架构经验】4年架构经验&#xff0c;负责过多个大型项目&#xff08;单表超10亿&#xff0c;整体超100亿的海量业务数据&#xff09;的架构设…

作者头像 李华
网站建设 2026/4/17 17:05:21

2026最新版Ubuntu安装Docker(20.10+)和Docker Compose

一、安装Docker 准备环境#安装前先卸载操作系统默认安装的docker&#xff0c; sudo apt-get remove docker docker-engine docker.io containerd runc#安装必要支持 sudo apt install apt-transport-https ca-certificates curl software-properties-common gnupg lsb-releas…

作者头像 李华
网站建设 2026/4/17 10:33:32

TOB企业获客软件选型指南:技术架构、方法论与实践评估

在数字化转型浪潮的推动下&#xff0c;TOB&#xff08;企业对企​​业&#xff09;企业的销售与市场模式正经历深刻变革。传统的电话销售、展会营销等线下获客方式成本高昂、效率瓶颈日益凸显&#xff0c;而线上渠道碎片化、数据孤岛等问题又为精准定位目标客户带来了巨大挑战。…

作者头像 李华
网站建设 2026/4/21 11:24:23

基于springboot + vue酒店管理系统

酒店管理管理 目录 基于springboot vue酒店管理系统 一、前言 二、系统功能演示 详细视频演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue酒店管理系统 一、前言 博主介绍…

作者头像 李华
网站建设 2026/4/16 15:44:30

出口接地电阻柜需要注意什么

接地电阻柜&#xff0c;用于出口项目需要更加严谨。在操作、安装、维护及环境适应性方面需遵循严格规范&#xff0c;以确保电力系统安全稳定运行。以下结合关键注意事项进行说明。操作前需确认电源稳定性&#xff0c;检查接线正确性&#xff0c;避免短路或接触不良。‌同时&…

作者头像 李华