UNPKG

@prachwal/mandelbrot-generator

Version:

Professional Mandelbrot fractal generator with TypeScript support, interactive web interface, and multiple output formats

24 lines (22 loc) 13 kB
<!DOCTYPE html><html class="default" lang="en" data-base="../"><head><meta charset="utf-8"/><meta http-equiv="x-ua-compatible" content="IE=edge"/><title>calculateSetBoundary | @prachwal/mandelbrot-generator - v1.0.0</title><meta name="description" content="Documentation for @prachwal/mandelbrot-generator"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="stylesheet" href="../assets/style.css"/><link rel="stylesheet" href="../assets/highlight.css"/><script defer src="../assets/main.js"></script><script async src="../assets/icons.js" id="tsd-icons-script"></script><script async src="../assets/search.js" id="tsd-search-script"></script><script async src="../assets/navigation.js" id="tsd-nav-script"></script></head><body><script>document.documentElement.dataset.theme = localStorage.getItem("tsd-theme") || "os";document.body.style.display="none";setTimeout(() => window.app?app.showPage():document.body.style.removeProperty("display"),500)</script><header class="tsd-page-toolbar"><div class="tsd-toolbar-contents container"><a href="../index.html" class="title">@prachwal/mandelbrot-generator - v1.0.0</a><div id="tsd-toolbar-links"></div><button id="tsd-search-trigger" class="tsd-widget" aria-label="Search"><svg width="16" height="16" viewBox="0 0 16 16" fill="none" aria-hidden="true"><use href="../assets/icons.svg#icon-search"></use></svg></button><dialog id="tsd-search" aria-label="Search"><input role="combobox" id="tsd-search-input" aria-controls="tsd-search-results" aria-autocomplete="list" aria-expanded="true" autocapitalize="off" autocomplete="off" placeholder="Search the docs" maxLength="100"/><ul role="listbox" id="tsd-search-results"></ul><div id="tsd-search-status" aria-live="polite" aria-atomic="true"><div>Preparing search index...</div></div></dialog><a href="#" class="tsd-widget menu" id="tsd-toolbar-menu-trigger" data-toggle="menu" aria-label="Menu"><svg width="16" height="16" viewBox="0 0 16 16" fill="none" aria-hidden="true"><use href="../assets/icons.svg#icon-menu"></use></svg></a></div></header><div class="container container-main"><div class="col-content"><div class="tsd-page-title"><ul class="tsd-breadcrumb" aria-label="Breadcrumb"><li><a href="" aria-current="page">calculateSetBoundary</a></li></ul><h1>Function calculateSetBoundary</h1></div><section class="tsd-panel"><ul class="tsd-signatures"><li class=""><div class="tsd-signature tsd-anchor-link" id="calculatesetboundary"><span class="tsd-kind-call-signature">calculateSetBoundary</span><span class="tsd-signature-symbol">(</span><br/>    <span class="tsd-kind-parameter">config</span><span class="tsd-signature-symbol">:</span> <a href="../interfaces/MandelbrotConfig.html" class="tsd-signature-type tsd-kind-interface">MandelbrotConfig</a><span class="tsd-signature-symbol">,</span><br/>    <span class="tsd-kind-parameter">samples</span><span class="tsd-signature-symbol">?:</span> <span class="tsd-signature-type">number</span><span class="tsd-signature-symbol">,</span><br/><span class="tsd-signature-symbol">)</span><span class="tsd-signature-symbol">:</span> <a href="../interfaces/BoundaryPoint.html" class="tsd-signature-type tsd-kind-interface">BoundaryPoint</a><span class="tsd-signature-symbol">[]</span><a href="#calculatesetboundary" aria-label="Permalink" class="tsd-anchor-icon"><svg viewBox="0 0 24 24" aria-hidden="true"><use href="../assets/icons.svg#icon-anchor"></use></svg></a></div><div class="tsd-description"><div class="tsd-comment tsd-typography"><p>Calculates an approximate boundary of the Mandelbrot set within given bounds</p> <p>This function samples points in the complex plane and identifies those that lie on or near the boundary of the Mandelbrot set. Boundary points are defined as those that escape after a significant number of iterations but before the maximum.</p> </div><div class="tsd-parameters"><h4 class="tsd-parameters-title">Parameters</h4><ul class="tsd-parameter-list"><li><span><span class="tsd-kind-parameter">config</span>: <a href="../interfaces/MandelbrotConfig.html" class="tsd-signature-type tsd-kind-interface">MandelbrotConfig</a></span><div class="tsd-comment tsd-typography"><p>Fractal generation configuration defining the sampling area</p> </div><div class="tsd-comment tsd-typography"></div></li><li><span><span class="tsd-kind-parameter">samples</span>: <span class="tsd-signature-type">number</span><span class="tsd-signature-symbol"> = 1000</span></span><div class="tsd-comment tsd-typography"><p>Number of sample points per dimension (default: 1000)</p> </div><div class="tsd-comment tsd-typography"></div></li></ul></div><h4 class="tsd-returns-title">Returns <a href="../interfaces/BoundaryPoint.html" class="tsd-signature-type tsd-kind-interface">BoundaryPoint</a><span class="tsd-signature-symbol">[]</span></h4><p>Array of boundary points with their coordinates and iteration counts</p> <div class="tsd-comment tsd-typography"><div class="tsd-tag-example"><h4 class="tsd-anchor-link" id="example">Example<a href="#example" aria-label="Permalink" class="tsd-anchor-icon"><svg viewBox="0 0 24 24" aria-hidden="true"><use href="../assets/icons.svg#icon-anchor"></use></svg></a></h4><pre><code class="typescript"><span class="hl-6">import</span><span class="hl-2"> { </span><span class="hl-7">calculateSetBoundary</span><span class="hl-2"> } </span><span class="hl-6">from</span><span class="hl-2"> </span><span class="hl-3">&#39;./mandelbrot.js&#39;</span><span class="hl-2">;</span><br/><span class="hl-6">import</span><span class="hl-2"> { </span><span class="hl-7">defaultConfig</span><span class="hl-2"> } </span><span class="hl-6">from</span><span class="hl-2"> </span><span class="hl-3">&#39;./config.js&#39;</span><span class="hl-2">;</span><br/><br/><span class="hl-0">// Find boundary points in the classic view</span><br/><span class="hl-4">const</span><span class="hl-2"> </span><span class="hl-8">boundary</span><span class="hl-2"> = </span><span class="hl-1">calculateSetBoundary</span><span class="hl-2">({</span><br/><span class="hl-2"> ...</span><span class="hl-7">defaultConfig</span><span class="hl-2">,</span><br/><span class="hl-2"> </span><span class="hl-7">centerX:</span><span class="hl-2"> -</span><span class="hl-5">0.5</span><span class="hl-2">,</span><br/><span class="hl-2"> </span><span class="hl-7">centerY:</span><span class="hl-2"> </span><span class="hl-5">0</span><span class="hl-2">,</span><br/><span class="hl-2"> </span><span class="hl-7">zoom:</span><span class="hl-2"> </span><span class="hl-5">1</span><span class="hl-2">,</span><br/><span class="hl-2"> </span><span class="hl-7">maxIterations:</span><span class="hl-2"> </span><span class="hl-5">256</span><br/><span class="hl-2">}, </span><span class="hl-5">500</span><span class="hl-2">);</span><br/><br/><span class="hl-7">console</span><span class="hl-2">.</span><span class="hl-1">log</span><span class="hl-2">(</span><span class="hl-3">`Found </span><span class="hl-4">${</span><span class="hl-7">boundary</span><span class="hl-10">.</span><span class="hl-7">length</span><span class="hl-4">}</span><span class="hl-3"> boundary points`</span><span class="hl-2">);</span><br/><br/><span class="hl-0">// Analyze boundary complexity</span><br/><span class="hl-4">const</span><span class="hl-2"> </span><span class="hl-8">avgIterations</span><span class="hl-2"> = </span><span class="hl-7">boundary</span><span class="hl-2">.</span><span class="hl-1">reduce</span><span class="hl-2">((</span><span class="hl-7">sum</span><span class="hl-2">, </span><span class="hl-7">p</span><span class="hl-2">) </span><span class="hl-4">=&gt;</span><span class="hl-2"> </span><span class="hl-7">sum</span><span class="hl-2"> + </span><span class="hl-7">p</span><span class="hl-2">.</span><span class="hl-7">iterations</span><span class="hl-2">, </span><span class="hl-5">0</span><span class="hl-2">) / </span><span class="hl-7">boundary</span><span class="hl-2">.</span><span class="hl-7">length</span><span class="hl-2">;</span><br/><span class="hl-7">console</span><span class="hl-2">.</span><span class="hl-1">log</span><span class="hl-2">(</span><span class="hl-3">`Average boundary iterations: </span><span class="hl-4">${</span><span class="hl-7">avgIterations</span><span class="hl-4">}</span><span class="hl-3">`</span><span class="hl-2">);</span><br/><br/><span class="hl-0">// Find most interesting boundary points</span><br/><span class="hl-4">const</span><span class="hl-2"> </span><span class="hl-8">complex</span><span class="hl-2"> = </span><span class="hl-7">boundary</span><span class="hl-2">.</span><span class="hl-1">filter</span><span class="hl-2">(</span><span class="hl-7">p</span><span class="hl-2"> </span><span class="hl-4">=&gt;</span><span class="hl-2"> </span><span class="hl-7">p</span><span class="hl-2">.</span><span class="hl-7">iterations</span><span class="hl-2"> &gt; </span><span class="hl-5">200</span><span class="hl-2">);</span> </code><button type="button">Copy</button></pre> </div><div class="tsd-tag-performance"><h4 class="tsd-anchor-link" id="performance">Performance<a href="#performance" aria-label="Permalink" class="tsd-anchor-icon"><svg viewBox="0 0 24 24" aria-hidden="true"><use href="../assets/icons.svg#icon-anchor"></use></svg></a></h4><ul> <li>Time complexity: O(samples²)</li> <li>Memory complexity: O(boundary_points)</li> <li>Higher sample counts provide more accurate boundaries but slower computation</li> </ul> </div><div class="tsd-tag-algorithm"><h4 class="tsd-anchor-link" id="algorithm">Algorithm<a href="#algorithm" aria-label="Permalink" class="tsd-anchor-icon"><svg viewBox="0 0 24 24" aria-hidden="true"><use href="../assets/icons.svg#icon-anchor"></use></svg></a></h4><p>Points are considered on the boundary if their iteration count is between 50% and 100% of the maximum iterations, indicating they're near the escape threshold.</p> </div><div class="tsd-tag-see"><h4 class="tsd-anchor-link" id="see">See<a href="#see" aria-label="Permalink" class="tsd-anchor-icon"><svg viewBox="0 0 24 24" aria-hidden="true"><use href="../assets/icons.svg#icon-anchor"></use></svg></a></h4><ul> <li><a href="../interfaces/BoundaryPoint.html" class="tsd-kind-interface">BoundaryPoint</a> for result structure</li> <li><a href="mandelbrotIteration.html" class="tsd-kind-function">mandelbrotIteration</a> for iteration computation</li> </ul> </div><div class="tsd-tag-since"><h4 class="tsd-anchor-link" id="since">Since<a href="#since" aria-label="Permalink" class="tsd-anchor-icon"><svg viewBox="0 0 24 24" aria-hidden="true"><use href="../assets/icons.svg#icon-anchor"></use></svg></a></h4><p>1.0.0</p> </div></div><aside class="tsd-sources"><ul><li>Defined in <a href="https://github.com/prachwal/mandelbrot-generator/blob/ae4cb4d8557fb6cf7109ede31bd9f1389eec74e6/src/mandelbrot.ts#L342">mandelbrot.ts:342</a></li></ul></aside></div></li></ul></section></div><div class="col-sidebar"><div class="page-menu"><div class="tsd-navigation settings"><details class="tsd-accordion"><summary class="tsd-accordion-summary"><svg width="20" height="20" viewBox="0 0 24 24" fill="none" aria-hidden="true"><use href="../assets/icons.svg#icon-chevronDown"></use></svg><h3>Settings</h3></summary><div class="tsd-accordion-details"><div class="tsd-filter-visibility"><span class="settings-label">Member Visibility</span><ul id="tsd-filter-options"><li class="tsd-filter-item"><label class="tsd-filter-input"><input type="checkbox" id="tsd-filter-inherited" name="inherited" checked/><svg width="32" height="32" viewBox="0 0 32 32" aria-hidden="true"><rect class="tsd-checkbox-background" width="30" height="30" x="1" y="1" rx="6" fill="none"></rect><path class="tsd-checkbox-checkmark" d="M8.35422 16.8214L13.2143 21.75L24.6458 10.25" stroke="none" stroke-width="3.5" stroke-linejoin="round" fill="none"></path></svg><span>Inherited</span></label></li><li class="tsd-filter-item"><label class="tsd-filter-input"><input type="checkbox" id="tsd-filter-external" name="external"/><svg width="32" height="32" viewBox="0 0 32 32" aria-hidden="true"><rect class="tsd-checkbox-background" width="30" height="30" x="1" y="1" rx="6" fill="none"></rect><path class="tsd-checkbox-checkmark" d="M8.35422 16.8214L13.2143 21.75L24.6458 10.25" stroke="none" stroke-width="3.5" stroke-linejoin="round" fill="none"></path></svg><span>External</span></label></li></ul></div><div class="tsd-theme-toggle"><label class="settings-label" for="tsd-theme">Theme</label><select id="tsd-theme"><option value="os">OS</option><option value="light">Light</option><option value="dark">Dark</option></select></div></div></details></div></div><div class="site-menu"><nav class="tsd-navigation"><a href="../modules.html">@prachwal/mandelbrot-generator - v1.0.0</a><ul class="tsd-small-nested-navigation" id="tsd-nav-container"><li>Loading...</li></ul></nav></div></div></div><footer><p class="tsd-generator">Generated using <a href="https://typedoc.org/" target="_blank">TypeDoc</a></p></footer><div class="overlay"></div></body></html>