我正在使用ggplot2创建如下图:
我遇到的问题是在上平面中组合点和线。就像在图像中一样,我希望均值由线表示,数据由点表示。
我可以使用geom_line为均值和数据生成线,然后将均值和数据放在一个组中,将概率放在另一个组中,如下所示:
但是我不能将线和点合并到一个平面中。因此,我没有重塑下面提供的数据,也没有对它们进行分组。
years <- c(1962, 1963, 1964, 1965, 1966, 1967, 1968, 1969)
a.data <- c(0.105, 0.075, 0.107, 0.112, 0.116, 0.062, 0.044, 0.073)
b.data <- c(-0.039, -0.022, -0.070, -0.062, -0.067, -0.065, -0.023, -0.015)
a.mean <- c(0.0893, 0.0893, 0.0893, 0.0893, 0.0893, 0.0763, 0.0757, 0.0757)
b.mean <- c(-0.040, -0.040, -0.040, -0.040, -0.040, -0.030, -0.029, -0.029)
prob <- c(0.0, 0.0, 0.0, 0.0, 0.348 0.020, 0.002, 0.0)
任何帮助将不胜感激。
答案 0 :(得分:0)
尝试解决您的问题,我发现我使用包gridExtra
来绘制图形的方法,不是使用不同的构面,而是使用同一网格中的两个图形。
如您所见,我不得不在不同的对象中恢复数据以完成图的每个部分。
library(tidyverse)
library(gridExtra)
data <- data.frame(
years = c(1962, 1963, 1964, 1965, 1966, 1967, 1968, 1969),
a.data = c(0.105, 0.075, 0.107, 0.112, 0.116, 0.062, 0.044, 0.073),
b.data = c(-0.039, -0.022, -0.070, -0.062, -0.067, -0.065, -0.023, -0.015),
a.mean = c(0.0893, 0.0893, 0.0893, 0.0893, 0.0893, 0.0763, 0.0757, 0.0757),
b.mean = c(-0.040, -0.040, -0.040, -0.040, -0.040, -0.030, -0.029, -0.029),
prob = c(0.0, 0.0, 0.0, 0.0, 0.348, 0.020, 0.002, 0.0)
)
data_points <- data %>% select(a.data, b.data, years) %>% gather(key = "a_b", value = "data", -years)
data_lines <- data %>% select(a.mean, b.mean, years) %>% gather(key = "a_b", value = "mean", -years)
p1 <- ggplot(data_points) +
geom_point(aes(x = years, y = data, color = factor(a_b))) +
geom_line(data = data_lines, aes(x = years, y = mean, color = factor(a_b))) +
theme(legend.position = "none")
p2 <- ggplot(data) + geom_line(aes(x = years, y = prob))
grid.arrange(p1, p2)