Package 'hdbma'

Title: Bayesian Mediation Analysis with High-Dimensional Data
Description: Mediation analysis is used to identify and quantify intermediate effects from factors that intervene the observed relationship between an exposure/predicting variable and an outcome. We use a Bayesian adaptive lasso method to take care of the hierarchical structures and high dimensional exposures or mediators.
Authors: Qingzhao Yu [aut, cre, cph], Bin Li [aut]
Maintainer: Qingzhao Yu <[email protected]>
License: GPL (>= 2)
Version: 1.0
Built: 2024-10-11 06:30:45 UTC
Source: CRAN

Help Index


Bayesian Mediation Analysis with High-Dimensional Data

Description

Mediation analysis is used to identify and quantify intermediate effects from factors that intervene the observed relationship between an exposure/predicting variable and an outcome. We use a Bayesian adaptive lasso method to take care of the hierarchical structures and high dimensional exposures or mediators.

Details

The DESCRIPTION file:

Package: hdbma
Type: Package
Title: Bayesian Mediation Analysis with High-Dimensional Data
Version: 1.0
Date: 2023-12-16
Authors@R: c(person("Qingzhao Yu", role = c("aut", "cre","cph"), email = "[email protected]"), person("Bin Li", role = "aut") )
Maintainer: Qingzhao Yu <[email protected]>
Depends: R (>= 2.14.1), R2jags,gplots,MASS,survival,splines
Imports: lattice, methods
Encoding: UTF-8
Description: Mediation analysis is used to identify and quantify intermediate effects from factors that intervene the observed relationship between an exposure/predicting variable and an outcome. We use a Bayesian adaptive lasso method to take care of the hierarchical structures and high dimensional exposures or mediators.
License: GPL (>= 2)
URL: https://www.r-project.org, https://publichealth.lsuhsc.edu/Faculty_pages/qyu/index.html
RoxygenNote: 7.2.3
NeedsCompilation: no
Packaged: 2023-12-15 01:53:30 UTC; qyu
Author: Qingzhao Yu [aut, cre, cph], Bin Li [aut]
Repository: CRAN
Date/Publication: 2023-12-15 12:30:02 UTC

Index of help topics:

hdbma                   High-Dimensional Bayesian Mediation Analysis
hdbma-package           Bayesian Mediation Analysis with
                        High-Dimensional Data
print.summary.hdbma     Print
summary.hdbma           Summary for hdbma results
weight_behavior         Weight_Behavior Data Set

The main function is hdbma to perform the Bayesian mediation anlysis with adaptive Laplace priors.

Author(s)

Qingzhao Yu [aut, cre, cph], Bin Li [aut]

Maintainer: Qingzhao Yu <[email protected]>

References

Yu, Q., Hagan, J., Wu, X., Richmond-Bryant, J., and Li, B., 2023, High-Dimensional Bayesian Mediation Analysis with Adaptive Laplace Priors. Submitted.

Examples

#See examples at summary.hdbma.

High-Dimensional Bayesian Mediation Analysis

Description

We use the adaptive lasso priors for the Bayesian mediation analysis. Significant exposure variables, mediators are identified and their effects infered.

Usage

hdbma(pred, m, y, refy = rep(NA, ncol(data.frame(y))),
predref = rep(NA, ncol(data.frame(pred))), fpy = NULL,
deltap = rep(0.001, ncol(data.frame(pred))), fmy = NULL,
deltam = rep(0.001, ncol(data.frame(m))), fpm = NULL,
mref = rep(NA, ncol(data.frame(m))), cova = NULL, mcov = NULL, mclist = NULL,
inits = NULL, n.chains = 1, n.iter = 1100, n.burnin = 100, n.thin = 1,
mucv = NULL, Omegacv = NULL, mu0.1 = NULL, Omega0.1 = NULL, mu1.1 = NULL,
Omega1.1 = NULL, mu0.a = NULL, Omega0.a = NULL, mu1.a = NULL, Omega1.a = NULL,
mu0.b = NULL, Omega0.b = NULL, mu1.b = NULL, Omega1.b = NULL, mu0.c = NULL,
Omega0.c = NULL, mu1.c = NULL, Omega1.c = NULL, preci = 1e-06, tmax = Inf,
multi = NULL, filename = NULL, deltax = 1, r1 = 1, partial = FALSE)

