亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

R語言實(shí)現(xiàn)漂亮的ROC圖效果

 更新時間:2022年06月07日 14:49:51   作者:科研君  
pROC是一個專門用來計(jì)算和繪制ROC曲線的R包,目前已被CRAN收錄,因此安裝也非常簡單,同時該包也兼容ggplot2函數(shù)繪圖,本次就教大家怎么用pROC來快速畫出ROC圖,感興趣的朋友一起看看吧

pROC是一個專門用來計(jì)算和繪制ROC曲線的R包,目前已被CRAN收錄,因此安裝也非常簡單,同時該包也兼容ggplot2函數(shù)繪圖,本次就教大家怎么用pROC來快速畫出ROC圖。在醫(yī)學(xué)領(lǐng)域主要用于判斷某種因素對于某種疾病的診斷是否有診斷價值。什么是ROC曲線和AUC,以及如何去看ROC曲線的結(jié)果,可以這樣總結(jié):ROC曲線呢,其實(shí)就是每個對應(yīng)的cutoff值都有一個對應(yīng)的真陽性率(縱坐標(biāo))和假陽性率(橫坐標(biāo)),比如選擇了10個cutoff值,那就相當(dāng)于有個10個點(diǎn),把這些點(diǎn)連成一條線就是ROC曲線。AUC值就是ROC曲線下的面積,一般認(rèn)為AUC值在0.7~1之間,模型預(yù)測的結(jié)果才有效。TPR(真陽性率) = TP(真陽)/(TP(真陽) + FN(假陰)),F(xiàn)PR(假陽性率) = FP(假陽) / (FP(假陽) + TN(真陰))。 比如下面的一個模型預(yù)測后的數(shù)據(jù)結(jié)果:

上圖中如果選cutoff值為0.5時
TPR = 5 /(5 + 0)= 1,
FPR = 2 / (2 + 3) = 0.4, 
預(yù)測的準(zhǔn)確性 = (TP + TN )/ 總的樣本數(shù) = (5 + 3)/10 = 0.8

好了,話不多說,我們直接上代碼

1.讀取數(shù)據(jù)

library(openxlsx)
ROC <- read.xlsx("ROC曲線.xlsx")

2.AUC和CI的計(jì)算

library(pROC)
## roc的計(jì)算,可以一次性批量計(jì)算a、b、c三組數(shù)據(jù)
res<-roc(outcome~a+b+c,data=ROC,aur=TRUE,
         ci=TRUE, # 顯示95%CI
         # percent=TRUE, ##是否需要以百分比顯示
         levels=c('group1','group2'),direction=">" #設(shè)置分組方向
         )
## 平滑曲線的ROC結(jié)果
smooth<-roc(outcome~a+b+c,data=ROC,aur=TRUE,
         ci=TRUE, # 顯示95%CI
         # percent=TRUE, ##是否需要以百分比顯示
         smooth=TRUE,
         levels=c('group1','group2'),direction=">" #設(shè)置分組方向
         )

顯示非平滑ROC曲線的結(jié)果

res
Call:
roc.formula(formula = outcome ~ a, data = ROC, aur = TRUE, ci = TRUE,     levels = c("group1", "group2"), direction = ">")
Data: a in 40 controls (outcome group1) > 32 cases (outcome group2).
Area under the curve: 0.7328
95% CI: 0.6171-0.8485 (DeLong)
$b
Call:
roc.formula(formula = outcome ~ b, data = ROC, aur = TRUE, ci = TRUE,     levels = c("group1", "group2"), direction = ">")

Data: b in 40 controls (outcome group1) > 32 cases (outcome group2).
Area under the curve: 0.8234
95% CI: 0.7303-0.9165 (DeLong)
$c
Call:
roc.formula(formula = outcome ~ c, data = ROC, aur = TRUE, ci = TRUE,     levels = c("group1", "group2"), direction = ">")

Data: c in 40 controls (outcome group1) > 32 cases (outcome group2).
Area under the curve: 0.9242
95% CI: 0.8679-0.9805 (DeLong)

3.利用ggplot2繪圖

library(ggplot2)
pa<- ggroc(smooth$a, 
       legacy.axes = TRUE # 將X軸改為0-1,(默認(rèn)是1-0)
       )+
   geom_segment(aes(x = 0, xend = 1, y = 0, yend = 1), 
                color="darkgrey", linetype=4)+
 theme_bw() +# 設(shè)置背景
 ggtitle('a-ROC')
