The following script demonstrates the RBesT library to reproduce the main results from Schmidli et. al, Biometrics 70, 1024, 2014.
The two main ideas of the paper are
use mixture priors to approximate accuratley numerical MCMC MAP priors
robustify informative MAP priors by adding a suitable non-informative component to the informative MAP prior
As example an adaptive design for a binomial endpoint is considered:
Stage 1: mI in test treatment and nI in control (e.g., mI = 20, nI = 15);
Stage 2: (m - mI ) in test treatment and max(n - ESSI, nmin) in control (e.g., nmin = 5).
| pc | 0.3_beta | 0.3_mix50 | 0.3_mix90 | 0.3_unif | 0_beta | 0_mix50 | 0_mix90 | 0_unif | 
|---|---|---|---|---|---|---|---|---|
| 0.1 | 81.5 | 83.4 | 82.1 | 88.9 | 0.1 | 0.3 | 0.1 | 1.8 | 
| 0.2 | 87.2 | 81.7 | 85.2 | 79.8 | 1.7 | 1.9 | 1.7 | 2.4 | 
| 0.3 | 93.2 | 79.6 | 86.6 | 77.3 | 6.1 | 4.1 | 5.6 | 2.3 | 
| 0.4 | 97.9 | 78.3 | 84.0 | 78.6 | 13.4 | 4.9 | 9.6 | 2.3 | 
| 0.5 | 99.7 | 81.1 | 81.1 | 81.2 | 26.1 | 4.1 | 10.5 | 2.7 | 
| 0.6 | 100.0 | 88.8 | 86.7 | 88.4 | 44.9 | 3.1 | 6.7 | 2.7 | 
| pc | 0.3_beta | 0.3_mix50 | 0.3_mix90 | 0.3_unif | 0_beta | 0_mix50 | 0_mix90 | 0_unif | 
|---|---|---|---|---|---|---|---|---|
| 0.1 | 20 | 25.1 | 20.7 | 38 | 20 | 25.1 | 20.7 | 38 | 
| 0.2 | 20 | 25.5 | 20.9 | 38 | 20 | 25.5 | 20.9 | 38 | 
| 0.3 | 20 | 28.9 | 21.7 | 38 | 20 | 28.9 | 21.7 | 38 | 
| 0.4 | 20 | 33.7 | 23.8 | 38 | 20 | 33.7 | 23.8 | 38 | 
| 0.5 | 20 | 37.5 | 27.5 | 38 | 20 | 37.5 | 27.5 | 38 | 
| 0.6 | 20 | 38.9 | 32.3 | 38 | 20 | 38.9 | 32.3 | 38 | 
Reproduction of Fig. 1 in Robust MAP Prior paper.
The bias and rMSE calculations are slightly involved as the sample size depends on the first stage.
Clinical example to exemplify the methodology.
## set seed to guarantee exact reproducible results
set.seed(25445)
map <- gMAP(cbind(r, n-r) ~ 1 | study,
            family=binomial,
            data=colitis,
            tau.dist="HalfNormal",
            beta.prior=2,
            tau.prior=1)## Assuming default prior location   for beta: 0map_auto <- automixfit(map)
## advanced: look at AIC of all fitted models
sapply(attr(map_auto, "models"), AIC)##          4          3          2          1 
## -11034.302 -11020.331 -10928.488  -9598.992print(map_auto)## EM for Beta Mixture Model
## Log-Likelihood = 5528.151
## 
## Univariate beta mixture
## Mixture Components:
##   comp1        comp2        comp3        comp4       
## w   0.48293993   0.35580282   0.12639836   0.03485889
## a   3.12704084  16.01896253   2.54798384   0.72394162
## b  25.25039063 127.79019632   9.28599276   1.45985258## use best fitting mixture model as prior
prior <- map_auto
pl <- plot(prior)
pl$mix + ggtitle("MAP prior for ulcerative colitis")Colitis MAPs from paper for further figures.
mapCol <- list(
    one = mixbeta(c(1,2.3,16)),
    two = mixbeta(c(0.77, 6.2, 50.8), c(1-0.77, 1.0, 4.7)),
    three = mixbeta(c(0.53, 2.5, 19.1), c(0.38, 14.6, 120.2), c(0.08, 0.9, 2.9))
    )## Warning in mixdist3(...): Weights do not sum to 1. Rescaling accordingly.mapCol <- c(mapCol, list(twoRob=robustify(mapCol$two, weight=0.1, mean=1/2),
                         threeRob=robustify(mapCol$three, weight=0.1, mean=1/2)
                         )
            )Posterior for different remission rates, Figure 3
