@cortex-js/compute-engine 0.54.0 → 0.55.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/compile.esm.js +24412 -0
- package/dist/compile.min.esm.js +941 -0
- package/dist/compile.min.umd.cjs +943 -0
- package/dist/compile.umd.cjs +24437 -0
- package/dist/compute-engine.esm.js +54357 -55186
- package/dist/compute-engine.min.esm.js +90 -99
- package/dist/compute-engine.min.umd.cjs +90 -99
- package/dist/compute-engine.umd.cjs +54581 -55410
- package/dist/core.esm.js +67441 -0
- package/dist/core.min.esm.js +1010 -0
- package/dist/core.min.umd.cjs +1012 -0
- package/dist/core.umd.cjs +67466 -0
- package/dist/interval.esm.js +13287 -0
- package/dist/interval.min.esm.js +18 -0
- package/dist/interval.min.umd.cjs +20 -0
- package/dist/interval.umd.cjs +13312 -0
- package/dist/latex-syntax.esm.js +14977 -0
- package/dist/latex-syntax.min.esm.js +7 -0
- package/dist/latex-syntax.min.umd.cjs +9 -0
- package/dist/latex-syntax.umd.cjs +15002 -0
- package/dist/math-json.esm.js +2 -2
- package/dist/math-json.min.esm.js +2 -2
- package/dist/math-json.min.umd.cjs +2 -2
- package/dist/math-json.umd.cjs +2 -2
- package/dist/numerics.esm.js +8618 -0
- package/dist/numerics.min.esm.js +5 -0
- package/dist/numerics.min.umd.cjs +7 -0
- package/dist/numerics.umd.cjs +8643 -0
- package/dist/types/big-decimal/big-decimal.d.ts +191 -0
- package/dist/types/big-decimal/index.d.ts +2 -0
- package/dist/types/big-decimal/transcendentals.d.ts +56 -0
- package/dist/types/big-decimal/utils.d.ts +86 -0
- package/dist/types/common/ansi-codes.d.ts +1 -1
- package/dist/types/common/configuration-change.d.ts +1 -1
- package/dist/types/common/fuzzy-string-match.d.ts +1 -1
- package/dist/types/common/grapheme-splitter.d.ts +1 -1
- package/dist/types/common/interruptible.d.ts +1 -1
- package/dist/types/common/one-of.d.ts +1 -1
- package/dist/types/common/signals.d.ts +1 -1
- package/dist/types/common/type/ast-nodes.d.ts +1 -1
- package/dist/types/common/type/boxed-type.d.ts +1 -1
- package/dist/types/common/type/lexer.d.ts +1 -1
- package/dist/types/common/type/parse.d.ts +1 -1
- package/dist/types/common/type/parser.d.ts +1 -1
- package/dist/types/common/type/primitive.d.ts +1 -1
- package/dist/types/common/type/reduce.d.ts +1 -1
- package/dist/types/common/type/serialize.d.ts +1 -1
- package/dist/types/common/type/subtype.d.ts +1 -1
- package/dist/types/common/type/type-builder.d.ts +1 -1
- package/dist/types/common/type/types.d.ts +1 -1
- package/dist/types/common/type/utils.d.ts +1 -1
- package/dist/types/common/utils.d.ts +1 -1
- package/dist/types/compile.d.ts +10 -0
- package/dist/types/compute-engine/assume.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/abstract-boxed-expression.d.ts +45 -6
- package/dist/types/compute-engine/boxed-expression/apply.d.ts +4 -4
- package/dist/types/compute-engine/boxed-expression/arithmetic-add.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/arithmetic-mul-div.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/arithmetic-power.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/ascii-math.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/box.d.ts +2 -2
- package/dist/types/compute-engine/boxed-expression/boxed-dictionary.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-function.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-number.d.ts +5 -5
- package/dist/types/compute-engine/boxed-expression/boxed-operator-definition.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-patterns.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-string.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-symbol.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-tensor.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-value-definition.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/cache.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/canonical-utils.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/canonical.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/compare.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/constants.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/expand.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/expression-map.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/factor.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/flatten.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/hold.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/inequality-bounds.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/init-lazy-refs.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/invisible-operator.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/match.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/negate.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/numerics.d.ts +4 -4
- package/dist/types/compute-engine/boxed-expression/order.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/pattern-utils.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/polynomial-degree.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/polynomials.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/predicates.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/rules.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/serialize.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/sgn.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/simplify.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/solve-linear-system.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/solve.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/stochastic-equal.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/trigonometry.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/type-guards.d.ts +1 -13
- package/dist/types/compute-engine/boxed-expression/utils.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/validate.d.ts +1 -1
- package/dist/types/compute-engine/collection-utils.d.ts +3 -3
- package/dist/types/compute-engine/compilation/base-compiler.d.ts +1 -1
- package/dist/types/compute-engine/compilation/compile-expression.d.ts +1 -1
- package/dist/types/compute-engine/compilation/glsl-target.d.ts +1 -1
- package/dist/types/compute-engine/compilation/gpu-target.d.ts +1 -1
- package/dist/types/compute-engine/compilation/interval-javascript-target.d.ts +1 -1
- package/dist/types/compute-engine/compilation/javascript-target.d.ts +1 -1
- package/dist/types/compute-engine/compilation/python-target.d.ts +1 -1
- package/dist/types/compute-engine/compilation/types.d.ts +1 -1
- package/dist/types/compute-engine/compilation/wgsl-target.d.ts +1 -1
- package/dist/types/compute-engine/cost-function.d.ts +1 -1
- package/dist/types/compute-engine/engine-assumptions.d.ts +1 -1
- package/dist/types/compute-engine/engine-cache.d.ts +1 -1
- package/dist/types/compute-engine/engine-common-symbols.d.ts +1 -1
- package/dist/types/compute-engine/engine-compilation-targets.d.ts +1 -1
- package/dist/types/compute-engine/engine-configuration-lifecycle.d.ts +1 -1
- package/dist/types/compute-engine/engine-declarations.d.ts +1 -1
- package/dist/types/compute-engine/engine-expression-entrypoints.d.ts +4 -4
- package/dist/types/compute-engine/engine-extension-contracts.d.ts +1 -1
- package/dist/types/compute-engine/engine-library-bootstrap.d.ts +1 -4
- package/dist/types/compute-engine/engine-numeric-configuration.d.ts +11 -15
- package/dist/types/compute-engine/engine-runtime-state.d.ts +1 -1
- package/dist/types/compute-engine/engine-scope.d.ts +1 -1
- package/dist/types/compute-engine/engine-sequences.d.ts +1 -1
- package/dist/types/compute-engine/engine-simplification-rules.d.ts +1 -1
- package/dist/types/compute-engine/engine-startup-coordinator.d.ts +1 -1
- package/dist/types/compute-engine/engine-type-resolver.d.ts +1 -1
- package/dist/types/compute-engine/engine-validation-entrypoints.d.ts +2 -2
- package/dist/types/compute-engine/free-functions.d.ts +14 -14
- package/dist/types/compute-engine/function-utils.d.ts +1 -1
- package/dist/types/compute-engine/global-types.d.ts +1 -1
- package/dist/types/compute-engine/index.d.ts +55 -154
- package/dist/types/compute-engine/interval/arithmetic.d.ts +1 -1
- package/dist/types/compute-engine/interval/comparison.d.ts +1 -1
- package/dist/types/compute-engine/interval/elementary.d.ts +1 -1
- package/dist/types/compute-engine/interval/index.d.ts +1 -1
- package/dist/types/compute-engine/interval/trigonometric.d.ts +1 -1
- package/dist/types/compute-engine/interval/types.d.ts +1 -1
- package/dist/types/compute-engine/interval/util.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/default-dictionary.d.ts +37 -0
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-algebra.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-arithmetic.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-calculus.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-complex.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-core.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-linear-algebra.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-logic.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-other.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-relational-operators.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-sets.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-statistics.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-symbols.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-trigonometry.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-units.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/indexed-types.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/latex-syntax.d.ts +113 -0
- package/dist/types/compute-engine/latex-syntax/parse-number.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/parse-symbol.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/parse.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/serialize-dms.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/serialize-number.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/serializer-style.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/serializer.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/tokenizer.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/types.d.ts +8 -8
- package/dist/types/compute-engine/latex-syntax/utils.d.ts +1 -1
- package/dist/types/compute-engine/library/arithmetic.d.ts +1 -1
- package/dist/types/compute-engine/library/calculus.d.ts +1 -1
- package/dist/types/compute-engine/library/collections.d.ts +1 -1
- package/dist/types/compute-engine/library/colors.d.ts +1 -1
- package/dist/types/compute-engine/library/combinatorics.d.ts +1 -1
- package/dist/types/compute-engine/library/complex.d.ts +1 -1
- package/dist/types/compute-engine/library/control-structures.d.ts +1 -1
- package/dist/types/compute-engine/library/core.d.ts +1 -1
- package/dist/types/compute-engine/library/fractals.d.ts +1 -1
- package/dist/types/compute-engine/library/library.d.ts +3 -3
- package/dist/types/compute-engine/library/linear-algebra.d.ts +1 -1
- package/dist/types/compute-engine/library/logic-analysis.d.ts +1 -1
- package/dist/types/compute-engine/library/logic.d.ts +1 -1
- package/dist/types/compute-engine/library/number-theory.d.ts +1 -1
- package/dist/types/compute-engine/library/polynomials.d.ts +1 -1
- package/dist/types/compute-engine/library/quantity-arithmetic.d.ts +1 -1
- package/dist/types/compute-engine/library/random-expression.d.ts +1 -1
- package/dist/types/compute-engine/library/relational-operator.d.ts +1 -1
- package/dist/types/compute-engine/library/sets.d.ts +1 -1
- package/dist/types/compute-engine/library/statistics.d.ts +1 -1
- package/dist/types/compute-engine/library/trigonometry.d.ts +1 -1
- package/dist/types/compute-engine/library/type-handlers.d.ts +1 -1
- package/dist/types/compute-engine/library/unit-data.d.ts +1 -1
- package/dist/types/compute-engine/library/units.d.ts +1 -1
- package/dist/types/compute-engine/library/utils.d.ts +1 -1
- package/dist/types/compute-engine/numeric-value/big-numeric-value.d.ts +24 -9
- package/dist/types/compute-engine/numeric-value/exact-numeric-value.d.ts +6 -7
- package/dist/types/compute-engine/numeric-value/machine-numeric-value.d.ts +7 -8
- package/dist/types/compute-engine/numeric-value/types.d.ts +8 -8
- package/dist/types/compute-engine/numerics/bigint.d.ts +2 -2
- package/dist/types/compute-engine/numerics/expression.d.ts +1 -1
- package/dist/types/compute-engine/numerics/interval.d.ts +1 -1
- package/dist/types/compute-engine/numerics/linear-algebra.d.ts +4 -0
- package/dist/types/compute-engine/numerics/monte-carlo.d.ts +1 -1
- package/dist/types/compute-engine/numerics/numeric-bigint.d.ts +1 -1
- package/dist/types/compute-engine/numerics/numeric-bignum.d.ts +4 -4
- package/dist/types/compute-engine/numerics/numeric-complex.d.ts +1 -1
- package/dist/types/compute-engine/numerics/numeric.d.ts +1 -1
- package/dist/types/compute-engine/numerics/primes.d.ts +1 -1
- package/dist/types/compute-engine/numerics/rationals.d.ts +1 -1
- package/dist/types/compute-engine/numerics/richardson.d.ts +1 -1
- package/dist/types/compute-engine/numerics/special-functions.d.ts +27 -1
- package/dist/types/compute-engine/numerics/statistics.d.ts +12 -12
- package/dist/types/compute-engine/numerics/strings.d.ts +1 -1
- package/dist/types/compute-engine/numerics/types.d.ts +2 -15
- package/dist/types/compute-engine/numerics/unit-data.d.ts +1 -1
- package/dist/types/compute-engine/oeis.d.ts +1 -1
- package/dist/types/compute-engine/sequence.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/antiderivative.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/derivative.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/distribute.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/fu-cost.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/fu-transforms.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/fu.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/logic-utils.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-abs.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-divide.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-factorial.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-hyperbolic.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-infinity.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-log.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-logic.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-power.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-product.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-rules.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-sum.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/simplify-trig.d.ts +1 -1
- package/dist/types/compute-engine/tensor/tensor-fields.d.ts +1 -1
- package/dist/types/compute-engine/tensor/tensors.d.ts +1 -1
- package/dist/types/compute-engine/types-definitions.d.ts +2 -4
- package/dist/types/compute-engine/types-engine.d.ts +40 -39
- package/dist/types/compute-engine/types-evaluation.d.ts +1 -1
- package/dist/types/compute-engine/types-expression.d.ts +49 -30
- package/dist/types/compute-engine/types-kernel-evaluation.d.ts +1 -1
- package/dist/types/compute-engine/types-kernel-serialization.d.ts +14 -5
- package/dist/types/compute-engine/types-serialization.d.ts +1 -1
- package/dist/types/compute-engine/types.d.ts +1 -1
- package/dist/types/compute-engine.d.ts +6 -3
- package/dist/types/core.d.ts +11 -0
- package/dist/types/interval.d.ts +8 -0
- package/dist/types/latex-syntax.d.ts +14 -0
- package/dist/types/math-json/symbols.d.ts +1 -1
- package/dist/types/math-json/types.d.ts +1 -1
- package/dist/types/math-json/utils.d.ts +1 -1
- package/dist/types/math-json.d.ts +2 -2
- package/dist/types/numerics.d.ts +23 -0
- package/package.json +33 -3
- package/dist/types/compute-engine/engine-latex-dictionary-state.d.ts +0 -13
- package/dist/types/compute-engine/engine-parse-entrypoint.d.ts +0 -7
|
@@ -0,0 +1,941 @@
|
|
|
1
|
+
/** Compute Engine 0.55.0 */
|
|
2
|
+
function si(e,n,t={}){let{contract:i=.125,step:r=1,power:s=2,atol:o=1e-16,rtol:a=o>0?0:Math.sqrt(Number.EPSILON),maxeval:u=1e6,breaktol:l=2}=t;if(!isFinite(n))return si(k=>e(1/k),1/n,{rtol:a,atol:o,maxeval:u,contract:Math.abs(i)>1?1/i:i,step:1/r,power:s});let c=r,p=Math.pow(1/i,s),m=e(n+c),d=[m],b=1/0,v=1;for(;v<u;){v+=1,c*=i,d.push(e(n+c));let k=p,w=1/0;for(let R=d.length-2;R>=0;R--){let P=d[R];d[R]=d[R+1]+(d[R+1]-d[R])/(k-1);let O=Math.abs(d[R]-P);w=Math.min(w,O),O<b&&(m=d[R],b=O),k*=p}if(w>l*b||!isFinite(w)||b<=Math.max(a*Math.abs(m),o))break}return[m,b]}var ws=new Map;function F(e){if(e<=100){let n=ws.get(e);return n===void 0&&(n=10n**BigInt(e),ws.set(e,n)),n}return 10n**BigInt(e)}function $s(e,n,t){return e*n/t}function Cs(e,n,t){return e*t/n}function Pn(e,n){if(e===0n)return 0n;if(e<0n)throw new RangeError("fpsqrt: negative input");let t,i=Number(e),r=Number(n);if(Number.isFinite(i)&&Number.isFinite(r)&&i>0&&r>0){let c=Math.sqrt(i/r)*r;Number.isFinite(c)&&c>0?(t=BigInt(Math.floor(c)),t===0n&&(t=1n)):t=As(e,n)}else t=As(e,n);let s=e*n,o;do o=t,t=(t+s/t)/2n;while(xe(t-o)>1n);let a=(t+s/t)/2n,u=xe(t*t-s);return xe(a*a-s)<u?a:t}function As(e,n){let i=Q(e),r=Math.max(0,i-15),s=Number(r>0?e/F(r):e),o=Q(n),a=Math.max(0,o-15),u=Number(a>0?n/F(a):n),l=r+a,c=Math.floor(l/2),p=Math.sqrt(s*u);l%2!==0&&(p*=3.1622776601683795);let m=BigInt(Math.round(p))*F(c);return m>0n?m:1n}function xe(e){return e<0n?-e:e}function Q(e){if(e===0n)return 1;if(e<0n&&(e=-e),e<0x20000000000000n)return Math.floor(Math.log10(Number(e)))+1;let n=0,t=e,i=1;for(;t>>BigInt(i)>0n;)i*=2;for(let s=i>>1;s>=1;s>>=1)t>>BigInt(s)>0n&&(n+=s,t>>=BigInt(s));n+=1;let r=Math.ceil(n*.30102999566398);return e<F(r-1)?r-1:e>=F(r)?r+1:r}function ui(e,n){if(e===0n)return n;let t=0,i=e,r=n/2n;for(;xe(i)>r;)i=i/2n,t++;let s=n,o=i;s+=o;for(let a=2;o=o*i/(BigInt(a)*n),xe(o)!==0n;a++)s+=o;for(let a=0;a<t;a++)s=s*s/n;return s}function Rs(e,n){if(e===n)return 0n;let t=Number(e),i=Number(n),r,s=e,o=0;if(Number.isFinite(t)&&Number.isFinite(i)&&t>0&&i>0){let u=t/i;if(Number.isFinite(u)&&u>0){let l=Math.log(u);Number.isFinite(l)?r=BigInt(Math.round(l*i)):r=oi(e,n)}else r=oi(e,n)}else{s=e;let u=2n*n,l=n/2n;for(;s>u||s<l;)s=Pn(s,n),o++;r=oi(s,n)}let a=0n;for(let u=0;u<100;u++){let l=ui(r,n);if(l===0n){r=r/2n;continue}let c=r+s*n/l-n,p=xe(c-r);if(p<=1n||p<100000n&&a>0n&&a<100000n&&p*4n>=a)break;a=p,r=c}for(let u=0;u<o;u++)r=2n*r;return r}function oi(e,n){let t=Q(e),i=Q(n);return BigInt(t-i)*2302585n*n/1000000n}var ft="314159265358979323846264338327950288419716939937510582097494459230781640628620899862803482534211706798214808651328230664709384460955058223172535940812848111745028410270193852110555964462294895493038196442881097566593344612847564823378678316527120190914564856692346034861045432664821339360726024914127372458700660631558817488152092096282925409171536436789259036001133053054882046652138414695194151160943305727036575959195309218611738193261179310511854807446237996274956735188575272489122793818301194912983367336244065664308602139494639522473719070217986094370277053921717629317675238467481846766940513200056812714526356082778577134275778960917363717872146844090122495343014654958537105079227968925892354201995611212902196086403441815981362977477130996051870721134999999837297804995105973173281609631859502445945534690830264252230825334468503526193118817101000313783875288658753320838142061717766914730359825349042875546873115956286388235378759375195778185778053217122680661300192787661119590921642019893809525720106548586327886593615338182796823030195203530185296899577362259941389124972177528347913151557485724245415069595082953311686172785588907509838175463746493931925506040092770167113900984882401285836160356370766010471018194295559619894676783744944825537977472684710404753464620804668425906949129331367702898915210475216205696602405803815019351125338243003558764024749647326391419927260426992279678235478163600934172164121992458631503028618297455570674983850549458858692699569092721079750930295532116534498720275596023648066549911988183479775356636980742654252786255181841757467289097777279380008164706001614524919217321721477235014144197356854816136115735255213347574184946843852332390739414333454776241686251898356948556209921922218427255025425688767179049460165346680498862723279178608578438382796797668145410095388378636095068006422512520511739298489608412848862694560424196528502221066118630674427862203919494504712371378696095636437191728746776465757396241389086583264599581339047802759009946576407895126946839835259570982582262052248940772671947826848260147699090264013639443745530506820349625245174939965143142980919065925093722169646151570985838741059788595977297549893016175392846813826868386894277415599185592524595395943104997252468084598727364469584865383673622262609912460805124388439045124413654976278079771569143599770012961608944169486855584840635",ct=null;function ai(e){if(ct!==null&&ct.scale===e)return ct.value;let t=Q(e)-1+10,i=ft.slice(0,t+1),r=BigInt(i),s=i.length-1,o=r*e/F(s);return ct={scale:e,value:o},o}function pt(e,n){if(e===0n)return[0n,n];let t=ai(n),i=2n*t,r=t/2n,s,o=xe(e);if(o>n*(1n<<30n)){let P=Q(o)-Q(n)+20,O=n*F(P),W=e*F(P),ve=2n*ai(O),U=W%ve;U<0n&&(U+=ve),s=U/F(P)}else s=e%i;s<0n&&(s+=i);let a=1n,u=1n;s>3n*r?(s=i-s,a=-1n):s>t?(s=s-t,a=-1n,u=-1n):s>r&&(s=t-s,u=-1n);let l=Q(n)-1,c=Math.min(18,Math.max(2,Math.ceil(.87*Math.sqrt(l)))),p=0,m=n>>BigInt(c);for(;s>m;)s=s/2n,p++;let d=s,b=n,v=s,k=n,w=s*s,R=n*n;for(let P=2;;P+=2){if(k=k*w/(BigInt(P)*BigInt(P-1)*R),k===0n){v=v*w/(BigInt(P+1)*BigInt(P)*R),v!==0n&&(P%4===2?(b-=k,d-=v):(b+=k,d+=v));break}if(v=v*w/(BigInt(P+1)*BigInt(P)*R),P%4===2?(b-=k,d-=v):(b+=k,d+=v),v===0n)break}for(let P=0;P<p;P++){let O=2n*d*b/n,W=2n*b*b/n-n;d=O,b=W}return[a*d,u*b]}function Dn(e,n){if(e===0n)return 0n;if(e<0n)return-Dn(-e,n);let i=ai(n)/2n;if(e>n){let p=n*n/e;return i-Dn(p,n)}let r=4n*n/10n,s=0,o=e;for(;o>r;){let p=o*o,m=(n*n+p)/n,d=Pn(m,n);o=o*n/(n+d),s++}let a=o,u=o,l=o*o,c=n*n;for(let p=3;u=u*l/c,u!==0n;p+=2)p%4===3?a-=u/BigInt(p):a+=u/BigInt(p);for(let p=0;p<s;p++)a=2n*a;return a}var li=NaN,x=class e{static precision=50;static ZERO=Object.freeze(Object.assign(Object.create(e.prototype),{significand:0n,exponent:0}));static ONE=Object.freeze(Object.assign(Object.create(e.prototype),{significand:1n,exponent:0}));static TWO=Object.freeze(Object.assign(Object.create(e.prototype),{significand:2n,exponent:0}));static NEGATIVE_ONE=Object.freeze(Object.assign(Object.create(e.prototype),{significand:-1n,exponent:0}));static HALF=Object.freeze(Object.assign(Object.create(e.prototype),{significand:5n,exponent:-1}));static NAN=Object.freeze(Object.assign(Object.create(e.prototype),{significand:0n,exponent:NaN}));static POSITIVE_INFINITY=Object.freeze(Object.assign(Object.create(e.prototype),{significand:1n,exponent:1/0}));static NEGATIVE_INFINITY=Object.freeze(Object.assign(Object.create(e.prototype),{significand:-1n,exponent:1/0}));static _piFullPrecision=null;static _piCache=null;static _piCachePrecision=0;static get PI(){e._piFullPrecision===null&&(e._piFullPrecision=new e(ft[0]+"."+ft.slice(1)));let n=e.precision;return(e._piCache===null||e._piCachePrecision!==n)&&(e._piCache=e._piFullPrecision.toPrecision(n+4),e._piCachePrecision=n),e._piCache}significand;exponent;constructor(n){if(n instanceof e){this.significand=n.significand,this.exponent=n.exponent;return}if(typeof n=="bigint"){[this.significand,this.exponent]=mt(n,0);return}if(typeof n=="number"){[this.significand,this.exponent]=Ru(n);return}[this.significand,this.exponent]=Fs(n)}isNaN(){return Number.isNaN(this.exponent)}isZero(){return this.exponent===0&&this.significand===0n}isFinite(){return Number.isFinite(this.exponent)}isInteger(){return this.isFinite()&&this.exponent>=0}isPositive(){return this.significand>0n}isNegative(){return this.significand<0n}cmp(n){if(typeof n=="number"){if(Number.isNaN(n))return li;let d=this.exponent;if(Number.isNaN(d))return li;if(n===0)return this.significand===0n?0:this.significand>0n?1:-1;if(!Number.isFinite(d))return n===1/0?this.significand>0n?0:-1:n===-1/0?this.significand<0n?0:1:this.significand>0n?1:-1;if(this.significand===0n)return n>0?-1:1;if(n===1/0)return-1;if(n===-1/0)return 1;if(this.significand>0n!=n>0)return this.significand>0n?1:-1;if(Number.isInteger(n)&&d>=0&&d<=15){let b=this.significand*F(d),v=BigInt(n);return b<v?-1:b>v?1:0}n=new e(n)}let t=this.exponent,i=n.exponent,r=this.significand,s=n.significand;if(t!==t||i!==i)return li;if(!Number.isFinite(t)||!Number.isFinite(i))return!Number.isFinite(t)&&!Number.isFinite(i)?r===s?0:r>s?1:-1:Number.isFinite(t)?s>0n?-1:1:r>0n?1:-1;if(r===0n)return s===0n?0:s>0n?-1:1;if(s===0n)return r>0n?1:-1;if(r>0n&&s<0n)return 1;if(r<0n&&s>0n)return-1;if(t===i)return r<s?-1:r>s?1:0;let o=Q(r),a=Q(s),u=o+t,l=a+i;if(u!==l){let d=r>0n?1:-1;return u>l?d:-d}let c=r,p=s,m=Math.abs(t-i);if(m>1e3){let d=o,b=a,v=Math.max(d,b)+1;d<v&&(c=c*F(v-d)),b<v&&(p=p*F(v-b))}else t<i?p=p*F(m):c=c*F(m);return c<p?-1:c>p?1:0}eq(n){return typeof n=="number"?n===0?this.significand===0n&&this.exponent===0:n===1?this.significand===1n&&this.exponent===0:n===-1?this.significand===-1n&&this.exponent===0:Number.isInteger(n)&&Number.isFinite(this.exponent)&&this.exponent>=0&&this.exponent<=15?this.significand*F(this.exponent)===BigInt(n):this.cmp(n)===0:this.significand===n.significand&&this.exponent===n.exponent}lt(n){return this.cmp(n)===-1}lte(n){let t=this.cmp(n);return t===-1||t===0}gt(n){return this.cmp(n)===1}gte(n){let t=this.cmp(n);return t===1||t===0}add(n){typeof n=="number"&&(n=new e(n));let t=this.exponent,i=n.exponent;if(Number.isFinite(t)&&Number.isFinite(i)){if(t===i)return B(this.significand+n.significand,t);let o=t-i;return o>0?B(this.significand*F(o)+n.significand,i):B(this.significand+n.significand*F(-o),t)}if(t!==t||i!==i)return e.NAN;let r=!Number.isFinite(t),s=!Number.isFinite(i);return r&&s?this.significand!==n.significand?e.NAN:this.significand>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY:r?this.significand>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY:n.significand>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY}sub(n){typeof n=="number"&&(n=new e(n));let t=this.exponent,i=n.exponent;if(Number.isFinite(t)&&Number.isFinite(i)){if(t===i)return B(this.significand-n.significand,t);let o=t-i;return o>0?B(this.significand*F(o)-n.significand,i):B(this.significand-n.significand*F(-o),t)}if(t!==t||i!==i)return e.NAN;let r=!Number.isFinite(t),s=!Number.isFinite(i);return r&&s?this.significand===n.significand?e.NAN:this.significand>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY:r?this.significand>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY:n.significand>0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY}mul(n){typeof n=="number"&&(n=new e(n));let t=this.exponent,i=n.exponent;if(Number.isFinite(t)&&Number.isFinite(i))return B(this.significand*n.significand,t+i);if(t!==t||i!==i||this.significand===0n||n.significand===0n)return e.NAN;let r=this.significand>0n?1n:-1n,s=n.significand>0n?1n:-1n;return r*s>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY}neg(){let n=this.significand;return n===0n?this:Number.isFinite(this.exponent)?B(-n,this.exponent):n>0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY}abs(){return this.significand>=0n?this:Number.isFinite(this.exponent)?B(-this.significand,this.exponent):e.POSITIVE_INFINITY}floor(){let n=this.exponent;if(n>=0)return this;if(Number.isFinite(n)){let t=this.trunc();return this.significand<0n?t.sub(B(1n,0)):t}return this}ceil(){let n=this.exponent;if(n>=0)return this;if(Number.isFinite(n)){let t=this.trunc();return this.significand>0n?t.add(B(1n,0)):t}return this}round(){let n=this.exponent;if(n>=0)return this;if(Number.isFinite(n)){let t=B(5n,-1);return this.significand>0n?this.add(t).trunc():this.sub(t).trunc()}return this}trunc(){let n=this.exponent;if(n>=0)return this;if(Number.isFinite(n)){let t=this.significand/F(-n);return B(t===0n?0n:t,0)}return this}div(n){typeof n=="number"&&(n=new e(n));let t=this.exponent,i=n.exponent,r=this.significand,s=n.significand;if(Number.isFinite(t)&&Number.isFinite(i)){if(s===0n)return r===0n?e.NAN:r>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY;if(r===0n)return B(0n,0);let u=e.precision,l=10,c=r<0n?-r:r,p=s<0n?-s:s,m=Q(c),d=Q(p),b=u+l+Math.max(0,d-m),v=F(b),k=r*v/s,w=t-i-b;return B(k,w).toPrecision(u)}if(t!==t||i!==i)return e.NAN;let o=!Number.isFinite(t),a=!Number.isFinite(i);if(o&&a)return e.NAN;if(o){let u=r>0n?1n:-1n,l=s>0n?1n:s<0n?-1n:1n;return u*l>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY}return B(0n,0)}inv(){return B(1n,0).div(this)}mod(n){typeof n=="number"&&(n=new e(n));let t=this.exponent,i=n.exponent;return Number.isFinite(t)&&Number.isFinite(i)?n.significand===0n?e.NAN:this.significand===0n?B(0n,0):this.sub(this.div(n).trunc().mul(n)).toPrecision(e.precision):t!==t||i!==i||!Number.isFinite(t)?e.NAN:new e(this)}pow(n){if(typeof n=="number"&&(n=new e(n)),this.isNaN()||n.isNaN()||!n.isFinite())return e.NAN;if(n.isInteger()){let t=n.toBigInt();if(t===0n)return B(1n,0);if(!this.isFinite())return t>0n?this.significand<0n&&t%2n!==0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY:B(0n,0);if(this.isZero())return t>0n?B(0n,0):e.POSITIVE_INFINITY;if(t<0n)return this.pow(n.neg()).inv();let i=this.significand<0n?-this.significand:this.significand,r=Q(i)+this.exponent,s=Number(t)*r;if(s>9e15)return this.significand<0n&&t%2n!==0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY;if(s<-9e15)return B(0n,0);let o=e.precision,a=B(1n,0),u=this,l=t;for(;l>0n;)l&1n&&(a=a.mul(u).toPrecision(o)),l>>=1n,l>0n&&(u=u.mul(u).toPrecision(o));return a}return this.isFinite()?this.isZero()?n.significand>0n?e.ZERO:e.POSITIVE_INFINITY:this.significand<0n?e.NAN:n.mul(this.ln()).exp():this.significand<0n?e.NAN:n.significand>0n?e.POSITIVE_INFINITY:e.ZERO}toNumber(){return Number.isFinite(this.exponent)?this.significand===0n?0:this.exponent===0?Number(this.significand):Number(this.toString()):this.exponent!==this.exponent?NaN:this.significand>0n?1/0:-1/0}toString(){if(!Number.isFinite(this.exponent))return this.exponent!==this.exponent?"NaN":this.significand>0n?"Infinity":"-Infinity";if(this.significand===0n)return"0";let n=this.significand<0n,t=(n?-this.significand:this.significand).toString(),i=t.length,r=i+this.exponent-1,s=n?"-":"";if(r>20||r<-6){let u=i===1?t:t[0]+"."+t.slice(1),l=r>=0?"+":"";return`${s}${u}e${l}${r}`}if(this.exponent>=0)return s+t+"0".repeat(this.exponent);let o=-this.exponent;if(o<i){let u=t.slice(0,i-o),l=t.slice(i-o);return`${s}${u}.${l}`}let a=o-i;return`${s}0.${"0".repeat(a)}${t}`}toFixed(n){let t=n??0;if(!Number.isFinite(this.exponent))return this.exponent!==this.exponent?"NaN":this.significand>0n?"Infinity":"-Infinity";let i=this.significand<0n,r=i?-this.significand:this.significand,s=this.exponent+t,o;if(s>=0)o=r*F(s);else{let p=F(-s),m=r/p,d=r%p,b=p/2n;d>b?o=m+1n:d<b||p%2n!==0n||m%2n===0n?o=m:o=m+1n}let a=i&&o!==0n?"-":"",u=o.toString();if(t===0)return`${a}${u}`;if(u.length<=t){let p=u.padStart(t,"0");return`${a}0.${p}`}let l=u.slice(0,u.length-t),c=u.slice(u.length-t);return`${a}${l}.${c}`}toPrecision(n){if(this.significand===0n||!Number.isFinite(this.exponent))return this;let t=this.significand<0n?-this.significand:this.significand,i=Q(t);if(i<=n)return this;let r=i-n,s=F(r),o=t/s,a=t%s,u=s/2n;(a>u||a===u&&o%2n!==0n)&&(o+=1n);let l=this.significand<0n?-o:o;return B(l,this.exponent+r)}toBigInt(){if(!Number.isFinite(this.exponent))throw this.exponent!==this.exponent?new RangeError("Cannot convert NaN to BigInt"):new RangeError("Cannot convert Infinity to BigInt");if(this.exponent>=0)return this.significand*F(this.exponent);let n=F(-this.exponent);return this.significand/n}};function B(e,n){let[t,i]=mt(e,n),r=Object.create(x.prototype);return r.significand=t,r.exponent=i,r}var Ds=1000000000n,Ps=1000n;function mt(e,n){if(e===0n)return[0n,0];for(;e%Ds===0n;)e/=Ds,n+=9;for(;e%Ps===0n;)e/=Ps,n+=3;for(;e%10n===0n;)e/=10n,n+=1;return[e,n]}function Ru(e){return Number.isNaN(e)?[0n,NaN]:e===1/0?[1n,1/0]:e===-1/0?[-1n,1/0]:Number.isInteger(e)?mt(BigInt(e),0):Fs(e.toString())}function Fs(e){if(e=e.trim(),e===""||e==="NaN")return[0n,NaN];if(e==="Infinity"||e==="+Infinity")return[1n,1/0];if(e==="-Infinity")return[-1n,1/0];let n,t=0,i=e.search(/[eE]/);if(i!==-1){if(n=e.slice(0,i),t=Number(e.slice(i+1)),!Number.isFinite(t))return[0n,NaN]}else n=e;let r=!1;n.startsWith("-")?(r=!0,n=n.slice(1)):n.startsWith("+")&&(n=n.slice(1));let s=n.indexOf("."),o,a;s===-1?(o=n,a=""):(o=n.slice(0,s),a=n.slice(s+1)),o=o.replace(/^0+/,"")||"0";let u=o+a;if(u.length===0||!/^\d+$/.test(u))return[0n,NaN];let l=BigInt(u);r&&(l=-l);let c=-a.length;return mt(l,c+t)}function Ae(e,n){let t=F(n),i=e.exponent+n;return i>=0?[e.significand*F(i),t]:[e.significand/F(-i),t]}function $e(e,n,t){if(e===0n)return x.ZERO;let i=e<0n,r=i?-e:e,s=Q(r);if(s>t){let l=s-t,c=F(l),p=c/2n,m=r%c;r=r/c,m>=p&&(r+=1n);let d=Q(n)-1,b=l-d,v=i?-r:r;return B(v,b)}let a=-(Q(n)-1),u=i?-r:r;return B(u,a)}x.prototype.sqrt=function(){if(this.isNaN())return x.NAN;if(this.isZero())return x.ZERO;if(!this.isFinite())return this.significand>0n?x.POSITIVE_INFINITY:x.NAN;if(this.significand<0n)return x.NAN;let e=x.precision,n=e+10,[t,i]=Ae(this,n),r=Pn(t,i);return $e(r,i,e)};x.prototype.cbrt=function(){if(this.isNaN())return x.NAN;if(this.isZero())return x.ZERO;if(!this.isFinite())return this.significand>0n?x.POSITIVE_INFINITY:x.NEGATIVE_INFINITY;if(this.significand<0n)return this.neg().cbrt().neg();let e=x.precision,n=e+10,[t,i]=Ae(this,n),r=t*i*i,s,o=this.toNumber(),a=Number(i);if(Number.isFinite(o)&&o>0&&Number.isFinite(a)){let l=Math.cbrt(o);Number.isFinite(l)&&l>0?(s=BigInt(Math.floor(l*a)),s===0n&&(s=1n)):s=Os(t,i)}else s=Os(t,i);let u;do{u=s;let l=s*s;if(l===0n){s=1n;break}s=(2n*s+r/l)/3n}while(xe(s-u)>1n);{let l=(2n*s+r/(s*s))/3n,c=xe(s*s*s-r);xe(l*l*l-r)<c&&(s=l)}return $e(s,i,e)};x.sqrt=function(e){return e.sqrt()};x.cbrt=function(e){return e.cbrt()};x.prototype.exp=function(){if(this.isNaN())return x.NAN;if(!this.isFinite())return this.significand>0n?x.POSITIVE_INFINITY:x.ZERO;if(this.isZero())return x.ONE;let e=x.precision,n=e+15,[t,i]=Ae(this,n),r=ui(t,i);return $e(r,i,e)};x.prototype.ln=function(){if(this.isNaN())return x.NAN;if(!this.isFinite())return this.significand>0n?x.POSITIVE_INFINITY:x.NAN;if(this.isZero())return x.NEGATIVE_INFINITY;if(this.significand<0n)return x.NAN;if(this.eq(1))return x.ZERO;let e=x.precision,n=e+15,[t,i]=Ae(this,n),r=Rs(t,i);return $e(r,i,e)};x.prototype.log=function(e){let n=e instanceof x?e:new x(e);return this.ln().div(n.ln())};x.exp=function(e){return e.exp()};x.ln=function(e){return e.ln()};x.log10=function(e){return e.log(10)};x.prototype.sin=function(){if(this.isNaN())return x.NAN;if(!this.isFinite())return x.NAN;if(this.isZero())return x.ZERO;let e=x.precision,n=e+15,[t,i]=Ae(this,n),[r]=pt(t,i);return $e(r,i,e)};x.prototype.cos=function(){if(this.isNaN())return x.NAN;if(!this.isFinite())return x.NAN;if(this.isZero())return x.ONE;let e=x.precision,n=e+15,[t,i]=Ae(this,n),[,r]=pt(t,i);return $e(r,i,e)};x.prototype.tan=function(){if(this.isNaN())return x.NAN;if(!this.isFinite())return x.NAN;if(this.isZero())return x.ZERO;let e=x.precision,n=e+15,[t,i]=Ae(this,n),[r,s]=pt(t,i);if(s===0n)return r>0n?x.POSITIVE_INFINITY:x.NEGATIVE_INFINITY;let o=r*i/s;return $e(o,i,e)};x.prototype.atan=function(){if(this.isNaN())return x.NAN;if(this.isZero())return x.ZERO;if(!this.isFinite()){let s=x.PI.div(x.TWO);return this.significand>0n?s:s.neg()}let e=x.precision,n=e+15,[t,i]=Ae(this,n),r=Dn(t,i);return $e(r,i,e)};x.prototype.asin=function(){if(this.isNaN())return x.NAN;if(!this.isFinite())return x.NAN;if(this.isZero())return x.ZERO;let e=this.abs(),n=x.ONE;if(e.gt(n))return x.NAN;if(e.eq(n)){let p=x.PI.div(x.TWO);return this.significand>0n?p:p.neg()}let t=x.precision,i=t+20,[r,s]=Ae(this,i),o=$s(r,r,s),a=s-o,u=Pn(a,s),l=Cs(r,u,s),c=Dn(l,s);return $e(c,s,t)};x.prototype.acos=function(){return this.isNaN()?x.NAN:this.isFinite()?this.abs().gt(x.ONE)?x.NAN:this.eq(1)?x.ZERO:this.eq(-1)?x.PI:x.PI.div(x.TWO).sub(this.asin()):x.NAN};x.sin=function(e){return e.sin()};x.cos=function(e){return e.cos()};x.tan=function(e){return e.tan()};x.asin=function(e){return e.asin()};x.acos=function(e){return e.acos()};x.atan=function(e){return e.atan()};x.atan2=function(e,n){let t=e instanceof x?e:new x(e);if(t.isNaN()||n.isNaN())return x.NAN;let i=x.PI,r=i.div(x.TWO);if(n.isZero())return t.isZero()?x.ZERO:t.significand>0n?r:r.neg();let s=t.div(n);return n.significand>0n?s.atan():t.significand>=0n?s.atan().add(i):s.atan().sub(i)};x.prototype.sinh=function(){if(this.isNaN())return x.NAN;if(this.isZero())return x.ZERO;if(!this.isFinite())return this.significand>0n?x.POSITIVE_INFINITY:x.NEGATIVE_INFINITY;let e=this.exp(),n=e.inv();return e.sub(n).div(x.TWO)};x.prototype.cosh=function(){if(this.isNaN())return x.NAN;if(this.isZero())return x.ONE;if(!this.isFinite())return x.POSITIVE_INFINITY;let e=this.exp(),n=e.inv();return e.add(n).div(x.TWO)};x.prototype.tanh=function(){if(this.isNaN())return x.NAN;if(this.isZero())return x.ZERO;if(!this.isFinite())return this.significand>0n?x.ONE:x.NEGATIVE_ONE;let e=this.mul(x.TWO).exp();return e.sub(x.ONE).div(e.add(x.ONE))};x.sinh=function(e){return e.sinh()};x.cosh=function(e){return e.cosh()};x.tanh=function(e){return e.tanh()};function Os(e,n){let i=Q(e),r=Math.max(0,i-15),s=Number(r>0?e/F(r):e),o=Q(n),a=Math.max(0,o-15),u=Number(a>0?n/F(a):n),l=r+2*a,c=Math.floor(l/3),p=l%3,m=Math.cbrt(s*u*u);p===1&&(m*=2.154434690031882),p===2&&(m*=4.641588833612779);let d=BigInt(Math.round(m))*F(c);return d>0n?d:1n}var lp=[BigInt(4),BigInt(2),BigInt(4),BigInt(2),BigInt(4),BigInt(6),BigInt(2),BigInt(6)];var Du=53,Ls=Math.floor(Math.log10(Math.pow(2,Du))),Pu=1e-10;var ci=1e4;function Ne(e,n){if(e===0)return n;if(n===0||e===n)return e;if(!Number.isInteger(e)||!Number.isInteger(n))return NaN;for(;n!==0;)[e,n]=[n,e%n];return e<0?-e:e}function Ge(e,n){if(e===0||n===0)return 0;let t=BigInt(e)*BigInt(n)/BigInt(Ne(e,n));return Number(t)}function On(e){if(!Number.isInteger(e)||e<0)return NaN;if(e>=170)return 1/0;let n=1;for(let t=2;t<=e;t++)n=n*t;return n}function Ln(e){if(!Number.isInteger(e)||e<0)return NaN;if(e<0)return NaN;if(e<=1)return 1;let n=e;for(;e>2;)e-=2,n*=e;return n}function Bn(e,n=Pu){return typeof e=="number"&&Math.abs(e)<=n?0:e}function dt(e,n,t=1){if(t===0){let s=dt(e,n,-1),o=dt(e,n,1);return s===void 0||o===void 0?NaN:Math.abs(s-o)>1e-5?NaN:(s+o)/2}let[i,r]=si(e,n,{step:t>0?1:-1});return i}var cn=["number","finite_number","complex","finite_complex","imaginary","real","finite_real","rational","finite_rational","integer","finite_integer","non_finite_number"],fi=["indexed_collection","list","tuple"],ht=[...fi,"collection","set","record","dictionary"],gt=["scalar",...cn,"boolean","string"],pi=["value",...ht,...gt],mi=["expression","symbol","function",...pi],je=["any","unknown","nothing","never","error",...mi];function bt(e){return typeof e=="string"?je.includes(e):typeof e!="object"||!("kind"in e)?!1:e.kind==="signature"||e.kind==="union"||e.kind==="intersection"||e.kind==="negation"||e.kind==="tuple"||e.kind==="list"||e.kind==="record"||e.kind==="dictionary"||e.kind==="set"||e.kind==="function"||e.kind==="collection"||e.kind==="indexed_collection"||e.kind==="reference"}var Vs=3,Js=1,qs=2,Fu=4,Ou=5,Lu=6,Bu=7,Vu=8,Ju=9,qu=10,zu=11;function q(e,n=0){if(typeof e=="string")return e;let t="";switch(e.kind){case"value":typeof e.value=="string"?t=`"${e.value}"`:typeof e.value=="boolean"?t=e.value?"true":"false":t=e.value.toString();break;case"reference":t=e.name;break;case"negation":t=`!${q(e.type,Vs)}`;break;case"union":t=e.types.map(u=>q(u,Js)).join(" | ");break;case"intersection":t=e.types.map(u=>q(u,qs)).join(" & ");break;case"expression":t=`expression<${Bs(e.operator)}>`;break;case"symbol":t=`symbol<${Bs(e.name)}>`;break;case"numeric":Number.isFinite(e.lower)&&Number.isFinite(e.upper)?t=`${e.type}<${e.lower}..${e.upper}>`:Number.isFinite(e.lower)?t=`${e.type}<${e.lower}..>`:Number.isFinite(e.upper)?t=`${e.type}<..${e.upper}>`:t=`${e.type}`;break;case"list":if(e.dimensions&&typeof e.elements=="string"&&cn.includes(e.elements)){if(e.dimensions===void 0)e.elements==="number"&&(t="tensor");else if(e.dimensions.length===1)e.elements==="number"?e.dimensions[0]<0?t="vector":t=`vector<${e.dimensions[0]}>`:e.dimensions[0]<0?t=`vector<${q(e.elements)}>`:t=`vector<${q(e.elements)}^${e.dimensions[0]}>`;else if(e.dimensions.length===2){let u=e.dimensions;e.elements==="number"?u[0]<0&&u[1]<0?t="matrix":t=`matrix<${u[0]}x${u[1]}>`:u[0]<0&&u[1]<0?t=`matrix<${q(e.elements)}>`:t=`matrix<${q(e.elements)}^(${u[0]}x${u[1]})>`}}if(!t){let u=e.dimensions?e.dimensions.length===1?`^${e.dimensions[0].toString()}`:`^(${e.dimensions.join("x")})`:"";t=`list<${q(e.elements)}${u}>`}break;case"record":t=`record<${Object.entries(e.elements).map(([u,l])=>`${u}: ${q(l)}`).join(", ")}>`;break;case"dictionary":t=`dictionary<${q(e.values)}>`;break;case"set":t=`set<${q(e.elements)}>`;break;case"collection":t=`collection<${q(e.elements)}>`;break;case"indexed_collection":t=`indexed_collection<${q(e.elements)}>`;break;case"tuple":if(e.elements.length===0)t="tuple";else if(e.elements.length===1){let[u]=e.elements;t=`tuple<${fn(u)}>`}else t="tuple<"+e.elements.map(u=>fn(u)).join(", ")+">";break;case"signature":let r=e.args?e.args.map(u=>fn(u)).join(", "):"",s=e.optArgs?e.optArgs.map(u=>fn(u)+"?").join(", "):"",o=e.variadicArg?e.variadicMin===0?`${fn(e.variadicArg)}*`:`${fn(e.variadicArg)}+`:"";t=`(${[r,s,o].filter(u=>u).join(", ")}) -> ${q(e.result)}`;break;default:t="error"}return n>0&&n>Gu(e.kind)?`(${t})`:t}function fn(e){return e.name?`${e.name}: ${q(e.type)}`:q(e.type)}function Bs(e){return/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)?e:`\`${e}\``}function Gu(e){switch(e){case"negation":return Vs;case"union":return Js;case"intersection":return qs;case"list":return Fu;case"record":return Ou;case"dictionary":return Lu;case"set":return Bu;case"collection":case"indexed_collection":return Vu;case"tuple":return Ju;case"signature":return qu;case"value":return zu;default:return 0}}function ju(e,n){if(e===n)return 0;if(e.length===0)return n.length;if(n.length===0)return e.length;let t=Array.from({length:e.length+1},(r,s)=>s),i=new Array(e.length+1);for(let r=1;r<=n.length;r++){i[0]=r;for(let s=1;s<=e.length;s++){let o=e[s-1]===n[r-1]?0:1;i[s]=Math.min(t[s]+1,i[s-1]+1,t[s-1]+o)}[t,i]=[i,t]}return t[e.length]}function yt(e,n){let i=null,r=1/0,s=e.length;for(let o of n){if(Math.abs(s-o.length)>7)continue;let a=ju(e,o);if(a===0)return o;a<=7&&a<r&&(r=a,i=o)}return i}var xt=class{input;pos=0;line=1;column=1;tokens=[];constructor(n){this.input=n}saveState(){return{pos:this.pos,line:this.line,column:this.column,tokens:[...this.tokens]}}restoreState(n){this.pos=n.pos,this.line=n.line,this.column=n.column,this.tokens=n.tokens}error(n){throw new Error(`Lexer error at line ${this.line}, column ${this.column}: ${n}`)}peek(n=0){let t=this.pos+n;return t<this.input.length?this.input[t]:""}advance(){let n=this.input[this.pos++];return n===`
|
|
3
|
+
`?(this.line++,this.column=1):this.column++,n}match(n){if(this.input.slice(this.pos,this.pos+n.length)===n){for(let t=0;t<n.length;t++)this.advance();return!0}return!1}isEOF(){return this.pos>=this.input.length}skipWhitespace(){for(;!this.isEOF()&&/\s/.test(this.peek());)this.advance()}readIdentifier(){let n="";for(;!this.isEOF()&&/[a-zA-Z0-9_]/.test(this.peek());)n+=this.advance();return n}readVerbatimString(){if(!this.match("`"))return"";let n="";for(;!this.isEOF()&&this.peek()!=="`";)this.match("\\`")?n+="`":this.match("\\\\")?n+="\\":n+=this.advance();return this.isEOF()&&this.error("Unterminated verbatim string"),this.advance(),n}readStringLiteral(){let n=this.advance(),t="";for(;!this.isEOF()&&this.peek()!==n;)this.match("\\"+n)?t+=n:this.match("\\\\")?t+="\\":t+=this.advance();return this.isEOF()&&this.error("Unterminated string literal"),this.advance(),t}readNumber(){let n="";if((this.peek()==="-"||this.peek()==="+")&&(n+=this.advance()),this.match("0x")||this.match("0X")){for(n+="x";!this.isEOF()&&/[0-9a-fA-F]/.test(this.peek());)n+=this.advance();return"0"+n}if(this.match("0b")||this.match("0B")){for(n+="b";!this.isEOF()&&/[01]/.test(this.peek());)n+=this.advance();return"0"+n}for(;!this.isEOF()&&/[0-9]/.test(this.peek());)n+=this.advance();if(this.peek()==="."&&/[0-9]/.test(this.peek(1)))for(n+=this.advance();!this.isEOF()&&/[0-9]/.test(this.peek());)n+=this.advance();if(this.peek()==="e"||this.peek()==="E")for(n+=this.advance(),(this.peek()==="+"||this.peek()==="-")&&(n+=this.advance());!this.isEOF()&&/[0-9]/.test(this.peek());)n+=this.advance();return n}createToken(n,t){return{type:n,value:t,position:this.pos-t.length,line:this.line,column:this.column-t.length}}nextToken(){if(this.skipWhitespace(),this.isEOF())return this.createToken("EOF","");let n=this.pos,t=this.peek();if(this.match("->"))return this.createToken("->","->");if(this.match(".."))return this.createToken("..","..");if(this.match("+\u221E")||this.match("+oo"))return this.createToken("PLUS_INFINITY",this.input.slice(n,this.pos));if(this.match("-\u221E")||this.match("-oo"))return this.createToken("MINUS_INFINITY",this.input.slice(n,this.pos));if(this.match("+infinity"))return this.createToken("PLUS_INFINITY","+infinity");if(this.match("-infinity"))return this.createToken("MINUS_INFINITY","-infinity");if(/[a-zA-Z_]/.test(t)){let i=this.readIdentifier();switch(i){case"true":return this.createToken("TRUE",i);case"false":return this.createToken("FALSE",i);case"nan":return this.createToken("NAN",i);case"infinity":return this.createToken("INFINITY",i);case"oo":return this.createToken("INFINITY",i);default:return this.createToken("IDENTIFIER",i)}}switch(t){case"|":return this.advance(),this.createToken("|","|");case"&":return this.advance(),this.createToken("&","&");case"!":return this.advance(),this.createToken("!","!");case"^":return this.advance(),this.createToken("^","^");case"(":return this.advance(),this.createToken("(","(");case")":return this.advance(),this.createToken(")",")");case"<":return this.advance(),this.createToken("<","<");case">":return this.advance(),this.createToken(">",">");case"[":return this.advance(),this.createToken("[","[");case"]":return this.advance(),this.createToken("]","]");case",":return this.advance(),this.createToken(",",",");case":":return this.advance(),this.createToken(":",":");case"?":return this.advance(),this.createToken("?","?");case"*":return this.advance(),this.createToken("*","*");case"+":return/[0-9]/.test(this.peek(1))?this.createToken("NUMBER_LITERAL",this.readNumber()):(this.advance(),this.createToken("+","+"));case"x":return/[0-9]/.test(this.peek(1))?(this.advance(),this.createToken("x","x")):(this.advance(),this.createToken("x","x"))}if(t==='"'||t==="'")return this.createToken("STRING_LITERAL",this.readStringLiteral());if(t==="`")return this.createToken("VERBATIM_STRING",this.readVerbatimString());if(/[0-9]/.test(t)||t==="-"&&/[0-9]/.test(this.peek(1))){let i=this.readNumber();return this.peek()==="x"&&/[0-9]/.test(this.peek(1)),this.createToken("NUMBER_LITERAL",i)}if(t==="\u221E")return this.advance(),this.createToken("INFINITY","\u221E");this.error(`Unexpected character: ${t}`)}tokenize(){let n=[];for(;!this.isEOF();){let t=this.nextToken();if(t&&(n.push(t),t.type==="EOF"))break}return n}peekToken(){if(this.tokens.length===0){let n=this.nextToken();n&&this.tokens.push(n)}return this.tokens[0]||this.createToken("EOF","")}consumeToken(){if(this.tokens.length===0){let n=this.nextToken();if(n)return n}return this.tokens.shift()||this.createToken("EOF","")}matchToken(n){return this.peekToken().type===n?(this.consumeToken(),!0):!1}expectToken(n){let t=this.consumeToken();return t.type!==n&&this.error(`Expected ${n}, got ${t.type}`),t}};var Et=class{lexer;typeResolver;current;constructor(n,t){this.lexer=new xt(n),this.typeResolver=t?.typeResolver??{forward:()=>{},resolve:()=>{},get names(){return[]}},this.current=this.lexer.consumeToken()}error(n,t){this.errorAtToken(this.current,n,t)}errorAtToken(n,t,i){let r=this.lexer.input,o=r.split(`
|
|
4
|
+
`)[n.line-1]||r,a=n.column,u=" ".repeat(Math.max(0,a-1))+"^",l=["","Invalid type",`| ${o}`,`| ${u}`,"|",`| ${t}`];throw i&&l.push(`| ${i}`),l.push(""),new Error(l.join(`
|
|
5
|
+
`))}advance(){let n=this.current;return this.current=this.lexer.consumeToken(),n}match(n){return this.current.type===n?(this.advance(),!0):!1}expect(n){return this.current.type!==n&&this.error(`Expected ${n}, got ${this.current.type}`),this.advance()}createNode(n,t={}){return{kind:n,position:this.current.position,line:this.current.line,column:this.current.column,...t}}parseType(){this.checkForNakedFunctionSignature();let n=this.parseUnionType();if(n||this.error("Expected a type"),this.current.type!=="EOF")if(this.current.type==="->"||this.current.type==="+"||this.current.type==="*"||this.current.type==="?")this.error("Function signatures must be enclosed in parentheses","For example `(x: number) -> number`");else if(this.current.type==="("){let t=this.lexer.input;t.includes("set(")||t.includes("collection(")||t.includes("list(")||t.includes("tuple(")?t.includes("set(")?this.error("Use `set<integer>` instead of `set(integer)`."):t.includes("collection(")?this.error("Use `collection<type>` instead of `collection(type)`.","For example `collection<number>`"):t.includes("list(")?this.error("Use `list<type>` instead of `list(type)`.","For example `list<number>`"):t.includes("tuple(")&&this.error("Use `tuple<type1, type2>` instead of `tuple(type1, type2)`.","For example `tuple<string, number>`"):this.error("Unexpected token after type")}else this.error("Unexpected token after type");return n}checkForNakedFunctionSignature(){if(this.current.type==="IDENTIFIER"){let n=this.lexer.saveState(),t=this.current;try{let i=this.current;if(this.advance(),this.current.type===":"){this.advance();let r=!1,s=0,o=10;for(;this.current.type!=="EOF"&&s<o;){if(this.current.type==="->"){r=!0;break}if(this.current.type==="+"||this.current.type==="*"||this.current.type==="?"){if(this.advance(),this.current.type==="->"){r=!0;break}s++}this.advance(),s++}r&&(this.lexer.restoreState(n),this.current=t,this.errorAtToken(i,"Function signatures must be enclosed in parentheses","For example `(z: string*) -> boolean`"))}this.lexer.restoreState(n),this.current=t}catch(i){if(this.lexer.restoreState(n),this.current=t,i instanceof Error&&i.message.includes("Function signatures must be enclosed"))throw i}}}parseUnionType(){let n=this.parseIntersectionType();if(!n)return;let t=[n];for(;this.match("|");){let i=this.parseIntersectionType();i||this.error("Expected type after |"),t.push(i)}return t.length===1?t[0]:this.createNode("union",{types:t})}parseIntersectionType(){let n=this.parsePrimaryType();if(!n)return;let t=[n];for(;this.match("&");){let i=this.parsePrimaryType();i||this.error("Expected type after &"),t.push(i)}return t.length===1?t[0]:this.createNode("intersection",{types:t})}parsePrimaryType(){if(this.match("!")){let n=this.parsePrimaryType();return n||this.error("Expected type after !"),this.createNode("negation",{type:n})}if(this.current.type==="("){let n=this.parseFunctionSignature();if(n)return n;if(this.match("(")){let t=this.parseUnionType();if(t||this.error("Expected type after ("),this.current.type===","){let i=[this.createNode("named_element",{name:void 0,type:t})];for(;this.match(",");){let r=this.parseUnionType();r||this.error("Expected type after ,"),i.push(this.createNode("named_element",{name:void 0,type:r}))}return this.expect(")"),this.createNode("tuple",{elements:i})}return this.expect(")"),this.createNode("group",{type:t})}}return this.parseListType()||this.parseTupleType()||this.parseRecordType()||this.parseDictionaryType()||this.parseSetType()||this.parseCollectionType()||this.parseExpressionType()||this.parseSymbolType()||this.parseNumericType()||this.parsePrimitiveType()||this.parseValue()||this.parseTypeReference()}isFunctionSignature(){let n=this.lexer.saveState(),t=this.current;this.advance();let i=1;for(;i>0&&this.current.type!=="EOF";)this.current.type==="("?i++:this.current.type===")"&&i--,this.advance();let r=this.current.type==="->";return this.lexer.restoreState(n),this.current=t,r}parseFunctionSignature(){if(this.current.type!=="("||!this.isFunctionSignature())return;let n=[];if(this.advance(),!this.match(")")){do{let o=this.parseArgument();o||this.error("Expected argument"),n.push(o)}while(this.match(","));this.expect(")")}this.expect("->");let t=this.parseUnionType();t||this.error("Expected return type after ->");let i=n.some(o=>o.modifier==="optional"),r=n.some(o=>o.modifier==="variadic_zero"||o.modifier==="variadic_one"),s=n.filter(o=>o.modifier==="variadic_zero"||o.modifier==="variadic_one").length;return i&&r&&this.error("Variadic arguments cannot be used with optional arguments"),s>1&&this.error("There can be only one variadic argument"),this.createNode("function_signature",{arguments:n,returnType:t})}parseArgument(){let n=this.parseNamedElement();if(!n)return;let t;return this.match("?")?t="optional":this.match("*")?t="variadic_zero":this.match("+")&&(t="variadic_one"),this.createNode("argument",{element:n,modifier:t})}parseNamedElement(){let n;if(this.current.type==="IDENTIFIER"||this.current.type==="VERBATIM_STRING"){let i=this.current;if(this.lexer.peekToken().type===":"){n=i.value,this.advance(),this.advance();let s=this.parseUnionType();return s?this.createNode("named_element",{name:n,type:s}):void 0}}let t=this.parseUnionType();if(t)return this.createNode("named_element",{name:void 0,type:t})}parseListType(){if(this.current.type==="IDENTIFIER"){let n=this.current,i=this.lexer.peekToken().type==="<";switch(n.value){case"list":return i?(this.advance(),this.parseListTypeImpl()):void 0;case"vector":return i?(this.advance(),this.parseVectorType()):(this.advance(),this.createNode("list",{elementType:this.createNode("primitive",{name:"number"}),dimensions:void 0}));case"matrix":return i?(this.advance(),this.parseMatrixType()):(this.advance(),this.createNode("matrix",{elementType:this.createNode("primitive",{name:"number"}),dimensions:[this.createNode("dimension",{size:-1}),this.createNode("dimension",{size:-1})]}));case"tensor":return i?(this.advance(),this.parseTensorType()):(this.advance(),this.createNode("list",{elementType:this.createNode("primitive",{name:"number"}),dimensions:void 0}));default:return}}}parseListTypeImpl(){let n=this.createNode("primitive",{name:"any"}),t;if(this.match("<")){if(t=this.parseDimensionWithX(),t||(t=this.parseDimensions()),!t){let i=this.parseUnionType();i&&(n=i,this.match("^")&&(t=this.parseDimensionWithX(),t||(t=this.parseDimensions())))}this.expect(">")}return this.createNode("list",{elementType:n,dimensions:t})}parseVectorType(){let n=this.createNode("primitive",{name:"number"}),t;if(this.match("<")){if(this.current.type==="NUMBER_LITERAL")t=parseInt(this.advance().value);else{let i=this.parseUnionType();i&&(n=i,this.match("^")&&(this.current.type==="NUMBER_LITERAL"?t=parseInt(this.advance().value):this.error("Expected number after ^")))}this.expect(">")}return this.createNode("vector",{elementType:n,size:t})}parseMatrixType(){let n=this.createNode("primitive",{name:"number"}),t;if(this.match("<")){if(t=this.parseDimensionWithX(),t||(t=this.parseDimensions()),!t){let i=this.parseUnionType();i&&(n=i,this.match("^")&&(t=this.parseDimensionWithX(),t||(t=this.parseDimensions())))}this.expect(">")}else t=[this.createNode("dimension",{size:null}),this.createNode("dimension",{size:null})];return this.createNode("matrix",{elementType:n,dimensions:t})}parseTensorType(){let n=this.createNode("primitive",{name:"number"});if(this.match("<")){let t=this.parseUnionType();t&&(n=t),this.expect(">")}return this.createNode("tensor",{elementType:n})}parseDimensions(){let n=[],t=this.parseDimension();if(t){for(n.push(t);this.match("x");){let i=this.parseDimension();i||this.error("Expected dimension after x"),n.push(i)}return n}}parseDimension(){if(this.match("?"))return this.createNode("dimension",{size:null});if(this.current.type==="NUMBER_LITERAL"){let n=parseInt(this.advance().value);return this.createNode("dimension",{size:n})}}parseDimensionWithX(){if(this.current.type==="NUMBER_LITERAL"){let n=[],t=parseInt(this.advance().value);if(n.push(this.createNode("dimension",{size:t})),this.current.type==="IDENTIFIER"&&this.current.value.startsWith("x")){let i=this.current.value,r=i.match(/x(\d+)/g);if(r&&r.join("")===i){this.advance();for(let s of r){let o=parseInt(s.substring(1));n.push(this.createNode("dimension",{size:o}))}}else(i==="x"||i.startsWith("x"))&&this.error("Expected a positive integer literal or `?` after x. For example: `2x3` or `2x?`")}if(n.length>1)return n}}parseTupleType(){if(this.current.type==="IDENTIFIER"&&this.current.value==="tuple"){if(this.lexer.peekToken().type!=="<")return;this.advance(),this.expect("<");let t=[];if(this.current.type!==">"){let i=this.parseNamedElement();i||this.error("Expected tuple element"),t.push(i);let r=i.name!==void 0;for(;this.match(",");){let s=this.parseNamedElement();s||this.error("Expected tuple element"),r&&!s.name&&this.error("All tuple elements should be named, or none. Previous elements were named, but this one isn't."),!r&&s.name&&this.error("All tuple elements should be named, or none. Previous elements were not named, but this one is."),t.push(s)}}return this.expect(">"),this.createNode("tuple",{elements:t})}}parseRecordType(){if(this.current.type==="IDENTIFIER"&&this.current.value==="record"){this.advance();let n=[];if(this.match("<")){if(this.current.type!==">")do{let t=this.parseRecordEntry();t||this.error("Expected record entry"),n.push(t)}while(this.match(","));this.expect(">")}return this.createNode("record",{entries:n})}}parseRecordEntry(){let n;if(this.current.type==="IDENTIFIER")n=this.advance().value;else if(this.current.type==="VERBATIM_STRING")n=this.advance().value;else return;this.expect(":");let t=this.parseUnionType();return t||this.error("Expected value type"),this.createNode("record_entry",{key:n,valueType:t})}parseDictionaryType(){if(this.current.type==="IDENTIFIER"&&this.current.value==="dictionary"){this.advance();let n=this.createNode("primitive",{name:"any"});if(this.match("<")){let t=this.parseUnionType();t&&(n=t),this.expect(">")}return this.createNode("dictionary",{valueType:n})}}parseSetType(){if(this.current.type==="IDENTIFIER"&&this.current.value==="set"){this.advance();let n=this.createNode("primitive",{name:"any"});if(this.match("<")){let t=this.parseUnionType();t&&(n=t),this.expect(">")}return this.createNode("set",{elementType:n})}}parseCollectionType(){if(this.current.type==="IDENTIFIER"){let n=this.current.value==="indexed_collection",t=this.current.value==="collection";if(n||t){this.advance();let i=this.createNode("primitive",{name:"any"});if(this.match("<")){let r=this.parseUnionType();r&&(i=r),this.expect(">")}return this.createNode("collection",{elementType:i,indexed:n})}}}parseExpressionType(){if(this.current.type==="IDENTIFIER"&&this.current.value==="expression"){if(this.lexer.peekToken().type!=="<")return;this.advance(),this.expect("<");let i=this.expect("IDENTIFIER").value;return this.expect(">"),this.createNode("expression",{operator:i})}}parseSymbolType(){if(this.current.type==="IDENTIFIER"&&this.current.value==="symbol"){if(this.lexer.peekToken().type!=="<")return;this.advance(),this.expect("<");let i=this.expect("IDENTIFIER").value;return this.expect(">"),this.createNode("symbol",{name:i})}}parseNumericType(){if(this.current.type==="IDENTIFIER"&&["real","finite_real","rational","finite_rational","integer","finite_integer"].includes(this.current.value)){let t=this.advance().value;if(this.match("<")){let i=this.parseValue();this.expect("..");let r=this.parseValue();return this.expect(">"),this.createNode("numeric",{baseType:t,lowerBound:i,upperBound:r})}return this.createNode("numeric",{baseType:t})}}parsePrimitiveType(){if(this.current.type==="IDENTIFIER"){let n=this.current.value;if(je.includes(n))return this.advance(),this.createNode("primitive",{name:n})}}parseValue(){let n,t;switch(this.current.type){case"STRING_LITERAL":n=this.advance().value,t="string";break;case"NUMBER_LITERAL":n=parseFloat(this.advance().value),t="number";break;case"TRUE":this.advance(),n=!0,t="boolean";break;case"FALSE":this.advance(),n=!1,t="boolean";break;case"NAN":this.advance(),n=NaN,t="nan";break;case"INFINITY":case"PLUS_INFINITY":this.advance(),n=1/0,t="infinity";break;case"MINUS_INFINITY":this.advance(),n=-1/0,t="infinity";break;default:return}return this.createNode("value",{value:n,valueType:t})}parseTypeReference(){let n=this.current.type==="IDENTIFIER"&&this.current.value==="type";if(n&&this.advance(),this.current.type==="IDENTIFIER"){let t=this.current,i=this.advance().value;return this.typeResolver.resolve(i)?this.createNode("type_reference",{name:i,isForward:n}):n&&this.typeResolver.forward(i)?this.createNode("type_reference",{name:i,isForward:!0}):(n||this.errorAtToken(t,`Unknown type "${i}"`,"Syntax error. The type was not recognized."),this.createNode("type_reference",{name:i,isForward:n}))}}};function zs(e,n){switch(e.kind){case"function_signature":return n.visitFunctionSignature(e);case"union":return n.visitUnionType(e);case"intersection":return n.visitIntersectionType(e);case"negation":return n.visitNegationType(e);case"group":return n.visitGroupType(e);case"list":return n.visitListType(e);case"vector":return n.visitVectorType(e);case"matrix":return n.visitMatrixType(e);case"tensor":return n.visitTensorType(e);case"tuple":return n.visitTupleType(e);case"record":return n.visitRecordType(e);case"dictionary":return n.visitDictionaryType(e);case"set":return n.visitSetType(e);case"collection":return n.visitCollectionType(e);case"expression":return n.visitExpressionType(e);case"symbol":return n.visitSymbolType(e);case"numeric":return n.visitNumericType(e);case"primitive":return n.visitPrimitiveType(e);case"type_reference":return n.visitTypeReference(e);case"value":return n.visitValue(e);default:throw new Error(`Unknown node kind: ${e.kind}`)}}var di=class{typeResolver;constructor(n){this.typeResolver=n??{forward:()=>{},resolve:()=>{},get names(){return[]}}}buildType(n){return zs(n,this)}visitFunctionSignature(n){let t=[],i=[],r,s;for(let u of n.arguments){let l=this.buildNamedElement(u.element);switch(u.modifier){case"optional":i.push(l);break;case"variadic_zero":r=l,s=0;break;case"variadic_one":r=l,s=1;break;default:t.push(l);break}}let o=this.buildType(n.returnType),a={kind:"signature",args:t.length>0?t:void 0,result:o};return i.length>0&&(a.optArgs=i),r&&(a.variadicArg=r,a.variadicMin=s),a}visitUnionType(n){return{kind:"union",types:n.types.map(i=>this.buildType(i))}}visitIntersectionType(n){return{kind:"intersection",types:n.types.map(i=>this.buildType(i))}}visitNegationType(n){return{kind:"negation",type:this.buildType(n.type)}}visitGroupType(n){return this.buildType(n.type)}visitListType(n){let t=this.buildType(n.elementType),i=n.dimensions?.map(r=>this.buildDimension(r));return{kind:"list",elements:t,dimensions:i}}visitVectorType(n){let t=this.buildType(n.elementType);return n.size!==void 0?{kind:"list",elements:t,dimensions:[n.size]}:{kind:"list",elements:t}}visitMatrixType(n){let t=this.buildType(n.elementType);if(n.dimensions){let i=n.dimensions.map(r=>this.buildDimension(r));return{kind:"list",elements:t,dimensions:i}}return{kind:"list",elements:t,dimensions:[-1,-1]}}visitTensorType(n){return{kind:"list",elements:this.buildType(n.elementType)}}visitTupleType(n){return{kind:"tuple",elements:n.elements.map(i=>this.buildNamedElement(i))}}visitRecordType(n){if(n.entries.length===0)return"record";let t={};for(let i of n.entries)t[i.key]=this.buildType(i.valueType);return{kind:"record",elements:t}}visitDictionaryType(n){let t=this.buildType(n.valueType);return this.isAnyType(t)?"dictionary":{kind:"dictionary",values:t}}visitSetType(n){let t=this.buildType(n.elementType);return this.isAnyType(t)?"set":{kind:"set",elements:t}}visitCollectionType(n){let t=this.buildType(n.elementType);return n.indexed?this.isAnyType(t)?"indexed_collection":{kind:"indexed_collection",elements:t}:this.isAnyType(t)?"collection":{kind:"collection",elements:t}}visitExpressionType(n){return{kind:"expression",operator:n.operator}}visitSymbolType(n){return{kind:"symbol",name:n.name}}visitNumericType(n){if(!n.lowerBound&&!n.upperBound)return n.baseType;let t=n.lowerBound?this.buildValue(n.lowerBound):-1/0,i=n.upperBound?this.buildValue(n.upperBound):1/0;return t===-1/0&&i===1/0?n.baseType:{kind:"numeric",type:n.baseType,lower:t,upper:i}}visitPrimitiveType(n){return n.name}visitTypeReference(n){let t=this.typeResolver.resolve(n.name);if(t)return t;if(n.isForward){let i=this.typeResolver.forward(n.name);if(i)return i}return n.name}visitValue(n){return{kind:"value",value:n.value}}buildNamedElement(n){let t=this.buildType(n.type);return n.name?{name:n.name,type:t}:{type:t}}buildDimension(n){return n.size??-1}buildValue(n){return n.value}isAnyType(n){return n==="any"||typeof n=="object"&&"kind"in n&&n.kind==="primitive"&&"name"in n&&n.name==="any"}};function Gs(e,n){return new di(n).buildType(e)}function Y(e,n){if(e!==void 0){if(bt(e))return e;if(typeof e=="string")try{let i=new Et(e,{typeResolver:n}).parseType();return Gs(i,n)}catch(t){throw new Error(`Failed to parse type "${e}": ${t instanceof Error?t.message:String(t)}`)}}}var Uu={number:cn,non_finite_number:[],finite_number:["finite_complex","finite_real","finite_integer","finite_rational"],complex:["finite_complex","imaginary","finite_real","finite_rational","finite_integer","non_finite_number"],finite_complex:["imaginary","finite_real","finite_rational","finite_integer"],imaginary:[],real:["rational","integer","finite_real","finite_rational","finite_integer","non_finite_number"],finite_real:["finite_rational","finite_integer"],rational:["finite_rational","finite_integer","integer","non_finite_number"],finite_rational:["finite_integer"],integer:["finite_integer","non_finite_number"],finite_integer:[],any:je,unknown:[],nothing:[],never:[],error:[],value:pi,scalar:gt,collection:ht,indexed_collection:fi,list:[],set:[],tuple:[],record:[],dictionary:[],function:[],symbol:[],boolean:[],string:[],expression:mi};function Vn(e,n){return n==="any"||e==="never"?!0:e==="unknown"||n==="unknown"?!1:e===n?!0:Uu[n].includes(e)}function A(e,n){if(typeof e=="string"&&!je.includes(e)&&(e=Y(e)),typeof n=="string"&&!je.includes(n)&&(n=Y(n)),n==="any")return!0;if(n==="never")return!1;if(n==="error")return e==="error";if(n==="nothing")return e==="nothing";if(e==="nothing")return!1;if(n==="unknown")return!0;if(e==="unknown")return!1;if(typeof n=="string")return typeof e=="string"?Vn(e,n):e.kind==="value"?typeof e.value=="boolean"?n==="boolean":typeof e.value=="number"?Number.isInteger(e.value)?Vn("integer",n):Vn("number",n):typeof e.value=="boolean"?Vn("boolean",n):typeof e.value=="string"?Vn("string",n):!1:e.kind==="union"?e.types.every(t=>A(t,n)):e.kind==="intersection"?e.types.some(t=>A(t,n)):e.kind==="negation"?!A(e.type,n):e.kind==="numeric"?!!A(e.type,n):n==="number"?js(e):n==="symbol"?hi(e):n==="expression"?Zu(e):n==="function"?Ws(e):n==="scalar"?Us(e):n==="value"?Hs(e):n==="indexed_collection"?Ys(e):n==="collection"?Zs(e):n==="tuple"?e.kind==="tuple":n==="list"?e.kind==="list":n==="set"?e.kind==="set":n==="record"?e.kind==="record":n==="dictionary"?e.kind==="dictionary":!1;if(n.kind==="union")return typeof e!="string"&&e.kind==="union"?e.types.every(t=>n.types.some(i=>A(t,i))):n.types.some(t=>A(e,t));if(n.kind==="expression"){if(e==="symbol")return!0;if(typeof e=="string")return!1;if(e.kind==="expression")return n.operator==="Symbol"?hi(e):e.operator===n.operator;if(e.kind==="symbol")return!0}if(typeof e=="string")return!1;if(n.kind==="reference"){if(e.kind==="reference")return e.name===n.name;if(n.alias===!0&&n.def)return A(e,n.def)}if(e.kind==="union")return e.types.some(t=>A(t,n));if(e.kind==="intersection"&&n.kind==="intersection")return n.types.every(t=>e.types.some(i=>A(i,t)));if(e.kind==="intersection")return e.types.every(t=>A(t,n));if(n.kind==="intersection")return n.types.every(t=>A(e,t));if(e.kind==="signature"&&n.kind==="signature"){if(!A(e.result,n.result))return!1;if(e.optArgs||e.variadicArg){if(n.args){if(!e.args||e.args.length!==n.args.length)return!1;for(let t=0;t<n.args.length;t++)if(!A(n.args[t].type,e.args[t].type))return!1}else if(e.args)return!1;if(n.optArgs){if(!e.optArgs||e.optArgs.length!==n.optArgs.length)return!1;for(let t=0;t<e.optArgs.length;t++)if(!A(n.optArgs[t].type,e.optArgs[t].type))return!1}else if(e.optArgs)return!1;if(n.variadicArg){if(!e.variadicArg||e.variadicMin!=n.variadicMin||!A(n.variadicArg.type,e.variadicArg.type))return!1}else if(e.variadicArg)return!1}else{if(n.args&&!e.args)return!1;let t=0;if(n.args){if(e.args.length<n.args.length)return!1;for(;t<n.args.length;){if(!A(n.args[t].type,e.args[t].type))return!1;t+=1}}if(n.optArgs){if(t>=e.args.length)return!0;for(let i=0;i<n.optArgs.length;i++){if(!A(n.optArgs[i].type,e.args[t].type))return!1;if(t+=1,t>=e.args.length)return!0}}if(n.variadicArg){if(t>=e.args.length&&n.variadicMin===0)return!0;if(n.variadicMin>0&&t+n.variadicMin>e.args.length)return!1;for(;t<e.args.length;){if(!A(n.variadicArg.type,e.args[t].type))return!1;t+=1}}}return!0}if(e.kind==="record"&&n.kind==="record"){for(let t of Object.keys(n.elements))if(!(t in e.elements)||!A(e.elements[t],n.elements[t]))return!1;return!0}if(e.kind==="dictionary"&&n.kind==="dictionary")return A(e.values,n.values);if(n.kind==="indexed_collection")return e.kind==="indexed_collection"||e.kind==="list"?A(e.elements,n.elements):e.kind==="tuple"?e.elements.every(t=>A(t.type,n.elements)):!1;if(n.kind==="collection"){if(e.kind==="collection"||e.kind==="indexed_collection"||e.kind==="list")return A(e.elements,n.elements);if(e.kind==="tuple")return e.elements.every(t=>A(t.type,n.elements));if(e.kind==="set")return A(e.elements,n.elements);if(e.kind==="dictionary")return A({kind:"tuple",elements:[{type:"string"},{type:e.values}]},n.elements);if(e.kind==="record")return A({kind:"tuple",elements:[{type:"string"},{type:pe(...Object.values(e.elements))}]},n.elements)}if(e.kind==="tuple"&&n.kind==="tuple"){if(e.elements.length!==n.elements.length)return!1;for(let t=0;t<e.elements.length;t++){let i=e.elements[t],r=n.elements[t];if(!A(i.type,r.type)||i.name!==r.name)return!1}return!0}if(n.kind==="list"&&e.kind==="list"){if(!A(e.elements,n.elements))return!1;if(n.dimensions){if(!e.dimensions||e.dimensions.length!==n.dimensions.length)return!1;for(let t=0;t<e.dimensions.length;t++)if(n.dimensions[t]!==-1&&e.dimensions[t]!==n.dimensions[t])return!1}return!0}if(e.kind==="symbol"&&n.kind==="symbol")return e.name===n.name;if(e.kind==="numeric"&&n.kind==="numeric")return!(!A(e.type,n.type)||(e.lower??-1/0)<(n.lower??-1/0)||(e.upper??1/0)>(n.upper??1/0));if(n.kind==="set"&&e.kind==="set")return!!A(e.elements,n.elements);if(e.kind==="negation"&&n.kind==="negation")return A(e.type,n.type);if(n.kind==="negation")return!A(e,n.type);if(n.kind==="value"&&e.kind==="value")return n.value===e.value;if(e.kind==="value"){if(typeof e.value=="boolean")return A("boolean",n);if(typeof e.value=="number")return Number.isInteger(e.value)?A("integer",n):A("real",n);if(typeof e.value=="string")return A("string",n)}return!1}function js(e){return typeof e=="string"?cn.includes(e):e.kind==="value"?typeof e.value=="number":e.kind==="numeric"}function Us(e){return js(e)?!0:typeof e=="string"?gt.includes(e):e.kind==="value"?["string","boolean","number"].includes(typeof e.value):!1}function Zs(e){return Ys(e)?!0:typeof e=="string"?ht.includes(e):["collection","set","record","dictionary"].includes(e.kind)}function Ys(e){return typeof e=="string"?!1:["indexed_collection","list","tuple"].includes(e.kind)}function Hs(e){return Us(e)||Zs(e)}function Ws(e){return e==="function"||typeof e!="string"&&e.kind==="signature"}function Zu(e){return typeof e=="string"&&["expression","symbol","function"].includes(e)||Hs(e)||Ws(e)||hi(e)?!0:typeof e=="string"?!1:e.kind==="expression"}function hi(e){return e==="symbol"?!0:typeof e=="string"?!1:e.kind==="symbol"?!0:e.kind==="expression"?e.operator==="Symbol":!1}function Yu(e,n){return e===n?e:e==="nothing"||n==="nothing"?"nothing":e==="any"?n:n==="any"?e:e==="never"?n:n==="never"?e:e==="unknown"?n:n==="unknown"||A(e,n)?e:A(n,e)?n:Xs(e,n)}function Hu(e,n){return e===n?e:e==="any"||n==="any"?"any":e==="never"?n:n==="never"?e:e==="unknown"?n:n==="unknown"?e:e==="nothing"?n:n==="nothing"?e:A(e,n)?n:A(n,e)?e:Xs(e,n)}function gi(...e){return e.length===0?"nothing":e.length===1?e[0]:e.reduce((n,t)=>Yu(n,t))}function pe(...e){return e.length===0?"nothing":e.length===1?e[0]:e.reduce((n,t)=>Hu(n,t))}function Xs(e,n){return e===n?e:e==="any"||n==="any"?"any":e==="never"?n:n==="never"?e:e==="unknown"?n:n==="unknown"?e:e==="nothing"?n:n==="nothing"?e:H(e,n,"non_finite_number")?"non_finite_number":H(e,n,"finite_integer")?"finite_integer":H(e,n,"integer")?"integer":H(e,n,"finite_rational")?"finite_rational":H(e,n,"rational")?"rational":H(e,n,"finite_real")?"finite_real":H(e,n,"real")?"real":H(e,n,"imaginary")?"imaginary":H(e,n,"finite_complex")?"finite_complex":H(e,n,"complex")?"complex":H(e,n,"finite_number")?"finite_number":H(e,n,"number")?"number":H(e,n,"list")?"list":H(e,n,"record")?"record":H(e,n,"dictionary")?"dictionary":H(e,n,"set")?"set":H(e,n,"tuple")?"tuple":H(e,n,"indexed_collection")?"indexed_collection":H(e,n,"collection")?"collection":H(e,n,"scalar")?"scalar":H(e,n,"value")?"value":H(e,n,"function")?"function":H(e,n,"expression")?"expression":"any"}function H(e,n,t){return!!(A(e,t)&&A(n,t))}function bi(e){if(e){if(e==="function")return"any";if(typeof e!="string"&&e.kind==="signature")return e.result}}function Te(e){if(e==="collection"||e==="indexed_collection"||e==="list"||e==="set"||e==="tuple"||e==="dictionary"||e==="record")return"any";if(typeof e!="string"){if(e.kind==="collection"||e.kind==="indexed_collection"||e.kind==="list"||e.kind==="set")return e.elements;if(e.kind==="tuple")return pe(...e.elements.map(n=>n.type));if(e.kind==="dictionary")return Y(`tuple<string, ${e.values}>`);if(e.kind==="record")return Y(`tuple<string, ${q(pe(...Object.values(e.elements)))}>`)}}var ce=class e{static unknown=new e("unknown");static number=new e("number");static non_finite_number=new e("non_finite_number");static finite_number=new e("finite_number");static finite_integer=new e("finite_integer");static finite_real=new e("finite_real");static string=new e("string");static dictionary=new e("dictionary");static setNumber=new e("set<number>");static setComplex=new e("set<complex>");static setImaginary=new e("set<imaginary>");static setReal=new e("set<real>");static setRational=new e("set<rational>");static setFiniteInteger=new e("set<finite_integer>");static setInteger=new e("set<integer>");type;static widen(...n){return new e(pe(...n.map(t=>t instanceof e?t.type:t)))}static narrow(...n){return new e(gi(...n.map(t=>t instanceof e?t.type:t)))}constructor(n,t){typeof n=="string"?this.type=Y(n,t):this.type=n}matches(n){return n instanceof e?A(this.type,n.type):A(this.type,n)}is(n){return A(this.type,n)&&A(n,this.type)}get isUnknown(){return this.type==="unknown"}toString(){return q(this.type)}toJSON(){return q(this.type)}[Symbol.toPrimitive](n){return n==="string"?this.toString():null}valueOf(){return q(this.type)}};function X(e){return e?._kind==="number"}function _(e,n){return e?._kind==="symbol"&&(n===void 0||e.symbol===n)}function h(e,n){return(e?._kind==="function"||e?._kind==="tensor")&&(n===void 0||e.operator===n)}function me(e){return e?._kind==="string"}function de(e){return e?._kind==="symbol"?e.symbol:void 0}var vm=[0,-1,1,Math.PI,Math.E,-Math.PI,-Math.E,.5,-.5];function Ce(e){if(!e)return;if(e.operator==="Function"&&e.isCanonical||_(e))return e;if(h(e,"BuiltinFunction"))return e.op1;if(h(e,"Delimiter")){let s=e.op1;if(h(s,"Sequence"))if(s.nops===1)e=s;else return Ce(e.engine._fn("Block",s.ops,{canonical:!1}));return Ce(h(e)?e.op1:void 0)}if(h(e,"Function"))return Qs(e.engine,e.ops);e.operator;let n=e.engine,t=e.subs({_:"_1"}),i=1,r=[];for(;i<10;)t.has(`_${i}`)&&r.push(t.engine.symbol(`_${i}`,{canonical:!1})),i++;if(r.length===0){t.operator!=="Block"?t=n.function("Block",[t]):t=t.canonical;let s=t.unknowns;s.length>0&&(r=s.map(o=>n.symbol(o,{canonical:!1})))}return Qs(n,[t,...r])}function Qs(e,n){if(n.length===0)return;let t=n[0].operator==="Block"?n[0].canonical:e.function("Block",[n[0]]),i=n.slice(1).map(r=>_(r)?r:e.error("expected-a-symbol",r.toString()));t.isScoped;for(let r of i)_(r)&&!t.localScope.bindings.has(r.symbol)&&e.declare(r.symbol,{inferred:!0,type:"unknown"},t.localScope);return e._fn("Function",[t,...i])}function Ks(e,n){let t=e.Nothing;for(let i of n){let r=i.operator;if(r==="Return"&&h(i)){t=i.op1.evaluate();break}if((r==="Break"||r==="Continue")&&h(i)){t=e.expr([r,i.op1.evaluate()]);break}t=i.evaluate()}return t}function eo(e,n){let t=[];for(let i of n){if(!i)continue;let r=e.bindings.get(i);r&&(t.push([i,r]),e.bindings.delete(i))}return t}function no(e,n){for(let[t,i]of n)e.bindings.set(t,i)}function to(e,n,t){if(n.operator==="Function"&&h(n)){let i=n.op1;if(i&&h(i)&&i.localScope){let r=new Set(n.ops.slice(1).map(u=>_(u)?u.symbol:"").filter(u=>u)),s=new Map;for(let[u,l]of i.localScope.bindings)r.has(u)&&s.set(u,l);let o={parent:t,bindings:s},a=e._fn("Block",i.ops,{scope:o});return e._fn("Function",[a,...n.ops.slice(1)])}return n}if(h(n)&&n.ops.length>0){let i=!1,r=n.ops.map(s=>{let o=to(e,s,t);return o!==s&&(i=!0),o});if(i)return e._fn(n.operator,r)}return n}function io(e){let n=e.engine;if(_(e)){let a=e.symbol;return u=>n.function(a,u).evaluate()}let t=Ce(e);if(!t)throw new Error("Invalid function literal");e=t,e.operator,e.isCanonical;let i=e;if(i.ops.length===1)return i.ops[0],()=>i.ops[0].evaluate();let[r,...s]=i.ops;if(r.isScoped,!r.localScope)throw new Error("Function body must be a scoped Block expression");let o=r;return a=>{if(a.length>s.length)throw new Error(`Too many arguments for function "${e.toString()}": expected ${s.length}, got ${a.length}`);if(n.strict&&!a.every(k=>k.isValid))return;if(a.length<s.length){let k=new Set([...r.symbols,...s.map(ee=>_(ee)?ee.symbol:"")]),w=s.slice(a.length).map((ee,Me)=>{let we=`_${Me+1}`,lt=0;for(;k.has(we);)we=`_${Me+1}_${lt++}`;return k.add(we),n.symbol(we,{canonical:!1})}),R=Object.fromEntries(s.slice(a.length).map((ee,Me)=>[_(ee)?ee.symbol:"",w[Me]])),P=a.map(ee=>ee.evaluate()),W={parent:o.localScope.parent??n.context.lexicalScope,bindings:new Map};for(let ee=0;ee<a.length;ee++){let Me=s[ee],we=_(Me)?Me.symbol:"";we&&n.declare(we,{value:P[ee],inferred:!0},W)}let j=o.localScope,ve=j.parent;j.parent=W;let U=s.slice(0,a.length).map(ee=>_(ee)?ee.symbol:""),oe=eo(j,U);n.pushScope(W);let ae;try{ae=Ks(n,o.ops)}finally{n.popScope(),j.parent=ve,no(j,oe)}return n.function("Function",[ae.subs(R),...w])}let u=a.map(k=>k.evaluate()),c={parent:o.localScope.parent??n.context.lexicalScope,bindings:new Map},p=s.map(k=>_(k)?k.symbol:"");for(let k=0;k<s.length;k++)p[k]&&n.declare(p[k],{value:u[k],inferred:!0},c);let m=o.localScope,d=m.parent;m.parent=c;let b=eo(m,p);n.pushScope(c);let v;try{v=Ks(n,o.ops),v=to(n,v,c)}finally{n.popScope(),m.parent=d,no(m,b)}return v.isValid?v:void 0}}function ne(e){return io(e)??(n=>e.engine.function("Apply",[e,...n]).evaluate())}function ro(e){let n=io(e),t=e.engine;return n?i=>n([t.number(i)])?.re??NaN:i=>t.function("Apply",[e,t.number(i)]).evaluate().re}function yi(e){return(e.isFiniteCollection??!1)&&e.isIndexedCollection}function Xu(e,n,t){if(!(e.isFiniteCollection!==!0||n.isFiniteCollection!==!0)){for(let i of e.each())if(n.contains(i)!==!0)return!1;if(t){let i=e.count;if(i===void 0)return!1;let r=n.count;if(r===void 0||i===r)return!1}return!0}}function Qu(e,n){if(h(e)){for(let t=0;t!==e.nops;t+=1)if(n(e.ops[t]))return t+1}}function vt(){return{isLazy:e=>!1,count:e=>h(e)?e.nops:0,isEmpty:e=>!h(e)||e.nops===0,isFinite:e=>!0,contains:(e,n)=>h(e)?e.ops.some(t=>t.isSame(n)):!1,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=1,t=e.nops;return{next:()=>n===t+1?{value:void 0,done:!0}:(n+=1,{value:e.ops[n-1-1],done:!1})}},subsetOf:Xu,at:(e,n)=>{if(!(typeof n!="number"||!h(e))&&(n<0&&(n=e.nops+n+1),!(n<1||n>e.nops)))return e.ops[n-1]},indexWhere:Qu,eltsgn:e=>{},elttype:e=>!h(e)||e.nops===0?"unknown":e.nops===1?e.ops[0].type.type:pe(...e.ops.map(n=>n.type.type))}}var pn=class extends Error{cause;value;constructor({message:n,value:t,cause:i}={}){super(n??"Operation canceled"),t&&(this.value=t),this.cause=i,this.name="CancellationError"}};function xi(e,n){let t=Date.now();for(;;){let{done:i,value:r}=e.next();if(i)return r;if(Date.now()-t>=n)throw new pn({value:r,cause:"timeout",message:`Timeout exceeded (${n}ms)`})}}function I(e){let n="",t="";for(let i of e)i!=null&&(typeof i=="string"&&(/[a-zA-Z]/.test(i[0])&&(t+=n),/\\[a-zA-Z]+\*?$/.test(i)?n=" ":n=""),t+=i.toString());return t}function mn(e,n,t){return n.includes(e)&&(n=`{${n}}`),/^[0-9]$/.test(t)?`${n}${e}${t}`:`${n}${e}{${t}}`}var D=245,Jn=260,Re=270,K=275,he=390,ge=600;var qn=700,Ei=810;var Qe=[{latexTrigger:["\\not","<"],kind:"infix",associativity:"any",precedence:246,parse:"NotLess"},{name:"NotLess",latexTrigger:["\\nless"],kind:"infix",associativity:"any",precedence:246},{latexTrigger:["<"],kind:"infix",associativity:"any",precedence:245,parse:"Less"},{name:"Less",latexTrigger:["\\lt"],kind:"infix",associativity:"any",precedence:245},{latexTrigger:["<","="],kind:"infix",associativity:"any",precedence:241,parse:"LessEqual"},{name:"LessEqual",latexTrigger:["\\le"],kind:"infix",associativity:"any",precedence:241},{latexTrigger:["\\leq"],kind:"infix",associativity:"any",precedence:241,parse:"LessEqual"},{latexTrigger:["\\leqslant"],kind:"infix",associativity:"any",precedence:D+5,parse:"LessEqual"},{name:"LessNotEqual",latexTrigger:["\\lneqq"],kind:"infix",associativity:"any",precedence:D},{name:"NotLessNotEqual",latexTrigger:["\\nleqq"],kind:"infix",associativity:"any",precedence:D},{name:"LessOverEqual",latexTrigger:["\\leqq"],kind:"infix",associativity:"any",precedence:D+5},{name:"GreaterOverEqual",latexTrigger:["\\geqq"],kind:"infix",associativity:"any",precedence:D+5,parse:"GreaterEqual"},{name:"Equal",latexTrigger:["="],kind:"infix",associativity:"right",precedence:D},{latexTrigger:["*","="],kind:"infix",associativity:"right",precedence:D,parse:"StarEqual"},{name:"StarEqual",latexTrigger:["\\star","="],kind:"infix",associativity:"right",precedence:D},{name:"PlusEqual",latexTrigger:["+","="],kind:"infix",associativity:"right",precedence:D},{name:"MinusEqual",latexTrigger:["-","="],kind:"infix",associativity:"right",precedence:D},{name:"SlashEqual",latexTrigger:["/","="],kind:"infix",associativity:"right",precedence:D},{name:"EqualEqual",latexTrigger:["=","="],kind:"infix",associativity:"right",precedence:D},{name:"EqualEqualEqual",latexTrigger:["=","=","="],kind:"infix",associativity:"right",precedence:D+5},{name:"TildeFullEqual",latexTrigger:["\\cong"],kind:"infix",associativity:"right",precedence:D},{name:"NotTildeFullEqual",latexTrigger:["\\ncong"],kind:"infix",associativity:"right",precedence:D},{name:"Approx",latexTrigger:["\\approx"],kind:"infix",associativity:"right",precedence:247},{name:"NotApprox",latexTrigger:["\\not","\\approx"],kind:"infix",associativity:"right",precedence:247},{name:"ApproxEqual",latexTrigger:["\\approxeq"],kind:"infix",associativity:"right",precedence:D},{name:"NotApproxEqual",latexTrigger:["\\not","\\approxeq"],kind:"infix",associativity:"right",precedence:250},{name:"NotEqual",latexTrigger:["\\ne"],kind:"infix",associativity:"right",precedence:255},{name:"Unequal",latexTrigger:["!","="],kind:"infix",associativity:"right",precedence:D},{name:"GreaterEqual",latexTrigger:["\\ge"],kind:"infix",associativity:"right",precedence:242},{latexTrigger:["\\geq"],kind:"infix",associativity:"right",precedence:242,parse:"GreaterEqual"},{latexTrigger:[">","="],kind:"infix",associativity:"right",precedence:243,parse:"GreaterEqual"},{latexTrigger:["\\geqslant"],kind:"infix",associativity:"right",precedence:D+5,parse:"GreaterEqual"},{name:"GreaterNotEqual",latexTrigger:["\\gneqq"],kind:"infix",associativity:"right",precedence:D},{name:"NotGreaterNotEqual",latexTrigger:["\\ngeqq"],kind:"infix",associativity:"right",precedence:D},{latexTrigger:[">"],kind:"infix",associativity:"right",precedence:245,parse:"Greater"},{name:"Greater",latexTrigger:["\\gt"],kind:"infix",associativity:"right",precedence:245},{name:"NotGreater",latexTrigger:["\\ngtr"],kind:"infix",associativity:"right",precedence:244},{latexTrigger:["\\not",">"],kind:"infix",associativity:"right",precedence:244,parse:"NotGreater"},{name:"RingEqual",latexTrigger:["\\circeq"],kind:"infix",associativity:"right",precedence:D},{name:"TriangleEqual",latexTrigger:["\\triangleq"],kind:"infix",associativity:"right",precedence:D},{name:"DotEqual",latexTrigger:["\\doteq"],kind:"infix",associativity:"right",precedence:D+5},{name:"DotEqualDot",latexTrigger:["\\doteqdot"],kind:"infix",associativity:"right",precedence:D+5},{name:"FallingDotEqual",latexTrigger:["\\fallingdotseq"],kind:"infix",associativity:"right",precedence:D+5},{name:"RisingDotEqual",latexTrigger:["\\fallingdotseq"],kind:"infix",associativity:"right",precedence:D+5},{name:"QuestionEqual",latexTrigger:["\\questeq"],kind:"infix",associativity:"right",precedence:D},{name:"MuchLess",latexTrigger:["\\ll"],kind:"infix",associativity:"right",precedence:D},{name:"MuchGreater",latexTrigger:["\\gg"],kind:"infix",associativity:"right",precedence:D},{name:"Precedes",latexTrigger:["\\prec"],kind:"infix",associativity:"right",precedence:D},{name:"Succeeds",latexTrigger:["\\succ"],kind:"infix",associativity:"right",precedence:D},{name:"PrecedesEqual",latexTrigger:["\\preccurlyeq"],kind:"infix",associativity:"right",precedence:D},{name:"SucceedsEqual",latexTrigger:["\\curlyeqprec"],kind:"infix",associativity:"right",precedence:D},{name:"NotPrecedes",latexTrigger:["\\nprec"],kind:"infix",associativity:"right",precedence:D},{name:"NotSucceeds",latexTrigger:["\\nsucc"],kind:"infix",associativity:"right",precedence:D},{name:"Between",latexTrigger:["\\between"],kind:"infix",associativity:"right",precedence:D+5}];function vi(e){return typeof e!="string"?!1:Qe.some(n=>n.name===e)}function Ni(e){return typeof e!="string"?!1:["Less","LessEqual","Greater","GreaterEqual"].includes(e)}function Ti(e){return typeof e!="string"?!1:["Equal","NotEqual"].includes(e)}var dn=["Error","'missing'"];function Ke(e){return!!(typeof e=="number"||hn(e)||typeof e=="string"&&It(e))}function hn(e){return e!==null&&typeof e=="object"&&"num"in e}function Nt(e){return e!==null&&typeof e=="object"&&"sym"in e}function oo(e){return e!==null&&typeof e=="object"&&"str"in e}function ao(e){return e!==null&&typeof e=="object"&&"dict"in e&&typeof e.dict=="object"&&!Array.isArray(e.dict)&&e.dict!==null}function gn(e){return e!==null&&typeof e=="object"&&"fn"in e&&Array.isArray(e.fn)&&e.fn.length>0&&typeof e.fn[0]=="string"}function L(e){return e==null?null:typeof e=="object"&&"str"in e?e.str:typeof e!="string"?null:e.length>=2&&e.at(0)==="'"&&e.at(-1)==="'"?e.substring(1,e.length-1):It(e)||Mi(e)?null:e}function ki(e){if(e==null||L(e)!==null)return null;let n=y(e);return n?[n,...N(e).map(t=>ki(t)).filter(t=>t!==null)]:e}function y(e){return Array.isArray(e)?e[0]:e==null?"":gn(e)?e.fn[0]:""}function N(e){return Array.isArray(e)?e.slice(1):e!==void 0&&gn(e)?e.fn.slice(1):[]}function f(e,n){return Array.isArray(e)?e[n]??null:e===null||!gn(e)?null:e.fn[n]??null}function J(e){return e==null?0:Array.isArray(e)?Math.max(0,e.length-1):gn(e)?Math.max(0,e.fn.length-1):0}function Si(e){return e==null?null:y(e)==="Hold"?f(e,1):e}function S(e){return typeof e=="string"&&Mi(e)?e.length>=2&&e.at(0)==="`"&&e.at(-1)==="`"?e.slice(1,-1):e:e==null?null:Nt(e)?e.sym:null}function so(e){let n=y(e);if(n==="KeyValuePair"||n==="Tuple"||n==="Pair"){let[t,i]=N(e),r=L(t);return r?[r,i??"Nothing"]:null}return null}function uo(e){if(e===null)return null;if(ao(e))return e;let n=so(e);if(n)return{[n[0]]:n[1]};if(y(e)==="Dictionary"){let t={},i=N(e);for(let r=1;r<J(e);r++){let s=so(i[r]);s&&(t[s[0]]=il(s[1])??"Nothing")}return{dict:t}}return null}function _i(e){return{dict:Object.fromEntries(Object.entries(e).map(([t,i])=>[t,Ii(i)??"Nothing"]))}}function tl(e){if(e=e.toLowerCase().replace(/[nd]$/,"").replace(/[\u0009-\u000d\u0020\u00a0]/g,""),e==="nan")return NaN;if(/^(infinity|\+infinity|oo|\+oo)$/i.test(e))return 1/0;if(/^(-infinity|-oo)$/.test(e))return-1/0;if(/\([0-9]+\)/.test(e)){let[n,t,i,r]=e.match(/(.+)\(([0-9]+)\)(.*)$/)??[];e=t+i.repeat(Math.ceil(16/i.length))+(r??"")}return parseFloat(e)}function C(e){return typeof e=="number"?e:typeof e=="string"&&It(e)?tl(e):e!==void 0&&hn(e)?C(e.num):null}function bn(e){if(e==null)return null;if(S(e)==="Half")return[1,2];let n=y(e);if(!n)return null;let t=null,i=null;if(n==="Negate"){let r=bn(N(e)[0]);if(r)return[-r[0],r[1]]}if(n==="Rational"||n==="Divide"){let[r,s]=N(e);t=C(r)??NaN,i=C(s)??NaN}if(n==="Power"){let[r,s]=N(e),o=C(s);o===1?(t=C(r),i=1):o===-1&&(t=1,i=C(r))}if(n==="Multiply"){let[r,s]=N(e);if(y(s)==="Power"){let[o,a]=N(s);C(a)===-1&&(t=C(r),i=C(o))}}return t===null||i===null?null:Number.isInteger(t)&&Number.isInteger(i)?[t,i]:null}function Tt(e,n){let t=null;if(Array.isArray(e)&&(t=e),gn(e)&&(t=e.fn),t===null)return[];let i=1,r=[];for(;i<t.length;)r.push(n(t[i])),i+=1;return r}function yn(e,n,t){let i=y(n),r=y(t);return i===e&&r===e?[e,...N(n),...N(t)]:i===e?[e,...N(n),t]:r===e?[e,n,...N(t)]:[e,n,t]}function en(e){if(e==null)return null;let n=y(e);if(n==="Delimiter"){if(e=f(e,1),e===null)return[];if(n=y(e),n!=="Sequence")return[e]}return n!=="Sequence"?null:N(e)}function z(e){return e==null||e==="Nothing"?!0:y(e)==="Sequence"&&J(e)===0}function V(e){return z(e)?dn:e}function It(e){return/^(nan|oo|\+oo|-oo|infinity|\+infinity|-infinity)$/i.test(e)||/^[+-]?(0|[1-9][0-9]*)(\.[0-9]+)?(\([0-9]+\))?([eE][+-]?[0-9]+)?$/.test(e)}function Mi(e){return/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)||e.length>=2&&e[0]==="`"&&e[e.length-1]==="`"}function Ii(e){if(typeof e=="string")return{str:e};if(typeof e=="number")return{num:e.toString()};if(typeof e=="boolean")return e?"True":"False";if(Array.isArray(e))return["List",...e.map(n=>Ii(n)??"Nothing")];if(e===null)return null;if(typeof e=="object"){let n={};for(let t in e)n[t]=Ii(e[t])??"Nothing";return{dict:n}}return gn(e)||Nt(e)||hn(e)||oo(e)||ao(e)?e:null}function il(e){return e==null?null:oo(e)?e.str:hn(e)?parseFloat(e.num):Nt(e)?e.sym:typeof e=="string"||typeof e=="number"?e:Array.isArray(e)?{fn:e}:e}function wi(e,n,t,i,r){if(n&&n.minPrec>=i)return null;let s=t?[t]:["Nothing"],o=!1;for(;!o;){for(o=!0,e.skipSpace();e.match(r);)s.push("Nothing"),e.skipSpace();if(e.skipVisualSpace(),e.atTerminator(n))s.push("Nothing");else{let a=e.parseExpression({...n,minPrec:i});s.push(a??"Nothing"),o=a===null}o||(e.skipSpace(),o=!e.match(r),o||e.skipVisualSpace())}return s}function Ie(e=""){return(n,t)=>{if(!t)return"";let i=N(t);if(i.length===0)return"";if(i.length===1)return n.serialize(i[0]);e={"&":"\\&",":":"\\colon","|":"\\mvert","-":"-","\xB7":"\\cdot","\u2012":"-","\u2013":"--","\u2014":"---","\u2015":"-","\u2022":"\\bullet","\u2026":"\\ldots"}[e]??e;let r=i.reduce((s,o)=>(s.push(n.serialize(o),e),s),[]);return r.pop(),I(r)}}var po=[{latexTrigger:["\\placeholder"],kind:"symbol",parse:e=>{for(;e.match("<space>"););if(e.match("["))for(;!e.match("]")&&!e.atBoundary;)e.nextToken();for(;e.match("<space>"););if(e.match("<{>"))for(;!e.match("<}>")&&!e.atBoundary;)e.nextToken();return"Nothing"}},{name:"ContinuationPlaceholder",latexTrigger:["\\dots"]},{latexTrigger:["\\ldots"],parse:"ContinuationPlaceholder"},{latexTrigger:[".",".","."],parse:"ContinuationPlaceholder"},{name:"Function",latexTrigger:["\\mapsto"],kind:"infix",precedence:Re,parse:(e,n,t)=>{let i=[];if(y(n)==="Delimiter"&&(n=f(n,1)??"Nothing"),y(n)==="Sequence")for(let s of N(n)){if(!S(s))return null;i.push(S(s))}else{if(!S(n))return null;i=[S(n)]}let r=e.parseExpression({minPrec:Re})??"Nothing";return y(r)==="Delimiter"&&(r=f(r,1)??"Nothing"),y(r)==="Sequence"&&(r=["Block",...N(r)]),["Function",r,...i]},serialize:(e,n)=>{let t=N(n);return t.length<1?"()\\mapsto()":t.length===1?I(["()","\\mapsto",e.serialize(f(n,1))]):t.length===2?I([e.serialize(f(n,2)),"\\mapsto",e.serialize(f(n,1))]):I([e.wrapString(N(n)?.slice(1).map(i=>e.serialize(i)).join(", "),"normal"),"\\mapsto",e.serialize(f(n,1))])}},{name:"Apply",kind:"function",symbolTrigger:"apply",serialize:(e,n)=>{let t=f(n,1),i=y(t);if(i==="InverseFunction"||i==="Derivative"){let o=e.options.applyFunctionStyle(n,e.level),a=N(n).slice(1);return e.serializeFunction(t,e.dictionary.ids.get(i))+e.wrapString(a.map(u=>e.serialize(u)).join(", "),o)}let r=f(n,2);if(typeof t=="string"||!r){let o=N(n).slice(1);return e.serialize(o)}if(J(n)===2)return I([e.wrap(t,20),"\\lhd",e.wrap(r,20)]);let s=e.options.applyFunctionStyle(n,e.level);return I(["\\operatorname{apply}",e.wrapString(e.serialize(i)+", "+e.serialize(["List",...N(n)]),s)])}},{latexTrigger:"\\lhd",kind:"infix",precedence:20,parse:"Apply"},{latexTrigger:"\\rhd",kind:"infix",precedence:20,parse:(e,n,t)=>["Apply",e.parseExpression({minPrec:21})??"Nothing",n]},{name:"EvaluateAt",openTrigger:".",closeTrigger:"|",kind:"matchfix",serialize:(e,n)=>{let t=f(n,1);if(!t)return"";let i=N(n).slice(1);if(y(t)==="Function"){let r=N(t).slice(1),s=f(t,1);if(y(s)==="Block"&&J(s)===1&&(s=f(s,1)),r.length>0)return`\\left.\\left(${e.serialize(s)}\\right)\\right|_{${r.map((o,a)=>`${e.serialize(o)}=${e.serialize(i[a])}`).join(", ")}}`}return`\\left.\\left(${e.serialize(t)}\\right)\\right|_{${i.map(r=>e.serialize(r)).join(", ")}}`}},{name:"Assign",latexTrigger:"\\coloneq",kind:"infix",associativity:"right",precedence:Jn,serialize:(e,n)=>{let t=Si(f(n,1));if(y(f(n,2))==="Function"){let i=f(n,2),r=Si(f(i,1)),s=N(i).slice(1);return I([e.serialize(t),e.wrapString(s.map(o=>e.serialize(o)).join(", "),e.options.applyFunctionStyle(n,e.level)),"\\coloneq",e.serialize(r)])}return I([e.serialize(t),"\\coloneq",e.serialize(f(n,2))])},parse:kt},{latexTrigger:"\\coloneqq",kind:"infix",associativity:"right",precedence:Jn,parse:kt},{latexTrigger:"\\colonequals",kind:"infix",associativity:"right",precedence:Jn,parse:kt},{latexTrigger:[":","="],kind:"infix",associativity:"right",precedence:Jn,parse:kt},{name:"Colon",latexTrigger:":",kind:"infix",associativity:"right",precedence:250,serialize:(e,n)=>I([e.serialize(f(n,1)),"\\colon",e.serialize(f(n,2))])},{latexTrigger:"\\colon",kind:"infix",associativity:"right",precedence:250,parse:"Colon"},{name:"BaseForm",serialize:(e,n)=>{let t=C(f(n,2))??NaN;if(isFinite(t)&&t>=2&&t<=36){let i=C(f(n,1))??NaN;if(isFinite(i)&&Number.isInteger(i)){let r=Number(i).toString(t),s=0;if(t===2||t===10?s=4:t===16?s=2:t>16&&(s=4),s>0){let o=r;r="";for(let a=0;a<o.length;a++)a>0&&a%s===0&&(r="\\, "+r),r=o[o.length-a-1]+r}return`(\\text{${r}}_{${t}}`}}return"\\operatorname{BaseForm}("+e.serialize(f(n,1))+", "+e.serialize(f(n,2))+")"}},{name:"Sequence",serialize:Ie(" ")},{name:"InvisibleOperator",serialize:Ie("")},{name:"Delimiter",serialize:(e,n)=>{let t=e.options.groupStyle(n,e.level+1),i=f(n,1),r={Set:"{,}",List:"[,]",Tuple:"(,)",Single:"(,)",Pair:"(,)",Triple:"(,)",Sequence:"(,)",String:'""'}[y(i)],s=r?i:["Sequence",i];if(r??="(,)",J(n)>1){let c=L(f(n,2));typeof c=="string"&&c.length<=3&&(r=c)}let[o,a,u]=["","",""];r.length===3?[o,a,u]=r:r.length===2?[o,u]=r:r.length===1&&(a=r);let l=i?s?Ie(a)(e,s):e.serialize(i):"";return e.wrapString(l,t,o+u)}},{name:"Tuple",serialize:(e,n)=>I(["(",Ie(",")(e,n),")"])},{name:"Pair",serialize:(e,n)=>I(["(",Ie(",")(e,n),")"])},{name:"Triple",serialize:(e,n)=>I(["(",Ie(",")(e,n),")"])},{name:"Single",serialize:(e,n)=>I(["(",Ie(",")(e,n),")"])},{name:"Domain",serialize:(e,n)=>y(n)==="Error"?e.serialize(n):`\\mathbf{${e.serialize(f(n,1))}}`},{latexTrigger:["\\mathtip"],parse:e=>{let n=e.parseGroup();return e.parseGroup(),n}},{latexTrigger:["\\texttip"],parse:e=>{let n=e.parseGroup();return e.parseGroup(),n}},{latexTrigger:["\\error"],parse:e=>["Error",e.parseGroup()]},{name:"Error",serialize:(e,n)=>{let t=f(n,1);if(L(t)==="missing")return`\\error{${e.options.missingSymbol??"\\placeholder{}"}}`;let i=ol(e,n)||"\\blacksquare",r=y(t)==="ErrorCode"?L(f(t,1)):L(t);return r==="incompatible-type"?S(f(t,3))==="Undefined"?`\\mathtip{\\error{${i}}}{\\notin ${e.serialize(f(t,2))}}`:`\\mathtip{\\error{${i}}}{\\in ${e.serialize(f(t,3))}\\notin ${e.serialize(f(t,2))}}`:typeof r=="string"?`\\error{${i}}`:`\\error{${i}}`}},{name:"ErrorCode",serialize:(e,n)=>{let t=L(f(n,1));return t==="missing"?e.options.missingSymbol??"\\placeholder{}":t==="unexpected-command"||t==="unexpected-operator"||t==="unexpected-token"||t==="invalid-symbol"||t==="unknown-environment"||t==="unexpected-base"||t==="incompatible-type"?"":`\\texttip{\\error{\\blacksquare}}{\\mathtt{${t}}}`}},{name:"FromLatex",serialize:(e,n)=>`\\texttt{${sl(L(f(n,1)))}}`},{name:"Latex",serialize:(e,n)=>n===null?"":I(Tt(n,t=>L(t)??e.serialize(t)))},{name:"LatexString",serialize:(e,n)=>n===null?"":I(Tt(n,t=>e.serialize(t)))},{name:"LatexTokens",serialize:rl},{name:"At",kind:"postfix",precedence:810,latexTrigger:["["],parse:$i("]"),serialize:(e,n)=>I(["\\lbrack",Ie(", ")(e,n),"\\rbrack"])},{kind:"postfix",precedence:810,latexTrigger:["\\lbrack"],parse:$i("\\rbrack")},{kind:"postfix",precedence:810,latexTrigger:["\\left","\\lbrack"],parse:$i("\\right","\\rbrack")},{kind:"postfix",latexTrigger:["_"],parse:(e,n,t)=>{let i=e.parseGroup()??e.parseToken();i===null&&e.options.strict===!1&&e.peek==="("&&(i=e.parseEnclosure());let r=S(n);return i!==null&&(r&&e.getSymbolType(r).matches("indexed_collection")||y(n)==="List")?(y(i)==="Delimiter"&&(i=f(i,1)??"Nothing"),y(i)==="Sequence"?["At",n,...N(i)]:["At",n,i]):["Subscript",n,i]}},{name:"List",kind:"matchfix",openTrigger:"[",closeTrigger:"]",parse:mo,serialize:ul},{kind:"matchfix",openTrigger:"(",closeTrigger:")",parse:al},{latexTrigger:[","],kind:"infix",precedence:20,parse:(e,n,t)=>{let i=wi(e,t,n,20,",");return i===null?null:["Delimiter",["Sequence",...i],{str:","}]}},{latexTrigger:[","],kind:"prefix",precedence:20,parse:(e,n)=>{let t=wi(e,n,null,20,",");return t===null?null:["Delimiter",["Sequence",...t],{str:","}]}},{name:"Range",latexTrigger:[".","."],kind:"infix",precedence:800,parse:ll,serialize:(e,n)=>{let t=N(n);if(t.length===0)return"";if(t.length===1)return"1.."+e.serialize(f(n,1));if(t.length===2)return e.wrap(f(n,1),10)+".."+e.wrap(f(n,2),10);if(t.length===3){let i=C(f(n,3)),r=C(f(n,1));return i!==null&&r!==null?e.wrap(f(n,1),10)+".."+e.wrap(r+i,10)+".."+e.wrap(f(n,2),10):e.wrap(f(n,1),10)+"..("+(e.wrap(f(n,1),K)+"+"+e.wrap(f(n,3),K))+").."+e.wrap(f(n,2),10)}return""}},{latexTrigger:[";"],kind:"infix",precedence:19,parse:(e,n,t)=>{let i=wi(e,t,n,19,";");return i===null?null:i.some(r=>y(r)==="Assign")?cl(i):["Delimiter",["Sequence",...i],"';'"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"none",precedence:21,parse:(e,n,t)=>{let i=e.index;return nn(e,"where")?fo(e,n,t):(e.index=i,null)}},{symbolTrigger:"where",kind:"infix",associativity:"none",precedence:21,parse:(e,n,t)=>fo(e,n,t)},{name:"Block",serialize:(e,n)=>{let t=N(n);return!t||t.length===0?"":t.filter(r=>y(r)!=="Declare").map(r=>e.serialize(r)).join("; ")}},{name:"If",serialize:(e,n)=>{let t=N(n);return!t||t.length<3?"":I(["\\text{if }",e.serialize(t[0]),"\\text{ then }",e.serialize(t[1]),"\\text{ else }",e.serialize(t[2])])}},{name:"Loop",serialize:(e,n)=>{let t=N(n);if(!t||t.length<2)return"";let i=t[0],r=t[1];if(y(r)==="Element"){let s=f(r,1),o=f(r,2);if(y(o)==="Range"){let a=f(o,1),u=f(o,2);return I(["\\text{for }",e.serialize(s),"\\text{ from }",e.serialize(a),"\\text{ to }",e.serialize(u),"\\text{ do }",e.serialize(i)])}}return I(["\\operatorname{Loop}(",e.serialize(i),", ",e.serialize(r),")"])}},{name:"Break",serialize:()=>"\\text{break}"},{name:"Continue",serialize:()=>"\\text{continue}"},{name:"Return",serialize:(e,n)=>{let t=f(n,1);return!t||S(t)==="Nothing"?"\\text{return}":I(["\\text{return }",e.serialize(t)])}},{symbolTrigger:"if",kind:"prefix",precedence:245,parse:(e,n)=>lo(e,n)},{symbolTrigger:"for",kind:"prefix",precedence:245,parse:(e,n)=>co(e,n)},{symbolTrigger:"break",kind:"prefix",precedence:245,parse:()=>["Break"]},{symbolTrigger:"continue",kind:"prefix",precedence:245,parse:()=>["Continue"]},{symbolTrigger:"return",kind:"prefix",precedence:245,parse:(e,n)=>["Return",e.parseExpression(n)??"Nothing"]},{name:"String",latexTrigger:["\\text"],parse:(e,n)=>{let t=e.index;return nn(e,"if")?lo(e,n):(e.index=t,nn(e,"for")?co(e,n):(e.index=t,nn(e,"break")?["Break"]:(e.index=t,nn(e,"continue")?["Continue"]:(e.index=t,nn(e,"return")?["Return",e.parseExpression(n)??"Nothing"]:(e.index=t,Pe(e))))))},serialize:(e,n)=>{let t=N(n);return t.length===0?"\\text{}":I(["\\text{",t.map(i=>e.serialize(i)).join(""),"}"])}},{name:"Subscript",latexTrigger:["_"],kind:"infix",serialize:(e,n)=>J(n)===2?e.serialize(f(n,1))+"_{"+e.serialize(f(n,2))+"}":"_{"+e.serialize(f(n,1))+"}"},{name:"Superplus",latexTrigger:["^","+"],kind:"postfix"},{name:"Subplus",latexTrigger:["_","+"],kind:"postfix"},{name:"Superminus",latexTrigger:["^","-"],kind:"postfix",parse:(e,n)=>e.options.strict===!1&&/^[0-9]$/.test(e.peek)?null:["Superminus",n]},{name:"Subminus",latexTrigger:["_","-"],kind:"postfix"},{latexTrigger:["^","*"],kind:"postfix",parse:(e,n)=>["Superstar",n]},{latexTrigger:["_","*"],kind:"postfix",parse:(e,n)=>["Substar",n]},{name:"Substar",latexTrigger:["_","\\star"],kind:"postfix"},{name:"Superdagger",latexTrigger:["^","\\dagger"],kind:"postfix"},{latexTrigger:["^","\\dag"],kind:"postfix",parse:(e,n)=>["Superdagger",n]},{name:"Prime",latexTrigger:["^","\\prime"],kind:"postfix",parse:(e,n)=>De(e,n,1),serialize:(e,n)=>{let t=C(f(n,2))??1,i=e.serialize(f(n,1));return t===1?i+"^\\prime":t===2?i+"^\\doubleprime":t===3?i+"^\\tripleprime":i+"^{("+e.serialize(f(n,2))+")}"}},{latexTrigger:"^{\\prime\\prime}",kind:"postfix",parse:(e,n)=>De(e,n,2)},{latexTrigger:"^{\\prime\\prime\\prime}",kind:"postfix",parse:(e,n)=>De(e,n,3)},{latexTrigger:["^","\\doubleprime"],kind:"postfix",parse:(e,n)=>De(e,n,2)},{latexTrigger:["^","\\tripleprime"],kind:"postfix",parse:(e,n)=>De(e,n,3)},{latexTrigger:"'",kind:"postfix",precedence:810,parse:(e,n)=>De(e,n,1)},{latexTrigger:"\\prime",kind:"postfix",precedence:810,parse:(e,n)=>De(e,n,1)},{latexTrigger:"\\doubleprime",kind:"postfix",precedence:810,parse:(e,n)=>De(e,n,2)},{latexTrigger:"\\tripleprime",kind:"postfix",precedence:810,parse:(e,n)=>De(e,n,3)},{latexTrigger:["^","<{>","("],kind:"postfix",parse:(e,n,t)=>{let i=S(n);if(!i||!e.getSymbolType(i).matches("function"))return null;e.addBoundary([")"]);let r=e.parseExpression(t);return!e.matchBoundary()||!e.match("<}>")?null:["Derivative",n,r]}},{name:"InverseFunction",latexTrigger:"^{-1",kind:"postfix",parse:(e,n)=>{if(y(n)==="Matrix")return e.match("<}>"),["Inverse",n];let t=S(n);if(!t)return null;let i=e.getSymbolType(t);if(i.matches(new ce("matrix")))return e.match("<}>"),["Inverse",n];if(!i.matches("function"))return null;let r=0;for(;!e.atEnd&&!e.match("<}>");)if(e.match("'"))r++;else if(e.match("\\prime"))r++;else if(e.match("\\doubleprime"))r+=2;else if(e.match("\\tripleprime"))r+=3;else return null;return r===1?["Derivative",["InverseFunction",n]]:r>0?["Derivative",["InverseFunction",n],r]:["InverseFunction",n]},serialize:(e,n)=>e.serialize(f(n,1))+"^{-1}"},{name:"Derivative",serialize:(e,n)=>{let t=C(f(n,2))??1,i=e.serialize(f(n,1));return t===1?i+"^{\\prime}":t===2?i+"^{\\doubleprime}":t===3?i+"^{\\tripleprime}":i+"^{("+e.serialize(f(n,2))+")}"}},{name:"D",serialize:(e,n)=>{if(y(n)!=="D")return"D";let t=f(n,1),i=f(n,2);if(!t||!i)return"D";let r=1,s=t;for(;y(s)==="D";){let l=f(s,2);if(S(l)===S(i))r++,s=f(s,1);else break}let o=s;y(s)==="Function"&&(o=f(s,1)??s);let a=e.serialize(o),u=e.serialize(i);return r===1?`\\frac{\\mathrm{d}}{\\mathrm{d}${u}}${a}`:`\\frac{\\mathrm{d}^{${r}}}{\\mathrm{d}${u}^{${r}}}${a}`}},{name:"NewtonDerivative1",latexTrigger:["\\dot"],kind:"prefix",precedence:740,parse:e=>{let n=e.parseGroup();if(n===null)return null;let t=e.options.timeDerivativeVariable;return["D",n,t]}},{name:"NewtonDerivative2",latexTrigger:["\\ddot"],kind:"prefix",precedence:740,parse:e=>{let n=e.parseGroup();if(n===null)return null;let t=e.options.timeDerivativeVariable;return["D",["D",n,t],t]}},{name:"NewtonDerivative3",latexTrigger:["\\dddot"],kind:"prefix",precedence:740,parse:e=>{let n=e.parseGroup();if(n===null)return null;let t=e.options.timeDerivativeVariable;return["D",["D",["D",n,t],t],t]}},{name:"NewtonDerivative4",latexTrigger:["\\ddddot"],kind:"prefix",precedence:740,parse:e=>{let n=e.parseGroup();if(n===null)return null;let t=e.options.timeDerivativeVariable;return["D",["D",["D",["D",n,t],t],t],t]}},{name:"EulerDerivative",latexTrigger:["D"],kind:"expression",parse:e=>{let n=1,t=null,i=!1;for(;!i;)if(e.match("_")){if(t=e.parseGroup()??e.parseToken(),!t)return null}else if(e.match("^")){let o=e.parseGroup()??e.parseToken();n=C(o)??1}else i=!0;if(!t)return null;e.skipSpace();let r=e.parseExpression({minPrec:740});if(!r)return null;let s=r;for(let o=0;o<n;o++)s=["D",s,t];return s}},{kind:"environment",name:"Which",symbolTrigger:"cases",parse:Ai,serialize:(e,n)=>{let t=[],i=N(n);if(i.length>0)for(let r=0;r<=i.length-2;r+=2){let s=[];s.push(e.serialize(i[r+1])),s.push(e.serialize(i[r])),t.push(s.join("&"))}return I(["\\begin{cases}",t.join("\\\\"),"\\end{cases}"])}},{kind:"environment",symbolTrigger:"dcases",parse:Ai},{kind:"environment",symbolTrigger:"rcases",parse:Ai}];function Pe(e,n){if(!e.match("<{>"))return"''";let t=[],i="",r=null,s=()=>{r!==null&&i?t.push(["Annotated",`'${i}'`,_i(r)]):i&&t.push(`'${i}'`),i="",r=null};for(;!e.atEnd&&!e.match("<}>");)if(e.peek==="<{>")s(),t.push(Pe(e));else if(e.match("\\textbf"))s(),t.push(Pe(e,{fontWeight:"bold"}));else if(e.match("\\textmd"))s(),t.push(Pe(e,{fontStyle:"normal"}));else if(e.match("\\textup"))s(),t.push(Pe(e,{fontStyle:"normal"}));else if(e.match("\\textsl"))s(),t.push(Pe(e,{fontStyle:"italic"}));else if(e.match("\\textit"))s(),t.push(Pe(e,{fontStyle:"italic"}));else if(e.match("\\texttt"))s(),t.push(Pe(e,{fontFamily:"monospace"}));else if(e.match("\\textsf"))s(),t.push(Pe(e,{fontFamily:"sans-serif"}));else if(e.match("\\textcolor")){let a=e.index,u=e.parseStringGroup(),l=e.parseExpression();u!==null&&l!==null?t.push(["Annotated",l,{dict:{color:u}}]):(e.index=a,i+="\\textcolor")}else if(e.match("\\color")){let a=e.parseStringGroup();a!==null&&(s(),r={color:a})}else if(e.match("<space>"))i+=" ";else if(e.match("<$>")){let a=e.index,u=e.parseExpression()??"Nothing";e.skipSpace(),e.match("<$>")?t.push(u):(i+="$",e.index=a)}else if(e.match("<$$>")){let a=e.index,u=e.parseExpression()??"Nothing";e.skipSpace(),e.match("<$$>")?t.push(u):(i+="$$",e.index=a)}else{let a=e.parseChar()??e.nextToken();i+={"\\enskip":"\u2002","\\enspace":"\u2002","\\quad":"\u2003","\\qquad":"\u2003\u2003","\\space":"\u2003","\\ ":"\u2003","\\;":"\u2004","\\,":"\u2009","\\:":"\u205F","\\!":"","\\{":"{","\\}":"}","\\$":"$","\\&":"&","\\#":"#","\\%":"%","\\_":"_","\\textbackslash":"\\","\\textasciitilde":"~","\\textasciicircum":"^","\\textless":"<","\\textgreater":">","\\textbar":"|","\\textunderscore":"_","\\textbraceleft":"{","\\textbraceright":"}","\\textasciigrave":"`","\\textquotesingle":"'","\\textquotedblleft":"\u201C","\\textquotedblright":"\u201D","\\textquotedbl":'"',"\\textquoteleft":"\u2018","\\textquoteright":"\u2019","\\textbullet":"\u2022","\\textdagger":"\u2020","\\textdaggerdbl":"\u2021","\\textsection":"\xA7","\\textparagraph":"\xB6","\\textperiodcentered":"\xB7","\\textellipsis":"\u2026","\\textemdash":"\u2014","\\textendash":"\u2013","\\textregistered":"\xAE","\\texttrademark":"\u2122","\\textdegree":"\xB0"}[a]??a}s();let o;return t.length===1?o=t[0]:t.every(a=>L(a)!==null)?o="'"+t.map(a=>L(a)).join()+"'":o=["Text",...t],n?["Annotated",o,_i(n)]:o}function rl(e,n){return n===null?"":I(Tt(n,t=>{let i=L(t);return i===null?e.serialize(t):i==="<{>"?"{":i==="<}>"?"}":i==="<$>"?"$":i==="<$$>"?"$$":i==="<space>"?" ":i}))}function sl(e){return e===null?"":e.replace(/[{}\[\]\\:\-\$%]/g,n=>({"{":"\\lbrace ","}":"\\rbrace ","[":"\\lbrack ","]":"\\rbrack ",":":"\\colon ","\\":"\\backslash "})[n]??"\\"+n)}function ol(e,n){let t=f(n,2);return t?y(t)==="LatexString"?L(f(t,1))??"":y(t)==="Hold"?e.serialize(f(t,1)):e.serialize(t):""}function De(e,n,t){for(;!e.atEnd;)if(e.match("'")||e.match("\\prime"))t++;else if(e.match("\\doubleprime"))t+=2;else if(e.match("\\tripleprime"))t+=3;else break;let i=y(n);if(i==="Derivative"||i==="Prime"){let a=C(f(n,2))??1;return[i,V(f(n,1)),a+t]}let r=S(n),s=r&&e.getSymbolType(r).matches("function")||y(n);e.skipSpace();let o=e.parseArguments("enclosure");if(o&&o.length>0){let a=o[0],u=S(a)??"x",c=typeof n=="string"?[n,...o]:["Apply",n,...o];for(let p=0;p<t;p++)c=["D",c,u];return c}return s?t===1?["Derivative",n]:["Derivative",n,t]:t===1?["Prime",V(n)]:["Prime",V(n),t]}function al(e,n){if(z(n))return["Delimiter"];let t=y(n);if(t==="Delimiter"&&f(n,2)!==null){let i=L(f(n,2));if(i?.length===1)return["Delimiter",f(n,1)??"Nothing",{str:`(${i})`}]}return t==="Matrix"&&(L(f(n,2))??"..")===".."?["Matrix",f(n,1)]:["Delimiter",n]}function mo(e,n){if(z(n))return["List"];let t=y(n);if(t==="Range"||t==="Linspace")return n;if(t==="Sequence")return["List",...N(n)];if(t==="Delimiter"){let i=L(f(n,2))??"...";if(i===";"||i===".;.")return["List",...(N(f(n,1))??[]).map(r=>mo(e,r))];if(i===","||i===".,.")return n=f(n,1),y(n)==="Sequence"?["List",...N(n)]:["List",n??"Nothing"]}return["List",n]}function ul(e,n){return J(n)>1&&N(n).every(t=>{let i=y(t);return Ti(i)||Ni(i)})?I(["\\begin{cases}",Ie("\\\\")(e,n),"\\end{cases}"]):I(["\\bigl\\lbrack",Ie(", ")(e,n),"\\bigr\\rbrack"])}function ll(e,n){if(n===null)return null;let t=e.parseExpression({minPrec:270});if(t===null)return null;if(y(t)==="Range"){let i=f(t,1),r=f(t,2);return i&&r?["Range",n,r,["Subtract",i,n]]:null}return["Range",n,t]}var St={"(":"(",")":")","[":"\\lbrack","]":"\\rbrack","\u27E6":"\\llbrack","\u27E7":"\\rrbrack","{":"\\lbrace","}":"\\rbrace","<":"\\langle",">":"\\rangle","\u2016":"\\Vert","\\":"\\backslash","\u2308":"\\lceil","\u2309":"\\rceil","\u230A":"\\lfloor","\u230B":"\\rfloor","\u231C":"\\ulcorner","\u231D":"\\urcorner","\u231E":"\\llcorner","\u231F":"\\lrcorner","\u23B0":"\\lmoustache","\u23B1":"\\rmoustache"};function kt(e,n,t){let i=(t?.minPrec??0)>=19,r=S(n);if(r&&r.includes("_")){let a=r.indexOf("_"),u=r.substring(0,a),l=r.substring(a+1),c=parseInt(l,10),p=!isNaN(c)&&String(c)===l?c:l,m=p!==""&&(typeof p=="number"||typeof p=="string"&&p.length===1);(e.getSymbolType(u).matches("indexed_collection")||!i&&m)&&(n=["Subscript",u,p])}if(y(n)==="InvisibleOperator"&&J(n)===2&&y(f(n,2))==="Delimiter"){let a=S(f(n,1));if(!a)return null;let u=e.parseExpression({...t??{},minPrec:20});if(u===null)return null;let l=f(f(n,2),1),c=[];return y(l)==="Sequence"?c=[...N(l)]:l&&(c=[l]),["Assign",a,["Function",u,...c??[]]]}if(y(n)==="Subscript"&&S(f(n,1))){let a=S(f(n,1));if(!e.getSymbolType(a).matches("indexed_collection")){let c=f(n,2),p=(c!==null&&typeof c=="string"?c:void 0)??(c!==null&&typeof c=="number"?String(c):void 0);if(p&&i){let m=e.parseExpression({...t??{},minPrec:20});return m===null?null:["Assign",a+"_"+p,m]}}let u=e.parseExpression({...t??{},minPrec:20});if(u===null)return null;let l=f(n,2);return L(l)!==null?["Assign",n,u]:S(l)?["Assign",n,u]:["Assign",n,u]}let s=y(n);if(s){let a=N(n),u=e.parseExpression({...t??{},minPrec:20});return u===null?null:["Assign",s,["Function",u,...a]]}if(!S(n))return null;let o=e.parseExpression({...t??{},minPrec:20});return o===null?null:["Assign",n,o]}function Ai(e){let n=e.parseTabular();if(!n)return["List"];if(n.every(i=>{if(i.length!==1)return!1;let r=y(i[0]);return Ni(r)||Ti(r)}))return["List",...n.map(i=>i[0])];let t=[];for(let i of n)if(i.length===1)t.push("True"),t.push(i[0]);else if(i.length===2){let r=L(i[1]);t.push(r?"True":ki(i[1])??"True"),t.push(i[0])}return["Which",...t]}function nn(e,n){let t=e.index;if(!e.match("<{>"))return e.index=t,!1;for(;e.match("<space>"););let i="";for(;!e.atEnd&&e.peek!=="<}>"&&e.peek!=="<space>";){let r=e.peek;if(/^[a-zA-Z]$/.test(r))i+=r,e.nextToken();else break}for(;e.match("<space>"););return!e.match("<}>")||i!==n?(e.index=t,!1):!0}function xn(e,n){let t=e.index;if(e.skipVisualSpace(),e.match("\\text")){if(nn(e,n))return!0;e.index=t}let i=e.index,r=e.parseSymbol();return r!==null&&S(r)===n?!0:(e.index=i,!1)}function zn(e,n){let t=e.index,i=xn(e,n);return e.index=t,i}function lo(e,n){e.skipVisualSpace();let t=e.parseExpression({minPrec:0,condition:s=>zn(s,"then")});if(t===null||!xn(e,"then"))return null;e.skipVisualSpace();let i=e.parseExpression({minPrec:0,condition:s=>zn(s,"else")});if(i===null||!xn(e,"else"))return null;e.skipVisualSpace();let r=e.parseExpression(n)??"Nothing";return["If",t,i,r]}function co(e,n){let t=e.parseExpression({minPrec:0,condition:a=>zn(a,"from")}),i=t?S(t):null;if(!i||!xn(e,"from"))return null;let r=e.parseExpression({minPrec:0,condition:a=>zn(a,"to")});if(r===null||!xn(e,"to"))return null;let s=e.parseExpression({minPrec:0,condition:a=>zn(a,"do")});return s===null||!xn(e,"do")?null:["Loop",e.parseExpression(n)??"Nothing",["Element",i,["Range",r,s]]]}function fo(e,n,t){let i={minPrec:21,condition:o=>{if(t?.condition?.(o))return!0;let a=o.index;o.skipVisualSpace();let u=o.peek===",";return o.index=a,u}},r=[];do{e.skipVisualSpace();let o=e.parseExpression(i);if(!o)break;r.push(o),e.skipVisualSpace()}while(e.match(","));if(r.length===0)return null;let s=[];for(let o of r){let a=ho(o);y(a)==="Assign"&&s.push(["Declare",f(a,1)]),s.push(a)}return s.push(n),["Block",...s]}function cl(e){let n=[];for(let t of e){let i=ho(t);y(i)==="Assign"&&n.push(["Declare",f(i,1)]),n.push(i)}return["Block",...n]}function ho(e){if(y(e)!=="Assign")return e;let n=f(e,1);if(y(n)!=="Subscript")return e;let t=S(f(n,1));if(!t)return e;let i=f(n,2),r=(typeof i=="string"?i:void 0)??(typeof i=="number"?String(i):void 0);return r?["Assign",`${t}_${r}`,f(e,2)??"Nothing"]:e}function $i(...e){return(n,t)=>{if(!S(t)&&y(t)!=="List")return null;let i=null;return e.length===0&&(i=n.parseGroup()),i??=n.parseExpression({minPrec:0}),i===null||e.length>0&&!n.matchAll(e)||L(i)!==null?null:(y(i)==="Delimiter"&&(i=f(i,1)??"Nothing"),y(i)==="Sequence"?["At",t,...N(i)]:["At",t,i])}}var _t=[["alpha","\\alpha",945],["beta","\\beta",946],["gamma","\\gamma",947],["delta","\\delta",948],["epsilon","\\epsilon",949],["epsilonSymbol","\\varepsilon",1013],["zeta","\\zeta",950],["eta","\\eta",951],["theta","\\theta",952],["thetaSymbol","\\vartheta",977],["iota","\\iota",953],["kappa","\\kappa",954],["kappaSymbol","\\varkappa",1008],["lambda","\\lambda",955],["mu","\\mu",956],["nu","\\nu",957],["xi","\\xi",958],["omicron","\\omicron",959],["pi","\\pi",960],["piSymbol","\\varpi",982],["rho","\\rho",961],["rhoSymbol","\\varrho",1009],["sigma","\\sigma",963],["finalSigma","\\varsigma",962],["tau","\\tau",964],["phi","\\phi",981],["phiLetter","\\varphi",966],["upsilon","\\upsilon",965],["chi","\\chi",967],["psi","\\psi",968],["omega","\\omega",969],["Alpha","\\Alpha",913],["Beta","\\Beta",914],["Gamma","\\Gamma",915],["Delta","\\Delta",916],["Epsilon","\\Epsilon",917],["Zeta","\\Zeta",918],["Eta","\\Eta",919],["Theta","\\Theta",920],["Iota","\\Iota",921],["Kappa","\\Kappa",922],["Lambda","\\Lambda",923],["Mu","\\Mu",924],["Nu","\\Nu",925],["Xi","\\Xi",926],["Omicron","\\Omicron",927],["Rho","\\Rho",929],["Sigma","\\Sigma",931],["Tau","\\Tau",932],["Phi","\\Phi",934],["Upsilon","\\Upsilon",933],["Chi","\\Chi",935],["Psi","\\Psi",936],["Omega","\\Omega",937],["digamma","\\digamma",989],["aleph","\\aleph",8501],["bet","\\beth",8502],["gimel","\\gimel",8503],["dalet","\\daleth",8504],["ell","\\ell",8499],["turnedCapitalF","\\Finv",8498],["turnedCapitalG","\\Game",8513],["weierstrass","\\wp",8472],["eth","\\eth",240],["invertedOhm","\\mho",8487],["hBar","\\hbar",295],["hSlash","\\hslash",8463],["blackClubSuit","\\clubsuit",9827],["whiteHeartSuit","\\heartsuit",9825],["blackSpadeSuit","\\spadesuit",9824],["whiteDiamondSuit","\\diamondsuit",9826],["sharp","\\sharp",9839],["flat","\\flat",9837],["natural","\\natural",9838]],go=[..._t.map(([e,n,t])=>({kind:"symbol",name:e,latexTrigger:[n],parse:e})),..._t.map(([e,n,t])=>({kind:"symbol",latexTrigger:[String.fromCodePoint(t)],parse:e}))];var bo=[{name:"To",latexTrigger:["\\to"],kind:"infix",precedence:270},{latexTrigger:["-",">"],kind:"infix",precedence:270,parse:(e,n,t)=>{if(e.options.strict!==!1)return null;let i=e.parseExpression({...t,minPrec:270});return i===null?null:["To",n,i]}}];var xo=[{name:"True",kind:"symbol",latexTrigger:["\\top"]},{kind:"symbol",latexTrigger:"\\mathrm{True}",parse:"True"},{kind:"symbol",latexTrigger:"\\operatorname{True}",parse:"True"},{kind:"symbol",latexTrigger:"\\mathsf{T}",parse:"True"},{name:"False",kind:"symbol",latexTrigger:["\\bot"]},{kind:"symbol",latexTrigger:"\\operatorname{False}",parse:"False"},{kind:"symbol",latexTrigger:"\\mathsf{F}",parse:"False"},{name:"And",kind:"infix",latexTrigger:["\\land"],precedence:235},{kind:"infix",latexTrigger:["\\wedge"],parse:"And",precedence:235},{kind:"infix",latexTrigger:"\\&",parse:"And",precedence:235},{kind:"infix",latexTrigger:"\\operatorname{and}",parse:"And",precedence:235},{name:"Or",kind:"infix",latexTrigger:["\\lor"],precedence:230},{kind:"infix",latexTrigger:["\\vee"],parse:"Or",precedence:230},{kind:"infix",latexTrigger:"\\parallel",parse:"Or",precedence:230},{kind:"infix",latexTrigger:"\\operatorname{or}",parse:"Or",precedence:230},{name:"Xor",kind:"infix",latexTrigger:["\\veebar"],precedence:232},{name:"Not",kind:"prefix",latexTrigger:["\\lnot"],precedence:880},{kind:"prefix",latexTrigger:["\\neg"],parse:"Not",precedence:880},{name:"Nand",kind:"infix",latexTrigger:["\\barwedge"],precedence:232},{name:"Nor",kind:"infix",latexTrigger:["\u22BD"],precedence:232},{kind:"function",symbolTrigger:"and",parse:"And"},{kind:"function",symbolTrigger:"or",parse:"Or"},{kind:"function",symbolTrigger:"not",parse:"Not"},{name:"Implies",kind:"infix",precedence:220,associativity:"right",latexTrigger:["\\implies"],serialize:"\\implies"},{latexTrigger:["\\Rightarrow"],kind:"infix",precedence:220,associativity:"right",parse:"Implies"},{latexTrigger:["\\rightarrow"],kind:"infix",precedence:220,associativity:"right",parse:"Implies"},{latexTrigger:["\\Longrightarrow"],kind:"infix",precedence:220,associativity:"right",parse:"Implies"},{latexTrigger:["\\longrightarrow"],kind:"infix",precedence:220,associativity:"right",parse:"Implies"},{latexTrigger:["=",">"],kind:"infix",precedence:220,associativity:"right",parse:(e,n,t)=>{if(e.options.strict!==!1)return null;let i=e.parseExpression({...t,minPrec:220});return i===null?null:["Implies",n,i]}},{name:"Equivalent",latexTrigger:["\\iff"],kind:"infix",associativity:"right",precedence:219},{latexTrigger:["\\Leftrightarrow"],kind:"infix",associativity:"right",precedence:219,parse:"Equivalent"},{latexTrigger:["\\leftrightarrow"],kind:"infix",associativity:"right",precedence:219,parse:"Equivalent"},{latexTrigger:["\\Longleftrightarrow"],kind:"infix",associativity:"right",precedence:219,parse:"Equivalent"},{latexTrigger:["\\longleftrightarrow"],kind:"infix",associativity:"right",precedence:219,parse:"Equivalent"},{latexTrigger:["<","=",">"],kind:"infix",precedence:219,associativity:"right",parse:(e,n,t)=>{if(e.options.strict!==!1)return null;let i=e.parseExpression({...t,minPrec:219});return i===null?null:["Equivalent",n,i]}},{latexTrigger:["\\equiv"],kind:"infix",associativity:"right",precedence:219,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:219}),r=e.index,s=e.parseExpression({...t,minPrec:219});return s!==null&&y(s)==="Mod"?["Congruent",n,i,V(f(s,1))]:(e.index=r,["Equivalent",n,V(i)])}},{name:"Proves",kind:"infix",latexTrigger:["\\vdash"],precedence:220,associativity:"right",serialize:"\\vdash"},{name:"Entails",kind:"infix",latexTrigger:["\\vDash"],precedence:220,associativity:"right",serialize:"\\vDash"},{name:"Satisfies",kind:"infix",latexTrigger:["\\models"],precedence:220,associativity:"right",serialize:"\\models"},{name:"ForAll",kind:"prefix",latexTrigger:["\\forall"],precedence:200,serialize:Gn("\\forall"),parse:jn("ForAll")},{name:"Exists",kind:"prefix",latexTrigger:["\\exists"],precedence:200,serialize:Gn("\\exists"),parse:jn("Exists")},{name:"ExistsUnique",kind:"prefix",latexTrigger:["\\exists","!"],precedence:200,serialize:Gn("\\exists!"),parse:jn("ExistsUnique")},{name:"NotForAll",kind:"prefix",latexTrigger:["\\lnot","\\forall"],precedence:200,serialize:Gn("\\lnot\\forall"),parse:jn("NotForAll")},{name:"NotExists",kind:"prefix",latexTrigger:["\\lnot","\\exists"],precedence:200,serialize:Gn("\\lnot\\exists"),parse:jn("NotExists")},{name:"KroneckerDelta",kind:"prefix",latexTrigger:["\\delta","_"],precedence:200,serialize:(e,n)=>{let t=N(n);return t.length===0?"\\delta":t.every(i=>S(i))?`\\delta_{${t.map(i=>e.serialize(i)).join("")}}`:`\\delta_{${t.map(i=>e.serialize(i)).join(", ")}}`},parse:e=>{let n=e.parseGroup();if(n===null){let i=e.parseToken();return i?["KroneckerDelta",i]:null}let t=en(n);return t&&t.length<=2?["KroneckerDelta",...t]:y(n)==="InvisibleOperator"?["KroneckerDelta",...N(n)]:n!==null?["KroneckerDelta",n]:null}},{name:"Boole",kind:"matchfix",openTrigger:"[",closeTrigger:"]",parse:(e,n)=>{let t=y(n);return!t||!Qe.some(i=>i.name===t)?null:["Boole",n]}},{kind:"matchfix",openTrigger:"\\llbracket",closeTrigger:"\\rrbracket",parse:(e,n)=>{let t=y(n);return!t||!Qe.some(i=>i.name===t)?null:["Boole",n]}},{name:"Predicate",serialize:(e,n)=>{let t=N(n);if(t.length===0)return"";let i=t[0],r=typeof i=="string"?i:e.serialize(i);if(t.length===1)return r;let s=t.slice(1).map(o=>e.serialize(o));return`${r}(${s.join(", ")})`}}];function Gn(e){return(n,t)=>{let i=N(t);if(i.length===0)return e;if(i.length===1)return`${e} ${n.serialize(i[0])}`;let r=n.serialize(i[0]),s=n.serialize(i[1]);return`${e} ${r}, ${s}`}}function yo(e,n){return e.peek==="\\to"||e.peek==="\\rightarrow"||e.peek==="\\implies"||e.peek==="\\Rightarrow"||e.peek==="\\iff"||e.peek==="\\Leftrightarrow"||e.peek==="\\land"||e.peek==="\\wedge"||e.peek==="\\lor"||e.peek==="\\vee"||(n.condition?.(e)??!1)}function jn(e){return(n,t)=>{let i=n.index,r=n.options.quantifierScope!=="loose",s=n.parseSymbol(t);if(s){if(n.skipSpace(),n.match(",")||n.match("\\mid")||n.match(".")||n.match(":")||n.match("\\colon")){let l=r?{...t,condition:p=>yo(p,t)}:t;n.enterQuantifierScope();let c=n.parseExpression(l);return n.exitQuantifierScope(),[e,s,V(c)]}n.enterQuantifierScope();let u=n.parseEnclosure();if(n.exitQuantifierScope(),u)return[e,s,V(u)]}n.index=i;let o={...t,condition:u=>u.peek===":"||u.peek==="\\colon"||(t.condition?.(u)??!1)},a=n.parseExpression(o);if(a===null)return null;if(n.skipSpace(),n.matchAny([",","\\mid",":","\\colon"])){let u=r?{...t,condition:c=>yo(c,t)}:t;n.enterQuantifierScope();let l=n.parseExpression(u);return n.exitQuantifierScope(),[e,a,V(l)]}if(n.match("(")){n.enterQuantifierScope();let u=n.parseExpression(t);return n.exitQuantifierScope(),n.match(")")?[e,a,V(u)]:null}return null}}function ke(e,n,t){if(z(e))return null;let i,r=y(e);if(r==="Delimiter"){let l=L(f(e,2));if(l!==","&&l!=="(,)"&&l!=="[,]")return null;let c=f(e,1);y(c)==="Sequence"?i=[...N(c)]:i=c?[c]:[]}else if(r==="Sequence")i=[...N(e)];else return null;if(i.length!==2)return null;let[s,o]=i;return["Interval",n?["Open",s]:s,t?["Open",o]:o]}var vo=[{name:"AlgebraicNumbers",latexTrigger:"\\overline\\Q"},{latexTrigger:"\\bar\\Q",parse:"AlgebraicNumbers"},{name:"ComplexNumbers",latexTrigger:["\\C"]},{latexTrigger:"\\mathbb{C}",parse:"ComplexNumbers"},{name:"ImaginaryNumbers",latexTrigger:["\\imaginaryI","\\R"]},{name:"EmptySet",latexTrigger:["\\emptyset"]},{latexTrigger:["\\varnothing"],parse:"EmptySet"},{name:"Integers",latexTrigger:["\\Z"]},{latexTrigger:"\\mathbb{Z}",parse:"Integers"},{name:"RationalNumbers",latexTrigger:["\\Q"]},{latexTrigger:"\\mathbb{Q}",parse:"RationalNumbers"},{name:"RealNumbers",latexTrigger:["\\R"]},{latexTrigger:"\\mathbb{R}",parse:"RealNumbers"},{name:"TranscendentalNumbers",latexTrigger:"\\R-\\bar\\Q"},{latexTrigger:"\\R\\backslash\\bar\\Q",parse:"TranscendentalNumbers"},{name:"NegativeNumbers",latexTrigger:"\\R_{<0}"},{latexTrigger:"\\R^-",parse:"NegativeNumbers"},{latexTrigger:"\\R^{-}",parse:"NegativeNumbers"},{latexTrigger:"\\R^-",parse:"NegativeNumbers"},{latexTrigger:"\\R_-",parse:"NegativeNumbers"},{latexTrigger:"\\R_{-}",parse:"NegativeNumbers"},{latexTrigger:"\\R^{\\lt}",parse:"NegativeNumbers"},{latexTrigger:"\\R^{<}",parse:"NegativeNumbers"},{latexTrigger:"\\R^{\\lt0}",parse:"NegativeNumbers"},{latexTrigger:"\\R^{<0}",parse:"NegativeNumbers"},{name:"NonPositiveNumbers",latexTrigger:"\\R_{\\le0}"},{latexTrigger:"\\R^{\\leq0}",parse:"NonPositiveNumbers"},{latexTrigger:"\\R^{-0}",parse:"NonPositiveNumbers"},{latexTrigger:"\\R^{\\leq}",parse:"NonPositiveNumbers"},{latexTrigger:"\\R^{0-}",parse:"NonPositiveNumbers"},{name:"PositiveNumbers",latexTrigger:"\\R_{>0}"},{latexTrigger:"\\R^+",parse:"PositiveNumbers"},{latexTrigger:"\\R^{+}",parse:"PositiveNumbers"},{latexTrigger:"\\R_+",parse:"PositiveNumbers"},{latexTrigger:"\\R_{+}",parse:"PositiveNumbers"},{latexTrigger:"\\R^{\\gt}",parse:"PositiveNumbers"},{latexTrigger:"\\R^{\\gt 0}",parse:"PositiveNumbers"},{latexTrigger:"\\R^{>}",parse:"PositiveNumbers"},{latexTrigger:"\\R^{>0}",parse:"PositiveNumbers"},{name:"NonNegativeNumbers",latexTrigger:"\\R_{\\geq0}"},{latexTrigger:"\\R^{0+}",parse:"NonNegativeNumbers"},{latexTrigger:"\\R^{\\geq}",parse:"NonNegativeNumbers"},{name:"ExtendedRealNumbers",latexTrigger:"\\overline\\R"},{latexTrigger:"\\bar\\R",parse:"ExtendedRealNumbers"},{name:"NegativeIntegers",latexTrigger:"\\Z_{<0}"},{latexTrigger:"\\Z_{\\lt0}",parse:"NegativeIntegers"},{latexTrigger:"\\Z^-",parse:"NegativeIntegers"},{latexTrigger:"\\Z^{-}",parse:"NegativeIntegers"},{latexTrigger:"\\Z_-",parse:"NegativeIntegers"},{latexTrigger:"\\Z_{-}",parse:"NegativeIntegers"},{latexTrigger:"\\Z^{\\lt}",parse:"NegativeIntegers"},{name:"NonPositiveIntegers",latexTrigger:"\\Z_{\\le0}"},{latexTrigger:"\\Z_{\\leq0}",parse:"NonPositiveIntegers"},{latexTrigger:"\\Z_{<0}",parse:"NonPositiveIntegers"},{name:"PositiveIntegers",latexTrigger:"\\N^*"},{latexTrigger:"\\Z_{>0}",parse:"PositiveIntegers"},{latexTrigger:"\\Z_{\\gt0}",parse:"PositiveIntegers"},{latexTrigger:"\\Z^{+}",parse:"PositiveIntegers"},{latexTrigger:"\\Z_+",parse:"PositiveIntegers"},{latexTrigger:"\\Z_{+}",parse:"PositiveIntegers"},{latexTrigger:"\\Z^{\\gt}",parse:"PositiveIntegers"},{latexTrigger:"\\Z^{\\gt0}",parse:"PositiveIntegers"},{latexTrigger:"\\N^+",parse:"PositiveIntegers"},{latexTrigger:"\\N^{+}",parse:"PositiveIntegers"},{latexTrigger:"\\N^*",parse:"PositiveIntegers"},{latexTrigger:"\\N^{*}",parse:"PositiveIntegers"},{latexTrigger:"\\N^\\star",parse:"PositiveIntegers"},{latexTrigger:"\\N^{\\star}",parse:"PositiveIntegers"},{latexTrigger:"\\N_1",parse:"PositiveIntegers"},{latexTrigger:"\\N_{1}",parse:"PositiveIntegers"},{name:"NonNegativeIntegers",latexTrigger:["\\N"]},{latexTrigger:"\\Z^{+0}",parse:"NonNegativeIntegers"},{latexTrigger:"\\Z^{\\geq}",parse:"NonNegativeIntegers"},{latexTrigger:"\\Z^{\\geq0}",parse:"NonNegativeIntegers"},{latexTrigger:"\\Z^{0+}",parse:"NonNegativeIntegers"},{latexTrigger:"\\mathbb{N}",parse:"NonNegativeIntegers"},{latexTrigger:"\\N_0",parse:"NonNegativeIntegers"},{latexTrigger:"\\N_{0}",parse:"NonNegativeIntegers"},{name:"ExtendedIntegers",latexTrigger:"\\overline\\Z"},{latexTrigger:"\\bar\\Z",parse:"ExtendedIntegers"},{name:"ExtendedRationalNumbers",latexTrigger:"\\overline\\Q"},{latexTrigger:"\\bar\\Q",parse:"ExtendedRationalNumbers"},{name:"ExtendedComplexNumbers",latexTrigger:"\\overline\\C"},{latexTrigger:"\\bar\\C",parse:"ExtendedComplexNumbers"},{latexTrigger:["^","\\complement"],kind:"postfix",parse:(e,n)=>["Complement",n]},{name:"Complement",latexTrigger:["^","<{>","\\complement","<}>"],kind:"postfix"},{name:"Intersection",latexTrigger:["\\cap"],kind:"infix",precedence:350},{name:"Interval",serialize:Eo},{kind:"matchfix",openTrigger:["["],closeTrigger:[")"],parse:(e,n)=>ke(n,!1,!0)},{kind:"matchfix",openTrigger:["\\lbrack"],closeTrigger:["\\rparen"],parse:(e,n)=>ke(n,!1,!0)},{kind:"matchfix",openTrigger:["\\lbrack"],closeTrigger:[")"],parse:(e,n)=>ke(n,!1,!0)},{kind:"matchfix",openTrigger:["["],closeTrigger:["\\rparen"],parse:(e,n)=>ke(n,!1,!0)},{kind:"matchfix",openTrigger:["("],closeTrigger:["]"],parse:(e,n)=>ke(n,!0,!1)},{kind:"matchfix",openTrigger:["\\lparen"],closeTrigger:["\\rbrack"],parse:(e,n)=>ke(n,!0,!1)},{kind:"matchfix",openTrigger:["\\lparen"],closeTrigger:["]"],parse:(e,n)=>ke(n,!0,!1)},{kind:"matchfix",openTrigger:["("],closeTrigger:["\\rbrack"],parse:(e,n)=>ke(n,!0,!1)},{kind:"matchfix",openTrigger:["]"],closeTrigger:["["],parse:(e,n)=>ke(n,!0,!0)},{kind:"matchfix",openTrigger:["\\rbrack"],closeTrigger:["\\lbrack"],parse:(e,n)=>ke(n,!0,!0)},{name:"Multiple",serialize:Eo},{name:"Union",latexTrigger:["\\cup"],kind:"infix",precedence:350},{name:"Set",kind:"matchfix",openTrigger:"{",closeTrigger:"}",parse:(e,n)=>z(n)?"EmptySet":(y(n)=="Delimiter"&&L(f(n,2))===","&&(n=f(n,1)),y(n)!=="Sequence"?["Set",n]:["Set",...N(n)]),serialize:(e,n)=>I(["\\lbrace",N(n).map(t=>e.serialize(t)).join(", "),"\\rbrace"])},{name:"SetMinus",latexTrigger:["\\setminus"],kind:"infix",precedence:650},{name:"SymmetricDifference",latexTrigger:["\\triangle"],kind:"infix",precedence:D},{latexTrigger:["\\ni"],kind:"infix",associativity:"none",precedence:160,parse:(e,n,t)=>{let i=e.parseExpression(t);return i===null?null:["Element",i,n]}},{name:"Element",latexTrigger:["\\in"],kind:"infix",precedence:240},{name:"NotElement",latexTrigger:["\\notin"],kind:"infix",precedence:240},{name:"NotSubset",latexTrigger:["\\nsubset"],kind:"infix",associativity:"none",precedence:240},{name:"NotSuperset",latexTrigger:["\\nsupset"],kind:"infix",associativity:"none",precedence:240},{name:"NotSubsetNotEqual",latexTrigger:["\\nsubseteq"],kind:"infix",associativity:"none",precedence:240},{name:"NotSupersetNotEqual",latexTrigger:["\\nsupseteq"],kind:"infix",associativity:"none",precedence:240},{name:"SquareSubset",latexTrigger:["\\sqsubset"],kind:"infix",associativity:"none",precedence:265},{name:"SquareSubsetEqual",latexTrigger:["\\sqsubseteq"],kind:"infix",associativity:"none",precedence:265},{name:"SquareSuperset",latexTrigger:["\\sqsupset"],kind:"infix",associativity:"none",precedence:265},{name:"SquareSupersetEqual",latexTrigger:["\\sqsupseteq"],kind:"infix",associativity:"none",precedence:265},{name:"Subset",latexTrigger:["\\subset"],kind:"infix",associativity:"none",precedence:240},{latexTrigger:["\\subsetneq"],kind:"infix",associativity:"none",precedence:240,parse:"Subset"},{latexTrigger:["\\varsubsetneqq"],kind:"infix",associativity:"none",precedence:240,parse:"Subset"},{name:"SubsetEqual",latexTrigger:["\\subseteq"],kind:"infix",associativity:"none",precedence:240},{name:"Superset",latexTrigger:["\\supset"],kind:"infix",associativity:"none",precedence:240},{latexTrigger:["\\supsetneq"],kind:"infix",associativity:"none",precedence:240,parse:"Superset"},{latexTrigger:["\\varsupsetneq"],kind:"infix",associativity:"none",precedence:240,parse:"Superset"},{name:"SupersetEqual",latexTrigger:["\\supseteq"],kind:"infix",associativity:"none",precedence:240}];function Eo(e,n){if(n===null)return"";let t=y(n);if(!t)return"";if(t==="Set")return J(n)===0?"\\emptyset":J(n)===2&&y(f(n,2))==="Condition"?I(["\\left\\lbrace",e.serialize(f(n,1)),"\\middle\\mid",e.serialize(f(n,2)),"\\right\\rbrace"]):I(["\\left\\lbrace",...N(n).map(r=>e.serialize(r)+" ,"),"\\right\\rbrace"]);if(t==="Range")return I(["\\mathopen\\lbrack",e.serialize(f(n,1)),", ",e.serialize(f(n,2)),"\\mathclose\\rbrack"]);if(t==="Interval"){let r=f(n,1),s=f(n,2),o=!1,a=!1;return y(r)==="Open"&&(r=f(r,1),o=!0),y(s)==="Open"&&(s=f(s,1),a=!0),I([o?"\\lparen":"\\lbrack",e.serialize(r),", ",e.serialize(s),a?"\\rparen":"\\rbrack"])}let i=e.numericSetStyle(n,e.level);return""}function En(e,n,t){e.indexOf("#1")<0&&e.indexOf("#2")<0&&(e=`#1 ${e} #2`);let i=e.split(/(#\d+)/).filter(r=>r.trim()!=="").map(r=>r.trim());return I(i.map(r=>{switch(r){case"#1":return n;case"#2":return t;default:return r}}))}function Mt(e,n){if(n==="none")return e;if(n==="0...360"){let t=e%360;return(t<0?t+360:t)||0}if(n==="-180...180"){let t=e%360;return t>180&&(t-=360),t<-180&&(t+=360),t||0}return e}function fl(e){let n=e<0?-1:1,t=Math.abs(e),i=Math.floor(t),r=(t-i)*60,s=Math.floor(r),o=(r-s)*60,a=Math.round(o*1e3)/1e3,u=s,l=i;return a>=60&&(a=0,u++),u>=60&&(u=0,l++),{deg:n*l||0,min:n*u||0,sec:a===0?0:n*a}}function wt(e){let{deg:n,min:t,sec:i}=fl(e),r=`${n}\xB0`;if(Math.abs(i)>.001){let s=i%1===0?i.toString():i.toFixed(2);r+=`${Math.abs(t)}'${Math.abs(Number(s))}"`}else Math.abs(t)>0?r+=`${Math.abs(t)}'`:r+=`0'0"`;return r}function pl(e){if(y(e)!=="Multiply")return[[],[]];let n=[],t=[];for(let i of N(e))if(y(i)==="Power"){let r=f(i,1),s=f(i,2);if(y(s)==="Negate"){let o=f(s,1);r&&o&&t.push(["Power",r,o])}else{let o=C(s)??NaN;o===-1?r&&t.push(r):o<0?r&&t.push(["Power",r,-o]):n.push(i)}}else if(y(i)==="Rational"&&J(i)===2||y(i)==="Divide"){let r=f(i,1),s=f(i,2);C(r)!==1&&n.push(r),C(s)!==1&&t.push(s)}else{let r=bn(i);r!==null?(r[0]!==1&&n.push(r[0]),t.push(r[1])):n.push(i)}return[n,t]}function ml(e){let n=e.parseOptionalGroup(),t=e.parseGroup()??e.parseToken();return z(t)?n!==null?["Root",dn,V(n)]:["Sqrt",dn]:n!==null?["Root",t,n]:["Sqrt",t]}function dl(e){if(typeof e=="number")return-e;if(typeof e=="string")return e.startsWith("-")?e.slice(1):e.startsWith("+")?"-"+e.slice(1):"-"+e;let n=e.num;return n.startsWith("-")?{num:n.slice(1)}:n.startsWith("+")?{num:"-"+n.slice(1)}:{num:"-"+n}}function Zn(e,n,t,i){return t==null?"\\sqrt{}":(i=i??2,n==="solidus"?e.wrapShort(t)+"^{1/"+e.serialize(i)+"}":n==="quotient"?e.wrapShort(t)+"^{\\frac{1}{"+e.serialize(i)+"}}":C(i)===2?"\\sqrt{"+e.serialize(t)+"}":"\\sqrt["+e.serialize(i)+"]{"+e.serialize(t)+"}")}function hl(e,n){e.level-=1;let t=y(n),i="",r=f(n,1);if(t==="Negate")i="-"+e.wrap(r,K+1);else if(t==="Subtract"){i=e.wrap(r,K);let s=f(n,2);if(s!==null){let o=e.wrap(s,K);o[0]==="-"?i+="+"+o.slice(1):o[0]==="+"?i+="-"+o.slice(1):i=i+"-"+o}}else if(t==="Add"){if(e.options.prettify&&J(n)===2&&e.options.invisiblePlus!=="+"){let[a,u]=[f(n,1),f(n,2)],[l,c]=[a,u],p=C(l),m=bn(c);if((p===null||m===null)&&([l,c]=[u,a],p=C(l),m=bn(c)),p!==null&&m!==null&&isFinite(p)&&Number.isInteger(p)&&p>=0&&p<=1e3&&isFinite(m[0])&&isFinite(m[1])&&m[0]>0&&m[0]<=100&&m[1]<=100)return i=En(e.options.invisiblePlus,e.serialize(l),e.serialize(c)),e.level+=1,i}if(e.options.prettify&&J(n)===2){let[a,u]=Yn(r),[l,c]=Yn(f(n,2));if(u<0&&c>0)return i=e.wrap(l,K)+"-"+e.wrap(a,K),e.level+=1,i}i=e.serialize(r);let s=J(n)+1,o=N(n);for(let a=2;a<s;a++)if(r=o[a-1],e.options.prettify){let[u,l]=Yn(r),c=e.wrap(u,K);l>0?c.startsWith("+")||c.startsWith("-")?i+=c:i+="+"+c:c.startsWith("+")?i+="-"+c.slice(1):c.startsWith("-")?i+="+"+c.slice(1):i+="-"+c}else{let u=e.wrap(r,K);u[0]==="-"||u[0]==="+"?i+=u:i+="+"+u}}return e.level+=1,i}function Mo(e,n){if(n===null)return"";e.level-=1;let t="";if(e.options.prettify===!0){let[u,l]=pl(n);l.length>0&&(l.length===1&&l[0]===1?u.length===0?t="1":u.length===1?t=e.serialize(u[0]):t=Mo(e,["Multiply",...u]):t=e.serialize(["Divide",u.length===1?u[0]:["Multiply",...u],l.length===1?l[0]:["Multiply",...l]]))}if(t)return e.level+=1,t;let i=!1,r=null,s=J(n)+1,o=N(n);e.options.prettify===!0&&o.length===2&&Ke(o[1])&&!Ke(o[0])&&(o=[o[1],o[0]]);let a=!1;for(let u=1;u<s;u++){if(r=o[u-1],r===null)continue;let l;if(Ke(r)){l=e.serialize(r),l==="-1"&&!t?(t="",i=!i):(l[0]==="-"&&(l=l.slice(1),i=!i),t?t=En(e.options.multiply,t,l):t=l),a=!0;continue}if(y(r)==="Power"){let c=bn(f(r,2));if(c!=null){let[p,m]=c;if(p===1&&m!==null){t+=Zn(e,e.rootStyle(r,e.level),f(r,1),m),a=!1;continue}}}if(y(r)==="Power"&&!isNaN(C(f(r,1))??NaN)){l=e.serialize(r),t?t=En(e.options.multiply,t,l):t=l,a=!0;continue}if(y(r)==="Negate"&&(r=f(r,1),i=!i),l=e.wrap(r,he),!t)t=l;else{let c=y(r);a&&(c==="Divide"||c==="Rational")?t=En(e.options.multiply,t,l):e.options.invisibleMultiply?t=En(e.options.invisibleMultiply,t,l):t=I([t,l])}a=!1}return e.level+=1,i?"-"+t:t}function At(e){let n=e.parseGroup(),t=null;if(n===null?(n=e.parseToken(),t=e.parseToken()):t=e.parseGroup(),n=V(n),t=V(t),y(n)==="PartialDerivative"&&(y(t)==="PartialDerivative"||y(t)==="Multiply"&&y(f(t,1))==="PartialDerivative")){let s=f(n,3)??null,o=f(n,1);o==null&&(o=V(e.parseExpression()));let a=[];if(y(t)==="Multiply"){for(let u of N(t))if(y(u)==="PartialDerivative"){let l=f(u,2);l&&a.push(l)}}else{let u=f(t,2);u&&a.push(u)}return a.length>1&&(a=["List",...a]),["PartialDerivative",o,...a,s===null?1:s]}let i=S(n);if(i==="d"||i==="d_upright"||i==="differentialD"){let s=[],o=a=>{if(!a)return;let u=S(a);if(u&&u!=="d"&&u!=="d_upright"&&u!=="differentialD"){s.push(a);return}let l=y(a);if(l==="Sequence"||l==="Multiply"||l==="InvisibleOperator")for(let c of N(a))o(c)};if(o(t),s.length===0){let a=S(t);a&&a.length>1&&a[0]==="d"&&s.push(a.slice(1))}if(s.length>0)return["D",V(e.parseExpression()),...s]}return["Divide",n,t]}function No(e,n){if(n===null)return"";let t=V(f(n,1)),i=V(f(n,2)),r=e.options.prettify?e.fractionStyle(n,e.level):"quotient";if(r==="inline-solidus"||r==="nice-solidus"){let u=e.wrapShort(t),l=e.wrapShort(i);return r==="inline-solidus"?`${u}/${l}`:`{}^{${u}}\\!\\!/\\!{}_{${l}}`}else{if(r==="reciprocal")return C(t)===1?e.wrap(i)+"^{-1}":e.wrap(t)+e.wrap(i)+"^{-1}";if(r==="factor")return C(i)===1?e.wrap(t):"\\frac{1}{"+e.serialize(i)+"}"+e.wrapString(e.serialize(t),e.groupStyle(n,1))}let s="\\frac";r==="block-quotient"?s="\\dfrac":r==="inline-quotient"&&(s="\\tfrac");let o=e.serialize(t),a=e.serialize(i);return`${s}{${o}}{${a}}`}function Ci(e,n){if(!n)return"";let t=y(n),i=V(f(n,1));if(t==="Sqrt")return Zn(e,e.rootStyle(n,e.level-1),i,2);let r=V(f(n,2));if(t==="Root")return Zn(e,e.rootStyle(n,e.level-1),i,r);if(e.options.prettify){let o=C(r)??1;if(o===-1)return e.serialize(["Divide","1",i]);if(o<0)return e.serialize(["Divide","1",["Power",i,-o]]);if(y(r)==="Divide"||y(r)==="Rational"){let a=C(f(r,1)),u=C(f(r,2));if(a===1){let l=e.rootStyle(n,e.level);return Zn(e,l,i,f(r,2))}if(a===-1)return u===2?e.serialize(["Divide","1",["Sqrt",i]]):e.serialize(["Divide","1",["Root",i,f(r,2)??dn]]);if(u===2)return`${e.serialize(["Sqrt",i])}^{${e.serialize(f(r,1))}}`}else if(y(r)==="Power"&&C(f(r,2))===-1){let a=e.rootStyle(n,e.level);return Zn(e,a,i,f(r,1))}}let s=o=>o.startsWith("-")?e.wrapString(o,"normal"):o;if(y(i)==="Power"){let o=f(i,1),a=f(i,2),u=s(e.wrapShort(o)),l=e.wrapShort(a);return`
|
|
6
|
+
${u}^{${mn("^",l,e.serialize(r))}}`}return mn("^",s(e.wrapShort(i)),e.serialize(r))}function Un(e,n){e.skipSpace();let t=e.index,i=e.parseNumber(),r=null,s=null;if(i!==null&&(e.match("'")||e.match("\\prime"))){r=C(i),e.skipSpace();let u=e.index,l=e.parseNumber();l!==null&&(e.match('"')||e.match("\\doubleprime"))?s=C(l):e.index=u}else return e.index=t,["Degrees",n];let o=C(n);if(o!==null&&r!==null){let u=o+r/60;return s!==null&&(u+=s/3600),["Degrees",u]}let a=[["Quantity",n,"deg"]];return a.push(["Quantity",i,"arcmin"]),s!==null&&a.push(["Quantity",s,"arcsec"]),["Add",...a]}var wo=[{name:"CatalanConstant",symbolTrigger:"G"},{name:"GoldenRatio",latexTrigger:"\\varphi"},{name:"EulerGamma",latexTrigger:"\\gamma"},{name:"Degrees",latexTrigger:["\\degree"],kind:"postfix",precedence:880,parse:(e,n)=>Un(e,n),serialize:(e,n)=>{let t=e.options,i=f(n,1);if(t.dmsFormat||t.angleNormalization&&t.angleNormalization!=="none"){let r=C(i);if(r!==null){let s=r;return t.angleNormalization&&t.angleNormalization!=="none"&&(s=Mt(s,t.angleNormalization)),t.dmsFormat?wt(s):`${s}\xB0`}}return I([e.serialize(i),"\\degree"])}},{latexTrigger:["\\degree"],kind:"postfix",precedence:880,parse:(e,n)=>Un(e,n)},{latexTrigger:["^","<{>","\\circ","<}>"],kind:"postfix",parse:(e,n)=>Un(e,n)},{latexTrigger:["^","\\circ"],kind:"postfix",parse:(e,n)=>Un(e,n)},{latexTrigger:["\xB0"],kind:"postfix",precedence:880,parse:(e,n)=>Un(e,n)},{latexTrigger:["\\ang"],parse:e=>{let n=e.parseGroup();return n===null?["Degrees"]:["Degrees",n]}},{name:"DMS",serialize:(e,n)=>{let t=C(f(n,1)),i=C(f(n,2)),r=C(f(n,3));if(t!==null){let o=i??0,a=r??0,u=`${t}\xB0`;return(o!==0||a!==0)&&(u+=`${o}'`),a!==0&&(u+=`${a}"`),u}let s=[];for(let o of[1,2,3]){let a=f(n,o);a!==null&&s.push(e.serialize(a))}return`\\operatorname{DMS}(${s.join(", ")})`}},{latexTrigger:["\\infty"],parse:"PositiveInfinity"},{latexTrigger:["\\infin"],parse:"PositiveInfinity"},{name:"PositiveInfinity",serialize:e=>e.options.positiveInfinity},{name:"NegativeInfinity",serialize:e=>e.options.negativeInfinity},{name:"ComplexInfinity",latexTrigger:["\\tilde","\\infty"],serialize:"\\tilde\\infty"},{latexTrigger:["\\tilde","<{>","\\infty","<}>"],parse:"ComplexInfinity"},{name:"Pi",kind:"symbol",latexTrigger:["\\pi"]},{latexTrigger:["\u03C0"],parse:"Pi"},{name:"ExponentialE",latexTrigger:["\\exponentialE"],parse:"ExponentialE",serialize:"\\exponentialE"},{latexTrigger:"\\operatorname{e}",parse:"ExponentialE"},{latexTrigger:"\\mathrm{e}",parse:"ExponentialE"},{kind:"function",symbolTrigger:"exp",parse:e=>{let n=e.parseArguments("implicit");return n===null?"Exp":["Exp",...n]}},{latexTrigger:"\\exp",parse:e=>{let n=e.parseArguments("implicit");return n===null?"Exp":["Exp",...n]}},{name:"ImaginaryUnit",latexTrigger:["\\imaginaryI"]},{latexTrigger:"\\operatorname{i}",parse:"ImaginaryUnit"},{latexTrigger:"\\mathrm{i}",parse:"ImaginaryUnit"},{name:"Abs",kind:"matchfix",openTrigger:"|",closeTrigger:"|",parse:(e,n)=>z(n)?null:["Abs",n]},{kind:"matchfix",openTrigger:["\\vert"],closeTrigger:["\\vert"],parse:(e,n)=>z(n)?null:["Abs",n]},{symbolTrigger:"abs",kind:"function",parse:"Abs"},{name:"Add",latexTrigger:["+"],kind:"infix",associativity:"any",precedence:K,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:K});if(i===null)return null;if(y(i)==="Negate"){let r=f(i,1);if(Ke(r))return yn("Add",n,dl(r))}return yn("Add",n,i)},serialize:hl},{kind:"prefix",latexTrigger:["+"],precedence:K,parse:(e,n)=>e.parseExpression({...n,minPrec:400})},{name:"Ceil",kind:"matchfix",openTrigger:"\\lceil",closeTrigger:"\\rceil",parse:(e,n)=>z(n)?null:["Ceil",n]},{kind:"matchfix",openTrigger:["\u2308"],closeTrigger:["\u2309"],parse:(e,n)=>z(n)?null:["Ceil",n]},{symbolTrigger:"ceil",kind:"function",parse:"Ceil"},{name:"Chop",symbolTrigger:"chop",kind:"function",parse:"Chop"},{name:"Complex",precedence:K-1,serialize:(e,n)=>{let t=e.serialize(f(n,1)),i=C(f(n,2));if(i===0)return t;let r=i===1?"\\imaginaryI":i===-1?"-\\imaginaryI":I([e.serialize(f(n,2)),"\\imaginaryI"]);return C(f(n,1))===0?r:i!==null&&i<0?I([t,r]):I([t,"+",r])}},{name:"Divide",latexTrigger:"\\frac",precedence:ge,parse:At,serialize:No},{latexTrigger:"\\dfrac",precedence:ge,parse:At},{latexTrigger:"\\tfrac",precedence:ge,parse:At},{latexTrigger:"\\cfrac",precedence:ge,parse:At},{kind:"infix",latexTrigger:"\\over",associativity:"none",precedence:ge,parse:"Divide"},{latexTrigger:["\\/"],kind:"infix",associativity:"left",precedence:ge,parse:"Divide"},{latexTrigger:["/"],kind:"infix",associativity:"left",precedence:ge,parse:"Divide"},{latexTrigger:["\\div"],kind:"infix",associativity:"left",precedence:ge,parse:"Divide"},{name:"Exp",serialize:(e,n)=>{let t=f(n,1);return S(t)||C(t)!==null?I(["\\exponentialE^{",e.serialize(t),"}"]):I(["\\exp",e.wrap(V(t))])}},{name:"Factorial",latexTrigger:["!"],kind:"postfix",precedence:Ei},{name:"Factorial2",latexTrigger:["!","!"],kind:"postfix",precedence:Ei},{name:"Floor",kind:"matchfix",openTrigger:"\\lfloor",closeTrigger:"\\rfloor",parse:(e,n)=>z(n)?null:["Floor",n]},{kind:"matchfix",openTrigger:["\u230A"],closeTrigger:["\u230B"],parse:(e,n)=>z(n)?null:["Floor",n]},{symbolTrigger:"floor",kind:"function",parse:"Floor"},{latexTrigger:["\\Gamma"],parse:"Gamma"},{latexTrigger:["\\zeta"],kind:"function",parse:"Zeta"},{latexTrigger:["\\Beta"],kind:"function",parse:"Beta"},{name:"LambertW",latexTrigger:["\\operatorname{W}"],kind:"function",serialize:(e,n)=>"\\operatorname{W}"+e.wrapArguments(n)},{name:"BesselJ",latexTrigger:["\\operatorname{J}"],kind:"function",serialize:(e,n)=>{let t=f(n,1),i=f(n,2);return t!==null&&i!==null?"\\operatorname{J}_{"+e.serialize(t)+"}"+e.wrapArguments(["BesselJ",i]):"\\operatorname{J}"+e.wrapArguments(n)}},{name:"BesselY",latexTrigger:["\\operatorname{Y}"],kind:"function",serialize:(e,n)=>{let t=f(n,1),i=f(n,2);return t!==null&&i!==null?"\\operatorname{Y}_{"+e.serialize(t)+"}"+e.wrapArguments(["BesselY",i]):"\\operatorname{Y}"+e.wrapArguments(n)}},{name:"BesselI",latexTrigger:["\\operatorname{I}"],kind:"function",serialize:(e,n)=>{let t=f(n,1),i=f(n,2);return t!==null&&i!==null?"\\operatorname{I}_{"+e.serialize(t)+"}"+e.wrapArguments(["BesselI",i]):"\\operatorname{I}"+e.wrapArguments(n)}},{name:"BesselK",latexTrigger:["\\operatorname{K}"],kind:"function",serialize:(e,n)=>{let t=f(n,1),i=f(n,2);return t!==null&&i!==null?"\\operatorname{K}_{"+e.serialize(t)+"}"+e.wrapArguments(["BesselK",i]):"\\operatorname{K}"+e.wrapArguments(n)}},{name:"AiryAi",latexTrigger:["\\operatorname{Ai}"],kind:"function",serialize:(e,n)=>"\\operatorname{Ai}"+e.wrapArguments(n)},{name:"AiryBi",latexTrigger:["\\operatorname{Bi}"],kind:"function",serialize:(e,n)=>"\\operatorname{Bi}"+e.wrapArguments(n)},{name:"GCD",latexTrigger:["\\gcd"],kind:"function"},{symbolTrigger:"gcd",kind:"function",parse:"GCD"},{symbolTrigger:"GCD",kind:"function",parse:"GCD"},{name:"Half",serialize:"\\frac12"},{name:"Lg",latexTrigger:["\\lg"],serialize:(e,n)=>"\\log_{10}"+e.wrapArguments(n),parse:e=>{let n=e.parseArguments("implicit");return n===null?"Lg":["Log",...n,10]}},{name:"Lb",latexTrigger:"\\lb",parse:e=>{let n=e.parseArguments("implicit");return n===null?"Log":["Log",n[0],2]}},{name:"Ln",latexTrigger:["\\ln"],parse:e=>_o("Ln",e),serialize:(e,n)=>"\\ln"+e.wrapArguments(n)},{name:"Log",latexTrigger:["\\log"],parse:e=>_o("Log",e),serialize:(e,n)=>{let[t,i]=N(n);return i?I(["\\log_{",e.serialize(i),"}",e.wrap(t)]):"\\log"+e.wrapArguments(n)}},{name:"LCM",latexTrigger:["\\lcm"],kind:"function"},{symbolTrigger:"lcm",kind:"function",parse:"LCM"},{symbolTrigger:"LCM",kind:"function",parse:"LCM"},{symbolTrigger:"max",kind:"function",parse:"Max",arguments:"implicit"},{symbolTrigger:"min",kind:"function",parse:"Min",arguments:"implicit"},{name:"Max",latexTrigger:"\\max",kind:"function",arguments:"implicit"},{name:"Min",latexTrigger:"\\min",kind:"function",arguments:"implicit"},{name:"Supremum",latexTrigger:"\\sup",kind:"function",arguments:"implicit"},{name:"Infimum",latexTrigger:"\\inf",kind:"function",arguments:"implicit"},{name:"Limit",latexTrigger:"\\lim",kind:"expression",parse:e=>{if(!e.match("_"))return null;let n=e.parseGroup();if(y(n)!=="To")return null;let t=e.parseArguments("implicit");return t?["Limit",["Function",t[0],f(n,1)],f(n,2)]:null},serialize:(e,n)=>{let t=f(n,1),i=f(t,2),r=f(n,2);return I(["\\lim_{",e.serialize(i),"\\to",e.serialize(r),"}",e.serialize(f(t,1))])}},{name:"MinusPlus",latexTrigger:["\\mp"],kind:"infix",associativity:"any",precedence:Re},{name:"Multiply",latexTrigger:["\\times"],kind:"infix",associativity:"any",precedence:he,serialize:Mo},{latexTrigger:["\\cdot"],kind:"infix",associativity:"any",precedence:he,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:he+2});return i===null?null:yn("Multiply",n,i)}},{latexTrigger:["*"],kind:"infix",associativity:"any",precedence:he,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:he+2});return i===null?["Multiply",n,dn]:yn("Multiply",n,i)}},{name:"Mod",latexTrigger:"\\bmod",kind:"infix",precedence:ge,serialize:(e,n)=>{if(J(n)!==2)return"";let t=e.serialize(f(n,1)),i=e.serialize(f(n,2));return I([t,"\\bmod",i])}},{latexTrigger:"\\mod",kind:"infix",precedence:ge,parse:"Mod"},{latexTrigger:"\\pmod",kind:"prefix",precedence:D,parse:e=>{let n=e.parseGroup()??e.parseToken();return["Mod",V(n)]}},{name:"Congruent",serialize:(e,n)=>{let t=e.serialize(f(n,1)),i=e.serialize(f(n,2));if(f(n,3)===null)return I([t,"\\equiv",i]);let r=e.serialize(f(n,3));return I([t,"\\equiv",i,"\\pmod{",r,"}"])}},{name:"Negate",latexTrigger:["-"],kind:"prefix",precedence:qn+1,parse:(e,n)=>{e.skipSpace();let t=e.parseExpression({...n,minPrec:qn+3});return t===null?null:["Negate",t]}},{kind:"matchfix",openTrigger:"||",closeTrigger:"||",parse:(e,n)=>z(n)?null:["Norm",n]},{name:"Norm",kind:"matchfix",openTrigger:["\\left","\\Vert"],closeTrigger:["\\right","\\Vert"],parse:(e,n)=>z(n)?null:["Norm",n],serialize:(e,n)=>{let t=f(n,1);if(y(t)==="Matrix"){let i=f(t,1),r=f(t,2),s=r?["Matrix",i,{str:"\u2016\u2016"},r]:["Matrix",i,{str:"\u2016\u2016"}];return e.serialize(s)}return`\\left\\Vert ${e.serialize(t)}\\right\\Vert`}},{name:"PlusMinus",latexTrigger:["\\pm"],kind:"infix",associativity:"any",precedence:Re,serialize:(e,n)=>{let t=f(n,1);if(t===null)return"\\pm";if(J(n)===1)return I(["\\pm",e.serialize(t)]);let i=f(n,2);return I([e.serialize(t),"\\pm",e.serialize(i)])}},{latexTrigger:["\\pm"],kind:"prefix",precedence:Re,parse:(e,n)=>{let t=e.parseExpression({...n,minPrec:400});return["PlusMinus",0,V(t)]}},{latexTrigger:["\\plusmn"],kind:"infix",associativity:"any",precedence:Re,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:400});return["PlusMinus",n,V(i)]}},{latexTrigger:["\\plusmn"],kind:"prefix",precedence:Re,parse:(e,n)=>{let t=e.parseExpression({...n,minPrec:400});return["PlusMinus",V(t)]}},{name:"Power",latexTrigger:["^"],kind:"infix",serialize:Ci},{latexTrigger:"\\prod",precedence:he,name:"Product",parse:Io("Product","Multiply",he),serialize:So("\\prod")},{latexTrigger:["*","*"],kind:"infix",associativity:"right",precedence:qn,parse:(e,n,t)=>{if(e.options.strict!==!1)return null;let i=e.parseExpression({...t,minPrec:qn});return i===null?null:["Power",n,i]}},{name:"Rational",precedence:ge,serialize:(e,n)=>n&&J(n)===1?"\\operatorname{Rational}"+e.wrapArguments(n):No(e,n)},{name:"Reduce",serialize:(e,n)=>{let t=f(n,1);if(!t)return"";let i=f(n,2);return S(i)==="Add"?`\\sum ${e.serialize(t)}`:S(i)==="Multiply"?`\\prod ${e.serialize(t)}`:`\\operatorname{Reduce}\\left(${e.serialize(t)}, ${e.serialize(f(n,2))}\\right)`}},{name:"Root",serialize:Ci},{name:"Round",symbolTrigger:"round",kind:"function"},{name:"Square",precedence:720,serialize:(e,n)=>{let t=e.wrapShort(f(n,1));return(t.startsWith("-")?e.wrapString(t,"normal"):t)+"^2"}},{latexTrigger:["\\sum"],precedence:K,name:"Sum",parse:Io("Sum","Add",he),serialize:So("\\sum")},{name:"Heaviside",symbolTrigger:"Heaviside",kind:"function"},{name:"Sign",symbolTrigger:"sgn",kind:"function"},{name:"Sqrt",latexTrigger:["\\sqrt"],parse:ml,serialize:Ci},{name:"Subtract",latexTrigger:["-"],kind:"infix",associativity:"left",precedence:K+2,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:K+3});return i===null?null:["Subtract",n,i]},serialize:(e,n)=>{let t=e.wrap(f(n,1),K+2),i=e.wrap(f(n,2),K+3);return I([t,"-",i])}}];function gl(e,n){if(e!==null){if(S(e))return{index:S(e)??"Nothing",upper:n};if(y(e)==="GreaterEqual"){let t=S(f(e,1))??"Nothing",i=f(e,2)??1;return{index:t,lower:i,upper:n}}if(y(e)==="Equal"){let t=S(f(e,1))??"Nothing",i=f(e,2);if(y(i)==="Range"){let s=f(i,1)??1,o=f(i,2)??void 0;return{index:t,lower:s,upper:o}}return{index:t,lower:i??1,upper:n}}if(y(e)==="Element")return{index:S(f(e,1))??"Nothing",element:e}}}function bl(e){let n=y(e);return n?new Set(["Less","LessEqual","Greater","GreaterEqual","NotEqual","And","Or","Not"]).has(n):!1}function To(e){if(e===null)return[];let n=en(e);if(n)return[...n];if(y(e)==="Tuple"){let t=N(e);return t?[...t]:[e]}return[e]}function yl(e,n){z(e)&&(e=null),z(n)&&(n=null);let t=To(e),i=To(n),r=[],s=0;for(;s<t.length;){let o=t[s],a=gl(o,i[s]);if(a){if(a.element&&s+1<t.length){let u=t[s+1];if(bl(u)&&y(u)!=="Element"&&y(u)!=="Equal"){let l=a.element;if(Array.isArray(l)&&l.length>=3){let c=[l[0],...l.slice(1),u];a.element=c}s++}}r.push(a)}s++}return r}function Io(e,n,t){return i=>{i.skipSpace(),i.pushSymbolTable();let r=null,s=null;for(;!(s&&r)&&(i.peek==="_"||i.peek==="^");)i.match("_")?s=i.parseGroup()??i.parseToken():i.match("^")&&(r=i.parseGroup()??i.parseToken()),i.skipSpace();if(!r&&!s){let l=i.parseExpression({minPrec:t});return i.popSymbolTable(),l?["Reduce",l,n]:null}let o=yl(s,r),a=i.parseExpression({minPrec:t});if(i.popSymbolTable(),a===null)return[e];let u=[];for(let l of o){if(l.element){u.push(l.element);continue}let c=l.lower,p=l.upper,m=l.index??"Nothing";p!=null?u.push(["Tuple",m,c??1,p]):c!=null?u.push(["Tuple",m,c]):u.push(["Tuple",m])}return[e,a,...u]}}var xl=new Set(["Tuple","Triple","Pair","Single","Limits","Element"]);function ko(e){return e==null||S(e)==="Nothing"?null:e}function El(e){let n=[],t=N(e);if(t.length<=1)return n;for(let i of t.slice(1)){let r=y(i);if(r&&xl.has(r)){n.push(i);continue}break}return n}function vl(e,n){if(y(n)==="Element"){let l=e.serialize(f(n,1)),c=e.serialize(f(n,2));return{sub:`${l}\\in ${c}`}}let t=f(n,1);t!==null&&y(t)==="Hold"&&(t=f(t,1));let i=ko(f(n,2)),r=ko(f(n,3)),s={},o=t?S(t):null,a=o!==null&&o!=="Nothing",u=a&&t?e.serialize(t):void 0;return a&&i!==null&&u?s.sub=`${u}=${e.serialize(i)}`:a&&u?s.sub=u:i!==null&&(s.sub=e.serialize(i)),r!==null&&(s.sup=e.serialize(r)),s}function So(e){return(n,t)=>{let i=f(t,1);if(!i)return e;let r=El(t),s=e;if(r.length>0){let o=[],a=[];for(let u of r){let l=vl(n,u);l.sub&&o.push(l.sub),l.sup&&a.push(l.sup)}o.length>0&&(s=mn("_",s,o.join(", "))),a.length>0&&(s=mn("^",s,a.join(", ")))}return I([s,n.serialize(i)])}}function _o(e,n){let t=null;n.match("_")&&(t=n.parseGroup()??n.parseToken());let i=n.parseArguments("implicit");return i===null&&t===null?[e]:i===null?[e,t]:t===null?[e,...i]:t===10?["Log",i[0]]:t===2?["Lb",...i]:["Log",i[0],t]}function Yn(e){let n=1,t=e;do{e=t;let i=y(e);if(i==="Negate")n*=-1,t=f(e,1);else if(i==="Multiply"){let[r,s]=Yn(f(e,1));s<0&&(n*=-1,r===1?t=["Multiply",...N(e).slice(1)]:t=["Multiply",r,...N(e).slice(1)])}else if(i==="Divide"||i==="Rational"){let[r,s]=Yn(f(e,1));s<0&&(n*=-1,t=[i,r,f(e,2)])}else{let r=C(e);r!==null&&r<0&&(n*=-1,t=-r)}}while(t!==e);return[e,n]}var Ao=[{name:"Real",kind:"function",latexTrigger:["\\Re"],arguments:"implicit"},{name:"Imaginary",kind:"function",latexTrigger:["\\Im"],arguments:"implicit"},{name:"Argument",kind:"function",latexTrigger:["\\arg"],arguments:"implicit"},{name:"Conjugate",latexTrigger:["^","\\star"],kind:"postfix"}];function M(e){return(n,t)=>{let i={"\\arcsin":"Arcsin","\\arccos":"Arccos","\\arctan":"Arctan","\\arctg":"Arctan","\\arcctg":"Arccot","\\arcsec":"Arcsec","\\arccsc":"Arccsc","\\arsinh":"Arsinh","\\arcsinh":"Arsinh","\\arcosh":"Arcosh","\\arccosh":"Arcosh","\\artanh":"Artanh","\\arctanh":"Artanh","\\arsech":"Arsech","\\arcsech":"Arsech","\\arcsch":"Arcsch","\\arccsch":"Arcsch","\\arcoth":"Arcoth","\\arccoth":"Arcoth","\\ch":"Cosh","\\cos":"Cos","\\cosh":"Cosh","\\cosec":"Csc","\\cot":"Cot","\\cotg":"Cot","\\ctg":"Cot","\\csc":"Csc","\\csch":"Csch","\\coth":"Coth","\\cth":"Coth","\\sec":"Sec","\\sech":"Sech","\\sin":"Sin","\\sinh":"Sinh","\\sh":"Sinh","\\tan":"Tan","\\tg":"Tan","\\tanh":"Tanh","\\th":"Tanh"},r=i[e??""]??e??"";if(n.atTerminator(t))return r;let s=r;do{let l=n.parsePostfixOperator(s,t);if(l===null)break;s=l}while(!0);n.skipSpace();let o=null;n.match("^")&&(o=n.parseGroup()??n.parseToken()),n.skipSpace();let a=n.parseArguments("implicit",{minPrec:he,condition:l=>i[l.peek]||(t?.condition?.(l)??!1)}),u=a===null?s:typeof s=="string"?[s,...a]:["Apply",s,...a];return o===null?u:["Power",u,o]}}var $o=[{name:"Arcsin",latexTrigger:["\\arcsin"],parse:M("Arcsin")},{name:"Arccos",latexTrigger:["\\arccos"],parse:M("Arccos")},{name:"Arctan",latexTrigger:["\\arctan"],parse:M("Arctan")},{latexTrigger:["\\arctg"],parse:M("Arctan")},{symbolTrigger:"arctg",parse:M("Arctan")},{name:"Arccot",symbolTrigger:"arcctg",parse:M("Arccot")},{latexTrigger:["\\arcctg"],parse:M("Arccot")},{name:"Arcoth",symbolTrigger:"arcoth",parse:M("Arcoth")},{symbolTrigger:"arccoth",parse:M("Arcoth")},{latexTrigger:["\\arcoth"],parse:M("Arcoth")},{latexTrigger:["\\arccoth"],parse:M("Arcoth")},{name:"Arcsec",symbolTrigger:"arcsec",parse:M("Arcsec")},{latexTrigger:["\\arcsec"],parse:M("Arcsec")},{name:"Arccsc",symbolTrigger:"arccsc",parse:M("Arccsc")},{latexTrigger:["\\arccsc"],parse:M("Arccsc")},{name:"Arsinh",symbolTrigger:"arsinh",parse:M("Arsinh")},{symbolTrigger:"arcsinh",parse:M("Arsinh")},{latexTrigger:["\\arsinh"],parse:M("Arsinh")},{latexTrigger:["\\arcsinh"],parse:M("Arsinh")},{name:"Arcosh",symbolTrigger:"arcosh",parse:M("Arcosh")},{symbolTrigger:"arccosh",parse:M("Arcosh")},{latexTrigger:"\\arcosh",parse:M("Arcosh")},{latexTrigger:"\\arccosh",parse:M("Arcosh")},{name:"Artanh",symbolTrigger:"artanh",parse:M("Artanh")},{symbolTrigger:"arctanh",parse:M("Artanh")},{latexTrigger:"\\artanh",parse:M("Artanh")},{latexTrigger:["\\arctanh"],parse:M("Artanh")},{name:"Arsech",symbolTrigger:"arsech",parse:M("Arsech")},{symbolTrigger:"arcsech",parse:M("Arsech")},{latexTrigger:["\\arsech"],parse:M("Arsech")},{latexTrigger:["\\arcsech"],parse:M("Arsech")},{name:"Arcsch",symbolTrigger:"arcsch",parse:M("Arcsch")},{symbolTrigger:"arccsch",parse:M("Arcsch")},{latexTrigger:["\\arcsch"],parse:M("Arcsch")},{latexTrigger:["\\arccsch"],parse:M("Arcsch")},{name:"Cosec",symbolTrigger:"cosec",parse:M("Cosec")},{latexTrigger:["\\cosec"],parse:M("Cosec")},{name:"Cosh",latexTrigger:["\\cosh"],parse:M("Cosh")},{latexTrigger:["\\ch"],parse:M("Cosh")},{name:"Cot",latexTrigger:["\\cot"],parse:M("Cot")},{latexTrigger:["\\cotg"],parse:M("Cot")},{latexTrigger:["\\ctg"],parse:M("Cot")},{name:"Csc",latexTrigger:["\\csc"],parse:M("Csc")},{name:"Csch",latexTrigger:["\\csch"],parse:M("Csch")},{name:"Coth",latexTrigger:["\\coth"],parse:M("Coth")},{latexTrigger:["\\cth"],parse:M("Coth")},{symbolTrigger:"cth",parse:M("Coth")},{latexTrigger:["\\coth"],parse:M("Coth")},{name:"Sec",latexTrigger:["\\sec"],parse:M("Sec")},{name:"Sech",symbolTrigger:"sech",parse:M("Sech")},{latexTrigger:["\\sech"],parse:M("Sech")},{name:"Sinh",latexTrigger:["\\sinh"],parse:M("Sinh")},{latexTrigger:["\\sh"],parse:M("Sinh")},{name:"Tan",latexTrigger:["\\tan"],parse:M("Tan")},{latexTrigger:["\\tg"],parse:M("Tan")},{name:"Tanh",latexTrigger:["\\tanh"],parse:M("Tanh")},{latexTrigger:["\\th"],parse:M("Tanh")},{name:"Cos",latexTrigger:["\\cos"],parse:M("Cos")},{name:"Sin",latexTrigger:["\\sin"],parse:M("Sin")},{name:"Sinc",symbolTrigger:"sinc",kind:"function"},{name:"FresnelS",symbolTrigger:"FresnelS",kind:"function"},{name:"FresnelC",symbolTrigger:"FresnelC",kind:"function"}];function vn(e){return n=>{let t=!1,i=[],r=[];for(;!t;){n.skipVisualSpace(),n.match("\\limits"),n.skipSpace();let a=null,u=null;for(;!(u!==null&&a!==null)&&(n.peek==="_"||n.peek==="^");)n.match("_")?u=n.parseGroup()??n.parseToken():n.match("^")&&(a=n.parseGroup()??n.parseToken()),n.skipSpace();z(u)&&(u=null),z(a)&&(a=null),i.push(u??"Nothing"),r.push(a??"Nothing"),n.skipVisualSpace(),t=!n.match(e)}let[s,o]=Nl(n);if(s&&o.length===0){if(y(s)==="Add"||y(s)==="Subtract"){let a=[],u=[];for(let l of N(s))if(o)u.push(l);else{let c;[c,o]=Fe(l),a.push(c??l)}if(o!==null&&u.length>0)return["Add",Co(e,["Add",...a],{indexes:o,subs:i,sups:r})??"Nothing",...u]}else if(y(s)==="Divide"){let a;[a,o]=Fe(f(s,1)),a!==null&&o!==null&&(s=["Divide",a,f(s,2)])}}return Co(e,s,{indexes:o,subs:i,sups:r})}}function Co(e,n,t){if(!n)return null;if(t.sups.length===0&&t.subs.length===0)return[e,n,...t.indexes];let i=t.indexes.length===0?y(n)==="Function"?N(n).slice(1):[]:t.indexes,r=Math.max(t.sups.length,t.subs.length,i.length);if(i.length===0)for(let o=0;o<r;o++)i.push("Nothing");else if(i.length!==r)for(let o=i.length;o<r;o++)i.push(["Error","'missing'"]);if(t.subs.length!==r)for(let o=t.subs.length;o<r;o++)t.subs.push("Nothing");if(t.sups.length!==r)for(let o=t.sups.length;o<r;o++)t.sups.push("Nothing");let s=i.map((o,a)=>{let u=t.sups[a],l=t.subs[a];return l==="Nothing"&&u==="Nothing"?o:["Tuple",o,l,u]});return[e,n,...s]}function Nl(e){let n=!1,t=e.parseExpression({minPrec:266,condition:()=>{let i=e.index;return n=Po(e),e.index=i,n}});return t!==null&&!n?Fe(t):[t,Tl(e)]}function Tl(e){let n=[];for(;Po(e);){e.skipVisualSpace();let t=S(e.parseSymbol());if(t===null)return n;n.push(t)}return n}function Fe(e){let n=y(e),t=f(e,1);if(!t)return[e,[]];if(n==="Sequence"&&J(e)===1)return Fe(t);if(n==="Multiply"||n==="InvisibleOperator"){let i=N(e);if(i){let[r,s]=Il(i);return r.length>0?[[n,...r],s]:[null,s]}}else if(n==="Delimiter"){let[i,r]=Fe(t);if(r)return i?[["Delimiter",["Sequence",i],...N(e).slice(1)],r]:[null,r]}else if(n==="Add"){let i=N(e);if(i.length>0){let[r,s]=Fe(i[i.length-1]);if(s.length>0){if(r)return[["Add",...i.slice(0,-1),r],s];if(i.length>2)return[["Add",...i.slice(0,-1)],s];if(i.length>2)return[i[0],s]}}}else if(n==="Negate"){let[i,r]=Fe(t);if(r.length>0)return[i?["Negate",i]:null,r]}else if(n==="Divide"){let[i,r]=Fe(t);if(r.length>0)return[["Divide",i??1,f(e,2)],r]}else{let i=N(e);if(i.length===1){let[r,s]=Fe(i[0]);if(s.length>0)return[[y(e),r],s]}}return[e,[]]}function Ro(e){return(n,t)=>{if(!f(t,1))return e;let i=f(t,1),r=[];y(i)==="BuiltInFunction"?(r=["x"],i=[f(i,1),"x"]):y(i)==="Function"?(r=N(i).slice(1),i=f(i,1)):S(i)?r=[]:r=[];let s=N(t).slice(1),o=[],a=s.map((l,c)=>{if(S(l)==="Nothing")return o.push(S(r[c])??"Nothing"),"";if(S(l))return o.push(S(l)??"Nothing"),"";let p=y(l);if(p==="Tuple"||p==="Pair"||p==="Limits"||p==="Range"){if(J(l)===3){let m=f(l,1);o.push(S(m)??"Nothing");let d=f(l,2),b=f(l,3);return S(d)==="Nothing"&&(d=null),S(b)==="Nothing"&&(b=null),d!==null&&b!==null?`_{${n.serialize(d)}}^{${n.serialize(b)}}`:d!==null?`_{${n.serialize(d)}}`:b!==null?`^{${n.serialize(b)}}`:""}return`_{${n.serialize(l)}}`}if(J(l)===2){if(S(f(l,1))){o.push(S(f(l,1))??"Nothing");let b=f(l,2);return S(b)==="Nothing"?"":`_{${n.serialize(b)}}`}o.push(S(r[c])??"Nothing");let m=f(l,1),d=f(l,2);if(S(m)==="Nothing"&&(m=null),S(d)==="Nothing"&&(d=null),m!==null&&d!==null)return`_{${n.serialize(m)}}^{${n.serialize(d)}}`;if(m!==null)return`_{${n.serialize(m)}}`;if(d!==null)return`^{${n.serialize(d)}}`}else o.push(S(r[c])??"Nothing")}),u=o.filter(l=>S(l)!=="Nothing").map(l=>`\\mathrm{d}${n.serialize(S(l)??"x")}`);return u.length>0&&(u=["\\,",...u]),a.length===0?`${e}\\,${n.serialize(i)}\\!${u.join(" ")}`:a.reverse().map(l=>`${e}${l}`).join("")+"\\!"+n.serialize(i)+u.join(" ")}}var Do=[{kind:"expression",name:"Integrate",latexTrigger:["\\int"],parse:vn("Integrate"),serialize:Ro("\\int")},{kind:"expression",latexTrigger:["\\iint"],parse:vn("Integrate")},{kind:"expression",latexTrigger:["\\iiint"],parse:vn("Integrate")},{kind:"expression",name:"CircularIntegrate",latexTrigger:["\\oint"],parse:vn("CircularIntegrate"),serialize:Ro("\\oint")},{kind:"expression",latexTrigger:["\\oiint"],parse:vn("CircularIntegrate")},{kind:"expression",latexTrigger:["\\oiiint"],parse:vn("CircularIntegrate")}];function Po(e){let n=e.index;for(;e.match("\\cdot")||e.skipVisualSpace(););return e.matchAll(["\\mathrm","<{>","d","<}>"])||e.matchAll(["\\operatorname","<{>","d","<}>"])||e.match("d")||e.match("\\differentialD")?!0:(e.index=n,!1)}function Il(e){let n=[...e],t=[];for(;n.length>0;){let i;if([n,i]=kl(n),!i)break;t.push(i)}return[n,t]}function kl(e){if(e.length<2)return[e,""];let n=e[e.length-2];if(n==="d"||n==="d_upright"){let t=S(e[e.length-1]);if(t)return[e.slice(0,-2),t]}return[e,""]}var Fo=[{name:"Matrix",serialize:(e,n)=>{let t=N(f(n,1));return Ri(e,t,L(f(n,2)),L(f(n,3)))}},{name:"Vector",serialize:(e,n)=>{let t=N(n);return Ri(e,t.map(i=>["List",i]),L(f(n,2)),L(f(n,3)))}},{kind:"environment",symbolTrigger:"pmatrix",parse:e=>{let n=Le(e),[t,i]=Oe(e);return n?[t,i,{str:"()"},{str:n}]:[t,i]}},{kind:"environment",symbolTrigger:"bmatrix",parse:e=>{let n=Le(e),[t,i]=Oe(e);return n?[t,i,{str:"[]"},{str:n}]:[t,i,{str:"[]"}]}},{kind:"environment",symbolTrigger:"Bmatrix",parse:e=>{let n=Le(e),[t,i]=Oe(e);return n?[t,i,{str:"{}"},{str:n}]:[t,i,{str:"{}"}]}},{kind:"environment",symbolTrigger:"vmatrix",parse:e=>{let n=Le(e),[t,i]=Oe(e);return n?["Determinant",[t,i,{str:n}]]:["Determinant",[t,i]]}},{kind:"environment",symbolTrigger:"Vmatrix",parse:e=>{let n=Le(e),[t,i]=Oe(e);return n?["Norm",[t,i,{str:n}]]:["Norm",[t,i]]}},{kind:"environment",symbolTrigger:"smallmatrix",parse:e=>{let n=Le(e),[t,i]=Oe(e);return n?[t,i,{str:"()"},{str:n}]:[t,i]}},{kind:"environment",symbolTrigger:"array",parse:e=>{let n=Le(e,!1),[t,i]=Oe(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{kind:"environment",symbolTrigger:"matrix",parse:e=>{let n=Le(e),[t,i]=Oe(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{kind:"environment",symbolTrigger:"matrix*",parse:e=>{let n=Le(e),[t,i]=Oe(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{name:"ConjugateTranspose",kind:"postfix",latexTrigger:["^","\\star"]},{kind:"postfix",latexTrigger:["^","\\H"],parse:"ConjugateTranspose"},{kind:"postfix",latexTrigger:["^","\\dagger"],parse:(e,n)=>["ConjugateTranspose",n]},{kind:"postfix",latexTrigger:["^","\\ast"],parse:(e,n)=>["ConjugateTranspose",n]},{kind:"postfix",latexTrigger:["^","\\top"],parse:(e,n)=>["Transpose",n]},{kind:"postfix",latexTrigger:["^","\\intercal"],parse:(e,n)=>["Transpose",n]},{name:"Transpose",kind:"postfix",latexTrigger:["^","T"]},{name:"PseudoInverse",kind:"postfix",latexTrigger:["^","+"]},{name:"Inverse",serialize:(e,n)=>e.serialize(f(n,1))+"^{-1}"},{name:"Trace",kind:"function",latexTrigger:"\\tr",arguments:"implicit",serialize:(e,n)=>Nn(e,n,"\\tr")},{symbolTrigger:"tr",kind:"function",parse:"Trace",arguments:"implicit"},{name:"Kernel",kind:"function",latexTrigger:"\\ker",arguments:"implicit",serialize:(e,n)=>Nn(e,n,"\\ker")},{symbolTrigger:"ker",kind:"function",parse:"Kernel",arguments:"implicit"},{name:"Dimension",kind:"function",latexTrigger:"\\dim",arguments:"implicit",serialize:(e,n)=>Nn(e,n,"\\dim")},{symbolTrigger:"dim",kind:"function",parse:"Dimension",arguments:"implicit"},{name:"Degree",kind:"function",latexTrigger:"\\deg",arguments:"implicit",serialize:(e,n)=>Nn(e,n,"\\deg")},{symbolTrigger:"deg",kind:"function",parse:"Degree",arguments:"implicit"},{name:"Hom",kind:"function",latexTrigger:"\\hom",arguments:"implicit",serialize:(e,n)=>Nn(e,n,"\\hom")},{symbolTrigger:"hom",kind:"function",parse:"Hom",arguments:"implicit"},{name:"Determinant",kind:"function",latexTrigger:"\\det",arguments:"implicit",serialize:(e,n)=>{let t=f(n,1);if(y(t)==="Matrix"){let i=N(f(t,1));return Ri(e,i,"||",L(f(t,2)))}return Nn(e,n,"\\det")}},{symbolTrigger:"det",kind:"function",parse:"Determinant",arguments:"implicit"},{name:"MatrixMultiply",serialize:(e,n)=>{let t=e.serialize(f(n,1)),i=e.serialize(f(n,2));return`${t} \\cdot ${i}`}}];function Oe(e){let n=e.parseTabular();return n?["Matrix",["List",...n.map(t=>["List",...t])]]:["",null]}function Le(e,n=!0){let t=e.parseStringGroup(n)?.trim();if(!t)return"";let i="";for(let r of t)r==="c"&&(i+="="),r==="l"&&(i+="<"),r==="r"&&(i+=">"),r==="|"&&(i+="|"),r===":"&&(i+=":");return i}function Nn(e,n,t){if(N(n).length!==1)return`${t}${e.wrapArguments(n)}`;let r=f(n,1),s=e.serialize(r);return typeof r=="string"||typeof r=="number"?`${t} ${s}`:`${t}\\left(${s}\\right)`}function Ri(e,n,t,i){t??="()";let[r,s]=["",""];typeof t=="string"&&t.length===2&&([r,s]=t);let o="";if(i)for(let c of i)c==="<"?o+="l":c===">"?o+="r":c==="="?o+="c":c==="|"?o+="|":c===":"&&(o+=":");let a=[];for(let c of n??[]){let p=[];for(let m of N(c))p.push(e.serialize(m));a.push(p.join(" & "))}let u=a.join(`\\\\
|
|
7
|
+
`),l=o.length>0?`[${o}]`:"";return r==="("&&s===")"?I(["\\begin{pmatrix}",l,u,"\\end{pmatrix}"]):r==="["&&s==="]"?I(["\\begin{bmatrix}",l,u,"\\end{bmatrix}"]):r==="{"&&s==="}"?I(["\\begin{Bmatrix}",l,u,"\\end{Bmatrix}"]):r==="|"&&s==="|"?I(["\\begin{vmatrix}",l,u,"\\end{vmatrix}"]):r==="\u2016"&&s==="\u2016"?I(["\\begin{Vmatrix}",l,u,"\\end{Vmatrix}"]):r==="{"&&s==="."?I(["\\begin{dcases}",l,u,"\\end{dcases}"]):r==="."&&s==="}"?I(["\\begin{rcases}",l,u,"\\end{rcases}"]):o||r!=="."||s!=="."?I(["\\left",St[r]??r,"\\begin{array}",`{${o}}`,u,"\\end{array}","\\right",St[s]??s]):I(["\\begin{matrix}",u,"\\end{matrix}"])}var Oo=[{name:"Mean",kind:"function",symbolTrigger:"mean"},{name:"Median",kind:"function",symbolTrigger:"median"},{name:"StandarDeviation",kind:"function",symbolTrigger:"stddev"},{latexTrigger:["\\bar"],kind:"expression",parse:(e,n)=>{let t=e.parseGroup()??e.parseToken();return!t||!S(t)?null:["Mean",t]}}];var $t={Q:1e30,R:1e27,Y:1e24,Z:1e21,E:1e18,P:1e15,T:1e12,G:1e9,M:1e6,k:1e3,h:100,da:10,d:.1,c:.01,m:.001,\u00B5:1e-6,\u03BC:1e-6,n:1e-9,p:1e-12,f:1e-15,a:1e-18,z:1e-21,y:1e-24,r:1e-27,q:1e-30},Lo=new Set(["m","g","s","A","K","mol","cd","Hz","N","Pa","J","W","C","V","F","ohm","S","Wb","T","H","lm","lx","Bq","Gy","Sv","kat","eV","L","bar"]),Ct={m:{dimension:[1,0,0,0,0,0,0],scale:1},kg:{dimension:[0,1,0,0,0,0,0],scale:1},g:{dimension:[0,1,0,0,0,0,0],scale:.001},s:{dimension:[0,0,1,0,0,0,0],scale:1},A:{dimension:[0,0,0,1,0,0,0],scale:1},K:{dimension:[0,0,0,0,1,0,0],scale:1},mol:{dimension:[0,0,0,0,0,1,0],scale:1},cd:{dimension:[0,0,0,0,0,0,1],scale:1},Hz:{dimension:[0,0,-1,0,0,0,0],scale:1},N:{dimension:[1,1,-2,0,0,0,0],scale:1},Pa:{dimension:[-1,1,-2,0,0,0,0],scale:1},J:{dimension:[2,1,-2,0,0,0,0],scale:1},W:{dimension:[2,1,-3,0,0,0,0],scale:1},C:{dimension:[0,0,1,1,0,0,0],scale:1},V:{dimension:[2,1,-3,-1,0,0,0],scale:1},F:{dimension:[-2,-1,4,2,0,0,0],scale:1},ohm:{dimension:[2,1,-3,-2,0,0,0],scale:1},S:{dimension:[-2,-1,3,2,0,0,0],scale:1},Wb:{dimension:[2,1,-2,-1,0,0,0],scale:1},T:{dimension:[0,1,-2,-1,0,0,0],scale:1},H:{dimension:[2,1,-2,-2,0,0,0],scale:1},lm:{dimension:[0,0,0,0,0,0,1],scale:1},lx:{dimension:[-2,0,0,0,0,0,1],scale:1},Bq:{dimension:[0,0,-1,0,0,0,0],scale:1},Gy:{dimension:[2,0,-2,0,0,0,0],scale:1},Sv:{dimension:[2,0,-2,0,0,0,0],scale:1},kat:{dimension:[0,0,-1,0,0,1,0],scale:1},degC:{dimension:[0,0,0,0,1,0,0],scale:1,offset:273.15},degF:{dimension:[0,0,0,0,1,0,0],scale:5/9,offset:459.67},min:{dimension:[0,0,1,0,0,0,0],scale:60},h:{dimension:[0,0,1,0,0,0,0],scale:3600},d:{dimension:[0,0,1,0,0,0,0],scale:86400},ha:{dimension:[2,0,0,0,0,0,0],scale:1e4},L:{dimension:[3,0,0,0,0,0,0],scale:.001},t:{dimension:[0,1,0,0,0,0,0],scale:1e3},eV:{dimension:[2,1,-2,0,0,0,0],scale:1602176634e-28},Da:{dimension:[0,1,0,0,0,0,0],scale:16605390666e-37},au:{dimension:[1,0,0,0,0,0,0],scale:149597870700},deg:{dimension:[0,0,0,0,0,0,0],scale:Math.PI/180},rad:{dimension:[0,0,0,0,0,0,0],scale:1},grad:{dimension:[0,0,0,0,0,0,0],scale:Math.PI/200},turn:{dimension:[0,0,0,0,0,0,0],scale:2*Math.PI},arcmin:{dimension:[0,0,0,0,0,0,0],scale:Math.PI/10800},arcsec:{dimension:[0,0,0,0,0,0,0],scale:Math.PI/648e3},percent:{dimension:[0,0,0,0,0,0,0],scale:.01},ppm:{dimension:[0,0,0,0,0,0,0],scale:1e-6},dB:{dimension:[0,0,0,0,0,0,0],scale:1},Np:{dimension:[0,0,0,0,0,0,0],scale:1},in:{dimension:[1,0,0,0,0,0,0],scale:.0254},ft:{dimension:[1,0,0,0,0,0,0],scale:.3048},mi:{dimension:[1,0,0,0,0,0,0],scale:1609.344},lb:{dimension:[0,1,0,0,0,0,0],scale:.45359237},oz:{dimension:[0,1,0,0,0,0,0],scale:.028349523125},gal:{dimension:[3,0,0,0,0,0,0],scale:.003785411784},atm:{dimension:[-1,1,-2,0,0,0,0],scale:101325},bar:{dimension:[-1,1,-2,0,0,0,0],scale:1e5},cal:{dimension:[2,1,-2,0,0,0,0],scale:4.184},kWh:{dimension:[2,1,-2,0,0,0,0],scale:36e5},\u00C5:{dimension:[1,0,0,0,0,0,0],scale:1e-10}};function Sl(e){if(e.length>2){let n=e.slice(0,2),t=e.slice(2);if($t[n]!==void 0&&Lo.has(t)){let i=Ct[t];if(i)return{prefixScale:$t[n],baseEntry:i}}}if(e.length>1){let n=e.slice(0,1),t=e.slice(1);if($t[n]!==void 0&&Lo.has(t)){let i=Ct[t];if(i)return{prefixScale:$t[n],baseEntry:i}}}return null}function _l(e){let n=Ct[e];if(n)return n;let t=Sl(e);return t?{dimension:t.baseEntry.dimension,scale:t.prefixScale*t.baseEntry.scale}:null}function Di(e){let n=_l(e);return n?n.dimension:null}var Sh=new Map(["N","J","W","Pa","Hz","C","V","F","ohm","S","Wb","T","H","lm","lx","Gy","kat"].map(e=>[Ct[e].dimension.join(","),e]));function Ml(e){let n=e.indexOf("^");if(n===-1)return e;let t=e.slice(0,n),i=e.slice(n+1),r=parseInt(i,10);return isNaN(r)?e:["Power",t,r]}function Hn(e){if(e=e.trim(),e.length===0)return null;if(e[0]==="("&&e[e.length-1]===")"){let r=0,s=!0;for(let o=0;o<e.length-1;o++)if(e[o]==="("?r++:e[o]===")"&&r--,r===0&&o<e.length-1){s=!1;break}if(s)return Hn(e.slice(1,-1))}let n=-1,t=[],i=0;for(let r=0;r<e.length;r++)e[r]==="("?i++:e[r]===")"?i--:i===0&&(e[r]==="/"&&n===-1?n=r:e[r]==="*"&&t.push(r));if(n!==-1){let r=e.slice(0,n).trim(),s=e.slice(n+1).trim(),o=Hn(r),a=Hn(s);return!o||!a?null:["Divide",o,a]}if(t.length>0){let r=[],s=0;for(let a of t)r.push(e.slice(s,a).trim()),s=a+1;r.push(e.slice(s).trim());let o=r.filter(a=>a.length>0).map(a=>Hn(a));return o.some(a=>a===null)?null:o.length===1?o[0]:["Multiply",...o]}return e[0]==="("?null:Ml(e)}function Bo(e){return e=e.trim(),e.length===0?null:/[/*^()]/.test(e)?Hn(e):e}function zo(e){if(!e.match("<{>"))return null;let n="",t=0;for(;!e.atEnd;){let i=e.peek;if(i==="<}>"&&t===0)return e.nextToken(),n;if(i==="<}>"){t--,e.nextToken();continue}if(i==="<{>"){t++,e.nextToken();continue}if(i==="<space>"){e.nextToken();continue}if(i==="\\cdot"){n+="*",e.nextToken();continue}if(i==="^"){n+="^",e.nextToken();continue}n+=i,e.nextToken()}return null}var wl=new Set(["d"]);function Go(e){if(!e||e.length===0||wl.has(e))return null;if(Di(e)!==null)return e;if(/[/*^]/.test(e))try{let n=Bo(e);if(n!==null&&Pi(n))return n}catch{return null}return null}function Pi(e){if(typeof e=="string")return Di(e)!==null;if(!Array.isArray(e))return!1;let n=e[0];return n==="Multiply"||n==="Divide"?e.slice(1).every(t=>Pi(t)):n==="Power"?Pi(e[1]):!1}var Vo=e=>{let n=e.index,t=zo(e);if(t===null)return e.index=n,null;let i=Go(t);return i===null?(e.index=n,null):["__unit__",i]};function tn(e){let n=S(e);if(n!==null)return n;if(typeof e=="number")return String(e);let t=y(e);if(!t)return"";if(t==="Divide"){let i=f(e,1),r=f(e,2);return`${tn(i)}/${tn(r)}`}if(t==="Multiply"){let i=[];if(Array.isArray(e))for(let r=1;r<e.length;r++)i.push(tn(e[r]));return i.join("\\cdot ")}if(t==="Power"){let i=f(e,1),r=f(e,2),s=typeof r=="number"?String(r):S(r)??String(r);return`${tn(i)}^{${s}}`}if(t==="Square"){let i=f(e,1);return`${tn(i)}^{2}`}return""}function Jo(e){let n=e.parseGroup();if(n===null)return null;let t=jo(e);return t===null?null:["Quantity",n,t]}function qo(e){return jo(e)}function jo(e){let n=e.index,t=zo(e);if(t===null)return e.index=n,null;let i=Go(t);return i===null?(e.index=n,null):i}var Uo=[{latexTrigger:"\\mathrm",kind:"expression",parse:Vo},{latexTrigger:"\\text",kind:"expression",parse:Vo},{latexTrigger:"\\qty",parse:Jo},{latexTrigger:"\\SI",parse:Jo},{latexTrigger:"\\unit",parse:qo},{latexTrigger:"\\si",parse:qo},{name:"Quantity",serialize:(e,n)=>{let t=f(n,1),i=f(n,2);if(t===null||i===null)return"";let r=S(i),s=r==="deg"||r==="rad"||r==="arcmin"||r==="arcsec",o=e.options;if(s&&(o.dmsFormat||o.angleNormalization&&o.angleNormalization!=="none")){let l=C(t);if(l===null){let p=e.serialize(t),m=tn(i);return I([p,"\\,",`\\mathrm{${m}}`])}let c=l;return r==="rad"?c=c*180/Math.PI:r==="arcmin"?c=c/60:r==="arcsec"&&(c=c/3600),o.angleNormalization&&o.angleNormalization!=="none"&&(c=Mt(c,o.angleNormalization)),o.dmsFormat?wt(c):`${c}\xB0`}let a=e.serialize(t),u=tn(i);return I([a,"\\,",`\\mathrm{${u}}`])}}];function fe(e){return n=>{let t=n.parseGroup();return t===null?[e]:[e,t]}}var Zo=[{name:"Overscript",latexTrigger:["\\overset"],kind:"infix",precedence:700},{name:"Underscript",latexTrigger:["\\underset"],kind:"infix",precedence:700},{name:"Increment",latexTrigger:["+","+"],kind:"postfix",precedence:880,parse:(e,n)=>S(n)===null?null:["Increment",n]},{name:"Decrement",latexTrigger:["-","-"],kind:"postfix",precedence:880,parse:(e,n)=>S(n)===null?null:["Decrement",n]},{name:"PreIncrement",latexTrigger:["+","+"],kind:"prefix",precedence:880,parse:(e,n)=>{let t=e.parseExpression(n);return S(t)===null?null:["PreIncrement",t]}},{name:"PreDecrement",latexTrigger:["-","-"],kind:"prefix",precedence:880,parse:(e,n)=>{let t=e.parseExpression(n);return S(t)===null?null:["PreDecrement",t]}},{name:"Ring",latexTrigger:["\\circ"],kind:"infix",precedence:265},{name:"StringJoin",latexTrigger:["\\lt","\\gt"],kind:"infix",precedence:780},{name:"Starstar",latexTrigger:["\\star","\\star"],kind:"infix",precedence:780},{name:"PartialDerivative",latexTrigger:["\\partial"],kind:"prefix",parse:e=>{let n=!1,t="Nothing",i="Nothing";for(;!n;)e.skipSpace(),e.match("_")?i=e.parseGroup()??e.parseToken():e.match("^")?t=e.parseGroup()??e.parseToken():n=!0;let r=en(i);if(r&&(i=["List",...r]),i===null||t===null)return null;let s=e.parseGroup()??"Nothing";if(!z(s)){let o=e.parseArguments()??["Nothing"];s=[s,...o]}return["PartialDerivative",s,i,t]},serialize:(e,n)=>{let t="\\partial",i=f(n,1),r=f(n,2),s=f(n,3);return r!==null&&r!=="Nothing"&&(y(r)==="List"?t+="_{"+e.serialize(["Sequence",...N(r)])+"}":t+="_{"+e.serialize(r)+"}"),s!==null&&s!=="Nothing"&&(t+="^{"+e.serialize(s)+"}"),i!==null&&i!=="Nothing"&&(t+=e.serialize(i)),t},precedence:740},{name:"OverBar",latexTrigger:["\\overline"],parse:fe("OverBar")},{name:"UnderBar",latexTrigger:["\\underline"],parse:fe("UnderBar")},{name:"OverVector",latexTrigger:["\\vec"],parse:fe("OverVector")},{name:"OverTilde",latexTrigger:["\\tilde"],parse:fe("OverTilde")},{name:"OverHat",latexTrigger:["\\hat"],parse:fe("OverHat")},{name:"OverRightArrow",latexTrigger:["\\overrightarrow"],parse:fe("OverRightArrow")},{name:"OverLeftArrow",latexTrigger:["\\overleftarrow"],parse:fe("OverLeftArrow")},{name:"OverRightDoubleArrow",latexTrigger:["\\Overrightarrow"],parse:fe("OverRightDoubleArrow")},{name:"OverLeftHarpoon",latexTrigger:["\\overleftharpoon"],parse:fe("OverLeftHarpoon")},{name:"OverRightHarpoon",latexTrigger:["\\overrightharpoon"],parse:fe("OverRightHarpoon")},{name:"OverLeftRightArrow",latexTrigger:["\\overleftrightarrow"],parse:fe("OverLeftRightArrow")},{name:"OverBrace",latexTrigger:["\\overbrace"],parse:fe("OverBrace")},{name:"OverLineSegment",latexTrigger:["\\overlinesegment"],parse:fe("OverLineSegment")},{name:"OverGroup",latexTrigger:["\\overgroup"],parse:fe("OverGroup")},{latexTrigger:["\\textcolor"],parse:e=>{let n=e.index,t=e.parseStringGroup(),i=e.parseGroup();return t!==null?i!==null?["Annotated",i,{dict:{color:t}}]:"Nothing":(e.index=n,"Nothing")}},{latexTrigger:["\\colorbox"],parse:e=>{let n=e.index,t=e.parseStringGroup(),i=e.parseGroup();return t!==null?i!==null?["Annotated",i,{dict:{backgroundColor:t}}]:"Nothing":(e.index=n,"Nothing")}},{latexTrigger:["\\boxed"],parse:e=>{let n=e.parseGroup();return n!==null?["Annotated",n,{dict:{border:!0}}]:"Nothing"}},{latexTrigger:["\\displaystyle"],parse:()=>"Nothing"},{latexTrigger:["\\textstyle"],parse:()=>"Nothing"},{latexTrigger:["\\scriptstyle"],parse:()=>"Nothing"},{latexTrigger:["\\scriptscriptstyle"],parse:()=>"Nothing"},{latexTrigger:["\\color"],parse:e=>(e.parseGroup(),"Nothing")},{latexTrigger:["\\tiny"],parse:()=>"Nothing"},{latexTrigger:["\\scriptsize"],parse:()=>"Nothing"},{latexTrigger:["\\footnotesize"],parse:()=>"Nothing"},{latexTrigger:["\\small"],parse:()=>"Nothing"},{latexTrigger:["\\normalsize"],parse:()=>"Nothing"},{latexTrigger:["\\large"],parse:()=>"Nothing"},{latexTrigger:["\\Large"],parse:()=>"Nothing"},{latexTrigger:["\\LARGE"],parse:()=>"Nothing"},{latexTrigger:["\\huge"],parse:()=>"Nothing"},{latexTrigger:["\\Huge"],parse:()=>"Nothing"},{name:"Annotated",serialize:(e,n)=>{let t=e.serialize(f(n,1)),i=uo(f(n,2));if(i==null)return t;i.dict.mathStyle==="normal"?t=I(["{\\displaystyle",t,"}"]):i.dict.mathStyle==="compact"&&(t=I(["{\\textstyle",t,"}"]));let r=i.dict.size;return r!==null&&r>=1&&r<=10&&(t=I(["{",{1:"\\tiny",2:"\\scriptsize",3:"\\footnotesize",4:"\\small",5:"\\normalsize",6:"\\large",7:"\\Large",8:"\\LARGE",9:"\\huge",10:"\\Huge"}[r],t,"}"])),i.dict.fontFamily==="monospace"?t=I(["\\texttt{",t,"}"]):i.dict.fontFamily==="sans-serif"&&(t=I(["\\textsf{",t,"}"])),i.dict.fontWeight==="bold"&&(t=I(["\\textbf{",t,"}"])),i.dict.fontStyle==="italic"?t=I(["\\textit{",t,"}"]):i.dict.fontStyle==="normal"&&(t=I(["\\textup{",t,"}"])),i.dict.color&&(t=I(["\\textcolor{",i.dict.color,"}{",t,"}"])),i.dict.backgroundColor&&(t=I(["\\colorbox{",i.dict.backgroundColor,"}{",t,"}"])),i.dict.border===!0&&(t=I(["\\boxed{",t,"}"])),t}},{latexTrigger:["\\!"],parse:()=>["HorizontalSpacing",-3]},{latexTrigger:["\\ "],parse:()=>["HorizontalSpacing",6]},{latexTrigger:["\\:"],parse:()=>["HorizontalSpacing",4]},{latexTrigger:["\\enskip"],parse:()=>["HorizontalSpacing",9]},{latexTrigger:["\\quad"],parse:()=>["HorizontalSpacing",18]},{latexTrigger:["\\qquad"],parse:()=>["HorizontalSpacing",36]},{latexTrigger:["\\,"],parse:()=>["HorizontalSpacing",3]},{latexTrigger:["\\;"],parse:()=>["HorizontalSpacing",5]},{latexTrigger:["\\enspace"],parse:()=>["HorizontalSpacing",9]},{latexTrigger:["\\phantom"],parse:e=>(e.parseGroup(),"Nothing")},{latexTrigger:["\\vphantom"],parse:e=>(e.parseGroup(),"Nothing")},{latexTrigger:["\\hphantom"],parse:e=>(e.parseGroup(),"Nothing")},{latexTrigger:["\\placeholder"],parse:e=>(e.parseOptionalGroup(),e.parseGroup()??"Nothing")},{latexTrigger:["\\smash"],parse:e=>(e.parseGroup(),"Nothing")},{latexTrigger:["\\strut"],parse:e=>"Nothing"},{latexTrigger:["\\mathstrut"],parse:e=>"Nothing"},{name:"HorizontalSpacing",serialize:(e,n)=>{if(f(n,2)!==null)return e.serialize(f(n,1));let t=C(f(n,1));return t===null?"":{"-3":"\\!",6:"\\ ",3:"\\,",4:"\\:",5:"\\;",9:"\\enspace",18:"\\quad",36:"\\qquad"}[t]??""}}];var Al=[{name:"Mu0",kind:"symbol",latexTrigger:"\\mu_0"},{name:"VacuumPermittivity",kind:"symbol",latexTrigger:"\\varepsilon_0"}];var $l=[...po,...go,...bo,...xo,...vo,...Qe,...wo,...Ao,...$o,...Do,...Fo,...Oo,...Uo,...Zo,...Al];var Cl="\\u{FE0F}",Rl="\\u{20E3}",Dl="\\u{200D}",Pl="\\p{RI}\\p{RI}",Fl="(?:[\\u{E0020}-\\u{E007E}]+\\u{E007F})",Yo=`(?:\\p{EMod}|${Cl}${Rl}?|${Fl})`,Ol="(?:(?=\\P{XIDC})\\p{Emoji})",Ho=`(?:${Ol}${Yo}*|\\p{Emoji}${Yo}+|${Pl})`,Wo=`(?:${Ho})(${Dl}${Ho})*`,Xh=new RegExp(`(?:${Wo})+`,"u"),Xo=new RegExp(`^(?:${Wo})+$`,"u");function Ko(e){return e!==void 0&&"value"in e}function Wn(e){return e!==void 0&&"operator"in e}function Tn(e,n,t=!0){let i=!t||e.every(s=>s.isCanonical)?e:e.map(s=>s.canonical);if(n){let s=a=>_(a,"Nothing")||a.operator===n||a.operator==="Sequence";if(i.every(a=>!s(a)))return i;let o=[];for(let a of i)_(a,"Nothing")||(h(a)&&(a.operator===n||a.operator==="Sequence")?o.push(...Tn(a.ops,n,t)):o.push(a));return o}if(i.every(s=>!(_(s,"Nothing")||s.operator==="Sequence")))return i;let r=[];for(let s of i)_(s,"Nothing")||(h(s,"Sequence")?r.push(...Tn(s.ops,n,t)):r.push(s));return r}function Dt(e,n,t){if(n=Tn(n),!e.strict||n.length===t)return n;let i=[...n.slice(0,t)],r=Math.min(t,n.length);for(;r<t;)i.push(e.error("missing")),r+=1;for(;r<n.length;)i.push(e.error("unexpected-argument",n[r].toString())),r+=1;return i}function Ue(e,n,t){return n==null?e.error("missing"):t===void 0?e.error("unexpected-argument",n.toString()):(n=n.canonical,!n.isValid||n.type.matches(t)?n:e.typeError(t,n.type,n))}function Oi(e,n,t){if(n.length===t.length&&n.every((r,s)=>r.type.matches(t[s])))return n;let i=[];for(let r=0;r<=t.length-1;r++)i.push(Ue(e,n[r],t[r]));for(let r=t.length;r<=n.length-1;r++)i.push(e.error("unexpected-argument",n[r].toString()));return i}function ea(e){let n={},t=Zl(e.engine),i=Ul(e.engine);if(_(e)&&!n[e.symbol]&&!e.symbol.startsWith("_")){if(!t.includes(e.symbol)){let r=yt(e.symbol,t);r&&(n[e.symbol]=r)}}else if(h(e)&&!n[e.operator]&&!e.operator.startsWith("_")){let r=e.operator;if(!i.includes(r)){let s=yt(r,i);s&&(n[r]=s)}for(let s of e.ops)n={...n,...ea(s)}}return n}function Ul(e){let n=[],t=e.context.lexicalScope;for(;t;){for(let i of t.bindings.keys()){let r=t.bindings.get(i);Wn(r)&&n.push(i)}t=t.parent}return n}function Zl(e){let n=[],t=e.context.lexicalScope;for(;t;){for(let i of t.bindings.keys()){let r=t.bindings.get(i);Ko(r)&&n.push(i)}t=t.parent}return n}function Be(e){let n=ea(e);if(Object.keys(n).length===0)return"";if(Object.keys(n).length===1){let[i,r]=Object.entries(n)[0];return`Unknown symbol "${i}". Did you mean "${r}"?`}let t=[];for(let[i,r]of Object.entries(n))t.push(`- "${i}" -> "${r}"?`);return`Unknown symbols found:
|
|
8
|
+
${t.join(`
|
|
9
|
+
`)}`}var re=Math.cosh||function(e){return Math.abs(e)<1e-9?1-e:(Math.exp(e)+Math.exp(-e))*.5},be=Math.sinh||function(e){return Math.abs(e)<1e-9?e:(Math.exp(e)-Math.exp(-e))*.5},Yl=function(e){var n=Math.PI/4;if(-n>e||e>n)return Math.cos(e)-1;var t=e*e;return t*(t*(t*(t*(t*(t*(t*(t/20922789888e3-1/87178291200)+1/479001600)-1/3628800)+1/40320)-1/720)+1/24)-1/2)},Hl=function(e,n){var t=Math.abs(e),i=Math.abs(n);return t<3e3&&i<3e3?Math.sqrt(t*t+i*i):(t<i?(t=i,i=e/n):i=n/e,t*Math.sqrt(1+i*i))},In=function(){throw SyntaxError("Invalid Param")};function Li(e,n){var t=Math.abs(e),i=Math.abs(n);return e===0?Math.log(i):n===0?Math.log(t):t<3e3&&i<3e3?Math.log(e*e+n*n)*.5:(e=e/2,n=n/2,.5*Math.log(e*e+n*n)+Math.LN2)}var Wl=function(e,n){var t={re:0,im:0};if(e==null)t.re=t.im=0;else if(n!==void 0)t.re=e,t.im=n;else switch(typeof e){case"object":if("im"in e&&"re"in e)t.re=e.re,t.im=e.im;else if("abs"in e&&"arg"in e){if(!Number.isFinite(e.abs)&&Number.isFinite(e.arg))return $.INFINITY;t.re=e.abs*Math.cos(e.arg),t.im=e.abs*Math.sin(e.arg)}else if("r"in e&&"phi"in e){if(!Number.isFinite(e.r)&&Number.isFinite(e.phi))return $.INFINITY;t.re=e.r*Math.cos(e.phi),t.im=e.r*Math.sin(e.phi)}else e.length===2?(t.re=e[0],t.im=e[1]):In();break;case"string":t.im=t.re=0;var i=e.match(/\d+\.?\d*e[+-]?\d+|\d+\.?\d*|\.\d+|./g),r=1,s=0;i===null&&In();for(var o=0;o<i.length;o++){var a=i[o];a===" "||a===" "||a===`
|
|
10
|
+
`||(a==="+"?r++:a==="-"?s++:a==="i"||a==="I"?(r+s===0&&In(),i[o+1]!==" "&&!isNaN(Number(i[o+1]))?(t.im+=parseFloat((s%2?"-":"")+i[o+1]),o++):t.im+=parseFloat((s%2?"-":"")+"1"),r=s=0):((r+s===0||isNaN(Number(a)))&&In(),i[o+1]==="i"||i[o+1]==="I"?(t.im+=parseFloat((s%2?"-":"")+a),o++):t.re+=parseFloat((s%2?"-":"")+a),r=s=0))}r+s>0&&In();break;case"number":t.im=0,t.re=e;break;default:In()}return isNaN(t.re)||isNaN(t.im),t},$=class e{constructor(n,t){this.re=0,this.im=0;var i=Wl(n,t);this.re=i.re,this.im=i.im}sign(){var n=this.abs();return new e(this.re/n,this.im/n)}add(n,t){var i=new e(n,t);return this.isInfinite()&&i.isInfinite()?e.NAN:this.isInfinite()||i.isInfinite()?e.INFINITY:new e(this.re+i.re,this.im+i.im)}sub(n,t){var i=new e(n,t);return this.isInfinite()&&i.isInfinite()?e.NAN:this.isInfinite()||i.isInfinite()?e.INFINITY:new e(this.re-i.re,this.im-i.im)}mul(n,t){var i=new e(n,t);return this.isInfinite()&&i.isZero()||this.isZero()&&i.isInfinite()?e.NAN:this.isInfinite()||i.isInfinite()?e.INFINITY:i.im===0&&this.im===0?new e(this.re*i.re,0):new e(this.re*i.re-this.im*i.im,this.re*i.im+this.im*i.re)}div(n,t){var i=new e(n,t);if(this.isZero()&&i.isZero()||this.isInfinite()&&i.isInfinite())return e.NAN;if(this.isInfinite()||i.isZero())return e.INFINITY;if(this.isZero()||i.isInfinite())return e.ZERO;n=this.re,t=this.im;var r=i.re,s=i.im,o,a;return s===0?new e(n/r,t/r):Math.abs(r)<Math.abs(s)?(a=r/s,o=r*a+s,new e((n*a+t)/o,(t*a-n)/o)):(a=s/r,o=s*a+r,new e((n+t*a)/o,(t-n*a)/o))}pow(n,t){var i=new e(n,t);if(n=this.re,t=this.im,i.isZero())return e.ONE;if(i.im===0){if(t===0&&n>0)return new e(Math.pow(n,i.re),0);if(n===0)switch((i.re%4+4)%4){case 0:return new e(Math.pow(t,i.re),0);case 1:return new e(0,Math.pow(t,i.re));case 2:return new e(-Math.pow(t,i.re),0);case 3:return new e(0,-Math.pow(t,i.re))}}if(n===0&&t===0&&i.re>0&&i.im>=0)return e.ZERO;var r=Math.atan2(t,n),s=Li(n,t);return n=Math.exp(i.re*s-i.im*r),t=i.im*s+i.re*r,new e(n*Math.cos(t),n*Math.sin(t))}sqrt(){var n=this.re,t=this.im,i=this.abs(),r,s;if(n>=0){if(t===0)return new e(Math.sqrt(n),0);r=.5*Math.sqrt(2*(i+n))}else r=Math.abs(t)/Math.sqrt(2*(i-n));return n<=0?s=.5*Math.sqrt(2*(i-n)):s=Math.abs(t)/Math.sqrt(2*(i+n)),new e(r,t<0?-s:s)}exp(){var n=Math.exp(this.re);return this.im,new e(n*Math.cos(this.im),n*Math.sin(this.im))}expm1(){var n=this.re,t=this.im;return new e(Math.expm1(n)*Math.cos(t)+Yl(t),Math.exp(n)*Math.sin(t))}log(){var n=this.re,t=this.im;return t===0&&n>0,new e(Li(n,t),Math.atan2(t,n))}abs(){return Hl(this.re,this.im)}arg(){return Math.atan2(this.im,this.re)}sin(){var n=this.re,t=this.im;return new e(Math.sin(n)*re(t),Math.cos(n)*be(t))}cos(){var n=this.re,t=this.im;return new e(Math.cos(n)*re(t),-Math.sin(n)*be(t))}tan(){var n=2*this.re,t=2*this.im,i=Math.cos(n)+re(t);return new e(Math.sin(n)/i,be(t)/i)}cot(){var n=2*this.re,t=2*this.im,i=Math.cos(n)-re(t);return new e(-Math.sin(n)/i,be(t)/i)}sec(){var n=this.re,t=this.im,i=.5*re(2*t)+.5*Math.cos(2*n);return new e(Math.cos(n)*re(t)/i,Math.sin(n)*be(t)/i)}csc(){var n=this.re,t=this.im,i=.5*re(2*t)-.5*Math.cos(2*n);return new e(Math.sin(n)*re(t)/i,-Math.cos(n)*be(t)/i)}asin(){var n=this.re,t=this.im,i=new e(t*t-n*n+1,-2*n*t).sqrt(),r=new e(i.re-t,i.im+n).log();return new e(r.im,-r.re)}acos(){var n=this.re,t=this.im,i=new e(t*t-n*n+1,-2*n*t).sqrt(),r=new e(i.re-t,i.im+n).log();return new e(Math.PI/2-r.im,r.re)}atan(){var n=this.re,t=this.im;if(n===0){if(t===1)return new e(0,1/0);if(t===-1)return new e(0,-1/0)}var i=n*n+(1-t)*(1-t),r=new e((1-t*t-n*n)/i,-2*n/i).log();return new e(-.5*r.im,.5*r.re)}acot(){var n=this.re,t=this.im;if(t===0)return new e(Math.atan2(1,n),0);var i=n*n+t*t;return i!==0?new e(n/i,-t/i).atan():new e(n!==0?n/0:0,t!==0?-t/0:0).atan()}asec(){var n=this.re,t=this.im;if(n===0&&t===0)return new e(0,1/0);var i=n*n+t*t;return i!==0?new e(n/i,-t/i).acos():new e(n!==0?n/0:0,t!==0?-t/0:0).acos()}acsc(){var n=this.re,t=this.im;if(n===0&&t===0)return new e(Math.PI/2,1/0);var i=n*n+t*t;return i!==0?new e(n/i,-t/i).asin():new e(n!==0?n/0:0,t!==0?-t/0:0).asin()}sinh(){var n=this.re,t=this.im;return new e(be(n)*Math.cos(t),re(n)*Math.sin(t))}cosh(){var n=this.re,t=this.im;return new e(re(n)*Math.cos(t),be(n)*Math.sin(t))}tanh(){var n=2*this.re,t=2*this.im,i=re(n)+Math.cos(t);return new e(be(n)/i,Math.sin(t)/i)}coth(){var n=2*this.re,t=2*this.im,i=re(n)-Math.cos(t);return new e(be(n)/i,-Math.sin(t)/i)}csch(){var n=this.re,t=this.im,i=Math.cos(2*t)-re(2*n);return new e(-2*be(n)*Math.cos(t)/i,2*re(n)*Math.sin(t)/i)}sech(){var n=this.re,t=this.im,i=Math.cos(2*t)+re(2*n);return new e(2*re(n)*Math.cos(t)/i,-2*be(n)*Math.sin(t)/i)}asinh(){var n=this.im;this.im=-this.re,this.re=n;var t=this.asin();return this.re=-this.im,this.im=n,n=t.re,t.re=-t.im,t.im=n,t}acosh(){var n=this.acos();if(n.im<=0){var t=n.re;n.re=-n.im,n.im=t}else{var t=n.im;n.im=-n.re,n.re=t}return n}atanh(){var n=this.re,t=this.im,i=n>1&&t===0,r=1-n,s=1+n,o=r*r+t*t,a=o!==0?new e((s*r-t*t)/o,(t*r+s*t)/o):new e(n!==-1?n/0:0,t!==0?t/0:0),u=a.re;return a.re=Li(a.re,a.im)/2,a.im=Math.atan2(a.im,u)/2,i&&(a.im=-a.im),a}acoth(){var n=this.re,t=this.im;if(n===0&&t===0)return new e(0,Math.PI/2);var i=n*n+t*t;return i!==0?new e(n/i,-t/i).atanh():new e(n!==0?n/0:0,t!==0?-t/0:0).atanh()}acsch(){var n=this.re,t=this.im;if(t===0)return new e(n!==0?Math.log(n+Math.sqrt(n*n+1)):1/0,0);var i=n*n+t*t;return i!==0?new e(n/i,-t/i).asinh():new e(n!==0?n/0:0,t!==0?-t/0:0).asinh()}asech(){var n=this.re,t=this.im;if(this.isZero())return e.INFINITY;var i=n*n+t*t;return i!==0?new e(n/i,-t/i).acosh():new e(n!==0?n/0:0,t!==0?-t/0:0).acosh()}inverse(){if(this.isZero())return e.INFINITY;if(this.isInfinite())return e.ZERO;var n=this.re,t=this.im,i=n*n+t*t;return new e(n/i,-t/i)}conjugate(){return new e(this.re,-this.im)}neg(){return new e(-this.re,-this.im)}ceil(n){return n=Math.pow(10,n||0),new e(Math.ceil(this.re*n)/n,Math.ceil(this.im*n)/n)}floor(n){return n=Math.pow(10,n||0),new e(Math.floor(this.re*n)/n,Math.floor(this.im*n)/n)}round(n){return n=Math.pow(10,n||0),new e(Math.round(this.re*n)/n,Math.round(this.im*n)/n)}equals(n,t){var i=new e(n,t);return Math.abs(i.re-this.re)<=e.EPSILON&&Math.abs(i.im-this.im)<=e.EPSILON}clone(){return new e(this.re,this.im)}toString(){var n=this.re,t=this.im,i="";return this.isNaN()?"NaN":this.isInfinite()?"Infinity":(Math.abs(n)<e.EPSILON&&(n=0),Math.abs(t)<e.EPSILON&&(t=0),t===0?i+n:(n!==0?(i+=n,i+=" ",t<0?(t=-t,i+="-"):i+="+",i+=" "):t<0&&(t=-t,i+="-"),t!==1&&(i+=t),i+"i"))}toVector(){return[this.re,this.im]}valueOf(){return this.im===0?this.re:null}isNaN(){return isNaN(this.re)||isNaN(this.im)}isZero(){return this.im===0&&this.re===0}isFinite(){return isFinite(this.re)&&isFinite(this.im)}isInfinite(){return!(this.isNaN()||this.isFinite())}};$.ZERO=new $(0,0);$.ONE=new $(1,0);$.I=new $(0,1);$.PI=new $(Math.PI,0);$.E=new $(Math.E,0);$.INFINITY=new $(1/0,1/0);$.NAN=new $(NaN,NaN);$.EPSILON=1e-15;function Z(e){if(!X(e))return null;let n=e.numericValue;return Math.round(typeof n=="number"?n:n.re)}function ta(e){return e?._kind==="number"}function sc(e){return e?._kind==="symbol"}function Xn(e,n){return(e?._kind==="function"||e?._kind==="tensor")&&(n===void 0||e.operator===n)}function Ze(e){if(Xn(e,"Interval")){let n=e.op1,t=e.op2,i=!1,r=!1;Xn(n,"Open")?(i=!0,n=n.op1):Xn(n,"Closed")&&(n=n.op1),Xn(t,"Open")?(r=!0,t=t.op1):Xn(t,"Closed")&&(t=t.op1);let s=n.N(),o=t.N();return!ta(s)||!ta(o)?void 0:{start:s.re,openStart:i,end:o.re,openEnd:r}}if(sc(e)){if(e.symbol==="EmptySet")return{start:0,openStart:!0,end:0,openEnd:!0};if(e.symbol==="RealNumbers")return{start:-1/0,openStart:!1,end:1/0,openEnd:!1};if(e.symbol==="NegativeNumbers")return{start:-1/0,openStart:!1,end:0,openEnd:!0};if(e.symbol==="NonPositiveNumbers")return{start:-1/0,openStart:!1,end:0,openEnd:!1};if(e.symbol==="PositiveNumbers")return{start:0,openStart:!0,end:1/0,openEnd:!1};if(e.symbol==="NonNegativeNumbers")return{start:0,openStart:!1,end:1/0,openEnd:!1}}}function ia(e,n,t){return n.every(i=>i.isCanonical)?n:n.map(i=>e.expr(i,{scope:t}))}var Qn=50,fb={List:{complexity:8200,signature:"(any*) -> list",type:(e,{engine:n})=>Y(`list<${ce.widen(...e.map(t=>t.type))}>`),canonical:oc,lazy:!0,evaluate:(e,{engine:n,materialization:t})=>{if(t)return n._fn("List",Ji(e).map(i=>i.evaluate({materialization:t})))},eq:sa,collection:vt()},Set:{complexity:8200,signature:"(any*) -> set",type:(e,{engine:n})=>Y(`set<${ce.widen(...e.map(t=>t.type))}>`),canonical:ac,eq:(e,n)=>{if(e.operator!==n.operator||!h(e)||!h(n)||e.nops!==n.nops)return!1;let t=i=>n.ops.some(r=>i.isSame(r));return e.ops.every(t)},collection:{...vt(),at:void 0,indexWhere:void 0}},Tuple:{description:"A fixed number of heterogeneous elements",complexity:8200,signature:"(any*) -> tuple",type:e=>Y(`tuple<${e.map(n=>n.type).join(", ")}>`),canonical:(e,{engine:n})=>n.tuple(...e),eq:sa,collection:{...vt(),keys:e=>["first","second","last"]}},KeyValuePair:{description:"A key/value pair",complexity:8200,signature:"(key: string, value: any) -> tuple<string, unknown>",type:([e,n])=>Y(`tuple<string, ${n.type}>`),canonical:(e,{engine:n})=>{let[t,i]=Oi(n,e,["string","any"]);return!t.isValid||!i.isValid?n._fn("KeyValuePair",[t,i]):n.tuple(t,i)}},Single:{description:"A tuple with a single element",complexity:8200,signature:"(value: any) -> tuple<any>",type:([e])=>Y(`tuple<${e.type}>`),canonical:(e,{engine:n})=>n.tuple(...Dt(n,e,1))},Pair:{description:"A tuple of two elements",complexity:8200,signature:"(first: any, second: any) -> tuple<any, any>",type:([e,n])=>Y(`tuple<${e.type}, ${n.type}>`),canonical:(e,{engine:n})=>n.tuple(...Dt(n,e,2))},Triple:{description:"A tuple of three elements",complexity:8200,signature:"(first: any, second: any, third: any) -> tuple<any, any, any>",type:([e,n,t])=>Y(`tuple<${e.type}, ${n.type}, ${t.type}>`),canonical:(e,{engine:n})=>n.tuple(...Dt(n,e,3))},Range:{complexity:8200,signature:"(number, number?, step: number?) -> indexed_collection<integer>",canonical:(e,{engine:n})=>e.length===0?null:e.length===1?n._fn("Range",[n.One,e[0].canonical]):e.length===2?n._fn("Range",[e[0].canonical,e[1].canonical]):n._fn("Range",[e[0].canonical,e[1].canonical,e[2].canonical.evaluate()]),eq:(e,n)=>{if(e.operator!==n.operator)return!1;let[t,i,r]=Ve(e),[s,o,a]=Ve(n);return t===s&&i===o&&r===a},collection:{isLazy:e=>!0,count:e=>{let[n,t,i]=Ve(e);return i===0?0:!isFinite(n)||!isFinite(t)?1/0:1+Math.max(0,Math.floor((t-n)/i))},contains:(e,n)=>{if(!n.type.matches("integer"))return!1;let t=n.re,[i,r,s]=Ve(e);return s===0?!1:s>0?t>=i&&t<=r:t<=i&&t>=r},iterator:e=>{let[n,t,i]=Ve(e),r=i===0?0:Math.floor((t-n)/i)+1,s=1;return{next:()=>s===r+1?{value:void 0,done:!0}:(s+=1,{value:e.engine.number(n+i*(s-1-1)),done:!1})}},at:(e,n)=>{if(typeof n!="number")return;let[t,i,r]=Ve(e);if(!(n<1||n>1+(i-t)/r))return e.engine.number(t+r*(n-1))},indexWhere:void 0,subsetOf:(e,n)=>{if(n.operator==="Range"){let[i,r,s]=Ve(e),[o,a,u]=Ve(n);return i>=o&&r<=a&&s%u===0}if(!n.isCollection)return!1;let t=1;for(let i of n.each()){if(!e.contains(i)||!e.at(t)?.isSame(i))return!1;t++}return!0},eltsgn:e=>{let[n,t,i]=Ve(e);return i===0?"zero":i>0?n<=t?"positive":"negative":n>=t?"positive":"negative"},elttype:e=>"finite_integer"}},Interval:{description:"A set of real numbers between two endpoints. The endpoints may or may not be included.",complexity:8200,lazy:!0,signature:"(number, number) -> set<real>",canonical:([e,n],{engine:t})=>{if(!e||!n)return null;let[i,r]=Oi(t,[e.canonical,n.canonical],["number","number"]);return!i.isValid||!r.isValid?null:t._fn("Interval",[i,r])},eq:(e,n)=>{let t=Ze(e),i=Ze(n);return!t||!i?!1:t.start===i.start&&t.end===i.end&&t.openStart===i.openStart&&t.openEnd===i.openEnd},collection:{count:e=>1/0,iterator:e=>{let n=Ze(e);if(!n)return{next:()=>({value:void 0,done:!0})};if(n.start>=n.end)return{next:()=>({value:void 0,done:!0})};let t=e.engine,i=0,r=0;return{next:()=>{let s=Math.pow(2,i);r>=s&&(i++,r=0);let o=(2*r+1)/Math.pow(2,i+1),a=n.start+o*(n.end-n.start);return r++,{value:t.number(a),done:!1}}}},isEmpty:e=>{let n=Ze(e);return n?n.openStart&&n.start===n.end||n.openEnd&&n.start===n.end?!0:n.openStart&&n.openEnd?!1:n.start>=n.end:!1},isFinite:e=>!1,contains:(e,n)=>{let t=Ze(e);return!t||t.openStart&&n.isLessEqual(t.start)||t.openEnd&&n.isGreaterEqual(t.end)?!1:n.isGreaterEqual(t.start)&&n.isLessEqual(t.end)},eltsgn:e=>{let n=Ze(e);if(!n||n.start===n.end)return"unsigned";if(n.start>=0&&!n.openStart)return"non-negative";if(n.end<=0&&!n.openEnd)return"non-positive";if(n.start>0&&n.end>0)return"positive";if(n.start<0&&n.end<0)return"negative"},elttype:e=>{let n=Ze(e);return n?isFinite(n.start)&&isFinite(n.end)?"finite_real":"real":"never"}}},Linspace:{complexity:8200,signature:"(start: number, end: number?, count: number?) -> indexed_collection",collection:{isLazy:e=>!0,count:e=>{if(!h(e))return;let n=e.op3.re;return isFinite(n)||(n=Qn),Math.max(0,Math.floor(n))},at:(e,n)=>{if(typeof n!="number"||!h(e))return;let t=e.op1.re,i=e.op2.re,r=e.op3.re;if(isFinite(r)||(r=Qn),!(!isFinite(t)||!isFinite(i))&&!(n<1||n>r))return e.engine.number(t+(i-t)*(n-1)/r)},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=e.op1.re,t=e.op2.re,i;isFinite(t)?i=Math.max(0,isFinite(e.op3.re)?e.op3.re:Qn):(t=n,n=1,i=Qn);let r=1;return{next:()=>r===i+1?{value:void 0,done:!0}:(r+=1,{value:e.engine.number(n+(t-n)*(r-1-1)/i),done:!1})}},contains:(e,n)=>{if(!n.type.matches("finite_real")||!h(e))return!1;let t=n.re,i=e.op1.re,r=e.op2.re;if(t<i||t>r)return!1;let s=e.op3.re;if(isFinite(s)||(s=Qn),s===0)return!1;let o=(r-i)/s;return(t-i)%o===0}}},Contains:{description:"Return True if the collection contains the given element, False otherwise.",complexity:8200,signature:"(collection, element: any) -> boolean",evaluate:([e,n],{engine:t})=>e.contains(n)?t.True:t.False},Count:{description:["Return the number of elements in the collection."],complexity:8200,signature:"(collection) -> integer",evaluate:([e],{engine:n})=>e.isEmptyCollection?n.Zero:n.number(e.count),sgn:([e])=>e.isEmptyCollection?"zero":"positive"},IsEmpty:{description:["Return True if the collection is empty, False otherwise."],complexity:8200,signature:"(collection) -> boolean",evaluate:([e],{engine:n})=>e.isEmptyCollection?n.True:n.False},Map:{description:["Return the collection where each element has been transformed by the mapping function.","Equivalent to `[f(x) for x in xs]`."],complexity:8200,lazy:!0,signature:"(collection, function) -> collection",type:e=>e[0].type,canonical:(e,{engine:n})=>{let t=Ue(n,e[0]?.canonical,"collection"),i=Ce(e[1]);return!t.isValid||!i?null:n._fn("Map",[t,i])},collection:{isLazy:e=>!0,count:e=>{if(h(e))return e.op1.count},isEmpty:e=>{if(h(e))return e.op1.isEmptyCollection},isFinite:e=>{if(h(e))return e.op1.isFiniteCollection},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=ne(e.op2);if(!n)return{next:()=>({value:void 0,done:!0})};let t=e.op1.each();return{next:()=>{for(;;){let{value:i,done:r}=t.next();return r?{value:void 0,done:!0}:{value:n([i])??e.engine.Nothing,done:!1}}}}},at:(e,n)=>{if(!h(e)||!e.isIndexedCollection||typeof n!="number"||!Number.isFinite(n)||n===0)return;let t=e.op1.at(n);if(t)return ne(e.op2)?.([t])}}},Filter:{description:["Return the elements of the collection for which the predicate function returns True.","Equivalent to `[x for x in xs if p(x)]`."],complexity:8200,lazy:!0,signature:"(collection, predicate: function) -> collection",type:e=>e[0].type,canonical:(e,{engine:n})=>{let t=Ue(n,e[0]?.canonical,"collection"),i=Ce(e[1]);return!t.isValid||!i?null:n._fn("Filter",[t,i])},collection:{isLazy:e=>!0,count:e=>1/0,contains:(e,n)=>{if(!h(e)||!e.contains(n))return!1;let t=ne(e.op2);return de(t([n]))==="True"},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=ne(e.op2);if(!n)return{next:()=>({value:void 0,done:!0})};let t=e.op1.each(),i=0,r=e.engine.iterationLimit;return{next:()=>{for(;;){let{value:s,done:o}=t.next();if(i+=1,i>r)throw new pn({cause:"iteration-limit-exceeded",message:`Iteration limit of ${r} exceeded while evaluating Filter()`});if(o)return{value:void 0,done:!0};let a=n([s]);if(!a)throw new Error(`Invalid filter predicate. ${Be(e.op2)}`);if(de(a)==="True")return{value:s,done:!1};if(de(a)!=="False")throw new Error(`Filter predicate must return "True" or "False". ${Be(e.op2)}`)}}}},at:(e,n)=>{if(typeof n!="number"||!Number.isFinite(n)||n===0||!h(e))return;let t=ne(e.op2);if(!t)return;if(n<0){if(!e.op1.isFiniteCollection)return;let r=Array.from(e.each()),s=r.length+n+1;return s<1||s>r.length?void 0:r[s-1]}let i=0;for(let r of e.op1.each()){let s=de(t([r]));if(s==="True"){if(i+=1,i===n)return r}else if(s!=="False")throw new Error(`Filter predicate must return "True" or "False". ${Be(e.op2)}`)}}}},Reduce:{complexity:8200,lazy:!0,signature:"(collection, function, initial:value?) -> value",canonical:(e,{engine:n})=>{let t=Ue(n,e[0],"collection"),i=Ce(e[1]);if(!t.isValid||!i)return null;let r=e[2]?.canonical;return r?.isValid?n._fn("Reduce",[t,i,r]):n._fn("Reduce",[t,i])},type:e=>Y(bi(e[1].type.type)??"unknown"),evaluate:([e,n,t],{engine:i})=>{if(!e.isFiniteCollection)return;if(t??=i.Nothing,t.type.matches("real")&&e.type.matches(i.type("collection<real>"))){let s=i._compile(n);return s.calling!=="lambda"||!s.run?void 0:xi((function*(){let o=t.re,a=!0;for(let u of e.each())a?o=u.re:o=s.run(o,u.re),a=!1,yield;return i.expr(o)})(),i._timeRemaining)}let r=ne(n);return xi(ua(e,(s,o)=>r([s,o])??i.Nothing,t),i._timeRemaining)}},Join:{description:["Join the elements of some collections into a flat collection."],complexity:8200,signature:"(collection*) -> collection",type:uc,collection:{isLazy:e=>!0,count:e=>{if(!h(e))return;let n=0;for(let t of e.ops){let i=t.count;if(i===void 0)return;if(!Number.isFinite(i))return 1/0;n+=i}return n},contains:(e,n)=>h(e)?e.ops.some(t=>t.contains(n)):!1,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=e.ops.map(i=>i.each()),t=0;return{next:()=>{for(;;){let{value:i,done:r}=n[t].next();if(!r)return{value:i,done:!1};if(t+=1,t>=n.length)return{value:void 0,done:!0}}}}}}},At:{description:["Access an element of an indexed collection.","If the index is negative, it is counted from the end.","Multiple indices can be provided to access nested collections (e.g., matrices)."],complexity:8200,signature:"(value: indexed_collection, index: (number|string)+) -> unknown",type:([e])=>e.operatorDefinition?.collection?.elttype?.(e)??Te(e.type.type)??"any",evaluate:(e,{engine:n})=>{let t=e[0],i=1;for(;e[i];){let s=t.baseDefinition?.collection?.at;if(!s)return;let o=e[i],a=me(o)?o.string:void 0;if(a!==void 0)t=s(t,a)??n.Nothing;else{let u=e[i].re;if(!Number.isInteger(u))return;t=s(t,u)??n.Nothing}i+=1}return t}},Take:{description:["Return `n` elements from a collection."],complexity:8200,signature:"(xs: indexed_collection, count: number) -> indexed_collection",type:([e])=>`list<${Te(e.type.type)}>`,evaluate:(e,{engine:n,materialization:t})=>{if(!t)return;let i=n._fn("Take",e),r=Array.from(i.each());return n._fn("List",r)},collection:{isLazy:e=>!0,count:aa,isEmpty:e=>{if(!h(e))return;let[n,t]=e.ops;if(n.isEmptyCollection)return!0;if(n.isFiniteCollection===!1)return!1;let i=Math.max(0,Z(t)??0),r=n.count;if(r!==void 0)return Number.isFinite(i)?Math.min(r,i)===0:!1},isFinite:e=>{if(h(e))return e.op1.isFiniteCollection},iterator:lc,at:(e,n)=>{if(typeof n!="number"||n===0||!h(e))return;let t=Math.max(0,Z(e.op2)??0);if(t===0)return;if(n>0)return n>t?void 0:e.op1.at(n);let i=aa(e);if(!(i===void 0||i===0)&&!(n<-i))return e.op1.at(i+n)}}},Drop:{description:["Return the collection without the first n elements."],complexity:8200,signature:"(xs: indexed_collection, count: number) -> indexed_collection",type:([e])=>`list<${Te(e.type.type)}>`,collection:{isLazy:e=>!0,count:e=>{if(!h(e))return;let[n,t]=e.ops,i=n.count;if(i===void 0)return;if(!Number.isFinite(i))return 1/0;if(n.isEmptyCollection)return 0;let r=Z(t)??0;return r>=i?0:Math.max(0,i-r)},isFinite:e=>{if(h(e))return e.op1.isFiniteCollection},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let[n,t]=e.ops,i=Z(t)??0;if(i<=0)return n.each();let r=i+1;return{next:()=>{let s=e.op1.at(r++);return s===void 0?{value:void 0,done:!0}:{value:s,done:!1}}}},at:(e,n)=>{if(typeof n!="number"||!h(e))return;let[t,i]=e.ops,r=Z(i)??0;if(!(r<=0))return t.at(n+r)}}},First:{complexity:8200,signature:"(collection) -> any",type:([e])=>e.operatorDefinition?.collection?.elttype?.(e)??"any",evaluate:([e],{engine:n})=>e.at(1)??n.Nothing},Second:{complexity:8200,signature:"(collection) -> any",type:([e])=>e.operatorDefinition?.collection?.elttype?.(e)??"any",evaluate:([e],{engine:n})=>e.at(2)??n.Nothing},Last:{complexity:8200,signature:"(collection) -> any",type:([e])=>e.operatorDefinition?.collection?.elttype?.(e)??"any",evaluate:([e],{engine:n})=>e.at(-1)??n.Nothing},Rest:{description:["Return the collection without the first element.","If the collection has only one element, return an empty collection."],complexity:8200,signature:"(indexed_collection) -> indexed_collection",collection:{isLazy:e=>!0,count:e=>{if(!h(e))return;let n=e.op1.count;if(n!==void 0)return Math.max(0,n-1)},isEmpty:e=>{if(!h(e))return;if(e.op1.isEmptyCollection)return!0;let n=e.op1.count;if(n!==void 0)return n<=1},isFinite:e=>{if(h(e))return e.op1.isFiniteCollection},iterator:e=>h(e)?{next:()=>{let n=1,t=e.op1.at(n>0?n+1:n);return t?(n+=1,{value:t,done:!1}):{value:void 0,done:!0}}}:{next:()=>({value:void 0,done:!0})},at:(e,n)=>{if(typeof n=="number"&&h(e))return e.op1.at(n>0?n+1:n)}}},Most:{complexity:8200,description:["Return the collection without the last element.","If the collection has only one element, return an empty collection."],signature:"(indexed_collection) -> indexed_collection",collection:{isLazy:e=>!0,count:e=>{if(!h(e))return;let n=e.op1.count;if(n!==void 0)return Math.max(0,n-1)},isFinite:e=>{if(h(e))return e.op1.isFiniteCollection},isEmpty:e=>{if(!h(e))return;let n=e.op1.count;if(n!==void 0)return n<=1},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=e.op1.count;if(n===void 0||n<=1)return{next:()=>({value:void 0,done:!0})};let t=1,i=n-1;return{next:()=>t>i?{value:void 0,done:!0}:{value:e.op1.at(t++),done:!1}}},at:(e,n)=>{if(typeof n!="number"||!h(e))return;let t=e.op1.count;if(t!==void 0&&(n<1&&(n=t+1+n),!(n<1||n>t-1)))return e.op1.at(n)}}},Slice:{description:["Return a range of elements from an indexed collection.","If the index is negative, it is counted from the end."],complexity:8200,signature:"(value: indexed_collection, start: number, end: number) -> list",type:([e])=>Y(`list<${Te(e.type.type)}>`),collection:{isLazy:e=>!0,count:e=>{if(!h(e))return;let n=Z(e.op2)??1,t=e.op1.count;if(t===void 0)return;let i=Z(e.op3)??t;return n<1?Math.max(0,i+n-1):Math.max(0,Math.min(i,t)-n+1)},isFinite:e=>!0,at:(e,n)=>{if(typeof n!="number"||!h(e))return;let t=e.op1.count;if(t===void 0)return;let i=Z(e.op2)??1;if(i<1&&(i=t+1+i),i<1&&(i=1),i>t)return;let r=Z(e.op3)??t;r<1&&(r=t+1+r),r<1&&(r=1),r>t&&(r=t)},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=Z(e.op2)??1,t=e.op1.count;if(t===void 0)return{next:()=>({value:void 0,done:!0})};if(n<1&&(n=t+1+n),n<1&&(n=1),n>t)return{next:()=>({value:void 0,done:!0})};let i=Z(e.op3)??t;i<1&&(i=t+1+i),i<1&&(i=1),i>t&&(i=t);let r=n,s=i;return{next:()=>{if(r>s)return{value:void 0,done:!0};let o=e.op1.at(r);return r+=1,{value:o,done:!1}}}}}},Reverse:{complexity:8200,signature:"(indexed_collection) -> indexed_collection",type:([e])=>e.type,collection:{isLazy:e=>!0,count:e=>{if(h(e))return e.op1.count},isEmpty:e=>{if(h(e))return e.op1.isEmptyCollection},isFinite:e=>{if(h(e))return e.op1.isFiniteCollection},contains:(e,n)=>h(e)?e.op1.contains(n)??!1:!1,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=-1;return{next:()=>{if(n===0)return{value:void 0,done:!0};let t=e.op1.at(n);return n-=1,{value:t,done:!1}}}},at:(e,n)=>{if(typeof n=="number"&&h(e))return e.op1.at(-n)}}},RotateLeft:{description:"Rotate the elements of the collection to the left by n positions.",complexity:8200,signature:"(indexed_collection, integer?) -> indexed_collection",collection:{isLazy:e=>!0,count:e=>{if(h(e))return e.op1.count},isEmpty:e=>{if(h(e))return e.op1.isEmptyCollection},isFinite:e=>{if(h(e))return e.op1.isFiniteCollection},contains:(e,n)=>h(e)?e.op1.contains(n)??!1:!1,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=e.op1.count;if(n===void 0||n<=0)return{next:()=>({value:void 0,done:!0})};let t=Z(e.op2)??1;t=(t%n+n)%n;let i=1,r=n;return{next:()=>{if(i===r+1)return{value:void 0,done:!0};i+=1;let s=e.op1.at((i-1-1+t)%n+1);return s===void 0?{value:void 0,done:!0}:{value:s,done:!1}}}},at:(e,n)=>{if(typeof n!="number"||!h(e))return;let t=e.op1.count;if(t===void 0||t<=0||(n<1&&(n=t+1+n),n<1||n>t))return;let i=Z(e.op2)??1;return i=(i%t+t)%t,e.op1.at((n-1+i)%t+1)}}},RotateRight:{description:"Rotate the elements of the collection to the right by n positions.",complexity:8200,signature:"(indexed_collection, integer?) -> indexed_collection",collection:{isLazy:e=>!0,count:e=>{if(h(e))return e.op1.count},contains:(e,n)=>h(e)?e.op1.contains(n)??!1:!1,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=e.op1.count;if(n===void 0||n<=0)return{next:()=>({value:void 0,done:!0})};let t=Z(e.op2)??1;t=(t%n+n)%n;let i=1;return{next:()=>{if(i===n+1)return{value:void 0,done:!0};i+=1;let r=(i-1-1+(n-t))%n+1,s=e.op1.at(r);return s===void 0?{value:void 0,done:!0}:{value:s,done:!1}}}},at:(e,n)=>{if(typeof n!="number"||!h(e))return;let t=e.op1.count;if(t===void 0||t<=0||(n<1&&(n=t+1+n),n<1||n>t))return;let i=Z(e.op2)??1;i=(i%t+t)%t;let r=(n-1+(t-i))%t+1;return e.op1.at(r)}}},IndexOf:{description:"Return the 1-based index of the first occurrence of value in collection, or 0 if not found.",complexity:8200,signature:"(collection, any) -> integer",evaluate:([e,n],{engine:t})=>{let i=e.indexWhere(r=>r.isSame(n))??void 0;return t.number(i??0)}},IndexWhere:{description:"Return the 1-based index of the first element satisfying the predicate, or 0 if not found.",complexity:8200,signature:"(collection, function) -> integer",evaluate:([e,n],{engine:t})=>{let i=ne(n);if(!i)return t.Zero;let r=e.indexWhere(s=>{let o=de(i([s]));if(o==="True")return!0;if(o==="False")return!1;throw new Error(`Filter predicate must return "True" or "False". ${Be(n)}`)})??void 0;return t.number(r??0)}},Find:{description:"Return the first element of the collection satisfying the predicate, or Nothing if none found.",complexity:8200,signature:"(collection, function) -> any",type:e=>e[0].type,evaluate:([e,n],{engine:t})=>{let i=ne(n);if(!i)return t.Nothing;for(let r of e.each()){let s=de(i([r]));if(s!=="False"){if(s==="True")return r;throw new Error(`Filter predicate must return "True" or "False". ${Be(n)}`)}}return t.Nothing}},CountIf:{description:"Return the number of elements in the collection satisfying the predicate.",complexity:8200,signature:"(collection, function) -> integer",evaluate:([e,n],{engine:t})=>{let i=ne(n);if(!i)return t.Zero;let r=0;for(let s of e.each()){let o=de(i([s]));if(o!=="False")if(o==="True")r++;else throw new Error(`Filter predicate must return "True" or "False". ${Be(n)}`)}return t.number(r)}},Position:{description:"Return a list of indexes of elements in the collection satisfying the predicate.",complexity:8200,signature:"(collection, function) -> list<integer>",type:()=>"list<integer>",evaluate:([e,n],{engine:t})=>{let i=ne(n);if(!i)return t.function("List",[]);let r=[],s=1;for(let o of e.each()){let a=de(i([o]));if(a==="True"&&r.push(t.number(s)),a!=="False")throw new Error(`Filter predicate must return "True" or "False". ${Be(n)}`);s++}return t.function("List",r)}},Ordering:{description:"Return the indexes that would sort the collection.",complexity:8200,signature:"(indexed_collection, function?) -> list<integer>",evaluate:([e,n],{engine:t})=>{if(!e.isFiniteCollection)return t.function("List",[]);let i=oa(e,n);return i?t.function("List",i):t.function("List",[])}},Sort:{description:"Return the elements of the collection sorted according to the given comparison function.",complexity:8200,signature:"(indexed_collection, function?) -> indexed_collection",type:e=>e[0].type,evaluate:([e,n],{engine:t})=>{if(!e.isFiniteCollection)return t.function(e.operator,[]);let i=oa(e,n);if(i)return t.function(e.operator,i.map(r=>e.at(r)))}},Shuffle:{description:"Randomize the order of the elements in the collection.",complexity:8200,signature:"(indexed_collection) -> indexed_collection",type:e=>e[0].type,evaluate:([e],{engine:n})=>{if(!e.isFiniteCollection)return;let t=Array.from(e.each());for(let i=t.length-1;i>0;i--){let r=Math.floor(Math.random()*(i+1));[t[i],t[r]]=[t[r],t[i]]}return n.function(e.operator,t)}},Tabulate:{description:"Create a collection by applying a function to each index in the specified dimensions.",complexity:8200,lazy:!0,signature:"(function, integer, integer?) -> collection",canonical:(e,{engine:n})=>{let t=Ce(e[0]);return t?e[2]?n._fn("Tabulate",[t,Ue(n,e[1]?.canonical,"integer"),Ue(n,e[2]?.canonical,"integer")]):n._fn("Tabulate",[t,Ue(n,e[1]?.canonical,"integer")]):null},evaluate:(e,{engine:n})=>{let t=ne(e[0]);if(!t)return;if(e.length===1)return n._fn("List",[]);let i=e.slice(1).map(s=>Z(s));if(i.some(s=>s===null||s<=0))return;if(i.length===1)return n._fn("List",Array.from({length:i[0]??0},(s,o)=>t([n.number(o+1)])??n.Nothing));let r=(s,o,a=0)=>{if(a===s.length){let l=o.map(c=>n.number(c));return t(l)??n.Nothing}let u=["List"];for(let l=1;l<=s[a];l++)o[a]=l,u.push(r(s,o,a+1));return u};return n.expr(r(i,Array(i.length).fill(0)))}},Tally:{description:"Return a tuple with the unique elements of the collection and their respective counts.",complexity:8200,signature:"(collection) -> tuple<list, list<integer>>",type:([e],{engine:n})=>{let t=e.type.type;return t==="string"?Y("tuple<list<string>, list<integer>>"):Y(`tuple<list<${Te(t)}>, list<integer>>`)},evaluate:(e,{engine:n})=>{if(!e[0].isFiniteCollection)return;let[t,i]=ra(e[0]);return n.tuple(n.function("List",t),n.function("List",i))}},Unique:{description:"Return a list of the unique elements of the collection.",complexity:8200,signature:"(collection) -> list",type:([e])=>`list<${Te(e.type.type)}>`,evaluate:(e,{engine:n})=>{if(!e[0].isFiniteCollection)return;let[t,i]=ra(e[0]);return n.function("List",t)}},Partition:{wikidata:"Q381060",complexity:8200,signature:"(collection, integer | function) -> list",type:([e])=>`list<${Te(e.type.type)}>`,evaluate:([e,n],{engine:t})=>{if(!e.isFiniteCollection)return;let i=Z(n);if(i!==null&&i>0){let a=Array.from(e.each()),u=[],l=Math.ceil(a.length/i);for(let c=0;c<i;c++){let p=a.slice(c*l,(c+1)*l);u.push(t.function("List",p))}return t.function("List",u)}let r=ne(n);if(!r)return;let s=[],o=[];for(let a of e.each()){let u=de(r([a]));if(u==="True")s.push(a);else if(u==="False")o.push(a);else throw new Error(`Partition predicate must return "True" or "False". ${Be(n)}`)}return t.function("List",[t.function("List",s),t.function("List",o)])}},Chunk:{description:"Split the collection into `k` nearly equal-sized chunks.",complexity:8200,signature:"(collection, integer) -> list<list>",evaluate:([e,n],{engine:t})=>{let i=Z(n);if(!e.isFiniteCollection||i===null||i<=0)return;let r=Array.from(e.each()),s=[],o=Math.ceil(r.length/i);for(let a=0;a<i;a++){let u=r.slice(a*o,(a+1)*o);s.push(t.function("List",u))}return t.function("List",s)}},GroupBy:{description:["Partition the collection into a dictionary of lists based on the key returned by the function."],complexity:8200,signature:"(collection, function) -> dictionary<list>",evaluate:([e,n],{engine:t})=>{if(!e.isFiniteCollection)return;let i=ne(n);if(!i)return;let r={};for(let s of e.each()){let o=i([s])??t.Nothing,a=(_(o)?o.symbol:void 0)??(me(o)?o.string:void 0)??o.toString();a in r||(r[a]=[]),r[a].push(s)}return t.function("Dictionary",Object.entries(r).map(([s,o])=>t._fn("Tuple",[t.string(s),t.function("List",o)])))}},Zip:{description:"Combine multiple collections element-wise into a list of tuples. The result has the length of the shortest input.",complexity:8200,signature:"(indexed_collection+) -> list",collection:{isLazy:e=>!0,count:Vi,isFinite:e=>{if(h(e))return e.ops.every(n=>n.isFiniteCollection)},isEmpty:e=>{if(h(e))return e.nops===0||e.ops.every(n=>n.isEmptyCollection)},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=Vi(e);if(n===void 0||n<=0)return{next:()=>({value:void 0,done:!0})};let t=1;return{next:()=>{if(t===n+1)return{value:void 0,done:!0};t+=1;let i=e.ops.map(r=>r.at(t-1));return i.some(r=>r===void 0)?{value:void 0,done:!0}:{value:e.engine.tuple(...i),done:!1}}}},at:(e,n)=>{if(typeof n!="number"||n<1||!h(e))return;let t=Vi(e);if(t===void 0||n<1||n>t)return;let i=e.ops.map(r=>r.at(n));if(!i.some(r=>r===void 0))return e.engine.tuple(...i)}}},Iterate:{description:"Produce an infinite sequence by repeatedly applying a function to the previous value, starting with an initial value.",complexity:8200,signature:"((index: integer, acc:any) -> any, initial: any?) -> list",canonical:([e,n],{engine:t})=>{let i=Ce(e);if(!i)return null;let r=n?.canonical;return r?t._fn("Iterate",[i,r]):t._fn("Iterate",[i])},collection:{isLazy:e=>!0,count:()=>1/0,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=ne(e.op1);if(!n)return{next:()=>({value:void 0,done:!0})};let t=e.op2??e.engine.Nothing,i=0;return{next:()=>(i+=1,t=n([e.engine.number(i),t])??e.engine.Nothing,{value:t,done:!1})}},at:(e,n)=>{if(typeof n!="number"||n<1||!h(e))return;let t=ne(e.op1);if(!t)return;let i=e.op2??e.engine.Nothing;for(let r=1;r<n;r++)i=t([e.engine.number(r),i])??e.engine.Nothing;return i}}},Repeat:{description:"Produce an infinite sequence by repeating a single value.",complexity:8200,signature:"(value: any) -> list",collection:{isLazy:e=>!0,count:()=>1/0,isEmpty:e=>!1,isFinite:()=>!1,contains:(e,n)=>h(e)?e.op1.isSame(n):!1,iterator:e=>h(e)?{next:()=>({value:e.op1,done:!1})}:{next:()=>({value:void 0,done:!0})},at:(e,n)=>{if(h(e))return e.op1}}},Cycle:{description:"Produce an infinite sequence by cycling through the elements of a finite collection.",complexity:8200,signature:"(list) -> list",collection:{isLazy:e=>!0,count:()=>1/0,isEmpty:e=>e.isEmptyCollection,isFinite:e=>!e.isEmptyCollection,contains:(e,n)=>h(e)?e.op1.contains(n)??!1:!1,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=1,t=e.op1.count;return t===void 0||t===0?{next:()=>({value:void 0,done:!0})}:{next:()=>{let i=(n-1-1)%t+1,r=e.op1.at(i);return r===void 0?{value:void 0,done:!0}:(n+=1,{value:r,done:!1})}}},at:(e,n)=>{if(typeof n!="number"||n<1||!h(e))return;let t=e.op1.count;if(t===void 0||t===0)return;let i=(n-1)%t+1;return e.op1.at(i)}}},Fill:{description:"Produce a 2D list (matrix) by applying a function to each pair of row and column indexes.",complexity:8200,signature:"(function, tuple) -> list",collection:{isLazy:e=>!0,count:e=>!h(e)||!h(e.op2)?void 0:e.op2.ops.map(t=>Z(t)??0)[0]??0,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=ne(e.op1);if(!n)return{next:()=>({value:void 0,done:!0})};if(!h(e.op2))return{next:()=>({value:void 0,done:!0})};let t=e.op2.ops.map(a=>Z(a)??0),i=t[0]??0,r=t[1]??0,s=i,o=1;return{next:()=>{if(o===s+1)return{value:void 0,done:!0};o+=1;let a=[];for(let u=1;u<=r;u++)a.push(n([e.engine.number(o-1),e.engine.number(u)])??e.engine.Nothing);return{value:e.engine.function("List",a),done:!1}}}},at:(e,n)=>{if(typeof n!="number"||n<1||!h(e))return;let t=ne(e.op1);if(!t||!h(e.op2))return;let i=e.op2.ops.map(u=>Z(u)??0),r=i[0]??0,s=i[1]??0;if(n>r*s)return;let o=Math.ceil(n/s),a=(n-1)%s+1;return t([e.engine.number(o),e.engine.number(a)])??e.engine.Nothing}}},ListFrom:{description:"Create a list from the elements of a collection.",complexity:8200,signature:"(value*) -> list",type:e=>{if(e.length===0)return"list";let n="unknown";for(let t of e){if(t.isCollection&&!t.isFiniteCollection)return"list";n=pe(n,Te(t.type.type)??n)}return Y(`list<${q(n)}>`)},evaluate:(e,{engine:n})=>{let t=[];for(let i of e)if(!i.isCollection)t.push(i);else{if(!i.isFiniteCollection)return;t.push(...Array.from(i.each()))}return n.function("List",t)}},SetFrom:{description:"Create a set from the elements of a collection.",complexity:8200,signature:"(value*) -> set",type:e=>{if(e.length===0)return"set";let n="unknown";for(let t of e){if(t.isCollection&&!t.isFiniteCollection)return"set";n=pe(n,Te(t.type.type)??n)}return Y(`set<${q(n)}>`)},evaluate:(e,{engine:n})=>{let t=[];for(let i of e)if(i.isCollection)t.push(i);else{if(!i.isFiniteCollection)return;t.push(...Array.from(i.each()))}return n.function("Set",t)}},TupleFrom:{description:"Create a tuple from the elements of a collection.",complexity:8200,signature:"(value*) -> tuple",evaluate:(e,{engine:n})=>{let t=[];for(let i of e)if(i.isCollection)t.push(i);else{if(!i.isFiniteCollection)return;t.push(...Array.from(i.each()))}return n.tuple(...t)}},DictionaryFrom:{description:"Create a dictionary from the elements of a collection of (key, value) pairs.",complexity:8200,signature:"(collection) -> dictionary",evaluate:([e],{engine:n})=>{if(!e.isCollection)return;if(h(e,"Record"))return n.function("Dictionary",[...e.ops]);let t=[];for(let i of e.each()){if(!h(i)||i.nops!==2)throw new Error(`Expected a collection of pairs, got ${i.type}`);let r=i.op1,s=i.op2;if(!me(r))throw new Error(`Expected a string key, got ${r.type}`);t.push(n.tuple(r,s))}return n.function("Dictionary",t)}},RecordFrom:{description:"Create a record from the elements of a collection of (key, value) pairs.",complexity:8200,signature:"(collection) -> record",evaluate:([e],{engine:n})=>{if(!e.isCollection)return;if(h(e,"Dictionary"))return n.function("Record",[...e.ops]);let t=[];for(let i of e.each()){if(!h(i)||i.nops!==2)throw new Error(`Expected a collection of pairs, got ${i.type}`);let r=i.op1,s=i.op2;if(!me(r))throw new Error(`Expected a string key, got ${r.type}`);t.push(n.tuple(r,s))}return n.function("Record",t)}}};function Ve(e){if(!h(e))return[1,0,0];if(e.nops===0)return[1,0,0];let n=e.op1.re;if(isFinite(n)?n=Math.round(n):n=1,e.nops===1)return[1,n,1];let t=e.op2.re;if(!isFinite(t)&&!t?t=1:isFinite(t)&&(t=Math.round(t)),e.nops===2)return[n,t,t>n?1:-1];let i=e.op3.re;return isFinite(i)?i=Math.abs(Math.round(i)):i=1,[n,t,n<t?i:-i]}function oc(e,{engine:n}){let t=e[0];if(e.length===1&&h(t,"Matrix")){let[i,r,s]=t.ops;if(!r||me(r)&&r.string==="..")return s?n._fn("Matrix",[i,n.string("[]"),s]):n._fn("Matrix",[i,r])}return e=e.map(i=>h(i,"Delimiter")?h(i.op1,"Sequence")?n._fn("List",ia(n,i.op1.ops)):n._fn("List",[i.op1?.canonical??n.Nothing]):i.canonical),n._fn("List",e)}function ac(e,{engine:n}){let t=[],i=r=>t.some(s=>s.isSame(r));for(let r of e)i(r)||t.push(r);return n._fn("Set",t)}function ra(e){let n=[],t=[],i=r=>{for(let s=0;s<n.length;s++)if(n[s].isSame(r))return s;return-1};for(let r of e.each()){let s=i(r);s>=0?t[s]++:(n.push(r),t.push(1))}return[n,t]}function*ua(e,n,t){let i=t;for(let r of e.each()){let s=n(i,r);if(s===null)return;yield i,i=s}return i}function uc(e){return e.some(n=>n.type.matches("record"))?"record":e.some(n=>n.type.matches("dictionary"))?"dictionary":e.some(n=>n.type.matches("set"))?"set":"list"}function sa(e,n){return e.operator!==n.operator||!h(e)||!h(n)||e.nops!==n.nops?!1:e.ops.every((t,i)=>t.isSame(n.ops[i]))}function oa(e,n=void 0){let t=n?ne(n):void 0,i=t?(o,a)=>{let u=t([o,a]);return u?.isNegative?-1:u?.isSame(0)?0:1}:(o,a)=>o.isLess(a)?-1:o.isEqual(a)?0:1,r=e.count;if(r===void 0||!Number.isFinite(r)||r<1)return;let s=Array.from({length:r},(o,a)=>a+1);return s.sort((o,a)=>{let u=e.at(o),l=e.at(a);return i(u,l)}),s}function Ji(e){if(e.length===0)return[];let n=[];for(let t of e)de(t)!=="Nothing"&&(h(t,"Sequence")?n.push(...Ji([...t.ops])):me(t)?n.push(t):t.isCollection?n.push(...Ji([...t.each()])):n.push(t));return n}function lc(e){if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=Math.max(0,Z(e.op2)??0);if(n===0)return{next:()=>({value:void 0,done:!0})};let t=1,i=0;return{next:()=>{if(i>=Math.abs(n))return{value:void 0,done:!0};let r=e.op1.at(t);return r?(t+=1,i+=1,{value:r,done:!1}):{value:void 0,done:!0}}}}function aa(e){if(!h(e))return;let[n,t]=e.ops,i=n.count;if(i===void 0)return;let r=Math.max(0,Z(t)??0);return Number.isFinite(r)?Math.min(i,r):1/0}function Vi(e){if(!h(e))return;let n=e.ops.map(t=>t.count);if(!n.some(t=>t===void 0))return n.some(t=>!Number.isFinite(t))?1/0:n.length===0?0:Math.min(...n)}function la(e){e?.operator,h(e);let n=1,t=n+ci,i,r=!0,s=e,o=s.op1;i=_(o)?o.symbol:void 0,n=Math.floor(s.op2.re),isNaN(n)&&(n=1),Number.isFinite(n)||(r=!1);let a=s.op3;return(_(a)?a.symbol:void 0)==="Nothing"||a.isInfinity?r=!1:(isNaN(a.re)||(t=Math.floor(a.re??t)),Number.isFinite(t)||(r=!1)),!r&&Number.isFinite(n)&&(t=n+ci),{index:i,lower:n,upper:t,isFinite:r}}var g=class e{static compile(n,t,i=0){if(n===void 0)return"";if(!n.isValid)throw new Error(`Cannot compile invalid expression: "${n.toString()}"`);if(_(n)){let r=n.symbol,s=t.operators?.(r);return s!==void 0?`(a,b) => a ${s[0]} b`:t.var?.(r)??r}if(X(n)){if(n.im!==0){if(!t.complex)throw new Error("Complex numbers are not supported by this target");return t.complex(n.re,n.im)}return t.number(n.re)}if(me(n))return t.string(n.string);if(!h(n))throw new Error(`Cannot compile expression: "${n.toString()}"`);return e.compileExpr(n.engine,n.operator,n.ops,i,t)}static compileExpr(n,t,i,r,s){if(t==="Error")throw new Error("Error");if(t==="Sequence")return i.length===0?"":`(${i.map(u=>e.compile(u,s,r)).join(", ")})`;if(t==="Sum"||t==="Product"){let u=s.functions?.(t);return typeof u=="function"?u(i,l=>e.compile(l,s),s):typeof u=="string"?`${u}(${i.map(l=>e.compile(l,s)).join(", ")})`:e.compileLoop(t,i,s)}let o=s.operators?.(t);if(o!==void 0&&!i.some(l=>e.isComplexValued(l))){if(/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(o[0]))return`${o[0]}(${i.map(c=>e.compile(c,s)).join(", ")})`;if(i.every(c=>!c.isCollection)){if(vi(t)&&i.length>2){let p=[];for(let m=0;m<i.length-1;m++)p.push(e.compileExpr(n,t,[i[m],i[m+1]],o[1],s));return`(${p.join(") && (")})`}let c;return i.length===1?c=`${o[0]}${e.compile(i[0],s,o[1])}`:c=i.map(p=>e.compile(p,s,o[1])).join(` ${o[0]} `),o[1]<r?`(${c})`:c}}if(t==="Function"){let u=s.functions?.(t);if(typeof u=="function")return u(i,c=>e.compile(c,s),s);let l=i.slice(1).map(c=>_(c)?c.symbol:"_");return`((${l.join(", ")}) => ${e.compile(i[0].canonical,{...s,var:c=>l.includes(c)?c:s.var(c)})})`}if(t==="Declare"){let u=_(i[0])?i[0].symbol:"_";return s.declare?s.declare(u):`let ${u}`}if(t==="Assign")return`${_(i[0])?i[0].symbol:"_"} = ${e.compile(i[1],s)}`;if(t==="Return")return`return ${e.compile(i[0],s)}`;if(t==="Break")return"break";if(t==="Continue")return"continue";if(t==="Loop"){let u=s.functions?.(t);return typeof u=="function"?u(i,l=>e.compile(l,s),s):e.compileForLoop(i,s)}if(t==="If"){if(i.length!==3)throw new Error("If: wrong number of arguments");let u=s.functions?.(t);return u?typeof u=="function"?u(i,l=>e.compile(l,s),s):`${u}(${i.map(l=>e.compile(l,s)).join(", ")})`:`((${e.compile(i[0],s)}) ? (${e.compile(i[1],s)}) : (${e.compile(i[2],s)}))`}if(t==="Which"){if(i.length<2||i.length%2!==0)throw new Error("Which: expected even number of arguments (condition/value pairs)");let u=s.functions?.(t);if(u)return typeof u=="function"?u(i,c=>e.compile(c,s),s):`${u}(${i.map(c=>e.compile(c,s)).join(", ")})`;let l=c=>{if(c>=i.length)return"NaN";let p=i[c],m=i[c+1];return _(p,"True")?`(${e.compile(m,s)})`:`((${e.compile(p,s)}) ? (${e.compile(m,s)}) : ${l(c+2)})`};return l(0)}if(t==="Block")return e.compileBlock(i,s);let a=s.functions?.(t);if(!a)throw new Error(`Unknown operator \`${t}\``);if(typeof a=="function"){let u=n.lookupDefinition(t);if(Wn(u)&&u.operator.broadcastable&&i.length===1&&yi(i[0])){let l=e.tempVar();return`(${e.compile(i[0],s)}).map((${l}) => ${a([i[0].engine.expr(l)],c=>e.compile(c,s),s)})`}return a(i,l=>e.compile(l,s),s)}return`${a}(${i.map(u=>e.compile(u,s)).join(", ")})`}static compileBlock(n,t){let i=[];for(let a of n)if(h(a,"Declare")){let u=a.ops[0];_(u)&&i.push(u.symbol)}if(n.length===1&&i.length===0)return e.compile(n[0],t);let r={};if(t.declare&&t.language){let a=t.language==="wgsl";for(let u of i)for(let l of n)if(h(l,"Assign")&&_(l.ops[0],u)){e.isComplexValued(l.ops[1])&&(r[u]=a?"vec2f":"vec2");break}}let s={...t,var:a=>i.includes(a)?a:t.var(a)},o=n.filter(a=>!_(a,"Nothing")).map(a=>h(a,"Declare")&&_(a.ops[0])&&t.declare?t.declare(a.ops[0].symbol,r[a.ops[0].symbol]):e.compile(a,s)).filter(a=>a!=="");return o.length===0?"":t.block?t.block(o):(o[o.length-1]=`return ${o[o.length-1]}`,`(() => {${t.ws(`
|
|
11
|
+
`)}${o.join(`;${t.ws(`
|
|
12
|
+
`)}`)}${t.ws(`
|
|
13
|
+
`)}})()`)}static compileForLoop(n,t){if(!n[0])throw new Error("Loop: no body");if(!n[1])throw new Error("Loop: no indexing set");let i=n[1];if(!h(i,"Element"))throw new Error("Loop: expected Element(index, Range(lo, hi))");let r=i.ops[0],s=i.ops[1];if(!_(r))throw new Error("Loop: index must be a symbol");if(!h(s,"Range"))throw new Error("Loop: expected Range(lo, hi)");let o=r.symbol,a=Math.floor(s.ops[0].re),u=Math.floor(s.ops[1].re);if(!Number.isFinite(a)||!Number.isFinite(u))throw new Error("Loop: bounds must be finite numbers");let l=t.number(0)!=="0",c={...t,var:m=>m===o?l?t.number(0).replace("0",o):o:t.var(m)},p=e.compileLoopBody(n[0],c);return`(() => {${t.ws(`
|
|
14
|
+
`)}for (let ${o} = ${a}; ${o} <= ${u}; ${o}++) {${t.ws(`
|
|
15
|
+
`)}${p}${t.ws(`
|
|
16
|
+
`)}}${t.ws(`
|
|
17
|
+
`)}})()`}static compileLoopBody(n,t){if(_(n,"Nothing"))return"";if(!h(n))return e.compile(n,t);let i=n.operator;if(i==="Break")return"break";if(i==="Continue")return"continue";if(i==="Return")return`return ${e.compile(n.ops[0],t)}`;if(i==="If"){let r=e.scalarConditionTarget(t),s=e.compile(n.ops[0],r),o=e.compileLoopBody(n.ops[1],t);if(n.ops.length>2){let a=e.compileLoopBody(n.ops[2],t);if(a)return`if (${s}) { ${o} } else { ${a} }`}return`if (${s}) { ${o} }`}return i==="Block"?n.ops.map(r=>e.compileLoopBody(r,t)).join("; "):e.compile(n,t)}static scalarConditionTarget(n){let t={Less:["<",20],Greater:[">",20],LessEqual:["<=",20],GreaterEqual:[">=",20],Equal:["===",20],NotEqual:["!==",20],And:["&&",6],Or:["||",5],Not:["!",16]};return n.number(0)==="0"?n:{...n,number:i=>String(i),var:i=>{let r=n.var(i);if(!r)return;let s=r.match(/^_IA\.point\((.+)\)$/);return s?s[1]:r},operators:i=>t[i]??n.operators?.(i),functions:i=>{if(!(i in t))return n.functions?.(i)}}}static compileLoop(n,t,i){if(!t[0])throw new Error("Sum/Product: no body");let{index:r,lower:s,upper:o,isFinite:a}=la(t[1]),u=n==="Sum",l=u?"+":"*",c=e.isComplexValued(t[0]);if(!r){let d=e.tempVar(),b=e.tempVar(),v=e.compile(t[0],i);return c?u?`${v}.reduce((${b}, ${d}) => ({ re: ${b}.re + ${d}.re, im: ${b}.im + ${d}.im }), { re: 0, im: 0 })`:`${v}.reduce((${b}, ${d}) => ({ re: ${b}.re * ${d}.re - ${b}.im * ${d}.im, im: ${b}.re * ${d}.im + ${b}.im * ${d}.re }), { re: 1, im: 0 })`:`${v}.reduce((${b}, ${d}) => ${b} ${l} ${d}, ${u?"0":"1"})`}let p=e.compile(t[0],{...i,var:d=>d===r?r:i.var(d)}),m=e.tempVar();if(c){let d=e.tempVar();return u?`(() => {
|
|
18
|
+
let ${m} = { re: 0, im: 0 };
|
|
19
|
+
let ${r} = ${s};
|
|
20
|
+
while (${r} <= ${o}) {
|
|
21
|
+
const ${d} = ${p};
|
|
22
|
+
${m} = { re: ${m}.re + ${d}.re, im: ${m}.im + ${d}.im };
|
|
23
|
+
${r}++;
|
|
24
|
+
}
|
|
25
|
+
return ${m};
|
|
26
|
+
})()`:`(() => {
|
|
27
|
+
let ${m} = { re: 1, im: 0 };
|
|
28
|
+
let ${r} = ${s};
|
|
29
|
+
while (${r} <= ${o}) {
|
|
30
|
+
const ${d} = ${p};
|
|
31
|
+
${m} = { re: ${m}.re * ${d}.re - ${m}.im * ${d}.im, im: ${m}.re * ${d}.im + ${m}.im * ${d}.re };
|
|
32
|
+
${r}++;
|
|
33
|
+
}
|
|
34
|
+
return ${m};
|
|
35
|
+
})()`}return`(() => {
|
|
36
|
+
let ${m} = ${u?"0":"1"};
|
|
37
|
+
let ${r} = ${s};
|
|
38
|
+
while (${r} <= ${o}) {
|
|
39
|
+
${m} ${l}= ${p};
|
|
40
|
+
${r}++;
|
|
41
|
+
}
|
|
42
|
+
return ${m};
|
|
43
|
+
})()`}static isComplexValued(n){if(X(n))return n.im!==0;if(_(n)){if(n.symbol==="ImaginaryUnit")return!0;let t=n.type;return t?t.matches("complex")&&!t.matches("real"):!1}if(h(n)){let t=n.operator;return t==="Abs"||t==="Arg"||t==="Re"||t==="Im"?!1:n.ops.some(i=>e.isComplexValued(i))}return!1}static tempVar(){return`_${Math.random().toString(36).substring(4)}`}static inlineExpression(n,t){if(/^[\p{L}_][\p{L}\p{N}_]*$/u.test(t)||/^[0-9]+$/.test(t))return new Function("x",`return \`${n}\`;`)(t);{let r=e.tempVar();return new Function("x",`return \`(() => { const ${r} = \${x}; return ${n.replace(/\\\${x}/g,r)}; })()\`;`)(t)}}};function Kn(e){return typeof e=="object"&&e!==null}function ca(e){return typeof e=="number"&&Number.isFinite(e)}function cc(e){if(!Kn(e))throw new Error("Invalid compile target: expected an object");if(typeof e.var!="function")throw new Error('Invalid compile target: missing required method "var()"');if(typeof e.string!="function")throw new Error('Invalid compile target: missing required method "string()"');if(typeof e.number!="function")throw new Error('Invalid compile target: missing required method "number()"');if(typeof e.ws!="function")throw new Error('Invalid compile target: missing required method "ws()"');if(typeof e.preamble!="string")throw new Error('Invalid compile target: "preamble" must be a string');if(!ca(e.indent))throw new Error('Invalid compile target: "indent" must be a finite number');if(e.operators!==void 0&&typeof e.operators!="function")throw new Error('Invalid compile target: "operators" must be a function');if(e.functions!==void 0&&typeof e.functions!="function")throw new Error('Invalid compile target: "functions" must be a function');if(e.language!==void 0&&typeof e.language!="string")throw new Error('Invalid compile target: "language" must be a string')}function fc(e,n){if(n!==void 0&&(!Array.isArray(n)||n.length!==2||typeof n[0]!="string"||!ca(n[1])))throw new Error(`Invalid compilation option "operators.${e}": expected [string, number]`)}function pc(e){if(e!==void 0&&typeof e!="function"){if(!Kn(e)||Array.isArray(e))throw new Error('Invalid compilation option "operators": expected a function or a record');for(let[n,t]of Object.entries(e))fc(n,t)}}function mc(e){if(e!==void 0){if(!Kn(e)||Array.isArray(e))throw new Error('Invalid compilation option "functions": expected a record');for(let[n,t]of Object.entries(e))if(typeof t!="string"&&typeof t!="function")throw new Error(`Invalid compilation option "functions.${n}": expected a string or function`)}}function dc(e){if(e!==void 0){if(!Kn(e)||Array.isArray(e))throw new Error('Invalid compilation option "vars": expected a record');for(let[n,t]of Object.entries(e))if(typeof t!="string")throw new Error(`Invalid compilation option "vars.${n}": expected a string`)}}function hc(e){if(e!==void 0&&!Array.isArray(e))throw new Error('Invalid compilation option "imports": expected an array')}function fa(e){if(e!==void 0){if(!Kn(e)||Array.isArray(e))throw new Error("Invalid compilation options: expected an object");if(e.to!==void 0&&typeof e.to!="string")throw new Error('Invalid compilation option "to": expected a string');if(e.target!==void 0&&cc(e.target),pc(e.operators),mc(e.functions),dc(e.vars),hc(e.imports),e.preamble!==void 0&&typeof e.preamble!="string")throw new Error('Invalid compilation option "preamble": expected a string');if(e.fallback!==void 0&&typeof e.fallback!="boolean")throw new Error('Invalid compilation option "fallback": expected a boolean')}}function gc(e,n){fa(n);try{if(n?.target){let r=g.compile(e,n.target);return{target:n.target.language??"custom",success:!0,code:r}}let t=n?.to??"javascript",i=e.engine.getCompilationTarget(t);if(!i)throw new Error(`Compilation target "${t}" is not registered. Available targets: ${e.engine.listCompilationTargets().join(", ")}`);return i.compile(e,{operators:n?.operators,functions:n?.functions,vars:n?.vars,imports:n?.imports,preamble:n?.preamble,realOnly:n?.realOnly})}catch(t){if(n?.fallback??!0)return console.warn(`Compilation fallback for "${e.operator}": ${t.message}`),{target:n?.to??"javascript",success:!1,code:"",calling:"expression",run:ro(e)};throw t}}function zi(e){let n=Math.abs(e);return n<=.0031308?12.92*e:(Math.sign(e)||1)*(1.055*Math.pow(n,1/2.4)-.055)}function Gi(e){let n=Math.abs(e);return n<=.04045?e/12.92:(Math.sign(e)||1)*Math.pow((n+.055)/1.055,2.4)}function Wi(e,n,t){e=e/360;let i,r,s;if(n===0)i=r=s=t;else{let o=(l,c,p)=>(p<0&&(p+=1),p>1&&(p-=1),p<.16666666666666666?l+(c-l)*6*p:p<.5?c:p<.6666666666666666?l+(c-l)*(.6666666666666666-p)*6:l),a=t<.5?t*(1+n):t+n-t*n,u=2*t-a;i=o(u,a,e+1/3),r=o(u,a,e),s=o(u,a,e-1/3)}return{r:Math.round(i*255),g:Math.round(r*255),b:Math.round(s*255)}}function Xi(e,n,t){e/=255,n/=255,t/=255;let i=Math.max(e,n,t),r=Math.min(e,n,t),s=(i+r)/2;if(i===r)return{h:0,s:0,l:s};let o=i-r,a=s>.5?o/(2-i-r):o/(i+r),u;return i===e?u=((n-t)/o+(n<t?6:0))/6:i===n?u=((t-e)/o+2)/6:u=((e-n)/o+4)/6,{h:u*360,s:a,l:s}}function bc(e){let n=e.startsWith("#")?e.substring(1):e,t,i,r,s;if(n.length===3)t=parseInt(n[0]+n[0],16),i=parseInt(n[1]+n[1],16),r=parseInt(n[2]+n[2],16);else if(n.length===6)t=parseInt(n.substring(0,2),16),i=parseInt(n.substring(2,4),16),r=parseInt(n.substring(4,6),16);else if(n.length===8)t=parseInt(n.substring(0,2),16),i=parseInt(n.substring(2,4),16),r=parseInt(n.substring(4,6),16),s=parseInt(n.substring(6,8),16)/255;else return{r:0,g:0,b:0};let o={r:t,g:i,b:r};return s!==void 0&&(o.alpha=s),o}function Bt(e){return typeof e=="number"?{r:e>>>24&255,g:e>>>16&255,b:e>>>8&255,alpha:(e&255)/255}:typeof e=="string"?bc(e):"C"in e?Mn(e):"a"in e&&"b"in e?et(e):e}function pa(e){let n=Bt(e),t=n.alpha!==void 0?Se(n.alpha*255):255;return(Se(n.r)<<24|Se(n.g)<<16|Se(n.b)<<8|t)>>>0}function Se(e){return e<0?0:e>255?255:Math.round(e)}function Hi(e){let[n,t,i]=[e.L,e.C,e.H],r=i*Math.PI/180,s={L:n,a:t*Math.cos(r),b:t*Math.sin(r)};return e.alpha!==void 0&&(s.alpha=e.alpha),s}function wa(e){let[n,t,i]=[e.L,e.a,e.b],r=Math.sqrt(t*t+i*i),o=Math.atan2(i,t)*180/Math.PI,a={L:n,C:r,H:o};return e.alpha!==void 0&&(a.alpha=e.alpha),a}function Lt(e){let[n,t,i]=[e.L,e.a,e.b],r=Math.pow(.9999999984505198*n+.39633779217376786*t+.2158037580607588*i,3),s=Math.pow(1.00000000888176*n-.10556134232365635*t-.0638541747717059*i,3),o=Math.pow(n*1.000000054672411-.0894841820949657*t-1.2914855378640917*i,3),a=4.076741661347994*r-3.307711590408193*s+.230969928729428*o,u=-1.2684380040921763*r+2.6097574006633715*s-.3413193963102197*o,l=-.004196086541837188*r-.7034186144594493*s+1.7076147009309444*o;return[zi(a),zi(u),zi(l)]}function ji(e){let[n,t,i]=e;return n>=0&&n<=1&&t>=0&&t<=1&&i>=0&&i<=1}function Ui(e,n){let[t,i,r]=e;return t=Se(t*255),i=Se(i*255),r=Se(r*255),n!==void 0?{r:t,g:i,b:r,alpha:n}:{r:t,g:i,b:r}}function et(e){let[n,t,i]=Lt(e);if(ji([n,t,i]))return Ui([n,t,i],e.alpha);let r=wa(e);if(r.C=0,[n,t,i]=Lt(Hi(r)),!ji([n,t,i]))return Ui([n,t,i],e.alpha);let s=0,o=e.L,a=(s+o)/2;r.C=a;let u=.36/Math.pow(2,12);for(;o-s>u;)a=(s+o)/2,r.C=a,[n,t,i]=Lt(Hi(r)),ji([n,t,i])?s=a:o=a;return Ui([n,t,i],e.alpha)}function Mn(e){return et(Hi(e))}function Qi(e){let[n,t,i]=[e.r,e.g,e.b],r=Gi(n/255),s=Gi(t/255),o=Gi(i/255),a=.41222147079999993*r+.5363325363*s+.0514459929*o,u=.2119034981999999*r+.6806995450999999*s+.1073969566*o,l=.08830246189999998*r+.2817188376*s+.6299787005000002*o,c=Math.cbrt(a),p=Math.cbrt(u),m=Math.cbrt(l),d={L:.2104542553*c+.793617785*p-.0040720468*m,a:1.9779984951*c-2.428592205*p+.4505937099*m,b:.0259040371*c+.7827717662*p-.808675766*m};return e.alpha!==void 0&&(d.alpha=e.alpha),d}function Ye(e){return wa(Qi(e))}function Zi(e,n){let t=n*Math.PI/180,i=0,r=1.5;for(let s=0;s<32;s++){let o=(i+r)/2,[a,u,l]=Lt({L:e,a:o*Math.cos(t),b:o*Math.sin(t)});a>=0&&a<=1&&u>=0&&u<=1&&l>=0&&l<=1?i=o:r=o}return i}function _n(e,n,t){let i=e/100;if(i<=0)return 255;let r=Mn({L:i,C:n,H:t});return(Se(r.r)<<24|Se(r.g)<<16|Se(r.b)<<8|255)>>>0}function yc(e){let{l:n,c:t,h:i}=Vt(e);return _n(n+2.8,t+.002,i+.46)}function Vt(e){let n=e>>>24&255,t=e>>>16&255,i=e>>>8&255,r=Ye({r:n,g:t,b:i});return{l:r.L*100,c:r.C,h:r.H<0?r.H+360:r.H}}function Yi(e,n,t){let{l:i,c:r,h:s}=Vt(e),{l:o,c:a,h:u}=Vt(n),l=i+(o-i)*t,c=r+(a-r)*t,p=u-s;p>180&&(p-=360),p<-180&&(p+=360);let m=s+p*t,d=e&255,b=n&255,v=Math.round(d+(b-d)*t);return _n(l,c,m<0?m+360:m>360?m-360:m)&4294967040|v}function xc(e,n=.1){let a=.45,u=0;for(let b=.45;b>=.35;b-=.01){let v=Zi(b,e);if(v>=.15){a=b,u=.15;break}else v>u&&(a=b,u=v)}if(u<.15*.8)for(let b=.45+.01;b<=.5;b+=.01){let v=Zi(b,e);if(v>=.15||v>u*1.2){a=b,u=Math.min(.15,v);break}}let l=.96,c=.02,p=Zi(.96,e);p<.02&&(c=p*(1-n)),c=Math.max(.015,Math.min(.02,c));let m=_n(a*100,u,e),d=_n(l*100,c,e);return{darkest:m,lightest:d}}function Ec(e,n){let t=Math.max(0,Math.min(1e3,n)),i,r,s;if(typeof e=="object")i=e.darkest,s=e.lightest,r=e.mid??0;else{r=e;let{h:u}=Vt(r),l=r&255,{darkest:c,lightest:p}=xc(u);i=c&4294967040|l,s=p&4294967040|l}if(!r&&typeof e=="object"&&!e.mid&&(r=Yi(i,s,.5)),t<=500){let u=t/500,l=u*u*(3-2*u);return Yi(s,r,l)}let o=(t-500)/500,a=o*o*(3-2*o);return Yi(r,i,a)}var vc=[{id:"pink",name:"Pink",colors:{mid:{lightness:69,chroma:.202,hue:7.4}}},{id:"red",name:"Red",colors:{lightest:{lightness:95,chroma:.2,hue:30},mid:{lightness:62,chroma:.25,hue:30},darkest:{lightness:36,chroma:.16,hue:25}}},{id:"brown",name:"Brown",colors:{lightest:{lightness:94.5,chroma:.021,hue:72.1},mid:{lightness:59,chroma:.2,hue:73},darkest:{lightness:20,chroma:.061,hue:72.7}}},{id:"orange",name:"Orange",colors:{lightest:{lightness:95,chroma:.06,hue:82},mid:{lightness:73,chroma:.21,hue:56},darkest:{lightness:46,chroma:.2,hue:35}}},{id:"yellow",name:"Yellow",colors:{lightest:{lightness:97,chroma:.02,hue:106},mid:{lightness:89,chroma:.21,hue:99},darkest:{lightness:67,chroma:.43,hue:59}}},{id:"lime",name:"Lime",colors:{mid:{lightness:65,chroma:.192,hue:134.3}}},{id:"green",name:"Green",colors:{mid:{lightness:64,chroma:.21,hue:144}}},{id:"teal",name:"Teal",colors:{mid:{lightness:65,chroma:.116,hue:192.6}}},{id:"cyan",name:"Cyan",colors:{lightest:{lightness:97,chroma:.11,hue:195},mid:{lightness:61,chroma:.11,hue:210},darkest:{lightness:42,chroma:.11,hue:210}}},{id:"blue",name:"Blue",colors:{lightest:{lightness:91,chroma:.22,hue:240},mid:{lightness:63,chroma:.22,hue:255},darkest:{lightness:38,chroma:.22,hue:252}}},{id:"indigo",name:"Indigo",colors:{lightest:{lightness:92.7,chroma:.036,hue:291},mid:{lightness:67,chroma:.285,hue:296},darkest:{lightness:28,chroma:.23,hue:278}}},{id:"purple",name:"Purple",colors:{mid:{lightness:67,chroma:.21,hue:299}}}];function kn({lightness:e,chroma:n,hue:t}){return _n(e,n,t)}function Nc(e){let{mid:n,lightest:t,darkest:i}=e.colors;if(t&&i&&n)return{lightest:kn(t),mid:kn(n),darkest:kn(i)};if(t&&i)return{lightest:kn(t),darkest:kn(i)};if(n)return kn(n);throw new Error(`Color scale preset "${e.id}" is missing required anchors.`)}var Ot=null;function Tc(){if(!Ot){Ot=Object.create(null);for(let e of vc)Ot[e.id]=Nc(e)}return Ot}var ma={red:"#d7170b",orange:"#fe8a2b",yellow:"#ffc02b",lime:"#63b215",green:"#21ba3a",teal:"#17cfcf",cyan:"#13a7ec",blue:"#0d80f2",indigo:"#63c",purple:"#a219e6",magenta:"#eb4799",brown:"#8c564b",olive:"#8a8f2a",midnight:"#2c4670",sky:"#d2dce9",black:"#000",white:"#ffffff",carbon:"#111111",charcoal:"#333333",slate:"#555555","dark-grey":"#666",graphite:"#777777",stone:"#999999",grey:"#A6A6A6","light-grey":"#d4d5d2",ash:"#E6E6E6",mist:"#F3F3F3",snow:"#FFFFFF"};function nt(e,n){let t=e.trim().toLowerCase();if(t.startsWith("#")){let u=t.substring(1),l,c,p,m=255;if(u.length===3)l=parseInt(u[0]+u[0],16),c=parseInt(u[1]+u[1],16),p=parseInt(u[2]+u[2],16);else if(u.length===6)l=parseInt(u.substring(0,2),16),c=parseInt(u.substring(2,4),16),p=parseInt(u.substring(4,6),16);else if(u.length===8)l=parseInt(u.substring(0,2),16),c=parseInt(u.substring(2,4),16),p=parseInt(u.substring(4,6),16),m=parseInt(u.substring(6,8),16);else return 0;return(l<<24|c<<16|p<<8|m)>>>0}let i=t.match(/^rgba?\s*\(\s*([^)]+)\s*\)$/);if(i){let u=i[1].replace(/[,/]/g," ").trim().split(/\s+/),l=parseFloat(u[0])||0,c=parseFloat(u[1])||0,p=parseFloat(u[2])||0;u[0].includes("%")||u[1].includes("%")||u[2].includes("%")?(u[0].includes("%")&&(l=l/100*255),u[1].includes("%")&&(c=c/100*255),u[2].includes("%")&&(p=p/100*255)):l<=1&&c<=1&&p<=1&&(l=l*255,c=c*255,p=p*255),l=Math.round(Math.max(0,Math.min(255,l))),c=Math.round(Math.max(0,Math.min(255,c))),p=Math.round(Math.max(0,Math.min(255,p)));let m=255;if(u.length>=4){let d=parseFloat(u[3]);u[3].includes("%")?d=d/100:d>1&&(d=d/255),m=Math.round(Math.max(0,Math.min(255,d*255)))}return(l<<24|c<<16|p<<8|m)>>>0}let r=t.match(/^oklch\s*\(\s*([^)]+)\s*\)$/);if(r){let u=r[1].replace(/[,/]/g," ").trim().split(/\s+/),l=parseFloat(u[0]);u[0].includes("%")?l=l/100:l<=1||(l=l/100);let c=parseFloat(u[1])||0,p=parseFloat(u[2])||0,m=1;u.length>=4&&(m=parseFloat(u[3]),u[3].includes("%")?m=m/100:m>1&&(m=m/255));let d=_n(l*100,c,p),b=Math.round(m*255);return d&4294967040|b}let s=t.match(/^oklab\s*\(\s*([^)]+)\s*\)$/);if(s){let u=s[1].replace(/[,/]/g," ").trim().split(/\s+/),l=parseFloat(u[0]);(u[0].includes("%")||l>1)&&(l=l/100);let c=parseFloat(u[1])||0,p=parseFloat(u[2])||0,m=1;u.length>=4&&(m=parseFloat(u[3]),u[3].includes("%")?m=m/100:m>1&&(m=m/255));let d=et({L:l,a:c,b:p}),b=d.r,v=d.g,k=d.b,w=Math.round(m*255);return(b<<24|v<<16|k<<8|w)>>>0}let o=t.match(/^hsl\s*\(\s*([^)]+)\s*\)$/);if(o){let u=o[1].replace(/[,/]/g," ").trim().split(/\s+/),l=parseFloat(u[0])||0,c=parseFloat(u[1])||0;u[1].includes("%")?c=c/100:c<=1||(c=c/100);let p=parseFloat(u[2])||0;u[2].includes("%")?p=p/100:p<=1||(p=p/100);let m=1;u.length>=4&&(m=parseFloat(u[3]),u[3].includes("%")?m=m/100:m>1&&(m=m/255));let{r:d,g:b,b:v}=Wi(l,c,p),k=Math.round(m*255);return(d<<24|b<<16|v<<8|k)>>>0}if(t==="transparent")return 0;let a=t.match(/^([a-z]+)-(\d+)$/);if(a){let u=Tc()[a[1]];if(u){let l=Ec(u,parseInt(a[2],10));return n?yc(l):l}}return t in ma?nt(ma[t]):(console.warn(`parseColor: unrecognized color "${e}"`),0)}function Aa(e,n){let t=nt(e,n);return[(t>>>24&255)/255,(t>>>16&255)/255,(t>>>8&255)/255]}function Jt(e,n){let t=Bt(e),i=Bt(n),r=.56,s=.57,o=.62,a=.65,u=.022,l=1.414,c=.1,p=5e-4,m=1.14,d=.027,b=1.14,v=.027;function k(j){return j>=u?j:j+(u-j)**l}function w(j){return(j<0?-1:1)*Math.pow(Math.abs(j),2.4)}let R=k(w(i.r/255)*.2126729+w(i.g/255)*.7151522+w(i.b/255)*.072175),P=k(w(t.r/255)*.2126729+w(t.g/255)*.7151522+w(t.b/255)*.072175),O,W;return Math.abs(P-R)<p?W=0:P>R?(O=P**r-R**s,W=O*m):(O=P**a-R**o,W=O*b),Math.abs(W)<c?0:W>0?W-v:W+d}function Ki(e){let n,t,i;typeof e!="object"||!("bg"in e)?(n=Bt(e),t="#ffffff",i="#000000"):(n=e.bg,t=e.fg1,i=e.fg2);let r=Math.abs(Jt(t,n)),s=Math.abs(Jt(i,n));return r>=s?pa(t):pa(i)}var Ic=["#4e79a7","#f28e2b","#59a14f","#e15759","#b07aa1","#9c755f","#ff9da7","#edc948","#76b7b2","#6b8fd6","#c07bc4"],kc=["#78a6d9","#ffae54","#7ddc7a","#ff7a7a","#d29be0","#c49a84","#ffb3bf","#ffe066","#7fd6d0","#8fb4ff","#e199eb"],Sc=["#4e79a7","#f28e2b","#2ca58d","#d13a3c","#b07aa1","#9c755f","#ff9da7","#e3c13b","#5fb8b2","#6b8fd6","#c07bc4"],_c=["#8fb1d4","#f6b878","#8ecf86","#f08a8b","#d3a9cc","#c3a492","#ffc6cc","#f3e08a","#a8d8d4","#a9c0ea","#e0b4e4"],Mc=["#78a6d9","#ffae54","#7ddc7a","#ff7a7a","#d29be0","#c49a84","#ffb3bf","#ffe066","#7fd6d0","#8fb4ff","#e199eb"],wc=["#2f6fb0","#ff7a00","#2fa23a","#e02f2f","#9b4db5","#7f4f38","#ff6f86","#f2c200","#2daaa3","#4c79e0","#b84ac6"],Ac=["#4f93ff","#ff8c1a","#33c94a","#ff4f4f","#b86bff","#a86a4a","#ff7f9e","#ffd400","#2ec9c1","#6f9bff","#cc5bd9"],$c=["#5E81B5","#E19C24","#8FB131","#EB6235","#8778B3","#C56E1A","#5E9EC9","#B23A3A","#4C9F70","#C979B7"],Cc=["#1f77b4","#ff7f0e","#2ca02c","#d62728","#9467bd","#8c564b","#e377c2","#7f7f7f","#bcbd22","#17becf"],Rc=["#007AFF","#FF9500","#34C759","#FF3B30","#AF52DE","#FF2D55","#30B0C7","#5856D6","#A2845E","#32ADE6","#00C7BE"],Dc=["#0A84FF","#FF9F0A","#30D158","#FF453A","#BF5AF2","#FF375F","#40C8E0","#5E5CE6","#AC8E68","#64D2FF","#00D1C1"],Pc=["#fdfdfd","#1d1d1d","#ebce2b","#702c8c","#db6917","#96cde6","#ba1c30","#c0bd7f","#7f7e80","#5fa641","#d485b2","#4277b6","#df8461","#463397","#e1a11a","#91218c","#e8e948","#7e1510","#92ae31","#6f340d","#d32b1e","#2b3514"],Fc=["#4148cc","#db3c80","#12b5b0","#ff8c14","#848aff","#78e16e","#1e78f0","#ebcd00","#beeb3c","#7828d2","#cd5f00","#00915f"],$a={tycho11:Ic,"tycho-dark11":kc,"tycho-robust11":Sc,"tycho-soft11":_c,"tycho-soft-dark11":Mc,"tycho-bold11":wc,"tycho-bold-dark11":Ac,tableau10:Cc,kelly22:Pc,mathematica10:$c,cupertino10:Rc,"cupertino-dark10":Dc,spectrum12:Fc},da=["#033198","#053399","#07359a","#09379b","#0b399c","#0c3b9c","#0e3d9d","#0f3f9e","#11409f","#1242a0","#1344a0","#1446a1","#1548a2","#164aa3","#174ca4","#184da4","#194fa5","#1951a6","#1a53a7","#1b54a8","#1b56a8","#1c58a9","#1d5aaa","#1d5bab","#1e5dab","#1e5fac","#1f60ad","#2062ae","#2064ae","#2166af","#2167b0","#2269b0","#226ab1","#236cb2","#236eb3","#246fb3","#2471b4","#2573b5","#2574b5","#2676b6","#2677b7","#2779b7","#287ab8","#287cb9","#297eb9","#297fba","#2a81bb","#2b82bb","#2b84bc","#2c85bd","#2d87bd","#2d88be","#2e8abf","#2f8cbf","#308dc0","#308fc1","#3190c1","#3292c2","#3394c3","#3495c3","#3597c4","#3698c5","#379ac5","#389cc6","#399dc7","#3a9fc7","#3ca1c8","#3da2c9","#3ea4c9","#40a6ca","#41a7cb","#43a9cb","#44abcc","#46accc","#47aecd","#49b0ce","#4bb2ce","#4db3cf","#4fb5d0","#51b7d0","#53b8d1","#55bad1","#57bcd2","#59bdd2","#5bbfd3","#5dc1d3","#60c3d4","#62c4d4","#64c6d5","#67c7d5","#69c9d5","#6ccbd6","#6eccd6","#71ced6","#74cfd6","#76d1d7","#79d2d7","#7bd4d7","#7ed5d7","#81d7d7","#83d8d7","#86d9d7","#89dad7","#8bdcd7","#8eddd7","#90ded7","#93dfd6","#95e0d6","#98e1d6","#9be2d5","#9de3d5","#9fe4d4","#a2e5d4","#a4e5d3","#a6e6d2","#a9e7d2","#abe7d1","#ade8d0","#afe8cf","#b1e9ce","#b3e9cd","#b5eacc","#b7eaca","#b9eac9","#bbeac8","#bdeac6","#beeac5","#c0eac3","#c1eac2","#c3eac0","#c4eabe","#c6eabc","#c7e9ba","#c8e9b8","#c9e9b6","#cbe8b4","#cce7b2","#cce7b0","#cde6ad","#cee5ab","#cfe5a8","#d0e4a6","#d0e3a3","#d1e2a1","#d1e19e","#d1df9b","#d2de98","#d2dd96","#d2dc93","#d2da90","#d2d98d","#d2d78a","#d2d687","#d2d484","#d2d381","#d2d17e","#d1cf7b","#d1cd78","#d0cc75","#d0ca72","#cfc86f","#cfc66d","#cec46a","#cec267","#cdc064","#ccbe62","#cbbc5f","#cbba5d","#cab85a","#c9b658","#c8b455","#c7b253","#c7b051","#c6ae4f","#c5ac4c","#c4aa4a","#c3a848","#c2a647","#c1a545","#c1a343","#c0a141","#bf9f40","#be9d3e","#bd9b3c","#bc993b","#bb9739","#ba9538","#ba9437","#b99235","#b89034","#b78e33","#b68c32","#b58b31","#b58930","#b4872f","#b3862e","#b2842d","#b1822c","#b0802b","#b07f2a","#af7d29","#ae7c28","#ad7a27","#ad7826","#ac7726","#ab7525","#aa7324","#a97223","#a97023","#a86f22","#a76d21","#a66c20","#a66a20","#a5681f","#a4671e","#a3651e","#a2641d","#a2621c","#a1611c","#a05f1b","#9f5d1a","#9e5c19","#9e5a19","#9d5818","#9c5717","#9b5517","#9a5316","#995215","#995014","#984e14","#974d13","#964b12","#954912","#944711","#934610","#92440f","#91420f","#90400e","#903e0d","#8f3c0c","#8e3a0b","#8d380b","#8c360a","#8b3409","#8a3208","#883008","#872e07","#862c06","#852a06","#842705","#832504","#822204","#812003","#801d02","#7f1a01","#7e1700"],ha=["#0b3c78","#2366a8","#4f97cf","#9bc7e4","#f7f7f7","#e88fa0","#c23c6f","#8e1d4d","#5a0c2e"],ga=["#2c557f","#4a7fa8","#7aa8c9","#b5cfe3","#f7f7f7","#e4b0b0","#c96c72","#9b3d4f","#6b1a2b"],ba=["#053061","#11458c","#1f5fa5","#337ab7","#4f94c6","#6baed6","#8bbdd9","#a6cce3","#c1dbec","#dceaf4","#f7f7f7","#fbe3d6","#f9c8b2","#f5a993","#ee8a75","#e36b58","#d64b41","#c72c33","#af212d","#971628","#7f0b23","#67001f"],ya=["#3b4cc0","#465ecf","#5070de","#5c82ea","#6f96f5","#86aafc","#9dbdff","#b6d0f3","#cfe1e8","#e6efe1","#f1f1f1","#f7f7f7","#f6e1d3","#f4cbb3","#f1b594","#ee9f76","#ea8960","#e06b53","#d24f49","#c1363f","#ae2036","#b40426"],xa=["#00441b","#006d5b","#1a8c7d","#2fa394","#4fb3a3","#6fc1b3","#8dcfc3","#a6dbd1","#bfe6de","#d7f0ea","#f7f7f7","#eeeeee","#ddd8e6","#c7bcda","#b3a0d0","#9f86c7","#8d6dbd","#7b56b1","#6a42a3","#5a3093","#4a1f82","#3b0f70"],Sn=e=>e.slice().reverse(),Ca={roma:da,"roma-reversed":Sn(da),vik:ha,"vik-reversed":Sn(ha),broc:ga,"broc-reversed":Sn(ga),rdbu:ba,"rdbu-reversed":Sn(ba),coolwarm:ya,"coolwarm-reversed":Sn(ya),"ocean-balance":xa,"ocean-balance-reversed":Sn(xa)},Ea=["#30123b","#321543","#33184a","#341b51","#351e58","#36215f","#372466","#38276d","#392a73","#3a2d79","#3b2f80","#3c3286","#3d358b","#3e3891","#3f3b97","#3f3e9c","#4040a2","#4143a7","#4146ac","#4249b1","#424bb5","#434eba","#4451bf","#4454c3","#4456c7","#4559cb","#455ccf","#455ed3","#4661d6","#4664da","#4666dd","#4669e0","#466be3","#476ee6","#4771e9","#4773eb","#4776ee","#4778f0","#477bf2","#467df4","#4680f6","#4682f8","#4685fa","#4687fb","#458afc","#458cfd","#448ffe","#4391fe","#4294ff","#4196ff","#4099ff","#3e9bfe","#3d9efe","#3ba0fd","#3aa3fc","#38a5fb","#37a8fa","#35abf8","#33adf7","#31aff5","#2fb2f4","#2eb4f2","#2cb7f0","#2ab9ee","#28bceb","#27bee9","#25c0e7","#23c3e4","#22c5e2","#20c7df","#1fc9dd","#1ecbda","#1ccdd8","#1bd0d5","#1ad2d2","#1ad4d0","#19d5cd","#18d7ca","#18d9c8","#18dbc5","#18ddc2","#18dec0","#18e0bd","#19e2bb","#19e3b9","#1ae4b6","#1ce6b4","#1de7b2","#1fe9af","#20eaac","#22ebaa","#25eca7","#27eea4","#2aefa1","#2cf09e","#2ff19b","#32f298","#35f394","#38f491","#3cf58e","#3ff68a","#43f787","#46f884","#4af880","#4ef97d","#52fa7a","#55fa76","#59fb73","#5dfc6f","#61fc6c","#65fd69","#69fd66","#6dfe62","#71fe5f","#75fe5c","#79fe59","#7dff56","#80ff53","#84ff51","#88ff4e","#8bff4b","#8fff49","#92ff47","#96fe44","#99fe42","#9cfe40","#9ffd3f","#a1fd3d","#a4fc3c","#a7fc3a","#a9fb39","#acfb38","#affa37","#b1f936","#b4f836","#b7f735","#b9f635","#bcf534","#bef434","#c1f334","#c3f134","#c6f034","#c8ef34","#cbed34","#cdec34","#d0ea34","#d2e935","#d4e735","#d7e535","#d9e436","#dbe236","#dde037","#dfdf37","#e1dd37","#e3db38","#e5d938","#e7d739","#e9d539","#ebd339","#ecd13a","#eecf3a","#efcd3a","#f1cb3a","#f2c93a","#f4c73a","#f5c53a","#f6c33a","#f7c13a","#f8be39","#f9bc39","#faba39","#fbb838","#fbb637","#fcb336","#fcb136","#fdae35","#fdac34","#fea933","#fea732","#fea431","#fea130","#fe9e2f","#fe9b2d","#fe992c","#fe962b","#fe932a","#fe9029","#fd8d27","#fd8a26","#fc8725","#fc8423","#fb8122","#fb7e21","#fa7b1f","#f9781e","#f9751d","#f8721c","#f76f1a","#f66c19","#f56918","#f46617","#f36315","#f26014","#f15d13","#f05b12","#ef5811","#ed5510","#ec530f","#eb500e","#ea4e0d","#e84b0c","#e7490c","#e5470b","#e4450a","#e2430a","#e14109","#df3f08","#dd3d08","#dc3b07","#da3907","#d83706","#d63506","#d43305","#d23105","#d02f05","#ce2d04","#cc2b04","#ca2a04","#c82803","#c52603","#c32503","#c12302","#be2102","#bc2002","#b91e02","#b71d02","#b41b01","#b21a01","#af1801","#ac1701","#a91601","#a71401","#a41301","#a11201","#9e1001","#9b0f01","#980e01","#950d01","#920b01","#8e0a01","#8b0902","#880802","#850702","#810602","#7e0502","#7a0403"],va=["#000004","#010005","#010106","#010108","#020109","#02020b","#02020d","#03030f","#030312","#040414","#050416","#060518","#06051a","#07061c","#08071e","#090720","#0a0822","#0b0924","#0c0926","#0d0a29","#0e0b2b","#100b2d","#110c2f","#120d31","#130d34","#140e36","#150e38","#160f3b","#180f3d","#19103f","#1a1042","#1c1044","#1d1147","#1e1149","#20114b","#21114e","#221150","#241253","#251255","#271258","#29115a","#2a115c","#2c115f","#2d1161","#2f1163","#311165","#331067","#341069","#36106b","#38106c","#390f6e","#3b0f70","#3d0f71","#3f0f72","#400f74","#420f75","#440f76","#451077","#471078","#491078","#4a1079","#4c117a","#4e117b","#4f127b","#51127c","#52137c","#54137d","#56147d","#57157e","#59157e","#5a167e","#5c167f","#5d177f","#5f187f","#601880","#621980","#641a80","#651a80","#671b80","#681c81","#6a1c81","#6b1d81","#6d1d81","#6e1e81","#701f81","#721f81","#732081","#752181","#762181","#782281","#792282","#7b2382","#7c2382","#7e2482","#802582","#812581","#832681","#842681","#862781","#882781","#892881","#8b2981","#8c2981","#8e2a81","#902a81","#912b81","#932b80","#942c80","#962c80","#982d80","#992d80","#9b2e7f","#9c2e7f","#9e2f7f","#a02f7f","#a1307e","#a3307e","#a5317e","#a6317d","#a8327d","#aa337d","#ab337c","#ad347c","#ae347b","#b0357b","#b2357b","#b3367a","#b5367a","#b73779","#b83779","#ba3878","#bc3978","#bd3977","#bf3a77","#c03a76","#c23b75","#c43c75","#c53c74","#c73d73","#c83e73","#ca3e72","#cc3f71","#cd4071","#cf4070","#d0416f","#d2426f","#d3436e","#d5446d","#d6456c","#d8456c","#d9466b","#db476a","#dc4869","#de4968","#df4a68","#e04c67","#e24d66","#e34e65","#e44f64","#e55064","#e75263","#e85362","#e95462","#ea5661","#eb5760","#ec5860","#ed5a5f","#ee5b5e","#ef5d5e","#f05f5e","#f1605d","#f2625d","#f2645c","#f3655c","#f4675c","#f4695c","#f56b5c","#f66c5c","#f66e5c","#f7705c","#f7725c","#f8745c","#f8765c","#f9785d","#f9795d","#f97b5d","#fa7d5e","#fa7f5e","#fa815f","#fb835f","#fb8560","#fb8761","#fc8961","#fc8a62","#fc8c63","#fc8e64","#fc9065","#fd9266","#fd9467","#fd9668","#fd9869","#fd9a6a","#fd9b6b","#fe9d6c","#fe9f6d","#fea16e","#fea36f","#fea571","#fea772","#fea973","#feaa74","#feac76","#feae77","#feb078","#feb27a","#feb47b","#feb67c","#feb77e","#feb97f","#febb81","#febd82","#febf84","#fec185","#fec287","#fec488","#fec68a","#fec88c","#feca8d","#fecc8f","#fecd90","#fecf92","#fed194","#fed395","#fed597","#fed799","#fed89a","#fdda9c","#fddc9e","#fddea0","#fde0a1","#fde2a3","#fde3a5","#fde5a7","#fde7a9","#fde9aa","#fdebac","#fcecae","#fceeb0","#fcf0b2","#fcf2b4","#fcf4b6","#fcf6b8","#fcf7b9","#fcf9bb","#fcfbbd","#fcfdbf"],Na=["#000004","#010005","#010106","#010108","#02010a","#02020c","#02020e","#030210","#040312","#040314","#050417","#060419","#07051b","#08051d","#09061f","#0a0722","#0b0724","#0c0826","#0d0829","#0e092b","#10092d","#110a30","#120a32","#140b34","#150b37","#160b39","#180c3c","#190c3e","#1b0c41","#1c0c43","#1e0c45","#1f0c48","#210c4a","#230c4c","#240c4f","#260c51","#280b53","#290b55","#2b0b57","#2d0b59","#2f0a5b","#310a5c","#320a5e","#340a5f","#360961","#380962","#390963","#3b0964","#3d0965","#3e0966","#400a67","#420a68","#440a68","#450a69","#470b6a","#490b6a","#4a0c6b","#4c0c6b","#4d0d6c","#4f0d6c","#510e6c","#520e6d","#540f6d","#550f6d","#57106e","#59106e","#5a116e","#5c126e","#5d126e","#5f136e","#61136e","#62146e","#64156e","#65156e","#67166e","#69166e","#6a176e","#6c186e","#6d186e","#6f196e","#71196e","#721a6e","#741a6e","#751b6e","#771c6d","#781c6d","#7a1d6d","#7c1d6d","#7d1e6d","#7f1e6c","#801f6c","#82206c","#84206b","#85216b","#87216b","#88226a","#8a226a","#8c2369","#8d2369","#8f2469","#902568","#922568","#932667","#952667","#972766","#982766","#9a2865","#9b2964","#9d2964","#9f2a63","#a02a63","#a22b62","#a32c61","#a52c60","#a62d60","#a82e5f","#a92e5e","#ab2f5e","#ad305d","#ae305c","#b0315b","#b1325a","#b3325a","#b43359","#b63458","#b73557","#b93556","#ba3655","#bc3754","#bd3853","#bf3952","#c03a51","#c13a50","#c33b4f","#c43c4e","#c63d4d","#c73e4c","#c83f4b","#ca404a","#cb4149","#cc4248","#ce4347","#cf4446","#d04545","#d24644","#d34743","#d44842","#d54a41","#d74b3f","#d84c3e","#d94d3d","#da4e3c","#db503b","#dd513a","#de5238","#df5337","#e05536","#e15635","#e25734","#e35933","#e45a31","#e55c30","#e65d2f","#e75e2e","#e8602d","#e9612b","#ea632a","#eb6429","#eb6628","#ec6726","#ed6925","#ee6a24","#ef6c23","#ef6e21","#f06f20","#f1711f","#f1731d","#f2741c","#f3761b","#f37819","#f47918","#f57b17","#f57d15","#f67e14","#f68013","#f78212","#f78410","#f8850f","#f8870e","#f8890c","#f98b0b","#f98c0a","#f98e09","#fa9008","#fa9207","#fa9407","#fb9606","#fb9706","#fb9906","#fb9b06","#fb9d07","#fc9f07","#fca108","#fca309","#fca50a","#fca60c","#fca80d","#fcaa0f","#fcac11","#fcae12","#fcb014","#fcb216","#fcb418","#fbb61a","#fbb81d","#fbba1f","#fbbc21","#fbbe23","#fac026","#fac228","#fac42a","#fac62d","#f9c72f","#f9c932","#f9cb35","#f8cd37","#f8cf3a","#f7d13d","#f7d340","#f6d543","#f6d746","#f5d949","#f5db4c","#f4dd4f","#f4df53","#f4e156","#f3e35a","#f3e55d","#f2e661","#f2e865","#f2ea69","#f1ec6d","#f1ed71","#f1ef75","#f1f179","#f2f27d","#f2f482","#f3f586","#f3f68a","#f4f88e","#f5f992","#f6fa96","#f8fb9a","#f9fc9d","#fafda1","#fcffa4"],Ta=["#0d0887","#100788","#130789","#16078a","#19068c","#1b068d","#1d068e","#20068f","#220690","#240691","#260591","#280592","#2a0593","#2c0594","#2e0595","#2f0596","#310597","#330597","#350498","#370499","#38049a","#3a049a","#3c049b","#3e049c","#3f049c","#41049d","#43039e","#44039e","#46039f","#48039f","#4903a0","#4b03a1","#4c02a1","#4e02a2","#5002a2","#5102a3","#5302a3","#5502a4","#5601a4","#5801a4","#5901a5","#5b01a5","#5c01a6","#5e01a6","#6001a6","#6100a7","#6300a7","#6400a7","#6600a7","#6700a8","#6900a8","#6a00a8","#6c00a8","#6e00a8","#6f00a8","#7100a8","#7201a8","#7401a8","#7501a8","#7701a8","#7801a8","#7a02a8","#7b02a8","#7d03a8","#7e03a8","#8004a8","#8104a7","#8305a7","#8405a7","#8606a6","#8707a6","#8808a6","#8a09a5","#8b0aa5","#8d0ba5","#8e0ca4","#8f0da4","#910ea3","#920fa3","#9410a2","#9511a1","#9613a1","#9814a0","#99159f","#9a169f","#9c179e","#9d189d","#9e199d","#a01a9c","#a11b9b","#a21d9a","#a31e9a","#a51f99","#a62098","#a72197","#a82296","#aa2395","#ab2494","#ac2694","#ad2793","#ae2892","#b02991","#b12a90","#b22b8f","#b32c8e","#b42e8d","#b52f8c","#b6308b","#b7318a","#b83289","#ba3388","#bb3488","#bc3587","#bd3786","#be3885","#bf3984","#c03a83","#c13b82","#c23c81","#c33d80","#c43e7f","#c5407e","#c6417d","#c7427c","#c8437b","#c9447a","#ca457a","#cb4679","#cc4778","#cc4977","#cd4a76","#ce4b75","#cf4c74","#d04d73","#d14e72","#d24f71","#d35171","#d45270","#d5536f","#d5546e","#d6556d","#d7566c","#d8576b","#d9586a","#da5a6a","#da5b69","#db5c68","#dc5d67","#dd5e66","#de5f65","#de6164","#df6263","#e06363","#e16462","#e26561","#e26660","#e3685f","#e4695e","#e56a5d","#e56b5d","#e66c5c","#e76e5b","#e76f5a","#e87059","#e97158","#e97257","#ea7457","#eb7556","#eb7655","#ec7754","#ed7953","#ed7a52","#ee7b51","#ef7c51","#ef7e50","#f07f4f","#f0804e","#f1814d","#f1834c","#f2844b","#f3854b","#f3874a","#f48849","#f48948","#f58b47","#f58c46","#f68d45","#f68f44","#f79044","#f79143","#f79342","#f89441","#f89540","#f9973f","#f9983e","#f99a3e","#fa9b3d","#fa9c3c","#fa9e3b","#fb9f3a","#fba139","#fba238","#fca338","#fca537","#fca636","#fca835","#fca934","#fdab33","#fdac33","#fdae32","#fdaf31","#fdb130","#fdb22f","#fdb42f","#fdb52e","#feb72d","#feb82c","#feba2c","#febb2b","#febd2a","#febe2a","#fec029","#fdc229","#fdc328","#fdc527","#fdc627","#fdc827","#fdca26","#fdcb26","#fccd25","#fcce25","#fcd025","#fcd225","#fbd324","#fbd524","#fbd724","#fad824","#fada24","#f9dc24","#f9dd25","#f8df25","#f8e125","#f7e225","#f7e425","#f6e626","#f6e826","#f5e926","#f5eb27","#f4ed27","#f3ee27","#f3f027","#f2f227","#f1f426","#f1f525","#f0f724","#f0f921"],Ia=["#440154","#440256","#450457","#450559","#46075a","#46085c","#460a5d","#460b5e","#470d60","#470e61","#471063","#471164","#471365","#481467","#481668","#481769","#48186a","#481a6c","#481b6d","#481c6e","#481d6f","#481f70","#482071","#482173","#482374","#482475","#482576","#482677","#482878","#482979","#472a7a","#472c7a","#472d7b","#472e7c","#472f7d","#46307e","#46327e","#46337f","#463480","#453581","#453781","#453882","#443983","#443a83","#443b84","#433d84","#433e85","#423f85","#424086","#424186","#414287","#414487","#404588","#404688","#3f4788","#3f4889","#3e4989","#3e4a89","#3e4c8a","#3d4d8a","#3d4e8a","#3c4f8a","#3c508b","#3b518b","#3b528b","#3a538b","#3a548c","#39558c","#39568c","#38588c","#38598c","#375a8c","#375b8d","#365c8d","#365d8d","#355e8d","#355f8d","#34608d","#34618d","#33628d","#33638d","#32648e","#32658e","#31668e","#31678e","#31688e","#30698e","#306a8e","#2f6b8e","#2f6c8e","#2e6d8e","#2e6e8e","#2e6f8e","#2d708e","#2d718e","#2c718e","#2c728e","#2c738e","#2b748e","#2b758e","#2a768e","#2a778e","#2a788e","#29798e","#297a8e","#297b8e","#287c8e","#287d8e","#277e8e","#277f8e","#27808e","#26818e","#26828e","#26828e","#25838e","#25848e","#25858e","#24868e","#24878e","#23888e","#23898e","#238a8d","#228b8d","#228c8d","#228d8d","#218e8d","#218f8d","#21908d","#21918c","#20928c","#20928c","#20938c","#1f948c","#1f958b","#1f968b","#1f978b","#1f988b","#1f998a","#1f9a8a","#1e9b8a","#1e9c89","#1e9d89","#1f9e89","#1f9f88","#1fa088","#1fa188","#1fa187","#1fa287","#20a386","#20a486","#21a585","#21a685","#22a785","#22a884","#23a983","#24aa83","#25ab82","#25ac82","#26ad81","#27ad81","#28ae80","#29af7f","#2ab07f","#2cb17e","#2db27d","#2eb37c","#2fb47c","#31b57b","#32b67a","#34b679","#35b779","#37b878","#38b977","#3aba76","#3bbb75","#3dbc74","#3fbc73","#40bd72","#42be71","#44bf70","#46c06f","#48c16e","#4ac16d","#4cc26c","#4ec36b","#50c46a","#52c569","#54c568","#56c667","#58c765","#5ac864","#5cc863","#5ec962","#60ca60","#63cb5f","#65cb5e","#67cc5c","#69cd5b","#6ccd5a","#6ece58","#70cf57","#73d056","#75d054","#77d153","#7ad151","#7cd250","#7fd34e","#81d34d","#84d44b","#86d549","#89d548","#8bd646","#8ed645","#90d743","#93d741","#95d840","#98d83e","#9bd93c","#9dd93b","#a0da39","#a2da37","#a5db36","#a8db34","#aadc32","#addc30","#b0dd2f","#b2dd2d","#b5de2b","#b8de29","#bade28","#bddf26","#c0df25","#c2df23","#c5e021","#c8e020","#cae11f","#cde11d","#d0e11c","#d2e21b","#d5e21a","#d8e219","#dae319","#dde318","#dfe318","#e2e418","#e5e419","#e7e419","#eae51a","#ece51b","#efe51c","#f1e51d","#f4e61e","#f6e620","#f8e621","#fbe723","#fde725"],ka=["#00204d","#00214e","#002250","#002252","#002353","#002455","#002557","#002558","#00265a","#00275c","#00275e","#002860","#002961","#002a63","#002a65","#002b67","#002c69","#002c6a","#002d6c","#002e6e","#002e6f","#002f6f","#002f6f","#00306f","#00306f","#00316f","#00326f","#00336f","#00336f","#00346f","#00356e","#01366e","#06366e","#0b376e","#0f386e","#12386d","#15396d","#183a6d","#1a3b6d","#1d3b6d","#1f3c6d","#213d6d","#233e6c","#243e6c","#263f6c","#28406c","#2a406c","#2b416c","#2d426c","#2e436c","#30436c","#31446b","#32456b","#34456b","#35466b","#36476b","#38486b","#39486b","#3a496b","#3b4a6b","#3d4a6b","#3e4b6b","#3f4c6b","#404d6b","#414d6b","#424e6b","#434f6b","#444f6b","#46506b","#47516b","#48526b","#49526b","#4a536b","#4b546c","#4c546c","#4d556c","#4e566c","#4f576c","#50576c","#51586c","#52596c","#53596c","#545a6c","#555b6d","#565c6d","#575c6d","#585d6d","#595e6d","#595f6d","#5a5f6d","#5b606e","#5c616e","#5d616e","#5e626e","#5f636e","#60646f","#61646f","#62656f","#63666f","#64666f","#646770","#656870","#666970","#676970","#686a71","#696b71","#6a6c71","#6b6c71","#6c6d72","#6c6e72","#6d6e72","#6e6f73","#6f7073","#707173","#717174","#727274","#727374","#737475","#747475","#757575","#767676","#777776","#787777","#787877","#797977","#7a7a78","#7b7a78","#7c7b78","#7d7c78","#7e7d78","#7f7d78","#807e79","#817f79","#828079","#838079","#848179","#848279","#858379","#868379","#878479","#888579","#898679","#8a8779","#8b8779","#8c8879","#8d8979","#8e8a79","#8f8a79","#908b79","#918c78","#928d78","#938e78","#948e78","#958f78","#969078","#979178","#989278","#999278","#9a9377","#9b9477","#9c9577","#9d9677","#9e9677","#9f9777","#a09877","#a19976","#a29a76","#a39a76","#a49b76","#a59c76","#a69d75","#a89e75","#a99f75","#aa9f75","#aba074","#aca174","#ada274","#aea374","#afa473","#b0a473","#b1a573","#b2a672","#b3a772","#b4a872","#b5a971","#b6a971","#b7aa71","#b8ab70","#b9ac70","#baad70","#bbae6f","#bcaf6f","#beaf6f","#bfb06e","#c0b16e","#c1b26d","#c2b36d","#c3b46d","#c4b56c","#c5b56c","#c6b66b","#c7b76b","#c8b86a","#c9b96a","#cbba69","#ccbb69","#cdbc68","#cebc68","#cfbd67","#d0be67","#d1bf66","#d2c066","#d3c165","#d4c264","#d6c364","#d7c463","#d8c563","#d9c562","#dac661","#dbc761","#dcc860","#ddc95f","#deca5f","#e0cb5e","#e1cc5d","#e2cd5c","#e3ce5c","#e4cf5b","#e5d05a","#e6d159","#e8d259","#e9d358","#ead357","#ebd456","#ecd555","#edd654","#efd753","#f0d852","#f1d951","#f2da50","#f3db4f","#f4dc4e","#f6dd4d","#f7de4c","#f8df4b","#f9e04a","#fae149","#fbe248","#fde346","#fee445","#ffe544","#ffe642","#ffe742","#ffe843","#ffe944","#ffea46"],Sa=["#03051a","#04051a","#05061b","#06071c","#07071d","#08081e","#0a091f","#0b0920","#0d0a21","#0e0b22","#100b23","#110c24","#130d25","#140e26","#160e27","#170f28","#180f29","#1a102a","#1b112b","#1d112c","#1e122d","#20122e","#211330","#221331","#241432","#251433","#271534","#281535","#2a1636","#2b1637","#2d1738","#2e1739","#30173a","#31183b","#33183c","#34193d","#35193e","#37193f","#381a40","#3a1a41","#3c1a42","#3d1a42","#3f1b43","#401b44","#421b45","#431c46","#451c47","#461c48","#481c48","#491d49","#4b1d4a","#4c1d4b","#4e1d4b","#501d4c","#511e4d","#531e4d","#541e4e","#561e4f","#581e4f","#591e50","#5b1e51","#5c1e51","#5e1f52","#601f52","#611f53","#631f53","#641f54","#661f54","#681f55","#691f55","#6b1f56","#6d1f56","#6e1f57","#701f57","#711f57","#731f58","#751f58","#761f58","#781f59","#7a1f59","#7b1f59","#7d1f5a","#7f1e5a","#811e5a","#821e5a","#841e5a","#861e5b","#871e5b","#891e5b","#8b1d5b","#8c1d5b","#8e1d5b","#901d5b","#921c5b","#931c5b","#951c5b","#971c5b","#981b5b","#9a1b5b","#9c1b5b","#9e1a5b","#9f1a5b","#a11a5b","#a3195b","#a4195b","#a6195a","#a8185a","#aa185a","#ab185a","#ad1759","#af1759","#b01759","#b21758","#b41658","#b51657","#b71657","#b91657","#ba1656","#bc1656","#bd1655","#bf1654","#c11754","#c21753","#c41753","#c51852","#c71951","#c81951","#ca1a50","#cb1b4f","#cd1c4e","#ce1d4e","#cf1e4d","#d11f4c","#d2204c","#d3214b","#d5224a","#d62449","#d72549","#d82748","#d92847","#db2946","#dc2b46","#dd2c45","#de2e44","#df2f44","#e03143","#e13342","#e23442","#e33641","#e43841","#e53940","#e63b40","#e73d3f","#e83f3f","#e8403e","#e9423e","#ea443e","#eb463e","#eb483e","#ec4a3e","#ec4c3e","#ed4e3e","#ed503e","#ee523f","#ee543f","#ef5640","#ef5840","#ef5a41","#f05c42","#f05e42","#f06043","#f16244","#f16445","#f16646","#f26747","#f26948","#f26b49","#f26d4b","#f26f4c","#f3714d","#f3734e","#f37450","#f37651","#f37852","#f47a54","#f47c55","#f47d57","#f47f58","#f4815a","#f4835b","#f4845d","#f4865e","#f58860","#f58a61","#f58b63","#f58d64","#f58f66","#f59067","#f59269","#f5946b","#f5966c","#f5976e","#f59970","#f69b71","#f69c73","#f69e75","#f6a077","#f6a178","#f6a37a","#f6a47c","#f6a67e","#f6a880","#f6a981","#f6ab83","#f6ad85","#f6ae87","#f6b089","#f6b18b","#f6b38d","#f6b48f","#f6b691","#f6b893","#f6b995","#f6bb97","#f6bc99","#f6be9b","#f6bf9d","#f6c19f","#f7c2a2","#f7c4a4","#f7c6a6","#f7c7a8","#f7c9aa","#f7caac","#f7ccaf","#f7cdb1","#f7cfb3","#f7d0b5","#f8d1b8","#f8d3ba","#f8d4bc","#f8d6be","#f8d7c0","#f8d9c3","#f8dac5","#f8dcc7","#f9ddc9","#f9dfcb","#f9e0cd","#f9e2d0","#f9e3d2","#f9e5d4","#fae6d6","#fae8d8","#fae9da","#faebdd"],_a=["#0b0405","#0d0406","#0e0508","#0f0609","#10060a","#11070c","#12080d","#13090f","#140910","#150a12","#160b13","#170c15","#180d16","#190e18","#1a0e19","#1b0f1a","#1c101c","#1d111d","#1e111f","#1f1220","#201322","#211423","#221425","#231526","#241628","#251729","#26172b","#27182d","#28192e","#291930","#291a31","#2a1b33","#2b1c35","#2c1c36","#2d1d38","#2e1e39","#2e1e3b","#2f1f3d","#30203e","#312140","#312142","#322243","#332345","#342447","#342548","#35254a","#35264c","#36274d","#37284f","#372851","#382953","#382a54","#392b56","#3a2c58","#3a2c59","#3b2d5b","#3b2e5d","#3b2f5f","#3c3060","#3c3162","#3d3164","#3d3266","#3e3367","#3e3469","#3e356b","#3f366d","#3f366f","#3f3770","#403872","#403974","#403a76","#403b78","#403c79","#413d7b","#413e7d","#413e7f","#413f80","#414082","#414184","#414285","#414387","#414488","#40468a","#40478b","#40488d","#40498e","#3f4a8f","#3f4b90","#3f4c92","#3e4d93","#3e4f94","#3e5095","#3d5195","#3d5296","#3c5397","#3c5598","#3b5698","#3b5799","#3b589a","#3a599a","#3a5b9b","#3a5c9b","#395d9c","#395e9c","#385f9c","#38619d","#38629d","#38639d","#37649e","#37659e","#37669e","#37689f","#36699f","#366a9f","#366b9f","#366ca0","#366da0","#366fa0","#3670a0","#3671a0","#3572a1","#3573a1","#3574a1","#3575a1","#3576a2","#3578a2","#3579a2","#357aa2","#357ba3","#357ca3","#357da3","#357ea4","#347fa4","#3480a4","#3482a4","#3483a5","#3484a5","#3485a5","#3486a5","#3487a6","#3488a6","#3489a6","#348ba6","#348ca7","#348da7","#348ea7","#348fa7","#3490a8","#3491a8","#3492a8","#3493a8","#3495a9","#3496a9","#3497a9","#3498a9","#3499aa","#349aaa","#359baa","#359caa","#359eaa","#359fab","#35a0ab","#35a1ab","#36a2ab","#36a3ab","#36a4ab","#37a5ac","#37a6ac","#37a8ac","#38a9ac","#38aaac","#39abac","#39acac","#3aadac","#3aaead","#3bafad","#3cb1ad","#3cb2ad","#3db3ad","#3eb4ad","#3fb5ad","#3fb6ad","#40b7ad","#41b8ad","#42b9ad","#43baad","#44bcad","#45bdad","#46bead","#47bfad","#48c0ad","#49c1ad","#4bc2ad","#4cc3ad","#4dc4ad","#4fc5ad","#50c6ad","#52c7ad","#53c9ad","#55caad","#57cbad","#59ccad","#5bcdad","#5ecdad","#60ceac","#62cfac","#65d0ad","#68d1ad","#6ad2ad","#6dd3ad","#70d4ad","#73d4ad","#76d5ae","#79d6ae","#7cd6af","#7fd7af","#82d8b0","#85d9b1","#88d9b1","#8bdab2","#8edbb3","#91dbb4","#94dcb5","#96ddb5","#99ddb6","#9cdeb7","#9edfb8","#a1dfb9","#a4e0bb","#a6e1bc","#a9e1bd","#abe2be","#aee3c0","#b0e4c1","#b2e4c2","#b5e5c4","#b7e6c5","#b9e6c7","#bbe7c8","#bee8ca","#c0e9cc","#c2e9cd","#c4eacf","#c6ebd1","#c8ecd2","#caedd4","#ccedd6","#ceeed7","#d0efd9","#d2f0db","#d4f1dc","#d6f1de","#d8f2e0","#daf3e1","#dcf4e3","#def5e5"],Ma=["#000000","#111111","#222222","#333333","#444444","#555555","#666666","#777777","#888888","#999999","#aaaaaa","#bbbbbb","#cccccc","#dddddd","#eeeeee","#ffffff"],Je=e=>e.slice().reverse(),Ra={turbo:Ea,"turbo-reversed":Je(Ea),grey:Ma,"grey-reversed":Je(Ma),magma:va,"magma-reversed":Je(va),inferno:Na,"inferno-reversed":Je(Na),plasma:Ta,"plasma-reversed":Je(Ta),viridis:Ia,"viridis-reversed":Je(Ia),cividis:ka,"cividis-reversed":Je(ka),rocket:Sa,"rocket-reversed":Je(Sa),mako:_a,"mako-reversed":Je(_a)};var Da=7,Pa=[.9999999999998099,676.5203681218851,-1259.1392167224028,771.3234287776531,-176.6150291621406,12.507343278686905,-.13857109526572012,9984369578019572e-21,15056327351493116e-23];function Ee(e){if(e<0)return NaN;let n=Math.PI,t=e*e*e;return e*Math.log(e)-e-.5*Math.log(e)+.5*Math.log(2*n)+1/(12*e)-1/(360*t)+1/(1260*t*e*e)}function te(e){if(e<.5)return Math.PI/(Math.sin(Math.PI*e)*te(1-e));if(e>100)return Math.exp(Ee(e));e-=1;let n=Pa[0];for(let i=1;i<Da+2;i++)n+=Pa[i]/(e+i);let t=e+Da+.5;return Math.sqrt(2*Math.PI)*Math.pow(t,e+.5)*Math.exp(-t)*n}function Fa(e){let n=Math.PI,t=n*n,i=t*n,r=e*e,s=e*r,o=s*r,a=o*r;return Math.sqrt(n)/2*(e+n/12*s+7*t/480*o+127*i/40320*a+4369*t*t/5806080*a*r+34807*i*t/182476800*a*r*r)}function tt(e){return 1-$n(e)}function $n(e){let n=.254829592,t=-.284496736,i=1.421413741,r=-1.453152027,s=1.061405429,o=.3275911,a=e<0?-1:1;e=Math.abs(e);let u=1/(1+o*e),l=((((s*u+r)*u+i)*u+t)*u+n)*u;return a*(1-l*Math.exp(-e*e))}var qt=.5772156649015329,An=[1/6,-1/30,1/42,-1/30,5/66,-691/2730,7/6,-3617/510,43867/798,-174611/330];function Gt(e){if(!isFinite(e))return NaN;if(e<0)return Number.isInteger(e)?NaN:Gt(1-e)-Math.PI/Math.tan(Math.PI*e);if(e===0)return NaN;let n=0,t=e;for(;t<7;)n-=1/t,t+=1;n+=Math.log(t)-1/(2*t);let i=t*t;for(let r=0;r<An.length;r++)n-=An[r]/(2*(r+1)*i),i*=t*t;return n}function jt(e){if(!isFinite(e))return NaN;if(e<0){if(Number.isInteger(e))return NaN;let r=Math.sin(Math.PI*e);return Math.PI*Math.PI/(r*r)-jt(1-e)}if(e===0)return NaN;let n=0,t=e;for(;t<7;)n+=1/(t*t),t+=1;n+=1/t+1/(2*t*t);let i=t*t*t;for(let r=0;r<An.length;r++)n+=An[r]/i,i*=t*t;return n}function er(e,n){if(!Number.isInteger(e)||e<0)return NaN;if(e===0)return Gt(n);if(e===1)return jt(n);if(!isFinite(n)||n===0)return NaN;if(n<0){if(Number.isInteger(n))return NaN;let a=0,u=n,l=e%2===0?1:-1;for(;u<1;)a+=l*wn(e)/Math.pow(u,e+1),u+=1;return a+er(e,u)}let t=0,i=n,r=e%2===0?-1:1;for(;i<7;)t+=r*wn(e)/Math.pow(i,e+1),i+=1;let s=e%2===0?-1:1;t+=s*wn(e-1)/Math.pow(i,e),t+=s*wn(e)/(2*Math.pow(i,e+1));let o=Math.pow(i,e+2);for(let a=0;a<Math.min(An.length,6);a++){let u=2*(a+1),l=1;for(let c=0;c<u;c++)l*=e+c;t+=s*An[a]*l/(wn(u)*o),o*=i*i}return t}function wn(e){if(e<=1)return 1;let n=1;for(let t=2;t<=e;t++)n*=t;return n}function Oa(e,n){return e>100||n>100||e+n>100?Math.exp(Ee(e)+Ee(n)-Ee(e+n)):te(e)*te(n)/te(e+n)}function nr(e){if(!isFinite(e))return NaN;if(e===1)return 1/0;if(e===0)return-.5;if(e===2)return Math.PI*Math.PI/6;if(e===4)return Math.PI**4/90;if(e===6)return Math.PI**6/945;if(e===8)return Math.PI**8/9450;if(e<0)return Math.pow(2,e)*Math.pow(Math.PI,e-1)*Math.sin(Math.PI*e/2)*te(1-e)*nr(1-e);let n=22,t=Oc(n),i=t[n],r=0;for(let s=0;s<=n;s++)r+=(s%2===0?1:-1)*(t[s]-i)/Math.pow(s+1,e);return-1/(i*(1-Math.pow(2,1-e)))*r}function Oc(e){let n=new Array(e+1);n[0]=1;for(let t=1;t<=e;t++)n[t]=n[t-1]+Lc(e,t);return n}function Lc(e,n){n>e-n&&(n=e-n);let t=1;for(let i=0;i<n;i++)t=t*(e-i)/(i+1);return t}function La(e){if(!isFinite(e))return e;if(e===0)return 0;let n=1/Math.E;if(e<-n)return NaN;if(Math.abs(e+n)<1e-15)return-1;let t;if(e<0){let i=Math.sqrt(2*(Math.E*e+1));t=-1+i-i*i/3+11/72*i*i*i}else if(e<=1)t=e*(1-e*(1-1.5*e));else if(e<100){let i=Math.log(e);t=i-Math.log(i)}else{let i=Math.log(e),r=Math.log(i);t=i-r+r/i}for(let i=0;i<30;i++){let r=Math.exp(t),o=t*r-e,a=r*(t+1),u=r*(t+2),l=o/(a-o*u/(2*a));if(t-=l,Math.abs(l)<1e-15*(1+Math.abs(t)))break}return t}function He(e,n){return!isFinite(n)||!Number.isInteger(e)?NaN:n===0?e===0?1:0:e<0?(e=-e,e%2===0?He(e,n):-He(e,n)):n<0?e%2===0?He(e,-n):-He(e,-n):n>25+e*e/2?Vc(e,n):n<5+e?Bc(e,n):Jc(e,n)}function Bc(e,n){let t=n/2,i=-(n*n)/4,r=1;for(let o=1;o<=e;o++)r/=o;let s=r;for(let o=1;o<=60&&(r*=i/(o*(e+o)),s+=r,!(Math.abs(r)<Math.abs(s)*1e-16));o++);return s*Math.pow(t,e)}function Ba(e,n){let t=4*e*e,i=1,r=0,s=1,o=8*n;for(let a=1;a<=20;a++){s*=t-(2*a-1)*(2*a-1);let u=wn(a)*Math.pow(o,a),l=s/u;if(a%2===1?r+=(a%4===1?1:-1)*l:i+=(a%4===2?-1:1)*l,Math.abs(l)<1e-15)break}return[i,r]}function Vc(e,n){let t=n-(e/2+.25)*Math.PI,[i,r]=Ba(e,n);return Math.sqrt(2/(Math.PI*n))*(i*Math.cos(t)-r*Math.sin(t))}function Jc(e,n){let t=Math.max(e+20,Math.ceil(n)+30),i=0,r=1,s=new Array(t+1);s[t]=r;for(let u=t;u>=1;u--){let l=2*u/n*r-i;i=r,r=l,s[u-1]=r}let o=s[0];for(let u=2;u<=t;u+=2)o+=2*s[u];let a=1/o;return s[e]*a}function zt(e,n){if(!isFinite(n)||!Number.isInteger(e))return NaN;if(n<=0)return NaN;if(e<0)return e=-e,e%2===0?zt(e,n):-zt(e,n);if(n>12+e*e/4)return Gc(e,n);let t=qc(n);if(e===0)return t;let i=zc(n);if(e===1)return i;let r=t,s=i;for(let o=1;o<e;o++){let a=2*o/n*s-r;r=s,s=a}return s}function qc(e){let n=e/2,t=n*n,i=He(0,e),r=0,s=1,o=0;for(let a=1;a<=60&&(o+=1/a,s*=-t/(a*a),r-=s*o,!(Math.abs(s*o)<Math.abs(r)*1e-16));a++);return 2/Math.PI*(i*(Math.log(n)+qt)+r)}function zc(e){let n=e/2,t=n*n,i=He(1,e),r=0,s=1,o=1;for(let a=0;a<=60;a++){a>0&&(o*=a,s*=t);let u=o*(a+1),l=0;for(let v=1;v<=a;v++)l+=1/v;let c=l+1/(a+1),p=-qt+l,m=-qt+c,b=(a%2===0?1:-1)*(p+m)*s/(o*u);if(r+=b,a>3&&Math.abs(b)<1e-16*Math.abs(r))break}return-2/(Math.PI*e)+2/Math.PI*Math.log(n)*i-n/Math.PI*r}function Gc(e,n){let t=n-(e/2+.25)*Math.PI,[i,r]=Ba(e,n);return Math.sqrt(2/(Math.PI*n))*(i*Math.sin(t)+r*Math.cos(t))}function rn(e,n){return!isFinite(n)||!Number.isInteger(e)?NaN:n===0?e===0?1:0:(e<0&&(e=-e),n<0?e%2===0?rn(e,-n):-rn(e,-n):n>40?Uc(e,n):jc(e,n))}function jc(e,n){let t=n/2,i=n*n/4,r=1;for(let o=1;o<=e;o++)r/=o;let s=r;for(let o=1;o<=80&&(r*=i/(o*(e+o)),s+=r,!(Math.abs(r)<Math.abs(s)*1e-16));o++);return s*Math.pow(t,e)}function Uc(e,n){let t=4*e*e,i=1,r=1;for(let s=1;s<=12;s++){let o=t-(2*s-1)*(2*s-1);if(i*=o/(s*8*n),r+=i,Math.abs(i)<1e-15)break}return Math.exp(n)/Math.sqrt(2*Math.PI*n)*r}function Va(e,n){if(!isFinite(n)||!Number.isInteger(e))return NaN;if(n<=0)return NaN;if(e<0&&(e=-e),n>40)return Yc(e,n);let t=Ja(n);if(e===0)return t;let i=Zc(n);if(e===1)return i;let r=t,s=i;for(let o=1;o<e;o++){let a=2*o/n*s+r;r=s,s=a}return s}function Ja(e){let n=e/2,t=n*n,i=rn(0,e),r=0,s=1,o=0;for(let a=1;a<=60&&(o+=1/a,s*=t/(a*a),r+=s*o,!(Math.abs(s*o)<Math.abs(r)*1e-16&&a>3));a++);return-(Math.log(n)+qt)*i+r}function Zc(e){let n=rn(0,e),t=rn(1,e),i=Ja(e);return(1/e-t*i)/n}function Yc(e,n){let t=4*e*e,i=1,r=1;for(let s=1;s<=12;s++){let o=t-(2*s-1)*(2*s-1);if(i*=o/(s*8*n),r+=i,Math.abs(i)<1e-15)break}return Math.sqrt(Math.PI/(2*n))*Math.exp(-n)*r}function qa(e){if(!isFinite(e))return NaN;if(e>5){let a=.6666666666666666*Math.pow(e,1.5);return Hc(e,a)}if(e<-5){let a=-e,u=2/3*Math.pow(a,1.5);return Wc(a,u)}let n=1/(Math.pow(3,2/3)*te(2/3)),t=1/(Math.pow(3,1/3)*te(1/3)),i=1,r=e,s=1,o=e;for(let a=1;a<=80;a++){let u=3*a;if(s*=e*e*e/((u-1)*u),o*=e*e*e/(u*(u+1)),i+=s,r+=o,Math.abs(s)+Math.abs(o)<1e-16*(Math.abs(i)+Math.abs(r)))break}return n*i-t*r}function Hc(e,n){let t=Math.pow(e,.25),i=1,r=1,s=[1,5/72,385/10368,85085/2239488,37182145/644972544];for(let o=1;o<s.length;o++)r=s[o]/Math.pow(n,o),i+=(o%2===0?1:-1)*r;return Math.exp(-n)/(2*Math.sqrt(Math.PI)*t)*i}function Wc(e,n){let t=Math.pow(e,.25);return Math.sin(n+Math.PI/4)/(Math.sqrt(Math.PI)*t)}function za(e){if(!isFinite(e))return NaN;if(e>5){let a=.6666666666666666*Math.pow(e,1.5);return Xc(e,a)}if(e<-5){let a=-e,u=2/3*Math.pow(a,1.5);return Qc(a,u)}let n=1/(Math.pow(3,2/3)*te(2/3)),t=1/(Math.pow(3,1/3)*te(1/3)),i=1,r=e,s=1,o=e;for(let a=1;a<=80;a++){let u=3*a;if(s*=e*e*e/((u-1)*u),o*=e*e*e/(u*(u+1)),i+=s,r+=o,Math.abs(s)+Math.abs(o)<1e-16*(Math.abs(i)+Math.abs(r)))break}return Math.sqrt(3)*(n*i+t*r)}function Xc(e,n){let t=Math.pow(e,.25),i=1,r=1,s=[1,5/72,385/10368,85085/2239488,37182145/644972544];for(let o=1;o<s.length;o++)r=s[o]/Math.pow(n,o),i+=r;return Math.exp(n)/(Math.sqrt(Math.PI)*t)*i}function Qc(e,n){let t=Math.pow(e,.25);return Math.cos(n+Math.PI/4)/(Math.sqrt(Math.PI)*t)}var Kc=[-2991.8191940101983,708840.0452577386,-6297414862058625e-8,25489088057337637e-7,-4429795180596978e-5,3180162978765678e-4],ef=[1,281.3762688899943,45584.78108065326,5173438887700964e-9,4193202458981112e-7,22441179564534092e-6,607366389490085e-3],nf=[-49884311457357354e-24,9504280628298596e-21,-.0006451914356839651,.018884331939670384,-.20552590095501388,1],tf=[399982968972496e-26,9154392157746574e-25,12500186247959882e-23,12226278902417902e-21,.0008680295429417843,.04121420907221998,1],Ga=[.4215435550436775,.1434079197807589,.011522095507358577,.000345017939782574,46361374928786735e-22,3055689837902576e-23,10230451416490724e-26,17201074326816183e-29,13428327623306275e-32,3763297112699879e-35],ja=[1,.7515863983533789,.11688892585919138,.0064405152650885865,.00015593440916415301,18462756734893055e-22,11269922476399903e-24,36014002958937136e-27,5887545336215784e-29,45200143407412973e-33,12544323709001127e-36],Ua=[.5044420736433832,.1971028335255234,.018764858409257526,.0006840793809153931,11513882611188428e-21,9828524436884223e-23,44534441586175015e-26,10826804113902088e-28,1375554606332618e-30,8363544356306774e-34,18695871016278324e-38],Za=[1,1.4749575992512833,.33774898912002,.02536037414203388,.0008146791071843061,12754507566772912e-21,10431458965757199e-23,46068072851523205e-26,11027321506624028e-28,13879653125957886e-31,8391588162831187e-34,18695871016278324e-38];function ye(e,n){let t=n[0];for(let i=1;i<n.length;i++)t=t*e+n[i];return t}function sn(e){if(!isFinite(e))return e!==e?NaN:e>0?.5:-.5;let n=e<0?-1:1;if(e=Math.abs(e),e<1.6){let t=e*e,i=t*t;return n*e*t*ye(i,Kc)/ye(i,ef)}if(e<36){let t=e*e,i=Math.PI*t,r=1/(i*i),s=1-r*ye(r,Ga)/ye(r,ja),o=1/i*ye(r,Ua)/ye(r,Za),a=Math.PI/2*t,u=Math.cos(a),l=Math.sin(a);return n*(.5-(s*u+o*l)/(Math.PI*e))}return n*.5}function on(e){if(!isFinite(e))return e!==e?NaN:e>0?.5:-.5;let n=e<0?-1:1;if(e=Math.abs(e),e<1.6){let t=e*e,i=t*t;return n*e*ye(i,nf)/ye(i,tf)}if(e<36){let t=e*e,i=Math.PI*t,r=1/(i*i),s=1-r*ye(r,Ga)/ye(r,ja),o=1/i*ye(r,Ua)/ye(r,Za),a=Math.PI/2*t,u=Math.cos(a),l=Math.sin(a);return n*(.5+(s*l-o*u)/(Math.PI*e))}return n*.5}function Ya(e){return e===0?1:Math.sin(e)/e}var it=[[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1],[1,5,10,10,5,1],[1,6,15,20,15,6,1],[1,7,21,35,35,21,7,1],[1,8,28,56,70,56,28,8,1]];function an(e,n){for(;e>=it.length;){let t=it.length,i=[1],r=it[t-1];for(let s=1;s<t;s++)i[s]=r[s-1]+r[s];i[t]=1,it.push(i)}return it[e][n]}function Wa(e){let n=0,t=0;for(let i of e)n+=i,t++;return t===0?NaN:n/t}function un(e){let n=[...e].sort((i,r)=>i-r),t=Math.floor(n.length/2);return n.length%2===0?(n[t-1]+n[t])/2:n[t]}function tr(e){let n=0,t=0,i=0;for(let r of e)n+=r,t+=r*r,i++;return i===0?NaN:(t-n*n/i)/(i-1)}function ir(e){let n=0,t=0,i=0;for(let r of e)n+=r,t+=r*r,i++;return i===0?NaN:(t-n*n/i)/i}function Xa(e){return Math.sqrt(tr(e))}function Qa(e){return Math.sqrt(ir(e))}function Ka(e){let n=0,t=0,i=0,r=0;for(let o of e){let a=o;if(!Number.isFinite(a))return NaN;n+=a,t+=a*a,i+=a*a*a*a,r++}if(r===0)return NaN;let s=(t-n*n/r)/(r-1);return(i-4*n*t/r+6*n*n*n/r/r-3*n*n*n*n/r/r/r)/(s*s)}function eu(e){let n=0,t=0,i=0,r=0;for(let a of e){let u=a;if(!Number.isFinite(u))return NaN;n+=u,t+=u*u,i+=u*u*u,r++}if(r===0)return NaN;let s=(t-n*n/r)/(r-1);return(i-t*n/r)/(r-1)/Math.pow(s,3/2)*Math.sqrt(r*1)}function nu(e){let n={};for(let r of e)n[r]=(n[r]??0)+1;let t=0,i=NaN;for(let r in n){let s=n[r];s>t&&(t=s,i=+r)}return i}function tu(e){let n=[...e].sort((o,a)=>o-a),t=Math.floor(n.length/2),i=un(n.slice(0,t)),r=un(n),s=un(n.slice(t));return[i,r,s]}function iu(e){let n=[...e].sort((s,o)=>s-o),t=Math.floor(n.length/2),i=n.slice(0,t),r=n.slice(t+1);return un(r)-un(i)}function lf(e,n){if(n===0)return{estimate:e,error:n};let t=Math.abs(n),i=Math.floor(Math.log10(t)),r=2,s=Math.pow(10,i-(r-1)),o=Math.round(n/s)*s,a=Math.max(0,-(i-(r-1)));return{estimate:Number(e.toFixed(a)),error:o}}function ru(e,n,t,i=1e5){let r=0,s=0;if(n===-1/0&&t===1/0)for(let d=0;d<i;d++){let b=Math.random(),v=Math.tan(Math.PI*(b-.5)),k=e(v)*Math.PI*(1+v*v);r+=k,s+=k*k}else if(n===-1/0)for(let d=0;d<i;d++){let b=Math.random(),v=t+Math.log(b),k=e(v)/b;r+=k,s+=k*k}else if(t===1/0)for(let d=0;d<i;d++){let b=Math.random(),v=n-Math.log(b),k=e(v)/b;r+=k,s+=k*k}else for(let d=0;d<i;d++){let b=e(n+Math.random()*(t-n));r+=b,s+=b*b}let o=r/i,a=(s-i*o*o)/(i-1),u=Math.sqrt(a/i),l=isFinite(n)&&isFinite(t)?t-n:1,c=o*l,p=u*l;return lf(c,p)}var rr={Add:["+",11],Negate:["-",14],Subtract:["-",11],Multiply:["*",12],Divide:["/",13],Equal:["===",8],NotEqual:["!==",8],LessEqual:["<=",9],GreaterEqual:[">=",9],Less:["<",9],Greater:[">",9],And:["&&",4],Or:["||",3],Not:["!",14]},sr={Abs:(e,n)=>g.isComplexValued(e[0])?`_SYS.cabs(${n(e[0])})`:`Math.abs(${n(e[0])})`,Add:(e,n)=>{if(e.length===1)return n(e[0]);if(!e.some(o=>g.isComplexValued(o)))return`(${e.map(o=>n(o)).join(" + ")})`;let i=e.map(o=>({code:n(o),isComplex:g.isComplexValued(o)})),r=i.map(o=>o.isComplex?`(${o.code}).re`:o.code),s=i.filter(o=>o.isComplex).map(o=>`(${o.code}).im`);return`({ re: ${r.join(" + ")}, im: ${s.join(" + ")} })`},Arccos:(e,n)=>g.isComplexValued(e[0])?`_SYS.cacos(${n(e[0])})`:`Math.acos(${n(e[0])})`,Arcosh:"Math.acosh",Arccot:([e],n)=>{if(e===null)throw new Error("Arccot: no argument");return g.isComplexValued(e)?`_SYS.cacot(${n(e)})`:`Math.atan(1 / (${n(e)}))`},Arcoth:([e],n)=>{if(e===null)throw new Error("Arcoth: no argument");return g.isComplexValued(e)?`_SYS.cacoth(${n(e)})`:`Math.atanh(1 / (${n(e)}))`},Arccsc:([e],n)=>{if(e===null)throw new Error("Arccsc: no argument");return g.isComplexValued(e)?`_SYS.cacsc(${n(e)})`:`Math.asin(1 / (${n(e)}))`},Arcsch:([e],n)=>{if(e===null)throw new Error("Arcsch: no argument");return g.isComplexValued(e)?`_SYS.cacsch(${n(e)})`:`Math.asinh(1 / (${n(e)}))`},Arcsec:([e],n)=>{if(e===null)throw new Error("Arcsec: no argument");return g.isComplexValued(e)?`_SYS.casec(${n(e)})`:`Math.acos(1 / (${n(e)}))`},Arsech:([e],n)=>{if(e===null)throw new Error("Arsech: no argument");return g.isComplexValued(e)?`_SYS.casech(${n(e)})`:`Math.acosh(1 / (${n(e)}))`},Arcsin:(e,n)=>g.isComplexValued(e[0])?`_SYS.casin(${n(e[0])})`:`Math.asin(${n(e[0])})`,Arsinh:"Math.asinh",Arctan:(e,n)=>g.isComplexValued(e[0])?`_SYS.catan(${n(e[0])})`:`Math.atan(${n(e[0])})`,Artanh:"Math.atanh",Ceil:"Math.ceil",Chop:"_SYS.chop",Cos:(e,n)=>g.isComplexValued(e[0])?`_SYS.ccos(${n(e[0])})`:`Math.cos(${n(e[0])})`,Cosh:(e,n)=>g.isComplexValued(e[0])?`_SYS.ccosh(${n(e[0])})`:`Math.cosh(${n(e[0])})`,Cot:([e],n)=>{if(e===null)throw new Error("Cot: no argument");return g.isComplexValued(e)?`_SYS.ccot(${n(e)})`:g.inlineExpression("Math.cos(${x}) / Math.sin(${x})",n(e))},Coth:([e],n)=>{if(e===null)throw new Error("Coth: no argument");return g.isComplexValued(e)?`_SYS.ccoth(${n(e)})`:g.inlineExpression("(Math.cosh(${x}) / Math.sinh(${x}))",n(e))},Csc:([e],n)=>{if(e===null)throw new Error("Csc: no argument");return g.isComplexValued(e)?`_SYS.ccsc(${n(e)})`:`1 / Math.sin(${n(e)})`},Csch:([e],n)=>{if(e===null)throw new Error("Csch: no argument");return g.isComplexValued(e)?`_SYS.ccsch(${n(e)})`:`1 / Math.sinh(${n(e)})`},Exp:(e,n)=>g.isComplexValued(e[0])?`_SYS.cexp(${n(e[0])})`:`Math.exp(${n(e[0])})`,Floor:"Math.floor",Fract:([e],n)=>{if(e===null)throw new Error("Fract: no argument");return g.inlineExpression("${x} - Math.floor(${x})",n(e))},Gamma:"_SYS.gamma",GCD:"_SYS.gcd",Integrate:(e,n,t)=>mf(e,n,t),LCM:"_SYS.lcm",Product:(e,n,t)=>ou("Product",e,n,t),Sum:(e,n,t)=>ou("Sum",e,n,t),Limit:(e,n)=>`_SYS.limit(${n(e[0])}, ${n(e[1])})`,Ln:(e,n)=>g.isComplexValued(e[0])?`_SYS.cln(${n(e[0])})`:`Math.log(${n(e[0])})`,List:(e,n)=>`[${e.map(t=>n(t)).join(", ")}]`,Matrix:(e,n)=>n(e[0]),Tuple:(e,n)=>`[${e.map(t=>n(t)).join(", ")}]`,Log:(e,n)=>e.length===1?`Math.log10(${n(e[0])})`:`(Math.log(${n(e[0])}) / Math.log(${n(e[1])}))`,GammaLn:"_SYS.lngamma",Lb:"Math.log2",Max:"Math.max",Mean:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.mean(${n(e[0])})`:`_SYS.mean([${e.map(t=>n(t)).join(", ")}])`,Median:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.median(${n(e[0])})`:`_SYS.median([${e.map(t=>n(t)).join(", ")}])`,Variance:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.variance(${n(e[0])})`:`_SYS.variance([${e.map(t=>n(t)).join(", ")}])`,PopulationVariance:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.populationVariance(${n(e[0])})`:`_SYS.populationVariance([${e.map(t=>n(t)).join(", ")}])`,StandardDeviation:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.standardDeviation(${n(e[0])})`:`_SYS.standardDeviation([${e.map(t=>n(t)).join(", ")}])`,PopulationStandardDeviation:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.populationStandardDeviation(${n(e[0])})`:`_SYS.populationStandardDeviation([${e.map(t=>n(t)).join(", ")}])`,Kurtosis:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.kurtosis(${n(e[0])})`:`_SYS.kurtosis([${e.map(t=>n(t)).join(", ")}])`,Skewness:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.skewness(${n(e[0])})`:`_SYS.skewness([${e.map(t=>n(t)).join(", ")}])`,Mode:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.mode(${n(e[0])})`:`_SYS.mode([${e.map(t=>n(t)).join(", ")}])`,Quartiles:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.quartiles(${n(e[0])})`:`_SYS.quartiles([${e.map(t=>n(t)).join(", ")}])`,InterquartileRange:(e,n)=>e.length===0?"NaN":e.length===1?`_SYS.interquartileRange(${n(e[0])})`:`_SYS.interquartileRange([${e.map(t=>n(t)).join(", ")}])`,Min:"Math.min",Power:(e,n)=>{let t=e[0],i=e[1];if(t===null)throw new Error("Power: no argument");if(g.isComplexValued(t)||g.isComplexValued(i))return`_SYS.cpow(${n(t)}, ${n(i)})`;let r=i.re;return r===.5?`Math.sqrt(${n(t)})`:r===1/3?`Math.cbrt(${n(t)})`:r===1?n(t):r===-1?`(1 / (${n(t)}))`:r===-.5?`(1 / Math.sqrt(${n(t)}))`:`Math.pow(${n(t)}, ${n(i)})`},Range:(e,n)=>{if(e.length===0)return"[]";if(e.length===1)return`Array.from({length: ${n(e[0])}}, (_, i) => i)`;let t=n(e[0]),i=n(e[1]),r=e[2]?n(e[2]):"1";if(t===null)throw new Error("Range: no start");if(i===null&&(i=t,t="1"),r==="0")throw new Error("Range: step cannot be zero");if(parseFloat(r)===1){let s=parseFloat(i),o=parseFloat(t);return s!==null&&o!==null?s-o<50?`[${Array.from({length:s-o+1},(a,u)=>o+u).join(", ")}]`:`Array.from({length: ${s-o+1}
|
|
44
|
+
}, (_, i) => ${t} + i)`:`Array.from({length: ${i} - ${t} + 1
|
|
45
|
+
}, (_, i) => ${t} + i)`}return`Array.from({length: Math.floor((${i} - ${t}) / ${r}) + 1}, (_, i) => ${t} + i * ${r})`},Root:([e,n],t)=>{if(e===null)throw new Error("Root: no argument");return n===null?`Math.sqrt(${t(e)})`:n?.re===2?`Math.sqrt(${t(e)})`:n?.re===3?`Math.cbrt(${t(e)})`:isNaN(n?.re)?`Math.pow(${t(e)}, 1 / (${t(n)}))`:`Math.pow(${t(e)}, ${1/n.re})`},Random:"Math.random",Round:"Math.round",Square:(e,n)=>{let t=e[0];if(t===null)throw new Error("Square: no argument");return`Math.pow(${n(t)}, 2)`},Sec:(e,n)=>{let t=e[0];if(t===null)throw new Error("Sec: no argument");return g.isComplexValued(t)?`_SYS.csec(${n(t)})`:`1 / Math.cos(${n(t)})`},Sech:(e,n)=>{let t=e[0];if(t===null)throw new Error("Sech: no argument");return g.isComplexValued(t)?`_SYS.csech(${n(t)})`:`1 / Math.cosh(${n(t)})`},Heaviside:"_SYS.heaviside",Sign:"Math.sign",Sinc:"_SYS.sinc",FresnelS:"_SYS.fresnelS",FresnelC:"_SYS.fresnelC",Sin:(e,n)=>g.isComplexValued(e[0])?`_SYS.csin(${n(e[0])})`:`Math.sin(${n(e[0])})`,Sinh:(e,n)=>g.isComplexValued(e[0])?`_SYS.csinh(${n(e[0])})`:`Math.sinh(${n(e[0])})`,Sqrt:(e,n)=>g.isComplexValued(e[0])?`_SYS.csqrt(${n(e[0])})`:`Math.sqrt(${n(e[0])})`,Tan:(e,n)=>g.isComplexValued(e[0])?`_SYS.ctan(${n(e[0])})`:`Math.tan(${n(e[0])})`,Tanh:(e,n)=>g.isComplexValued(e[0])?`_SYS.ctanh(${n(e[0])})`:`Math.tanh(${n(e[0])})`,Mod:([e,n],t)=>{if(e===null||n===null)throw new Error("Mod: missing argument");let i=t(e),r=t(n);return`((${i} % ${r}) + ${r}) % ${r}`},Truncate:"Math.trunc",Remainder:([e,n],t)=>{if(e===null||n===null)throw new Error("Remainder: missing argument");return`(${t(e)} - ${t(n)} * Math.round(${t(e)} / ${t(n)}))`},Subtract:([e,n],t)=>{if(e===null||n===null)throw new Error("Subtract: missing argument");let i=g.isComplexValued(e),r=g.isComplexValued(n);if(!i&&!r)return`(${t(e)} - ${t(n)})`;let s=t(e),o=t(n),a=i?`(${s}).re`:s,u=i?`(${s}).im`:"0",l=r?`(${o}).re`:o,c=r?`(${o}).im`:"0";return`({ re: ${a} - ${l}, im: ${u} - ${c} })`},Divide:([e,n],t)=>{if(e===null||n===null)throw new Error("Divide: missing argument");let i=g.isComplexValued(e),r=g.isComplexValued(n);return!i&&!r?`(${t(e)} / ${t(n)})`:i&&r?`(() => { const _a = ${t(e)}, _b = ${t(n)}, _d = _b.re * _b.re + _b.im * _b.im; return { re: (_a.re * _b.re + _a.im * _b.im) / _d, im: (_a.im * _b.re - _a.re * _b.im) / _d }; })()`:i&&!r?`(() => { const _a = ${t(e)}, _r = ${t(n)}; return { re: _a.re / _r, im: _a.im / _r }; })()`:`(() => { const _r = ${t(e)}, _b = ${t(n)}, _d = _b.re * _b.re + _b.im * _b.im; return { re: _r * _b.re / _d, im: -_r * _b.im / _d }; })()`},Negate:([e],n)=>{if(e===null)throw new Error("Negate: no argument");return g.isComplexValued(e)?`_SYS.cneg(${n(e)})`:`(-${n(e)})`},Multiply:(e,n)=>{if(e.length===1)return n(e[0]);if(!e.some(o=>g.isComplexValued(o)))return`(${e.map(o=>n(o)).join(" * ")})`;if(e.length===2){let o=g.isComplexValued(e[0]),a=g.isComplexValued(e[1]),u=n(e[0]),l=n(e[1]);return o&&a?`(() => { const _a = ${u}, _b = ${l}; return { re: _a.re * _b.re - _a.im * _b.im, im: _a.re * _b.im + _a.im * _b.re }; })()`:o&&!a?`(() => { const _a = ${u}, _r = ${l}; return { re: _a.re * _r, im: _a.im * _r }; })()`:`(() => { const _r = ${u}, _b = ${l}; return { re: _r * _b.re, im: _r * _b.im }; })()`}let i=[],r=[];for(let o=0;o<e.length;o++){let a=`_v${o}`;r.push(a),i.push(`const ${a} = ${n(e[o])}`)}let s=g.isComplexValued(e[0]);i.push(`let _re = ${s?`${r[0]}.re`:r[0]}`),i.push(`let _im = ${s?`${r[0]}.im`:"0"}`);for(let o=1;o<e.length;o++){let a=r[o],u=g.isComplexValued(e[o]),l=u?`${a}.re`:a,c=u?`${a}.im`:"0";i.push(`const _nre${o} = _re * ${l} - _im * ${c}`),i.push(`const _nim${o} = _re * ${c} + _im * ${l}`),i.push(`_re = _nre${o}`),i.push(`_im = _nim${o}`)}return`(() => { ${i.join("; ")}; return { re: _re, im: _im }; })()`},Factorial:"_SYS.factorial",Factorial2:"_SYS.factorial2",Exp2:([e],n)=>{if(e===null)throw new Error("Exp2: no argument");return`Math.pow(2, ${n(e)})`},Log2:"Math.log2",Log10:"Math.log10",Lg:"Math.log10",Arctan2:"Math.atan2",Hypot:"Math.hypot",Degrees:([e],n)=>{if(e===null)throw new Error("Degrees: no argument");return`(${n(e)} * Math.PI / 180)`},Haversine:([e],n)=>{if(e===null)throw new Error("Haversine: no argument");return g.inlineExpression("(1 - Math.cos(${x})) / 2",n(e))},InverseHaversine:([e],n)=>{if(e===null)throw new Error("InverseHaversine: no argument");return`(2 * Math.asin(Math.sqrt(${n(e)})))`},Erf:"_SYS.erf",Erfc:"_SYS.erfc",ErfInv:"_SYS.erfInv",Beta:"_SYS.beta",Digamma:"_SYS.digamma",Trigamma:"_SYS.trigamma",PolyGamma:(e,n)=>`_SYS.polygamma(${n(e[0])}, ${n(e[1])})`,Zeta:"_SYS.zeta",LambertW:"_SYS.lambertW",BesselJ:(e,n)=>`_SYS.besselJ(${n(e[0])}, ${n(e[1])})`,BesselY:(e,n)=>`_SYS.besselY(${n(e[0])}, ${n(e[1])})`,BesselI:(e,n)=>`_SYS.besselI(${n(e[0])}, ${n(e[1])})`,BesselK:(e,n)=>`_SYS.besselK(${n(e[0])}, ${n(e[1])})`,AiryAi:"_SYS.airyAi",AiryBi:"_SYS.airyBi",Binomial:(e,n)=>`_SYS.binomial(${n(e[0])}, ${n(e[1])})`,Fibonacci:"_SYS.fibonacci",Re:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).re`:n(e[0]),Im:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).im`:"0",Arg:(e,n)=>g.isComplexValued(e[0])?`_SYS.carg(${n(e[0])})`:`(${n(e[0])} >= 0 ? 0 : Math.PI)`,Conjugate:(e,n)=>g.isComplexValued(e[0])?`_SYS.cconj(${n(e[0])})`:n(e[0]),Color:([e],n)=>{if(e===null)throw new Error("Color: no argument");return`_SYS.color(${n(e)})`},ColorToString:(e,n)=>{if(e.length===0)throw new Error("ColorToString: no argument");return e.length>=2?`_SYS.colorToString(${n(e[0])}, ${n(e[1])})`:`_SYS.colorToString(${n(e[0])})`},ColorMix:(e,n)=>{if(e.length<2)throw new Error("ColorMix: need two colors");return e.length>=3?`_SYS.colorMix(${n(e[0])}, ${n(e[1])}, ${n(e[2])})`:`_SYS.colorMix(${n(e[0])}, ${n(e[1])})`},ColorContrast:([e,n],t)=>{if(e===null||n===null)throw new Error("ColorContrast: need two colors");return`_SYS.colorContrast(${t(e)}, ${t(n)})`},ContrastingColor:(e,n)=>{if(e.length===0)throw new Error("ContrastingColor: no argument");return e.length>=3?`_SYS.contrastingColor(${n(e[0])}, ${n(e[1])}, ${n(e[2])})`:`_SYS.contrastingColor(${n(e[0])})`},ColorToColorspace:([e,n],t)=>{if(e===null||n===null)throw new Error("ColorToColorspace: need color and space");return`_SYS.colorToColorspace(${t(e)}, ${t(n)})`},ColorFromColorspace:([e,n],t)=>{if(e===null||n===null)throw new Error("ColorFromColorspace: need components and space");return`_SYS.colorFromColorspace(${t(e)}, ${t(n)})`},Colormap:(e,n)=>{if(e.length===0)throw new Error("Colormap: no argument");return e.length>=2?`_SYS.colormap(${n(e[0])}, ${n(e[1])})`:`_SYS.colormap(${n(e[0])})`}};function G(e){return{re:e.re,im:e.im}}function qe(e){if(typeof e=="string"){let t=nt(e);return{r:t>>>24&255,g:t>>>16&255,b:t>>>8&255,alpha:(t&255)/255}}let n={r:e[0]*255,g:e[1]*255,b:e[2]*255};return e.length>=4&&(n.alpha=e[3]),n}function or(e){let n=(e>>>24&255)/255,t=(e>>>16&255)/255,i=(e>>>8&255)/255,r=(e&255)/255;return Math.abs(r-1)<1e-4?[n,t,i]:[n,t,i,r]}var cf={color(e){return or(nt(e))},colorToString(e,n){let t=qe(e),i=(n??"hex").toLowerCase();switch(i){case"hex":{let r=Math.round(Math.max(0,Math.min(255,t.r))),s=Math.round(Math.max(0,Math.min(255,t.g))),o=Math.round(Math.max(0,Math.min(255,t.b))),a=`#${r.toString(16).padStart(2,"0")}${s.toString(16).padStart(2,"0")}${o.toString(16).padStart(2,"0")}`;if(t.alpha!==void 0&&Math.abs(t.alpha-1)>1e-4){let u=Math.round(Math.max(0,Math.min(255,t.alpha*255)));a+=u.toString(16).padStart(2,"0")}return a}case"rgb":{let r=Math.round(t.r),s=Math.round(t.g),o=Math.round(t.b);return t.alpha!==void 0&&Math.abs(t.alpha-1)>1e-4?`rgb(${r} ${s} ${o} / ${t.alpha})`:`rgb(${r} ${s} ${o})`}case"hsl":{let r=Xi(t.r,t.g,t.b),s=Math.round(r.h*10)/10,o=Math.round(r.s*1e3)/10,a=Math.round(r.l*1e3)/10;return t.alpha!==void 0&&Math.abs(t.alpha-1)>1e-4?`hsl(${s} ${o}% ${a}% / ${t.alpha})`:`hsl(${s} ${o}% ${a}%)`}case"oklch":{let r=Ye(t),s=Math.round(r.L*1e3)/1e3,o=Math.round(r.C*1e3)/1e3,a=Math.round(r.H*10)/10;return t.alpha!==void 0&&Math.abs(t.alpha-1)>1e-4?`oklch(${s} ${o} ${a} / ${t.alpha})`:`oklch(${s} ${o} ${a})`}default:throw new Error(`Unknown color format: ${i}`)}},colorMix(e,n,t=.5){let i=qe(e),r=qe(n);t=Math.max(0,Math.min(1,t));let s=Ye(i),o=Ye(r),a=o.H-s.H;a>180&&(a-=360),a<-180&&(a+=360);let u=s.H+a*t;u<0&&(u+=360),u>=360&&(u-=360);let l=Mn({L:s.L+(o.L-s.L)*t,C:s.C+(o.C-s.C)*t,H:u}),c=l.r/255,p=l.g/255,m=l.b/255,d=i.alpha??1,b=r.alpha??1,v=d+(b-d)*t;return Math.abs(v-1)>1e-4?[c,p,m,v]:[c,p,m]},colorContrast(e,n){return Jt(qe(e),qe(n))},contrastingColor(e,n,t){let i=qe(e);return or(n!==void 0&&t!==void 0?Ki({bg:i,fg1:qe(n),fg2:qe(t)}):Ki(i))},colorToColorspace(e,n){let t=qe(e),i=t.alpha,r;switch(n.toLowerCase()){case"rgb":r=[t.r/255,t.g/255,t.b/255];break;case"hsl":{let s=Xi(t.r,t.g,t.b);r=[s.h,s.s,s.l];break}case"oklch":{let s=Ye(t);r=[s.L,s.C,s.H];break}case"oklab":case"lab":{let s=Qi(t);r=[s.L,s.a,s.b];break}default:throw new Error(`Unknown color space: ${n}`)}return i!==void 0&&Math.abs(i-1)>1e-4&&r.push(i),r},colormap(e,n){let i={...Ra,...$a,...Ca}[e];if(!i)throw new Error(`Unknown palette: ${e}`);let r=i.map(o=>Aa(o));if(n===void 0)return r;if(Number.isInteger(n)&&n>=2){let o=n,a=[];for(let u=0;u<o;u++){let l=o===1?0:u/(o-1);a.push(this._interpolatePalette(r,l))}return a}let s=Math.max(0,Math.min(1,n));return this._interpolatePalette(r,s)},_interpolatePalette(e,n){if(e.length===0)return[0,0,0];if(n<=0)return[...e[0]];if(n>=1)return[...e[e.length-1]];let t=n*(e.length-1),i=Math.floor(t),r=t-i;if(r===0||i>=e.length-1)return[...e[Math.min(i,e.length-1)]];let s={r:e[i][0]*255,g:e[i][1]*255,b:e[i][2]*255},o={r:e[i+1][0]*255,g:e[i+1][1]*255,b:e[i+1][2]*255},a=Ye(s),u=Ye(o),l=u.H-a.H;l>180&&(l-=360),l<-180&&(l+=360);let c=a.H+l*r;c<0&&(c+=360),c>=360&&(c-=360);let p=Mn({L:a.L+(u.L-a.L)*r,C:a.C+(u.C-a.C)*r,H:c});return[p.r/255,p.g/255,p.b/255]},colorFromColorspace(e,n){let t=e[0],i=e[1],r=e[2],s=e.length>=4?e[3]:void 0,o;switch(n.toLowerCase()){case"rgb":o=[t,i,r];break;case"hsl":{let a=Wi(t,i,r);o=[a.r/255,a.g/255,a.b/255];break}case"oklch":{let a=Mn({L:t,C:i,H:r});o=[a.r/255,a.g/255,a.b/255];break}case"oklab":case"lab":{let a=et({L:t,a:i,b:r});o=[a.r/255,a.g/255,a.b/255];break}default:throw new Error(`Unknown color space: ${n}`)}return s!==void 0&&Math.abs(s-1)>1e-4&&o.push(s),o}},au={chop:Bn,factorial:On,factorial2:Ln,gamma:te,gcd:Ne,heaviside:e=>e<0?0:e===0?.5:1,integrate:(e,n,t)=>ru(e,n,t,1e7).estimate,lcm:Ge,lngamma:Ee,limit:dt,mean:Wa,median:un,variance:tr,populationVariance:ir,standardDeviation:Xa,populationStandardDeviation:Qa,kurtosis:Ka,skewness:eu,mode:nu,quartiles:tu,interquartileRange:iu,erf:$n,erfc:tt,erfInv:Fa,beta:Oa,digamma:Gt,trigamma:jt,polygamma:er,zeta:nr,lambertW:La,besselJ:He,besselY:zt,besselI:rn,besselK:Va,airyAi:qa,airyBi:za,sinc:Ya,fresnelS:sn,fresnelC:on,binomial:an,fibonacci:cr,csin:e=>G(new $(e.re,e.im).sin()),ccos:e=>G(new $(e.re,e.im).cos()),ctan:e=>G(new $(e.re,e.im).tan()),casin:e=>G(new $(e.re,e.im).asin()),cacos:e=>G(new $(e.re,e.im).acos()),catan:e=>G(new $(e.re,e.im).atan()),csinh:e=>G(new $(e.re,e.im).sinh()),ccosh:e=>G(new $(e.re,e.im).cosh()),ctanh:e=>G(new $(e.re,e.im).tanh()),csqrt:e=>G(new $(e.re,e.im).sqrt()),cexp:e=>G(new $(e.re,e.im).exp()),cln:e=>G(new $(e.re,e.im).log()),cpow:(e,n)=>{let t=typeof e=="number"?new $(e,0):new $(e.re,e.im),i=typeof n=="number"?new $(n,0):new $(n.re,n.im);return G(t.pow(i))},ccot:e=>G(new $(e.re,e.im).cot()),csec:e=>G(new $(e.re,e.im).sec()),ccsc:e=>G(new $(e.re,e.im).csc()),ccoth:e=>G(new $(e.re,e.im).coth()),csech:e=>G(new $(e.re,e.im).sech()),ccsch:e=>G(new $(e.re,e.im).csch()),cacot:e=>G(new $(e.re,e.im).acot()),casec:e=>G(new $(e.re,e.im).asec()),cacsc:e=>G(new $(e.re,e.im).acsc()),cacoth:e=>G(new $(e.re,e.im).acoth()),casech:e=>G(new $(e.re,e.im).asech()),cacsch:e=>G(new $(e.re,e.im).acsch()),cabs:e=>new $(e.re,e.im).abs(),carg:e=>new $(e.re,e.im).arg(),cconj:e=>G(new $(e.re,e.im).conjugate()),cneg:e=>({re:-e.re,im:-e.im}),...cf},ur=class extends Function{SYS=au;constructor(n,t=""){return super("_SYS","_",t?`${t};return ${n}`:`return ${n}`),new Proxy(this,{apply:(i,r,s)=>super.apply(r,[this.SYS,...s]),get:(i,r)=>r==="toString"?()=>n:r==="isCompiled"?!0:i[r]})}},Ut=class extends Function{SYS=au;constructor(n,t){return super("_SYS",...t,`return ${n}`),new Proxy(this,{apply:(i,r,s)=>super.apply(r,[this.SYS,...s]),get:(i,r)=>r==="toString"?()=>`(${t.join(", ")}) => ${n}`:r==="isCompiled"?!0:i[r]})}},lr=class{getOperators(){return rr}getFunctions(){return sr}createTarget(n={}){return{language:"javascript",operators:t=>rr[t],functions:t=>sr[t],var:t=>({Pi:"Math.PI",ExponentialE:"Math.E",NaN:"Number.NaN",ImaginaryUnit:"({ re: 0, im: 1 })",Half:"0.5",MachineEpsilon:"Number.EPSILON",GoldenRatio:"((1 + Math.sqrt(5)) / 2)",CatalanConstant:"0.91596559417721901",EulerGamma:"0.57721566490153286"})[t],string:t=>JSON.stringify(t),number:t=>t.toString(),complex:(t,i)=>`({ re: ${t}, im: ${i} })`,indent:0,ws:t=>t??"",preamble:"",...n}}compile(n,t={}){let{operators:i,functions:r,vars:s,imports:o=[],preamble:a,realOnly:u}=t,l=n.unknowns,c=o.map(b=>{if(typeof b=="function")return b.toString();throw new Error(`Unsupported import \`${b}\``)}).join(`
|
|
46
|
+
`),p={};if(r)for(let[b,v]of Object.entries(r))typeof v=="function"?df(v)?(c+=`${v.toString()};
|
|
47
|
+
`,p[b]=v.name):(c+=`const ${b} = ${v.toString()};
|
|
48
|
+
`,p[b]=b):typeof v=="string"&&(p[b]=v);let m=b=>{if(i){let v=typeof i=="function"?i(b):i[b];if(v)return v}return rr[b]},d=this.createTarget({operators:m,functions:b=>p?.[b]?p[b]:sr[b],var:b=>{if(s&&b in s)return JSON.stringify(s[b]);let v={Pi:"Math.PI",ExponentialE:"Math.E",NaN:"Number.NaN",ImaginaryUnit:"({ re: 0, im: 1 })",Half:"0.5",MachineEpsilon:"Number.EPSILON",GoldenRatio:"((1 + Math.sqrt(5)) / 2)",CatalanConstant:"0.91596559417721901",EulerGamma:"0.57721566490153286"}[b];if(v!==void 0)return v;if(l.includes(b))return`_.${b}`},preamble:(a??"")+c});return ff(n,d,u)}};function ar(e){let n=e.run;return{...e,run:((...i)=>{let r=n(...i);return typeof r=="object"&&r!==null&&"im"in r?r.im===0?r.re:NaN:r})}}function ff(e,n,t){if(h(e,"Function")){let o=e.ops,a=o.slice(1).map(p=>_(p)?p.symbol:"_"),u=g.compile(o[0].canonical,{...n,var:p=>a.includes(p)?p:n.var(p)}),l=new Ut(u,a),c={target:"javascript",success:!0,code:`(${a.join(", ")}) => ${u}`,calling:"lambda",run:l};return t?ar(c):c}if(_(e)){let o=n.operators?.(e.symbol);if(o){let a=new Ut(`a ${o[0]} b`,["a","b"]),u={target:"javascript",success:!0,code:`(a, b) => a ${o[0]} b`,calling:"lambda",run:a};return t?ar(u):u}}let i=g.compile(e,n),r=new ur(i,n.preamble),s={target:"javascript",success:!0,code:i,calling:"expression",run:r};return t?ar(s):s}var pf=100;function uu(e){e.operator;let n=e,t=_(n.op1)?n.op1.symbol:"_",i=n.op2,r=n.op3,s=i.re,o=r.re;return{index:t,lowerExpr:i,upperExpr:r,lowerNum:!isNaN(s)&&Number.isFinite(s)?Math.floor(s):void 0,upperNum:!isNaN(o)&&Number.isFinite(o)?Math.floor(o):void 0}}function su(e,n,t){return n!==void 0?String(n):`Math.floor(${g.compile(e,t)})`}function ou(e,n,t,i){if(!n[0])throw new Error(`${e}: no body`);if(!n[1])throw new Error(`${e}: no indexing set`);let{index:r,lowerExpr:s,upperExpr:o,lowerNum:a,upperNum:u}=uu(n[1]),l=e==="Sum",c=l?"+":"*",p=l?"0":"1",m=g.isComplexValued(n[0]),d=a!==void 0&&u!==void 0;if(d&&a>u)return p;if(d&&u-a+1<=pf){let P=[];for(let U=a;U<=u;U++){let oe={...i,var:ae=>ae===r?String(U):i.var(ae)};P.push(`(${g.compile(n[0],oe)})`)}if(!m)return`(${P.join(` ${c} `)})`;let O=P.map((U,oe)=>`_t${oe}`),W=P.map((U,oe)=>`const ${O[oe]} = ${U}`).join("; ");if(l){let U=O.map(ae=>`${ae}.re`).join(" + "),oe=O.map(ae=>`${ae}.im`).join(" + ");return`(() => { ${W}; return { re: ${U}, im: ${oe} }; })()`}let j=O[0],ve=[W];for(let U=1;U<O.length;U++){let oe=j;j=`_p${U}`,ve.push(`const ${j} = { re: ${oe}.re * ${O[U]}.re - ${oe}.im * ${O[U]}.im, im: ${oe}.re * ${O[U]}.im + ${oe}.im * ${O[U]}.re }`)}return`(() => { ${ve.join("; ")}; return ${j}; })()`}let b=su(s,a,i),v=su(o,u,i),k=g.compile(n[0],{...i,var:R=>R===r?r:i.var(R)}),w=g.tempVar();if(m){let R=g.tempVar();return l?`(() => { let ${w} = { re: 0, im: 0 }; let ${r} = ${b}; const _upper = ${v}; while (${r} <= _upper) { const ${R} = ${k}; ${w} = { re: ${w}.re + ${R}.re, im: ${w}.im + ${R}.im }; ${r}++; } return ${w}; })()`:`(() => { let ${w} = { re: 1, im: 0 }; let ${r} = ${b}; const _upper = ${v}; while (${r} <= _upper) { const ${R} = ${k}; ${w} = { re: ${w}.re * ${R}.re - ${w}.im * ${R}.im, im: ${w}.re * ${R}.im + ${w}.im * ${R}.re }; ${r}++; } return ${w}; })()`}return`(() => { let ${w} = ${p}; let ${r} = ${b}; const _upper = ${v}; while (${r} <= _upper) { ${w} ${c}= ${k}; ${r}++; } return ${w}; })()`}function mf(e,n,t){let{index:i,lowerExpr:r,upperExpr:s,lowerNum:o,upperNum:a}=uu(e[1]),u=g.compile(e[0],{...t,var:p=>p===i?p:t.var(p)}),l=o!==void 0?String(o):g.compile(r,t),c=a!==void 0?String(a):g.compile(s,t);return`_SYS.integrate((${i}) => (${u}), ${l}, ${c})`}function df(e){let n=e.toString();return n.includes("=>")?!1:n.startsWith("function ")&&n.includes(e.name)}function cr(e){if(!Number.isInteger(e))return NaN;if(e<0)return e%2===0?-cr(-e):cr(-e);if(e<=1)return e;let n=0,t=1;for(let i=2;i<=e;i++){let r=n+t;n=t,t=r}return t}var lu={Add:["+",11],Negate:["-",14],Subtract:["-",11],Multiply:["*",12],Divide:["/",13],Equal:["==",8],NotEqual:["!=",8],LessEqual:["<=",9],GreaterEqual:[">=",9],Less:["<",9],Greater:[">",9],And:["&&",4],Or:["||",3],Not:["!",14]};function ze(e){return e?.language==="wgsl"?"vec2f":"vec2"}var hf=100;function cu(e,n,t,i){if(!n[0])throw new Error(`${e}: no body`);if(!n[1])throw new Error(`${e}: no indexing set`);if(g.isComplexValued(n[0]))throw new Error(`${e}: complex-valued body not supported in GPU targets`);let r=n[1];if(!h(r,"Limits"))throw new Error(`${e}: expected Limits indexing set`);let s=r.ops,o=_(s[0])?s[0].symbol:"_",a=s[1].re,u=s[2].re,l=!isNaN(a)&&Number.isFinite(a)?Math.floor(a):void 0,c=!isNaN(u)&&Number.isFinite(u)?Math.floor(u):void 0,p=e==="Sum",m=p?"+":"*",d=p?"0.0":"1.0",b=i.language==="wgsl",v=l!==void 0&&c!==void 0;if(v&&l>c)return d;if(v&&c-l+1<=hf){let ae=[];for(let ee=l;ee<=c;ee++){let Me=Zt(ee),we={...i,var:lt=>lt===o?Me:i.var(lt)};ae.push(`(${g.compile(n[0],we)})`)}return`(${ae.join(` ${m} `)})`}let k=g.tempVar(),w=b?"f32":"float",R=b?"i32":"int",P={...i,var:ae=>ae===o?b?`f32(${o})`:`float(${o})`:i.var(ae)},O=g.compile(n[0],P),W=l!==void 0?String(l):g.compile(s[1],i),j=c!==void 0?String(c):g.compile(s[2],i),ve=b?`var ${k}: ${w}`:`${w} ${k}`,U=b?`var ${o}: ${R}`:`${R} ${o}`;return[`${ve} = ${d};`,`for (${U} = ${W}; ${o} <= ${j}; ${o}++) {`,` ${k} ${m}= ${O};`,"}",`return ${k}`].join(`
|
|
49
|
+
`)}var gf={Add:(e,n,t)=>{if(e.length===0)return"0.0";if(e.length===1)return n(e[0]);if(!e.some(s=>g.isComplexValued(s)))return e.map(s=>n(s)).join(" + ");let r=ze(t);return e.map(s=>{let o=n(s);return g.isComplexValued(s)?o:`${r}(${o}, 0.0)`}).join(" + ")},Multiply:(e,n,t)=>{if(e.length===0)return"1.0";if(e.length===1)return n(e[0]);if(!e.some(o=>g.isComplexValued(o)))return e.map(o=>n(o)).join(" * ");let r=n(e[0]),s=g.isComplexValued(e[0]);for(let o=1;o<e.length;o++){let a=n(e[o]),u=g.isComplexValued(e[o]);!s&&!u?r=`(${r} * ${a})`:s&&!u?r=`(${a} * ${r})`:!s&&u?(r=`(${r} * ${a})`,s=!0):r=`_gpu_cmul(${r}, ${a})`}return r},Subtract:(e,n,t)=>{if(e.length===0)return"0.0";if(e.length===1)return n(e[0]);if(!e.some(a=>g.isComplexValued(a))){if(e.length===2)return`${n(e[0])} - ${n(e[1])}`;let a=n(e[0]);for(let u=1;u<e.length;u++)a=`${a} - ${n(e[u])}`;return a}let r=ze(t),s=a=>{let u=n(a);return g.isComplexValued(a)?u:`${r}(${u}, 0.0)`};if(e.length===2)return`${s(e[0])} - ${s(e[1])}`;let o=s(e[0]);for(let a=1;a<e.length;a++)o=`${o} - ${s(e[a])}`;return o},Divide:(e,n,t)=>{if(e.length===0)return"1.0";if(e.length===1)return n(e[0]);let i=g.isComplexValued(e[0]),r=e.length>=2&&g.isComplexValued(e[1]);if(!i&&!r){if(e.length===2)return`${n(e[0])} / ${n(e[1])}`;let o=n(e[0]);for(let a=1;a<e.length;a++)o=`${o} / ${n(e[a])}`;return o}return i&&r?`_gpu_cdiv(${n(e[0])}, ${n(e[1])})`:i&&!r?`(${n(e[0])} / ${n(e[1])})`:`_gpu_cdiv(${ze(t)}(${n(e[0])}, 0.0), ${n(e[1])})`},Negate:([e],n)=>{if(e===null)throw new Error("Negate: no argument");return`(-${n(e)})`},Abs:(e,n)=>g.isComplexValued(e[0])?`length(${n(e[0])})`:`abs(${n(e[0])})`,Arccos:(e,n)=>g.isComplexValued(e[0])?`_gpu_cacos(${n(e[0])})`:`acos(${n(e[0])})`,Arcsin:(e,n)=>g.isComplexValued(e[0])?`_gpu_casin(${n(e[0])})`:`asin(${n(e[0])})`,Arctan:(e,n)=>g.isComplexValued(e[0])?`_gpu_catan(${n(e[0])})`:`atan(${n(e[0])})`,Ceil:"ceil",Clamp:"clamp",Cos:(e,n)=>g.isComplexValued(e[0])?`_gpu_ccos(${n(e[0])})`:`cos(${n(e[0])})`,Degrees:"degrees",Exp:(e,n)=>g.isComplexValued(e[0])?`_gpu_cexp(${n(e[0])})`:`exp(${n(e[0])})`,Exp2:"exp2",Floor:"floor",Fract:"fract",Ln:(e,n)=>g.isComplexValued(e[0])?`_gpu_cln(${n(e[0])})`:`log(${n(e[0])})`,Log2:"log2",Max:"max",Min:"min",Mix:"mix",Power:(e,n,t)=>{let i=e[0],r=e[1];if(i===null)throw new Error("Power: no argument");if(g.isComplexValued(i)||g.isComplexValued(r)){if(_(i,"ExponentialE"))return`_gpu_cexp(${n(r)})`;let s=ze(t),o=g.isComplexValued(i)?n(i):`${s}(${n(i)}, 0.0)`,a=g.isComplexValued(r)?n(r):`${s}(${n(r)}, 0.0)`;return`_gpu_cpow(${o}, ${a})`}return`pow(${n(i)}, ${n(r)})`},Radians:"radians",Round:"round",Sign:"sign",Sin:(e,n)=>g.isComplexValued(e[0])?`_gpu_csin(${n(e[0])})`:`sin(${n(e[0])})`,Smoothstep:"smoothstep",Sqrt:(e,n)=>g.isComplexValued(e[0])?`_gpu_csqrt(${n(e[0])})`:`sqrt(${n(e[0])})`,Step:"step",Tan:(e,n)=>g.isComplexValued(e[0])?`_gpu_ctan(${n(e[0])})`:`tan(${n(e[0])})`,Truncate:"trunc",Re:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).x`:n(e[0]),Im:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).y`:"0.0",Arg:(e,n)=>{if(g.isComplexValued(e[0])){let t=n(e[0]);return`atan(${t}.y, ${t}.x)`}return`(${n(e[0])} >= 0.0 ? 0.0 : 3.14159265359)`},Conjugate:(e,n,t)=>{if(g.isComplexValued(e[0])){let i=ze(t),r=n(e[0]);return`${i}(${r}.x, -${r}.y)`}return n(e[0])},Remainder:([e,n],t)=>{if(e===null||n===null)throw new Error("Remainder: missing argument");return`(${t(e)} - ${t(n)} * round(${t(e)} / ${t(n)}))`},Cot:([e],n)=>{if(e===null)throw new Error("Cot: no argument");if(g.isComplexValued(e))return`_gpu_cdiv(_gpu_ccos(${n(e)}), _gpu_csin(${n(e)}))`;let t=n(e);return`(cos(${t}) / sin(${t}))`},Csc:([e],n,t)=>{if(e===null)throw new Error("Csc: no argument");return g.isComplexValued(e)?`_gpu_cdiv(${ze(t)}(1.0, 0.0), _gpu_csin(${n(e)}))`:`(1.0 / sin(${n(e)}))`},Sec:([e],n,t)=>{if(e===null)throw new Error("Sec: no argument");return g.isComplexValued(e)?`_gpu_cdiv(${ze(t)}(1.0, 0.0), _gpu_ccos(${n(e)}))`:`(1.0 / cos(${n(e)}))`},Arccot:([e],n)=>{if(e===null)throw new Error("Arccot: no argument");return`atan(1.0 / (${n(e)}))`},Arccsc:([e],n)=>{if(e===null)throw new Error("Arccsc: no argument");return`asin(1.0 / (${n(e)}))`},Arcsec:([e],n)=>{if(e===null)throw new Error("Arcsec: no argument");return`acos(1.0 / (${n(e)}))`},Sinh:(e,n)=>g.isComplexValued(e[0])?`_gpu_csinh(${n(e[0])})`:`sinh(${n(e[0])})`,Cosh:(e,n)=>g.isComplexValued(e[0])?`_gpu_ccosh(${n(e[0])})`:`cosh(${n(e[0])})`,Tanh:(e,n)=>g.isComplexValued(e[0])?`_gpu_ctanh(${n(e[0])})`:`tanh(${n(e[0])})`,Coth:([e],n)=>{if(e===null)throw new Error("Coth: no argument");if(g.isComplexValued(e))return`_gpu_cdiv(_gpu_ccosh(${n(e)}), _gpu_csinh(${n(e)}))`;let t=n(e);return`(cosh(${t}) / sinh(${t}))`},Csch:([e],n,t)=>{if(e===null)throw new Error("Csch: no argument");return g.isComplexValued(e)?`_gpu_cdiv(${ze(t)}(1.0, 0.0), _gpu_csinh(${n(e)}))`:`(1.0 / sinh(${n(e)}))`},Sech:([e],n,t)=>{if(e===null)throw new Error("Sech: no argument");return g.isComplexValued(e)?`_gpu_cdiv(${ze(t)}(1.0, 0.0), _gpu_ccosh(${n(e)}))`:`(1.0 / cosh(${n(e)}))`},Arcosh:(e,n)=>g.isComplexValued(e[0])?`_gpu_cacosh(${n(e[0])})`:`acosh(${n(e[0])})`,Arsinh:(e,n)=>g.isComplexValued(e[0])?`_gpu_casinh(${n(e[0])})`:`asinh(${n(e[0])})`,Artanh:(e,n)=>g.isComplexValued(e[0])?`_gpu_catanh(${n(e[0])})`:`atanh(${n(e[0])})`,Arcoth:([e],n)=>{if(e===null)throw new Error("Arcoth: no argument");return`atanh(1.0 / (${n(e)}))`},Arcsch:([e],n)=>{if(e===null)throw new Error("Arcsch: no argument");return`asinh(1.0 / (${n(e)}))`},Arsech:([e],n)=>{if(e===null)throw new Error("Arsech: no argument");return`acosh(1.0 / (${n(e)}))`},Arctan2:(e,n)=>{if(e.length<2)throw new Error("Arctan2: need two arguments");return`atan(${n(e[0])}, ${n(e[1])})`},Hypot:([e,n],t)=>{if(e===null||n===null)throw new Error("Hypot: need two arguments");return`length(vec2(${t(e)}, ${t(n)}))`},Haversine:([e],n)=>{if(e===null)throw new Error("Haversine: no argument");return`((1.0 - cos(${n(e)})) * 0.5)`},InverseHaversine:([e],n)=>{if(e===null)throw new Error("InverseHaversine: no argument");return`(2.0 * asin(sqrt(${n(e)})))`},Gamma:([e],n)=>{if(e===null)throw new Error("Gamma: no argument");return`_gpu_gamma(${n(e)})`},GammaLn:([e],n)=>{if(e===null)throw new Error("GammaLn: no argument");return`_gpu_gammaln(${n(e)})`},Factorial:([e],n)=>{if(e===null)throw new Error("Factorial: no argument");return`_gpu_gamma(${n(e)} + 1.0)`},Beta:([e,n],t)=>{if(e===null||n===null)throw new Error("Beta: need two arguments");let i=t(e),r=t(n);return`(_gpu_gamma(${i}) * _gpu_gamma(${r}) / _gpu_gamma(${i} + ${r}))`},Erf:([e],n)=>{if(e===null)throw new Error("Erf: no argument");return`_gpu_erf(${n(e)})`},Erfc:([e],n)=>{if(e===null)throw new Error("Erfc: no argument");return`(1.0 - _gpu_erf(${n(e)}))`},ErfInv:([e],n)=>{if(e===null)throw new Error("ErfInv: no argument");return`_gpu_erfinv(${n(e)})`},Heaviside:([e],n)=>{if(e===null)throw new Error("Heaviside: no argument");return`_gpu_heaviside(${n(e)})`},Sinc:([e],n)=>{if(e===null)throw new Error("Sinc: no argument");return`_gpu_sinc(${n(e)})`},FresnelC:([e],n)=>{if(e===null)throw new Error("FresnelC: no argument");return`_gpu_fresnelC(${n(e)})`},FresnelS:([e],n)=>{if(e===null)throw new Error("FresnelS: no argument");return`_gpu_fresnelS(${n(e)})`},BesselJ:([e,n],t,i)=>{if(e===null||n===null)throw new Error("BesselJ: need two arguments");return`_gpu_besselJ(${i?.language==="wgsl"?"i32":"int"}(${t(e)}), ${t(n)})`},Lb:"log2",Log:(e,n)=>{if(e.length===0)throw new Error("Log: no argument");return e.length===1?`(log(${n(e[0])}) / log(10.0))`:`(log(${n(e[0])}) / log(${n(e[1])}))`},Log10:([e],n)=>{if(e===null)throw new Error("Log10: no argument");return`(log(${n(e)}) * 0.4342944819032518)`},Lg:([e],n)=>{if(e===null)throw new Error("Lg: no argument");return`(log(${n(e)}) * 0.4342944819032518)`},Square:([e],n)=>{if(e===null)throw new Error("Square: no argument");let t=n(e);return`(${t} * ${t})`},Root:([e,n],t)=>{if(e===null)throw new Error("Root: no argument");return n==null?`sqrt(${t(e)})`:n?.re===2?`sqrt(${t(e)})`:`pow(${t(e)}, 1.0 / ${t(n)})`},ColorMix:(e,n)=>{if(e.length<2)throw new Error("ColorMix: need two colors");let t=n(e[0]),i=n(e[1]),r=e.length>=3?n(e[2]):"0.5";return`_gpu_color_mix(${t}, ${i}, ${r})`},ColorContrast:([e,n],t)=>{if(e===null||n===null)throw new Error("ColorContrast: need two colors");return`_gpu_apca(${t(e)}, ${t(n)})`},ContrastingColor:(e,n,t)=>{if(e.length===0)throw new Error("ContrastingColor: no argument");let i=n(e[0]);if(e.length>=3){let o=n(e[1]),a=n(e[2]);return`(abs(_gpu_apca(${i}, ${o})) >= abs(_gpu_apca(${i}, ${a})) ? ${o} : ${a})`}let s=t?.language==="wgsl"?"vec3f":"vec3";return`((_gpu_apca(${i}, ${s}(0.0)) > 50.0) ? ${s}(0.0) : ${s}(1.0))`},ColorToColorspace:([e,n],t)=>{if(e===null||n===null)throw new Error("ColorToColorspace: need color and space");return`_gpu_srgb_to_oklab(${t(e)})`},ColorFromColorspace:([e,n],t)=>{if(e===null||n===null)throw new Error("ColorFromColorspace: need components and space");return`_gpu_oklab_to_srgb(${t(e)})`},Mandelbrot:([e,n],t,i)=>{if(e===null||n===null)throw new Error("Mandelbrot: missing arguments");let r=i?.language==="wgsl"?"i32":"int";return`_fractal_mandelbrot(${t(e)}, ${r}(${t(n)}))`},Julia:([e,n,t],i,r)=>{if(e===null||n===null||t===null)throw new Error("Julia: missing arguments");let s=r?.language==="wgsl"?"i32":"int";return`_fractal_julia(${i(e)}, ${i(n)}, ${s}(${i(t)}))`},Cross:"cross",Distance:"distance",Dot:"dot",Length:"length",Normalize:"normalize",Reflect:"reflect",Refract:"refract",Sum:(e,n,t)=>cu("Sum",e,n,t),Product:(e,n,t)=>cu("Product",e,n,t),Loop:(e,n,t)=>{if(!e[0])throw new Error("Loop: no body");if(!e[1])throw new Error("Loop: no indexing set");let i=e[1];if(!h(i,"Element"))throw new Error("Loop: expected Element(index, Range(lo, hi))");let r=i.ops[0],s=i.ops[1];if(!_(r))throw new Error("Loop: index must be a symbol");if(!h(s,"Range"))throw new Error("Loop: expected Range(lo, hi)");let o=r.symbol,a=Math.floor(s.ops[0].re),u=Math.floor(s.ops[1].re);if(!Number.isFinite(a)||!Number.isFinite(u))throw new Error("Loop: bounds must be finite numbers");let l=t.language==="wgsl",c=l?"i32":"int",p=g.compile(e[0],{...t,var:d=>d===o?o:t.var(d)});return`for (${l?`var ${o}: ${c}`:`${c} ${o}`} = ${a}; ${o} <= ${u}; ${o}++) {
|
|
50
|
+
${p};
|
|
51
|
+
}`},Function:()=>{throw new Error("Anonymous functions (Function) are not supported in GPU targets")}};function Yt(e,n,t,i,r){let s=e[0];if(!h(s))return n(s);let o=s.ops;if(o.length===0)return n(s);let a=o.length,u=o[0],l=h(u)?u.nops:0;if(l===1&&o.every(c=>h(c)&&c.nops===1)){let c=o.map(p=>n(h(p)?p.ops[0]:p));return a>=2&&a<=4?`${t(a)}(${c.join(", ")})`:`${r(a)}(${c.join(", ")})`}if(a===l&&a>=2&&a<=4&&o.every(c=>h(c)&&c.nops===l)){let c=[];for(let p=0;p<l;p++){let m=o.map(d=>n(h(d)?d.ops[p]:d));c.push(`${t(a)}(${m.join(", ")})`)}return`${i(a)}(${c.join(", ")})`}return n(s)}var bf=`
|
|
52
|
+
float _gpu_gamma(float z) {
|
|
53
|
+
const float PI = 3.14159265358979;
|
|
54
|
+
// For z < 0.5, use reflection formula with inlined Lanczos (non-recursive)
|
|
55
|
+
float w = z;
|
|
56
|
+
if (z < 0.5) w = 1.0 - z;
|
|
57
|
+
w -= 1.0;
|
|
58
|
+
float x = 0.99999999999980993;
|
|
59
|
+
x += 676.5203681218851 / (w + 1.0);
|
|
60
|
+
x += -1259.1392167224028 / (w + 2.0);
|
|
61
|
+
x += 771.32342877765313 / (w + 3.0);
|
|
62
|
+
x += -176.61502916214059 / (w + 4.0);
|
|
63
|
+
x += 12.507343278686905 / (w + 5.0);
|
|
64
|
+
x += -0.13857109526572012 / (w + 6.0);
|
|
65
|
+
x += 9.9843695780195716e-6 / (w + 7.0);
|
|
66
|
+
x += 1.5056327351493116e-7 / (w + 8.0);
|
|
67
|
+
float t = w + 7.5;
|
|
68
|
+
float g = sqrt(2.0 * PI) * pow(t, w + 0.5) * exp(-t) * x;
|
|
69
|
+
if (z < 0.5) return PI / (sin(PI * z) * g);
|
|
70
|
+
return g;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
float _gpu_gammaln(float z) {
|
|
74
|
+
// Stirling asymptotic expansion for ln(Gamma(z)), z > 0
|
|
75
|
+
float z3 = z * z * z;
|
|
76
|
+
return z * log(z) - z - 0.5 * log(z)
|
|
77
|
+
+ 0.5 * log(2.0 * 3.14159265358979)
|
|
78
|
+
+ 1.0 / (12.0 * z)
|
|
79
|
+
- 1.0 / (360.0 * z3)
|
|
80
|
+
+ 1.0 / (1260.0 * z3 * z * z);
|
|
81
|
+
}
|
|
82
|
+
`,yf=`
|
|
83
|
+
float _gpu_erf(float x) {
|
|
84
|
+
float ax = abs(x);
|
|
85
|
+
float t = 1.0 / (1.0 + 0.3275911 * ax);
|
|
86
|
+
float y = ((((1.061405429 * t - 1.453152027) * t + 1.421413741) * t - 0.284496736) * t + 0.254829592) * t;
|
|
87
|
+
float result = 1.0 - y * exp(-ax * ax);
|
|
88
|
+
return x < 0.0 ? -result : result;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
float _gpu_erfinv(float x) {
|
|
92
|
+
float pi = 3.14159265358979;
|
|
93
|
+
float x2 = x * x;
|
|
94
|
+
float x3 = x * x2;
|
|
95
|
+
float x5 = x3 * x2;
|
|
96
|
+
float x7 = x5 * x2;
|
|
97
|
+
float x9 = x7 * x2;
|
|
98
|
+
return sqrt(pi) * 0.5 * (x + (pi / 12.0) * x3 + (7.0 * pi * pi / 480.0) * x5 + (127.0 * pi * pi * pi / 40320.0) * x7 + (4369.0 * pi * pi * pi * pi / 5806080.0) * x9);
|
|
99
|
+
}
|
|
100
|
+
`,xf=`
|
|
101
|
+
float _gpu_heaviside(float x) {
|
|
102
|
+
if (x < 0.0) return 0.0;
|
|
103
|
+
if (x > 0.0) return 1.0;
|
|
104
|
+
return 0.5;
|
|
105
|
+
}
|
|
106
|
+
`,Ef=`
|
|
107
|
+
fn _gpu_heaviside(x: f32) -> f32 {
|
|
108
|
+
if (x < 0.0) { return 0.0; }
|
|
109
|
+
if (x > 0.0) { return 1.0; }
|
|
110
|
+
return 0.5;
|
|
111
|
+
}
|
|
112
|
+
`,vf=`
|
|
113
|
+
float _gpu_sinc(float x) {
|
|
114
|
+
if (abs(x) < 1e-10) return 1.0;
|
|
115
|
+
return sin(x) / x;
|
|
116
|
+
}
|
|
117
|
+
`,Nf=`
|
|
118
|
+
fn _gpu_sinc(x: f32) -> f32 {
|
|
119
|
+
if (abs(x) < 1e-10) { return 1.0; }
|
|
120
|
+
return sin(x) / x;
|
|
121
|
+
}
|
|
122
|
+
`,Tf=`
|
|
123
|
+
float _gpu_polevl(float x, float c[12], int n) {
|
|
124
|
+
float ans = c[0];
|
|
125
|
+
for (int i = 1; i < n; i++) ans = ans * x + c[i];
|
|
126
|
+
return ans;
|
|
127
|
+
}
|
|
128
|
+
`,If=`
|
|
129
|
+
fn _gpu_polevl(x: f32, c: array<f32, 12>, n: i32) -> f32 {
|
|
130
|
+
var ans = c[0];
|
|
131
|
+
for (var i: i32 = 1; i < n; i++) { ans = ans * x + c[i]; }
|
|
132
|
+
return ans;
|
|
133
|
+
}
|
|
134
|
+
`,kf=`
|
|
135
|
+
float _gpu_fresnelC(float x_in) {
|
|
136
|
+
float sgn = x_in < 0.0 ? -1.0 : 1.0;
|
|
137
|
+
float x = abs(x_in);
|
|
138
|
+
|
|
139
|
+
if (x < 1.6) {
|
|
140
|
+
float x2 = x * x;
|
|
141
|
+
float t = x2 * x2;
|
|
142
|
+
float cn[6] = float[6](
|
|
143
|
+
-4.98843114573573548651e-8, 9.50428062829859605134e-6,
|
|
144
|
+
-6.45191435683965050962e-4, 1.88843319396703850064e-2,
|
|
145
|
+
-2.05525900955013891793e-1, 9.99999999999999998822e-1
|
|
146
|
+
);
|
|
147
|
+
float cd[7] = float[7](
|
|
148
|
+
3.99982968972495980367e-12, 9.15439215774657478799e-10,
|
|
149
|
+
1.25001862479598821474e-7, 1.22262789024179030997e-5,
|
|
150
|
+
8.68029542941784300606e-4, 4.12142090722199792936e-2, 1.0
|
|
151
|
+
);
|
|
152
|
+
return sgn * x * _gpu_polevl(t, cn, 6) / _gpu_polevl(t, cd, 7);
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
if (x < 36.0) {
|
|
156
|
+
float x2 = x * x;
|
|
157
|
+
float t = 3.14159265358979 * x2;
|
|
158
|
+
float u = 1.0 / (t * t);
|
|
159
|
+
float fn[10] = float[10](
|
|
160
|
+
4.21543555043677546506e-1, 1.43407919780758885261e-1,
|
|
161
|
+
1.15220955073585758835e-2, 3.450179397825740279e-4,
|
|
162
|
+
4.63613749287867322088e-6, 3.05568983790257605827e-8,
|
|
163
|
+
1.02304514164907233465e-10, 1.72010743268161828879e-13,
|
|
164
|
+
1.34283276233062758925e-16, 3.76329711269987889006e-20
|
|
165
|
+
);
|
|
166
|
+
float fd[11] = float[11](
|
|
167
|
+
1.0, 7.51586398353378947175e-1,
|
|
168
|
+
1.16888925859191382142e-1, 6.44051526508858611005e-3,
|
|
169
|
+
1.55934409164153020873e-4, 1.8462756734893054587e-6,
|
|
170
|
+
1.12699224763999035261e-8, 3.60140029589371370404e-11,
|
|
171
|
+
5.8875453362157841001e-14, 4.52001434074129701496e-17,
|
|
172
|
+
1.25443237090011264384e-20
|
|
173
|
+
);
|
|
174
|
+
float gn[11] = float[11](
|
|
175
|
+
5.04442073643383265887e-1, 1.97102833525523411709e-1,
|
|
176
|
+
1.87648584092575249293e-2, 6.84079380915393090172e-4,
|
|
177
|
+
1.15138826111884280931e-5, 9.82852443688422223854e-8,
|
|
178
|
+
4.45344415861750144738e-10, 1.08268041139020870318e-12,
|
|
179
|
+
1.37555460633261799868e-15, 8.36354435630677421531e-19,
|
|
180
|
+
1.86958710162783235106e-22
|
|
181
|
+
);
|
|
182
|
+
float gd[12] = float[12](
|
|
183
|
+
1.0, 1.47495759925128324529,
|
|
184
|
+
3.37748989120019970451e-1, 2.53603741420338795122e-2,
|
|
185
|
+
8.14679107184306179049e-4, 1.27545075667729118702e-5,
|
|
186
|
+
1.04314589657571990585e-7, 4.60680728515232032307e-10,
|
|
187
|
+
1.10273215066240270757e-12, 1.38796531259578871258e-15,
|
|
188
|
+
8.39158816283118707363e-19, 1.86958710162783236342e-22
|
|
189
|
+
);
|
|
190
|
+
float f = 1.0 - u * _gpu_polevl(u, fn, 10) / _gpu_polevl(u, fd, 11);
|
|
191
|
+
float g = (1.0 / t) * _gpu_polevl(u, gn, 11) / _gpu_polevl(u, gd, 12);
|
|
192
|
+
float z = 1.5707963267948966 * x2;
|
|
193
|
+
float c = cos(z);
|
|
194
|
+
float s = sin(z);
|
|
195
|
+
return sgn * (0.5 + (f * s - g * c) / (3.14159265358979 * x));
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
return sgn * 0.5;
|
|
199
|
+
}
|
|
200
|
+
`,Sf=`
|
|
201
|
+
fn _gpu_fresnelC(x_in: f32) -> f32 {
|
|
202
|
+
let sgn: f32 = select(1.0, -1.0, x_in < 0.0);
|
|
203
|
+
let x = abs(x_in);
|
|
204
|
+
|
|
205
|
+
if (x < 1.6) {
|
|
206
|
+
let x2 = x * x;
|
|
207
|
+
let t = x2 * x2;
|
|
208
|
+
var cn = array<f32, 12>(
|
|
209
|
+
-4.98843114573573548651e-8, 9.50428062829859605134e-6,
|
|
210
|
+
-6.45191435683965050962e-4, 1.88843319396703850064e-2,
|
|
211
|
+
-2.05525900955013891793e-1, 9.99999999999999998822e-1,
|
|
212
|
+
0.0, 0.0, 0.0, 0.0, 0.0, 0.0
|
|
213
|
+
);
|
|
214
|
+
var cd = array<f32, 12>(
|
|
215
|
+
3.99982968972495980367e-12, 9.15439215774657478799e-10,
|
|
216
|
+
1.25001862479598821474e-7, 1.22262789024179030997e-5,
|
|
217
|
+
8.68029542941784300606e-4, 4.12142090722199792936e-2, 1.0,
|
|
218
|
+
0.0, 0.0, 0.0, 0.0, 0.0
|
|
219
|
+
);
|
|
220
|
+
return sgn * x * _gpu_polevl(t, cn, 6) / _gpu_polevl(t, cd, 7);
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
if (x < 36.0) {
|
|
224
|
+
let x2 = x * x;
|
|
225
|
+
let t = 3.14159265358979 * x2;
|
|
226
|
+
let u = 1.0 / (t * t);
|
|
227
|
+
var fn = array<f32, 12>(
|
|
228
|
+
4.21543555043677546506e-1, 1.43407919780758885261e-1,
|
|
229
|
+
1.15220955073585758835e-2, 3.450179397825740279e-4,
|
|
230
|
+
4.63613749287867322088e-6, 3.05568983790257605827e-8,
|
|
231
|
+
1.02304514164907233465e-10, 1.72010743268161828879e-13,
|
|
232
|
+
1.34283276233062758925e-16, 3.76329711269987889006e-20,
|
|
233
|
+
0.0, 0.0
|
|
234
|
+
);
|
|
235
|
+
var fd = array<f32, 12>(
|
|
236
|
+
1.0, 7.51586398353378947175e-1,
|
|
237
|
+
1.16888925859191382142e-1, 6.44051526508858611005e-3,
|
|
238
|
+
1.55934409164153020873e-4, 1.8462756734893054587e-6,
|
|
239
|
+
1.12699224763999035261e-8, 3.60140029589371370404e-11,
|
|
240
|
+
5.8875453362157841001e-14, 4.52001434074129701496e-17,
|
|
241
|
+
1.25443237090011264384e-20, 0.0
|
|
242
|
+
);
|
|
243
|
+
var gn = array<f32, 12>(
|
|
244
|
+
5.04442073643383265887e-1, 1.97102833525523411709e-1,
|
|
245
|
+
1.87648584092575249293e-2, 6.84079380915393090172e-4,
|
|
246
|
+
1.15138826111884280931e-5, 9.82852443688422223854e-8,
|
|
247
|
+
4.45344415861750144738e-10, 1.08268041139020870318e-12,
|
|
248
|
+
1.37555460633261799868e-15, 8.36354435630677421531e-19,
|
|
249
|
+
1.86958710162783235106e-22, 0.0
|
|
250
|
+
);
|
|
251
|
+
var gd = array<f32, 12>(
|
|
252
|
+
1.0, 1.47495759925128324529,
|
|
253
|
+
3.37748989120019970451e-1, 2.53603741420338795122e-2,
|
|
254
|
+
8.14679107184306179049e-4, 1.27545075667729118702e-5,
|
|
255
|
+
1.04314589657571990585e-7, 4.60680728515232032307e-10,
|
|
256
|
+
1.10273215066240270757e-12, 1.38796531259578871258e-15,
|
|
257
|
+
8.39158816283118707363e-19, 1.86958710162783236342e-22
|
|
258
|
+
);
|
|
259
|
+
let f = 1.0 - u * _gpu_polevl(u, fn, 10) / _gpu_polevl(u, fd, 11);
|
|
260
|
+
let g = (1.0 / t) * _gpu_polevl(u, gn, 11) / _gpu_polevl(u, gd, 12);
|
|
261
|
+
let z = 1.5707963267948966 * x2;
|
|
262
|
+
let c = cos(z);
|
|
263
|
+
let s = sin(z);
|
|
264
|
+
return sgn * (0.5 + (f * s - g * c) / (3.14159265358979 * x));
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
return sgn * 0.5;
|
|
268
|
+
}
|
|
269
|
+
`,_f=`
|
|
270
|
+
float _gpu_fresnelS(float x_in) {
|
|
271
|
+
float sgn = x_in < 0.0 ? -1.0 : 1.0;
|
|
272
|
+
float x = abs(x_in);
|
|
273
|
+
|
|
274
|
+
if (x < 1.6) {
|
|
275
|
+
float x2 = x * x;
|
|
276
|
+
float t = x2 * x2;
|
|
277
|
+
float sn[6] = float[6](
|
|
278
|
+
-2.99181919401019853726e3, 7.08840045257738576863e5,
|
|
279
|
+
-6.29741486205862506537e7, 2.54890880573376359104e9,
|
|
280
|
+
-4.42979518059697779103e10, 3.18016297876567817986e11
|
|
281
|
+
);
|
|
282
|
+
float sd[7] = float[7](
|
|
283
|
+
1.0, 2.81376268889994315696e2, 4.55847810806532581675e4,
|
|
284
|
+
5.1734388877009640073e6, 4.19320245898111231129e8, 2.2441179564534092094e10,
|
|
285
|
+
6.07366389490084914091e11
|
|
286
|
+
);
|
|
287
|
+
return sgn * x * x2 * _gpu_polevl(t, sn, 6) / _gpu_polevl(t, sd, 7);
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
if (x < 36.0) {
|
|
291
|
+
float x2 = x * x;
|
|
292
|
+
float t = 3.14159265358979 * x2;
|
|
293
|
+
float u = 1.0 / (t * t);
|
|
294
|
+
float fn[10] = float[10](
|
|
295
|
+
4.21543555043677546506e-1, 1.43407919780758885261e-1,
|
|
296
|
+
1.15220955073585758835e-2, 3.450179397825740279e-4,
|
|
297
|
+
4.63613749287867322088e-6, 3.05568983790257605827e-8,
|
|
298
|
+
1.02304514164907233465e-10, 1.72010743268161828879e-13,
|
|
299
|
+
1.34283276233062758925e-16, 3.76329711269987889006e-20
|
|
300
|
+
);
|
|
301
|
+
float fd[11] = float[11](
|
|
302
|
+
1.0, 7.51586398353378947175e-1,
|
|
303
|
+
1.16888925859191382142e-1, 6.44051526508858611005e-3,
|
|
304
|
+
1.55934409164153020873e-4, 1.8462756734893054587e-6,
|
|
305
|
+
1.12699224763999035261e-8, 3.60140029589371370404e-11,
|
|
306
|
+
5.8875453362157841001e-14, 4.52001434074129701496e-17,
|
|
307
|
+
1.25443237090011264384e-20
|
|
308
|
+
);
|
|
309
|
+
float gn[11] = float[11](
|
|
310
|
+
5.04442073643383265887e-1, 1.97102833525523411709e-1,
|
|
311
|
+
1.87648584092575249293e-2, 6.84079380915393090172e-4,
|
|
312
|
+
1.15138826111884280931e-5, 9.82852443688422223854e-8,
|
|
313
|
+
4.45344415861750144738e-10, 1.08268041139020870318e-12,
|
|
314
|
+
1.37555460633261799868e-15, 8.36354435630677421531e-19,
|
|
315
|
+
1.86958710162783235106e-22
|
|
316
|
+
);
|
|
317
|
+
float gd[12] = float[12](
|
|
318
|
+
1.0, 1.47495759925128324529,
|
|
319
|
+
3.37748989120019970451e-1, 2.53603741420338795122e-2,
|
|
320
|
+
8.14679107184306179049e-4, 1.27545075667729118702e-5,
|
|
321
|
+
1.04314589657571990585e-7, 4.60680728515232032307e-10,
|
|
322
|
+
1.10273215066240270757e-12, 1.38796531259578871258e-15,
|
|
323
|
+
8.39158816283118707363e-19, 1.86958710162783236342e-22
|
|
324
|
+
);
|
|
325
|
+
float f = 1.0 - u * _gpu_polevl(u, fn, 10) / _gpu_polevl(u, fd, 11);
|
|
326
|
+
float g = (1.0 / t) * _gpu_polevl(u, gn, 11) / _gpu_polevl(u, gd, 12);
|
|
327
|
+
float z = 1.5707963267948966 * x2;
|
|
328
|
+
float c = cos(z);
|
|
329
|
+
float s = sin(z);
|
|
330
|
+
return sgn * (0.5 - (f * c + g * s) / (3.14159265358979 * x));
|
|
331
|
+
}
|
|
332
|
+
|
|
333
|
+
return sgn * 0.5;
|
|
334
|
+
}
|
|
335
|
+
`,Mf=`
|
|
336
|
+
fn _gpu_fresnelS(x_in: f32) -> f32 {
|
|
337
|
+
let sgn: f32 = select(1.0, -1.0, x_in < 0.0);
|
|
338
|
+
let x = abs(x_in);
|
|
339
|
+
|
|
340
|
+
if (x < 1.6) {
|
|
341
|
+
let x2 = x * x;
|
|
342
|
+
let t = x2 * x2;
|
|
343
|
+
var sn = array<f32, 12>(
|
|
344
|
+
-2.99181919401019853726e3, 7.08840045257738576863e5,
|
|
345
|
+
-6.29741486205862506537e7, 2.54890880573376359104e9,
|
|
346
|
+
-4.42979518059697779103e10, 3.18016297876567817986e11,
|
|
347
|
+
0.0, 0.0, 0.0, 0.0, 0.0, 0.0
|
|
348
|
+
);
|
|
349
|
+
var sd = array<f32, 12>(
|
|
350
|
+
1.0, 2.81376268889994315696e2, 4.55847810806532581675e4,
|
|
351
|
+
5.1734388877009640073e6, 4.19320245898111231129e8, 2.2441179564534092094e10,
|
|
352
|
+
6.07366389490084914091e11,
|
|
353
|
+
0.0, 0.0, 0.0, 0.0, 0.0
|
|
354
|
+
);
|
|
355
|
+
return sgn * x * x2 * _gpu_polevl(t, sn, 6) / _gpu_polevl(t, sd, 7);
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
if (x < 36.0) {
|
|
359
|
+
let x2 = x * x;
|
|
360
|
+
let t = 3.14159265358979 * x2;
|
|
361
|
+
let u = 1.0 / (t * t);
|
|
362
|
+
var fn = array<f32, 12>(
|
|
363
|
+
4.21543555043677546506e-1, 1.43407919780758885261e-1,
|
|
364
|
+
1.15220955073585758835e-2, 3.450179397825740279e-4,
|
|
365
|
+
4.63613749287867322088e-6, 3.05568983790257605827e-8,
|
|
366
|
+
1.02304514164907233465e-10, 1.72010743268161828879e-13,
|
|
367
|
+
1.34283276233062758925e-16, 3.76329711269987889006e-20,
|
|
368
|
+
0.0, 0.0
|
|
369
|
+
);
|
|
370
|
+
var fd = array<f32, 12>(
|
|
371
|
+
1.0, 7.51586398353378947175e-1,
|
|
372
|
+
1.16888925859191382142e-1, 6.44051526508858611005e-3,
|
|
373
|
+
1.55934409164153020873e-4, 1.8462756734893054587e-6,
|
|
374
|
+
1.12699224763999035261e-8, 3.60140029589371370404e-11,
|
|
375
|
+
5.8875453362157841001e-14, 4.52001434074129701496e-17,
|
|
376
|
+
1.25443237090011264384e-20, 0.0
|
|
377
|
+
);
|
|
378
|
+
var gn = array<f32, 12>(
|
|
379
|
+
5.04442073643383265887e-1, 1.97102833525523411709e-1,
|
|
380
|
+
1.87648584092575249293e-2, 6.84079380915393090172e-4,
|
|
381
|
+
1.15138826111884280931e-5, 9.82852443688422223854e-8,
|
|
382
|
+
4.45344415861750144738e-10, 1.08268041139020870318e-12,
|
|
383
|
+
1.37555460633261799868e-15, 8.36354435630677421531e-19,
|
|
384
|
+
1.86958710162783235106e-22, 0.0
|
|
385
|
+
);
|
|
386
|
+
var gd = array<f32, 12>(
|
|
387
|
+
1.0, 1.47495759925128324529,
|
|
388
|
+
3.37748989120019970451e-1, 2.53603741420338795122e-2,
|
|
389
|
+
8.14679107184306179049e-4, 1.27545075667729118702e-5,
|
|
390
|
+
1.04314589657571990585e-7, 4.60680728515232032307e-10,
|
|
391
|
+
1.10273215066240270757e-12, 1.38796531259578871258e-15,
|
|
392
|
+
8.39158816283118707363e-19, 1.86958710162783236342e-22
|
|
393
|
+
);
|
|
394
|
+
let f = 1.0 - u * _gpu_polevl(u, fn, 10) / _gpu_polevl(u, fd, 11);
|
|
395
|
+
let g = (1.0 / t) * _gpu_polevl(u, gn, 11) / _gpu_polevl(u, gd, 12);
|
|
396
|
+
let z = 1.5707963267948966 * x2;
|
|
397
|
+
let c = cos(z);
|
|
398
|
+
let s = sin(z);
|
|
399
|
+
return sgn * (0.5 - (f * c + g * s) / (3.14159265358979 * x));
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
return sgn * 0.5;
|
|
403
|
+
}
|
|
404
|
+
`,wf=`
|
|
405
|
+
float _gpu_factorial(int n) {
|
|
406
|
+
float f = 1.0;
|
|
407
|
+
for (int i = 2; i <= n; i++) f *= float(i);
|
|
408
|
+
return f;
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
float _gpu_besselJ_series(int n, float x) {
|
|
412
|
+
float halfX = x / 2.0;
|
|
413
|
+
float negQ = -(x * x) / 4.0;
|
|
414
|
+
float term = 1.0;
|
|
415
|
+
for (int i = 1; i <= n; i++) term /= float(i);
|
|
416
|
+
float s = term;
|
|
417
|
+
for (int k = 1; k <= 60; k++) {
|
|
418
|
+
term *= negQ / (float(k) * float(n + k));
|
|
419
|
+
s += term;
|
|
420
|
+
if (abs(term) < abs(s) * 1e-7) break;
|
|
421
|
+
}
|
|
422
|
+
return s * pow(halfX, float(n));
|
|
423
|
+
}
|
|
424
|
+
|
|
425
|
+
float _gpu_besselJ_asymptotic(int n, float x) {
|
|
426
|
+
float mu = 4.0 * float(n) * float(n);
|
|
427
|
+
float P = 1.0;
|
|
428
|
+
float Q = 0.0;
|
|
429
|
+
float ak = 1.0;
|
|
430
|
+
float e8x = 8.0 * x;
|
|
431
|
+
for (int k = 1; k <= 12; k++) {
|
|
432
|
+
float twokm1 = float(2 * k - 1);
|
|
433
|
+
ak *= mu - twokm1 * twokm1;
|
|
434
|
+
float denom = _gpu_factorial(k) * pow(e8x, float(k));
|
|
435
|
+
float contrib = ak / denom;
|
|
436
|
+
if (k == 1 || k == 3 || k == 5 || k == 7 || k == 9 || k == 11) {
|
|
437
|
+
// odd k: contributes to Q
|
|
438
|
+
if (((k - 1) / 2) % 2 == 0) Q += contrib;
|
|
439
|
+
else Q -= contrib;
|
|
440
|
+
} else {
|
|
441
|
+
// even k: contributes to P
|
|
442
|
+
if ((k / 2) % 2 == 1) P -= contrib;
|
|
443
|
+
else P += contrib;
|
|
444
|
+
}
|
|
445
|
+
if (abs(contrib) < 1e-7) break;
|
|
446
|
+
}
|
|
447
|
+
float chi = x - (float(n) / 2.0 + 0.25) * 3.14159265358979;
|
|
448
|
+
return sqrt(2.0 / (3.14159265358979 * x)) * (P * cos(chi) - Q * sin(chi));
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
float _gpu_besselJ(int n, float x) {
|
|
452
|
+
if (x == 0.0) return n == 0 ? 1.0 : 0.0;
|
|
453
|
+
float sgn = 1.0;
|
|
454
|
+
if (n < 0) {
|
|
455
|
+
n = -n;
|
|
456
|
+
if (n % 2 != 0) sgn = -1.0;
|
|
457
|
+
}
|
|
458
|
+
if (x < 0.0) {
|
|
459
|
+
x = -x;
|
|
460
|
+
if (n % 2 != 0) sgn *= -1.0;
|
|
461
|
+
}
|
|
462
|
+
if (x > 25.0 + float(n * n) / 2.0) return sgn * _gpu_besselJ_asymptotic(n, x);
|
|
463
|
+
if (x < 5.0 + float(n)) return sgn * _gpu_besselJ_series(n, x);
|
|
464
|
+
// Miller's backward recurrence
|
|
465
|
+
int M = max(n + 20, int(ceil(x)) + 30);
|
|
466
|
+
if (M > 200) return sgn * _gpu_besselJ_series(n, x);
|
|
467
|
+
float vals[201];
|
|
468
|
+
float jp1 = 0.0;
|
|
469
|
+
float jk = 1.0;
|
|
470
|
+
vals[M] = jk;
|
|
471
|
+
for (int k = M; k >= 1; k--) {
|
|
472
|
+
float jm1 = (2.0 * float(k) / x) * jk - jp1;
|
|
473
|
+
jp1 = jk;
|
|
474
|
+
jk = jm1;
|
|
475
|
+
vals[k - 1] = jk;
|
|
476
|
+
}
|
|
477
|
+
float norm = vals[0];
|
|
478
|
+
for (int k = 2; k <= M; k += 2) norm += 2.0 * vals[k];
|
|
479
|
+
return sgn * vals[n] / norm;
|
|
480
|
+
}
|
|
481
|
+
`,Af=`
|
|
482
|
+
fn _gpu_factorial(n: i32) -> f32 {
|
|
483
|
+
var f: f32 = 1.0;
|
|
484
|
+
for (var i: i32 = 2; i <= n; i++) { f *= f32(i); }
|
|
485
|
+
return f;
|
|
486
|
+
}
|
|
487
|
+
|
|
488
|
+
fn _gpu_besselJ_series(n_in: i32, x: f32) -> f32 {
|
|
489
|
+
let halfX = x / 2.0;
|
|
490
|
+
let negQ = -(x * x) / 4.0;
|
|
491
|
+
var term: f32 = 1.0;
|
|
492
|
+
for (var i: i32 = 1; i <= n_in; i++) { term /= f32(i); }
|
|
493
|
+
var s = term;
|
|
494
|
+
for (var k: i32 = 1; k <= 60; k++) {
|
|
495
|
+
term *= negQ / (f32(k) * f32(n_in + k));
|
|
496
|
+
s += term;
|
|
497
|
+
if (abs(term) < abs(s) * 1e-7) { break; }
|
|
498
|
+
}
|
|
499
|
+
return s * pow(halfX, f32(n_in));
|
|
500
|
+
}
|
|
501
|
+
|
|
502
|
+
fn _gpu_besselJ_asymptotic(n_in: i32, x: f32) -> f32 {
|
|
503
|
+
let mu = 4.0 * f32(n_in) * f32(n_in);
|
|
504
|
+
var P: f32 = 1.0;
|
|
505
|
+
var Q: f32 = 0.0;
|
|
506
|
+
var ak: f32 = 1.0;
|
|
507
|
+
let e8x = 8.0 * x;
|
|
508
|
+
for (var k: i32 = 1; k <= 12; k++) {
|
|
509
|
+
let twokm1 = f32(2 * k - 1);
|
|
510
|
+
ak *= mu - twokm1 * twokm1;
|
|
511
|
+
let denom = _gpu_factorial(k) * pow(e8x, f32(k));
|
|
512
|
+
let contrib = ak / denom;
|
|
513
|
+
if (k == 1 || k == 3 || k == 5 || k == 7 || k == 9 || k == 11) {
|
|
514
|
+
if (((k - 1) / 2) % 2 == 0) { Q += contrib; }
|
|
515
|
+
else { Q -= contrib; }
|
|
516
|
+
} else {
|
|
517
|
+
if ((k / 2) % 2 == 1) { P -= contrib; }
|
|
518
|
+
else { P += contrib; }
|
|
519
|
+
}
|
|
520
|
+
if (abs(contrib) < 1e-7) { break; }
|
|
521
|
+
}
|
|
522
|
+
let chi = x - (f32(n_in) / 2.0 + 0.25) * 3.14159265358979;
|
|
523
|
+
return sqrt(2.0 / (3.14159265358979 * x)) * (P * cos(chi) - Q * sin(chi));
|
|
524
|
+
}
|
|
525
|
+
|
|
526
|
+
fn _gpu_besselJ(n_in: i32, x_in: f32) -> f32 {
|
|
527
|
+
var n = n_in;
|
|
528
|
+
var x = x_in;
|
|
529
|
+
if (x == 0.0) { return select(0.0, 1.0, n == 0); }
|
|
530
|
+
var sgn: f32 = 1.0;
|
|
531
|
+
if (n < 0) {
|
|
532
|
+
n = -n;
|
|
533
|
+
if (n % 2 != 0) { sgn = -1.0; }
|
|
534
|
+
}
|
|
535
|
+
if (x < 0.0) {
|
|
536
|
+
x = -x;
|
|
537
|
+
if (n % 2 != 0) { sgn *= -1.0; }
|
|
538
|
+
}
|
|
539
|
+
if (x > 25.0 + f32(n * n) / 2.0) { return sgn * _gpu_besselJ_asymptotic(n, x); }
|
|
540
|
+
if (x < 5.0 + f32(n)) { return sgn * _gpu_besselJ_series(n, x); }
|
|
541
|
+
// Miller's backward recurrence
|
|
542
|
+
var M = max(n + 20, i32(ceil(x)) + 30);
|
|
543
|
+
if (M > 200) { return sgn * _gpu_besselJ_series(n, x); }
|
|
544
|
+
var vals: array<f32, 201>;
|
|
545
|
+
var jp1: f32 = 0.0;
|
|
546
|
+
var jk: f32 = 1.0;
|
|
547
|
+
vals[M] = jk;
|
|
548
|
+
for (var k: i32 = M; k >= 1; k--) {
|
|
549
|
+
let jm1 = (2.0 * f32(k) / x) * jk - jp1;
|
|
550
|
+
jp1 = jk;
|
|
551
|
+
jk = jm1;
|
|
552
|
+
vals[k - 1] = jk;
|
|
553
|
+
}
|
|
554
|
+
var norm = vals[0];
|
|
555
|
+
for (var k2: i32 = 2; k2 <= M; k2 += 2) { norm += 2.0 * vals[k2]; }
|
|
556
|
+
return sgn * vals[n] / norm;
|
|
557
|
+
}
|
|
558
|
+
`,$f=`
|
|
559
|
+
float _fractal_mandelbrot(vec2 c, int maxIter) {
|
|
560
|
+
vec2 z = vec2(0.0, 0.0);
|
|
561
|
+
for (int i = 0; i < maxIter; i++) {
|
|
562
|
+
z = vec2(z.x*z.x - z.y*z.y + c.x, 2.0*z.x*z.y + c.y);
|
|
563
|
+
if (dot(z, z) > 4.0)
|
|
564
|
+
return clamp((float(i) - log2(log2(dot(z, z))) + 4.0) / float(maxIter), 0.0, 1.0);
|
|
565
|
+
}
|
|
566
|
+
return 1.0;
|
|
567
|
+
}
|
|
568
|
+
|
|
569
|
+
float _fractal_julia(vec2 z, vec2 c, int maxIter) {
|
|
570
|
+
for (int i = 0; i < maxIter; i++) {
|
|
571
|
+
z = vec2(z.x*z.x - z.y*z.y + c.x, 2.0*z.x*z.y + c.y);
|
|
572
|
+
if (dot(z, z) > 4.0)
|
|
573
|
+
return clamp((float(i) - log2(log2(dot(z, z))) + 4.0) / float(maxIter), 0.0, 1.0);
|
|
574
|
+
}
|
|
575
|
+
return 1.0;
|
|
576
|
+
}
|
|
577
|
+
`,Cf=`
|
|
578
|
+
fn _fractal_mandelbrot(c: vec2f, maxIter: i32) -> f32 {
|
|
579
|
+
var z = vec2f(0.0, 0.0);
|
|
580
|
+
for (var i: i32 = 0; i < maxIter; i++) {
|
|
581
|
+
z = vec2f(z.x*z.x - z.y*z.y + c.x, 2.0*z.x*z.y + c.y);
|
|
582
|
+
if (dot(z, z) > 4.0) {
|
|
583
|
+
return clamp((f32(i) - log2(log2(dot(z, z))) + 4.0) / f32(maxIter), 0.0, 1.0);
|
|
584
|
+
}
|
|
585
|
+
}
|
|
586
|
+
return 1.0;
|
|
587
|
+
}
|
|
588
|
+
|
|
589
|
+
fn _fractal_julia(z_in: vec2f, c: vec2f, maxIter: i32) -> f32 {
|
|
590
|
+
var z = z_in;
|
|
591
|
+
for (var i: i32 = 0; i < maxIter; i++) {
|
|
592
|
+
z = vec2f(z.x*z.x - z.y*z.y + c.x, 2.0*z.x*z.y + c.y);
|
|
593
|
+
if (dot(z, z) > 4.0) {
|
|
594
|
+
return clamp((f32(i) - log2(log2(dot(z, z))) + 4.0) / f32(maxIter), 0.0, 1.0);
|
|
595
|
+
}
|
|
596
|
+
}
|
|
597
|
+
return 1.0;
|
|
598
|
+
}
|
|
599
|
+
`,Rf=`
|
|
600
|
+
float _gpu_srgb_to_linear(float c) {
|
|
601
|
+
if (c <= 0.04045) return c / 12.92;
|
|
602
|
+
return pow((c + 0.055) / 1.055, 2.4);
|
|
603
|
+
}
|
|
604
|
+
|
|
605
|
+
float _gpu_linear_to_srgb(float c) {
|
|
606
|
+
if (c <= 0.0031308) return 12.92 * c;
|
|
607
|
+
return 1.055 * pow(c, 1.0 / 2.4) - 0.055;
|
|
608
|
+
}
|
|
609
|
+
|
|
610
|
+
vec3 _gpu_srgb_to_oklab(vec3 rgb) {
|
|
611
|
+
float r = _gpu_srgb_to_linear(rgb.x);
|
|
612
|
+
float g = _gpu_srgb_to_linear(rgb.y);
|
|
613
|
+
float b = _gpu_srgb_to_linear(rgb.z);
|
|
614
|
+
float l_ = pow(0.4122214708 * r + 0.5363325363 * g + 0.0514459929 * b, 1.0 / 3.0);
|
|
615
|
+
float m_ = pow(0.2119034982 * r + 0.6806995451 * g + 0.1073969566 * b, 1.0 / 3.0);
|
|
616
|
+
float s_ = pow(0.0883024619 * r + 0.2817188376 * g + 0.6299787005 * b, 1.0 / 3.0);
|
|
617
|
+
return vec3(
|
|
618
|
+
0.2104542553 * l_ + 0.793617785 * m_ - 0.0040720468 * s_,
|
|
619
|
+
1.9779984951 * l_ - 2.428592205 * m_ + 0.4505937099 * s_,
|
|
620
|
+
0.0259040371 * l_ + 0.7827717662 * m_ - 0.808675766 * s_
|
|
621
|
+
);
|
|
622
|
+
}
|
|
623
|
+
|
|
624
|
+
vec3 _gpu_oklab_to_srgb(vec3 lab) {
|
|
625
|
+
float l_ = lab.x + 0.3963377774 * lab.y + 0.2158037573 * lab.z;
|
|
626
|
+
float m_ = lab.x - 0.1055613458 * lab.y - 0.0638541728 * lab.z;
|
|
627
|
+
float s_ = lab.x - 0.0894841775 * lab.y - 1.291485548 * lab.z;
|
|
628
|
+
float l = l_ * l_ * l_;
|
|
629
|
+
float m = m_ * m_ * m_;
|
|
630
|
+
float s = s_ * s_ * s_;
|
|
631
|
+
float r = 4.0767416621 * l - 3.3077115913 * m + 0.2309699292 * s;
|
|
632
|
+
float g = -1.2684380046 * l + 2.6097574011 * m - 0.3413193965 * s;
|
|
633
|
+
float b = -0.0041960863 * l - 0.7034186147 * m + 1.707614701 * s;
|
|
634
|
+
return clamp(vec3(_gpu_linear_to_srgb(r), _gpu_linear_to_srgb(g), _gpu_linear_to_srgb(b)), 0.0, 1.0);
|
|
635
|
+
}
|
|
636
|
+
|
|
637
|
+
vec3 _gpu_oklab_to_oklch(vec3 lab) {
|
|
638
|
+
float C = length(lab.yz);
|
|
639
|
+
float H = atan(lab.z, lab.y);
|
|
640
|
+
return vec3(lab.x, C, H);
|
|
641
|
+
}
|
|
642
|
+
|
|
643
|
+
vec3 _gpu_oklch_to_oklab(vec3 lch) {
|
|
644
|
+
return vec3(lch.x, lch.y * cos(lch.z), lch.y * sin(lch.z));
|
|
645
|
+
}
|
|
646
|
+
|
|
647
|
+
vec3 _gpu_color_mix(vec3 rgb1, vec3 rgb2, float t) {
|
|
648
|
+
vec3 lch1 = _gpu_oklab_to_oklch(_gpu_srgb_to_oklab(rgb1));
|
|
649
|
+
vec3 lch2 = _gpu_oklab_to_oklch(_gpu_srgb_to_oklab(rgb2));
|
|
650
|
+
float L = mix(lch1.x, lch2.x, t);
|
|
651
|
+
float C = mix(lch1.y, lch2.y, t);
|
|
652
|
+
float dh = lch2.z - lch1.z;
|
|
653
|
+
const float PI = 3.14159265359;
|
|
654
|
+
if (dh > PI) dh -= 2.0 * PI;
|
|
655
|
+
if (dh < -PI) dh += 2.0 * PI;
|
|
656
|
+
float H = lch1.z + dh * t;
|
|
657
|
+
return _gpu_oklab_to_srgb(_gpu_oklch_to_oklab(vec3(L, C, H)));
|
|
658
|
+
}
|
|
659
|
+
|
|
660
|
+
float _gpu_apca(vec3 bg, vec3 fg) {
|
|
661
|
+
float bgR = _gpu_srgb_to_linear(bg.x);
|
|
662
|
+
float bgG = _gpu_srgb_to_linear(bg.y);
|
|
663
|
+
float bgB = _gpu_srgb_to_linear(bg.z);
|
|
664
|
+
float fgR = _gpu_srgb_to_linear(fg.x);
|
|
665
|
+
float fgG = _gpu_srgb_to_linear(fg.y);
|
|
666
|
+
float fgB = _gpu_srgb_to_linear(fg.z);
|
|
667
|
+
float bgY = 0.2126729 * bgR + 0.7151522 * bgG + 0.0721750 * bgB;
|
|
668
|
+
float fgY = 0.2126729 * fgR + 0.7151522 * fgG + 0.0721750 * fgB;
|
|
669
|
+
float bgC = pow(bgY, 0.56);
|
|
670
|
+
float fgC = pow(fgY, 0.57);
|
|
671
|
+
float contrast = (bgC > fgC)
|
|
672
|
+
? (bgC - fgC) * 1.14
|
|
673
|
+
: (bgC - fgC) * 1.14;
|
|
674
|
+
return contrast * 100.0;
|
|
675
|
+
}
|
|
676
|
+
`,Df=`
|
|
677
|
+
fn _gpu_srgb_to_linear(c: f32) -> f32 {
|
|
678
|
+
if (c <= 0.04045) { return c / 12.92; }
|
|
679
|
+
return pow((c + 0.055) / 1.055, 2.4);
|
|
680
|
+
}
|
|
681
|
+
|
|
682
|
+
fn _gpu_linear_to_srgb(c: f32) -> f32 {
|
|
683
|
+
if (c <= 0.0031308) { return 12.92 * c; }
|
|
684
|
+
return 1.055 * pow(c, 1.0 / 2.4) - 0.055;
|
|
685
|
+
}
|
|
686
|
+
|
|
687
|
+
fn _gpu_srgb_to_oklab(rgb: vec3f) -> vec3f {
|
|
688
|
+
let r = _gpu_srgb_to_linear(rgb.x);
|
|
689
|
+
let g = _gpu_srgb_to_linear(rgb.y);
|
|
690
|
+
let b = _gpu_srgb_to_linear(rgb.z);
|
|
691
|
+
let l_ = pow(0.4122214708 * r + 0.5363325363 * g + 0.0514459929 * b, 1.0 / 3.0);
|
|
692
|
+
let m_ = pow(0.2119034982 * r + 0.6806995451 * g + 0.1073969566 * b, 1.0 / 3.0);
|
|
693
|
+
let s_ = pow(0.0883024619 * r + 0.2817188376 * g + 0.6299787005 * b, 1.0 / 3.0);
|
|
694
|
+
return vec3f(
|
|
695
|
+
0.2104542553 * l_ + 0.793617785 * m_ - 0.0040720468 * s_,
|
|
696
|
+
1.9779984951 * l_ - 2.428592205 * m_ + 0.4505937099 * s_,
|
|
697
|
+
0.0259040371 * l_ + 0.7827717662 * m_ - 0.808675766 * s_
|
|
698
|
+
);
|
|
699
|
+
}
|
|
700
|
+
|
|
701
|
+
fn _gpu_oklab_to_srgb(lab: vec3f) -> vec3f {
|
|
702
|
+
let l_ = lab.x + 0.3963377774 * lab.y + 0.2158037573 * lab.z;
|
|
703
|
+
let m_ = lab.x - 0.1055613458 * lab.y - 0.0638541728 * lab.z;
|
|
704
|
+
let s_ = lab.x - 0.0894841775 * lab.y - 1.291485548 * lab.z;
|
|
705
|
+
let l = l_ * l_ * l_;
|
|
706
|
+
let m = m_ * m_ * m_;
|
|
707
|
+
let s = s_ * s_ * s_;
|
|
708
|
+
let r = 4.0767416621 * l - 3.3077115913 * m + 0.2309699292 * s;
|
|
709
|
+
let g = -1.2684380046 * l + 2.6097574011 * m - 0.3413193965 * s;
|
|
710
|
+
let b = -0.0041960863 * l - 0.7034186147 * m + 1.707614701 * s;
|
|
711
|
+
return clamp(vec3f(_gpu_linear_to_srgb(r), _gpu_linear_to_srgb(g), _gpu_linear_to_srgb(b)), vec3f(0.0), vec3f(1.0));
|
|
712
|
+
}
|
|
713
|
+
|
|
714
|
+
fn _gpu_oklab_to_oklch(lab: vec3f) -> vec3f {
|
|
715
|
+
let C = length(lab.yz);
|
|
716
|
+
let H = atan2(lab.z, lab.y);
|
|
717
|
+
return vec3f(lab.x, C, H);
|
|
718
|
+
}
|
|
719
|
+
|
|
720
|
+
fn _gpu_oklch_to_oklab(lch: vec3f) -> vec3f {
|
|
721
|
+
return vec3f(lch.x, lch.y * cos(lch.z), lch.y * sin(lch.z));
|
|
722
|
+
}
|
|
723
|
+
|
|
724
|
+
fn _gpu_color_mix(rgb1: vec3f, rgb2: vec3f, t: f32) -> vec3f {
|
|
725
|
+
let lch1 = _gpu_oklab_to_oklch(_gpu_srgb_to_oklab(rgb1));
|
|
726
|
+
let lch2 = _gpu_oklab_to_oklch(_gpu_srgb_to_oklab(rgb2));
|
|
727
|
+
let L = mix(lch1.x, lch2.x, t);
|
|
728
|
+
let C = mix(lch1.y, lch2.y, t);
|
|
729
|
+
let PI = 3.14159265359;
|
|
730
|
+
var dh = lch2.z - lch1.z;
|
|
731
|
+
if (dh > PI) { dh -= 2.0 * PI; }
|
|
732
|
+
if (dh < -PI) { dh += 2.0 * PI; }
|
|
733
|
+
let H = lch1.z + dh * t;
|
|
734
|
+
return _gpu_oklab_to_srgb(_gpu_oklch_to_oklab(vec3f(L, C, H)));
|
|
735
|
+
}
|
|
736
|
+
|
|
737
|
+
fn _gpu_apca(bg: vec3f, fg: vec3f) -> f32 {
|
|
738
|
+
let bgR = _gpu_srgb_to_linear(bg.x);
|
|
739
|
+
let bgG = _gpu_srgb_to_linear(bg.y);
|
|
740
|
+
let bgB = _gpu_srgb_to_linear(bg.z);
|
|
741
|
+
let fgR = _gpu_srgb_to_linear(fg.x);
|
|
742
|
+
let fgG = _gpu_srgb_to_linear(fg.y);
|
|
743
|
+
let fgB = _gpu_srgb_to_linear(fg.z);
|
|
744
|
+
let bgY = 0.2126729 * bgR + 0.7151522 * bgG + 0.0721750 * bgB;
|
|
745
|
+
let fgY = 0.2126729 * fgR + 0.7151522 * fgG + 0.0721750 * fgB;
|
|
746
|
+
let bgC = pow(bgY, 0.56);
|
|
747
|
+
let fgC = pow(fgY, 0.57);
|
|
748
|
+
let contrast = (bgC - fgC) * 1.14;
|
|
749
|
+
return contrast * 100.0;
|
|
750
|
+
}
|
|
751
|
+
`,fr={_gpu_cmul:{deps:[],glsl:`vec2 _gpu_cmul(vec2 a, vec2 b) {
|
|
752
|
+
return vec2(a.x * b.x - a.y * b.y, a.x * b.y + a.y * b.x);
|
|
753
|
+
}`,wgsl:`fn _gpu_cmul(a: vec2f, b: vec2f) -> vec2f {
|
|
754
|
+
return vec2f(a.x * b.x - a.y * b.y, a.x * b.y + a.y * b.x);
|
|
755
|
+
}`},_gpu_cdiv:{deps:[],glsl:`vec2 _gpu_cdiv(vec2 a, vec2 b) {
|
|
756
|
+
float d = b.x * b.x + b.y * b.y;
|
|
757
|
+
return vec2((a.x * b.x + a.y * b.y) / d, (a.y * b.x - a.x * b.y) / d);
|
|
758
|
+
}`,wgsl:`fn _gpu_cdiv(a: vec2f, b: vec2f) -> vec2f {
|
|
759
|
+
let d = b.x * b.x + b.y * b.y;
|
|
760
|
+
return vec2f((a.x * b.x + a.y * b.y) / d, (a.y * b.x - a.x * b.y) / d);
|
|
761
|
+
}`},_gpu_cexp:{deps:[],glsl:`vec2 _gpu_cexp(vec2 z) {
|
|
762
|
+
float e = exp(z.x);
|
|
763
|
+
return vec2(e * cos(z.y), e * sin(z.y));
|
|
764
|
+
}`,wgsl:`fn _gpu_cexp(z: vec2f) -> vec2f {
|
|
765
|
+
let e = exp(z.x);
|
|
766
|
+
return vec2f(e * cos(z.y), e * sin(z.y));
|
|
767
|
+
}`},_gpu_cln:{deps:[],glsl:`vec2 _gpu_cln(vec2 z) {
|
|
768
|
+
return vec2(log(length(z)), atan(z.y, z.x));
|
|
769
|
+
}`,wgsl:`fn _gpu_cln(z: vec2f) -> vec2f {
|
|
770
|
+
return vec2f(log(length(z)), atan2(z.y, z.x));
|
|
771
|
+
}`},_gpu_cpow:{deps:["_gpu_cexp","_gpu_cmul","_gpu_cln"],glsl:`vec2 _gpu_cpow(vec2 z, vec2 w) {
|
|
772
|
+
return _gpu_cexp(_gpu_cmul(w, _gpu_cln(z)));
|
|
773
|
+
}`,wgsl:`fn _gpu_cpow(z: vec2f, w: vec2f) -> vec2f {
|
|
774
|
+
return _gpu_cexp(_gpu_cmul(w, _gpu_cln(z)));
|
|
775
|
+
}`},_gpu_csqrt:{deps:[],glsl:`vec2 _gpu_csqrt(vec2 z) {
|
|
776
|
+
float r = length(z);
|
|
777
|
+
float theta = atan(z.y, z.x);
|
|
778
|
+
return sqrt(r) * vec2(cos(theta * 0.5), sin(theta * 0.5));
|
|
779
|
+
}`,wgsl:`fn _gpu_csqrt(z: vec2f) -> vec2f {
|
|
780
|
+
let r = length(z);
|
|
781
|
+
let theta = atan2(z.y, z.x);
|
|
782
|
+
return sqrt(r) * vec2f(cos(theta * 0.5), sin(theta * 0.5));
|
|
783
|
+
}`},_gpu_csin:{deps:[],glsl:`vec2 _gpu_csin(vec2 z) {
|
|
784
|
+
return vec2(sin(z.x) * cosh(z.y), cos(z.x) * sinh(z.y));
|
|
785
|
+
}`,wgsl:`fn _gpu_csin(z: vec2f) -> vec2f {
|
|
786
|
+
return vec2f(sin(z.x) * cosh(z.y), cos(z.x) * sinh(z.y));
|
|
787
|
+
}`},_gpu_ccos:{deps:[],glsl:`vec2 _gpu_ccos(vec2 z) {
|
|
788
|
+
return vec2(cos(z.x) * cosh(z.y), -sin(z.x) * sinh(z.y));
|
|
789
|
+
}`,wgsl:`fn _gpu_ccos(z: vec2f) -> vec2f {
|
|
790
|
+
return vec2f(cos(z.x) * cosh(z.y), -sin(z.x) * sinh(z.y));
|
|
791
|
+
}`},_gpu_ctan:{deps:["_gpu_cdiv","_gpu_csin","_gpu_ccos"],glsl:`vec2 _gpu_ctan(vec2 z) {
|
|
792
|
+
return _gpu_cdiv(_gpu_csin(z), _gpu_ccos(z));
|
|
793
|
+
}`,wgsl:`fn _gpu_ctan(z: vec2f) -> vec2f {
|
|
794
|
+
return _gpu_cdiv(_gpu_csin(z), _gpu_ccos(z));
|
|
795
|
+
}`},_gpu_csinh:{deps:[],glsl:`vec2 _gpu_csinh(vec2 z) {
|
|
796
|
+
return vec2(sinh(z.x) * cos(z.y), cosh(z.x) * sin(z.y));
|
|
797
|
+
}`,wgsl:`fn _gpu_csinh(z: vec2f) -> vec2f {
|
|
798
|
+
return vec2f(sinh(z.x) * cos(z.y), cosh(z.x) * sin(z.y));
|
|
799
|
+
}`},_gpu_ccosh:{deps:[],glsl:`vec2 _gpu_ccosh(vec2 z) {
|
|
800
|
+
return vec2(cosh(z.x) * cos(z.y), sinh(z.x) * sin(z.y));
|
|
801
|
+
}`,wgsl:`fn _gpu_ccosh(z: vec2f) -> vec2f {
|
|
802
|
+
return vec2f(cosh(z.x) * cos(z.y), sinh(z.x) * sin(z.y));
|
|
803
|
+
}`},_gpu_ctanh:{deps:["_gpu_cdiv","_gpu_csinh","_gpu_ccosh"],glsl:`vec2 _gpu_ctanh(vec2 z) {
|
|
804
|
+
return _gpu_cdiv(_gpu_csinh(z), _gpu_ccosh(z));
|
|
805
|
+
}`,wgsl:`fn _gpu_ctanh(z: vec2f) -> vec2f {
|
|
806
|
+
return _gpu_cdiv(_gpu_csinh(z), _gpu_ccosh(z));
|
|
807
|
+
}`},_gpu_casin:{deps:["_gpu_csqrt","_gpu_cln"],glsl:`vec2 _gpu_casin(vec2 z) {
|
|
808
|
+
vec2 iz = vec2(-z.y, z.x);
|
|
809
|
+
vec2 s = _gpu_csqrt(vec2(1.0 - z.x * z.x + z.y * z.y, -2.0 * z.x * z.y));
|
|
810
|
+
vec2 l = _gpu_cln(iz + s);
|
|
811
|
+
return vec2(l.y, -l.x);
|
|
812
|
+
}`,wgsl:`fn _gpu_casin(z: vec2f) -> vec2f {
|
|
813
|
+
let iz = vec2f(-z.y, z.x);
|
|
814
|
+
let s = _gpu_csqrt(vec2f(1.0 - z.x * z.x + z.y * z.y, -2.0 * z.x * z.y));
|
|
815
|
+
let l = _gpu_cln(iz + s);
|
|
816
|
+
return vec2f(l.y, -l.x);
|
|
817
|
+
}`},_gpu_cacos:{deps:["_gpu_casin"],glsl:`vec2 _gpu_cacos(vec2 z) {
|
|
818
|
+
vec2 s = _gpu_casin(z);
|
|
819
|
+
return vec2(1.5707963268 - s.x, -s.y);
|
|
820
|
+
}`,wgsl:`fn _gpu_cacos(z: vec2f) -> vec2f {
|
|
821
|
+
let s = _gpu_casin(z);
|
|
822
|
+
return vec2f(1.5707963268 - s.x, -s.y);
|
|
823
|
+
}`},_gpu_catan:{deps:["_gpu_cln"],glsl:`vec2 _gpu_catan(vec2 z) {
|
|
824
|
+
vec2 iz = vec2(-z.y, z.x);
|
|
825
|
+
vec2 a = _gpu_cln(vec2(1.0 - iz.x, -iz.y));
|
|
826
|
+
vec2 b = _gpu_cln(vec2(1.0 + iz.x, iz.y));
|
|
827
|
+
vec2 d = vec2(a.x - b.x, a.y - b.y);
|
|
828
|
+
return vec2(-0.5 * d.y, 0.5 * d.x);
|
|
829
|
+
}`,wgsl:`fn _gpu_catan(z: vec2f) -> vec2f {
|
|
830
|
+
let iz = vec2f(-z.y, z.x);
|
|
831
|
+
let a = _gpu_cln(vec2f(1.0 - iz.x, -iz.y));
|
|
832
|
+
let b = _gpu_cln(vec2f(1.0 + iz.x, iz.y));
|
|
833
|
+
let d = vec2f(a.x - b.x, a.y - b.y);
|
|
834
|
+
return vec2f(-0.5 * d.y, 0.5 * d.x);
|
|
835
|
+
}`},_gpu_casinh:{deps:["_gpu_csqrt","_gpu_cln"],glsl:`vec2 _gpu_casinh(vec2 z) {
|
|
836
|
+
vec2 z2 = vec2(z.x * z.x - z.y * z.y, 2.0 * z.x * z.y);
|
|
837
|
+
vec2 s = _gpu_csqrt(vec2(1.0 + z2.x, z2.y));
|
|
838
|
+
return _gpu_cln(z + s);
|
|
839
|
+
}`,wgsl:`fn _gpu_casinh(z: vec2f) -> vec2f {
|
|
840
|
+
let z2 = vec2f(z.x * z.x - z.y * z.y, 2.0 * z.x * z.y);
|
|
841
|
+
let s = _gpu_csqrt(vec2f(1.0 + z2.x, z2.y));
|
|
842
|
+
return _gpu_cln(z + s);
|
|
843
|
+
}`},_gpu_cacosh:{deps:["_gpu_csqrt","_gpu_cln"],glsl:`vec2 _gpu_cacosh(vec2 z) {
|
|
844
|
+
vec2 z2 = vec2(z.x * z.x - z.y * z.y, 2.0 * z.x * z.y);
|
|
845
|
+
vec2 s = _gpu_csqrt(vec2(z2.x - 1.0, z2.y));
|
|
846
|
+
return _gpu_cln(z + s);
|
|
847
|
+
}`,wgsl:`fn _gpu_cacosh(z: vec2f) -> vec2f {
|
|
848
|
+
let z2 = vec2f(z.x * z.x - z.y * z.y, 2.0 * z.x * z.y);
|
|
849
|
+
let s = _gpu_csqrt(vec2f(z2.x - 1.0, z2.y));
|
|
850
|
+
return _gpu_cln(z + s);
|
|
851
|
+
}`},_gpu_catanh:{deps:["_gpu_cln"],glsl:`vec2 _gpu_catanh(vec2 z) {
|
|
852
|
+
vec2 a = _gpu_cln(vec2(1.0 + z.x, z.y));
|
|
853
|
+
vec2 b = _gpu_cln(vec2(1.0 - z.x, -z.y));
|
|
854
|
+
return vec2(0.5 * (a.x - b.x), 0.5 * (a.y - b.y));
|
|
855
|
+
}`,wgsl:`fn _gpu_catanh(z: vec2f) -> vec2f {
|
|
856
|
+
let a = _gpu_cln(vec2f(1.0 + z.x, z.y));
|
|
857
|
+
let b = _gpu_cln(vec2f(1.0 - z.x, -z.y));
|
|
858
|
+
return vec2f(0.5 * (a.x - b.x), 0.5 * (a.y - b.y));
|
|
859
|
+
}`}};function Pf(e,n){let t=new Set;for(let a of Object.keys(fr))e.includes(a)&&t.add(a);if(t.size===0)return"";let i=new Set;function r(a){if(i.has(a))return;let u=fr[a];if(u){for(let l of u.deps)r(l);i.add(a)}}for(let a of t)r(a);let s=n==="wgsl"?"wgsl":"glsl",o=[];for(let a of i)o.push(fr[a][s]);return`
|
|
860
|
+
`+o.join(`
|
|
861
|
+
|
|
862
|
+
`)+`
|
|
863
|
+
`}var Ff={Pi:"3.14159265359",ExponentialE:"2.71828182846",GoldenRatio:"1.61803398875",CatalanConstant:"0.91596559417",EulerGamma:"0.57721566490"};function Zt(e){let n=e.toString();return!n.includes(".")&&!n.includes("e")&&!n.includes("E")?`${n}.0`:n}var ln=class{getOperators(){return lu}getFunctions(){return{...gf,...this.getLanguageSpecificFunctions()}}getConstants(){return Ff}createTarget(n={}){let t=this.getFunctions(),i=this.getConstants(),r=this.languageId==="wgsl"?"vec2f":"vec2";return{language:this.languageId,operators:s=>lu[s],functions:s=>t[s],var:s=>s==="ImaginaryUnit"?`${r}(0.0, 1.0)`:s in i?i[s]:s,string:s=>JSON.stringify(s),number:Zt,complex:(s,o)=>`${r}(${Zt(s)}, ${Zt(o)})`,indent:0,ws:s=>s??"",preamble:"",declare:(s,o)=>{let a=o??(this.languageId==="wgsl"?"f32":"float");return this.languageId==="wgsl"?`var ${s}: ${a}`:`${a} ${s}`},block:s=>{if(s.length===0)return"";let o=s.length-1;return s[o]=`return ${s[o]}`,s.join(`;
|
|
864
|
+
`)},...n}}compile(n,t={}){let{functions:i,vars:r}=t,s=this.getFunctions(),o=this.getConstants(),a=this.languageId==="wgsl"?"vec2f":"vec2",u=this.createTarget({functions:m=>{if(i&&m in i){let d=i[m];if(typeof d=="string")return d;if(typeof d=="function")return d.name||m}return s[m]},var:m=>r&&m in r?r[m]:m==="ImaginaryUnit"?`${a}(0.0, 1.0)`:m in o?o[m]:m}),l=g.compile(n,u),c={target:this.languageId,success:!0,code:l},p="";return p+=Pf(l,this.languageId),l.includes("_gpu_gamma")&&(p+=bf),l.includes("_gpu_erf")&&(p+=yf),l.includes("_gpu_heaviside")&&(p+=this.languageId==="wgsl"?Ef:xf),l.includes("_gpu_sinc")&&(p+=this.languageId==="wgsl"?Nf:vf),l.includes("_gpu_fresnel")&&(p+=this.languageId==="wgsl"?If:Tf),l.includes("_gpu_fresnelC")&&(p+=this.languageId==="wgsl"?Sf:kf),l.includes("_gpu_fresnelS")&&(p+=this.languageId==="wgsl"?Mf:_f),l.includes("_gpu_besselJ")&&(p+=this.languageId==="wgsl"?Af:wf),l.includes("_fractal_")&&(p+=this.languageId==="wgsl"?Cf:$f),(l.includes("_gpu_srgb_to")||l.includes("_gpu_oklab")||l.includes("_gpu_oklch")||l.includes("_gpu_color_mix")||l.includes("_gpu_apca"))&&(p+=this.languageId==="wgsl"?Df:Rf),p&&(c.preamble=p),c}compileToSource(n,t={}){let i=this.createTarget();return g.compile(n,i)}};function fu(e,n){return e.length===2?`vec2(${e.map(t=>n(t)).join(", ")})`:e.length===3?`vec3(${e.map(t=>n(t)).join(", ")})`:e.length===4?`vec4(${e.map(t=>n(t)).join(", ")})`:`float[${e.length}](${e.map(t=>n(t)).join(", ")})`}var Of={Inversesqrt:"inversesqrt",Mod:"mod",List:fu,Matrix:(e,n)=>Yt(e,n,t=>`vec${t}`,t=>`mat${t}`,t=>`float[${t}]`),Tuple:fu},pr=class extends ln{languageId="glsl";getLanguageSpecificFunctions(){return Of}compileFunction(n,t,i,r){let s=this.createTarget(),o=g.compile(n,s),a=r.map(([u,l])=>`${l} ${u}`).join(", ");if(o.includes(`
|
|
865
|
+
`)){let u=o.split(`
|
|
866
|
+
`).map(l=>` ${l}`).join(`
|
|
867
|
+
`);return`${i} ${t}(${a}) {
|
|
868
|
+
${u};
|
|
869
|
+
}`}return`${i} ${t}(${a}) {
|
|
870
|
+
return ${o};
|
|
871
|
+
}`}compileShader(n){let{type:t,version:i="300 es",inputs:r=[],outputs:s=[],uniforms:o=[],body:a}=n,u=`#version ${i}
|
|
872
|
+
|
|
873
|
+
`;t==="fragment"&&(u+=`precision highp float;
|
|
874
|
+
|
|
875
|
+
`);let l=i.startsWith("300")||i.startsWith("3")?"in":t==="vertex"?"attribute":"varying";for(let p of r)u+=`${l} ${p.type} ${p.name};
|
|
876
|
+
`;r.length>0&&(u+=`
|
|
877
|
+
`);let c=i.startsWith("300")||i.startsWith("3")?"out":"varying";for(let p of s)u+=`${c} ${p.type} ${p.name};
|
|
878
|
+
`;s.length>0&&(u+=`
|
|
879
|
+
`);for(let p of o)u+=`uniform ${p.type} ${p.name};
|
|
880
|
+
`;o.length>0&&(u+=`
|
|
881
|
+
`),u+=`void main() {
|
|
882
|
+
`;for(let p of a){let m=this.compileToSource(p.expression);u+=` ${p.variable} = ${m};
|
|
883
|
+
`}return u+=`}
|
|
884
|
+
`,u}};function pu(e,n){return e.length===2?`vec2f(${e.map(t=>n(t)).join(", ")})`:e.length===3?`vec3f(${e.map(t=>n(t)).join(", ")})`:e.length===4?`vec4f(${e.map(t=>n(t)).join(", ")})`:`array<f32, ${e.length}>(${e.map(t=>n(t)).join(", ")})`}var Lf={Inversesqrt:"inverseSqrt",Mod:([e,n],t)=>{if(e===null||n===null)throw new Error("Mod: missing argument");return`(${t(e)} % ${t(n)})`},Hypot:([e,n],t)=>{if(e===null||n===null)throw new Error("Hypot: need two arguments");return`length(vec2f(${t(e)}, ${t(n)}))`},List:pu,Matrix:(e,n)=>Yt(e,n,t=>`vec${t}f`,t=>`mat${t}x${t}f`,t=>`array<f32, ${t}>`),Tuple:pu},Bf={float:"f32",int:"i32",uint:"u32",bool:"bool",vec2:"vec2f",vec3:"vec3f",vec4:"vec4f",mat2:"mat2x2f",mat3:"mat3x3f",mat4:"mat4x4f"};function Cn(e){return Bf[e]??e}var mr=class extends ln{languageId="wgsl";getLanguageSpecificFunctions(){return Lf}compileFunction(n,t,i,r){let s=this.createTarget(),o=g.compile(n,s),a=r.map(([u,l])=>`${u}: ${Cn(l)}`).join(", ");if(o.includes(`
|
|
885
|
+
`)){let u=o.split(`
|
|
886
|
+
`).map(l=>` ${l}`).join(`
|
|
887
|
+
`);return`fn ${t}(${a}) -> ${Cn(i)} {
|
|
888
|
+
${u};
|
|
889
|
+
}`}return`fn ${t}(${a}) -> ${Cn(i)} {
|
|
890
|
+
return ${o};
|
|
891
|
+
}`}compileShader(n){let{type:t,inputs:i=[],outputs:r=[],uniforms:s=[],workgroupSize:o,body:a}=n,u="";if(i.length>0){u+=`struct VertexInput {
|
|
892
|
+
`;for(let k of i){let w=k.builtin?`@builtin(${k.builtin})`:`@location(${k.location??0})`;u+=` ${w} ${k.name}: ${Cn(k.type)},
|
|
893
|
+
`}u+=`};
|
|
894
|
+
|
|
895
|
+
`}if(r.length>0){u+=`struct ${t==="vertex"?"VertexOutput":"FragmentOutput"} {
|
|
896
|
+
`;for(let w of r){let R=w.builtin?`@builtin(${w.builtin})`:`@location(${w.location??0})`;u+=` ${R} ${w.name}: ${Cn(w.type)},
|
|
897
|
+
`}u+=`};
|
|
898
|
+
|
|
899
|
+
`}for(let k of s){let w=k.group??0,R=k.binding??0;u+=`@group(${w}) @binding(${R}) var<uniform> ${k.name}: ${Cn(k.type)};
|
|
900
|
+
`}s.length>0&&(u+=`
|
|
901
|
+
`);let l=`@${t}`,c=t==="compute"&&o?`@workgroup_size(${o.join(", ")})
|
|
902
|
+
`:"",p=i.length>0,m=r.length>0,d=t==="vertex"?"VertexOutput":"FragmentOutput",b=p?"input: VertexInput":"",v=m?` -> ${d}`:"";u+=`${l}
|
|
903
|
+
${c}fn main(${b})${v} {
|
|
904
|
+
`,m&&(u+=` var output: ${d};
|
|
905
|
+
`);for(let k of a){let w=this.compileToSource(k.expression);u+=` ${k.variable} = ${w};
|
|
906
|
+
`}return m&&(u+=` return output;
|
|
907
|
+
`),u+=`}
|
|
908
|
+
`,u}};var mu={Add:["+",11],Negate:["-",14],Subtract:["-",11],Multiply:["*",12],Divide:["/",13],Power:["**",15],Equal:["==",8],NotEqual:["!=",8],LessEqual:["<=",9],GreaterEqual:[">=",9],Less:["<",9],Greater:[">",9],And:["and",4],Or:["or",3],Not:["not",14]},du={Add:(e,n)=>e.length===0?"0":e.length===1?n(e[0]):e.map(t=>n(t)).join(" + "),Multiply:(e,n)=>e.length===0?"1":e.length===1?n(e[0]):e.map(t=>n(t)).join(" * "),Subtract:(e,n)=>{if(e.length===0)return"0";if(e.length===1)return n(e[0]);if(e.length===2)return`${n(e[0])} - ${n(e[1])}`;let t=n(e[0]);for(let i=1;i<e.length;i++)t=`${t} - ${n(e[i])}`;return t},Divide:(e,n)=>{if(e.length===0)return"1";if(e.length===1)return n(e[0]);if(e.length===2)return`${n(e[0])} / ${n(e[1])}`;let t=n(e[0]);for(let i=1;i<e.length;i++)t=`${t} / ${n(e[i])}`;return t},Sin:(e,n)=>g.isComplexValued(e[0])?`cmath.sin(${n(e[0])})`:`np.sin(${n(e[0])})`,Cos:(e,n)=>g.isComplexValued(e[0])?`cmath.cos(${n(e[0])})`:`np.cos(${n(e[0])})`,Tan:(e,n)=>g.isComplexValued(e[0])?`cmath.tan(${n(e[0])})`:`np.tan(${n(e[0])})`,Arcsin:(e,n)=>g.isComplexValued(e[0])?`cmath.asin(${n(e[0])})`:`np.arcsin(${n(e[0])})`,Arccos:(e,n)=>g.isComplexValued(e[0])?`cmath.acos(${n(e[0])})`:`np.arccos(${n(e[0])})`,Arctan:(e,n)=>g.isComplexValued(e[0])?`cmath.atan(${n(e[0])})`:`np.arctan(${n(e[0])})`,Arctan2:"np.arctan2",Sinh:(e,n)=>g.isComplexValued(e[0])?`cmath.sinh(${n(e[0])})`:`np.sinh(${n(e[0])})`,Cosh:(e,n)=>g.isComplexValued(e[0])?`cmath.cosh(${n(e[0])})`:`np.cosh(${n(e[0])})`,Tanh:(e,n)=>g.isComplexValued(e[0])?`cmath.tanh(${n(e[0])})`:`np.tanh(${n(e[0])})`,Arsinh:"np.arcsinh",Arcosh:"np.arccosh",Artanh:"np.arctanh",Cot:([e],n)=>{if(e===null)throw new Error("Cot: no argument");return`(np.cos(${n(e)}) / np.sin(${n(e)}))`},Csc:([e],n)=>{if(e===null)throw new Error("Csc: no argument");return`(1 / np.sin(${n(e)}))`},Sec:([e],n)=>{if(e===null)throw new Error("Sec: no argument");return`(1 / np.cos(${n(e)}))`},Arccot:([e],n)=>{if(e===null)throw new Error("Arccot: no argument");return`np.arctan(1 / (${n(e)}))`},Arccsc:([e],n)=>{if(e===null)throw new Error("Arccsc: no argument");return`np.arcsin(1 / (${n(e)}))`},Arcsec:([e],n)=>{if(e===null)throw new Error("Arcsec: no argument");return`np.arccos(1 / (${n(e)}))`},Coth:([e],n)=>{if(e===null)throw new Error("Coth: no argument");return`(np.cosh(${n(e)}) / np.sinh(${n(e)}))`},Csch:([e],n)=>{if(e===null)throw new Error("Csch: no argument");return`(1 / np.sinh(${n(e)}))`},Sech:([e],n)=>{if(e===null)throw new Error("Sech: no argument");return`(1 / np.cosh(${n(e)}))`},Arcoth:([e],n)=>{if(e===null)throw new Error("Arcoth: no argument");return`np.arctanh(1 / (${n(e)}))`},Arcsch:([e],n)=>{if(e===null)throw new Error("Arcsch: no argument");return`np.arcsinh(1 / (${n(e)}))`},Arsech:([e],n)=>{if(e===null)throw new Error("Arsech: no argument");return`np.arccosh(1 / (${n(e)}))`},Lb:"np.log2",Square:([e],n)=>{if(e===null)throw new Error("Square: no argument");return`np.square(${n(e)})`},Fract:([e],n)=>{if(e===null)throw new Error("Fract: no argument");return`np.modf(${n(e)})[0]`},Exp:(e,n)=>g.isComplexValued(e[0])?`cmath.exp(${n(e[0])})`:`np.exp(${n(e[0])})`,Ln:(e,n)=>g.isComplexValued(e[0])?`cmath.log(${n(e[0])})`:`np.log(${n(e[0])})`,Log:(e,n)=>e.length===1?`np.log10(${n(e[0])})`:e.length===2?`(np.log(${n(e[0])}) / np.log(${n(e[1])}))`:"np.log10",Log10:"np.log10",Log2:"np.log2",Exp2:"np.exp2",Power:(e,n)=>e.length!==2?"np.power":g.isComplexValued(e[0])||g.isComplexValued(e[1])?`(${n(e[0])} ** ${n(e[1])})`:`np.power(${n(e[0])}, ${n(e[1])})`,Sqrt:(e,n)=>g.isComplexValued(e[0])?`cmath.sqrt(${n(e[0])})`:`np.sqrt(${n(e[0])})`,Root:(e,n)=>e.length!==2?"np.power":`np.power(${n(e[0])}, 1.0 / ${n(e[1])})`,Abs:(e,n)=>g.isComplexValued(e[0])?`abs(${n(e[0])})`:`np.abs(${n(e[0])})`,Sign:"np.sign",Floor:"np.floor",Ceil:"np.ceil",Round:"np.round",Truncate:"np.trunc",Min:"np.minimum",Max:"np.maximum",Mod:"np.mod",Remainder:"np.remainder",Real:"np.real",Imaginary:"np.imag",Argument:"np.angle",Conjugate:"np.conj",Sum:"np.sum",Product:"np.prod",Mean:"np.mean",Median:"np.median",Variance:"np.var",StandardDeviation:"np.std",Dot:"np.dot",Cross:"np.cross",Norm:"np.linalg.norm",Determinant:"np.linalg.det",Inverse:"np.linalg.inv",Transpose:"np.transpose",MatrixMultiply:"np.matmul",Equal:"np.equal",NotEqual:"np.not_equal",Less:"np.less",LessEqual:"np.less_equal",Greater:"np.greater",GreaterEqual:"np.greater_equal",And:"np.logical_and",Or:"np.logical_or",Not:"np.logical_not",Erf:"scipy.special.erf",Erfc:"scipy.special.erfc",Gamma:"scipy.special.gamma",GammaLn:"scipy.special.loggamma",Factorial:"scipy.special.factorial",List:(e,n)=>`[${e.map(t=>n(t)).join(", ")}]`,Matrix:(e,n)=>`np.array(${n(e[0])})`,Tuple:(e,n)=>`(${e.map(t=>n(t)).join(", ")})`,Sequence:(e,n)=>`np.array([${e.map(t=>n(t)).join(", ")}])`,Range:(e,n)=>e.length===1?`np.arange(${n(e[0])})`:e.length===2?`np.arange(${n(e[0])}, ${n(e[1])})`:e.length===3?`np.arange(${n(e[0])}, ${n(e[1])}, ${n(e[2])})`:"np.arange"},dr=class{includeImports;useScipy;constructor(n={}){this.includeImports=n.includeImports??!1,this.useScipy=n.useScipy??!1}getOperators(){return mu}getFunctions(){return du}createTarget(n={}){return{language:"python",operators:t=>mu[t],functions:t=>du[t],var:t=>{let i={Pi:"np.pi",ExponentialE:"np.e",ImaginaryUnit:"1j",Infinity:"np.inf",NaN:"np.nan",GoldenRatio:"((1 + np.sqrt(5)) / 2)",CatalanConstant:"0.915965594177219015054603514932384110774",EulerGamma:"0.5772156649015328606065120900824024310421"};return t in i?i[t]:t},complex:(t,i)=>`complex(${t}, ${i})`,string:t=>JSON.stringify(t),number:t=>isFinite(t)?t.toString():t===1/0?"np.inf":t===-1/0?"-np.inf":"np.nan",indent:0,ws:t=>t??"",preamble:"",...n}}compile(n,t={}){return{target:"python",success:!0,code:this.compileToSource(n,t)}}compileToSource(n,t={}){let i=this.createTarget(),r=g.compile(n,i);if(this.includeImports){let s=`import numpy as np
|
|
909
|
+
`;return s+=`import cmath
|
|
910
|
+
`,this.useScipy&&(s+=`import scipy.special
|
|
911
|
+
`),`${s}
|
|
912
|
+
${r}`}return r}compileFunction(n,t,i,r){let s=this.createTarget(),o=g.compile(n,s),a=i.join(", "),u="";return this.includeImports&&(u+=`import numpy as np
|
|
913
|
+
`,u+=`import cmath
|
|
914
|
+
`,this.useScipy&&(u+=`import scipy.special
|
|
915
|
+
`),u+=`
|
|
916
|
+
`),u+=`def ${t}(${a}):
|
|
917
|
+
`,r&&(u+=` r"""${r}"""
|
|
918
|
+
`),u+=` return ${o}
|
|
919
|
+
`,u}compileVectorized(n,t,i,r){let o=this.compileFunction(n,`_${t}_scalar`,i,r)+`
|
|
920
|
+
`;return o+=`# Vectorized version
|
|
921
|
+
`,o+=`${t} = np.vectorize(_${t}_scalar)
|
|
922
|
+
`,o}compileLambda(n,t){let i=this.createTarget(),r=g.compile(n,i);return`lambda ${t.join(", ")}: ${r}`}};function E(e){return{kind:"interval",value:e}}function hr(e){return{lo:e,hi:e}}function se(e,n,t){let i=Math.ceil((e.lo-n)/t),r=n+i*t,s=1e-15;return r>=e.lo-s&&r<=e.hi+s}function Rn(e,n){if(e.kind==="empty")return n;if(n.kind==="empty")return e;if(e.kind==="singular"||n.kind==="singular")return{kind:"singular"};if(e.kind==="entire"||n.kind==="entire")return{kind:"entire"};let t=e.value,i=n.value,r=e.kind==="partial"?e.domainClipped:null,s=n.kind==="partial"?n.domainClipped:null,o={lo:Math.min(t.lo,i.lo),hi:Math.max(t.hi,i.hi)};if(r||s){let a=Ht(r,s);return{kind:"partial",value:o,domainClipped:a}}return{kind:"interval",value:o}}function Ht(e,n){return e==="both"||n==="both"?"both":e===null?n:n===null||e===n?e:"both"}function gr(e){return e.lo===e.hi}function ue(e){return e.lo<=0&&e.hi>=0}function br(e){return e.lo>0}function rt(e){return e.hi<0}function yr(e){return e.lo>=0}function xr(e){return e.hi<=0}function Er(e){return e.hi-e.lo}function vr(e){return(e.lo+e.hi)/2}function Nr(e){if(e.kind==="interval"||e.kind==="partial")return e.value}function Tr(e){return"kind"in e?e.kind==="interval"||e.kind==="partial"?e.value:void 0:e}function T(...e){let n=[];for(let t of e)if("kind"in t){if(t.kind==="empty")return{kind:"empty"};if(t.kind==="entire")return{kind:"entire"};if(t.kind==="singular")return t;n.push(t.value)}else n.push(t);return n}function Ir(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return E({lo:i.lo+r.lo,hi:i.hi+r.hi})}function st(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return E({lo:i.lo-r.hi,hi:i.hi-r.lo})}function kr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:-t.hi,hi:-t.lo})}function Sr(e,n){let t=[e.lo*n.lo,e.lo*n.hi,e.hi*n.lo,e.hi*n.hi];return{lo:Math.min(...t),hi:Math.max(...t)}}function ot(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return E(Sr(i,r))}function le(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return Vf(i,r)}function Vf(e,n){return n.lo>0||n.hi<0?E(Sr(e,{lo:1/n.hi,hi:1/n.lo})):n.lo<0&&n.hi>0?{kind:"singular"}:n.lo===0&&n.hi>0?e.lo>=0?{kind:"partial",value:{lo:e.lo/n.hi,hi:1/0},domainClipped:"hi"}:e.hi<=0?{kind:"partial",value:{lo:-1/0,hi:e.hi/n.hi},domainClipped:"lo"}:{kind:"entire"}:n.hi===0&&n.lo<0?e.lo>=0?{kind:"partial",value:{lo:-1/0,hi:e.lo/n.lo},domainClipped:"lo"}:e.hi<=0?{kind:"partial",value:{lo:e.hi/n.lo,hi:1/0},domainClipped:"hi"}:{kind:"entire"}:{kind:"empty"}}function _r(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return Jf(t)}function Jf(e){return e.hi<0?{kind:"empty"}:e.lo>=0?E({lo:Math.sqrt(e.lo),hi:Math.sqrt(e.hi)}):{kind:"partial",value:{lo:0,hi:Math.sqrt(e.hi)},domainClipped:"lo"}}function Mr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?E({lo:t.lo*t.lo,hi:t.hi*t.hi}):t.hi<=0?E({lo:t.hi*t.hi,hi:t.lo*t.lo}):E({lo:0,hi:Math.max(t.lo*t.lo,t.hi*t.hi)})}function hu(e,n){return n===0?{lo:1,hi:1}:n===1?e:n%2===0?e.lo>=0?{lo:Math.pow(e.lo,n),hi:Math.pow(e.hi,n)}:e.hi<=0?{lo:Math.pow(e.hi,n),hi:Math.pow(e.lo,n)}:{lo:0,hi:Math.max(Math.pow(e.lo,n),Math.pow(e.hi,n))}:{lo:Math.pow(e.lo,n),hi:Math.pow(e.hi,n)}}function Wt(e,n){let t=T(e);if(!Array.isArray(t))return t;let[i]=t;if(Number.isInteger(n)){if(n>=0)return E(hu(i,n));{if(ue(i))return{kind:"singular"};let r=hu(i,-n);return E({lo:1/r.hi,hi:1/r.lo})}}else return rt(i)?{kind:"empty"}:i.lo<0?{kind:"partial",value:n>0?{lo:0,hi:Math.pow(i.hi,n)}:{lo:Math.pow(i.hi,n),hi:1/0},domainClipped:"lo"}:n>0?E({lo:Math.pow(i.lo,n),hi:Math.pow(i.hi,n)}):i.lo===0?{kind:"partial",value:{lo:Math.pow(i.hi,n),hi:1/0},domainClipped:"hi"}:E({lo:Math.pow(i.hi,n),hi:Math.pow(i.lo,n)})}function wr(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(r.lo===r.hi&&Number.isInteger(r.lo))return Wt(i,r.lo);if(i.hi<=0)return i.lo===-1&&i.hi===-1&&Math.floor(r.hi)>Math.floor(r.lo)?E({lo:-1,hi:1}):{kind:"empty"};if(i.lo<=0){let o={lo:Math.max(i.lo,Number.EPSILON),hi:i.hi},a=[Math.pow(o.lo,r.lo),Math.pow(o.lo,r.hi),Math.pow(o.hi,r.lo),Math.pow(o.hi,r.hi)];return{kind:"partial",value:{lo:Math.min(...a),hi:Math.max(...a)},domainClipped:"lo"}}let s=[Math.pow(i.lo,r.lo),Math.pow(i.lo,r.hi),Math.pow(i.hi,r.lo),Math.pow(i.hi,r.hi)];return E({lo:Math.min(...s),hi:Math.max(...s)})}function Ar(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.exp(t.lo),hi:Math.exp(t.hi)})}function $r(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?E({lo:Math.log(t.lo),hi:Math.log(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log(t.hi)},domainClipped:"lo"}}function Cr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?E({lo:Math.log10(t.lo),hi:Math.log10(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log10(t.hi)},domainClipped:"lo"}}function Rr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?E({lo:Math.log2(t.lo),hi:Math.log2(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log2(t.hi)},domainClipped:"lo"}}function Dr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?E(t):t.hi<=0?E({lo:-t.hi,hi:-t.lo}):E({lo:0,hi:Math.max(-t.lo,t.hi)})}function Pr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.floor(t.lo),r=Math.floor(t.hi);return i===r?E({lo:i,hi:r}):{kind:"singular",at:i+1,continuity:"right"}}function Fr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.ceil(t.lo),r=Math.ceil(t.hi);return i===r?E({lo:i,hi:r}):{kind:"singular",at:i,continuity:"left"}}function Xt(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.round(t.lo),r=Math.round(t.hi);return i===r?E({lo:i,hi:r}):{kind:"singular",at:i+.5,continuity:"right"}}function Or(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.floor(t.lo),r=Math.floor(t.hi);return i===r?E({lo:t.lo-i,hi:t.hi-i}):{kind:"singular",at:i+1,continuity:"right"}}function Lr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.trunc(t.lo),r=Math.trunc(t.hi);if(i===r)return E({lo:i,hi:r});if(t.lo>=0)return{kind:"singular",at:i+1,continuity:"right"};let s=Math.ceil(t.lo);return s!==0?{kind:"singular",at:s,continuity:"left"}:{kind:"singular",at:1,continuity:"right"}}function Br(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return E({lo:Math.min(i.lo,r.lo),hi:Math.min(i.hi,r.hi)})}function Vr(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return E({lo:Math.max(i.lo,r.lo),hi:Math.max(i.hi,r.hi)})}function Jr(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(ue(r))return{kind:"singular"};let s=Math.abs(r.lo===r.hi?r.lo:Math.max(Math.abs(r.lo),Math.abs(r.hi))),o=Math.floor(i.lo/s),a=Math.floor(i.hi/s);if(o!==a)return{kind:"singular",at:(o+1)*s,continuity:"right"};let u=i.lo-s*o,l=i.hi-s*o;return E({lo:Math.min(u,l),hi:Math.max(u,l)})}function qr(e,n){return st(e,ot(n,Xt(le(e,n))))}function zr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>0?E({lo:1,hi:1}):t.hi<0?E({lo:0,hi:0}):t.lo===0&&t.hi===0?E({lo:.5,hi:.5}):{kind:"singular",at:0}}function Gr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>0?E({lo:1,hi:1}):t.hi<0?E({lo:-1,hi:-1}):t.lo===0&&t.hi===0?E({lo:0,hi:0}):{kind:"singular",at:0}}var gu=1.4616321449683622,qf=.8856031944108887;function jr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return zf(t)}function zf(e){if(e.hi>=0&&e.lo<=0)return{kind:"singular",at:0};if(e.lo<0){let n=Math.ceil(e.lo),t=Math.floor(e.hi);if(n<=t)return{kind:"singular",at:n};let i=te(e.lo),r=te(e.hi);return E({lo:Math.min(i,r),hi:Math.max(i,r)})}return e.lo>=gu?E({lo:te(e.lo),hi:te(e.hi)}):e.hi<=gu?E({lo:te(e.hi),hi:te(e.lo)}):E({lo:qf,hi:Math.max(te(e.lo),te(e.hi))})}function Ur(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return Gf(t)}function Gf(e){if(e.hi>=0&&e.lo<=0)return{kind:"singular",at:0};if(e.lo<0){let n=Math.ceil(e.lo),t=Math.floor(e.hi);if(n<=t)return{kind:"singular",at:n};let i=Ee(e.lo),r=Ee(e.hi);return E({lo:Math.min(i,r),hi:Math.max(i,r)})}return E({lo:Ee(e.lo),hi:Ee(e.hi)})}function Zr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=On(Math.round(t.lo)),r=On(Math.round(t.hi));return!Number.isFinite(i)||!Number.isFinite(r)?E({lo:Math.min(i,r),hi:Math.max(i,r)}):E({lo:i,hi:r})}function Yr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=Ln(Math.round(t.lo)),r=Ln(Math.round(t.hi));return!Number.isFinite(i)||!Number.isFinite(r)?E({lo:Math.min(i,r),hi:Math.max(i,r)}):E({lo:i,hi:r})}function bu(e,n){let t=T(e);if(!Array.isArray(t))return t;let i=T(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[an(Math.round(r.lo),Math.round(s.lo)),an(Math.round(r.lo),Math.round(s.hi)),an(Math.round(r.hi),Math.round(s.lo)),an(Math.round(r.hi),Math.round(s.hi))];return E({lo:Math.min(...o),hi:Math.max(...o)})}function yu(e,n){let t=T(e);if(!Array.isArray(t))return t;let i=T(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[Ne(Math.round(r.lo),Math.round(s.lo)),Ne(Math.round(r.lo),Math.round(s.hi)),Ne(Math.round(r.hi),Math.round(s.lo)),Ne(Math.round(r.hi),Math.round(s.hi))];return E({lo:Math.min(...o),hi:Math.max(...o)})}function xu(e,n){let t=T(e);if(!Array.isArray(t))return t;let i=T(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[Ge(Math.round(r.lo),Math.round(s.lo)),Ge(Math.round(r.lo),Math.round(s.hi)),Ge(Math.round(r.hi),Math.round(s.lo)),Ge(Math.round(r.hi),Math.round(s.hi))];return E({lo:Math.min(...o),hi:Math.max(...o)})}function Eu(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Bn(t.lo),hi:Bn(t.hi)})}function vu(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:$n(t.lo),hi:$n(t.hi)})}function Nu(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:tt(t.hi),hi:tt(t.lo)})}function Tu(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.pow(2,t.lo),hi:Math.pow(2,t.hi)})}function Iu(e,n){let t=T(e);if(!Array.isArray(t))return t;let i=T(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[Math.hypot(r.lo,s.lo),Math.hypot(r.lo,s.hi),Math.hypot(r.hi,s.lo),Math.hypot(r.hi,s.hi)],a=Math.min(...o);return r.lo<=0&&r.hi>=0&&(a=Math.min(a,Math.abs(s.lo),Math.abs(s.hi))),s.lo<=0&&s.hi>=0&&(a=Math.min(a,Math.abs(r.lo),Math.abs(r.hi))),r.lo<=0&&r.hi>=0&&s.lo<=0&&s.hi>=0&&(a=0),E({lo:a,hi:Math.max(...o)})}var _e=2*Math.PI,ie=Math.PI,We=Math.PI/2,ku=3*Math.PI/2;function Wr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=_e)return E({lo:-1,hi:1});let i=Math.sin(t.lo),r=Math.sin(t.hi),s=Math.min(i,r),o=Math.max(i,r);return se(t,We,_e)&&(o=1),se(t,ku,_e)&&(s=-1),E({lo:s,hi:o})}function Xr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=_e)return E({lo:-1,hi:1});let i=Math.cos(t.lo),r=Math.cos(t.hi),s=Math.min(i,r),o=Math.max(i,r);return se(t,0,_e)&&(o=1),se(t,ie,_e)&&(s=-1),E({lo:s,hi:o})}function Qr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=ie)return{kind:"singular"};if(se(t,We,ie)){let s=Math.ceil((t.lo-We)/ie);return{kind:"singular",at:We+s*ie}}let i=Math.tan(t.lo),r=Math.tan(t.hi);return i>1e10&&r<-1e10||i<-1e10&&r>1e10?{kind:"singular"}:E({lo:i,hi:r})}function Kr(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=ie)return{kind:"singular"};if(se(t,0,ie))return{kind:"singular",at:Math.ceil(t.lo/ie)*ie};let i=1/Math.tan(t.lo),r=1/Math.tan(t.hi);return E({lo:Math.min(i,r),hi:Math.max(i,r)})}function es(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=ie)return{kind:"singular"};if(se(t,We,ie)){let a=Math.ceil((t.lo-We)/ie);return{kind:"singular",at:We+a*ie}}let i=1/Math.cos(t.lo),r=1/Math.cos(t.hi),s=Math.min(i,r),o=Math.max(i,r);return se(t,0,_e)&&(s=Math.min(s,1),o=Math.max(o,1)),se(t,ie,_e)&&(s=Math.min(s,-1),o=Math.max(o,-1)),E({lo:s,hi:o})}function ns(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=ie)return{kind:"singular"};if(se(t,0,ie))return{kind:"singular",at:Math.ceil(t.lo/ie)*ie};let i=1/Math.sin(t.lo),r=1/Math.sin(t.hi),s=Math.min(i,r),o=Math.max(i,r);return se(t,We,_e)&&(s=Math.min(s,1),o=Math.max(o,1)),se(t,ku,_e)&&(s=Math.min(s,-1),o=Math.max(o,-1)),E({lo:s,hi:o})}function Qt(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo>1||t.hi<-1)return{kind:"empty"};if(t.lo<-1||t.hi>1){let i=Math.max(t.lo,-1),r=Math.min(t.hi,1);return{kind:"partial",value:{lo:Math.asin(i),hi:Math.asin(r)},domainClipped:t.lo<-1&&t.hi>1?"both":t.lo<-1?"lo":"hi"}}return E({lo:Math.asin(t.lo),hi:Math.asin(t.hi)})}function Kt(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo>1||t.hi<-1)return{kind:"empty"};if(t.lo<-1||t.hi>1){let i=Math.max(t.lo,-1),r=Math.min(t.hi,1);return{kind:"partial",value:{lo:Math.acos(r),hi:Math.acos(i)},domainClipped:t.lo<-1&&t.hi>1?"both":t.lo<-1?"lo":"hi"}}return E({lo:Math.acos(t.hi),hi:Math.acos(t.lo)})}function ei(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.atan(t.lo),hi:Math.atan(t.hi)})}function ts(e,n){let t=T(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(i.lo===i.hi&&r.lo===r.hi){let o=Math.atan2(i.lo,r.lo);return E({lo:o,hi:o})}let s=[];return s.push(Math.atan2(i.lo,r.lo)),s.push(Math.atan2(i.lo,r.hi)),s.push(Math.atan2(i.hi,r.lo)),s.push(Math.atan2(i.hi,r.hi)),r.lo<0&&i.lo<0&&i.hi>0?E({lo:-ie,hi:ie}):E({lo:Math.min(...s),hi:Math.max(...s)})}function at(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.sinh(t.lo),hi:Math.sinh(t.hi)})}function ut(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?E({lo:Math.cosh(t.lo),hi:Math.cosh(t.hi)}):t.hi<=0?E({lo:Math.cosh(t.hi),hi:Math.cosh(t.lo)}):E({lo:1,hi:Math.max(Math.cosh(t.lo),Math.cosh(t.hi))})}function is(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.tanh(t.lo),hi:Math.tanh(t.hi)})}function ni(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.asinh(t.lo),hi:Math.asinh(t.hi)})}function ti(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<1?{kind:"empty"}:t.lo<1?{kind:"partial",value:{lo:0,hi:Math.acosh(t.hi)},domainClipped:"lo"}:E({lo:Math.acosh(t.lo),hi:Math.acosh(t.hi)})}function ii(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo>=1||t.hi<=-1)return{kind:"empty"};if(t.lo<=-1||t.hi>=1){let i=Math.max(t.lo,-1+Number.EPSILON),r=Math.min(t.hi,1-Number.EPSILON);return{kind:"partial",value:{lo:Math.atanh(i),hi:Math.atanh(r)},domainClipped:t.lo<=-1&&t.hi>=1?"both":t.lo<=-1?"lo":"hi"}}return E({lo:Math.atanh(t.lo),hi:Math.atanh(t.hi)})}function rs(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return ue(t)?{kind:"singular",at:0}:ei(le(E({lo:1,hi:1}),E(t)))}function ss(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return ue(t)?{kind:"singular",at:0}:Qt(le(E({lo:1,hi:1}),E(t)))}function os(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return ue(t)?{kind:"singular",at:0}:Kt(le(E({lo:1,hi:1}),E(t)))}function as(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return ue(t)?{kind:"singular",at:0}:le(ut(t),at(t))}function us(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return ue(t)?{kind:"singular",at:0}:le(E({lo:1,hi:1}),at(t))}function ls(e){return le(E({lo:1,hi:1}),ut(e))}function cs(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return ue(t)?{kind:"singular",at:0}:ii(le(E({lo:1,hi:1}),E(t)))}function fs(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return ue(t)?{kind:"singular",at:0}:ni(le(E({lo:1,hi:1}),E(t)))}function ps(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n;return ue(t)?{kind:"singular",at:0}:ti(le(E({lo:1,hi:1}),E(t)))}var Hr=[4.49341,7.72525,10.90412,14.06619,17.22076,20.3713,23.51945,26.66605,29.8116,32.95639],jf=-.21724;function ms(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n,i=u=>u===0?1:Math.sin(u)/u,r=i(t.lo),s=r,o=u=>{u<r&&(r=u),u>s&&(s=u)};o(i(t.hi)),t.lo<=0&&t.hi>=0&&o(1);let a=Hr[Hr.length-1];for(let u of Hr)u>=t.lo&&u<=t.hi&&o(i(u)),-u>=t.lo&&-u<=t.hi&&o(i(-u));return(Math.abs(t.lo)>a||Math.abs(t.hi)>a)&&o(jf),E({lo:r,hi:s})}var Su=[],_u=[];for(let e=1;e<=20;e++)Su.push(Math.sqrt(2*e)),_u.push(Math.sqrt(2*e-1));function ds(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n,i=sn(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(sn(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of Su)o>=t.lo&&o<=t.hi&&s(sn(o)),-o>=t.lo&&-o<=t.hi&&s(sn(-o));return E({lo:i,hi:r})}function hs(e){let n=T(e);if(!Array.isArray(n))return n;let[t]=n,i=on(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(on(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of _u)o>=t.lo&&o<=t.hi&&s(on(o)),-o>=t.lo&&-o<=t.hi&&s(on(-o));return E({lo:i,hi:r})}function Xe(e){return"kind"in e?e:{kind:"interval",value:e}}function gs(e,n){let t=T(e,n);if(!Array.isArray(t))return"maybe";let[i,r]=t;return i.hi<r.lo?"true":i.lo>=r.hi?"false":"maybe"}function bs(e,n){let t=T(e,n);if(!Array.isArray(t))return"maybe";let[i,r]=t;return i.hi<=r.lo?"true":i.lo>r.hi?"false":"maybe"}function ys(e,n){let t=T(e,n);if(!Array.isArray(t))return"maybe";let[i,r]=t;return i.lo>r.hi?"true":i.hi<=r.lo?"false":"maybe"}function xs(e,n){let t=T(e,n);if(!Array.isArray(t))return"maybe";let[i,r]=t;return i.lo>=r.hi?"true":i.hi<r.lo?"false":"maybe"}function ri(e,n){let t=T(e,n);if(!Array.isArray(t))return"maybe";let[i,r]=t;return i.lo===i.hi&&r.lo===r.hi&&i.lo===r.lo?"true":i.hi<r.lo||r.hi<i.lo?"false":"maybe"}function Es(e,n){let t=ri(e,n);return t==="true"?"false":t==="false"?"true":"maybe"}function vs(e,n){return e==="false"||n==="false"?"false":e==="true"&&n==="true"?"true":"maybe"}function Ns(e,n){return e==="true"||n==="true"?"true":e==="false"&&n==="false"?"false":"maybe"}function Ts(e){return e==="true"?"false":e==="false"?"true":"maybe"}function Is(e,n,t,i){if(e==="true"||e==="false"||e==="maybe"){let p=e,m=n,d=t;switch(p){case"true":return Xe(m());case"false":return Xe(d());case"maybe":return Rn(Xe(m()),Xe(d()))}}let r=e,s=n,o=t,a=i,u=T(r);if(!Array.isArray(u))return u;let[l]=u;switch(s(l)){case"true":return Xe(o(l));case"false":return Xe(a(l));case"maybe":let p=Xe(o(l)),m=Xe(a(l));return Rn(p,m)}}function ks(e,n,t){let i=T(e,n,t);if(!Array.isArray(i))return i;let[r,s,o]=i,a=Math.max(r.lo,s.lo),u=Math.min(r.hi,o.hi);return a>u?{kind:"empty"}:{kind:"interval",value:{lo:a,hi:u}}}var Mu={ok:E,point:hr,containsExtremum:se,unionResults:Rn,mergeDomainClip:Ht,isPoint:gr,containsZero:ue,isPositive:br,isNegative:rt,isNonNegative:yr,isNonPositive:xr,width:Er,midpoint:vr,getValue:Nr,unwrap:Tr,unwrapOrPropagate:T,add:Ir,sub:st,mul:ot,div:le,negate:kr,sqrt:_r,square:Mr,pow:Wt,powInterval:wr,exp:Ar,ln:$r,log10:Cr,log2:Rr,abs:Dr,floor:Pr,ceil:Fr,round:Xt,fract:Or,trunc:Lr,min:Br,max:Vr,mod:Jr,remainder:qr,heaviside:zr,sign:Gr,gamma:jr,gammaln:Ur,factorial:Zr,factorial2:Yr,binomial:bu,gcd:yu,lcm:xu,chop:Eu,erf:vu,erfc:Nu,exp2:Tu,hypot:Iu,sin:Wr,cos:Xr,tan:Qr,cot:Kr,sec:es,csc:ns,asin:Qt,acos:Kt,atan:ei,atan2:ts,sinh:at,cosh:ut,tanh:is,asinh:ni,acosh:ti,atanh:ii,acot:rs,acsc:ss,asec:os,coth:as,csch:us,sech:ls,acoth:cs,acsch:fs,asech:ps,sinc:ms,fresnelS:ds,fresnelC:hs,less:gs,lessEqual:bs,greater:ys,greaterEqual:xs,equal:ri,notEqual:Es,and:vs,or:Ns,not:Ts,piecewise:Is,clamp:ks};var Uf={Add:["_IA.add",20],Negate:["_IA.negate",20],Subtract:["_IA.sub",20],Multiply:["_IA.mul",20],Divide:["_IA.div",20],Equal:["_IA.equal",20],NotEqual:["_IA.notEqual",20],LessEqual:["_IA.lessEqual",20],GreaterEqual:["_IA.greaterEqual",20],Less:["_IA.less",20],Greater:["_IA.greater",20],And:["_IA.and",20],Or:["_IA.or",20],Not:["_IA.not",20]},Ss={Add:(e,n)=>{if(e.length===0)return"_IA.point(0)";if(e.length===1)return n(e[0]);let t=n(e[0]);for(let i=1;i<e.length;i++)t=`_IA.add(${t}, ${n(e[i])})`;return t},Subtract:(e,n)=>{if(e.length===0)return"_IA.point(0)";if(e.length===1)return`_IA.negate(${n(e[0])})`;if(e.length===2)return`_IA.sub(${n(e[0])}, ${n(e[1])})`;let t=n(e[0]);for(let i=1;i<e.length;i++)t=`_IA.sub(${t}, ${n(e[i])})`;return t},Multiply:(e,n)=>{if(e.length===0)return"_IA.point(1)";if(e.length===1)return n(e[0]);let t=n(e[0]);for(let i=1;i<e.length;i++)t=`_IA.mul(${t}, ${n(e[i])})`;return t},Divide:(e,n)=>{if(e.length===0)return"_IA.point(1)";if(e.length===1)return n(e[0]);if(e.length===2)return`_IA.div(${n(e[0])}, ${n(e[1])})`;let t=n(e[0]);for(let i=1;i<e.length;i++)t=`_IA.div(${t}, ${n(e[i])})`;return t},Negate:(e,n)=>`_IA.negate(${n(e[0])})`,Abs:(e,n)=>`_IA.abs(${n(e[0])})`,Ceil:(e,n)=>`_IA.ceil(${n(e[0])})`,Exp:(e,n)=>`_IA.exp(${n(e[0])})`,Floor:(e,n)=>`_IA.floor(${n(e[0])})`,Ln:(e,n)=>`_IA.ln(${n(e[0])})`,Log:(e,n)=>e.length===1?`_IA.log10(${n(e[0])})`:`_IA.div(_IA.ln(${n(e[0])}), _IA.ln(${n(e[1])}))`,Lb:(e,n)=>`_IA.log2(${n(e[0])})`,Max:(e,n)=>{if(e.length===0)return"_IA.point(-Infinity)";if(e.length===1)return n(e[0]);let t=n(e[0]);for(let i=1;i<e.length;i++)t=`_IA.max(${t}, ${n(e[i])})`;return t},Min:(e,n)=>{if(e.length===0)return"_IA.point(Infinity)";if(e.length===1)return n(e[0]);let t=n(e[0]);for(let i=1;i<e.length;i++)t=`_IA.min(${t}, ${n(e[i])})`;return t},Power:(e,n)=>{let t=e[0],i=e[1];if(t===null)throw new Error("Power: no argument");if(_(t,"ExponentialE"))return`_IA.exp(${n(i)})`;if(X(i)&&i.im===0){let r=i.re;return r===.5?`_IA.sqrt(${n(t)})`:r===2?`_IA.square(${n(t)})`:`_IA.pow(${n(t)}, ${r})`}return`_IA.powInterval(${n(t)}, ${n(i)})`},Root:(e,n)=>{let[t,i]=e;if(t===null)throw new Error("Root: no argument");return i===null?`_IA.sqrt(${n(t)})`:i?.re===2?`_IA.sqrt(${n(t)})`:X(i)&&i.im===0?`_IA.pow(${n(t)}, ${1/i.re})`:`_IA.powInterval(${n(t)}, _IA.div(_IA.point(1), ${n(i)}))`},Round:(e,n)=>`_IA.round(${n(e[0])})`,Heaviside:(e,n)=>`_IA.heaviside(${n(e[0])})`,Sign:(e,n)=>`_IA.sign(${n(e[0])})`,Sqrt:(e,n)=>`_IA.sqrt(${n(e[0])})`,Square:(e,n)=>`_IA.square(${n(e[0])})`,Sin:(e,n)=>`_IA.sin(${n(e[0])})`,Cos:(e,n)=>`_IA.cos(${n(e[0])})`,Tan:(e,n)=>`_IA.tan(${n(e[0])})`,Cot:(e,n)=>`_IA.cot(${n(e[0])})`,Sec:(e,n)=>`_IA.sec(${n(e[0])})`,Csc:(e,n)=>`_IA.csc(${n(e[0])})`,Arcsin:(e,n)=>`_IA.asin(${n(e[0])})`,Arccos:(e,n)=>`_IA.acos(${n(e[0])})`,Arctan:(e,n)=>`_IA.atan(${n(e[0])})`,Arccot:(e,n)=>`_IA.acot(${n(e[0])})`,Arccsc:(e,n)=>`_IA.acsc(${n(e[0])})`,Arcsec:(e,n)=>`_IA.asec(${n(e[0])})`,Sinh:(e,n)=>`_IA.sinh(${n(e[0])})`,Cosh:(e,n)=>`_IA.cosh(${n(e[0])})`,Tanh:(e,n)=>`_IA.tanh(${n(e[0])})`,Coth:(e,n)=>`_IA.coth(${n(e[0])})`,Csch:(e,n)=>`_IA.csch(${n(e[0])})`,Sech:(e,n)=>`_IA.sech(${n(e[0])})`,Arsinh:(e,n)=>`_IA.asinh(${n(e[0])})`,Arcosh:(e,n)=>`_IA.acosh(${n(e[0])})`,Artanh:(e,n)=>`_IA.atanh(${n(e[0])})`,Arcoth:(e,n)=>`_IA.acoth(${n(e[0])})`,Arcsch:(e,n)=>`_IA.acsch(${n(e[0])})`,Arsech:(e,n)=>`_IA.asech(${n(e[0])})`,Sinc:(e,n)=>`_IA.sinc(${n(e[0])})`,FresnelS:(e,n)=>`_IA.fresnelS(${n(e[0])})`,FresnelC:(e,n)=>`_IA.fresnelC(${n(e[0])})`,Factorial:(e,n)=>`_IA.factorial(${n(e[0])})`,Factorial2:(e,n)=>`_IA.factorial2(${n(e[0])})`,Gamma:(e,n)=>`_IA.gamma(${n(e[0])})`,GammaLn:(e,n)=>`_IA.gammaln(${n(e[0])})`,Binomial:(e,n)=>`_IA.binomial(${n(e[0])}, ${n(e[1])})`,GCD:(e,n)=>`_IA.gcd(${n(e[0])}, ${n(e[1])})`,LCM:(e,n)=>`_IA.lcm(${n(e[0])}, ${n(e[1])})`,Chop:(e,n)=>`_IA.chop(${n(e[0])})`,Erf:(e,n)=>`_IA.erf(${n(e[0])})`,Erfc:(e,n)=>`_IA.erfc(${n(e[0])})`,Exp2:(e,n)=>`_IA.exp2(${n(e[0])})`,Arctan2:(e,n)=>`_IA.atan2(${n(e[0])}, ${n(e[1])})`,Hypot:(e,n)=>`_IA.hypot(${n(e[0])}, ${n(e[1])})`,Fract:(e,n)=>`_IA.fract(${n(e[0])})`,Truncate:(e,n)=>`_IA.trunc(${n(e[0])})`,Mod:(e,n)=>`_IA.mod(${n(e[0])}, ${n(e[1])})`,Remainder:(e,n)=>`_IA.remainder(${n(e[0])}, ${n(e[1])})`,Sum:(e,n,t)=>Au("Sum",e,n,t),Product:(e,n,t)=>Au("Product",e,n,t),If:(e,n)=>{if(e.length!==3)throw new Error("If: wrong number of arguments");return`_IA.piecewise(
|
|
923
|
+
${n(e[0])},
|
|
924
|
+
() => ${n(e[1])},
|
|
925
|
+
() => ${n(e[2])}
|
|
926
|
+
)`},Which:(e,n)=>{if(e.length<2||e.length%2!==0)throw new Error("Which: expected even number of arguments (condition/value pairs)");let t=i=>{if(i>=e.length)return"{ kind: 'empty' }";let r=e[i],s=e[i+1];return _(r,"True")?n(s):`_IA.piecewise(
|
|
927
|
+
${n(r)},
|
|
928
|
+
() => ${n(s)},
|
|
929
|
+
() => ${t(i+2)}
|
|
930
|
+
)`};return t(0)},Equal:(e,n)=>`_IA.equal(${n(e[0])}, ${n(e[1])})`,NotEqual:(e,n)=>`_IA.notEqual(${n(e[0])}, ${n(e[1])})`,LessEqual:(e,n)=>`_IA.lessEqual(${n(e[0])}, ${n(e[1])})`,GreaterEqual:(e,n)=>`_IA.greaterEqual(${n(e[0])}, ${n(e[1])})`,Less:(e,n)=>`_IA.less(${n(e[0])}, ${n(e[1])})`,Greater:(e,n)=>`_IA.greater(${n(e[0])}, ${n(e[1])})`,And:(e,n)=>`_IA.and(${n(e[0])}, ${n(e[1])})`,Or:(e,n)=>`_IA.or(${n(e[0])}, ${n(e[1])})`,Not:(e,n)=>`_IA.not(${n(e[0])})`},Zf=100;function Yf(e){e.operator;let n=e,t=_(n.op1)?n.op1.symbol:"_",i=n.op2,r=n.op3,s=i.re,o=r.re;return{index:t,lowerExpr:i,upperExpr:r,lowerNum:!isNaN(s)&&Number.isFinite(s)?Math.floor(s):void 0,upperNum:!isNaN(o)&&Number.isFinite(o)?Math.floor(o):void 0}}function wu(e,n,t){return n!==void 0?String(n):`Math.floor((${g.compile(e,t)}).hi)`}function Au(e,n,t,i){if(!n[0])throw new Error(`${e}: no body`);if(!n[1])throw new Error(`${e}: no indexing set`);let{index:r,lowerExpr:s,upperExpr:o,lowerNum:a,upperNum:u}=Yf(n[1]),l=e==="Sum",c=l?"_IA.add":"_IA.mul",p=l?"_IA.point(0)":"_IA.point(1)",m=a!==void 0&&u!==void 0;if(m&&a>u)return p;if(m&&u-a+1<=Zf){let R=[];for(let O=a;O<=u;O++){let W={...i,var:j=>j===r?`_IA.point(${O})`:i.var(j)};R.push(g.compile(n[0],W))}let P=R[R.length-1];for(let O=R.length-2;O>=0;O--)P=`${c}(${R[O]}, ${P})`;return P}let d=wu(s,a,i),b=wu(o,u,i),v=g.tempVar(),k=g.compile(n[0],{...i,var:w=>w===r?`_IA.point(${r})`:i.var(w)});return`(() => { let ${v} = ${p}; const _upper = ${b}; for (let ${r} = ${d}; ${r} <= _upper; ${r}++) { ${v} = ${c}(${v}, ${k}); } return ${v}; })()`}var _s=class extends Function{IA=Mu;constructor(n,t=""){return super("_IA","_",t?`${t};return ${n}`:`return ${n}`),new Proxy(this,{apply:(i,r,s)=>{try{let o=s.map(Cu);return super.apply(r,[this.IA,...o])}catch{return{kind:"entire"}}},get:(i,r)=>r==="toString"?()=>n:r==="isCompiled"?!0:i[r]})}};function $u(e){return e!==null&&typeof e=="object"}function Hf(e){return $u(e)&&"lo"in e&&"hi"in e}function Cu(e){if(e==null||Hf(e))return e;if($u(e)){let n={};for(let[t,i]of Object.entries(e))n[t]=Cu(i);return n}return typeof e=="number"?{lo:e,hi:e}:e}var Ms=class{getOperators(){return Uf}getFunctions(){return Ss}createTarget(n={}){return{language:"interval-javascript",operators:()=>{},functions:t=>Ss[t],var:t=>({Pi:"_IA.point(Math.PI)",ExponentialE:"_IA.point(Math.E)",NaN:"{ lo: NaN, hi: NaN }",ImaginaryUnit:"{ lo: NaN, hi: NaN }",Half:"_IA.point(0.5)",MachineEpsilon:"_IA.point(Number.EPSILON)",GoldenRatio:"_IA.point((1 + Math.sqrt(5)) / 2)",CatalanConstant:"_IA.point(0.91596559417721901)",EulerGamma:"_IA.point(0.57721566490153286)"})[t],string:t=>JSON.stringify(t),number:t=>`_IA.point(${t})`,indent:0,ws:t=>t??"",preamble:"",...n}}compile(n,t={}){let{functions:i,vars:r,preamble:s}=t,o=n.unknowns,a={},u="";if(i)for(let[c,p]of Object.entries(i))typeof p=="function"?(u+=`const ${c} = ${p.toString()};
|
|
931
|
+
`,a[c]=c):typeof p=="string"&&(a[c]=p);let l=this.createTarget({functions:c=>a?.[c]?a[c]:Ss[c],var:c=>{if(r&&c in r)return r[c];let p={Pi:"_IA.point(Math.PI)",ExponentialE:"_IA.point(Math.E)",NaN:"{ lo: NaN, hi: NaN }",ImaginaryUnit:"{ lo: NaN, hi: NaN }",Half:"_IA.point(0.5)",MachineEpsilon:"_IA.point(Number.EPSILON)",GoldenRatio:"_IA.point((1 + Math.sqrt(5)) / 2)",CatalanConstant:"_IA.point(0.91596559417721901)",EulerGamma:"_IA.point(0.57721566490153286)"};if(c in p)return p[c];if(o.includes(c))return`_.${c}`},preamble:(s??"")+u});return Wf(n,l)}};function Wf(e,n){let t;try{t=g.compile(e,n)}catch{return{target:"interval-js",success:!1,code:""}}let i=new _s(t,n.preamble);return{target:"interval-js",success:!0,code:t,calling:"expression",run:i}}var N2="0.55.0";export{g as BaseCompiler,pr as GLSLTarget,ln as GPUShaderTarget,Ms as IntervalJavaScriptTarget,lr as JavaScriptTarget,dr as PythonTarget,mr as WGSLTarget,gc as compile,N2 as version};
|
|
932
|
+
/*! Bundled license information:
|
|
933
|
+
|
|
934
|
+
complex-esm/dist/src/complex.js:
|
|
935
|
+
(**
|
|
936
|
+
* @license Complex.js v2.1.1 12/05/2020
|
|
937
|
+
*
|
|
938
|
+
* Copyright (c) 2020, Robert Eisele (robert@xarg.org)
|
|
939
|
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
|
940
|
+
**)
|
|
941
|
+
*/
|