首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >广义指数分布风险函数的图例绘制

广义指数分布风险函数的图例绘制
EN

Stack Overflow用户
提问于 2020-12-30 16:19:27
回答 1查看 21关注 0票数 0
代码语言:javascript
复制
library(ggplot2)
hazard<-function(x,a,b)
{
  h=(a*b*exp(-b*x)*((1-exp(-b*x))^(a-1)))/(1-((1-exp(-b*x))^a))
  return(h)
}
a=seq(1,30,1)
y1=hazard(a,0.2,0.5)
y2=hazard(a,1,0.5)
y3=hazard(a,0.5,1)
y4=hazard(a,2,2)
df=data.frame(a,y1,y2,y3,y4)
ggplot(df,aes(a))+
 geom_line(aes(y=y1),colour="blue")+
  geom_line(aes(y=y2),colour="red")+
  geom_line(aes(y=y3),colour="green")+
  geom_line(aes(y=y4),colour="black")+
  ylab("hazard function")+ggtitle("Plotting the hazard function")

我不能添加图例,因为我对每条曲线使用单独的geom_lines()。给我一个建议

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-30 16:23:56

您不应该绘制单独的线条,而应获取长格式的数据。如果你想要特定的颜色,你可以使用scale_color_manual来分配它们。

代码语言:javascript
复制
library(ggplot2)

df %>%
  tidyr::pivot_longer(cols = -a) %>%
  ggplot() + aes(a, value, color = name) + 
  geom_line() + 
  scale_color_manual(values = c('blue', 'red', 'green', 'black')) + 
  ylab("hazard function")+
  ggtitle("Plotting the hazard function")

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65503973

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档