1写在前面
前面写了superheat
的教程,今天写一下第二波,如何进行聚类
以及添加注释图
吧。🤩
分分钟提升你的heatmap
的颜值哦!~🥰
2用到的包
# devtools::install_github("rlbarter/superheat")
library(superheat)
library(tidyverse)
3示例数据
data("mtcars")
DT::datatable(mtcars)
data:image/s3,"s3://crabby-images/33487/33487d07cfe9a7537a112e2b6a10b0a978c2dbcf" alt="alt"
4行聚类
4.1 生成聚类树
superheat(mtcars,
scale = T,
row.dendrogram = T)
data:image/s3,"s3://crabby-images/22479/22479615bc79ae7da8203b26f8b14cec46eb62aa" alt="alt"
4.2 聚类结果可视化
set.seed(123)
superheat(mtcars,
scale = T,
n.clusters.rows = 3)
data:image/s3,"s3://crabby-images/30fe6/30fe61eaa3a708806f4b110da9dab473b7c7e73f" alt="alt"
4.3 强制显示行名
默认情况下,在聚类时,相应的标签会分组到聚类名称中(通常为 1
、2
、3
……等)。😘
如果想强制标签为原始变量名称,可以分别指定left.label = 'variable'
或Bottom.label = 'variable'
。🥳
set.seed(123)
superheat(mtcars,
scale = T,
n.clusters.rows = 3,
left.label = 'variable')
data:image/s3,"s3://crabby-images/38b28/38b28d1219d28df6308400f7c46888e4d8268f9c" alt="alt"
4.4 提取聚类结果
我们来试试提取一下聚类的结果吧。🤩
set.seed(123)
superheatmap <- superheat(mtcars,
scale = T,
n.clusters.rows = 3,
left.label = 'variable',
print.plot = F)
superheatmap$membership.rows
data:image/s3,"s3://crabby-images/218ce/218ce8aacb43f81b8e18f52842c646e8323cb502" alt="alt"
4.5 自定义聚类结果
有时候你可能会有自己想要的聚类结果,手动定义一下吧。😘
gears <- paste(mtcars$gear, "gears")
set.seed(123)
superheat(mtcars,
scale = T,
membership.rows = gears)
data:image/s3,"s3://crabby-images/16c74/16c74476da517bd9824d9b098212d4aa53680ee9" alt="alt"
5注释图-Scatterplots
我们可以在热图的旁边添加一些注释图,非常简单,比如yt
(‘y top’
)或者yr
(‘y right’
)。🤒
常用的类型有以下几种,我们一起看看吧。😂
5.1 基础绘图
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon")
data:image/s3,"s3://crabby-images/4e611/4e61180b6384aadac898f6936780d918980524de" alt="alt"
5.2 调整大小
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.point.size = 4)
data:image/s3,"s3://crabby-images/efba6/efba6a0027c146625c5d500cb041bd465df2cd49" alt="alt"
5.3 调整颜色
point.col <- rep("wheat3", nrow(mtcars))
point.col[5] <- "red"
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.obs.col = point.col,
yr.point.size = 4)
data:image/s3,"s3://crabby-images/025ab/025ab9e9e0e6a012a016ec6a49a6d6b085dc33b5" alt="alt"
5.4 聚类颜色
我们甚至可以直接设置聚类的颜色,参数为yr.cluster.col
。🧐
superheat(dplyr::select(mtcars, -mpg, -gear),
# scale
scale = T,
# 行聚类
membership.rows = paste(mtcars$gear, "gears"),
left.label = "variable",
# mpg scatterplot
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.cluster.col = c("turquoise4", "plum4", "springgreen4"),
yr.point.size = 4)
data:image/s3,"s3://crabby-images/07f73/07f7343b6c9e4c05325eb9055ece04d38bad3585" alt="alt"
5.5 只显示一个聚类点
mpg.per.cluster <- mtcars %>%
group_by(gear) %>%
summarize(mpg.avg = mean(mpg)) %>%
select(mpg.avg) %>%
unlist
superheat(dplyr::select(mtcars, -mpg, -gear),
scale = T,
membership.rows = paste(mtcars$gear, "gears"),
left.label = "variable",
yr = mpg.per.cluster,
yr.axis.name = "miles per gallon",
yr.cluster.col = c("black", "red", "orange"),
yr.point.size = 4)
data:image/s3,"s3://crabby-images/eb9a3/eb9a3101debfd016e8f1b19a16fc45a7b515bf6b" alt="alt"
6注释图-Scatterplots
6.1 基础绘图
换个Line plot
试试。🤪
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "line",
order.rows = order(mtcars$mpg))
data:image/s3,"s3://crabby-images/a15ae/a15ae21afdd021a25453a3939a394c9afbddcd51" alt="alt"
6.2 调整大小
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "line",
yr.line.size = 4,
order.rows = order(mtcars$mpg))
data:image/s3,"s3://crabby-images/e2a02/e2a0223bae044d8e45f9c170fef53a8c5c4328c3" alt="alt"
6.3 调整颜色
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "line",
yr.line.size = 4,
yr.line.col = "springgreen4",
order.rows = order(mtcars$mpg))
data:image/s3,"s3://crabby-images/6c71f/6c71f9c6535d9efd4a07553aae5d4ba574ce8de6" alt="alt"
6.4 聚类
superheat(dplyr::select(mtcars, -mpg),
scale = T,
membership.rows = paste(mtcars$gear, "gears"),
left.label = "variable",
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "line",
yr.line.size = 4,
yr.cluster.col = c("plum4", "paleturquoise4", "salmon3"),
order.rows = order(mtcars$mpg))
data:image/s3,"s3://crabby-images/0dfb7/0dfb7a8dec9b7cf8d31bf9f4dce2ec70f402a56b" alt="alt"
7注释图-Smoothed line
7.1 Loess curve
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "smooth",
yr.line.size = 4,
yr.line.col = "red4",
order.rows = order(mtcars$cyl))
data:image/s3,"s3://crabby-images/1779e/1779e6217718536460b12496c0843bf2d83df0e7" alt="alt"
7.2 Linear regression line
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "smooth",
smoothing.method = "lm",
yr.line.size = 4,
yr.line.col = "plum4",
order.rows = order(mtcars$cyl))
data:image/s3,"s3://crabby-images/c3153/c3153f58c929dcc200a2a0d52971089d44f748ee" alt="alt"
7.3 Scatterplot with connecting line plot
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "scatterline",
yr.line.col = "tomato3",
yr.obs.col = rep("orange", nrow(mtcars)),
yr.point.size = 4,
order.rows = order(mtcars$cyl))
data:image/s3,"s3://crabby-images/1af08/1af08936e6ab3ad801beedba222138ba63293768" alt="alt"
7.4 Scatterplot with smoothed line
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "scattersmooth",
yr.line.col = "tomato3",
yr.obs.col = rep("orange", nrow(mtcars)),
order.rows = order(mtcars$cyl))
data:image/s3,"s3://crabby-images/4b7d2/4b7d2202921e2207812c3faaf3c48fc0f8ebff62" alt="alt"
8注释图-Barplot
8.1 基础绘图
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "bar")
data:image/s3,"s3://crabby-images/bc067/bc067ccc15182b62297f26bddc403097324c2e6c" alt="alt"
8.2 调整颜色
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "bar",
yr.bar.col = "black",
yr.obs.col = rep("beige", nrow(mtcars)))
data:image/s3,"s3://crabby-images/aec4a/aec4ace473bfe450e9d3fd416de3532140173819" alt="alt"
8.3 聚类
mpg.per.cluster <- mtcars %>%
group_by(gear) %>%
summarize(mpg.avg = mean(mpg)) %>%
select(mpg.avg) %>%
unlist
superheat(dplyr::select(mtcars, -mpg, -gear),
scale = T,
membership.rows = paste(mtcars$gear, "gears"),
left.label = "variable",
yr = mpg.per.cluster,
yr.axis.name = "miles per gallon",
yr.plot.type = "bar",
yr.bar.col = "black",
yr.cluster.col = c("beige", "white", "beige"))
data:image/s3,"s3://crabby-images/81892/81892a8064071f6f8bef78a868dd1cbe71a4ad5d" alt="alt"
9注释图-Boxplot
9.1 基础绘图
mpg.per.cluster <- mtcars %>%
group_by(gear) %>%
summarize(mpg.avg = mean(mpg)) %>%
select(mpg.avg) %>%
unlist
superheat(dplyr::select(mtcars, -mpg, -gear),
scale = T,
membership.rows = paste(mtcars$gear, "gears"),
left.label = "variable",
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "boxplot")
data:image/s3,"s3://crabby-images/447e1/447e1ad93d8a19bc4b60a65a99232dc3de99d82c" alt="alt"
9.2 调整颜色
mpg.per.cluster <- mtcars %>%
group_by(gear) %>%
summarize(mpg.avg = mean(mpg)) %>%
select(mpg.avg) %>%
unlist
superheat(dplyr::select(mtcars, -mpg, -gear),
scale = T,
membership.rows = paste(mtcars$gear, "gears"),
left.label = "variable",
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.plot.type = "boxplot",
yr.cluster.col = c("beige", "slategray1", "beige"))
data:image/s3,"s3://crabby-images/b4ec5/b4ec57560f862ea125dc6b8e5529b1d85790d58d" alt="alt"
10注释图坐标轴的调整
10.1 调整轴名称
用到yr.axis.name
或者yt.axis.name
就行啦。🤒
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yt = cor(mtcars)[-1,"mpg"],
yt.plot.type = "bar",
yt.axis.name = "Correlation\nwith mpg")
data:image/s3,"s3://crabby-images/782bf/782bf57c1cf16fe8bc3cb3e4e22b3387b5fffefd" alt="alt"
10.2 调整坐标轴名称及数字大小
可以分别使用yr.axis.name.size/yt.axis.name.size
或yr.axis.size/yt.axis.size
来调整。😘
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yt = cor(mtcars)[-1,"mpg"],
yt.plot.type = "bar",
yt.axis.name = "Correlation\nwith mpg",
yt.axis.size = 14,
yt.axis.name.size = 14)
data:image/s3,"s3://crabby-images/1021a/1021a9a6b692fe89e2aff1f00da31123267c9470" alt="alt"
10.3 调整坐标轴Limits
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.lim = c(0, 60),
yt = cor(mtcars)[-1,"mpg"],
yt.plot.type = "bar",
yt.axis.name = "Correlation\nwith mpg",
yt.lim = c(-1.5, 1))
data:image/s3,"s3://crabby-images/ca334/ca334e4fab37b0f8b2d920354655c4b634c27d2d" alt="alt"
10.4 调整坐标轴ticks
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.lim = c(0, 60),
yr.breaks = c(10, 40),
yt = cor(mtcars)[-1,"mpg"],
yt.plot.type = "bar",
yt.axis.name = "Correlation\nwith mpg")
data:image/s3,"s3://crabby-images/20605/20605167aebe3fe71056cd9d0eb2871bc1b69b30" alt="alt"
10.5 调整坐标轴ticks的labels
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.lim = c(0, 60),
yr.breaks = c(10, 40),
yr.break.labels = c("low", "high"),
yt = cor(mtcars)[-1,"mpg"],
yt.plot.type = "bar",
yt.axis.name = "Correlation\nwith mpg")
data:image/s3,"s3://crabby-images/8a7c3/8a7c316c1eca22fd7b8289a1d658c53f6a0cc09c" alt="alt"
10.6 调整注释图大小
superheat(dplyr::select(mtcars, -mpg),
scale = T,
yr = mtcars$mpg,
yr.axis.name = "miles per gallon",
yr.axis.size = 14,
yr.axis.name.size = 14,
yr.plot.size = 0.8,
yt = cor(mtcars)[-1,"mpg"],
yt.plot.type = "bar",
yt.axis.name = "Correlation with mpg",
yt.axis.size = 14,
yt.axis.name.size = 14,
yt.plot.size = 0.7)
data:image/s3,"s3://crabby-images/e03ef/e03efc889fe064a1614aee873d1a6921d370a197" alt="alt"
data:image/s3,"s3://crabby-images/cb5aa/cb5aa1a68809461270d6d4fc3adf76fa22245221" alt="alt"
点个在看吧各位~ ✐.ɴɪᴄᴇ ᴅᴀʏ 〰
📍 🤩 LASSO | 不来看看怎么美化你的LASSO结果吗!?
📍 🤣 chatPDF | 别再自己读文献了!让chatGPT来帮你读吧!~
📍 🤩 WGCNA | 值得你深入学习的生信分析方法!~
📍 🤩 ComplexHeatmap | 颜狗写的高颜值热图代码!
📍 🤥 ComplexHeatmap | 你的热图注释还挤在一起看不清吗!?
📍 🤨 Google | 谷歌翻译崩了我们怎么办!?(附完美解决方案)
📍 🤩 scRNA-seq | 吐血整理的单细胞入门教程
📍 🤣 NetworkD3 | 让我们一起画个动态的桑基图吧~
📍 🤩 RColorBrewer | 再多的配色也能轻松搞定!~
📍 🧐 rms | 批量完成你的线性回归
📍 🤩 CMplot | 完美复刻Nature上的曼哈顿图
📍 🤠 Network | 高颜值动态网络可视化工具
📍 🤗 boxjitter | 完美复刻Nature上的高颜值统计图
📍 🤫 linkET | 完美解决ggcor安装失败方案(附教程)
📍 ......
本文由 mdnice 多平台发布