geom_point不是空心的,错误条重叠

时间:2016-09-28 19:07:36

标签: r ggplot2

这对我来说似乎是一个非常愚蠢的错误,但每当我根据因素指定geom_point并选择一个空心点和一个实心点(形状1和19),并绘制误差条时,它就会越过该点。

以下是我的数据框:

> dput(head(allbins.sum))
structure(list(T = c(0L, 0L, 10L, 10L, 20L, 20L), treatment = structure(c(1L, 
2L, 1L, 2L, 1L, 2L), .Label = c("control bead", "dP bead"), class = "factor"), 
    N = c(3, 3, 3, 3, 3, 3), cellsBase = c(0, 0, 0.013028995209506, 
    0.135599858885737, -0.0130289952095061, 0.759359209760127
    ), sd = c(0, 0, 0.0597063567767786, 0.0469731690178533, 0.0983667566897066, 
    0.183436089048999), se = c(0, 0, 0.034471481157405, 0.0271199717771474, 
    0.0567920734541125, 0.105906875391532), ci = c(0, 0, 0.148318812500416, 
    0.116687820597672, 0.244356569875469, 0.455680506502609), 
    bin = c("BinA", "BinA", "BinA", "BinA", "BinA", "BinA")), .Names = c("T", 
"treatment", "N", "cellsBase", "sd", "se", "ci", "bin"), row.names = c(NA, 
6L), class = "data.frame")

> dput(head(allbins.fitdata))
structure(list(wellvidbin = structure(c(1L, 1L, 1L, 1L, 1L, 1L
), .Label = c("A1-002-BinA", "A1-002-BinB", "A1-002-BinC", "A1-031-BinA", 
"A1-031-BinB", "A1-031-BinC", "A3-004-BinA", "A3-004-BinB", "A3-004-BinC", 
"B1-032-BinA", "B1-032-BinB", "B1-032-BinC", "B4-026-BinA", "B4-026-BinB", 
"B4-026-BinC", "C4-027-BinA", "C4-027-BinB", "C4-027-BinC"), class = "factor"), 
    treatment = structure(c(2L, 2L, 2L, 2L, 2L, 2L), .Label = c("control bead", 
    "dP bead"), class = "factor"), wellvid = structure(c(1L, 
    1L, 1L, 1L, 1L, 1L), .Label = c("A1-002", "A1-031", "A3-004", 
    "B1-032", "B4-026", "C4-027"), class = "factor"), bin = structure(c(1L, 
    1L, 1L, 1L, 1L, 1L), .Label = c("BinA", "BinB", "BinC"), class = "factor"), 
    T = c(0L, 10L, 20L, 30L, 40L, 50L), T.factor = structure(1:6, .Label = c("0", 
    "10", "20", "30", "40", "50", "60"), class = "factor"), cells = c(7L, 
    11L, 26L, 27L, 28L, 36L), cellsS = c(-1.36568429306349, -1.20296446240061, 
    -0.592765097414793, -0.552085139749072, -0.511405182083351, 
    -0.185965520757582), cellsBase = c(0, 0.162719830662884, 
    0.772919195648701, 0.813599153314422, 0.854279110980143, 
    1.17971877230591), treatT = structure(c(2L, 4L, 6L, 8L, 10L, 
    12L), .Label = c("control bead.0", "P bead.0", "control bead.10", 
    "P bead.10", "control bead.20", "P bead.20", "control bead.30", 
    "P bead.30", "control bead.40", "P bead.40", "control bead.50", 
    "P bead.50", "control bead.60", "P bead.60"), class = "factor"), 
    fit = c(0.0285939715820639, 0.304399288764407, 0.58020460594675, 
    0.856009923129092, 1.13181524031144, 1.40762055749378), se.fit = c(0.157415367032567, 
    0.132348142293459, 0.114707848741265, 0.108190467052118, 
    0.114707848741265, 0.132348142293459), upr = c(0.337128090965895, 
    0.563801647659587, 0.805031989479629, 1.06806323855124, 1.35664262384431, 
    1.66702291638896), lwr = c(-0.279940147801767, 0.0449969298692267, 
    0.35537722241387, 0.643956607706942, 0.906987856778556, 1.1482181985986
    )), .Names = c("wellvidbin", "treatment", "wellvid", "bin", 
"T", "T.factor", "cells", "cellsS", "cellsBase", "treatT", "fit", 
"se.fit", "upr", "lwr"), class = c("data.table", "data.frame"
), row.names = c(NA, -6L), .internal.selfref = <pointer: 0x0000000000100788>)

代码:

ggplot(data=allbins.sum, aes(x=T, y=cellsBase, shape=treatment)) + geom_point(size=5, aes(shape=treatment))+ 
  geom_errorbar(aes(ymin=cellsBase-se, ymax=cellsBase+se), width=2, size=1) +
  geom_smooth(data=allbins.fitdata, size=1,  aes(y=fit, ymin=lwr, ymax=upr), 
              color="black", method="lm", stat="identity", alpha=0.2)+ 
  facet_grid(bin~.) +
  scale_shape_manual(values=c(1, 19))

这给了我这个情节: enter image description here

有关如何将空心圆挖空的任何提示? 我还尝试指定geom_shape (aes(fill=treatment)然后scale_fill_manual,但它也适用于我的geom_smooth

感谢您的帮助!

1 个答案:

答案 0 :(得分:3)

如果您的意思是不希望错误栏的线条通过“空心”显示出来。点,然后首先绘制geom_errorbar,然后绘制geom_point秒,使用实心填充,这样它将覆盖错误栏。

ggplot(data=allbins.sum, aes(x=T, y=cellsBase)) + 
  # plotting this first
  geom_errorbar(aes(ymin=cellsBase-se, ymax=cellsBase+se), width=2, size=1) +

  # plotting this second, with a hollow fillable shape, and black outline
  geom_point(size=5, shape = 21, color='black',
             aes(fill = treatment)) +

  # solid black and solid white fill for the points
  scale_fill_manual(values = c('black', 'white')) +
  theme_bw()

enter image description here

(您发布的数据仅包含allbins.sum的这些点,allbins.fitdata的代码有错误,因此此图中没有错误栏)