introduction to ggplot2 from Wickham and Grolemund' chapter 1
#scatterplot
#build coordinate system at global level, and geom_ function at local level
library(ggplot2)
ggplot(data = mpg)+
geom_point(mapping = aes(x=displ, y=hwy))
data:image/s3,"s3://crabby-images/b0e47/b0e47740a7f6d09445c2eac1941cd5edfd6d5e77" alt=""
g <- ggplot(data = mpg)
g+geom_point(mapping = aes(x=displ, y=hwy, color=class))
data:image/s3,"s3://crabby-images/b619c/b619ca0e04e7c6492a16f3e9fd961557bf9b3bb6" alt=""
g+geom_point(aes(x=displ, y=hwy, size=class))
## Warning: Using size for a discrete variable is not advised.
data:image/s3,"s3://crabby-images/eba98/eba9829cd903e525a4f012e5ccbfce78186f2f6d" alt=""
g+geom_point(aes(x=displ, y=hwy, alpha=class))
## Warning: Using alpha for a discrete variable is not advised.
data:image/s3,"s3://crabby-images/fbed6/fbed6601cd7e45b574e2c39962f3675a6112ed4f" alt=""
g+geom_point(aes(x=displ, y=hwy, shape=class)) #the 7th category is not plotted
## Warning: The shape palette can deal with a maximum of 6 discrete values because more than 6 becomes difficult to
## discriminate; you have 7. Consider specifying shapes manually if you must have them.
## Warning: Removed 62 rows containing missing values (geom_point).
data:image/s3,"s3://crabby-images/5405e/5405e6be3d4e045780f8d38970f7db51a6795942" alt=""
g+geom_point(aes(x=displ, y=hwy), color="blue")
data:image/s3,"s3://crabby-images/9ebad/9ebad9143da856ac99995762646043e7fc550a8e" alt=""
#facets
g+geom_point(aes(x=displ, y=hwy))+
facet_wrap(~class, nrow=2)
data:image/s3,"s3://crabby-images/bd258/bd258631e89b06cded5ac0e7a557ab8d1a7c479a" alt=""
g+geom_point(aes(x=displ, y=hwy))+
facet_wrap(~class) #by default nrow=3
data:image/s3,"s3://crabby-images/b8099/b809947343d480578f8741ee63da21b39c4b2ed1" alt=""
g+geom_point(aes(x=displ, y=hwy))+
facet_grid(~class)
data:image/s3,"s3://crabby-images/7c733/7c73385020cb907e9041427182bd15122660076c" alt=""
g+geom_point(aes(x=displ, y=hwy))+
facet_grid(drv ~ cyl)
data:image/s3,"s3://crabby-images/f9582/f95820e000f896286740bf94d0bd5b4702db6feb" alt=""
g+geom_point(aes(x=displ, y=hwy))+
facet_grid(. ~ cyl)
data:image/s3,"s3://crabby-images/d562b/d562b8f6d8a583a74720275570ce2055443f4ec6" alt=""
g+geom_point(aes(x=displ, y=hwy))+
facet_grid(drv ~ .)
data:image/s3,"s3://crabby-images/770d4/770d4f4757f95481324109ec4b106add1dd2aafa" alt=""
g+geom_point(aes(x=displ, y=hwy))+
facet_wrap(drv ~ .)
data:image/s3,"s3://crabby-images/936f4/936f42663d5fc4c3c31f7c5ee1fdc39f2d490c1b" alt=""
g+geom_point(aes(x=displ, y=hwy))+
facet_grid(. ~ drv)
data:image/s3,"s3://crabby-images/a761e/a761e2430646d1b7881f39fc4c9f7f58f603b134" alt=""
#lines (use of group, color, and linetype)
#by default, geom_smooth use method="loess"
g+geom_point(aes(x=displ, y=hwy))
data:image/s3,"s3://crabby-images/9a6d3/9a6d388297678880de7dd27bb03ad3abc89e0d17" alt=""
g+geom_smooth(aes(x=displ, y=hwy))
## `geom_smooth()` using method = 'loess' and formula 'y ~ x'
data:image/s3,"s3://crabby-images/5ed7b/5ed7b6561c045214b9ad503e2ad297c4f3f3796a" alt=""
g+geom_smooth(aes(x=displ, y=hwy, linetype=drv)) #with legend
## `geom_smooth()` using method = 'loess' and formula 'y ~ x'
data:image/s3,"s3://crabby-images/9ab38/9ab3814d4bb183dd31453b4af6b9c2a06a28ae8e" alt=""
g+geom_point(aes(x=displ, y=hwy))+
geom_smooth(aes(x=displ, y=hwy))
## `geom_smooth()` using method = 'loess' and formula 'y ~ x'
data:image/s3,"s3://crabby-images/207c9/207c97adea5655abfd80e832b484cc125ecb42ce" alt=""
g+geom_point(aes(x=displ, y=hwy))+
geom_smooth(aes(x=displ, y=hwy, group=drv),
show.legend = T) #do not add legend
## `geom_smooth()` using method = 'loess' and formula 'y ~ x'
data:image/s3,"s3://crabby-images/93c92/93c92a1f61025cf07403579af07aeef1edfeb4f4" alt=""
#local level
#g+geom_point(aes(x=displ, y=hwy))+
# geom_smooth(aes(group=drv),
# show.legend = T)
g+geom_point(aes(x=displ, y=hwy))+
geom_smooth(aes(x=displ, y=hwy, color=drv),
show.legend = T)
## `geom_smooth()` using method = 'loess' and formula 'y ~ x'
data:image/s3,"s3://crabby-images/f0105/f01051759c2192827ab401acbef96438dabc9471" alt=""
g <- ggplot(data = mpg, mapping = aes(x=displ, y=hwy))
g+geom_point()+geom_smooth()
## `geom_smooth()` using method = 'loess' and formula 'y ~ x'
data:image/s3,"s3://crabby-images/8e4ec/8e4ec0767bbbbca1cb2b084c6bc6e55d5b1c85ec" alt=""
g+geom_point(aes(color=class))+geom_smooth()
## `geom_smooth()` using method = 'loess' and formula 'y ~ x'
data:image/s3,"s3://crabby-images/b9132/b91324fbc6e7414d3915b2839e46cb9e9ea10c24" alt=""
#g+geom_point(aes(color=class))+geom_smooth(
# data = filter(mpg, class=="subcompact"),
# se=FALSE,
# method = "lm"
#)
ggplot(data = diamonds)+
stat_count(mapping = aes(x=cut))
data:image/s3,"s3://crabby-images/a9fbb/a9fbb2064a327dfe3e8c2e18a312c8a94e6ca6b2" alt=""
ggplot(data = diamonds)+
geom_bar(mapping = aes(x=cut))
data:image/s3,"s3://crabby-images/fb744/fb7448653aac97dfdf098939aa2a0d557cc10fe1" alt=""
#ggplot(data = diamonds)+
# geom_histogram(mapping = aes(x=cut))#do not work; x needs to be a continuous variable
ggplot(data = diamonds)+
geom_histogram(mapping = aes(x=cut), stat = "count")
## Warning: Ignoring unknown parameters: binwidth, bins, pad
data:image/s3,"s3://crabby-images/3a933/3a93346b9d315c51c3c31c8877f1bff2f03875f7" alt=""
ggplot(data = diamonds)+
stat_summary(mapping = aes(x=cut, y=depth),
fun.ymax = max,
fun.ymin = min,
fun.y = median)
## Warning: `fun.y` is deprecated. Use `fun` instead.
## Warning: `fun.ymin` is deprecated. Use `fun.min` instead.
## Warning: `fun.ymax` is deprecated. Use `fun.max` instead.
data:image/s3,"s3://crabby-images/789cc/789ccc061b3c6db014caf44fd483ee597584e64d" alt=""
?stat_summary
#position adjustments
ggplot(data = diamonds)+
geom_bar(mapping = aes(x=cut, color=cut))
data:image/s3,"s3://crabby-images/8818d/8818d6d1580e539068185cde3c18e70fbca39586" alt=""
ggplot(data = diamonds)+
geom_bar(mapping = aes(x=cut, fill=cut))
data:image/s3,"s3://crabby-images/b5cd9/b5cd9253258dab5bc6dc7fb495f8fb58fea351ae" alt=""
ggplot(data = diamonds)+
geom_bar(mapping = aes(x=cut, fill=clarity))
data:image/s3,"s3://crabby-images/43822/43822e8939d153dc63fe866da39d413c3381b34d" alt=""
#position
ggplot(data = diamonds,
mapping = aes(x=cut, fill=clarity))+
geom_bar(alpha=1/5, position = "identity")
data:image/s3,"s3://crabby-images/76fd6/76fd6d44b50e4415f8f4e79ce6471e4850259619" alt=""
ggplot(data = diamonds,
mapping = aes(x=cut, color=clarity))+
geom_bar(fill=NA, position = "identity")
data:image/s3,"s3://crabby-images/56f9c/56f9c138d0507bf5f76786e610214d9973807e9a" alt=""
#position=fill - stacking
ggplot(data = diamonds)+
geom_bar(mapping = aes(x=cut, fill=clarity),
position = "fill")
data:image/s3,"s3://crabby-images/07cbc/07cbc2b28bc12fd80b2536070b7a0daab3033273" alt=""
#dodge-besides each other
ggplot(data = diamonds)+
geom_bar(mapping = aes(x=cut, fill=clarity),
position = "dodge")
data:image/s3,"s3://crabby-images/52d45/52d459fbd9a728fb77a907276be7528064ae27ad" alt=""
#add some random noise
table(mpg$displ)
##
## 1.6 1.8 1.9 2 2.2 2.4 2.5 2.7 2.8 3 3.1 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4 4.2 4.4 4.6 4.7 5 5.2 5.3 5.4 5.6 5.7 5.9
## 5 14 3 21 6 13 20 8 10 8 6 9 4 5 2 3 8 3 15 4 1 11 17 2 5 6 8 1 8 2
## 6 6.1 6.2 6.5 7
## 1 1 2 1 1
ggplot(data = mpg)+
geom_point(mapping = aes(x=displ, y=hwy),
position = "jitter")
data:image/s3,"s3://crabby-images/f6d9e/f6d9e6abcc3a01ffdf33ff2cc6c495286f6f3602" alt=""
#coordinate system
ggplot(data = mpg, mapping = aes(x=class, y=hwy))+
geom_boxplot()
data:image/s3,"s3://crabby-images/75226/752263d8f0e79f779d19f85fb1d64941180150d7" alt=""
ggplot(data = mpg, mapping = aes(x=class, y=hwy))+
geom_boxplot()+
coord_flip()
data:image/s3,"s3://crabby-images/82c01/82c01176635776379dad6e334c5e03b3eba414e3" alt=""
nz<- map_data("nz")
ggplot(nz, aes(long, lat, group=group))+
geom_polygon(fill="white", color="black")
data:image/s3,"s3://crabby-images/d5a12/d5a129ac84e9e462a43594057afc7d3f109610a2" alt=""
#coord_quickmap() sets the aspect ratio correctly
ggplot(nz, aes(long, lat, group=group))+
geom_polygon(fill="white", color="black")+
coord_quickmap()
data:image/s3,"s3://crabby-images/74f0d/74f0d7f713e90239a8c4fd60bdf5996614d8f8c9" alt=""
bar <- ggplot(data = diamonds)+
geom_bar(mapping = aes(x=cut, fill=cut),
show.legend = F, #don't add legend
width = 1)+
theme(aspect.ratio = 1)+
labs(x=NULL, y=NULL) #don't add anything on x,y-axis
bar+coord_flip()
data:image/s3,"s3://crabby-images/3c2bb/3c2bbfd822f1bf4958032cccd517e4ab0b770d20" alt=""
data:image/s3,"s3://crabby-images/1eb0c/1eb0ce0b7f1cd0ae2419a73d6c5ed352d276c5d4" alt=""