| derive_var_ontrtfl {admiral} | R Documentation |
Derive On-Treatment Flag Variable
Description
Derive on-treatment flag (ONTRTFL) in an ADaM dataset with a single
assessment date (e.g ADT) or event start and end dates (e.g.
ASTDT/AENDT).
Usage
derive_var_ontrtfl(
dataset,
new_var = ONTRTFL,
start_date,
end_date = NULL,
ref_start_date,
ref_end_date = NULL,
ref_end_window = 0,
ignore_time_for_ref_end_date = TRUE,
filter_pre_timepoint = NULL,
span_period = FALSE
)
Arguments
dataset |
Input dataset Required columns are |
new_var |
On-treatment flag variable name to be created. Default is |
start_date |
The start date (e.g. Refer to |
end_date |
The end date of assessment/event (e.g. Refer to Optional; Default is null. If the used and date value is missing on an
observation, it is assumed the medication is ongoing and |
ref_start_date |
The lower bound of the on-treatment period Required; A date or date-time object column is expected. Refer to |
ref_end_date |
The upper bound of the on-treatment period A date or date-time object column is expected. Refer to Optional; This can be null and everything after |
ref_end_window |
A window to add to the upper bound |
ignore_time_for_ref_end_date |
If the argument is set to Permitted Values: |
filter_pre_timepoint |
An expression to filter observations as not
on-treatment when |
span_period |
A logical scalar. If |
Details
On-Treatment is calculated by determining whether the assessment
date or start/stop dates fall between 2 dates. The following logic is used
to assign on-treatment = "Y":
-
start_dateis missing andref_start_dateis non-missing No timepoint filter is provided (
filter_pre_timepoint) and bothstart_dateandref_start_dateare non-missing andstart_date=ref_start_dateA timepoint is provided (
filter_pre_timepoint) and bothstart_dateandref_start_dateare non-missing andstart_date = ref_start_dateand the filter provided infilter_pre_timepointis not true.-
ref_end_dateis not provided andref_start_date < start_date -
ref_end_dateis provided andref_start_date < start_date<=ref_end_date + ref_end_window.
If the end_date is provided and the end_date < ref_start_date then the
ONTRTFL is set to NULL.This would be applicable to cases where the
start_date is missing and ONTRTFL has been assigned as "Y" above.
If the span_period is TRUE, this allows the user to assign
ONTRTFL as "Y" to cases where the record started prior to the
ref_start_date and was ongoing or ended after the ref_start_date.
Any date imputations needed should be done prior to calling this function.
Value
The input dataset with an additional column named ONTRTFL with a
value of "Y" or NA
See Also
BDS-Findings Functions that returns variable appended to dataset:
derive_basetype_records(),
derive_var_analysis_ratio(),
derive_var_anrind(),
derive_var_atoxgr(),
derive_var_atoxgr_dir(),
derive_var_base(),
derive_var_chg(),
derive_var_pchg(),
derive_var_shift()
Examples
library(tibble)
library(dplyr, warn.conflicts = FALSE)
library(lubridate, warn.conflicts = FALSE)
advs <- tribble(
~USUBJID, ~ADT, ~TRTSDT, ~TRTEDT,
"P01", ymd("2020-02-24"), ymd("2020-01-01"), ymd("2020-03-01"),
"P02", ymd("2020-01-01"), ymd("2020-01-01"), ymd("2020-03-01"),
"P03", ymd("2019-12-31"), ymd("2020-01-01"), ymd("2020-03-01")
)
derive_var_ontrtfl(
advs,
start_date = ADT,
ref_start_date = TRTSDT,
ref_end_date = TRTEDT
)
advs <- tribble(
~USUBJID, ~ADT, ~TRTSDT, ~TRTEDT,
"P01", ymd("2020-07-01"), ymd("2020-01-01"), ymd("2020-03-01"),
"P02", ymd("2020-04-30"), ymd("2020-01-01"), ymd("2020-03-01"),
"P03", ymd("2020-03-15"), ymd("2020-01-01"), ymd("2020-03-01")
)
derive_var_ontrtfl(
advs,
start_date = ADT,
ref_start_date = TRTSDT,
ref_end_date = TRTEDT,
ref_end_window = 60
)
advs <- tribble(
~USUBJID, ~ADTM, ~TRTSDTM, ~TRTEDTM,
"P01", ymd_hm("2020-01-02T12:00"), ymd_hm("2020-01-01T12:00"), ymd_hm("2020-03-01T12:00"),
"P02", ymd("2020-01-01"), ymd_hm("2020-01-01T12:00"), ymd_hm("2020-03-01T12:00"),
"P03", ymd("2019-12-31"), ymd_hm("2020-01-01T12:00"), ymd_hm("2020-03-01T12:00"),
) %>%
mutate(TPT = c(NA, "PRE", NA))
derive_var_ontrtfl(
advs,
start_date = ADTM,
ref_start_date = TRTSDTM,
ref_end_date = TRTEDTM,
filter_pre_timepoint = TPT == "PRE"
)
advs <- tribble(
~USUBJID, ~ASTDT, ~TRTSDT, ~TRTEDT, ~AENDT,
"P01", ymd("2020-03-15"), ymd("2020-01-01"), ymd("2020-03-01"), ymd("2020-12-01"),
"P02", ymd("2019-04-30"), ymd("2020-01-01"), ymd("2020-03-01"), ymd("2020-03-15"),
"P03", ymd("2019-04-30"), ymd("2020-01-01"), ymd("2020-03-01"), NA,
)
derive_var_ontrtfl(
advs,
start_date = ASTDT,
end_date = AENDT,
ref_start_date = TRTSDT,
ref_end_date = TRTEDT,
ref_end_window = 60,
span_period = TRUE
)
advs <- tribble(
~USUBJID, ~ASTDT, ~AP01SDT, ~AP01EDT, ~AENDT,
"P01", ymd("2020-03-15"), ymd("2020-01-01"), ymd("2020-03-01"), ymd("2020-12-01"),
"P02", ymd("2019-04-30"), ymd("2020-01-01"), ymd("2020-03-01"), ymd("2020-03-15"),
"P03", ymd("2019-04-30"), ymd("2020-01-01"), ymd("2020-03-01"), NA,
)
derive_var_ontrtfl(
advs,
new_var = ONTR01FL,
start_date = ASTDT,
end_date = AENDT,
ref_start_date = AP01SDT,
ref_end_date = AP01EDT,
span_period = TRUE
)