相关性表示两组数据之间的关系是否“相似”或“相近”;但当遇到多组数据时,如何直观的比较各组数据之间的相关性是一个大家比较关注的问题,相关图可以通过对相关系数矩阵的可视化来解决这一问题。这里列出2种方法:
数据以R语言内置的mtcars数据框为例(直接输入mtcars就能查看其内容,其包含了11个变量,对那个变量都测量了32辆汽车)
1. 利用corrgram包中的corrgram()函数。
代码为:
install.packages("corrgram") #安装corrgram包 library(corrgram) #加载corrgram包 corrgram(mtcars,order=TRUE,lower.panel=panel.shade,upper.panel=panel.pie,text.panel=panel.txt,main="correlogram of mydata intercorrelations") #画图,不需要事先计算出相关系数矩阵 (panel.shade + panel.pie)
order=TRUE表示相关矩阵将使用主成分分析法对变量重新排序(能够使二元变量的关系模式更加明显);
lower.panel=panel.shade,下三角的图形用阴影深度表示相关性大小;
upper.panel=panel.pie ,上三角图形用饼图填充比例来表示相关性(panel.ellipse用平滑曲线和置信椭圆表示相关性,panel.pts用散点图表示相关性);
text.panel=panel.txt主对角线输出的变量名字;
main=”correlogram of mydata intercorrelations” 添加标题
diag.panel=panel.minmax主对角线输出变量的最小最大值。
corrgram(mtcars,order=TRUE,lower.panel=panel.ellipse,upper.panel=panel.pts,text.panel=panel.txt,main="correlogram of mydata intercorrelations") #画图,不需要事先计算出相关系数矩阵 (panel.ellipse + panel.pts)
corrgram(mtcars,order=TRUE,lower.panel=panel.shade,upper.panel=panel.pts,text.panel=panel.txt,main="correlogram of mydata intercorrelations") #画图,不需要事先计算出相关系数矩阵 (panel.shade + panel.pts)
参考:
future张帆的博客 http://blog.sina.com.cn/s/blog_a153fe9b0102x309.html
2 利用corrplot包中的corrplot()函数
corrplot介绍:
使用:
corrplot(corr, method = c(“circle”, “square”, “ellipse”, “number”, “shade”, “color”, “pie”), type = c(“full”, “lower”, “upper”), add = FALSE, col = NULL, bg = “white”, title = “”, is.corr = TRUE, diag = TRUE, outline = FALSE, mar = c(0, 0, 0, 0), addgrid.col = NULL, addCoef.col = NULL, addCoefasPercent = FALSE, order = c(“original”, “AOE”, “FPC”, “hclust”, “alphabet”), hclust.method = c(“complete”, “ward”, “ward.D”, “ward.D2”, “single”, “average”, “mcquitty”, “median”, “centroid”), addrect = NULL, rect.col = “black”, rect.lwd = 2, tl.pos = NULL, tl.cex = 1, tl.col = “red”, tl.offset = 0.4, tl.srt = 90, cl.pos = NULL, cl.lim = NULL, cl.length = NULL, cl.cex = 0.8, cl.ratio = 0.15, cl.align.text = “c”, cl.offset = 0.5, number.cex = 1, number.font = 2, number.digits = NULL, addshade = c(“negative”, “positive”, “all”), shade.lwd = 1, shade.col = “white”, p.mat = NULL, sig.level = 0.05, insig = c(“pch”, “p-value”, “blank”, “n”), pch = 4, pch.col = “black”, pch.cex = 3, plotCI = c(“n”, “square”, “circle”, “rect”), lowCI.mat = NULL, uppCI.mat = NULL, na.label = “?”, na.label.col = “black”, …)
部分参数:
corr:需要可视化的相关系数矩阵
method:指定可视化的方法,可以是圆形、方形、椭圆形、数值、阴影、颜色或饼图形
type:指定展示的方式,可以是完全的、下三角或上三角
col:指定图形展示的颜色,默认以均匀的颜色展示
bg:指定图的背景色
title:为图形添加标题
is.corr:是否为相关系数绘图,默认为TRUE,同样也可以实现非相关系数的可视化,只需使该参数设为FALSE即可
diag:是否展示对角线上的结果,默认为TRUE
outline:是否绘制圆形、方形或椭圆形的轮廓,默认为FALSE
mar:具体设置图形的四边间距
addgrid.col:当选择的方法为颜色或阴影时,默认的网格线颜色为白色,否则为灰色
addCoef.col:为相关系数添加颜色,默认不添加相关系数,只有方法为number时,该参数才起作用
addCoefasPercent:为节省绘图空间,是否将相关系数转换为百分比格式,默认为FALSE
order:指定相关系数排序的方法,可以是原始顺序(original)、特征向量角序(AOE)、第一主成分顺序(FPC)、层次聚类顺序(hclust)和字母顺序,一般”AOE”排序结果都比”FPC”要好
hclust.method:当order为hclust时,该参数可以是层次聚类中ward法、最大距离法等7种之一
addrect:当order为hclust时,可以为添加相关系数图添加矩形框,默认不添加框,如果想添加框时,只需为该参数指定一个整数即可
rect.col:指定矩形框的颜色
rect.lwd:指定矩形框的线宽
tl.pos:指定文本标签(变量名称)的位置,当type=full时,默认标签位置在左边和顶部(lt),当type=lower时,默认标签在左边和对角线(ld),当type=upper时,默认标签在顶部和对角线,d表示对角线,n表示不添加文本标签
tl.cex:指定文本标签的大小
tl.col:指定文本标签的颜色
cl.pos:图例(颜色)位置,当type=upper或full时,图例在右表(r),当type=lower时,图例在底部,不需要图例时,只需指定该参数为n
addshade:只有当method=shade时,该参数才有用,参数值可以是negtive/positive和all,分表表示对负相关系数、正相关系数和所有相关系数添加阴影。注意:正相关系数的阴影是45度,负相关系数的阴影是135度
shade.lwd:指定阴影的线宽
shade.col:指定阴影线的颜色
虽然该函数的参数比较多,但可以组合各种参数,灵活实现各种各样的相关系数图。下面就举几个例子:
代码为:
install.packages("corrplot") library(corrplot) mf_cor<-cor(mtcars) #计算相关系数矩阵 col3 <- colorRampPalette(c("blue", "white", "red")) #自定义指定梯度颜色 corrgram也可以指定 参见《R语言实战》第一版 P259 cor.plot <- corrplot(corr = mf_cor,col=col3(10),type="upper",tl.pos="d",tl.cex = 0.75) #画右上方 方法默认“圆形“ cor.plot <- corrplot(corr = mf_cor,add=TRUE, type="lower",col=col3(10),method="color",addCoef.col="black",diag=FALSE,tl.pos="n", cl.pos="n",number.cex = 0.7) #画左下方 方法 “颜色”
col=col3(10) #颜色为指定的梯度颜色 10个渐进梯度
type=”upper” #画右上方
tl.pos=”d” #指定文本标签(变量名称)的位置 画再对角线上
tl.cex = 0.75 #文本标签(变量名称)的大小,为默认的 0.75倍
number.cex = 0.7 #写在图中的相关系数文字的大小,为默认的0.7倍
其他例子:(复制的别人部分文章,数据用的mtcars[,1:7]) 下面部分可忽略
corr <- cor(mtcars[,1:7])
#参数全部默认情况下的相关系数图
corrplot(corr = corr)
#指定数值方法的相关系数图
corrplot(corr = corr, method=”number”, col=”black”, cl.pos=”n”)
#按照特征向量角序(AOE)排序相关系数图
corrplot(corr = corr, order = ‘AOE’)
#同时添加相关系数值
corrplot(corr = corr, order =”AOE”, addCoef.col=”grey”)
#选择方法为color
corrplot(corr = corr, method = ‘color’, order =”AOE”, addCoef.col=”grey”)
我觉得这幅图比上面的圆形图要清爽很多
#绘制圆形轮廓相关系数图
corrplot(corr = corr, col = wb, order=”AOE”, outline=TRUE, cl.pos=”n”)
这个图看起来非常像围棋
#自定义背景色
corrplot(corr = corr, col = wb, bg=”gold2″, order=”AOE”, cl.pos=”n”)
#混合方法之上三角为圆形,下三角为数字
corrplot(corr = corr,order=”AOE”,type=”upper”,tl.pos=”d”)
corrplot(corr = corr,add=TRUE, type=”lower”, method=”number”,order=”AOE”,diag=FALSE,tl.pos=”n”, cl.pos=”n”)
这幅图将颜色、圆的大小和数值型相关系数相结合,更容易发现变量之间的相关性
#混合方法之上三角为圆形,下三角为方形
corrplot(corr = corr,order=”AOE”,type=”upper”,tl.pos=”d”)
corrplot(corr = corr,add=TRUE, type=”lower”, method=”square”,order=”AOE”,diag=FALSE,tl.pos=”n”, cl.pos=”n”)
#混合方法之上三角为圆形,下三角为黑色数字
corrplot(corr = corr,order=”AOE”,type=”upper”,tl.pos=”tp”)
corrplot(corr = corr,add=TRUE, type=”lower”, method=”number”,order=”AOE”, col=”black”,diag=FALSE,tl.pos=”n”, cl.pos=”n”)
个人更倾向于上图的展现形式,既清爽又能很好的反映变量间的相关系数。
#以层次聚类法排序
corrplot(corr = corr, order=”hclust”)
#以层次聚类法排序,并绘制3个矩形框
corrplot(corr = corr, order=”hclust”, addrect = 3, rect.col = “black”)
另一部分例子:(不是用的mtcar数据,但代码和解释都可互用)
corrplot(M,method=”number”,col=”black”)
#仅计算相关系数的数值,不添加颜色信息