N <- 20
post <- foreach(prior=names(mapCol), .combine=rbind) %do% {
    res <- data.frame(mean=rep(NA, N+1), sd=0, r=0:N)
    for(r in 0:N) {
        res[r+1,1:2] <- summary(postmix(mapCol[[prior]], r=r, n=N))[c("mean", "sd")]
    }
    res$prior <- prior
    res
}
qplot(r, mean, data=post, colour=prior, shape=prior) + geom_abline(slope=1/20)qplot(r, sd, data=post, colour=prior, shape=prior) + coord_cartesian(ylim=c(0,0.17))sessionInfo()## R version 3.5.1 (2018-07-02)
## Platform: x86_64-pc-linux-gnu (64-bit)
## Running under: Red Hat Enterprise Linux
## 
## Matrix products: default
## BLAS/LAPACK: /CHBS/apps/busdev_apps/eb/software/imkl/2018.3.222-GCC-6.4.0-2.28/compilers_and_libraries_2018.3.222/linux/mkl/lib/intel64_lin/libmkl_gf_lp64.so
## 
## locale:
##  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
##  [3] LC_TIME=en_US.UTF-8        LC_COLLATE=C              
##  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
##  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
##  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
## [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
## 
## attached base packages:
## [1] stats     graphics  grDevices utils     datasets  methods   base     
## 
## other attached packages:
##  [1] foreach_1.4.4   forcats_0.3.0   stringr_1.3.1   readr_1.1.1    
##  [5] tidyr_0.8.1     tibble_1.4.2    tidyverse_1.2.1 scales_1.0.0   
##  [9] bindrcpp_0.2.2  ggplot2_3.1.0   purrr_0.2.5     dplyr_0.7.6    
## [13] bayesplot_1.6.0 knitr_1.20      RBesT_1.3-7     Rcpp_0.12.19   
## 
## loaded via a namespace (and not attached):
##  [1] lubridate_1.7.4    mvtnorm_1.0-8      lattice_0.20-35   
##  [4] prettyunits_1.0.2  assertthat_0.2.0   rprojroot_1.3-2   
##  [7] digest_0.6.15      cellranger_1.1.0   R6_2.2.2          
## [10] plyr_1.8.4         ggridges_0.5.0     backports_1.1.2   
## [13] stats4_3.5.1       evaluate_0.11      httr_1.3.1        
## [16] highr_0.7          pillar_1.3.0       rlang_0.2.1       
## [19] readxl_1.1.0       lazyeval_0.2.1     rstudioapi_0.7    
## [22] callr_2.0.4        checkmate_1.8.5    rmarkdown_1.10    
## [25] labeling_0.3       loo_2.0.0          munsell_0.5.0     
## [28] broom_0.5.0        modelr_0.1.2       compiler_3.5.1    
## [31] rstan_2.18.2       pkgconfig_2.0.1    pkgbuild_1.0.2    
## [34] htmltools_0.3.6    tidyselect_0.2.4   gridExtra_2.3     
## [37] codetools_0.2-15   matrixStats_0.54.0 crayon_1.3.4      
## [40] withr_2.1.2        grid_3.5.1         nlme_3.1-137      
## [43] jsonlite_1.5       gtable_0.2.0       magrittr_1.5      
## [46] StanHeaders_2.18.0 cli_1.0.0          stringi_1.2.4     
## [49] debugme_1.1.0      reshape2_1.4.3     xml2_1.2.0        
## [52] Formula_1.2-3      iterators_1.0.10   tools_3.5.1       
## [55] glue_1.3.0         hms_0.4.2          processx_3.1.0    
## [58] parallel_3.5.1     yaml_2.2.0         inline_0.3.15     
## [61] colorspace_1.3-2   rvest_0.3.2        bindr_0.1.1       
## [64] haven_1.1.2