
Parse a string of phase I/II dose-finding outcomes to vector notation.
Source:R/parse_phase1_2_outcomes.R
      parse_phase1_2_outcomes.RdParse a string of phase I/II dose-finding outcomes to a binary vector notation necessary for model invocation.
The outcome string describes the doses given, outcomes observed and groups patients into cohorts. The format of the string is described in Brock et al. (2017). See Examples.
The letters E, T, N and B are used to represents patients that
experienced (E)fficacy only, (T)oxicity only, (B)oth efficacy and toxicity,
and (N)either. These letters are concatenated after numerical dose-levels to
convey the outcomes of cohorts of patients. For instance, 2ETB
represents a cohort of three patients that were treated at dose-level 2, and
experienced efficacy, toxicity and both events, respectively. The results of
cohorts are separated by spaces. Thus, 2ETB 1NN extends our previous
example, where the next cohort of two were treated at dose-level 1 and both
patients experienced neither efficacy nor toxicity. See Examples.
Value
If as_list == TRUE, a list with elements eff,
tox, dose and num_patients. If as_list == FALSE,
a data.frame with columns eff, tox and dose.
References
Brock, K., Billingham, L., Copland, M., Siddique, S., Sirovica, M., & Yap, C. (2017). Implementing the EffTox dose-finding design in the Matchpoint trial. BMC Medical Research Methodology, 17(1), 112. https://doi.org/10.1186/s12874-017-0381-x
Examples
x = parse_phase1_2_outcomes('1NNE 2EEN 3TBB')
# Three cohorts of three patients. The first cohort was treated at dose 1 and
# had no toxicity with one efficacy, etc.
x$num_patients  # 9
#> [1] 9
x$dose         # c(1, 1, 1, 2, 2, 2, 3, 3, 3)
#> [1] 1 1 1 2 2 2 3 3 3
x$eff           # c(0, 0, 1, 1, 1, 0, 0, 1, 1)
#> [1] 0 0 1 1 1 0 0 1 1
sum(x$eff)      # 5
#> [1] 5
x$tox           # c(0, 0, 0, 0, 0, 0, 1, 1, 1)
#> [1] 0 0 0 0 0 0 1 1 1
sum(x$tox)      # 3
#> [1] 3
# The same information can be parsed to a data-frame:
y = parse_phase1_2_outcomes('1NNE 2EEN 3TBB', as_list = FALSE)
y
#> # A tibble: 9 × 6
#>   cohort patient dose_string  dose   tox   eff
#>    <int>   <int> <chr>       <int> <int> <int>
#> 1      1       1 1               1     0     0
#> 2      1       2 1               1     0     0
#> 3      1       3 1               1     0     1
#> 4      2       4 2               2     0     1
#> 5      2       5 2               2     0     1
#> 6      2       6 2               2     0     0
#> 7      3       7 3               3     1     0
#> 8      3       8 3               3     1     1
#> 9      3       9 3               3     1     1