olmm {vcrpart} | R Documentation |
Fitting ordinal and nominal two-stage linear mixed models
Description
Fits different types of two-stage linear mixed models for longitudinal (or clustered) ordinal (or multinomial) responses. O ne-stage models are also allowed. Random effects are assumed to be multivariate normal distributed with expectation 0. At the time being, cumulative link models with the logit, probit or cauchy link, the baseline-category logit and the adjacent-category logit model are implemented. Coefficients can be category-specific (i.e. non-proportional odds effects) or global (i.e. proportional odds, or parallel effects).
The function solves the score function for coefficients of the marginal likelihood by using Gauss-Hermite quadrature (e.g., Hedeker; 1994). Random effects are predicted by their expectation (see Hartzl et al.; 2001). Standard deviations of parameter estimates are, by default, based on the expected Fisher-information matrix.
Usage
cumulative(link = c("logit", "probit", "cauchy"))
adjacent(link = "logit")
baseline(link = "logit")
olmm(formula, data, family = cumulative(),
weights, subset, na.action = na.omit,
offset, contrasts, control = olmm_control(), ...)
Arguments
formula |
a symbolic description of the model. This should be something like
where |
data |
an optional data frame with the variables
in |
family |
an |
weights |
a numeric vector of weights with length equal the number of observations. The weights should be constant for subjects. |
offset |
a matrix specifying the offset separately for each predictor equation, of which there are the number of categories of the response minus one. |
subset , na.action , contrasts |
further model
specification arguments as in |
control |
a list of control parameters produced by
|
link |
character string. The name of the link function. |
... |
arguments to be passed to |
Details
The function can be used to fit simple ordinal two-stage mixed effect models with up to 3-4 random effects. For models with higher dimensions on random effects, the procedure may not convergence (cf. Tutz; 1996). Coefficients for the adjacent-category logit model are extracted via coefficient transformation (e.g. Agresti; 2010).
The three implemented families are defined as follows:
cumulative
is defined as the link of the sum of
probabilities of lower categories, e.g., for link = "logit"
,
the logit of the sum of probabilities of lower
categories. adjacent
is defined as the logit of
the probability of the lower of two adjacent
categories. baseline
is defined as the logit of the
probability of a category with reference to the highest
category. Notice that the estimated coefficients of cumulative models
may have the opposite sign those obtained with alternative software.
For alternative fitting functions, see for example the
functions clmm
of ordinal,
nplmt
of package mixcat,
DPolmm
of package DPpackage,
lcmm
of package lcmm,
MCMCglmm
of package MCMCglmm or
OrdinalBoost
of package GMMBoost.
The implementation adopts functions of the packages statmod (Novomestky, 2012) and matrixcalc (Smyth et al., 2014), which is not visible for the user. The authors are grateful for these codes.
The formula
argument specifies the model to be
fitted. Categorical regression models distinguish between global
effects (or proportional-odds effects), which are defined with
ge
terms, and category-specific effects, which are
defined by ce
terms. For undefined terms, the
function will use ge
terms. Notice that this default
does not necessarily yield interpretable outputs. For example, for the
baseline
model you may use only ce
terms, which must be specified manually manually. See the example
below. For cumulative
models at present it is not
possible to specifiy ce
for the random effects
component because the internal, unconstraint integration would
yield unusable predictor values.
Value
olmm
returns an object of class
olmm
. cumulative
,
adjacent
and baseline
yield an
object of class family.olmm
. The olmm
class is
a list containing the following components:
env |
environment in which the object was built. |
frame |
the model frame. |
call |
the matched call to the function that created the object
(class |
control |
a list of class |
formula |
the formula of the call. |
terms |
a list of |
family |
an object of class |
y |
(ordered) categorical response vector. |
X |
model matrix for the fixed effects. |
W |
model matrix for the random effects. |
subject |
a factor vector with grouping levels. |
subjectName |
variable name of the subject vector. |
weights |
numeric observations weights vector. |
weights_sbj |
numeric weights vector of length N. |
offset |
numeric offset matrix |
xlevels |
(only where relevant) a list of levels of the factors used in fitting. |
contrasts |
(only where relevant) a list of contrasts used. |
dims |
a named integer of dimensions. Some of the
dimensions are |
fixef |
a matrix of fixed effects (one column for each predictor). |
ranefCholFac |
a lower triangular matrix. The cholesky decomposition of the covariance matrix of the random effects. |
coefficients |
a numeric vector of several fitted model parameters |
restricted |
a logical vector indicating which elements
of the |
eta |
a matrix of unconditional linear predictors of the fixed effects without random effects. |
u |
a matrix of orthogonal standardized random effects (one row for each subject level). |
logLik_obs |
a numeric vector of log likelihood value (one value for each observation). |
logLik_sbj |
a numeric vector of log likelihood values (one value for each subject level). |
logLik |
a numeric value. The log likelihood of the model. |
score_obs |
a matrix of observation-wise partial derivates of the marginal log-likelihood equation. |
score_sbj |
a matrix of subject-wise partial derivates of the marginal log-likelihood equation. |
score |
a numeric vector of (total) partial derivates of the log-Likelihood function. |
info |
the information matrix (default is the expected information). |
ghx |
a matrix of quadrature points for the Gauss-Hermite quadrature integration. |
ghw |
a matrix of weights for the Gauss-Hermite quadrature integration. |
ranefElMat |
a transformation matrix |
optim |
a list of arguments for calling the optimizer function. |
control |
a list of used control arguments produced by
|
output |
the output of the optimizer (class
|
Author(s)
Reto Burgin
References
Agresti, A. (2010). Analysis of Ordinal Categorical Data (2 ed.). New Jersey, USA: John Wiley & Sons.
Hartzel, J., A. Agresti and B. Caffo (2001). Multinomial Logit Random Effect Models, Statistical Modelling 1(2), 81–102.
Hedeker, D. and R. Gibbons (1994). A Random-Effects Ordinal Regression Model for Multilevel Analysis, Biometrics 20(4), 933–944.
Tutz, G. and W. Hennevogl (1996). Random Effects in Ordinal Regression Models, Computational Statistics & Data Analysis 22(5), 537–557.
Tutz, G. (2012). Regression for Categorical Data. New York, USA: Cambridge Series in Statistical and Probabilistic Mathematics.
Novomestky, F. (2012). matrixcalc: Collection of Functions for Matrix Calculations. R package version 1.0-3. URL https://CRAN.R-project.org/package=matrixcalc
Smyth, G., Y. Hu, P. Dunn, B. Phipson and Y. Chen (2014). statmod: Statistical Modeling. R package version 1.4.20. URL https://CRAN.R-project.org/package=statmod
See Also
olmm-methods
, olmm_control
,
ordered
Examples
## ------------------------------------------------------------------- #
## Example 1: Schizophrenia
##
## Estimating the cumulative mixed models of
## Agresti (2010) chapters 10.3.1
## ------------------------------------------------------------------- #
data(schizo)
model.10.3.1 <-
olmm(imps79o ~ tx + sqrt(week) + re(1|id),
data = schizo, family = cumulative())
summary(model.10.3.1)
## ------------------------------------------------------------------- #
## Example 2: Movie critics
##
## Estimating three of several adjacent-categories
## mixed models of Hartzl et. al. (2001)
## ------------------------------------------------------------------- #
data(movie)
## model with category-specific effects for "review"
model.24.1 <- olmm(critic ~ ce(review) + re(1|movie, intercept = "ce"),
data = movie, family = adjacent())
summary(model.24.1)