十一成畦、timeROC

1.準(zhǔn)備輸入數(shù)據(jù)

load("TCGA-KIRC_sur_model.Rdata")

2.構(gòu)建lasso回歸模型

輸入數(shù)據(jù)是表達(dá)矩陣(僅含tumor樣本)和對(duì)應(yīng)的生死。

x=t(exprSet)
y=meta$event
library(glmnet)
cv_fit <- cv.glmnet(x=x, y=y, nlambda = 1000,alpha = 1)
model_lasso_min <- glmnet(x=x, y=y, alpha = 1, lambda=cv_fit$lambda.min)
choose_gene_mi n=rownames(model_lasso_min$beta)[as.numeric(model_lasso_min$beta)!=0]
length(choose_gene_min)
#> [1] 39

3.模型預(yù)測(cè)和評(píng)估

3.1自己預(yù)測(cè)自己

lasso.prob <- predict(cv_fit, newx=x , s=cv_fit$lambda.min )
re=cbind(y ,lasso.prob)
head(re)
#>                              y         1
#> TCGA-A3-3307-01A-01T-0860-13 0 0.1107463
#> TCGA-A3-3308-01A-02R-1324-13 0 0.3985909
#> TCGA-A3-3311-01A-02R-1324-13 1 0.2875707
#> TCGA-A3-3313-01A-02R-1324-13 1 0.3884061
#> TCGA-A3-3316-01A-01T-0860-13 0 0.3288315
#> TCGA-A3-3317-01A-01T-0860-13 0 0.3793098

3.2 time-ROC

new_dat=meta
library(timeROC)
library(survival)
library(survminer)
new_dat$fp=as.numeric(lasso.prob[,1])
with(new_dat,
     ROC <<- timeROC(T=time,#結(jié)局時(shí)間 
                     delta=event,#生存結(jié)局 
                     marker=fp,#預(yù)測(cè)變量 
                     cause=1,#陽(yáng)性結(jié)局賦值悬槽,比如死亡與否
                     weighting="marginal",#權(quán)重計(jì)算方法,marginal是默認(rèn)值瞬浓,采用km計(jì)算刪失分布
                     times=c(60,100),#時(shí)間點(diǎn)初婆,選取5年(60個(gè)月)和8年生存率,小的年份寫前面
                     ROC = TRUE,
                     iid = TRUE)
)
auc_60 = ROC$AUC[[1]]
auc_100 = ROC$AUC[[2]]
dat = data.frame(tpr_60 = ROC$TP[,1],
                 fpr_60 = ROC$FP[,1],
                 tpr_100 = ROC$TP[,2],
                 fpr_100 = ROC$FP[,2])
library(ggplot2)

ggplot() + 
  geom_line(data = dat,aes(x = fpr_60, y = tpr_60),color = "blue") + 
  geom_line(data = dat,aes(x = fpr_100, y = tpr_100),color = "red")+
  geom_line(aes(x=c(0,1),y=c(0,1)),color = "grey")+
  theme_bw()+
  annotate("text",x = .75, y = .25,
           label = paste("AUC of 60 = ",round(auc_60,2)),color = "blue")+
  annotate("text",x = .75, y = .15,label = paste("AUC of 100 = ",round(auc_100,2)),color = "red")+
  scale_x_continuous(name  = "fpr")+
  scale_y_continuous(name = "tpr")

4.切割數(shù)據(jù)構(gòu)建模型并預(yù)測(cè)

4.1 切割數(shù)據(jù)

用R包c(diǎn)aret切割數(shù)據(jù)猿棉,生成的結(jié)果是一組代表列數(shù)的數(shù)字磅叛,用這些數(shù)字來(lái)給表達(dá)矩陣和meta取子集即可。

library(caret)
set.seed(12345679)
sam<- createDataPartition(meta$event, p = .5,list = FALSE)
train <- exprSet[,sam]
test <- exprSet[,-sam]
train_meta <- meta[sam,]
test_meta <- meta[-sam,]

4.2 切割后的train數(shù)據(jù)集建模

和上面的建模方法一樣萨赁。

