Introduction to BASSLINE

Introduction

library(BASSLINE)

BASSLINE (BAyeSian Survival anaLysIs usiNg shapE mixtures of log-normal distributions) uses shape mixtures of log-normal distributions to fit data with fat tails and has been adapted from code produced for Objective Bayesian Survival Analysis Using Shape Mixtures of Log-Normal Distributions (Vallejos and Steel 2015). Some of the functions have been rewritten in C++ for increased performance.

5 distributions from the log-normal family are supported by BASSLINE:

  • The log-normal distribution
  • The log student’s T distribution
  • The log-logistic distribution
  • The log-Laplace distribution
  • The log-exponential power distribution

As well as MCMC (Markov chain Monte Carlo) algorithms for the 5 distributions, additional functions which allow log-marginal likelihood estimators and deviance information criteria to be calculated are provided. Case deletion analysis and outlier detection are also supported.

This vignette demonstrates how to use the BASSLINE package to carry out survival analysis using the included cancer data-set from the veterans administration lung cancer trial.

Quick Start

Essential parameters for running the MCMC are :

  • N: total number of iterations
  • thin: length of the thinning period (i.e. only every thin iterations will be stored in the output)
  • burn: length of burn-in period (i.e. the initial burn iterations that will be discarded from the output)
  • Time: Vector of survival times
  • Cens: Vector indicating if observations are censored
  • X: Matrix of covariates for each observation

Starting values for the βs and σ2 are randomly sampled from an appropriate distribution if not given by the user as arguments. Additional arguments allow the type of prior to be specified, and the observations to be specified as set or point observations. See the documentation for any of the MCMC functions included with BASSLINE for more information on these additional arguments.

?MCMC_LN()

Note that BASSLINE does not support factors/ levels. Factors should be converted to separate binary variables for each level which can be easily done via the provided BASSLINE_convert function. For example:

Time Cens treatment
10 1 A
15 1 B
24 0 C
21 1 A

can be converted by simply passing the dataframe object to the function.

converted <- BASSLINE_convert(df)
Time Cens treatment.A treatment.B treatment.C
10 1 1 0 0
15 1 0 1 0
24 0 0 0 1
21 1 1 0 0

The Cancer Data Set

Included with BASSLINE is an example data set, cancer. This data has been obtained from a study conducted by the US Veterans Administration where male patients with advanced inoperable lung cancer were given either standard or experimental chemotherapy treatment (Kalbfleisch and Prentice 2002). 137 patients took part in the trial, 9 of whom left the study before their death and are thus right censored. Various covariates were also documented for each patient.

Viewing the first 5 observations shows the data set’s format:

data(cancer)
head(cancer, 5)
Time Cens Intercept Treat Type.1 Type.2 Type.3 Status MFD Age Prior
72 1 1 0 1 0 0 60 7 69 0
411 1 1 0 1 0 0 70 5 64 1
228 1 1 0 1 0 0 60 3 38 0
126 1 1 0 1 0 0 60 9 63 1
118 1 1 0 1 0 0 70 11 65 1

The first column of cancer denotes the survival time for the observation. The second column denotes the censored status for the observation (0 for right censored; 1 for not censored ). All remaining columns are covariates. Additional information can be found in the documentation for cancer.

?cancer
Time <- cancer[,"Time"]
Cens <- cancer[,"Cens"]

MCMC chains

MCMC chains can be easily generated by providing the aforementioned essential parameters. As previous discussed, starting values are randomly sampled if not provided by the user. The user will possibly obtain improved results from experimenting with these starting values.

Please note N = 1000, as used in these examples, is not enough to reach convergence and is only used as a demonstration. The user is advised to run longer chains with a longer burn-in period for more accurate estimations (especially for the log-exponential power model).

# Log-normal
LN <- MCMC_LN(N = 1000, thin = 20, burn = 40, Time = Time,
              Cens = Cens, X = cancer[,3:11])
