Title: | Network Meta-Analysis using Frequentist Methods |
---|---|
Description: | A comprehensive set of functions providing frequentist methods for network meta-analysis (Balduzzi et al., 2023) <doi:10.18637/jss.v106.i02> and supporting Schwarzer et al. (2015) <doi:10.1007/978-3-319-21416-0>, Chapter 8 "Network Meta-Analysis": - frequentist network meta-analysis following Rücker (2012) <doi:10.1002/jrsm.1058>; - additive network meta-analysis for combinations of treatments (Rücker et al., 2020) <doi:10.1002/bimj.201800167>; - network meta-analysis of binary data using the Mantel-Haenszel or non-central hypergeometric distribution method (Efthimiou et al., 2019) <doi:10.1002/sim.8158>, or penalised logistic regression (Evrenoglou et al., 2022) <doi:10.1002/sim.9562>; - rankograms and ranking of treatments by the Surface under the cumulative ranking curve (SUCRA) (Salanti et al., 2013) <doi:10.1016/j.jclinepi.2010.03.016>; - ranking of treatments using P-scores (frequentist analogue of SUCRAs without resampling) according to Rücker & Schwarzer (2015) <doi:10.1186/s12874-015-0060-8>; - split direct and indirect evidence to check consistency (Dias et al., 2010) <doi:10.1002/sim.3767>, (Efthimiou et al., 2019) <doi:10.1002/sim.8158>; - league table with network meta-analysis results; - 'comparison-adjusted' funnel plot (Chaimani & Salanti, 2012) <doi:10.1002/jrsm.57>; - net heat plot and design-based decomposition of Cochran's Q according to Krahn et al. (2013) <doi:10.1186/1471-2288-13-35>; - measures characterizing the flow of evidence between two treatments by König et al. (2013) <doi:10.1002/sim.6001>; - automated drawing of network graphs described in Rücker & Schwarzer (2016) <doi:10.1002/jrsm.1143>; - partial order of treatment rankings ('poset') and Hasse diagram for 'poset' (Carlsen & Bruggemann, 2014) <doi:10.1002/cem.2569>; (Rücker & Schwarzer, 2017) <doi:10.1002/jrsm.1270>; - contribution matrix as described in Papakonstantinou et al. (2018) <doi:10.12688/f1000research.14770.3> and Davies et al. (2022) <doi:10.1002/sim.9346>; - subgroup network meta-analysis. |
Authors: | Gerta Rücker [aut] , Ulrike Krahn [aut], Jochem König [aut] , Orestis Efthimiou [aut] , Annabel Davies [aut] , Theodoros Papakonstantinou [aut] , Guido Schwarzer [aut, cre] |
Maintainer: | Guido Schwarzer <[email protected]> |
License: | GPL (>= 2) |
Version: | 3.0-0 |
Built: | 2025-01-17 17:19:36 UTC |
Source: | https://github.com/guido-s/netmeta |
R package netmeta (Balduzzi et al., 2023) provides frequentist methods for network meta-analysis and supports Schwarzer et al. (2015), Chapter 8 on network meta-analysis https://link.springer.com/book/10.1007/978-3-319-21416-0.
R package netmeta is an add-on package for meta providing the following network meta-analysis models:
frequentist network meta-analysis (function
netmeta
) based on Rücker (2012) and Rücker &
Schwarzer (2014);
additive network meta-analysis for combinations of treatments
(netcomb
for connected networks,
discomb
for disconnected networks) (Rücker et al.,
2020a);
network meta-analysis of binary data
(netmetabin
) using the Mantel-Haenszel or
non-central hypergeometric distribution method (Efthimiou et al.,
2019), or penalised logistic regression (Evrenoglou et al., 2022).
The following methods are available to present results of a network meta-analysis:
network graphs (netgraph
) described in Rücker &
Schwarzer (2016);
forest plots (forest.netmeta
,
forest.netcomb
);
league tables with network meta-analysis results
(netleague
);
tables with network, direct and indirect estimates
(nettable
) looking similar to the statistical part
of a GRADE table for a network meta-analysis (Puhan et al.,
2014).
The following methods are implemented to rank treatments:
rankograms (rankogram
) (Salanti et al., 2011);
ranking of treatments (netrank
) based on
P-scores (Rücker & Schwarzer, 2015) or the Surface Under the
Cumulative RAnking curve (SUCRA) (Salanti et al., 2011);
partial order of treatment rankings (netposet
,
plot.netposet
) and Hasse diagram
(hasse
) according to Carlsen & Bruggemann (2014)
and Rücker & Schwarzer (2017).
Available functions to evaluate network inconsistency:
split direct and indirect evidence (netsplit
)
to check for consistency (Dias et al., 2010; Efthimiou et al.,
2019);
net heat plot (netheat
) and design-based
decomposition of Cochran's Q (decomp.design
)
described in Krahn et al. (2013).
Additional methods and functions:
subgroup network meta-analysis (subgroup.netmeta
);
information on network connectivity
(netconnection
);
contribution of direct comparisons to network estimates
(netcontrib
) (Papakonstantinou et al., 2018; Davies
et al., 2022);
importance of individual studies measured by reduction of
precision if removed from network (netimpact
)
(Rücker et al., 2020b);
‘comparison-adjusted’ funnel plot
(funnel.netmeta
) to assess funnel plot asymmetry in
network meta-analysis (Chaimani & Salanti, 2012);
conduct pairwise meta-analyses for all comparisons with
direct evidence in a network meta-analysis
(netpairwise
);
results of several network meta-analyses can be combined with
netbind
to show these results in a forest plot
(forest.netbind
).
measures characterizing the flow of evidence between two
treatments (netmeasures
) described in König et
al. (2013);
calculate comparison effects of two arbitrary complex
interventions in component network meta-analysis
(netcomparison
);
calculate effect of arbitrary complex interventions in
component network meta-analysis (netcomplex
).
Functions and datasets from netmeta are utilised in Schwarzer et al. (2015), Chapter 8 "Network Meta-Analysis", https://link.springer.com/book/10.1007/978-3-319-21416-0.
Type help(package = "netmeta")
for a listing of all R
functions available in netmeta.
Type citation("netmeta")
on how to cite netmeta in
publications.
To report problems and bugs
type bug.report(package = "netmeta")
if you do not use
RStudio,
send an email to Guido Schwarzer [email protected] if you use RStudio.
The development version of netmeta is available on GitHub https://github.com/guido-s/netmeta.
Guido Schwarzer [email protected], Gerta Rücker [email protected]
Balduzzi S, Rücker G, Nikolakopoulou A, Papakonstantinou T, Salanti G, Efthimiou O, Schwarzer G (2023): netmeta: An R Package for network meta-analysis using frequentist methods. Journal of Statistical Software, 106, 1–40
Carlsen L, Bruggemann R (2014): Partial order methodology: a valuable tool in chemometrics. Journal of Chemometrics, 28, 226–34
Chaimani A & Salanti G (2012): Using network meta-analysis to evaluate the existence of small-study effects in a network of interventions. Research Synthesis Methods, 3, 161–76
Davies AL, Papakonstantinou T, Nikolakopoulou A, Rücker G, Galla T (2022): Network meta-analysis and random walks. Statistics in Medicine, 41, 2091–2114
Dias S, Welton NJ, Caldwell DM, Ades AE (2010): Checking consistency in mixed treatment comparison meta-analysis. Statistics in Medicine, 29, 932–44
Efthimiou O, Rücker G, Schwarzer G, Higgins J, Egger M, Salanti G (2019): A Mantel-Haenszel model for network meta-analysis of rare events. Statistics in Medicine, 38, 2992–3012
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.
König J, Krahn U, Binder H (2013): Visualizing the flow of evidence in network meta-analysis and characterizing mixed treatment comparisons. Statistics in Medicine, 32, 5414–29
Krahn U, Binder H, König J (2013): A graphical tool for locating inconsistency in network meta-analyses. BMC Medical Research Methodology, 13, 35
Papakonstantinou, T., Nikolakopoulou, A., Rücker, G., Chaimani, A., Schwarzer, G., Egger, M., Salanti, G. (2018): Estimating the contribution of studies in network meta-analysis: paths, flows and streams. F1000Research
Puhan MA, Schünemann HJ, Murad MH, et al. (2014): A GRADE working group approach for rating the quality of treatment effect estimates from network meta-analysis. British Medical Journal, 349, g5630
Rücker G (2012): Network meta-analysis, electrical networks and graph theory. Research Synthesis Methods, 3, 312–24
Rücker G, Schwarzer G (2014): Reduce dimension or reduce weights? Comparing two approaches to multi-arm studies in network meta-analysis. Statistics in Medicine, 33, 4353–69
Rücker G, Schwarzer G (2015): Ranking treatments in frequentist network meta-analysis works without resampling methods. BMC Medical Research Methodology, 15, 58
Rücker G, Schwarzer G (2016): Automated drawing of network plots in network meta-analysis. Research Synthesis Methods, 7, 94–107
Rücker G, Schwarzer G (2017): Resolve conflicting rankings of outcomes in network meta-analysis: Partial ordering of treatments. Research Synthesis Methods, 8, 526–36
Rücker G, Petropoulou M, Schwarzer G (2020a): Network meta-analysis of multicomponent interventions. Biometrical Journal, 62, 808–21
Rücker G, Nikolakopoulou A, Papakonstantinou T, Salanti G, Riley RD, Schwarzer G (2020b): The statistical importance of a study for a network meta-analysis estimate. BMC Medical Research Methodology, 20, 190
Salanti G, Ades AE, Ioannidis JP (2011): Graphical methods and numerical summaries for presenting results from multiple-treatment meta-analysis: an overview and tutorial. Journal of Clinical Epidemiology, 64, 163–71
Schwarzer G, Carpenter JR and Rücker G (2015): Meta-Analysis with R (Use R!). Springer International Publishing, Switzerland.
Useful links:
The as.data.frame
method returns a data frame containing
information on membership of studies / pairwise comparisons to a
(sub)network.
## S3 method for class 'netconnection' as.data.frame(x, ...)
## S3 method for class 'netconnection' as.data.frame(x, ...)
x |
An object of class |
... |
Additional arguments (ignored). |
A data frame is returned by the function
as.data.frame
.
Guido Schwarzer [email protected]
# Artificial example with two subnetworks # t1 <- c("G", "B", "B", "D", "A", "F") t2 <- c("B", "C", "E", "E", "H", "A") # nc2 <- netconnection(t1, t2) print(nc2, details = TRUE) as.data.frame(nc2)
# Artificial example with two subnetworks # t1 <- c("G", "B", "B", "D", "A", "F") t2 <- c("B", "C", "E", "E", "H", "A") # nc2 <- netconnection(t1, t2) print(nc2, details = TRUE) as.data.frame(nc2)
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 'netmeta' as.data.frame(x, row.names = NULL, optional = FALSE, details = FALSE, ...)
## S3 method for class 'netmeta' as.data.frame(x, row.names = NULL, optional = FALSE, details = FALSE, ...)
x |
An object of class |
row.names |
|
optional |
A logical. If |
details |
A logical. If |
... |
Additional arguments. |
A data frame is returned by the function
as.data.frame
.
Guido Schwarzer [email protected]
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis and show data frame # net1 <- netmeta(p1, common = FALSE) as.data.frame(net1) ## Not run: data(Senn2013) # Conduct network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") as.data.frame(net2) as.data.frame(net2, details = TRUE) ## End(Not run)
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis and show data frame # net1 <- netmeta(p1, common = FALSE) as.data.frame(net1) ## Not run: data(Senn2013) # Conduct network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") as.data.frame(net2) as.data.frame(net2, details = TRUE) ## End(Not run)
This dataset comes from a systematic review of randomized controlled trials on pharmacologic treatments for chronic obstructive pulmonary disease (COPD) (Baker et al., 2009).
The primary outcome, occurrence of one or more episodes of COPD exacerbation, is binary (yes / no). For this outcome, five drug treatments (fluticasone, budesonide, salmeterol, formoterol, tiotropium) and two combinations (fluticasone + salmeterol, budesonide + formoterol) were compared to placebo. The authors considered the two combinations as separate treatments instead of evaluating the individual components.
A data frame with the following columns:
study | study label |
year | year of publication |
id | study ID |
treatment | treatment |
exac | one or more episodes of COPD exacerbation |
total | number of individuals in treatment arm |
Baker WL, Baker EL, Coleman CI (2009): Pharmacologic Treatments for Chronic Obstructive Pulmonary Disease: A Mixed-Treatment Comparison Meta-analysis. Pharmacotherapy: The Journal of Human Pharmacology and Drug Therapy, 29, 891–905
data(Baker2009) Baker2009 ## Not run: # 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. # p1 <- pairwise(treatment, exac, total, studlab = paste(study, year), data = Baker2009, sm = "OR") # Conduct network meta-analysis # net1 <- netmeta(p1, ref = "plac") # Conduct component network meta-analysis # cnet1 <- netcomb(net1) cnet1 ## End(Not run)
data(Baker2009) Baker2009 ## Not run: # 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. # p1 <- pairwise(treatment, exac, total, studlab = paste(study, year), data = Baker2009, sm = "OR") # Conduct network meta-analysis # net1 <- netmeta(p1, ref = "plac") # Conduct component network meta-analysis # cnet1 <- netcomb(net1) cnet1 ## End(Not run)
Auxiliary functions to (i) create a combination / C matrix with information on treatment combinations and interaction terms and (ii) a vector with all combinations in a component network meta-analysis.
createC(x, ...) ## S3 method for class 'matrix' createC( x, comb.ia, inactive = NULL, sep.comps = gs("sep.comps"), sep.ia = gs("sep.ia"), ... ) ## S3 method for class 'netcomb' createC(x, comb.ia = NULL, inactive = NULL, sep.ia = x$sep.ia, ...) ## S3 method for class 'netmeta' createC(x, inactive = NULL, sep.comps = gs("sep.comps"), ...) ## S3 method for class 'netconnection' createC(x, inactive = NULL, sep.comps = gs("sep.comps"), ...) ## Default S3 method: createC(x, n = 1, ...) combinations(x, n = NULL)
createC(x, ...) ## S3 method for class 'matrix' createC( x, comb.ia, inactive = NULL, sep.comps = gs("sep.comps"), sep.ia = gs("sep.ia"), ... ) ## S3 method for class 'netcomb' createC(x, comb.ia = NULL, inactive = NULL, sep.ia = x$sep.ia, ...) ## S3 method for class 'netmeta' createC(x, inactive = NULL, sep.comps = gs("sep.comps"), ...) ## S3 method for class 'netconnection' createC(x, inactive = NULL, sep.comps = gs("sep.comps"), ...) ## Default S3 method: createC(x, n = 1, ...) combinations(x, n = NULL)
x |
A |
... |
Additional arguments. |
comb.ia |
A character vector specifying treatment combinations which will be considered as interactions. |
inactive |
A character string defining the inactive treatment
component (see |
sep.comps |
A single character to define separator between treatment components. |
sep.ia |
A single character to define separator for interactions. |
n |
A single number specifying the number of components in combinations. |
R function createC
returns a combination matrix / C matrix with
studies in rows and component and interaction terms in columns.
R function combinations
returns a character vector with combinations.
Guido Schwarzer [email protected], Gerta Rücker [email protected]
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive component network meta-analysis (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Available combinations in CNMA combinations(nc1) # Create C matrix with all available interactions, i.e., one interaction # for each combination createC(nc1) # Run interaction CNMA model with all available interactions # (same result as standard NMA) netcomb(net1, C.matrix = createC(nc1)) ## Not run: # Conduct random effects network meta-analysis on full dataset # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, ref = "placebo", sm = "OR", common = FALSE) # Additive component network meta-analysis (with placebo as inactive # treatment) # nc2 <- netcomb(net2, inactive = "placebo") # Available combinations in CNMA combinations(nc2) # Create C matrix with all available interactions, i.e., one interaction # for each combination head(createC(nc2)) # Run interaction CNMA model with all available interactions # (same result as standard NMA) netcomb(net2, C.matrix = createC(nc2)) ## End(Not run)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive component network meta-analysis (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Available combinations in CNMA combinations(nc1) # Create C matrix with all available interactions, i.e., one interaction # for each combination createC(nc1) # Run interaction CNMA model with all available interactions # (same result as standard NMA) netcomb(net1, C.matrix = createC(nc1)) ## Not run: # Conduct random effects network meta-analysis on full dataset # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, ref = "placebo", sm = "OR", common = FALSE) # Additive component network meta-analysis (with placebo as inactive # treatment) # nc2 <- netcomb(net2, inactive = "placebo") # Available combinations in CNMA combinations(nc2) # Create C matrix with all available interactions, i.e., one interaction # for each combination head(createC(nc2)) # Run interaction CNMA model with all available interactions # (same result as standard NMA) netcomb(net2, C.matrix = createC(nc2)) ## End(Not run)
This function performs a design-based decomposition of Cochran's Q for assessing the homogeneity in the whole network, the homogeneity within designs, and the homogeneity/consistency between designs. It allows also an assessment of the consistency assumption after detaching the effect of single designs.
decomp.design( x, tau.preset = x$tau.preset, warn = gs("warn"), nchar.trts = x$nchar.trts )
decomp.design( x, tau.preset = x$tau.preset, warn = gs("warn"), nchar.trts = x$nchar.trts )
x |
An object of class |
tau.preset |
An optional value for the square-root of the
between-study variance |
warn |
A logical indicating whether warnings should be printed. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
In the context of network meta-analysis and the assessment of the homogeneity and consistency assumption, a generalized Cochran's Q statistic for multivariate meta-analysis can be used as shown in Krahn et al. (2013). This Q statistic can be decomposed in a sum of within-design Q statistics and one between-designs Q statistic that incorporates the concept of design inconsistency, see Higgins et al. (2012).
For assessing the inconsistency in a random effects model, the
between-designs Q statistic can be calculated based on a full
design-by-treatment interaction random effects model (see Higgins
et al., 2012). This Q statistic will be automatically given in the
output ( estimated by the method of moments (see Jackson
et al., 2012). Alternatively, the square-root of the between-study
variance can be prespecified by argument
tau.preset
to
obtain a between-designs Q statistic (in Q.inc.random
), its
design-specific contributions Q.inc.design.random.preset
) as
well as residuals after detaching of single designs
(residuals.inc.detach.random.preset
).
Since an inconsistent treatment effect of one design can
simultaneously inflate several residuals, Krahn et al. (2013)
suggest for locating the inconsistency in a network to fit a set of
extended models allowing for example for a deviating effect of each
study design in turn. The recalculated between-designs Q statistics
are given in list component Q.inc.detach
. The change of the
inconsistency contribution of single designs can be investigated in
more detail by a net heat plot (see function
netheat). Designs where only one treatment is involved in
other designs of the network or where the removal of corresponding
studies would lead to a splitting of the network do not contribute
to the inconsistency assessment. These designs are not included in
Q.inc.detach
.
Network meta-analysis with a single design: NULL
. Otherwise,
a list containing the following components:
Q.decomp |
Data frame with Q statistics (variable |
Q.het.design |
Data frame with design-specific decomposition
of the within-designs Q statistic ( |
Q.inc.detach |
Data frame with between-designs Q statistics
( |
Q.inc.design |
A named vector with contributions of single
designs to the between design Q statistic given in
|
Q.inc.random |
Data frame with between-designs Q statistic
( |
Q.inc.random.preset |
Data frame with between-designs Q
statistic ( |
Q.inc.design.random.preset |
A named vector with contributions
of single designs to the between design Q statistic based on a
random effects model with prespecified square-root of
between-study variance |
residuals.inc.detach |
Matrix with residuals, i.e. design-specific direct estimates minus the corresponding network estimates after detaching the design of the column. |
residuals.inc.detach.random.preset |
Matrix with residuals
analogous to |
call |
Function call. |
version |
Version of R package netmeta used to create object. |
Ulrike Krahn [email protected], Jochem König [email protected]
Higgins JPT, Jackson D, Barrett JK, Lu G, Ades AE, White IR (2012): Consistency and inconsistency in network meta-analysis: concepts and models for multi-arm studies. Research Synthesis Methods, 3, 98–110
Krahn U, Binder H, König J (2013): A graphical tool for locating inconsistency in network meta-analyses. BMC Medical Research Methodology, 13, 35
Jackson D, White IR and Riley RD (2012): Quantifying the impact of between-study heterogeneity in multivariate meta-analyses. Statistics in Medicine, 31, 3805–20
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct network meta-analysis with placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013.5, sm = "MD", reference = "plac") # Decomposition of Cochran's Q # decomp.design(net1)
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct network meta-analysis with placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013.5, sm = "MD", reference = "plac") # Decomposition of Cochran's Q # decomp.design(net1)
Network meta-analysis comparing the effects of two diets to control on mortality.
The data are rates, given as the number of deaths and person-years. These data are used as an example in the supplemental material of Dias et al. (2013).
A data frame with the following columns:
treat1 | treatment 1 |
treat2 | treatment 2 |
treat3 | treatment 3 |
years1 | person years arm 1 |
years2 | person years arm 2 |
years3 | person years arm 3 |
d1 | events (deaths) arm 1 |
d2 | events (deaths) arm 2 |
d3 | events (deaths) arm 3 |
ID | study ID |
Dias S, Sutton AJ, Ades AE and Welton NJ (2013): Evidence synthesis for decision making 2: A generalized linear modeling framework for pairwise and network meta-analysis of randomized controlled trials. Medical Decision Making, 33, 607–17
pairwise
, metainc
,
netmeta
, netgraph.netmeta
data(dietaryfat) # Transform data from arm-based format to contrast-based format # Using incidence rate ratios (sm = "IRR") as effect measure. # Note, the argument 'sm' is not necessary as this is the default # in R function metainc() called internally # p1 <- pairwise(list(treat1, treat2, treat3), list(d1, d2, d3), time = list(years1, years2, years3), studlab = ID, data = dietaryfat, sm = "IRR") p1 # Conduct network meta-analysis # net1 <- netmeta(p1) net1 # Conduct network meta-analysis using incidence rate differences # (sm = "IRD") # p2 <- pairwise(list(treat1, treat2, treat3), list(d1, d2, d3), time = list(years1, years2, years3), studlab = ID, data = dietaryfat, sm = "IRD") net2 <- netmeta(p2) net2 # Draw network graph # netgraph(net1, points = TRUE, cex.points = 3, cex = 1.25) netgraph(net1, points = TRUE, cex.points = 3, cex = 1.25, labels = c("Control","Diet", "Diet 2"))
data(dietaryfat) # Transform data from arm-based format to contrast-based format # Using incidence rate ratios (sm = "IRR") as effect measure. # Note, the argument 'sm' is not necessary as this is the default # in R function metainc() called internally # p1 <- pairwise(list(treat1, treat2, treat3), list(d1, d2, d3), time = list(years1, years2, years3), studlab = ID, data = dietaryfat, sm = "IRR") p1 # Conduct network meta-analysis # net1 <- netmeta(p1) net1 # Conduct network meta-analysis using incidence rate differences # (sm = "IRD") # p2 <- pairwise(list(treat1, treat2, treat3), list(d1, d2, d3), time = list(years1, years2, years3), studlab = ID, data = dietaryfat, sm = "IRD") net2 <- netmeta(p2) net2 # Draw network graph # netgraph(net1, points = TRUE, cex.points = 3, cex = 1.25) netgraph(net1, points = TRUE, cex.points = 3, cex = 1.25, labels = c("Control","Diet", "Diet 2"))
Some treatments in a network meta-analysis may be combinations of other treatments or have common components. The influence of individual components can be evaluated in an additive network meta-analysis model assuming that the effect of treatment combinations is the sum of the effects of its components. This function implements this additive model in a frequentist way and is particularly intended for disconnected networks.
discomb( TE, seTE, treat1, treat2, studlab, data = NULL, subset = NULL, inactive = NULL, sep.comps = gs("sep.comps"), C.matrix, sm, level = gs("level"), level.ma = gs("level.ma"), common = gs("common"), random = gs("random") | !is.null(tau.preset), reference.group, baseline.reference = gs("baseline.reference"), seq = gs("sep"), tau.preset = NULL, tol.multiarm = gs("tol.multiarm"), tol.multiarm.se = gs("tol.multiarm.se"), details.chkmultiarm = gs("details.chkmultiarm"), details.chkident = FALSE, sep.trts = gs("sep.trts"), nchar.comps = gs("nchar.comps"), sep.ia = gs("sep.ia"), func.inverse = invmat, n1 = NULL, n2 = NULL, event1 = NULL, event2 = NULL, incr = NULL, overall.hetstat = gs("overall.hetstat"), backtransf = gs("backtransf"), na.unident = gs("na.unident"), title = gs("title"), keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), nchar.trts = nchar.comps, ... )
discomb( TE, seTE, treat1, treat2, studlab, data = NULL, subset = NULL, inactive = NULL, sep.comps = gs("sep.comps"), C.matrix, sm, level = gs("level"), level.ma = gs("level.ma"), common = gs("common"), random = gs("random") | !is.null(tau.preset), reference.group, baseline.reference = gs("baseline.reference"), seq = gs("sep"), tau.preset = NULL, tol.multiarm = gs("tol.multiarm"), tol.multiarm.se = gs("tol.multiarm.se"), details.chkmultiarm = gs("details.chkmultiarm"), details.chkident = FALSE, sep.trts = gs("sep.trts"), nchar.comps = gs("nchar.comps"), sep.ia = gs("sep.ia"), func.inverse = invmat, n1 = NULL, n2 = NULL, event1 = NULL, event2 = NULL, incr = NULL, overall.hetstat = gs("overall.hetstat"), backtransf = gs("backtransf"), na.unident = gs("na.unident"), title = gs("title"), keepdata = gs("keepdata"), warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), nchar.trts = nchar.comps, ... )
TE |
Estimate of treatment effect, i.e. difference between
first and second treatment (e.g. log odds ratio, mean difference,
or log hazard ratio). Or an R object created with
|
seTE |
Standard error of treatment estimate. |
treat1 |
Label/Number for first treatment. |
treat2 |
Label/Number for second treatment. |
studlab |
An optional - but important! - vector with study
labels (see |
data |
An optional data frame containing the study information. |
subset |
An optional vector specifying a subset of studies to be used. |
inactive |
A character string defining the inactive treatment component (see Details). |
sep.comps |
A single character to define separator between treatment components. |
C.matrix |
C matrix (see Details). |
sm |
A character string indicating underlying summary measure,
e.g., |
level |
The level used to calculate confidence intervals for individual comparisons. |
level.ma |
The level used to calculate confidence intervals for network estimates. |
common |
A logical indicating whether a common effects / common effects network meta-analysis should be conducted. |
random |
A logical indicating whether a random effects network meta-analysis should be conducted. |
reference.group |
Reference treatment (first treatment is used if argument is missing). |
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment (default) or vice versa. This argument is
only considered if |
seq |
A character or numerical vector specifying the sequence of treatments in printouts. |
tau.preset |
An optional value for the square-root of the
between-study variance |
tol.multiarm |
A numeric for the tolerance for consistency of treatment estimates in multi-arm studies which are consistent by design. |
tol.multiarm.se |
A numeric for the tolerance for consistency
of standard errors in multi-arm studies which are consistent by
design. This check is not conducted if the argument is
|
details.chkmultiarm |
A logical indicating whether treatment estimates and / or variances of multi-arm studies with inconsistent results or negative multi-arm variances should be printed. |
details.chkident |
A logical indicating whether details on unidentifiable components should be printed. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.comps |
A numeric defining the minimum number of characters used to create unique names for components (see Details). |
sep.ia |
A single character to define separator for interactions. |
func.inverse |
R function used to calculate the pseudoinverse
of the Laplacian matrix L (see |
n1 |
Number of observations in first treatment group. |
n2 |
Number of observations in second treatment group. |
event1 |
Number of events in first treatment group. |
event2 |
Number of events in second treatment group. |
incr |
Numerical value added to cell frequencies. |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and forest plots. If
|
na.unident |
A logical indicating whether unidentifiable components and combinations should be set to missing values. |
title |
Title of meta-analysis / systematic review. |
keepdata |
A logical indicating whether original data(set) should be kept in netmeta object. |
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. |
nchar.trts |
Deprecated argument (replaced by
|
... |
Additional arguments (to catch deprecated arguments). |
Treatments in network meta-analysis (NMA) can be complex
interventions. Some treatments may be combinations of others or
have common components. The standard analysis provided by
netmeta
is a NMA where all existing (single or
combined) treatments are considered as different nodes in the
network. Exploiting the fact that some treatments are combinations
of common components, an additive component network meta-analysis
(CNMA) model can be used to evaluate the influence of individual
components. This model assumes that the effect of a treatment
combination is the sum of the effects of its components which
implies that common components cancel out in comparisons.
This R function can be used for disconnected networks. Use
netmeta
and netcomb
for connected
networks.
The additive CNMA model has been implemented using Bayesian methods (Mills et al., 2012; Welton et al., 2013). This function implements the additive model in a frequentist way (Rücker et al., 2020).
The underlying multivariate model is given by
with
vector of true treatment effects (differences) from individual studies,
design matrix describing the structure of the network,
parameter vector that represents the existing combined treatments,
matrix describing how the treatments are composed,
parameter vector representing the treatment components.
All parameters are estimated using weighted least squares regression.
Argument inactive
can be used to specify a single component
that does not have any therapeutic value. Accordingly, it is
assumed that the treatment effect of the combination of this
component with an additional treatment component is equal to the
treatment effect of the additional component alone.
Argument sep.comps
can be used to specify the separator
between individual components. By default, the matrix C is
calculated internally from treatment names. However, it is possible
to specify a different matrix using argument C.matrix
.
By default, component names are not abbreviated in
printouts. However, in order to get more concise printouts,
argument nchar.comps
can be used to define the minimum
number of characters for abbreviated component names (see
abbreviate
, argument minlength
). R function
treats
is utilised internally to create abbreviated
component names.
An object of classes discomb
and netcomb
with
corresponding print
, summary
, and forest
functions. The object is a list containing the following
components:
studlab |
Study labels. |
treat1 |
Label/Number for first treatment. |
treat2 |
Label/Number for second treatment. |
TE |
Estimate of treatment effect, i.e. difference between first and second treatment. |
seTE |
Standard error of treatment estimate. |
seTE.adj.common , seTE.adj.random
|
Standard error of treatment estimate, adjusted for multi-arm studies. |
event1 |
Number of events in first treatment group. |
event2 |
Number of events in second treatment group. |
n1 |
Number of observations in first treatment group. |
n2 |
Number of observations in second treatment group. |
k |
Total number of studies. |
m |
Total number of pairwise comparisons. |
n |
Total number of treatments. |
d |
Total number of designs (corresponding to the unique set of treatments compared within studies). |
c |
Total number of components. |
trts |
Treatments included in network meta-analysis. |
comps |
Unique list of components present in the network. |
TE.cnma.common , TE.cnma.random
|
A vector of length m of consistent treatment effects estimated by the additive (common and random effects) model. |
seTE.cnma.common , seTE.cnma.random
|
A vector of length m with standard errors estimated by the additive (common and random effects) model. |
lower.cnma.common , lower.cnma.random
|
A vector of length m of lower confidence interval limits for consistent treatment effects estimated by the additive (common and random effects) model. |
upper.cnma.common , upper.cnma.random
|
A vector of length m of upper confidence interval limits for consistent treatment effects estimated by the additive (common and random effects) model. |
statistic.cnma.common , statistic.cnma.random
|
A vector of length m of z-values for the test of an overall effect estimated by the additive (common and random effects) model. |
pval.cnma.common , pval.cnma.random
|
A vector of length m of p-values for the test of an overall effect estimated by the additive (common and random effects) model. |
TE.common , TE.random
|
nxn matrix with overall treatment effects estimated by the additive (common and random effects) model. |
seTE.common , seTE.random
|
nxn matrix with standard errors estimated by the additive (common and random effects) model. |
lower.common , upper.common , lower.random , upper.random
|
nxn matrices with lower and upper confidence interval limits estimated by the additive (common and random effects) model. |
statistic.common , pval.common , statistic.random , pval.random
|
nxn matrices with z-values and p-values for test of overall effect estimated by the additive (common and random effects) model. |
Comp.common , Comp.random
|
A vector of component effects (common and random effects model). |
seComp.common , seComp.random
|
A vector with corresponding standard errors (common and random effects model). |
lower.Comp.common , lower.Comp.random
|
A vector with lower confidence limits for components (common and random effects model). |
upper.Comp.common , upper.Comp.random
|
A vector with upper confidence limits for components (common and random effects model). |
statistic.Comp.common , statistic.Comp.random
|
A vector with z-values for the overall effect of components (common and random effects model). |
pval.Comp.common , pval.Comp.random
|
A vector with p-values for the overall effect of components (common and random effects model). |
Comb.common , Comb.random
|
A vector of combination effects (common and random effects model). |
seComb.common , seComb.random
|
A vector with corresponding standard errors (common and random effects model). |
lower.Comb.common , lower.Comb.random
|
A vector with lower confidence limits for combinations (common and random effects model). |
upper.Comb.common , upper.Comb.random
|
A vector with upper confidence limits for combinations (common and random effects model). |
statistic.Comb.common , statistic.Comb.random
|
A vector with z-values for the overall effect of combinations (common and random effects model). |
pval.Comb.common , pval.Comb.random
|
A vector with p-values for the overall effect of combinations (common and random effects model). |
Q.additive |
Overall heterogeneity / inconsistency statistic (additive model). |
df.Q.additive |
Degrees of freedom for test of heterogeneity / inconsistency (additive model). |
pval.Q.additive |
P-value for test of heterogeneity / inconsistency (additive model). |
tau |
Square-root of between-study variance (additive model). |
I2 |
I-squared (additive model). |
Q.standard |
Overall heterogeneity / inconsistency statistic (standard model). |
df.Q.standard |
Degrees of freedom for test of heterogeneity / inconsistency (standard model). |
pval.Q.standard |
P-value for test of heterogeneity / inconsistency (standard model). |
Q.diff |
Test statistic for difference in goodness of fit between standard and additive model. |
df.Q.diff |
Degrees of freedom for difference in goodness of fit between standard and additive model. |
pval.Q.diff |
P-value for difference in goodness of fit between standard and additive model. |
X.matrix |
Design matrix (mxn). |
B.matrix |
Edge-vertex incidence matrix (mxn). |
C.matrix |
As defined above. |
sm |
Summary measure. |
level.ma |
Level for confidence intervals. |
common , random , tau.preset
|
As defined above. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.comps |
A numeric defining the minimum number of characters used to create unique component names. |
inactive , sep.comps
|
As defined above. |
backtransf |
A logical indicating whether results should be back transformed in printouts and forest plots. |
title |
Title of meta-analysis / systematic review. |
x |
As defined above. |
call |
Function call. |
version |
Version of R package netmeta used to create object. |
This function calculates effects for individual components and complex interventions present in the network.
R function netcomplex
can be used to calculate the
effect for arbitrary complex interventions in a component network
meta-analysis. Furthermore, R function netcomparison
can be used to calculate the effect for comparisons of two
arbitrary complex intervention in a component network
meta-analysis.
Gerta Rücker [email protected], Guido Schwarzer [email protected]
König J, Krahn U, Binder H (2013): Visualizing the flow of evidence in network meta-analysis and characterizing mixed treatment comparisons. Statistics in Medicine, 32, 5414–29
Mills EJ, Thorlund K, Ioannidis JP (2012): Calculating additive treatment effects from multiple randomized trials provides useful estimates of combination therapies. Journal of Clinical Epidemiology, 65, 1282–8
Rücker G, Petropoulou M, Schwarzer G (2020): Network meta-analysis of multicomponent interventions. Biometrical Journal, 62, 808–21
Welton NJ, Caldwell DM, Adamopoulos E, Vedhara K (2009): Mixed treatment comparison meta-analysis of complex interventions: psychological interventions in coronary heart disease. American Journal of Epidemiology, 169: 1158–65
netcomb
, forest.netcomb
,
summary.netcomb
, netmeta
,
netconnection
, netcomplex
,
netcomparison
# Artificial dataset # t1 <- c("A + B", "A + C", "A" , "A" , "D", "D", "E") t2 <- c("C" , "B" , "B + C", "A + D", "E", "F", "F") # mean <- c(4.1, 2.05, 0, 0, 0.1, 0.1, 0.05) se.mean <- rep(0.1, 7) # study <- paste("study", c(1:4, 5, 5, 5)) # dat <- data.frame(mean, se.mean, t1, t2, study, stringsAsFactors = FALSE) # trts <- c("A", "A + B", "A + C", "A + D", "B", "B + C", "C", "D", "E", "F") # comps <- LETTERS[1:6] # Use netconnection() to display network information # netconnection(t1, t2, study) dc1 <- discomb(mean, se.mean, t1, t2, study, seq = trts) dc1 forest(dc1, ref = "F") # Define C matrix manually (which will produce the same results) # C <- rbind(c(1, 0, 0, 0, 0, 0), # A c(1, 1, 0, 0, 0, 0), # A + B c(1, 0, 1, 0, 0, 0), # A + C c(1, 0, 0, 1, 0, 0), # A + D c(0, 1, 0, 0, 0, 0), # B c(0, 1, 1, 0, 0, 0), # B + C c(0, 0, 1, 0, 0, 0), # C c(0, 0, 0, 1, 0, 0), # D c(0, 0, 0, 0, 1, 0), # E c(0, 0, 0, 0, 0, 1)) # F # colnames(C) <- comps rownames(C) <- trts # dc2 <- discomb(mean, se.mean, t1, t2, study, seq = trts, C.matrix = C) # # Compare C matrices # all.equal(dc1$C.matrix, dc2$C.matrix)
# Artificial dataset # t1 <- c("A + B", "A + C", "A" , "A" , "D", "D", "E") t2 <- c("C" , "B" , "B + C", "A + D", "E", "F", "F") # mean <- c(4.1, 2.05, 0, 0, 0.1, 0.1, 0.05) se.mean <- rep(0.1, 7) # study <- paste("study", c(1:4, 5, 5, 5)) # dat <- data.frame(mean, se.mean, t1, t2, study, stringsAsFactors = FALSE) # trts <- c("A", "A + B", "A + C", "A + D", "B", "B + C", "C", "D", "E", "F") # comps <- LETTERS[1:6] # Use netconnection() to display network information # netconnection(t1, t2, study) dc1 <- discomb(mean, se.mean, t1, t2, study, seq = trts) dc1 forest(dc1, ref = "F") # Define C matrix manually (which will produce the same results) # C <- rbind(c(1, 0, 0, 0, 0, 0), # A c(1, 1, 0, 0, 0, 0), # A + B c(1, 0, 1, 0, 0, 0), # A + C c(1, 0, 0, 1, 0, 0), # A + D c(0, 1, 0, 0, 0, 0), # B c(0, 1, 1, 0, 0, 0), # B + C c(0, 0, 1, 0, 0, 0), # C c(0, 0, 0, 1, 0, 0), # D c(0, 0, 0, 0, 1, 0), # E c(0, 0, 0, 0, 0, 1)) # F # colnames(C) <- comps rownames(C) <- trts # dc2 <- discomb(mean, se.mean, t1, t2, study, seq = trts, C.matrix = C) # # Compare C matrices # all.equal(dc1$C.matrix, dc2$C.matrix)
This dataset comes from a systematic review aiming to determine the effects of eight antithrombotic treatments in reducing the incidence of major thrombotic events in patients with non-valvular atrial fibrillation (Dogliotti et al., 2014). The review included 20 studies (79,808 participants), four of which were three-arm studies. The primary outcome is stroke reduction.
A data frame with the following columns:
study | study label |
id | study ID |
treatment | treatment |
stroke | number of strokes |
total | number of individuals in treatment arm |
Dogliotti A, Paolasso E, Giugliano RP (2014): Current and new oral antithrombotics in non-valvular atrial fibrillation: a network meta-analysis of 79 808 patients. Heart, 100, 396–405
data(Dogliotti2014) Dogliotti2014 ## Not run: # 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. # p1 <- pairwise(treatment, stroke, total, studlab = study, data = Dogliotti2014, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis # netmetabin(p1, ref = "plac") ## End(Not run)
data(Dogliotti2014) Dogliotti2014 ## Not run: # 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. # p1 <- pairwise(treatment, stroke, total, studlab = study, data = Dogliotti2014, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis # netmetabin(p1, ref = "plac") ## End(Not run)
Network meta-analysis comparing inhaled medications in patients with chronic obstructive pulmonary disease.
A data frame with the following columns:
id | study ID |
treatment | treatment |
death | mortality |
randomized | number of individuals in treatment arm |
Dong Y-H, Lin H-H, Shau W-Y, Wu Y-C, Chang C-H, Lai M-S (2013): Comparative safety of inhaled medications in patients with chronic obstructive pulmonary disease: systematic review and mixed treatment comparison meta-analysis of randomised controlled trials. Thorax, 68, 48–56
dat.dong2013
,
pairwise
, metabin
,
netmetabin
Dong2013 <- dat.dong2013 # 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. # p1 <- pairwise(treatment, death, randomized, studlab = id, data = Dong2013, sm = "OR") # Only consider first ten studies (to reduce runtime of example) # p1.10 <- subset(p1, id <= 10) # Conduct Mantel-Haenszel network meta-analysis # netmetabin(p1.10, ref = "plac") ## Not run: # Conduct Mantel-Haenszel network meta-analysis for the whole # dataset # p2 <- pairwise(treatment, death, randomized, studlab = id, data = Dong2013, sm = "OR") netmetabin(p2, ref = "plac") ## End(Not run)
Dong2013 <- dat.dong2013 # 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. # p1 <- pairwise(treatment, death, randomized, studlab = id, data = Dong2013, sm = "OR") # Only consider first ten studies (to reduce runtime of example) # p1.10 <- subset(p1, id <= 10) # Conduct Mantel-Haenszel network meta-analysis # netmetabin(p1.10, ref = "plac") ## Not run: # Conduct Mantel-Haenszel network meta-analysis for the whole # dataset # p2 <- pairwise(treatment, death, randomized, studlab = id, data = Dong2013, sm = "OR") netmetabin(p2, ref = "plac") ## End(Not run)
Forest plot to show network estimates of two or more network meta-analyses.
## S3 method for class 'netbind' forest( x, pooled = ifelse(x$x$random, "random", "common"), equal.size = gs("equal.size"), leftcols = "studlab", leftlabs = "Treatment", rightcols = c("effect", "ci"), rightlabs = NULL, subset.treatments, digits = gs("digits.forest"), digits.prop = max(gs("digits.pval") - 2, 2), backtransf = x$backtransf, lab.NA = gs("lab.NA"), smlab, ... ) ## S3 method for class 'netbind' plot(x, ...)
## S3 method for class 'netbind' forest( x, pooled = ifelse(x$x$random, "random", "common"), equal.size = gs("equal.size"), leftcols = "studlab", leftlabs = "Treatment", rightcols = c("effect", "ci"), rightlabs = NULL, subset.treatments, digits = gs("digits.forest"), digits.prop = max(gs("digits.pval") - 2, 2), backtransf = x$backtransf, lab.NA = gs("lab.NA"), smlab, ... ) ## S3 method for class 'netbind' plot(x, ...)
x |
An object of class |
pooled |
A character string indicating whether results for the
common ( |
equal.size |
A logical indicating whether all squares should be of equal size. Otherwise, the square size is proportional to the precision of estimates. |
leftcols |
A character vector specifying columns to be plotted on the left side of the forest plot (see Details). |
leftlabs |
A character vector specifying labels for columns on left side of the forest plot. |
rightcols |
A character vector specifying columns to be plotted on the right side of the forest plot (see Details). |
rightlabs |
A character vector specifying labels for columns on right side of the forest plot. |
subset.treatments |
A character vector specifying treatments to show in forest plot as comparators to the reference. |
digits |
Minimal number of significant digits for treatment
effects and confidence intervals, see |
digits.prop |
Minimal number of significant digits for the direct evidence proportion. |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
lab.NA |
A character string to label missing values. |
smlab |
A label printed at top of figure. By default, text indicating either common or random effects model is printed. |
... |
Additional arguments for |
A forest plot, also called confidence interval plot, is drawn in the active graphics window.
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. If argument rightcols
is
FALSE
, no columns will be plotted on the right side.
For more information see help page of forest.meta
function.
Guido Schwarzer [email protected]
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Standard random effects NMA model (with placebo as reference # treatment) # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive CNMA model with placebo as inactive component and # reference # nc1 <- netcomb(net1, inactive = "placebo") # Combine results of standard NMA and CNMA # nb1 <- netbind(nc1, net1, name = c("Additive CNMA", "Standard NMA"), col.study = c("red", "black"), col.square = c("red", "black")) forest(nb1, col.subgroup = "black", addrow.subgroups = FALSE, fontsize = 10, spacing = 0.7, squaresize = 0.9, label.left = "Favours Placebo", label.right = "Favours other")
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Standard random effects NMA model (with placebo as reference # treatment) # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive CNMA model with placebo as inactive component and # reference # nc1 <- netcomb(net1, inactive = "placebo") # Combine results of standard NMA and CNMA # nb1 <- netbind(nc1, net1, name = c("Additive CNMA", "Standard NMA"), col.study = c("red", "black"), col.square = c("red", "black")) forest(nb1, col.subgroup = "black", addrow.subgroups = FALSE, fontsize = 10, spacing = 0.7, squaresize = 0.9, label.left = "Favours Placebo", label.right = "Favours other")
Draws a forest plot in the active graphics window (using grid graphics system).
## S3 method for class 'netcomb' forest( x, pooled = ifelse(x$random, "random", "common"), reference.group = x$reference.group, baseline.reference = x$baseline.reference, equal.size = gs("equal.size"), leftcols = "studlab", leftlabs = "Treatment", rightcols = c("effect", "ci"), rightlabs = NULL, digits = gs("digits.forest"), smlab = NULL, sortvar = x$seq, overall.hetstat = gs("overall.hetstat"), backtransf = x$backtransf, lab.NA = gs("lab.NA"), add.data, addrows.below.overall = if (x$overall.hetstat) 2 else gs("addrows.below.overall"), drop.reference.group = gs("drop.reference.group"), ... ) ## S3 method for class 'netcomb' plot(x, ...)
## S3 method for class 'netcomb' forest( x, pooled = ifelse(x$random, "random", "common"), reference.group = x$reference.group, baseline.reference = x$baseline.reference, equal.size = gs("equal.size"), leftcols = "studlab", leftlabs = "Treatment", rightcols = c("effect", "ci"), rightlabs = NULL, digits = gs("digits.forest"), smlab = NULL, sortvar = x$seq, overall.hetstat = gs("overall.hetstat"), backtransf = x$backtransf, lab.NA = gs("lab.NA"), add.data, addrows.below.overall = if (x$overall.hetstat) 2 else gs("addrows.below.overall"), drop.reference.group = gs("drop.reference.group"), ... ) ## S3 method for class 'netcomb' plot(x, ...)
x |
An object of class |
pooled |
A character string indicating whether results for the
common ( |
reference.group |
Reference treatment(s). |
baseline.reference |
A logical indicating whether results should be expressed as comparisons of other treatments versus the reference treatment (default) or vice versa. |
equal.size |
A logical indicating whether all squares should be of equal size. Otherwise, the square size is proportional to the precision of estimates. |
leftcols |
A character vector specifying (additional) columns
to be plotted on the left side of the forest plot or a logical
value (see |
leftlabs |
A character vector specifying labels for
(additional) columns on left side of the forest plot (see
|
rightcols |
A character vector specifying (additional) columns
to be plotted on the right side of the forest plot or a logical
value (see |
rightlabs |
A character vector specifying labels for
(additional) columns on right side of the forest plot (see
|
digits |
Minimal number of significant digits for treatment
effects and confidence intervals, see |
smlab |
A label printed at top of figure. By default, text indicating either common or random effects model is printed. |
sortvar |
An optional vector used to sort the individual studies (must be of same length as the total number of treatments). |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
lab.NA |
A character string to label missing values. |
add.data |
An optional data frame with additional columns to print in forest plot (see Details). |
addrows.below.overall |
A numeric value indicating how many empty rows are printed between meta-analysis results and heterogeneity statistics. |
drop.reference.group |
A logical indicating whether the reference group should be printed in the forest plot. |
... |
Additional arguments for |
A forest plot, also called confidence interval plot, is drawn in the active graphics window.
Argument sortvar
can be either a numeric or character vector
with length of number of treatments. If sortvar
is numeric
the order
function is utilised internally to
determine the order of values. If sortvar
is character it
must be a permutation of the treatment names. It is also possible
to to sort by treatment comparisons (sortvar = TE
, etc.),
standard error (sortvar = seTE
), and number of studies with
direct treatment comparisons (sortvar = k
).
Argument add.data
can be used to add additional columns to
the forest plot. This argument must be a data frame with the same
row names as the treatment effects matrices in R object x
,
i.e., x$TE.common
or x$TE.random
.
For more information see help page of forest.meta
function.
Guido Schwarzer [email protected]
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # forest(nc1) ## Not run: # Specify, order of treatments # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Ind drug", "Hypericum", "Face-to-face CBT", "Face-to-face PST", "Face-to-face interpsy", "Face-to-face psychodyn", "Other face-to-face", "Remote CBT", "Self-help CBT", "No contact CBT", "Face-to-face CBT + SSRI", "Face-to-face interpsy + SSRI", "Face-to-face PST + SSRI", "UC", "Placebo") # # Note, three treatments are actually combinations of 'SSRI' with # other components: # "Face-to-face CBT + SSRI", # "Face-to-face interpsy + SSRI", # "Face-to-face PST + SSRI" # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, ref = "placebo", seq = trts, sm = "OR", common = FALSE) # net2 # Additive model for treatment components (with placebo as inactive # treatment) # nc2 <- netcomb(net2, inactive = "placebo") # forest(nc2) ## End(Not run)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # forest(nc1) ## Not run: # Specify, order of treatments # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Ind drug", "Hypericum", "Face-to-face CBT", "Face-to-face PST", "Face-to-face interpsy", "Face-to-face psychodyn", "Other face-to-face", "Remote CBT", "Self-help CBT", "No contact CBT", "Face-to-face CBT + SSRI", "Face-to-face interpsy + SSRI", "Face-to-face PST + SSRI", "UC", "Placebo") # # Note, three treatments are actually combinations of 'SSRI' with # other components: # "Face-to-face CBT + SSRI", # "Face-to-face interpsy + SSRI", # "Face-to-face PST + SSRI" # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, ref = "placebo", seq = trts, sm = "OR", common = FALSE) # net2 # Additive model for treatment components (with placebo as inactive # treatment) # nc2 <- netcomb(net2, inactive = "placebo") # forest(nc2) ## End(Not run)
Draws a forest plot in the active graphics window (using grid graphics system).
## S3 method for class 'netcomparison' forest( x, pooled = ifelse(x$random, "random", "common"), leftcols = c("studlab", "treat1", "treat2"), leftlabs = c("Comparison", "Trt 1", "Trt 2"), rightcols = c("effect", "ci", "statistic", "pval"), rightlabs = c(NA, NA, "z", "p-value"), nchar.comps = x$nchar.trts, digits = gs("digits.forest"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), smlab = NULL, backtransf = x$backtransf, lab.NA = gs("lab.NA"), equal.size = gs("equal.size"), ... ) ## S3 method for class 'netcomparison' plot(x, ...)
## S3 method for class 'netcomparison' forest( x, pooled = ifelse(x$random, "random", "common"), leftcols = c("studlab", "treat1", "treat2"), leftlabs = c("Comparison", "Trt 1", "Trt 2"), rightcols = c("effect", "ci", "statistic", "pval"), rightlabs = c(NA, NA, "z", "p-value"), nchar.comps = x$nchar.trts, digits = gs("digits.forest"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), smlab = NULL, backtransf = x$backtransf, lab.NA = gs("lab.NA"), equal.size = gs("equal.size"), ... ) ## S3 method for class 'netcomparison' plot(x, ...)
x |
An object of class |
pooled |
A character string indicating whether results for the
common ( |
leftcols |
A character vector specifying (additional) columns
to be plotted on the left side of the forest plot or a logical
value (see |
leftlabs |
A character vector specifying labels for
(additional) columns on left side of the forest plot (see
|
rightcols |
A character vector specifying (additional) columns
to be plotted on the right side of the forest plot or a logical
value (see |
rightlabs |
A character vector specifying labels for
(additional) columns on right side of the forest plot (see
|
nchar.comps |
A numeric defining the minimum number of characters used to create unique names for components. |
digits |
Minimal number of significant digits for treatment
effects and confidence intervals, see |
digits.stat |
Minimal number of significant digits for tests
of overall effect, see |
digits.pval |
Minimal number of significant digits for p-value
of overall effects, see |
smlab |
A label printed at top of figure. By default, text indicating either common or random effects model is printed. |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
lab.NA |
A character string to label missing values. |
equal.size |
A logical indicating whether all squares should be of equal size. Otherwise, the square size is proportional to the precision of estimates. |
... |
Additional arguments for |
A forest plot, also called confidence interval plot, is drawn in
the active graphics window. For more information see help page of
forest.meta
function.
Guido Schwarzer [email protected]
netcomparison
, netcomb
,
discomb
, forest.meta
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Some comparisons # t1 <- c("F + TCA", "F + Plac", "SSRI + Plac + TCA") t2 <- c("UC", "Plac", "UC") # netcomparison(nc1, t1, t2) # forest(netcomparison(nc1, t1, t2)) forest(netcomparison(nc1, t1, t2), nchar.comps = 4) forest(netcomparison(nc1, c("F", "TCA"), "UC"), nchar.comps = 4)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Some comparisons # t1 <- c("F + TCA", "F + Plac", "SSRI + Plac + TCA") t2 <- c("UC", "Plac", "UC") # netcomparison(nc1, t1, t2) # forest(netcomparison(nc1, t1, t2)) forest(netcomparison(nc1, t1, t2), nchar.comps = 4) forest(netcomparison(nc1, c("F", "TCA"), "UC"), nchar.comps = 4)
Draws a forest plot in the active graphics window (using grid graphics system).
## S3 method for class 'netcomplex' forest( x, pooled = ifelse(x$random, "random", "common"), leftcols = "studlab", leftlabs = NULL, rightcols = c("effect", "ci", "statistic", "pval"), rightlabs = c(NA, NA, "z", "p-value"), nchar.comps = x$nchar.trts, digits = gs("digits.forest"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), smlab = NULL, backtransf = x$backtransf, lab.NA = gs("lab.NA"), equal.size = gs("equal.size"), ... ) ## S3 method for class 'netcomplex' plot(x, ...)
## S3 method for class 'netcomplex' forest( x, pooled = ifelse(x$random, "random", "common"), leftcols = "studlab", leftlabs = NULL, rightcols = c("effect", "ci", "statistic", "pval"), rightlabs = c(NA, NA, "z", "p-value"), nchar.comps = x$nchar.trts, digits = gs("digits.forest"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), smlab = NULL, backtransf = x$backtransf, lab.NA = gs("lab.NA"), equal.size = gs("equal.size"), ... ) ## S3 method for class 'netcomplex' plot(x, ...)
x |
An object of class |
pooled |
A character string indicating whether results for the
common ( |
leftcols |
A character vector specifying (additional) columns
to be plotted on the left side of the forest plot or a logical
value (see |
leftlabs |
A character vector specifying labels for
(additional) columns on left side of the forest plot (see
|
rightcols |
A character vector specifying (additional) columns
to be plotted on the right side of the forest plot or a logical
value (see |
rightlabs |
A character vector specifying labels for
(additional) columns on right side of the forest plot (see
|
nchar.comps |
A numeric defining the minimum number of characters used to create unique names for components. |
digits |
Minimal number of significant digits for treatment
effects and confidence intervals, see |
digits.stat |
Minimal number of significant digits for tests
of overall effect, see |
digits.pval |
Minimal number of significant digits for p-value
of overall effects, see |
smlab |
A label printed at top of figure. By default, text indicating either common or random effects model is printed. |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
lab.NA |
A character string to label missing values. |
equal.size |
A logical indicating whether all squares should be of equal size. Otherwise, the square size is proportional to the precision of estimates. |
... |
Additional arguments for |
A forest plot, also called confidence interval plot, is drawn in
the active graphics window. For more information see help page of
forest.meta
function.
Guido Schwarzer [email protected]
netcomplex
, netcomb
,
discomb
, forest.meta
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Some complex interventions # ints <- c("F + TCA", "F + Plac", "SSRI + Plac + TCA") netcomplex(nc1, ints) # forest(netcomplex(nc1, ints)) forest(netcomplex(nc1, ints), nchar.comps = 4) # Component effects # forest(netcomplex(nc1, nc1$comps))
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Some complex interventions # ints <- c("F + TCA", "F + Plac", "SSRI + Plac + TCA") netcomplex(nc1, ints) # forest(netcomplex(nc1, ints)) forest(netcomplex(nc1, ints), nchar.comps = 4) # Component effects # forest(netcomplex(nc1, nc1$comps))
Draws a forest plot in the active graphics window (using grid graphics system).
## S3 method for class 'netmeta' forest( x, pooled = ifelse(x$random, "random", "common"), reference.group = x$reference.group, baseline.reference = x$baseline.reference, labels = x$trts, equal.size = gs("equal.size"), leftcols = "studlab", leftlabs, rightcols = c("effect", "ci"), rightlabs, digits = gs("digits.forest"), small.values = x$small.values, nsim = gs("nsim"), digits.prop = 2, smlab = NULL, sortvar = x$seq, overall.hetstat = gs("overall.hetstat"), print.tau2 = gs("forest.tau2"), print.tau = gs("forest.tau"), print.I2 = gs("forest.I2"), backtransf = x$backtransf, lab.NA = gs("lab.NA"), add.data, addrows.below.overall = if (x$overall.hetstat) 2 else gs("addrows.below.overall"), drop.reference.group = gs("drop.reference.group"), col.subgroup = "black", print.subgroup.name = FALSE, ... ) ## S3 method for class 'netmeta' plot(x, ...)
## S3 method for class 'netmeta' forest( x, pooled = ifelse(x$random, "random", "common"), reference.group = x$reference.group, baseline.reference = x$baseline.reference, labels = x$trts, equal.size = gs("equal.size"), leftcols = "studlab", leftlabs, rightcols = c("effect", "ci"), rightlabs, digits = gs("digits.forest"), small.values = x$small.values, nsim = gs("nsim"), digits.prop = 2, smlab = NULL, sortvar = x$seq, overall.hetstat = gs("overall.hetstat"), print.tau2 = gs("forest.tau2"), print.tau = gs("forest.tau"), print.I2 = gs("forest.I2"), backtransf = x$backtransf, lab.NA = gs("lab.NA"), add.data, addrows.below.overall = if (x$overall.hetstat) 2 else gs("addrows.below.overall"), drop.reference.group = gs("drop.reference.group"), col.subgroup = "black", print.subgroup.name = FALSE, ... ) ## S3 method for class 'netmeta' plot(x, ...)
x |
An object of class |
pooled |
A character string indicating whether results for the
common ( |
reference.group |
Reference treatment(s). |
baseline.reference |
A logical indicating whether results should be expressed as comparisons of other treatments versus the reference treatment (default) or vice versa. |
labels |
An optional vector with treatment labels. |
equal.size |
A logical indicating whether all squares should be of equal size. Otherwise, the square size is proportional to the precision of estimates. |
leftcols |
A character vector specifying 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 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). |
digits |
Minimal number of significant digits for treatment
effects and confidence intervals, see |
small.values |
A character string specifying whether small
treatment effects indicate a beneficial ( |
nsim |
Number of simulations to calculate SUCRAs. |
digits.prop |
Minimal number of significant digits for
P-scores, SUCRAs and direct evidence proportions, see
|
smlab |
A label printed at top of figure. By default, text indicating either common or random effects model is printed. |
sortvar |
An optional vector used to sort treatments (must be of same length as the total number of treatments). |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
print.tau2 |
A logical value indicating whether to print the
value of the between-study variance |
print.tau |
A logical value indicating whether to print
|
print.I2 |
A logical value indicating whether to print the value of the I-squared statistic. |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
lab.NA |
A character string to label missing values. |
add.data |
An optional data frame with additional columns to print in forest plot (see Details). |
addrows.below.overall |
A numeric value indicating how many empty rows are printed between meta-analysis results and heterogeneity statistics. |
drop.reference.group |
A logical indicating whether the reference group should be printed in the forest plot. |
col.subgroup |
The colour to print information on subgroups. |
print.subgroup.name |
A logical indicating whether the name of the grouping variable should be printed in front of the group labels. |
... |
Additional arguments for |
A forest plot, also called confidence interval plot, is drawn in the active graphics window.
Argument sortvar
can be either a numeric or character vector
with length of number of treatments. If sortvar
is numeric
the order
function is utilised internally to
determine the order of values. If sortvar
is character it
must be a permutation of the treatment names. It is also possible
to provide either sortvar = Pscore
, sortvar =
"Pscore"
, sortvar = -Pscore
, or sortvar = "-Pscore"
in order to sort treatments according to the ranking generated by
netrank
which is called internally. It is also
possible to use "SUCRA" instead of "Pscore". Similar expressions
are possible to sort by treatment comparisons (sortvar = TE
,
etc.), standard error (sortvar = seTE
), number of studies
with direct treatment comparisons (sortvar = k
), and direct
evidence proportion (sortvar = prop.direct
, see also
netmeasures
).
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 following columns are available:
Name | Definition |
"studlab" |
Treatments |
"TE" |
Network estimates (either from common or random effects model) |
"seTE" |
Corresponding standard errors |
"Pscore" |
P-scores (see netrank ) |
"SUCRA" |
SUCRAs (see netrank ) |
"n.trts" |
Number of participants per treatment arm |
"k" |
Number of studies in pairwise comparisons |
"prop.direct" |
Direct evidence proportions (see
netmeasures ) |
"effect" |
(Back-transformed) network estimates |
"ci" |
Confidence intervals |
"effect.ci" |
(Back-transformed) network estimates and confidence intervals |
As a sidenote, the rather odd column name "studlab"
to
describe the treatment comparisons comes from internally calling
forest.meta
which uses study labels as the essential
information.
Argument add.data
can be used to add additional columns to
the forest plot. This argument must be a data frame with row names
equal to the treatment names in R object x
, i.e.,
x$trts
.
See help page of forest.meta
for more information on
the generation of forest plots and additional arguments.
Guido Schwarzer [email protected]
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) forest(net1) ## Not run: data(Senn2013) # Conduct network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") forest(net2, ref = "plac") forest(net2, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", rightcols = FALSE) # Random effects effect model # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", common = FALSE) forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference") # Add column with P-Scores on right side of forest plot # forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", rightcols = c("effect", "ci", "Pscore"), just.addcols = "right") # Add column with P-Scores on left side of forest plot # forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", leftcols = c("studlab", "Pscore"), just.addcols = "right") # Sort forest plot by descending P-Score # forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", rightcols = c("effect", "ci", "Pscore"), just.addcols = "right", sortvar = -Pscore) # Drop reference group and sort by and print number of studies with # direct treatment comparisons # forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", leftcols = c("studlab", "k"), leftlabs = c("Contrast\nto Placebo", "Direct\nComparisons"), sortvar = -k, drop = TRUE, smlab = "Random Effects Model") ## End(Not run)
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) forest(net1) ## Not run: data(Senn2013) # Conduct network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") forest(net2, ref = "plac") forest(net2, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", rightcols = FALSE) # Random effects effect model # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", common = FALSE) forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference") # Add column with P-Scores on right side of forest plot # forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", rightcols = c("effect", "ci", "Pscore"), just.addcols = "right") # Add column with P-Scores on left side of forest plot # forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", leftcols = c("studlab", "Pscore"), just.addcols = "right") # Sort forest plot by descending P-Score # forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", rightcols = c("effect", "ci", "Pscore"), just.addcols = "right", sortvar = -Pscore) # Drop reference group and sort by and print number of studies with # direct treatment comparisons # forest(net3, xlim = c(-1.5, 1), ref = "plac", xlab = "HbA1c difference", leftcols = c("studlab", "k"), leftlabs = c("Contrast\nto Placebo", "Direct\nComparisons"), sortvar = -k, drop = TRUE, smlab = "Random Effects Model") ## End(Not run)
Forest plot to show direct and indirect evidence in network meta-analysis. Furthermore, estimates from network meta-analysis as well as prediction intervals can be printed.
## S3 method for class 'netsplit' forest( x, pooled = ifelse(x$x$random, "random", "common"), show = x$show, subgroup = "comparison", overall = x$overall, direct = x$direct, indirect = x$indirect, prediction = x$prediction, only.reference = x$only.reference, sortvar = NULL, subset = NULL, text.overall = "Network estimate", text.direct = "Direct estimate", text.indirect = "Indirect estimate", text.predict = "Prediction interval", type.overall, type.direct, type.indirect, col.square = "gray", col.square.lines = col.square, col.inside = "white", col.diamond = "gray", col.diamond.lines = "black", col.predict = "red", col.predict.lines = "black", col.subgroup = "black", equal.size = TRUE, leftcols, leftlabs, rightcols = c("effect", "ci"), rightlabs = NULL, digits = gs("digits.forest"), digits.prop = max(gs("digits.pval") - 2, 2), backtransf = x$backtransf, lab.NA = "", smlab, ... ) ## S3 method for class 'netsplit' plot(x, ...)
## S3 method for class 'netsplit' forest( x, pooled = ifelse(x$x$random, "random", "common"), show = x$show, subgroup = "comparison", overall = x$overall, direct = x$direct, indirect = x$indirect, prediction = x$prediction, only.reference = x$only.reference, sortvar = NULL, subset = NULL, text.overall = "Network estimate", text.direct = "Direct estimate", text.indirect = "Indirect estimate", text.predict = "Prediction interval", type.overall, type.direct, type.indirect, col.square = "gray", col.square.lines = col.square, col.inside = "white", col.diamond = "gray", col.diamond.lines = "black", col.predict = "red", col.predict.lines = "black", col.subgroup = "black", equal.size = TRUE, leftcols, leftlabs, rightcols = c("effect", "ci"), rightlabs = NULL, digits = gs("digits.forest"), digits.prop = max(gs("digits.pval") - 2, 2), backtransf = x$backtransf, lab.NA = "", smlab, ... ) ## S3 method for class 'netsplit' plot(x, ...)
x |
An object of class |
pooled |
A character string indicating whether results for the
common ( |
show |
A character string indicating which comparisons should be printed (see Details). |
subgroup |
A character string indicating which layout should
be used in forest plot: subgroups by comparisons
( |
overall |
A logical indicating whether network meta-analysis estimates should be printed. |
direct |
A logical indicating whether direct estimates should be printed. |
indirect |
A logical indicating whether indirect estimates should be printed. |
prediction |
A logical indicating whether prediction intervals should be printed. |
only.reference |
A logical indicating whether only comparisons with the reference group should be printed. |
sortvar |
An optional vector used to sort comparisons (must be of same length as the total number of comparisons). |
subset |
An optional logical vector specifying a subset of comparisons to print (must be of same length as the total number of comparisons) . |
text.overall |
A character string used in the plot to label the network estimates. |
text.direct |
A character string used in the plot to label the direct estimates. |
text.indirect |
A character string used in the plot to label the indirect estimates. |
text.predict |
A character string used in the plot to label the prediction interval. |
type.overall |
A character string specifying how to plot treatment effects and confidence intervals for the overall network evidence. |
type.direct |
A character string specifying how to plot treatment effects and confidence intervals for the direct evidence. |
type.indirect |
A character string specifying how to plot treatment effects and confidence intervals for the indirect evidence. |
col.square |
The colour for squares. |
col.square.lines |
The colour for the outer lines of squares. |
col.inside |
The colour for results and confidence limits if confidence limits are completely within squares squares. |
col.diamond |
The colour of diamonds. |
col.diamond.lines |
The colour of the outer lines of diamonds. |
col.predict |
Background colour of prediction intervals. |
col.predict.lines |
Colour of outer lines of prediction intervals. |
col.subgroup |
The colour to print information on subgroups, i.e., pairwise comparisons. |
equal.size |
A logical indicating whether all squares should be of equal size. Otherwise, the square size is proportional to the precision of estimates. |
leftcols |
A character vector specifying columns to be plotted on the left side of the forest plot (see Details). |
leftlabs |
A character vector specifying labels for columns on left side of the forest plot. |
rightcols |
A character vector specifying columns to be plotted on the right side of the forest plot (see Details). |
rightlabs |
A character vector specifying labels for columns on right side of the forest plot. |
digits |
Minimal number of significant digits for treatment
effects and confidence intervals, see |
digits.prop |
Minimal number of significant digits for the direct evidence proportion. |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
lab.NA |
A character string to label missing values. |
smlab |
A label printed at top of figure. By default, text indicating either common or random effects model is printed. |
... |
Additional arguments for |
A forest plot, also called confidence interval plot, is drawn in the active graphics window.
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. If argument rightcols
is
FALSE
, no columns will be plotted on the right side.
If direct estimates are included in the forest plot (direct =
TRUE
, default), the following columns will be printed on the left
side of the forest plot: the comparisons (column "studlab"
in forest.meta
), number of pairwise comparisons
("k"
), direct evidence proportion ("k"
), and
I from pairwise comparison (
"I2"
).
If direct estimates are not included in the forest plot
(direct = FALSE
), only the comparisons ("studlab"
)
are printed on the left side of the forest plot.
For more information see help page of forest.meta
function.
Argument show
determines which comparisons are printed:
“all” | All comparisons |
“both” | Only comparisons contributing both direct and indirect evidence |
“with.direct” | Comparisons providing direct evidence |
“direct.only” | Comparisons providing only direct evidence |
“indirect.only” | Comparisons providing only indirect evidence |
Guido Schwarzer [email protected]
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) net1 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013.5, common = FALSE, reference = "plac") # ns1 <- netsplit(net1) # Forest plot showing comparisons contributing both direct and # indirect evidence # forest(ns1, fontsize = 6, spacing = 0.5, addrow.subgroups = FALSE) ## Not run: # Forest plot showing comparisons contributing direct evidence # forest(ns1, fontsize = 6, spacing = 0.5, addrow.subgroups = FALSE, show = "with.direct") # Forest plot only showing network estimates compared to reference # group and prediction intervals # forest(ns1, fontsize = 8, spacing = 0.75, show = "all", only.reference = TRUE, prediction = TRUE, direct = FALSE, indirect = FALSE) ## End(Not run)
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) net1 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013.5, common = FALSE, reference = "plac") # ns1 <- netsplit(net1) # Forest plot showing comparisons contributing both direct and # indirect evidence # forest(ns1, fontsize = 6, spacing = 0.5, addrow.subgroups = FALSE) ## Not run: # Forest plot showing comparisons contributing direct evidence # forest(ns1, fontsize = 6, spacing = 0.5, addrow.subgroups = FALSE, show = "with.direct") # Forest plot only showing network estimates compared to reference # group and prediction intervals # forest(ns1, fontsize = 8, spacing = 0.75, show = "all", only.reference = TRUE, prediction = TRUE, direct = FALSE, indirect = FALSE) ## End(Not run)
Forest plot to show subgroup estimates of network meta-analysis.
## S3 method for class 'subgroup.netmeta' forest( x, pooled = ifelse(x$x$random, "random", "common"), equal.size = gs("equal.size"), leftcols = c("studlab", "Q", "df.Q", "pval.Q"), leftlabs = c("Comparison /\nSubgroup", "Q", "d.f.", "p-value"), rightcols = c("effect", "ci", "k", if (pooled == "random") "tau"), rightlabs = c(NA, NA, "Number of\nStudies", if (pooled == "random") "Tau"), calcwidth.subgroup = gs("calcwidth.subgroup"), digits = gs("digits.forest"), digits.Q = gs("digits.Q"), digits.pval.Q = gs("digits.pval.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), sep.trts = " vs ", backtransf = x$x$backtransf, lab.NA = ".", smlab, col.subgroup = "black", ... ) ## S3 method for class 'subgroup.netmeta' plot(x, ...)
## S3 method for class 'subgroup.netmeta' forest( x, pooled = ifelse(x$x$random, "random", "common"), equal.size = gs("equal.size"), leftcols = c("studlab", "Q", "df.Q", "pval.Q"), leftlabs = c("Comparison /\nSubgroup", "Q", "d.f.", "p-value"), rightcols = c("effect", "ci", "k", if (pooled == "random") "tau"), rightlabs = c(NA, NA, "Number of\nStudies", if (pooled == "random") "Tau"), calcwidth.subgroup = gs("calcwidth.subgroup"), digits = gs("digits.forest"), digits.Q = gs("digits.Q"), digits.pval.Q = gs("digits.pval.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), sep.trts = " vs ", backtransf = x$x$backtransf, lab.NA = ".", smlab, col.subgroup = "black", ... ) ## S3 method for class 'subgroup.netmeta' plot(x, ...)
x |
An object of class |
pooled |
A character string indicating whether results for the
common ( |
equal.size |
A logical indicating whether all squares should be of equal size. Otherwise, the square size is proportional to the precision of estimates. |
leftcols |
A character vector specifying columns to be plotted on the left side of the forest plot (see Details). |
leftlabs |
A character vector specifying labels for columns on left side of the forest plot. |
rightcols |
A character vector specifying columns to be plotted on the right side of the forest plot (see Details). |
rightlabs |
A character vector specifying labels for columns on right side of the forest plot. |
calcwidth.subgroup |
A logical indicating whether text with comparison labels should be considered to calculate width of the column with treatment labels. |
digits |
Minimal number of significant digits for treatment
effects and confidence intervals, see |
digits.Q |
Minimal number of significant digits for
heterogeneity statistic Q, see |
digits.pval.Q |
Minimal number of significant digits for
p-value of heterogeneity test, see |
digits.tau2 |
Minimal number of significant digits for
between-study variance |
digits.tau |
Minimal number of significant digits for
|
sep.trts |
A character string used to label treatment comparisons. |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
lab.NA |
A character string to label missing values. |
smlab |
A label printed at top of figure. By default, text indicating either common or random effects model is printed. |
col.subgroup |
The colour to print information on subgroups. |
... |
Additional arguments for |
A forest plot, also called confidence interval plot, is drawn in the active graphics window.
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. If argument rightcols
is
FALSE
, no columns will be plotted on the right side.
For more information see help page of forest.meta
function.
Guido Schwarzer [email protected]
subgroup.netmeta
, netmeta
,
forest.meta
# Add examples
# Add examples
Network meta-analysis comparing the effects of a number of treatments for Parkinson's disease.
The data are the mean lost work-time reduction in patients given dopamine agonists as adjunct therapy in Parkinson’s disease (Franchini et al. 2012). The data are given as sample size, mean and standard deviation in each trial arm. Treatments are placebo and four active drugs. These data are used as an example in the supplemental material of Dias et al. (2013) where placebo is coded as 1 and the four active drugs as 2 to 5.
A data frame with the following columns:
Study | study label |
Treatment1 | treatment 1 |
y1 | treatment effect arm 1 |
sd1 | Standard deviation arm 1 |
n1 | Sample size arm 1 |
Treatment2 | treatment 2 |
y2 | treatment effect arm 2 |
sd2 | Standard deviation arm 2 |
n2 | Sample size arm 2 |
Treatment3 | treatment 3 |
y3 | treatment effect arm 3 |
sd3 | Standard deviation arm 3 |
n3 | Sample size arm 3 |
Dias S, Sutton AJ, Ades AE and Welton NJ (2013): Evidence synthesis for decision making 2: A generalized linear modeling framework for pairwise and network meta-analysis of randomized controlled trials. Medical Decision Making, 33, 607–17
Franchini AJ, Dias S, Ades AE, Jansen JP, Welton NJ (2012): Accounting for correlation in network meta-analysis with multi-arm trials. Research Synthesis Methods, 3, 142–60
dat.franchini2012
,
pairwise
, metacont
,
netmeta
, netgraph.netmeta
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 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, thickness = "se.common", iterate = TRUE, plastic = TRUE) netgraph(net1, points = TRUE, cex.points = 3, cex = 1.5, thickness = "se.common", iterate = TRUE, plastic = TRUE, start = "eigen")
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 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, thickness = "se.common", iterate = TRUE, plastic = TRUE) netgraph(net1, points = TRUE, cex.points = 3, cex = 1.5, thickness = "se.common", iterate = TRUE, plastic = TRUE, start = "eigen")
Draw a ‘comparison-adjusted’ funnel plot to assess funnel plot asymmetry in network meta-analysis.
## S3 method for class 'netmeta' funnel( x, order, pooled = ifelse(x$random, "random", "common"), xlab = NULL, level = x$level, pch, col = "black", legend = TRUE, pos.legend = "topright", pos.tests = "topleft", lump.comparator = FALSE, text.comparator = "comparator", method.bias, text.linreg = "(Egger)", text.rank = "(Begg-Mazumdar)", text.mm = "(Thompson-Sharp)", sep.trts = x$sep.trts, nchar.trts = x$nchar.trts, backtransf = x$backtransf, digits.pval = gs("digits.pval"), warn.deprecated = gs("warn.deprecated"), linreg = FALSE, rank = FALSE, mm = FALSE, ... )
## S3 method for class 'netmeta' funnel( x, order, pooled = ifelse(x$random, "random", "common"), xlab = NULL, level = x$level, pch, col = "black", legend = TRUE, pos.legend = "topright", pos.tests = "topleft", lump.comparator = FALSE, text.comparator = "comparator", method.bias, text.linreg = "(Egger)", text.rank = "(Begg-Mazumdar)", text.mm = "(Thompson-Sharp)", sep.trts = x$sep.trts, nchar.trts = x$nchar.trts, backtransf = x$backtransf, digits.pval = gs("digits.pval"), warn.deprecated = gs("warn.deprecated"), linreg = FALSE, rank = FALSE, mm = FALSE, ... )
x |
An object of class |
order |
A mandatory character or numerical vector specifying the order of treatments or list of comparators (see Details). |
pooled |
A character string indicating whether results for the
common ( |
xlab |
A label for the x-axis. |
level |
The confidence level utilised in the plot. For the
funnel plot, confidence limits are not drawn if |
pch |
The plotting symbol(s) used for individual studies within direct comparisons. |
col |
The colour(s) used for individual studies within direct comparisons. |
legend |
A logical indicating whether a legend with information on direct comparisons should be added to the plot. |
pos.legend |
The position of the legend describing plotting symbols and colours for direct comparisons. |
pos.tests |
The position of results for test(s) of funnel plot asymmetry. |
lump.comparator |
A logical indicating whether comparators should be lumped, e.g., to specify inactive treatments. information on direct comparisons should be added to the plot. |
text.comparator |
A character string used in the plot to label
the comparator if |
method.bias |
A character vector indicating which test(s) for
funnel plot asymmetry to use. Admissible values are
|
text.linreg |
A character string used in the plot to label the Egger test for funnel plot asymmetry. |
text.rank |
A character string used in the plot to label the Begg test for funnel plot asymmetry. |
text.mm |
A character string used in the plot to label the Thompson-Sharp test for funnel plot asymmetry. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.trts |
A numeric defining the minimum number of
characters used to create unique treatment names (see
|
backtransf |
A logical indicating whether results for relative
summary measures (argument |
digits.pval |
Minimal number of significant digits for p-value of test(s) for funnel plot asymmetry. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
linreg |
Deprecated argument (replaced by |
rank |
Deprecated argument (replaced by |
mm |
Deprecated argument (replaced by |
... |
Additional graphical arguments passed as arguments to
|
A ‘comparison-adjusted’ funnel plot (Chaimani & Salanti, 2012) is drawn in the active graphics window.
Argument order
is mandatory to determine the order of
treatments (Chaimani et al., 2013):
“Before using this plot, investigators should order the treatments in a meaningful way and make assumptions about how small studies differ from large ones. For example, if they anticipate that newer treatments are favored in small trials, then they could name the treatments from oldest to newest so that all comparisons refer to ‘old versus new intervention’. Other possibilities include defining the comparisons so that all refer to an active treatment versus placebo or sponsored versus non-sponsored intervention.”
Alternatively, it is possible to only provide a single or few
treatment name(s) in argument order
to define the
comparator(s). In this case only comparisons with this / these
treatment(s) will be considered. If argument lump.comparator
is TRUE
, all comparators will be lumped into a single
group. The text for this group can be specified with argument
text.comparator
.
In the funnel plot, if yaxis
is "se"
, the standard
error of the treatment estimates is plotted on the y-axis which is
likely to be the best choice (Sterne & Egger, 2001). Other possible
choices for yaxis
are "invvar"
(inverse of the
variance), "invse"
(inverse of the standard error), and
"size"
(study size).
A data frame with the following columns:
studlab |
Study label. |
treat1 |
Label/Number for first treatment. |
treat2 |
Label/Number for second treatment. |
comparison |
Treatment comparison. |
TE |
Estimate of treatment effect, e.g., log odds ratio. |
TE.direct |
Pooled estimate from direct evidence. |
TE.adj |
‘Comparison-adjusted’ treatment effect (TE - TE.direct). |
seTE |
Standard error of treatment estimate. |
pch |
Plotting symbol(s). |
col |
Colour of plotting symbol(s). |
Guido Schwarzer [email protected]
Chaimani A & Salanti G (2012): Using network meta-analysis to evaluate the existence of small-study effects in a network of interventions. Research Synthesis Methods, 3, 161–76
Chaimani A, Higgins JP, Mavridis D, Spyridonos P, Salanti G (2013): Graphical tools for network meta-analysis in STATA. PLOS ONE, 8, e76654
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
netmeta
, funnel.meta
,
metabias
## Not run: data(Senn2013) net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") # 'Comparison-adjusted' funnel plot not created as argument 'order' # is missing # try(funnel(net1)) # Only show comparisons with placebo # funnel(net1, order = "pl") # Add result for Egger test of funnel plot asymmetry # funnel(net1, order = "pl", method.bias = "Egger", digits.pval = 2) # (Nonsensical) alphabetic order of treatments with placebo as # last treatment # ord <- c("a", "b", "me", "mi", "pi", "r", "si", "su", "v", "pl") funnel(net1, order = ord) # Add results for tests of funnel plot asymmetry and use different # plotting symbols and colours # funnel(net1, order = ord, pch = rep(c(15:18, 1), 3), col = 1:3, method.bias = c("Egger", "Begg", "Thompson"), digits.pval = 2) # Same results for tests of funnel plot asymmetry using reversed # order of treatments # funnel(net1, order = rev(ord), pch = rep(c(15:18, 1), 3), col = 1:3, method.bias = c("Egger", "Begg", "Thompson"), digits.pval = 2) # Calculate tests for funnel plot asymmetry # f1 <- funnel(net1, order = ord) # metabias(metagen(TE.adj, seTE, data = f1)) metabias(metagen(TE.adj, seTE, data = f1), method = "Begg") metabias(metagen(TE.adj, seTE, data = f1), method = "Thompson") ## End(Not run)
## Not run: data(Senn2013) net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") # 'Comparison-adjusted' funnel plot not created as argument 'order' # is missing # try(funnel(net1)) # Only show comparisons with placebo # funnel(net1, order = "pl") # Add result for Egger test of funnel plot asymmetry # funnel(net1, order = "pl", method.bias = "Egger", digits.pval = 2) # (Nonsensical) alphabetic order of treatments with placebo as # last treatment # ord <- c("a", "b", "me", "mi", "pi", "r", "si", "su", "v", "pl") funnel(net1, order = ord) # Add results for tests of funnel plot asymmetry and use different # plotting symbols and colours # funnel(net1, order = ord, pch = rep(c(15:18, 1), 3), col = 1:3, method.bias = c("Egger", "Begg", "Thompson"), digits.pval = 2) # Same results for tests of funnel plot asymmetry using reversed # order of treatments # funnel(net1, order = rev(ord), pch = rep(c(15:18, 1), 3), col = 1:3, method.bias = c("Egger", "Begg", "Thompson"), digits.pval = 2) # Calculate tests for funnel plot asymmetry # f1 <- funnel(net1, order = ord) # metabias(metagen(TE.adj, seTE, data = f1)) metabias(metagen(TE.adj, seTE, data = f1), method = "Begg") metabias(metagen(TE.adj, seTE, data = f1), method = "Thompson") ## End(Not run)
Network meta-analysis comparing the effects of a number of interventions for decreasing blood loss and blood transfusion requirements during liver transplantation.
A data frame with the following columns:
study | study information (first author, year) |
treatment | treatment |
death | mortality at 60 days post-transplantation |
n | number of individuals in treatment arm |
Gurusamy KS, Pissanou T, Pikhart H, Vaughan J, Burroughs AK, Davidson BR (2011): Methods to decrease blood loss and transfusion requirements for liver transplantation. Cochrane Database of Systematic Reviews, CD009052
data(Gurusamy2011) # Only consider three studies (to reduce runtime of example) # studies <- c("Findlay 2001", "Garcia-Huete 1997", "Dalmau 2000") three <- subset(Gurusamy2011, study %in% studies) # 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. # p1 <- pairwise(treatment, death, n, studlab = study, data = three, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis # netmetabin(p1, ref = "cont") ## Not run: p2 <- pairwise(treatment, death, n, studlab = study, data = Gurusamy2011, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis netmetabin(p2, ref = "cont") ## End(Not run)
data(Gurusamy2011) # Only consider three studies (to reduce runtime of example) # studies <- c("Findlay 2001", "Garcia-Huete 1997", "Dalmau 2000") three <- subset(Gurusamy2011, study %in% studies) # 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. # p1 <- pairwise(treatment, death, n, studlab = study, data = three, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis # netmetabin(p1, ref = "cont") ## Not run: p2 <- pairwise(treatment, death, n, studlab = study, data = Gurusamy2011, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis netmetabin(p2, ref = "cont") ## End(Not run)
This function generates a Hasse diagram for a partial order of treatment ranks in a network meta-analysis.
## S3 method for class 'netposet' hasse(x, pooled = ifelse(x$random, "random", "common"), newpage = TRUE, ...) hasse(x, ...)
## S3 method for class 'netposet' hasse(x, pooled = ifelse(x$random, "random", "common"), newpage = TRUE, ...) hasse(x, ...)
x |
An object of class |
pooled |
A character string indicating whether Hasse diagram
show be drawn for common ( |
newpage |
A logical value indicating whether a new figure should be printed in an existing graphics window. Otherwise, the Hasse diagram is added to the existing figure. |
... |
Additional arguments (ignored). |
Generate a Hasse diagram (Carlsen & Bruggemann, 2014) for a partial order of treatment ranks in a network meta-analysis (Rücker & Schwarzer, 2017).
This R function is a wrapper function for R function
hasse
in R package hasseDiagram
(Krzysztof Ciomek, https://github.com/kciomek/hasseDiagram),
i.e., function hasse
can only be used if R package
hasseDiagram is installed.
Gerta Rücker [email protected], Guido Schwarzer [email protected]
Carlsen L, Bruggemann R (2014): Partial order methodology: a valuable tool in chemometrics. Journal of Chemometrics, 28, 226–34
Rücker G, Schwarzer G (2017): Resolve conflicting rankings of outcomes in network meta-analysis: Partial ordering of treatments. Research Synthesis Methods, 8, 526–36
netmeta
, netposet
,
netrank
, plot.netrank
,
dat.linde2015
## Not run: # Define order of treatments in depression dataset dat.linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # Partial order of treatment rankings # po <- netposet(netrank(net1), netrank(net2), outcomes = outcomes) # Hasse diagram # hasse(po) ## End(Not run)
## Not run: # Define order of treatments in depression dataset dat.linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # Partial order of treatment rankings # po <- netposet(netrank(net1), netrank(net2), outcomes = outcomes) # Hasse diagram # hasse(po) ## End(Not run)
Auxiliary function to derive hat matrix from network meta-analysis
hatmatrix( x, method = "Ruecker", type, common = x$common, random = x$random, nchar.trts = x$nchar.trts, nchar.studlab = x$nchar.studlab ) ## S3 method for class 'hatmatrix' print( x, common = x$x$common, random = x$x$random, nchar.trts = x$x$nchar.trts, nchar.studlab = x$x$nchar.studlab, digits = gs("digits"), legend = gs("legend"), legend.studlab = TRUE, ... )
hatmatrix( x, method = "Ruecker", type, common = x$common, random = x$random, nchar.trts = x$nchar.trts, nchar.studlab = x$nchar.studlab ) ## S3 method for class 'hatmatrix' print( x, common = x$x$common, random = x$x$random, nchar.trts = x$x$nchar.trts, nchar.studlab = x$x$nchar.studlab, digits = gs("digits"), legend = gs("legend"), legend.studlab = TRUE, ... )
x |
A |
method |
A character string indicating which method is used to
derive the hat matrix. Either |
type |
A character string indicating which specific hat matrix should be derived (can be abbreviated, see Details). |
common |
A logical indicating whether a hat matrix should be printed for the common effects network meta-analysis. |
random |
A logical indicating whether a hat matrix should be printed for the random effects network meta-analysis. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
nchar.studlab |
A numeric defining the minimum number of characters used to create unique study labels. |
digits |
Minimal number of significant digits, see
|
legend |
A logical indicating whether a legend should be printed. |
legend.studlab |
A logical indicating whether a legend should be printed for abbreviated study labels. |
... |
Additional arguments (ignored). |
This auxiliary function can be used to derive various hat matrices from a network meta-analysis object.
This hat matrix is estimated if method = "Ruecker"
.
Let n be the number of different treatments (nodes,
vertices) in a network and let m be the number of existing
comparisons (edges) between the treatments. If there are only
two-arm studies, m is equal to the number of studies,
k. Let seTE.adj.common and seTE.adj.random be the vectors of
adjusted standard errors under the common and random effects model
(see netmeta
). Let W be the m x
m diagonal matrix that contains the inverse variance 1 /
seTE.adj.common or 1 / seTE.adj.random
.
The given comparisons define the network structure. Therefrom an
m x n design matrix X (edge-vertex incidence matrix) is
formed; for more precise information, see Rücker (2012). Moreover,
the n x n Laplacian matrix L and its
Moore-Penrose pseudoinverse L are calculated (both
matrices play an important role in graph theory and electrical
network theory). Using these matrices, the variances based on both
direct and indirect comparisons can be estimated. The hat matrix
H is estimated by H =
XL
X
W = X(X
W
X)
X
W.
One of the following hat matrices is estimated if method
= "Krahn"
.
Use of type = "design"
(default) results in a hat matrix of
dimension n(n-1)/2 x s, where s is the sum of
the number of independent comparisons from each design.
Use of type = "studies"
results in a hat matrix of dimension
n(n-1)/2 x l, where l is the number of
independent pairwise comparisons, i.e., a three-arm study
contributes two pairwise comparisons.
One of three hat matrices is estimated if method = "Davies"
.
Here, we focus on the hat matrix of the aggregate (two-step) version of the graph theoretical NMA model. In the first step, a pairwise meta-analysis is performed across each edge using the adjusted weights (these account for correlations due to multi-arm trials). From this we obtain direct treatment effect estimates (and corresponding aggregate weights) associated with each edge. In step two, we combine these direct estimates in a network meta analysis to obtain the network estimates. This is done using weighted least squares regression. The hat matrix associated with this second step is called the aggregate hat matrix.
All three versions of the aggregate hat matrix contain the same information: the second two can be derived directly from the first. They differ in their dimensionality.
Each row of the hat matrix that represents a treatment comparison (ij) describes the flow of evidence through each edge for that comparison. This defines a directed acyclic 'flow graph' from node i to node j.
(1) Use of type = "short"
(default) results in a hat matrix
of dimension e x e, where e is the number of
(unique) edges (direct comparisons) in the network. This is the
aggregate hat matrix described in Davies et al. (2022). Each row
and column represents a pair of treatments for which there is at
least one direct comparison.
(2) Use of type = "long"
results in a hat matrix of
dimension n(n-1)/2 x e. There is a row for every
possible pair of treatments in the network - regardless of whether
there is direct evidence for this comparison. Each column
represents a pair of treatments for which there is at least one
direct comparison. The extra rows can be calculated from the short
hat matrix using consistency equations.
(3) Use of type = "full"
results in a hat matrix of
dimension n(n-1)/2 x n(n-1)/2. In comparison to the
long hat matrix, columns of zeroes are added for comparisons that
do not have any direct evidence. Therefore, there is a row and
column for every pair of treatments in the network. This hat matrix
is used to calculate the transition matrices for the random walk in
netcontrib
.
A list with two hat matrices: common
(common effects model)
and random
(random effects model).
Guido Schwarzer [email protected]
Davies AL, Papakonstantinou T, Nikolakopoulou A, Rücker G, Galla T (2022): Network meta-analysis and random walks. Statistics in Medicine, 41, 2091–2114
Krahn U, Binder H, König J (2013): A graphical tool for locating inconsistency in network meta-analyses. BMC Medical Research Methodology, 13, 35
Rücker G (2012): Network meta-analysis, electrical networks and graph theory. Research Synthesis Methods, 3, 312–24
netmeta
, netcontrib
,
netheat
, dat.dong2013
# Only consider first ten studies for concise output first10 <- subset(dat.dong2013, id <= 10) p1 <- pairwise(treatment, death, randomized, studlab = id, data = first10, sm = "OR") net1 <- netmeta(p1, common = FALSE) hatmatrix(net1) hatmatrix(net1, method = "k") hatmatrix(net1, method = "k", type = "studies") hatmatrix(net1, method = "d") hatmatrix(net1, method = "d", type = "long") hatmatrix(net1, method = "d", type = "full")
# Only consider first ten studies for concise output first10 <- subset(dat.dong2013, id <= 10) p1 <- pairwise(treatment, death, randomized, studlab = id, data = first10, sm = "OR") net1 <- netmeta(p1, common = FALSE) hatmatrix(net1) hatmatrix(net1, method = "k") hatmatrix(net1, method = "k", type = "studies") hatmatrix(net1, method = "d") hatmatrix(net1, method = "d", type = "long") hatmatrix(net1, method = "d", type = "full")
Generic function for heat plots
heatplot(x, ...)
heatplot(x, ...)
x |
An R object. |
... |
Additional arguments. |
For more details, look at the following function to generate heat plots:
heatplot.crossnma
(if installed)
Guido Schwarzer [email protected]
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct random effects network meta-analysis with # placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013.5, sm = "MD", common = FALSE, reference = "plac") # Generate a heat plot (with abbreviated treatment labels) # heatplot(net1, nchar.trts = 4)
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct random effects network meta-analysis with # placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013.5, sm = "MD", common = FALSE, reference = "plac") # Generate a heat plot (with abbreviated treatment labels) # heatplot(net1, nchar.trts = 4)
Produces a heat plot containing treatment estimates with confidence intervals for all possible pairwise comparisons.
## S3 method for class 'netmeta' heatplot( x, pooled = ifelse(x$random, "random", "common"), seq = x$seq, nchar.trts = x$nchar.trts, low.colour = "red", mid.colour = "white", high.colour = "springgreen4", size = 6, size.trt = 16, size.axis = 12, digits = gs("digits.forest"), backtransf = x$backtransf, ... )
## S3 method for class 'netmeta' heatplot( x, pooled = ifelse(x$random, "random", "common"), seq = x$seq, nchar.trts = x$nchar.trts, low.colour = "red", mid.colour = "white", high.colour = "springgreen4", size = 6, size.trt = 16, size.axis = 12, digits = gs("digits.forest"), backtransf = x$backtransf, ... )
x |
An object of class |
pooled |
A character string indicating whether results for the
common ( |
seq |
A character or numerical vector specifying the sequence of treatments in rows and columns of the heat plot. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
low.colour |
A string indicating the colour of low relative treatment effects for the heat plot (e.g odds ratio of ~0.5) |
mid.colour |
A string indicating the colour of null relative treatment effects for the heat plot (e.g odds ratio of ~1.0). |
high.colour |
A string indicating the colour of high relative treatment effects for the heat plot (e.g odds ratio of ~2.0). |
size |
The size of cell entries with the relative treatment effect and confidence intervals. |
size.trt |
The size of treatment names placed on the top and left of the plot. |
size.axis |
The size of labels on the top and left of the plot |
digits |
Minimal number of significant digits for treatment
effects and confidence intervals, see |
backtransf |
A logical indicating whether results should be
back transformed in forest plots. If |
... |
Additional arguments. |
League heat plot, where a color scale is used to represent the values of relative treatment effects.
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct random effects network meta-analysis with # placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013.5, sm = "MD", common = FALSE, reference = "plac") # Generate a heat plot (with abbreviated treatment labels) # heatplot(net1, nchar.trts = 4)
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct random effects network meta-analysis with # placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013.5, sm = "MD", common = FALSE, reference = "plac") # Generate a heat plot (with abbreviated treatment labels) # heatplot(net1, nchar.trts = 4)
Calculates the Moore-Penrose pseudoinverse of a square matrix X.
invmat(X)
invmat(X)
X |
A square matrix. |
This function is used by default in R package netmeta to
calculate the Moore-Penrose pseudoinverse L of the
Laplacian matrix L (Rücker, 2012):
L = (X - J / n)
+ J / n
with identity matrix J of dimension nxn.
The Moore-Penrose pseudoinverse for matrix X.
Gerta Rücker [email protected], Guido Schwarzer [email protected]
Rücker G (2012): Network meta-analysis, electrical networks and graph theory. Research Synthesis Methods, 3, 312–24
data(smokingcessation) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1) invmat(net1$L.matrix.common) ## Not run: data(Senn2013) net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013) L1 <- net2$L.matrix.common L2 <- invmat(net2$Lplus.matrix.common) all.equal(round(L1, 10), round(L2, 10)) ## End(Not run)
data(smokingcessation) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1) invmat(net1$L.matrix.common) ## Not run: data(Senn2013) net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013) L1 <- net2$L.matrix.common L2 <- invmat(net2$Lplus.matrix.common) all.equal(round(L1, 10), round(L2, 10)) ## End(Not run)
Network meta-analysis of nine classes of antidepressants including placebo for the primary care setting; partly shown in Linde et al. (2015), supplementary Table 2.
A data frame with the following columns:
id | Study ID |
author | First author |
year | Publication year |
treatment1 | First treatment |
treatment2 | Second treatment |
treatment3 | Third treatment |
n1 | Number of patients receiving first treatment |
resp1 | Number of early responder (treatment 1) |
remi1 | Number of early remissions (treatment 1) |
loss1 | Number of patients loss to follow-up (treatment 1) |
loss.ae1 | Number of patients loss to follow-up due to adverse events (treatment 1) |
ae1 | Number of patients with adverse events (treatment 1) |
n2 | Number of patients receiving second treatment |
resp2 | Number of early responder (treatment 2) |
remi2 | Number of early remissions (treatment 2) |
loss2 | Number of patients loss to follow-up (treatment 2) |
loss.ae2 | Number of patients loss to follow-up due to adverse events (treatment 2) |
ae2 | Number of patients with adverse events (treatment 2) |
n3 | Number of patients receiving third treatment |
resp3 | Number of early responder (treatment 3) |
remi3 | Number of early remissions (treatment 3) |
loss3 | Number of patients loss to follow-up (treatment 3) |
loss.ae3 | Number of patients loss to follow-up due to adverse events (treatment 3) |
ae3 | Number of patients with adverse events (treatment 3) |
Linde K, Kriston L, Rücker G, et al. (2015): Efficacy and acceptability of pharmacological treatments for depressive disorders in primary care: Systematic review and network meta-analysis. Annals of Family Medicine, 13, 69–79
pairwise
, metabin
,
netmeta
, netposet
data(Linde2015) # Transform data from arm-based format to contrast-based format # Outcome: early response p1 <- pairwise(list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = Linde2015, sm = "OR") p1 ## Not run: # Define order of treatments trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Conduct random effects network meta-analysis net1 <- netmeta(p1, common = FALSE, reference = "Placebo", seq = trts) print(net1, digits = 2) ## End(Not run)
data(Linde2015) # Transform data from arm-based format to contrast-based format # Outcome: early response p1 <- pairwise(list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = Linde2015, sm = "OR") p1 ## Not run: # Define order of treatments trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Conduct random effects network meta-analysis net1 <- netmeta(p1, common = FALSE, reference = "Placebo", seq = trts) print(net1, digits = 2) ## End(Not run)
Network meta-analysis of 22 treatments (including placebo and usual care) for the primary care of depression.
A data frame with the following columns:
id | Study ID |
author | First author |
year | Year of publication |
treat1 | First treatment (abbreviated) |
treat2 | Second treatment (abbreviated) |
treat1.long | First treatment |
treat2.long | Second treatment |
lnOR | Response after treatment (log odds ratio) |
selnOR | Standard error of log odds ratio |
resp1 | Responder (first treatment) |
n1 | Sample size (first treatment) |
resp2 | Responder (second treatment) |
n2 | Sample size (second treatment) |
Linde K, Rücker G, Schneider A et al. (2016): Questionable assumptions hampered interpretation of a network meta-analysis of primary care depression treatments. Journal of Clinical Epidemiology, 71, 86–96
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE, nchar.trts = 6) # net1 ## Not run: # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, reference.group = "placebo", sm = "OR", common = FALSE, nchar.trts = 6) # net2 ## End(Not run)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE, nchar.trts = 6) # net1 ## Not run: # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, reference.group = "placebo", sm = "OR", common = FALSE, nchar.trts = 6) # net2 ## End(Not run)
Merge pairwise object with additional data, e.g., information on network connectivity.
## S3 method for class 'pairwise' merge(x, y, all.x = TRUE, ...)
## S3 method for class 'pairwise' merge(x, y, all.x = TRUE, ...)
x |
An object of class |
y |
A data frame or an object of class |
all.x |
A logical indicating whether to keep all observations from the pairwise object, i.e., also include observations not belonging to a subnetwork due to missing estimates or standard errors. |
... |
Other arguments (passed on to |
An object of class pairwise
.
Guido Schwarzer [email protected]
pairwise
, netconnection
,
dat.woods2010
# 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. # p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") head(p1) # Add information on network connectivity nc1 <- netconnection(p1) p1nc1 <- merge(p1, nc1) head(p1nc1)
# 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. # p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") head(p1) # Add information on network connectivity nc1 <- netconnection(p1) p1nc1 <- merge(p1, nc1) head(p1nc1)
Test of funnel plot asymmetry in network meta-analysis
## S3 method for class 'netmeta' metabias( x, order, pooled = ifelse(x$random, "random", "common"), method.bias = "Egger", lump.comparator = gs("lump.comparator"), ... )
## S3 method for class 'netmeta' metabias( x, order, pooled = ifelse(x$random, "random", "common"), method.bias = "Egger", lump.comparator = gs("lump.comparator"), ... )
x |
An object of class |
order |
A mandatory character or numerical vector specifying the order of treatments or list of comparators (see Details). |
pooled |
A character string indicating whether results for the
common ( |
method.bias |
A character vector indicating which test(s) for
funnel plot asymmatrx to use. Admissible values are
|
lump.comparator |
A logical indicating whether comparators should be lumped, e.g., to specify inactive treatments. information on direct comparisons should be added to the plot. |
... |
Additional arguments (passed on to
|
Test of funnel plot asymmetry in network meta-analysis
Argument order
is mandatory to determine the order of
treatments (Chaimani et al., 2013):
“[...] investigators should order the treatments in a meaningful way and make assumptions about how small studies differ from large ones. For example, if they anticipate that newer treatments are favored in small trials, then they could name the treatments from oldest to newest so that all comparisons refer to ‘old versus new intervention’. Other possibilities include defining the comparisons so that all refer to an active treatment versus placebo or sponsored versus non-sponsored intervention.”
Alternatively, it is possible to only provide a single or few
treatment name(s) in argument order
to define the
comparator(s). In this case only comparisons with this / these
treatment(s) will be considered. If argument lump.comparator
is TRUE
, all comparators will be lumped into a single
group.
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 |
Network meta-analysis object. |
version |
Version of R package meta used to create object. |
version.netmeta |
Version of R package netmeta 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 comparisons. |
k.min |
Minimum number of comparisons to perform test for funnel plot asymmetry. |
version |
Version of R package meta used to create object. |
version.netmeta |
Version of R package netmeta used to create object. |
Guido Schwarzer [email protected]
Chaimani A & Salanti G (2012): Using network meta-analysis to evaluate the existence of small-study effects in a network of interventions. Research Synthesis Methods, 3, 161–76
Chaimani A, Higgins JP, Mavridis D, Spyridonos P, Salanti G (2013): Graphical tools for network meta-analysis in STATA. PLOS ONE, 8, e76654
netmeta
, funnel.netmeta
,
metabias
## Not run: data(Senn2013) net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") # Test for asymmetry in 'comparison-adjusted' funnel plot not # conducted as argument 'order' is missing # try(metabias(net1)) # Test for funnel plot asymmetry comparing active treatments with # placebo metabias(net1, order = "pl") # Rank test # metabias(net1, order = "pl", method.bias = "Begg") # Test for funnel plot asymmetry based on (non-sensical) alphabetic # order of treatments with placebo as last treatment # ord <- c("a", "b", "me", "mi", "pi", "r", "si", "su", "v", "pl") metabias(net1, order = ord) ## End(Not run)
## Not run: data(Senn2013) net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") # Test for asymmetry in 'comparison-adjusted' funnel plot not # conducted as argument 'order' is missing # try(metabias(net1)) # Test for funnel plot asymmetry comparing active treatments with # placebo metabias(net1, order = "pl") # Rank test # metabias(net1, order = "pl", method.bias = "Begg") # Test for funnel plot asymmetry based on (non-sensical) alphabetic # order of treatments with placebo as last treatment # ord <- c("a", "b", "me", "mi", "pi", "r", "si", "su", "v", "pl") metabias(net1, order = ord) ## End(Not run)
This function can be used to combine network meta-analysis objects which is especially useful to generate a forest plot with results of several network meta-analyses.
netbind( ..., name, common, random, col.study = "black", col.inside = "white", col.square = "gray", col.square.lines = col.square, backtransf, reference.group, baseline.reference, warn.deprecated = gs("warn.deprecated"), fixed, comb.fixed, comb.random )
netbind( ..., name, common, random, col.study = "black", col.inside = "white", col.square = "gray", col.square.lines = col.square, backtransf, reference.group, baseline.reference, warn.deprecated = gs("warn.deprecated"), fixed, comb.fixed, comb.random )
... |
Any number of network meta-analysis objects or a single list with network meta-analyses. |
name |
An optional character vector providing descriptive names for network meta-analysis objects. |
common |
A logical indicating whether results for the common effects model should be reported. |
random |
A logical indicating whether results for the random effects model should be reported. |
col.study |
The colour for network estimates and confidence limits. |
col.inside |
The colour for network estimates and confidence limits if confidence limits are completely within squares. |
col.square |
The colour for squares. |
col.square.lines |
The colour for the outer lines of squares. |
backtransf |
A logical indicating whether results should be
back transformed. If |
reference.group |
Reference treatment. |
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment (default) or vice versa. This argument is
only considered if |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
fixed |
Deprecated argument; replaced by |
comb.fixed |
Deprecated argument; replaced by |
comb.random |
Deprecated argument; replaced by |
An object of class "netbind"
with corresponding
forest
function. The object is a list containing the
following components:
common |
A data frame with results for the common effects model. |
random |
A data frame with results for the random effects model. |
sm |
Summary measure used in network meta-analyses. |
level.ma |
Level for confidence intervals. |
reference.group , baseline.reference
|
As defined above. |
Guido Schwarzer [email protected]
netmeta
, netcomb
,
discomb
, forest.netbind
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Standard random effects NMA model (with placebo as reference # treatment) # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive CNMA model with placebo as inactive component and # reference # nc1 <- netcomb(net1, inactive = "placebo") # Combine results of standard NMA and CNMA # nb1 <- netbind(nc1, net1, name = c("Additive CNMA", "Standard NMA"), col.study = c("red", "black"), col.square = c("red", "black")) forest(nb1, col.subgroup = "black", addrow.subgroups = FALSE, fontsize = 10, spacing = 0.7, squaresize = 0.9, label.left = "Favours Placebo", label.right = "Favours other")
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Standard random effects NMA model (with placebo as reference # treatment) # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive CNMA model with placebo as inactive component and # reference # nc1 <- netcomb(net1, inactive = "placebo") # Combine results of standard NMA and CNMA # nb1 <- netbind(nc1, net1, name = c("Additive CNMA", "Standard NMA"), col.study = c("red", "black"), col.square = c("red", "black")) forest(nb1, col.subgroup = "black", addrow.subgroups = FALSE, fontsize = 10, spacing = 0.7, squaresize = 0.9, label.left = "Favours Placebo", label.right = "Favours other")
Some treatments in a network meta-analysis may be combinations of other treatments or have common components. The influence of individual components can be evaluated in an additive network meta-analysis model assuming that the effect of treatment combinations is the sum of the effects of its components. This function implements this additive model in a frequentist way.
netcomb( x, inactive = NULL, sep.comps = gs("sep.comps"), C.matrix, common = x$common, random = x$random | !is.null(tau.preset), tau.preset = NULL, details.chkident = FALSE, nchar.comps = x$nchar.trts, sep.ia = gs("sep.ia"), func.inverse = invmat, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, na.unident = gs("na.unident"), warn.deprecated = gs("warn.deprecated"), ... )
netcomb( x, inactive = NULL, sep.comps = gs("sep.comps"), C.matrix, common = x$common, random = x$random | !is.null(tau.preset), tau.preset = NULL, details.chkident = FALSE, nchar.comps = x$nchar.trts, sep.ia = gs("sep.ia"), func.inverse = invmat, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, na.unident = gs("na.unident"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
inactive |
A character string defining the inactive treatment component (see Details). |
sep.comps |
A single character to define separator between treatment components. |
C.matrix |
C matrix (see Details). |
common |
A logical indicating whether a common effects network meta-analysis should be conducted. |
random |
A logical indicating whether a random effects network meta-analysis should be conducted. |
tau.preset |
An optional value for the square-root of the
between-study variance |
details.chkident |
A logical indicating whether details on unidentifiable components should be printed. |
nchar.comps |
A numeric defining the minimum number of characters used to create unique names for components (see Details). |
sep.ia |
A single character to define separator for interactions. |
func.inverse |
R function used to calculate the pseudoinverse
of the Laplacian matrix L (see |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be back transformed in printouts and forest plots. |
na.unident |
A logical indicating whether unidentifiable components and combinations should be set to missing values. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
Treatments in network meta-analysis (NMA) can be complex
interventions. Some treatments may be combinations of others or
have common components. The standard analysis provided by
netmeta
is a NMA where all existing (single or
combined) treatments are considered as different nodes in the
network. Exploiting the fact that some treatments are combinations
of common components, an additive component network meta-analysis
(CNMA) model can be used to evaluate the influence of individual
components. This model assumes that the effect of a treatment
combination is the sum of the effects of its components which
implies that common components cancel out in comparisons.
The additive CNMA model has been implemented using Bayesian methods (Mills et al., 2012; Welton et al., 2013). This function implements the additive model in a frequentist way (Rücker et al., 2020).
The underlying multivariate model is given by
with
vector of true treatment effects (differences) from individual studies,
design matrix describing the structure of the network,
parameter vector that represents the existing combined treatments,
matrix describing how the treatments are composed,
parameter vector representing the treatment components.
All parameters are estimated using weighted least squares regression.
Argument inactive
can be used to specify a single component
that does not have any therapeutic value. Accordingly, it is
assumed that the treatment effect of the combination of this
component with an additional treatment component is equal to the
treatment effect of the additional component alone.
Argument sep.comps
can be used to specify the separator
between individual components. By default, the matrix C is
calculated internally from treatment names. However, it is possible
to specify a different matrix using argument C.matrix
.
By default, component names are not abbreviated in
printouts. However, in order to get more concise printouts,
argument nchar.comps
can be used to define the minimum
number of characters for abbreviated component names (see
abbreviate
, argument minlength
). R function
treats
is utilised internally to create abbreviated
component names.
An object of class netcomb
with corresponding print
,
summary
, and forest
functions. The object is a list
containing the following components:
studlab |
Study labels. |
treat1 |
Label/Number for first treatment. |
treat2 |
Label/Number for second treatment. |
TE |
Estimate of treatment effect, i.e. difference between first and second treatment. |
seTE |
Standard error of treatment estimate. |
seTE.adj.common , seTE.adj.random
|
Standard error of treatment estimate, adjusted for multi-arm studies. |
design |
Design of study providing pairwise comparison. |
event1 |
Number of events in first treatment group. |
event2 |
Number of events in second treatment group. |
n1 |
Number of observations in first treatment group. |
n2 |
Number of observations in second treatment group. |
k |
Total number of studies. |
m |
Total number of pairwise comparisons. |
n |
Total number of treatments. |
d |
Total number of designs (corresponding to the unique set of treatments compared within studies). |
c |
Total number of components. |
trts |
Treatments included in network meta-analysis. |
k.trts |
Number of studies evaluating a treatment. |
n.trts |
Number of observations receiving a treatment (if
arguments |
events.trts |
Number of events observed for a treatment (if
arguments |
studies |
Study labels coerced into a factor with its levels sorted alphabetically. |
narms |
Number of arms for each study. |
designs |
Unique list of designs present in the network. A design corresponds to the set of treatments compared within a study. |
comps |
Unique list of components present in the network. |
TE.nma.common , TE.nma.random
|
A vector of length m of consistent treatment effects estimated by network meta-analysis (nma) (common and random effects model). |
seTE.nma.common , seTE.nma.random
|
A vector of length m of effective standard errors estimated by network meta-analysis (common and random effects model). |
lower.nma.common , lower.nma.random
|
A vector of length m of lower confidence interval limits for consistent treatment effects estimated by network meta-analysis (common and random effects model). |
upper.nma.common , upper.nma.random
|
A vector of length m of upper confidence interval limits for the consistent treatment effects estimated by network meta-analysis (common and random effects model). |
statistic.nma.common , statistic.nma.random
|
A vector of length m of z-values for test of treatment effect for individual comparisons (common and random effects model). |
pval.nma.common , pval.nma.random
|
A vector of length m of p-values for test of treatment effect for individual comparisons (common and random effects model). |
TE.cnma.common , TE.cnma.random
|
A vector of length m of consistent treatment effects estimated by the additive (common and random effects) model. |
seTE.cnma.common , seTE.cnma.random
|
A vector of length m with standard errors estimated by the additive (common and random effects) model. |
lower.cnma.common , lower.cnma.random
|
A vector of length m of lower confidence interval limits for consistent treatment effects estimated by the additive (common and random effects) model. |
upper.cnma.common , upper.cnma.random
|
A vector of length m of upper confidence interval limits for consistent treatment effects estimated by the additive (common and random effects) model. |
statistic.cnma.common , statistic.cnma.random
|
A vector of length m of z-values for the test of an overall effect estimated by the additive (common and random effects) model. |
pval.cnma.common , pval.cnma.random
|
A vector of length m of p-values for the test of an overall effect estimated by the additive (common and random effects) model. |
TE.common , TE.random
|
nxn matrix with overall treatment effects estimated by the additive (common and random effects) model. |
seTE.common , seTE.random
|
nxn matrix with standard errors estimated by the additive (common and random effects) model. |
lower.common , upper.common , lower.random , upper.random
|
nxn matrices with lower and upper confidence interval limits estimated by the additive (common and random effects) model. |
statistic.common , pval.common , statistic.random , pval.random
|
nxn matrices with z-values and p-values for test of overall effect estimated by the additive (common and random effects) model. |
Comp.common , Comp.random
|
A vector of component effects (common and random effects model). |
seComp.common , seComp.random
|
A vector with corresponding standard errors (common and random effects model). |
lower.Comp.common , lower.Comp.random
|
A vector with lower confidence limits for components (common and random effects model). |
upper.Comp.common , upper.Comp.random
|
A vector with upper confidence limits for components (common and random effects model). |
statistic.Comp.common , statistic.Comp.random
|
A vector with z-values for the overall effect of components (common and random effects model). |
pval.Comp.common , pval.Comp.random
|
A vector with p-values for the overall effect of components (common and random effects model). |
Comb.common , Comb.random
|
A vector of combination effects (common and random effects model). |
seComb.common , seComb.random
|
A vector with corresponding standard errors (common and random effects model). |
lower.Comb.common , lower.Comb.random
|
A vector with lower confidence limits for combinations (common and random effects model). |
upper.Comb.common , upper.Comb.random
|
A vector with upper confidence limits for combinations (common and random effects model). |
statistic.Comb.common , statistic.Comb.random
|
A vector with z-values for the overall effect of combinations (common and random effects model). |
pval.Comb.common , pval.Comb.random
|
A vector with p-values for the overall effect of combinations (common and random effects model). |
Q.additive |
Overall heterogeneity / inconsistency statistic (additive model). |
df.Q.additive |
Degrees of freedom for test of heterogeneity / inconsistency (additive model). |
pval.Q.additive |
P-value for test of heterogeneity / inconsistency (additive model). |
tau |
Square-root of between-study variance (additive model). |
I2 , lower.I2 , upper.I2
|
I-squared, lower and upper confidence limits. |
Q.standard |
Overall heterogeneity / inconsistency statistic (standard model). |
df.Q.standard |
Degrees of freedom for test of heterogeneity / inconsistency (standard model). |
pval.Q.standard |
P-value for test of heterogeneity / inconsistency (standard model). |
Q.diff |
Test statistic for difference in goodness of fit between standard and additive model. |
df.Q.diff |
Degrees of freedom for difference in goodness of fit between standard and additive model. |
pval.Q.diff |
P-value for difference in goodness of fit between standard and additive model. |
A.matrix |
Adjacency matrix (nxn). |
B.matrix |
Edge-vertex incidence matrix (mxn). |
C.matrix |
As defined above. |
sm |
Summary measure. |
level.ma |
Level for confidence intervals. |
common , random , tau.preset
|
As defined above. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.comps |
A numeric defining the minimum number of characters used to create unique component names. |
inactive , sep.comps , sep.ia
|
As defined above. |
backtransf |
A logical indicating whether results should be back transformed in printouts and forest plots. |
title |
Title of meta-analysis / systematic review. |
x |
As defined above. |
call |
Function call. |
version |
Version of R package netmeta used to create object. |
This function calculates effects for individual components and complex interventions present in the network.
R function netcomplex
can be used to calculate the
effect for arbitrary complex interventions in a component network
meta-analysis. Furthermore, R function netcomparison
can be used to calculate the effect for comparisons of two
arbitrary complex intervention in a component network
meta-analysis.
Gerta Rücker [email protected], Guido Schwarzer [email protected]
König J, Krahn U, Binder H (2013): Visualizing the flow of evidence in network meta-analysis and characterizing mixed treatment comparisons. Statistics in Medicine, 32, 5414–29
Mills EJ, Thorlund K, Ioannidis JP (2012): Calculating additive treatment effects from multiple randomized trials provides useful estimates of combination therapies. Journal of Clinical Epidemiology, 65, 1282–8
Rücker G, Petropoulou M, Schwarzer G (2020): Network meta-analysis of multicomponent interventions. Biometrical Journal, 62, 808–21
Welton NJ, Caldwell DM, Adamopoulos E, Vedhara K (2009): Mixed treatment comparison meta-analysis of complex interventions: psychological interventions in coronary heart disease. American Journal of Epidemiology, 169: 1158–65
discomb
, netmeta
,
forest.netcomb
, print.netcomb
,
netcomplex
, netcomparison
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) net1 forest(net1, xlim = c(0.2, 50)) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") nc1 forest(nc1, xlim = c(0.2, 50)) ## Not run: # Specify, order of treatments # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Ind drug", "Hypericum", "Face-to-face CBT", "Face-to-face PST", "Face-to-face interpsy", "Face-to-face psychodyn", "Other face-to-face", "Remote CBT", "Self-help CBT", "No contact CBT", "Face-to-face CBT + SSRI", "Face-to-face interpsy + SSRI", "Face-to-face PST + SSRI", "UC", "Placebo") # # Note, three treatments are actually combinations of 'SSRI' with # other components: # "Face-to-face CBT + SSRI", # "Face-to-face interpsy + SSRI", # "Face-to-face PST + SSRI" # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, ref = "placebo", seq = trts, sm = "OR", common = FALSE) net2 forest(net2, xlim = c(0.2, 50)) # Additive model for treatment components (with placebo as inactive # treatment) # nc2 <- netcomb(net2, inactive = "placebo") nc2 forest(nc2, xlim = c(0.2, 50)) ## End(Not run)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) net1 forest(net1, xlim = c(0.2, 50)) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") nc1 forest(nc1, xlim = c(0.2, 50)) ## Not run: # Specify, order of treatments # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Ind drug", "Hypericum", "Face-to-face CBT", "Face-to-face PST", "Face-to-face interpsy", "Face-to-face psychodyn", "Other face-to-face", "Remote CBT", "Self-help CBT", "No contact CBT", "Face-to-face CBT + SSRI", "Face-to-face interpsy + SSRI", "Face-to-face PST + SSRI", "UC", "Placebo") # # Note, three treatments are actually combinations of 'SSRI' with # other components: # "Face-to-face CBT + SSRI", # "Face-to-face interpsy + SSRI", # "Face-to-face PST + SSRI" # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, ref = "placebo", seq = trts, sm = "OR", common = FALSE) net2 forest(net2, xlim = c(0.2, 50)) # Additive model for treatment components (with placebo as inactive # treatment) # nc2 <- netcomb(net2, inactive = "placebo") nc2 forest(nc2, xlim = c(0.2, 50)) ## End(Not run)
Calculate comparison effects of two arbitrary complex interventions (i.e., combinations of several components) in component network meta-analysis.
netcomparison( x, treat1, treat2, common = x$common, random = x$random, level = x$level.ma, nchar.comps = x$nchar.comps, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netcomparison' print( x, common = x$common, random = x$random, backtransf = x$backtransf, nchar.comps = x$nchar.comps, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), big.mark = gs("big.mark"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
netcomparison( x, treat1, treat2, common = x$common, random = x$random, level = x$level.ma, nchar.comps = x$nchar.comps, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netcomparison' print( x, common = x$common, random = x$random, backtransf = x$backtransf, nchar.comps = x$nchar.comps, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), big.mark = gs("big.mark"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
treat1 |
A character vector defining the first complex intervention(s). |
treat2 |
A character vector defining the second complex intervention(s). |
common |
A logical indicating whether results for common effects model should be conducted. |
random |
A logical indicating whether results for random effects model should be conducted. |
level |
The level used to calculate confidence intervals for combinations of components. |
nchar.comps |
A numeric defining the minimum number of characters used to create unique names for components (see Details). |
backtransf |
A logical indicating whether printed results
should be back transformed. If |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
digits |
Minimal number of significant digits, see
|
digits.stat |
Minimal number of significant digits for z-value
of test for overall effect, see |
digits.pval |
Minimal number of significant digits for
p-values, 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 combination effect should be printed according to JAMA reporting standards. |
big.mark |
A character used as thousands separator. |
legend |
A logical indicating whether a legend should be printed. |
R functions netcomb
and discomb
calculate effects for individual components and complex
interventions present in the component network meta-analysis
(CNMA). This function can be used to calculate the effect for
comparisons of two arbitrary complex interventions defined by
arguments treat1
and treat2
.
All complex interventions occuring in the network are considered
for the first complex intervention if argument treat1
is
missing. The reference group defined in the (C)NMA is used as
second complex intervention if argument treat2
is
missing. The first complex intervention in the (C)NMA is used if
the reference group is not defined.
The following matrices are needed to calculate comparison effects of arbitrary complex interventions, (Rücker et al., 2020, Section 3.2):
B matrix describing how comparisons are composed by complex intervetions,
C matrix describing how the complex interventions are composed by the components.
Internally, both matrices are constructed based on arguments
x
, treat1
and treat2
.
By default, component names are not abbreviated in
printouts. However, in order to get more concise printouts,
argument nchar.comps
can be used to define the minimum
number of characters for abbreviated component names (see
abbreviate
, argument minlength
). R function
treats
is utilised internally to create abbreviated
component names.
A list is returned by the function netcomparison
with the
following elements:
comparison |
Comparison. |
TE.common , TE.random
|
A vector of comparison effects (common and random effects model). |
seTE.common , seTE.random
|
A vector with corresponding standard errors (common and random effects model). |
lower.common , lower.random
|
A vector with lower confidence limits for comparisons (common and random effects model). |
upper.common , upper.random
|
A vector with upper confidence limits for comparisons (common and random effects model). |
statistic.common , statistic.random
|
A vector with z-values for the overall effect of comparisons (common and random effects model). |
pval.common , pval.random
|
A vector with p-values for the overall effect of comparisons (common and random effects model). |
trts |
Treatments included in comparisons. |
comps |
Components included in comparisons. |
treat1 , treat2
|
A defined above. |
common , random
|
A defined above. |
level , nchar.comps , backtransf , x
|
A defined above. |
B.matrix |
B matrix. |
C.matrix |
C matrix. |
R function netcomplex
can be used to calculate the
effect for arbitrary complex interventions in a component network
meta-analysis.
Guido Schwarzer [email protected]
Rücker G, Petropoulou M, Schwarzer G (2020): Network meta-analysis of multicomponent interventions. Biometrical Journal, 62, 808–21
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Result for comparison Face-to-face PST vs TCA netcomparison(nc1, "Face-to-face PST", "TCA", nchar.comps = 4) netcomparison(nc1, "F", "T", nchar.comps = 4) # Result for comparison Face-to-face PST vs TCA + Placebo netcomparison(nc1, "Face-to-face PST", "TCA + Plac", nchar.comps = 4) ## Not run: # Artificial example t1 <- rep("A", 3) t2 <- c("B+C", "A+C", "C+D") TE <- c(0, 1, 0) seTE <- rep(1, 3) # Conduct (C)NMA net2 <- netmeta(TE, seTE, t1, t2, random = FALSE) nc2 <- netcomb(net2) # Result for comparison A vs B + D netcomparison(nc2, "A", "B + D") # Same results netcomparison(nc2, "A", "B+D") netcomparison(nc2, "A", "D+B") netcomparison(nc2, "a", "d+b") # Generated B matrix netcomparison(nc2, "A", "B + D")$C.matrix # Generated B matrix netcomparison(nc2, "A", "B + D")$B.matrix ## End(Not run)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Result for comparison Face-to-face PST vs TCA netcomparison(nc1, "Face-to-face PST", "TCA", nchar.comps = 4) netcomparison(nc1, "F", "T", nchar.comps = 4) # Result for comparison Face-to-face PST vs TCA + Placebo netcomparison(nc1, "Face-to-face PST", "TCA + Plac", nchar.comps = 4) ## Not run: # Artificial example t1 <- rep("A", 3) t2 <- c("B+C", "A+C", "C+D") TE <- c(0, 1, 0) seTE <- rep(1, 3) # Conduct (C)NMA net2 <- netmeta(TE, seTE, t1, t2, random = FALSE) nc2 <- netcomb(net2) # Result for comparison A vs B + D netcomparison(nc2, "A", "B + D") # Same results netcomparison(nc2, "A", "B+D") netcomparison(nc2, "A", "D+B") netcomparison(nc2, "a", "d+b") # Generated B matrix netcomparison(nc2, "A", "B + D")$C.matrix # Generated B matrix netcomparison(nc2, "A", "B + D")$B.matrix ## End(Not run)
Calculate effect of arbitrary complex interventions (i.e., combinations of several components) in component network meta-analysis.
netcomplex( x, complex, common = x$common, random = x$random, level = x$level.ma, nchar.comps = x$nchar.trts, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netcomplex' print( x, common = x$common, random = x$random, backtransf = x$backtransf, nchar.comps = x$nchar.comps, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), big.mark = gs("big.mark"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
netcomplex( x, complex, common = x$common, random = x$random, level = x$level.ma, nchar.comps = x$nchar.trts, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netcomplex' print( x, common = x$common, random = x$random, backtransf = x$backtransf, nchar.comps = x$nchar.comps, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), big.mark = gs("big.mark"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
complex |
A matrix, vector or single numeric defining the complex intervention(s) (see Details). |
common |
A logical indicating whether results for common effects model should be conducted. |
random |
A logical indicating whether results for random effects model should be conducted. |
level |
The level used to calculate confidence intervals for combinations of components. |
nchar.comps |
A numeric defining the minimum number of characters used to create unique names for components (see Details). |
backtransf |
A logical indicating whether printed results
should be back transformed. If |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
digits |
Minimal number of significant digits, see
|
digits.stat |
Minimal number of significant digits for z-value
of test for overall effect, see |
digits.pval |
Minimal number of significant digits for
p-values, 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 combination effect should be printed according to JAMA reporting standards. |
big.mark |
A character used as thousands separator. |
legend |
A logical indicating whether a legend should be printed. |
R functions netcomb
and discomb
only
report results for complex interventions present in the
network. This function can be used to calculate the effect for
arbitrary complex interventions.
Complex interventions can be specified using argument complex
:
a character vector with definition of complex interventions,
a single numeric defining the number of components to combine in a complex intervention,
a dedicated C matrix.
In order to calculate effects of arbitrary complex interventions, a
C matrix is needed which describes how the complex interventions
are composed by the components (Rücker et al., 2020, Section
3.2). The C matrix is constructed internally if not provided by
argument complex
. All complex interventions occuring in the
network are considered if argument complex
is missing.
By default, component names are not abbreviated in
printouts. However, in order to get more concise printouts,
argument nchar.comps
can be used to define the minimum
number of characters for abbreviated component names (see
abbreviate
, argument minlength
). R function
treats
is utilised internally to create abbreviated
component names.
A list is returned by the function netcomplex
with the
following elements:
complex |
Complex intervention(s). |
Comb.common , Comb.random
|
A vector of combination effects (common and random effects model). |
seComb.common , seComb.random
|
A vector with corresponding standard errors (common and random effects model). |
lower.Comb.common , lower.Comb.random
|
A vector with lower confidence limits for combinations (common and random effects model). |
upper.Comb.common , upper.Comb.random
|
A vector with upper confidence limits for combinations (common and random effects model). |
statistic.Comb.common , statistic.Comb.random
|
A vector with z-values for the overall effect of combinations (common and random effects model). |
pval.Comb.common , pval.Comb.random
|
A vector with p-values for the overall effect of combinations (common and random effects model). |
common , random
|
A defined above. |
level , nchar.comps , backtransf , x
|
A defined above. |
C.matrix |
C matrix. |
R function netcomparison
can be used to calculate the
effect for comparisons of two arbitrary complex intervention in a
component network meta-analysis.
Guido Schwarzer [email protected]
Rücker G, Petropoulou M, Schwarzer G (2020): Network meta-analysis of multicomponent interventions. Biometrical Journal, 62, 808–21
netcomb
, discomb
,
netcomparison
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Result for combination Face-to-face PST + SSRI netcomplex(nc1, "Face-to-face PST + SSRI", nchar.comps = 4) netcomplex(nc1, "F + S", nchar.comps = 4) # Result for combination Face-to-face PST + SSRI + Placebo netcomplex(nc1, "Face-to-face PST + SSRI + Plac", nchar.comps = 4) ## Not run: # Artificial example t1 <- rep("A", 3) t2 <- c("B+C", "A+C", "C+D") TE <- c(0, 1, 0) seTE <- rep(1, 3) # Conduct (C)NMA net2 <- netmeta(TE, seTE, t1, t2, random = FALSE) nc2 <- netcomb(net2) # Result for combination A + B + C netcomplex(nc2, "A + B + C") # Same results netcomplex(nc2, "A+B+C") netcomplex(nc2, "B+C+A") netcomplex(nc2, "C+B+A") netcomplex(nc2, "c+b+a") # Generated C matrix netcomplex(nc2, c(LETTERS[1:4], "A+B+C"))$C.matrix # Results for all possible combinations of two components netcomplex(nc2, 2) # Results for all possible combinations of three components netcomplex(nc2, 3) ## End(Not run)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") # Result for combination Face-to-face PST + SSRI netcomplex(nc1, "Face-to-face PST + SSRI", nchar.comps = 4) netcomplex(nc1, "F + S", nchar.comps = 4) # Result for combination Face-to-face PST + SSRI + Placebo netcomplex(nc1, "Face-to-face PST + SSRI + Plac", nchar.comps = 4) ## Not run: # Artificial example t1 <- rep("A", 3) t2 <- c("B+C", "A+C", "C+D") TE <- c(0, 1, 0) seTE <- rep(1, 3) # Conduct (C)NMA net2 <- netmeta(TE, seTE, t1, t2, random = FALSE) nc2 <- netcomb(net2) # Result for combination A + B + C netcomplex(nc2, "A + B + C") # Same results netcomplex(nc2, "A+B+C") netcomplex(nc2, "B+C+A") netcomplex(nc2, "C+B+A") netcomplex(nc2, "c+b+a") # Generated C matrix netcomplex(nc2, c(LETTERS[1:4], "A+B+C"))$C.matrix # Results for all possible combinations of two components netcomplex(nc2, 2) # Results for all possible combinations of three components netcomplex(nc2, 3) ## End(Not run)
To determine the network structure and to test whether a given
network is fully connected. Network information is provided as a
triple of vectors treat1
, treat2
, and studlab
where each row corresponds to an existing pairwise treatment
comparison (treat1
, treat2
) in a study
(studlab
). The function calculates the number of subnetworks
(connectivity components; value of 1 corresponds to a fully
connected network) and the distance matrix (in block-diagonal form
in the case of subnetworks). If some treatments are combinations of
other treatments or have common components, an analysis based on
the additive network meta-analysis model might be possible, see
discomb function.
## Default S3 method: netconnection( data = NULL, treat1, treat2, studlab = NULL, subset = NULL, sep.trts = ":", nchar.trts = 666, title = "", details.disconnected = FALSE, warn = FALSE, ... ) ## S3 method for class 'pairwise' netconnection( data, treat1, treat2, studlab = NULL, subset = NULL, sep.trts = ":", drop.NA = TRUE, nchar.trts = 666, title = "", details.disconnected = FALSE, warn = FALSE, ... ) ## S3 method for class 'netmeta' netconnection( data, sep.trts = data$sep.trts, nchar.trts = data$nchar.trts, title = data$title, details.disconnected = FALSE, warn = FALSE, ... ) ## S3 method for class 'netcomb' netconnection( data, sep.trts = data$sep.trts, nchar.trts, title = data$title, details.disconnected = FALSE, warn = FALSE, ... ) ## S3 method for class 'netconnection' print( x, digits = max(4, .Options$digits - 3), nchar.trts = x$nchar.trts, details = FALSE, details.disconnected = x$details.disconnected, ... ) netconnection(data, ...)
## Default S3 method: netconnection( data = NULL, treat1, treat2, studlab = NULL, subset = NULL, sep.trts = ":", nchar.trts = 666, title = "", details.disconnected = FALSE, warn = FALSE, ... ) ## S3 method for class 'pairwise' netconnection( data, treat1, treat2, studlab = NULL, subset = NULL, sep.trts = ":", drop.NA = TRUE, nchar.trts = 666, title = "", details.disconnected = FALSE, warn = FALSE, ... ) ## S3 method for class 'netmeta' netconnection( data, sep.trts = data$sep.trts, nchar.trts = data$nchar.trts, title = data$title, details.disconnected = FALSE, warn = FALSE, ... ) ## S3 method for class 'netcomb' netconnection( data, sep.trts = data$sep.trts, nchar.trts, title = data$title, details.disconnected = FALSE, warn = FALSE, ... ) ## S3 method for class 'netconnection' print( x, digits = max(4, .Options$digits - 3), nchar.trts = x$nchar.trts, details = FALSE, details.disconnected = x$details.disconnected, ... ) netconnection(data, ...)
data |
A data frame, e.g., created with
|
treat1 |
Label / number for first treatment (ignored if
|
treat2 |
Label / number for second treatment (ignored if
|
studlab |
Study labels (ignored if |
subset |
An optional vector specifying a subset of studies to be used. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
title |
Title of meta-analysis / systematic review. |
details.disconnected |
A logical indicating whether to print more details for disconnected networks. |
warn |
A logical indicating whether warnings should be printed. |
... |
Additional arguments (ignored at the moment) |
drop.NA |
A logical indicating whether comparisons with missing treatment estimates or standard errors should be considered. |
x |
An object of class |
digits |
Minimal number of significant digits, see
|
details |
A logical indicating whether to print the distance matrix. |
An object of class netconnection
with corresponding
print
function. The object is a list containing the
following components:
treat1 , treat2 , studlab , title , warn , nchar.trts
|
As defined above. |
k |
Total number of studies. |
m |
Total number of pairwise comparisons. |
n |
Total number of treatments. |
n.subnets |
Number of subnetworks; equal to 1 for a fully connected network. |
D.matrix |
Distance matrix. |
A.matrix |
Adjacency matrix. |
L.matrix |
Laplace matrix. |
call |
Function call. |
version |
Version of R package netmeta used to create object. |
Gerta Rücker [email protected], Guido Schwarzer [email protected]
data(Senn2013) nc1 <- netconnection(treat1, treat2, studlab, data = Senn2013) nc1 # Extract number of (sub)networks # nc1$n.subnets # Extract distance matrix # nc1$D.matrix ## Not run: # Conduct network meta-analysis (results not shown) # net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013) # Artificial example with two subnetworks # t1 <- c("G", "B", "B", "D", "A", "F") t2 <- c("B", "C", "E", "E", "H", "A") # nc2 <- netconnection(t1, t2) print(nc2, details = TRUE) # Number of subnetworks # nc2$n.subnets # Extract distance matrix # nc2$D.matrix # Conduct network meta-analysis (results in an error message due to # unconnected network) try(net2 <- netmeta(1:6, 1:6, t1, t2, 1:6)) # Conduct network meta-analysis on first subnetwork # net2.1 <- netmeta(1:6, 1:6, t1, t2, 1:6, subset = nc2$subnet == 1) # Conduct network meta-analysis on second subnetwork # net2.2 <- netmeta(1:6, 1:6, t1, t2, 1:6, subset = nc2$subnet == 2) net2.1 net2.2 ## End(Not run)
data(Senn2013) nc1 <- netconnection(treat1, treat2, studlab, data = Senn2013) nc1 # Extract number of (sub)networks # nc1$n.subnets # Extract distance matrix # nc1$D.matrix ## Not run: # Conduct network meta-analysis (results not shown) # net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013) # Artificial example with two subnetworks # t1 <- c("G", "B", "B", "D", "A", "F") t2 <- c("B", "C", "E", "E", "H", "A") # nc2 <- netconnection(t1, t2) print(nc2, details = TRUE) # Number of subnetworks # nc2$n.subnets # Extract distance matrix # nc2$D.matrix # Conduct network meta-analysis (results in an error message due to # unconnected network) try(net2 <- netmeta(1:6, 1:6, t1, t2, 1:6)) # Conduct network meta-analysis on first subnetwork # net2.1 <- netmeta(1:6, 1:6, t1, t2, 1:6, subset = nc2$subnet == 1) # Conduct network meta-analysis on second subnetwork # net2.2 <- netmeta(1:6, 1:6, t1, t2, 1:6, subset = nc2$subnet == 2) net2.1 net2.2 ## End(Not run)
This function generates the contribution of direct comparisons to every network treatment comparison. The output is a matrix where rows represent network treatment effects and columns represent the contribution of direct treatment effects.
netcontrib( x, method = "shortestpath", hatmatrix.F1000 = FALSE, common = x$common, random = x$random, nchar.trts = x$nchar.trts, warn.deprecated = gs("warn.deprecated"), verbose = FALSE, ... ) ## S3 method for class 'netcontrib' print( x, common = x$x$common, random = x$x$random, digits = 4, nchar.trts = x$nchar.trts, legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
netcontrib( x, method = "shortestpath", hatmatrix.F1000 = FALSE, common = x$common, random = x$random, nchar.trts = x$nchar.trts, warn.deprecated = gs("warn.deprecated"), verbose = FALSE, ... ) ## S3 method for class 'netcontrib' print( x, common = x$x$common, random = x$x$random, digits = 4, nchar.trts = x$nchar.trts, legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
method |
A character string indicating which method is to
calculate the contribution matrix. Either |
hatmatrix.F1000 |
A logical indicating whether hat matrix
given in F1000 article should be used for |
common |
A logical indicating whether a contribution matrix should be printed for the common effects network meta-analysis. |
random |
A logical indicating whether a contribution matrix should be printed for the random effects network meta-analysis. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names (see Details). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
verbose |
A logical indicating whether progress information should be printed. |
... |
Additional arguments. |
digits |
Minimal number of significant digits, see
|
legend |
A logical indicating whether a legend should be printed. |
In network meta-analysis (NMA), it is important to assess the influence of limitations or other characteristics of individual studies on the estimates obtained from the network. To this end, the contribution matrix shows how much each direct treatment effect contributes to each treatment effect estimate from network meta-analysis.
We use ideas from graph theory to derive the proportion that is contributed by each direct treatment effect. We start with the 'projection' matrix in a two-step network meta-analysis model, called the H matrix, which is analogous to the hat matrix in a linear regression model. H entries are translated to proportion contributions based on the observation that the rows of H can be interpreted as flow networks. A stream is defined as the composition of a path and its associated flow (Papakonstantinou et al., 2018).
To account for multi-arm trials, we use the H matrix from a
two-step (aggregate) version of the graph theoretical NMA model
(Davies et al., 2022). This H matrix can be obtained from
hatmatrix
with argument method = "davies"
.
Four methods are implemented to estimate the proportion contributions:
(1) If argument method = "randomwalk"
, an analytical
random-walk (RW) approach is used (Davies et al., 2022). Here, the
"full" version of the aggregate H matrix (hatmatrix
with arguments method = "davies"
and type = "full"
)
is used to define RW transition matrices. For each pair of
treatments (ij) in the network, the elements in the corresponding
row of H-full define a transition matrix from node i to node j. We
use the igraph package to find every (directed) path from
node i to node j. The flow through each path is then equal to the
probability that a walker takes that path. This is simply the
product of the transition probabilities associated with each edge
along the path.
(2) If argument method = "shortestpath"
, an iterative
algorithm is used (Papakonstantinou et al., 2018). Broadly
speaking, each iteration of the algorithm consists of the following
steps: (i) A path in the evidence flow network is selected. (ii)
The minimum flow through the edges making up the path is
identified. This is assigned as the flow associated with the
path. (iii) The flow of the path is subtracted from the values of
flow in the edges that make up that path. This means that the edge
corresponding to the minimum flow in that path is removed from the
graph. (iv) A new path is then selected from the remaining
graph. The process repeats until all the evidence flow in the edges
has been assigned to a path.
In the original F1000 paper (Papakonstantinou et al., 2018), the
hat matrix used did not account for correlations due to multi-arm
trials. For reproducibility the result of this version can be
obtained by specifying hatmatrix.F1000 = TRUE
for
method = "shortestpath"
. For other purposes, this method is
not recommended.
(3) If argument method = "cccp"
, contributions are estimated
using l1
from R package cccp (Rücker et
al., 2023, unpublished).
(4) If argument method = "pseudoinverse"
, contributions are
derived from an L2 solution based on a Moore-Penrose pseudoinverse
(Rücker et al., 2023, unpublished).
Once the streams have been identified by any method, the proportion contribution of each direct comparison is equal to the sum over the flow of evidence in each path containing that edge divided by the number of edges that make up that path.
By default, treatment names are not abbreviated in
printouts. However, in order to get more concise printouts,
argument nchar.trts
can be used to define the minimum number
of characters for abbreviated treatment names (see
abbreviate
, argument minlength
). R function
treats
is utilised internally to create abbreviated
treatment names.
Calculation of network contributions can be compute-intensive for
the random-walk approach in large networks. Crude information on
the computation progress is printed if argument verbose
is
TRUE
. In addition, computation times are printed if R
package tictoc is installed.
An object of class netcontrib
with corresponding
print
function. The object is a list containing the
following components:
common |
Numeric matrix of percentage contributions of direct comparisons for each network comparison for the common effects model. |
random |
Numeric matrix of percentage contributions of direct comparisons for each network comparison for the random effects model. |
x |
As defined above. |
tictoc.common |
Computation times under common effects model (if R package tictoc is installed). |
tictoc.random |
Computation times under random effects model (if R package tictoc is installed). |
with the contribution matrices for common and random NMA. Each matrix has the percentage contributions of each direct comparison as columns for each network comparison, direct or indirect as rows.
Theodoros Papakonstantinou [email protected], Annabel Davies [email protected]
Davies AL, Papakonstantinou T, Nikolakopoulou A, Rücker G, Galla T (2022): Network meta-analysis and random walks. Statistics in Medicine, 41, 2091–2114
Papakonstantinou, T., Nikolakopoulou, A., Rücker, G., Chaimani, A., Schwarzer, G., Egger, M., Salanti, G. (2018): Estimating the contribution of studies in network meta-analysis: paths, flows and streams. F1000Research
# Use the Woods dataset # p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1) cm <- netcontrib(net1) cm netcontrib(net1, method = "r")
# Use the Woods dataset # p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1) cm <- netcontrib(net1) cm netcontrib(net1, method = "r")
Calculate distance matrix for an adjacency matrix based on distance algorithm by Müller et al. (1987).
## Default S3 method: netdistance(x) ## S3 method for class 'netmeta' netdistance(x) ## S3 method for class 'netcomb' netdistance(x) ## S3 method for class 'netconnection' netdistance(x) ## S3 method for class 'netdistance' print(x, lab.Inf = ".", ...) netdistance(x)
## Default S3 method: netdistance(x) ## S3 method for class 'netmeta' netdistance(x) ## S3 method for class 'netcomb' netdistance(x) ## S3 method for class 'netconnection' netdistance(x) ## S3 method for class 'netdistance' print(x, lab.Inf = ".", ...) netdistance(x)
x |
Either a netmeta or netcomb object or an adjacency matrix. |
lab.Inf |
A character string to label infinite values. |
... |
Additional arguments (ignored). |
Gerta Rücker [email protected] Guido Schwarzer [email protected]
Müller WR, Szymanski K, Knop JV, and Trinajstic N (1987): An algorithm for construction of the molecular distance matrix. Journal of Computational Chemistry, 8, 170–73
data(smokingcessation) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1, common = FALSE) netdistance(net1) ## Not run: data(Senn2013) net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") netdistance(net1) netdistance(net1$A.matrix) ## End(Not run)
data(smokingcessation) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1, common = FALSE) netdistance(net1) ## Not run: data(Senn2013) net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") netdistance(net1) netdistance(net1$A.matrix) ## End(Not run)
Generic function for network graphs
netgraph(x, ...)
netgraph(x, ...)
x |
An R object. |
... |
Additional arguments. |
For more details, look at the following functions to generate network graphs:
Guido Schwarzer [email protected]
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) # Network graph with default settings # netgraph(net1) ## Not run: data(Senn2013) # Generation of an object of class 'netmeta' with reference # treatment 'plac' # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac") # Network graph with default settings # netgraph(net2) p3 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net3 <- netmeta(p3) # Network graph with default settings # netgraph(net3) # Network graph with # - number of studies for each pairwise comparison and # - number of participants for each treatment arm # netgraph(net3, number.of.studies = TRUE, labels = paste0(trts, " (n=", n.trts, ")")) ## End(Not run)
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) # Network graph with default settings # netgraph(net1) ## Not run: data(Senn2013) # Generation of an object of class 'netmeta' with reference # treatment 'plac' # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac") # Network graph with default settings # netgraph(net2) p3 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net3 <- netmeta(p3) # Network graph with default settings # netgraph(net3) # Network graph with # - number of studies for each pairwise comparison and # - number of participants for each treatment arm # netgraph(net3, number.of.studies = TRUE, labels = paste0(trts, " (n=", n.trts, ")")) ## End(Not run)
This function generates a graph of the evidence network.
## S3 method for class 'discomb' netgraph( x, labels = x$trts, adj = NULL, offset = if (!is.null(adj) && all(unique(adj) == 0.5)) 0 else 0.0175, rotate = 0, points = !missing(cex.points), cex.points = 1, ... )
## S3 method for class 'discomb' netgraph( x, labels = x$trts, adj = NULL, offset = if (!is.null(adj) && all(unique(adj) == 0.5)) 0 else 0.0175, rotate = 0, points = !missing(cex.points), cex.points = 1, ... )
x |
An object of class |
labels |
An optional vector with treatment labels. |
adj |
One, two, or three values in [0, 1] (or a vector / matrix with length / number of rows equal to the number of treatments) specifying the x (and optionally y and z) adjustment for treatment labels. |
offset |
Distance between edges (i.e. treatments) in graph and treatment labels for 2-D plots (value of 0.0175 corresponds to a difference of 1.75% of the range on x- and y-axis). |
rotate |
A single numeric with value between -180 and 180 specifying the angle to rotate nodes in a circular network. |
points |
A logical indicating whether points should be printed at nodes (i.e. treatments) of the network graph. |
cex.points |
Corresponding point size. Can be a vector with length equal to the number of treatments. |
... |
Additional arguments passed on to
|
The arguments seq
and iterate
are used internally and
cannot be specified by the user.
Guido Schwarzer [email protected], Gerta Rücker [email protected]
# Artificial dataset # t1 <- c("A + B", "A + C", "A" , "A" , "D", "D", "E") t2 <- c("C" , "B" , "B + C", "A + D", "E", "F", "F") # mean <- c(4.1, 2.05, 0, 0, 0.1, 0.1, 0.05) se.mean <- rep(0.1, 7) # study <- paste("study", c(1:4, 5, 5, 5)) # dat <- data.frame(mean, se.mean, t1, t2, study, stringsAsFactors = FALSE) # trts <- c("A", "A + B", "A + C", "A + D", "B", "B + C", "C", "D", "E", "F") # comps <- LETTERS[1:6] # Use netconnection() to display network information # netconnection(t1, t2, study) dc1 <- discomb(mean, se.mean, t1, t2, study, seq = trts) netgraph(dc1)
# Artificial dataset # t1 <- c("A + B", "A + C", "A" , "A" , "D", "D", "E") t2 <- c("C" , "B" , "B + C", "A + D", "E", "F", "F") # mean <- c(4.1, 2.05, 0, 0, 0.1, 0.1, 0.05) se.mean <- rep(0.1, 7) # study <- paste("study", c(1:4, 5, 5, 5)) # dat <- data.frame(mean, se.mean, t1, t2, study, stringsAsFactors = FALSE) # trts <- c("A", "A + B", "A + C", "A + D", "B", "B + C", "C", "D", "E", "F") # comps <- LETTERS[1:6] # Use netconnection() to display network information # netconnection(t1, t2, study) dc1 <- discomb(mean, se.mean, t1, t2, study, seq = trts) netgraph(dc1)
This function generates a graph of the evidence network.
## S3 method for class 'netcomb' netgraph(x, ...)
## S3 method for class 'netcomb' netgraph(x, ...)
x |
An object of class |
... |
Additional arguments passed on to
|
Guido Schwarzer [email protected], Gerta Rücker [email protected]
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") netgraph(nc1)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, ref = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components (with placebo as inactive # treatment) # nc1 <- netcomb(net1, inactive = "placebo") netgraph(nc1)
This function generates a graph of the evidence network.
## S3 method for class 'netconnection' netgraph( x, seq, col = seq_len(x$n.subnets), reference.group = NULL, plastic = gs("plastic"), ... )
## S3 method for class 'netconnection' netgraph( x, seq, col = seq_len(x$n.subnets), reference.group = NULL, plastic = gs("plastic"), ... )
x |
An object of class |
seq |
A character or numerical vector specifying the sequence
of treatments arrangement (anticlockwise if |
col |
A single color (or vector of colors) for lines
connecting treatments (edges) if argument |
reference.group |
Reference treatment (only relevant for disconnected networks). |
plastic |
A logical indicating whether the appearance of the comparisons should be in '3D look'. |
... |
Additional arguments passed on to
|
Argument col
can be a single color for all edges, a vector
of length equal to the number of edges, or a vector of length equal
to the number of subnetworks. Argument reference.group
is
only considered in disconnected networks, i.e., if more than one
(sub)network exists, and if argument col
provides colors for
subnetworks. In this case, the first color provided in argument
col
defines the color for the subnetwork with the reference
treatment.
Guido Schwarzer [email protected], Gerta Rücker [email protected]
netconnection
, netgraph.netmeta
# Artificial example with two subnetworks # t1 <- c("G", "B", "B", "D", "A", "F") t2 <- c("B", "C", "E", "E", "H", "A") # nc1 <- netconnection(t1, t2) print(nc1, details = TRUE) netgraph(nc1, points = TRUE, adj = 0.5, bg.points = "lightgray") netgraph(nc1, points = TRUE, adj = 0.5, bg.points = "lightgray", plastic = TRUE)
# Artificial example with two subnetworks # t1 <- c("G", "B", "B", "D", "A", "F") t2 <- c("B", "C", "E", "E", "H", "A") # nc1 <- netconnection(t1, t2) print(nc1, details = TRUE) netgraph(nc1, points = TRUE, adj = 0.5, bg.points = "lightgray") netgraph(nc1, points = TRUE, adj = 0.5, bg.points = "lightgray", plastic = TRUE)
This function generates a graph of the evidence network.
## S3 method for class 'netimpact' netgraph( x, col.ignore = "red", number.of.studies = TRUE, main, sub, multiarm = gs("multiarm"), col.multiarm = NULL, alpha.transparency = 0.5, col.ignore.multiarm = "transparent", col = "black", plastic = gs("plastic"), ... )
## S3 method for class 'netimpact' netgraph( x, col.ignore = "red", number.of.studies = TRUE, main, sub, multiarm = gs("multiarm"), col.multiarm = NULL, alpha.transparency = 0.5, col.ignore.multiarm = "transparent", col = "black", plastic = gs("plastic"), ... )
x |
An object of class |
col.ignore |
A character string indicating color for
comparisons removed from network, either |
number.of.studies |
A logical indicating whether number of studies should be added to network graph. |
main |
Main title. |
sub |
Subtitle. |
multiarm |
A logical indicating whether multi-arm studies should be marked in plot. |
col.multiarm |
Either a function from R package colorspace or grDevice to define colors for multi-arm studies or a character vector with colors to highlight multi-arm studies. |
alpha.transparency |
The alpha transparency of colors used to highlight multi-arm studies (0 means transparent and 1 means opaque). |
col.ignore.multiarm |
A character string indicating color to
mark multi-arm studies removed from network, either
|
col |
A single color (or vector of colors) for lines
connecting treatments (edges) if argument |
plastic |
A logical indicating whether the appearance of the comparisons should be in '3D look'. |
... |
Additional arguments passed on to
|
Guido Schwarzer [email protected], Gerta Rücker [email protected]
netimpact
, netgraph.netmeta
,
dat.franchini2012
# Only consider first two studies (to reduce runtime of example) # studies <- unique(dat.franchini2012$Study) p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = subset(dat.franchini2012, Study %in% studies[1:2]), studlab = Study) net1 <- netmeta(p1) ni1 <- netimpact(net1, verbose = TRUE) netgraph(ni1) netgraph(ni1, plastic = TRUE) ## Not run: p2 <- 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) net2 <- netmeta(p2) ni2 <- netimpact(net2, verbose = TRUE) netgraph(ni2) netgraph(ni2, plastic = TRUE) ## End(Not run)
# Only consider first two studies (to reduce runtime of example) # studies <- unique(dat.franchini2012$Study) p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = subset(dat.franchini2012, Study %in% studies[1:2]), studlab = Study) net1 <- netmeta(p1) ni1 <- netimpact(net1, verbose = TRUE) netgraph(ni1) netgraph(ni1, plastic = TRUE) ## Not run: p2 <- 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) net2 <- netmeta(p2) ni2 <- netimpact(net2, verbose = TRUE) netgraph(ni2) netgraph(ni2, plastic = TRUE) ## End(Not run)
This function generates a graph of the evidence network.
## S3 method for class 'netmeta' netgraph( x, seq = x$seq, labels = x$trts, cex = 1, adj = NULL, srt.labels = 0, offset = if (!is.null(adj) && all(unique(adj) == 0.5)) 0 else 0.0175, scale = 1.1, col = gs("col.netgraph"), plastic = gs("plastic"), thickness = gs("thickness"), lwd = 5, lwd.min = lwd/2.5, lwd.max, rescale.thickness, dim = "2d", rotate = 0, highlight = NULL, col.highlight = "red2", scale.highlight = 1, multiarm = gs("multiarm"), col.multiarm = NULL, alpha.transparency = 0.5, points = !missing(cex.points), cex.points = 1, pch.points = 20, col.points = if (length(pch.points) == 1 && pch.points == 21) "black" else "red", bg.points = "red", points.min, points.max, rescale.pointsize, number.of.studies = gs("number.of.studies"), cex.number.of.studies = cex, col.number.of.studies = "white", bg.number.of.studies = "black", pos.number.of.studies = 0.5, start.layout = ifelse(dim == "2d", "circle", "eigen"), eig1 = 2, eig2 = 3, eig3 = 4, iterate = FALSE, tol = 1e-04, maxit = 500, allfigures = FALSE, A.matrix = x$A.matrix, N.matrix = sign(A.matrix), D.matrix = netdistance(N.matrix), xpos = NULL, ypos = NULL, zpos = NULL, figure = TRUE, ... )
## S3 method for class 'netmeta' netgraph( x, seq = x$seq, labels = x$trts, cex = 1, adj = NULL, srt.labels = 0, offset = if (!is.null(adj) && all(unique(adj) == 0.5)) 0 else 0.0175, scale = 1.1, col = gs("col.netgraph"), plastic = gs("plastic"), thickness = gs("thickness"), lwd = 5, lwd.min = lwd/2.5, lwd.max, rescale.thickness, dim = "2d", rotate = 0, highlight = NULL, col.highlight = "red2", scale.highlight = 1, multiarm = gs("multiarm"), col.multiarm = NULL, alpha.transparency = 0.5, points = !missing(cex.points), cex.points = 1, pch.points = 20, col.points = if (length(pch.points) == 1 && pch.points == 21) "black" else "red", bg.points = "red", points.min, points.max, rescale.pointsize, number.of.studies = gs("number.of.studies"), cex.number.of.studies = cex, col.number.of.studies = "white", bg.number.of.studies = "black", pos.number.of.studies = 0.5, start.layout = ifelse(dim == "2d", "circle", "eigen"), eig1 = 2, eig2 = 3, eig3 = 4, iterate = FALSE, tol = 1e-04, maxit = 500, allfigures = FALSE, A.matrix = x$A.matrix, N.matrix = sign(A.matrix), D.matrix = netdistance(N.matrix), xpos = NULL, ypos = NULL, zpos = NULL, figure = TRUE, ... )
x |
An object of class |
seq |
A character or numerical vector specifying the sequence
of treatments arrangement (anticlockwise if |
labels |
An optional vector with treatment labels. |
cex |
The magnification to be used for treatment labels. |
adj |
One, two, or three values in [0, 1] (or a vector / matrix with length / number of rows equal to the number of treatments) specifying the x (and optionally y and z) adjustment for treatment labels. |
srt.labels |
The character string |
offset |
Distance between edges (i.e. treatments) in graph and treatment labels for 2-D plots (value of 0.0175 corresponds to a difference of 1.75% of the range on x- and y-axis). |
scale |
Additional space added outside of edges (i.e. treatments). Increase this value for larger treatment labels (value of 1.10 corresponds to an additional space of 10% around the network graph). |
col |
A single color (or vector of colors) for lines
connecting treatments (edges) if argument |
plastic |
A logical indicating whether the appearance of the
comparisons should be in '3D look' (not to be confused with
argument |
thickness |
Either a character variable to determine the
method to plot line widths (see Details) or a matrix of the same
dimension and row and column names as argument |
lwd |
A numeric for scaling the line width of comparisons. |
lwd.min |
Minimum line width in network graph. All connections
with line widths below this values will be set to |
lwd.max |
Maximum line width in network graph. The connection
with the largest value according to argument |
rescale.thickness |
A logical value or R function to scale the thickness of lines (see Details). |
dim |
A character string indicating whether a 2- or
3-dimensional plot should be produced, either |
rotate |
A single numeric with value between -180 and 180 specifying the angle to rotate nodes in a circular network. |
highlight |
A character vector identifying comparisons that
should be marked in the network graph, e.g. |
col.highlight |
Color(s) to highlight the comparisons given by
|
scale.highlight |
Scaling factor(s) for the line width(s) to
highlight the comparisons given by |
multiarm |
A logical indicating whether multi-arm studies should be marked in plot. |
col.multiarm |
Either a function from R package colorspace or grDevice to define colors for multi-arm studies or a character vector with colors to highlight multi-arm studies. |
alpha.transparency |
The alpha transparency of colors used to highlight multi-arm studies (0 means transparent and 1 means opaque). |
points |
A logical indicating whether points should be printed at nodes (i.e. treatments) of the network graph. |
cex.points , pch.points , col.points , bg.points
|
Corresponding size, type, color, and background color for points. Can be a vector with length equal to the number of treatments. |
points.min |
Minimum point size. All points with size below
this values will be set to |
points.max |
Maximum point size in network graph. The node
with the largest value according to argument |
rescale.pointsize |
A logical value or R function to scale the point size (see Details). |
number.of.studies |
A logical indicating whether number of studies should be added to network graph. |
cex.number.of.studies |
The magnification to be used for number of studies. |
col.number.of.studies |
Color for number of studies. |
bg.number.of.studies |
Color for shadow around number of studies. |
pos.number.of.studies |
A single value (or vector of values) in [0, 1] specifying the position of the number of studies on the lines connecting treatments (edges). Length of the vector must be equal to the number of edges. |
start.layout |
A character string indicating which starting
layout is used if |
eig1 |
A numeric indicating which eigenvector is used as x
coordinate if |
eig2 |
A numeric indicating which eigenvector is used as
y-coordinate if |
eig3 |
A numeric indicating which eigenvector is used as
z-coordinate if |
iterate |
A logical indicating whether the stress majorization algorithm is carried out for optimization of the layout. |
tol |
A numeric for the tolerance for convergence if
|
maxit |
An integer defining the maximum number of iteration
steps if |
allfigures |
A logical indicating whether all iteration steps
are shown if |
A.matrix |
Adjacency matrix (nxn) characterizing
the structure of the network graph. Row and column names must be
the same set of values as provided by argument |
N.matrix |
Neighborhood matrix (nxn) replacing
A.matrix if neighborhood is to be specified differently from node
adjacency in the network graph, for example content-based. Row
and column names must be the same set of values as provided by
argument |
D.matrix |
Distance matrix (nxn) replacing
A.matrix and N.matrix if distances should be provided
directly. Row and column names must be the same set of values as
provided by argument |
xpos |
Vector (n) of x coordinates. |
ypos |
Vector (n) of y coordinates. |
zpos |
Vector (n) of z coordinates. |
figure |
A logical indicating whether network graph should be shown. |
... |
Additional graphical arguments (passed on to
|
This function generates a network graph for an R object created
with netmeta
. R function plot.default
is used
to create the network graph.
The network is laid out in the plane, where the nodes in the graph
layout correspond to the treatments and edges display the observed
treatment comparisons. For the default setting, nodes are placed on
a circle. Other starting layouts are "eigen", "prcomp", and
"random" (Rücker & Schwarzer 2015). If iterate = TRUE
, the
layout is further optimized using the stress majorization
algorithm. This algorithm specifies an 'ideal' distance (e.g., the
graph distance) between two nodes in the plane. In the optimal
layout, these distances are best approximated in the sense of least
squares. Starting from an initial layout, the optimum is
approximated in an iterative process called stress majorization
(Kamada and Kawai 1989, Michailidis and de Leeuw 2001, Hu
2012). The starting layout can be chosen as a circle or coming from
eigenvectors of the Laplacian matrix (corresponding to Hall's
algorithm, Hall 1970), calculated in different ways, or
random. Moreover, it can be chosen whether the iteration steps are
shown (argument allfigures = TRUE
).
An optimized circular presentation which typically has a reduced
(sometimes minimal) number of crossings can be achieved by using
argument seq = "optimal"
in combination with argument
start.layout
. Note, is is not possible of prespecify the
best value for argument start.layout
for any situation as
the result depends on the network structure.
Argument thickness
providing the line width of edges
(comparisons) can be a matrix of the same dimension as argument
A.matrix
or any of the following character strings (which
can be abbreviated):
Proportional to number of studies comparing two treatments
(thickness = "number.of.studies"
, default)
Proportional to inverse standard error of common effects model
comparing two treatments (thickness = "se.common"
)
Proportional to inverse standard error of random effects
model comparing two treatments (thickness = "se.random"
)
Weight from common effects model comparing two treatments
(thickness = "w.common"
)
Weight from random effects model comparing two treatments
(thickness = "w.random"
)
Same line width for all comparisons (thickness =
"equal"
)
Only evidence from direct treatment comparisons is considered to
determine the line width if argument thickness
is equal to
any but the last method.
Line widths are determined by argument lwd
if all lines have
the same width. This is possible if either argument thickness
= "equal"
, all pairwise comparisons have the same number of
studies for thickness = "number.of.studies"
or all direct
comparisons are equally precise.
Otherwise, the line width of the thickest line is equal to the
value of argument lwd.max
and all lines with a thickness
below the value of argument lwd.min
are set to this
value. Default for argument lwd.max
is 4 * lwd
.
Argument rescale.thickness
can be used to provide a function
to specify the relative line width of edges (comparisons). By
default, the square root function sqrt
is used
in order to lessen differences in line widths. Argument
rescale.thickness = FALSE
or rescale.thickness = I
,
i.e., the identity function I
, can be used to
not rescale line widths.
Points are printed at nodes (treatments) if argument points =
TRUE
or argument cex.points
is provided.
Point sizes are equal to the value of argument cex.points
if
all points are of equal size.
Otherwise, the point size of the largest point is equal to the
value of argument points.max
and all points smaller than the
value of argument points.min
are set to this value. The
default for argument points.max
is equal to the largest
value provided in argument cex.points
if this largest value
is below or equal to 25. Otherwise the default is points.max
= 8
.
Argument rescale.pointsize
can be used to provide a function
to specify relative point sizes. Point sizes are not rescaled at
all if they are all equal or the largest cex.points
value is
below or equal to 25. Otherwise, the square root function
sqrt
is used in order to lessen the differences
in point sizes. Argument rescale.pointsize = FALSE
or
rescale.pointsize = I
, i.e., the identity function
I
, can be used to not rescale point sizes.
Argument srt.labels
can be used to specific the rotation (in
degrees) of the treatment labels. If srt.labels
is equal to
"orthogonal"
, treatment labels are orthogonal to the
circle. If srt.labels
is a single numeric, all labels are
rotated by this degree. If srt.labels
is a numeric vector,
it must be of the same length as the number of treatments and
labels are rotated counter-clockwise starting on the right
side. Finally, if srt.labels
is a named numeric vector, it
must be of the same length as the number of treatments and the
names must be equal to the treatment names (and treatment labels
are rotated according to the specified values).
Further, a couple of graphical parameters can be specified, such as
color and appearance of the edges (treatments) and the nodes
(comparisons), whether special comparisons should be highlighted
and whether multi-arm studies should be indicated as colored
polygons. By default, if R package colorspace is available the
sequential_hcl
function is used to
highlight multi-arm studies; otherwise the rainbow
is
used.
In order to generate 3-D plots (argument dim = "3d"
), R
package rgl is necessary. Note, under macOS the X.Org X
Window System must be available (see
https://www.xquartz.org).
A list containing two data frames with information on nodes and edges.
List element 'nodes'
trts |
Treatment names. |
labels |
Treatment labels. |
seq |
Sequence of treatment labels. |
srt |
String rotation. |
xpos |
Position of treatment / edge on x-axis. |
ypos |
Position of treatment / edge on y-axis. |
zpos |
Position of treatment / edge on z-axis (for 3-D plots). |
xpos.labels |
Position of treatment labels on x-axis (for 2-D plots). |
ypos.labels |
Position of treatment labels on y-axis (for 2-D plots). |
offset.x |
Offset of treatment labels on x-axis (for 2-D plots). |
offset.y |
Offset of treatment labels on y-axis (for 2-D plots). |
cex |
Point size of treatments / edges. |
col |
Color for points. |
pch |
Point type. |
bg |
Background color for points. |
adj.x |
Adjustment for treatment label on x-axis. |
adj.y |
Adjustment for treatment label on y-axis. |
adj.z |
Adjustment for treatment label on z-axis (for 3-D plots). |
List element 'edges'
treat1 |
Name of first treatment. |
treat2 |
Name of second treatment. |
n.stud |
Number of studies directly comparing treatments. |
xpos |
Position of number of studies on x-axis. |
ypos |
Position of number of studies on y-axis. |
adj |
Adjustment of number of studies. |
pos.number.of.studies |
Position of number of studies on edge. |
col |
Color for edges. |
Gerta Rücker [email protected], Ulrike Krahn [email protected], Jochem König [email protected], Guido Schwarzer [email protected]
Hall KM (1970): An r-dimensional quadratic placement algorithm. Management Science, 17, 219–29
Hu Y (2012): Combinatorial Scientific Computing, Chapter Algorithms for Visualizing Large Networks, pages 525–49. Chapman and Hall / CRC, Computational Science.
Kamada T, Kawai S (1989): An algorithm for drawing general undirected graphs. Information Processing Letters, 31, 7–15
Krahn U, Binder H, König J (2013): A graphical tool for locating inconsistency in network meta-analyses. BMC Medical Research Methodology, 13, 35
Michailidis G, de Leeuw J (2001): Data visualization through graph drawing. Computational Statistics, 16, 435–50
Rücker G, Schwarzer G (2016): Automated drawing of network plots in network meta-analysis. Research Synthesis Methods, 7, 94–107
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) # Network graph with default settings # netgraph(net1) ## Not run: data(Senn2013) # Generation of an object of class 'netmeta' with reference # treatment 'plac' # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac") # Network graph with default settings # netgraph(net2) # Network graph with specified order of the treatments and one # highlighted comparison # trts <- c("plac", "benf", "migl", "acar", "sulf", "metf", "rosi", "piog", "sita", "vild") netgraph(net2, highlight = "rosi:plac", seq = trts) # Same network graph using argument 'seq' in netmeta function # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac", seq = trts) netgraph(net3, highlight = "rosi:plac") # Network graph optimized, starting from a circle, with multi-arm # study colored # netgraph(net2, start = "circle", iterate = TRUE, multiarm = TRUE, col.multiarm = "purple") # Network graph optimized, starting from a circle, with multi-arm # study colored and all intermediate iteration steps visible # netgraph(net2, start = "circle", iterate = TRUE, multiarm = TRUE, col.multiarm = "purple", allfigures = TRUE) # Network graph optimized, starting from Laplacian eigenvectors, # with multi-arm study colored # netgraph(net2, start = "eigen", multiarm = TRUE, col.multiarm = "purple") # Network graph optimized, starting from different Laplacian # eigenvectors, with multi-arm study colored # netgraph(net2, start = "prcomp", multiarm = TRUE, col.multiarm = "purple") # Network graph optimized, starting from random initial layout, # with multi-arm study colored # netgraph(net2, start = "random", multiarm = TRUE, col.multiarm = "purple") # Network graph without plastic look and one highlighted comparison # netgraph(net2, plastic = FALSE, highlight = "rosi:plac") # Network graph with same thickness for all comparisons # netgraph(net2, thickness = "equal") # Network graph with changed labels and specified order of the # treatments # netgraph(net2, seq = c(1, 3, 5, 2, 9, 4, 7, 6, 8, 10), labels = LETTERS[1:10]) # Rotate treatment labels (orthogonal to circle) # netgraph(net2, srt.labels = "o") # Network graph in 3-D (opens a new device, where you may rotate and # zoom the plot using the mouse / the mouse wheel). # The rgl package must be installed for 3-D plots. # netgraph(net2, dim = "3d") ## End(Not run)
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) # Network graph with default settings # netgraph(net1) ## Not run: data(Senn2013) # Generation of an object of class 'netmeta' with reference # treatment 'plac' # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac") # Network graph with default settings # netgraph(net2) # Network graph with specified order of the treatments and one # highlighted comparison # trts <- c("plac", "benf", "migl", "acar", "sulf", "metf", "rosi", "piog", "sita", "vild") netgraph(net2, highlight = "rosi:plac", seq = trts) # Same network graph using argument 'seq' in netmeta function # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac", seq = trts) netgraph(net3, highlight = "rosi:plac") # Network graph optimized, starting from a circle, with multi-arm # study colored # netgraph(net2, start = "circle", iterate = TRUE, multiarm = TRUE, col.multiarm = "purple") # Network graph optimized, starting from a circle, with multi-arm # study colored and all intermediate iteration steps visible # netgraph(net2, start = "circle", iterate = TRUE, multiarm = TRUE, col.multiarm = "purple", allfigures = TRUE) # Network graph optimized, starting from Laplacian eigenvectors, # with multi-arm study colored # netgraph(net2, start = "eigen", multiarm = TRUE, col.multiarm = "purple") # Network graph optimized, starting from different Laplacian # eigenvectors, with multi-arm study colored # netgraph(net2, start = "prcomp", multiarm = TRUE, col.multiarm = "purple") # Network graph optimized, starting from random initial layout, # with multi-arm study colored # netgraph(net2, start = "random", multiarm = TRUE, col.multiarm = "purple") # Network graph without plastic look and one highlighted comparison # netgraph(net2, plastic = FALSE, highlight = "rosi:plac") # Network graph with same thickness for all comparisons # netgraph(net2, thickness = "equal") # Network graph with changed labels and specified order of the # treatments # netgraph(net2, seq = c(1, 3, 5, 2, 9, 4, 7, 6, 8, 10), labels = LETTERS[1:10]) # Rotate treatment labels (orthogonal to circle) # netgraph(net2, srt.labels = "o") # Network graph in 3-D (opens a new device, where you may rotate and # zoom the plot using the mouse / the mouse wheel). # The rgl package must be installed for 3-D plots. # netgraph(net2, dim = "3d") ## End(Not run)
This function creates a net heat plot, a graphical tool for locating inconsistency in network meta-analyses.
netheat( x, random = FALSE, tau.preset = NULL, showall = TRUE, nchar.trts = x$nchar.trts, ... )
netheat( x, random = FALSE, tau.preset = NULL, showall = TRUE, nchar.trts = x$nchar.trts, ... )
x |
An object of class |
random |
A logical indicating whether the net heat plot should be based on a random effects model. |
tau.preset |
An optional value for the square-root of the
between-study variance |
showall |
A logical indicating whether results should be shown for all designs or only a sensible subset (see Details). |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
... |
Additional arguments. |
The net heat plot is a matrix visualization proposed by Krahn et al. (2013) that highlights hot spots of inconsistency between specific direct evidence in the whole network and renders transparent possible drivers.
In this plot, the area of a gray square displays the contribution
of the direct estimate of one design in the column to a network
estimate in a row. In combination, the colors show the detailed
change in inconsistency when relaxing the assumption of consistency
for the effects of single designs. The colors on the diagonal
represent the inconsistency contribution of the corresponding
design. The colors on the off-diagonal are associated with the
change in inconsistency between direct and indirect evidence in a
network estimate in the row after relaxing the consistency
assumption for the effect of one design in the column. Cool colors
indicate an increase and warm colors a decrease: the stronger the
intensity of the color, the greater the difference between the
inconsistency before and after the detachment. So, a blue colored
element indicates that the evidence of the design in the column
supports the evidence in the row. A clustering procedure is applied
to the heat matrix in order to find warm colored hot spots of
inconsistency. In the case that the colors of a column
corresponding to design are identical to the colors on the
diagonal, the detaching of the effect of design
dissolves
the total inconsistency in the network.
The pairwise contrasts corresponding to designs of three- or multi-arm studies are marked by '_' following the treatments of the design.
Designs where only one treatment is involved in other designs of
the network or where the removal of corresponding studies would
lead to a splitting of the network do not contribute to the
inconsistency assessment. By default (showall = TRUE
), these
designs are not incorporated into the net heat plot. If
showall = FALSE
, additional designs with minimal
contribution to the inconsistency Q statistic are not incorporated
(i.e., designs with abs(Q.inc.design)
<=
.Machine$double.eps^0.5)
.).
In the case of random = TRUE
, the net heat plot is based on
a random effects model generalised for multivariate meta-analysis
in which the between-study variance is estimated by the
method of moments (see Jackson et al., 2012) and embedded in a full
design-by-treatment interaction model (see Higgins et al., 2012).
Ulrike Krahn [email protected]
Krahn U, Binder H, König J (2013): A graphical tool for locating inconsistency in network meta-analyses. BMC Medical Research Methodology, 13, 35
Jackson D, White IR and Riley RD (2012): Quantifying the impact of between-study heterogeneity in multivariate meta-analyses. Statistics in Medicine, 31, 3805–20
Higgins JPT, Jackson D, Barrett JK, Lu G, Ades AE, White IR (2012): Consistency and inconsistency in network meta-analysis: concepts and models for multi-arm studies. Research Synthesis Methods, 3, 98–110
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct network meta-analysis with placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013.5, sm = "MD", reference = "plac") # Generate a net heat plot based on a common effects model # netheat(net1) ## Not run: # Generate a net heat plot based on a random effects model # netheat(net1, random = TRUE) ## End(Not run)
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct network meta-analysis with placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013.5, sm = "MD", reference = "plac") # Generate a net heat plot based on a common effects model # netheat(net1) ## Not run: # Generate a net heat plot based on a random effects model # netheat(net1, random = TRUE) ## End(Not run)
This function measures the importance of individual studies in network meta-analysis by the reduction of the precision if the study is removed / ignored from the network (Rücker et al., 2020).
netimpact( x, seTE.ignore = 100 * max(x$seTE, na.rm = TRUE), event.ignore = 0.01, nchar.trts = x$nchar.trts, nchar.studlab = x$nchar.studlab, verbose = FALSE )
netimpact( x, seTE.ignore = 100 * max(x$seTE, na.rm = TRUE), event.ignore = 0.01, nchar.trts = x$nchar.trts, nchar.studlab = x$nchar.studlab, verbose = FALSE )
x |
An object of class |
seTE.ignore |
Assumed (large) standard error in order to
mimicking the removal of individual studies from the network
meta-analysis (ignored for |
event.ignore |
Assumed event number mimicking the removal of
individual studies from the network meta-analysis (considered for
|
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names (see Details). |
nchar.studlab |
A numeric defining the minimum number of characters used to create unique study labels. |
verbose |
A logical indicating whether information on the estimation progress should be printed. |
An object of class "netimpact"
with corresponding
netgraph
and print
function. The object is a list
containing the following components:
impact.common |
A matrix with contributions of individual studies (columns) to comparisons (rows) under the common effects model. |
impact.random |
A matrix with contributions of individual studies (columns) to comparisons (rows) under the random effects model. |
ignored.comparisons |
List with comparisons of ignored study. |
seTE.ignore , event.ignore , x
|
As defined above. |
nets |
List of all network meta-analyses (removing a single study). |
version |
Version of R package netmeta used to create object. |
Guido Schwarzer [email protected], Gerta Rücker [email protected]
Rücker G, Nikolakopoulou A, Papakonstantinou T, Salanti G, Riley RD, Schwarzer G (2020): The statistical importance of a study for a network meta-analysis estimate. BMC Medical Research Methodology, 20, 190
netmeta
, netmetabin
,
netgraph.netimpact
, print.netimpact
,
dat.franchini2012
# Only consider first two studies (to reduce runtime of example) # studies <- unique(dat.franchini2012$Study) p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = subset(dat.franchini2012, Study %in% studies[1:2]), studlab = Study) net1 <- netmeta(p1) ni1 <- netimpact(net1, verbose = TRUE) ni1 netgraph(ni1)
# Only consider first two studies (to reduce runtime of example) # studies <- unique(dat.franchini2012$Study) p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = subset(dat.franchini2012, Study %in% studies[1:2]), studlab = Study) net1 <- netmeta(p1) ni1 <- netimpact(net1, verbose = TRUE) ni1 netgraph(ni1)
A league table is a square matrix showing all pairwise comparisons in a network meta-analysis. Typically, both treatment estimates and confidence intervals are shown.
netleague( x, y, common = x$common, random = x$random, seq = x$seq, ci = TRUE, backtransf = x$backtransf, direct, digits = gs("digits"), big.mark = gs("big.mark"), text.NA = ".", bracket = gs("CIbracket"), separator = gs("CIseparator"), lower.blank = gs("CIlower.blank"), upper.blank = gs("CIupper.blank"), writexl = !missing(path), path = "leaguetable.xlsx", overwrite = FALSE, details = gs("details"), warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netleague' print( x, common = x$x$common, random = x$x$random, warn.deprecated = gs("warn.deprecated"), ... )
netleague( x, y, common = x$common, random = x$random, seq = x$seq, ci = TRUE, backtransf = x$backtransf, direct, digits = gs("digits"), big.mark = gs("big.mark"), text.NA = ".", bracket = gs("CIbracket"), separator = gs("CIseparator"), lower.blank = gs("CIlower.blank"), upper.blank = gs("CIupper.blank"), writexl = !missing(path), path = "leaguetable.xlsx", overwrite = FALSE, details = gs("details"), warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netleague' print( x, common = x$x$common, random = x$x$random, warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of created with |
y |
An object of class |
common |
A logical indicating whether a league table should be printed for the common effects network meta-analysis. |
random |
A logical indicating whether a league table should be printed for the random effects network meta-analysis. |
seq |
A character or numerical vector specifying the sequence of treatments in rows and columns of a league table. |
ci |
A logical indicating whether confidence intervals should be shown. |
backtransf |
A logical indicating whether printed results
should be back transformed. If |
direct |
A logical indicating whether league tables with
network estimates or estimates from direct comparisons
should be shown if (i) argument |
digits |
Minimal number of significant digits, see
|
big.mark |
A character used as thousands separator. |
text.NA |
A character string to label missing values. |
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. |
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. |
details |
A logical specifying whether details on rows and columns should be printed. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (passed on to |
A league table is a square matrix showing all pairwise comparisons in a network meta-analysis (Hutton et al., 2015). Typically, both treatment estimates and confidence intervals are shown.
If argument y
is not provided, the league table contains
the network estimates in the lower triangle and the direct treatment
estimates from pairwise comparisons in the upper triangle, if the input
for argument x
was created with netmeta
;
the network estimates from the component network meta-analysis in the
lower triangle, if the input for argument x
was created with
netcomb
, and, in the upper triangle, (i) the network estimates from
the network meta-analysis, if argument direct = FALSE
, or
(ii)) the direct treatment estimates from pairwise comparisons, if
argument direct = TRUE
;
the network estimates from the component network meta-analysis in the
lower and upper triangle, if the input for argument x
was created
with discomb
.
Note, for the random-effects model, the direct treatment estimates are based
on the common between-study variance from the network
meta-analysis, i.e. the square of list element
x$tau
.
If argument y
is provided, the league table contains
information on treatment comparisons from (component) network meta-analysis
object x
in the lower triangle and from (component) network
meta-analysis object y
in the upper triangle. This is, for
example, useful to print information on efficacy and safety in the
same league table. If argument direct = TRUE
, direct estimates are
shown both in the lower and upper triangle if the input for arguments
x
and y
was created with netmeta
.
By default, an R object with the league tables is generated. Alternatively,
an Excel file is created if argument writexl = TRUE
.
This implementation reports pairwise comparisons of the treatment in the column versus the treatment in the row in the lower triangle and row versus column in the upper triangle. This is a common presentation for network meta-analyses which allows to easily compare direction and magnitude of treatment effects. For example, given treatments A, B, and C, the results reported in the first row and second column as well as second row and first column are from the pairwise comparison A versus B. Note, this presentation is different from the printout of a network meta-analysis object which reports opposite pairwise comparisons in the lower and upper triangle, e.g., A versus B in the first row and second column and B versus A in the second row and first column.
If the same (component) network meta-analysis object is used for arguments
x
and y
, reciprocal treatment estimates will be shown
in the upper triangle (see examples), e.g., the comparison B versus
A.
R function netrank
can be used to change the order of
rows and columns in the league table (see examples).
An object of class netleague
with corresponding print
function if writexl = FALSE
. The object is a list containing
the league tables in list elements 'common' and 'random'. An Excel
file is created if writexl = TRUE
. In this case, NULL
is returned in R.
Guido Schwarzer [email protected], Gerta Rücker [email protected]
Hutton B, Salanti G, Caldwell DM, et al. (2015): The PRISMA Extension Statement for Reporting of Systematic Reviews Incorporating Network Meta-analyses of Health Care Interventions: Checklist and Explanations. Annals of Internal Medicine, 162, 777
netmeta
, netcomb
,
discomb
, netposet
, netrank
,
dat.woods2010
,
dat.linde2015
# Network meta-analysis of count mortality statistics # p0 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net0 <- netmeta(p0) oldopts <- options(width = 100) # League table for common and random effects model with # - network estimates in lower triangle # - direct estimates in upper triangle # netleague(net0, digits = 2, bracket = "(", separator = " - ") # League table for common effects model # netleague(net0, random = FALSE, digits = 2) # Change order of treatments according to treatment ranking (random # effects model) # netleague(net0, common = FALSE, digits = 2, seq = netrank(net0)) # print(netrank(net0), common = FALSE) ## Not run: # Create a CSV file with league table for random effects model # league0 <- netleague(net0, digits = 2, bracket = "(", separator = " to ") # write.table(league0$random, file = "league0-random.csv", row.names = FALSE, col.names = FALSE, sep = ",") # # Create Excel files with league tables # (if R package writexl is available) # netleague(net0, digits = 2, bracket = "(", separator = " to ", path = tempfile(fileext = ".xlsx")) ## End(Not run) # Define order of treatments in depression dataset dat.linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo", small = "undesirable") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo", small = "undesirable") options(width = 200) netleague(net1, digits = 2) netleague(net1, digits = 2, ci = FALSE) netleague(net2, digits = 2, ci = FALSE) # League table for two outcomes with # - network estimates of first outcome in lower triangle # - network estimates of second outcome in upper triangle # netleague(net1, net2, digits = 2, ci = FALSE) netleague(net1, net2, seq = netrank(net1), ci = FALSE) netleague(net1, net2, seq = netrank(net2), ci = FALSE) netrank(net1) netrank(net2) # Report results for network meta-analysis twice # netleague(net1, net1, seq = netrank(net1), ci = FALSE, backtransf = FALSE) netleague(net1, net1, seq = netrank(net1), ci = FALSE, backtransf = FALSE, direct = TRUE) options(oldopts) ## Not run: # Generate a partial order of treatment rankings # np <- netposet(net1, net2, outcomes = outcomes) # Requires R package 'hasse' # hasse(np) plot(np) ## End(Not run)
# Network meta-analysis of count mortality statistics # p0 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net0 <- netmeta(p0) oldopts <- options(width = 100) # League table for common and random effects model with # - network estimates in lower triangle # - direct estimates in upper triangle # netleague(net0, digits = 2, bracket = "(", separator = " - ") # League table for common effects model # netleague(net0, random = FALSE, digits = 2) # Change order of treatments according to treatment ranking (random # effects model) # netleague(net0, common = FALSE, digits = 2, seq = netrank(net0)) # print(netrank(net0), common = FALSE) ## Not run: # Create a CSV file with league table for random effects model # league0 <- netleague(net0, digits = 2, bracket = "(", separator = " to ") # write.table(league0$random, file = "league0-random.csv", row.names = FALSE, col.names = FALSE, sep = ",") # # Create Excel files with league tables # (if R package writexl is available) # netleague(net0, digits = 2, bracket = "(", separator = " to ", path = tempfile(fileext = ".xlsx")) ## End(Not run) # Define order of treatments in depression dataset dat.linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo", small = "undesirable") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo", small = "undesirable") options(width = 200) netleague(net1, digits = 2) netleague(net1, digits = 2, ci = FALSE) netleague(net2, digits = 2, ci = FALSE) # League table for two outcomes with # - network estimates of first outcome in lower triangle # - network estimates of second outcome in upper triangle # netleague(net1, net2, digits = 2, ci = FALSE) netleague(net1, net2, seq = netrank(net1), ci = FALSE) netleague(net1, net2, seq = netrank(net2), ci = FALSE) netrank(net1) netrank(net2) # Report results for network meta-analysis twice # netleague(net1, net1, seq = netrank(net1), ci = FALSE, backtransf = FALSE) netleague(net1, net1, seq = netrank(net1), ci = FALSE, backtransf = FALSE, direct = TRUE) options(oldopts) ## Not run: # Generate a partial order of treatment rankings # np <- netposet(net1, net2, outcomes = outcomes) # Requires R package 'hasse' # hasse(np) plot(np) ## End(Not run)
Auxiliary function to create a matrix with additional information for pairwise comparisons
netmatrix( x, var, levels, labels = levels, func = "mode", ties.method = "random" )
netmatrix( x, var, levels, labels = levels, func = "mode", ties.method = "random" )
x |
A |
var |
Variable with additional information. |
levels |
An optional vector of the values that |
labels |
An optional vector with labels for |
func |
A character string with the function name to summarize values within pairwise comparisons; see Details. |
ties.method |
A character string describing how ties are
handled if |
For each pairwise comparison, unique values will be calculated for
the variable var
based on the argument func
: "mode"
(most common value), "min" (minimum value), "max", "mean",
"median", and "sum". In order to determine the most common value,
the argument ties.method
can be used in the case of ties
with "first" meaning that the first / smallest value will be
selected; similar for "last" (last / largest value) and "random"
(random selection).
A matrix with the same row and column names as the adjacency matrix
x$A.matrix
.
Guido Schwarzer [email protected]
data(smokingcessation) # Add variable with (fictious) risk of bias values # with 1 = "low risk" and 2 = "high risk" # smokingcessation$rob <- rep(1:2, 12) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1, common = FALSE, ref = "A") # Generate network graph with information on risk of bias # col.rob <- netmatrix(net1, rob, ties.method = "last", levels = 1:2, labels = c("green", "yellow")) # netgraph(net1, plastic = FALSE, col = col.rob, cex.points = 5, bg.points = "gray", adj = 0.5) netgraph(net1, plastic = FALSE, col = col.rob, cex.points = n.trts, bg.points = "blue", labels = paste0(trts, " (n=", n.trts, ")"), offset = c(0.05, 0.035, 0.05, 0.025))
data(smokingcessation) # Add variable with (fictious) risk of bias values # with 1 = "low risk" and 2 = "high risk" # smokingcessation$rob <- rep(1:2, 12) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1, common = FALSE, ref = "A") # Generate network graph with information on risk of bias # col.rob <- netmatrix(net1, rob, ties.method = "last", levels = 1:2, labels = c("green", "yellow")) # netgraph(net1, plastic = FALSE, col = col.rob, cex.points = 5, bg.points = "gray", adj = 0.5) netgraph(net1, plastic = FALSE, col = col.rob, cex.points = n.trts, bg.points = "blue", labels = paste0(trts, " (n=", n.trts, ")"), offset = c(0.05, 0.035, 0.05, 0.025))
This function provides measures for quantifying the direct evidence proportion, the mean path length and the minimal parallelism (the latter on aggregated and study level) of mixed treatment comparisons (network estimates) as well as the evidence flow per design, see König et al. (2013). These measures support the critical evaluation of the network meta-analysis results by rendering transparent the process of data pooling.
netmeasures( x, random = x$random | !missing(tau.preset), tau.preset = x$tau.preset, warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), ... )
netmeasures( x, random = x$random | !missing(tau.preset), tau.preset = x$tau.preset, warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
random |
A logical indicating whether random effects model should be used to calculate network measures. |
tau.preset |
An optional value for the square-root of the
between-study variance |
warn |
A logical indicating whether warnings should be printed. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
The direct evidence proportion gives the absolute contribution of direct effect estimates combined for two-arm and multi-arm studies to one network estimate.
Concerning indirectness, comparisons with a mean path length beyond two should be interpreted with particular caution, as more than two direct comparisons have to be combined serially on average.
Large indices of parallelism, either on study-level or on aggregated level, can be considered as supporting the validity of a network meta-analysis if there is only a small amount of heterogeneity.
The network estimates for two treatments are linear combinations of
direct effect estimates comparing these or other treatments. The
linear coefficients can be seen as the generalization of weights
known from classical meta-analysis. These coefficients are given in
the projection matrix of the underlying model. For
multi-arm studies, the coefficients depend on the choice of the
study-specific baseline treatment, but the absolute flow of
evidence can be made explicit for each design as shown in König et
al. (2013) and is given in
H.tilde
.
All measures are calculated based on the common effects
meta-analysis by default. In the case that in function
netmeta
the argument random = TRUE
, all measures
are calculated for a random effects model. The value of the
square-root of the between-study variance can also be
prespecified by argument
tau.preset
in function
netmeta
.
A list containing the following components:
random , tau.preset
|
As defined above. |
proportion |
A named vector of the direct evidence proportion of each network estimate. |
meanpath |
A named vector of the mean path length of each network estimate. |
minpar |
A named vector of the minimal parallelism on aggregated level of each network estimate. |
minpar.study |
A named vector of the minimal parallelism on study level of each network estimate. |
H.tilde |
Design-based hat matrix with information on absolute evidence flow per design. The number of rows is equal to the number of possible pairwise treatment comparisons and the number of columns is equal to the number of designs. |
Ulrike Krahn [email protected], Jochem König [email protected]
König J, Krahn U, Binder H (2013): Visualizing the flow of evidence in network meta-analysis and characterizing mixed treatment comparisons. Statistics in Medicine, 32, 5414–29
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct network meta-analysis # net1 <- netmeta(p1) # Calculate measures based on a common effects model # nm1 <- netmeasures(net1) # Plot of minimal parallelism versus mean path length # plot(nm1$meanpath, nm1$minpar, type = "n", xlab = "Mean path length", ylab = "Minimal parallelism") text(nm1$meanpath, nm1$minpar, names(nm1$meanpath), cex = 0.8) ## Not run: data(Senn2013) # Conduct common effects network meta-analysis with reference # treatment 'plac', i.e. placebo # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac", random = FALSE) # Calculate measures based on a common effects model # nm2 <- netmeasures(net2) # Plot of minimal parallelism versus mean path length # plot(nm2$meanpath, nm2$minpar, type = "n", xlab = "Mean path length", ylab = "Minimal parallelism") text(nm2$meanpath, nm2$minpar, names(nm2$meanpath), cex = 0.8) # Conduct random effects network meta-analysis with reference # treatment 'plac', i.e. placebo # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac", common = FALSE) # Calculate measures based on a random effects model # nm3 <- netmeasures(net3) ## End(Not run)
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct network meta-analysis # net1 <- netmeta(p1) # Calculate measures based on a common effects model # nm1 <- netmeasures(net1) # Plot of minimal parallelism versus mean path length # plot(nm1$meanpath, nm1$minpar, type = "n", xlab = "Mean path length", ylab = "Minimal parallelism") text(nm1$meanpath, nm1$minpar, names(nm1$meanpath), cex = 0.8) ## Not run: data(Senn2013) # Conduct common effects network meta-analysis with reference # treatment 'plac', i.e. placebo # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac", random = FALSE) # Calculate measures based on a common effects model # nm2 <- netmeasures(net2) # Plot of minimal parallelism versus mean path length # plot(nm2$meanpath, nm2$minpar, type = "n", xlab = "Mean path length", ylab = "Minimal parallelism") text(nm2$meanpath, nm2$minpar, names(nm2$meanpath), cex = 0.8) # Conduct random effects network meta-analysis with reference # treatment 'plac', i.e. placebo # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", reference = "plac", common = FALSE) # Calculate measures based on a random effects model # nm3 <- netmeasures(net3) ## End(Not run)
Network meta-analysis is a generalisation of pairwise meta-analysis that compares all pairs of treatments within a number of treatments for the same condition. The graph-theoretical approach for network meta-analysis uses methods that were originally developed in electrical network theory. It has been found to be equivalent to the frequentist approach to network meta-analysis which is based on weighted least squares regression (Rücker, 2012).
Print method for objects of class netmeta
.
netmeta( TE, seTE, treat1, treat2, studlab, data = NULL, subset = NULL, correlated, sm, level = gs("level"), level.ma = gs("level.ma"), common = gs("common"), random = gs("random") | !is.null(tau.preset), prediction = gs("prediction"), level.predict = gs("level.predict"), reference.group, baseline.reference = gs("baseline.reference"), small.values = gs("small.values"), all.treatments = gs("all.treatments"), seq = gs("seq"), method.tau = gs("method.tau.netmeta"), tau.preset = NULL, tol.multiarm = gs("tol.multiarm"), tol.multiarm.se = gs("tol.multiarm.se"), details.chkmultiarm = gs("details.chkmultiarm"), sep.trts = gs("sep.trts"), nchar.trts = gs("nchar.trts"), nchar.studlab = gs("nchar.studlab"), func.inverse = invmat, n1 = NULL, n2 = NULL, event1 = NULL, event2 = NULL, incr = NULL, mean1 = NULL, mean2 = NULL, sd1 = NULL, sd2 = NULL, time1 = NULL, time2 = NULL, overall.hetstat = gs("overall.hetstat"), backtransf = gs("backtransf"), title = gs("title"), keepdata = gs("keepdata"), keeprma = gs("keeprma"), control = NULL, warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), nchar = nchar.trts, ... ) ## S3 method for class 'netmeta' print( x, common = x$common, random = x$random, prediction = x$prediction, reference.group = x$reference.group, baseline.reference = x$baseline.reference, all.treatments = x$all.treatments, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, nchar.trts = x$nchar.trts, header = TRUE, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval"), 2), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), 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.tau = gs("print.tau"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), text.I2 = gs("text.I2"), details.methods = gs("details"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
netmeta( TE, seTE, treat1, treat2, studlab, data = NULL, subset = NULL, correlated, sm, level = gs("level"), level.ma = gs("level.ma"), common = gs("common"), random = gs("random") | !is.null(tau.preset), prediction = gs("prediction"), level.predict = gs("level.predict"), reference.group, baseline.reference = gs("baseline.reference"), small.values = gs("small.values"), all.treatments = gs("all.treatments"), seq = gs("seq"), method.tau = gs("method.tau.netmeta"), tau.preset = NULL, tol.multiarm = gs("tol.multiarm"), tol.multiarm.se = gs("tol.multiarm.se"), details.chkmultiarm = gs("details.chkmultiarm"), sep.trts = gs("sep.trts"), nchar.trts = gs("nchar.trts"), nchar.studlab = gs("nchar.studlab"), func.inverse = invmat, n1 = NULL, n2 = NULL, event1 = NULL, event2 = NULL, incr = NULL, mean1 = NULL, mean2 = NULL, sd1 = NULL, sd2 = NULL, time1 = NULL, time2 = NULL, overall.hetstat = gs("overall.hetstat"), backtransf = gs("backtransf"), title = gs("title"), keepdata = gs("keepdata"), keeprma = gs("keeprma"), control = NULL, warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), nchar = nchar.trts, ... ) ## S3 method for class 'netmeta' print( x, common = x$common, random = x$random, prediction = x$prediction, reference.group = x$reference.group, baseline.reference = x$baseline.reference, all.treatments = x$all.treatments, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, nchar.trts = x$nchar.trts, header = TRUE, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = max(gs("digits.pval"), 2), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), 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.tau = gs("print.tau"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), text.I2 = gs("text.I2"), details.methods = gs("details"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
TE |
Estimate of treatment effect, i.e. difference between
first and second treatment (e.g. log odds ratio, mean difference,
or log hazard ratio). Or an R object created with
|
seTE |
Standard error of treatment estimate. |
treat1 |
Label/Number for first treatment. |
treat2 |
Label/Number for second treatment. |
studlab |
An optional - but important! - vector with study labels (see Details). |
data |
An optional data frame containing the study information. |
subset |
An optional vector specifying a subset of studies to be used. |
correlated |
An optional logical vector specifying whether treatment arms of a multi-arm study are correlated. |
sm |
A character string indicating underlying summary measure,
e.g., |
level |
The level used to calculate confidence intervals for individual comparisons. |
level.ma |
The level used to calculate confidence intervals for network estimates. |
common |
A logical indicating whether results for the common effects model should be printed. |
random |
A logical indicating whether results for the random effects model should be printed. |
prediction |
A logical indicating whether prediction intervals should be printed. |
level.predict |
The level used to calculate prediction intervals for a new study. |
reference.group |
Reference treatment. |
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment (default) or vice versa. This argument is
only considered if |
small.values |
A character string specifying whether small
treatment effects indicate a beneficial ( |
all.treatments |
A logical or |
seq |
A character or numerical vector specifying the sequence of treatments in printouts. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
tau.preset |
An optional value for manually setting the
square-root of the between-study variance |
tol.multiarm |
A numeric for the tolerance for consistency of treatment estimates in multi-arm studies which are consistent by design. |
tol.multiarm.se |
A numeric for the tolerance for consistency
of standard errors in multi-arm studies which are consistent by
design. This check is not conducted if the argument is
|
details.chkmultiarm |
A logical indicating whether treatment estimates and / or variances of multi-arm studies with inconsistent results or negative multi-arm variances should be printed. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
nchar.studlab |
A numeric defining the minimum number of characters used to create unique study labels. |
func.inverse |
R function used to calculate the pseudoinverse of the Laplacian matrix L (see Details). |
n1 |
Number of observations in first treatment group. |
n2 |
Number of observations in second treatment group. |
event1 |
Number of events in first treatment group. |
event2 |
Number of events in second treatment group. |
incr |
Numerical value added to cell frequencies (for details,
see |
mean1 |
Mean in first treatment group. |
mean2 |
Mean in second treatment group. |
sd1 |
Standard deviation in first treatment group. |
sd2 |
Standard deviation in second treatment group. |
time1 |
Person time at risk in first treatment group. |
time2 |
Person time at risk in second treatment group. |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and forest plots. If
|
title |
Title of meta-analysis / systematic review. |
keepdata |
A logical indicating whether original data(set) should be kept in netmeta object. |
keeprma |
A logical indicating whether |
control |
An optional list to control the iterative process to
estimate the between-study variance |
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. |
nchar |
Deprecated argument (replaced by |
... |
Additional arguments. |
x |
An object of class |
header |
A logical indicating whether information on title of meta-analysis, comparison and outcome should be printed at the beginning of the printout. |
digits |
Minimal number of significant digits, see
|
digits.stat |
Minimal number of significant digits for tests
of overall effect, see |
digits.pval |
Minimal number of significant digits for p-value
of overall effects, see |
digits.pval.Q |
Minimal number of significant digits for
p-value of heterogeneity tests, see |
digits.Q |
Minimal number of significant digits for
heterogeneity statistics, 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 |
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.tau |
A logical specifying whether |
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 |
text.tau2 |
Text printed to identify between-study variance
|
text.tau |
Text printed to identify |
text.I2 |
Text printed to identify heterogeneity statistic
I |
details.methods |
A logical specifying whether details on statistical methods should be printed. |
legend |
A logical indicating whether a legend should be printed. |
Network meta-analysis using R package netmeta is described in detail in Schwarzer et al. (2015), Chapter 8.
Let n be the number of different treatments (nodes, vertices) in a network and let m be the number of existing comparisons (edges) between the treatments. If there are only two-arm studies, m is the number of studies. Let TE and seTE be the vectors of observed effects and their standard errors. Let W be the mxm diagonal matrix that contains the inverse variance 1 / seTE^2.
The given comparisons define the network structure. Therefrom an mxn design matrix X (edge-vertex incidence matrix) is formed; for more precise information, see Rücker (2012). Moreover, the nxn Laplacian matrix L and its Moore-Penrose pseudoinverse L+ are calculated (both matrices play an important role in graph theory and electrical network theory). Using these matrices, the variances based on both direct and indirect comparisons can be estimated. Moreover, the hat matrix H can be estimated by H = XL+X^tW = X(X^t W X)^+X^tW and finally consistent treatment effects can be estimated by applying the hat matrix to the observed (potentially inconsistent) effects. H is a projection matrix which maps the observed effects onto the consistent (n-1)-dimensional subspace. This is the Aitken estimator (Senn et al., 2013). As in pairwise meta-analysis, the Q statistic measures the deviation from consistency. Q can be separated into parts for each pairwise meta-analysis and a part for remaining inconsistency between comparisons.
Often multi-arm studies are included in a network meta-analysis. In multi-arm studies, the treatment effects on different comparisons are not independent, but correlated. This is accounted for by reweighting all comparisons of each multi-arm study. The method is described in Rücker (2012) and Rücker and Schwarzer (2014).
Comparisons belonging to multi-arm studies are identified by
identical study labels (argument studlab
). It is therefore
important to use identical study labels for all comparisons
belonging to the same multi-arm study, e.g., study label
"Willms1999" for the three-arm study in the data example (Senn et
al., 2013). The function netmeta then automatically accounts for
within-study correlation by reweighting all comparisons of each
multi-arm study.
Data entry for this function is in contrast-based format,
that is, data are given as contrasts (differences) between two
treatments (argument TE
) with standard error (argument
seTE
). In principle, meta-analysis functions from R package
meta, e.g. metabin
for binary outcomes or
metacont
for continuous outcomes, can be used to
calculate treatment effects separately for each treatment
comparison which is a rather tedious enterprise. If data are
provided in arm-based format, that is, data are given for
each treatment arm separately (e.g. number of events and
participants for binary outcomes), a much more convenient way to
transform data into contrast-based form is available. Function
pairwise
can automatically 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). Additional
arguments of these functions can be provided (see help page of
function pairwise
).
Note, all pairwise comparisons must be provided for a multi-arm
study. Consider a multi-arm study of p treatments with known
variances. For this study, treatment effects and standard errors
must be provided for each of p(p - 1) / 2 possible
comparisons. For instance, a three-arm study contributes three
pairwise comparisons, a four-arm study even six pairwise
comparisons. Function pairwise
automatically
calculates all pairwise comparisons for multi-arm studies.
A simple random effects model assuming that a constant
heterogeneity variance is added to each comparison of the network
can be defined via a generalised methods of moments estimate of the
between-studies variance (Jackson et al., 2012). This
is added to the observed sampling variance
seTE^2
of each
comparison in the network (before appropriate adjustment for
multi-arm studies). Then, as in standard pairwise meta-analysis,
the procedure is repeated with the resulting enlarged standard
errors.
For the random-effects model, the direct treatment estimates are
based on the common between-study variance from the
network meta-analysis.
Internally, both common and random effects models are calculated
regardless of values choosen for arguments common
and
random
. Accordingly, the network estimates for the random
effects model can be extracted from component TE.random
of
an object of class "netmeta"
even if argument random =
FALSE
. However, all functions in R package netmeta will
adequately consider the values for common
and
random
. E.g. function print.summary.netmeta
will not print results for the random effects model if random
= FALSE
.
By default, treatment names are not abbreviated in
printouts. However, in order to get more concise printouts,
argument nchar.trts
can be used to define the minimum number
of characters for abbreviated treatment names (see
abbreviate
, argument minlength
). R function
treats
is utilised internally to create abbreviated
treatment names.
Names of treatment comparisons are created by concatenating
treatment labels of pairwise comparisons using sep.trts
as
separator (see paste
). These comparison names are
used in the covariance matrices Cov.common
and
Cov.random
and in some R functions, e.g,
decomp.design
. By default, a colon is used as the
separator. If any treatment label contains a colon the following
characters are used as separator (in consecutive order):
"-"
, "_"
, "/"
, "+"
, "."
,
"|"
, and "*"
. If all of these characters are used in
treatment labels, a corresponding error message is printed asking
the user to specify a different separator.
An object of class netmeta
with corresponding print
,
summary
, forest
, and netrank
functions. The
object is a list containing the following components:
studlab , treat1 , treat2 , TE , seTE
|
As defined above. |
seTE.adj.common , seTE.adj.random
|
Standard error of treatment estimate, adjusted for multi-arm studies. |
design |
Design of study providing pairwise comparison. |
n1 , n2 , event1 , event2 , incr
|
As defined above. |
mean1 , mean2 , sd1 , sd2 , time1 , time2
|
As defined above. |
sd1 , sd2 , time1 , time2
|
As defined above. |
k |
Total number of studies. |
m |
Total number of pairwise comparisons. |
n |
Total number of treatments. |
d |
Total number of designs (corresponding to the unique set of treatments compared within studies). |
trts |
Treatments included in network meta-analysis. |
k.trts |
Number of studies evaluating a treatment. |
n.trts |
Number of observations receiving a treatment (if
arguments |
events.trts |
Number of events observed for a treatment (if
arguments |
multiarm |
Logical vector to identify pairwise comparisons from multi-arm studies. |
n.arms |
Number of treatment arms in study providing pairwise comparison. |
studies |
Vector with unique study labels. |
narms |
Number of arms for each study. |
designs |
Vector with unique designs present in the network. A design corresponds to the set of treatments compared within a study. |
comparisons |
Vector with unique direct comparisons present in the network. |
TE.nma.common , TE.nma.random
|
A vector of length m of consistent treatment effects estimated by network meta-analysis (nma) (common / random effects model). |
seTE.nma.common , seTE.nma.random
|
A vector of length m of effective standard errors estimated by network meta-analysis (common / random effects model). |
lower.nma.common , lower.nma.random
|
A vector of length m of lower confidence interval limits for consistent treatment effects estimated by network meta-analysis (common effects / random effects model). |
upper.nma.common , upper.nma.random
|
A vector of length m of upper confidence interval limits for the consistent treatment effects estimated by network meta-analysis (common effects / random effects model). |
statistic.nma.common , statistic.nma.random
|
A vector of length m of z-values for test of treatment effect for individual comparisons (common / random effects model). |
pval.nma.common , pval.nma.random
|
A vector of length m of p-values for test of treatment effect for individual comparisons (common / random effects model). |
leverage.common |
A vector of length m of leverages, interpretable as factors by which variances are reduced using information from the whole network. |
w.common , w.random
|
A vector of length m of weights of individual studies (common / random effects model). |
Q.common |
A vector of length m of contributions to total heterogeneity / inconsistency statistic. |
TE.common , TE.random
|
nxn matrix with estimated overall treatment effects (common / random effects model). |
seTE.common , seTE.random
|
nxn matrix with standard errors (common / random effects model). |
lower.common , upper.common , lower.random , upper.random
|
nxn matrices with lower and upper confidence interval limits (common / random effects model). |
statistic.common , pval.common , statistic.random , pval.random
|
nxn matrices with z-value and p-value for test of overall treatment effect (common / random effects model). |
seTE.predict |
nxn matrix with standard errors for prediction intervals. |
lower.predict , upper.predict
|
nxn matrices with lower and upper prediction interval limits. |
prop.direct.common , prop.direct.random
|
A named vector of the direct evidence proportion of each network estimate. (common effects / random effects model). |
TE.direct.common , TE.direct.random
|
nxn matrix with estimated treatment effects from direct evidence (common effects / random effects model). |
seTE.direct.common , seTE.direct.random
|
nxn matrix with estimated standard errors from direct evidence (common effects / random effects model). |
lower.direct.common , upper.direct.common , lower.direct.random
|
nxn matrices with lower and upper confidence interval limits from direct evidence (common / random effects model). |
upper.direct.random |
nxn matrices with lower and upper confidence interval limits from direct evidence (common effects / random effects model). |
statistic.direct.common , pval.direct.common , statistic.direct.random
|
nxn matrices with z-value and p-value for test of overall treatment effect from direct evidence (common / random effects model). |
pval.direct.random |
nxn matrices with z-value and p-value for test of overall treatment effect from direct evidence (common / random effects model). |
TE.indirect.common , TE.indirect.random
|
nxn matrix with estimated treatment effects from indirect evidence (common / random effects model). |
seTE.indirect.common , seTE.indirect.random
|
nxn matrix with estimated standard errors from indirect evidence (common / random effects model). |
lower.indirect.common , upper.indirect.common , lower.indirect.random
|
nxn matrices with lower and upper confidence interval limits from indirect evidence (common / random effects model). |
upper.indirect.random |
nxn matrices with lower and upper confidence interval limits from indirect evidence (common / random effects model). |
statistic.indirect.common , pval.indirect.common , statistic.indirect.random
|
nxn matrices with z-value and p-value for test of overall treatment effect from indirect evidence (common / random effects model). |
pval.indirect.random |
nxn matrices with z-value and p-value for test of overall treatment effect from indirect evidence (common / random effects model). |
Q |
Overall heterogeneity / inconsistency statistic. |
df.Q |
Degrees of freedom for test of heterogeneity / inconsistency. |
pval.Q |
P-value for test of heterogeneity / inconsistency. |
I2 , lower.I2 , upper.I2
|
I-squared, lower and upper confidence limits. |
tau |
Square-root of between-study variance. |
Q.heterogeneity |
Overall heterogeneity statistic. |
df.Q.heterogeneity |
Degrees of freedom for test of overall heterogeneity. |
pval.Q.heterogeneity |
P-value for test of overall heterogeneity. |
Q.inconsistency |
Overall inconsistency statistic. |
df.Q.inconsistency |
Degrees of freedom for test of overall inconsistency. |
pval.Q.inconsistency |
P-value for test of overall inconsistency. |
Q.decomp |
Data frame with columns 'treat1', 'treat2', 'Q', 'df' and 'pval.Q', providing heterogeneity statistics for each pairwise meta-analysis of direct comparisons. |
A.matrix |
Adjacency matrix (nxn). |
X.matrix |
Design matrix (mxn). |
B.matrix |
Edge-vertex incidence matrix (mxn). |
L.matrix.common , L.matrix.random
|
Laplacian matrix (nxn). |
Lplus.matrix.common , Lplus.matrix.random
|
Moore-Penrose pseudoinverse of the Laplacian matrix (nxn). |
Q.matrix |
Matrix of heterogeneity statistics for pairwise meta-analyses, where direct comparisons exist (nxn). |
G.matrix |
Matrix with variances and covariances of comparisons (mxm). G is defined as BL+B^t. |
H.matrix.common , H.matrix.random
|
Hat matrix (mxm), defined as H = GW = BL+B^tW. |
n.matrix |
nxn matrix with number of
observations in direct comparisons (if arguments |
events.matrix |
nxn matrix with number of events
in direct comparisons (if arguments |
P.common , P.random
|
nxn matrix with direct evidence proportions (common / random effects model). |
Cov.common |
Variance-covariance matrix (common effects model) |
Cov.random |
Variance-covariance matrix (random effects model) |
sm , level , level.ma
|
As defined above. |
common , random
|
As defined above. |
prediction , level.predict
|
As defined above. |
reference.group , baseline.reference , small.values , all.treatments
|
As defined above. |
seq , tau.preset , tol.multiarm , tol.multiarm.se
|
As defined above. |
details.chkmultiarm , sep.trts , nchar.trts
|
As defined above. |
backtransf , title , warn , warn.deprecated
|
As defined above. |
call |
Function call. |
version |
Version of R package netmeta used to create object. |
In addition, the following component is stored if metafor is
used to calculate the between-study variance and argument
keeprma = TRUE
:
rma.tau |
R object created with |
R function rma.mv
from R package
metafor (Viechtbauer 2010) is called internally to estimate
the between-study variance for the (restricted)
maximum likelihood method. For binary outcomes, incidence rates,
and the mean difference, the variance-covariance matrix is
calculated if arguments
event1
, event2
, n1
,
and n2
(binary outcomes); event1
, event2
,
time1
, and time2
(incidence rates); n1
,
n2
, sd1
, and sd2
(mean difference) are
provided. For datasets preprocessed with pairwise
the respective variables are selected automatically.
Gerta Rücker [email protected], Guido Schwarzer [email protected]
Jackson D, White IR, Riley RD (2012): Quantifying the impact of between-study heterogeneity in multivariate meta-analyses. Statistics in Medicine, 31, 3805–20
Rücker G (2012): Network meta-analysis, electrical networks and graph theory. Research Synthesis Methods, 3, 312–24
Rücker G, Schwarzer G (2014): Reduce dimension or reduce weights? Comparing two approaches to multi-arm studies in network meta-analysis. Statistics in Medicine, 33, 4353–69
Schwarzer G, Carpenter JR, Rücker G (2015): Meta-Analysis with R (Use R!). Springer International Publishing, Switzerland
Senn S, Gavini F, Magrez D, Scheen A (2013): Issues in performing a network meta-analysis. Statistical Methods in Medical Research, 22, 169–89
Viechtbauer W (2010): Conducting Meta-Analyses in R with the metafor Package. Journal of Statistical Software, 36, 1–48
pairwise
, forest.netmeta
,
netrank
, metagen
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) net1 ## Not run: data(Senn2013) # Conduct common effects network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", random = FALSE) net2 net2$Q.decomp # Comparison with reference group # print(net2, reference = "plac") # Conduct random effects network meta-analysis # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", common = FALSE) net3 # Change printing order of treatments with placebo last and use # long treatment names # trts <- c("acar", "benf", "metf", "migl", "piog", "rosi", "sita", "sulf", "vild", "plac") net4 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, sm = "MD", common = FALSE, seq = trts, reference = "Placebo") print(net4, digits = 2) ## End(Not run)
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) net1 ## Not run: data(Senn2013) # Conduct common effects network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", random = FALSE) net2 net2$Q.decomp # Comparison with reference group # print(net2, reference = "plac") # Conduct random effects network meta-analysis # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", common = FALSE) net3 # Change printing order of treatments with placebo last and use # long treatment names # trts <- c("acar", "benf", "metf", "migl", "piog", "rosi", "sita", "sulf", "vild", "plac") net4 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, sm = "MD", common = FALSE, seq = trts, reference = "Placebo") print(net4, digits = 2) ## End(Not run)
Provides four models for the network meta-analysis of binary data (Mantel-Haenszel method, based on the non-central hypergeometric distribution, penalised logistic regression, and the inverse variance method).
netmetabin( event1, n1, event2, n2, treat1, treat2, studlab, data = NULL, subset = NULL, sm, method = "MH", cc.pooled = FALSE, incr, method.incr, allstudies, level = gs("level"), level.ma = gs("level.ma"), common = gs("common"), random = method %in% c("Inverse", "LRP") & (gs("random") | !is.null(tau.preset)), prediction = gs("prediction"), level.predict = gs("level.predict"), reference.group = "", baseline.reference = gs("baseline.reference"), small.values = gs("small.values"), all.treatments = gs("all.treatments"), seq = gs("seq"), tau.preset = NULL, tol.multiarm = 0.001, tol.multiarm.se = NULL, details.chkmultiarm = FALSE, details.chkdata = TRUE, sep.trts = ":", nchar.trts = 666, func.inverse = invmat, overall.hetstat = gs("overall.hetstat"), backtransf = gs("backtransf"), title = gs("title"), keepdata = gs("keepdata"), addincr, allincr, warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), ... )
netmetabin( event1, n1, event2, n2, treat1, treat2, studlab, data = NULL, subset = NULL, sm, method = "MH", cc.pooled = FALSE, incr, method.incr, allstudies, level = gs("level"), level.ma = gs("level.ma"), common = gs("common"), random = method %in% c("Inverse", "LRP") & (gs("random") | !is.null(tau.preset)), prediction = gs("prediction"), level.predict = gs("level.predict"), reference.group = "", baseline.reference = gs("baseline.reference"), small.values = gs("small.values"), all.treatments = gs("all.treatments"), seq = gs("seq"), tau.preset = NULL, tol.multiarm = 0.001, tol.multiarm.se = NULL, details.chkmultiarm = FALSE, details.chkdata = TRUE, sep.trts = ":", nchar.trts = 666, func.inverse = invmat, overall.hetstat = gs("overall.hetstat"), backtransf = gs("backtransf"), title = gs("title"), keepdata = gs("keepdata"), addincr, allincr, warn = gs("warn"), warn.deprecated = gs("warn.deprecated"), ... )
event1 |
Number of events (first treatment). |
n1 |
Number of observations (first treatment). |
event2 |
Number of events (second treatment). |
n2 |
Number of observations (second treatment) |
treat1 |
Label/Number for first treatment. |
treat2 |
Label/Number for second treatment. |
studlab |
An optional - but important! - vector with study labels (see Details). |
data |
An optional data frame containing the study information. |
subset |
An optional vector specifying a subset of studies to be used. |
sm |
A character string indicating underlying summary measure,
i.e., |
method |
A character string indicating which method is to be
used for pooling of studies. One of |
cc.pooled |
A logical indicating whether |
incr |
A numerical value which is added to each cell count, i.e., to the numbers of events and non-events, of all treatment arms in studies with zero events or non-events in any of the treatment arms ("continuity correction"). |
method.incr |
A character string indicating which continuity
correction method should be used ( |
allstudies |
A logical indicating whether studies with zero
events or non-events in all treatment arms should be included in
an inverse variance meta-analysis (applies only if |
level |
The level used to calculate confidence intervals for individual studies. |
level.ma |
The level used to calculate confidence intervals for network estimates. |
common |
A logical indicating whether a common effects network meta-analysis should be conducted. |
random |
A logical indicating whether a random effects network meta-analysis should be conducted. |
prediction |
A logical indicating whether a prediction
interval should be printed (only considered if |
level.predict |
The level used to calculate prediction
interval for a new study (only considered if |
reference.group |
Reference treatment. |
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment (default) or vice versa. This argument is
only considered if |
small.values |
A character string specifying whether small
treatment effects indicate a beneficial ( |
all.treatments |
A logical or |
seq |
A character or numerical vector specifying the sequence of treatments in printouts. |
tau.preset |
An optional value for manually setting the
square-root of the between-study variance |
tol.multiarm |
A numeric for the tolerance for consistency of
treatment estimates in multi-arm studies which are consistent by
design (only considered if |
tol.multiarm.se |
A numeric for the tolerance for consistency
of standard errors in multi-arm studies which are consistent by
design (only considered if the argument is not |
details.chkmultiarm |
A logical indicating whether treatment
estimates and / or variances of multi-arm studies with
inconsistent results or negative multi-arm variances should be
printed (only considered if |
details.chkdata |
A logical indicating whether number of events and participants of studies with inconsistent data should be printed. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names (see Details). |
func.inverse |
R function used to calculate the pseudoinverse
of the Laplacian matrix L (see |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and forest plots. If
|
title |
Title of meta-analysis / systematic review. |
keepdata |
A logical indicating whether original data(set) should be kept in netmeta object. |
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 from meta-analysis due to zero standard errors). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
This function implements four models for the network meta-analysis of binary data:
The Mantel-Haenszel network meta-analysis model, as described
in Efthimiou et al. (2019) (method = "MH"
);
a network meta-analysis model using the non-central
hypergeometric distribution with the Breslow approximation, as
described in Stijnen et al. (2010) (method = "NCH"
);
a logistic regression with penalised likelihood, as described
in Evrenoglou et al. (2022) (method = "LRP"
);
the inverse variance method for network meta-analysis
(method = "Inverse"
), also provided by
netmeta
.
Comparisons belonging to multi-arm studies are identified by
identical study labels (argument studlab
). It is therefore
important to use identical study labels for all comparisons
belonging to the same multi-arm study.
Data entry for this function is in contrast-based format,
that is, each line of the data corresponds to a single pairwise
comparison between two treatments (arguments treat1
,
treat2
, event1
, n1
, event2
, and
n2
). If data are provided in arm-based format, that
is, number of events and participants are given for each treatment
arm separately, function pairwise
can be used to
transform the data to contrast-based format (see help page
of function pairwise
).
Note, all pairwise comparisons must be provided for a multi-arm
study. Consider a multi-arm study of p treatments with known
variances. For this study, the number of events and observations
must be provided for each treatment, for each of p(p
- 1) / 2 possible comparisons in separate lines in the data. For
instance, a three-arm study contributes three pairwise comparisons,
a four-arm study even six pairwise comparisons. Function
pairwise
automatically calculates all pairwise
comparisons for multi-arm studies.
For method = "Inverse"
, both common and random effects
models are calculated regardless of values choosen for arguments
common
and random
. Accordingly, the network estimates
for the random effects model can be extracted from component
TE.random
of an object of class "netmeta"
even if
argument random = FALSE
. However, all functions in R
package netmeta will adequately consider the values for
common
and random
. E.g. function
print.summary.netmeta
will not print results for the
random effects model if random = FALSE
.
For the random-effects model, the direct treatment estimates are
based on the common between-study variance from the
network meta-analysis.
For method = "MH"
and method = "NCH"
, only a common
effects model is available.
By default, treatment names are not abbreviated in
printouts. However, in order to get more concise printouts,
argument nchar.trts
can be used to define the minimum number
of characters for abbreviated treatment names (see
abbreviate
, argument minlength
). R function
treats
is utilised internally to create abbreviated
treatment names.
Names of treatment comparisons are created by concatenating
treatment labels of pairwise comparisons using sep.trts
as
separator (see paste
). These comparison names are
used in the covariance matrices Cov.common
and
Cov.random
and in some R functions, e.g,
decomp.design
. By default, a colon is used as the
separator. If any treatment label contains a colon the following
characters are used as separator (in consecutive order):
"-"
, "_"
, "/"
, "+"
, "."
,
"|"
, and "*"
. If all of these characters are used in
treatment labels, a corresponding error message is printed asking
the user to specify a different separator.
An object of class netmetabin
and netmeta
with
corresponding print
, summary
, forest
, and
netrank
functions. The object is a list containing the
following components:
studlab , treat1 , treat2
|
As defined above. |
n1 , n2 , event1 , event2
|
As defined above. |
TE |
Estimate of treatment effect, i.e. difference between first and second treatment (e.g. log odds ratio). |
seTE |
Standard error of treatment estimate. |
k |
Total number of studies. |
m |
Total number of pairwise comparisons. |
n |
Total number of treatments. |
d |
Total number of designs (corresponding to the unique set of treatments compared within studies). |
trts |
Treatments included in network meta-analysis. |
k.trts |
Number of studies evaluating a treatment. |
n.trts |
Number of observations receiving a treatment. |
events.trts |
Number of events observed for a treatment. |
studies |
Study labels coerced into a factor with its levels sorted alphabetically. |
narms |
Number of arms for each study. |
designs |
Unique list of designs present in the network. A design corresponds to the set of treatments compared within a study. |
TE.common , seTE.common
|
nxn matrix with estimated overall treatment effects and standard errors for common effects model. |
lower.common , upper.common
|
nxn matrices with lower and upper confidence interval limits for common effects model. |
statistic.common , pval.common
|
nxn matrices with z-value and p-value for test of overall treatment effect under common effects model. |
TE.random , seTE.random
|
nxn matrix with
estimated overall treatment effects and standard errors for
random effects model (only available if |
lower.random , upper.random
|
nxn matrices with
lower and upper confidence interval limits for random effects
model (only available if |
statistic.random , pval.random
|
nxn matrices
with z-value and p-value for test of overall treatment effect
under random effects model (only available if |
TE.direct.common , seTE.direct.common
|
nxn matrix with estimated treatment effects and standard errors from direct evidence under common effects model. |
lower.direct.common , upper.direct.common
|
nxn matrices with lower and upper confidence interval limits from direct evidence under common effects model. |
statistic.direct.common , pval.direct.common
|
nxn matrices with z-value and p-value for test of overall treatment effect from direct evidence under common effects model. |
TE.direct.random , seTE.direct.random
|
nxn
matrix with estimated treatment effects and standard errors from
direct evidence under random effects model (only available if
|
lower.direct.random , upper.direct.random
|
nxn
matrices with lower and upper confidence interval limits from
direct evidence under random effects model (only available if
|
statistic.direct.random , pval.direct.random
|
nxn matrices with z-value and
p-value for test of overall treatment effect from direct evidence
under random effects model (only available if |
Q |
Overall heterogeneity / inconsistency statistic. (only
available if |
df.Q |
Degrees of freedom for test of heterogeneity / inconsistency. |
pval.Q |
P-value for test of heterogeneity / inconsistency. |
I2 , lower.I2 , upper.I2
|
I-squared, lower and upper confidence
limits (only available if |
tau |
Square-root of between-study variance (only available if
|
Q.heterogeneity |
Overall heterogeneity statistic. (only
available if |
df.Q.heterogeneity |
Degrees of freedom for test of overall heterogeneity. |
pval.Q.heterogeneity |
P-value for test of overall heterogeneity. |
Q.inconsistency |
Overall inconsistency statistic. |
df.Q.inconsistency |
Degrees of freedom for test of overall inconsistency. |
pval.Q.inconsistency |
P-value for test of overall inconsistency. |
A.matrix |
Adjacency matrix (nxn). |
H.matrix.common |
Hat matrix (mxm) |
n.matrix |
nxn matrix with number of observations in direct comparisons. |
events.matrix |
nxn matrix with number of events in direct comparisons. |
sm , method , level , level.ma
|
As defined above. |
incr , method.incr , allstudies , cc.pooled
|
As defined above. |
addincr , allincr
|
As defined above. |
common , random
|
As defined above. |
prediction , level.predict
|
As defined above. |
reference.group , baseline.reference , small.values , all.treatments
|
As defined above. |
seq , tau.preset , tol.multiarm , tol.multiarm.se
|
As defined above. |
details.chkmultiarm , details.chkdata
|
As defined above. |
sep.trts , nchar.trts , overall.hetstat
|
As defined above. |
backtransf , title , warn , warn.deprecated
|
As defined above. |
data |
Dataset (in contrast-based format). |
data.design |
List with data in arm-based format (each list element corresponds to a single design). |
call |
Function call. |
version |
Version of R package netmeta used to create object. |
Orestis Efthimiou [email protected], Guido Schwarzer [email protected], Theodoros Evrenoglou [email protected]
Efthimiou O, Rücker G, Schwarzer G, Higgins J, Egger M, Salanti G (2019): A Mantel-Haenszel model for network meta-analysis of rare events. Statistics in Medicine, 38, 2992–3012
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.
Senn S, Gavini F, Magrez D, Scheen A (2013): Issues in performing a network meta-analysis. Statistical Methods in Medical Research, 22, 169–89
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
pairwise
, netmeta
,
dat.gurusamy2011
,
dat.dong2013
# Only consider first ten studies (to reduce runtime of example) # first10 <- subset(dat.dong2013, id <= 10) # 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. # p1 <- pairwise(treatment, death, randomized, studlab = id, data = first10, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis (without continuity # correction) # nb1 <- netmetabin(p1, ref = "plac") nb1 # Obtain the league table # netleague(nb1) ## Not run: # Conduct Mantel-Haenszel network meta-analysis for the whole # dataset # p2 <- pairwise(treatment, death, randomized, studlab = id, data = dat.dong2013, sm = "OR") netmetabin(p2, ref = "plac") # Conduct network meta-analysis using the non-central # hypergeometric model (without continuity correction) # netmetabin(p2, ref = "plac", method = "NCH") # Conduct Mantel-Haenszel network meta-analysis (with continuity # correction of 0.5; include all studies) # netmetabin(p2, ref = "plac", cc.pooled = TRUE) p3 <- pairwise(treatment, death, n, studlab = study, data = dat.gurusamy2011, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis (without continuity # correction) # netmetabin(p3, ref = "cont") ## End(Not run)
# Only consider first ten studies (to reduce runtime of example) # first10 <- subset(dat.dong2013, id <= 10) # 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. # p1 <- pairwise(treatment, death, randomized, studlab = id, data = first10, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis (without continuity # correction) # nb1 <- netmetabin(p1, ref = "plac") nb1 # Obtain the league table # netleague(nb1) ## Not run: # Conduct Mantel-Haenszel network meta-analysis for the whole # dataset # p2 <- pairwise(treatment, death, randomized, studlab = id, data = dat.dong2013, sm = "OR") netmetabin(p2, ref = "plac") # Conduct network meta-analysis using the non-central # hypergeometric model (without continuity correction) # netmetabin(p2, ref = "plac", method = "NCH") # Conduct Mantel-Haenszel network meta-analysis (with continuity # correction of 0.5; include all studies) # netmetabin(p2, ref = "plac", cc.pooled = TRUE) p3 <- pairwise(treatment, death, n, studlab = study, data = dat.gurusamy2011, sm = "OR") # Conduct Mantel-Haenszel network meta-analysis (without continuity # correction) # netmetabin(p3, ref = "cont") ## End(Not run)
Conduct pairwise meta-analyses for all comparisons with direct evidence in a network meta-analysis.
netpairwise(x, ...) ## S3 method for class 'netmeta' netpairwise( x, separate = FALSE, common = x$common, random = x$random, level = x$level, level.ma = x$level.ma, prediction = x$prediction, level.predict = x$level.predict, reference.group = if (missing(order)) x$reference.group else "", baseline.reference = x$baseline.reference, method.tau = x$method.tau, order = NULL, sep.trts = x$sep.trts, nchar.trts = x$nchar.trts, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netmetabin' netpairwise( x, separate = FALSE, common = x$common, random = x$random, level = x$level, level.ma = x$level.ma, prediction = x$prediction, level.predict = x$level.predict, reference.group = if (missing(order)) x$reference.group else "", baseline.reference = x$baseline.reference, method = x$method, incr = x$incr, method.incr = x$method.incr, allstudies = x$allstudies, method.tau = x$method.tau, order = NULL, sep.trts = x$sep.trts, nchar.trts = x$nchar.trts, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netpairwise' print(x, ...) ## S3 method for class 'netpairwise' summary(object, ...) ## S3 method for class 'summary.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' forest(x, ...) ## S3 method for class 'netpairwise' plot(x, ...) ## S3 method for class 'netpairwise' funnel(x, k.min = 3, ...) ## S3 method for class 'netpairwise' radial(x, k.min = 3, ...) ## S3 method for class 'netpairwise' baujat(x, k.min = 3, ...) ## S3 method for class 'netpairwise' metabias(x, k.min = 10, ...) ## S3 method for class 'metabias.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' trimfill(x, k.min = 3, ...) ## S3 method for class 'trimfill.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' metainf(x, k.min = 2, ...) ## S3 method for class 'metainf.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' metacum(x, k.min = 2, ...) ## S3 method for class 'metacum.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' metareg(x, ..., k.min = 2) ## S3 method for class 'metareg.netpairwise' print(x, ...)
netpairwise(x, ...) ## S3 method for class 'netmeta' netpairwise( x, separate = FALSE, common = x$common, random = x$random, level = x$level, level.ma = x$level.ma, prediction = x$prediction, level.predict = x$level.predict, reference.group = if (missing(order)) x$reference.group else "", baseline.reference = x$baseline.reference, method.tau = x$method.tau, order = NULL, sep.trts = x$sep.trts, nchar.trts = x$nchar.trts, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netmetabin' netpairwise( x, separate = FALSE, common = x$common, random = x$random, level = x$level, level.ma = x$level.ma, prediction = x$prediction, level.predict = x$level.predict, reference.group = if (missing(order)) x$reference.group else "", baseline.reference = x$baseline.reference, method = x$method, incr = x$incr, method.incr = x$method.incr, allstudies = x$allstudies, method.tau = x$method.tau, order = NULL, sep.trts = x$sep.trts, nchar.trts = x$nchar.trts, backtransf = x$backtransf, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netpairwise' print(x, ...) ## S3 method for class 'netpairwise' summary(object, ...) ## S3 method for class 'summary.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' forest(x, ...) ## S3 method for class 'netpairwise' plot(x, ...) ## S3 method for class 'netpairwise' funnel(x, k.min = 3, ...) ## S3 method for class 'netpairwise' radial(x, k.min = 3, ...) ## S3 method for class 'netpairwise' baujat(x, k.min = 3, ...) ## S3 method for class 'netpairwise' metabias(x, k.min = 10, ...) ## S3 method for class 'metabias.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' trimfill(x, k.min = 3, ...) ## S3 method for class 'trimfill.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' metainf(x, k.min = 2, ...) ## S3 method for class 'metainf.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' metacum(x, k.min = 2, ...) ## S3 method for class 'metacum.netpairwise' print(x, ...) ## S3 method for class 'netpairwise' metareg(x, ..., k.min = 2) ## S3 method for class 'metareg.netpairwise' print(x, ...)
x |
An object of class |
... |
Additional arguments (passed on to |
separate |
A logical indicating whether results for pairwise comparisons should be printed as separate meta-analyses or as subgroups which is more concise. |
common |
A logical indicating whether a common effects network meta-analysis should be conducted. |
random |
A logical indicating whether a random effects network meta-analysis should be conducted. |
level |
The level used to calculate confidence intervals for individual comparisons. |
level.ma |
The level used to calculate confidence intervals for pooled estimates. |
prediction |
A logical indicating whether prediction intervals should be printed. |
level.predict |
The level used to calculate prediction intervals for a new study. |
reference.group |
Reference treatment. |
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment (default) or vice versa. This argument is
only considered if |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
order |
An optional character or numerical vector specifying the order of treatments. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names (see Details). |
backtransf |
A logical indicating whether results should be
back transformed in printouts and forest plots. If
|
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
method |
A character string indicating which method is to be
used for pooling of studies, see |
incr |
A numerical value which is added to cell counts,
see |
method.incr |
A character string indicating which continuity
correction method should be used ( |
allstudies |
A logical indicating whether studies with zero
events or non-events in all treatment arms should be included in
the meta-analysis, see |
object |
An object of class |
k.min |
Minimum number of studies in pairwise comparison to show funnel plot, radial plot or conduct test for funnel plot asymmetry. |
Conduct pairwise meta-analyses for all comparisons with direct
evidence in a network meta-analysis. In contrast to
netmeta
and netsplit
, unadjusted
standard errors are used in the calculations and the between-study
heterogeneity variance is allowed to differ between comparisons.
The R function metagen
is called internally.
Either a single metagen
object with pairwise
comparisons as subgroups or a list with metagen
objects for each direct pairwise comparison.
This function must not be confused with pairwise
which can be used as a pre-processing step to convert data from
arm-based to contrast-based format by calculating all pairwise
comparisons within a study.
Guido Schwarzer [email protected]
oldsets <- settings.meta(digits = 2, digits.tau2 = 2, digits.tau = 2) data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) # Calculate and print concise results for all pairwise # meta-analyses # np1 <- netpairwise(net1) np1 print(np1, details.method = FALSE) ## Not run: data(Senn2013) # Random effects model # net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, sm = "MD", common = FALSE, reference = "plac") # Calculate and print concise results for all pairwise # meta-analyses # np2 <- netpairwise(net2) np2 print(np2, details.method = FALSE) forest(np2) # Print detailed information for each pairwise comparison # np3 <- netpairwise(net2, separate = TRUE) forest(np3) funnel(np3) radial(np3) funnel(np3, k.min = 1) ## End(Not run) settings.meta(oldsets)
oldsets <- settings.meta(digits = 2, digits.tau2 = 2, digits.tau = 2) data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis # net1 <- netmeta(p1, common = FALSE) # Calculate and print concise results for all pairwise # meta-analyses # np1 <- netpairwise(net1) np1 print(np1, details.method = FALSE) ## Not run: data(Senn2013) # Random effects model # net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, sm = "MD", common = FALSE, reference = "plac") # Calculate and print concise results for all pairwise # meta-analyses # np2 <- netpairwise(net2) np2 print(np2, details.method = FALSE) forest(np2) # Print detailed information for each pairwise comparison # np3 <- netpairwise(net2, separate = TRUE) forest(np3) funnel(np3) radial(np3) funnel(np3, k.min = 1) ## End(Not run) settings.meta(oldsets)
Partial order of treatments in network meta-analysis. The set of treatments in a network is called a partially ordered set (in short, a poset), if different outcomes provide different treatment ranking lists.
netposet( ..., outcomes, treatments, small.values, common, random, fixed, comb.fixed, comb.random ) ## S3 method for class 'netposet' print(x, pooled = ifelse(x$random, "random", "common"), ...)
netposet( ..., outcomes, treatments, small.values, common, random, fixed, comb.fixed, comb.random ) ## S3 method for class 'netposet' print(x, pooled = ifelse(x$random, "random", "common"), ...)
... |
See details. |
outcomes |
A character vector with outcome names. |
treatments |
A character vector with treatment names. |
small.values |
See details. |
common |
A logical indicating whether to show results for the common effects model. |
random |
A logical indicating whether to show results for the random effects model. |
fixed |
Ignored deprecated argument (replaced by
|
comb.fixed |
Ignored deprecated argument (replaced by
|
comb.random |
Ignored deprecated argument (replaced by
|
x |
An object of class |
pooled |
A character string indicating whether Hasse diagram
should be drawn for common ( |
In network meta-analysis, frequently different outcomes are considered which may each provide a different ordering of treatments. The concept of a partially ordered set (in short, a poset, Carlsen & Bruggemann, 2014) of treatments can be used to gain further insights in situations with apparently conflicting orderings. This implementation for rankings in network meta-analyis is described in Rücker & Schwarzer (2017).
In function netposet
, argument ...{}
can be any of the
following:
arbitrary number of netrank
objects providing
P-scores;
arbitrary number of netmeta
objects;
single ranking matrix with each column providing P-scores (Rücker & Schwarzer 2015) or SUCRA values (Salanti et al. 2011) for an outcome and rows corresponding to treatments.
Note, albeit in general a ranking matrix is not constrained to have
values between 0 and 1, netposet
stops with an error in this
case as this function expects a matrix with P-scores or SUCRA
values.
Argument outcomes
can be used to label outcomes. If argument
outcomes
is missing,
column names of the ranking matrix are used as outcome labels (if first argument is a ranking matrix and column names are available);
capital letters 'A', 'B', ... are used as outcome labels and a corresponding warning is printed.
Argument treatments
can be used to provide treatment labels
if the first argument is a ranking matrix. If argument
treatment
is missing,
row names of the ranking matrix are used as treatment labels (if available);
letters 'a', 'b', ... are used as treatment labels and a corresponding warning is printed.
If argument ...{}
consists of netmeta
objects,
netrank
is called internally to calculate P-scores. In this
case, argument small.values
can be used to specify for each
outcome whether small values are beneficial ("desirable"
) or
harmfull ("undesirable"
); see netrank
. This
argument is ignored for a ranking matrix and netrank
objects.
Arguments common
and random
can be used to define
whether results should be printed and plotted for common and random
effects model. If netmeta and netrank objects are provided in
argument ...{}
, values for common
and random
within these objects are considered; if these values are not
unique, argument common
or random
are set to
TRUE
.
In function print.netposet
, argument ...{}
is
passed on to the printing function.
An object of class netposet
with corresponding print
,
plot
, and hasse
functions. The object is a list
containing the following components:
P.common |
Ranking matrix with rows corresponding to treatments and columns corresponding to outcomes (common effects model). |
M0.common |
Hasse matrix skipping unnecessary paths (common effects model). |
M.common |
"Full" Hasse matrix (common effects model). |
O.common |
Matrix with information about partial ordering (common effects model). |
P.random |
Ranking matrix with rows corresponding to treatments and columns corresponding to outcomes (random effects model). |
M0.random |
Hasse matrix skipping unnecessary paths (random effects model). |
M.random |
"Full" Hasse matrix (random effects model). |
O.random |
Matrix with information about partial ordering (random effects model). |
small.values , common , random
|
As.defined above. |
call |
Function call. |
version |
Version of R package netmeta used to create object. |
Gerta Rücker [email protected], Guido Schwarzer [email protected]
Carlsen L, Bruggemann R (2014): Partial order methodology: a valuable tool in chemometrics. Journal of Chemometrics, 28, 226–34
Rücker G, Schwarzer G (2015): Ranking treatments in frequentist network meta-analysis works without resampling methods. BMC Medical Research Methodology, 15, 58
Rücker G, Schwarzer G (2017): Resolve conflicting rankings of outcomes in network meta-analysis: Partial ordering of treatments. Research Synthesis Methods, 8, 526–36
Salanti G, Ades AE, Ioannidis JP (2011): Graphical methods and numerical summaries for presenting results from multiple-treatment meta-analysis: an overview and tutorial. Journal of Clinical Epidemiology, 64, 163–71
netmeta
, netrank
,
plot.netrank
, hasse
,
plot.netposet
, dat.linde2015
## Not run: # Define order of treatments in depression dataset linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # Partial order of treatment rankings (two outcomes) # po <- netposet(netrank(net1), netrank(net2), outcomes = outcomes) # Hasse diagram # hasse(po) # # Outcome labels # outcomes <- c("Early response", "Early remission", "Lost to follow-up", "Lost to follow-up due to AEs", "Adverse events (AEs)") # (3) Loss to follow-up # p3 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss1, loss2, loss3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net3 <- netmeta(p3, common = FALSE, seq = trts, ref = "Placebo", small.values = "desirable") # (4) Loss to follow-up due to adverse events # p4 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss.ae1, loss.ae2, loss.ae3), n = list(n1, n2, n3), studlab = id, data = subset(dat.linde2015, id != 55), sm = "OR") # net4 <- netmeta(p4, common = FALSE, seq = trts, ref = "Placebo", small.values = "desirable") # (5) Adverse events # p5 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(ae1, ae2, ae3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net5 <- netmeta(p5, common = FALSE, seq = trts, ref = "Placebo", small.values = "desirable") # Partial order of treatment rankings (all five outcomes) # po.ranks <- netposet(netrank(net1), netrank(net2), netrank(net3), netrank(net4), netrank(net5), outcomes = outcomes) # Same result # po.nets <- netposet(net1, net2, net3, net4, net5, outcomes = outcomes) # all.equal(po.ranks, po.nets) # Print matrix with P-scores (random effects model) # po.nets$P.random # Hasse diagram for all outcomes (random effects model) # hasse(po.ranks) # Hasse diagram for outcomes early response and early remission # po12 <- netposet(netrank(net1), netrank(net2), outcomes = outcomes[1:2]) hasse(po12) # Scatter plot # oldpar <- par(pty = "s") plot(po12) par(oldpar) ## End(Not run) # Example using ranking matrix with P-scores # # Ribassin-Majed L, Marguet S, Lee A.W., et al. (2017): # What is the best treatment of locally advanced nasopharyngeal # carcinoma? An individual patient data network meta-analysis. # Journal of Clinical Oncology, 35, 498-505 # outcomes <- c("OS", "PFS", "LC", "DC") treatments <- c("RT", "IC-RT", "IC-CRT", "CRT", "CRT-AC", "RT-AC", "IC-RT-AC") # # P-scores (from Table 1) # pscore.os <- c(15, 33, 63, 70, 96, 28, 45) / 100 pscore.pfs <- c( 4, 46, 79, 52, 94, 36, 39) / 100 pscore.lc <- c( 9, 27, 47, 37, 82, 58, 90) / 100 pscore.dc <- c(16, 76, 95, 48, 72, 32, 10) / 100 # pscore.matrix <- data.frame(pscore.os, pscore.pfs, pscore.lc, pscore.dc) rownames(pscore.matrix) <- treatments colnames(pscore.matrix) <- outcomes pscore.matrix # po <- netposet(pscore.matrix) po12 <- netposet(pscore.matrix[, 1:2]) po po12 # hasse(po) hasse(po12) # oldpar <- par(pty = "s") plot(po12) par(oldpar)
## Not run: # Define order of treatments in depression dataset linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # Partial order of treatment rankings (two outcomes) # po <- netposet(netrank(net1), netrank(net2), outcomes = outcomes) # Hasse diagram # hasse(po) # # Outcome labels # outcomes <- c("Early response", "Early remission", "Lost to follow-up", "Lost to follow-up due to AEs", "Adverse events (AEs)") # (3) Loss to follow-up # p3 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss1, loss2, loss3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net3 <- netmeta(p3, common = FALSE, seq = trts, ref = "Placebo", small.values = "desirable") # (4) Loss to follow-up due to adverse events # p4 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss.ae1, loss.ae2, loss.ae3), n = list(n1, n2, n3), studlab = id, data = subset(dat.linde2015, id != 55), sm = "OR") # net4 <- netmeta(p4, common = FALSE, seq = trts, ref = "Placebo", small.values = "desirable") # (5) Adverse events # p5 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(ae1, ae2, ae3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net5 <- netmeta(p5, common = FALSE, seq = trts, ref = "Placebo", small.values = "desirable") # Partial order of treatment rankings (all five outcomes) # po.ranks <- netposet(netrank(net1), netrank(net2), netrank(net3), netrank(net4), netrank(net5), outcomes = outcomes) # Same result # po.nets <- netposet(net1, net2, net3, net4, net5, outcomes = outcomes) # all.equal(po.ranks, po.nets) # Print matrix with P-scores (random effects model) # po.nets$P.random # Hasse diagram for all outcomes (random effects model) # hasse(po.ranks) # Hasse diagram for outcomes early response and early remission # po12 <- netposet(netrank(net1), netrank(net2), outcomes = outcomes[1:2]) hasse(po12) # Scatter plot # oldpar <- par(pty = "s") plot(po12) par(oldpar) ## End(Not run) # Example using ranking matrix with P-scores # # Ribassin-Majed L, Marguet S, Lee A.W., et al. (2017): # What is the best treatment of locally advanced nasopharyngeal # carcinoma? An individual patient data network meta-analysis. # Journal of Clinical Oncology, 35, 498-505 # outcomes <- c("OS", "PFS", "LC", "DC") treatments <- c("RT", "IC-RT", "IC-CRT", "CRT", "CRT-AC", "RT-AC", "IC-RT-AC") # # P-scores (from Table 1) # pscore.os <- c(15, 33, 63, 70, 96, 28, 45) / 100 pscore.pfs <- c( 4, 46, 79, 52, 94, 36, 39) / 100 pscore.lc <- c( 9, 27, 47, 37, 82, 58, 90) / 100 pscore.dc <- c(16, 76, 95, 48, 72, 32, 10) / 100 # pscore.matrix <- data.frame(pscore.os, pscore.pfs, pscore.lc, pscore.dc) rownames(pscore.matrix) <- treatments colnames(pscore.matrix) <- outcomes pscore.matrix # po <- netposet(pscore.matrix) po12 <- netposet(pscore.matrix[, 1:2]) po po12 # hasse(po) hasse(po12) # oldpar <- par(pty = "s") plot(po12) par(oldpar)
Ranking treatments in frequentist network meta-analysis with and without resampling methods.
netrank( x, small.values = x$small.values, method, nsim, common = x$common, random = x$random, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netrank' print( x, common = x$common, random = x$random, sort = TRUE, digits = gs("digits.prop"), warn.deprecated = gs("warn.deprecated"), ... )
netrank( x, small.values = x$small.values, method, nsim, common = x$common, random = x$random, warn.deprecated = gs("warn.deprecated"), ... ) ## S3 method for class 'netrank' print( x, common = x$common, random = x$random, sort = TRUE, digits = gs("digits.prop"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
small.values |
A character string specifying whether small
treatment effects indicate a beneficial ( |
method |
A character string specifying whether the
|
nsim |
Number of simulations to calculate SUCRAs. |
common |
A logical indicating whether to print P-scores or SUCRAs for the common effects model. |
random |
A logical indicating whether to print P-scores or SUCRAs for the random effects model. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments passed on to
|
sort |
A logical indicating whether printout should be sorted by decreasing P-score. |
digits |
Minimal number of significant digits, see
|
Treatments are ranked based on a network meta-analysis. Ranking is performed by a ranking metric: P-score or SUCRA.
P-scores are based solely on the point estimates and standard errors of the network estimates. They measure the extent of certainty that a treatment is better than another treatment, averaged over all competing treatments (Rücker and Schwarzer 2015).
The Surface Under the Cumulative RAnking curve (SUCRA) is the rank
of treatment i within the range of treatments, measured on a
scale from 0 (worst) to 1 (best) (Salanti et al. 2011). A
resampling method is used to calculate SUCRAs for frequentist
network meta-analysis. The number of simulations is determine by
argument nsim
.
The interpretation of P-scores and SUCRAs is comparable.
The P-score of treatment i is defined as the mean of all 1 - P[j] where P[j] denotes the one-sided P-value of accepting the alternative hypothesis that treatment i is better than one of the competing treatments j. Thus, if treatment i is better than many other treatments, many of these P-values will be small and the P-score will be large. Vice versa, if treatment i is worse than most other treatments, the P-score is small.
The P-score of treatment i can be interpreted as the mean extent of certainty that treatment i is better than another treatment.
An object of class netrank
with corresponding print
function. The object is a list containing the following components:
ranking.common |
A named numeric vector with P-scores or SUCRAs for the common effects model. |
Pmatrix.common |
Numeric matrix based on pairwise one-sided p-values for the common effects model. |
ranking.random |
A named numeric vector with P-scores or SUCRAs for the random effects model. |
Pmatrix.random |
Numeric matrix based on pairwise one-sided p-values of the random effects model. |
small.values , method , x
|
As defined above. |
version |
Version of R package netmeta used to create object. |
Gerta Rücker [email protected], Guido Schwarzer [email protected], Theodoros Papakonstantinou [email protected]
Rücker G, Schwarzer G (2017): Resolve conflicting rankings of outcomes in network meta-analysis: Partial ordering of treatments. Research Synthesis Methods, 8, 526–36
Salanti G, Ades AE, Ioannidis JP (2011): Graphical methods and numerical summaries for presenting results from multiple-treatment meta-analysis: an overview and tutorial. Journal of Clinical Epidemiology, 64, 163–71
netmeta
, rankogram
,
plot.rankogram
data(smokingcessation) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1) netrank(net1) ## Not run: data(Senn2013) net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", random = FALSE) nr2 <- netrank(net2) nr2 print(nr2, sort = FALSE) net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") nr3 <- netrank(net3) nr3 print(nr3, sort = "common") print(nr3, sort = FALSE) net4 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") nr4 <- netrank(net4, method = "SUCRA", nsim = 100) nr4 print(nr4, sort = "common") print(nr4, sort = FALSE) ## End(Not run)
data(smokingcessation) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1) netrank(net1) ## Not run: data(Senn2013) net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", random = FALSE) nr2 <- netrank(net2) nr2 print(nr2, sort = FALSE) net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") nr3 <- netrank(net3) nr3 print(nr3, sort = "common") print(nr3, sort = FALSE) net4 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") nr4 <- netrank(net4, method = "SUCRA", nsim = 100) nr4 print(nr4, sort = "common") print(nr4, sort = FALSE) ## End(Not run)
Methods to split network estimates into the contribution of direct and indirect evidence and to test for local inconsistency in network meta-analysis.
netsplit( x, method, upper = TRUE, reference.group = x$reference.group, baseline.reference = x$baseline.reference, show = gs("show"), overall = TRUE, direct = TRUE, indirect = TRUE, only.reference = FALSE, ci = FALSE, test = show %in% c("all", "with.direct", "both"), order = NULL, sep.trts = x$sep.trts, quote.trts = "", tol.direct = 5e-04, common = x$common, random = x$random, backtransf = x$backtransf, warn = FALSE, warn.deprecated = gs("warn.deprecated"), verbose = FALSE, ... ) ## S3 method for class 'netsplit' print( x, common = x$x$common, random = x$x$random, show = x$show, overall = x$overall, direct = x$direct, indirect = x$indirect, ci = x$ci, test = x$test, only.reference = x$only.reference, sortvar = NULL, subset = NULL, nchar.trts = x$nchar.trts, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), digits.prop = max(gs("digits.pval") - 2, 2), text.NA = gs("lab.NA"), backtransf = x$backtransf, scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), legend = gs("legend"), indent = TRUE, warn.deprecated = gs("warn.deprecated"), ... )
netsplit( x, method, upper = TRUE, reference.group = x$reference.group, baseline.reference = x$baseline.reference, show = gs("show"), overall = TRUE, direct = TRUE, indirect = TRUE, only.reference = FALSE, ci = FALSE, test = show %in% c("all", "with.direct", "both"), order = NULL, sep.trts = x$sep.trts, quote.trts = "", tol.direct = 5e-04, common = x$common, random = x$random, backtransf = x$backtransf, warn = FALSE, warn.deprecated = gs("warn.deprecated"), verbose = FALSE, ... ) ## S3 method for class 'netsplit' print( x, common = x$x$common, random = x$x$random, show = x$show, overall = x$overall, direct = x$direct, indirect = x$indirect, ci = x$ci, test = x$test, only.reference = x$only.reference, sortvar = NULL, subset = NULL, nchar.trts = x$nchar.trts, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), digits.prop = max(gs("digits.pval") - 2, 2), text.NA = gs("lab.NA"), backtransf = x$backtransf, scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), legend = gs("legend"), indent = TRUE, warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
method |
A character string indicating which method to split
direct and indirect evidence is to be used. Either
|
upper |
A logical indicating whether treatment comparisons
should be selected from the lower or upper triangle of the
treatment effect matrices (see list elements |
reference.group |
Reference treatment. Ignored if argument
|
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment or vice versa. This argument is only
considered if |
show |
A character string indicating which comparisons should be printed (see Details). |
overall |
A logical indicating whether estimates from network meta-analysis should be printed. |
direct |
A logical indicating whether direct estimates should be printed. |
indirect |
A logical indicating whether indirect estimates should be printed. |
only.reference |
A logical indicating whether only comparisons with the reference group should be printed. |
ci |
A logical indicating whether confidence intervals should be printed in addition to treatment estimates. |
test |
A logical indicating whether results of a test comparing direct and indirect estimates should be printed. |
order |
A optional character or numerical vector specifying the order of treatments in comparisons. |
sep.trts |
A character string used in comparison names as separator between treatment labels, e.g., " vs ". |
quote.trts |
A character used to print around treatment labels. |
tol.direct |
A numeric defining the maximum deviation of the direct evidence proportion from 0 or 1 to classify a comparison as providing only indirect or direct evidence, respectively. |
common |
A logical indicating whether results for the common effects network meta-analysis should be printed. |
random |
A logical indicating whether results for the random effects network meta-analysis should be printed. |
backtransf |
A logical indicating whether printed results
should be back transformed. For example, if |
warn |
A logical indicating whether warnings should be printed. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
verbose |
A logical indicating whether progress information should be printed. |
... |
Additional arguments. |
sortvar |
An optional vector used to sort comparisons (must be of same length as the total number of comparisons). |
subset |
An optional logical vector specifying a subset of comparisons to print (must be of same length as the total number of comparisons) . |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
digits |
Minimal number of significant digits, see
|
digits.stat |
Minimal number of significant digits for z-value
of test of agreement between direct and indirect evidence, see
|
digits.pval |
Minimal number of significant digits for p-value
of test of agreement between direct and indirect evidence, see
|
digits.prop |
Minimal number of significant digits for direct
evidence proportions, see |
text.NA |
A character string specifying text printed for missing values. |
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. |
legend |
A logical indicating whether a legend should be printed. |
indent |
A logical indicating whether items in the legend should be indented. |
A comparison of direct and indirect treatment estimates can serve as check for consistency of network meta-analysis (Dias et al., 2010).
This function provides two methods to derive indirect estimates:
Separate Indirect from Direct Evidence (SIDE) using a
back-calculation method (method = "Back-calculation"
)
based on the direct evidence proportion to calculate the
indirect evidence (König et al., 2013);
Separate Indirect from Direct Design Evidence (SIDDE) as described in Efthimiou et al. (2019).
Note, for the back-calculation method, indirect treatment estimates
are already calculated in netmeta
and this function
combines and prints these estimates in a user-friendly
way. Furthermore, this method is not available for the
Mantel-Haenszel and non-central hypergeometric distribution
approach implemented in netmetabin
.
For the random-effects model, the direct treatment estimates are
based on the common between-study variance from the
network meta-analysis, i.e. the square of list element
x$tau
.
Argument show
determines which comparisons are printed:
“all” | All comparisons |
“both” | Only comparisons contributing both direct and indirect evidence |
“with.direct” | Comparisons providing direct evidence |
“direct.only” | Comparisons providing only direct evidence |
“indirect.only” | Comparisons providing only indirect evidence |
The node-splitting method and SIDDE can be compute-intensive in
large networks. Crude information on the computation progress is
printed if argument verbose = TRUE
. In addition, computation
times are printed if R package tictoc is installed.
An object of class netsplit
with corresponding print
and forest
functions. The object is a list containing the
following components:
common , random
|
As defined above. |
comparison |
A vector with treatment comparisons. |
prop.common , prop.random
|
A vector with direct evidence proportions (common / random effects model). |
common , random
|
Results of network meta-analysis (common / random effects model), i.e., data frame with columns comparison, TE, seTE, lower, upper, z, and p. |
direct.common , direct.random
|
Network meta-analysis results based on direct evidence (common / random effects model), i.e., data frame with columns comparison, TE, seTE, lower, upper, z, and p. |
indirect.common , indirect.random
|
Network meta-analysis results based on indirect evidence (common / random effects model), i.e., data frame with columns comparison, TE, seTE, lower, upper, z, and p. |
compare.common , compare.random
|
Comparison of direct and indirect evidence in network meta-analysis (common / random effects model), i.e., data frame with columns comparison, TE, seTE, lower, upper, z, and p. |
sm |
A character string indicating underlying summary measure |
level.ma |
The level used to calculate confidence intervals for pooled estimates. |
tictoc |
Computation times for node-splitting method or SIDDE (if R package tictoc is installed). |
version |
Version of R package netmeta used to create object. |
Guido Schwarzer [email protected], Gerta Rücker [email protected], Orestis Efthimiou [email protected]
Dias S, Welton NJ, Caldwell DM, Ades AE (2010): Checking consistency in mixed treatment comparison meta-analysis. Statistics in Medicine, 29, 932–44
Efthimiou O, Rücker G, Schwarzer G, Higgins J, Egger M, Salanti G (2019): A Mantel-Haenszel model for network meta-analysis of rare events. Statistics in Medicine, 38, 2992–3012
König J, Krahn U, Binder H (2013): Visualizing the flow of evidence in network meta-analysis and characterizing mixed treatment comparisons. Statistics in Medicine, 32, 5414–29
Puhan MA, Schünemann HJ, Murad MH, et al. (2014): A GRADE working group approach for rating the quality of treatment effect estimates from network meta-analysis. British Medical Journal, 349, g5630
forest.netsplit
, netmeta
,
netmetabin
, netmeasures
,
dat.woods2010
, Senn2013
,
dat.dong2013
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") # net1 <- netmeta(p1) # print(netsplit(net1), digits = 2) ## Not run: print(netsplit(net1), digits = 2, backtransf = FALSE, common = FALSE) # Sort by increasing number of studies in direct comparisons print(netsplit(net1), digits = 2, sortvar = k) # Sort by decreasing number of studies in direct comparisons print(netsplit(net1), digits = 2, sortvar = -k) # Sort by increasing evidence proportion under common effects model print(netsplit(net1), digits = 2, sortvar = prop.common) # Sort by decreasing evidence proportion under common effects model print(netsplit(net1), digits = 2, sortvar = -prop.common) # Sort by decreasing evidence proportion under common effects model # and number of studies print(netsplit(net1), digits = 2, sortvar = cbind(-prop.common, -k)) data(Senn2013) # net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013) # print(netsplit(net2), digits = 2) # Layout of Puhan et al. (2014), Table 1 print(netsplit(net2), digits = 2, ci = TRUE, test = FALSE) p3 <- pairwise(treatment, death, randomized, studlab = id, data = dat.dong2013, sm = "OR") net3 <- netmetabin(p3) netsplit(net3) ## End(Not run)
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") # net1 <- netmeta(p1) # print(netsplit(net1), digits = 2) ## Not run: print(netsplit(net1), digits = 2, backtransf = FALSE, common = FALSE) # Sort by increasing number of studies in direct comparisons print(netsplit(net1), digits = 2, sortvar = k) # Sort by decreasing number of studies in direct comparisons print(netsplit(net1), digits = 2, sortvar = -k) # Sort by increasing evidence proportion under common effects model print(netsplit(net1), digits = 2, sortvar = prop.common) # Sort by decreasing evidence proportion under common effects model print(netsplit(net1), digits = 2, sortvar = -prop.common) # Sort by decreasing evidence proportion under common effects model # and number of studies print(netsplit(net1), digits = 2, sortvar = cbind(-prop.common, -k)) data(Senn2013) # net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013) # print(netsplit(net2), digits = 2) # Layout of Puhan et al. (2014), Table 1 print(netsplit(net2), digits = 2, ci = TRUE, test = FALSE) p3 <- pairwise(treatment, death, randomized, studlab = id, data = dat.dong2013, sm = "OR") net3 <- netmetabin(p3) netsplit(net3) ## End(Not run)
Construct a table with network, direct and indirect estimates from one or more network meta-analyses.
nettable( ..., name = NULL, method = NULL, order = NULL, common, random, upper = TRUE, reference.group = NULL, baseline.reference = NULL, backtransf = NULL, nchar.trts = if (writexl) 666 else NULL, digits = gs("digits"), digits.I2 = gs("digits.I2"), digits.pval = gs("digits.pval"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), big.mark = gs("big.mark"), text.NA = ".", bracket = gs("CIbracket"), separator = gs("CIseparator"), lower.blank = gs("CIlower.blank"), upper.blank = gs("CIupper.blank"), tol.direct = 5e-04, writexl = !missing(path), path = "nettable.xlsx", overwrite = FALSE, warn = FALSE, verbose = FALSE ) ## S3 method for class 'nettable' print(x, common = x$x$common, random = x$x$random, legend = gs("legend"), ...)
nettable( ..., name = NULL, method = NULL, order = NULL, common, random, upper = TRUE, reference.group = NULL, baseline.reference = NULL, backtransf = NULL, nchar.trts = if (writexl) 666 else NULL, digits = gs("digits"), digits.I2 = gs("digits.I2"), digits.pval = gs("digits.pval"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), big.mark = gs("big.mark"), text.NA = ".", bracket = gs("CIbracket"), separator = gs("CIseparator"), lower.blank = gs("CIlower.blank"), upper.blank = gs("CIupper.blank"), tol.direct = 5e-04, writexl = !missing(path), path = "nettable.xlsx", overwrite = FALSE, warn = FALSE, verbose = FALSE ) ## S3 method for class 'nettable' print(x, common = x$x$common, random = x$x$random, legend = gs("legend"), ...)
... |
Any number of network meta-analysis objects or a single list with network meta-analyses. |
name |
An optional character vector providing descriptive names for network meta-analysis objects. |
method |
A character string indicating which method to split
direct and indirect evidence is to be used. Either
|
order |
A optional character or numerical vector specifying the order of treatments in comparisons. |
common |
A logical indicating whether table for the common effects network meta-analysis should be printed. |
random |
A logical indicating whether table for the random effects network meta-analysis should be printed. |
upper |
A logical indicating whether treatment comparisons
should be selected from the lower or upper triangle of the
treatment effect matrices (see list elements |
reference.group |
Reference treatment. Ignored if argument
|
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment or vice versa. This argument is only
considered if |
backtransf |
A logical indicating whether printed results
should be back transformed. For example, if |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
digits |
Minimal number of significant digits, see
|
digits.I2 |
Minimal number of significant digits for I-squared
statistic, see |
digits.pval |
Minimal number of significant digits for p-value
of test of agreement between direct and indirect evidence, 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. |
text.NA |
A character string specifying text printed for missing values. |
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. |
tol.direct |
A numeric defining the maximum deviation of the direct evidence proportion from 0 or 1 to classify a comparison as providing only indirect or direct evidence, respectively. |
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. |
warn |
A logical indicating whether warnings should be printed. |
verbose |
A logical indicating whether progress information should be printed. |
x |
An object of class |
legend |
A logical indicating whether a legend should be printed for abbreviated treatment names. |
Construct a table with network, direct and indirect estimates from one or more network meta-analyses. The table looks very similar to the statistical part of a GRADE table for a network meta-analysis (Puhan et al., 2014).
By default, an R object with the network tables is
generated. Alternatively, an Excel file is created if argument
writexl = TRUE
.
Two methods to derive indirect estimates are available:
Separate Indirect from Direct Evidence (SIDE) using a
back-calculation method (method = "Back-calculation"
)
based on the direct evidence proportion to calculate the
indirect evidence (König et al., 2013);
Separate Indirect from Direct Design Evidence (SIDDE) as described in Efthimiou et al. (2019).
Note, for the back-calculation method, indirect treatment estimates
are already calculated in netmeta
and this function
combines and prints these estimates in a user-friendly
way. Furthermore, this method is not available for the
Mantel-Haenszel and non-central hypergeometric distribution
approach implemented in netmetabin
.
For the random-effects model, the direct treatment estimates are
based on the common between-study variance from the
network meta-analysis, i.e. the square of list element
x$tau
.
The SIDDE approach can be compute-intensive in large
networks. Crude information on the computation progress is printed
for SIDDE if argument verbose
is TRUE
.
An object of class nettable
with corresponding print
function if argument writexl = FALSE
. The object is a list
containing the network tables in list elements 'common' and
'random'. An Excel file is created if writexl = TRUE
. In
this case, NULL
is returned in R.
Guido Schwarzer [email protected]
Dias S, Welton NJ, Caldwell DM, Ades AE (2010): Checking consistency in mixed treatment comparison meta-analysis. Statistics in Medicine, 29, 932–44
Efthimiou O, Rücker G, Schwarzer G, Higgins J, Egger M, Salanti G (2019): A Mantel-Haenszel model for network meta-analysis of rare events. Statistics in Medicine, 38, 2992–3012
König J, Krahn U, Binder H (2013): Visualizing the flow of evidence in network meta-analysis and characterizing mixed treatment comparisons. Statistics in Medicine, 32, 5414–29
Puhan MA, Schünemann HJ, Murad MH, et al. (2014): A GRADE working group approach for rating the quality of treatment effect estimates from network meta-analysis. British Medical Journal, 349, g5630
netsplit
, netmeta
,
netmetabin
, netmeasures
,
dat.woods2010
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") # net1 <- netmeta(p1) # nt1 <- nettable(net1, digits = 2) nt1 print(nt1, common = FALSE) print(nt1, random = FALSE) ## Not run: # Create a CSV file with network table from random effects model # table1 <- nettable(net1, digits = 2, bracket = "(", separator = " to ") # write.table(table1$random, file = "table1-random.csv", row.names = FALSE, col.names = TRUE, sep = ",") # # Create Excel files with network tables # (if R package writexl is available) # nettable(net1, digits = 2, bracket = "(", separator = " to ", path = tempfile(fileext = ".xlsx")) ## End(Not run)
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") # net1 <- netmeta(p1) # nt1 <- nettable(net1, digits = 2) nt1 print(nt1, common = FALSE) print(nt1, random = FALSE) ## Not run: # Create a CSV file with network table from random effects model # table1 <- nettable(net1, digits = 2, bracket = "(", separator = " to ") # write.table(table1$random, file = "table1-random.csv", row.names = FALSE, col.names = TRUE, sep = ",") # # Create Excel files with network tables # (if R package writexl is available) # nettable(net1, digits = 2, bracket = "(", separator = " to ", path = tempfile(fileext = ".xlsx")) ## End(Not run)
This function generates a scatter plot or biplot of P-scores with an overlay describing partial order of treatment ranks.
## S3 method for class 'netposet' plot( x, plottype = "scatter", pooled = ifelse(x$random, "random", "common"), dim = "2d", sel.x = 1, sel.y = 2, sel.z = 3, cex = 1, col = "black", cex.text = cex, col.text = col, adj.x = 0, adj.y = 1, offset.x = 0.005, offset.y = -0.005, pch = NULL, cex.points = cex, col.points = col, col.lines = "black", lty.lines = 1, lwd.lines = 1, arrows = FALSE, length = 0.05, grid = TRUE, col.grid = "gray", lty.grid = 2, lwd.grid = 1, ... )
## S3 method for class 'netposet' plot( x, plottype = "scatter", pooled = ifelse(x$random, "random", "common"), dim = "2d", sel.x = 1, sel.y = 2, sel.z = 3, cex = 1, col = "black", cex.text = cex, col.text = col, adj.x = 0, adj.y = 1, offset.x = 0.005, offset.y = -0.005, pch = NULL, cex.points = cex, col.points = col, col.lines = "black", lty.lines = 1, lwd.lines = 1, arrows = FALSE, length = 0.05, grid = TRUE, col.grid = "gray", lty.grid = 2, lwd.grid = 1, ... )
x |
An object of class |
plottype |
A character string indicating whether a scatter
plot or biplot should be produced, either |
pooled |
A character string indicating whether scatter plot
should be drawn for common ( |
dim |
A character string indicating whether a 2- or
3-dimensional plot should be produced, either |
sel.x |
A numeric specifying number of outcome to use for the x-axis in a scatterplot (argument is not considered for a biplot). |
sel.y |
A numeric specifying number of outcome to use for the y-axis in a scatterplot (argument is not considered for a biplot). |
sel.z |
A numeric specifying number of outcome to use for the z-axis in a scatterplot (argument is not considered for a biplot). |
cex |
The magnification to be used for treatment labels and points. |
col |
Colour(s) of treatment labels and points. |
cex.text |
The magnification to be used for treatment labels. |
col.text |
Colour(s) of treatment labels. |
adj.x |
Value(s) in [0, 1] to specify adjustment of treatment
labels on x-axis (only considered in 2-D plots); see
|
adj.y |
Value(s) in [0, 1] to specify adjustment of treatment
labels on y-axis (only considered in 2-D plots); see
|
offset.x |
Offset(s) of treatment labels on x-axis (only considered in 2-D plots). |
offset.y |
Offset(s) of treatment labels on y-axis (only considered in 2-D plots). |
pch |
Plot symbol(s) for points; no points printed if equal to
|
cex.points |
Magnification(s) to be used for points. |
col.points |
Colour(s) of points. |
col.lines |
Line colour. |
lty.lines |
Line type. |
lwd.lines |
Line width. |
arrows |
A logical indicating whether arrows should be printed (only considered in 2-D plots). |
length |
Length of arrows; see |
grid |
A logical indicating whether grid lines should be added to plot. |
col.grid |
Colour of grid lines. |
lty.grid |
Line type of grid lines. |
lwd.grid |
Line width of grid lines. |
... |
Additional graphical arguments. |
By default (arguments plottype = "scatter"
and dim =
"2d"
), a scatter plot is created showing P-scores (see
netrank
) for the first two outcomes considered in the
generation of a partially ordered set of treatment ranks (using
netposet
). In addition to the P-scores, the partially
order of treatment ranks is shown as lines connecting treatments
which is analogous to a Hasse diagram. If argument dim =
"3d"
), a 3-D scatter plot is generated showing P-scores for the
first three outcomes.
To overcome the restriction of two or three dimension, a biplot
(Gabriel, 1971) can be generated using argument plottype =
"biplot"
. This is essentially a scatter plot using the first two
(dim = "2d"
) or three (dim = "3d"
) components in a
principal components analysis (using
prcomp
). Note, if only two / three outcomes
are considered in a netposet
object, a 2-D / 3-D scatter
plot is generated instead of a biplot as a principal component
analysis is superfluous in such a situation.
Arguments sel.x
and sel.y
can be used to select
different outcomes to show on x- and y-axis in a 2-D scatter plot;
argument sel.z
can be used accordingly in a 3-D scatter
plot. These arguments are ignored for a biplot.
Note, in order to generate 3-D plots (argument dim = "3d"
),
R package rgl is necessary. Note, under macOS the X.Org X
Window System must be available (see
https://www.xquartz.org).
Gerta Rücker [email protected], Guido Schwarzer [email protected]
Carlsen L, Bruggemann R (2014): Partial order methodology: a valuable tool in chemometrics. Journal of Chemometrics, 28, 226–34
Gabriel KR (1971): The biplot graphic display of matrices with application to principal component analysis. Biometrika, 58, 453–67
netposet
, hasse
,
netrank
, netmeta
,
dat.linde2015
## Not run: # Define order of treatments in depression data set dat.linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # Partial order of treatment rankings # po2 <- netposet(netrank(net1), netrank(net2), outcomes = outcomes) # Scatter plot # plot(po2) # Same scatter plot as only two outcomes considered in netposet() # plot(po2, "biplot") # Consider three outcomes # # Outcome labels # outcomes <- c("Early response", "Early remission", "Lost to follow-up") # (3) Loss to follow-up # p3 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss1, loss2, loss3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net3 <- netmeta(p3, common = FALSE, seq = trts, ref = "Placebo", small.values = "desirable") # Partial order of treatment rankings (with three outcomes) # po3 <- netposet(netrank(net1), netrank(net2), netrank(net3), outcomes = outcomes) # Hasse diagram # hasse(po3) # Scatter plot # plot(po3) # Biplot (reverse limits of y-axis as biplot is upside down) # plot(po3, "bi", xlim = c(-1, 1.7), ylim = c(2.5, -2.5)) ## End(Not run)
## Not run: # Define order of treatments in depression data set dat.linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo", small.values = "undesirable") # Partial order of treatment rankings # po2 <- netposet(netrank(net1), netrank(net2), outcomes = outcomes) # Scatter plot # plot(po2) # Same scatter plot as only two outcomes considered in netposet() # plot(po2, "biplot") # Consider three outcomes # # Outcome labels # outcomes <- c("Early response", "Early remission", "Lost to follow-up") # (3) Loss to follow-up # p3 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss1, loss2, loss3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net3 <- netmeta(p3, common = FALSE, seq = trts, ref = "Placebo", small.values = "desirable") # Partial order of treatment rankings (with three outcomes) # po3 <- netposet(netrank(net1), netrank(net2), netrank(net3), outcomes = outcomes) # Hasse diagram # hasse(po3) # Scatter plot # plot(po3) # Biplot (reverse limits of y-axis as biplot is upside down) # plot(po3, "bi", xlim = c(-1, 1.7), ylim = c(2.5, -2.5)) ## End(Not run)
Produce an image plot of treatment ranking(s) generated with R
function netrank
.
## S3 method for class 'netrank' plot( ..., name, common, random, seq, low = "red", mid = "yellow", high = "green", col = "black", main, main.size = 14, main.col = col, main.face = "bold", legend = TRUE, axis.size = 12, axis.col = col, axis.face = "plain", na.value = "grey50", angle = 45, hjust.x = 1, vjust.x = 1, hjust.y = 1, vjust.y = 0, nchar.trts, digits = 3, fixed, comb.fixed, comb.random, warn.deprecated = gs("warn.deprecated") )
## S3 method for class 'netrank' plot( ..., name, common, random, seq, low = "red", mid = "yellow", high = "green", col = "black", main, main.size = 14, main.col = col, main.face = "bold", legend = TRUE, axis.size = 12, axis.col = col, axis.face = "plain", na.value = "grey50", angle = 45, hjust.x = 1, vjust.x = 1, hjust.y = 1, vjust.y = 0, nchar.trts, digits = 3, fixed, comb.fixed, comb.random, warn.deprecated = gs("warn.deprecated") )
... |
A single netrank object or a list of netrank objects. |
name |
An optional character vector providing descriptive names for the network meta-analysis objects. |
common |
A logical indicating whether results for the common effects model should be plotted. |
random |
A logical indicating whether results for the random effects model should be plotted. |
seq |
A character or numerical vector specifying the sequence of treatments on the x-axis. |
low |
A character string defining the colour for a P-score of
0, see |
mid |
A character string defining the colour for a P-score of
0.5, see |
high |
A character string defining the colour for a P-score of
1, see |
col |
Colour of text. |
main |
Title. |
main.size |
Font size of title, see
|
main.col |
Colour of title, see
|
main.face |
Font face of title, see
|
legend |
A logical indicating whether a legend should be printed. |
axis.size |
Font size of axis text, see
|
axis.col |
Colour of axis text, see
|
axis.face |
Font face of axis text, see
|
na.value |
Colour for missing values, see
|
angle |
Angle for text on x-axis, see
|
hjust.x |
A numeric between 0 and 1 with horizontal
justification of text on x-axis, see
|
vjust.x |
A numeric between 0 and 1 with vertical
justification of text on x-axis, see
|
hjust.y |
A numeric between 0 and 1 with horizontal
justification of text on y-axis, see
|
vjust.y |
A numeric between 0 and 1 with vertical
justification of text on y-axis, see
|
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
digits |
Minimal number of significant digits, see
|
fixed |
Deprecated argument (replaced by 'common'). |
comb.fixed |
Deprecated argument (replaced by 'common'). |
comb.random |
Deprecated argument (replaced by 'random'). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
This function produces an image plot of network rankings (Palpacuer
et al., 2018, Figure 4). Note, a scatter plot of two network
rankings can be generated with plot.netposet
.
By default, treatments are ordered by decreasing P-scores of the
first network meta-analysis object. Argument seq
can be used
to specify a differenct treatment order.
A ggplot2 object or NULL if no ranking was conducted.
Guido Schwarzer [email protected], Clément Palpacuer [email protected]
Palpacuer C, Duprez R, Huneau A, Locher C, Boussageon R, Laviolle B, et al. (2018): Pharmacologically controlled drinking in the treatment of alcohol dependence or alcohol use disorders: a systematic review with direct and network meta-analyses on nalmefene, naltrexone, acamprosate, baclofen and topiramate. Addiction, 113, 220–37
netrank
, netmeta
,
netposet
, hasse
,
dat.linde2015
## Not run: # Define order of treatments in depression dataset dat.linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo") # Image plot of treatment rankings (two outcomes) # plot(netrank(net1, small.values = "undesirable"), netrank(net2, small.values = "undesirable"), name = outcomes, digits = 2) # Outcome labels # outcomes <- c("Early response", "Early remission", "Lost to follow-up", "Lost to follow-up due to AEs", "Adverse events (AEs)") # (3) Loss to follow-up # p3 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss1, loss2, loss3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net3 <- netmeta(p3, common = FALSE, seq = trts, ref = "Placebo") # (4) Loss to follow-up due to adverse events # p4 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss.ae1, loss.ae2, loss.ae3), n = list(n1, n2, n3), studlab = id, data = subset(dat.linde2015, id != 55), sm = "OR") # net4 <- netmeta(p4, common = FALSE, seq = trts, ref = "Placebo") # (5) Adverse events # p5 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(ae1, ae2, ae3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net5 <- netmeta(p5, common = FALSE, seq = trts, ref = "Placebo") # Image plot of treatment rankings (two outcomes) # plot(netrank(net1, small.values = "undesirable"), netrank(net2, small.values = "undesirable"), netrank(net3, small.values = "desirable"), netrank(net4, small.values = "desirable"), netrank(net5, small.values = "desirable"), name = outcomes, digits = 2) ## End(Not run)
## Not run: # Define order of treatments in depression dataset dat.linde2015 # trts <- c("TCA", "SSRI", "SNRI", "NRI", "Low-dose SARI", "NaSSa", "rMAO-A", "Hypericum", "Placebo") # Outcome labels # outcomes <- c("Early response", "Early remission") # (1) Early response # p1 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net1 <- netmeta(p1, common = FALSE, seq = trts, ref = "Placebo") # (2) Early remission # p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(remi1, remi2, remi3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, seq = trts, ref = "Placebo") # Image plot of treatment rankings (two outcomes) # plot(netrank(net1, small.values = "undesirable"), netrank(net2, small.values = "undesirable"), name = outcomes, digits = 2) # Outcome labels # outcomes <- c("Early response", "Early remission", "Lost to follow-up", "Lost to follow-up due to AEs", "Adverse events (AEs)") # (3) Loss to follow-up # p3 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss1, loss2, loss3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net3 <- netmeta(p3, common = FALSE, seq = trts, ref = "Placebo") # (4) Loss to follow-up due to adverse events # p4 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(loss.ae1, loss.ae2, loss.ae3), n = list(n1, n2, n3), studlab = id, data = subset(dat.linde2015, id != 55), sm = "OR") # net4 <- netmeta(p4, common = FALSE, seq = trts, ref = "Placebo") # (5) Adverse events # p5 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(ae1, ae2, ae3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net5 <- netmeta(p5, common = FALSE, seq = trts, ref = "Placebo") # Image plot of treatment rankings (two outcomes) # plot(netrank(net1, small.values = "undesirable"), netrank(net2, small.values = "undesirable"), netrank(net3, small.values = "desirable"), netrank(net4, small.values = "desirable"), netrank(net5, small.values = "desirable"), name = outcomes, digits = 2) ## End(Not run)
This function produces a rankogram, i.e., an image plot of ranking probabilities for all treatments.
## S3 method for class 'rankogram' plot( x, type = if (cumulative.rankprob) "step" else "bar", pooled = ifelse(x$random, "random", "common"), sort = TRUE, trts, cumulative.rankprob = x$cumulative.rankprob, ylim, ylab, nchar.trts = x$nchar.trts, ... )
## S3 method for class 'rankogram' plot( x, type = if (cumulative.rankprob) "step" else "bar", pooled = ifelse(x$random, "random", "common"), sort = TRUE, trts, cumulative.rankprob = x$cumulative.rankprob, ylim, ylab, nchar.trts = x$nchar.trts, ... )
x |
An object of class |
type |
A character string specifying whether a "bar" chart, a "line" graph, or "step" functions should be drawn. Can be abbreviated. |
pooled |
A character string indicating whether results for the
common ( |
sort |
A logical indicating whether treatments should be sorted by decreasing SUCRAs. |
trts |
Treatment(s) to show in rankogram. |
cumulative.rankprob |
A logical indicating whether cumulative ranking probabilites should be shown. |
ylim |
The y limits (min, max) of the plot. |
ylab |
A label for the y-axis. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
... |
Additional graphical arguments (ignored at the moment). |
This function produces an image plot of (cumulative) ranking
probabilities for all treatments as a bar graph, a line graph or as
step functions (argument type
).
By default (argument pooled
), results for the random effects
model are shown if a network meta-analysis was conducted for both
the common and random effects model.
Treatments are sorted according to their mean effects if argument
sort = TRUE
(default). A subset of treatments can be
specified using argument trts
.
Cumulative ranking probabilites are shown if
cumulative.rankprob = TRUE
. By default, step functions are
shown for cumulative ranking probabilites.
Theodoros Papakonstantinou [email protected], Guido Schwarzer [email protected]
Salanti G, Ades AE, Ioannidis JP (2011): Graphical methods and numerical summaries for presenting results from multiple-treatment meta-analysis: an overview and tutorial. Journal of Clinical Epidemiology, 64, 163–71
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "good") set.seed(1909) # get reproducible results ran1 <- rankogram(net1, nsim = 100) ran1 plot(ran1) plot(ran1, type = "l") plot(ran1, cumulative.rankprob = TRUE)
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "good") set.seed(1909) # get reproducible results ran1 <- rankogram(net1, nsim = 100) ran1 plot(ran1) plot(ran1, type = "l") plot(ran1, cumulative.rankprob = TRUE)
Print method for objects of class decomp.design
.
## S3 method for class 'decomp.design' print( x, digits.Q = gs("digits.Q"), showall = FALSE, digits.pval.Q = gs("digits.pval.Q"), digits.tau2 = gs("digits.tau2"), scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), nchar.trts = x$nchar.trts, sort = TRUE, legend = gs("legend"), ... )
## S3 method for class 'decomp.design' print( x, digits.Q = gs("digits.Q"), showall = FALSE, digits.pval.Q = gs("digits.pval.Q"), digits.tau2 = gs("digits.tau2"), scientific.pval = gs("scientific.pval"), big.mark = gs("big.mark"), nchar.trts = x$nchar.trts, sort = TRUE, legend = gs("legend"), ... )
x |
An object of class |
digits.Q |
Minimal number of significant digits for Q
statistics, see |
showall |
A logical indicating whether results should be shown for all designs or only designs contributing to chi-squared statistics (default). |
digits.pval.Q |
Minimal number of significant digits for
p-value of heterogeneity tests, see |
digits.tau2 |
Minimal number of significant digits for
between-study 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. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
sort |
A logical indicating whether to sort results by p-values. |
legend |
A logical indicating whether a legend should be printed. |
... |
Additional arguments (ignored at the moment). |
Guido Schwarzer [email protected], Ulrike Krahn [email protected]
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct network meta-analysis with placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013.5, sm = "MD", reference = "plac") # Decomposition of Cochran's Q # decomp.design(net1)
data(Senn2013) # Only consider first five studies (to reduce runtime of example) # studies <- unique(Senn2013$studlab) Senn2013.5 <- subset(Senn2013, studlab %in% studies[1:5]) # Conduct network meta-analysis with placebo as reference treatment # net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013.5, sm = "MD", reference = "plac") # Decomposition of Cochran's Q # decomp.design(net1)
Print method for objects of class netbind
.
## S3 method for class 'netbind' print( x, common = x$x$common, random = x$x$random, warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'netbind' print( x, common = x$x$common, random = x$x$random, warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
common |
A logical indicating whether results for the common effects model should be printed. |
random |
A logical indicating whether results for the random effects model should be printed. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
Guido Schwarzer [email protected]
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Standard random effects NMA model (with placebo as reference # treatment) # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive CNMA model with placebo as inactive component and # reference # nc1 <- netcomb(net1, inactive = "placebo") # Combine results of standard NMA and CNMA # nb1 <- netbind(nc1, net1, name = c("Additive CNMA", "Standard NMA"), col.study = c("red", "black"), col.square = c("red", "black")) nb1 print(nb1, common = TRUE)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Standard random effects NMA model (with placebo as reference # treatment) # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive CNMA model with placebo as inactive component and # reference # nc1 <- netcomb(net1, inactive = "placebo") # Combine results of standard NMA and CNMA # nb1 <- netbind(nc1, net1, name = c("Additive CNMA", "Standard NMA"), col.study = c("red", "black"), col.square = c("red", "black")) nb1 print(nb1, common = TRUE)
Print method for objects of class netcomb
.
## S3 method for class 'netcomb' print( x, common = x$common, random = x$random, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, nchar.comps = x$nchar.comps, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), 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.tau = gs("print.tau"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), text.I2 = gs("text.I2"), details.methods = gs("details"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'netcomb' print( x, common = x$common, random = x$random, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, nchar.comps = x$nchar.comps, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), 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.tau = gs("print.tau"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), text.I2 = gs("text.I2"), details.methods = gs("details"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
common |
A logical indicating whether results for the common effects model should be printed. |
random |
A logical indicating whether results for the random effects model should be printed. |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and forest plots. If
|
nchar.comps |
A numeric defining the minimum number of characters used to create unique names for components. |
digits |
Minimal number of significant digits, see
|
digits.stat |
Minimal number of significant digits for z- or
t-value, 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 tests, see |
digits.Q |
Minimal number of significant digits for
heterogeneity statistics, 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 |
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.tau |
A logical specifying whether |
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 |
text.tau2 |
Text printed to identify between-study variance
|
text.tau |
Text printed to identify |
text.I2 |
Text printed to identify heterogeneity statistic
I |
details.methods |
A logical specifying whether details on statistical methods should be printed. |
legend |
A logical indicating whether a legend should be printed. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
Guido Schwarzer [email protected]
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc1 <- netcomb(net1) nc1 print(nc1, digits = 2, digits.stat = 3) ## Not run: # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc2 <- netcomb(net2) nc2 print(nc2, digits = 2, digits.stat = 3) ## End(Not run)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc1 <- netcomb(net1) nc1 print(nc1, digits = 2, digits.stat = 3) ## Not run: # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc2 <- netcomb(net2) nc2 print(nc2, digits = 2, digits.stat = 3) ## End(Not run)
Print method for objects of class netimpact
.
## S3 method for class 'netimpact' print( x, common = x$x$common, random = x$x$random, digits = gs("digits.prop"), nchar.trts = x$nchar.trts, nchar.studlab = x$nchar.studlab, details.methods = gs("details"), legend = gs("legend"), legend.studlab = TRUE, warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'netimpact' print( x, common = x$x$common, random = x$x$random, digits = gs("digits.prop"), nchar.trts = x$nchar.trts, nchar.studlab = x$nchar.studlab, details.methods = gs("details"), legend = gs("legend"), legend.studlab = TRUE, warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
common |
A logical indicating whether results for the common effects model should be printed. |
random |
A logical indicating whether results for the random effects model should be printed. |
digits |
Minimal number of significant digits. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names (see Details). |
nchar.studlab |
A numeric defining the minimum number of characters used to create unique study labels. |
details.methods |
A logical specifying whether details on statistical methods should be printed. |
legend |
A logical indicating whether a legend should be printed. |
legend.studlab |
A logical indicating whether a legend should be printed for abbreviated study labels. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
Guido Schwarzer [email protected]
# Only consider first two studies (to reduce runtime of example) # studies <- unique(dat.franchini2012$Study) p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = subset(dat.franchini2012, Study %in% studies[1:2]), studlab = Study) net1 <- netmeta(p1) ni <- netimpact(net1, verbose = TRUE) ni
# Only consider first two studies (to reduce runtime of example) # studies <- unique(dat.franchini2012$Study) p1 <- pairwise(list(Treatment1, Treatment2, Treatment3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = subset(dat.franchini2012, Study %in% studies[1:2]), studlab = Study) net1 <- netmeta(p1) ni <- netimpact(net1, verbose = TRUE) ni
Print method for objects of class rankogram
.
## S3 method for class 'rankogram' print( x, common = x$common, random = x$random, cumulative.rankprob = x$cumulative.rankprob, sort = TRUE, nchar.trts = x$nchar.trts, digits = gs("digits.prop"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'rankogram' print( x, common = x$common, random = x$random, cumulative.rankprob = x$cumulative.rankprob, sort = TRUE, nchar.trts = x$nchar.trts, digits = gs("digits.prop"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An R object of class |
common |
A logical indicating to print ranking probabilities and SUCRAs for the common effects model. |
random |
A logical indicating to print ranking probabilities and SUCRAs for the random effects model. |
cumulative.rankprob |
A logical indicating whether cumulative ranking probabilities should be printed. |
sort |
A logical indicating whether treatments should be sorted by decreasing SUCRAs. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
digits |
Minimal number of significant digits, see
|
legend |
A logical indicating whether a legend should be printed. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments for printing. |
Guido Schwarzer [email protected]
Salanti G, Ades AE, Ioannidis JP (2011): Graphical methods and numerical summaries for presenting results from multiple-treatment meta-analysis: an overview and tutorial. Journal of Clinical Epidemiology, 64, 163–71
rankogram
, plot.rankogram
,
dat.woods2010
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "desirable") ran1 <- rankogram(net1, nsim = 100) ran1 print(ran1, cumulative.rankprob = TRUE)
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "desirable") ran1 <- rankogram(net1, nsim = 100) ran1 print(ran1, cumulative.rankprob = TRUE)
Print detailed information for component network meta-analysis.
## S3 method for class 'summary.netcomb' print( x, common = x$x$common, random = x$x$random, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, nchar.comps = x$nchar.comps, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.Q = gs("digits.Q"), 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.tau = gs("print.tau"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), details.methods = gs("details"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'summary.netcomb' print( x, common = x$x$common, random = x$x$random, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, nchar.comps = x$nchar.comps, digits = gs("digits"), digits.stat = gs("digits.stat"), digits.pval = gs("digits.pval"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.Q = gs("digits.Q"), 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.tau = gs("print.tau"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), details.methods = gs("details"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
common |
A logical indicating whether results for the common effects model should be printed. |
random |
A logical indicating whether results for the random effects model should be printed. |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and forest plots. If
|
nchar.comps |
A numeric defining the minimum number of characters used to create unique component names. |
digits |
Minimal number of significant digits, see
|
digits.stat |
Minimal number of significant digits for z- or
t-value, 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 tests, see |
digits.Q |
Minimal number of significant digits for
heterogeneity statistics, 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.tau |
A logical specifying whether |
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 |
details.methods |
A logical specifying whether details on statistical methods should be printed. |
legend |
A logical indicating whether a legend should be printed. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments. |
Guido Schwarzer [email protected]
netcomb
, discomb
,
summary.netcomb
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc1 <- netcomb(net1) print(summary(nc1), digits = 2)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc1 <- netcomb(net1) print(summary(nc1), digits = 2)
Print method for objects of class summary.netmeta
.
## S3 method for class 'summary.netmeta' print( x, sortvar, common = x$x$common, random = x$x$random, prediction = x$prediction, reference.group = x$reference.group, baseline.reference = x$baseline.reference, all.treatments = x$all.treatments, details = TRUE, nma = TRUE, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, nchar.trts = x$nchar.trts, nchar.studlab = x$nchar.studlab, digits = gs("digits"), digits.se = gs("digits.se"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), 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.tau = gs("print.tau"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), truncate, text.truncate = "*** Output truncated ***", details.methods = gs("details"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'summary.netmeta' print( x, sortvar, common = x$x$common, random = x$x$random, prediction = x$prediction, reference.group = x$reference.group, baseline.reference = x$baseline.reference, all.treatments = x$all.treatments, details = TRUE, nma = TRUE, overall.hetstat = x$overall.hetstat, backtransf = x$backtransf, nchar.trts = x$nchar.trts, nchar.studlab = x$nchar.studlab, digits = gs("digits"), digits.se = gs("digits.se"), digits.pval.Q = max(gs("digits.pval.Q"), 2), digits.Q = gs("digits.Q"), digits.tau2 = gs("digits.tau2"), 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.tau = gs("print.tau"), print.Q = gs("print.Q"), print.I2 = gs("print.I2"), print.I2.ci = gs("print.I2.ci"), truncate, text.truncate = "*** Output truncated ***", details.methods = gs("details"), legend = gs("legend"), warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
sortvar |
An optional vector used to sort individual studies
(must be of same length as |
common |
A logical indicating whether results for the common effects model should be printed. |
random |
A logical indicating whether results for the random effects model should be printed. |
prediction |
A logical indicating whether prediction intervals should be printed. |
reference.group |
Reference treatment. |
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment (default) or vice versa. This argument is
only considered if |
all.treatments |
A logical or |
details |
A logical indicating whether further details for individual studies should be printed. |
nma |
A logical indicating whether summary results of network meta-analysis should be printed. |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and forest plots. If
|
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
nchar.studlab |
A numeric defining the minimum number of characters used to create unique study labels. |
digits |
Minimal number of significant digits, see
|
digits.se |
Minimal number of significant digits for standard
deviations and standard errors, see |
digits.pval.Q |
Minimal number of significant digits for
p-value of heterogeneity tests, see |
digits.Q |
Minimal number of significant digits for
heterogeneity statistics, see |
digits.tau2 |
Minimal number of significant digits for
between-study variance, see |
digits.I2 |
Minimal number of significant digits for I-squared
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.tau |
A logical specifying whether |
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 |
truncate |
An optional vector used to truncate the printout of
results for individual studies (must be a logical vector of
length corresponding to the number of pairwise comparisons
|
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. |
legend |
A logical indicating whether a legend should be printed. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments. |
Guido Schwarzer [email protected]
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis and print detailed # summary # net1 <- netmeta(p1, common = FALSE) summary(net1) ## Not run: data(Senn2013) # Conduct common effects network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", random = FALSE, ref = "plac") snet2 <- summary(net2) print(snet2, digits = 3) # Only show individual study results for multi-arm studies # print(snet2, digits = 3, truncate = multiarm) # Only show first three individual study results # print(snet2, digits = 3, truncate = 1:3) # Only show individual study results for Kim2007 and Willms1999 # print(snet2, digits = 3, truncate = c("Kim2007", "Willms1999")) # Only show individual study results for studies starting with the # letter "W" # print(snet2, ref = "plac", digits = 3, truncate = substring(studlab, 1, 1) == "W") # Conduct random effects network meta-analysis # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", common = FALSE, ref = "plac") print(summary(net3), digits = 3) ## End(Not run)
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis and print detailed # summary # net1 <- netmeta(p1, common = FALSE) summary(net1) ## Not run: data(Senn2013) # Conduct common effects network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", random = FALSE, ref = "plac") snet2 <- summary(net2) print(snet2, digits = 3) # Only show individual study results for multi-arm studies # print(snet2, digits = 3, truncate = multiarm) # Only show first three individual study results # print(snet2, digits = 3, truncate = 1:3) # Only show individual study results for Kim2007 and Willms1999 # print(snet2, digits = 3, truncate = c("Kim2007", "Willms1999")) # Only show individual study results for studies starting with the # letter "W" # print(snet2, ref = "plac", digits = 3, truncate = substring(studlab, 1, 1) == "W") # Conduct random effects network meta-analysis # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", common = FALSE, ref = "plac") print(summary(net3), digits = 3) ## End(Not run)
Draw a ‘comparison-adjusted’ radial plot to assess funnel plot asymmetry in network meta-analysis.
## S3 method for class 'netmeta' radial( x, order, pooled = ifelse(x$random, "random", "common"), level = x$level, pch, col = "black", legend = FALSE, pos.legend = "topright", pos.tests = "topleft", lump.comparator = FALSE, text.comparator = "comparator", method.bias, text.linreg = "(Egger)", text.rank = "(Begg-Mazumdar)", text.mm = "(Thompson-Sharp)", sep.trts = x$sep.trts, nchar.trts = x$nchar.trts, digits.pval = gs("digits.pval"), warn.deprecated = gs("warn.deprecated"), linreg = FALSE, rank = FALSE, mm = FALSE, ... )
## S3 method for class 'netmeta' radial( x, order, pooled = ifelse(x$random, "random", "common"), level = x$level, pch, col = "black", legend = FALSE, pos.legend = "topright", pos.tests = "topleft", lump.comparator = FALSE, text.comparator = "comparator", method.bias, text.linreg = "(Egger)", text.rank = "(Begg-Mazumdar)", text.mm = "(Thompson-Sharp)", sep.trts = x$sep.trts, nchar.trts = x$nchar.trts, digits.pval = gs("digits.pval"), warn.deprecated = gs("warn.deprecated"), linreg = FALSE, rank = FALSE, mm = FALSE, ... )
x |
An object of class |
order |
A mandatory character or numerical vector specifying the order of treatments or list of comparators (see Details). |
pooled |
A character string indicating whether results for the
common ( |
level |
The confidence level utilised in the plot. |
pch |
The plotting symbol(s) used for individual studies within direct comparisons. |
col |
The colour(s) used for individual studies within direct comparisons. |
legend |
A logical indicating whether a legend with information on direct comparisons should be added to the plot. |
pos.legend |
The position of the legend describing plotting symbols and colours for direct comparisons. |
pos.tests |
The position of results for test(s) of funnel plot asymmetry. |
lump.comparator |
A logical indicating whether comparators should be lumped, e.g., to specify inactive treatments. information on direct comparisons should be added to the plot. |
text.comparator |
A character string used in the plot to label
the comparator if |
method.bias |
A character vector indicating which test(s) for
funnel plot asymmetry to use. Admissible values are
|
text.linreg |
A character string used in the plot to label the Egger test for funnel plot asymmetry. |
text.rank |
A character string used in the plot to label the Begg test for funnel plot asymmetry. |
text.mm |
A character string used in the plot to label the Thompson-Sharp test for funnel plot asymmetry. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.trts |
A numeric defining the minimum number of
characters used to create unique treatment names (see
|
digits.pval |
Minimal number of significant digits for p-value of test(s) for funnel plot asymmetry. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
linreg |
Deprecated argument (replaced by |
rank |
Deprecated argument (replaced by |
mm |
Deprecated argument (replaced by |
... |
Additional graphical arguments passed as arguments to
|
A ‘comparison-adjusted’ radial plot is drawn in the active graphics window. The idea of this radial plot is similar to a ‘comparison-adjusted’ funnel plot (Chaimani & Salanti, 2012).
Argument order
is mandatory to determine the order of
treatments (Chaimani et al., 2013):
“Before using this plot, investigators should order the treatments in a meaningful way and make assumptions about how small studies differ from large ones. For example, if they anticipate that newer treatments are favored in small trials, then they could name the treatments from oldest to newest so that all comparisons refer to ‘old versus new intervention’. Other possibilities include defining the comparisons so that all refer to an active treatment versus placebo or sponsored versus non-sponsored intervention.”
Alternatively, it is possible to only provide a single or few
treatment name(s) in argument order
to define the
comparator(s). In this case only comparisons with this / these
treatment(s) will be considered. If argument lump.comparator
is TRUE
, all comparators will be lumped into a single
group. The text for this group can be specified with argument
text.comparator
.
A data frame with the following columns:
studlab |
Study label. |
treat1 |
Label/Number for first treatment. |
treat2 |
Label/Number for second treatment. |
comparison |
Treatment comparison. |
TE |
Estimate of treatment effect, e.g., log odds ratio. |
TE.direct |
Pooled estimate from direct evidence. |
TE.adj |
‘Comparison-adjusted’ treatment effect (TE - TE.direct). |
seTE |
Standard error of treatment estimate. |
pch |
Plotting symbol(s). |
col |
Colour of plotting symbol(s). |
Guido Schwarzer [email protected]
Chaimani A & Salanti G (2012): Using network meta-analysis to evaluate the existence of small-study effects in a network of interventions. Research Synthesis Methods, 3, 161–76
Chaimani A, Higgins JP, Mavridis D, Spyridonos P, Salanti G (2013): Graphical tools for network meta-analysis in STATA. PLOS ONE, 8, e76654
netmeta
, radial.meta
,
funnel.meta
, metabias
## Not run: data(Senn2013) net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") # 'Comparison-adjusted' radial plot not created as argument 'order' # is missing # try(radial(net1)) # Only show comparisons with placebo # radial(net1, order = "pl") # Add result for Egger test of funnel plot asymmetry # radial(net1, order = "pl", method.bias = "Egger", digits.pval = 2) # (Non-sensical) alphabetic order of treatments with placebo as # last treatment # ord <- c("a", "b", "me", "mi", "pi", "r", "si", "su", "v", "pl") radial(net1, order = ord) # Add results for tests of funnel plot asymmetry and use different # plotting symbols and colours # radial(net1, order = ord, pch = rep(c(15:18, 1), 3), col = 1:3, method.bias = c("Egger", "Begg", "Thompson"), digits.pval = 2) # Same results for tests of funnel plot asymmetry using reversed # order of treatments # radial(net1, order = rev(ord), pch = rep(c(15:18, 1), 3), col = 1:3, method.bias = c("Egger", "Begg", "Thompson"), digits.pval = 2) # Calculate tests for funnel plot asymmetry # f1 <- radial(net1, order = ord) # metabias(metagen(TE.adj, seTE, data = f1)) metabias(metagen(TE.adj, seTE, data = f1), method = "Begg") metabias(metagen(TE.adj, seTE, data = f1), method = "Thompson") ## End(Not run)
## Not run: data(Senn2013) net1 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD") # 'Comparison-adjusted' radial plot not created as argument 'order' # is missing # try(radial(net1)) # Only show comparisons with placebo # radial(net1, order = "pl") # Add result for Egger test of funnel plot asymmetry # radial(net1, order = "pl", method.bias = "Egger", digits.pval = 2) # (Non-sensical) alphabetic order of treatments with placebo as # last treatment # ord <- c("a", "b", "me", "mi", "pi", "r", "si", "su", "v", "pl") radial(net1, order = ord) # Add results for tests of funnel plot asymmetry and use different # plotting symbols and colours # radial(net1, order = ord, pch = rep(c(15:18, 1), 3), col = 1:3, method.bias = c("Egger", "Begg", "Thompson"), digits.pval = 2) # Same results for tests of funnel plot asymmetry using reversed # order of treatments # radial(net1, order = rev(ord), pch = rep(c(15:18, 1), 3), col = 1:3, method.bias = c("Egger", "Begg", "Thompson"), digits.pval = 2) # Calculate tests for funnel plot asymmetry # f1 <- radial(net1, order = ord) # metabias(metagen(TE.adj, seTE, data = f1)) metabias(metagen(TE.adj, seTE, data = f1), method = "Begg") metabias(metagen(TE.adj, seTE, data = f1), method = "Thompson") ## End(Not run)
Generic function to calculate the probabilities of each treatment being at each possible rank and the SUCRAs (Surface Under the Cumulative RAnking curve) in network meta-analysis.
rankogram(x, ...)
rankogram(x, ...)
x |
An R object. |
... |
Additional arguments. |
For more details, look at the following functions to generate rankograms:
Guido Schwarzer [email protected]
Salanti G, Ades AE, Ioannidis JP (2011): Graphical methods and numerical summaries for presenting results from multiple-treatment meta-analysis: an overview and tutorial. Journal of Clinical Epidemiology, 64, 163–71
netmeta
, netrank
,
plot.rankogram
, dat.woods2010
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "desirable") set.seed(1909) # get reproducible results ran1 <- rankogram(net1, nsim = 100) ran1 print(ran1, cumulative.rankprob = TRUE) plot(ran1)
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "desirable") set.seed(1909) # get reproducible results ran1 <- rankogram(net1, nsim = 100) ran1 print(ran1, cumulative.rankprob = TRUE) plot(ran1)
This function calculates the probabilities of each treatment being at each possible rank and the SUCRAs (Surface Under the Cumulative RAnking curve) from a sample of treatment estimates in network meta-analysis.
## Default S3 method: rankogram( x, pooled = "unspecified", small.values = "desirable", cumulative.rankprob = FALSE, keep.samples = FALSE, nchar.trts = gs("nchar.trts"), ... )
## Default S3 method: rankogram( x, pooled = "unspecified", small.values = "desirable", cumulative.rankprob = FALSE, keep.samples = FALSE, nchar.trts = gs("nchar.trts"), ... )
x |
A matrix or data frame with treatment effects in columns and samples in rows. |
pooled |
A character string indicating whether samples come from
a common ( |
small.values |
An optional character string specifying whether small
treatment effects indicate a beneficial ( |
cumulative.rankprob |
A logical indicating whether cumulative ranking probabilities should be printed. |
keep.samples |
A logical indicating whether to keep the generated samples. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
... |
Additional arguments (ignored). |
We derive a matrix showing the probability of each treatment being at each possible rank. To this aim, we use samples and summarise them using the ranking metric SUCRAs (Surface Under the Cumulative RAnking curve).
The matrix / data frame in argument x
must contain the sampled
effects for each treatment.
An object of class rankogram
with corresponding print
and plot
function. The object is a list containing the
following components:
ranking.matrix.common |
Numeric matrix giving the probability of each treatment being at each possible rank for the common effects model. |
ranking.common |
SUCRA values for the common effects model. |
ranking.matrix.random |
Numeric matrix giving the probability of each treatment being at each possible rank for the random effects model. |
ranking.random |
SUCRA values for the random effects model. |
cumrank.matrix.common |
Numeric matrix giving the cumulative ranking probability of each treatment for the common effects model. |
cumrank.matrix.random |
Numeric matrix giving the cumulative ranking probability of each treatment for the random effects model. |
nsim , common , random
|
As defined above |
,
small.values , x
|
As defined above |
,
Theodoros Papakonstantinou [email protected], Guido Schwarzer [email protected]
Salanti G, Ades AE, Ioannidis JP (2011): Graphical methods and numerical summaries for presenting results from multiple-treatment meta-analysis: an overview and tutorial. Journal of Clinical Epidemiology, 64, 163–71
netmeta
, netrank
,
plot.rankogram
,
dat.woods2010
,
dat.linde2015
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "desirable") set.seed(1909) # get reproducible results ran1 <- rankogram(net1, nsim = 100, common = FALSE, keep.samples = TRUE) ran1 rankogram(ran1$samples.random, pooled = "random") ## Not run: p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, ref = "Placebo", small = "undesirable") ran2 <- rankogram(net2, nsim = 100, common = FALSE, keep.samples = TRUE) ran2 # Wrong ranking due to using the default, # i.e., argument 'small.values = "desirable". rankogram(ran2$samples.random, pooled = "random") # Correct ranking rankogram(ran2$samples.random, pooled = "random", small.values = "undesirable") ## End(Not run)
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "desirable") set.seed(1909) # get reproducible results ran1 <- rankogram(net1, nsim = 100, common = FALSE, keep.samples = TRUE) ran1 rankogram(ran1$samples.random, pooled = "random") ## Not run: p2 <- pairwise(treat = list(treatment1, treatment2, treatment3), event = list(resp1, resp2, resp3), n = list(n1, n2, n3), studlab = id, data = dat.linde2015, sm = "OR") # net2 <- netmeta(p2, common = FALSE, ref = "Placebo", small = "undesirable") ran2 <- rankogram(net2, nsim = 100, common = FALSE, keep.samples = TRUE) ran2 # Wrong ranking due to using the default, # i.e., argument 'small.values = "desirable". rankogram(ran2$samples.random, pooled = "random") # Correct ranking rankogram(ran2$samples.random, pooled = "random", small.values = "undesirable") ## End(Not run)
This function calculates the probabilities of each treatment being at each possible rank and the SUCRAs (Surface Under the Cumulative RAnking curve) in frequentist network meta-analysis.
## S3 method for class 'netmeta' rankogram( x, nsim = gs("nsim"), common = x$common, random = x$random, small.values = x$small.values, cumulative.rankprob = FALSE, keep.samples = FALSE, nchar.trts = x$nchar.trts, warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'netmeta' rankogram( x, nsim = gs("nsim"), common = x$common, random = x$random, small.values = x$small.values, cumulative.rankprob = FALSE, keep.samples = FALSE, nchar.trts = x$nchar.trts, warn.deprecated = gs("warn.deprecated"), ... )
x |
An object of class |
nsim |
Number of simulations. |
common |
A logical indicating to compute ranking probabilities and SUCRAs for the common effects model. |
random |
A logical indicating to compute ranking probabilities and SUCRAs for the random effects model. |
small.values |
A character string specifying whether small
treatment effects indicate a beneficial ( |
cumulative.rankprob |
A logical indicating whether cumulative ranking probabilities should be printed. |
keep.samples |
A logical indicating whether to keep the generated samples. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (ignored). |
We derive a matrix showing the probability of each treatment being at each possible rank. To this aim, we use resampling from a multivariate normal distribution with estimated network effects as means and corresponding estimated variance covariance matrix. We then summarise them using the ranking metric SUCRAs (Surface Under the Cumulative RAnking curve).
An object of class rankogram
with corresponding print
and plot
function. The object is a list containing the
following components:
ranking.matrix.common |
Numeric matrix giving the probability of each treatment being at each possible rank for the common effects model. |
ranking.common |
SUCRA values for the common effects model. |
ranking.matrix.random |
Numeric matrix giving the probability of each treatment being at each possible rank for the random effects model. |
ranking.random |
SUCRA values for the random effects model. |
cumrank.matrix.common |
Numeric matrix giving the cumulative ranking probability of each treatment for the common effects model. |
cumrank.matrix.random |
Numeric matrix giving the cumulative ranking probability of each treatment for the random effects model. |
nsim , common , random
|
As defined above |
,
small.values , x
|
As defined above |
,
Theodoros Papakonstantinou [email protected], Guido Schwarzer [email protected]
Salanti G, Ades AE, Ioannidis JP (2011): Graphical methods and numerical summaries for presenting results from multiple-treatment meta-analysis: an overview and tutorial. Journal of Clinical Epidemiology, 64, 163–71
netmeta
, netrank
,
plot.rankogram
, dat.woods2010
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "desirable") set.seed(1909) # get reproducible results ran1 <- rankogram(net1, nsim = 100) ran1 print(ran1, cumulative.rankprob = TRUE) plot(ran1)
p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = dat.woods2010, sm = "OR") net1 <- netmeta(p1, small.values = "desirable") set.seed(1909) # get reproducible results ran1 <- rankogram(net1, nsim = 100) ran1 print(ran1, cumulative.rankprob = TRUE) plot(ran1)
Network meta-analysis in diabetes comparing effects of a number of drugs on the HbA1c value.
These data are used as an example in Senn et al. (2013) and have been preprocessed for use in R package netmeta.
A data frame with the following columns:
TE | treatment effect |
seTE | standard error of treatment effect |
treat1 | treatment 1 |
treat2 | treatment 2 |
treat1.long | treatment 1 (full treatment names) |
treat2.long | treatment 2 (full treatment names) |
studlab | Study label |
Treatment labels provided by columns treat1
and
treat2
have been abbreviated:
acar = Acarbose
benf = Benfluorex
metf = Metformin
migl = Miglitol
piog = Pioglitazone
plac = Placebo
rosi = Rosiglitazone
sita = Sitagliptin
sulf = Sulfonylurea
vild = Vildagliptin
Full treatment names are available in columns treat1.long
and treat2.long
.
Senn S, Gavini F, Magrez D, Scheen A (2013): Issues in performing a network meta-analysis. Statistical Methods in Medical Research, 22, 169–89
data(Senn2013) head(Senn2013) ## Not run: # Common effects model # net1 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, sm = "MD", random = FALSE, nchar.trts = 4) net1 net1$Q.decomp # Forest plot # forest(net1, ref = "plac") # Comparison with reference group # netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, reference = "plac") # Random effects model # net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, common = FALSE) net2 forest(net2, ref = "plac") ## End(Not run)
data(Senn2013) head(Senn2013) ## Not run: # Common effects model # net1 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, sm = "MD", random = FALSE, nchar.trts = 4) net1 net1$Q.decomp # Forest plot # forest(net1, ref = "plac") # Comparison with reference group # netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, reference = "plac") # Random effects model # net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, common = FALSE) net2 forest(net2, ref = "plac") ## End(Not run)
Print and change default settings to conduct and print or plot network meta-analyses in R package netmeta.
settings.netmeta(..., quietly = TRUE)
settings.netmeta(..., quietly = TRUE)
... |
Arguments to change default settings. |
quietly |
A logical indicating whether information on settings should be printed. |
Guido Schwarzer [email protected]
Network meta-analysis comparing the effects of a number of interventions for smoking cessation.
These data are used as an example in Dias et al. (2013), page 651.
A data frame with the following columns:
event1 | number of individuals with successful smoking cessation in arm 1 |
n1 | number of individuals in arm 1 |
event2 | number of individuals with successful smoking cessation in arm 2 |
n2 | number of individuals in arm 2 |
event3 | number of individuals with successful smoking cessation in arm 3 |
n3 | number of individuals in arm 3 |
treat1 | treatment 1 |
treat2 | treatment 2 |
treat3 | treatment 3 |
Dias S, Welton NJ, Sutton AJ, Caldwell DM, Lu G and Ades AE (2013): Evidence Synthesis for Decision Making 4: Inconsistency in networks of evidence based on randomized controlled trials. Medical Decision Making, 33, 641–56
pairwise
, metabin
,
netmeta
, netgraph.netmeta
data(smokingcessation) # Transform data from 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. # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") p1 # Conduct network meta-analysis # net1 <- netmeta(p1) net1 # Draw network graph # netgraph(net1, points = TRUE, cex.points = 3, cex = 1.25) tname <- c("No intervention", "Self-help", "Individual counselling", "Group counselling") netgraph(net1, points = TRUE, cex.points = 3, cex = 1.25, labels = tname)
data(smokingcessation) # Transform data from 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. # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") p1 # Conduct network meta-analysis # net1 <- netmeta(p1) net1 # Draw network graph # netgraph(net1, points = TRUE, cex.points = 3, cex = 1.25) tname <- c("No intervention", "Self-help", "Individual counselling", "Group counselling") netgraph(net1, points = TRUE, cex.points = 3, cex = 1.25, labels = tname)
This dataset contains data from a Cochrane review assessing efficacy and safety of three drug classes as adjuvant treatment to levodopa therapy in patients with Parkinson’s disease and motor complications (Stowe et al., 2010). The authors conducted three pairwise meta-analyses comparing dopamine agonists, catechol-O-methyl transferase inhibitors (COMTIs), and monoamine oxidase type B inhibitors (MAOBIs), respectively, with placebo.
The primary outcome was the mean reduction of the time spent in a relatively immobile ’off’ phase (mean off-time), calculated in hours per day. Relative treatment effects were expressed as mean difference. Data on this outcome were available for 5,331 patients from 28 studies comparing an active treatment with placebo and one three-arm study comparing two active treatments with placebo.
A data frame with the following columns:
study | study label |
id | study id |
t1 | treatment 1 |
y1 | treatment effect arm 1 |
sd1 | Standard deviation arm 1 |
n1 | Sample size arm 1 |
t2 | treatment 2 |
y2 | treatment effect arm 2 |
sd2 | Standard deviation arm 2 |
n2 | Sample size arm 2 |
t3 | treatment 3 |
y3 | treatment effect arm 3 |
sd3 | Standard deviation arm 3 |
n3 | Sample size arm 3 |
Stowe R, Ives N, Clarke CE, Deane K, Hilten V, Wheatley K, et al. (2010): Evaluation of the efficacy and safety of adjuvant treatment to levodopa therapy in Parkinson's disease patients with motor complications. Cochrane Database of Systematic Reviews
pairwise
, metacont
,
netmeta
, netgraph.netmeta
data(Stowe2010) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(t1, t2, t3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = Stowe2010, studlab = study) p1 # Conduct network meta-analysis net1 <- netmeta(p1, ref = "plac") net1
data(Stowe2010) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(t1, t2, t3), n = list(n1, n2, n3), mean = list(y1, y2, y3), sd = list(sd1, sd2, sd3), data = Stowe2010, studlab = study) p1 # Conduct network meta-analysis net1 <- netmeta(p1, ref = "plac") net1
Subgroup analysis for objects of class netmeta
.
## S3 method for class 'netmeta' subgroup( x, subgroup, only.connected = FALSE, common = x$common, random = x$random, method.tau = x$method.tau, level.ma = x$level.ma, backtransf = x$backtransf, nchar.trts = x$nchar.trts, ... ) subgroup(x, ...) ## S3 method for class 'subgroup.netmeta' print( x, common = x$x$common, random = x$x$random, backtransf = x$x$backtransf, nchar.trts = x$x$nchar.trts, digits = gs("digits"), digits.se = gs("digits.se"), digits.Q = gs("digits.Q"), digits.pval.Q = gs("digits.pval.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), big.mark = gs("big.mark"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), print.se = !backtransf, print.tau2 = gs("print.tau2"), print.tau = gs("print.tau"), print.Q = gs("print.Q"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), details.methods = gs("details"), legend = gs("legend"), ... )
## S3 method for class 'netmeta' subgroup( x, subgroup, only.connected = FALSE, common = x$common, random = x$random, method.tau = x$method.tau, level.ma = x$level.ma, backtransf = x$backtransf, nchar.trts = x$nchar.trts, ... ) subgroup(x, ...) ## S3 method for class 'subgroup.netmeta' print( x, common = x$x$common, random = x$x$random, backtransf = x$x$backtransf, nchar.trts = x$x$nchar.trts, digits = gs("digits"), digits.se = gs("digits.se"), digits.Q = gs("digits.Q"), digits.pval.Q = gs("digits.pval.Q"), digits.tau2 = gs("digits.tau2"), digits.tau = gs("digits.tau"), big.mark = gs("big.mark"), scientific.pval = gs("scientific.pval"), zero.pval = gs("zero.pval"), JAMA.pval = gs("JAMA.pval"), print.se = !backtransf, print.tau2 = gs("print.tau2"), print.tau = gs("print.tau"), print.Q = gs("print.Q"), text.tau2 = gs("text.tau2"), text.tau = gs("text.tau"), details.methods = gs("details"), legend = gs("legend"), ... )
x |
An object of class |
subgroup |
A vector defining the subgroups considered in the network meta-analysis. |
only.connected |
A logical indicating whether networks of subgroups must be connected. |
common |
A logical indicating whether results for common effect subgroup network meta-analysis should be printed. |
random |
A logical indicating whether results for random effects subgroup network meta-analysis should be printed. |
method.tau |
A character string indicating which method is
used to estimate the between-study variance |
level.ma |
The level used to calculate confidence intervals for network estimates. |
backtransf |
A logical indicating whether results should be
back transformed in printouts and forest plots. If
|
nchar.trts |
A numeric defining the minimum number of
characters used to create unique treatment names
(see |
... |
Additional arguments. |
digits |
Minimal number of significant digits, see
|
digits.se |
Minimal number of significant digits for standard errors. |
digits.Q |
Minimal number of significant digits for
heterogeneity statistic Q, see |
digits.pval.Q |
Minimal number of significant digits for
p-value of heterogeneity test, see |
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. |
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.se |
A logical specifying whether standard errors should be printed. |
print.tau2 |
A logical specifying whether between-study
variance |
print.tau |
A logical specifying whether |
print.Q |
A logical value indicating whether to print the results of the test of heterogeneity. |
text.tau2 |
Text printed to identify between-study variance
|
text.tau |
Text printed to identify |
details.methods |
A logical specifying whether details on statistical methods should be printed. |
legend |
A logical indicating whether a legend should be printed. |
An object of class "subgroup.netmeta"
with corresponding print
and forest
function.
forest.subgroup.netmeta
, forest.netmeta
## Not run: data("Senn2013") # Add variable with (fictitious) risk of bias values Senn2013$rob <- NA set.seed(1909) for (i in unique(Senn2013$studlab)) Senn2013$rob[Senn2013$studlab == i] <- sample(1:3, 1) Senn2013$rob <- factor(Senn2013$rob, levels = 1:3, labels = c("low", "moderate", "high")) # Conduct network meta-analysis net <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, sm = "MD", reference = "plac", nchar.trts = 4) # Conduct subgroup network meta-analysis subgroup(net, rob, common = FALSE) ## End(Not run)
## Not run: data("Senn2013") # Add variable with (fictitious) risk of bias values Senn2013$rob <- NA set.seed(1909) for (i in unique(Senn2013$studlab)) Senn2013$rob[Senn2013$studlab == i] <- sample(1:3, 1) Senn2013$rob <- factor(Senn2013$rob, levels = 1:3, labels = c("low", "moderate", "high")) # Conduct network meta-analysis net <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013, sm = "MD", reference = "plac", nchar.trts = 4) # Conduct subgroup network meta-analysis subgroup(net, rob, common = FALSE) ## End(Not run)
Summary method for objects of class netcomb
.
## S3 method for class 'netcomb' summary( object, common = object$common, random = object$random, overall.hetstat = object$overall.hetstat, backtransf = object$backtransf, nchar.comps = object$nchar.comps, warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'netcomb' summary( object, common = object$common, random = object$random, overall.hetstat = object$overall.hetstat, backtransf = object$backtransf, nchar.comps = object$nchar.comps, warn.deprecated = gs("warn.deprecated"), ... )
object |
An object of class |
common |
A logical indicating whether results for the common effects model should be printed. |
random |
A logical indicating whether results for the random effects model should be printed. |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be back transformed in printouts and forest plots. |
nchar.comps |
A numeric defining the minimum number of characters used to create unique component names. |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
A list of class "summary.netcomb" is returned with the following elements:
k |
Total number of studies. |
m |
Total number of pairwise comparisons. |
n |
Total number of treatments. |
d |
Total number of designs (corresponding to the unique set of treatments compared within studies). |
c |
Total number of components. |
s |
Total number of subnetworks (for |
trts |
Treatments included in network meta-analysis. |
k.trts |
Number of studies evaluating a treatment. |
n.trts |
Number of observations receiving a treatment (if available). |
events.trts |
Number of events observed for a treatment (if available). |
studies |
Study labels coerced into a factor with its levels sorted alphabetically. |
narms |
Number of arms for each study. |
designs |
Vector with unique designs present in the network. A design corresponds to the set of treatments compared within a study. |
comps |
Components included in network meta-analysis. |
k.comps |
Number of studies evaluating a component. |
n.comps |
Number of observations receiving a component (if available). |
events.comps |
Number of events observed for a component (if available). |
comparison |
Results for pairwise comparisons (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p). |
comparison.nma.common |
Results for pairwise comparisons based on common effects NMA model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p, leverage). |
comparison.nma.random |
Results for pairwise comparisons based on random effects NMA model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p). |
comparison.cnma.common |
Results for pairwise comparisons based on common effects CNMA model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p, leverage). |
comparison.cnma.random |
Results for pairwise comparisons based on random effects CNMA model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p). |
components.common |
Results for components based on common effects CNMA model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p, leverage). |
components.random |
Results for components based on random effects CNMA model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p). |
combinations.common |
Results for available combinations based on common effects CNMA model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p, leverage). |
combinations.random |
Results for available combinations based on random effects CNMA model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p). |
common |
Results for common effects model (a list with elements TE, seTE, lower, upper, z, p). |
random |
Results for random effects model (a list with elements TE, seTE, lower, upper, z, p). |
predict |
Prediction intervals (a list with elements seTE, lower, upper). |
Q.additive |
Overall heterogeneity / inconsistency statistic. |
df.Q.additive |
Degrees of freedom for test of heterogeneity / inconsistency. |
pval.Q.additive |
P-value for test of heterogeneity / inconsistency. |
I2 , lower.I2 , upper.I2
|
I-squared, lower and upper confidence limits. |
tau |
Square-root of between-study variance. |
Q.additive |
Overall heterogeneity / inconsistency statistic (CNMA model). |
df.Q.additive |
Degrees of freedom for test of heterogeneity / inconsistency (CNMA model). |
pval.Q.additive |
P-value for test of heterogeneity / inconsistency (CNMA model). |
Q.standard |
Overall heterogeneity statistic (NMA model). |
df.Q.heterogeneity |
Degrees of freedom for test of overall heterogeneity (NMA model). |
pval.Q.heterogeneity |
P-value for test of overall heterogeneity (NMA model). |
Q.diff |
Q statistic for difference between CNMA and NMA model. |
df.Q.diff , pval.Q.diff
|
Corresponding degrees of freedom and p-value. |
sm |
A character string indicating underlying summary measure. |
method |
A character string indicating which method is to be used for pooling of studies. |
level |
The level used to calculate confidence intervals for individual studies. |
level.ma |
The level used to calculate confidence intervals for pooled estimates. |
ci.lab |
Label for confidence interval. |
reference.group , baseline.reference
|
As defined above. |
all.treatments |
As defined above. |
seq |
A character specifying the sequence of treatments. |
tau.preset |
An optional value for the square-root of the
between-study variance |
sep.comps |
A character used in comparison names as separator between component labels. |
nchar.comps |
A numeric defining the minimum number of characters used to create unique component names. |
overall.hetstat , backtransf
|
As defined above. |
title |
Title of meta-analysis / systematic review. |
x |
|
call |
Function call. |
version |
Version of R package netmeta used to create object. |
Guido Schwarzer [email protected]
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc1 <- netcomb(net1) summary(nc1) print(summary(nc1), digits = 2, digits.stat = 3) ## Not run: # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc2 <- netcomb(net2) summary(nc2) print(summary(nc2), digits = 2, digits.stat = 3) ## End(Not run)
data(Linde2016) # Only consider studies including Face-to-face PST (to reduce # runtime of example) # face <- subset(Linde2016, id %in% c(16, 24, 49, 118)) # Conduct random effects network meta-analysis # net1 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = face, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc1 <- netcomb(net1) summary(nc1) print(summary(nc1), digits = 2, digits.stat = 3) ## Not run: # Conduct random effects network meta-analysis # net2 <- netmeta(lnOR, selnOR, treat1, treat2, id, data = Linde2016, reference.group = "placebo", sm = "OR", common = FALSE) # Additive model for treatment components # nc2 <- netcomb(net2) summary(nc2) print(summary(nc2), digits = 2, digits.stat = 3) ## End(Not run)
Summary method for objects of class netconnection
to print
list of studies in subnetworks.
## S3 method for class 'netconnection' summary(object, ...) ## S3 method for class 'summary.netconnection' print(x, ...)
## S3 method for class 'netconnection' summary(object, ...) ## S3 method for class 'summary.netconnection' print(x, ...)
object |
An object of class |
... |
Additional arguments (passed on to
|
x |
An object of class |
Guido Schwarzer [email protected]
# Artificial example with two subnetworks # t1 <- c("G", "B", "B", "D", "A", "F") t2 <- c("B", "C", "E", "E", "H", "A") # nc2 <- netconnection(t1, t2) print(nc2, details = TRUE) summary(nc2)
# Artificial example with two subnetworks # t1 <- c("G", "B", "B", "D", "A", "F") t2 <- c("B", "C", "E", "E", "H", "A") # nc2 <- netconnection(t1, t2) print(nc2, details = TRUE) summary(nc2)
Summary method for objects of class netmeta
.
## S3 method for class 'netmeta' summary( object, common = object$common, random = object$random, prediction = object$prediction, reference.group = object$reference.group, baseline.reference = object$baseline.reference, all.treatments = object$all.treatments, overall.hetstat = object$overall.hetstat, backtransf = object$backtransf, nchar.trts = object$nchar.trts, warn.deprecated = gs("warn.deprecated"), ... )
## S3 method for class 'netmeta' summary( object, common = object$common, random = object$random, prediction = object$prediction, reference.group = object$reference.group, baseline.reference = object$baseline.reference, all.treatments = object$all.treatments, overall.hetstat = object$overall.hetstat, backtransf = object$backtransf, nchar.trts = object$nchar.trts, warn.deprecated = gs("warn.deprecated"), ... )
object |
An object of class |
common |
A logical indicating whether results for the common effects model should be printed. |
random |
A logical indicating whether results for the random effects model should be printed. |
prediction |
A logical indicating whether prediction intervals should be printed. |
reference.group |
Reference treatment. |
baseline.reference |
A logical indicating whether results
should be expressed as comparisons of other treatments versus the
reference treatment (default) or vice versa. This argument is
only considered if |
all.treatments |
A logical or |
overall.hetstat |
A logical indicating whether to print heterogeneity measures. |
backtransf |
A logical indicating whether results should be back transformed in printouts and forest plots. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names (see Details). |
warn.deprecated |
A logical indicating whether warnings should be printed if deprecated arguments are used. |
... |
Additional arguments (to catch deprecated arguments). |
A list of class "summary.netmeta" is returned with the following elements:
k |
Total number of studies. |
m |
Total number of pairwise comparisons. |
n |
Total number of treatments. |
d |
Total number of designs (corresponding to the unique set of treatments compared within studies). |
trts |
Treatments included in network meta-analysis. |
k.trts |
Number of studies evaluating a treatment. |
n.trts |
Number of observations receiving a treatment (if available). |
events.trts |
Number of events observed for a treatment (if available). |
studies |
Study labels coerced into a factor with its levels sorted alphabetically. |
narms |
Number of arms for each study. |
designs |
Vector with unique designs present in the network. A design corresponds to the set of treatments compared within a study. |
comparisons |
Vector with unique direct comparisons present in the network. |
comparison |
Results for pairwise comparisons (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p). |
comparison.nma.common |
Results for pairwise comparisons based on common effects model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p, leverage). |
comparison.nma.random |
Results for pairwise comparisons based on random effects model (data frame with columns studlab, treat1, treat2, TE, seTE, lower, upper, z, p). |
common |
Results for common effects model (a list with elements TE, seTE, lower, upper, z, p). |
random |
Results for random effects model (a list with elements TE, seTE, lower, upper, z, p). |
predict |
Prediction intervals (a list with elements seTE, lower, upper). |
Q |
Overall heterogeneity / inconsistency statistic. |
df.Q |
Degrees of freedom for test of heterogeneity / inconsistency. |
pval.Q |
P-value for test of heterogeneity / inconsistency. |
I2 , lower.I2 , upper.I2
|
I-squared, lower and upper confidence limits. |
tau |
Square-root of between-study variance. |
Q.heterogeneity |
Overall heterogeneity statistic. |
df.Q.heterogeneity |
Degrees of freedom for test of overall heterogeneity. |
pval.Q.heterogeneity |
P-value for test of overall heterogeneity. |
Q.inconsistency |
Overall inconsistency statistic. |
df.Q.inconsistency |
Degrees of freedom for test of overall inconsistency. |
pval.Q.inconsistency |
P-value for test of overall inconsistency. |
Q.decomp |
Data frame with columns 'treat1', 'treat2', 'Q', 'df' and 'pval.Q', providing heterogeneity statistics for each pairwise meta-analysis of direct comparisons. |
sm |
A character string indicating underlying summary measure. |
method |
A character string indicating which method is to be used for pooling of studies. |
level |
The level used to calculate confidence intervals for individual studies. |
level.ma |
The level used to calculate confidence intervals for pooled estimates. |
level.predict |
The level used to calculate prediction intervals for a new study. |
ci.lab |
Label for confidence interval. |
incr |
Numerical value added to cell frequencies (if applicable). |
method.incr |
A character string indicating which continuity correction method was used (if applicable). |
allstudies |
A logical indicating whether studies with zero events or non-events in all treatment arms should be included in an inverse variance meta-analysis (if applicable). |
cc.pooled |
A logical indicating whether |
reference.group , baseline.reference
|
As defined above. |
all.treatments |
As defined above. |
seq |
A character specifying the sequence of treatments. |
tau.preset |
An optional value for the square-root of the
between-study variance |
sep.trts |
A character used in comparison names as separator between treatment labels. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
prediction , overall.hetstat , backtransf
|
As defined above. |
title |
Title of meta-analysis / systematic review. |
call |
Function call. |
version |
Version of R package netmeta used to create object. |
Guido Schwarzer [email protected]
data(smokingcessation) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1) summary(net1) ## Not run: data(Senn2013) # Conduct common effects network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", random = FALSE) print(net2, ref = "plac", digits = 3) summary(net2) # Conduct random effects network meta-analysis # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", common = FALSE) print(net3, ref = "plac", digits = 3) summary(net3) ## End(Not run)
data(smokingcessation) p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") net1 <- netmeta(p1) summary(net1) ## Not run: data(Senn2013) # Conduct common effects network meta-analysis # net2 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", random = FALSE) print(net2, ref = "plac", digits = 3) summary(net2) # Conduct random effects network meta-analysis # net3 <- netmeta(TE, seTE, treat1, treat2, studlab, data = Senn2013, sm = "MD", common = FALSE) print(net3, ref = "plac", digits = 3) summary(net3) ## End(Not run)
Auxiliary functions to create uniquely abbreviated treatment names.
treats(x, nchar.trts = 8, row = TRUE) comps(x, trts, sep.trts, nchar.trts = 8, row = TRUE)
treats(x, nchar.trts = 8, row = TRUE) comps(x, trts, sep.trts, nchar.trts = 8, row = TRUE)
x |
A vector with treatment or comparison names or a matrix with treatment or comparison names as row and / or column names. |
nchar.trts |
A numeric defining the minimum number of characters used to create unique treatment names. |
row |
A logical indicating whether row or column names should
be used (only considered if argument |
trts |
A character vector with treatment names. |
sep.trts |
A character used in comparison names as separator between treatment labels. |
These auxiliary functions can be used to create uniquely abbreviated treatment names (and are used internally in several R functions for this purpose).
In order to construct uniquely abbreviated treatment names,
treats
uses substring
to extract the first
nchar.trts
characters. If these abbreviated treatment names
are not unique, abbreviate
with argument
minlength = nchar.trts
is used.
In order to construct comparisons with uniquely abbreviated
treatment names, comps
calls treats
internally.
Guido Schwarzer [email protected]
netmeta
, print.netmeta
,
print.summary.netmeta
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis and show data frame # net1 <- netmeta(p1, common = FALSE) # Full treatment names # net1$trts # Treatment names with maximal four characters # treats(net1$trts, nchar.trts = 4) ## Not run: data(Senn2013) # net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013) # Full treatment names # net2$trts # Treatment names with four characters # treats(net2$trts, nchar.trts = 4) # With two characters # treats(net2$trts, nchar.trts = 2) # With one character (if possible) # treats(net2$trts, nchar.trts = 1) # Full comparison names # net2$comparisons # Abbreviated comparison names # with(net2, comps(comparisons, trts, sep.trts, nchar = 4)) ## End(Not run)
data(smokingcessation) # Transform data from arm-based format to contrast-based format # p1 <- pairwise(list(treat1, treat2, treat3), event = list(event1, event2, event3), n = list(n1, n2, n3), data = smokingcessation, sm = "OR") # Conduct random effects network meta-analysis and show data frame # net1 <- netmeta(p1, common = FALSE) # Full treatment names # net1$trts # Treatment names with maximal four characters # treats(net1$trts, nchar.trts = 4) ## Not run: data(Senn2013) # net2 <- netmeta(TE, seTE, treat1.long, treat2.long, studlab, data = Senn2013) # Full treatment names # net2$trts # Treatment names with four characters # treats(net2$trts, nchar.trts = 4) # With two characters # treats(net2$trts, nchar.trts = 2) # With one character (if possible) # treats(net2$trts, nchar.trts = 1) # Full comparison names # net2$comparisons # Abbreviated comparison names # with(net2, comps(comparisons, trts, sep.trts, nchar = 4)) ## End(Not run)
Count mortality statistics in randomised controlled trials of treatments for chronic obstructive pulmonary disease (Woods et al. (2010), Table 1).
A data frame with the following columns:
author | first author / study name |
treatment | treatment |
r | number of deaths in treatment arm |
N | number of patients in treatment arm |
Woods BS, Hawkins N, Scott DA (2010): Network meta-analysis on the log-hazard scale, combining count and hazard ratio statistics accounting for multi-arm trials: A tutorial. BMC Medical Research Methodology, 10, 54
data(Woods2010) # 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. # p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = Woods2010, sm = "OR") p1 # Conduct network meta-analysis # net1 <- netmeta(p1) net1 ## Not run: # Show forest plot # forest(net1, ref = "Placebo", drop = TRUE, leftlabs = "Contrast to Placebo") ## End(Not run)
data(Woods2010) # 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. # p1 <- pairwise(treatment, event = r, n = N, studlab = author, data = Woods2010, sm = "OR") p1 # Conduct network meta-analysis # net1 <- netmeta(p1) net1 ## Not run: # Show forest plot # forest(net1, ref = "Placebo", drop = TRUE, leftlabs = "Contrast to Placebo") ## End(Not run)