Update c++ snippet
This commit is contained in:
765
index.html
765
index.html
@@ -25894,13 +25894,14 @@ Berrisch, J. <span class="citation" data-cites="berrisch2025rcpptimer">(<a href=
|
|||||||
<div class="sourceCode" id="cb1"><pre class="sourceCode numberSource cpp number-lines code-with-copy"><code class="sourceCode cpp"><span id="cb1-1"><a href></a><span class="co">//[[Rcpp::depends(rcpptimer)]]</span></span>
|
<div class="sourceCode" id="cb1"><pre class="sourceCode numberSource cpp number-lines code-with-copy"><code class="sourceCode cpp"><span id="cb1-1"><a href></a><span class="co">//[[Rcpp::depends(rcpptimer)]]</span></span>
|
||||||
<span id="cb1-2"><a href></a><span class="pp">#include </span><span class="im"><rcpptimer.h></span></span>
|
<span id="cb1-2"><a href></a><span class="pp">#include </span><span class="im"><rcpptimer.h></span></span>
|
||||||
<span id="cb1-3"><a href></a></span>
|
<span id="cb1-3"><a href></a></span>
|
||||||
<span id="cb1-4"><a href></a><span class="dt">void</span> main<span class="op">(){</span></span>
|
<span id="cb1-4"><a href></a><span class="co">//[[Rcpp::export]]</span></span>
|
||||||
<span id="cb1-5"><a href></a> Rcpp<span class="op">::</span>Timer timer<span class="op">;</span></span>
|
<span id="cb1-5"><a href></a><span class="dt">void</span> ex<span class="op">()</span></span>
|
||||||
<span id="cb1-6"><a href></a></span>
|
<span id="cb1-6"><a href></a><span class="op">{</span></span>
|
||||||
<span id="cb1-7"><a href></a> timer<span class="op">.</span>tic<span class="op">();</span></span>
|
<span id="cb1-7"><a href></a> Rcpp<span class="op">::</span>Timer timer<span class="op">;</span></span>
|
||||||
<span id="cb1-8"><a href></a> <span class="co">// Code to be timed</span></span>
|
<span id="cb1-8"><a href></a> timer<span class="op">.</span>tic<span class="op">();</span></span>
|
||||||
<span id="cb1-9"><a href></a> timer<span class="op">.</span>toc<span class="op">();</span></span>
|
<span id="cb1-9"><a href></a> <span class="co">// Code to be timed</span></span>
|
||||||
<span id="cb1-10"><a href></a><span class="op">}</span></span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
<span id="cb1-10"><a href></a> timer<span class="op">.</span>toc<span class="op">();</span></span>
|
||||||
|
<span id="cb1-11"><a href></a><span class="op">}</span></span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
||||||
</div></div>
|
</div></div>
|
||||||
</section></section>
|
</section></section>
|
||||||
<section>
|
<section>
|
||||||
@@ -25951,7 +25952,7 @@ Berrisch, J. <span class="citation" data-cites="berrisch2025rcpptimer">(<a href=
|
|||||||
</div>
|
</div>
|
||||||
<div id="tabset-1-2">
|
<div id="tabset-1-2">
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
<div class="sourceCode cell-code hidden" id="cb2" data-startfrom="821" data-source-offset="0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 820;"><span id="cb2-821"><a href></a>d3 <span class="op">=</span> <span class="pp">require</span>(<span class="st">"d3@7"</span>)</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
<div class="sourceCode cell-code hidden" id="cb2" data-startfrom="822" data-source-offset="0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 821;"><span id="cb2-822"><a href></a>d3 <span class="op">=</span> <span class="pp">require</span>(<span class="st">"d3@7"</span>)</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
||||||
<div class="cell-output cell-output-display">
|
<div class="cell-output cell-output-display">
|
||||||
<div id="ojs-cell-1" data-nodetype="declaration">
|
<div id="ojs-cell-1" data-nodetype="declaration">
|
||||||
|
|
||||||
@@ -25959,7 +25960,7 @@ Berrisch, J. <span class="citation" data-cites="berrisch2025rcpptimer">(<a href=
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
<div class="sourceCode cell-code hidden" id="cb3" data-startfrom="825" data-source-offset="0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 824;"><span id="cb3-825"><a href></a>cdf_data <span class="op">=</span> <span class="fu">FileAttachment</span>(<span class="st">"assets/crps_learning/weights_plot/cdf_data.csv"</span>)<span class="op">.</span><span class="fu">csv</span>({ <span class="dt">typed</span><span class="op">:</span> <span class="kw">true</span> })</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
<div class="sourceCode cell-code hidden" id="cb3" data-startfrom="826" data-source-offset="0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 825;"><span id="cb3-826"><a href></a>cdf_data <span class="op">=</span> <span class="fu">FileAttachment</span>(<span class="st">"assets/crps_learning/weights_plot/cdf_data.csv"</span>)<span class="op">.</span><span class="fu">csv</span>({ <span class="dt">typed</span><span class="op">:</span> <span class="kw">true</span> })</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
||||||
<div class="cell-output cell-output-display">
|
<div class="cell-output cell-output-display">
|
||||||
<div id="ojs-cell-2" data-nodetype="declaration">
|
<div id="ojs-cell-2" data-nodetype="declaration">
|
||||||
|
|
||||||
@@ -25967,190 +25968,190 @@ Berrisch, J. <span class="citation" data-cites="berrisch2025rcpptimer">(<a href=
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
<div class="sourceCode cell-code hidden" id="cb4" data-startfrom="830" data-source-offset="-0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 829;"><span id="cb4-830"><a href></a><span class="kw">function</span> <span class="fu">updateChartInner</span>(g<span class="op">,</span> x<span class="op">,</span> y<span class="op">,</span> linesGroup<span class="op">,</span> color<span class="op">,</span> line<span class="op">,</span> data) {</span>
|
<div class="sourceCode cell-code hidden" id="cb4" data-startfrom="831" data-source-offset="-0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 830;"><span id="cb4-831"><a href></a><span class="kw">function</span> <span class="fu">updateChartInner</span>(g<span class="op">,</span> x<span class="op">,</span> y<span class="op">,</span> linesGroup<span class="op">,</span> color<span class="op">,</span> line<span class="op">,</span> data) {</span>
|
||||||
<span id="cb4-831"><a href></a> <span class="co">// Update axes with transitions</span></span>
|
<span id="cb4-832"><a href></a> <span class="co">// Update axes with transitions</span></span>
|
||||||
<span id="cb4-832"><a href></a> x<span class="op">.</span><span class="fu">domain</span>(d3<span class="op">.</span><span class="fu">extent</span>(data<span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">x</span>))<span class="op">;</span></span>
|
<span id="cb4-833"><a href></a> x<span class="op">.</span><span class="fu">domain</span>(d3<span class="op">.</span><span class="fu">extent</span>(data<span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">x</span>))<span class="op">;</span></span>
|
||||||
<span id="cb4-833"><a href></a> g<span class="op">.</span><span class="fu">select</span>(<span class="st">".x-axis"</span>)<span class="op">.</span><span class="fu">transition</span>()<span class="op">.</span><span class="fu">duration</span>(<span class="dv">1500</span>)<span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisBottom</span>(x)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">10</span>))<span class="op">;</span></span>
|
<span id="cb4-834"><a href></a> g<span class="op">.</span><span class="fu">select</span>(<span class="st">".x-axis"</span>)<span class="op">.</span><span class="fu">transition</span>()<span class="op">.</span><span class="fu">duration</span>(<span class="dv">1500</span>)<span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisBottom</span>(x)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">10</span>))<span class="op">;</span></span>
|
||||||
<span id="cb4-834"><a href></a> y<span class="op">.</span><span class="fu">domain</span>([<span class="dv">0</span><span class="op">,</span> d3<span class="op">.</span><span class="fu">max</span>(data<span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">y</span>)])<span class="op">;</span></span>
|
<span id="cb4-835"><a href></a> y<span class="op">.</span><span class="fu">domain</span>([<span class="dv">0</span><span class="op">,</span> d3<span class="op">.</span><span class="fu">max</span>(data<span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">y</span>)])<span class="op">;</span></span>
|
||||||
<span id="cb4-835"><a href></a> g<span class="op">.</span><span class="fu">select</span>(<span class="st">".y-axis"</span>)<span class="op">.</span><span class="fu">transition</span>()<span class="op">.</span><span class="fu">duration</span>(<span class="dv">1500</span>)<span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisLeft</span>(y)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))<span class="op">;</span></span>
|
<span id="cb4-836"><a href></a> g<span class="op">.</span><span class="fu">select</span>(<span class="st">".y-axis"</span>)<span class="op">.</span><span class="fu">transition</span>()<span class="op">.</span><span class="fu">duration</span>(<span class="dv">1500</span>)<span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisLeft</span>(y)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))<span class="op">;</span></span>
|
||||||
<span id="cb4-836"><a href></a></span>
|
<span id="cb4-837"><a href></a></span>
|
||||||
<span id="cb4-837"><a href></a> <span class="co">// Group data by basis function</span></span>
|
<span id="cb4-838"><a href></a> <span class="co">// Group data by basis function</span></span>
|
||||||
<span id="cb4-838"><a href></a> <span class="kw">const</span> dataByFunction <span class="op">=</span> <span class="bu">Array</span><span class="op">.</span><span class="fu">from</span>(d3<span class="op">.</span><span class="fu">group</span>(data<span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">b</span>))<span class="op">;</span></span>
|
<span id="cb4-839"><a href></a> <span class="kw">const</span> dataByFunction <span class="op">=</span> <span class="bu">Array</span><span class="op">.</span><span class="fu">from</span>(d3<span class="op">.</span><span class="fu">group</span>(data<span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">b</span>))<span class="op">;</span></span>
|
||||||
<span id="cb4-839"><a href></a> <span class="kw">const</span> keyFn <span class="op">=</span> d <span class="kw">=></span> d[<span class="dv">0</span>]<span class="op">;</span></span>
|
<span id="cb4-840"><a href></a> <span class="kw">const</span> keyFn <span class="op">=</span> d <span class="kw">=></span> d[<span class="dv">0</span>]<span class="op">;</span></span>
|
||||||
<span id="cb4-840"><a href></a></span>
|
<span id="cb4-841"><a href></a></span>
|
||||||
<span id="cb4-841"><a href></a> <span class="co">// Update basis function lines</span></span>
|
<span id="cb4-842"><a href></a> <span class="co">// Update basis function lines</span></span>
|
||||||
<span id="cb4-842"><a href></a> <span class="kw">const</span> u <span class="op">=</span> linesGroup<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"path"</span>)<span class="op">.</span><span class="fu">data</span>(dataByFunction<span class="op">,</span> keyFn)<span class="op">;</span></span>
|
<span id="cb4-843"><a href></a> <span class="kw">const</span> u <span class="op">=</span> linesGroup<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"path"</span>)<span class="op">.</span><span class="fu">data</span>(dataByFunction<span class="op">,</span> keyFn)<span class="op">;</span></span>
|
||||||
<span id="cb4-843"><a href></a> u<span class="op">.</span><span class="fu">join</span>(</span>
|
<span id="cb4-844"><a href></a> u<span class="op">.</span><span class="fu">join</span>(</span>
|
||||||
<span id="cb4-844"><a href></a> enter <span class="kw">=></span> enter<span class="op">.</span><span class="fu">append</span>(<span class="st">"path"</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">"fill"</span><span class="op">,</span><span class="st">"none"</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-width"</span><span class="op">,</span><span class="dv">3</span>)</span>
|
<span id="cb4-845"><a href></a> enter <span class="kw">=></span> enter<span class="op">.</span><span class="fu">append</span>(<span class="st">"path"</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">"fill"</span><span class="op">,</span><span class="st">"none"</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-width"</span><span class="op">,</span><span class="dv">3</span>)</span>
|
||||||
<span id="cb4-845"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> (_<span class="op">,</span> i) <span class="kw">=></span> <span class="fu">color</span>(i))<span class="op">.</span><span class="fu">attr</span>(<span class="st">"d"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">line</span>(d[<span class="dv">1</span>]<span class="op">.</span><span class="fu">map</span>(pt <span class="kw">=></span> ({<span class="dt">x</span><span class="op">:</span> pt<span class="op">.</span><span class="at">x</span><span class="op">,</span> <span class="dt">y</span><span class="op">:</span> <span class="dv">0</span>}))))</span>
|
<span id="cb4-846"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> (_<span class="op">,</span> i) <span class="kw">=></span> <span class="fu">color</span>(i))<span class="op">.</span><span class="fu">attr</span>(<span class="st">"d"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">line</span>(d[<span class="dv">1</span>]<span class="op">.</span><span class="fu">map</span>(pt <span class="kw">=></span> ({<span class="dt">x</span><span class="op">:</span> pt<span class="op">.</span><span class="at">x</span><span class="op">,</span> <span class="dt">y</span><span class="op">:</span> <span class="dv">0</span>}))))</span>
|
||||||
<span id="cb4-846"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"opacity"</span><span class="op">,</span><span class="dv">0</span>)<span class="op">,</span></span>
|
<span id="cb4-847"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"opacity"</span><span class="op">,</span><span class="dv">0</span>)<span class="op">,</span></span>
|
||||||
<span id="cb4-847"><a href></a> update <span class="kw">=></span> update<span class="op">,</span></span>
|
<span id="cb4-848"><a href></a> update <span class="kw">=></span> update<span class="op">,</span></span>
|
||||||
<span id="cb4-848"><a href></a> exit <span class="kw">=></span> exit<span class="op">.</span><span class="fu">transition</span>()<span class="op">.</span><span class="fu">duration</span>(<span class="dv">1000</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"opacity"</span><span class="op">,</span><span class="dv">0</span>)<span class="op">.</span><span class="fu">remove</span>()</span>
|
<span id="cb4-849"><a href></a> exit <span class="kw">=></span> exit<span class="op">.</span><span class="fu">transition</span>()<span class="op">.</span><span class="fu">duration</span>(<span class="dv">1000</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"opacity"</span><span class="op">,</span><span class="dv">0</span>)<span class="op">.</span><span class="fu">remove</span>()</span>
|
||||||
<span id="cb4-849"><a href></a> )</span>
|
<span id="cb4-850"><a href></a> )</span>
|
||||||
<span id="cb4-850"><a href></a> <span class="op">.</span><span class="fu">transition</span>()<span class="op">.</span><span class="fu">duration</span>(<span class="dv">1000</span>)</span>
|
<span id="cb4-851"><a href></a> <span class="op">.</span><span class="fu">transition</span>()<span class="op">.</span><span class="fu">duration</span>(<span class="dv">1000</span>)</span>
|
||||||
<span id="cb4-851"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"d"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">line</span>(d[<span class="dv">1</span>]))</span>
|
<span id="cb4-852"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"d"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">line</span>(d[<span class="dv">1</span>]))</span>
|
||||||
<span id="cb4-852"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> (_<span class="op">,</span> i) <span class="kw">=></span> <span class="fu">color</span>(i))</span>
|
<span id="cb4-853"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> (_<span class="op">,</span> i) <span class="kw">=></span> <span class="fu">color</span>(i))</span>
|
||||||
<span id="cb4-853"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"opacity"</span><span class="op">,</span><span class="dv">1</span>)<span class="op">;</span></span>
|
<span id="cb4-854"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"opacity"</span><span class="op">,</span><span class="dv">1</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-854"><a href></a>}</span>
|
<span id="cb4-855"><a href></a>}</span>
|
||||||
<span id="cb4-855"><a href></a></span>
|
<span id="cb4-856"><a href></a></span>
|
||||||
<span id="cb4-856"><a href></a>chart <span class="op">=</span> {</span>
|
<span id="cb4-857"><a href></a>chart <span class="op">=</span> {</span>
|
||||||
<span id="cb4-857"><a href></a> <span class="co">// State variable for selected mu parameter</span></span>
|
<span id="cb4-858"><a href></a> <span class="co">// State variable for selected mu parameter</span></span>
|
||||||
<span id="cb4-858"><a href></a> <span class="kw">let</span> selectedMu <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
<span id="cb4-859"><a href></a> <span class="kw">let</span> selectedMu <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
||||||
<span id="cb4-859"><a href></a> </span>
|
<span id="cb4-860"><a href></a> </span>
|
||||||
<span id="cb4-860"><a href></a> <span class="kw">const</span> filteredData <span class="op">=</span> () <span class="kw">=></span> cdf_data<span class="op">.</span><span class="fu">filter</span>(d <span class="kw">=></span></span>
|
<span id="cb4-861"><a href></a> <span class="kw">const</span> filteredData <span class="op">=</span> () <span class="kw">=></span> cdf_data<span class="op">.</span><span class="fu">filter</span>(d <span class="kw">=></span></span>
|
||||||
<span id="cb4-861"><a href></a> <span class="bu">Math</span><span class="op">.</span><span class="fu">abs</span>(selectedMu <span class="op">-</span> d<span class="op">.</span><span class="at">mu</span>) <span class="op"><</span> <span class="fl">0.001</span></span>
|
<span id="cb4-862"><a href></a> <span class="bu">Math</span><span class="op">.</span><span class="fu">abs</span>(selectedMu <span class="op">-</span> d<span class="op">.</span><span class="at">mu</span>) <span class="op"><</span> <span class="fl">0.001</span></span>
|
||||||
<span id="cb4-862"><a href></a> )<span class="op">;</span></span>
|
<span id="cb4-863"><a href></a> )<span class="op">;</span></span>
|
||||||
<span id="cb4-863"><a href></a> </span>
|
<span id="cb4-864"><a href></a> </span>
|
||||||
<span id="cb4-864"><a href></a> <span class="kw">const</span> container <span class="op">=</span> d3<span class="op">.</span><span class="fu">create</span>(<span class="st">"div"</span>)</span>
|
<span id="cb4-865"><a href></a> <span class="kw">const</span> container <span class="op">=</span> d3<span class="op">.</span><span class="fu">create</span>(<span class="st">"div"</span>)</span>
|
||||||
<span id="cb4-865"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"max-width"</span><span class="op">,</span> <span class="st">"none"</span>)</span>
|
<span id="cb4-866"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"max-width"</span><span class="op">,</span> <span class="st">"none"</span>)</span>
|
||||||
<span id="cb4-866"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">;</span></span>
|
<span id="cb4-867"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-867"><a href></a> </span>
|
<span id="cb4-868"><a href></a> </span>
|
||||||
<span id="cb4-868"><a href></a> <span class="kw">const</span> controlsContainer <span class="op">=</span> container<span class="op">.</span><span class="fu">append</span>(<span class="st">"div"</span>)</span>
|
<span id="cb4-869"><a href></a> <span class="kw">const</span> controlsContainer <span class="op">=</span> container<span class="op">.</span><span class="fu">append</span>(<span class="st">"div"</span>)</span>
|
||||||
<span id="cb4-869"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"display"</span><span class="op">,</span> <span class="st">"flex"</span>)</span>
|
<span id="cb4-870"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"display"</span><span class="op">,</span> <span class="st">"flex"</span>)</span>
|
||||||
<span id="cb4-870"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"gap"</span><span class="op">,</span> <span class="st">"20px"</span>)</span>
|
<span id="cb4-871"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"gap"</span><span class="op">,</span> <span class="st">"20px"</span>)</span>
|
||||||
<span id="cb4-871"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"align-items"</span><span class="op">,</span> <span class="st">"center"</span>)<span class="op">;</span></span>
|
<span id="cb4-872"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"align-items"</span><span class="op">,</span> <span class="st">"center"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-872"><a href></a> </span>
|
<span id="cb4-873"><a href></a> </span>
|
||||||
<span id="cb4-873"><a href></a> <span class="co">// Single slider control for mu</span></span>
|
<span id="cb4-874"><a href></a> <span class="co">// Single slider control for mu</span></span>
|
||||||
<span id="cb4-874"><a href></a> <span class="kw">const</span> sliderContainer <span class="op">=</span> controlsContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'div'</span>)</span>
|
<span id="cb4-875"><a href></a> <span class="kw">const</span> sliderContainer <span class="op">=</span> controlsContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'div'</span>)</span>
|
||||||
<span id="cb4-875"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'display'</span><span class="op">,</span><span class="st">'flex'</span>)</span>
|
<span id="cb4-876"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'display'</span><span class="op">,</span><span class="st">'flex'</span>)</span>
|
||||||
<span id="cb4-876"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'align-items'</span><span class="op">,</span><span class="st">'center'</span>)</span>
|
<span id="cb4-877"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'align-items'</span><span class="op">,</span><span class="st">'center'</span>)</span>
|
||||||
<span id="cb4-877"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'gap'</span><span class="op">,</span><span class="st">'10px'</span>)</span>
|
<span id="cb4-878"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'gap'</span><span class="op">,</span><span class="st">'10px'</span>)</span>
|
||||||
<span id="cb4-878"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'flex'</span><span class="op">,</span><span class="st">'1'</span>)<span class="op">;</span></span>
|
<span id="cb4-879"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'flex'</span><span class="op">,</span><span class="st">'1'</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-879"><a href></a> </span>
|
<span id="cb4-880"><a href></a> </span>
|
||||||
<span id="cb4-880"><a href></a> sliderContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'label'</span>)</span>
|
<span id="cb4-881"><a href></a> sliderContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'label'</span>)</span>
|
||||||
<span id="cb4-881"><a href></a> <span class="op">.</span><span class="fu">text</span>(<span class="st">'Naive:'</span>)</span>
|
<span id="cb4-882"><a href></a> <span class="op">.</span><span class="fu">text</span>(<span class="st">'Naive:'</span>)</span>
|
||||||
<span id="cb4-882"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span><span class="st">'20px'</span>)<span class="op">;</span></span>
|
<span id="cb4-883"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span><span class="st">'20px'</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-883"><a href></a> </span>
|
<span id="cb4-884"><a href></a> </span>
|
||||||
<span id="cb4-884"><a href></a> <span class="kw">const</span> muSlider <span class="op">=</span> sliderContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'input'</span>)</span>
|
<span id="cb4-885"><a href></a> <span class="kw">const</span> muSlider <span class="op">=</span> sliderContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'input'</span>)</span>
|
||||||
<span id="cb4-885"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'type'</span><span class="op">,</span><span class="st">'range'</span>)</span>
|
<span id="cb4-886"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'type'</span><span class="op">,</span><span class="st">'range'</span>)</span>
|
||||||
<span id="cb4-886"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'min'</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
<span id="cb4-887"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'min'</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
||||||
<span id="cb4-887"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'max'</span><span class="op">,</span> <span class="dv">1</span>)</span>
|
<span id="cb4-888"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'max'</span><span class="op">,</span> <span class="dv">1</span>)</span>
|
||||||
<span id="cb4-888"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'step'</span><span class="op">,</span> <span class="fl">0.1</span>)</span>
|
<span id="cb4-889"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'step'</span><span class="op">,</span> <span class="fl">0.1</span>)</span>
|
||||||
<span id="cb4-889"><a href></a> <span class="op">.</span><span class="fu">property</span>(<span class="st">'value'</span><span class="op">,</span> selectedMu)</span>
|
<span id="cb4-890"><a href></a> <span class="op">.</span><span class="fu">property</span>(<span class="st">'value'</span><span class="op">,</span> selectedMu)</span>
|
||||||
<span id="cb4-890"><a href></a> <span class="op">.</span><span class="fu">on</span>(<span class="st">'input'</span><span class="op">,</span> <span class="kw">function</span>(<span class="bu">event</span>) {</span>
|
<span id="cb4-891"><a href></a> <span class="op">.</span><span class="fu">on</span>(<span class="st">'input'</span><span class="op">,</span> <span class="kw">function</span>(<span class="bu">event</span>) {</span>
|
||||||
<span id="cb4-891"><a href></a> selectedMu <span class="op">=</span> <span class="op">+</span><span class="kw">this</span><span class="op">.</span><span class="at">value</span><span class="op">;</span></span>
|
<span id="cb4-892"><a href></a> selectedMu <span class="op">=</span> <span class="op">+</span><span class="kw">this</span><span class="op">.</span><span class="at">value</span><span class="op">;</span></span>
|
||||||
<span id="cb4-892"><a href></a> muDisplay<span class="op">.</span><span class="fu">text</span>(selectedMu<span class="op">.</span><span class="fu">toFixed</span>(<span class="dv">1</span>))<span class="op">;</span></span>
|
<span id="cb4-893"><a href></a> muDisplay<span class="op">.</span><span class="fu">text</span>(selectedMu<span class="op">.</span><span class="fu">toFixed</span>(<span class="dv">1</span>))<span class="op">;</span></span>
|
||||||
<span id="cb4-893"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
<span id="cb4-894"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
||||||
<span id="cb4-894"><a href></a> })</span>
|
<span id="cb4-895"><a href></a> })</span>
|
||||||
<span id="cb4-895"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'width'</span><span class="op">,</span> <span class="st">'100%'</span>)</span>
|
<span id="cb4-896"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'width'</span><span class="op">,</span> <span class="st">'100%'</span>)</span>
|
||||||
<span id="cb4-896"><a href></a> <span class="co">//.style('-webkit-appearance', 'none')</span></span>
|
<span id="cb4-897"><a href></a> <span class="co">//.style('-webkit-appearance', 'none')</span></span>
|
||||||
<span id="cb4-897"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'appearance'</span><span class="op">,</span> <span class="st">'none'</span>)</span>
|
<span id="cb4-898"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'appearance'</span><span class="op">,</span> <span class="st">'none'</span>)</span>
|
||||||
<span id="cb4-898"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'height'</span><span class="op">,</span> <span class="st">'8px'</span>)</span>
|
<span id="cb4-899"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'height'</span><span class="op">,</span> <span class="st">'8px'</span>)</span>
|
||||||
<span id="cb4-899"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'background'</span><span class="op">,</span> <span class="st">'#BDBDBDFF'</span>)<span class="op">;</span></span>
|
<span id="cb4-900"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'background'</span><span class="op">,</span> <span class="st">'#BDBDBDFF'</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-900"><a href></a> </span>
|
<span id="cb4-901"><a href></a> </span>
|
||||||
<span id="cb4-901"><a href></a> <span class="kw">const</span> muDisplay <span class="op">=</span> sliderContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'span'</span>)</span>
|
<span id="cb4-902"><a href></a> <span class="kw">const</span> muDisplay <span class="op">=</span> sliderContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'span'</span>)</span>
|
||||||
<span id="cb4-902"><a href></a> <span class="op">.</span><span class="fu">text</span>(selectedMu<span class="op">.</span><span class="fu">toFixed</span>(<span class="dv">1</span>))</span>
|
<span id="cb4-903"><a href></a> <span class="op">.</span><span class="fu">text</span>(selectedMu<span class="op">.</span><span class="fu">toFixed</span>(<span class="dv">1</span>))</span>
|
||||||
<span id="cb4-903"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span><span class="st">'20px'</span>)<span class="op">;</span></span>
|
<span id="cb4-904"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span><span class="st">'20px'</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-904"><a href></a> </span>
|
<span id="cb4-905"><a href></a> </span>
|
||||||
<span id="cb4-905"><a href></a> <span class="co">// Add Reset button</span></span>
|
<span id="cb4-906"><a href></a> <span class="co">// Add Reset button</span></span>
|
||||||
<span id="cb4-906"><a href></a> controlsContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'button'</span>)</span>
|
<span id="cb4-907"><a href></a> controlsContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'button'</span>)</span>
|
||||||
<span id="cb4-907"><a href></a> <span class="op">.</span><span class="fu">text</span>(<span class="st">'Reset'</span>)</span>
|
<span id="cb4-908"><a href></a> <span class="op">.</span><span class="fu">text</span>(<span class="st">'Reset'</span>)</span>
|
||||||
<span id="cb4-908"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span> <span class="st">'20px'</span>)</span>
|
<span id="cb4-909"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span> <span class="st">'20px'</span>)</span>
|
||||||
<span id="cb4-909"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'align-self'</span><span class="op">,</span> <span class="st">'center'</span>)</span>
|
<span id="cb4-910"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'align-self'</span><span class="op">,</span> <span class="st">'center'</span>)</span>
|
||||||
<span id="cb4-910"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'margin-left'</span><span class="op">,</span> <span class="st">'auto'</span>)</span>
|
<span id="cb4-911"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'margin-left'</span><span class="op">,</span> <span class="st">'auto'</span>)</span>
|
||||||
<span id="cb4-911"><a href></a> <span class="op">.</span><span class="fu">on</span>(<span class="st">'click'</span><span class="op">,</span> () <span class="kw">=></span> {</span>
|
<span id="cb4-912"><a href></a> <span class="op">.</span><span class="fu">on</span>(<span class="st">'click'</span><span class="op">,</span> () <span class="kw">=></span> {</span>
|
||||||
<span id="cb4-912"><a href></a> selectedMu <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
<span id="cb4-913"><a href></a> selectedMu <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
||||||
<span id="cb4-913"><a href></a> muSlider<span class="op">.</span><span class="fu">property</span>(<span class="st">'value'</span><span class="op">,</span> selectedMu)<span class="op">;</span></span>
|
<span id="cb4-914"><a href></a> muSlider<span class="op">.</span><span class="fu">property</span>(<span class="st">'value'</span><span class="op">,</span> selectedMu)<span class="op">;</span></span>
|
||||||
<span id="cb4-914"><a href></a> muDisplay<span class="op">.</span><span class="fu">text</span>(selectedMu<span class="op">.</span><span class="fu">toFixed</span>(<span class="dv">1</span>))<span class="op">;</span></span>
|
<span id="cb4-915"><a href></a> muDisplay<span class="op">.</span><span class="fu">text</span>(selectedMu<span class="op">.</span><span class="fu">toFixed</span>(<span class="dv">1</span>))<span class="op">;</span></span>
|
||||||
<span id="cb4-915"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
<span id="cb4-916"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
||||||
<span id="cb4-916"><a href></a> })<span class="op">;</span></span>
|
<span id="cb4-917"><a href></a> })<span class="op">;</span></span>
|
||||||
<span id="cb4-917"><a href></a></span>
|
<span id="cb4-918"><a href></a></span>
|
||||||
<span id="cb4-918"><a href></a> <span class="co">// Build SVG</span></span>
|
<span id="cb4-919"><a href></a> <span class="co">// Build SVG</span></span>
|
||||||
<span id="cb4-919"><a href></a> <span class="kw">const</span> width <span class="op">=</span> <span class="dv">600</span><span class="op">;</span></span>
|
<span id="cb4-920"><a href></a> <span class="kw">const</span> width <span class="op">=</span> <span class="dv">600</span><span class="op">;</span></span>
|
||||||
<span id="cb4-920"><a href></a> <span class="kw">const</span> height <span class="op">=</span> <span class="dv">450</span><span class="op">;</span></span>
|
<span id="cb4-921"><a href></a> <span class="kw">const</span> height <span class="op">=</span> <span class="dv">450</span><span class="op">;</span></span>
|
||||||
<span id="cb4-921"><a href></a> <span class="kw">const</span> margin <span class="op">=</span> {<span class="dt">top</span><span class="op">:</span> <span class="dv">40</span><span class="op">,</span> <span class="dt">right</span><span class="op">:</span> <span class="dv">20</span><span class="op">,</span> <span class="dt">bottom</span><span class="op">:</span> <span class="dv">40</span><span class="op">,</span> <span class="dt">left</span><span class="op">:</span> <span class="dv">40</span>}<span class="op">;</span></span>
|
<span id="cb4-922"><a href></a> <span class="kw">const</span> margin <span class="op">=</span> {<span class="dt">top</span><span class="op">:</span> <span class="dv">40</span><span class="op">,</span> <span class="dt">right</span><span class="op">:</span> <span class="dv">20</span><span class="op">,</span> <span class="dt">bottom</span><span class="op">:</span> <span class="dv">40</span><span class="op">,</span> <span class="dt">left</span><span class="op">:</span> <span class="dv">40</span>}<span class="op">;</span></span>
|
||||||
<span id="cb4-922"><a href></a> <span class="kw">const</span> innerWidth <span class="op">=</span> width <span class="op">-</span> margin<span class="op">.</span><span class="at">left</span> <span class="op">-</span> margin<span class="op">.</span><span class="at">right</span><span class="op">;</span></span>
|
<span id="cb4-923"><a href></a> <span class="kw">const</span> innerWidth <span class="op">=</span> width <span class="op">-</span> margin<span class="op">.</span><span class="at">left</span> <span class="op">-</span> margin<span class="op">.</span><span class="at">right</span><span class="op">;</span></span>
|
||||||
<span id="cb4-923"><a href></a> <span class="kw">const</span> innerHeight <span class="op">=</span> height <span class="op">-</span> margin<span class="op">.</span><span class="at">top</span> <span class="op">-</span> margin<span class="op">.</span><span class="at">bottom</span><span class="op">;</span></span>
|
<span id="cb4-924"><a href></a> <span class="kw">const</span> innerHeight <span class="op">=</span> height <span class="op">-</span> margin<span class="op">.</span><span class="at">top</span> <span class="op">-</span> margin<span class="op">.</span><span class="at">bottom</span><span class="op">;</span></span>
|
||||||
<span id="cb4-924"><a href></a></span>
|
<span id="cb4-925"><a href></a></span>
|
||||||
<span id="cb4-925"><a href></a> <span class="co">// Set controls container width to match SVG plot width</span></span>
|
<span id="cb4-926"><a href></a> <span class="co">// Set controls container width to match SVG plot width</span></span>
|
||||||
<span id="cb4-926"><a href></a> controlsContainer<span class="op">.</span><span class="fu">style</span>(<span class="st">"max-width"</span><span class="op">,</span> <span class="st">"none"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">;</span></span>
|
<span id="cb4-927"><a href></a> controlsContainer<span class="op">.</span><span class="fu">style</span>(<span class="st">"max-width"</span><span class="op">,</span> <span class="st">"none"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-927"><a href></a> <span class="co">// Distribute each control evenly and make sliders full-width</span></span>
|
<span id="cb4-928"><a href></a> <span class="co">// Distribute each control evenly and make sliders full-width</span></span>
|
||||||
<span id="cb4-928"><a href></a> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"div"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"flex"</span><span class="op">,</span> <span class="st">"1"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"min-width"</span><span class="op">,</span> <span class="st">"0px"</span>)<span class="op">;</span></span>
|
<span id="cb4-929"><a href></a> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"div"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"flex"</span><span class="op">,</span> <span class="st">"1"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"min-width"</span><span class="op">,</span> <span class="st">"0px"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-929"><a href></a> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"input"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"box-sizing"</span><span class="op">,</span> <span class="st">"border-box"</span>)<span class="op">;</span></span>
|
<span id="cb4-930"><a href></a> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"input"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"box-sizing"</span><span class="op">,</span> <span class="st">"border-box"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-930"><a href></a> </span>
|
<span id="cb4-931"><a href></a> </span>
|
||||||
<span id="cb4-931"><a href></a> <span class="co">// Create scales</span></span>
|
<span id="cb4-932"><a href></a> <span class="co">// Create scales</span></span>
|
||||||
<span id="cb4-932"><a href></a> <span class="kw">const</span> x <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleLinear</span>()</span>
|
<span id="cb4-933"><a href></a> <span class="kw">const</span> x <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleLinear</span>()</span>
|
||||||
<span id="cb4-933"><a href></a> <span class="op">.</span><span class="fu">range</span>([<span class="dv">0</span><span class="op">,</span> innerWidth])<span class="op">;</span></span>
|
<span id="cb4-934"><a href></a> <span class="op">.</span><span class="fu">range</span>([<span class="dv">0</span><span class="op">,</span> innerWidth])<span class="op">;</span></span>
|
||||||
<span id="cb4-934"><a href></a> </span>
|
<span id="cb4-935"><a href></a> </span>
|
||||||
<span id="cb4-935"><a href></a> <span class="kw">const</span> y <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleLinear</span>()</span>
|
<span id="cb4-936"><a href></a> <span class="kw">const</span> y <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleLinear</span>()</span>
|
||||||
<span id="cb4-936"><a href></a> <span class="op">.</span><span class="fu">range</span>([innerHeight<span class="op">,</span> <span class="dv">0</span>])<span class="op">;</span></span>
|
<span id="cb4-937"><a href></a> <span class="op">.</span><span class="fu">range</span>([innerHeight<span class="op">,</span> <span class="dv">0</span>])<span class="op">;</span></span>
|
||||||
<span id="cb4-937"><a href></a> </span>
|
<span id="cb4-938"><a href></a> </span>
|
||||||
<span id="cb4-938"><a href></a> <span class="co">// Create a color scale for the basis functions</span></span>
|
<span id="cb4-939"><a href></a> <span class="co">// Create a color scale for the basis functions</span></span>
|
||||||
<span id="cb4-939"><a href></a> <span class="kw">const</span> color <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleOrdinal</span>([<span class="st">"#80C684FF"</span><span class="op">,</span> <span class="st">"#FFD44EFF"</span><span class="op">,</span> <span class="st">"#D81A5FFF"</span>])<span class="op">;</span></span>
|
<span id="cb4-940"><a href></a> <span class="kw">const</span> color <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleOrdinal</span>([<span class="st">"#80C684FF"</span><span class="op">,</span> <span class="st">"#FFD44EFF"</span><span class="op">,</span> <span class="st">"#D81A5FFF"</span>])<span class="op">;</span></span>
|
||||||
<span id="cb4-940"><a href></a> </span>
|
<span id="cb4-941"><a href></a> </span>
|
||||||
<span id="cb4-941"><a href></a> <span class="co">// Create SVG</span></span>
|
<span id="cb4-942"><a href></a> <span class="co">// Create SVG</span></span>
|
||||||
<span id="cb4-942"><a href></a> <span class="kw">const</span> svg <span class="op">=</span> d3<span class="op">.</span><span class="fu">create</span>(<span class="st">"svg"</span>)</span>
|
<span id="cb4-943"><a href></a> <span class="kw">const</span> svg <span class="op">=</span> d3<span class="op">.</span><span class="fu">create</span>(<span class="st">"svg"</span>)</span>
|
||||||
<span id="cb4-943"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)</span>
|
<span id="cb4-944"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)</span>
|
||||||
<span id="cb4-944"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"height"</span><span class="op">,</span> <span class="st">"auto"</span>)</span>
|
<span id="cb4-945"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"height"</span><span class="op">,</span> <span class="st">"auto"</span>)</span>
|
||||||
<span id="cb4-945"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"viewBox"</span><span class="op">,</span> [<span class="dv">0</span><span class="op">,</span> <span class="dv">0</span><span class="op">,</span> width<span class="op">,</span> height])</span>
|
<span id="cb4-946"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"viewBox"</span><span class="op">,</span> [<span class="dv">0</span><span class="op">,</span> <span class="dv">0</span><span class="op">,</span> width<span class="op">,</span> height])</span>
|
||||||
<span id="cb4-946"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"preserveAspectRatio"</span><span class="op">,</span> <span class="st">"xMidYMid meet"</span>)</span>
|
<span id="cb4-947"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"preserveAspectRatio"</span><span class="op">,</span> <span class="st">"xMidYMid meet"</span>)</span>
|
||||||
<span id="cb4-947"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"style"</span><span class="op">,</span> <span class="st">"max-width: 100%; height: auto;"</span>)<span class="op">;</span></span>
|
<span id="cb4-948"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"style"</span><span class="op">,</span> <span class="st">"max-width: 100%; height: auto;"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-948"><a href></a> </span>
|
<span id="cb4-949"><a href></a> </span>
|
||||||
<span id="cb4-949"><a href></a> <span class="co">// Create the chart group</span></span>
|
<span id="cb4-950"><a href></a> <span class="co">// Create the chart group</span></span>
|
||||||
<span id="cb4-950"><a href></a> <span class="kw">const</span> g <span class="op">=</span> svg<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb4-951"><a href></a> <span class="kw">const</span> g <span class="op">=</span> svg<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb4-951"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"transform"</span><span class="op">,</span> <span class="vs">`translate(</span><span class="sc">${</span>margin<span class="op">.</span><span class="at">left</span><span class="sc">}</span><span class="vs">,</span><span class="sc">${</span>margin<span class="op">.</span><span class="at">top</span><span class="sc">}</span><span class="vs">)`</span>)<span class="op">;</span></span>
|
<span id="cb4-952"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"transform"</span><span class="op">,</span> <span class="vs">`translate(</span><span class="sc">${</span>margin<span class="op">.</span><span class="at">left</span><span class="sc">}</span><span class="vs">,</span><span class="sc">${</span>margin<span class="op">.</span><span class="at">top</span><span class="sc">}</span><span class="vs">)`</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-952"><a href></a> </span>
|
<span id="cb4-953"><a href></a> </span>
|
||||||
<span id="cb4-953"><a href></a> <span class="co">// Add axes</span></span>
|
<span id="cb4-954"><a href></a> <span class="co">// Add axes</span></span>
|
||||||
<span id="cb4-954"><a href></a> <span class="kw">const</span> xAxis <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb4-955"><a href></a> <span class="kw">const</span> xAxis <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb4-955"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"transform"</span><span class="op">,</span> <span class="vs">`translate(0,</span><span class="sc">${</span>innerHeight<span class="sc">}</span><span class="vs">)`</span>)</span>
|
<span id="cb4-956"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"transform"</span><span class="op">,</span> <span class="vs">`translate(0,</span><span class="sc">${</span>innerHeight<span class="sc">}</span><span class="vs">)`</span>)</span>
|
||||||
<span id="cb4-956"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"x-axis"</span>)</span>
|
<span id="cb4-957"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"x-axis"</span>)</span>
|
||||||
<span id="cb4-957"><a href></a> <span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisBottom</span>(x)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">10</span>))</span>
|
<span id="cb4-958"><a href></a> <span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisBottom</span>(x)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">10</span>))</span>
|
||||||
<span id="cb4-958"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"font-size"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
<span id="cb4-959"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"font-size"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-959"><a href></a> </span>
|
<span id="cb4-960"><a href></a> </span>
|
||||||
<span id="cb4-960"><a href></a> <span class="kw">const</span> yAxis <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb4-961"><a href></a> <span class="kw">const</span> yAxis <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb4-961"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"y-axis"</span>)</span>
|
<span id="cb4-962"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"y-axis"</span>)</span>
|
||||||
<span id="cb4-962"><a href></a> <span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisLeft</span>(y)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))</span>
|
<span id="cb4-963"><a href></a> <span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisLeft</span>(y)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))</span>
|
||||||
<span id="cb4-963"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"font-size"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
<span id="cb4-964"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"font-size"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-964"><a href></a> </span>
|
<span id="cb4-965"><a href></a> </span>
|
||||||
<span id="cb4-965"><a href></a> <span class="co">// Add a horizontal line at y = 0</span></span>
|
<span id="cb4-966"><a href></a> <span class="co">// Add a horizontal line at y = 0</span></span>
|
||||||
<span id="cb4-966"><a href></a> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"line"</span>)</span>
|
<span id="cb4-967"><a href></a> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"line"</span>)</span>
|
||||||
<span id="cb4-967"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x1"</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
<span id="cb4-968"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x1"</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
||||||
<span id="cb4-968"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x2"</span><span class="op">,</span> innerWidth)</span>
|
<span id="cb4-969"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x2"</span><span class="op">,</span> innerWidth)</span>
|
||||||
<span id="cb4-969"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y1"</span><span class="op">,</span> <span class="fu">y</span>(<span class="dv">0</span>))</span>
|
<span id="cb4-970"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y1"</span><span class="op">,</span> <span class="fu">y</span>(<span class="dv">0</span>))</span>
|
||||||
<span id="cb4-970"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y2"</span><span class="op">,</span> <span class="fu">y</span>(<span class="dv">0</span>))</span>
|
<span id="cb4-971"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y2"</span><span class="op">,</span> <span class="fu">y</span>(<span class="dv">0</span>))</span>
|
||||||
<span id="cb4-971"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> <span class="st">"#000"</span>)</span>
|
<span id="cb4-972"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> <span class="st">"#000"</span>)</span>
|
||||||
<span id="cb4-972"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-opacity"</span><span class="op">,</span> <span class="fl">0.2</span>)<span class="op">;</span></span>
|
<span id="cb4-973"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-opacity"</span><span class="op">,</span> <span class="fl">0.2</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-973"><a href></a> </span>
|
<span id="cb4-974"><a href></a> </span>
|
||||||
<span id="cb4-974"><a href></a> <span class="co">// Add gridlines</span></span>
|
<span id="cb4-975"><a href></a> <span class="co">// Add gridlines</span></span>
|
||||||
<span id="cb4-975"><a href></a> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb4-976"><a href></a> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb4-976"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"grid-lines"</span>)</span>
|
<span id="cb4-977"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"grid-lines"</span>)</span>
|
||||||
<span id="cb4-977"><a href></a> <span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"line"</span>)</span>
|
<span id="cb4-978"><a href></a> <span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"line"</span>)</span>
|
||||||
<span id="cb4-978"><a href></a> <span class="op">.</span><span class="fu">data</span>(y<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))</span>
|
<span id="cb4-979"><a href></a> <span class="op">.</span><span class="fu">data</span>(y<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))</span>
|
||||||
<span id="cb4-979"><a href></a> <span class="op">.</span><span class="fu">join</span>(<span class="st">"line"</span>)</span>
|
<span id="cb4-980"><a href></a> <span class="op">.</span><span class="fu">join</span>(<span class="st">"line"</span>)</span>
|
||||||
<span id="cb4-980"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x1"</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
<span id="cb4-981"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x1"</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
||||||
<span id="cb4-981"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x2"</span><span class="op">,</span> innerWidth)</span>
|
<span id="cb4-982"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x2"</span><span class="op">,</span> innerWidth)</span>
|
||||||
<span id="cb4-982"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y1"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">y</span>(d))</span>
|
<span id="cb4-983"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y1"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">y</span>(d))</span>
|
||||||
<span id="cb4-983"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y2"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">y</span>(d))</span>
|
<span id="cb4-984"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y2"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">y</span>(d))</span>
|
||||||
<span id="cb4-984"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> <span class="st">"#ccc"</span>)</span>
|
<span id="cb4-985"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> <span class="st">"#ccc"</span>)</span>
|
||||||
<span id="cb4-985"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-opacity"</span><span class="op">,</span> <span class="fl">0.5</span>)<span class="op">;</span></span>
|
<span id="cb4-986"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-opacity"</span><span class="op">,</span> <span class="fl">0.5</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-986"><a href></a> </span>
|
<span id="cb4-987"><a href></a> </span>
|
||||||
<span id="cb4-987"><a href></a> <span class="co">// Create a line generator</span></span>
|
<span id="cb4-988"><a href></a> <span class="co">// Create a line generator</span></span>
|
||||||
<span id="cb4-988"><a href></a> <span class="kw">const</span> line <span class="op">=</span> d3<span class="op">.</span><span class="fu">line</span>()</span>
|
<span id="cb4-989"><a href></a> <span class="kw">const</span> line <span class="op">=</span> d3<span class="op">.</span><span class="fu">line</span>()</span>
|
||||||
<span id="cb4-989"><a href></a> <span class="op">.</span><span class="fu">x</span>(d <span class="kw">=></span> <span class="fu">x</span>(d<span class="op">.</span><span class="at">x</span>))</span>
|
<span id="cb4-990"><a href></a> <span class="op">.</span><span class="fu">x</span>(d <span class="kw">=></span> <span class="fu">x</span>(d<span class="op">.</span><span class="at">x</span>))</span>
|
||||||
<span id="cb4-990"><a href></a> <span class="op">.</span><span class="fu">y</span>(d <span class="kw">=></span> <span class="fu">y</span>(d<span class="op">.</span><span class="at">y</span>))</span>
|
<span id="cb4-991"><a href></a> <span class="op">.</span><span class="fu">y</span>(d <span class="kw">=></span> <span class="fu">y</span>(d<span class="op">.</span><span class="at">y</span>))</span>
|
||||||
<span id="cb4-991"><a href></a> <span class="op">.</span><span class="fu">curve</span>(d3<span class="op">.</span><span class="at">curveBasis</span>)<span class="op">;</span></span>
|
<span id="cb4-992"><a href></a> <span class="op">.</span><span class="fu">curve</span>(d3<span class="op">.</span><span class="at">curveBasis</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-992"><a href></a> </span>
|
<span id="cb4-993"><a href></a> </span>
|
||||||
<span id="cb4-993"><a href></a> <span class="co">// Group to contain the basis function lines</span></span>
|
<span id="cb4-994"><a href></a> <span class="co">// Group to contain the basis function lines</span></span>
|
||||||
<span id="cb4-994"><a href></a> <span class="kw">const</span> linesGroup <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb4-995"><a href></a> <span class="kw">const</span> linesGroup <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb4-995"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"basis-functions"</span>)<span class="op">;</span></span>
|
<span id="cb4-996"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"basis-functions"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb4-996"><a href></a> </span>
|
<span id="cb4-997"><a href></a> </span>
|
||||||
<span id="cb4-997"><a href></a> <span class="co">// Store the current basis functions for transition</span></span>
|
<span id="cb4-998"><a href></a> <span class="co">// Store the current basis functions for transition</span></span>
|
||||||
<span id="cb4-998"><a href></a> <span class="kw">let</span> currentBasisFunctions <span class="op">=</span> <span class="kw">new</span> <span class="bu">Map</span>()<span class="op">;</span></span>
|
<span id="cb4-999"><a href></a> <span class="kw">let</span> currentBasisFunctions <span class="op">=</span> <span class="kw">new</span> <span class="bu">Map</span>()<span class="op">;</span></span>
|
||||||
<span id="cb4-999"><a href></a> </span>
|
<span id="cb4-1000"><a href></a> </span>
|
||||||
<span id="cb4-1000"><a href></a> <span class="co">// Function to update the chart with new data</span></span>
|
<span id="cb4-1001"><a href></a> <span class="co">// Function to update the chart with new data</span></span>
|
||||||
<span id="cb4-1001"><a href></a> <span class="kw">function</span> <span class="fu">updateChart</span>(data) {</span>
|
<span id="cb4-1002"><a href></a> <span class="kw">function</span> <span class="fu">updateChart</span>(data) {</span>
|
||||||
<span id="cb4-1002"><a href></a> <span class="fu">updateChartInner</span>(g<span class="op">,</span> x<span class="op">,</span> y<span class="op">,</span> linesGroup<span class="op">,</span> color<span class="op">,</span> line<span class="op">,</span> data)<span class="op">;</span></span>
|
<span id="cb4-1003"><a href></a> <span class="fu">updateChartInner</span>(g<span class="op">,</span> x<span class="op">,</span> y<span class="op">,</span> linesGroup<span class="op">,</span> color<span class="op">,</span> line<span class="op">,</span> data)<span class="op">;</span></span>
|
||||||
<span id="cb4-1003"><a href></a> }</span>
|
<span id="cb4-1004"><a href></a> }</span>
|
||||||
<span id="cb4-1004"><a href></a> </span>
|
<span id="cb4-1005"><a href></a> </span>
|
||||||
<span id="cb4-1005"><a href></a> <span class="co">// Store the update function</span></span>
|
<span id="cb4-1006"><a href></a> <span class="co">// Store the update function</span></span>
|
||||||
<span id="cb4-1006"><a href></a> svg<span class="op">.</span><span class="fu">node</span>()<span class="op">.</span><span class="at">update</span> <span class="op">=</span> updateChart<span class="op">;</span></span>
|
<span id="cb4-1007"><a href></a> svg<span class="op">.</span><span class="fu">node</span>()<span class="op">.</span><span class="at">update</span> <span class="op">=</span> updateChart<span class="op">;</span></span>
|
||||||
<span id="cb4-1007"><a href></a> </span>
|
<span id="cb4-1008"><a href></a> </span>
|
||||||
<span id="cb4-1008"><a href></a> <span class="co">// Initial render</span></span>
|
<span id="cb4-1009"><a href></a> <span class="co">// Initial render</span></span>
|
||||||
<span id="cb4-1009"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
<span id="cb4-1010"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
||||||
<span id="cb4-1010"><a href></a> </span>
|
<span id="cb4-1011"><a href></a> </span>
|
||||||
<span id="cb4-1011"><a href></a> container<span class="op">.</span><span class="fu">node</span>()<span class="op">.</span><span class="fu">appendChild</span>(svg<span class="op">.</span><span class="fu">node</span>())<span class="op">;</span></span>
|
<span id="cb4-1012"><a href></a> container<span class="op">.</span><span class="fu">node</span>()<span class="op">.</span><span class="fu">appendChild</span>(svg<span class="op">.</span><span class="fu">node</span>())<span class="op">;</span></span>
|
||||||
<span id="cb4-1012"><a href></a> <span class="cf">return</span> container<span class="op">.</span><span class="fu">node</span>()<span class="op">;</span></span>
|
<span id="cb4-1013"><a href></a> <span class="cf">return</span> container<span class="op">.</span><span class="fu">node</span>()<span class="op">;</span></span>
|
||||||
<span id="cb4-1013"><a href></a>}</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
<span id="cb4-1014"><a href></a>}</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
||||||
<div class="cell-output cell-output-display">
|
<div class="cell-output cell-output-display">
|
||||||
<div>
|
<div>
|
||||||
<div id="ojs-cell-3-1" data-nodetype="declaration">
|
<div id="ojs-cell-3-1" data-nodetype="declaration">
|
||||||
@@ -27232,7 +27233,7 @@ Y_{t} = \mu + Y_{t-1} + \varepsilon_t \quad \text{with} \quad \varepsilon_t = \
|
|||||||
<div class="tab-content">
|
<div class="tab-content">
|
||||||
<div id="tabset-12-1">
|
<div id="tabset-12-1">
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
<div class="sourceCode cell-code hidden" id="cb5" data-startfrom="2658" data-source-offset="0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 2657;"><span id="cb5-2658"><a href></a>bsplineData <span class="op">=</span> <span class="fu">FileAttachment</span>(<span class="st">"assets/mcrps_learning/basis_functions.csv"</span>)<span class="op">.</span><span class="fu">csv</span>({ <span class="dt">typed</span><span class="op">:</span> <span class="kw">true</span> })</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
<div class="sourceCode cell-code hidden" id="cb5" data-startfrom="2659" data-source-offset="0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 2658;"><span id="cb5-2659"><a href></a>bsplineData <span class="op">=</span> <span class="fu">FileAttachment</span>(<span class="st">"assets/mcrps_learning/basis_functions.csv"</span>)<span class="op">.</span><span class="fu">csv</span>({ <span class="dt">typed</span><span class="op">:</span> <span class="kw">true</span> })</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
||||||
<div class="cell-output cell-output-display">
|
<div class="cell-output cell-output-display">
|
||||||
<div id="ojs-cell-4" data-nodetype="declaration">
|
<div id="ojs-cell-4" data-nodetype="declaration">
|
||||||
|
|
||||||
@@ -27240,194 +27241,194 @@ Y_{t} = \mu + Y_{t-1} + \varepsilon_t \quad \text{with} \quad \varepsilon_t = \
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="cell">
|
<div class="cell">
|
||||||
<div class="sourceCode cell-code hidden" id="cb6" data-startfrom="2662" data-source-offset="0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 2661;"><span id="cb6-2662"><a href></a><span class="co">// Defined above</span></span>
|
<div class="sourceCode cell-code hidden" id="cb6" data-startfrom="2663" data-source-offset="0"><pre class="sourceCode numberSource js number-lines code-with-copy"><code class="sourceCode javascript" style="counter-reset: source-line 2662;"><span id="cb6-2663"><a href></a><span class="co">// Defined above</span></span>
|
||||||
<span id="cb6-2663"><a href></a><span class="co">// function updateChartInner(g, x, y, linesGroup, color, line, data) {</span></span>
|
<span id="cb6-2664"><a href></a><span class="co">// function updateChartInner(g, x, y, linesGroup, color, line, data) {</span></span>
|
||||||
<span id="cb6-2664"><a href></a><span class="co">// // Update axes with transitions</span></span>
|
<span id="cb6-2665"><a href></a><span class="co">// // Update axes with transitions</span></span>
|
||||||
<span id="cb6-2665"><a href></a><span class="co">// x.domain([0, d3.max(data, d => d.x)]);</span></span>
|
<span id="cb6-2666"><a href></a><span class="co">// x.domain([0, d3.max(data, d => d.x)]);</span></span>
|
||||||
<span id="cb6-2666"><a href></a><span class="co">// g.select(".x-axis").transition().duration(1500).call(d3.axisBottom(x).ticks(10));</span></span>
|
<span id="cb6-2667"><a href></a><span class="co">// g.select(".x-axis").transition().duration(1500).call(d3.axisBottom(x).ticks(10));</span></span>
|
||||||
<span id="cb6-2667"><a href></a><span class="co">// y.domain([0, d3.max(data, d => d.y)]);</span></span>
|
<span id="cb6-2668"><a href></a><span class="co">// y.domain([0, d3.max(data, d => d.y)]);</span></span>
|
||||||
<span id="cb6-2668"><a href></a><span class="co">// g.select(".y-axis").transition().duration(1500).call(d3.axisLeft(y).ticks(5));</span></span>
|
<span id="cb6-2669"><a href></a><span class="co">// g.select(".y-axis").transition().duration(1500).call(d3.axisLeft(y).ticks(5));</span></span>
|
||||||
<span id="cb6-2669"><a href></a></span>
|
<span id="cb6-2670"><a href></a></span>
|
||||||
<span id="cb6-2670"><a href></a><span class="co">// // Group data by basis function</span></span>
|
<span id="cb6-2671"><a href></a><span class="co">// // Group data by basis function</span></span>
|
||||||
<span id="cb6-2671"><a href></a><span class="co">// const dataByFunction = Array.from(d3.group(data, d => d.b));</span></span>
|
<span id="cb6-2672"><a href></a><span class="co">// const dataByFunction = Array.from(d3.group(data, d => d.b));</span></span>
|
||||||
<span id="cb6-2672"><a href></a><span class="co">// const keyFn = d => d[0];</span></span>
|
<span id="cb6-2673"><a href></a><span class="co">// const keyFn = d => d[0];</span></span>
|
||||||
<span id="cb6-2673"><a href></a></span>
|
<span id="cb6-2674"><a href></a></span>
|
||||||
<span id="cb6-2674"><a href></a><span class="co">// // Update basis function lines</span></span>
|
<span id="cb6-2675"><a href></a><span class="co">// // Update basis function lines</span></span>
|
||||||
<span id="cb6-2675"><a href></a><span class="co">// const u = linesGroup.selectAll("path").data(dataByFunction, keyFn);</span></span>
|
<span id="cb6-2676"><a href></a><span class="co">// const u = linesGroup.selectAll("path").data(dataByFunction, keyFn);</span></span>
|
||||||
<span id="cb6-2676"><a href></a><span class="co">// u.join(</span></span>
|
<span id="cb6-2677"><a href></a><span class="co">// u.join(</span></span>
|
||||||
<span id="cb6-2677"><a href></a><span class="co">// enter => enter.append("path").attr("fill","none").attr("stroke-width",3)</span></span>
|
<span id="cb6-2678"><a href></a><span class="co">// enter => enter.append("path").attr("fill","none").attr("stroke-width",3)</span></span>
|
||||||
<span id="cb6-2678"><a href></a><span class="co">// .attr("stroke", (_, i) => color(i)).attr("d", d => line(d[1].map(pt => ({x: pt.x, y: 0}))))</span></span>
|
<span id="cb6-2679"><a href></a><span class="co">// .attr("stroke", (_, i) => color(i)).attr("d", d => line(d[1].map(pt => ({x: pt.x, y: 0}))))</span></span>
|
||||||
<span id="cb6-2679"><a href></a><span class="co">// .style("opacity",0),</span></span>
|
<span id="cb6-2680"><a href></a><span class="co">// .style("opacity",0),</span></span>
|
||||||
<span id="cb6-2680"><a href></a><span class="co">// update => update,</span></span>
|
<span id="cb6-2681"><a href></a><span class="co">// update => update,</span></span>
|
||||||
<span id="cb6-2681"><a href></a><span class="co">// exit => exit.transition().duration(1000).style("opacity",0).remove()</span></span>
|
<span id="cb6-2682"><a href></a><span class="co">// exit => exit.transition().duration(1000).style("opacity",0).remove()</span></span>
|
||||||
<span id="cb6-2682"><a href></a><span class="co">// )</span></span>
|
<span id="cb6-2683"><a href></a><span class="co">// )</span></span>
|
||||||
<span id="cb6-2683"><a href></a><span class="co">// .transition().duration(1000)</span></span>
|
<span id="cb6-2684"><a href></a><span class="co">// .transition().duration(1000)</span></span>
|
||||||
<span id="cb6-2684"><a href></a><span class="co">// .attr("d", d => line(d[1]))</span></span>
|
<span id="cb6-2685"><a href></a><span class="co">// .attr("d", d => line(d[1]))</span></span>
|
||||||
<span id="cb6-2685"><a href></a><span class="co">// .attr("stroke", (_, i) => color(i))</span></span>
|
<span id="cb6-2686"><a href></a><span class="co">// .attr("stroke", (_, i) => color(i))</span></span>
|
||||||
<span id="cb6-2686"><a href></a><span class="co">// .style("opacity",1);</span></span>
|
<span id="cb6-2687"><a href></a><span class="co">// .style("opacity",1);</span></span>
|
||||||
<span id="cb6-2687"><a href></a><span class="co">// }</span></span>
|
<span id="cb6-2688"><a href></a><span class="co">// }</span></span>
|
||||||
<span id="cb6-2688"><a href></a></span>
|
<span id="cb6-2689"><a href></a></span>
|
||||||
<span id="cb6-2689"><a href></a>chart0 <span class="op">=</span> {</span>
|
<span id="cb6-2690"><a href></a>chart0 <span class="op">=</span> {</span>
|
||||||
<span id="cb6-2690"><a href></a> <span class="co">// State variables for selected parameters</span></span>
|
<span id="cb6-2691"><a href></a> <span class="co">// State variables for selected parameters</span></span>
|
||||||
<span id="cb6-2691"><a href></a> <span class="kw">let</span> selectedMu <span class="op">=</span> <span class="fl">0.5</span><span class="op">;</span></span>
|
<span id="cb6-2692"><a href></a> <span class="kw">let</span> selectedMu <span class="op">=</span> <span class="fl">0.5</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2692"><a href></a> <span class="kw">let</span> selectedSig <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
<span id="cb6-2693"><a href></a> <span class="kw">let</span> selectedSig <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2693"><a href></a> <span class="kw">let</span> selectedNonc <span class="op">=</span> <span class="dv">0</span><span class="op">;</span></span>
|
<span id="cb6-2694"><a href></a> <span class="kw">let</span> selectedNonc <span class="op">=</span> <span class="dv">0</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2694"><a href></a> <span class="kw">let</span> selectedTailw <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
<span id="cb6-2695"><a href></a> <span class="kw">let</span> selectedTailw <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2695"><a href></a> <span class="kw">const</span> filteredData <span class="op">=</span> () <span class="kw">=></span> bsplineData<span class="op">.</span><span class="fu">filter</span>(d <span class="kw">=></span></span>
|
<span id="cb6-2696"><a href></a> <span class="kw">const</span> filteredData <span class="op">=</span> () <span class="kw">=></span> bsplineData<span class="op">.</span><span class="fu">filter</span>(d <span class="kw">=></span></span>
|
||||||
<span id="cb6-2696"><a href></a> <span class="bu">Math</span><span class="op">.</span><span class="fu">abs</span>(selectedMu <span class="op">-</span> d<span class="op">.</span><span class="at">mu</span>) <span class="op"><</span> <span class="fl">0.001</span> <span class="op">&&</span></span>
|
<span id="cb6-2697"><a href></a> <span class="bu">Math</span><span class="op">.</span><span class="fu">abs</span>(selectedMu <span class="op">-</span> d<span class="op">.</span><span class="at">mu</span>) <span class="op"><</span> <span class="fl">0.001</span> <span class="op">&&</span></span>
|
||||||
<span id="cb6-2697"><a href></a> d<span class="op">.</span><span class="at">sig</span> <span class="op">===</span> selectedSig <span class="op">&&</span></span>
|
<span id="cb6-2698"><a href></a> d<span class="op">.</span><span class="at">sig</span> <span class="op">===</span> selectedSig <span class="op">&&</span></span>
|
||||||
<span id="cb6-2698"><a href></a> d<span class="op">.</span><span class="at">nonc</span> <span class="op">===</span> selectedNonc <span class="op">&&</span></span>
|
<span id="cb6-2699"><a href></a> d<span class="op">.</span><span class="at">nonc</span> <span class="op">===</span> selectedNonc <span class="op">&&</span></span>
|
||||||
<span id="cb6-2699"><a href></a> d<span class="op">.</span><span class="at">tailw</span> <span class="op">===</span> selectedTailw</span>
|
<span id="cb6-2700"><a href></a> d<span class="op">.</span><span class="at">tailw</span> <span class="op">===</span> selectedTailw</span>
|
||||||
<span id="cb6-2700"><a href></a> )<span class="op">;</span></span>
|
<span id="cb6-2701"><a href></a> )<span class="op">;</span></span>
|
||||||
<span id="cb6-2701"><a href></a> <span class="kw">const</span> container <span class="op">=</span> d3<span class="op">.</span><span class="fu">create</span>(<span class="st">"div"</span>)</span>
|
<span id="cb6-2702"><a href></a> <span class="kw">const</span> container <span class="op">=</span> d3<span class="op">.</span><span class="fu">create</span>(<span class="st">"div"</span>)</span>
|
||||||
<span id="cb6-2702"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"max-width"</span><span class="op">,</span> <span class="st">"none"</span>)</span>
|
<span id="cb6-2703"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"max-width"</span><span class="op">,</span> <span class="st">"none"</span>)</span>
|
||||||
<span id="cb6-2703"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">;;</span></span>
|
<span id="cb6-2704"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">;;</span></span>
|
||||||
<span id="cb6-2704"><a href></a> <span class="kw">const</span> controlsContainer <span class="op">=</span> container<span class="op">.</span><span class="fu">append</span>(<span class="st">"div"</span>)</span>
|
<span id="cb6-2705"><a href></a> <span class="kw">const</span> controlsContainer <span class="op">=</span> container<span class="op">.</span><span class="fu">append</span>(<span class="st">"div"</span>)</span>
|
||||||
<span id="cb6-2705"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"display"</span><span class="op">,</span> <span class="st">"flex"</span>)</span>
|
<span id="cb6-2706"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"display"</span><span class="op">,</span> <span class="st">"flex"</span>)</span>
|
||||||
<span id="cb6-2706"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"gap"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
<span id="cb6-2707"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"gap"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2707"><a href></a> <span class="co">// slider controls</span></span>
|
<span id="cb6-2708"><a href></a> <span class="co">// slider controls</span></span>
|
||||||
<span id="cb6-2708"><a href></a> <span class="kw">const</span> sliders <span class="op">=</span> [</span>
|
<span id="cb6-2709"><a href></a> <span class="kw">const</span> sliders <span class="op">=</span> [</span>
|
||||||
<span id="cb6-2709"><a href></a> { <span class="dt">label</span><span class="op">:</span> <span class="st">'Mu'</span><span class="op">,</span> <span class="kw">get</span><span class="op">:</span> () <span class="kw">=></span> selectedMu<span class="op">,</span> <span class="kw">set</span><span class="op">:</span> v <span class="kw">=></span> selectedMu <span class="op">=</span> v<span class="op">,</span> <span class="dt">min</span><span class="op">:</span> <span class="fl">0.1</span><span class="op">,</span> <span class="dt">max</span><span class="op">:</span> <span class="fl">0.9</span><span class="op">,</span> <span class="dt">step</span><span class="op">:</span> <span class="fl">0.2</span> }<span class="op">,</span></span>
|
<span id="cb6-2710"><a href></a> { <span class="dt">label</span><span class="op">:</span> <span class="st">'Mu'</span><span class="op">,</span> <span class="kw">get</span><span class="op">:</span> () <span class="kw">=></span> selectedMu<span class="op">,</span> <span class="kw">set</span><span class="op">:</span> v <span class="kw">=></span> selectedMu <span class="op">=</span> v<span class="op">,</span> <span class="dt">min</span><span class="op">:</span> <span class="fl">0.1</span><span class="op">,</span> <span class="dt">max</span><span class="op">:</span> <span class="fl">0.9</span><span class="op">,</span> <span class="dt">step</span><span class="op">:</span> <span class="fl">0.2</span> }<span class="op">,</span></span>
|
||||||
<span id="cb6-2710"><a href></a> { <span class="dt">label</span><span class="op">:</span> <span class="st">'Sigma'</span><span class="op">,</span> <span class="kw">get</span><span class="op">:</span> () <span class="kw">=></span> <span class="bu">Math</span><span class="op">.</span><span class="fu">log2</span>(selectedSig)<span class="op">,</span> <span class="kw">set</span><span class="op">:</span> v <span class="kw">=></span> selectedSig <span class="op">=</span> <span class="dv">2</span> <span class="op">**</span> v<span class="op">,</span> <span class="dt">min</span><span class="op">:</span> <span class="op">-</span><span class="dv">2</span><span class="op">,</span> <span class="dt">max</span><span class="op">:</span> <span class="dv">2</span><span class="op">,</span> <span class="dt">step</span><span class="op">:</span> <span class="dv">1</span> }<span class="op">,</span></span>
|
<span id="cb6-2711"><a href></a> { <span class="dt">label</span><span class="op">:</span> <span class="st">'Sigma'</span><span class="op">,</span> <span class="kw">get</span><span class="op">:</span> () <span class="kw">=></span> <span class="bu">Math</span><span class="op">.</span><span class="fu">log2</span>(selectedSig)<span class="op">,</span> <span class="kw">set</span><span class="op">:</span> v <span class="kw">=></span> selectedSig <span class="op">=</span> <span class="dv">2</span> <span class="op">**</span> v<span class="op">,</span> <span class="dt">min</span><span class="op">:</span> <span class="op">-</span><span class="dv">2</span><span class="op">,</span> <span class="dt">max</span><span class="op">:</span> <span class="dv">2</span><span class="op">,</span> <span class="dt">step</span><span class="op">:</span> <span class="dv">1</span> }<span class="op">,</span></span>
|
||||||
<span id="cb6-2711"><a href></a> { <span class="dt">label</span><span class="op">:</span> <span class="st">'Noncentrality'</span><span class="op">,</span> <span class="kw">get</span><span class="op">:</span> () <span class="kw">=></span> selectedNonc<span class="op">,</span> <span class="kw">set</span><span class="op">:</span> v <span class="kw">=></span> selectedNonc <span class="op">=</span> v<span class="op">,</span> <span class="dt">min</span><span class="op">:</span> <span class="op">-</span><span class="dv">4</span><span class="op">,</span> <span class="dt">max</span><span class="op">:</span> <span class="dv">4</span><span class="op">,</span> <span class="dt">step</span><span class="op">:</span> <span class="dv">2</span> }<span class="op">,</span></span>
|
<span id="cb6-2712"><a href></a> { <span class="dt">label</span><span class="op">:</span> <span class="st">'Noncentrality'</span><span class="op">,</span> <span class="kw">get</span><span class="op">:</span> () <span class="kw">=></span> selectedNonc<span class="op">,</span> <span class="kw">set</span><span class="op">:</span> v <span class="kw">=></span> selectedNonc <span class="op">=</span> v<span class="op">,</span> <span class="dt">min</span><span class="op">:</span> <span class="op">-</span><span class="dv">4</span><span class="op">,</span> <span class="dt">max</span><span class="op">:</span> <span class="dv">4</span><span class="op">,</span> <span class="dt">step</span><span class="op">:</span> <span class="dv">2</span> }<span class="op">,</span></span>
|
||||||
<span id="cb6-2712"><a href></a> { <span class="dt">label</span><span class="op">:</span> <span class="st">'Tailweight'</span><span class="op">,</span> <span class="kw">get</span><span class="op">:</span> () <span class="kw">=></span> <span class="bu">Math</span><span class="op">.</span><span class="fu">log2</span>(selectedTailw)<span class="op">,</span> <span class="kw">set</span><span class="op">:</span> v <span class="kw">=></span> selectedTailw <span class="op">=</span> <span class="dv">2</span> <span class="op">**</span> v<span class="op">,</span> <span class="dt">min</span><span class="op">:</span> <span class="op">-</span><span class="dv">2</span><span class="op">,</span> <span class="dt">max</span><span class="op">:</span> <span class="dv">2</span><span class="op">,</span> <span class="dt">step</span><span class="op">:</span> <span class="dv">1</span> }</span>
|
<span id="cb6-2713"><a href></a> { <span class="dt">label</span><span class="op">:</span> <span class="st">'Tailweight'</span><span class="op">,</span> <span class="kw">get</span><span class="op">:</span> () <span class="kw">=></span> <span class="bu">Math</span><span class="op">.</span><span class="fu">log2</span>(selectedTailw)<span class="op">,</span> <span class="kw">set</span><span class="op">:</span> v <span class="kw">=></span> selectedTailw <span class="op">=</span> <span class="dv">2</span> <span class="op">**</span> v<span class="op">,</span> <span class="dt">min</span><span class="op">:</span> <span class="op">-</span><span class="dv">2</span><span class="op">,</span> <span class="dt">max</span><span class="op">:</span> <span class="dv">2</span><span class="op">,</span> <span class="dt">step</span><span class="op">:</span> <span class="dv">1</span> }</span>
|
||||||
<span id="cb6-2713"><a href></a> ]<span class="op">;</span></span>
|
<span id="cb6-2714"><a href></a> ]<span class="op">;</span></span>
|
||||||
<span id="cb6-2714"><a href></a> <span class="co">// Build slider controls with D3 data join</span></span>
|
<span id="cb6-2715"><a href></a> <span class="co">// Build slider controls with D3 data join</span></span>
|
||||||
<span id="cb6-2715"><a href></a> <span class="kw">const</span> sliderCont <span class="op">=</span> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">'div'</span>)<span class="op">.</span><span class="fu">data</span>(sliders)<span class="op">.</span><span class="fu">join</span>(<span class="st">'div'</span>)</span>
|
<span id="cb6-2716"><a href></a> <span class="kw">const</span> sliderCont <span class="op">=</span> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">'div'</span>)<span class="op">.</span><span class="fu">data</span>(sliders)<span class="op">.</span><span class="fu">join</span>(<span class="st">'div'</span>)</span>
|
||||||
<span id="cb6-2716"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'display'</span><span class="op">,</span><span class="st">'flex'</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">'align-items'</span><span class="op">,</span><span class="st">'center'</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">'gap'</span><span class="op">,</span><span class="st">'10px'</span>)</span>
|
<span id="cb6-2717"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'display'</span><span class="op">,</span><span class="st">'flex'</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">'align-items'</span><span class="op">,</span><span class="st">'center'</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">'gap'</span><span class="op">,</span><span class="st">'10px'</span>)</span>
|
||||||
<span id="cb6-2717"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'flex'</span><span class="op">,</span><span class="st">'1'</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">'min-width'</span><span class="op">,</span><span class="st">'0px'</span>)<span class="op">;</span></span>
|
<span id="cb6-2718"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'flex'</span><span class="op">,</span><span class="st">'1'</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">'min-width'</span><span class="op">,</span><span class="st">'0px'</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2718"><a href></a> sliderCont<span class="op">.</span><span class="fu">append</span>(<span class="st">'label'</span>)<span class="op">.</span><span class="fu">text</span>(d <span class="kw">=></span> d<span class="op">.</span><span class="at">label</span> <span class="op">+</span> <span class="st">':'</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span><span class="st">'20px'</span>)<span class="op">;</span></span>
|
<span id="cb6-2719"><a href></a> sliderCont<span class="op">.</span><span class="fu">append</span>(<span class="st">'label'</span>)<span class="op">.</span><span class="fu">text</span>(d <span class="kw">=></span> d<span class="op">.</span><span class="at">label</span> <span class="op">+</span> <span class="st">':'</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span><span class="st">'20px'</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2719"><a href></a> sliderCont<span class="op">.</span><span class="fu">append</span>(<span class="st">'input'</span>)</span>
|
<span id="cb6-2720"><a href></a> sliderCont<span class="op">.</span><span class="fu">append</span>(<span class="st">'input'</span>)</span>
|
||||||
<span id="cb6-2720"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'type'</span><span class="op">,</span><span class="st">'range'</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">'min'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">min</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">'max'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">max</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">'step'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">step</span>)</span>
|
<span id="cb6-2721"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">'type'</span><span class="op">,</span><span class="st">'range'</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">'min'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">min</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">'max'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">max</span>)<span class="op">.</span><span class="fu">attr</span>(<span class="st">'step'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="at">step</span>)</span>
|
||||||
<span id="cb6-2721"><a href></a> <span class="op">.</span><span class="fu">property</span>(<span class="st">'value'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="fu">get</span>())</span>
|
<span id="cb6-2722"><a href></a> <span class="op">.</span><span class="fu">property</span>(<span class="st">'value'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="fu">get</span>())</span>
|
||||||
<span id="cb6-2722"><a href></a> <span class="op">.</span><span class="fu">on</span>(<span class="st">'input'</span><span class="op">,</span> <span class="kw">function</span>(<span class="bu">event</span><span class="op">,</span> d) {</span>
|
<span id="cb6-2723"><a href></a> <span class="op">.</span><span class="fu">on</span>(<span class="st">'input'</span><span class="op">,</span> <span class="kw">function</span>(<span class="bu">event</span><span class="op">,</span> d) {</span>
|
||||||
<span id="cb6-2723"><a href></a> <span class="kw">const</span> val <span class="op">=</span> <span class="op">+</span><span class="kw">this</span><span class="op">.</span><span class="at">value</span><span class="op">;</span> d<span class="op">.</span><span class="fu">set</span>(val)<span class="op">;</span></span>
|
<span id="cb6-2724"><a href></a> <span class="kw">const</span> val <span class="op">=</span> <span class="op">+</span><span class="kw">this</span><span class="op">.</span><span class="at">value</span><span class="op">;</span> d<span class="op">.</span><span class="fu">set</span>(val)<span class="op">;</span></span>
|
||||||
<span id="cb6-2724"><a href></a> d3<span class="op">.</span><span class="fu">select</span>(<span class="kw">this</span><span class="op">.</span><span class="at">parentNode</span>)<span class="op">.</span><span class="fu">select</span>(<span class="st">'span'</span>)<span class="op">.</span><span class="fu">text</span>(d<span class="op">.</span><span class="at">label</span><span class="op">.</span><span class="fu">match</span>(<span class="ss">/Sigma</span><span class="sc">|</span><span class="ss">Tailweight/</span>) <span class="op">?</span> <span class="dv">2</span><span class="op">**</span>val <span class="op">:</span> val)<span class="op">;</span></span>
|
<span id="cb6-2725"><a href></a> d3<span class="op">.</span><span class="fu">select</span>(<span class="kw">this</span><span class="op">.</span><span class="at">parentNode</span>)<span class="op">.</span><span class="fu">select</span>(<span class="st">'span'</span>)<span class="op">.</span><span class="fu">text</span>(d<span class="op">.</span><span class="at">label</span><span class="op">.</span><span class="fu">match</span>(<span class="ss">/Sigma</span><span class="sc">|</span><span class="ss">Tailweight/</span>) <span class="op">?</span> <span class="dv">2</span><span class="op">**</span>val <span class="op">:</span> val)<span class="op">;</span></span>
|
||||||
<span id="cb6-2725"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
<span id="cb6-2726"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
||||||
<span id="cb6-2726"><a href></a> })</span>
|
<span id="cb6-2727"><a href></a> })</span>
|
||||||
<span id="cb6-2727"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'width'</span><span class="op">,</span> <span class="st">'100%'</span>)<span class="op">;</span></span>
|
<span id="cb6-2728"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'width'</span><span class="op">,</span> <span class="st">'100%'</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2728"><a href></a> sliderCont<span class="op">.</span><span class="fu">append</span>(<span class="st">'span'</span>)<span class="op">.</span><span class="fu">text</span>(d <span class="kw">=></span> (d<span class="op">.</span><span class="at">label</span><span class="op">.</span><span class="fu">match</span>(<span class="ss">/Sigma</span><span class="sc">|</span><span class="ss">Tailweight/</span>) <span class="op">?</span> d<span class="op">.</span><span class="fu">get</span>() <span class="op">:</span> d<span class="op">.</span><span class="fu">get</span>()))</span>
|
<span id="cb6-2729"><a href></a> sliderCont<span class="op">.</span><span class="fu">append</span>(<span class="st">'span'</span>)<span class="op">.</span><span class="fu">text</span>(d <span class="kw">=></span> (d<span class="op">.</span><span class="at">label</span><span class="op">.</span><span class="fu">match</span>(<span class="ss">/Sigma</span><span class="sc">|</span><span class="ss">Tailweight/</span>) <span class="op">?</span> d<span class="op">.</span><span class="fu">get</span>() <span class="op">:</span> d<span class="op">.</span><span class="fu">get</span>()))</span>
|
||||||
<span id="cb6-2729"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span><span class="st">'20px'</span>)<span class="op">;</span></span>
|
<span id="cb6-2730"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span><span class="st">'20px'</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2730"><a href></a> </span>
|
<span id="cb6-2731"><a href></a> </span>
|
||||||
<span id="cb6-2731"><a href></a> <span class="co">// Add Reset button to clear all sliders to their defaults</span></span>
|
<span id="cb6-2732"><a href></a> <span class="co">// Add Reset button to clear all sliders to their defaults</span></span>
|
||||||
<span id="cb6-2732"><a href></a> controlsContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'button'</span>)</span>
|
<span id="cb6-2733"><a href></a> controlsContainer<span class="op">.</span><span class="fu">append</span>(<span class="st">'button'</span>)</span>
|
||||||
<span id="cb6-2733"><a href></a> <span class="op">.</span><span class="fu">text</span>(<span class="st">'Reset'</span>)</span>
|
<span id="cb6-2734"><a href></a> <span class="op">.</span><span class="fu">text</span>(<span class="st">'Reset'</span>)</span>
|
||||||
<span id="cb6-2734"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span> <span class="st">'20px'</span>)</span>
|
<span id="cb6-2735"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'font-size'</span><span class="op">,</span> <span class="st">'20px'</span>)</span>
|
||||||
<span id="cb6-2735"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'align-self'</span><span class="op">,</span> <span class="st">'center'</span>)</span>
|
<span id="cb6-2736"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'align-self'</span><span class="op">,</span> <span class="st">'center'</span>)</span>
|
||||||
<span id="cb6-2736"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'margin-left'</span><span class="op">,</span> <span class="st">'auto'</span>)</span>
|
<span id="cb6-2737"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">'margin-left'</span><span class="op">,</span> <span class="st">'auto'</span>)</span>
|
||||||
<span id="cb6-2737"><a href></a> <span class="op">.</span><span class="fu">on</span>(<span class="st">'click'</span><span class="op">,</span> () <span class="kw">=></span> {</span>
|
<span id="cb6-2738"><a href></a> <span class="op">.</span><span class="fu">on</span>(<span class="st">'click'</span><span class="op">,</span> () <span class="kw">=></span> {</span>
|
||||||
<span id="cb6-2738"><a href></a> <span class="co">// reset state vars</span></span>
|
<span id="cb6-2739"><a href></a> <span class="co">// reset state vars</span></span>
|
||||||
<span id="cb6-2739"><a href></a> selectedMu <span class="op">=</span> <span class="fl">0.5</span><span class="op">;</span></span>
|
<span id="cb6-2740"><a href></a> selectedMu <span class="op">=</span> <span class="fl">0.5</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2740"><a href></a> selectedSig <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
<span id="cb6-2741"><a href></a> selectedSig <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2741"><a href></a> selectedNonc <span class="op">=</span> <span class="dv">0</span><span class="op">;</span></span>
|
<span id="cb6-2742"><a href></a> selectedNonc <span class="op">=</span> <span class="dv">0</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2742"><a href></a> selectedTailw <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
<span id="cb6-2743"><a href></a> selectedTailw <span class="op">=</span> <span class="dv">1</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2743"><a href></a> <span class="co">// update input positions</span></span>
|
<span id="cb6-2744"><a href></a> <span class="co">// update input positions</span></span>
|
||||||
<span id="cb6-2744"><a href></a> sliderCont<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">'input'</span>)<span class="op">.</span><span class="fu">property</span>(<span class="st">'value'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="fu">get</span>())<span class="op">;</span></span>
|
<span id="cb6-2745"><a href></a> sliderCont<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">'input'</span>)<span class="op">.</span><span class="fu">property</span>(<span class="st">'value'</span><span class="op">,</span> d <span class="kw">=></span> d<span class="op">.</span><span class="fu">get</span>())<span class="op">;</span></span>
|
||||||
<span id="cb6-2745"><a href></a> <span class="co">// update displayed labels</span></span>
|
<span id="cb6-2746"><a href></a> <span class="co">// update displayed labels</span></span>
|
||||||
<span id="cb6-2746"><a href></a> sliderCont<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">'span'</span>)</span>
|
<span id="cb6-2747"><a href></a> sliderCont<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">'span'</span>)</span>
|
||||||
<span id="cb6-2747"><a href></a> <span class="op">.</span><span class="fu">text</span>(d <span class="kw">=></span> d<span class="op">.</span><span class="at">label</span><span class="op">.</span><span class="fu">match</span>(<span class="ss">/Sigma</span><span class="sc">|</span><span class="ss">Tailweight/</span>) <span class="op">?</span> (<span class="dv">2</span><span class="op">**</span>d<span class="op">.</span><span class="fu">get</span>()) <span class="op">:</span> d<span class="op">.</span><span class="fu">get</span>())<span class="op">;</span></span>
|
<span id="cb6-2748"><a href></a> <span class="op">.</span><span class="fu">text</span>(d <span class="kw">=></span> d<span class="op">.</span><span class="at">label</span><span class="op">.</span><span class="fu">match</span>(<span class="ss">/Sigma</span><span class="sc">|</span><span class="ss">Tailweight/</span>) <span class="op">?</span> (<span class="dv">2</span><span class="op">**</span>d<span class="op">.</span><span class="fu">get</span>()) <span class="op">:</span> d<span class="op">.</span><span class="fu">get</span>())<span class="op">;</span></span>
|
||||||
<span id="cb6-2748"><a href></a> <span class="co">// redraw chart</span></span>
|
<span id="cb6-2749"><a href></a> <span class="co">// redraw chart</span></span>
|
||||||
<span id="cb6-2749"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
<span id="cb6-2750"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
||||||
<span id="cb6-2750"><a href></a> })<span class="op">;</span></span>
|
<span id="cb6-2751"><a href></a> })<span class="op">;</span></span>
|
||||||
<span id="cb6-2751"><a href></a></span>
|
<span id="cb6-2752"><a href></a></span>
|
||||||
<span id="cb6-2752"><a href></a> <span class="co">// Build SVG</span></span>
|
<span id="cb6-2753"><a href></a> <span class="co">// Build SVG</span></span>
|
||||||
<span id="cb6-2753"><a href></a> <span class="kw">const</span> width <span class="op">=</span> <span class="dv">1200</span><span class="op">;</span></span>
|
<span id="cb6-2754"><a href></a> <span class="kw">const</span> width <span class="op">=</span> <span class="dv">1200</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2754"><a href></a> <span class="kw">const</span> height <span class="op">=</span> <span class="dv">450</span><span class="op">;</span></span>
|
<span id="cb6-2755"><a href></a> <span class="kw">const</span> height <span class="op">=</span> <span class="dv">450</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2755"><a href></a> <span class="kw">const</span> margin <span class="op">=</span> {<span class="dt">top</span><span class="op">:</span> <span class="dv">40</span><span class="op">,</span> <span class="dt">right</span><span class="op">:</span> <span class="dv">20</span><span class="op">,</span> <span class="dt">bottom</span><span class="op">:</span> <span class="dv">40</span><span class="op">,</span> <span class="dt">left</span><span class="op">:</span> <span class="dv">40</span>}<span class="op">;</span></span>
|
<span id="cb6-2756"><a href></a> <span class="kw">const</span> margin <span class="op">=</span> {<span class="dt">top</span><span class="op">:</span> <span class="dv">40</span><span class="op">,</span> <span class="dt">right</span><span class="op">:</span> <span class="dv">20</span><span class="op">,</span> <span class="dt">bottom</span><span class="op">:</span> <span class="dv">40</span><span class="op">,</span> <span class="dt">left</span><span class="op">:</span> <span class="dv">40</span>}<span class="op">;</span></span>
|
||||||
<span id="cb6-2756"><a href></a> <span class="kw">const</span> innerWidth <span class="op">=</span> width <span class="op">-</span> margin<span class="op">.</span><span class="at">left</span> <span class="op">-</span> margin<span class="op">.</span><span class="at">right</span><span class="op">;</span></span>
|
<span id="cb6-2757"><a href></a> <span class="kw">const</span> innerWidth <span class="op">=</span> width <span class="op">-</span> margin<span class="op">.</span><span class="at">left</span> <span class="op">-</span> margin<span class="op">.</span><span class="at">right</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2757"><a href></a> <span class="kw">const</span> innerHeight <span class="op">=</span> height <span class="op">-</span> margin<span class="op">.</span><span class="at">top</span> <span class="op">-</span> margin<span class="op">.</span><span class="at">bottom</span><span class="op">;</span></span>
|
<span id="cb6-2758"><a href></a> <span class="kw">const</span> innerHeight <span class="op">=</span> height <span class="op">-</span> margin<span class="op">.</span><span class="at">top</span> <span class="op">-</span> margin<span class="op">.</span><span class="at">bottom</span><span class="op">;</span></span>
|
||||||
<span id="cb6-2758"><a href></a></span>
|
<span id="cb6-2759"><a href></a></span>
|
||||||
<span id="cb6-2759"><a href></a> <span class="co">// Set controls container width to match SVG plot width</span></span>
|
<span id="cb6-2760"><a href></a> <span class="co">// Set controls container width to match SVG plot width</span></span>
|
||||||
<span id="cb6-2760"><a href></a> controlsContainer<span class="op">.</span><span class="fu">style</span>(<span class="st">"max-width"</span><span class="op">,</span> <span class="st">"none"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">;</span></span>
|
<span id="cb6-2761"><a href></a> controlsContainer<span class="op">.</span><span class="fu">style</span>(<span class="st">"max-width"</span><span class="op">,</span> <span class="st">"none"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2761"><a href></a> <span class="co">// Distribute each control evenly and make sliders full-width</span></span>
|
<span id="cb6-2762"><a href></a> <span class="co">// Distribute each control evenly and make sliders full-width</span></span>
|
||||||
<span id="cb6-2762"><a href></a> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"div"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"flex"</span><span class="op">,</span> <span class="st">"1"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"min-width"</span><span class="op">,</span> <span class="st">"0px"</span>)<span class="op">;</span></span>
|
<span id="cb6-2763"><a href></a> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"div"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"flex"</span><span class="op">,</span> <span class="st">"1"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"min-width"</span><span class="op">,</span> <span class="st">"0px"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2763"><a href></a> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"input"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"box-sizing"</span><span class="op">,</span> <span class="st">"border-box"</span>)<span class="op">;</span></span>
|
<span id="cb6-2764"><a href></a> controlsContainer<span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"input"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)<span class="op">.</span><span class="fu">style</span>(<span class="st">"box-sizing"</span><span class="op">,</span> <span class="st">"border-box"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2764"><a href></a> </span>
|
<span id="cb6-2765"><a href></a> </span>
|
||||||
<span id="cb6-2765"><a href></a> <span class="co">// Create scales</span></span>
|
<span id="cb6-2766"><a href></a> <span class="co">// Create scales</span></span>
|
||||||
<span id="cb6-2766"><a href></a> <span class="kw">const</span> x <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleLinear</span>()</span>
|
<span id="cb6-2767"><a href></a> <span class="kw">const</span> x <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleLinear</span>()</span>
|
||||||
<span id="cb6-2767"><a href></a> <span class="op">.</span><span class="fu">domain</span>([<span class="dv">0</span><span class="op">,</span> <span class="dv">1</span>])</span>
|
<span id="cb6-2768"><a href></a> <span class="op">.</span><span class="fu">domain</span>([<span class="dv">0</span><span class="op">,</span> <span class="dv">1</span>])</span>
|
||||||
<span id="cb6-2768"><a href></a> <span class="op">.</span><span class="fu">range</span>([<span class="dv">0</span><span class="op">,</span> innerWidth])<span class="op">;</span></span>
|
<span id="cb6-2769"><a href></a> <span class="op">.</span><span class="fu">range</span>([<span class="dv">0</span><span class="op">,</span> innerWidth])<span class="op">;</span></span>
|
||||||
<span id="cb6-2769"><a href></a> </span>
|
<span id="cb6-2770"><a href></a> </span>
|
||||||
<span id="cb6-2770"><a href></a> <span class="kw">const</span> y <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleLinear</span>()</span>
|
<span id="cb6-2771"><a href></a> <span class="kw">const</span> y <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleLinear</span>()</span>
|
||||||
<span id="cb6-2771"><a href></a> <span class="op">.</span><span class="fu">domain</span>([<span class="dv">0</span><span class="op">,</span> <span class="dv">1</span>])</span>
|
<span id="cb6-2772"><a href></a> <span class="op">.</span><span class="fu">domain</span>([<span class="dv">0</span><span class="op">,</span> <span class="dv">1</span>])</span>
|
||||||
<span id="cb6-2772"><a href></a> <span class="op">.</span><span class="fu">range</span>([innerHeight<span class="op">,</span> <span class="dv">0</span>])<span class="op">;</span></span>
|
<span id="cb6-2773"><a href></a> <span class="op">.</span><span class="fu">range</span>([innerHeight<span class="op">,</span> <span class="dv">0</span>])<span class="op">;</span></span>
|
||||||
<span id="cb6-2773"><a href></a> </span>
|
<span id="cb6-2774"><a href></a> </span>
|
||||||
<span id="cb6-2774"><a href></a> <span class="co">// Create a color scale for the basis functions</span></span>
|
<span id="cb6-2775"><a href></a> <span class="co">// Create a color scale for the basis functions</span></span>
|
||||||
<span id="cb6-2775"><a href></a> <span class="kw">const</span> color <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleOrdinal</span>([<span class="st">"#9B26B0FF"</span><span class="op">,</span> <span class="st">"#3F51B4FF"</span><span class="op">,</span> <span class="st">"#02A9F3FF"</span><span class="op">,</span> <span class="st">"#009687FF"</span><span class="op">,</span> <span class="st">"#8BC34AFF"</span><span class="op">,</span> <span class="st">"#FFEB3AFF"</span><span class="op">,</span> <span class="st">"#FF9800FF"</span><span class="op">,</span> <span class="st">"#795447FF"</span>])<span class="op">;</span></span>
|
<span id="cb6-2776"><a href></a> <span class="kw">const</span> color <span class="op">=</span> d3<span class="op">.</span><span class="fu">scaleOrdinal</span>([<span class="st">"#9B26B0FF"</span><span class="op">,</span> <span class="st">"#3F51B4FF"</span><span class="op">,</span> <span class="st">"#02A9F3FF"</span><span class="op">,</span> <span class="st">"#009687FF"</span><span class="op">,</span> <span class="st">"#8BC34AFF"</span><span class="op">,</span> <span class="st">"#FFEB3AFF"</span><span class="op">,</span> <span class="st">"#FF9800FF"</span><span class="op">,</span> <span class="st">"#795447FF"</span>])<span class="op">;</span></span>
|
||||||
<span id="cb6-2776"><a href></a> </span>
|
<span id="cb6-2777"><a href></a> </span>
|
||||||
<span id="cb6-2777"><a href></a> <span class="co">// Create SVG</span></span>
|
<span id="cb6-2778"><a href></a> <span class="co">// Create SVG</span></span>
|
||||||
<span id="cb6-2778"><a href></a> <span class="kw">const</span> svg <span class="op">=</span> d3<span class="op">.</span><span class="fu">create</span>(<span class="st">"svg"</span>)</span>
|
<span id="cb6-2779"><a href></a> <span class="kw">const</span> svg <span class="op">=</span> d3<span class="op">.</span><span class="fu">create</span>(<span class="st">"svg"</span>)</span>
|
||||||
<span id="cb6-2779"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)</span>
|
<span id="cb6-2780"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"width"</span><span class="op">,</span> <span class="st">"100%"</span>)</span>
|
||||||
<span id="cb6-2780"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"height"</span><span class="op">,</span> <span class="st">"auto"</span>)</span>
|
<span id="cb6-2781"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"height"</span><span class="op">,</span> <span class="st">"auto"</span>)</span>
|
||||||
<span id="cb6-2781"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"viewBox"</span><span class="op">,</span> [<span class="dv">0</span><span class="op">,</span> <span class="dv">0</span><span class="op">,</span> width<span class="op">,</span> height])</span>
|
<span id="cb6-2782"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"viewBox"</span><span class="op">,</span> [<span class="dv">0</span><span class="op">,</span> <span class="dv">0</span><span class="op">,</span> width<span class="op">,</span> height])</span>
|
||||||
<span id="cb6-2782"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"preserveAspectRatio"</span><span class="op">,</span> <span class="st">"xMidYMid meet"</span>)</span>
|
<span id="cb6-2783"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"preserveAspectRatio"</span><span class="op">,</span> <span class="st">"xMidYMid meet"</span>)</span>
|
||||||
<span id="cb6-2783"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"style"</span><span class="op">,</span> <span class="st">"max-width: 100%; height: auto;"</span>)<span class="op">;</span></span>
|
<span id="cb6-2784"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"style"</span><span class="op">,</span> <span class="st">"max-width: 100%; height: auto;"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2784"><a href></a> </span>
|
<span id="cb6-2785"><a href></a> </span>
|
||||||
<span id="cb6-2785"><a href></a> <span class="co">// Create the chart group</span></span>
|
<span id="cb6-2786"><a href></a> <span class="co">// Create the chart group</span></span>
|
||||||
<span id="cb6-2786"><a href></a> <span class="kw">const</span> g <span class="op">=</span> svg<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb6-2787"><a href></a> <span class="kw">const</span> g <span class="op">=</span> svg<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb6-2787"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"transform"</span><span class="op">,</span> <span class="vs">`translate(</span><span class="sc">${</span>margin<span class="op">.</span><span class="at">left</span><span class="sc">}</span><span class="vs">,</span><span class="sc">${</span>margin<span class="op">.</span><span class="at">top</span><span class="sc">}</span><span class="vs">)`</span>)<span class="op">;</span></span>
|
<span id="cb6-2788"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"transform"</span><span class="op">,</span> <span class="vs">`translate(</span><span class="sc">${</span>margin<span class="op">.</span><span class="at">left</span><span class="sc">}</span><span class="vs">,</span><span class="sc">${</span>margin<span class="op">.</span><span class="at">top</span><span class="sc">}</span><span class="vs">)`</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2788"><a href></a> </span>
|
<span id="cb6-2789"><a href></a> </span>
|
||||||
<span id="cb6-2789"><a href></a> <span class="co">// Add axes</span></span>
|
<span id="cb6-2790"><a href></a> <span class="co">// Add axes</span></span>
|
||||||
<span id="cb6-2790"><a href></a> <span class="kw">const</span> xAxis <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb6-2791"><a href></a> <span class="kw">const</span> xAxis <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb6-2791"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"transform"</span><span class="op">,</span> <span class="vs">`translate(0,</span><span class="sc">${</span>innerHeight<span class="sc">}</span><span class="vs">)`</span>)</span>
|
<span id="cb6-2792"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"transform"</span><span class="op">,</span> <span class="vs">`translate(0,</span><span class="sc">${</span>innerHeight<span class="sc">}</span><span class="vs">)`</span>)</span>
|
||||||
<span id="cb6-2792"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"x-axis"</span>)</span>
|
<span id="cb6-2793"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"x-axis"</span>)</span>
|
||||||
<span id="cb6-2793"><a href></a> <span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisBottom</span>(x)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">10</span>))</span>
|
<span id="cb6-2794"><a href></a> <span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisBottom</span>(x)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">10</span>))</span>
|
||||||
<span id="cb6-2794"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"font-size"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
<span id="cb6-2795"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"font-size"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2795"><a href></a> </span>
|
<span id="cb6-2796"><a href></a> </span>
|
||||||
<span id="cb6-2796"><a href></a> <span class="kw">const</span> yAxis <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb6-2797"><a href></a> <span class="kw">const</span> yAxis <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb6-2797"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"y-axis"</span>)</span>
|
<span id="cb6-2798"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"y-axis"</span>)</span>
|
||||||
<span id="cb6-2798"><a href></a> <span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisLeft</span>(y)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))</span>
|
<span id="cb6-2799"><a href></a> <span class="op">.</span><span class="fu">call</span>(d3<span class="op">.</span><span class="fu">axisLeft</span>(y)<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))</span>
|
||||||
<span id="cb6-2799"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"font-size"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
<span id="cb6-2800"><a href></a> <span class="op">.</span><span class="fu">style</span>(<span class="st">"font-size"</span><span class="op">,</span> <span class="st">"20px"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2800"><a href></a> </span>
|
<span id="cb6-2801"><a href></a> </span>
|
||||||
<span id="cb6-2801"><a href></a> <span class="co">// Add a horizontal line at y = 0</span></span>
|
<span id="cb6-2802"><a href></a> <span class="co">// Add a horizontal line at y = 0</span></span>
|
||||||
<span id="cb6-2802"><a href></a> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"line"</span>)</span>
|
<span id="cb6-2803"><a href></a> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"line"</span>)</span>
|
||||||
<span id="cb6-2803"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x1"</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
<span id="cb6-2804"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x1"</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
||||||
<span id="cb6-2804"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x2"</span><span class="op">,</span> innerWidth)</span>
|
<span id="cb6-2805"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x2"</span><span class="op">,</span> innerWidth)</span>
|
||||||
<span id="cb6-2805"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y1"</span><span class="op">,</span> <span class="fu">y</span>(<span class="dv">0</span>))</span>
|
<span id="cb6-2806"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y1"</span><span class="op">,</span> <span class="fu">y</span>(<span class="dv">0</span>))</span>
|
||||||
<span id="cb6-2806"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y2"</span><span class="op">,</span> <span class="fu">y</span>(<span class="dv">0</span>))</span>
|
<span id="cb6-2807"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y2"</span><span class="op">,</span> <span class="fu">y</span>(<span class="dv">0</span>))</span>
|
||||||
<span id="cb6-2807"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> <span class="st">"#000"</span>)</span>
|
<span id="cb6-2808"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> <span class="st">"#000"</span>)</span>
|
||||||
<span id="cb6-2808"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-opacity"</span><span class="op">,</span> <span class="fl">0.2</span>)<span class="op">;</span></span>
|
<span id="cb6-2809"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-opacity"</span><span class="op">,</span> <span class="fl">0.2</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2809"><a href></a> </span>
|
<span id="cb6-2810"><a href></a> </span>
|
||||||
<span id="cb6-2810"><a href></a> <span class="co">// Add gridlines</span></span>
|
<span id="cb6-2811"><a href></a> <span class="co">// Add gridlines</span></span>
|
||||||
<span id="cb6-2811"><a href></a> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb6-2812"><a href></a> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb6-2812"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"grid-lines"</span>)</span>
|
<span id="cb6-2813"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"grid-lines"</span>)</span>
|
||||||
<span id="cb6-2813"><a href></a> <span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"line"</span>)</span>
|
<span id="cb6-2814"><a href></a> <span class="op">.</span><span class="fu">selectAll</span>(<span class="st">"line"</span>)</span>
|
||||||
<span id="cb6-2814"><a href></a> <span class="op">.</span><span class="fu">data</span>(y<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))</span>
|
<span id="cb6-2815"><a href></a> <span class="op">.</span><span class="fu">data</span>(y<span class="op">.</span><span class="fu">ticks</span>(<span class="dv">5</span>))</span>
|
||||||
<span id="cb6-2815"><a href></a> <span class="op">.</span><span class="fu">join</span>(<span class="st">"line"</span>)</span>
|
<span id="cb6-2816"><a href></a> <span class="op">.</span><span class="fu">join</span>(<span class="st">"line"</span>)</span>
|
||||||
<span id="cb6-2816"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x1"</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
<span id="cb6-2817"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x1"</span><span class="op">,</span> <span class="dv">0</span>)</span>
|
||||||
<span id="cb6-2817"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x2"</span><span class="op">,</span> innerWidth)</span>
|
<span id="cb6-2818"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"x2"</span><span class="op">,</span> innerWidth)</span>
|
||||||
<span id="cb6-2818"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y1"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">y</span>(d))</span>
|
<span id="cb6-2819"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y1"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">y</span>(d))</span>
|
||||||
<span id="cb6-2819"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y2"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">y</span>(d))</span>
|
<span id="cb6-2820"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"y2"</span><span class="op">,</span> d <span class="kw">=></span> <span class="fu">y</span>(d))</span>
|
||||||
<span id="cb6-2820"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> <span class="st">"#ccc"</span>)</span>
|
<span id="cb6-2821"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke"</span><span class="op">,</span> <span class="st">"#ccc"</span>)</span>
|
||||||
<span id="cb6-2821"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-opacity"</span><span class="op">,</span> <span class="fl">0.5</span>)<span class="op">;</span></span>
|
<span id="cb6-2822"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"stroke-opacity"</span><span class="op">,</span> <span class="fl">0.5</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2822"><a href></a> </span>
|
<span id="cb6-2823"><a href></a> </span>
|
||||||
<span id="cb6-2823"><a href></a> <span class="co">// Create a line generator</span></span>
|
<span id="cb6-2824"><a href></a> <span class="co">// Create a line generator</span></span>
|
||||||
<span id="cb6-2824"><a href></a> <span class="kw">const</span> line <span class="op">=</span> d3<span class="op">.</span><span class="fu">line</span>()</span>
|
<span id="cb6-2825"><a href></a> <span class="kw">const</span> line <span class="op">=</span> d3<span class="op">.</span><span class="fu">line</span>()</span>
|
||||||
<span id="cb6-2825"><a href></a> <span class="op">.</span><span class="fu">x</span>(d <span class="kw">=></span> <span class="fu">x</span>(d<span class="op">.</span><span class="at">x</span>))</span>
|
<span id="cb6-2826"><a href></a> <span class="op">.</span><span class="fu">x</span>(d <span class="kw">=></span> <span class="fu">x</span>(d<span class="op">.</span><span class="at">x</span>))</span>
|
||||||
<span id="cb6-2826"><a href></a> <span class="op">.</span><span class="fu">y</span>(d <span class="kw">=></span> <span class="fu">y</span>(d<span class="op">.</span><span class="at">y</span>))</span>
|
<span id="cb6-2827"><a href></a> <span class="op">.</span><span class="fu">y</span>(d <span class="kw">=></span> <span class="fu">y</span>(d<span class="op">.</span><span class="at">y</span>))</span>
|
||||||
<span id="cb6-2827"><a href></a> <span class="op">.</span><span class="fu">curve</span>(d3<span class="op">.</span><span class="at">curveBasis</span>)<span class="op">;</span></span>
|
<span id="cb6-2828"><a href></a> <span class="op">.</span><span class="fu">curve</span>(d3<span class="op">.</span><span class="at">curveBasis</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2828"><a href></a> </span>
|
<span id="cb6-2829"><a href></a> </span>
|
||||||
<span id="cb6-2829"><a href></a> <span class="co">// Group to contain the basis function lines</span></span>
|
<span id="cb6-2830"><a href></a> <span class="co">// Group to contain the basis function lines</span></span>
|
||||||
<span id="cb6-2830"><a href></a> <span class="kw">const</span> linesGroup <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
<span id="cb6-2831"><a href></a> <span class="kw">const</span> linesGroup <span class="op">=</span> g<span class="op">.</span><span class="fu">append</span>(<span class="st">"g"</span>)</span>
|
||||||
<span id="cb6-2831"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"basis-functions"</span>)<span class="op">;</span></span>
|
<span id="cb6-2832"><a href></a> <span class="op">.</span><span class="fu">attr</span>(<span class="st">"class"</span><span class="op">,</span> <span class="st">"basis-functions"</span>)<span class="op">;</span></span>
|
||||||
<span id="cb6-2832"><a href></a> </span>
|
<span id="cb6-2833"><a href></a> </span>
|
||||||
<span id="cb6-2833"><a href></a> <span class="co">// Store the current basis functions for transition</span></span>
|
<span id="cb6-2834"><a href></a> <span class="co">// Store the current basis functions for transition</span></span>
|
||||||
<span id="cb6-2834"><a href></a> <span class="kw">let</span> currentBasisFunctions <span class="op">=</span> <span class="kw">new</span> <span class="bu">Map</span>()<span class="op">;</span></span>
|
<span id="cb6-2835"><a href></a> <span class="kw">let</span> currentBasisFunctions <span class="op">=</span> <span class="kw">new</span> <span class="bu">Map</span>()<span class="op">;</span></span>
|
||||||
<span id="cb6-2835"><a href></a> </span>
|
<span id="cb6-2836"><a href></a> </span>
|
||||||
<span id="cb6-2836"><a href></a> <span class="co">// Function to update the chart with new data</span></span>
|
<span id="cb6-2837"><a href></a> <span class="co">// Function to update the chart with new data</span></span>
|
||||||
<span id="cb6-2837"><a href></a> <span class="kw">function</span> <span class="fu">updateChart</span>(data) {</span>
|
<span id="cb6-2838"><a href></a> <span class="kw">function</span> <span class="fu">updateChart</span>(data) {</span>
|
||||||
<span id="cb6-2838"><a href></a> <span class="fu">updateChartInner</span>(g<span class="op">,</span> x<span class="op">,</span> y<span class="op">,</span> linesGroup<span class="op">,</span> color<span class="op">,</span> line<span class="op">,</span> data)<span class="op">;</span></span>
|
<span id="cb6-2839"><a href></a> <span class="fu">updateChartInner</span>(g<span class="op">,</span> x<span class="op">,</span> y<span class="op">,</span> linesGroup<span class="op">,</span> color<span class="op">,</span> line<span class="op">,</span> data)<span class="op">;</span></span>
|
||||||
<span id="cb6-2839"><a href></a> }</span>
|
<span id="cb6-2840"><a href></a> }</span>
|
||||||
<span id="cb6-2840"><a href></a> </span>
|
<span id="cb6-2841"><a href></a> </span>
|
||||||
<span id="cb6-2841"><a href></a> <span class="co">// Store the update function</span></span>
|
<span id="cb6-2842"><a href></a> <span class="co">// Store the update function</span></span>
|
||||||
<span id="cb6-2842"><a href></a> svg<span class="op">.</span><span class="fu">node</span>()<span class="op">.</span><span class="at">update</span> <span class="op">=</span> updateChart<span class="op">;</span></span>
|
<span id="cb6-2843"><a href></a> svg<span class="op">.</span><span class="fu">node</span>()<span class="op">.</span><span class="at">update</span> <span class="op">=</span> updateChart<span class="op">;</span></span>
|
||||||
<span id="cb6-2843"><a href></a> </span>
|
<span id="cb6-2844"><a href></a> </span>
|
||||||
<span id="cb6-2844"><a href></a> <span class="co">// Initial render</span></span>
|
<span id="cb6-2845"><a href></a> <span class="co">// Initial render</span></span>
|
||||||
<span id="cb6-2845"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
<span id="cb6-2846"><a href></a> <span class="fu">updateChart</span>(<span class="fu">filteredData</span>())<span class="op">;</span></span>
|
||||||
<span id="cb6-2846"><a href></a> </span>
|
<span id="cb6-2847"><a href></a> </span>
|
||||||
<span id="cb6-2847"><a href></a> container<span class="op">.</span><span class="fu">node</span>()<span class="op">.</span><span class="fu">appendChild</span>(svg<span class="op">.</span><span class="fu">node</span>())<span class="op">;</span></span>
|
<span id="cb6-2848"><a href></a> container<span class="op">.</span><span class="fu">node</span>()<span class="op">.</span><span class="fu">appendChild</span>(svg<span class="op">.</span><span class="fu">node</span>())<span class="op">;</span></span>
|
||||||
<span id="cb6-2848"><a href></a> <span class="cf">return</span> container<span class="op">.</span><span class="fu">node</span>()<span class="op">;</span></span>
|
<span id="cb6-2849"><a href></a> <span class="cf">return</span> container<span class="op">.</span><span class="fu">node</span>()<span class="op">;</span></span>
|
||||||
<span id="cb6-2849"><a href></a>}</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
<span id="cb6-2850"><a href></a>}</span></code><button title="Copy to Clipboard" class="code-copy-button"><i class="bi"></i></button></pre></div>
|
||||||
<div class="cell-output cell-output-display">
|
<div class="cell-output cell-output-display">
|
||||||
<div id="ojs-cell-5" data-nodetype="declaration">
|
<div id="ojs-cell-5" data-nodetype="declaration">
|
||||||
|
|
||||||
|
|||||||
@@ -713,9 +713,10 @@ Supports OpenMP parallelism
|
|||||||
//[[Rcpp::depends(rcpptimer)]]
|
//[[Rcpp::depends(rcpptimer)]]
|
||||||
#include <rcpptimer.h>
|
#include <rcpptimer.h>
|
||||||
|
|
||||||
void main(){
|
//[[Rcpp::export]]
|
||||||
|
void ex()
|
||||||
|
{
|
||||||
Rcpp::Timer timer;
|
Rcpp::Timer timer;
|
||||||
|
|
||||||
timer.tic();
|
timer.tic();
|
||||||
// Code to be timed
|
// Code to be timed
|
||||||
timer.toc();
|
timer.toc();
|
||||||
|
|||||||
Reference in New Issue
Block a user