高级图形进阶
1、lattice
data:image/s3,"s3://crabby-images/ca7c4/ca7c4b09cc8fa5bdb3155281ec801ed4476110e7" alt=""
data:image/s3,"s3://crabby-images/572b5/572b5ee913bac4a91b1ad036308fa123829722a6" alt=""
1 2 3 4 5 6 7
| library(lattice) histogram(~height|voice.part, data = singer, main="合唱团身高和声部的分布", xlab="身高(英尺)")
|
data:image/s3,"s3://crabby-images/9087b/9087b3dfe6692fe0ebac254fb5806b45e564b235" alt=""
1 2 3 4 5 6 7 8 9
| library(lattice) attach(mtcars) gearPlot <- factor(mtcars$gear, levels = c(3, 4, 5), labels = c("3 gears", "4 gears", "5 gears")) plot(gearPlot)
|
data:image/s3,"s3://crabby-images/aca7e/aca7eafaf4a8b8183c872e7a822083b787672885" alt=""
1 2 3
| cylPlot <- factor(mtcars$cyl, levels = c(4, 6, 8), labels = c("4 cylinders", "6 cylinders", "8 cylinders")) plot(cylPlot)
|
data:image/s3,"s3://crabby-images/2d60d/2d60d40d1d55f757c837089ba8e22c30b085d1c3" alt=""
1 2
| densityplot(~mpg, main = "核密度图", xlab = "每加仑的英里数")
|
data:image/s3,"s3://crabby-images/bd394/bd3949adaa030990b1ebded6cfae28a2ebd585c5" alt=""
1 2 3
| densityplot(~mpg | cyl, main = "各气缸的核密度图", xlab = "每加仑的英里数")
|
data:image/s3,"s3://crabby-images/2f6b2/2f6b201abc0c56328281ad5218331a7e42622cd1" alt=""
1 2 3
| bwplot(cyl ~ mpg | gear, main = "气缸和档数的箱线图", xlab = "英里每加仑", ylab = "气缸数")
|
data:image/s3,"s3://crabby-images/3ad84/3ad843ffc05fc48573d3b7a856cba6ea0400a2bf" alt=""
1 2 3
| xyplot(mpg ~ wt | cyl * gear, main = "气缸和档数的散点图", xlab = "车重", ylab = "英里每加仑")
|
data:image/s3,"s3://crabby-images/c18f8/c18f851d61da7b93bca75f34cb087e5f75180cb7" alt=""
1 2 3
| dotplot(cyl ~ mpg | gear, main = "气缸和档数的点图", xlab = "Miles Per Gallon")
|
data:image/s3,"s3://crabby-images/c1a63/c1a63bb00da95c6ca9e92b6797f9582b28d46deb" alt=""
1 2
| cloud(mpg ~ wt * qsec | cyl, main = "各气缸的3D散点图")
|
data:image/s3,"s3://crabby-images/05ffc/05ffc0724072aaa0cbe05aa9aa80c4452152524c" alt=""
1 2 3 4 5
| splom(mtcars[c(1, 3, 4, 5, 6)], main = "散点矩阵图") detach(mtcars)
|
data:image/s3,"s3://crabby-images/88711/8871154ee581b3050b3780b02ae306bd8da44772" alt=""
1 2 3 4
| myg <-densityplot(~height | voice.part, data=singer) update(myg, col="red", pch=16, cex=.8, lwd=2)
|
data:image/s3,"s3://crabby-images/4d485/4d485a40e5feb1565d61dbade43c9583f810c907" alt=""
1、条件变量
1 2 3 4 5 6 7
| displacement <- equal.count(mtcars$disp, number = 3, overlap = 0) xyplot(mpg ~ wt | displacement, data = mtcars, main = "不同排量的汽车车重与每加仑续航的散点图", xlab = "车重", ylab = "每加仑英里", layout = c(3, 1), aspect = 1.5)
|
data:image/s3,"s3://crabby-images/3d260/3d260b29e9d411cec7e4d8fc554a66c573585d71" alt=""
2、面板函数
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| displacement <- equal.count(mtcars$disp, number = 3, overlap = 0) mypanel <- function(x, y) { panel.xyplot(x, y, pch = 19) panel.rug(x, y) panel.grid(h = -1, v = -1) panel.lmline(x, y, col = "red", lwd = 1, lty = 2) } xyplot(mpg ~ wt | displacement, data = mtcars, layout = c(3, 1), aspect = 1.5, main = "不同排量的汽车车重与每加仑续航的散点图(自定义面板函数)", xlab = "车重", ylab = "每加仑英里", panel = mypanel)
|
data:image/s3,"s3://crabby-images/60695/606953680d0a818ba7d5ab4fa4b82aa84b1e0cfb" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| library(lattice) mtcars$transmission <- factor(mtcars$am, levels = c(0, 1), labels = c("Automatic", "Manual")) panel.smoother <- function(x, y) { panel.grid(h = -1, v = -1) panel.xyplot(x, y) panel.loess(x, y) panel.abline(h = mean(y), lwd = 2, lty = 2, col = "green") } xyplot(mpg ~ disp | transmission, data = mtcars, scales = list(cex = 0.8, col = "red"), panel = panel.smoother, xlab = "排量", ylab = "每加仑英里", main = "不同变速箱类型的排量和每加仑续航散点图", sub = "虚线表示组平均值", aspect = 1)
|
data:image/s3,"s3://crabby-images/75ad2/75ad21c6ed1c4f6d97768787781c2b85ffca1d51" alt=""
3、分组变量,多个面板的数据合一
1 2 3 4 5 6 7 8
| library(lattice) mtcars$transmission <- factor(mtcars$am, levels = c(0, 1), labels = c("自动档", "手动档")) densityplot(~mpg, data = mtcars, group = transmission, main = "不同变速箱类型的排量和每加仑续航", xlab = "每加仑续航", auto.key = TRUE)
|
data:image/s3,"s3://crabby-images/7957e/7957e878258cad4814d6263ffb025e797a91abea" alt=""
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
| library(lattice) mtcars$transmission <- factor(mtcars$am, levels = c(0, 1), labels = c("Automatic", "Manual")) colors = c("red", "blue") lines = c(1, 2) points = c(16, 17) key.trans <- list(title = "传动方式", space = "bottom", columns = 2, text = list(levels(mtcars$transmission)), points = list(pch = points, col = colors), lines = list(col = colors, lty = lines), cex.title = 1, cex = 0.9) densityplot(~mpg, data = mtcars, group = transmission, main = "不同变速箱类型的排量和每加仑续航", xlab = "每加仑续航", pch = points, lty = lines, col = colors, lwd = 2, jitter = 0.005, key = key.trans)
|
data:image/s3,"s3://crabby-images/60a70/60a70494df688aff0889ddbfee1fc31b9e6e9cf9" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
| library(lattice) colors <- "darkgreen" symbols <- c(1:12) linetype <- c(1:3) key.species <- list(title = "植物", space = "right", text = list(levels(CO2$Plant)), points = list(pch = symbols, col = colors)) xyplot(uptake ~ conc | Type * Treatment, data = CO2, group = Plant, type = "o", pch = symbols, col = colors, lty = linetype, main = "二氧化碳吸收率\n 在草本植物中", ylab = expression(paste("吸收率 ", bgroup("(", italic(frac("umol", "m"^2)), ")"))), xlab = expression(paste("浓度 ", bgroup("(", italic(frac(mL, L)), ")"))), sub = "草本植物种类: 稗草", key = key.species)
|
data:image/s3,"s3://crabby-images/dc793/dc7937527acb0fa599b529a56de9765ab36381a8" alt=""
4、lattice的图形参数
1 2 3 4 5 6 7 8 9 10
| show.settings() mysettings <- trellis.par.get() mysettings$superpose.symbol mysettings$superpose.symbol$pch <- c(1:10) trellis.par.set(mysettings) show.settings()
|
data:image/s3,"s3://crabby-images/ce96b/ce96b7f51281d0cc9a8a33bb49cce578fc67e08b" alt=""
5、图形摆放
1 2 3 4 5 6 7 8 9
| library(lattice) graph1 <- histogram(~height | voice.part, data = singer, main = "Heights of Choral Singers by Voice Part") graph2 <- densityplot(~height, data = singer, group = voice.part, plot.points = FALSE, auto.key = list(columns = 4)) plot(graph1, split = c(1, 1, 1, 2)) plot(graph2, split = c(1, 2, 1, 2), newpage = FALSE)
|
data:image/s3,"s3://crabby-images/f4122/f41229bcd25efa7b038f42fdd8c711f2b49c3b6f" alt=""
1 2 3 4 5 6 7 8
| library(lattice) graph1 <- histogram(~height | voice.part, data = singer, main = "Heights of Choral Singers by Voice Part") graph2 <- densityplot(~height, data = singer, group = voice.part, plot.points = FALSE, auto.key = list(columns = 4)) plot(graph1, position = c(0, 0.3, 1, 1)) plot(graph2, position = c(0, 0, 1, 0.3), newpage = FALSE)
|
data:image/s3,"s3://crabby-images/7cb02/7cb02a9f6f8b2035a15ae623710f4e190ddac07f" alt=""
2、ggplot2包
data:image/s3,"s3://crabby-images/3d23f/3d23f940c5b02d0b53cad43c0294254204f664ad" alt=""
1 2 3 4 5 6 7 8
| library(ggplot2) mtcars$cylinder <- as.factor(mtcars$cyl) qplot(cylinder, mpg, data=mtcars, geom=c("boxplot", "jitter"), fill=cylinder, main="叠加数据点的箱线图", xlab= "气缸数", ylab="每加仑续航")
|
data:image/s3,"s3://crabby-images/4b22a/4b22ab1c9a5facb00dab0f835838d71ccabc374e" alt=""
1 2 3 4 5 6 7 8 9 10
| library(ggplot2) transmission <- factor(mtcars$am, levels = c(0, 1), labels = c("自动", "手动")) qplot(wt, mpg, data = mtcars, color = transmission, shape = transmission, geom = c("point", "smooth"), method = "lm", formula = y ~ x, xlab = "车重", ylab = "每加仑续航", main = "回归示例")
|
data:image/s3,"s3://crabby-images/2a6ee/2a6ee0270a2a6a2ad758ccca7563e7fe1ca6b7da" alt=""
1 2 3 4 5 6 7
| library(ggplot2) mtcars$cyl <- factor(mtcars$cyl, levels = c(4, 6, 8), labels = c("4 cylinders", "6 cylinders", "8 cylinders")) mtcars$am <- factor(mtcars$am, levels = c(0, 1), labels = c("Automatic", "Manual")) qplot(wt, mpg, data = mtcars, facets = am ~ cyl, size = hp)
|
data:image/s3,"s3://crabby-images/4d56b/4d56b944558ad98f0e4d3eb554df1d127121eff4" alt=""
1 2 3 4 5 6
| library(ggplot2) data(singer, package = "lattice") qplot(height, data = singer, geom = c("density"), facets = voice.part ~ ., fill = voice.part)
|
data:image/s3,"s3://crabby-images/a6685/a668505eca229e428eec613bcdbfc3ff47302d92" alt=""