#計(jì)算lambda
x = t(train)
y = train_meta$event
cv_fit <- cv.glmnet(x=x, y=y, nlambda = 1000,alpha = 1)
#構(gòu)建模型
model_lasso_min <- glmnet(x=x, y=y, alpha = 1, lambda=cv_fit$lambda.min)
#挑出基因
choose_gene_min=rownames(model_lasso_min$beta)[as.numeric(model_lasso_min$beta)!=0]
length(choose_gene_min)
#> [1] 18

4.3 模型預(yù)測(cè)

用訓(xùn)練集構(gòu)建模型弊琴,預(yù)測(cè)測(cè)試集的生死,注意newx參數(shù)變了杖爽。

lasso.prob <- predict(cv_fit, newx=t(test), s=cv_fit$lambda.min)
re=cbind(test_meta$event ,lasso.prob)

4.4 time-ROC

new_dat = test_meta
library(timeROC)
library(survival)
library(survminer)
new_dat$fp=as.numeric(lasso.prob[,1])
with(new_dat,
     ROC <<- timeROC(T=time,#結(jié)局時(shí)間 
                     delta=event,#生存結(jié)局 
                     marker=fp,#預(yù)測(cè)變量 
                     cause=1,#陽(yáng)性結(jié)局賦值敲董,比如死亡與否
                     weighting="marginal",#權(quán)重計(jì)算方法,marginal是默認(rèn)值慰安,采用km計(jì)算刪失分布
                     times=c(60,100),#時(shí)間點(diǎn)腋寨,選取5年(60個(gè)月)和8年生存率
                     ROC = TRUE,
                     iid = TRUE)
)
auc_60 = ROC$AUC[[1]]
auc_100 = ROC$AUC[[2]]
dat = data.frame(tpr_60 = ROC$TP[,1],
                 fpr_60 = ROC$FP[,1],
                 tpr_100 = ROC$TP[,2],
                 fpr_100 = ROC$FP[,2])
library(ggplot2)

ggplot() + 
  geom_line(data = dat,aes(x = fpr_60, y = tpr_60),color = "blue") + 
  geom_line(data = dat,aes(x = fpr_100, y = tpr_100),color = "red")+
  geom_line(aes(x=c(0,1),y=c(0,1)),color = "grey")+
  theme_bw()+
  annotate("text",x = .75, y = .25,
           label = paste("AUC of 60 = ",round(auc_60,2)),color = "blue")+
  annotate("text",x = .75, y = .15,label = paste("AUC of 100 = ",round(auc_100,2)),color = "red")+
  scale_x_continuous(name  = "fpr")+
  scale_y_continuous(name = "tpr")

*生信技能樹(shù)課程筆記

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市泻帮,隨后出現(xiàn)的幾起案子精置,更是在濱河造成了極大的恐慌,老刑警劉巖锣杂,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件脂倦,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡元莫,警方通過(guò)查閱死者的電腦和手機(jī)赖阻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)踱蠢,“玉大人火欧,你說(shuō)我怎么就攤上這事【ソ兀” “怎么了苇侵?”我有些...
    開(kāi)封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)企锌。 經(jīng)常有香客問(wèn)我榆浓,道長(zhǎng),這世上最難降的妖魔是什么撕攒? 我笑而不...
    開(kāi)封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任陡鹃,我火速辦了婚禮,結(jié)果婚禮上抖坪,老公的妹妹穿的比我還像新娘萍鲸。我一直安慰自己,他們只是感情好擦俐,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布脊阴。 她就那樣靜靜地躺著,像睡著了一般蚯瞧。 火紅的嫁衣襯著肌膚如雪蹬叭。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天状知,我揣著相機(jī)與錄音秽五,去河邊找鬼。 笑死饥悴,一個(gè)胖子當(dāng)著我的面吹牛坦喘,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播西设,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼瓣铣,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了贷揽?” 一聲冷哼從身側(cè)響起棠笑,我...
    開(kāi)封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎禽绪,沒(méi)想到半個(gè)月后蓖救,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體洪规,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年循捺,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了斩例。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡从橘,死狀恐怖念赶,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情恰力,我是刑警寧澤叉谜,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站踩萎,受9級(jí)特大地震影響停局,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜驻民,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一翻具、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧回还,春花似錦裆泳、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至蝗柔,卻和暖如春闻葵,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背癣丧。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工槽畔, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人胁编。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓厢钧,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親嬉橙。 傳聞我的和親對(duì)象是個(gè)殘疾皇子早直,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容