\HeaderA{maPlot}{Scatter-plots for cDNA microarray spot statistics}{maPlot}
\keyword{hplot}{maPlot}
\begin{Description}\relax
The function \code{maPlot} produces scatter-plots of
microarray spot statistics for the classes \code{"\LinkA{marrayRaw}{marrayRaw}"} and \code{"\LinkA{marrayNorm}{marrayNorm}"}. It also allows the user to highlight and annotate subsets of points on the plot, and display fitted curves from robust local regression or other smoothing procedures.
\end{Description}
\begin{Usage}
\begin{verbatim}
maPlot(m, x="maA", y="maM", z="maPrintTip", lines.func, text.func, legend.func, ...)
\end{verbatim}
\end{Usage}
\begin{Arguments}
\begin{ldescription}
\item[\code{m}] Microarray object of class \code{"\LinkA{marrayRaw}{marrayRaw}"} and \code{"\LinkA{marrayNorm}{marrayNorm}"}.
\item[\code{x}] Name of accessor function for the abscissa spot statistic, typically a slot name for the microarray object \code{m}, such as \code{maA}.
\item[\code{y}] Name of accessor function for the ordinate spot statistic, typically a slot name for the microarray object \code{m}, such as \code{maM}.
\item[\code{z}] Name of accessor method for the spot statistic used to stratify the data, typically a slot name for the microarray layout object (see \code{"\LinkA{marrayLayout}{marrayLayout}"}) such as \code{maPlate} or a method such as \code{maPrintTip}. If \code{z} is NULL, the data are not stratified.
\item[\code{lines.func}] Function for computing and plotting smoothed fits of \code{y} as a function of \code{x}, separately within values of \code{z}, e.g. \code{\LinkA{maLoessLines}{maLoessLines}}. If \code{lines.func} is NULL, no fitting is performed.
\item[\code{text.func}] Function for highlighting a subset of points, e.g., \code{\LinkA{maText}{maText}}. If \code{text.func} is NULL, no points are highlighted.
\item[\code{legend.func}] Function for adding a legend to the plot, e.g. \code{\LinkA{maLegendLines}{maLegendLines}}. If \code{legend.func} is NULL, there is no legend.
\item[\code{...}] Optional graphical parameters, see \code{\LinkA{par}{par}}.
\end{ldescription}
\end{Arguments}
\begin{Details}\relax
This function calls the general function \code{\LinkA{maPlot.func}{maPlot.func}}, which is not specific to microarray data. If there are more than one array in the batch, the plot is done for the first array, by default. Default graphical parameters are chosen for convenience using the function \code{\LinkA{maDefaultPar}{maDefaultPar}} (e.g. color palette,  axis labels,  plot title) but the user has the option to overwrite these parameters at any point.
\end{Details}
\begin{Author}\relax
Sandrine Dudoit, \url{http://www.stat.berkeley.edu/~sandrine}.
\end{Author}
\begin{References}\relax
S. Dudoit and Y. H. Yang. (2002). Bioconductor R packages for exploratory analysis and normalization of cDNA microarray data. In G. Parmigiani, E. S. Garrett, R. A. Irizarry and S. L. Zeger, editors, \emph{The Analysis of Gene Expression Data: Methods and Software}, Springer, New York.
\end{References}
\begin{SeeAlso}\relax
\code{\LinkA{maPlot.func}{maPlot.func}}, \code{\LinkA{maDefaultPar}{maDefaultPar}}, \code{\LinkA{maLoessLines}{maLoessLines}}, \code{\LinkA{maLegendLines}{maLegendLines}}, \code{\LinkA{maText}{maText}}, \code{\LinkA{plot}{plot}}, \code{\LinkA{lowess}{lowess}}, \code{\LinkA{loess}{loess}}, \code{\LinkA{legend}{legend}}.
\end{SeeAlso}
\begin{Examples}
\begin{ExampleCode}

# To see the demo type demo(marrayPlots)

# Examples use swirl dataset, for description type ? swirl
data(swirl)

# - Default arguments
maPlot(swirl)

# Lowess fit using all spots
maPlot(swirl, z=NULL, legend.func=NULL)

# Loess fit using all spots
maPlot(swirl, z=NULL, legend.func=maLegendLines(legend="All spots",col="green"), lines.func=maLoessLines(loess.args=list(span=0.3),col="green"))

# Pre-normalization MA-plot for the Swirl 81 array, with the lowess fits for 
# individual grid columns and 1% tails of M highlighted
defs <- maDefaultPar(swirl[, 1], x = "maA", y = "maM", z = "maGridCol")
legend.func <- do.call("maLegendLines", defs$def.legend)
lines.func <- do.call("maLowessLines", c(list(TRUE, f = 0.3), defs$def.lines))
text.func<-maText(subset=maTop(maM(swirl)[,1],h=0.01,l=0.01), labels="o", col="violet")
maPlot(swirl[, 1], x = "maA", y = "maM", z = "maGridCol", lines.func=lines.func, text.func = text.func, legend.func=legend.func, main = "Swirl array 81: pre-normalization MA-plot")

\end{ExampleCode}
\end{Examples}


