| Type: | Package | 
| Title: | Simulating Oncology Trials using an Illness-Death Model | 
| Version: | 0.1.0 | 
| Description: | Based on the illness-death model a large number of clinical trials with oncology endpoints progression-free survival (PFS) and overall survival (OS) can be simulated, see Meller, Beyersmann and Rufibach (2019) <doi:10.1002/sim.8295>. The simulation set-up allows for random and event-driven censoring, an arbitrary number of treatment arms, staggered study entry and drop-out. Exponentially, Weibull and piecewise exponentially distributed survival times can be generated. The correlation between PFS and OS can be calculated. | 
| License: | Apache License 2.0 | 
| URL: | https://github.com/insightsengineering/simIDM/ | 
| BugReports: | https://github.com/insightsengineering/simIDM/issues | 
| Depends: | R (≥ 3.6) | 
| Imports: | checkmate, furrr, future, mstate, parallelly, stats, survival | 
| Suggests: | coxphw, knitr, mvna, prodlim, rmarkdown, rpact, testthat (≥ 3.0.0) | 
| VignetteBuilder: | knitr | 
| Config/testthat/edition: | 3 | 
| Encoding: | UTF-8 | 
| Language: | en-US | 
| RoxygenNote: | 7.2.3 | 
| NeedsCompilation: | no | 
| Packaged: | 2023-12-11 09:17:50 UTC; sabanesd | 
| Author: | Alexandra Erdmann [aut, cre], Kaspar Rufibach [aut], Holger Löwe [aut], Daniel Sabanés Bové [aut], F. Hoffmann-La Roche AG [cph, fnd], University of Ulm [cph, fnd] | 
| Maintainer: | Alexandra Erdmann <alexandra.erdmann@uni-ulm.de> | 
| Repository: | CRAN | 
| Date/Publication: | 2023-12-11 10:20:02 UTC | 
simIDM Package
Description
simIDM simulates a survival multistate model that jointly models PFS and OS.
Author(s)
Maintainer: Alexandra Erdmann alexandra.erdmann@uni-ulm.de
Authors:
- Kaspar Rufibach kaspar.rufibach@roche.com 
- Holger Löwe hbj.loewe@gmail.com 
- Daniel Sabanés Bové daniel.sabanes_bove@roche.com 
Other contributors:
- F. Hoffmann-La Roche AG [copyright holder, funder] 
- University of Ulm [copyright holder, funder] 
See Also
Useful links:
- Report bugs at https://github.com/insightsengineering/simIDM/issues 
OS Hazard Function from Constant Transition Hazards
Description
OS Hazard Function from Constant Transition Hazards
Usage
ExpHazOS(t, h01, h02, h12)
Arguments
| t | ( | 
| h01 | (positive  | 
| h02 | (positive  | 
| h12 | (positive  | 
Value
This returns the value of the OS hazard function at time t.
Examples
ExpHazOS(c(1:5), 0.2, 1.1, 0.8)
Quantile function for OS survival function induced by an illness-death model
Description
Quantile function for OS survival function induced by an illness-death model
Usage
ExpQuantOS(q = 1/2, h01, h02, h12)
Arguments
| q | ( | 
| h01 | ( | 
| h02 | ( | 
| h12 | ( | 
Value
This returns the time(s) t such that the OS survival function at t equals q.
Examples
ExpQuantOS(1 / 2, 0.2, 0.5, 2.1)
OS Survival Function from Constant Transition Hazards
Description
OS Survival Function from Constant Transition Hazards
Usage
ExpSurvOS(t, h01, h02, h12)
Arguments
| t | ( | 
| h01 | (positive  | 
| h02 | (positive  | 
| h12 | (positive  | 
Value
This returns the value of OS survival function at time t.
Examples
ExpSurvOS(c(1:5), 0.2, 0.4, 0.1)
PFS Survival Function from Constant Transition Hazards
Description
PFS Survival Function from Constant Transition Hazards
Usage
ExpSurvPFS(t, h01, h02)
Arguments
| t | ( | 
| h01 | (positive  | 
| h02 | (positive  | 
Value
This returns the value of PFS survival function at time t.
Examples
ExpSurvPFS(c(1:5), 0.2, 0.4)
Single Piecewise Exponentially Distributed Event Time
Description
This returns an event time with a distribution resulting from piece-wise constant hazards using the inversion method.
Usage
PCWInversionMethod(haz, pw, LogU)
Arguments
| haz | ( | 
| pw | ( | 
| LogU | ( | 
Value
This returns one single event time.
Examples
PCWInversionMethod(haz = c(1.1, 0.5, 0.4), pw = c(0, 7, 10), LogU = log(1 - runif(1)))
Helper Function for survPFSOS()
Description
Helper Function for survPFSOS()
Usage
PFSOSInteg(u, t, transition)
Arguments
| u | ( | 
| t | ( | 
| transition | ( | 
Value
Numeric result of the integrand used to calculate the PFS*OS survival function.
Note
Not all vectors u and t work here due to assertions in log_p11().
OS Survival Function from Piecewise Constant Hazards
Description
OS Survival Function from Piecewise Constant Hazards
Usage
PWCsurvOS(t, h01, h02, h12, pw01, pw02, pw12)
Arguments
| t | ( | 
| h01 | ( | 
| h02 | ( | 
| h12 | ( | 
| pw01 | ( | 
| pw02 | ( | 
| pw12 | ( | 
Value
This returns the value of OS survival function at time t.
Examples
PWCsurvOS(1:5, c(0.3, 0.5), c(0.5, 0.8), c(0.7, 1), c(0, 4), c(0, 8), c(0, 3))
PFS Survival Function from Piecewise Constant Hazards
Description
PFS Survival Function from Piecewise Constant Hazards
Usage
PWCsurvPFS(t, h01, h02, pw01, pw02)
Arguments
| t | ( | 
| h01 | ( | 
| h02 | ( | 
| pw01 | ( | 
| pw02 | ( | 
Value
This returns the value of PFS survival function at time t.
Examples
PWCsurvPFS(1:5, c(0.3, 0.5), c(0.5, 0.8), c(0, 4), c(0, 8))
Helper Function of PWCsurvOS()
Description
Helper Function of PWCsurvOS()
Usage
PwcOSInt(x, t, h01, h02, h12, pw01, pw02, pw12)
Arguments
| x | ( | 
| t | ( | 
| h01 | ( | 
| h02 | ( | 
| h12 | ( | 
| pw01 | ( | 
| pw02 | ( | 
| pw12 | ( | 
Value
Numeric results of the integrand used to calculate
the OS survival function for piecewise constant transition hazards, see  PWCsurvOS.
Helper Function for WeibSurvOS()
Description
Helper Function for WeibSurvOS()
Usage
WeibOSInteg(x, t, h01, h02, h12, p01, p02, p12)
Arguments
| x | ( | 
| t | ( | 
| h01 | (positive  | 
| h02 | (positive  | 
| h12 | (positive  | 
| p01 | (positive  | 
| p02 | (positive  | 
| p12 | (positive  | 
Value
Numeric results of the integrand used to calculate
the OS survival function for Weibull transition hazards, see  WeibSurvOS().
OS Survival Function from Weibull Transition Hazards
Description
OS Survival Function from Weibull Transition Hazards
Usage
WeibSurvOS(t, h01, h02, h12, p01, p02, p12)
Arguments
| t | ( | 
| h01 | (positive  | 
| h02 | (positive  | 
| h12 | (positive  | 
| p01 | (positive  | 
| p02 | (positive  | 
| p12 | (positive  | 
Value
This returns the value of OS survival function at time t.
Examples
WeibSurvOS(c(1:5), 0.2, 0.5, 2.1, 1.2, 0.9, 1)
PFS Survival Function from Weibull Transition Hazards
Description
PFS Survival Function from Weibull Transition Hazards
Usage
WeibSurvPFS(t, h01, h02, p01, p02)
Arguments
| t | ( | 
| h01 | (positive  | 
| h02 | (positive  | 
| p01 | (positive  | 
| p02 | (positive  | 
Value
This returns the value of PFS survival function at time t.
Examples
WeibSurvPFS(c(1:5), 0.2, 0.5, 1.2, 0.9)
Staggered Study Entry
Description
This function adds staggered study entry times to a simulated data set with illness-death model structure.
Usage
addStaggeredEntry(simData, N, accrualParam, accrualValue)
Arguments
| simData | ( | 
| N | ( | 
| accrualParam | ( | 
| accrualValue | ( | 
Value
This returns a data set containing a single simulated study containing accrual times,
i.e. staggered study entry.
This is a helper function of getSimulatedData().
Examples
simData <- data.frame(
  id = c(1, 1, 2, 3), from = c(0, 1, 0, 0), to = c(1, 2, "cens", 2),
  entry = c(0, 3, 0, 0),
  exit = c(3, 5.3, 5.6, 7.2), censTime = c(6.8, 6.8, 5.6, 9.4)
)
addStaggeredEntry(simData, 3, accrualParam = "time", accrualValue = 5)
Assertion for vector describing intervals
Description
We define an intervals vector to always start with 0, and contain unique ordered time points.
Usage
assert_intervals(x, y)
Arguments
| x | what to check. | 
| y | ( | 
Value
Raises an error if x is not an intervals vector starting with 0.
Examples
assert_intervals(c(0, 5, 7), 3)
Assertion for Positive Number
Description
Assertion for Positive Number
Usage
assert_positive_number(x, zero_ok = FALSE)
Arguments
| x | what to check. | 
| zero_ok | ( | 
Value
Raises an error if x is not a single positive (or non-negative) number.
Examples
assert_positive_number(3.2)
assert_positive_number(0, zero_ok = TRUE)
Average OS Hazard Ratio from Constant Transition Hazards
Description
Average OS Hazard Ratio from Constant Transition Hazards
Usage
avgHRExpOS(transitionByArm, alpha = 0.5, upper = Inf)
Arguments
| transitionByArm | ( | 
| alpha | ( | 
| upper | ( | 
Value
This returns the value of the average hazard ratio.
Examples
transitionTrt <- exponential_transition(h01 = 0.18, h02 = 0.06, h12 = 0.17)
transitionCtl <- exponential_transition(h01 = 0.23, h02 = 0.07, h12 = 0.19)
transitionList <- list(transitionCtl, transitionTrt)
avgHRExpOS(transitionByArm = transitionList, alpha = 0.5, upper = 100)
Helper Function for avgHRExpOS()
Description
It is an integrand of the form OS hazard function with intensities h01, h02, h12 at time point t multiplied with a weighted product of the two OS Survival functions at t (one for intensities h0 and one for h1).
Usage
avgHRIntegExpOS(x, h01, h02, h12, h0, h1, alpha)
Arguments
| x | ( | 
| h01 | (positive  | 
| h02 | (positive  | 
| h12 | (positive  | 
| h0 | ( | 
| h1 | ( | 
| alpha | ( | 
Value
This returns the value of the integrand used to calculate
the average hazard ratio for constant transition hazards, see avgHRExpOS().
Examples
h0 <- list(h01 = 0.18, h02 = 0.06, h12 = 0.17)
h1 <- list(h01 = 0.23, h02 = 0.07, h12 = 0.19)
avgHRIntegExpOS(x = 5, h01 = 0.2, h02 = 0.5, h12 = 0.7, h0 = h0, h1 = h1, alpha = 0.5)
Event-driven censoring.
Description
This function censors a study after a pre-specified number of events occurred.
Usage
censoringByNumberEvents(data, eventNum, typeEvent)
Arguments
| data | ( | 
| eventNum | ( | 
| typeEvent | ( | 
Value
This function returns a data set that is censored after eventNum of
typeEvent-events occurred.
Examples
transition1 <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 0.8, p02 = 0.9, p12 = 1)
transition2 <- weibull_transition(h01 = 1, h02 = 1.3, h12 = 1.7, p01 = 1.1, p02 = 0.9, p12 = 1.1)
simStudy <- getOneClinicalTrial(
  nPat = c(20, 20), transitionByArm = list(transition1, transition2),
  dropout = list(rate = 0.3, time = 10),
  accrual = list(param = "time", value = 7)
)
simStudyWide <- getDatasetWideFormat(simStudy)
censoringByNumberEvents(data = simStudyWide, eventNum = 20, typeEvent = "PFS")
Correlation of PFS and OS event times for data from the IDM
Description
Correlation of PFS and OS event times for data from the IDM
Usage
corPFSOS(
  data,
  transition,
  bootstrap = TRUE,
  bootstrap_n = 100,
  conf_level = 0.95
)
Arguments
| data | ( | 
| transition | ( | 
| bootstrap | ( | 
| bootstrap_n | ( | 
| conf_level | ( | 
Value
The correlation of PFS and OS.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
data <- getClinicalTrials(
  nRep = 1, nPat = c(100), seed = 1234, datType = "1rowTransition",
  transitionByArm = list(transition), dropout = list(rate = 0.5, time = 12),
  accrual = list(param = "intensity", value = 7)
)[[1]]
corPFSOS(data, transition = exponential_transition(), bootstrap = FALSE)
## Not run: 
corPFSOS(data, transition = exponential_transition(), bootstrap = TRUE)
## End(Not run)
Correlation of PFS and OS event times for Different Transition Models
Description
Correlation of PFS and OS event times for Different Transition Models
Usage
corTrans(transition)
Arguments
| transition | ( | 
Value
The correlation of PFS and OS.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
corTrans(transition)
Empirical Significance for a List of Simulated Trials
Description
This function computes four types of empirical significance — PFS, OS, at-least (significant in at least one of PFS/OS), and joint (significant in both PFS and OS) — using the log-rank test. Empirical significance is calculated as the proportion of significant results in simulated trials, each ending when a set number of PFS/OS events occur. Critical values for PFS and OS test significance must be specified. If trials simulate equal transition hazards across groups (H0), empirical significance estimates type I error; if they simulate differing transition hazards (H1), it estimates power.
Usage
empSignificant(simTrials, criticalPFS, criticalOS, eventNumPFS, eventNumOS)
Arguments
| simTrials | ( | 
| criticalPFS | (positive  | 
| criticalOS | (positive  | 
| eventNumPFS | ( | 
| eventNumOS | ( | 
Value
This returns values of four measures of empirical significance.
Examples
transition1 <- exponential_transition(h01 = 0.06, h02 = 0.3, h12 = 0.3)
transition2 <- exponential_transition(h01 = 0.1, h02 = 0.4, h12 = 0.3)
simTrials <- getClinicalTrials(
  nRep = 50, nPat = c(800, 800), seed = 1234, datType = "1rowPatient",
  transitionByArm = list(transition1, transition2), dropout = list(rate = 0.5, time = 12),
  accrual = list(param = "intensity", value = 7)
)
empSignificant(
  simTrials = simTrials, criticalPFS = 2.4, criticalOS = 2.2,
  eventNumPFS = 300, eventNumOS = 500
)
Estimate Parameters of the Multistate Model Using Clinical Trial Data
Description
Estimate Parameters of the Multistate Model Using Clinical Trial Data
Usage
estimateParams(data, transition)
Arguments
| data | ( | 
| transition | ( | 
Details
This function estimates parameters for transition models using clinical trial data.
The transition object can be initialized with starting values for parameter estimation.
It uses stats::optim() to optimize the parameters.
Value
Returns a TransitionParameters object with the estimated parameters.
Examples
transition <- exponential_transition(h01 = 2, h02 = 1.4, h12 = 1.6)
simData <- getOneClinicalTrial(
  nPat = c(30), transitionByArm = list(transition),
  dropout = list(rate = 0.3, time = 12),
  accrual = list(param = "time", value = 1)
)
# Initialize transition with desired starting values for optimization:
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
estimate <- estimateParams(simData, transition)
Transition Hazards for Exponential Event Times
Description
This creates a list with class TransitionParameters containing
hazards, time intervals and Weibull rates for exponential event times
in an illness-death model.
Usage
exponential_transition(h01 = 1, h02 = 1, h12 = 1)
Arguments
| h01 | (positive  | 
| h02 | (positive  | 
| h12 | (positive  | 
Value
List with elements hazards, intervals, weibull_rates and family
(exponential).
Examples
exponential_transition(1, 1.6, 0.3)
Helper Function for Computing E(OS^2)
Description
Helper Function for Computing E(OS^2)
Usage
expvalOSInteg(x, transition)
Arguments
| x | ( | 
| transition | ( | 
Value
Numeric results of the integrand used to calculate E(OS^2).
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
expvalOSInteg(0.4, transition)
Helper Function for Computing E(PFS^2)
Description
Helper Function for Computing E(PFS^2)
Usage
expvalPFSInteg(x, transition)
Arguments
| x | ( | 
| transition | ( | 
Value
Numeric results of the integrand used to calculate E(PFS^2).
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
expvalPFSInteg(0.4, transition)
Helper function for censoringByNumberEvents
Description
Helper function for censoringByNumberEvents
Usage
getCensoredData(time, event, data)
Arguments
| time | ( | 
| event | ( | 
| data | ( | 
Value
This function returns a data frame with columns: event time, censoring indicator, event indicator and event time in calendar time.
Examples
transition1 <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 0.8, p02 = 0.9, p12 = 1)
transition2 <- weibull_transition(h01 = 1, h02 = 1.3, h12 = 1.7, p01 = 1.1, p02 = 0.9, p12 = 1.1)
simStudy <- getOneClinicalTrial(
  nPat = c(20, 20), transitionByArm = list(transition1, transition2),
  dropout = list(rate = 0.3, time = 10),
  accrual = list(param = "time", value = 7)
)
simStudyWide <- getDatasetWideFormat(simStudy)
simStudyWide$censTimeInd <- 5 - simStudyWide$recruitTime
NotRecruited <- simStudyWide$id[simStudyWide$censTimeInd < 0]
censoredData <- simStudyWide[!(simStudyWide$id %in% NotRecruited), ]
getCensoredData(time = censoredData$OStime, event = censoredData$OSevent, data = censoredData)
Simulation of a Large Number of Oncology Clinical Trials
Description
Simulation of a Large Number of Oncology Clinical Trials
Usage
getClinicalTrials(nRep, ..., seed = 1234, datType = "1rowTransition")
Arguments
| nRep | ( | 
| ... | parameters transferred to  | 
| seed | ( | 
| datType | ( | 
Value
This function returns a list with nRep simulated data sets in the format specified by datType.
See getDatasetWideFormat() getOneClinicalTrial() for details.
Examples
transition1 <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
transition2 <- exponential_transition(h01 = 1, h02 = 1.3, h12 = 1.7)
getClinicalTrials(
  nRep = 10, nPat = c(20, 20), seed = 1234, datType = "1rowTransition",
  transitionByArm = list(transition1, transition2), dropout = list(rate = 0.5, time = 12),
  accrual = list(param = "intensity", value = 7)
)
Conversion of a Data Set from One Row per Transition to One Row per Patient
Description
Conversion of a Data Set from One Row per Transition to One Row per Patient
Usage
getDatasetWideFormat(data)
Arguments
| data | ( | 
Details
The output data set contains the following columns:
- id ( - integer): patient id.
- trt - integer): treatment id.
- PFStime ( - numeric): event time of PFS event.
- CensoredPFS ( - logical): censoring indicator for PFS event.
- PFSevent ( - logical): event indicator for PFS event.
- OStime ( - numeric): event time of OS event.
- CensoredOS ( - logical): censoring indicator for OS event.
- OSevent ( - logical): event indicator for OS event.
- recruitTime ( - numeric): time of recruitment.
- OStimeCal ( - numeric): OS event time at calendar time scale.
- PFStimeCal ( - numeric): PFS event time at calendar time scale.
Value
This function returns a data set with one row per patient and endpoints PFS and OS.
Examples
transition1 <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
transition2 <- exponential_transition(h01 = 1, h02 = 1.3, h12 = 1.7)
transition3 <- exponential_transition(h01 = 1.1, h02 = 1, h12 = 1.5)
simData <- getOneClinicalTrial(
  nPat = c(30, 20, 30), transitionByArm = list(transition1, transition2, transition3),
  dropout = list(rate = 0, time = 12),
  accrual = list(param = "time", value = 0)
)
getDatasetWideFormat(simData)
Number of recruited/censored/ongoing Patients.
Description
Number of recruited/censored/ongoing Patients.
Usage
getEventsAll(data, t)
Arguments
| data | ( | 
| t | ( | 
Value
This function returns number of recruited patients, number of censored and number of patients under observations.
Examples
transition1 <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 0.8, p02 = 0.9, p12 = 1)
transition2 <- weibull_transition(h01 = 1, h02 = 1.3, h12 = 1.7, p01 = 1.1, p02 = 0.9, p12 = 1.1)
simStudy <- getOneClinicalTrial(
  nPat = c(20, 20), transitionByArm = list(transition1, transition2),
  dropout = list(rate = 0.6, time = 10),
  accrual = list(param = "time", value = 0)
)
simStudyWide <- getDatasetWideFormat(simStudy)
getEventsAll(data = simStudyWide, t = 1.5)
Retrieve Initial Parameter Vectors for Likelihood Maximization
Description
Retrieve Initial Parameter Vectors for Likelihood Maximization
Usage
getInit(transition)
## S3 method for class 'ExponentialTransition'
getInit(transition)
## S3 method for class 'WeibullTransition'
getInit(transition)
Arguments
| transition | ( | 
Value
The numeric vector of initial parameters for likelihood maximization.
Methods (by class)
-  getInit(ExponentialTransition): for the Exponential Transition Model
-  getInit(WeibullTransition): for the Weibull Transition Model
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
getInit(transition)
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
getInit(transition)
transition <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 2, p02 = 2.5, p12 = 3)
getInit(transition)
Helper Function for trackEventsPerTrial
Description
Helper Function for trackEventsPerTrial
Usage
getNumberEvents(event, time, t)
Arguments
| event | ( | 
| time | ( | 
| t | ( | 
Value
This function returns the number of events occurred until time t.
Examples
event <- c(0, 1, 1, 1, 0)
time <- c(3, 3.4, 5, 6, 5.5)
getNumberEvents(event = event, time = time, t = 5)
Simulation of a Single Oncology Clinical Trial
Description
This function creates a data set with a single simulated oncology clinical trial with one row per transition based on an illness-death model. Studies with an arbitrary number of treatment arms are possible.
Usage
getOneClinicalTrial(
  nPat,
  transitionByArm,
  dropout = list(rate = 0, time = 12),
  accrual = list(param = "time", value = 0)
)
Arguments
| nPat | ( | 
| transitionByArm | ( | 
| dropout | dropout ( | 
| accrual | accrual ( | 
Value
This returns a data frame with one simulated clinical trial and multiple treatment arms.
See getSimulatedData() for the explanation of the columns. The column trt contains the treatment indicator.
This is a helper function of getClinicalTrials().
Examples
transition1 <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
transition2 <- exponential_transition(h01 = 1, h02 = 1.3, h12 = 1.7)
transition3 <- exponential_transition(h01 = 1.1, h02 = 1, h12 = 1.5)
getOneClinicalTrial(
  nPat = c(30, 20, 30), transitionByArm = list(transition1, transition2, transition3),
  dropout = list(rate = 0, time = 12),
  accrual = list(param = "time", value = 0)
)
Transitions from the Intermediate State to the Absorbing State
Description
This function creates transition entry and exit times from the intermediate state to the absorbing state for an existing data frame containing the exit times out of the initial state.
Usage
getOneToTwoRows(simDataOne, transition)
Arguments
| simDataOne | ( | 
| transition | ( | 
Value
This returns a data frame with one row per patient for the second transition,
i.e. the transition out of the intermediate
state. This is a helper function of getSimulatedData().
Examples
simDataOne <- data.frame(
  id = c(1:3), to = c(1, 1, 1), from = c(0, 0, 0), entry = c(0, 0, 0),
  exit = c(3, 5.6, 7.2), censTime = c(6.8, 5.9, 9.4)
)
transition <- exponential_transition(1, 1.6, 0.3)
getOneToTwoRows(simDataOne, transition)
Piecewise Exponentially Distributed Event Times
Description
This returns event times with a distribution resulting from piece-wise constant hazards using the inversion method.
Usage
getPCWDistr(U, haz, pw, t_0)
Arguments
| U | ( | 
| haz | ( | 
| pw | ( | 
| t_0 | ( | 
Value
This returns a vector with event times.
Examples
getPCWDistr(U = runif(3), haz = c(1.1, 0.5, 0.4), pw = c(0, 7, 10), t_0 = c(0, 1, 4.2))
Piecewise Constant Hazard Values
Description
This returns piecewise constant hazard values at specified time points.
Usage
getPWCHazard(haz, pw, x)
Arguments
| haz | ( | 
| pw | ( | 
| x | ( | 
Value
Hazard values at input time-points.
Examples
getPWCHazard(c(1, 1.2, 1.4), c(0, 2, 3), c(1, 4, 6))
Format Results of Parameter Estimation for Different Transition Models
Description
Format Results of Parameter Estimation for Different Transition Models
Usage
getResults(transition, res)
## S3 method for class 'ExponentialTransition'
getResults(transition, res)
## S3 method for class 'WeibullTransition'
getResults(transition, res)
Arguments
| transition | ( | 
| res | ( | 
Value
Returns a TransitionParameters object with parameter estimates.
Methods (by class)
-  getResults(ExponentialTransition): for the Exponential Transition Model
-  getResults(WeibullTransition): for the Weibull Transition Model
Examples
results <- c(1.2, 1.5, 1.6)
getResults(exponential_transition(), results)
results <- c(1.2, 1.5, 1.6)
getResults(exponential_transition(), results)
results <- c(1.2, 1.5, 1.6, 2, 2.5, 1)
getResults(weibull_transition(), results)
Simulate Data Set from an Illness-Death Model
Description
This function creates a single simulated data set for a single treatment arm. It simulates data from an illness-death model with one row per transition and subject.
Usage
getSimulatedData(
  N,
  transition = exponential_transition(h01 = 1, h02 = 1, h12 = 1),
  dropout = list(rate = 0, time = 12),
  accrual = list(param = "time", value = 0)
)
Arguments
| N | ( | 
| transition | ( | 
| dropout | ( | 
| accrual | ( | 
Details
The output data set contains the following columns:
- id ( - integer): patient id.
- from ( - numeric): starting state of the transition.
- to ( - character): final state of the transition.
- entry ( - numeric): entry time of the transition on the individual time scale.
- exit ( - numeric): exit time of the transition on the individual time scale.
- entryAct ( - numeric): entry time of the transition on study time scale.
- exitAct ( - numeric): exit time of the transition on study time scale.
- censAct ( - numeric): censoring time of the individual on study time scale.
Value
This returns a data frame with one row per transition per individual.
Examples
getSimulatedData(
  N = 10,
  transition = exponential_transition(h01 = 1, h02 = 1.5, h12 = 1),
  dropout = list(rate = 0.3, time = 1),
  accrual = list(param = "time", value = 5)
)
Sum of Two Piecewise Constant Hazards
Description
This returns the sum of two piecewise constant hazards per interval.
Usage
getSumPCW(haz1, haz2, pw1, pw2)
Arguments
| haz1 | ( | 
| haz2 | ( | 
| pw1 | ( | 
| pw2 | ( | 
Value
List with elements hazards and intervals for the sum of two piecewise constant hazards.
Examples
getSumPCW(c(1.2, 0.3, 0.6), c(1.2, 0.7, 1), c(0, 8, 9), c(0, 1, 4))
Generate the Target Function for Optimization
Description
Generate the Target Function for Optimization
Usage
getTarget(transition)
## S3 method for class 'ExponentialTransition'
getTarget(transition)
## S3 method for class 'WeibullTransition'
getTarget(transition)
Arguments
| transition | ( | 
Details
This function creates a target function for optimization, computing the negative log-likelihood for given parameters, data, and transition model type.
Value
Function that calculates the negative log-likelihood for the given parameters.
Methods (by class)
-  getTarget(ExponentialTransition): for the Exponential Transition Model
-  getTarget(WeibullTransition): for the Weibull Transition Model
Examples
transition <- exponential_transition(2, 1.3, 0.8)
simData <- getOneClinicalTrial(
  nPat = c(30), transitionByArm = list(transition),
  dropout = list(rate = 0.8, time = 12),
  accrual = list(param = "time", value = 1)
)
params <- c(1.2, 1.5, 1.6) # For ExponentialTransition
data <- prepareData(simData)
transition <- exponential_transition()
fun <- getTarget(transition)
fun(params, data)
transition <- exponential_transition(2, 1.3, 0.8)
simData <- getOneClinicalTrial(
  nPat = c(30), transitionByArm = list(transition),
  dropout = list(rate = 0.8, time = 12),
  accrual = list(param = "time", value = 1)
)
params <- c(1.2, 1.5, 1.6)
data <- prepareData(simData)
transition <- exponential_transition()
target <- getTarget(transition)
target(params, data)
transition <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 2, p02 = 2.5, p12 = 3)
simData <- getOneClinicalTrial(
  nPat = c(30), transitionByArm = list(transition),
  dropout = list(rate = 0.8, time = 12),
  accrual = list(param = "time", value = 1)
)
params <- c(1.2, 1.5, 1.6, 0.8, 1.3, 1.1)
data <- prepareData(simData)
transition <- weibull_transition()
target <- getTarget(transition)
target(params, data)
Time-point by which a specified number of events occurred.
Description
This returns the study time-point by which a specified number of events (PFS or OS) occurred.
Usage
getTimePoint(data, eventNum, typeEvent, byArm = FALSE)
Arguments
| data | ( | 
| eventNum | ( | 
| typeEvent | ( | 
| byArm | ( | 
Value
This returns  the time-point by which eventNum of typeEvent-events occurred.
Examples
transition1 <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 0.8, p02 = 0.9, p12 = 1)
transition2 <- weibull_transition(h01 = 1, h02 = 1.3, h12 = 1.7, p01 = 1.1, p02 = 0.9, p12 = 1.1)
simStudy <- getOneClinicalTrial(
  nPat = c(20, 20), transitionByArm = list(transition1, transition2),
  dropout = list(rate = 0.3, time = 10),
  accrual = list(param = "time", value = 0)
)
simStudyWide <- getDatasetWideFormat(simStudy)
getTimePoint(simStudyWide, eventNum = 10, typeEvent = "OS", byArm = FALSE)
Event Times Distributed as Sum of Weibull
Description
This returns event times with a distribution resulting from the sum of two Weibull distributed random variables using the inversion method.
Usage
getWaitTimeSum(U, haz1, haz2, p1, p2, entry)
Arguments
| U | ( | 
| haz1 | (positive  | 
| haz2 | (positive  | 
| p1 | (positive  | 
| p2 | (positive  | 
| entry | ( | 
Value
This returns a vector with event times.
Examples
getWaitTimeSum(U = c(0.4, 0.5), haz1 = 0.8, haz2 = 1, p1 = 1.1, p2 = 1.5, entry = c(0, 0))
Hazard Function for Different Transition Models
Description
Hazard Function for Different Transition Models
Usage
haz(transition, t, trans)
## S3 method for class 'ExponentialTransition'
haz(transition, t, trans)
## S3 method for class 'WeibullTransition'
haz(transition, t, trans)
## S3 method for class 'PWCTransition'
haz(transition, t, trans)
Arguments
| transition | ( | 
| t | ( | 
| trans | ( | 
Details
The transition types are:
-  1: Transition from state 0 (stable) to 1 (progression).
-  2: Transition from state 0 (stable) to 2 (death).
-  3: Transition from state 1 (progression) to 2 (death).
Value
The hazard rate for the specified transition and time.
Methods (by class)
-  haz(ExponentialTransition): for an exponential transition model.
-  haz(WeibullTransition): for the Weibull transition model.
-  haz(PWCTransition): for the piecewise constant transition model.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
haz(transition, 0.4, 2)
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
haz(transition, 0.4, 2)
transition <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 2, p02 = 2.5, p12 = 3)
haz(transition, 0.4, 2)
transition <- piecewise_exponential(
  h01 = c(1, 1, 1), h02 = c(1.5, 0.5, 1), h12 = c(1, 1, 1),
  pw01 = c(0, 3, 8), pw02 = c(0, 6, 7), pw12 = c(0, 8, 9)
)
haz(transition, 6, 2)
Helper for Efficient Integration
Description
Helper for Efficient Integration
Usage
integrateVector(integrand, upper, ...)
Arguments
| integrand | ( | 
| upper | ( | 
| ... | additional arguments to be passed to  | 
Value
This function returns for each upper limit the estimates of the integral.
Log-Rank Test for a Single Trial
Description
This function evaluates the significance of either PFS or OS endpoints in a trial, based on a pre-specified critical value.
Usage
logRankTest(data, typeEvent = c("PFS", "OS"), critical)
Arguments
| data | ( | 
| typeEvent | ( | 
| critical | (positive  | 
Value
Logical value indicating log-rank test significance.
Examples
transition1 <- exponential_transition(h01 = 0.06, h02 = 0.3, h12 = 0.3)
transition2 <- exponential_transition(h01 = 0.1, h02 = 0.4, h12 = 0.3)
simTrial <- getClinicalTrials(
  nRep = 1, nPat = c(800, 800), seed = 1234, datType = "1rowPatient",
  transitionByArm = list(transition1, transition2), dropout = list(rate = 0.5, time = 12),
  accrual = list(param = "intensity", value = 7)
)[[1]]
logRankTest(data = simTrial, typeEvent = "OS", critical = 3.4)
Probability of Remaining in Progression Between Two Time Points for Different Transition Models
Description
Probability of Remaining in Progression Between Two Time Points for Different Transition Models
Usage
log_p11(transition, s, t)
Arguments
| transition | ( | 
| s | ( | 
| t | ( | 
Value
This returns the natural logarithm of the probability of remaining in progression (state 1) between two time points, conditional on being in state 1 at the lower time point.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
log_p11(transition, 1, 3)
Compute the Negative Log-Likelihood for a Given Data Set and Transition Model
Description
Compute the Negative Log-Likelihood for a Given Data Set and Transition Model
Usage
negLogLik(transition, data)
Arguments
| transition | ( | 
| data | ( | 
Details
Calculates the negative log-likelihood for a given data set and transition model. It uses the hazard and survival functions specific to the transition model.
Value
The value of the negative log-likelihood.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
simData <- getOneClinicalTrial(
  nPat = c(30), transitionByArm = list(transition),
  dropout = list(rate = 0.8, time = 12),
  accrual = list(param = "time", value = 1)
)
negLogLik(transition, prepareData(simData))
Helper Function for log_p11()
Description
Helper Function for log_p11()
Usage
p11Integ(x, transition)
Arguments
| x | ( | 
| transition | ( | 
Value
Hazard rate at the specified time for the transition from progression to death.
Helper function to conduct log-rank tests for either PFS or OS
Description
This function evaluates the significance of either PFS or OS endpoints for each trial in a list of trials, based on a pre-specified critical value.
Usage
passedLogRank(simTrials, typeEvent, eventNum, critical)
Arguments
| simTrials | ( | 
| typeEvent | ( | 
| eventNum | ( | 
| critical | (positive  | 
Value
Logical vector indicating log-rank test significance for each trial.
Examples
transition1 <- exponential_transition(h01 = 0.06, h02 = 0.3, h12 = 0.3)
transition2 <- exponential_transition(h01 = 0.1, h02 = 0.4, h12 = 0.3)
simTrials <- getClinicalTrials(
  nRep = 50, nPat = c(800, 800), seed = 1234, datType = "1rowPatient",
  transitionByArm = list(transition1, transition2), dropout = list(rate = 0.5, time = 12),
  accrual = list(param = "intensity", value = 7)
)
passedLogRank(simTrials = simTrials, typeEvent = "PFS", eventNum = 300, critical = 2.4)
Transition Hazards for Piecewise Exponential Event Times
Description
This creates a list with class TransitionParameters containing
hazards, time intervals and Weibull rates for piecewise exponential event times
in an illness-death model.
Usage
piecewise_exponential(h01, h02, h12, pw01, pw02, pw12)
Arguments
| h01 | ( | 
| h02 | ( | 
| h12 | ( | 
| pw01 | ( | 
| pw02 | ( | 
| pw12 | ( | 
Value
List with elements hazards, intervals, weibull_rates and family
(piecewise exponential).
Examples
piecewise_exponential(
  h01 = c(1, 1, 1), h02 = c(1.5, 0.5, 1), h12 = c(1, 1, 1),
  pw01 = c(0, 3, 8), pw02 = c(0, 6, 7), pw12 = c(0, 8, 9)
)
Preparation of a Data Set to Compute Log-likelihood
Description
Preparation of a Data Set to Compute Log-likelihood
Usage
prepareData(data)
Arguments
| data | ( | 
Details
The output data set contains the following columns:
- id ( - integer): patient id.
- from ( - integer): start event state.
- to ( - integer): end event state.
- trans ( - integer): transition (1, 2 or 3) identifier-  1: Transition from state 0 (stable) to 1 (progression).
-  2: Transition from state 0 (stable) to 2 (death).
-  3: Transition from state 1 (progression) to 2 (death).
 
-  
- entry ( - numeric): time at which the patient begins to be at risk for the transition.
- exit ( - numeric): time at which the patient ends to be at risk for the transition.
- status ( - logical): event indicator for the transition.
Value
This function returns a data set with one row per patient and transition, when the patient is at risk.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
simData <- getOneClinicalTrial(
  nPat = c(30), transitionByArm = list(transition),
  dropout = list(rate = 0.8, time = 12),
  accrual = list(param = "time", value = 1)
)
prepareData(simData)
Cumulative Hazard for Piecewise Constant Hazards
Description
Cumulative Hazard for Piecewise Constant Hazards
Usage
pwA(t, haz, pw)
Arguments
| t | ( | 
| haz | ( | 
| pw | ( | 
Value
This returns the value of cumulative hazard at time t.
Examples
pwA(1:5, c(0.5, 0.9), c(0, 4))
Helper Function for Adding Progress Bar to Trial Simulation
Description
Helper Function for Adding Progress Bar to Trial Simulation
Usage
runTrial(x, pb, ...)
Arguments
| x | ( | 
| ... | parameters transferred to  | 
Value
This returns the same as getOneClinicalTrial(), but updates the progress bar.
Helper Function for Single Quantile for OS Survival Function
Description
Helper Function for Single Quantile for OS Survival Function
Usage
singleExpQuantOS(q, h01, h02, h12)
Arguments
| q | ( | 
| h01 | ( | 
| h02 | ( | 
| h12 | ( | 
Value
Single time t such that the OS survival function at t equals q.
OS Survival Function for Different Transition Models
Description
OS Survival Function for Different Transition Models
Usage
survOS(transition, t)
## S3 method for class 'ExponentialTransition'
survOS(transition, t)
## S3 method for class 'WeibullTransition'
survOS(transition, t)
## S3 method for class 'PWCTransition'
survOS(transition, t)
Arguments
| transition | ( | 
| t | ( | 
Value
The value of the survival function for the specified transition and time.
Methods (by class)
-  survOS(ExponentialTransition): Survival Function for an exponential transition model.
-  survOS(WeibullTransition): Survival Function for a Weibull transition model.
-  survOS(PWCTransition): Survival Function for a piecewise constant transition model.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
survOS(transition, 0.4)
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
survOS(transition, 0.4)
transition <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 2, p02 = 2.5, p12 = 3)
survOS(transition, 0.4)
transition <- piecewise_exponential(
  h01 = c(1, 1, 1), h02 = c(1.5, 0.5, 1), h12 = c(1, 1, 1),
  pw01 = c(0, 3, 8), pw02 = c(0, 6, 7), pw12 = c(0, 8, 9)
)
survOS(transition, 0.4)
PFS Survival Function for Different Transition Models
Description
PFS Survival Function for Different Transition Models
Usage
survPFS(transition, t)
## S3 method for class 'ExponentialTransition'
survPFS(transition, t)
## S3 method for class 'WeibullTransition'
survPFS(transition, t)
## S3 method for class 'PWCTransition'
survPFS(transition, t)
Arguments
| transition | ( | 
| t | ( | 
Value
The value of the survival function for the specified transition and time.
Methods (by class)
-  survPFS(ExponentialTransition): Survival Function for an exponential transition model.
-  survPFS(WeibullTransition): Survival Function for a Weibull transition model.
-  survPFS(PWCTransition): Survival Function for a piecewise constant transition model.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
survPFS(transition, 0.4)
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
survPFS(transition, 0.4)
transition <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 2, p02 = 2.5, p12 = 3)
survPFS(transition, 0.4)
transition <- piecewise_exponential(
  h01 = c(1, 1, 1), h02 = c(1.5, 0.5, 1), h12 = c(1, 1, 1),
  pw01 = c(0, 3, 8), pw02 = c(0, 6, 7), pw12 = c(0, 8, 9)
)
survPFS(transition, 0.4)
Survival Function of the Product PFS*OS for Different Transition Models
Description
Survival Function of the Product PFS*OS for Different Transition Models
Usage
survPFSOS(t, transition)
Arguments
| t | ( | 
| transition | ( | 
Value
This returns the value of PFS*OS survival function at time t.
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
survPFSOS(0.4, transition)
Survival Function for Different Transition Models
Description
Survival Function for Different Transition Models
Usage
survTrans(transition, t, trans)
## S3 method for class 'ExponentialTransition'
survTrans(transition, t, trans)
## S3 method for class 'WeibullTransition'
survTrans(transition, t, trans)
Arguments
| transition | ( | 
| t | ( | 
| trans | ( | 
Value
The survival probability for the specified transition and time.
Methods (by class)
-  survTrans(ExponentialTransition): for the Exponential Transition Model
-  survTrans(WeibullTransition): for the Weibull Transition Model
Examples
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
survTrans(transition, 0.4, 2)
transition <- exponential_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6)
survTrans(transition, 0.4, 2)
transition <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 2, p02 = 2.5, p12 = 3)
survTrans(transition, 0.4, 2)
Event tracking in an oncology trial.
Description
Event tracking in an oncology trial.
Usage
trackEventsPerTrial(data, timeP, byArm = FALSE)
Arguments
| data | ( | 
| timeP | ( | 
| byArm | ( | 
Value
This function returns a data frame including number of PFS events, number of OS events,
number of recruited patients, number of censored patients and number of ongoing patients at timeP.
Examples
transition1 <- weibull_transition(h01 = 1.2, h02 = 1.5, h12 = 1.6, p01 = 0.8, p02 = 0.9, p12 = 1)
transition2 <- weibull_transition(h01 = 1, h02 = 1.3, h12 = 1.7, p01 = 1.1, p02 = 0.9, p12 = 1.1)
simStudy <- getOneClinicalTrial(
  nPat = c(20, 20), transitionByArm = list(transition1, transition2),
  dropout = list(rate = 0.3, time = 10),
  accrual = list(param = "time", value = 0)
)
simStudyWide <- getDatasetWideFormat(simStudy)
trackEventsPerTrial(data = simStudyWide, timeP = 1.5, byArm = FALSE)
Transition Hazards for Weibull Distributed Event Times
Description
This creates a list with class TransitionParameters containing
hazards, time intervals and Weibull rates for Weibull distributed event times
in an illness-death model.
Usage
weibull_transition(h01 = 1, h02 = 1, h12 = 1, p01 = 1, p02 = 1, p12 = 1)
Arguments
| h01 | (positive  | 
| h02 | (positive  | 
| h12 | (positive  | 
| p01 | (positive  | 
| p02 | (positive  | 
| p12 | (positive  | 
Value
List with elements hazards, intervals, weibull_rates and family
(Weibull).
Examples
weibull_transition(h01 = 1, h02 = 1.3, h12 = 0.5, p01 = 1.2, p02 = 1.3, p12 = 0.5)