Использование geom_line и geom_point для разных серий в одном фасете - PullRequest
0 голосов
/ 23 января 2019

Я использую ggplot2 для создания графика, подобного следующему:

enter image description here

Проблема, с которой я сталкиваюсь, заключается в объединении точек и линий вверхняя грань.Как и на рисунке, я хочу, чтобы средства были представлены линиями, а данные - точками.

Я могу производить строки для средних и данных, используя geom_line и помещая средние значения и данные в одну группу, а вероятности в другую, как показано здесь:

enter image description here

Но я не могу объединить линии и точки в одном фасете.Из-за этого я не изменил приведенные ниже данные и не сгруппировал их.

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)

Любая помощь будет принята с благодарностью.

1 Ответ

0 голосов
/ 23 января 2019

Пытаясь решить вашу проблему, я нахожу способ сделать график не с другим фасетом, а с двумя графиками в одной сетке, используя пакет gridExtra.

Как видите, мне пришлось восстанавливать данные в разных целях для выполнения каждой части графика.

resulting_plot

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)
...