Learn R Programming

metafor (version 1.4-0)

forest.rma: Forest Plots for rma Objects

Description

Function to create forest plots for objects of class "rma".

Usage

## S3 method for class 'rma':
forest(x, annotate=TRUE, addfit=TRUE, addcred=FALSE, showweight=FALSE,
       xlim=NULL, alim=NULL, ylim=NULL, at=NULL, steps=5, 
       level=x$level, digits=2, refline=0, xlab=NULL, 
       slab=NULL, mlab=NULL, ilab=NULL, ilab.xpos=NULL, ilab.pos=NULL, 
       order=NULL, transf=FALSE, atransf=FALSE, targs=NULL, rows=NULL, 
       efac=1, pch=15, psize=NULL, col="darkgray", border="darkgray", 
       cex=NULL, cex.lab=NULL, cex.axis=NULL, \dots)

Arguments

x
an object of class "rma".
annotate
logical specifying whether annotations should be added to the plot (default is TRUE).
addfit
logical specifying whether the summary estimate (for models without moderators) or fitted values (for models with moderators) should be added to the plot. See Details.
addcred
logical specifying whether the bounds of the credibility interval should be added to the plot. See Details.
showweight
logical specifying whether the annotations should also include the weights given to the observed effects or outcomes during the model fitting (default is FALSE).
xlim
horizontal limits of the plot region. Defaults to NULL, which means that the function tries to set the horizontal plot limits to some sensible values.
alim
the actual x axis limits. Defaults to NULL, which means that the function tries to set the x axis limits to some sensible values.
ylim
the y limits of the plot. Defaults to NULL, which means that the function tries to set the y axis limits to some sensible values.
at
position of the x axis tick marks and corresponding labels. Defaults to NULL, which means that the function tries to set the tick mark positions/labels to some sensible values.
steps
the number of tick marks for the x axis (default is 5). Ignored when the user specifies the positions via the at argument.
level
numerical value between 0 and 100 specifying the confidence interval level (the default is to take the value from the object).
digits
integer value specifying the number of decimal places to which the tick mark labels of the x axis and the annotations should be rounded (default is 2).
refline
value at which a vertical reference line should be drawn (default is 0). The line can be suppressed by setting this argument to NA.
xlab
title for the x axis. If NULL (default), the function tries to set an appropriate axis title.
slab
an optional vector with unique labels for the $k$ studies. Defaults to NULL, which means that the labels are either taken from the object (if study labels were specified) or simple labels are created within the function. To suppress labels, s
mlab
an optional character string giving a label to the summary estimate from a fixed- or random-effects model. Defaults to NULL, which means that the label is created within the function.
ilab
an optional vector or matrix of character strings providing additional information about the studies.
ilab.xpos
vector of numerical value(s) specifying the x axis position(s) of the character vector(s) given via ilab.
ilab.pos
integer(s) (either 1, 2, 3, or 4) specifying the alignment of the character vector(s) given via ilab (2 means right, 4 mean left aligned). The default is to center the labels.
order
an optional character string specifying how the studies should be ordered. See Details.
transf
an optional argument specifying the name of a function that should be used to transform the observed effect sizes, summary estimates, fitted values, and confidence interval bounds (e.g., transf=exp). Defaults to FALSE, which mean
atransf
an optional argument specifying the name of a function that should be used to transform the x axis labels and annotations (e.g., transf=exp). Defaults to FALSE, which means that no transformation is used.
targs
optional arguments needed by the function specified via transf or atransf.
rows
an optional vector specifying the rows (or more generally, the horizontal positions) for plotting the outcomes. Defaults to NULL, which means that the function sets this value automatically. Can also be a single value specifying the row (hori
efac
vertical expansion factor for arrows, confidence interval limits, and the symbol used to denote summary estimates. The default value of 1 should usually work okay.
pch
plotting symbol to use for the observed effect sizes or outcomes. By default, a filled square is used. See points for other options. Can also be a vector of values.
psize
an optional vector with point sizes for the observed effect sizes or outcomes. Default is NULL, which means that the point sizes are drawn proportional to the precision of the estimates.
cex
an optional character and symbol expansion factor. If NULL (default), the function tries to set this to a sensible value.
cex.lab
an optional expansion factor for the x axis titel. If NULL (default), the function tries to set this to a sensible value.
cex.axis
an optional expansion factor for the x axis labels. If NULL (default), the function tries to set this to a sensible value.
col
character string specifying the name of a color to use for the fitted values ("darkgray" by default).
border
character string specifying the name of a color to use for the border of the fitted values ("darkgray" by default).
...
other arguments.

Details

The plot shows the individual observed effect sizes or outcomes with corresponding confidence intervals. For fixed- and random-effects models (i.e., for models without moderators), a polygon is added to the bottom of the forest plot, showing the summary estimate based on the model (with the outer edges of the polygon indicating the confidence interval limits). For random-effects models and if addcred=TRUE, a dashed line indicates the (approximate) bounds of the credibility interval (where 95% of the true effects are estimated to fall). For models involving moderators, the fitted value for each study is added as a polygon to the plot. With the col and border arguments, one can change the (border) color of these polygons. With the transf argument, the observed effect sizes, summary estimate, fitted values, and interval bounds can be transformed with an arbitrary function. For example, when analyzing log odds ratios, one could use transf=exp to obtain a forest plot showing the odds ratios. Alternatively, one can use the atransf argument to transform the x axis labels and annotations. The examples below illustrate the use of these arguments. The studies can be reordered with the order argument:
  • order="obs": the studies are ordered by the observed effect sizes,
  • order="fit": the studies are ordered by the fitted values,
  • order="prec": the studies are ordered by their sampling variances,
  • order="resid": the studies are ordered by the size of their residuals,
  • order="rstandard": the studies are ordered by the size of their standardized residuals,
  • order="abs.resid": the studies are ordered by the size of their absolute residuals,
  • order="abs.rstandard": the studies are ordered by the size of their absolute standardized residuals.
Alternatively, it is also possible to set order equal to a vector with indices specifying the desired order (see examples below). Additional summary estimates can also be added to the plot with the addpoly function. See the documentation for that function for examples.

References

Lewis, S. & Clarke, M. (2001). Forest plots: Trying to see the wood and the trees. British Medical Journal, 322, 1479--1480. Viechtbauer, W. (2010). Conducting meta-analyses in R with the metafor package. Journal of Statistical Software, 36(3), 1--48. http://www.jstatsoft.org/v36/i03/.

See Also

forest, addpoly

Examples

Run this code
### load BCG vaccine data
data(dat.bcg)

### meta-analysis of the log relative risks using a random-effects model
res <- rma(ai=tpos, bi=tneg, ci=cpos, di=cneg, data=dat.bcg, measure="RR", 
           slab=paste(author, year, sep=", "), method="REML")

### several forest plots illustrating the use of various arguments
forest(res)
forest(res, order=order(dat.bcg$ablat))
forest(res, transf=exp, alim=c(0,6), steps=4, xlim=c(-8,12), refline=1)
forest(res, atransf=exp, at=log(c(.05,.25,1,4,20)), xlim=c(-8,8), 
       order="prec", showweight=TRUE, cex=.8)

### forest plot with extra annotations
forest(res, slab=paste(dat.bcg$author, dat.bcg$year, sep=", "), 
       xlim=c(-16, 6), at=log(c(.05, .25, 1, 4)), atransf=exp,
       ilab=cbind(dat.bcg$tpos, dat.bcg$tneg, dat.bcg$cpos, dat.bcg$cneg), 
       ilab.xpos=c(-9.5,-8,-6,-4.5), cex=.75)
op <- par(cex=.75, font=2)
text(c(-9.5,-8,-6,-4.5), 15, c("TB+", "TB-", "TB+", "TB-"))
text(c(-8.75,-5.25),     16, c("Vaccinated", "Control"))
text(-16,                15, "Author(s) and Year",     pos=4)
text(6,                  15, "Relative Risk [95% CI]", pos=2)
par(op)

### mixed-effects model with absolute latitude in the model
res <- rma(ai=tpos, bi=tneg, ci=cpos, di=cneg, mods=ablat, data=dat.bcg, 
           measure="RR", method="REML", slab=paste(author, year, sep=", "))

### forest plot with observed and fitted values
forest(res, xlim=c(-9,5), order="fit", cex=.8, ilab=dat.bcg$ablat, 
       ilab.xpos=-4, atransf=exp, at=log(c(.05,.25,1,4)))
op <- par(font=2)
text(-9, 15, "Author(s) and Year",    pos=4, cex=.8)
text( 5, 15, "Observed RR [95% CI]",  pos=2, cex=.8)
text(-4, 15, "Latitude",                     cex=.8)
par(op)

### forest plot with subgrouping of studies
res <- rma(ai=tpos, bi=tneg, ci=cpos, di=cneg, data=dat.bcg, measure="RR", 
           slab=paste(author, year, sep=", "), method="REML")
forest(res, slab=paste(dat.bcg$author, dat.bcg$year, sep=", "), 
       xlim=c(-16, 6), at=log(c(.05, .25, 1, 4)), atransf=exp,
       ilab=cbind(dat.bcg$tpos, dat.bcg$tneg, dat.bcg$cpos, dat.bcg$cneg), 
       ilab.xpos=c(-9.5,-8,-6,-4.5), cex=.75, ylim=c(-1, 21), 
       order=order(dat.bcg$alloc), rows=c(1:2,5:11,14:17))
op <- par(cex=.75, font=4)
text(-16, c(18,12,3), c("Systematic Allcoation", "Random Allocation", 
                        "Alternate Allocation"), pos=4)
par(cex=.75, font=2)
text(c(-9.5,-8,-6,-4.5), 20, c("TB+", "TB-", "TB+", "TB-"))
text(c(-8.75,-5.25),     21, c("Vaccinated", "Control"))
text(-16,                20, "Author(s) and Year",     pos=4)
text(6,                  20, "Relative Risk [95% CI]", pos=2)
par(op)

### see also addpoly.default function for an example where summaries
### for the three subgroups are added to such a forest plot

Run the code above in your browser using DataLab