Arguments

pred

the vector/matrix of exposure(s)/predictor(s).

m

a data frame contains all potential mediators and covariates.

y

the vector/matrix of outcome(s).

refy

the reference group of y if the outcome is categorical.

predref

the reference group of pred if the exposure/predictor is categorical.

fpy

the transformation function of predictor(s) (pred) to explain y. [[1]] list all continuous predictors to be transformed, then following items list the transformation functions for each predictor in list [[1]] in that order.

deltap

the vector of changing amount in predictors.

fmy

the transformation functions of mediators (m) to explain y, [[1]] list all continuous mediators in m to be transformed, then following items list the transformation functions for each mediator in list [[1]] in that order.

deltam

the vector of changing amount in mediators.

fpm

the transformation functions of predictors (pred) to explain mediators (m), [[1]] is a matrix, the first column indicator the mediators to be explained, the second column are the continuous predictors to be transformed; then transformation functions are listed in the following items by the row order of [[1]].

mref

the reference group of m if any of them is categorical. By default, the reference group is the first one in alphebetic order.

cova

the covariates for the outcome.

mcov

the data frame with all covariates for mediators

mclist

the list of all covariates for mediators. If mclist is NULL but mcov is not, use all covariates in mcov for all mediators. Otherwise the first item of mclist lists all mediators that are using different covariates, the following items give the columns of covariates in mcov for the mediators in order of mclist[[1]]. Use NA is no covariates are to be used. If a mediator is not listed in mclist[[1]], use all covariates in mcov.

inits

to specify the starting values of parameters. Default is NULL. See R2jags:jags.

n.chains

number of Markov chains (default: 1). See R2jags:jags.

n.iter

number of total iterations per chain (including burn in; default: 1100). See R2jags:jags.

n.burnin

length of burn in, i.e. number of iterations to discard at the beginning. Default is 100. If n.burnin is 0, jags() will run 100 iterations for adaption. See R2jags:jags.

n.thin

thinning rate. Must be a positive integer. Default is 1. See R2jags:jags.

mucv

the prior mean for the variables in cova. Default is 0.

Omegacv

the prior precision for the variables in cova. Default is 0 preci.

mu0.1

the prior mean for the intercept in the prediction model for all mediators. Default is 0.

Omega0.1

the prior precision for the intercept in the prediction model for all mediators. Default is preci.

mu1.1

a vector of the size of meditators include the prior mean for the slope of the exposures in the prediction model for all mediators. Default is rep(0,P).

Omega1.1

the prior precision matrix (P*P) for the slope of the exposures in the prediction model for all mediators. Default is a diagoal matrix with preci.

mu0.a

the prior mean for the intercept in the prediction model for all continuous mediators. Default is rep(0,p1), p1 is the number of continuous mediators.

Omega0.a

the prior precision for the intercept in the prediction model for all continuous mediators. Default is diag(preci).

mu1.a

the prior mean for the slope of the exposures in the prediction model for all continuous mediators. Default is rep(0,p1), p1 is the number of continuous mediators.

Omega1.a

the prior precision for the slope of the exposures in the prediction model for all continuous mediators. Default is diag(preci).

mu0.b

the prior mean for the intercept in the prediction logit model for all binary mediators. Default is rep(0,p2), p2 is the number of bianry mediators.

Omega0.b

the prior precision matrix for the intercept in the prediction logit model for all binary mediators. Default is diag(preci).

mu1.b

the prior mean for the slope of exposure(s) in the prediction logit model for all binary mediators. Default is rep(0,p2).

Omega1.b

the prior precision matrix for the slope of exposure(s) in the prediction logit model for all binary mediators. Default is diag(preci).

mu0.c

