Шкала вероятности ежегодного превышения в ggplot - PullRequest
0 голосов
/ 16 ноября 2018

У меня есть кадр данных df расчетной годовой вероятности превышения (AEP) суточного максимального количества жидких осадков (P):

df <- tibble::tribble(
   ~AEP,          ~P,
  0.001, 299.0973209,
   0.01, 254.7226534,
   0.03, 233.0298722,
   0.05, 223.9571177,
    0.1, 211.2898816,
    0.3, 190.5075232,
    0.5, 182.3294549,
      1, 170.5569051,
      3, 148.9113334,
      5,  138.991102,
     10, 125.4449161,
     20, 110.1408306,
     25,   104.74124,
     30, 100.2363357,
     40, 92.15268627,
     50, 85.75477796,
     60, 79.55311702,
     70, 73.44249835,
     75, 70.21061223,
     80, 66.79821521,
     90, 58.54507042,
     95, 52.44861458,
     97, 48.86357489,
     99, 43.12184627,
   99.5, 39.72675936,
   99.7,  37.5826596,
   99.9, 33.91759317
  )

Все, что мне нужно, - это создать конкретныймасштаб с равным расстоянием между перерывами посередине и возрастающим на обоих концах.Прекрасный пример из книги здесь:

enter image description here

Все, что я смог создать сам (на основе фрагментов кода из этого gist ) верните мне кучу ярлыков:

library(dplyr)
library(scales)
library(ggplot2)

df %>% 
  ggplot(aes(x = AEP, y = P)) + 
  geom_point() +
  geom_line() +
  scale_y_continuous(name = "Precipitation (P), mm",
                     labels = scales::comma,
                     breaks = seq(0, 300, 50)) +
  scale_x_continuous(name = "AEP, %",
                     breaks = df$AEP,
                     labels = str_c(df$AEP,'%'),
                     expand = c(0.001,0.001)) +
  theme_grey(base_size = 12)

enter image description here

1 Ответ

0 голосов
/ 17 ноября 2018

Я нашел ответ в одном из вопросов о переполнении стека . Чтобы создать желаемый масштаб, нам нужно применить квантильную функцию qnorm ко всем AEP значениям (или другим значениям x), например,

df %>% 
  ggplot(aes(x = qnorm(AEP/100), # transform to quantiles
             y = P)) + 
  geom_point() +
  geom_line() +
  scale_y_continuous(name = "Precipitation (P), mm",
                     labels = scales::comma,
                     breaks = seq(0, 300, 50)) +
  scale_x_continuous(name = "AEP, %",
                     breaks = qnorm(df$AEP/100), #transform
                     labels = df$AEP,
                     expand = c(0.035,0.035)) +
  theme_bw(base_size = 12)

enter image description here

...