山脊图(Ridgeline plot)是一种用于展示几组数据变量分布情况的图形,一般由多个彼此重叠的密度图组成,实现了在有限的空间上,以类3D的形式非常紧凑展示数据的目的。
安装、加载R包
rm(list = ls())
setwd("D:\\山脊图")
#安装R包
install.packages("ggplot2")
install.packages("ggridges")
install.packages("reshape")
install.packages("ggprism")
#加载R包
library(ggplot2)
library(ggridges)
library(reshape)
library(ggprism)
数据
# 加载数据
df <- read.table(file="data.txt",sep="\t",header=T,check.names=FALSE)
#变量格式转换,宽数据转化为长数据,方便后续作图
df1 <- melt(df)
data:image/s3,"s3://crabby-images/ae178/ae17825d659d392d36ca0ee4b58fd0dd68a4c883" alt=""
data:image/s3,"s3://crabby-images/8f05f/8f05ff3c797afd5e9dd88d2a685b36561f45aad7" alt=""
绘图
1、基础绘图——基于ggridges包和ggplot2包进行绘制
ggplot(df1, aes(x = value, y = variable, fill = variable)) + geom_density_ridges()
data:image/s3,"s3://crabby-images/9895f/9895f9c127ffe76500cf39045828b687f9045604" alt=""
2、个性化绘制
#展示形式1
p1 <- ggplot(df1, aes(x = value, y = variable, fill = variable)) +#数据
geom_density_ridges(stat = "density_ridges") +#绘制山脊图
theme_prism(palette = "candy_bright",#主题样式
base_fontface = "plain", # 字体样式
base_family = "serif", # 字体格式
base_size = 16, #字体大小
base_line_size = 0.8)+ #坐标轴粗细
scale_fill_prism(palette = "candy_bright")+#颜色
theme(legend.position = "none",#图例去除
axis.line.y = element_blank(),#去除Y轴轴线
axis.ticks.y = element_blank())+#去除Y轴刻度
scale_y_discrete(expand = c(0.05, 0))#调整起始图形距离X轴距离
p1
data:image/s3,"s3://crabby-images/7bb01/7bb017e114ce23c172919beb69f28ecacc882bf1" alt=""
#展示形式2
p2 <- ggplot(df1, aes(x = value, y = variable, fill = variable)) +
geom_density_ridges(stat="binline", bins=40) +
theme_prism(palette = "candy_bright",
base_fontface = "plain", # 字体样式
base_family = "serif", # 字体格式
base_size = 16, #字体大小
base_line_size = 0.8)+ #坐标轴粗细
scale_fill_prism(palette = "candy_bright")+
theme(legend.position = "none",
axis.line.y = element_blank(),
axis.ticks.y = element_blank())+
scale_y_discrete(expand = c(0.05, 0))
p2
data:image/s3,"s3://crabby-images/93409/934097983cb5a6d2c082d64850b40ce4ff34838a" alt=""
3、拼接图片
cowplot::plot_grid(p1, p2, ncol = 2)
data:image/s3,"s3://crabby-images/5610a/5610a87a0846e42a9c4b36b0ed4086d511318055" alt=""
网友评论