Skip to content

Commit

Permalink
Merge branch 'main' into 2142_derive_summary_records_get_summary_reco…
Browse files Browse the repository at this point in the history
…rds_mods
  • Loading branch information
zdz2101 authored Nov 2, 2023
2 parents 0b4ef60 + a69501b commit b61cc15
Show file tree
Hide file tree
Showing 9 changed files with 212 additions and 57 deletions.
2 changes: 2 additions & 0 deletions .github/workflows/common.yml
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,8 @@ jobs:
with:
r-version: "4.3"
skip-multiversion-docs: true
secrets:
GITHUB_PAT: ${{ secrets.GITHUB_TOKEN }}
linter:
name: Lint
uses: pharmaverse/admiralci/.github/workflows/lintr.yml@main
Expand Down
2 changes: 1 addition & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Package: admiral
Type: Package
Title: ADaM in R Asset Library
Version: 0.12.3.9001
Version: 0.12.3.9002
Authors@R: c(
person("Ben", "Straub", email = "[email protected]", role = c("aut", "cre")),
person("Stefan", "Bundfuss", role = "aut"),
Expand Down
34 changes: 33 additions & 1 deletion NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,19 @@

- `derive_extreme_records()`, `derive_var_extreme_flag()`,`derive_vars_joined()` and `derive_vars_merged()` were enhanced with the arguments `true_value` and `false_value` to align with preexisting functions that had similar functionality (#2125)

- `restrict_derivation()` now allows `{dplyr}` functions like `mutate` in the `derivation argument (#2143)
- `restrict_derivation()` now allows `{dplyr}` functions like `mutate` in the
`derivation` argument (#2143)

- `derive_summary_records()`, `derive_var_merged_summary()`, and `get_summary_records()`
were enhanced such that more than one summary variable can be derived, e.g.,
`AVAL` as the sum and `ADT` as the maximum of the contributing records. (#1792)

- `derive_summary_records()` was enhanced with the following optional arguments: `dataset_add`, `dataset_ref`, `missing_values`. These arguments respectively, generate summary variables from additional datasets, retain/add specific records from a reference dataset, and impute user-defined missing values. (#2142)

- The `tmp_event_nr_var` argument was added to `derive_extreme_records()` to
allow more control of the selection of records. It creates a temporary variable
for the event number, which can be used in `order`. (#2140)


## Breaking Changes

Expand All @@ -30,6 +35,31 @@ were enhanced such that more than one summary variable can be derived, e.g.,

- The default value for the `false_value` argument in `derive_extreme_records()` was changed to `NA_character_` (#2125)

- The `ignore_event_order` argument in `derive_extreme_event()` was deprecated
and the selection of the records was changed to allow more control. Before, the
records were selected first by event and then by `order`. Now they are selected
by `order` only but the event number can be added to it.

To achieve the old behavior update
```
order = exprs(my_order_var),
ignore_event_order = FALSE,
```
to
```
tmp_event_nr_var = event_nr,
order = exprs(event_nr, my_order_var),
```
and
```
order = exprs(my_order_var),
ignore_event_order = TRUE,
```
to
```
order = exprs(my_order_var),
```

- The following functions, which were deprecated in previous `{admiral}` versions, have been removed: (#2098)
- `derive_param_extreme_event()`
- `derive_vars_last_dose()`
Expand Down Expand Up @@ -61,6 +91,8 @@ were enhanced such that more than one summary variable can be derived, e.g.,
- Removed Deprecation section in Reference tab. Added new Superseded section in
Reference tab. (#2174)

- Added a link to the previous versions of the website to the navigation bar. (#2205)

## Various

- Website now has button/links to Slack channel and GitHub Issues (#2127)
Expand Down
96 changes: 62 additions & 34 deletions R/derive_extreme_event.R
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,16 @@
#' For `event_joined()` events the observations are selected by calling
#' `filter_joined`. The `condition` field is passed to the `filter` argument.
#'
#' @param tmp_event_nr_var Temporary event number variable
#'
#' The specified variable is added to all source datasets and is set to the
#' number of the event before selecting the records of the event.
#'
#' It can be used in `order` to determine which record should be used if
#' records from more than one event are selected.
#'
#' The variable is not included in the output dataset.
#'
#' @param order Sort order
#'
#' If a particular event from `events` has more than one observation, within
Expand All @@ -41,6 +51,13 @@
#'
#' @param ignore_event_order Ignore event order
#'
#' `r lifecycle::badge("deprecated")`
#'
#' This argument is *deprecated*. If event order should be ignored, please
#' specify neither `ignore_event_order` nor `tmp_event_nr_var`. If the event
#' order should be considered, don't specify `ignore_event_order` but specify
#' `tmp_event_nr_var` and and the specified variable to `order`.
#'
#' If the argument is set to `TRUE`, all events defined by `events` are
#' considered equivalent. If there is more than one observation per by group
#' the first or last (with respect to `mode` and `order`) is select without
Expand Down Expand Up @@ -73,12 +90,14 @@
#'
#' 1. The variables specified by the `set_values_to` field of the event
#' are added to the selected observations.
#' 1. The variable specified for `tmp_event_nr_var` is added and set to
#' the number of the event.
#' 1. Only the variables specified for the `keep_source_vars` field of the
#' event, and the by variables (`by_vars`) and the variables created by
#' `set_values_to` are kept.
#' 1. All selected observations are bound together.
#' 1. For each group (with respect to the variables specified for the
#' `by_vars` parameter) the first event is selected. If there is more than one
#' observation per event the first or last observation (with respect to the
#' `by_vars` parameter) the first or last observation (with respect to the
#' order specified for the `order` parameter and the mode specified for the
#' `mode` parameter) is selected.
#' 1. The variables specified by the `set_values_to` parameter are added to
Expand Down Expand Up @@ -141,8 +160,9 @@
#' set_values_to = exprs(AVALC = "Missing", AVAL = 99)
#' )
#' ),
#' order = exprs(ADY),
#' mode = "last",
#' tmp_event_nr_var = event_nr,
#' order = exprs(event_nr, desc(ADY)),
#' mode = "first",
#' set_values_to = exprs(
#' PARAMCD = "WSP",
#' PARAM = "Worst Sleeping Problems"
Expand Down Expand Up @@ -178,7 +198,8 @@
#' set_values_to = exprs(AVALC = "Y")
#' )
#' ),
#' order = exprs(AVISITN),
#' tmp_event_nr_var = event_nr,
#' order = exprs(event_nr, AVISITN),
#' mode = "first",
#' keep_source_vars = exprs(AVISITN),
#' set_values_to = exprs(
Expand Down Expand Up @@ -243,7 +264,8 @@
#' derive_extreme_event(
#' adrs,
#' by_vars = exprs(USUBJID),
#' order = exprs(ADT),
#' tmp_event_nr_var = event_nr,
#' order = exprs(event_nr, ADT),
#' mode = "first",
#' source_datasets = list(adsl = adsl),
#' events = list(
Expand Down Expand Up @@ -321,6 +343,7 @@
derive_extreme_event <- function(dataset,
by_vars = NULL,
events,
tmp_event_nr_var = NULL,
order,
mode,
source_datasets = NULL,
Expand Down Expand Up @@ -355,7 +378,29 @@ derive_extreme_event <- function(dataset,
)
}

assert_logical_scalar(ignore_event_order)
if (!missing(ignore_event_order)) {
assert_logical_scalar(ignore_event_order)
if (ignore_event_order) {
deprecate_details <- paste(
"The event order is ignored by default.",
"Please remove `ignore_event_order = TRUE` from the call.",
sep = "\n"
)
} else {
deprecate_details <- c(
"Please remove `ignore_event_order = FALSE` from the call.",
"Specify `tmp_event_nr_var`.",
"Add the specified variable to `order`."
)
}
deprecate_warn(
"1.0.0",
"derive_extreme_event(ignore_event_order=)",
"derive_extreme_event(tmp_event_nr_var=)",
details = deprecate_details
)
}
tmp_event_nr_var <- assert_symbol(enexpr(tmp_event_nr_var), optional = TRUE)
check_type <-
assert_character_scalar(
check_type,
Expand All @@ -368,11 +413,6 @@ derive_extreme_event <- function(dataset,
# Create new observations
## Create a dataset (selected_records) from `events`
event_index <- as.list(seq_along(events))
if (ignore_event_order) {
tmp_event_no <- NULL
} else {
tmp_event_no <- get_new_tmp_var(dataset, prefix = "tmp_event_no")
}

selected_records_ls <- map2(
events,
Expand All @@ -383,6 +423,9 @@ derive_extreme_event <- function(dataset,
} else {
data_source <- source_datasets[[event$dataset_name]]
}
if (!is.null(tmp_event_nr_var)) {
data_source <- mutate(data_source, !!tmp_event_nr_var := index)
}
if (is.null(event$order)) {
event_order <- order
} else {
Expand Down Expand Up @@ -417,41 +460,26 @@ derive_extreme_event <- function(dataset,
} else {
event_keep_source_vars <- event$keep_source_vars
}
if (!ignore_event_order) {
data_events <- mutate(data_events, !!tmp_event_no := index)
}
data_events %>%
process_set_values_to(set_values_to = event$set_values_to) %>%
select(!!!event_keep_source_vars, !!tmp_event_no, !!!by_vars, names(event$set_values_to))
select(
!!!event_keep_source_vars, !!tmp_event_nr_var, !!!by_vars,
names(event$set_values_to)
)
}
)
selected_records <- bind_rows(selected_records_ls)

## tmp obs number within by_vars and a type of event
tmp_obs <- get_new_tmp_var(selected_records)
selected_records <- selected_records %>%
derive_var_obs_number(
new_var = !!tmp_obs,
order = order,
by_vars = expr_c(by_vars, tmp_event_no),
check_type = check_type
)

## filter_extreme
if (mode == "first") {
tmp_obs_expr <- expr(!!tmp_obs)
} else {
tmp_obs_expr <- expr(desc(!!tmp_obs))
}
new_obs <- selected_records %>%
filter_extreme(
by_vars = by_vars,
order = expr_c(tmp_event_no, tmp_obs_expr),
mode = "first",
order = order,
mode = mode,
check_type = check_type
) %>%
mutate(!!!set_values_to) %>%
select(-!!tmp_event_no, -!!tmp_obs)
select(-!!tmp_event_nr_var)

# Create output dataset
bind_rows(dataset, new_obs)
Expand Down
9 changes: 7 additions & 2 deletions _pkgdown.yml
Original file line number Diff line number Diff line change
Expand Up @@ -138,8 +138,8 @@ reference:

navbar:
structure:
left: [getstarted, reference, articles, community, news]
right: [search, slack, newissue, github]
left: [getstarted, reference, articles, community, news, versions]
right: [search, slack, history, newissue, github]
components:
getstarted:
text: Get Started
Expand Down Expand Up @@ -194,6 +194,11 @@ navbar:
href: articles/lab_grading.html
- text: Hy's Law Implementation
href: articles/hys_law.html

history:
icon: fa-history
href: articles/website-versions.html
aria-label: Previous Release Websites
slack:
icon: fa-slack
href: https://app.slack.com/client/T028PB489D3/C02M8KN8269
Expand Down
35 changes: 29 additions & 6 deletions man/derive_extreme_event.Rd

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

Loading

0 comments on commit b61cc15

Please sign in to comment.