Build a plot layer by layer
Layers
library(ggplot2)
data(Oxboys, package = "nlme")
diamonds = na.omit(diamonds)
msleep = na.omit(msleep)
mtcars = na.omit(mtcars)
Oxboys = na.omit(Oxboys)
p <- ggplot(diamonds, aes(carat, price, colour = cut))
# This plot object cannot be displayed until we add a layer
p <- p + layer(geom = "point")
p
data:image/s3,"s3://crabby-images/ec16d/ec16d52882f539d0e026c1706199f884f5f6e651" alt="plot of chunk ggplot-part3-1"
# Here is what a more complicated call looks like. It produces a histogram
# coloured “steelblue” with a bin width of 2 histogram is a combination of
# bars and binning
p <- ggplot(diamonds, aes(x = carat))
p <- p + layer(geom = "bar", geom_params = list(fill = "steelblue"), stat = "bin",
stat_params = list(binwidth = 2))
p
data:image/s3,"s3://crabby-images/6ae32/6ae32e04534565983528e2189fb334408f4befc6" alt="plot of chunk ggplot-part3-1"
# same as the following command
ggplot(diamonds, aes(x = carat)) + geom_histogram(binwidth = 2, fill = "steelblue")
# The following example shows the equivalence between these two ways of
# making plots
ggplot(msleep, aes(sleep_rem/sleep_total, awake)) + geom_point()
# which is equivalent to
qplot(sleep_rem/sleep_total, awake, data = msleep)
# You can add layers to qplot too:
qplot(sleep_rem/sleep_total, awake, data = msleep) + geom_smooth()
# This is equivalent to
qplot(sleep_rem/sleep_total, awake, data = msleep, geom = c("point", "smooth"))
# or
ggplot(msleep, aes(sleep_rem/sleep_total, awake)) + geom_point() + geom_smooth()
# plot objects can be stored as variables. The summary function can be
# helpful for inspecting the structure of a plot without plotting it
p <- ggplot(msleep, aes(sleep_rem/sleep_total, awake))
summary(p)
data: name, genus, vore, order, conservation, sleep_total,
sleep_rem, sleep_cycle, awake, brainwt, bodywt [20x11]
mapping: x = sleep_rem/sleep_total, y = awake
faceting: facet_null()
p <- p + geom_point()
summary(p)
data: name, genus, vore, order, conservation, sleep_total,
sleep_rem, sleep_cycle, awake, brainwt, bodywt [20x11]
mapping: x = sleep_rem/sleep_total, y = awake
faceting: facet_null()
-----------------------------------
geom_point: na.rm = FALSE
stat_identity:
position_identity: (width = NULL, height = NULL)
# a set of plots can be initialised using different data then enhanced with
# the same layer
bestfit <- geom_smooth(method = "lm", se = F, colour = "steelblue", alpha = 0.5,
size = 2)
qplot(sleep_rem, sleep_total, data = msleep) + bestfit
data:image/s3,"s3://crabby-images/9370e/9370e4ab636562c4d337892235e15eb70e5d71ca" alt="plot of chunk ggplot-part3-2"
qplot(awake, brainwt, data = msleep, log = "y") + bestfit
data:image/s3,"s3://crabby-images/7a7b8/7a7b81e55f1d9d53788d8c86b5f8015088e1144e" alt="plot of chunk ggplot-part3-2"
qplot(bodywt, brainwt, data = msleep, log = "xy") + bestfit
data:image/s3,"s3://crabby-images/5030c/5030c3650e0f37f76430f33293125c0cabea0713" alt="plot of chunk ggplot-part3-2"
Data
# You can replace the old dataset with %+%
p <- ggplot(mtcars, aes(mpg, wt, colour = cyl)) + geom_point()
p
data:image/s3,"s3://crabby-images/64802/64802edabb21572a83ddfe2a94ae4eb25c08b67a" alt="plot of chunk ggplot-part3-3"
mtcars <- transform(mtcars, mpg = mpg^2)
p %+% mtcars
data:image/s3,"s3://crabby-images/30695/30695c321373886b5807d534d952ec4fdeea63a2" alt="plot of chunk ggplot-part3-3"
Aesthetic mappings
Plots and layers
# The **aes** function takes a list of aesthetic-variable pairs aes(x =
# weight, y = height, colour = age)
p <- ggplot(mtcars, aes(x = mpg, y = wt))
p + geom_point()
data:image/s3,"s3://crabby-images/f172f/f172fc3d7f2272ac1a342ccce5724902b5675133" alt="plot of chunk ggplot-part3-4"
# Overriding aesthetics.
p + geom_point(aes(colour = factor(cyl)))
data:image/s3,"s3://crabby-images/21acb/21acb2b6671a06287bd49e0ddbde74ae1049127f" alt="plot of chunk ggplot-part3-4"
# overriding y-position (now y is 'disp',although the y lab is still 'wt')
p + geom_point(aes(y = disp))
data:image/s3,"s3://crabby-images/5b24c/5b24c5677db6d44f577dc153790c29fdf70bec21" alt="plot of chunk ggplot-part3-4"
Setting vs. mapping
# The difference between setting colour to 'darkblue' and mapping colour to
# 'darkblue'.
p <- ggplot(mtcars, aes(mpg, wt))
p + geom_point(colour = "darkblue") # setting
data:image/s3,"s3://crabby-images/a9380/a93806434b25a2d1bf04f4d60b0ec556f01709b9" alt="plot of chunk ggplot-part3-5"
# This sets the point colour to be dark blue instead of black. This is quite
# different than
p + geom_point(aes(colour = "darkblue")) # mapping
data:image/s3,"s3://crabby-images/66015/66015f3f71113c10f4df6232fd1b4f0dfac12836" alt="plot of chunk ggplot-part3-5"
# qplot
qplot(mpg, wt, data = mtcars, colour = I("darkblue")) # setting
qplot(mpg, wt, data = mtcars, colour = "darkblue") # mapping
Grouping
Multiple groups, one aesthetic
# Correctly specifying produces one line per subject.
p <- ggplot(Oxboys, aes(age, height, group = Subject)) + geom_line()
p
data:image/s3,"s3://crabby-images/25ac0/25ac0d8330e3efacf08304965b0364131a8ad6c0" alt="plot of chunk ggplot-part3-6"
qplot(age, height, data = Oxboys, group = Subject, geom = "line")
# A single line connects all observations. This pattern is characteristic
# of an **incorrect** grouping aesthetic, and is what we see if the group
# aesthetic is omitted, which in this case is equivalent to group = 1
ggplot(Oxboys, aes(age, height, group = 1)) + geom_line()
data:image/s3,"s3://crabby-images/f595b/f595b776313e0007f9c41f652095019e87103b3b" alt="plot of chunk ggplot-part3-7"
qplot(age, height, data = Oxboys, geom = "line")
Different groups on different layers
# Adding smooths to the Oxboys data. Using the same grouping as the lines
# results in a line of best fit for each boy.
p + geom_smooth(aes(group = Subject), method = "lm", se = F)
data:image/s3,"s3://crabby-images/f1123/f1123a8a26d437af92e878d89289825509363d85" alt="plot of chunk ggplot-part3-8"
# or
qplot(age, height, data = Oxboys, group = Subject, geom = "line") + geom_smooth(method = "lm",
se = F)
# Using aes(group = 1) in the smooth layer fits a single line of best fit
# across all boys.
p + geom_smooth(aes(group = 1), method = "lm", size = 2, se = F)
data:image/s3,"s3://crabby-images/10e08/10e08bd0933194e5ecb40b0cfae7aa2c7fd2d7ff" alt="plot of chunk ggplot-part3-9"
qplot(age, height, data = Oxboys, group = Subject, geom = "line") + geom_smooth(aes(group = 1),
method = "lm", size = 2, se = F)
Further reading