We developed the R package SimCorMultRes to facilitate simulation of correlated categorical (binary and multinomial) responses under a desired marginal model specification. The simulated correlated categorical responses are obtained by applying threshold approaches to correlated continuous responses of underlying regression models and the dependence structure is parametrized in terms of the correlation matrix of the latent continuous responses. This article provides an elaborate introduction to SimCorMultRes the package demonstrating its design and usage via three examples. The package can be obtained via CRAN.
Fitting marginal models with correlated binary or multinomial responses is required in many applications in which the responses are assumed to be correlated. The obvious instance of such studies is longitudinal studies (Diggle, K. Y. Liang, and S. L. Zeger 2002) where the categorical responses for each subject are collected across time points and form a cluster. For each cluster, the associated covariates are also recorded as they might influence the true marginal probabilities. Ordinary regression models designed for independent responses might not lead to consistent estimators of the marginal regression parameters or of their standard errors. For this reason, many authors have developed and proposed procedures for estimating the regression parameters of a marginal model with categorical responses that are robust to misspecification of the dependence structure, including maximum likelihood methods (Fitzmaurice and N. M. Laird 1993; Glonek and P. McCullagh 1995), copula approaches (Masarotto and C. Varin 2012), quasi-least squares approaches (Shults and N. R. Chaganty 1998), generalized quasi-likelihood methods (Sutradhar and K. Das 1999; Sutradhar 2003) and generalized estimating equations (GEE) approaches (Lipsitz, N. M. Laird, and D. P. Harrington 1991; Chaganty and H. Joe 2004; Touloumis, A. Agresti, and M. Kateri 2013). Although the asymptotic properties of these methods are well-established, the evaluation of their performance in finite samples under misspecification of the correlation structure relies on simulations. The crucial step of these empirical studies is to simulate correlated categorical responses that satisfy a desired marginal model and dependence structure specification.
Motivated by this, we present the R package SimCorMultRes (Touloumis 2016) which makes it easy to simulate correlated categorical responses under a given marginal model and dependence structure configuration. The package implements marginal models for correlated binary responses (two response categories) as well as for correlated multinomial responses (three or more response categories) while taking into account the nature of the response categories (ordinal or nominal). In summary, the correlated binary/multinomial responses are obtained as realizations of an underlying continuum. This means that latent regression models with correlated continuous responses are utilized so as to generate the correlated categorical responses that satisfy the desired marginal model specification. The categorical responses are obtained by applying threshold approaches to the correlated continuous responses. In order to avoid theoretical pitfalls outlined in the next paragraph, the desired dependence structure is expressed in terms of the correlation matrix of the latent responses. To the best of our knowledge, SimCorMultRes is the first package in R that allows direct simulation of correlated categorical responses under a marginal model specification with categorical and/or continuous covariates.
To fully appreciate the features of SimCorMultRes, we briefly compare it with two R packages: i) GenOrd (Barbiero and P. A. Ferrari 2015), that implements the methods presented by (Ferrari and A. Barbiero 2012) and its features being discussed in greater detail in (Barbiero and P. A. Ferrari 2016), and ii) MultiOrd (Amatya and H. Demirtas 2016), that is described in (Amatya and H. Demirtas 2015) and relies on the simulation techniques proposed by (Demirtas 2006). These packages are designed to simulate random vectors of correlated binary or ordinal responses subject to fixed but common marginal probabilities across all subjects and a predefined correlation matrix for the correlated categorical responses. Therefore, unlike SimCorMultRes, it is not straightforward to utilize GenOrd or MultiOrd for simulating categorical responses conditional on a regression model specification for the marginal probabilities, especially when the marginal probabilities vary across subjects. In addition, SimCorMultRes has the unique feature (to the best of our knowledge) to simulate correlated nominal responses. Another difference between SimCorMultRes and the R packages GenOrd and MultiOrd is that the former requires the association among the categorical responses to be directly expressed via their correlation matrix and that the joint specification of the marginal probabilities and of the correlation matrix leads to a valid joint distribution for the correlated categorical responses. A necessary condition for this is that the so-called Frétchet-Hoeffding bounds are satisfied, which can be verified by employing the method of (Demirtas and D. Hedeker 2011). As noted by one of the reviewers, both GenOrd and MultiOrd have built-in mechanisms to check the restrictions imposed by the Frétchet-Hoeffding bounds. Unfortunately, even if these restrictions are met, it is still theoretically possible that a legitimate joint distribution does not exist for the correlated categorical responses (Bergsma and T. Rudas 2002). To circumvent this difficulty, the methodology implemented in SimCorMultRes always defines the joint distribution of the correlated categorical responses in terms of the joint distribution of correlated latent random variables and thus, it allows the user to generate correlated categorical responses under any configuration of the marginal probabilities provided that the user-defined correlation matrix of the latent continuous responses is positive definite, a condition that can be more easily verified.
The remainder of this paper is organized as follows. First we present the theoretical background of the threshold approaches implemented in SimCorMultRes. In particular, we introduce the general two-stage algorithm for simulating correlated categorical responses, focusing on the threshold approaches that give rise to the marginal models with correlated categorical responses and on the modified version of the NORmal To Anything (NORTA) method (Cario and B. L. Nelson 1997), the default simulation method of correlated latent random variables in SimCorMultRes. Next, we describe the core and utility functions of the package. Then, we demonstrate the use of SimCorMultRes by considering the problems of evaluating two estimation methods for marginal models with correlated nominal multinomial responses, of assessing the quality of an approximation that links the uniform local odds ratios structure with the correlation parameter of an underlying bivariate normal distribution, and of simulating correlated categorical random variables under no marginal model specification. Finally, we summarize the features of SimCorMultRes and discuss future extensions.
In this section, we introduce the threshold approaches that give rise to marginal models with correlated binary, ordinal or nominal responses. Since the thresholds are applied to correlated continuous responses, simulation of correlated continuous responses is required. This step can be performed in various ways, eġ,̇ directly from an appropriate multivariate distribution, by utilizing distributional properties about the sum or the difference of random vectors or by employing copula approaches. Herein we discuss a simple and straightforward simulation method that is based on the NORTA method, and we present a general algorithm that combines the threshold approaches with the modified NORTA method, enabling us to generate correlated categorical responses subject to a marginal model specification in a unified manner. However, we underline that the use of the NORTA method is optional in the general algorithm and that it can be replaced with another simulation method/technique as long as the distributional restrictions regarding the correlated continuous variables that are imposed by the thresholds are met.
For notational ease, adopt a longitudinal set-up for generating the
correlated binary or multinomial variables. Let
Suppose the aim is to simulate correlated binary variables such that the
marginal probabilities satisfy the model
Now, consider the multivariate latent regression model
Options for marginal modelling of correlated ordinal responses include
the marginal cumulative link model
First, consider the marginal cumulative link model ((2)) and
suppose the multivariate latent regression model
Next, consider the marginal continuation-ratio model ((3))
and suppose the following multivariate latent regression model holds
The marginal continuation-ratio model ((3)) arises by
applying the threshold
Consider the marginal baseline-category logit model
To connect the marginal baseline-category logit model ((4))
with underlying regression models, consider the multivariate latent
regression model
the assumption of choice independence is met at each measurement
occasion, that is
The threshold
(Li and J. L. Hammond 1975) proposed a simple method for generating continuous random vectors with given marginal distributions and a prescribed correlation matrix. (Cario and B. L. Nelson 1997) introduced the NORTA method which essentially modifies the approach of (Li and J. L. Hammond 1975) to account for any type of marginal distributions (discrete, continuous or mixed). Here, we describe a simple version of the NORTA method in which the desired marginal distributions are continuous and identical which is required by all the threshold approaches implemented in SimCorMultRes.
Let
Generate a random vector
Apply the transformation
If
We propose a simple and efficient two-staged general algorithm for generating correlated categorical responses:
Marginal model specification: Provide the covariates, the regression parameters and the link function (if required) of the desired marginal model ((1)), ((2)), ((3)), or ((4)).
Simulation of continuous random vectors via the NORTA method and
threshold approach: Define the desired dependence structure by
fixing
In the marginal models described above, we usually choose
Expressing the association structure in terms of
As mentioned before, the proposed version of the NORTA method is not the only option to simulate continuous random vectors in Stage 2 and instead, alternative simulation techniques can be easily employed. However, the user must be cautious in order to respect the corresponding marginal distributional assumptions and the assumption of local independence or choice independence whenever the marginal models ((3)) or ((4)) are used, respectively.
We emphasize that the proposed algorithm can also handle the situation in which no marginal model specification is provided. For more details, please refer to the third example below.
SimCorMultRes contains four core functions (rbin
, rmult.bcl
,
rmult.clm
and rmult.crm
) that enable the user to generate correlated
categorical responses and two utility functions (rnorta
and
rsmvnorm
) initially designed for internal use in the core functions.
We describe in detail the arguments and the output of the core and
utility functions.
Each core function in SimCorMultRes simulates correlated categorical
responses under a marginal model specification. In particular, rbin
simulates correlated binary responses that satisfy the marginal
model ((1)), rmult.clm
simulates correlated ordinal responses
that satisfy the marginal cumulative link model ((2)),
rmult.crm
simulates correlated ordinal responses that satisfy the
marginal continuation-ratio model ((3)) and rmult.bcl
simulates correlated nominal responses that satisfy the marginal
baseline-category logit model ((4)).
The common cluster size (clsize
) of the subjects is required in all
core functions.
The ncategories
argument in rmult.bcl
indicates the number of
nominal response categories. The number of ordinal response categories
in rmult.clm
and rmult.crm
is indirectly defined by the intercepts
argument. It contains the values of the threshold parameters which can
be provided either as a intercepts
corresponds to intercepts
argument
is also employed in rbin
to specify whether the intercepts in the
marginal model ((1)) are time-dependent. If
intercepts
should be a single
number that reflects the value of
The values for the marginal regression parameters (betas
) should be
provided as a numeric vector whenever
betas
should be provided
as a matrix with betas
unless the function rmult.bcl
is used.
The functional relationship of the covariates in the marginal model
(xformula
) is specified similarly as in other regression models with
the single difference that no response variable should be provided. The
covariates defined in xformula
can be imported via the xdata
argument in “long” format, meaning that each row contains all the
subject-specific covariates information at a given time. When xdata
is
missing, then the covariates are extracted from the environment that the
core function is called.
The link
argument in rbin
, rmult.clm
or rmult.crm
determines the
c.d.f. "probit"
), the logit
("logit"
), the complimentary log-log ("cloglog"
) and the cauchit
("cauchit"
). It is worth mentioning that there is no link
argument
in the function rmult.bcl
because the marginal distribution of the
latent continuous random variables
In all core functions, the latent random vectors rlatent
argument. In the first case, the correlation
matrix cor.matrix
) in the modified NORTA method and the link
argument,
wherever present, are required. Checks are carried out to ensure that
cor.matrix
is a positive-definite correlation matrix and whenever
rmult.crm
or rmult.bcl
is employed, cor.matrix
is forced to
satisfy the restrictions of the latent dependence structure that are
implied by the threshold approach associated with
models ((3)) or ((4)), respectively. In the case
where the preferred simulation method is not the NORTA method, rlatent
should contain the values of the latent random vectors while
cor.matrix
and link
are ignored. Examples of using the rlatent
argument can be found in the help files and the vignette of
SimCorMultRes.
The output of any core function is displayed as a list with three items:
(i) a matrix with the simulated responses such that the (Ysim
), (ii) a data
frame (simdata
) that contains the simulated responses (y), the
covariates specified by xformula
, subjects’ identities (id) and the
measurement occasions (time), and (iii) the NORTA generated or
user-defined latent random vectors (rlatent
).
The utility function rnorta
offers a more general implementation of
the NORTA method described earlier. The user needs to specify the number
of random vectors (R
), the correlation matrix cor.matrix
) and the names of the
quantile functions of the desired marginal distributions (distr
). The
optional qparameters
argument permits users to consider parameter
values for the marginal distributions other than the default (obtained
when qparameters = NULL
). The function returns R
random vectors with
marginal distributions specified by distr
(and qparameters
) when
cor.matrix
is the correlation matrix of the multivariate normal
distribution in the NORTA method. We highlight that rnorta
has been
extended to handle situations that are beyond the scope of simulation of
correlated categorical responses subject to a marginal model
specification. Unlike the simple version of the NORTA method needed for
our purposes, rnorta
does not require marginal distributions to be
identical. In fact, any univariate discrete or continuous distribution
whose quantile function is available in R can be employed in distr
provided that the required R package is available.
The function rsmvnorm
generates R
random vectors from a multivariate
normal distribution with mean vector the zero vector and covariance
matrix cor.matrix
.
Note that an error message is returned whenever cor.matrix
in
functions rnorta
or rsmvnorm
is not a positive-definite correlation
matrix.
We now illustrate the use of SimCorMultRes to: i) evaluate the performance of GEE approaches for estimating the regression parameters of a marginal baseline-category logit model, ii) to verify approximations that relate a uniform local odds ratios structure to the correlation coefficient of a bivariate normal distribution (Goodman 1979) and, iii) to simulate correlated categorical random variables with fixed arbitrary univariate probabilities that are not subject to a marginal model specification.
The motivation behind the creation of SimCorMultRes lies on evaluating statistical methods that estimate the regression coefficients of marginal models with correlated binary or multinomial responses. To exemplify this, we employ two GEE models for estimating a marginal model with correlated nominal responses: i) the local odds ratios GEE approach (Touloumis, A. Agresti, and M. Kateri 2013) and ii) the independence “working” model, which treats all observations as independent when solving the estimating equations. Although the two competing GEE models are asymptotically equally efficient, in the sense that they both produce consistent estimators for the marginal regression parameters and of their standard errors, the regression coefficient estimators of the independence “working” model are expected to be slightly less precise than those of the local odds ratios GEE approach in small and moderate sample sizes due to the fact that the independence “working” model does not account for the dependence among the correlated responses (Touloumis, A. Agresti, and M. Kateri 2013).
To investigate this assertion for the case of correlated nominal
responses, we employed the marginal baseline-category logit model
> library("SimCorMultRes")
> library("multgee")
Loading required package: gnm
Loading required package: VGAM
Loading required package: stats4
Loading required package: splines
> set.seed(1)
> N <- 100
> clsize <- 4
> ncategories <- 5
> betas <- c(2, 1, 1, 2, 1.5, 1.5, 2.5, 0.5, 0, 0)
> x <- rnorm(N * clsize)
> cor.matrix <- toeplitz(0.56^seq(0, clsize * ncategories - 1))
> for (i in 1:clsize) {
+ diag.index <- 1:ncategories + (i - 1) * ncategories
+ cor.matrix[diag.index, diag.index] <- diag(1, ncategories)
+ }
Conditional on the above marginal model specification and dependence
structure, we simulated correlated nominal responses and we fitted the
local odds ratios GEE approach with an RC-type dependence structure and
the independence “working” model using the R package
multgee
(Touloumis 2015). We replicated this procedure
> B <- 1000
> indeGEEcoefs <- matrix(NA_real_, B, 8)
> RCGEEcoefs <- matrix(NA_real_, B, 8)
> for (b in 1:B) {
+ SimNomRes <- rmult.bcl(clsize = clsize, ncategories = ncategories,
+ betas = betas, xformula = ~x, cor.matrix = cor.matrix)
+ fitRC <- try(nomLORgee(y ~ x, id = id, repeated = time, data = SimNomRes$simdata,
+ LORstr = "RC", add = 0.05), silent = TRUE)
+ if (!inherits(fitRC, "try-error")) {
+ if (fitRC$convergence$conv)
+ RCGEEcoefs[b, ] <- coef(fitRC)
+ }
+ fitinde <- try(nomLORgee(y ~ x, id = id, repeated = time, data = SimNomRes$simdata,
+ LORstr = "independence"), silent = TRUE)
+ if (!inherits(fitinde, "try-error")) {
+ if (fitinde$convergence$conv)
+ indeGEEcoefs[b, ] <- coef(fitinde)
+ }
+ }
Although the local odds GEE approach did not always converge, the convergence rate for the local odds ratios GEE model was high
> convergence <- c(mean(!is.na(indeGEEcoefs)), mean(!is.na(RCGEEcoefs))) * 100
> convergence
[1] 100.0 99.7
and therefore, we can conduct a fair comparison by excluding the results from those 3 iterations in which the local odds ratios GEE approach failed to converge.
Table 1 summarizes the simulation results by displaying the
simulated mean and standard error of the regression estimates from the
two competing GEE models and the simulated relative efficiency (SRE) for
each regression parameter of model ((5)). For a given
coefficient of model ((5)), the SRE criterion was defined as
the ratio of the simulated mean square error of the corresponding Monte
Carlo estimate based on the local odds ratios GEE approach to that based
on the independence “working” model. Values of the SRE criterion greater
(less) than 1.0 imply that the local odds ratios GEE approach is more
(less) efficient than the independence “working” model in estimating
this specific regression parameter. As expected, the two GEE models seem
to estimate consistently the marginal model ((5)), with the
local odds ratios GEE approach being
The results of Table 1 were calculated using the following R commands:
> simindemean <- colMeans(indeGEEcoefs, na.rm = TRUE)
> simindesd <- apply(indeGEEcoefs, 2, function(x) sd(x, na.rm = TRUE))
> simRCmean <- colMeans(RCGEEcoefs, na.rm = TRUE)
> simRCsd <- apply(RCGEEcoefs, 2, function(x) sd(x, na.rm = TRUE))
> simindesmse <- (betas[-c(9:10)] - simindemean)^2 + simindesd^2
> simRCsmse <- (betas[-c(9:10)] - simRCmean)^2 + simRCsd^2
> SRE <- simindesmse/simRCsmse
> rbind(simindemean, simindesd, simRCmean, simRCsd, SRE)
Model | ||||||||
---|---|---|---|---|---|---|---|---|
IEE | 2.0701 | 1.0308 | 1.0494 | 2.0530 | 1.5682 | 1.5441 | 2.5702 | 0.5209 |
0.3567 | 0.3232 | 0.4011 | 0.3601 | 0.3740 | 0.3412 | 0.3627 | 0.2995 | |
LOR | 2.0471 | 0.9951 | 1.0378 | 1.9832 | 1.5487 | 1.4943 | 2.5473 | 0.4946 |
0.3512 | 0.3105 | 0.3944 | 0.3490 | 0.3673 | 0.3319 | 0.3562 | 0.2873 | |
SRE | 1.0522 | 1.0927 | 1.0405 | 1.0852 | 1.0526 | 1.0738 | 1.0573 | 1.0921 |
Let
For each value of
> library("SimCorMultRes")
> set.seed(123)
> commonlogoddsratio <- function(N, rho, intercepts, B) {
+ cor.matrix <- toeplitz(c(1, rho))
+ x <- rep(0, 2 * N)
+ ans <- rep(0, B)
+ for (b in 1:B) {
+ CorOrdRes <- rmult.clm(clsize = 2, intercepts = intercepts, betas = 0,
+ xformula = ~x, link = "probit", cor.matrix = cor.matrix)
+ simdata <- data.frame(table(CorOrdRes$Ysim[, 1], CorOrdRes$Ysim[, 2]))
+ if (any(simdata[, 3] == 0))
+ simdata[, 3] <- simdata[, 3] + 0.001
+ colnames(simdata) <- c("x", "y", "Freq")
+ fit <- glm(Freq ~ x + y + as.numeric(x):as.numeric(y), family = poisson(),
+ data = simdata)
+ ans[b] <- as.numeric(coef(fit)[length(coef(fit))])
+ }
+ ans
+ }
> N <- 1000
> intercepts <- c(-3, -2, -1, 0, 1, 2, 3)
> B <- 10000
> rho <- seq(0.05, 0.95, 0.05)
> logoddsratio <- rep(0, length(rho))
> for (i in seq_along(rho)) {
+ simdata <- commonlogoddsratio(N, rho[i], intercepts, B)
+ logoddsratio[i] <- mean(simdata)
+ }
There were 50 or more warnings (use warnings() to see the first 50)
> eta <- 1/(2 * logoddsratio)
> rhophi <- (sqrt(1 + eta^2) - eta) * 13/12
The produced warnings()
reflect the fact that we have added 0.001 to
each cell of the two-way contingency table whenever an observed zero
count occurred to ensure the existence of the maximum likelihood
estimator of
> absdif <- abs(rhophi - rho)
> plot(rho, absdif, xlab = expression(rho), ylab = expression(abs(rho[hat(phi)] -
+ rho)), xaxt = "n")
> axis(1, at = seq(0.05, 0.95, 0.1), labels = seq(0.05, 0.95, 0.1))
Figure 1 displays the absolute difference between the true
correlation parameter
For completeness’ sake, we illustrate how to utilize SimCorMultRes in order to generate correlated categorical random variables conditional on a desired dependence structure and known marginal probabilities that are not determined by a regression model.
Suppose the goal is to simulate
To this direction, first define
> library(SimCorMultRes)
> set.seed(123)
> N <- 5000
> clsize <- 3
> mprobs_1 <- c(0.1, 0.3, 0.4, 0.2)
> mprobs_2 <- c(0.2, 0.2, 0.2, 0.4)
> mprobs_3 <- c(0.2, 0.4, 0.3, 0.1)
> cprobs_1 <- cumsum(mprobs_1[-4])
> cprobs_2 <- cumsum(mprobs_2[-4])
> cprobs_3 <- cumsum(mprobs_3[-4])
> intercepts <- qnorm(rbind(cprobs_1, cprobs_2, cprobs_3))
> x <- rep(0, clsize * N)
Next, for the pairwise dependence structure, approximate the desired
pairwise uniform local odds ratios
> CommomLOR <- log(2)
> eta <- 1/(2 * CommomLOR)
> rhophi <- (sqrt(1 + eta^2) - eta) * 13/12
> rhophi
[1] 0.5543136
To sum up, the desired correlated multinomial responses can be simulated
under a cumulative probit model with no covariates and an exchangeable
correlation matrix for the underlying trivariate normal distribution
with correlation parameter equal to
> cor.matrix <- toeplitz(c(1, rhophi, rhophi))
> simdata <- rmult.clm(clsize = clsize, intercepts = intercepts, betas = 0,
+ xformula = ~x, link = "probit", cor.matrix = cor.matrix)
The simulated category-specific probabilities satisfy the desired marginal configuration
> t(apply(simdata$Ysim, 2, function(x) table(x)/N))
1 2 3 4
[1,] 0.0970 0.2986 0.4068 0.1976
[2,] 0.1996 0.2046 0.1978 0.3980
[3,] 0.2068 0.3868 0.3068 0.0996
and a simulated correlation matrix for the latent random variables
> cor(simdata$rlatent)
[,1] [,2] [,3]
[1,] 1.0000000 0.5476759 0.5527712
[2,] 0.5476759 1.0000000 0.5534464
[3,] 0.5527712 0.5534464 1.0000000
This approach can also be employed to generate correlated binary random variables with known marginal probabilities provided that the desired correlation structure of the binary responses can be expressed in terms of a correlation matrix in the NORTA method. In this case SimCorMultRes is essentially implementing the simulation method of (Emrich and M. R. Piedmonte 1991) without performing the first step of their algorithm.
We have presented the R package SimCorMultRes that simulates correlated binary or multinomial random variables conditional on a marginal model specification while expressing the dependence structure via the correlation structure of latent random variables. We outlined the underlying theory that SimCorMultRes is based on and illustrated the use of the package with three examples. To the best of our knowledge, SimCorMultRes is the first R package that targets specifically on the generation of correlated binary, nominal or ordinal responses under marginal model specification. In some instances, it could also be used to simulate correlated categorical responses even when no model specification is provided for the marginal probabilities by exploiting the relationship of association measures for discrete variables and the bivariate normal distribution. This can be achieved by following a similar approach as the one adopted in the third example herein. The results in this paper were obtained using SimCorMultRes version 1.4.1 and R 3.3.1.
Although the NORTA method is the default tool for simulating the latent
random vectors denoted by rlatent
argument in the core functions. For example, generating correlated
binary responses under a marginal logit model specification and with an
exchangeable correlation matrix, can be accomplished by taking the
difference of two independent random vectors from the multivariate
Gumbel distribution each with correlation matrix the desired correlation
matrix. This approach can be found in standard textbooks, such as
(Balakrishnan 1992). A working example, can be found in the vignette
of this package.
A future direction is to increase the scope of marginal regression models for nominal and ordinal responses, e.g., by including threshold approaches that give rise to a marginal adjacent-categories logit model and allowing category-specific regression parameters in the marginal models with ordinal responses.
The author wishes to thank the associate editor and two anonymous referees for their valuable comments and suggestions which significantly improved this manuscript and led to a more flexible implementation of the related methodologies in SimCorMultRes.
SimCorMultRes, GenOrd, MultiOrd, mvtBinaryEP, multgee
This article is converted from a Legacy LaTeX article using the texor package. The pdf version is the official version. To report a problem with the html, refer to CONTRIBUTE on the R Journal homepage.
Text and figures are licensed under Creative Commons Attribution CC BY 4.0. The figures that have been reused from other sources don't fall under this license and can be recognized by a note in their caption: "Figure from ...".
For attribution, please cite this work as
Touloumis, "Simulating Correlated Binary and Multinomial Responses under Marginal Model Specification: The SimCorMultRes Package", The R Journal, 2016
BibTeX citation
@article{RJ-2016-034, author = {Touloumis, Anestis}, title = {Simulating Correlated Binary and Multinomial Responses under Marginal Model Specification: The SimCorMultRes Package}, journal = {The R Journal}, year = {2016}, note = {https://rjournal.github.io/}, volume = {8}, issue = {2}, issn = {2073-4859}, pages = {79-91} }