specifyModel(file="", text, exog.variances=FALSE, endog.variances=TRUE, covs,
suffix="", quiet=FALSE)
specifyEquations(file="", text, ...)
cfa(file="", text, covs=paste(factors, collapse=","),
reference.indicators=TRUE, raw=FALSE,
subscript=c("name", "number"), ...)
multigroupModel(..., groups=names(models), allEqual=FALSE)
classifyVariables(model)
removeRedundantPaths(model, warn=TRUE)
## S3 method for class 'semmod':
combineModels(..., warn=TRUE)
## S3 method for class 'semmod':
update(object, file = "", text, ...)
## S3 method for class 'semmod':
edit(name, ...)
## S3 method for class 'semmod':
print(x, ...)
## S3 method for class 'semmodList':
print(x, ...)"" (the default) and the text argument is not supplied,
then the specification TRUE (the default is FALSE), free variance
parameters are added for the exogenous variables that lack them.TRUE (the default), free error-variance parameters
are added for the endogenous variables that lack them.FALSE, the default, variances of factors are
set to 1 by cfa; if TRUE, variances of factors are free parameters
to estimate from the data, and instead the first factor loading for each factor is set
TRUE (the default is FALSE), a path from Intercept to each
observed variable is added to the model, and the raw second moment for Intercept is
fixed to 1. The sem flam to name factor-loading parameters,
either "name" (the default) to use the names of observed variables, or "number" to
number the parameters serially witFALSE, the default, then the number of input lines is reported and
a message is printed suggesting that specifyEquations or cfa be used.semmod or semmodList, as produced by
specifyModel or multigroupModel.multigroupModel, one or more optionally named arguments each of
which is a semmod object produced, e.g., by specifyModel, specifyEquations,
or cfa; if only one such model is ... arguments.FALSE (the default), then if only one model object is given for
a multigroup model, all corresponding parameters in the groups will be distinct; if TRUE,
all corresponding parameters will be constrained to be equal.specifyModel,
to specify a model in RAM (path) format via single- and double-headed arrows;
specifyEquations, to specify a model in equation format, which is then
translated by the function into RAM format; and cfa, for compact
specification of simple confirmatory factor analysis models.
specifyModel:
Each line of the RAM specification for specifyModel consists of three (unquoted) entries,
separated by commas:
[object Object],[object Object],[object Object]
Lines may end in a comment following #}.
specifyEquations:
For specifyEquations, each input line is either a regression equation or the specification
of a variance or covariance. Regression equations are of the form
y = par1*x1 + par2*x2 + ... + park*xk
where y and the xs are variables in the model (either observed or latent),
and the pars are parameters. If a parameter is given as a numeric value (e.g.,
1) then it is treated as fixed. Note that no error variable is included in
the equation; error variances are specified via either the covs argument,
via V(y) = par (see immediately below), or are added automatically to the model
when, as by default, endog.variances=TRUE. A regression equation may be split over more
than one input by breaking at a +, so that + is either the last non-blank character
on a line or the first non-blank character on the subsequent line.
Variances are specified in the form V(var) = par and covariances in the form
C(var1, var2) = par, where the vars are variables (observed or unobserved) in
the model. The symbols V and C may be in either lower- or upper-case. If par
is a numeric value (e.g., 1) then it is treated as fixed. In conformity with the RAM model,
a variance or covariance for an endogenous variable in the model is an error variance or
covariance.
Warning: If the covs argument to specifyEquations is used to specify
variances and covariances, please be aware that
covs="x1, x2" and covs=c("x1", "x2") are not
equivalent: covs="x1, x2" specifies the variance of x1, the variance
of x2, and their covariance, while covs=c("x1", "x2") specifies
the variance of x1 and the variance of x2 but not their covariance.
To set a start value for a free parameter, enclose the numeric start value in parentheses after the
parameter name, as parameter(value).
cfa:
For cfa, each input line includes the names of the variables, separated by commas,
that load on the corresponding factor; the name of the factor is given optionally at the beginning
of the line, followed by a colon. If necessary, the variables that load on a factor may be continued
across two or more input lines; in this case, each such line but the last must end in a comma. A
variable may load on more than one factor (as long as the resulting model is identified, of course),
but each factor may appear in only one input line (or set of input lines, if the variable list
is continued onto the next line).
Equality constraints for factor loadings can be set by using equal-signs (=) rather than commas
to separate observed variable names. For example, fac1: x1=x2=x3, x4=x5 sets the loadings
for x1, x2, and x3 equal to each other, and the loadings for x4 and x5
equal to each other.
Equality constraints among error variances can similarly be specified by using var: or variance:
at the beginning of a line (actually, any character string beginning with var will do, and thus
no factor name may begin with the characters var). For example, var: x1=x2=x3, x4=x5 sets the
error variances for x1, x2, and x3 equal to each other, and the
error variances for x4 and x5 equal to each other. There may be several lines beginning with
var:.
If the argument reference.indicators=FALSE, the default,
cfa will fix the variance of each factor to 1, and by
default include covariances (i.e., correlations) among all pairs of factors. Alternatively,
if reference.indicators=TRUE, then the factor variances are free parameters to be estimated
from the data, and the first loading for each factor is set to 1 to identify the model. These two
approaches produce equivalent models, with the same fit to the data, but alternative parametrizations.
Specifying the argument covs=NULL implicitly fixes the factor intercorrelations to 0.
See sem and the examples for further details on model specification.
Other Functions:
classifyVariables classifies the variables in a model as endogenous or exogenous.
combineModels and removeRedundantPaths take semmod objects as arguments and do what their names imply.
The file input argument to the update method for semmod objects, which by default comes from
standard input, is a set of update directives, one per line. There are five kinds of directives. In each case
the directive begins with the directive name, followed by one or more fields separated by commas.
[object Object],[object Object],[object Object],[object Object],[object Object]
The edit method for semmod objects opens the model in the R editor.
specifyModel, specifyEquations, cfa, removeRedundantPaths, combineModels,
update, and edit return an object of class semmod, suitable as input for sem.
multigroupModel returns an object of class semmodList, also suitable as input for sem.
classifyVariables returns a list with two character vectors: endogenous, containing the names of endogenous
variables in the model; and exogenous, containing the names of exogenous variables.sem