TCGA+biomarker——Nomogram列线图

列线图简介

列线图(Alignment Diagram),又称诺莫图(Nomogram图),它是建立在多因素回归分析的基础上,将多个预测指标进行整合,然后采用带有刻度的线段,按照一定的比例绘制在同一平面上,从而用以表达预测模型中各个变量之间的相互关系。它的基本原理,简单的说,就是通过构建多因素回归模型(常用的回归模型,例如Cox回归、Logistic回归等),根据模型中各个影响因素对结局变量的贡献程度(回归系数的大小),给每个影响因素的每个取值水平进行赋分,然后再将各个评分相加得到总评分,最后通过总评分与结局事件发生概率之间的函数转换关系,从而计算出该个体结局事件的预测值。列线图将复杂的回归方程,转变为了可视化的图形,使预测模型的结果更具有可读性,方便对患者进行评估。正是由于列线图这种直观便于理解的特点,使它在医学研究和临床实践中也逐渐得到了越来越多的关注和应用。

列线图案例展示

image

列线图结果解释

image

解释:假设有一个患者,治疗方式是Resection,肿瘤大小是3-5,复发部位是Intrahepatic,多处复发是No,复发时间是1-2,复发时AFP是>200,复发时albumin-bilirutinl grade是II, III,抗病毒治疗是Yes。在图上找到各个点,对应上方Point的值,将所有的值相加(本处只是讲解大概的值,具体数值应该在模型中计算:Total Points=0+42+20+0+4+31+22+0=119)。在Total中我们可以看到,119对应的2年和5年的生存率分别约为0.80和0.68(本处是大致值,由于没有具体模型参数,无法给出精确值)。这就进一步说明Nomogram图的内容,本质就是对模型各个参数的一个直观展示。

如何绘制列线图?

方法1:nomogram函数绘制 (适用于rms:psm函数返回的回归结果)
rm(list = ls())
# install.packages("survival")
# install.packages("rms")

library(survival)
library(rms)

#载入并查看数据集
data("lung") #status中1代表活着,2代表死了. sex中male=1,female=2
head(lung)
str(lung)

#关键步骤:按照nomogram要求“打包”数据
ddist <- datadist(lung)
options(datadist="ddist")

#构建COX模型,绘制诺莫图
res.cox <- psm(Surv(time, status) ~ age+sex+ph.ecog+ph.karno+pat.karno, data = lung,dist='lognormal')
surv <- Survival(res.cox) # 构建生存概率函数
# function(x) surv(365, x)#计算1年事件发生概率
# function(x) surv(1825, x)#计算5年事件发生概率

nom.cox <- nomogram(res.cox,
                    fun=list(function(x) surv(365, x),
                             function(x) surv(1825, x)),
                    funlabel=c("1-year Survival Probability", "5-year Survival Probability"),
                    maxscale=10,
                    fun.at=c(0.01,seq(0.1,0.9,by=0.2),0.95,0.99))

#maxscale参数指定最高分数,一般设置为100或者10分
#fun.at设置生存率的刻度

plot(nom.cox)

结果如下:这类结果过于简陋!

image
方法2:regplot函数绘制

regplot包中的regplot()函数可绘制较为美观的nomogram。但是,它目前只接收coxph()、lm()和glm()函数返回的回归对象。

rm(list = ls())
install.packages("regplot")
library(regplot)
library("survival")
library("survminer")

#载入并查看数据集
data("lung")
head(lung)
str(lung)#该数据将所有变量都转换为数值型,包括性别(1,2表示),分期(1,2,3,4表示)等。

#建议将多分类变量字符化,因子化
#如sex,若保持其数值型,图会将sex作为连续性数值展示(会出现0.5,1.5的数值),这有悖于常理.
#因此,为了合乎逻辑,对于多分类变量要注意转化

#lung$sex=as.factor(lung$sex) #直接将数字型因子化,默认从小到大
lung$sex <- as.factor(ifelse(lung$sex==1,"male","female"))#将数值转化为真实属性后再因子化

#构建cox模型
res.cox <- coxph(Surv(time, status) ~ age+sex+ph.ecog+ph.karno+pat.karno, data = lung)
#status中1代表活着,2代表死了. 默认数值较小者为结局,表明该模型以生存为结局事件

#绘制列线图, #因子化分类变量每个协变量用方框表示,数值型变量以连续性坐标轴表示。
nom1<-regplot(res.cox, clickable=TRUE, 
        points=TRUE, rank="sd",failtime = c(180,365),prfail = T)

#指定标记的样本行
nom2<-regplot(res.cox,observation=lung[3,], clickable=TRUE, 
               points=TRUE, rank="sd",failtime = c(180,365),droplines=T,prfail = T,
             other=(list(bvcol="red",sq="green",obscol="blue")))

#res.cox表示模型,可以是广义线性模型(glm),线性(lm),生存分析(cox比例风险模型)
#observation指定某个患者各协变量的取值映射到相应的得分,并计算总得分
#failtime = c(180,365)计算其在180和365天的累计事件发生概率
#本案例中lung是个生存类数据,status=1代表构建的是生存模型,因此prfail = T
#参考:https://mp.weixin.qq.com/s/WpRnX7YdF-Jv3oQqYaFMVA

如下图,regplot绘图更加美观,可以比较灵活的定义细节。

image

可任意标记想突出的患者在列线图上的分值分布,及事件发生风险概率!

image

网络参考
https://mp.weixin.qq.com/s/BWpy3F-nEKXCdVXmY3GYZg
https://mp.weixin.qq.com/s/gpR6IlS4XGaE8xngS7bQrQ

往期回顾
TCGA+biomarker——常见结果展示
TCGA+biomarker——Sample基线表
TCGA+biomarker——单因素Cox回归
TCGA+biomarker——多因素Cox回归
TCGA+biomarker——Cox回归森林图

更多内容可关注公共号“YJY技能修炼”~~~

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