Partially color histogram in R

前端 未结 4 1955
慢半拍i
慢半拍i 2020-12-05 00:51

\"enter

I have a histogram as shown in the picture. I want the bars in the two regions

相关标签:
4条回答
  • 2020-12-05 01:29

    I was using @Thomas' solution for years before I noticed that it's imprecise.

    In the example below I am following the accepted answer.

    fake_data <- c(0.35, 0.41, 0.41, 0.49, 0.49, 0.49, 0.51, 0.51, 0.59, 0.64, 0.7)
    
    fake_hist <- hist(fake_data, plot = F)
    fake_cuts <- cut(fake_hist$breaks, c(-Inf, 0.5, Inf))
    
    plot(fake_hist, col = fake_cuts)
    

    [wrong_hist][1]

    The cut is intended at 0.5, but the third bar is black, although it should be red. The reason is, that breaks contain all the boundaries including the left boundary of the first bar, meaning there are n+1 values, where n is the number of bars in the histogram. For colouring of n bars, one needs only the right boundaries and therefore we must exclude the first value.

    fake_data <- c(0.35, 0.41, 0.41, 0.49, 0.49, 0.49, 0.51, 0.51, 0.59, 0.64, 0.7)
    
    fake_hist <- hist(fake_data, plot = F)
    fake_cuts <- cut(fake_hist$breaks[-1], c(-Inf, 0.5, Inf))
    
    plot(fake_hist, col = fake_cuts)
    

    correct_hist

    Produces the colour split where expected.

    I am posting it here because it took me so long to find that there is a problem.

    0 讨论(0)
  • 2020-12-05 01:34

    Try this:

    hist(pr4$x[pr4$x[,1]>-2,1],breaks=100, col = c(rep("white", 69), rep("green", 15), rep("red", 16)))
    

    You might have to adjust the repeat number for each color depending on the number of breaks within the histogram.

    0 讨论(0)
  • 2020-12-05 01:46

    Here's the method I mentioned in comments:

    Make some test data (you should do this in your question!)

    test = runif(10000,-2,0)
    

    get R to compute the histogram but not plot it:

    h = hist(test, breaks=100,plot=FALSE)
    

    Your histogram is divided into three parts:

    ccat = cut(h$breaks, c(-Inf, -0.6, -0.4, Inf))
    

    plot with this palette, implicit conversion of factor to number indexes the palette:

    plot(h, col=c("white","green","red")[ccat])
    

    coloured bars

    ggplot2 solutions are also available.

    0 讨论(0)
  • 2020-12-05 01:52

    The best way to do this is to allow hist to do the calculations for you but then use hist (again) to do the actual plotting. Here's an example:

    set.seed(1)
    x <- rnorm(1000)
    h <- hist(rnorm(1000), breaks=50, plot=FALSE)
    cuts <- cut(h$breaks, c(-Inf,-.5,1.75,Inf))
    plot(h, col=cuts)
    

    The .5 and 1.75 in the last line are the threshold values where you want to have different colors.

    Note: my original answer used barplot, but that strategy makes the axes kind of difficult to work with.

    Here's the result:

    enter image description here

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