实验7:高级绘图(上)
一:实验目的与要求
1:了解R语言中各种图形元素的添加方法,并能够灵活应用这些元素。
2:了解R语言中的各种图形函数,掌握常见图形的绘制方法。
二:实验内容
【lattice包绘图】
Eg.1:以mtcars数据集为例,绘制车身重量(wt)与每加仑汽油行驶的英里数(mpg)的散点图
|-------------------------------------------------------------------------------------------------------------------------|
| library('lattice') xyplot(wt ~ mpg, data = mtcars, xlab = 'Weight', ylab = 'Miles per Gallon', main = 'lattice包绘制散点图') |
data:image/s3,"s3://crabby-images/bbcc0/bbcc01c064c8a1f878a98491f6c5b16ac4220ea9" alt=""
Eg.2:查看参数列表名称
|--------------------------|
| names(trellis.par.get()) |
data:image/s3,"s3://crabby-images/c4fe9/c4fe9d001dadd9b28ba55b4c6d120ab0609f719d" alt=""
Eg.3:fontsize查看字体大小和散点大小的参数
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| op <- trellis.par.get() trellis.par.get('fontsize') trellis.par.set(fontsize = list(text = 20, points = 20)) xyplot(wt ~ mpg, data = mtcars, xlab = 'Weight', ylab = 'Miles per Gallon', main = 'lattice包绘制散点图') trellis.par.set(op) |
data:image/s3,"s3://crabby-images/c920b/c920bd7d50de5a5c5017b828ab5b20854a77a59e" alt=""
data:image/s3,"s3://crabby-images/00731/00731832fceae3810ceb28178d6632ba9861998d" alt=""
Eg.4:图形化显示所有参数
|-----------------|
| show.settings() |
data:image/s3,"s3://crabby-images/52cf2/52cf22861e6c85526f5fe116478d3c926b92c8ef" alt=""
Eg.5:以Species(鸢尾花种类)为条件变量绘制Sepal.Length(花萼长度)与Sepal.Width(花萼宽度)的散点图
|-------------------------------------------------------------------------------------------|
| library(lattice) attach(iris) xyplot(Sepal.Length ~ Sepal.Width | Species) detach(iris) |
data:image/s3,"s3://crabby-images/2fbcd/2fbcd3d925945efda90a6adae414066a3c906fe2" alt=""
Eg.6:面板函数
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| my_panel <- function(x,y){ panel.lmline(x, y, col = "red", lwd = 1, lty = 2) panel.loess(x,y) panel.grid(h = -1, v = -1) panel.rug(x, y) panel.xyplot(x, y) } xyplot(mpg ~ wt, data = mtcars, xlab = "Weight", ylab = "Miles per Gallon",main = "Miles per Gallon on Weight", panel = my_panel) |
data:image/s3,"s3://crabby-images/b2acc/b2accf149bd64b2e4cb261ae50265ad29e4732ff" alt=""
Eg.7:分组变量
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| xyplot(Sepal.Length ~ Sepal.Width, group = Species, data = iris,pch = 1:3, col = 1:3, main = 'Sepal.Length VS Sepal.Width', key = list(space = "right", title = "Species", cex.title = 1, cex = 1, text = list(levels(factor(iris$Species))), points=list(pch = 1:3, col= 1:3))) |
data:image/s3,"s3://crabby-images/4ad17/4ad17899102cb69f78607cc5d224788b1541f064" alt=""
Eg.8:图形组合
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| graph1 <- xyplot(Sepal.Length ~ Sepal.Width | Species, data = iris, main = '栅栏图') graph2 <- xyplot(Sepal.Length ~ Sepal.Width, group = Species, data = iris, main = '散点图1') graph3 <- xyplot(Petal.Length ~ Petal.Width, group = Species, data = iris, main = '散点图2') # split函数 plot(graph1, split = c(1,1,3,1)) plot(graph2, split = c(2,1,3,1),newpage=F) plot(graph2, split = c(3,1,3,1),newpage=F) # position函数 plot(graph1, position = c(0, 0, 1/3, 1)) plot(graph2, position = c(1/3, 0, 2/3, 1), newpage = F) plot(graph3, position = c(2/3, 0, 1, 1), newpage = F) |
data:image/s3,"s3://crabby-images/bf7f9/bf7f9146ad04c6be0bbe5ec58de0ccd1be5b0804" alt=""
Eg.9:条形图
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| barchart(VADeaths, main = 'Death Rates in 1940 Virginia(By Group)') barchart(VADeaths, groups = FALSE, main = list("Death Rates in 1940 Virginia", cex = 1.2)) |
data:image/s3,"s3://crabby-images/73122/7312208fc466df0fba3ed3fe884f82ac59f678eb" alt=""
data:image/s3,"s3://crabby-images/8f09e/8f09e2f1862786d4745fb6fdea24681651f73585" alt=""
Eg.10:泰塔尼克号航行中不同人群获救与否的人数情况
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| str(Titanic) as.data.frame(Titanic) pic1 <- barchart(Class ~ Freq|Age + Sex, data = as.data.frame(Titanic), groups = Survived, stack = TRUE, auto.key = list(title = "Survived", columns = 2)) pic2 <- barchart(Class ~ Freq|Age + Sex, data = as.data.frame(Titanic), groups = Survived, stack = TRUE, auto.key = list(title = "Survived", columns = 2), scales = list(x = "free")) pic3 <- update(pic2, panel=function(...){ panel.grid(h=0,v=-1) panel.barchart(...,border = "Transparent") }) plot(pic1, split = c(1,1,3,1)) plot(pic2, split = c(2,1,3,1), newpage = FALSE) plot(pic3, split = c(3,1,3,1), newpage = FALSE) |
data:image/s3,"s3://crabby-images/edbdc/edbdc7c6e9c35087c08ff2f760331b8a329e3209" alt=""
data:image/s3,"s3://crabby-images/b6c49/b6c49ab225274c0e39b74c4f30e727f8cb3d16e5" alt=""
data:image/s3,"s3://crabby-images/6480a/6480a83efffa3d2016484dc8b7db775f42e44a81" alt=""
Eg.11:点图
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dotplot(VADeaths, pch = 1:4, xlab = 'Death rates per 1000', main = list('Death Rates in 1940 Virginia (By Group)', cex = 0.8), key = list(column = 4, text = list(colnames(VADeaths)), points = list(pch = 1:4, col =1:4))) dotplot(VADeaths, group = FALSE, xlab = 'Death rates per 1000',main = list('Death Rates in 1940 Virginia', cex = 0.8)) |
data:image/s3,"s3://crabby-images/64481/644815900a93d38d3e576340bc83fdfe92dbdc18" alt=""
data:image/s3,"s3://crabby-images/77e23/77e23a65641501839911dc501f1d49811712a067" alt=""
Eg.12:直方图
|---------------------------------------------------------------------------------------------------------|
| histogram( ~ height | voice.part, data = singer, nint = 17, layout = c(1,8), xlab = "Height(inches)") |
data:image/s3,"s3://crabby-images/7e962/7e962f25a5f66034d00bfb131a4b4197957382be" alt=""
Eg.13:核密度图
|----------------------------------------------------------------------------------------------------------------------------------------------------|
| densityplot( ~ height | voice.part, data = singer, layout=c(1, 8), xlab = "Height (inches)",main = "Heights of New York Choral Society singers") |
data:image/s3,"s3://crabby-images/3a956/3a956cec739eb139de7210ba47f5fbf09966e9d4" alt=""
Eg.14:叠加核密度图
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| densityplot( ~ height, group = voice.part, data = singer, xlab = "Height (inches)" , plot.points = FALSE,main = "Heights of New York Choral Society singers", lty = 1:8, col = 1:8, lwd = 1.5,key = list(text = list(levels(singer$voice.part)), column = 4, lines = list(lty = 1:8, col = 1:8))) |
data:image/s3,"s3://crabby-images/a1f72/a1f729ae48920e3b17442894c38f6e43c90bddcd" alt=""
Eg.15:添加核密度图
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| histogram( ~ height | voice.part, data = singer, xlab = "Height (inches)", type = "density", panel = function(x, ...) { panel.histogram(x, ...) panel.mathdensity(dmath = dnorm, col = "black", args = list(mean=mean(x),sd=sd(x))) }) |
data:image/s3,"s3://crabby-images/39a78/39a78a78c4a6f17ab4e6a71a8a844f03475b2516" alt=""
Eg.16:带状图
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| nrow(singer[singer$voice.part == 'Bass 2', ]) stripplot(~ height, group = voice.part, data = singer, xlab = "Height (inches)", main = "Heights of New York Choral Society singers", subset = (voice.part == "Bass 2"),jitter.data=T) |
data:image/s3,"s3://crabby-images/9fe6c/9fe6c12036803aee88e05c1c35183c06cd348896" alt=""
Eg.17:QQ图
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| qqmath(~ height | voice.part, data = singer, prepanel = prepanel.qqmathline, panel = function(x, ...) { panel.qqmathline(x, ...) panel.qqmath(x, ...) }) qq(voice.part ~ height, aspect = 1, data = singer,subset = (voice.part == "Bass 2" | voice.part == "Tenor 2")) |
data:image/s3,"s3://crabby-images/d46ed/d46ede50c6ce8232f434b3ab1250be0e8b47d65d" alt=""
data:image/s3,"s3://crabby-images/e4518/e45186f671bb2418b016d218db66574adc0282e0" alt=""
Eg.18:箱线图
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pic1 <- bwplot( ~ height | voice.part, data=singer, xlab="Height (inches)") pic2 <- bwplot(voice.part ~ height, data=singer, xlab="Height (inches)") plot(pic1, split = c(1, 1, 2, 1)) plot(pic2, split = c(2, 1, 2, 1), newpage = FALSE) |
data:image/s3,"s3://crabby-images/a4291/a4291e513018ecee56119ab00e74977b1fbe6a11" alt=""
Eg.19:散点图
|------------------------------------------------------|
| xyplot(Sepal.Length~Sepal.Width|Species,data=iris) |
data:image/s3,"s3://crabby-images/450b0/450b0aacc485d629a2060287bf8d4f665a0414ff" alt=""
Eg.20:散点矩阵图
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| splom(iris[, 1:4], groups = irisSpecies, pscales = 0, pch = 1:3, col = 1:3, varnames = colnames(iris)\[1:4\],key = list(columns = 3, text = list(levels(irisSpecies)), points = list(pch = 1:3, col = 1:3))) |
data:image/s3,"s3://crabby-images/62d6a/62d6ad73050bd21c1cf1a278152b195bcdad0d99" alt=""
Eg.21:三维水平图
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| data(Cars93, package = "MASS") cor.Cars93 <-cor(Cars93[, !sapply(Cars93, is.factor)], use = "pair") levelplot(cor.Cars93, scales = list(x=list(rot=90))) |
data:image/s3,"s3://crabby-images/f0526/f0526644101772b615f9408a854cea844fb256dc" alt=""
Eg.22:三维等高线
|---------------------------------|
| contourplot(volcano, cuts = 20) |
data:image/s3,"s3://crabby-images/53015/53015d342ec0e55fe95a453018407464460337ca" alt=""
Eg.23:三维散点图
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| par.set <-list(axis.line = list(col = "transparent"), clip = list(panel = "off")) # 去除边框,不削减面板范围 cloud(Sepal.Length ~ Petal.Length * Petal.Width, data = iris, groups = Species, pch = 1:3,col= 1:3, # 点颜色及样式 screen = list(z = 20, x = -70, y =0), # 调节三维散点图的展示角度 par.settings = par.set, scales = list(col = "black"), # 加箭头指示 key=list(column=3, text=list(levels(iris$Species)), points = list(pch = 1:3, col = 1:3))) |
data:image/s3,"s3://crabby-images/b0e10/b0e10149c107343c375ef291478914e931ba0531" alt=""
Eg.24:三维曲面图
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| par.set <-list(axis.line = list(col = "transparent"), clip = list(panel = "off")) # 去除边框,不削减面板范围 wireframe(volcano, shade = TRUE, par.settings = par.set, aspect = c(61/87, 0.4)) |
data:image/s3,"s3://crabby-images/b3e63/b3e63d04d9339e438929e0176a46cd4b7dc2010e" alt=""
【ggplot2包绘图】
Eg.1:qplot函数
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| library(ggplot2) qplot(Species, Sepal.Length, data = iris, geom = "boxplot", fill = Species,main = "依据种类分组的花萼长度箱线图") qplot(Species, Sepal.Length, data = iris, geom = c("violin", "jitter"), fill = Species,main = "依据种类分组的花萼长度小提琴图") qplot(Sepal.Length, Sepal.Width, data = iris, colour = Species, shape = Species,main = "绘制花萼长度和花萼宽度的散点图") qplot(Sepal.Length, Sepal.Width, data = iris, geom = c("point", "smooth"), facets = ~Species,colour = Species, main = "绘制分面板的散点图") |
data:image/s3,"s3://crabby-images/d1497/d149791090a1fafb3a35071e1fd7fa79cbd5b742" alt=""
data:image/s3,"s3://crabby-images/edde6/edde6f6a76e14f0aabaa79e70a88ea21dcfd9d6e" alt=""
data:image/s3,"s3://crabby-images/1a021/1a021b0974a9567dc59f3657aad025b26c915d7f" alt=""
data:image/s3,"s3://crabby-images/1c679/1c679c2bc23f20b03213b1f59b2044ee8380cc24" alt=""
Eg.2:语言逻辑
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| plot(irisSepal.Length, irisSepal.Width) library(ggplot2) ggplot(data= iris, aes(x = Sepal.Length, y = Sepal.Width)) + #绘制底层画布 geom_point(color = "darkred") #在画布上添加点 |
data:image/s3,"s3://crabby-images/9a1da/9a1da257ee9973e950758d66c9854075ab0c317c" alt=""
data:image/s3,"s3://crabby-images/8012d/8012d954019896cc314e67b4a55e0a684315cac3" alt=""
Eg.3:绘制画布
|------------------------------------------------------------------------------------------------|
| ggplot(data = iris, aes(x = Sepal.Length, y = Sepal.Width, colour = Species, shape = Species)) |
data:image/s3,"s3://crabby-images/d4da6/d4da61343efb0f92d88adc7252a3e93c774a3570" alt=""
Eg.4:几何对象
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| # 方法1 ggplot(data = iris, aes(x = Sepal.Length, y = Sepal.Width, colour = Species, shape = Species))+geom_point() # 方法2 ggplot(data = iris) + geom_point(aes(x = Sepal.Length, y = Sepal.Width, colour = Species, shape = Species)) |
data:image/s3,"s3://crabby-images/f0ee4/f0ee4159e1762198468001e00231b6e804828bfe" alt=""
Eg.5:统计变换
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| # 方法1 ggplot(iris) + geom_bar(aes(x=Sepal.Length), stat="bin", binwidth = 0.5) # 方法2 ggplot(iris) + stat_bin(aes(x=Sepal.Length), geom="bar", binwidth = 0.5) |
data:image/s3,"s3://crabby-images/4cbdb/4cbdbc84968327c89ce020d9b4c394d1450e93ae" alt=""
Eg.6:标尺设置
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| set.seed(1234) # 设置随机种子 my_iris <- iris[sample(1:150, 100, replace = FALSE),] # 随机抽样 p <- ggplot(my_iris) + geom_bar(aes(x = Species, fill = Species)) p # 左图 p$scales # 查看p的标尺参数 p + scale_fill_manual( values = c("orange", "olivedrab", "navy"), # 颜色设置 breaks = c("setosa", "versicolor", "virginica"), # 图例和轴要显示的分段点 name = "my_Species", # 图例和轴使用的名称 labels = c("set", "ver", "vir") # 图例使用的标签 ) # 右图 |
data:image/s3,"s3://crabby-images/bf75f/bf75f04869a5ee6e616a507f618b424e737144dc" alt=""
data:image/s3,"s3://crabby-images/69a4a/69a4a3cec4682e5c83a4c5513c50dc948a21ff23" alt=""
Eg.7:修改图形的颜色
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, colour = Species))+ scale_color_manual(values = c("orange", "olivedrab", "navy"))+ geom_point(size = 2) ggplot(iris,aes(x = Sepal.Length, y = Sepal.Width, colour = Species))+ scale_color_brewer(palette = "Set1")+ geom_point(size=2) |
data:image/s3,"s3://crabby-images/f024f/f024f602eebcef9e7ef5a044ab8581ff525b3d4f" alt=""
data:image/s3,"s3://crabby-images/bbb61/bbb61d5e1ebf87d9dc3bc1087ea3470a5d115e03" alt=""
Eg.8:坐标系转换
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| # 饼图 = 堆叠长条图 + polar coordinates pie <- ggplot(my_iris, aes(x = factor(1), fill = Species)) +geom_bar(width = 1) pie + coord_polar(theta = "y") # 靶心图 = 饼图 + polar coordinates pie + coord_polar() #锯齿图 = 柱状图 + polar coordinates cxc <- ggplot(my_iris, aes(x = Species)) +geom_bar(width = 1, colour = "black") cxc + coord_polar() |
data:image/s3,"s3://crabby-images/43bd5/43bd544700bda8fe71218425ac113a632e4500b2" alt=""
data:image/s3,"s3://crabby-images/91814/91814485fb59f2df65fbcc83eb990ff117a8c47e" alt=""
data:image/s3,"s3://crabby-images/7ac6b/7ac6bce86bb06877d4ba1bd15f0ed34e2f7ad661" alt=""
Eg.9:分面
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| library(ggplot2) library(tidyr) library(dplyr) my_iris1 <- iris %>% gather(feature_name, feature_value, one_of(c("Sepal.Length", "Sepal.Width", "Petal.Length", "Petal.Width"))) # 数据变换 ggplot(my_iris1) +geom_violin(aes(x = Species, y = feature_value)) + facet_grid(feature_name ~ Species, scales = "free") # 分面 |
data:image/s3,"s3://crabby-images/fbbe1/fbbe134d7e655eae8dcdb5353c846143e4addf10" alt=""
Eg.10:facet-wrap函数
|------------------------------------------------------------------------------------------------------------------------------|
| ggplot(my_iris1) + geom_violin(aes(x = Species, y = feature_value)) + facet_wrap(~ feature_name + Species, scales = "free") |
data:image/s3,"s3://crabby-images/7be7a/7be7ae941df61c7e27cad1f97f0dcea6730deb7b" alt=""
Eg.11:保存图形
|-------------------------------------------------------------------------------------------------------------------------------------------------|
| ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, colour = Species))+geom_point(size = 2) ggsave(file = "mygraph.pdf", width = 5, height = 4) |
data:image/s3,"s3://crabby-images/0f2f5/0f2f5fe47780efda4a9d8a33af1371f99da448e0" alt=""
data:image/s3,"s3://crabby-images/ec6a6/ec6a6d50fa5a9fe739bddc39a67903855b761708" alt=""