#> Sampling initial betas from a Normal(0, 1) distribution
#> Initial beta 1 : 0 
#>  Initial beta 2 : -0.62 
#>  Initial beta 3 : 0.24 
#>  Initial beta 4 : 1.05 
#>  Initial beta 5 : 0.79 
#>  Initial beta 6 : -0.25 
#>  Initial beta 7 : 1.24 
#>  Initial beta 8 : -0.29 
#>  Initial beta 9 : 1.49 
#> 
#> Sampling initial sigma^2 from a Gamma(2, 2) distribution
#> Initial sigma^2 : 2.64

# Log-student's T
LST <- MCMC_LST(N = 1000, thin = 20, burn = 40 , Time = Time, Cens = Cens,
                X = cancer[,3:11])
#> Sampling initial betas from a Normal(0, 1) distribution
#> Initial beta 1 : 0.98 
#>  Initial beta 2 : -0.63 
#>  Initial beta 3 : -0.44 
#>  Initial beta 4 : -2.34 
#>  Initial beta 5 : -0.08 
#>  Initial beta 6 : 0.98 
#>  Initial beta 7 : -1.96 
#>  Initial beta 8 : 1.31 
#>  Initial beta 9 : 0.33 
#> 
#> Sampling initial sigma^2 from a Gamma(2, 2) distribution
#> Initial sigma^2 : 0.36 
#> 
#> Sampling initial nu from a Gamma(2, 2) distribution
#> Initial nu : 2.92 
#> 
#> AR nu : 0.43

# Log-Laplace
LLAP <- MCMC_LLAP(N = 1000, thin = 20, burn = 40,  Time = Time, Cens = Cens,
                  X = cancer[,3:11])
#> Sampling initial betas from a Normal(0, 1) distribution
#> Initial beta 1 : -3.01 
#>  Initial beta 2 : -0.73 
#>  Initial beta 3 : -0.34 
#>  Initial beta 4 : -1.35 
#>  Initial beta 5 : 0.81 
#>  Initial beta 6 : 0.06 
#>  Initial beta 7 : -2.07 
#>  Initial beta 8 : 0.28 
#>  Initial beta 9 : -0.16 
#> 
#> Sampling initial sigma^2 from a Gamma(2, 2) distribution
#> Initial sigma^2 : 2.55

#Log-exponential power
LEP <- MCMC_LEP(N = 1000, thin = 20, burn = 40, Time = Time, Cens = Cens,
                X = cancer[,3:11])
#> Sampling initial betas from a Normal(0, 1) distribution
#> Initial beta 1 : 0.77 
#>  Initial beta 2 : 0.32 
#>  Initial beta 3 : 1.61 
#>  Initial beta 4 : 0.83 
#>  Initial beta 5 : 0.15 
#>  Initial beta 6 : 0.34 
#>  Initial beta 7 : 0.65 
#>  Initial beta 8 : 1.61 
#>  Initial beta 9 : 0.2 
#> 
#> Sampling initial sigma^2 from a Gamma(2, 2) distribution
#> Initial sigma^2 : 1.49 
#> 
#> Sampling initial alpha from a Uniform(1, 2) distribution
#> Initial alpha : 1.35 
#> 
#> Inf.sigma2
#> AR beta 1 : 0.6 
#>  AR beta 2 : 0.68 
#>  AR beta 3 : 0.78 
#>  AR beta 4 : 0.7 
#>  AR beta 5 : 0.8 
#>  AR beta 6 : 0.03 
#>  AR beta 7 : 0.07 
#>  AR beta 8 : 0.03 
#>  AR beta 9 : 0.75 
#> AR sigma2 : 0.89 
#> AR alpha : 0.09

#Log-logistic
LLOG <- MCMC_LLOG(N = 1000, thin = 20, burn = 40, Time = Time, Cens = Cens,
                  X = cancer[,3:11])
#> Sampling initial betas from a Normal(0, 1) distribution
#> Initial beta 1 : -0.43 
#>  Initial beta 2 : 0.05 
#>  Initial beta 3 : 0.95 
#>  Initial beta 4 : -0.4 
#>  Initial beta 5 : 0.41 
#>  Initial beta 6 : 1.4 
#>  Initial beta 7 : 0.24 
#>  Initial beta 8 : 0.08 
#>  Initial beta 9 : 1.21 
#> 
#> Sampling initial sigma^2 from a Gamma(2, 2) distribution
#> Initial sigma^2 : 0.53

