forked from tidyverse/ggplot2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathggplot.Rd
85 lines (80 loc) · 3.12 KB
/
ggplot.Rd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
\name{ggplot}
\alias{ggplot}
\title{Create a new ggplot plot}
\usage{
ggplot(data = NULL, ...)
}
\arguments{
\item{data}{default data set}
\item{...}{other arguments passed to specific methods}
}
\description{
\code{ggplot()} initializes a ggplot object. It can be
used to declare the input data frame for a graphic and to
specify the set of plot aesthetics intended to be common
throughout all subsequent layers unless specifically
overridden.
}
\details{
\code{ggplot()} is typically used to construct a plot
incrementally, using the + operator to add layers to the
existing ggplot object. This is advantageous in that the
code is explicit about which layers are added and the
order in which they are added. For complex graphics with
multiple layers, initialization with \code{ggplot} is
recommended.
There are three common ways to invoke \code{ggplot}:
\itemize{ \item \code{ggplot(df, aes(x, y, <other
aesthetics>))} \item \code{ggplot(df)} \item
\code{ggplot()} } The first method is recommended if all
layers use the same data and the same set of aesthetics,
although this method can also be used to add a layer
using data from another data frame. See the first example
below. The second method specifies the default data frame
to use for the plot, but no aesthetics are defined up
front. This is useful when one data frame is used
predominantly as layers are added, but the aesthetics may
vary from one layer to another. The third method
initializes a skeleton \code{ggplot} object which is
fleshed out as layers are added. This method is useful
when multiple data frames are used to produce different
layers, as is often the case in complex graphics.
The examples below illustrate how these methods of
invoking \code{ggplot} can be used in constructing a
graphic.
}
\examples{
df <- data.frame(gp = factor(rep(letters[1:3], each = 10)),
y = rnorm(30))
# Compute sample mean and standard deviation in each group
library(plyr)
ds <- ddply(df, .(gp), summarise, mean = mean(y), sd = sd(y))
# Declare the data frame and common aesthetics.
# The summary data frame ds is used to plot
# larger red points in a second geom_point() layer.
# If the data = argument is not specified, it uses the
# declared data frame from ggplot(); ditto for the aesthetics.
ggplot(df, aes(x = gp, y = y)) +
geom_point() +
geom_point(data = ds, aes(y = mean),
colour = 'red', size = 3)
# Same plot as above, declaring only the data frame in ggplot().
# Note how the x and y aesthetics must now be declared in
# each geom_point() layer.
ggplot(df) +
geom_point(aes(x = gp, y = y)) +
geom_point(data = ds, aes(x = gp, y = mean),
colour = 'red', size = 3)
# Set up a skeleton ggplot object and add layers:
ggplot() +
geom_point(data = df, aes(x = gp, y = y)) +
geom_point(data = ds, aes(x = gp, y = mean),
colour = 'red', size = 3) +
geom_errorbar(data = ds, aes(x = gp, y = mean,
ymin = mean - sd, ymax = mean + sd),
colour = 'red', width = 0.4)
}
\seealso{
\url{http://had.co.nz/ggplot2}
}
\keyword{internal}