Skip to content

Commit

Permalink
Merge pull request #215 from jdblischak/create-cutting-test
Browse files Browse the repository at this point in the history
Add `create_cutting_test()` and `multitest()`
  • Loading branch information
nanxstats authored Mar 11, 2024
2 parents 9ac40f3 + f96a370 commit db0d586
Show file tree
Hide file tree
Showing 18 changed files with 292 additions and 33 deletions.
2 changes: 1 addition & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Package: simtrial
Type: Package
Title: Clinical Trial Simulation
Version: 0.3.2.7
Version: 0.3.2.10
Authors@R: c(
person("Keaven", "Anderson", email = "[email protected]", role = c("aut")),
person("Yilong", "Zhang", email = "[email protected]", role = c("aut")),
Expand Down
2 changes: 2 additions & 0 deletions NAMESPACE
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

export(counting_process)
export(create_cutting)
export(create_cutting_test)
export(cut_data_by_date)
export(cut_data_by_event)
export(early_zero)
Expand All @@ -15,6 +16,7 @@ export(maxcombo)
export(mb)
export(mb_weight)
export(milestone)
export(multitest)
export(pvalue_maxcombo)
export(randomize_by_fixed_block)
export(rmst)
Expand Down
2 changes: 1 addition & 1 deletion R/input_checking.R
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ input_check_vector <- function(x = NA, require_whole_number = FALSE) {
#' @param tol tolerance
#'
#' @return TRUE, FALSE, or NA
#' @seealso \code{\link[base]{is.integer}}
#' @seealso [base::is.integer()]
#' @noRd
#' @examples
#' x <- c(1.1, -1.1, 0, 2, NA)
Expand Down
10 changes: 5 additions & 5 deletions R/maxcombo.R
Original file line number Diff line number Diff line change
Expand Up @@ -22,15 +22,15 @@
#' arguments will change as we add additional features.
#'
#' @param data a tte dataset
#' @param rho Numeric vector passed to \code{\link{fh_weight}}. Must be greater
#' than or equal to zero. Must be the same length as \code{gamma}.
#' @param gamma Numeric vector passed to \code{\link{fh_weight}}. Must be
#' greater than or equal to zero. Must be the same length as \code{rho}.
#' @param rho Numeric vector passed to [fh_weight()]. Must be greater
#' than or equal to zero. Must be the same length as `gamma`.
#' @param gamma Numeric vector passed to [fh_weight()]. Must be
#' greater than or equal to zero. Must be the same length as `rho`.
#'
#' @return pvalues
#' @export
#'
#' @seealso \code{\link{fh_weight}}
#' @seealso [fh_weight()]
#'
#' @examples
#' sim_pw_surv(n = 200) |>
Expand Down
4 changes: 2 additions & 2 deletions R/rmst.R
Original file line number Diff line number Diff line change
Expand Up @@ -197,8 +197,8 @@ diff_rmst <- function(x, op_single, reference, trunc_time, alpha = alpha) {
#'
#' @return
#' A data frame of
#' - Cutoff time: same as \code{tau};
#' - Group label: same as \code{group_label};
#' - Cutoff time: same as `tau`;
#' - Group label: same as `group_label`;
#' - Estimated RMST;
#' - Variance, standard error, and CIs of the estimated RMST;
#' - Number of events.
Expand Down
110 changes: 103 additions & 7 deletions R/sim_gs_n.R
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,13 @@
#' arguments will change as we add additional features.
#'
#' @inheritParams sim_fixed_n
#' @param test A test function such as [wlr()],
#' [maxcombo()], or [rmst()]. The simulated data set is
#' passed as the first positional argument to the test function provided.
#' @param test A test function such as [wlr()], [maxcombo()], or [rmst()]. The
#' simulated data set is passed as the first positional argument to the test
#' function provided. Alternatively a list of functions created by
#' [create_cutting_test()]. The list form is experimental and currently
#' limited. It only accepts one test per cutting (in the future multiple tests
#' may be accepted), and all the tests must consistently return the same exact
#' results (again this may be more flexible in the future).
#' @param cutting A list of cutting functions created by [create_cutting()],
#' see examples.
#' @param seed Random seed.
Expand Down Expand Up @@ -268,6 +272,17 @@ sim_gs_n <- function(
cut_date <- rep(-100, n_analysis)
ans_1sim <- NULL

# Organize tests for each cutting
if (is.function(test)) {
test_single <- test
test <- vector(mode = "list", length = n_analysis)
test[] <- list(test_single)
}
if (length(test) != length(cutting)) {
stop("If you want to run different tests at each cutting, the list of
tests must be the same length as the list of cuttings")
}

for (i_analysis in seq_len(n_analysis)) {
# Get cut date
cut_date[i_analysis] <- cutting[[i_analysis]](data = simu_data)
Expand All @@ -276,7 +291,7 @@ sim_gs_n <- function(
simu_data_cut <- simu_data |> cut_data_by_date(cut_date[i_analysis])

# Test
ans_1sim_new <- test(simu_data_cut, ...)
ans_1sim_new <- test[[i_analysis]](simu_data_cut, ...)
ans_1sim_new$analysis <- i_analysis
ans_1sim_new$cut_date <- cut_date[i_analysis]
ans_1sim_new$sim_id <- sim_id
Expand All @@ -294,16 +309,16 @@ sim_gs_n <- function(

#' Create a cutting function
#'
#' Create a cutting function for use with \code{\link{sim_gs_n}}
#' Create a cutting function for use with [sim_gs_n()]
#'
#' @param ... Arguments passed to \code{\link{get_analysis_date}}
#' @param ... Arguments passed to [get_analysis_date()]
#'
#' @return A function that accepts a data frame of simulated trial data and
#' returns a cut date
#'
#' @export
#'
#' @seealso \code{\link{get_analysis_date}}, \code{\link{sim_gs_n}}
#' @seealso [get_analysis_date()], [sim_gs_n()]
#'
#' @examples
#' # Simulate trial data
Expand All @@ -324,3 +339,84 @@ create_cutting <- function(...) {
get_analysis_date(data, ...)
}
}

#' Create a cutting test function
#'
#' Create a cutting test function for use with [sim_gs_n()]
#'
#' @param test A test function such as [wlr()], [maxcombo()], or [rmst()]
#' @param ... Arguments passed to the cutting test function
#'
#' @return A function that accepts a data frame of simulated trial data and
#' returns a test result
#'
#' @export
#'
#' @seealso [sim_gs_n()], [create_cutting()]
#'
#' @examples
#' # Simulate trial data
#' trial_data <- sim_pw_surv()
#'
#' # Cut after 150 events
#' trial_data_cut <- cut_data_by_event(trial_data, 150)
#'
#' # Create a cutting test function that can be used by sim_gs_n()
#' regular_logrank_test <- create_cutting_test(wlr, weight = fh(rho = 0, gamma = 0))
#'
#' # Test the cutting
#' regular_logrank_test(trial_data_cut)
#'
#' # The results are the same as directly calling the function
#' stopifnot(all.equal(
#' regular_logrank_test(trial_data_cut),
#' wlr(trial_data_cut, weight = fh(rho = 0, gamma = 0))
#' ))
create_cutting_test <- function(test, ...) {
stopifnot(is.function(test))
function(data) {
test(data, ...)
}
}

#' Perform multiple tests on trial data cutting
#'
#' WARNING: This experimental function is a work-in-progress. The function
#' arguments and/or returned output format may change as we add additional
#' features.
#'
#' @param data Trial data cut by [cut_data_by_event()] or [cut_data_by_date()]
#' @param ... One or more test functions. Use [create_cutting_test()] to change
#' the default arguments of each test function.
#'
#' @return A list of test results, one per test. If the test functions are named
#' in the call to `multitest()`, the returned list uses the same names.
#'
#' @export
#'
#' @seealso [create_cutting_test()]
#'
#' @examples
#' trial_data <- sim_pw_surv(n = 200)
#' trial_data_cut <- cut_data_by_event(trial_data, 150)
#'
#' # create cutting test functions
#' wlr_partial <- create_cutting_test(wlr, weight = fh(rho = 0, gamma = 0))
#' rmst_partial <- create_cutting_test(rmst, tau = 20)
#' maxcombo_partial <- create_cutting_test(maxcombo, rho = c(0, 0), gamma = c(0, 0.5))
#'
#' multitest(
#' data = trial_data_cut,
#' wlr = wlr_partial,
#' rmst = rmst_partial,
#' maxcombo = maxcombo_partial
#' )
multitest <- function(data, ...) {
tests <- list(...)
output <- vector(mode = "list", length = length(tests))
names(output) <- names(tests)
for (i in seq_along(tests)) {
output[[i]] <- tests[[i]](data)
}
return(output)
}
4 changes: 2 additions & 2 deletions R/wlr.R
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@
#' Weighted logrank test
#'
#' @param data cutted dataset generated by sim_pw_surv
#' @param weight weighting functions, such as \code{\link{fh_weight}},
#' \code{\link{mb_weight}}, and \code{\link{early_zero_weight}}.
#' @param weight weighting functions, such as [fh_weight()], [mb_weight()], and
#' [early_zero_weight()].
#'
#' @return test results
#'
Expand Down
4 changes: 2 additions & 2 deletions R/wlr_weight.R
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@

#' Fleming-Harrington weighting function
#'
#' @param rho Non-negative number. \code{rho = 0, gamma = 0} is equivalent to regular logrank test.
#' @param gamma Non-negative number. \code{rho = 0, gamma = 0} is equivalent to regular logrank test.
#' @param rho Non-negative number. `rho = 0, gamma = 0` is equivalent to regular logrank test.
#' @param gamma Non-negative number. `rho = 0, gamma = 0` is equivalent to regular logrank test.
#'
#' @export
#' @return A list of parameters of the Fleming-Harrington weighting function
Expand Down
2 changes: 2 additions & 0 deletions _pkgdown.yml
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,8 @@ reference:
- milestone
- wlr
- maxcombo
- create_cutting_test
- multitest

- title: "Randomization algorithms"
contents:
Expand Down
6 changes: 3 additions & 3 deletions man/create_cutting.Rd

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

42 changes: 42 additions & 0 deletions man/create_cutting_test.Rd

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

4 changes: 2 additions & 2 deletions man/fh.Rd

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

6 changes: 3 additions & 3 deletions man/maxcombo.Rd

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

42 changes: 42 additions & 0 deletions man/multitest.Rd

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

Loading

0 comments on commit db0d586

Please sign in to comment.