楼主: fullcream
17851 9

[问答] 如何用R画Logistic回归模型的ROC曲线 [推广有奖]

  • 1关注
  • 0粉丝

等待验证会员

初中生

85%

还不是VIP/贵宾

-

威望
0
论坛币
10 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
137 点
帖子
14
精华
0
在线时间
13 小时
注册时间
2018-11-18
最后登录
2019-7-30

楼主
fullcream 发表于 2018-12-22 21:56:10 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
老师们好!

我用LASSO回归做出了Logistic回归模型,下一步需要该模型的ROC曲线,请问应该如何实现?

还要画该模型对测试的ROC曲线,咋画呢?  谢谢老师啦
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:回归模型 如何实现 归模型 下一步

沙发
啊啊啊啊啊吖 发表于 2018-12-30 15:48:23
帮你顶顶帖子让更多人看到哈~~

藤椅
fullcream 发表于 2019-1-4 11:09:46
啊啊啊啊啊吖 发表于 2018-12-30 15:48
帮你顶顶帖子让更多人看到哈~~
谢谢!!

板凳
wudinbg 发表于 2019-1-20 22:26:23
可以用pROC package
已有 1 人评分论坛币 收起 理由
cheetahfly + 10 热心帮助其他会员

总评分: 论坛币 + 10   查看全部评分

报纸
来一碗鱼丸粗面 学生认证  发表于 2019-1-28 21:41:15
wudinbg 发表于 2019-1-20 22:26
可以用pROC package
请问是这个代码吗?> install.packages("pROC")

> library("pROC")

> roc

> plot(roc, print.auc=TRUE, auc.polygon=TRUE, grid=c(0.1,0.2),grid.col=c("green","red"),

有点看不明白,我是做了随进森林,但是不会计算AUC和ROC曲线
已有 1 人评分论坛币 收起 理由
cheetahfly + 10 精彩帖子

总评分: 论坛币 + 10   查看全部评分

地板
fullcream 发表于 2019-3-17 21:44:22
微信截图_20190317214609.png
老师们,就像这样的logistic模型,怎么画他的ROC曲线呢?? 求指点

7
西風の碧樹 学生认证  发表于 2019-3-17 22:46:58
你可以用AUC package来画,我下面这个代码是做了一个logistic regression,然后画出了roc并标出了auc的值,你可以参考下运用到你的数据中

LR_model <- glm(as.factor(Diagnosis) ~ Season+Age+Chd_d+Acci_tra+High_fever+
                  Ach_con+Smoke,data=training.set,
                family=binomial(link = "logit"))
glm.probs <- predict(LR_model,test.set[,-10],type="response")
sum(ifelse(glm.probs>0.5,1,0)==test.set$Diagnosis)/30 #accuracy

library(AUC)
plot(roc(glm.probs,as.factor(test.set$Diagnosis)), col=rainbow(10),
     main="ROC curve for Logistic Regression model")
lr.auc <- auc(roc(glm.probs,as.factor(test.set$Diagnosis)))
text(0.8, 0.2, labels=paste('AUC=', round(lr.auc, 3), sep=''), cex=1.2)

8
西風の碧樹 学生认证  发表于 2019-3-17 22:51:04
你可以用AUC包来画,下面的代码是先建立了一个logistic regression,然后用AUC包里的roc,auc函数来画roc图并标注auc的值,你可以参考下用到你的数据中。(发完贴发现粘贴的代码排版被网站搞乱了,可以看附件图片)

##Logistic regression
LR_model <- glm(as.factor(Diagnosis) ~ Season+Age+Chd_d+Acci_tra+High_fever+
                  Ach_con+Smoke,data=training.set,
                family=binomial(link = "logit"))
glm.probs <- predict(LR_model,test.set[,-10],type="response")
sum(ifelse(glm.probs>0.5,1,0)==test.set$Diagnosis)/30 #accuracy
##plot roc and indicate auc
library(AUC)
plot(roc(glm.probs,as.factor(test.set$Diagnosis)), col=rainbow(10),
     main="ROC curve for Logistic Regression model")
lr.auc <- auc(roc(glm.probs,as.factor(test.set$Diagnosis)))
text(0.8, 0.2, labels=paste('AUC=', round(lr.auc, 3), sep=''), cex=1.2)

Annotation 2019-03-17 105509.jpg (71.73 KB)

Annotation 2019-03-17 105509.jpg

9
tianwk 发表于 2019-3-22 01:29:39
thanks for sharing

10
fullcream 发表于 2019-3-24 19:31:05
谢谢老师指点!

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-20 08:53