Title: | General Package for Meta-Analysis |
---|---|
Description: | User-friendly general package providing standard methods for meta-analysis and supporting Schwarzer, Carpenter, and Rücker <DOI:10.1007/978-3-319-21416-0>, "Meta-Analysis with R" (2015): - common effect and random effects meta-analysis; - several plots (forest, funnel, Galbraith / radial, L'Abbe, Baujat, bubble); - three-level meta-analysis model; - generalised linear mixed model; - Hartung-Knapp method for random effects model; - Kenward-Roger method for random effects model; - prediction interval; - statistical tests for funnel plot asymmetry; - trim-and-fill method to evaluate bias in meta-analysis; - meta-regression; - cumulative meta-analysis and leave-one-out meta-analysis; - import data from 'RevMan 5'; - produce forest plot summarising several (subgroup) meta-analyses. |
Authors: | Guido Schwarzer [cre, aut] |
Maintainer: | Guido Schwarzer <[email protected]> |
License: | GPL (>= 2) |
Version: | 8.0-2 |
Built: | 2025-01-14 16:28:02 UTC |
Source: | https://github.com/guido-s/meta |
R package meta is a user-friendly general package providing standard methods for meta-analysis and supporting Schwarzer et al. (2015), https://link.springer.com/book/10.1007/978-3-319-21416-0.
R package meta (Schwarzer, 2007; Balduzzi et al., 2019) provides the following statistical methods for meta-analysis.
Common effect (also called fixed effect) and random effects model:
Meta-analysis of continuous outcome data (metacont
)
Meta-analysis of binary outcome data (metabin
)
Meta-analysis of incidence rates (metainc
)
Generic inverse variance meta-analysis (metagen
)
Meta-analysis of single correlations (metacor
)
Meta-analysis of single means (metamean
)
Meta-analysis of single proportions (metaprop
)
Meta-analysis of single incidence rates (metarate
)
Several plots for meta-analysis:
Forest plot (forest.meta
, forest.metabind
)
Funnel plot (funnel.meta
)
Galbraith plot / radial plot (radial.meta
)
L'Abbe plot for meta-analysis with binary outcome data
(labbe.metabin
, labbe.default
)
Baujat plot to explore heterogeneity in meta-analysis
(baujat.meta
)
Bubble plot to display the result of a meta-regression
(bubble.metareg
)
Three-level meta-analysis model (Van den Noortgate et al., 2013)
Generalised linear mixed models (GLMMs) for binary and count
data (Stijnen et al., 2010) (metabin
,
metainc
, metaprop
, and
metarate
)
Various estimators for the between-study variance
in a random effects model (Veroniki et al., 2016);
see description of argument
method.tau
below
Two methods to estimate the I-squared statistic
(Higgins and Thompson, 2002); see description of argument
method.I2
below
Hartung-Knapp method for random effects meta-analysis
(Hartung & Knapp, 2001a,b), see description of arguments
method.random.ci
and adhoc.hakn.ci
below
Kenward-Roger method for random effects meta-analysis
(Partlett and Riley, 2017), see description of arguments
method.random.ci
and method.predict
below
Prediction interval for the treatment effect of a new study
(Veroniki et al., 2019; Higgins et al., 2009; Partlett and Riley, 2017;
Nagashima et al., 2019), see description of argument method.predict
below
Statistical tests for funnel plot asymmetry
(metabias.meta
, metabias.rm5
) and
trim-and-fill method (trimfill.meta
,
trimfill.default
) to evaluate bias in meta-analysis
Meta-regression (metareg
)
Cumulative meta-analysis (metacum
) and
leave-one-out meta-analysis (metainf
)
Import data from RevMan Web (read.cdir
), RevMan
5 (read.rm5
), see also metacr
to
conduct meta-analysis for a single comparison and outcome from a
Cochrane review
R package meta provides two vignettes:
vignette("meta-workflow")
with an overview of main
functions,
vignette("meta-tutorial")
with up-to-date commands for
Balduzzi et al. (2019).
Additional statistical meta-analysis methods are provided by add-on R packages:
Frequentist methods for network meta-analysis (R package netmeta)
Statistical methods for sensitivity analysis in meta-analysis (R package metasens)
Statistical methods for meta-analysis of diagnostic accuracy studies with several cutpoints (R package diagmeta)
In the following, more details on available and default statistical
meta-analysis methods are provided and R function
settings.meta
is briefly described which can be used
to change the default settings. Additional information on
meta-analysis objects and available summary measures can be found
on the help pages meta-object
and
meta-sm
.
The following methods are available in all meta-analysis functions
to estimate the between-study variance .
Argument | Method |
method.tau = "REML"
|
Restricted maximum-likelihood estimator (Viechtbauer, 2005) |
(default) | |
method.tau = "PM"
|
Paule-Mandel estimator (Paule and Mandel, 1982) |
method.tau = "DL"
|
DerSimonian-Laird estimator (DerSimonian and Laird, 1986) |
method.tau = "ML"
|
Maximum-likelihood estimator (Viechtbauer, 2005) |
method.tau = "HS"
|
Hunter-Schmidt estimator (Hunter and Schmidt, 2015) |
method.tau = "SJ"
|
Sidik-Jonkman estimator (Sidik and Jonkman, 2005) |
method.tau = "HE"
|
Hedges estimator (Hedges and Olkin, 1985) |
method.tau = "EB"
|
Empirical Bayes estimator (Morris, 1983) |
For GLMMs, only the maximum-likelihood method is available.
Historically, the DerSimonian-Laird method was the de facto
standard to estimate the between-study variance and is
the default in some software packages including Review Manager 5
(RevMan 5) and R package meta, version 4 and below. However,
its role has been challenged and especially the REML and
Paule-Mandel estimators have been recommended (Veroniki et al.,
2016; Langan et al., 2019). Accordingly, the currenct default in R
package meta is the REML estimator.
The following R command could be used to employ the Paule-Mandel instead of the REML estimator in all meta-analyses of the current R session:
settings.meta(method.tau = "PM")
Other estimators for could be selected in a similar
way.
Note, for binary outcomes, two variants of the DerSimonian-Laird
estimator are available if the Mantel-Haenszel method is used for
pooling. If argument Q.Cochrane = TRUE
(default), the
heterogeneity statistic Q is based on the Mantel-Haenszel instead
of the inverse variance estimator under the common effect
model. This is the estimator for implemented in RevMan
5.
The following methods are available in all meta-analysis functions to estimate the I-squared statistic (Higgins and Thompson, 2002).
Argument | Method |
method.I2 = "Q"
|
Based on heterogeneity statistic Q (default) |
method.I2 = "tau2"
|
Based on between-study variance
|
Using method.I2 = "Q"
(Higgins and Thompson, 2002, section 3.3), the
value of I does not change if the estimate of
changes.
Furthermore, the value of I
and the test of heterogeneity based on
the Q statistic are in agreement. R package metafor uses the second
method (
method.I2 = "tau2"
) which is described in Higgins and Thompson
(2002), section 3.2. This method is more general in the way that the value
of I changes with the estimate of
.
The following methods are available in all meta-analysis functions to calculate a confidence interval for the random effects estimate.
Argument | Method |
method.random.ci = "classic" |
Based on standard normal quantile |
(DerSimonian and Laird, 1986) (default) | |
method.random.ci = "HK" |
Method by Hartung and Knapp (2001a/b) |
method.random.ci = "KR" |
Kenward-Roger method (Partlett and Riley, 2017) |
DerSimonian and Laird (1986) introduced the classic random effects
model using a quantile of the standard normal distribution to
calculate a confidence interval for the random effects
estimate. This method implicitly assumes that the weights in the
random effects meta-analysis are not estimated but
given. Particularly, the uncertainty in the estimation of the
between-study variance is ignored.
Hartung and Knapp (2001a,b) proposed an alternative method for random effects meta-analysis based on a refined variance estimator for the treatment estimate and a quantile of a t-distribution with k-1 degrees of freedom where k corresponds to the number of studies in the meta-analysis.
The Kenward-Roger method is only available for the REML estimator
(method.tau = "REML"
) of the between-study variance
(Partlett and Riley, 2017). This method is based on an
adjusted variance estimate for the random effects
estimate. Furthermore, a quantile of a t-distribution with
adequately modified degrees of freedom is used to calculate the
confidence interval.
For GLMMs and three-level models, the Kenward-Roger method is not
available, but a method similar to Knapp and Hartung (2003) is used
if method.random.ci = "HK"
. For this method, the variance
estimator is not modified, however, a quantile of a
t-distribution with k-1 degrees of freedom is used;
see description of argument test
in
rma.glmm
and rma.mv
.
Simulation studies (Hartung and Knapp, 2001a,b; IntHout et al., 2014; Langan et al., 2019) show improved coverage probabilities of the Hartung-Knapp method compared to the classic random effects method. However, in rare settings with very homogeneous treatment estimates, the Hartung-Knapp variance estimate can be arbitrarily small resulting in a very narrow confidence interval (Knapp and Hartung, 2003; Wiksten et al., 2016). In such cases, an ad hoc variance correction has been proposed by utilising the variance estimate from the classic random effects model with the Hartung-Knapp method (Knapp and Hartung, 2003; IQWiQ, 2022). An alternative ad hoc approach is to use the confidence interval of the classic common or random effects meta-analysis if it is wider than the interval from the Hartung-Knapp method (Wiksten et al., 2016; Jackson et al., 2017).
Argument adhoc.hakn.ci
can be used to choose the ad
hoc correction for the Hartung-Knapp (HK) method:
Argument | Ad hoc method |
adhoc.hakn.ci = "" |
no ad hoc correction (default) |
adhoc.hakn.ci = "se" |
use variance correction if HK standard error is smaller |
than standard error from classic random effects | |
meta-analysis (Knapp and Hartung, 2003) | |
adhoc.hakn.ci = "IQWiG6" |
use variance correction if HK confidence interval |
is narrower than CI from classic random effects model | |
with DerSimonian-Laird estimator (IQWiG, 2022) | |
adhoc.hakn.ci = "ci" |
use wider confidence interval of classic random effects |
and HK meta-analysis | |
(Hybrid method 2 in Jackson et al., 2017) |
For GLMMs and three-level models, the ad hoc variance corrections are not available.
The following methods are available in all meta-analysis functions to calculate a prediction interval for the treatment effect in a single new study.
Argument | Method |
method.predict = "V" |
Based on t-distribution with k-1 degrees of freedom |
(Veroniki et al., 2019) (default) | |
method.predict = "HTS" |
Based on t-distribution with k-2 degrees of freedom |
(Higgins et al., 2009) | |
method.predict = "HK" |
Based on Hartung-Knapp standard error and |
t-distribution with k-1 degrees of freedom | |
method.predict = "HK-PR" |
Based on Hartung-Knapp standard error and |
t-distribution with k-2 degrees of freedom | |
(Partlett and Riley, 2017) | |
method.predict = "KR" |
Based on Kenward-Roger standard error and |
t-distribution with approximate Kenward-Roger | |
degrees of freedom | |
method.predict = "KR-PR" |
Based on Kenward-Roger standard error and |
t-distribution with approximate Kenward-Roger | |
degrees of freedom minus 1 (Partlett and Riley, 2017) | |
method.predict = "NNF" |
Bootstrap approach (Nagashima et al., 2019) |
method.predict = "S" |
Based on standard normal quantile (Skipka, 2006) |
By default (method.predict = "V"
), the prediction interval
is based on a t-distribution with k-1 degrees of
freedom where k corresponds to the number of studies in the
meta-analysis (Veroniki et al., 2019). The method by Higgins et al., (2009),
which is based on a t-distribution with k-2 degrees of freedom,
has been the default in R package meta, version 7.0-0 or lower.
The Hartung-Knapp prediction intervals are also based on a t-distribution, however, use a different standard error.
The Kenward-Roger method is only available for the REML estimator
(method.tau = "REML"
) of the between-study variance
(Partlett and Riley, 2017). This method is based on an
adjusted variance estimate for the random effects
estimate. Furthermore, a quantile of a t-distribution with
adequately modified degrees of freedom is used to calculate the prediction
interval.
The bootstrap approach is only available if R package pimeta
is installed (Nagashima et al., 2019). Internally, the
pima
function is called with argument
method = "boot"
. Argument seed.predict
can be used to
get a reproducible bootstrap prediction interval and argument
seed.predict.subgroup
for reproducible bootstrap prediction
intervals in subgroups.
The method of Skipka (2006) ignores the uncertainty in the
estimation of the between-study variance and thus has
too narrow limits for meta-analyses with a small number of studies.
For GLMMs and three-level models, only the methods by Veroniki et al.
(2019), Higgins et al. (2009) and Skipka (2006) are available. Argument
method.predict = "V"
in R package meta gives the same
prediction intervals as R functions rma.glmm
or
rma.mv
with argument test = "t"
.
Note, in R package meta, version 7.0-0 or lower, the methods
method.predict = "HK-PR"
and method.predict = "KR-PR"
have
been available as method.predict = "HK"
and
method.predict = "KR"
.
Argument adhoc.hakn.pi
can be used to choose the ad
hoc correction for the Hartung-Knapp method:
Argument | Ad hoc method |
adhoc.hakn.pi = "" |
no ad hoc correction (default) |
adhoc.hakn.pi = "se" |
use variance correction if HK standard error is smaller |
The following methods are available in all meta-analysis functions
to calculate a confidence interval for and
.
Argument | Method |
method.tau.ci = "J" |
Method by Jackson (2013) |
method.tau.ci = "BJ" |
Method by Biggerstaff and Jackson (2008) |
method.tau.ci = "QP" |
Q-Profile method (Viechtbauer, 2007) |
method.tau.ci = "PL" |
Profile-Likelihood method for three-level |
meta-analysis model (Van den Noortgate et al., 2013) | |
method.tau.ci = "" |
No confidence interval |
The first three methods have been recommended by Veroniki et
al. (2016). By default, the Jackson method is used for the
DerSimonian-Laird estimator of and the Q-profile
method for all other estimators of
.
The Profile-Likelihood method is the only method available for the three-level meta-analysis model.
For GLMMs, no confidence intervals for and
are calculated.
R function settings.meta
can be used to change the
previously described and several other default settings for the
current R session.
Some pre-defined general settings are available:
settings.meta("RevMan5")
settings.meta("JAMA")
settings.meta("BMJ")
settings.meta("IQWiG5")
settings.meta("IQWiG6")
settings.meta("geneexpr")
The first command can be used to reproduce meta-analyses from Cochrane reviews conducted with Review Manager 5 (RevMan 5) and specifies to use a RevMan 5 layout in forest plots.
The second command can be used to generate forest plots following
instructions for authors of the Journal of the American
Medical Association
(https://jamanetwork.com/journals/jama/pages/instructions-for-authors/). Study
labels according to JAMA guidelines can be generated using
labels.meta
.
The third command can be used to generate forest plots in the current layout of the British Medical Journal.
The next two commands implement the recommendations of the Institute for Quality and Efficiency in Health Care (IQWiG), Germany accordinging to General Methods 5 and 6, respectively (https://www.iqwig.de/en/about-us/methods/methods-paper/).
The last setting can be used to print p-values in scientific notation and to suppress the calculation of confidence intervals for the between-study variance.
See settings.meta
for more details on these
pre-defined general settings.
In addition, settings.meta
can be used to define
individual settings for the current R session. For example, the
following R command specifies the use of Hartung-Knapp and
Paule-Mandel method, and the printing of prediction intervals for
any meta-analysis generated after execution of this command:
settings.meta(method.random.ci = "HK", method.tau =
"PM", prediction = TRUE)
The following data sets are available in R package meta.
Data set | Description |
Fleiss1993bin |
Aspirin after myocardial infarction |
Fleiss1993cont |
Mental health treatment on medical utilisation |
Olkin1995 |
Thrombolytic therapy after acute myocardial infarction |
Pagliaro1992 |
Prevention of first bleeding in cirrhosis |
amlodipine |
Amlodipine for work capacity |
caffeine |
Caffeine for daytime drowsiness (Cochrane Practice review) |
cisapride |
Cisapride in non-ulcer dispepsia |
lungcancer |
Smoking example |
smoking |
Smoking example |
woodyplants |
Elevated CO$_2$ and total biomass of woody plants |
R package metadat has a large collection of meta-analysis data sets.
Balduzzi et al. (2019) is the preferred citation in publications
for meta. Type citation("meta")
for a BibTeX entry of
this publication.
Type help(package = "meta")
for a listing of all R functions
and datasets available in meta. For example, results of
several meta-analyses can be combined with metabind
which is useful to generate a forest plot with results of several
subgroup analyses.
R package meta imports R functions from metafor (Viechtbauer, 2010) to
estimate the between-study variance ,
conduct meta-regression,
estimate three-level models,
estimate generalised linear mixed models.
To report problems and bugs
type bug.report(package = "meta")
if you do not use
RStudio,
send an email to Guido Schwarzer [email protected] if you use RStudio.
The development version of meta is available on GitHub https://github.com/guido-s/meta/.
Guido Schwarzer [email protected]
Balduzzi S, Rücker G, Schwarzer G (2019): How to perform a meta-analysis with R: a practical tutorial. Evidence-Based Mental Health, 22, 153–160
Biggerstaff BJ, Jackson D (2008): The exact distribution of Cochran’s heterogeneity statistic in one-way random effects meta-analysis. Statistics in Medicine, 27, 6093–110
DerSimonian R & Laird N (1986): Meta-analysis in clinical trials. Controlled Clinical Trials, 7, 177–88
Hartung J, Knapp G (2001a): On tests of the overall treatment effect in meta-analysis with normally distributed responses. Statistics in Medicine, 20, 1771–82
Hartung J, Knapp G (2001b): A refined method for the meta-analysis of controlled clinical trials with binary outcome. Statistics in Medicine, 20, 3875–89
Hedges LV & Olkin I (1985): Statistical methods for meta-analysis. San Diego, CA: Academic Press
Higgins JPT & Thompson SG (2002): Quantifying heterogeneity in a meta-analysis. Statistics in Medicine, 21, 1539–58
Higgins JPT, Thompson SG, Spiegelhalter DJ (2009): A re-evaluation of random-effects meta-analysis. Journal of the Royal Statistical Society: Series A, 172, 137–59
Hunter JE & Schmidt FL (2015): Methods of Meta-Analysis: Correcting Error and Bias in Research Findings (Third edition). Thousand Oaks, CA: Sage
IntHout J, Ioannidis JPA, Borm GF (2014): The Hartung-Knapp-Sidik-Jonkman method for random effects meta-analysis is straightforward and considerably outperforms the standard DerSimonian-Laird method. BMC Medical Research Methodology, 14, 25
IQWiG (2022): General Methods: Version 6.1. https://www.iqwig.de/en/about-us/methods/methods-paper/
Jackson D (2013): Confidence intervals for the between-study variance in random effects meta-analysis using generalised Cochran heterogeneity statistics. Research Synthesis Methods, 4, 220–229
Jackson D, Law M, Rücker G, Schwarzer G (2017): The Hartung-Knapp modification for random-effects meta-analysis: A useful refinement but are there any residual concerns? Statistics in Medicine, 36, 3923–34
Knapp G & Hartung J (2003): Improved tests for a random effects meta-regression with a single covariate. Statistics in Medicine, 22, 2693–710
Langan D, Higgins JPT, Jackson D, Bowden J, Veroniki AA, Kontopantelis E, et al. (2019): A comparison of heterogeneity variance estimators in simulated random-effects meta-analyses. Research Synthesis Methods, 10, 83–98
Schwarzer G (2007): meta: An R package for meta-analysis. R News, 7, 40–5
Schwarzer G, Carpenter JR and Rücker G (2015): Meta-Analysis with R (Use-R!). Springer International Publishing, Switzerland
Skipka G (2006): The inclusion of the estimated inter-study variation into forest plots for random effects meta-analysis - a suggestion for a graphical representation [abstract]. XIV Cochrane Colloquium, Dublin, 23-26.
Stijnen T, Hamza TH, Ozdemir P (2010): Random effects meta-analysis of event outcome in the framework of the generalized linear mixed model with applications in sparse data. Statistics in Medicine, 29, 3046–67
Veroniki AA, Jackson D, Viechtbauer W, Bender R, Bowden J, Knapp G, et al. (2016): Methods to estimate the between-study variance and its uncertainty in meta-analysis. Research Synthesis Methods, 7, 55–79
Veroniki AA, Jackson D, Bender R, Kuss O, Higgins JPT, Knapp G, Salanti G (2019): Methods to calculate uncertainty in the estimated overall effect size from a random-effects meta-analysis. Research Synthesis Methods, 10, 23–43
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
Viechtbauer W (2005): Bias and efficiency of meta-analytic variance estimators in the random-effects model. Journal of Educational and Behavioral Statistics, 30, 261–93
Viechtbauer W (2007): Confidence intervals for the amount of heterogeneity in meta-analysis. Statistics in Medicine, 26, 37–52
Viechtbauer W (2010): Conducting Meta-Analyses in R with the metafor Package. Journal of Statistical Software, 36, 1–48
Wiksten A, Rücker G, Schwarzer G (2016): Hartung-Knapp method is not always conservative compared with fixed-effect meta-analysis. Statistics in Medicine, 35, 2503–15
Auxiliary function to extract parts of pairwise
object.
## S3 method for class 'pairwise' x[...]
## S3 method for class 'pairwise' x[...]
x |
An object of class |
... |
Additional arguments (passed on to [.data.frame). |
Guido Schwarzer [email protected]
pairwise
, subset.pairwise
,
dat.franchini2012
# Transform data from arm-based format to contrast-based format p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = dat.franchini2012, studlab = Study) p1[, 1:5] p1[!grepl("Lieberman", p1$studlab), 1:5]
# Transform data from arm-based format to contrast-based format p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = dat.franchini2012, studlab = Study) p1[, 1:5] p1[!grepl("Lieberman", p1$studlab), 1:5]
Meta-analysis on the effect of amlodipine on work capacity.
This meta-analysis is used as a data example in Hartung and Knapp (2001).
A data frame with the following columns:
study | study label |
n.amlo | number of observations in amlodipine group |
mean.amlo | estimated mean in amlodipine group |
var.amlo | variance in amlodipine group |
n.plac | number of observations in placebo group |
mean.plac | estimated mean in placebo group |
var.plac | variance in placebo group |
Hartung J & Knapp G (2001): On tests of the overall treatment effect in meta-analysis with normally distributed responses. Statistics in Medicine, 20, 1771–82
data(amlodipine) m <- metacont(n.amlo, mean.amlo, sqrt(var.amlo), n.plac, mean.plac, sqrt(var.plac), data = amlodipine, studlab = study, method.tau = "DL") m.hk <- update(m, method.random.ci = "HK") # Same results for mean difference as in Table III in Hartung and # Knapp (2001) # vars.common <- c("TE.common", "lower.common", "upper.common") vars.random <- c("TE.random", "lower.random", "upper.random") # res.common <- as.data.frame(m[vars.common]) names(res.common) <- vars.random # res.md <- rbind(res.common, as.data.frame(m[vars.random]), as.data.frame(m.hk[vars.random])) # res.md <- round(res.md, 5) # row.names(res.md) <- c("CE", "RE", "RE (HaKn)") names(res.md) <- c("Absolute difference", "CI lower", "CI upper") # res.md
data(amlodipine) m <- metacont(n.amlo, mean.amlo, sqrt(var.amlo), n.plac, mean.plac, sqrt(var.plac), data = amlodipine, studlab = study, method.tau = "DL") m.hk <- update(m, method.random.ci = "HK") # Same results for mean difference as in Table III in Hartung and # Knapp (2001) # vars.common <- c("TE.common", "lower.common", "upper.common") vars.random <- c("TE.random", "lower.random", "upper.random") # res.common <- as.data.frame(m[vars.common]) names(res.common) <- vars.random # res.md <- rbind(res.common, as.data.frame(m[vars.random]), as.data.frame(m.hk[vars.random])) # res.md <- round(res.md, 5) # row.names(res.md) <- c("CE", "RE", "RE (HaKn)") names(res.md) <- c("Absolute difference", "CI lower", "CI upper") # res.md
The as.data.frame
method returns a data frame containing
information on individual studies, e.g., estimated treatment effect
and its standard error.
## S3 method for class 'meta' as.data.frame(x, row.names = NULL, optional = FALSE, ...)
## S3 method for class 'meta' as.data.frame(x, row.names = NULL, optional = FALSE, ...)
x |
An object of class |
row.names |
|
optional |
logical. If |
... |
other arguments |
A data frame is returned by the function as.data.frame
.
Guido Schwarzer [email protected]
metabin
, metacont
,
metagen
, forest.meta
data(Fleiss1993cont) # # Generate additional variable with grouping information # Fleiss1993cont$group <- c(1, 2, 1, 1, 2) # # Do meta-analysis without grouping information # m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD", studlab = paste(study, year)) # # Update meta-analysis object and do subgroup analyses # update(m1, subgroup = group) # Same result using metacont function directly # m2 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD", studlab = paste(study, year), subgroup = group) m2 # Compare printout of the following two commands # as.data.frame(m1) m1$data
data(Fleiss1993cont) # # Generate additional variable with grouping information # Fleiss1993cont$group <- c(1, 2, 1, 1, 2) # # Do meta-analysis without grouping information # m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD", studlab = paste(study, year)) # # Update meta-analysis object and do subgroup analyses # update(m1, subgroup = group) # Same result using metacont function directly # m2 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD", studlab = paste(study, year), subgroup = group) m2 # Compare printout of the following two commands # as.data.frame(m1) m1$data
Produce weighted bar plot of risk of bias assessment
## S3 method for class 'rob' barplot( height, overall = FALSE, weighted = TRUE, colour = "cochrane", quiet = FALSE, ... )
## S3 method for class 'rob' barplot( height, overall = FALSE, weighted = TRUE, colour = "cochrane", quiet = FALSE, ... )
height |
An object of class |
overall |
A logical indicating whether to include a bar for overall risk of bias in the figure. |
weighted |
A logical indicating whether weights should be used in the bar plot. |
colour |
Specify colour scheme for the bar plot; see
|
quiet |
A logical to suppress the display of the bar plot. |
... |
Additional arguments (ignored) |
This is a wrapper function for rob_summary
of
R package robvis to produce a weighted bar plot of risk of
bias assessment.
Guido Schwarzer [email protected]
rob
, traffic_light
,
rob_summary
# Use RevMan 5 settings oldset <- settings.meta("RevMan5") data(caffeine) m1 <- metabin(h.caf, n.caf, h.decaf, n.decaf, sm = "OR", data = caffeine, studlab = paste(study, year)) # Add risk of bias assessment to meta-analysis m2 <- rob(D1, D2, D3, D4, D5, overall = rob, data = m1, tool = "rob2") # Print risk of bias assessment rob(m2) ## Not run: # Weighted bar plot (if R package robvis has been installed) barplot(rob(m2)) ## End(Not run) # Use previous settings settings.meta(oldset)
# Use RevMan 5 settings oldset <- settings.meta("RevMan5") data(caffeine) m1 <- metabin(h.caf, n.caf, h.decaf, n.decaf, sm = "OR", data = caffeine, studlab = paste(study, year)) # Add risk of bias assessment to meta-analysis m2 <- rob(D1, D2, D3, D4, D5, overall = rob, data = m1, tool = "rob2") # Print risk of bias assessment rob(m2) ## Not run: # Weighted bar plot (if R package robvis has been installed) barplot(rob(m2)) ## End(Not run) # Use previous settings settings.meta(oldset)
Draw a Baujat plot to explore heterogeneity in meta-analysis.
## S3 method for class 'meta' baujat( x, yscale = 1, xlim, ylim, xlab = "Contribution to overall heterogeneity", ylab = "Influence on overall result", pch = 21, cex = 1, col = "black", bg = "darkgray", studlab = TRUE, cex.studlab = 0.8, pos.studlab, offset = 0.5, xmin = 0, ymin = 0, grid = TRUE, col.grid = "lightgray", lty.grid = "dotted", lwd.grid = par("lwd"), pty = "s", pooled, ... )
## S3 method for class 'meta' baujat( x, yscale = 1, xlim, ylim, xlab = "Contribution to overall heterogeneity", ylab = "Influence on overall result", pch = 21, cex = 1, col = "black", bg = "darkgray", studlab = TRUE, cex.studlab = 0.8, pos.studlab, offset = 0.5, xmin = 0, ymin = 0, grid = TRUE, col.grid = "lightgray", lty.grid = "dotted", lwd.grid = par("lwd"), pty = "s", pooled, ... )
x |
An object of class |
yscale |
Scaling factor for values on y-axis. |
xlim |
The x limits (min,max) of the plot. |
ylim |
The y limits (min,max) of the plot. |
xlab |
A label for the x-axis. |
ylab |
A label for the y-axis. |
pch |
The plotting symbol used for individual studies. |
cex |
The magnification to be used for plotting symbol. |
col |
A vector with colour of plotting symbols. |
bg |
A vector with background colour of plotting symbols (only
used if |
studlab |
A logical indicating whether study labels should be
printed in the graph. A vector with study labels can also be
provided (must be of same length as |
cex.studlab |
The magnification for study labels. |
pos.studlab |
Position of study labels, see argument
|
offset |
Offset for study labels (see |
xmin |
A numeric specifying minimal value to print study labels (on x-axis). |
ymin |
A numeric specifying minimal value to print study labels (on y-axis). |
grid |
A logical indicating whether a grid is printed in the plot. |
col.grid |
Colour for grid lines. |
lty.grid |
The line type for grid lines. |
lwd.grid |
The line width for grid lines. |
pty |
A character specifying type of plot region (see
|
pooled |
A character string indicating whether a common effect
or random effects model is used for pooling. Either missing (see
Details), |
... |
Graphical arguments as in |
Baujat et al. (2002) introduced a scatter plot to explore
heterogeneity in meta-analysis. On the x-axis the contribution of
each study to the overall heterogeneity statistic (see list object
Q
of the meta-analysis object x
) is plotted. On the
y-axis the standardised difference of the overall treatment effect
with and without each study is plotted; this quantity describes the
influence of each study on the overal treatment effect.
Information from object x
is utilised if argument
pooled
is missing. A common effect model is assumed
(pooled="common"
) if argument x$common
is
TRUE
; a random effects model is assumed
(pooled="random"
) if argument x$random
is
TRUE
and x$common
is FALSE
.
Internally, the metainf
function is used to calculate
the values on the y-axis.
A data.frame with the following variables:
x |
Coordinate on x-axis (contribution to heterogeneity statistic) |
y |
Coordinate on y-axis (influence on overall treatment effect) |
Guido Schwarzer [email protected]
Baujat B, Mahé C, Pignon JP, Hill C (2002): A graphical method for exploring heterogeneity in meta-analyses: Application to a meta-analysis of 65 trials. Statistics in Medicine, 30, 2641–52
data(Olkin1995) # Only consider first ten studies m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, sm = "OR", method = "I", studlab = paste(author, year), subset = 1:10) # Generate Baujat plot baujat(m1) ## Not run: m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, sm = "OR", method = "I", studlab = paste(author, year)) # Do not print study labels if the x-value is smaller than 4 and # the y-value is smaller than 1 baujat(m1, yscale = 10, xmin = 4, ymin = 1) # Change position of study labels baujat(m1, yscale = 10, xmin = 4, ymin = 1, pos = 1, xlim = c(0, 6.5)) # Generate Baujat plot and assign x- and y- coordinates to R object # b1 b1 <- baujat(m1) # Calculate overall heterogeneity statistic sum(b1$x) m1$Q ## End(Not run)
data(Olkin1995) # Only consider first ten studies m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, sm = "OR", method = "I", studlab = paste(author, year), subset = 1:10) # Generate Baujat plot baujat(m1) ## Not run: m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, sm = "OR", method = "I", studlab = paste(author, year)) # Do not print study labels if the x-value is smaller than 4 and # the y-value is smaller than 1 baujat(m1, yscale = 10, xmin = 4, ymin = 1) # Change position of study labels baujat(m1, yscale = 10, xmin = 4, ymin = 1, pos = 1, xlim = c(0, 6.5)) # Generate Baujat plot and assign x- and y- coordinates to R object # b1 b1 <- baujat(m1) # Calculate overall heterogeneity statistic sum(b1$x) m1$Q ## End(Not run)
meta
objectCalculate best linear unbiased predictors (BLUPs) for meta-analysis object created with R package meta.
## S3 method for class 'meta' blup(x, level = x$level, backtransf = x$backtransf, ...) ## S3 method for class 'blup.meta' print( x, backtransf = attr(x, "x")$backtransf, digits = gs("digits"), digits.se = gs("digits.se"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), big.mark = gs("big.mark"), se = FALSE, print.tau2 = gs("print.tau2"), print.tau = gs("print.tau"), details = gs("details"), ... ) ## S3 method for class 'blup.meta' estimates( x, se = FALSE, backtransf = attr(x, "x")$backtransf, digits = gs("digits"), digits.se = gs("digits.se"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), writexl = !missing(path), path = "estimates_blup.xlsx", overwrite = FALSE, ... ) ## S3 method for class 'estimates.blup.meta' print(x, big.mark = gs("big.mark"), details = gs("details"), ...)
## S3 method for class 'meta' blup(x, level = x$level, backtransf = x$backtransf, ...) ## S3 method for class 'blup.meta' print( x, backtransf = attr(x, "x")$backtransf, digits = gs("digits"), digits.se = gs("digits.se"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), big.mark = gs("big.mark"), se = FALSE, print.tau2 = gs("print.tau2"), print.tau = gs("print.tau"), details = gs("details"), ... ) ## S3 method for class 'blup.meta' estimates( x, se = FALSE, backtransf = attr(x, "x")$backtransf, digits = gs("digits"), digits.se = gs("digits.se"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), writexl = !missing(path), path = "estimates_blup.xlsx", overwrite = FALSE, ... ) ## S3 method for class 'estimates.blup.meta' print(x, big.mark = gs("big.mark"), details = gs("details"), ...)
x |
An object of class |
level |
The level used to calculate prediction intervals for BLUPs. |
backtransf |
A logical indicating whether BLUPs should be
back transformed. If |
... |
Additional arguments (passed on to |
digits |
Minimal number of significant digits, see
|
digits.se |
Minimal number of significant digits for standard errors. |
digits.tau2 |
Minimal number of significant digits for
between-study variance |
digits.tau |
Minimal number of significant digits for
|
big.mark |
A character used as thousands separator. |
se |
A logical indicating whether standard errors should be printed / extracted. |
print.tau2 |
A logical specifying whether between-study
variance |
print.tau |
A logical specifying whether |
details |
A logical specifying whether details on statistical methods should be printed. |
writexl |
A logical indicating whether an Excel file should be created (R package writexl must be available). |
path |
A character string specifying the filename of the Excel file. |
overwrite |
A logical indicating whether an existing Excel file should be overwritten. |
Data frame with variables
studlab |
Study label |
blup |
estimated best linear unbiased predictor |
se.blup |
standard error (only if argument |
lower |
lower prediction limits |
upper |
upper prediction limits |
Guido Schwarzer [email protected]
m1 <- metabin(tpos, tpos + tneg, cpos, cpos + cneg, data = dat.bcg, studlab = paste(author, year), method = "Inverse") summary(m1) blup(m1) ## Not run: estimates(blup(m1), path = "blup_m1.xlsx") ## End(Not run)
m1 <- metabin(tpos, tpos + tneg, cpos, cpos + cneg, data = dat.bcg, studlab = paste(author, year), method = "Inverse") summary(m1) blup(m1) ## Not run: estimates(blup(m1), path = "blup_m1.xlsx") ## End(Not run)
Draw a bubble plot to display the result of a meta-regression.
## S3 method for class 'metareg' bubble( x, xlim, ylim, xlab, ylab, cex, min.cex = 0.5, max.cex = 5, pch = 21, col = "black", bg = "darkgray", lty = 1, lwd = 1, col.line = "black", studlab = FALSE, cex.studlab = 0.8, pos.studlab = 2, offset = 0.5, regline = TRUE, backtransf = x$.meta$x$backtransf, ref, col.ref = "lightgray", lty.ref = 1, lwd.ref = 1, pscale = x$.meta$x$pscale, irscale = x$.meta$x$irscale, axes = TRUE, box = TRUE, ... ) bubble(x, ...)
## S3 method for class 'metareg' bubble( x, xlim, ylim, xlab, ylab, cex, min.cex = 0.5, max.cex = 5, pch = 21, col = "black", bg = "darkgray", lty = 1, lwd = 1, col.line = "black", studlab = FALSE, cex.studlab = 0.8, pos.studlab = 2, offset = 0.5, regline = TRUE, backtransf = x$.meta$x$backtransf, ref, col.ref = "lightgray", lty.ref = 1, lwd.ref = 1, pscale = x$.meta$x$pscale, irscale = x$.meta$x$irscale, axes = TRUE, box = TRUE, ... ) bubble(x, ...)
x |
An object of class |
xlim |
The x limits (min,max) of the plot. |
ylim |
The y limits (min,max) of the plot. |
xlab |
A label for the x-axis. |
ylab |
A label for the y-axis. |
cex |
The magnification to be used for plotting symbols. |
min.cex |
Minimal magnification for plotting symbols. |
max.cex |
Maximal magnification for plotting symbols. |
pch |
The plotting symbol(s) used for individual studies. |
col |
A vector with colour of plotting symbols. |
bg |
A vector with background colour of plotting symbols (only
used if |
lty |
The line type for the meta-regression line. |
lwd |
The line width for the meta-regression line. |
col.line |
Colour for the meta-regression line. |
studlab |
A logical indicating whether study labels should be printed in the graph. A vector with study labels can also be provided (must be of same length as the numer of studies in the meta-analysis then). |
cex.studlab |
The magnification for study labels. |
pos.studlab |
Position of study labels, see argument
|
offset |
Offset for study labels (see |
regline |
A logical indicating whether a regression line should be added to the bubble plot. |
backtransf |
A logical indicating whether results for relative
summary measures (argument |
ref |
A numerical giving the reference value to be plotted as
a line in the bubble plot. No reference line is plotted if
argument |
col.ref |
Colour of the reference line. |
lty.ref |
The line type for the reference line. |
lwd.ref |
The line width for the reference line. |
pscale |
A numeric giving scaling factor for printing of probabilities. |
irscale |
A numeric defining a scaling factor for printing of incidence rates. |
axes |
Either a logical or a character string equal to |
box |
A logical indicating whether a box should be printed. |
... |
Graphical arguments as in |
A bubble plot can be used to display the result of a meta-regression. It is a scatter plot with the treatment effect for each study on the y-axis and the covariate used in the meta-regression on the x-axis. Typically, the size of the plotting symbol is inversely proportional to the variance of the estimated treatment effect (Thompson & Higgins, 2002).
Argument cex
specifies the plotting size for each individual
study. If this argument is missing the weights from the
meta-regression model will be used (which typically is a random
effects model). Use cex="common"
in order to utilise weights
from a common effect model to define the size of the plotted
symbols (even for a random effects meta-regression). If a vector
with individual study weights is provided, the length of this
vector must be of the same length as the number of studies.
Arguments min.cex
and max.cex
can be used to define
the size of the smallest and largest plotting symbol. The plotting
size of the most precise study is set to max.cex
whereas the
plotting size of all studies with a plotting size smaller than
min.cex
will be set to min.cex
.
For a meta-regression with more than one covariate. Only a scatter plot of the first covariate in the regression model is shown. In this case the effect of the first covariate adjusted for other covariates in the meta-regression model is shown.
For a factor or categorial covariate separate bubble plots for each group compared to the baseline group are plotted.
Guido Schwarzer [email protected]
Thompson SG, Higgins JP (2002): How should meta-regression analyses be undertaken and interpreted? Statistics in Medicine, 21, 1559–73
data(Fleiss1993cont) # Add some (fictitious) grouping variables: Fleiss1993cont$age <- c(55, 65, 52, 65, 58) Fleiss1993cont$region <- c("Europe", "Europe", "Asia", "Asia", "Europe") m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") mr1 <- metareg(m1, region) mr1 bubble(mr1) bubble(mr1, lwd = 2, col.line = "blue") mr2 <- metareg(m1, age) mr2 bubble(mr2, lwd = 2, col.line = "blue", xlim = c(50, 70)) bubble(mr2, lwd = 2, col.line = "blue", xlim = c(50, 70), cex = "common") # Do not print regression line # bubble(mr2, lwd = 2, col.line = "blue", xlim = c(50, 70), regline = FALSE)
data(Fleiss1993cont) # Add some (fictitious) grouping variables: Fleiss1993cont$age <- c(55, 65, 52, 65, 58) Fleiss1993cont$region <- c("Europe", "Europe", "Asia", "Asia", "Europe") m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") mr1 <- metareg(m1, region) mr1 bubble(mr1) bubble(mr1, lwd = 2, col.line = "blue") mr2 <- metareg(m1, age) mr2 bubble(mr2, lwd = 2, col.line = "blue", xlim = c(50, 70)) bubble(mr2, lwd = 2, col.line = "blue", xlim = c(50, 70), cex = "common") # Do not print regression line # bubble(mr2, lwd = 2, col.line = "blue", xlim = c(50, 70), regline = FALSE)
Caffeine for daytime drowsiness (Cochrane Practice review)
A data frame with the following columns:
study | study label |
year | year of publication |
h.caf | Number of participants with headaches (caffeine group) |
n.caf | Number of participants (caffeine group) |
h.decaf | Number of participants with headaches (decaf group) |
n.decaf | Number of participants (decaf group) |
D1 | Domain 1 of risk of bias 2 tool (RoB 2) |
D2 | Domain 2 (RoB 2) |
D3 | Domain 3 (RoB 2) |
D4 | Domain 4 (RoB 2) |
D5 | Domain 5 (RoB 2) |
rob | Overall RoB 2 assessment |
Data come from the Cochrane Practice review on caffeine for daytime drowsiness. Eight fictitous studies evaluate the risk of headaches after drinking either caffeinated or decaffeinated coffee.
Higgins JPT, Savović J, Page MJ, Sterne JA on behalf of the RoB2 Development Group (2019): Revised Cochrane risk-of-bias tool for randomized trials. https://www.riskofbias.info/welcome/rob-2-0-tool
oldset <- settings.meta("RevMan5") data(caffeine) head(caffeine) m1 <- metabin(h.caf, n.caf, h.decaf, n.decaf, sm = "OR", data = caffeine, studlab = paste(study, year)) # Add risk of bias assessment to meta-analysis m1 <- rob(D1, D2, D3, D4, D5, overall = rob, data = m1, tool = "rob2") # Print risk of bias assessment rob(m1) # Forest plot with risk of bias assessment forest(m1) settings.meta(oldset)
oldset <- settings.meta("RevMan5") data(caffeine) head(caffeine) m1 <- metabin(h.caf, n.caf, h.decaf, n.decaf, sm = "OR", data = caffeine, studlab = paste(study, year)) # Add risk of bias assessment to meta-analysis m1 <- rob(D1, D2, D3, D4, D5, overall = rob, data = m1, tool = "rob2") # Print risk of bias assessment rob(m1) # Forest plot with risk of bias assessment forest(m1) settings.meta(oldset)
Calculation of confidence intervals; based on normal approximation or t-distribution.
ci(TE, seTE, level = 0.95, df = NULL, null.effect = 0)
ci(TE, seTE, level = 0.95, df = NULL, null.effect = 0)
TE |
Estimated treatment effect. |
seTE |
Standard error of treatment estimate. |
level |
The confidence level required. |
df |
Degrees of freedom (for confidence intervals based on t-distribution). |
null.effect |
A numeric value specifying the effect under the null hypothesis. |
List with components
TE |
Estimated treatment effect |
seTE |
Standard error of treatment estimate |
lower |
Lower confidence limits |
upper |
Upper confidence limits |
statistic |
Test statistic (either z-score or t-score) |
p |
P-value of text.with null hypothesis |
level |
The confidence level required |
df |
Degrees of freedom (t-distribution) |
This function is primarily called from other functions of the
library meta
, e.g. forest.meta
, summary.meta
.
Guido Schwarzer [email protected]
data.frame(ci(170, 10)) data.frame(ci(170, 10, 0.99)) data.frame(ci(1.959964, 1)) data.frame(ci(2.2621571628, 1, df = 9))
data.frame(ci(170, 10)) data.frame(ci(170, 10, 0.99)) data.frame(ci(1.959964, 1)) data.frame(ci(2.2621571628, 1, df = 9))
Meta-analysis on cisapride in non-ulcer dispepsia.
This meta-analysis is used as a data example in Hartung and Knapp (2001).
A data frame with the following columns:
study | study label |
event.cisa | number of events in cisapride group |
n.cisa | number of observations in cisapride group |
event.plac | number of events in placebo group |
n.plac | number of observations in placebo group |
Hartung J & Knapp G (2001): A refined method for the meta-analysis of controlled clinical trials with binary outcome. Statistics in Medicine, 20, 3875–89
data(cisapride) m.or <- metabin(event.cisa, n.cisa, event.plac, n.plac, data = cisapride, sm = "OR", method = "Inverse", method.tau = "DL", studlab = study, method.incr = "all") m.or.hk <- update(m.or, method.random.ci = "HK") m.rr <- update(m.or, sm = "RR") m.rr.hk <- update(m.or, sm = "RR", method.random.ci = "HK") vars.common <- c("TE.common", "lower.common", "upper.common") vars.random <- c("TE.random", "lower.random", "upper.random") # res.common.or <- as.data.frame(m.or[vars.common]) names(res.common.or) <- vars.random # res.common.rr <- as.data.frame(m.rr[vars.common]) names(res.common.rr) <- vars.random # Results for log risk ratio - see Table VII in Hartung and Knapp (2001) # res.rr <- rbind(res.common.rr, as.data.frame(m.rr[vars.random]), as.data.frame(m.rr.hk[vars.random])) # row.names(res.rr) <- c("CE", "RE", "RE (HaKn)") names(res.rr) <- c("Log risk ratio", "CI lower", "CI upper") # res.rr # Results for log odds ratio (Table VII in Hartung and Knapp 2001) # res.or <- rbind(res.common.or, as.data.frame(m.or[vars.random]), as.data.frame(m.or.hk[vars.random])) # row.names(res.or) <- c("CE", "RE", "RE (HaKn)") names(res.or) <- c("Log odds ratio", "CI lower", "CI upper") # res.or
data(cisapride) m.or <- metabin(event.cisa, n.cisa, event.plac, n.plac, data = cisapride, sm = "OR", method = "Inverse", method.tau = "DL", studlab = study, method.incr = "all") m.or.hk <- update(m.or, method.random.ci = "HK") m.rr <- update(m.or, sm = "RR") m.rr.hk <- update(m.or, sm = "RR", method.random.ci = "HK") vars.common <- c("TE.common", "lower.common", "upper.common") vars.random <- c("TE.random", "lower.random", "upper.random") # res.common.or <- as.data.frame(m.or[vars.common]) names(res.common.or) <- vars.random # res.common.rr <- as.data.frame(m.rr[vars.common]) names(res.common.rr) <- vars.random # Results for log risk ratio - see Table VII in Hartung and Knapp (2001) # res.rr <- rbind(res.common.rr, as.data.frame(m.rr[vars.random]), as.data.frame(m.rr.hk[vars.random])) # row.names(res.rr) <- c("CE", "RE", "RE (HaKn)") names(res.rr) <- c("Log risk ratio", "CI lower", "CI upper") # res.rr # Results for log odds ratio (Table VII in Hartung and Knapp 2001) # res.or <- rbind(res.common.or, as.data.frame(m.or[vars.random]), as.data.frame(m.or.hk[vars.random])) # row.names(res.or) <- c("CE", "RE", "RE (HaKn)") names(res.or) <- c("Log odds ratio", "CI lower", "CI upper") # res.or
Draw a drapery plot with (scaled) p-value curves for individual studies and meta-analysis estimates.
drapery( x, type = "zvalue", layout = "grayscale", study.results = TRUE, lty.study = 1, lwd.study = 1, col.study = "darkgray", labels, col.labels = "black", cex.labels = 0.7, subset.labels, srt.labels, common = x$common, random = x$random, lty.common = 1, lwd.common = max(3, lwd.study), col.common = "blue", lty.random = 1, lwd.random = lwd.common, col.random = "red", sign = NULL, lty.sign = 1, lwd.sign = 1, col.sign = "black", prediction = random, col.predict = "lightblue", alpha = if (type == "zvalue") c(0.001, 0.01, 0.05, 0.1) else c(0.01, 0.05, 0.1), lty.alpha = 2, lwd.alpha = 1, col.alpha = "black", cex.alpha = 0.7, col.null.effect = "black", legend = TRUE, pos.legend = "topleft", bg = "white", bty = "o", backtransf = x$backtransf, xlab, ylab, xlim, ylim, lwd.max = 2.5, lwd.study.weight = if (random) "random" else "common", at = NULL, n.grid = if (type == "zvalue") 10000 else 1000, mar = c(5.1, 4.1, 4.1, 4.1), plot = TRUE, warn.deprecated = gs("warn.deprecated"), fixed, lwd.fixed, lty.fixed, col.fixed, ... )
drapery( x, type = "zvalue", layout = "grayscale", study.results = TRUE, lty.study = 1, lwd.study = 1, col.study = "darkgray", labels, col.labels = "black", cex.labels = 0.7, subset.labels, srt.labels, common = x$common, random = x$random, lty.common = 1, lwd.common = max(3, lwd.study), col.common = "blue", lty.random = 1, lwd.random = lwd.common, col.random = "red", sign = NULL, lty.sign = 1, lwd.sign = 1, col.sign = "black", prediction = random, col.predict = "lightblue", alpha = if (type == "zvalue") c(0.001, 0.01, 0.05, 0.1) else c(0.01, 0.05, 0.1), lty.alpha = 2, lwd.alpha = 1, col.alpha = "black", cex.alpha = 0.7, col.null.effect = "black", legend = TRUE, pos.legend = "topleft", bg = "white", bty = "o", backtransf = x$backtransf, xlab, ylab, xlim, ylim, lwd.max = 2.5, lwd.study.weight = if (random) "random" else "common", at = NULL, n.grid = if (type == "zvalue") 10000 else 1000, mar = c(5.1, 4.1, 4.1, 4.1), plot = TRUE, warn.deprecated = gs("warn.deprecated"), fixed, lwd.fixed, lty.fixed, col.fixed, ... )
x |
An object of class |
type |
A character string indicating whether to plot test
statistics ( |
layout |
A character string for the line layout of individual
studies: |
study.results |
A logical indicating whether results for individual studies should be shown in the figure. |
lty.study |
Line type for individual studies. |
lwd.study |
Line width for individual studies. |
col.study |
Colour of lines for individual studies. |
labels |
A logical or character string indicating whether
study labels should be shown at the top of the drapery plot;
either |
col.labels |
Colour of study labels. |
cex.labels |
The magnification for study labels. |
subset.labels |
A vector specifying which study labels should be shown in the drapery plot. |
srt.labels |
A numerical vector or single numeric (between 0 and 90) specifying the angle to rotate study labels; see Details. |
common |
A logical indicating whether to show result for the common effect model. |
random |
A logical indicating whether to show result for the random effects model. |
lty.common |
Line type for common effect meta-analysis. |
lwd.common |
Line width for common effect meta-analysis. |
col.common |
Colour of lines for common effect meta-analysis. |
lty.random |
Line type for random effects meta-analysis. |
lwd.random |
Line width for random effects meta-analysis. |
col.random |
Colour of lines for random effects meta-analysis. |
sign |
Significance level used to highlight significant values in curves. |
lty.sign |
Line type for significant values. |
lwd.sign |
Line width for significant values. |
col.sign |
Line colour for significant values. |
prediction |
A logical indicating whether to show prediction region. |
col.predict |
Colour of prediction region |
alpha |
Horizonal lines are printed for the specified alpha values. |
lty.alpha |
Line type of horizonal lines for alpha values. |
lwd.alpha |
Line width of horizonal lines for alpha values. |
col.alpha |
Colour of horizonal lines for alpha values. |
cex.alpha |
The magnification for the text of the alpha |
col.null.effect |
Colour of vertical line indicating null effect. |
legend |
A logical indicating whether a legend should be printed. |
pos.legend |
A character string with position of legend (see
|
bg |
Background colour of legend (see |
bty |
Type of the box around the legend; either |
backtransf |
A logical indicating whether results should be
back transformed on the x-axis. For example, if |
xlab |
A label for the x-axis. |
ylab |
A label for the y-axis. |
xlim |
The x limits (min, max) of the plot. |
ylim |
The y limits (min, max) of the plot (ignored if
|
lwd.max |
The maximum line width (only considered if argument
|
lwd.study.weight |
A character string indicating whether to
determine line width for individual studies using weights from
common effect ( |
at |
Points at which tick-marks are to be drawn on the x-axis. |
n.grid |
The number of grid points to calculate the p-value or test statistic functions. |
mar |
Physical plot margin, see |
plot |
A logical indicating whether to generate a figure. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
fixed |
Deprecated argument (replaced by 'common'). |
lwd.fixed |
Deprecated argument (replaced by 'lwd.common'). |
lty.fixed |
Deprecated argument (replaced by 'lty.common'). |
col.fixed |
Deprecated argument (replaced by 'col.common'). |
... |
Graphical arguments as in |
The concept of a p-value function, also called confidence curve, goes back to Birnbaum (1961). A drapery plot, showing p-value functions (or a scaled version based on the corresponding test statistics) for individual studies as well as meta-analysis estimates, is drawn in the active graphics window. Furthermore, a prediction region for a single future study is shown as a shaded area. In contrast to a forest plot, a drapery plot does not provide information for a single confidence level however for any confidence level.
Argument type
can be used to either show p-value functions
(Birnbaum, 1961) or a scaled version (Infanger, 2019) with test
statistics (default).
Argument layout
determines how curves for individual studies
are presented:
darker gray tones with increasing precision (layout =
"grayscale"
)
thicker lines with increasing precision (layout =
"linewidth"
)
equal lines (layout = "equal"
)
Argument labels
determines how curves of individual studies
are labelled:
number of the study in the (unsorted) forest plot / printout
of a meta-analysis (labels = "id"
)
study labels provided by argument studlab
in
meta-analysis functions (labels = "studlab"
)
no study labels (labels = FALSE
)
By default, study labels are used (labels = "studlab"
) if no
label has more than three characters; otherwise IDs are used
(labels = "id"
). The connection between IDs and study labels
(among other information) is part of a data frame which is
invisibly returned (if argument study.results = TRUE
).
Argument srt.labels
can be used to change the rotation of
IDs or study labels. By default, study labels are rotated by +/- 45
degrees if at least one study label has more than three characters;
otherwise labels are not rotated.
If labels = "studlab"
, labels are rotated by -45 degrees for
studies with a treatment estimate below the common effect estimate
and otherwise by 45 degrees.
Gerta Rücker [email protected], Guido Schwarzer [email protected]
Birnbaum A (1961): Confidence Curves: An Omnibus Technique for Estimation and Testing Statistical Hypotheses. Journal of the American Statistical Association, 56, 246–9
Infanger D and Schmidt-Trucksäss A (2019): P value functions: An underused method to present research results and to promote quantitative reasoning Statistics in Medicine, 38, 4189–97
data("lungcancer") m1 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = lungcancer, studlab = study) # Drapery plot # drapery(m1, xlim = c(0.5, 50)) ## Not run: data(Fleiss1993bin) m2 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR", random = FALSE) # Produce drapery plot and print data frame with connection between # IDs and study labels # (drapery(m2)) # For studies with a significant effect (p < 0.05), show # study labels and print labels and lines in red # drapery(m2, labels = "studlab", subset.labels = pval < 0.05, srt.labels = 0, col.labels = "red", col.study = ifelse(pval < 0.05, "red", "darkgray")) ## End(Not run)
data("lungcancer") m1 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = lungcancer, studlab = study) # Drapery plot # drapery(m1, xlim = c(0.5, 50)) ## Not run: data(Fleiss1993bin) m2 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR", random = FALSE) # Produce drapery plot and print data frame with connection between # IDs and study labels # (drapery(m2)) # For studies with a significant effect (p < 0.05), show # study labels and print labels and lines in red # drapery(m2, labels = "studlab", subset.labels = pval < 0.05, srt.labels = 0, col.labels = "red", col.study = ifelse(pval < 0.05, "red", "darkgray")) ## End(Not run)
Extract study and meta-analysis results from meta-analysis object which can be stored in an Excel file.
## S3 method for class 'meta' estimates( x, sortvar, study.results = TRUE, common = x$common, random = x$random, prediction = x$prediction, overall = x$overall, subgroup, prediction.subgroup = x$prediction.subgroup, se = FALSE, ci = TRUE, statistic = FALSE, pval = FALSE, n = TRUE, backtransf = x$backtransf, digits = gs("digits"), digits.se = gs("digits.se"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), writexl = !missing(path), path = "estimates.xlsx", overwrite = FALSE, ... ) estimates(x, ...) ## S3 method for class 'estimates.meta' print( x, digits.tau = gs("digits.tau"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), big.mark = gs("big.mark"), details = TRUE, ... )
## S3 method for class 'meta' estimates( x, sortvar, study.results = TRUE, common = x$common, random = x$random, prediction = x$prediction, overall = x$overall, subgroup, prediction.subgroup = x$prediction.subgroup, se = FALSE, ci = TRUE, statistic = FALSE, pval = FALSE, n = TRUE, backtransf = x$backtransf, digits = gs("digits"), digits.se = gs("digits.se"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), writexl = !missing(path), path = "estimates.xlsx", overwrite = FALSE, ... ) estimates(x, ...) ## S3 method for class 'estimates.meta' print( x, digits.tau = gs("digits.tau"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), big.mark = gs("big.mark"), details = TRUE, ... )
x |
A meta-analysis object of class |
sortvar |
An optional vector used to sort the individual
studies (must be of same length as |
study.results |
A logical indicating whether study results should be extracted. |
common |
A logical indicating whether results of common effect meta-analysis should be extracted. |
random |
A logical indicating whether results of random effects meta-analysis should be extracted. |
prediction |
A logical indicating whether prediction interval should be extracted. |
overall |
A logical indicating whether overall summaries should be extracted. This argument is useful in a meta-analysis with subgroups if overall results should not be extracted. |
subgroup |
A logical indicating whether subgroup results should be extracted. |
prediction.subgroup |
A single logical or logical vector indicating whether / which prediction intervals should be extracted for subgroups. |
se |
A logical indicating whether standard errors should be extracted. |
ci |
A logical indicating whether confidence / prediction interval should be extracted. |
statistic |
A logical indicating whether to extract statistic of test for overall effect. |
pval |
A logical indicating whether to extract p-value of test for overall effect. |
n |
A logical indicating whether sample sizes should be extracted (if available). |
backtransf |
A logical indicating whether extracted results should be back transformed. |
digits |
Minimal number of significant digits, see
|
digits.se |
Minimal number of significant digits for standard
errors, see |
digits.stat |
Minimal number of significant digits for z- or
t-statistic for test of overall effect, see |
digits.pval |
Minimal number of significant digits for p-value
of overall treatment effect, see |
writexl |
A logical indicating whether an Excel file should be created (R package writexl must be available). |
path |
A character string specifying the filename of the Excel file. |
overwrite |
A logical indicating whether an existing Excel file should be overwritten. |
... |
Additional arguments passed on to |
digits.tau |
Minimal number of significant digits for square
root of between-study variance, see |
text.tau2 |
Text printed to identify between-study variance
|
text.tau |
Text printed to identify |
big.mark |
A character used as thousands separator. |
details |
A logical specifying whether details on statistical methods should be printed. |
Extract study and meta-analysis results from meta-analysis object.
By default, a data frame with the results is
generated. Alternatively, an Excel file is created if argument
writexl = TRUE
.
The following information is extracted.
Variable | Content |
studlab | Study label / descriptor of meta-analysis result |
estimate | (Back transformed) estimate for individual studies / meta-analysis |
se | Standard error |
lower | Lower (back transformed) confidence / prediction interval limit |
upper | Upper (back transformed) confidence / prediction interval limit |
k | Number of studies |
df | Degrees of freedom for confidence / prediction intervals |
statistic | Statistic for test of effect |
pval | P-value for test of effect |
n | Total sample size |
n.e | Sample size in first (experimental) group |
n.c | Sample size in second (control) group |
Some variables are only extracted if the corresponding logical
argument se
, ci
, statistic
or n
is
TRUE
. Furthermore, (group) sample sizes are only extracted
if available in the meta-analysis object.
The variables estimate
, lower
and upper
contain the back transformed effects and confidence interval
limits, e.g., odds ratio (argument sm = "OR"
in
metabin
or metagen
) or correlation
(sm = "ZCOR"
in metacor
or
metagen
), if argument backtransf
is
TRUE
. Otherwise, these variables contain the transformed
values, e.g., log odds ratio (sm = "OR"
) or Fisher's Z
transformed correlations (sm = "ZCOR"
). See
meta-sm
for available summary measures and
meta-transf
for the corresponding transformations and
back transformations.
A data frame with additional class 'extract.meta' or an Excel file.
Guido Schwarzer [email protected]
meta-transf
, meta-sm
,
as.data.frame.meta
m1 <- metacor(c(0.85, 0.7, 0.95), c(20, 40, 10)) summary(m1) estimates(m1) estimates(m1, backtransf = FALSE) estimates(update(m1, common = FALSE, random = FALSE)) estimates(update(m1, prediction = TRUE)) estimates(update(m1, prediction = TRUE, level.ma = 0.99, level.predict = 0.9)) ## Not run: # Create Excel file with extracted results # (if R package writexl is available) # fname1 <- tempfile(fileext = ".xlsx") estimates(m1, path = fname1) # An existing Excel file is not overwritten but a warning is printed estimates(m1, path = fname1) # Overwrite an existing Excel file estimates(m1, path = fname1, overwrite = TRUE) # Suppress message on file creation and overwrite existing file suppressMessages(estimates(m1, path = fname1, overwrite = TRUE)) # Save the extracted results in a text file fname2 <- tempfile(fileext = ".csv") fname2 write.csv(estimates(m1), file = fname2, row.names = FALSE) ## End(Not run)
m1 <- metacor(c(0.85, 0.7, 0.95), c(20, 40, 10)) summary(m1) estimates(m1) estimates(m1, backtransf = FALSE) estimates(update(m1, common = FALSE, random = FALSE)) estimates(update(m1, prediction = TRUE)) estimates(update(m1, prediction = TRUE, level.ma = 0.99, level.predict = 0.9)) ## Not run: # Create Excel file with extracted results # (if R package writexl is available) # fname1 <- tempfile(fileext = ".xlsx") estimates(m1, path = fname1) # An existing Excel file is not overwritten but a warning is printed estimates(m1, path = fname1) # Overwrite an existing Excel file estimates(m1, path = fname1, overwrite = TRUE) # Suppress message on file creation and overwrite existing file suppressMessages(estimates(m1, path = fname1, overwrite = TRUE)) # Save the extracted results in a text file fname2 <- tempfile(fileext = ".csv") fname2 write.csv(estimates(m1), file = fname2, row.names = FALSE) ## End(Not run)
Meta-analysis on aspirin in preventing death after myocardial infarction.
Data example in Fleiss (1993) for meta-analysis with binary outcomes.
A data frame with the following columns:
study | study label |
year | year of publication |
d.asp | number of deaths in aspirin group |
n.asp | number of observations in aspirin group |
d.plac | number of deaths in placebo group |
n.plac | number of observations in placebo group |
Fleiss JL (1993): The statistical basis of meta-analysis. Statistical Methods in Medical Research, 2, 121–45
data(Fleiss1993bin) metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR", random = FALSE)
data(Fleiss1993bin) metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR", random = FALSE)
Meta-analysis on the Effect of Mental Health Treatment on Medical Utilisation.
Data example in Fleiss (1993) for meta-analysis with continuous outcomes.
A data frame with the following columns:
study | study label |
year | year of publication |
n.psyc | number of observations in psychotherapy group |
mean.psyc | estimated mean in psychotherapy group |
sd.psyc | standard deviation in psychotherapy group |
n.cont | number of observations in control group |
mean.cont | estimated mean in control group |
sd.cont | standard deviation in control group |
Fleiss JL (1993): The statistical basis of meta-analysis. Statistical Methods in Medical Research, 2, 121–45
data(Fleiss1993cont) # Note, the following command uses the bias-corrected version of # Hedges' g. Accordingly, results differ from Fleiss (1993), section 3, # using the uncorrected version of Hedges' g. metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, studlab = paste(study, year), random = FALSE, sm = "SMD")
data(Fleiss1993cont) # Note, the following command uses the bias-corrected version of # Hedges' g. Accordingly, results differ from Fleiss (1993), section 3, # using the uncorrected version of Hedges' g. metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, studlab = paste(study, year), random = FALSE, sm = "SMD")
Draw a forest plot (using grid graphics system) in the active graphics window or store the forest plot in a file.
## S3 method for class 'meta' forest( x, sortvar, studlab = TRUE, layout = gs("layout"), common = x$common, random = x$random, overall = x$overall, text.common = x$text.common, text.random = x$text.random, lty.common = gs("lty.common"), lty.random = gs("lty.random"), col.common = gs("col.common"), col.random = gs("col.random"), text.w.common = x$text.w.common, text.w.random = x$text.w.random, prediction = x$prediction, text.predict = x$text.predict, subgroup = TRUE, subgroup.hetstat = subgroup & (is.character(hetstat) || hetstat), print.subgroup.labels = TRUE, subgroup.name = x$subgroup.name, print.subgroup.name = x$print.subgroup.name, sep.subgroup = x$sep.subgroup, text.common.w = text.common, text.random.w = text.random, text.predict.w = text.predict, sort.subgroup = gs("sort.subgroup"), pooled.totals = common | random, pooled.events = gs("pooled.events"), pooled.times = gs("pooled.times"), study.results = gs("study.results"), rob = x$rob, rob.text = "Risk of Bias", rob.xpos = 0, rob.legend = TRUE, rob.only = FALSE, xlab = "", xlab.pos, smlab = NULL, smlab.pos, xlim, allstudies = TRUE, weight.study = NULL, pscale = x$pscale, irscale = x$irscale, irunit = x$irunit, file = NULL, width = gs("width"), rows.gr = NULL, func.gr = NULL, args.gr = NULL, dev.off = NULL, ref, lower.equi = gs("lower.equi"), upper.equi = gs("upper.equi"), lty.equi = gs("lty.equi"), col.equi = gs("col.equi"), fill.equi = gs("fill.equi"), fill.lower.equi = fill.equi, fill.upper.equi = rev(fill.equi), fill = gs("fill"), leftcols = gs("leftcols"), rightcols = gs("rightcols"), leftlabs = gs("leftlabs"), rightlabs = gs("rightlabs"), label.e = x$label.e, label.c = x$label.c, label.e.attach = gs("label.e.attach"), label.c.attach = gs("label.c.attach"), label.left = x$label.left, label.right = x$label.right, bottom.lr = gs("bottom.lr"), lab.NA = gs("lab.NA"), lab.NA.effect = gs("lab.NA.effect"), lab.NA.weight = gs("lab.NA.weight"), lwd = gs("lwd"), at = NULL, label = TRUE, col.label = gs("col.label"), type.study = gs("type.study"), type.common = gs("type.common"), type.random = type.common, type.subgroup = ifelse(study.results, "diamond", "square"), type.subgroup.common = type.subgroup, type.subgroup.random = type.subgroup, col.study = gs("col.study"), col.square = gs("col.square"), col.square.lines = gs("col.square.lines"), col.circle = gs("col.circle"), col.circle.lines = col.circle, col.inside = gs("col.inside"), col.inside.common = col.inside, col.inside.random = col.inside, col.diamond = gs("col.diamond"), col.diamond.common = col.diamond, col.diamond.random = col.diamond, col.diamond.lines = gs("col.diamond.lines"), col.diamond.lines.common = col.diamond.lines, col.diamond.lines.random = col.diamond.lines, col.predict = gs("col.predict"), col.predict.lines = gs("col.predict.lines"), col.subgroup = gs("col.subgroup"), col.label.left = x$col.label.left, col.label.right = x$col.label.right, hetstat = common | random | overall.hetstat, overall.hetstat = x$overall.hetstat & !inherits(x, "metamerge"), hetlab = gs("hetlab"), resid.hetstat = gs("resid.hetstat"), resid.hetlab = gs("resid.hetlab"), print.I2 = gs("forest.I2"), print.I2.ci = gs("forest.I2.ci"), print.tau2 = gs("forest.tau2"), print.tau2.ci = gs("forest.tau2.ci"), print.tau = gs("forest.tau"), print.tau.ci = gs("forest.tau.ci"), print.Q = gs("forest.Q"), print.pval.Q = gs("forest.pval.Q"), print.Rb = gs("forest.Rb"), print.Rb.ci = gs("forest.Rb.ci"), text.subgroup.nohet = gs("text.subgroup.nohet"), LRT = gs("LRT"), test.overall = gs("test.overall"), test.overall.common = common & overall & test.overall, test.overall.random = random & overall & test.overall, label.test.overall.common, label.test.overall.random, print.stat = gs("forest.stat"), test.subgroup = x$test.subgroup, test.subgroup.common = test.subgroup & common, test.subgroup.random = test.subgroup & random, common.subgroup = common, random.subgroup = random, prediction.subgroup = x$prediction.subgroup, print.Q.subgroup = gs("forest.Q.subgroup"), label.test.subgroup.common, label.test.subgroup.random, test.effect.subgroup = gs("test.effect.subgroup"), test.effect.subgroup.common, test.effect.subgroup.random, label.test.effect.subgroup.common, label.test.effect.subgroup.random, text.addline1, text.addline2, details = gs("forest.details"), col.lines = gs("col.lines"), header.line, col.header.line = col.lines, col.jama.line = col.subgroup, fontsize = gs("fontsize"), fontfamily = gs("fontfamily"), fs.heading = fontsize, fs.common = gs("fs.common"), fs.random = gs("fs.random"), fs.predict = gs("fs.predict"), fs.common.labels = gs("fs.common.labels"), fs.random.labels = gs("fs.random.labels"), fs.predict.labels = gs("fs.predict.labels"), fs.study = fontsize, fs.study.labels = fs.study, fs.hetstat = gs("fs.hetstat"), fs.test.overall = gs("fs.test.overall"), fs.test.subgroup = gs("fs.test.subgroup"), fs.test.effect.subgroup = gs("fs.test.effect.subgroup"), fs.addline = gs("fs.addline"), fs.axis = fontsize, fs.smlab = fontsize, fs.xlab = fontsize, fs.lr = fontsize, fs.rob = fontsize, fs.rob.symbols = fontsize, fs.details = fontsize, ff.heading = "bold", ff.common = gs("ff.common"), ff.random = gs("ff.random"), ff.predict = gs("ff.predict"), ff.common.labels = gs("ff.common.labels"), ff.random.labels = gs("ff.random.labels"), ff.predict.labels = gs("ff.predict.labels"), ff.study = "plain", ff.study.labels = ff.study, ff.hetstat = gs("ff.hetstat"), ff.test.overall = gs("ff.test.overall"), ff.test.subgroup = gs("ff.test.subgroup"), ff.test.effect.subgroup = gs("ff.test.effect.subgroup"), ff.addline = gs("ff.addline"), ff.axis = gs("ff.axis"), ff.smlab = gs("ff.smlab"), ff.xlab = gs("ff.xlab"), ff.lr = gs("ff.lr"), ff.rob = "plain", ff.rob.symbols = "bold", ff.details = "plain", squaresize = if (layout == "BMJ") 0.9/spacing else 0.8/spacing, lwd.square = gs("lwd.square"), lwd.diamond = gs("lwd.diamond"), arrow.type = gs("arrow.type"), arrow.length = gs("arrow.length"), plotwidth = if (layout %in% c("BMJ", "JAMA")) "8cm" else "6cm", colgap = gs("colgap"), colgap.left = colgap, colgap.right = colgap, colgap.studlab = colgap.left, colgap.forest = gs("colgap.forest"), colgap.forest.left = colgap.forest, colgap.forest.right = colgap.forest, colgap.rob = "1mm", colgap.rob.overall = "2mm", calcwidth.pooled = (common | random) & (overall | !is.null(x$subgroup)), calcwidth.common = calcwidth.pooled, calcwidth.random = calcwidth.pooled, calcwidth.predict = gs("calcwidth.predict"), calcwidth.hetstat = gs("calcwidth.hetstat"), calcwidth.tests = gs("calcwidth.tests"), calcwidth.subgroup = gs("calcwidth.subgroup"), calcwidth.addline = gs("calcwidth.addline"), just = if (layout == "JAMA") "left" else "right", just.studlab = gs("just.studlab"), just.addcols = gs("just.addcols"), just.addcols.left = just.addcols, just.addcols.right = just.addcols, bmj.text = NULL, bmj.xpos = 0, bmj.sep = " / ", spacing = gs("spacing"), addrow = gs("addrow"), addrow.overall = gs("addrow.overall"), addrow.subgroups = gs("addrow.subgroups"), addrows.below.overall = gs("addrows.below.overall"), new = TRUE, backtransf = x$backtransf, digits = gs("digits.forest"), digits.se = gs("digits.se"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), digits.pval.Q = gs("digits.pval.Q"), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), digits.I2 = gs("digits.I2"), digits.weight = gs("digits.weight"), digits.mean = gs("digits.mean"), digits.sd = gs("digits.sd"), digits.cor = digits, digits.time = digits, digits.n = 0, digits.event = 0, digits.TE = gs("digits.TE.forest"), digits.addcols = digits, digits.addcols.right = digits.addcols, digits.addcols.left = digits.addcols, scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), zero.pval = if (layout == "JAMA") FALSE else gs("zero.pval"), JAMA.pval = if (layout == "JAMA") TRUE else gs("JAMA.pval"), warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'meta' plot(x, ...) .forestArgs()
## S3 method for class 'meta' forest( x, sortvar, studlab = TRUE, layout = gs("layout"), common = x$common, random = x$random, overall = x$overall, text.common = x$text.common, text.random = x$text.random, lty.common = gs("lty.common"), lty.random = gs("lty.random"), col.common = gs("col.common"), col.random = gs("col.random"), text.w.common = x$text.w.common, text.w.random = x$text.w.random, prediction = x$prediction, text.predict = x$text.predict, subgroup = TRUE, subgroup.hetstat = subgroup & (is.character(hetstat) || hetstat), print.subgroup.labels = TRUE, subgroup.name = x$subgroup.name, print.subgroup.name = x$print.subgroup.name, sep.subgroup = x$sep.subgroup, text.common.w = text.common, text.random.w = text.random, text.predict.w = text.predict, sort.subgroup = gs("sort.subgroup"), pooled.totals = common | random, pooled.events = gs("pooled.events"), pooled.times = gs("pooled.times"), study.results = gs("study.results"), rob = x$rob, rob.text = "Risk of Bias", rob.xpos = 0, rob.legend = TRUE, rob.only = FALSE, xlab = "", xlab.pos, smlab = NULL, smlab.pos, xlim, allstudies = TRUE, weight.study = NULL, pscale = x$pscale, irscale = x$irscale, irunit = x$irunit, file = NULL, width = gs("width"), rows.gr = NULL, func.gr = NULL, args.gr = NULL, dev.off = NULL, ref, lower.equi = gs("lower.equi"), upper.equi = gs("upper.equi"), lty.equi = gs("lty.equi"), col.equi = gs("col.equi"), fill.equi = gs("fill.equi"), fill.lower.equi = fill.equi, fill.upper.equi = rev(fill.equi), fill = gs("fill"), leftcols = gs("leftcols"), rightcols = gs("rightcols"), leftlabs = gs("leftlabs"), rightlabs = gs("rightlabs"), label.e = x$label.e, label.c = x$label.c, label.e.attach = gs("label.e.attach"), label.c.attach = gs("label.c.attach"), label.left = x$label.left, label.right = x$label.right, bottom.lr = gs("bottom.lr"), lab.NA = gs("lab.NA"), lab.NA.effect = gs("lab.NA.effect"), lab.NA.weight = gs("lab.NA.weight"), lwd = gs("lwd"), at = NULL, label = TRUE, col.label = gs("col.label"), type.study = gs("type.study"), type.common = gs("type.common"), type.random = type.common, type.subgroup = ifelse(study.results, "diamond", "square"), type.subgroup.common = type.subgroup, type.subgroup.random = type.subgroup, col.study = gs("col.study"), col.square = gs("col.square"), col.square.lines = gs("col.square.lines"), col.circle = gs("col.circle"), col.circle.lines = col.circle, col.inside = gs("col.inside"), col.inside.common = col.inside, col.inside.random = col.inside, col.diamond = gs("col.diamond"), col.diamond.common = col.diamond, col.diamond.random = col.diamond, col.diamond.lines = gs("col.diamond.lines"), col.diamond.lines.common = col.diamond.lines, col.diamond.lines.random = col.diamond.lines, col.predict = gs("col.predict"), col.predict.lines = gs("col.predict.lines"), col.subgroup = gs("col.subgroup"), col.label.left = x$col.label.left, col.label.right = x$col.label.right, hetstat = common | random | overall.hetstat, overall.hetstat = x$overall.hetstat & !inherits(x, "metamerge"), hetlab = gs("hetlab"), resid.hetstat = gs("resid.hetstat"), resid.hetlab = gs("resid.hetlab"), print.I2 = gs("forest.I2"), print.I2.ci = gs("forest.I2.ci"), print.tau2 = gs("forest.tau2"), print.tau2.ci = gs("forest.tau2.ci"), print.tau = gs("forest.tau"), print.tau.ci = gs("forest.tau.ci"), print.Q = gs("forest.Q"), print.pval.Q = gs("forest.pval.Q"), print.Rb = gs("forest.Rb"), print.Rb.ci = gs("forest.Rb.ci"), text.subgroup.nohet = gs("text.subgroup.nohet"), LRT = gs("LRT"), test.overall = gs("test.overall"), test.overall.common = common & overall & test.overall, test.overall.random = random & overall & test.overall, label.test.overall.common, label.test.overall.random, print.stat = gs("forest.stat"), test.subgroup = x$test.subgroup, test.subgroup.common = test.subgroup & common, test.subgroup.random = test.subgroup & random, common.subgroup = common, random.subgroup = random, prediction.subgroup = x$prediction.subgroup, print.Q.subgroup = gs("forest.Q.subgroup"), label.test.subgroup.common, label.test.subgroup.random, test.effect.subgroup = gs("test.effect.subgroup"), test.effect.subgroup.common, test.effect.subgroup.random, label.test.effect.subgroup.common, label.test.effect.subgroup.random, text.addline1, text.addline2, details = gs("forest.details"), col.lines = gs("col.lines"), header.line, col.header.line = col.lines, col.jama.line = col.subgroup, fontsize = gs("fontsize"), fontfamily = gs("fontfamily"), fs.heading = fontsize, fs.common = gs("fs.common"), fs.random = gs("fs.random"), fs.predict = gs("fs.predict"), fs.common.labels = gs("fs.common.labels"), fs.random.labels = gs("fs.random.labels"), fs.predict.labels = gs("fs.predict.labels"), fs.study = fontsize, fs.study.labels = fs.study, fs.hetstat = gs("fs.hetstat"), fs.test.overall = gs("fs.test.overall"), fs.test.subgroup = gs("fs.test.subgroup"), fs.test.effect.subgroup = gs("fs.test.effect.subgroup"), fs.addline = gs("fs.addline"), fs.axis = fontsize, fs.smlab = fontsize, fs.xlab = fontsize, fs.lr = fontsize, fs.rob = fontsize, fs.rob.symbols = fontsize, fs.details = fontsize, ff.heading = "bold", ff.common = gs("ff.common"), ff.random = gs("ff.random"), ff.predict = gs("ff.predict"), ff.common.labels = gs("ff.common.labels"), ff.random.labels = gs("ff.random.labels"), ff.predict.labels = gs("ff.predict.labels"), ff.study = "plain", ff.study.labels = ff.study, ff.hetstat = gs("ff.hetstat"), ff.test.overall = gs("ff.test.overall"), ff.test.subgroup = gs("ff.test.subgroup"), ff.test.effect.subgroup = gs("ff.test.effect.subgroup"), ff.addline = gs("ff.addline"), ff.axis = gs("ff.axis"), ff.smlab = gs("ff.smlab"), ff.xlab = gs("ff.xlab"), ff.lr = gs("ff.lr"), ff.rob = "plain", ff.rob.symbols = "bold", ff.details = "plain", squaresize = if (layout == "BMJ") 0.9/spacing else 0.8/spacing, lwd.square = gs("lwd.square"), lwd.diamond = gs("lwd.diamond"), arrow.type = gs("arrow.type"), arrow.length = gs("arrow.length"), plotwidth = if (layout %in% c("BMJ", "JAMA")) "8cm" else "6cm", colgap = gs("colgap"), colgap.left = colgap, colgap.right = colgap, colgap.studlab = colgap.left, colgap.forest = gs("colgap.forest"), colgap.forest.left = colgap.forest, colgap.forest.right = colgap.forest, colgap.rob = "1mm", colgap.rob.overall = "2mm", calcwidth.pooled = (common | random) & (overall | !is.null(x$subgroup)), calcwidth.common = calcwidth.pooled, calcwidth.random = calcwidth.pooled, calcwidth.predict = gs("calcwidth.predict"), calcwidth.hetstat = gs("calcwidth.hetstat"), calcwidth.tests = gs("calcwidth.tests"), calcwidth.subgroup = gs("calcwidth.subgroup"), calcwidth.addline = gs("calcwidth.addline"), just = if (layout == "JAMA") "left" else "right", just.studlab = gs("just.studlab"), just.addcols = gs("just.addcols"), just.addcols.left = just.addcols, just.addcols.right = just.addcols, bmj.text = NULL, bmj.xpos = 0, bmj.sep = " / ", spacing = gs("spacing"), addrow = gs("addrow"), addrow.overall = gs("addrow.overall"), addrow.subgroups = gs("addrow.subgroups"), addrows.below.overall = gs("addrows.below.overall"), new = TRUE, backtransf = x$backtransf, digits = gs("digits.forest"), digits.se = gs("digits.se"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), digits.pval.Q = gs("digits.pval.Q"), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), digits.I2 = gs("digits.I2"), digits.weight = gs("digits.weight"), digits.mean = gs("digits.mean"), digits.sd = gs("digits.sd"), digits.cor = digits, digits.time = digits, digits.n = 0, digits.event = 0, digits.TE = gs("digits.TE.forest"), digits.addcols = digits, digits.addcols.right = digits.addcols, digits.addcols.left = digits.addcols, scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), zero.pval = if (layout == "JAMA") FALSE else gs("zero.pval"), JAMA.pval = if (layout == "JAMA") TRUE else gs("JAMA.pval"), warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'meta' plot(x, ...) .forestArgs()
x |
An object of class |
sortvar |
An optional vector used to sort the individual
studies (must be of same length as |
studlab |
A logical indicating whether study labels should be
printed in the graph. A vector with study labels can also be
provided (must be of same length as |
layout |
A character string specifying the layout of the forest plot (see Details). |
common |
A logical indicating whether common effect estimate should be plotted. |
random |
A logical indicating whether random effects estimate should be plotted. |
overall |
A logical indicating whether overall summaries should be plotted. This argument is useful in a meta-analysis with subgroups if summaries should only be plotted on group level. |
text.common |
A character string used in the plot to label the pooled common effect estimate. |
text.random |
A character string used in the plot to label the pooled random effects estimate. |
lty.common |
Line type of pooled common effect estimate. |
lty.random |
Line type of pooled random effects estimate. |
col.common |
Line colour of pooled common effect estimate. |
col.random |
Line colour of pooled random effects estimate. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
prediction |
A logical indicating whether a prediction interval should be printed. |
text.predict |
A character string used in the plot to label the prediction interval. |
subgroup |
A single logical or logical vector indicating whether / which subgroup results should be shown in forest plot. This argument is useful in a meta-analysis with subgroups if summaries should not be plotted for (some) subgroups. |
subgroup.hetstat |
A single logical or logical vector indicating whether / which information on heterogeneity in subgroups should be shown in forest plot. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should not be printed for (some) subgroups. |
print.subgroup.labels |
A logical indicating whether subgroup label should be printed. |
subgroup.name |
A character string with a label for the grouping variable. |
print.subgroup.name |
A logical indicating whether the name of the grouping variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between label and levels of grouping variable. |
text.common.w |
A character string to label the pooled common effect estimate within subgroups, or a character vector of same length as number of subgroups with corresponging labels. |
text.random.w |
A character string to label the pooled random effect estimate within subgroups, or a character vector of same length as number of subgroups with corresponging labels. |
text.predict.w |
A character string to label the prediction interval within subgroups, or a character vector of same length as number of subgroups with corresponging labels. |
sort.subgroup |
A logical indicating whether groups should be ordered alphabetically. |
pooled.totals |
A logical indicating whether total number of observations should be given in the figure. |
pooled.events |
A logical indicating whether total number of events should be given in the figure. |
pooled.times |
A logical indicating whether total person time at risk should be given in the figure. |
study.results |
A logical indicating whether results for individual studies should be shown in the figure (useful to only plot subgroup results). |
rob |
Risk of bias (RoB) assessment. |
rob.text |
Column heading for RoB table. |
rob.xpos |
A numeric specifying the horizontal position of the
risk of bias label in RoB table heading. The value is a so called
normalised parent coordinate in the horizontal direction (see
|
rob.legend |
A logical specifying whether a legend with RoB domains should be printed. |
rob.only |
A logical indicating whether the risk of bias assessment is the only information printed on the right side of the forest plot. |
xlab |
A label for the x-axis. |
xlab.pos |
A numeric specifying the center of the label on the x-axis. |
smlab |
A label for the summary measure (printed at top of figure). |
smlab.pos |
A numeric specifying the center of the label for the summary measure. |
xlim |
The x limits (min,max) of the plot, or the character string "symmetric" to produce symmetric forest plots. |
allstudies |
A logical indicating whether studies with inestimable treatment effects should be included in the forest plot. |
weight.study |
A character string indicating weighting used to
determine size of squares or diamonds (argument
|
pscale |
A numeric giving scaling factor for printing of
single event probabilities or risk differences, i.e. if argument
|
irscale |
A numeric defining a scaling factor for printing of
single incidence rates or incidence rate differences, i.e. if
argument |
irunit |
A character specifying the time unit used to calculate rates, e.g., person-years. |
file |
File name. |
width |
Width of graphics file. |
rows.gr |
Additional rows in forest plot to change height of graphics file (e.g., in order to add a title at the top of the forest plot). |
func.gr |
Name of graphics function, e.g., |
args.gr |
List with additional graphical parameters passed on to graphics function (argument 'height' cannot be provided as the height is calculated internally; use instead argument 'rows.gr'). |
dev.off |
A logical to specify whether current graphics device should be shut down, i.e., whether file should be stored. |
ref |
A numerical giving the reference value to be plotted as
a line in the forest plot. No reference line is plotted if
argument |
lower.equi |
A numerical giving the lower limit of equivalence
to be plotted as a line in the forest plot. Or a vector to
provide several limits, e.g., for large, moderate and small
effects. No line is plotted if argument |
upper.equi |
A numerical giving the upper limit of equivalence
to be plotted as a line in the forest plot. Or a vector to
provide several limits, e.g., for small, moderate and large
effects. No line is plotted if argument |
lty.equi |
Line type (limits of equivalence). |
col.equi |
Line colour (limits of equivalence). |
fill.equi |
Colour(s) for area between limits of equivalence or more general limits. |
fill.lower.equi |
Colour of area between lower limit(s) and reference value. Can be equal to the number of lower limits or the number of limits plus 1 (in this case the the region between minimum and smallest limit is also filled). |
fill.upper.equi |
Colour of area between reference value and upper limit(s). Can be equal to the number of upper limits or the number of limits plus 1 (in this case the region between largest limit and maximum is also filled). |
fill |
Colour for background of confidence interval plot. |
leftcols |
A character vector specifying (additional) columns to be printed on the left side of the forest plot or a logical value (see Details). |
rightcols |
A character vector specifying (additional) columns to be printed on the right side of the forest plot or a logical value (see Details). |
leftlabs |
A character vector specifying labels for (additional) columns on left side of the forest plot (see Details). |
rightlabs |
A character vector specifying labels for (additional) columns on right side of the forest plot (see Details). |
label.e |
Label to be used for experimental group in table heading. |
label.c |
Label to be used for control group in table heading. |
label.e.attach |
A character specifying the column name where
label |
label.c.attach |
A character specifying the column name where
label |
label.left |
Graph label on left side of null effect. |
label.right |
Graph label on right side of null effect. |
bottom.lr |
A logical indicating whether labels on right and left side should be printed at bottom or top of forest plot. |
lab.NA |
A character string to label missing values. |
lab.NA.effect |
A character string to label missing values in individual treatment estimates and confidence intervals. |
lab.NA.weight |
A character string to label missing weights. |
lwd |
The line width, see |
at |
The points at which tick-marks are to be drawn, see
|
label |
A logical value indicating whether to draw the labels
on the tick marks, or an expression or character vector which
specify the labels to use. See |
col.label |
The colour of labels on the x-axis. |
type.study |
A character string or vector specifying how to plot treatment effects and confidence intervals for individual studies (see Details). |
type.common |
A character string specifying how to plot treatment effect and confidence interval for common effect meta-analysis (see Details). |
type.random |
A character string specifying how to plot treatment effect and confidence interval for random effects meta-analysis (see Details). |
type.subgroup |
A character string specifying how to plot treatment effect and confidence interval for subgroup results (see Details). |
type.subgroup.common |
A character string specifying how to plot treatment effect and confidence interval for subgroup results (common effect model). |
type.subgroup.random |
A character string specifying how to plot treatment effect and confidence interval for subgroup results (random effects model). |
col.study |
The colour for individual study results and confidence limits. |
col.square |
The colour for squares reflecting study's weight in the meta-analysis. |
col.square.lines |
The colour for the outer lines of squares reflecting study's weight in the meta-analysis. |
col.circle |
The colour for circles reflecting study weights in the meta-analysis. |
col.circle.lines |
The colour for the outer lines of circles reflecting study's weight in the meta-analysis. |
col.inside |
The colour for individual study results and confidence limits if confidence limits are completely within squares. |
col.inside.common |
The colour for result of common effect meta-analysis if confidence limit lies completely within square. |
col.inside.random |
The colour for result of random effects meta-analysis if confidence limit lies completely within square. |
col.diamond |
The colour of diamonds representing the results for common effect and random effects models. |
col.diamond.common |
The colour(s) of diamonds for common effect estimates. |
col.diamond.random |
The colour(s) of diamonds for random effects estimates. |
col.diamond.lines |
The colour of the outer lines of diamonds representing the results for common effect and random effects models. |
col.diamond.lines.common |
The colour(s) of the outer lines of diamond for common effect estimate. |
col.diamond.lines.random |
The colour(s) of the outer lines of diamond for random effects estimate. |
col.predict |
Background colour(s) of prediction intervals. |
col.predict.lines |
Colour(s) of outer lines of prediction intervals. |
col.subgroup |
The colour to print information on subgroups. |
col.label.left |
The colour of the label on the left side of the null effect. |
col.label.right |
The colour of the label on the right side of the null effect. |
hetstat |
Either a logical value indicating whether to print results for heterogeneity measures at all or a character string (see Details). |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
hetlab |
Label printed in front of results for heterogeneity measures. |
resid.hetstat |
A logical value indicating whether to print measures of residual heterogeneity in a meta-analysis with subgroups. |
resid.hetlab |
Label printed in front of results for residual heterogeneity measures. |
print.I2 |
A logical value indicating whether to print the value of the I-squared statistic. |
print.I2.ci |
A logical value indicating whether to print the confidence interval of the I-squared statistic. |
print.tau2 |
A logical value indicating whether to print the
value of the between-study variance |
print.tau2.ci |
A logical value indicating whether to print
the confidence interval of |
print.tau |
A logical value indicating whether to print
|
print.tau.ci |
A logical value indicating whether to print the
confidence interval of |
print.Q |
A logical value indicating whether to print the value of the heterogeneity statistic Q. |
print.pval.Q |
A logical value indicating whether to print the p-value of the heterogeneity statistic Q. |
print.Rb |
A logical value indicating whether to print the value of the I-squared statistic. |
print.Rb.ci |
A logical value indicating whether to print the confidence interval of the I-squared statistic. |
text.subgroup.nohet |
A logical value or character string which is printed to indicate subgroups with less than two studies contributing to meta-analysis (and thus without heterogeneity). If FALSE, heterogeneity statistics are printed (with NAs). |
LRT |
A logical value indicating whether to report Likelihood-Ratio or Wald-type test of heterogeneity for generalised linear mixed models. |
test.overall |
A logical value indicating whether to print results of test for overall effect. |
test.overall.common |
A logical value indicating whether to print results of test for overall effect (common effect model). |
test.overall.random |
A logical value indicating whether to print results of test for overall effect (random effects model). |
label.test.overall.common |
Label printed in front of results of test for overall effect (common effect model). |
label.test.overall.random |
Label printed in front of results of test for overall effect (random effects model). |
print.stat |
A logical value indicating whether z- or t-value for test of treatment effect should be printed. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
test.subgroup.common |
A logical value indicating whether to print results of test for subgroup differences (common effect model). |
test.subgroup.random |
A logical value indicating whether to print results of test for subgroup differences (random effects model). |
common.subgroup |
A single logical or logical vector indicating whether / which common effect estimates should be printed for subgroups. |
random.subgroup |
A single logical or logical vector indicating whether / which random effects estimates should be printed for subgroups. |
prediction.subgroup |
A single logical or logical vector indicating whether / which prediction intervals should be printed for subgroups. |
print.Q.subgroup |
A logical value indicating whether to print the value of the heterogeneity statistic Q (test for subgroup differences). |
label.test.subgroup.common |
Label printed in front of results of test for subgroup differences (common effect model). |
label.test.subgroup.random |
Label printed in front of results of test for subgroup differences (random effects model). |
test.effect.subgroup |
A single logical or logical vector indicating whether / which tests for effect in subgroups should be printed. |
test.effect.subgroup.common |
A single logical or logical vector indicating whether / which tests for effect in subgroups should be printed (common effect model). |
test.effect.subgroup.random |
A single logical or logical vector indicating whether / which tests for effect in subgroups should be printed (random effects model). |
label.test.effect.subgroup.common |
Label printed in front of results of test for effect in subgroups (common effect model). |
label.test.effect.subgroup.random |
Label printed in front of results of test for effect in subgroups (random effects model). |
text.addline1 |
Text for first additional line (below meta-analysis results). |
text.addline2 |
Text for second additional line (below meta-analysis results). |
details |
A logical specifying whether details on statistical methods should be printed. |
col.lines |
The colour of lines. |
header.line |
A logical value indicating whether to print a header line or a character string ("both", "below", ""). |
col.header.line |
Colour of the header line(s). |
col.jama.line |
Colour of the additional JAMA lines. |
fontsize |
The size of text (in points), see
|
fontfamily |
The font family, see |
fs.heading |
The size of text for column headings, see
|
fs.common |
The size of text for results of common effect
model, see |
fs.random |
The size of text for results of random effects
model, see |
fs.predict |
The size of text for results of prediction
interval, see |
fs.common.labels |
The size of text for label of common effect
model, see |
fs.random.labels |
The size of text for label of random
effects model, see |
fs.predict.labels |
The size of text for label of prediction
interval, see |
fs.study |
The size of text for results of individual studies,
see |
fs.study.labels |
The size of text for labels of individual
studies, see |
fs.hetstat |
The size of text for heterogeneity measures, see
|
fs.test.overall |
The size of text of test for overall effect,
see |
fs.test.subgroup |
The size of text of test of subgroup
differences, see |
fs.test.effect.subgroup |
The size of text of test of effect
in subgroups, see |
fs.addline |
The size of text for additional lines, see
|
fs.axis |
The size of text on x-axis, see |
fs.smlab |
The size of text of label for summary measure, see
|
fs.xlab |
The size of text of label on x-axis, see
|
fs.lr |
The size of text of label on left and right side of
forest plot, see |
fs.rob |
The size of text of risk of bias items in the legend,
see |
fs.rob.symbols |
The size of risk of bias symbols, see
|
fs.details |
The size of text for details on (meta-analysis)
methods, see |
ff.heading |
The fontface for column headings, see
|
ff.common |
The fontface of text for results of common effect
model, see |
ff.random |
The fontface of text for results of random effects
model, see |
ff.predict |
The fontface of text for results of prediction
interval, see |
ff.common.labels |
The fontface of text for label of common
effect model, see |
ff.random.labels |
The fontface of text for label of random
effects model, see |
ff.predict.labels |
The fontface of text for label of
prediction interval, see |
ff.study |
The fontface of text for results of individual
studies, see |
ff.study.labels |
The fontface of text for labels of
individual studies, see |
ff.hetstat |
The fontface of text for heterogeneity measures,
see |
ff.test.overall |
The fontface of text of test for overall
effect, see |
ff.test.subgroup |
The fontface of text for test of subgroup
differences, see |
ff.test.effect.subgroup |
The fontface of text for test of
effect in subgroups, see |
ff.addline |
The fontface of text for additional lines, see
|
ff.axis |
The fontface of text on x-axis, see
|
ff.smlab |
The fontface of text of label for summary measure,
see |
ff.xlab |
The fontface of text of label on x-axis, see
|
ff.lr |
The fontface of text of label on left and right side
of forest plot, see |
ff.rob |
The fontface of text of risk of bias items, see
|
ff.rob.symbols |
The fontface of risk of bias symbols, see
|
ff.details |
The fontface for details on (meta-analysis)
methods, see |
squaresize |
A numeric used to increase or decrease the size of squares in the forest plot. |
lwd.square |
The line width of the border around squares. |
lwd.diamond |
The line width of the border around diamonds. |
arrow.type |
A character string indicating whether arrows
printed for results outside the forest plot should be
|
arrow.length |
The length of arrows in inches. |
plotwidth |
Either a character string, e.g., "8cm", "60mm", or
"3inch", or a |
colgap |
Either a character string or a
|
colgap.left |
Either a character string or a
|
colgap.right |
Either a character string or a
|
colgap.studlab |
Either a character string or a
|
colgap.forest |
Either a character string or a
|
colgap.forest.left |
Either a character string or a
|
colgap.forest.right |
Either a character string or a
|
colgap.rob |
Either a character string or a
|
colgap.rob.overall |
Either a character string or a
|
calcwidth.pooled |
A logical indicating whether text for common effect and random effects model should be considered to calculate width of the column with study labels. |
calcwidth.common |
A logical indicating whether text given in
arguments |
calcwidth.random |
A logical indicating whether text given in
arguments |
calcwidth.predict |
A logical indicating whether text given in
argument |
calcwidth.hetstat |
A logical indicating whether text for heterogeneity statistics should be considered to calculate width of the column with study labels. |
calcwidth.tests |
A logical indicating whether text for tests of overall effect or subgroup differences should be considered to calculate width of the column with study labels. |
calcwidth.subgroup |
A logical indicating whether text with subgroup labels should be considered to calculate width of the column with study labels. |
calcwidth.addline |
A logical indicating whether text for additional lines should be considered to calculate width of the column with study labels. |
just |
Justification of text in all columns but columns with study labels and additional variables (possible values: "left", "right", "center"). |
just.studlab |
Justification of text for study labels (possible values: "left", "right", "center"). |
just.addcols |
Justification of text for additional columns (possible values: "left", "right", "center"). |
just.addcols.left |
Justification of text for additional columns on left side of forest plot (possible values: "left", "right", "center"). Can be of same length as number of additional columns on left side of forest plot. |
just.addcols.right |
Justification of text for additional columns on right side of forest plot (possible values: "left", "right", "center"). Can be of same length as number of additional columns on right side of forest plot. |
bmj.text |
A character string used in the plot with BMJ layout to label the group specific information. |
bmj.xpos |
A numeric specifying the horizontal position of the
BMJ label. The value is a so called normalised parent coordinate
in the horizontal direction (see |
bmj.sep |
A character string used to separate sample sizes from number of events or means / standard deviations. |
spacing |
A numeric determining line spacing in a forest plot. |
addrow |
A logical value indicating whether an empty row is printed above study results. |
addrow.overall |
A logical value indicating whether an empty row is printed above overall meta-analysis results. |
addrow.subgroups |
A logical value indicating whether an empty row is printed between results for subgroups. |
addrows.below.overall |
A numeric value indicating how many empty rows are printed between meta-analysis results and heterogeneity statistics and test results. |
new |
A logical value indicating whether a new figure should be printed in an existing graphics window. |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
digits |
Minimal number of significant digits for treatment
effects, see |
digits.se |
Minimal number of significant digits for standard errors. |
digits.stat |
Minimal number of significant digits for z- or t-statistic for test of overall effect. |
digits.pval |
Minimal number of significant digits for p-value of overall treatment effect. |
digits.pval.Q |
Minimal number of significant digits for p-value of heterogeneity test. |
digits.Q |
Minimal number of significant digits for heterogeneity statistic Q. |
digits.tau2 |
Minimal number of significant digits for between-study variance. |
digits.tau |
Minimal number of significant digits for square root of between-study variance. |
digits.I2 |
Minimal number of significant digits for I-squared statistic. |
digits.weight |
Minimal number of significant digits for weights. |
digits.mean |
Minimal number of significant digits for means;
only applies to |
digits.sd |
Minimal number of significant digits for standard
deviations; only applies to |
digits.cor |
Minimal number of significant digits for
correlations; only applies to |
digits.time |
Minimal number of significant digits for times;
only applies to |
digits.n |
Minimal number of significant digits for sample sizes. |
digits.event |
Minimal number of significant digits for event numbers. |
digits.TE |
Minimal number of significant digits for list element 'TE'. |
digits.addcols |
A vector or scalar with minimal number of significant digits for additional columns. |
digits.addcols.right |
A vector or scalar with minimal number of significant digits for additional columns on right side of forest plot. |
digits.addcols.left |
A vector or scalar with minimal number of significant digits for additional columns on left side of forest plot. |
scientific.pval |
A logical specifying whether p-values should be printed in scientific notation, e.g., 1.2345e-01 instead of 0.12345. |
big.mark |
A character used as thousands separator. |
zero.pval |
A logical specifying whether p-values should be printed with a leading zero. |
JAMA.pval |
A logical specifying whether p-values for test of overall effect should be printed according to JAMA reporting standards. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional graphical arguments. |
A forest plot, also called confidence interval plot, is drawn in the active graphics window. The forest functions in R package meta are based on the grid graphics system. Resize the graphics windows if the forest plot is too large or too small for the graphics window. Alternatively, save the forest plot in a file.
A forest plot can be directly stored in a file using argument
file
or specifying the R function for the graphics device
driver using argument func.gr
, e.g., pdf
. If
only the filename is provided, the extension is checked and matched
against the most common graphics device drivers.
Extension | Graphics device |
.pdf |
pdf |
.ps |
postscript |
.svg |
svg |
.bmp |
bmp |
.jpg / .jpeg |
jpeg |
.png |
png |
.tif / .tiff |
tiff
|
The height of the graphics device is automatically determined if
the forest plot is saved to a file. Argument rows.gr
can be
used to increase or decrease the number of rows shown in the forest
plot (either to show missing information or to remove
whitespace). The width of the graphics device can be specified with
argument width
, see, for example, pdf
or
jpeg
. Other arguments of graphics device functions
can be provided as a list in argument args.gr
.
Alternatively, the (resized) graphics window can be stored to a
file using either dev.copy2eps
or
dev.copy2pdf
. It is also possible to manually create
a file using, for example, pdf
, png
, or
svg
and to specify the width and height of the
graphic (see Examples).
By default, treatment estimates and confidence intervals are plotted in the following way:
For an individual study, a square with treatment estimate in
the center and confidence interval as line extending either side
of the square (type.study = "square"
)
For meta-analysis results, a diamond with treatment estimate
in the center and right and left side corresponding to lower and
upper confidence limits (type.common = "diamond"
,
type.random = "diamond"
, and type.subgroup = "diamond"
)
In a forest plot, size of the squares typically reflects the precision of
individual treatment estimates based either on the common effect
(weight.study = "common"
) or random effects meta-analysis
(weight.study = "random"
). Information from meta-analysis object
x
is utilised if argument weight.study
is missing. Weights
from the common effect model are used if argument x$common
is
TRUE
; weights from the random effects model are used if argument
x$random
is TRUE
and x$common
is FALSE
.
The same square sizes are used if weight.study = "same"
.
A prediction interval for treatment effect of a new study (Higgins
et al., 2009) is given in the forest plot if arguments
prediction
and random
are TRUE
. For
graphical presentation of prediction intervals the approach by
Guddat et al. (2012) is used.
Argument leftcols
can be used to specify columns which are
printed on the left side of the forest plot. By default, i.e. if
argument leftcols
is NULL
and layout = "meta"
,
and depending on the class of the meta-analysis object (which is
defined by the R function used to generate the object) a different
set of columns is printed on the left
side of the forest plot:
Function | Value of argument leftcols |
metabin |
c("studlab", "event.e", "n.e",
"event.c", "n.c") |
metacont |
c("studlab", "n.e", "mean.e",
"sd.e", "n.c", "mean.c", "sd.c") |
metacor |
c("studlab", "n") |
metagen |
c("studlab", "TE", "seTE") |
metainc |
c("studlab", "event.e", "time.e",
"event.c", "time.c") |
metamean |
c("studlab", "n", "mean", "sd")
|
metaprop |
c("studlab", "event", "n") |
metarate |
c("studlab", "event", "time", "n")
|
metacum |
"studlab" |
metainf |
"studlab"
|
For three-level models, the cluster variable is printed next to the
study labels (value "cluster"
in argument leftcols
).
By default, study labels and labels for pooled estimates and
heterogeneity statistics will be printed in the first column on the
left side of the forest plot. The character string "studlab"
is used to identify study labels as this is the name of the list
element of a meta-analysis object.
If the character string "studlab"
is not provided in
leftcols
and rightcols
, the first additional
variable specified by the user is used as study labels (and labels
for pooled estimates are printed in this column). Additional
variables are any variables not mentioned in the section on
predefined column names below. For example, leftcols =
"studlab"
and leftcols = "study"
would result in the same
forest plot if the variable "study"
was used in the command
to conduct the meta-analysis. If no additional variable is provided
by the user, no study labels will be printed.
Depending on the number of columns printed on the left side of the
forest plot, information on heterogeneity measures or statistical
tests (see below) can be overlapping with the x-axis. Argument
addrows.below.overall
can be used to specify the number of
empty rows that are printed between meta-analysis results and
information on heterogeneity measures and statistical tests. By
default, no additional rows are added to the forest plot. If
addrows.below.overall = NULL
, the function tries to add a
sufficient number of empty rows to prevent overlapping
text. Another possibility is to manually increase the space between
the columns on the left side (argument colgap.left
) or
between the columns on the left side and the forest plot (argument
colgap.forest.left
).
Argument rightcols
can be used to
specify columns which are printed on the right side of the
forest plot. If argument rightcols
is
FALSE
, no columns will be printed on the right side. By
default, i.e. if argument rightcols
is
NULL
and layout = "meta"
, the following
columns will be printed on the right side
of the forest plot:
Meta-analysis results | Value of argument rightcols |
No summary | c("effect", "ci") |
Only common effect model | c("effect", "ci", "w.common")
|
Only random effects model | c("effect", "ci", "w.random")
|
Both models | c("effect", "ci", "w.common", "w.random")
|
By default, estimated treatment effect and corresponding confidence
interval will be printed. Depending on arguments common
and
random
, weights of the common effect and/or random effects
model will be given too.
For an object of class metacum
or
metainf
the following columns will be printed:
c("effect", "ci", "pval", "tau2", "tau", "I2")
. This
information corresponds to the printout with
print.meta
.
The arguments leftlabs
and rightlabs
can be used to
specify column headings which are printed on left or right side of
the forest plot. For certain columns predefined labels exist which
are used by default, i.e., if arguments leftlabs
and
rightlabs
are NULL
:
Column: | studlab |
TE |
seTE |
cluster |
n.e |
n.c |
Label: | "Study" | "TE" | "seTE" | "Cluster" | "Total" | "Total" |
Column: | n |
event.e |
event.c |
event |
mean.e |
mean.c |
Label: | "Total" | "Events" | "Events" | "Events" | "Mean" | "Mean" |
Column: | sd.e |
sd.c |
time.e
|
time.c |
effect |
|
Label: | "SD" | "SD" | "Time" | "Time" |
x$sm |
|
Column: | ci |
effect.ci |
w.common |
w.random |
cycles |
|
Label: | x$level "%-CI" |
effect+ci | "W(common)" | "W(random)" | "Cycles" |
For other columns, the column name will be used as a label if no
column label is defined. It is possible to only provide labels for
new columns (see Examples). Otherwise the length of leftlabs
and rightlabs
must be the same as the number of printed
columns. The value NA
can be used to specify columns which
should use default labels (see Examples).
In pairwise meta-analysis comparing two groups (i.e.,
metabin
, metacont
,
metainc
, and metagen
depending on the
outcome), arguments label.e
and label.c
are used to
label columns belonging to the two treatment groups. By default,
labels defined in the meta-analysis object are used. The columns
where treatment labels are attached can be changed using arguments
label.e.attach
and label.c.attach
.
A risk of bias (RoB) assessment can be shown in the forest plot by
either using a meta-analysis object with an RoB assessment as main
input or providing a suitable object created with
rob
. Argument rob = FALSE
can be used to
suppress the print of the risk of bias information.
RoB assessments are shown as the only information on the right side
of the forest plot. Thus, arguments rightcols
and
rightlabs
should not be used. Predefined columns shown by
default on the right side of a forest plot will be moved to the
left side.
Argument hetstat
can be a character string to specify where
to print heterogeneity information:
row with results for common effect model (hetstat =
"common"
),
row with results for random effects model (hetstat =
"random"
).
Otherwise, information on heterogeneity measures is printed below
the meta-analysis results if argument overall.hetstat = TRUE
(default). The heterogeneity measures to print can be specified
(see list of arguments following overall.hetstat
).
In addition, the following arguments can be used to print results for various statistical tests:
Argument | Statistical test |
test.overall.common |
Test for overall effect (common effect model) |
test.overall.random |
Test for overall effect (random effects model) |
test.effect.subgroup.common |
Test for effect in subgroup (CE model) |
test.effect.subgroup.random |
Test for effect in subgroup (RE model) |
test.subgroup.common |
Test for subgroup differences (CE model) |
test.subgroup.random |
Test for subgroup differences (RE model) |
By default, these arguments are FALSE
with exception of
tests for subgroup differences which are TRUE
. R function
settings.meta
can be used to change this default for
the entire R session. For example, use the following command to
always print results of tests for an overall effect:
settings.meta(test.overall = TRUE)
.
Argument subgroup
determines whether summary results are
printed for subgroups. A logical vector of length equal to the
number of subgroups can be provided to determine which subgroup
summaries are printed. By default, only subgroup results based on
at least two studies are printed which is identical to use argument
subgroup = k.w > 1
. The order of the logical vector
corresponds to the order of subgroups in list element 'subgroup.levels' of a
meta-analysis object. Argument subgroup = k.w >= 1
can be
used to show results for all subgroups (including those with a
single study).
The following arguments can be used in a similar way:
subgroup.hetstat
(heterogeneity statistic in
subgroups),
common.subgroup
(common effect estimates in
subgroups),
random.subgroup
(random effects estimates in
subgroups),
prediction.subgroup
(prediction interval in
subgroups),
test.effect.subgroup
(test for effect in subgroups),
test.effect.subgroup.common
(test for effect in
subgroups, common effect model),
test.effect.subgroup.random
(test for effect in
subgroups, random effects model).
Arguments text.common
, text.random
, and
text.predict
can be used to change the label to identify
overall results (common effect and random effects model as well as
prediction interval). By default the following text is printed:
"Common effect model" (argument text.common
)
"Random effects model" (text.random
)
"Prediction interval" (text.predict
)
If confidence interval levels are different for individual studies,
meta-analysis, and prediction interval (arguments level
,
level.ma
, level.predict
in meta-analysis functions,
e.g., metabin
), additional information is printed,
e.g., " (99%-CI)" for a 99% confidence interval in the
meta-analysis.
Argument pscale
can be used to rescale single proportions or
risk differences, e.g., pscale = 1000
means that proportions
are expressed as events per 1000 observations. This is useful in
situations with (very) low event probabilities.
Argument irscale
can be used to rescale single rates or rate
differences, e.g., irscale = 1000
means that rates are
expressed as events per 1000 time units, e.g., person-years. This is
useful in situations with (very) low rates. Argument irunit
can be used to specify the time unit used in individual studies
(default: "person-years"). This information is printed in summaries
and forest plots if argument irscale
is not equal to 1.
If argument layout = "RevMan5"
(and arguments leftcols
and
rightcols
are NULL
), the layout for forest plots used for
Cochrane reviews (which were generated with Review Manager 5) is reproduced:
All columns are printed on the left side of the forest plot
(see arguments leftcols
and rightcols
)
Tests for overall effect and subgroup differences are printed
(test.overall
, test.effect.subgroup
,
test.subgroup
)
Diamonds representing meta-analysis results are printed in
black (diamond.common
, diamond.random
)
Colour of squares depends on the meta-analysis object
(col.square
, col.square.lines
)
Information on effect measure and meta-analysis method is
printed above the forest plot (smlab
)
Label "Study or Subgroup" is printed for meta-analysis with
subgroups (leftlabs
)
If argument layout = "JAMA"
(and arguments leftcols
and
rightcols
are NULL
), instructions for authors of the
Journal of the American Medical Association, see
https://jamanetwork.com/journals/jama/pages/instructions-for-authors/,
are taken into account:
Graph labels on right and left side are printed in bold font
at top of forest plot (see arguments bottom.lr
and
ff.lr
)
Information on effect measure and level of confidence
interval is printed at bottom of forest plot (xlab
)
Tests for overall effect are printed (test.overall
)
Diamonds representing meta-analysis results are printed in
lightblue (diamond.common
, diamond.random
)
Squares representing individual study results are printed in
darkblue (col.square
, col.square.lines
)
Between-study variance is not printed
Empty rows are omitted (addrow
, addrow.overall
,
addrow.subgroups
)
Label "Source" is printed instead of "Study" (leftlabs
)
P-values are printed without leading zeros (zero.pval
)
P-values are rounded to three digits (for 0.001 < p
0.01) or two digits (p > 0.01) (
JAMA.pval
)
Study labels according to JAMA guidelines can be generated using
labels.meta
.
The following changes are conducted if argument
layout = "subgroup"
(and arguments leftcols
and
rightcols
are NULL
) and a subgroup analysis was
conducted:
Individual study results are omitted (see argument
study.results
)
Total number of observations is not printed
(pooled.totals
)
Label "Subgroup" is printed instead of "Study"
(leftlabs
)
R function .forestArgs
generates a character vector with all
arguments of forest.meta
.
Guido Schwarzer [email protected]
Guddat C, Grouven U, Bender R, Skipka G (2012): A note on the graphical presentation of prediction intervals in random-effects meta-analyses. Systematic Reviews, 1, 34
Higgins JPT, Thompson SG, Spiegelhalter DJ (2009): A re-evaluation of random-effects meta-analysis. Journal of the Royal Statistical Society: Series A, 172, 137-59
metabin
, metacont
,
metagen
, forest.metabind
,
settings.meta
, labels.meta
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = c(41, 47, 51, 59), sm = "RR", method = "I", studlab = paste(author, year)) ## Not run: # Do standard (symmetric) forest plot # forest(m1) ## End(Not run) # Layout of forest plot similar to Review Manager 5 # # Furthermore, add labels on both sides of forest plot and # prediction interval # forest(m1, layout = "RevMan5", common = FALSE, label.left = "Favours experimental", col.label.left = "green", label.right = "Favours control", col.label.right = "red", prediction = TRUE) ## Not run: # Create PDF files with the forest plot # # - specify filename (R function pdf() is used due to extension .pdf) # - height of the figure is automatically determined # - width is set to 10 inches forest(m1, file = "forest-m1-1.pdf", width = 10) # # - specify graphics device function # (filename "Rplots.pdf" used, see help page of R function pdf()) # - height of the figure is automatically determined # - width is set to 10 inches # - set title for PDF file # - set background of forest plot forest(m1, func.gr = pdf, width = 10, args.gr = list(title = "My Forest Plot", bg = "green")) # # - manually specify the height of the figure pdf("forest-m1-2.pdf", width = 10, height = 3) forest(m1) dev.off() # Define equivalence limits: 0.75 and 1 / 0.75 # forest(m1, layout = "RevMan5", common = FALSE, lower.equi = 0.75, upper.equi = 1 / 0.75, fill.equi = "lightgray") # Fill areas with beneficial and detrimental effects # forest(m1, layout = "RevMan5", common = FALSE, lower.equi = 0.75, upper.equi = 1 / 0.75, fill.lower.equi = c("green", "lightgray"), fill.upper.equi = c("lightgray", "red")) # Define thresholds for small, moderate and large effects # and use hcl.colors() to define colours to fill areas # thresholds <- c(0.25, 0.5, 0.75) n.cols <- length(thresholds) + 1 forest(m1, layout = "RevMan5", common = FALSE, label.left = "Desirable effect", label.right = "Undesirable effect", lty.equi = 3, col.equi = "darkgray", lower.equi = thresholds, upper.equi = 1 / rev(thresholds), fill.lower.equi = hcl.colors(n.cols, palette = "Blues 2", alpha = 0.6), fill.upper.equi = hcl.colors(n.cols, palette = "Oranges", alpha = 0.6, rev = TRUE)) # Conduct subgroup meta-analysis # m2 <- update(m1, subgroup = ifelse(year < 1987, "Before 1987", "1987 and later"), print.subgroup.name = FALSE) # Show summary results for subgroups with at least two studies # forest(m2, sortvar = -TE, random = FALSE) # Show results for all subgroups # forest(m2, sortvar = -TE, random = FALSE, subgroup = k.w >= 1) # Forest plot specifying argument xlim # forest(m1, xlim = c(0.01, 10)) # Print results of test for overall effect # forest(m1, test.overall.common = TRUE, test.overall.random = TRUE) # Forest plot with 'classic' layout used in R package meta, # version < 1.6-0 # forest(m1, col.square = "black", hetstat = FALSE) # Change set of columns printed on left side of forest plot # (resulting in overlapping text) # forest(m1, random = FALSE, leftcols = "studlab") # Use argument 'calcwidth.hetstat' to consider text for heterogeneity # measures in width of column with study labels # forest(m1, random = FALSE, leftcols = "studlab", calcwidth.hetstat = TRUE) # Use argument 'addrows.below.overall' to manually add two empty # rows # forest(m1, random = FALSE, leftcols = "studlab", addrows = 2) # Do not print columns on right side of forest plot # forest(m1, rightcols = FALSE) # Change study label to "Author" # forest(m1, random = FALSE, leftlabs = c("Author", NA, NA, NA, NA)) # Just give effect estimate and 95% confidence interval on right # side of forest plot (in one column) # forest(m1, rightcols = "effect.ci") # Just give effect estimate and 95% confidence interval on right # side of forest plot # forest(m1, rightcols = c("effect", "ci")) # 1. Change order of columns on left side # 2. Attach labels to columns 'event.e' and 'event.c' instead of # columns 'n.e' and 'n.c' # forest(m1, leftcols = c("studlab", "n.e", "event.e", "n.c", "event.c"), label.e.attach = "event.e", label.c.attach = "event.c") # Specify column labels only for variables 'year' and 'author' # (and define digits for additional variables) # forest(m1, leftcols = c("studlab", "event.e", "n.e", "event.c", "n.c", "author", "year"), leftlabs = c("Author", "Year of Publ")) # Center text in all columns # forest(m1, leftcols = c("studlab", "event.e", "n.e", "event.c", "n.c", "author", "year"), leftlabs = c("Author", "Year of Publ"), hetstat = FALSE, just = "center", just.addcols = "center", just.studlab = "center") # Same result # forest(m1, leftcols = c("studlab", "event.e", "n.e", "event.c", "n.c", "author", "year"), leftlabs = c("Author", "Year of Publ"), hetstat = FALSE, just = "c", just.addcols = "c", just.studlab = "c") # Change some fontsizes and fontfaces # forest(m1, fs.study = 10, ff.study = "italic", fs.study.label = 11, ff.study.label = "bold", fs.axis = 5, ff.axis = "italic", ff.smlab = "bold.italic", ff.common = "plain", ff.hetstat = "plain") # Change some colours # forest(m1, col.diamond = "green", col.diamond.lines = "red", col.study = c("green", "blue", "red", "orange"), col.square = "pink", col.square.lines = "black") # Sort by weight in common effect model # forest(m1, sortvar = w.common, random = FALSE) # Sort by decreasing weight in common effect model # forest(m1, sortvar = -w.common, random = FALSE) # Sort by size of treatment effect # forest(m1, sortvar = TE, random = FALSE) # Sort by size of treatment effect # forest(m1, sortvar = -TE, random = FALSE) # Sort by decreasing year of publication # forest(m1, sortvar = -year, random = FALSE) # Print results of test for subgroup differences (random effects # model) # forest(m2, sortvar = -TE, common = FALSE) # Print only subgroup results # forest(m2, layout = "subgroup") # Print only subgroup results (and consider text for tests of # subgroup differences in width of subgroup column) # forest(m2, layout = "subgroup", calcwidth.tests = TRUE) # Print only subgroup results (and consider text for heterogeneity # in width of subgroup column) # forest(m2, layout = "subgroup", calcwidth.hetstat = TRUE) ## End(Not run)
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = c(41, 47, 51, 59), sm = "RR", method = "I", studlab = paste(author, year)) ## Not run: # Do standard (symmetric) forest plot # forest(m1) ## End(Not run) # Layout of forest plot similar to Review Manager 5 # # Furthermore, add labels on both sides of forest plot and # prediction interval # forest(m1, layout = "RevMan5", common = FALSE, label.left = "Favours experimental", col.label.left = "green", label.right = "Favours control", col.label.right = "red", prediction = TRUE) ## Not run: # Create PDF files with the forest plot # # - specify filename (R function pdf() is used due to extension .pdf) # - height of the figure is automatically determined # - width is set to 10 inches forest(m1, file = "forest-m1-1.pdf", width = 10) # # - specify graphics device function # (filename "Rplots.pdf" used, see help page of R function pdf()) # - height of the figure is automatically determined # - width is set to 10 inches # - set title for PDF file # - set background of forest plot forest(m1, func.gr = pdf, width = 10, args.gr = list(title = "My Forest Plot", bg = "green")) # # - manually specify the height of the figure pdf("forest-m1-2.pdf", width = 10, height = 3) forest(m1) dev.off() # Define equivalence limits: 0.75 and 1 / 0.75 # forest(m1, layout = "RevMan5", common = FALSE, lower.equi = 0.75, upper.equi = 1 / 0.75, fill.equi = "lightgray") # Fill areas with beneficial and detrimental effects # forest(m1, layout = "RevMan5", common = FALSE, lower.equi = 0.75, upper.equi = 1 / 0.75, fill.lower.equi = c("green", "lightgray"), fill.upper.equi = c("lightgray", "red")) # Define thresholds for small, moderate and large effects # and use hcl.colors() to define colours to fill areas # thresholds <- c(0.25, 0.5, 0.75) n.cols <- length(thresholds) + 1 forest(m1, layout = "RevMan5", common = FALSE, label.left = "Desirable effect", label.right = "Undesirable effect", lty.equi = 3, col.equi = "darkgray", lower.equi = thresholds, upper.equi = 1 / rev(thresholds), fill.lower.equi = hcl.colors(n.cols, palette = "Blues 2", alpha = 0.6), fill.upper.equi = hcl.colors(n.cols, palette = "Oranges", alpha = 0.6, rev = TRUE)) # Conduct subgroup meta-analysis # m2 <- update(m1, subgroup = ifelse(year < 1987, "Before 1987", "1987 and later"), print.subgroup.name = FALSE) # Show summary results for subgroups with at least two studies # forest(m2, sortvar = -TE, random = FALSE) # Show results for all subgroups # forest(m2, sortvar = -TE, random = FALSE, subgroup = k.w >= 1) # Forest plot specifying argument xlim # forest(m1, xlim = c(0.01, 10)) # Print results of test for overall effect # forest(m1, test.overall.common = TRUE, test.overall.random = TRUE) # Forest plot with 'classic' layout used in R package meta, # version < 1.6-0 # forest(m1, col.square = "black", hetstat = FALSE) # Change set of columns printed on left side of forest plot # (resulting in overlapping text) # forest(m1, random = FALSE, leftcols = "studlab") # Use argument 'calcwidth.hetstat' to consider text for heterogeneity # measures in width of column with study labels # forest(m1, random = FALSE, leftcols = "studlab", calcwidth.hetstat = TRUE) # Use argument 'addrows.below.overall' to manually add two empty # rows # forest(m1, random = FALSE, leftcols = "studlab", addrows = 2) # Do not print columns on right side of forest plot # forest(m1, rightcols = FALSE) # Change study label to "Author" # forest(m1, random = FALSE, leftlabs = c("Author", NA, NA, NA, NA)) # Just give effect estimate and 95% confidence interval on right # side of forest plot (in one column) # forest(m1, rightcols = "effect.ci") # Just give effect estimate and 95% confidence interval on right # side of forest plot # forest(m1, rightcols = c("effect", "ci")) # 1. Change order of columns on left side # 2. Attach labels to columns 'event.e' and 'event.c' instead of # columns 'n.e' and 'n.c' # forest(m1, leftcols = c("studlab", "n.e", "event.e", "n.c", "event.c"), label.e.attach = "event.e", label.c.attach = "event.c") # Specify column labels only for variables 'year' and 'author' # (and define digits for additional variables) # forest(m1, leftcols = c("studlab", "event.e", "n.e", "event.c", "n.c", "author", "year"), leftlabs = c("Author", "Year of Publ")) # Center text in all columns # forest(m1, leftcols = c("studlab", "event.e", "n.e", "event.c", "n.c", "author", "year"), leftlabs = c("Author", "Year of Publ"), hetstat = FALSE, just = "center", just.addcols = "center", just.studlab = "center") # Same result # forest(m1, leftcols = c("studlab", "event.e", "n.e", "event.c", "n.c", "author", "year"), leftlabs = c("Author", "Year of Publ"), hetstat = FALSE, just = "c", just.addcols = "c", just.studlab = "c") # Change some fontsizes and fontfaces # forest(m1, fs.study = 10, ff.study = "italic", fs.study.label = 11, ff.study.label = "bold", fs.axis = 5, ff.axis = "italic", ff.smlab = "bold.italic", ff.common = "plain", ff.hetstat = "plain") # Change some colours # forest(m1, col.diamond = "green", col.diamond.lines = "red", col.study = c("green", "blue", "red", "orange"), col.square = "pink", col.square.lines = "black") # Sort by weight in common effect model # forest(m1, sortvar = w.common, random = FALSE) # Sort by decreasing weight in common effect model # forest(m1, sortvar = -w.common, random = FALSE) # Sort by size of treatment effect # forest(m1, sortvar = TE, random = FALSE) # Sort by size of treatment effect # forest(m1, sortvar = -TE, random = FALSE) # Sort by decreasing year of publication # forest(m1, sortvar = -year, random = FALSE) # Print results of test for subgroup differences (random effects # model) # forest(m2, sortvar = -TE, common = FALSE) # Print only subgroup results # forest(m2, layout = "subgroup") # Print only subgroup results (and consider text for tests of # subgroup differences in width of subgroup column) # forest(m2, layout = "subgroup", calcwidth.tests = TRUE) # Print only subgroup results (and consider text for heterogeneity # in width of subgroup column) # forest(m2, layout = "subgroup", calcwidth.hetstat = TRUE) ## End(Not run)
Draws a forest plot in the active graphics window (using grid graphics system).
## S3 method for class 'metabind' forest( x, leftcols, leftlabs, rightcols = c("effect", "ci"), rightlabs, common = x$common, random = x$random, overall = x$overall, subgroup = FALSE, hetstat = FALSE, overall.hetstat = x$overall.hetstat, prediction = x$prediction, lab.NA = "", col.square = gs("col.square"), col.square.lines = col.square, col.circle = gs("col.circle"), col.circle.lines = col.circle, col.diamond = gs("col.diamond"), col.diamond.common = col.diamond, col.diamond.random = col.diamond, col.diamond.lines = gs("col.diamond.lines"), col.diamond.lines.common = col.diamond.lines, col.diamond.lines.random = col.diamond.lines, col.predict = gs("col.predict"), col.predict.lines = gs("col.predict.lines"), type = NULL, type.common = NULL, type.random = NULL, type.predict = NULL, digits = gs("digits.forest"), digits.se = gs("digits.se"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval") - 2, 2), digits.pval.Q = max(gs("digits.pval.Q") - 2, 2), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), digits.I2 = max(gs("digits.I2") - 1, 0), scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), print.subgroup.labels = x$with.subgroups, addrow.subgroups = print.subgroup.labels, smlab, calcwidth.pooled = overall, warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'metabind' forest( x, leftcols, leftlabs, rightcols = c("effect", "ci"), rightlabs, common = x$common, random = x$random, overall = x$overall, subgroup = FALSE, hetstat = FALSE, overall.hetstat = x$overall.hetstat, prediction = x$prediction, lab.NA = "", col.square = gs("col.square"), col.square.lines = col.square, col.circle = gs("col.circle"), col.circle.lines = col.circle, col.diamond = gs("col.diamond"), col.diamond.common = col.diamond, col.diamond.random = col.diamond, col.diamond.lines = gs("col.diamond.lines"), col.diamond.lines.common = col.diamond.lines, col.diamond.lines.random = col.diamond.lines, col.predict = gs("col.predict"), col.predict.lines = gs("col.predict.lines"), type = NULL, type.common = NULL, type.random = NULL, type.predict = NULL, digits = gs("digits.forest"), digits.se = gs("digits.se"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval") - 2, 2), digits.pval.Q = max(gs("digits.pval.Q") - 2, 2), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), digits.I2 = max(gs("digits.I2") - 1, 0), scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), print.subgroup.labels = x$with.subgroups, addrow.subgroups = print.subgroup.labels, smlab, calcwidth.pooled = overall, warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
leftcols |
A character vector specifying (additional) columns to be plotted on the left side of the forest plot or a logical value (see Details). |
leftlabs |
A character vector specifying labels for (additional) columns on left side of the forest plot (see Details). |
rightcols |
A character vector specifying (additional) columns to be plotted on the right side of the forest plot or a logical value (see Details). |
rightlabs |
A character vector specifying labels for (additional) columns on right side of the forest plot (see Details). |
common |
A logical indicating whether common effect estimates should be plotted. |
random |
A logical indicating whether random effects estimates should be plotted. |
overall |
A logical indicating whether overall summaries should be plotted. This argument is useful in a meta-analysis with subgroups if summaries should only be plotted on group level. |
subgroup |
A logical indicating whether subgroup results should be shown in forest plot. This argument is useful in a meta-analysis with subgroups if summaries should not be plotted on group level. |
hetstat |
Either a logical value indicating whether to print results for heterogeneity measures at all or a character string (see Details). |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether prediction interval(s) should be printed. |
lab.NA |
A character string to label missing values. |
col.square |
The colour for squares reflecting study's weight in the meta-analysis. |
col.square.lines |
The colour for the outer lines of squares reflecting study's weight in the meta-analysis. |
col.circle |
The colour for circles reflecting study weights in the meta-analysis. |
col.circle.lines |
The colour for the outer lines of circles reflecting study's weight in the meta-analysis. |
col.diamond |
The colour of diamonds representing the results for common effect and random effects models. |
col.diamond.common |
The colour of diamonds for common effect estimates. |
col.diamond.random |
The colour of diamonds for random effects estimates. |
col.diamond.lines |
The colour of the outer lines of diamonds representing the results for common effect and random effects models. |
col.diamond.lines.common |
The colour of the outer lines of diamond for common effect estimates. |
col.diamond.lines.random |
The colour of the outer lines of diamond for random effects estimates. |
col.predict |
Background colour of prediction intervals. |
col.predict.lines |
Colour of outer lines of prediction intervals. |
type |
A character string or vector specifying how to plot estimates. |
type.common |
A single character string specifying how to plot common effect estimates. |
type.random |
A single character string specifying how to plot random effects estimates. |
type.predict |
A single character string specifying how to plot prediction intervals. |
digits |
Minimal number of significant digits for treatment
effects, see |
digits.se |
Minimal number of significant digits for standard
errors, see |
digits.stat |
Minimal number of significant digits for z- or
t-statistic for test of overall effect, see |
digits.pval |
Minimal number of significant digits for p-value
of overall treatment effect, see |
digits.pval.Q |
Minimal number of significant digits for
p-value of heterogeneity test, see |
digits.Q |
Minimal number of significant digits for
heterogeneity statistic Q, see |
digits.tau2 |
Minimal number of significant digits for
between-study variance, see |
digits.tau |
Minimal number of significant digits for square
root of between-study variance, see |
digits.I2 |
Minimal number of significant digits for I-squared
statistic, see |
scientific.pval |
A logical specifying whether p-values should be printed in scientific notation, e.g., 1.2345e-01 instead of 0.12345. |
big.mark |
A character used as thousands separator. |
print.subgroup.labels |
A logical indicating whether subgroup label should be printed. |
addrow.subgroups |
A logical value indicating whether an empty row is printed between results for subgroups. |
smlab |
A label for the summary measurex (printed at top of figure). |
calcwidth.pooled |
A logical indicating whether text for common effect and random effects model should be considered to calculate width of the column with study labels. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional graphical arguments (passed on to
|
A forest plot, also called confidence interval plot, is drawn in
the active graphics window. The forest functions in R package
meta are based on the grid graphics system. In order to
print the forest plot, resize the graphics window and either use
dev.copy2eps
or dev.copy2pdf
. Another
possibility is to create a file using pdf
,
png
, or svg
and to specify the width
and height of the graphic (see forest.meta
examples).
The arguments leftcols
and rightcols
can be used to
specify columns which are plotted on the left and right side of the
forest plot, respectively.
The arguments leftlabs
and rightlabs
can be used to
specify column headings which are plotted on left and right side of
the forest plot, respectively. For certain columns predefined
labels exist. For other columns, the column name will be used as a
label. It is possible to only provide labels for new columns (see
forest.meta
examples). Otherwise the length of
leftlabs
and rightlabs
must be the same as the number
of printed columns, respectively. The value NA
can be used
to specify columns which should use default labels.
Argument hetstat
can be a character string to specify where
to print heterogeneity information:
row with results for common effect model (hetstat =
"common"
),
row with results for random effects model (hetstat =
"random"
),
rows with 'study' information (hetstat = "study"
).
Otherwise, information on heterogeneity is printed in dedicated rows.
Guido Schwarzer [email protected]
forest.meta
, metabin
,
metacont
, metagen
,
metabind
, settings.meta
data(Fleiss1993cont) # Add some (fictitious) grouping variables: # Fleiss1993cont$age <- c(55, 65, 55, 65, 55) Fleiss1993cont$region <- c("Europe", "Europe", "Asia", "Asia", "Europe") m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") # Conduct two subgroup analyses # mu1 <- update(m1, subgroup = age, bylab = "Age group") mu2 <- update(m1, subgroup = region, bylab = "Region") # Combine subgroup meta-analyses and show forest plot with subgroup # results # mb1 <- metabind(mu1, mu2) mb1 forest(mb1)
data(Fleiss1993cont) # Add some (fictitious) grouping variables: # Fleiss1993cont$age <- c(55, 65, 55, 65, 55) Fleiss1993cont$region <- c("Europe", "Europe", "Asia", "Asia", "Europe") m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") # Conduct two subgroup analyses # mu1 <- update(m1, subgroup = age, bylab = "Age group") mu2 <- update(m1, subgroup = region, bylab = "Region") # Combine subgroup meta-analyses and show forest plot with subgroup # results # mb1 <- metabind(mu1, mu2) mb1 forest(mb1)
Draw a funnel plot which can be used to assess small study effects in meta-analysis. A contour-enhanced funnel plot can also be produced to assess causes of funnel plot asymmetry.
## S3 method for class 'meta' funnel( x, type = "standard", xlim = NULL, ylim = NULL, xlab = NULL, ylab = NULL, common = x$common, random = x$random, axes = TRUE, pch = if (!inherits(x, "trimfill")) 21 else ifelse(x$trimfill, 1, 21), text = NULL, cex = 1, lty.common = 2, lty.random = 9, lwd = 1, lwd.common = lwd, lwd.random = lwd, col = "black", bg = "darkgray", col.common = "black", col.random = "black", log, yaxis, contour.levels = if (type == "contour") c(0.9, 0.95, 0.99) else NULL, col.contour = if (type == "contour") c("gray80", "gray70", "gray60") else NULL, ref = ifelse(is_relative_effect(x$sm), 1, 0), level = if (common | random) x$level else NULL, studlab = FALSE, cex.studlab = 0.8, pos.studlab = 2, ref.triangle = FALSE, lty.ref = 1, lwd.ref = lwd, col.ref = "black", lty.ref.triangle = 5, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) setvals(x, vals = seq_along(unique(x)))
## S3 method for class 'meta' funnel( x, type = "standard", xlim = NULL, ylim = NULL, xlab = NULL, ylab = NULL, common = x$common, random = x$random, axes = TRUE, pch = if (!inherits(x, "trimfill")) 21 else ifelse(x$trimfill, 1, 21), text = NULL, cex = 1, lty.common = 2, lty.random = 9, lwd = 1, lwd.common = lwd, lwd.random = lwd, col = "black", bg = "darkgray", col.common = "black", col.random = "black", log, yaxis, contour.levels = if (type == "contour") c(0.9, 0.95, 0.99) else NULL, col.contour = if (type == "contour") c("gray80", "gray70", "gray60") else NULL, ref = ifelse(is_relative_effect(x$sm), 1, 0), level = if (common | random) x$level else NULL, studlab = FALSE, cex.studlab = 0.8, pos.studlab = 2, ref.triangle = FALSE, lty.ref = 1, lwd.ref = lwd, col.ref = "black", lty.ref.triangle = 5, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) setvals(x, vals = seq_along(unique(x)))
x |
An object of class |
type |
A character string indicating type of funnel plot. Either
|
xlim |
The x limits (min,max) of the plot. |
ylim |
The y limits (min,max) of the plot. |
xlab |
A label for the x-axis. |
ylab |
A label for the y-axis. |
common |
A logical indicating whether the common effect estimate should be plotted. |
random |
A logical indicating whether the random effects estimate should be plotted. |
axes |
A logical indicating whether axes should be drawn on the plot. |
pch |
The plotting symbol(s) used for individual studies. |
text |
A character vector specifying the text to be used instead of plotting symbol. |
cex |
The magnification to be used for plotting symbols. |
lty.common |
Line type (common effect estimate). |
lty.random |
Line type (random effects estimate). |
lwd |
The line width for confidence intervals (if |
lwd.common |
The line width for common effect estimate (if
|
lwd.random |
The line width for random effects estimate (if
|
col |
A vector with colour of plotting symbols. |
bg |
A vector with background colour of plotting symbols (only
used if |
col.common |
Colour of line representing common effect estimate. |
col.random |
Colour of line representing random effects estimate. |
log |
A character string which contains |
yaxis |
A character string indicating which type of weights
are to be used. Either |
contour.levels |
A numeric vector specifying contour levels to produce contour-enhanced funnel plot. |
col.contour |
Colour of contours. |
ref |
Reference value (null effect) used to produce contour-enhanced funnel plot. |
level |
The confidence level utilised in the plot. For the
funnel plot, confidence limits are not drawn if
|
studlab |
A logical indicating whether study labels should be
printed in the graph. A vector with study labels can also be
provided (must be of same length as |
cex.studlab |
Size(s) of study labels, see argument |
pos.studlab |
Position of study labels, see argument
|
ref.triangle |
A logical indicating whether approximate confidence limits should be printed around reference value (null effect). |
lty.ref |
Line type (reference value). |
lwd.ref |
The line width for the reference value and
corresponding confidence intervals (if |
col.ref |
Colour of line representing reference value. |
lty.ref.triangle |
Line type (confidence intervals of reference value). |
backtransf |
A logical indicating whether results for relative
summary measures (argument |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (passed on to plot.default). |
vals |
Vector with values used in |
A funnel plot (Light & Pillemer, 1984) is drawn in the active
graphics window. If common
is TRUE, the estimate of the
common effect model is plotted as a vertical line. Similarly, if
random
is TRUE, the estimate of the random effects model is
plotted. If level
is not NULL, the corresponding approximate
confidence limits are drawn around the common effect estimate (if
common
is TRUE) or the random effects estimate (if
random
is TRUE and common
is FALSE).
In the funnel plot, the standard error of the treatment estimates
is plotted on the y-axis by default (yaxis = "se"
) which is
likely to be the best choice (Sterne & Egger, 2001). Only exception
is meta-analysis of diagnostic test accuracy studies (Deeks et al.,
2005) where the inverse of the square root of the effective
study size is used (yaxis = "ess"
). Other possible choices
for yaxis
are "invvar"
(inverse of the variance),
"invse"
(inverse of the standard error), "size"
(study size), and "invsqrtsize"
(1 / sqrt(study size)).
If argument yaxis
is not equal to "size"
,
"invsqrtsize"
or "ess"
, contour-enhanced funnel plots
can be produced (Peters et al., 2008) by specifying the contour
levels (argument contour.levels
). By default (argument
col.contour
missing), suitable gray levels will be used to
distinguish the contours. Different colours can be chosen by
argument col.contour
.
R function setvals
can be used to easily define the input for the
arguments pch
, text
, cex
, col
, bg
,
and cex.studlab
.
Guido Schwarzer [email protected], Petra Graham [email protected]
Deeks JJ, Macaskill P, Irwig L (2005): The performance of tests of publication bias and other sample size effects in systematic reviews of diagnostic test accuracy was assessed. Journal of Clinical Epidemiology, 58:882–93
Light RJ & Pillemer DB (1984): Summing Up. The Science of Reviewing Research. Cambridge: Harvard University Press
Peters JL, Sutton AJ, Jones DR, Abrams KR, Rushton L (2008): Contour-enhanced meta-analysis funnel plots help distinguish publication bias from other causes of asymmetry. Journal of Clinical Epidemiology, 61, 991–6
Sterne JAC & Egger M (2001): Funnel plots for detecting bias in meta-analysis: Guidelines on choice of axis. Journal of Clinical Epidemiology, 54, 1046–55
metabias
, metabin
,
metagen
, radial
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = c(41, 47, 51, 59), studlab = paste(author, year), sm = "RR", method = "I") # Standard funnel plot # funnel(m1) # Funnel plot with confidence intervals, common effect estimate and # contours # fun <- funnel(m1, common = TRUE, level = 0.95, type = "contour") legend("topleft", fun$text.contour, fill = fun$col.contour, bg = "white") # Contour-enhanced funnel plot with user-chosen colours # funnel(m1, common = TRUE, level = 0.95, contour = c(0.9, 0.95, 0.99), col.contour = c("darkgreen", "green", "lightgreen"), lwd = 2, cex = 2, pch = 16, studlab = TRUE, cex.studlab = 1.25) legend(0.05, 0.05, c("0.1 > p > 0.05", "0.05 > p > 0.01", "< 0.01"), fill = c("darkgreen", "green", "lightgreen")) fun <- funnel(m1, common = TRUE, level = 0.95, contour = c(0.9, 0.95, 0.99), col.contour = c("darkgreen", "green", "lightgreen"), lwd = 2, cex = 2, pch = 16, studlab = TRUE, cex.studlab = 1.25) legend(0.05, 0.05, fun$text.contour, fill = fun$col.contour) # Use different colours for log risk ratios below and above 0 # funnel(m1, bg = setvals(TE < 0, c("green", "red")))
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = c(41, 47, 51, 59), studlab = paste(author, year), sm = "RR", method = "I") # Standard funnel plot # funnel(m1) # Funnel plot with confidence intervals, common effect estimate and # contours # fun <- funnel(m1, common = TRUE, level = 0.95, type = "contour") legend("topleft", fun$text.contour, fill = fun$col.contour, bg = "white") # Contour-enhanced funnel plot with user-chosen colours # funnel(m1, common = TRUE, level = 0.95, contour = c(0.9, 0.95, 0.99), col.contour = c("darkgreen", "green", "lightgreen"), lwd = 2, cex = 2, pch = 16, studlab = TRUE, cex.studlab = 1.25) legend(0.05, 0.05, c("0.1 > p > 0.05", "0.05 > p > 0.01", "< 0.01"), fill = c("darkgreen", "green", "lightgreen")) fun <- funnel(m1, common = TRUE, level = 0.95, contour = c(0.9, 0.95, 0.99), col.contour = c("darkgreen", "green", "lightgreen"), lwd = 2, cex = 2, pch = 16, studlab = TRUE, cex.studlab = 1.25) legend(0.05, 0.05, fun$text.contour, fill = fun$col.contour) # Use different colours for log risk ratios below and above 0 # funnel(m1, bg = setvals(TE < 0, c("green", "red")))
Get default for a meta-analysis setting in R package meta.
gs(x = NULL, unname = NULL)
gs(x = NULL, unname = NULL)
x |
A character string or vector with setting name(s). |
unname |
A logical whether to remove names from attributes. |
This function can be used to get the default for a meta-analysis
setting defined using settings.meta
.
This function is primarily used to define default settings in
meta-analysis functions, e.g., metabin
or
metacont
. A list of all arguments with current
settings is printed using the command
settings.meta("print")
.
Guido Schwarzer [email protected]
# Get default setting for confidence interval of random effects # model # gs("method.random.ci") # Get default setting for summary measure in metabin() # gs("smbin")
# Get default setting for confidence interval of random effects # model # gs("method.random.ci") # Get default setting for summary measure in metabin() # gs("smbin")
Deprecated function to create study labels in JAMA layout (for
forest plot). Replaced by labels.meta
.
JAMAlabels(author, year, citation, data = NULL)
JAMAlabels(author, year, citation, data = NULL)
author |
A vector providing study authors. |
year |
A vector providing year of publication. |
citation |
A vector providing citation numbers. |
data |
An optional data frame containing the study information. |
This auxiliary function can be used to create study labels in JAMA layout which can be added to a forest plot using argument 'studlab'.
Guido Schwarzer [email protected]
data(Fleiss1993bin) refs <- 20 + 1:7 Fleiss1993bin$mylabs <- JAMAlabels(study, year, refs, data = Fleiss1993bin) m <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR", random = FALSE) forest(m, studlab = mylabs, layout = "JAMA", fontfamily = "Times", fontsize = 10)
data(Fleiss1993bin) refs <- 20 + 1:7 Fleiss1993bin$mylabs <- JAMAlabels(study, year, refs, data = Fleiss1993bin) m <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR", random = FALSE) forest(m, studlab = mylabs, layout = "JAMA", fontfamily = "Times", fontsize = 10)
Draw a L'Abbé plot for meta-analysis with binary outcomes.
## S3 method for class 'metabin' labbe( x, xlim, ylim, xlab = NULL, ylab = NULL, TE.common = x$TE.common, TE.random = x$TE.random, common = x$common, random = x$random, backtransf = x$backtransf, axes = TRUE, pch = 21, text = NULL, cex = 1, col = "black", bg = "lightgray", lwd = 1, lwd.common = lwd, lwd.random = lwd, lty.common = 2, lty.random = 9, col.common = col, col.random = col, nulleffect = TRUE, lwd.nulleffect = lwd, col.nulleffect = "lightgray", sm = x$sm, weight, studlab = FALSE, cex.studlab = 0.8, pos.studlab = 2, label.e = x$label.e, label.c = x$label.c, warn.deprecated = gs("warn.deprecated"), TE.fixed, fixed, lwd.fixed, lty.fixed, col.fixed, ... ) ## Default S3 method: labbe( x, y, xlim, ylim, xlab = NULL, ylab = NULL, TE.common = NULL, TE.random = NULL, common = !is.null(TE.common), random = !is.null(TE.random), backtransf = TRUE, axes = TRUE, pch = 21, text = NULL, cex = 1, col = "black", bg = "lightgray", lwd = 1, lwd.common = lwd, lwd.random = lwd, lty.common = 2, lty.random = 9, col.common = col, col.random = col, nulleffect = TRUE, lwd.nulleffect = lwd, col.nulleffect = "lightgray", sm = "", weight, studlab = FALSE, cex.studlab = 0.8, pos.studlab = 2, label.e = NULL, label.c = NULL, warn.deprecated = gs("warn.deprecated"), TE.fixed, fixed, lwd.fixed, lty.fixed, col.fixed, ... )
## S3 method for class 'metabin' labbe( x, xlim, ylim, xlab = NULL, ylab = NULL, TE.common = x$TE.common, TE.random = x$TE.random, common = x$common, random = x$random, backtransf = x$backtransf, axes = TRUE, pch = 21, text = NULL, cex = 1, col = "black", bg = "lightgray", lwd = 1, lwd.common = lwd, lwd.random = lwd, lty.common = 2, lty.random = 9, col.common = col, col.random = col, nulleffect = TRUE, lwd.nulleffect = lwd, col.nulleffect = "lightgray", sm = x$sm, weight, studlab = FALSE, cex.studlab = 0.8, pos.studlab = 2, label.e = x$label.e, label.c = x$label.c, warn.deprecated = gs("warn.deprecated"), TE.fixed, fixed, lwd.fixed, lty.fixed, col.fixed, ... ) ## Default S3 method: labbe( x, y, xlim, ylim, xlab = NULL, ylab = NULL, TE.common = NULL, TE.random = NULL, common = !is.null(TE.common), random = !is.null(TE.random), backtransf = TRUE, axes = TRUE, pch = 21, text = NULL, cex = 1, col = "black", bg = "lightgray", lwd = 1, lwd.common = lwd, lwd.random = lwd, lty.common = 2, lty.random = 9, col.common = col, col.random = col, nulleffect = TRUE, lwd.nulleffect = lwd, col.nulleffect = "lightgray", sm = "", weight, studlab = FALSE, cex.studlab = 0.8, pos.studlab = 2, label.e = NULL, label.c = NULL, warn.deprecated = gs("warn.deprecated"), TE.fixed, fixed, lwd.fixed, lty.fixed, col.fixed, ... )
x |
An object of class |
xlim |
The x limits (min, max) of the plot. |
ylim |
The y limits (min, max) of the plot. |
xlab |
A label for the x-axis. |
ylab |
A label for the y-axis. |
TE.common |
A numeric or vector specifying combined common effect estimate(s). |
TE.random |
A numeric or vector specifying combined random effects estimate(s). |
common |
A logical indicating whether the common effect estimate should be plotted. |
random |
A logical indicating whether the random effects estimate should be plotted. |
backtransf |
A logical indicating which values should be printed on x- and y-axis (see Details). |
axes |
A logical indicating whether axes should be drawn on the plot. |
pch |
The plotting symbol used for individual studies. |
text |
A character vector specifying the text to be used instead of plotting symbol. |
cex |
The magnification to be used for plotting symbol. |
col |
A vector with colour of plotting symbols. |
bg |
A vector with background colour of plotting symbols (only
used if |
lwd |
The line width. |
lwd.common |
The line width(s) for common effect estimate(s)
(if |
lwd.random |
The line width(s) for random effects estimate(s)
(if |
lty.common |
Line type(s) for common effect estimate(s). |
lty.random |
Line type(s) for random effects estimate(s). |
col.common |
Colour of line(s) for common effect estimate(s). |
col.random |
Colour of line(s) for random effects estimate(s). |
nulleffect |
A logical indicating whether line for null effect should be added to the plot.. |
lwd.nulleffect |
Width of line for null effect. |
col.nulleffect |
Colour of line for null effect. |
sm |
A character string indicating underlying summary measure,
i.e., |
weight |
Either a numeric vector specifying relative sizes of
plotting symbols or a character string indicating which type of
plotting symbols is to be used for individual treatment
estimates. One of missing (see Details), |
studlab |
A logical indicating whether study labels should be
printed in the graph. A vector with study labels can also be
provided (must be of same length as |
cex.studlab |
Size of study labels. |
pos.studlab |
Position of study labels, see argument
|
label.e |
Label for experimental group. |
label.c |
Label for control group. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
TE.fixed |
Deprecated argument (replaced by 'TE.common'). |
fixed |
Deprecated argument (replaced by 'common'). |
lwd.fixed |
Deprecated argument (replaced by 'lwd.common'). |
lty.fixed |
Deprecated argument (replaced by 'lty.common'). |
col.fixed |
Deprecated argument (replaced by 'col.common'). |
... |
Graphical arguments as in |
y |
The y coordinates of the L'Abbé plot, if argument |
A L'Abbé plot is a scatter plot with the risk in the control group on the x-axis and the risk in the experimental group on the y-axis (L'Abbé et al., 1987). It can be used to evaluate heterogeneity in meta-analysis. Furthermore, this plot can aid to choose a summary measure (odds ratio, risk ratio, risk difference) that will result in more consistent results (Jiménez et al., 1997; Deeks, 2002).
If argument backtransf
is TRUE (default), event
probabilities will be printed on x- and y-axis. Otherwise,
transformed event probabilities will be printed as defined by the
summary measure, i.e., log odds of probabilities for odds ratio as
summary measure (sm = "OR"
), log probabilities for sm
= "RR"
, and arcsine-transformed probabilities for sm =
"ASD"
.
If common
is TRUE, the estimate of the common effct model is
plotted as a line. If random
is TRUE, the estimate of the
random effects model is plotted as a line.
Information from object x
is utilised if argument
weight
is missing. Weights from the common effect model are
used (weight = "common"
) if argument x$common
is
TRUE
; weights from the random effects model are used
(weight = "random"
) if argument x$random
is
TRUE
and x$common
is FALSE
.
Guido Schwarzer [email protected]
Deeks JJ (2002): Issues in the selection of a summary statistic for meta-analysis of clinical trials with binary outcomes. Statistics in Medicine, 21, 1575–600
Jiménez FJ, Guallar E, Martín-Moreno JM (1997): A graphical display useful for meta-analysis. European Journal of Public Health, 1, 101–5
L'Abbé KA, Detsky AS, O'Rourke K (1987): Meta-analysis in clinical research. Annals of Internal Medicine, 107, 224–33
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, studlab = paste(author, year), sm = "RR", method = "I") # L'Abbe plot for risk ratio # labbe(m1) # L'Abbe plot for odds ratio # labbe(m1, sm = "OR") # same plot labbe(update(m1, sm = "OR")) # L'Abbe plot for risk difference # labbe(m1, sm = "RD") # L'Abbe plot on log odds scale # labbe(m1, sm = "OR", backtransf = FALSE) # L'Abbe plot for odds ratio with coloured lines for various # treatment effects (defined as log odds ratios) # mycols <- c("blue", "yellow", "green", "red", "green", "yellow", "blue") labbe(m1, sm = "OR", random = FALSE, TE.common = log(c(1 / 10, 1 / 5, 1 / 2, 1, 2, 5, 10)), col.common = mycols, lwd.common = 2) # L'Abbe plot on log odds scale with coloured lines for various # treatment effects (defined as log odds ratios) # labbe(m1, sm = "OR", random = FALSE, backtransf = FALSE, TE.common = log(c(1 / 10, 1 / 5, 1 / 2, 1, 2, 5, 10)), col.common = mycols, lwd.common = 2)
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, studlab = paste(author, year), sm = "RR", method = "I") # L'Abbe plot for risk ratio # labbe(m1) # L'Abbe plot for odds ratio # labbe(m1, sm = "OR") # same plot labbe(update(m1, sm = "OR")) # L'Abbe plot for risk difference # labbe(m1, sm = "RD") # L'Abbe plot on log odds scale # labbe(m1, sm = "OR", backtransf = FALSE) # L'Abbe plot for odds ratio with coloured lines for various # treatment effects (defined as log odds ratios) # mycols <- c("blue", "yellow", "green", "red", "green", "yellow", "blue") labbe(m1, sm = "OR", random = FALSE, TE.common = log(c(1 / 10, 1 / 5, 1 / 2, 1, 2, 5, 10)), col.common = mycols, lwd.common = 2) # L'Abbe plot on log odds scale with coloured lines for various # treatment effects (defined as log odds ratios) # labbe(m1, sm = "OR", random = FALSE, backtransf = FALSE, TE.common = log(c(1 / 10, 1 / 5, 1 / 2, 1, 2, 5, 10)), col.common = mycols, lwd.common = 2)
Create study labels for forest plot.
## S3 method for class 'meta' labels( object, author = object$studlab, year = "", citation = NULL, layout = "JAMA", data = object$data, ... )
## S3 method for class 'meta' labels( object, author = object$studlab, year = "", citation = NULL, layout = "JAMA", data = object$data, ... )
object |
An object of class |
author |
An optional vector providing study authors. |
year |
An optional vector providing year of publication. |
citation |
An optional vector providing citation numbers. |
layout |
A character string specifying layout. Either "JAMA" or "Lancet". |
data |
An optional data frame containing the study information. |
... |
Additional arguments (ignored at the moment). |
This auxiliary function can be used to create study labels in JAMA or Lancet layout which can be added to a forest plot using argument 'studlab'.
Guido Schwarzer [email protected]
data(Fleiss1993bin) refs <- 20 + 1:7 m <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = study, sm = "OR", random = FALSE) forest(m, studlab = labels(m, year = year, citation = refs, layout = "JAMA"), layout = "JAMA", fontfamily = "Times", fontsize = 10) forest(m, studlab = labels(m, year = year, citation = refs, layout = "Lancet"))
data(Fleiss1993bin) refs <- 20 + 1:7 m <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = study, sm = "OR", random = FALSE) forest(m, studlab = labels(m, year = year, citation = refs, layout = "JAMA"), layout = "JAMA", fontfamily = "Times", fontsize = 10) forest(m, studlab = labels(m, year = year, citation = refs, layout = "Lancet"))
This function transforms data from pairwise comparisons to a long arm-based format, i.e., two rows for a pairwise comparison.
longarm( treat1, treat2, event1, n1, event2, n2, mean1, sd1, mean2, sd2, time1, time2, data = NULL, studlab, id1 = NULL, id2 = NULL, append = TRUE, keep.duplicated = FALSE, keep.internal = FALSE )
longarm( treat1, treat2, event1, n1, event2, n2, mean1, sd1, mean2, sd2, time1, time2, data = NULL, studlab, id1 = NULL, id2 = NULL, append = TRUE, keep.duplicated = FALSE, keep.internal = FALSE )
treat1 |
Either label for first treatment or a meta-analysis or pairwise object (see Details). |
treat2 |
Label for second treatment. |
event1 |
Number of events (first treatment). |
n1 |
Number of observations (first treatment). |
event2 |
Number of events (second treatment). |
n2 |
Number of observations (second treatment) |
mean1 |
Estimated mean (first treatment). |
sd1 |
Standard deviation (first treatment). |
mean2 |
Estimated mean (second treatment). |
sd2 |
Standard deviation (second treatment). |
time1 |
Person time at risk (first treatment) |
time2 |
Person time at risk (second treatment) |
data |
An optional data frame containing the study information. |
studlab |
A vector with study labels (optional). |
id1 |
Last character(s) of variable names for additional variables with group specific information for first treatment. |
id2 |
Last character(s) of variable names for additional variables with group specific information for second treatment. |
append |
A logical indicating if data frame provided in argument 'data' should be returned. |
keep.duplicated |
A logical indicating if duplicated rows should be returned (see Details). |
keep.internal |
A logical indicating if variables generated internally should be returned (typically only relevant for data checking). |
This function transforms data given as one pairwise comparison per row to a long arm-based format with one row per treatment arm. The long arm-based format is, for example, the required input format for WinBUGS.
The function can be used to transform data with a binary,
continuous or count outcome. The corresponding meta-analysis
functions are metabin
, metacont
and
metainc
. Accordingly, a meta-analysis object created
with one of these functions can be provided as argument
treat1
. It is also possible to use the longarm function with
an R objected created with pairwise
from R
package netmeta.
Otherwise, arguments treat1
and treat2
are mandatory
to identify the individual treatments and, depending on the
outcome, the following additional arguments are mandatory:
event1, n1, event2, n2 (binary outcome);
n1, mean1, sd1, n2, mean2, sd2 (continuous outcome);
time1, n1, time2, n2 (count outcome).
Argument studlab
must be provided if several pairwise
comparisons come from a single study with more than two treatments.
The following variables will be returned:
studlab | study label |
treat | treatment label |
n | group sample size (count outcome only if provided) |
events | number of events (binary or count outcome) |
nonevents | number of non-events (binary outcome) |
mean | estimated mean (continuous outcome) |
sd | standard deviation (continuous outcome) |
time | person time at risk (count outcome) |
In addition, the data set provided in argument data
will be
returned if argument append = TRUE
(default).
Argument keep.duplicated
can be used to keep duplicated rows
from the data set. Duplicated rows can occur, for example, in a
three-arm study comparing treatments A and B with placebo. In this
situation, the placebo arm will be returned twice in the data set
in long arm-based format if keep.duplicated = TRUE
. By
default, duplicated rows with not be kept in the data set.
A data frame in long arm-based format.
R function to.long
from R package
metafor is called internally.
Guido Schwarzer [email protected]
metabin
, metacont
,
metainc
, pairwise
# Artificial example with three studies m <- metabin(1:3, 100:102, 4:6, 200:202, studlab = LETTERS[1:3]) # Transform data to long arm-based format longarm(m) # Keep internal variables longarm(m, keep.internal = TRUE)
# Artificial example with three studies m <- metabin(1:3, 100:102, 4:6, 200:202, studlab = LETTERS[1:3]) # Transform data to long arm-based format longarm(m) # Keep internal variables longarm(m, keep.internal = TRUE)
Detailed description of R objects of class "meta".
The following R functions create an object of class "meta"
:
metabin
, metacont
,
metacor
, metagen
,
metainc
, metamean
,
metaprop
, metarate
,
metacr
, metamerge
,
trimfill
The following generic functions are available for an object of
class "meta"
:
as.data.frame.meta
, labels.meta
,
print.meta
, print.summary.meta
,
summary.meta
, update.meta
,
weights.meta
An object of class "meta"
is a list containing the following
components.
studlab |
Study labels |
sm |
Effect measure |
null.effect |
Effect under the null hypothesis |
TE |
Effect estimates (individual studies) |
seTE |
Standard error of effect estimates (individual studies) |
statistic |
Statistics for test of effect (individual studies) |
pval |
P-values for test of effect (individual studies) |
df |
Degrees of freedom (individual studies) |
level |
Level of confidence intervals for individual studies |
lower |
Lower confidence limits (individual studies) |
upper |
Upper confidence limits (individual studies) |
three.level |
Indicator variable for three-level meta-analysis model |
cluster |
Cluster variable (three-level meta-analysis model) |
rho |
Within-cluster correlation (three-level meta-analysis model) |
k |
Number of estimates combined in meta-analysis |
k.study |
Number of studies combined in meta-analysis |
k.all |
Number of all studies |
k.TE |
Number of studies with estimable effects |
overall |
Print meta-analysis results |
overall.hetstat |
Print overall heterogeneity statistics |
common |
Print results for common effect meta-analysis |
random |
Print results for random effects meta-analysis |
prediction |
Print prediction interval |
backtransf |
Back transform results in printouts and plots |
method |
Meta-analysis method (common effect model) |
method.random |
Meta-analysis method (random effects model) |
w.common |
Weights for common effect model (individual studies) |
TE.common |
Estimated overall effect (common effect model) |
seTE.common |
Standard error of overall effect (common effect model) |
statistic.common |
Statistic for test of overall effect (common effect model) |
pval.common |
P-value for test of overall effect (common effect model) |
level.ma |
Level of confidence interval for meta-analysis estimates |
lower.common |
Lower confidence limit (common effect model) |
upper.common |
Upper confidence limit (common effect model) |
w.random |
Weight for random effects model (individual studies) |
TE.random |
Estimated overall effect (random effects model) |
seTE.random |
Standard error of overall effect (random effects model) |
statistic.random |
Statistic for test of overall effect (random effects model) |
pval.random |
P-value for test of overall effect (random effects model) |
method.random.ci |
Confidence interval method (random effects model) |
df.random |
Degrees of freedom (random effects model) |
lower.random |
Lower confidence limit (random effects model) |
upper.random |
Upper confidence limit (random effects model) |
seTE.classic |
Standard error (classic random effects method) |
adhoc.hakn.ci |
Ad hoc correction for Hartung-Knapp method (confidence interval) |
df.hakn.ci |
Degrees of freedom for Hartung-Knapp method |
(if used in meta-analysis) | |
seTE.hakn.ci |
Standard error for Hartung-Knapp method |
(not taking ad hoc variance correction into account) | |
seTE.hakn.adhoc.ci |
Standard error for Hartung-Knapp method |
(taking ad hoc variance correction into account) | |
df.kero |
Degrees of freedom for Kenward-Roger method |
(if used in meta-analysis) | |
seTE.kero |
Standard error for Kenward-Roger method |
method.predict |
Method to calculate prediction interval |
adhoc.hakn.pi |
Ad hoc correction for Hartung-Knapp method (prediction interval) |
df.hakn.ci |
Degrees of freedom for Hartung-Knapp method |
(prediction interval) | |
seTE.predict |
Standard error used to calculate prediction interval |
df.predict |
Degrees of freedom for prediction interval |
level.predict |
Level of prediction interval |
lower.predict |
Lower limit of prediction interval |
upper.predict |
Upper limit of prediction interval |
seTE.hakn.pi |
Standard error for Hartung-Knapp method |
(not taking ad hoc variance correction into account) | |
seTE.hakn.adhoc.pi |
Standard error for Hartung-Knapp method |
(taking ad hoc variance correction into account) | |
Q |
Heterogeneity statistic |
df.Q |
Degrees of freedom for heterogeneity statistic
Q |
pval.Q |
P-value of heterogeneity test |
method.tau |
Method to estimate between-study variance |
control |
Additional arguments for iterative estimation
of |
method.tau.ci |
Method for confidence interval of |
level.hetstat |
Level of confidence intervals for heterogeneity statistics |
tau2 |
Between-study variance |
se.tau2 |
Standard error of |
lower.tau2 |
Lower confidence limit ( ) |
upper.tau2 |
Upper confidence limit ( ) |
tau |
Square-root of between-study variance |
lower.tau |
Lower confidence limit ( ) |
upper.tau |
Upper confidence limit ( ) |
tau.preset |
Prespecified value for |
TE.tau |
Effect estimate used to estimate |
detail.tau |
Detail on between-study variance estimate |
phi |
Multiplicative heterogeneity parameter in
penalised logistic regression |
H |
Heterogeneity statistic H |
lower.H |
Lower confidence limit (heterogeneity statistic H) |
upper.H |
Upper confidence limit (heterogeneity statistic H) |
I2 |
Heterogeneity statistic I |
lower.I2 |
Lower confidence limit (heterogeneity statistic I ) |
upper.I2 |
Upper confidence limit (heterogeneity statistic I ) |
Rb |
Heterogeneity statistic R |
lower.Rb |
Lower confidence limit (heterogeneity statistic R ) |
upper.Rb |
Upper confidence limit (heterogeneity statistic R ) |
method.bias |
Method to test for funnel plot asymmetry |
text.common |
Label for common effect model |
text.random |
Label for random effects model |
text.predict |
Label for prediction interval |
text.w.common |
Label for weights (common effect model) |
text.w.random |
Label for weights (random effects model) |
title |
Title of meta-analysis / systematic review |
complab |
Comparison label |
outclab |
Outcome label |
label.e |
Label for experimental group |
label.c |
Label for control group |
label.left |
Graph label on left side of forest plot |
label.right |
Graph label on right side of forest plot |
keepdata |
Keep original data |
data |
Original data (set) used in function call (if
keepdata = TRUE ) |
subset |
Information on subset of original data used in meta-analysis |
(if keepdata = TRUE ) |
|
exclude |
Studies excluded from meta-analysis |
warn |
Print warnings |
call |
Function call |
version |
Version of R package meta used to create object |
For subgroup analysis (argument subgroup
), the following
additional components are added to the list.
subgroup |
Subgroup information (for individual studies) |
subgroup.name |
Name of subgroup variable |
print.subgroup.name |
Print name of subgroup variable |
sep.subgroup |
Separator between name of subgroup variable and value |
test.subgroup |
Print test for subgroup differences |
prediction.subgroup |
Print prediction interval for subgroup(s) |
tau.common |
Assumption of common between-study variance in subgroups |
subgroup.levels |
Levels of grouping variable |
k.w |
Number of estimates combined in subgroups |
k.study.w |
Number of studies combined in subgroups |
k.all.w |
Number of studies in subgroups |
k.TE.w |
Number of studies with estimable effects in subgroups |
TE.common.w |
Estimated effect in subgroups (common effect model) |
seTE.common.w |
Standard error in subgroups (common effect model) |
statistic.common.w |
Statistic for test of effect in subgroups (common effect model) |
pval.common.w |
P-value for test of effect in subgroups (common effect model) |
lower.common.w |
Lower confidence limit in subgroups (common effect model) |
upper.common.w |
Upper confidence limit in subgroups (common effect model) |
w.common.w |
Total weight in subgroups (common effect model) |
TE.random.w |
Estimated effect in subgroups (random effect model) |
seTE.random.w |
Standard error in subgroups (random effects model) |
statistic.random.w |
Statistic for test of effect in subgroups (random effects model) |
pval.random.w |
P-value for test of effect in subgroups (random effects model) |
df.random.w |
Degrees of freedom in subgroups (random effects model) |
lower.random.w |
Lower confidence limit in subgroups (random effects model) |
upper.random.w |
Upper confidence limit in subgroups (random effects model) |
w.random.w |
Total weight in subgroups (random effects model) |
seTE.classic.w |
Standard error (classic random effects method) |
df.hakn.ci.w |
Degrees of freedom for Hartung-Knapp method in subgroups |
seTE.hakn.ci.w |
Standard error for Hartung-Knapp method in subgroups |
(not taking ad hoc variance correction into account) | |
seTE.hakn.adhoc.ci.w |
Standard error for Hartung-Knapp method in subgroups |
df.kero.w |
Degrees of freedom for Kenward-Roger method in subgroups |
seTE.kero.w |
Standard error for Kenward-Roger method in subgroups |
seTE.predict.w |
Standard error for prediction interval in subgroups |
df.predict.w |
Degrees of freedom for prediction interval in subgroups |
lower.predict.w |
Lower limit of prediction interval in subgroups |
upper.predict.w |
Upper limit of prediction interval in subgroups |
seTE.hakn.pi.w |
Standard error for Hartung-Knapp method in subgroups (prediction intervals) |
(not taking ad hoc variance correction into account) | |
seTE.hakn.adhoc.pi.w |
Standard error for Hartung-Knapp method in subgroups (prediction intervals) |
Q.w |
Heterogeneity statistic Q in subgroups |
pval.Q.w |
P-value for test of heterogeneity in subgroups |
tau2.w |
Between-study variance in subgroups |
tau.w |
Square-root of between-study variance in subgroups |
H.w |
Heterogeneity statistic H in subgroups |
lower.H.w |
Lower confidence limit for H in subgroups |
upper.H.w |
Upper confidence limit for H in subgroups |
I2.w |
Heterogeneity statistic I in subgroups |
lower.I2.w |
Lower confidence limit for I in subgroups |
upper.I2.w |
Upper confidence limit for I in subgroups |
Rb.w |
Heterogeneity statistic R in subgroups |
lower.Rb.w |
Lower confidence limit for R in subgroups |
upper.Rb.w |
Upper confidence limit for R in subgroups |
Q.w.common |
Within-group heterogeneity statistic Q (common effect model) |
Q.w.random |
Within-group heterogeneity statistic Q (random effects model) |
(only calculated if argument tau.common = TRUE ) |
|
df.Q.w |
Degrees of freedom for Q.w.common and Q.w.random |
pval.Q.w.common |
P-value of test for residual heterogeneity (common effect model) |
pval.Q.w.random |
P-value of test for residual heterogeneity (random effects model) |
Q.b.common |
Between-groups heterogeneity statistic Q (common effect model) |
df.Q.b.common |
Degrees of freedom for Q.b.common
|
pval.Q.b.common |
P-value of test for subgroup differences (common effect model) |
Q.b.random |
Between-groups heterogeneity statistic Q (random effects model) |
df.Q.b.random |
Degrees of freedom for Q.b.random
|
pval.Q.b.random |
P-value of test for subgroup differences (random effects model) |
An object created with metabin
has the additional
class "metabin"
and the following components.
event.e |
Events in experimental group (individual studies) |
n.e |
Sample size in experimental group (individual studies) |
event.e |
Events in control group (individual studies) |
n.e |
Sample size in control group (individual studies) |
incr |
Increment added to zero cells |
method.incr |
Continuity correction method |
sparse |
Continuity correction applied |
allstudies |
Include studies with double zeros |
doublezeros |
Indicator for studies with double zeros |
MH.exact |
Exact Mantel-Haenszel method |
RR.Cochrane |
Cochrane method to calculate risk ratio |
Q.Cochrane |
Cochrane method to calculate
|
Q.CMH |
Cochran-Mantel-Haenszel statistic |
df.Q.CMH |
Degrees of freedom for Q.CMH |
pval.Q.CMH |
P-value of Cochran-Mantel-Haenszel test |
print.CMH |
Print results for Cochran-Mantel-Haenszel statistic |
incr.e |
Continuity correction in experimental group (individual studies) |
incr.c |
Continuity correction in control group (individual studies) |
k.MH |
Number of studies (Mantel-Haenszel method) |
An object created with metacont
has the additional
class "metacont"
and the following components.
n.e |
Sample size in experimental group (individual studies) |
mean.e |
Estimated mean in experimental group (individual studies) |
sd.e |
Standard deviation in experimental group (individual studies) |
n.c |
Sample size in control group (individual studies) |
mean.c |
Estimated mean in control group (individual studies) |
sd.c |
Standard deviation in control group (individual studies) |
pooledvar |
Use pooled variance for mean difference |
method.smd |
Method for standardised mean difference (SMD) |
sd.glass |
Denominator in Glass' method |
exact.smd |
Use exact formulae for SMD |
method.ci |
Method to calculate confidence limits |
method.mean |
Method to approximate mean |
method.sd |
Method to approximate standard deviation |
An object created with metacor
has the additional
class "metacor"
and the following components.
cor |
Correlation (individual studies) |
n |
Sample size (individual studies) |
An object created with metainc
has the additional
class "metainc"
and the following components.
event.e |
Events in experimental group (individual studies) |
time.e |
Person time in experimental group (individual studies) |
n.e |
Sample size in experimental group (individual studies) |
event.c |
Events in control group (individual studies) |
time.c |
Person time in control group (individual studies) |
n.c |
Sample size in control group (individual studies) |
incr |
Increment added to zero cells |
method.incr |
Continuity correction method |
sparse |
Continuity correction applied |
incr.event |
Continuity correction (individual studies) |
k.MH |
Number of studies (Mantel-Haenszel method) |
An object created with metamean
has the additional
class "metamean"
and the following components.
n |
Sample size (individual studies) |
mean |
Estimated mean (individual studies) |
sd |
Standard deviation (individual studies) |
method.ci |
Method to calculate confidence limits |
method.mean |
Method to approximate mean |
method.sd |
Method to approximate standard deviation |
An object created with metaprop
has the additional
class "metaprop"
and the following components.
event |
Events (individual studies) |
n |
Sample size (individual studies) |
incr |
Increment added to zero cells |
method.incr |
Continuity correction method |
sparse |
Continuity correction applied |
method.ci |
Method to calculate confidence limits |
incr.event |
Continuity correction (individual studies) |
An object created with metarate
has the additional
class "metarate"
and the following components.
event |
Events (individual studies) |
time |
Person time (individual studies) |
n |
Sample size (individual studies) |
incr |
Increment added to zero cells |
method.incr |
Continuity correction method |
sparse |
Continuity correction applied |
method.ci |
Method to calculate confidence limits |
incr.event |
Continuity correction (individual studies) |
An object created with trimfill
has the additional
classes "trimfill"
and "metagen"
and the following
components.
k0 |
Number of added studies |
left |
Studies missing on left side |
ma.common |
Use common effect or random effects model to estimate |
number of missing studies | |
type |
Method to estimate missing studies |
n.iter.max |
Maximum number of iterations |
n.iter |
Number of iterations |
trimfill |
Filled studies (individual studies) |
class.x |
Primary class of meta-analysis object |
An object created with metamerge
has the additional
class "metamerge"
. Furthermore, the following components
have a different meaning:
k |
Vector with number of estimates |
k.study |
Vector with number of studies |
k.all |
Vector with total number of studies |
k.TE |
Vector with number of studies with estimable effects |
k.MH |
Vector with number of studies combined with Mantel-Haenszel method |
TE.common |
Vector with common effect estimates |
seTE.common |
Vector with standard errors of common effect estimates |
lower.common |
Vector with lower confidence limits (common effect model) |
upper.common |
Vector with upper confidence limits (common effect model) |
statistic.common |
Vector with test statistics for test of overall effect (common effect model) |
pval.common |
Vector with p-value of test for overall effect (common effect model) |
TE.random |
Vector with random effects estimates |
seTE.random |
Vector with standard errors of random effects estimates |
lower.random |
Vector with lower confidence limits (random effects model) |
upper.random |
Vector with upper confidence limits (random effects model) |
statistic.random |
Vector with test statistics for test of overall effect (random effects model) |
pval.random |
Vector with p-value of test for overall effect (random effects model) |
w.common |
Vector or matrix with common effect weights |
w.random |
Vector or matrix with random effects weights |
Guido Schwarzer [email protected]
meta-package
, meta-sm
,
print.meta
, summary.meta
,
forest.meta
Description of summary measures available in R package meta
The following summary measures (argument sm
) are recognised
in R package meta.
metabin)
Argument | Summary measure |
sm = "OR" |
Odds ratio (Fleiss, 1993) |
sm = "RR" |
Risk ratio (Fleiss, 1993) |
sm = "RD" |
Risk difference (Fleiss, 1993) |
sm = "ASD" |
Arcsine difference (Rücker et al., 2009) |
sm = "DOR" |
Diagnostic odds ratio (Moses et al., 1993) |
sm = "VE" |
Vaccine efficacy or vaccine effectiveness |
Note, mathematically, odds ratios and diagnostic odds ratios are
identical, however, the labels in printouts and figures
differ. Furthermore, log risk ratio (logRR) and log vaccine ratio
(logVR) are mathematical identical, however, back-transformed
results differ as vaccine efficacy or effectiveness is defined as
VE = 100 * (1 - RR)
.
A continuity correction is used for some summary measures in the
case of a zero cell count (see metabin
).
List elements TE
, TE.common
, TE.random
, etc.,
contain transformed values, e.g., log odds ratios, log risk ratios
or log vaccine ratios. In printouts and plots transformed values
are back transformed if argument backtransf = TRUE
(default), with exception of the arcsine difference where no
back-transformation exists. Auxiliary function
logVR2VE
is used to back-transform log vaccine ratios
to vaccine efficacy or effectiveness while exp
is used to back-transform log odds or risk ratios.
metacont)
Argument | Summary measure |
sm = "MD" |
Mean difference |
sm = "SMD" |
Standardised mean difference |
sm = "ROM" |
Ratio of means |
Three variants to calculate the standardised mean difference are
available (see metacont
).
For the ratio of means, list elements TE
, TE.common
,
TE.random
, etc., contain the log transformed ratio of
means. In printouts and plots these values are back transformed
using exp
if argument backtransf = TRUE
(default).
metacor)
Argument | Summary measure |
sm = "ZCOR" |
Fisher's z transformed correlation |
sm = "COR" |
Untransformed correlations |
For Fisher's z transformed correlations, list elements TE
,
TE.common
, TE.random
, etc., contain the transformed
correlations. In printouts and plots these values are back
transformed using auxiliary function z2cor
if
argument backtransf = TRUE
(default).
metainc)
Argument | Summary measure |
sm = "IRR" |
Incidence rate ratio |
sm = "IRD" |
Incidence rate difference |
sm = "IRSD" |
Square root transformed incidence rate difference |
sm = "VE" |
Vaccine efficacy or vaccine effectiveness |
Note, log incidence rate ratio (logIRR) and log vaccine ratio
(logVR) are mathematical identical, however, back-transformed
results differ as vaccine efficacy or effectiveness is defined as
VE = 100 * (1 - IRR)
.
List elements TE
, TE.common
, TE.random
, etc.,
contain the transformed incidence rates. In printouts and plots
these values are back transformed if argument backtransf =
TRUE
(default). For back-transformation, exp
is used for the incidence rate ratio, power of 2 is used for square
root transformed rates and logVR2VE
is used for
vaccine efficacy / effectiveness.
metamean)
Argument | Summary measure |
sm = "MRAW" |
Raw, i.e. untransformed, means |
sm = "MLN" |
Log transformed means |
Calculations are conducted on the log scale if sm =
"MLN"
. Accordingly, list elements TE
, TE.common
, and
TE.random
contain the logarithm of means. In printouts and
plots these values are back transformed using
exp
if argument backtransf = TRUE
.
metaprop)
The following transformations of proportions are implemented to calculate an overall proportion:
Argument | Summary measure |
sm = "PLOGIT" |
Logit transformation |
sm = "PAS" |
Arcsine transformation |
sm = "PFT" |
Freeman-Tukey Double arcsine transformation |
sm = "PLN" |
Log transformation |
sm = "PRAW" |
No transformation |
List elements TE
, TE.common
, TE.random
, etc.,
contain the transformed proportions. In printouts and plots these
values are back transformed if argument backtransf = TRUE
(default). For back-transformation, logit2p
is used
for logit transformed proportions, asin2p
is used for
(Freeman-Tukey) arcsine transformed proportions and
exp
is used for log transformed proportions.
metarate)
The following transformations of incidence rates are implemented to calculate an overall rate:
Argument | Summary measure |
sm = "IRLN" |
Log transformation |
sm = "IRS" |
Square root transformation |
sm = "IRFT" |
Freeman-Tukey Double arcsine transformation |
sm = "IR" |
No transformation |
List elements TE
, TE.common
, TE.random
, etc.,
contain the transformed incidence rates. In printouts and plots
these values are back transformed if argument backtransf =
TRUE
(default). For back-transformation, exp
is used for log transformed rates, power of 2 is used for square
root transformed rates and asin2ir
is used for
Freeman-Tukey arcsine transformed rates.
metagen)
The following summary measures are recognised in addition to the above mentioned summary measures:
Argument | Summary measure |
sm = "HR" |
Hazard ratio |
sm = "VE" |
Vaccine efficacy or vaccine effectiveness |
List elements TE
, TE.common
, TE.random
, etc.,
contain transformed values, i.e., log hazard ratios and log vaccine
ratios. In printouts and plots these values are back transformed if
argument backtransf = TRUE
(default); see also
meta-transf.
Guido Schwarzer [email protected]
Borenstein M, Hedges LV, Higgins JP, Rothstein HR (2010): A basic introduction to fixed-effect and random-effects models for meta-analysis. Research Synthesis Methods, 1, 97–111
Fleiss JL (1993): The statistical basis of meta-analysis. Statistical Methods in Medical Research, 2, 121–45
Moses LE, Shapiro D, Littenberg B (1993): Combining Independent Studies of a Diagnostic Test into a Summary Roc Curve: Data-Analytic Approaches and Some Additional Considerations. Statistics in Medicine, 12, 1293–1316
Rücker G, Schwarzer G, Carpenter J, Olkin I (2009): Why add anything to nothing? The arcsine difference as a measure of treatment effect in meta-analysis with zero cells. Statistics in Medicine, 28, 721–38
Stijnen T, Hamza TH, Ozdemir P (2010): Random effects meta-analysis of event outcome in the framework of the generalized linear mixed model with applications in sparse data. Statistics in Medicine, 29, 3046–67
meta-package
, meta-transf
,
meta-object
, print.meta
,
summary.meta
, forest.meta
Auxiliary functions to (back) transform effect estimates or confidence / prediction interval limit(s).
transf(x, sm, func = NULL, args = NULL) cor2z(x) p2asin(x) p2logit(x) VE2logVR(x) backtransf(x, sm, n, time, func = NULL, args = NULL) asin2ir(x, time = NULL) asin2p(x, n = NULL) logit2p(x) logVR2VE(x) z2cor(x)
transf(x, sm, func = NULL, args = NULL) cor2z(x) p2asin(x) p2logit(x) VE2logVR(x) backtransf(x, sm, n, time, func = NULL, args = NULL) asin2ir(x, time = NULL) asin2p(x, n = NULL) logit2p(x) logVR2VE(x) z2cor(x)
x |
Numerical vector with effect estimates, lower or upper confidence / prediction interval limit(s). |
sm |
Summary measure. |
func |
User-specified function for (back) transformation. |
args |
Function arguments for user-specified function. |
n |
Sample size(s) to back transform Freeman-Tukey transformed proportions. |
time |
Time(s) to back transform Freeman-Tukey transformed incidence rates. |
Often in a meta-analysis, effect estimates are transformed before
calculating a weighted average. For example, the log odds ratio and
its standard error is used instead of the odds ratio in R function
metagen
. To report the results of a meta-analysis,
effect estimates are typically back transformed to the original
scale. R package meta provides some auxiliary functions for
(back) transformations.
The following auxiliary functions are provided by R package meta to transform effect estimates or confidence / prediction interval limits.
Function | Transformation |
cor2z |
Correlations to Fisher's Z transformed correlations |
p2logit |
Proportions to logit transformed proportions |
p2asin |
Proportions to arcsine transformed proportions |
VE2logVR |
Vaccine efficacy / effectiveness to log vaccine ratio |
Note, no function for the Freeman-Tukey arcsine transformation is provided as this transformation is based on the number of events and sample sizes instead of the effect estimates.
R function transf
is a wrapper function for the above and
additional transformations, e.g., the log transformation using
log
for odds or risk ratios. Argument sm
is mandatory to specify the requested transformation. It is also
possible to specify a different function with arguments func
and args
.
The following auxiliary functions are available to back transform effect estimates or confidence / prediction interval limits.
Function | Transformation |
asin2ir |
Freeman-Tukey arcsine transformed rates to rates |
asin2p |
(Freeman-Tukey) arcsine transformed proportions to proportions |
logit2p |
Logit transformed proportions to proportions |
logVR2VE |
Log vaccine ratio to vaccine efficacy / effectiveness |
z2cor |
Fisher's Z transformed correlations to correlations |
Argument time
is mandatory in R function asin2ir
.
If argument n
is provided in R function asin2p
,
Freeman-Tukey arcsine transformed proportions are
back transformed. Otherwise, arcsine transformed proportions are
back transformed.
R function backtransf
is a wrapper function for the above
and additional transformations, e.g., the exponential
transformation using exp
for log odds or log
risk ratios. Argument sm
is mandatory to specify the
requested transformation. For the Freeman-Tukey transformations,
argument n
or time
is mandatory.
It is also possible to specify a different function with arguments
func
and args
.
Guido Schwarzer [email protected]
logit2p(p2logit(0.5))
logit2p(p2logit(0.5))
Add pooled results from external analysis to an existing meta-analysis object. This is useful, for example, to add results from a Bayesian meta-analysis which is not implemented in R package meta.
metaadd( x, type, TE, lower, upper, statistic = NA, pval = NA, text, data = NULL, method.common = "", method.random = "", method.tau = "", method.random.ci = "", method.predict = "", transf = gs("transf") )
metaadd( x, type, TE, lower, upper, statistic = NA, pval = NA, text, data = NULL, method.common = "", method.random = "", method.tau = "", method.random.ci = "", method.predict = "", transf = gs("transf") )
x |
Meta-analysis object. |
type |
A character string or vector indicating whether added
results are from common effect, random effects model or
prediction interval. Either |
TE |
Pooled estimate(s). |
lower |
Lower limit(s) of confidence or prediction interval. |
upper |
Upper limit(s) of confidence or prediction interval. |
statistic |
Test statistic(s). |
pval |
P-value(s). |
text |
A character string or vector used in printouts and forest plot to label the added results. |
data |
An optional data frame containing the new results or an
object of class |
method.common |
A character string or vector to describe the common effect method(s). |
method.random |
A character string or vector to describe the random effects method(s). |
method.tau |
A character string or vector to describe the estimator(s) of the between-study variance. |
method.random.ci |
A character string or vector to describe the method(s) to calculate confidence intervals under the random effects model. |
method.predict |
A character string or vector to describe the method(s) used for prediction intervals. |
transf |
A logical indicating whether inputs for arguments
|
In R package meta, objects of class "meta"
contain
results of both common effect and random effects
meta-analyses. This function enables the user to add the pooled
results of an additional analysis to an existing meta-analysis
object. This is useful, for example, to add the result of a
Bayesian meta-analysis.
If argument data
is a meta-analysis object created with R
package meta, arguments TE
, lower
,
upper
, statistic
and pval
are ignored as this
information is extracted from the meta-analysis.
Otherwise, arguments TE
, lower
and upper
have
to be provided if type = "common"
or type =
"random"
. For type = "prediction"
, only arguments
lower
and upper
are mandatory.
Note, R function metamerge
can be used to add
meta-analysis results of another meta-analysis object (see
meta-object
).
An object of class "meta"
with corresponding generic
functions (see meta-object
).
Guido Schwarzer [email protected]
data(Fleiss1993bin) # Common effect and random effects meta-analysis m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR") # Naive pooling m2 <- metabin(sum(d.asp), sum(n.asp), sum(d.plac), sum(n.plac), data = Fleiss1993bin, sm = "OR", text.common = "Naive pooling") # Add results of second meta-analysis from common effect model m12 <- metaadd(m1, data = m2, method.common = "Naive pooling") m12 forest(m12)
data(Fleiss1993bin) # Common effect and random effects meta-analysis m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR") # Naive pooling m2 <- metabin(sum(d.asp), sum(n.asp), sum(d.plac), sum(n.plac), data = Fleiss1993bin, sm = "OR", text.common = "Naive pooling") # Add results of second meta-analysis from common effect model m12 <- metaadd(m1, data = m2, method.common = "Naive pooling") m12 forest(m12)
Test for funnel plot asymmetry, based on rank correlation or linear regression method.
## S3 method for class 'meta' metabias( x, method.bias = x$method.bias, plotit = FALSE, correct = FALSE, k.min = 10, ... ) ## S3 method for class 'metabias' print( x, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval"), 2), digits.se = gs("digits.se"), digits.tau2 = gs("digits.tau2"), scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), text.tau2 = gs("text.tau2"), details.methods = gs("details"), ... ) metabias(x, ...) ## Default S3 method: metabias( x, seTE, method.bias = "Egger", plotit = FALSE, correct = FALSE, k.min = 10, ... )
## S3 method for class 'meta' metabias( x, method.bias = x$method.bias, plotit = FALSE, correct = FALSE, k.min = 10, ... ) ## S3 method for class 'metabias' print( x, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval"), 2), digits.se = gs("digits.se"), digits.tau2 = gs("digits.tau2"), scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), text.tau2 = gs("text.tau2"), details.methods = gs("details"), ... ) metabias(x, ...) ## Default S3 method: metabias( x, seTE, method.bias = "Egger", plotit = FALSE, correct = FALSE, k.min = 10, ... )
x |
An object of class |
method.bias |
A character string indicating which test is to be used (see Details), can be abbreviated. |
plotit |
A logical indicating whether a plot should be produced (see Details). |
correct |
A logical indicating whether a continuity corrected statistic is used for rank correlation tests. |
k.min |
Minimum number of studies to perform test for funnel plot asymmetry. |
... |
Additional arguments passed on to
|
digits |
Minimal number of significant digits for estimates,
see |
digits.stat |
Minimal number of significant digits for z- or
t-value of test for test of funnel plot asymmetry, see
|
digits.pval |
Minimal number of significant digits for p-value
of test for test of funnel plot asymmetry, see
|
digits.se |
Minimal number of significant digits for standard
errors, see |
digits.tau2 |
Minimal number of significant digits for
residual heterogeneity variance, see |
scientific.pval |
A logical specifying whether p-values should be printed in scientific notation, e.g., 1.2345e-01 instead of 0.12345. |
big.mark |
A character used as thousands separator. |
zero.pval |
A logical specifying whether p-values should be printed with a leading zero. |
JAMA.pval |
A logical specifying whether p-values for test of overall effect should be printed according to JAMA reporting standards. |
text.tau2 |
Text printed to identify residual heterogeneity
variance |
details.methods |
A logical specifying whether details on statistical methods should be printed. |
seTE |
Standard error of estimated treatment effect (mandatory
if |
Functions to conduct rank correlation or linear regression tests for funnel plot asymmetry.
The following tests are generic tests for funnel plot asymmetry
which only require estimates of the treatment effect and
corresponding standard errors. Accordingly, these are the only
tests provided by R function metabias.default
.
If argument method.bias
is "Begg"
, the test statistic
is based on the rank correlation between standardised treatment
estimates and variance estimates of estimated treatment effects;
Kendall's tau is used as correlation measure (Begg & Mazumdar,
1994). The test statistic follows a standard normal
distribution. By default (if correct
is FALSE), no
continuity correction is utilised (Kendall & Gibbons, 1990).
If argument method.bias
is "Egger"
, the test
statistic is based on a weighted linear regression of the treatment
effect on its standard error (Egger et al., 1997). The test
statistic follows a t distribution with number of studies -
2
degrees of freedom.
If argument method.bias
is "Thompson"
, the test
statistic is based on a weighted linear regression of the treatment
effect on its standard error using an additive between-study
variance component denoted as methods (3a) - (3d) in Thompson &
Sharp (1999). The test statistic follows a t distribution with
number of studies - 2
degrees of freedom.
The following tests for funnel plot asymmetry are only available
for meta-analyses comparing two binary outcomes, i.e. meta-analyses
generated with the metabin
function. The only exception is
the test by Peters et al. (2006) which can also be used in a
meta-analysis of single proportions generated with metaprop
.
If argument method.bias
is "Harbord"
, the test
statistic is based on a weighted linear regression utilising
efficient score and score variance (Harbord et al., 2006,
2009). The test statistic follows a t distribution with
number of studies - 2
degrees of freedom.
In order to calculate an arcsine test for funnel plot asymmetry
(Rücker et al., 2008), one has to use the metabin
function
with argument sm = "ASD"
as input to the metabias
command. The three arcsine tests described in Rücker et al. (2008)
can be calculated by setting method.bias
to "Begg"
,
"Egger"
and "Thompson"
, respectively.
If argument method.bias
is "Macaskill"
, the test
statistic is based on a weighted linear regression of the treatment
effect on the total sample size with weights reciprocal to the
variance of the average event probability (Macaskill et al., 2001,
method FPV). The test statistic follows a t distribution
with number of studies - 2
degrees of freedom.
If argument method.bias
is "Peters"
, the test
statistic is based on a weighted linear regression of the treatment
effect on the inverse of the total sample size with weights
reciprocal to the variance of the average event probability (Peters
et al., 2006). The test statistic follows a t distribution with
number of studies - 2
degrees of freedom. Note, this test is
a variant of Macaskill et al. (2001), method FPV, using the
inverse sample size as covariate.
If argument method.bias
is "Schwarzer"
, the test
statistic is based on the rank correlation between a standardised
cell frequency and the inverse of the variance of the cell
frequency; Kendall's tau is used as correlation measure (Schwarzer
et al., 2007). The test statistic follows a standard normal
distribution. By default (if correct
is FALSE), no
continuity correction is utilised (Kendall & Gibbons, 1990).
Finally, for meta-analysis of diagnostic test accuracy studies, if
argument method.bias
is "Deeks"
, the test statistic
is based on a weighted linear regression of the log diagnostic odds
ratio on the inverse of the squared effective sample size using the
effective sample size as weights (Deeks et al., 2005). The test
statistic follows a t distribution with number of studies -
2
degrees of freedom.
If argument method.bias
is "Pustejovsky"
, the test
statistic is based on a weighted linear regression of the treatment
effect on the square root of the sum of the inverse group sample
sizes using the treatment effect variance as weights (Pustejovsky &
Rodgers, 2019). The test statistic follows a t distribution with
number of studies - 2
degrees of freedom.
Following recommendations by Sterne et al. (2011), by default, a
test for funnel plot asymmetry is only conducted if the number of
studies is ten or larger (argument k.min = 10
). This
behaviour can be changed by setting a smaller value for argument
k.min
. Note, the minimum number of studies is three.
If argument method.bias
is missing, the Harbord test
(method.bias = "Harbord"
) is used in meta-analyses with a binary
outcome for the odds ratio and Deeks' test (method.bias = "Deeks"
)
for the diagnostic odds ratios. In all other settings, the Egger test
(method.bias = "Egger"
) is used (Sterne et al., 2011).
No test for funnel plot asymmetry is conducted in meta-analyses with subgroups.
If argument plotit = TRUE
, a scatter plot is shown if
argument method.bias
is equal to "Begg"
,
"Egger"
, "Thompson"
, "Harbord"
, or
"Deeks"
.
A list with class metabias
containing the following
components if a test for funnel plot asymmetry is conducted:
statistic |
Test statistic. |
df |
The degrees of freedom of the test statistic in the case that it follows a t distribution. |
pval |
The p-value for the test. |
estimate |
Estimates used to calculate test statisic. |
method |
A character string indicating what type of test was used. |
title |
Title of Cochrane review. |
complab |
Comparison label. |
outclab |
Outcome label. |
var.model |
A character string indicating whether none, multiplicative, or additive residual heterogeneity variance was assumed. |
method.bias |
As defined above. |
x |
Meta-analysis object. |
version |
Version of R package meta used to create object. |
Or a list with the following elements if test is not conducted due to the number of studies:
k |
Number of studies in meta-analysis. |
k.min |
Minimum number of studies to perform test for funnel plot asymmetry. |
version |
Version of R package meta used to create object. |
Guido Schwarzer [email protected]
Begg CB & Mazumdar M (1994): Operating characteristics of a rank correlation test for publication bias. Biometrics, 50, 1088–101
Deeks JJ, Macaskill P, Irwig L (2005): The performance of tests of publication bias and other sample size effects in systematic reviews of diagnostic test accuracy was assessed. Journal of Clinical Epidemiology, 58:882–93
Egger M, Smith GD, Schneider M & Minder C (1997): Bias in meta-analysis detected by a simple, graphical test. British Medical Journal, 315, 629–34
Harbord RM, Egger M & Sterne J (2006): A modified test for small-study effects in meta-analyses of controlled trials with binary endpoints. Statistics in Medicine, 25, 3443–57
Harbord RM, Harris RJ, Sterne JAC (2009): Updated tests for small-study effects in meta–analyses. The Stata Journal, 9, 197–210
Kendall M & Gibbons JD (1990): Rank Correlation Methods. London: Edward Arnold
Macaskill P, Walter SD, Irwig L (2001): A comparison of methods to detect publication bias in meta-analysis. Statistics in Medicine, 20, 641–54
Peters JL, Sutton AJ, Jones DR, Abrams KR & Rushton L (2006): Comparison of two methods to detect publication bias in meta-analysis. Journal of the American Medical Association, 295, 676–80
Pustejovsky JE, Rodgers MA (2019): Testing for funnel plot asymmetry of standardized mean differences. Research Synthesis Methods, 10, 57–71
Rücker G, Schwarzer G, Carpenter JR (2008): Arcsine test for publication bias in meta-analyses with binary outcomes. Statistics in Medicine, 27, 746–63
Schwarzer G, Antes G & Schumacher M (2007): A test for publication bias in meta-analysis with sparse binary data. Statistics in Medicine, 26, 721–33
Sterne, JAC et al. (2011): Recommendations for examining and interpreting funnel plot asymmetry in meta-analyses of randomised controlled trials. BMJ (Clinical research ed.), 343, 1
Thompson SG & Sharp, SJ (1999): Explaining heterogeneity in meta-analysis: a comparison of methods, Statistics in Medicine, 18, 2693–708
funnel
, funnel.meta
,
metabin
, metacont
,
metagen
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = 1:10, sm = "RR", method = "I") metabias(m1) metabias(m1, plotit = TRUE) metabias(m1, method.bias = "Begg") metabias(m1, method.bias = "Begg", correct = TRUE) metabias(m1, method.bias = "Schwarzer") metabias(m1, method.bias = "Egger")$pval # Arcsine test (based on linear regression) # m1.as <- update(m1, sm = "ASD") metabias(m1.as) # Same result (using function metabias.default) metabias(m1.as$TE, m1.as$seTE) # No test for funnel plot asymmetry calculated # m2 <- update(m1, subset = 1:5) metabias(m2) m3 <- update(m1, subset = 1:2) metabias(m3) # Test for funnel plot asymmetry calculated (use of argument k.min) # metabias(m2, k.min = 5)
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = 1:10, sm = "RR", method = "I") metabias(m1) metabias(m1, plotit = TRUE) metabias(m1, method.bias = "Begg") metabias(m1, method.bias = "Begg", correct = TRUE) metabias(m1, method.bias = "Schwarzer") metabias(m1, method.bias = "Egger")$pval # Arcsine test (based on linear regression) # m1.as <- update(m1, sm = "ASD") metabias(m1.as) # Same result (using function metabias.default) metabias(m1.as$TE, m1.as$seTE) # No test for funnel plot asymmetry calculated # m2 <- update(m1, subset = 1:5) metabias(m2) m3 <- update(m1, subset = 1:2) metabias(m3) # Test for funnel plot asymmetry calculated (use of argument k.min) # metabias(m2, k.min = 5)
Conduct a test for funnel plot asymmetry for all outcomes in a Cochrane review of intervention studies
## S3 method for class 'rm5' metabias( x, comp.no, outcome.no, method.bias = "linreg", method.bias.binary = method.bias, method.bias.or = "score", k.min = 10, ... ) ## S3 method for class 'cdir' metabias( x, comp.no, outcome.no, method.bias = "linreg", method.bias.binary = method.bias, method.bias.or = "score", k.min = 10, ... )
## S3 method for class 'rm5' metabias( x, comp.no, outcome.no, method.bias = "linreg", method.bias.binary = method.bias, method.bias.or = "score", k.min = 10, ... ) ## S3 method for class 'cdir' metabias( x, comp.no, outcome.no, method.bias = "linreg", method.bias.binary = method.bias, method.bias.or = "score", k.min = 10, ... )
x |
An object of class |
comp.no |
Comparison number. |
outcome.no |
Outcome number. |
method.bias |
A character string indicating which test for
small-study effects is to be used for all outcomes. Either
|
method.bias.binary |
A character string indicating which test
is to be used for binary outcomes. Either |
method.bias.or |
A character string indicating which test is
to be used for binary outcomes with odds ratio as summary
measure. Either |
k.min |
Minimum number of studies to perform test for small-study effects. |
... |
Additional arguments (ignored at the moment) |
This function can be used to conduct a test for funnel plot asymmetry for all or selected meta-analyses in a Cochrane review of intervention studies (Higgins et al, 2023).
The R function metacr
is called internally.
Guido Schwarzer [email protected]
Higgins JPT, Thomas J, Chandler J, Cumpston M, Li T, Page MJ, Welch VA (editors) (2023): Cochrane Handbook for Systematic Reviews of Interventions Version 6.4 (updated August 2023). Available from https://training.cochrane.org/handbook/
metabias
, metacr
,
read.rm5
, read.cdir
,
summary.rm5
, summary.cdir
# Locate export data file "Fleiss1993_CR.csv" in sub-directory of # package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Print results for all tests of small-study effects # metabias(Fleiss1993_CR, k.min = 5) # Print result of test of small-study effects for second outcome in # first comparison # metabias(Fleiss1993_CR, comp.no = 1, outcome.no = 2, k.min = 5)
# Locate export data file "Fleiss1993_CR.csv" in sub-directory of # package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Print results for all tests of small-study effects # metabias(Fleiss1993_CR, k.min = 5) # Print result of test of small-study effects for second outcome in # first comparison # metabias(Fleiss1993_CR, comp.no = 1, outcome.no = 2, k.min = 5)
Calculation of common effect and random effects estimates (risk
ratio, odds ratio, risk difference, arcsine difference, or
diagnostic odds ratio) for meta-analyses with binary outcome
data. Mantel-Haenszel, inverse variance, Peto method, generalised
linear mixed model (GLMM), logistic regression with penalised likelihood
and sample size method are available for pooling. For GLMMs,
the rma.glmm
function from R package metafor
(Viechtbauer, 2010) is called internally. For penalised logistic regression,
R package brglm2 must be available.
metabin( event.e, n.e, event.c, n.c, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, method = ifelse(tau.common, "Inverse", gs("method")), sm = ifelse(!is.na(charmatch(tolower(method), c("peto", "glmm", "lrp", "ssw"), nomatch = NA)), "OR", gs("smbin")), incr = gs("incr"), method.incr = gs("method.incr"), allstudies = gs("allstudies"), level = gs("level"), MH.exact = gs("MH.exact"), RR.Cochrane = gs("RR.Cochrane"), Q.Cochrane = gs("Q.Cochrane") & method == "MH" & method.tau == "DL", model.glmm = gs("model.glmm"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau, method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, method.bias = ifelse(sm == "OR", "Harbord", ifelse(sm == "DOR", "Deeks", gs("method.bias"))), backtransf = gs("backtransf"), pscale = 1, text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.e = gs("label.e"), label.c = gs("label.c"), label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, hakn, adhoc.hakn, print.CMH = gs("print.CMH"), keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
metabin( event.e, n.e, event.c, n.c, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, method = ifelse(tau.common, "Inverse", gs("method")), sm = ifelse(!is.na(charmatch(tolower(method), c("peto", "glmm", "lrp", "ssw"), nomatch = NA)), "OR", gs("smbin")), incr = gs("incr"), method.incr = gs("method.incr"), allstudies = gs("allstudies"), level = gs("level"), MH.exact = gs("MH.exact"), RR.Cochrane = gs("RR.Cochrane"), Q.Cochrane = gs("Q.Cochrane") & method == "MH" & method.tau == "DL", model.glmm = gs("model.glmm"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau, method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, method.bias = ifelse(sm == "OR", "Harbord", ifelse(sm == "DOR", "Deeks", gs("method.bias"))), backtransf = gs("backtransf"), pscale = 1, text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.e = gs("label.e"), label.c = gs("label.c"), label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, hakn, adhoc.hakn, print.CMH = gs("print.CMH"), keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
event.e |
Number of events in experimental group, or true
positives in diagnostic study, or an R object
created with |
n.e |
Number of observations in experimental group or number of ill participants in diagnostic study. |
event.c |
Number of events in control group or false positives in diagnostic study. |
n.c |
Number of observations in control group or number of healthy participants in diagnostic study. |
studlab |
An optional vector with study labels. |
data |
An optional data frame containing the study information, i.e., event.e, n.e, event.c, and n.c. |
subset |
An optional vector specifying a subset of studies to be used. |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots. |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
method |
A character string indicating which method is to be
used for pooling of studies. One of |
sm |
A character string indicating which summary measure
( |
incr |
Could be either a numerical value which is added to
cell frequencies for studies with a zero cell count or the
character string |
method.incr |
A character string indicating which continuity
correction method should be used ( |
allstudies |
A logical indicating if studies with zero or all
events in both groups are to be included in the meta-analysis
(applies only if |
level |
The level used to calculate confidence intervals for individual studies. |
MH.exact |
A logical indicating if |
RR.Cochrane |
A logical indicating if 2* |
Q.Cochrane |
A logical indicating if the Mantel-Haenszel estimate is used in the calculation of the heterogeneity statistic Q which is implemented in RevMan 5, the program for preparing and maintaining Cochrane reviews. |
model.glmm |
A character string indicating which GLMM should
be used. One of |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
method.bias |
A character string indicating which test for
funnel plot asymmetry is to be used. Either |
backtransf |
A logical indicating whether results for odds
ratio ( |
pscale |
A numeric defining a scaling factor for printing of risk differences. |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.e |
Label for experimental group. |
label.c |
Label for control group. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
hakn |
Deprecated argument (replaced by 'method.random.ci'). |
adhoc.hakn |
Deprecated argument (replaced by 'adhoc.hakn.ci'). |
print.CMH |
A logical indicating whether result of the Cochran-Mantel-Haenszel test for overall effect should be printed. |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
warn |
A logical indicating whether warnings should be printed
(e.g., if |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments passed on to
|
Calculation of common and random effects estimates for meta-analyses with binary outcome data.
The following measures of treatment effect are available (Rücker et al., 2009):
Risk ratio (sm = "RR"
)
Odds ratio (sm = "OR"
)
Risk difference (sm = "RD"
)
Arcsine difference (sm = "ASD"
)
Diagnostic Odds ratio (sm = "DOR"
)
Vaccine efficacy or vaccine effectiveness (sm = "VE"
)
Note, mathematically, odds ratios and diagnostic odds ratios are
identical, however, the labels in printouts and figures
differ. Furthermore, log risk ratio (logRR) and log vaccine ratio
(logVR) are mathematical identical, however, back-transformed
results differ as vaccine efficacy or effectiveness is defined as
VE = 100 * (1 - RR)
.
A three-level random effects meta-analysis model (Van den Noortgate
et al., 2013) is utilised if argument cluster
is used and at
least one cluster provides more than one estimate. Internally,
rma.mv
is called to conduct the analysis and
weights.rma.mv
with argument type =
"rowsum"
is used to calculate random effects weights.
Default settings are utilised for several arguments (assignments
using gs
function). These defaults can be changed for
the current R session using the settings.meta
function.
Furthermore, R function update.meta
can be used to
rerun a meta-analysis with different settings.
By default, both common effect (also called common effect) and
random effects models are considered (see arguments common
and random
). If method
is "MH"
(default), the
Mantel-Haenszel method (Greenland & Robins, 1985; Robins et al.,
1986) is used to calculate the common effect estimate; if
method
is "Inverse"
, inverse variance weighting is
used for pooling (Fleiss, 1993); if method
is "Peto"
,
the Peto method is used for pooling (Yusuf et al., 1985); if
method
is "SSW"
, the sample size method is used for
pooling (Bakbergenuly et al., 2020).
While the Mantel-Haenszel and Peto method are defined under the
common effect model, random effects variants based on these methods
are also implemented in metabin
. Following RevMan 5, the
Mantel-Haenszel estimator is used in the calculation of the
between-study heterogeneity statistic Q which is used in the
DerSimonian-Laird estimator (DerSimonian and Laird,
1986). Accordingly, the results for the random effects
meta-analysis using the Mantel-Haenszel or inverse variance method
are typically very similar. For the Peto method, Peto's log odds
ratio, i.e. (O-E) / V
and its standard error sqrt(1 /
V)
with O-E
and V
denoting "Observed minus Expected"
and its variance, are utilised in the random effects
model. Accordingly, results of a random effects model using
sm = "Peto"
can be different to results from a random
effects model using sm = "MH"
or sm =
"Inverse"
. Note, the random effects estimate is based on the
inverse variance method for all methods discussed so far.
A distinctive and frequently overlooked advantage of binary endpoints is that individual patient data (IPD) can be extracted from a two-by-two table. Accordingly, statistical methods for IPD, i.e., logistic regression and generalised linear mixed models, can be utilised in a meta-analysis of binary outcomes (Stijnen et al., 2010; Simmonds et al., 2016).
R package brglm2 must be available to fit a one-stage logistic
regression model with penalised likelihood (Evrenoglou et al., 2022).
The estimation of the summary odds ratio relies on the maximisation of the
likelihood function, penalised using a Firth-type correction. This
penalisation aims to reduce bias in cases with rare events and a small
number of available studies. However, this method is not restricted
to only such cases and can be applied more generally to binary data. Note,
with this type of penalisation, all studies can be included in the analysis,
regardless of the total number of observed events. This allows both single
and double zero studies to be included without any continuity correction.
The random effects model uses a multiplicative heterogeneity parameter
, added to the model as an ad hoc term. The estimation of
this parameter relies on a modified expression of Pearson's statistic, which
accounts for sparse data. An estimate of
equal to 1 indicates the
absence of heterogeneity.
Generalised linear mixed models are available
(argument method = "GLMM"
) for the odds ratio as summary measure for
the common effect and random effects model by calling the
rma.glmm
function from R package
metafor internally.
Four different GLMMs are available for
meta-analysis with binary outcomes using argument model.glmm
(which corresponds to argument model
in the
rma.glmm
function):
1. | Logistic regression model with common study effects (default) |
(model.glmm = "UM.FS" , i.e., Unconditional
Model - Fixed Study effects) |
|
2. | Mixed-effects logistic regression model with random study effects |
(model.glmm = "UM.RS" , i.e., Unconditional
Model - Random Study effects) |
|
3. | Generalised linear mixed model (conditional Hypergeometric-Normal) |
(model.glmm = "CM.EL" , i.e., Conditional
Model - Exact Likelihood) |
|
4. | Generalised linear mixed model (conditional Binomial-Normal) |
(model.glmm = "CM.AL" , i.e., Conditional
Model - Approximate Likelihood)
|
Details on these four GLMMs as well as additional arguments which
can be provided using argument '...
' in metabin
are
described in rma.glmm
where you can also
find information on the iterative algorithms used for estimation.
Note, regardless of which value is used for argument
model.glmm
, results for two different GLMMs are calculated:
common effect model (with fixed treatment effect) and random
effects model (with random treatment effects).
Three approaches are available to apply a continuity correction:
Only studies with a zero cell count (method.incr =
"only0"
)
All studies if at least one study has a zero cell count
(method.incr = "if0all"
)
All studies irrespective of zero cell counts
(method.incr = "all"
)
By default, a continuity correction is only applied to studies with
a zero cell count (method.incr = "only0"
). This method
showed the best performance for the odds ratio in a simulation
study under the random effects model (Weber et al., 2020).
The continuity correction method is used both to calculate individual study results with confidence limits and to conduct meta-analysis based on the inverse variance method. For the risk difference, the method is only considered to calculate standard errors and confidence limits. For Peto method and GLMMs no continuity correction is used in the meta-analysis. Furthermore, the continuity correction is ignored for individual studies for the Peto method.
For studies with a zero cell count, by default, 0.5 (argument
incr
) is added to all cell frequencies for the odds ratio or
only the number of events for the risk ratio (argument
RR.Cochrane = FALSE
, default). The increment is added to all
cell frequencies for the risk ratio if argument RR.Cochrane =
TRUE
. For the risk difference, incr
is only added to all
cell frequencies to calculate the standard error. Finally, a
treatment arm continuity correction is used if incr = "TACC"
(Sweeting et al., 2004; Diamond et al., 2007).
For odds ratio and risk ratio, treatment estimates and standard
errors are only calculated for studies with zero or all events in
both groups if allstudies = TRUE
.
For the Mantel-Haenszel method, by default (if MH.exact
is
FALSE), incr
is added to cell frequencies of a study with a
zero cell count in the calculation of the pooled risk ratio or odds
ratio as well as the estimation of the variance of the pooled risk
difference, risk ratio or odds ratio. This approach is also used in
other software, e.g. RevMan 5 and the Stata procedure
metan. According to Fleiss (in Cooper & Hedges, 1994), there is no
need to add 0.5 to a cell frequency of zero to calculate the
Mantel-Haenszel estimate and he advocates the exact method
(MH.exact
= TRUE). Note, estimates based on exact
Mantel-Haenszel method or GLMM are not defined if the number of
events is zero in all studies either in the experimental or control
group.
Argument subgroup
can be used to conduct subgroup analysis for
a categorical covariate. The metareg
function can be
used instead for more than one categorical covariate or continuous
covariates.
Arguments subset
and exclude
can be used to exclude
studies from the meta-analysis. Studies are removed completely from
the meta-analysis using argument subset
, while excluded
studies are shown in printouts and forest plots using argument
exclude
(see Examples in metagen
).
Meta-analysis results are the same for both arguments.
Internally, both common effect and random effects models are
calculated regardless of values choosen for arguments
common
and random
. Accordingly, the estimate
for the random effects model can be extracted from component
TE.random
of an object of class "meta"
even if
argument random = FALSE
. However, all functions in R
package meta will adequately consider the values for
common
and random
. E.g. function
print.meta
will not print results for the random
effects model if random = FALSE
.
A prediction interval will only be shown if prediction =
TRUE
.
An object of class c("metabin", "meta")
with corresponding
generic functions (see meta-object
).
Guido Schwarzer [email protected]
Bakbergenuly I, Hoaglin DC, Kulinskaya E (2020): Methods for estimating between-study variance and overall effect in meta-analysis of odds-ratios. Research Synthesis Methods, 11, 426–42
Cooper H & Hedges LV (1994): The Handbook of Research Synthesis. Newbury Park, CA: Russell Sage Foundation
Diamond GA, Bax L, Kaul S (2007): Uncertain Effects of Rosiglitazone on the Risk for Myocardial Infarction and Cardiovascular Death. Annals of Internal Medicine, 147, 578–81
DerSimonian R & Laird N (1986): Meta-analysis in clinical trials. Controlled Clinical Trials, 7, 177–88
Evrenoglou T, White IR, Afach S, Mavridis D, Chaimani A. (2022): Network meta-analysis of rare events using penalized likelihood regression. Statistics in Medicine, 41, 5203–19
Fleiss JL (1993): The statistical basis of meta-analysis. Statistical Methods in Medical Research, 2, 121–45
Greenland S & Robins JM (1985): Estimation of a common effect parameter from sparse follow-up data. Biometrics, 41, 55–68
Review Manager (RevMan) [Computer program]. Version 5.4. The Cochrane Collaboration, 2020
Robins J, Breslow N, Greenland S (1986): Estimators of the Mantel-Haenszel Variance Consistent in Both Sparse Data and Large-Strata Limiting Models. Biometrics, 42, 311–23
Rücker G, Schwarzer G, Carpenter J, Olkin I (2009): Why add anything to nothing? The arcsine difference as a measure of treatment effect in meta-analysis with zero cells. Statistics in Medicine, 28, 721–38
Simmonds MC, Higgins JP (2016): A general framework for the use of logistic regression models in meta-analysis. Statistical Methods in Medical Research, 25, 2858–77
StataCorp. 2011. Stata Statistical Software: Release 12. College Station, TX: StataCorp LP.
Stijnen T, Hamza TH, Ozdemir P (2010): Random effects meta-analysis of event outcome in the framework of the generalized linear mixed model with applications in sparse data. Statistics in Medicine, 29, 3046–67
Sweeting MJ, Sutton AJ, Lambert PC (2004): What to add to nothing? Use and avoidance of continuity corrections in meta-analysis of sparse data. Statistics in Medicine, 23, 1351–75
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
Viechtbauer W (2010): Conducting meta-analyses in R with the metafor package. Journal of Statistical Software, 36, 1–48
Weber F, Knapp G, Ickstadt K, Kundt G, Glass Ä (2020): Zero-cell corrections in random-effects meta-analyses. Research Synthesis Methods, 11, 913–9
Yusuf S, Peto R, Lewis J, Collins R, Sleight P (1985): Beta blockade during and after myocardial infarction: An overview of the randomized trials. Progress in Cardiovascular Diseases, 27, 335–71
meta-package
, update.meta
,
forest
, funnel
,
metabias
, metacont
,
metagen
, metareg
,
print.meta
# Calculate odds ratio and confidence interval for a single study # metabin(10, 20, 15, 20, sm = "OR") # Different results (due to handling of studies with double zeros) # metabin(0, 10, 0, 10, sm = "OR") metabin(0, 10, 0, 10, sm = "OR", allstudies = TRUE) # Use subset of Olkin (1995) to conduct meta-analysis based on # inverse variance method (with risk ratio as summary measure) # data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = c(41, 47, 51, 59), studlab = paste(author, year), method = "Inverse") m1 # Show results for individual studies summary(m1) # Use different subset of Olkin (1995) # m2 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = year < 1970, studlab = paste(author, year), method = "Inverse") m2 forest(m2) # Meta-analysis with odds ratio as summary measure # m3 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = year < 1970, studlab = paste(author, year), sm = "OR", method = "Inverse") # Same meta-analysis result using 'update.meta' function m3 <- update(m2, sm = "OR") m3 # Meta-analysis based on Mantel-Haenszel method (with odds ratio as # summary measure) # m4 <- update(m3, method = "MH") m4 # Meta-analysis based on Peto method (only available for odds ratio # as summary measure) # m5 <- update(m3, method = "Peto") m5 ## Not run: # Meta-analysis using generalised linear mixed models # (only if R package 'lme4' is available) # # Logistic regression model with (k = 4) fixed study effects # (default: model.glmm = "UM.FS") # m6 <- metabin(ev.exp, n.exp, ev.cont, n.cont, studlab = paste(author, year), data = Olkin1995, subset = year < 1970, method = "GLMM") # Same results: m6 <- update(m2, method = "GLMM") m6 # Mixed-effects logistic regression model with random study effects # (warning message printed due to argument 'nAGQ') # m7 <- update(m6, model.glmm = "UM.RS") # # Use additional argument 'nAGQ' for internal call of 'rma.glmm' # function # m7 <- update(m6, model.glmm = "UM.RS", nAGQ = 1) m7 # Generalised linear mixed model (conditional Hypergeometric-Normal) # (R package 'BiasedUrn' must be available) # m8 <- update(m6, model.glmm = "CM.EL") m8 # Generalised linear mixed model (conditional Binomial-Normal) # m9 <- update(m6, model.glmm = "CM.AL") m9 # Logistic regression model with (k = 70) fixed study effects # (about 18 seconds with Intel Core i7-3667U, 2.0GHz) # m10 <- metabin(ev.exp, n.exp, ev.cont, n.cont, studlab = paste(author, year), data = Olkin1995, method = "GLMM") m10 # Mixed-effects logistic regression model with random study effects # - about 50 seconds with Intel Core i7-3667U, 2.0GHz # - several warning messages, e.g. "failure to converge, ..." # update(m10, model.glmm = "UM.RS") # Conditional Hypergeometric-Normal GLMM # - long computation time (about 12 minutes with Intel Core # i7-3667U, 2.0GHz) # - estimation problems for this very large dataset: # * warning that Choleski factorisation of Hessian failed # * confidence interval for treatment effect smaller in random # effects model compared to common effect model # system.time(m11 <- update(m10, model.glmm = "CM.EL")) m11 # Generalised linear mixed model (conditional Binomial-Normal) # (less than 1 second with Intel Core i7-3667U, 2.0GHz) # update(m10, model.glmm = "CM.AL") ## End(Not run)
# Calculate odds ratio and confidence interval for a single study # metabin(10, 20, 15, 20, sm = "OR") # Different results (due to handling of studies with double zeros) # metabin(0, 10, 0, 10, sm = "OR") metabin(0, 10, 0, 10, sm = "OR", allstudies = TRUE) # Use subset of Olkin (1995) to conduct meta-analysis based on # inverse variance method (with risk ratio as summary measure) # data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = c(41, 47, 51, 59), studlab = paste(author, year), method = "Inverse") m1 # Show results for individual studies summary(m1) # Use different subset of Olkin (1995) # m2 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = year < 1970, studlab = paste(author, year), method = "Inverse") m2 forest(m2) # Meta-analysis with odds ratio as summary measure # m3 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = year < 1970, studlab = paste(author, year), sm = "OR", method = "Inverse") # Same meta-analysis result using 'update.meta' function m3 <- update(m2, sm = "OR") m3 # Meta-analysis based on Mantel-Haenszel method (with odds ratio as # summary measure) # m4 <- update(m3, method = "MH") m4 # Meta-analysis based on Peto method (only available for odds ratio # as summary measure) # m5 <- update(m3, method = "Peto") m5 ## Not run: # Meta-analysis using generalised linear mixed models # (only if R package 'lme4' is available) # # Logistic regression model with (k = 4) fixed study effects # (default: model.glmm = "UM.FS") # m6 <- metabin(ev.exp, n.exp, ev.cont, n.cont, studlab = paste(author, year), data = Olkin1995, subset = year < 1970, method = "GLMM") # Same results: m6 <- update(m2, method = "GLMM") m6 # Mixed-effects logistic regression model with random study effects # (warning message printed due to argument 'nAGQ') # m7 <- update(m6, model.glmm = "UM.RS") # # Use additional argument 'nAGQ' for internal call of 'rma.glmm' # function # m7 <- update(m6, model.glmm = "UM.RS", nAGQ = 1) m7 # Generalised linear mixed model (conditional Hypergeometric-Normal) # (R package 'BiasedUrn' must be available) # m8 <- update(m6, model.glmm = "CM.EL") m8 # Generalised linear mixed model (conditional Binomial-Normal) # m9 <- update(m6, model.glmm = "CM.AL") m9 # Logistic regression model with (k = 70) fixed study effects # (about 18 seconds with Intel Core i7-3667U, 2.0GHz) # m10 <- metabin(ev.exp, n.exp, ev.cont, n.cont, studlab = paste(author, year), data = Olkin1995, method = "GLMM") m10 # Mixed-effects logistic regression model with random study effects # - about 50 seconds with Intel Core i7-3667U, 2.0GHz # - several warning messages, e.g. "failure to converge, ..." # update(m10, model.glmm = "UM.RS") # Conditional Hypergeometric-Normal GLMM # - long computation time (about 12 minutes with Intel Core # i7-3667U, 2.0GHz) # - estimation problems for this very large dataset: # * warning that Choleski factorisation of Hessian failed # * confidence interval for treatment effect smaller in random # effects model compared to common effect model # system.time(m11 <- update(m10, model.glmm = "CM.EL")) m11 # Generalised linear mixed model (conditional Binomial-Normal) # (less than 1 second with Intel Core i7-3667U, 2.0GHz) # update(m10, model.glmm = "CM.AL") ## End(Not run)
This function can be used to combine meta-analysis objects and is, for example, useful to summarize results of various meta-analysis methods or to generate a forest plot with results of several subgroup analyses.
metabind( ..., subgroup = NULL, name = NULL, common = NULL, random = NULL, prediction = NULL, backtransf = NULL, outclab = NULL, pooled = NULL, warn.deprecated = gs("warn.deprecated") )
metabind( ..., subgroup = NULL, name = NULL, common = NULL, random = NULL, prediction = NULL, backtransf = NULL, outclab = NULL, pooled = NULL, warn.deprecated = gs("warn.deprecated") )
... |
Any number of meta-analysis objects or a single list with meta-analyses. |
subgroup |
An optional variable to generate a forest plot with subgroups. |
name |
An optional character vector providing descriptive names for the meta-analysis objects. |
common |
A logical vector indicating whether results of common effect model should be considered. |
random |
A logical vector indicating whether results of random effects model should be considered. |
prediction |
A logical vector indicating whether results of prediction intervals should be considered. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and plots. If
|
outclab |
Outcome label for all meta-analyis objects. |
pooled |
Deprecated argument (replaced by |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
This function can be used to combine any number of meta-analysis objects which is useful, for example, to summarize results of various meta-analysis methods or to generate a forest plot with results of several subgroup analyses (see Examples).
Individual study results are not retained with metabind
as
the function allows to combine meta-analyses from different data
sets (e.g., with randomised or observational studies). Individual
study results are retained with R function metamerge
which can be used to combine results of meta-analyses of the
same dataset.
An object of class c("metabind", "meta")
with corresponding
generic functions (see meta-object
).
Guido Schwarzer [email protected]
metagen
, forest.metabind
,
metamerge
data(Fleiss1993cont) # Add some (fictitious) grouping variables: # Fleiss1993cont$age <- c(55, 65, 55, 65, 55) Fleiss1993cont$region <- c("Europe", "Europe", "Asia", "Asia", "Europe") m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") # Conduct two subgroup analyses # mu1 <- update(m1, subgroup = age, subgroup.name = "Age group") mu2 <- update(m1, subgroup = region, subgroup.name = "Region") # Combine random effects subgroup meta-analyses and show forest # plot with subgroup results # mb1 <- metabind(mu1, mu2, common = FALSE) mb1 forest(mb1) # Use various estimation methods for between-study heterogeneity # variance # m1.pm <- update(m1, method.tau = "PM") m1.dl <- update(m1, method.tau = "DL") m1.ml <- update(m1, method.tau = "ML") m1.hs <- update(m1, method.tau = "HS") m1.sj <- update(m1, method.tau = "SJ") m1.he <- update(m1, method.tau = "HE") m1.eb <- update(m1, method.tau = "EB") # Combine meta-analyses and show results # taus <- c("Restricted maximum-likelihood estimator", "Paule-Mandel estimator", "DerSimonian-Laird estimator", "Maximum-likelihood estimator", "Hunter-Schmidt estimator", "Sidik-Jonkman estimator", "Hedges estimator", "Empirical Bayes estimator") # m1.taus <- metabind(m1, m1.pm, m1.dl, m1.ml, m1.hs, m1.sj, m1.he, m1.eb, name = taus, common = FALSE) m1.taus forest(m1.taus)
data(Fleiss1993cont) # Add some (fictitious) grouping variables: # Fleiss1993cont$age <- c(55, 65, 55, 65, 55) Fleiss1993cont$region <- c("Europe", "Europe", "Asia", "Asia", "Europe") m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") # Conduct two subgroup analyses # mu1 <- update(m1, subgroup = age, subgroup.name = "Age group") mu2 <- update(m1, subgroup = region, subgroup.name = "Region") # Combine random effects subgroup meta-analyses and show forest # plot with subgroup results # mb1 <- metabind(mu1, mu2, common = FALSE) mb1 forest(mb1) # Use various estimation methods for between-study heterogeneity # variance # m1.pm <- update(m1, method.tau = "PM") m1.dl <- update(m1, method.tau = "DL") m1.ml <- update(m1, method.tau = "ML") m1.hs <- update(m1, method.tau = "HS") m1.sj <- update(m1, method.tau = "SJ") m1.he <- update(m1, method.tau = "HE") m1.eb <- update(m1, method.tau = "EB") # Combine meta-analyses and show results # taus <- c("Restricted maximum-likelihood estimator", "Paule-Mandel estimator", "DerSimonian-Laird estimator", "Maximum-likelihood estimator", "Hunter-Schmidt estimator", "Sidik-Jonkman estimator", "Hedges estimator", "Empirical Bayes estimator") # m1.taus <- metabind(m1, m1.pm, m1.dl, m1.ml, m1.hs, m1.sj, m1.he, m1.eb, name = taus, common = FALSE) m1.taus forest(m1.taus)
Calculation of common and random effects estimates for meta-analyses with continuous outcome data; inverse variance weighting is used for pooling.
metacont( n.e, mean.e, sd.e, n.c, mean.c, sd.c, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, median.e, q1.e, q3.e, min.e, max.e, median.c, q1.c, q3.c, min.c, max.c, method.mean = "Luo", method.sd = "Shi", approx.mean.e, approx.mean.c = approx.mean.e, approx.sd.e, approx.sd.c = approx.sd.e, sm = gs("smcont"), method.ci = gs("method.ci.cont"), level = gs("level"), pooledvar = gs("pooledvar"), method.smd = gs("method.smd"), sd.glass = gs("sd.glass"), exact.smd = gs("exact.smd"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = gs("method.tau"), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, method.bias = gs("method.bias"), backtransf = gs("backtransf"), text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.e = gs("label.e"), label.c = gs("label.c"), label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, id, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
metacont( n.e, mean.e, sd.e, n.c, mean.c, sd.c, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, median.e, q1.e, q3.e, min.e, max.e, median.c, q1.c, q3.c, min.c, max.c, method.mean = "Luo", method.sd = "Shi", approx.mean.e, approx.mean.c = approx.mean.e, approx.sd.e, approx.sd.c = approx.sd.e, sm = gs("smcont"), method.ci = gs("method.ci.cont"), level = gs("level"), pooledvar = gs("pooledvar"), method.smd = gs("method.smd"), sd.glass = gs("sd.glass"), exact.smd = gs("exact.smd"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = gs("method.tau"), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, method.bias = gs("method.bias"), backtransf = gs("backtransf"), text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.e = gs("label.e"), label.c = gs("label.c"), label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, id, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
n.e |
Number of observations in experimental group or an R object
created with |
mean.e |
Estimated mean in experimental group. |
sd.e |
Standard deviation in experimental group. |
n.c |
Number of observations in control group. |
mean.c |
Estimated mean in control group. |
sd.c |
Standard deviation in control group. |
studlab |
An optional vector with study labels. |
data |
An optional data frame containing the study information. |
subset |
An optional vector specifying a subset of studies to be used. |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots. |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
median.e |
Median in experimental group (used to estimate the mean and standard deviation). |
q1.e |
First quartile in experimental group (used to estimate the mean and standard deviation). |
q3.e |
Third quartile in experimental group (used to estimate the mean and standard deviation). |
min.e |
Minimum in experimental group (used to estimate the mean and standard deviation). |
max.e |
Maximum in experimental group (used to estimate the mean and standard deviation). |
median.c |
Median in control group (used to estimate the mean and standard deviation). |
q1.c |
First quartile in control group (used to estimate the mean and standard deviation). |
q3.c |
Third quartile in control group (used to estimate the mean and standard deviation). |
min.c |
Minimum in control group (used to estimate the mean and standard deviation). |
max.c |
Maximum in control group (used to estimate the mean and standard deviation). |
method.mean |
A character string indicating which method to use to approximate the mean from the median and other statistics (see Details). |
method.sd |
A character string indicating which method to use to approximate the standard deviation from sample size, median, interquartile range and range (see Details). |
approx.mean.e |
Approximation method to estimate means in experimental group (see Details). |
approx.mean.c |
Approximation method to estimate means in control group (see Details). |
approx.sd.e |
Approximation method to estimate standard deviations in experimental group (see Details). |
approx.sd.c |
Approximation method to estimate standard deviations in control group (see Details). |
sm |
A character string indicating which summary measure
( |
method.ci |
A character string indicating which method is used to calculate confidence intervals for individual studies (see Details). |
level |
The level used to calculate confidence intervals for individual studies. |
pooledvar |
A logical indicating if a pooled variance should
be used for the mean difference ( |
method.smd |
A character string indicating which method is
used to estimate the standardised mean difference
( |
sd.glass |
A character string indicating which standard
deviation is used in the denominator for Glass' method to
estimate the standardised mean difference. Either
|
exact.smd |
A logical indicating whether exact formulae should be used in estimation of the standardised mean difference and its standard error (see Details). |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
method.bias |
A character string indicating which test is to
be used. Either |
backtransf |
A logical indicating whether results for ratio of
means ( |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.e |
Label for experimental group. |
label.c |
Label for control group. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
id |
Deprecated argument (replaced by 'cluster'). |
adhoc.hakn |
Deprecated argument (replaced by 'adhoc.hakn.ci'). |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
warn |
A logical indicating whether warnings should be printed (e.g., if studies are excluded from meta-analysis due to zero standard deviations). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments (to catch deprecated arguments). |
Calculation of common and random effects estimates for meta-analyses with continuous outcome data; inverse variance weighting is used for pooling.
A three-level random effects meta-analysis model (Van den Noortgate
et al., 2013) is utilised if argument cluster
is used and at
least one cluster provides more than one estimate. Internally,
rma.mv
is called to conduct the analysis and
weights.rma.mv
with argument type =
"rowsum"
is used to calculate random effects weights.
Default settings are utilised for several arguments (assignments
using gs
function). These defaults can be changed for
the current R session using the settings.meta
function.
Furthermore, R function update.meta
can be used to
rerun a meta-analysis with different settings.
Three different types of summary measures are available for continuous outcomes:
mean difference (argument sm = "MD"
)
standardised mean difference (sm = "SMD"
)
ratio of means (sm = "ROM"
)
For the standardised mean difference three methods are implemented:
Hedges' g (default, method.smd = "Hedges"
) - see
Hedges (1981)
Cohen's d (method.smd = "Cohen"
) - see Cohen (1988)
Glass' delta (method.smd = "Glass"
) - see Glass (1976)
Hedges (1981) calculated the exact bias in Cohen's d which is a
ratio of gamma distributions with the degrees of freedom,
i.e. total sample size minus two, as argument. By default (argument
exact.smd = FALSE
), an accurate approximation of this bias
provided in Hedges (1981) is utilised for Hedges' g as well as its
standard error; these approximations are also used in RevMan
5. Following Borenstein et al. (2009) these approximations are not
used in the estimation of Cohen's d. White and Thomas (2005) argued
that approximations are unnecessary with modern software and
accordingly promote to use the exact formulae; this is possible
using argument exact.smd = TRUE
. For Hedges' g the exact
formulae are used to calculate the standardised mean difference as
well as the standard error; for Cohen's d the exact formula is only
used to calculate the standard error. In typical applications (with
sample sizes above 10), the differences between using the exact
formulae and the approximation will be minimal.
For Glass' delta, by default (argument sd.glass =
"control"
), the standard deviation in the control group
(sd.c
) is used in the denominator of the standard mean
difference. The standard deviation in the experimental group
(sd.e
) can be used by specifying sd.glass =
"experimental"
.
Meta-analysis of ratio of means – also called response ratios –
is described in Hedges et al. (1999) and Friedrich et al. (2008).
Calculations are conducted on the log scale and list elements
TE
, TE.common
, and TE.random
contain the
logarithm of the ratio of means. In printouts and plots these
values are back transformed if argument backtransf = TRUE
.
Missing means in the experimental group (analogously for the control group) can be derived from
sample size, median, interquartile range and range (arguments
n.e
, median.e
, q1.e
, q3.e
,
min.e
, and max.e
),
sample size, median and interquartile range (arguments
n.e
, median.e
, q1.e
, and q3.e
), or
sample size, median and range (arguments n.e
,
median.e
, min.e
, and max.e
).
By default, methods described in Luo et al. (2018) are utilised
(argument method.mean = "Luo"
):
equation (15) if sample size, median, interquartile range and range are available,
equation (11) if sample size, median and interquartile range are available,
equation (7) if sample size, median and range are available.
Instead the methods described in Wan et al. (2014) are used if
argument method.mean = "Wan"
:
equation (10) if sample size, median, interquartile range and range are available,
equation (14) if sample size, median and interquartile range are available,
equation (2) if sample size, median and range are available.
The following methods are also available to estimate means from quantiles or ranges if R package estmeansd is installed:
Method for Unknown Non-Normal Distributions (MLN) approach
(Cai et al. (2021), argument method.mean = "Cai"
),
Quantile Estimation (QE) method (McGrath et al. (2020),
argument method.mean = "QE-McGrath"
)),
Box-Cox (BC) method (McGrath et al. (2020),
argument method.mean = "BC-McGrath"
)).
By default, missing means are replaced successively using
interquartile ranges and ranges (if available), interquartile
ranges (if available) and finally ranges. Arguments
approx.mean.e
and approx.mean.c
can be used to
overwrite this behaviour for each individual study and treatment
arm:
use means directly (entry ""
in argument
approx.mean.e
or approx.mean.c
);
median, interquartile range and range ("iqr.range"
);
median and interquartile range ("iqr"
);
median and range ("range"
).
Missing standard deviations in the experimental group (analogously for the control group) can be derived from
sample size, median, interquartile range and range (arguments
n.e
, median.e
, q1.e
, q3.e
,
min.e
, and max.e
),
sample size, median and interquartile range (arguments
n.e
, median.e
, q1.e
and q3.e
), or
sample size, median and range (arguments n.e
,
median.e
, min.e
and max.e
).
Wan et al. (2014) describe methods to estimate the standard
deviation from the sample size, median and additional
statistics. Shi et al. (2020) provide an improved estimate of the
standard deviation if the interquartile range and range are
available in addition to the sample size and median. Accordingly,
equation (11) in Shi et al. (2020) is the default (argument
method.sd = "Shi"
), if the median, interquartile range and
range are provided. The method by Wan et al. (2014) is used if
argument method.sd = "Wan"
and, depending on the sample
size, either equation (12) or (13) is used. If only the
interquartile range or range is available, equations (15) / (16)
and (7) / (9) in Wan et al. (2014) are used, respectively.
The following methods are also available to estimate standard deviations from quantiles or ranges if R package estmeansd is installed:
Method for Unknown Non-Normal Distributions (MLN) approach
(Cai et al. (2021), argument method.mean = "Cai"
),
Quantile Estimation (QE) method (McGrath et al. (2020),
argument method.mean = "QE-McGrath"
)),
Box-Cox (BC) method (McGrath et al. (2020),
argument method.mean = "BC-McGrath"
)).
By default, missing standard deviations are replaced successively
using these method, i.e., interquartile ranges and ranges are used
before interquartile ranges before ranges. Arguments
approx.sd.e
and approx.sd.c
can be used to overwrite
this default for each individual study and treatment arms:
sample size, median, interquartile range and range
("iqr.range"
);
sample size, median and interquartile range ("iqr"
);
sample size, median and range ("range"
).
For the mean difference (argument sm = "MD"
), the confidence
interval for individual studies can be based on the
standard normal distribution (method.ci = "z"
, default), or
t-distribution (method.ci = "t"
).
Note, this choice does not affect the results of the common effect and random effects meta-analysis.
Argument subgroup
can be used to conduct subgroup analysis for
a categorical covariate. The metareg
function can be
used instead for more than one categorical covariate or continuous
covariates.
Arguments subset
and exclude
can be used to exclude
studies from the meta-analysis. Studies are removed completely from
the meta-analysis using argument subset
, while excluded
studies are shown in printouts and forest plots using argument
exclude
(see Examples in metagen
).
Meta-analysis results are the same for both arguments.
Internally, both common effect and random effects models are
calculated regardless of values choosen for arguments common
and random
. Accordingly, the estimate for the random effects
model can be extracted from component TE.random
of an object
of class "meta"
even if argument random =
FALSE
. However, all functions in R package meta will
adequately consider the values for common
and
random
. E.g. function print.meta
will not
print results for the random effects model if random =
FALSE
.
A prediction interval will only be shown if prediction =
TRUE
.
An object of class c("metacont", "meta")
with corresponding
generic functions (see meta-object
).
The function metagen
is called internally to
calculate individual and overall treatment estimates and standard
errors.
Guido Schwarzer [email protected]
Borenstein M, Hedges LV, Higgins JPT, Rothstein HR (2009): Introduction to Meta-Analysis. Chichester: Wiley
Cai S, Zhou J, Pan J (2021): Estimating the sample mean and standard deviation from order statistics and sample size in meta-analysis. Statistical Methods in Medical Research, 30, 2701–2719
Cohen J (1988): Statistical Power Analysis for the Behavioral Sciences (second ed.). Lawrence Erlbaum Associates
Friedrich JO, Adhikari NK, Beyene J (2008): The ratio of means method as an alternative to mean differences for analyzing continuous outcome variables in meta-analysis: A simulation study. BMC Medical Research Methodology, 8, 32
Glass G (1976): Primary, secondary, and meta-analysis of research. Educational Researcher, 5, 3–8
Hedges LV (1981): Distribution theory for Glass's estimator of effect size and related estimators. Journal of Educational and Behavioral Statistics, 6, 107–28
Hedges LV, Gurevitch J, Curtis PS (1999): The meta-analysis of response ratios in experimental ecology. Ecology, 80, 1150–6
Luo D, Wan X, Liu J, Tong T (2018): Optimally estimating the sample mean from the sample size, median, mid-range, and/or mid-quartile range. Statistical Methods in Medical Research, 27, 1785–805
McGrath S, Zhao X, Steele R, et al. and the DEPRESsion Screening Data (DEPRESSD) Collaboration (2020): Estimating the sample mean and standard deviation from commonly reported quantiles in meta-analysis. Statistical Methods in Medical Research, 29, 2520–2537
Review Manager (RevMan) [Computer program]. Version 5.4. The Cochrane Collaboration, 2020
Shi J, Luo D, Weng H, Zeng XT, Lin L, Chu H, Tong T (2020): Optimally estimating the sample standard deviation from the five-number summary. Research Synthesis Methods, 11, 641–54
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
Wan X, Wang W, Liu J, Tong T (2014): Estimating the sample mean and standard deviation from the sample size, median, range and/or interquartile range. BMC Medical Research Methodology, 14, 135
White IR, Thomas J (2005): Standardized mean differences in individually-randomized and cluster-randomized trials, with applications to meta-analysis. Clinical Trials, 2, 141–51
meta-package
, update.meta
,
metabin
, metagen
, pairwise
data(Fleiss1993cont) # Meta-analysis with Hedges' g as effect measure # m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") m1 forest(m1) # Use Cohen's d instead of Hedges' g as effect measure # update(m1, method.smd = "Cohen") # Use Glass' delta instead of Hedges' g as effect measure # update(m1, method.smd = "Glass") # Use Glass' delta based on the standard deviation in the experimental group # update(m1, method.smd = "Glass", sd.glass = "experimental") # Calculate Hedges' g based on exact formulae # update(m1, exact.smd = TRUE) data(amlodipine) m2 <- metacont(n.amlo, mean.amlo, sqrt(var.amlo), n.plac, mean.plac, sqrt(var.plac), data = amlodipine, studlab = study) m2 # Use pooled variance # update(m2, pooledvar = TRUE) # Meta-analysis of response ratios (Hedges et al., 1999) # data(woodyplants) m3 <- metacont(n.elev, mean.elev, sd.elev, n.amb, mean.amb, sd.amb, data = woodyplants, sm = "ROM") m3 print(m3, backtransf = FALSE)
data(Fleiss1993cont) # Meta-analysis with Hedges' g as effect measure # m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") m1 forest(m1) # Use Cohen's d instead of Hedges' g as effect measure # update(m1, method.smd = "Cohen") # Use Glass' delta instead of Hedges' g as effect measure # update(m1, method.smd = "Glass") # Use Glass' delta based on the standard deviation in the experimental group # update(m1, method.smd = "Glass", sd.glass = "experimental") # Calculate Hedges' g based on exact formulae # update(m1, exact.smd = TRUE) data(amlodipine) m2 <- metacont(n.amlo, mean.amlo, sqrt(var.amlo), n.plac, mean.plac, sqrt(var.plac), data = amlodipine, studlab = study) m2 # Use pooled variance # update(m2, pooledvar = TRUE) # Meta-analysis of response ratios (Hedges et al., 1999) # data(woodyplants) m3 <- metacont(n.elev, mean.elev, sd.elev, n.amb, mean.amb, sd.amb, data = woodyplants, sm = "ROM") m3 print(m3, backtransf = FALSE)
Calculation of common effect and random effects estimates for meta-analyses with correlations; inverse variance weighting is used for pooling.
metacor( cor, n, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, sm = gs("smcor"), level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = gs("method.tau"), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = 0, method.bias = gs("method.bias"), backtransf = gs("backtransf"), text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, adhoc.hakn, keepdata = gs("keepdata"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
metacor( cor, n, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, sm = gs("smcor"), level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = gs("method.tau"), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = 0, method.bias = gs("method.bias"), backtransf = gs("backtransf"), text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, adhoc.hakn, keepdata = gs("keepdata"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
cor |
Correlation. |
n |
Number of observations. |
studlab |
An optional vector with study labels. |
data |
An optional data frame containing the study information, i.e., cor and n. |
subset |
An optional vector specifying a subset of studies to be used. |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots. |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
sm |
A character string indicating which summary measure
( |
level |
The level used to calculate confidence intervals for individual studies. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
null.effect |
A numeric value specifying the effect under the null hypothesis. |
method.bias |
A character string indicating which test is to
be used. Either |
backtransf |
A logical indicating whether results for Fisher's
z transformed correlations ( |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
adhoc.hakn |
Deprecated argument (replaced by 'adhoc.hakn.ci'). |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments (to catch deprecated arguments). |
Common effect and random effects meta-analysis of correlations
based either on Fisher's z transformation of correlations (sm
= "ZCOR"
) or direct combination of (untransformed) correlations
(sm = "COR"
) (see Cooper et al., 2009, p264-5 and
p273-4). Only few statisticians would advocate the use of
untransformed correlations unless sample sizes are very large (see
Cooper et al., 2009, p265). The artificial example given below
shows that the smallest study gets the largest weight if
correlations are combined directly because the correlation is
closest to 1.
A three-level random effects meta-analysis model (Van den Noortgate
et al., 2013) is utilised if argument cluster
is used and at
least one cluster provides more than one estimate. Internally,
rma.mv
is called to conduct the analysis and
weights.rma.mv
with argument type =
"rowsum"
is used to calculate random effects weights.
Default settings are utilised for several arguments (assignments
using gs
function). These defaults can be changed for
the current R session using the settings.meta
function.
Furthermore, R function update.meta
can be used to
rerun a meta-analysis with different settings.
Argument subgroup
can be used to conduct subgroup analysis for
a categorical covariate. The metareg
function can be
used instead for more than one categorical covariate or continuous
covariates.
Arguments subset
and exclude
can be used to exclude
studies from the meta-analysis. Studies are removed completely from
the meta-analysis using argument subset
, while excluded
studies are shown in printouts and forest plots using argument
exclude
(see Examples in metagen
).
Meta-analysis results are the same for both arguments.
Internally, both common effect and random effects models are
calculated regardless of values choosen for arguments
common
and random
. Accordingly, the estimate
for the random effects model can be extracted from component
TE.random
of an object of class "meta"
even if
argument random = FALSE
. However, all functions in R
package meta will adequately consider the values for
common
and random
. E.g. functions
print.meta
and forest.meta
will not
print results for the random effects model if random =
FALSE
.
A prediction interval will only be shown if prediction =
TRUE
.
An object of class c("metacor", "meta")
with corresponding
generic functions (see meta-object
).
The function metagen
is called internally to
calculate individual and overall treatment estimates and standard
errors.
Guido Schwarzer [email protected]
Cooper H, Hedges LV, Valentine JC (2009): The Handbook of Research Synthesis and Meta-Analysis, 2nd Edition. New York: Russell Sage Foundation
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
meta-package
, update.meta
,
metacont
, metagen
,
print.meta
m1 <- metacor(c(0.85, 0.7, 0.95), c(20, 40, 10)) # Print correlations (back transformed from Fisher's z # transformation) # m1 # Print Fisher's z transformed correlations # print(m1, backtransf = FALSE) # Forest plot with back transformed correlations # forest(m1) # Forest plot with Fisher's z transformed correlations # forest(m1, backtransf = FALSE) m2 <- update(m1, sm = "cor") m2 ## Not run: # Identical forest plots (as back transformation is the identity # transformation) forest(m2) forest(m2, backtransf = FALSE) ## End(Not run)
m1 <- metacor(c(0.85, 0.7, 0.95), c(20, 40, 10)) # Print correlations (back transformed from Fisher's z # transformation) # m1 # Print Fisher's z transformed correlations # print(m1, backtransf = FALSE) # Forest plot with back transformed correlations # forest(m1) # Forest plot with Fisher's z transformed correlations # forest(m1, backtransf = FALSE) m2 <- update(m1, sm = "cor") m2 ## Not run: # Identical forest plots (as back transformation is the identity # transformation) forest(m2) forest(m2, backtransf = FALSE) ## End(Not run)
Wrapper function to perform meta-analysis for a single outcome of a Cochrane Intervention review.
metacr( x, comp.no = 1, outcome.no = 1, method, sm, level = gs("level"), common, random, prediction = gs("prediction") | !missing(method.predict), method.tau = "DL", method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.common = FALSE, method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = "classic", adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, Q.Cochrane, swap.events, logscale, backtransf = gs("backtransf"), test.subgroup, prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, rob = NULL, tool = NULL, categories = NULL, col = NULL, symbols = NULL, text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title, complab, outclab, col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), keepdata = gs("keepdata"), warn = FALSE, warn.deprecated = gs("warn.deprecated"), ... )
metacr( x, comp.no = 1, outcome.no = 1, method, sm, level = gs("level"), common, random, prediction = gs("prediction") | !missing(method.predict), method.tau = "DL", method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.common = FALSE, method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = "classic", adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, Q.Cochrane, swap.events, logscale, backtransf = gs("backtransf"), test.subgroup, prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, rob = NULL, tool = NULL, categories = NULL, col = NULL, symbols = NULL, text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title, complab, outclab, col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), keepdata = gs("keepdata"), warn = FALSE, warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
comp.no |
Comparison number. |
outcome.no |
Outcome number. |
method |
A character string indicating which method is to be
used for pooling of studies. One of |
sm |
A character string indicating which summary measure
( |
level |
The level used to calculate confidence intervals for individual studies. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
Q.Cochrane |
A logical indicating if the Mantel-Haenszel estimate is used in the calculation of the heterogeneity statistic Q which is implemented in RevMan 5. |
swap.events |
A logical indicating whether events and non-events should be interchanged. |
logscale |
A logical indicating whether effect estimates are
entered on log-scale (ignored for |
backtransf |
A logical indicating whether results should be
back transformed in printouts and plots. If
|
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
rob |
A logical indicating whether risk of bias (RoB)
assessment should be considered in meta-analysis (only for
|
tool |
Risk of bias (RoB) tool (only for |
categories |
Possible RoB categories (only for
|
col |
Colours for RoB categories (only for |
symbols |
Corresponding symbols for RoB categories (only for
|
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
warn |
A logical indicating whether warnings should be printed
(e.g., if |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
Cochrane intervention reviews are based on the comparison of two interventions. Each Cochrane intervention review can have a variable number of comparisons. For each comparison, a variable number of outcomes can be define. For each outcome, a separate meta-analysis is conducted. Review Manager 5 (RevMan 5) was the software used for preparing and maintaining Cochrane Reviews.
This wrapper function can be used to perform meta-analysis for a
single outcome of a Cochrane intervention review. Internally, R
functions metabin
, metacont
, and
metagen
are called - depending on the definition of
the outcome in RevMan 5.
Information on the risk of bias RoB) assessment can be provided
with arguments tool
, categories
, col
and
symbols
. This is not useful if an overall RoB assessment has
been done. In this case use rob
to add the full
flexible RoB information to a metacr
object.
Note, it is recommended to choose the RevMan 5 settings before
executing metacr
, i.e., settings.meta("revman5")
.
An object of class "meta"
and - depending on outcome type
utilised in Cochrane intervention review for selected outcome -
"metabin"
, "metacont"
, or "metagen"
with
corresponding generic functions (see meta-object
).
Guido Schwarzer [email protected]
Review Manager (RevMan) [Computer program]. Version 5.4. The Cochrane Collaboration, 2020
meta-package
, rob
,
metabin
, metacont
,
metagen
, read.cdir
,
read.rm5
, settings.meta
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") # Fleiss1993_CR <- read.rm5(filename) # Choose RevMan 5 settings and store old settings # oldset <- settings.meta("revman5", quietly = FALSE) # Same result as R command example(Fleiss1993bin) # metacr(Fleiss1993_CR) # Same result as R command example(Fleiss1993cont) # metacr(Fleiss1993_CR, 1, 2) forest(metacr(Fleiss1993_CR, 1, 2)) # Change summary measure to RR # m1 <- metacr(Fleiss1993_CR) update(m1, sm="RR") # Use old settings # settings.meta(oldset)
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") # Fleiss1993_CR <- read.rm5(filename) # Choose RevMan 5 settings and store old settings # oldset <- settings.meta("revman5", quietly = FALSE) # Same result as R command example(Fleiss1993bin) # metacr(Fleiss1993_CR) # Same result as R command example(Fleiss1993cont) # metacr(Fleiss1993_CR, 1, 2) forest(metacr(Fleiss1993_CR, 1, 2)) # Change summary measure to RR # m1 <- metacr(Fleiss1993_CR) update(m1, sm="RR") # Use old settings # settings.meta(oldset)
Performs a cumulative meta-analysis.
## S3 method for class 'meta' metacum(x, pooled, sortvar, no = 1, ...) metacum(x, ...) ## Default S3 method: metacum(x, ...)
## S3 method for class 'meta' metacum(x, pooled, sortvar, no = 1, ...) metacum(x, ...) ## Default S3 method: metacum(x, ...)
x |
An object of class |
pooled |
A character string indicating whether a common effect
or random effects model is used for pooling. Either missing (see
Details), |
sortvar |
An optional vector used to sort the individual
studies (must be of same length as |
no |
A numeric specifying which meta-analysis results to consider. |
... |
Additional arguments (ignored). |
A cumulative meta-analysis is performed. Studies are included
sequentially as defined by sortvar
.
Information from object x
is utilised if argument
pooled
is missing. A common effect model is assumed
(pooled = "common"
) if argument x$common
is
TRUE
; a random effects model is assumed (pooled =
"random"
) if argument x$random
is TRUE
and
x$common
is FALSE
.
An object of class "meta"
and "metacum"
with
corresponding generic functions (see meta-object
).
The following list elements have a different meaning:
TE , seTE
|
Estimated treatment effect and standard error of pooled estimate in cumulative meta-analyses. |
lower , upper
|
Lower and upper confidence interval limits. |
statistic |
Statistic for test of overall effect. |
pval |
P-value for test of overall effect. |
studlab |
Study label describing addition of studies. |
w |
Sum of weights from common effect or random effects model. |
TE.common , seTE.common
|
Value is |
TE.random , seTE.random
|
Value is |
Q |
Value is |
Guido Schwarzer [email protected]
Cooper H & Hedges LV (1994): The Handbook of Research Synthesis. Newbury Park, CA: Russell Sage Foundation
data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = study, sm = "RR", method = "I") m1 metacum(m1) metacum(m1, pooled = "random") forest(metacum(m1)) forest(metacum(m1, pooled = "random")) metacum(m1, sortvar = study) metacum(m1, sortvar = 7:1) m2 <- update(m1, title = "Fleiss1993bin meta-analysis", backtransf = FALSE) metacum(m2) data(Fleiss1993cont) m3 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") metacum(m3)
data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = study, sm = "RR", method = "I") m1 metacum(m1) metacum(m1, pooled = "random") forest(metacum(m1)) forest(metacum(m1, pooled = "random")) metacum(m1, sortvar = study) metacum(m1, sortvar = 7:1) m2 <- update(m1, title = "Fleiss1993bin meta-analysis", backtransf = FALSE) metacum(m2) data(Fleiss1993cont) m3 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") metacum(m3)
Common effect and random effects meta-analysis based on estimates (e.g. log hazard ratios) and their standard errors. The inverse variance method is used for pooling.
Three-level random effects meta-analysis (Van den Noortgate et al., 2013) is
available by internally calling rma.mv
function from
R package metafor (Viechtbauer, 2010).
metagen( TE, seTE, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, cycles = NULL, sm = "", method.ci = if (missing(df)) "z" else "t", level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = gs("method.tau"), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), detail.tau = "", method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = 0, method.bias = gs("method.bias"), n.e = NULL, n.c = NULL, pval, df, lower, upper, level.ci = 0.95, median, q1, q3, min, max, method.mean = "Luo", method.sd = "Shi", approx.TE, approx.seTE, transf = gs("transf") & missing(func.transf), backtransf = gs("backtransf") | !missing(func.backtransf), func.transf, func.backtransf, args.transf, args.backtransf, pscale = 1, irscale = 1, irunit = "person-years", text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.e = gs("label.e"), label.c = gs("label.c"), label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, id, adhoc.hakn, keepdata = gs("keepdata"), keeprma = gs("keeprma"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
metagen( TE, seTE, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, cycles = NULL, sm = "", method.ci = if (missing(df)) "z" else "t", level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = gs("method.tau"), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), detail.tau = "", method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = 0, method.bias = gs("method.bias"), n.e = NULL, n.c = NULL, pval, df, lower, upper, level.ci = 0.95, median, q1, q3, min, max, method.mean = "Luo", method.sd = "Shi", approx.TE, approx.seTE, transf = gs("transf") & missing(func.transf), backtransf = gs("backtransf") | !missing(func.backtransf), func.transf, func.backtransf, args.transf, args.backtransf, pscale = 1, irscale = 1, irunit = "person-years", text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.e = gs("label.e"), label.c = gs("label.c"), label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, id, adhoc.hakn, keepdata = gs("keepdata"), keeprma = gs("keeprma"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
TE |
Estimate of treatment effect, e.g., log hazard ratio or
risk difference or an R object created with |
seTE |
Standard error of treatment estimate or standard deviation of n-of-1 trials. |
studlab |
An optional vector with study labels. |
data |
An optional data frame containing the study information. |
subset |
An optional vector specifying a subset of studies to be used (see Details). |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots (see Details). |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
cycles |
A numeric vector with the number of cycles per patient / study in n-of-1 trials. |
sm |
A character string indicating underlying summary measure,
e.g., |
method.ci |
A character string indicating which method is used to calculate confidence intervals for individual studies, see Details. |
level |
The level used to calculate confidence intervals for individual studies. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
detail.tau |
Detail on between-study variance estimate. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
null.effect |
A numeric value specifying the effect under the null hypothesis. |
method.bias |
A character string indicating which test is to
be used. Either |
n.e |
Number of observations in experimental group (or total sample size in study). |
n.c |
Number of observations in control group. |
pval |
P-value (used to estimate the standard error). |
df |
Degrees of freedom (used in test or to construct confidence intervals). |
lower |
Lower limit of confidence interval (used to estimate the standard error). |
upper |
Upper limit of confidence interval (used to estimate the standard error). |
level.ci |
Level of confidence interval. |
median |
Median (used to estimate the treatment effect and standard error). |
q1 |
First quartile (used to estimate the treatment effect and standard error). |
q3 |
Third quartile (used to estimate the treatment effect and standard error). |
min |
Minimum (used to estimate the treatment effect and standard error). |
max |
Maximum (used to estimate the treatment effect and standard error). |
method.mean |
A character string indicating which method to use to approximate the mean from the median and other statistics (see Details). |
method.sd |
A character string indicating which method to use to approximate the standard deviation from sample size, median, interquartile range and range (see Details). |
approx.TE |
Approximation method to estimate treatment estimate (see Details). |
approx.seTE |
Approximation method to estimate standard error (see Details). |
transf |
A logical indicating whether inputs for arguments
|
backtransf |
A logical indicating whether results should be
back transformed in printouts and plots. If |
func.transf |
A function used to transform inputs for
arguments |
func.backtransf |
A function used to back-transform results. |
args.transf |
An optional list to provide additional arguments
to |
args.backtransf |
An optional list to provide additional
arguments to |
pscale |
A numeric giving scaling factor for printing of
single event probabilities or risk differences, i.e. if argument
|
irscale |
A numeric defining a scaling factor for printing of
single incidence rates or incidence rate differences, i.e. if
argument |
irunit |
A character specifying the time unit used to calculate rates, e.g. person-years. |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.e |
Label for experimental group. |
label.c |
Label for control group. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
id |
Deprecated argument (replaced by 'cluster'). |
adhoc.hakn |
Deprecated argument (replaced by 'adhoc.hakn.ci'). |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
keeprma |
A logical indicating whether |
warn |
A logical indicating whether warnings should be printed (e.g., if studies are excluded from meta-analysis due to zero standard errors). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments (to catch deprecated arguments). |
This function provides the generic inverse variance method
for meta-analysis which requires treatment estimates and their
standard errors (Borenstein et al., 2010). The method is useful,
e.g., for pooling of survival data (using log hazard ratio and
standard errors as input). Arguments TE
and seTE
can
be used to provide treatment estimates and standard errors
directly. However, it is possible to derive these quantities from
other information.
Argument cycles
can be used to conduct a meta-analysis of n-of-1
trials according to Senn (2024). In this case, argument seTE
does
not contain the standard error but standard deviation for individual
trials / patients. Trial-specific standard errors are calculated from an
average standard deviation multiplied by the number of cycles minus 1, i.e.,
the degrees of freedom. Details of the meta-analysis method are provided in
Senn (2024). Note, arguments used in the approximation of means or
standard errors, like lower
and upper
, or df
, are
ignored for the meta-analysis of n-of-1 trials.
A three-level random effects meta-analysis model (Van den Noortgate
et al., 2013) is utilised if argument cluster
is used and at
least one cluster provides more than one estimate. Internally,
rma.mv
is called to conduct the analysis and
weights.rma.mv
with argument type =
"rowsum"
is used to calculate random effects weights.
Default settings are utilised for several arguments (assignments
using gs
function). These defaults can be changed for
the current R session using the settings.meta
function.
Furthermore, R function update.meta
can be used to
rerun a meta-analysis with different settings.
Missing treatment estimates can be derived from
confidence limits provided by arguments lower
and
upper
;
median, interquartile range and range (arguments
median
, q1
, q3
, min
, and max
);
median and interquartile range (arguments median
,
q1
and q3
);
median and range (arguments median
, min
and
max
).
For confidence limits, the treatment estimate is defined as the center of the confidence interval (on the log scale for relative effect measures like the odds ratio or hazard ratio).
If the treatment effect is a mean it can be approximated from sample size, median, interquartile range and range.
By default, methods described in Luo et al. (2018) are utilised
(argument method.mean = "Luo"
):
equation (7) if sample size, median and range are available,
equation (11) if sample size, median and interquartile range are available,
equation (15) if sample size, median, range and interquartile range are available.
Instead the methods described in Wan et al. (2014) are used if
argument method.mean = "Wan"
:
equation (2) if sample size, median and range are available,
equation (14) if sample size, median and interquartile range are available,
equation (10) if sample size, median, range and interquartile range are available.
The following methods are also available to estimate means from quantiles or ranges if R package estmeansd is installed:
Method for Unknown Non-Normal Distributions (MLN) approach
(Cai et al. (2021), argument method.mean = "Cai"
),
Quantile Estimation (QE) method (McGrath et al. (2020),
argument method.mean = "QE-McGrath"
)),
Box-Cox (BC) method (McGrath et al. (2020),
argument method.mean = "BC-McGrath"
)).
By default, missing treatment estimates are replaced successively
using these method, i.e., confidence limits are utilised before
interquartile ranges. Argument approx.TE
can be used to
overwrite this default for each individual study:
Use treatment estimate directly (entry ""
in argument
approx.TE
);
confidence limits ("ci"
in argument approx.TE
);
median, interquartile range and range ("iqr.range"
);
median and interquartile range ("iqr"
);
median and range ("range"
).
Missing standard errors can be derived from
p-value provided by arguments pval
and (optional)
df
;
confidence limits (arguments lower
, upper
, and
(optional) df
);
sample size, median, interquartile range and range (arguments
n.e
and / or n.c
, median
, q1
,
q3
, min
, and max
);
sample size, median and interquartile range (arguments
n.e
and / or n.c
, median
, q1
and
q3
);
sample size, median and range (arguments n.e
and / or
n.c
, median
, min
and max
).
For p-values and confidence limits, calculations are either based
on the standard normal or t-distribution if argument
df
is provided. Furthermore, argument level.ci
can be
used to provide the level of the confidence interval.
Wan et al. (2014) describe methods to estimate the standard
deviation (and thus the standard error by deviding the standard
deviation with the square root of the sample size) from the sample
size, median and additional statistics. Shi et al. (2020) provide
an improved estimate of the standard deviation if the interquartile
range and range are available in addition to the sample size and
median. Accordingly, equation (11) in Shi et al. (2020) is the
default (argument method.sd = "Shi"
), if the median,
interquartile range and range are provided (arguments
median
, q1
, q3
, min
and
max
). The method by Wan et al. (2014) is used if argument
method.sd = "Wan"
and, depending on the sample size, either
equation (12) or (13) is used. If only the interquartile range or
range is available, equations (15) / (16) and (7) / (9) in Wan et
al. (2014) are used, respectively. The sample size of individual
studies must be provided with arguments n.e
and / or
n.c
. The total sample size is calculated as n.e
+
n.c
if both arguments are provided.
The following methods are also available to estimate standard deviations from quantiles or ranges if R package estmeansd is installed:
Method for Unknown Non-Normal Distributions (MLN) approach
(Cai et al. (2021), argument method.mean = "Cai"
),
Quantile Estimation (QE) method (McGrath et al. (2020),
argument method.mean = "QE-McGrath"
)),
Box-Cox (BC) method (McGrath et al. (2020),
argument method.mean = "BC-McGrath"
)).
By default, missing standard errors are replaced successively using
these method, e.g., p-value before confidence limits before
interquartile range and range. Argument approx.seTE
can be
used to overwrite this default for each individual study:
Use standard error directly (entry ""
in argument
approx.seTE
);
p-value ("pval"
in argument approx.seTE
);
confidence limits ("ci"
);
median, interquartile range and range ("iqr.range"
);
median and interquartile range ("iqr"
);
median and range ("range"
).
For the mean difference (argument sm = "MD"
), the confidence
interval for individual studies can be based on the
standard normal distribution (method.ci = "z"
), or
t-distribution (method.ci = "t"
).
By default, the first method is used if argument df
is
missing and the second method otherwise.
Note, this choice does not affect the results of the common effect and random effects meta-analysis.
Argument subgroup
can be used to conduct subgroup analysis for
a categorical covariate. The metareg
function can be
used instead for more than one categorical covariate or continuous
covariates.
Argument null.effect
can be used to specify the (treatment)
effect under the null hypothesis in a test for an overall
effect.
By default (null.effect = 0
), the null hypothesis
corresponds to "no difference" (which is obvious for absolute
effect measures like the mean difference (sm = "MD"
) or
standardised mean difference (sm = "SMD"
)). For relative
effect measures, e.g., risk ratio (sm = "RR"
) or odds ratio
(sm = "OR"
), the null effect is defined on the log scale,
i.e., log(RR) = 0 or log(OR) = 0 which is equivalent
to testing RR = 1 or OR = 1.
Use of argument null.effect
is especially useful for summary
measures without a "natural" null effect, i.e., in situations
without a second (treatment) group. For example, an overall
proportion of 50% could be tested in the meta-analysis of single
proportions with argument null.effect = 0.5
.
Note, all tests for an overall effect are two-sided with the
alternative hypothesis that the effect is unequal to
null.effect
.
Arguments subset
and exclude
can be used to exclude
studies from the meta-analysis. Studies are removed completely from
the meta-analysis using argument subset
, while excluded
studies are shown in printouts and forest plots using argument
exclude
(see Examples).
Meta-analysis results are the same for both arguments.
Internally, both common effect and random effects models are
calculated regardless of values choosen for arguments common
and random
. Accordingly, the estimate for the random effects
model can be extracted from component TE.random
of an object
of class "meta"
even if argument random =
FALSE
. However, all functions in R package meta will
adequately consider the values for common
and
random
. For example, functions print.meta
and
forest.meta
will not show results for the random
effects model if random = FALSE
.
A prediction interval will only be shown if prediction =
TRUE
.
Argument pscale
can be used to rescale single proportions or
risk differences, e.g. pscale = 1000
means that proportions
are expressed as events per 1000 observations. This is useful in
situations with (very) low event probabilities.
Argument irscale
can be used to rescale single rates or rate
differences, e.g. irscale = 1000
means that rates are
expressed as events per 1000 time units, e.g. person-years. This is
useful in situations with (very) low rates. Argument irunit
can be used to specify the time unit used in individual studies
(default: "person-years"). This information is printed in summaries
and forest plots if argument irscale
is not equal to 1.
Default settings for common
, random
,
pscale
, irscale
, irunit
and several other
arguments can be set for the whole R session using
settings.meta
.
An object of class c("metagen", "meta")
with corresponding
generic functions (see meta-object
).
R function rma.uni
from R package
metafor (Viechtbauer 2010) is called internally to estimate
the between-study variance .
Guido Schwarzer [email protected]
Borenstein M, Hedges LV, Higgins JP, Rothstein HR (2010): A basic introduction to fixed-effect and random-effects models for meta-analysis. Research Synthesis Methods, 1, 97–111
Cai S, Zhou J, Pan J (2021): Estimating the sample mean and standard deviation from order statistics and sample size in meta-analysis. Statistical Methods in Medical Research, 30, 2701–2719
Luo D, Wan X, Liu J, Tong T (2018): Optimally estimating the sample mean from the sample size, median, mid-range, and/or mid-quartile range. Statistical Methods in Medical Research, 27, 1785–805
McGrath S, Zhao X, Steele R, et al. and the DEPRESsion Screening Data (DEPRESSD) Collaboration (2020): Estimating the sample mean and standard deviation from commonly reported quantiles in meta-analysis. Statistical Methods in Medical Research, 29, 2520–2537
Senn S (2024): The analysis of continuous data from n-of-1 trials using paired cycles: a simple tutorial. Trials, 25.
Shi J, Luo D, Weng H, Zeng X-T, Lin L, Chu H, et al. (2020): Optimally estimating the sample standard deviation from the five-number summary. Research Synthesis Methods.
Viechtbauer W (2010): Conducting Meta-Analyses in R with the metafor Package. Journal of Statistical Software, 36, 1–48
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
Wan X, Wang W, Liu J, Tong T (2014): Estimating the sample mean and standard deviation from the sample size, median, range and/or interquartile range. BMC Medical Research Methodology, 14, 135
meta-package
, update.meta
,
metabin
, metacont
, pairwise
,
print.meta
, settings.meta
data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I") m1 # Identical results using the generic inverse variance method with # log risk ratio and its standard error: # Note, argument 'n.e' in metagen() is used to provide the total # sample size which is calculated from the group sample sizes n.e # and n.c in meta-analysis m1. m1.gen <- metagen(TE, seTE, studlab, n.e = n.e + n.c, data = m1, sm = "RR") m1.gen forest(m1.gen, leftcols = c("studlab", "n.e", "TE", "seTE")) # Meta-analysis with prespecified between-study variance # metagen(m1$TE, m1$seTE, sm = "RR", tau.preset = sqrt(0.1)) # Meta-analysis of survival data: # logHR <- log(c(0.95, 1.5)) selogHR <- c(0.25, 0.35) metagen(logHR, selogHR, sm = "HR") # Paule-Mandel method to estimate between-study variance for data # from Paule & Mandel (1982) # average <- c(27.044, 26.022, 26.340, 26.787, 26.796) variance <- c(0.003, 0.076, 0.464, 0.003, 0.014) # metagen(average, sqrt(variance), sm = "MD", method.tau = "PM") # Conduct meta-analysis using hazard ratios and 95% confidence intervals # # Data from Steurer et al. (2006), Analysis 1.1 Overall survival # https://doi.org/10.1002/14651858.CD004270.pub2 # study <- c("FCG on CLL 1996", "Leporrier 2001", "Rai 2000", "Robak 2000") HR <- c(0.55, 0.92, 0.79, 1.18) lower.HR <- c(0.28, 0.79, 0.59, 0.64) upper.HR <- c(1.09, 1.08, 1.05, 2.17) # # Hazard ratios and confidence intervals as input # summary(metagen(HR, lower = lower.HR, upper = upper.HR, studlab = study, sm = "HR", transf = FALSE)) # # Same result with log hazard ratios as input # summary(metagen(log(HR), lower = log(lower.HR), upper = log(upper.HR), studlab = study, sm = "HR")) # # Again, same result using an unknown summary measure and # arguments 'func.transf' and 'func.backtransf' # summary(metagen(HR, lower = lower.HR, upper = upper.HR, studlab = study, sm = "Hazard ratio", func.transf = log, func.backtransf = exp)) # # Finally, same result only providing argument 'func.transf' as the # back-transformation for the logarithm is known # summary(metagen(HR, lower = lower.HR, upper = upper.HR, studlab = study, sm = "Hazard ratio", func.transf = log)) # Exclude MRC-1 and MRC-2 studies from meta-analysis, however, # show them in printouts and forest plots # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", exclude = study %in% c("MRC-1", "MRC-2")) # # Exclude MRC-1 and MRC-2 studies completely from meta-analysis # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", subset = !(study %in% c("MRC-1", "MRC-2"))) # Exclude studies with total sample size above 1500 # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", exclude = (n.asp + n.plac) > 1500) # Exclude studies containing "MRC" in study name # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", exclude = grep("MRC", study)) # Use both arguments 'subset' and 'exclude' # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", subset = (n.asp + n.plac) > 1500, exclude = grep("MRC", study)) ## Not run: # Three-level model: effects of modified school calendars on # student achievement data(dat.konstantopoulos2011, package = "metadat") metagen(yi, sqrt(vi), studlab = study, data = dat.konstantopoulos2011, sm = "SMD", cluster = district, detail.tau = c("district", "district/school")) ## End(Not run)
data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I") m1 # Identical results using the generic inverse variance method with # log risk ratio and its standard error: # Note, argument 'n.e' in metagen() is used to provide the total # sample size which is calculated from the group sample sizes n.e # and n.c in meta-analysis m1. m1.gen <- metagen(TE, seTE, studlab, n.e = n.e + n.c, data = m1, sm = "RR") m1.gen forest(m1.gen, leftcols = c("studlab", "n.e", "TE", "seTE")) # Meta-analysis with prespecified between-study variance # metagen(m1$TE, m1$seTE, sm = "RR", tau.preset = sqrt(0.1)) # Meta-analysis of survival data: # logHR <- log(c(0.95, 1.5)) selogHR <- c(0.25, 0.35) metagen(logHR, selogHR, sm = "HR") # Paule-Mandel method to estimate between-study variance for data # from Paule & Mandel (1982) # average <- c(27.044, 26.022, 26.340, 26.787, 26.796) variance <- c(0.003, 0.076, 0.464, 0.003, 0.014) # metagen(average, sqrt(variance), sm = "MD", method.tau = "PM") # Conduct meta-analysis using hazard ratios and 95% confidence intervals # # Data from Steurer et al. (2006), Analysis 1.1 Overall survival # https://doi.org/10.1002/14651858.CD004270.pub2 # study <- c("FCG on CLL 1996", "Leporrier 2001", "Rai 2000", "Robak 2000") HR <- c(0.55, 0.92, 0.79, 1.18) lower.HR <- c(0.28, 0.79, 0.59, 0.64) upper.HR <- c(1.09, 1.08, 1.05, 2.17) # # Hazard ratios and confidence intervals as input # summary(metagen(HR, lower = lower.HR, upper = upper.HR, studlab = study, sm = "HR", transf = FALSE)) # # Same result with log hazard ratios as input # summary(metagen(log(HR), lower = log(lower.HR), upper = log(upper.HR), studlab = study, sm = "HR")) # # Again, same result using an unknown summary measure and # arguments 'func.transf' and 'func.backtransf' # summary(metagen(HR, lower = lower.HR, upper = upper.HR, studlab = study, sm = "Hazard ratio", func.transf = log, func.backtransf = exp)) # # Finally, same result only providing argument 'func.transf' as the # back-transformation for the logarithm is known # summary(metagen(HR, lower = lower.HR, upper = upper.HR, studlab = study, sm = "Hazard ratio", func.transf = log)) # Exclude MRC-1 and MRC-2 studies from meta-analysis, however, # show them in printouts and forest plots # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", exclude = study %in% c("MRC-1", "MRC-2")) # # Exclude MRC-1 and MRC-2 studies completely from meta-analysis # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", subset = !(study %in% c("MRC-1", "MRC-2"))) # Exclude studies with total sample size above 1500 # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", exclude = (n.asp + n.plac) > 1500) # Exclude studies containing "MRC" in study name # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", exclude = grep("MRC", study)) # Use both arguments 'subset' and 'exclude' # metabin(d.asp, n.asp, d.plac, n.plac, study, data = Fleiss1993bin, sm = "RR", method = "I", subset = (n.asp + n.plac) > 1500, exclude = grep("MRC", study)) ## Not run: # Three-level model: effects of modified school calendars on # student achievement data(dat.konstantopoulos2011, package = "metadat") metagen(yi, sqrt(vi), studlab = study, data = dat.konstantopoulos2011, sm = "SMD", cluster = district, detail.tau = c("district", "district/school")) ## End(Not run)
Calculation of common effect and random effects estimates (incidence
rate ratio or incidence rate difference) for meta-analyses with
event counts. Mantel-Haenszel, Cochran, inverse variance method,
and generalised linear mixed model (GLMM) are available for
pooling. For GLMMs, the rma.glmm
function
from R package metafor (Viechtbauer 2010) is called
internally.
metainc( event.e, time.e, event.c, time.c, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, method = if (sm == "IRSD") "Inverse" else "MH", sm = gs("sminc"), incr = gs("incr"), method.incr = gs("method.incr"), model.glmm = "UM.FS", level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = ifelse(!is.na(charmatch(tolower(method), "glmm", nomatch = NA)), "ML", gs("method.tau")), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, method.bias = gs("method.bias"), n.e = NULL, n.c = NULL, backtransf = if (sm == "IRSD") FALSE else gs("backtransf"), irscale = 1, irunit = "person-years", text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.e = gs("label.e"), label.c = gs("label.c"), label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, hakn, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
metainc( event.e, time.e, event.c, time.c, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, method = if (sm == "IRSD") "Inverse" else "MH", sm = gs("sminc"), incr = gs("incr"), method.incr = gs("method.incr"), model.glmm = "UM.FS", level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = ifelse(!is.na(charmatch(tolower(method), "glmm", nomatch = NA)), "ML", gs("method.tau")), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, method.bias = gs("method.bias"), n.e = NULL, n.c = NULL, backtransf = if (sm == "IRSD") FALSE else gs("backtransf"), irscale = 1, irunit = "person-years", text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.e = gs("label.e"), label.c = gs("label.c"), label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, hakn, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
event.e |
Number of events in experimental group or an R object
created with |
time.e |
Person time at risk in experimental group. |
event.c |
Number of events in control group. |
time.c |
Person time at risk in control group. |
studlab |
An optional vector with study labels. |
data |
An optional data frame containing the study information, i.e., event.e, time.e, event.c, and time.c. |
subset |
An optional vector specifying a subset of studies to be used. |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots. |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
method |
A character string indicating which method is to be
used for pooling of studies. One of |
sm |
A character string indicating which summary measure
( |
incr |
A numerical value which is added to cell frequencies for studies with a zero cell count, see Details. |
method.incr |
A character string indicating which continuity
correction method should be used ( |
model.glmm |
A character string indicating which GLMM should
be used. One of |
level |
The level used to calculate confidence intervals for individual studies. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
method.bias |
A character string indicating which test is to
be used. Either |
n.e |
Number of observations in experimental group (optional). |
n.c |
Number of observations in control group (optional). |
backtransf |
A logical indicating whether results for
incidence rate ratio ( |
irscale |
A numeric defining a scaling factor for printing of incidence rate differences. |
irunit |
A character string specifying the time unit used to calculate rates, e.g. person-years. |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.e |
Label for experimental group. |
label.c |
Label for control group. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
hakn |
Deprecated argument (replaced by 'method.random.ci'). |
adhoc.hakn |
Deprecated argument (replaced by 'adhoc.hakn.ci'). |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
warn |
A logical indicating whether warnings should be printed
(e.g., if |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments passed on to
|
Calculation of common and random effects estimates for meta-analyses comparing two incidence rates.
The following measures of treatment effect are available:
Incidence Rate Ratio (sm = "IRR"
)
Incidence Rate Difference (sm = "IRD"
)
Square root transformed Incidence Rate Difference (sm =
"IRSD"
)
Vaccine efficacy or vaccine effectiveness (sm = "VE"
)
Note, log incidence rate ratio (logIRR) and log vaccine ratio
(logVR) are mathematical identical, however, back-transformed
results differ as vaccine efficacy or effectiveness is defined as
VE = 100 * (1 - IRR)
.
A three-level random effects meta-analysis model (Van den Noortgate
et al., 2013) is utilised if argument cluster
is used and at
least one cluster provides more than one estimate. Internally,
rma.mv
is called to conduct the analysis and
weights.rma.mv
with argument type =
"rowsum"
is used to calculate random effects weights.
Default settings are utilised for several arguments (assignments
using gs
function). These defaults can be changed for
the current R session using the settings.meta
function.
Furthermore, R function update.meta
can be used to
rerun a meta-analysis with different settings.
By default, both common effect and random effects models are
considered (see arguments common
and random
). If
method
is "MH"
(default), the Mantel-Haenszel method
is used to calculate the common effect estimate (Greenland &
Robbins, 1985); if method
is "Inverse"
, inverse
variance weighting is used for pooling; if method
is
"Cochran"
, the Cochran method is used for pooling
(Bayne-Jones, 1964, Chapter 8). For these three methods, the random
effects estimate is always based on the inverse variance method.
A distinctive and frequently overlooked advantage of incidence
rates is that individual patient data (IPD) can be extracted from
count data. Accordingly, statistical methods for IPD, i.e.,
generalised linear mixed models, can be utilised in a meta-analysis
of incidence rate ratios (Stijnen et al., 2010). These methods are
available (argument method = "GLMM"
) for the common effect
and random effects model by calling the
rma.glmm
function from R package
metafor internally.
Three different GLMMs are available for meta-analysis of incidence
rate ratios using argument model.glmm
(which corresponds to
argument model
in the rma.glmm
function):
1. | Poisson regression model with fixed study effects (default) |
(model.glmm = "UM.FS" , i.e., Unconditional
Model - Fixed Study effects) |
|
2. | Mixed-effects Poisson regression model with random study effects |
(model.glmm = "UM.RS" , i.e., Unconditional
Model - Random Study effects) |
|
3. | Generalised linear mixed model (conditional Poisson-Normal) |
(model.glmm = "CM.EL" , i.e., Conditional
Model - Exact Likelihood)
|
Details on these three GLMMs as well as additional arguments which
can be provided using argument '...
' in metainc
are described in rma.glmm
where you can also
find information on the iterative algorithms used for estimation.
Note, regardless of which value is used for argument
model.glmm
, results for two different GLMMs are calculated:
common effect model (with fixed treatment effect) and random effects
model (with random treatment effects).
Three approaches are available to apply a continuity correction:
Only studies with a zero cell count (method.incr =
"only0", default
)
All studies if at least one study has a zero cell count
(method.incr = "if0all"
)
All studies irrespective of zero cell counts
(method.incr = "all"
)
For studies with a zero cell count, by default, 0.5 is added to all
cell frequencies of these studies (argument incr
). This
continuity correction is used both to calculate individual study
results with confidence limits and to conduct meta-analysis based
on the inverse variance method. For Mantel-Haenszel method, Cochran
method, and GLMMs, nothing is added to zero cell counts.
Accordingly, estimates for these methods are not defined if the
number of events is zero in all studies either in the experimental
or control group.
Argument subgroup
can be used to conduct subgroup analysis for
a categorical covariate. The metareg
function can be
used instead for more than one categorical covariate or continuous
covariates.
Arguments subset
and exclude
can be used to exclude
studies from the meta-analysis. Studies are removed completely from
the meta-analysis using argument subset
, while excluded
studies are shown in printouts and forest plots using argument
exclude
(see Examples in metagen
).
Meta-analysis results are the same for both arguments.
Internally, both common effect and random effects models are
calculated regardless of values choosen for arguments
common
and random
. Accordingly, the estimate
for the random effects model can be extracted from component
TE.random
of an object of class "meta"
even if
argument random = FALSE
. However, all functions in R
package meta will adequately consider the values for
common
and random
. E.g. function
print.meta
will not print results for the random
effects model if random = FALSE
.
A prediction interval will only be shown if prediction =
TRUE
.
An object of class c("metainc", "meta")
with corresponding
generic functions (see meta-object
).
Guido Schwarzer [email protected]
Bayne-Jones S et al. (1964): Smoking and Health: Report of the Advisory Committee to the Surgeon General of the United States. U-23 Department of Health, Education, and Welfare. Public Health Service Publication No. 1103.
Greenland S & Robins JM (1985): Estimation of a common effect parameter from sparse follow-up data. Biometrics, 41, 55–68
Stijnen T, Hamza TH, Ozdemir P (2010): Random effects meta-analysis of event outcome in the framework of the generalized linear mixed model with applications in sparse data. Statistics in Medicine, 29, 3046–67
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
Viechtbauer W (2010): Conducting Meta-Analyses in R with the Metafor Package. Journal of Statistical Software, 36, 1–48
meta-package
, metabin
,
update.meta
, print.meta
data(smoking) m1 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = smoking, studlab = study) print(m1, digits = 2) m2 <- update(m1, method = "Cochran") print(m2, digits = 2) data(lungcancer) m3 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = lungcancer, studlab = study) print(m3, digits = 2) # Redo Cochran meta-analysis with inflated standard errors # # All cause mortality # TEa <- log((smoking$d.smokers/smoking$py.smokers) / (smoking$d.nonsmokers/smoking$py.nonsmokers)) seTEa <- sqrt(1 / smoking$d.smokers + 1 / smoking$d.nonsmokers + 2.5 / smoking$d.nonsmokers) metagen(TEa, seTEa, sm = "IRR", studlab = smoking$study) # Lung cancer mortality # TEl <- log((lungcancer$d.smokers/lungcancer$py.smokers) / (lungcancer$d.nonsmokers/lungcancer$py.nonsmokers)) seTEl <- sqrt(1 / lungcancer$d.smokers + 1 / lungcancer$d.nonsmokers + 2.25 / lungcancer$d.nonsmokers) metagen(TEl, seTEl, sm = "IRR", studlab = lungcancer$study) ## Not run: # Meta-analysis using generalised linear mixed models # (only if R packages 'metafor' and 'lme4' are available) # Poisson regression model (fixed study effects) # m4 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = smoking, studlab = study, method = "GLMM") m4 # Mixed-effects Poisson regression model (random study effects) # update(m4, model.glmm = "UM.RS", nAGQ = 1) # # Generalised linear mixed model (conditional Poisson-Normal) # update(m4, model.glmm = "CM.EL") ## End(Not run)
data(smoking) m1 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = smoking, studlab = study) print(m1, digits = 2) m2 <- update(m1, method = "Cochran") print(m2, digits = 2) data(lungcancer) m3 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = lungcancer, studlab = study) print(m3, digits = 2) # Redo Cochran meta-analysis with inflated standard errors # # All cause mortality # TEa <- log((smoking$d.smokers/smoking$py.smokers) / (smoking$d.nonsmokers/smoking$py.nonsmokers)) seTEa <- sqrt(1 / smoking$d.smokers + 1 / smoking$d.nonsmokers + 2.5 / smoking$d.nonsmokers) metagen(TEa, seTEa, sm = "IRR", studlab = smoking$study) # Lung cancer mortality # TEl <- log((lungcancer$d.smokers/lungcancer$py.smokers) / (lungcancer$d.nonsmokers/lungcancer$py.nonsmokers)) seTEl <- sqrt(1 / lungcancer$d.smokers + 1 / lungcancer$d.nonsmokers + 2.25 / lungcancer$d.nonsmokers) metagen(TEl, seTEl, sm = "IRR", studlab = lungcancer$study) ## Not run: # Meta-analysis using generalised linear mixed models # (only if R packages 'metafor' and 'lme4' are available) # Poisson regression model (fixed study effects) # m4 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = smoking, studlab = study, method = "GLMM") m4 # Mixed-effects Poisson regression model (random study effects) # update(m4, model.glmm = "UM.RS", nAGQ = 1) # # Generalised linear mixed model (conditional Poisson-Normal) # update(m4, model.glmm = "CM.EL") ## End(Not run)
Performs an influence analysis. Pooled estimates are calculated omitting one study at a time.
## S3 method for class 'meta' metainf(x, pooled, sortvar, no = 1, ...) metainf(x, ...) ## Default S3 method: metainf(x, ...)
## S3 method for class 'meta' metainf(x, pooled, sortvar, no = 1, ...) metainf(x, ...) ## Default S3 method: metainf(x, ...)
x |
An object of class |
pooled |
A character string indicating whether a common effect
or random effects model is used for pooling. Either missing (see
Details), |
sortvar |
An optional vector used to sort the individual
studies (must be of same length as |
no |
A numeric specifying which meta-analysis results to consider. |
... |
Additional arguments (ignored). |
Performs a influence analysis; pooled estimates are calculated
omitting one study at a time. Studies are sorted according to
sortvar
.
Information from object x
is utilised if argument
pooled
is missing. A common effect model is assumed
(pooled="common"
) if argument x$common
is
TRUE
; a random effects model is assumed
(pooled="random"
) if argument x$random
is
TRUE
and x$common
is FALSE
.
An object of class "meta"
and "metainf"
with
corresponding generic functions (see meta-object
).
The following list elements have a different meaning:
TE , seTE
|
Estimated treatment effect and standard error of pooled estimate in influence analysis. |
lower , upper
|
Lower and upper confidence interval limits. |
statistic |
Statistic for test of overall effect. |
pval |
P-value for test of overall effect. |
studlab |
Study label describing omission of studies. |
w |
Sum of weights from common effect or random effects model. |
TE.common , seTE.common
|
Value is |
TE.random , seTE.random
|
Value is |
Q |
Value is |
Guido Schwarzer [email protected]
Cooper H & Hedges LV (1994): The Handbook of Research Synthesis. Newbury Park, CA: Russell Sage Foundation
data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = study, sm = "RR", method = "I") m1 metainf(m1) metainf(m1, pooled = "random") forest(metainf(m1)) forest(metainf(m1), layout = "revman5") forest(metainf(m1, pooled = "random")) metainf(m1, sortvar = study) metainf(m1, sortvar = 7:1) m2 <- update(m1, title = "Fleiss1993bin meta-analysis", backtransf = FALSE) metainf(m2) data(Fleiss1993cont) m3 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") metainf(m3)
data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = study, sm = "RR", method = "I") m1 metainf(m1) metainf(m1, pooled = "random") forest(metainf(m1)) forest(metainf(m1), layout = "revman5") forest(metainf(m1, pooled = "random")) metainf(m1, sortvar = study) metainf(m1, sortvar = 7:1) m2 <- update(m1, title = "Fleiss1993bin meta-analysis", backtransf = FALSE) metainf(m2) data(Fleiss1993cont) m3 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") metainf(m3)
Calculation of an overall mean from studies reporting a single mean using the inverse variance method for pooling; inverse variance weighting is used for pooling.
metamean( n, mean, sd, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, median, q1, q3, min, max, method.mean = "Luo", method.sd = "Shi", approx.mean, approx.sd, sm = gs("smmean"), method.ci = gs("method.ci.cont"), level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = gs("method.tau"), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = NA, method.bias = gs("method.bias"), backtransf = gs("backtransf"), text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
metamean( n, mean, sd, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, median, q1, q3, min, max, method.mean = "Luo", method.sd = "Shi", approx.mean, approx.sd, sm = gs("smmean"), method.ci = gs("method.ci.cont"), level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = gs("method.tau"), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = NA, method.bias = gs("method.bias"), backtransf = gs("backtransf"), text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
n |
Number of observations. |
mean |
Estimated mean. |
sd |
Standard deviation. |
studlab |
An optional vector with study labels. |
data |
An optional data frame containing the study information. |
subset |
An optional vector specifying a subset of studies to be used. |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots. |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
median |
Median (used to estimate the mean and standard deviation). |
q1 |
First quartile (used to estimate the mean and standard deviation). |
q3 |
Third quartile (used to estimate the mean and standard deviation). |
min |
Minimum (used to estimate the mean and standard deviation). |
max |
Maximum (used to estimate the mean and standard deviation). |
method.mean |
A character string indicating which method to use to approximate the mean from the median and other statistics (see Details). |
method.sd |
A character string indicating which method to use to approximate the standard deviation from sample size, median, interquartile range and range (see Details). |
approx.mean |
Approximation method to estimate means (see Details). |
approx.sd |
Approximation method to estimate standard deviations (see Details). |
sm |
A character string indicating which summary measure
( |
method.ci |
A character string indicating which method is used to calculate confidence intervals for individual studies, see Details. |
level |
The level used to calculate confidence intervals for individual studies. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
null.effect |
A numeric value specifying the effect under the null hypothesis. |
method.bias |
A character string indicating which test is to
be used. Either |
backtransf |
A logical indicating whether results should be
back transformed in printouts and plots for |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
adhoc.hakn |
Deprecated argument (replaced by 'adhoc.hakn.ci'). |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
warn |
A logical indicating whether warnings should be printed (e.g., if studies are excluded from meta-analysis due to zero standard deviations). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments (to catch deprecated arguments). |
Common effect and random effects meta-analysis of single means to
calculate an overall mean; inverse variance weighting is used for
pooling. Note, you should use R function metacont
to
compare means of pairwise comparisons instead of using
metamean
for each treatment arm separately which will break
randomisation in randomised controlled trials.
A three-level random effects meta-analysis model (Van den Noortgate
et al., 2013) is utilised if argument cluster
is used and at
least one cluster provides more than one estimate. Internally,
rma.mv
is called to conduct the analysis and
weights.rma.mv
with argument type =
"rowsum"
is used to calculate random effects weights.
Default settings are utilised for several arguments (assignments
using gs
function). These defaults can be changed for
the current R session using the settings.meta
function.
Furthermore, R function update.meta
can be used to
rerun a meta-analysis with different settings.
The following transformations of means are implemented to calculate an overall mean:
Raw, i.e. untransformed, means (sm = "MRAW"
, default)
Log transformed means (sm = "MLN"
)
Calculations are conducted on the log scale if sm =
"MLN"
. Accordingly, list elements TE
, TE.common
, and
TE.random
contain the logarithm of means. In printouts and
plots these values are back transformed if argument
backtransf = TRUE
(default).
Missing means can be derived from
sample size, median, interquartile range and range (arguments
n
, median
, q1
, q3
, min
, and
max
),
sample size, median and interquartile range (arguments
n
, median
, q1
, and q3
), or
sample size, median and range (arguments n
,
median
, min
, and max
).
By default, methods described in Luo et al. (2018) are utilised
(argument method.mean = "Luo"
):
equation (15) if sample size, median, interquartile range and range are available,
equation (11) if sample size, median and interquartile range are available,
equation (7) if sample size, median and range are available.
Instead the methods described in Wan et al. (2014) are used if
argument method.mean = "Wan"
:
equation (10) if sample size, median, interquartile range and range are available,
equation (14) if sample size, median and interquartile range are available,
equation (2) if sample size, median and range are available.
The following methods are also available to estimate means from quantiles or ranges if R package estmeansd is installed:
Method for Unknown Non-Normal Distributions (MLN) approach
(Cai et al. (2021), argument method.mean = "Cai"
),
Quantile Estimation (QE) method (McGrath et al. (2020),
argument method.mean = "QE-McGrath"
)),
Box-Cox (BC) method (McGrath et al. (2020),
argument method.mean = "BC-McGrath"
)).
By default, missing means are replaced successively using
interquartile ranges and ranges (if available), interquartile
ranges (if available) and finally ranges. Argument
approx.mean
can be used to overwrite this behaviour for each
individual study and treatment arm:
use means directly (entry ""
in argument
approx.mean
);
median, interquartile range and range ("iqr.range"
);
median and interquartile range ("iqr"
);
median and range ("range"
).
Missing standard deviations can be derived from
sample size, median, interquartile range and range (arguments
n
, median
, q1
, q3
, min
, and
max
),
sample size, median and interquartile range (arguments
n
, median
, q1
and q3
), or
sample size, median and range (arguments n
,
median
, min
and max
).
Wan et al. (2014) describe methods to estimate the standard
deviation from the sample size, median and additional
statistics. Shi et al. (2020) provide an improved estimate of the
standard deviation if the interquartile range and range are
available in addition to the sample size and median. Accordingly,
equation (11) in Shi et al. (2020) is the default (argument
method.sd = "Shi"
), if the median, interquartile range and
range are provided. The method by Wan et al. (2014) is used if
argument method.sd = "Wan"
and, depending on the sample
size, either equation (12) or (13) is used. If only the
interquartile range or range is available, equations (15) / (16)
and (7) / (9) in Wan et al. (2014) are used, respectively.
The following methods are also available to estimate standard deviations from quantiles or ranges if R package estmeansd is installed:
Method for Unknown Non-Normal Distributions (MLN) approach
(Cai et al. (2021), argument method.mean = "Cai"
),
Quantile Estimation (QE) method (McGrath et al. (2020),
argument method.mean = "QE-McGrath"
)),
Box-Cox (BC) method (McGrath et al. (2020),
argument method.mean = "BC-McGrath"
)).
By default, missing standard deviations are replaced successively
using these method, i.e., interquartile ranges and ranges are used
before interquartile ranges before ranges. Argument
approx.sd
can be used to overwrite this default for each
individual study and treatment arms:
sample size, median, interquartile range and range
("iqr.range"
);
sample size, median and interquartile range ("iqr"
);
sample size, median and range ("range"
).
For untransformed means (argument sm = "MRAW"
), the
confidence interval for individual studies can be based on the
standard normal distribution (method.ci = "z"
, default), or
t-distribution (method.ci = "t"
).
Argument subgroup
can be used to conduct subgroup analysis for
a categorical covariate. The metareg
function can be
used instead for more than one categorical covariate or continuous
covariates.
Arguments subset
and exclude
can be used to exclude
studies from the meta-analysis. Studies are removed completely from
the meta-analysis using argument subset
, while excluded
studies are shown in printouts and forest plots using argument
exclude
(see Examples in metagen
).
Meta-analysis results are the same for both arguments.
Internally, both common effect and random effects models are
calculated regardless of values choosen for arguments
common
and random
. Accordingly, the estimate
for the random effects model can be extracted from component
TE.random
of an object of class "meta"
even if
argument random = FALSE
. However, all functions in R
package meta will adequately consider the values for
common
and random
. E.g. functions
print.meta
and forest.meta
will not
print results for the random effects model if random =
FALSE
.
A prediction interval will only be shown if prediction =
TRUE
.
An object of class c("metamean", "meta")
with corresponding
generic functions (see meta-object
).
The function metagen
is called internally to
calculate individual and overall treatment estimates and standard
errors.
Guido Schwarzer [email protected]
Cai S, Zhou J, Pan J (2021): Estimating the sample mean and standard deviation from order statistics and sample size in meta-analysis. Statistical Methods in Medical Research, 30, 2701–2719
Luo D, Wan X, Liu J, Tong T (2018): Optimally estimating the sample mean from the sample size, median, mid-range, and/or mid-quartile range. Statistical Methods in Medical Research, 27, 1785–805
McGrath S, Zhao X, Steele R, et al. and the DEPRESsion Screening Data (DEPRESSD) Collaboration (2020): Estimating the sample mean and standard deviation from commonly reported quantiles in meta-analysis. Statistical Methods in Medical Research, 29, 2520–2537
Shi J, Luo D, Weng H, Zeng X-T, Lin L, Chu H, et al. (2020): Optimally estimating the sample standard deviation from the five-number summary. Research Synthesis Methods.
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
Wan X, Wang W, Liu J, Tong T (2014): Estimating the sample mean and standard deviation from the sample size, median, range and/or interquartile range. BMC Medical Research Methodology, 14, 135
meta-package
, update.meta
,
metamean
, metagen
m1 <- metamean(rep(100, 3), 1:3, rep(1, 3)) m1 m2 <- update(m1, sm = "MLN") m2 # With test for overall mean equal to 2 # update(m1, null.effect = 2) update(m2, null.effect = 2) # Print results without back-transformation # update(m1, backtransf = FALSE) update(m2, backtransf = FALSE) update(m1, null.effect = 2, backtransf = FALSE) update(m2, null.effect = 2, backtransf = FALSE)
m1 <- metamean(rep(100, 3), 1:3, rep(1, 3)) m1 m2 <- update(m1, sm = "MLN") m2 # With test for overall mean equal to 2 # update(m1, null.effect = 2) update(m2, null.effect = 2) # Print results without back-transformation # update(m1, backtransf = FALSE) update(m2, backtransf = FALSE) update(m1, null.effect = 2, backtransf = FALSE) update(m2, null.effect = 2, backtransf = FALSE)
This function can be used to merge results of two meta-analyses
into a single meta-analysis object if they are based on the same
data set. This is, for example, useful to produce a forest plot of
a random-effects meta-analysis with different estimates of the
between-study variance .
metamerge( meta1, meta2, common1 = meta1$common, random1 = meta1$random, prediction1 = meta1$prediction, common2 = meta2$common, random2 = meta2$random, prediction2 = meta2$prediction, label1 = NULL, label2 = NULL, label1.common = label1, label2.common = label2, label1.random = label1, label2.random = label2, label1.predict = label1, label2.predict = label2, label1.subgroup = label1, label2.subgroup = label2, hetlabel1 = label1.random, hetlabel2 = label2.random, taulabel1 = label1.random, taulabel2 = label2.random, text.pooled1 = NULL, text.pooled2 = NULL, text.w.pooled1 = NULL, text.w.pooled2 = NULL, text.common1 = text.pooled1, text.common2 = text.pooled2, text.random1 = text.pooled1, text.random2 = text.pooled2, text.predict1 = text.pooled1, text.predict2 = text.pooled2, text.w.common1 = text.w.pooled1, text.w.common2 = text.w.pooled2, text.w.random1 = text.w.pooled1, text.w.random2 = text.w.pooled2, keep = FALSE, keep.Q = keep, keep.I2 = keep.Q, keep.w = keep, common = common1 | common2, random = random1 | random2, overall = common | random, overall.hetstat = common | random, prediction = prediction1 | prediction2, backtransf, warn.deprecated = gs("warn.deprecated"), pooled1, pooled2 )
metamerge( meta1, meta2, common1 = meta1$common, random1 = meta1$random, prediction1 = meta1$prediction, common2 = meta2$common, random2 = meta2$random, prediction2 = meta2$prediction, label1 = NULL, label2 = NULL, label1.common = label1, label2.common = label2, label1.random = label1, label2.random = label2, label1.predict = label1, label2.predict = label2, label1.subgroup = label1, label2.subgroup = label2, hetlabel1 = label1.random, hetlabel2 = label2.random, taulabel1 = label1.random, taulabel2 = label2.random, text.pooled1 = NULL, text.pooled2 = NULL, text.w.pooled1 = NULL, text.w.pooled2 = NULL, text.common1 = text.pooled1, text.common2 = text.pooled2, text.random1 = text.pooled1, text.random2 = text.pooled2, text.predict1 = text.pooled1, text.predict2 = text.pooled2, text.w.common1 = text.w.pooled1, text.w.common2 = text.w.pooled2, text.w.random1 = text.w.pooled1, text.w.random2 = text.w.pooled2, keep = FALSE, keep.Q = keep, keep.I2 = keep.Q, keep.w = keep, common = common1 | common2, random = random1 | random2, overall = common | random, overall.hetstat = common | random, prediction = prediction1 | prediction2, backtransf, warn.deprecated = gs("warn.deprecated"), pooled1, pooled2 )
meta1 |
First meta-analysis object (see Details). |
meta2 |
Second meta-analysis object (see Details). |
common1 |
A logical indicating whether results of common effect model should be considered for first meta-analysis. |
random1 |
A logical indicating whether results of random effects model should be considered for first meta-analysis. |
prediction1 |
A logical indicating whether prediction interval should be considered for first meta-analysis. |
common2 |
A logical indicating whether results of common effect model should be considered for second meta-analysis. |
random2 |
A logical indicating whether results of random effects model should be considered for second meta-analysis. |
prediction2 |
A logical indicating whether prediction interval should be considered for second meta-analysis. |
label1 |
Default setting for arguments 'label1.common', 'label1.random', 'label1.predict' and 'label1.subgroup'. |
label2 |
Default setting for arguments 'label2.common', 'label2.random', 'label2.predict' and 'label2.subgroup'. |
label1.common |
A character string ... |
label2.common |
A character string ... |
label1.random |
A character string ... (default label for arguments 'hetlabel1' and 'taulabel1'). |
label2.random |
A character string ... (default label for arguments 'hetlabel2' and 'taulabel2'). |
label1.predict |
A character string ... |
label2.predict |
A character string ... |
label1.subgroup |
A character string ... |
label2.subgroup |
A character string ... |
hetlabel1 |
A character string used to label heterogeneity statistics of the first meta-analysis. |
hetlabel2 |
A character string used to label heterogeneity statistics of the second meta-analysis. |
taulabel1 |
A character string used to label estimate of between-study variance of the first meta-analysis. |
taulabel2 |
A character string used to label estimate of between-study variance of the second meta-analysis. |
text.pooled1 |
A character string used in printouts and forest plot to label the results from the first meta-analysis. |
text.pooled2 |
A character string used in printouts and forest plot to label the results from the second meta-analysis. |
text.w.pooled1 |
A character string used to label weights of
the first meta-analysis; can be of same length as the number of
pooled estimates requested in argument |
text.w.pooled2 |
A character string used to label weights of
the second meta-analysis; can be of same length as the number of
pooled estimates requested in argument |
text.common1 |
A character string used in printouts and forest plot to label results for common effect models from the first meta-analysis. |
text.common2 |
A character string used in printouts and forest plot to label results for common effect models from the second meta-analysis. |
text.random1 |
A character string used in printouts and forest plot to label results for random effects models from the first meta-analysis. |
text.random2 |
A character string used in printouts and forest plot to label results for random effects models from the second meta-analysis. |
text.predict1 |
A character string used in printouts and forest plot to label prediction interval from the first meta-analysis. |
text.predict2 |
A character string used in printouts and forest plot to label prediction interval from the second meta-analysis. |
text.w.common1 |
A character string used to label common effect weights of the first meta-analysis; can be of same length as the number of common effect estimates. |
text.w.common2 |
A character string used to label common effect weights of the second meta-analysis; can be of same length as the number of common effect estimates. |
text.w.random1 |
A character string used to label random effects weights of the first meta-analysis; can be of same length as the number of random effects estimates. |
text.w.random2 |
A character string used to label random effects weights of the second meta-analysis; can be of same length as the number of random effects estimates. |
keep |
A logical indicating whether to keep additional information from second meta-analysis. |
keep.Q |
A logical indicating whether heterogeneity statistic Q of second meta-analysis should be kept or ignored. |
keep.I2 |
A logical indicating whether heterogeneity statistic I2 of second meta-analysis should be kept or ignored. |
keep.w |
A logical indicating whether weights of the second meta-analysis should be kept or ignored. |
common |
A logical indicating whether results of common effect meta-analyses should be reported. |
random |
A logical indicating whether results of random effects meta-analyses should be reported. |
overall |
A logical indicating whether overall summaries should be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. |
prediction |
A logical indicating whether prediction intervals should be reported. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and plots. If
|
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
pooled1 |
Deprecated argument (replaced by 'common1',
'random1', 'prediction1'). A character string indicating whether
results of common effect or random effects model should be
considered for first meta-analysis. Either |
pooled2 |
Deprecated argument (replaced by 'common2',
'random2', 'prediction2'). A character string indicating whether
results of common effect or random effects model should be
considered for second meta-analysis. Either |
In R package meta, objects of class "meta"
contain
results of both common effect and random effects
meta-analyses. This function enables the user to merge the results
of two meta-analysis object if they are based on the same data set.
Applications of this function include printing and plotting results of the common effect or random effects meta-analysis and the
trim-and-fill method (trimfill
),
limit meta-analyis (limitmeta
from R
package metasens),
Copas selection model (copas
from R
package metasens),
robust variance meta-analysis model
(robu
from R package robumeta).
The first argument (meta1
) must be an object created by a
meta-analysis function (see meta-object
). If an
object created with limitmeta
or
copas
is provided as the first argument,
this object will be returned, i.e., argument meta2
will be
ignored.
The second meta-analysis could be an object created by a
meta-analysis function or with trimfill
,
limitmeta
, copas
,
or robu
.
The created meta-analysis object only contains the study results,
i.e., estimated effects and confidence intervals, from the first
meta-analysis which are shown in printouts and forest plots. This
only makes a difference for meta-analysis methods where individual
study results differ, e.g., Mantel-Haenszel and Peto method for
binary outcomes (see metabin
).
R function metaadd
can be used to add pooled results
from any (external) meta-analysis.
R function metabind
can be used to print and plot the
results of several meta-analyses without the restriction that the
same data set has to be used. Accordingly, individual study results
are ignored.
An object of class "meta"
and "metamerge"
with
corresponding generic functions (see meta-object
).
The following list elements have a different meaning:
TE , seTE , studlab
|
Treatment estimate, standard error, and study labels (first meta-analyis). |
lower , upper
|
Lower and upper confidence interval limits for individual studies (first meta-analysis). |
statistic , pval
|
Statistic and p-value for test of treatment effect for individual studies (first meta-analysis. |
w.common |
Vector or matrix with common effect weights. |
w.random |
Vector or matrix with random effects weights. |
k |
Vector with number of estimates (same length as number of common effect and random effects estimates). |
k.study |
Vector with number of studies (same length as number of common effect and random effects estimates). |
k.all |
Vector with total number of studies (same length as number of common effect and random effects estimates). |
k.TE |
Vector with number of studies with estimable effects (same length as number of common effect and random effects estimates). |
k.MH |
Vector with number of studies combined with Mantel-Haenszel method (same length as number of common effect and random effects estimates). |
TE.common |
Vector with common effect estimates. |
seTE.common |
Vector with standard errors of common effect estimates. |
lower.common |
Vector with lower confidence limits (common effect model). |
upper.common |
Vector with upper confidence limits (common effect model). |
statistic.common |
Vector with test statistics for test of overall effect (common effect model). |
pval.common |
Vector with p-value of test for overall effect (common effect model). |
TE.random |
Vector with random effects estimates. |
seTE.random |
Vector with standard errors of random effects estimates. |
lower.random |
Vector with lower confidence limits (random effects model). |
upper.random |
Vector with upper confidence limits (random effects model). |
statistic.random |
Vector with test statistics for test of overall effect (random effects model). |
pval.random |
Vector with p-value of test for overall effect (random effects model). |
Furthermore, meta-analysis results of common effect or random
effects model are taken from first meta-analysis if only random
effects or common effects models are selected from both
meta-analyses (arguments pooled1
and pooled2
).
Guido Schwarzer [email protected]
# Print results with more significant digits and do not show confidence # intervals for tau^2 and tau oldset <- settings.meta(digits = 6, digits.stat = 4, digits.pval = 6, digits.Q = 6, digits.I2 = 4, digits.H = 4, print.tau2.ci = FALSE, print.tau.ci = FALSE) oldopts <- options(width = 120) data(Fleiss1993bin) # Mantel-Haenszel method m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR") # Peto method m2 <- update(m1, method = "Peto") # Inverse variance method (only common effect model) m3 <- update(m2, method = "Inverse", random = FALSE) # Merge results from MH and Peto method # - show individual results for MH method # (as this is the first meta-analysis) # - keep all additional information from Peto meta-analysis (i.e., # weights, Q statistic and I2 statistic) m12 <- metamerge(m1, m2, label1 = "REML", label2 = "REML-Peto", label1.common = "MH", label2.common = "Peto", text.common1 = "Mantel-Haenszel method", text.common2 = "Peto method", text.w.random1 = "REML", text.w.random2 = "REML-Peto", hetlabel1 = "MH/IV", hetlabel2 = "Peto", keep = TRUE) # Add common effect results from inverse variance method # - keep weights from IV meta-analysis # - Q and I2 statistic are identical for sm = "MH" and sm = "Inverse" # as inverse variance method is used for sm = "MH" under random # effects model m123 <- metamerge(m12, m3, label2 = "IV", text.common2 = "Inverse variance method", keep.w = TRUE) summary(m123) ## Not run: forest(m123, digits = 6) # Merge results (show individual results for Peto method) m21 <- metamerge(m2, m1, label1 = "REML-Peto", label2 = "REML", label1.common = "Peto", label2.common = "MH", hetlabel1 = "Peto", hetlabel2 = "MH/IV", text.common1 = "Peto method", text.common2 = "Mantel-Haenszel method", keep = TRUE) # Add results from inverse variance method # - keep weights from IV meta-analysis # - Q and I2 statistic are identical for sm = "MH" and sm = "Inverse" # as inverse variance method is used for sm = "MH" under random # effects model m213 <- metamerge(m21, m3, label2 = "IV", text.common2 = "Inverse variance method", keep.w = TRUE) summary(m213) # Random effects method using ML estimator for between-study variance tau2 m4 <- update(m1, common = FALSE, method.tau = "ML") # Use DerSimonian-Laird estimator for tau2 m5 <- update(m4, method.tau = "DL") # Use Paule-Mandel estimator for tau2 m6 <- update(m4, method.tau = "PM") # Merge random effects results for ML and DL estimators # - keep weights for DL estimator (which are different from ML) m45 <- metamerge(m4, m5, label1 = "ML", label2 = "DL", text.w.random1 = "RE-ML", text.w.random2 = "RE-DL", keep.w = TRUE) summary(m45) # Add results for PM estimator # - keep weights m456 <- metamerge(m45, m6, label2 = "PM", text.w.random2 = "RE-PM", keep.w = TRUE) summary(m456) m123456 <- metamerge(m123, m456) m123456 # Use Hartung-Knapp confidence intervals # - do not keep information on Q, I2 and weights m7 <- update(m4, method.random.ci = "HK", text.random = "Hartung-Knapp method") m8 <- update(m5, method.random.ci = "HK", text.random = "Hartung-Knapp method") m9 <- update(m6, method.random.ci = "HK", text.random = "Hartung-Knapp method") # Merge results for Hartung-Knapp method (with REML and DL estimator) # - RE weights for REML estimator are shown m78 <- metamerge(m7, m8, label1 = "ML", label2 = "DL") summary(m78) m789 <- metamerge(m78, m9, label2 = "PM") summary(m789) # Merge everything m1to9 <- metamerge(metamerge(m123, m456, keep.w = TRUE), m789) summary(m1to9) m10 <- update(m1, method = "GLMM") m.all <- metamerge(m1to9, m10, keep.Q = TRUE, label2 = "GLMM", taulabel2 = "ML-GLMM") summary(m.all) forest(m.all, layout = "JAMA") forest(m.all, details = TRUE) ## End(Not run) settings.meta(oldset) options(oldopts)
# Print results with more significant digits and do not show confidence # intervals for tau^2 and tau oldset <- settings.meta(digits = 6, digits.stat = 4, digits.pval = 6, digits.Q = 6, digits.I2 = 4, digits.H = 4, print.tau2.ci = FALSE, print.tau.ci = FALSE) oldopts <- options(width = 120) data(Fleiss1993bin) # Mantel-Haenszel method m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR") # Peto method m2 <- update(m1, method = "Peto") # Inverse variance method (only common effect model) m3 <- update(m2, method = "Inverse", random = FALSE) # Merge results from MH and Peto method # - show individual results for MH method # (as this is the first meta-analysis) # - keep all additional information from Peto meta-analysis (i.e., # weights, Q statistic and I2 statistic) m12 <- metamerge(m1, m2, label1 = "REML", label2 = "REML-Peto", label1.common = "MH", label2.common = "Peto", text.common1 = "Mantel-Haenszel method", text.common2 = "Peto method", text.w.random1 = "REML", text.w.random2 = "REML-Peto", hetlabel1 = "MH/IV", hetlabel2 = "Peto", keep = TRUE) # Add common effect results from inverse variance method # - keep weights from IV meta-analysis # - Q and I2 statistic are identical for sm = "MH" and sm = "Inverse" # as inverse variance method is used for sm = "MH" under random # effects model m123 <- metamerge(m12, m3, label2 = "IV", text.common2 = "Inverse variance method", keep.w = TRUE) summary(m123) ## Not run: forest(m123, digits = 6) # Merge results (show individual results for Peto method) m21 <- metamerge(m2, m1, label1 = "REML-Peto", label2 = "REML", label1.common = "Peto", label2.common = "MH", hetlabel1 = "Peto", hetlabel2 = "MH/IV", text.common1 = "Peto method", text.common2 = "Mantel-Haenszel method", keep = TRUE) # Add results from inverse variance method # - keep weights from IV meta-analysis # - Q and I2 statistic are identical for sm = "MH" and sm = "Inverse" # as inverse variance method is used for sm = "MH" under random # effects model m213 <- metamerge(m21, m3, label2 = "IV", text.common2 = "Inverse variance method", keep.w = TRUE) summary(m213) # Random effects method using ML estimator for between-study variance tau2 m4 <- update(m1, common = FALSE, method.tau = "ML") # Use DerSimonian-Laird estimator for tau2 m5 <- update(m4, method.tau = "DL") # Use Paule-Mandel estimator for tau2 m6 <- update(m4, method.tau = "PM") # Merge random effects results for ML and DL estimators # - keep weights for DL estimator (which are different from ML) m45 <- metamerge(m4, m5, label1 = "ML", label2 = "DL", text.w.random1 = "RE-ML", text.w.random2 = "RE-DL", keep.w = TRUE) summary(m45) # Add results for PM estimator # - keep weights m456 <- metamerge(m45, m6, label2 = "PM", text.w.random2 = "RE-PM", keep.w = TRUE) summary(m456) m123456 <- metamerge(m123, m456) m123456 # Use Hartung-Knapp confidence intervals # - do not keep information on Q, I2 and weights m7 <- update(m4, method.random.ci = "HK", text.random = "Hartung-Knapp method") m8 <- update(m5, method.random.ci = "HK", text.random = "Hartung-Knapp method") m9 <- update(m6, method.random.ci = "HK", text.random = "Hartung-Knapp method") # Merge results for Hartung-Knapp method (with REML and DL estimator) # - RE weights for REML estimator are shown m78 <- metamerge(m7, m8, label1 = "ML", label2 = "DL") summary(m78) m789 <- metamerge(m78, m9, label2 = "PM") summary(m789) # Merge everything m1to9 <- metamerge(metamerge(m123, m456, keep.w = TRUE), m789) summary(m1to9) m10 <- update(m1, method = "GLMM") m.all <- metamerge(m1to9, m10, keep.Q = TRUE, label2 = "GLMM", taulabel2 = "ML-GLMM") summary(m.all) forest(m.all, layout = "JAMA") forest(m.all, details = TRUE) ## End(Not run) settings.meta(oldset) options(oldopts)
Calculation of an overall proportion from studies reporting a
single proportion. Inverse variance method and generalised linear
mixed model (GLMM) are available for pooling. For GLMMs, the
rma.glmm
function from R package
metafor (Viechtbauer 2010) is called internally.
metaprop( event, n, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, method, sm = gs("smprop"), incr = gs("incr"), method.incr = gs("method.incr"), method.ci = gs("method.ci.prop"), level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = ifelse(!is.na(charmatch(tolower(method), "glmm", nomatch = NA)), "ML", gs("method.tau")), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = NA, method.bias = gs("method.bias"), backtransf = gs("backtransf"), pscale = 1, text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, hakn, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
metaprop( event, n, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, method, sm = gs("smprop"), incr = gs("incr"), method.incr = gs("method.incr"), method.ci = gs("method.ci.prop"), level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau = ifelse(!is.na(charmatch(tolower(method), "glmm", nomatch = NA)), "ML", gs("method.tau")), method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = NA, method.bias = gs("method.bias"), backtransf = gs("backtransf"), pscale = 1, text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, hakn, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
event |
Number of events. |
n |
Number of observations. |
studlab |
An optional vector with study labels. |
data |
An optional data frame containing the study information, i.e., event and n. |
subset |
An optional vector specifying a subset of studies to be used. |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots. |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
method |
A character string indicating which method is to be
used for pooling of studies. One of |
sm |
A character string indicating which summary measure
( |
incr |
A numeric which is added to event number and sample size of studies with zero or all events, i.e., studies with an event probability of either 0 or 1. |
method.incr |
A character string indicating which continuity
correction method should be used ( |
method.ci |
A character string indicating which method is used to calculate confidence intervals for individual studies, see Details. |
level |
The level used to calculate confidence intervals for individual studies. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
null.effect |
A numeric value specifying the effect under the null hypothesis. |
method.bias |
A character string indicating which test is to
be used. Either |
backtransf |
A logical indicating whether results for
transformed proportions (argument |
pscale |
A numeric defining a scaling factor for printing of single event probabilities. |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
hakn |
Deprecated argument (replaced by 'method.random.ci'). |
adhoc.hakn |
Deprecated argument (replaced by 'adhoc.hakn.ci'). |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
warn |
A logical indicating whether warnings should be printed (e.g., if estimation problems exist in fitting a GLMM). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments passed on to
|
This function provides methods for common effect and random effects
meta-analysis of single proportions to calculate an overall
proportion. Note, you should use R function metabin
to compare proportions of pairwise comparisons instead of using
metaprop
for each treatment arm separately which will break
randomisation in randomised controlled trials.
The following transformations of proportions are implemented to calculate an overall proportion:
Logit transformation (sm = "PLOGIT"
, default)
Arcsine transformation (sm = "PAS"
)
Freeman-Tukey Double arcsine transformation (sm = "PFT"
)
Log transformation (sm = "PLN"
)
No transformation (sm = "PRAW"
)
List elements TE
, TE.common
, TE.random
, etc.,
contain the transformed proportions. In printouts and plots these
values are back transformed if argument backtransf = TRUE
(default).
A generalised linear mixed model (GLMM) - more specific, a random
intercept logistic regression model - can be utilised for the
meta-analysis of proportions (Stijnen et al., 2010). This is the
default method for the logit transformation (argument sm =
"PLOGIT"
). Internally, the rma.glmm
function from R package metafor is called to fit a GLMM.
Classic meta-analysis (Borenstein et al., 2010) utilising the
(un)transformed proportions and corresponding standard errors in
the inverse variance method is conducted by calling the
metagen
function internally. This is the only
available method for all transformations but the logit
transformation. The classic meta-analysis model with logit
transformed proportions is used by setting argument method =
"Inverse"
.
A three-level random effects meta-analysis model (Van den Noortgate
et al., 2013) is utilised if argument cluster
is used and at
least one cluster provides more than one estimate. Internally,
rma.mv
is called to conduct the analysis and
weights.rma.mv
with argument type =
"rowsum"
is used to calculate random effects weights.
Default settings are utilised for several arguments (assignments
using gs
function). These defaults can be changed for
the current R session using the settings.meta
function.
Furthermore, R function update.meta
can be used to
rerun a meta-analysis with different settings.
Contradictory recommendations on the use of transformations of proportions have been published in the literature. For example, Barendregt et al. (2013) recommend the use of the Freeman-Tukey double arcsine transformation instead of the logit transformation whereas Warton & Hui (2011) strongly advise to use generalised linear mixed models with the logit transformation instead of the arcsine transformation.
Schwarzer et al. (2019) describe seriously misleading results in a meta-analysis with very different sample sizes due to problems with the back-transformation of the Freeman-Tukey transformation which requires a single sample size (Miller, 1978). Accordingly, Schwarzer et al. (2019) also recommend to use GLMMs for the meta-analysis of single proportions, however, admit that individual study weights are not available with this method. Meta-analysts which require individual study weights should consider the inverse variance method with the arcsine or logit transformation.
In order to prevent misleading conclusions for the Freeman-Tukey double arcsine transformation, sensitivity analyses using other transformations or using a range of sample sizes should be conducted (Schwarzer et al., 2019).
Three approaches are available to apply a continuity correction:
Only studies with a zero cell count (method.incr =
"only0"
)
All studies if at least one study has a zero cell count
(method.incr = "if0all"
)
All studies irrespective of zero cell counts
(method.incr = "all"
)
If the summary measure is equal to "PLOGIT", "PLN", or "PRAW", the continuity correction is applied if a study has either zero or all events, i.e., an event probability of either 0 or 1.
By default, 0.5 is used as continuity correction (argument
incr
). This continuity correction is used both to calculate
individual study results with confidence limits and to conduct
meta-analysis based on the inverse variance method. For GLMMs no
continuity correction is used.
Various methods are available to calculate confidence intervals for individual study results (see Agresti & Coull 1998 and Newcombe 1988):
Clopper-Pearson interval also called 'exact' binomial
interval (method.ci = "CP"
, default)
Wilson Score interval (method.ci = "WS"
)
Wilson Score interval with continuity correction
(method.ci = "WSCC"
)
Agresti-Coull interval (method.ci = "AC"
)
Simple approximation interval (method.ci = "SA"
)
Simple approximation interval with continuity correction
(method.ci = "SACC"
)
Normal approximation interval based on summary measure,
i.e. defined by argument sm
(method.ci = "NAsm"
)
Note, with exception of the normal approximation based on the
summary measure, i.e. method.ci = "NAsm"
, the same
confidence interval is calculated for individual studies for any
summary measure (argument sm
) as only number of events and
observations are used in the calculation disregarding the chosen
transformation.
Results will be presented for transformed proportions if argument
backtransf = FALSE
. In this case, argument method.ci =
"NAsm"
is used, i.e. confidence intervals based on the normal
approximation based on the summary measure.
Argument subgroup
can be used to conduct subgroup analysis for
a categorical covariate. The metareg
function can be
used instead for more than one categorical covariate or continuous
covariates.
Argument null.effect
can be used to specify the proportion
used under the null hypothesis in a test for an overall effect.
By default (null.effect = NA
), no hypothesis test is
conducted as it is unclear which value is a sensible choice for the
data at hand. An overall proportion of 50%, for example, could be
tested by setting argument null.effect = 0.5
.
Note, all tests for an overall effect are two-sided with the
alternative hypothesis that the effect is unequal to
null.effect
.
Arguments subset
and exclude
can be used to exclude
studies from the meta-analysis. Studies are removed completely from
the meta-analysis using argument subset
, while excluded
studies are shown in printouts and forest plots using argument
exclude
(see Examples in metagen
).
Meta-analysis results are the same for both arguments.
Internally, both common effect and random effects models are
calculated regardless of values choosen for arguments
common
and random
. Accordingly, the estimate
for the random effects model can be extracted from component
TE.random
of an object of class "meta"
even if
argument random = FALSE
. However, all functions in R
package meta will adequately consider the values for
common
and random
. E.g. function
print.meta
will not print results for the random
effects model if random = FALSE
.
Argument pscale
can be used to rescale proportions, e.g.
pscale = 1000
means that proportions are expressed as events
per 1000 observations. This is useful in situations with (very) low
event probabilities.
A prediction interval will only be shown if prediction =
TRUE
.
An object of class c("metaprop", "meta")
with corresponding
generic functions (see meta-object
).
Guido Schwarzer [email protected]
Agresti A & Coull BA (1998): Approximate is better than "exact" for interval estimation of binomial proportions. The American Statistician, 52, 119–26
Barendregt JJ, Doi SA, Lee YY, Norman RE, Vos T (2013): Meta-analysis of prevalence. Journal of Epidemiology and Community Health, 67, 974–8
Borenstein M, Hedges LV, Higgins JP, Rothstein HR (2010): A basic introduction to fixed-effect and random-effects models for meta-analysis. Research Synthesis Methods, 1, 97–111
Freeman MF & Tukey JW (1950): Transformations related to the angular and the square root. Annals of Mathematical Statistics, 21, 607–11
Miller JJ (1978): The inverse of the Freeman-Tukey double arcsine transformation. The American Statistician, 32, 138
Newcombe RG (1998): Two-sided confidence intervals for the single proportion: comparison of seven methods. Statistics in Medicine, 17, 857–72
Pettigrew HM, Gart JJ, Thomas DG (1986): The bias and higher cumulants of the logarithm of a binomial variate. Biometrika, 73, 425–35
Schwarzer G, Chemaitelly H, Abu-Raddad LJ, Rücker G (2019): Seriously misleading results using inverse of Freeman-Tukey double arcsine transformation in meta-analysis of single proportions. Research Synthesis Methods, 10, 476–83
Stijnen T, Hamza TH, Ozdemir P (2010): Random effects meta-analysis of event outcome in the framework of the generalized linear mixed model with applications in sparse data. Statistics in Medicine, 29, 3046–67
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
Viechtbauer W (2010): Conducting meta-analyses in R with the metafor package. Journal of Statistical Software, 36, 1–48
Warton DI, Hui FKC (2011): The arcsine is asinine: the analysis of proportions in ecology. Ecology, 92, 3–10
meta-package
, update.meta
,
metacont
, metagen
,
print.meta
, forest.meta
# Meta-analysis using generalised linear mixed model # metaprop(4:1, 10 * 1:4) # Apply various classic meta-analysis methods to estimate # proportions # m1 <- metaprop(4:1, 10 * 1:4, method = "Inverse") m2 <- update(m1, sm = "PAS") m3 <- update(m1, sm = "PRAW") m4 <- update(m1, sm = "PLN") m5 <- update(m1, sm = "PFT") # m1 m2 m3 m4 m5 # forest(m1) ## Not run: forest(m2) forest(m3) forest(m3, pscale = 100) forest(m4) forest(m5) ## End(Not run) # Do not back transform results, e.g. print logit transformed # proportions if sm = "PLOGIT" and store old settings # oldset <- settings.meta(backtransf = FALSE) # m6 <- metaprop(4:1, c(10, 20, 30, 40), method = "Inverse") m7 <- update(m6, sm = "PAS") m8 <- update(m6, sm = "PRAW") m9 <- update(m6, sm = "PLN") m10 <- update(m6, sm = "PFT") # forest(m6) ## Not run: forest(m7) forest(m8) forest(m8, pscale = 100) forest(m9) forest(m10) ## End(Not run) # Use old settings # settings.meta(oldset) # Examples with zero events # m1 <- metaprop(c(0, 0, 10, 10), rep(100, 4), method = "Inverse") m2 <- metaprop(c(0, 0, 10, 10), rep(100, 4), incr = 0.1, method = "Inverse") # m1 m2 # ## Not run: forest(m1) forest(m2) ## End(Not run) # Example from Miller (1978): # death <- c(3, 6, 10, 1) animals <- c(11, 17, 21, 6) # m3 <- metaprop(death, animals, sm = "PFT") forest(m3) # Data examples from Newcombe (1998) # - apply various methods to estimate confidence intervals for # individual studies # event <- c(81, 15, 0, 1) n <- c(263, 148, 20, 29) # m1 <- metaprop(event, n, method.ci = "SA", method = "Inverse") m2 <- update(m1, method.ci = "SACC") m3 <- update(m1, method.ci = "WS") m4 <- update(m1, method.ci = "WSCC") m5 <- update(m1, method.ci = "CP") # lower <- round(logit2p(rbind(NA, m1$lower, m2$lower, NA, m3$lower, m4$lower, NA, m5$lower)), 4) upper <- round(logit2p(rbind(NA, m1$upper, m2$upper, NA, m3$upper, m4$upper, NA, m5$upper)), 4) # tab1 <- data.frame( scen1 = meta:::formatCI(lower[, 1], upper[, 1]), scen2 = meta:::formatCI(lower[, 2], upper[, 2]), scen3 = meta:::formatCI(lower[, 3], upper[, 3]), scen4 = meta:::formatCI(lower[, 4], upper[, 4]) ) names(tab1) <- c("r=81, n=263", "r=15, n=148", "r=0, n=20", "r=1, n=29") row.names(tab1) <- c("Simple", "- SA", "- SACC", "Score", "- WS", "- WSCC", "Binomial", "- CP") tab1[is.na(tab1)] <- "" # Newcombe (1998), Table I, methods 1-5: tab1 # Same confidence interval, i.e. unaffected by choice of summary # measure # print(metaprop(event, n, method.ci = "WS", method = "Inverse"), ma = FALSE) print(metaprop(event, n, sm = "PLN", method.ci = "WS"), ma = FALSE) print(metaprop(event, n, sm = "PFT", method.ci = "WS"), ma = FALSE) print(metaprop(event, n, sm = "PAS", method.ci = "WS"), ma = FALSE) print(metaprop(event, n, sm = "PRAW", method.ci = "WS"), ma = FALSE) # Different confidence intervals as argument sm = "NAsm" # print(metaprop(event, n, method.ci = "NAsm", method = "Inverse"), ma = FALSE) print(metaprop(event, n, sm = "PLN", method.ci = "NAsm"), ma = FALSE) print(metaprop(event, n, sm = "PFT", method.ci = "NAsm"), ma = FALSE) print(metaprop(event, n, sm = "PAS", method.ci = "NAsm"), ma = FALSE) print(metaprop(event, n, sm = "PRAW", method.ci = "NAsm"), ma = FALSE) # Different confidence intervals as argument backtransf = FALSE. # Accordingly, method.ci = "NAsm" used internally. # print(metaprop(event, n, method.ci = "WS", method = "Inverse"), ma = FALSE, backtransf = FALSE) print(metaprop(event, n, sm = "PLN", method.ci = "WS"), ma = FALSE, backtransf = FALSE) print(metaprop(event, n, sm = "PFT", method.ci = "WS"), ma = FALSE, backtransf = FALSE) print(metaprop(event, n, sm = "PAS", method.ci = "WS"), ma = FALSE, backtransf = FALSE) print(metaprop(event, n, sm = "PRAW", method.ci = "WS"), ma = FALSE, backtransf = FALSE) # Same results (printed on original and log scale, respectively) # print(metaprop(event, n, sm = "PLN", method.ci = "NAsm"), ma = FALSE) print(metaprop(event, n, sm = "PLN"), ma = FALSE, backtransf = FALSE) # Results for first study (on log scale) round(log(c(0.3079848, 0.2569522, 0.3691529)), 4) # Print results as events per 1000 observations # print(metaprop(6:8, c(100, 1200, 1000), method = "Inverse"), pscale = 1000, digits = 1)
# Meta-analysis using generalised linear mixed model # metaprop(4:1, 10 * 1:4) # Apply various classic meta-analysis methods to estimate # proportions # m1 <- metaprop(4:1, 10 * 1:4, method = "Inverse") m2 <- update(m1, sm = "PAS") m3 <- update(m1, sm = "PRAW") m4 <- update(m1, sm = "PLN") m5 <- update(m1, sm = "PFT") # m1 m2 m3 m4 m5 # forest(m1) ## Not run: forest(m2) forest(m3) forest(m3, pscale = 100) forest(m4) forest(m5) ## End(Not run) # Do not back transform results, e.g. print logit transformed # proportions if sm = "PLOGIT" and store old settings # oldset <- settings.meta(backtransf = FALSE) # m6 <- metaprop(4:1, c(10, 20, 30, 40), method = "Inverse") m7 <- update(m6, sm = "PAS") m8 <- update(m6, sm = "PRAW") m9 <- update(m6, sm = "PLN") m10 <- update(m6, sm = "PFT") # forest(m6) ## Not run: forest(m7) forest(m8) forest(m8, pscale = 100) forest(m9) forest(m10) ## End(Not run) # Use old settings # settings.meta(oldset) # Examples with zero events # m1 <- metaprop(c(0, 0, 10, 10), rep(100, 4), method = "Inverse") m2 <- metaprop(c(0, 0, 10, 10), rep(100, 4), incr = 0.1, method = "Inverse") # m1 m2 # ## Not run: forest(m1) forest(m2) ## End(Not run) # Example from Miller (1978): # death <- c(3, 6, 10, 1) animals <- c(11, 17, 21, 6) # m3 <- metaprop(death, animals, sm = "PFT") forest(m3) # Data examples from Newcombe (1998) # - apply various methods to estimate confidence intervals for # individual studies # event <- c(81, 15, 0, 1) n <- c(263, 148, 20, 29) # m1 <- metaprop(event, n, method.ci = "SA", method = "Inverse") m2 <- update(m1, method.ci = "SACC") m3 <- update(m1, method.ci = "WS") m4 <- update(m1, method.ci = "WSCC") m5 <- update(m1, method.ci = "CP") # lower <- round(logit2p(rbind(NA, m1$lower, m2$lower, NA, m3$lower, m4$lower, NA, m5$lower)), 4) upper <- round(logit2p(rbind(NA, m1$upper, m2$upper, NA, m3$upper, m4$upper, NA, m5$upper)), 4) # tab1 <- data.frame( scen1 = meta:::formatCI(lower[, 1], upper[, 1]), scen2 = meta:::formatCI(lower[, 2], upper[, 2]), scen3 = meta:::formatCI(lower[, 3], upper[, 3]), scen4 = meta:::formatCI(lower[, 4], upper[, 4]) ) names(tab1) <- c("r=81, n=263", "r=15, n=148", "r=0, n=20", "r=1, n=29") row.names(tab1) <- c("Simple", "- SA", "- SACC", "Score", "- WS", "- WSCC", "Binomial", "- CP") tab1[is.na(tab1)] <- "" # Newcombe (1998), Table I, methods 1-5: tab1 # Same confidence interval, i.e. unaffected by choice of summary # measure # print(metaprop(event, n, method.ci = "WS", method = "Inverse"), ma = FALSE) print(metaprop(event, n, sm = "PLN", method.ci = "WS"), ma = FALSE) print(metaprop(event, n, sm = "PFT", method.ci = "WS"), ma = FALSE) print(metaprop(event, n, sm = "PAS", method.ci = "WS"), ma = FALSE) print(metaprop(event, n, sm = "PRAW", method.ci = "WS"), ma = FALSE) # Different confidence intervals as argument sm = "NAsm" # print(metaprop(event, n, method.ci = "NAsm", method = "Inverse"), ma = FALSE) print(metaprop(event, n, sm = "PLN", method.ci = "NAsm"), ma = FALSE) print(metaprop(event, n, sm = "PFT", method.ci = "NAsm"), ma = FALSE) print(metaprop(event, n, sm = "PAS", method.ci = "NAsm"), ma = FALSE) print(metaprop(event, n, sm = "PRAW", method.ci = "NAsm"), ma = FALSE) # Different confidence intervals as argument backtransf = FALSE. # Accordingly, method.ci = "NAsm" used internally. # print(metaprop(event, n, method.ci = "WS", method = "Inverse"), ma = FALSE, backtransf = FALSE) print(metaprop(event, n, sm = "PLN", method.ci = "WS"), ma = FALSE, backtransf = FALSE) print(metaprop(event, n, sm = "PFT", method.ci = "WS"), ma = FALSE, backtransf = FALSE) print(metaprop(event, n, sm = "PAS", method.ci = "WS"), ma = FALSE, backtransf = FALSE) print(metaprop(event, n, sm = "PRAW", method.ci = "WS"), ma = FALSE, backtransf = FALSE) # Same results (printed on original and log scale, respectively) # print(metaprop(event, n, sm = "PLN", method.ci = "NAsm"), ma = FALSE) print(metaprop(event, n, sm = "PLN"), ma = FALSE, backtransf = FALSE) # Results for first study (on log scale) round(log(c(0.3079848, 0.2569522, 0.3691529)), 4) # Print results as events per 1000 observations # print(metaprop(6:8, c(100, 1200, 1000), method = "Inverse"), pscale = 1000, digits = 1)
Calculation of an overall incidence rate from studies reporting a
single incidence rate. Inverse variance method and generalised
linear mixed model (GLMM) are available for pooling. For GLMMs, the
rma.glmm
function from R package
metafor (Viechtbauer 2010) is called internally.
metarate( event, time, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, n = NULL, method = "Inverse", sm = gs("smrate"), incr = gs("incr"), method.incr = gs("method.incr"), method.ci = gs("method.ci.rate"), level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau, method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = NA, method.bias = gs("method.bias"), backtransf = gs("backtransf"), irscale = 1, irunit = "person-years", text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, hakn, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
metarate( event, time, studlab, data = NULL, subset = NULL, exclude = NULL, cluster = NULL, rho = 0, n = NULL, method = "Inverse", sm = gs("smrate"), incr = gs("incr"), method.incr = gs("method.incr"), method.ci = gs("method.ci.rate"), level = gs("level"), common = gs("common"), random = gs("random") | !is.null(tau.preset), overall = common | random, overall.hetstat = if (is.null(gs("overall.hetstat"))) common | random else gs("overall.hetstat"), prediction = gs("prediction") | !missing(method.predict), method.tau, method.tau.ci = gs("method.tau.ci"), level.hetstat = gs("level.hetstat"), tau.preset = NULL, TE.tau = NULL, tau.common = gs("tau.common"), method.I2 = gs("method.I2"), level.ma = gs("level.ma"), method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), level.predict = gs("level.predict"), method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, null.effect = NA, method.bias = gs("method.bias"), backtransf = gs("backtransf"), irscale = 1, irunit = "person-years", text.common = gs("text.common"), text.random = gs("text.random"), text.predict = gs("text.predict"), text.w.common = gs("text.w.common"), text.w.random = gs("text.w.random"), title = gs("title"), complab = gs("complab"), outclab = "", label.left = gs("label.left"), label.right = gs("label.right"), col.label.left = gs("col.label.left"), col.label.right = gs("col.label.right"), subgroup, subgroup.name = NULL, print.subgroup.name = gs("print.subgroup.name"), sep.subgroup = gs("sep.subgroup"), test.subgroup = gs("test.subgroup"), prediction.subgroup = gs("prediction.subgroup"), seed.predict.subgroup = NULL, byvar, hakn, adhoc.hakn, keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), control = NULL, ... )
event |
Number of events. |
time |
Person time at risk. |
studlab |
An optional vector with study labels. |
data |
An optional data frame containing the study information, i.e., event and time. |
subset |
An optional vector specifying a subset of studies to be used. |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots. |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
n |
Number of observations. |
method |
A character string indicating which method is to be
used for pooling of studies. One of |
sm |
A character string indicating which summary measure
( |
incr |
A numeric which is added to the event number of studies with zero events, i.e., studies with an incidence rate of 0. |
method.incr |
A character string indicating which continuity
correction method should be used ( |
method.ci |
A character string indicating whether to use approximate normal ("NAsm") or exact Poisson ("Poisson") confidence limits. |
level |
The level used to calculate confidence intervals for individual studies. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
prediction |
A logical indicating whether a prediction interval should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
null.effect |
A numeric value specifying the effect under the null hypothesis. |
method.bias |
A character string indicating which test is to
be used. Either |
backtransf |
A logical indicating whether results for
transformed rates (argument |
irscale |
A numeric defining a scaling factor for printing of rates. |
irunit |
A character string specifying the time unit used to calculate rates, e.g. person-years. |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
hakn |
Deprecated argument (replaced by 'method.random.ci'). |
adhoc.hakn |
Deprecated argument (replaced by 'adhoc.hakn.ci'). |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
warn |
A logical indicating whether warnings should be printed
(e.g., if |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments passed on to
|
This function provides methods for common effect and random effects
meta-analysis of single incidence rates to calculate an overall
rate. Note, you should use R function metainc
to
compare incidence rates of pairwise comparisons instead of using
metarate
for each treatment arm separately which will break
randomisation in randomised controlled trials.
The following transformations of incidence rates are implemented to calculate an overall rate:
Log transformation (sm = "IRLN"
, default)
Square root transformation (sm = "IRS"
)
Freeman-Tukey Double arcsine transformation (sm =
"IRFT"
)
No transformation (sm = "IR"
)
List elements TE
, TE.common
, TE.random
, etc.,
contain the transformed incidence rates. In printouts and plots
these values are back transformed if argument backtransf =
TRUE
(default).
By default (argument method = "Inverse"
), the inverse
variance method (Borenstein et al., 2010) is used for pooling by
calling metagen
internally. A random intercept
Poisson regression model (Stijnen et al., 2010) can be utilised
instead with argument method = "GLMM"
which calls the
rma.glmm
function from R package
metafor.
A three-level random effects meta-analysis model (Van den Noortgate
et al., 2013) is utilised if argument cluster
is used and at
least one cluster provides more than one estimate. Internally,
rma.mv
is called to conduct the analysis and
weights.rma.mv
with argument type =
"rowsum"
is used to calculate random effects weights.
Default settings are utilised for several arguments (assignments
using gs
function). These defaults can be changed for
the current R session using the settings.meta
function.
Furthermore, R function update.meta
can be used to
rerun a meta-analysis with different settings.
Three approaches are available to apply a continuity correction:
Only studies with a zero cell count (method.incr =
"only0"
)
All studies if at least one study has a zero cell count
(method.incr = "if0all"
)
All studies irrespective of zero cell counts
(method.incr = "all"
)
If the summary measure (argument sm
) is equal to "IR" or
"IRLN", the continuity correction is applied if a study has zero
events, i.e., an incidence rate of 0.
By default, 0.5 is used as continuity correction (argument
incr
). This continuity correction is used both to calculate
individual study results with confidence limits and to conduct
meta-analysis based on the inverse variance method.
For the Freeman-Tukey (Freeman & Tukey, 1950) and square root transformation as well as GLMMs no continuity correction is used.
Argument subgroup
can be used to conduct subgroup analysis for
a categorical covariate. The metareg
function can be
used instead for more than one categorical covariate or continuous
covariates.
Argument null.effect
can be used to specify the rate used
under the null hypothesis in a test for an overall effect.
By default (null.effect = NA
), no hypothesis test is
conducted as it is unclear which value is a sensible choice for the
data at hand. An overall rate of 2, for example, could be tested
by setting argument null.effect = 2
.
Note, all tests for an overall effect are two-sided with the
alternative hypothesis that the effect is unequal to
null.effect
.
Arguments subset
and exclude
can be used to exclude
studies from the meta-analysis. Studies are removed completely from
the meta-analysis using argument subset
, while excluded
studies are shown in printouts and forest plots using argument
exclude
(see Examples in metagen
).
Meta-analysis results are the same for both arguments.
Internally, both common effect and random effects models are
calculated regardless of values choosen for arguments
common
and random
. Accordingly, the estimate
for the random effects model can be extracted from component
TE.random
of an object of class "meta"
even if
argument random = FALSE
. However, all functions in R
package meta will adequately consider the values for
common
and random
. E.g. function
print.meta
will not print results for the random
effects model if random = FALSE
.
Argument irscale
can be used to rescale rates, e.g.
irscale = 1000
means that rates are expressed as events per
1000 time units, e.g. person-years. This is useful in situations
with (very) low rates. Argument irunit
can be used to
specify the time unit used in individual studies (default:
"person-years"). This information is printed in summaries and
forest plots if argument irscale
is not equal to 1.
A prediction interval will only be shown if prediction =
TRUE
.
An object of class c("metarate", "meta")
with corresponding
generic functions (see meta-object
).
Guido Schwarzer [email protected]
Borenstein M, Hedges LV, Higgins JP, Rothstein HR (2010): A basic introduction to fixed-effect and random-effects models for meta-analysis. Research Synthesis Methods, 1, 97–111
Freeman MF & Tukey JW (1950): Transformations related to the angular and the square root. Annals of Mathematical Statistics, 21, 607–11
Stijnen T, Hamza TH, Ozdemir P (2010): Random effects meta-analysis of event outcome in the framework of the generalized linear mixed model with applications in sparse data. Statistics in Medicine, 29, 3046–67
Van den Noortgate W, López-López JA, Marín-Martínez F, Sánchez-Meca J (2013): Three-level meta-analysis of dependent effect sizes. Behavior Research Methods, 45, 576–94
Viechtbauer W (2010): Conducting Meta-Analyses in R with the Metafor Package. Journal of Statistical Software, 36, 1–48
meta-package
, update.meta
,
metacont
, metagen
,
print.meta
# Apply various meta-analysis methods to estimate incidence rates # m1 <- metarate(4:1, c(10, 20, 30, 40)) m2 <- update(m1, sm = "IR") m3 <- update(m1, sm = "IRS") m4 <- update(m1, sm = "IRFT") # m1 m2 m3 m4 # forest(m1) forest(m1, irscale = 100) forest(m1, irscale = 100, irunit = "person-days") forest(m1, backtransf = FALSE) ## Not run: forest(m2) forest(m3) forest(m4) ## End(Not run) m5 <- metarate(40:37, c(100, 200, 300, 400), sm = "IRFT") m5
# Apply various meta-analysis methods to estimate incidence rates # m1 <- metarate(4:1, c(10, 20, 30, 40)) m2 <- update(m1, sm = "IR") m3 <- update(m1, sm = "IRS") m4 <- update(m1, sm = "IRFT") # m1 m2 m3 m4 # forest(m1) forest(m1, irscale = 100) forest(m1, irscale = 100, irunit = "person-days") forest(m1, backtransf = FALSE) ## Not run: forest(m2) forest(m3) forest(m4) ## End(Not run) m5 <- metarate(40:37, c(100, 200, 300, 400), sm = "IRFT") m5
Meta-regression for objects of class meta
. This is a wrapper
function for the R function rma.uni
in the R
package metafor (Viechtbauer 2010).
## S3 method for class 'meta' metareg( x, formula, method.tau = x$method.tau, hakn = x$method.random.ci == "HK", level.ma = x$level.ma, intercept = TRUE, ... ) metareg(x, ...) ## Default S3 method: metareg(x, ...)
## S3 method for class 'meta' metareg( x, formula, method.tau = x$method.tau, hakn = x$method.random.ci == "HK", level.ma = x$level.ma, intercept = TRUE, ... ) metareg(x, ...) ## Default S3 method: metareg(x, ...)
x |
An object of class |
formula |
Either a character string or a formula object. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance tau-squared. Either
|
hakn |
A logical indicating whether the method by Hartung and Knapp should be used to adjust test statistics and confidence intervals. |
level.ma |
The level used to calculate confidence intervals for parameter estimates in the meta-regression model. |
intercept |
A logical indicating whether an intercept should be included in the meta-regression model. |
... |
Additional arguments passed to R function
|
This R function is a wrapper function for R function
rma.uni
in the R package metafor
(Viechtbauer 2010).
Note, results are not back-transformed in printouts of
meta-analyses using summary measures with transformations, e.g.,
log risk ratios are printed instead of the risk ratio if argument
sm = "RR"
and logit transformed proportions are printed if
argument sm = "PLOGIT"
.
Argument '...' can be used to pass additional arguments to R
function rma.uni
. For example, argument
control
to provide a list of control values for the
iterative estimation algorithm. See help page of R function
rma.uni
for more details.
An object of class c("metareg", "rma.uni", "rma")
. Please
look at the help page of R function rma.uni
for more details on the output from this function.
In addition, a list .meta
is added to the output containing
the following components:
x , formula , method.tau , hakn , level.ma , intercept
|
As defined above. |
dots |
Information provided in argument '...'. |
call |
Function call. |
version |
Version of R package meta used to create object. |
version.metafor |
Version of R package metafor used to create object. |
Guido Schwarzer [email protected]
Viechtbauer W (2010): Conducting Meta-Analyses in R with the Metafor Package. Journal of Statistical Software, 36, 1–48
data(Fleiss1993cont) # Add some (fictitious) grouping variables: Fleiss1993cont$age <- c(55, 65, 55, 65, 55) Fleiss1993cont$region <- c("Europe", "Europe", "Asia", "Asia", "Europe") m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") ## Not run: # Error due to wrong ordering of arguments (order has changed in # R package meta, version 3.0-0) # try(metareg(~ region, m1)) try(metareg(~ region, data = m1)) # Warning as no information on covariate is available # metareg(m1) ## End(Not run) # Do meta-regression for covariate region # mu2 <- update(m1, subgroup = region, tau.common = TRUE, common = FALSE) metareg(mu2) # Same result for # - tau-squared # - test of heterogeneity # - test for subgroup differences # (as argument 'tau.common' was used to create mu2) # mu2 metareg(mu2, intercept = FALSE) metareg(m1, region) # Different result for # - tau-squared # - test of heterogeneity # - test for subgroup differences # (as argument 'tau.common' is - by default - FALSE) # mu1 <- update(m1, subgroup = region) mu1 # Generate bubble plot # bubble(metareg(mu2)) # Do meta-regression with two covariates # metareg(mu1, region + age) # Do same meta-regressions using formula notation # metareg(m1, ~ region) metareg(mu1, ~ region + age) # Do meta-regression using REML method and print intermediate # results for iterative estimation algorithm; furthermore print # results with three digits. # metareg(mu1, region, method.tau = "REML", control = list(verbose = TRUE), digits = 3) # Use Hartung-Knapp method # mu3 <- update(mu2, method.random.ci = "HK") mu3 metareg(mu3, intercept = FALSE)
data(Fleiss1993cont) # Add some (fictitious) grouping variables: Fleiss1993cont$age <- c(55, 65, 55, 65, 55) Fleiss1993cont$region <- c("Europe", "Europe", "Asia", "Asia", "Europe") m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD") ## Not run: # Error due to wrong ordering of arguments (order has changed in # R package meta, version 3.0-0) # try(metareg(~ region, m1)) try(metareg(~ region, data = m1)) # Warning as no information on covariate is available # metareg(m1) ## End(Not run) # Do meta-regression for covariate region # mu2 <- update(m1, subgroup = region, tau.common = TRUE, common = FALSE) metareg(mu2) # Same result for # - tau-squared # - test of heterogeneity # - test for subgroup differences # (as argument 'tau.common' was used to create mu2) # mu2 metareg(mu2, intercept = FALSE) metareg(m1, region) # Different result for # - tau-squared # - test of heterogeneity # - test for subgroup differences # (as argument 'tau.common' is - by default - FALSE) # mu1 <- update(m1, subgroup = region) mu1 # Generate bubble plot # bubble(metareg(mu2)) # Do meta-regression with two covariates # metareg(mu1, region + age) # Do same meta-regressions using formula notation # metareg(m1, ~ region) metareg(mu1, ~ region + age) # Do meta-regression using REML method and print intermediate # results for iterative estimation algorithm; furthermore print # results with three digits. # metareg(mu1, region, method.tau = "REML", control = list(verbose = TRUE), digits = 3) # Use Hartung-Knapp method # mu3 <- update(mu2, method.random.ci = "HK") mu3 metareg(mu3, intercept = FALSE)
Calculate the number needed to treat (NNT) from estimated risk difference, risk ratio, odds ratio, or hazard ratio, and a baseline probability, i.e., control group event probability for binary outcomes or survival probability for hazard ratios.
nnt(x, ...) ## S3 method for class 'meta' nnt( x, p.c, common = x$common, random = x$random, small.values = "desirable", ... ) ## Default S3 method: nnt(x, p.c, sm, lower, upper, small.values = "desirable", transf = FALSE, ...) ## S3 method for class 'nnt.meta' print( x, common = x$common, random = x$random, digits = gs("digits"), digits.prop = gs("digits.prop"), big.mark = gs("big.mark"), ... ) ## S3 method for class 'nnt.default' print( x, digits = gs("digits"), digits.prop = gs("digits.prop"), big.mark = gs("big.mark"), ... )
nnt(x, ...) ## S3 method for class 'meta' nnt( x, p.c, common = x$common, random = x$random, small.values = "desirable", ... ) ## Default S3 method: nnt(x, p.c, sm, lower, upper, small.values = "desirable", transf = FALSE, ...) ## S3 method for class 'nnt.meta' print( x, common = x$common, random = x$random, digits = gs("digits"), digits.prop = gs("digits.prop"), big.mark = gs("big.mark"), ... ) ## S3 method for class 'nnt.default' print( x, digits = gs("digits"), digits.prop = gs("digits.prop"), big.mark = gs("big.mark"), ... )
x |
An object of class |
... |
Additional arguments (to catch deprecated arguments). |
p.c |
Baseline probability, i.e., control group event probability for binary outcomes or survival probability in control group for hazard ratios. |
common |
A logical indicating whether NNTs should be calculated based on common effect estimate. |
random |
A logical indicating whether NNTs should be calculated based on random effects estimate. |
small.values |
A character string specifying whether small
treatment effects indicate a beneficial ( |
sm |
Summary measure. |
lower |
Lower confidence interval limit. |
upper |
Upper confidence interval limit. |
transf |
A logical indicating whether treatment estimates and
confidence limits are transformed or on the original scale.
If |
digits |
Minimal number of significant digits to print NNT and its
confidence interval, see |
digits.prop |
Minimal number of significant digits for
proportions, see |
big.mark |
A character used as thousands separator. |
The number needed to treat (NNT) is the estimated number of patients who need to be treated with a new treatment instead of a standard for one additional patient to benefit (Laupacis et al., 1988; Cook & Sackett, 1995). This definition of the NNT implies that the new treatment is more beneficial than the standard. If the new treatment is indeed less beneficial than the standard, the NNT gives the number of patients treated with the new treatment to observe an additional harmful event. Accordingly, the abbreviations NNTB and NNTH can be used to distinguish between beneficial and harmful NNTs (Altman, 1998).
NNTs can be easily computed from an estimated risk difference (RD),
risk ratio (RR), or odds ratio (OR) and a given baseline probability
(Higgins et al., 2023, section 15.4.4). It is also possible to
calculate NNTs from hazard ratios (HR) (Altman & Andersen,
1999). Accordingly, NNTs can be calculated for meta-analyses
generated with metabin
or metagen
if
argument sm
was equal to "RD"
, "RR"
,
"OR"
, or "HR"
. It is also possible to provide only
estimated treatment effects and baseline probabilities (see Examples).
The baseline probability can be specified using argument p.c
. If
this argument is missing, the minimum, mean, and maximum of the
control event probabilities in the meta-analysis are used for
metabin
and control event probabilities of 0.1, 0.2,
..., 0.9 are used for metagen
. Note, the survival instead of
mortality probability must be provided for hazard ratios.
Argument small.values
can be used to specify whether small
treatment effects indicate a beneficial ("desirable"
) or harmful
("undesirable"
) effect. For small.values = "desirable"
, odds,
risk and hazard ratios below 1 and risk differences below 0 indicate that the
new treatment is beneficial. For small.values = "undesirable"
, odds,
risk and hazard ratios above 1 and risk differences above 0 indicate that
the new treatment is beneficial.
A positive value for the estimated NNT indicates that the new treatment is beneficial, i.e., the NNT is actually an NNTB. On the other hand, a negative value for the estimated NNT indicates that the new treatment is harmful, i.e., the NNT is actually an NNTH.
The minimal value for the NNTB is 1. In this extreme case the new treatment is 100% effective and the standard treatment is 0% effective, i.e., only one patient has to be treated with the new treatment for one additional patient to benefit. The NNTB increases with decreasing difference between the two risks. If both risks are equal, the NNTB is infinite.
The other extreme is an NNT of -1 if the new treatment is 0% effective and the standard is 100% effective. Here, one additional harmful event is observed for each patient treated with the new treatment. The NNT approaches minus infinity if the difference between the two risks decreases to 0. Finally, an NNT of -1 translates to an NNTH of 1 with possible values from 1 to infinity.
Confidence limits for an NNT are derived from the lower and upper confidence limits of the summary measure using the same formulae as for the NNT (Higgins et al., 2023, section 15.4.4).
A peculiar problem arises if the confidence interval for the summary measure includes the null effect (i.e., RR = 1, OR = 1, HR = 1, or RD = 0). In this case the confidence interval for the NNT contains both NNTB and NNTH values and it seemingly does not include the estimated NNT.
As described above, a positive NNT value corresponds to an NNTB and the absolute value of a negative NNT is equal to an NNTH. Accordingly, a confidence interval for the NNT from 20 to -5 translates to NNTB values between 20 and infinity and NNTH values between 5 and infinity (Altman, 1998).
Guido Schwarzer [email protected]
Altman DG (1998): Confidence intervals for the number needed to treat. British Medical Journal, 317, 1309–12
Altman DG, Andersen PK (1999): Calculating the number needed to treat for trials where the outcome is time to an event. British Medical Journal, 319, 1492–95
Cook RJ, Sackett DL (1995): The number needed to treat: a clinically useful measure of treatment effect. British Medical Journal, 310, 452–54
Higgins JPT, Thomas J, Chandler J, Cumpston M, Li T, Page MJ, Welch VA (editors) (2023): Cochrane Handbook for Systematic Reviews of Interventions Version 6.4 (updated August 2023). Available from https://training.cochrane.org/handbook/
Laupacis A, Sackett DL, Roberts RS (1988): An assessment of clinically useful measures of the consequences of treatment. New England Journal of Medicine, 318, 1728–33
# Calculate NNTs for risk differences of -0.12 and -0.22 # (Cochrane Handbook, version 6.3, subsection 15.4.4.1) nnt(c(-0.12, -0.22), sm = "RD") # Calculate NNT for risk ratio of 0.92 and baseline risk of 0.3 # (Cochrane Handbook, version 6.3, subsection 15.4.4.2) nnt(0.92, p.c = 0.3, sm = "RR") # Calculate NNT for odds ratio of 0.73 and baseline risk of 0.3 # (Cochrane Handbook, version 6.3, subsection 15.4.4.3) nnt(0.73, p.c = 0.3, sm = "OR") # Calculate NNTs for Mantel-Haenszel odds ratio data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, random = FALSE) nnt(m1) # Calculate NNTs from hazard ratio at two and four years (example from # Altman & Andersen, 1999). Note, argument 'p.c' must provide survival # probabilities instead of mortality rates for the control group. nnt(0.72, lower = 0.55, upper = 0.92, sm = "HR", p.c = 1 - c(0.33, 0.49))
# Calculate NNTs for risk differences of -0.12 and -0.22 # (Cochrane Handbook, version 6.3, subsection 15.4.4.1) nnt(c(-0.12, -0.22), sm = "RD") # Calculate NNT for risk ratio of 0.92 and baseline risk of 0.3 # (Cochrane Handbook, version 6.3, subsection 15.4.4.2) nnt(0.92, p.c = 0.3, sm = "RR") # Calculate NNT for odds ratio of 0.73 and baseline risk of 0.3 # (Cochrane Handbook, version 6.3, subsection 15.4.4.3) nnt(0.73, p.c = 0.3, sm = "OR") # Calculate NNTs for Mantel-Haenszel odds ratio data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, random = FALSE) nnt(m1) # Calculate NNTs from hazard ratio at two and four years (example from # Altman & Andersen, 1999). Note, argument 'p.c' must provide survival # probabilities instead of mortality rates for the control group. nnt(0.72, lower = 0.55, upper = 0.92, sm = "HR", p.c = 1 - c(0.33, 0.49))
Meta-analysis on Thrombolytic Therapy after Acute Myocardial Infarction
A data frame with the following columns:
author | first author |
year | year of publication |
ev.exp | number of events in experimental group |
n.exp | number of observations in experimental group |
ev.cont | number of events in control group |
n.cont | number of observations in control group |
Olkin I (1995): Statistical and theoretical considerations in meta-analysis. Journal of Clinical Epidemiology, 48, 133–46
data(Olkin1995) metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995)
data(Olkin1995) metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995)
Conversion from log odds ratio to standardised mean difference using method by Hasselblad & Hedges (1995) or Cox (1970).
or2smd( lnOR, selnOR, studlab, data = NULL, subset = NULL, exclude = NULL, method = "HH", ... )
or2smd( lnOR, selnOR, studlab, data = NULL, subset = NULL, exclude = NULL, method = "HH", ... )
lnOR |
Log odds ratio(s) or meta-analysis object. |
selnOR |
Standard error(s) of log odds ratio(s) (ignored if
argument |
studlab |
An optional vector with study labels (ignored if
argument |
data |
An optional data frame containing the study information
(ignored if argument |
subset |
An optional vector specifying a subset of studies to
be used (ignored if argument |
exclude |
An optional vector specifying studies to exclude
from meta-analysis, however, to include in printouts and forest
plots (ignored if argument |
method |
A character string indicating which method is used to
convert log odds ratios to standardised mean differences. Either
|
... |
Additional arguments passed on to
|
This function implements the following methods for the conversion from log odds ratios to standardised mean difference:
Hasselblad & Hedges (1995) assuming logistic distributions
(method == "HH"
)
Cox (1970) and Cox & Snell (1989) assuming normal
distributions (method == "CS"
)
Internally, metagen
is used to conduct a
meta-analysis with the standardised mean difference as summary
measure.
Argument lnOR
can be either a vector of log odds ratios or a
meta-analysis object created with metabin
or
metagen
and the odds ratio as summary measure.
Argument selnOR
is mandatory if argument lnOR
is a
vector and ignored otherwise. Additional arguments in ...
are only passed on to metagen
if argument lnOR
is a vector.
An object of class c("metagen", "meta")
with corresponding
generic functions (see meta-object
).
Guido Schwarzer [email protected]
Borenstein M, Hedges LV, Higgins JPT, Rothstein HR (2009): Introduction to Meta-Analysis. Chichester: Wiley
Cox DR (1970): Analysis of Binary Data. London: Chapman and Hall / CRC
Cox DR, Snell EJ (1989): Analysis of Binary Data (2nd edition). London: Chapman and Hall / CRC
Hasselblad V, Hedges LV (1995): Meta-analysis of screening and diagnostic tests. Psychological Bulletin, 117, 167–78
smd2or
, metabin
,
metagen
, metacont
# Example from Borenstein et al. (2009), Chapter 7 # mb <- or2smd(0.9069, sqrt(0.0676)) # TE = standardised mean difference (SMD); seTE = standard error of SMD data.frame(SMD = round(mb$TE, 4), varSMD = round(mb$seTE^2, 4)) # Use dataset from Fleiss (1993) # data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR", random = FALSE) or2smd(m1)
# Example from Borenstein et al. (2009), Chapter 7 # mb <- or2smd(0.9069, sqrt(0.0676)) # TE = standardised mean difference (SMD); seTE = standard error of SMD data.frame(SMD = round(mb$TE, 4), varSMD = round(mb$seTE^2, 4)) # Use dataset from Fleiss (1993) # data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, studlab = paste(study, year), sm = "OR", random = FALSE) or2smd(m1)
Meta-analysis on Prevention of First Bleeding in Cirrhosis comparing beta-blocker or sclerotherapy with placebo.
A data frame with the following columns:
id | study id |
treat.exp | treatment in experimental group |
logOR | log odds ratio |
selogOR | standard error of log odds ratio |
bleed.exp | number of bleedings in experimental group |
n.cont | number of observations in experimental group |
bleed.plac | number of bleedings in placebo group |
n.plac | number of observations in placebo group |
Pagliaro L, D’Amico G et al. (1992): Prevention of first bleeding in cirrhosis. Annals in Internal Medicine, 117, 59–70
data(Pagliaro1992) sclero <- subset(Pagliaro1992, treat.exp == "Sclerotherapy") m <- metagen(logOR, selogOR, data = sclero, sm = "OR") m # Thompson & Sharp (1999), Table IV, method (2) metabias(m, method = "Egger") # Thompson & Sharp (1999), Table IV, method (3a) metabias(m, method = "Thompson") # Thompson & Sharp (1999), Table IV, method (3b) update(m, method.tau = "ML") metabias(update(m, method.tau = "ML"), method = "Thompson")
data(Pagliaro1992) sclero <- subset(Pagliaro1992, treat.exp == "Sclerotherapy") m <- metagen(logOR, selogOR, data = sclero, sm = "OR") m # Thompson & Sharp (1999), Table IV, method (2) metabias(m, method = "Egger") # Thompson & Sharp (1999), Table IV, method (3a) metabias(m, method = "Thompson") # Thompson & Sharp (1999), Table IV, method (3b) update(m, method.tau = "ML") metabias(update(m, method.tau = "ML"), method = "Thompson")
This function transforms data that are given in wide or long
arm-based format (e.g. input format for WinBUGS) to a
contrast-based format that is needed, for example, as input to R function
netmeta
from R package netmeta. The function
can transform data with binary, continuous, or generic outcomes as well as
incidence rates from arm-based to contrast-based format.
pairwise( treat, event, n, mean, sd, TE, seTE, time, agent, dose, data = NULL, studlab, incr = gs("incr"), method = "Inverse", method.incr = gs("method.incr"), allstudies = gs("allstudies"), reference.group, keep.all.comparisons, sep.ag = "*", varnames = c("TE", "seTE"), append = !is.null(data), addincr = gs("addincr"), allincr = gs("allincr"), warn = FALSE, warn.deprecated = gs("warn.deprecated"), ... )
pairwise( treat, event, n, mean, sd, TE, seTE, time, agent, dose, data = NULL, studlab, incr = gs("incr"), method = "Inverse", method.incr = gs("method.incr"), allstudies = gs("allstudies"), reference.group, keep.all.comparisons, sep.ag = "*", varnames = c("TE", "seTE"), append = !is.null(data), addincr = gs("addincr"), allincr = gs("allincr"), warn = FALSE, warn.deprecated = gs("warn.deprecated"), ... )
treat |
A list or vector with treatment information for individual treatment arms (see Details). |
event |
A list or vector with information on number of events for individual treatment arms (see Details). |
n |
A list or vector with information on number of observations for individual treatment arms (see Details). |
mean |
A list or vector with estimated means for individual treatment arms (see Details). |
sd |
A list or vector with information on the standard deviation for individual treatment arms (see Details). |
TE |
A list or vector with estimated treatment effects for individual treatment arms (see Details). |
seTE |
A list or vector with standard errors of estimated treatment effect for individual treatment arms (see Details). |
time |
A list or vector with information on person time at risk for individual treatment arms (see Details). |
agent |
A list or vector with agent information for individual treatment arms (see Details). |
dose |
A list or vector with dose information for individual treatment arms (see Details). |
data |
An optional data frame containing the study information. |
studlab |
A vector with study labels (optional). |
incr |
A numerical value which is added to cell frequencies for studies with a zero cell count, see Details. |
method |
A character string indicating which method is to be
used to calculate treatment estimates. Either |
method.incr |
A character string indicating which continuity
correction method should be used ( |
allstudies |
A logical indicating if studies with zero or all
events in two treatment arms are to be included in the
meta-analysis (applies only if |
reference.group |
Reference treatment (first treatment is used if argument is missing). |
keep.all.comparisons |
A logical indicating whether all pairwise comparisons or only comparisons with the study-specific reference group should be kept ('basic parameters'). |
sep.ag |
A character used as separator between agent in dose to create treatment labels. |
varnames |
Character vector of length 2 with the variable names for the treatment estimate and its standard error; by default, "TE" and "seTE". |
append |
Either a logical indicating whether variables from the dataset
provided in argument |
addincr |
Deprecated argument (replaced by 'method.incr');
see |
allincr |
Deprecated argument (replaced by 'method.incr');
see |
warn |
A logical indicating whether warnings should be printed (e.g., if studies are excluded due to only providing a single treatment arm). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments passed-through to the functions to calculate effects. |
The pairwise function transforms data given in (wide or long)
arm-based format into the contrast-based format which consists of
pairwise comparisons and is needed, for example, as input to the
netmeta
function.
The pairwise function can transform data with binary outcomes
(using the metabin
function from R package meta),
continuous outcomes (metacont
function), incidence
rates (metainc
function), and generic outcomes
(metagen
function). Depending on the outcome, the
following arguments are mandatory:
treat, event, n (see metabin
);
treat, n, mean, sd (see metacont
);
treat, event, time (see metainc
);
treat, TE, seTE (see metagen
).
Argument treat
is mandatory to identify the individual
treatments. The other arguments contain outcome specific
data. These arguments must be either lists (wide arm-based format,
i.e., one row per study) or vectors (long arm-based format,
i.e., multiple rows per study) of the same length.
For the wide arm-based format, each list consists of as many
vectors of the same length as the multi-arm study with the largest
number of treatments. If a single multi-arm study has five arms,
five vectors have to be provided for each lists. Two-arm studies
have entries with NA
for the third and subsequent
vectors. Each list entry is a vector with information for each
individual study; i.e., the length of this vector corresponds to
the total number of studies incorporated in the network
meta-analysis. Typically, list elements are part of a data frame
(argument data
, optional); see Examples. An optional vector
with study labels can be provided which can be part of the data
frame.
In the long arm-based format, argument studlab
is mandatory
to identify rows contributing to individual studies.
Additional arguments for meta-analysis functions can be provided
using argument '...'. The most important argument is sm
defining the summary measure. More information on this and other
arguments is given in the help pages of R functions
metabin
, metacont
,
metainc
, and metagen
, respectively.
For standardised mean differences (argument sm = "SMD"
),
equations (4) and (5) in Crippa & Orsini (2016) are used to
calculated SMDs and standard errors. These equations guarantee
consistent SMDs and standard errors for multi-arm studies. Note,
the summary measure is actually Cohen's d as Hedges' g is not
consistent in multi-arm studies.
For binary outcomes, 0.5 is added to all cell frequencies (odds
ratio) or only the number of events (risk ratio) for studies with a
zero cell count. For odds ratio and risk ratio, treatment estimates
and standard errors are only calculated for studies with zero or
all events in both groups if allstudies
is TRUE
. This
continuity correction is used both to calculate individual study
results with confidence limits and to conduct meta-analysis based
on the inverse variance method. For the risk difference, 0.5 is
only added to all cell frequencies to calculate the standard error.
For incidence rates, 0.5 is added to all cell frequencies for the incidence rate ratio as summary measure. For the incidence risk difference, 0.5 is only added to all cell frequencies to calculate the standard error.
The value of pairwise is a data frame with as many rows as there
are pairwise comparisons. For each study with p treatments,
p*(p-1) / 2 contrasts are generated. Each row contains the
treatment effect (TE
), its standard error (seTE
), the
treatments compared ((treat1
), (treat2
)) and the
study label ((studlab
)). Further columns are added according
to type of data.
All variables from the original dataset are also part of the output
dataset if argument append = TRUE
. If data are provided in the long
arm-based format, the value of a variable can differ between treatment arms;
for example, the mean age or percentage of women in the treatment arm. In
this situation, two variables instead of one variable will be included
in the output dataset. The values "1" and "2" are added to the
names for these variables, e.g. "mean.age1" and "mean.age2" for the
mean age.
In general, any variable names in the original dataset that are identical to the main variable names (i.e., "TE", "seTE", ...) will be renamed to variable names with ending ".orig".
A reduced dataset with basic comparisons (Rücker & Schwarzer,
2014) can be generated using argument keep.all.comparisons =
FALSE
. Furthermore, the reference group for the basic comparisons
can be specified with argument reference.group
.
R function netmeta
expects data in a
contrast-based format, where each row corresponds to a
comparison of two treatments and contains a measure of the
treatment effect comparing two treatments with standard error,
labels for the two treatments and an optional study label. In
contrast-based format, a three-arm study contributes three rows
with treatment comparison and corresponding standard error for
pairwise comparison A vs B, A vs C, and
B vs C whereas a four-arm study contributes six rows
/ pairwise comparisons: A vs B, A vs C,
..., C vs D.
Other programs for network meta-analysis in WinBUGS and Stata require data in an arm-based format, i.e. treatment estimate for each treatment arm instead of a difference of two treatments. A common (wide) arm-based format consists of one data row per study, containing treatment and other necessary information for all study arms. For example, a four-arm study contributes one row with four treatment estimates and corresponding standard errors for treatments A, B, C, and D. Another possible arm-based format is a long format where each row corresponds to a single study arm. Accordingly, in the long arm-based format a study contributes as many rows as treatments considered in the study.
A data frame with the following columns:
TE |
Treatment estimate comparing treatment 'treat1' and 'treat2'. |
seTE |
Standard error of treatment estimate. |
studlab |
Study labels. |
treat1 |
First treatment in comparison. |
treat2 |
Second treatment in comparison. |
event1 |
Number of events for first treatment arm (for metabin and metainc). |
event2 |
Number of events for second treatment arm (for metabin and metainc). |
n1 |
Number of observations for first treatment arm (for metabin and metacont). |
n2 |
Number of observations for second treatment arm (for metabin and metacont). |
mean1 |
Estimated mean for first treatment arm (for metacont). |
mean2 |
Estimated mean for second treatment arm (for metacont). |
sd1 |
Standard deviation for first treatment arm (for metacont). |
sd2 |
Standard deviation for second treatment arm (for metacont). |
TE1 |
Estimated treatment effect for first treatment arm (for metagen). |
TE2 |
Estimated treatment effect for second treatment arm (for metagen). |
seTE1 |
Standard error of estimated treatment effect for first treatment arm (for metagen). |
seTE2 |
Standard error of estimated treatment effect for second treatment arm (for metagen). |
time1 |
Person time at risk for first treatment arm (for metainc). |
time2 |
Person time at risk for second treatment arm (for metainc). |
agent1 |
First agent in comparison. |
agent2 |
Second agent in comparison. |
dose1 |
Dose of first agent in comparison. |
dose2 |
Dose of second agent in comparison. |
All variables from the original dataset are also part of the output dataset; see Details.
This function must not be confused with netpairwise
which can be used to conduct pairwise meta-analyses for all
comparisons with direct evidence in a network meta-analysis.
Gerta Rücker[email protected], Guido Schwarzer [email protected]
Crippa A, Orsini N (2016): Dose-response meta-analysis of differences in means. BMC Medical Research Methodology, 16:91.
longarm
, metabin
,
metacont
, metagen
,
metainc
, netmeta
,
netgraph.netmeta
,
dat.senn2013
,
dat.franchini2012
,
dat.franchini2012
p0 <- pairwise(studlab = study, treat = treatment, n = ni, mean = mi, sd = sdi, data = dat.senn2013, append = c("study", "comment")) head(p0) # Meta-analysis of studies comparing metformin to placebo metagen(p0, subset = treat1 == "metformin" & treat2 == "placebo") ## Not run: # Example using continuous outcomes (internal call of function # metacont) # Franchini2012 <- dat.franchini2012 # Transform data from arm-based format to contrast-based format p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = Franchini2012, studlab = Study) p1 # Conduct network meta-analysis library("netmeta") # net1 <- netmeta(p1) net1 # Draw network graphs # netgraph(net1, points = TRUE, cex.points = 3, cex = 1.5, thickness = "se.common") netgraph(net1, points = TRUE, cex.points = 3, cex = 1.5, plastic = TRUE, thickness = "se.common", iterate = TRUE) netgraph(net1, points = TRUE, cex.points = 3, cex = 1.5, plastic = TRUE, thickness = "se.common", iterate = TRUE, start = "eigen") # Example using generic outcomes (internal call of function # metagen) # # Calculate standard error for means y1, y2, y3 Franchini2012$se1 <- with(Franchini2012, sqrt(sd1^2 / n1)) Franchini2012$se2 <- with(Franchini2012, sqrt(sd2^2 / n2)) Franchini2012$se3 <- with(Franchini2012, sqrt(sd3^2 / n3)) # Transform data from arm-based format to contrast-based format # using means and standard errors (note, argument 'sm' has to be # used to specify that argument 'TE' is a mean difference) p2 <- pairwise(list(Treatment1, Treatment2, Treatment3), TE = list(y1, y2, y3), seTE = list(se1, se2, se3), n = list(n1, n2, n3), data = Franchini2012, studlab = Study, sm = "MD") p2 # Compare pairwise objects p1 (based on continuous outcomes) and p2 # (based on generic outcomes) # all.equal( p1[, c("TE", "seTE", "studlab", "treat1", "treat2")], p2[, c("TE", "seTE", "studlab", "treat1", "treat2")]) # Same result as network meta-analysis based on continuous outcomes # (object net1) net2 <- netmeta(p2) net2 # Example with binary data # data(smokingcessation) # Transform data from arm-based format to contrast-based format # (internal call of metabin function). Argument 'sm' has to be used # for odds ratio as risk ratio (sm = "RR") is default of metabin # function. # p3 <- pairwise(list(treat1, treat2, treat3), list(event1, event2, event3), list(n1, n2, n3), data = smokingcessation, sm = "OR") p3 # Conduct network meta-analysis # net3 <- netmeta(p3) net3 # Example with incidence rates # data(dietaryfat) # Transform data from arm-based format to contrast-based format # p4 <- pairwise(list(treat1, treat2, treat3), list(d1, d2, d3), time = list(years1, years2, years3), studlab = ID, data = dietaryfat) p4 # Conduct network meta-analysis using incidence rate ratios (sm = # "IRR"). Note, the argument 'sm' is not necessary as this is the # default in R function metainc called internally. # net4 <- netmeta(p4, sm = "IRR") summary(net4) # Example with long data format # # Transform data from long arm-based format to contrast-based # format Argument 'sm' has to be used for odds ratio as summary # measure; by default the risk ratio is used in the metabin # function called internally. # p5 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") p5 # Conduct network meta-analysis net5 <- netmeta(p5) net5 ## End(Not run)
p0 <- pairwise(studlab = study, treat = treatment, n = ni, mean = mi, sd = sdi, data = dat.senn2013, append = c("study", "comment")) head(p0) # Meta-analysis of studies comparing metformin to placebo metagen(p0, subset = treat1 == "metformin" & treat2 == "placebo") ## Not run: # Example using continuous outcomes (internal call of function # metacont) # Franchini2012 <- dat.franchini2012 # Transform data from arm-based format to contrast-based format p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = Franchini2012, studlab = Study) p1 # Conduct network meta-analysis library("netmeta") # net1 <- netmeta(p1) net1 # Draw network graphs # netgraph(net1, points = TRUE, cex.points = 3, cex = 1.5, thickness = "se.common") netgraph(net1, points = TRUE, cex.points = 3, cex = 1.5, plastic = TRUE, thickness = "se.common", iterate = TRUE) netgraph(net1, points = TRUE, cex.points = 3, cex = 1.5, plastic = TRUE, thickness = "se.common", iterate = TRUE, start = "eigen") # Example using generic outcomes (internal call of function # metagen) # # Calculate standard error for means y1, y2, y3 Franchini2012$se1 <- with(Franchini2012, sqrt(sd1^2 / n1)) Franchini2012$se2 <- with(Franchini2012, sqrt(sd2^2 / n2)) Franchini2012$se3 <- with(Franchini2012, sqrt(sd3^2 / n3)) # Transform data from arm-based format to contrast-based format # using means and standard errors (note, argument 'sm' has to be # used to specify that argument 'TE' is a mean difference) p2 <- pairwise(list(Treatment1, Treatment2, Treatment3), TE = list(y1, y2, y3), seTE = list(se1, se2, se3), n = list(n1, n2, n3), data = Franchini2012, studlab = Study, sm = "MD") p2 # Compare pairwise objects p1 (based on continuous outcomes) and p2 # (based on generic outcomes) # all.equal( p1[, c("TE", "seTE", "studlab", "treat1", "treat2")], p2[, c("TE", "seTE", "studlab", "treat1", "treat2")]) # Same result as network meta-analysis based on continuous outcomes # (object net1) net2 <- netmeta(p2) net2 # Example with binary data # data(smokingcessation) # Transform data from arm-based format to contrast-based format # (internal call of metabin function). Argument 'sm' has to be used # for odds ratio as risk ratio (sm = "RR") is default of metabin # function. # p3 <- pairwise(list(treat1, treat2, treat3), list(event1, event2, event3), list(n1, n2, n3), data = smokingcessation, sm = "OR") p3 # Conduct network meta-analysis # net3 <- netmeta(p3) net3 # Example with incidence rates # data(dietaryfat) # Transform data from arm-based format to contrast-based format # p4 <- pairwise(list(treat1, treat2, treat3), list(d1, d2, d3), time = list(years1, years2, years3), studlab = ID, data = dietaryfat) p4 # Conduct network meta-analysis using incidence rate ratios (sm = # "IRR"). Note, the argument 'sm' is not necessary as this is the # default in R function metainc called internally. # net4 <- netmeta(p4, sm = "IRR") summary(net4) # Example with long data format # # Transform data from long arm-based format to contrast-based # format Argument 'sm' has to be used for odds ratio as summary # measure; by default the risk ratio is used in the metabin # function called internally. # p5 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") p5 # Conduct network meta-analysis net5 <- netmeta(p5) net5 ## End(Not run)
Print method for objects of class meta
.
R function cilayout can be utilised to change the layout to print
confidence intervals (both in printout from print.meta and
print.summary.meta function as well as in forest plots). The
default layout is "[lower; upper]". Another popular layout is
"(lower - upper)" which is used throughout an R session by using R
command cilayout("(", " - ")
.
Argument pscale
can be used to rescale single proportions or
risk differences, e.g. pscale = 1000
means that proportions
are expressed as events per 1000 observations. This is useful in
situations with (very) low event probabilities.
Argument irscale
can be used to rescale single rates or rate
differences, e.g. irscale = 1000
means that rates are
expressed as events per 1000 time units, e.g. person-years. This is
useful in situations with (very) low rates. Argument irunit
can be used to specify the time unit used in individual studies
(default: "person-years"). This information is printed in summaries
and forest plots if argument irscale
is not equal to 1.
## S3 method for class 'meta' print( x, common = x$common, random = x$random, prediction = x$prediction, overall = x$overall, overall.hetstat = x$overall.hetstat, test.subgroup = x$test.subgroup, test.subgroup.common = test.subgroup & common, test.subgroup.random = test.subgroup & random, prediction.subgroup = x$prediction.subgroup, backtransf = x$backtransf, pscale = x$pscale, irscale = x$irscale, irunit = x$irunit, subgroup.name = x$subgroup.name, print.subgroup.name = x$print.subgroup.name, sep.subgroup = x$sep.subgroup, nchar.subgroup = 35, sort.overall = NULL, sort.tau = NULL, sort.het = NULL, sort.Q = NULL, header = TRUE, print.CMH = x$print.CMH, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval"), 2), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), digits.Q = gs("digits.Q"), digits.df = gs("digits.df"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.H = gs("digits.H"), digits.I2 = gs("digits.I2"), big.mark = gs("big.mark"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), print.tau2 = gs("print.tau2"), print.tau2.ci = gs("print.tau2.ci"), print.tau = gs("print.tau"), print.tau.ci = gs("print.tau.ci"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), print.H = gs("print.H"), print.Rb = gs("print.Rb"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), text.I2 = gs("text.I2"), text.Rb = gs("text.Rb"), details.methods = gs("details"), warn.backtransf = FALSE, func.backtransf = x$func.backtransf, warn.deprecated = gs("warn.deprecated"), ... ) cilayout( bracket = gs("CIbracket"), separator = gs("CIseparator"), lower.blank = gs("CIlower.blank"), upper.blank = gs("CIupper.blank") )
## S3 method for class 'meta' print( x, common = x$common, random = x$random, prediction = x$prediction, overall = x$overall, overall.hetstat = x$overall.hetstat, test.subgroup = x$test.subgroup, test.subgroup.common = test.subgroup & common, test.subgroup.random = test.subgroup & random, prediction.subgroup = x$prediction.subgroup, backtransf = x$backtransf, pscale = x$pscale, irscale = x$irscale, irunit = x$irunit, subgroup.name = x$subgroup.name, print.subgroup.name = x$print.subgroup.name, sep.subgroup = x$sep.subgroup, nchar.subgroup = 35, sort.overall = NULL, sort.tau = NULL, sort.het = NULL, sort.Q = NULL, header = TRUE, print.CMH = x$print.CMH, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval"), 2), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), digits.Q = gs("digits.Q"), digits.df = gs("digits.df"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.H = gs("digits.H"), digits.I2 = gs("digits.I2"), big.mark = gs("big.mark"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), print.tau2 = gs("print.tau2"), print.tau2.ci = gs("print.tau2.ci"), print.tau = gs("print.tau"), print.tau.ci = gs("print.tau.ci"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), print.H = gs("print.H"), print.Rb = gs("print.Rb"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), text.I2 = gs("text.I2"), text.Rb = gs("text.Rb"), details.methods = gs("details"), warn.backtransf = FALSE, func.backtransf = x$func.backtransf, warn.deprecated = gs("warn.deprecated"), ... ) cilayout( bracket = gs("CIbracket"), separator = gs("CIseparator"), lower.blank = gs("CIlower.blank"), upper.blank = gs("CIupper.blank") )
x |
An object of class |
common |
A logical indicating whether results for common effect meta-analysis should be printed. |
random |
A logical indicating whether results for random effects meta-analysis should be printed. |
prediction |
A logical indicating whether a prediction interval should be printed. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
test.subgroup.common |
A logical value indicating whether to print results of test for subgroup differences (based on common effect model). |
test.subgroup.random |
A logical value indicating whether to print results of test for subgroup differences (based on random effects model). |
prediction.subgroup |
A single logical or logical vector indicating whether / which prediction intervals should be printed for subgroups. |
backtransf |
A logical indicating whether printed results
should be back transformed. If |
pscale |
A numeric giving scaling factor for printing of
single event probabilities or risk differences, i.e. if argument
|
irscale |
A numeric defining a scaling factor for printing of
single incidence rates or incidence rate differences, i.e. if
argument |
irunit |
A character specifying the time unit used to calculate rates, e.g. person-years. |
subgroup.name |
A character string with a name for the grouping variable. |
print.subgroup.name |
A logical indicating whether the name of the grouping variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between label and levels of grouping variable. |
nchar.subgroup |
A numeric specifying the number of characters to print from subgroup labels. |
sort.overall |
An optional vector used to sort meta-analysis results. |
sort.tau |
An optional vector used to sort estimators of the between-study heterogeneity variance. |
sort.het |
An optional vector used to sort heterogeneity statistics. |
sort.Q |
An optional vector used to sort test of heterogeneity. |
header |
A logical indicating whether information on title of meta-analysis, comparison and outcome should be printed at the beginning of the printout. |
print.CMH |
A logical indicating whether result of the Cochran-Mantel-Haenszel test for overall effect should be printed. |
digits |
Minimal number of significant digits, see
|
digits.stat |
Minimal number of significant digits for z- or
t-value of test for overall effect, see |
digits.pval |
Minimal number of significant digits for p-value
of overall treatment effect, see |
digits.tau2 |
Minimal number of significant digits for
between-study variance |
digits.tau |
Minimal number of significant digits for
|
digits.Q |
Minimal number of significant digits for
heterogeneity statistic Q, see |
digits.df |
Minimal number of significant digits for degrees of freedom. |
digits.pval.Q |
Minimal number of significant digits for
p-value of heterogeneity test, see |
digits.H |
Minimal number of significant digits for H
statistic, see |
digits.I2 |
Minimal number of significant digits for I-squared
and Rb statistic, see |
big.mark |
A character used as thousands separator. |
scientific.pval |
A logical specifying whether p-values should be printed in scientific notation, e.g., 1.2345e-01 instead of 0.12345. |
zero.pval |
A logical specifying whether p-values should be printed with a leading zero. |
JAMA.pval |
A logical specifying whether p-values for test of overall effect should be printed according to JAMA reporting standards. |
print.tau2 |
A logical specifying whether between-study
variance |
print.tau2.ci |
A logical value indicating whether to print
the confidence interval of |
print.tau |
A logical specifying whether |
print.tau.ci |
A logical value indicating whether to print the
confidence interval of |
print.Q |
A logical value indicating whether to print the results of the test of heterogeneity. |
print.I2 |
A logical specifying whether heterogeneity
statistic I |
print.I2.ci |
A logical specifying whether confidence interval for
heterogeneity statistic I |
print.H |
A logical specifying whether heterogeneity statistic H should be printed. |
print.Rb |
A logical specifying whether heterogeneity
statistic R |
text.tau2 |
Text printed to identify between-study variance
|
text.tau |
Text printed to identify |
text.I2 |
Text printed to identify heterogeneity statistic
I |
text.Rb |
Text printed to identify heterogeneity statistic
R |
details.methods |
A logical specifying whether details on statistical methods should be printed. |
warn.backtransf |
Deprecated argument (ignored). |
func.backtransf |
A function used to back-transform results. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (passed on to |
bracket |
A character with bracket symbol to print lower confidence interval: "[", "(", "{", "". |
separator |
A character string with information on separator between lower and upper confidence interval. |
lower.blank |
A logical indicating whether blanks between left bracket and lower confidence limit should be printed. |
upper.blank |
A logical indicating whether blanks between separator and upper confidence limit should be printed. |
Calculate and print a summary of all meta-analyses in a Cochrane review.
## S3 method for class 'rm5' print(x, comp.no, outcome.no, ...)
## S3 method for class 'rm5' print(x, comp.no, outcome.no, ...)
x |
An object of class |
comp.no |
Comparison number. |
outcome.no |
Outcome number. |
... |
Additional arguments (passed on to |
This function can be used to redo all or selected meta-analyses of a Cochrane Review of interventions (Higgins et al., 2023).
Review Manager 5 (RevMan 5) was the software used for preparing and
maintaining Cochrane Reviews. In RevMan 5, subgroup analyses can be defined
and data from a Cochrane review can be imported to R using the function
read.rm5
.
The R function metacr
is called internally.
Guido Schwarzer [email protected]
Higgins JPT, Thomas J, Chandler J, Cumpston M, Li T, Page MJ, Welch VA (editors) (2023): Cochrane Handbook for Systematic Reviews of Interventions Version 6.4 (updated August 2023). Available from https://training.cochrane.org/handbook/
summary.meta
, metacr
,
read.rm5
, metabias.rm5
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Print results for all meta-analysis # Fleiss1993_CR # Print results only for second outcome of first comparison # print(Fleiss1993_CR, comp.no = 1, outcome.no = 2)
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Print results for all meta-analysis # Fleiss1993_CR # Print results only for second outcome of first comparison # print(Fleiss1993_CR, comp.no = 1, outcome.no = 2)
Print method for objects of class summary.meta
.
## S3 method for class 'summary.meta' print( x, sortvar, common = x$x$common, random = x$x$random, details = FALSE, ma = TRUE, overall = x$overall & ma, backtransf = x$backtransf, pscale = x$pscale, irscale = x$irscale, irunit = x$irunit, digits = gs("digits"), digits.se = gs("digits.se"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval"), 2), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), digits.Q = gs("digits.Q"), digits.df = gs("digits.df"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.H = gs("digits.H"), digits.I2 = gs("digits.I2"), digits.prop = gs("digits.prop"), digits.weight = gs("digits.weight"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), big.mark = gs("big.mark"), print.tau2 = gs("print.tau2"), print.tau2.ci = gs("print.tau2.ci"), print.tau = gs("print.tau"), print.tau.ci = gs("print.tau.ci"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), print.H = gs("print.H"), print.Rb = gs("print.Rb"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), text.I2 = gs("text.I2"), text.Rb = gs("text.Rb"), truncate, text.truncate = "*** Output truncated ***", details.methods = TRUE, warn.backtransf = FALSE, ... )
## S3 method for class 'summary.meta' print( x, sortvar, common = x$x$common, random = x$x$random, details = FALSE, ma = TRUE, overall = x$overall & ma, backtransf = x$backtransf, pscale = x$pscale, irscale = x$irscale, irunit = x$irunit, digits = gs("digits"), digits.se = gs("digits.se"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval"), 2), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), digits.Q = gs("digits.Q"), digits.df = gs("digits.df"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.H = gs("digits.H"), digits.I2 = gs("digits.I2"), digits.prop = gs("digits.prop"), digits.weight = gs("digits.weight"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), big.mark = gs("big.mark"), print.tau2 = gs("print.tau2"), print.tau2.ci = gs("print.tau2.ci"), print.tau = gs("print.tau"), print.tau.ci = gs("print.tau.ci"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), print.H = gs("print.H"), print.Rb = gs("print.Rb"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), text.I2 = gs("text.I2"), text.Rb = gs("text.Rb"), truncate, text.truncate = "*** Output truncated ***", details.methods = TRUE, warn.backtransf = FALSE, ... )
x |
An object of class |
sortvar |
An optional vector used to sort the individual
studies (must be of same length as |
common |
A logical indicating whether results of common effect meta-analysis should be printed. |
random |
A logical indicating whether results of random effects meta-analysis should be printed. |
details |
A logical indicating whether further details of individual studies should be printed. |
ma |
A logical indicating whether the summary results of the meta-analysis should be printed. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
backtransf |
A logical indicating whether printed results
should be back transformed. If |
pscale |
A numeric giving scaling factor for printing of
single event probabilities or risk differences, i.e. if argument
|
irscale |
A numeric defining a scaling factor for printing of
single incidence rates or incidence rate differences, i.e. if
argument |
irunit |
A character specifying the time unit used to calculate rates, e.g. person-years. |
digits |
Minimal number of significant digits, see
|
digits.se |
Minimal number of significant digits for standard
deviations and standard errors, see |
digits.stat |
Minimal number of significant digits for z- or
t-value of test for effect, see |
digits.pval |
Minimal number of significant digits for p-value
of test of treatment effect, see |
digits.tau2 |
Minimal number of significant digits for
between-study variance, see |
digits.tau |
Minimal number of significant digits for square
root of between-study variance, see |
digits.Q |
Minimal number of significant digits for
heterogeneity statistic Q, see |
digits.df |
Minimal number of significant digits for degrees of freedom. |
digits.pval.Q |
Minimal number of significant digits for
p-value of heterogeneity test, see |
digits.H |
Minimal number of significant digits for H
statistic, see |
digits.I2 |
Minimal number of significant digits for I-squared
and Rb statistic, see |
digits.prop |
Minimal number of significant digits for
proportions, see |
digits.weight |
Minimal number of significant digits for
weights, see |
scientific.pval |
A logical specifying whether p-values should be printed in scientific notation, e.g., 1.2345e-01 instead of 0.12345. |
zero.pval |
A logical specifying whether p-values should be printed with a leading zero. |
JAMA.pval |
A logical specifying whether p-values for test of overall effect should be printed according to JAMA reporting standards. |
big.mark |
A character used as thousands separator. |
print.tau2 |
A logical specifying whether between-study
variance |
print.tau2.ci |
A logical value indicating whether to print
the confidence interval of |
print.tau |
A logical specifying whether |
print.tau.ci |
A logical value indicating whether to print the
confidence interval of |
print.Q |
A logical value indicating whether to print the results of the test of heterogeneity. |
print.I2 |
A logical specifying whether heterogeneity
statistic I |
print.I2.ci |
A logical specifying whether confidence interval for
heterogeneity statistic I |
print.H |
A logical specifying whether heterogeneity statistic H should be printed. |
print.Rb |
A logical specifying whether heterogeneity
statistic R |
text.tau2 |
Text printed to identify between-study variance
|
text.tau |
Text printed to identify |
text.I2 |
Text printed to identify heterogeneity statistic
I |
text.Rb |
Text printed to identify heterogeneity statistic
R |
truncate |
An optional vector used to truncate the printout of
results for individual studies (must be a logical vector of same
length as |
text.truncate |
A character string printed if study results were truncated from the printout. |
details.methods |
A logical specifying whether details on statistical methods should be printed. |
warn.backtransf |
Deprecated argument (ignored). |
... |
Additional arguments (passed on to
|
Print method for objects of class summary.meta
giving
detailed information on the meta-analysis.
Argument pscale
can be used to rescale single proportions or
risk differences, e.g. pscale = 1000
means that proportions
are expressed as events per 1000 observations. This is useful in
situations with (very) low event probabilities.
Argument irscale
can be used to rescale single rates or rate
differences, e.g. irscale = 1000
means that rates are
expressed as events per 1000 time units, e.g. person-years. This is
useful in situations with (very) low rates. Argument irunit
can be used to specify the time unit used in individual studies
(default: "person-years"). This information is printed in summaries
and forest plots if argument irscale
is not equal to 1.
Guido Schwarzer [email protected]
Cooper H & Hedges LV (1994), The Handbook of Research Synthesis. Newbury Park, CA: Russell Sage Foundation.
Crippa A, Khudyakov P, Wang M, Orsini N, Spiegelman D (2016), A new measure of between-studies heterogeneity in meta-analysis. Statistics in Medicine, 35, 3661–75.
Higgins JPT & Thompson SG (2002), Quantifying heterogeneity in a meta-analysis. Statistics in Medicine, 21, 1539–58.
summary.meta
, update.meta
,
metabin
, metacont
,
metagen
data(Fleiss1993cont) m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD", studlab = paste(study, year)) sm1 <- summary(m1) sm1 print(sm1, digits = 2) ## Not run: # Use unicode characters to print tau^2, tau, and I^2 print(sm1, text.tau2 = "\u03c4\u00b2", text.tau = "\u03c4", text.I2 = "I\u00b2") ## End(Not run)
data(Fleiss1993cont) m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD", studlab = paste(study, year)) sm1 <- summary(m1) sm1 print(sm1, digits = 2) ## Not run: # Use unicode characters to print tau^2, tau, and I^2 print(sm1, text.tau2 = "\u03c4\u00b2", text.tau = "\u03c4", text.I2 = "I\u00b2") ## End(Not run)
Draw a radial plot (also called Galbraith plot) which can be used to assess bias in meta-analysis.
## S3 method for class 'meta' radial( x, xlim = NULL, ylim = NULL, xlab = "Inverse of standard error", ylab = "Standardised treatment effect (z-score)", common = TRUE, axes = TRUE, pch = 1, text = NULL, cex = 1, col = NULL, level = NULL, warn.deprecated = gs("warn.deprecated"), fixed, ... ) ## Default S3 method: radial( x, y, xlim = NULL, ylim = NULL, xlab = "Inverse of standard error", ylab = "Standardised treatment effect (z-score)", common = TRUE, axes = TRUE, pch = 1, text = NULL, cex = 1, col = NULL, level = NULL, ... )
## S3 method for class 'meta' radial( x, xlim = NULL, ylim = NULL, xlab = "Inverse of standard error", ylab = "Standardised treatment effect (z-score)", common = TRUE, axes = TRUE, pch = 1, text = NULL, cex = 1, col = NULL, level = NULL, warn.deprecated = gs("warn.deprecated"), fixed, ... ) ## Default S3 method: radial( x, y, xlim = NULL, ylim = NULL, xlab = "Inverse of standard error", ylab = "Standardised treatment effect (z-score)", common = TRUE, axes = TRUE, pch = 1, text = NULL, cex = 1, col = NULL, level = NULL, ... )
x |
An object of class |
xlim |
The x limits (min, max) of the plot. |
ylim |
The y limits (min, max) of the plot. |
xlab |
A label for the x-axis. |
ylab |
A label for the y-axis. |
common |
A logical indicating whether the pooled common effect estimate should be plotted. |
axes |
A logical indicating whether axes should be drawn on the plot. |
pch |
The plotting symbol used for individual studies. |
text |
A character vector specifying the text to be used instead of plotting symbol. |
cex |
The magnification to be used for plotting symbol. |
col |
A vector with colour of plotting symbols. |
level |
The confidence level utilised in the plot. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
fixed |
Deprecated argument (replaced by 'common'). |
... |
Graphical arguments as in |
y |
Standard error of estimated treatment effect. |
A radial plot (Galbraith 1988a,b), also called Galbraith plot, is
drawn in the active graphics window. If common
is TRUE, the
pooled estimate of the common effect model is plotted. If
level
is not NULL, the corresponding confidence limits are
drawn.
Guido Schwarzer [email protected]
Galbraith RF (1988a): Graphical display of estimates having differing standard errors. Technometrics, 30, 271–81
Galbraith RF (1988b): A note on graphical presentation of estimated odds ratios from several clinical trials. Statistics in Medicine, 7, 889–94
metabias
, metabin
,
metagen
, funnel
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = c(41, 47, 51, 59), studlab = paste(author, year), sm = "RR", method = "I") # Radial plot # radial(m1, level = 0.95)
data(Olkin1995) m1 <- metabin(ev.exp, n.exp, ev.cont, n.cont, data = Olkin1995, subset = c(41, 47, 51, 59), studlab = paste(author, year), sm = "RR", method = "I") # Radial plot # radial(m1, level = 0.95)
Reads Cochrane data package (version 1) of a Cochrane intervention review and creates a data frame from it.
read.cdir( file, title = "Cochrane Review of Interventions", exdir = tempdir(), numbers.in.labels = TRUE, rob = !missing(tool) | !missing(categories) | !missing(col) | !missing(symbols), tool = NULL, categories = NULL, col = NULL, symbols = NULL, keep.orig = FALSE, ... ) ## S3 method for class 'cdir' print(x, ...)
read.cdir( file, title = "Cochrane Review of Interventions", exdir = tempdir(), numbers.in.labels = TRUE, rob = !missing(tool) | !missing(categories) | !missing(col) | !missing(symbols), tool = NULL, categories = NULL, col = NULL, symbols = NULL, keep.orig = FALSE, ... ) ## S3 method for class 'cdir' print(x, ...)
file |
The name of a file to read data values from. |
title |
Title of Cochrane review. |
exdir |
The directory to extract files to (the equivalent of ‘unzip -d’). It will be created if necessary. |
numbers.in.labels |
A logical indicating whether comparison
number and outcome number should be printed at the beginning of
the comparison (argument |
rob |
A logical indicating whether risk of bias (RoB) assessment should be considered in meta-analyses. |
tool |
Risk of bias (RoB) tool. |
categories |
Possible RoB categories. |
col |
Colours for RoB categories. |
symbols |
Corresponding symbols for RoB categories. |
keep.orig |
A logical indicating whether to return the original data files. |
... |
Additional arguments (passed on to
|
x |
An object of class "cdir". |
RevMan Web is the current software used for preparing and maintaining Cochrane reviews. RevMan Web includes the ability to write systematic reviews of interventions or diagnostic test accuracy reviews.
This function provides the ability to read the Cochrane data
package from a Cochrane intervention review created with RevMan
Web. The ZIP-file is extracted with unzip
.
Argument title
can be used to overwrite the title of the
Cochrane review.
Information on the risk of bias (RoB) assessment can be provided
with arguments tool
, categories
, col
and
symbols
. This is only useful if (i) all outcomes are based
on the same RoB categories and (ii) an overall RoB assessment has
not been done. If no overall RoB assessment was conducted, R
function metacr
can be used to provide the RoB
information for a single outcome. R function rob
is
the most flexible way to add RoB information to a meta-analysis
object.
Two possible ways exist to create the ZIP-file.
In RevMan Web, press the "Export" button at the bottom of the Default view website. After a couple of seconds, the data package will be shown at the bottom of the Default view website under "Downloads".
In the Cochrane Library, press on "Download statistical data" in the Contents menu to download an rm5-file. This file can be converted to a data package in RevMan Web using Help - Convert a RevMan 5 file.
A list consisting of a data frame 'data' with the study data and
(if available) a data frame 'rob' with information on the risk of
bias assessment. If keep.orig = TRUE
, an additional list
'orig' is returned containing elements 'settings', 'datarows',
'subgroup' and 'rob' (if available).
The data frame 'data' contains the following variables:
comp.no |
Comparison number. |
outcome.no |
Outcome number. |
group.no |
Group number. |
studlab |
Study label. |
year |
Year of publication. |
event.e |
Number of events in experimental group. |
n.e |
Number of observations in experimental group. |
event.c |
Number of events in control group. |
n.c |
Number of observations in control group. |
mean.e |
Estimated mean in experimental group. |
sd.e |
Standard deviation in experimental group. |
mean.c |
Estimated mean in control group. |
sd.c |
Standard deviation in control group. |
O.E |
Observed minus expected (IPD analysis). |
V |
Variance of |
TE , seTE
|
Estimated treatment effect and standard error of individual studies. |
lower , upper
|
Lower and upper limit of 95% confidence interval for treatment effect in individual studies. |
weight |
Weight of individual studies (according to meta-analytical method used in respective meta-analysis - see details). |
order |
Ordering of studies. |
grplab |
Group label. |
type |
Type of outcome. D = dichotomous, C = continuous, P = IPD. |
method |
A character string indicating which method has been
used for pooling of studies. One of |
sm |
A character string indicating which summary measure has been used for pooling of studies. |
model |
A character string indicating which meta-analytical
model has been used (either |
common |
A logical indicating whether common effect meta-analysis has been used in respective meta-analysis (see details). |
random |
A logical indicating whether random effects meta-analysis has been used in respective meta-analysis (see details). |
title |
Title of Cochrane review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.e |
Label for experimental group. |
label.c |
Label for control group. |
label.left |
Graph label on left side of forest plot. |
label.right |
Graph label on right side of forest plot. |
The data frame 'rob' contains the following variables:
studlab |
Study label. |
D1 , D2 , ...
|
Risk of bias domain 1, 2, ... |
D1.details , D2.details , ...
|
Details on risk of bias domain 1, 2, ... |
Guido Schwarzer [email protected]
https://documentation.cochrane.org/revman-kb/data-package-user-guide-243761660.html
https://documentation.cochrane.org/revman-kb/data-package-specification-249561249.html
# Locate file "Fleiss1993.zip" with Cochrane data package in # sub-directory of R package meta # filename <- system.file("extdata/Fleiss1993.zip", package = "meta") Fleiss1993_CR <- read.cdir(filename) Fleiss1993_CR # Same result as R Command example(Fleiss1993bin): # metacr(Fleiss1993_CR) # Same result as R Command example(Fleiss1993cont): # metacr(Fleiss1993_CR, 1, 2)
# Locate file "Fleiss1993.zip" with Cochrane data package in # sub-directory of R package meta # filename <- system.file("extdata/Fleiss1993.zip", package = "meta") Fleiss1993_CR <- read.cdir(filename) Fleiss1993_CR # Same result as R Command example(Fleiss1993bin): # metacr(Fleiss1993_CR) # Same result as R Command example(Fleiss1993cont): # metacr(Fleiss1993_CR, 1, 2)
Reads a file created with RevMan 4 and creates a data frame from it.
read.mtv(file)
read.mtv(file)
file |
The name of a file to read data values from. |
Reads a file created with RevMan 4 (Menu: "File" - "Export" - "Analysis data file...") and creates a data frame from it.
A data frame containing the following components:
comp.no |
Comparison number. |
outcome.no |
Outcome number. |
group.no |
Group number. |
studlab |
Study label. |
year |
Year of publication. |
event.e |
Number of events in experimental group. |
n.e |
Number of observations in experimental group. |
event.c |
Number of events in control group. |
n.c |
Number of observations in control group. |
mean.e |
Estimated mean in experimental group. |
sd.e |
Standard deviation in experimental group. |
mean.c |
Estimated mean in control group. |
sd.c |
Standard deviation in control group. |
O.E |
Observed minus expected (IPD analysis). |
V |
Variance of |
order |
Ordering of studies. |
conceal |
Concealment of treatment allocation. |
grplab |
Group label. |
type |
Type of outcome. D = dichotomous, C = continuous, P = IPD. |
outclab |
Outcome label. |
graph.exp |
Graph label for experimental group. |
graph.cont |
Graph label for control group. |
label.exp |
Label for experimental group. |
label.cont |
Label for control group. |
complab |
Comparison label. |
Guido Schwarzer [email protected]
Review Manager (RevMan) [Computer program]. Version 4.2. Copenhagen: The Nordic Cochrane Centre, The Cochrane Collaboration, 2003
# Locate MTV-data file "FLEISS1993.MTV" in sub-directory of R package # meta # filename <- system.file("extdata/FLEISS1993.MTV", package = "meta") fleiss1933.cc <- read.mtv(filename) # Same result as R Command example(Fleiss1993bin): # metabin(event.e, n.e, event.c, n.c, data = fleiss1933.cc, subset = type == "D", studlab = paste(studlab, year)) # Same result: example(Fleiss1993cont) # metacont(n.e, mean.e, sd.e, n.c, mean.c, sd.c, data = fleiss1933.cc, subset = type == "C", studlab = paste(studlab, year))
# Locate MTV-data file "FLEISS1993.MTV" in sub-directory of R package # meta # filename <- system.file("extdata/FLEISS1993.MTV", package = "meta") fleiss1933.cc <- read.mtv(filename) # Same result as R Command example(Fleiss1993bin): # metabin(event.e, n.e, event.c, n.c, data = fleiss1933.cc, subset = type == "D", studlab = paste(studlab, year)) # Same result: example(Fleiss1993cont) # metacont(n.e, mean.e, sd.e, n.c, mean.c, sd.c, data = fleiss1933.cc, subset = type == "C", studlab = paste(studlab, year))
Reads analysis data from Cochrane intervention review created with RevMan 5 and creates a data frame from it.
read.rm5( file, sep = ",", quote = "\"", title, numbers.in.labels = TRUE, debug = 0 )
read.rm5( file, sep = ",", quote = "\"", title, numbers.in.labels = TRUE, debug = 0 )
file |
The name of a file to read data values from. |
sep |
The field separator character (only considered for CSV-files). Values on each line of the file are separated by this character. The comma is the default field separator character in RevMan 5. |
quote |
The set of quoting characters (only considered for CSV-files). In RevMan 5 a "\"" is the default quoting character. |
title |
Title of Cochrane review. |
numbers.in.labels |
A logical indicating whether comparison
number and outcome number should be printed at the beginning of
the comparison (argument |
debug |
An integer between 0 and 3 indicating whether to print debug messages (only considered for RM5-files). |
Review Manager 5 (RevMan 5) was the software used for preparing and maintaining Cochrane reviews. RevMan 5 includes the ability to write systematic reviews of interventions, diagnostic test accuracy reviews, methodology reviews and overviews of reviews.
This function provides the ability to read the analysis data from a Cochrane intervention review created with RevMan 5; a data frame is created from it. Cochrane intervention reviews are based on comparisons of two interventions.
By default in RevMan 5, the name of the exported CSV data file is
the title of the Cochrane review. Furthermore, the title is part of
the RM5-file. Argument title
can be used to overwrite the
title of the Cochrane review.
A RM5-file (which is in a specific XML format) can be used directly to import the analysis dataset.
If the import fails, use argument debug = 3
for more details.
In the past, the following (rather complicated) procedure based on a CSV-file generated within RevMan 5 was necessary - which is only described here for backward compatibility.
In order to generate a data analysis file in RevMan 5 use the
following Menu points: "File"
- "Export"
-
"Data and analyses"
. It is mandatory to include the
following fields in the exported data file by selecting them with
the mouse cursor in the Export Analysis Data Wizard: (i) Comparison
Number, (ii) Outcome Number, (iii) Subgroup Number. When these
fields are not selected a corresponding error message will be
printed in R. It is recommended to include all fields in the
exported data file except for the last field
"Risk of bias tables". For example, in order to redo the
meta-analysis in R for the RevMan 5 data type
"O-E and Variance"
the fields "O-E"
and
"Variance"
have to be selected in the Export Analysis Data
Wizard. If the last field "Risk of bias tables" is selected the
import in R fails with an error message
"line X did not have Y elements".
A data frame containing the following components:
comp.no |
Comparison number. |
outcome.no |
Outcome number. |
group.no |
Group number. |
studlab |
Study label. |
year |
Year of publication. |
event.e |
Number of events in experimental group. |
n.e |
Number of observations in experimental group. |
event.c |
Number of events in control group. |
n.c |
Number of observations in control group. |
mean.e |
Estimated mean in experimental group. |
sd.e |
Standard deviation in experimental group. |
mean.c |
Estimated mean in control group. |
sd.c |
Standard deviation in control group. |
O.E |
Observed minus expected (IPD analysis). |
V |
Variance of |
TE , seTE
|
Estimated treatment effect and standard error of individual studies. |
lower , upper
|
Lower and upper limit of 95% confidence interval for treatment effect in individual studies. |
weight |
Weight of individual studies (according to meta-analytical method used in respective meta-analysis - see details). |
order |
Ordering of studies. |
grplab |
Group label. |
type |
Type of outcome. D = dichotomous, C = continuous, P = IPD. |
method |
A character string indicating which method has been
used for pooling of studies. One of |
sm |
A character string indicating which summary measure has been used for pooling of studies. |
model |
A character string indicating which meta-analytical
model has been used (either |
common |
A logical indicating whether common effect meta-analysis has been used in respective meta-analysis (see details). |
random |
A logical indicating whether random effects meta-analysis has been used in respective meta-analysis (see details). |
outclab |
Outcome label. |
k |
Total number of studies combined in respective meta-analysis). |
event.e.pooled |
Number of events in experimental group in respective meta-analysis (see details). |
n.e.pooled |
Number of observations in experimental group in respective meta-analysis (see details). |
event.c.pooled |
Number of events in control group in respective meta-analysis (see details). |
n.c.pooled |
Number of observations in control group in respective meta-analysis (see details). |
TE.pooled |
Estimated treatment effect in respective meta-analysis (see details). |
lower , upper
|
Lower and upper limit of 95% confidence interval for treatment effect in respective meta-analysis (see details). |
weight.pooled |
Total weight in respective meta-analysis (see details). |
Z.pooled |
Z-score for test of overall treatment effect in respective meta-analysis (see details). |
pval.pooled |
P-value for test of overall treatment effect in respective meta-analysis (see details). |
Q |
Heterogeneity statistic Q in respective meta-analysis (see details). |
pval.Q |
P-value of heterogeneity statistic Q in respective meta-analysis (see details). |
I2 |
Heterogeneity statistic I |
tau2 |
Between-study variance (moment estimator of DerSimonian-Laird) in respective meta-analysis. |
Q.w |
Heterogeneity statistic Q within groups in respective meta-analysis (see details). |
pval.Q.w |
P-value of heterogeneity statistic Q within groups in respective meta-analysis (see details). |
I2.w |
Heterogeneity statistic I |
label.e |
Label for experimental group. |
label.c |
Label for control group. |
label.left |
Graph label on left side of forest plot. |
label.right |
Graph label on right side of forest plot. |
complab |
Comparison label. |
Guido Schwarzer [email protected]
Review Manager (RevMan) [Computer program]. Version 5.4. The Cochrane Collaboration, 2020
summary.rm5
, metabias.rm5
,
metabin
, metacont
,
metagen
, metacr
,
print.rm5
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Same result as R command example(Fleiss1993bin): # metacr(Fleiss1993_CR) # Same result as R command example(Fleiss1993cont): # metacr(Fleiss1993_CR, 1, 2) ## Not run: # Locate file "Fleiss1993.rm5" in sub-directory of R package meta # filename <- system.file("extdata/Fleiss1993.rm5", package = "meta") Fleiss1993_CR <- read.cdir(filename) Fleiss1993_CR # Same result as R Command example(Fleiss1993bin): # metacr(Fleiss1993_CR) ## End(Not run)
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Same result as R command example(Fleiss1993bin): # metacr(Fleiss1993_CR) # Same result as R command example(Fleiss1993cont): # metacr(Fleiss1993_CR, 1, 2) ## Not run: # Locate file "Fleiss1993.rm5" in sub-directory of R package meta # filename <- system.file("extdata/Fleiss1993.rm5", package = "meta") Fleiss1993_CR <- read.cdir(filename) Fleiss1993_CR # Same result as R Command example(Fleiss1993bin): # metacr(Fleiss1993_CR) ## End(Not run)
Create table with risk of bias assessment or add table to existing meta-analysis
rob( item1, item2 = NULL, item3 = NULL, item4 = NULL, item5 = NULL, item6 = NULL, item7 = NULL, item8 = NULL, item9 = NULL, item10 = NULL, studlab = NULL, overall = NULL, weight = NULL, data = NULL, tool = gs("tool.rob"), domains = NULL, categories = NULL, cat1 = categories, cat2 = categories, cat3 = categories, cat4 = categories, cat5 = categories, cat6 = categories, cat7 = categories, cat8 = categories, cat9 = categories, cat10 = categories, cat.overall = categories, col = NULL, col1 = col, col2 = col, col3 = col, col4 = col, col5 = col, col6 = col, col7 = col, col8 = col, col9 = col, col10 = col, col.overall = col, symbols = NULL, symb1 = symbols, symb2 = symbols, symb3 = symbols, symb4 = symbols, symb5 = symbols, symb6 = symbols, symb7 = symbols, symb8 = symbols, symb9 = symbols, symb10 = symbols, symb.overall = symbols, legend = TRUE, overwrite = FALSE, warn = TRUE ) ## S3 method for class 'rob' print(x, legend = attr(x, "legend"), details = TRUE, ...)
rob( item1, item2 = NULL, item3 = NULL, item4 = NULL, item5 = NULL, item6 = NULL, item7 = NULL, item8 = NULL, item9 = NULL, item10 = NULL, studlab = NULL, overall = NULL, weight = NULL, data = NULL, tool = gs("tool.rob"), domains = NULL, categories = NULL, cat1 = categories, cat2 = categories, cat3 = categories, cat4 = categories, cat5 = categories, cat6 = categories, cat7 = categories, cat8 = categories, cat9 = categories, cat10 = categories, cat.overall = categories, col = NULL, col1 = col, col2 = col, col3 = col, col4 = col, col5 = col, col6 = col, col7 = col, col8 = col, col9 = col, col10 = col, col.overall = col, symbols = NULL, symb1 = symbols, symb2 = symbols, symb3 = symbols, symb4 = symbols, symb5 = symbols, symb6 = symbols, symb7 = symbols, symb8 = symbols, symb9 = symbols, symb10 = symbols, symb.overall = symbols, legend = TRUE, overwrite = FALSE, warn = TRUE ) ## S3 method for class 'rob' print(x, legend = attr(x, "legend"), details = TRUE, ...)
item1 |
Risk of bias item 1 or a meta-analysis object of class
|
item2 |
Risk of bias item 2. |
item3 |
Risk of bias item 3. |
item4 |
Risk of bias item 4. |
item5 |
Risk of bias item 5. |
item6 |
Risk of bias item 6. |
item7 |
Risk of bias item 7. |
item8 |
Risk of bias item 8. |
item9 |
Risk of bias item 9. |
item10 |
Risk of bias item 10. |
studlab |
Study labels. |
overall |
Overall risk of bias assess. |
weight |
Weight for each study. |
data |
A data frame or a meta-analysis object of class
|
tool |
Risk of bias (RoB) tool. |
domains |
A character vector with names of RoB domains. |
categories |
Possible RoB categories. |
cat1 |
Possible categories for RoB item 1. |
cat2 |
Possible categories for RoB item 2. |
cat3 |
Possible categories for RoB item 3. |
cat4 |
Possible categories for RoB item 4. |
cat5 |
Possible categories for RoB item 5. |
cat6 |
Possible categories for RoB item 6. |
cat7 |
Possible categories for RoB item 7. |
cat8 |
Possible categories for RoB item 8. |
cat9 |
Possible categories for RoB item 9. |
cat10 |
Possible categories for RoB item 10. |
cat.overall |
Possible categories for overall RoB. |
col |
Colours for RoB categories. |
col1 |
Colours for categories for RoB item 1. |
col2 |
Colours for categories for RoB item 2. |
col3 |
Colours for categories for RoB item 3. |
col4 |
Colours for categories for RoB item 4. |
col5 |
Colours for categories for RoB item 5. |
col6 |
Colours for categories for RoB item 6. |
col7 |
Colours for categories for RoB item 7. |
col8 |
Colours for categories for RoB item 8. |
col9 |
Colours for categories for RoB item 9. |
col10 |
Colours for categories for RoB item 10. |
col.overall |
Colours for categories for overall RoB. |
symbols |
Corresponding symbols for RoB categories. |
symb1 |
Corresponding symbols for RoB item 1. |
symb2 |
Corresponding symbols for RoB item 2. |
symb3 |
Corresponding symbols for RoB item 3. |
symb4 |
Corresponding symbols for RoB item 4. |
symb5 |
Corresponding symbols for RoB item 5. |
symb6 |
Corresponding symbols for RoB item 6. |
symb7 |
Corresponding symbols for RoB item 7. |
symb8 |
Corresponding symbols for RoB item 8. |
symb9 |
Corresponding symbols for RoB item 9. |
symb10 |
Corresponding symbols for RoB item 10. |
symb.overall |
Corresponding symbols for overall RoB. |
legend |
A logical specifying whether legend with RoB domains should be printed. |
overwrite |
A logical indicating whether an existing risk of bias table in a meta-analysis object should be overwritten. |
warn |
A logical indicating whether warnings should be printed. |
x |
An object of class |
details |
A logical indicating whether to print details on categories and colours. |
... |
Additional printing arguments. |
This function can be used to define a risk of bias (RoB) assessment
for a meta-analysis which can be shown in a forest plot
(forest.meta
), summary weighted barplot
(barplot.rob
) or traffic light plot
(traffic_light
). It is also possible to extract the
risk of bias assessment from a meta-analysis with RoB information.
The risk of bias table contains
study labels;
variables for individual RoB domains (with variable names A, B, ...);
an overall RoB assessment if argument overall
is
provided;
weights for individual studies used in summary weighted barplots.
Note, an overall RoB assessment is mandatory to create a summary weighted barplot or a traffic light plot.
The RoB table is directly returned if argument data
is a
data frame or argument item1
is a meta-analysis with risk of
bias assessment. The RoB table is added as a new list element 'rob'
to a meta-analysis object if argument data
is a
meta-analysis.
The user must either specify the categories and (optionally) domains of the RoB tool (using the eponymous arguments) or one of the following RoB tools.
Argument | Risk of bias tool |
tool = "RoB1" |
RoB 1 tool for randomized studies (Higgins et al., 2011) |
tool = "RoB2" |
RoB 2 tool for randomized studies (Sterne et al., 2019) |
tool = "RoB2-cluster" |
RoB 2 tool for cluster-randomized trials |
tool = "RoB2-crossover" |
RoB 2 tool for crossover trials |
tool = "ROBINS-I" |
Risk Of Bias In Non-randomized Studies - of Interventions |
(Sterne et al., 2016) | |
tool = "ROBINS-E" |
Risk Of Bias In Non-randomized Studies - of Exposures |
(ROBINS-E Development Group, 2023) |
These RoB tools are described on the website https://www.riskofbias.info/.
By default, i.e., if argument domains
is not provided by the
user, the following names are used for RoB domains.
RoB 1 tool for randomized studies (RoB1):
Random sequence generation (selection bias)
Allocation concealment (selection bias)
Blinding of participants and personnel (performance bias)
Blinding of outcome assessment (detection bias)
Incomplete outcome data (attrition bias)
Selective reporting (reporting bias)
Other bias
RoB 2 tool for randomized studies (RoB2):
Bias arising from the randomization process
Bias due to deviations from intended intervention"
Bias due to missing outcome data
Bias in measurement of the outcome
Bias in selection of the reported result
RoB 2 tool for cluster-randomized trials (RoB2-cluster):
Bias arising from the randomization process
Bias arising from the identification or recruitment of participants into clusters
Bias due to deviations from intended intervention
Bias due to missing outcome data
Bias in measurement of the outcome
Bias in selection of the reported result
RoB 2 tool for crossover trials (RoB2-crossover)
Bias arising from the randomization process
Bias arising from period and carryover effects
Bias due to deviations from intended intervention
Bias due to missing outcome data
Bias in measurement of the outcome
Bias in selection of the reported result
Risk Of Bias In Non-randomized Studies - of Intervention (ROBINS-I):
Risk of bias due to confounding
Risk of bias in selection of participants into the study
Risk of bias in classification of interventions
Risk of bias due to deviations from intented interventions
Risk of bias due to missing outcome data
Risk of bias in measurement of the outcome
Risk of bias in the selection of the reported results
Risk Of Bias In Non-randomized Studies - of Exposures (ROBINS-E):
Risk of bias due to confounding
Risk of bias arising from measurement of the exposure into the study (or into the analysis)
Risk of bias due to post-exposure interventions
Risk of bias due to deviations from intented interventions
Risk of bias due to missing outcome data
Risk of bias in measurement of the outcome
Risk of bias in the selection of the reported results
User-defined RoB assessment:
First item
Second item
...
It is possible to define additional bias domains for the available
RoB tools. In this case, only the names for new RoB domains have to
be provided in argument domains
. If argument domains
is not used to specify new domains, the names "Additional item 1"
etc. will be used. It is also possible to modify the pre-defined
domain names using argument domains
.
The maximum number of bias domains / items is ten (see arguments
item1
, ..., item10
).
By default, the following settings are used.
RoB 1 tool:
Argument | Values |
categories |
"Low risk of bias", "Unclear risk of bias", "High risk of bias" |
col |
"green", "yellow", "red" |
symbols |
"+", "?", "-" |
RoB 2 tools:
Argument | Values |
categories |
"Low risk of bias", "Some concerns", "High risk of bias" |
col |
"green", "yellow", "red" |
symbols |
"+", "?", "-" |
ROBINS tools:
Argument | Values |
categories |
"Low risk", "Some concerns", "High risk", "Very high risk", "NI" |
col |
"green", "yellow", "red", "darkred", "darkgrey" |
symbols |
none |
User-defined RoB tools:
Argument | Values |
categories |
Must be specified by the user |
col |
1, 2, ... |
symbols |
none |
If colours (col
) and symbols (symbols
) are provided,
they must be of the same length as the number of categories.
A data frame with study labels and risk of bias items and additional class "rob".
Guido Schwarzer [email protected]
Higgins JPT, Altman DG, Gøtzsche PC, Jüni P, Moher D, Oxman AD et al. (2011): The Cochrane Collaboration's tool for assessing risk of bias in randomised trials. British Medical Journal, 343: d5928
ROBINS-E Development Group (Higgins J, Morgan R, Rooney A et al.) (2023): Risk Of Bias In Non-randomized Studies - of Exposure (ROBINS-E) Available from: https://www.riskofbias.info/welcome/robins-e-tool.
Sterne JA, Hernán MA, Reeves BC, Savović J, Berkman ND, Viswanathan M, et al. (2016): ROBINS-I: a tool for assessing risk of bias in non-randomised studies of interventions. British Medical Journal, 355: i4919
Sterne JAC, Savović J, Page MJ, Elbers RG, Blencowe NS, Boutron I, et al. (2019): RoB 2: a revised tool for assessing risk of bias in randomised trials. British Medical Journal, 366: l4898.
forest.meta
, barplot.rob
,
traffic_light
# Use RevMan 5 settings oldset <- settings.meta("RevMan5", quietly = FALSE) data(caffeine) m1 <- metabin(h.caf, n.caf, h.decaf, n.decaf, sm = "OR", data = caffeine, studlab = paste(study, year)) # Add risk of bias assessment to meta-analysis m2 <- rob(D1, D2, D3, D4, D5, overall = rob, data = m1, tool = "rob2") # Print risk of bias assessment rob(m2) # Forest plot with risk of bias assessment forest(m2) # Use previous settings settings.meta(oldset)
# Use RevMan 5 settings oldset <- settings.meta("RevMan5", quietly = FALSE) data(caffeine) m1 <- metabin(h.caf, n.caf, h.decaf, n.decaf, sm = "OR", data = caffeine, studlab = paste(study, year)) # Add risk of bias assessment to meta-analysis m2 <- rob(D1, D2, D3, D4, D5, overall = rob, data = m1, tool = "rob2") # Print risk of bias assessment rob(m2) # Forest plot with risk of bias assessment forest(m2) # Use previous settings settings.meta(oldset)
Print and change default settings to conduct and print or plot meta-analyses in R package meta. The following general settings are available: Review Manager 5, Journal of the American Medical Association.
settings.meta(..., quietly = TRUE)
settings.meta(..., quietly = TRUE)
... |
Arguments to change default settings. |
quietly |
A logical indicating whether information on settings should be printed. |
This function can be used to define defaults for several arguments
(i.e., assignments using gs
) of the following R
functions: metabin
, metacont
,
metacor
, metacr
, metagen
,
metainc
, metaprop
,
metarate
Furthermore, some of these settings are considered to print meta-analysis results and to produce forest plots.
The function can be used to either change individual settings (see Examples) or use one of the following general settings:
settings.meta("RevMan5")
settings.meta("BMJ")
settings.meta("JAMA")
settings.meta("IQWiG5")
settings.meta("IQWiG6")
settings.meta("geneexpr")
settings.meta("meta4")
settings.meta("meta7")
The first command can be used to reproduce meta-analyses from Cochrane reviews conducted with Review Manager 5 (RevMan 5) and specifies to use a RevMan 5 layout in forest plots.
The second command can be used to generate forest plots in BMJ layout.
The third command can be used to generate forest plots following
instructions for authors of the Journal of the American
Medical Association
(https://jamanetwork.com/journals/jama/pages/instructions-for-authors/).
Study labels according to JAMA guidelines can be generated using
labels.meta
.
The next commands implement the recommendations of the Institute for Quality and Efficiency in Health Care, Germany (IQWiG) accordinging to General Methods 5 and 6, respectively (https://www.iqwig.de/en/about-us/methods/methods-paper/).
The setting "geneexpr"
can be used to print p-values in
scientific notation and to suppress the calculation of confidence
intervals for the between-study variance.
The last settings use the default settings of R package meta, version 4 and 7.0-0, respectively, or below.
RevMan 5 settings, in detail:
Argument | Value | Comment |
method.random.ci |
"classic" | only available method in RevMan 5 |
method.tau |
"DL" | only available method in RevMan 5 |
method.I2 |
"Q" | only available method in RevMan 5 |
tau.common |
FALSE | common between-study variance in subgroups |
MH.exact |
FALSE | exact Mantel-Haenszel method |
RR.Cochrane |
TRUE | calculation of risk ratios |
Q.Cochrane |
TRUE | calculation of heterogeneity statistic |
exact.smd |
FALSE | exact formulae for Hedges' g and Cohen's d |
layout |
"RevMan5" | layout for forest plots |
prediction |
FALSE | no prediction interval |
test.overall |
TRUE | print information on test of overall effect |
test.subgroup |
TRUE | print information on test for subgroup differences |
test.effect.subgroup |
TRUE | print information on test for effect in subgroups |
forest.I2 |
TRUE | show heterogeneity statistic I2 in forest plots |
forest.tau2 |
TRUE | show between-study heterogeneity |
variance in forest plots | ||
forest.tau |
FALSE | do not show between-study heterogeneity |
standard deviation in forest plots | ||
forest.Q |
TRUE | show heterogeneity statistic Q in forest plots |
forest.pval.Q |
TRUE | show p-value of test for heterogeneity in forest plots |
forest.Rb |
FALSE | do not show heterogeneity statistic Rb in forest plots |
digits.tau2 |
3 | number of digits for tau-squared |
digits.tau |
4 | number of digits for square root of tau-squared |
digits.I2 |
0 | number of digits for I-squared measure |
CIbracket , |
"[" | |
CIseparator |
", " | print confidence intervals as
"[., .] " |
header.line , |
TRUE | print header line |
BMJ settings:
Argument | Value | Comment |
layout |
"BMJ" | layout for forest plots |
test.overall |
TRUE | print information on test of overall effect |
test.subgroup |
FALSE | print information on test for subgroup differences |
test.effect.subgroup |
FALSE | print information on test for effect in subgroups |
forest.I2 |
TRUE | show heterogeneity statistic I2 in forest plots |
forest.tau2 |
TRUE | show between-study heterogeneity |
variance in forest plots | ||
forest.tau |
FALSE | do not show between-study heterogeneity |
standard deviation in forest plots | ||
forest.Q |
TRUE | show heterogeneity statistic Q in forest plots |
forest.pval.Q |
TRUE | show p-value of test for heterogeneity in forest plots |
forest.Rb |
FALSE | do not show heterogeneity statistic Rb in forest plots |
digits.I2 |
0 | number of digits for I-squared measure |
digits.pval |
2 | number of digits for p-values |
CIbracket , |
"(" | |
CIseparator |
" to " | print confidence intervals as
"(. to .) " |
hetlab , |
"Test for heterogeneity: " | |
header.line , |
TRUE | print header line |
JAMA settings:
Argument | Value | Comment |
layout |
"JAMA" | layout for forest plots |
test.overall |
TRUE | print information on test of overall effect |
test.subgroup |
FALSE | print information on test for subgroup differences |
test.effect.subgroup |
FALSE | print information on test for effect in subgroups |
forest.I2 |
TRUE | show heterogeneity statistic I2 in forest plots |
forest.tau2 |
FALSE | do not show between-study heterogeneity |
variance in forest plots | ||
forest.tau |
FALSE | do not show between-study heterogeneity |
standard deviation in forest plots | ||
forest.Q |
TRUE | show heterogeneity statistic Q in forest plots |
forest.pval.Q |
TRUE | show p-value of test for heterogeneity in forest plots |
forest.Rb |
FALSE | do not show heterogeneity statistic Rb in forest plots |
digits.I2 |
0 | number of digits for I-squared measure |
digits.pval |
3 | number of digits for p-values |
CIbracket , |
"(" | |
CIseparator |
"-" | print confidence intervals as
"(.-.) " |
zero.pval , |
FALSE | print p-values with leading zero |
JAMA.pval , |
TRUE | round p-values to three digits
(for 0.001 < p 0.01) |
or two digits (p > 0.01) | ||
header.line , |
TRUE | print header line |
IQWiG, General Methods 5 settings:
Argument | Value | Comment |
method.random.ci |
"HK" | Hartung-Knapp method |
prediction |
TRUE | Prediction interval |
IQWiG, General Methods 6 settings:
Argument | Value | Comment |
method.random.ci |
"HK" | Hartung-Knapp method |
adhoc.hakn.ci |
"IQWiG6" | ad hoc variance correction |
method.tau |
"PM" | Paule-Mandel estimator for between-study variance |
prediction |
TRUE | Prediction interval |
Settings for gene expression data:
Argument | Value | Comment |
scientific.pval |
TRUE | Scientific notation for p-values |
method.tau.ci |
FALSE | no confidence interval for between-study |
heterogeneity variance | ||
Settings for meta, version 4 or below:
Argument | Value | Comment |
method.tau |
"DL" | DerSimonian-Laird estimator |
method.I2 |
"Q" | Use Q to calculate I-squared |
method.predict |
"HTS" | prediction interval with k-2 degrees |
of freedom | ||
exact.smd |
FALSE | Use exact formula for standardised mean |
difference (White and Thomas, 2005) | ||
text.common |
"Fixed effect model" | |
text.w.common |
"fixed" | |
warn.deprecated |
FALSE | Do not print warnings for deprecated |
arguments |
Settings for meta, version 7.0-0 or below:
Argument | Value | Comment |
method.tau |
"REML" | REML estimator |
method.I2 |
"Q" | Use Q to calculate I-squared |
method.predict |
"HTS" | prediction interval with k-2 degrees |
of freedom | ||
exact.smd |
TRUE | Use exact formula for standardised mean |
difference (White and Thomas, 2005) | ||
text.common |
"Common effect model" | |
text.w.common |
"common" | |
warn.deprecated |
FALSE | Do not print warnings for deprecated |
arguments |
A list of all arguments with current settings is printed using the
command settings.meta()
.
In order to reset all settings of R package meta the command
settings.meta(reset = TRUE)
can be used.
Guido Schwarzer [email protected]
White IR, Thomas J (2005): Standardized mean differences in individually-randomized and cluster-randomized trials, with applications to meta-analysis. Clinical Trials, 2, 141–51
gs
, forest.meta
,
print.meta
, labels.meta
# Get listing of current settings # settings.meta() # Meta-analyses using default settings # metabin(10, 20, 15, 20) metaprop(4, 20) metabin(10, 20, 15, 20, sm = "RD") metaprop(4, 20, sm = "PLN") # Change summary measure for R functions metabin and metaprop # and store old settings # oldset <- settings.meta(smbin = "RD", smprop = "PLN") # metabin(10, 20, 15, 20) metaprop(4, 20) # Use old settings # settings.meta(oldset) # Change level used to calculate confidence intervals # (99%-CI for studies, 99.9%-CI for pooled effects) # metagen(1:3, 2:4 / 10, sm = "MD") settings.meta(level = 0.99, level.ma = 0.999) metagen(1:3, 2:4 / 10, sm = "MD") # Always print a prediction interval # settings.meta(prediction = TRUE) metagen(1:3, 2:4 / 10, sm = "MD") metagen(4:6, 4:2 / 10, sm = "MD") # Try to set unknown argument results in a warning # try(settings.meta(unknownarg = TRUE)) # Reset to default settings of R package meta # settings.meta("reset") metabin(10, 20, 15, 20) metaprop(4, 20) metagen(1:3, 2:4 / 10, sm = "MD") # Do not back transform results (e.g. print log odds ratios instead # of odds ratios, print transformed correlations / proportions # instead of correlations / proportions) # settings.meta(backtransf = FALSE) metabin(10, 20, 15, 20) metaprop(4, 20) metacor(c(0.85, 0.7, 0.95), c(20, 40, 10)) # Forest plot using RevMan 5 style # settings.meta("RevMan5") forest(metagen(1:3, 2:4 / 10, sm = "MD", common = FALSE), label.left = "Favours A", label.right = "Favours B", colgap.studlab = "2cm", colgap.forest.left = "0.2cm") # Forest plot using JAMA style # settings.meta("JAMA") forest(metagen(1:3, 2:4 / 10, sm = "MD", common = FALSE), label.left = "Favours A", label.right = "Favours B", colgap.studlab = "2cm", colgap.forest.left = "0.2cm") # Use slightly different layout for confidence intervals # (especially useful if upper confidence limit can be negative) # settings.meta(CIseparator = " - ") forest(metagen(-(1:3), 2:4 / 10, sm = "MD", common = FALSE), label.left = "Favours A", label.right = "Favours B", colgap.studlab = "2cm", colgap.forest.left = "0.2cm") # Use old settings # settings.meta(oldset)
# Get listing of current settings # settings.meta() # Meta-analyses using default settings # metabin(10, 20, 15, 20) metaprop(4, 20) metabin(10, 20, 15, 20, sm = "RD") metaprop(4, 20, sm = "PLN") # Change summary measure for R functions metabin and metaprop # and store old settings # oldset <- settings.meta(smbin = "RD", smprop = "PLN") # metabin(10, 20, 15, 20) metaprop(4, 20) # Use old settings # settings.meta(oldset) # Change level used to calculate confidence intervals # (99%-CI for studies, 99.9%-CI for pooled effects) # metagen(1:3, 2:4 / 10, sm = "MD") settings.meta(level = 0.99, level.ma = 0.999) metagen(1:3, 2:4 / 10, sm = "MD") # Always print a prediction interval # settings.meta(prediction = TRUE) metagen(1:3, 2:4 / 10, sm = "MD") metagen(4:6, 4:2 / 10, sm = "MD") # Try to set unknown argument results in a warning # try(settings.meta(unknownarg = TRUE)) # Reset to default settings of R package meta # settings.meta("reset") metabin(10, 20, 15, 20) metaprop(4, 20) metagen(1:3, 2:4 / 10, sm = "MD") # Do not back transform results (e.g. print log odds ratios instead # of odds ratios, print transformed correlations / proportions # instead of correlations / proportions) # settings.meta(backtransf = FALSE) metabin(10, 20, 15, 20) metaprop(4, 20) metacor(c(0.85, 0.7, 0.95), c(20, 40, 10)) # Forest plot using RevMan 5 style # settings.meta("RevMan5") forest(metagen(1:3, 2:4 / 10, sm = "MD", common = FALSE), label.left = "Favours A", label.right = "Favours B", colgap.studlab = "2cm", colgap.forest.left = "0.2cm") # Forest plot using JAMA style # settings.meta("JAMA") forest(metagen(1:3, 2:4 / 10, sm = "MD", common = FALSE), label.left = "Favours A", label.right = "Favours B", colgap.studlab = "2cm", colgap.forest.left = "0.2cm") # Use slightly different layout for confidence intervals # (especially useful if upper confidence limit can be negative) # settings.meta(CIseparator = " - ") forest(metagen(-(1:3), 2:4 / 10, sm = "MD", common = FALSE), label.left = "Favours A", label.right = "Favours B", colgap.studlab = "2cm", colgap.forest.left = "0.2cm") # Use old settings # settings.meta(oldset)
Conversion from standardised mean difference to log odds ratio using method by Hasselblad & Hedges (1995) or Cox (1970).
smd2or( smd, se.smd, studlab, data = NULL, subset = NULL, exclude = NULL, method = "HH", backtransf = gs("backtransf"), ... )
smd2or( smd, se.smd, studlab, data = NULL, subset = NULL, exclude = NULL, method = "HH", backtransf = gs("backtransf"), ... )
smd |
Standardised mean difference(s) (SMD) or meta-analysis object. |
se.smd |
Standard error(s) of SMD (ignored if argument
|
studlab |
An optional vector with study labels (ignored if
argument |
data |
An optional data frame containing the study information
(ignored if argument |
subset |
An optional vector specifying a subset of studies to
be used (ignored if argument |
exclude |
An optional vector specifying studies to exclude
from meta-analysis, however, to include in printouts and forest
plots (ignored if argument |
method |
A character string indicating which method is used to
convert SMDs to log odds ratios. Either |
backtransf |
A logical indicating whether odds ratios (if TRUE) or log odds ratios (if FALSE) should be shown in printouts and plots. |
... |
Additional arguments passed on to
|
This function implements the following methods for the conversion from standardised mean difference to log odds ratio:
Hasselblad & Hedges (1995) assuming logistic distributions
(method == "HH"
)
Cox (1970) and Cox & Snell (1989) assuming normal
distributions (method == "CS"
)
Internally, metagen
is used to conduct a
meta-analysis with the odds ratio as summary measure.
Argument smd
can be either a vector of standardised mean
differences or a meta-analysis object created with
metacont
or metagen
and the
standardised mean difference as summary measure.
Argument se.smd
is mandatory if argument smd
is a
vector and ignored otherwise. Additional arguments in ...
are only passed on to metagen
if argument smd
is a vector.
An object of class c("metagen", "meta")
with corresponding
generic functions (see meta-object
).
Guido Schwarzer [email protected]
Borenstein M, Hedges LV, Higgins JPT, Rothstein HR (2009): Introduction to Meta-Analysis. Chichester: Wiley
Cox DR (1970): Analysis of Binary Data. London: Chapman and Hall / CRC
Cox DR, Snell EJ (1989): Analysis of Binary Data (2nd edition). London: Chapman and Hall / CRC
Hasselblad V, Hedges LV (1995): Meta-analysis of screening and diagnostic tests. Psychological Bulletin, 117, 167–78
or2smd
, metacont
,
metagen
, metabin
# Example from Borenstein et al. (2009), Chapter 7 # mb <- smd2or(0.5, sqrt(0.0205), backtransf = FALSE) # TE = log odds ratio; seTE = standard error of log odds ratio data.frame(lnOR = round(mb$TE, 4), varlnOR = round(mb$seTE^2, 4)) # Use dataset from Fleiss (1993) # data(Fleiss1993cont) m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD", studlab = paste(study, year)) smd2or(m1)
# Example from Borenstein et al. (2009), Chapter 7 # mb <- smd2or(0.5, sqrt(0.0205), backtransf = FALSE) # TE = log odds ratio; seTE = standard error of log odds ratio data.frame(lnOR = round(mb$TE, 4), varlnOR = round(mb$seTE^2, 4)) # Use dataset from Fleiss (1993) # data(Fleiss1993cont) m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, sm = "SMD", studlab = paste(study, year)) smd2or(m1)
Meta-analyses on the effect of smoking on mortality risk.
A data frame with the following columns:
study | study label |
participants | total number of participants |
d.smokers | number of deaths in smokers' group |
py.smokers | person years at risk in smokers' group |
d.nonsmokers | number of deaths in non-smokers' group |
py.nonsmokers | person years at risk in non-smokers' group |
Data have been reconstructed based on the famous Smoking and Health
Report to the Surgeon General (Bayne-Jones S et al., 1964). Data
sets can be used to evaluate the risk of smoking on overall
mortality (dataset smoking
) and lung-cancer deaths (dataset
lungcancer
), respectively.
The person time is attributed such that the rate ratios are equal to the reported mortality ratios implicitly assuming that the data have arisen from a homogeneous age group; more detailed information by age is not available from the report. Note, the group of "non-smokers" actually consists of all participants except those who are smokers of cigarettes only. Information on real non-smokers is not available from the published Smoking and Health Report.
Bayne-Jones S et al. (1964): Smoking and Health: Report of the Advisory Committee to the Surgeon General of the United States. U-23 Department of Health, Education, and Welfare. Public Health Service Publication No. 1103.
data(smoking) m1 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = smoking, studlab = study) print(m1, digits = 2) data(lungcancer) m2 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = lungcancer, studlab = study) print(m2, digits = 2)
data(smoking) m1 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = smoking, studlab = study) print(m1, digits = 2) data(lungcancer) m2 <- metainc(d.smokers, py.smokers, d.nonsmokers, py.nonsmokers, data = lungcancer, studlab = study) print(m2, digits = 2)
The subset
method returns a subset of a longarm object.
## S3 method for class 'longarm' subset(x, subset, ...)
## S3 method for class 'longarm' subset(x, subset, ...)
x |
An object of class |
subset |
A logical expression indicating elements or rows to keep: missing values are taken as false. |
... |
Additional arguments. |
A longarm
object is returned.
Guido Schwarzer [email protected]
# Artificial example with three studies m <- metabin(1:3, 100:102, 4:6, 200:202, studlab = LETTERS[1:3]) # Transform data to long arm-based format l1 <- longarm(m) l1 # Subset without Study B subset(l1, studlab != "B")
# Artificial example with three studies m <- metabin(1:3, 100:102, 4:6, 200:202, studlab = LETTERS[1:3]) # Transform data to long arm-based format l1 <- longarm(m) l1 # Subset without Study B subset(l1, studlab != "B")
The subset
method returns a subset of a pairwise object.
## S3 method for class 'pairwise' subset(x, subset, ...)
## S3 method for class 'pairwise' subset(x, subset, ...)
x |
An object of class |
subset |
A logical expression indicating rows to keep; missing values are taken as false. |
... |
Additional arguments. |
A pairwise object is returned.
Guido Schwarzer [email protected]
# Transform data from arm-based format to contrast-based format p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = dat.franchini2012, studlab = Study) # Subset without Lieberman studies subset(p1, !grepl("Lieberman", studlab))[, 1:5]
# Transform data from arm-based format to contrast-based format p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = dat.franchini2012, studlab = Study) # Subset without Lieberman studies subset(p1, !grepl("Lieberman", studlab))[, 1:5]
Summary method for objects of class meta
.
## S3 method for class 'meta' summary(object, ...)
## S3 method for class 'meta' summary(object, ...)
object |
An object of class |
... |
Additional arguments (ignored). |
Summary method for objects of class meta
.
An object of classes summary.meta
and meta
(see
meta-object
.
Guido Schwarzer [email protected]
Cooper H & Hedges LV (1994): The Handbook of Research Synthesis. Newbury Park, CA: Russell Sage Foundation
Crippa A, Khudyakov P, Wang M, Orsini N, Spiegelman D (2016): A new measure of between-studies heterogeneity in meta-analysis. Statistics in Medicine, 35, 3661–75
Higgins JPT & Thompson SG (2002): Quantifying heterogeneity in a meta-analysis. Statistics in Medicine, 21, 1539–58
print.summary.meta
, metabin
,
metacont
, metagen
data(Fleiss1993cont) m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, studlab = paste(study, year), sm = "SMD") summary(m1) summary(update(m1, subgroup = c(1, 2, 1, 1, 2), subgroup.name = "group")) forest(update(m1, subgroup = c(1, 2, 1, 1, 2), subgroup.name = "group")) ## Not run: # Use unicode characters to print tau^2, tau, and I^2 print(summary(m1), text.tau2 = "\u03c4\u00b2", text.tau = "\u03c4", text.I2 = "I\u00b2") ## End(Not run)
data(Fleiss1993cont) m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, studlab = paste(study, year), sm = "SMD") summary(m1) summary(update(m1, subgroup = c(1, 2, 1, 1, 2), subgroup.name = "group")) forest(update(m1, subgroup = c(1, 2, 1, 1, 2), subgroup.name = "group")) ## Not run: # Use unicode characters to print tau^2, tau, and I^2 print(summary(m1), text.tau2 = "\u03c4\u00b2", text.tau = "\u03c4", text.I2 = "I\u00b2") ## End(Not run)
Calculate and print a detailed summary of all meta-analyses in a Cochrane review.
## S3 method for class 'rm5' summary(object, comp.no, outcome.no, ...) ## S3 method for class 'cdir' summary(object, comp.no, outcome.no, ...) ## S3 method for class 'summary.rm5' print(x, ...) ## S3 method for class 'summary.cdir' print(x, ...)
## S3 method for class 'rm5' summary(object, comp.no, outcome.no, ...) ## S3 method for class 'cdir' summary(object, comp.no, outcome.no, ...) ## S3 method for class 'summary.rm5' print(x, ...) ## S3 method for class 'summary.cdir' print(x, ...)
object |
An object of class |
comp.no |
Comparison number. |
outcome.no |
Outcome number. |
... |
Additional arguments (passed on to |
x |
An object of class |
This function can be used to rerun all or selected meta-analyses of a Cochrane Review of interventions (Higgins et al., 2023).
The R function metacr
is called internally.
Guido Schwarzer [email protected]
Higgins JPT, Thomas J, Chandler J, Cumpston M, Li T, Page MJ, Welch VA (editors) (2023): Cochrane Handbook for Systematic Reviews of Interventions Version 6.4 (updated August 2023). Available from https://training.cochrane.org/handbook/
summary.meta
, metacr
,
read.rm5
, read.cdir
,
metabias.rm5
, metabias.cdir
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Print summary results for all meta-analysis # summary(Fleiss1993_CR) # Print summary results only for second outcome of first comparison # summary(Fleiss1993_CR, comp.no = 1, outcome.no = 2)
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Print summary results for all meta-analysis # summary(Fleiss1993_CR) # Print summary results only for second outcome of first comparison # summary(Fleiss1993_CR, comp.no = 1, outcome.no = 2)
Produce traffic light plot of risk of bias assessment
traffic_light(object, colour = "cochrane", psize = 15, quiet = FALSE)
traffic_light(object, colour = "cochrane", psize = 15, quiet = FALSE)
object |
An object of class |
colour |
Specify colour scheme for the traffic light plot; see
|
psize |
Size of the traffic lights. |
quiet |
A logical to suppress the display of the traffic light plot. |
This is a wrapper function for
rob_traffic_light
of R package robvis
to produce a traffic light plot of risk of bias assessment.
Guido Schwarzer [email protected]
rob
, barplot.rob
,
rob_traffic_light
# Use RevMan 5 settings oldset <- settings.meta("RevMan5") data(caffeine) m1 <- metabin(h.caf, n.caf, h.decaf, n.decaf, sm = "OR", data = caffeine, studlab = paste(study, year)) # Add risk of bias assessment to meta-analysis m2 <- rob(D1, D2, D3, D4, D5, overall = rob, data = m1, tool = "rob2") # Print risk of bias assessment rob(m2) ## Not run: # Traffic light plot (if R package robvis has been installed) traffic_light(rob(m2)) ## End(Not run) # Use previous settings settings.meta(oldset)
# Use RevMan 5 settings oldset <- settings.meta("RevMan5") data(caffeine) m1 <- metabin(h.caf, n.caf, h.decaf, n.decaf, sm = "OR", data = caffeine, studlab = paste(study, year)) # Add risk of bias assessment to meta-analysis m2 <- rob(D1, D2, D3, D4, D5, overall = rob, data = m1, tool = "rob2") # Print risk of bias assessment rob(m2) ## Not run: # Traffic light plot (if R package robvis has been installed) traffic_light(rob(m2)) ## End(Not run) # Use previous settings settings.meta(oldset)
Trim-and-fill method for estimating and adjusting for the number and outcomes of missing studies in a meta-analysis.
## S3 method for class 'meta' trimfill( x, left = NULL, ma.common = TRUE, type = "L", n.iter.max = 50, common = FALSE, random = TRUE, prediction = x$prediction, backtransf = x$backtransf, pscale = x$pscale, irscale = x$irscale, irunit = x$irunit, silent = TRUE, warn.deprecated = gs("warn.deprecated"), ... ) ## Default S3 method: trimfill( x, seTE, left = NULL, ma.common = TRUE, type = "L", n.iter.max = 50, sm = "", studlab = NULL, level = 0.95, level.ma = level, common = FALSE, random = TRUE, method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), method.tau = gs("method.tau"), method.tau.ci = if (method.tau == "DL") "J" else "QP", level.hetstat = gs("level.hetstat"), prediction = FALSE, level.predict = level, method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, backtransf = TRUE, pscale = 1, irscale = 1, irunit = "person-years", silent = TRUE, ... )
## S3 method for class 'meta' trimfill( x, left = NULL, ma.common = TRUE, type = "L", n.iter.max = 50, common = FALSE, random = TRUE, prediction = x$prediction, backtransf = x$backtransf, pscale = x$pscale, irscale = x$irscale, irunit = x$irunit, silent = TRUE, warn.deprecated = gs("warn.deprecated"), ... ) ## Default S3 method: trimfill( x, seTE, left = NULL, ma.common = TRUE, type = "L", n.iter.max = 50, sm = "", studlab = NULL, level = 0.95, level.ma = level, common = FALSE, random = TRUE, method.random.ci = gs("method.random.ci"), adhoc.hakn.ci = gs("adhoc.hakn.ci"), method.tau = gs("method.tau"), method.tau.ci = if (method.tau == "DL") "J" else "QP", level.hetstat = gs("level.hetstat"), prediction = FALSE, level.predict = level, method.predict = gs("method.predict"), adhoc.hakn.pi = gs("adhoc.hakn.pi"), seed.predict = NULL, backtransf = TRUE, pscale = 1, irscale = 1, irunit = "person-years", silent = TRUE, ... )
x |
An object of class |
left |
A logical indicating whether studies are supposed to be
missing on the left or right side of the funnel plot. If NULL,
the linear regression test for funnel plot symmetry (i.e.,
function |
ma.common |
A logical indicating whether a common effect or random effects model is used to estimate the number of missing studies. |
type |
A character indicating which method is used to estimate
the number of missing studies. Either |
n.iter.max |
Maximum number of iterations to estimate number of missing studies. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
prediction |
A logical indicating whether a prediction interval should be printed. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and plots. If
|
pscale |
A numeric giving scaling factor for printing of
single event probabilities or risk differences, i.e. if argument
|
irscale |
A numeric defining a scaling factor for printing of
single incidence rates or incidence rate differences, i.e. if
argument |
irunit |
A character specifying the time unit used to calculate rates, e.g. person-years. |
silent |
A logical indicating whether basic information on iterations shown. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
seTE |
Standard error of estimated treatment effect. |
sm |
An optional character string indicating underlying
summary measure, e.g., |
studlab |
An optional vector with study labels; ignored if
|
level |
The level used to calculate confidence intervals for
individual studies. If existing, |
level.ma |
The level used to calculate confidence interval for
the pooled estimate. If existing, |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
level.predict |
The level used to calculate prediction interval for a new study. |
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for the
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
The trim-and-fill method (Duval, Tweedie 2000a, 2000b) can be used for estimating and adjusting for the number and outcomes of missing studies in a meta-analysis. The method relies on scrutiny of one side of a funnel plot for asymmetry assumed due to publication bias.
Three different methods have been proposed originally to estimate
the number of missing studies. Two of these methods (L- and
R-estimator) have been shown to perform better in simulations, and
are available in this R function (argument type
).
A common effect or random effects model can be used to estimate the
number of missing studies (argument ma.common
). Furthermore,
a common effect and/or random effects model can be used to
summaries study results (arguments common
and
random
). Simulation results (Peters et al. 2007) indicate
that the common-random model, i.e. using a common effect model to
estimate the number of missing studies and a random effects model
to summaries results, (i) performs better than the common-common
model, and (ii) performs no worse than and marginally better in
certain situations than the random-random model. Accordingly, the
common-random model is the default.
An empirical comparison of the trim-and-fill method and the Copas selection model (Schwarzer et al. 2010) indicates that the trim-and-fill method leads to excessively conservative inference in practice. The Copas selection model is available in R package metasens.
The function metagen
is called internally.
An object of class c("trimfill", "metagen", "meta")
with
corresponding generic functions (see meta-object
).
Guido Schwarzer [email protected]
Duval S & Tweedie R (2000a): A nonparametric "Trim and Fill" method of accounting for publication bias in meta-analysis. Journal of the American Statistical Association, 95, 89–98
Duval S & Tweedie R (2000b): Trim and Fill: A simple funnel-plot-based method of testing and adjusting for publication bias in meta-analysis. Biometrics, 56, 455–63
Peters JL, Sutton AJ, Jones DR, Abrams KR, Rushton L (2007): Performance of the trim and fill method in the presence of publication bias and between-study heterogeneity. Statisics in Medicine, 10, 4544–62
Schwarzer G, Carpenter J, Rücker G (2010): Empirical evaluation suggests Copas selection model preferable to trim-and-fill method for selection bias in meta-analysis Journal of Clinical Epidemiology, 63, 282–8
data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, sm = "OR") tf1 <- trimfill(m1) tf1 funnel(tf1) funnel(tf1, pch = ifelse(tf1$trimfill, 1, 16), level = 0.9, random = FALSE) # # Use log odds ratios on x-axis # funnel(tf1, backtransf = FALSE) funnel(tf1, pch = ifelse(tf1$trimfill, 1, 16), level = 0.9, random = FALSE, backtransf = FALSE) trimfill(m1$TE, m1$seTE, sm = m1$sm)
data(Fleiss1993bin) m1 <- metabin(d.asp, n.asp, d.plac, n.plac, data = Fleiss1993bin, sm = "OR") tf1 <- trimfill(m1) tf1 funnel(tf1) funnel(tf1, pch = ifelse(tf1$trimfill, 1, 16), level = 0.9, random = FALSE) # # Use log odds ratios on x-axis # funnel(tf1, backtransf = FALSE) funnel(tf1, pch = ifelse(tf1$trimfill, 1, 16), level = 0.9, random = FALSE, backtransf = FALSE) trimfill(m1$TE, m1$seTE, sm = m1$sm)
Conduct trim-and-fill analysis for all meta-analyses in a Cochrane review.
## S3 method for class 'rm5' trimfill(x, comp.no, outcome.no, ...) ## S3 method for class 'cdir' trimfill(x, comp.no, outcome.no, ...) ## S3 method for class 'trimfill.rm5' print(x, ...) ## S3 method for class 'trimfill.cdir' print(x, ...)
## S3 method for class 'rm5' trimfill(x, comp.no, outcome.no, ...) ## S3 method for class 'cdir' trimfill(x, comp.no, outcome.no, ...) ## S3 method for class 'trimfill.rm5' print(x, ...) ## S3 method for class 'trimfill.cdir' print(x, ...)
x |
An object of class |
comp.no |
Comparison number. |
outcome.no |
Outcome number. |
... |
Additional arguments (passed on to |
This function can be used to conduct a trim-and-fill analysis for all or selected meta-analyses in a Cochrane review of intervention studies (Higgins et al., 2023).
The R function metacr
is called internally.
Guido Schwarzer [email protected]
Higgins JPT, Thomas J, Chandler J, Cumpston M, Li T, Page MJ, Welch VA (editors) (2023): Cochrane Handbook for Systematic Reviews of Interventions Version 6.4 (updated August 2023). Available from https://training.cochrane.org/handbook/
summary.meta
, metacr
,
read.rm5
, read.cdir
,
metabias.rm5
, metabias.cdir
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Conduct trim-and-fill analysis # trimfill(Fleiss1993_CR) # Conduct trim-and-fill analysis only for second outcome of first # comparison # trimfill(Fleiss1993_CR, comp.no = 1, outcome.no = 2)
# Locate export data file "Fleiss1993_CR.csv" # in sub-directory of package "meta" # filename <- system.file("extdata", "Fleiss1993_CR.csv", package = "meta") Fleiss1993_CR <- read.rm5(filename) # Conduct trim-and-fill analysis # trimfill(Fleiss1993_CR) # Conduct trim-and-fill analysis only for second outcome of first # comparison # trimfill(Fleiss1993_CR, comp.no = 1, outcome.no = 2)
Update an existing meta-analysis object.
## S3 method for class 'meta' update( object, data = object$data, subset, studlab, exclude, cluster, rho = object$rho, cycles, method, sm = object$sm, incr, method.incr = object$method.incr, allstudies = object$allstudies, MH.exact = object$MH.exact, RR.Cochrane = object$RR.Cochrane, Q.Cochrane = object$Q.Cochrane, model.glmm = object$model.glmm, level = object$level, level.ma = object$level.ma, common = object$common, random = object$random, overall = object$overall, overall.hetstat = object$overall.hetstat, method.random.ci = object$method.random.ci, adhoc.hakn.ci = object$adhoc.hakn.ci, method.predict = object$method.predict, adhoc.hakn.pi = object$adhoc.hakn.pi, seed.predict = object$seed.predict, method.tau = object$method.tau, method.tau.ci = object$method.tau.ci, level.hetstat = object$level.hetstat, tau.preset = object$tau.preset, TE.tau = object$TE.tau, tau.common = object$tau.common, method.I2 = object$method.I2, prediction = object$prediction, level.predict = object$level.predict, null.effect = object$null.effect, method.bias = object$method.bias, backtransf = object$backtransf, func.backtransf = object$func.backtransf, args.backtransf = object$args.backtransf, pscale = object$pscale, irscale = object$irscale, irunit = object$irunit, text.common = object$text.common, text.random = object$text.random, text.predict = object$text.predict, text.w.common = object$text.w.common, text.w.random = object$text.w.random, title = object$title, complab = object$complab, outclab = object$outclab, label.e = object$label.e, label.c = object$label.c, label.left = object$label.left, label.right = object$label.right, col.label.left = object$col.label.left, col.label.right = object$col.label.right, n.e = object$n.e, n.c = object$n.c, method.mean = object$method.mean, method.sd = object$method.sd, approx.mean.e = object$approx.mean.e, approx.mean.c = object$approx.mean.c, approx.sd.e = object$approx.sd.e, approx.sd.c = object$approx.sd.c, approx.mean = object$approx.mean, approx.sd = object$approx.sd, approx.TE = object$approx.TE, approx.seTE = object$approx.seTE, pooledvar = object$pooledvar, method.smd = object$method.smd, sd.glass = object$sd.glass, exact.smd = object$exact.smd, method.ci = object$method.ci, subgroup, subgroup.name = object$subgroup.name, print.subgroup.name = object$print.subgroup.name, sep.subgroup = object$sep.subgroup, test.subgroup = object$test.subgroup, prediction.subgroup = object$prediction.subgroup, seed.predict.subgroup = object$seed.predict.subgroup, byvar, id, print.CMH = object$print.CMH, keepdata = TRUE, left = object$left, ma.common = object$ma.common, type = object$type, n.iter.max = object$n.iter.max, warn = FALSE, warn.deprecated = gs("warn.deprecated"), verbose = FALSE, control = object$control, ... )
## S3 method for class 'meta' update( object, data = object$data, subset, studlab, exclude, cluster, rho = object$rho, cycles, method, sm = object$sm, incr, method.incr = object$method.incr, allstudies = object$allstudies, MH.exact = object$MH.exact, RR.Cochrane = object$RR.Cochrane, Q.Cochrane = object$Q.Cochrane, model.glmm = object$model.glmm, level = object$level, level.ma = object$level.ma, common = object$common, random = object$random, overall = object$overall, overall.hetstat = object$overall.hetstat, method.random.ci = object$method.random.ci, adhoc.hakn.ci = object$adhoc.hakn.ci, method.predict = object$method.predict, adhoc.hakn.pi = object$adhoc.hakn.pi, seed.predict = object$seed.predict, method.tau = object$method.tau, method.tau.ci = object$method.tau.ci, level.hetstat = object$level.hetstat, tau.preset = object$tau.preset, TE.tau = object$TE.tau, tau.common = object$tau.common, method.I2 = object$method.I2, prediction = object$prediction, level.predict = object$level.predict, null.effect = object$null.effect, method.bias = object$method.bias, backtransf = object$backtransf, func.backtransf = object$func.backtransf, args.backtransf = object$args.backtransf, pscale = object$pscale, irscale = object$irscale, irunit = object$irunit, text.common = object$text.common, text.random = object$text.random, text.predict = object$text.predict, text.w.common = object$text.w.common, text.w.random = object$text.w.random, title = object$title, complab = object$complab, outclab = object$outclab, label.e = object$label.e, label.c = object$label.c, label.left = object$label.left, label.right = object$label.right, col.label.left = object$col.label.left, col.label.right = object$col.label.right, n.e = object$n.e, n.c = object$n.c, method.mean = object$method.mean, method.sd = object$method.sd, approx.mean.e = object$approx.mean.e, approx.mean.c = object$approx.mean.c, approx.sd.e = object$approx.sd.e, approx.sd.c = object$approx.sd.c, approx.mean = object$approx.mean, approx.sd = object$approx.sd, approx.TE = object$approx.TE, approx.seTE = object$approx.seTE, pooledvar = object$pooledvar, method.smd = object$method.smd, sd.glass = object$sd.glass, exact.smd = object$exact.smd, method.ci = object$method.ci, subgroup, subgroup.name = object$subgroup.name, print.subgroup.name = object$print.subgroup.name, sep.subgroup = object$sep.subgroup, test.subgroup = object$test.subgroup, prediction.subgroup = object$prediction.subgroup, seed.predict.subgroup = object$seed.predict.subgroup, byvar, id, print.CMH = object$print.CMH, keepdata = TRUE, left = object$left, ma.common = object$ma.common, type = object$type, n.iter.max = object$n.iter.max, warn = FALSE, warn.deprecated = gs("warn.deprecated"), verbose = FALSE, control = object$control, ... )
object |
An object of class |
data |
Dataset. |
subset |
Subset. |
studlab |
Study label. |
exclude |
An optional vector specifying studies to exclude from meta-analysis, however, to include in printouts and forest plots. |
cluster |
An optional vector specifying which estimates come from the same cluster resulting in the use of a three-level meta-analysis model. |
rho |
Assumed correlation of estimates within a cluster. |
cycles |
A numeric vector with the number of cycles per patient / study
in n-of-1 trials (see |
method |
A character string indicating which method is to be
used for pooling of studies (see |
sm |
A character string indicating which summary measure is used for pooling. |
incr |
Information on increment added to cell frequencies of
studies with zero cell counts (see |
method.incr |
A character string indicating which continuity
correction method should be used (see |
allstudies |
A logical indicating if studies with zero or all
events in both groups are to be included in the meta-analysis
(applies only to |
MH.exact |
A logical indicating if |
RR.Cochrane |
A logical indicating which method to use as
continuity correction for the risk ratio (see
|
Q.Cochrane |
A logical indicating which method to use to
calculate the heterogeneity statistic Q (see
|
model.glmm |
A character string indicating which GLMM model
should be used (see |
level |
The level used to calculate confidence intervals for individual studies. |
level.ma |
The level used to calculate confidence intervals for meta-analysis estimates. |
common |
A logical indicating whether a common effect meta-analysis should be conducted. |
random |
A logical indicating whether a random effects meta-analysis should be conducted. |
overall |
A logical indicating whether overall summaries should be reported. This argument is useful in a meta-analysis with subgroups if overall results should not be reported. |
overall.hetstat |
A logical value indicating whether to print heterogeneity measures for overall treatment comparisons. This argument is useful in a meta-analysis with subgroups if heterogeneity statistics should only be printed on subgroup level. |
method.random.ci |
A character string indicating which method
is used to calculate confidence interval and test statistic for
random effects estimate (see |
adhoc.hakn.ci |
A character string indicating whether an
ad hoc variance correction should be applied in the case
of an arbitrarily small Hartung-Knapp variance estimate (see
|
method.predict |
A character string indicating which method is
used to calculate a prediction interval (see
|
adhoc.hakn.pi |
A character string indicating whether an
ad hoc variance correction should be applied for
prediction interval (see |
seed.predict |
A numeric value used as seed to calculate
bootstrap prediction interval (see |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
method.tau.ci |
A character string indicating which method is
used to estimate the confidence interval of |
level.hetstat |
The level used to calculate confidence intervals for heterogeneity statistics. |
tau.preset |
Prespecified value for the square root of the
between-study variance |
TE.tau |
Overall treatment effect used to estimate the between-study variance tau-squared. |
tau.common |
A logical indicating whether tau-squared should be the same across subgroups. |
method.I2 |
A character string indicating which method is
used to estimate the heterogeneity statistic I |
prediction |
A logical indicating whether a prediction interval should be printed. |
level.predict |
The level used to calculate prediction interval for a new study. |
null.effect |
A numeric value specifying the effect under the null hypothesis. |
method.bias |
A character string indicating which test for
funnel plot asymmetry is to be used, can be abbreviated. See
function |
backtransf |
A logical indicating whether results should be
back transformed in printouts and plots. If |
func.backtransf |
A function used to back-transform results
(see |
args.backtransf |
An optional list to provide additional
arguments to |
pscale |
A numeric giving scaling factor for printing of
single event probabilities or risk differences, i.e. if argument
|
irscale |
A numeric defining a scaling factor for printing of
single incidence rates or incidence rate differences, i.e. if
argument |
irunit |
A character specifying the time unit used to calculate rates, e.g. person-years. |
text.common |
A character string used in printouts and forest plot to label the pooled common effect estimate. |
text.random |
A character string used in printouts and forest plot to label the pooled random effects estimate. |
text.predict |
A character string used in printouts and forest plot to label the prediction interval. |
text.w.common |
A character string used to label weights of common effect model. |
text.w.random |
A character string used to label weights of random effects model. |
title |
Title of meta-analysis / systematic review. |
complab |
Comparison label. |
outclab |
Outcome label. |
label.e |
Label for experimental group. |
label.c |
Label for control group. |
label.left |
Graph label on left side of null effect in forest plot. |
label.right |
Graph label on right side of null effect in forest plot. |
col.label.left |
The colour of the graph label on the left side of the null effect. |
col.label.right |
The colour of the graph label on the right side of the null effect. |
n.e |
Number of observations in experimental group (only for
|
n.c |
Number of observations in control group (only for metagen object). |
method.mean |
A character string indicating which method to
use to approximate the mean from the median and other statistics
(see |
method.sd |
A character string indicating which method to use
to approximate the standard deviation from sample size, median,
interquartile range and range (see |
approx.mean.e |
Approximation method to estimate means in
experimental group (see |
approx.mean.c |
Approximation method to estimate means in
control group (see |
approx.sd.e |
Approximation method to estimate standard
deviations in experimental group (see |
approx.sd.c |
Approximation method to estimate standard
deviations in control group (see |
approx.mean |
Approximation method to estimate means (see
|
approx.sd |
Approximation method to estimate standard
deviations (see |
approx.TE |
Approximation method to estimate treatment
estimate (see |
approx.seTE |
Approximation method to estimate standard error
(see |
pooledvar |
A logical indicating if a pooled variance should
be used for the mean difference or ratio of means (see
|
method.smd |
A character string indicating which method is
used to estimate the standardised mean difference (see
|
sd.glass |
A character string indicating which standard
deviation is used in the denominator for Glass' method to
estimate the standardised mean difference (only for metacont
object with |
exact.smd |
A logical indicating whether exact formulae should be used in estimation of the standardised mean difference and its standard error. |
method.ci |
A character string indicating which method is used
to calculate confidence intervals for individual studies. Either
|
subgroup |
An optional vector to conduct a meta-analysis with subgroups. |
subgroup.name |
A character string with a name for the subgroup variable. |
print.subgroup.name |
A logical indicating whether the name of the subgroup variable should be printed in front of the group labels. |
sep.subgroup |
A character string defining the separator between name of subgroup variable and subgroup label. |
test.subgroup |
A logical value indicating whether to print results of test for subgroup differences. |
prediction.subgroup |
A logical indicating whether prediction intervals should be printed for subgroups. |
seed.predict.subgroup |
A numeric vector providing seeds to calculate bootstrap prediction intervals within subgroups. Must be of same length as the number of subgroups. |
byvar |
Deprecated argument (replaced by 'subgroup'). |
id |
Deprecated argument (replaced by 'cluster'). |
print.CMH |
A logical indicating whether result of the Cochran-Mantel-Haenszel test for overall effect should be printed. |
keepdata |
A logical indicating whether original data (set) should be kept in meta object. |
left |
A logical indicating whether studies are supposed to be
missing on the left or right side of the funnel plot. If NULL,
the linear regression test for funnel plot symmetry (i.e.,
function |
ma.common |
A logical indicating whether a common effect or random effects model is used to estimate the number of missing studies. |
type |
A character indicating which method is used to estimate
the number of missing studies. Either |
n.iter.max |
Maximum number of iterations to estimate number of missing studies. |
warn |
A logical indicating whether warnings should be printed
(e.g., if |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
verbose |
A logical indicating whether to print information on updates of older meta versions. |
control |
An optional list to control the iterative process to
estimate the between-study variance |
... |
Additional arguments (ignored at the moment). |
Wrapper function to update an existing meta-analysis object which
was created with R function metabin
,
metacont
, metacor
,
metagen
, metainc
,
metamean
, metaprop
, or
metarate
. More details on function arguments are
available in help files of respective R functions.
This function can also be used for objects of class 'trimfill', 'metacum', and 'metainf'.
An object of class "meta"
and "metabin"
,
"metacont"
, "metacor"
, "metainc"
,
"metagen"
, "metamean"
, "metaprop"
, or
"metarate"
(see meta-object
).
Guido Schwarzer [email protected]
metabin
, metacont
,
metacor
, metagen
,
metainc
, metamean
,
metaprop
, metarate
data(Fleiss1993cont) m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, studlab = paste(study, year), sm = "SMD") m1 # Change summary measure (from 'SMD' to 'MD') # update(m1, sm = "MD") # Restrict analysis to subset of studies # update(m1, subset = 1:2) # Use different levels for confidence intervals # m2 <- update(m1, level = 0.66, level.ma = 0.99) print(m2, digits = 2) forest(m2)
data(Fleiss1993cont) m1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, studlab = paste(study, year), sm = "SMD") m1 # Change summary measure (from 'SMD' to 'MD') # update(m1, sm = "MD") # Restrict analysis to subset of studies # update(m1, subset = 1:2) # Use different levels for confidence intervals # m2 <- update(m1, level = 0.66, level.ma = 0.99) print(m2, digits = 2) forest(m2)
This function returns a data frame containing information on absolute and percentage weights of individual studies contributing to common effect and random effects meta-analysis.
## S3 method for class 'meta' weights( object, common = object$common, random = object$random, warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'meta' weights( object, common = object$common, random = object$random, warn.deprecated = gs("warn.deprecated"), ... )
object |
An object of class |
common |
A logical indicating whether absolute and percentage weights from the common effect model should be calculated. |
random |
A logical indicating whether absolute and percentage weights from the random effects model should be calculated. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
A data frame with the following variables is returned:
Variable | Definition | Condition |
w.common | absolute weights in common effect model | (if
common = TRUE ) |
p.common | percentage weights in common effect model | (if
common = TRUE ) |
w.random | absolute weights in random effects model | (if
random = TRUE ) |
p.random | percentage weights in random effects model | (if
random = TRUE )
|
Guido Schwarzer [email protected]
data(Fleiss1993cont) # Do meta-analysis (common effect and random effects model) # meta1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, studlab = paste(study, year), sm = "SMD") # Print weights for common effect and random effects meta-analysis # weights(meta1) # Do meta-analysis (only random effects model) # meta2 <- update(meta1, common = FALSE) # Print weights for random effects meta-analysis # weights(meta2) # Print weights for common effect and random effects meta-analysis # weights(meta2, common = TRUE)
data(Fleiss1993cont) # Do meta-analysis (common effect and random effects model) # meta1 <- metacont(n.psyc, mean.psyc, sd.psyc, n.cont, mean.cont, sd.cont, data = Fleiss1993cont, studlab = paste(study, year), sm = "SMD") # Print weights for common effect and random effects meta-analysis # weights(meta1) # Do meta-analysis (only random effects model) # meta2 <- update(meta1, common = FALSE) # Print weights for random effects meta-analysis # weights(meta2) # Print weights for common effect and random effects meta-analysis # weights(meta2, common = TRUE)
Meta-analysis on effects of elevated CO_2 on total biomass of woody plants
This dataset has been used as an example in Hedges et al. (1999) to describe methods for the meta-analysis of response ratios. The complete dataset with 102 observations and 26 variables is available online as a supplement. Here only a subset of 10 variables is provided and used in the examples.
A data frame with the following columns:
obsno | observation number |
papno | database paper number |
treat | treatment code |
level | treatment level |
n.elev | number of observations in experimental group (elevated CO_2-level) |
mean.elev | estimated mean in experimental group |
sd.elev | standard deviation in experimental group |
n.amb | number of observations in control group (ambient CO_2-level) |
mean.amb | estimated mean in control group |
sd.amb | standard deviation in control group |
Hedges LV, Gurevitch J, Curtis PS (1999): The meta-analysis of response ratios in experimental ecology. Ecology, 80, 1150–6
data(woodyplants) # Meta-analysis of response ratios (Hedges et al., 1999) # m1 <- metacont(n.elev, mean.elev, sd.elev, n.amb, mean.amb, sd.amb, data = woodyplants, sm = "ROM", studlab = paste(obsno, papno, sep = " / ")) print(m1, prediction = TRUE) # Meta-analysis for plants grown with low soil fertility treatment # m2 <- update(m1, subset = (treat == "fert" & level == "low")) print(m2, prediction = TRUE) # Meta-analysis for plants grown under low light conditions # m3 <- update(m1, subset = (treat == "light" & level == "low")) print(m3, prediction = TRUE)
data(woodyplants) # Meta-analysis of response ratios (Hedges et al., 1999) # m1 <- metacont(n.elev, mean.elev, sd.elev, n.amb, mean.amb, sd.amb, data = woodyplants, sm = "ROM", studlab = paste(obsno, papno, sep = " / ")) print(m1, prediction = TRUE) # Meta-analysis for plants grown with low soil fertility treatment # m2 <- update(m1, subset = (treat == "fert" & level == "low")) print(m2, prediction = TRUE) # Meta-analysis for plants grown under low light conditions # m3 <- update(m1, subset = (treat == "light" & level == "low")) print(m3, prediction = TRUE)