列线图疑问

单因素生存分析,单因素回归Cox分析

多因素Cox分析

列线图

Cox与KM生存分析及结果解读

COX


KM


生存分析


TCGA

Cox与KM生存分析及结果解读,查找与预后相关的biomarker

生存分析:针对于慢性病(癌症),因为其无法在短时间内判断预后,不宜采用治愈率和病死率等指标,而是需要对患者进行随访,分析一定时间后患者生存或死亡的情况,这样将事件的结果和出现这一结果所经历的时间结合起来分析的统计方法称为生存分析。

生存分析KM法与Cox法异同介绍

KM 方法即Kaplan-Meier survival estimate是一种无参数方法(non-parametric)来从观察的生存时间来估计生存概率的方法。KM生存分析模型,是单变量分析(univariable analysis),在做单变量分析时,模型只描述了该单变量和生存之间的关系而忽略其他变量的影响。(为什么要考虑multi-variables?比如在比较两组病人拥有和不拥有某种基因型对生存率的影响,但是其中一组的患者年龄较大,所以生存率可能受到基因型 或/和 年龄的共同影响)。同时,Kaplan-Meier方法只能针对分类变量(治疗A vs 治疗B,男 vs 女),不能分析连续变量对生存造成的影响。为了解决上述两种问题,Cox比例风险回归模型(Cox proportional hazards regression model)就被提了出来。因此,Cox比例风险回归模型,可以分析连续变量对生存造成的影响,也可以多变量分析对生存的影响。

R语言中的生存分析R包介绍

R是数据分析常用的软件之一,通过各种功能强大的R包,可以简单方便的实现各种分析。在R语言中,能够进行生存分析的R包很多,survival和survminer是其中最基本的两个,survival负责分析,survimner负责可视化,二者相结合,可以轻松实现生存分析。

R语言中的KM模型分析

1. 准备生存数据

对于每个个体而言,其生存数据会出现两种情况,第一种是观测到生存时间,通常用1表示,第二种则是删失。通常用0表示。survival自带了一个测试数据lung, 内容如下所示

每一行代表一个样本,time表示生存时间,status表示删失情况,这里只有1和2两种取值,默认排序后的第一个level对应的值为删失,这里则为1表示删失。其他列为样本对应的性别,年龄等基本信息。

2. 进行生存分析

这里根据性别这个二分类变量,采用KM算法来估计生存曲线,代码如下(summary结果只显示部分)

> library("survival")

> library("survminer")

> kmfit<-survfit(Surv(time,status) ~ sex, data =  lung)

> summary(kmfit)

Call: survfit(formula = Surv(time,status) ~ sex, data = lung)

sex=1

timen.risk n.event survival std.errlower95% CIupper95% CI

1113830.97830.01240.95421.000

1213510.97100.01430.94340.999

1313420.95650.01740.92310.991

1513210.94930.01870.91340.987

2613110.94200.01990.90380.982

3013010.93480.02100.89450.977

从kmfit中summary可以看到已经包含了每个时间点的生存概率,删失等信息,通过这些信息,完全可以自己写代码来画图。为了方便,我们直接采用survminer中的函数来进行可视化。

3. 分析结果的可视化

最基本的可视化方式如下

library("survminer")

ggsurvplot(kmfit,

pval =TRUE, conf.int =TRUE,

risk.table =TRUE,

risk.table.col ="strata",

linetype ="strata",

surv.median.line ="hv",

ggtheme = theme_bw(),

palette = c("#E7B800","#2E9FDF"))

语言中的Cox模型分析

1.单变量Cox回归

library("survival")

library("survminer")

res.cox <- coxph(Surv(time,status) ~ sex, data =  lung)

summary(res.cox)

res.cox <- coxph(Surv(time,status) ~ sex, data =  lung)

summary(res.cox)

summary的结果:

Call:

coxph(formula = Surv(time,status) ~ sex, data = lung)

n=228, number of events=165

coefexp(coef) se(coef)      z Pr(>|z|)

sex-0.53100.58800.1672-3.1760.00149**

---

Signif. codes:0‘***’0.001‘**’0.01‘*’0.05‘.’0.1‘ ’1

exp(coef)exp(-coef)lower.95upper.95

sex0.5881.7010.42370.816

Concordance=0.579(se =0.021)

Likelihood ratio test=10.63on1df,   p=0.001

Wald test            =10.09on1df,   p=0.001

Score (logrank) test =10.33on1df,   p=0.001

Cox回归结果可以解释如下:

统计显着性。标记为“z”的列给出了Wald统计值。它对应于每个回归系数与其标准误差的比率(z = coef / se(coef))。wald统计评估是否beta(ββ)系数在统计上显着不同于0。从上面的输出,我们可以得出结论,变量性别具有高度统计学意义的系数。

