plotMAhex {hexbin} | R Documentation |
MA-plot using hexagon bins
Description
Creates an MA-plot using hexagons with color/glyph coding for control spots.
Usage
plotMAhex(MA, array = 1, xlab = "A", ylab = "M",
main = colnames(MA)[array], xlim = NULL, ylim = NULL,
status = NULL, values, pch, col, cex, nbin = 40,
zero.weights = FALSE, style = "colorscale", legend = 1.2,
lcex = 1, minarea = 0.04, maxarea = 0.8, mincnt = 2,
maxcnt = NULL, trans = NULL, inv = NULL, colorcut = NULL,
border = NULL, density = NULL, pen = NULL,
colramp = function(n) { LinGray(n, beg = 90, end = 15) },
newpage = TRUE, type = c("p", "l", "n"),
xaxt = c("s", "n"), yaxt = c("s", "n"),
verbose = getOption("verbose"))
Arguments
MA |
an |
array |
integer giving the array to be plotted. Corresponds to
columns of |
xlab , ylab , main |
character strings giving label for x-axis, y-axis or main tile of the plot. |
xlim , ylim |
numeric vectors of length 2 giving limits for x-axis (or y-axis respectively), defaulting to min and max of the data. |
status |
character vector giving the control status of each spot
on the array, of same length as the number of rows of |
values |
character vector giving values of |
pch |
vector or list of plotting characters. Default to integer code 16.
Ignored is there is no |
col |
numeric or character vector of colors, of the same length
as |
cex |
numeric vector of plot symbol expansions, of the the same
length as |
nbin |
Number of bins |
zero.weights |
logical, should spots with zero or negative weights be plotted? |
style |
string specifying the style of hexagon plot,
see |
legend |
numeric width of the legend in inches of |
lcex |
characters expansion size for the text in the legend. |
minarea |
fraction of cell area for the lowest count. |
maxarea |
fraction of the cell area for the largest count. |
mincnt |
cells with fewer counts are ignored. |
maxcnt |
cells with more counts are ignored. |
trans |
|
inv |
the inverse transformation of |
colorcut |
vector of values covering [0, 1] that determine
hexagon color class boundaries and hexagon legend size boundaries.
Alternatively, an integer ( |
border , density , pen |
color for polygon borders and filling of
each hexagon drawn, passed to |
colramp |
function accepting an integer |
newpage |
should a new page start? |
type , xaxt , yaxt |
strings to be used (when set to |
verbose |
logical indicating if some diagnostic output should happen. |
Details
An MA-plot is a plot of log-intensity ratios (M-values) versus
log-intensity averages (A-values). If MA
is an RGList
or
MAList
then this function produces an ordinary within-array
MA-plot. If MA
is an MArrayLM
object, then the plot is an
fitted model MA-plot in which the estimated coefficient is on the y-axis
and the average A-value is on the x-axis.
If MA
is a matrix
or ExpressionSet
object, then this
function produces a between-array MA-plot. In this case the A-values in
the plot are the average log-intensities across the arrays and the
M-values are the deviations of the log-intensities for the specified
array from the average. If there are more than five arrays, then the
average is computed robustly using medians. With five or fewer arrays,
it is computed by means.
The status
vector is intended to specify the control status of
each spot, for example "gene", "ratio control", "house keeping gene",
"buffer" and so on. The vector is usually computed using the function
controlStatus
from package limma and a
spot-types file. However the function may be used to highlight any
subset of spots.
The arguments values
, pch
, col
and cex
can be included as attributes to status
instead of being
passed as arguments to plotMA
.
See points
for possible values for pch
,
col
and cex
.
Value
A plot is created on the current graphics device. and a list with the following items is returned invisibly:
plot.vp |
the |
legend.vp |
if a legend has been produced, its
|
hbin |
a |
Author(s)
Nicholas Lewin-Koh, adapted from code by Gordon Smyth
References
See http://www.statsci.org/micrarra/refs/maplots.html
See Also
plotMA
from package limma,
and gplot.hexbin
.
Examples
if(require(marray)){
data(swirl)
hb <- plotMAhex(swirl[,1],newpage=FALSE,
main = "M vs A plot with hexagons", legend=0)
hexVP.abline(hb$plot.vp,h=0,col=gray(.6))
hexMA.loess(hb)
}