Skip to content

Commit

Permalink
enh(plot_idf): labels
Browse files Browse the repository at this point in the history
  • Loading branch information
dimfalk committed Mar 3, 2024
1 parent 505d411 commit 7c439a2
Show file tree
Hide file tree
Showing 8 changed files with 53 additions and 9 deletions.
2 changes: 1 addition & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
Package: kostra2020
Title: R Interface for KOSTRA-DWD-2020 Dataset
Version: 1.3.1
Version: 1.3.2
Date: 2024-03-03
Authors@R:
person("Dimitri", "Falk", , "[email protected]", role = c("aut", "cre"))
Expand Down
2 changes: 1 addition & 1 deletion NEWS.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# version 1.3.1
# version 1.3.2

## features

Expand Down
40 changes: 38 additions & 2 deletions R/plot_idf.R
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
#' @param x Tibble containing grid cell statistics from KOSTRA-DWD-2010R,
#' as provided by `get_stats()`.
#' @param tn (optional) numeric. Return period \code{[a]} to be used for filtering.
#' @param log10 logical. Transform x axis to log10 scale?
#'
#' @return ggplot object.
#' @export
Expand All @@ -13,8 +14,11 @@
#' get_stats("49125") |> plot_idf()
#'
#' get_stats("49125") |> plot_idf(tn = 100)
#'
#' get_stats("49125") |> plot_idf(log10 = TRUE)
plot_idf <- function(x = NULL,
tn = NULL) {
tn = NULL,
log10 = FALSE) {

# debugging ------------------------------------------------------------------

Expand All @@ -23,6 +27,8 @@ plot_idf <- function(x = NULL,

# tn <- 100

# log10 <- TRUE

# check arguments ------------------------------------------------------------

checkmate::assert_tibble(x)
Expand All @@ -36,6 +42,8 @@ plot_idf <- function(x = NULL,
checkmate::test_choice(tn, allowed_tn)
)

checkmate::assert_logical(log10, len = 1)

# pre-processing -------------------------------------------------------------

# optionally filter for tn
Expand All @@ -50,6 +58,7 @@ plot_idf <- function(x = NULL,
attr(x, "returnperiods_a") <- tn
}

# labels
if (attr(x, "type") == "HN") {

cnames <- colnames(x)[colnames(x) |> stringr::str_detect("HN_*")]
Expand Down Expand Up @@ -82,10 +91,24 @@ plot_idf <- function(x = NULL,

lab_legend <- attr(x, "returnperiods_a") |> as.character()



# y-axis ticks
val_max <- x_long[["value"]] |> max() |> round(-1)

if(val_max < 200) {

y_ticks <- seq(from = 0, to = val_max, by = 10)

} else {

y_ticks <- seq(from = 0, to = val_max, by = 20)
}

# main -----------------------------------------------------------------------

# plot tile statistics, colours according to return periods
ggplot2::ggplot(x_long, ggplot2::aes(x = D_min, y = value, colour = name)) +
gg <- ggplot2::ggplot(x_long, ggplot2::aes(x = D_min, y = value, colour = name)) +
ggplot2::geom_point() +
ggplot2::geom_line() +
ggplot2::labs(title = lab_title,
Expand All @@ -94,5 +117,18 @@ plot_idf <- function(x = NULL,
x = "duration [min]",
y = lab_y,
color = "return periods [a]") +
ggplot2::scale_y_continuous(breaks = y_ticks,
labels = y_ticks) +
ggplot2::scale_color_discrete(labels = lab_legend)

if (log10 == TRUE) {

gg <- gg + ggplot2::scale_x_continuous(trans = "log10",
breaks = attr(x, "durations_min"),
labels = attr(x, "durations_min"),
guide = ggplot2::guide_axis(angle = 90))
}

# return object
gg
}
4 changes: 2 additions & 2 deletions README.Rmd
Original file line number Diff line number Diff line change
Expand Up @@ -211,8 +211,8 @@ xts

Data can now additionally be visualized as intensity-duration-frequency curves using `plot_idf()`, underpinned by `{ggplot2}` ...

```{r}
plot_idf(kostra)
```{r, fig.width = 9}
plot_idf(kostra, log10 = TRUE)
```

.. or exported to disk using `write_stats()` based on `write.table()`.
Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ and load the package via

``` r
library(kostra2020)
#> 1.3.0
#> 1.3.2
```

## Getting started
Expand Down Expand Up @@ -355,7 +355,7 @@ Data can now additionally be visualized as intensity-duration-frequency
curves using `plot_idf()`, underpinned by `{ggplot2}`

``` r
plot_idf(kostra)
plot_idf(kostra, log10 = TRUE)
```

<img src="man/figures/README-unnamed-chunk-20-1.png" width="100%" />
Expand Down
Binary file modified man/figures/README-unnamed-chunk-20-1.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
6 changes: 5 additions & 1 deletion man/plot_idf.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 4 additions & 0 deletions tests/testthat/test-plot_idf.R
Original file line number Diff line number Diff line change
Expand Up @@ -11,4 +11,8 @@ test_that("Output class is as expected.", {
gg3 <- get_stats("49125") |> plot_idf(tn = 100)

expect_s3_class(gg3, c("gg", "ggplot"))

gg4 <- get_stats("49125") |> plot_idf(log10 = TRUE)

expect_s3_class(gg4, c("gg", "ggplot"))
})

0 comments on commit 7c439a2

Please sign in to comment.