可芸 發表於 2022-2-18 09:19:56

R语言两组变量特征相关关系热图绘制画法

<div id="navCategory"><h5 class="catalogue">目录</h5><ul class="first_class_ul"><li>准备数据</li><li>简单热图</li><li>只对列进行聚类</li><li>将相关系数显示在图上</li><li>在图上加上显著性标记</li></ul></div><p class="maodian"></p><h2>准备数据</h2>
<p>两组变量的数据可以像下面这样处理,分别保存在两个csv文件中。</p>
<div class="jb51code"><pre class="brush:ruby;">&gt; # 导入数据及数据预处理
&gt; setwd("D:/weixin/")
&gt; rows &lt;- read.csv("rows.csv")
&gt; cols &lt;- read.csv("cols.csv")
&gt; str(rows)
'data.frame':   100 obs. of6 variables:
$ r1: num476 482 640 452 308 ...
$ r2: num2059 1987 1952 1927 1854 ...
$ r3: num513 601 682 497 463 ...
$ r4: num2235 2114 2038 1945 1916 ...
$ r5: num433 376 525 395 238 ...
$ r6: num2028 1943 1802 1775 1748 ...
&gt; str(cols)
'data.frame':   100 obs. of5 variables:
$ c1: num2387 2437 2484 2349 2198 ...
$ c2: num540 535 706 509 359 ...
$ c3: num472 610 465 473 471 ...
$ c4: num74.4 57.3 49.5 51.8 47.6 ...
$ c5: num995 915 1038 794 652 ...
</pre></div>
<p class="maodian"></p><h2>简单热图</h2>
<div class="jb51code"><pre class="brush:ruby;">&gt; # 构建相关关系矩阵
&gt; library(psych)
&gt; data.corr &lt;- corr.test(rows, cols, method="pearson", adjust="fdr")
&gt; data.r &lt;- data.corr$r# 相关系数
&gt; data.p &lt;- data.corr$p# p值
&gt;
&gt; # 画热图
&gt; library(pheatmap)
&gt; pheatmap(data.r, clustering_method="average")
</pre></div>
<p style="text-align:center"><img alt="在这里插入图片描述" src="https://img.jbzj.com/file_images/article/202202/2022021808590611.png" /></p>
<p class="maodian"></p><h2>只对列进行聚类</h2>
<div class="jb51code"><pre class="brush:ruby;">&gt; pheatmap(data.r, clustering_method="average", cluster_rows=F)
</pre></div>
<p style="text-align:center"><img alt="在这里插入图片描述" src="https://img.jbzj.com/file_images/article/202202/2022021808590612.png" /></p>
<p class="maodian"></p><h2>将相关系数显示在图上</h2>
<div class="jb51code"><pre class="brush:ruby;">&gt; data.r.fmt &lt;- matrix(sprintf("%.2f", data.r), nrow=nrow(data.p))# 只保留小数点后两位
&gt; pheatmap(data.r, clustering_method="average", cluster_rows=F, display_numbers=data.r.fmt)
</pre></div>
<p style="text-align:center"><img alt="在这里插入图片描述" src="https://img.jbzj.com/file_images/article/202202/2022021808590613.png" /></p>
<p class="maodian"></p><h2>在图上加上显著性标记</h2>
<div class="jb51code"><pre class="brush:ruby;">&gt; getSig &lt;- function(dc) {
+   sc &lt;- ''
+   if (dc &lt; 0.01) sc &lt;- '***'
+   else if (dc &lt; 0.05) sc &lt;- '**'
+   else if (dc &lt; 0.1) sc &lt;- '*'
+   sc
+ }
&gt; sig.mat &lt;- matrix(sapply(data.p, getSig), nrow=nrow(data.p))
&gt; str(sig.mat)
chr "*" "***" "" "***" "***" "***" "***" "" "***" "**" ...
&gt; pheatmap(data.r, clustering_method="average", cluster_rows=F, display_numbers=sig.mat)
</pre></div>
<p style="text-align:center"><img alt="在这里插入图片描述" src="https://img.jbzj.com/file_images/article/202202/2022021808590614.png" /></p>
<p>如果想进一步改变图形效果,可以参考pheatmap函数的用法,修改相应的参数。比如:聚类方式改为complete,加上标题等。</p>
<div class="jb51code"><pre class="brush:ruby;">&gt; pheatmap(data.r, clustering_method="complete", cluster_rows=F, display_numbers=sig.mat, main="Corr Heatmap")
</pre></div>
<p style="text-align:center"><img alt="在这里插入图片描述" src="https://img.jbzj.com/file_images/article/202202/2022021808590615.png" /></p>
<p>以上就是R语言两组变量特征相关关系热图绘制画法的详细内容,更多关于R语言绘制相关关系热图的资料请关注琼殿技术社区其它相关文章!</p>
                           
                            <div class="art_xg">
                              <b>您可能感兴趣的文章:</b><ul><li>ComplexHeatmap绘制单个热图</li><li>R语言绘制corrplot相关热图分析美化示例及详细图解</li><li>R语言数据可视化绘图bar&nbsp;chart条形图实现示例</li><li>R语言数据可视化绘图Lollipop chart棒棒糖图</li><li>R语言绘图数据可视化Ridgeline&nbsp;plot山脊图画法</li><li>R语言ComplexHeatmap绘制复杂热图heatmap</li></ul>
                            </div>

                        </div>
                        <!--endmain-->
頁: [1]
查看完整版本: R语言两组变量特征相关关系热图绘制画法