821 lines
666 KiB
HTML
Raw Permalink Normal View History

2025-01-12 00:52:51 +08:00
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="generator" content="pandoc" />
<meta http-equiv="X-UA-Compatible" content="IE=EDGE" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<meta name="author" content="Tal Galili" />
<meta name="date" content="2024-11-15" />
<title>Frequently asked questions</title>
<script>// Pandoc 2.9 adds attributes on both header and div. We remove the former (to
// be compatible with the behavior of Pandoc < 2.8).
document.addEventListener('DOMContentLoaded', function(e) {
var hs = document.querySelectorAll("div.section[class*='level'] > :first-child");
var i, h, a;
for (i = 0; i < hs.length; i++) {
h = hs[i];
if (!/^h[1-6]$/i.test(h.tagName)) continue; // it should be a header h1-h6
a = h.attributes;
while (a.length > 0) h.removeAttribute(a[0].name);
}
});
</script>
<style type="text/css">
code{white-space: pre-wrap;}
span.smallcaps{font-variant: small-caps;}
span.underline{text-decoration: underline;}
div.column{display: inline-block; vertical-align: top; width: 50%;}
div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;}
ul.task-list{list-style: none;}
</style>
<style type="text/css">
code {
white-space: pre;
}
.sourceCode {
overflow: visible;
}
</style>
<style type="text/css" data-origin="pandoc">
pre > code.sourceCode { white-space: pre; position: relative; }
pre > code.sourceCode > span { line-height: 1.25; }
pre > code.sourceCode > span:empty { height: 1.2em; }
.sourceCode { overflow: visible; }
code.sourceCode > span { color: inherit; text-decoration: inherit; }
div.sourceCode { margin: 1em 0; }
pre.sourceCode { margin: 0; }
@media screen {
div.sourceCode { overflow: auto; }
}
@media print {
pre > code.sourceCode { white-space: pre-wrap; }
pre > code.sourceCode > span { display: inline-block; text-indent: -5em; padding-left: 5em; }
}
pre.numberSource code
{ counter-reset: source-line 0; }
pre.numberSource code > span
{ position: relative; left: -4em; counter-increment: source-line; }
pre.numberSource code > span > a:first-child::before
{ content: counter(source-line);
position: relative; left: -1em; text-align: right; vertical-align: baseline;
border: none; display: inline-block;
-webkit-touch-callout: none; -webkit-user-select: none;
-khtml-user-select: none; -moz-user-select: none;
-ms-user-select: none; user-select: none;
padding: 0 4px; width: 4em;
color: #aaaaaa;
}
pre.numberSource { margin-left: 3em; border-left: 1px solid #aaaaaa; padding-left: 4px; }
div.sourceCode
{ }
@media screen {
pre > code.sourceCode > span > a:first-child::before { text-decoration: underline; }
}
code span.al { color: #ff0000; font-weight: bold; }
code span.an { color: #60a0b0; font-weight: bold; font-style: italic; }
code span.at { color: #7d9029; }
code span.bn { color: #40a070; }
code span.bu { color: #008000; }
code span.cf { color: #007020; font-weight: bold; }
code span.ch { color: #4070a0; }
code span.cn { color: #880000; }
code span.co { color: #60a0b0; font-style: italic; }
code span.cv { color: #60a0b0; font-weight: bold; font-style: italic; }
code span.do { color: #ba2121; font-style: italic; }
code span.dt { color: #902000; }
code span.dv { color: #40a070; }
code span.er { color: #ff0000; font-weight: bold; }
code span.ex { }
code span.fl { color: #40a070; }
code span.fu { color: #06287e; }
code span.im { color: #008000; font-weight: bold; }
code span.in { color: #60a0b0; font-weight: bold; font-style: italic; }
code span.kw { color: #007020; font-weight: bold; }
code span.op { color: #666666; }
code span.ot { color: #007020; }
code span.pp { color: #bc7a00; }
code span.sc { color: #4070a0; }
code span.ss { color: #bb6688; }
code span.st { color: #4070a0; }
code span.va { color: #19177c; }
code span.vs { color: #4070a0; }
code span.wa { color: #60a0b0; font-weight: bold; font-style: italic; }
</style>
<script>
// apply pandoc div.sourceCode style to pre.sourceCode instead
(function() {
var sheets = document.styleSheets;
for (var i = 0; i < sheets.length; i++) {
if (sheets[i].ownerNode.dataset["origin"] !== "pandoc") continue;
try { var rules = sheets[i].cssRules; } catch (e) { continue; }
var j = 0;
while (j < rules.length) {
var rule = rules[j];
// check if there is a div.sourceCode rule
if (rule.type !== rule.STYLE_RULE || rule.selectorText !== "div.sourceCode") {
j++;
continue;
}
var style = rule.style.cssText;
// check if color or background-color is set
if (rule.style.color === '' && rule.style.backgroundColor === '') {
j++;
continue;
}
// replace div.sourceCode by a pre.sourceCode rule
sheets[i].deleteRule(j);
sheets[i].insertRule('pre.sourceCode{' + style + '}', j);
}
}
})();
</script>
<style type="text/css">body {
background-color: #fff;
margin: 1em auto;
max-width: 700px;
overflow: visible;
padding-left: 2em;
padding-right: 2em;
font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
font-size: 14px;
line-height: 1.35;
}
#TOC {
clear: both;
margin: 0 0 10px 10px;
padding: 4px;
width: 400px;
border: 1px solid #CCCCCC;
border-radius: 5px;
background-color: #f6f6f6;
font-size: 13px;
line-height: 1.3;
}
#TOC .toctitle {
font-weight: bold;
font-size: 15px;
margin-left: 5px;
}
#TOC ul {
padding-left: 40px;
margin-left: -1.5em;
margin-top: 5px;
margin-bottom: 5px;
}
#TOC ul ul {
margin-left: -2em;
}
#TOC li {
line-height: 16px;
}
table {
margin: 1em auto;
border-width: 1px;
border-color: #DDDDDD;
border-style: outset;
border-collapse: collapse;
}
table th {
border-width: 2px;
padding: 5px;
border-style: inset;
}
table td {
border-width: 1px;
border-style: inset;
line-height: 18px;
padding: 5px 5px;
}
table, table th, table td {
border-left-style: none;
border-right-style: none;
}
table thead, table tr.even {
background-color: #f7f7f7;
}
p {
margin: 0.5em 0;
}
blockquote {
background-color: #f6f6f6;
padding: 0.25em 0.75em;
}
hr {
border-style: solid;
border: none;
border-top: 1px solid #777;
margin: 28px 0;
}
dl {
margin-left: 0;
}
dl dd {
margin-bottom: 13px;
margin-left: 13px;
}
dl dt {
font-weight: bold;
}
ul {
margin-top: 0;
}
ul li {
list-style: circle outside;
}
ul ul {
margin-bottom: 0;
}
pre, code {
background-color: #f7f7f7;
border-radius: 3px;
color: #333;
white-space: pre-wrap;
}
pre {
border-radius: 3px;
margin: 5px 0px 10px 0px;
padding: 10px;
}
pre:not([class]) {
background-color: #f7f7f7;
}
code {
font-family: Consolas, Monaco, 'Courier New', monospace;
font-size: 85%;
}
p > code, li > code {
padding: 2px 0px;
}
div.figure {
text-align: center;
}
img {
background-color: #FFFFFF;
padding: 2px;
border: 1px solid #DDDDDD;
border-radius: 3px;
border: 1px solid #CCCCCC;
margin: 0 5px;
}
h1 {
margin-top: 0;
font-size: 35px;
line-height: 40px;
}
h2 {
border-bottom: 4px solid #f7f7f7;
padding-top: 10px;
padding-bottom: 2px;
font-size: 145%;
}
h3 {
border-bottom: 2px solid #f7f7f7;
padding-top: 10px;
font-size: 120%;
}
h4 {
border-bottom: 1px solid #f7f7f7;
margin-left: 8px;
font-size: 105%;
}
h5, h6 {
border-bottom: 1px solid #ccc;
font-size: 105%;
}
a {
color: #0033dd;
text-decoration: none;
}
a:hover {
color: #6666ff; }
a:visited {
color: #800080; }
a:visited:hover {
color: #BB00BB; }
a[href^="http:"] {
text-decoration: underline; }
a[href^="https:"] {
text-decoration: underline; }
code > span.kw { color: #555; font-weight: bold; }
code > span.dt { color: #902000; }
code > span.dv { color: #40a070; }
code > span.bn { color: #d14; }
code > span.fl { color: #d14; }
code > span.ch { color: #d14; }
code > span.st { color: #d14; }
code > span.co { color: #888888; font-style: italic; }
code > span.ot { color: #007020; }
code > span.al { color: #ff0000; font-weight: bold; }
code > span.fu { color: #900; font-weight: bold; }
code > span.er { color: #a61717; background-color: #e3d2d2; }
</style>
</head>
<body>
<h1 class="title toc-ignore">Frequently asked questions</h1>
<h4 class="author">Tal Galili</h4>
<h4 class="date">2024-11-15</h4>
<div id="TOC">
<ul>
<li><a href="#introduction" id="toc-introduction">Introduction</a>
<ul>
<li><a href="#how-to-colour-the-labels-of-a-dendrogram-by-an-additional-factor-variable" id="toc-how-to-colour-the-labels-of-a-dendrogram-by-an-additional-factor-variable">How
to colour the labels of a dendrogram by an additional factor
variable</a></li>
<li><a href="#how-to-color-a-dendrograms-labels-according-to-defined-groups-in-r" id="toc-how-to-color-a-dendrograms-labels-according-to-defined-groups-in-r">How
to color a dendrograms labels according to defined groups? (in
R)</a></li>
<li><a href="#how-to-color-a-dendrograms-brancheslabels-based-on-cluster-i.e.-cutree-result" id="toc-how-to-color-a-dendrograms-brancheslabels-based-on-cluster-i.e.-cutree-result">How
to color a dendrograms branches/labels based on cluster (i.e.: cutree
result)</a></li>
<li><a href="#change-dendrograms-labels" id="toc-change-dendrograms-labels">Change dendrograms labels</a></li>
<li><a href="#larger-font-for-leaves-in-a-dendrogram" id="toc-larger-font-for-leaves-in-a-dendrogram">Larger font for leaves
in a dendrogram</a></li>
<li><a href="#how-to-view-attributes-of-a-dendrogram" id="toc-how-to-view-attributes-of-a-dendrogram">How to view attributes
of a dendrogram</a></li>
<li><a href="#how-to-color-the-branches-in-heatmap.2" id="toc-how-to-color-the-branches-in-heatmap.2">How to color the
branches in heatmap.2?</a></li>
<li><a href="#for-package-developers---how-to-call-imported-calls-from-dendextend-0.18.3" id="toc-for-package-developers---how-to-call-imported-calls-from-dendextend-0.18.3">For
package developers - how to call imported calls from dendextend
0.18.3?</a></li>
<li><a href="#how-to-plot-a-fan-polar-dendrogram-in-r" id="toc-how-to-plot-a-fan-polar-dendrogram-in-r">How to plot a fan
(Polar) Dendrogram in R?</a></li>
<li><a href="#a-way-to-calculate-lowest-value-of-h-in-cut-that-produces-groupings-of-a-given-minimum-size" id="toc-a-way-to-calculate-lowest-value-of-h-in-cut-that-produces-groupings-of-a-given-minimum-size">A
way to calculate lowest value of h in cut that produces groupings of a
given minimum size?</a></li>
<li><a href="#coloring-dendrograms-end-branches-or-leaves-based-on-column-number-of-data-frame-in-r" id="toc-coloring-dendrograms-end-branches-or-leaves-based-on-column-number-of-data-frame-in-r">Coloring
dendrograms end branches (or leaves) based on column number of data
frame in R</a></li>
<li><a href="#color-side-bar-dendrogram-plot" id="toc-color-side-bar-dendrogram-plot">Color side bar dendrogram
plot</a></li>
<li><a href="#plot-a-mirror-labels-on-the-left-horizontal-dendrogram" id="toc-plot-a-mirror-labels-on-the-left-horizontal-dendrogram">Plot a
“mirror” (labels on the left) horizontal dendrogram</a></li>
</ul></li>
</ul>
</div>
<!--
%\VignetteEngine{knitr::rmarkdown}
%\VignetteIndexEntry{Frequently asked questions}
-->
<div id="introduction" class="section level2">
<h2>Introduction</h2>
<p>Questions are often taken from here the <a href="https://stackoverflow.com/questions/tagged/dendrogram+r">stackoverflow
<code>dendrogram</code> tag</a>.</p>
<div id="how-to-colour-the-labels-of-a-dendrogram-by-an-additional-factor-variable" class="section level3">
<h3>How to colour the labels of a dendrogram by an additional factor
variable</h3>
<p>Asked (<a href="https://stackoverflow.com/questions/27485549/how-to-colour-the-labels-of-a-dendrogram-by-an-additional-factor-variable-in-r" class="uri">https://stackoverflow.com/questions/27485549/how-to-colour-the-labels-of-a-dendrogram-by-an-additional-factor-variable-in-r</a>)[here].</p>
<p>Solution: use the <code>labels_colors</code> function.</p>
<div class="sourceCode" id="cb1"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb1-1"><a href="#cb1-1" tabindex="-1"></a><span class="co"># install.packages(&quot;dendextend&quot;)</span></span>
<span id="cb1-2"><a href="#cb1-2" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb1-3"><a href="#cb1-3" tabindex="-1"></a></span>
<span id="cb1-4"><a href="#cb1-4" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(<span class="fu">hclust</span>(<span class="fu">dist</span>(USArrests[<span class="dv">1</span><span class="sc">:</span><span class="dv">5</span>,])))</span>
<span id="cb1-5"><a href="#cb1-5" tabindex="-1"></a><span class="co"># Like: </span></span>
<span id="cb1-6"><a href="#cb1-6" tabindex="-1"></a><span class="co"># dend &lt;- USArrests[1:5,] %&gt;% dist %&gt;% hclust %&gt;% as.dendrogram</span></span>
<span id="cb1-7"><a href="#cb1-7" tabindex="-1"></a></span>
<span id="cb1-8"><a href="#cb1-8" tabindex="-1"></a><span class="co"># By default, the dend has no colors to the labels</span></span>
<span id="cb1-9"><a href="#cb1-9" tabindex="-1"></a><span class="fu">labels_colors</span>(dend)</span></code></pre></div>
<pre><code>## NULL</code></pre>
<div class="sourceCode" id="cb3"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb3-1"><a href="#cb3-1" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mfrow =</span> <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">2</span>))</span>
<span id="cb3-2"><a href="#cb3-2" tabindex="-1"></a><span class="fu">plot</span>(dend, <span class="at">main =</span> <span class="st">&quot;Original dend&quot;</span>)</span>
<span id="cb3-3"><a href="#cb3-3" tabindex="-1"></a></span>
<span id="cb3-4"><a href="#cb3-4" tabindex="-1"></a><span class="co"># let&#39;s add some color:</span></span>
<span id="cb3-5"><a href="#cb3-5" tabindex="-1"></a><span class="fu">labels_colors</span>(dend) <span class="ot">&lt;-</span> <span class="dv">1</span><span class="sc">:</span><span class="dv">5</span></span>
<span id="cb3-6"><a href="#cb3-6" tabindex="-1"></a><span class="co"># Now each state has a color</span></span>
<span id="cb3-7"><a href="#cb3-7" tabindex="-1"></a><span class="fu">labels_colors</span>(dend) </span></code></pre></div>
<pre><code>## Arkansas Arizona California Alabama Alaska
## 1 2 3 4 5</code></pre>
<div class="sourceCode" id="cb5"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb5-1"><a href="#cb5-1" tabindex="-1"></a><span class="fu">plot</span>(dend, <span class="at">main =</span> <span class="st">&quot;A color for every state&quot;</span>)</span></code></pre></div>
<p><img role="img" src="
<p>Instead of using <code>1:5</code>, we can obviously use colors that
are based on another factor (organized): the labels themselves. But in
such a case, we want to map between the order of the labels and the
order of the items in the original dataset. Here is another example
based on the iris dataset:</p>
<div class="sourceCode" id="cb6"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb6-1"><a href="#cb6-1" tabindex="-1"></a><span class="co"># install.packages(&quot;dendextend&quot;)</span></span>
<span id="cb6-2"><a href="#cb6-2" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb6-3"><a href="#cb6-3" tabindex="-1"></a></span>
<span id="cb6-4"><a href="#cb6-4" tabindex="-1"></a>small_iris <span class="ot">&lt;-</span> iris[<span class="fu">c</span>(<span class="dv">1</span>, <span class="dv">51</span>, <span class="dv">101</span>, <span class="dv">2</span>, <span class="dv">52</span>, <span class="dv">102</span>), ]</span>
<span id="cb6-5"><a href="#cb6-5" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(<span class="fu">hclust</span>(<span class="fu">dist</span>(small_iris[,<span class="sc">-</span><span class="dv">5</span>])))</span>
<span id="cb6-6"><a href="#cb6-6" tabindex="-1"></a><span class="co"># Like: </span></span>
<span id="cb6-7"><a href="#cb6-7" tabindex="-1"></a><span class="co"># dend &lt;- small_iris[,-5] %&gt;% dist %&gt;% hclust %&gt;% as.dendrogram</span></span>
<span id="cb6-8"><a href="#cb6-8" tabindex="-1"></a></span>
<span id="cb6-9"><a href="#cb6-9" tabindex="-1"></a><span class="co"># By default, the dend has no colors to the labels</span></span>
<span id="cb6-10"><a href="#cb6-10" tabindex="-1"></a><span class="fu">labels_colors</span>(dend)</span></code></pre></div>
<pre><code>## NULL</code></pre>
<div class="sourceCode" id="cb8"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb8-1"><a href="#cb8-1" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mfrow =</span> <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">2</span>))</span>
<span id="cb8-2"><a href="#cb8-2" tabindex="-1"></a><span class="fu">plot</span>(dend, <span class="at">main =</span> <span class="st">&quot;Original dend&quot;</span>)</span>
<span id="cb8-3"><a href="#cb8-3" tabindex="-1"></a></span>
<span id="cb8-4"><a href="#cb8-4" tabindex="-1"></a><span class="co"># Let&#39;s add some color:</span></span>
<span id="cb8-5"><a href="#cb8-5" tabindex="-1"></a>colors_to_use <span class="ot">&lt;-</span> <span class="fu">as.numeric</span>(small_iris[,<span class="dv">5</span>])</span>
<span id="cb8-6"><a href="#cb8-6" tabindex="-1"></a>colors_to_use</span></code></pre></div>
<pre><code>## [1] 1 2 3 1 2 3</code></pre>
<div class="sourceCode" id="cb10"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb10-1"><a href="#cb10-1" tabindex="-1"></a><span class="co"># But sort them based on their order in dend:</span></span>
<span id="cb10-2"><a href="#cb10-2" tabindex="-1"></a>colors_to_use <span class="ot">&lt;-</span> colors_to_use[<span class="fu">order.dendrogram</span>(dend)]</span>
<span id="cb10-3"><a href="#cb10-3" tabindex="-1"></a>colors_to_use</span></code></pre></div>
<pre><code>## [1] 1 1 2 2 3 3</code></pre>
<div class="sourceCode" id="cb12"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb12-1"><a href="#cb12-1" tabindex="-1"></a><span class="co"># Now we can use them</span></span>
<span id="cb12-2"><a href="#cb12-2" tabindex="-1"></a><span class="fu">labels_colors</span>(dend) <span class="ot">&lt;-</span> colors_to_use</span>
<span id="cb12-3"><a href="#cb12-3" tabindex="-1"></a><span class="co"># Now each state has a color</span></span>
<span id="cb12-4"><a href="#cb12-4" tabindex="-1"></a><span class="fu">labels_colors</span>(dend) </span></code></pre></div>
<pre><code>## 1 2 51 52 101 102
## 1 1 2 2 3 3</code></pre>
<div class="sourceCode" id="cb14"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb14-1"><a href="#cb14-1" tabindex="-1"></a><span class="fu">plot</span>(dend, <span class="at">main =</span> <span class="st">&quot;A color for every Species&quot;</span>)</span></code></pre></div>
<p><img role="img" src="
</div>
<div id="how-to-color-a-dendrograms-labels-according-to-defined-groups-in-r" class="section level3">
<h3>How to color a dendrograms labels according to defined groups? (in
R)</h3>
<p>Asked (<a href="https://stackoverflow.com/questions/31117849/how-to-color-a-dendrograms-labels-according-to-defined-groups-in-r" class="uri">https://stackoverflow.com/questions/31117849/how-to-color-a-dendrograms-labels-according-to-defined-groups-in-r</a>)[here].</p>
<p>Solution: use the <code>color_labels</code> function.</p>
<p>I suspect the function you are looking for is either
<code>color_labels</code> or <code>get_leaves_branches_col</code>. The
first color your labels based on <code>cutree</code> (like
<code>color_branches</code> do) and the second allows you to get the
colors of the branch of each leaf, and then use it to color the labels
of the tree (if you use unusual methods for coloring the branches (as
happens when using <code>branches_attr_by_labels</code>). For
example:</p>
<div class="sourceCode" id="cb15"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb15-1"><a href="#cb15-1" tabindex="-1"></a> <span class="co"># define dendrogram object to play with:</span></span>
<span id="cb15-2"><a href="#cb15-2" tabindex="-1"></a> hc <span class="ot">&lt;-</span> <span class="fu">hclust</span>(<span class="fu">dist</span>(USArrests[<span class="dv">1</span><span class="sc">:</span><span class="dv">5</span>,]), <span class="st">&quot;ave&quot;</span>)</span>
<span id="cb15-3"><a href="#cb15-3" tabindex="-1"></a> dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(hc)</span>
<span id="cb15-4"><a href="#cb15-4" tabindex="-1"></a></span>
<span id="cb15-5"><a href="#cb15-5" tabindex="-1"></a> <span class="fu">library</span>(dendextend)</span>
<span id="cb15-6"><a href="#cb15-6" tabindex="-1"></a> <span class="fu">par</span>(<span class="at">mfrow =</span> <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">2</span>), <span class="at">mar =</span> <span class="fu">c</span>(<span class="dv">5</span>,<span class="dv">2</span>,<span class="dv">1</span>,<span class="dv">0</span>))</span>
<span id="cb15-7"><a href="#cb15-7" tabindex="-1"></a> dend <span class="ot">&lt;-</span> dend <span class="sc">%&gt;%</span></span>
<span id="cb15-8"><a href="#cb15-8" tabindex="-1"></a> <span class="fu">color_branches</span>(<span class="at">k =</span> <span class="dv">3</span>) <span class="sc">%&gt;%</span></span>
<span id="cb15-9"><a href="#cb15-9" tabindex="-1"></a> <span class="fu">set</span>(<span class="st">&quot;branches_lwd&quot;</span>, <span class="fu">c</span>(<span class="dv">2</span>,<span class="dv">1</span>,<span class="dv">2</span>)) <span class="sc">%&gt;%</span></span>
<span id="cb15-10"><a href="#cb15-10" tabindex="-1"></a> <span class="fu">set</span>(<span class="st">&quot;branches_lty&quot;</span>, <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">2</span>,<span class="dv">1</span>))</span>
<span id="cb15-11"><a href="#cb15-11" tabindex="-1"></a> </span>
<span id="cb15-12"><a href="#cb15-12" tabindex="-1"></a> <span class="fu">plot</span>(dend)</span>
<span id="cb15-13"><a href="#cb15-13" tabindex="-1"></a></span>
<span id="cb15-14"><a href="#cb15-14" tabindex="-1"></a> dend <span class="ot">&lt;-</span> <span class="fu">color_labels</span>(dend, <span class="at">k =</span> <span class="dv">3</span>)</span>
<span id="cb15-15"><a href="#cb15-15" tabindex="-1"></a> <span class="co"># The same as:</span></span>
<span id="cb15-16"><a href="#cb15-16" tabindex="-1"></a> <span class="co"># labels_colors(dend) &lt;- get_leaves_branches_col(dend)</span></span>
<span id="cb15-17"><a href="#cb15-17" tabindex="-1"></a> <span class="fu">plot</span>(dend)</span></code></pre></div>
<p><img role="img" src="
<p>Either way, you should always have a look at the <code>set</code>
function, for ideas on what can be done to your dendrogram (this saves
the hassle of remembering all the different functions names).</p>
</div>
<div id="how-to-color-a-dendrograms-brancheslabels-based-on-cluster-i.e.-cutree-result" class="section level3">
<h3>How to color a dendrograms branches/labels based on cluster (i.e.:
cutree result)</h3>
<p>Use the <code>color_branches</code> and <code>color_labels</code>
functions, with the <code>k</code> (or<code>h</code>) parameter:</p>
<div class="sourceCode" id="cb16"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb16-1"><a href="#cb16-1" tabindex="-1"></a><span class="co"># install.packages(&quot;dendextend&quot;)</span></span>
<span id="cb16-2"><a href="#cb16-2" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb16-3"><a href="#cb16-3" tabindex="-1"></a></span>
<span id="cb16-4"><a href="#cb16-4" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(<span class="fu">hclust</span>(<span class="fu">dist</span>(USArrests[<span class="dv">1</span><span class="sc">:</span><span class="dv">5</span>,])))</span>
<span id="cb16-5"><a href="#cb16-5" tabindex="-1"></a><span class="co"># Like: </span></span>
<span id="cb16-6"><a href="#cb16-6" tabindex="-1"></a><span class="co"># dend &lt;- USArrests[1:5,] %&gt;% dist %&gt;% hclust %&gt;% as.dendrogram</span></span>
<span id="cb16-7"><a href="#cb16-7" tabindex="-1"></a></span>
<span id="cb16-8"><a href="#cb16-8" tabindex="-1"></a>dend1 <span class="ot">&lt;-</span> <span class="fu">color_branches</span>(dend, <span class="at">k =</span> <span class="dv">3</span>)</span>
<span id="cb16-9"><a href="#cb16-9" tabindex="-1"></a>dend2 <span class="ot">&lt;-</span> <span class="fu">color_labels</span>(dend, <span class="at">k =</span> <span class="dv">3</span>)</span>
<span id="cb16-10"><a href="#cb16-10" tabindex="-1"></a></span>
<span id="cb16-11"><a href="#cb16-11" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mfrow =</span> <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">2</span>))</span>
<span id="cb16-12"><a href="#cb16-12" tabindex="-1"></a><span class="fu">plot</span>(dend1, <span class="at">main =</span> <span class="st">&quot;Colored branches&quot;</span>)</span>
<span id="cb16-13"><a href="#cb16-13" tabindex="-1"></a><span class="fu">plot</span>(dend2, <span class="at">main =</span> <span class="st">&quot;Colored labels&quot;</span>)</span></code></pre></div>
<p><img role="img" src="
</div>
<div id="change-dendrograms-labels" class="section level3">
<h3>Change dendrograms labels</h3>
<p>Use the left assign <code>labels&lt;-</code> function:</p>
<div class="sourceCode" id="cb17"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb17-1"><a href="#cb17-1" tabindex="-1"></a><span class="co"># install.packages(&quot;dendextend&quot;)</span></span>
<span id="cb17-2"><a href="#cb17-2" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb17-3"><a href="#cb17-3" tabindex="-1"></a></span>
<span id="cb17-4"><a href="#cb17-4" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(<span class="fu">hclust</span>(<span class="fu">dist</span>(USArrests[<span class="dv">1</span><span class="sc">:</span><span class="dv">5</span>,])))</span>
<span id="cb17-5"><a href="#cb17-5" tabindex="-1"></a><span class="co"># Like: </span></span>
<span id="cb17-6"><a href="#cb17-6" tabindex="-1"></a><span class="co"># dend &lt;- USArrests[1:5,] %&gt;% dist %&gt;% hclust %&gt;% as.dendrogram</span></span>
<span id="cb17-7"><a href="#cb17-7" tabindex="-1"></a></span>
<span id="cb17-8"><a href="#cb17-8" tabindex="-1"></a><span class="fu">labels</span>(dend)</span></code></pre></div>
<pre><code>## [1] &quot;Arkansas&quot; &quot;Arizona&quot; &quot;California&quot; &quot;Alabama&quot; &quot;Alaska&quot;</code></pre>
<div class="sourceCode" id="cb19"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb19-1"><a href="#cb19-1" tabindex="-1"></a><span class="fu">labels</span>(dend) <span class="ot">&lt;-</span> <span class="dv">1</span><span class="sc">:</span><span class="dv">5</span></span>
<span id="cb19-2"><a href="#cb19-2" tabindex="-1"></a><span class="fu">labels</span>(dend)</span></code></pre></div>
<pre><code>## [1] 1 2 3 4 5</code></pre>
</div>
<div id="larger-font-for-leaves-in-a-dendrogram" class="section level3">
<h3>Larger font for leaves in a dendrogram</h3>
<p>Asked (<a href="https://stackoverflow.com/questions/26965390/larger-font-and-spacing-between-leaves-in-r-dendrogram" class="uri">https://stackoverflow.com/questions/26965390/larger-font-and-spacing-between-leaves-in-r-dendrogram</a>)[here].</p>
<p>Solution: use the <code>set</code> function, with the “labels_cex”
parameter.</p>
<div class="sourceCode" id="cb21"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb21-1"><a href="#cb21-1" tabindex="-1"></a><span class="co"># install.packages(&quot;dendextend&quot;)</span></span>
<span id="cb21-2"><a href="#cb21-2" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb21-3"><a href="#cb21-3" tabindex="-1"></a></span>
<span id="cb21-4"><a href="#cb21-4" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(<span class="fu">hclust</span>(<span class="fu">dist</span>(USArrests[<span class="dv">1</span><span class="sc">:</span><span class="dv">5</span>,])))</span>
<span id="cb21-5"><a href="#cb21-5" tabindex="-1"></a><span class="co"># Like: </span></span>
<span id="cb21-6"><a href="#cb21-6" tabindex="-1"></a><span class="co"># dend &lt;- USArrests[1:5,] %&gt;% dist %&gt;% hclust %&gt;% as.dendrogram</span></span>
<span id="cb21-7"><a href="#cb21-7" tabindex="-1"></a></span>
<span id="cb21-8"><a href="#cb21-8" tabindex="-1"></a><span class="co"># By default, the dend has no text size to it (showing only the first leaf)</span></span>
<span id="cb21-9"><a href="#cb21-9" tabindex="-1"></a><span class="fu">get_leaves_nodePar</span>(dend)[[<span class="dv">1</span>]]</span></code></pre></div>
<pre><code>## [1] NA</code></pre>
<div class="sourceCode" id="cb23"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb23-1"><a href="#cb23-1" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mfrow =</span> <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">2</span>), <span class="at">mar =</span> <span class="fu">c</span>(<span class="dv">10</span>,<span class="dv">4</span>,<span class="dv">4</span>,<span class="dv">2</span>))</span>
<span id="cb23-2"><a href="#cb23-2" tabindex="-1"></a><span class="fu">plot</span>(dend, <span class="at">main =</span> <span class="st">&quot;Original dend&quot;</span>)</span>
<span id="cb23-3"><a href="#cb23-3" tabindex="-1"></a></span>
<span id="cb23-4"><a href="#cb23-4" tabindex="-1"></a><span class="co"># let&#39;s increase the size of the labels:</span></span>
<span id="cb23-5"><a href="#cb23-5" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">set</span>(dend, <span class="st">&quot;labels_cex&quot;</span>, <span class="dv">2</span>)</span>
<span id="cb23-6"><a href="#cb23-6" tabindex="-1"></a><span class="co"># Now each state has a larger label</span></span>
<span id="cb23-7"><a href="#cb23-7" tabindex="-1"></a><span class="fu">get_leaves_nodePar</span>(dend)[[<span class="dv">1</span>]]</span></code></pre></div>
<pre><code>## $lab.cex
## [1] 2
##
## $pch
## [1] NA</code></pre>
<div class="sourceCode" id="cb25"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb25-1"><a href="#cb25-1" tabindex="-1"></a><span class="fu">plot</span>(dend, <span class="at">main =</span> <span class="st">&quot;A larger font for labels&quot;</span>)</span></code></pre></div>
<p><img role="img" src="
<p>(Note that changing the spacing between the labels is currently not
implemented)</p>
</div>
<div id="how-to-view-attributes-of-a-dendrogram" class="section level3">
<h3>How to view attributes of a dendrogram</h3>
<p>Asked (<a href="https://stackoverflow.com/questions/26240200/how-to-access-attributes-of-a-dendrogram-in-r" class="uri">https://stackoverflow.com/questions/26240200/how-to-access-attributes-of-a-dendrogram-in-r</a>)[here],
and (<a href="https://stackoverflow.com/questions/25664911/r-hclust-height-of-final-merge" class="uri">https://stackoverflow.com/questions/25664911/r-hclust-height-of-final-merge</a>)[here].</p>
<p>It generally depends on which attribute we want to view. For
“midpoint” (or height) use the <code>get_nodes_attr</code> function,
with the “midpoint” parameter.</p>
<div class="sourceCode" id="cb26"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb26-1"><a href="#cb26-1" tabindex="-1"></a><span class="co"># install.packages(&quot;dendextend&quot;)</span></span>
<span id="cb26-2"><a href="#cb26-2" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb26-3"><a href="#cb26-3" tabindex="-1"></a></span>
<span id="cb26-4"><a href="#cb26-4" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(<span class="fu">hclust</span>(<span class="fu">dist</span>(USArrests[<span class="dv">1</span><span class="sc">:</span><span class="dv">5</span>,])))</span>
<span id="cb26-5"><a href="#cb26-5" tabindex="-1"></a><span class="co"># Like: </span></span>
<span id="cb26-6"><a href="#cb26-6" tabindex="-1"></a><span class="co"># dend &lt;- USArrests[1:5,] %&gt;% dist %&gt;% hclust %&gt;% as.dendrogram</span></span>
<span id="cb26-7"><a href="#cb26-7" tabindex="-1"></a></span>
<span id="cb26-8"><a href="#cb26-8" tabindex="-1"></a><span class="co"># midpoint for all nodes</span></span>
<span id="cb26-9"><a href="#cb26-9" tabindex="-1"></a><span class="fu">get_nodes_attr</span>(dend, <span class="st">&quot;midpoint&quot;</span>)</span></code></pre></div>
<pre><code>## [1] 1.25 NA 1.50 0.50 NA NA 0.50 NA NA</code></pre>
<div class="sourceCode" id="cb28"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb28-1"><a href="#cb28-1" tabindex="-1"></a><span class="co"># Perhaps also for the height:</span></span>
<span id="cb28-2"><a href="#cb28-2" tabindex="-1"></a><span class="fu">get_nodes_attr</span>(dend, <span class="st">&quot;height&quot;</span>)</span></code></pre></div>
<pre><code>## [1] 108.85192 0.00000 63.00833 23.19418 0.00000 0.00000 37.17701
## [8] 0.00000 0.00000</code></pre>
<p>To also change an attribute, you can use the various assign functions
from the package: <code>assign_values_to_leaves_nodePar</code>,
<code>assign_values_to_leaves_edgePar</code>,
<code>assign_values_to_nodes_nodePar</code>,
<code>assign_values_to_branches_edgePar</code>,
<code>remove_branches_edgePar</code>,
<code>remove_nodes_nodePar</code></p>
</div>
<div id="how-to-color-the-branches-in-heatmap.2" class="section level3">
<h3>How to color the branches in heatmap.2?</h3>
<p>Asked (<a href="https://stackoverflow.com/questions/29265536/how-to-color-the-branches-and-tick-labels-in-the-heatmap-2" class="uri">https://stackoverflow.com/questions/29265536/how-to-color-the-branches-and-tick-labels-in-the-heatmap-2</a>?)[here].</p>
<p>Solution: use the <code>color_branches</code> function (or the
<code>set</code> function, with the “branches_k_color”, “k”, and “value”
parameters).</p>
<p>(Getting the data for this example is from the (<a href="https://stackoverflow.com/questions/29265536/how-to-color-the-branches-and-tick-labels-in-the-heatmap-2" class="uri">https://stackoverflow.com/questions/29265536/how-to-color-the-branches-and-tick-labels-in-the-heatmap-2</a>)[original
SO question])</p>
<div class="sourceCode" id="cb30"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb30-1"><a href="#cb30-1" tabindex="-1"></a>test <span class="ot">&lt;-</span> test0</span>
<span id="cb30-2"><a href="#cb30-2" tabindex="-1"></a>rnames <span class="ot">&lt;-</span> test[,<span class="dv">1</span>] </span>
<span id="cb30-3"><a href="#cb30-3" tabindex="-1"></a>test <span class="ot">&lt;-</span> <span class="fu">data.matrix</span>(test[,<span class="dv">2</span><span class="sc">:</span><span class="fu">ncol</span>(test)]) <span class="co"># to matrix</span></span>
<span id="cb30-4"><a href="#cb30-4" tabindex="-1"></a><span class="fu">rownames</span>(test) <span class="ot">&lt;-</span> rnames </span>
<span id="cb30-5"><a href="#cb30-5" tabindex="-1"></a>test <span class="ot">&lt;-</span> <span class="fu">scale</span>(test, <span class="at">center=</span>T, <span class="at">scale=</span>T) <span class="co"># data standarization</span></span>
<span id="cb30-6"><a href="#cb30-6" tabindex="-1"></a>test <span class="ot">&lt;-</span> <span class="fu">t</span>(test) <span class="co"># transpose</span></span>
<span id="cb30-7"><a href="#cb30-7" tabindex="-1"></a></span>
<span id="cb30-8"><a href="#cb30-8" tabindex="-1"></a></span>
<span id="cb30-9"><a href="#cb30-9" tabindex="-1"></a><span class="do">## Creating a color palette &amp; color breaks</span></span>
<span id="cb30-10"><a href="#cb30-10" tabindex="-1"></a></span>
<span id="cb30-11"><a href="#cb30-11" tabindex="-1"></a>my_palette <span class="ot">&lt;-</span> <span class="fu">colorRampPalette</span>(<span class="fu">c</span>(<span class="st">&quot;forestgreen&quot;</span>, <span class="st">&quot;yellow&quot;</span>, <span class="st">&quot;red&quot;</span>))(<span class="at">n =</span> <span class="dv">299</span>)</span>
<span id="cb30-12"><a href="#cb30-12" tabindex="-1"></a></span>
<span id="cb30-13"><a href="#cb30-13" tabindex="-1"></a>col_breaks <span class="ot">=</span> <span class="fu">c</span>(<span class="fu">seq</span>(<span class="sc">-</span><span class="dv">1</span>,<span class="sc">-</span><span class="fl">0.5</span>,<span class="at">length=</span><span class="dv">100</span>), <span class="co"># forestgreen</span></span>
<span id="cb30-14"><a href="#cb30-14" tabindex="-1"></a> <span class="fu">seq</span>(<span class="sc">-</span><span class="fl">0.5</span>,<span class="fl">0.5</span>,<span class="at">length=</span><span class="dv">100</span>), <span class="co"># yellow</span></span>
<span id="cb30-15"><a href="#cb30-15" tabindex="-1"></a> <span class="fu">seq</span>(<span class="fl">0.5</span>,<span class="dv">1</span>,<span class="at">length=</span><span class="dv">100</span>)) <span class="co"># red</span></span>
<span id="cb30-16"><a href="#cb30-16" tabindex="-1"></a></span>
<span id="cb30-17"><a href="#cb30-17" tabindex="-1"></a><span class="co"># distance &amp; hierarchical clustering</span></span>
<span id="cb30-18"><a href="#cb30-18" tabindex="-1"></a>distance <span class="ot">=</span> <span class="fu">dist</span>(test, <span class="at">method =</span><span class="st">&quot;euclidean&quot;</span>) </span>
<span id="cb30-19"><a href="#cb30-19" tabindex="-1"></a>hcluster <span class="ot">=</span> <span class="fu">hclust</span>(distance, <span class="at">method =</span><span class="st">&quot;ward.D&quot;</span>)</span>
<span id="cb30-20"><a href="#cb30-20" tabindex="-1"></a></span>
<span id="cb30-21"><a href="#cb30-21" tabindex="-1"></a></span>
<span id="cb30-22"><a href="#cb30-22" tabindex="-1"></a>dend1 <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(hcluster)</span>
<span id="cb30-23"><a href="#cb30-23" tabindex="-1"></a></span>
<span id="cb30-24"><a href="#cb30-24" tabindex="-1"></a><span class="co"># Get the dendextend package</span></span>
<span id="cb30-25"><a href="#cb30-25" tabindex="-1"></a><span class="cf">if</span>(<span class="sc">!</span><span class="fu">require</span>(dendextend)) <span class="fu">install.packages</span>(<span class="st">&quot;dendextend&quot;</span>)</span>
<span id="cb30-26"><a href="#cb30-26" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb30-27"><a href="#cb30-27" tabindex="-1"></a><span class="co"># get some colors</span></span>
<span id="cb30-28"><a href="#cb30-28" tabindex="-1"></a>cols_branches <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="st">&quot;darkred&quot;</span>, <span class="st">&quot;forestgreen&quot;</span>, <span class="st">&quot;orange&quot;</span>, <span class="st">&quot;blue&quot;</span>)</span>
<span id="cb30-29"><a href="#cb30-29" tabindex="-1"></a><span class="co"># Set the colors of 4 branches</span></span>
<span id="cb30-30"><a href="#cb30-30" tabindex="-1"></a>dend1 <span class="ot">&lt;-</span> <span class="fu">color_branches</span>(dend1, <span class="at">k =</span> <span class="dv">4</span>, <span class="at">col =</span> cols_branches)</span>
<span id="cb30-31"><a href="#cb30-31" tabindex="-1"></a><span class="co"># or with:</span></span>
<span id="cb30-32"><a href="#cb30-32" tabindex="-1"></a><span class="co"># dend1 &lt;- set(dend1, &quot;branches_k_color&quot;, k = 4, value = cols_branches)</span></span>
<span id="cb30-33"><a href="#cb30-33" tabindex="-1"></a></span>
<span id="cb30-34"><a href="#cb30-34" tabindex="-1"></a><span class="co"># Get the colors of the tips of the dendrogram:</span></span>
<span id="cb30-35"><a href="#cb30-35" tabindex="-1"></a><span class="co"># col_labels &lt;- cols_branches[cutree(dend1, k = 4)] # this may need tweaking in various cases - the following is a more general solution.</span></span>
<span id="cb30-36"><a href="#cb30-36" tabindex="-1"></a></span>
<span id="cb30-37"><a href="#cb30-37" tabindex="-1"></a>col_labels <span class="ot">&lt;-</span> <span class="fu">get_leaves_branches_col</span>(dend1)</span>
<span id="cb30-38"><a href="#cb30-38" tabindex="-1"></a><span class="co"># But due to the way heatmap.2 works - we need to fix it to be in the </span></span>
<span id="cb30-39"><a href="#cb30-39" tabindex="-1"></a><span class="co"># order of the data! </span></span>
<span id="cb30-40"><a href="#cb30-40" tabindex="-1"></a>col_labels <span class="ot">&lt;-</span> col_labels[<span class="fu">order</span>(<span class="fu">order.dendrogram</span>(dend1))]</span>
<span id="cb30-41"><a href="#cb30-41" tabindex="-1"></a></span>
<span id="cb30-42"><a href="#cb30-42" tabindex="-1"></a>dend1</span>
<span id="cb30-43"><a href="#cb30-43" tabindex="-1"></a><span class="co"># plot(dend1)</span></span>
<span id="cb30-44"><a href="#cb30-44" tabindex="-1"></a><span class="co"># a &lt;- heights_per_k.dendrogram(dend1)</span></span>
<span id="cb30-45"><a href="#cb30-45" tabindex="-1"></a><span class="co"># a2 &lt;- heights_per_k.dendrogram(dend1)</span></span>
<span id="cb30-46"><a href="#cb30-46" tabindex="-1"></a><span class="co"># nleaves(dend1)</span></span>
<span id="cb30-47"><a href="#cb30-47" tabindex="-1"></a></span>
<span id="cb30-48"><a href="#cb30-48" tabindex="-1"></a></span>
<span id="cb30-49"><a href="#cb30-49" tabindex="-1"></a><span class="co"># Creating Heat Map</span></span>
<span id="cb30-50"><a href="#cb30-50" tabindex="-1"></a><span class="co"># if(!require(gplots)) install.packages(&quot;gplots&quot;)</span></span>
<span id="cb30-51"><a href="#cb30-51" tabindex="-1"></a><span class="fu">library</span>(gplots)</span>
<span id="cb30-52"><a href="#cb30-52" tabindex="-1"></a><span class="fu">heatmap.2</span>(test, </span>
<span id="cb30-53"><a href="#cb30-53" tabindex="-1"></a> <span class="at">main =</span> <span class="fu">paste</span>( <span class="st">&quot;test&quot;</span>), </span>
<span id="cb30-54"><a href="#cb30-54" tabindex="-1"></a> <span class="at">trace=</span><span class="st">&quot;none&quot;</span>, </span>
<span id="cb30-55"><a href="#cb30-55" tabindex="-1"></a> <span class="at">margins =</span><span class="fu">c</span>(<span class="dv">5</span>,<span class="dv">7</span>), </span>
<span id="cb30-56"><a href="#cb30-56" tabindex="-1"></a> <span class="at">col=</span>my_palette, </span>
<span id="cb30-57"><a href="#cb30-57" tabindex="-1"></a> <span class="at">breaks=</span>col_breaks, </span>
<span id="cb30-58"><a href="#cb30-58" tabindex="-1"></a> <span class="at">dendrogram=</span><span class="st">&quot;row&quot;</span>, </span>
<span id="cb30-59"><a href="#cb30-59" tabindex="-1"></a> <span class="at">Rowv =</span> dend1, </span>
<span id="cb30-60"><a href="#cb30-60" tabindex="-1"></a> <span class="at">Colv =</span> <span class="st">&quot;NA&quot;</span>, </span>
<span id="cb30-61"><a href="#cb30-61" tabindex="-1"></a> <span class="at">key.xlab =</span> <span class="st">&quot;Concentration (index)&quot;</span>,</span>
<span id="cb30-62"><a href="#cb30-62" tabindex="-1"></a> <span class="at">cexRow =</span><span class="fl">0.6</span>,</span>
<span id="cb30-63"><a href="#cb30-63" tabindex="-1"></a> <span class="at">cexCol =</span> <span class="fl">0.8</span>,</span>
<span id="cb30-64"><a href="#cb30-64" tabindex="-1"></a> <span class="at">na.rm =</span> <span class="cn">TRUE</span>,</span>
<span id="cb30-65"><a href="#cb30-65" tabindex="-1"></a> <span class="at">RowSideColors =</span> col_labels <span class="co"># to add nice colored strips </span></span>
<span id="cb30-66"><a href="#cb30-66" tabindex="-1"></a> <span class="co"># colRow = col_labels # to add nice colored labels - only for qplots 2.17.0 and higher</span></span>
<span id="cb30-67"><a href="#cb30-67" tabindex="-1"></a> ) </span></code></pre></div>
</div>
<div id="for-package-developers---how-to-call-imported-calls-from-dendextend-0.18.3" class="section level3">
<h3>For package developers - how to call imported calls from dendextend
0.18.3?</h3>
<p>If you are developing a package and you wish to use dendextend as an
imported package, that is - without loading it to the search path, you
should run:</p>
<div class="sourceCode" id="cb31"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb31-1"><a href="#cb31-1" tabindex="-1"></a>dendextend<span class="sc">::</span><span class="fu">assign_dendextend_options</span>()</span>
<span id="cb31-2"><a href="#cb31-2" tabindex="-1"></a><span class="co"># This populates the dendextend::dendextend_options() space</span></span></code></pre></div>
<p>Before using any of its function (for example:
<code>dendextend::color_branches</code> ). As of dendextend version
1.0.0, this is no longer required.</p>
</div>
<div id="how-to-plot-a-fan-polar-dendrogram-in-r" class="section level3">
<h3>How to plot a fan (Polar) Dendrogram in R?</h3>
<p>Asked (<a href="https://stats.stackexchange.com/questions/4062/how-to-plot-a-fan-polar-dendrogram-in-r" class="uri">https://stats.stackexchange.com/questions/4062/how-to-plot-a-fan-polar-dendrogram-in-r</a>)[here].</p>
<p>Solution: use the <code>circlize_dendrogram</code> function.</p>
<div class="sourceCode" id="cb32"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb32-1"><a href="#cb32-1" tabindex="-1"></a><span class="co"># install.packages(&quot;dendextend&quot;)</span></span>
<span id="cb32-2"><a href="#cb32-2" tabindex="-1"></a><span class="co"># install.packages(&quot;circlize&quot;)</span></span>
<span id="cb32-3"><a href="#cb32-3" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb32-4"><a href="#cb32-4" tabindex="-1"></a><span class="fu">library</span>(circlize)</span>
<span id="cb32-5"><a href="#cb32-5" tabindex="-1"></a></span>
<span id="cb32-6"><a href="#cb32-6" tabindex="-1"></a><span class="co"># create a dendrogram</span></span>
<span id="cb32-7"><a href="#cb32-7" tabindex="-1"></a>hc <span class="ot">&lt;-</span> <span class="fu">hclust</span>(<span class="fu">dist</span>(datasets<span class="sc">::</span>mtcars))</span>
<span id="cb32-8"><a href="#cb32-8" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(hc)</span>
<span id="cb32-9"><a href="#cb32-9" tabindex="-1"></a></span>
<span id="cb32-10"><a href="#cb32-10" tabindex="-1"></a><span class="co"># modify the dendrogram to have some colors in the branches and labels</span></span>
<span id="cb32-11"><a href="#cb32-11" tabindex="-1"></a>dend <span class="ot">&lt;-</span> dend <span class="sc">%&gt;%</span> </span>
<span id="cb32-12"><a href="#cb32-12" tabindex="-1"></a> <span class="fu">color_branches</span>(<span class="at">k=</span><span class="dv">4</span>) <span class="sc">%&gt;%</span> </span>
<span id="cb32-13"><a href="#cb32-13" tabindex="-1"></a> color_labels</span>
<span id="cb32-14"><a href="#cb32-14" tabindex="-1"></a></span>
<span id="cb32-15"><a href="#cb32-15" tabindex="-1"></a><span class="co"># plot the radial plot</span></span>
<span id="cb32-16"><a href="#cb32-16" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mar =</span> <span class="fu">rep</span>(<span class="dv">0</span>,<span class="dv">4</span>))</span>
<span id="cb32-17"><a href="#cb32-17" tabindex="-1"></a><span class="co"># circlize_dendrogram(dend, dend_track_height = 0.8) </span></span>
<span id="cb32-18"><a href="#cb32-18" tabindex="-1"></a><span class="fu">circlize_dendrogram</span>(dend, <span class="at">labels_track_height =</span> <span class="cn">NA</span>, <span class="at">dend_track_height =</span> .<span class="dv">3</span>) </span></code></pre></div>
<p><img role="img" src="
</div>
<div id="a-way-to-calculate-lowest-value-of-h-in-cut-that-produces-groupings-of-a-given-minimum-size" class="section level3">
<h3>A way to calculate lowest value of h in cut that produces groupings
of a given minimum size?</h3>
<p>Asked (<a href="https://stackoverflow.com/questions/31124810/r-cut-dendrogram-into-groups-with-minimum-size/" class="uri">https://stackoverflow.com/questions/31124810/r-cut-dendrogram-into-groups-with-minimum-size/</a>)[here].</p>
<p>Solution: use the <code>heights_per_k.dendrogram</code> function.</p>
<p>This feature is available in the dendextend package with the
<code>heights_per_k.dendrogram</code> function (which also has a faster
C++ implementation when loading the dendextendRcpp function).</p>
<div class="sourceCode" id="cb33"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb33-1"><a href="#cb33-1" tabindex="-1"></a>hc <span class="ot">&lt;-</span> <span class="fu">hclust</span>(<span class="fu">dist</span>(USArrests[<span class="dv">1</span><span class="sc">:</span><span class="dv">4</span>,]), <span class="st">&quot;ave&quot;</span>)</span>
<span id="cb33-2"><a href="#cb33-2" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(hc)</span>
<span id="cb33-3"><a href="#cb33-3" tabindex="-1"></a><span class="fu">heights_per_k.dendrogram</span>(dend)</span></code></pre></div>
<pre><code>## 1 2 3 4
## 86.47086 68.84745 45.98871 28.36531</code></pre>
<p>As a sidenote, the dendextend package has a
<code>cutree.dendrogram</code> S3 method for dendrograms (which works
very similarly to <code>cutree</code> for <code>hclust</code>
objects).</p>
</div>
<div id="coloring-dendrograms-end-branches-or-leaves-based-on-column-number-of-data-frame-in-r" class="section level3">
<h3>Coloring dendrograms end branches (or leaves) based on column
number of data frame in R</h3>
<p>Asked (<a href="https://stackoverflow.com/questions/30062187/coloring-dendrogram-s-end-branches-or-leaves-based-on-column-number-of-data-fr" class="uri">https://stackoverflow.com/questions/30062187/coloring-dendrogram-s-end-branches-or-leaves-based-on-column-number-of-data-fr</a>)[here].</p>
<p>Solution: use the <code>assign_values_to_leaves_edgePar</code>
function.</p>
<div class="sourceCode" id="cb35"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb35-1"><a href="#cb35-1" tabindex="-1"></a>aa1 <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="dv">2</span>,<span class="dv">4</span>,<span class="dv">6</span>,<span class="dv">8</span>)</span>
<span id="cb35-2"><a href="#cb35-2" tabindex="-1"></a>bb1 <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="dv">1</span>,<span class="dv">3</span>,<span class="dv">7</span>,<span class="dv">11</span>)</span>
<span id="cb35-3"><a href="#cb35-3" tabindex="-1"></a>aa2 <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="dv">3</span>,<span class="dv">6</span>,<span class="dv">9</span>,<span class="dv">12</span>)</span>
<span id="cb35-4"><a href="#cb35-4" tabindex="-1"></a>bb2 <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="dv">3</span>,<span class="dv">5</span>,<span class="dv">7</span>,<span class="dv">9</span>)</span>
<span id="cb35-5"><a href="#cb35-5" tabindex="-1"></a>data.main <span class="ot">&lt;-</span> <span class="fu">data.frame</span>(aa1,bb1,aa2,bb2)</span>
<span id="cb35-6"><a href="#cb35-6" tabindex="-1"></a>d1 <span class="ot">&lt;-</span> <span class="fu">dist</span>(<span class="fu">t</span>(data.main))</span>
<span id="cb35-7"><a href="#cb35-7" tabindex="-1"></a>hcl1 <span class="ot">&lt;-</span> <span class="fu">hclust</span>(d1)</span>
<span id="cb35-8"><a href="#cb35-8" tabindex="-1"></a><span class="co"># plot(hcl1)</span></span>
<span id="cb35-9"><a href="#cb35-9" tabindex="-1"></a></span>
<span id="cb35-10"><a href="#cb35-10" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(hcl1)</span>
<span id="cb35-11"><a href="#cb35-11" tabindex="-1"></a>col_aa_red <span class="ot">&lt;-</span> <span class="fu">ifelse</span>(<span class="fu">grepl</span>(<span class="st">&quot;aa&quot;</span>, <span class="fu">labels</span>(dend)), <span class="st">&quot;red&quot;</span>, <span class="st">&quot;blue&quot;</span>)</span>
<span id="cb35-12"><a href="#cb35-12" tabindex="-1"></a>dend2 <span class="ot">&lt;-</span> <span class="fu">assign_values_to_leaves_edgePar</span>(<span class="at">dend=</span>dend, <span class="at">value =</span> col_aa_red, <span class="at">edgePar =</span> <span class="st">&quot;col&quot;</span>)</span>
<span id="cb35-13"><a href="#cb35-13" tabindex="-1"></a><span class="fu">plot</span>(dend2)</span></code></pre></div>
<p><img role="img" src="
</div>
<div id="color-side-bar-dendrogram-plot" class="section level3">
<h3>Color side bar dendrogram plot</h3>
<p>Asked (<a href="https://stackoverflow.com/questions/34539746/color-side-bar-dendrogram-plot/" class="uri">https://stackoverflow.com/questions/34539746/color-side-bar-dendrogram-plot/</a>)[here].</p>
<p>Solution: use the <code>color_branches</code> function.</p>
<p>Example using <code>mtcars</code>:</p>
<div class="sourceCode" id="cb36"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb36-1"><a href="#cb36-1" tabindex="-1"></a><span class="do">## mtcars example</span></span>
<span id="cb36-2"><a href="#cb36-2" tabindex="-1"></a></span>
<span id="cb36-3"><a href="#cb36-3" tabindex="-1"></a><span class="co"># Create the dend:</span></span>
<span id="cb36-4"><a href="#cb36-4" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(<span class="fu">hclust</span>(<span class="fu">dist</span>(mtcars)))</span>
<span id="cb36-5"><a href="#cb36-5" tabindex="-1"></a></span>
<span id="cb36-6"><a href="#cb36-6" tabindex="-1"></a><span class="co"># Create a vector giving a color for each car to which company it belongs to</span></span>
<span id="cb36-7"><a href="#cb36-7" tabindex="-1"></a>car_type <span class="ot">&lt;-</span> <span class="fu">rep</span>(<span class="st">&quot;Other&quot;</span>, <span class="fu">length</span>(<span class="fu">rownames</span>(mtcars)))</span>
<span id="cb36-8"><a href="#cb36-8" tabindex="-1"></a>is_x <span class="ot">&lt;-</span> <span class="fu">grepl</span>(<span class="st">&quot;Merc&quot;</span>, <span class="fu">rownames</span>(mtcars))</span>
<span id="cb36-9"><a href="#cb36-9" tabindex="-1"></a>car_type[is_x] <span class="ot">&lt;-</span> <span class="st">&quot;Mercedes&quot;</span></span>
<span id="cb36-10"><a href="#cb36-10" tabindex="-1"></a>is_x <span class="ot">&lt;-</span> <span class="fu">grepl</span>(<span class="st">&quot;Mazda&quot;</span>, <span class="fu">rownames</span>(mtcars))</span>
<span id="cb36-11"><a href="#cb36-11" tabindex="-1"></a>car_type[is_x] <span class="ot">&lt;-</span> <span class="st">&quot;Mazda&quot;</span></span>
<span id="cb36-12"><a href="#cb36-12" tabindex="-1"></a>is_x <span class="ot">&lt;-</span> <span class="fu">grepl</span>(<span class="st">&quot;Toyota&quot;</span>, <span class="fu">rownames</span>(mtcars))</span>
<span id="cb36-13"><a href="#cb36-13" tabindex="-1"></a>car_type[is_x] <span class="ot">&lt;-</span> <span class="st">&quot;Toyota&quot;</span></span>
<span id="cb36-14"><a href="#cb36-14" tabindex="-1"></a>car_type <span class="ot">&lt;-</span> <span class="fu">factor</span>(car_type)</span>
<span id="cb36-15"><a href="#cb36-15" tabindex="-1"></a>n_car_types <span class="ot">&lt;-</span> <span class="fu">length</span>(<span class="fu">unique</span>(car_type))</span>
<span id="cb36-16"><a href="#cb36-16" tabindex="-1"></a>cols_4 <span class="ot">&lt;-</span> colorspace<span class="sc">::</span><span class="fu">rainbow_hcl</span>(n_car_types, <span class="at">c =</span> <span class="dv">70</span>, <span class="at">l =</span> <span class="dv">50</span>)</span>
<span id="cb36-17"><a href="#cb36-17" tabindex="-1"></a>col_car_type <span class="ot">&lt;-</span> cols_4[car_type]</span>
<span id="cb36-18"><a href="#cb36-18" tabindex="-1"></a></span>
<span id="cb36-19"><a href="#cb36-19" tabindex="-1"></a><span class="co"># extra: showing the various clusters cuts </span></span>
<span id="cb36-20"><a href="#cb36-20" tabindex="-1"></a>k234 <span class="ot">&lt;-</span> <span class="fu">cutree</span>(dend, <span class="at">k =</span> <span class="dv">2</span><span class="sc">:</span><span class="dv">4</span>)</span>
<span id="cb36-21"><a href="#cb36-21" tabindex="-1"></a></span>
<span id="cb36-22"><a href="#cb36-22" tabindex="-1"></a><span class="co"># color labels by car company:</span></span>
<span id="cb36-23"><a href="#cb36-23" tabindex="-1"></a><span class="fu">labels_colors</span>(dend) <span class="ot">&lt;-</span> col_car_type[<span class="fu">order.dendrogram</span>(dend)]</span>
<span id="cb36-24"><a href="#cb36-24" tabindex="-1"></a><span class="co"># color branches based on cutting the tree into 4 clusters:</span></span>
<span id="cb36-25"><a href="#cb36-25" tabindex="-1"></a>dend <span class="ot">&lt;-</span> <span class="fu">color_branches</span>(dend, <span class="at">k =</span> <span class="dv">4</span>)</span>
<span id="cb36-26"><a href="#cb36-26" tabindex="-1"></a></span>
<span id="cb36-27"><a href="#cb36-27" tabindex="-1"></a><span class="do">### plots</span></span>
<span id="cb36-28"><a href="#cb36-28" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mar =</span> <span class="fu">c</span>(<span class="dv">12</span>,<span class="dv">4</span>,<span class="dv">1</span>,<span class="dv">1</span>))</span>
<span id="cb36-29"><a href="#cb36-29" tabindex="-1"></a><span class="fu">plot</span>(dend)</span>
<span id="cb36-30"><a href="#cb36-30" tabindex="-1"></a><span class="fu">colored_bars</span>(<span class="fu">cbind</span>(k234[,<span class="dv">3</span><span class="sc">:</span><span class="dv">1</span>], col_car_type), dend, <span class="at">rowLabels =</span> <span class="fu">c</span>(<span class="fu">paste0</span>(<span class="st">&quot;k = &quot;</span>, <span class="dv">4</span><span class="sc">:</span><span class="dv">2</span>), <span class="st">&quot;Car Type&quot;</span>))</span></code></pre></div>
<p><img role="img" src="
<div class="sourceCode" id="cb37"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb37-1"><a href="#cb37-1" tabindex="-1"></a><span class="co"># horiz version:</span></span>
<span id="cb37-2"><a href="#cb37-2" tabindex="-1"></a><span class="co"># dend &lt;- sort(dend)</span></span>
<span id="cb37-3"><a href="#cb37-3" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mar =</span> <span class="fu">c</span>(<span class="dv">4</span>,<span class="dv">1</span>,<span class="dv">1</span>,<span class="dv">12</span>))</span>
<span id="cb37-4"><a href="#cb37-4" tabindex="-1"></a><span class="fu">plot</span>(dend, <span class="at">horiz =</span> <span class="cn">TRUE</span>)</span>
<span id="cb37-5"><a href="#cb37-5" tabindex="-1"></a><span class="fu">colored_bars</span>(<span class="fu">cbind</span>(k234[,<span class="dv">3</span><span class="sc">:</span><span class="dv">1</span>], col_car_type), dend, <span class="at">rowLabels =</span> <span class="fu">c</span>(<span class="fu">paste0</span>(<span class="st">&quot;k = &quot;</span>, <span class="dv">4</span><span class="sc">:</span><span class="dv">2</span>), <span class="st">&quot;Car Type&quot;</span>), <span class="at">horiz =</span> <span class="cn">TRUE</span>)</span>
<span id="cb37-6"><a href="#cb37-6" tabindex="-1"></a><span class="fu">legend</span>(<span class="st">&quot;topleft&quot;</span>, <span class="at">legend =</span> <span class="fu">levels</span>(car_type), <span class="at">fill =</span> cols_4)</span></code></pre></div>
<p><img role="img" src="
</div>
<div id="plot-a-mirror-labels-on-the-left-horizontal-dendrogram" class="section level3">
<h3>Plot a “mirror” (labels on the left) horizontal dendrogram</h3>
<p>Asked (<a href="https://github.com/talgalili/dendextend/issues/29" class="uri">https://github.com/talgalili/dendextend/issues/29</a>)[here].</p>
<p>Solution: use the <code>plot_horiz.dendrogram</code> function.</p>
<p>Example using <code>USArrests</code>:</p>
<div class="sourceCode" id="cb38"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb38-1"><a href="#cb38-1" tabindex="-1"></a><span class="co"># Create the dend:</span></span>
<span id="cb38-2"><a href="#cb38-2" tabindex="-1"></a>hc <span class="ot">&lt;-</span> <span class="fu">hclust</span>(<span class="fu">dist</span>(USArrests), <span class="st">&quot;ave&quot;</span>)</span>
<span id="cb38-3"><a href="#cb38-3" tabindex="-1"></a>d <span class="ot">&lt;-</span> <span class="fu">as.dendrogram</span>(hc)</span>
<span id="cb38-4"><a href="#cb38-4" tabindex="-1"></a><span class="fu">library</span>(dendextend)</span>
<span id="cb38-5"><a href="#cb38-5" tabindex="-1"></a>d <span class="ot">&lt;-</span> d <span class="sc">%&gt;%</span> <span class="fu">color_branches</span>(<span class="at">k=</span><span class="dv">3</span>) <span class="sc">%&gt;%</span> color_labels</span>
<span id="cb38-6"><a href="#cb38-6" tabindex="-1"></a></span>
<span id="cb38-7"><a href="#cb38-7" tabindex="-1"></a><span class="co"># horiz normal version</span></span>
<span id="cb38-8"><a href="#cb38-8" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mar =</span> <span class="fu">c</span>(<span class="dv">3</span>,<span class="dv">1</span>,<span class="dv">1</span>,<span class="dv">7</span>))</span>
<span id="cb38-9"><a href="#cb38-9" tabindex="-1"></a><span class="fu">plot</span>(d, <span class="at">horiz =</span> <span class="cn">TRUE</span>)</span></code></pre></div>
<p><img role="img" src="
<div class="sourceCode" id="cb39"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb39-1"><a href="#cb39-1" tabindex="-1"></a><span class="co"># horiz mirror version</span></span>
<span id="cb39-2"><a href="#cb39-2" tabindex="-1"></a><span class="fu">par</span>(<span class="at">mar =</span> <span class="fu">c</span>(<span class="dv">3</span>,<span class="dv">7</span>,<span class="dv">1</span>,<span class="dv">1</span>))</span>
<span id="cb39-3"><a href="#cb39-3" tabindex="-1"></a><span class="fu">plot_horiz.dendrogram</span>(d, <span class="at">side =</span> <span class="cn">TRUE</span>)</span></code></pre></div>
<p><img role="img" src="
</div>
</div>
<!-- code folding -->
<!-- dynamically load mathjax for compatibility with self-contained -->
<script>
(function () {
var script = document.createElement("script");
script.type = "text/javascript";
script.src = "https://mathjax.rstudio.com/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML";
document.getElementsByTagName("head")[0].appendChild(script);
})();
</script>
</body>
</html>