-
Notifications
You must be signed in to change notification settings - Fork 26
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Dotplot: Number of dots for axis breaks #182
Comments
Ah yeah, so the short answer is "not with geom_dots b/c of limitations in ggplot2" and the long answer is "yes, if you do a bunch of stuff manually". The problem with this is that in order to set the y axis scale to match the dot count, you need to know the binwidth, but in order to know the binwidth, you need to know the physical plot dimensions (to pick a binwidth so that the tallest stack fits inside the plot). However, y axis scales are set before plot dimensions are known in ggplot, and it is not possible to change them after plot dimensions are known (this happens much later in the pipeline). So, it cannot be done within a single geom like geom_dots, and this is fundamental limitation of dotplots in ggplot2 (there are old stackoverflow questions about this problem with ggplot2::geom_dotplot, for example, which has the same problem). That said, I don't know what your use case is, but if you're willing to do some stuff manually, it can theoretically be done. {ggdist} exposes a few functions, set.seed(1234)
x = rnorm(100)
# determine the binwidth
# you could also skip this step and manually specify a binwidth... maxheight
# here is the max height of the chart assuming y units and x units are square,
# and is intended to get a chart with around a 3/2 aspect ratio
binwidth = find_dotplot_binwidth(x, maxheight = 2/3*diff(range(x)), heightratio = 1)
# bin the dots
bin_df = bin_dots(x = x, y = 0, binwidth = binwidth, heightratio = 1)
bin_df %>%
ggplot(aes(x, y/binwidth)) +
geom_point() +
coord_fixed(ratio = binwidth) Now if we want the dots to actually be ellipses with a desired width/height in data space, we could use bin_df %>%
ggplot(aes(x0 = x, y0 = y / binwidth, a = binwidth/2, b = 1/2, angle = 0)) +
ggforce::geom_ellipse() +
coord_fixed(ratio = binwidth) |
Thanks! For my current use case, I might be able to get along with the [0, 1] scaling of the y-axis, but for the future, I'll think about adopting your customized suggestion. Would it make sense to add that customized suggestion to ggdist (probably as some new function, with the remark that this new function is very limited compared to |
Since such a new function would create a |
Hmm, to be honest I'd want a good use case before doing that --- I don't see a big need for the y axis labels on dotplots myself, and the version with y axis labels is just a lot less flexible and a lot more brittle (requires fixed coords, doesn't easily support conditioning on other aesthetics, mapping other things to the y axis to stack multiple dotplots, etc etc). I generally prefer providing building blocks for charts rather than full-on charts as output since the latter tend to be less customizable (or, to achieve a lot of customizability, lead to recreating a lot of ggplot functionality). So at the moment I think the most sensible approach is to update the example in the docs for |
In fact, now that I think about it a better solution here would be to provide layers that can be added to a chart that provide labels for the thickness positional subscale used by slabs and dots geoms... that actually seems like a potentially viable solution that solves the problem more cleanly and would allow use with geom_dots. Plus it would handle the case of multiple slabs/dots stacked in rows or columns. |
Yes, I totally understand. |
Ok, I can't follow you here, but if you say this would be a more general solution, that sounds good. |
There is now a prototype implementation of a solution to this on the Since that issue now supercedes this one, I am closing this. Follow #183 for updates. |
In a (one-sided) dotplot, is it possible to show the number of dots on the "density" axis (y-axis by default)?
This might already be supported, but I couldn't find a way to achieve this (and I also couldn't find an older Github issue where this was mentioned).
Example (from
?geom_dots
):gives
data:image/s3,"s3://crabby-images/b0098/b009840463fd342e679662859a251210fbf83b9b" alt="Rplot"
where the y-axis has an upper limit of 1. I know that there's the
height
aesthetic, but currently I don't see how fixing it to some specific value (possibly in combination with thescale
aesthetic) could be used for achieving the number of dots on the y-axis.The text was updated successfully, but these errors were encountered: