我试图展示几个变量的周汇总数据的网格图。这个图表的两个组成部分最相关的是一个分布摘要图(箱形图或小提琴图),显示某个变量在给定周内取值的情况,以及一个整数变量在几周内累积计数的累积计数图(阶梯图)。我想使用
问题在于
我已经拼凑出了一个使用
以下是必要的可重复生产代码:
grid
在一个对齐的x轴上绘制这两个图表。我将使用ggplot2
来制作单独的图表,因为我喜欢Hadley Wickham(开玩笑,ggplot只是非常好用)。问题在于
geom_boxplot
仅接受x轴的因子,而geom_step
仅接受连续数据作为x轴。即使您使用coord_cartesian
或scale_x_...
强制使用相似的x限制,它们也不一定对齐。我已经拼凑出了一个使用
geom_rect
的黑客方法,可以适用于这个特定的应用程序,但如果例如我有其他导致单个周有多个框的因素,那么这将是一个痛苦的过程。以下是必要的可重复生产代码:
library(ggplot2)
library(grid)
var1 <- data.frame(val = rnorm(300),
week = c(rep(25, 100),
rep(26, 100),
rep(27, 100))
)
var2 <- data.frame(cumul = cumsum(c(0, rpois(2, 15))),
week = c(25, 26, 27)
)
g1 <- ggplot(var1, aes(x = factor(week), y = val)) +
geom_boxplot()
g2 <- ggplot(var2, aes(x = week, y = cumul)) +
geom_step() + scale_x_continuous(breaks = 25:27)
grid.newpage()
grid.draw(rbind(ggplotGrob(g1),
ggplotGrob(g2),
size = "last"))
而这个应急解决方法:
library(dplyr)
chiggity_check <- var1 %>%
group_by(week) %>%
summarise(week.avg = mean(val),
week.25 = quantile(val)[2],
week.75 = quantile(val)[4],
week.05 = quantile(val)[1],
week.95 = quantile(val)[5])
riggity_rect <- ggplot(chiggity_check) +
geom_rect(aes(xmin = week - 0.25, xmax = week + 0.25,
ymin = week.25,
ymax = week.75)) +
geom_segment(aes(x = week - 0.25, xend = week + 0.25,
y = week.avg, yend=week.avg),
color = "white") +
geom_segment(aes(x = week, xend = week ,
y = week.25, yend=week.05)) +
geom_segment(aes(x = week, xend = week ,
y = week.75, yend=week.95)) +
coord_cartesian(c(24.5,27.5)) +
scale_x_continuous(breaks = 25:27)
grid.newpage()
grid.draw(rbind(ggplotGrob(riggity_rect),
ggplotGrob(g2 + coord_cartesian(c(24.5,27.5))),
size = "last"))
问题是:有没有办法将 geom_boxplot
强制转换为连续轴或者将 geom_step
转换为因子轴?或者是否有其他实现方式,例如 stat_summary
,可以更加灵活,以便我可以对齐轴并且可能轻松添加像分组颜色变量这样的东西?