Diagnostics

After generating MCMC chains, their suitability should be assessed. This can be done, in part, via the Trace_Plot function included with BASSLINE which will plot a chain for a variable across (non-discarded) iterations. We will investigate the chain for β1 from the log-normal model.

Trace_plot(1, LN)

For additional analysis of chains, the coda package is recommended which offers many different functions:

library(coda)
plot(as.mcmc(LN[,1:10])) 

ACF plots are also available via coda:

acfplot(as.mcmc(LN[,1:10]))

Deviance Information Criterion

The deviance information criterion (DIC), a hierarchical modeling generalization of the Akaike information criterion (Spiegelhalter et al. 2002), can be easily calculated for the 5 models.

If the deviance is defined as

D(θ, y) = −2log (f(y|θ))

then

DIC = D(θ̄) + 2pD

Where pD is the number of effective parameters.

Each member of the log-normal family has a function to calculate DIC. We will present an example using the log-normal distribution and compare two models with differing covariates (all of the available covariates vs. only the last 4 covariates).

LN <- MCMC_LN(N = 1000, thin = 20, burn = 40, Time = Time,
              Cens = Cens, X = cancer[,3:11])
#> Sampling initial betas from a Normal(0, 1) distribution
#> Initial beta 1 : -0.96 
#>  Initial beta 2 : 1.5 
#>  Initial beta 3 : -1.57 
#>  Initial beta 4 : 0.26 
#>  Initial beta 5 : 0.15 
#>  Initial beta 6 : -0.38 
#>  Initial beta 7 : 0.17 
#>  Initial beta 8 : -0.07 
#>  Initial beta 9 : 0.38 
#> 
#> Sampling initial sigma^2 from a Gamma(2, 2) distribution
#> Initial sigma^2 : 0.87
DIC_LN(Time = Time, Cens = Cens, X = cancer[,3:11], chain = LN)
#> Effective number of parameters : 8.99 
#> Actual number of parameters : 10
#> [1] 1448.816

# Reduced model
LN.2 <- MCMC_LN(N = 1000, thin = 20, burn = 40, Time = Time,
              Cens = Cens, X = cancer[,8:11])
#> Sampling initial betas from a Normal(0, 1) distribution
#> Initial beta 1 : 1.16 
#>  Initial beta 2 : 2.34 
#>  Initial beta 3 : 0.49 
#>  Initial beta 4 : 0.08 
#> 
#> Sampling initial sigma^2 from a Gamma(2, 2) distribution
#> Initial sigma^2 : 0.27
DIC_LN(Time = Time, Cens = Cens, X = cancer[,8:11], chain = LN.2)
#> Effective number of parameters : 4.66 
#> Actual number of parameters : 5
#> [1] 1454.456

Log-Marginal Likelihood

The log-marginal likelihood is given by:

log (m(t)) = log (∫−∞0Θf(t ∣ β, σ2, θ)π(β, σ2, θ)dβ dσ2 dθ)

And can be easily estimated using the supplied function for each distribution which is based on the work of Chib (Chib 1995) and Chib and Jeliaskov (Chib and Jeliazkov 2001). The function will return a list which includes the log-marginal likelihood estimation, the log-likelihood ordinate, the log-prior ordinate, and the log-posterior ordinates. Messages detailing the progress of the algorithm are provided to the user.

LML_LN(thin = 20, Time, Cens = Cens, X = cancer[,3:11], chain = LN) 
#> Likelihood ordinate ready!
#> Prior ordinate ready!
#> Posterior ordinate sigma2 ready!
#> Posterior ordinate beta ready!
#> $LL.ord
#> [1] -715.414
#> 
#> $LP.ord
#> [1] -0.2639658
#> 
#> $LPO.sigma2
#> [1] 0.7994308
#> 
#> $LPO.beta
#> [1] 15.59302
#> 
#> $LML
#> [1] -732.0705

