crm_dtps {trialr} | R Documentation |
Calculate dose-transition pathways for a CRM study
Description
Calculate dose-transition pathways (DTPs, Yap et al, 2017) for a dose-finding trial using the continual reassessment method (CRM) design. DTPs are a glimpse into the future for an in-progress trial. They tell us what the model would advise for all feasible future outcomes. They can be used in the design stages to detect possible undesirable behaviour. They can be used during the trial to aid planning and understanding.
Usage
crm_dtps(
skeleton,
target,
model,
cohort_sizes,
previous_outcomes = "",
next_dose = NULL,
user_dose_func = NULL,
verbose = FALSE,
i_am_patient = FALSE,
...
)
Arguments
skeleton |
a vector of the prior guesses of toxicity at doses. This should be a monotonically-increasing vector of numbers between 0 and 1. |
target |
the target toxicity probability, a number between 0 and 1.
This value would normally be one of the values in |
model |
Character string to denote desired model. One of |
cohort_sizes |
vector of future cohort sizes, i.e. positive integers.
E.g. To calculate paths for the the next cohort of two followed by another
cohort of three, use |
previous_outcomes |
Outcomes observed hitherto in the syntax required
by |
next_dose |
optional, integer (1-based) dose-level to be given to the next cohort. If omitted, the dose suggested by the model is used. |
user_dose_func |
optional delegate for deciding dose. A function that
takes a |
verbose |
logical, TRUE to get log messages. |
i_am_patient |
logical. The number of paths to analyse grows faster than linearly in the number of future cohorts to resolve. Fitting many models by MCMC can take a long time. This function will not proceed unless you signify your patience when the number of paths to reolve exceeds 100. |
... |
Extra parameters passed to |
Details
Different model choices require that different parameters are provided. See below.
Value
A list
of dose_finding_path_node
objects.
Parameter requirements of empiric
model
-
beta_sd
Parameter requirements of logistic
model
-
a0
-
beta_mean
-
beta_sd
Parameter requirements of logistic_gamma
model
-
a0
-
beta_shape
-
beta_inverse_scale
Parameter requirements of logistic2
model
-
alpha_mean
-
alpha_sd
-
beta_mean
-
beta_sd
Author(s)
Kristian Brock
References
Yap C, Billingham LJ, Cheung YK, Craddock C, O’Quigley J. Dose transition pathways: The missing link between complex dose-finding designs and simple decision-making. Clinical Cancer Research. 2017;23(24):7440-7447. doi:10.1158/1078-0432.CCR-17-0582
See Also
df_parse_outcomes
,
stan_crm
,
crm_path_analysis
,
dose_finding_path_node
Examples
## Not run:
target <- 0.25
skeleton <- c(0.05, 0.15, 0.25, 0.4, 0.6)
# Run DTPs for the first two cohorts of two for new a trial:
paths <- crm_dtps(skeleton = skeleton, target = target, model = 'empiric',
cohort_sizes = c(2, 2), next_dose = 3, beta_sd = 1)
length(paths) # 13
library(tibble)
df <- as_tibble(paths)
df
# Run DTPs for the next cohort of three in a trial that has already treated
# six patients, seeing some toxicity at dose-level 3:
paths2 <- crm_dtps(skeleton = skeleton, target = target, model = 'empiric',
cohort_sizes = c(3), previous_outcomes = '2NNN 3TTN',
beta_sd = 1)
length(paths2) # 5
as_tibble(paths2)
# We see that de-escalation to dose-level 2 should occur now, and that any
# further toxicity will result in advice for further de-escalation to
# dose-level 1.
# An example with a custom dose selection function
paths3 <- crm_dtps(skeleton = skeleton, target = target, model = 'empiric',
cohort_sizes = c(3, 3), previous_outcomes = '2NN 3TN',
next_dose = 2, beta_sd = 1,
user_dose_func = function(x) {
careful_escalation(x, tox_threshold = target + 0.1,
certainty_threshold = 0.7)
}, seed = 123, refresh = 0)
spread_paths(as_tibble(paths3) %>% select(-fit, -parent_fit, -dose_index))
# Stopping is recommended when the dose selection function returns NA.
## End(Not run)