mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.
223 lines (222 loc) • 2.2 MB
HTML
<!DOCTYPE html>
<html>
<head>
<title>d3.js</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link rel="stylesheet" media="all" href="../../doc-style.css" />
<script src="../../doc-filelist.js"></script>
<script>
var relativeDir = "../../", thisFile = "Users/knut/Documents/source/mermaid/bower_components/d3/d3.js", defaultSidebar = true;
</script>
<script src="../../doc-script.js"></script>
<script src="../../mermaid.js"></script>
<link rel="stylesheet" href="../../mermaid.css" />
</head>
<body>
<div id="sidebar_wrapper">
<div id="sidebar_switch">
<span class="tree">Files</span>
<span class="headings">Headings</span>
</div>
<div id="tree"></div>
<div id="headings">
<div class="heading h1">
<a href="#d3.js">d3.js</a>
</div>
</div>
</div>
<div id="sidebar-toggle"></div>
<div id="container"><div class="background highlight"></div>
<table cellpadding="0" cellspacing="0">
<tbody>
<tr>
<td class="docs">
<div class="pilwrap" id="d3.js">
<h1>
<a href="#d3.js" name="d3.js" class="pilcrow">¶</a>d3.js
</h1>
</div>
</td>
<td class="code highlight"></td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-1" id="section-1">¶</a>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre><span class="nx">d3</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">d3</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">version</span><span class="o">:</span> <span class="s2">"3.3.8"</span>
<span class="p">};</span>
<span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nb">Date</span><span class="p">.</span><span class="nx">now</span><span class="p">)</span> <span class="nb">Date</span><span class="p">.</span><span class="nx">now</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">return</span> <span class="o">+</span><span class="k">new</span> <span class="nb">Date</span><span class="p">();</span>
<span class="p">};</span>
<span class="kd">var</span> <span class="nx">d3_arraySlice</span> <span class="o">=</span> <span class="p">[].</span><span class="nx">slice</span><span class="p">,</span> <span class="nx">d3_array</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">list</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d3_arraySlice</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">list</span><span class="p">);</span>
<span class="p">};</span>
<span class="kd">var</span> <span class="nx">d3_document</span> <span class="o">=</span> <span class="nb">document</span><span class="p">,</span> <span class="nx">d3_documentElement</span> <span class="o">=</span> <span class="nx">d3_document</span><span class="p">.</span><span class="nx">documentElement</span><span class="p">,</span> <span class="nx">d3_window</span> <span class="o">=</span> <span class="nb">window</span><span class="p">;</span>
<span class="k">try</span> <span class="p">{</span>
<span class="nx">d3_array</span><span class="p">(</span><span class="nx">d3_documentElement</span><span class="p">.</span><span class="nx">childNodes</span><span class="p">)[</span><span class="mi">0</span><span class="p">].</span><span class="nx">nodeType</span><span class="p">;</span>
<span class="p">}</span> <span class="k">catch</span> <span class="p">(</span><span class="nx">e</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">d3_array</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">list</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="nx">list</span><span class="p">.</span><span class="nx">length</span><span class="p">,</span> <span class="nx">array</span> <span class="o">=</span> <span class="k">new</span> <span class="nb">Array</span><span class="p">(</span><span class="nx">i</span><span class="p">);</span>
<span class="k">while</span> <span class="p">(</span><span class="nx">i</span><span class="o">--</span><span class="p">)</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">]</span> <span class="o">=</span> <span class="nx">list</span><span class="p">[</span><span class="nx">i</span><span class="p">];</span>
<span class="k">return</span> <span class="nx">array</span><span class="p">;</span>
<span class="p">};</span>
<span class="p">}</span>
<span class="k">try</span> <span class="p">{</span>
<span class="nx">d3_document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s2">"div"</span><span class="p">).</span><span class="nx">style</span><span class="p">.</span><span class="nx">setProperty</span><span class="p">(</span><span class="s2">"opacity"</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">""</span><span class="p">);</span>
<span class="p">}</span> <span class="k">catch</span> <span class="p">(</span><span class="nx">error</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">d3_element_prototype</span> <span class="o">=</span> <span class="nx">d3_window</span><span class="p">.</span><span class="nx">Element</span><span class="p">.</span><span class="nx">prototype</span><span class="p">,</span> <span class="nx">d3_element_setAttribute</span> <span class="o">=</span> <span class="nx">d3_element_prototype</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">,</span> <span class="nx">d3_element_setAttributeNS</span> <span class="o">=</span> <span class="nx">d3_element_prototype</span><span class="p">.</span><span class="nx">setAttributeNS</span><span class="p">,</span> <span class="nx">d3_style_prototype</span> <span class="o">=</span> <span class="nx">d3_window</span><span class="p">.</span><span class="nx">CSSStyleDeclaration</span><span class="p">.</span><span class="nx">prototype</span><span class="p">,</span> <span class="nx">d3_style_setProperty</span> <span class="o">=</span> <span class="nx">d3_style_prototype</span><span class="p">.</span><span class="nx">setProperty</span><span class="p">;</span>
<span class="nx">d3_element_prototype</span><span class="p">.</span><span class="nx">setAttribute</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">name</span><span class="p">,</span> <span class="nx">value</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">d3_element_setAttribute</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="k">this</span><span class="p">,</span> <span class="nx">name</span><span class="p">,</span> <span class="nx">value</span> <span class="o">+</span> <span class="s2">""</span><span class="p">);</span>
<span class="p">};</span>
<span class="nx">d3_element_prototype</span><span class="p">.</span><span class="nx">setAttributeNS</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">space</span><span class="p">,</span> <span class="nx">local</span><span class="p">,</span> <span class="nx">value</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">d3_element_setAttributeNS</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="k">this</span><span class="p">,</span> <span class="nx">space</span><span class="p">,</span> <span class="nx">local</span><span class="p">,</span> <span class="nx">value</span> <span class="o">+</span> <span class="s2">""</span><span class="p">);</span>
<span class="p">};</span>
<span class="nx">d3_style_prototype</span><span class="p">.</span><span class="nx">setProperty</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">name</span><span class="p">,</span> <span class="nx">value</span><span class="p">,</span> <span class="nx">priority</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">d3_style_setProperty</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="k">this</span><span class="p">,</span> <span class="nx">name</span><span class="p">,</span> <span class="nx">value</span> <span class="o">+</span> <span class="s2">""</span><span class="p">,</span> <span class="nx">priority</span><span class="p">);</span>
<span class="p">};</span>
<span class="p">}</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">ascending</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">a</span><span class="p">,</span> <span class="nx">b</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">a</span> <span class="o"><</span> <span class="nx">b</span> <span class="o">?</span> <span class="o">-</span><span class="mi">1</span> <span class="o">:</span> <span class="nx">a</span> <span class="o">></span> <span class="nx">b</span> <span class="o">?</span> <span class="mi">1</span> <span class="o">:</span> <span class="nx">a</span> <span class="o">>=</span> <span class="nx">b</span> <span class="o">?</span> <span class="mi">0</span> <span class="o">:</span> <span class="kc">NaN</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">descending</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">a</span><span class="p">,</span> <span class="nx">b</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">b</span> <span class="o"><</span> <span class="nx">a</span> <span class="o">?</span> <span class="o">-</span><span class="mi">1</span> <span class="o">:</span> <span class="nx">b</span> <span class="o">></span> <span class="nx">a</span> <span class="o">?</span> <span class="mi">1</span> <span class="o">:</span> <span class="nx">b</span> <span class="o">>=</span> <span class="nx">a</span> <span class="o">?</span> <span class="mi">0</span> <span class="o">:</span> <span class="kc">NaN</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">min</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">f</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="nx">n</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">length</span><span class="p">,</span> <span class="nx">a</span><span class="p">,</span> <span class="nx">b</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o">===</span> <span class="mi">1</span><span class="p">)</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span> <span class="o">&&</span> <span class="o">!</span><span class="p">((</span><span class="nx">a</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">a</span> <span class="o"><=</span> <span class="nx">a</span><span class="p">))</span> <span class="nx">a</span> <span class="o">=</span> <span class="kc">undefined</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">((</span><span class="nx">b</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">a</span> <span class="o">></span> <span class="nx">b</span><span class="p">)</span> <span class="nx">a</span> <span class="o">=</span> <span class="nx">b</span><span class="p">;</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span> <span class="o">&&</span> <span class="o">!</span><span class="p">((</span><span class="nx">a</span> <span class="o">=</span> <span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">i</span><span class="p">))</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">a</span> <span class="o"><=</span> <span class="nx">a</span><span class="p">))</span> <span class="nx">a</span> <span class="o">=</span> <span class="kc">undefined</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">((</span><span class="nx">b</span> <span class="o">=</span> <span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">i</span><span class="p">))</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">a</span> <span class="o">></span> <span class="nx">b</span><span class="p">)</span> <span class="nx">a</span> <span class="o">=</span> <span class="nx">b</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">a</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">max</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">f</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="nx">n</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">length</span><span class="p">,</span> <span class="nx">a</span><span class="p">,</span> <span class="nx">b</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o">===</span> <span class="mi">1</span><span class="p">)</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span> <span class="o">&&</span> <span class="o">!</span><span class="p">((</span><span class="nx">a</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">a</span> <span class="o"><=</span> <span class="nx">a</span><span class="p">))</span> <span class="nx">a</span> <span class="o">=</span> <span class="kc">undefined</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">((</span><span class="nx">b</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">b</span> <span class="o">></span> <span class="nx">a</span><span class="p">)</span> <span class="nx">a</span> <span class="o">=</span> <span class="nx">b</span><span class="p">;</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span> <span class="o">&&</span> <span class="o">!</span><span class="p">((</span><span class="nx">a</span> <span class="o">=</span> <span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">i</span><span class="p">))</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">a</span> <span class="o"><=</span> <span class="nx">a</span><span class="p">))</span> <span class="nx">a</span> <span class="o">=</span> <span class="kc">undefined</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">((</span><span class="nx">b</span> <span class="o">=</span> <span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">i</span><span class="p">))</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">b</span> <span class="o">></span> <span class="nx">a</span><span class="p">)</span> <span class="nx">a</span> <span class="o">=</span> <span class="nx">b</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">a</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">extent</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">f</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="nx">n</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">length</span><span class="p">,</span> <span class="nx">a</span><span class="p">,</span> <span class="nx">b</span><span class="p">,</span> <span class="nx">c</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o">===</span> <span class="mi">1</span><span class="p">)</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span> <span class="o">&&</span> <span class="o">!</span><span class="p">((</span><span class="nx">a</span> <span class="o">=</span> <span class="nx">c</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">a</span> <span class="o"><=</span> <span class="nx">a</span><span class="p">))</span> <span class="nx">a</span> <span class="o">=</span> <span class="nx">c</span> <span class="o">=</span> <span class="kc">undefined</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">((</span><span class="nx">b</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="o">!=</span> <span class="kc">null</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">a</span> <span class="o">></span> <span class="nx">b</span><span class="p">)</span> <span class="nx">a</span> <span class="o">=</span> <span class="nx">b</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">c</span> <span class="o"><</span> <span class="nx">b</span><span class="p">)</span> <span class="nx">c</span> <span class="o">=</span> <span class="nx">b</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span> <span class="o">&&</span> <span class="o">!</span><span class="p">((</span><span class="nx">a</span> <span class="o">=</span> <span class="nx">c</span> <span class="o">=</span> <span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">i</span><span class="p">))</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="nx">a</span> <span class="o"><=</span> <span class="nx">a</span><span class="p">))</span> <span class="nx">a</span> <span class="o">=</span> <span class="kc">undefined</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">((</span><span class="nx">b</span> <span class="o">=</span> <span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">i</span><span class="p">))</span> <span class="o">!=</span> <span class="kc">null</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">a</span> <span class="o">></span> <span class="nx">b</span><span class="p">)</span> <span class="nx">a</span> <span class="o">=</span> <span class="nx">b</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">c</span> <span class="o"><</span> <span class="nx">b</span><span class="p">)</span> <span class="nx">c</span> <span class="o">=</span> <span class="nx">b</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">return</span> <span class="p">[</span> <span class="nx">a</span><span class="p">,</span> <span class="nx">c</span> <span class="p">];</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">sum</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">f</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">s</span> <span class="o">=</span> <span class="mi">0</span><span class="p">,</span> <span class="nx">n</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">length</span><span class="p">,</span> <span class="nx">a</span><span class="p">,</span> <span class="nx">i</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o">===</span> <span class="mi">1</span><span class="p">)</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nb">isNaN</span><span class="p">(</span><span class="nx">a</span> <span class="o">=</span> <span class="o">+</span><span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">]))</span> <span class="nx">s</span> <span class="o">+=</span> <span class="nx">a</span><span class="p">;</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nb">isNaN</span><span class="p">(</span><span class="nx">a</span> <span class="o">=</span> <span class="o">+</span><span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">i</span><span class="p">)))</span> <span class="nx">s</span> <span class="o">+=</span> <span class="nx">a</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">s</span><span class="p">;</span>
<span class="p">};</span>
<span class="kd">function</span> <span class="nx">d3_number</span><span class="p">(</span><span class="nx">x</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">x</span> <span class="o">!=</span> <span class="kc">null</span> <span class="o">&&</span> <span class="o">!</span><span class="nb">isNaN</span><span class="p">(</span><span class="nx">x</span><span class="p">);</span>
<span class="p">}</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">mean</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">f</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">n</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">length</span><span class="p">,</span> <span class="nx">a</span><span class="p">,</span> <span class="nx">m</span> <span class="o">=</span> <span class="mi">0</span><span class="p">,</span> <span class="nx">i</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="nx">j</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o">===</span> <span class="mi">1</span><span class="p">)</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">(</span><span class="nx">d3_number</span><span class="p">(</span><span class="nx">a</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">]))</span> <span class="nx">m</span> <span class="o">+=</span> <span class="p">(</span><span class="nx">a</span> <span class="o">-</span> <span class="nx">m</span><span class="p">)</span> <span class="o">/</span> <span class="o">++</span><span class="nx">j</span><span class="p">;</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">while</span> <span class="p">(</span><span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="k">if</span> <span class="p">(</span><span class="nx">d3_number</span><span class="p">(</span><span class="nx">a</span> <span class="o">=</span> <span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">i</span><span class="p">)))</span> <span class="nx">m</span> <span class="o">+=</span> <span class="p">(</span><span class="nx">a</span> <span class="o">-</span> <span class="nx">m</span><span class="p">)</span> <span class="o">/</span> <span class="o">++</span><span class="nx">j</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">j</span> <span class="o">?</span> <span class="nx">m</span> <span class="o">:</span> <span class="kc">undefined</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">quantile</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">values</span><span class="p">,</span> <span class="nx">p</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">H</span> <span class="o">=</span> <span class="p">(</span><span class="nx">values</span><span class="p">.</span><span class="nx">length</span> <span class="o">-</span> <span class="mi">1</span><span class="p">)</span> <span class="o">*</span> <span class="nx">p</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="nx">h</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">floor</span><span class="p">(</span><span class="nx">H</span><span class="p">),</span> <span class="nx">v</span> <span class="o">=</span> <span class="o">+</span><span class="nx">values</span><span class="p">[</span><span class="nx">h</span> <span class="o">-</span> <span class="mi">1</span><span class="p">],</span> <span class="nx">e</span> <span class="o">=</span> <span class="nx">H</span> <span class="o">-</span> <span class="nx">h</span><span class="p">;</span>
<span class="k">return</span> <span class="nx">e</span> <span class="o">?</span> <span class="nx">v</span> <span class="o">+</span> <span class="nx">e</span> <span class="o">*</span> <span class="p">(</span><span class="nx">values</span><span class="p">[</span><span class="nx">h</span><span class="p">]</span> <span class="o">-</span> <span class="nx">v</span><span class="p">)</span> <span class="o">:</span> <span class="nx">v</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">median</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">f</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o">></span> <span class="mi">1</span><span class="p">)</span> <span class="nx">array</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">map</span><span class="p">(</span><span class="nx">f</span><span class="p">);</span>
<span class="nx">array</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">filter</span><span class="p">(</span><span class="nx">d3_number</span><span class="p">);</span>
<span class="k">return</span> <span class="nx">array</span><span class="p">.</span><span class="nx">length</span> <span class="o">?</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">quantile</span><span class="p">(</span><span class="nx">array</span><span class="p">.</span><span class="nx">sort</span><span class="p">(</span><span class="nx">d3</span><span class="p">.</span><span class="nx">ascending</span><span class="p">),</span> <span class="p">.</span><span class="mi">5</span><span class="p">)</span> <span class="o">:</span> <span class="kc">undefined</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">bisector</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">f</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="p">{</span>
<span class="nx">left</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">a</span><span class="p">,</span> <span class="nx">x</span><span class="p">,</span> <span class="nx">lo</span><span class="p">,</span> <span class="nx">hi</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o"><</span> <span class="mi">3</span><span class="p">)</span> <span class="nx">lo</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o"><</span> <span class="mi">4</span><span class="p">)</span> <span class="nx">hi</span> <span class="o">=</span> <span class="nx">a</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="nx">lo</span> <span class="o"><</span> <span class="nx">hi</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">mid</span> <span class="o">=</span> <span class="nx">lo</span> <span class="o">+</span> <span class="nx">hi</span> <span class="o">>>></span> <span class="mi">1</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">a</span><span class="p">,</span> <span class="nx">a</span><span class="p">[</span><span class="nx">mid</span><span class="p">],</span> <span class="nx">mid</span><span class="p">)</span> <span class="o"><</span> <span class="nx">x</span><span class="p">)</span> <span class="nx">lo</span> <span class="o">=</span> <span class="nx">mid</span> <span class="o">+</span> <span class="mi">1</span><span class="p">;</span> <span class="k">else</span> <span class="nx">hi</span> <span class="o">=</span> <span class="nx">mid</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">lo</span><span class="p">;</span>
<span class="p">},</span>
<span class="nx">right</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">a</span><span class="p">,</span> <span class="nx">x</span><span class="p">,</span> <span class="nx">lo</span><span class="p">,</span> <span class="nx">hi</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o"><</span> <span class="mi">3</span><span class="p">)</span> <span class="nx">lo</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o"><</span> <span class="mi">4</span><span class="p">)</span> <span class="nx">hi</span> <span class="o">=</span> <span class="nx">a</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="nx">lo</span> <span class="o"><</span> <span class="nx">hi</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">mid</span> <span class="o">=</span> <span class="nx">lo</span> <span class="o">+</span> <span class="nx">hi</span> <span class="o">>>></span> <span class="mi">1</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">x</span> <span class="o"><</span> <span class="nx">f</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">a</span><span class="p">,</span> <span class="nx">a</span><span class="p">[</span><span class="nx">mid</span><span class="p">],</span> <span class="nx">mid</span><span class="p">))</span> <span class="nx">hi</span> <span class="o">=</span> <span class="nx">mid</span><span class="p">;</span> <span class="k">else</span> <span class="nx">lo</span> <span class="o">=</span> <span class="nx">mid</span> <span class="o">+</span> <span class="mi">1</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">lo</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="p">};</span>
<span class="kd">var</span> <span class="nx">d3_bisector</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">bisector</span><span class="p">(</span><span class="kd">function</span><span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">;</span>
<span class="p">});</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">bisectLeft</span> <span class="o">=</span> <span class="nx">d3_bisector</span><span class="p">.</span><span class="nx">left</span><span class="p">;</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">bisect</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">bisectRight</span> <span class="o">=</span> <span class="nx">d3_bisector</span><span class="p">.</span><span class="nx">right</span><span class="p">;</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">shuffle</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">m</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">length</span><span class="p">,</span> <span class="nx">t</span><span class="p">,</span> <span class="nx">i</span><span class="p">;</span>
<span class="k">while</span> <span class="p">(</span><span class="nx">m</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">i</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">random</span><span class="p">()</span> <span class="o">*</span> <span class="nx">m</span><span class="o">--</span> <span class="o">|</span> <span class="mi">0</span><span class="p">;</span>
<span class="nx">t</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">m</span><span class="p">],</span> <span class="nx">array</span><span class="p">[</span><span class="nx">m</span><span class="p">]</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">],</span> <span class="nx">array</span><span class="p">[</span><span class="nx">i</span><span class="p">]</span> <span class="o">=</span> <span class="nx">t</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">array</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">permute</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">,</span> <span class="nx">indexes</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="nx">indexes</span><span class="p">.</span><span class="nx">length</span><span class="p">,</span> <span class="nx">permutes</span> <span class="o">=</span> <span class="k">new</span> <span class="nb">Array</span><span class="p">(</span><span class="nx">i</span><span class="p">);</span>
<span class="k">while</span> <span class="p">(</span><span class="nx">i</span><span class="o">--</span><span class="p">)</span> <span class="nx">permutes</span><span class="p">[</span><span class="nx">i</span><span class="p">]</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="nx">indexes</span><span class="p">[</span><span class="nx">i</span><span class="p">]];</span>
<span class="k">return</span> <span class="nx">permutes</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">pairs</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">array</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">,</span> <span class="nx">n</span> <span class="o">=</span> <span class="nx">array</span><span class="p">.</span><span class="nx">length</span> <span class="o">-</span> <span class="mi">1</span><span class="p">,</span> <span class="nx">p0</span><span class="p">,</span> <span class="nx">p1</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="mi">0</span><span class="p">],</span> <span class="nx">pairs</span> <span class="o">=</span> <span class="k">new</span> <span class="nb">Array</span><span class="p">(</span><span class="nx">n</span> <span class="o"><</span> <span class="mi">0</span> <span class="o">?</span> <span class="mi">0</span> <span class="o">:</span> <span class="nx">n</span><span class="p">);</span>
<span class="k">while</span> <span class="p">(</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">n</span><span class="p">)</span> <span class="nx">pairs</span><span class="p">[</span><span class="nx">i</span><span class="p">]</span> <span class="o">=</span> <span class="p">[</span> <span class="nx">p0</span> <span class="o">=</span> <span class="nx">p1</span><span class="p">,</span> <span class="nx">p1</span> <span class="o">=</span> <span class="nx">array</span><span class="p">[</span><span class="o">++</span><span class="nx">i</span><span class="p">]</span> <span class="p">];</span>
<span class="k">return</span> <span class="nx">pairs</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">zip</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="p">(</span><span class="nx">n</span> <span class="o">=</span> <span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span><span class="p">))</span> <span class="k">return</span> <span class="p">[];</span>
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="nx">m</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">min</span><span class="p">(</span><span class="nx">arguments</span><span class="p">,</span> <span class="nx">d3_zipLength</span><span class="p">),</span> <span class="nx">zips</span> <span class="o">=</span> <span class="k">new</span> <span class="nb">Array</span><span class="p">(</span><span class="nx">m</span><span class="p">);</span> <span class="o">++</span><span class="nx">i</span> <span class="o"><</span> <span class="nx">m</span><span class="p">;</span> <span class="p">)</span> <span class="p">{</span>
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">j</span> <span class="o">=</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="nx">n</span><span class="p">,</span> <span class="nx">zip</span> <span class="o">=</span> <span class="nx">zips</span><span class="p">[</span><span class="nx">i</span><span class="p">]</span> <span class="o">=</span> <span class="k">new</span> <span class="nb">Array</span><span class="p">(</span><span class="nx">n</span><span class="p">);</span> <span class="o">++</span><span class="nx">j</span> <span class="o"><</span> <span class="nx">n</span><span class="p">;</span> <span class="p">)</span> <span class="p">{</span>
<span class="nx">zip</span><span class="p">[</span><span class="nx">j</span><span class="p">]</span> <span class="o">=</span> <span class="nx">arguments</span><span class="p">[</span><span class="nx">j</span><span class="p">][</span><span class="nx">i</span><span class="p">];</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">zips</span><span class="p">;</span>
<span class="p">};</span>
<span class="kd">function</span> <span class="nx">d3_zipLength</span><span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span>
<span class="p">}</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">transpose</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">matrix</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">zip</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nx">d3</span><span class="p">,</span> <span class="nx">matrix</span><span class="p">);</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">keys</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">map</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">keys</span> <span class="o">=</span> <span class="p">[];</span>
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">key</span> <span class="k">in</span> <span class="nx">map</span><span class="p">)</span> <span class="nx">keys</span><span class="p">.</span><span class="nx">push</span><span class="p">(</span><span class="nx">key</span><span class="p">);</span>
<span class="k">return</span> <span class="nx">keys</span><span class="p">;</span>
<span class="p">};</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">values</span> <span class="o">=</span> <span class="kd">function