pb<- ggroc(smooth$b, legacy.axes = TRUE)+geom_segment(aes(x = 0, xend = 1, y = 0, yend = 1), color="darkgrey", linetype=4)+theme_bw() +ggtitle('b-ROC')
pc<- ggroc(smooth$c, legacy.axes = TRUE)+geom_segment(aes(x = 0, xend = 1, y = 0, yend = 1), color="darkgrey", linetype=4)+theme_bw() +ggtitle('c-ROC')
cowplot::plot_grid(pa,pb,pc,labels = "AUTO",nrow = 1)

4.合并多個ROC曲線結(jié)果

ggroc(smooth, legacy.axes = TRUE)+
    geom_segment(aes(x = 0, xend = 1, y = 0, yend = 1), color="darkgrey", linetype=4)+
    theme_bw()+ggtitle('ROC')+ggsci::scale_color_lancet()+
    annotate("text",x=0.75,y=0.125,label=paste("a-AUC = ", round(res$a$auc,3)))+
    annotate("text",x=0.75,y=0.25,label=paste("b-AUC = ", round(res$b$auc,3)))+
    annotate("text",x=0.75,y=0.375,label=paste("c-AUC = ", round(res$c$auc,3)))

到此這篇關(guān)于R語言實(shí)現(xiàn)漂亮的ROC圖的文章就介紹到這了,更多相關(guān)R語言 ROC圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • R語言文本文件讀寫(txt/csv/xlsx)

    R語言文本文件讀寫(txt/csv/xlsx)

    這篇文章主要介紹了R語言文本文件讀寫(txt/csv/xlsx),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • R語言向量知識點(diǎn)及實(shí)例講解

    R語言向量知識點(diǎn)及實(shí)例講解

    在本篇文章里小編給大家整理的是一篇關(guān)于R語言向量知識點(diǎn)及實(shí)例講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。
    2021-03-03
  • linux命令行下使用R語言繪圖實(shí)例講解

    linux命令行下使用R語言繪圖實(shí)例講解

    這篇文章主要介紹了linux命令行下使用R語言繪圖實(shí)例講解,文中實(shí)例講解的很清晰,有需要的同學(xué)可以研究下
    2021-03-03
  • R語言中文本文件分割 符號 sep的用法

    R語言中文本文件分割 符號 sep的用法

    這篇文章主要介紹了R語言中文本文件分割 符號 sep的用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • 使用R語言批量修改文件名的方法

    使用R語言批量修改文件名的方法

    這篇文章主要介紹了使用R語言批量修改文件名的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • 解決R語言中install_github中無法安裝遇到的問題

    解決R語言中install_github中無法安裝遇到的問題

    這篇文章主要介紹了解決R語言中install_github中無法安裝遇到的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • R語言-計(jì)算平均值不同函數(shù)的區(qū)別說明

    R語言-計(jì)算平均值不同函數(shù)的區(qū)別說明

    這篇文章主要介紹了R語言-計(jì)算平均值不同函數(shù)的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • R語言:排序的應(yīng)用操作

    R語言:排序的應(yīng)用操作

    這篇文章主要介紹了R語言:排序的應(yīng)用操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • 輕松學(xué)會R語言識別Excel日期

    輕松學(xué)會R語言識別Excel日期

    想知道如何用R語言識別Excel中的日期嗎?別擔(dān)心,我們有你需要的全部信息!本指南將向你展示如何使用R語言輕松識別Excel表格中的日期數(shù)據(jù),讓你在數(shù)據(jù)分析中游刃有余,快來掌握這一技巧,讓數(shù)據(jù)處理更加高效!
    2023-12-12
  • R語言ComplexHeatmap繪制復(fù)雜熱圖heatmap

    R語言ComplexHeatmap繪制復(fù)雜熱圖heatmap

    ComplexHeatmap可以繪制很復(fù)雜的熱圖,能滿足日常以及文章所需,本文介紹一下文章常見的復(fù)雜熱圖的繪制方式,含代碼,文章比較長,建議耐心看一下,也許就有你需要的熱圖
    2022-06-06

最新評論