Add jitter to box plot using markers in plotly
Asked Answered
D

1

8

I made a boxplot:

dat %>%
  plot_ly(y = ~xval, color = ~get(col), type = "box", 
          boxpoints = "all", jitter = 0.7,
          pointpos = 0, marker = list(size = 3),
          source = shiny_source, key = shiny_key,
          hoverinfo = 'text', text = txt)

enter image description here

but problem is that jittered points are not interactive and cannot be marked separately, so I came with an idea to add those points using add_markers:

dat %>%
  plot_ly(y = ~xval, color = ~get(col), type = "box", 
          boxpoints = FALSE, jitter = 0.7,
          pointpos = 0, marker = list(size = 3),
          source = shiny_source, key = shiny_key,
          hoverinfo = 'col', text = txt
  ) %>%
  add_markers(x = ~get(col), y = ~varval, size = I(6))

enter image description here

but now points are in straight line and I'd like to add some jitter (for example by using beeswarm package). But I don't know how to get coordinates of qualitative variable IC0 on X axis. Any ideas?

Debbi answered 20/10, 2017 at 7:52 Comment(1)
As far as I remember the jitter is added by the JS package and not by the R API.Lock
F
17

I find myself in the same potential case often with plotly and ggplot2-- 3 lines of code to get 90% of what I want, and 30 lines of code to get the aesthetics just right.

One potential solution/workaround: Take advantage of R's "factors are coded with integers" paradigm, plot everything on a numeric scale, and then cover your tracks by hiding x labels and x hover values.

dat <- data.frame(xval = sample(100,1000,replace = TRUE),
                  group = as.factor(sample(c("a","b","c"),1000,replace = TRUE)))

dat %>%
  plot_ly() %>% 
  add_trace(x = ~as.numeric(group),y = ~xval, color = ~group, type = "box", 
            hoverinfo = 'name+y') %>%
  add_markers(x = ~jitter(as.numeric(group)), y = ~xval, color = ~group,
              marker = list(size = 6),
              hoverinfo = "text",
              text = ~paste0("Group: ",group,
                             "<br>xval: ",xval),
              showlegend = FALSE) %>% 
  layout(legend = list(orientation = "h",
                       x =0.5, xanchor = "center",
                       y = 1, yanchor = "bottom"
                       ),
         xaxis = list(title = "Group",
                      showticklabels = FALSE))

Yields the following

enter image description here

Francefrancene answered 20/10, 2017 at 10:38 Comment(4)
Great solution. Thanks!Debbi
is it possible to get rid of the box altogether and just plot the jittered points?Possing
Yes -- Just comment out the first add_trace( ... type = "box" ... ) call and change the showlegend parameter in the add_markers( ... ) call to TRUEFrancefrancene
Is there a way to add the group name on the x Axis?Rodi

© 2022 - 2024 — McMap. All rights reserved.