Manual Stata 13

Download as pdf or txt
Download as pdf or txt
You are on page 1of 371

STATA MULTILEVEL MIXED-EFFECTS

REFERENCE MANUAL
RELEASE 13

A Stata Press Publication


StataCorp LP
College Station, Texas

Copyright c 19852013 StataCorp LP


All rights reserved
Version 13

Published by Stata Press, 4905 Lakeway Drive, College Station, Texas 77845
Typeset in TEX
ISBN-10: 1-59718-119-6
ISBN-13: 978-1-59718-119-8
This manual is protected by copyright. All rights are reserved. No part of this manual may be reproduced, stored
in a retrieval system, or transcribed, in any form or by any meanselectronic, mechanical, photocopy, recording, or
otherwisewithout the prior written permission of StataCorp LP unless permitted subject to the terms and conditions
of a license granted to you by StataCorp LP to use the software and documentation. No license, express or implied,
by estoppel or otherwise, to any intellectual property rights is granted by this document.
StataCorp provides this manual as is without warranty of any kind, either expressed or implied, including, but
not limited to, the implied warranties of merchantability and fitness for a particular purpose. StataCorp may make
improvements and/or changes in the product(s) and the program(s) described in this manual at any time and without
notice.
The software described in this manual is furnished under a license agreement or nondisclosure agreement. The software
may be copied only in accordance with the terms of the agreement. It is against the law to copy the software onto
DVD, CD, disk, diskette, tape, or any other medium for any purpose other than backup or archival purposes.
The automobile dataset appearing on the accompanying media is Copyright c 1979 by Consumers Union of U.S.,
Inc., Yonkers, NY 10703-1057 and is reproduced by permission from CONSUMER REPORTS, April 1979.
Stata,

, Stata Press, Mata,

, and NetCourse are registered trademarks of StataCorp LP.

Stata and Stata Press are registered trademarks with the World Intellectual Property Organization of the United Nations.
NetCourseNow is a trademark of StataCorp LP.
Other brand and product names are registered trademarks or trademarks of their respective companies.
For copyright information about the software, type help copyright within Stata.

The suggested citation for this software is


StataCorp. 2013. Stata: Release 13 . Statistical Software. College Station, TX: StataCorp LP.

Contents
me . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Introduction to multilevel mixed-effects models

mecloglog . . . . . . . . . . . . . . . . . . Multilevel mixed-effects complementary log-log regression

37

mecloglog postestimation . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for mecloglog

51

meglm . . . . . . . . . . . . . . . . . . . . . . . . . . . . Multilevel mixed-effects generalized linear model

56

meglm postestimation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for meglm

81

melogit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Multilevel mixed-effects logistic regression

98

melogit postestimation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for melogit 112


menbreg . . . . . . . . . . . . . . . . . . . . . . . . Multilevel mixed-effects negative binomial regression 120
menbreg postestimation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for menbreg 137
meologit . . . . . . . . . . . . . . . . . . . . . . . . . . Multilevel mixed-effects ordered logistic regression 141
meologit postestimation . . . . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for meologit 155
meoprobit . . . . . . . . . . . . . . . . . . . . . . . . . . Multilevel mixed-effects ordered probit regression 160
meoprobit postestimation . . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for meoprobit 174
mepoisson . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Multilevel mixed-effects Poisson regression 179
mepoisson postestimation . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for mepoisson 193
meprobit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Multilevel mixed-effects probit regression 197
meprobit postestimation . . . . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for meprobit 210
meqrlogit . . . . . . . . . . . . . . Multilevel mixed-effects logistic regression (QR decomposition) 218
meqrlogit postestimation . . . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for meqrlogit 242
meqrpoisson . . . . . . . . . . . . Multilevel mixed-effects Poisson regression (QR decomposition) 258
meqrpoisson postestimation . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for meqrpoisson 276
mixed . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Multilevel mixed-effects linear regression 285
mixed postestimation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Postestimation tools for mixed 336
Glossary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

355

Subject and author index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

359

Cross-referencing the documentation


When reading this manual, you will find references to other Stata manuals. For example,
[U] 26 Overview of Stata estimation commands
[R] regress
[D] reshape

The first example is a reference to chapter 26, Overview of Stata estimation commands, in the Users
Guide; the second is a reference to the regress entry in the Base Reference Manual; and the third
is a reference to the reshape entry in the Data Management Reference Manual.
All the manuals in the Stata Documentation have a shorthand notation:
[GSM]
[GSU]
[GSW]
[U ]
[R]
[D ]
[G ]
[XT]
[ME]
[MI]
[MV]
[PSS]
[P ]
[SEM]
[SVY]
[ST]
[TS]
[TE]
[I]

Getting Started with Stata for Mac


Getting Started with Stata for Unix
Getting Started with Stata for Windows
Stata Users Guide
Stata Base Reference Manual
Stata Data Management Reference Manual
Stata Graphics Reference Manual
Stata Longitudinal-Data/Panel-Data Reference Manual
Stata Multilevel Mixed-Effects Reference Manual
Stata Multiple-Imputation Reference Manual
Stata Multivariate Statistics Reference Manual
Stata Power and Sample-Size Reference Manual
Stata Programming Reference Manual
Stata Structural Equation Modeling Reference Manual
Stata Survey Data Reference Manual
Stata Survival Analysis and Epidemiological Tables Reference Manual
Stata Time-Series Reference Manual
Stata Treatment-Effects Reference Manual:
Potential Outcomes/Counterfactual Outcomes
Stata Glossary and Index

[M ]

Mata Reference Manual

iii

Title
me Introduction to multilevel mixed-effects models
Syntax by example
Acknowledgments

Formal syntax
References

Description
Also see

Remarks and examples

Syntax by example
Linear mixed-effects models
Linear model of y on x with random intercepts by id
mixed y x || id:
Three-level linear model of y on x with random intercepts by doctor and patient
mixed y x || doctor: || patient:
Linear model of y on x with random intercepts and coefficients on x by id
mixed y x || id: x
Same model with covariance between the random slope and intercept
mixed y x || id: x, covariance(unstructured)
Linear model of y on x with crossed random effects for id and week
mixed y x || _all: R.id || _all: R.week
Same model specified to be more computationally efficient
mixed y x || _all: R.id || week:
Full factorial repeated-measures ANOVA of y on a and b with random effects by field
mixed y a##b || field:
Generalized linear mixed-effects models
Logistic model of y on x with random intercepts by id, reporting odds ratios
melogit y x || id: , or
Same model specified as a GLM
meglm y x || id:, family(bernoulli) link(logit)
Three-level ordered probit model of y on x with random intercepts by doctor and
patient
meoprobit y x || doctor: || patient:

me Introduction to multilevel mixed-effects models

Formal syntax
Linear mixed-effects models
mixed depvar fe equation

|| re equation

|| re equation . . .

, options

where the syntax of the fixed-effects equation, fe equation, is


indepvars

if

in

weight

, fe options

and the syntax of a random-effects equation, re equation, is the same as below for a generalized
linear mixed-effects model.

Generalized linear mixed-effects models


mecmd depvar fe equation

|| re equation

|| re equation . . .

, options

where the syntax of the fixed-effects equation, fe equation, is


indepvars

if

in

, fe options

and the syntax of a random-effects equation, re equation, is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.

Description
Mixed-effects models are characterized as containing both fixed effects and random effects. The
fixed effects are analogous to standard regression coefficients and are estimated directly. The random
effects are not directly estimated (although they may be obtained postestimation) but are summarized
according to their estimated variances and covariances. Random effects may take the form of either
random intercepts or random coefficients, and the grouping structure of the data may consist of
multiple levels of nested groups. As such, mixed-effects models are also known in the literature as
multilevel models and hierarchical models. Mixed-effects commands fit mixed-effects models for a
variety of distributions of the response conditional on normally distributed random effects.

me Introduction to multilevel mixed-effects models

Mixed-effects linear regression


mixed
Multilevel mixed-effects linear regression

Mixed-effects generalized linear model


meglm
Multilevel mixed-effects generalized linear model

Mixed-effects binary regression


melogit
Multilevel mixed-effects
meqrlogit
Multilevel mixed-effects
meprobit
Multilevel mixed-effects
mecloglog
Multilevel mixed-effects

logistic regression
logistic regression (QR decomposition)
probit regression
complementary log-log regression

Mixed-effects ordinal regression


meologit
Multilevel mixed-effects ordered logistic regression
meoprobit
Multilevel mixed-effects ordered probit regression

Mixed-effects count-data regression


mepoisson
Multilevel mixed-effects Poisson regression
meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)
menbreg
Multilevel mixed-effects negative binomial regression

Mixed-effects multinomial regression


Although there is no memlogit command, multilevel mixed-effects multinomial
logistic models can be fit using gsem; see [SEM] example 41g.

Remarks and examples


Remarks are presented under the following headings:
Introduction
Using mixed-effects commands
Mixed-effects models
Linear mixed-effects models
Generalized linear mixed-effects models
Alternative mixed-effects model specification
Likelihood calculation
Computation time and the Laplacian approximation
Diagnosing convergence problems
Distribution theory for likelihood-ratio test
Examples
Two-level models
Covariance structures
Three-level models
Crossed-effects models

me Introduction to multilevel mixed-effects models

Introduction
Multilevel models have been used extensively in diverse fields, from the health and social sciences
to econometrics. Mixed-effects models for binary outcomes have been used, for example, to analyze
the effectiveness of toenail infection treatments (Lesaffre and Spiessens 2001) and to model union
membership of young males (Vella and Verbeek 1998). Ordered outcomes have been studied by, for
example, Tutz and Hennevogl (1996), who analyzed data on wine bitterness, and De Boeck and
Wilson (2004), who studied verbal aggressiveness. For applications of mixed-effects models for count
responses, see, for example, the study on police stops in New York City (Gelman and Hill 2007)
and the analysis of the number of patents (Hall, Griliches, and Hausman 1986). Rabe-Hesketh and
Skrondal (2012) provide more examples of linear and generalized linear mixed-effects models.
For a comprehensive treatment of mixed-effects models, see, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and
Skrondal (2012).

Using mixed-effects commands


Below we summarize general capabilities of the mixed-effects commands. We let mecmd stand
for any mixed-effects command, such as mixed, melogit, or meprobit.
1. Fit a two-level random-intercept model with levelvar defining the second level:
. mecmd depvar

indepvars

. . . || levelvar:, . . .

2. Fit a two-level random-coefficients model containing the random-effects covariates revars at the
level levelvar:
. mecmd depvar

indepvars

. . . || levelvar: revars, . . .

This model assumes an independent covariance structure between the random effects; that is, all
covariances are assumed to be 0. There is no statistical justification, however, for imposing any
particular covariance structure between random effects at the onset of the analysis. In practice,
models with an unstructured random-effects covariance matrix, which allows for distinct variances
and covariances between all random-effects covariates (revars) at the same level, must be explored
first; see Other covariance structures and example 3 in [ME] meqrlogit for details.
Statas commands use the default independent covariance structure for computational feasibility.
Numerical methods for fitting mixed-effects models are computationally intensivecomputation
time increases significantly as the number of parameters increases; see Computation time and the
Laplacian approximation for details. The unstructured covariance is the most general and contains
many parameters, which may result in an unreasonable computation time even for relatively simple
random-effects models. Whenever feasible, however, you should start your statistical analysis
by fitting mixed-effects models with an unstructured covariance between random effects, as we
show next.
3. Specify the unstructured covariance between the random effects in the above:
. mecmd depvar

indepvars

. . . || levelvar: revars, covariance(unstructured) . . .

4. Fit a three-level nested model with levelvar1 defining the third level and levelvar2 defining the
second level:
. mecmd depvar

indepvars

. . . || levelvar1: || levelvar2:, . . .

me Introduction to multilevel mixed-effects models

5. Fit the above three-level nested model as a two-level model with exchangeable covariance structure
at the second level (mixed, meqrlogit, and meqrpoisson only):
. mecmd depvar

indepvars

. . . || levelvar1: R.levelvar2, cov(exchangeable) . . .

See example 11 in [ME] mixed for details about this equivalent specification. This specification
may be useful for a more efficient fitting of random-effects models with a mixture of crossed
and nested effects.
6. Fit higher-level nested models:
. mecmd depvar

indepvars

. . . || levelvar1: || levelvar2: || levelvar3: || . . .

7. Fit a two-way crossed-effects model with the all: notation for each random-effects equation:
. mecmd depvar

indepvars

. . . || _all: R.factor1 || _all: R.factor2 . . .

When you use the all: notation for each random-effects equation, the total dimension of the
random-effects design equals r1 + r2 , where r1 and r2 are the numbers of levels in factor1 and
factor2, respectively. This specification may be infeasible for some mixed-effects models; see
item 8 below for a more efficient specification of this model.
8. Fit a two-way crossed-effects model with the all: notation for the first random-effects equation
only:
. mecmd depvar

indepvars

. . . || _all: R.factor1 || factor2:, . . .

Compared with the specification in item 7, this specification requires only r1 + 1 parameters and
is thus more efficient; see Crossed-effects models for details.
9. Fit a two-way full-factorial random-effects model:
. mecmd depvar

indepvars

. . . || _all: R.factor1 || factor2: || factor1: . . .

10. Fit a two-level mixed-effects model with a blocked-diagonal covariance structure between revars1
and revars2:
. mecmd depvar

indepvars

. . . || levelvar: revars1, noconstant ///


|| levelvar: revars2, noconstant . . .

11. Fit a linear mixed-effects model where the correlation between the residual errors follows an
autoregressive process of order 1:
. mixed depvar

indepvars

. . . || levelvar:, residuals(ar 1, t(time)) . . .

More residual error structures are available; see [ME] mixed for details.
12. Fit a two-level linear mixed-effects model accounting for sampling weights expr1 at the first
(residual) level and for sampling weights expr2 at the level of levelvar:
. mixed depvar

indepvars

[pweight=expr1]

. . . || levelvar:, pweight(expr2) . . .

Mixed-effects commandswith the exception of mixed, meqrlogit, and meqrpoissonallow


constraints on both fixed-effects and random-effects parameters. We provide several examples
below of imposing constraints on variance components.
13. Fit a mixed-effects model with the variance of the random intercept on levelvar constrained to
be 16:
. constraint 1 _b[var(_cons[levelvar]):_cons]=16
. mecmd depvar

indepvars

. . . || levelvar:, constraints(1) . . .

me Introduction to multilevel mixed-effects models

14. Fit a mixed-effects model with the variance of the random intercept on levelvar and the variance
of the random slope on revar to be equal:
. constraint 1 _b[var(revar[levelvar]):_cons] = _b[var(_cons[levelvar]):_cons]
. mecmd depvar

indepvars

. . . || levelvar: revar, constraints(1) . . .

Note that the constraints above are equivalent to imposing an identity covariance structure for
the random-effects equation:
. mecmd depvar

indepvars

. . . || levelvar: revar, cov(identity) . . .

15. Assuming four random slopes revars, fit a mixed-effects model with the variance components at
the level of levelvar constrained to have a banded structure:
. mat p = (1,.,.,. \ 2,1,.,. \ 3,2,1,. \ 4,3,2,1)
. mecmd depvar indepvars . . . || levelvar: revars, noconstant ///
covariance(pattern(p)) . . .

16. Assuming four random slopes revars, fit a mixed-effects model with the variance components at
the level of levelvar constrained to the specified numbers, and with all the covariances constrained
to be 0:
. mat f = diag((1,2,3,4))
. mecmd depvar indepvars
covariance(fixed(f))

. . . || levelvar: revars, noconstant ///


...

The variance components in models in items 15 and 16 can also be constrained by using the
constraints() option, but using covariance(pattern()) or covariance(fixed()) is more
convenient.

Mixed-effects models
Linear mixed-effects models

Mixed-effects models for continuous responses, or linear mixed-effects (LME) models, are a
generalization of linear regression allowing for the inclusion of random deviations (effects) other than
those associated with the overall error term. In matrix notation,

y = X + Zu +

(1)

where y is the n 1 vector of responses, X is an n p design/covariate matrix for the fixed effects
, and Z is the n q design/covariate matrix for the random effects u. The n 1 vector of errors
is assumed to be multivariate normal with mean 0 and variance matrix 2 R.
The fixed portion of (1), X, is analogous to the linear predictor from a standard OLS regression
model with being the regression coefficients to be estimated. For the random portion of (1), Zu + ,
we assume that u has variancecovariance matrix G and that u is orthogonal to so that
Var

G
0
0 2 R

The random effects u are not directly estimated (although they may be predicted) but instead are
characterized by the elements of G, known as variance components, that are estimated along with
the overall residual variance 2 and the residual-variance parameters that are contained within R.

me Introduction to multilevel mixed-effects models

The general forms of the design matrices X and Z allow estimation for a broad class of linear
models: blocked designs, split-plot designs, growth curves, multilevel or hierarchical designs, etc.
They also allow a flexible method of modeling within-cluster correlation. Subjects within the same
cluster can be correlated as a result of a shared random intercept, or through a shared random slope
on age (for example), or both. The general specification of G also provides additional flexibility: the
random intercept and random slope could themselves be modeled as independent, or correlated, or
independent with equal variances, and so forth. The general structure of R also allows for residual
errors to be heteroskedastic and correlated and allows flexibility in exactly how these characteristics
can be modeled.
In clustered-data situations, it is convenient not to consider all n observations at once but instead
to organize the mixed model as a series of M independent groups (or clusters)

yj = Xj + Zj uj +

(2)

for j = 1, . . . , M , with cluster j consisting of nj observations. The response yj comprises the rows
of y corresponding with the j th cluster, with Xj and j defined analogously. The random effects uj
can now be thought of as M realizations of a q 1 vector that is normally distributed with mean 0
and q q variance matrix . The matrix Zj is the nj q design matrix for the j th cluster random
effects. Relating this to (1),

Z1 0 0

u1
0 Z2 0
... ; G = IM ; R = IM
Z=
(3)
..
..
..
...
; u =
.
.
.
uM
0
0
0 ZM
where denotes the variance matrix of the level-1 residuals and is the Kronecker product.
The mixed-model formulation (2) is from Laird and Ware (1982) and offers two key advantages.
First, it makes specifications of random-effects terms easier. If the clusters are schools, you can
simply specify a random effect at the school level, as opposed to thinking of what a school-level
random effect would mean when all the data are considered as a whole (if it helps, think Kronecker
products). Second, representing a mixed-model with (2) generalizes easily to more than one set of
random effects. For example, if classes are nested within schools, then (2) can be generalized to
allow random effects at both the school and the class-within-school levels.
In Stata, you can use mixed to fit linear mixed-effects models; see [ME] mixed for a detailed
discussion and examples. Various predictions, statistics, and diagnostic measures are available after
fitting an LME model with mixed. For the most part, calculation centers around obtaining estimates
of random effects; see [ME] mixed postestimation for a detailed discussion and examples.
Generalized linear mixed-effects models

Generalized linear mixed-effects (GLME) models, also known as generalized linear mixed models
(GLMMs), are extensions of generalized linear models allowing for the inclusion of random deviations
(effects). In matrix notation,

g E(y|X, u) = X + Zu,

yF

(4)

where y is the n 1 vector of responses from the distributional family F , X is an np design/covariate


matrix for the fixed effects , and Z is an n q design/covariate matrix for the random effects u.
The X + Zu part is called the linear predictor and is often denoted as . g() is called the link
function and is assumed to be invertible such that

E(y|u) = g 1 (X + Zu) = h() =

me Introduction to multilevel mixed-effects models

For notational convenience here and throughout this manual entry, we suppress the dependence of y
on X. Substituting various definitions for g() and F results in a wide array of models. For instance,
if g() is the logit function and y is distributed as Bernoulli, we have
logit E(y) = X + Zu,

y Bernoulli

or mixed-effects logistic regression. If g() is the natural log function and y is distributed as Poisson,
we have
ln E(y) = X + Zu,
y Poisson
or mixed-effects Poisson regression.
In Stata, you can use meglm to fit mixed-effects models for nonlinear responses. Some combinations
of families and links are so common that we implemented them as separate commands in terms of
meglm.
Command
melogit
meprobit
mecloglog
meologit
meoprobit
mepoisson
menbreg

meglm equivalent
family(bernoulli) link(logit)
family(bernoulli) link(probit)
family(bernoulli) link(cloglog)
family(ordinal) link(logit)
family(ordinal) link(probit)
family(poisson) link(log)
family(nbinomial) link(log)

When no familylink combination is specified, meglm defaults to a Gaussian family with an


identity link. Thus meglm can be used to fit linear mixed-effects models; however, for those models
we recommend using the more specialized mixed, which, in addition to meglm capabilities, accepts
frequency and sampling weights and allows for modeling of the structure of the residual errors; see
[ME] mixed for details.
Various predictions, statistics, and diagnostic measures are available after fitting a GLME model
with meglm and other me commands. For the most part, calculation centers around obtaining estimates
of random effects; see [ME] meglm postestimation for a detailed discussion and examples.
For the random portion of (4), Zu, we assume that u has variancecovariance matrix G such that
Var(u) = G
The random effects u are not directly estimated (although they may be predicted) but instead are
characterized by the elements of G, known as variance components.
Analogously to (2), in clustered-data situations, we can write

E(yj |uj ) = g 1 (Xj + Zj uj ),

yj F

with all the elements defined as before. In terms of the whole dataset, we now have

Z1 0 0

u1
0 Z2 0
.
.. ; G = IM
Z=
..
..
..
...
; u =
.
.
.
uM
0
0
0 ZM

(5)

(6)

me Introduction to multilevel mixed-effects models

Finally, we state our convention on counting and ordering model levels. Models (2) and (5) are
what we call two-level models, with extensions to three, four, or any number of levels. The observation
yij is for individual i within cluster j , and the individuals comprise the first level while the clusters
comprise the second level of the model. In our hypothetical three-level model with classes nested
within schools, the observations within classes (the students, presumably) would constitute the first
level, the classes would constitute the second level, and the schools would constitute the third level.
This differs from certain citations in the classical ANOVA literature and texts such as Pinheiro and
Bates (2000) but is the standard in the vast literature on hierarchical models, for example, Skrondal
and Rabe-Hesketh (2004).

Alternative mixed-effects model specification


In this section, we present a hierarchical or multistage formulation of mixed-effects models where
each level is described by its own set of equations.
Consider a random-intercept model that we write here in general terms:

yij = 0 + 1 xij + uj +

ij

(7)

This single-equation specification contains both level-1 and level-2 effects. In the hierarchical form,
we specify a separate equation for each level.

yij = 0j + 1 xij +

ij

(8)

0j = 00 + u0j

The equation for the intercept 0j consists of the overall mean intercept 00 and a cluster-specific
random intercept u0j . To fit this model in Stata, we must translate the multiple-equation notation into
a single-equation form. We substitute the second equation into the first one and rearrange terms.

yij = 00 + u0j + 1 xij +

ij

= 00 + 1 xij + u0j +

ij

(9)

Note that model (9) is the same as model (7) with 00 0 and u0j uj . Thus the Stata syntax
for our generic random-intercept model is
. mixed y x || id:

where id is the variable designating the clusters.


We can extend model (8) to include a random slope. We do so by specifying an additional equation
for the slope on xij .

yij = 0j + 1j xij +
0j = 00 + u0j

ij

(10)

1j = 10 + u1j
The additional equation for the slope 1j consists of the overall mean slope 10 and a cluster-specific
random slope u1j . We substitute the last two equations into the first one to obtain a reduced-form
model.

10

me Introduction to multilevel mixed-effects models

yij = (00 + u0j ) + (10 + u1j )xij +


= 00 + 10 xij + u0j + u1j xij +

ij
ij

The Stata syntax for this model becomes


. mixed y x || id: x, covariance(unstructured)

where we specified an unstructured covariance structure for the level-2 u terms.


Here we further extend the random-slope random-intercept model (10) by adding a level-2 covariate
zj into the level-2 equations.

yij = 0j + 1j xij +

ij

0j = 00 + 01 zj + u0j
1j = 10 + 11 zj + u1j
We substitute as before to obtain a single-equation form:

yij = (00 + 01 zj + u0j ) + (10 + 11 zj + u1j )xij +

ij

= 00 + 01 zj + 10 xij + 11 zj xij + u0j + u1j xij +

ij

Now the fixed-effects portion of the equation contains a constant and variables x, z , and their
interaction. Assuming both x and z are continuous variables, we can use the following Stata syntax
to fit this model:
. mixed y x z c.x#c.z

|| id: x, covariance(unstructured)

We refer you to Raudenbush and Bryk (2002) and Rabe-Hesketh and Skrondal (2012) for a
more thorough discussion and further examples of multistage mixed-model formulations, including
three-level models.

Likelihood calculation

The key to fitting mixed models lies in estimating the variance components, and for that there exist
many methods. Most of the early literature in LME models dealt with estimating variance components
in ANOVA models. For simple models with balanced data, estimating variance components amounts
to solving a system of equations obtained by setting expected mean-squares expressions equal to their
observed counterparts. Much of the work in extending the ANOVA method to unbalanced data for
general ANOVA designs is attributed to Henderson (1953).
The ANOVA method, however, has its shortcomings. Among these is a lack of uniqueness in that
alternative, unbiased estimates of variance components could be derived using other quadratic forms
of the data in place of observed mean squares (Searle, Casella, and McCulloch 1992, 3839). As a
result, ANOVA methods gave way to more modern methods, such as minimum norm quadratic unbiased
estimation (MINQUE) and minimum variance quadratic unbiased estimation (MIVQUE); see Rao (1973)
for MINQUE and LaMotte (1973) for MIVQUE. Both methods involve finding optimal quadratic forms
of the data that are unbiased for the variance components.

me Introduction to multilevel mixed-effects models

11

Stata uses maximum likelihood (ML) to fit LME and GLME models. The ML estimates are based
on the usual application of likelihood theory, given the distributional assumptions of the model. In
addition, for linear mixed-effects models, mixed offers the method of restricted maximum likelihood
(REML). The basic idea behind REML (Thompson 1962) is that you can form a set of linear contrasts
of the response that do not depend on the fixed effects but instead depend only on the variance
components to be estimated. You then apply ML methods by using the distribution of the linear
contrasts to form the likelihood; see the Methods and formulas section of [ME] mixed for a detailed
discussion of ML and REML methods in the context of linear mixed-effects models.
Log-likelihood calculations for fitting any LME or GLME model require integrating out the random
effects. For LME models, this integral has a closed-form solution; for GLME models, it does not. In
dealing with this difficulty, early estimation methods avoided the integration altogether. Two such
popular methods are the closely related penalized quasi-likelihood (PQL) and marginal quasi-likelihood
(MQL) (Breslow and Clayton 1993). Both PQL and MQL use a combination of iterative reweighted
least squares (see [R] glm) and standard estimation techniques for fitting LME models. Efficient
computational methods for fitting LME models have existed for some time (Bates and Pinheiro 1998;
Littell et al. 2006), and PQL and MQL inherit this computational efficiency. However, both of these
methods suffer from two key disadvantages. First, they have been shown to be biased, and this bias
can be severe when clusters are small or intracluster correlation is high (Rodrguez and Goldman 1995;
Lin and Breslow 1996). Second, because they are quasi-likelihood methods and not true likelihood
methods, their use prohibits comparing nested models via likelihood-ratio (LR) tests, blocking the
main avenue of inference involving variance components.
The advent of modern computers has brought with it the development of more computationally
intensive methods, such as bias-corrected PQL (Lin and Breslow 1996), Bayesian Markov-Chain Monte
Carlo, and simulated maximum likelihood, just to name a few; see Ng et al. (2006) for a discussion
of these alternate strategies (and more) for mixed-effects models for binary outcomes.
One widely used modern method is to directly estimate the integral required to calculate the log
likelihood by GaussHermite quadrature or some variation thereof. Because the log likelihood itself
is estimated, this method has the advantage of permitting LR tests for comparing nested models. Also,
if done correctly, quadrature approximations can be quite accurate, thus minimizing bias. meglm and
the other me commands support three types of GaussHermite quadratures: meanvariance adaptive
GaussHermite quadrature (MVAGH), mode-curvature adaptive GaussHermite quadrature (MCAGH),
and nonadaptive GaussHermite quadrature (GHQ); see Methods and formulas of [ME] meglm for
a detailed discussion of these quadrature methods. A fourth method, the Laplacian approximation,
that does not involve numerical integration is also offered; see Computation time and the Laplacian
approximation below and Methods and formulas of [ME] meglm for a detailed discussion of the
Laplacian approximation method.
Computation time and the Laplacian approximation

Like many programs that fit generalized linear mixed models, me commands can be computationally
intensive. This is particularly true for large datasets with many lowest-level clusters, models with
many random coefficients, models with many estimable parameters (both fixed effects and variance
components), or any combination thereof.
Computation time will also depend on hardware and other external factors but in general is
(roughly) a function of p2 {M + M (NQ )qt }, where p is the number of estimable parameters, M is
the number of lowest-level (smallest) clusters, NQ is the number of quadrature points, and qt is the
total dimension of the random effects, that is, the total number of random intercepts and coefficients
at all levels.
For a given model and a given dataset, the only prevailing factor influencing computation time
is (NQ )qt . However, because this is a power function, this factor can get prohibitively large. For

12

me Introduction to multilevel mixed-effects models

example, using five quadrature points for a model with one random intercept and three random
coefficients, we get (NQ )qt = 54 = 625. Even a modest increase to seven quadrature points would
increase this factor by almost fourfold (74 = 2,401), which, depending on M and p, could drastically
slow down estimation. When fitting mixed-effects models, you should always assess whether the
approximation is adequate by refitting the model with a larger number of quadrature points. If the
results are essentially the same, the lower number of quadrature points can be used.
However, we do not deny a tradeoff between speed and accuracy, and in that spirit we give you
the option to choose a (possibly) less accurate solution in the interest of getting quicker results.
Toward this end is the limiting case of NQ = 1, otherwise known as the Laplacian approximation; see
Methods and formulas of [ME] meglm. The computational benefit is evident1 raised to any power
equals 1and the Laplacian approximation has been shown to perform well in certain situations
(Liu and Pierce 1994; Tierney and Kadane 1986). When using Laplacian approximation, keep the
following in mind:
1. Fixed-effects parameters and their standard errors are well approximated by the Laplacian method.
Therefore, if your interest lies primarily here, then the Laplacian approximation may be a viable
alternative.
2. Estimates of variance components exhibit bias, particularly the variances.
3. The model log likelihood and comparison LR test are in fair agreement with statistics obtained via
quadrature methods.
Although this is by no means the rule, we find the above observations to be fairly typical based
on our own experience. Pinheiro and Chao (2006) also make observations similar to points 1 and 2
on the basis of their simulation studies: bias due to Laplace (when present) tends to exhibit itself
more in the estimated variance components than in the estimates of the fixed effects as well as at the
lower levels in higher-level models.
Item 3 is of particular interest, because it demonstrates that the Laplacian approximation can
produce a decent estimate of the model log likelihood. Consequently, you can use the Laplacian
approximation during the model building phase of your analysis, during which you are comparing
competing models by using LR tests. Once you settle on a parsimonious model that fits well, you
can then increase the number of quadrature points and obtain more accurate parameter estimates for
further study.
Of course, sometimes the Laplacian approximation will perform either better or worse than observed
here. This behavior depends primarily on cluster size and intracluster correlation, but the relative
influence of these factors is unclear. The idea behind the Laplacian approximation is to approximate
the posterior density of the random effects given the response with a normal distribution; see Methods
and formulas of [ME] meglm. Asymptotic theory dictates that this approximation improves with larger
clusters. Of course, the key question, as always, is How large is large enough? Also, there are data
situations where the Laplacian approximation performs well even with small clusters. Therefore, it
is difficult to make a definitive call as to when you can expect the Laplacian approximation to yield
accurate results across all aspects of the model.
In conclusion, consider our above advice as a rule of thumb based on empirical evidence.

Diagnosing convergence problems

Given the flexibility of mixed-effects models, you will find that some models fail to converge
when used with your data. The default gradient-based method used by mixed-effects commands is
the NewtonRaphson algorithm, requiring the calculation of a gradient vector and Hessian (secondderivative) matrix; see [R] ml.

me Introduction to multilevel mixed-effects models

13

A failure to converge can take any one of three forms:


1. repeated nonconcave or backed-up iterations without convergence;
2. a Hessian (second-derivative) calculation that has become asymmetric, unstable, or has missing
values; or
3. the message standard-error calculation has failed when computing standard errors.
All three situations essentially amount to the same thing: the Hessian calculation has become unstable,
most likely because of a ridge in the likelihood function, a subsurface of the likelihood in which all
points give the same value of the likelihood and for which there is no unique solution.
Such behavior is usually the result of one of the following two situations:
A. A model that is not identified given the data, for example, fitting the three-level nested random
intercept model
(3)

(2)

yjk = xjk + uk + ujk +

jk

without any replicated measurements at the (j, k) level, that is, with only one i per (j, k)
(2)
combination. This model is unidentified for such data because the random intercepts ujk are
confounded with the overall errors jk .
B. A model that contains a variance component whose estimate is really close to 0. When this occurs,
a ridge is formed by an interval of values near 0, which produce the same likelihood and look
equally good to the optimizer.
For LME models, one useful way to diagnose problems of nonconvergence is to rely on the
expectation-maximization (EM) algorithm (Dempster, Laird, and Rubin 1977), normally used by mixed
only as a means of refining starting values; see Diagnosing convergence problems of [ME] mixed for
details.
If your data and model are nearly unidentified, as opposed to fully unidentified, you may be
able to obtain convergence with standard errors by changing some of the settings of the gradientbased optimization. Adding the difficult option can be particularly helpful if you are seeing
many nonconcave messages; you may also consider changing the technique() or using the
nonrtolerance option; see [R] maximize.
Regardless of how the convergence problem revealed itself, you may try to obtain better starting
values; see Obtaining better starting values in [ME] meglm for details.

Distribution theory for likelihood-ratio test

When determining the asymptotic distribution of an LR test comparing two nested mixed-effects
models, issues concerning boundary problems imposed by estimating strictly positive quantities (that
is, variances) can complicate the situation. For example, when performing LR tests involving linear
mixed-effects models (whether comparing with linear regression within mixed or comparing two
separate linear mixed-effects models with lrtest), you may thus sometimes see a test labeled as
chibar rather than the usual chi2, or you may see a chi2 test with a note attached stating that the
test is conservative or possibly conservative depending on the hypothesis being tested.
At the heart of the issue is the number of variances being restricted to 0 in the reduced model.
If there are none, the usual asymptotic theory holds, and the distribution of the test statistic is 2
with degrees of freedom equal to the difference in the number of estimated parameters between both
models.

14

me Introduction to multilevel mixed-effects models

When there is only one variance being set to 0 in the reduced model, the asymptotic distribution
of the LR test statistic is a 50:50 mixture of a 2p and a 2p+1 distribution, where p is the number
of other restricted parameters in the reduced model that are unaffected by boundary conditions. Stata
labels such test statistics as chibar and adjusts the significance levels accordingly. See Self and
Liang (1987) for the appropriate theory or Gutierrez, Carter, and Drukker (2001) for a Stata-specific
discussion.
When more than one variance parameter is being set to 0 in the reduced model, however, the
situation becomes more complicated. For example, consider a comparison test versus linear regression
for a mixed model with two random coefficients and unstructured covariance matrix
=

02
01

01
12

Because the random component of the mixed model comprises three parameters (02 , 01 , 12 ),
on the surface it would seem that the LR comparison test would be distributed as 23 . However, two
complications need to be considered. First, the variances 02 and 12 are restricted to be positive, and
second, constraints such as 12 = 0 implicitly restrict the covariance 01 to be 0 as well. From a
technical standpoint, it is unclear how many parameters must be restricted to reduce the model to
linear regression.
Because of these complications, appropriate and sufficiently general distribution theory for the
more-than-one-variance case has yet to be developed. Theory (for example, Stram and Lee [1994])
and empirical studies (for example, McLachlan and Basford [1988]) have demonstrated that, whatever
the distribution of the LR test statistic, its tail probabilities are bounded above by those of the 2
distribution with degrees of freedom equal to the full number of restricted parameters (three in the
above example).
The mixed and me commands use this reference distribution, the 2 with full degrees of freedom,
to produce a conservative test and place a note in the output labeling the test as such. Because the
displayed significance level is an upper bound, rejection of the null hypothesis based on the reported
level would imply rejection on the basis of the actual level.

Examples
Two-level models

Example 1: Growth-curve model


Consider a longitudinal dataset, used by both Ruppert, Wand, and Carroll (2003) and Diggle
et al. (2002), consisting of weight measurements of 48 pigs on 9 successive weeks. Pigs are
identified by the variable id. Each pig experiences a linear trend in growth, but overall weight
measurements vary from pig to pig. Because we are not really interested in these particular 48 pigs
per se, we instead treat them as a random sample from a larger population and model the between-pig
variability as a random effect, or in the terminology of (2), as a random-intercept term at the pig
level. We thus wish to fit the model

weightij = 0 + 1 weekij + uj +

ij

for i = 1, . . . , 9 weeks and j = 1, . . . , 48 pigs. The fixed portion of the model, 0 + 1 weekij ,
simply states that we want one overall regression line representing the population average. The random
effect uj serves to shift this regression line up or down according to each pig. Because the random
effects occur at the pig level (id), we fit the model by typing

me Introduction to multilevel mixed-effects models

15

. use http://www.stata-press.com/data/r13/pig
(Longitudinal analysis of pig weights)
. mixed weight week || id:
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log likelihood = -1014.9268
Iteration 1:
log likelihood = -1014.9268
Computing standard errors:
Mixed-effects ML regression
Group variable: id

Log likelihood = -1014.9268


weight

Coef.

week
_cons

6.209896
19.35561

Std. Err.
.0390124
.5974059

Random-effects Parameters

z
159.18
32.40

Number of obs
Number of groups
Obs per group: min
avg
max

=
=
=
=
=

432
48
9
9.0
9

Wald chi2(1)
Prob > chi2

=
=

25337.49
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.133433
18.18472

6.286359
20.52651

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

14.81751

3.124226

9.801716

22.40002

var(Residual)

4.383264

.3163348

3.805112

5.04926

id: Identity

LR test vs. linear regression: chibar2(01) =

472.65 Prob >= chibar2 = 0.0000

We explain the output in detail in example 1 of [ME] mixed. Here we only highlight the most important
points.
1. The first estimation table reports the fixed effects. We estimate 0 = 19.36 and 1 = 6.21.
2. The second estimation table shows the estimated variance components. The first section of the
table is labeled id: Identity, meaning that these are random effects at the id (pig) level and
that their variancecovariance matrix is a multiple of the identity matrix; that is, = u2 I. The
estimate of u2 is 14.82 with standard error 3.12.
3. The row labeled var(Residual) displays the estimated standard deviation of the overall error
term; that is, 2 = 4.38. This is the variance of the level-one errors, that is, the residuals.
4. An LR test comparing the model with one-level ordinary linear regression is provided and is highly
significant for these data.
We can predict the random intercept uj and list the predicted random intercept for the first 10
pigs by typing

16

me Introduction to multilevel mixed-effects models


. predict r_int, reffects
. egen byte tag = tag(id)
. list id r_int if id<=10 & tag
id

r_int

1.
10.
19.
28.
37.

1
2
3
4
5

-1.683105
.8987018
-1.952043
-1.79068
-3.189159

46.
55.
64.
73.
82.

6
7
8
9
10

-3.780823
-2.382344
-1.952043
-6.739143
1.16764

In example 3 of [ME] mixed, we show how to fit a random-slope model for these data, and in
example 1 of [ME] mixed postestimation, we show how to plot the estimated regression lines for
each of the pigs.

Example 2: Split-plot design


Here we replicate the example of a split-plot design from Kuehl (2000, 477). The researchers
investigate the effects of nitrogen in four different chemical forms and the effects of thatch accumulation
on the quality of golf turf. The experimental plots were arranged in a randomized complete block
design with two replications. After two years of nitrogen treatment, the second treatment factor, years
of thatch accumulation, was added to the experiment. Each of the eight experimental plots was split
into three subplots. Within each plot, the subplots were randomly assigned to accumulate thatch for
a period of 2, 5, and 8 years.

me Introduction to multilevel mixed-effects models

17

. use http://www.stata-press.com/data/r13/clippings, clear


(Turfgrass experiment)
. describe
Contains data from http://www.stata-press.com/data/r13/clippings.dta
obs:
24
Turfgrass experiment
vars:
4
21 Feb 2013 14:57
size:
168

variable name

storage
type

display
format

chlorophyll

float

%9.0g

thatch
block
nitrogen

byte
byte
byte

%9.0g
%9.0g
%17.0g

value
label

variable label

nitrolab

Chlorophyll content (mg/g) of


grass clippings
Years of thatch accumulation
Replication
Nitrogen fertilizer

Sorted by:

Nitrogen treatment is stored in the variable nitrogen, and the chemicals used are urea, ammonium
sulphate, isobutylidene diurea (IBDU), and sulphur-coated urea (urea SC). The length of thatch
accumulation is stored in the variable thatch. The response is the chlorophyll content of grass
clippings, recorded in mg/g and stored in the variable chlorophyll. The block variable identifies
the replication group.
There are two sources of variation in this example corresponding to the whole-plot errors and the
subplot errors. The subplot errors are the residual errors. The whole-plot errors represents variation
in the chlorophyll content across nitrogen treatments and replications. We create the variable wpunit
to represent the whole-plot units that correspond to the levels of the nitrogen treatment and block
interaction.
. egen wpunit = group(nitrogen block)
. mixed chlorophyll ibn.nitrogen##ibn.thatch ibn.block, noomitted noconstant ||
> wpunit:, reml
note: 8.thatch omitted because of collinearity
note: 1.nitrogen#8.thatch omitted because of collinearity
note: 2.nitrogen#8.thatch omitted because of collinearity
note: 3.nitrogen#8.thatch omitted because of collinearity
note: 4.nitrogen#2.thatch omitted because of collinearity
note: 4.nitrogen#5.thatch omitted because of collinearity
note: 4.nitrogen#8.thatch omitted because of collinearity
note: 2.block omitted because of collinearity
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log restricted-likelihood = -13.212401
Iteration 1:
log restricted-likelihood = -13.203149
Iteration 2:
log restricted-likelihood = -13.203125
Iteration 3:
log restricted-likelihood = -13.203125

18

me Introduction to multilevel mixed-effects models


Computing standard errors:
Mixed-effects REML regression
Group variable: wpunit

Log restricted-likelihood = -13.203125


chlorophyll

Coef.

nitrogen
urea
ammonium ..
IBDU
Urea (SC)

5.245833
5.945833
7.945834
8.595833

.3986014
.3986014
.3986014
.3986014

thatch
2
5

-1.1
.1500006

nitrogen#
thatch
urea#2
urea#5
ammonium .. #
2
ammonium .. #
5
IBDU#2
IBDU#5
block
1

Std. Err.

=
=
=
=
=

24
8
3
3.0
3

Wald chi2(13)
Prob > chi2

=
=

2438.36
0.0000

P>|z|

[95% Conf. Interval]

13.16
14.92
19.93
21.56

0.000
0.000
0.000
0.000

4.464589
5.164589
7.164589
7.814589

6.027078
6.727078
8.727078
9.377078

.4632314
.4632314

-2.37
0.32

0.018
0.746

-2.007917
-.7579163

-.1920828
1.057917

-.1500005
.0999994

.6551081
.6551081

-0.23
0.15

0.819
0.879

-1.433989
-1.183989

1.133988
1.383988

.8999996

.6551081

1.37

0.169

-.3839887

2.183988

-.1000006
-.2000005
-1.950001

.6551081
.6551081
.6551081

-0.15
-0.31
-2.98

0.879
0.760
0.003

-1.383989
-1.483989
-3.233989

1.183988
1.083988
-.6660124

-.2916666

.2643563

-1.10

0.270

-.8097955

.2264622

Random-effects Parameters

Number of obs
Number of groups
Obs per group: min
avg
max

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

.0682407

.1195933

.0021994

2.117344

var(Residual)

.2145833

.1072917

.080537

.5717376

wpunit: Identity

LR test vs. linear regression: chibar2(01) =

0.53 Prob >= chibar2 = 0.2324

me Introduction to multilevel mixed-effects models

19

We can calculate the cell means for source of nitrogen and years of thatch accumulation by using
margins.
. margins thatch#nitrogen
Predictive margins
Number of obs
Expression
: Linear prediction, fixed portion, predict()

Margin
thatch#
nitrogen
2#urea
2 #
ammonium ..
2#IBDU
2#Urea (SC)
5#urea
5 #
ammonium ..
5#IBDU
5#Urea (SC)
8#urea
8 #
ammonium ..
8#IBDU
8#Urea (SC)

Delta-method
Std. Err.

P>|z|

24

[95% Conf. Interval]

3.85

.3760479

10.24

0.000

3.11296

4.58704

5.6
6.5
7.35
5.35

.3760479
.3760479
.3760479
.3760479

14.89
17.29
19.55
14.23

0.000
0.000
0.000
0.000

4.86296
5.76296
6.61296
4.61296

6.33704
7.23704
8.087041
6.087041

5.85
6
8.6
5.1

.3760479
.3760479
.3760479
.3760479

15.56
15.96
22.87
13.56

0.000
0.000
0.000
0.000

5.11296
5.26296
7.86296
4.36296

6.58704
6.73704
9.337041
5.837041

5.8
7.8
8.45

.3760479
.3760479
.3760479

15.42
20.74
22.47

0.000
0.000
0.000

5.06296
7.06296
7.712959

6.53704
8.537041
9.18704

It is easier to see the effect of the treatments if we plot the impact of the four nitrogen and the
three thatch treatments. We can use marginsplot to plot the means of chlorophyll content versus
years of thatch accumulation by nitrogen source.

20

me Introduction to multilevel mixed-effects models


.
>
>
>
>

marginsplot, ytitle(Chlorophyll (mg/g)) title("")


subtitle("Mean chlorophyll content of grass clippings versus"
"nitrogen source for years of thatch accumulation") xsize(3) ysize(3.2)
legend(cols(1) position(5) ring(0) region(lwidth(none)))
ylabel(0(2)10, angle(0))
Variables that uniquely identify margins: thatch nitrogen

Mean chlorophyll content of grass clippings versus


nitrogen source for years of thatch accumulation
10

Chlorophyll (mg/g)

urea
ammonium sulphate
IBDU
Urea (SC)

0
2

5
Years of thatch accumulation

We can see an increase in the mean chlorophyll content over the years of thatch accumulation for
all but one nitrogen source.
The marginal means can be obtained by using margins on one variable at a time.
. margins thatch
Predictive margins
Number of obs
Expression
: Linear prediction, fixed portion, predict()

thatch
2
5
8

Margin

Delta-method
Std. Err.

5.825
6.45
6.7875

.188024
.188024
.188024

30.98
34.30
36.10

P>|z|

0.000
0.000
0.000

24

[95% Conf. Interval]

5.45648
6.08148
6.41898

6.19352
6.81852
7.15602

me Introduction to multilevel mixed-effects models


. margins nitrogen
Predictive margins
Number of obs
Expression
: Linear prediction, fixed portion, predict()

Margin
nitrogen
urea
ammonium ..
IBDU
Urea (SC)

4.766667
5.75
6.766667
8.133333

Delta-method
Std. Err.

.2643563
.2643563
.2643563
.2643563

18.03
21.75
25.60
30.77

21

24

P>|z|

[95% Conf. Interval]

0.000
0.000
0.000
0.000

4.248538
5.231871
6.248538
7.615205

5.284796
6.268129
7.284796
8.651462

Marchenko (2006) shows more examples of fitting other experimental designs using linear mixedeffects models.

Example 3: Binomial counts


We use the data taken from Agresti (2013, 219) on graduate school applications to the 23 departments
within the College of Liberal Arts and Sciences at the University of Florida during the 19971998
academic year. The dataset contains the department ID (department), the number of applications
(napplied), and the number of students admitted (nadmitted) cross-classified by gender (female).
. use http://www.stata-press.com/data/r13/admissions, clear
(Graduate school admissions data)
. describe
Contains data from http://www.stata-press.com/data/r13/admissions.dta
obs:
46
Graduate school admissions data
vars:
4
25 Feb 2013 09:28
size:
460
(_dta has notes)

variable name
department
nadmitted
napplied
female

storage
type
long
byte
float
byte

display
format

value
label

%8.0g
%8.0g
%9.0g
%8.0g

dept

variable label
department id
number of admissions
number of applications
=1 if female, =0 if male

Sorted by:

We wish to investigate whether admission decisions are independent of gender. Given department
and gender, the probability of admission follows a binomial model, that is, Pr(Yij = yij ) =
Binomial(nij , ij ), where i = {0, 1} and j = 1, . . . , 23. We fit a mixed-effects binomial logistic
model with a random intercept at the department level.

22

me Introduction to multilevel mixed-effects models


. melogit nadmitted female ||
Fitting fixed-effects model:
Iteration 0:
log likelihood
Iteration 1:
log likelihood
Iteration 2:
log likelihood
Iteration 3:
log likelihood
Refining starting values:
Grid node 0:
log likelihood

department:, binomial(napplied) or
=
=
=
=

-302.47786
-300.00004
-299.99934
-299.99934

= -145.08843

Fitting full model:


Iteration 0:
log likelihood = -145.08843
Iteration 1:
log likelihood = -140.8514
Iteration 2:
log likelihood = -140.61709
Iteration 3:
log likelihood = -140.61628
Iteration 4:
log likelihood = -140.61628
Mixed-effects logistic regression
Binomial variable:
napplied
Group variable:
department

Number of obs

46

Integration method: mvaghermite

Number of groups
Obs per group: min
avg
max
Integration points

=
=
=
=
=

23
2
2.0
2
7

Log likelihood = -140.61628

Wald chi2(1)
Prob > chi2

=
=

2.14
0.1435

nadmitted

Odds Ratio

female
_cons

1.176898
.7907009

.1310535
.2057191

1.345383

.460702

department
var(_cons)

Std. Err.

z
1.46
-0.90

LR test vs. logistic regression: chibar2(01) =

P>|z|

[95% Conf. Interval]

0.144
0.367

.9461357
.4748457

1.463944
1.316655

.6876497

2.632234

318.77 Prob>=chibar2 = 0.0000

The odds of being admitted are higher for females than males but without statistical significance.
The estimate of u2 is 1.35 with the standard error of 0.46. An LR test comparing the model with
the one-level binomial regression model favors the random-intercept model, indicating that there is a
significant variation in the number of admissions between departments.
We can further assess the model fit by performing a residual analysis. For example, here we predict
and plot Anscombe residuals.

me Introduction to multilevel mixed-effects models

23

Anscombe residuals
0
1

. predict anscres, anscombe


(predictions based on fixed effects and posterior means of random effects)
. twoway (scatter anscres department if female, msymbol(S))
> (scatter anscres department if !female, msymbol(T)),
> yline(-2 2) xline(1/23, lwidth(vvthin) lpattern(dash))
> xlabel(1/23) legend(label(1 "females") label(2 "males"))

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
department id
females

males

Anscombe residuals are constructed to be approximately normally distributed, thus residuals that
are above two in absolute value are usually considered outliers. In the graph above, the residual
for female admissions in department 2 is a clear outlier, suggesting a poor fit for that particular
observation; see [ME] meglm postestimation for more information about Anscombe residuals and
other model diagnostics tools.

Covariance structures

Example 4: Growth-curve model with correlated random effects


Here we extend the model from example 1 of [ME] me to allow for a random slope on week and
an unstructured covariance structure between the random intercept and the random slope on week.

24

me Introduction to multilevel mixed-effects models


. use http://www.stata-press.com/data/r13/pig, clear
(Longitudinal analysis of pig weights)
. mixed weight week || id: week, covariance(unstructured)
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log likelihood = -868.96185
Iteration 1:
log likelihood = -868.96185
Computing standard errors:
Mixed-effects ML regression
Group variable: id

Log likelihood = -868.96185


weight

Coef.

week
_cons

6.209896
19.35561

Std. Err.
.0910745
.3996387

Random-effects Parameters

z
68.18
48.43

Number of obs
Number of groups
Obs per group: min
avg
max

=
=
=
=
=

432
48
9
9.0
9

Wald chi2(1)
Prob > chi2

=
=

4649.17
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.031393
18.57234

6.388399
20.13889

Estimate

Std. Err.

[95% Conf. Interval]

var(week)
var(_cons)
cov(week,_cons)

.3715251
6.823363
-.0984378

.0812958
1.566194
.2545767

.2419532
4.351297
-.5973991

.570486
10.69986
.4005234

var(Residual)

1.596829

.123198

1.372735

1.857505

id: Unstructured

LR test vs. linear regression:


chi2(3) =
764.58
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

The unstructured covariance structure allows for correlation between the random effects. Other
covariance structures supported by mixed, besides the default independent, include identity and
exchangeable; see [ME] mixed for details. You can also specify multiple random-effects equations
at the same level, in which case the covariance types can be combined to form more complex
blocked-diagonal covariance structures; see example 5 below.
We can predict the fitted values and plot the estimated regression line for each of the pigs. The
fitted values are based on both the fixed and the random effects.

me Introduction to multilevel mixed-effects models

25

20

Predicted weight
40
60

80

. predict wgt_hat, fitted


. twoway connected wgt_hat week if id<=10, connect(L) ytitle("Predicted weight")

10

week

Example 5: Blocked-diagonal covariance structures


In this example, we fit a logistic mixed-effects model with a blocked-diagonal covariance structure
of random effects.
We use the data from the 1989 Bangladesh fertility survey (Huq and Cleland 1990), which polled
1,934 Bangladeshi women on their use of contraception. The women sampled were from 60 districts,
identified by the variable district. Each district contained either urban or rural areas (variable
urban) or both. The variable c use is the binary response, with a value of 1 indicating contraceptive
use. Other covariates include mean-centered age and three indicator variables recording number of
children. Below we fit a standard logistic regression model amended to have random coefficients on
each indicator variable for children and an overall district random intercept.

26

me Introduction to multilevel mixed-effects models


. use http://www.stata-press.com/data/r13/bangladesh, clear
(Bangladesh Fertility Survey, 1989)
. melogit c_use urban age child* || district: child*, cov(exchangeable)
> || district:, or
Fitting fixed-effects model:
Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:

log
log
log
log

likelihood
likelihood
likelihood
likelihood

=
=
=
=

-1229.5485
-1228.5268
-1228.5263
-1228.5263

Refining starting values:


Grid node 0:

log likelihood = -1234.3979

Fitting full model:


Iteration
Iteration
Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:
4:
5:

log
log
log
log
log
log

likelihood
likelihood
likelihood
likelihood
likelihood
likelihood

=
=
=
=
=
=

-1234.3979
-1208.0052
-1206.4497
-1206.2417
-1206.2397
-1206.2397

(not concave)

Mixed-effects logistic regression


Group variable:
district

Number of obs
Number of groups

Integration method: mvaghermite

=
=

1934
60

Obs per group: min =


avg =
max =

2
32.2
118

Integration points =

Wald chi2(5)
Log likelihood = -1206.2397
Prob > chi2
( 1) [var(child1[district])]_cons - [var(child3[district])]_cons
( 2) [cov(child2[district],child1[district])]_cons [cov(child3[district],child2[district])]_cons = 0
( 3) [cov(child3[district],child1[district])]_cons [cov(child3[district],child2[district])]_cons = 0
( 4) [var(child2[district])]_cons - [var(child3[district])]_cons
c_use

Odds Ratio

urban
age
child1
child2
child3
_cons

2.105163
.9735765
2.992596
3.879345
3.774627
.1859471

.2546604
.0077461
.502149
.7094125
.7055812
.0274813

.0841518
.0841518
.0841518
.1870273

.0880698
.0880698
.0880698
.0787274

.0616875

.0844681

0.73

.0616875

.0844681

.0616875

.0844681

district
var(child1)
var(child2)
var(child3)
var(_cons)
district
cov(child2,
child1)
cov(child3,
child1)
cov(child3,
child2)

Std. Err.

LR test vs. logistic regression:

=
=
= 0

100.01
0.0000

= 0

P>|z|

[95% Conf. Interval]

0.000
0.001
0.000
0.000
0.000
0.000

1.660796
.9585122
2.153867
2.710815
2.616744
.1391841

2.668426
.9888775
4.157931
5.551584
5.444863
.2484214

.0108201
.0108201
.0108201
.0819596

.654479
.654479
.654479
.426786

0.465

-.1038669

.2272419

0.73

0.465

-.1038669

.2272419

0.73

0.465

-.1038669

.2272419

6.15
-3.37
6.53
7.41
7.11
-11.38

chi2(3) =

44.57

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.

me Introduction to multilevel mixed-effects models

27

The fixed effects can be interpreted just as you would the output from logit. Urban women have
roughly double the odds of using contraception as compared with their rural counterparts. Having
any number of children will increase the odds from three- to fourfold when compared with the base
category of no children. Contraceptive use also decreases with age.
Because we specified cov(exchangeable), the estimated variances on each indicator variable
for children are constrained to be the same, and the estimated covariances on each indicator variable
for children are constrained to be the same. More complex covariance structures with constraints can
be specified using covariance(pattern()) and covariance(fixed()); see example 6 below.

Example 6: Meta analysis


In this example, we present a mixed-effects model for meta analysis of clinical trials. The term
meta-analysis refers to a statistical analysis that involves summary data from similar but independent
studies.
Turner et al. (2000) performed a study of nine clinical trials examining the effect of taking diuretics
during pregnancy on the risk of pre-eclampsia. The summary data consist of the log odds-ratio
(variable or) estimated from each study, and the corresponding estimated variance (variable varor).
The square root of the variance is stored in the variable std and the trial identifier is stored in the
variable trial.
. use http://www.stata-press.com/data/r13/diuretics
(Meta analysis of clinical trials studying diuretics and pre-eclampsia)
. list
trial

or

varor

std

1.
2.
3.
4.
5.

1
2
3
4
5

.04
-.92
-1.12
-1.47
-1.39

.16
.12
.18
.3
.11

.4
.3464102
.4242641
.5477226
.3316625

6.
7.
8.
9.

6
7
8
9

-.3
-.26
1.09
.14

.01
.12
.69
.07

.1
.3464102
.8306624
.2645751

In a random-effects modeling of summary data, the observed log odds-ratios are treated as a
continuous outcome and assumed to be normally distributed, and the true treatment effect varies
randomly among the trials. The random-effects model can be written as

yi N ( + i , i2 )
i N (0, 2 )
where yi is the observed treatment effect corresponding to the ith study, + i is the true treatment
effect, i2 is the variance of the observed treatment effect, and is the between-trial variance
component. Our aim is to estimate , the global mean.
Notice that the responses yi do not provide enough information to estimate this model, because
we cannot estimate the group-level variance component from a dataset that contains one observation
per group. However, we already have estimates for the i s, therefore we can constrain each i to

28

me Introduction to multilevel mixed-effects models

be equal to its estimated value, which will allow us to estimate and . We use meglm to estimate
this model because the mixed command does not support constraints.
In meglm, one way to constrain a group of individual variances to specific values is by using the fixed
covariance structure (an alternative way is to define each constraint individually with the constraint
command and specify them in the constraints() option). The covariance(fixed()) option
requires a Stata matrix defining the constraints, thus we first create matrix f with the values of i ,
stored in variable varor, on the main diagonal. We will use this matrix to constrain the variances.
. mkmat varor, mat(f)
. mat f = diag(f)

In the random-effects equation part, we need to specify nine random slopes, one for each trial.
Because random-effects equations do not support factor variables (see [U] 11.4.3 Factor variables), we
cannot use the i.trial notation. Instead, we tabulate the variable trial and use the generate()
option to create nine dummy variables named tr1, tr2, . . . , tr9. We can then fit the model. Because
the model is computationally demanding, we use three integration points instead of the default seven;
see Computation time and the Laplacian approximation above for details.

me Introduction to multilevel mixed-effects models


. qui tabulate trial, gen(tr)
. meglm or || _all: tr1-tr9, nocons cov(fixed(f)) intp(3) nocnsreport
Fitting fixed-effects model:
Iteration 0:
log likelihood = -10.643432
Iteration 1:
log likelihood = -10.643432
Refining starting values:
Grid node 0:
log likelihood = -10.205455
Fitting full model:
Iteration 0:
log likelihood = -10.205455
Iteration 1:
log likelihood = -9.4851163 (backed up)
Iteration 2:
log likelihood =
-9.45869
Iteration 3:
log likelihood = -9.4552794
Iteration 4:
log likelihood = -9.4552759
Iteration 5:
log likelihood = -9.4552759
Mixed-effects GLM
Number of obs
=
Family:
Gaussian
Link:
identity
Group variable:
_all
Number of groups
=

Integration method: mvaghermite


Log likelihood = -9.4552759
or

Coef.

_cons

-.5166151

Std. Err.
.2059448

z
-2.51

Obs per group: min =


avg =
max =

9
9.0
9

Integration points =
Wald chi2(0)
=
Prob > chi2
=

3
.
.

P>|z|
0.012

29

[95% Conf. Interval]


-.9202594

-.1129708

.0476023

1.187413

_all
var(tr1)
var(tr2)
var(tr3)
var(tr4)
var(tr5)
var(tr6)
var(tr7)
var(tr8)
var(tr9)

.16
.12
.18
.3
.11
.01
.12
.69
.07

var(e.or)

.2377469

(constrained)
(constrained)
(constrained)
(constrained)
(constrained)
(constrained)
(constrained)
(constrained)
(constrained)
.1950926

We estimate = 0.52, which agrees with the estimate reported by Turner et al. (2000).
We can fit the above model in a more efficient way. We can consider the trials as nine independent
random variables, each with variance unity, and each being multiplied by a different standard error.
To accomplish this, we treat trial as a random-effects level, use the standard deviations of the log
odds-ratios as a random covariate at the trial level, and constrain the variance component of trial
to unity.

30

me Introduction to multilevel mixed-effects models


. constraint 1 _b[var(std[trial]):_cons] = 1
. meglm or || trial: std, nocons constraints(1)
Fitting fixed-effects model:
Iteration 0:
log likelihood = -10.643432
Iteration 1:
log likelihood = -10.643432
Refining starting values:
Grid node 0:
log likelihood = -10.205455
Fitting full model:
Iteration 0:
log likelihood = -10.205455
Iteration 1:
log likelihood = -9.4851164 (backed up)
Iteration 2:
log likelihood =
-9.45869
Iteration 3:
log likelihood = -9.4552794
Iteration 4:
log likelihood = -9.4552759
Iteration 5:
log likelihood = -9.4552759
Mixed-effects GLM
Number of obs
Family:
Gaussian
Link:
identity
Group variable:
trial
Number of groups
Obs per group: min
avg
max
Integration method: mvaghermite
Integration points
Wald chi2(0)
Log likelihood = -9.4552759
Prob > chi2
( 1) [var(std[trial])]_cons = 1
or

Coef.

_cons

-.5166151

trial
var(std)

var(e.or)

.2377469

Std. Err.
.2059448

z
-2.51

P>|z|
0.012

=
=
=
=
=
=
=

9
1
1.0
1
7
.
.

[95% Conf. Interval]


-.9202594

-.1129708

.0476023

1.187413

(constrained)
.1950926

The results are the same, but this model took a fraction of the time compared with the less efficient
specification.

Three-level models

The methods we have discussed so far extend from two-level models to models with three or
more levels with nested random effects. By nested, we mean that the random effects shared within
lower-level subgroups are unique to the upper-level groups. For example, assuming that classroom
effects would be nested within schools would be natural, because classrooms are unique to schools.
Below we illustrate a three-level mixed-effects ordered probit model.

Example 7: Three-level ordinal response model


In this example, we fit a three-level ordered probit model. The data are from the Television,
School, and Family Smoking Prevention and Cessation Project (Flay et al. 1988; Rabe-Hesketh and
Skrondal 2012, chap. 11), where schools were randomly assigned into one of four groups defined
by two treatment variables. Students within each school are nested in classes, and classes are nested

me Introduction to multilevel mixed-effects models

31

in schools. The dependent variable is the tobacco and health knowledge (THK) scale score collapsed
into four ordered categories. We regress the outcome on the treatment variables and their interaction
and control for the pretreatment score.
. use http://www.stata-press.com/data/r13/tvsfpors, clear
. meoprobit thk prethk cc##tv
Fitting fixed-effects model:
Iteration 0:
log likelihood
Iteration 1:
log likelihood
Iteration 2:
log likelihood
Iteration 3:
log likelihood
Refining starting values:
Grid node 0:
log likelihood

|| school: || class:
= -2212.775
= -2127.8111
= -2127.7612
= -2127.7612
= -2195.6424

Fitting full model:


Iteration 0:
log likelihood = -2195.6424
Iteration 1:
log likelihood = -2167.9576
Iteration 2:
log likelihood = -2140.2644
Iteration 3:
log likelihood = -2128.6948
Iteration 4:
log likelihood = -2119.9225
Iteration 5:
log likelihood = -2117.0947
Iteration 6:
log likelihood = -2116.7004
Iteration 7:
log likelihood = -2116.6981
Iteration 8:
log likelihood = -2116.6981
Mixed-effects oprobit regression

Group Variable

No. of
Groups

school
class

28
135

(not
(not
(not
(not

concave)
concave)
concave)
concave)

Number of obs

1600

Integration points =
Wald chi2(4)
=
Prob > chi2
=

7
124.20
0.0000

Observations per Group


Minimum
Average
Maximum
18
1

57.1
11.9

Integration method: mvaghermite


Log likelihood = -2116.6981
Std. Err.

137
28

thk

Coef.

P>|z|

[95% Conf. Interval]

prethk
1.cc
1.tv

.238841
.5254813
.1455573

.0231446
.1285816
.1255827

10.32
4.09
1.16

0.000
0.000
0.246

.1934784
.2734659
-.1005803

.2842036
.7774967
.3916949

cc#tv
1 1

-.2426203

.1811999

-1.34

0.181

-.5977656

.1125251

/cut1
/cut2
/cut3

-.074617
.6863046
1.413686

.1029791
.1034813
.1064889

-0.72
6.63
13.28

0.469
0.000
0.000

-.2764523
.4834849
1.204972

.1272184
.8891242
1.622401

school
var(_cons)

.0186456

.0160226

.0034604

.1004695

school>class
var(_cons)

.0519974

.0224014

.0223496

.1209745

LR test vs. oprobit regression:


chi2(2) =
22.13
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

32

me Introduction to multilevel mixed-effects models

Notes:
1. Our model now has two random-effects equations, separated by ||. The first is a random intercept
(constant only) at the school level (level three), and the second is a random intercept at the
class level (level two). The order in which these are specified (from left to right) is significant
meoprobit assumes that class is nested within school.
2. The information on groups is now displayed as a table, with one row for each grouping. You can
suppress this table with the nogroup or the noheader option, which will also suppress the rest
of the header.
3. The variance-component estimates are now organized and labeled according to level. The variance
component for class is labeled school>class to emphasize that classes are nested within schools.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left to
right as the groups go from biggest (highest level) to smallest (lowest level).

Crossed-effects models

Not all mixed-effects models contain nested levels of random effects.

Example 8: Crossed random effects


Returning to our longitudinal analysis of pig weights, suppose that we wish to fit

weightij = 0 + 1 weekij + ui + vj +

ij

(11)

for the i = 1, . . . , 9 weeks and j = 1, . . . , 48 pigs and

ui N (0, u2 );

vj N (0, v2 );

ij

N (0, 2 )

all independently. That is, we assume an overall population-average growth curve 0 + 1 week and
a random pig-specific shift. In other words, the effect due to week, ui , is systematic to that week and
common to all pigs. The rationale behind (11) could be that, assuming that the pigs were measured
contemporaneously, we might be concerned that week-specific random factors such as weather and
feeding patterns had significant systematic effects on all pigs.
Model (11) is an example of a two-way crossed-effects model, with the pig effects vj being crossed
with the week effects ui . One way to fit such models is to consider all the data as one big cluster,
and treat ui and vj as a series of 9 + 48 = 57 random coefficients on indicator variables for week
and pig. The random effects u and the variance components G are now represented as

me Introduction to multilevel mixed-effects models

u1
..
.

u
u = 9 N (0, G);
v1
.
..
v48

33

G=

u2 I9
0

0
v2 I48

Because G is block diagonal, it can be represented as repeated-level equations. All we need is an ID


variable to identify all the observations as one big group and a way to tell mixed-effects commands
to treat week and pig as factor variables (or equivalently, as two sets of overparameterized indicator
variables identifying weeks and pigs, respectively). The mixed-effects commands support the special
group designation all for the former and the R.varname notation for the latter.
. use http://www.stata-press.com/data/r13/pig
(Longitudinal analysis of pig weights)
. mixed weight week || _all: R.id || _all: R.week
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log likelihood = -1013.824
Iteration 1:
log likelihood = -1013.824
Computing standard errors:
Mixed-effects ML regression
Number of obs
Group variable: _all
Number of groups
Obs per group: min
avg
max
Log likelihood =

Wald chi2(1)
Prob > chi2

-1013.824

weight

Coef.

week
_cons

6.209896
19.35561

Std. Err.
.0539313
.6333982

Random-effects Parameters

z
115.14
30.56

=
=
=
=
=

432
1
432
432.0
432

=
=

13258.28
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.104192
18.11418

6.315599
20.59705

Estimate

Std. Err.

[95% Conf. Interval]

var(R.id)

14.83623

3.126142

9.816733

22.42231

var(R.week)

.0849874

.0868856

.0114588

.6303302

var(Residual)

4.297328

.3134404

3.724888

4.957741

_all: Identity

_all: Identity

LR test vs. linear regression:


chi2(2) =
474.85
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

We estimate u2 = 0.08 and v2 = 14.84.


The R.varname notation is equivalent to giving a list of overparameterized (none dropped) indicator
variables for use in a random-effects specification. When you use R.varname, mixed-effects commands
handle the calculations internally rather than creating the indicators in the data. Because the set of
indicators is overparameterized, R.varname implies noconstant.

34

me Introduction to multilevel mixed-effects models

Note that the column dimension of our random-effects design is 57. Computation time and memory
requirements grow (roughly) quadratically with the dimension of the random effects. As a result,
fitting such crossed-effects models is feasible only when the total column dimension is small to
moderate. For this reason, mixed-effects commands use the Laplacian approximation as the default
estimation method for crossed-effects models; see Computation time and the Laplacian approximation
above for more details.
It is often possible to rewrite a mixed-effects model in a way that is more computationally efficient.
For example, we can treat pigs as nested within the all group, yielding the equivalent and more
efficient (total column dimension 10) way to fit (11):
. mixed weight week || _all: R.week || id:
The results of both estimations are identical, but the latter specification, organized at the cluster (pig)
level with random-effects dimension 1 (a random intercept) is much more computationally efficient.
Whereas with the first form we are limited in how many pigs we can analyze, there is no such
limitation with the second form.
All the mixed-effects commandsexcept mixed, meqrlogit, and meqrpoissonautomatically
attempt to recast the less efficient model specification into a more efficient one. However, this automatic
conversion may not be sufficient for some complicated mixed-effects specifications, especially if both
crossed and nested effects are involved. Therefore, we strongly encourage you to always specify the
more efficient syntax; see Rabe-Hesketh and Skrondal (2012) and Marchenko (2006) for additional
techniques to make calculations more efficient in more complex mixed-effects models.

Acknowledgments
We are indebted to Sophia Rabe-Hesketh of the University of California, Berkeley; Anders Skrondal
of the University of Oslo and the Norwegian Institute of Public Health; and Andrew Pickles of the
University of Manchester for their extensive body of work in Stata, both previous and ongoing, in
this area.

References
Agresti, A. 2013. Categorical Data Analysis. 3rd ed. Hoboken, NJ: Wiley.
Bates, D. M., and J. C. Pinheiro. 1998. Computational methods for multilevel modelling. In Technical Memorandum
BL0112140-980226-01TM. Murray Hill, NJ: Bell Labs, Lucent Technologies.
http://stat.bell-labs.com/NLME/CompMulti.pdf.
Breslow, N. E., and D. G. Clayton. 1993. Approximate inference in generalized linear mixed models. Journal of the
American Statistical Association 88: 925.
De Boeck, P., and M. Wilson, ed. 2004. Explanatory Item Response Models: A Generalized Linear and Nonlinear
Approach. New York: Springer.
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.
Dempster, A. P., N. M. Laird, and D. B. Rubin. 1977. Maximum likelihood from incomplete data via the EM
algorithm. Journal of the Royal Statistical Society, Series B 39: 138.
Diggle, P. J., P. J. Heagerty, K.-Y. Liang, and S. L. Zeger. 2002. Analysis of Longitudinal Data. 2nd ed. Oxford:
Oxford University Press.
Flay, B. R., B. R. Brannon, C. A. Johnson, W. B. Hansen, A. L. Ulene, D. A. Whitney-Saltiel, L. R. Gleason,
S. Sussman, M. D. Gavin, K. M. Glowacz, D. F. Sobol, and D. C. Spiegel. 1988. The television, school, and family
smoking cessation and prevention project: I. Theoretical basis and program development. Preventive Medicine 17:
585607.

me Introduction to multilevel mixed-effects models

35

Gelman, A., and J. Hill. 2007. Data Analysis Using Regression and Multilevel/Hierarchical Models. Cambridge:
Cambridge University Press.
Gutierrez, R. G., S. L. Carter, and D. M. Drukker. 2001. sg160: On boundary-value likelihood-ratio tests. Stata
Technical Bulletin 60: 1518. Reprinted in Stata Technical Bulletin Reprints, vol. 10, pp. 269273. College Station,
TX: Stata Press.
Hall, B. H., Z. Griliches, and J. A. Hausman. 1986. Patents and R and D: Is there a lag? International Economic
Review 27: 265283.
Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.
Henderson, C. R. 1953. Estimation of variance and covariance components. Biometrics 9: 226252.
Huq, N. M., and J. Cleland. 1990. Bangladesh Fertility Survey 1989 (Main Report). National Institute of Population
Research and Training.
Kuehl, R. O. 2000. Design of Experiments: Statistical Principles of Research Design and Analysis. 2nd ed. Belmont,
CA: Duxbury.
Laird, N. M., and J. H. Ware. 1982. Random-effects models for longitudinal data. Biometrics 38: 963974.
LaMotte, L. R. 1973. Quadratic estimation of variance components. Biometrics 29: 311330.
Lesaffre, E., and B. Spiessens. 2001. On the effect of the number of quadrature points in a logistic random-effects
model: An example. Journal of the Royal Statistical Society, Series C 50: 325335.
Lin, X., and N. E. Breslow. 1996. Bias correction in generalized linear mixed models with multiple components of
dispersion. Journal of the American Statistical Association 91: 10071016.
Littell, R. C., G. A. Milliken, W. W. Stroup, R. D. Wolfinger, and O. Schabenberger. 2006. SAS System for Mixed
Models. 2nd ed. Cary, NC: SAS Institute.
Liu, Q., and D. A. Pierce. 1994. A note on GaussHermite quadrature. Biometrika 81: 624629.
Marchenko, Y. V. 2006. Estimating variance components in Stata. Stata Journal 6: 121.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
McLachlan, G. J., and K. E. Basford. 1988. Mixture Models. New York: Dekker.
Ng, E. S.-W., J. R. Carpenter, H. Goldstein, and J. Rasbash. 2006. Estimation in generalised linear mixed models
with binary outcomes by simulated maximum likelihood. Statistical Modelling 6: 2342.
Pinheiro, J. C., and D. M. Bates. 2000. Mixed-Effects Models in S and S-PLUS. New York: Springer.
Pinheiro, J. C., and E. C. Chao. 2006. Efficient Laplacian and adaptive Gaussian quadrature algorithms for multilevel
generalized linear mixed models. Journal of Computational and Graphical Statistics 15: 5881.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Rao, C. R. 1973. Linear Statistical Inference and Its Applications. 2nd ed. New York: Wiley.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Rodrguez, G., and N. Goldman. 1995. An assessment of estimation procedures for multilevel models with binary
responses. Journal of the Royal Statistical Society, Series A 158: 7389.
Ruppert, D., M. P. Wand, and R. J. Carroll. 2003. Semiparametric Regression. Cambridge: Cambridge University
Press.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Self, S. G., and K.-Y. Liang. 1987. Asymptotic properties of maximum likelihood estimators and likelihood ratio tests
under nonstandard conditions. Journal of the American Statistical Association 82: 605610.
Skrondal, A., and S. Rabe-Hesketh. 2004. Generalized Latent Variable Modeling: Multilevel, Longitudinal, and
Structural Equation Models. Boca Raton, FL: Chapman & Hall/CRC.
Stram, D. O., and J. W. Lee. 1994. Variance components testing in the longitudinal mixed effects model. Biometrics
50: 11711177.
Thompson, W. A., Jr. 1962. The problem of negative estimates of variance components. Annals of Mathematical
Statistics 33: 273289.

36

me Introduction to multilevel mixed-effects models

Tierney, L., and J. B. Kadane. 1986. Accurate approximations for posterior moments and marginal densities. Journal
of the American Statistical Association 81: 8286.
Turner, R. M., R. Z. Omar, M. Yang, H. Goldstein, and S. G. Thompson. 2000. A multilevel model framework for
meta-analysis of clinical trials with binary outcomes. Statistics in Medicine 19: 434173432.
Tutz, G., and W. Hennevogl. 1996. Random effects in ordinal regression models. Computational Statistics & Data
Analysis 22: 537557.
Vella, F., and M. Verbeek. 1998. Whose wages do unions raise? A dynamic model of unionism and wage rate
determination for young men. Journal of Applied Econometrics 13: 163183.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.

Also see
[ME] Glossary

Title
mecloglog Multilevel mixed-effects complementary log-log regression
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
mecloglog depvar fe equation || re equation

|| re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

noconstant
offset(varname)
asis

suppress constant term from the fixed-effects equation


include varname in model with coefficient constrained to 1
retain perfect predictor variables

re options

Description

Model

covariance(vartype)
noconstant

variancecovariance structure of the random effects


suppress constant term from the random-effects equation

37

38

mecloglog Multilevel mixed-effects complementary log-log regression

options

Description

Model

binomial(varname | #)
constraints(constraints)
collinear

set binomial trials if data are in binomial form


apply specified linear constraints
keep collinear variables

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
eform
nocnsreport
notable
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


report exponentiated coefficients
do not display constraints
suppress coefficient table
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with complementary
log-log regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intmethod(intmethod)
intpoints(#)

integration method
set the number of integration (quadrature) points for all levels;
default is intpoints(7)

Maximization

maximize options

control the maximization process; seldom used

startvalues(svmethod)
startgrid (gridspec)
noestimate
dnumerical
coeflegend

method for obtaining starting values


perform a grid search to improve starting values
do not fit the model; show starting values instead
use numerical derivative techniques
display legend instead of statistics

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0; the
default if the R. notation is used
all variances and covariances to be distinctly estimated
user-selected variances and covariances constrained to specified
values; the remaining variances and covariances unrestricted
user-selected variances and covariances constrained to be equal;
the remaining variances and covariances unrestricted

exchangeable
identity
unstructured
fixed(matname)
pattern(matname)

mecloglog Multilevel mixed-effects complementary log-log regression

intmethod

Description

mvaghermite

mean-variance adaptive GaussHermite quadrature; the default


unless a crossed random-effects model is fit
mode-curvature adaptive GaussHermite quadrature
nonadaptive GaussHermite quadrature
Laplacian approximation; the default for crossed random-effects
models

mcaghermite
ghermite
laplace

39

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
by is allowed; see [U] 11.1.10 Prefix commands.
startvalues(), startgrid, noestimate, dnumerical, and coeflegend do not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Complementary log-log regression

Description
mecloglog fits mixed-effects models for binary or binomial responses. The conditional distribution
of the response given the random effects is assumed to be Bernoulli, with probability of success
determined by the inverse complementary log-log function.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
offset(varname) specifies that varname be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
asis forces retention of perfect predictor variables and their associated, perfectly predicted observations
and may produce instabilities in maximization; see [R] probit.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, unstructured, fixed(matname), or pattern(matname).
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent) unless a crossed random-effects model is fit, in which case the
default is covariance(identity).
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.
covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.

40

mecloglog Multilevel mixed-effects complementary log-log regression

covariance(unstructured) allows for all variances and covariances to be distinct. If an equation


consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2
unique parameters.
covariance(fixed(matname)) and covariance(pattern(matname)) covariance structures
provide a convenient way to impose constraints on variances and covariances of random effects.
Each specification requires a matname that defines the restrictions placed on variances and
covariances. Only elements in the lower triangle of matname are used, and row and column names
of matname are ignored. A missing value in matname means that a given element is unrestricted.
In a fixed(matname) covariance structure, (co)variance (i, j) is constrained to equal the
value specified in the i, j th entry of matname. In a pattern(matname) covariance structure,
(co)variances (i, j) and (k, l) are constrained to be equal if matname[i, j] = matname[k, l].
binomial(varname | #) specifies that the data are in binomial form; that is, depvar records the number
of successes from a series of binomial trials. This number of trials is given either as varname,
which allows this number to vary over the observations, or as the constant #. If binomial() is
not specified (the default), depvar is treated as Bernoulli, with any nonzero, nonmissing values
indicating positive responses.
constraints(constraints), collinear; see [R] estimation options.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.

Reporting

level(#); see [R] estimation options.


eform reports exponentiated coefficients and corresponding standard errors and confidence intervals.
This option may be specified either at estimation or upon replay.
nocnsreport; see [R] estimation options.
notable suppresses the estimation table, either at estimation or upon replay.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents mecloglog from performing a likelihood-ratio test that compares the mixed-effects
complementary log-log model with standard (marginal) complementary log-log regression. This
option may also be specified upon replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

Integration

intmethod(intmethod) specifies the integration method to be used for the random-effects model.
mvaghermite performs mean and variance adaptive GaussHermite quadrature; mcaghermite
performs mode and curvature adaptive GaussHermite quadrature; ghermite performs nonadaptive
GaussHermite quadrature; and laplace performs the Laplacian approximation, equivalent to mode
curvature adaptive Gaussian quadrature with one integration point.

mecloglog Multilevel mixed-effects complementary log-log regression

41

The default integration method is mvaghermite unless a crossed random-effects model is fit, in
which case the default integration method is laplace. The Laplacian approximation has been
known to produce biased parameter estimates; however, the bias tends to be more prominent in
the estimates of the variance components rather than in the estimates of the fixed effects.
For crossed random-effects models, estimation with more than one quadrature point may be
prohibitively intensive even for a small number of levels. For this reason, the integration method
defaults to the Laplacian approximation. You may override this behavior by specifying a different
integration method.
intpoints(#) sets the number of integration points for quadrature. The default is intpoints(7),
which means that seven quadrature points are used for each level of random effects. This option
is not allowed with intmethod(laplace).
The more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases as a function of the number of quadrature points raised to a power
equaling the dimension of the random-effects specification. In crossed random-effects models and
in models with many levels or many random coefficients, this increase can be substantial.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for mecloglog are listed below.
from() accepts a properly labeled vector of initial values or a list of coefficient names with values.
A list of values is not allowed.
The following options are available with mecloglog but are not shown in the dialog box:
startvalues(svmethod), startgrid (gridspec) , noestimate, and dnumerical; see [ME]
meglm.
coeflegend; see [R] estimation options.

Remarks and examples


For a general introduction to me commands, see [ME] me.
mecloglog is a convenience command for meglm with a cloglog link and a bernoulli or
binomial family; see [ME] meglm.
Remarks are presented under the following headings:
Introduction
Two-level models
Three-level models

Introduction
Mixed-effects complementary log-log regression is complementary log-log regression containing
both fixed effects and random effects. In longitudinal data and panel data, random effects are useful
for modeling intracluster correlation; that is, observations in the same cluster are correlated because
they share common cluster-level random effects.

42

mecloglog Multilevel mixed-effects complementary log-log regression

Comprehensive treatments of mixed models are provided by, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and
Skrondal (2012). Guo and Zhao (2000) and Rabe-Hesketh and Skrondal (2012, chap. 10) are good
introductory readings on applied multilevel modeling of binary data.
mecloglog allows for not just one, but many levels of nested clusters of random effects. For
example, in a three-level model you can specify random effects for schools and then random effects
for classes nested within schools. In this model, the observations (presumably, the students) comprise
the first level, the classes comprise the second level, and the schools comprise the third.
However, for simplicity, we here consider the two-level model, where for a series of M independent
clusters, and conditional on a set of fixed effects xij and a set of random effects uj ,
Pr(yij = 1|xij , uj ) = H(xij + zij uj )

(1)

for j = 1, . . . , M clusters, with cluster j consisting of i = 1, . . . , nj observations. The responses are


the binary-valued yij , and we follow the standard Stata convention of treating yij = 1 if depvarij = 0
and treating yij = 0 otherwise. The 1 p row vector xij are the covariates for the fixed effects,
analogous to the covariates you would find in a standard cloglog regression model, with regression
coefficients (fixed effects) . For notational convenience here and throughout this manual entry, we
suppress the dependence of yij on xij .
The 1 q vector zij are the covariates corresponding to the random effects and can be used to
represent both random intercepts and random coefficients. For example, in a random-intercept model,
zij is simply the scalar 1. The random effects uj are M realizations from a multivariate normal
distribution with mean 0 and q q variance matrix . The random effects are not directly estimated
as model parameters but are instead summarized according to the unique elements of , known
as variance components. One special case of (1) places zij = xij , so that all covariate effects are
essentially random and distributed as multivariate normal with mean and variance .
Finally, because this is cloglog regression, H() is the inverse of the complementary log-log function
that maps the linear predictor to the probability of a success (yij = 1) with H(v) = 1exp{ exp(v)}.

Model (1) may also be stated in terms of a latent linear response, where only yij = I(yij
> 0)
is observed for the latent

yij
= xij + zij uj + ij

The errors ij are independent and identically extreme-value (Gumbel) distributed with the mean
equal to Eulers constant and variance 2 = 2 /6, independently of uj . This nonsymmetric error
distribution is an alternative to the symmetric error distribution underlying logistic and probit analysis
and is usually used when the positive (or negative) outcome is rare.
Model (1) is an example of a generalized linear mixed model (GLMM), which generalizes the
linear mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using
mixed and fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there
is insight to be gained through examination of the linear mixed model. This is especially true for
Stata users because the terminology, syntax, options, and output for fitting these types of models are
nearly identical. See [ME] mixed and the references therein, particularly in Introduction, for more
information.
Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out
the random effects. One widely used modern method is to directly estimate the integral required to
calculate the log likelihood by GaussHermite quadrature or some variation thereof. Because the log
likelihood itself is estimated, this method has the advantage of permitting likelihood-ratio tests for
comparing nested models. Also, if done correctly, quadrature approximations can be quite accurate,
thus minimizing bias.

mecloglog Multilevel mixed-effects complementary log-log regression

43

mecloglog supports three types of GaussHermite quadrature and the Laplacian approximation
method; see Methods and formulas of [ME] meglm for details. The simplest random-effects model
you can fit using mecloglog is the two-level model with a random intercept,
Pr(yij = 1|uj ) = H(xij + uj )
This model can also be fit using xtcloglog with the re option; see [XT] xtcloglog.
Below we present two short examples of mixed-effects cloglog regression; refer to [ME] melogit for
additional examples including crossed-effects models and to [ME] me and [ME] meglm for examples
of other random-effects models.

Two-level models
We begin with a simple application of (1) as a two-level model, because a one-level model, in our
terminology, is just standard cloglog regression; see [R] cloglog.

Example 1
In example 1 of [XT] xtcloglog, we analyze unionization of women in the United States over
the period 19701988. The women are identified by the variable idcode. Here we refit that model
with mecloglog. Because the original example used 12 integration points by default, we request 12
integration points as well.

44

mecloglog Multilevel mixed-effects complementary log-log regression


. use http://www.stata-press.com/data/r13/union
(NLS Women 14-24 in 1968)
. mecloglog union age grade not_smsa south##c.year || idcode:, intpoints(12)
Fitting fixed-effects model:
Iteration 0:
log likelihood
Iteration 1:
log likelihood
Iteration 2:
log likelihood
Iteration 3:
log likelihood
Iteration 4:
log likelihood
Refining starting values:
Grid node 0:
log likelihood

=
=
=
=
=

-14237.139
-13546.159
-13540.611
-13540.607
-13540.607

= -11104.448

Fitting full model:


Iteration 0:
log likelihood = -11104.448
Iteration 1:
log likelihood = -10617.891
Iteration 2:
log likelihood = -10537.919
Iteration 3:
log likelihood = -10535.946
Iteration 4:
log likelihood = -10535.941
Iteration 5:
log likelihood = -10535.941
Mixed-effects cloglog regression
Group variable:
idcode

Number of obs
Number of groups
Obs per group: min
avg
max
Integration points
Wald chi2(6)
Prob > chi2

Integration method: mvaghermite


Log likelihood = -10535.941
Coef.

age
grade
not_smsa
1.south
year

.0128542
.0699965
-.1982009
-2.049901
-.0006158

.0119441
.0138551
.0649258
.4892644
.0123999

1.08
5.05
-3.05
-4.19
-0.05

0.282
0.000
0.002
0.000
0.960

-.0105559
.0428409
-.3254531
-3.008842
-.0249191

.0362642
.097152
-.0709488
-1.090961
.0236875

south#c.year
1

.0164457

.0060685

2.71

0.007

.0045516

.0283399

_cons

-3.277375

.6610552

-4.96

0.000

-4.57302

-1.981731

3.489803

.1630921

3.184351

3.824555

LR test vs. cloglog regression:

chibar2(01) =

P>|z|

26200
4434
1
5.9
12
12
248.12
0.0000

union

idcode
var(_cons)

Std. Err.

=
=
=
=
=
=
=
=

[95% Conf. Interval]

6009.33 Prob>=chibar2 = 0.0000

The estimates are practically the same. xtcloglog reports the estimated variance component as a
standard deviation, u = 1.86. mecloglog reports u2 = 3.49, the square root of which is 1.87. We
find that age and education each have a positive effect on union membership, although the former is
not statistically significant. Women who live outside of metropolitan areas are less likely to unionize.
The estimated variance of the random intercept at the individual level, 2 , is 3.49 with standard
error 0.16. The reported likelihood-ratio test shows that there is enough variability between women to
favor a mixed-effects cloglog regression over an ordinary cloglog regression; see Distribution theory
for likelihood-ratio test in [ME] me for a discussion of likelihood-ratio testing of variance components.

mecloglog Multilevel mixed-effects complementary log-log regression

45

Three-level models
Two-level models extend naturally to models with three or more levels with nested random effects.
Below we analyze the data from example 2 of [ME] melogit with mecloglog.

Example 2
Rabe-Hesketh, Toulopoulou, and Murray (2001) analyzed data from a study that measured the
cognitive ability of patients with schizophrenia compared with their relatives and control subjects.
Cognitive ability was measured as the successful completion of the Tower of London, a computerized
task, measured at three levels of difficulty. For all but one of the 226 subjects, there were three
measurements (one for each difficulty level). Because patients relatives were also tested, a family
identifier, family, was also recorded.
We fit a cloglog model with response dtlm, the indicator of cognitive function, and with covariates
difficulty and a set of indicator variables for group, with the controls (group==1) being the base
category. We also allow for random effects due to families and due to subjects within families.

46

mecloglog Multilevel mixed-effects complementary log-log regression


. use http://www.stata-press.com/data/r13/towerlondon
(Tower of London data)
. mecloglog dtlm difficulty i.group || family: || subject:
Fitting fixed-effects model:
Iteration 0:
log likelihood
Iteration 1:
log likelihood
Iteration 2:
log likelihood
Iteration 3:
log likelihood
Iteration 4:
log likelihood
Refining starting values:
Grid node 0:
log likelihood

=
=
=
=
=

-337.21921
-313.79023
-313.56906
-313.56888
-313.56888

= -314.57061

Fitting full model:


Iteration 0:
log likelihood = -314.57061
Iteration 1:
log likelihood = -308.82101
Iteration 2:
log likelihood = -305.71841
Iteration 3:
log likelihood = -305.26804
Iteration 4:
log likelihood = -305.26516
Iteration 5:
log likelihood = -305.26516
Mixed-effects cloglog regression

Group Variable

No. of
Groups

family
subject

118
226

(not concave)

Number of obs

677

Observations per Group


Minimum
Average
Maximum
2
2

5.7
3.0

27
3

Integration method: mvaghermite

Integration points =

Log likelihood = -305.26516

Wald chi2(3)
Prob > chi2
Std. Err.

P>|z|

=
=

7
83.32
0.0000

dtlm

Coef.

[95% Conf. Interval]

difficulty

-1.342844

.1501508

-8.94

0.000

-1.637135

-1.048554

group
2
3

-.1331007
-.7714314

.269389
.3097099

-0.49
-2.49

0.621
0.013

-.6610935
-1.378452

.3948922
-.164411

_cons

-1.6718

.2290325

-7.30

0.000

-2.120695

-1.222905

family
var(_cons)

.2353453

.2924064

.0206122

2.687117

family>
subject
var(_cons)

.7737687

.4260653

.2629714

2.276742

LR test vs. cloglog regression:


chi2(2) =
16.61
Prob > chi2 = 0.0002
Note: LR test is conservative and provided only for reference.

Notes:
1. This is a three-level model with two random-effects equations, separated by ||. The first is a
random intercept (constant only) at the family level, and the second is a random intercept at the
subject level. The order in which these are specified (from left to right) is significantmecloglog
assumes that subject is nested within family.

mecloglog Multilevel mixed-effects complementary log-log regression

47

2. The information on groups is now displayed as a table, with one row for each upper level. Among
other things, we see that we have 226 subjects from 118 families. You can suppress this table
with the nogroup or the noheader option, which will suppress the rest of the header as well.
After adjusting for the random-effects structure, the probability of successful completion of the
Tower of London decreases dramatically as the level of difficulty increases. Also, schizophrenics
(group==3) tended not to perform as well as the control subjects.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left to
right as the groups go from biggest (highest level) to smallest (lowest level).

Stored results
mecloglog stores the following in e():
Scalars
e(N)
e(k)
e(k dv)
e(k eq)
e(k eq model)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(N clust)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(ic)
e(rc)
e(converged)

number of observations
number of parameters
number of dependent variables
number of equations in e(b)
number of equations in overall model test
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
number of clusters
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
number of iterations
return code
1 if converged, 0 otherwise

48

mecloglog Multilevel mixed-effects complementary log-log regression


Macros
e(cmd)
e(cmdline)
e(depvar)
e(covariates)
e(ivars)
e(model)
e(title)
e(link)
e(family)
e(clustvar)
e(offset)
e(binomial)
e(intmethod)
e(n quad)
e(chi2type)
e(vce)
e(vcetype)
e(opt)
e(which)
e(ml method)
e(user)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)
Matrices
e(b)
e(Cns)
e(ilog)
e(gradient)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
e(V modelbased)
Functions
e(sample)

mecloglog
command as typed
name of dependent variable
list of covariates
grouping variables
cloglog
title in estimation output
cloglog
bernoulli or binomial
name of cluster variable
offset
binomial number of trials
integration method
number of integration points
Wald; type of model 2
vcetype specified in vce()
title used to label Std. Err.
type of optimization
max or min; whether optimizer is to perform maximization or minimization
type of ml method
name of likelihood-evaluator program
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict
coefficient vector
constraints matrix
iteration log (up to 20 iterations)
gradient vector
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
model-based variance
marks estimation sample

Methods and formulas


Model (1) assumes Bernoulli data, a special case of the binomial. Because binomial data are also
supported by mecloglog (option binomial()), the methods presented below are in terms of the
more general binomial mixed-effects model.
For a two-level binomial model, consider the response yij as the number of successes from a
series of rij Bernoulli trials (replications). For cluster j , j = 1, . . . , M , the conditional distribution
of yj = (yj1 , . . . , yjnj ) , given a set of cluster-level random effects uj , is

mecloglog Multilevel mixed-effects complementary log-log regression

nj

f (yj |uj ) =
i=1

rij
yij

H(ij )

yij

1 H(ij )

rij yij

nj

yij log H(ij ) (rij yij ) exp(ij ) + log

= exp

49

i=1

rij
yij

for ij = xij + zij uj + offsetij and H(v) = 1 exp{ exp(v)}.


Defining rj = (rj1 , . . . , rjnj ) and
nj

log

c (yj , rj ) =
i=1

rij
yij

where c(yj , rj ) does not depend on the model parameters, we can express the above compactly in
matrix notation,

f (yj |uj ) = exp yj log H(j ) (rj yj ) exp(j ) + c (yj , rj )


where j is formed by stacking the row vectors ij . We extend the definitions of the functions H(),
log(), and exp() to be vector functions where necessary.
Because the prior distribution of uj is multivariate normal with mean 0 and q q variance matrix
, the likelihood contribution for the j th cluster is obtained by integrating uj out of the joint density
f (yj , uj ),
1/2

Lj (, ) = (2)q/2 ||

f (yj |uj ) exp uj 1 uj /2 duj


(2)

= exp {c (yj , rj )} (2)q/2 ||


where

1/2

exp {g (, , uj )} duj

g (, , uj ) = yj log H(j ) (rj yj ) exp(j ) uj 1 uj /2

and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , rj , Xj , Zj ).
The integration in (2) has no closed form and thus must be approximated. mecloglog offers
four approximation methods: meanvariance adaptive GaussHermite quadrature (default), modecurvature adaptive GaussHermite quadrature, nonadaptive GaussHermite quadrature, and Laplacian
approximation.
The Laplacian approximation is based on a second-order Taylor expansion of g (, , uj ) about
the value of uj that maximizes it; see Methods and formulas in [ME] meglm for details.
Gaussian quadrature relies on transforming the multivariate integral in (2) into a set of nested
univariate integrals. Each univariate integral can then be evaluated using a form of Gaussian quadrature;
see Methods and formulas in [ME] meglm for details.
The log likelihood for the entire dataset is simply the sum of the contributions of the M individual
M
clusters, namely, L(, ) = j=1 Lj (, ).
Maximization of L(, ) is performed with respect to (, 2 ), where 2 is a vector comprising
the unique elements of . Parameter estimates are stored in e(b) as (, 2 ), with the corresponding
variancecovariance matrix stored in e(V).

50

mecloglog Multilevel mixed-effects complementary log-log regression

References
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.
Guo, G., and H. Zhao. 2000. Multilevel modeling of binary data. Annual Review of Sociology 26: 441462.
Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Rabe-Hesketh, S., T. Toulopoulou, and R. M. Murray. 2001. Multilevel modeling of cognitive function in schizophrenic
patients and their first degree relatives. Multivariate Behavioral Research 36: 279298.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.

Also see
[ME] mecloglog postestimation Postestimation tools for mecloglog
[ME] melogit Multilevel mixed-effects logistic regression
[ME] meprobit Multilevel mixed-effects probit regression
[ME] me Introduction to multilevel mixed-effects models
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtcloglog Random-effects and population-averaged cloglog models
[U] 20 Estimation and postestimation commands

Title
mecloglog postestimation Postestimation tools for mecloglog
Description
Options for predict
Remarks and examples

Syntax for predict


Syntax for estat group
Methods and formulas

Menu for predict


Menu for estat
Also see

Description
The following postestimation command is of special interest after mecloglog:
Command

Description

estat group

summarize the composition of the nested groups

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
51

52

mecloglog postestimation Postestimation tools for mecloglog

Syntax for predict


Syntax for obtaining predictions of random effects and their standard errors
predict

type

newvarsspec

if

in ,

remeans | remodes

reses(newvarsspec)

Syntax for obtaining other predictions


predict

type

newvarsspec

if

in

, statistic options

newvarsspec is stub* or newvarlist.


Description

statistic
Main

predicted mean; the default


fitted linear predictor
linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction
Pearson residuals
deviance residuals
Anscombe residuals

mu
fitted
xb
stdp
pearson
deviance
anscombe

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

Description

options
Main

means
modes
nooffset
fixedonly

compute statistic using empirical Bayes means; the default


compute statistic using empirical Bayes modes
ignore the offset variable in calculating predictions; relevant only
if you specified offset() when you fit the model
prediction for the fixed portion of the model only

Integration

intpoints(#)
iterate(#)
tolerance(#)

use # quadrature points to compute empirical Bayes means


set maximum number of iterations in computing statistics involving
empirical Bayes estimators
set convergence tolerance for computing statistics involving empirical
Bayes estimators

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

mecloglog postestimation Postestimation tools for mecloglog

53

Options for predict

Main

remeans, remodes, reses(); see [ME] meglm postestimation.


mu, the default, calculates the predicted mean (the probability of a positive outcome), that is, the
inverse link function applied to the linear prediction. By default, this is based on a linear predictor
that includes both the fixed effects and the random effects, and the predicted mean is conditional on
the values of the random effects. Use the fixedonly option if you want predictions that include
only the fixed portion of the model, that is, if you want random effects set to 0.
fitted, xb, stdp, pearson, deviance, anscombe, means, modes, nooffset, fixedonly; see
[ME] meglm postestimation.
By default or if the means option is specified, statistics mu, fitted, xb, stdp, pearson, deviance,
and anscombe are based on the posterior mean estimates of random effects. If the modes option
is specified, these statistics are based on the posterior mode estimates of random effects.

Integration

intpoints(), iterate(), tolerance(); see [ME] meglm postestimation.

Syntax for estat group


estat group

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a mixed-effects
complementary log-log model with mecloglog. Here we show a short example of predicted probabilities and predicted random effects; refer to [ME] meglm postestimation for additional examples.

Example 1
In example 2 of [ME] mecloglog, we analyzed the cognitive ability (dtlm) of patients with
schizophrenia compared with their relatives and control subjects. We used a three-level complementary
log-log model with random effects at the family and subject levels. Cognitive ability was measured
as the successful completion of the Tower of London, a computerized task, measured at three levels
of difficulty.

54

mecloglog postestimation Postestimation tools for mecloglog


. use http://www.stata-press.com/data/r13/towerlondon
(Tower of London data)
. mecloglog dtlm difficulty i.group || family: || subject:
Fitting fixed-effects model:
(output omitted )
Mixed-effects cloglog regression

Group Variable

No. of
Groups

family
subject

118
226

Number of obs

677

Integration points =
Wald chi2(3)
=
Prob > chi2
=

7
83.32
0.0000

Observations per Group


Minimum
Average
Maximum
2
2

5.7
3.0

Integration method: mvaghermite


Log likelihood = -305.26516
Std. Err.

27
3

dtlm

Coef.

P>|z|

[95% Conf. Interval]

difficulty

-1.342844

.1501508

-8.94

0.000

-1.637135

-1.048554

group
2
3

-.1331007
-.7714314

.269389
.3097099

-0.49
-2.49

0.621
0.013

-.6610935
-1.378452

.3948922
-.164411

_cons

-1.6718

.2290325

-7.30

0.000

-2.120695

-1.222905

family
var(_cons)

.2353453

.2924064

.0206122

2.687117

family>
subject
var(_cons)

.7737687

.4260653

.2629714

2.276742

LR test vs. cloglog regression:


chi2(2) =
16.61
Prob > chi2 = 0.0002
Note: LR test is conservative and provided only for reference.

We obtain predicted probabilities based on the contribution of both fixed effects and random effects
by typing
. predict pr
(predictions based on fixed effects and posterior means of random effects)
(option mu assumed)
(using 7 quadrature points)

As the note says, the predicted values are based on the posterior means of random effects. You
can use the modes option to obtain predictions based on the posterior modes of random effects.
We obtain predictions of the posterior means themselves by typing
. predict re*, remeans
(calculating posterior means of random effects)
(using 7 quadrature points)

Because we have one random effect at the family level and another random effect at the subject
level, Stata saved the predicted posterior means in the variables re1 and re2, respectively. If you are
not sure which prediction corresponds to which level, you can use the describe command to show
the variable labels.

mecloglog postestimation Postestimation tools for mecloglog

55

Here we list the data for family 16:


. list family subject dtlm pr re1 re2 if family==16, sepby(subject)
family

subject

dtlm

pr

re1

re2

208.
209.
210.

16
16
16

5
5
5

1
0
0

.486453
.1597047
.0444156

.4184933
.4184933
.4184933

.2760492
.2760492
.2760492

211.
212.
213.

16
16
16

34
34
34

1
1
1

.9659582
.5862808
.205816

.4184933
.4184933
.4184933

1.261488
1.261488
1.261488

214.
215.
216.

16
16
16

35
35
35

0
1
0

.5571261
.1915688
.0540124

.4184933
.4184933
.4184933

-.1616545
-.1616545
-.1616545

We can see that the predicted random effects (re1) at the family level are the same for all members
of the family. Similarly, the predicted random effects (re2) at the individual level are constant within
each individual. Based on a cutoff of 0.5, the predicted probabilities (pr) for this family do not match
the observed outcomes (dtlm) as well as the predicted probabilities from the logistic example; see
example 1 in [ME] melogit postestimation.

Methods and formulas


Methods and formulas for predicting random effects and other statistics are given in Methods and
formulas of [ME] meglm postestimation.

Also see
[ME] mecloglog Multilevel mixed-effects complementary log-log regression
[ME] meglm postestimation Postestimation tools for meglm
[U] 20 Estimation and postestimation commands

Title
meglm Multilevel mixed-effects generalized linear model
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
|| re equation . . .

meglm depvar fe equation || re equation

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

noconstant
exposure(varnamee )
offset(varnameo )
asis

suppress the constant term from the fixed-effects equation


include ln(varnamee ) in model with coefficient constrained to 1
include varnameo in model with coefficient constrained to 1
retain perfect predictor variables

re options

Description

Model

covariance(vartype)
noconstant

variancecovariance structure of the random effects


suppress constant term from the random-effects equation

56

meglm Multilevel mixed-effects generalized linear model

options

57

Description

Model

family(family)
link(link)
constraints(constraints)
collinear

distribution of depvar; default is family(gaussian)


link function; default varies per family
apply specified linear constraints
keep collinear variables

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
eform
irr
or
nocnsreport
notable
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


report exponentiated fixed-effects coefficients
report fixed-effects coefficients as incidence-rate ratios
report fixed-effects coefficients as odds ratios
do not display constraints
suppress coefficient table
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with reference model
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intmethod(intmethod)
intpoints(#)

integration method
set the number of integration (quadrature) points for all levels;
default is intpoints(7)

Maximization

maximize options

control the maximization process; seldom used

startvalues(svmethod)
startgrid (gridspec)
noestimate
dnumerical
coeflegend

method for obtaining starting values


perform a grid search to improve starting values
do not fit the model; show starting values instead
use numerical derivative techniques
display legend instead of statistics

58

meglm Multilevel mixed-effects generalized linear model

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0; the
default if the R. notation is used
all variances and covariances to be distinctly estimated
user-selected variances and covariances constrained to specified
values; the remaining variances and covariances unrestricted
user-selected variances and covariances constrained to be equal;
the remaining variances and covariances unrestricted

exchangeable
identity
unstructured
fixed(matname)
pattern(matname)

family

Description

gaussian
bernoulli
binomial # | varname
gamma
nbinomial mean | constant
ordinal
poisson

Gaussian (normal); the default


Bernoulli
binomial; default number of binomial trials is 1
gamma
negative binomial; default dispersion is mean
ordinal
Poisson

link

Description

identity
log
logit
probit
cloglog

identity
log
logit
probit
complementary log-log

intmethod

Description

mvaghermite

mean-variance adaptive GaussHermite quadrature; the default


unless a crossed random-effects model is fit
mode-curvature adaptive GaussHermite quadrature
nonadaptive GaussHermite quadrature
Laplacian approximation; the default for crossed random-effects
models

mcaghermite
ghermite
laplace

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
by is allowed; see [U] 11.1.10 Prefix commands.
startvalues(), startgrid, noestimate, dnumerical, and coeflegend do not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

meglm Multilevel mixed-effects generalized linear model

59

Menu
Statistics

>

Multilevel mixed-effects models

>

Generalized linear models (GLMs)

Description
meglm fits multilevel mixed-effects generalized linear models. meglm allows a variety of distributions
for the response conditional on normally distributed random effects.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
exposure(varnamee ) specifies a variable that reflects the amount of exposure over which the depvar
events were observed for each observation; ln(varnamee ) is included in the fixed-effects portion
of the model with the coefficient constrained to be 1.
offset(varnameo ) specifies that varnameo be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
asis forces retention of perfect predictor variables and their associated, perfectly predicted observations
and may produce instabilities in maximization; see [R] probit.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, unstructured, fixed(matname), or pattern(matname).
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent) unless a crossed random-effects model is fit, in which case the
default is covariance(identity).
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.
covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.
covariance(unstructured) allows for all variances and covariances to be distinct. If an equation
consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2
unique parameters.
covariance(fixed(matname)) and covariance(pattern(matname)) covariance structures
provide a convenient way to impose constraints on variances and covariances of random effects.
Each specification requires a matname that defines the restrictions placed on variances and
covariances. Only elements in the lower triangle of matname are used, and row and column names
of matname are ignored. A missing value in matname means that a given element is unrestricted.
In a fixed(matname) covariance structure, (co)variance (i, j) is constrained to equal the
value specified in the i, j th entry of matname. In a pattern(matname) covariance structure,
(co)variances (i, j) and (k, l) are constrained to be equal if matname[i, j] = matname[k, l].
family(family) specifies the distribution of depvar; family(gaussian) is the default.
link(link) specifies the link function; the default is the canonical link for the family() specified
except for the gamma and negative binomial families.

60

meglm Multilevel mixed-effects generalized linear model

If you specify both family() and link(), not all combinations make sense. You may choose
from the following combinations:

Gaussian
Bernoulli
binomial
gamma
negative binomial
ordinal
Poisson
D denotes the default.

identity

log

logit

probit

cloglog

D
D

x
x

x
x

D
D
D

constraints(constraints), collinear; see [R] estimation options.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.

Reporting

level(#); see [R] estimation options.


eform reports exponentiated fixed-effects coefficients and corresponding standard errors and confidence
intervals. This option may be specified either at estimation or upon replay.
irr reports estimated fixed-effects coefficients transformed to incidence-rate ratios, that is, exp()
rather than . Standard errors and confidence intervals are similarly transformed. This option
affects how results are displayed, not how they are estimated or stored. irr may be specified
either at estimation or upon replay. This option is allowed for count models only.
or reports estimated fixed-effects coefficients transformed to odds ratios, that is, exp() rather than .
Standard errors and confidence intervals are similarly transformed. This option affects how results
are displayed, not how they are estimated. or may be specified at estimation or upon replay. This
option is allowed for logistic models only.
nocnsreport; see [R] estimation options.
notable suppresses the estimation table, either at estimation or upon replay.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents meglm from fitting a reference linear regression model and using this model to
calculate a likelihood-ratio test comparing the mixed model with ordinary regression. This option
may also be specified upon replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

meglm Multilevel mixed-effects generalized linear model

Integration

61

intmethod(intmethod) specifies the integration method to be used for the random-effects model.
mvaghermite performs mean and variance adaptive GaussHermite quadrature; mcaghermite
performs mode and curvature adaptive GaussHermite quadrature; ghermite performs nonadaptive
GaussHermite quadrature; and laplace performs the Laplacian approximation, equivalent to mode
curvature adaptive Gaussian quadrature with one integration point.
The default integration method is mvaghermite unless a crossed random-effects model is fit, in
which case the default integration method is laplace. The Laplacian approximation has been
known to produce biased parameter estimates; however, the bias tends to be more prominent in
the estimates of the variance components rather than in the estimates of the fixed effects.
For crossed random-effects models, estimation with more than one quadrature point may be
prohibitively intensive even for a small number of levels. For this reason, the integration method
defaults to the Laplacian approximation. You may override this behavior by specifying a different
integration method.
intpoints(#) sets the number of integration points for quadrature. The default is intpoints(7),
which means that seven quadrature points are used for each level of random effects. This option
is not allowed with intmethod(laplace).
The more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases as a function of the number of quadrature points raised to a power
equaling the dimension of the random-effects specification. In crossed random-effects models and
in models with many levels or many random coefficients, this increase can be substantial.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for meglm are listed below.
from() accepts a properly labeled vector of initial values or a list of coefficient names with values.
A list of values is not allowed.
The following options are available with meglm but are not shown in the dialog box:
startvalues(svmethod) specifies how starting values are to be computed. Starting values specified
in from() override the computed starting values.
startvalues(zero) specifies that starting values be set to 0.
startvalues(constantonly) builds on startvalues(zero) by fitting a constant-only model
to obtain estimates of the intercept and auxiliary parameters, and it substitutes 1 for the variances
of random effects.
startvalues(fixedonly) builds on startvalues(constantonly) by fitting a full fixedeffects model to obtain estimates of coefficients along with intercept and auxiliary parameters, and
it continues to use 1 for the variances of random effects. This is the default behavior.
startvalues(iv) builds on startvalues(fixedonly) by using instrumental-variable methods
with generalized residuals to obtain variances of random effects.
startgrid (gridspec) performs a grid search on variance components of random effects to improve
starting values. No grid search is performed by default unless the starting values are found to be
not feasible, in which case meglm runs startgrid() to perform a minimal search involving
q 3 likelihood evaluations, where q is the number of random effects. Sometimes this resolves the

62

meglm Multilevel mixed-effects generalized linear model

problem. Usually, however, there is no problem and startgrid() is not run by default. There
can be benefits from running startgrid() to get better starting values even when starting values
are feasible.
startgrid() is a brute-force approach that tries various values for variances and covariances
and chooses the ones that work best. You may already be using a default form of startgrid()
without knowing it. If you see meglm displaying Grid node 1, Grid node 2, . . . following Grid
node 0 in the iteration log, that is meglm doing a default search because the original starting values
were not feasible. The default form tries 0.1, 1, and 10 for all variances of all random effects.
startgrid(numlist) specifies values to try for variances of random effects.
startgrid(covspec) specifies the particular variances and covariances in which grid searches
are to be performed. covspec is name[level] for variances and name1[level]*name2[level] for
covariances. For example, the variance of the random intercept at level id is specified as cons[id],
and the variance of the random slope on variable week at the same level is specified as week[id].
The residual variance for the linear mixed-effects model is specified as e.depvar, where depvar
is the name of the dependent variable. The covariance between the random slope and the random
intercept above is specified as cons[id]*week[id].
startgrid(numlist covspec) combines the two syntaxes. You may also specify startgrid()
multiple times so that you can search the different ranges for different variances and covariances.
noestimate specifies that the model is not to be fit. Instead, starting values are to be shown (as
modified by the above options if modifications were made), and they are to be shown using the
coeflegend style of output.
dnumerical specifies that during optimization, the gradient vector and Hessian matrix be computed
using numerical techniques instead of analytical formulas. By default, analytical formulas for computing the gradient and Hessian are used for all integration methods except intmethod(laplace).
coeflegend; see [R] estimation options.

Remarks and examples


For a general introduction to me commands, see [ME] me. For additional examples of mixed-effects
models for binary and binomial outcomes, see [ME] melogit, [ME] meprobit, and [ME] mecloglog.
For additional examples of mixed-effects models for ordinal responses, see [ME] meologit and
[ME] meoprobit. For additional examples of mixed-effects models for multinomial outcomes, see
[SEM] example 41g. For additional examples of mixed-effects models for count outcomes, see
[ME] mepoisson and [ME] menbreg.
Remarks are presented under the following headings:
Introduction
Two-level models for continuous responses
Two-level models for nonlinear responses
Three-level models for nonlinear responses
Crossed-effects models
Obtaining better starting values

meglm Multilevel mixed-effects generalized linear model

63

Introduction
meglm fits multilevel mixed-effects generalized linear models of the form

g E(y|X, u) = X + Zu,

yF

(1)

where y is the n 1 vector of responses from the distributional family F , X is an np design/covariate


matrix for the fixed effects , and Z is the n q design/covariate matrix for the random effects u.
The X + Zu part is called the linear predictor, and it is often denoted as . The linear predictor
also contains the offset or exposure variable when offset() or exposure() is specified. g() is
called the link function and is assumed to be invertible such that

E(y|X, u) = g 1 (X + Zu) = h() =


For notational convenience here and throughout this manual entry, we suppress the dependence of y
on X. Substituting various definitions for g() and F results in a wide array of models. For instance,
if y is distributed as Gaussian (normal) and g() is the identity function, we have

E(y) = X + Zu,

y normal

or mixed-effects linear regression. If g() is the logit function and y is distributed as Bernoulli, we
have
logit E(y) = X + Zu,
y Bernoulli
or mixed-effects logistic regression. If g() is the natural log function and y is distributed as Poisson,
we have
ln E(y) = X + Zu,
y Poisson
or mixed-effects Poisson regression. In fact, some combinations of families and links are so common
that we implemented them as separate commands in terms of meglm.
Command
melogit
meprobit
mecloglog
meologit
meoprobit
mepoisson
menbreg

meglm equivalent
family(bernoulli) link(logit)
family(bernoulli) link(probit)
family(bernoulli) link(cloglog)
family(ordinal) link(logit)
family(ordinal) link(probit)
family(poisson) link(log)
family(nbinomial) link(log)

When no familylink combination is specified, meglm defaults to a Gaussian family with an


identity link. Thus meglm can be used to fit linear mixed-effects models; however, for those models
we recommend using the more specialized mixed, which, in addition to meglm capabilities, accepts
frequency and sampling weights and allows for modeling of the structure of the residual errors; see
[ME] mixed for details.
The random effects u are assumed to be distributed as multivariate normal with mean 0 and q q
variance matrix . The random effects are not directly estimated (although they may be predicted),
but instead are characterized by the variance components, the elements of G = Var(u).

64

meglm Multilevel mixed-effects generalized linear model

The general forms of the design matrices X and Z allow estimation for a broad class of generalized
mixed-effects models: blocked designs, split-plot designs, growth curves, multilevel or hierarchical
designs, etc. They also allow a flexible method of modeling within-cluster correlation. Subjects within
the same cluster can be correlated as a result of a shared random intercept, or through a shared random
slope on a covariate, or both. The general specification of variance components also provides additional
flexibilitythe random intercept and random slope could themselves be modeled as independent, or
correlated, or independent with equal variances, and so forth.
Comprehensive treatments of mixed models are provided by, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and
Skrondal (2012).
The key to fitting mixed models lies in estimating the variance components, and for that there
exist many methods; see, for example, Breslow and Clayton (1993); Lin and Breslow (1996); Bates
and Pinheiro (1998); and Ng et al. (2006). meglm uses maximum likelihood (ML) to estimate model
parameters. The ML estimates are based on the usual application of likelihood theory, given the
distributional assumptions of the model.
Returning to (1): in clustered-data situations, it is convenient not to consider all n observations at
once but instead to organize the mixed model as a series of M independent groups (or clusters)

g{E(yj )} = Xj + Zj uj

(2)

for j = 1, . . . , M , with cluster j consisting of nj observations. The response yj comprises the rows
of y corresponding with the j th cluster, with Xj defined analogously. The random effects uj can
now be thought of as M realizations of a q 1 vector that is normally distributed with mean 0
and q q variance matrix . The matrix Zi is the nj q design matrix for the j th cluster random
effects. Relating this to (1), note that

Z1
0
Z=
...

0
Z2
..
.

..
.

0
0
..
;
.
ZM

u1
.
u = .. ;

G = IM

uM

where IM is the M M identity matrix and is the Kronecker product.


The mixed-model formula (2) is from Laird and Ware (1982) and offers two key advantages. First,
it makes specifications of random-effects terms easier. If the clusters are schools, you can simply
specify a random effect at the school level, as opposed to thinking of what a school-level random
effect would mean when all the data are considered as a whole (if it helps, think Kronecker products).
Second, representing a mixed-model with (2) generalizes easily to more than one set of random
effects. For example, if classes are nested within schools, then (2) can be generalized to allow random
effects at both the school and the class-within-school levels.

Two-level models for continuous responses


We begin with a simple application of (2).

meglm Multilevel mixed-effects generalized linear model

65

Example 1
Consider a longitudinal dataset, used by both Ruppert, Wand, and Carroll (2003) and Diggle
et al. (2002), consisting of weight measurements of 48 pigs on 9 successive weeks. Pigs are
identified by the variable id. Each pig experiences a linear trend in growth but overall weight
measurements vary from pig to pig. Because we are not really interested in these particular 48 pigs
per se, we instead treat them as a random sample from a larger population and model the between-pig
variability as a random effect, or in the terminology of (2), as a random-intercept term at the pig
level. We thus wish to fit the model

weightij = 0 + 1 weekij + uj +

ij

for i = 1, . . . , 9 weeks and j = 1, . . . , 48 pigs. The fixed portion of the model, 0 + 1 weekij ,
simply states that we want one overall regression line representing the population average. The random
effect uj serves to shift this regression line up or down according to each pig. Because the random
effects occur at the pig level (id), we fit the model by typing
. use http://www.stata-press.com/data/r13/pig
(Longitudinal analysis of pig weights)
. meglm weight week || id:
Fitting fixed-effects model:
Iteration 0:
log likelihood = -1251.2506
Iteration 1:
log likelihood = -1251.2506
Refining starting values:
Grid node 0:
log likelihood = -1150.6253
Fitting full model:
Iteration 0:
log likelihood = -1150.6253 (not concave)
Iteration 1:
log likelihood = -1036.1793
Iteration 2:
log likelihood = -1017.912
Iteration 3:
log likelihood = -1014.9537
Iteration 4:
log likelihood = -1014.9268
Iteration 5:
log likelihood = -1014.9268
Mixed-effects GLM
Number of obs
Family:
Gaussian
Link:
identity
Group variable:
id
Number of groups
Obs per group: min
avg
max
Integration method: mvaghermite
Integration points
Wald chi2(1)
Log likelihood = -1014.9268
Prob > chi2
weight

Coef.

Std. Err.

week
_cons

6.209896
19.35561

.0390124
.5974047

var(_cons)

14.81745

var(e.weight)

4.383264

432

=
=
=
=
=
=
=

48
9
9.0
9
7
25337.48
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.133433
18.18472

6.286359
20.52651

3.124202

9.801687

22.39989

.3163349

3.805112

5.049261

159.18
32.40

id

LR test vs. linear regression:

chibar2(01) =

472.65 Prob>=chibar2 = 0.0000

At this point, a guided tour of the model specification and output is in order:

66

meglm Multilevel mixed-effects generalized linear model

1. By typing weight week, we specified the response, weight, and the fixed portion of the model
in the same way that we would if we were using regress or any other estimation command. Our
fixed effects are a coefficient on week and a constant term.
2. When we added || id:, we specified random effects at the level identified by the group variable
id, that is, the pig level (level two). Because we wanted only a random intercept, that is all we
had to type.
3. The estimation log displays a set of iterations from optimizing the log likelihood. By default, these
are NewtonRaphson iterations, but other methods are available by specifying the appropriate
maximize options; see [R] maximize.
4. The header describes the model, presents a summary of the random-effects group, reports the
integration method used to fit the model, and reports a Wald test against the null hypothesis that all
the coefficients on the independent variables in the mean equation are 0. Here the null hypothesis
is rejected at all conventional levels. You can suppress the group information with the nogroup
or the noheader option, which will suppress the rest of the header as well.
5. The estimation table reports the fixed effects, followed by the random effects, followed by the
overall error term.
a. For the fixed-effects part, we estimate 0 = 19.36 and 1 = 6.21.
b. The random-effects equation is labeled id, meaning that these are random effects at the id
(pig) level. We have only one random effect at this level, the random intercept. The variance
of the level-two errors, u2 , is estimated as 14.82 with standard error 3.12.
c. The row labeled var(e.weight) displays the estimated variance of the overall error term:
2 = 4.38. This is the variance of the level-one errors, that is, the residuals.
6. Finally, a likelihood-ratio test comparing the model with ordinary linear regression is provided and
is highly significant for these data. See Distribution theory for likelihood-ratio test in [ME] me for
a discussion of likelihood-ratio testing of variance components.

See Remarks and examples in [ME] mixed for further analysis of these data including a random-slope
model and a model with an unstructured covariance structure.

Two-level models for nonlinear responses


By specifying different familylink combinations, we can fit a variety of mixed-effects models for
nonlinear responses. Here we replicate the model from example 2 of meqrlogit.

Example 2
Ng et al. (2006) analyzed a subsample of data from the 1989 Bangladesh fertility survey (Huq and
Cleland 1990), which polled 1,934 Bangladeshi women on their use of contraception. The women
sampled were from 60 districts, identified by the variable district. Each district contained either
urban or rural areas (variable urban) or both. The variable c use is the binary response, with a value
of 1 indicating contraceptive use. Other covariates include mean-centered age and three indicator
variables recording number of children.
We fit a standard logistic regression model, amended to have a random intercept for each district
and a random slope on the indicator variable urban. We fit the model by typing

meglm Multilevel mixed-effects generalized linear model

67

. use http://www.stata-press.com/data/r13/bangladesh
(Bangladesh Fertility Survey, 1989)
. meglm c_use urban age child* || district: urban, family(bernoulli) link(logit)
Fitting fixed-effects model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Refining starting values:
Grid node 0:
log likelihood =
Fitting full model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Iteration 4:
log likelihood =
Iteration 5:
log likelihood =
Iteration 6:
log likelihood =
Mixed-effects GLM
Family:
Bernoulli
Link:
logit
Group variable:
district

-1229.5485
-1228.5268
-1228.5263
-1228.5263
-1215.8592
-1215.8592
-1209.6285
-1205.7903
-1205.1337
-1205.0034
-1205.0025
-1205.0025

(not concave)

Integration method: mvaghermite


Log likelihood = -1205.0025
c_use

Coef.

urban
age
child1
child2
child3
_cons

.7143927
-.0262261
1.128973
1.363165
1.352238
-1.698137

.1513595
.0079656
.1599347
.1761804
.1815608
.1505019

.2741013
.2390807

.2131525
.0857012

district
var(urban)
var(_cons)

Std. Err.

z
4.72
-3.29
7.06
7.74
7.45
-11.28

Number of obs

1934

Number of groups
Obs per group: min
avg
max
Integration points
Wald chi2(5)
Prob > chi2

=
=
=
=
=
=
=

60
2
32.2
118
7
97.30
0.0000

P>|z|
0.000
0.001
0.000
0.000
0.000
0.000

[95% Conf. Interval]


.4177335
-.0418384
.815507
1.017857
.9963853
-1.993115

1.011052
-.0106138
1.442439
1.708472
1.708091
-1.403159

.059701
.1184191

1.258463
.4826891

LR test vs. logistic regression:


chi2(2) =
47.05
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Because we did not specify a covariance structure for the random effects (u1j , u0j ) , meglm used the
default independent structure:
= Var

u1j
u0j

2
u1
0

0
2
u0

2
2
with u1
= 0.27 and u0
= 0.24. You can request a different covariance structure by specifying the
covariance() option. See Two-level models in [ME] meqrlogit for further analysis of these data,
and see [ME] me and [ME] mixed for further examples of covariance structures.

68

meglm Multilevel mixed-effects generalized linear model

Three-level models for nonlinear responses


Two-level models extend naturally to models with three or more levels with nested random effects.
Here we replicate the model from example 2 of [ME] meologit.

Example 3
We use the data from the Television, School, and Family Smoking Prevention and Cessation
Project (Flay et al. 1988; Rabe-Hesketh and Skrondal 2012, chap. 11), where schools were randomly
assigned into one of four groups defined by two treatment variables. Students within each school are
nested in classes, and classes are nested in schools. The dependent variable is the tobacco and health
knowledge (THK) scale score collapsed into four ordered categories. We regress the outcome on the
treatment variables, social resistance classroom curriculum and TV intervention, and their interaction
and control for the pretreatment score.
. use http://www.stata-press.com/data/r13/tvsfpors
. meglm thk prethk cc##tv || school: || class:, family(ordinal) link(logit)
Fitting fixed-effects model:
Iteration 0:
log likelihood = -2212.775
Iteration 1:
log likelihood = -2125.509
Iteration 2:
log likelihood = -2125.1034
Iteration 3:
log likelihood = -2125.1032
Refining starting values:
Grid node 0:
log likelihood = -2152.1514
Fitting full model:
Iteration 0:
log likelihood = -2152.1514 (not concave)
Iteration 1:
log likelihood = -2125.9213 (not concave)
Iteration 2:
log likelihood = -2120.1861
Iteration 3:
log likelihood = -2115.6177
Iteration 4:
log likelihood = -2114.5896
Iteration 5:
log likelihood = -2114.5881
Iteration 6:
log likelihood = -2114.5881
Mixed-effects GLM
Family:
Link:

Number of obs
ordinal
logit

Group Variable

No. of
Groups

school
class

28
135

Observations per Group


Minimum
Average
Maximum
18
1

57.1
11.9

137
28

1600

meglm Multilevel mixed-effects generalized linear model


Integration method: mvaghermite

Integration points =
Wald chi2(4)
=
Prob > chi2
=

Log likelihood = -2114.5881


Std. Err.

P>|z|

69

7
124.39
0.0000

thk

Coef.

[95% Conf. Interval]

prethk
1.cc
1.tv

.4085273
.8844369
.236448

.039616
.2099124
.2049065

10.31
4.21
1.15

0.000
0.000
0.249

.3308814
.4730161
-.1651614

.4861731
1.295858
.6380575

cc#tv
1 1

-.3717699

.2958887

-1.26

0.209

-.951701

.2081612

/cut1
/cut2
/cut3

-.0959459
1.177478
2.383672

.1688988
.1704946
.1786736

-0.57
6.91
13.34

0.570
0.000
0.000

-.4269815
.8433151
2.033478

.2350896
1.511642
2.733865

school
var(_cons)

.0448735

.0425387

.0069997

.2876749

school>class
var(_cons)

.1482157

.0637521

.063792

.3443674

LR test vs. ologit regression:


chi2(2) =
21.03
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Notes:
1. Our model now has two random-effects equations, separated by ||. The first is a random intercept
(constant only) at the school level (level three), and the second is a random intercept at the class
level (level two). The order in which these are specified (from left to right) is significantmeglm
assumes that class is nested within school.
2. The information on groups is now displayed as a table, with one row for each grouping. You can
suppress this table with the nogroup or the noheader option, which will suppress the rest of the
header, as well.
3. The variance-component estimates are now organized and labeled according to level. The variance
component for class is labeled school>class to emphasize that classes are nested within schools.
We refer you to example 2 of [ME] meologit and example 1 of [ME] meologit postestimation for
a substantive interpretation of the results.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left to
right as the groups go from biggest (highest level) to smallest (lowest level).

Crossed-effects models
Not all mixed models contain nested levels of random effects. In this section, we consider a
crossed-effects model, that is, a mixed-effects model in which the levels of random effects are not
nested; see [ME] me for more information on crossed-effects models.

70

meglm Multilevel mixed-effects generalized linear model

Example 4
We use the salamander cross-breeding data from Karim and Zeger (1992) as analyzed in RabeHesketh and Skrondal (2012, chap. 16.10). The salamanders come from two populationswhiteside
and roughbuttand are labeled whiteside males (wsm), whiteside females (wsf), roughbutt males
(rbm), and roughbutt females (rbf). Male identifiers are recorded in the variable male, and female
identifiers are recorded in the variable female. The salamanders were divided into groups such that
each group contained 60 malefemale pairs, with each salamander having three potential partners
from the same population and three potential partners from the other population. The outcome (y) is
coded 1 if there was a successful mating and is coded 0 otherwise; see the references for a detailed
description of the mating experiment.
We fit a crossed-effects logistic regression for successful mating, where each male has the same
value of his random intercept across all females, and each female has the same value of her random
intercept across all males.
To fit a crossed-effects model in Stata, we use the all: R.varname syntax. We treat the entire
dataset as one super cluster, denoted all, and we nest each gender within the super cluster by using
the R.varname notation. R.male requests a random intercept for each level of male and imposes an
identity covariance structure on the random effects; that is, the variances of the random intercepts
are restricted to be equal for all male salamanders. R.female accomplishes the same for the female
salamanders. In Stata, we type

meglm Multilevel mixed-effects generalized linear model

71

. use http://www.stata-press.com/data/r13/salamander
. meglm y wsm##wsf || _all: R.male || _all: R.female, family(bernoulli)
> link(logit) or
note: crossed random effects model specified; option intmethod(laplace)
implied
Fitting fixed-effects model:
Iteration 0:
log likelihood = -223.13998
Iteration 1:
log likelihood = -222.78752
Iteration 2:
log likelihood = -222.78735
Iteration 3:
log likelihood = -222.78735
Refining starting values:
Grid node 0:
log likelihood =
Fitting full model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Iteration 4:
log likelihood =
Iteration 5:
log likelihood =
Mixed-effects GLM
Family:
Bernoulli
Link:
logit
Group variable:
_all

Integration method:

-211.58149
-211.58149
-209.32221
-209.31084
-209.27663
-209.27659
-209.27659

(backed up)
Number of obs

360

Number of groups
Obs per group: min
avg
max

=
=
=
=

1
360
360.0
360

Wald chi2(3)
Prob > chi2

=
=

37.54
0.0000

laplace

Log likelihood = -209.27659


y

Odds Ratio

Std. Err.

1.wsm
1.wsf

.4956747
.0548105

.2146564
.0300131

wsm#wsf
1 1

36.17082

_cons

P>|z|

[95% Conf. Interval]

-1.62
-5.30

0.105
0.000

.2121174
.0187397

1.15829
.1603114

22.77918

5.70

0.000

10.52689

124.2844

2.740043

.9768565

2.83

0.005

1.362368

5.510873

_all>male
var(_cons)

1.04091

.511001

.3976885

2.724476

_all>female
var(_cons)

1.174448

.5420751

.4752865

2.902098

LR test vs. logistic regression:


chi2(2) =
27.02
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Because we specified a crossed-effects model, meglm defaulted to the method of Laplacian approximation to calculate the likelihood; see Computation time and the Laplacian approximation in [ME] me
for a discussion of computational complexity of mixed-effects models, and see Methods and formulas
below for the formulas used by the Laplacian approximation method.
The estimates of the random intercepts suggest that the heterogeneity among the female salamanders,
1.17, is larger than the heterogeneity among the male salamanders, 1.04.

72

meglm Multilevel mixed-effects generalized linear model

Setting both random intercepts to 0, the odds of successful mating for a roughbutt malefemale
pair are given by the estimate of cons, 2.74. Rabe-Hesketh and Skrondal (2012, chap. 16.10) show
how to calculate the odds ratios for the other three salamander pairings.

The R.varname notation is equivalent to giving a list of overparameterized (none dropped)


indicator variables for use in a random-effects specification. When you specify R.varname, meglm
handles the calculations internally rather than creating the indicators in the data. Because the set of
indicators is overparameterized, R.varname implies noconstant. You can include factor variables in
the fixed-effects specification by using standard methods; see [U] 11.4.3 Factor variables. However,
random-effects equations support only the R.varname factor specification. For more complex factor
specifications (such as interactions) in random-effects equations, use generate to form the variables
manually.

Technical note
We fit the salamander model by using
. meglm y wsm##wsf || _all: R.male || _all: R.female . . .
as a direct way to demonstrate the R. notation. However, we can technically treat female salamanders
as nested within the all group, yielding the equivalent way to fit the model:
. meglm y wsm##wsf || _all: R.male || female: . . .
We leave it to you to verify that both produce identical results. As we note in example 8 of [ME] me,
the latter specification, organized at the cluster (female) level with random-effects dimension one (a
random intercept) is, in general, much more computationally efficient.

Obtaining better starting values


Given the flexibility of mixed-effects models, you will find that some models fail to converge
when used with your data; see Diagnosing convergence problems in [ME] me for details. What we
say below applies regardless of how the convergence problem revealed itself. You might have seen
the error message initial values not feasible or some other error message, or you might have an
infinite iteration log.
meglm provides two options to help you obtain better starting values: startvalues() and
startgrid().
startvalues(svmethod) allows you to specify one of four starting-value calculation methods:
zero, constantonly, fixedonly, or iv. By default, meglm uses startvalues(fixedonly).
Evidently, that did not work for you. Try the other methods, starting with startvalues(iv):
. meglm ..., ... startvalues(iv)

If that does not solve the problem, proceed through the others.
By the way, if you have starting values for some parameters but not othersperhaps you fit a
simplified model to get themyou can combine the options startvalues() and from():
. meglm ..., ...
. matrix b = e(b)
. meglm ..., ... from(b) startvalues(iv)

// simplified model
// full model

meglm Multilevel mixed-effects generalized linear model

73

The other special option meglm provides is startgrid(), which can be used with or without
startvalues(). startgrid() is a brute-force approach that tries various values for variances and
covariances and chooses the ones that work best.
1. You may already be using a default form of startgrid() without knowing it. If you see
meglm displaying Grid node 1, Grid node 2, . . . following Grid node 0 in the iteration log,
that is meglm doing a default search because the original starting values were not feasible.
The default form tries 0.1, 1, and 10 for all variances of all random effects and, if applicable,
for the residual variance.
2. startgrid(numlist) specifies values to try for variances of random effects.
3. startgrid(covspec) specifies the particular variances and covariances in which grid searches
are to be performed. Variances and covariances are specified in the usual way.
startgrid( cons[id] x[id] cons[id]*x[id]) specifies that 0.1, 1, and 10 be tried
for each member of the list.
4. startgrid(numlist covspec) combines the two syntaxes. You can specify startgrid()
multiple times so that you can search the different ranges for different variances and
covariances.
Our advice to you is the following:
1. If you receive an iteration log and it does not contain Grid node 1, Grid node 2, . . . , then
specify startgrid(.1 1 10). Do that whether the iteration log was infinite or ended with
some other error. In this case, we know that meglm did not run startgrid() on its own
because it did not report Grid node 1, Grid node 2, etc. Your problem is poor starting values,
not infeasible ones.
A synonym for startgrid(.1 1 10) is just startgrid without parentheses.
Be careful, however, if you have many random effects. Specifying startgrid() could run
a long time because it runs all possible combinations. If you have 10 random effects, that
means 103 = 1,000 likelihood evaluations.
If you have many random effects, rerun your difficult meglm command including option
iterate(#) and look at the results. Identify the problematic variances and search across
them only. Do not just look for variances going to 0. Variances getting really big can be
a problem, too, and even reasonable values can be a problem. Use your knowledge and
intuition about the model.
Perhaps you will try to fit your model by specifying startgrid(.1 1 10 cons[id] x[id]
cons[id]*x[id]).
Values 0.1, 1, and 10 are the default. Equivalent to specifying
startgrid(.1 1 10 cons[id] x[id] cons[id]*x[id]) is
startgrid( cons[id] x[id] cons[id]*x[id]).
Look at covariances as well as variances. If you expect a covariance to be negative but it is
positive, then try negative starting values for the covariance by specifying startgrid(-.1
-1 -10 cons[id]*x[id]).
Remember that you can specify startgrid() multiple times. Thus you might specify both
startgrid( cons[id] x[id]) and startgrid(-.1 -1 -10 cons[id]*x[id]).

74

meglm Multilevel mixed-effects generalized linear model

2. If you receive the message initial values not feasible, you know that meglm already tried
the default startgrid().
The default startgrid() only tried the values 0.1, 1, and 10, and only tried them on the
variances of random effects. You may need to try different values or try the same values on
covariances or variances of errors of observed endogenous variables.
We suggest you first rerun the model causing difficulty and include the noestimate option.
If, looking at the results, you have an idea of which variance or covariance is a problem, or if
you have few variances and covariances, we would recommend running startgrid() first.
On the other hand, if you have no idea as to which variance or covariance is the problem
and you have many of them, you will be better off if you first simplify the model. After
doing that, if your simplified model does not include all the variances and covariances, you
can specify a combination of from() and startgrid().

Stored results
meglm stores the following in e():
Scalars
e(N)
e(k)
e(k dv)
e(k eq)
e(k eq model)
e(k cat)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(N clust)
e(rank)
e(ic)
e(rc)
e(converged)

number of observations
number of parameters
number of dependent variables
number of equations in e(b)
number of equations in overall model test
number of categories (with ordinal outcomes)
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
number of clusters
rank of e(V)
number of iterations
return code
1 if converged, 0 otherwise

meglm Multilevel mixed-effects generalized linear model


Macros
e(cmd)
e(cmdline)
e(depvar)
e(covariates)
e(ivars)
e(model)
e(title)
e(link)
e(family)
e(clustvar)
e(offset)
e(binomial)
e(dispersion)
e(intmethod)
e(n quad)
e(chi2type)
e(vce)
e(vcetype)
e(opt)
e(which)
e(ml method)
e(user)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)
Matrices
e(b)
e(Cns)
e(cat)
e(ilog)
e(gradient)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
e(V modelbased)
Functions
e(sample)

meglm
command as typed
name of dependent variable
list of covariates
grouping variables
name of marginal model
title in estimation output
link
family
name of cluster variable
offset
binomial number of trials (with binomial models)
mean or constant (with negative binomial models)
integration method
number of integration points
Wald; type of model 2
vcetype specified in vce()
title used to label Std. Err.
type of optimization
max or min; whether optimizer is to perform maximization or minimization
type of ml method
name of likelihood-evaluator program
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict
coefficient vector
constraints matrix
category values (with ordinal outcomes)
iteration log (up to 20 iterations)
gradient vector
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
model-based variance
marks estimation sample

Methods and formulas


Methods and formulas are presented under the following headings:
Introduction
GaussHermite quadrature
Adaptive GaussHermite quadrature
Laplacian approximation

75

76

meglm Multilevel mixed-effects generalized linear model

Introduction
Without a loss of generality, consider a two-level generalized mixed-effects model
yF
E(yj |Xj , uj ) = g 1 Xj + Zj uj ,
for j = 1, . . . , M clusters, with the j th cluster consisting of nj observations, where, for the j th
cluster, yj is the nj 1 response vector, Xj is the nj p matrix of fixed predictors, Zj is the
nj q matrix of random predictors, uj is the q 1 vector of random effects, is the p 1 vector of
regression coefficients on the fixed predictors, and we use to denote the unknown q q variance
matrix of the random effects. For simplicity, we consider a model with no auxiliary parameters.
Let j be the linear predictor, j = Xj + Zj uj , that also includes the offset or the exposure
variable when offset() or exposure() is specified. Let yij and ij be the ith individual elements
of yj and j , i = 1, . . . , nj . Let f (yij |ij ) be the conditional density function for the response at
observation i. Because the observations are assumed to be conditionally independent, we can overload
the definition of f () with vector inputs to mean
ni

log f (yj |j ) =

log f (yij |ij )


j=1

The random effects uj are assumed to be multivariate normal with mean 0 and variance . The
likelihood function for cluster j is given by

Lj (, ) = (2)q/2 ||1/2
q/2

= (2)
where

1/2

||

1
f (yj |j ) exp uj 1 uj duj
2
q
1
exp log f (yj |j ) uj 1 uj duj
2
q

denotes the set of values on the real line and

(3)

is the analog in q -dimensional space.

The multivariate integral in (3) is generally not tractable, so we must use numerical methods to
approximate the integral. We can use a change-of-variables technique to transform this multivariate
integral into a set of nested univariate integrals. Each univariate integral can then be evaluated
using a form of Gaussian quadrature. meglm supports three types of GaussHermite quadratures:
meanvariance adaptive GaussHermite quadrature (MVAGH), mode-curvature adaptive GaussHermite
quadrature (MCAGH), and nonadaptive GaussHermite quadrature (GHQ). meglm also offers the
Laplacian-approximation method, which is used as a default method for crossed mixed-effects models.
Below we describe the four methods. The methods described below are based on Skrondal and
Rabe-Hesketh (2004, chap. 6.3).

GaussHermite quadrature
Let uj = Lvj , where vj is a q 1 random vector whose elements are independently standard
normal variables and L is the Cholesky decomposition of , = LL . Then j = Xj + Zj Lvj ,
and the likelihood in (3) becomes

Lj (, ) = (2)q/2
q

1
exp log f (yj |j ) vj vj
2

= (2)q/2

exp log f (yj |j )

...

dvj
1
2

(4)

q
2
vjk
k=1

dvj1 , . . . , dvjq

meglm Multilevel mixed-effects generalized linear model

77

Consider a q -dimensional quadrature grid containing r quadrature points in each dimension. Let
ak = (ak1 , . . . , akq ) be a point on this grid, and let wk = (wk1 , . . . , wkq ) be the vector of
corresponding weights. The GHQ approximation to the likelihood is
r

LGHQ
(, ) =
j

exp log f (yj |jk )

...
k1 =1

nj

i=1

kq =1

k1 =1

log f (yij |ijk )

exp

...

wkp
p=1

kq =1

wkp
p=1

where
jk = Xj + Zj Lak
and ijk is the ith element of jk .

Adaptive GaussHermite quadrature


This section sets the stage for MVAGH quadrature and MCAGH quadrature.
Lets reconsider the likelihood in (4). We use (vj ) to denote a multivariate standard normal with
mean 0 and variance Iq , and we use (vj |j , j ) to denote a multivariate normal with mean j
and variance j .
For fixed model parameters, the posterior density for vj is proportional to

(vj )f (yj |j )
where
j = Xj + Zj Lvj
It is reasonable to assume that this posterior density can be approximated by a multivariate normal
density with mean vector j and variance matrix j . Instead of using the prior density of vj as the
weighting distribution in the integral, we can use our approximation for the posterior density,

Lj (, ) =
q

f (yj |j )(vj )
(vj |j , j ) dvj
(vj |j , j )

Then the MVAGH approximation to the likelihood is


r

LMVAGH
(, ) =
j
k1 =1

wjk
p

exp log f (yj |jk )

...
kq =1

where
jk = Xj + Zj Lajk

p=1

78

meglm Multilevel mixed-effects generalized linear model

and ajk and wjk


are the abscissas and weights after an orthogonalizing transformation of ajk and
p
wjkp , respectively, which eliminates posterior covariances between the random effects.

Estimates of j and j are computed using one of two different methods. The mean j and
variance j are computed iteratively by updating the posterior moments with the MVAGH approximation,
starting with a 0 mean vector and identity variance matrix. For the MCAGH approximation, j and j
are computed by optimizing the integrand with respect to vj , where j is the optimal value and j
is the curvature at j .

Laplacian approximation
Consider the likelihood in (3) and denote the argument in the exponential function by

1
g(, , uj ) = log f (yj |Xj + Zj uj ) uj 1 uj
2
The Laplacian approximation is based on a second-order Taylor expansion of g(, , uj ) about the
value of uj that maximizes it. The first and second partial derivatives with respect to uj are

g (, , uj ) =

g (, , uj ) =

log f (yj |j )
g(, , uj )
1 uj
= Zj
uj
j
2 log f (yj |j )
2 g(, , uj )
= Zj
Zj 1
uj uj
j j

The maximizer of g(, , uj ) is uj such that g (, , uj ) = 0. The integral in (3) is proportional


to the posterior density of uj given the data, so uj is also the posterior mode.
Let

pj = Xj + Zj uj

S1 =

S2 =

log f (yj |pj )


pj

S1
2 log f (yj |pj )
=
pj
pj pj

Hj = g (, , uj ) = Zj S2 Zj 1
then

0 = g (, , uj ) = Zj S1 1 uj

meglm Multilevel mixed-effects generalized linear model

79

Given the above, the second-order Taylor approximation takes the form

1
g(, , uj ) g(, , uj ) + (uj uj ) Hj (uj uj )
2
because the first-order derivative term is 0. The integral is approximated by

exp{g(, , uj )} duj (2)q/2 |Hj |

1/2

exp{g(, , uj )}

Thus the Laplacian approximated log likelihood is

1
1
log LLap
(, ) = log || log |Hj | + g(, , uj )
j
2
2
The log likelihood for the entire dataset is simply the sum of the contributions of the M individual
M
clusters, namely, L(, ) = j=1 Lj (, ).
Maximization of L(, ) is performed with respect to (, 2 ), where 2 is a vector comprising
the unique elements of . Parameter estimates are stored in e(b) as (, 2 ), with the corresponding
variancecovariance matrix stored in e(V). In the presence of auxiliary parameters, their estimates
and standard errors are included in e(b) and e(V), respectively.

References
Andrews, M. J., T. Schank, and R. Upward. 2006. Practical fixed-effects estimation methods for the three-way
error-components model. Stata Journal 6: 461481.
Bates, D. M., and J. C. Pinheiro. 1998. Computational methods for multilevel modelling. In Technical Memorandum
BL0112140-980226-01TM. Murray Hill, NJ: Bell Labs, Lucent Technologies.
http://stat.bell-labs.com/NLME/CompMulti.pdf.
Breslow, N. E., and D. G. Clayton. 1993. Approximate inference in generalized linear mixed models. Journal of the
American Statistical Association 88: 925.
Cameron, A. C., and P. K. Trivedi. 2010. Microeconometrics Using Stata. Rev. ed. College Station, TX: Stata Press.
Canette, I. 2011. Including covariates in crossed-effects models. The Stata Blog: Not Elsewhere Classified.
http://blog.stata.com/2010/12/22/including-covariates-in-crossed-effects-models/.
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.
Diggle, P. J., P. J. Heagerty, K.-Y. Liang, and S. L. Zeger. 2002. Analysis of Longitudinal Data. 2nd ed. Oxford:
Oxford University Press.
Flay, B. R., B. R. Brannon, C. A. Johnson, W. B. Hansen, A. L. Ulene, D. A. Whitney-Saltiel, L. R. Gleason,
S. Sussman, M. D. Gavin, K. M. Glowacz, D. F. Sobol, and D. C. Spiegel. 1988. The television, school, and family
smoking cessation and prevention project: I. Theoretical basis and program development. Preventive Medicine 17:
585607.
Harville, D. A. 1977. Maximum likelihood approaches to variance component estimation and to related problems.
Journal of the American Statistical Association 72: 320338.
Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.
Hocking, R. R. 1985. The Analysis of Linear Models. Monterey, CA: Brooks/Cole.
Horton, N. J. 2011. Stata tip 95: Estimation of error covariances in a linear model. Stata Journal 11: 145148.
Huq, N. M., and J. Cleland. 1990. Bangladesh Fertility Survey 1989 (Main Report). National Institute of Population
Research and Training.

80

meglm Multilevel mixed-effects generalized linear model

Karim, M. R., and S. L. Zeger. 1992. Generalized linear models with random effects; salamander mating revisited.
Biometrics 48: 631644.
Laird, N. M., and J. H. Ware. 1982. Random-effects models for longitudinal data. Biometrics 38: 963974.
LaMotte, L. R. 1973. Quadratic estimation of variance components. Biometrics 29: 311330.
Lin, X., and N. E. Breslow. 1996. Bias correction in generalized linear mixed models with multiple components of
dispersion. Journal of the American Statistical Association 91: 10071016.
Marchenko, Y. V. 2006. Estimating variance components in Stata. Stata Journal 6: 121.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
Ng, E. S.-W., J. R. Carpenter, H. Goldstein, and J. Rasbash. 2006. Estimation in generalised linear mixed models
with binary outcomes by simulated maximum likelihood. Statistical Modelling 6: 2342.
Nichols, A. 2007. Causal inference with observational data. Stata Journal 7: 507541.
Pantazis, N., and G. Touloumi. 2010. Analyzing longitudinal data in the presence of informative drop-out: The jmre1
command. Stata Journal 10: 226251.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Ruppert, D., M. P. Wand, and R. J. Carroll. 2003. Semiparametric Regression. Cambridge: Cambridge University
Press.
Searle, S. R. 1989. Obituary: Charles Roy Henderson 19111989. Biometrics 45: 13331335.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Skrondal, A., and S. Rabe-Hesketh. 2004. Generalized Latent Variable Modeling: Multilevel, Longitudinal, and
Structural Equation Models. Boca Raton, FL: Chapman & Hall/CRC.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.

Also see
[ME] meglm postestimation Postestimation tools for meglm
[ME] mixed Multilevel mixed-effects linear regression
[ME] me Introduction to multilevel mixed-effects models
[R] glm Generalized linear models
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[U] 20 Estimation and postestimation commands

Title
meglm postestimation Postestimation tools for meglm
Description
Options for predict
Remarks and examples
Also see

Syntax for predict


Syntax for estat group
Methods and formulas

Menu for predict


Menu for estat
References

Description
The following postestimation command is of special interest after meglm:
Command

Description

estat group

summarize the composition of the nested groups

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
81

82

meglm postestimation Postestimation tools for meglm

Syntax for predict


Syntax for obtaining predictions of random effects and their standard errors
predict

type

newvarsspec

if

in ,

remeans | remodes

reses(newvarsspec)

Syntax for obtaining other predictions


predict

type

newvarsspec

if

in

, statistic options

newvarsspec is stub* or newvarlist.


statistic

Description

Main

mu
pr
fitted
xb
stdp
residuals
pearson
deviance
anscombe

mean response; the default


synonym for mu for ordinal and binary response models
fitted linear predictor
linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction
raw residuals; available only with the Gaussian family
Pearson residuals
deviance residuals
Anscombe residuals

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

meglm postestimation Postestimation tools for meglm

83

Description

options
Main

means
modes
nooffset
fixedonly
outcome(outcome)

compute statistic using empirical Bayes means; the default


compute statistic using empirical Bayes modes
ignore the offset or exposure variable in calculating predictions; relevant only
if you specified offset() or exposure() when you fit the model
prediction for the fixed portion of the model only
outcome category for predicted probabilities for ordinal models

Integration

intpoints(#)
iterate(#)
tolerance(#)

use # quadrature points to compute empirical Bayes means


set maximum number of iterations in computing statistics involving
empirical Bayes estimators
set convergence tolerance for computing statistics involving empirical
Bayes estimators

For ordinal outcomes, you specify one or k new variables in newvarlist with mu and pr, where k is the number of
outcomes. If you do not specify outcome(), those options assume outcome(#1).

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

Options for predict

Main

remeans calculates posterior means of the random effects, also known as empirical Bayes means.
You must specify q new variables, where q is the number of random-effects terms in the model.
However, it is much easier to just specify stub* and let Stata name the variables stub1, stub2, . . . ,
stubq for you.
remodes calculates posterior modes of the random effects, also known as empirical Bayes modes.
You must specify q new variables, where q is the number of random-effects terms in the model.
However, it is much easier to just specify stub* and let Stata name the variables stub1, stub2, . . . ,
stubq for you.
reses(stub* | newvarlist) calculates standard errors of the empirical Bayes estimators and stores the
result in newvarlist. This option requires the remeans or the remodes option. You must specify q
new variables, where q is the number of random-effects terms in the model. However, it is much
easier to just specify stub* and let Stata name the variables stub1, stub2, . . . , stubq for you.
The remeans, remodes, and reses() options often generate multiple new variables at once.
When this occurs, the random effects (and standard errors) contained in the generated variables
correspond to the order in which the variance components are listed in the output of meglm. Still,
examining the variable labels of the generated variables (by using the describe command, for
instance) can be useful in deciphering which variables correspond to which terms in the model.
mu, the default, calculates the predicted mean, that is, the inverse link function applied to the linear
prediction. By default, this is based on a linear predictor that includes both the fixed effects and
the random effects, and the predicted mean is conditional on the values of the random effects. Use
the fixedonly option if you want predictions that include only the fixed portion of the model,
that is, if you want random effects set to 0.

84

meglm postestimation Postestimation tools for meglm

pr calculates predicted probabilities and is a synonym for mu. This option is available only for ordinal
and binary response models.
fitted calculates the fitted linear prediction. By default, the fitted predictor includes both the fixed
effects and the random effects. Use the fixedonly option if you want predictions that include
only the fixed portion of the model, that is, if you want random effects set to 0.
xb calculates the linear prediction x based on the estimated fixed effects (coefficients) in the model.
This is equivalent to fixing all random effects in the model to their theoretical (prior) mean value
of 0.
stdp calculates the standard error of the fixed-effects linear predictor x.
residuals calculates raw residuals, that is, responses minus the fitted values. This option is available
only for the Gaussian family.
pearson calculates Pearson residuals. Pearson residuals that are large in absolute value may indicate
a lack of fit. By default, residuals include both the fixed portion and the random portion of the
model. The fixedonly option modifies the calculation to include the fixed portion only.
deviance calculates deviance residuals. Deviance residuals are recommended by McCullagh and
Nelder (1989) as having the best properties for examining the goodness of fit of a GLM. They
are approximately normally distributed if the model is correctly specified. They may be plotted
against the fitted values or against a covariate to inspect the model fit. By default, residuals include
both the fixed portion and the random portion of the model. The fixedonly option modifies the
calculation to include the fixed portion only.
anscombe calculates Anscombe residuals, which are designed to closely follow a normal distribution.
By default, residuals include both the fixed portion and the random portion of the model. The
fixedonly option modifies the calculation to include the fixed portion only.
means specifies that posterior means be used as the estimates of the random effects for any statistic
involving random effects. means is the default.
modes specifies that posterior modes be used as the estimates of the random effects for any statistic
involving random effects.
nooffset is relevant only if you specified offset(varnameo ) or exposure(varnamee ) with
meglm. It modifies the calculations made by predict so that they ignore the offset or the
exposure variable; the linear prediction is treated as X + Zu rather than X + Zu + offset, or
X + Zu + ln(exposure), whichever is relevant.
fixedonly modifies predictions to include only the fixed portion of the model, equivalent to setting
all random effects equal to 0.
outcome(outcome) specifies the outcome for which the predicted probabilities are to be calculated.
outcome() should contain either one value of the dependent variable or one of #1, #2, . . . , with
#1 meaning the first category of the dependent variable, #2 meaning the second category, etc.

Integration

intpoints(#) specifies the number of quadrature points used to compute the empirical Bayes means;
the default is the value from estimation.
iterate(#) specifies the maximum number of iterations when computing statistics involving empirical
Bayes estimators; the default is the value from estimation.
tolerance(#) specifies convergence tolerance when computing statistics involving empirical Bayes
estimators; the default is the value from estimation.

meglm postestimation Postestimation tools for meglm

85

Syntax for estat group


estat group

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a mixed-effects
model using meglm. For the most part, calculation centers around obtaining predictions of the random
effects. Random effects are not estimated when the model is fit but instead need to be predicted after
estimation.

Example 1
In example 2 of [ME] meglm, we modeled the probability of contraceptive use among Bangladeshi
women by fitting a mixed-effects logistic regression model. To facilitate a more direct comparison
between urban and rural women, we express rural status in terms of urban status and eliminate the
constant from both the fixed-effects part and the random-effects part.

86

meglm postestimation Postestimation tools for meglm


. use http://www.stata-press.com/data/r13/bangladesh
(Bangladesh Fertility Survey, 1989)
. generate byte rural = 1 - urban
. meglm c_use rural urban age child*, nocons || district: rural urban, nocons
> family(bernoulli) link(logit)
Fitting fixed-effects model:
Iteration 0:
log likelihood = -1229.5485
Iteration 1:
log likelihood = -1228.5268
Iteration 2:
log likelihood = -1228.5263
Iteration 3:
log likelihood = -1228.5263
Refining starting values:
Grid node 0:
log likelihood =
Fitting full model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Iteration 4:
log likelihood =
Iteration 5:
log likelihood =
Iteration 6:
log likelihood =
Iteration 7:
log likelihood =
Mixed-effects GLM
Family:
Bernoulli
Link:
logit
Group variable:
district

-1208.3922
-1208.3922
-1203.6498
-1200.6662
-1199.9939
-1199.3784
-1199.3272
-1199.3268
-1199.3268

(not concave)
(not concave)

Integration method: mvaghermite


Log likelihood = -1199.3268
( 1) [c_use]_cons = 0
c_use

Coef.

rural
urban
age
child1
child2
child3
_cons

-1.712549
-.9004495
-.0264472
1.132291
1.358692
1.354788
0

.1603689
.1674683
.0080196
.1603052
.1769369
.1827459
(omitted)

.3882825
.239777

.1284858
.1403374

district
var(rural)
var(urban)

Std. Err.

z
-10.68
-5.38
-3.30
7.06
7.68
7.41

Number of obs

1934

Number of groups
Obs per group: min
avg
max
Integration points
Wald chi2(6)
Prob > chi2

=
=
=
=
=
=
=

60
2
32.2
118
7
120.59
0.0000

P>|z|
0.000
0.000
0.001
0.000
0.000
0.000

[95% Conf. Interval]


-2.026866
-1.228681
-.0421652
.8180983
1.011902
.9966122

-1.398232
-.5722176
-.0107291
1.446483
1.705482
1.712963

.2029918
.0761401

.7427064
.7550947

LR test vs. logistic regression:


chi2(2) =
58.40
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

We used the binary variables, rural and urban, instead of the factor notation i.urban because,
although supported in the fixed-effects specification of the model, such notation is not supported in
random-effects specifications.
This particular model allows for district random effects that are specific to the rural and urban
areas of that district and that can be interpreted as such. We can obtain predictions of posterior means
of the random effects and their standard errors by typing

meglm postestimation Postestimation tools for meglm

87

. predict re_rural re_urban, remeans reses(se_rural se_urban)


(calculating posterior means of random effects)
(using 7 quadrature points)

The order in which we specified the variables to be generated corresponds to the order in which the
variance components are listed in meglm output. If in doubt, a simple describe will show how these
newly generated variables are labeled just to be sure.
Having generated estimated random effects and standard errors, we can now list them for the first
10 districts:
. by district, sort: generate tag = (_n==1)
. list district re_rural se_rural re_urban se_urban if district <= 10 & tag,
> sep(0)

1.
118.
138.
140.
170.
209.
274.
292.
329.
352.

district

re_rural

se_rural

re_urban

se_urban

1
2
3
4
5
6
7
8
9
10

-.9523374
-.0425217
-1.25e-16
-.2703357
.0691029
-.3939819
-.1904756
.0382993
-.3715211
-.5624707

.316291
.3819309
.6231232
.3980832
.3101591
.2759802
.4043461
.3177392
.3919996
.4763545

-.5619418
2.73e-18
.2229486
.574464
.0074569
.2622263
4.60e-18
.2250237
.0628076
9.03e-20

.2329456
.4896702
.4658747
.3962131
.4650451
.4177785
.4896702
.4654329
.453568
.4896702

The estimated standard errors are conditional on the values of the estimated model parameters:
and the components of . Their interpretation is therefore not one of standard sample-to-sample
variability but instead one that does not incorporate uncertainty in the estimated model parameters;
see Methods and formulas. That stated, conditional standard errors can still be used as a measure of
relative precision, provided that you keep this caveat in mind.
You can also obtain predictions of posterior modes and compare them with the posterior means:
. predict mod_rural mod_urban, remodes
(calculating posterior modes of random effects)
. list district re_rural mod_rural re_urban mod_urban if district <= 10 & tag,
> sep(0)

1.
118.
138.
140.
170.
209.
274.
292.
329.
352.

district

re_rural

mod_rural

re_urban

mod_urban

1
2
3
4
5
6
7
8
9
10

-.9523374
-.0425217
-1.25e-16
-.2703357
.0691029
-.3939819
-.1904756
.0382993
-.3715211
-.5624707

-.9295366
-.0306312
0
-.2529507
.0789803
-.3803784
-.1737696
.0488528
-.3540084
-.535444

-.5619418
2.73e-18
.2229486
.574464
.0074569
.2622263
4.60e-18
.2250237
.0628076
9.03e-20

-.5584528
0
.2223551
.5644512
.0077525
.2595116
0
.2244676
.0605462
0

The two set of predictions are fairly close.


Because not all districts contain both urban and rural areas, some of the posterior modes are 0 and
some of the posterior means are practically 0. A closer examination of the data reveals that district
3 has no rural areas, and districts 2, 7, and 10 have no urban areas.

88

meglm postestimation Postestimation tools for meglm

Had we imposed an unstructured covariance structure in our model, the estimated posterior modes
and posterior means in the cases in question would not be exactly 0 because of the correlation between
urban and rural effects. For instance, if a district has no urban areas, it can still yield a nonzero
(albeit small) random-effects estimate for a nonexistent urban area because of the correlation with its
rural counterpart; see example 1 of [ME] meqrlogit postestimation for details.

Example 2
Continuing with the model from example 1, we can obtain predicted probabilities, and unless
we specify the fixedonly option, these predictions will incorporate the estimated subject-specific
random effects uj .
. predict pr, pr
(predictions based on fixed effects and posterior means of random effects)
(using 7 quadrature points)

The predicted probabilities for observation i in cluster j are obtained by applying the inverse link
function to the linear predictor, pij = g 1 (xij + zij uj ); see Methods and formulas for details. By
default, the calculation uses posterior means for uj unless you specify the modes option, in which
case the calculation uses posterior modes for uj .
. predict prm, pr modes
(predictions based on fixed effects and posterior modes of random effects)

We can list the two sets of predicted probabilities together with the actual outcome for some
district, lets say district 38:
. list c_use pr prm if district == 38
c_use

pr

prm

1228.
1229.
1230.
1231.
1232.

yes
no
yes
yes
yes

.5783408
.5326623
.6411679
.5326623
.5718783

.5780864
.5324027
.6409279
.5324027
.5716228

1233.
1234.
1235.
1236.
1237.

no
no
no
no
no

.3447686
.4507973
.1940524
.2846738
.1264883

.344533
.4505391
.1976133
.2893007
.1290078

1238.
1239.
1240.
1241.

no
no
no
no

.206763
.202459
.206763
.1179788

.2104961
.2061346
.2104961
.1203522

The two sets of predicted probabilities are fairly close.


For mixed-effects models with many levels or many random effects, the calculation of the posterior
means of random effects or any quantities that are based on the posterior means of random effects
may take a long time. This is because we must resort to numerical integration to obtain the posterior
means. In contrast, the calculation of the posterior modes of random effects is usually orders of
magnitude faster because there is no numerical integration involved. For this reason, empirical modes
are often used in practice as an approximation to empirical means. Note that for linear mixed-effects
models, the two predictors are the same.

meglm postestimation Postestimation tools for meglm

89

We can compare the observed values with the predicted values by constructing a classification table.
Defining success as yij = 1 if pij > 0.5 and defining yij = 0 otherwise, we obtain the following
table.
. gen p_use = pr > .5
. label var p_use "Predicted outcome"
. tab2 c_use p_use, row
-> tabulation of c_use by p_use
Key

frequency
row percentage
Use
contracept
ion

Predicted outcome
0
1

Total

no

991
84.34

184
15.66

1,175
100.00

yes

423
55.73

336
44.27

759
100.00

Total

1,414
73.11

520
26.89

1,934
100.00

The model correctly classified 84% of women who did not use contraceptives but only 44% of
women who did. In the next example, we will look at some residual diagnostics.

Technical note
Out-of-sample predictions are permitted after meglm, but if these predictions involve estimated
random effects, the integrity of the estimation data must be preserved. If the estimation data have
changed since the model was fit, predict will be unable to obtain predicted random effects that
are appropriate for the fitted model and will give an error. Thus to obtain out-of-sample predictions
that contain random-effects terms, be sure that the data for these predictions are in observations that
augment the estimation data.

Example 3
Continuing our discussion from example 2, here we look at residual diagnostics. meglm offers
three kinds of predicted residuals for nonlinear responsesPearson, Anscombe, and deviance. Of the
three, Anscombe residuals are designed to be approximately normally distributed; thus we can check
for outliers by plotting Anscombe residuals against observation numbers and seeing which residuals
are greater than 2 in absolute value.

90

meglm postestimation Postestimation tools for meglm


. predict anscombe, anscombe
(predictions based on fixed effects and posterior means of random effects)
. gen n = _n
. label var n "observation number"

. twoway (scatter anscombe n if c_use) (scatter anscombe n if !c_use),


> yline(-2 2) legend(off) text(2.5 1400 "contraceptive use")
> text(-.1 500 "no contraceptive use")

Anscombe residuals
0
1

contraceptive use

no contraceptive use

500

1000
observation number

1500

2000

There seem to be some outliers among residuals that identify women who use contraceptives. We
could examine the observations corresponding to the outliers, or we could try fitting a model with
perhaps a different covariance structure, which we leave as an exercise.

Example 4
In example 3 of [ME] meglm, we estimated the effects of two treatments on the tobacco and health
knowledge (THK) scale score of students in 28 schools. The dependent variable was collapsed into
four ordered categories, and we fit a three-level ordinal logistic regression.

meglm postestimation Postestimation tools for meglm

91

. use http://www.stata-press.com/data/r13/tvsfpors, clear


. meologit thk prethk i.cc##i.tv || school: || class:
Fitting fixed-effects model:
Iteration 0:
log likelihood = -2212.775
Iteration 1:
log likelihood = -2125.509
Iteration 2:
log likelihood = -2125.1034
Iteration 3:
log likelihood = -2125.1032
Refining starting values:
Grid node 0:
log likelihood = -2152.1514
Fitting full model:
(output omitted )
Mixed-effects ologit regression

Group Variable

No. of
Groups

school
class

28
135

Number of obs

1600

Integration points =
Wald chi2(4)
=
Prob > chi2
=

7
124.39
0.0000

Observations per Group


Minimum
Average
Maximum
18
1

57.1
11.9

Integration method: mvaghermite


Log likelihood = -2114.5881
Std. Err.

137
28

thk

Coef.

P>|z|

[95% Conf. Interval]

prethk
1.cc
1.tv

.4085273
.8844369
.236448

.039616
.2099124
.2049065

10.31
4.21
1.15

0.000
0.000
0.249

.3308814
.4730161
-.1651614

.4861731
1.295858
.6380575

cc#tv
1 1

-.3717699

.2958887

-1.26

0.209

-.951701

.2081612

/cut1
/cut2
/cut3

-.0959459
1.177478
2.383672

.1688988
.1704946
.1786736

-0.57
6.91
13.34

0.570
0.000
0.000

-.4269815
.8433151
2.033478

.2350896
1.511642
2.733865

school
var(_cons)

.0448735

.0425387

.0069997

.2876749

school>class
var(_cons)

.1482157

.0637521

.063792

.3443674

LR test vs. ologit regression:


chi2(2) =
21.03
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Not surprisingly, the level of knowledge before the intervention is a good predictor of the level of
knowledge after the intervention. The social resistance classroom curriculum is effective in raising
the knowledge score, but the TV intervention and the interaction term are not.
We can rank schools by their institutional effectiveness by plotting the random effects at the school
level.

92

meglm postestimation Postestimation tools for meglm


. predict re_school re_class, remeans reses(se_school se_class)
(calculating posterior means of random effects)
(using 7 quadrature points)
. generate lower = re_school - 1.96*se_school
. generate upper = re_school + 1.96*se_school
. egen tag = tag(school)
. gsort +re_school -tag
. generate rank = sum(tag)
. generate labpos = re_school + 1.96*se_school + .1
twoway (rcap lower upper rank) (scatter re_school rank)
(scatter labpos rank, mlabel(school) msymbol(none) mlabpos(0)),
xtitle(rank) ytitle(predicted posterior mean) legend(off)
xscale(range(0 28)) xlabel(1/28) ysize(2)
1

.
>
>
>

410

507

513

509 505

199

408
408198
198

405 412

197
402
402197

510

414

401 196

411508
508
403 411

515

506

.5

predicted posterior mean


0
.5

407
407415
415
404 193 409
409194
194 514

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
rank

Although there is some variability in the predicted posterior means, we cannot see significant differences
among the schools in this example.

Methods and formulas


Continuing the discussion in Methods and formulas of [ME] meglm and using the definitions and
formulas defined there, we begin by considering the prediction of the random effects uj for the j th
cluster in a two-level model. Prediction of random effects in multilevel generalized linear models
involves assigning values to random effects, and there are many methods for doing so; see Skrondal
and Rabe-Hesketh (2009) and Skrondal and Rabe-Hesketh (2004, chap. 7) for a comprehensive
review. Stata offers two methods of predicting random effects: empirical Bayes means (also known
as posterior means) and empirical Bayes modes (also known as posterior modes). Below we provide
more details about the two methods.
Let denote the estimated model parameters comprising and the unique elements of .
Empirical Bayes (EB) predictors of the random effects are the means or modes of the empirical
posterior distribution with the parameter estimates replaced with their estimates . The method
is called empirical because is treated as known. EB combines the prior information about the
random effects with the likelihood to obtain the conditional posterior distribution of random effects.
Using Bayes theorem, the empirical conditional posterior distribution of random effects for cluster j
is

meglm postestimation Postestimation tools for meglm

(uj |yj , Xj , Zj ; ) =
=
=

93

Pr(yj , uj |Xj , Zj ; )
Pr(yj |Xj , Zj ; )
f (yj |uj , Xj , Zj ; ) (uj ; )
f (yj |uj ) (uj ) duj
f (yj |uj , Xj , Zj ; ) (uj ; )
Lj ()

The denominator is just the likelihood contribution of the j th cluster.


EB mean predictions of random effects,

u, also known as posterior means, are calculated as

uj (uj |yj , Xj , Zj ; ) duj

u=
q

uj f (yj |uj , Xj , Zj ; ) (uj ; ) duj


q f (yj |uj ) (uj ) duj

where we use the notation u rather than u to distinguish predicted values from estimates. This
multivariate integral is approximated by the meanvariance adaptive Gaussian quadrature; see Methods
and formulas of [ME] meglm for details about the quadrature. If you have multiple random effects
within a level or random effects across levels, the calculation involves orthogonalizing transformations
using the Cholesky transformation because the random effects are no longer independent under the
posterior distribution.
In a linear mixed-effects model, the posterior density is multivariate normal, and EB means are also
best linear unbiased predictors (BLUPs); see Skrondal and Rabe-Hesketh (2004, 227). In generalized
mixed-effects models, the posterior density tends to multivariate normal as cluster size increases.
EB modal predictions can be approximated by solving for the mode

uj in

log (uj |yj , Xj , Zj ; ) = 0


uj
Because the denominator in () does not depend on u, we can omit it from the calculation to obtain

log f (yj |uj , Xj , Zj ; ) (uj ; )


uj
=

log f yj |uj , Xj , Zj ; +
log uj ; = 0
uj
uj

The calculation of EB modes does not require numerical integration, and for that reason they are
often used in place of EB means. As the posterior density gets closer to being multivariate normal,
EB modes get closer and closer to EB means.
Just like there are many methods of assigning values to the random effects, there exist many methods
of calculating standard errors of the predicted random effects; see Skrondal and Rabe-Hesketh (2009)
for a comprehensive review.
Stata uses the posterior standard deviation as the standard error of the posterior means predictor
of random effects. The EB posterior covariance matrix of the random effects is given by

94

meglm postestimation Postestimation tools for meglm

cov(uj |yj , Xj , Zj ; ) =

(uj uj )(uj uj ) (uj |yj , Xj , Zj ; ) duj


q

The posterior covariance matrix and the integrals are approximated by the meanvariance adaptive
Gaussian quadrature; see Methods and formulas of [ME] meglm for details about the quadrature.
Conditional standard errors for the estimated posterior modes are derived from standard theory of
maximum likelihood, which dictates that the asymptotic variance matrix of uj is the negative inverse
of the Hessian, g (, , uj ).
In what follows, we show formulas using the posterior means estimates of random effects uj ,
which are used by default or if the means option is specified. If the modes option is specified, uj
are simply replaced with the posterior modes uj in these formulas.
For any ith observation in the j th cluster in a two-level model, define the linear predictor as

ij = xij + zij uj
The linear predictor includes the offset or exposure variable if one was specified during estimation,
unless the nooffset option is specified. If the fixedonly option is specified, contains the linear
predictor for only the fixed portion of the model, ij = xij .
The predicted mean, conditional on the random effects uj , is

ij = g 1 (ij )
where g 1 () is the inverse link function for ij = g 1 (ij ) defined as follows for the available
links in link(link):
Inverse link
ij
1/{1 + exp(ij )}
(ij )
exp(ij )
1 exp{ exp(ij )}

link
identity
logit
probit
log
cloglog

By default, random effects and any statistic based on themmu, fitted, pearson, deviance,
anscombeare calculated using posterior means of random effects unless option modes is specified,
in which case the calculations are based on posterior modes of random effects.
Raw residuals are calculated as the difference between the observed and fitted outcomes,

ij = yij ij
and are only defined for the Gaussian family.
Let rij be the number of Bernoulli trials in a binomial model, be the conditional overdispersion
parameter under the mean parameterization of the negative binomial model, and be the conditional
overdispersion parameter under the constant parameterization of the negative binomial model.

meglm postestimation Postestimation tools for meglm

95

Pearson residuals are raw residuals divided by the square root of the variance function
P
ij
=

ij
{V (ij )}1/2

where V (ij ) is the family-specific variance function defined as follows for the available families in
family(family):
family

Variance function V (ij )

bernoulli
binomial

ij (1 ij )
ij (1 ij /rij )

gamma
gaussian
nbinomial mean
nbinomial constant
ordinal
poisson

2ij
1
ij (1 + ij )
ij (1 + )
not defined
ij

96

meglm postestimation Postestimation tools for meglm

Deviance residuals are calculated as


D
ij
= sign(ij ) dij2

where the squared deviance residual dij2 is defined as follows:

family

Squared deviance dij2

bernoulli

2 log(1 ij )

if yij = 0

2 log(ij )

if yij = 1

binomial

2rij log

rij
rij ij

2yij log

yij
ij

2rij log

rij
ij
yij
ij

+ 2(rij yij ) log

2 log

gaussian

2
ij

nbinomial mean

2 log (1 + ij )
yij
ij

nbinomial constant

not defined

ordinal

not defined

poisson

2ij

yij
ij

if 0 < yij < rij

1 + yij
1 + ij

otherwise

ij
ij

if yij = 0

2 (1 + yij ) log

if yij = 0

2yij log

rij yij
rij ij

if yij = rij

gamma

2yij log

if yij = 0

2ij

otherwise

meglm postestimation Postestimation tools for meglm

97

A
Anscombe residuals, denoted ij
, are calculated as follows:

family

A
Anscombe residual ij
2/3

bernoulli

2/3

3 yij H(yij ) ij H(ij )


2 ij 2ij
2/3

binomial

2/3

3 yij H(yij /rij ) ij H(ij /rij )


2 ij 2ij /rij
1/3

gamma

1/6

1/6

1/3

3(yij ij )
1/3

ij

gaussian

ij

nbinomial mean

H(yij ) H(ij ) + 1.5(yij ij )


(ij + 2ij )1/6

nbinomial constant

not defined

ordinal

not defined

2/3

2/3

poisson

2/3

2/3

3(yij ij )
1/6

2ij

where H(t) is a specific univariate case of the Hypergeometric2F1 function (Wolfram 1999, 771772),
defined here as H(t) = 2 F1 (2/3, 1/3, 5/3, t).
For a discussion of the general properties of the various residuals, see Hardin and Hilbe (2012,
chap. 4).

References
Hardin, J. W., and J. M. Hilbe. 2012. Generalized Linear Models and Extensions. 3rd ed. College Station, TX: Stata
Press.
McCullagh, P., and J. A. Nelder. 1989. Generalized Linear Models. 2nd ed. London: Chapman & Hall/CRC.
Skrondal, A., and S. Rabe-Hesketh. 2004. Generalized Latent Variable Modeling: Multilevel, Longitudinal, and
Structural Equation Models. Boca Raton, FL: Chapman & Hall/CRC.
. 2009. Prediction in multilevel generalized linear models. JRSSA 172: 659687.
Wolfram, S. 1999. The Mathematica Book. 4th ed. Cambridge: Cambridge University Press.

Also see
[ME] meglm Multilevel mixed-effects generalized linear model
[U] 20 Estimation and postestimation commands

Title
melogit Multilevel mixed-effects logistic regression
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
melogit depvar fe equation || re equation

|| re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

noconstant
offset(varname)
asis

suppress constant term from the fixed-effects equation


include varname in model with coefficient constrained to 1
retain perfect predictor variables

re options

Description

Model

covariance(vartype)
noconstant

variancecovariance structure of the random effects


suppress constant term from the random-effects equation

98

melogit Multilevel mixed-effects logistic regression

options

99

Description

Model

binomial(varname | #)
constraints(constraints)
collinear

set binomial trials if data are in binomial form


apply specified linear constraints
keep collinear variables

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
or
nocnsreport
notable
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


report fixed-effects coefficients as odds ratios
do not display constraints
suppress coefficient table
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with logistic regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intmethod(intmethod)
intpoints(#)

integration method
set the number of integration (quadrature) points for all levels;
default is intpoints(7)

Maximization

maximize options

control the maximization process; seldom used

startvalues(svmethod)
startgrid (gridspec)
noestimate
dnumerical
coeflegend

method for obtaining starting values


perform a grid search to improve starting values
do not fit the model; show starting values instead
use numerical derivative techniques
display legend instead of statistics

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0; the
default if the R. notation is used
all variances and covariances to be distinctly estimated
user-selected variances and covariances constrained to specified
values; the remaining variances and covariances unrestricted
user-selected variances and covariances constrained to be equal;
the remaining variances and covariances unrestricted

exchangeable
identity
unstructured
fixed(matname)
pattern(matname)

100

melogit Multilevel mixed-effects logistic regression

intmethod

Description

mvaghermite

mean-variance adaptive GaussHermite quadrature; the default


unless a crossed random-effects model is fit
mode-curvature adaptive GaussHermite quadrature
nonadaptive GaussHermite quadrature
Laplacian approximation; the default for crossed random-effects
models

mcaghermite
ghermite
laplace

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
by is allowed; see [U] 11.1.10 Prefix commands.
startvalues(), startgrid, noestimate, dnumerical, and coeflegend do not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Logistic regression

Description
melogit fits mixed-effects models for binary and binomial responses. The conditional distribution
of the response given the random effects is assumed to be Bernoulli, with success probability determined
by the logistic cumulative distribution function.
melogit performs optimization using the original metric of variance components. When variance
components are near the boundary of the parameter space, you may consider using the meqrlogit
command, which provides alternative parameterizations of variance components; see [ME] meqrlogit.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
offset(varname) specifies that varname be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
asis forces retention of perfect predictor variables and their associated, perfectly predicted observations
and may produce instabilities in maximization; see [R] probit.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, unstructured, fixed(matname), or pattern(matname).
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent) unless a crossed random-effects model is fit, in which case the
default is covariance(identity).
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.

melogit Multilevel mixed-effects logistic regression

101

covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.
covariance(unstructured) allows for all variances and covariances to be distinct. If an equation
consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2
unique parameters.
covariance(fixed(matname)) and covariance(pattern(matname)) covariance structures
provide a convenient way to impose constraints on variances and covariances of random effects.
Each specification requires a matname that defines the restrictions placed on variances and
covariances. Only elements in the lower triangle of matname are used, and row and column names
of matname are ignored. A missing value in matname means that a given element is unrestricted.
In a fixed(matname) covariance structure, (co)variance (i, j) is constrained to equal the
value specified in the i, j th entry of matname. In a pattern(matname) covariance structure,
(co)variances (i, j) and (k, l) are constrained to be equal if matname[i, j] = matname[k, l].
binomial(varname | #) specifies that the data are in binomial form; that is, depvar records the number
of successes from a series of binomial trials. This number of trials is given either as varname,
which allows this number to vary over the observations, or as the constant #. If binomial() is
not specified (the default), depvar is treated as Bernoulli, with any nonzero, nonmissing values
indicating positive responses.
constraints(constraints), collinear; see [R] estimation options.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.

Reporting

level(#); see [R] estimation options.


or reports estimated fixed-effects coefficients transformed to odds ratios, that is, exp() rather than .
Standard errors and confidence intervals are similarly transformed. This option affects how results
are displayed, not how they are estimated. or may be specified either at estimation or upon replay.
nocnsreport; see [R] estimation options.
notable suppresses the estimation table, either at estimation or upon replay.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents melogit from performing a likelihood-ratio test that compares the mixed-effects
logistic model with standard (marginal) logistic regression. This option may also be specified upon
replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

102

melogit Multilevel mixed-effects logistic regression

Integration

intmethod(intmethod) specifies the integration method to be used for the random-effects model.
mvaghermite performs mean and variance adaptive GaussHermite quadrature; mcaghermite
performs mode and curvature adaptive GaussHermite quadrature; ghermite performs nonadaptive
GaussHermite quadrature; and laplace performs the Laplacian approximation, equivalent to mode
curvature adaptive Gaussian quadrature with one integration point.
The default integration method is mvaghermite unless a crossed random-effects model is fit, in
which case the default integration method is laplace. The Laplacian approximation has been
known to produce biased parameter estimates; however, the bias tends to be more prominent in
the estimates of the variance components rather than in the estimates of the fixed effects.
For crossed random-effects models, estimation with more than one quadrature point may be
prohibitively intensive even for a small number of levels. For this reason, the integration method
defaults to the Laplacian approximation. You may override this behavior by specifying a different
integration method.
intpoints(#) sets the number of integration points for quadrature. The default is intpoints(7),
which means that seven quadrature points are used for each level of random effects. This option
is not allowed with intmethod(laplace).
The more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases as a function of the number of quadrature points raised to a power
equaling the dimension of the random-effects specification. In crossed random-effects models and
in models with many levels or many random coefficients, this increase can be substantial.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for melogit are listed below.
from() accepts a properly labeled vector of initial values or a list of coefficient names with values.
A list of values is not allowed.
The following options are available with melogit but are not shown in the dialog box:
startvalues(svmethod), startgrid (gridspec) , noestimate, and dnumerical; see [ME]
meglm.
coeflegend; see [R] estimation options.

Remarks and examples


For a general introduction to me commands, see [ME] me.
melogit is a convenience command for meglm with a logit link and a bernoulli or binomial
family; see [ME] meglm.
Remarks are presented under the following headings:
Introduction
Two-level models
Three-level models

melogit Multilevel mixed-effects logistic regression

103

Introduction
Mixed-effects logistic regression is logistic regression containing both fixed effects and random
effects. In longitudinal data and panel data, random effects are useful for modeling intracluster
correlation; that is, observations in the same cluster are correlated because they share common
cluster-level random effects.
Comprehensive treatments of mixed models are provided by, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and
Skrondal (2012). Guo and Zhao (2000) and Rabe-Hesketh and Skrondal (2012, chap. 10) are good
introductory readings on applied multilevel modeling of binary data.
melogit allows for not just one, but many levels of nested clusters of random effects. For example,
in a three-level model you can specify random effects for schools and then random effects for classes
nested within schools. In this model, the observations (presumably, the students) comprise the first
level, the classes comprise the second level, and the schools comprise the third level.
However, for simplicity, for now we consider the two-level model, where for a series of M
independent clusters, and conditional on a set of random effects uj ,
Pr(yij = 1|xij , uj ) = H(xij + zij uj )

(1)

for j = 1, . . . , M clusters, with cluster j consisting of i = 1, . . . , nj observations. The responses are


the binary-valued yij , and we follow the standard Stata convention of treating yij = 1 if depvarij = 0
and treating yij = 0 otherwise. The 1 p row vector xij are the covariates for the fixed effects,
analogous to the covariates you would find in a standard logistic regression model, with regression
coefficients (fixed effects) . For notational convenience here and throughout this manual entry, we
suppress the dependence of yij on xij .
The 1 q vector zij are the covariates corresponding to the random effects and can be used to
represent both random intercepts and random coefficients. For example, in a random-intercept model,
zij is simply the scalar 1. The random effects uj are M realizations from a multivariate normal
distribution with mean 0 and q q variance matrix . The random effects are not directly estimated
as model parameters but are instead summarized according to the unique elements of , known
as variance components. One special case of (1) places zij = xij , so that all covariate effects are
essentially random and distributed as multivariate normal with mean and variance .
Finally, because this is logistic regression, H() is the logistic cumulative distribution function, which
maps the linear predictor to the probability of a success (yij = 1) with H(v) = exp(v)/{1 +exp(v)}.

Model (1) may also be stated in terms of a latent linear response, where only yij = I(yij
> 0)
is observed for the latent

yij
= xij + zij uj + ij

The errors

ij

are distributed as logistic with mean 0 and variance 2 /3 and are independent of uj .

Model (1) is an example of a generalized linear mixed model (GLMM), which generalizes the
linear mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using
mixed and fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there
is insight to be gained through examination of the linear mixed model. This is especially true for
Stata users because the terminology, syntax, options, and output for fitting these types of models are
nearly identical. See [ME] mixed and the references therein, particularly in Introduction, for more
information.
Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out
the random effects. One widely used modern method is to directly estimate the integral required to

104

melogit Multilevel mixed-effects logistic regression

calculate the log likelihood by GaussHermite quadrature or some variation thereof. Because the
log likelihood is computed, this method has the advantage of permitting likelihood-ratio tests for
comparing nested models. Also, if done correctly, quadrature approximations can be quite accurate,
thus minimizing bias.
melogit supports three types of GaussHermite quadrature and the Laplacian approximation
method; see Methods and formulas of [ME] meglm for details. The simplest random-effects model
you can fit using melogit is the two-level model with a random intercept,
Pr(yij = 1|uj ) = H(xij + uj )
This model can also be fit using xtlogit with the re option; see [XT] xtlogit.
Below we present two short examples of mixed-effects logit regression; refer to [ME] me and
[ME] meglm for additional examples including crossed random-effects models.

Two-level models
We begin with a simple application of (1) as a two-level model, because a one-level model, in our
terminology, is just standard logistic regression; see [R] logistic.

Example 1
Ng et al. (2006) analyzed a subsample of data from the 1989 Bangladesh fertility survey (Huq
and Cleland 1990), which polled 1,934 Bangladeshi women on their use of contraception.
. use http://www.stata-press.com/data/r13/bangladesh
(Bangladesh Fertility Survey, 1989)
. describe
Contains data from http://www.stata-press.com/data/r13/bangladesh.dta
obs:
1,934
Bangladesh Fertility Survey,
1989
vars:
7
28 May 2013 20:27
size:
19,340
(_dta has notes)

variable name
district
c_use
urban
age
child1
child2
child3
Sorted by:

storage
type
byte
byte
byte
float
byte
byte
byte

display
format
%9.0g
%9.0g
%9.0g
%6.2f
%9.0g
%9.0g
%9.0g

value
label

yesno
urban

variable label
District
Use contraception
Urban or rural
Age, mean centered
1 child
2 children
3 or more children

district

The women sampled were from 60 districts, identified by the variable district. Each district
contained either urban or rural areas (variable urban) or both. The variable c use is the binary
response, with a value of 1 indicating contraceptive use. Other covariates include mean-centered age
and three indicator variables recording number of children. Below we fit a standard logistic regression
model amended to have random effects for each district.

melogit Multilevel mixed-effects logistic regression

105

. melogit c_use urban age child* || district:


Fitting fixed-effects model:
Iteration 0:
log likelihood = -1229.5485
Iteration 1:
log likelihood = -1228.5268
Iteration 2:
log likelihood = -1228.5263
Iteration 3:
log likelihood = -1228.5263
Refining starting values:
Grid node 0:
log likelihood = -1219.2681
Fitting full model:
Iteration 0:
log likelihood = -1219.2681
Iteration 1:
log likelihood = -1207.5978
Iteration 2:
log likelihood = -1206.8428
Iteration 3:
log likelihood = -1206.8322
Iteration 4:
log likelihood = -1206.8322

(not concave)

Mixed-effects logistic regression


Group variable:
district

Number of obs
Number of groups
Obs per group: min
avg
max
Integration points
Wald chi2(5)
Prob > chi2

Integration method: mvaghermite


Log likelihood = -1206.8322
c_use

Coef.

urban
age
child1
child2
child3
_cons

.7322765
-.0264981
1.116001
1.365895
1.344031
-1.68929

.1194857
.0078916
.1580921
.1746691
.1796549
.1477591

.215618

.0733222

district
var(_cons)

Std. Err.

z
6.13
-3.36
7.06
7.82
7.48
-11.43

LR test vs. logistic regression: chibar2(01) =

P>|z|
0.000
0.001
0.000
0.000
0.000
0.000

=
=
=
=
=
=
=
=

1934
60
2
32.2
118
7
109.60
0.0000

[95% Conf. Interval]


.4980888
-.0419654
.8061465
1.02355
.9919139
-1.978892

.9664641
-.0110309
1.425856
1.70824
1.696148
-1.399687

.1107208

.4198954

43.39 Prob>=chibar2 = 0.0000

The estimation table reports the fixed effects and the estimated variance components. The fixed
effects can be interpreted just as you would the output from logit. You can also specify the or option
at estimation or on replay to display the fixed effects as odds ratios instead. If you did display results
as odds ratios, you would find urban women to have roughly double the odds of using contraception
as that of their rural counterparts. Having any number of children will increase the odds from threeto fourfold when compared with the base category of no children. Contraceptive use also decreases
with age.
Underneath the fixed effect, the table shows the estimated variance components. The random-effects
equation is labeled district, meaning that these are random effects at the district level. Because
we have only one random effect at this level, the table shows only one variance component. The
estimate of u2 is 0.22 with standard error 0.07.
A likelihood-ratio test comparing the model to ordinary logistic regression is provided and is highly
significant for these data.

106

melogit Multilevel mixed-effects logistic regression

Three-level models
Two-level models extend naturally to models with three or more levels with nested random effects.
By nested, we mean that the random effects shared within lower-level subgroups are unique to the
upper-level groups. For example, assuming that classroom effects would be nested within schools
would be natural, because classrooms are unique to schools.

Example 2
Rabe-Hesketh, Toulopoulou, and Murray (2001) analyzed data from a study measuring the cognitive
ability of patients with schizophrenia compared with their relatives and control subjects. Cognitive
ability was measured as the successful completion of the Tower of London, a computerized task,
measured at three levels of difficulty. For all but one of the 226 subjects, there were three measurements
(one for each difficulty level). Because patients relatives were also tested, a family identifier, family,
was also recorded.
. use http://www.stata-press.com/data/r13/towerlondon
(Tower of London data)
. describe
Contains data from http://www.stata-press.com/data/r13/towerlondon.dta
obs:
677
Tower of London data
vars:
5
31 May 2013 10:41
size:
4,739
(_dta has notes)

variable name
family
subject
dtlm
difficulty
group

Sorted by:

storage
type
int
int
byte
byte
byte

family

display
format
%8.0g
%9.0g
%9.0g
%9.0g
%8.0g

value
label

variable label
Family ID
Subject ID
1 = task completed
Level of difficulty: -1, 0, or 1
1: controls; 2: relatives; 3:
schizophrenics

subject

We fit a logistic model with response dtlm, the indicator of cognitive function, and with covariates
difficulty and a set of indicator variables for group, with the controls (group==1) being the base
category. We allow for random effects due to families and due to subjects within families. We also
request to display odds ratios for the fixed-effects parameters.

melogit Multilevel mixed-effects logistic regression

107

. melogit dtlm difficulty i.group || family: || subject: , or


Fitting fixed-effects model:
Iteration 0:
log likelihood = -317.35042
Iteration 1:
log likelihood = -313.90007
Iteration 2:
log likelihood = -313.89079
Iteration 3:
log likelihood = -313.89079
Refining starting values:
Grid node 0:
log likelihood = -310.28429
Fitting full model:
Iteration 0:
log likelihood = -310.28429
Iteration 1:
log likelihood = -307.36653
Iteration 2:
log likelihood = -305.19357
Iteration 3:
log likelihood = -305.12073
Iteration 4:
log likelihood = -305.12041
Iteration 5:
log likelihood = -305.12041
Mixed-effects logistic regression

Group Variable

No. of
Groups

family
subject

118
226

Number of obs

677

Observations per Group


Minimum
Average
Maximum
2
2

5.7
3.0

27
3

Integration method: mvaghermite

Integration points =

Log likelihood = -305.12041

Wald chi2(3)
Prob > chi2

dtlm

Odds Ratio

Std. Err.

difficulty

.1923372

.037161

group
2
3

.7798263
.3491318

_cons

=
=

7
74.90
0.0000

P>|z|

[95% Conf. Interval]

-8.53

0.000

.1317057

.2808806

.2763763
.13965

-0.70
-2.63

0.483
0.009

.3893369
.15941

1.561961
.764651

.226307

.0644625

-5.22

0.000

.1294902

.3955112

family
var(_cons)

.5692105

.5215654

.0944757

3.429459

family>
subject
var(_cons)

1.137917

.6854853

.3494165

3.705762

LR test vs. logistic regression:


chi2(2) =
17.54
Prob > chi2 = 0.0002
Note: LR test is conservative and provided only for reference.

Notes:
1. This is a three-level model with two random-effects equations, separated by ||. The first is a
random intercept (constant only) at the family level, and the second is a random intercept at the
subject level. The order in which these are specified (from left to right) is significantmelogit
assumes that subject is nested within family.

108

melogit Multilevel mixed-effects logistic regression

2. The information on groups is now displayed as a table, with one row for each upper level. Among
other things, we see that we have 226 subjects from 118 families. You can suppress this table
with the nogroup or the noheader option, which will suppress the rest of the header as well.
After adjusting for the random-effects structure, the probability of successful completion of the
Tower of London decreases dramatically as the level of difficulty increases. Also, schizophrenics
(group==3) tended not to perform as well as the control subjects. Of course, we would make similar
conclusions from a standard logistic model fit to the same data, but the odds ratios would differ
somewhat.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left to
right as the groups go from biggest (highest level) to smallest (lowest level).

Stored results
melogit stores the following in e():
Scalars
e(N)
e(k)
e(k dv)
e(k eq)
e(k eq model)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(N clust)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(ic)
e(rc)
e(converged)

number of observations
number of parameters
number of dependent variables
number of equations in e(b)
number of equations in overall model test
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
number of clusters
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
number of iterations
return code
1 if converged, 0 otherwise

melogit Multilevel mixed-effects logistic regression


Macros
e(cmd)
e(cmdline)
e(depvar)
e(covariates)
e(ivars)
e(model)
e(title)
e(link)
e(family)
e(clustvar)
e(offset)
e(binomial)
e(intmethod)
e(n quad)
e(chi2type)
e(vce)
e(vcetype)
e(opt)
e(which)
e(ml method)
e(user)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)
Matrices
e(b)
e(Cns)
e(ilog)
e(gradient)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
e(V modelbased)
Functions
e(sample)

109

melogit
command as typed
name of dependent variable
list of covariates
grouping variables
logistic
title in estimation output
logit
bernoulli or binomial
name of cluster variable
offset
binomial number of trials
integration method
number of integration points
Wald; type of model 2
vcetype specified in vce()
title used to label Std. Err.
type of optimization
max or min; whether optimizer is to perform maximization or minimization
type of ml method
name of likelihood-evaluator program
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict
coefficient vector
constraints matrix
iteration log (up to 20 iterations)
gradient vector
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
model-based variance
marks estimation sample

Methods and formulas


Model (1) assumes Bernoulli data, a special case of the binomial. Because binomial data are also
supported by melogit (option binomial()), the methods presented below are in terms of the more
general binomial mixed-effects model.
For a two-level binomial model, consider the response yij as the number of successes from a
series of rij Bernoulli trials (replications). For cluster j , j = 1, . . . , M , the conditional distribution
of yj = (yj1 , . . . , yjnj ) , given a set of cluster-level random effects uj , is
nj

f (yj |uj ) =
i=1

rij
yij

H(ij )

yij

1 H(ij )

rij yij

nj

yij ij rij log 1 + exp(ij ) + log

= exp
i=1

for ij = xij + zij uj + offsetij and H(v) = exp(v)/{1 + exp(v)}.

rij
yij

110

melogit Multilevel mixed-effects logistic regression

Defining rj = (rj1 , . . . , rjnj ) and


nj

c (yj , rj ) =

log
i=1

rij
yij

where c(yj , rj ) does not depend on the model parameters, we can express the above compactly in
matrix notation,

f (yj |uj ) = exp yj j rj log 1 + exp(j ) + c (yj , rj )


where j is formed by stacking the row vectors ij . We extend the definitions of the functions log()
and exp() to be vector functions where necessary.
Because the prior distribution of uj is multivariate normal with mean 0 and q q variance matrix
, the likelihood contribution for the j th cluster is obtained by integrating uj out of the joint density
f (yj , uj ),
1/2

Lj (, ) = (2)q/2 ||

f (yj |uj ) exp uj 1 uj /2 duj


(2)
q/2

= exp {c (yj , rj )} (2)


where

||

1/2

exp {g (, , uj )} duj

g (, , uj ) = yj j rj log 1 + exp(j ) uj 1 uj /2

and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , rj , Xj , Zj ).
The integration in (2) has no closed form and thus must be approximated. melogit offers four
approximation methods: meanvariance adaptive GaussHermite quadrature (default unless a crossed
random-effects model is fit), mode-curvature adaptive GaussHermite quadrature, nonadaptive Gauss
Hermite quadrature, and Laplacian approximation (default for crossed random-effects models).
The Laplacian approximation is based on a second-order Taylor expansion of g (, , uj ) about
the value of uj that maximizes it; see Methods and formulas in [ME] meglm for details.
Gaussian quadrature relies on transforming the multivariate integral in (2) into a set of nested
univariate integrals. Each univariate integral can then be evaluated using a form of Gaussian quadrature;
see Methods and formulas in [ME] meglm for details.
The log likelihood for the entire dataset is simply the sum of the contributions of the M individual
M
clusters, namely, L(, ) = j=1 Lj (, ).
Maximization of L(, ) is performed with respect to (, 2 ), where 2 is a vector comprising
the unique elements of . Parameter estimates are stored in e(b) as (, 2 ), with the corresponding
variancecovariance matrix stored in e(V).

References
Andrews, M. J., T. Schank, and R. Upward. 2006. Practical fixed-effects estimation methods for the three-way
error-components model. Stata Journal 6: 461481.
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.

melogit Multilevel mixed-effects logistic regression

111

Guo, G., and H. Zhao. 2000. Multilevel modeling of binary data. Annual Review of Sociology 26: 441462.
Gutierrez, R. G., S. L. Carter, and D. M. Drukker. 2001. sg160: On boundary-value likelihood-ratio tests. Stata
Technical Bulletin 60: 1518. Reprinted in Stata Technical Bulletin Reprints, vol. 10, pp. 269273. College Station,
TX: Stata Press.
Harbord, R. M., and P. Whiting. 2009. metandi: Meta-analysis of diagnostic accuracy using hierarchical logistic
regression. Stata Journal 9: 211229.
Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.
Huq, N. M., and J. Cleland. 1990. Bangladesh Fertility Survey 1989 (Main Report). National Institute of Population
Research and Training.
Joe, H. 2008. Accuracy of Laplace approximation for discrete response mixed models. Computational Statistics &
Data Analysis 52: 50665074.
Laird, N. M., and J. H. Ware. 1982. Random-effects models for longitudinal data. Biometrics 38: 963974.
Lin, X., and N. E. Breslow. 1996. Bias correction in generalized linear mixed models with multiple components of
dispersion. Journal of the American Statistical Association 91: 10071016.
Marchenko, Y. V. 2006. Estimating variance components in Stata. Stata Journal 6: 121.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
McLachlan, G. J., and K. E. Basford. 1988. Mixture Models. New York: Dekker.
Ng, E. S.-W., J. R. Carpenter, H. Goldstein, and J. Rasbash. 2006. Estimation in generalised linear mixed models
with binary outcomes by simulated maximum likelihood. Statistical Modelling 6: 2342.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Rabe-Hesketh, S., T. Toulopoulou, and R. M. Murray. 2001. Multilevel modeling of cognitive function in schizophrenic
patients and their first degree relatives. Multivariate Behavioral Research 36: 279298.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Self, S. G., and K.-Y. Liang. 1987. Asymptotic properties of maximum likelihood estimators and likelihood ratio tests
under nonstandard conditions. Journal of the American Statistical Association 82: 605610.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.

Also see
[ME] melogit postestimation Postestimation tools for melogit
[ME] mecloglog Multilevel mixed-effects complementary log-log regression
[ME] meprobit Multilevel mixed-effects probit regression
[ME] meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)
[ME] me Introduction to multilevel mixed-effects models
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtlogit Fixed-effects, random-effects, and population-averaged logit models
[U] 20 Estimation and postestimation commands

Title
melogit postestimation Postestimation tools for melogit
Description
Options for predict
Option for estat icc
Methods and formulas

Syntax for predict


Syntax for estat
Remarks and examples
Also see

Menu for predict


Menu for estat
Stored results

Description
The following postestimation commands are of special interest after melogit:
Command

Description

estat group
estat icc

summarize the composition of the nested groups


estimate intraclass correlations

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

112

melogit postestimation Postestimation tools for melogit

113

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
estat icc displays the intraclass correlation for pairs of latent linear responses at each nested
level of the model. Intraclass correlations are available for random-intercept models or for randomcoefficient models conditional on random-effects covariates being equal to 0. They are not available
for crossed-effects models.

Syntax for predict


Syntax for obtaining predictions of random effects and their standard errors
predict

type

newvarsspec

if

in ,

remeans | remodes

reses(newvarsspec)

Syntax for obtaining other predictions


predict

type

newvarsspec

if

in

, statistic options

newvarsspec is stub* or newvarlist.


statistic

Description

Main

mu
fitted
xb
stdp
pearson
deviance
anscombe

predicted mean; the default


fitted linear predictor
linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction
Pearson residuals
deviance residuals
Anscombe residuals

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

114

melogit postestimation Postestimation tools for melogit

Description

options
Main

compute statistic using empirical Bayes means; the default


compute statistic using empirical Bayes modes
ignore the offset variable in calculating predictions; relevant only
if you specified offset() when you fit the model
prediction for the fixed portion of the model only

means
modes
nooffset
fixedonly
Integration

use # quadrature points to compute empirical Bayes means


set maximum number of iterations in computing statistics involving
empirical Bayes estimators
set convergence tolerance for computing statistics involving empirical
Bayes estimators

intpoints(#)
iterate(#)
tolerance(#)

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

Options for predict

Main

remeans, remodes, reses(); see [ME] meglm postestimation.


mu, the default, calculates the predicted mean (the probability of a positive outcome), that is, the
inverse link function applied to the linear prediction. By default, this is based on a linear predictor
that includes both the fixed effects and the random effects, and the predicted mean is conditional on
the values of the random effects. Use the fixedonly option if you want predictions that include
only the fixed portion of the model, that is, if you want random effects set to 0.
fitted, xb, stdp, pearson, deviance, anscombe, means, modes, nooffset, fixedonly; see
[ME] meglm postestimation.
By default or if the means option is specified, statistics mu, fitted, xb, stdp, pearson, deviance,
and anscombe are based on the posterior mean estimates of random effects. If the modes option
is specified, these statistics are based on the posterior mode estimates of random effects.

Integration

intpoints(), iterate(), tolerance(); see [ME] meglm postestimation.

melogit postestimation Postestimation tools for melogit

115

Syntax for estat


Summarize the composition of the nested groups
estat group
Estimate intraclass correlations
estat icc

, level(#)

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Option for estat icc


level(#) specifies the confidence level, as a percentage, for confidence intervals. The default is
level(95) or as set by set level; see [U] 20.7 Specifying the width of confidence intervals.

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a logistic mixedeffects model with melogit. Here we show a short example of predicted probabilities and predicted
random effects; refer to [ME] meglm postestimation for additional examples.

Example 1
In example 2 of [ME] melogit, we analyzed the cognitive ability (dtlm) of patients with schizophrenia
compared with their relatives and control subjects, by using a three-level logistic model with random
effects at the family and subject levels. Cognitive ability was measured as the successful completion
of the Tower of London, a computerized task, measured at three levels of difficulty.
. use http://www.stata-press.com/data/r13/towerlondon
(Tower of London data)
. melogit dtlm difficulty i.group || family: || subject: , or
(output omitted )

We obtain predicted probabilities based on the contribution of both fixed effects and random effects
by typing
. predict pr
(predictions based on fixed effects and posterior means of random effects)
(option mu assumed)
(using 7 quadrature points)

As the note says, the predicted values are based on the posterior means of random effects. You can
use the modes option to obtain predictions based on the posterior modes of random effects.
We obtain predictions of the posterior means themselves by typing
. predict re*, remeans
(calculating posterior means of random effects)
(using 7 quadrature points)

116

melogit postestimation Postestimation tools for melogit

Because we have one random effect at the family level and another random effect at the subject level,
Stata saved the predicted posterior means in the variables re1 and re2, respectively. If you are not
sure which prediction corresponds to which level, you can use the describe command to show the
variable labels.
Here we list the data for family 16:
. list family subject dtlm pr re1 re2 if family==16, sepby(subject)
family

subject

dtlm

pr

re1

re2

208.
209.
210.

16
16
16

5
5
5

1
0
0

.5337746
.1804649
.0406325

.8045555
.8045555
.8045555

.2204122
.2204122
.2204122

211.
212.
213.

16
16
16

34
34
34

1
1
1

.8956181
.6226832
.2409364

.8045555
.8045555
.8045555

1.430945
1.430945
1.430945

214.
215.
216.

16
16
16

35
35
35

0
1
0

.6627467
.2742936
.0677705

.8045555
.8045555
.8045555

-.042955
-.042955
-.042955

The predicted random effects at the family level (re1) are the same for all members of the family.
Similarly, the predicted random effects at the individual level (re2) are constant within each individual.
The predicted probabilities (pr) for this family seem to be in fair agreement with the response (dtlm)
based on a cutoff of 0.5.
We can use estat icc to estimate the residual intraclass correlation (conditional on the difficulty
level and the individuals category) between the latent responses of subjects within the same family
or between the latent responses of the same subject and family:
. estat icc
Residual intraclass correlation
Level

ICC

family
subject|family

.1139105
.3416307

Std. Err.

[95% Conf. Interval]

.0997727
.0889471

.0181851
.192923

.4715289
.5297291

estat icc reports two intraclass correlations for this three-level nested model. The first is the
level-3 intraclass correlation at the family level, the correlation between latent measurements of the
cognitive ability in the same family. The second is the level-2 intraclass correlation at the subjectwithin-family level, the correlation between the latent measurements of cognitive ability in the same
subject and family.
There is not a strong correlation between individual realizations of the latent response, even within
the same subject.

melogit postestimation Postestimation tools for melogit

117

Stored results
estat icc stores the following in r():
Scalars
r(icc#)
r(se#)
r(level)

level-# intraclass correlation


standard errors of level-# intraclass correlation
confidence level of confidence intervals

Macros
r(label#)

label for level #

Matrices
r(ci#)

vector of confidence intervals (lower and upper) for level-# intraclass correlation

For a G-level nested model, # can be any integer between 2 and G.

Methods and formulas


Methods and formulas are presented under the following headings:
Prediction
Intraclass correlations

Prediction
Methods and formulas for predicting random effects and other statistics are given in Methods and
formulas of [ME] meglm postestimation.

Intraclass correlations
Consider a simple, two-level random-intercept model, stated in terms of a latent linear response,

where only yij = I(yij


> 0) is observed for the latent variable,
(2)

yij
= + uj +

(1)
ij
(2)

with i = 1, . . . , nj and level-2 groups j = 1, . . . , M . Here is an unknown fixed intercept, uj


(1)
ij

is

a level-2 random intercept, and


is a level-1 error term. Errors are assumed to be logistic with
mean 0 and variance 12 = 2 /3; random intercepts are assumed to be normally distributed with
mean 0 and variance 22 and to be independent of error terms.
The intraclass correlation for this model is

= Corr(yij
, yi j ) =

22
2 /3 + 22

It corresponds to the correlation between the latent responses i and i from the same group j .
Now consider a three-level nested random-intercept model,
(2)

(3)

yijk
= + ujk + uk +

(1)
ijk

118

melogit postestimation Postestimation tools for melogit

for measurements i = 1, . . . , njk and level-2 groups j = 1, . . . , M1k nested within level-3 groups
(2)
(3)
k = 1, . . . , M2 . Here ujk is a level-2 random intercept, uk is a level-3 random intercept, and
(1)
ijk is a level-1 error term. The error terms have a logistic distribution with mean 0 and variance
12 = 2 /3. The random intercepts are assumed to be normally distributed with mean 0 and variances
22 and 32 , respectively, and to be mutually independent. The error terms are also independent of the

random intercepts.
We can consider two types of intraclass correlations for this model. We will refer to them as
level-2 and level-3 intraclass correlations. The level-3 intraclass correlation is

(3) = Corr(yijk
, yi j k ) =

32
2 /3 + 22 + 32

This is the correlation between latent responses i and i from the same level-3 group k and from
different level-2 groups j and j .
The level-2 intraclass correlation is

(2) = Corr(yijk
, yi jk ) =

22 + 32
+ 22 + 32

2 /3

This is the correlation between latent responses i and i from the same level-3 group k and level-2
group j . (Note that level-1 intraclass correlation is undefined.)
More generally, for a G-level nested random-intercept model, the g -level intraclass correlation is
defined as
G
2
l=g l
(g) =
G
2 /3 + l=2 l2
The above formulas also apply in the presence of fixed-effects covariates X in a randomeffects model. In this case, intraclass correlations are conditional on fixed-effects covariates and are
referred to as residual intraclass correlations. estat icc also uses the same formulas to compute
intraclass correlations for random-coefficient models, assuming 0 baseline values for the random-effects
covariates, and labels them as conditional intraclass correlations.
Intraclass correlations will always fall in [0,1] because variance components are nonnegative. To
accommodate the range of an intraclass correlation, we use the logit transformation to obtain confidence
intervals. We use the delta method to estimate the standard errors of the intraclass correlations.
Let (g) be a point estimate of the intraclass correlation and SE((g) ) be its standard error. The
(1 ) 100% confidence interval for logit((g) ) is
logit((g) ) z/2

SE((g) )

(g) (1 (g) )

where z/2 is the 1 /2 quantile of the standard normal distribution and logit(x) = ln{x/(1 x)}.
Let ku be the upper endpoint of this interval, and let kl be the lower. The (1 ) 100% confidence
interval for (g) is then given by

1
1
,
1 + ekl 1 + eku

melogit postestimation Postestimation tools for melogit

Also see
[ME] melogit Multilevel mixed-effects logistic regression
[ME] meglm postestimation Postestimation tools for meglm
[U] 20 Estimation and postestimation commands

119

Title
menbreg Multilevel mixed-effects negative binomial regression
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
menbreg depvar fe equation || re equation

|| re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.

fe options

Description

Model

noconstant
exposure(varnamee )
offset(varnameo )

suppress the constant term from the fixed-effects equation


include ln(varnamee ) in model with coefficient constrained to 1
include varnameo in model with coefficient constrained to 1

re options

Description

Model

covariance(vartype)
noconstant

variancecovariance structure of the random effects


suppress constant term from the random-effects equation

120

menbreg Multilevel mixed-effects negative binomial regression

options

121

Description

Model

dispersion(dispersion)
constraints(constraints)
collinear

parameterization of the conditional overdispersion;


dispersion may be mean (default) or constant
apply specified linear constraints
keep collinear variables

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
irr
nocnsreport
notable
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


report fixed-effects coefficients as incidence-rate ratios
do not display constraints
suppress coefficient table
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with negative
binomial regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intmethod(intmethod)
intpoints(#)

integration method
set the number of integration (quadrature) points for all levels;
default is intpoints(7)

Maximization

maximize options

control the maximization process; seldom used

startvalues(svmethod)
startgrid (gridspec)
noestimate
dnumerical
coeflegend

method for obtaining starting values


perform a grid search to improve starting values
do not fit the model; show starting values instead
use numerical derivative techniques
display legend instead of statistics

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0; the
default if the R. notation is used
all variances and covariances to be distinctly estimated
user-selected variances and covariances constrained to specified
values; the remaining variances and covariances unrestricted
user-selected variances and covariances constrained to be equal;
the remaining variances and covariances unrestricted

exchangeable
identity
unstructured
fixed(matname)
pattern(matname)

122

menbreg Multilevel mixed-effects negative binomial regression

intmethod

Description

mvaghermite

mean-variance adaptive GaussHermite quadrature; the default


unless a crossed random-effects model is fit
mode-curvature adaptive GaussHermite quadrature
nonadaptive GaussHermite quadrature
Laplacian approximation; the default for crossed random-effects
models

mcaghermite
ghermite
laplace

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
by is allowed; see [U] 11.1.10 Prefix commands.
startvalues(), startgrid, noestimate, dnumerical, and coeflegend do not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Negative binomial regression

Description
menbreg fits mixed-effects negative binomial models to count data. The conditional distribution
of the response given random effects is assumed to follow a Poisson-like process, except that the
variation is greater than that of a true Poisson process.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
exposure(varnamee ) specifies a variable that reflects the amount of exposure over which the depvar
events were observed for each observation; ln(varnamee ) is included in the fixed-effects portion
of the model with the coefficient constrained to be 1.
offset(varnameo ) specifies that varnameo be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, unstructured, fixed(matname), or pattern(matname).
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent) unless a crossed random-effects model is fit, in which case the
default is covariance(identity).
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.
covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.

menbreg Multilevel mixed-effects negative binomial regression

123

covariance(unstructured) allows for all variances and covariances to be distinct. If an equation


consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2
unique parameters.
covariance(fixed(matname)) and covariance(pattern(matname)) covariance structures
provide a convenient way to impose constraints on variances and covariances of random effects.
Each specification requires a matname that defines the restrictions placed on variances and
covariances. Only elements in the lower triangle of matname are used, and row and column names
of matname are ignored. A missing value in matname means that a given element is unrestricted.
In a fixed(matname) covariance structure, (co)variance (i, j) is constrained to equal the
value specified in the i, j th entry of matname. In a pattern(matname) covariance structure,
(co)variances (i, j) and (k, l) are constrained to be equal if matname[i, j] = matname[k, l].
dispersion(mean | constant) specifies the parameterization of the conditional overdispersion given
random effects. dispersion(mean), the default, yields a model where the conditional overdispersion is a function of the conditional mean given random effects. For example, in a two-level
model, the conditional overdispersion is equal to 1 +E(yij |uj ). dispersion(constant) yields
a model where the conditional overdispersion is constant and is equal to 1 + . and are the
respective conditional overdispersion parameters.
constraints(constraints), collinear; see [R] estimation options.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.

Reporting

level(#); see [R] estimation options.


irr reports estimated fixed-effects coefficients transformed to incidence-rate ratios, that is, exp()
rather than . Standard errors and confidence intervals are similarly transformed. This option
affects how results are displayed, not how they are estimated or stored. irr may be specified
either at estimation or upon replay.
nocnsreport; see [R] estimation options.
notable suppresses the estimation table, either at estimation or upon replay.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents menbreg from performing a likelihood-ratio test that compares the mixed-effects
negative binomial model with standard (marginal) negative binomial regression. This option may
also be specified upon replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

124

menbreg Multilevel mixed-effects negative binomial regression

Integration

intmethod(intmethod) specifies the integration method to be used for the random-effects model.
mvaghermite performs mean and variance adaptive GaussHermite quadrature; mcaghermite
performs mode and curvature adaptive GaussHermite quadrature; ghermite performs nonadaptive
GaussHermite quadrature; and laplace performs the Laplacian approximation, equivalent to mode
curvature adaptive Gaussian quadrature with one integration point.
The default integration method is mvaghermite unless a crossed random-effects model is fit, in
which case the default integration method is laplace. The Laplacian approximation has been
known to produce biased parameter estimates; however, the bias tends to be more prominent in
the estimates of the variance components rather than in the estimates of the fixed effects.
For crossed random-effects models, estimation with more than one quadrature point may be
prohibitively intensive even for a small number of levels. For this reason, the integration method
defaults to the Laplacian approximation. You may override this behavior by specifying a different
integration method.
intpoints(#) sets the number of integration points for quadrature. The default is intpoints(7),
which means that seven quadrature points are used for each level of random effects. This option
is not allowed with intmethod(laplace).
The more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases as a function of the number of quadrature points raised to a power
equaling the dimension of the random-effects specification. In crossed random-effects models and
in models with many levels or many random coefficients, this increase can be substantial.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for menbreg are listed below.
from() accepts a properly labeled vector of initial values or a list of coefficient names with values.
A list of values is not allowed.
The following options are available with menbreg but are not shown in the dialog box:
startvalues(svmethod), startgrid (gridspec) , noestimate, and dnumerical; see [ME]
meglm.
coeflegend; see [R] estimation options.

Remarks and examples


For a general introduction to me commands, see [ME] me.
menbreg is a convenience command for meglm with a log link and an nbinomial family; see
[ME] meglm.
Remarks are presented under the following headings:
Introduction
Two-level models

menbreg Multilevel mixed-effects negative binomial regression

125

Introduction
Mixed-effects negative binomial regression is negative binomial regression containing both fixed
effects and random effects. In longitudinal data and panel data, random effects are useful for modeling
intracluster correlation; that is, observations in the same cluster are correlated because they share
common cluster-level random effects.
Comprehensive treatments of mixed models are provided by, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and Skrondal (2012). Rabe-Hesketh and Skrondal (2012, chap. 13) is a good introductory reading on applied
multilevel modeling of count data.
menbreg allows for not just one, but many levels of nested clusters of random effects. For example,
in a three-level model you can specify random effects for schools and then random effects for classes
nested within schools. In this model, the observations (presumably, the students) comprise the first
level, the classes comprise the second level, and the schools comprise the third.
However, for simplicity, consider a two-level model, where for a series of M independent clusters,
and conditional on the latent variable ij and a set of random effects uj ,

yij |ij Poisson(ij )


and

ij |uj Gamma(rij , pij )


and

uj N (0, )
where yij is the count response of the ith observation, i = 1, . . . , nj , from the j th cluster,
j = 1, . . . , M , and rij and pij have two different parameterizations, (2) and (3) below. The random
effects uj are M realizations from a multivariate normal distribution with mean 0 and q q
variance matrix . The random effects are not directly estimated as model parameters but are instead
summarized according to the unique elements of , known as variance components.
The probability that a random response yij takes the value y is then given by
Pr(yij = y|uj ) =

(y + rij )
r
p ij (1 pij )y
(y + 1)(rij ) ij

(1)

where for convenience we suppress the dependence of the observable data yij on rij and pij .
Model (1) is an extension of the standard negative binomial model (see [R] nbreg) to incorporate
normally distributed random effects at different hierarchical levels. (The negative binomial model
itself can be viewed as a random-effects model, a Poisson model with a gamma-distributed random
effect.) The standard negative binomial model is used to model overdispersed count data for which the
variance is greater than that of a Poisson model. In a Poisson model, the variance is equal to the mean,
and thus overdispersion is defined as the extra variability compared with the mean. According to this
definition, the negative binomial model presents two different parameterizations of the overdispersion:
the mean parameterization, where the overdispersion is a function of the mean, 1 + E(Y |x), > 0;
and the constant parameterization, where the overdispersion is a constant function, 1 + , 0. We
refer to and as conditional overdispersion parameters.

126

menbreg Multilevel mixed-effects negative binomial regression

Let ij = E(yij |x, uj ) = exp(xij +zij uj ), where xij is the 1 p row vector of the fixed-effects
covariates, analogous to the covariates you would find in a standard negative binomial regression
model, with regression coefficients (fixed effects) ; zij is the 1 q vector of the random-effects
covariates and can be used to represent both random intercepts and random coefficients. For example,
in a random-intercept model, zij is simply the scalar 1. One special case places zij = xij , so that
all covariate effects are essentially random and distributed as multivariate normal with mean and
variance .
Similarly to the standard negative binomial model, we can consider two parameterizations of
what we call the conditional overdispersion, the overdispersion conditional on random effects, in a
random-effects negative binomial model. For the mean-overdispersion (or, more technically, meanconditional-overdispersion) parameterization,

rij = 1/ and pij =

1
1 + ij

(2)

and the conditional overdispersion is equal to 1 + ij . For the constant-overdispersion (or, more
technically, constant-conditional-overdispersion) parameterization,

rij = ij / and pij =

1
1+

(3)

and the conditional overdispersion is equal to 1 + . In what follows, for brevity, we will use the
term overdispersion parameter to mean conditional overdispersion parameter, unless stated otherwise.
In the context of random-effects negative binomial models, it is important to decide which model
is used as a reference model for the definition of the overdispersion. For example, if we consider
a corresponding random-effects Poisson model as a comparison model, the parameters and can
still be viewed as unconditional overdispersion parameters, as we show below, although the notion
of a constant overdispersion is no longer applicable.
If we retain the definition of the overdispersion as the excess variation with respect to a Poisson
process for which the variance is equal to the mean, we need to carefully distinguish between the
marginal (unconditional) mean with random effects integrated out and the conditional mean given
random effects.
In what follows, for simplicity, we omit the dependence of the formulas on x. Conditionally on
random effects, the (conditional) dispersion Var(yij |uj ) = (1+ij )ij for the mean parameterization
and Var(yij |uj ) = (1 + )ij for the constant parameterization; the usual interpretation of the
parameters holds (conditionally).
If we consider the marginal mean or, specifically, the marginal dispersion for, for example, a
two-level random-intercept model, then

Var(yij ) = 1 + {exp( 2 )(1 + ) 1}E(yij ) E(yij )


for the mean parameterization and

Var(yij ) = 1 + + {exp( 2 ) 1}E(yij ) E(yij )


for the constant parameterization, where 2 is the variance component corresponding to the random
intercept.

menbreg Multilevel mixed-effects negative binomial regression

127

A few things of interest compared with the standard negative binomial model. First, the randomeffects negative binomial model is not strictly an overdispersed model. The combination of values
of and 2 can lead to an underdispersed model, a model with smaller variability than the Poisson
variability. Underdispersed models are not as common in practice, so we will concentrate on the
overdispersion in this entry. Second, (or ) no longer solely determine the overdispersion and thus
cannot be viewed as unconditional overdispersion parameters. Overdispersion is now a function of
both (or ) and 2 . Third, the notion of a constant overdispersion is not applicable.
Two special cases are worth mentioning. When 2 = 0, the dispersion reduces to that of a standard
negative binomial model. When = 0 (or = 0), the dispersion reduces to that of a two-level
random-intercept Poisson model, which itself is, in general, an overdispersed model; see Rabe-Hesketh
and Skrondal (2012, chap. 13.7) for more details. As such, and retain the typical interpretation
as dispersion parameters relative to a random-intercept Poisson model.
Model (1) is an example of a generalized linear mixed model (GLMM), which generalizes the linear
mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using mixed and
fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there is insight
to be gained through examination of the linear mixed model. This is especially true for Stata users
because the terminology, syntax, options, and output for fitting these types of models are nearly
identical. See [ME] mixed and the references therein, particularly in the Introduction of [ME] mixed,
for more information.
Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out
the random effects. One widely used modern method is to directly estimate the integral required to
calculate the log likelihood by GaussHermite quadrature or some variation thereof. Because the log
likelihood itself is estimated, this method has the advantage of permitting likelihood-ratio tests for
comparing nested models. Also, if done correctly, quadrature approximations can be quite accurate,
thus minimizing bias.
menbreg supports three types of GaussHermite quadrature and the Laplacian approximation
method; see Methods and formulas of [ME] meglm for details.
Below we present two short examples of mixed-effects negative binomial regression; refer to
[ME] me and [ME] meglm for more examples including crossed-effects models.

Two-level models
Example 1
Rabe-Hesketh and Skrondal (2012, chap. 13.7) analyze the data from Winkelmann (2004) on
the impact of the 1997 health reform in Germany on the number of doctor visits. The intent of
policymakers was to reduce government expenditures on health care. We use a subsample of the data
restricted to 1,158 women who were employed full time the year before or after the reform.

128

menbreg Multilevel mixed-effects negative binomial regression


. use http://www.stata-press.com/data/r13/drvisits
. describe
Contains data from http://www.stata-press.com/data/r13/drvisits.dta
obs:
2,227
vars:
8
23 Jan 2013 18:39
size:
71,264

variable name

storage
type

display
format

id
numvisit

float
float

%9.0g
%9.0g

age
educ
married
badh

float
float
float
float

%9.0g
%9.0g
%9.0g
%9.0g

loginc
reform

float
float

%9.0g
%9.0g

value
label

variable label
person id
number of doctor visits in the
last 3 months before interview
age in years
education in years
=1 if married, 0 otherwise
self-reported health status, =1
if bad
log of household income
=0 if interview before reform, =1
if interview after reform

Sorted by:

The dependent variable, numvisit, is a count of doctor visits. The covariate of interest is a dummy
variable, reform, which indicates whether a doctor visit took place before or after the reform. Other
covariates include a self-reported health status, age, education, marital status, and a log of household
income.

menbreg Multilevel mixed-effects negative binomial regression

129

We first fit a two-level random-intercept Poisson model. We specify the random intercept at the
id level, that is, an individual-person level.
. mepoisson numvisit reform age
Fitting fixed-effects model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Iteration 4:
log likelihood =

educ married badh loginc || id:, irr


-9326.8542
-5989.7308
-5942.7581
-5942.7243
-5942.7243

Refining starting values:


Grid node 0:
log likelihood = -4761.1257
Fitting full model:
Iteration 0:
log likelihood = -4761.1257
Iteration 1:
log likelihood = -4683.2239
Iteration 2:
log likelihood = -4646.9329
Iteration 3:
log likelihood = -4645.736
Iteration 4:
log likelihood = -4645.7371
Iteration 5:
log likelihood = -4645.7371
Mixed-effects Poisson regression
Group variable:
id

Number of obs
Number of groups
Obs per group: min
avg
max

Integration method: mvaghermite


Log likelihood = -4645.7371
numvisit

IRR

Std. Err.

reform
age
educ
married
badh
loginc
_cons

.9517026
1.005821
1.008788
1.082078
2.471857
1.094144
.5216748

.0309352
.002817
.0127394
.0596331
.151841
.0743018
.2668604

var(_cons)

.8177932

.0503902

z
-1.52
2.07
0.69
1.43
14.73
1.32
-1.27

=
=
=
=
=

2227
1518
1
1.5
2

Integration points =
Wald chi2(6)
=
Prob > chi2
=

7
249.37
0.0000

P>|z|

[95% Conf. Interval]

0.128
0.038
0.488
0.152
0.000
0.185
0.203

.8929617
1.000315
.9841258
.9712905
2.191471
.9577909
.191413

1.014308
1.011357
1.034068
1.205503
2.788116
1.249909
1.421766

.724761

.9227673

id

LR test vs. Poisson regression:


. estimates store mepoisson

chibar2(01) =

2593.97 Prob>=chibar2 = 0.0000

Because we specified the irr option, the parameters are reported as incidence-rate ratios. The
healthcare reform seems to reduce the expected number of visits by 5% but without statistical
significance.
Because we have only one random effect at the id level, the table shows only one variance
component. The estimate of u2 is 0.82 with standard error 0.05. The reported likelihood-ratio test
shows that there is enough variability between women to favor a mixed-effects Poisson regression
over a standard Poisson regression; see Distribution theory for likelihood-ratio test in [ME] me for a
discussion of likelihood-ratio testing of variance components.
It is possible that after conditioning on the person-level random effect, the counts of doctor visits
are overdispersed. For example, medical problems occurring during the time period leading to the
survey can result in extra doctor visits. We thus reexamine the data with menbreg.

130

menbreg Multilevel mixed-effects negative binomial regression


. menbreg numvisit reform age educ married badh loginc || id:, irr
Fitting fixed-effects model:
Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:

log
log
log
log

likelihood
likelihood
likelihood
likelihood

=
=
=
=

-4610.7165
-4563.4682
-4562.3241
-4562.3238

Refining starting values:


Grid node 0:

log likelihood = -4643.5216

Fitting full model:


Iteration
Iteration
Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:
4:
5:

log
log
log
log
log
log

likelihood
likelihood
likelihood
likelihood
likelihood
likelihood

=
=
=
=
=
=

-4643.5216
-4555.961
-4518.7353
-4513.1951
-4513.1853
-4513.1853

(not concave)

Mixed-effects nbinomial regression


Overdispersion:
mean
Group variable:
id

Number of obs

2227

Number of groups

1518

Obs per group: min =


avg =
max =

1
1.5
2

Integration method: mvaghermite

Integration points =

Log likelihood = -4513.1853

Wald chi2(6)
Prob > chi2

numvisit

IRR

Std. Err.

reform
age
educ
married
badh
loginc
_cons

.9008536
1.003593
1.007026
1.089597
3.043562
1.136342
.5017199

.042022
.0028206
.012827
.064213
.2366182
.0867148
.285146

/lnalpha

-.7962692

.1190614

var(_cons)

.4740088

.0582404

=
=

7
237.35
0.0000

P>|z|

[95% Conf. Interval]

-2.24
1.28
0.55
1.46
14.32
1.67
-1.21

0.025
0.202
0.583
0.145
0.000
0.094
0.225

.8221449
.9980799
.9821969
.970738
2.613404
.9784833
.1646994

.9870975
1.009137
1.032483
1.223008
3.544523
1.319668
1.528377

-6.69

0.000

-1.029625

-.5629132

.3725642

.6030754

id

LR test vs. nbinomial regression:chibar2(01) =

98.28 Prob>=chibar2 = 0.0000

The estimated effect of the healthcare reform now corresponds to the reduction in the number of
doctor visits by 10%twice as much compared with the Poisson modeland this effect is significant
at the 5% level.
The estimate of the variance component u2 drops down to 0.47 compared with mepoisson, which
is not surprising given that now we have an additional parameter that controls the variability of the
data.
Because the conditional overdispersion is assumed to be greater than 0, it is parameterized
on the log scale, and its log estimate is reported as /lnalpha in the output. In our model, =
exp(0.80) = 0.45. We can also compute the unconditional overdispersion in this model by using
the corresponding formula in the Introduction above: exp(.47) (1 + .45) 1 = 1.32.
The reported likelihood-ratio test shows that there is enough variability between women to favor a
mixed-effects negative binomial regression over negative binomial regression without random effects.

menbreg Multilevel mixed-effects negative binomial regression

131

We can also perform a likelihood-ratio test comparing the mixed-effects negative binomial model to
the mixed-effects Poisson model. Because we are comparing two different estimators, we need to use
the force option with lrtest. In general, there is no guarantee as to the validity or interpretability of
the resulting likelihood-ratio test, but in our case we know the test is valid because the mixed-effects
Poisson model is nested within the mixed-effects negative binomial model.
. lrtest mepoisson ., force
Likelihood-ratio test
(Assumption: mepoisson nested in .)

LR chi2(1) =
Prob > chi2 =

265.10
0.0000

Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

The reported likelihood-ratio test favors the mixed-effects negative binomial model. The reported
test is conservative because the test of H0 : = 0 occurs on the boundary of the parameter space;
see Distribution theory for likelihood-ratio test in [ME] me for details.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left
to right as the groups go from biggest (highest level) to smallest (lowest level). To demonstrate a
three-level model, we revisit example 2 from [ME] meqrpoisson.

Example 2
Rabe-Hesketh and Skrondal (2012, exercise 13.7) describe data from the Atlas of Cancer Mortality
in the European Economic Community (EEC) (Smans, Mair, and Boyle 1993). The data were analyzed
in Langford, Bentham, and McDonald (1998) and record the number of deaths among males due to
malignant melanoma during 19711980.
. use http://www.stata-press.com/data/r13/melanoma
(Skin cancer (melanoma) data)
. describe
Contains data from http://www.stata-press.com/data/r13/melanoma.dta
obs:
354
Skin cancer (melanoma) data
vars:
6
30 May 2013 17:10
size:
4,956
(_dta has notes)
storage
type

display
format

value
label

nation
region
county

byte
byte
int

%11.0g
%9.0g
%9.0g

deaths
expected
uv

int
float
float

%9.0g
%9.0g
%9.0g

variable name

variable label
Nation ID
Region ID: EEC level-I areas
County ID: EEC level-II/level-III
areas
No. deaths during 1971-1980
No. expected deaths
UV dose, mean-centered

Sorted by:

Nine European nations (variable nation) are represented, and data were collected over geographical
regions defined by EEC statistical services as level I areas (variable region), with deaths being recorded
for each of 354 counties, which are level II or level III EEC-defined areas (variable county, which
identifies the observations). Counties are nested within regions, and regions are nested within nations.

132

menbreg Multilevel mixed-effects negative binomial regression

The variable deaths records the number of deaths for each county, and expected records the
expected number of deaths (the exposure) on the basis of crude rates for the combined countries. The
variable uv is a measure of exposure to ultraviolet (UV) radiation.
In example 2 of [ME] meqrpoisson, we noted that because counties also identified the observations,
we could model overdispersion by using a four-level Poisson model with a random intercept at the
county level. Here we fit a three-level negative binomial model with the default mean-dispersion
parameterization.
. menbreg deaths uv, exposure(expected) || nation: || region:
Fitting fixed-effects model:
Iteration 0:
log likelihood = -1361.855
Iteration 1:
log likelihood = -1230.0211
Iteration 2:
log likelihood = -1211.049
Iteration 3:
log likelihood = -1202.5641
Iteration 4:
log likelihood = -1202.5329
Iteration 5:
log likelihood = -1202.5329
Refining starting values:
Grid node 0:
log likelihood = -1209.6951
Fitting full model:
Iteration 0:
log likelihood = -1209.6951 (not concave)
(output omitted )
Iteration 11: log likelihood = -1086.3902
Mixed-effects nbinomial regression
Number of obs
Overdispersion:
mean

Group Variable

No. of
Groups

nation
region

9
78

354

Integration points =
Wald chi2(1)
=
Prob > chi2
=

7
8.73
0.0031

Observations per Group


Minimum
Average
Maximum
3
1

39.3
4.5

Integration method: mvaghermite


Log likelihood = -1086.3902
z

95
13

deaths

Coef.

Std. Err.

P>|z|

[95% Conf. Interval]

uv
_cons
ln(expected)

-.0335933
-.0790606
1

.0113725
.1295931
(exposure)

-2.95
-0.61

0.003
0.542

-.055883
-.3330583

-.0113035
.1749372

/lnalpha

-4.182603

.3415036

-12.25

0.000

-4.851937

-3.513268

nation
var(_cons)

.1283614

.0678971

.0455187

.3619758

nation>
region
var(_cons)

.0401818

.0104855

.0240938

.067012

LR test vs. nbinomial regression:


chi2(2) =
232.29
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

menbreg Multilevel mixed-effects negative binomial regression

133

The estimates are very close to those of meqrpoisson. The conditional overdispersion in our
model is = exp(4.18) = 0.0153. It is in agreement with the estimate of the random intercept
at the county level, 0.0146, in a four-level random-effects Poisson model reported by meqrpoisson.
Because the negative binomial is a three-level model, we gained some computational efficiency over
the four-level Poisson model.

Stored results
menbreg stores the following in e():
Scalars
e(N)
e(k)
e(k dv)
e(k eq)
e(k eq model)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(N clust)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(ic)
e(rc)
e(converged)

number of observations
number of parameters
number of dependent variables
number of equations in e(b)
number of equations in overall model test
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
number of clusters
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
number of iterations
return code
1 if converged, 0 otherwise

134

menbreg Multilevel mixed-effects negative binomial regression

Macros
e(cmd)
e(cmdline)
e(depvar)
e(covariates)
e(ivars)
e(model)
e(title)
e(link)
e(family)
e(clustvar)
e(dispersion)
e(offset)
e(exposure)
e(intmethod)
e(n quad)
e(chi2type)
e(vce)
e(vcetype)
e(opt)
e(which)
e(ml method)
e(user)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)
Matrices
e(b)
e(Cns)
e(ilog)
e(gradient)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
e(V modelbased)
Functions
e(sample)

menbreg
command as typed
name of dependent variable
list of covariates
grouping variables
nbreg
title in estimation output
log
nbinomial
name of cluster variable
mean or constant
offset
exposure variable
integration method
number of integration points
Wald; type of model 2
vcetype specified in vce()
title used to label Std. Err.
type of optimization
max or min; whether optimizer is to perform maximization or minimization
type of ml method
name of likelihood-evaluator program
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict
coefficient vector
constraints matrix
iteration log (up to 20 iterations)
gradient vector
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
model-based variance
marks estimation sample

Methods and formulas


Without a loss of generality, consider a two-level negative binomial model. For cluster j , j =
1, . . . , M , the conditional distribution of yj = (yj1 , . . . , yjnj ) , given a set of cluster-level random
effects uj and the conditional overdispersion parameter in a mean-overdispersion parameterization,
is
nj

f (yj |uj , ) =
i=1

(yij + r)
pr (1 pij )yij
(yij + 1)(r) ij
nj

{log (yij + r) log (yij + 1) log (r) + c(yij , )}

= exp
i=1

menbreg Multilevel mixed-effects negative binomial regression

135

where c(yij , ) is defined as

1
log{1 + exp(ij + log )} yij log{1 + exp(ij log )}

and r = 1/, pij = 1/(1 + ij ), and ij = xij + zij uj .


For the constant-overdispersion parameterization with the conditional overdispersion parameter ,
the conditional distribution of yj is

nj

f (yj |uj , ) =
i=1

(yij + rij )
prij (1 p)yij
(yij + 1)(rij )
nj

{log (yij + rij ) log (yij + 1) log (rij ) + c(yij , )}

= exp
i=1

where c(yij , ) is defined as

ij
+ yij log(1 + ) + yij log

and rij = ij / and p = 1/(1 + ).


For conciseness, let denote either conditional overdispersion parameter. Because the prior
distribution of uj is multivariate normal with mean 0 and q q variance matrix , the likelihood
contribution for the j th cluster is obtained by integrating uj out of the joint density f (yj , uj , ),

Lj (, , ) = (2)q/2 ||

1/2

f (yj |uj , ) exp uj 1 uj /2 duj

= (2)q/2 ||

1/2

exp {g (, , uj , )} duj

(4)

where

g (, , uj , ) = f (yj |uj , ) uj 1 uj /2

and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , Xj , Zj ).
The integration in (4) has no closed form and thus must be approximated. menbreg offers four
approximation methods: meanvariance adaptive GaussHermite quadrature (default unless a crossed
random-effects model is fit), mode-curvature adaptive GaussHermite quadrature, nonadaptive Gauss
Hermite quadrature, and Laplacian approximation (default for crossed random-effects models).
The Laplacian approximation is based on a second-order Taylor expansion of g (, , uj ) about
the value of uj that maximizes it; see Methods and formulas in [ME] meglm for details.
Gaussian quadrature relies on transforming the multivariate integral in (4) into a set of nested
univariate integrals. Each univariate integral can then be evaluated using a form of Gaussian quadrature;
see Methods and formulas in [ME] meglm for details.
The log likelihood for the entire dataset is simply the sum of the contributions of the M individual
M
clusters, namely, L(, , ) = j=1 Lj (, , ).

136

menbreg Multilevel mixed-effects negative binomial regression

Maximization of L(, , ) is performed with respect to (, ln, 2 ), where 2 is a vector


comprising the unique elements of . Parameter estimates are stored in e(b) as (, ln, 2 ), with
the corresponding variancecovariance matrix stored in e(V).

References
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.
Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.
Langford, I. H., G. Bentham, and A. McDonald. 1998. Multi-level modelling of geographically aggregated health
data: A case study on malignant melanoma mortality and UV exposure in the European community. Statistics in
Medicine 17: 4157.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Smans, M., C. S. Mair, and P. Boyle. 1993. Atlas of Cancer Mortality in the European Economic Community. Lyon,
France: IARC Scientific Publications.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.
Winkelmann, R. 2004. Health care reform and the number of doctor visitsAn econometric analysis. Journal of
Applied Econometrics 19: 455472.

Also see
[ME] menbreg postestimation Postestimation tools for menbreg
[ME] mepoisson Multilevel mixed-effects Poisson regression
[ME] meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)
[ME] me Introduction to multilevel mixed-effects models
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtnbreg Fixed-effects, random-effects, & population-averaged negative binomial models
[U] 20 Estimation and postestimation commands

Title
menbreg postestimation Postestimation tools for menbreg
Description
Options for predict
Remarks and examples

Syntax for predict


Syntax for estat group
Methods and formulas

Menu for predict


Menu for estat
Also see

Description
The following postestimation command is of special interest after menbreg:
Command

Description

estat group

summarize the composition of the nested groups

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
137

138

menbreg postestimation Postestimation tools for menbreg

Syntax for predict


Syntax for obtaining predictions of random effects and their standard errors
predict

type

newvarsspec

if

in ,

remeans | remodes

reses(newvarsspec)

Syntax for obtaining other predictions


predict

type

newvarsspec

if

in

, statistic options

newvarsspec is stub* or newvarlist.


Description

statistic
Main

number of events; the default


fitted linear predictor
linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction
Pearson residuals
deviance residuals
Anscombe residuals

mu
fitted
xb
stdp
pearson
deviance
anscombe

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

Description

options
Main

means
modes
nooffset
fixedonly

compute statistic using empirical Bayes means; the default


compute statistic using empirical Bayes modes
ignore the offset or exposure variable in calculating predictions; relevant only
if you specified offset() or exposure() when you fit the model
prediction for the fixed portion of the model only

Integration

intpoints(#)
iterate(#)
tolerance(#)

use # quadrature points to compute empirical Bayes means


set maximum number of iterations in computing statistics involving
empirical Bayes estimators
set convergence tolerance for computing statistics involving empirical
Bayes estimators

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

menbreg postestimation Postestimation tools for menbreg

139

Options for predict

Main

remeans, remodes, reses(); see [ME] meglm postestimation.


mu, the default, calculates the predicted mean (the predicted number of events), that is, the inverse
link function applied to the linear prediction. By default, this is based on a linear predictor that
includes both the fixed effects and the random effects, and the predicted mean is conditional on
the values of the random effects. Use the fixedonly option if you want predictions that include
only the fixed portion of the model, that is, if you want random effects set to 0.
fitted, xb, stdp, pearson, deviance, anscombe, means, modes, nooffset, fixedonly; see
[ME] meglm postestimation.
By default or if the means option is specified, statistics mu, pr, fitted, xb, stdp, pearson,
deviance, and anscombe are based on the posterior mean estimates of random effects. If the
modes option is specified, these statistics are based on the posterior mode estimates of random
effects.

Integration

intpoints(), iterate(), tolerance(); see [ME] meglm postestimation.

Syntax for estat group


estat group

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a mixed-effects
negative binomial model with menbreg. For the most part, calculation centers around obtaining
estimates of the subject/group-specific random effects. Random effects are not estimated when the
model is fit but instead need to be predicted after estimation.
Here we show a short example of predicted counts and predicted random effects; refer to [ME] meglm
postestimation for additional examples applicable to mixed-effects generalized linear models.

Example 1
In example 2 of [ME] menbreg, we modeled the number of deaths among males in nine European
nations as a function of exposure to ultraviolet radiation (uv). We used a three-level negative binomial
model with random effects at the nation and region levels.

140

menbreg postestimation Postestimation tools for menbreg


. use http://www.stata-press.com/data/r13/melanoma
(Skin cancer (melanoma) data)
. menbreg deaths uv, exposure(expected) || nation: || region:
(output omitted )

We can use predict to obtain the predicted counts as well as the estimates of the random effects
at the nation and region levels.
. predict mu
(predictions based on fixed effects and posterior means of random effects)
(option mu assumed)
(using 7 quadrature points)
. predict re_nat re_reg, remeans
(calculating posterior means of random effects)
(using 7 quadrature points)

Stata displays a note that the predicted values of mu are based on the posterior means of random
effects. You can use option modes to obtain predictions based on the posterior modes of random
effects.
Here we list the data for the first nation in the dataset, which happens to be Belgium:
. list nation region deaths mu re_nat re_reg if nation==1, sepby(region)
nation

region

deaths

mu

re_nat

re_reg

1.

Belgium

79

64.4892

-.0819939

.2937711

2.
3.
4.
5.
6.

Belgium
Belgium
Belgium
Belgium
Belgium

2
2
2
2
2

80
51
43
89
19

77.64736
44.56528
53.10434
65.35963
35.18457

-.0819939
-.0819939
-.0819939
-.0819939
-.0819939

.024005
.024005
.024005
.024005
.024005

7.
8.
9.
10.
11.

Belgium
Belgium
Belgium
Belgium
Belgium

3
3
3
3
3

19
15
33
9
12

8.770186
43.95521
34.17878
7.332448
12.93873

-.0819939
-.0819939
-.0819939
-.0819939
-.0819939

-.3434432
-.3434432
-.3434432
-.3434432
-.3434432

We can see that the predicted random effects at the nation level, re nat, are the same for all
the observations. Similarly, the predicted random effects at the region level, re reg, are the same
within each region. The predicted counts, mu, are not as close to the observed deaths as the predicted
counts from the mixed-effects Poisson model in example 1 of [ME] mepoisson postestimation.

Methods and formulas


Methods and formulas for predicting random effects and other statistics are given in Methods and
formulas of [ME] meglm postestimation.

Also see
[ME] menbreg Multilevel mixed-effects negative binomial regression
[ME] meglm postestimation Postestimation tools for meglm
[U] 20 Estimation and postestimation commands

Title
meologit Multilevel mixed-effects ordered logistic regression
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
meologit depvar fe equation || re equation

|| re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

offset(varname)

include varname in model with coefficient constrained to 1

re options

Description

Model

covariance(vartype)
noconstant

variancecovariance structure of the random effects


suppress constant term from the random-effects equation

141

142

meologit Multilevel mixed-effects ordered logistic regression

options

Description

Model

constraints(constraints)
collinear

apply specified linear constraints


keep collinear variables

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
or
nocnsreport
notable
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


report fixed-effects coefficients as odds ratios
do not display constraints
suppress coefficient table
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with ordered logistic
regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intmethod(intmethod)
intpoints(#)

integration method
set the number of integration (quadrature) points for all levels;
default is intpoints(7)

Maximization

maximize options

control the maximization process; seldom used

startvalues(svmethod)
startgrid (gridspec)
noestimate
dnumerical
coeflegend

method for obtaining starting values


perform a grid search to improve starting values
do not fit the model; show starting values instead
use numerical derivative techniques
display legend instead of statistics

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0; the
default if the R. notation is used
all variances and covariances to be distinctly estimated
user-selected variances and covariances constrained to specified
values; the remaining variances and covariances unrestricted
user-selected variances and covariances constrained to be equal;
the remaining variances and covariances unrestricted

exchangeable
identity
unstructured
fixed(matname)
pattern(matname)

meologit Multilevel mixed-effects ordered logistic regression

intmethod

Description

mvaghermite

mean-variance adaptive GaussHermite quadrature; the default


unless a crossed random-effects model is fit
mode-curvature adaptive GaussHermite quadrature
nonadaptive GaussHermite quadrature
Laplacian approximation; the default for crossed random-effects
models

mcaghermite
ghermite
laplace

143

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
by is allowed; see [U] 11.1.10 Prefix commands.
startvalues(), startgrid, noestimate, dnumerical, and coeflegend do not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Ordered logistic regression

Description
meologit fits mixed-effects logistic models for ordered responses. The actual values taken on by
the response are irrelevant except that larger values are assumed to correspond to higher outcomes.
The conditional distribution of the response given the random effects is assumed to be multinomial,
with success probability determined by the logistic cumulative distribution function.

Options

Model

offset(varname) specifies that varname be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, unstructured, fixed(matname), or pattern(matname).
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent) unless a crossed random-effects model is fit, in which case the
default is covariance(identity).
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.
covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.
covariance(unstructured) allows for all variances and covariances to be distinct. If an equation
consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2
unique parameters.

144

meologit Multilevel mixed-effects ordered logistic regression

covariance(fixed(matname)) and covariance(pattern(matname)) covariance structures


provide a convenient way to impose constraints on variances and covariances of random effects.
Each specification requires a matname that defines the restrictions placed on variances and
covariances. Only elements in the lower triangle of matname are used, and row and column names
of matname are ignored. A missing value in matname means that a given element is unrestricted.
In a fixed(matname) covariance structure, (co)variance (i, j) is constrained to equal the
value specified in the i, j th entry of matname. In a pattern(matname) covariance structure,
(co)variances (i, j) and (k, l) are constrained to be equal if matname[i, j] = matname[k, l].
noconstant suppresses the constant (intercept) term; may be specified for any or all of the randomeffects equations.
constraints(constraints), collinear; see [R] estimation options.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.

Reporting

level(#); see [R] estimation options.


or reports estimated fixed-effects coefficients transformed to odds ratios, that is, exp() rather than .
Standard errors and confidence intervals are similarly transformed. This option affects how results
are displayed, not how they are estimated. or may be specified either at estimation or upon replay.
nocnsreport; see [R] estimation options.
notable suppresses the estimation table, either at estimation or upon replay.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents meologit from performing a likelihood-ratio test that compares the mixed-effects
ordered logistic model with standard (marginal) ordered logistic regression. This option may also
be specified upon replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

Integration

intmethod(intmethod) specifies the integration method to be used for the random-effects model.
mvaghermite performs mean and variance adaptive GaussHermite quadrature; mcaghermite
performs mode and curvature adaptive GaussHermite quadrature; ghermite performs nonadaptive
GaussHermite quadrature; and laplace performs the Laplacian approximation, equivalent to mode
curvature adaptive Gaussian quadrature with one integration point.
The default integration method is mvaghermite unless a crossed random-effects model is fit, in
which case the default integration method is laplace. The Laplacian approximation has been
known to produce biased parameter estimates; however, the bias tends to be more prominent in
the estimates of the variance components rather than in the estimates of the fixed effects.

meologit Multilevel mixed-effects ordered logistic regression

145

For crossed random-effects models, estimation with more than one quadrature point may be
prohibitively intensive even for a small number of levels. For this reason, the integration method
defaults to the Laplacian approximation. You may override this behavior by specifying a different
integration method.
intpoints(#) sets the number of integration points for quadrature. The default is intpoints(7),
which means that seven quadrature points are used for each level of random effects. This option
is not allowed with intmethod(laplace).
The more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases as a function of the number of quadrature points raised to a power
equaling the dimension of the random-effects specification. In crossed random-effects models and
in models with many levels or many random coefficients, this increase can be substantial.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for meologit are listed below.
from() accepts a properly labeled vector of initial values or a list of coefficient names with values.
A list of values is not allowed.
The following options are available with meologit but are not shown in the dialog box:
startvalues(svmethod), startgrid (gridspec) , noestimate, and dnumerical; see [ME]
meglm.
coeflegend; see [R] estimation options.

Remarks and examples


For a general introduction to me commands, see [ME] me.
meologit is a convenience command for meglm with a logit link and an ordinal family; see
[ME] meglm.
Remarks are presented under the following headings:
Introduction
Two-level models
Three-level models

Introduction
Mixed-effects ordered logistic regression is ordered logistic regression containing both fixed effects
and random effects. An ordered response is a variable that is categorical and ordered, for instance,
poor, good, and excellent, which might indicate a persons current health status or the repair
record of a car. In the absence of random effects, mixed-effects ordered logistic regression reduces
to ordered logistic regression; see [R] ologit.
Comprehensive treatments of mixed models are provided by, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and Skrondal (2012). Agresti (2010, chap. 10) and Rabe-Hesketh and Skrondal (2012, chap. 11) are good
introductory readings on applied multilevel modeling of ordinal data.

146

meologit Multilevel mixed-effects ordered logistic regression

meologit allows for many levels of nested clusters of random effects. For example, in a three-level
model you can specify random effects for schools and then random effects for classes nested within
schools. In this model, the observations (presumably, the students) comprise the first level, the classes
comprise the second level, and the schools comprise the third.
However, for simplicity, for now we consider the two-level model, where for a series of M
independent clusters, and conditional on a set of fixed effects xij , a set of cutpoints , and a set of
random effects uj , the cumulative probability of the response being in a category higher than k is
Pr(yij > k|xij , , uj ) = H(xij + zij uj k )

(1)

for j = 1, . . . , M clusters, with cluster j consisting of i = 1, . . . , nj observations. The cutpoints


are labeled 1 , 2 , . . . , K1 , where K is the number of possible outcomes. H() is the logistic
cumulative distribution function that represents cumulative probability.
The 1 p row vector xij are the covariates for the fixed effects, analogous to the covariates
you would find in a standard logistic regression model, with regression coefficients (fixed effects)
. In our parameterization, xij does not contain a constant term because its effect is absorbed into
the cutpoints. For notational convenience here and throughout this manual entry, we suppress the
dependence of yij on xij .
The 1 q vector zij are the covariates corresponding to the random effects and can be used to
represent both random intercepts and random coefficients. For example, in a random-intercept model,
zij is simply the scalar 1. The random effects uj are M realizations from a multivariate normal
distribution with mean 0 and q q variance matrix . The random effects are not directly estimated
as model parameters but are instead summarized according to the unique elements of , known
as variance components. One special case of (1) places zij = xij , so that all covariate effects are
essentially random and distributed as multivariate normal with mean and variance .
From (1), we can derive the probability of observing outcome k as

Pr(yij = k|, uj ) = Pr(k1 < xij + zij uj +


= Pr(k1 xij zij uj <

ij

k )

ij

k xij zij uj )

= H(k xij zij uj ) H(k1 xij zij uj )


where 0 is taken as and K is taken as +.
From the above, we may also write the model in terms of a latent linear response, where observed
ordinal responses yij are generated from the latent continuous responses, such that

yij
= xij + zij uj +

and

The errors

2
yij = ..

K
ij

if
if
if

ij

yij
1

1 < yij 2

K1 < yij

are distributed as logistic with mean 0 and variance 2 /3 and are independent of uj .

Model (1) is an example of a generalized linear mixed model (GLMM), which generalizes the
linear mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using
mixed and fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there

meologit Multilevel mixed-effects ordered logistic regression

147

is insight to be gained through examination of the linear mixed model. This is especially true for
Stata users because the terminology, syntax, options, and output for fitting these types of models are
nearly identical. See [ME] mixed and the references therein, particularly in the Introduction, for more
information.
Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out
the random effects. One widely used modern method is to directly estimate the integral required to
calculate the log likelihood by GaussHermite quadrature or some variation thereof. Because the log
likelihood itself is estimated, this method has the advantage of permitting likelihood-ratio tests for
comparing nested models. Also, if done correctly, quadrature approximations can be quite accurate,
thus minimizing bias.
meologit supports three types of GaussHermite quadrature and the Laplacian approximation
method; see Methods and formulas of [ME] meglm for details.
Below we present two short examples of mixed-effects ordered logistic regression; refer to
[ME] melogit for additional examples including crossed random-effects models and to [ME] me and
[ME] meglm for examples of other random-effects models.

Two-level models
We begin with a simple application of (1) as a two-level model, because a one-level model, in our
terminology, is just standard ordered logistic regression; see [R] ologit.

Example 1
We use the data from the Television, School, and Family Smoking Prevention and Cessation Project
(Flay et al. 1988; Rabe-Hesketh and Skrondal 2012, chap. 11), where schools were randomly assigned
into one of four groups defined by two treatment variables. Students within each school are nested in
classes, and classes are nested in schools. In this example, we ignore the variability of classes within
schools and fit a two-level model; we incorporate classes in a three-level model in example 2. The
dependent variable is the tobacco and health knowledge (THK) scale score collapsed into four ordered
categories. We regress the outcome on the treatment variables and their interaction and control for
the pretreatment score.

148

meologit Multilevel mixed-effects ordered logistic regression


. use http://www.stata-press.com/data/r13/tvsfpors
. meologit thk prethk cc##tv || school:
Fitting fixed-effects model:
Iteration 0:
log likelihood = -2212.775
Iteration 1:
log likelihood = -2125.509
Iteration 2:
log likelihood = -2125.1034
Iteration 3:
log likelihood = -2125.1032
Refining starting values:
Grid node 0:
log likelihood = -2136.2426
Fitting full model:
Iteration 0:
log likelihood = -2136.2426 (not concave)
Iteration 1:
log likelihood = -2120.2577
Iteration 2:
log likelihood = -2119.7574
Iteration 3:
log likelihood = -2119.7428
Iteration 4:
log likelihood = -2119.7428
Mixed-effects ologit regression
Number of obs
Group variable:
school
Number of groups
Obs per group: min
avg
max
Integration method: mvaghermite
Integration points
Wald chi2(4)
Log likelihood = -2119.7428
Prob > chi2
Coef.

prethk
1.cc
1.tv

.4032892
.9237904
.2749937

.03886
.204074
.1977424

10.38
4.53
1.39

0.000
0.000
0.164

.327125
.5238127
-.1125744

.4794534
1.323768
.6625618

cc#tv
1 1

-.4659256

.2845963

-1.64

0.102

-1.023724

.0918728

/cut1
/cut2
/cut3

-.0884493
1.153364
2.33195

.1641062
.165616
.1734199

-0.54
6.96
13.45

0.590
0.000
0.000

-.4100916
.8287625
1.992053

.233193
1.477965
2.671846

.0735112

.0383106

.0264695

.2041551

LR test vs. ologit regression:

chibar2(01) =

P>|z|

1600
28
18
57.1
137
7
128.06
0.0000

thk

school
var(_cons)

Std. Err.

=
=
=
=
=
=
=
=

[95% Conf. Interval]

10.72 Prob>=chibar2 = 0.0005

Those of you familiar with the mixed command or other me commands will recognize the syntax
and output. Below we comment on the items specific to ordered outcomes.
1. The estimation table reports the fixed effects, the estimated cutpoints (1 , 2 , 3 ), and the estimated
variance components. The fixed effects can be interpreted just as you would the output from ologit.
We find that students with higher preintervention scores tend to have higher postintervention scores.
Because of their interaction, the impact of the treatment variables on the knowledge score is not
straightforward; we defer this discussion to example 1 of [ME] meologit postestimation. You can
also specify the or option at estimation or on replay to display the fixed effects as odds ratios
instead.
2. Underneath the fixed effects and the cutpoints, the table shows the estimated variance components.
The random-effects equation is labeled school, meaning that these are random effects at the school
level. Because we have only one random effect at this level, the table shows only one variance
component. The estimate of u2 is 0.07 with standard error 0.04. The reported likelihood-ratio test

meologit Multilevel mixed-effects ordered logistic regression

149

shows that there is enough variability between schools to favor a mixed-effects ordered logistic
regression over a standard ordered logistic regression; see Distribution theory for likelihood-ratio
test in [ME] me for a discussion of likelihood-ratio testing of variance components.
We now store our estimates for later use.
. estimates store r_2

Three-level models
Two-level models extend naturally to models with three or more levels with nested random effects.
Below we continue with example 1.

Example 2
In this example, we fit a three-level model incorporating classes nested within schools as an
additional level. The fixed-effects part remains the same.

150

meologit Multilevel mixed-effects ordered logistic regression


. meologit thk prethk cc##tv ||
Fitting fixed-effects model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Refining starting values:
Grid node 0:
log likelihood =
Fitting full model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Iteration 4:
log likelihood =
Iteration 5:
log likelihood =
Iteration 6:
log likelihood =
Mixed-effects ologit regression

Group Variable

No. of
Groups

school
class

28
135

school: || class:
-2212.775
-2125.509
-2125.1034
-2125.1032
-2152.1514
-2152.1514
-2125.9213
-2120.1861
-2115.6177
-2114.5896
-2114.5881
-2114.5881

(not concave)
(not concave)

Number of obs

1600

Integration points =
Wald chi2(4)
=
Prob > chi2
=

7
124.39
0.0000

Observations per Group


Minimum
Average
Maximum
18
1

57.1
11.9

Integration method: mvaghermite


Log likelihood = -2114.5881
Std. Err.

137
28

thk

Coef.

P>|z|

[95% Conf. Interval]

prethk
1.cc
1.tv

.4085273
.8844369
.236448

.039616
.2099124
.2049065

10.31
4.21
1.15

0.000
0.000
0.249

.3308814
.4730161
-.1651614

.4861731
1.295858
.6380575

cc#tv
1 1

-.3717699

.2958887

-1.26

0.209

-.951701

.2081612

/cut1
/cut2
/cut3

-.0959459
1.177478
2.383672

.1688988
.1704946
.1786736

-0.57
6.91
13.34

0.570
0.000
0.000

-.4269815
.8433151
2.033478

.2350896
1.511642
2.733865

school
var(_cons)

.0448735

.0425387

.0069997

.2876749

school>class
var(_cons)

.1482157

.0637521

.063792

.3443674

LR test vs. ologit regression:


chi2(2) =
21.03
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Notes:
1. Our model now has two random-effects equations, separated by ||. The first is a random intercept
(constant only) at the school level (level three), and the second is a random intercept at the class
level (level two). The order in which these are specified (from left to right) is significantmeologit
assumes that class is nested within school.

meologit Multilevel mixed-effects ordered logistic regression

151

2. The information on groups is now displayed as a table, with one row for each grouping. You can
suppress this table with the nogroup or the noheader option, which will suppress the rest of the
header as well.
3. The variance-component estimates are now organized and labeled according to level. The variance
component for class is labeled school>class to emphasize that classes are nested within schools.
Compared with the two-level model from example 1, the estimate of the variance of the random
intercept at the school level dropped from 0.07 to 0.04. This is not surprising because we now use two
random components versus one random component to account for unobserved heterogeneity among
students. We can use lrtest and our stored estimation result from example 1 to see which model
provides a better fit:
. lrtest r_2 .
Likelihood-ratio test
LR chi2(1) =
10.31
(Assumption: r_2 nested in .)
Prob > chi2 =
0.0013
Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

The likelihood-ratio test favors the three-level model. For more information about the likelihood-ratio
test in the context of mixed-effects models, see Distribution theory for likelihood-ratio test in [ME] me.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left to
right as the groups go from biggest (highest level) to smallest (lowest level).

Stored results
meologit stores the following in e():
Scalars
e(N)
e(k)
e(k dv)
e(k cat)
e(k eq)
e(k eq model)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(N clust)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(ic)
e(rc)
e(converged)

number of observations
number of parameters
number of dependent variables
number of categories
number of equations in e(b)
number of equations in overall model test
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
number of clusters
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
number of iterations
return code
1 if converged, 0 otherwise

152

meologit Multilevel mixed-effects ordered logistic regression

Macros
e(cmd)
e(cmdline)
e(depvar)
e(covariates)
e(ivars)
e(model)
e(title)
e(link)
e(family)
e(clustvar)
e(offset)
e(intmethod)
e(n quad)
e(chi2type)
e(vce)
e(vcetype)
e(opt)
e(which)
e(ml method)
e(user)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)

meologit
command as typed
name of dependent variable
list of covariates
grouping variables
ologit
title in estimation output
logit
ordinal
name of cluster variable
offset
integration method
number of integration points
Wald; type of model 2
vcetype specified in vce()
title used to label Std. Err.
type of optimization
max or min; whether optimizer is to perform maximization or minimization
type of ml method
name of likelihood-evaluator program
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict

Matrices
e(b)
e(Cns)
e(ilog)
e(gradient)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
e(V modelbased)

coefficient vector
constraints matrix
iteration log (up to 20 iterations)
gradient vector
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
model-based variance

Functions
e(sample)

marks estimation sample

Methods and formulas


Without a loss of generality, consider a two-level ordered logistic model. The probability of
observing outcome k for response yij is then

pij = Pr(yij = k|, uj ) = Pr(k1 < ij + it k )


1
1
=

1 + exp(k + ij ) 1 + exp(k1 + ij )
where ij = xij + zij uj + offsetij , 0 is taken as , and K is taken as +. Here xij does
not contain a constant term because its effect is absorbed into the cutpoints.
For cluster j , j = 1, . . . , M , the conditional distribution of yj = (yj1 , . . . , yjnj ) given a set of
cluster-level random effects uj is

meologit Multilevel mixed-effects ordered logistic regression

153

nj
I (yij )

pijk

f (yj |, uj ) =
i=1

nj

= exp

Ik (yij ) log(pij )
i=1

where

Ik (yij ) =

1 if yij = k
0 otherwise

Because the prior distribution of uj is multivariate normal with mean 0 and q q variance matrix
, the likelihood contribution for the j th cluster is obtained by integrating uj out of the joint density
f (yj , uj ),
1/2

f (yj |, uj ) exp uj 1 uj /2 duj

1/2

exp {g (, , , uj )} duj

Lj (, , ) = (2)q/2 ||

(2)
= (2)q/2 ||
where

nj

Ik (yij ) log(pij ) uj 1 uj /2

g (, , , uj ) =
i=1

and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , rj , Xj , Zj ).
The integration in (2) has no closed form and thus must be approximated. meologit offers
four approximation methods: meanvariance adaptive GaussHermite quadrature (default unless a
crossed random-effects model is fit), mode-curvature adaptive GaussHermite quadrature, nonadaptive
GaussHermite quadrature, and Laplacian approximation (default for crossed random-effects models).
The Laplacian approximation is based on a second-order Taylor expansion of g (, , , uj ) about
the value of uj that maximizes it; see Methods and formulas in [ME] meglm for details.
Gaussian quadrature relies on transforming the multivariate integral in (2) into a set of nested
univariate integrals. Each univariate integral can then be evaluated using a form of Gaussian quadrature;
see Methods and formulas in [ME] meglm for details.
The log likelihood for the entire dataset is simply the sum of the contributions of the M individual
M
clusters, namely, L(, , ) = j=1 Lj (, , ).
Maximization of L(, , ) is performed with respect to (, , 2 ), where 2 is a vector comprising
the unique elements of . Parameter estimates are stored in e(b) as (, , 2 ), with the corresponding
variancecovariance matrix stored in e(V).

References
Agresti, A. 2010. Analysis of Ordinal Categorical Data. 2nd ed. Hoboken, NJ: Wiley.
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.
Flay, B. R., B. R. Brannon, C. A. Johnson, W. B. Hansen, A. L. Ulene, D. A. Whitney-Saltiel, L. R. Gleason,
S. Sussman, M. D. Gavin, K. M. Glowacz, D. F. Sobol, and D. C. Spiegel. 1988. The television, school, and family
smoking cessation and prevention project: I. Theoretical basis and program development. Preventive Medicine 17:
585607.

154

meologit Multilevel mixed-effects ordered logistic regression

Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.

Also see
[ME] meologit postestimation Postestimation tools for meologit
[ME] meoprobit Multilevel mixed-effects ordered probit regression
[ME] me Introduction to multilevel mixed-effects models
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtologit Random-effects ordered logistic models
[U] 20 Estimation and postestimation commands

Title
meologit postestimation Postestimation tools for meologit
Description
Options for predict
Remarks and examples

Syntax for predict


Syntax for estat group
Methods and formulas

Menu for predict


Menu for estat
Also see

Description
The following postestimation command is of special interest after meologit:
Command

Description

estat group

summarize the composition of the nested groups

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
155

156

meologit postestimation Postestimation tools for meologit

Syntax for predict


Syntax for obtaining predictions of random effects and their standard errors
predict

type

newvarsspec

if

in ,

remeans | remodes

reses(newvarsspec)

Syntax for obtaining other predictions


predict

type

newvarsspec

if

in

, statistic options

newvarsspec is stub* or newvarlist.


Description

statistic
Main

predicted probabilities; the default


fitted linear predictor
linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction

pr
fitted
xb
stdp

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

Description

options
Main

means
modes
nooffset
fixedonly
outcome(outcome)

compute statistic using empirical Bayes means; the default


compute statistic using empirical Bayes modes
ignore the offset variable in calculating predictions; relevant only
if you specified offset() when you fit the model
prediction for the fixed portion of the model only
outcome category for predicted probabilities

Integration

intpoints(#)
iterate(#)
tolerance(#)

use # quadrature points to compute empirical Bayes means


set maximum number of iterations in computing statistics involving
empirical Bayes estimators
set convergence tolerance for computing statistics involving empirical
Bayes estimators

You specify one or k new variables in newvarlist with pr, where k is the number of outcomes. If you
do not specify outcome(), those options assume outcome(#1).

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

meologit postestimation Postestimation tools for meologit

157

Options for predict

Main

remeans, remodes, reses(); see [ME] meglm postestimation.


pr, the default, calculates the predicted probabilities. By default, the probabilities are based on a
linear predictor that includes both the fixed effects and the random effects, and the predicted
probabilities are conditional on the values of the random effects. Use the fixedonly option if
you want predictions that include only the fixed portion of the model, that is, if you want random
effects set to 0.
You specify one or k new variables, where k is the number of categories of the dependent variable.
If you specify the outcome() option, the probabilities will be predicted for the requested outcome
only, in which case you specify only one new variable. If you specify one new variable and do
not specify outcome(), outcome(#1) is assumed.
fitted, xb, stdp, means, modes, nooffset, fixedonly; see [ME] meglm postestimation.
By default or if the means option is specified, statistics pr, fitted, xb, and stdp are based on
the posterior mean estimates of random effects. If the modes option is specified, these statistics
are based on the posterior mode estimates of random effects.
outcome(outcome) specifies the outcome for which the predicted probabilities are to be calculated.
outcome() should contain either one value of the dependent variable or one of #1, #2, . . . , with
#1 meaning the first category of the dependent variable, #2 meaning the second category, etc.

Integration

intpoints(), iterate(), tolerance(); see [ME] meglm postestimation.

Syntax for estat group


estat group

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting an ordered logistic
mixed-effects model with meologit. Here we show a short example of predicted probabilities and
predicted random effects; refer to [ME] meglm postestimation for additional examples applicable to
mixed-effects generalized linear models.

158

meologit postestimation Postestimation tools for meologit

Example 1
In example 2 of [ME] meologit, we modeled the tobacco and health knowledge (thk) scorecoded
1, 2, 3, 4among students as a function of two treatments (cc and tv) by using a three-level ordered
logistic model with random effects at the school and class levels.
. use http://www.stata-press.com/data/r13/tvsfpors
. meologit thk prethk cc##tv || school: || class:
(output omitted )

We obtain predicted probabilities for all four outcomes based on the contribution of both fixed
effects and random effects by typing
. predict pr*
(predictions based on fixed effects and posterior means of random effects)
(option mu assumed)
(using 7 quadrature points)

As the note says, the predicted values are based on the posterior means of random effects. You can
use the modes option to obtain predictions based on the posterior modes of random effects.
Because we specified a stub name, Stata saved the predicted random effects in variables pr1
through pr4. Here we list the predicted probabilities for the first two classes for school 515:
. list class thk pr? if school==515 & (class==515101 | class==515102),
> sepby(class)
class

thk

pr1

pr2

pr3

pr4

1464.
1465.
1466.
1467.
1468.
1469.

515101
515101
515101
515101
515101
515101

2
2
1
4
3
3

.1485538
.372757
.372757
.2831409
.2079277
.2831409

.2354556
.3070787
.3070787
.3021398
.2760683
.3021398

.2915916
.1966117
.1966117
.2397316
.2740791
.2397316

.3243991
.1235526
.1235526
.1749877
.2419248
.1749877

1470.
1471.
1472.
1473.
1474.
1475.
1476.

515102
515102
515102
515102
515102
515102
515102

1
2
2
2
2
1
2

.3251654
.4202843
.4202843
.4202843
.3251654
.4202843
.3251654

.3074122
.3011963
.3011963
.3011963
.3074122
.3011963
.3074122

.2193101
.1749344
.1749344
.1749344
.2193101
.1749344
.2193101

.1481123
.103585
.103585
.103585
.1481123
.103585
.1481123

For each observation, our best guess for the predicted outcome is the one with the highest predicted
probability. For example, for the very first observation in the table above, we would choose outcome 4
as the most likely to occur.
We obtain predictions of the posterior means themselves at the school and class levels by typing
. predict re_s re_c, remeans
(calculating posterior means of random effects)
(using 7 quadrature points)

meologit postestimation Postestimation tools for meologit

159

Here we list the predicted random effects for the first two classes for school 515:
. list class re_s re_c if school==515 & (class==515101 | class==515102),
> sepby(class)
class

re_s

re_c

1464.
1465.
1466.
1467.
1468.
1469.

515101
515101
515101
515101
515101
515101

-.0473739
-.0473739
-.0473739
-.0473739
-.0473739
-.0473739

.0633081
.0633081
.0633081
.0633081
.0633081
.0633081

1470.
1471.
1472.
1473.
1474.
1475.
1476.

515102
515102
515102
515102
515102
515102
515102

-.0473739
-.0473739
-.0473739
-.0473739
-.0473739
-.0473739
-.0473739

-.1354929
-.1354929
-.1354929
-.1354929
-.1354929
-.1354929
-.1354929

We can see that the predicted random effects at the school level (re s) are the same for all classes
and that the predicted random effects at the class level (re c) are constant within each class.

Methods and formulas


Methods and formulas for predicting random effects and other statistics are given in Methods and
formulas of [ME] meglm postestimation.

Also see
[ME] meologit Multilevel mixed-effects ordered logistic regression
[ME] meglm postestimation Postestimation tools for meglm
[U] 20 Estimation and postestimation commands

Title
meoprobit Multilevel mixed-effects ordered probit regression
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
meoprobit depvar fe equation || re equation

|| re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

offset(varname)

include varname in model with coefficient constrained to 1

re options

Description

Model

covariance(vartype)
noconstant

variancecovariance structure of the random effects


suppress constant term from the random-effects equation

160

meoprobit Multilevel mixed-effects ordered probit regression

options

161

Description

Model

constraints(constraints)
collinear

apply specified linear constraints


keep collinear variables

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
nocnsreport
notable
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


do not display constraints
suppress coefficient table
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with ordered probit
regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intmethod(intmethod)
intpoints(#)

integration method
set the number of integration (quadrature) points for all levels;
default is intpoints(7)

Maximization

maximize options

control the maximization process; seldom used

startvalues(svmethod)
startgrid (gridspec)
noestimate
dnumerical
coeflegend

method for obtaining starting values


perform a grid search to improve starting values
do not fit the model; show starting values instead
use numerical derivative techniques
display legend instead of statistics

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0; the
default if the R. notation is used
all variances and covariances to be distinctly estimated
user-selected variances and covariances constrained to specified
values; the remaining variances and covariances unrestricted
user-selected variances and covariances constrained to be equal;
the remaining variances and covariances unrestricted

exchangeable
identity
unstructured
fixed(matname)
pattern(matname)

162

meoprobit Multilevel mixed-effects ordered probit regression

intmethod

Description

mvaghermite

mean-variance adaptive GaussHermite quadrature; the default


unless a crossed random-effects model is fit
mode-curvature adaptive GaussHermite quadrature
nonadaptive GaussHermite quadrature
Laplacian approximation; the default for crossed random-effects
models

mcaghermite
ghermite
laplace

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
by is allowed; see [U] 11.1.10 Prefix commands.
startvalues(), startgrid, noestimate, dnumerical, and coeflegend do not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Ordered probit regression

Description
meoprobit fits mixed-effects probit models for ordered responses. The actual values taken on by
the response are irrelevant except that larger values are assumed to correspond to higher outcomes.
The conditional distribution of the response given the random effects is assumed to be multinomial,
with success probability determined by the standard normal cumulative distribution function.

Options

Model

offset(varname) specifies that varname be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, unstructured, fixed(matname), or pattern(matname).
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent) unless a crossed random-effects model is fit, in which case the
default is covariance(identity).
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.
covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.
covariance(unstructured) allows for all variances and covariances to be distinct. If an equation
consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2
unique parameters.

meoprobit Multilevel mixed-effects ordered probit regression

163

covariance(fixed(matname)) and covariance(pattern(matname)) covariance structures


provide a convenient way to impose constraints on variances and covariances of random effects.
Each specification requires a matname that defines the restrictions placed on variances and
covariances. Only elements in the lower triangle of matname are used, and row and column names
of matname are ignored. A missing value in matname means that a given element is unrestricted.
In a fixed(matname) covariance structure, (co)variance (i, j) is constrained to equal the
value specified in the i, j th entry of matname. In a pattern(matname) covariance structure,
(co)variances (i, j) and (k, l) are constrained to be equal if matname[i, j] = matname[k, l].
noconstant suppresses the constant (intercept) term; may be specified for any or all of the randomeffects equations.
constraints(constraints), collinear; see [R] estimation options.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.

Reporting

level(#), nocnsreport; see [R] estimation options.


notable suppresses the estimation table, either at estimation or upon replay.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents meoprobit from performing a likelihood-ratio test that compares the mixed-effects
ordered probit model with standard (marginal) ordered probit regression. This option may also be
specified upon replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

Integration

intmethod(intmethod) specifies the integration method to be used for the random-effects model.
mvaghermite performs mean and variance adaptive GaussHermite quadrature; mcaghermite
performs mode and curvature adaptive GaussHermite quadrature; ghermite performs nonadaptive
GaussHermite quadrature; and laplace performs the Laplacian approximation, equivalent to mode
curvature adaptive Gaussian quadrature with one integration point.
The default integration method is mvaghermite unless a crossed random-effects model is fit, in
which case the default integration method is laplace. The Laplacian approximation has been
known to produce biased parameter estimates; however, the bias tends to be more prominent in
the estimates of the variance components rather than in the estimates of the fixed effects.
For crossed random-effects models, estimation with more than one quadrature point may be
prohibitively intensive even for a small number of levels. For this reason, the integration method
defaults to the Laplacian approximation. You may override this behavior by specifying a different
integration method.

164

meoprobit Multilevel mixed-effects ordered probit regression

intpoints(#) sets the number of integration points for quadrature. The default is intpoints(7),
which means that seven quadrature points are used for each level of random effects. This option
is not allowed with intmethod(laplace).
The more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases as a function of the number of quadrature points raised to a power
equaling the dimension of the random-effects specification. In crossed random-effects models and
in models with many levels or many random coefficients, this increase can be substantial.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for meoprobit are listed below.
from() accepts a properly labeled vector of initial values or a list of coefficient names with values.
A list of values is not allowed.
The following options are available with meoprobit but are not shown in the dialog box:
startvalues(svmethod), startgrid (gridspec) , noestimate, and dnumerical; see [ME]
meglm.
coeflegend; see [R] estimation options.

Remarks and examples


For a general introduction to me commands, see [ME] me.
meoprobit is a convenience command for meglm with a probit link and an ordinal family;
see [ME] meglm.
Remarks are presented under the following headings:
Introduction
Two-level models
Three-level models

Introduction
Mixed-effects ordered probit regression is ordered probit regression containing both fixed effects
and random effects. An ordered response is a variable that is categorical and ordered, for instance,
poor, good, and excellent, which might indicate a persons current health status or the repair
record of a car. In the absence of random effects, mixed-effects ordered probit regression reduces to
ordered probit regression; see [R] oprobit.
Comprehensive treatments of mixed models are provided by, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and Skrondal (2012). Agresti (2010, chap. 10) and Rabe-Hesketh and Skrondal (2012, chap. 11) are good
introductory readings on applied multilevel modeling of ordinal data.
meoprobit allows for many levels of nested clusters of random effects. For example, in a threelevel model you can specify random effects for schools and then random effects for classes nested
within schools. In this model, the observations (presumably, the students) comprise the first level, the
classes comprise the second level, and the schools comprise the third.

meoprobit Multilevel mixed-effects ordered probit regression

165

However, for simplicity, for now we consider the two-level model, where for a series of M
independent clusters, and conditional on a set of fixed effects xij , a set of cutpoints , and a set of
random effects uj , the cumulative probability of the response being in a category higher than k is
Pr(yij > k|xij , , uj ) = (xij + zij uj k )

(1)

for j = 1, . . . , M clusters, with cluster j consisting of i = 1, . . . , nj observations. The cutpoints


are labeled 1 , 2 , . . . , K1 , where K is the number of possible outcomes. () is the standard
normal cumulative distribution function that represents cumulative probability.
The 1 p row vector xij are the covariates for the fixed effects, analogous to the covariates you
would find in a standard probit regression model, with regression coefficients (fixed effects) . In our
parameterization, xij does not contain a constant term because its effect is absorbed into the cutpoints.
For notational convenience here and throughout this manual entry, we suppress the dependence of
yij on xij .
The 1 q vector zij are the covariates corresponding to the random effects and can be used to
represent both random intercepts and random coefficients. For example, in a random-intercept model,
zij is simply the scalar 1. The random effects uj are M realizations from a multivariate normal
distribution with mean 0 and q q variance matrix . The random effects are not directly estimated
as model parameters but are instead summarized according to the unique elements of , known
as variance components. One special case of (1) places zij = xij so that all covariate effects are
essentially random and distributed as multivariate normal with mean and variance .
From (1), we can derive the probability of observing outcome k as

Pr(yij = k|, uj ) = Pr(k1 < xij + zij uj +


= Pr(k1 xij zij uj <

ij

k )

ij

k xij zij uj )

= (k xij zij uj ) (k1 xij zij uj )


where 0 is taken as and K is taken as +.
From the above, we may also write the model in terms of a latent linear response, where observed
ordinal responses yij are generated from the latent continuous responses, such that

yij
= xij + zij uj +

and

The errors
uj .

2
yij = ..

K
ij

if
if
if

ij

yij
1

1 < yij 2

K1 < yij

are distributed as standard normal with mean 0 and variance 1 and are independent of

Model (1) is an example of a generalized linear mixed model (GLMM), which generalizes the
linear mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using
mixed and fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there
is insight to be gained through examination of the linear mixed model. This is especially true for
Stata users because the terminology, syntax, options, and output for fitting these types of models are
nearly identical. See [ME] mixed and the references therein, particularly in the Introduction, for more
information.

166

meoprobit Multilevel mixed-effects ordered probit regression

Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out
the random effects. One widely used modern method is to directly estimate the integral required to
calculate the log likelihood by GaussHermite quadrature or some variation thereof. Because the log
likelihood itself is estimated, this method has the advantage of permitting likelihood-ratio tests for
comparing nested models. Also, if done correctly, quadrature approximations can be quite accurate,
thus minimizing bias.
meoprobit supports three types of GaussHermite quadrature and the Laplacian approximation
method; see Methods and formulas of [ME] meglm for details.
Below we present two short examples of mixed-effects ordered probit regression; refer to [ME] melogit for additional examples including crossed random-effects models and to [ME] me and [ME] meglm
for examples of other random-effects models.

Two-level models
We begin with a simple application of (1) as a two-level model, because a one-level model, in our
terminology, is just standard ordered probit regression; see [R] oprobit.

Example 1
We use the data from the Television, School, and Family Smoking Prevention and Cessation Project
(Flay et al. 1988; Rabe-Hesketh and Skrondal 2012, chap. 11), where schools were randomly assigned
into one of four groups defined by two treatment variables. Students within each school are nested in
classes, and classes are nested in schools. In this example, we ignore the variability of classes within
schools and fit a two-level model; we incorporate classes in a three-level model in example 2. The
dependent variable is the tobacco and health knowledge (THK) scale score collapsed into four ordered
categories. We regress the outcome on the treatment variables and their interaction and control for
the pretreatment score.

meoprobit Multilevel mixed-effects ordered probit regression

167

. use http://www.stata-press.com/data/r13/tvsfpors
. meoprobit thk prethk cc##tv || school:
Fitting fixed-effects model:
Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:

log
log
log
log

likelihood
likelihood
likelihood
likelihood

= -2212.775
= -2127.8111
= -2127.7612
= -2127.7612

Refining starting values:


Grid node 0:

log likelihood = -2149.7302

Fitting full model:


Iteration
Iteration
Iteration
Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:
4:
5:
6:

log
log
log
log
log
log
log

likelihood
likelihood
likelihood
likelihood
likelihood
likelihood
likelihood

=
=
=
=
=
=
=

-2149.7302
-2129.6838
-2123.5143
-2122.2896
-2121.7949
-2121.7716
-2121.7715

(not concave)
(not concave)

Mixed-effects oprobit regression


Group variable:
school

Number of obs
Number of groups

=
=

1600
28

Obs per group: min =


avg =
max =

18
57.1
137

Integration method: mvaghermite

Integration points =

Log likelihood = -2121.7715

Wald chi2(4)
Prob > chi2

Coef.

prethk
1.cc
1.tv

.2369804
.5490957
.1695405

.0227739
.1255108
.1215889

10.41
4.37
1.39

0.000
0.000
0.163

.1923444
.303099
-.0687693

.2816164
.7950923
.4078504

cc#tv
1 1

-.2951837

.1751969

-1.68

0.092

-.6385634

.0481959

/cut1
/cut2
/cut3

-.0682011
.67681
1.390649

.1003374
.1008836
.1037494

-0.68
6.71
13.40

0.497
0.000
0.000

-.2648587
.4790817
1.187304

.1284565
.8745382
1.593995

.0288527

.0146201

.0106874

.0778937

LR test vs. oprobit regression:

chibar2(01) =

P>|z|

7
128.05
0.0000

thk

school
var(_cons)

Std. Err.

=
=

[95% Conf. Interval]

11.98 Prob>=chibar2 = 0.0003

Those of you familiar with the mixed command or other me commands will recognize the syntax
and output. Below we comment on the items specific to ordered outcomes.
1. The estimation table reports the fixed effects, the estimated cutpoints (1 , 2 , 3 ), and the
estimated variance components. The fixed effects can be interpreted just as you would the output
from oprobit. We find that students with higher preintervention scores tend to have higher
postintervention scores. Because of their interaction, the impact of the treatment variables on the
knowledge score is not straightforward; we defer this discussion to example 1 of [ME] meoprobit
postestimation.
2. Underneath the fixed effects and the cutpoints, the table shows the estimated variance components.
The random-effects equation is labeled school, meaning that these are random effects at the school
level. Because we have only one random effect at this level, the table shows only one variance

168

meoprobit Multilevel mixed-effects ordered probit regression

component. The estimate of u2 is 0.03 with standard error 0.01. The reported likelihood-ratio test
shows that there is enough variability between schools to favor a mixed-effects ordered probit
regression over a standard ordered probit regression; see Distribution theory for likelihood-ratio
test in [ME] me for a discussion of likelihood-ratio testing of variance components.
We now store our estimates for later use.
. estimates store r_2

Three-level models
Two-level models extend naturally to models with three or more levels with nested random effects.
Below we continue with example 1.

Example 2
In this example, we fit a three-level model incorporating classes nested within schools as an
additional level. The fixed-effects part remains the same.

meoprobit Multilevel mixed-effects ordered probit regression

169

. meoprobit thk prethk cc##tv || school: || class:


Fitting fixed-effects model:
Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:

log
log
log
log

likelihood
likelihood
likelihood
likelihood

= -2212.775
= -2127.8111
= -2127.7612
= -2127.7612

Refining starting values:


Grid node 0:

log likelihood = -2195.6424

Fitting full model:


Iteration
Iteration
Iteration
Iteration
Iteration
Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:
4:
5:
6:
7:
8:

log
log
log
log
log
log
log
log
log

likelihood
likelihood
likelihood
likelihood
likelihood
likelihood
likelihood
likelihood
likelihood

=
=
=
=
=
=
=
=
=

-2195.6424
-2167.9576
-2140.2644
-2128.6948
-2119.9225
-2117.0947
-2116.7004
-2116.6981
-2116.6981

(not
(not
(not
(not

Mixed-effects oprobit regression

Group Variable

No. of
Groups

school
class

28
135

concave)
concave)
concave)
concave)

Number of obs

1600

Observations per Group


Minimum
Average
Maximum
18
1

57.1
11.9

137
28

Integration method: mvaghermite

Integration points =

Log likelihood = -2116.6981

Wald chi2(4)
Prob > chi2
Std. Err.

Coef.

prethk
1.cc
1.tv

.238841
.5254813
.1455573

.0231446
.1285816
.1255827

10.32
4.09
1.16

0.000
0.000
0.246

.1934784
.2734659
-.1005803

.2842036
.7774967
.3916949

cc#tv
1 1

-.2426203

.1811999

-1.34

0.181

-.5977656

.1125251

/cut1
/cut2
/cut3

-.074617
.6863046
1.413686

.1029791
.1034813
.1064889

-0.72
6.63
13.28

0.469
0.000
0.000

-.2764523
.4834849
1.204972

.1272184
.8891242
1.622401

school
var(_cons)

.0186456

.0160226

.0034604

.1004695

school>class
var(_cons)

.0519974

.0224014

.0223496

.1209745

chi2(2) =

P>|z|

7
124.20
0.0000

thk

LR test vs. oprobit regression:

=
=

22.13

[95% Conf. Interval]

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.

Notes:
1. Our model now has two random-effects equations, separated by ||. The first is a random intercept
(constant only) at the school level (level three), and the second is a random intercept at the
class level (level two). The order in which these are specified (from left to right) is significant
meoprobit assumes that class is nested within school.

170

meoprobit Multilevel mixed-effects ordered probit regression

2. The information on groups is now displayed as a table, with one row for each grouping. You can
suppress this table with the nogroup or the noheader option, which will suppress the rest of the
header as well.
3. The variance-component estimates are now organized and labeled according to level. The variance
component for class is labeled school>class to emphasize that classes are nested within schools.
Compared with the two-level model from example 1, the estimate of the random intercept at the
school level dropped from 0.03 to 0.02. This is not surprising because we now use two random
components versus one random component to account for unobserved heterogeneity among students.
We can use lrtest and our stored estimation result from example 1 to see which model provides a
better fit:
. lrtest r_2 .
Likelihood-ratio test
LR chi2(1) =
10.15
(Assumption: r_2 nested in .)
Prob > chi2 =
0.0014
Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

The likelihood-ratio test favors the three-level model. For more information about the likelihoodratio test in the context of mixed-effects models, see Distribution theory for likelihood-ratio test in
[ME] me.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left to
right as the groups go from biggest (highest level) to smallest (lowest level).

Stored results
meoprobit stores the following in e():
Scalars
e(N)
e(k)
e(k dv)
e(k cat)
e(k eq)
e(k eq model)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(N clust)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(ic)
e(rc)
e(converged)

number of observations
number of parameters
number of dependent variables
number of categories
number of equations in e(b)
number of equations in overall model test
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
number of clusters
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
number of iterations
return code
1 if converged, 0 otherwise

meoprobit Multilevel mixed-effects ordered probit regression


Macros
e(cmd)
e(cmdline)
e(depvar)
e(covariates)
e(ivars)
e(model)
e(title)
e(link)
e(family)
e(clustvar)
e(offset)
e(intmethod)
e(n quad)
e(chi2type)
e(vce)
e(vcetype)
e(opt)
e(which)
e(ml method)
e(user)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)

meoprobit
command as typed
name of dependent variable
list of covariates
grouping variables
oprobit
title in estimation output
probit
ordinal
name of cluster variable
offset
integration method
number of integration points
Wald; type of model 2
vcetype specified in vce()
title used to label Std. Err.
type of optimization
max or min; whether optimizer is to perform maximization or minimization
type of ml method
name of likelihood-evaluator program
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict

Matrices
e(b)
e(Cns)
e(ilog)
e(gradient)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
e(V modelbased)

coefficient vector
constraints matrix
iteration log (up to 20 iterations)
gradient vector
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
model-based variance

Functions
e(sample)

marks estimation sample

171

Methods and formulas


Without a loss of generality, consider a two-level ordered probit model. The probability of observing
outcome k for response yij is then

pij = Pr(yij = k|, uj ) = Pr(k1 < ij +

it

k )

= (k ij ) (k1 ij )
where ij = xij + zij uj + offsetij , 0 is taken as , and K is taken as +. Here xij does
not contain a constant term because its effect is absorbed into the cutpoints.
For cluster j , j = 1, . . . , M , the conditional distribution of yj = (yj1 , . . . , yjnj ) given a set of
cluster-level random effects uj is

172

meoprobit Multilevel mixed-effects ordered probit regression


nj
I (yij )

pijk

f (yj |uj ) =
i=1

nj

= exp

Ik (yij ) log(pij )
i=1

where

Ik (yij ) =

1 if yij = k
0 otherwise

Because the prior distribution of uj is multivariate normal with mean 0 and q q variance matrix
, the likelihood contribution for the j th cluster is obtained by integrating uj out of the joint density
f (yj , uj ),
1/2

Lj (, , ) = (2)q/2 ||

f (yj |, uj ) exp uj 1 uj /2 duj


(2)

q/2

= (2)

1/2

||

where

exp {g (, , , uj )} duj

nj

Ik (yij ) log(pij ) uj 1 uj /2

g (, , , uj ) =
i=1

and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , rj , Xj , Zj ).
The integration in (2) has no closed form and thus must be approximated. meoprobit offers
four approximation methods: meanvariance adaptive GaussHermite quadrature (default unless a
crossed random-effects model is fit), mode-curvature adaptive GaussHermite quadrature, nonadaptive
GaussHermite quadrature, and Laplacian approximation (default for crossed random-effects models).
The Laplacian approximation is based on a second-order Taylor expansion of g (, , , uj ) about
the value of uj that maximizes it; see Methods and formulas in [ME] meglm for details.
Gaussian quadrature relies on transforming the multivariate integral in (2) into a set of nested
univariate integrals. Each univariate integral can then be evaluated using a form of Gaussian quadrature;
see Methods and formulas in [ME] meglm for details.
The log likelihood for the entire dataset is simply the sum of the contributions of the M individual
M
clusters, namely, L(, , ) = j=1 Lj (, , ).
Maximization of L(, , ) is performed with respect to (, , 2 ), where 2 is a vector comprising
the unique elements of . Parameter estimates are stored in e(b) as (, , 2 ), with the corresponding
variancecovariance matrix stored in e(V).

References
Agresti, A. 2010. Analysis of Ordinal Categorical Data. 2nd ed. Hoboken, NJ: Wiley.
Andrews, M. J., T. Schank, and R. Upward. 2006. Practical fixed-effects estimation methods for the three-way
error-components model. Stata Journal 6: 461481.
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.

meoprobit Multilevel mixed-effects ordered probit regression

173

Flay, B. R., B. R. Brannon, C. A. Johnson, W. B. Hansen, A. L. Ulene, D. A. Whitney-Saltiel, L. R. Gleason,


S. Sussman, M. D. Gavin, K. M. Glowacz, D. F. Sobol, and D. C. Spiegel. 1988. The television, school, and family
smoking cessation and prevention project: I. Theoretical basis and program development. Preventive Medicine 17:
585607.
Gutierrez, R. G., S. L. Carter, and D. M. Drukker. 2001. sg160: On boundary-value likelihood-ratio tests. Stata
Technical Bulletin 60: 1518. Reprinted in Stata Technical Bulletin Reprints, vol. 10, pp. 269273. College Station,
TX: Stata Press.
Harbord, R. M., and P. Whiting. 2009. metandi: Meta-analysis of diagnostic accuracy using hierarchical logistic
regression. Stata Journal 9: 211229.
Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.
Joe, H. 2008. Accuracy of Laplace approximation for discrete response mixed models. Computational Statistics &
Data Analysis 52: 50665074.
Laird, N. M., and J. H. Ware. 1982. Random-effects models for longitudinal data. Biometrics 38: 963974.
Lin, X., and N. E. Breslow. 1996. Bias correction in generalized linear mixed models with multiple components of
dispersion. Journal of the American Statistical Association 91: 10071016.
Marchenko, Y. V. 2006. Estimating variance components in Stata. Stata Journal 6: 121.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
McLachlan, G. J., and K. E. Basford. 1988. Mixture Models. New York: Dekker.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Self, S. G., and K.-Y. Liang. 1987. Asymptotic properties of maximum likelihood estimators and likelihood ratio tests
under nonstandard conditions. Journal of the American Statistical Association 82: 605610.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.

Also see
[ME] meoprobit postestimation Postestimation tools for meoprobit
[ME] meologit Multilevel mixed-effects ordered logistic regression
[ME] me Introduction to multilevel mixed-effects models
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtoprobit Random-effects ordered probit models
[U] 20 Estimation and postestimation commands

Title
meoprobit postestimation Postestimation tools for meoprobit
Description
Options for predict
Remarks and examples

Syntax for predict


Syntax for estat group
Methods and formulas

Menu for predict


Menu for estat
Also see

Description
The following postestimation command is of special interest after meoprobit:
Command

Description

estat group

summarize the composition of the nested groups

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
174

meoprobit postestimation Postestimation tools for meoprobit

175

Syntax for predict


Syntax for obtaining predictions of random effects and their standard errors
predict

type

newvarsspec

if

in ,

remeans | remodes

reses(newvarsspec)

Syntax for obtaining other predictions


predict

type

newvarsspec

if

in

, statistic options

newvarsspec is stub* or newvarlist.


Description

statistic
Main

predicted probabilities; the default


fitted linear predictor
linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction

pr
fitted
xb
stdp

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

Description

options
Main

means
modes
nooffset
fixedonly
outcome(outcome)

compute statistic using empirical Bayes means; the default


compute statistic using empirical Bayes modes
ignore the offset variable in calculating predictions; relevant only
if you specified offset() when you fit the model
prediction for the fixed portion of the model only
outcome category for predicted probabilities

Integration

intpoints(#)
iterate(#)
tolerance(#)

use # quadrature points to compute empirical Bayes means


set maximum number of iterations in computing statistics involving
empirical Bayes estimators
set convergence tolerance for computing statistics involving empirical
Bayes estimators

You specify one or k new variables in newvarlist with pr, where k is the number of outcomes. If you
do not specify outcome(), those options assume outcome(#1).

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

176

meoprobit postestimation Postestimation tools for meoprobit

Options for predict

Main

remeans, remodes, reses(); see [ME] meglm postestimation.


pr, the default, calculates the predicted probabilities. By default, the probabilities are based on a
linear predictor that includes both the fixed effects and the random effects, and the predicted
probabilities are conditional on the values of the random effects. Use the fixedonly option if
you want predictions that include only the fixed portion of the model, that is, if you want random
effects set to 0.
You specify one or k new variables, where k is the number of categories of the dependent variable.
If you specify the outcome() option, the probabilities will be predicted for the requested outcome
only, in which case you specify only one new variable. If you specify one new variable and do
not specify outcome(), outcome(#1) is assumed.
fitted, xb, stdp, means, modes, nooffset, fixedonly; see [ME] meglm postestimation.
By default or if the means option is specified, statistics pr, fitted, xb, and stdp are based on
the posterior mean estimates of random effects. If the modes option is specified, these statistics
are based on the posterior mode estimates of random effects.
outcome(outcome) specifies the outcome for which the predicted probabilities are to be calculated.
outcome() should contain either one value of the dependent variable or one of #1, #2, . . . , with
#1 meaning the first category of the dependent variable, #2 meaning the second category, etc.

Integration

intpoints(), iterate(), tolerance(); see [ME] meglm postestimation.

Syntax for estat group


estat group

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting an ordered probit
mixed-effects model using meoprobit. Here we show a short example of predicted probabilities and
predicted random effects; refer to [ME] meglm postestimation for additional examples applicable to
mixed-effects generalized linear models.

meoprobit postestimation Postestimation tools for meoprobit

177

Example 1
In example 2 of [ME] meoprobit, we modeled the tobacco and health knowledge (thk) score
coded 1, 2, 3, 4among students as a function of two treatments (cc and tv) using a three-level
ordered probit model with random effects at the school and class levels.
. use http://www.stata-press.com/data/r13/tvsfpors
. meoprobit thk prethk cc##tv || school: || class:
(output omitted )

We obtain predicted probabilities for all four outcomes based on the contribution of both fixed
effects and random effects by typing
. predict pr*
(predictions based on fixed effects and posterior means of random effects)
(option mu assumed)
(using 7 quadrature points)

As the note says, the predicted values are based on the posterior means of random effects. You can
use the modes option to obtain predictions based on the posterior modes of random effects.
Because we specified a stub name, Stata saved the predicted random effects in variables pr1
through pr4. Here we list the predicted probabilities for the first two classes for school 515:
. list class thk pr? if school==515 & (class==515101 | class==515102),
> sepby(class)
class

thk

pr1

pr2

pr3

pr4

1464.
1465.
1466.
1467.
1468.
1469.

515101
515101
515101
515101
515101
515101

2
2
1
4
3
3

.1503512
.3750887
.3750887
.2886795
.2129906
.2886795

.2416885
.2958534
.2958534
.2920168
.2729831
.2920168

.2828209
.2080368
.2080368
.2433916
.2696254
.2433916

.3251394
.121021
.121021
.1759121
.2444009
.1759121

1470.
1471.
1472.
1473.
1474.
1475.
1476.

515102
515102
515102
515102
515102
515102
515102

1
2
2
2
2
1
2

.3318574
.4223251
.4223251
.4223251
.3318574
.4223251
.3318574

.2959802
.2916287
.2916287
.2916287
.2959802
.2916287
.2959802

.2261095
.187929
.187929
.187929
.2261095
.187929
.2261095

.1460529
.0981172
.0981172
.0981172
.1460529
.0981172
.1460529

For each observation, our best guess for the predicted outcome is the one with the highest predicted
probability. For example, for the very first observation in the table above, we would choose outcome 4
as the most likely to occur.
We obtain predictions of the posterior means themselves at the school and class levels by typing
. predict re_s re_c, remeans
(calculating posterior means of random effects)
(using 7 quadrature points)

178

meoprobit postestimation Postestimation tools for meoprobit

Here we list the predicted random effects for the first two classes for school 515:
. list class re_s re_c if school==515 & (class==515101 | class==515102),
> sepby(class)
class

re_s

re_c

1464.
1465.
1466.
1467.
1468.
1469.

515101
515101
515101
515101
515101
515101

-.0340769
-.0340769
-.0340769
-.0340769
-.0340769
-.0340769

.0390243
.0390243
.0390243
.0390243
.0390243
.0390243

1470.
1471.
1472.
1473.
1474.
1475.
1476.

515102
515102
515102
515102
515102
515102
515102

-.0340769
-.0340769
-.0340769
-.0340769
-.0340769
-.0340769
-.0340769

-.0834322
-.0834322
-.0834322
-.0834322
-.0834322
-.0834322
-.0834322

We can see that the predicted random effects at the school level (re s) are the same for all classes
and that the predicted random effects at the class level (re c) are constant within each class.

Methods and formulas


Methods and formulas for predicting random effects and other statistics are given in Methods and
formulas of [ME] meglm postestimation.

Also see
[ME] meoprobit Multilevel mixed-effects ordered probit regression
[ME] meglm postestimation Postestimation tools for meglm
[U] 20 Estimation and postestimation commands

Title
mepoisson Multilevel mixed-effects Poisson regression
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
mepoisson depvar fe equation || re equation

|| re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.

fe options

Description

Model

noconstant
exposure(varnamee )
offset(varnameo )

suppress the constant term from the fixed-effects equation


include ln(varnamee ) in model with coefficient constrained to 1
include varnameo in model with coefficient constrained to 1

re options

Description

Model

covariance(vartype)
noconstant

variancecovariance structure of the random effects


suppress constant term from the random-effects equation

179

180

mepoisson Multilevel mixed-effects Poisson regression

options

Description

Model

constraints(constraints)
collinear

apply specified linear constraints


keep collinear variables

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
irr
nocnsreport
notable
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


report fixed-effects coefficients as incidence-rate ratios
do not display constraints
suppress coefficient table
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with Poisson
regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intmethod(intmethod)
intpoints(#)

integration method
set the number of integration (quadrature) points for all levels;
default is intpoints(7)

Maximization

maximize options

control the maximization process; seldom used

startvalues(svmethod)
startgrid (gridspec)
noestimate
dnumerical
coeflegend

method for obtaining starting values


perform a grid search to improve starting values
do not fit the model; show starting values instead
use numerical derivative techniques
display legend instead of statistics

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0; the
default if the R. notation is used
all variances and covariances to be distinctly estimated
user-selected variances and covariances constrained to specified
values; the remaining variances and covariances unrestricted
user-selected variances and covariances constrained to be equal;
the remaining variances and covariances unrestricted

exchangeable
identity
unstructured
fixed(matname)
pattern(matname)

mepoisson Multilevel mixed-effects Poisson regression

181

intmethod

Description

mvaghermite

mean-variance adaptive GaussHermite quadrature; the default


unless a crossed random-effects model is fit
mode-curvature adaptive GaussHermite quadrature
nonadaptive GaussHermite quadrature
Laplacian approximation; the default for crossed random-effects
models

mcaghermite
ghermite
laplace

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
by is allowed; see [U] 11.1.10 Prefix commands.
startvalues(), startgrid, noestimate, dnumerical, and coeflegend do not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Poisson regression

Description
mepoisson fits mixed-effects models for count responses. The conditional distribution of the
response given the random effects is assumed to be Poisson.
mepoisson performs optimization with the original metric of variance components. When variance
components are near the boundary of the parameter space, you may consider using the meqrpoisson
command, which provides alternative parameterizations of variance components; see [ME] meqrpoisson.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
exposure(varnamee ) specifies a variable that reflects the amount of exposure over which the depvar
events were observed for each observation; ln(varnamee ) is included in the fixed-effects portion
of the model with the coefficient constrained to be 1.
offset(varnameo ) specifies that varnameo be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, unstructured, fixed(matname), or pattern(matname).
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent) unless a crossed random-effects model is fit, in which case the
default is covariance(identity).
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.

182

mepoisson Multilevel mixed-effects Poisson regression

covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.
covariance(unstructured) allows for all variances and covariances to be distinct. If an equation
consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2
unique parameters.
covariance(fixed(matname)) and covariance(pattern(matname)) covariance structures
provide a convenient way to impose constraints on variances and covariances of random effects.
Each specification requires a matname that defines the restrictions placed on variances and
covariances. Only elements in the lower triangle of matname are used, and row and column names
of matname are ignored. A missing value in matname means that a given element is unrestricted.
In a fixed(matname) covariance structure, (co)variance (i, j) is constrained to equal the
value specified in the i, j th entry of matname. In a pattern(matname) covariance structure,
(co)variances (i, j) and (k, l) are constrained to be equal if matname[i, j] = matname[k, l].
constraints(constraints), collinear; see [R] estimation options.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.

Reporting

level(#); see [R] estimation options.


irr reports estimated fixed-effects coefficients transformed to incidence-rate ratios, that is, exp()
rather than . Standard errors and confidence intervals are similarly transformed. This option
affects how results are displayed, not how they are estimated or stored. irr may be specified
either at estimation or upon replay.
nocnsreport; see [R] estimation options.
notable suppresses the estimation table, either at estimation or upon replay.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents mepoisson from performing a likelihood-ratio test that compares the mixed-effects
Poisson model with standard (marginal) Poisson regression. This option may also be specified
upon replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

Integration

intmethod(intmethod) specifies the integration method to be used for the random-effects model.
mvaghermite performs mean and variance adaptive GaussHermite quadrature; mcaghermite
performs mode and curvature adaptive GaussHermite quadrature; ghermite performs nonadaptive
GaussHermite quadrature; and laplace performs the Laplacian approximation, equivalent to mode
curvature adaptive Gaussian quadrature with one integration point.

mepoisson Multilevel mixed-effects Poisson regression

183

The default integration method is mvaghermite unless a crossed random-effects model is fit, in
which case the default integration method is laplace. The Laplacian approximation has been
known to produce biased parameter estimates; however, the bias tends to be more prominent in
the estimates of the variance components rather than in the estimates of the fixed effects.
For crossed random-effects models, estimation with more than one quadrature point may be
prohibitively intensive even for a small number of levels. For this reason, the integration method
defaults to the Laplacian approximation. You may override this behavior by specifying a different
integration method.
intpoints(#) sets the number of integration points for quadrature. The default is intpoints(7),
which means that seven quadrature points are used for each level of random effects. This option
is not allowed with intmethod(laplace).
The more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases as a function of the number of quadrature points raised to a power
equaling the dimension of the random-effects specification. In crossed random-effects models and
in models with many levels or many random coefficients, this increase can be substantial.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for mepoisson are listed below.
from() accepts a properly labeled vector of initial values or a list of coefficient names with values.
A list of values is not allowed.
The following options are available with mepoisson but are not shown in the dialog box:
startvalues(svmethod), startgrid (gridspec) , noestimate, and dnumerical; see [ME]
meglm.
coeflegend; see [R] estimation options.

Remarks and examples


For a general introduction to me commands, see [ME] me.
Remarks are presented under the following headings:
Introduction
A two-level model
A three-level model

Introduction
Mixed-effects Poisson regression is Poisson regression containing both fixed effects and random
effects. In longitudinal data and panel data, random effects are useful for modeling intracluster
correlation; that is, observations in the same cluster are correlated because they share common
cluster-level random effects.
Comprehensive treatments of mixed models are provided by, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and Skrondal (2012). Rabe-Hesketh and Skrondal (2012, chap. 13) is a good introductory read on applied
multilevel modeling of count data.

184

mepoisson Multilevel mixed-effects Poisson regression

mepoisson allows for not just one, but many levels of nested clusters. For example, in a three-level
model you can specify random effects for schools and then random effects for classes nested within
schools. In this model, the observations (presumably, the students) comprise the first level, the classes
comprise the second level, and the schools comprise the third level.
However, for simplicity, for now we consider the two-level model, where for a series of M
independent clusters, and conditional on a set of random effects uj ,
y

Pr(yij = y|xij , uj ) = exp (ij ) ij /y!

(1)

for ij = exp(xij + zij uj ), j = 1, . . . , M clusters, with cluster j consisting of i = 1, . . . , nj


observations. The responses are counts yij . The 1 p row vector xij are the covariates for the fixed
effects, analogous to the covariates you would find in a standard Poisson regression model, with
regression coefficients (fixed effects) . For notational convenience here and throughout this manual
entry, we suppress the dependence of yij on xij .
The 1 q vector zij are the covariates corresponding to the random effects and can be used to
represent both random intercepts and random coefficients. For example, in a random-intercept model,
zij is simply the scalar 1. The random effects uj are M realizations from a multivariate normal
distribution with mean 0 and q q variance matrix . The random effects are not directly estimated
as model parameters but are instead summarized according to the unique elements of , known
as variance components. One special case of (1) places zij = xij so that all covariate effects are
essentially random and distributed as multivariate normal with mean and variance .
As noted in chapter 13.7 of Rabe-Hesketh and Skrondal (2012), the inclusion of a random intercept
causes the marginal variance of yij to be greater than the marginal mean, provided the variance of
the random intercept is not 0. Thus the random intercept in a mixed-effects Poisson model produces
overdispersion, a measure of variability above and beyond that allowed by a Poisson process; see
[R] nbreg and [ME] menbreg.
Model (1) is a member of the class of generalized linear mixed models (GLMMs), which generalize
the linear mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using
mixed and fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there
is insight to be gained through examination of the linear mixed model. This is especially true for
Stata users because the terminology, syntax, options, and output for fitting these types of models are
nearly identical. See [ME] mixed and the references therein, particularly in the Introduction, for more
information.
Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out
the random effects. One widely used modern method is to directly estimate the integral required to
calculate the log likelihood by GaussHermite quadrature or some variation thereof. Because the log
likelihood itself is estimated, this method has the advantage of permitting likelihood-ratio tests for
comparing nested models. Also, if done correctly, quadrature approximations can be quite accurate,
thus minimizing bias.
mepoisson supports three types of GaussHermite quadrature and the Laplacian approximation
method; see Methods and formulas of [ME] meglm for details.
Below we present two short examples of mixed-effects Poisson regression; refer to [ME] me and
[ME] meglm for additional examples including crossed random-effects models.

mepoisson Multilevel mixed-effects Poisson regression

185

A two-level model
We begin with a simple application of (1) as a two-level model, because a one-level model, in our
terminology, is just standard Poisson regression; see [R] poisson.

Example 1
Breslow and Clayton (1993) fit a mixed-effects Poisson model to data from a randomized trial of
the drug progabide for the treatment of epilepsy.
. use http://www.stata-press.com/data/r13/epilepsy
(Epilepsy data; progabide drug treatment)
. describe
Contains data from http://www.stata-press.com/data/r13/epilepsy.dta
obs:
236
Epilepsy data; progabide drug
treatment
vars:
8
31 May 2013 14:09
size:
4,956
(_dta has notes)

variable name

storage
type

display
format

subject
seizures
treat
visit

byte
int
byte
float

%9.0g
%9.0g
%9.0g
%9.0g

lage
lbas

float
float

%9.0g
%9.0g

lbas_trt
v4

float
byte

%9.0g
%8.0g

Sorted by:

value
label

variable label
Subject ID: 1-59
No. of seizures
1: progabide; 0: placebo
Dr. visit; coded as (-.3, -.1,
.1, .3)
log(age), mean-centered
log(0.25*baseline seizures),
mean-centered
lbas/treat interaction
Fourth visit indicator

subject

Originally from Thall and Vail (1990), data were collected on 59 subjects (31 progabide, 28
placebo). The number of epileptic seizures (seizures) was recorded during the two weeks prior to
each of four doctor visits (visit). The treatment group is identified by the indicator variable treat.
Data were also collected on the logarithm of age (lage) and the logarithm of one-quarter the number
of seizures during the eight weeks prior to the study (lbas). The variable lbas trt represents the
interaction between lbas and treatment. lage, lbas, and lbas trt are mean centered. Because the
study originally noted a substantial decrease in seizures prior to the fourth doctor visit, an indicator
v4 for the fourth visit was also recorded.
Breslow and Clayton (1993) fit a random-effects Poisson model for the number of observed seizures,

log(ij ) = 0 + 1 treatij + 2 lbasij + 3 lbas trtij + 4 lageij + 5 v4ij + uj


for j = 1, . . . , 59 subjects and i = 1, . . . , 4 visits. The random effects uj are assumed to be normally
distributed with mean 0 and variance u2 .

186

mepoisson Multilevel mixed-effects Poisson regression


. mepoisson seizures treat lbas
Fitting fixed-effects model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Iteration 4:
log likelihood =
Refining starting values:
Grid node 0:
log likelihood =
Fitting full model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Iteration 4:
log likelihood =
Iteration 5:
log likelihood =
Iteration 6:
log likelihood =

lbas_trt lage v4 || subject:


-1016.4106
-819.20112
-817.66006
-817.65925
-817.65925
-680.40523
-680.40523
-672.95766
-667.14039
-665.51823
-665.29165
-665.29067
-665.29067

(not concave)
(not concave)

Mixed-effects Poisson regression


Group variable:
subject

Number of obs
Number of groups
Obs per group: min
avg
max
Integration points
Wald chi2(5)
Prob > chi2

Integration method: mvaghermite


Log likelihood = -665.29067
seizures

Coef.

treat
lbas
lbas_trt
lage
v4
_cons

-.9330306
.8844225
.3382561
.4842226
-.1610871
2.154578

.4007512
.1312033
.2033021
.3471905
.0545758
.2199928

.2528664

.0589844

subject
var(_cons)

Std. Err.

LR test vs. Poisson regression:

z
-2.33
6.74
1.66
1.39
-2.95
9.79

chibar2(01) =

P>|z|
0.020
0.000
0.096
0.163
0.003
0.000

=
=
=
=
=
=
=
=

236
59
4
4.0
4
7
121.70
0.0000

[95% Conf. Interval]


-1.718489
.6272689
-.0602087
-.1962582
-.2680536
1.7234

-.1475727
1.141576
.736721
1.164703
-.0541206
2.585756

.1600801

.399434

304.74 Prob>=chibar2 = 0.0000

The number of seizures before the fourth visit does exhibit a significant drop, and the patients on
progabide demonstrate a decrease in frequency of seizures compared with the placebo group. The
subject-specific random effects also appear significant: u2 = 0.25 with standard error 0.06.
Because this is a simple random-intercept model, you can obtain equivalent results by using
xtpoisson with the re and normal options.

A three-level model
mepoisson can also fit higher-level models with multiple levels of nested random effects.

mepoisson Multilevel mixed-effects Poisson regression

187

Example 2
Rabe-Hesketh and Skrondal (2012, exercise 13.7) describe data from the Atlas of Cancer Mortality
in the European Economic Community (EEC) (Smans, Mair, and Boyle 1993). The data were analyzed
in Langford, Bentham, and McDonald (1998) and record the number of deaths among males due to
malignant melanoma during 19711980.
. use http://www.stata-press.com/data/r13/melanoma
(Skin cancer (melanoma) data)
. describe
Contains data from http://localpress.stata.com/data/r13/melanoma.dta
obs:
354
Skin cancer (melanoma) data
vars:
6
30 May 2013 17:10
size:
4,956
(_dta has notes)
storage
type

display
format

value
label

nation
region
county

byte
byte
int

%11.0g
%9.0g
%9.0g

deaths
expected
uv

int
float
float

%9.0g
%9.0g
%9.0g

variable name

variable label
Nation ID
Region ID: EEC level-I areas
County ID: EEC level-II/level-III
areas
No. deaths during 1971-1980
No. expected deaths
UV dose, mean-centered

Sorted by:

Nine European nations (variable nation) are represented, and data were collected over geographical
regions defined by EEC statistical services as level I areas (variable region), with deaths being recorded
for each of 354 counties, which are level II or level III EEC-defined areas (variable county, which
identifies the observations). Counties are nested within regions, and regions are nested within nations.
The variable deaths records the number of deaths for each county, and expected records the
expected number of deaths (the exposure) on the basis of crude rates for the combined countries.
Finally, the variable uv is a measure of exposure to ultraviolet (UV) radiation.
In modeling the number of deaths, one possibility is to include dummy variables for the nine nations
as fixed effects. Another is to treat these as random effects and fit the three-level random-intercept
Poisson model,

log(ijk ) = log(expectedijk ) + 0 + 1 uvijk + uk + vjk


for nation k , region j , and county i. The model includes an exposure term for expected deaths.

188

mepoisson Multilevel mixed-effects Poisson regression


. mepoisson deaths c.uv##c.uv, exposure(expected) || nation: || region:
Fitting fixed-effects model:
Iteration 0:
log likelihood = -2136.0274
Iteration 1:
log likelihood = -1723.127
Iteration 2:
log likelihood = -1722.9762
Iteration 3:
log likelihood = -1722.9762
Refining starting values:
Grid node 0:
log likelihood = -1166.9773
Fitting full model:
Iteration 0:
log likelihood = -1166.9773
Iteration 1:
log likelihood = -1152.6069
Iteration 2:
log likelihood = -1151.902
Iteration 3:
log likelihood = -1127.412
Iteration 4:
log likelihood = -1101.9248
Iteration 5:
log likelihood = -1094.1984
Iteration 6:
log likelihood =
-1088.05
Iteration 7:
log likelihood = -1086.9097
Iteration 8:
log likelihood = -1086.8995
Iteration 9:
log likelihood = -1086.8994
Mixed-effects Poisson regression

Group Variable

No. of
Groups

nation
region

9
78

(not
(not
(not
(not

Number of obs

3
1

uv

354

Integration points =
Wald chi2(2)
=
Prob > chi2
=

7
25.70
0.0000

39.3
4.5

Log likelihood = -1086.8994


Coef.

Observations per Group


Minimum
Average
Maximum

Integration method: mvaghermite

deaths

concave)
concave)
concave)
concave)

95
13

Std. Err.

P>|z|

[95% Conf. Interval]

.0057002

.0137919

0.41

0.679

-.0213315

.0327318

c.uv#c.uv

-.0058377

.0013879

-4.21

0.000

-.008558

-.0031174

_cons
ln(expected)

.1289989
1

.1581224
(exposure)

0.82

0.415

-.1809154

.4389132

nation
var(_cons)

.1841878

.0945722

.0673298

.5038655

nation>
region
var(_cons)

.0382645

.0087757

.0244105

.0599811

LR test vs. Poisson regression:


chi2(2) = 1272.15
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

By including an exposure variable that is an expected rate, we are in effect specifying a linear model
for the log of the standardized mortality ratio, the ratio of observed deaths to expected deaths that is
based on a reference population, the reference population being all nine nations.

mepoisson Multilevel mixed-effects Poisson regression

189

Looking at the estimated variance components, we can see that there is more unobserved variability
between nations than between regions within each nation. This may be due to, for example, countryspecific informational campaigns on the risks of sun exposure.

Stored results
mepoisson stores the following in e():
Scalars
e(N)
e(k)
e(k dv)
e(k eq)
e(k eq model)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(N clust)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(ic)
e(rc)
e(converged)
Macros
e(cmd)
e(cmdline)
e(depvar)
e(covariates)
e(ivars)
e(model)
e(title)
e(link)
e(family)
e(clustvar)
e(offset)
e(exposure)
e(intmethod)
e(n quad)
e(chi2type)
e(vce)
e(vcetype)
e(opt)
e(which)
e(ml method)
e(user)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)

number of observations
number of parameters
number of dependent variables
number of equations in e(b)
number of equations in overall model test
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
number of clusters
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
number of iterations
return code
1 if converged, 0 otherwise
mepoisson
command as typed
name of dependent variable
list of covariates
grouping variables
poisson
title in estimation output
log
poisson
name of cluster variable
offset
exposure variable
integration method
number of integration points
Wald; type of model 2
vcetype specified in vce()
title used to label Std. Err.
type of optimization
max or min; whether optimizer is to perform maximization or minimization
type of ml method
name of likelihood-evaluator program
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict

190

mepoisson Multilevel mixed-effects Poisson regression

Matrices
e(b)
e(Cns)
e(ilog)
e(gradient)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
e(V modelbased)
Functions
e(sample)

coefficient vector
constraints matrix
iteration log (up to 20 iterations)
gradient vector
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
model-based variance
marks estimation sample

Methods and formulas


In a two-level Poisson model, for cluster j , j = 1, . . . , M , the conditional distribution of
yj = (yj1 , . . . , yjnj ) , given a set of cluster-level random effects uj , is
nj
yij

f (yj |uj ) =

[{exp (xij + zij uj )}

exp { exp (xij + zij uj )} /yij !]

i=1
nj

{yij (xij + zij uj ) exp (xij + zij uj ) log(yij !)}

= exp
i=1
n

j
Defining c (yj ) = i=1
log(yij !), where c(yj ) does not depend on the model parameters, we
can express the above compactly in matrix notation,

f (yj |uj ) = exp yj (Xj + Zj uj ) 1 exp (Xj + Zj uj ) c (yj )


where Xj is formed by stacking the row vectors xij and Zj is formed by stacking the row vectors
zij . We extend the definition of exp() to be a vector function where necessary.
Because the prior distribution of uj is multivariate normal with mean 0 and q q variance matrix
, the likelihood contribution for the j th cluster is obtained by integrating uj out of the joint density
f (yj , uj ),
1/2

Lj (, ) = (2)q/2 ||

f (yj |uj ) exp uj 1 uj /2 duj


(2)

= exp {c (yj )} (2)


where

q/2

1/2

||

exp {g (, , uj )} duj

g (, , uj ) = yj (Xj + Zj uj ) 1 exp (Xj + Zj uj ) uj 1 uj /2

and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , Xj , Zj ).
The integration in (2) has no closed form and thus must be approximated. mepoisson offers
four approximation methods: meanvariance adaptive GaussHermite quadrature (default unless a
crossed random-effects model is fit), mode-curvature adaptive GaussHermite quadrature, nonadaptive
GaussHermite quadrature, and Laplacian approximation (default for crossed random-effects models).

mepoisson Multilevel mixed-effects Poisson regression

191

The Laplacian approximation is based on a second-order Taylor expansion of g (, , uj ) about


the value of uj that maximizes it; see Methods and formulas in [ME] meglm for details.
Gaussian quadrature relies on transforming the multivariate integral in (2) into a set of nested
univariate integrals. Each univariate integral can then be evaluated using a form of Gaussian quadrature;
see Methods and formulas in [ME] meglm for details.
The log likelihood for the entire dataset is simply the sum of the contributions of the M individual
M
clusters, namely, L(, ) = j=1 Lj (, ).
Maximization of L(, ) is performed with respect to (, 2 ), where 2 is a vector comprising
the unique elements of . Parameter estimates are stored in e(b) as (, 2 ), with the corresponding
variancecovariance matrix stored in e(V).

References
Andrews, M. J., T. Schank, and R. Upward. 2006. Practical fixed-effects estimation methods for the three-way
error-components model. Stata Journal 6: 461481.
Breslow, N. E., and D. G. Clayton. 1993. Approximate inference in generalized linear mixed models. Journal of the
American Statistical Association 88: 925.
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.
Gutierrez, R. G., S. L. Carter, and D. M. Drukker. 2001. sg160: On boundary-value likelihood-ratio tests. Stata
Technical Bulletin 60: 1518. Reprinted in Stata Technical Bulletin Reprints, vol. 10, pp. 269273. College Station,
TX: Stata Press.
Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.
Joe, H. 2008. Accuracy of Laplace approximation for discrete response mixed models. Computational Statistics &
Data Analysis 52: 50665074.
Laird, N. M., and J. H. Ware. 1982. Random-effects models for longitudinal data. Biometrics 38: 963974.
Langford, I. H., G. Bentham, and A. McDonald. 1998. Multi-level modelling of geographically aggregated health
data: A case study on malignant melanoma mortality and UV exposure in the European community. Statistics in
Medicine 17: 4157.
Leyland, A. H., and H. Goldstein, ed. 2001. Multilevel Modelling of Health Statistics. New York: Wiley.
Lin, X., and N. E. Breslow. 1996. Bias correction in generalized linear mixed models with multiple components of
dispersion. Journal of the American Statistical Association 91: 10071016.
Marchenko, Y. V. 2006. Estimating variance components in Stata. Stata Journal 6: 121.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
McLachlan, G. J., and K. E. Basford. 1988. Mixture Models. New York: Dekker.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Rabe-Hesketh, S., A. Skrondal, and A. Pickles. 2005. Maximum likelihood estimation of limited and discrete dependent
variable models with nested random effects. Journal of Econometrics 128: 301323.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Self, S. G., and K.-Y. Liang. 1987. Asymptotic properties of maximum likelihood estimators and likelihood ratio tests
under nonstandard conditions. Journal of the American Statistical Association 82: 605610.
Skrondal, A., and S. Rabe-Hesketh. 2004. Generalized Latent Variable Modeling: Multilevel, Longitudinal, and
Structural Equation Models. Boca Raton, FL: Chapman & Hall/CRC.
Smans, M., C. S. Mair, and P. Boyle. 1993. Atlas of Cancer Mortality in the European Economic Community. Lyon,
France: IARC Scientific Publications.

192

mepoisson Multilevel mixed-effects Poisson regression

Thall, P. F., and S. C. Vail. 1990. Some covariance models for longitudinal count data with overdispersion. Biometrics
46: 657671.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.

Also see
[ME] mepoisson postestimation Postestimation tools for mepoisson
[ME] menbreg Multilevel mixed-effects negative binomial regression
[ME] meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)
[ME] me Introduction to multilevel mixed-effects models
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtpoisson Fixed-effects, random-effects, and population-averaged Poisson models
[U] 20 Estimation and postestimation commands

Title
mepoisson postestimation Postestimation tools for mepoisson
Description
Options for predict
Remarks and examples

Syntax for predict


Syntax for estat group
Methods and formulas

Menu for predict


Menu for estat
Also see

Description
The following postestimation command is of special interest after mepoisson:
Command

Description

estat group

summarize the composition of the nested groups

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
193

194

mepoisson postestimation Postestimation tools for mepoisson

Syntax for predict


Syntax for obtaining predictions of random effects and their standard errors
predict

type

newvarsspec

if

in ,

remeans | remodes

reses(newvarsspec)

Syntax for obtaining other predictions


predict

type

newvarsspec

if

in

, statistic options

newvarsspec is stub* or newvarlist.


Description

statistic
Main

number of events; the default


fitted linear predictor
linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction
Pearson residuals
deviance residuals
Anscombe residuals

mu
fitted
xb
stdp
pearson
deviance
anscombe

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

Description

options
Main

means
modes
nooffset
fixedonly

compute statistic using empirical Bayes means; the default


compute statistic using empirical Bayes modes
ignore the offset or exposure variable in calculating predictions; relevant only
if you specified offset() or exposure() when you fit the model
prediction for the fixed portion of the model only

Integration

intpoints(#)
iterate(#)
tolerance(#)

use # quadrature points to compute empirical Bayes means


set maximum number of iterations in computing statistics involving
empirical Bayes estimators
set convergence tolerance for computing statistics involving empirical
Bayes estimators

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

mepoisson postestimation Postestimation tools for mepoisson

195

Options for predict

Main

remeans, remodes, reses(); see [ME] meglm postestimation.


mu, the default, calculates the predicted mean (the predicted number of events), that is, the inverse
link function applied to the linear prediction. By default, this is based on a linear predictor that
includes both the fixed effects and the random effects, and the predicted mean is conditional on
the values of the random effects. Use the fixedonly option if you want predictions that include
only the fixed portion of the model, that is, if you want random effects set to 0.
fitted, xb, stdp, pearson, deviance, anscombe, means, modes, nooffset, fixedonly; see
[ME] meglm postestimation.
By default or if the means option is specified, statistics mu, pr, fitted, xb, stdp, pearson,
deviance, and anscombe are based on the posterior mean estimates of random effects. If the
modes option is specified, these statistics are based on the posterior mode estimates of random
effects.

Integration

intpoints(), iterate(), tolerance(); see [ME] meglm postestimation.

Syntax for estat group


estat group

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a mixed-effects
Poisson model with mepoisson. For the most part, calculation centers around obtaining estimates
of the subject/group-specific random effects. Random effects are not estimated when the model is fit
but instead need to be predicted after estimation.
Here we show a short example of predicted counts and predicted random effects; refer to [ME] meglm
postestimation for additional examples applicable to mixed-effects generalized linear models.

Example 1
In example 2 of [ME] mepoisson, we modeled the number of deaths among males in nine European
nations as a function of exposure to ultraviolet radiation (uv). We used a three-level Poisson model
with random effects at the nation and region levels.

196

mepoisson postestimation Postestimation tools for mepoisson


. use http://www.stata-press.com/data/r13/melanoma
(Skin cancer (melanoma) data)
. mepoisson deaths c.uv##c.uv, exposure(expected) || nation: || region:
(output omitted )

We can use predict to obtain the predicted counts as well as the estimates of the random effects
at the nation and region levels.
. predict mu
(predictions based on fixed effects and posterior means of random effects)
(option mu assumed)
(using 7 quadrature points)
. predict re_nat re_reg, remeans
(calculating posterior means of random effects)
(using 7 quadrature points)

Stata displays a note that the predicted values of mu are based on the posterior means of random
effects. You can use option modes to obtain predictions based on the posterior modes of random
effects.
Here we list the data for the first nation in the dataset, which happens to be Belgium:
. list nation region deaths mu re_nat re_reg if nation==1, sepby(region)
nation

region

deaths

mu

re_nat

re_reg

1.

Belgium

79

69.17982

-.123059

.3604518

2.
3.
4.
5.
6.

Belgium
Belgium
Belgium
Belgium
Belgium

2
2
2
2
2

80
51
43
89
19

78.14297
46.21698
54.25965
66.78156
34.83411

-.123059
-.123059
-.123059
-.123059
-.123059

.049466
.049466
.049466
.049466
.049466

7.
8.
9.
10.
11.

Belgium
Belgium
Belgium
Belgium
Belgium

3
3
3
3
3

19
15
33
9
12

8.166062
40.92741
30.78324
6.914059
12.16361

-.123059
-.123059
-.123059
-.123059
-.123059

-.4354829
-.4354829
-.4354829
-.4354829
-.4354829

We can see that the predicted random effects at the nation level, re nat, are the same for all the
observations. Similarly, the predicted random effects at the region level, re reg, are the same within
each region. The predicted counts, mu, are closer to the observed deaths than the predicted counts
from the negative binomial mixed-effects model in example 1 of [ME] menbreg postestimation.

Methods and formulas


Methods and formulas for predicting random effects and other statistics are given in Methods and
formulas of [ME] meglm postestimation.

Also see
[ME] mepoisson Multilevel mixed-effects Poisson regression
[ME] meglm postestimation Postestimation tools for meglm
[U] 20 Estimation and postestimation commands

Title
meprobit Multilevel mixed-effects probit regression
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
meprobit depvar fe equation || re equation

|| re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

noconstant
offset(varname)
asis

suppress constant term from the fixed-effects equation


include varname in model with coefficient constrained to 1
retain perfect predictor variables

re options

Description

Model

covariance(vartype)
noconstant

variancecovariance structure of the random effects


suppress constant term from the random-effects equation

197

198

meprobit Multilevel mixed-effects probit regression

options

Description

Model

binomial(varname | #)
constraints(constraints)
collinear

set binomial trials if data are in binomial form


apply specified linear constraints
keep collinear variables

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
nocnsreport
notable
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


do not display constraints
suppress coefficient table
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with probit regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intmethod(intmethod)
intpoints(#)

integration method
set the number of integration (quadrature) points for all levels;
default is intpoints(7)

Maximization

maximize options

control the maximization process; seldom used

startvalues(svmethod)
startgrid (gridspec)
noestimate
dnumerical
coeflegend

method for obtaining starting values


perform a grid search to improve starting values
do not fit the model; show starting values instead
use numerical derivative techniques
display legend instead of statistics

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0; the
default if the R. notation is used
all variances and covariances to be distinctly estimated
user-selected variances and covariances constrained to specified
values; the remaining variances and covariances unrestricted
user-selected variances and covariances constrained to be equal;
the remaining variances and covariances unrestricted

exchangeable
identity
unstructured
fixed(matname)
pattern(matname)

meprobit Multilevel mixed-effects probit regression

intmethod

Description

mvaghermite

mean-variance adaptive GaussHermite quadrature; the default


unless a crossed random-effects model is fit
mode-curvature adaptive GaussHermite quadrature
nonadaptive GaussHermite quadrature
Laplacian approximation; the default for crossed random-effects
models

mcaghermite
ghermite
laplace

199

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
by is allowed; see [U] 11.1.10 Prefix commands.
startvalues(), startgrid, noestimate, dnumerical, and coeflegend do not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Probit regression

Description
meprobit fits mixed-effects models for binary or binomial responses. The conditional distribution
of the response given the random effects is assumed to be Bernoulli, with success probability determined
by the standard normal cumulative distribution function.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
offset(varname) specifies that varname be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
asis forces retention of perfect predictor variables and their associated, perfectly predicted observations
and may produce instabilities in maximization; see [R] probit.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, unstructured, fixed(matname), or pattern(matname).
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent) unless a crossed random-effects model is fit, in which case the
default is covariance(identity).
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.
covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.
covariance(unstructured) allows for all variances and covariances to be distinct. If an equation
consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2
unique parameters.

200

meprobit Multilevel mixed-effects probit regression

covariance(fixed(matname)) and covariance(pattern(matname)) covariance structures


provide a convenient way to impose constraints on variances and covariances of random effects.
Each specification requires a matname that defines the restrictions placed on variances and
covariances. Only elements in the lower triangle of matname are used, and row and column names
of matname are ignored. A missing value in matname means that a given element is unrestricted.
In a fixed(matname) covariance structure, (co)variance (i, j) is constrained to equal the
value specified in the i, j th entry of matname. In a pattern(matname) covariance structure,
(co)variances (i, j) and (k, l) are constrained to be equal if matname[i, j] = matname[k, l].
binomial(varname | #) specifies that the data are in binomial form; that is, depvar records the number
of successes from a series of binomial trials. This number of trials is given either as varname,
which allows this number to vary over the observations, or as the constant #. If binomial() is
not specified (the default), depvar is treated as Bernoulli, with any nonzero, nonmissing values
indicating positive responses.
constraints(constraints), collinear; see [R] estimation options.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.

Reporting

level(#), nocnsreport, ; see [R] estimation options.


notable suppresses the estimation table, either at estimation or upon replay.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents meprobit from performing a likelihood-ratio test that compares the mixed-effects
probit model with standard (marginal) probit regression. This option may also be specified upon
replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

Integration

intmethod(intmethod) specifies the integration method to be used for the random-effects model.
mvaghermite performs mean and variance adaptive GaussHermite quadrature; mcaghermite
performs mode and curvature adaptive GaussHermite quadrature; ghermite performs nonadaptive
GaussHermite quadrature; and laplace performs the Laplacian approximation, equivalent to mode
curvature adaptive Gaussian quadrature with one integration point.
The default integration method is mvaghermite unless a crossed random-effects model is fit, in
which case the default integration method is laplace. The Laplacian approximation has been
known to produce biased parameter estimates; however, the bias tends to be more prominent in
the estimates of the variance components rather than in the estimates of the fixed effects.
For crossed random-effects models, estimation with more than one quadrature point may be
prohibitively intensive even for a small number of levels. For this reason, the integration method

meprobit Multilevel mixed-effects probit regression

201

defaults to the Laplacian approximation. You may override this behavior by specifying a different
integration method.
intpoints(#) sets the number of integration points for quadrature. The default is intpoints(7),
which means that seven quadrature points are used for each level of random effects. This option
is not allowed with intmethod(laplace).
The more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases as a function of the number of quadrature points raised to a power
equaling the dimension of the random-effects specification. In crossed random-effects models and
in models with many levels or many random coefficients, this increase can be substantial.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for meprobit are listed below.
from() accepts a properly labeled vector of initial values or a list of coefficient names with values.
A list of values is not allowed.
The following options are available with meprobit but are not shown in the dialog box:
startvalues(svmethod), startgrid (gridspec) , noestimate, and dnumerical; see [ME]
meglm.
coeflegend; see [R] estimation options.

Remarks and examples


For a general introduction to me commands, see [ME] me.
meprobit is a convenience command for meglm with a probit link and a bernoulli or binomial
family; see [ME] meglm.
Remarks are presented under the following headings:
Introduction
Two-level models
Three-level models

Introduction
Mixed-effects probit regression is probit regression containing both fixed effects and random effects.
In longitudinal data and panel data, random effects are useful for modeling intracluster correlation;
that is, observations in the same cluster are correlated because they share common cluster-level random
effects.
Comprehensive treatments of mixed models are provided by, for example, Searle, Casella, and McCulloch (1992); Verbeke and Molenberghs (2000); Raudenbush and Bryk (2002); Demidenko (2004);
Hedeker and Gibbons (2006); McCulloch, Searle, and Neuhaus (2008); and Rabe-Hesketh and
Skrondal (2012). Guo and Zhao (2000) and Rabe-Hesketh and Skrondal (2012, chap. 10) are good
introductory readings on applied multilevel modeling of binary data.

202

meprobit Multilevel mixed-effects probit regression

meprobit allows for not just one, but many levels of nested clusters of random effects. For
example, in a three-level model you can specify random effects for schools and then random effects
for classes nested within schools. In this model, the observations (presumably, the students) comprise
the first level, the classes comprise the second level, and the schools comprise the third.
However, for simplicity, we here consider the two-level model, where for a series of M independent
clusters, and conditional on a set of fixed effects xij and a set of random effects uj ,
Pr(yij = 1|xij , uj ) = H(xij + zij uj )

(1)

for j = 1, . . . , M clusters, with cluster j consisting of i = 1, . . . , nj observations. The responses are


the binary-valued yij , and we follow the standard Stata convention of treating yij = 1 if depvarij = 0
and treating yij = 0 otherwise. The 1 p row vector xij are the covariates for the fixed effects,
analogous to the covariates you would find in a standard probit regression model, with regression
coefficients (fixed effects) . For notational convenience here and throughout this manual entry, we
suppress the dependence of yij on xij .
The 1 q vector zij are the covariates corresponding to the random effects and can be used to
represent both random intercepts and random coefficients. For example, in a random-intercept model,
zij is simply the scalar 1. The random effects uj are M realizations from a multivariate normal
distribution with mean 0 and q q variance matrix . The random effects are not directly estimated
as model parameters but are instead summarized according to the unique elements of , known
as variance components. One special case of (1) places zij = xij , so that all covariate effects are
essentially random and distributed as multivariate normal with mean and variance .
Finally, because this is probit regression, H() is the standard normal cumulative distribution
function, which maps the linear predictor to the probability of a success (yij = 1) with H(v) = (v).

Model (1) may also be stated in terms of a latent linear response, where only yij = I(yij
> 0)
is observed for the latent

yij
= xij + zij uj + ij

The errors
of uj .

ij

are distributed as a standard normal with mean 0 and variance 1 and are independent

Model (1) is an example of a generalized linear mixed model (GLMM), which generalizes the
linear mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using
mixed and fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there
is insight to be gained through examination of the linear mixed model. This is especially true for
Stata users because the terminology, syntax, options, and output for fitting these types of models are
nearly identical. See [ME] mixed and the references therein, particularly in Introduction, for more
information.
Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out
the random effects. One widely used modern method is to directly estimate the integral required to
calculate the log likelihood by GaussHermite quadrature or some variation thereof. Because the log
likelihood itself is estimated, this method has the advantage of permitting likelihood-ratio tests for
comparing nested models. Also, if done correctly, quadrature approximations can be quite accurate,
thus minimizing bias.
meprobit supports three types of GaussHermite quadrature and the Laplacian approximation
method; see Methods and formulas of [ME] meglm for details. The simplest random-effects model
you can fit using meprobit is the two-level model with a random intercept,
Pr(yij = 1|uj ) = (xij + uj )
This model can also be fit using xtprobit with the re option; see [XT] xtprobit.

meprobit Multilevel mixed-effects probit regression

203

Below we present two short examples of mixed-effects probit regression; refer to [ME] melogit
for additional examples including crossed random-effects models and to [ME] me and [ME] meglm
for examples of other random-effects models.

Two-level models
We begin with a simple application of (1) as a two-level model, because a one-level model, in our
terminology, is just standard probit regression; see [R] probit.

Example 1
In example 1 of [ME] melogit, we analyzed a subsample of data from the 1989 Bangladesh
fertility survey (Huq and Cleland 1990), which polled 1,934 Bangladeshi women on their use of
contraception. The women sampled were from 60 districts, identified by the variable district. Each
district contained either urban or rural areas (variable urban) or both. The variable c use is the binary
response, with a value of 1 indicating contraceptive use. Other covariates include mean-centered age
and three indicator variables recording number of children. Here we refit that model with meprobit:
. use http://www.stata-press.com/data/r13/bangladesh
(Bangladesh Fertility Survey, 1989)
. meprobit c_use urban age child* || district:
Fitting fixed-effects model:
Iteration 0:
log likelihood = -1228.8313
Iteration 1:
log likelihood = -1228.2466
Iteration 2:
log likelihood = -1228.2466
Refining starting values:
Grid node 0:
log likelihood = -1237.3973
Fitting full model:
Iteration 0:
log likelihood = -1237.3973 (not concave)
Iteration 1:
log likelihood = -1221.2111 (not concave)
Iteration 2:
log likelihood = -1207.4451
Iteration 3:
log likelihood = -1206.7002
Iteration 4:
log likelihood = -1206.5346
Iteration 5:
log likelihood = -1206.5336
Iteration 6:
log likelihood = -1206.5336
Mixed-effects probit regression
Number of obs
Group variable:
district
Number of groups
Obs per group: min
avg
max
Integration method: mvaghermite
Integration points
Wald chi2(5)
Log likelihood = -1206.5336
Prob > chi2
c_use

Coef.

urban
age
child1
child2
child3
_cons

.4490191
-.0162203
.674377
.8281581
.8137876
-1.02799

.0727176
.0048005
.0947829
.1048136
.1073951
.0870307

.0798719

.026886

district
var(_cons)

Std. Err.

z
6.17
-3.38
7.11
7.90
7.58
-11.81

P>|z|
0.000
0.001
0.000
0.000
0.000
0.000

=
=
=
=
=
=
=
=

1934
60
2
32.2
118
7
115.36
0.0000

[95% Conf. Interval]


.3064953
-.0256291
.488606
.6227272
.6032972
-1.198567

.5915429
-.0068114
.8601481
1.033589
1.024278
-.8574132

.0412921

.1544972

204

meprobit Multilevel mixed-effects probit regression

LR test vs. probit regression:

chibar2(01) =

43.43 Prob>=chibar2 = 0.0000

Comparing the estimates of meprobit with those of melogit, we observe the familiar result
where the probit estimates are closer to 0 in absolute value due to the smaller variance of the error
term in the probit model. Example 1 of [ME] meprobit postestimation shows that the marginal effect
of covariates is nearly the same between the two models.
Unlike a logistic regression, coefficients from a probit regression cannot be interpreted in terms of
odds ratios. Most commonly, probit regression coefficients are interpreted in terms of partial effects,
as we demonstrate in example 1 of [ME] meprobit postestimation. For now, we only note that urban
women and women with more children are more likely to use contraceptives and that contraceptive
use decreases with age. The estimated variance of the random intercept at the district level, 2 , is
0.08 with standard error 0.03. The reported likelihood-ratio test shows that there is enough variability
between districts to favor a mixed-effects probit regression over an ordinary probit regression; see
Distribution theory for likelihood-ratio test in [ME] me for a discussion of likelihood-ratio testing of
variance components.

Three-level models
Two-level models extend naturally to models with three or more levels with nested random effects.
Below we replicate example 2 of [ME] melogit with meprobit.

Example 2
Rabe-Hesketh, Toulopoulou, and Murray (2001) analyzed data from a study that measured the
cognitive ability of patients with schizophrenia compared with their relatives and control subjects.
Cognitive ability was measured as the successful completion of the Tower of London, a computerized
task, measured at three levels of difficulty. For all but one of the 226 subjects, there were three
measurements (one for each difficulty level). Because patients relatives were also tested, a family
identifier, family, was also recorded.
We fit a probit model with response dtlm, the indicator of cognitive function, and with covariates
difficulty and a set of indicator variables for group, with the controls (group==1) being the base
category. We also allow for random effects due to families and due to subjects within families.

meprobit Multilevel mixed-effects probit regression

205

. use http://www.stata-press.com/data/r13/towerlondon
(Tower of London data)
. meprobit dtlm difficulty i.group || family: || subject:
Fitting fixed-effects model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Refining starting values:
Grid node 0:
log likelihood =
Fitting full model:
Iteration 0:
log likelihood =
Iteration 1:
log likelihood =
Iteration 2:
log likelihood =
Iteration 3:
log likelihood =
Iteration 4:
log likelihood =
Iteration 5:
log likelihood =
Iteration 6:
log likelihood =
Mixed-effects probit regression

Group Variable

No. of
Groups

family
subject

118
226

-317.11238
-314.50535
-314.50121
-314.50121
-326.18533
-326.18533
-313.16256
-308.47528
-305.02228
-304.88972
-304.88845
-304.88845

(not concave)
(not concave)

Number of obs

677

Observations per Group


Minimum
Average
Maximum
2
2

5.7
3.0

27
3

Integration method: mvaghermite

Integration points =

Log likelihood = -304.88845

Wald chi2(3)
Prob > chi2
Std. Err.

P>|z|

=
=

7
83.28
0.0000

dtlm

Coef.

[95% Conf. Interval]

difficulty

-.9329891

.1037376

-8.99

0.000

-1.136311

-.7296672

group
2
3

-.1632243
-.6220196

.204265
.228063

-0.80
-2.73

0.424
0.006

-.5635763
-1.069015

.2371276
-.1750244

_cons

-.8405154

.1597223

-5.26

0.000

-1.153565

-.5274654

family
var(_cons)

.2120948

.1736281

.0426292

1.055244

family>
subject
var(_cons)

.3559141

.219331

.106364

1.190956

LR test vs. probit regression:


chi2(2) =
19.23
Prob > chi2 = 0.0001
Note: LR test is conservative and provided only for reference.

Notes:
1. This is a three-level model with two random-effects equations, separated by ||. The first is a
random intercept (constant only) at the family level, and the second is a random intercept at the
subject level. The order in which these are specified (from left to right) is significantmeprobit
assumes that subject is nested within family.

206

meprobit Multilevel mixed-effects probit regression

2. The information on groups is now displayed as a table, with one row for each upper level. Among
other things, we see that we have 226 subjects from 118 families. You can suppress this table
with the nogroup or the noheader option, which will suppress the rest of the header as well.
After adjusting for the random-effects structure, the probability of successful completion of the
Tower of London decreases dramatically as the level of difficulty increases. Also, schizophrenics
(group==3) tended not to perform as well as the control subjects.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left to
right as the groups go from biggest (highest level) to smallest (lowest level).

Stored results
meprobit stores the following in e():
Scalars
e(N)
e(k)
e(k dv)
e(k eq)
e(k eq model)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(N clust)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(ic)
e(rc)
e(converged)

number of observations
number of parameters
number of dependent variables
number of equations in e(b)
number of equations in overall model test
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
number of clusters
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
number of iterations
return code
1 if converged, 0 otherwise

meprobit Multilevel mixed-effects probit regression


Macros
e(cmd)
e(cmdline)
e(depvar)
e(covariates)
e(ivars)
e(model)
e(title)
e(link)
e(family)
e(clustvar)
e(offset)
e(binomial)
e(intmethod)
e(n quad)
e(chi2type)
e(vce)
e(vcetype)
e(opt)
e(which)
e(ml method)
e(user)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)
Matrices
e(b)
e(Cns)
e(ilog)
e(gradient)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
e(V modelbased)
Functions
e(sample)

207

meprobit
command as typed
name of dependent variable
list of covariates
grouping variables
probit
title in estimation output
probit
bernoulli or binomial
name of cluster variable
offset
binomial number of trials
integration method
number of integration points
Wald; type of model 2
vcetype specified in vce()
title used to label Std. Err.
type of optimization
max or min; whether optimizer is to perform maximization or minimization
type of ml method
name of likelihood-evaluator program
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict
coefficient vector
constraints matrix
iteration log (up to 20 iterations)
gradient vector
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
model-based variance
marks estimation sample

Methods and formulas


Model (1) assumes Bernoulli data, a special case of the binomial. Because binomial data are also
supported by meprobit (option binomial()), the methods presented below are in terms of the more
general binomial mixed-effects model.
For a two-level binomial model, consider the response yij as the number of successes from a
series of rij Bernoulli trials (replications). For cluster j , j = 1, . . . , M , the conditional distribution
of yj = (yj1 , . . . , yjnj ) , given a set of cluster-level random effects uj , is
nj

f (yj |uj ) =
i=1

rij
yij

(ij )

yij

1 (ij )

rij yij

nj

yij log (ij ) (rij yij ) log (ij ) + log

= exp
i=1

for ij = xij + zij uj + offsetij .

rij
yij

208

meprobit Multilevel mixed-effects probit regression

Defining rj = (rj1 , . . . , rjnj ) and


nj

c (yj , rj ) =

log
i=1

rij
yij

where c(yj , rj ) does not depend on the model parameters, we can express the above compactly in
matrix notation,

f (yj |uj ) = exp yj log (j ) (rj yj ) log (j ) + c (yj , rj )


where j is formed by stacking the row vectors ij . We extend the definitions of (), log(), and
exp() to be vector functions where necessary.
Because the prior distribution of uj is multivariate normal with mean 0 and q q variance matrix
, the likelihood contribution for the j th cluster is obtained by integrating uj out of the joint density
f (yj , uj ),
1/2

Lj (, ) = (2)q/2 ||

f (yj |uj ) exp uj 1 uj /2 duj


(2)

= exp {c (yj , rj )} (2)q/2 ||


where

1/2

exp {g (, , uj )} duj

g (, , uj ) = yj log (j ) (rj yj ) log (j ) uj 1 uj /2

and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , rj , Xj , Zj ).
The integration in (2) has no closed form and thus must be approximated. meprobit offers
four approximation methods: meanvariance adaptive GaussHermite quadrature (default unless a
crossed random-effects model is fit), mode-curvature adaptive GaussHermite quadrature, nonadaptive
GaussHermite quadrature, and Laplacian approximation (default for crossed random-effects models).
The Laplacian approximation is based on a second-order Taylor expansion of g (, , uj ) about
the value of uj that maximizes it; see Methods and formulas in [ME] meglm for details.
Gaussian quadrature relies on transforming the multivariate integral in (2) into a set of nested
univariate integrals. Each univariate integral can then be evaluated using a form of Gaussian quadrature;
see Methods and formulas in [ME] meglm for details.
The log likelihood for the entire dataset is simply the sum of the contributions of the M individual
M
clusters, namely, L(, ) = j=1 Lj (, ).
Maximization of L(, ) is performed with respect to (, 2 ), where 2 is a vector comprising
the unique elements of . Parameter estimates are stored in e(b) as (, 2 ), with the corresponding
variancecovariance matrix stored in e(V).

References
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.
Guo, G., and H. Zhao. 2000. Multilevel modeling of binary data. Annual Review of Sociology 26: 441462.
Hedeker, D., and R. D. Gibbons. 2006. Longitudinal Data Analysis. Hoboken, NJ: Wiley.

meprobit Multilevel mixed-effects probit regression

209

Huq, N. M., and J. Cleland. 1990. Bangladesh Fertility Survey 1989 (Main Report). National Institute of Population
Research and Training.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Rabe-Hesketh, S., T. Toulopoulou, and R. M. Murray. 2001. Multilevel modeling of cognitive function in schizophrenic
patients and their first degree relatives. Multivariate Behavioral Research 36: 279298.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.

Also see
[ME] meprobit postestimation Postestimation tools for meprobit
[ME] mecloglog Multilevel mixed-effects complementary log-log regression
[ME] melogit Multilevel mixed-effects logistic regression
[ME] me Introduction to multilevel mixed-effects models
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtprobit Random-effects and population-averaged probit models
[U] 20 Estimation and postestimation commands

Title
meprobit postestimation Postestimation tools for meprobit
Description
Options for predict
Option for estat icc
Methods and formulas

Syntax for predict


Syntax for estat
Remarks and examples
Also see

Menu for predict


Menu for estat
Stored results

Description
The following postestimation commands are of special interest after meprobit:
Command

Description

estat group
estat icc

summarize the composition of the nested groups


estimate intraclass correlations

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

210

meprobit postestimation Postestimation tools for meprobit

211

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
estat icc displays the intraclass correlation for pairs of latent linear responses at each nested
level of the model. Intraclass correlations are available for random-intercept models or for randomcoefficient models conditional on random-effects covariates being equal to 0. They are not available
for crossed-effects models.

Syntax for predict


Syntax for obtaining predictions of random effects and their standard errors
predict

type

newvarsspec

if

in ,

remeans | remodes

reses(newvarsspec)

Syntax for obtaining other predictions


predict

type

newvarsspec

if

in

, statistic options

newvarsspec is stub* or newvarlist.


statistic

Description

Main

mu
fitted
xb
stdp
pearson
deviance
anscombe

predicted mean; the default


fitted linear predictor
linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction
Pearson residuals
deviance residuals
Anscombe residuals

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

212

meprobit postestimation Postestimation tools for meprobit

Description

options
Main

compute statistic using empirical Bayes means; the default


compute statistic using empirical Bayes modes
ignore the offset variable in calculating predictions; relevant only
if you specified offset() when you fit the model
prediction for the fixed portion of the model only

means
modes
nooffset
fixedonly
Integration

use # quadrature points to compute empirical Bayes means


set maximum number of iterations in computing statistics involving
empirical Bayes estimators
set convergence tolerance for computing statistics involving empirical
Bayes estimators

intpoints(#)
iterate(#)
tolerance(#)

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

Options for predict

Main

remeans, remodes, reses(); see [ME] meglm postestimation.


mu, the default, calculates the predicted mean (the probability of a positive outcome), that is, the
inverse link function applied to the linear prediction. By default, this is based on a linear predictor
that includes both the fixed effects and the random effects, and the predicted mean is conditional on
the values of the random effects. Use the fixedonly option if you want predictions that include
only the fixed portion of the model, that is, if you want random effects set to 0.
fitted, xb, stdp, pearson, deviance, anscombe, means, modes, nooffset, fixedonly; see
[ME] meglm postestimation.
By default or if the means option is specified, statistics mu, fitted, xb, stdp, pearson, deviance,
and anscombe are based on the posterior mean estimates of random effects. If the modes option
is specified, these statistics are based on the posterior mode estimates of random effects.

Integration

intpoints(), iterate(), tolerance(); see [ME] meglm postestimation.

meprobit postestimation Postestimation tools for meprobit

213

Syntax for estat


Summarize the composition of the nested groups
estat group
Estimate intraclass correlations
estat icc

, level(#)

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Option for estat icc


level(#) specifies the confidence level, as a percentage, for confidence intervals. The default is
level(95) or as set by set level; see [U] 20.7 Specifying the width of confidence intervals.

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a mixed-effects
probit model using meprobit. Here we show a short example of predicted probabilities and predicted
random effects; refer to [ME] meglm postestimation for additional examples.

Example 1
In example 2 of [ME] meprobit, we analyzed the cognitive ability (dtlm) of patients with
schizophrenia compared with their relatives and control subjects, by using a three-level probit model
with random effects at the family and subject levels. Cognitive ability was measured as the successful
completion of the Tower of London, a computerized task, measured at three levels of difficulty.
. use http://www.stata-press.com/data/r13/towerlondon
(Tower of London data)
. meprobit dtlm difficulty i.group || family: || subject:
(output omitted )

We obtain predicted probabilities based on the contribution of both fixed effects and random effects
by typing
. predict pr
(predictions based on fixed effects and posterior means of random effects)
(option mu assumed)
(using 7 quadrature points)

As the note says, the predicted values are based on the posterior means of random effects. You can
use the modes option to obtain predictions based on the posterior modes of random effects.
We obtain predictions of the posterior means themselves by typing
. predict re*, remeans
(calculating posterior means of random effects)
(using 7 quadrature points)

214

meprobit postestimation Postestimation tools for meprobit

Because we have one random effect at the family level and another random effect at the subject level,
Stata saved the predicted posterior means in the variables re1 and re2, respectively. If you are not
sure which prediction corresponds to which level, you can use the describe command to show the
variable labels.
Here we list the data for family 16:
. list family subject dtlm pr re1 re2 if family==16, sepby(subject)
family

subject

dtlm

pr

re1

re2

208.
209.
210.

16
16
16

5
5
5

1
0
0

.5301687
.1956408
.0367041

.5051272
.5051272
.5051272

.1001124
.1001124
.1001124

211.
212.
213.

16
16
16

34
34
34

1
1
1

.8876646
.6107262
.2572725

.5051272
.5051272
.5051272

.7798247
.7798247
.7798247

214.
215.
216.

16
16
16

35
35
35

0
1
0

.6561904
.2977437
.071612

.5051272
.5051272
.5051272

-.0322885
-.0322885
-.0322885

The predicted random effects at the family level (re1) are the same for all members of the family.
Similarly, the predicted random effects at the individual level (re2) are constant within each individual.
The predicted probabilities (pr) for this family seem to be in fair agreement with the response (dtlm)
based on a cutoff of 0.5.
We can use estat icc to estimate the residual intraclass correlation (conditional on the difficulty
level and the individuals category) between the latent responses of subjects within the same family
or between the latent responses of the same subject and family:
. estat icc
Residual intraclass correlation
Level

ICC

family
subject|family

.1352637
.3622485

Std. Err.

[95% Conf. Interval]

.1050492
.0877459

.0261998
.2124808

.4762821
.5445812

estat icc reports two intraclass correlations for this three-level nested model. The first is the
level-3 intraclass correlation at the family level, the correlation between latent measurements of the
cognitive ability in the same family. The second is the level-2 intraclass correlation at the subjectwithin-family level, the correlation between the latent measurements of cognitive ability in the same
subject and family.
There is not a strong correlation between individual realizations of the latent response, even within
the same subject.

meprobit postestimation Postestimation tools for meprobit

215

Stored results
estat icc stores the following in r():
Scalars
r(icc#)
r(se#)
r(level)

level-# intraclass correlation


standard errors of level-# intraclass correlation
confidence level of confidence intervals

Macros
r(label#)

label for level #

Matrices
r(ci#)

vector of confidence intervals (lower and upper) for level-# intraclass correlation

For a G-level nested model, # can be any integer between 2 and G.

Methods and formulas


Methods and formulas are presented under the following headings:
Prediction
Intraclass correlations

Prediction
Methods and formulas for predicting random effects and other statistics are given in Methods and
formulas of [ME] meglm postestimation.

Intraclass correlations
Consider a simple, two-level random-intercept model, stated in terms of a latent linear response,

where only yij = I(yij


> 0) is observed for the latent variable,
(2)

(1)
ij

yij
= + uj +

(2)

with i = 1, . . . , nj and level-2 groups j = 1, . . . , M . Here is an unknown fixed intercept, uj


(1)
ij

is

a level-2 random intercept, and


is a level-1 error term. Errors are assumed to be distributed as
standard normal with mean 0 and variance 1; random intercepts are assumed to be normally distributed
with mean 0 and variance 22 and to be independent of error terms.
The intraclass correlation for this model is

= Corr(yij
, yi j ) =

22
1 + 22

It corresponds to the correlation between the latent responses i and i from the same group j .
Now consider a three-level nested random-intercept model,
(2)

(3)

yijk
= + ujk + uk +

(1)
ijk

216

meprobit postestimation Postestimation tools for meprobit

for measurements i = 1, . . . , njk and level-2 groups j = 1, . . . , M1k nested within level-3 groups
(2)
(3)
(1)
k = 1, . . . , M2 . Here ujk is a level-2 random intercept, uk is a level-3 random intercept, and ijk
is a level-1 error term. The error terms have a standard normal distribution with mean 0 and variance
1. The random intercepts are assumed to be normally distributed with mean 0 and variances 22 and
32 , respectively, and to be mutually independent. The error terms are also independent of the random
intercepts.
We can consider two types of intraclass correlations for this model. We will refer to them as
level-2 and level-3 intraclass correlations. The level-3 intraclass correlation is

(3) = Corr(yijk
, yi j k ) =

32
1 + 22 + 32

This is the correlation between latent responses i and i from the same level-3 group k and from
different level-2 groups j and j .
The level-2 intraclass correlation is

(2) = Corr(yijk
, yi jk ) =

22 + 32
1 + 22 + 32

This is the correlation between latent responses i and i from the same level-3 group k and level-2
group j . (Note that level-1 intraclass correlation is undefined.)
More generally, for a G-level nested random-intercept model, the g -level intraclass correlation is
defined as
G
2
l=g l
(g)
=
G
1 + l=2 l2
The above formulas also apply in the presence of fixed-effects covariates X in a randomeffects model. In this case, intraclass correlations are conditional on fixed-effects covariates and are
referred to as residual intraclass correlations. estat icc also uses the same formulas to compute
intraclass correlations for random-coefficient models, assuming 0 baseline values for the random-effects
covariates, and labels them as conditional intraclass correlations.
Intraclass correlations will always fall in [0,1] because variance components are nonnegative. To
accommodate the range of an intraclass correlation, we use the logit transformation to obtain confidence
intervals. We use the delta method to estimate the standard errors of the intraclass correlations.
Let (g) be a point estimate of the intraclass correlation and SE((g) ) be its standard error. The
(1 ) 100% confidence interval for logit((g) ) is
logit((g) ) z/2

SE((g) )

(g) (1

(g) )

where z/2 is the 1 /2 quantile of the standard normal distribution and logit(x) = ln{x/(1 x)}.
Let ku be the upper endpoint of this interval, and let kl be the lower. The (1 ) 100% confidence
interval for (g) is then given by

1
1
,
1 + ekl 1 + eku

meprobit postestimation Postestimation tools for meprobit

Also see
[ME] meprobit Multilevel mixed-effects probit regression
[ME] meglm postestimation Postestimation tools for meglm
[U] 20 Estimation and postestimation commands

217

Title
meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
meqrlogit depvar fe equation || re equation || re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname , re options
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

noconstant
offset(varname)

suppress constant term from the fixed-effects equation


include varname in model with coefficient constrained to 1

re options

Description

Model

covariance(vartype)
noconstant
collinear

variancecovariance structure of the random effects


suppress constant term from the random-effects equation
keep collinear variables

218

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

options

219

Description

Model

binomial(varname | #)

set binomial trials if data are in binomial form

Reporting

level(#)
or
variance
stddeviations
noretable
nofetable
estmetric
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


report fixed-effects coefficients as odds ratios
show random-effects parameter estimates as variances and
covariances; the default
show random-effects parameter estimates as standard deviations
and correlations
suppress random-effects table
suppress fixed-effects table
show parameter estimates in the estimation metric
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with logistic
regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intpoints(# [ # . . . ] )
laplace

set the number of integration (quadrature) points;


default is intpoints(7)
use Laplacian approximation; equivalent to intpoints(1)

Maximization

control the maximization process; seldom used


tolerance for random-effects estimates; default is
retolerance(1e-8); seldom used
maximum number of iterations for random-effects estimation;
reiterate(#)
default is reiterate(50); seldom used
matsqrt
parameterize variance components using matrix square roots;
the default
matlog
parameterize variance components using matrix logarithms
refineopts(maximize options) control the maximization process during refinement of starting
values

maximize options
retolerance(#)

coeflegend

display legend instead of statistics

220

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances
0; the default if the R. notation is used
all variances and covariances to be distinctly estimated

exchangeable
identity
unstructured

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
indepvars and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
bootstrap, by, jackknife, mi estimate, rolling, and statsby are allowed; see [U] 11.1.10 Prefix commands.
coeflegend does not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Estimation by QR decomposition

>

Logistic regression

Description
meqrlogit, like melogit, fits mixed-effects models for binary or binomial responses. The
conditional distribution of the response given the random effects is assumed to be Bernoulli, with
success probability determined by the logistic cumulative distribution function.
meqrlogit provides an alternative estimation method, which uses the QR decomposition of the
variance-components matrix. This method may aid convergence when variance components are near
the boundary of the parameter space.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
offset(varname) specifies that varname be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, and unstructured.
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent), except when the R. notation is used, in which case the default is
covariance(identity) and only covariance(identity) and covariance(exchangeable)
are allowed.
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

221

covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.
covariance(unstructured) allows for all variances and covariances to be distinct. If an equation
consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2 unique
parameters.
collinear specifies that meqrlogit not omit collinear variables from the random-effects equation.
Usually, there is no reason to leave collinear variables in place; in fact, doing so usually causes
the estimation to fail because of the matrix singularity caused by the collinearity. However, with
certain models (for example, a random-effects model with a full set of contrasts), the variables
may be collinear, yet the model is fully identified because of restrictions on the random-effects
covariance structure. In such cases, using the collinear option allows the estimation to take
place with the random-effects equation intact.
binomial(varname | #) specifies that the data are in binomial form; that is, depvar records the number
of successes from a series of binomial trials. This number of trials is given either as varname,
which allows this number to vary over the observations, or as the constant #. If binomial() is
not specified (the default), depvar is treated as Bernoulli, with any nonzero, nonmissing values
indicating positive responses.

Reporting

level(#); see [R] estimation options.


or reports estimated fixed-effects coefficients transformed to odds ratios, that is, exp() rather than .
Standard errors and confidence intervals are similarly transformed. This option affects how results
are displayed, not how they are estimated. or may be specified either at estimation or upon replay.
variance, the default, displays the random-effects parameter estimates as variances and covariances.
stddeviations displays the random-effects parameter estimates as standard deviations and correlations.
noretable suppresses the random-effects table.
nofetable suppresses the fixed-effects table.
estmetric displays all parameter estimates in the estimation metric. Fixed-effects estimates are
unchanged from those normally displayed, but random-effects parameter estimates are displayed
as log-standard deviations and hyperbolic arctangents of correlations, with equation names that
organize them by model level.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents meqrlogit from performing a likelihood-ratio test that compares the mixed-effects
logistic model with standard (marginal) logistic regression. This option may also be specified upon
replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

Integration

intpoints(# [ # . . . ] ) sets the number of integration points for adaptive Gaussian quadrature. The
more integration points, the more accurate the approximation to the log likelihood. However,

222

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

computation time increases with the number of quadrature points, and in models with many levels
or many random coefficients, this increase can be substantial.
You may specify one number of integration points applying to all levels of random effects in
the model, or you may specify distinct numbers of points for each level. intpoints(7) is the
default; that is, by default seven quadrature points are used for each level.
laplace specifies that log likelihoods be calculated using the Laplacian approximation, equivalent
to adaptive Gaussian quadrature with one integration point for each level in the model; laplace
is equivalent to intpoints(1). Computation time increases as a function of the number of
quadrature points raised to a power equaling the dimension of the random-effects specification.
The computational time saved by using laplace can thus be substantial, especially when you
have many levels or random coefficients.
The Laplacian approximation has been known to produce biased parameter estimates, but the bias
tends to be more prominent in the estimates of the variance components rather than in the estimates
of the fixed effects. If your interest lies primarily with the fixed-effects estimates, the Laplace
approximation may be a viable faster alternative to adaptive quadrature with multiple integration
points.
When the R.varname notation is used, the dimension of the random effects increases by the
number of distinct values of varname. Even when this number is small to moderate, it increases
the total random-effects dimension to the point where estimation with more than one quadrature
point is prohibitively intensive.
For this reason, when you use the R. notation in your random-effects equations, the laplace
option is assumed. You can override this behavior by using the intpoints() option, but doing
so is not recommended.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for meqrlogit are listed below.
For the technique() option, the default is technique(nr). The bhhh algorithm may not be
specified.
from(init specs) is particularly useful when combined with refineopts(iterate(0)) (see the
description below), which bypasses the initial optimization stage.
retolerance(#) specifies the convergence tolerance for the estimated random effects used by adaptive
Gaussian quadrature. Although not estimated as model parameters, random-effects estimators are
used to adapt the quadrature points. Estimating these random effects is an iterative procedure,
with convergence declared when the maximum relative change in the random effects is less than
retolerance(). The default is retolerance(1e-8). You should seldom have to use this option.
reiterate(#) specifies the maximum number of iterations used when estimating the random effects
to be used in adapting the Gaussian quadrature points; see the retolerance() option. The default
is reiterate(50). You should seldom have to use this option.
matsqrt (the default), during optimization, parameterizes variance components by using the matrix
square roots of the variancecovariance matrices formed by these components at each model level.
matlog, during optimization, parameterizes variance components by using the matrix logarithms of
the variancecovariance matrices formed by these components at each model level.

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

223

The matsqrt parameterization ensures that variancecovariance matrices are positive semidefinite,
while matlog ensures matrices that are positive definite. For most problems, the matrix square root
is more stable near the boundary of the parameter space. However, if convergence is problematic,
one option may be to try the alternate matlog parameterization. When convergence is not an issue,
both parameterizations yield equivalent results.
refineopts(maximize options) controls the maximization process during the refinement of starting
values. Estimation in meqrlogit takes place in two stages. In the first stage, starting values
are refined by holding the quadrature points fixed between iterations. During the second stage,
quadrature points are adapted with each evaluation of the log likelihood. Maximization options
specified within refineopts() control the first stage of optimization; that is, they control the
refining of starting values.
maximize options specified outside refineopts() control the second stage.
The one exception to the above rule is the nolog option, which when specified outside refineopts() applies globally.
from(init specs) is not allowed within refineopts() and instead must be specified globally.
Refining starting values helps make the iterations of the second stage (those that lead toward the solution) more numerically stable. In this regard, of particular interest is refineopts(iterate(#)),
with two iterations being the default. Should the maximization fail because of instability in the
Hessian calculations, one possible solution may be to increase the number of iterations here.
The following option is available with meqrlogit but is not shown in the dialog box:
coeflegend; see [R] estimation options.

Remarks and examples


Remarks are presented under the following headings:
Introduction
Two-level models
Other covariance structures
Three-level models
Crossed-effects models

Introduction
Mixed-effects logistic regression is logistic regression containing both fixed effects and random
effects. In longitudinal data and panel data, random effects are useful for modeling intracluster
correlation; that is, observations in the same cluster are correlated because they share common
cluster-level random effects.
meqrlogit allows for not just one, but many levels of nested clusters of random effects. For
example, in a three-level model you can specify random effects for schools and then random effects
for classes nested within schools. In this model, the observations (presumably, the students) comprise
the first level, the classes comprise the second level, and the schools comprise the third.
However, for simplicity, for now we consider the two-level model, where for a series of M
independent clusters, and conditional on a set of random effects uj ,
Pr(yij = 1|uj ) = H (xij + zij uj )

(1)

224

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

for j = 1, . . . , M clusters, with cluster j consisting of i = 1, . . . , nj observations. The responses are


the binary-valued yij , and we follow the standard Stata convention of treating yij = 1 if depvarij = 0
and treating yij = 0 otherwise. The 1 p row vector xij are the covariates for the fixed effects,
analogous to the covariates you would find in a standard logistic regression model, with regression
coefficients (fixed effects) .
The 1 q vector zij are the covariates corresponding to the random effects and can be used to
represent both random intercepts and random coefficients. For example, in a random-intercept model,
zij is simply the scalar 1. The random effects uj are M realizations from a multivariate normal
distribution with mean 0 and q q variance matrix . The random effects are not directly estimated
as model parameters but are instead summarized according to the unique elements of , known
as variance components. One special case of (1) places zij = xij so that all covariate effects are
essentially random and distributed as multivariate normal with mean and variance .
Finally, because this is logistic regression, H() is the logistic cumulative distribution function, which
maps the linear predictor to the probability of a success (yij = 1), with H(v) = exp(v)/{1 +exp(v)}.

Model (1) may also be stated in terms of a latent linear response, where only yij = I(yij
> 0)
is observed for the latent

yij
= xij + zij uj + ij

The errors

ij

are distributed as logistic with mean 0 and variance 2 /3 and are independent of uj .

Model (1) is an example of a generalized linear mixed model (GLMM), which generalizes the
linear mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using
mixed and fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there
is insight to be gained through examination of the linear mixed model. This is especially true for
Stata users because the terminology, syntax, options, and output for fitting these types of models are
nearly identical. See [ME] mixed and the references therein, particularly in Introduction, for more
information.
Multilevel models with binary responses have been used extensively in the health and social
sciences. As just one example, Leyland and Goldstein (2001, sec. 3.6) describe a study of equity
of healthcare in Great Britain. Multilevel models with binary and other limited dependent responses
also have a long history in econometrics; Rabe-Hesketh, Skrondal, and Pickles (2005) provide an
excellent survey.
Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out the
random effects. One widely used modern method is to directly estimate the integral required to calculate
the log likelihood by GaussHermite quadrature or some variation thereof. The estimation method
used by meqrlogit is a multicoefficient and multilevel extension of one of these quadrature types,
namely, adaptive Gaussian quadrature (AGQ) based on conditional modes, with the multicoefficient
extension from Pinheiro and Bates (1995) and the multilevel extension from Pinheiro and Chao (2006);
see Methods and formulas.

Two-level models
We begin with a simple application of (1) as a two-level model, because a one-level model, in our
terminology, is just standard logistic regression; see [R] logistic.

Example 1
Ng et al. (2006) analyze a subsample of data from the 1989 Bangladesh fertility survey (Huq and
Cleland 1990), which polled 1,934 Bangladeshi women on their use of contraception.

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

225

. use http://www.stata-press.com/data/r13/bangladesh
(Bangladesh Fertility Survey, 1989)
. describe
Contains data from http://www.stata-press.com/data/r13/bangladesh.dta
obs:
1,934
Bangladesh Fertility Survey,
1989
vars:
7
28 May 2013 20:27
size:
19,340
(_dta has notes)

variable name
district
c_use
urban
age
child1
child2
child3
Sorted by:

storage
type
byte
byte
byte
float
byte
byte
byte

display
format
%9.0g
%9.0g
%9.0g
%6.2f
%9.0g
%9.0g
%9.0g

value
label

yesno
urban

variable label
District
Use contraception
Urban or rural
Age, mean centered
1 child
2 children
3 or more children

district

The women sampled were from 60 districts, identified by the variable district. Each district
contained either urban or rural areas (variable urban) or both. The variable c use is the binary
response, with a value of 1 indicating contraceptive use. Other covariates include mean-centered age
and three indicator variables recording number of children.
Consider a standard logistic regression model, amended to have random effects for each district.
Defining ij = Pr(c useij = 1), we have
logit(ij ) = 0 + 1 urbanij + 2 ageij + 3 child1ij + 4 child2ij + 5 child3ij + uj
for j = 1, . . . , 60 districts, with i = 1, . . . , nj women in district j .

(2)

226

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)


. meqrlogit c_use urban age child* || district:
Refining starting values:
Iteration 0:
Iteration 1:
Iteration 2:

log likelihood = -1219.2682


log likelihood = -1209.3544
log likelihood = -1207.1912

Performing gradient-based optimization:


Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:

log
log
log
log

likelihood
likelihood
likelihood
likelihood

=
=
=
=

-1207.1912
-1206.8323
-1206.8322
-1206.8322

Mixed-effects logistic regression


Group variable: district

Number of obs
Number of groups

Integration points =
7
Log likelihood = -1206.8322
c_use

Coef.

urban
age
child1
child2
child3
_cons

.7322764
-.0264982
1.116002
1.365895
1.344031
-1.68929

=
=

1934
60

Obs per group: min =


avg =
max =

2
32.2
118

Wald chi2(5)
Prob > chi2
Std. Err.
.1194857
.0078916
.1580921
.174669
.1796549
.1477592

z
6.13
-3.36
7.06
7.82
7.48
-11.43

P>|z|
0.000
0.001
0.000
0.000
0.000
0.000

=
=

109.60
0.0000

[95% Conf. Interval]


.4980887
-.0419654
.8061466
1.02355
.9919141
-1.978892

.9664641
-.0110309
1.425856
1.70824
1.696148
-1.399687

Random-effects Parameters

Estimate

Std. Err.

[95% Conf. Interval]

district: Identity
var(_cons)

.2156188

.0733234

.1107202

LR test vs. logistic regression: chibar2(01) =

.4199007

43.39 Prob>=chibar2 = 0.0000

Notes:
1. The estimation log consists of two parts:
(a) A set of iterations aimed at refining starting values. These are designed to be relatively quick
iterations aimed at getting the parameter estimates within a neighborhood of the eventual
solution, making the iterations in (b) more numerically stable.
(b) A set of gradient-based iterations. By default, these are NewtonRaphson iterations, but other
methods are available by specifying the appropriate maximize options; see [R] maximize.
2. The first estimation table reports the fixed effects, and these can be interpreted just as you would
the output from logit. You can also specify the or option at estimation or on replay to display
the fixed effects as odds ratios instead.
If you did display results as odds ratios, you would find urban women to have roughly double the
odds of using contraception as that of their rural counterparts. Having any number of children will
increase the odds from three- to fourfold when compared with the base category of no children.
Contraceptive use also decreases with age.
3. The second estimation table shows the estimated variance components. The first section of the table
is labeled district: Identity, meaning that these are random effects at the district level
and that their variancecovariance matrix is a multiple of the identity matrix; that is, = u2 I.

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

227

Because we have only one random effect at this level, meqrlogit knew that Identity is the
only possible covariance structure. In any case, u2 was estimated as 0.22 with standard error 0.07.
If you prefer standard deviation estimates u to variance estimates u2 , specify the stddeviations
option either at estimation or on replay.
4. A likelihood-ratio test comparing the model to ordinary logistic regression, (2) without uj , is
provided and is highly significant for these data.
5. Finally, because (2) is a simple random-intercept model, you can also fit it with xtlogit, specifying
the re option.
We now store our estimates for later use.
. estimates store r_int

In what follows, we will be extending (2), focusing on the variable urban. Before we begin, to
keep things short we restate (2) as
logit(ij ) = 0 + 1 urbanij + Fij + uj
where Fij is merely shorthand for the portion of the fixed-effects specification having to do with age
and children.

Example 2
Extending (2) to allow for a random slope on the indicator variable urban yields the model
logit(ij ) = 0 + 1 urbanij + Fij + uj + vj urbanij

(3)

which we can fit by typing


. meqrlogit c_use urban age child* || district: urban
(output omitted )
. estimates store r_urban

Extending the model was as simple as adding urban to the random-effects specification so that
the model now includes a random intercept and a random coefficient on urban. We dispense with
the output because, although this is an improvement over the random-intercept model (2),
. lrtest r_int r_urban
Likelihood-ratio test
LR chi2(1) =
3.66
(Assumption: r_int nested in r_urban)
Prob > chi2 =
0.0558
Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

we find the default covariance structure for (uj , vj ), covariance(Independent),


= Var

uj
vj

u2
0

0
v2

to be inadequate. We state that the random-coefficient model is an improvement over the randomintercept model because the null hypothesis of the likelihood-ratio comparison test (H0 : v2 = 0) is
on the boundary of the parameter test. This makes the reported p-value, 5.6%, an upper bound on
the actual p-value, which is actually half of that; see Distribution theory for likelihood-ratio test in
[ME] me.

228

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

We see below that we can reject this model in favor of one that allows correlation between uj
and vj .
. meqrlogit c_use urban age child* || district: urban, covariance(unstructured)
Refining starting values:
Iteration 0:
log likelihood = -1215.8594 (not concave)
Iteration 1:
log likelihood = -1204.0802
Iteration 2:
log likelihood = -1199.798
Performing gradient-based optimization:
Iteration 0:
log likelihood = -1199.798
Iteration 1:
log likelihood = -1199.4744
Iteration 2:
log likelihood = -1199.3158
Iteration 3:
log likelihood = -1199.315
Iteration 4:
log likelihood = -1199.315
Mixed-effects logistic regression
Number of obs
=
1934
Group variable: district
Number of groups
=
60
Obs per group: min =
2
avg =
32.2
max =
118
Integration points =
7
Wald chi2(5)
=
97.50
Log likelihood = -1199.315
Prob > chi2
=
0.0000
c_use

Coef.

urban
age
child1
child2
child3
_cons

.8157872
-.026415
1.13252
1.357739
1.353827
-1.71165

Std. Err.
.171552
.008023
.1603285
.1770522
.1828801
.1605617

P>|z|

4.76
-3.29
7.06
7.67
7.40
-10.66

[95% Conf. Interval]

0.000
0.001
0.000
0.000
0.000
0.000

Random-effects Parameters

Estimate

Std. Err.

district: Unstructured
var(urban)
var(_cons)
cov(urban,_cons)

.6663222
.3897434
-.4058846

.3224715
.1292459
.1755418

.4795516
-.0421398
.8182819
1.010723
.9953881
-2.026345

1.152023
-.0106902
1.446758
1.704755
1.712265
-1.396954

[95% Conf. Interval]

.2580709
.2034723
-.7499403

1.7204
.7465388
-.0618289

LR test vs. logistic regression:


chi2(3) =
58.42
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.
. estimates store r_urban_corr
. lrtest r_urban r_urban_corr
Likelihood-ratio test
(Assumption: r_urban nested in r_urban_corr)

LR chi2(1) =
Prob > chi2 =

11.38
0.0007

By specifying covariance(unstructured) above, we told meqrlogit to allow correlation between


random effects at the district level; that is,
= Var

uj
vj

u2
uv

uv
v2

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

229

Example 3
The purpose of introducing a random coefficient on the binary variable urban in (3) was to allow
for separate random effects, within each district, for the urban and rural areas of that district. Hence,
if we have the binary variable rural in our data such that ruralij = 1 urbanij , then we can
reformulate (3) as
logit(ij ) = 0 ruralij + (0 + 1 )urbanij + Fij + uj ruralij + (uj + vj )urbanij

(3a)

where we have translated both the fixed portion and the random portion to be in terms of rural
rather than a random intercept. Translating the fixed portion is not necessary to make the point we
make below, but we do so anyway for uniformity.
Translating the estimated random-effects parameters from the previous output to ones appropriate
for (3a), we get Var(uj ) = u2 = 0.39,
Var(uj + vj ) = u2 + v2 + 2uv

= 0.39 + 0.67 2(0.41) = 0.24


and Cov(uj , uj + vj ) = u2 + uv = 0.39 0.41 = 0.02.
An alternative that does not require remembering how to calculate variances and covariances
involving sumsand one that also gives you standard errorsis to let Stata do the work for you:
. generate byte rural = 1 - urban
. meqrlogit c_use rural urban age child*, noconstant || district: rural urban,
> noconstant cov(unstr)
(output omitted )
Mixed-effects logistic regression
Group variable: district

Number of obs
Number of groups

Integration points =
7
Log likelihood = -1199.315
c_use

Coef.

rural
urban
age
child1
child2
child3

-1.71165
-.8958623
-.026415
1.13252
1.357739
1.353827

=
=

1934
60

Obs per group: min =


avg =
max =

2
32.2
118

Wald chi2(6)
Prob > chi2
Std. Err.
.1605618
.1704961
.008023
.1603285
.1770522
.1828801

z
-10.66
-5.25
-3.29
7.06
7.67
7.40

P>|z|
0.000
0.000
0.001
0.000
0.000
0.000

Random-effects Parameters

Estimate

Std. Err.

district: Unstructured
var(rural)
var(urban)
cov(rural,urban)

.3897439
.2442965
-.0161411

.1292459
.1450673
.1057469

LR test vs. logistic regression:

chi2(3) =

58.42

=
=

120.24
0.0000

[95% Conf. Interval]


-2.026345
-1.230028
-.0421398
.818282
1.010724
.9953882

-1.396954
-.5616961
-.0106902
1.446758
1.704755
1.712265

[95% Conf. Interval]

.2034726
.0762886
-.2234011

.7465394
.7823029
.1911189

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.

230

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

The above output demonstrates an equivalent fit to that we displayed for model (3), with the added
benefit of a more direct comparison of the parameters for rural and urban areas.

Technical note
We used the binary variables rural and urban instead of the factor notation i.urban because,
although supported in the fixed-effects specification of the model, such notation is not supported in
random-effects specifications.

Technical note
Our model fits for (3) and (3a) are equivalent only because we allowed for correlation in the
random effects for both. Had we used the default Independent covariance structure, we would be
fitting different models; in (3) we would be making the restriction that Cov(uj , vj ) = 0, whereas in
(3a) we would be assuming that Cov(uj , uj + vj ) = 0.
The moral here is that although meqrlogit will do this by default, one should be cautious when
imposing an independent covariance structure, because the correlation between random effects is not
invariant to model translations that would otherwise yield equivalent results in standard regression
models. In our example, we remapped an intercept and binary coefficient to two complementary
binary coefficients, something we could do in standard logistic regression without consequence but
that here required more consideration.
Rabe-Hesketh and Skrondal (2012, sec. 11.4) provide a nice discussion of this phenomenon in the
related case of recentering a continuous covariate.

Other covariance structures


In the above examples, we demonstrated the Independent and Unstructured covariance structures. Also available are Identity (seen previously in output but not directly specified), which
restricts random effects to be uncorrelated and share a common variance, and Exchangeable, which
assumes a common variance and a common pairwise covariance.
You can also specify multiple random-effects equations at the same level, in which case the above
four covariance types can be combined to form more complex blocked-diagonal covariance structures.
This could be used, for example, to impose an equality constraint on a subset of variance components
or to otherwise group together a set of related random effects.
Continuing the previous example, typing
. meqrlogit c_use urban age child* || district: child*, cov(exchangeable) ||
> district:

would fit a model with the same fixed effects as (3) but with random-effects structure
logit(ij ) = 0 + + u1j child1ij + u2j child2ij + u3j child3ij + vj
That is, we have random coefficients on each indicator variable for children (the first district:
specification) and an overall district random intercept (the second district: specification). The
above syntax fits a model with overall covariance structure

u1j
u c c 0
2
u u c 0
= Var 2j = c

u3j
c c u2 0
2
vj
0
0
0 v

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

231

reflecting the relationship among the random coefficients for children. We did not have to specify
noconstant on the first district: specification. meqrlogit automatically avoids collinearity by
including an intercept on only the final specification among repeated-level equations.
Of course, if we fit the above model, we would heed our own advice from the previous technical
note and make sure that not only our data but also our specification characterization of the random
effects permitted the above structure. That is, we would check the above against a model that had
an Unstructured covariance for all four random effects and then perhaps against a model that
assumed an Unstructured covariance among the three random coefficients on children, coupled
with independence with the random intercept. All comparisons can be made by storing estimates
(command estimates store) and then using lrtest, as demonstrated previously.

Three-level models
The methods we have discussed so far extend from two-level models to models with three or more
levels with nested random effects.

Example 4
Rabe-Hesketh, Toulopoulou, and Murray (2001) analyzed data from a study measuring the cognitive
ability of patients with schizophrenia compared with their relatives and control subjects. Cognitive
ability was measured as the successful completion of the Tower of London, a computerized task,
measured at three levels of difficulty. For all but one of the 226 subjects, there were three measurements
(one for each difficulty level). Because patients relatives were also tested, a family identifier, family,
was also recorded.
. use http://www.stata-press.com/data/r13/towerlondon, clear
(Tower of London data)
. describe
Contains data from http://www.stata-press.com/data/r13/towerlondon.dta
obs:
677
Tower of London data
vars:
5
31 May 2013 10:41
size:
4,739
(_dta has notes)

variable name
family
subject
dtlm
difficulty
group

Sorted by:

storage
type
int
int
byte
byte
byte

family

display
format
%8.0g
%9.0g
%9.0g
%9.0g
%8.0g

value
label

variable label
Family ID
Subject ID
1 = task completed
Level of difficulty: -1, 0, or 1
1: controls; 2: relatives; 3:
schizophrenics

subject

We fit a logistic model with response dtlm, the indicator of cognitive function, and with covariates
difficulty and a set of indicator variables for group, with the controls (group==1) being the base
category. We allow for random effects due to families and due to subjects within families, and we
request to see odds ratios.

232

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)


. meqrlogit dtlm difficulty i.group || family: || subject: , or
Refining starting values:
Iteration 0:
Iteration 1:
Iteration 2:

log likelihood = -310.28433


log likelihood = -306.42785
log likelihood = -305.26009

(not concave)

Performing gradient-based optimization:


Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:

log
log
log
log

likelihood
likelihood
likelihood
likelihood

=
=
=
=

-305.26009
-305.12089
-305.12043
-305.12043

Mixed-effects logistic regression

Group Variable

No. of
Groups

family
subject

118
226

Number of obs

Observations per Group


Minimum
Average
Maximum
2
2

5.7
3.0

=
Integration
Points

27
3
Wald chi2(3)
Prob > chi2

Log likelihood = -305.12043


Std. Err.

P>|z|

7
7
=
=

74.89
0.0000

dtlm

Odds Ratio

difficulty

.192337

.0371622

-8.53

0.000

.131704

.2808839

group
2
3

.7798295
.3491338

.2763766
.1396499

-0.70
-2.63

0.483
0.009

.3893394
.1594117

1.561964
.7646517

_cons

.2263075

.064463

-5.22

0.000

.1294902

.3955132

Random-effects Parameters

677

[95% Conf. Interval]

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

.569182

.5216584

.0944323

3.430694

var(_cons)

1.137931

.6857496

.3492673

3.70744

family: Identity

subject: Identity

LR test vs. logistic regression:

chi2(2) =

17.54

Prob > chi2 = 0.0002

Note: LR test is conservative and provided only for reference.

Notes:
1. This is a three-level model with two random-effects equations, separated by ||. The first is a
random intercept (constant only) at the family level, and the second is a random intercept at the
subject level. The order in which these are specified (from left to right) is significantmeqrlogit
assumes that subject is nested within family.
2. The information on groups is now displayed as a table, with one row for each upper level. Among
other things, we see that we have 226 subjects from 118 families. Also the number of integration
points for adaptive Gaussian quadrature is displayed within this table, because you can choose
to have it vary by model level. As with two-level models, the default is seven points. You can
suppress this table with the nogroup or the noheader option, which will suppress the rest of the
header as well.
3. The variance-component estimates are now organized and labeled according to level.

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

233

After adjusting for the random-effects structure, the odds of successful completion of the Tower of
London decrease dramatically as the level of difficulty increases. Also, schizophrenics (group==3)
tended not to perform as well as the control subjects. Of course, we would make similar conclusions
from a standard logistic model fit to the same data, but the odds ratios would differ somewhat.

Technical note
In the previous example, the subjects are coded with unique values between 1 and 251 (with some
gaps), but such coding is not necessary to produce nesting within families. Once we specified the
nesting structure to meqrlogit, all that was important was the relative coding of subject within
each unique value of family. We could have coded subjects as the numbers 1, 2, 3, and so on,
restarting at 1 with each new family, and meqrlogit would have produced the same results.
Group identifiers may also be coded using string variables.

The above extends to models with more than two levels of nesting in the obvious manner, by
adding more random-effects equations, each separated by ||. The order of nesting goes from left to
right as the groups go from biggest (highest level) to smallest (lowest level).

Crossed-effects models
Not all mixed-effects models contain nested random effects.

Example 5
Rabe-Hesketh and Skrondal (2012, 443460) perform an analysis on school data from Fife,
Scotland. The data, originally from Paterson (1991), are from a study measuring students attainment
as an integer score from 1 to 10, based on the Scottish school exit examination taken at age 16. The
study comprises 3,435 students who first attended any one of 148 primary schools and then any one
of 19 secondary schools.
. use http://www.stata-press.com/data/r13/fifeschool
(School data from Fife, Scotland)
. describe
Contains data from http://www.stata-press.com/data/r13/fifeschool.dta
obs:
3,435
School data from Fife, Scotland
vars:
5
28 May 2013 10:08
size:
24,045
(_dta has notes)

variable name

storage
type

display
format

pid
sid
attain
vrq

int
byte
byte
int

%9.0g
%9.0g
%9.0g
%9.0g

sex

byte

%9.0g

value
label

Sorted by:
. generate byte attain_gt_6 = attain > 6

variable label
Primary school ID
Secondary school ID
Attainment score at age 16
Verbal-reasoning score from final
year of primary school
1: female; 0: male

234

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

To make the analysis relevant to our present discussion, we focus not on the attainment score itself
but instead on whether the score is greater than 6. We wish to model this indicator as a function of
the fixed effect sex and of random effects due to primary and secondary schools.
For this analysis, it would make sense to assume that the random effects are not nested, but instead
crossed, meaning that the effect due to primary school is the same regardless of the secondary school
attended. Our model is thus
logit{Pr(attainijk > 6)} = 0 + 1 sexijk + uj + vk

(4)

for student i, i = 1, . . . , njk , who attended primary school j , j = 1, . . . , 148, and then secondary
school k , k = 1, . . . , 19.
Because there is no evident nesting, one solution would be to consider the data as a whole and
fit a two-level, one-cluster model with random-effects structure

u1
..
.

u
u = 148 N (0, );
v1
.
..
v19

u2 I148
0

0
v2 I19

We can fit such a model by using the group designation all:, which tells meqrlogit to treat the
whole dataset as one cluster, and the R.varname notation, which mimics the creation of indicator
variables identifying schools:
. meqrlogit attain_gt_6 sex || _all:R.pid || _all:R.sid, or

But we do not recommend fitting the model this way because of high total dimension (148 + 19 = 167)
of the random effects. This would require working with matrices of column dimension 167, which is
probably not a problem for most current hardware, but would be a problem if this number got much
larger.
An equivalent way to fit (4) that has a smaller dimension is to treat the clusters identified by
primary schools as nested within all the data, that is, as nested within the all group.

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)


. meqrlogit attain_gt_6 sex || _all:R.sid || pid:, or
Note: factor variables specified; option laplace assumed
(output omitted )
Mixed-effects logistic regression
Number of obs

Group Variable

No. of
Groups

_all
pid

1
148

Observations per Group


Minimum
Average
Maximum
3435
1

3435.0
23.2

Odds Ratio

sex
_cons

1.32512
.5311497

Std. Err.
.0986967
.0622641

Random-effects Parameters

z
3.78
-5.40

3435

Integration
Points

3435
72

1
1

Wald chi2(1)
Prob > chi2

Log likelihood = -2220.0035


attain_gt_6

235

=
=

14.28
0.0002

P>|z|

[95% Conf. Interval]

0.000
0.000

1.145135
.4221188

1.533395
.6683427

Estimate

Std. Err.

[95% Conf. Interval]

var(R.sid)

.1239738

.0694742

.0413353

.371825

var(_cons)

.4520502

.0953867

.298934

.6835936

_all: Identity

pid: Identity

LR test vs. logistic regression:


chi2(2) =
195.80
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.
Note: log-likelihood calculations are based on the Laplacian approximation.

Choosing the primary schools as those to nest was no accident; because there are far fewer secondary
schools than primary schools, the above required only 19 random coefficients for the secondary
schools and one random intercept at the primary school level, for a total dimension of 20. Our data
also include a measurement of verbal reasoning, the variable vrq. Adding a fixed effect due to vrq in
(4) would negate the effect due to secondary school, a fact we leave to you to verify as an exercise.

See [ME] mixed for a similar discussion of crossed effects in the context of linear mixed models.
Also see Rabe-Hesketh and Skrondal (2012) for more examples of crossed-effects models, including
models with random interactions, and for more techniques on how to avoid high-dimensional estimation.

Technical note
The estimation in the previous example was performed using a Laplacian approximation, even
though we did not specify this. Whenever the R. notation is used in random-effects specifications,
estimation reverts to the Laplacian method because of the high dimension induced by having the R.
variables.
In the above example, through some creative nesting, we reduced the dimension of the random
effects to 20, but this is still too large to permit estimation via adaptive Gaussian quadrature; see
Computation time and the Laplacian approximation in [ME] me. Even with two quadrature points,
our rough formula for computation time would contain within it a factor of 220 = 1,048,576.

236

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

The laplace option is therefore assumed when you use R. notation. If the number of distinct
levels of your R. variables is small enough (say, five or fewer) to permit estimation via AGQ, you
can override the imposition of laplace by specifying the intpoints() option.

Stored results
meqrlogit stores the following in e():
Scalars
e(N)
e(k)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(reparm rc)
e(rc)
e(converged)
Macros
e(cmd)
e(cmdline)
e(depvar)
e(ivars)
e(model)
e(title)
e(offset)
e(binomial)
e(redim)
e(vartypes)
e(revars)
e(n quad)
e(laplace)
e(chi2type)
e(vce)
e(vcetype)
e(method)
e(opt)
e(ml method)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)
e(marginsnotok)
e(asbalanced)
e(asobserved)

number of observations
number of parameters
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
return code, final reparameterization
return code
1 if converged, 0 otherwise
meqrlogit
command as typed
name of dependent variable
grouping variables
logistic
title in estimation output
offset
binomial number of trials
random-effects dimensions
variance-structure types
random-effects covariates
number of integration points
laplace, if Laplace approximation
Wald; type of model 2
bootstrap or jackknife if defined
title used to label Std. Err.
ML
type of optimization
type of ml method
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict
predictions disallowed by margins
factor variables fvset as asbalanced
factor variables fvset as asobserved

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)


Matrices
e(b)
e(Cns)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)
Functions
e(sample)

237

coefficient vector
constraints matrix
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator
marks estimation sample

Methods and formulas


Model (1) assumes Bernoulli data, a special case of the binomial. Because binomial data are also
supported by meqrlogit (option binomial()), the methods presented below are in terms of the
more general binomial mixed-effects model.
For a two-level binomial model, consider the response yij as the number of successes from a
series of rij Bernoulli trials (replications). For cluster j , j = 1, . . . , M , the conditional distribution
of yj = (yj1 , . . . , yjnj ) , given a set of cluster-level random effects uj , is
nj

f (yj |uj ) =
i=1

rij
r y
y
{H (xij + zij uj )} ij {1 H (xij + zij uj )} ij ij
yij
nj

yij (xij + zij uj ) rij log {1 + exp (xij + zij uj )} + log

= exp
i=1

rij
yij

for H(v) = exp(v)/{1 + exp(v)}.


Defining rj = (rj1 , . . . , rjnj ) and
nj

c (yj , rj ) =

log
i=1

rij
yij

where c(yj , rj ) does not depend on the model parameters, we can express the above compactly in
matrix notation,

f (yj |uj ) = exp yj (Xj + Zj uj ) rj log {1 + exp (Xj + Zj uj )} + c (yj , rj )


where Xj is formed by stacking the row vectors xij and Zj is formed by stacking the row vectors zij .
We extend the definitions of the functions log() and exp() to be vector functions where necessary.
Because the prior distribution of uj is multivariate normal with mean 0 and q q variance matrix
, the likelihood contribution for the j th cluster is obtained by integrating uj out of the joint density
f (yj , uj ),
1/2

Lj (, ) = (2)q/2 ||

f (yj |uj ) exp uj 1 uj /2 duj


(5)
q/2

= exp {c (yj , rj )} (2)

||

1/2

exp {g (, , uj )} duj

238

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

where

g (, , uj ) = yj (Xj + Zj uj ) rj log {1 + exp (Xj + Zj uj )} uj 1 uj /2


and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , rj , Xj , Zj ).
The integration in (5) has no closed form and thus must be approximated. The Laplacian approximation (Tierney and Kadane 1986; Pinheiro and Bates 1995) is based on a second-order Taylor
expansion of g (, , uj ) about the value of uj that maximizes it. Taking first and second derivatives,
we obtain
g (, , uj )
g (, , uj ) =
= Zj {yj m(, uj )} 1 uj
uj

g (, , uj ) =

2 g (, , uj )
= Zj V(, uj )Zj + 1
uj uj

where m(, uj ) is the vector function with the ith element equal to the conditional mean of yij
given uj , that is, rij H(xij + zij uj ). V(, uj ) is the diagonal matrix whose diagonal entries vij
are the conditional variances of yij given uj , namely,

vij = rij H (xij + zij uj ) {1 H (xij + zij uj )}


The maximizer of g (, , uj ) is uj such that g (, , uj ) = 0. The integrand in (5) is proportional
to the posterior density f (uj |yj ), so uj also represents the posterior mode, a plausible estimator of
uj in its own right.
Given the above derivatives, the second-order Taylor approximation then takes the form

g (, , uj ) g (, , uj ) +

1
(uj uj ) g (, , uj ) (uj uj )
2

(6)

The first-derivative term vanishes because g (, , uj ) = 0. Therefore,

exp {g (, , uj )} duj exp {g (, , uj )}

1
exp (uj uj ) {g (, , uj )} (uj uj ) duj (7)
2
1/2

= exp {g (, , uj )} (2)q/2 |g (, , uj )|

because the latter integrand can be recognized as the kernel of a multivariate normal density.
Combining the above with (5) (and taking logs) gives the Laplacian log-likelihood contribution of
the j th cluster,

1
LLap
(, ) = log || log |Rj | + g (, , uj ) + c(yj , rj )
j
2
where Rj is an upper-triangular matrix such that g (, , uj ) = Rj Rj . Pinheiro and Chao (2006)
show that uj and Rj can be efficiently computed as the iterative solution to a least-squares problem
by using matrix decomposition methods similar to those used in fitting LME models (Bates and
Pinheiro 1998; Pinheiro and Bates 2000; [ME] mixed).

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

239

The fidelity of the Laplacian approximation is determined wholly by the accuracy of the approximation in (6). An alternative that does not depend so heavily on this approximation is integration via
AGQ (Naylor and Smith 1982; Liu and Pierce 1994).
The application of AGQ to this particular problem is from Pinheiro and Bates (1995). When we
reexamine the integral in question, a transformation of integration variables yields
1

exp g , , uj + R1
j t

exp {g (, , uj )} duj = |Rj |

dt
(8)

q/2

= (2)

|Rj |

exp g , , uj +

R1
j t

+ t t/2 (t)dt

where () is the standard multivariate normal density. Because the integrand is now expressed as
some function multiplied by a normal density, it can be estimated by applying the rules of standard

GaussHermite quadrature.
For a predetermined number of quadrature points NQ , define ak = 2ak

and wk = wk / , for k = 1, . . . , NQ , where (ak , wk ) are a set of abscissas and weights for
GaussHermite quadrature approximations of exp(x2 )f (x)dx, as obtained from Abramowitz and
Stegun (1972, 924).
Define ak = (ak1 , ak2 , . . . , akq ) ; that is, ak is a vector that spans the NQ abscissas over the
dimension q of the random effects. Applying quadrature rules to (8) yields the AGQ approximation,

exp {g (, , uj )} duj
NQ
1

(2)q/2 |Rj |

NQ

k1 =1

exp g , , uj + R1
j ak + ak ak /2

kq =1

wkp
p=1

(2)q/2 Gj (, )
resulting in the AGQ log-likelihood contribution of the ith cluster,

1
LAGQ
(, ) = log || + log Gj (, ) + c(yj , rj )
j
2
The adaptive part of adaptive Gaussian quadrature lies in the translation and rescaling of the
integration variables in (8) by using uj and R1
j , respectively. This transformation of quadrature
abscissas (centered at 0 in standard form) is chosen to better capture the features of the integrand,
which through (7) can be seen to resemble a multivariate normal distribution with mean uj and
T
variance R1
j Rj . AGQ is therefore not as dependent as the Laplace method upon the approximation
in (6). In AGQ, (6) serves merely to redirect the quadrature abscissas, with the AGQ approximation
improving as the number of quadrature points NQ increases. In fact, Pinheiro and Bates (1995)
point out that AGQ with only one quadrature point (a = 0 and w = 1) reduces to the Laplacian
approximation.
The log likelihood for the entire dataset is then simply the sum of the contributions of the M individual
M
M
Lap
AGQ
clusters, namely, L(, ) = j=1 Lj (, ) for Laplace and L(, ) = j=1 Lj
(, ) for
AGQ.
Maximization of L(, ) is performed with respect to (, ), where is a vector comprising the
unique elements of the matrix square root of . This is done to ensure that is always positive
semidefinite. If the matlog option is specified, then instead consists of the unique elements of
the matrix logarithm of . For well-conditioned problems, both methods produce equivalent results,
yet our experience deems the former as more numerically stable near the boundary of the parameter
space.

240

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

Once maximization is achieved, parameter estimates are mapped from (, ) to (, ), where


is a vector containing the unique (estimated) elements of , expressed as logarithms of standard
deviations for the diagonal elements and hyperbolic arctangents of the correlations for off-diagonal
elements. This last step is necessary to (a) obtain a parameterization under which parameter estimates
can be displayed and interpreted individually, rather than as elements of a matrix square root (or
logarithm), and (b) parameterize these elements such that their ranges each encompass the entire real
line.
Parameter estimates are stored in e(b) as (, ), with the corresponding variancecovariance matrix
stored in e(V). Parameter estimates can be displayed in this metric by specifying the estmetric option.
However, in meqrlogit output, variance components are most often displayed either as variances
and covariances (the default) or as standard deviations and correlations (option stddeviations).
The approach outlined above can be extended from two-level models to higher-level models; see
Pinheiro and Chao (2006) for details.

References
Abramowitz, M., and I. A. Stegun, ed. 1972. Handbook of Mathematical Functions with Formulas, Graphs, and
Mathematical Tables. 10th ed. Washington, DC: National Bureau of Standards.
Andrews, M. J., T. Schank, and R. Upward. 2006. Practical fixed-effects estimation methods for the three-way
error-components model. Stata Journal 6: 461481.
Bates, D. M., and J. C. Pinheiro. 1998. Computational methods for multilevel modelling. In Technical Memorandum
BL0112140-980226-01TM. Murray Hill, NJ: Bell Labs, Lucent Technologies.
http://stat.bell-labs.com/NLME/CompMulti.pdf.
Gutierrez, R. G., S. L. Carter, and D. M. Drukker. 2001. sg160: On boundary-value likelihood-ratio tests. Stata
Technical Bulletin 60: 1518. Reprinted in Stata Technical Bulletin Reprints, vol. 10, pp. 269273. College Station,
TX: Stata Press.
Harbord, R. M., and P. Whiting. 2009. metandi: Meta-analysis of diagnostic accuracy using hierarchical logistic
regression. Stata Journal 9: 211229.
Huq, N. M., and J. Cleland. 1990. Bangladesh Fertility Survey 1989 (Main Report). National Institute of Population
Research and Training.
Joe, H. 2008. Accuracy of Laplace approximation for discrete response mixed models. Computational Statistics &
Data Analysis 52: 50665074.
Laird, N. M., and J. H. Ware. 1982. Random-effects models for longitudinal data. Biometrics 38: 963974.
Leyland, A. H., and H. Goldstein, ed. 2001. Multilevel Modelling of Health Statistics. New York: Wiley.
Lin, X., and N. E. Breslow. 1996. Bias correction in generalized linear mixed models with multiple components of
dispersion. Journal of the American Statistical Association 91: 10071016.
Liu, Q., and D. A. Pierce. 1994. A note on GaussHermite quadrature. Biometrika 81: 624629.
Marchenko, Y. V. 2006. Estimating variance components in Stata. Stata Journal 6: 121.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
McLachlan, G. J., and K. E. Basford. 1988. Mixture Models. New York: Dekker.
Naylor, J. C., and A. F. M. Smith. 1982. Applications of a method for the efficient computation of posterior
distributions. Journal of the Royal Statistical Society, Series C 31: 214225.
Ng, E. S.-W., J. R. Carpenter, H. Goldstein, and J. Rasbash. 2006. Estimation in generalised linear mixed models
with binary outcomes by simulated maximum likelihood. Statistical Modelling 6: 2342.
Paterson, L. 1991. Socio-economic status and educational attainment: A multidimensional and multilevel study.
Evaluation and Research in Education 5: 97121.
Pinheiro, J. C., and D. M. Bates. 1995. Approximations to the log-likelihood function in the nonlinear mixed-effects
model. Journal of Computational and Graphical Statistics 4: 1235.

meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)

241

. 2000. Mixed-Effects Models in S and S-PLUS. New York: Springer.


Pinheiro, J. C., and E. C. Chao. 2006. Efficient Laplacian and adaptive Gaussian quadrature algorithms for multilevel
generalized linear mixed models. Journal of Computational and Graphical Statistics 15: 5881.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Rabe-Hesketh, S., A. Skrondal, and A. Pickles. 2005. Maximum likelihood estimation of limited and discrete dependent
variable models with nested random effects. Journal of Econometrics 128: 301323.
Rabe-Hesketh, S., T. Toulopoulou, and R. M. Murray. 2001. Multilevel modeling of cognitive function in schizophrenic
patients and their first degree relatives. Multivariate Behavioral Research 36: 279298.
Self, S. G., and K.-Y. Liang. 1987. Asymptotic properties of maximum likelihood estimators and likelihood ratio tests
under nonstandard conditions. Journal of the American Statistical Association 82: 605610.
Tierney, L., and J. B. Kadane. 1986. Accurate approximations for posterior moments and marginal densities. Journal
of the American Statistical Association 81: 8286.

Also see
[ME] meqrlogit postestimation Postestimation tools for meqrlogit
[ME] mecloglog Multilevel mixed-effects complementary log-log regression
[ME] melogit Multilevel mixed-effects logistic regression
[ME] meprobit Multilevel mixed-effects probit regression
[ME] me Introduction to multilevel mixed-effects models
[MI] estimation Estimation commands for use with mi estimate
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtlogit Fixed-effects, random-effects, and population-averaged logit models
[U] 20 Estimation and postestimation commands

Title
meqrlogit postestimation Postestimation tools for meqrlogit
Description
Options for predict
Options for estat recovariance
Stored results
Also see

Syntax for predict


Syntax for estat
Option for estat icc
Methods and formulas

Menu for predict


Menu for estat
Remarks and examples
References

Description
The following postestimation commands are of special interest after meqrlogit:
Command

Description

estat group
summarize the composition of the nested groups
estat recovariance display the estimated random-effects covariance matrix (or matrices)
estat icc
estimate intraclass correlations
The following standard postestimation commands are also available:
Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

242

meqrlogit postestimation Postestimation tools for meqrlogit

243

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
estat recovariance displays the estimated variancecovariance matrix of the random effects
for each level in the model. Random effects can be either random intercepts, in which case the
corresponding rows and columns of the matrix are labeled as cons, or random coefficients, in which
case the label is the name of the associated variable in the data.
estat icc displays the intraclass correlation for pairs of latent linear responses at each nested
level of the model. Intraclass correlations are available for random-intercept models or for randomcoefficient models conditional on random-effects covariates being equal to 0. They are not available
for crossed-effects models.

Syntax for predict


Syntax for obtaining estimated random effects and their standard errors
predict

stub* | newvarlist

type

if

in ,

reffects | reses

relevel(levelvar)
Syntax for obtaining other predictions
predict

type

newvar

if

in

, statistic nooffset fixedonly

Description

statistic
Main

predicted mean; the default


linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction
Pearson residuals
deviance residuals
Anscombe residuals

mu
xb
stdp
pearson
deviance
anscombe

These statistics are available both in and out of sample; type predict
only for the estimation sample.

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

. . . if e(sample) . . . if wanted

244

meqrlogit postestimation Postestimation tools for meqrlogit

Options for predict

Main

reffects calculates posterior modal estimates of the random effects. By default, estimates for all
random effects in the model are calculated. However, if the relevel(levelvar) option is specified,
then estimates for only level levelvar in the model are calculated. For example, if classes are
nested within schools, then typing
. predict b*, reffects relevel(school)
would yield random-effects estimates at the school level. You must specify q new variables, where
q is the number of random-effects terms in the model (or level). However, it is much easier to
just specify stub* and let Stata name the variables stub1, stub2, . . . , stubq for you.
reses calculates standard errors for the random-effects estimates obtained by using the reffects
option. By default, standard errors for all random effects in the model are calculated. However,
if the relevel(levelvar) option is specified, then standard errors for only level levelvar in the
model are calculated. For example, if classes are nested within schools, then typing
. predict se*, reses relevel(school)
would yield standard errors at the school level. You must specify q new variables, where q is the
number of random-effects terms in the model (or level). However, it is much easier to just specify
stub* and let Stata name the variables stub1, stub2, . . . , stubq for you.
The reffects and reses options often generate multiple new variables at once. When this occurs,
the random effects (or standard errors) contained in the generated variables correspond to the order
in which the variance components are listed in the output of meqrlogit. Still, examining the
variable labels of the generated variables (with the describe command, for instance) can be
useful in deciphering which variables correspond to which terms in the model.
relevel(levelvar) specifies the level in the model at which predictions for random effects and their
standard errors are to be obtained. levelvar is the name of the model level and is either the name
of the variable describing the grouping at that level or is all, a special designation for a group
comprising all the estimation data.
mu, the default, calculates the predicted mean. By default, this is based on a linear predictor that
includes both the fixed effects and the random effects, and the predicted mean is conditional on
the values of the random effects. Use the fixedonly option (see below) if you want predictions
that include only the fixed portion of the model, that is, if you want random effects set to 0.
xb calculates the linear prediction x based on the estimated fixed effects (coefficients) in the model.
This is equivalent to fixing all random effects in the model to their theoretical (prior) mean value
of 0.
stdp calculates the standard error of the fixed-effects linear predictor x.
pearson calculates Pearson residuals. Pearson residuals large in absolute value may indicate a lack
of fit. By default, residuals include both the fixed portion and the random portion of the model.
The fixedonly option modifies the calculation to include the fixed portion only.
deviance calculates deviance residuals. Deviance residuals are recommended by McCullagh and
Nelder (1989) as having the best properties for examining the goodness of fit of a GLM. They are
approximately normally distributed if the model is correctly specified. They may be plotted against
the fitted values or against a covariate to inspect the models fit. By default, residuals include
both the fixed portion and the random portion of the model. The fixedonly option modifies the
calculation to include the fixed portion only.

meqrlogit postestimation Postestimation tools for meqrlogit

245

anscombe calculates Anscombe residuals, which are designed to closely follow a normal distribution.
By default, residuals include both the fixed portion and the random portion of the model. The
fixedonly option modifies the calculation to include the fixed portion only.
nooffset is relevant only if you specified offset(varname) with meqrlogit. It modifies the
calculations made by predict so that they ignore the offset variable; the linear prediction is
treated as X + Zu rather than X + Zu + offset.
fixedonly modifies predictions to include only the fixed portion of the model, equivalent to setting
all random effects equal to 0; see the mu option.

Syntax for estat


Summarize the composition of the nested groups
estat group
Display the estimated random-effects covariance matrix (or matrices)
estat recovariance

, relevel(levelvar) correlation matlist options

Estimate intraclass correlations


estat icc

, level(#)

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Options for estat recovariance


relevel(levelvar) specifies the level in the model for which the random-effects covariance matrix
is to be displayed and returned in r(cov). By default, the covariance matrices for all levels in the
model are displayed. levelvar is the name of the model level and is either the name of the variable
describing the grouping at that level or is all, a special designation for a group comprising all
the estimation data.
correlation displays the covariance matrix as a correlation matrix and returns the correlation matrix
in r(corr).
matlist options are style and formatting options that control how the matrix (or matrices) is displayed;
see [P] matlist for a list of options that are available.

Option for estat icc


level(#) specifies the confidence level, as a percentage, for confidence intervals. The default is
level(95) or as set by set level; see [U] 20.7 Specifying the width of confidence intervals.

246

meqrlogit postestimation Postestimation tools for meqrlogit

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a logistic mixedeffects model with meqrlogit. For the most part, calculation centers around obtaining estimates of
the subject/group-specific random effects. Random effects are not provided as estimates when the
model is fit but instead need to be predicted after estimation. Calculation of intraclass correlations,
estimating the dependence between latent linear responses for different levels of nesting, may also
be of interest.

Example 1
Following Rabe-Hesketh and Skrondal (2012, chap. 10), we consider a two-level mixed-effects model
for onycholysis (separation of toenail plate from nail bed) among those who contract toenail fungus. The
data are obtained from De Backer et al. (1998) and were also studied by Lesaffre and Spiessens (2001).
The onycholysis outcome is dichotomously coded as 1 (moderate or severe onycholysis) or 0 (none
or mild onycholysis). Fixed-effects covariates include treatment (0: itraconazole; 1: terbinafine), the
month of measurement, and their interaction.
We fit the two-level model with meqrlogit:
. use http://www.stata-press.com/data/r13/toenail
(Onycholysis severity)
. meqrlogit outcome treatment month trt_month || patient:, intpoints(30)
Refining starting values:
Iteration 0:
log likelihood = -749.95893
Iteration 1:
log likelihood = -630.0759
Iteration 2:
log likelihood = -625.6965
Performing gradient-based optimization:
Iteration 0:
log likelihood = -625.6965
Iteration 1:
log likelihood = -625.39741
Iteration 2:
log likelihood = -625.39709
Iteration 3:
log likelihood = -625.39709
Mixed-effects logistic regression
Number of obs
=
1908
Group variable: patient
Number of groups
=
294
Obs per group: min =
1
avg =
6.5
max =
7
Integration points = 30
Wald chi2(3)
=
150.52
Log likelihood = -625.39709
Prob > chi2
=
0.0000
outcome

Coef.

treatment
month
trt_month
_cons

-.1609377
-.3910603
-.1368073
-1.618961

Std. Err.
.5842081
.0443958
.0680236
.4347772

Random-effects Parameters

z
-0.28
-8.81
-2.01
-3.72

P>|z|
0.783
0.000
0.044
0.000

[95% Conf. Interval]


-1.305965
-.4780744
-.270131
-2.471109

.9840892
-.3040463
-.0034836
-.7668132

Estimate

Std. Err.

[95% Conf. Interval]

16.06538

3.057362

11.06372

patient: Identity
var(_cons)

LR test vs. logistic regression: chibar2(01) =

23.32819

565.22 Prob>=chibar2 = 0.0000

It is of interest to determine the dependence among responses for the same subject (between-subject
heterogeneity). Under the latent-linear-response formulation, this dependence can be obtained with

meqrlogit postestimation Postestimation tools for meqrlogit

247

the intraclass correlation. Formally, in a two-level random-effects model, the intraclass correlation
corresponds to the correlation of latent responses within the same individual and also to the proportion
of variance explained by the individual random effect.
In the presence of fixed-effects covariates, estat icc reports the residual intraclass correlation,
which is the correlation between latent linear responses conditional on the fixed-effects covariates.
We use estat icc to estimate the residual intraclass correlation:
. estat icc
Residual intraclass correlation
Level

ICC

patient

.8300271

Std. Err.
.026849

[95% Conf. Interval]


.7707982

.8764047

Conditional on treatment and month of treatment, we estimate that latent responses within the
same patient have a large correlation of approximately 0.83. Further, 83% of the variance of a latent
response is explained by the between-patient variability.

Example 2
In example 3 of [ME] meqrlogit, we represented the probability of contraceptive use among
Bangladeshi women by using the model (stated with slightly different notation here)
logit(ij ) = 0 ruralij +1 urbanij + 2 ageij +

3 child1ij + 4 child2ij + 5 child3ij + aj ruralij + bj urbanij


where ij is the probability of contraceptive use, j = 1, . . . , 60 districts, i = 1, . . . , nj women within
each district, and aj and bj are normally distributed with mean 0 and variancecovariance matrix
= Var

aj
bj

a2
ab

ab
b2

248

meqrlogit postestimation Postestimation tools for meqrlogit


. use http://www.stata-press.com/data/r13/bangladesh
(Bangladesh Fertility Survey, 1989)
. generate byte rural = 1 - urban
. meqrlogit c_use rural urban age child*, noconstant || district: rural urban,
> noconstant cov(unstructured)
Refining starting values:
Iteration 0:
log likelihood = -1208.3924
Iteration 1:
log likelihood = -1204.1317
Iteration 2:
log likelihood = -1200.6022
Performing gradient-based optimization:
Iteration 0:
log likelihood = -1200.6022
Iteration 1:
log likelihood = -1199.3331
Iteration 2:
log likelihood = -1199.315
Iteration 3:
log likelihood = -1199.315
Mixed-effects logistic regression
Number of obs
=
1934
Group variable: district
Number of groups
=
60
Obs per group: min =
2
avg =
32.2
max =
118
Integration points =
7
Wald chi2(6)
=
120.24
Log likelihood = -1199.315
Prob > chi2
=
0.0000
c_use

Coef.

rural
urban
age
child1
child2
child3

-1.71165
-.8958623
-.026415
1.13252
1.357739
1.353827

Std. Err.
.1605618
.1704961
.008023
.1603285
.1770522
.1828801

z
-10.66
-5.25
-3.29
7.06
7.67
7.40

P>|z|
0.000
0.000
0.001
0.000
0.000
0.000

Random-effects Parameters

Estimate

Std. Err.

district: Unstructured
var(rural)
var(urban)
cov(rural,urban)

.3897439
.2442965
-.0161411

.1292459
.1450673
.1057469

[95% Conf. Interval]


-2.026345
-1.230028
-.0421398
.818282
1.010724
.9953882

-1.396954
-.5616961
-.0106902
1.446758
1.704755
1.712265

[95% Conf. Interval]

.2034726
.0762886
-.2234011

.7465394
.7823029
.1911189

LR test vs. logistic regression:


chi2(3) =
58.42
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Rather than see the estimated variance components listed as variance and covariances as above,
we can instead see them as correlations and standard deviations in matrix form; that is, we can see
as a correlation matrix:
. estat recovariance, correlation
Random-effects correlation matrix for level district
rural
urban
rural
urban

1
-.05231

The purpose of using this particular model was to allow for district random effects that were
specific to the rural and urban areas of that district and that could be interpreted as such. We can
obtain predictions of these random effects,
. predict re_rural re_urban, reffects

meqrlogit postestimation Postestimation tools for meqrlogit

249

and their corresponding standard errors,


. predict se_rural se_urban, reses

The order in which we specified the variables to be generated corresponds to the order in which the
variance components are listed in meqrlogit output. If in doubt, a simple describe will show how
these newly generated variables are labeled just to be sure.
Having generated estimated random effects and standard errors, we can now list them for the first
10 districts:
. by district, sort: generate tolist = (_n==1)
. list district re_rural se_rural re_urban se_urban if district <= 10 & tolist,
> sep(0)
district

re_rural

se_rural

re_urban

se_urban

1
2
3
4
5
6
7
8
9
10

-.9206641
-.0307772
-.0149147
-.2684802
.0787537
-.3842217
-.1742786
.0447142
-.3561363
-.5368572

.3129662
.3784629
.6242095
.3951617
.3078451
.2741989
.4008164
.315396
.3885605
.4743089

-.5551252
.0012746
.2257356
.5760574
.004534
.2727722
.0072177
.2256405
.0733451
.0222337

.2321872
.4938357
.4689535
.3970433
.4675103
.4184851
.4938659
.46799
.4555067
.4939776

1.
118.
138.
140.
170.
209.
274.
292.
329.
352.

Technical note
When these data were first introduced in [ME] meqrlogit, we noted that not all districts contained
both urban and rural areas. This fact is somewhat demonstrated by the random effects that are nearly
0 in the above. A closer examination of the data would reveal that district 3 has no rural areas, and
districts 2, 7, and 10 have no urban areas.
The estimated random effects are not exactly 0 in these cases because of the correlation between
urban and rural effects. For instance, if a district has no urban areas, it can still yield a nonzero
(albeit small) random-effects estimate for a nonexistent urban area because of the correlation with its
rural counterpart.
Had we imposed an independent covariance structure in our model, the estimated random effects
in the cases in question would be exactly 0.

Technical note
The estimated standard errors produced above with the reses option are conditional on the values
of the estimated model parameters: and the components of . Their interpretation is therefore not
one of standard sample-to-sample variability but instead one that does not incorporate uncertainty in
the estimated model parameters; see Methods and formulas.
That stated, conditional standard errors can still be used as a measure of relative precision, provided
that you keep this caveat in mind.

250

meqrlogit postestimation Postestimation tools for meqrlogit

Example 3
Continuing with example 2, we can obtain predicted probabilities, the default prediction:
. predict p
(option mu assumed; predicted means)

These predictions are based on a linear predictor that includes both the fixed effects and the random
effects due to district. Specifying the fixedonly option gives predictions that set the random effects
to their prior mean of 0. Below we compare both over the first 20 observations:
. predict p_fixed, fixedonly
(option mu assumed; predicted means)
. list c_use p p_fixed age child* in 1/20
c_use

p_fixed

age

child1

child2

child3

1.
2.
3.
4.
5.

no
no
no
no
no

.3579543
.2134724
.4672256
.4206505
.2510909

.4927183
.3210403
.6044016
.5584864
.3687281

18.44
-5.56
1.44
8.44
-13.56

0
0
0
0
0

0
0
1
0
0

1
0
0
1
0

6.
7.
8.
9.
10.

no
no
no
no
no

.2412878
.3579543
.4992191
.4572049
.4662518

.3565185
.4927183
.6345999
.594723
.6034657

-11.56
18.44
-3.56
-5.56
1.44

0
0
0
1
0

0
0
0
0
0

0
1
1
0
1

11.
12.
13.
14.
15.

yes
no
no
no
no

.2412878
.2004691
.4506573
.4400747
.4794195

.3565185
.3040173
.5883407
.5779263
.6160359

-11.56
-2.56
-4.56
5.44
-0.56

0
0
1
0
0

0
0
0
0
0

0
0
0
1
1

16.
17.
18.
19.
20.

yes
no
yes
yes
no

.4465936
.2134724
.4794195
.4637674
.5001973

.5843561
.3210403
.6160359
.6010735
.6355067

4.44
-5.56
-0.56
-6.56
-3.56

0
0
0
1
0

0
0
0
0
1

1
0
1
0
0

Technical note
Out-of-sample predictions are permitted after meqrlogit, but if these predictions involve estimated
random effects, the integrity of the estimation data must be preserved. If the estimation data have
changed since the model was fit, predict will be unable to obtain predicted random effects that
are appropriate for the fitted model and will give an error. Thus to obtain out-of-sample predictions
that contain random-effects terms, be sure that the data for these predictions are in observations that
augment the estimation data.

meqrlogit postestimation Postestimation tools for meqrlogit

251

Example 4
Continuing with example 2, we can also compute intraclass correlations for the model.
In the presence of random-effects covariates, the intraclass correlation is no longer constant and
depends on the values of the random-effects covariates. In this case, estat icc reports conditional
intraclass correlations assuming 0 values for all random-effects covariates. For example, in a twolevel model, this conditional correlation represents the correlation of the latent responses for two
measurements on the same subject, both of which have random-effects covariates equal to 0. Similarly
to the interpretation of intercept variances in random-coefficient models (Rabe-Hesketh and Skrondal
2012, chap. 16), interpretation of this conditional intraclass correlation relies on the usefulness of
the 0 baseline values of random-effects covariates. For example, mean centering of the covariates is
often used to make a 0 value a useful reference.
Estimation of the conditional intraclass correlation in the Bangladeshi contraceptive study setting
of example 2 is of interest. In example 2, the random-effects covariates rural and urban for the
random level district are mutually exclusive indicator variables and can never be simultaneously
0. Thus we could not use estat icc to estimate the conditional intraclass correlation for this model,
because estat icc requires that the random intercept is included in all random-effects specifications.
Instead, we consider an alternative model for the Bangladeshi contraceptive study. In example 2 of
[ME] meqrlogit, we represented the probability of contraceptive use among Bangladeshi women with
fixed-effects for urban residence (urban), age (age), and the number of children (child1child3).
The random effects for urban and rural residence are represented as a random slope for urban residence
and a random intercept at the district level.
We fit the model with meqrlogit:
. use http://www.stata-press.com/data/r13/bangladesh, clear
(Bangladesh Fertility Survey, 1989)
. meqrlogit c_use urban age child* || district: urban, covariance(unstructured)
Refining starting values:
Iteration 0:
log likelihood = -1215.8594 (not concave)
Iteration 1:
log likelihood = -1204.0802
Iteration 2:
log likelihood = -1199.798
Performing gradient-based optimization:
Iteration 0:
log likelihood = -1199.798
Iteration 1:
log likelihood = -1199.4744
Iteration 2:
log likelihood = -1199.3158
Iteration 3:
log likelihood = -1199.315
Iteration 4:
log likelihood = -1199.315
Mixed-effects logistic regression
Number of obs
=
1934
Group variable: district
Number of groups
=
60
Obs per group: min =
2
avg =
32.2
max =
118
Integration points =
7
Wald chi2(5)
=
97.50
Log likelihood = -1199.315
Prob > chi2
=
0.0000
c_use

Coef.

urban
age
child1
child2
child3
_cons

.8157872
-.026415
1.13252
1.357739
1.353827
-1.71165

Std. Err.
.171552
.008023
.1603285
.1770522
.1828801
.1605617

z
4.76
-3.29
7.06
7.67
7.40
-10.66

P>|z|
0.000
0.001
0.000
0.000
0.000
0.000

[95% Conf. Interval]


.4795516
-.0421398
.8182819
1.010723
.9953881
-2.026345

1.152023
-.0106902
1.446758
1.704755
1.712265
-1.396954

252

meqrlogit postestimation Postestimation tools for meqrlogit

Random-effects Parameters

Estimate

Std. Err.

district: Unstructured
var(urban)
var(_cons)
cov(urban,_cons)

.6663222
.3897434
-.4058846

.3224715
.1292459
.1755418

[95% Conf. Interval]

.2580709
.2034723
-.7499403

1.7204
.7465388
-.0618289

LR test vs. logistic regression:


chi2(3) =
58.42
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

We use estat icc to estimate the intraclass correlation conditional on urban being equal to 0:
. estat icc
Conditional intraclass correlation
Level

ICC

district

.1059197

Std. Err.

[95% Conf. Interval]

.0314044

.0582458

.1849513

Note: ICC is conditional on zero values of random-effects covariates.

This estimate suggests that the latent responses are not strongly correlated for rural residents
(urban == 0) within the same district, conditional on the fixed-effects covariates.

Example 5
In example 4 of [ME] meqrlogit, we fit a three-level model for the cognitive ability of schizophrenia
patients as compared with their relatives and a control. Fixed-effects covariates include the difficulty
of the test, difficulty, and an individuals category, group (control, family member of patient, or
patient). Family units (family) represent the third nesting level, and individual subjects (subject)
represent the second nesting level. Three measurements were taken on all but one subject, one for
each difficulty measure.
We fit the model with meqrlogit:
. use http://www.stata-press.com/data/r13/towerlondon
(Tower of London data)
. meqrlogit dtlm difficulty i.group || family: || subject:
Refining starting values:
Iteration 0:
log likelihood = -310.28433
Iteration 1:
log likelihood = -306.42785 (not concave)
Iteration 2:
log likelihood = -305.26009
Performing gradient-based optimization:
Iteration 0:
log likelihood = -305.26009
Iteration 1:
log likelihood = -305.12089
Iteration 2:
log likelihood = -305.12043
Iteration 3:
log likelihood = -305.12043
Mixed-effects logistic regression
Number of obs

Group Variable

No. of
Groups

family
subject

118
226

Observations per Group


Minimum
Average
Maximum
2
2

5.7
3.0

27
3

677

Integration
Points
7
7

meqrlogit postestimation Postestimation tools for meqrlogit


Wald chi2(3)
Prob > chi2

Log likelihood = -305.12043


Std. Err.

P>|z|

74.89
0.0000

dtlm

Coef.

difficulty

-1.648506

.1932139

-8.53

0.000

-2.027198

-1.269814

group
2
3

-.24868
-1.0523

.3544065
.3999896

-0.70
-2.63

0.483
0.009

-.9433039
-1.836265

.445944
-.2683348

_cons

-1.485861

.2848469

-5.22

0.000

-2.04415

-.927571

Random-effects Parameters

=
=

253

[95% Conf. Interval]

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

.569182

.5216584

.0944323

3.430694

var(_cons)

1.137931

.6857496

.3492673

3.70744

family: Identity

subject: Identity

LR test vs. logistic regression:


chi2(2) =
17.54
Prob > chi2 = 0.0002
Note: LR test is conservative and provided only for reference.

We can use estat icc to estimate the residual intraclass correlation (conditional on the difficulty
level and the individuals category) between the latent responses of subjects within the same family
or between the latent responses of the same subject and family:
. estat icc
Residual intraclass correlation
Level

ICC

family
subject|family

.1139052
.3416289

Std. Err.

[95% Conf. Interval]

.0997976
.0889531

.0181741
.1929134

.4716556
.5297405

estat icc reports two intraclass correlations for this three-level nested model. The first is the
level-3 intraclass correlation at the family level, the correlation between latent measurements of the
cognitive ability in the same family. The second is the level-2 intraclass correlation at the subjectwithin-family level, the correlation between the latent measurements of cognitive ability in the same
subject and family.
There is not a strong correlation between individual realizations of the latent response, even within
the same subject.

254

meqrlogit postestimation Postestimation tools for meqrlogit

Stored results
estat recovariance stores the following in r():
Scalars
r(relevels)

number of levels

Matrices
r(Cov#)
r(Corr#)

level-# random-effects covariance matrix


level-# random-effects correlation matrix (if option correlation was specified)

For a G-level nested model, # can be any integer between 2 and G.


estat icc stores the following in r():
Scalars
r(icc#)
r(se#)
r(level)

level-# intraclass correlation


standard errors of level-# intraclass correlation
confidence level of confidence intervals

Macros
r(label#)

label for level #

Matrices
r(ci#)

vector of confidence intervals (lower and upper) for level-# intraclass correlation

For a G-level nested model, # can be any integer between 2 and G.

Methods and formulas


Methods and formulas are presented under the following headings:
Prediction
Intraclass correlations

Prediction
Continuing the discussion in Methods and formulas of [ME] meqrlogit, and using the definitions
and formulas defined there, we begin by considering the prediction of the random effects uj for the
j th cluster in a two-level model.
Given a set of estimated meqrlogit parameters (, ), a profile likelihood in uj is derived from
the joint distribution f (yj , uj ) as

Lj (uj ) = exp {c (yj , rj )} (2)q/2 ||1/2 exp g , , uj

(1)

The conditional maximum likelihood estimator of uj conditional on fixed (, ) is the maximizer


of Lj (uj ) or, equivalently, the value of uj that solves

0=g

, , uj

= Zj yj m(, uj )

uj

Because (1) is proportional to the conditional density f (uj |yj ), you can also refer to uj as the
conditional mode (or posterior mode if you lean toward Bayesian terminology). Regardless, you are
referring to the same estimator.

meqrlogit postestimation Postestimation tools for meqrlogit

255

Conditional standard errors for the estimated random effects are derived from standard theory of
maximum likelihood, which dictates that the asymptotic variance matrix of uj is the negative inverse
of the Hessian, which is estimated as

= Zj V(, uj )Zj +

, , uj

Similar calculations extend to models with more than one level of random effects; see Pinheiro and
Chao (2006).
For any observation i in the j th cluster in a two-level model, define the linear predictor as

ij = xij + zij uj
In a three-level model, for the ith observation within the j th level-two cluster within the k th level-three
cluster,
(2) (2)
(3) (3)
ijk = xijk + zijk uk + zijk ujk
where z(p) and u(p) refer to the level p design variables and random effects, respectively. For models
with more than three levels, the definition of extends in the natural way, with only the notation
becoming more complicated.
If the fixedonly option is specified, contains the linear predictor for only the fixed portion of
the model, for example, in a two-level model ij = xij . In what follows, we assume a two-level
model, with the only necessary modification for multilevel models being the indexing.
The predicted mean conditional on the random effects uj is

ij = rij H(ij )
Pearson residuals are calculated as
P
ij
=

yij ij
{V (ij )}1/2

for V (ij ) = ij (1 ij /rij ).


Deviance residuals are calculated as
D
ij
= sign(yij ij ) dij2

where

rij

2rij log

r
ij ij

yij
+ 2(rij yij ) log
dij2 = 2yij log
ij

rij

2rij log
ij

if yij = 0

rij yij
rij ij

if 0 < yij < rij


if yij = rij

Anscombe residuals are calculated as


2/3

A
ij

3 yij H(yij /rij ) 2/3 H(ij /rij )


2 ij 2ij /rij

1/6

where H(t) is a specific univariate case of the Hypergeometric2F1 function (Wolfram 1999, 771772).
For Anscombe residuals for binomial regression, the specific form of the Hypergeometric2F1 function
that we require is H(t) = 2 F1 (2/3, 1/3, 5/3, t).
For a discussion of the general properties of the above residuals, see Hardin and Hilbe (2012,
chap. 4).

256

meqrlogit postestimation Postestimation tools for meqrlogit

Intraclass correlations
Consider a simple, two-level random-intercept model, stated in terms of a latent linear response,

where only yij = I(yij


> 0) is observed for the latent variable,
(2)

yij
= + uj +

(1)
ij
(2)

with i = 1, . . . , nj and level-2 groups j = 1, . . . , M . Here is an unknown fixed intercept, uj

is

(1)
ij

a level-2 random intercept, and


is a level-1 error term. Errors are assumed to be logistic with
mean 0 and variance 12 = 2 /3; random intercepts are assumed to be normally distributed with
mean 0 and variance 22 and to be independent of error terms.
The intraclass correlation for this model is

= Corr(yij
, yi j ) =

22
2 /3 + 22

It corresponds to the correlation between the latent responses i and i from the same group j .
Now consider a three-level nested random-intercept model,
(2)

(3)

yijk
= + ujk + uk +

(1)
ijk

for measurements i = 1, . . . , njk and level-2 groups j = 1, . . . , M1k nested within level-3 groups
(2)
(3)
k = 1, . . . , M2 . Here ujk is a level-2 random intercept, uk is a level-3 random intercept, and
(1)
ijk is a level-1 error term. The error terms have a logistic distribution with mean 0 and variance
12 = 2 /3. The random intercepts are assumed to be normally distributed with mean 0 and variances
22 and 32 , respectively, and to be mutually independent. The error terms are also independent of the

random intercepts.
We can consider two types of intraclass correlations for this model. We will refer to them as
level-2 and level-3 intraclass correlations. The level-3 intraclass correlation is

(3) = Corr(yijk
, yi j k ) =

32
2 /3 + 22 + 32

This is the correlation between latent responses i and i from the same level-3 group k and from
different level-2 groups j and j .
The level-2 intraclass correlation is

(2) = Corr(yijk
, yi jk ) =

22 + 32
2 /3 + 22 + 32

This is the correlation between latent responses i and i from the same level-3 group k and level-2
group j . (Note that level-1 intraclass correlation is undefined.)
More generally, for a G-level nested random-intercept model, the g -level intraclass correlation is
defined as
G
2
l=g l
(g) =
G
2 /3 + l=2 l2

meqrlogit postestimation Postestimation tools for meqrlogit

257

The above formulas also apply in the presence of fixed-effects covariates X in a randomeffects model. In this case, intraclass correlations are conditional on fixed-effects covariates and are
referred to as residual intraclass correlations. estat icc also uses the same formulas to compute
intraclass correlations for random-coefficient models, assuming 0 baseline values for the random-effects
covariates, and labels them as conditional intraclass correlations.
Intraclass correlations will always fall in [0,1] because variance components are nonnegative. To
accommodate the range of an intraclass correlation, we use the logit transformation to obtain confidence
intervals. We use the delta method to estimate the standard errors of the intraclass correlations.
Let (g) be a point estimate of the intraclass correlation and SE((g) ) be its standard error. The
(1 ) 100% confidence interval for logit((g) ) is
logit((g) ) z/2

SE((g) )

(g) (1

(g) )

where z/2 is the 1 /2 quantile of the standard normal distribution and logit(x) = ln{x/(1 x)}.
Let ku be the upper endpoint of this interval, and let kl be the lower. The (1 ) 100% confidence
interval for (g) is then given by

1
1
,
1 + ekl 1 + eku

References
De Backer, M., C. De Vroey, E. Lesaffre, I. Scheys, and P. De Keyser. 1998. Twelve weeks of continuous oral therapy
for toenail onychomycosis caused by dermatophytes: A double-blind comparative trial of terbinafine 250 mg/day
versus itraconazole 200 mg/day. Journal of the American Academy of Dermatology 38: S57S63.
Hardin, J. W., and J. M. Hilbe. 2012. Generalized Linear Models and Extensions. 3rd ed. College Station, TX: Stata
Press.
Lesaffre, E., and B. Spiessens. 2001. On the effect of the number of quadrature points in a logistic random-effects
model: An example. Journal of the Royal Statistical Society, Series C 50: 325335.
McCullagh, P., and J. A. Nelder. 1989. Generalized Linear Models. 2nd ed. London: Chapman & Hall/CRC.
Pinheiro, J. C., and E. C. Chao. 2006. Efficient Laplacian and adaptive Gaussian quadrature algorithms for multilevel
generalized linear mixed models. Journal of Computational and Graphical Statistics 15: 5881.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Wolfram, S. 1999. The Mathematica Book. 4th ed. Cambridge: Cambridge University Press.

Also see
[ME] meqrlogit Multilevel mixed-effects logistic regression (QR decomposition)
[U] 20 Estimation and postestimation commands

Title
meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)
Syntax
Remarks and examples
Also see

Menu
Stored results

Description
Methods and formulas

Options
References

Syntax
meqrpoisson depvar fe equation || re equation || re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname , re options
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

noconstant
exposure(varnamee )
offset(varnameo )

suppress constant term from the fixed-effects equation


include ln(varnamee ) in model with coefficient constrained to 1
include varnameo in model with coefficient constrained to 1

re options

Description

Model

covariance(vartype)
noconstant
collinear

variancecovariance structure of the random effects


suppress constant term from the random-effects equation
keep collinear variables

258

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

options

259

Description

Reporting

level(#)
irr
variance
stddeviations
noretable
nofetable
estmetric
noheader
nogroup
nolrtest
display options

set confidence level; default is level(95)


report fixed-effects coefficients as incidence-rate ratios
show random-effects parameter estimates as variances and
covariances; the default
show random-effects parameter estimates as standard deviations
and correlations
suppress random-effects table
suppress fixed-effects table
show parameter estimates in the estimation metric
suppress output header
suppress table summarizing groups
do not perform likelihood-ratio test comparing with Poisson
regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

Integration

intpoints(# [ # . . . ] )
laplace

set the number of integration (quadrature) points;


default is intpoints(7)
use Laplacian approximation; equivalent to intpoints(1)

Maximization

control the maximization process; seldom used


tolerance for random-effects estimates; default is
retolerance(1e-8); seldom used
reiterate(#)
maximum number of iterations for random-effects estimation;
default is reiterate(50); seldom used
matsqrt
parameterize variance components using matrix square roots;
the default
matlog
parameterize variance components using matrix logarithms
refineopts(maximize options) control the maximization process during refinement of starting
values

maximize options
retolerance(#)

coeflegend

display legend instead of statistics

vartype

Description

independent

one unique variance parameter per random effect, all covariances


0; the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances
0; the default if the R. notation is used
all variances and covariances to be distinctly estimated

exchangeable
identity
unstructured

260

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
indepvars and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
bootstrap, by, jackknife, mi estimate, rolling, and statsby are allowed; see [U] 11.1.10 Prefix commands.
coeflegend does not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Estimation by QR decomposition

>

Poisson regression

Description
meqrpoisson, like mepoisson, fits mixed-effects models for count responses, for which the
conditional distribution of the response given the random effects is assumed to be Poisson.
meqrpoisson provides an alternative estimation method that uses the QR decomposition of the
variance-components matrix. This method may aid convergence when variance components are near
the boundary of the parameter space.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
exposure(varnamee ) specifies a variable that reflects the amount of exposure over which the depvar
events were observed for each observation; ln(varnamee ) is included in the fixed-effects portion
of the model with the coefficient constrained to be 1.
offset(varnameo ) specifies that varnameo be included in the fixed-effects portion of the model with
the coefficient constrained to be 1.
covariance(vartype) specifies the structure of the covariance matrix for the random effects and
may be specified for each random-effects equation. vartype is one of the following: independent,
exchangeable, identity, and unstructured.
covariance(independent) covariance structure allows for a distinct variance for each random
effect within a random-effects equation and assumes that all covariances are 0. The default is
covariance(independent), except when the R. notation is used, in which case the default is
covariance(identity) and only covariance(identity) and covariance(exchangeable)
are allowed.
covariance(exchangeable) structure specifies one common variance for all random effects and
one common pairwise covariance.
covariance(identity) is short for multiple of the identity; that is, all variances are equal
and all covariances are 0.
covariance(unstructured) allows for all variances and covariances to be distinct. If an equation
consists of p random-effects terms, the unstructured covariance matrix will have p(p + 1)/2 unique
parameters.

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

261

collinear specifies that meqrpoisson not omit collinear variables from the random-effects equation.
Usually, there is no reason to leave collinear variables in place; in fact, doing so usually causes
the estimation to fail because of the matrix singularity caused by the collinearity. However, with
certain models (for example, a random-effects model with a full set of contrasts), the variables
may be collinear, yet the model is fully identified because of restrictions on the random-effects
covariance structure. In such cases, using the collinear option allows the estimation to take
place with the random-effects equation intact.

Reporting

level(#); see [R] estimation options.


irr reports estimated fixed-effects coefficients transformed to incidence-rate ratios, that is, exp()
rather than . Standard errors and confidence intervals are similarly transformed. This option
affects how results are displayed, not how they are estimated. irr may be specified at estimation
or upon replay.
variance, the default, displays the random-effects parameter estimates as variances and covariances.
stddeviations displays the random-effects parameter estimates as standard deviations and correlations.
noretable suppresses the random-effects table.
nofetable suppresses the fixed-effects table.
estmetric displays all parameter estimates in the estimation metric. Fixed-effects estimates are
unchanged from those normally displayed, but random-effects parameter estimates are displayed
as log-standard deviations and hyperbolic arctangents of correlations, with equation names that
organize them by model level.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nolrtest prevents meqrpoisson from performing a likelihood-ratio test that compares the mixedeffects Poisson model with standard (marginal) Poisson regression. This option may also be specified
upon replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

Integration

intpoints(# [ # . . . ] ) sets the number of integration points for adaptive Gaussian quadrature. The
more integration points, the more accurate the approximation to the log likelihood. However,
computation time increases with the number of quadrature points, and in models with many levels
or many random coefficients, this increase can be substantial.
You may specify one number of integration points applying to all levels of random effects in
the model, or you may specify distinct numbers of points for each level. intpoints(7) is the
default; that is, by default seven quadrature points are used for each level.
laplace specifies that log likelihoods be calculated using the Laplacian approximation, equivalent
to adaptive Gaussian quadrature with one integration point for each level in the model; laplace
is equivalent to intpoints(1). Computation time increases as a function of the number of
quadrature points raised to a power equaling the dimension of the random-effects specification.

262

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

The computational time saved by using laplace can thus be substantial, especially when you
have many levels or random coefficients.
The Laplacian approximation has been known to produce biased parameter estimates, but the bias
tends to be more prominent in the estimates of the variance components rather than in the estimates
of the fixed effects. If your interest lies primarily with the fixed-effects estimates, the Laplace
approximation may be a viable faster alternative to adaptive quadrature with multiple integration
points.
When the R.varname notation is used, the dimension of the random effects increases by the
number of distinct values of varname. Even when this number is small to moderate, it increases
the total random-effects dimension to the point where estimation with more than one quadrature
point is prohibitively intensive.

For this reason, when you use the R. notation in your random-effects equations, the laplace
option is assumed. You can override this behavior by using the intpoints() option, but doing
so is not recommended.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), nonrtolerance, and from(init specs); see [R] maximize. Those that require
special mention for meqrpoisson are listed below.
For the technique() option, the default is technique(nr). The bhhh algorithm may not be
specified.
from(init specs) is particularly useful when combined with refineopts(iterate(0)) (see the
description below), which bypasses the initial optimization stage.
retolerance(#) specifies the convergence tolerance for the estimated random effects used by adaptive
Gaussian quadrature. Although not estimated as model parameters, random-effects estimators are
used to adapt the quadrature points. Estimating these random effects is an iterative procedure,
with convergence declared when the maximum relative change in the random effects is less than
retolerance(). The default is retolerance(1e-8). You should seldom have to use this option.
reiterate(#) specifies the maximum number of iterations used when estimating the random effects
to be used in adapting the Gaussian quadrature points; see the retolerance() option. The default
is reiterate(50). You should seldom have to use this option.
matsqrt (the default), during optimization, parameterizes variance components by using the matrix
square roots of the variancecovariance matrices formed by these components at each model level.
matlog, during optimization, parameterizes variance components by using the matrix logarithms of
the variancecovariance matrices formed by these components at each model level.
The matsqrt parameterization ensures that variancecovariance matrices are positive semidefinite,
while matlog ensures matrices that are positive definite. For most problems, the matrix square root
is more stable near the boundary of the parameter space. However, if convergence is problematic,
one option may be to try the alternate matlog parameterization. When convergence is not an issue,
both parameterizations yield equivalent results.
refineopts(maximize options) controls the maximization process during the refinement of starting
values. Estimation in meqrpoisson takes place in two stages. In the first stage, starting values
are refined by holding the quadrature points fixed between iterations. During the second stage,
quadrature points are adapted with each evaluation of the log likelihood. Maximization options
specified within refineopts() control the first stage of optimization; that is, they control the
refining of starting values.

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

263

maximize options specified outside refineopts() control the second stage.


The one exception to the above rule is the nolog option, which when specified outside refineopts() applies globally.
from(init specs) is not allowed within refineopts() and instead must be specified globally.
Refining starting values helps make the iterations of the second stage (those that lead toward the solution) more numerically stable. In this regard, of particular interest is refineopts(iterate(#)),
with two iterations being the default. Should the maximization fail because of instability in the
Hessian calculations, one possible solution may be to increase the number of iterations here.
The following option is available with meqrpoisson but is not shown in the dialog box:
coeflegend; see [R] estimation options.

Remarks and examples


Remarks are presented under the following headings:
Introduction
A two-level model
A three-level model

Introduction
Mixed-effects Poisson regression is Poisson regression containing both fixed effects and random
effects. In longitudinal data and panel data, random effects are useful for modeling intracluster
correlation; that is, observations in the same cluster are correlated because they share common
cluster-level random effects.
meqrpoisson allows for not just one, but many levels of nested clusters. For example, in a threelevel model you can specify random effects for schools and then random effects for classes nested
within schools. The observations (students, presumably) would comprise level one of the model, the
classes would comprise level two, and the schools would comprise level three.
However, for simplicity, for now we consider the two-level model, where for a series of M
independent clusters, and conditional on a set of random effects uj ,
y

Pr(yij = y|uj ) = exp (ij ) ij /y!

(1)

for ij = exp(xij + zij uj ), j = 1, . . . , M clusters, and with cluster j consisting of i = 1, . . . , nj


observations. The responses are counts yij . The 1 p row vector xij are the covariates for the fixed
effects, analogous to the covariates you would find in a standard Poisson regression model, with
regression coefficients (fixed effects) .
The 1 q vector zij are the covariates corresponding to the random effects and can be used to
represent both random intercepts and random coefficients. For example, in a random-intercept model,
zij is simply the scalar 1. The random effects uj are M realizations from a multivariate normal
distribution with mean 0 and q q variance matrix . The random effects are not directly estimated
as model parameters but are instead summarized according to the unique elements of , known
as variance components. One special case of (1) places zij = xij so that all covariate effects are
essentially random and distributed as multivariate normal with mean and variance .

264

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

Model (1) is an example of a generalized linear mixed model (GLMM), which generalizes the
linear mixed-effects (LME) model to non-Gaussian responses. You can fit LMEs in Stata by using
mixed and fit GLMMs by using meglm. Because of the relationship between LMEs and GLMMs, there
is insight to be gained through examination of the linear mixed model. This is especially true for
Stata users because the terminology, syntax, options, and output for fitting these types of models are
nearly identical. See [ME] mixed and the references therein, particularly in the Introduction, for more
information.
Log-likelihood calculations for fitting any generalized mixed-effects model require integrating out the
random effects. One widely used modern method is to directly estimate the integral required to calculate
the log likelihood by GaussHermite quadrature or some variation thereof. The estimation method
used by meqrpoisson is a multicoefficient and multilevel extension of one of these quadrature types,
namely, adaptive Gaussian quadrature (AGQ) based on conditional modes, with the multicoefficient
extension from Pinheiro and Bates (1995) and the multilevel extension from Pinheiro and Chao (2006);
see Methods and formulas.
Below we present two short examples of mixed-effects Poisson regression; refer to [ME] me and
[ME] meglm for additional examples.

A two-level model
In this section, we begin with a two-level mixed-effects Poisson regression, because a one-level
model, in multilevel-model terminology, is just standard Poisson regression; see [R] poisson.

Example 1
Breslow and Clayton (1993) fit a mixed-effects Poisson model to data from a randomized trial of
the drug progabide for the treatment of epilepsy.
. use http://www.stata-press.com/data/r13/epilepsy
(Epilepsy data; progabide drug treatment)
. describe
Contains data from http://www.stata-press.com/data/r13/epilepsy.dta
obs:
236
Epilepsy data; progabide drug
treatment
vars:
8
31 May 2013 14:09
size:
4,956
(_dta has notes)

variable name

storage
type

display
format

subject
seizures
treat
visit

byte
int
byte
float

%9.0g
%9.0g
%9.0g
%9.0g

lage
lbas

float
float

%9.0g
%9.0g

lbas_trt
v4

float
byte

%9.0g
%8.0g

Sorted by:

value
label

variable label
Subject ID: 1-59
No. of seizures
1: progabide; 0: placebo
Dr. visit; coded as (-.3, -.1,
.1, .3)
log(age), mean-centered
log(0.25*baseline seizures),
mean-centered
lbas/treat interaction
Fourth visit indicator

subject

Originally from Thall and Vail (1990), data were collected on 59 subjects (31 on progabide, 28 on
placebo). The number of epileptic seizures (seizures) was recorded during the two weeks prior to
each of four doctor visits (visit). The treatment group is identified by the indicator variable treat.

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

265

Data were also collected on the logarithm of age (lage) and the logarithm of one-quarter the number
of seizures during the eight weeks prior to the study (lbas). The variable lbas trt represents the
interaction between lbas and treatment. lage, lbas, and lbas trt are mean centered. Because the
study originally noted a substantial decrease in seizures prior to the fourth doctor visit, an indicator,
v4, for the fourth visit was also recorded.
Breslow and Clayton (1993) fit a random-effects Poisson model for the number of observed seizures

log(ij ) = 0 + 1 treatij + 2 lbasij + 3 lbas trtij + 4 lageij + 5 v4ij + uj


for j = 1, . . . , 59 subjects and i = 1, . . . , 4 visits. The random effects uj are assumed to be normally
distributed with mean 0 and variance u2 .
. meqrpoisson seizures treat lbas lbas_trt lage v4 || subject:
Refining starting values:
Iteration 0:
log likelihood = -680.40577 (not concave)
Iteration 1:
log likelihood = -668.60112
Iteration 2:
log likelihood = -666.3822
Performing gradient-based optimization:
Iteration 0:
log likelihood = -666.3822
Iteration 1:
log likelihood = -665.4603
Iteration 2:
log likelihood = -665.29075
Iteration 3:
log likelihood = -665.29068
Mixed-effects Poisson regression
Number of obs
Group variable: subject
Number of groups
Obs per group: min
avg
max
Integration points =
7
Wald chi2(5)
Log likelihood = -665.29068
Prob > chi2
seizures

Coef.

treat
lbas
lbas_trt
lage
v4
_cons

-.9330388
.8844331
.3382609
.4842391
-.1610871
2.154575

Std. Err.
.4008345
.1312313
.2033384
.3472774
.0545758
.2200425

Random-effects Parameters

z
-2.33
6.74
1.66
1.39
-2.95
9.79

P>|z|
0.020
0.000
0.096
0.163
0.003
0.000

=
=
=
=
=
=
=

236
59
4
4.0
4
121.67
0.0000

[95% Conf. Interval]


-1.71866
.6272246
-.0602751
-.1964121
-.2680537
1.723299

-.1474177
1.141642
.7367969
1.16489
-.0541206
2.58585

Estimate

Std. Err.

[95% Conf. Interval]

.2528263

.0589559

.1600784

subject: Identity
var(_cons)
LR test vs. Poisson regression:

chibar2(01) =

.3993115

304.74 Prob>=chibar2 = 0.0000

The number of seizures before the fourth visit does exhibit a significant drop, and the patients
on progabide demonstrate a decrease in frequency of seizures compared with the placebo group.
The subject-specific random effects also appear significant: u2 = 0.25 with standard error 0.06. The
above results are also in good agreement with those of Breslow and Clayton (1993, table 4), who fit
this model by the method of penalized quasi-likelihood (PQL).
Because this is a simple random-intercept model, you can obtain equivalent results by using
xtpoisson with the re and normal options.

266

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

Example 2
In their study of PQL, Breslow and Clayton (1993) also fit a model where they dropped the fixed
effect on v4 and replaced it with a random subject-specific linear trend over the four doctor visits.
The model they fit is

log(ij ) = 0 + 1 treatij + 2 lbasij +3 lbas trtij +


4 lageij + 5 visitij + uj + vj visitij
where (uj , vj ) are bivariate normal with 0 mean and variancecovariance matrix
= Var

uj
vj

u2
uv

uv
v2

. meqrpoisson seizures treat lbas lbas_trt lage visit || subject: visit,


> cov(unstructured) intpoints(9)
Refining starting values:
Iteration 0:
Iteration 1:
Iteration 2:

log likelihood = -672.17188


log likelihood = -660.46056
log likelihood = -655.86727

(not concave)

Performing gradient-based optimization:


Iteration
Iteration
Iteration
Iteration

0:
1:
2:
3:

log
log
log
log

likelihood
likelihood
likelihood
likelihood

= -655.86727
= -655.6822
= -655.68103
= -655.68103

Mixed-effects Poisson regression


Group variable: subject

Number of obs
Number of groups

Integration points =
9
Log likelihood = -655.68103
seizures

Coef.

treat
lbas
lbas_trt
lage
visit
_cons

-.9286588
.8849767
.3379757
.4767192
-.2664098
2.099555

=
=

236
59

Obs per group: min =


avg =
max =

4
4.0
4

Wald chi2(5)
Prob > chi2
Std. Err.
.4021643
.131252
.2044445
.353622
.1647096
.2203712

z
-2.31
6.74
1.65
1.35
-1.62
9.53

P>|z|
0.021
0.000
0.098
0.178
0.106
0.000

Random-effects Parameters

Estimate

Std. Err.

subject: Unstructured
var(visit)
var(_cons)
cov(visit,_cons)

.5314808
.2514928
.0028715

.2293851
.0587892
.0887018

LR test vs. Poisson regression:

chi2(3) =

324.54

=
=

115.56
0.0000

[95% Conf. Interval]


-1.716886
.6277275
-.0627281
-.2163673
-.5892347
1.667635

-.1404313
1.142226
.7386795
1.169806
.0564151
2.531474

[95% Conf. Interval]

.2280931
.1590552
-.1709808

1.238406
.3976522
.1767238

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

267

In the above, we specified the cov(unstructured) option to allow correlation between uj and vj ,
although on the basis of the above output it probably was not necessarythe default Independent
structure would have sufficed. In the interest of getting more accurate estimates, we also increased
the number of quadrature points to nine, although the estimates do not change much when compared
with estimates based on the default seven quadrature points.
The essence of the above-fitted model is that after adjusting for other covariates, the log trend in
seizures is modeled as a random subject-specific line, with intercept distributed as N (0 , u2 ) and
slope distributed as N (5 , v2 ). From the above output, 0 = 2.10, u2 = 0.25, 5 = 0.27, and
v2 = 0.53.
You can predict the random effects uj and vj by using predict after meqrpoisson; see
[ME] meqrpoisson postestimation. Better still, you can obtain a predicted number of seizures that
takes these random effects into account.

A three-level model
meqrpoisson can also fit higher-level models with multiple levels of nested random effects.

Example 3
Rabe-Hesketh and Skrondal (2012, exercise 13.7) describe data from the Atlas of Cancer Mortality
in the European Economic Community (EEC) (Smans, Mair, and Boyle 1993). The data were analyzed
in Langford, Bentham, and McDonald (1998) and record the number of deaths among males due to
malignant melanoma during 19711980.
. use http://www.stata-press.com/data/r13/melanoma
(Skin cancer (melanoma) data)
. describe
Contains data from http://www.stata-press.com/data/r13/melanoma.dta
obs:
354
Skin cancer (melanoma) data
vars:
6
30 May 2013 17:10
size:
4,956
(_dta has notes)
storage
type

display
format

value
label

nation
region
county

byte
byte
int

%11.0g
%9.0g
%9.0g

deaths
expected
uv

int
float
float

%9.0g
%9.0g
%9.0g

variable name

variable label
Nation ID
Region ID: EEC level-I areas
County ID: EEC level-II/level-III
areas
No. deaths during 1971-1980
No. expected deaths
UV dose, mean-centered

Sorted by:

Nine European nations (variable nation) are represented, and data were collected over geographical
regions defined by EEC statistical services as level I areas (variable region), with deaths being
recorded for each of 354 counties, which are level II or level III EEC-defined areas (variable county,
which identifies the observations). Counties are nested within regions, and regions are nested within
nations.
The variable deaths records the number of deaths for each county, and expected records the
expected number of deaths (the exposure) on the basis of crude rates for the combined countries.
Finally, the variable uv is a measure of exposure to ultraviolet (UV) radiation.

268

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

In modeling the number of deaths, one possibility is to include dummy variables for the nine nations
as fixed effects. Another is to treat these as random effects and fit the three-level random-intercept
Poisson model,

log(ijk ) = log(expectedijk ) + 0 + 1 uvijk + uk + vjk


for nation k , region j , and county i. The model includes an exposure term for expected deaths.
. meqrpoisson deaths uv, exposure(expected) || nation: || region:
Refining starting values:
Iteration 0:
log likelihood = -1169.0851 (not concave)
Iteration 1:
log likelihood = -1156.523 (not concave)
Iteration 2:
log likelihood = -1101.8313
Performing gradient-based optimization:
Iteration 0:
log likelihood = -1101.8313
Iteration 1:
log likelihood = -1100.7407
Iteration 2:
log likelihood = -1098.0445
Iteration 3:
log likelihood = -1097.7212
Iteration 4:
log likelihood = -1097.714
Iteration 5:
log likelihood = -1097.714
Mixed-effects Poisson regression
Number of obs

Group Variable

No. of
Groups

nation
region

9
78

Log likelihood =

Observations per Group


Minimum
Average
Maximum
3
1

39.3
4.5

deaths

Coef.

Std. Err.

uv
_cons
ln(expected)

-.0281991
-.0639473
1

.0114027
.1335245
(exposure)

Random-effects Parameters

95
13

-2.47
-0.48

P>|z|
0.013
0.632

354

Integration
Points

Wald chi2(1)
Prob > chi2

-1097.714

7
7
=
=

6.12
0.0134

[95% Conf. Interval]


-.050548
-.3256505

-.0058503
.1977559

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

.1370339

.0722797

.0487365

.3853022

var(_cons)

.0483853

.010927

.0310802

.0753257

nation: Identity

region: Identity

LR test vs. Poisson regression:


chi2(2) = 1252.12
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

By including an exposure variable that is an expected rate, we are in effect specifying a linear model
for the log of the standardized mortality ratio, the ratio of observed deaths to expected deaths that is
based on a reference population. Here the reference population is all nine nations.
We now add a random intercept for counties nested within regions, making this a four-level
model. Because counties also identify the observations, the corresponding variance component can be
interpreted as a measure of overdispersion, variability above and beyond that allowed by a Poisson
process; see [R] nbreg and [ME] menbreg.

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

269

. meqrpoisson deaths uv, exposure(expected) || nation: || region: || county:,


> laplace
Refining starting values:
Iteration 0:
log likelihood = -1381.1202 (not concave)
Iteration 1:
log likelihood = -1144.7025 (not concave)
Iteration 2:
log likelihood = -1138.6807
Performing gradient-based optimization:
Iteration 0:
log likelihood = -1138.6807
Iteration 1:
log likelihood =
-1123.31
Iteration 2:
log likelihood = -1095.0497
Iteration 3:
log likelihood = -1086.9521
Iteration 4:
log likelihood = -1086.7321
Iteration 5:
log likelihood = -1086.7309
Iteration 6:
log likelihood = -1086.7309
Mixed-effects Poisson regression
Number of obs
=
354

Group Variable

No. of
Groups

nation
region
county

9
78
354

Observations per Group


Minimum
Average
Maximum
3
1
1

39.3
4.5
1.0

Integration
Points

95
13
1

1
1
1

Wald chi2(1)
Prob > chi2

Log likelihood = -1086.7309


deaths

Coef.

Std. Err.

uv
_cons
ln(expected)

-.0334681
-.0864109
1

.0113919
.1298713
(exposure)

Random-effects Parameters

z
-2.94
-0.67

P>|z|
0.003
0.506

=
=

8.63
0.0033

[95% Conf. Interval]


-.0557959
-.3409539

-.0111404
.1681321

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

.1287416

.0680887

.04566

.3629957

var(_cons)

.0405965

.0105002

.0244527

.0673986

var(_cons)

.0146027

.0050766

.0073878

.0288637

nation: Identity

region: Identity

county: Identity

LR test vs. Poisson regression:

chi2(3) =

1274.08

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.


Note: log-likelihood calculations are based on the Laplacian approximation.

In the above, we used a Laplacian approximation, which is not only faster but also produces estimates
that closely agree with those obtained with the default seven quadrature points.
See Computation time and the Laplacian approximation in [ME] me for a discussion comparing
Laplacian approximation with adaptive quadrature.

270

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

Stored results
meqrpoisson stores the following in e():
Scalars
e(N)
e(k)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(df m)
e(ll)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(reparm rc)
e(rc)
e(converged)

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
return code, final reparameterization
return code
1 if converged, 0 otherwise

Macros
e(cmd)
e(cmdline)
e(depvar)
e(ivars)
e(exposurevar)
e(model)
e(title)
e(offset)
e(redim)
e(vartypes)
e(revars)
e(n quad)
e(laplace)
e(chi2type)
e(vce)
e(vcetype)
e(method)
e(opt)
e(ml method)
e(technique)
e(datasignature)
e(datasignaturevars)
e(properties)
e(estat cmd)
e(predict)
e(marginsnotok)
e(asbalanced)
e(asobserved)

meqrpoisson
command as typed
name of dependent variable
grouping variables
exposure variable
Poisson
title in estimation output
offset
random-effects dimensions
variance-structure types
random-effects covariates
number of integration points
laplace, if Laplace approximation
Wald; type of model 2
bootstrap or jackknife if defined
title used to label Std. Err.
ML
type of optimization
type of ml method
maximization technique
the checksum
variables used in calculation of checksum
b V
program used to implement estat
program used to implement predict
predictions disallowed by margins
factor variables fvset as asbalanced
factor variables fvset as asobserved

Matrices
e(b)
e(Cns)
e(N g)
e(g min)
e(g avg)
e(g max)
e(V)

coefficient vector
constraints matrix
group counts
group-size minimums
group-size averages
group-size maximums
variancecovariance matrix of the estimator

Functions
e(sample)

marks estimation sample

number of observations
number of parameters
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
model degrees of freedom
log likelihood
2

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

271

Methods and formulas


In a two-level Poisson model, for cluster j , j = 1, . . . , M , the conditional distribution of
yj = (yj1 , . . . , yjnj ) , given a set of cluster-level random effects uj , is
nj
yij

f (yj |uj ) =

[{exp (xij + zij uj )}

exp { exp (xij + zij uj )} /yij !]

i=1
nj

{yij (xij + zij uj ) exp (xij + zij uj ) log(yij !)}

= exp
i=1
n

j
Defining c (yj ) = i=1
log(yij !), where c(yj ) does not depend on the model parameters, we
can express the above compactly in matrix notation,

f (yj |uj ) = exp yj (Xj + Zj uj ) 1 exp (Xj + Zj uj ) c (yj )


where Xj is formed by stacking the row vectors xij and Zj is formed by stacking the row vectors
zij . We extend the definition of exp() to be a vector function where necessary.
Because the prior distribution of uj is multivariate normal with mean 0 and q q variance matrix
, the likelihood contribution for the j th cluster is obtained by integrating uj out of the joint density
f (yj , uj ),
1/2

Lj (, ) = (2)q/2 ||

f (yj |uj ) exp uj 1 uj /2 duj


(2)
1/2

= exp {c (yj )} (2)q/2 ||


where

exp {g (, , uj )} duj

g (, , uj ) = yj (Xj + Zj uj ) 1 exp (Xj + Zj uj ) uj 1 uj /2

and for convenience, in the arguments of g() we suppress the dependence on the observable data
(yj , Xj , Zj ).
The integration in (2) has no closed form and thus must be approximated. The Laplacian approximation (Tierney and Kadane 1986; Pinheiro and Bates 1995) is based on a second-order Taylor
expansion of g (, , uj ) about the value of uj that maximizes it. Taking first and second derivatives,
we obtain
g (, , uj )
= Zj {yj m(, uj )} 1 uj
g (, , uj ) =
uj

g (, , uj ) =

2 g (, , uj )
= Zj V(, uj )Zj + 1
uj uj

where m(, uj ) is the vector function with the ith element equal to the conditional mean of yij
given uj , that is, exp(xij + zij uj ). V(, uj ) is the diagonal matrix whose diagonal entries vij
are the conditional variances of yij given uj , namely,

vij = exp (xij + zij uj )


because equality of mean and variance is a characteristic of the Poisson distribution.

272

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

The maximizer of g (, , uj ) is uj such that g (, , uj ) = 0. The integrand in (2) is proportional


to the posterior density f (uj |yj ), so uj also represents the posterior mode, a plausible estimator of
uj in its own right.
Given the above derivatives, the second-order Taylor approximation then takes the form

g (, , uj ) g (, , uj ) +

1
(uj uj ) g (, , uj ) (uj uj )
2

(3)

The first-derivative term vanishes because g (, , uj ) = 0. Therefore,

exp {g (, , uj )} duj exp {g (, , uj )}


1
exp (uj uj ) {g (, , uj )} (uj uj ) duj (4)
2

1/2

= exp {g (, , uj )} (2)q/2 |g (, , uj )|

because the latter integrand can be recognized as the kernel of a multivariate normal density.
Combining the above with (2) (and taking logs) gives the Laplacian log-likelihood contribution of
the j th cluster,

1
LLap
(, ) = log || log |Rj | + g (, , uj ) c(yj )
j
2
where Rj is an upper-triangular matrix such that g (, , uj ) = Rj Rj . Pinheiro and Chao (2006)
show that uj and Rj can be efficiently computed as the iterative solution to a least-squares problem
by using matrix decomposition methods similar to those used in fitting LME models (Bates and
Pinheiro 1998; Pinheiro and Bates 2000; [ME] mixed).
The fidelity of the Laplacian approximation is determined wholly by the accuracy of the approximation in (3). An alternative that does not depend so heavily on this approximation is integration via
AGQ (Naylor and Smith 1982; Liu and Pierce 1994).
The application of AGQ to this particular problem is from Pinheiro and Bates (1995). When we
reexamine the integral in question, a transformation of integration variables yields
1

exp {g (, , uj )} duj = |Rj |

exp g , , uj + R1
j t

dt
(5)

q/2

= (2)

|Rj |

exp g , , uj +

R1
j t

+ t t/2 (t)dt

where () is the standard multivariate normal density. Because the integrand is now expressed as
some function multiplied by a normal density, it can be estimated by applying the rules of standard

GaussHermite quadrature.
For a predetermined number of quadrature points NQ , define ak = 2ak

and wk = wk / , for k = 1, . . . , NQ , where (ak , wk ) are a set of abscissas and weights for
GaussHermite quadrature approximations of exp(x2 )f (x)dx, as obtained from Abramowitz and
Stegun (1972, 924).

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

273

Define ak = (ak1 , ak2 , . . . , akq ) ; that is, ak is a vector that spans the NQ abscissas over the
dimension q of the random effects. Applying quadrature rules to (5) yields the AGQ approximation,

exp {g (, , uj )} duj
NQ
1

(2)q/2 |Rj |

NQ

k1 =1

exp g , , uj + R1
j ak + ak ak /2

kq =1

wkp
p=1

(2)q/2 Gj (, )
resulting in the AGQ log-likelihood contribution of the j th cluster,

1
LAGQ
(, ) = log || + log Gj (, ) c(yj )
j
2
The adaptive part of adaptive Gaussian quadrature lies in the translation and rescaling of the
integration variables in (5) by using uj and R1
j , respectively. This transformation of quadrature
abscissas (centered at 0 in standard form) is chosen to better capture the features of the integrand,
through which (4) can be seen to resemble a multivariate normal distribution with mean uj and
T
variance R1
j Rj . AGQ is therefore not as dependent as the Laplace method upon the approximation
in (3). In AGQ, (3) serves merely to redirect the quadrature abscissas, with the AGQ approximation
improving as the number of quadrature points, NQ , increases. In fact, Pinheiro and Bates (1995)
point out that AGQ with only one quadrature point (a = 0 and w = 1) reduces to the Laplacian
approximation.
The log likelihood for the entire dataset is then simply the sum of the contributions of the M individual
M
M
Lap
AGQ
clusters, namely, L(, ) = j=1 Lj (, ) for Laplace and L(, ) = j=1 Lj
(, ) for
AGQ.
Maximization of L(, ) is performed with respect to (, ), where is a vector comprising the
unique elements of the matrix square root of . This is done to ensure that is always positive
semidefinite. If the matlog option is specified, then instead consists of the unique elements of
the matrix logarithm of . For well-conditioned problems, both methods produce equivalent results,
yet our experience deems the former as more numerically stable near the boundary of the parameter
space.
Once maximization is achieved, parameter estimates are mapped from (, ) to (, ), where
is a vector containing the unique (estimated) elements of , expressed as logarithms of standard
deviations for the diagonal elements and hyperbolic arctangents of the correlations for off-diagonal
elements. This last step is necessary to (a) obtain a parameterization under which parameter estimates
can be displayed and interpreted individually, rather than as elements of a matrix square root (or
logarithm), and (b) parameterize these elements such that their ranges each encompass the entire real
line.
Parameter estimates are stored in e(b) as (, ), with the corresponding variancecovariance matrix
stored in e(V). Parameter estimates can be displayed in this metric by specifying the estmetric option.
However, in meqrpoisson output, variance components are most often displayed either as variances
and covariances (the default) or as standard deviations and correlations (option stddeviations).
The approach outlined above can be extended from two-level models to models with three or more
levels; see Pinheiro and Chao (2006) for details.

274

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

References
Abramowitz, M., and I. A. Stegun, ed. 1972. Handbook of Mathematical Functions with Formulas, Graphs, and
Mathematical Tables. 10th ed. Washington, DC: National Bureau of Standards.
Andrews, M. J., T. Schank, and R. Upward. 2006. Practical fixed-effects estimation methods for the three-way
error-components model. Stata Journal 6: 461481.
Bates, D. M., and J. C. Pinheiro. 1998. Computational methods for multilevel modelling. In Technical Memorandum
BL0112140-980226-01TM. Murray Hill, NJ: Bell Labs, Lucent Technologies.
http://stat.bell-labs.com/NLME/CompMulti.pdf.
Breslow, N. E., and D. G. Clayton. 1993. Approximate inference in generalized linear mixed models. Journal of the
American Statistical Association 88: 925.
Gutierrez, R. G., S. L. Carter, and D. M. Drukker. 2001. sg160: On boundary-value likelihood-ratio tests. Stata
Technical Bulletin 60: 1518. Reprinted in Stata Technical Bulletin Reprints, vol. 10, pp. 269273. College Station,
TX: Stata Press.
Joe, H. 2008. Accuracy of Laplace approximation for discrete response mixed models. Computational Statistics &
Data Analysis 52: 50665074.
Laird, N. M., and J. H. Ware. 1982. Random-effects models for longitudinal data. Biometrics 38: 963974.
Langford, I. H., G. Bentham, and A. McDonald. 1998. Multi-level modelling of geographically aggregated health
data: A case study on malignant melanoma mortality and UV exposure in the European community. Statistics in
Medicine 17: 4157.
Leyland, A. H., and H. Goldstein, ed. 2001. Multilevel Modelling of Health Statistics. New York: Wiley.
Lin, X., and N. E. Breslow. 1996. Bias correction in generalized linear mixed models with multiple components of
dispersion. Journal of the American Statistical Association 91: 10071016.
Liu, Q., and D. A. Pierce. 1994. A note on GaussHermite quadrature. Biometrika 81: 624629.
Marchenko, Y. V. 2006. Estimating variance components in Stata. Stata Journal 6: 121.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
McLachlan, G. J., and K. E. Basford. 1988. Mixture Models. New York: Dekker.
Naylor, J. C., and A. F. M. Smith. 1982. Applications of a method for the efficient computation of posterior
distributions. Journal of the Royal Statistical Society, Series C 31: 214225.
Pinheiro, J. C., and D. M. Bates. 1995. Approximations to the log-likelihood function in the nonlinear mixed-effects
model. Journal of Computational and Graphical Statistics 4: 1235.
. 2000. Mixed-Effects Models in S and S-PLUS. New York: Springer.
Pinheiro, J. C., and E. C. Chao. 2006. Efficient Laplacian and adaptive Gaussian quadrature algorithms for multilevel
generalized linear mixed models. Journal of Computational and Graphical Statistics 15: 5881.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
Rabe-Hesketh, S., A. Skrondal, and A. Pickles. 2005. Maximum likelihood estimation of limited and discrete dependent
variable models with nested random effects. Journal of Econometrics 128: 301323.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Self, S. G., and K.-Y. Liang. 1987. Asymptotic properties of maximum likelihood estimators and likelihood ratio tests
under nonstandard conditions. Journal of the American Statistical Association 82: 605610.
Skrondal, A., and S. Rabe-Hesketh. 2004. Generalized Latent Variable Modeling: Multilevel, Longitudinal, and
Structural Equation Models. Boca Raton, FL: Chapman & Hall/CRC.
Smans, M., C. S. Mair, and P. Boyle. 1993. Atlas of Cancer Mortality in the European Economic Community. Lyon,
France: IARC Scientific Publications.
Thall, P. F., and S. C. Vail. 1990. Some covariance models for longitudinal count data with overdispersion. Biometrics
46: 657671.
Tierney, L., and J. B. Kadane. 1986. Accurate approximations for posterior moments and marginal densities. Journal
of the American Statistical Association 81: 8286.

meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)

Also see
[ME] meqrpoisson postestimation Postestimation tools for meqrpoisson
[ME] menbreg Multilevel mixed-effects negative binomial regression
[ME] mepoisson Multilevel mixed-effects Poisson regression
[ME] me Introduction to multilevel mixed-effects models
[MI] estimation Estimation commands for use with mi estimate
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtpoisson Fixed-effects, random-effects, and population-averaged Poisson models
[U] 20 Estimation and postestimation commands

275

Title
meqrpoisson postestimation Postestimation tools for meqrpoisson
Description
Options for predict
Options for estat recovariance
Methods and formulas

Syntax for predict


Syntax for estat
Remarks and examples
References

Menu for predict


Menu for estat
Stored results
Also see

Description
The following postestimation commands are of special interest after meqrpoisson:
Command

Description

estat group
summarize the composition of the nested groups
estat recovariance display the estimated random-effects covariance matrix (or matrices)
The following standard postestimation commands are also available:
Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

276

meqrpoisson postestimation Postestimation tools for meqrpoisson

277

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
estat recovariance displays the estimated variancecovariance matrix of the random effects
for each level in the model. Random effects can be either random intercepts, in which case the
corresponding rows and columns of the matrix are labeled as cons, or random coefficients, in which
case the label is the name of the associated variable in the data.

Syntax for predict


Syntax for obtaining estimated random effects and their standard errors
predict

stub* | newvarlist

type

if

in ,

reffects | reses

relevel(levelvar)
Syntax for obtaining other predictions
predict

type

newvar

if

in

, statistic nooffset fixedonly

Description

statistic
Main

predicted mean; the default


linear predictor for the fixed portion of the model only
standard error of the fixed-portion linear prediction
Pearson residuals
deviance residuals
Anscombe residuals

mu
xb
stdp
pearson
deviance
anscombe

These statistics are available both in and out of sample; type predict
only for the estimation sample.

. . . if e(sample) . . . if wanted

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

Options for predict

Main

reffects calculates posterior modal estimates of the random effects. By default, estimates for all
random effects in the model are calculated. However, if the relevel(levelvar) option is specified,
then estimates for only level levelvar in the model are calculated. For example, if classes are
nested within schools, then typing
. predict b*, reffects relevel(school)

278

meqrpoisson postestimation Postestimation tools for meqrpoisson

would yield random-effects estimates at the school level. You must specify q new variables, where
q is the number of random-effects terms in the model (or level). However, it is much easier to
just specify stub* and let Stata name the variables stub1, stub2, . . . , stubq for you.
reses calculates standard errors for the random-effects estimates obtained by using the reffects
option. By default, standard errors for all random effects in the model are calculated. However,
if the relevel(levelvar) option is specified, then standard errors for only level levelvar in the
model are calculated. For example, if classes are nested within schools, then typing
. predict se*, reses relevel(school)
would yield standard errors at the school level. You must specify q new variables, where q is the
number of random-effects terms in the model (or level). However, it is much easier to just specify
stub* and let Stata name the variables stub1, stub2, . . . , stubq for you.
The reffects and reses options often generate multiple new variables at once. When this occurs,
the random effects (or standard errors) contained in the generated variables correspond to the order
in which the variance components are listed in the output of meqrpoisson. Still, examining the
variable labels of the generated variables (with the describe command, for instance) can be
useful in deciphering which variables correspond to which terms in the model.
relevel(levelvar) specifies the level in the model at which predictions for random effects and their
standard errors are to be obtained. levelvar is the name of the model level and is either the name
of the variable describing the grouping at that level or is all, a special designation for a group
comprising all the estimation data.
mu, the default, calculates the predicted mean, that is, the predicted count. By default, this is based
on a linear predictor that includes both the fixed effects and the random effects, and the predicted
mean is conditional on the values of the random effects. Use the fixedonly option (see below) if
you want predictions that include only the fixed portion of the model, that is, if you want random
effects set to 0.
xb calculates the linear prediction x based on the estimated fixed effects (coefficients) in the model.
This is equivalent to fixing all random effects in the model to their theoretical (prior) mean value
of 0.
stdp calculates the standard error of the fixed-effects linear predictor x.
pearson calculates Pearson residuals. Pearson residuals large in absolute value may indicate a lack
of fit. By default, residuals include both the fixed portion and the random portion of the model.
The fixedonly option modifies the calculation to include the fixed portion only.
deviance calculates deviance residuals. Deviance residuals are recommended by McCullagh and
Nelder (1989) as having the best properties for examining the goodness of fit of a GLM. They are
approximately normally distributed if the model is correctly specified. They may be plotted against
the fitted values or against a covariate to inspect the models fit. By default, residuals include
both the fixed portion and the random portion of the model. The fixedonly option modifies the
calculation to include the fixed portion only.
anscombe calculates Anscombe residuals, which are designed to closely follow a normal distribution.
By default, residuals include both the fixed portion and the random portion of the model. The
fixedonly option modifies the calculation to include the fixed portion only.
nooffset is relevant only if you specified offset(varnameo ) or exposure(varnamee ) for meqrpoisson. It modifies the calculations made by predict so that they ignore the offset/exposure
variable; the linear prediction is treated as X + Zu rather than X + Zu + offset, or
X + Zu + ln(exposure), whichever is relevant.

meqrpoisson postestimation Postestimation tools for meqrpoisson

279

fixedonly modifies predictions to include only the fixed portion of the model, equivalent to setting
all random effects equal to 0; see the mu option.

Syntax for estat


Summarize the composition of the nested groups
estat group
Display the estimated random-effects covariance matrix (or matrices)
estat recovariance

, relevel(levelvar) correlation matlist options

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

Options for estat recovariance


relevel(levelvar) specifies the level in the model for which the random-effects covariance matrix
is to be displayed and returned in r(cov). By default, the covariance matrices for all levels in the
model are displayed. levelvar is the name of the model level and is either the name of the variable
describing the grouping at that level or is all, a special designation for a group comprising all
the estimation data.
correlation displays the covariance matrix as a correlation matrix and returns the correlation matrix
in r(corr).
matlist options are style and formatting options that control how the matrix (or matrices) is displayed;
see [P] matlist for a list of that are available.

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a Poisson mixedeffects model with meqrpoisson. For the most part, calculation centers around obtaining estimates
of the subject/group-specific random effects. Random effects are not estimated when the model is fit
but instead need to be predicted after estimation.

Example 1
In example 2 of [ME] meqrpoisson, we modeled the number of observed epileptic seizures as a
function of treatment with the drug progabide and other covariates,

log(ij ) = 0 + 1 treatij + 2 lbasij +3 lbas trtij +


4 lageij + 5 visitij + uj + vj visitij
where (uj , vj ) are bivariate normal with 0 mean and variancecovariance matrix
= Var

uj
vj

u2
uv

uv
v2

280

meqrpoisson postestimation Postestimation tools for meqrpoisson


. use http://www.stata-press.com/data/r13/epilepsy
(Epilepsy data; progabide drug treatment)
. meqrpoisson seizures treat lbas lbas_trt lage visit || subject: visit,
> cov(unstructured) intpoints(9)
Refining starting values:
Iteration 0:
log likelihood = -672.17188 (not concave)
Iteration 1:
log likelihood = -660.46056
Iteration 2:
log likelihood = -655.86727
Performing gradient-based optimization:
Iteration 0:
log likelihood = -655.86727
Iteration 1:
log likelihood = -655.6822
Iteration 2:
log likelihood = -655.68103
Iteration 3:
log likelihood = -655.68103
Mixed-effects Poisson regression
Number of obs
=
236
Group variable: subject
Number of groups
=
59
Obs per group: min =
4
avg =
4.0
max =
4
Integration points =
9
Wald chi2(5)
=
115.56
Log likelihood = -655.68103
Prob > chi2
=
0.0000
seizures

Coef.

treat
lbas
lbas_trt
lage
visit
_cons

-.9286588
.8849767
.3379757
.4767192
-.2664098
2.099555

Std. Err.
.4021643
.131252
.2044445
.353622
.1647096
.2203712

z
-2.31
6.74
1.65
1.35
-1.62
9.53

P>|z|
0.021
0.000
0.098
0.178
0.106
0.000

Random-effects Parameters

Estimate

Std. Err.

subject: Unstructured
var(visit)
var(_cons)
cov(visit,_cons)

.5314808
.2514928
.0028715

.2293851
.0587892
.0887018

[95% Conf. Interval]


-1.716886
.6277275
-.0627281
-.2163673
-.5892347
1.667635

-.1404313
1.142226
.7386795
1.169806
.0564151
2.531474

[95% Conf. Interval]

.2280931
.1590552
-.1709808

1.238406
.3976522
.1767238

LR test vs. Poisson regression:


chi2(3) =
324.54
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

The purpose of this model was to allow subject-specific linear log trends over each subjects four
doctor visits, after adjusting for the other covariates. The intercepts of these lines are distributed
N (0 , u2 ), and the slopes are distributed N (5 , v2 ), based on the fixed effects and assumed distribution
of the random effects.
We can use predict to obtain estimates of the random effects uj and vj and combine these with
our estimates of 0 and 5 to obtain the intercepts and slopes of the linear log trends.
. predict re_visit re_cons, reffects
. generate b1 = _b[visit] + re_visit
. generate b0 = _b[_cons] + re_cons
. by subject, sort: generate tolist = _n==1

meqrpoisson postestimation Postestimation tools for meqrpoisson

281

. list subject treat b1 b0 if tolist & (subject <=5 | subject >=55)


subject

treat

b1

b0

1.
5.
9.
13.
17.

1
2
3
4
5

0
0
0
0
0

-.4284563
-.2727145
.0026486
-.3194157
.6063656

2.164691
2.179111
2.450811
2.268827
2.123723

217.
221.
225.
229.
233.

55
56
57
58
59

1
1
1
1
1

-.2304782
.2904741
-.4831492
-.252236
-.1266651

2.311493
3.211369
1.457485
1.168154
2.204869

We list these slopes (b1) and intercepts (b0) for five control subjects and five subjects on the treatment.
. count
31
. count
25
. count
28
. count
20

if tolist & treat


if tolist & treat & b1 < 0
if tolist & !treat
if tolist & !treat & b1 < 0

We also find that 25 of the 31 subjects taking progabide were estimated to have a downward trend
in seizures over their four doctor visits, compared with 20 of the 28 control subjects.
We also obtain predictions for number of seizures, and unless we specify the fixedonly option,
these predictions will incorporate the estimated subject-specific random effects.
. predict n
(option mu assumed; predicted means)
. list subject treat visit seizures n if subject <= 2 | subject >= 58, sep(0)

1.
2.
3.
4.
5.
6.
7.
8.
229.
230.
231.
232.
233.
234.
235.
236.

subject

treat

visit

seizures

1
1
1
1
2
2
2
2
58
58
58
58
59
59
59
59

0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1

-.3
-.1
.1
.3
-.3
-.1
.1
.3
-.3
-.1
.1
.3
-.3
-.1
.1
.3

5
3
3
3
3
5
3
3
0
0
0
0
1
4
3
2

3.887582
3.568324
3.275285
3.00631
3.705628
3.508926
3.322664
3.14629
.9972093
.9481507
.9015056
.8571553
2.487858
2.425625
2.364948
2.305789

282

meqrpoisson postestimation Postestimation tools for meqrpoisson

Technical note
Out-of-sample predictions are permitted after meqrpoisson, but if these predictions involve
estimated random effects, the integrity of the estimation data must be preserved. If the estimation data
have changed since the model was fit, predict will be unable to obtain predicted random effects that
are appropriate for the fitted model and will give an error. Thus to obtain out-of-sample predictions
that contain random-effects terms, be sure that the data for these predictions are in observations that
augment the estimation data.

Stored results
estat recovariance stores the following in r():
Scalars
r(relevels)
Matrices
r(Cov#)
r(Corr#)

number of levels
level-# random-effects covariance matrix
level-# random-effects correlation matrix (if option correlation was specified)

For a G-level nested model, # can be any integer between 2 and G.

Methods and formulas


Continuing the discussion in Methods and formulas of [ME] meqrpoisson and using the definitions
and formulas defined there, we begin by considering the prediction of the random effects uj for the
j th cluster in a two-level model.
Given a set of estimated meqrpoisson parameters, (, ), a profile likelihood in uj is derived
from the joint distribution f (yj , uj ) as

Lj (uj ) = exp {c (yj )} (2)q/2 ||1/2 exp g , , uj

(1)

The conditional maximum likelihood estimator of uj conditional on fixed (, ) is the maximizer


of Lj (uj ) or, equivalently, the value of uj that solves

0=g

, , uj

= Zj yj m(, uj )

uj

Because (1) is proportional to the conditional density f (uj |yj ), you can also refer to uj as the
conditional mode (or posterior mode if you lean toward Bayesian terminology). Regardless, you are
referring to the same estimator.
Conditional standard errors for the estimated random effects are derived from standard theory of
maximum likelihood, which dictates that the asymptotic variance matrix of uj is the negative inverse
of the Hessian, which is estimated as

, , uj

= Zj V(, uj )Zj +

Similar calculations extend to models with more than one level of random effects; see Pinheiro and
Chao (2006).

meqrpoisson postestimation Postestimation tools for meqrpoisson

283

For any observation i in the j th cluster in a two-level model, define the linear predictor as

ij = xij + zij uj
In a three-level model, for the ith observation within the j th level-two cluster within the k th level-three
cluster,
(3) (3)
(2) (2)
ijk = xijk + zijk uk + zijk ujk
where z(p) and u(p) refer to the level p design variables and random effects, respectively. For models
with more than three levels, the definition of extends in the natural way, with only the notation
becoming more complicated.
If the fixedonly option is specified, contains the linear predictor for only the fixed portion of
the model, for example, in a two-level model ij = xij . In what follows, we assume a two-level
model, with the only necessary modification for multilevel models being the indexing.
The predicted mean conditional on the random effects uj is

ij = exp(ij )
Pearson residuals are calculated as
P
ij
=

yij ij
{V (ij )}1/2

for V (ij ) = ij .
Deviance residuals are calculated as
D
ij
= sign(yij ij ) dij2

where

dij2 =

2ij

if yij = 0

2 yij log

yij
ij

(yij ij )

otherwise

Anscombe residuals are calculated as


2/3

A
ij

2/3

3 yij ij
1/6

2ij

For a discussion of the general properties of the above residuals, see Hardin and Hilbe (2012,
chap. 4).

References
Hardin, J. W., and J. M. Hilbe. 2012. Generalized Linear Models and Extensions. 3rd ed. College Station, TX: Stata
Press.
McCullagh, P., and J. A. Nelder. 1989. Generalized Linear Models. 2nd ed. London: Chapman & Hall/CRC.
Pinheiro, J. C., and E. C. Chao. 2006. Efficient Laplacian and adaptive Gaussian quadrature algorithms for multilevel
generalized linear mixed models. Journal of Computational and Graphical Statistics 15: 5881.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.

284

meqrpoisson postestimation Postestimation tools for meqrpoisson

Also see
[ME] meqrpoisson Multilevel mixed-effects Poisson regression (QR decomposition)
[U] 20 Estimation and postestimation commands

Title
mixed Multilevel mixed-effects linear regression
Syntax
Remarks and examples
References

Menu
Stored results
Also see

Description
Methods and formulas

Options
Acknowledgments

Syntax
mixed depvar fe equation

|| re equation

|| re equation . . .

, options

where the syntax of fe equation is


indepvars

if

in

weight

, fe options

and the syntax of re equation is one of the following:


for random coefficients and intercepts
levelvar:

varlist

, re options

for random effects among the values of a factor variable


levelvar: R.varname , re options
levelvar is a variable identifying the group structure for the random effects at that level or is all
representing one group comprising all observations.
fe options

Description

Model

noconstant

suppress constant term from the fixed-effects equation

re options

Description

Model

covariance(vartype)
noconstant
collinear
fweight(exp)
pweight(exp)

variancecovariance structure of the random effects


suppress constant term from the random-effects equation
keep collinear variables
frequency weights at higher levels
sampling weights at higher levels

285

286

mixed Multilevel mixed-effects linear regression

options

Description

Model

mle
reml
pwscale(scale method)
residuals(rspec)

fit model via maximum likelihood; the default


fit model via restricted maximum likelihood
control scaling of sampling weights in two-level models
structure of residual errors

SE/Robust

vce(vcetype)

vcetype may be oim, robust, or cluster clustvar

Reporting

level(#)
variance
stddeviations
noretable
nofetable
estmetric
noheader
nogroup
nostderr
nolrtest
display options

set confidence level; default is level(95)


show random-effects and residual-error parameter estimates as variances
and covariances; the default
show random-effects and residual-error parameter estimates as standard
deviations
suppress random-effects table
suppress fixed-effects table
show parameter estimates in the estimation metric
suppress output header
suppress table summarizing groups
do not estimate standard errors of random-effects parameters
do not perform likelihood-ratio test comparing with linear regression
control column formats, row spacing, line width, display of omitted
variables and base and empty cells, and factor-variable labeling

EM options

emiterate(#)
emtolerance(#)
emonly
emlog
emdots

number of EM iterations; default is emiterate(20)


EM convergence tolerance; default is emtolerance(1e-10)
fit model exclusively using EM
show EM iteration log
show EM iterations as dots

Maximization

maximize options
matsqrt
matlog

control the maximization process; seldom used


parameterize variance components using matrix square roots; the default
parameterize variance components using matrix logarithms

coeflegend

display legend instead of statistics

mixed Multilevel mixed-effects linear regression

vartype

Description

independent

one unique variance parameter per random effect, all covariances 0;


the default unless the R. notation is used
equal variances for random effects, and one common pairwise
covariance
equal variances for random effects, all covariances 0;
the default if the R. notation is used
all variances and covariances to be distinctly estimated

exchangeable
identity
unstructured

287

indepvars may contain factor variables; see [U] 11.4.3 Factor variables.
depvar, indepvars, and varlist may contain time-series operators; see [U] 11.4.4 Time-series varlists.
bootstrap, by, jackknife, mi estimate, rolling, and statsby are allowed; see [U] 11.1.10 Prefix commands.
Weights are not allowed with the bootstrap prefix; see [R] bootstrap.
pweights and fweights are allowed; see [U] 11.1.6 weight.
coeflegend does not appear in the dialog box.
See [U] 20 Estimation and postestimation commands for more capabilities of estimation commands.

Menu
Statistics

>

Multilevel mixed-effects models

>

Linear regression

Description
mixed fits linear mixed-effects models. The overall error distribution of the linear mixed-effects
model is assumed to be Gaussian, and heteroskedasticity and correlations within lowest-level groups
also may be modeled.

Options

Model

noconstant suppresses the constant (intercept) term and may be specified for the fixed-effects
equation and for any or all of the random-effects equations.
covariance(vartype), where vartype is
independent | exchangeable | identity | unstructured
specifies the structure of the covariance matrix for the random effects and may be specified for
each random-effects equation. An independent covariance structure allows for a distinct variance
for each random effect within a random-effects equation and assumes that all covariances are 0.
exchangeable structure specifies one common variance for all random effects and one common
pairwise covariance. identity is short for multiple of the identity; that is, all variances are
equal and all covariances are 0. unstructured allows for all variances and covariances to be
distinct. If an equation consists of p random-effects terms, the unstructured covariance matrix will
have p(p + 1)/2 unique parameters.
covariance(independent) is the default, except when the R. notation is used, in which
case covariance(identity) is the default and only covariance(identity) and covariance(exchangeable) are allowed.

288

mixed Multilevel mixed-effects linear regression

collinear specifies that mixed not omit collinear variables from the random-effects equation.
Usually, there is no reason to leave collinear variables in place; in fact, doing so usually causes
the estimation to fail because of the matrix singularity caused by the collinearity. However, with
certain models (for example, a random-effects model with a full set of contrasts), the variables
may be collinear, yet the model is fully identified because of restrictions on the random-effects
covariance structure. In such cases, using the collinear option allows the estimation to take
place with the random-effects equation intact.
fweight(exp) specifies frequency weights at higher levels in a multilevel model, whereas frequency
weights at the first level (the observation level) are specified in the usual manner, for example,
[fw=fwtvar1]. exp can be any valid Stata expression, and you can specify fweight() at levels
two and higher of a multilevel model. For example, in the two-level model
. mixed fixed_portion [fw = wt1] || school: . . . , fweight(wt2) . . .
the variable wt1 would hold the first-level (the observation-level) frequency weights, and wt2
would hold the second-level (the school-level) frequency weights.
pweight(exp) specifies sampling weights at higher levels in a multilevel model, whereas sampling
weights at the first level (the observation level) are specified in the usual manner, for example,
[pw=pwtvar1]. exp can be any valid Stata expression, and you can specify pweight() at levels
two and higher of a multilevel model. For example, in the two-level model
. mixed fixed_portion [pw = wt1] || school: . . . , pweight(wt2) . . .
variable wt1 would hold the first-level (the observation-level) sampling weights, and wt2 would
hold the second-level (the school-level) sampling weights.
See Survey data in Remarks and examples below for more information regarding the use of
sampling weights in multilevel models.
Weighted estimation, whether frequency or sampling, is not supported under restricted maximumlikelihood estimation (REML).
mle and reml specify the statistical method for fitting the model.
mle, the default, specifies that the model be fit using maximum likelihood (ML).
reml specifies that the model be fit using restricted maximum likelihood (REML), also known as
residual maximum likelihood.
pwscale(scale method), where scale method is
size | effective | gk
controls how sampling weights (if specified) are scaled in two-level models.
scale method size specifies that first-level (observation-level) weights be scaled so that they
sum to the sample size of their corresponding second-level cluster. Second-level sampling
weights are left unchanged.
scale method effective specifies that first-level weights be scaled so that they sum to the
effective sample size of their corresponding second-level cluster. Second-level sampling weights
are left unchanged.
scale method gk specifies the Graubard and Korn (1996) method. Under this method, secondlevel weights are set to the cluster averages of the products of the weights at both levels, and
first-level weights are then set equal to 1.
pwscale() is supported only with two-level models. See Survey data in Remarks and examples
below for more details on using pwscale().

mixed Multilevel mixed-effects linear regression

289

residuals(rspec), where rspec is


restype , residual options
specifies the structure of the residual errors within the lowest-level groups (the second level of a
multilevel model with the observations comprising the first level) of the linear mixed model. For
example, if you are modeling random effects for classes nested within schools, then residuals()
refers to the residual variancecovariance structure of the observations within classes, the lowestlevel groups.
restype is
independent | exchangeable | ar # | ma # | unstructured |
banded # | toeplitz # | exponential
By default, restype is independent, which means that all residuals are independent and
identically distributed (i.i.d.) Gaussian with one common variance. When combined with
by(varname), independence is still assumed, but you estimate a distinct variance for each
level of varname. Unlike with the structures described below, varname does not need to be
constant within groups.
restype exchangeable estimates two parameters, one common within-group variance and one
common pairwise covariance. When combined with by(varname), these two parameters
are distinctly estimated for each level of varname. Because you are modeling a withingroup covariance, varname must be constant within lowest-level groups.
restype ar # assumes that within-group errors have an autoregressive (AR) structure of
order #; ar 1 is the default. The t(varname) option is required, where varname is an
integer-valued time variable used to order the observations within groups and to determine
the lags between successive observations. Any nonconsecutive time values will be treated
as gaps. For this structure, # + 1 parameters are estimated (# AR coefficients and one
overall error variance). restype ar may be combined with by(varname), but varname
must be constant within groups.
restype ma # assumes that within-group errors have a moving average (MA) structure of
order #; ma 1 is the default. The t(varname) option is required, where varname is an
integer-valued time variable used to order the observations within groups and to determine
the lags between successive observations. Any nonconsecutive time values will be treated
as gaps. For this structure, # + 1 parameters are estimated (# MA coefficients and one
overall error variance). restype ma may be combined with by(varname), but varname
must be constant within groups.
restype unstructured is the most general structure; it estimates distinct variances for
each within-group error and distinct covariances for each within-group error pair. The
t(varname) option is required, where varname is a nonnegative-integervalued variable
that identifies the observations within each group. The groups may be unbalanced in that
not all levels of t() need to be observed within every group, but you may not have
repeated t() values within any particular group. When you have p levels of t(), then
p(p + 1)/2 parameters are estimated. restype unstructured may be combined with
by(varname), but varname must be constant within groups.
restype banded # is a special case of unstructured that restricts estimation to the
covariances within the first # off-diagonals and sets the covariances outside this band to
0. The t(varname) option is required, where varname is a nonnegative-integervalued
variable that identifies the observations within each group. # is an integer between 0 and
p 1, where p is the number of levels of t(). By default, # is p 1; that is, all elements

290

mixed Multilevel mixed-effects linear regression

of the covariance matrix are estimated. When # is 0, only the diagonal elements of the
covariance matrix are estimated. restype banded may be combined with by(varname),
but varname must be constant within groups.
restype toeplitz # assumes that within-group errors have Toeplitz structure of order #,
for which correlations are constant with respect to time lags less than or equal to #
and are 0 for lags greater than #. The t(varname) option is required, where varname
is an integer-valued time variable used to order the observations within groups and to
determine the lags between successive observations. # is an integer between 1 and the
maximum observed lag (the default). Any nonconsecutive time values will be treated as
gaps. For this structure, # + 1 parameters are estimated (# correlations and one overall
error variance). restype toeplitz may be combined with by(varname), but varname
must be constant within groups.
restype exponential is a generalization of the AR covariance model that allows for unequally
spaced and noninteger time values. The t(varname) option is required, where varname
is real-valued. For the exponential covariance model, the correlation between two errors
is the parameter , raised to a power equal to the absolute value of the difference between
the t() values for those errors. For this structure, two parameters are estimated (the
correlation parameter and one overall error variance). restype exponential may be
combined with by(varname), but varname must be constant within groups.
residual options are by(varname) and t(varname).
by(varname) is for use within the residuals() option and specifies that a set of distinct
residual-error parameters be estimated for each level of varname. In other words, you
use by() to model heteroskedasticity.
t(varname) is for use within the residuals() option to specify a time variable for the
ar, ma, toeplitz, and exponential structures, or to identify the observations when
restype is unstructured or banded.

SE/Robust

vce(vcetype) specifies the type of standard error reported, which includes types that are derived
from asymptotic theory (oim), that are robust to some kinds of misspecification (robust), and
that allow for intragroup correlation (cluster clustvar); see [R] vce option. If vce(robust) is
specified, robust variances are clustered at the highest level in the multilevel model.
vce(robust) and vce(cluster clustvar) are not supported with REML estimation.

Reporting

level(#); see [R] estimation options.


variance, the default, displays the random-effects and residual-error parameter estimates as variances
and covariances.
stddeviations displays the random-effects and residual-error parameter estimates as standard
deviations and correlations.
noretable suppresses the random-effects table from the output.
nofetable suppresses the fixed-effects table from the output.
estmetric displays all parameter estimates in the estimation metric. Fixed-effects estimates are
unchanged from those normally displayed, but random-effects parameter estimates are displayed
as log-standard deviations and hyperbolic arctangents of correlations, with equation names that

mixed Multilevel mixed-effects linear regression

291

organize them by model level. Residual-variance parameter estimates are also displayed in their
original estimation metric.
noheader suppresses the output header, either at estimation or upon replay.
nogroup suppresses the display of group summary information (number of groups, average group
size, minimum, and maximum) from the output header.
nostderr prevents mixed from calculating standard errors for the estimated random-effects parameters,
although standard errors are still provided for the fixed-effects parameters. Specifying this option
will speed up computation times. nostderr is available only when residuals are modeled as
independent with constant variance.
nolrtest prevents mixed from fitting a reference linear regression model and using this model to
calculate a likelihood-ratio test comparing the mixed model to ordinary regression. This option
may also be specified on replay to suppress this test from the output.
display options: noomitted, vsquish, noemptycells, baselevels, allbaselevels, nofvlabel, fvwrap(#), fvwrapon(style), cformat(% fmt), pformat(% fmt), sformat(% fmt), and
nolstretch; see [R] estimation options.

EM options

These options control the expectation-maximization (EM) iterations that take place before estimation
switches to a gradient-based method. When residuals are modeled as independent with constant
variance, EM will either converge to the solution or bring parameter estimates close to the solution.
For other residual structures or for weighted estimation, EM is used to obtain starting values.
emiterate(#) specifies the number of EM iterations to perform. The default is emiterate(20).
emtolerance(#) specifies the convergence tolerance for the EM algorithm. The default is
emtolerance(1e-10). EM iterations will be halted once the log (restricted) likelihood changes
by a relative amount less than #. At that point, optimization switches to a gradient-based method,
unless emonly is specified, in which case maximization stops.
emonly specifies that the likelihood be maximized exclusively using EM. The advantage of specifying
emonly is that EM iterations are typically much faster than those for gradient-based methods.
The disadvantages are that EM iterations can be slow to converge (if at all) and that EM provides
no facility for estimating standard errors for the random-effects parameters. emonly is available
only with unweighted estimation and when residuals are modeled as independent with constant
variance.
emlog specifies that the EM iteration log be shown. The EM iteration log is, by default, not
displayed unless the emonly option is specified.
emdots specifies that the EM iterations be shown as dots. This option can be convenient because
the EM algorithm may require many iterations to converge.

Maximization

maximize options: difficult, technique(algorithm spec), iterate(#), no log, trace,


gradient, showstep, hessian, showtolerance, tolerance(#), ltolerance(#),
nrtolerance(#), and nonrtolerance; see [R] maximize. Those that require special mention
for mixed are listed below.
For the technique() option, the default is technique(nr). The bhhh algorithm may not be
specified.
matsqrt (the default), during optimization, parameterizes variance components by using the matrix
square roots of the variancecovariance matrices formed by these components at each model level.

292

mixed Multilevel mixed-effects linear regression

matlog, during optimization, parameterizes variance components by using the matrix logarithms of
the variancecovariance matrices formed by these components at each model level.
The matsqrt parameterization ensures that variancecovariance matrices are positive semidefinite,
while matlog ensures matrices that are positive definite. For most problems, the matrix square root
is more stable near the boundary of the parameter space. However, if convergence is problematic,
one option may be to try the alternate matlog parameterization. When convergence is not an issue,
both parameterizations yield equivalent results.
The following option is available with mixed but is not shown in the dialog box:
coeflegend; see [R] estimation options.

Remarks and examples


Remarks are presented under the following headings:
Introduction
Two-level models
Covariance structures
Likelihood versus restricted likelihood
Three-level models
Blocked-diagonal covariance structures
Heteroskedastic random effects
Heteroskedastic residual errors
Other residual-error structures
Crossed-effects models
Diagnosing convergence problems
Survey data

Introduction
Linear mixed models are models containing both fixed effects and random effects. They are a
generalization of linear regression allowing for the inclusion of random deviations (effects) other than
those associated with the overall error term. In matrix notation,

y = X + Zu +

(1)

where y is the n 1 vector of responses, X is an n p design/covariate matrix for the fixed effects
, and Z is the n q design/covariate matrix for the random effects u. The n 1 vector of errors
is assumed to be multivariate normal with mean 0 and variance matrix 2 R.
The fixed portion of (1), X, is analogous to the linear predictor from a standard OLS regression
model with being the regression coefficients to be estimated. For the random portion of (1), Zu + ,
we assume that u has variancecovariance matrix G and that u is orthogonal to so that
Var

G
0
0 2 R

The random effects u are not directly estimated (although they may be predicted), but instead are
characterized by the elements of G, known as variance components, that are estimated along with
the overall residual variance 2 and the residual-variance parameters that are contained within R.

mixed Multilevel mixed-effects linear regression

293

The general forms of the design matrices X and Z allow estimation for a broad class of linear
models: blocked designs, split-plot designs, growth curves, multilevel or hierarchical designs, etc.
They also allow a flexible method of modeling within-cluster correlation. Subjects within the same
cluster can be correlated as a result of a shared random intercept, or through a shared random
slope on (say) age, or both. The general specification of G also provides additional flexibilitythe
random intercept and random slope could themselves be modeled as independent, or correlated, or
independent with equal variances, and so forth. The general structure of R also allows for residual
errors to be heteroskedastic and correlated, and allows flexibility in exactly how these characteristics
can be modeled.
Comprehensive treatments of mixed models are provided by, among others, Searle, Casella, and
McCulloch (1992); McCulloch, Searle, and Neuhaus (2008); Verbeke and Molenberghs (2000);
Raudenbush and Bryk (2002); Demidenko (2004); and Pinheiro and Bates (2000). In particular,
chapter 2 of Searle, Casella, and McCulloch (1992) provides an excellent history.
The key to fitting mixed models lies in estimating the variance components, and for that there exist
many methods. Most of the early literature in mixed models dealt with estimating variance components
in ANOVA models. For simple models with balanced data, estimating variance components amounts
to solving a system of equations obtained by setting expected mean-squares expressions equal to their
observed counterparts. Much of the work in extending the ANOVA method to unbalanced data for
general ANOVA designs is due to Henderson (1953).
The ANOVA method, however, has its shortcomings. Among these is a lack of uniqueness in that
alternative, unbiased estimates of variance components could be derived using other quadratic forms
of the data in place of observed mean squares (Searle, Casella, and McCulloch 1992, 3839). As a
result, ANOVA methods gave way to more modern methods, such as minimum norm quadratic unbiased
estimation (MINQUE) and minimum variance quadratic unbiased estimation (MIVQUE); see Rao (1973)
for MINQUE and LaMotte (1973) for MIVQUE. Both methods involve finding optimal quadratic forms
of the data that are unbiased for the variance components.
The most popular methods, however, are ML and REML, and these are the two methods that are
supported by mixed. The ML estimates are based on the usual application of likelihood theory, given
the distributional assumptions of the model. The basic idea behind REML (Thompson 1962) is that
you can form a set of linear contrasts of the response that do not depend on the fixed effects , but
instead depend only on the variance components to be estimated. You then apply ML methods by
using the distribution of the linear contrasts to form the likelihood.
Returning to (1): in clustered-data situations, it is convenient not to consider all n observations at
once but instead to organize the mixed model as a series of M independent groups (or clusters)

yj = Xj + Zj uj +

(2)

for j = 1, . . . , M , with cluster j consisting of nj observations. The response yj comprises the rows
of y corresponding with the j th cluster, with Xj and j defined analogously. The random effects uj
can now be thought of as M realizations of a q 1 vector that is normally distributed with mean 0
and q q variance matrix . The matrix Zi is the nj q design matrix for the j th cluster random
effects. Relating this to (1), note that

Z1 0 0

u1
0 Z2 0
... ; G = IM ; R = IM
Z=
(3)
..
..
..
...
; u =
.
.
.
uM
0
0
0 ZM
The mixed-model formulation (2) is from Laird and Ware (1982) and offers two key advantages.
First, it makes specifications of random-effects terms easier. If the clusters are schools, you can

294

mixed Multilevel mixed-effects linear regression

simply specify a random effect at the school level, as opposed to thinking of what a school-level
random effect would mean when all the data are considered as a whole (if it helps, think Kronecker
products). Second, representing a mixed-model with (2) generalizes easily to more than one set of
random effects. For example, if classes are nested within schools, then (2) can be generalized to allow
random effects at both the school and the class-within-school levels. This we demonstrate later.
In the sections that follow, we assume that residuals are independent with constant variance; that
is, in (3) we treat equal to the identity matrix and limit ourselves to estimating one overall residual
variance, 2 . Beginning in Heteroskedastic residual errors, we relax this assumption.

Two-level models
We begin with a simple application of (2) as a two-level model, because a one-level linear model,
by our terminology, is just standard OLS regression.

Example 1
Consider a longitudinal dataset, used by both Ruppert, Wand, and Carroll (2003) and Diggle
et al. (2002), consisting of weight measurements of 48 pigs on 9 successive weeks. Pigs are
identified by the variable id. Below is a plot of the growth curves for the first 10 pigs.

20

40

weight

60

80

. use http://www.stata-press.com/data/r13/pig
(Longitudinal analysis of pig weights)
. twoway connected weight week if id<=10, connect(L)

10

week

It seems clear that each pig experiences a linear trend in growth and that overall weight measurements
vary from pig to pig. Because we are not really interested in these particular 48 pigs per se, we
instead treat them as a random sample from a larger population and model the between-pig variability
as a random effect, or in the terminology of (2), as a random-intercept term at the pig level. We thus
wish to fit the model
weightij = 0 + 1 weekij + uj + ij
(4)
for i = 1, . . . , 9 weeks and j = 1, . . . , 48 pigs. The fixed portion of the model, 0 + 1 weekij ,
simply states that we want one overall regression line representing the population average. The random
effect uj serves to shift this regression line up or down according to each pig. Because the random
effects occur at the pig level (id), we fit the model by typing

mixed Multilevel mixed-effects linear regression

295

. mixed weight week || id:


Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
Iteration 1:

log likelihood = -1014.9268


log likelihood = -1014.9268

Computing standard errors:


Mixed-effects ML regression
Group variable: id

Number of obs
Number of groups

Coef.

week
_cons

6.209896
19.35561

432
48

Obs per group: min =


avg =
max =

9
9.0
9

Wald chi2(1)
Prob > chi2

Log likelihood = -1014.9268


weight

=
=

Std. Err.
.0390124
.5974059

Random-effects Parameters

z
159.18
32.40

=
=

25337.49
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.133433
18.18472

6.286359
20.52651

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

14.81751

3.124226

9.801716

22.40002

var(Residual)

4.383264

.3163348

3.805112

5.04926

id: Identity

LR test vs. linear regression: chibar2(01) =

472.65 Prob >= chibar2 = 0.0000

Notes:
1. By typing weight week, we specified the response, weight, and the fixed portion of the model
in the same way that we would if we were using regress or any other estimation command. Our
fixed effects are a coefficient on week and a constant term.
2. When we added || id:, we specified random effects at the level identified by the group variable
id, that is, the pig level (level two). Because we wanted only a random intercept, that is all we
had to type.
3. The estimation log consists of three parts:
a. A set of EM iterations used to refine starting values. By default, the iterations themselves are
not displayed, but you can display them with the emlog option.
b. A set of gradient-based iterations. By default, these are NewtonRaphson iterations, but other
methods are available by specifying the appropriate maximize options; see [R] maximize.
c. The message Computing standard errors. This is just to inform you that mixed has finished
its iterative maximization and is now reparameterizing from a matrix-based parameterization
(see Methods and formulas) to the natural metric of variance components and their estimated
standard errors.
4. The output title, Mixed-effects ML regression, informs us that our model was fit using ML, the
default. For REML estimates, use the reml option.
Because this model is a simple random-intercept model fit by ML, it would be equivalent to using
xtreg with its mle option.
5. The first estimation table reports the fixed effects. We estimate 0 = 19.36 and 1 = 6.21.

296

mixed Multilevel mixed-effects linear regression

6. The second estimation table shows the estimated variance components. The first section of the
table is labeled id: Identity, meaning that these are random effects at the id (pig) level and that
their variancecovariance matrix is a multiple of the identity matrix; that is, = u2 I. Because
we have only one random effect at this level, mixed knew that Identity is the only possible
covariance structure. In any case, the variance of the level-two errors, u2 , is estimated as 14.82
with standard error 3.12.
7. The row labeled var(Residual) displays the estimated variance of the overall error term; that
is, 2 = 4.38. This is the variance of the level-one errors, that is, the residuals.
8. Finally, a likelihood-ratio test comparing the model with one-level ordinary linear regression, model
(4) without uj , is provided and is highly significant for these data.
We now store our estimates for later use:
. estimates store randint

Example 2
Extending (4) to allow for a random slope on week yields the model

weightij = 0 + 1 weekij + u0j + u1j weekij +

(5)

ij

and we fit this with mixed:


. mixed weight week || id: week
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
Iteration 1:

log likelihood = -869.03825


log likelihood = -869.03825

Computing standard errors:


Mixed-effects ML regression
Group variable: id

Number of obs
Number of groups

Coef.

week
_cons

6.209896
19.35561

432
48

Obs per group: min =


avg =
max =

9
9.0
9

Wald chi2(1)
Prob > chi2

Log likelihood = -869.03825


weight

=
=

Std. Err.
.0906819
.3979159

Random-effects Parameters

z
68.48
48.64

=
=

4689.51
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.032163
18.57571

6.387629
20.13551

Estimate

Std. Err.

[95% Conf. Interval]

var(week)
var(_cons)

.3680668
6.756364

.0801181
1.543503

.2402389
4.317721

.5639103
10.57235

var(Residual)

1.598811

.1233988

1.374358

1.85992

id: Independent

LR test vs. linear regression:

chi2(2) =

764.42

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.


. estimates store randslope

mixed Multilevel mixed-effects linear regression

297

Because we did not specify a covariance structure for the random effects (u0j , u1j ) , mixed used
the default Independent structure; that is,
= Var

u0j
u1j

2
u0
0

0
2
u1

(6)

2
2
with u0
= 6.76 and u1
= 0.37. Our point estimates of the fixed effects are essentially identical to
those from model (4), but note that this does not hold generally. Given the 95% confidence interval
2
for u1
, it would seem that the random slope is significant, and we can use lrtest and our two
stored estimation results to verify this fact:

. lrtest randslope randint


Likelihood-ratio test
(Assumption: randint nested in randslope)

LR chi2(1) =
Prob > chi2 =

291.78
0.0000

Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

The near-zero significance level favors the model that allows for a random pig-specific regression
line over the model that allows only for a pig-specific shift.

Covariance structures
In example 2, we fit a model with the default Independent covariance given in (6). Within any
random-effects level specification, we can override this default by specifying an alternative covariance
structure via the covariance() option.

Example 3
We generalize (6) to allow u0j and u1j to be correlated; that is,
= Var

u0j
u1j

2
u0
01

01
2
u1

298

mixed Multilevel mixed-effects linear regression


. mixed weight week || id: week, covariance(unstructured)
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log likelihood = -868.96185
Iteration 1:
log likelihood = -868.96185
Computing standard errors:
Mixed-effects ML regression
Number of obs
Group variable: id
Number of groups
Obs per group: min
avg
max
Wald chi2(1)
Prob > chi2

Log likelihood = -868.96185


weight

Coef.

week
_cons

6.209896
19.35561

Std. Err.
.0910745
.3996387

Random-effects Parameters

z
68.18
48.43

=
=
=
=
=

432
48
9
9.0
9

=
=

4649.17
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.031393
18.57234

6.388399
20.13889

Estimate

Std. Err.

[95% Conf. Interval]

var(week)
var(_cons)
cov(week,_cons)

.3715251
6.823363
-.0984378

.0812958
1.566194
.2545767

.2419532
4.351297
-.5973991

.570486
10.69986
.4005234

var(Residual)

1.596829

.123198

1.372735

1.857505

id: Unstructured

LR test vs. linear regression:


chi2(3) =
764.58
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

But we do not find the correlation to be at all significant.


. lrtest . randslope
Likelihood-ratio test
(Assumption: randslope nested in .)

LR chi2(1) =
Prob > chi2 =

0.15
0.6959

Instead, we could have also specified covariance(identity), restricting u0j and u1j to not
only be independent but also to have common variance, or we could have specified covariance(exchangeable), which imposes a common variance but allows for a nonzero correlation.

Likelihood versus restricted likelihood


Thus far, all our examples have used ML to estimate variance components. We could have just as
easily asked for REML estimates. Refitting the model in example 2 by REML, we get

mixed Multilevel mixed-effects linear regression


. mixed weight week || id: week, reml
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log restricted-likelihood = -870.51473
Iteration 1:
log restricted-likelihood = -870.51473
Computing standard errors:
Mixed-effects REML regression
Number of obs
Group variable: id
Number of groups
Obs per group: min
avg
max
Wald chi2(1)
Prob > chi2

Log restricted-likelihood = -870.51473


weight

Coef.

week
_cons

6.209896
19.35561

Std. Err.
.0916387
.4021144

Random-effects Parameters

z
67.77
48.13

=
=
=
=
=

432
48
9
9.0
9

=
=

4592.10
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.030287
18.56748

299

6.389504
20.14374

Estimate

Std. Err.

[95% Conf. Interval]

var(week)
var(_cons)

.3764405
6.917604

.0827027
1.593247

.2447317
4.404624

.5790317
10.86432

var(Residual)

1.598784

.1234011

1.374328

1.859898

id: Independent

LR test vs. linear regression:


chi2(2) =
765.92
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Although ML estimators are based on the usual likelihood theory, the idea behind REML is to
transform the response into a set of linear contrasts whose distribution is free of the fixed effects .
The restricted likelihood is then formed by considering the distribution of the linear contrasts. Not
only does this make the maximization problem free of , it also incorporates the degrees of freedom
used to estimate into the estimation of the variance components. This follows because, by necessity,
the rank of the linear contrasts must be less than the number of observations.
As a simple example, consider a constant-only regression where yi N (, 2 ) for i = 1, . . . , n.
The ML estimate of 2 can be derived theoretically as the n-divided sample variance. The REML
estimate can be derived by considering the first n 1 error contrasts, yi y , whose joint distribution
is free of . Applying maximum likelihood to this distribution results in an estimate of 2 , that is,
the (n 1)-divided sample variance, which is unbiased for 2 .
The unbiasedness property of REML extends to all mixed models when the data are balanced, and
thus REML would seem the clear choice in balanced-data problems, although in large samples the
difference between ML and REML is negligible. One disadvantage of REML is that likelihood-ratio (LR)
tests based on REML are inappropriate for comparing models with different fixed-effects specifications.
ML is appropriate for such LR tests and has the advantage of being easy to explain and being the
method of choice for other estimators.
Another factor to consider is that ML estimation under mixed is more feature-rich, allowing for
weighted estimation and robust variancecovariance matrices, features not supported under REML. In
the end, which method to use should be based both on your needs and on personal taste.

300

mixed Multilevel mixed-effects linear regression

Examining the REML output, we find that the estimates of the variance components are slightly
larger than the ML estimates. This is typical, because ML estimates, which do not incorporate the
degrees of freedom used to estimate the fixed effects, tend to be biased downward.

Three-level models
The clustered-data representation of the mixed model given in (2) can be extended to two nested
levels of clustering, creating a three-level model once the observations are considered. Formally,
(3) (3)

(2) (2)

yjk = Xjk + Zjk uk + Zjk ujk +

jk

(7)

for i = 1, . . . , njk first-level observations nested within j = 1, . . . , Mk second-level groups, which


are nested within k = 1, . . . , M third-level groups. Group j, k consists of njk observations, so yjk ,
(3)
Xjk , and jk each have row dimension njk . Zjk is the njk q3 design matrix for the third-level
(3)

(2)

(2)

random effects uk , and Zjk is the njk q2 design matrix for the second-level random effects ujk .
Furthermore, assume that
(3)

uk N (0, 3 );
(3)

(2)

and that uk , ujk , and

jk

(2)

ujk N (0, 2 );

jk

N (0, 2 I)

are independent.

Fitting a three-level model requires you to specify two random-effects equations: one for level
(3)
three and then one for level two. The variable list for the first equation represents Zjk and for the
(2)

second equation represents Zjk ; that is, you specify the levels top to bottom in mixed.

Example 4
Baltagi, Song, and Jung (2001) estimate a CobbDouglas production function examining the
productivity of public capital in each states private output. Originally provided by Munnell (1990),
the data were recorded over 19701986 for 48 states grouped into nine regions.

mixed Multilevel mixed-effects linear regression

301

. use http://www.stata-press.com/data/r13/productivity
(Public Capital Productivity)
. describe
Contains data from http://www.stata-press.com/data/r13/productivity.dta
obs:
816
Public Capital Productivity
vars:
11
29 Mar 2013 10:57
size:
29,376
(_dta has notes)

variable name

storage
type

display
format

state
region
year
public
hwy
water
other

byte
byte
int
float
float
float
float

%9.0g
%9.0g
%9.0g
%9.0g
%9.0g
%9.0g
%9.0g

private
gsp
emp
unemp

float
float
float
float

%9.0g
%9.0g
%9.0g
%9.0g

value
label

variable label
states 1-48
regions 1-9
years 1970-1986
public capital stock
log(highway component of public)
log(water component of public)
log(bldg/other component of
public)
log(private capital stock)
log(gross state product)
log(non-agriculture payrolls)
state unemployment rate

Sorted by:

Because the states are nested within regions, we fit a three-level mixed model with random intercepts
(3)
(2)
at both the region and the state-within-region levels. That is, we use (7) with both Zjk and Zjk set
to the njk 1 column of ones, and 3 = 32 and 2 = 22 are both scalars.
. mixed gsp private emp hwy water other unemp || region: || state:
(output omitted )
Mixed-effects ML regression
Number of obs
=

Group Variable

No. of
Groups

region
state

9
48

Log likelihood =

Observations per Group


Minimum
Average
Maximum
51
17

90.7
17.0

Coef.

private
emp
hwy
water
other
unemp
_cons

.2671484
.754072
.0709767
.0761187
-.0999955
-.0058983
2.128823

136
17

Wald chi2(6)
Prob > chi2

1430.5017

gsp

816

Std. Err.
.0212591
.0261868
.023041
.0139248
.0169366
.0009031
.1543854

z
12.57
28.80
3.08
5.47
-5.90
-6.53
13.79

P>|z|
0.000
0.000
0.002
0.000
0.000
0.000
0.000

=
=

18829.06
0.0000

[95% Conf. Interval]


.2254814
.7027468
.0258172
.0488266
-.1331906
-.0076684
1.826233

.3088154
.8053973
.1161363
.1034109
-.0668004
-.0041282
2.431413

302

mixed Multilevel mixed-effects linear regression

Random-effects Parameters

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

.0014506

.0012995

.0002506

.0083957

var(_cons)

.0062757

.0014871

.0039442

.0099855

var(Residual)

.0013461

.0000689

.0012176

.0014882

region: Identity

state: Identity

LR test vs. linear regression:


chi2(2) = 1154.73
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Notes:
1. Our model now has two random-effects equations, separated by ||. The first is a random intercept
(constant only) at the region level (level three), and the second is a random intercept at the state
level (level two). The order in which these are specified (from left to right) is significantmixed
assumes that state is nested within region.
2. The information on groups is now displayed as a table, with one row for each grouping. You can
suppress this table with the nogroup or the noheader option, which will suppress the rest of the
header, as well.
3. The variance-component estimates are now organized and labeled according to level.
After adjusting for the nested-level error structure, we find that the highway and water components
of public capital had significant positive effects on private output, whereas the other public buildings
component had a negative effect.

Technical note
In the previous example, the states are coded 148 and are nested within nine regions. mixed
treated the states as nested within regions, regardless of whether the codes for each state were unique
between regions. That is, even if codes for states were duplicated between regions, mixed would
have enforced the nesting and produced the same results.
The group information at the top of the mixed output and that produced by the postestimation
command estat group (see [ME] mixed postestimation) take the nesting into account. The statistics
are thus not necessarily what you would get if you instead tabulated each group variable individually.

Model (7) extends in a straightforward manner to more than three levels, as does the specification
of such models in mixed.

Blocked-diagonal covariance structures


Covariance matrices of random effects within an equation can be modeled either as a multiple of
the identity matrix, as diagonal (that is, Independent), as exchangeable, or as general symmetric
(Unstructured). These may also be combined to produce more complex block-diagonal covariance
structures, effectively placing constraints on the variance components.

mixed Multilevel mixed-effects linear regression

303

Example 5
Returning to our productivity data, we now add random coefficients on hwy and unemp at the
region level. This only slightly changes the estimates of the fixed effects, so we focus our attention
on the variance components:
. mixed gsp private emp hwy water other unemp || region: hwy unemp || state:,
> nolog nogroup nofetable
Mixed-effects ML regression
Log likelihood =

Number of obs
Wald chi2(6)
Prob > chi2

1447.6787

Random-effects Parameters

=
=
=

816
17137.94
0.0000

Estimate

Std. Err.

[95% Conf. Interval]

var(hwy)
var(unemp)
var(_cons)

.0000209
.0000238
.0030349

.0001103
.0000135
.0086684

6.71e-10
7.84e-06
.0000112

.650695
.0000722
.8191296

var(_cons)

.0063658

.0015611

.0039365

.0102943

var(Residual)

.0012469

.0000643

.001127

.0013795

region: Independent

state: Identity

LR test vs. linear regression:

chi2(4) =

1189.08

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.


. estimates store prodrc
(3)

This model is the same as that fit in example 4 except that Zjk is now the njk 3 matrix with
columns determined by the values of hwy, unemp, and an intercept term (one), in that order, and
(because we used the default Independent structure) 3 is

3 =

hwy unemp
0
a2
0
b2
0
0

cons
0
0
c2

The random-effects specification at the state level remains unchanged; that is, 2 is still treated as
the scalar variance of the random intercepts at the state level.
An LR test comparing this model with that from example 4 favors the inclusion of the two random
coefficients, a fact we leave to the interested reader to verify.
The estimated variance components, upon examination, reveal that the variances of the random
coefficients on hwy and unemp could be treated as equal. That is,

3 =

hwy unemp
a2
0
0
a2
0
0

cons
0
0
c2

looks plausible. We can impose this equality constraint by treating 3 as block diagonal: the first
block is a 2 2 multiple of the identity matrix, that is, a2 I2 ; the second is a scalar, equivalently, a
1 1 multiple of the identity.

304

mixed Multilevel mixed-effects linear regression

We construct block-diagonal covariances by repeating level specifications:


. mixed gsp private emp hwy water other unemp || region: hwy unemp,
> cov(identity) || region: || state:, nolog nogroup nofetable
Mixed-effects ML regression
Number of obs
=
Wald chi2(6)
=
Log likelihood = 1447.6784
Prob > chi2
=

816
17136.65
0.0000

Random-effects Parameters

Estimate

Std. Err.

[95% Conf. Interval]

region: Identity
var(hwy unemp)

.0000238

.0000134

7.89e-06

.0000719

var(_cons)

.0028191

.0030429

.0003399

.023383

var(_cons)

.006358

.0015309

.0039661

.0101925

var(Residual)

.0012469

.0000643

.001127

.0013795

region: Identity

state: Identity

LR test vs. linear regression:


chi2(3) = 1189.08
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

We specified two equations for the region level: the first for the random coefficients on hwy and
unemp with covariance set to Identity and the second for the random intercept cons, whose
covariance defaults to Identity because it is of dimension 1. mixed labeled the estimate of a2 as
var(hwy unemp) to designate that it is common to the random coefficients on both hwy and unemp.
An LR test shows that the constrained model fits equally well.
. lrtest . prodrc
Likelihood-ratio test
LR chi2(1) =
0.00
(Assumption: . nested in prodrc)
Prob > chi2 =
0.9784
Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

Because the null hypothesis for this test is one of equality (H0 : a2 = b2 ), it is not on the
boundary of the parameter space. As such, we can take the reported significance as precise rather
than a conservative estimate.
You can repeat level specifications as often as you like, defining successive blocks of a blockdiagonal covariance matrix. However, repeated-level equations must be listed consecutively; otherwise,
mixed will give an error.

Technical note
In the previous estimation output, there was no constant term included in the first region equation,
even though we did not use the noconstant option. When you specify repeated-level equations,
mixed knows not to put constant terms in each equation because such a model would be unidentified.
By default, it places the constant in the last repeated-level equation, but you can use noconstant
creatively to override this.
Linear mixed-effects models can also be fit using meglm with the default gaussian family. meglm
provides two more covariance structures through which you can impose constraints on variance
components; see [ME] meglm for details.

mixed Multilevel mixed-effects linear regression

305

Heteroskedastic random effects


Blocked-diagonal covariance structures and repeated-level specifications of random effects can also
be used to model heteroskedasticity among random effects at a given level.

Example 6
Following Rabe-Hesketh and Skrondal (2012, sec. 7.2), we analyze data from Asian children in
a British community who were weighed up to four times, roughly between the ages of 6 weeks and
27 months. The dataset is a random sample of data previously analyzed by Goldstein (1986) and
Prosser, Rasbash, and Goldstein (1991).
. use http://www.stata-press.com/data/r13/childweight
(Weight data on Asian children)
. describe
Contains data from http://www.stata-press.com/data/r13/childweight.dta
obs:
198
Weight data on Asian children
vars:
5
23 May 2013 15:12
size:
3,168
(_dta has notes)

variable name
id
age
weight
brthwt
girl
Sorted by:

storage
type
int
float
float
int
float

id

display
format
%8.0g
%8.0g
%8.0g
%8.0g
%9.0g

value
label

variable label

bg

child identifier
age in years
weight in Kg
Birth weight in g
gender

age

. graph twoway (line weight age, connect(ascending)), by(girl)


> xtitle(Age in years) ytitle(Weight in kg)
girl

10
5

Weight in kg

15

20

boy

Age in years
Graphs by gender

Ignoring gender effects for the moment, we begin with the following model for the ith measurement
on the j th child:

weightij = 0 + 1 ageij + 2 age2ij + uj0 + uj1 ageij +

ij

306

mixed Multilevel mixed-effects linear regression

This models overall mean growth as quadratic in age and allows for two child-specific random
effects: a random intercept uj0 , which represents each childs vertical shift from the overall mean
(0 ), and a random age slope uj1 , which represents each childs deviation in linear growth rate from
the overall mean linear growth rate (1 ). For simplicity, we do not consider child-specific changes in
the quadratic component of growth.
. mixed weight age c.age#c.age || id: age, nolog
Mixed-effects ML regression
Number of obs
Group variable: id
Number of groups
Obs per group: min
avg
max
Wald chi2(2)
Prob > chi2

Log likelihood = -258.51915


weight

Coef.

Std. Err.

age

7.693701

.2381076

c.age#c.age

-1.654542

_cons

3.497628

198
68
1
2.9
5

=
=

1863.46
0.0000

P>|z|

[95% Conf. Interval]

32.31

0.000

7.227019

8.160384

.0874987

-18.91

0.000

-1.826037

-1.483048

.1416914

24.68

0.000

3.219918

3.775338

Random-effects Parameters

=
=
=
=
=

Estimate

Std. Err.

[95% Conf. Interval]

var(age)
var(_cons)

.2987207
.5023857

.0827569
.141263

.1735603
.2895294

.5141388
.8717297

var(Residual)

.3092897

.0474887

.2289133

.417888

id: Independent

LR test vs. linear regression:


chi2(2) =
114.70
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Because there is no reason to believe that the random effects are uncorrelated, it is always a good
idea to first fit a model with the covariance(unstructured) option. We do not include the output
for such a model because for these data the correlation between random effects is not significant;
however, we did check this before reverting to mixeds default Independent structure.
Next we introduce gender effects into the fixed portion of the model by including a main gender
effect and a genderage interaction for overall mean growth:

mixed Multilevel mixed-effects linear regression


. mixed weight i.girl i.girl#c.age c.age#c.age || id: age, nolog
Mixed-effects ML regression
Number of obs
Group variable: id
Number of groups
Obs per group: min
avg
max
Log likelihood =

Wald chi2(4)
Prob > chi2

-253.182
Std. Err.

P>|z|

198
68
1
2.9
5

=
=

1942.30
0.0000

weight

Coef.

girl
girl

-.5104676

.2145529

-2.38

0.017

-.9309835

-.0899516

girl#c.age
boy
girl

7.806765
7.577296

.2524583
.2531318

30.92
29.93

0.000
0.000

7.311956
7.081166

8.301574
8.073425

c.age#c.age

-1.654323

.0871752

-18.98

0.000

-1.825183

-1.483463

_cons

3.754275

.1726404

21.75

0.000

3.415906

4.092644

Random-effects Parameters

=
=
=
=
=

307

[95% Conf. Interval]

Estimate

Std. Err.

[95% Conf. Interval]

var(age)
var(_cons)

.2772846
.4076892

.0769233
.12386

.1609861
.2247635

.4775987
.7394906

var(Residual)

.3131704

.047684

.2323672

.422072

id: Independent

LR test vs. linear regression:


chi2(2) =
104.39
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.
. estimates store homoskedastic

The main gender effect is significant at the 5% level, but the genderage interaction is not:
. test 0.girl#c.age = 1.girl#c.age
( 1) [weight]0b.girl#c.age - [weight]1.girl#c.age = 0
chi2( 1) =
1.66
Prob > chi2 =
0.1978

On average, boys are heavier than girls, but their average linear growth rates are not significantly
different.
In the above model, we introduced a gender effect on average growth, but we still assumed that the
variability in child-specific deviations from this average was the same for boys and girls. To check
this assumption, we introduce gender into the random component of the model. Because support
for factor-variable notation is limited in specifications of random effects (see Crossed-effects models
below), we need to generate the interactions ourselves.

308

mixed Multilevel mixed-effects linear regression


. gen boy = !girl
. gen boyXage = boy*age
. gen girlXage = girl*age
. mixed weight i.girl i.girl#c.age c.age#c.age || id: boy boyXage, noconstant
> || id: girl girlXage, noconstant nolog nofetable
Mixed-effects ML regression
Group variable: id

Number of obs
Number of groups

198
68

Obs per group: min =


avg =
max =

1
2.9
5

Wald chi2(4)
Prob > chi2

Log likelihood = -248.94752


Random-effects Parameters

=
=

=
=

2358.11
0.0000

Estimate

Std. Err.

[95% Conf. Interval]

var(boy)
var(boyXage)

.3161091
.4734482

.1557911
.1574626

.1203181
.2467028

.8305061
.9085962

var(girl)
var(girlXage)

.5798676
.0664634

.1959725
.0553274

.2989896
.0130017

1.124609
.3397538

var(Residual)

.3078826

.046484

.2290188

.4139037

id: Independent

id: Independent

LR test vs. linear regression:

chi2(4) =

112.86

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.


. estimates store heteroskedastic

In the above, we suppress displaying the fixed portion of the model (the nofetable option)
because it does not differ much from that of the previous model.
Our previous model had the random-effects specification
|| id: age

which we have replaced with the dual repeated-level specification


|| id: boy boyXage, noconstant || id: girl girlXage, noconstant

The former models a random intercept and random slope on age, and does so treating all children as
a random sample from one population. The latter also specifies a random intercept and random slope
on age, but allows for the variability of the random intercepts and slopes to differ between boys and
girls. In other words, it allows for heteroskedasticity in random effects due to gender. We use the
noconstant option so that we can separate the overall random intercept (automatically provided by
the former syntax) into one specific to boys and one specific to girls.
There seems to be a large gender effect in the variability of linear growth rates. We can compare
both models with an LR test, recalling that we stored the previous estimation results under the name
homoskedastic:
. lrtest homoskedastic heteroskedastic
Likelihood-ratio test
LR chi2(2) =
8.47
(Assumption: homoskedastic nested in heteroskedas~c) Prob > chi2 =
0.0145
Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

mixed Multilevel mixed-effects linear regression

309

Because the null hypothesis here is one of equality of variances and not that variances are 0, the
above does not test on the boundary; thus we can treat the significance level as precise and not
conservative. Either way, the results favor the new model with heteroskedastic random effects.

Heteroskedastic residual errors


Up to this point, we have assumed that the level-one residual errorsthe s in the stated
modelshave been i.i.d. Gaussian with variance 2 . This is demonstrated in mixed output in the
random-effects table, where up until now we have estimated a single residual-error variance, labeled
as var(Residual).
To relax the assumptions of homoskedasticity or independence of residual errors, use the residuals() option.

Example 7
West, Welch, and Galecki (2007, chap. 7) analyze data studying the effect of ceramic dental veneer
placement on gingival (gum) health. Data on 55 teeth located in the maxillary arches of 12 patients
were considered.
. use http://www.stata-press.com/data/r13/veneer, clear
(Dental veneer data)
. describe
Contains data from http://www.stata-press.com/data/r13/veneer.dta
obs:
110
Dental veneer data
vars:
7
24 May 2013 12:11
size:
1,100
(_dta has notes)

variable name

storage
type

display
format

patient
tooth
gcf
age
base_gcf
cda

byte
byte
byte
byte
byte
float

%8.0g
%8.0g
%8.0g
%8.0g
%8.0g
%9.0g

followup

byte

%9.0g

value
label

variable label

Patient ID
Tooth number with patient
Gingival crevicular fluid (GCF)
Patient age
Baseline GCF
Average contour difference after
veneer placement
Follow-up time: 3 or 6 months

Sorted by:

Veneers were placed to match the original contour of the tooth as closely as possible, and researchers
were interested in how contour differences (variable cda) impacted gingival health. Gingival health
was measured as the amount of gingival crevical fluid (GCF) at each tooth, measured at baseline
(variable base gcf) and at two posttreatment follow-ups at 3 and 6 months. The variable gcf records
GCF at follow-up, and the variable followup records the follow-up time.
Because two measurements were taken for each tooth and there exist multiple teeth per patient, we
fit a three-level model with the following random effects: a random intercept and random slope on
follow-up time at the patient level, and a random intercept at the tooth level. For the ith measurement
of the j th tooth from the k th patient, we have

gcfijk = 0 + 1 followupijk + 2 base gcfijk + 3 cdaijk + 4 ageijk +


u0k + u1k followupijk + v0jk +

ijk

310

mixed Multilevel mixed-effects linear regression

which we can fit using mixed:


. mixed gcf followup base_gcf cda age || patient: followup, cov(un) || tooth:,
> reml nolog
Mixed-effects REML regression
Number of obs
=
110

Group Variable

No. of
Groups

patient
tooth

12
55

Observations per Group


Minimum
Average
Maximum
2
2

9.2
2.0

Wald chi2(4)
Prob > chi2

Log restricted-likelihood = -420.92761


gcf

Coef.

followup
base_gcf
cda
age
_cons

.3009815
-.0183127
-.329303
-.5773932
45.73862

Std. Err.
1.936863
.1433094
.5292525
.2139656
12.55497

12
2

z
0.16
-0.13
-0.62
-2.70
3.64

P>|z|
0.877
0.898
0.534
0.007
0.000

=
=

7.48
0.1128

[95% Conf. Interval]


-3.4952
-.299194
-1.366619
-.9967582
21.13133

4.097163
.2625685
.7080128
-.1580283
70.34591

Random-effects Parameters

Estimate

Std. Err.

[95% Conf. Interval]

patient: Unstructured
var(followup)
var(_cons)
cov(followup,_cons)

41.88772
524.9851
-140.4229

18.79997
253.0205
66.57623

17.38009
204.1287
-270.9099

100.9535
1350.175
-9.935908

var(_cons)

47.45738

16.63034

23.8792

94.3165

var(Residual)

48.86704

10.50523

32.06479

74.47382

tooth: Identity

LR test vs. linear regression:

chi2(4) =

91.12

Prob > chi2 = 0.0000

Note: LR test is conservative and provided only for reference.

We used REML estimation for no other reason than variety.


Among the other features of the model fit, we note that the residual variance 2 was estimated
as 48.87 and that our model assumed that the residuals were independent with constant variance
(homoskedastic). Because it may be the case that the precision of gcf measurements could change
over time, we modify the above to estimate two distinct error variances: one for the 3-month follow-up
and one for the 6-month follow-up.
To fit this model, we add the residuals(independent, by(followup)) option, which maintains
independence of residual errors but allows for heteroskedasticity with respect to follow-up time.

mixed Multilevel mixed-effects linear regression

311

. mixed gcf followup base_gcf cda age || patient: followup, cov(un) || tooth:,
> residuals(independent, by(followup)) reml nolog
Mixed-effects REML regression
Number of obs
=
110

Group Variable

No. of
Groups

patient
tooth

12
55

Observations per Group


Minimum
Average
Maximum
2
2

Log restricted-likelihood =
gcf

Coef.

followup
base_gcf
cda
age
_cons

.2703944
.0062144
-.2947235
-.5743755
45.15089

9.2
2.0

Wald chi2(4)
Prob > chi2

-420.4576
Std. Err.
1.933096
.1419121
.5245126
.2142249
12.51452

12
2

z
0.14
0.04
-0.56
-2.68
3.61

P>|z|
0.889
0.965
0.574
0.007
0.000

=
=

7.51
0.1113

[95% Conf. Interval]


-3.518405
-.2719283
-1.322749
-.9942487
20.62288

4.059193
.284357
.7333023
-.1545024
69.6789

Random-effects Parameters

Estimate

Std. Err.

[95% Conf. Interval]

patient: Unstructured
var(followup)
var(_cons)
cov(followup,_cons)

41.75169
515.2018
-139.0496

18.72989
251.9661
66.27806

17.33099
197.5542
-268.9522

100.583
1343.596
-9.14694

var(_cons)

47.35914

16.48931

23.93514

93.70693

Residual: Independent,
by followup
3 months: var(e)
6 months: var(e)

61.36785
36.42861

18.38913
14.97501

34.10946
16.27542

110.4096
81.53666

tooth: Identity

LR test vs. linear regression:


chi2(5) =
92.06
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Comparison of both models via an LR test reveals the difference in residual variances to be not
significant, something we leave to you to verify as an exercise.

The default residual-variance structure is independent, and when specified without by() is
equivalent to the default behavior of mixed: estimating one overall residual standard variance for the
entire model.

Other residual-error structures


Besides the default independent residual-error structure, mixed supports four other structures that
allow for correlation between residual errors within the lowest-level (smallest or level two) groups.
For purposes of notation, in what follows we assume a two-level model, with the obvious extension
to higher-level models.
The exchangeable structure assumes one overall variance and one common pairwise covariance;
that is,

312

mixed Multilevel mixed-effects linear regression

j1

j2 1

Var( j ) = Var
.. = ..
.
.

1
jnj

1
2
..
.
1

1
1
..
..

.
.
2
1

By default, mixed will report estimates of the two parameters as estimates of the common variance
2 and of the covariance 1 . If the stddeviations option is specified, you obtain estimates of
and the pairwise correlation. When the by(varname) option is also specified, these two parameters
are estimated for each level varname.
The ar p structure assumes that the errors have an AR structure of order p. That is,
ij

= 1

i1,j

+ + p

ip,j

+ uij

where uij are i.i.d. Gaussian with mean 0 and variance u2 . mixed reports estimates of 1 , . . . , p
and the overall error variance 2 , which can be derived from the above expression. The t(varname)
option is required, where varname is a time variable used to order the observations within lowest-level
groups and to determine any gaps between observations. When the by(varname) option is also
specified, the set of p + 1 parameters is estimated for each level of varname. If p = 1, then the
estimate of 1 is reported as rho, because in this case it represents the correlation between successive
error terms.
The ma q structure assumes that the errors are an MA process of order q . That is,
ij

= uij + 1 ui1,j + + q uiq,j

where uij are i.i.d. Gaussian with mean 0 and variance u2 . mixed reports estimates of 1 , . . . , q
and the overall error variance 2 , which can be derived from the above expression. The t(varname)
option is required, where varname is a time variable used to order the observations within lowest-level
groups and to determine any gaps between observations. When the by(varname) option is also
specified, the set of q + 1 parameters is estimated for each level of varname.
The unstructured structure is the most general and estimates unique variances and unique pairwise
covariances for all residuals within the lowest-level grouping. Because the data may be unbalanced
and the ordering of the observations is arbitrary, the t(varname) option is required, where varname
is an identification variable that matches error terms in different groups. If varname has n distinct
levels, then n(n + 1)/2 parameters are estimated. Not all n levels need to be observed within each
group, but duplicated levels of varname within a given group are not allowed because they would
cause a singularity in the estimated error-variance matrix for that group. When the by(varname)
option is also specified, the set of n(n + 1)/2 parameters is estimated for each level of varname.
The banded q structure is a special case of unstructured that confines estimation to within
the first q off-diagonal elements of the residual variancecovariance matrix and sets the covariances
outside this band to 0. As is the case with unstructured, the t(varname) option is required, where
varname is an identification variable that matches error terms in different groups. However, with
banded variance structures, the ordering of the values in varname is significant because it determines
which covariances are to be estimated and which are to be set to 0. For example, if varname has
n = 5 distinct values t = 1, 2, 3, 4, 5, then a banded variancecovariance structure of order q = 2
would estimate the following:

mixed Multilevel mixed-effects linear regression

Var( j ) = Var

12

2j
12
=
13

3j

0
4j
0
5j
1j

12
22
23
24
0

13
23
32
34
35

0
24
34
42
45

313

0
0

35

45
2
5

In other words, you would have an unstructured variance matrix that constrains 14 = 15 = 25 = 0.
If varname has n distinct levels, then (q + 1)(2n q)/2 parameters are estimated. Not all n levels
need to be observed within each group, but duplicated levels of varname within a given group are
not allowed because they would cause a singularity in the estimated error-variance matrix for that
group. When the by(varname) option is also specified, the set of parameters is estimated for each
level of varname. If q is left unspecified, then banded is equivalent to unstructured; that is, all
variances and covariances are estimated. When q = 0, Var( j ) is treated as diagonal and can thus be
used to model uncorrelated yet heteroskedastic residual errors.
The toeplitz q structure assumes that the residual errors are homoskedastic and that the correlation
between two errors is determined by the time lag between the two. That is, Var( ij ) = 2 and
Corr(

ij , i+k,j )

= k

If the lag k is less than or equal to q , then the pairwise correlation k is estimated; if the lag is greater
than q , then k is assumed to be 0. If q is left unspecified, then k is estimated for each observed lag
k . The t(varname) option is required, where varname is a time variable t used to determine the lags
between pairs of residual errors. As such, t() must be integer-valued. q + 1 parameters are estimated:
one overall variance 2 and q correlations. When the by(varname) option is also specified, the set
of q + 1 parameters is estimated for each level of varname.
The exponential structure is a generalization of the AR structure that allows for noninteger and
irregularly spaced time lags. That is, Var( ij ) = 2 and
Corr(

ij , kj )

= |ik|

for 0 1, with i and k not required to be integers. The t(varname) option is required, where
varname is a time variable used to determine i and k for each residual-error pair. t() is real-valued.
mixed reports estimates of 2 and . When the by(varname) option is also specified, these two
parameters are estimated for each level of varname.

Example 8
Pinheiro and Bates (2000, chap. 5) analyze data from a study of the estrus cycles of mares.
Originally analyzed in Pierson and Ginther (1987), the data record the number of ovarian follicles
larger than 10mm, daily over a period ranging from three days before ovulation to three days after
the subsequent ovulation.

314

mixed Multilevel mixed-effects linear regression


. use http://www.stata-press.com/data/r13/ovary
(Ovarian follicles in mares)
. describe
Contains data from http://www.stata-press.com/data/r13/ovary.dta
obs:
308
Ovarian follicles in mares
vars:
6
20 May 2013 13:49
size:
5,544
(_dta has notes)

variable name

storage
type

display
format

mare
stime
follicles

byte
float
byte

%9.0g
%9.0g
%9.0g

sin1
cos1
time

float
float
float

%9.0g
%9.0g
%9.0g

Sorted by:

mare

value
label

variable label
mare ID
Scaled time
Number of ovarian follicles > 10
mm in diameter
sine(2*pi*stime)
cosine(2*pi*stime)
time order within mare

stime

The stime variable is time that has been scaled so that ovulation occurs at scaled times 0 and 1,
and the time variable records the time ordering within mares. Because graphical evidence suggests
a periodic behavior, the analysis includes the sin1 and cos1 variables, which are sine and cosine
transformations of scaled time, respectively.
We consider the following model for the ith measurement on the j th mare:

folliclesij = 0 + 1 sin1ij + 2 cos1ij + uj +

ij

The above model incorporates the cyclical nature of the data as affecting the overall average
number of follicles and includes mare-specific random effects uj . Because we believe successive
measurements within each mare are probably correlated (even after controlling for the periodicity in
the average), we also model the within-mare errors as being AR of order 2.
. mixed follicles sin1 cos1 || mare:, residuals(ar 2, t(time)) reml nolog
Mixed-effects REML regression
Number of obs
=
Group variable: mare
Number of groups
=
Obs per group: min =
avg =
max =
Wald chi2(2)
Prob > chi2

Log restricted-likelihood = -772.59855


follicles

Coef.

sin1
cos1
_cons

-2.899228
-.8652936
12.14455

Std. Err.
.5110786
.5432926
.9473631

z
-5.67
-1.59
12.82

P>|z|
0.000
0.111
0.000

=
=

308
11
25
28.0
31

34.72
0.0000

[95% Conf. Interval]


-3.900923
-1.930127
10.28775

-1.897532
.1995402
14.00135

mixed Multilevel mixed-effects linear regression

Random-effects Parameters

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

7.092439

4.401937

2.101337

23.93843

phi1
phi2
var(e)

.5386104
.144671
14.25104

.0624899
.0632041
2.435238

.4161325
.0207933
10.19512

.6610883
.2685488
19.92054

315

mare: Identity

Residual: AR(2)

LR test vs. linear regression:


chi2(3) =
251.67
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

We picked an order of 2 as a guess, but we could have used LR tests of competing AR models to
determine the optimal order, because models of smaller order are nested within those of larger order.

Example 9
Fitzmaurice, Laird, and Ware (2011, chap. 7) analyzed data on 37 subjects who participated in an
exercise therapy trial.
. use http://www.stata-press.com/data/r13/exercise
(Exercise Therapy Trial)
. describe
Contains data from http://www.stata-press.com/data/r13/exercise.dta
obs:
259
Exercise Therapy Trial
vars:
4
24 Jun 2012 18:35
size:
1,036
(_dta has notes)

variable name

storage
type

display
format

id
day
program

byte
byte
byte

%9.0g
%9.0g
%9.0g

strength

byte

%9.0g

Sorted by:

id

value
label

variable label
Person ID
Day of measurement
1 = reps increase; 2 = weights
increase
Strength measurement

day

Subjects (variable id) were placed on either an increased-repetition regimen (program==1) or a program
that kept the repetitions constant but increased weight (program==2). Muscle-strength measurements
(variable strength) were taken at baseline (day==0) and then every two days over the next twelve
days.
Following Fitzmaurice, Laird, and Ware (2011, chap. 7), and to demonstrate fitting residual-error
structures to data collected at uneven time points, we confine our analysis to those data collected at
baseline and at days 4, 6, 8, and 12. We fit a full two-way factorial model of strength on program
and day, with an unstructured residual-error covariance matrix over those repeated measurements
taken on the same subject:

316

mixed Multilevel mixed-effects linear regression


. keep if inlist(day, 0, 4, 6, 8, 12)
(74 observations deleted)
. mixed strength i.program##i.day || id:,
> noconstant residuals(unstructured, t(day)) nolog
Mixed-effects ML regression
Group variable: id

Number of obs
Number of groups

Coef.

2.program

173
37

Obs per group: min =


avg =
max =

3
4.7
5

Wald chi2(9)
Prob > chi2

Log likelihood = -296.58215


strength

=
=

=
=

45.85
0.0000

Std. Err.

P>|z|

1.360119

1.003549

1.36

0.175

-.6068016

3.32704

day
4
6
8
12

1.125
1.360127
1.583563
1.623576

.3322583
.3766894
.4905876
.5372947

3.39
3.61
3.23
3.02

0.001
0.000
0.001
0.003

.4737858
.6218298
.6220287
.5704977

1.776214
2.098425
2.545097
2.676654

program#day
2 4
2 6
2 8
2 12

-.169034
.2113012
-.1299763
.3212829

.4423472
.4982385
.6524813
.7306782

-0.38
0.42
-0.20
0.44

0.702
0.671
0.842
0.660

-1.036019
-.7652283
-1.408816
-1.11082

.6979505
1.187831
1.148864
1.753386

_cons

79.6875

.7560448

105.40

0.000

78.20568

81.16932

Random-effects Parameters
id:

[95% Conf. Interval]

Estimate

Std. Err.

[95% Conf. Interval]

9.14566
11.87114
10.06571
13.22464
13.16909
9.625236
8.489043
9.280414
8.898006
10.49185
11.89787
11.28344
11.0507
10.5006
12.4091

2.126248
2.761219
2.348863
3.113921
3.167347
2.33197
2.106377
2.369554
2.348243
2.492529
2.848751
2.805027
2.646988
2.590278
3.010796

5.79858
7.524948
6.371091
8.335981
8.219208
5.054659
4.36062
4.636173
4.295535
5.606578
6.314421
5.785689
5.862697
5.423748
6.508051

(empty)

Residual: Unstructured
var(e0)
var(e4)
var(e6)
var(e8)
var(e12)
cov(e0,e4)
cov(e0,e6)
cov(e0,e8)
cov(e0,e12)
cov(e4,e6)
cov(e4,e8)
cov(e4,e12)
cov(e6,e8)
cov(e6,e12)
cov(e8,e12)
LR test vs. linear regression:

chi2(14) =

314.67

14.42475
18.72757
15.90284
20.98026
21.09995
14.19581
12.61747
13.92465
13.50048
15.37711
17.48132
16.78119
16.2387
15.57745
18.31016

Prob > chi2 = 0.0000

Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

Because we are using the variable id only to group the repeated measurements and not to introduce
random effects at the subject level, we use the noconstant option to omit any subject-level effects.

mixed Multilevel mixed-effects linear regression

317

The unstructured covariance matrix is the most general and contains many parameters. In this example,
we estimate a distinct residual variance for each day and a distinct covariance for each pair of days.
That there is positive covariance between all pairs of measurements is evident, but what is not as
evident is whether the covariances may be more parsimoniously represented. One option would be to
explore whether the correlation diminishes as the time gap between strength measurements increases
and whether it diminishes systematically. Given the irregularity of the time intervals, an exponential
structure would be more appropriate than, say, an AR or MA structure.
. estimates store unstructured
. mixed strength i.program##i.day || id:, noconstant
> residuals(exponential, t(day)) nolog nofetable
Mixed-effects ML regression
Number of obs
Group variable: id
Number of groups
Obs per group: min
avg
max
Wald chi2(9)
Prob > chi2

Log likelihood = -307.83324


Random-effects Parameters
id:

=
=
=
=
=

173
37
3
4.7
5

=
=

36.77
0.0000

Estimate

Std. Err.

[95% Conf. Interval]

.9786462
11.22349

.0051238
2.338371

.9659207
7.460765

(empty)

Residual: Exponential
rho
var(e)
LR test vs. linear regression:

chi2(1) =

292.17

.9866854
16.88389

Prob > chi2 = 0.0000

Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

In the above example, we suppressed displaying the main regression parameters because they
did not differ much from those of the previous model. While the unstructured model estimated 15
variancecovariance parameters, the exponential model claims to get the job done with just 2, a fact
that is not disputed by an LR test comparing the two nested models (at least not at the 0.01 level).
. lrtest unstructured .
Likelihood-ratio test
LR chi2(13) =
22.50
(Assumption: . nested in unstructured)
Prob > chi2 =
0.0481
Note: The reported degrees of freedom assumes the null hypothesis is not on
the boundary of the parameter space. If this is not true, then the
reported test is conservative.

318

mixed Multilevel mixed-effects linear regression

Crossed-effects models
Not all mixed models contain nested levels of random effects.

Example 10
Returning to our longitudinal analysis of pig weights, suppose that instead of (5) we wish to fit

weightij = 0 + 1 weekij + ui + vj +

ij

(8)

for the i = 1, . . . , 9 weeks and j = 1, . . . , 48 pigs and

ui N (0, u2 );

vj N (0, v2 );

ij

N (0, 2 )

all independently. Both (5) and (8) assume an overall population-average growth curve 0 + 1 week
and a random pig-specific shift.
The models differ in how week enters into the random part of the model. In (5), we assume
that the effect due to week is linear and pig specific (a random slope); in (8), we assume that the
effect due to week, ui , is systematic to that week and common to all pigs. The rationale behind (8)
could be that, assuming that the pigs were measured contemporaneously, we might be concerned that
week-specific random factors such as weather and feeding patterns had significant systematic effects
on all pigs.
Model (8) is an example of a two-way crossed-effects model, with the pig effects vj being crossed
with the week effects ui . One way to fit such models is to consider all the data as one big cluster,
and treat the ui and vj as a series of 9 + 48 = 57 random coefficients on indicator variables for
week and pig. In the notation of (2),

u1
.
.
.

u
u = 9 N (0, G);
v1
.
..
v48

G=

u2 I9
0

0
v2 I48

Because G is block diagonal, it can be represented in mixed as repeated-level equations. All we need
is an identification variable to identify all the observations as one big group and a way to tell mixed
to treat week and pig as factor variables (or equivalently, as two sets of overparameterized indicator
variables identifying weeks and pigs, respectively). mixed supports the special group designation
all for the former and the R.varname notation for the latter.

mixed Multilevel mixed-effects linear regression


. use http://www.stata-press.com/data/r13/pig, clear
(Longitudinal analysis of pig weights)
. mixed weight week || _all: R.week || _all: R.id
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log likelihood = -1013.824
Iteration 1:
log likelihood = -1013.824
Computing standard errors:
Mixed-effects ML regression
Number of obs
Group variable: _all
Number of groups
Obs per group: min
avg
max
Log likelihood =

Wald chi2(1)
Prob > chi2

-1013.824

weight

Coef.

week
_cons

6.209896
19.35561

Std. Err.
.0539313
.6333982

Random-effects Parameters

z
115.14
30.56

=
=
=
=
=

432
1
432
432.0
432

=
=

13258.28
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.104192
18.11418

319

6.315599
20.59705

Estimate

Std. Err.

[95% Conf. Interval]

var(R.week)

.0849874

.0868856

.0114588

.6303302

var(R.id)

14.83623

3.126142

9.816733

22.42231

var(Residual)

4.297328

.3134404

3.724888

4.957741

_all: Identity

_all: Identity

LR test vs. linear regression:


chi2(2) =
474.85
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.
. estimates store crossed

Thus we estimate u2 = 0.08 and v2 = 14.84. Both (5) and (8) estimate a total of five parameters:
two fixed effects and three variance components. The models, however, are not nested within each
other, which precludes the use of an LR test to compare both models. Refitting model (5) and looking
at the Akaike information criteria values by using estimates stats,
. quietly mixed weight week || id:week
. estimates stats crossed .
Akaikes information criterion and Bayesian information criterion
Model

Obs

ll(null)

ll(model)

df

AIC

BIC

crossed
.

432
432

.
.

-1013.824
-869.0383

5
5

2037.648
1748.077

2057.99
1768.419

Note:

N=Obs used in calculating BIC; see t

definitely favors model (5). This finding is not surprising given that our rationale behind (8) was
somewhat fictitious. In our estimates stats output, the values of ll(null) are missing. mixed
does not fit a constant-only model as part of its usual estimation of the full model, but you can use
mixed to fit a constant-only model directly, if you wish.

320

mixed Multilevel mixed-effects linear regression

The R.varname notation is equivalent to giving a list of overparameterized (none dropped)


indicator variables for use in a random-effects specification. When you specify R.varname, mixed
handles the calculations internally rather than creating the indicators in the data. Because the set of
indicators is overparameterized, R.varname implies noconstant. You can include factor variables in
the fixed-effects specification by using standard methods; see [U] 11.4.3 Factor variables. However,
random-effects equations support only the R.varname factor specification. For more complex factor
specifications (such as interactions) in random-effects equations, use generate to form the variables
manually, as we demonstrated in example 6.

Technical note
Although we were able to fit the crossed-effects model (8), it came at the expense of increasing the
column dimension of our random-effects design from 2 in model (5) to 57 in model (8). Computation
time and memory requirements grow (roughly) quadratically with the dimension of the random effects.
As a result, fitting such crossed-effects models is feasible only when the total column dimension is
small to moderate.
Reexamining model (8), we note that if we drop ui , we end up with a model equivalent to (4),
meaning that we could have fit (4) by typing
. mixed weight week || _all: R.id
instead of
. mixed weight week || id:
as we did when we originally fit the model. The results of both estimations are identical, but the
latter specification, organized at the cluster (pig) level with random-effects dimension 1 (a random
intercept) is much more computationally efficient. Whereas with the first form we are limited in how
many pigs we can analyze, there is no such limitation with the second form.
Furthermore, we fit model (8) by using
. mixed weight week || _all: R.week || _all: R.id
as a direct way to demonstrate the R. notation. However, we can technically treat pigs as nested
within the all group, yielding the equivalent and more efficient (total column dimension 10) way
to fit (8):
. mixed weight week || _all: R.week || id:
We leave it to you to verify that both produce identical results. See Rabe-Hesketh and Skrondal (2012)
for additional techniques to make calculations more efficient in more complex models.

Example 11
As another example of how the same model may be fit in different ways by using mixed (and
as a way to demonstrate covariance(exchangeable)), consider the three-level model used in
example 4:
(3)
(2)
yjk = Xjk + uk + ujk + jk

mixed Multilevel mixed-effects linear regression

321

where yjk represents the logarithms of gross state products for the njk = 17 observations from state
(3)
(2)
j in region k , Xjk is a set of regressors, uk is a random intercept at the region level, and ujk is
(3)

a random intercept at the state (nested within region) level. We assume that uk
(2)
ujk

N (0, 22 )

N (0, 32 ) and

independently. Define

vk =

(3)

(2)

uk + u1k
(3)
(2)
uk + u2k
..
.
(3)

(2)

uk + uMk ,k
where Mk is the number of states in region k . Making this substitution, we can stack the observations
for all the states within region k to get

y k = X k + Zk v k +

where Zk is a set of indicators identifying the states within each region; that is,

Zk = IMk J17
for a k -column vector of 1s Jk , and

2 + 2
3

= Var(vk ) =

32
..
.
32

32

32
+ 22
..
.

..
.

32
32
..
.

32

32

32 + 22

Mk Mk

Because is an exchangeable matrix, we can fit this alternative form of the model by specifying the
exchangeable covariance structure.

322

mixed Multilevel mixed-effects linear regression


. use http://www.stata-press.com/data/r13/productivity
(Public Capital Productivity)
. mixed gsp private emp hwy water other unemp || region: R.state,
> cov(exchangeable)
(output omitted )
Mixed-effects ML regression
Number of obs
Group variable: region
Number of groups
Obs per group: min
avg
max
Log likelihood =

Wald chi2(6)
Prob > chi2

1430.5017

gsp

Coef.

private
emp
hwy
water
other
unemp
_cons

.2671484
.7540721
.0709767
.0761187
-.0999955
-.0058983
2.128823

Std. Err.
.0212591
.0261868
.023041
.0139248
.0169366
.0009031
.1543855

z
12.57
28.80
3.08
5.47
-5.90
-6.53
13.79

P>|z|
0.000
0.000
0.002
0.000
0.000
0.000
0.000

=
=
=
=
=

816
9
51
90.7
136

=
=

18829.06
0.0000

[95% Conf. Interval]


.2254813
.7027468
.0258172
.0488266
-.1331907
-.0076684
1.826233

.3088154
.8053973
.1161363
.1034109
-.0668004
-.0041282
2.431413

Random-effects Parameters

Estimate

Std. Err.

[95% Conf. Interval]

region: Exchangeable
var(R.state)
cov(R.state)

.0077263
.0014506

.0017926
.0012995

.0049032
-.0010963

.0121749
.0039975

var(Residual)

.0013461

.0000689

.0012176

.0014882

LR test vs. linear regression:


chi2(2) = 1154.73
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

The estimates of the fixed effects and their standard errors are equivalent to those from example 4,
and remapping the variance components from (32 + 22 , 32 , 2 ), as displayed here, to (32 , 22 , 2 ),
as displayed in example 4, will show that they are equivalent as well.
Of course, given the discussion in the previous technical note, it is more efficient to fit this model
as we did originally, as a three-level model.

Diagnosing convergence problems


Given the flexibility of mixed-effects models, you will find that some models fail to converge
when used with your data; see Diagnosing convergence problems in [ME] me for advice applicable
to mixed-effects models in general.
In unweighted LME models with independent and homoskedastic residuals, one useful way to
diagnose problems of nonconvergence is to rely on the EM algorithm (Dempster, Laird, and Rubin 1977),
normally used by mixed only as a means of refining starting values. The advantages of EM are that it
does not require a Hessian calculation, each successive EM iteration will result in a larger likelihood,
iterations can be calculated quickly, and iterations will quickly bring parameter estimates into a
neighborhood of the solution. The disadvantages of EM are that, once in a neighborhood of the

mixed Multilevel mixed-effects linear regression

323

solution, it can be slow to converge, if at all, and EM provides no facility for estimating standard
errors of the estimated variance components. One useful property of EM is that it is always willing
to provide a solution if you allow it to iterate enough times, if you are satisfied with being in a
neighborhood of the optimum rather than right on the optimum, and if standard errors of variance
components are not crucial to your analysis.
If you encounter a nonconvergent model, try using the emonly option to bypass gradient-based
optimization. Use emiterate(#) to specify the maximum number of EM iterations, which you will
usually want to set much higher than the default of 20. If your EM solution shows an estimated
variance component that is near 0, a ridge is formed by an interval of values near 0, which produces
the same likelihood and looks equally good to the optimizer. In this case, the solution is to drop the
offending variance component from the model.

Survey data
Multilevel modeling of survey data is a little different from standard modeling in that weighted
sampling can take place at multiple levels in the model, resulting in multiple sampling weights. Most
survey datasets, regardless of the design, contain one overall inclusion weight for each observation in
the data. This weight reflects the inverse of the probability of ultimate selection, and by ultimate we
mean that it factors in all levels of clustered sampling, corrections for noninclusion and oversampling,
poststratification, etc.
For simplicity, in what follows assume a simple two-stage sampling design where groups are
randomly sampled and then individuals within groups are sampled. Also assume that no additional
weight corrections are performed; that is, sampling weights are simply the inverse of the probability
of selection. The sampling weight for observation i in cluster j in our two-level sample is then
wij = 1/ij , where ij is the probability that observation i, j is selected. If you were performing a
standard analysis such as OLS regression with regress, you would simply use a variable holding wij
as your pweight variable, and the fact that it came from two levels of sampling would not concern
you. Perhaps you would type vce(cluster groupvar) where groupvar identifies the top-level groups
to get standard errors that control for correlation within these groups, but you would still use only a
single weight variable.
Now take these same data and fit a two-level model with mixed. As seen in (14) in Methods and
formulas later in this entry, it is not sufficient to use the single sampling weight wij , because weights
enter into the log likelihood at both the group level and the individual level. Instead, what is required
for a two-level model under this sampling design is wj , the inverse of the probability that group j
is selected in the first stage, and wi|j , the inverse of the probability that individual i from group j is
selected at the second stage conditional on group j already being selected. It simply will not do to
just use wij without making any assumptions about wj .
Given the rules of conditional probability, wij = wj wi|j . If your dataset has only wij , then you
will need to either assume equal probability sampling at the first stage (wj = 1 for all j ) or find
some way to recover wj from other variables in your data; see Rabe-Hesketh and Skrondal (2006)
and the references therein for some suggestions on how to do this, but realize that there is little yet
known about how well these approximations perform in practice.
What you really need to fit your two-level model are data that contain wj in addition to either wij
or wi|j . If you have wij that is, the unconditional inclusion weight for observation i, j then you
need to either divide wij by wj to obtain wi|j or rescale wij so that its dependence on wj disappears.
If you already have wi|j , then rescaling becomes optional (but still an important decision to make).
Weight rescaling is not an exact science, because the scale of the level-one weights is at issue
regardless of whether they represent wij or wi|j : because wij is unique to group j , the group-to-group

324

mixed Multilevel mixed-effects linear regression

magnitudes of these weights need to be normalized so that they are consistent from group to group.
This is in stark contrast to a standard analysis, where the scale of sampling weights does not factor
into estimation, instead only affecting the estimate of the total population size.
mixed offers three methods for standardizing weights in a two-level model, and you can specify
which method you want via the pwscale() option. If you specify pwscale(size), then the wi|j (or
wij , it does not matter) are scaled to sum to the cluster size nj . Method pwscale(effective) adds
in a dependence on the sum of the squared weights so that level-one weights sum to the effective
sample size. Just like pwscale(size), pwscale(effective) also behaves the same whether you
have wi|j or wij , and so it can be used with either.
Although both pwscale(size) and pwscale(effective) leave wj untouched, the pwscale(gk)
method is a little different in that 1) it changes the weights at both levels and 2) it does assume
you have wi|j for level-one weights and not wij (if you have the latter, then first divide by wj ).
Using the method of Graubard and Korn (1996), it sets the weights at the group level (level two) to
the cluster averages of the products of both level weights (this product being wij ). It then sets the
individual weights to 1 everywhere; see Methods and formulas for the computational details of all
three methods.
Determining which method is best is a tough call and depends on cluster size (the smaller
the clusters, the greater the sensitivity to scale), whether the sampling is informative (that is, the
sampling weights are correlated with the residuals), whether you are interested primarily in regression
coefficients or in variance components, whether you have a simple random-intercept model or a
more complex random-coefficients model, and other factors; see Rabe-Hesketh and Skrondal (2006),
Carle (2009), and Pfeffermann et al. (1998) for some detailed advice. At the very least, you want
to compare estimates across all three scaling methods (four, if you add no scaling) and perform a
sensitivity analysis.
If you choose to rescale level-one weights, it does not matter whether you have wi|j or wij . For
the pwscale(size) and pwscale(effective) methods, you get identical results, and even though
pwscale(gk) assumes wi|j , you can obtain this as wi|j = wij /wj before proceeding.
If you do not specify pwscale(), then no scaling takes place, and thus at a minimum, you need
to make sure you have wi|j in your data and not wij .

Example 12
Rabe-Hesketh and Skrondal (2006) analyzed data from the 2000 Programme for International
Student Assessment (PISA) study on reading proficiency among 15-year-old American students, as
performed by the Organisation for Economic Co-operation and Development (OECD). The original
study was a three-stage cluster sample, where geographic areas were sampled at the first stage, schools
at the second, and students at the third. Our version of the data does not contain the geographic-areas
variable, so we treat this as a two-stage sample where schools are sampled at the first stage and
students at the second.

mixed Multilevel mixed-effects linear regression

325

. use http://www.stata-press.com/data/r13/pisa2000
(Programme for International Student Assessment (PISA) 2000 data)
. describe
Contains data from http://www.stata-press.com/data/r13/pisa2000.dta
obs:
2,069
Programme for International
Student Assessment (PISA) 2000
data
vars:
11
12 Jun 2012 10:08
size:
37,242
(_dta has notes)

variable name

storage
type

display
format

female
isei

byte
byte

%8.0g
%8.0g

w_fstuwt
wnrschbw
high_school

float
float
byte

%9.0g
%9.0g
%8.0g

college

byte

%8.0g

one_for
both_for

byte
byte

%8.0g
%8.0g

test_lang

byte

%8.0g

pass_read

byte

%8.0g

id_school

int

%8.0g

value
label

variable label
1 if female
International socio-economic
index
Student-level weight
School-level weight
1 if highest level by either
parent is high school
1 if highest level by either
parent is college
1 if one parent foreign born
1 if both parents are foreign
born
1 if English (the test language)
is spoken at home
1 if passed reading proficiency
threshold
School ID

Sorted by:

For student i in school j , where the variable id school identifies the schools, the variable
w fstuwt is a student-level overall inclusion weight (wij , not wi|j ) adjusted for noninclusion and
nonparticipation of students, and the variable wnrschbw is the school-level weight wj adjusted for
oversampling of schools with more minority students. The weight adjustments do not interfere with
the methods prescribed above, and thus we can treat the weight variables simply as wij and wj ,
respectively.
Rabe-Hesketh and Skrondal (2006) fit a two-level logistic model for passing a reading proficiency
threshold. We fit a two-level linear random-intercept model for socioeconomic index. Because we
have wij and not wi|j , we rescale using pwscale(size) and thus obtain results as if we had wi|j .

326

mixed Multilevel mixed-effects linear regression


. mixed isei female high_school college one_for both_for test_lang
> [pw=w_fstuwt] || id_school:, pweight(wnrschbw) pwscale(size)
(output omitted )
Mixed-effects regression
Number of obs
Group variable: id_school
Number of groups
Obs per group: min
avg
max

=
=
=
=
=

2069
148
1
14.0
28

Wald chi2(6)
=
187.23
Log pseudolikelihood = -1443093.9
Prob > chi2
=
0.0000
(Std. Err. adjusted for 148 clusters in id_school)

isei

Coef.

female
high_school
college
one_for
both_for
test_lang
_cons

.59379
6.410618
19.39494
-.9584613
-.2021101
2.519539
28.10788

Robust
Std. Err.
.8732886
1.500337
2.121145
1.789947
2.32633
2.393165
2.435712

z
0.68
4.27
9.14
-0.54
-0.09
1.05
11.54

P>|z|
0.497
0.000
0.000
0.592
0.931
0.292
0.000

[95% Conf. Interval]


-1.117824
3.470011
15.23757
-4.466692
-4.761633
-2.170978
23.33397

2.305404
9.351224
23.55231
2.54977
4.357413
7.210056
32.88179

Random-effects Parameters

Estimate

Robust
Std. Err.

[95% Conf. Interval]

id_school: Identity
var(_cons)

34.69374

8.574865

21.37318

56.31617

var(Residual)

218.7382

11.22111

197.8147

241.8748

Notes:
1. We specified the level-one weights using standard Stata weight syntax, that is, [pw=w fstuwt].
2. We specified the level-two weights via the pweight(wnrschbw) option as part of the randomeffects specification for the id school level. As such, it is treated as a school-level weight.
Accordingly, wnrschbw needs to be constant within schools, and mixed did check for that before
estimating.
3. Because our level-one weights are unconditional, we specified pwscale(size) to rescale them.
4. As is the case with other estimation commands in Stata, standard errors in the presence of sampling
weights are robust.
5. Robust standard errors are clustered at the top level of the model, and this will always be true unless
you specify vce(cluster clustvar), where clustvar identifies an even higher level of grouping.
As a form of sensitivity analysis, we compare the above with scaling via pwscale(gk). Because
pwscale(gk) assumes wi|j , you want to first divide wij by wj . But you can handle that within the
weight specification itself.

mixed Multilevel mixed-effects linear regression


. mixed isei female high_school college one_for both_for test_lang
> [pw=w_fstuwt/wnrschbw] || id_school:, pweight(wnrschbw) pwscale(gk)
(output omitted )
Mixed-effects regression
Number of obs
=
Group variable: id_school
Number of groups
=
Obs per group: min =
avg =
max =

327

2069
148
1
14.0
28

Wald chi2(6)
=
291.37
Log pseudolikelihood = -7270505.6
Prob > chi2
=
0.0000
(Std. Err. adjusted for 148 clusters in id_school)

isei

Coef.

female
high_school
college
one_for
both_for
test_lang
_cons

-.3519458
7.074911
19.27285
-.9142879
1.214151
2.661866
31.20145

Robust
Std. Err.
.7436334
1.139777
1.286029
1.783091
1.611885
1.556491
1.907413

z
-0.47
6.21
14.99
-0.51
0.75
1.71
16.36

P>|z|
0.636
0.000
0.000
0.608
0.451
0.087
0.000

[95% Conf. Interval]


-1.80944
4.84099
16.75228
-4.409082
-1.945085
-.3887996
27.46299

1.105549
9.308833
21.79342
2.580506
4.373388
5.712532
34.93991

Random-effects Parameters

Estimate

Robust
Std. Err.

[95% Conf. Interval]

id_school: Identity
var(_cons)

31.67522

6.792239

20.80622

48.22209

var(Residual)

226.2429

8.150714

210.8188

242.7955

The results are somewhat similar to before, which is good news from a sensitivity standpoint. Note
that we specified [pw=w fstwtw/wnrschbw] and thus did the conversion from wij to wi|j within
our call to mixed.

We close this section with a bit of bad news. Although weight rescaling and the issues that arise
have been well studied for two-level models, as pointed out by Carle (2009), . . . a best practice
for scaling weights across multiple levels has yet to be advanced. As such, pwscale() is currently
supported only for two-level models. If you are fitting a higher-level model with survey data, you
need to make sure your sampling weights are conditional on selection at the previous stage and not
overall inclusion weights, because there is currently no rescaling option to fall back on if you do not.

328

mixed Multilevel mixed-effects linear regression

Stored results
mixed stores the following in e():
Scalars
e(N)
e(k)
e(k f)
e(k r)
e(k rs)
e(k rc)
e(k res)
e(N clust)
e(nrgroups)
e(ar p)
e(ma q)
e(res order)
e(df m)
e(ll)
e(chi2)
e(p)
e(ll c)
e(chi2 c)
e(df c)
e(p c)
e(rank)
e(rc)
e(converged)
Macros
e(cmd)
e(cmdline)
e(depvar)
e(wtype)
e(wexp)
e(fweightk)
e(pweightk)
e(ivars)
e(title)
e(redim)
e(vartypes)
e(revars)
e(resopt)
e(rstructure)
e(rstructlab)
e(rbyvar)
e(rglabels)
e(pwscale)
e(timevar)
e(chi2type)
e(clustvar)
e(vce)
e(vcetype)
e(method)
e(opt)
e(optmetric)
e(emonly)
e(ml method)
e(technique)
e(properties)
e(estat cmd)
e(predict)
e(asbalanced)
e(asobserved)

number of observations
number of parameters
number of fixed-effects parameters
number of random-effects parameters
number of variances
number of covariances
number of residual-error parameters
number of clusters
number of residual-error by() groups
AR order of residual errors, if specified
MA order of residual errors, if specified
order of residual-error structure, if appropriate
model degrees of freedom
log (restricted) likelihood
2

significance
log likelihood, comparison model
2 , comparison model
degrees of freedom, comparison model
significance, comparison model
rank of e(V)
return code
1 if converged, 0 otherwise
mixed
command as typed
name of dependent variable
weight type (first-level weights)
weight expression (first-level weights)
fweight expression for kth highest level, if specified
pweight expression for kth highest level, if specified
grouping variables
title in estimation output
random-effects dimensions
variance-structure types
random-effects covariates
residuals() specification, as typed
residual-error structure
residual-error structure output label
residual-error by() variable, if specified
residual-error by() groups labels
sampling-weight scaling method
residual-error t() variable, if specified
Wald; type of model 2 test
name of cluster variable
vcetype specified in vce()
title used to label Std. Err.
ML or REML
type of optimization
matsqrt or matlog; random-effects matrix parameterization
emonly, if specified
type of ml method
maximization technique
b V
program used to implement estat
program used to implement predict
factor variables fvset as asbalanced
factor variables fvset as asobserved

mixed Multilevel mixed-effects linear regression


Matrices
e(b)
e(N g)
e(g min)
e(g avg)
e(g max)
e(tmap)
e(V)
e(V modelbased)
Functions
e(sample)

329

coefficient vector
group counts
group-size minimums
group-size averages
group-size maximums
ID mapping for unstructured residual errors
variancecovariance matrix of the estimator
model-based variance
marks estimation sample

Methods and formulas


As given by (1), in the absence of weights we have the linear mixed model

y = X + Zu +
where y is the n 1 vector of responses, X is an n p design/covariate matrix for the fixed effects
, and Z is the n q design/covariate matrix for the random effects u. The n 1 vector of errors
is for now assumed to be multivariate normal with mean 0 and variance matrix 2 In . We also
assume that u has variancecovariance matrix G and that u is orthogonal to so that
Var

G
0
0 2 In

Considering the combined error term Zu + , we see that y is multivariate normal with mean X
and n n variancecovariance matrix

V = ZGZ + 2 In
Defining as the vector of unique elements of G results in the log likelihood

L(, , 2 ) =

1
n log(2) + log |V| + (y X) V1 (y X)
2

(9)

which is maximized as a function of , , and 2 . As explained in chapter 6 of Searle, Casella,


and McCulloch (1992), considering instead the likelihood of a set of linear contrasts Ky that do not
depend on results in the restricted log likelihood

LR (, , 2 ) = L(, , 2 )

1
log X V1 X
2

(10)

Given the high dimension of V, however, the log-likelihood and restricted log-likelihood criteria are
not usually computed by brute-force application of the above expressions. Instead, you can simplify
the problem by subdividing the data into independent clusters (and subclusters if possible) and using
matrix decomposition methods on the smaller matrices that result from treating each cluster one at a
time.
Consider the two-level model described previously in (2),

yj = Xj + Zj uj +

for j = 1, . . . , M clusters with cluster j containing nj observations, with Var(uj ) = , a q q


matrix.

330

mixed Multilevel mixed-effects linear regression

Efficient methods for computing (9) and (10) are given in chapter 2 of Pinheiro and Bates (2000).
Namely, for the two-level model, define to be the Cholesky factor of 2 1 , such that 2 1 =
. For j = 1, . . . , M , decompose

Zj

= Qj

R11j
0

by using an orthogonal-triangular (QR) decomposition, with Qj a (nj + q)-square matrix and R11j
a q -square matrix. We then apply Qj as follows:

R10j
R00j

= Qj

Xj
;
0

c1j
c0j

= Qj

yj
0

Stack the R00j and c0j matrices, and perform the additional QR decomposition

R001 c01
R00 c0
..
...
= Q0
.
0
c1
R00M c0M
Pinheiro and Bates (2000) show that ML estimates of , 2 , and (the unique elements of ,
that is) are obtained by maximizing the profile log likelihood (profiled in )
M

L() =

det()
n
log
{log n log(2) 1} n log ||c1 || +
2
det(R11j )
j=1

(11)

where || || denotes the 2-norm. Following this maximization with


= R1
00 c0 ;

2 = n1 ||c1 ||2

(12)

REML estimates are obtained by maximizing

LR () =

np
{log(n p) log(2) 1} (n p) log ||c1 ||
2
M

log |det(R00 )| +

log
j=1

det()
det(R11j )

(13)

followed by
= R1
00 c0 ;

2 = (n p)1 ||c1 ||2

For numerical stability, maximization of (11) and (13) is not performed with respect to the unique
elements of but instead with respect to the unique elements of the matrix square root (or matrix
logarithm if the matlog option is specified) of / 2 ; define to be the vector containing these
elements.
Once maximization with respect to is completed, (, 2 ) is reparameterized to {, log( )},
where is a vector containing the unique elements of , expressed as logarithms of standard
deviations for the diagonal elements and hyperbolic arctangents of the correlations for off-diagonal
elements. This last step is necessary 1) to obtain a joint variancecovariance estimate of the elements
of and 2 ; 2) to obtain a parameterization under which parameter estimates can be interpreted
individually, rather than as elements of a matrix square root (or logarithm); and 3) to parameterize
these elements such that their ranges each encompass the entire real line.

mixed Multilevel mixed-effects linear regression

331

Obtaining a joint variancecovariance matrix for the estimated {, log( )} requires the evaluation
of the log likelihood (or log-restricted likelihood) with only profiled out. For ML, we have

L {, log( )} = L{(, 2 ), 2 }
M

det()
||c1 ||2
n
+
log
= log(2 2 )
2
2 2
det(R
11j )
j=1
with the analogous expression for REML.
The variancecovariance matrix of is estimated as
1
Var() = 2 R1
00 R00

but this does not mean that Var() is identical under both ML and REML because R00 depends on
. Because is asymptotically uncorrelated with {, log( )}, the covariance of with the other
estimated parameters is treated as 0.
Parameter estimates are stored in e(b) as {, , log( )}, with the corresponding (block-diagonal)
variancecovariance matrix stored in e(V). Parameter estimates can be displayed in this metric by
specifying the estmetric option. However, in mixed output, variance components are most often
displayed either as variances and covariances or as standard deviations and correlations.
EM iterations are derived by considering the uj in (2) as missing data. Here we describe the
procedure for maximizing the log likelihood via EM; the procedure for maximizing the restricted log
likelihood is similar. The log likelihood for the full data (y, u) is
M

LF (, , 2 ) =

log f1 (yj |uj , , 2 ) + log f2 (uj |)


j=1

where f1 () is the density function for multivariate normal with mean Xj + Zj uj and variance
2 Inj , and f2 () is the density for multivariate normal with mean 0 and q q covariance matrix
. As before, we can profile and 2 out of the optimization, yielding the following EM iterative
procedure:
1. For the current iterated value of (t) , fix = ((t) ) and 2 = 2 ((t) ) according to (12).
2. Expectation step: Calculate

D() E LF (, , 2 )|y
=C

M
1
log det ()
2
2

E uj 1 uj |y
j=1

where C is a constant that does not depend on , and the expected value of the quadratic form
uj 1 uj is taken with respect to the conditional density f (uj |y, , (t) , 2 ).
3. Maximization step: Maximize D() to produce (t+1) .

332

mixed Multilevel mixed-effects linear regression

For general, symmetric , the maximizer of D() can be derived explicitly, making EM iterations
quite fast.
For general, residual-error structures,
Var( j ) = 2 j
where the subscript j merely represents that
data are first transformed according to
1/2

yj = j

and j vary in dimension in unbalanced data, the


1/2

Xj = j

yj ;

1/2

Zj = j

Xj ;

Zj ;

yj ,

and the likelihood-evaluation techniques described above are applied to


Xj , and Zj instead.
The unique elements of , , are estimated along with the fixed effects and variance components.
Because 2 is always estimated and multiplies the entire j matrix, is parameterized to take this
into account.
In the presence of sampling weights, following Rabe-Hesketh and Skrondal (2006), the weighted
log pseudolikelihood for a two-level model is given as
nj

L(, , 2 ) =

wj log

wi|j log f1 (yij |uj , , 2 ) f2 (uj |)duj

exp

j=1

(14)

i=1

where wj is the inverse of the probability of selection for the j th cluster, wi|j is the inverse of the
conditional probability of selection of individual i given the selection of cluster j , and f1 () and
f2 () are the multivariate normal densities previously defined.
Weighted estimation is achieved through incorporating wj and wi|j into the matrix decomposition
methods detailed above to reflect replicated clusters for wj and replicated observations within clusters
for wi|j . Because this estimation is based on replicated clusters and observations, frequency weights
are handled similarly.
Rescaling of sampling weights can take one of three available forms:
Under pwscale(size),
1

nj

wi|j

nj wi|j

wi|j
i=1

Under pwscale(effective),
nj

wi|j

wi|j

nj
2
wi|j

wi|j
i=1

i=1

Under both the above, wj remains unchanged. For method pwscale(gk), however, both weights are
modified:
nj

wj = n1
j

wi|j wj ;

=1
wi|j

i=1

Under ML estimation, robust standard errors are obtained in the usual way (see [P] robust) with
the one distinction being that in multilevel models, robust variances are, at a minimum, clustered at
the highest level. This is because given the form of the log likelihood, scores aggregate at the top-level
clusters. For a two-level model, scores are obtained as the partial derivatives of Lj (, , 2 ) with
M
respect to {, , log( )}, where Lj is the log likelihood for cluster j and L = j=1 Lj . Robust
variances are not supported under REML estimation because the form of the log restricted likelihood
does not lend itself to separation by highest-level clusters.

mixed Multilevel mixed-effects linear regression

333

EM iterations always assume equal weighting and an independent, homoskedastic error structure.
As such, with weighted data or when error structures are more complex, EM is used only to obtain
starting values.

For extensions to models with three or more levels, see Bates and Pinheiro (1998) and Rabe-Hesketh
and Skrondal (2006).

Charles Roy Henderson (19111989) was born in Iowa and grew up on the family farm. His
education in animal husbandry, animal nutrition, and statistics at Iowa State was interspersed
with jobs in the Iowa Extension Service, Ohio University, and the U.S. Army. After completing
his PhD, Henderson joined the Animal Science faculty at Cornell. He developed and applied
statistical methods in the improvement of farm livestock productivity through genetic selection,
with particular focus on dairy cattle. His methods are general and have been used worldwide
in livestock breeding and beyond agriculture. Hendersons work on variance components and
best linear unbiased predictions has proved to be one of the main roots of current mixed-model
methods.

Acknowledgments
We thank Badi Baltagi of the Department of Economics at Syracuse University and Ray Carroll
of the Department of Statistics at Texas A&M University for each providing us with a dataset used
in this entry.

References
Andrews, M. J., T. Schank, and R. Upward. 2006. Practical fixed-effects estimation methods for the three-way
error-components model. Stata Journal 6: 461481.
Baltagi, B. H., S. H. Song, and B. C. Jung. 2001. The unbalanced nested error component regression model. Journal
of Econometrics 101: 357381.
Bates, D. M., and J. C. Pinheiro. 1998. Computational methods for multilevel modelling. In Technical Memorandum
BL0112140-980226-01TM. Murray Hill, NJ: Bell Labs, Lucent Technologies.
http://stat.bell-labs.com/NLME/CompMulti.pdf.
Cameron, A. C., and P. K. Trivedi. 2010. Microeconometrics Using Stata. Rev. ed. College Station, TX: Stata Press.
Canette, I. 2011. Including covariates in crossed-effects models. The Stata Blog: Not Elsewhere Classified.
http://blog.stata.com/2010/12/22/including-covariates-in-crossed-effects-models/.
Carle, A. C. 2009. Fitting multilevel models in complex survey data with design weights: Recommendations. BMC
Medical Research Methodology 9: 49.
Demidenko, E. 2004. Mixed Models: Theory and Applications. Hoboken, NJ: Wiley.
Dempster, A. P., N. M. Laird, and D. B. Rubin. 1977. Maximum likelihood from incomplete data via the EM
algorithm. Journal of the Royal Statistical Society, Series B 39: 138.
Diggle, P. J., P. J. Heagerty, K.-Y. Liang, and S. L. Zeger. 2002. Analysis of Longitudinal Data. 2nd ed. Oxford:
Oxford University Press.
Fitzmaurice, G. M., N. M. Laird, and J. H. Ware. 2011. Applied Longitudinal Analysis. 2nd ed. Hoboken, NJ: Wiley.
Goldstein, H. 1986. Efficient statistical modelling of longitudinal data. Annals of Human Biology 13: 129141.
Graubard, B. I., and E. L. Korn. 1996. Modelling the sampling design in the analysis of health surveys. Statistical
Methods in Medical Research 5: 263281.
Harville, D. A. 1977. Maximum likelihood approaches to variance component estimation and to related problems.
Journal of the American Statistical Association 72: 320338.

334

mixed Multilevel mixed-effects linear regression

Henderson, C. R. 1953. Estimation of variance and covariance components. Biometrics 9: 226252.


Hocking, R. R. 1985. The Analysis of Linear Models. Monterey, CA: Brooks/Cole.
Horton, N. J. 2011. Stata tip 95: Estimation of error covariances in a linear model. Stata Journal 11: 145148.
Laird, N. M., and J. H. Ware. 1982. Random-effects models for longitudinal data. Biometrics 38: 963974.
LaMotte, L. R. 1973. Quadratic estimation of variance components. Biometrics 29: 311330.
Marchenko, Y. V. 2006. Estimating variance components in Stata. Stata Journal 6: 121.
McCulloch, C. E., S. R. Searle, and J. M. Neuhaus. 2008. Generalized, Linear, and Mixed Models. 2nd ed. Hoboken,
NJ: Wiley.
Munnell, A. H. 1990. Why has productivity growth declined? Productivity and public investment. New England
Economic Review Jan./Feb.: 322.
Nichols, A. 2007. Causal inference with observational data. Stata Journal 7: 507541.
Pantazis, N., and G. Touloumi. 2010. Analyzing longitudinal data in the presence of informative drop-out: The jmre1
command. Stata Journal 10: 226251.
Pfeffermann, D., C. J. Skinner, D. J. Holmes, H. Goldstein, and J. Rasbash. 1998. Weighting for unequal selection
probabilities in multilevel models. Journal of the Royal Statistical Society, Series B 60: 2340.
Pierson, R. A., and O. J. Ginther. 1987. Follicular population dynamics during the estrous cycle of the mare. Animal
Reproduction Science 14: 219231.
Pinheiro, J. C., and D. M. Bates. 2000. Mixed-Effects Models in S and S-PLUS. New York: Springer.
Prosser, R., J. Rasbash, and H. Goldstein. 1991. ML3 Software for 3-Level Analysis: Users Guide for V. 2. London:
Institute of Education, University of London.
Rabe-Hesketh, S., and A. Skrondal. 2006. Multilevel modelling of complex survey data. Journal of the Royal Statistical
Society, Series A 169: 805827.
. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station, TX: Stata Press.
Rao, C. R. 1973. Linear Statistical Inference and Its Applications. 2nd ed. New York: Wiley.
Raudenbush, S. W., and A. S. Bryk. 2002. Hierarchical Linear Models: Applications and Data Analysis Methods.
2nd ed. Thousand Oaks, CA: Sage.
Ruppert, D., M. P. Wand, and R. J. Carroll. 2003. Semiparametric Regression. Cambridge: Cambridge University
Press.
Schunck, R. 2013. Within and between estimates in random-effects models: Advantages and drawbacks of correlated
random effects and hybrid models. Stata Journal 13: 6576.
Searle, S. R. 1989. Obituary: Charles Roy Henderson 19111989. Biometrics 45: 13331335.
Searle, S. R., G. Casella, and C. E. McCulloch. 1992. Variance Components. New York: Wiley.
Thompson, W. A., Jr. 1962. The problem of negative estimates of variance components. Annals of Mathematical
Statistics 33: 273289.
Verbeke, G., and G. Molenberghs. 2000. Linear Mixed Models for Longitudinal Data. New York: Springer.
West, B. T., K. B. Welch, and A. T. Galecki. 2007. Linear Mixed Models: A Practical Guide Using Statistical
Software. Boca Raton, FL: Chapman & Hall/CRC.
Wiggins, V. L. 2011. Multilevel random effects in xtmixed and semthe long and wide of it. The Stata Blog: Not
Elsewhere Classified.
http://blog.stata.com/2011/09/28/multilevel-random-effects-in-xtmixed-and-sem-the-long-and-wide-of-it/.

mixed Multilevel mixed-effects linear regression

Also see
[ME] mixed postestimation Postestimation tools for mixed
[ME] me Introduction to multilevel mixed-effects models
[MI] estimation Estimation commands for use with mi estimate
[SEM] intro 5 Tour of models (Multilevel mixed-effects models)
[XT] xtrc Random-coefficients model
[XT] xtreg Fixed-, between-, and random-effects and population-averaged linear models
[U] 20 Estimation and postestimation commands

335

Title
mixed postestimation Postestimation tools for mixed
Description
Options for predict
Option for estat icc
Remarks and examples
References

Syntax for predict


Syntax for estat
Options for estat recovariance
Stored results
Also see

Menu for predict


Menu for estat
Options for estat wcorrelation
Methods and formulas

Description
The following postestimation commands are of special interest after mixed:
Command

Description

estat
estat
estat
estat

summarize the composition of the nested groups


estimate intraclass correlations
display the estimated random-effects covariance matrix (or matrices)
display model-implied within-cluster correlations and standard deviations

group
icc
recovariance
wcorrelation

The following standard postestimation commands are also available:


Command

Description

contrast
estat ic
estat summarize
estat vce
estimates
lincom

contrasts and ANOVA-style joint tests of estimates


Akaikes and Schwarzs Bayesian information criteria (AIC and BIC)
summary statistics for the estimation sample
variancecovariance matrix of the estimators (VCE)
cataloging estimation results
point estimates, standard errors, testing, and inference for linear
combinations of coefficients
likelihood-ratio test
marginal means, predictive margins, marginal effects, and average marginal
effects
graph the results from margins (profile plots, interaction plots, etc.)
point estimates, standard errors, testing, and inference for nonlinear
combinations of coefficients
predictions, residuals, influence statistics, and other diagnostic measures
point estimates, standard errors, testing, and inference for generalized
predictions
pairwise comparisons of estimates
Wald tests of simple and composite linear hypotheses
Wald tests of nonlinear hypotheses

lrtest
margins
marginsplot
nlcom
predict
predictnl
pwcompare
test
testnl

336

mixed postestimation Postestimation tools for mixed

337

Special-interest postestimation commands


estat group reports the number of groups and minimum, average, and maximum group sizes
for each level of the model. Model levels are identified by the corresponding group variable in the
data. Because groups are treated as nested, the information in this summary may differ from what
you would get if you used the tabulate command on each group variable individually.
estat icc displays the intraclass correlation for pairs of responses at each nested level of the model.
Intraclass correlations are available for random-intercept models or for random-coefficient models
conditional on random-effects covariates being equal to 0. They are not available for crossed-effects
models or with residual error structures other than independent structures.
estat recovariance displays the estimated variancecovariance matrix of the random effects
for each level in the model. Random effects can be either random intercepts, in which case the
corresponding rows and columns of the matrix are labeled as cons, or random coefficients, in which
case the label is the name of the associated variable in the data.
estat wcorrelation displays the overall correlation matrix for a given cluster calculated on the
basis of the design of the random effects and their assumed covariance and the correlation structure
of the residuals. This allows for a comparison of different multilevel models in terms of the ultimate
within-cluster correlation matrix that each model implies.

Syntax for predict


Syntax for obtaining BLUPs of random effects, or the BLUPs standard errors
predict

type

stub* | newvarlist

if

in ,

reffects | reses

relevel(levelvar)
Syntax for obtaining scores after ML estimation
predict

type

stub* | newvarlist

if

in , scores

Syntax for obtaining other predictions


predict
statistic

type

newvar

if

in

, statistic relevel(levelvar)

Description

Main

xb
stdp
fitted

residuals
rstandard

linear prediction for the fixed portion of the model only; the default
standard error of the fixed-portion linear prediction
fitted values, fixed-portion linear prediction plus contributions based on
predicted random effects
residuals, response minus fitted values
standardized residuals

Unstarred statistics are available both in and out of sample; type predict . . . if e(sample) . . . if wanted
only for the estimation sample. Starred statistics are calculated only for the estimation sample, even when
if e(sample) is not specified.

338

mixed postestimation Postestimation tools for mixed

Menu for predict


Statistics

>

Postestimation

>

Predictions, residuals, etc.

Options for predict

Main

xb, the default, calculates the linear prediction x based on the estimated fixed effects (coefficients)
in the model. This is equivalent to fixing all random effects in the model to their theoretical mean
value of 0.
stdp calculates the standard error of the linear predictor x.
reffects calculates best linear unbiased predictions (BLUPs) of the random effects. By default, BLUPs
for all random effects in the model are calculated. However, if the relevel(levelvar) option is
specified, then BLUPs for only level levelvar in the model are calculated. For example, if classes
are nested within schools, then typing
. predict b*, reffects relevel(school)
would produce BLUPs at the school level. You must specify q new variables, where q is the number
of random-effects terms in the model (or level). However, it is much easier to just specify stub*
and let Stata name the variables stub1, stub2, . . . , stubq for you.
reses calculates the standard errors of the best linear unbiased predictions (BLUPs) of the random
effects. By default, standard errors for all BLUPs in the model are calculated. However, if the
relevel(levelvar) option is specified, then standard errors for only level levelvar in the model
are calculated; see the reffects option. You must specify q new variables, where q is the number
of random-effects terms in the model (or level). However, it is much easier to just specify stub*
and let Stata name the variables stub1, stub2, . . . , stubq for you.
The reffects and reses options often generate multiple new variables at once. When this occurs,
the random effects (or standard errors) contained in the generated variables correspond to the order
in which the variance components are listed in the output of mixed. Still, examining the variable
labels of the generated variables (with the describe command, for instance) can be useful in
deciphering which variables correspond to which terms in the model.
fitted calculates fitted values, which are equal to the fixed-portion linear predictor plus contributions
based on predicted random effects, or in mixed-model notation, x+Zu. By default, the fitted values
take into account random effects from all levels in the model; however, if the relevel(levelvar)
option is specified, then the fitted values are fit beginning with the topmost level down to and
including level levelvar. For example, if classes are nested within schools, then typing
. predict yhat_school, fitted relevel(school)
would produce school-level predictions. That is, the predictions would incorporate school-specific
random effects but not those for each class nested within each school.
residuals calculates residuals, equal to the responses minus fitted values. By default, the fitted values
take into account random effects from all levels in the model; however, if the relevel(levelvar)
option is specified, then the fitted values are fit beginning at the topmost level down to and including
level levelvar.
rstandard calculates standardized residuals, equal to the residuals multiplied by the inverse square
root of the estimated error covariance matrix.

mixed postestimation Postestimation tools for mixed

339

scores calculates the parameter-level scores, one for each parameter in the model including regression
coefficients and variance components. The score for a parameter is the first derivative of the log
likelihood (or log pseudolikelihood) with respect to that parameter. One score per highest-level
group is calculated, and it is placed on the last record within that group. Scores are calculated in
the estimation metric as stored in e(b).
scores is not available after restricted maximum-likelihood (REML) estimation.
relevel(levelvar) specifies the level in the model at which predictions involving random effects are
to be obtained; see the options above for the specifics. levelvar is the name of the model level
and is either the name of the variable describing the grouping at that level or is all, a special
designation for a group comprising all the estimation data.

Syntax for estat


Summarize the composition of the nested groups
estat group
Estimate intraclass correlations
estat icc

, level(#)

Display the estimated random-effects covariance matrix (or matrices)


estat recovariance

, relevel(levelvar) correlation matlist options

Display model-implied within-cluster correlations and standard deviations


estat wcorrelation

, wcor options

wcor options

Description

at(at spec)

specify the cluster for which you want the correlation matrix; default
is the first two-level cluster encountered in the data
display correlation matrix for all the data
display the covariance matrix instead of the correlation matrix
list the data corresponding to the correlation matrix
list the rows and columns of the correlation matrix in the order they
were originally present in the data
set the display format; default is format(%6.3f)
style and formatting options that control how matrices are displayed

all
covariance
list
nosort
format(% fmt)
matlist options

Menu for estat


Statistics

>

Postestimation

>

Reports and statistics

340

mixed postestimation Postestimation tools for mixed

Option for estat icc


level(#) specifies the confidence level, as a percentage, for confidence intervals. The default is
level(95) or as set by set level; see [U] 20.7 Specifying the width of confidence intervals.

Options for estat recovariance


relevel(levelvar) specifies the level in the model for which the random-effects covariance matrix
is to be displayed. By default, the covariance matrices for all levels in the model are displayed.
levelvar is the name of the model level and is either the name of the variable describing the
grouping at that level or is all, a special designation for a group comprising all the estimation
data.
correlation displays the covariance matrix as a correlation matrix.
matlist options are style and formatting options that control how the matrix (or matrices) is displayed;
see [P] matlist for a list of what is available.

Options for estat wcorrelation


at(at spec) specifies the cluster of observations for which you want the within-cluster correlation
matrix. at spec is
relevel var = value , relevel var = value . . .
For example, if you specify
. estat wcorrelation, at(school = 33)
you get the within-cluster correlation matrix for those observations in school 33. If you specify
. estat wcorrelation, at(school = 33 classroom = 4)
you get the correlation matrix for classroom 4 in school 33.
If at() is not specified, then you get the correlations for the first level-two cluster encountered
in the data. This is usually what you want.
all specifies that you want the correlation matrix for all the data. This is not recommended unless
you have a relatively small dataset or you enjoy seeing large N N matrices. However, this can
prove useful in some cases.
covariance specifies that the within-cluster covariance matrix be displayed instead of the default
correlations and standard deviations.
list lists the model data for those observations depicted in the displayed correlation matrix. This
option is useful if you have many random-effects design variables and you wish to see the
represented values of these design variables.
nosort lists the rows and columns of the correlation matrix in the order that they were originally
present in the data. Normally, estat wcorrelation will first sort the data according to level
variables, by-group variables, and time variables to produce correlation matrices whose rows and
columns follow a natural ordering. nosort suppresses this.
format(% fmt) sets the display format for the standard-deviation vector and correlation matrix. The
default is format(%6.3f).
matlist options are style and formatting options that control how the matrix (or matrices) is displayed;
see [P] matlist for a list of what is available.

mixed postestimation Postestimation tools for mixed

341

Remarks and examples


Various predictions, statistics, and diagnostic measures are available after fitting a mixed model
using mixed. For the most part, calculation centers around obtaining BLUPs of the random effects.
Random effects are not estimated when the model is fit but instead need to be predicted after
estimation. Calculation of intraclass correlations, estimating the dependence between responses for
different levels of nesting, may also be of interest.

Example 1
In example 3 of [ME] mixed, we modeled the weights of 48 pigs measured on nine successive
weeks as
weightij = 0 + 1 weekij + u0j + u1j weekij + ij
(1)
for i = 1, . . . , 9, j = 1, . . . , 48,
and variancecovariance matrix

N (0, 2 ), and u0j and u1j normally distributed with mean 0

ij

= Var

u0j
u1j

2
u0
01

01
2
u1

. use http://www.stata-press.com/data/r13/pig
(Longitudinal analysis of pig weights)
. mixed weight week || id: week, covariance(unstructured)
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log likelihood = -868.96185
Iteration 1:
log likelihood = -868.96185
Computing standard errors:
Mixed-effects ML regression
Number of obs
Group variable: id
Number of groups
Obs per group: min
avg
max
Wald chi2(1)
Prob > chi2

Log likelihood = -868.96185


weight

Coef.

week
_cons

6.209896
19.35561

Std. Err.
.0910745
.3996387

Random-effects Parameters

z
68.18
48.43

=
=
=
=
=

432
48
9
9.0
9

=
=

4649.17
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

6.031393
18.57234

6.388399
20.13889

Estimate

Std. Err.

[95% Conf. Interval]

var(week)
var(_cons)
cov(week,_cons)

.3715251
6.823363
-.0984378

.0812958
1.566194
.2545767

.2419532
4.351297
-.5973991

.570486
10.69986
.4005234

var(Residual)

1.596829

.123198

1.372735

1.857505

id: Unstructured

LR test vs. linear regression:


chi2(3) =
764.58
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

Rather than see the estimated variance components listed as variance and covariances as above, we
can instead see them as correlations and standard deviations in matrix form; that is, we can see as
a correlation matrix:

342

mixed postestimation Postestimation tools for mixed


. estat recovariance, correlation
Random-effects correlation matrix for level id

week
_cons

week

_cons

1
-.0618257

We can use estat wcorrelation to display the within-cluster marginal standard deviations and
correlations for one of the clusters.
. estat wcorrelation, format(%4.2g)
Standard deviations and correlations for id = 1:
Standard deviations:
obs

sd

2.9

3.1

3.3

3.7

4.1

4.5

5.5

6.1

obs

1
2
3
4
5
6
7
8
9

1
.8
.77
.72
.67
.63
.59
.55
.52

1
.83
.81
.78
.75
.72
.69
.66

1
.86
.85
.83
.81
.79
.77

1
.89
.88
.87
.86
.85

1
.91
.91
.9
.89

1
.93
.93
.92

1
.94
.94

1
.95

Correlations:

Because within-cluster correlations can vary between clusters, estat wcorrelation by default
displays the results for the first cluster. In this example, each cluster (pig) has the same number
of observations, and the timings of measurements (week) are the same between clusters. Thus the
within-cluster correlations are the same for all the clusters. In example 4, we fit a model where
different clusters have different within-cluster correlations and show how to display these correlations.
We can also obtain BLUPs of the pig-level random effects (u0j and u1j ). We need to specify
the variables to be created in the order u1 u0 because that is the order in which the corresponding
variance components are listed in the output (week cons). We obtain the predictions and list them
for the first 10 pigs.
. predict u1 u0, reffects
. by id, sort: generate tolist = (_n==1)
. list id u0 u1 if id <=10 & tolist
id

u0

u1

1.
10.
19.
28.
37.

1
2
3
4
5

.2369444
-1.584127
-3.526551
1.964378
1.299236

-.3957636
.510038
.3200372
-.7719702
-.9241479

46.
55.
64.
73.
82.

6
7
8
9
10

-1.147302
-2.590529
-1.137067
-3.189545
1.160324

-.5448151
.0394454
-.1696566
-.7365507
.0030772

mixed postestimation Postestimation tools for mixed

343

If you forget how to order your variables in predict, or if you use predict stub*, remember
that predict labels the generated variables for you to avoid confusion.
. describe u0 u1
storage
variable name
type

display
format

u0
u1

%9.0g
%9.0g

float
float

value
label

variable label
BLUP r.e. for id: _cons
BLUP r.e. for id: week

Examining (1), we see that within each pig, the successive weight measurements are modeled as
simple linear regression with intercept 0 + uj0 and slope 1 + uj1 . We can generate estimates of
the pig-level intercepts and slopes with
. generate intercept = _b[_cons] + u0
. generate slope = _b[week] + u1
. list id intercept slope if id<=10 & tolist
id

interc~t

slope

1.
10.
19.
28.
37.

1
2
3
4
5

19.59256
17.77149
15.82906
21.31999
20.65485

5.814132
6.719934
6.529933
5.437926
5.285748

46.
55.
64.
73.
82.

6
7
8
9
10

18.20831
16.76509
18.21855
16.16607
20.51594

5.665081
6.249341
6.040239
5.473345
6.212973

Thus we can plot estimated regression lines for each of the pigs. Equivalently, we can just plot
the fitted values because they are based on both the fixed and the random effects:

20

Fitted values: xb + Zu
40
60

80

. predict fitweight, fitted


. twoway connected fitweight week if id<=10, connect(L)

10

week

We can also generate standardized residuals and see whether they follow a standard normal
distribution, as they should in any good-fitting model:

344

mixed postestimation Postestimation tools for mixed


. predict rs, rstandard
. summarize rs
Obs
Variable
rs

Mean

432

1.01e-09

Std. Dev.
.8929356

Min

Max

-3.621446

3.000929

Standardized residuals
2
0
2

. qnorm rs

0
Inverse Normal

Example 2
Following Rabe-Hesketh and Skrondal (2012, chap. 2), we fit a two-level random-effects model
for human peak-expiratory-flow rate. The subjects were each measured twice with the Mini-Wright
peak-flow meter. It is of interest to determine how reliable the meter is as a measurement device. The
intraclass correlation provides a measure of reliability. Formally, in a two-level random-effects model,
the intraclass correlation corresponds to the correlation of measurements within the same individual
and also to the proportion of variance explained by the individual random effect.

mixed postestimation Postestimation tools for mixed

345

First, we fit the two-level model with mixed:


. use http://www.stata-press.com/data/r13/pefrate, clear
(Peak-expiratory-flow rate)
. mixed wm || id:
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
Iteration 1:

log likelihood = -184.57839


log likelihood = -184.57839

Computing standard errors:


Mixed-effects ML regression
Group variable: id

Number of obs
Number of groups

Coef.

_cons

453.9118

34
17

Obs per group: min =


avg =
max =

2
2.0
2

Wald chi2(0)
Prob > chi2

Log likelihood = -184.57839


wm

=
=

Std. Err.
26.18617

Random-effects Parameters

z
17.33

=
=

.
.

P>|z|

[95% Conf. Interval]

0.000

402.5878

505.2357

Estimate

Std. Err.

[95% Conf. Interval]

var(_cons)

11458.94

3998.952

5782.176

22708.98

var(Residual)

396.441

135.9781

202.4039

776.4942

id: Identity

LR test vs. linear regression: chibar2(01) =

46.27 Prob >= chibar2 = 0.0000

Now we use estat icc to estimate the intraclass correlation:


. estat icc
Intraclass correlation
Level

ICC

id

.9665602

Std. Err.

[95% Conf. Interval]

.0159495

.9165853

.9870185

This correlation is close to 1, indicating that the Mini-Wright peak-flow meter is reliable. But
as noted by Rabe-Hesketh and Skrondal (2012), the reliability is not only a characteristic of the
instrument but also of the between-subject variance. Here we see that the between-subject standard
deviation, sd( cons), is much larger than the within-subject standard deviation, sd(Residual).
In the presence of fixed-effects covariates, estat icc reports the residual intraclass correlation,
the correlation between measurements conditional on the fixed-effects covariates. This is equivalent
to the correlation of the model residuals.
In the presence of random-effects covariates, the intraclass correlation is no longer constant and
depends on the values of the random-effects covariates. In this case, estat icc reports conditional
intraclass correlations assuming 0 values for all random-effects covariates. For example, in a two-level
model, this conditional correlation represents the correlation of the residuals for two measurements on
the same subject, which both have random-effects covariates equal to 0. Similarly to the interpretation
of intercept variances in random-coefficient models (Rabe-Hesketh and Skrondal 2012, chap. 4),

346

mixed postestimation Postestimation tools for mixed

interpretation of this conditional intraclass correlation relies on the usefulness of the 0 baseline values
of random-effects covariates. For example, mean centering of the covariates is often used to make a
0 value a useful reference.

Example 3
In example 4 of [ME] mixed, we estimated a CobbDouglas production function with random
intercepts at the region level and at the state-within-region level:
(3)

(2)

yjk = Xjk + uk + ujk +

jk

. use http://www.stata-press.com/data/r13/productivity
(Public Capital Productivity)
. mixed gsp private emp hwy water other unemp || region: || state:
(output omitted )

We can use estat group to see how the data are broken down by state and region:
. estat group

Group Variable

No. of
Groups

region
state

9
48

Observations per Group


Minimum
Average
Maximum
51
17

90.7
17.0

136
17

We are reminded that we have balanced productivity data for 17 years for each state.
We can use predict, fitted to get the fitted values
(3)

(2)

yjk = Xjk + uk + ujk


but if we instead want fitted values at the region level, that is,
(3)

yjk = Xjk + uk
we need to use the relevel() option:
. predict gsp_region, fitted relevel(region)
. list gsp gsp_region in 1/10
gsp

gsp_re~n

1.
2.
3.
4.
5.

10.25478
10.2879
10.35147
10.41721
10.42671

10.40529
10.42336
10.47343
10.52648
10.54947

6.
7.
8.
9.
10.

10.4224
10.4847
10.53111
10.59573
10.62082

10.53537
10.60781
10.64727
10.70503
10.72794

mixed postestimation Postestimation tools for mixed

347

Technical note
Out-of-sample predictions are permitted after mixed, but if these predictions involve BLUPs of
random effects, the integrity of the estimation data must be preserved. If the estimation data have
changed since the mixed model was fit, predict will be unable to obtain predicted random effects that
are appropriate for the fitted model and will give an error. Thus to obtain out-of-sample predictions
that contain random-effects terms, be sure that the data for these predictions are in observations that
augment the estimation data.

We can use estat icc to estimate residual intraclass correlations between productivity years in
the same region and in the same state and region.
. estat icc
Residual intraclass correlation
Level

ICC

region
state|region

.159893
.8516265

Std. Err.

[95% Conf. Interval]

.127627
.0301733

.0287143
.7823466

.5506202
.9016272

estat icc reports two intraclass correlations for this three-level nested model. The first is the
level-3 intraclass correlation at the region level, the correlation between productivity years in the same
region. The second is the level-2 intraclass correlation at the state-within-region level, the correlation
between productivity years in the same state and region.
Conditional on the fixed-effects covariates, we find that annual productivity is only slightly correlated
within the same region, but it is highly correlated within the same state and region. We estimate that
state and region random effects compose approximately 85% of the total residual variance.

Example 4
In example 1, we fit a model where each cluster had the same model-implied within-cluster
correlations. Here we fit a model where different clusters have different within-cluster correlations,
and we show how to display them for different clusters. We use the Asian children weight data from
example 6 of [ME] mixed.

348

mixed postestimation Postestimation tools for mixed


. use http://www.stata-press.com/data/r13/childweight, clear
(Weight data on Asian children)
. mixed weight age || id: age, covariance(unstructured)
Performing EM optimization:
Performing gradient-based optimization:
Iteration 0:
log likelihood = -344.37065
Iteration 1:
log likelihood = -342.83973
Iteration 2:
log likelihood = -342.71863
Iteration 3:
log likelihood = -342.71777
Iteration 4:
log likelihood = -342.71777
Computing standard errors:
Mixed-effects ML regression
Group variable: id

Log likelihood = -342.71777


weight

Coef.

age
_cons

3.459671
5.110496

Std. Err.
.1258877
.1494781

Random-effects Parameters

z
27.48
34.19

Number of obs
Number of groups
Obs per group: min
avg
max

=
=
=
=
=

198
68
1
2.9
5

Wald chi2(1)
Prob > chi2

=
=

755.27
0.0000

P>|z|

[95% Conf. Interval]

0.000
0.000

3.212936
4.817524

3.706406
5.403468

Estimate

Std. Err.

[95% Conf. Interval]

var(age)
var(_cons)
cov(age,_cons)

.2023917
.0970274
.140134

.1242867
.1107994
.0566901

.0607405
.0103484
.0290235

.6743834
.9097357
.2512445

var(Residual)

1.357922

.1650514

1.070074

1.723201

id: Unstructured

LR test vs. linear regression:


chi2(3) =
27.38
Prob > chi2 = 0.0000
Note: LR test is conservative and provided only for reference.

mixed postestimation Postestimation tools for mixed

349

We use estat wcorrelation to display the within-cluster correlations for the first cluster.
. estat wcorrelation, list
Standard deviations and correlations for id = 45:
Standard deviations:
obs
1
2
3
4

sd
Correlations:
obs
1
2
3
4
5

1.224

1.314

1.448

1.506

1.771

1.000
0.141
0.181
0.193
0.230

1.000
0.274
0.293
0.348

1.000
0.376
0.447

1.000
0.477

1.000

Data:

1.
2.
3.
4.
5.

id

weight

age

45
45
45
45
45

5.171
10.86
13.15
13.2
15.88

.136893
.657084
1.21834
1.42916
2.27242

We specified the list option to display the data associated with the cluster. The next cluster in
the dataset has ID 258. To display the within-cluster correlations for this cluster, we specify the at()
option.
. estat wcorrelation, at(id=258) list
Standard deviations and correlations for id = 258:
Standard deviations:
1
2
3
4
obs
sd
Correlations:
obs
1
2
3
4

1.231

1.320

1.424

1.782

1.000
0.152
0.186
0.244

1.000
0.270
0.356

1.000
0.435

1.000

Data:

1.
2.
3.
4.

id

weight

age

258
258
258
258

5.3
9.74
9.98
11.34

.19165
.687201
1.12799
2.30527

The within-cluster correlations for this model depend on age. The values for age in the two clusters
are different, as are the corresponding within-cluster correlations.

350

mixed postestimation Postestimation tools for mixed

Stored results
estat icc stores the following in r():
Scalars
r(icc#)
r(se#)
r(level)

level-# intraclass correlation


standard errors of level-# intraclass correlation
confidence level of confidence intervals

Macros
r(label#)

label for level #

Matrices
r(ci#)

vector of confidence intervals (lower and upper) for level-# intraclass correlation

For a G-level nested model, # can be any integer between 2 and G.


estat recovariance stores the following in r():
Scalars
r(relevels)

number of levels

Matrices
r(Cov#)
r(Corr#)

level-# random-effects covariance matrix


level-# random-effects correlation matrix (if option correlation was specified)

For a G-level nested model, # can be any integer between 2 and G.


estat wcorrelation stores the following in r():
Matrices
r(sd)
r(Corr)
r(Cov)
r(G)
r(Z)
r(R)

standard deviations
within-cluster correlation matrix
within-cluster variancecovariance matrix
variancecovariance matrix of random effects
model-based design matrix
variancecovariance matrix of level-one errors

Methods and formulas


Methods and formulas are presented under the following headings:
Prediction
Intraclass correlations
Within-cluster covariance matrix

Prediction
Following the notation defined throughout [ME] mixed, BLUPs of random effects u are obtained as

u = GZ V1 y X
where G and V are G and V = ZGZ + 2 R with maximum likelihood (ML) or REML estimates of
the variance components plugged in. Standard errors for BLUPs are calculated based on the iterative
technique of Bates and Pinheiro (1998, sec. 3.3) for estimating the BLUPs themselves. If estimation
is done by REML, these standard errors account for uncertainty in the estimate of , while for ML
the standard errors treat as known. As such, standard errors of REML-based BLUPs will usually be
larger.

mixed postestimation Postestimation tools for mixed

Fitted values are given by X + Zu, residuals as


as

351

= y X Zu, and standardized residuals

= 1 R1/2

If the relevel(levelvar) option is specified, fitted values, residuals, and standardized residuals
consider only those random-effects terms up to and including level levelvar in the model.
For details concerning the calculation of scores, see Methods and formulas in [ME] mixed.

Intraclass correlations
Consider a simple, two-level random-intercept model,
(2)

(1)
ij

yij = + uj +

for measurements i = 1, . . . , nj and level-2 groups j = 1, . . . , M , where yij is a response, is an


(1)
unknown fixed intercept, uj is a level-2 random intercept, and ij is a level-1 error term. Errors are
assumed to be normally distributed with mean 0 and variance 12 ; random intercepts are assumed to
be normally distributed with mean 0 and variance 22 and to be independent of error terms.
The intraclass correlation for this model is

= Corr(yij , yi j ) =

12

22
+ 22

It corresponds to the correlation between measurements i and i from the same group j .
Now consider a three-level nested random-intercept model,
(2)

(3)

yijk = + ujk + uk +

(1)
ijk

for measurements i = 1, . . . , njk and level-2 groups j = 1, . . . , M1k nested within level-3 groups
(2)
(3)
(1)
k = 1, . . . , M2 . Here ujk is a level-2 random intercept, uk is a level-3 random intercept, and ijk
is a level-1 error term. The error terms and random intercepts are assumed to be normally distributed
with mean 0 and variances 12 , 22 , and 32 , respectively, and to be mutually independent.
We can consider two types of intraclass correlations for this model. We will refer to them as
level-2 and level-3 intraclass correlations. The level-3 intraclass correlation is

(3) = Corr(yijk , yi j k ) =

32
12 + 22 + 32

This is the correlation between measurements i and i from the same level-3 group k and from
different level-2 groups j and j .
The level-2 intraclass correlation is

(2) = Corr(yijk , yi jk ) =

12

22 + 32
+ 22 + 32

This is the correlation between measurements i and i from the same level-3 group k and level-2
group j . (Note that level-1 intraclass correlation is undefined.)

352

mixed postestimation Postestimation tools for mixed

More generally, for a G-level nested random-intercept model, the g -level intraclass correlation is
defined as
G
2
l=g l
(g)
= G
2
l=1 l
The above formulas also apply in the presence of fixed-effects covariates X in a randomeffects model. In this case, intraclass correlations are conditional on fixed-effects covariates and are
referred to as residual intraclass correlations. estat icc also uses the same formulas to compute
intraclass correlations for random-coefficient models, assuming 0 baseline values for the randomeffects covariates, and labels them as conditional intraclass correlations. The above formulas assume
independent residual structures.
Intraclass correlations are estimated using the delta method and will always fall in (0,1) because
variance components are nonnegative. To accommodate the range of an intraclass correlation, we use
the logit transformation to obtain confidence intervals.
Let (g) be a point estimate of the intraclass correlation and SE((g) ) be its standard error. The
(1 ) 100% confidence interval for logit((g) ) is
logit((g) ) z/2

SE((g) )

(g) (1 (g) )

where z/2 is the 1 /2 quantile of the standard normal distribution and logit(x) = ln{x/(1 x)}.
Let ku be the upper endpoint of this interval, and let kl be the lower. The (1 ) 100% confidence
interval for (g) is then given by
1
1
,
k
l
1+e
1 + eku

Within-cluster covariance matrix


A two-level linear mixed model of the form

yj = Xj + Zj uj +
implies the marginal model

y j = Xj +

where j N (0, Vj ), Vj = Zj GZj + R. In a marginal model, the random part is described in


terms of the marginal or total residuals j , and Vj is the covariance structure of these residuals.
estat wcorrelation calculates the marginal covariance matrix Vj for cluster j and by default
displays the results in terms of standard deviations and correlations. This allows for a comparison of
different multilevel models in terms of the ultimate within-cluster correlation matrix that each model
implies.
Calculation of the marginal covariance matrix extends naturally to higher-level models; see, for
example, chapter 4.8 in West, Welch, and Galecki (2007).

mixed postestimation Postestimation tools for mixed

353

References
Bates, D. M., and J. C. Pinheiro. 1998. Computational methods for multilevel modelling. In Technical Memorandum
BL0112140-980226-01TM. Murray Hill, NJ: Bell Labs, Lucent Technologies.
http://stat.bell-labs.com/NLME/CompMulti.pdf.
Rabe-Hesketh, S., and A. Skrondal. 2012. Multilevel and Longitudinal Modeling Using Stata. 3rd ed. College Station,
TX: Stata Press.
West, B. T., K. B. Welch, and A. T. Galecki. 2007. Linear Mixed Models: A Practical Guide Using Statistical
Software. Boca Raton, FL: Chapman & Hall/CRC.

Also see
[ME] mixed Multilevel mixed-effects linear regression
[U] 20 Estimation and postestimation commands

Glossary
BLUPs. BLUPs are best linear unbiased predictions of either random effects or linear combinations of
random effects. In linear models containing random effects, these effects are not estimated directly
but instead are integrated out of the estimation. Once the fixed effects and variance components
have been estimated, you can use these estimates to predict group-specific random effects. These
predictions are called BLUPs because they are unbiased and have minimal mean squared errors
among all linear functions of the response.
canonical link. Corresponding to each family of distributions in a generalized linear model (GLM)
is a canonical link function for which there is a sufficient statistic with the same dimension as
the number of parameters in the linear predictor. The use of canonical link functions provides the
GLM with desirable statistical properties, especially when the sample size is small.
conditional overdispersion. In a negative binomial mixed-effects model, conditional overdispersion
is overdispersion conditional on random effects. Also see overdispersion.
covariance structure. In a mixed-effects model, covariance structure refers to the variancecovariance
structure of the random effects.
crossed-effects model. A crossed-effects model is a mixed-effects model in which the levels of
random effects are not nested. A simple crossed-effects model for cross-sectional time-series data
would contain a random effect to control for panel-specific variation and a second random effect
to control for time-specific random variation. Rather than being nested within panel, in this model
a random effect due to a given time is the same for all panels.
crossed-random effects. See crossed-effects model.
EB. See empirical Bayes.
empirical Bayes. In generalized linear mixed-effects models, empirical Bayes refers to the method
of prediction of the random effects after the model parameters have been estimated. The empirical
Bayes method uses Bayesian principles to obtain the posterior distribution of the random effects,
but instead of assuming a prior distribution for the model parameters, the parameters are treated
as given.
empirical Bayes mean. See posterior mean.
empirical Bayes mode. See posterior mode.
fixed effects. In the context of multilevel mixed-effects models, fixed effects represent effects that
are constant for all groups at any level of nesting. In the ANOVA literature, fixed effects represent
the levels of a factor for which the inference is restricted to only the specific levels observed in
the study. See also fixed-effects model in [XT] Glossary.
GaussHermite quadrature. In the context of generalized linear mixed models, GaussHermite
quadrature is a method of approximating the integral used in the calculation of the log likelihood.
The quadrature locations and weights for individual clusters are fixed during the optimization
process.
generalized linear mixed-effects model. A generalized linear mixed-effect model is an extension of
a generalized linear model allowing for the inclusion of random deviations (effects).
generalized linear model. The generalized linear model is an estimation framework in which the
user specifies a distributional family for the dependent variable and a link function that relates the
dependent variable to a linear combination of the regressors. The distribution must be a member of
355

356

Glossary

the exponential family of distributions. The generalized linear model encompasses many common
models, including linear, probit, and Poisson regression.
GHQ. See GaussHermite quadrature.
GLM. See generalized linear model.
GLME model. See generalized linear mixed-effects model.
GLMM. Generalized linear mixed model. See generalized linear mixed-effects model.
hierarchical model. A hierarchical model is one in which successively more narrowly defined groups
are nested within larger groups. For example, in a hierarchical model, patients may be nested
within doctors who are in turn nested within the hospital at which they practice.
intraclass correlation. In the context of mixed-effects models, intraclass correlation refers to the
correlation for pairs of responses at each nested level of the model.
Laplacian approximation. Laplacian approximation is a technique used to approximate definite
integrals without resorting to quadrature methods. In the context of mixed-effects models, Laplacian
approximation is as a rule faster than quadrature methods at the cost of producing biased parameter
estimates of variance components.
linear mixed model. See linear mixed-effects model.
linear mixed-effects model. A linear mixed-effects model is an extension of a linear model allowing
for the inclusion of random deviations (effects).
link function. In a generalized linear model or a generalized linear mixed-effects model, the link
function relates a linear combination of predictors to the expected value of the dependent variable.
In a linear regression model, the link function is simply the identity function.
LME model. See linear mixed-effects model.
MCAGH. See mode-curvature adaptive GaussHermite quadrature.
meanvariance adaptive GaussHermite quadrature. In the context of generalized linear mixed
models, meanvariance adaptive GaussHermite quadrature is a method of approximating the
integral used in the calculation of the log likelihood. The quadrature locations and weights for
individual clusters are updated during the optimization process by using the posterior mean and
the posterior standard deviation.
mixed model. See mixed-effects model.
mixed-effects model. A mixed-effects model contains both fixed and random effects. The fixed effects
are estimated directly, whereas the random effects are summarized according to their (co)variances.
Mixed-effects models are used primarily to perform estimation and inference on the regression
coefficients in the presence of complicated within-subject correlation structures induced by multiple
levels of grouping.
mode-curvature adaptive GaussHermite quadrature. In the context of generalized linear mixed
models, mode-curvature adaptive GaussHermite quadrature is a method of approximating the
integral used in the calculation of the log likelihood. The quadrature locations and weights for
individual clusters are updated during the optimization process by using the posterior mode and
the standard deviation of the normal density that approximates the log posterior at the mode.
MVAGH. See meanvariance adaptive GaussHermite quadrature.
nested random effects. In the context of mixed-effects models, nested random effects refer to the
nested grouping factors for the random effects. For example, we may have data on students who
are nested in classes that are nested in schools.

Glossary

357

one-level model. A one-level model has no multilevel structure and no random effects. Linear
regression is a one-level model.
overdispersion. In count-data models, overdispersion occurs when there is more variation in the data
than would be expected if the process were Poisson.
posterior mean. In generalized linear mixed-effects models, posterior mean refer to the predictions
of random effects based on the mean of the posterior distribution.
posterior mode. In generalized linear mixed-effects models, posterior mode refer to the predictions
of random effects based on the mode of the posterior distribution.
QR decomposition. QR decomposition is an orthogonal-triangular decomposition of an augmented
data matrix that speeds up the calculation of the log likelihood; see Methods and formulas in
[ME] mixed for more details.
quadrature. Quadrature is a set of numerical methods to evaluate a definite integral.
random coefficient. In the context of mixed-effects models, a random coefficient is a counterpart to
a slope in the fixed-effects equation. You can think of a random coefficient as a randomly varying
slope at a specific level of nesting.
random effects. In the context of mixed-effects models, random effects represent effects that may
vary from group to group at any level of nesting. In the ANOVA literature, random effects represent
the levels of a factor for which the inference can be generalized to the underlying population
represented by the levels observed in the study. See also random-effects model in [XT] Glossary.
random intercept. In the context of mixed-effects models, a random intercept is a counterpart to the
intercept in the fixed-effects equation. You can think of a random intercept as a randomly varying
intercept at a specific level of nesting.
REML. See restricted maximum likelihood.
restricted maximum likelihood. Restricted maximum likelihood is a method of fitting linear mixedeffects models that involves transforming out the fixed effects to focus solely on variancecomponent
estimation.
three-level model. A three-level mixed-effects model has one level of observations and two levels of
grouping. Suppose that you have a dataset consisting of patients overseen by doctors at hospitals,
and each doctor practices at one hospital. Then a three-level model would contain a set of random
effects to control for hospital-specific variation, a second set of random effects to control for
doctor-specific random variation within a hospital, and a random-error term to control for patients
random variation.
two-level model. A two-level mixed-effects model has one level of observations and one level of
grouping. Suppose that you have a panel dataset consisting of patients at hospitals; a two-level
model would contain a set of random effects at the hospital level (the second level) to control for
hospital-specific random variation and a random-error term at the observation level (the first level)
to control for within-hospital variation.
variance components. In a mixed-effects model, the variance components refer to the variances and
covariances of the various random effects.

Subject and author index


This is the subject and author index for the Multilevel
Mixed-Effects Reference Manual. Readers interested in
topics other than multilevel mixed-effects should see the
combined subject index (and the combined author index)
in the Glossary and Index.

A
Abramowitz, M., [ME] meqrlogit, [ME] meqrpoisson
Agresti, A., [ME] me, [ME] meologit, [ME] meoprobit
Andrews, M. J., [ME] meglm, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
Anscombe residual, [ME] mecloglog postestimation,
[ME] meglm postestimation, [ME] melogit
postestimation, [ME] menbreg postestimation,
[ME] mepoisson postestimation, [ME] meprobit
postestimation, [ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation

B
Baltagi, B. H., [ME] mixed
Basford, K. E., [ME] me, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson
Bates, D. M., [ME] me, [ME] meglm, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed, [ME] mixed
postestimation
Bentham, G., [ME] menbreg, [ME] mepoisson,
[ME] meqrpoisson
BLUPs, [ME] me, [ME] mixed, [ME] mixed
postestimation, [ME] Glossary
Boyle, P., [ME] menbreg, [ME] mepoisson,
[ME] meqrpoisson
Brannon, B. R., [ME] me, [ME] meglm,
[ME] meologit, [ME] meoprobit
Breslow, N. E., [ME] me, [ME] meglm, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson
Bryk, A. S., [ME] me, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrpoisson, [ME] mixed

C
Cameron, A. C., [ME] meglm, [ME] mixed
Canette, I., [ME] meglm, [ME] mixed
canonical link, [ME] meglm, [ME] Glossary
Carle, A. C., [ME] mixed
Carpenter, J. R., [ME] me, [ME] meglm, [ME] melogit,
[ME] meqrlogit
Carroll, R. J., [ME] me, [ME] meglm, [ME] mixed
Carter, S. L., [ME] me, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson

359

Casella, G., [ME] me, [ME] mecloglog, [ME] meglm,


[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] mixed
Chao, E. C., [ME] me, [ME] meqrlogit,
[ME] meqrlogit postestimation,
[ME] meqrpoisson, [ME] meqrpoisson
postestimation
choice models, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] meologit, [ME] meoprobit,
[ME] meprobit, [ME] meqrlogit
Clayton, D. G., [ME] me, [ME] meglm,
[ME] mepoisson, [ME] meqrpoisson
Cleland, J., [ME] me, [ME] meglm, [ME] melogit,
[ME] meprobit, [ME] meqrlogit
cluster estimator of variance, multilevel mixedeffects models, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] mixed
complementary log-log regression, [ME] mecloglog
conditional overdispersion, [ME] menbreg,
[ME] Glossary
constrained estimation, multilevel mixedeffects, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit
correlated errors, see robust, Huber/White/sandwich
estimator of variance, multilevel mixed-effects
model
count outcome model, see outcomes, count
covariance structure, [ME] me, [ME] Glossary
crossed-effects model, [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed, [ME] Glossary

D
De Backer, M., [ME] meqrlogit postestimation
De Boeck, P., [ME] me
De Keyser, P., [ME] meqrlogit postestimation
De Vroey, C., [ME] meqrlogit postestimation
Demidenko, E., [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit, [ME] mixed
Dempster, A. P., [ME] me, [ME] mixed
deviance residual, [ME] mecloglog postestimation,
[ME] meglm postestimation, [ME] melogit
postestimation, [ME] menbreg postestimation,
[ME] mepoisson postestimation, [ME] meprobit
postestimation, [ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation
dichotomous outcome model, see outcomes, binary
Diggle, P. J., [ME] me, [ME] meglm, [ME] mixed

360 Subject and author index


Drukker, D. M., [ME] me, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson

E
EB, see empirical Bayes
empirical Bayes, [ME] mecloglog postestimation,
[ME] meglm, [ME] meglm postestimation,
[ME] melogit postestimation, [ME] menbreg
postestimation, [ME] meologit postestimation,
[ME] meoprobit postestimation,
[ME] mepoisson postestimation, [ME] meprobit
postestimation, [ME] Glossary
means, see posterior mean
modes, see posterior mode
estat
group command, [ME] mecloglog postestimation,
[ME] meglm postestimation, [ME] melogit
postestimation, [ME] menbreg postestimation,
[ME] meologit postestimation, [ME] meoprobit
postestimation, [ME] mepoisson postestimation,
[ME] meprobit postestimation, [ME] meqrlogit
postestimation, [ME] meqrpoisson
postestimation, [ME] mixed postestimation
icc command, [ME] melogit postestimation,
[ME] meprobit postestimation, [ME] meqrlogit
postestimation, [ME] mixed postestimation
recovariance command, [ME] meqrlogit
postestimation, [ME] meqrpoisson
postestimation, [ME] mixed postestimation
wcorrelation command, [ME] mixed
postestimation

Gibbons, R. D., [ME] me, [ME] mecloglog,


[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit
Ginther, O. J., [ME] mixed
Gleason, L. R., [ME] me, [ME] meglm, [ME] meologit,
[ME] meoprobit
GLME, see generalized linear mixed-effects model
GLMM, see generalized linear mixed model
Glowacz, K. M., [ME] me, [ME] meglm,
[ME] meologit, [ME] meoprobit
Goldman, N., [ME] me
Goldstein, H., [ME] me, [ME] meglm, [ME] melogit,
[ME] mepoisson, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed
Graubard, B. I., [ME] mixed
Griliches, Z., [ME] me
group, estat subcommand, [ME] mecloglog
postestimation, [ME] meglm postestimation,
[ME] melogit postestimation, [ME] menbreg
postestimation, [ME] meologit postestimation,
[ME] meoprobit postestimation,
[ME] mepoisson postestimation, [ME] meprobit
postestimation, [ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation, [ME] mixed
postestimation
Guo, G., [ME] mecloglog, [ME] melogit,
[ME] meprobit
Gutierrez, R. G., [ME] me, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson

H
F
Fitzmaurice, G. M., [ME] mixed
fixed-effects model, [ME] Glossary
multilevel mixed-effects models, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
Flay, B. R., [ME] me, [ME] meglm, [ME] meologit,
[ME] meoprobit

G
Galecki, A. T., [ME] mixed, [ME] mixed
postestimation
GaussHermite quadrature, see quadrature, Gauss
Hermite
Gavin, M. D., [ME] me, [ME] meglm, [ME] meologit,
[ME] meoprobit
Gelman, A., [ME] me
generalized
linear mixed model, [ME] me, [ME] Glossary
linear mixed-effects model, [ME] me, [ME] meglm,
[ME] Glossary
GHQ, see quadrature, GaussHermite

Hall, B. H., [ME] me


Hansen, W. B., [ME] me, [ME] meglm, [ME] meologit,
[ME] meoprobit
Harbord, R. M., [ME] melogit, [ME] meoprobit,
[ME] meqrlogit
Hardin, J. W., [ME] meglm postestimation,
[ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation
Harville, D. A., [ME] meglm, [ME] mixed
Hausman, J. A., [ME] me
Heagerty, P. J., [ME] me, [ME] meglm, [ME] mixed
Hedeker, D., [ME] me, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit
Henderson, C. R., [ME] me, [ME] mixed
Hennevogl, W., [ME] me
heteroskedasticity, robust variances, see robust,
Huber/White/sandwich estimator of variance,
multilevel mixed-effects model
hierarchical model, [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed, [ME] Glossary

Subject and author index 361


Hilbe, J. M., [ME] meglm postestimation,
[ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation
Hill, J., [ME] me
Hocking, R. R., [ME] meglm, [ME] mixed
Holmes, D. J., [ME] mixed
Horton, N. J., [ME] meglm, [ME] mixed
Huber/White/sandwich estimator of variance, see robust,
Huber/White/sandwich estimator of variance,
multilevel mixed-effects model
Huq, N. M., [ME] me, [ME] meglm, [ME] melogit,
[ME] meprobit, [ME] meqrlogit

I
icc, estat subcommand, [ME] melogit
postestimation, [ME] meprobit postestimation,
[ME] meqrlogit postestimation, [ME] mixed
postestimation
incidence-rate ratio, [ME] meglm, [ME] menbreg,
[ME] mepoisson, [ME] meqrpoisson
intraclass correlation, [ME] Glossary, also see estat
icc command
IRR, see incidence-rate ratio

J
Joe, H., [ME] melogit, [ME] meoprobit,
[ME] mepoisson, [ME] meqrlogit,
[ME] meqrpoisson
Johnson, C. A., [ME] me, [ME] meglm,
[ME] meologit, [ME] meoprobit
Jung, B. C., [ME] mixed

K
Kadane, J. B., [ME] me, [ME] meqrlogit,
[ME] meqrpoisson
Karim, M. R., [ME] meglm
Korn, E. L., [ME] mixed
Kuehl, R. O., [ME] me

L
Laird, N. M., [ME] me, [ME] meglm, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
LaMotte, L. R., [ME] me, [ME] meglm, [ME] mixed
Langford, I. H., [ME] menbreg, [ME] mepoisson,
[ME] meqrpoisson
Laplacian approximation, [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] Glossary
Lee, J. W., [ME] me
Lesaffre, E., [ME] me, [ME] meqrlogit postestimation

Leyland, A. H., [ME] mepoisson, [ME] meqrlogit,


[ME] meqrpoisson
Liang, K.-Y., [ME] me, [ME] meglm, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
limited dependent variables, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrlogit, [ME] meqrpoisson
Lin, X., [ME] me, [ME] meglm, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson
linear mixed-effects model, [ME] me, [ME] mixed,
[ME] Glossary
link function, [ME] meglm, [ME] Glossary
Littell, R. C., [ME] me
Liu, Q., [ME] me, [ME] meqrlogit, [ME] meqrpoisson
LME, see linear mixed-effects model
logistic and logit regression, mixed-effects,
[ME] melogit, [ME] meqrlogit, also see ordered
logistic regression

M
Mair, C. S., [ME] menbreg, [ME] mepoisson,
[ME] meqrpoisson
Marchenko, Y. V., [ME] me, [ME] meglm,
[ME] melogit, [ME] meoprobit,
[ME] mepoisson, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed
maximum restricted likelihood, [ME] mixed
MCAGH, see quadrature, mode-curvature adaptive
GaussHermite
McCullagh, P., [ME] meglm postestimation,
[ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation
McCulloch, C. E., [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
McDonald, A., [ME] menbreg, [ME] mepoisson,
[ME] meqrpoisson
McLachlan, G. J., [ME] me, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson
meanvariance adaptive GaussHermite quadrature,
see quadrature, meanvariance adaptive Gauss
Hermite
mecloglog command, [ME] mecloglog
meglm command, [ME] meglm
melogit command, [ME] melogit
menbreg command, [ME] menbreg
meologit command, [ME] meologit
meoprobit command, [ME] meoprobit
mepoisson command, [ME] mepoisson
meprobit command, [ME] meprobit

362 Subject and author index


meqrlogit command, [ME] meqrlogit
meqrpoisson command, [ME] meqrpoisson
Milliken, G. A., [ME] me
mixed command, [ME] mixed
mixed model, [ME] mecloglog, [ME] melogit,
[ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed, [ME] Glossary
mode-curvature adaptive GaussHermite quadrature,
see quadrature, mode-curvature adaptive Gauss
Hermite
Molenberghs, G., [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit, [ME] mixed
multilevel model, [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
Munnell, A. H., [ME] mixed
Murray, R. M., [ME] mecloglog, [ME] melogit,
[ME] meprobit, [ME] meqrlogit
MVAGH, see quadrature, meanvariance adaptive
GaussHermite

N
Naylor, J. C., [ME] meqrlogit, [ME] meqrpoisson
negative binomial regression, mixed-effects,
[ME] menbreg
Nelder, J. A., [ME] meglm postestimation,
[ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation
nested random effects, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed, [ME] Glossary
Neuhaus, J. M., [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
Ng, E. S.-W., [ME] me, [ME] meglm, [ME] melogit,
[ME] meqrlogit
Nichols, A., [ME] meglm, [ME] mixed
nonadaptive GaussHermite quadrature, see quadrature,
GaussHermite
nonconstant variance, see robust, Huber/White/sandwich
estimator of variance, multilevel mixed-effects
model

O
odds ratio, [ME] meglm, [ME] melogit, [ME] meologit,
[ME] meqrlogit

ologit regression, mixed-effects, [ME] meologit


Omar, R. Z., [ME] me
one-level model, [ME] me, [ME] Glossary
oprobit regression, mixed-effects, [ME] meoprobit
ordered
logistic regression, [ME] meologit
probit regression, [ME] meoprobit
ordinal outcome, see outcomes, ordinal
outcomes,
binary, multilevel mixed-effects, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] meprobit,
[ME] meqrlogit
count, multilevel mixed-effects, [ME] menbreg,
[ME] mepoisson, [ME] meqrpoisson
ordinal, multilevel mixed-effects, [ME] meologit,
[ME] meoprobit
overdispersion, [ME] menbreg, [ME] mepoisson,
[ME] meqrpoisson, [ME] Glossary

P
Pantazis, N., [ME] meglm, [ME] mixed
Paterson, L., [ME] meqrlogit
Pearson residual, [ME] mecloglog postestimation,
[ME] meglm postestimation, [ME] melogit
postestimation, [ME] menbreg postestimation,
[ME] mepoisson postestimation, [ME] meprobit
postestimation, [ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation
Pfeffermann, D., [ME] mixed
Pickles, A., [ME] me, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson
Pierce, D. A., [ME] me, [ME] meqrlogit,
[ME] meqrpoisson
Pierson, R. A., [ME] mixed
Pinheiro, J. C., [ME] me, [ME] meglm,
[ME] meqrlogit, [ME] meqrlogit postestimation,
[ME] meqrpoisson, [ME] meqrpoisson
postestimation, [ME] mixed, [ME] mixed
postestimation
Poisson regression, mixed-effects, [ME] mepoisson,
[ME] meqrpoisson
posterior
mean, [ME] mecloglog postestimation, [ME] meglm
postestimation, [ME] melogit postestimation,
[ME] menbreg postestimation, [ME] meologit
postestimation, [ME] meoprobit postestimation,
[ME] mepoisson postestimation, [ME] meprobit
postestimation, [ME] Glossary
mode, [ME] mecloglog postestimation,
[ME] meglm postestimation, [ME] melogit
postestimation, [ME] menbreg postestimation,
[ME] meologit postestimation, [ME] meoprobit
postestimation, [ME] mepoisson postestimation,
[ME] meprobit postestimation, [ME] Glossary
probit regression, mixed-effects, [ME] meprobit, also
see ordered probit regression
Prosser, R., [ME] mixed

Subject and author index 363

Q
QR decomposition, [ME] meqrlogit,
[ME] meqrpoisson, [ME] Glossary
quadrature,
GaussHermite, [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed, [ME] Glossary
meanvariance adaptive GaussHermite,
[ME] me, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed, [ME] Glossary
mode-curvature adaptive GaussHermite,
[ME] me, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed, [ME] Glossary
nonadaptive GaussHermite, see quadrature, Gauss
Hermite
qualitative dependent variables, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] meologit,
[ME] meoprobit, [ME] meprobit,
[ME] meqrlogit

R
Rabe-Hesketh, S., [ME] me, [ME] mecloglog,
[ME] meglm, [ME] meglm postestimation,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrlogit,
[ME] meqrlogit postestimation,
[ME] meqrpoisson, [ME] meqrpoisson
postestimation, [ME] mixed, [ME] mixed
postestimation
random coefficient, [ME] Glossary
random intercept, [ME] Glossary
random-effects model, [ME] Glossary
multilevel mixed-effects models, [ME] me,
[ME] mecloglog, [ME] meglm, [ME] melogit,
[ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed
Rao, C. R., [ME] me, [ME] mixed
Rasbash, J., [ME] me, [ME] meglm, [ME] melogit,
[ME] meqrlogit, [ME] mixed
Raudenbush, S. W., [ME] me, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit,
[ME] meqrpoisson, [ME] mixed
recovariance, estat subcommand, [ME] meqrlogit
postestimation, [ME] meqrpoisson
postestimation, [ME] mixed postestimation

regression diagnostics, [ME] mecloglog postestimation,


[ME] meglm postestimation, [ME] melogit
postestimation, [ME] menbreg postestimation,
[ME] mepoisson postestimation, [ME] meprobit
postestimation, [ME] meqrlogit postestimation,
[ME] meqrpoisson postestimation, [ME] mixed
postestimation
REML, see restricted maximum likelihood
restricted maximum likelihood, [ME] mixed,
[ME] Glossary
robust, Huber/White/sandwich estimator of variance,
multilevel mixed-effects model, [ME] mecloglog,
[ME] meglm, [ME] melogit, [ME] menbreg,
[ME] meologit, [ME] meoprobit,
[ME] mepoisson, [ME] meprobit, [ME] mixed
robust regression, also
see robust, Huber/White/sandwich estimator of
variance, multilevel mixed-effects model
Rodrguez, G., [ME] me
Rubin, D. B., [ME] me, [ME] mixed
Ruppert, D., [ME] me, [ME] meglm, [ME] mixed

S
sandwich/Huber/White estimator of variance, see robust,
Huber/White/sandwich estimator of variance,
multilevel mixed-effects model
Schabenberger, O., [ME] me
Schank, T., [ME] meglm, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
Scheys, I., [ME] meqrlogit postestimation
Schunck, R., [ME] mixed
Searle, S. R., [ME] me, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrlogit,
[ME] meqrpoisson, [ME] mixed
Self, S. G., [ME] me, [ME] melogit, [ME] meoprobit,
[ME] mepoisson, [ME] meqrlogit,
[ME] meqrpoisson
Skinner, C. J., [ME] mixed
Skrondal, A., [ME] me, [ME] mecloglog,
[ME] meglm, [ME] meglm postestimation,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] meqrlogit,
[ME] meqrlogit postestimation,
[ME] meqrpoisson, [ME] meqrpoisson
postestimation, [ME] mixed, [ME] mixed
postestimation
Smans, M., [ME] menbreg, [ME] mepoisson,
[ME] meqrpoisson
Smith, A. F. M., [ME] meqrlogit, [ME] meqrpoisson
Sobol, D. F., [ME] me, [ME] meglm, [ME] meologit,
[ME] meoprobit
Song, S. H., [ME] mixed
Spiegel, D. C., [ME] me, [ME] meglm, [ME] meologit,
[ME] meoprobit

364 Subject and author index


Spiessens, B., [ME] me, [ME] meqrlogit
postestimation
standard errors,
robust, see robust, Huber/White/sandwich estimator
of variance, multilevel mixed-effects model
Stegun, I. A., [ME] meqrlogit, [ME] meqrpoisson
Stram, D. O., [ME] me
Stroup, W. W., [ME] me
Sussman, S., [ME] me, [ME] meglm, [ME] meologit,
[ME] meoprobit

T
Thall, P. F., [ME] mepoisson, [ME] meqrpoisson
Thompson, S. G., [ME] me
Thompson, W. A., Jr., [ME] me, [ME] mixed
Tierney, L., [ME] me, [ME] meqrlogit,
[ME] meqrpoisson
Toulopoulou, T., [ME] mecloglog, [ME] melogit,
[ME] meprobit, [ME] meqrlogit
Touloumi, G., [ME] meglm, [ME] mixed
Trivedi, P. K., [ME] meglm, [ME] mixed
Turner, R. M., [ME] me
Tutz, G., [ME] me
two-level model, [ME] me, [ME] Glossary

U
Ulene, A. L., [ME] me, [ME] meglm, [ME] meologit,
[ME] meoprobit
Upward, R., [ME] meglm, [ME] melogit,
[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed

V
Vail, S. C., [ME] mepoisson, [ME] meqrpoisson
variance,
Huber/White/sandwich estimator, see robust,
Huber/White/sandwich estimator of variance,
multilevel mixed-effects model
nonconstant, see robust, Huber/White/sandwich
estimator of variance, multilevel mixed-effects
model
variance components, [ME] Glossary, also see mixed
model
Vella, F., [ME] me
Verbeek, M., [ME] me
Verbeke, G., [ME] me, [ME] mecloglog, [ME] meglm,
[ME] melogit, [ME] menbreg, [ME] meologit,
[ME] meoprobit, [ME] mepoisson,
[ME] meprobit, [ME] mixed

W
Wand, M. P., [ME] me, [ME] meglm, [ME] mixed

Ware, J. H., [ME] me, [ME] meglm, [ME] melogit,


[ME] meoprobit, [ME] mepoisson,
[ME] meqrlogit, [ME] meqrpoisson,
[ME] mixed
wcorrelation, estat subcommand, [ME] mixed
postestimation
Welch, K. B., [ME] mixed, [ME] mixed postestimation
West, B. T., [ME] mixed, [ME] mixed postestimation
White/Huber/sandwich estimator of variance, see robust,
Huber/White/sandwich estimator of variance,
multilevel mixed-effects model
Whiting, P., [ME] melogit, [ME] meoprobit,
[ME] meqrlogit
Whitney-Saltiel, D. A., [ME] me, [ME] meglm,
[ME] meologit, [ME] meoprobit
Wiggins, V. L., [ME] mixed
Wilson, M., [ME] me
Winkelmann, R., [ME] menbreg
Wolfinger, R. D., [ME] me
Wolfram, S., [ME] meglm postestimation,
[ME] meqrlogit postestimation

Y
Yang, M., [ME] me

Z
Zeger, S. L., [ME] me, [ME] meglm, [ME] mixed
Zhao, H., [ME] mecloglog, [ME] melogit,
[ME] meprobit

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy