12.9 密度图
ggplot(mpg, aes(cty)) +
geom_density(aes(fill = factor(cyl)), alpha = 0.8) +
labs(
title = "Density plot",
subtitle = "City Mileage Grouped by Number of cylinders",
caption = "Source: mpg",
x = "City Mileage",
fill = "# Cylinders"
)
data:image/s3,"s3://crabby-images/636e5/636e59db2fcfc853f3928641bc14f6e42a089ae9" alt="按汽缸数分组的城市里程"
图 12.37: 按汽缸数分组的城市里程
添加透明度,解决遮挡
ggplot(diamonds, aes(x = price, fill = cut)) + geom_density()
data:image/s3,"s3://crabby-images/64786/64786749fd748558f63a3b17a34d1ffad9b7d8ef" alt="密度图"
图 12.38: 密度图
ggplot(diamonds, aes(x = price, fill = cut)) + geom_density(alpha = 0.5)
data:image/s3,"s3://crabby-images/0cef3/0cef3b60f4011b3495825f60d19808465a93effe" alt="添加透明度的密度图"
图 12.39: 添加透明度的密度图
堆积密度图
ggplot(diamonds, aes(x = price, fill = cut)) +
geom_density(position = "stack")
data:image/s3,"s3://crabby-images/f42f2/f42f2dfd55989a39c033597bc99c49a96f0a4ccb" alt="堆积密度图"
图 12.40: 堆积密度图
条件密度估计
# You can use position="fill" to produce a conditional density estimate
ggplot(diamonds, aes(carat, stat(count), fill = cut)) +
geom_density(position = "fill")
data:image/s3,"s3://crabby-images/6bf99/6bf990be5bd750947faa99b1ab4f1e2ba6610392" alt="条件密度估计图"
图 12.41: 条件密度估计图
岭线图是密度图的一种变体,可以防止密度曲线重叠在一起
ggplot(diamonds) +
::geom_density_ridges(aes(x = price, y = color, fill = color)) ggridges
二维的密度图又是一种延伸
ggplot(diamonds, aes(x = carat, y = price)) +
geom_density_2d(aes(color = cut)) +
facet_grid(~cut)
stat
函数,特别是 nlevel 参数,在密度曲线之间填充我们又可以得到热力图
ggplot(diamonds, aes(x = carat, y = price)) +
stat_density_2d(aes(fill = stat(nlevel)), geom = "polygon") +
facet_grid(. ~ cut)
gemo_hex
也是二维密度图的一种变体,特别适合数据量比较大的情形
ggplot(diamonds, aes(x = carat, y = price)) + geom_hex() +
scale_fill_viridis_c()
heatmaps in ggplot2 二维密度图
ggplot(faithful, aes(x = eruptions, y = waiting)) +
stat_density_2d(aes(fill = ..level..), geom = "polygon") +
xlim(1, 6) +
ylim(40, 100)
ggplot(faithful, aes(x = eruptions, y = waiting)) +
stat_density2d(aes(fill = stat(level)), geom = "polygon") +
scale_fill_viridis_c(option = "viridis") +
xlim(1, 6) +
ylim(40, 100)
data:image/s3,"s3://crabby-images/aa678/aa67812013ed87f937a76aebba5002c30af70e80" alt="二维密度图"
data:image/s3,"s3://crabby-images/334a3/334a32a424aa3dfe7332770c0c4bb35dcc3b1a48" alt="二维密度图"
图 12.42: 二维密度图
MASS::kde2d()
实现二维核密度估计,ggplot2 包提供了两种等价的绘图方式
stat_density_2d()
和..
stat_density2d()
和stat()
::plot_ly(
plotlydata = faithful, x = ~eruptions,
y = ~waiting, type = "histogram2dcontour"
%>%
) ::config(displayModeBar = FALSE) plotly
图 12.43: 二维直方图/密度图/轮廓图
# plot_ly(faithful, x = ~waiting, y = ~eruptions) %>%
# add_histogram2d() %>%
# add_histogram2dcontour()
延伸一下,热力图
library(KernSmooth)
<- bkde2D(x = faithful, bandwidth = c(0.7, 7))
den # 热力图
<- plotly::plot_ly(x = den$x1, y = den$x2, z = den$fhat) %>%
p1 ::config(displayModeBar = FALSE) %>%
plotly::add_heatmap()
plotly
# 等高线图
<- plotly::plot_ly(x = den$x1, y = den$x2, z = den$fhat) %>%
p2 ::config(displayModeBar = FALSE) %>%
plotly::add_contour()
plotly
::tagList(p1, p2) htmltools