data:image/s3,"s3://crabby-images/6cd51/6cd51949b6712ab47e1e535bdd2dfe5664b5d7c3" alt=""
3. 散点图
[TOC]
22
散点图通常用于刻画两个连续型变量之间的关系。绘制散点图时,数据集中的每一个观测值都由每个点表示。
3.1 绘制基本散点图
library(gcookbook)
library(ggplot2)
# 列出我们用到的列
head(heightweight[, c("ageYear", "heightIn")])
> head(heightweight[, c("ageYear", "heightIn")])
ageYear heightIn
1 11.92 56.3
2 12.92 62.3
3 12.75 63.3
4 13.42 59.0
5 15.92 62.5
6 14.25 62.5
ggplot(heightweight, aes(x=ageYear, y=heightIn)) + geom_point()
data:image/s3,"s3://crabby-images/e0abd/e0abdcdeb3e426b203acd97e549ab6b4ac63ada7" alt=""
# shape参数设置点型 size设置点的大小
ggplot(heightweight, aes(x=ageYear, y=heightIn)) +
geom_point(shape=21)
ggplot(heightweight, aes(x=ageYear, y=heightIn)) +
geom_point(size=1.5)
data:image/s3,"s3://crabby-images/da943/da9430173a8299c6e7886d3fbec653beb0abca47" alt=""
3.2 使用点形和颜色属性进行分组
head(heightweight[, c("sex", "ageYear", "heightIn")])
> head(heightweight[, c("sex", "ageYear", "heightIn")])
sex ageYear heightIn
1 f 11.92 56.3
2 f 12.92 62.3
3 f 12.75 63.3
4 f 13.42 59.0
5 f 15.92 62.5
6 f 14.25 62.5
ggplot(heightweight, aes(x=ageYear, y=heightIn, colour=sex)) +
geom_point()
ggplot(heightweight, aes(x=ageYear, y=heightIn, shape=sex)) +
geom_point()
data:image/s3,"s3://crabby-images/ac3df/ac3df36ed232379231163c85e8d1e67661d7886c" alt=""
data:image/s3,"s3://crabby-images/22a29/22a29e57b8b9b97c32484f315b331009efc67789" alt=""
# scale_shape_manual()使用其它点形状
#scale_colour_brewer()使用其它颜色
ggplot(heightweight, aes(x=ageYear, y=heightIn, shape=sex, colour=sex)) +
geom_point() +
scale_shape_manual(values=c(1,2)) +
scale_colour_brewer(palette="Set1")
data:image/s3,"s3://crabby-images/ce407/ce407260e9df6f48651f7054f7d05cf4edc02cf5" alt=""
3.3 使用不同于默认设置的点形
# 使用点形和填充色属性分别表示不同变量
hw <- heightweight
# 分组 Categorize into <100 and >=100 groups
hw$weightGroup <- cut(hw$weightLb, breaks=c(-Inf, 100, Inf),
labels=c("< 100", ">= 100"))
# 使用具有颜色和填充色的点形及对应于空值(NA)和填充色的颜色
ggplot(hw, aes(x=ageYear, y=heightIn, shape=sex, fill=weightGroup)) +
geom_point(size=2.5) +
scale_shape_manual(values=c(21, 24)) +
scale_fill_manual(values=c(NA, "black"),
guide=guide_legend(override.aes=list(shape=21)))
data:image/s3,"s3://crabby-images/31ff8/31ff896f1713f982618f55c6a6a6876288fe6d32" alt=""
3.4 将连续型变量映射到点的颜色或大小属性上
ggplot(heightweight, aes(x=ageYear, y=heightIn, colour=weightLb)) +
geom_point()
ggplot(heightweight, aes(x=ageYear, y=heightIn, size=weightLb)) +
geom_point()
data:image/s3,"s3://crabby-images/2c01e/2c01ebab0f2ef7290df9098624f459c8e556dc3c" alt=""
# 默认点的大小范围为1-6mm
# scale_size_continuous(range=c(2, 5))修改点的大小范围
# 将色阶设定为由黑至白
ggplot(heightweight, aes(x=weightLb, y=heightIn, fill=ageYear)) +
geom_point(shape=21, size=2.5) +
scale_fill_gradient(low="black", high="white")
# 使用 guide_legend() 函数以离散的图例代替色阶
ggplot(heightweight, aes(x=weightLb, y=heightIn, fill=ageYear)) +
geom_point(shape=21, size=2.5) +
scale_fill_gradient(low="black", high="white", breaks=12:17,
guide=guide_legend())
data:image/s3,"s3://crabby-images/f4ff5/f4ff5deeb954b85606c9698378782e9f8e9e3704" alt=""
# 调用scale_size_area()函数使数据点的面积正比于变量值。
ggplot(heightweight, aes(x=ageYear, y=heightIn, size=weightLb, colour=sex)) +
geom_point(alpha=.5) +
scale_size_area() +
scale_colour_brewer(palette="Set1")
data:image/s3,"s3://crabby-images/3e4c4/3e4c4a5837637dc9b3d6737ba2f1921c706af6ea" alt=""
3.5 处理图形重叠
方法:
- 使用半透明的点
- 将数据分箱(bin),并用矩形表示
- 将数据分箱(bin),并用六边形表示
- 使用箱线图
sp <- ggplot(diamonds, aes(x=carat, y=price))
sp + geom_point()
# 透明度
sp + geom_point(alpha=.1)
sp + geom_point(alpha=.01)
# stat_bin2d()函数默认分别在x轴和y轴方向上将数据分割为30各组
sp + stat_bin2d()
# bin=50设置箱数,limits参数设定图例范围
sp + stat_bin2d(bins=50) +
scale_fill_gradient(low="lightblue", high="red", limits=c(0, 6000))
data:image/s3,"s3://crabby-images/5d47c/5d47cd7f22555cdce0c47270a41cbeed33ba6c4d" alt=""
# stat_binhex()函数使用六边形分箱
library(hexbin)
sp + stat_binhex() +
scale_fill_gradient(low="lightblue", high="red",
limits=c(0, 8000))
sp + stat_binhex() +
scale_fill_gradient(low="lightblue", high="red",
breaks=c(0, 250, 500, 1000, 2000, 4000, 6000),
limits=c(0, 6000))
data:image/s3,"s3://crabby-images/95ea9/95ea9bf6ee709821a71cad0d25f8d0ede9b007a7" alt=""
sp1 <- ggplot(ChickWeight, aes(x=Time, y=weight))
sp1 + geom_point()
# 调用position_jitter()函数给数据点增加随机扰动,通过width,height参数调节
sp1 + geom_point(position="jitter")
# 也可以调用 geom_jitter()
sp1 + geom_point(position=position_jitter(width=.5, height=0))
data:image/s3,"s3://crabby-images/ae076/ae07627c2bb8795064f03ce0a686310afe99334f" alt=""
# 箱线图
sp1 + geom_boxplot(aes(group=Time))
data:image/s3,"s3://crabby-images/ec007/ec0074f3ecd25896b841cbbc5218ee2312f40217" alt=""
参考书籍
- R Graphics Cookbook, 2nd edition.
网友评论