Bars in geom_bar have unwanted different widths when using facet_wrap

后端 未结 2 2069
借酒劲吻你
借酒劲吻你 2020-12-01 22:02

I can\'d find a solution for the following problem(s). I would appreciate some help a lot!

The following code produces bar charts using facet. However, due to \"extr

相关标签:
2条回答
  • 2020-12-01 22:09

    Here what I did after suggestion from Gregor. Using geom_segment and geom_point makes a nice graph as I think.

    library(ggplot2)
    
    all<-read.xls('all_auto_visual_c.xls')
    
    all$station<-as.factor(all$station)
    all$group.new<-factor(all$group, levels=c('C. hyperboreus','C. glacialis','Combined','M. longa','Pseudocalanus sp.','Copepoda'))
    all$shortname2.new<-factor(all$shortname2, levels=c('All','F','M','C5','C4','C3','C2','C1','Micro',     'Oith','Tric','Cegg','Cnaup','C3&2','C2&1'))
    
    allp<-ggplot(all, aes(x=perc_correct, y=shortname2.new)) +
      geom_segment(aes(yend=shortname2.new), xend=0, colour="grey50") +
      geom_point(size=4, aes(colour=sample_size)) +
      scale_colour_gradient("Sample size (n)",low="lightblue",high="navyblue") +
      geom_text(aes(label = perc_correct, hjust = -0.5)) +
      theme_bw() +
      theme(panel.grid.major.y = element_blank()) +
      facet_grid(group.new~station,scales="free_y",space="free") +
      xlab("Automatic identification and visual validation concur (%)") + ylab("Species and stages")+
      ggtitle("Visual validation of predictions")+
      theme_bw() + 
      theme(plot.title = element_text(lineheight=.8, face="bold", size=20,vjust=1), axis.text.x = element_text(colour="grey20",size=12,angle=0,hjust=.5,vjust=.5,face="bold"), axis.text.y = element_text(colour="grey20",size=12,angle=0,hjust=1,vjust=0,face="bold"), axis.title.x = element_text(colour="grey20",size=15,angle=0,hjust=.5,vjust=0,face="bold"), axis.title.y = element_text(colour="grey20",size=15,angle=90,hjust=.5,vjust=1,face="bold"),legend.position="none", strip.text.x = element_text(size = 12, face="bold", colour = "black", angle = 0), strip.text.y = element_text(size = 8, face="bold", colour = "black"))
    
    allp
    
    ggsave(allp, file="auto_visual_no_label.jpeg", height= 11, width= 8.5, dpi= 400,)
    

    This is what it produces!

    enter image description here

    0 讨论(0)
  • 2020-12-01 22:25

    Assuming the bar widths are inversely proportional to the number of x-breaks, an appropriate scaling factor can be entered as a width aesthetic to control the width of the bars. But first, calculate the number of x-breaks in each panel, calculate the scaling factor, and put them back into the "all" data frame.

    Updating to ggplot2 2.0.0 Each column mentioned in facet_wrap gets its own line in the strip. In the edit, a new label variable is setup in the dataframe so that the strip label remains on one line.

    library(ggplot2)
    library(plyr)
    
    all = structure(list(station = structure(c(2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
    1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L), .Label = c("Station 101", 
    "Station 126"), class = "factor"), shortname2 = structure(c(2L, 
    7L, 8L, 11L, 1L, 5L, 7L, 8L, 11L, 1L, 2L, 3L, 5L, 7L, 8L, 12L, 
    11L, 1L, 6L, 8L, 15L, 14L, 9L, 10L, 4L, 6L, 2L, 7L, 8L, 11L, 
    1L, 5L, 7L, 8L, 11L, 1L, 2L, 3L, 5L, 7L, 8L, 12L, 11L, 1L, 8L, 
    11L, 1L, 15L, 14L, 13L, 9L, 10L), .Label = c("All", "C1", "C2", 
    "C2&1", "C3", "C3&2", "C4", "C5", "Cegg", "Cnaup", "F", "M", 
    "Micro", "Oith", "Tric"), class = "factor"), color = c(1L, 2L, 
    3L, 4L, 5L, 6L, 7L, 8L, 10L, 11L, 12L, 13L, 14L, 15L, 16L, 17L, 
    18L, 19L, 21L, 26L, 30L, 31L, 33L, 34L, 20L, 21L, 1L, 2L, 3L, 
    4L, 5L, 6L, 7L, 8L, 10L, 11L, 12L, 13L, 14L, 15L, 16L, 17L, 18L, 
    19L, 26L, 28L, 29L, 30L, 31L, 32L, 33L, 34L), group = structure(c(1L, 
    1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 
    4L, 6L, 5L, 3L, 3L, 3L, 3L, 6L, 6L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 
    2L, 2L, 2L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 5L, 5L, 5L, 3L, 3L, 
    3L, 3L, 3L), .Label = c("cgla", "Chyp", "Cope", "mlong", "pseudo", 
    "specC"), class = "factor"), sample_size = c(11L, 37L, 55L, 16L, 
    119L, 21L, 55L, 42L, 40L, 158L, 24L, 16L, 17L, 27L, 14L, 45L, 
    98L, 241L, 30L, 34L, 51L, 22L, 14L, 47L, 13L, 41L, 24L, 41L, 
    74L, 20L, 159L, 18L, 100L, 32L, 29L, 184L, 31L, 17L, 27L, 23L, 
    21L, 17L, 49L, 185L, 30L, 16L, 46L, 57L, 16L, 12L, 30L, 42L), 
        perc_correct = c(91L, 78L, 89L, 81L, 85L, 90L, 91L, 93L, 
        80L, 89L, 75L, 75L, 76L, 81L, 86L, 76L, 79L, 78L, 90L, 97L, 
        75L, 86L, 93L, 74L, 85L, 88L, 88L, 90L, 92L, 90L, 91L, 89L, 
        89L, 91L, 90L, 89L, 81L, 88L, 74L, 78L, 90L, 82L, 84L, 82L, 
        90L, 94L, 91L, 81L, 69L, 83L, 90L, 81L)), class = "data.frame", row.names = c(NA, 
    -52L))
    
    all$station <- as.factor(all$station)
    
    # Calculate scaling factor and insert into data frame
    library(plyr)
    N = ddply(all, .(station, group), function(x) length(row.names(x)))
    N$Fac = N$V1 / max(N$V1)
    all = merge(all, N[,-3], by = c("station", "group"))
    all$label = paste(all$group, all$station, sep = ", ")
    
    
    allp <- ggplot(data = all, aes(x=shortname2, y=perc_correct, group=group, fill=sample_size, width = .5*Fac)) + 
      geom_bar(stat="identity", position="dodge",  colour="NA") +
      scale_fill_gradient("Sample size (n)",low="lightblue",high="navyblue")+
      facet_wrap(~label,ncol=2,scales="free_x")   +
      xlab("Species and stages") + ylab("Automatic identification and visual validation concur (%)") +
      ggtitle("Visual validation of predictions") + 
      theme_bw() + 
      theme(plot.title = element_text(lineheight=.8, face="bold", size=20,vjust=1),
        axis.text.x = element_text(colour="grey20",size=12,angle=0,hjust=.5,vjust=.5,face="bold"), 
        axis.text.y = element_text(colour="grey20",size=12,angle=0,hjust=1,vjust=0,face="bold"), 
        axis.title.x = element_text(colour="grey20",size=15,angle=0,hjust=.5,vjust=0,face="bold"), 
        axis.title.y = element_text(colour="grey20",size=15,angle=90,hjust=.5,vjust=1,face="bold"),
        legend.position="none", 
        strip.text.x = element_text(size = 12, face="bold", colour = "black", angle = 0), 
        strip.text.y = element_text(size = 12, face="bold", colour = "black"))
    
    allp
    

    enter image description here

    0 讨论(0)
提交回复
热议问题