2016-12-01 1 views
0

9つのサブプロットを含むggplot2を使ってプロットを作成しようとしています。私の目標は、9つのサブプロットごとに垂直軸を個々のレベルでスケーリングできるようにすることです。そのために、構文facet_wrap(scales = "free_y")を試しています。しかし、それは私のために働いているようには見えず、その代わりに、縦軸は9つのサブプロット全体で同じに見えます。 MWEは以下のとおりです。ファセットを作成していない(scale = "free_y")

x <- rep(c(rep("F",4),rep("M",4)),9) 
y <- abs(c(rnorm(36,0,20),rnorm(36,0,5))) 
z <- rep(1:9,each=8) 
meanG1 <- c() 
meanG2 <- c() 
for (i in c(1,9,17,25,33,41,49,57,65)){ 
    meanG1 <- c(meanG1, rep(mean(y[i:(i+3)]),8)) 
    meanG2 <- c(meanG2, rep(mean(y[5:(i+3)]),8)) 
} 
dat <- data.frame(x=x,y=y,z=z,meanG1=meanG1,meanG2=meanG2) 

ggplot(dat, aes(x, y)) + 
    geom_point(aes(colour = factor(x)), shape = 20, size=5, alpha = 0.5) + 
    scale_shape(solid = FALSE) + 
    ggtitle(paste("My Plot")) + 
    ylab("Count") + 
    scale_y_continuous(limits=c(0, max(dat$y))) + 
    theme(axis.title.x = element_blank(), 
     legend.position="bottom", 
     axis.text=element_text(size=12), 
     axis.title=element_text(size=12), 
     legend.title=element_text(size=12), 
     legend.text=element_text(size=12), 
     plot.title=element_text(hjust=0.5)) + 
    labs(colour = "Group", size=12) + 
    geom_segment(aes(x = 1, y = meanG1, xend = 2, yend = meanG2), colour="gray25", size = 0.1) + 
    facet_wrap(~ z, ncol = 3, scales = "free_y") 

この問題を引き起こす可能性のある問題や解決方法については、誰かが耳を傾けています。ありがとうございました。

答えて

3

それはすべての面

間でy軸の範囲を「固定」されているため、あなたはあなたのggplotコード

scale_y_continuous(limits=c(0, max(dat$y))) 

からこれを削除する必要があります

関連する問題