Title: | Bayesian Latent Variable Models |
---|---|
Description: | Estimation of latent variable models using Bayesian methods. Currently estimates the loglinear cognitive diagnosis model of Henson, Templin, and Willse (2009) <doi:10.1007/s11336-008-9089-5>. |
Authors: | Jonathan Templin [aut, cre] |
Maintainer: | Jonathan Templin <[email protected]> |
License: | GPL (>= 2) |
Version: | 0.1.2 |
Built: | 2025-01-02 06:46:08 UTC |
Source: | CRAN |
Estimation of latent variable models using Bayesian methods. Currently supports diagnostic classification models.
Creates control specifics for estimation options for estimating Bayesian latent variable models.
blatentControl( calculateDIC = TRUE, calculateWAIC = TRUE, defaultPriors = setDefaultPriors(), defaultInitializeParameters = setDefaultInitializeParameters(), estimateLatents = TRUE, estimator = "blatent", estimatorType = "R", estimatorLocation = "", executableName = "", fileSaveLocation = paste0(getwd(), "/"), HDPIntervalValue = 0.95, maxTuneChains = 0, minTuneChains = 0, missingMethod = "omit", nBurnin = 1000, nChains = 4, nCores = -1, nSampled = 1000, nThin = 5, nTuneIterations = 0, parallel = FALSE, posteriorPredictiveChecks = setPosteriorPredictiveCheckOptions(), seed = NULL )
blatentControl( calculateDIC = TRUE, calculateWAIC = TRUE, defaultPriors = setDefaultPriors(), defaultInitializeParameters = setDefaultInitializeParameters(), estimateLatents = TRUE, estimator = "blatent", estimatorType = "R", estimatorLocation = "", executableName = "", fileSaveLocation = paste0(getwd(), "/"), HDPIntervalValue = 0.95, maxTuneChains = 0, minTuneChains = 0, missingMethod = "omit", nBurnin = 1000, nChains = 4, nCores = -1, nSampled = 1000, nThin = 5, nTuneIterations = 0, parallel = FALSE, posteriorPredictiveChecks = setPosteriorPredictiveCheckOptions(), seed = NULL )
calculateDIC |
Calculates DIC following Markov chain. DIC will be marginalized for models with latent variables. Defaults to TRUE. |
calculateWAIC |
Calculates WAIC following Markov chain. WAIC will be marginalized for models with latent variables. Defaults to TRUE. |
defaultPriors |
Sets priors for all parameters that are not specified in priorsList of
|
defaultInitializeParameters |
List of values that sets distributions used to initialize
parameters. Defaults to list set by
|
estimateLatents |
Estimate latent variables summaries for each observation following MCMC estimation. Defaults to |
estimator |
Sets the estimation algorithm to be used. Currently, one option is available that works. The eventual values will be:
|
estimatorType |
Sets location of estimator. Currently, only one option (the default) works.
|
estimatorLocation |
Sets the path to the location of estimator executable, if |
executableName |
Sets the name for the executable file for the estimator. Defaults to
|
fileSaveLocation |
Sets the path for output files used for external estimation routines.
Only used when |
HDPIntervalValue |
Sets the value for all highest density posterior interval parameter summaries. Defaults to |
maxTuneChains |
Sets the maximum number of tuning chains for MCMC sampling algorithm, if needed. Currently,
no Metropolis steps exist in algorithm, so is unused. Defaults to |
minTuneChains |
Sets the minimum number of tuning chains for MCMC sampling algorithm, if needed.
Currently, no Metropolis steps exist in algorithm, so is unused. Defaults to |
missingMethod |
Sets the way missing observed variables are treated within algorithm. Defaults to
|
nBurnin |
Sets the number of burnin iterations. Defaults to |
nChains |
Sets the number of independent Markov chains run by the program. Defaults to |
nCores |
Sets the number of cores used in parallel processing if option
Note: currently, parallel processing is unavailable, so this is unused. |
nSampled |
Sets the number of posterior draws to sample, per chain. Defaults to |
nThin |
Sets the thinning interval, saving only the posterior draws that comes at this value.
Defaults to |
nTuneIterations |
Sets the number of iterations per tuning chain, if needed. Currently,
no Metropolis steps exist in algorithm, so is unused. Defaults to |
parallel |
If |
posteriorPredictiveChecks |
List of values that sets options for posterior predictive model checks.
Defaults to list set by |
seed |
Sets the random number seed for the analysis. Defaults to |
A list of values containing named entries for all arguments shown above.
Blatantly runs Bayesian latent variable models.
blatentEstimate( dataMat, modelText, priorsList = NULL, options = blatentControl() )
blatentEstimate( dataMat, modelText, priorsList = NULL, options = blatentControl() )
dataMat |
A data frame containing the data used for the analysis. |
modelText |
A character string that contains the specifications for the model to be run. See |
priorsList |
A list of priors to be placed on parameters of the model. Defaults to NULL. Currently only accepts NULL.
All priors not set in |
options |
A list of options for estimating the model. Use the |
A blatentModel object (an R6 class).
Simulates data using parameters from posterior distribution of blatent Markov chain.
blatentPPMC( model, nSamples, seed = model$options$seed, parallel = TRUE, nCores = 4, type = c("mean", "covariance", "univariate", "bivariate", "tetrachoric", "pearson"), lowPPMCpercentile = c(0.025, 0.025, 0, 0, 0.025, 0.025), highPPMCpercentile = c(0.975, 0.975, 1, 1, 0.975, 0.975) )
blatentPPMC( model, nSamples, seed = model$options$seed, parallel = TRUE, nCores = 4, type = c("mean", "covariance", "univariate", "bivariate", "tetrachoric", "pearson"), lowPPMCpercentile = c(0.025, 0.025, 0, 0, 0.025, 0.025), highPPMCpercentile = c(0.975, 0.975, 1, 1, 0.975, 0.975) )
model |
A blatent MCMC model object. |
nSamples |
The number of PPMC samples to be simulated. |
seed |
The random number seed. Defaults to the seed set in the blatent model object. |
parallel |
If parallelization should be used in PPMC. Defaults to |
nCores |
If |
type |
The type of statistic to generate, submitted as a character vector. Options include:
|
lowPPMCpercentile |
A vector of the lower bound percentiles used for flagging statistics against PPMC
predictive distributions. Results are flagged if the observed statistics percentile is lower than
the number in the vector. Provided in order of each term in |
highPPMCpercentile |
A vector of the upper bound percentiles used for flagging statistics against PPMC
predictive distributions. Results are flagged if the observed statistics percentile is higher than
the number in the vector. Provided in order of each term in |
Simulates data from a model specified by blatent syntax and using a set of default parameter specifications.
blatentSimulate( modelText, nObs, defaultSimulatedParameters = setDefaultSimulatedParameters(), paramVals = NULL, seed = NULL, calculateInfo = FALSE )
blatentSimulate( modelText, nObs, defaultSimulatedParameters = setDefaultSimulatedParameters(), paramVals = NULL, seed = NULL, calculateInfo = FALSE )
modelText |
A character string that contains the specifications for the model to be run. See |
nObs |
The number of observations to be simulated. |
defaultSimulatedParameters |
The specifications for the generation of the types of parameters in the simulation. Currently comprised
of a list of unevaluated expressions (encapsulated in quotation marks; not calls for ease of user input) that will be evaluated by
simulation function to generate parameters. Defaults to values generated by
|
paramVals |
A named vector of parameter values which will be set rather than generated. A named vector of the length parameters of an analysis
can be obtained by using |
seed |
The random number seed value used for setting the data. Defaults to |
calculateInfo |
A logical variable where |
Rupp, A. A., Templin, J., & Henson, R. A. (2010). Diagnostic Measurement: Theory, Methods, and Applications. New York: Guilford.
# Generating data using Q-matrix structure from data example in Chapter 9 of # Rupp, Templin, & Henson (2010). RTHCh9ModelSyntax = " item1 ~ A1 item2 ~ A2 item3 ~ A3 item4 ~ A1 + A2 + A1:A2 item5 ~ A1 + A3 + A1:A3 item6 ~ A2 + A3 + A2:A3 item7 ~ A1 + A2 + A3 + A1:A2 + A1:A3 + A2:A3 + A1:A2:A3 # Latent Variable Specifications: A1 A2 A3 <- latent(unit='rows',distribution='bernoulli',structure='univariate',type='ordinal') # Observed Variable Specifications: item1-item7 <- observed(distribution = 'bernoulli', link = 'probit') " simSpecs = setDefaultSimulatedParameters( observedIntercepts = "runif(n = 1, min = -1, max = -1)", observedMainEffects = "runif(n = 1, min = 2, max = 2)", observedInteractions = "runif(n = 1, min = 0, max = 0)", latentIntercepts = "runif(n = 1, min = 0, max = 0)", latentMainEffects = "runif(n = 1, min = 0, max = 0)", latentInteractions = "runif(n = 1, min = 0, max = 0)" ) simulatedData = blatentSimulate(modelText = RTHCh9ModelSyntax, nObs = 1000, defaultSimulatedParameters = simSpecs) # setting values for specific parameters: paramVals = createParameterVector(modelText = RTHCh9ModelSyntax) paramVals["item1.(Intercept)"] = -2 # creating data simulatedData2 = blatentSimulate(modelText = RTHCh9ModelSyntax, nObs = 1000, defaultSimulatedParameters = simSpecs, paramVals = paramVals)
# Generating data using Q-matrix structure from data example in Chapter 9 of # Rupp, Templin, & Henson (2010). RTHCh9ModelSyntax = " item1 ~ A1 item2 ~ A2 item3 ~ A3 item4 ~ A1 + A2 + A1:A2 item5 ~ A1 + A3 + A1:A3 item6 ~ A2 + A3 + A2:A3 item7 ~ A1 + A2 + A3 + A1:A2 + A1:A3 + A2:A3 + A1:A2:A3 # Latent Variable Specifications: A1 A2 A3 <- latent(unit='rows',distribution='bernoulli',structure='univariate',type='ordinal') # Observed Variable Specifications: item1-item7 <- observed(distribution = 'bernoulli', link = 'probit') " simSpecs = setDefaultSimulatedParameters( observedIntercepts = "runif(n = 1, min = -1, max = -1)", observedMainEffects = "runif(n = 1, min = 2, max = 2)", observedInteractions = "runif(n = 1, min = 0, max = 0)", latentIntercepts = "runif(n = 1, min = 0, max = 0)", latentMainEffects = "runif(n = 1, min = 0, max = 0)", latentInteractions = "runif(n = 1, min = 0, max = 0)" ) simulatedData = blatentSimulate(modelText = RTHCh9ModelSyntax, nObs = 1000, defaultSimulatedParameters = simSpecs) # setting values for specific parameters: paramVals = createParameterVector(modelText = RTHCh9ModelSyntax) paramVals["item1.(Intercept)"] = -2 # creating data simulatedData2 = blatentSimulate(modelText = RTHCh9ModelSyntax, nObs = 1000, defaultSimulatedParameters = simSpecs, paramVals = paramVals)
The blatent model syntax provides the specifications for a Bayesian latent variable model.
The model syntax, encapsulated in quotation marks, consists of up to three components:
Model Formulae: R model-like formulae specifying the model for all observed and latent variables in the model. See formula
for
R formula specifics. Blatent model formulae differ only in that more than one variable can be provided to the left of the ~
.
In this section of syntax, there are no differences between latent and observed variables. Model statements are formed using
the linear predictor for each variable. This means that to specify a measurement model, the latent variables will appear to the right-hand side of the ~
.
Examples:
Measurement model where one latent variable (LV) predicts ten items (item1-item10, implying item1, item2, ..., item10):
item1-item10 ~ LV
One observed variable (X) predicting another observed variable (Y):
Y ~ X
Two items (itemA and itemB) measuring two latent variables (LV1, LV2) with a latent variable interaction:
itemA itemB ~ LV1 + LV2 + LV1:LV2
Two items (itemA and itemB) measuring two latent variables (LV1, LV2) with a latent variable interaction (R formula
shorthand):
itemA itemB ~ LV1*LV2
Measurement model with seven items (item1-item7) measuring three latent variables (A1, A2, A3) from Chapter 9 of Rupp, Templin, Henson (2010):
item1 ~ A1
item2 ~ A2
item3 ~ A3
item4 ~ A1 + A2 + A1:A2
item5 ~ A1 + A3 + A1:A3
item6 ~ A2 + A3 + A2:A3
item7 ~ A1 + A2 + A3 + A1:A2 + A1:A3 + A2:A3 + A1:A2:A3
Latent Variable Specifications: Latent variables are declared using a unevaluated function call to
the latent
function. Here, only the latent variables are declared along with options for their estimation.
See latent
for more information.
A1 A2 A3 <- latent(unit = 'rows', distribution = 'mvbernoulli', structure = 'joint', type = 'ordinal', jointName = 'class')
Additionally, blatent currently uses a Bayesian Inference Network style of specifying the distributional associations between latent variables: Model statements must be given to specify any associations between latent variables. By default, all latent variables are independent, which is a terrible assumption. To fix this, for instance, as shown in Hu and Templin (2020), the following syntax will give a model that is equivalent to the saturated model for a DCM:
# Structural Model A1 ~ 1 A2 ~ A1 A3 ~ A1 + A2 + A1:A2
Observed Variable Specifications: Observed variables are declared using a unevaluated function call to
the observed
function. Here, only the observed variables are declared along with options for their estimation.
See observed
for more information.
item1-item7 <- observed(distribution = 'bernoulli', link = 'probit')
Continuing with the syntax example from above, the full syntax for the model in Chapter 9 of Rupp, Templin, Henson (2010) is:
modelText = " # Measurement Model item1 ~ A1 item2 ~ A2 item3 ~ A3 item4 ~ A1 + A2 + A1:A2 item5 ~ A1 + A3 + A1:A3 item6 ~ A2 + A3 + A2:A3 item7 ~ A1 + A2 + A3 + A1:A2 + A1:A3 + A2:A3 + A1:A2:A3 # Structural Model A1 ~ 1 A2 ~ A1 A3 ~ A1 + A2 + A1:A2 A1 A2 A3 <- latent(unit = 'rows', distribution = 'bernoulli', structure = 'univariate', type = 'ordinal') # Observed Variable Specifications: item1-item7 <- observed(distribution = 'bernoulli', link = 'probit') "
Rupp, A. A., Templin, J., & Henson, R. A. (2010). Diagnostic Measurement: Theory, Methods, and Applications. New York: Guilford.
Hu, B., & Templin, J. (2020). Using diagnostic classification models to validate attribute hierarchies and evaluate model fit in Bayesian networks. Multivariate Behavioral Research. https://doi.org/10.1080/00273171.2019.1632165
Calculates DIC for a given model using model object specs.
calculateDIC(model)
calculateDIC(model)
model |
A blatent MCMC model object. |
Calculates WAIC for a given model using model object specs.
calculateWAIC(model)
calculateWAIC(model)
model |
A blatent MCMC model object. |
Creates named numeric vector with parameter names for analysis specified by modelText.
createParameterVector(modelText)
createParameterVector(modelText)
modelText |
A character string that contains the specifications for the model to be run. See |
# Generating parameters for data using Q-matrix structure from data example in Chapter 9 of # Rupp, Templin, & Henson (2010). RTHCh9ModelSyntax = " item1 ~ A1 item2 ~ A2 item3 ~ A3 item4 ~ A1 + A2 + A1:A2 item5 ~ A1 + A3 + A1:A3 item6 ~ A2 + A3 + A2:A3 item7 ~ A1 + A2 + A3 + A1:A2 + A1:A3 + A2:A3 + A1:A2:A3 # Latent Variable Specifications: A1 A2 A3 <- latent(unit='rows',distribution='bernoulli',structure='univariate',type='ordinal') # Observed Variable Specifications: item1-item7 <- observed(distribution = 'bernoulli', link = 'probit') " paramVals = createParameterVector(modelText = RTHCh9ModelSyntax)
# Generating parameters for data using Q-matrix structure from data example in Chapter 9 of # Rupp, Templin, & Henson (2010). RTHCh9ModelSyntax = " item1 ~ A1 item2 ~ A2 item3 ~ A3 item4 ~ A1 + A2 + A1:A2 item5 ~ A1 + A3 + A1:A3 item6 ~ A2 + A3 + A2:A3 item7 ~ A1 + A2 + A3 + A1:A2 + A1:A3 + A2:A3 + A1:A2:A3 # Latent Variable Specifications: A1 A2 A3 <- latent(unit='rows',distribution='bernoulli',structure='univariate',type='ordinal') # Observed Variable Specifications: item1-item7 <- observed(distribution = 'bernoulli', link = 'probit') " paramVals = createParameterVector(modelText = RTHCh9ModelSyntax)
Used in blatentSyntax
to declare latent variables as an unevaluated function call.
Sets specifications used in estimation.
latent( unit = "rows", distribution = "bernoulli", structure = "univariate", link = "probit", type = "ordinal", meanIdentification = NULL, varianceIdentification = NULL, joint = NULL, vars = NULL )
latent( unit = "rows", distribution = "bernoulli", structure = "univariate", link = "probit", type = "ordinal", meanIdentification = NULL, varianceIdentification = NULL, joint = NULL, vars = NULL )
unit |
Attaches the unit (person) ID number or label to observations in data. Currently only allows "rows" which indicates each
row of the data is a separate unit in the model. Defaults to |
distribution |
Specifies the distribution of the latent variable(s) to which the function points. Defaults to
|
structure |
Specifies the type of distributional structure for the latent variables. Defaults to
|
link |
Specifies the link function used for any latent variable model where the latent variable is predicted.
Defaults to
|
type |
Specifies the type of latent variable to be estimated. Defaults to
|
meanIdentification |
Reserved for future use. |
varianceIdentification |
Reserved for future use. |
joint |
Specifies the name of the joint distribution of latent variables. Defaults to |
vars |
Reserved for future use. |
Used in blatentSyntax
to declare the distribution and link function for observed variables
as an unevaluated function call. Sets specifications used in estimation.
observed(distribution = "bernoulli", link = "probit")
observed(distribution = "bernoulli", link = "probit")
distribution |
Specifies the distribution of the observed variable(s) to which the function points. Defaults to
|
link |
Specifies the link function used for any observed variable model where the observed variable is predicted.
Defaults to
|
Converts a rectangular Q-matrix into blatent model syntax. Q-matrix must have observed variables listed across columns and latent variables listed across rows.
QmatrixToBlatentSyntax( Qmatrix, observedVariables = "rownames", latentVariables = "colnames", lvDist = "joint" )
QmatrixToBlatentSyntax( Qmatrix, observedVariables = "rownames", latentVariables = "colnames", lvDist = "joint" )
Qmatrix |
A data frame or matrix containing a Q-matrix. |
observedVariables |
If |
latentVariables |
A vector of the variable or column names of the latent variables. Defaults to |
lvDist |
A character that indicates the type of latent variable distribution to be used. |
A character vector containing blatent model syntax.
# Example 1: Joint distribution using data.frame # empty data.frame exampleQmatrixDF = data.frame(matrix(data = 0, nrow = 10, ncol = 3)) # name columns of Qmatrix names(exampleQmatrixDF) = c("observedVariableName", "Attribute1", "Attribute2") # names of observed variables exampleQmatrixDF[1:10, "observedVariableName"] = paste0("Item",1:10) # Entries for Qmatrix exampleQmatrixDF[1:5,"Attribute1"] = 1 exampleQmatrixDF[3:10,"Attribute2"] = 1 # produce blatentSyntax using QmatrixToBlatentSyntax() function blatentSyntaxJoint = QmatrixToBlatentSyntax( Qmatrix = exampleQmatrixDF, observedVariables = "observedVariableName", latentVariables = c("Attribute1", "Attribute2"), lvDist = "joint" ) cat(blatentSyntaxJoint) # Example 2: Univariate distributions using matrix # empty data.frame exampleQmatrixM = matrix(data = 0, nrow = 10, ncol = 2) # name columns of Qmatrix as latent variable names colnames(exampleQmatrixM) = c("Attribute1", "Attribute2") # name rows of Qmatrix as observed variable names rownames(exampleQmatrixM) = paste0("Item",1:10) # Entries for Qmatrix exampleQmatrixM[1:5,"Attribute1"] = 1 exampleQmatrixM[3:10,"Attribute2"] = 1 # produce blatentSyntax using QmatrixToBlatentSyntax() function # (with default options for observedVariables and latentVariables) blatentSyntaxM = QmatrixToBlatentSyntax(Qmatrix = exampleQmatrixM, lvDist = "univariate") cat(blatentSyntaxM)
# Example 1: Joint distribution using data.frame # empty data.frame exampleQmatrixDF = data.frame(matrix(data = 0, nrow = 10, ncol = 3)) # name columns of Qmatrix names(exampleQmatrixDF) = c("observedVariableName", "Attribute1", "Attribute2") # names of observed variables exampleQmatrixDF[1:10, "observedVariableName"] = paste0("Item",1:10) # Entries for Qmatrix exampleQmatrixDF[1:5,"Attribute1"] = 1 exampleQmatrixDF[3:10,"Attribute2"] = 1 # produce blatentSyntax using QmatrixToBlatentSyntax() function blatentSyntaxJoint = QmatrixToBlatentSyntax( Qmatrix = exampleQmatrixDF, observedVariables = "observedVariableName", latentVariables = c("Attribute1", "Attribute2"), lvDist = "joint" ) cat(blatentSyntaxJoint) # Example 2: Univariate distributions using matrix # empty data.frame exampleQmatrixM = matrix(data = 0, nrow = 10, ncol = 2) # name columns of Qmatrix as latent variable names colnames(exampleQmatrixM) = c("Attribute1", "Attribute2") # name rows of Qmatrix as observed variable names rownames(exampleQmatrixM) = paste0("Item",1:10) # Entries for Qmatrix exampleQmatrixM[1:5,"Attribute1"] = 1 exampleQmatrixM[3:10,"Attribute2"] = 1 # produce blatentSyntax using QmatrixToBlatentSyntax() function # (with default options for observedVariables and latentVariables) blatentSyntaxM = QmatrixToBlatentSyntax(Qmatrix = exampleQmatrixM, lvDist = "univariate") cat(blatentSyntaxM)
All parameters are initialized with distributions using these parameters. Used to quickly set priors for sets of parameters.
setDefaultInitializeParameters( normalMean = 0, normalVariance = 1, normalCovariance = 0, dirichletAlpha = 1 )
setDefaultInitializeParameters( normalMean = 0, normalVariance = 1, normalCovariance = 0, dirichletAlpha = 1 )
normalMean |
Sets the initialization distribution mean for all parameters with
normal distributions. Defaults to |
normalVariance |
Sets the initialization distribution variance for all parameters with
normal distributions. Defaults to |
normalCovariance |
Sets the initialization distribution covariance for all parameters with
multivariate normal distributions. Defaults to |
dirichletAlpha |
Sets the initialization of the alpha parameters for all parameters with a categorical distribution.
Defaults to |
A list containing named values for each argument in the function.
All parameters not named in priorsList, an input argument to
blatentEstimate
, recieve these parameters if their prior distributions
are of the same family. Used to quickly set priors for sets of parameters.
setDefaultPriors( normalMean = 0, normalVariance = 1, normalCovariance = 0, dirichletAlpha = 1 )
setDefaultPriors( normalMean = 0, normalVariance = 1, normalCovariance = 0, dirichletAlpha = 1 )
normalMean |
Sets the prior distribution mean for all parameters with
normal distributions not named in priorsList. Defaults to |
normalVariance |
Sets the prior distribution variance for all parameters with
normal distributions not named in priorsList. Defaults to |
normalCovariance |
Sets the prior distribution covariance for all parameters with
multivariate normal distributions not named in priorsList. Defaults to |
dirichletAlpha |
Sets the prior distribution parameter values when variable distributions are Dirichlet. Defaults to |
A list containing named values for each argument in the function.
Sets the specifications for the generation of the types of parameters in the simulation. Currently comprised of a list of unevaluated expressions (encapsulated in quotation marks; not calls for ease of user input) that will be evaluated by simulation function to generate parameters. Input must be in the form of a random number generation function to be called, surrounded by quotation marks.
setDefaultSimulatedParameters( observedIntercepts = "runif(n = 1, min = -2, max = 2)", observedMainEffects = "runif(n = 1, min = 0, max = 2)", observedInteractions = "runif(n = 1, min = -2, max = 2)", latentIntercepts = "runif(n = 1, min = -1, max = 1)", latentMainEffects = "runif(n = 1, min = -1, max = 1)", latentInteractions = "runif(n = 1, min = -0.5, max = 0.5)", latentJointMultinomial = "rdirichlet(n = 1, alpha = rep(1,nCategories))" )
setDefaultSimulatedParameters( observedIntercepts = "runif(n = 1, min = -2, max = 2)", observedMainEffects = "runif(n = 1, min = 0, max = 2)", observedInteractions = "runif(n = 1, min = -2, max = 2)", latentIntercepts = "runif(n = 1, min = -1, max = 1)", latentMainEffects = "runif(n = 1, min = -1, max = 1)", latentInteractions = "runif(n = 1, min = -0.5, max = 0.5)", latentJointMultinomial = "rdirichlet(n = 1, alpha = rep(1,nCategories))" )
observedIntercepts |
The data generating function for all intercepts for observed variables. Defaults to |
observedMainEffects |
The data generating function for the main effects for observed variables. Defaults to |
observedInteractions |
The data generating function for all interactions for observed variables. Defaults to |
latentIntercepts |
The data generating function for all intercepts for Bernoulli latent variables modeled with univariate structural models. Defaults to |
latentMainEffects |
The data generating function for the main effects for Bernoulli latent variables modeled with univariate structural models. Defaults to |
latentInteractions |
The data generating function for all interactions for Bernoulli latent variables modeled with univariate structural models. Defaults to |
latentJointMultinomial |
The data generating function for all interactions for multivariate Bernoulli latent variables modeled with joint structural models.
Defaults to |
Provides a list of posterior predictive model checks to be run following estimation of a blatent model. Currently six types of posterior predictive model checks (PPMCs) are available: univarate: mean and univariate Chi-square statistic, bivariate: covariance, tetrachoric correlation, pearson correlation, and bivariate Chi-square statistic.
setPosteriorPredictiveCheckOptions( estimatePPMC = TRUE, PPMCsamples = 1000, PPMCtypes = c("mean", "covariance", "univariate", "bivariate", "tetrachoric", "pearson"), lowPPMCpercentile = c(0.025, 0.025, 0, 0, 0.025, 0.025), highPPMCpercentile = c(0.975, 0.975, 1, 1, 0.975, 0.975) )
setPosteriorPredictiveCheckOptions( estimatePPMC = TRUE, PPMCsamples = 1000, PPMCtypes = c("mean", "covariance", "univariate", "bivariate", "tetrachoric", "pearson"), lowPPMCpercentile = c(0.025, 0.025, 0, 0, 0.025, 0.025), highPPMCpercentile = c(0.975, 0.975, 1, 1, 0.975, 0.975) )
estimatePPMC |
If |
PPMCsamples |
The number of samples from the posterior distribution and simulated PPMC data sets. |
PPMCtypes |
The type of PPMC tests to conduct. For each test, the statistic listed is calculated on each PPMC-based simulated data set. Comparisons are made with the values of the statistics calculated on the original data set. Currently six PPMC statistics are available:
|
lowPPMCpercentile |
A vector of length equal to the length and number of |
highPPMCpercentile |
A vector of length equal to the length and number of |
A list of named values containing a logical value for each parameter above.