介绍
已经有很多热图包了,如heatmap、大名鼎鼎的ComplexHeatmap等,够让人赏(yan)心(hua)悦(liao)目(luan)了,heatmaply究竟有什么卵用呢?
它可以绘制交互热图,鼠标点点点就可以看到每个小块的数值、还可以放大、缩小。
安装和加载
install.packages('heatmaply')
library("heatmaply")
基本用法
heatmaply(mtcars)
data:image/s3,"s3://crabby-images/d2d40/d2d40d14ea7128c35141b40af29020316176e078" alt=""
相关性热图
heatmaply_cor(
cor(mtcars),
xlab = "Features",
ylab = "Features",
k_col = 2,
k_row = 2
)
data:image/s3,"s3://crabby-images/7a903/7a903e84462f5ebdffd11e7f1b7a4f1f53e2322e" alt=""
更高级的相关性热图
r <- cor(mtcars)
## We use this function to calculate a matrix of p-values from correlation tests
## https://stackoverflow.com/a/13112337/4747043
cor.test.p <- function(x){
FUN <- function(x, y) cor.test(x, y)[["p.value"]]
z <- outer(
colnames(x),
colnames(x),
Vectorize(function(i,j) FUN(x[,i], x[,j]))
)
dimnames(z) <- list(colnames(x), colnames(x))
z
}
p <- cor.test.p(mtcars)
heatmaply_cor(
r,
node_type = "scatter",
point_size_mat = -log10(p),
point_size_name = "-log10(p-value)",
label_names = c("x", "y", "Correlation")
)
data:image/s3,"s3://crabby-images/ab676/ab67631ca34222dc6682b9959daafaea16d7b902" alt=""
数据转化(缩放、规一化和百分比化)
heatmaply(
mtcars,
xlab = "Features",
ylab = "Cars",
scale = "column",
main = "Data transformation using 'scale'"
)
data:image/s3,"s3://crabby-images/80ad5/80ad5c6a4baab4ce04ed192dc9ef8926b7ad07f8" alt=""
heatmaply(
normalize(mtcars),
xlab = "Features",
ylab = "Cars",
main = "Data transformation using 'normalize'"
)
data:image/s3,"s3://crabby-images/3c196/3c19653e9fbc0757cffe845f6cbf2082194f6a4d" alt=""
heatmaply(
percentize(mtcars),
xlab = "Features",
ylab = "Cars",
main = "Data transformation using 'percentize'"
)
data:image/s3,"s3://crabby-images/2b481/2b4819a01eff77a1445d61a7aa72ed9903c0b18d" alt=""
缺失值可视化
heatmaply_na(
airquality[1:30, ],
showticklabels = c(TRUE, FALSE),
k_col = 3,
k_row = 3
)
data:image/s3,"s3://crabby-images/2b8d0/2b8d0fb50d8a5e0025f7c9676d9edcaeb8b6b270" alt=""
更换调色板
heatmaply(
percentize(mtcars),
colors = heat.colors(100)
)
data:image/s3,"s3://crabby-images/d002d/d002dc3c39ba21f50593c7e9934f868da9371cdb" alt=""
heatmaply(
mtcars,
scale_fill_gradient_fun = ggplot2::scale_fill_gradient2(
low = "blue",
high = "red",
midpoint = 200,
limits = c(0, 500)
)
)
data:image/s3,"s3://crabby-images/0eb9b/0eb9b0bc2cfb32ae5449622d239b751dd642ccb5" alt=""
自定义树状图和注释
heatmaply(
percentize(mtcars)[1:10, ],
seriate = "OLO"
)
data:image/s3,"s3://crabby-images/15868/15868b6bc1f09b3304bc4ee8582cb55b30812e01" alt=""
heatmaply(
percentize(mtcars)[1:10, ],
seriate = "GW"
)
data:image/s3,"s3://crabby-images/7630d/7630dccf7499118f3749fbd0502b3ebe2c0b548d" alt=""
heatmaply(
percentize(mtcars)[1:10, ],
seriate = "mean"
)
data:image/s3,"s3://crabby-images/57baf/57baf8ee86e799d53dd5b4a2720daeb2e66af48c" alt=""
heatmaply(
percentize(mtcars)[1:10, ],
seriate = "none"
)
data:image/s3,"s3://crabby-images/e49f3/e49f3d2ae4e23a77c110a76020fbb6248e15388b" alt=""
使用dendextend定制树状图
x <- as.matrix(datasets::mtcars)
library("dendextend")
row_dend <- x %>%
dist %>%
hclust %>%
as.dendrogram %>%
set("branches_k_color", k = 3) %>%
set("branches_lwd", c(1, 3)) %>%
ladderize
# rotate_DendSer(ser_weight = dist(x))
col_dend <- x %>%
t %>%
dist %>%
hclust %>%
as.dendrogram %>%
set("branches_k_color", k = 2) %>%
set("branches_lwd", c(1, 2)) %>%
ladderize
# rotate_DendSer(ser_weight = dist(t(x)))
heatmaply(
percentize(x),
Rowv = row_dend,
Colv = col_dend
)
data:image/s3,"s3://crabby-images/37f18/37f181f5d1084334a993369ff514a84f183cb182" alt=""
用RowSideColors添加额外注释
x <- as.matrix(datasets::mtcars)
rc <- colorspace::rainbow_hcl(nrow(x))
library("gplots")
library("viridis")
heatmap.2(
x,
trace = "none",
col = viridis(100),
RowSideColors = rc,
key = FALSE
)
data:image/s3,"s3://crabby-images/404ba/404ba9339a7e3f02e5471c74bbb673d204cea591" alt=""
heatmaply(
x,
seriate = "mean",
RowSideColors = rc
)
data:image/s3,"s3://crabby-images/53ebb/53ebb3245089209836ad659fa9af162b0081d56c" alt=""
heatmaply(
x[, -c(8, 9)],
seriate = "mean",
col_side_colors = c(rep(0, 5), rep(1, 4)),
row_side_colors = x[, 8:9]
)
data:image/s3,"s3://crabby-images/372ee/372eefd9c3467a72e4ccce019d9bba7a19bb5be4" alt=""
文本注释
heatmaply(
mtcars,
cellnote = mtcars
)
data:image/s3,"s3://crabby-images/4d001/4d00195f98c88392fb46d24b7d1d651775a451b5" alt=""
mat <- mtcars
mat[] <- paste("This cell is", rownames(mat))
mat[] <- lapply(colnames(mat), function(colname) {
paste0(mat[, colname], ", ", colname)
})
heatmaply(
mtcars,
custom_hovertext = mat
)
data:image/s3,"s3://crabby-images/bef9e/bef9e2f6c0df7b17c41498fa5c88e6546f82acb5" alt=""
还可以绘制静态图
ggheatmap(
mtcars,
scale = "column",
row_side_colors = mtcars[, c("cyl", "gear")]
)
data:image/s3,"s3://crabby-images/531fd/531fdfee6cc77b68a2ee0ad7f044a643aacc2f72" alt=""
网友评论