the prior mean for the intercept in the prediction logit model for all categorical mediators. Default is 0 for all (array(0,p3,cat1,nmc), where p3 is the number of categorical mediators, cat1 is the maximum number of categories of all categorical mediators, and nmc is the number of mcov.

Omega0.c

the prior precision matrix for intercept in the prediction logit model for all categorical mediators. Default is preci at the diagnal matrix of nmc*nmc dimension.

mu1.c

the prior mean for the slope of exposures in the prediction logit model for all categorical mediators. Default is 0 for all (array(0,p3,cat1,c1), where p3 is the number of categorical mediators, cat1 is the maximum number of categories of all categorical mediators, and c1 is the number of exposures.

Omega1.c

the prior precision matrix for the slope of exposures in the prediction logit model for all categorical mediators. Default is preci at the diagnal matrix of c1*c1 dimension.

preci

the prior precision level. Default is 0.000001.

tmax

the maximum time to event for survival analysis. Default is Inf.

multi

in the survival analysis only. If true, calculate the multiplicative effect of survival time.

filename

the directory and filename for the bugs model. If is NULL, the function will generate the bugs model using default functions.

deltax

the change unit in the exposures to calculate the mediation effects. Default is 1.

r1

the penalty parameter is

λ=λ(αβ^)r.\lambda^*=\frac{\lambda}{(\alpha\hat{\beta})^r}.

. Default is 1.

partial

if true, do the partial lasso,

λ=λαr.\lambda^*=\frac{\lambda}{\alpha^r}.

Default is FALSE.

Details

The function will automatically catch the types of the outcome and compile the bugs model. Results will be summarized use the summary function. Please see examples under summary.

Value

A hdbma object is returned with the following items. Results are summarized using the summary.hdbma function.

aie1, ade1, ate1, ..., ate4

the average indirect effect (ie), direct effect (de) and total effect (te) from the four different methods. See the references.

sims.list

the simulation results from the bugs model.

data0

the organized data set that was analyzed.

omu3, omu4

the total effects from method 3 or 4 for survival outcome only.

Author(s)

Qingzhao Yu and Bin Li

References

Yu, Q., Hagan, J., Wu, X., Richmond-Bryant, J., and Li, B., 2023, High-Dimensional Bayesian Mediation Analysis with Adaptive Laplace Priors. Submitted.

Examples

#Check summary.hdbma.

Print

Description

print the results from summary.hdbma.

Usage

## S3 method for class 'summary.hdbma'
print(x, ..., digit = x$digit, method = x$method, RE = x$RE)

Arguments

x

the results from summary.hdbma.

...

further arguments passed to or from other methods.

digit

the number of digit to be shown.

method

the method to be shown. See the reference.

RE

if true, present results for relative effects. Default is True.

Value

No return value, called for to print results and plots.

Author(s)

Qingzhao Yu and Bin Li

References

Yu, Q., Hagan, J., Wu, X., Richmond-Bryant, J., and Li, B., 2023, High-Dimensional Bayesian Mediation Analysis with Adaptive Laplace Priors. Submitted.

Examples

#Examples at summary.hdbma.

Summary for hdbma results

Description

This function summarize the results from hdbma objects with estimations, standard errors, and confidence intervals.

Usage

## S3 method for class 'hdbma'
summary(object, ..., plot = TRUE, RE = TRUE,
quant = c(0.025, 0.25, 0.5, 0.75, 0.975), digit = 4, method = 1)

Arguments

object

the hdbma object from the hdbma function.

...

further arguments passed to or from other methods.

plot

if true, plot the estimation summaries. Default is True.

RE

if true, present results for relative effects. Default is True.

quant

the set of quantiles to be shown in the sumamry results. Default is c(0.025, 0.25, 0.5, 0.75, 0.975).

digit

the number of digit to be shown.

method

the method to be shown. See the reference.

Value

result1, ..., result4

the inference results for estimated mediation effects from methods 1 to 4.

result1.re, ..., result4.re

the inference results for estimated relative effects from methods 1 to 4.

Author(s)

Qingzhao Yu and Bin Li

References

Yu, Q., Hagan, J., Wu, X., Richmond-Bryant, J., and Li, B., 2023, High-Dimensional Bayesian Mediation Analysis with Adaptive Laplace Priors. Submitted.

Examples

data("weight_behavior")
#for all the examples, needs to remove or increase n.iter and n.burnin

#binary predictor
test.b.c<- hdbma(pred=weight_behavior[,3], m=weight_behavior[,c(4,14,12,13)],
                 y=weight_behavior[,1],n.iter=10,n.burnin = 1)
summary(test.b.c)

##use covariate for y
test.b.c.2<- hdbma(pred=weight_behavior[,3], m=weight_behavior[,12:14],
                     y=weight_behavior[,1],cova=weight_behavior[,2],n.iter=10,n.burnin = 1)
summary(test.b.c.2)

#categorical predictor
test.ca.c<- hdbma(pred=weight_behavior[,4], m=weight_behavior[,12:14],
                     y=weight_behavior[,1],n.iter=10,n.burnin = 1)
summary(test.ca.c)

#use covariate for mediators
test.b.c.3<- hdbma(pred=weight_behavior[,3], m=weight_behavior[,c(9,12:14)],
                       y=weight_behavior[,1],mcov=weight_behavior[,c(2,5)],
                       mclist = list(1,2),n.iter=10,n.burnin = 1)
summary(test.b.c.3)

#use continuous predictor
test.c.c<- hdbma(pred=weight_behavior[,2], m=weight_behavior[,12:14],
                       y=weight_behavior[,1],n.iter=10,n.burnin = 1)
summary(test.c.c,method=3)

#use transfered continuous predictor
test.c.c.2<- hdbma(pred=weight_behavior[,2], m=weight_behavior[,12:14],
                     y=weight_behavior[,1],fpy=list(1,c("x","x^2")),
                     n.iter=10,n.burnin = 1)
summary(test.c.c.2,method=1)

#multiple predictors
test.m.c<- hdbma(pred=weight_behavior[,2:4], m=weight_behavior[,12:14],
                 y=weight_behavior[,1],n.iter=10,n.burnin = 1)
summary(test.m.c,RE=FALSE)

##binary outcome
test.m.b<- hdbma(pred=weight_behavior[,2:4], m=weight_behavior[,12:14],
                     y=weight_behavior[,15],cova=weight_behavior[,5],
                     n.iter=10,n.burnin = 1)
summary(test.m.b,method=2)

##categorical outcome
weight_behavior[,14]=as.factor(weight_behavior[,14])
test.m.c<- hdbma(pred=weight_behavior[,2:4], m=weight_behavior[,12:13],
                     y=weight_behavior[,14],cova=weight_behavior[,5],
                     n.iter=10,n.burnin = 1)
summary(test.m.c,method=2)
summary(test.m.c,method=1)

##time-to-event outcome
##Surv class outcome (survival analysis)
#use a simulation
set.seed(1)
N=100

alpha=0.5
x=rnorm(N,0,1)
x=ifelse(x>0,1,0)
e1=rnorm(N,0,1)
M=alpha*x+e1
lambda=0.01
rho=1
beta=1.2
c=-1
rateC=0.001
v=runif(n=N)
Tlat =(- log(v) / (lambda * exp(c*x+M*beta)))^(1 / rho)
C=rexp(n=N, rate=rateC)
time=pmin(Tlat, C)
status <- as.numeric(Tlat <= C)

test.m.t.1<- hdbma(pred=x, m=M,y=Surv(time,status),inits=function(){
  list(r=1,lambda=0.01)
},n.iter=10,n.burnin = 1)
summary(test.m.t.1,RE=FALSE)

Weight_Behavior Data Set

Description

This database was obtained from the Louisiana State University Health Sciences Center, New Orleans, by Dr. Richard Scribner. He explored the relationship between BMI and kids behavior through a survey at children, teachers and parents in Grenada in 2014. This data set includes 691 observations and 15 variables.

Usage

data(weight_behavior)

Format

The data set contains the following variables:

bmi - body mass index, calculated by weight(kg)/height(cm)^2, numeric

age - children's age in years at the time of survey, numeric

sex - sex of the children, factor

race - race of the children, factor

numpeople - number of people in family, numeric

car - the number of cars in family, numeric

gotosch - the method used to go to school, factor

snack - eat snack or not in a day, binary

tvhours - number of hours watching TV per week, numeric

cmpthours - number of hours using computer per week, numeric

cellhours - number of hours playing with cell phones per week, numeric

sports - join in a sport team or not, 1: yes; and 2: no

exercises - number of hours of exercises per week, numeric

sweat - number of hours of sweating activities per week, numeric

overweigh - the child is overweighed or not, binary

Examples

data(weight_behavior)
names(weight_behavior)