Add second x-axis in ggplot2

后端 未结 2 671
一生所求
一生所求 2021-02-09 04:18

In the \"graphics\" package one can add a second x-axis (indicating the percentiles of the distribution) to a histogram as follows:

x  <- rnorm(1000)
hist(x,          


        
相关标签:
2条回答
  • 2021-02-09 04:43

    I'm not entirely certain what you're after, since your first example doesn't actually produce what you describe.

    But in terms of simply adding the percentage along with the raw value along the x axis, the easiest strategy would probably be to simply combine the two with a line break in a single set of labels:

    dat <- data.frame(x = rnorm(1000))
    perc <- quantile(dat$x,seq(from = 0,to = 1,by = 0.1))
    l <- paste(round(perc,1),names(perc),sep = "\n")
    > ggplot(dat,aes(x = x)) + 
         geom_histogram() + 
         scale_x_continuous(breaks = perc,labels = l)
    

    enter image description here

    0 讨论(0)
  • 2021-02-09 05:01

    Here's another approach which uses annotate(...) and does not require that the two scales have the same breaks.

    library(ggplot2)
    library(grid)
    
    set.seed(123)
    x     <- rnorm(1000)
    perc  <- quantile(x, seq(from=.00, to=1, by=.1))
    labs  <- gsub("\\%","",names(perc))   # strip "%" from names
    yval  <- hist(x,breaks=30,plot=F)$count
    yrng  <- diff(range(yval))
    g1 <- ggplot() +
      geom_histogram(aes(x=x))+ 
      xlim(range(x))+
      coord_cartesian(ylim=c(0,1.1*max(yval)))+
      labs(x="")+
      annotate(geom = "text", x = perc, y = -0.1*yrng, label = labs, size=4) +
      annotate(geom = "text", x=0, y=-0.16*yrng, label="Bias", size=4.5)+
      theme(plot.margin = unit(c(1, 1, 2, 1), "lines"))
    
    g2 <- ggplot_gtable(ggplot_build(g1))
    g2$layout$clip[g2$layout$name == "panel"] <- "off"
    grid.draw(g2)
    

    This adds the second x-axis and the label using annotate(...). The last three lines of code turn off clipping of the viewport. Otherwise the annotations aren't visible.

    Credit to @Henrik for his answer to this question.

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