在R中使用ggplot将参考线添加到条形图中

时间:2019-12-14 14:09:53

标签: r ggplot2

这是一个最小的示例,显示了我要绘制的图。

数据如下:

plot1 = data.frame(
    Factor1 = as.factor(rep('A', 4)),
    Factor2 = as.factor(rep(c('C', 'D'), 2)),
    Factor3 = as.factor(c( rep('E', 2), rep('F', 2))),
    Y = c(0.225490, 0.121958, 0.218182, 0.269789)
)

plot2 = data.frame(
    Factor1 = as.factor(rep('B', 4)),
    Factor2 = as.factor(rep(c('C', 'D'), 2)),
    Factor3 = as.factor(c( rep('E', 2), rep('F', 2))),
    Y = c(-0.058585, -0.031686, 0.013141, 0.016249)
)

用于绘图的基本代码如下:

require(ggplot2)
require(grid)

p1 <- ggplot(data=plot1, aes(x=Factor2, y=Y, fill=factor(Factor3))) +
    ggtitle('Type: A') +
    coord_cartesian(ylim = c(-0.10, 0.30)) +
    geom_bar(position=position_dodge(.9), width=0.5, stat='identity') +
    scale_x_discrete(name='Regime',
        labels=c('C', 'D')) +
    scale_y_continuous('Activations') +
    scale_fill_brewer(palette='Dark2', name='Background:',
        breaks=c('E','F'),
        labels=c('E','F')) +
    theme(axis.text=element_text(size=11),
        axis.title.x=element_text(size=13, vjust=-0.75),
        axis.title.y=element_text(size=13, vjust=0.75),
        legend.text=element_blank(),
        legend.title=element_blank(),
        legend.position='none',
        plot.title=element_text(hjust=0.5))

p2 <- ggplot(data=plot2, aes(x=Factor2, y=Y, fill=factor(Factor3))) +
    ggtitle('Type: B') +
    coord_cartesian(ylim = c(-0.10, 0.30)) +
    geom_bar(position=position_dodge(.9), width=0.5, stat='identity') +
    scale_x_discrete(name='Regime',
        labels=c('C', 'D')) +
    scale_y_continuous('Activations') +
    scale_fill_brewer(palette='Dark2', name='Background:',
        breaks=c('E','F'),
        labels=c('E','F')) +
    theme(axis.text=element_text(size=11),
        axis.title.x=element_text(size=13, vjust=-0.75),
        axis.title.y=element_blank(),
        legend.text=element_text(size=11),
        legend.title=element_text(size=13),
        plot.title=element_text(hjust=0.5))

pushViewport(viewport(
    layout=grid.layout(1, 2, heights=unit(4, 'null'),
        widths=unit(c(1,1.17), 'null'))))
print(p1, vp=viewport(layout.pos.row=1, layout.pos.col=1))
print(p2, vp=viewport(layout.pos.row=1, layout.pos.col=2))

这个数字看起来像这样:

Attempt

但是,我需要这样的东西:

Correct

粗黑线是参考值。它们是恒定的,图中表示该“参考情况”。但是,在其他需要制作条形图的图中,基准值应保持不变,以使比较简单明了。我知道我应该使用geom_segment(),但是在进行这项工作的过程中,这些行只是缺少一些限制。

有什么帮助/建议吗?谢谢!

2 个答案:

答案 0 :(得分:4)

我能够使用geom_errorbarh来做到这一点。例如,第二个数字:

p1 + 
  geom_errorbarh(
    aes(xmin = as.numeric(Factor2)-.2,xmax = as.numeric(Factor2)+.2), #+/-.2 for width
    position = position_dodge(0.9), size = 2, height = 0
  )

输出: enter image description here 而且,如果我了解您描述的其他图,则可以在其中指定参考数据,例如data = plot1

答案 1 :(得分:2)

如果您的参考不会更改,则可以创建另一个数据集并将其合并到要绘制的数据集中。

在这里,我首先添加plot1plot2。然后,我创建一个新的数据集作为参考数据集。

library(dplyr)
new_df = rbind(plot1, plot2)
ref_plot = new_df
ref_plot <- ref_plot %>% rename(Ref_value = Y)

然后,现在您拥有new_df(这是要绘制的数据集)和ref_plot,其中包含每个条件的参考值。

我宁愿使用grid,而不是使用facet_wrap并创建两个不同的绘图,然后将其合并,而将所有绘图放在同一图形上。这更加方便,不需要写两次相同的东西。

正如@AHart在我面前提到的几分钟,您可以使用geom_errorbar在绘图上定义参考值。区别在于我更喜欢​​使用geom_errorbar而不是geom_errobarh

这是剧情:

library(ggplot2)
new_df %>% left_join(ref_plot) %>% 
  ggplot(aes(x = Factor2, y = Y, fill = Factor3))+
  geom_bar(stat = "identity", position = position_dodge())+
  geom_errorbar(aes(ymin = Ref_value-0.00001, ymax = Ref_value+0.0001, group = Factor3), position = position_dodge(.9),width = 0.2)+
  facet_wrap(.~Factor1, labeller = labeller(Factor1 = c(A = "Type A", B = "Type B"))) +
  scale_x_discrete(name='Regime',
                   labels=c('C', 'D')) +
  scale_fill_brewer(palette='Dark2', name='Background:',
                    breaks=c('E','F'),
                    labels=c('E','F')) +
  theme(axis.text=element_text(size=11),
        axis.title.x=element_text(size=13, vjust=-0.75),
        axis.title.y=element_blank(),
        legend.text=element_text(size=11),
        legend.title=element_text(size=13),
        plot.title=element_text(hjust=0.5))

enter image description here