回归系数。Cox模型结果中要注意的第二个特征是回归系数(coef)的符号。一个积极的信号意味着危险(死亡风险)较高,因此对于那些变量值较高的受试者,预后更差。变量性被编码为数字向量。1:男,2:女。Cox模型的R总结给出了第二组相对于第一组,即女性与男性的风险比(HR)。性别的β系数= -0.53表明在这些数据中,女性的死亡风险(低存活率)低于男性。

危害比例。指数系数(exp(coef)= exp(-0.53)= 0.59)也称为风险比,给出协变量的效应大小。例如,女性(性别= 2)将危害降低了0.59倍,即41%。女性与预后良好相关。

风险比的置信区间。总结结果还给出了风险比(exp(coef))的95%置信区间的上限和下限,下限95%界限= 0.4237,上限95%界限= 0.816。

全球统计学意义的模型。最后,输出为模型的总体显着性提供了三个替代测试的p值:可能性比率测试,Wald测试和得分logrank统计。这三种方法是渐近等价的。对于足够大的N,他们会得到相似的结果。对于小N来说,它们可能有所不同。似然比检验对于小样本量具有更好的表现,所以通常是优选的。

2.多变量Cox回归

要一次性将单变量coxph函数应用于多个协变量,请输入:

res.cox <- coxph(Surv(time,status) ~ age + sex + ph.ecog, data =  lung)

summary(res.cox)

Call:

coxph(formula = Surv(time,status) ~ age + sex + ph.ecog, data = lung)

n=227, number of events=164

(1observation deleted due to missingness)

coefexp(coef)  se(coef)      z Pr(>|z|)

age0.0110671.0111280.0092671.1940.232416

sex-0.5526120.5754450.167739-3.2940.000986***

ph.ecog0.4637281.5899910.1135774.0834.45e-05***

---

Signif. codes:0‘***’0.001‘**’0.01‘*’0.05‘.’0.1‘ ’1

exp(coef)exp(-coef)lower.95upper.95

age1.01110.98900.99291.0297

sex0.57541.73780.41420.7994

ph.ecog1.59000.62891.27271.9864

Concordance=0.637(se =0.025)

Likelihood ratio test=30.5on3df,   p=1e-06

Wald test            =29.93on3df,   p=1e-06

Score (logrank) test =30.5on3df,   p=1e-06

所有3个整体测试(可能性,Wald 和 得分)的p值都是显着的,表明该模型是显着的。这些测试评估了所有的beta(ββ)为0.在上面的例子中,检验统计是完全一致的,综合零假设被完全拒绝。

在多变量Cox分析中,协变量性别和ph.ecog仍然显着(p <0.05)。然而,协变量年龄并不显着(P = 0.17,这比0.05)。

性别p值为0.000986,危险比HR = exp(coef)= 0.58,表明患者性别和死亡风险降低之间有很强的关系。协变量的风险比可以解释为对风险的倍增效应。例如,保持其他协变量不变,女性(性别= 2)将危害降低0.58倍,即42%。我们的结论是,女性与良好的预后相关。

类似地,ph.ecog的p值是4.45e-05,危险比HR = 1.59,表明ph.ecog值与死亡风险增加之间的强关系。保持其他协变量不变,ph.ecog值越高,生存率越差。

相比之下,年龄的p值现在是p = 0.23。风险比HR = exp(coef)= 1.01,95%置信区间为0.99至1.03。由于HR的置信区间为1,这些结果表明,年龄在调整了ph值和患者性别后对HR的差异的贡献较小,并且仅趋向显着性。例如,保持其他协变量不变,额外的年龄会导致每日死亡危险因素为exp(beta)= 1.01或1%,这不是一个重要的贡献。

可视化估计的生存时间分布

已经将Cox模型拟合到数据中,可以在特定风险组的任何给定时间点可视化预测的存活比例。函数survfit()估计生存比例,默认情况下为协变量的平均值。

绘制生存曲线:

kmfit<-survfit(Surv(time, status) ~ sex, data =  lung)

ggsurvplot(kmfit,

pval =TRUE, conf.int=TRUE,

risk.table =TRUE,

risk.table.col ="strata",

linetype ="strata",

surv.median.line ="hv",

ggtheme = theme_bw(),

palette = c("#E7B800","#2E9FDF"))

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,718评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,683评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,207评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,755评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,862评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,050评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,136评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,882评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,330评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,651评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,789评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,477评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,135评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,864评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,099评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,598评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,697评论 2 351

推荐阅读更多精彩内容