原创:黄小仙
今天给大家介绍一下Ridgeline plot(山脊图)的画法。
data:image/s3,"s3://crabby-images/d83f6/d83f68b08bab7d3e7ca5270e51f5951e5873376d" alt=""
作图数据如下:
data:image/s3,"s3://crabby-images/96651/96651de57a251c4e0eb9d94822d6a431996a8cdd" alt=""
Step1. 绘图数据的准备
首先要把你想要绘图的数据调整成R语言可以识别的格式,建议大家在excel中保存成csv格式。
Step2. 绘图数据的读取
data<-read.csv(“your file path”, header = T)
#注释:header=T表示数据中的第一行是列名,如果没有列名就用header=F
Step3. 绘图所需package的安装、调用
library(reshape2)
library(ggplot2)
library(ggridges)
# 注释:package使用之前需要调用
# 今天要用到geom_density_ridges()函数需要调用ggridges包
# 直接用install.packages(ggridges)可以安装
Step4. 绘图
ggplot(data_melt, aes(x = value , y = variable , fill = variable)) +
geom_density_ridges() +
theme_ridges() +
theme(legend.position = "none")
data:image/s3,"s3://crabby-images/59d40/59d40ade3f499a732d1afe0b44fad29b1039936c" alt=""
##调整透明度
ggplot(data_melt, aes(x = value , y = variable , fill = variable)) +
geom_density_ridges(alpha = 0.5) +
theme_ridges() +
theme(legend.position = "none")
data:image/s3,"s3://crabby-images/5d06c/5d06ce05a6a2dbbaff94d46a00e44b012fee11df" alt=""
data:image/s3,"s3://crabby-images/5144d/5144d8c07e0e6988a69eb09eaa12fb543b02d975" alt=""
##更改顺序
level<-levels(data_melt$variable)
data_melt$variable<-factor(data_melt$variable, levels = rev(level))
ggplot(data_melt, aes(x = value , y = variable , fill = variable)) +
geom_density_ridges(alpha = 0.5) +
theme_ridges() +
theme(legend.position = "none")
data:image/s3,"s3://crabby-images/57fd5/57fd5c1e67ac425c61b66dd7edc954e61980708e" alt=""
data:image/s3,"s3://crabby-images/20b1e/20b1e3e5ba0a17996a706e041a95b9106cb2a12a" alt=""
data:image/s3,"s3://crabby-images/fc222/fc222cb9623ced0e2a5d0dbb6c83c202e6c45894" alt=""
##更改线条形状
ggplot(data_melt, aes(x = value , y = variable , fill = variable)) +
geom_density_ridges(alpha = 0.5, stat="binline", bins=20) +
theme_ridges() +
theme(legend.position = "none")
data:image/s3,"s3://crabby-images/74f9f/74f9fd082782f0509baf26aeab8c5252e702492d" alt=""
data:image/s3,"s3://crabby-images/a6925/a6925683b4f069c68e22771ace6b3276e9f80b5a" alt=""
(公众号:生信了)
网友评论