Leave-One-Out Cross-Validation Analysis

Leave-one-out cross-validation analysis is also available for all 5 of the supported distributions. The functions returns matrices with n rows.

Its first column contains the logarithm of the conditional predictive ordinate (CPO) (Geisser and Eddy 1979). Larger values of the CPO indicate better predictive accuracy.

The second and third columns contain the Kullback–Leibler (KL) divergence between π(β, σ2, θ ∣ ti) and π(β, σ2, θ ∣ t) and its calibration index pi (Cho et al. 2008) respectively. The later is used in order to evaluate the existence of influential observations. If pi is substantially larger than 0.5, observation i is declared influential. Suggested cut-off values are 0.8 and 0.9.

LN.CD <- CaseDeletion_LN(Time, Cens = Cens, X = cancer[,3:11], chain = LN)
knitr::kable(LN.CD[1:5,])
logCPO KL CALIBRATION
-5.439256 0.0053998 0.5518206
-7.561821 0.0301061 0.6208670
-7.007455 0.0291901 0.6190680
-5.942066 0.0038883 0.5440069
-5.867201 0.0038184 0.5436112

It is sensible to report the number of observations which are deemed influential for a given cutoff which can be easily found by the user.

sum(LN.CD[,3] > 0.8)
#> [1] 3

Outlier Detection

Outlier detection is available for a specified observation (obs) for the log-student’s T, log-Laplace, log-logistic, log-exponential power models. This returns a unique number corresponding to the Bayes Factor associated with the test M0 : Λobs = λref versus M0 : Λobs ≠ λref (with all other Λj, j ≠ obs free). The value of λref is required as input.

The recommended value of λref is 1 with the exception of the log-logistic model where we recommend 0.4 instead. The calculations which support these recommendations can be found in the original paper (Vallejos and Steel 2015).

OD.LST <- rep(0, 5)
for(i in 1 : 5)
{
    OD.LST[i] <- BF_lambda_obs_LST(N = 100, thin = 20 , burn = 1, ref = 1,
                                   obs = i, Time = Time, Cens = Cens,
                                   X = cancer[,3:11], chain = LST)
}
#> AR nu : 0.41 
#> AR nu : 0.4 
#> AR nu : 0.39 
#> AR nu : 0.49 
#> AR nu : 0.38

References

Chib, Siddhartha. 1995. “Marginal Likelihood from the Gibbs Output.” Journal of the American Statistical Association 90 (432): 1313–21. https://doi.org/10.1080/01621459.1995.10476635.
Chib, Siddhartha, and Ivan Jeliazkov. 2001. “Marginal Likelihood from the Metropolis–Hastings Output.” Journal of the American Statistical Association 96 (453): 270–81. https://doi.org/10.1198/016214501750332848.
Cho, Hyunsoon, Joseph G. Ibrahim, Debajyoti Sinha, and Hongtu Zhu. 2008. “Bayesian Case Influence Diagnostics for Survival Models.” Biometrics 65 (1): 116–24. https://doi.org/10.1111/j.1541-0420.2008.01037.x.
Geisser, Seymour, and William F. Eddy. 1979. “A Predictive Approach to Model Selection.” Journal of the American Statistical Association 74 (365): 153–60. https://doi.org/10.1080/01621459.1979.10481632.
Kalbfleisch, John D., and Ross L. Prentice. 2002. The Statistical Analysis of Failure Time Data. John Wiley & Sons, Inc. https://doi.org/10.1002/9781118032985.
Spiegelhalter, David J., Nicola G. Best, Bradley P. Carlin, and Angelika Van Der Linde. 2002. “Bayesian Measures of Model Complexity and Fit.” Journal of the Royal Statistical Society: Series B (Statistical Methodology) 64 (4): 583–639. https://doi.org/10.1111/1467-9868.00353.
Vallejos, Catalina A., and Mark F. J. Steel. 2015. “Objective Bayesian Survival Analysis Using Shape Mixtures of Log-Normal Distributions.” Journal of the American Statistical Association 110 (510): 697–710. https://doi.org/10.1080/01621459.2014.923316.