| sim_brar_binary {RARtrials} | R Documentation | 
Simulate a Trial Using Bayesian Response-Adaptive Randomization with a Control Group for Binary Outcomes
Description
sim_brar_binary simulate a trial with two to five arms using Bayesian Response-Adaptive 
Randomization with a control group for binary outcomes. The conjugate prior distributions follow Beta
(Beta(\alpha,\beta)) distributions and can be specified individually for each arm.
Usage
sim_brar_binary(
  Pats,
  nMax,
  TimeToOutcome,
  enrollrate,
  N1,
  armn,
  h,
  au,
  N2,
  tp,
  armlabel,
  blocksize,
  alpha1 = 1,
  beta1 = 1,
  alpha2 = alpha1,
  beta2 = beta1,
  alpha3 = alpha1,
  beta3 = beta1,
  alpha4 = alpha1,
  beta4 = beta1,
  alpha5 = alpha1,
  beta5 = beta1,
  minstart,
  deltaa,
  tpp = 0,
  deltaa1,
  side,
  ...
)
Arguments
| Pats | the number of patients accrued within a certain time frame indicates the count of individuals who have been affected by the disease during that specific period, for example, a month or a day. If this number is 10, it represents that 10 people have got the disease within the specified time frame. | 
| nMax | the assumed maximum accrued number of patients with the disease in the population, this number should be chosen carefully to ensure a sufficient number of patients are simulated, especially when considering the delay mechanism. | 
| TimeToOutcome | the distribution of delayed response times or a fixed delay time for responses. The delayed time could be a month, a week or any other time frame. When the unit changes, the number of TimeToOutcome should also change. It can be in the format of expression(rnorm( length( vStartTime ),30, 3)), representing delayed responses with a normal distribution, where the mean is 30 days and the standard deviation is 3 days. | 
| enrollrate | probability that patients in the population can enroll in the trial. This parameter is related to the number of people who have been affected by the disease in the population, following an exponential distribution. | 
| N1 | number of participants with equal randomization in the 'initialization' period. Recommend using 10 percent of the total sample size. | 
| armn | number of total arms in the trial. | 
| h | a vector of success probabilities in hypotheses, for example, as c(0.1,0.1) where 0.1 stands for the success probability for both groups. Another example is c(0.1,0.3) where 0.1 and 0.3 stand for the success probabilities for the control and the treatment group, respectively. | 
| au | a vector of cut-off values in the final selection at the end of the trial, with a length equal to the number of arms minus 1. | 
| N2 | maximal sample size for the trial. | 
| tp | tuning parameter. Some commonly used numbers are 0.5, 1 and n/2N. | 
| armlabel | a vector of arm labels with an example of c(1, 2), where 1 and 2 describe how each arm is labeled in a two-armed trial. | 
| blocksize | size of block used for equal randomization regarding participants in the 'initialization' period. Recommend to be an even multiple of the number of total arms. | 
| alpha1,beta1 | 
 | 
| alpha2,beta2 | 
 | 
| alpha3,beta3 | 
 | 
| alpha4,beta4 | 
 | 
| alpha5,beta5 | 
 | 
| minstart | a specified number of participants when one starts to check decision rules. | 
| deltaa | a vector of minimal effect expected to be observed for early futility stopping in
each arm is approximately  | 
| tpp | indicator of  | 
| deltaa1 | a vector of pre-specified minimal effect size expected to be observed at the final stage
for each arm. The length of this parameter is  | 
| side | direction of a one-sided test, with values 'upper' or 'lower'. | 
| ... | additional arguments to be passed to  | 
Details
This function generates a designed trial using Bayesian response-adaptive randomization with
a control group under no delay and delayed scenarios for binary outcomes. The function can handle trials with up to
5 arms. This function uses the formula
\frac{Pr(p_k=max\{p_1,...,p_K\})^{tp}} {\sum_{k=1}^{K}{Pr(p_k=max\{p_1,...,p_K\})^{tp}}} with side equals to 'upper',
and \frac{Pr(p_k=min\{p_1,...,p_K\})^{tp}} {\sum_{k=1}^{K}{Pr(p_k=min\{p_1,...,p_K\}){tp}}} 
with side equals to 'lower', utilizing available data at each step.
Considering the delay mechanism, Pats (the number of patients accrued within a certain time frame),
nMax (the assumed maximum accrued number of patients with the disease in the population) and 
TimeToOutcome (the distribution of delayed response times or a fixed delay time for responses) 
are parameters in the functions adapted from https://github.com/kwathen/IntroBayesianSimulation.
Refer to the website for more details.
Value
sim_brar_binary returns an object of class "brar". An object of class "brar" is a list containing 
final decision, test statistics, the simulated data set and participants accrued for each arm 
at the time of termination of that group in one trial.
The simulated data set includes 5 columns: participant ID number, enrollment time, observed time of results,
allocated arm, and participants' results. In the final decision, 'Superiorityfinal' refers to the selected arm, 
while 'Not Selected' indicates the arm stopped due to futility, and 'Control Selected' denotes the control arm chosen 
because other arms did not meet futility criteria before the final stage or were not deemed effective at the final stage. 
Note that before final stage of the trial, test statistics is calculated from deltaa, and test statistics is
calculated from deltaa1 at the final stage.
References
Wathen J, Thall P (2017). “A simulation study of outcome adaptive randomization in multi-arm clinical trials.” Clinical Trials, 14, 174077451769230. doi:10.1177/1740774517692302.
Examples
#sim_brar_binary with delayed responses follow a normal distribution with a mean
#of 30 days and a standard deviation of 3 days, where h1=c(0.2,0.4) and tp=0.5.
sim_brar_binary(Pats=10,nMax=50000,TimeToOutcome=expression(rnorm( length( vStartTime ),30, 3)),
enrollrate=0.1,N1=24,armn=2,h=c(0.2,0.4),au=0.36,N2=224,tp=0.5,armlabel=c(1,2),blocksize=4,
alpha1=1,beta1=1,alpha2=1,beta2=1,minstart=24,deltaa=-0.01,tpp=0,deltaa1=0.1,side='upper')