在ggplot2中进行分面时添加功能区

时间:2016-06-24 13:04:31

标签: r ggplot2

我在R中有一个facet grid ggplot2图,我试图为每个facet覆盖一条水平线和一条带。我分别为水平线和功能区值制作了单独的数据帧。但是,在添加功能区时,我遇到了“找不到对象错误”的问题。

下面是一些可重现的代码。

# create DF
df1 = data.frame( x = rep(letters[1:4], 4),
              y = rnorm(16, 0 , 1),
              group = rep(1:4, each=4))

# horizonal line DF
hLines = data.frame(group = unique(df1$group) , 
                y = aggregate(y ~ group, data=df1 , FUN=mean)[2] )

# CIs DF
hCIs = data.frame(group = unique(df1$group), 
              low = hLines$y -  (2 * aggregate(y ~ group, data=df1 , FUN=sd)[2] ),
              high = hLines$y + (2 * aggregate(y ~ group, data=df1 , FUN=sd)[2] ) )

ggplot(df1 , aes(x = x , y = y)) +
  facet_grid(~group) +
  geom_point(size=3) +
  geom_hline(data=hLines, aes(yintercept = y))+
  geom_ribbon(data=hCIs, aes(x=x, ymin=low, ymax=high))+
  theme_bw()

当不包含geom_ribbon命令时,它可以正常工作。但是当我尝试添加功能区时,我得到了:

  

eval(expr,envir,enclos)中的错误:找不到对象'low'

非常感谢你的帮助。

编辑: 我在hCI的列名中犯了一个错误。但是,在指定时:

colnames(hCIs) = c("group", "low", "high")

......我仍然收到错误:

  

错误:美学必须是长度1或与数据(4)相同:x,ymin,ymax,y

1 个答案:

答案 0 :(得分:4)

geom_ribbon在指定新数据来源时没有x的信息:hCIs没有x

如果您合并2个数据帧以获得每个x数据点的hCIs值,那么就可以使用:

ggplot(df1 , aes(x = x , y = y)) +
    facet_grid(~group) +
    geom_point(size=3) +
    geom_hline(data=hLines, aes(yintercept = y))+
    geom_ribbon(data=merge(hCIs, df1), aes(ymin=low, ymax=high, group = group), alpha = 0.2)+
    theme_bw()

enter image description here