基于ggplot2包以及corrplot包的相关矩阵可视化包ggcorrplot,ggcorrplot包提供对相关矩阵重排序以及在相关图中展示显著性水平的方法,同时也能计算相关性p-value
安装方法就不提了,不懂的可以浏览我以前的文章
library(ggcorrplot)
#计算相关矩阵(cor()计算结果不提供p-value)
data("mtcars")
corr <- round(cor(mtcars), 1)
head(corr[, 1:6])
data:image/s3,"s3://crabby-images/186a9/186a969aad9fe372f962065ca782b96f686a9729" alt=""
#用ggcorrplot包提供的函数cor_pmat()
p.mat <- cor_pmat(mtcars)
head(p.mat[, 1:4])
data:image/s3,"s3://crabby-images/a25c1/a25c1ec5bad17190d3bc8895a26c67454862d8d0" alt=""
可视化相关性矩阵
ggcorrplot(corr)#method默认为square
data:image/s3,"s3://crabby-images/f0642/f06421697a5c60e279df18e5f5c8fb2755e20be6" alt=""
#方法为circle
ggcorrplot(corr, method = "circle")
data:image/s3,"s3://crabby-images/0d649/0d64972cf8a141a0871452d40fcb8223b956dd4f" alt=""
#重排矩阵,使用分等级聚类
ggcorrplot(corr, hc.order = TRUE, outline.color = "white")
data:image/s3,"s3://crabby-images/478f8/478f8e8a13953daabf5136f8873df3004f8a829c" alt=""
#控制矩阵形状
ggcorrplot(corr, hc.order = TRUE, type = "lower", outline.color = "white")#下三角形
data:image/s3,"s3://crabby-images/6418e/6418e4d5b524158b351b7bbcf65fef6934054eb6" alt=""
#上三角形
ggcorrplot(corr, hc.order = TRUE, type = "upper", outline.color = "white")
data:image/s3,"s3://crabby-images/6fdb5/6fdb5d4c954a631fd363f31aa51cb9833efb15eb" alt=""
#更改颜色以及主题
ggcorrplot(corr, hc.order = TRUE, type = "lower", outline.color = "white",
ggtheme = ggplot2::theme_gray, colors = c("#6D9EC1", "white", "#E46726"))
data:image/s3,"s3://crabby-images/cd716/cd716730d66cecae53f76ad1ed9ea0096b609bba" alt=""
#添加相关系数
ggcorrplot(corr, hc.order = TRUE, type = "lower", lab = TRUE)
data:image/s3,"s3://crabby-images/4fc0a/4fc0a50350fc0fa30639e7254c0866bd1eeb8afe" alt=""
#增加显著性水平,不显著的话就不添加了
ggcorrplot(corr, hc.order = TRUE, type = "lower", p.mat = p.mat)
data:image/s3,"s3://crabby-images/26189/26189cd92bea1ba0d090f3fc0314f360b2543bda" alt=""
#将不显著的色块设置成空白
ggcorrplot(corr, p.mat = p.mat, hc.order=TRUE, type = "lower", insig = "blank")
data:image/s3,"s3://crabby-images/f78d6/f78d6bceb242333e4a964e89f13904306ef885c9" alt=""
网友评论