@cortex-js/compute-engine 0.55.4 → 0.55.6
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 +137 -545
- package/dist/compile.min.esm.js +60 -430
- package/dist/compile.min.umd.cjs +66 -436
- package/dist/compile.umd.cjs +137 -545
- package/dist/compute-engine.esm.js +227 -563
- package/dist/compute-engine.min.esm.js +68 -437
- package/dist/compute-engine.min.umd.cjs +68 -437
- package/dist/compute-engine.umd.cjs +227 -563
- package/dist/core.esm.js +225 -562
- package/dist/core.min.esm.js +67 -436
- package/dist/core.min.umd.cjs +67 -436
- package/dist/core.umd.cjs +225 -562
- package/dist/interval.esm.js +136 -60
- package/dist/interval.min.esm.js +7 -7
- package/dist/interval.min.umd.cjs +7 -7
- package/dist/interval.umd.cjs +136 -60
- package/dist/latex-syntax.esm.js +219 -74
- package/dist/latex-syntax.min.esm.js +7 -6
- package/dist/latex-syntax.min.umd.cjs +7 -6
- package/dist/latex-syntax.umd.cjs +219 -74
- 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 +2 -2
- package/dist/numerics.min.esm.js +2 -2
- package/dist/numerics.min.umd.cjs +2 -2
- package/dist/numerics.umd.cjs +2 -2
- package/dist/types/big-decimal/big-decimal.d.ts +1 -1
- package/dist/types/big-decimal/index.d.ts +1 -1
- package/dist/types/big-decimal/transcendentals.d.ts +1 -1
- package/dist/types/big-decimal/utils.d.ts +1 -1
- 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 +1 -1
- package/dist/types/compute-engine/assume.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/abstract-boxed-expression.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/apply.d.ts +1 -1
- 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 +1 -1
- 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 +1 -1
- 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 +1 -1
- 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 -1
- 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 +1 -1
- 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/constant-folding.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 -47
- 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 -48
- 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 +1 -1
- package/dist/types/compute-engine/engine-extension-contracts.d.ts +1 -1
- package/dist/types/compute-engine/engine-library-bootstrap.d.ts +1 -1
- package/dist/types/compute-engine/engine-numeric-configuration.d.ts +1 -1
- 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 +1 -1
- package/dist/types/compute-engine/free-functions.d.ts +1 -1
- 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 +2 -1
- 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 +1 -1
- 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 +1 -1
- 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 +4 -2
- package/dist/types/compute-engine/latex-syntax/tokenizer.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/types.d.ts +1 -1
- 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 +1 -1
- 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 +1 -1
- package/dist/types/compute-engine/numeric-value/exact-numeric-value.d.ts +1 -1
- package/dist/types/compute-engine/numeric-value/machine-numeric-value.d.ts +1 -1
- package/dist/types/compute-engine/numeric-value/types.d.ts +1 -1
- package/dist/types/compute-engine/numerics/bigint.d.ts +1 -1
- 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 +1 -1
- 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 +1 -1
- 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 +1 -1
- package/dist/types/compute-engine/numerics/statistics.d.ts +1 -1
- package/dist/types/compute-engine/numerics/strings.d.ts +1 -1
- package/dist/types/compute-engine/numerics/types.d.ts +1 -1
- 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 +1 -1
- package/dist/types/compute-engine/types-engine.d.ts +1 -1
- package/dist/types/compute-engine/types-evaluation.d.ts +1 -1
- package/dist/types/compute-engine/types-expression.d.ts +1 -1
- package/dist/types/compute-engine/types-kernel-evaluation.d.ts +1 -1
- package/dist/types/compute-engine/types-kernel-serialization.d.ts +1 -1
- 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 +2 -1
- package/dist/types/core.d.ts +1 -1
- package/dist/types/interval.d.ts +1 -1
- package/dist/types/latex-syntax.d.ts +2 -2
- 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 +1 -1
- package/package.json +1 -1
- package/dist/types/compute-engine/compilation/fractal-orbit.d.ts +0 -13
package/dist/compile.min.esm.js
CHANGED
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
/** Compute Engine 0.55.
|
|
2
|
-
function li(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 li(T=>e(1/T),1/n,{rtol:a,atol:o,maxeval:u,contract:Math.abs(i)>1?1/i:i,step:1/r,power:s});let c=r,f=Math.pow(1/i,s),d=e(n+c),m=[d],b=1/0,E=1;for(;E<u;){E+=1,c*=i,m.push(e(n+c));let T=f,M=1/0;for(let C=m.length-2;C>=0;C--){let P=m[C];m[C]=m[C+1]+(m[C+1]-m[C])/(T-1);let O=Math.abs(m[C]-P);M=Math.min(M,O),O<b&&(d=m[C],b=O),T*=f}if(M>l*b||!isFinite(M)||b<=Math.max(a*Math.abs(d),o))break}return[d,b]}var Rs=new Map;function F(e){if(e<=100){let n=Rs.get(e);return n===void 0&&(n=10n**BigInt(e),Rs.set(e,n)),n}return 10n**BigInt(e)}function Ps(e,n,t){return e*n/t}function Fs(e,n,t){return e*t/n}function On(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=Ds(e,n)}else t=Ds(e,n);let s=e*n,o;do o=t,t=(t+s/t)/2n;while(Te(t-o)>1n);let a=(t+s/t)/2n,u=Te(t*t-s);return Te(a*a-s)<u?a:t}function Ds(e,n){let i=K(e),r=Math.max(0,i-15),s=Number(r>0?e/F(r):e),o=K(n),a=Math.max(0,o-15),u=Number(a>0?n/F(a):n),l=r+a,c=Math.floor(l/2),f=Math.sqrt(s*u);l%2!==0&&(f*=3.1622776601683795);let d=BigInt(Math.round(f))*F(c);return d>0n?d:1n}function Te(e){return e<0n?-e:e}function K(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 pi(e,n){if(e===0n)return n;let t=0,i=e,r=n/2n;for(;Te(i)>r;)i=i/2n,t++;let s=n,o=i;s+=o;for(let a=2;o=o*i/(BigInt(a)*n),Te(o)!==0n;a++)s+=o;for(let a=0;a<t;a++)s=s*s/n;return s}function Ls(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=ci(e,n)}else r=ci(e,n)}else{s=e;let u=2n*n,l=n/2n;for(;s>u||s<l;)s=On(s,n),o++;r=ci(s,n)}let a=0n;for(let u=0;u<100;u++){let l=pi(r,n);if(l===0n){r=r/2n;continue}let c=r+s*n/l-n,f=Te(c-r);if(f<=1n||f<100000n&&a>0n&&a<100000n&&f*4n>=a)break;a=f,r=c}for(let u=0;u<o;u++)r=2n*r;return r}function ci(e,n){let t=K(e),i=K(n);return BigInt(t-i)*2302585n*n/1000000n}var mt="314159265358979323846264338327950288419716939937510582097494459230781640628620899862803482534211706798214808651328230664709384460955058223172535940812848111745028410270193852110555964462294895493038196442881097566593344612847564823378678316527120190914564856692346034861045432664821339360726024914127372458700660631558817488152092096282925409171536436789259036001133053054882046652138414695194151160943305727036575959195309218611738193261179310511854807446237996274956735188575272489122793818301194912983367336244065664308602139494639522473719070217986094370277053921717629317675238467481846766940513200056812714526356082778577134275778960917363717872146844090122495343014654958537105079227968925892354201995611212902196086403441815981362977477130996051870721134999999837297804995105973173281609631859502445945534690830264252230825334468503526193118817101000313783875288658753320838142061717766914730359825349042875546873115956286388235378759375195778185778053217122680661300192787661119590921642019893809525720106548586327886593615338182796823030195203530185296899577362259941389124972177528347913151557485724245415069595082953311686172785588907509838175463746493931925506040092770167113900984882401285836160356370766010471018194295559619894676783744944825537977472684710404753464620804668425906949129331367702898915210475216205696602405803815019351125338243003558764024749647326391419927260426992279678235478163600934172164121992458631503028618297455570674983850549458858692699569092721079750930295532116534498720275596023648066549911988183479775356636980742654252786255181841757467289097777279380008164706001614524919217321721477235014144197356854816136115735255213347574184946843852332390739414333454776241686251898356948556209921922218427255025425688767179049460165346680498862723279178608578438382796797668145410095388378636095068006422512520511739298489608412848862694560424196528502221066118630674427862203919494504712371378696095636437191728746776465757396241389086583264599581339047802759009946576407895126946839835259570982582262052248940772671947826848260147699090264013639443745530506820349625245174939965143142980919065925093722169646151570985838741059788595977297549893016175392846813826868386894277415599185592524595395943104997252468084598727364469584865383673622262609912460805124388439045124413654976278079771569143599770012961608944169486855584840635",dt=null;function fi(e){if(dt!==null&&dt.scale===e)return dt.value;let t=K(e)-1+10,i=mt.slice(0,t+1),r=BigInt(i),s=i.length-1,o=r*e/F(s);return dt={scale:e,value:o},o}function ht(e,n){if(e===0n)return[0n,n];let t=fi(n),i=2n*t,r=t/2n,s,o=Te(e);if(o>n*(1n<<30n)){let P=K(o)-K(n)+20,O=n*F(P),Q=e*F(P),_e=2n*fi(O),Y=Q%_e;Y<0n&&(Y+=_e),s=Y/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=K(n)-1,c=Math.min(18,Math.max(2,Math.ceil(.87*Math.sqrt(l)))),f=0,d=n>>BigInt(c);for(;s>d;)s=s/2n,f++;let m=s,b=n,E=s,T=n,M=s*s,C=n*n;for(let P=2;;P+=2){if(T=T*M/(BigInt(P)*BigInt(P-1)*C),T===0n){E=E*M/(BigInt(P+1)*BigInt(P)*C),E!==0n&&(P%4===2?(b-=T,m-=E):(b+=T,m+=E));break}if(E=E*M/(BigInt(P+1)*BigInt(P)*C),P%4===2?(b-=T,m-=E):(b+=T,m+=E),E===0n)break}for(let P=0;P<f;P++){let O=2n*m*b/n,Q=2n*b*b/n-n;m=O,b=Q}return[a*m,u*b]}function Ln(e,n){if(e===0n)return 0n;if(e<0n)return-Ln(-e,n);let i=fi(n)/2n;if(e>n){let f=n*n/e;return i-Ln(f,n)}let r=4n*n/10n,s=0,o=e;for(;o>r;){let f=o*o,d=(n*n+f)/n,m=On(d,n);o=o*n/(n+m),s++}let a=o,u=o,l=o*o,c=n*n;for(let f=3;u=u*l/c,u!==0n;f+=2)f%4===3?a-=u/BigInt(f):a+=u/BigInt(f);for(let f=0;f<s;f++)a=2n*a;return a}var di=NaN,y=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(mt[0]+"."+mt.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]=gt(n,0);return}if(typeof n=="number"){[this.significand,this.exponent]=zu(n);return}[this.significand,this.exponent]=Vs(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 di;let m=this.exponent;if(Number.isNaN(m))return di;if(n===0)return this.significand===0n?0:this.significand>0n?1:-1;if(!Number.isFinite(m))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)&&m>=0&&m<=15){let b=this.significand*F(m),E=BigInt(n);return b<E?-1:b>E?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 di;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=K(r),a=K(s),u=o+t,l=a+i;if(u!==l){let m=r>0n?1:-1;return u>l?m:-m}let c=r,f=s,d=Math.abs(t-i);if(d>1e3){let m=o,b=a,E=Math.max(m,b)+1;m<E&&(c=c*F(E-m)),b<E&&(f=f*F(E-b))}else t<i?f=f*F(d):c=c*F(d);return c<f?-1:c>f?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 V(this.significand+n.significand,t);let o=t-i;return o>0?V(this.significand*F(o)+n.significand,i):V(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 V(this.significand-n.significand,t);let o=t-i;return o>0?V(this.significand*F(o)-n.significand,i):V(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 V(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)?V(-n,this.exponent):n>0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY}abs(){return this.significand>=0n?this:Number.isFinite(this.exponent)?V(-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(V(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(V(1n,0)):t}return this}round(){let n=this.exponent;if(n>=0)return this;if(Number.isFinite(n)){let t=V(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 V(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 V(0n,0);let u=e.precision,l=10,c=r<0n?-r:r,f=s<0n?-s:s,d=K(c),m=K(f),b=u+l+Math.max(0,m-d),E=F(b),T=r*E/s,M=t-i-b;return V(T,M).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 V(0n,0)}inv(){return V(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?V(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 V(1n,0);if(!this.isFinite())return t>0n?this.significand<0n&&t%2n!==0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY:V(0n,0);if(this.isZero())return t>0n?V(0n,0):e.POSITIVE_INFINITY;if(t<0n)return this.pow(n.neg()).inv();let i=this.significand<0n?-this.significand:this.significand,r=K(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 V(0n,0);let o=e.precision,a=V(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 f=F(-s),d=r/f,m=r%f,b=f/2n;m>b?o=d+1n:m<b||f%2n!==0n||d%2n===0n?o=d:o=d+1n}let a=i&&o!==0n?"-":"",u=o.toString();if(t===0)return`${a}${u}`;if(u.length<=t){let f=u.padStart(t,"0");return`${a}0.${f}`}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=K(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 V(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 V(e,n){let[t,i]=gt(e,n),r=Object.create(y.prototype);return r.significand=t,r.exponent=i,r}var Os=1000000000n,Bs=1000n;function gt(e,n){if(e===0n)return[0n,0];for(;e%Os===0n;)e/=Os,n+=9;for(;e%Bs===0n;)e/=Bs,n+=3;for(;e%10n===0n;)e/=10n,n+=1;return[e,n]}function zu(e){return Number.isNaN(e)?[0n,NaN]:e===1/0?[1n,1/0]:e===-1/0?[-1n,1/0]:Number.isInteger(e)?gt(BigInt(e),0):Vs(e.toString())}function Vs(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 gt(l,c+t)}function Fe(e,n){let t=F(n),i=e.exponent+n;return i>=0?[e.significand*F(i),t]:[e.significand/F(-i),t]}function Le(e,n,t){if(e===0n)return y.ZERO;let i=e<0n,r=i?-e:e,s=K(r);if(s>t){let l=s-t,c=F(l),f=c/2n,d=r%c;r=r/c,d>=f&&(r+=1n);let m=K(n)-1,b=l-m,E=i?-r:r;return V(E,b)}let a=-(K(n)-1),u=i?-r:r;return V(u,a)}y.prototype.sqrt=function(){if(this.isNaN())return y.NAN;if(this.isZero())return y.ZERO;if(!this.isFinite())return this.significand>0n?y.POSITIVE_INFINITY:y.NAN;if(this.significand<0n)return y.NAN;let e=y.precision,n=e+10,[t,i]=Fe(this,n),r=On(t,i);return Le(r,i,e)};y.prototype.cbrt=function(){if(this.isNaN())return y.NAN;if(this.isZero())return y.ZERO;if(!this.isFinite())return this.significand>0n?y.POSITIVE_INFINITY:y.NEGATIVE_INFINITY;if(this.significand<0n)return this.neg().cbrt().neg();let e=y.precision,n=e+10,[t,i]=Fe(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=zs(t,i)}else s=zs(t,i);let u;do{u=s;let l=s*s;if(l===0n){s=1n;break}s=(2n*s+r/l)/3n}while(Te(s-u)>1n);{let l=(2n*s+r/(s*s))/3n,c=Te(s*s*s-r);Te(l*l*l-r)<c&&(s=l)}return Le(s,i,e)};y.sqrt=function(e){return e.sqrt()};y.cbrt=function(e){return e.cbrt()};y.prototype.exp=function(){if(this.isNaN())return y.NAN;if(!this.isFinite())return this.significand>0n?y.POSITIVE_INFINITY:y.ZERO;if(this.isZero())return y.ONE;let e=y.precision,n=e+15,[t,i]=Fe(this,n),r=pi(t,i);return Le(r,i,e)};y.prototype.ln=function(){if(this.isNaN())return y.NAN;if(!this.isFinite())return this.significand>0n?y.POSITIVE_INFINITY:y.NAN;if(this.isZero())return y.NEGATIVE_INFINITY;if(this.significand<0n)return y.NAN;if(this.eq(1))return y.ZERO;let e=y.precision,n=e+15,[t,i]=Fe(this,n),r=Ls(t,i);return Le(r,i,e)};y.prototype.log=function(e){let n=e instanceof y?e:new y(e);return this.ln().div(n.ln())};y.exp=function(e){return e.exp()};y.ln=function(e){return e.ln()};y.log10=function(e){return e.log(10)};y.prototype.sin=function(){if(this.isNaN())return y.NAN;if(!this.isFinite())return y.NAN;if(this.isZero())return y.ZERO;let e=y.precision,n=e+15,[t,i]=Fe(this,n),[r]=ht(t,i);return Le(r,i,e)};y.prototype.cos=function(){if(this.isNaN())return y.NAN;if(!this.isFinite())return y.NAN;if(this.isZero())return y.ONE;let e=y.precision,n=e+15,[t,i]=Fe(this,n),[,r]=ht(t,i);return Le(r,i,e)};y.prototype.tan=function(){if(this.isNaN())return y.NAN;if(!this.isFinite())return y.NAN;if(this.isZero())return y.ZERO;let e=y.precision,n=e+15,[t,i]=Fe(this,n),[r,s]=ht(t,i);if(s===0n)return r>0n?y.POSITIVE_INFINITY:y.NEGATIVE_INFINITY;let o=r*i/s;return Le(o,i,e)};y.prototype.atan=function(){if(this.isNaN())return y.NAN;if(this.isZero())return y.ZERO;if(!this.isFinite()){let s=y.PI.div(y.TWO);return this.significand>0n?s:s.neg()}let e=y.precision,n=e+15,[t,i]=Fe(this,n),r=Ln(t,i);return Le(r,i,e)};y.prototype.asin=function(){if(this.isNaN())return y.NAN;if(!this.isFinite())return y.NAN;if(this.isZero())return y.ZERO;let e=this.abs(),n=y.ONE;if(e.gt(n))return y.NAN;if(e.eq(n)){let f=y.PI.div(y.TWO);return this.significand>0n?f:f.neg()}let t=y.precision,i=t+20,[r,s]=Fe(this,i),o=Ps(r,r,s),a=s-o,u=On(a,s),l=Fs(r,u,s),c=Ln(l,s);return Le(c,s,t)};y.prototype.acos=function(){return this.isNaN()?y.NAN:this.isFinite()?this.abs().gt(y.ONE)?y.NAN:this.eq(1)?y.ZERO:this.eq(-1)?y.PI:y.PI.div(y.TWO).sub(this.asin()):y.NAN};y.sin=function(e){return e.sin()};y.cos=function(e){return e.cos()};y.tan=function(e){return e.tan()};y.asin=function(e){return e.asin()};y.acos=function(e){return e.acos()};y.atan=function(e){return e.atan()};y.atan2=function(e,n){let t=e instanceof y?e:new y(e);if(t.isNaN()||n.isNaN())return y.NAN;let i=y.PI,r=i.div(y.TWO);if(n.isZero())return t.isZero()?y.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)};y.prototype.sinh=function(){if(this.isNaN())return y.NAN;if(this.isZero())return y.ZERO;if(!this.isFinite())return this.significand>0n?y.POSITIVE_INFINITY:y.NEGATIVE_INFINITY;let e=this.exp(),n=e.inv();return e.sub(n).div(y.TWO)};y.prototype.cosh=function(){if(this.isNaN())return y.NAN;if(this.isZero())return y.ONE;if(!this.isFinite())return y.POSITIVE_INFINITY;let e=this.exp(),n=e.inv();return e.add(n).div(y.TWO)};y.prototype.tanh=function(){if(this.isNaN())return y.NAN;if(this.isZero())return y.ZERO;if(!this.isFinite())return this.significand>0n?y.ONE:y.NEGATIVE_ONE;let e=this.mul(y.TWO).exp();return e.sub(y.ONE).div(e.add(y.ONE))};y.sinh=function(e){return e.sinh()};y.cosh=function(e){return e.cosh()};y.tanh=function(e){return e.tanh()};function zs(e,n){let i=K(e),r=Math.max(0,i-15),s=Number(r>0?e/F(r):e),o=K(n),a=Math.max(0,o-15),u=Number(a>0?n/F(a):n),l=r+2*a,c=Math.floor(l/3),f=l%3,d=Math.cbrt(s*u*u);f===1&&(d*=2.154434690031882),f===2&&(d*=4.641588833612779);let m=BigInt(Math.round(d))*F(c);return m>0n?m:1n}var Np=[BigInt(4),BigInt(2),BigInt(4),BigInt(2),BigInt(4),BigInt(6),BigInt(2),BigInt(6)];var Ju=53,Js=Math.floor(Math.log10(Math.pow(2,Ju))),qu=1e-10;var mi=1e4;function ke(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 Ue(e,n){if(e===0||n===0)return 0;let t=BigInt(e)*BigInt(n)/BigInt(ke(e,n));return Number(t)}function Vn(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 zn(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 Jn(e,n=qu){return typeof e=="number"&&Math.abs(e)<=n?0:e}function bt(e,n,t=1){if(t===0){let s=bt(e,n,-1),o=bt(e,n,1);return s===void 0||o===void 0?NaN:Math.abs(s-o)>1e-5?NaN:(s+o)/2}let[i,r]=li(e,n,{step:t>0?1:-1});return i}var mn=["number","finite_number","complex","finite_complex","imaginary","real","finite_real","rational","finite_rational","integer","finite_integer","non_finite_number"],hi=["indexed_collection","list","tuple"],yt=[...hi,"collection","set","record","dictionary"],xt=["scalar",...mn,"boolean","string"],gi=["value",...yt,...xt],bi=["expression","symbol","function",...gi],Ye=["any","unknown","nothing","never","error",...bi];function Et(e){return typeof e=="string"?Ye.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 js=3,Gs=1,Zs=2,ju=4,Gu=5,Zu=6,Uu=7,Yu=8,Wu=9,Hu=10,Xu=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,js)}`;break;case"union":t=e.types.map(u=>q(u,Gs)).join(" | ");break;case"intersection":t=e.types.map(u=>q(u,Zs)).join(" & ");break;case"expression":t=`expression<${qs(e.operator)}>`;break;case"symbol":t=`symbol<${qs(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"&&mn.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<${hn(u)}>`}else t="tuple<"+e.elements.map(u=>hn(u)).join(", ")+">";break;case"signature":let r=e.args?e.args.map(u=>hn(u)).join(", "):"",s=e.optArgs?e.optArgs.map(u=>hn(u)+"?").join(", "):"",o=e.variadicArg?e.variadicMin===0?`${hn(e.variadicArg)}*`:`${hn(e.variadicArg)}+`:"";t=`(${[r,s,o].filter(u=>u).join(", ")}) -> ${q(e.result)}`;break;default:t="error"}return n>0&&n>Qu(e.kind)?`(${t})`:t}function hn(e){return e.name?`${e.name}: ${q(e.type)}`:q(e.type)}function qs(e){return/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)?e:`\`${e}\``}function Qu(e){switch(e){case"negation":return js;case"union":return Gs;case"intersection":return Zs;case"list":return ju;case"record":return Gu;case"dictionary":return Zu;case"set":return Uu;case"collection":case"indexed_collection":return Yu;case"tuple":return Wu;case"signature":return Hu;case"value":return Xu;default:return 0}}function Ku(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 vt(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=Ku(e,o);if(a===0)return o;a<=7&&a<r&&(r=a,i=o)}return i}var Nt=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
|
|
1
|
+
/** Compute Engine 0.55.6 */
|
|
2
|
+
function fi(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 fi(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 B=Math.abs(d[R]-P);w=Math.min(w,B),B<b&&(m=d[R],b=B),k*=p}if(w>l*b||!isFinite(w)||b<=Math.max(a*Math.abs(m),o))break}return[m,b]}var Ds=new Map;function F(e){if(e<=100){let n=Ds.get(e);return n===void 0&&(n=10n**BigInt(e),Ds.set(e,n)),n}return 10n**BigInt(e)}function Fs(e,n,t){return e*n/t}function Os(e,n,t){return e*t/n}function Bn(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=Ps(e,n)}else t=Ps(e,n);let s=e*n,o;do o=t,t=(t+s/t)/2n;while(Te(t-o)>1n);let a=(t+s/t)/2n,u=Te(t*t-s);return Te(a*a-s)<u?a:t}function Ps(e,n){let i=K(e),r=Math.max(0,i-15),s=Number(r>0?e/F(r):e),o=K(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 Te(e){return e<0n?-e:e}function K(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 di(e,n){if(e===0n)return n;let t=0,i=e,r=n/2n;for(;Te(i)>r;)i=i/2n,t++;let s=n,o=i;s+=o;for(let a=2;o=o*i/(BigInt(a)*n),Te(o)!==0n;a++)s+=o;for(let a=0;a<t;a++)s=s*s/n;return s}function Ls(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=pi(e,n)}else r=pi(e,n)}else{s=e;let u=2n*n,l=n/2n;for(;s>u||s<l;)s=Bn(s,n),o++;r=pi(s,n)}let a=0n;for(let u=0;u<100;u++){let l=di(r,n);if(l===0n){r=r/2n;continue}let c=r+s*n/l-n,p=Te(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 pi(e,n){let t=K(e),i=K(n);return BigInt(t-i)*2302585n*n/1000000n}var gt="314159265358979323846264338327950288419716939937510582097494459230781640628620899862803482534211706798214808651328230664709384460955058223172535940812848111745028410270193852110555964462294895493038196442881097566593344612847564823378678316527120190914564856692346034861045432664821339360726024914127372458700660631558817488152092096282925409171536436789259036001133053054882046652138414695194151160943305727036575959195309218611738193261179310511854807446237996274956735188575272489122793818301194912983367336244065664308602139494639522473719070217986094370277053921717629317675238467481846766940513200056812714526356082778577134275778960917363717872146844090122495343014654958537105079227968925892354201995611212902196086403441815981362977477130996051870721134999999837297804995105973173281609631859502445945534690830264252230825334468503526193118817101000313783875288658753320838142061717766914730359825349042875546873115956286388235378759375195778185778053217122680661300192787661119590921642019893809525720106548586327886593615338182796823030195203530185296899577362259941389124972177528347913151557485724245415069595082953311686172785588907509838175463746493931925506040092770167113900984882401285836160356370766010471018194295559619894676783744944825537977472684710404753464620804668425906949129331367702898915210475216205696602405803815019351125338243003558764024749647326391419927260426992279678235478163600934172164121992458631503028618297455570674983850549458858692699569092721079750930295532116534498720275596023648066549911988183479775356636980742654252786255181841757467289097777279380008164706001614524919217321721477235014144197356854816136115735255213347574184946843852332390739414333454776241686251898356948556209921922218427255025425688767179049460165346680498862723279178608578438382796797668145410095388378636095068006422512520511739298489608412848862694560424196528502221066118630674427862203919494504712371378696095636437191728746776465757396241389086583264599581339047802759009946576407895126946839835259570982582262052248940772671947826848260147699090264013639443745530506820349625245174939965143142980919065925093722169646151570985838741059788595977297549893016175392846813826868386894277415599185592524595395943104997252468084598727364469584865383673622262609912460805124388439045124413654976278079771569143599770012961608944169486855584840635",ht=null;function mi(e){if(ht!==null&&ht.scale===e)return ht.value;let t=K(e)-1+10,i=gt.slice(0,t+1),r=BigInt(i),s=i.length-1,o=r*e/F(s);return ht={scale:e,value:o},o}function bt(e,n){if(e===0n)return[0n,n];let t=mi(n),i=2n*t,r=t/2n,s,o=Te(e);if(o>n*(1n<<30n)){let P=K(o)-K(n)+20,B=n*F(P),Q=e*F(P),ke=2n*mi(B),Y=Q%ke;Y<0n&&(Y+=ke),s=Y/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=K(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 B=2n*d*b/n,Q=2n*b*b/n-n;d=B,b=Q}return[a*d,u*b]}function Ln(e,n){if(e===0n)return 0n;if(e<0n)return-Ln(-e,n);let i=mi(n)/2n;if(e>n){let p=n*n/e;return i-Ln(p,n)}let r=4n*n/10n,s=0,o=e;for(;o>r;){let p=o*o,m=(n*n+p)/n,d=Bn(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 hi=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(gt[0]+"."+gt.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]=yt(n,0);return}if(typeof n=="number"){[this.significand,this.exponent]=Vu(n);return}[this.significand,this.exponent]=Js(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 hi;let d=this.exponent;if(Number.isNaN(d))return hi;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 hi;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=K(r),a=K(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 J(this.significand+n.significand,t);let o=t-i;return o>0?J(this.significand*F(o)+n.significand,i):J(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 J(this.significand-n.significand,t);let o=t-i;return o>0?J(this.significand*F(o)-n.significand,i):J(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 J(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)?J(-n,this.exponent):n>0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY}abs(){return this.significand>=0n?this:Number.isFinite(this.exponent)?J(-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(J(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(J(1n,0)):t}return this}round(){let n=this.exponent;if(n>=0)return this;if(Number.isFinite(n)){let t=J(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 J(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 J(0n,0);let u=e.precision,l=10,c=r<0n?-r:r,p=s<0n?-s:s,m=K(c),d=K(p),b=u+l+Math.max(0,d-m),v=F(b),k=r*v/s,w=t-i-b;return J(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 J(0n,0)}inv(){return J(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?J(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 J(1n,0);if(!this.isFinite())return t>0n?this.significand<0n&&t%2n!==0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY:J(0n,0);if(this.isZero())return t>0n?J(0n,0):e.POSITIVE_INFINITY;if(t<0n)return this.pow(n.neg()).inv();let i=this.significand<0n?-this.significand:this.significand,r=K(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 J(0n,0);let o=e.precision,a=J(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=K(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 J(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 J(e,n){let[t,i]=yt(e,n),r=Object.create(x.prototype);return r.significand=t,r.exponent=i,r}var Bs=1000000000n,Vs=1000n;function yt(e,n){if(e===0n)return[0n,0];for(;e%Bs===0n;)e/=Bs,n+=9;for(;e%Vs===0n;)e/=Vs,n+=3;for(;e%10n===0n;)e/=10n,n+=1;return[e,n]}function Vu(e){return Number.isNaN(e)?[0n,NaN]:e===1/0?[1n,1/0]:e===-1/0?[-1n,1/0]:Number.isInteger(e)?yt(BigInt(e),0):Js(e.toString())}function Js(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 yt(l,c+t)}function Oe(e,n){let t=F(n),i=e.exponent+n;return i>=0?[e.significand*F(i),t]:[e.significand/F(-i),t]}function Le(e,n,t){if(e===0n)return x.ZERO;let i=e<0n,r=i?-e:e,s=K(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=K(n)-1,b=l-d,v=i?-r:r;return J(v,b)}let a=-(K(n)-1),u=i?-r:r;return J(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]=Oe(this,n),r=Bn(t,i);return Le(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]=Oe(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=qs(t,i)}else s=qs(t,i);let u;do{u=s;let l=s*s;if(l===0n){s=1n;break}s=(2n*s+r/l)/3n}while(Te(s-u)>1n);{let l=(2n*s+r/(s*s))/3n,c=Te(s*s*s-r);Te(l*l*l-r)<c&&(s=l)}return Le(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]=Oe(this,n),r=di(t,i);return Le(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]=Oe(this,n),r=Ls(t,i);return Le(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]=Oe(this,n),[r]=bt(t,i);return Le(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]=Oe(this,n),[,r]=bt(t,i);return Le(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]=Oe(this,n),[r,s]=bt(t,i);if(s===0n)return r>0n?x.POSITIVE_INFINITY:x.NEGATIVE_INFINITY;let o=r*i/s;return Le(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]=Oe(this,n),r=Ln(t,i);return Le(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]=Oe(this,i),o=Fs(r,r,s),a=s-o,u=Bn(a,s),l=Os(r,u,s),c=Ln(l,s);return Le(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 qs(e,n){let i=K(e),r=Math.max(0,i-15),s=Number(r>0?e/F(r):e),o=K(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 yp=[BigInt(4),BigInt(2),BigInt(4),BigInt(2),BigInt(4),BigInt(6),BigInt(2),BigInt(6)];var Ju=53,zs=Math.floor(Math.log10(Math.pow(2,Ju))),qu=1e-10;var gi=1e4;function Se(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 Ye(e,n){if(e===0||n===0)return 0;let t=BigInt(e)*BigInt(n)/BigInt(Se(e,n));return Number(t)}function Jn(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 qn(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 zn(e,n=qu){return typeof e=="number"&&Math.abs(e)<=n?0:e}function xt(e,n,t=1){if(t===0){let s=xt(e,n,-1),o=xt(e,n,1);return s===void 0||o===void 0?NaN:Math.abs(s-o)>1e-5?NaN:(s+o)/2}let[i,r]=fi(e,n,{step:t>0?1:-1});return i}var hn=["number","finite_number","complex","finite_complex","imaginary","real","finite_real","rational","finite_rational","integer","finite_integer","non_finite_number"],bi=["indexed_collection","list","tuple"],Et=[...bi,"collection","set","record","dictionary"],vt=["scalar",...hn,"boolean","string"],yi=["value",...Et,...vt],xi=["expression","symbol","function",...yi],He=["any","unknown","nothing","never","error",...xi];function Nt(e){return typeof e=="string"?He.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 js=3,Us=1,Zs=2,zu=4,Gu=5,ju=6,Uu=7,Zu=8,Yu=9,Hu=10,Wu=11;function z(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=`!${z(e.type,js)}`;break;case"union":t=e.types.map(u=>z(u,Us)).join(" | ");break;case"intersection":t=e.types.map(u=>z(u,Zs)).join(" & ");break;case"expression":t=`expression<${Gs(e.operator)}>`;break;case"symbol":t=`symbol<${Gs(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"&&hn.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<${z(e.elements)}>`:t=`vector<${z(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<${z(e.elements)}>`:t=`matrix<${z(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<${z(e.elements)}${u}>`}break;case"record":t=`record<${Object.entries(e.elements).map(([u,l])=>`${u}: ${z(l)}`).join(", ")}>`;break;case"dictionary":t=`dictionary<${z(e.values)}>`;break;case"set":t=`set<${z(e.elements)}>`;break;case"collection":t=`collection<${z(e.elements)}>`;break;case"indexed_collection":t=`indexed_collection<${z(e.elements)}>`;break;case"tuple":if(e.elements.length===0)t="tuple";else if(e.elements.length===1){let[u]=e.elements;t=`tuple<${gn(u)}>`}else t="tuple<"+e.elements.map(u=>gn(u)).join(", ")+">";break;case"signature":let r=e.args?e.args.map(u=>gn(u)).join(", "):"",s=e.optArgs?e.optArgs.map(u=>gn(u)+"?").join(", "):"",o=e.variadicArg?e.variadicMin===0?`${gn(e.variadicArg)}*`:`${gn(e.variadicArg)}+`:"";t=`(${[r,s,o].filter(u=>u).join(", ")}) -> ${z(e.result)}`;break;default:t="error"}return n>0&&n>Xu(e.kind)?`(${t})`:t}function gn(e){return e.name?`${e.name}: ${z(e.type)}`:z(e.type)}function Gs(e){return/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)?e:`\`${e}\``}function Xu(e){switch(e){case"negation":return js;case"union":return Us;case"intersection":return Zs;case"list":return zu;case"record":return Gu;case"dictionary":return ju;case"set":return Uu;case"collection":case"indexed_collection":return Zu;case"tuple":return Yu;case"signature":return Hu;case"value":return Wu;default:return 0}}function Qu(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 Tt(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=Qu(e,o);if(a===0)return o;a<=7&&a<r&&(r=a,i=o)}return i}var It=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 kt=class{lexer;typeResolver;current;constructor(n,t){this.lexer=new It(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
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(Ye.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 Us(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 yi=class{typeResolver;constructor(n){this.typeResolver=n??{forward:()=>{},resolve:()=>{},get names(){return[]}}}buildType(n){return Us(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 Ys(e,n){return new yi(n).buildType(e)}function H(e,n){if(e!==void 0){if(Et(e))return e;if(typeof e=="string")try{let i=new Tt(e,{typeResolver:n}).parseType();return Ys(i,n)}catch(t){throw new Error(`Failed to parse type "${e}": ${t instanceof Error?t.message:String(t)}`)}}}var el={number:mn,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:Ye,unknown:[],nothing:[],never:[],error:[],value:gi,scalar:xt,collection:yt,indexed_collection:hi,list:[],set:[],tuple:[],record:[],dictionary:[],function:[],symbol:[],boolean:[],string:[],expression:bi};function qn(e,n){return n==="any"||e==="never"?!0:e==="unknown"||n==="unknown"?!1:e===n?!0:el[n].includes(e)}function A(e,n){if(typeof e=="string"&&!Ye.includes(e)&&(e=H(e)),typeof n=="string"&&!Ye.includes(n)&&(n=H(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"?qn(e,n):e.kind==="value"?typeof e.value=="boolean"?n==="boolean":typeof e.value=="number"?Number.isInteger(e.value)?qn("integer",n):qn("number",n):typeof e.value=="boolean"?qn("boolean",n):typeof e.value=="string"?qn("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"?Ws(e):n==="symbol"?xi(e):n==="expression"?nl(e):n==="function"?eo(e):n==="scalar"?Hs(e):n==="value"?Ks(e):n==="indexed_collection"?Qs(e):n==="collection"?Xs(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"?xi(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:he(...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 Ws(e){return typeof e=="string"?mn.includes(e):e.kind==="value"?typeof e.value=="number":e.kind==="numeric"}function Hs(e){return Ws(e)?!0:typeof e=="string"?xt.includes(e):e.kind==="value"?["string","boolean","number"].includes(typeof e.value):!1}function Xs(e){return Qs(e)?!0:typeof e=="string"?yt.includes(e):["collection","set","record","dictionary"].includes(e.kind)}function Qs(e){return typeof e=="string"?!1:["indexed_collection","list","tuple"].includes(e.kind)}function Ks(e){return Hs(e)||Xs(e)}function eo(e){return e==="function"||typeof e!="string"&&e.kind==="signature"}function nl(e){return typeof e=="string"&&["expression","symbol","function"].includes(e)||Ks(e)||eo(e)||xi(e)?!0:typeof e=="string"?!1:e.kind==="expression"}function xi(e){return e==="symbol"?!0:typeof e=="string"?!1:e.kind==="symbol"?!0:e.kind==="expression"?e.operator==="Symbol":!1}function tl(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:no(e,n)}function il(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:no(e,n)}function Ei(...e){return e.length===0?"nothing":e.length===1?e[0]:e.reduce((n,t)=>tl(n,t))}function he(...e){return e.length===0?"nothing":e.length===1?e[0]:e.reduce((n,t)=>il(n,t))}function no(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:X(e,n,"non_finite_number")?"non_finite_number":X(e,n,"finite_integer")?"finite_integer":X(e,n,"integer")?"integer":X(e,n,"finite_rational")?"finite_rational":X(e,n,"rational")?"rational":X(e,n,"finite_real")?"finite_real":X(e,n,"real")?"real":X(e,n,"imaginary")?"imaginary":X(e,n,"finite_complex")?"finite_complex":X(e,n,"complex")?"complex":X(e,n,"finite_number")?"finite_number":X(e,n,"number")?"number":X(e,n,"list")?"list":X(e,n,"record")?"record":X(e,n,"dictionary")?"dictionary":X(e,n,"set")?"set":X(e,n,"tuple")?"tuple":X(e,n,"indexed_collection")?"indexed_collection":X(e,n,"collection")?"collection":X(e,n,"scalar")?"scalar":X(e,n,"value")?"value":X(e,n,"function")?"function":X(e,n,"expression")?"expression":"any"}function X(e,n,t){return!!(A(e,t)&&A(n,t))}function vi(e){if(e){if(e==="function")return"any";if(typeof e!="string"&&e.kind==="signature")return e.result}}function Se(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 he(...e.elements.map(n=>n.type));if(e.kind==="dictionary")return H(`tuple<string, ${e.values}>`);if(e.kind==="record")return H(`tuple<string, ${q(he(...Object.values(e.elements)))}>`)}}var pe=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(he(...n.map(t=>t instanceof e?t.type:t)))}static narrow(...n){return new e(Ei(...n.map(t=>t instanceof e?t.type:t)))}constructor(n,t){typeof n=="string"?this.type=H(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 L(e){return e?._kind==="number"}function k(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 ge(e){return e?._kind==="string"}function be(e){return e?._kind==="symbol"?e.symbol:void 0}var Dd=[0,-1,1,Math.PI,Math.E,-Math.PI,-Math.E,.5,-.5];function Oe(e){if(!e)return;if(e.operator==="Function"&&e.isCanonical||k(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 Oe(e.engine._fn("Block",s.ops,{canonical:!1}));return Oe(h(e)?e.op1:void 0)}if(h(e,"Function"))return to(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 to(n,[t,...r])}function to(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=>k(r)?r:e.error("expected-a-symbol",r.toString()));t.isScoped;for(let r of i)k(r)&&!t.localScope.bindings.has(r.symbol)&&e.declare(r.symbol,{inferred:!0,type:"unknown"},t.localScope);return e._fn("Function",[t,...i])}function io(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 ro(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 so(e,n){for(let[t,i]of n)e.bindings.set(t,i)}function oo(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=>k(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=oo(e,s,t);return o!==s&&(i=!0),o});if(i)return e._fn(n.operator,r)}return n}function sl(e){let n=e.engine;if(k(e)){let a=e.symbol;return u=>n.function(a,u).evaluate()}let t=Oe(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(T=>T.isValid))return;if(a.length<s.length){let T=new Set([...r.symbols,...s.map(ne=>k(ne)?ne.symbol:"")]),M=s.slice(a.length).map((ne,De)=>{let Pe=`_${De+1}`,pt=0;for(;T.has(Pe);)Pe=`_${De+1}_${pt++}`;return T.add(Pe),n.symbol(Pe,{canonical:!1})}),C=Object.fromEntries(s.slice(a.length).map((ne,De)=>[k(ne)?ne.symbol:"",M[De]])),P=a.map(ne=>ne.evaluate()),Q={parent:o.localScope.parent??n.context.lexicalScope,bindings:new Map};for(let ne=0;ne<a.length;ne++){let De=s[ne],Pe=k(De)?De.symbol:"";Pe&&n.declare(Pe,{value:P[ne],inferred:!0},Q)}let U=o.localScope,_e=U.parent;U.parent=Q;let Y=s.slice(0,a.length).map(ne=>k(ne)?ne.symbol:""),ue=ro(U,Y);n.pushScope(Q);let le;try{le=io(n,o.ops)}finally{n.popScope(),U.parent=_e,so(U,ue)}return n.function("Function",[le.subs(C),...M])}let u=a.map(T=>T.evaluate()),c={parent:o.localScope.parent??n.context.lexicalScope,bindings:new Map},f=s.map(T=>k(T)?T.symbol:"");for(let T=0;T<s.length;T++)f[T]&&n.declare(f[T],{value:u[T],inferred:!0},c);let d=o.localScope,m=d.parent;d.parent=c;let b=ro(d,f);n.pushScope(c);let E;try{E=io(n,o.ops),E=oo(n,E,c)}finally{n.popScope(),d.parent=m,so(d,b)}return E.isValid?E:void 0}}function te(e){return sl(e)??(n=>e.engine.function("Apply",[e,...n]).evaluate())}function Ni(e){return(e.isFiniteCollection??!1)&&e.isIndexedCollection}function ol(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 al(e,n){if(h(e)){for(let t=0;t!==e.nops;t+=1)if(n(e.ops[t]))return t+1}}function It(){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:ol,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:al,eltsgn:e=>{},elttype:e=>!h(e)||e.nops===0?"unknown":e.nops===1?e.ops[0].type.type:he(...e.ops.map(n=>n.type.type))}}var gn=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 Ti(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 gn({value:r,cause:"timeout",message:`Timeout exceeded (${n}ms)`})}}function _(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 bn(e,n,t){return n.includes(e)&&(n=`{${n}}`),/^[0-9]$/.test(t)?`${n}${e}${t}`:`${n}${e}{${t}}`}var D=245,jn=260,Be=270,ee=275,ye=390,xe=600;var Gn=700,Ii=810;var rn=[{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 _i(e){return typeof e!="string"?!1:rn.some(n=>n.name===e)}function ki(e){return typeof e!="string"?!1:["Less","LessEqual","Greater","GreaterEqual"].includes(e)}function Si(e){return typeof e!="string"?!1:["Equal","NotEqual"].includes(e)}var yn=["Error","'missing'"];function sn(e){return!!(typeof e=="number"||xn(e)||typeof e=="string"&&Mt(e))}function xn(e){return e!==null&&typeof e=="object"&&"num"in e}function _t(e){return e!==null&&typeof e=="object"&&"sym"in e}function uo(e){return e!==null&&typeof e=="object"&&"str"in e}function lo(e){return e!==null&&typeof e=="object"&&"dict"in e&&typeof e.dict=="object"&&!Array.isArray(e.dict)&&e.dict!==null}function En(e){return e!==null&&typeof e=="object"&&"fn"in e&&Array.isArray(e.fn)&&e.fn.length>0&&typeof e.fn[0]=="string"}function B(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):Mt(e)||$i(e)?null:e}function wi(e){if(e==null||B(e)!==null)return null;let n=x(e);return n?[n,...N(e).map(t=>wi(t)).filter(t=>t!==null)]:e}function x(e){return Array.isArray(e)?e[0]:e==null?"":En(e)?e.fn[0]:""}function N(e){return Array.isArray(e)?e.slice(1):e!==void 0&&En(e)?e.fn.slice(1):[]}function p(e,n){return Array.isArray(e)?e[n]??null:e===null||!En(e)?null:e.fn[n]??null}function J(e){return e==null?0:Array.isArray(e)?Math.max(0,e.length-1):En(e)?Math.max(0,e.fn.length-1):0}function Ai(e){return e==null?null:x(e)==="Hold"?p(e,1):e}function S(e){return typeof e=="string"&&$i(e)?e.length>=2&&e.at(0)==="`"&&e.at(-1)==="`"?e.slice(1,-1):e:e==null?null:_t(e)?e.sym:null}function ao(e){let n=x(e);if(n==="KeyValuePair"||n==="Tuple"||n==="Pair"){let[t,i]=N(e),r=B(t);return r?[r,i??"Nothing"]:null}return null}function co(e){if(e===null)return null;if(lo(e))return e;let n=ao(e);if(n)return{[n[0]]:n[1]};if(x(e)==="Dictionary"){let t={},i=N(e);for(let r=1;r<J(e);r++){let s=ao(i[r]);s&&(t[s[0]]=pl(s[1])??"Nothing")}return{dict:t}}return null}function kt(e){return{dict:Object.fromEntries(Object.entries(e).map(([t,i])=>[t,Mi(i)??"Nothing"]))}}function fl(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 R(e){return typeof e=="number"?e:typeof e=="string"&&Mt(e)?fl(e):e!==void 0&&xn(e)?R(e.num):null}function vn(e){if(e==null)return null;if(S(e)==="Half")return[1,2];let n=x(e);if(!n)return null;let t=null,i=null;if(n==="Negate"){let r=vn(N(e)[0]);if(r)return[-r[0],r[1]]}if(n==="Rational"||n==="Divide"){let[r,s]=N(e);t=R(r)??NaN,i=R(s)??NaN}if(n==="Power"){let[r,s]=N(e),o=R(s);o===1?(t=R(r),i=1):o===-1&&(t=1,i=R(r))}if(n==="Multiply"){let[r,s]=N(e);if(x(s)==="Power"){let[o,a]=N(s);R(a)===-1&&(t=R(r),i=R(o))}}return t===null||i===null?null:Number.isInteger(t)&&Number.isInteger(i)?[t,i]:null}function St(e,n){let t=null;if(Array.isArray(e)&&(t=e),En(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 Nn(e,n,t){let i=x(n),r=x(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 on(e){if(e==null)return null;let n=x(e);if(n==="Delimiter"){if(e=p(e,1),e===null)return[];if(n=x(e),n!=="Sequence")return[e]}return n!=="Sequence"?null:N(e)}function j(e){return e==null||e==="Nothing"?!0:x(e)==="Sequence"&&J(e)===0}function z(e){return j(e)?yn:e}function Mt(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 $i(e){return/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)||e.length>=2&&e[0]==="`"&&e[e.length-1]==="`"}function Mi(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=>Mi(n)??"Nothing")];if(e===null)return null;if(typeof e=="object"){let n={};for(let t in e)n[t]=Mi(e[t])??"Nothing";return{dict:n}}return En(e)||_t(e)||xn(e)||uo(e)||lo(e)?e:null}function pl(e){return e==null?null:uo(e)?e.str:xn(e)?parseFloat(e.num):_t(e)?e.sym:typeof e=="string"||typeof e=="number"?e:Array.isArray(e)?{fn:e}:e}var po=[{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&&x(s)==="Mod"?["Congruent",n,i,z(p(s,1))]:(e.index=r,["Equivalent",n,z(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:Zn("\\forall"),parse:We("ForAll")},{name:"Exists",kind:"prefix",latexTrigger:["\\exists"],precedence:200,serialize:Zn("\\exists"),parse:We("Exists")},{name:"ExistsUnique",kind:"prefix",latexTrigger:["\\exists","!"],precedence:200,serialize:Zn("\\exists!"),parse:We("ExistsUnique")},{name:"NotForAll",kind:"prefix",latexTrigger:["\\lnot","\\forall"],precedence:200,serialize:Zn("\\lnot\\forall"),parse:We("NotForAll")},{name:"NotExists",kind:"prefix",latexTrigger:["\\lnot","\\exists"],precedence:200,serialize:Zn("\\lnot\\exists"),parse:We("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=on(n);return t&&t.length<=2?["KroneckerDelta",...t]:x(n)==="InvisibleOperator"?["KroneckerDelta",...N(n)]:n!==null?["KroneckerDelta",n]:null}},{name:"Boole",kind:"matchfix",openTrigger:"[",closeTrigger:"]",parse:(e,n)=>{let t=x(n);return!t||!rn.some(i=>i.name===t)?null:["Boole",n]}},{kind:"matchfix",openTrigger:"\\llbracket",closeTrigger:"\\rrbracket",parse:(e,n)=>{let t=x(n);return!t||!rn.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 Zn(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 fo(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 We(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:f=>fo(f,t)}:t;n.enterQuantifierScope();let c=n.parseExpression(l);return n.exitQuantifierScope(),[e,s,z(c)]}n.enterQuantifierScope();let u=n.parseEnclosure();if(n.exitQuantifierScope(),u)return[e,s,z(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=>fo(c,t)}:t;n.enterQuantifierScope();let l=n.parseExpression(u);return n.exitQuantifierScope(),[e,a,z(l)]}if(n.match("(")){n.enterQuantifierScope();let u=n.parseExpression(t);return n.exitQuantifierScope(),n.match(")")?[e,a,z(u)]:null}return null}}function Ci(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 we(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(),_(r)}}var yo=[{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:Be,parse:(e,n,t)=>{let i=[];if(x(n)==="Delimiter"&&(n=p(n,1)??"Nothing"),x(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:Be})??"Nothing";return x(r)==="Delimiter"&&(r=p(r,1)??"Nothing"),x(r)==="Sequence"&&(r=["Block",...N(r)]),["Function",r,...i]},serialize:(e,n)=>{let t=N(n);return t.length<1?"()\\mapsto()":t.length===1?_(["()","\\mapsto",e.serialize(p(n,1))]):t.length===2?_([e.serialize(p(n,2)),"\\mapsto",e.serialize(p(n,1))]):_([e.wrapString(N(n)?.slice(1).map(i=>e.serialize(i)).join(", "),"normal"),"\\mapsto",e.serialize(p(n,1))])}},{name:"Apply",kind:"function",symbolTrigger:"apply",serialize:(e,n)=>{let t=p(n,1),i=x(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=p(n,2);if(typeof t=="string"||!r){let o=N(n).slice(1);return e.serialize(o)}if(J(n)===2)return _([e.wrap(t,20),"\\lhd",e.wrap(r,20)]);let s=e.options.applyFunctionStyle(n,e.level);return _(["\\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=p(n,1);if(!t)return"";let i=N(n).slice(1);if(x(t)==="Function"){let r=N(t).slice(1),s=p(t,1);if(x(s)==="Block"&&J(s)===1&&(s=p(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=Ai(p(n,1));if(x(p(n,2))==="Function"){let i=p(n,2),r=Ai(p(i,1)),s=N(i).slice(1);return _([e.serialize(t),e.wrapString(s.map(o=>e.serialize(o)).join(", "),e.options.applyFunctionStyle(n,e.level)),"\\coloneq",e.serialize(r)])}return _([e.serialize(t),"\\coloneq",e.serialize(p(n,2))])},parse:wt},{latexTrigger:"\\coloneqq",kind:"infix",associativity:"right",precedence:jn,parse:wt},{latexTrigger:"\\colonequals",kind:"infix",associativity:"right",precedence:jn,parse:wt},{latexTrigger:[":","="],kind:"infix",associativity:"right",precedence:jn,parse:wt},{name:"Colon",latexTrigger:":",kind:"infix",associativity:"right",precedence:250,serialize:(e,n)=>_([e.serialize(p(n,1)),"\\colon",e.serialize(p(n,2))])},{latexTrigger:"\\colon",kind:"infix",associativity:"right",precedence:250,parse:"Colon"},{name:"BaseForm",serialize:(e,n)=>{let t=R(p(n,2))??NaN;if(isFinite(t)&&t>=2&&t<=36){let i=R(p(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(p(n,1))+", "+e.serialize(p(n,2))+")"}},{name:"Sequence",serialize:we(" ")},{name:"InvisibleOperator",serialize:we("")},{name:"Delimiter",serialize:(e,n)=>{let t=e.options.groupStyle(n,e.level+1),i=p(n,1),r={Set:"{,}",List:"[,]",Tuple:"(,)",Single:"(,)",Pair:"(,)",Triple:"(,)",Sequence:"(,)",String:'""'}[x(i)],s=r?i:["Sequence",i];if(r??="(,)",J(n)>1){let c=B(p(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?we(a)(e,s):e.serialize(i):"";return e.wrapString(l,t,o+u)}},{name:"Tuple",serialize:(e,n)=>_(["(",we(",")(e,n),")"])},{name:"Pair",serialize:(e,n)=>_(["(",we(",")(e,n),")"])},{name:"Triple",serialize:(e,n)=>_(["(",we(",")(e,n),")"])},{name:"Single",serialize:(e,n)=>_(["(",we(",")(e,n),")"])},{name:"Domain",serialize:(e,n)=>x(n)==="Error"?e.serialize(n):`\\mathbf{${e.serialize(p(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=p(n,1);if(B(t)==="missing")return`\\error{${e.options.missingSymbol??"\\placeholder{}"}}`;let i=ml(e,n)||"\\blacksquare",r=x(t)==="ErrorCode"?B(p(t,1)):B(t);return r==="incompatible-type"?S(p(t,3))==="Undefined"?`\\mathtip{\\error{${i}}}{\\notin ${e.serialize(p(t,2))}}`:`\\mathtip{\\error{${i}}}{\\in ${e.serialize(p(t,3))}\\notin ${e.serialize(p(t,2))}}`:typeof r=="string"?`\\error{${i}}`:`\\error{${i}}`}},{name:"ErrorCode",serialize:(e,n)=>{let t=B(p(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{${mo(B(p(n,1)))}}`},{name:"Latex",serialize:(e,n)=>n===null?"":_(St(n,t=>B(t)??e.serialize(t)))},{name:"LatexString",serialize:(e,n)=>n===null?"":_(St(n,t=>e.serialize(t)))},{name:"LatexTokens",serialize:dl},{name:"At",kind:"postfix",precedence:810,latexTrigger:["["],parse:Di("]"),serialize:(e,n)=>_(["\\lbrack",we(", ")(e,n),"\\rbrack"])},{kind:"postfix",precedence:810,latexTrigger:["\\lbrack"],parse:Di("\\rbrack")},{kind:"postfix",precedence:810,latexTrigger:["\\left","\\lbrack"],parse:Di("\\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")||x(n)==="List")?(x(i)==="Delimiter"&&(i=p(i,1)??"Nothing"),x(i)==="Sequence"?["At",n,...N(i)]:["At",n,i]):["Subscript",n,i]}},{name:"List",kind:"matchfix",openTrigger:"[",closeTrigger:"]",parse:xo,serialize:gl},{kind:"matchfix",openTrigger:"(",closeTrigger:")",parse:hl},{latexTrigger:[","],kind:"infix",precedence:20,parse:(e,n,t)=>{let i=Ci(e,t,n,20,",");return i===null?null:["Delimiter",["Sequence",...i],{str:","}]}},{latexTrigger:[","],kind:"prefix",precedence:20,parse:(e,n)=>{let t=Ci(e,n,null,20,",");return t===null?null:["Delimiter",["Sequence",...t],{str:","}]}},{name:"Range",latexTrigger:[".","."],kind:"infix",precedence:800,parse:bl,serialize:(e,n)=>{let t=N(n);if(t.length===0)return"";if(t.length===1)return"1.."+e.serialize(p(n,1));if(t.length===2)return e.wrap(p(n,1),10)+".."+e.wrap(p(n,2),10);if(t.length===3){let i=R(p(n,3)),r=R(p(n,1));return i!==null&&r!==null?e.wrap(p(n,1),10)+".."+e.wrap(r+i,10)+".."+e.wrap(p(n,2),10):e.wrap(p(n,1),10)+"..("+(e.wrap(p(n,1),ee)+"+"+e.wrap(p(n,3),ee))+").."+e.wrap(p(n,2),10)}return""}},{latexTrigger:[";"],kind:"infix",precedence:19,parse:(e,n,t)=>{let i=Ci(e,t,n,19,";");return i===null?null:i.some(r=>x(r)==="Assign")?yl(i):["Delimiter",["Sequence",...i],"';'"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"none",precedence:21,parse:(e,n,t)=>{let i=e.index;return de(e,"where")?bo(e,n,t):(e.index=i,null)}},{symbolTrigger:"where",kind:"infix",associativity:"none",precedence:21,parse:(e,n,t)=>bo(e,n,t)},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:235,parse:(e,n,t)=>{let i=e.index;if(!de(e,"and"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:235});return["And",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:230,parse:(e,n,t)=>{let i=e.index;if(!de(e,"or"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:230});return["Or",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:219,parse:(e,n,t)=>{let i=e.index;if(!de(e,"iff"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:219});return["Equivalent",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:219,parse:(e,n,t)=>{let i=e.index;if(!de(e,"if and only if"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:219});return["Equivalent",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:21,parse:(e,n,t)=>{let i=e.index;if(!de(e,"such that"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:21});return["Colon",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"prefix",precedence:200,parse:(e,n)=>{let t=e.index;return de(e,"for all")?We("ForAll")(e,n):(e.index=t,null)}},{latexTrigger:["\\text"],kind:"prefix",precedence:200,parse:(e,n)=>{let t=e.index;return de(e,"there exists")?We("Exists")(e,n):(e.index=t,null)}},{name:"Block",serialize:(e,n)=>{let t=N(n);return!t||t.length===0?"":t.filter(r=>x(r)!=="Declare").map(r=>e.serialize(r)).join("; ")}},{name:"If",serialize:(e,n)=>{let t=N(n);return!t||t.length<3?"":_(["\\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(x(r)==="Element"){let s=p(r,1),o=p(r,2);if(x(o)==="Range"){let a=p(o,1),u=p(o,2);return _(["\\text{for }",e.serialize(s),"\\text{ from }",e.serialize(a),"\\text{ to }",e.serialize(u),"\\text{ do }",e.serialize(i)])}}return _(["\\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=p(n,1);return!t||S(t)==="Nothing"?"\\text{return}":_(["\\text{return }",e.serialize(t)])}},{symbolTrigger:"if",kind:"prefix",precedence:245,parse:(e,n)=>ho(e,n)},{symbolTrigger:"for",kind:"prefix",precedence:245,parse:(e,n)=>go(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:"Text",serialize:(e,n)=>{let t=N(n);if(t.length===0)return"";let i=-1,r=-1;for(let a=0;a<t.length;a++)B(t[a])!==null&&(i<0&&(i=a),r=a);if(i<0)return _(t.map(a=>e.serialize(a)));let s=[];for(let a=0;a<i;a++)s.push(e.serialize(t[a]));let o="";for(let a=i;a<=r;a++){let u=B(t[a]);u!==null?o+=mo(u):x(t[a])==="Annotated"||x(t[a])==="Text"?o+=e.serialize(t[a]):o+="$"+e.serialize(t[a])+"$"}s.push("\\text{"+o+"}");for(let a=r+1;a<t.length;a++)s.push(e.serialize(t[a]));return _(s)}},{name:"String",latexTrigger:["\\text"],parse:(e,n)=>{let t=e.index;return de(e,"if")?ho(e,n):(e.index=t,de(e,"for")?go(e,n):(e.index=t,de(e,"break")?["Break"]:(e.index=t,de(e,"continue")?["Continue"]:(e.index=t,de(e,"return")?["Return",e.parseExpression(n)??"Nothing"]:(e.index=t,Me(e))))))},serialize:(e,n)=>{let t=N(n);return t.length===0?"\\text{}":_(["\\text{",t.map(i=>e.serialize(i)).join(""),"}"])}},{name:"Subscript",latexTrigger:["_"],kind:"infix",serialize:(e,n)=>J(n)===2?e.serialize(p(n,1))+"_{"+e.serialize(p(n,2))+"}":"_{"+e.serialize(p(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)=>Ve(e,n,1),serialize:(e,n)=>{let t=R(p(n,2))??1,i=e.serialize(p(n,1));return t===1?i+"^\\prime":t===2?i+"^\\doubleprime":t===3?i+"^\\tripleprime":i+"^{("+e.serialize(p(n,2))+")}"}},{latexTrigger:"^{\\prime\\prime}",kind:"postfix",parse:(e,n)=>Ve(e,n,2)},{latexTrigger:"^{\\prime\\prime\\prime}",kind:"postfix",parse:(e,n)=>Ve(e,n,3)},{latexTrigger:["^","\\doubleprime"],kind:"postfix",parse:(e,n)=>Ve(e,n,2)},{latexTrigger:["^","\\tripleprime"],kind:"postfix",parse:(e,n)=>Ve(e,n,3)},{latexTrigger:"'",kind:"postfix",precedence:810,parse:(e,n)=>Ve(e,n,1)},{latexTrigger:"\\prime",kind:"postfix",precedence:810,parse:(e,n)=>Ve(e,n,1)},{latexTrigger:"\\doubleprime",kind:"postfix",precedence:810,parse:(e,n)=>Ve(e,n,2)},{latexTrigger:"\\tripleprime",kind:"postfix",precedence:810,parse:(e,n)=>Ve(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(x(n)==="Matrix")return e.match("<}>"),["Inverse",n];let t=S(n);if(!t)return null;let i=e.getSymbolType(t);if(i.matches(new pe("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(p(n,1))+"^{-1}"},{name:"Derivative",serialize:(e,n)=>{let t=R(p(n,2))??1,i=e.serialize(p(n,1));return t===1?i+"^{\\prime}":t===2?i+"^{\\doubleprime}":t===3?i+"^{\\tripleprime}":i+"^{("+e.serialize(p(n,2))+")}"}},{name:"D",serialize:(e,n)=>{if(x(n)!=="D")return"D";let t=p(n,1),i=p(n,2);if(!t||!i)return"D";let r=1,s=t;for(;x(s)==="D";){let l=p(s,2);if(S(l)===S(i))r++,s=p(s,1);else break}let o=s;x(s)==="Function"&&(o=p(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=R(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:Ri,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 _(["\\begin{cases}",t.join("\\\\"),"\\end{cases}"])}},{kind:"environment",symbolTrigger:"dcases",parse:Ri},{kind:"environment",symbolTrigger:"rcases",parse:Ri}];function Me(e,n){if(!e.match("<{>"))return"''";let t=[],i="",r=null,s=()=>{r!==null&&i?t.push(["Annotated",`'${i}'`,kt(r)]):i&&t.push(`'${i}'`),i="",r=null};for(;!e.atEnd&&!e.match("<}>");)if(e.peek==="<{>")s(),t.push(Me(e));else if(e.match("\\textbf"))s(),t.push(Me(e,{fontWeight:"bold"}));else if(e.match("\\textmd"))s(),t.push(Me(e,{fontStyle:"normal"}));else if(e.match("\\textup"))s(),t.push(Me(e,{fontStyle:"normal"}));else if(e.match("\\textsl"))s(),t.push(Me(e,{fontStyle:"italic"}));else if(e.match("\\textit"))s(),t.push(Me(e,{fontStyle:"italic"}));else if(e.match("\\texttt"))s(),t.push(Me(e,{fontFamily:"monospace"}));else if(e.match("\\textsf"))s(),t.push(Me(e,{fontFamily:"sans-serif"}));else if(e.match("\\textcolor")){let a=e.index,u=e.parseStringGroup();if(u!==null){s();let l=Me(e);t.push(["Annotated",l,kt({color:u})])}else 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("<$>")?(s(),t.push(u)):(i+="$",e.index=a)}else if(e.match("<$$>")){let a=e.index,u=e.parseExpression()??"Nothing";e.skipSpace(),e.match("<$$>")?(s(),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=>B(a)!==null)?o="'"+t.map(a=>B(a)).join()+"'":o=["Text",...t],n?["Annotated",o,kt(n)]:o}function dl(e,n){return n===null?"":_(St(n,t=>{let i=B(t);return i===null?e.serialize(t):i==="<{>"?"{":i==="<}>"?"}":i==="<$>"?"$":i==="<$$>"?"$$":i==="<space>"?" ":i}))}function mo(e){return e===null?"":e.replace(/[{}\[\]\\:\-\$%]/g,n=>({"{":"\\lbrace ","}":"\\rbrace ","[":"\\lbrack ","]":"\\rbrack ",":":"\\colon ","\\":"\\backslash "})[n]??"\\"+n)}function ml(e,n){let t=p(n,2);return t?x(t)==="LatexString"?B(p(t,1))??"":x(t)==="Hold"?e.serialize(p(t,1)):e.serialize(t):""}function Ve(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=x(n);if(i==="Derivative"||i==="Prime"){let a=R(p(n,2))??1;return[i,z(p(n,1)),a+t]}let r=S(n),s=r&&e.getSymbolType(r).matches("function")||x(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 f=0;f<t;f++)c=["D",c,u];return c}return s?t===1?["Derivative",n]:["Derivative",n,t]:t===1?["Prime",z(n)]:["Prime",z(n),t]}function hl(e,n){if(j(n))return["Delimiter"];let t=x(n);if(t==="Delimiter"&&p(n,2)!==null){let i=B(p(n,2));if(i?.length===1)return["Delimiter",p(n,1)??"Nothing",{str:`(${i})`}]}return t==="Matrix"&&(B(p(n,2))??"..")===".."?["Matrix",p(n,1)]:["Delimiter",n]}function xo(e,n){if(j(n))return["List"];let t=x(n);if(t==="Range"||t==="Linspace")return n;if(t==="Sequence")return["List",...N(n)];if(t==="Delimiter"){let i=B(p(n,2))??"...";if(i===";"||i===".;.")return["List",...(N(p(n,1))??[]).map(r=>xo(e,r))];if(i===","||i===".,.")return n=p(n,1),x(n)==="Sequence"?["List",...N(n)]:["List",n??"Nothing"]}return["List",n]}function gl(e,n){return J(n)>1&&N(n).every(t=>{let i=x(t);return Si(i)||ki(i)})?_(["\\begin{cases}",we("\\\\")(e,n),"\\end{cases}"]):_(["\\bigl\\lbrack",we(", ")(e,n),"\\bigr\\rbrack"])}function bl(e,n){if(n===null)return null;let t=e.parseExpression({minPrec:270});if(t===null)return null;if(x(t)==="Range"){let i=p(t,1),r=p(t,2);return i&&r?["Range",n,r,["Subtract",i,n]]:null}return["Range",n,t]}var At={"(":"(",")":")","[":"\\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 wt(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),f=!isNaN(c)&&String(c)===l?c:l,d=f!==""&&(typeof f=="number"||typeof f=="string"&&f.length===1);(e.getSymbolType(u).matches("indexed_collection")||!i&&d)&&(n=["Subscript",u,f])}if(x(n)==="InvisibleOperator"&&J(n)===2&&x(p(n,2))==="Delimiter"){let a=S(p(n,1));if(!a)return null;let u=e.parseExpression({...t??{},minPrec:20});if(u===null)return null;let l=p(p(n,2),1),c=[];return x(l)==="Sequence"?c=[...N(l)]:l&&(c=[l]),["Assign",a,["Function",u,...c??[]]]}if(x(n)==="Subscript"&&S(p(n,1))){let a=S(p(n,1));if(!e.getSymbolType(a).matches("indexed_collection")){let c=p(n,2),f=(c!==null&&typeof c=="string"?c:void 0)??(c!==null&&typeof c=="number"?String(c):void 0);if(f&&i){let d=e.parseExpression({...t??{},minPrec:20});return d===null?null:["Assign",a+"_"+f,d]}}let u=e.parseExpression({...t??{},minPrec:20});if(u===null)return null;let l=p(n,2);return B(l)!==null?["Assign",n,u]:S(l)?["Assign",n,u]:["Assign",n,u]}let s=x(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 Ri(e){let n=e.parseTabular();if(!n)return["List"];if(n.every(i=>{if(i.length!==1)return!1;let r=x(i[0]);return ki(r)||Si(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=B(i[1]);t.push(r?"True":wi(i[1])??"True"),t.push(i[0])}return["Which",...t]}function de(e,n){let t=e.index;if(!e.match("<{>"))return e.index=t,!1;for(;e.match("<space>"););for(let i=0;i<n.length;i++)if(n[i]===" "){if(!e.match("<space>"))return e.index=t,!1;for(;e.match("<space>"););}else{if(e.peek!==n[i])return e.index=t,!1;e.nextToken()}for(;e.match("<space>"););return e.match("<}>")?!0:(e.index=t,!1)}function Tn(e,n){let t=e.index;if(e.skipVisualSpace(),e.match("\\text")){if(de(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 Un(e,n){let t=e.index,i=Tn(e,n);return e.index=t,i}function ho(e,n){e.skipVisualSpace();let t=e.parseExpression({minPrec:0,condition:s=>Un(s,"then")});if(t===null||!Tn(e,"then"))return null;e.skipVisualSpace();let i=e.parseExpression({minPrec:0,condition:s=>Un(s,"else")});if(i===null||!Tn(e,"else"))return null;e.skipVisualSpace();let r=e.parseExpression(n)??"Nothing";return["If",t,i,r]}function go(e,n){let t=e.parseExpression({minPrec:0,condition:a=>Un(a,"from")}),i=t?S(t):null;if(!i||!Tn(e,"from"))return null;let r=e.parseExpression({minPrec:0,condition:a=>Un(a,"to")});if(r===null||!Tn(e,"to"))return null;let s=e.parseExpression({minPrec:0,condition:a=>Un(a,"do")});return s===null||!Tn(e,"do")?null:["Loop",e.parseExpression(n)??"Nothing",["Element",i,["Range",r,s]]]}function bo(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=Eo(o);x(a)==="Assign"&&s.push(["Declare",p(a,1)]),s.push(a)}return s.push(n),["Block",...s]}function yl(e){let n=[];for(let t of e){let i=Eo(t);x(i)==="Assign"&&n.push(["Declare",p(i,1)]),n.push(i)}return["Block",...n]}function Eo(e){if(x(e)!=="Assign")return e;let n=p(e,1);if(x(n)!=="Subscript")return e;let t=S(p(n,1));if(!t)return e;let i=p(n,2),r=(typeof i=="string"?i:void 0)??(typeof i=="number"?String(i):void 0);return r?["Assign",`${t}_${r}`,p(e,2)??"Nothing"]:e}function Di(...e){return(n,t)=>{if(!S(t)&&x(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)||B(i)!==null?null:(x(i)==="Delimiter"&&(i=p(i,1)??"Nothing"),x(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]],vo=[...$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 No=[{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]}}];function Ae(e,n,t){if(j(e))return null;let i,r=x(e);if(r==="Delimiter"){let l=B(p(e,2));if(l!==","&&l!=="(,)"&&l!=="[,]")return null;let c=p(e,1);x(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 Io=[{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:To},{kind:"matchfix",openTrigger:["["],closeTrigger:[")"],parse:(e,n)=>Ae(n,!1,!0)},{kind:"matchfix",openTrigger:["\\lbrack"],closeTrigger:["\\rparen"],parse:(e,n)=>Ae(n,!1,!0)},{kind:"matchfix",openTrigger:["\\lbrack"],closeTrigger:[")"],parse:(e,n)=>Ae(n,!1,!0)},{kind:"matchfix",openTrigger:["["],closeTrigger:["\\rparen"],parse:(e,n)=>Ae(n,!1,!0)},{kind:"matchfix",openTrigger:["("],closeTrigger:["]"],parse:(e,n)=>Ae(n,!0,!1)},{kind:"matchfix",openTrigger:["\\lparen"],closeTrigger:["\\rbrack"],parse:(e,n)=>Ae(n,!0,!1)},{kind:"matchfix",openTrigger:["\\lparen"],closeTrigger:["]"],parse:(e,n)=>Ae(n,!0,!1)},{kind:"matchfix",openTrigger:["("],closeTrigger:["\\rbrack"],parse:(e,n)=>Ae(n,!0,!1)},{kind:"matchfix",openTrigger:["]"],closeTrigger:["["],parse:(e,n)=>Ae(n,!0,!0)},{kind:"matchfix",openTrigger:["\\rbrack"],closeTrigger:["\\lbrack"],parse:(e,n)=>Ae(n,!0,!0)},{name:"Multiple",serialize:To},{name:"Union",latexTrigger:["\\cup"],kind:"infix",precedence:350},{name:"Set",kind:"matchfix",openTrigger:"{",closeTrigger:"}",parse:(e,n)=>j(n)?"EmptySet":(x(n)=="Delimiter"&&B(p(n,2))===","&&(n=p(n,1)),x(n)!=="Sequence"?["Set",n]:["Set",...N(n)]),serialize:(e,n)=>_(["\\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 To(e,n){if(n===null)return"";let t=x(n);if(!t)return"";if(t==="Set")return J(n)===0?"\\emptyset":J(n)===2&&x(p(n,2))==="Condition"?_(["\\left\\lbrace",e.serialize(p(n,1)),"\\middle\\mid",e.serialize(p(n,2)),"\\right\\rbrace"]):_(["\\left\\lbrace",...N(n).map(r=>e.serialize(r)+" ,"),"\\right\\rbrace"]);if(t==="Range")return _(["\\mathopen\\lbrack",e.serialize(p(n,1)),", ",e.serialize(p(n,2)),"\\mathclose\\rbrack"]);if(t==="Interval"){let r=p(n,1),s=p(n,2),o=!1,a=!1;return x(r)==="Open"&&(r=p(r,1),o=!0),x(s)==="Open"&&(s=p(s,1),a=!0),_([o?"\\lparen":"\\lbrack",e.serialize(r),", ",e.serialize(s),a?"\\rparen":"\\rbrack"])}let i=e.numericSetStyle(n,e.level);return""}function In(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.map(r=>{switch(r){case"#1":return n;case"#2":return t;default:return r}}))}function Ct(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 xl(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 Rt(e){let{deg:n,min:t,sec:i}=xl(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 El(e){if(x(e)!=="Multiply")return[[],[]];let n=[],t=[];for(let i of N(e))if(x(i)==="Power"){let r=p(i,1),s=p(i,2);if(x(s)==="Negate"){let o=p(s,1);r&&o&&t.push(["Power",r,o])}else{let o=R(s)??NaN;o===-1?r&&t.push(r):o<0?r&&t.push(["Power",r,-o]):n.push(i)}}else if(x(i)==="Rational"&&J(i)===2||x(i)==="Divide"){let r=p(i,1),s=p(i,2);R(r)!==1&&n.push(r),R(s)!==1&&t.push(s)}else{let r=vn(i);r!==null?(r[0]!==1&&n.push(r[0]),t.push(r[1])):n.push(i)}return[n,t]}function vl(e){let n=e.parseOptionalGroup(),t=e.parseGroup()??e.parseToken();return j(t)?n!==null?["Root",yn,z(n)]:["Sqrt",yn]:n!==null?["Root",t,n]:["Sqrt",t]}function Nl(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 Wn(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)+"}}":R(i)===2?"\\sqrt{"+e.serialize(t)+"}":"\\sqrt["+e.serialize(i)+"]{"+e.serialize(t)+"}")}function Tl(e,n){e.level-=1;let t=x(n),i="",r=p(n,1);if(t==="Negate")i="-"+e.wrap(r,ee+1);else if(t==="Subtract"){i=e.wrap(r,ee);let s=p(n,2);if(s!==null){let o=e.wrap(s,ee);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]=[p(n,1),p(n,2)],[l,c]=[a,u],f=R(l),d=vn(c);if((f===null||d===null)&&([l,c]=[u,a],f=R(l),d=vn(c)),f!==null&&d!==null&&isFinite(f)&&Number.isInteger(f)&&f>=0&&f<=1e3&&isFinite(d[0])&&isFinite(d[1])&&d[0]>0&&d[0]<=100&&d[1]<=100)return i=In(e.options.invisiblePlus,e.serialize(l),e.serialize(c)),e.level+=1,i}if(e.options.prettify&&J(n)===2){let[a,u]=Hn(r),[l,c]=Hn(p(n,2));if(u<0&&c>0)return i=e.wrap(l,ee)+"-"+e.wrap(a,ee),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]=Hn(r),c=e.wrap(u,ee);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,ee);u[0]==="-"||u[0]==="+"?i+=u:i+="+"+u}}return e.level+=1,i}function $o(e,n){if(n===null)return"";e.level-=1;let t="";if(e.options.prettify===!0){let[u,l]=El(n);l.length>0&&(l.length===1&&l[0]===1?u.length===0?t="1":u.length===1?t=e.serialize(u[0]):t=$o(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&&sn(o[1])&&!sn(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(sn(r)){l=e.serialize(r),l==="-1"&&!t?(t="",i=!i):(l[0]==="-"&&(l=l.slice(1),i=!i),t?t=In(e.options.multiply,t,l):t=l),a=!0;continue}if(x(r)==="Power"){let c=vn(p(r,2));if(c!=null){let[f,d]=c;if(f===1&&d!==null){t+=Wn(e,e.rootStyle(r,e.level),p(r,1),d),a=!1;continue}}}if(x(r)==="Power"&&!isNaN(R(p(r,1))??NaN)){l=e.serialize(r),t?t=In(e.options.multiply,t,l):t=l,a=!0;continue}if(x(r)==="Negate"&&(r=p(r,1),i=!i),l=e.wrap(r,ye),!t)t=l;else{let c=x(r);a&&(c==="Divide"||c==="Rational")?t=In(e.options.multiply,t,l):e.options.invisibleMultiply?t=In(e.options.invisibleMultiply,t,l):t=_([t,l])}a=!1}return e.level+=1,i?"-"+t:t}function Dt(e){let n=e.parseGroup(),t=null;if(n===null?(n=e.parseToken(),t=e.parseToken()):t=e.parseGroup(),n=z(n),t=z(t),x(n)==="PartialDerivative"&&(x(t)==="PartialDerivative"||x(t)==="Multiply"&&x(p(t,1))==="PartialDerivative")){let s=p(n,3)??null,o=p(n,1);o==null&&(o=z(e.parseExpression()));let a=[];if(x(t)==="Multiply"){for(let u of N(t))if(x(u)==="PartialDerivative"){let l=p(u,2);l&&a.push(l)}}else{let u=p(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=x(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",z(e.parseExpression()),...s]}return["Divide",n,t]}function _o(e,n){if(n===null)return"";let t=z(p(n,1)),i=z(p(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 R(t)===1?e.wrap(i)+"^{-1}":e.wrap(t)+e.wrap(i)+"^{-1}";if(r==="factor")return R(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 Pi(e,n){if(!n)return"";let t=x(n),i=z(p(n,1));if(t==="Sqrt")return Wn(e,e.rootStyle(n,e.level-1),i,2);let r=z(p(n,2));if(t==="Root")return Wn(e,e.rootStyle(n,e.level-1),i,r);if(e.options.prettify){let o=R(r)??1;if(o===-1)return e.serialize(["Divide","1",i]);if(o<0)return e.serialize(["Divide","1",["Power",i,-o]]);if(x(r)==="Divide"||x(r)==="Rational"){let a=R(p(r,1)),u=R(p(r,2));if(a===1){let l=e.rootStyle(n,e.level);return Wn(e,l,i,p(r,2))}if(a===-1)return u===2?e.serialize(["Divide","1",["Sqrt",i]]):e.serialize(["Divide","1",["Root",i,p(r,2)??yn]]);if(u===2)return`${e.serialize(["Sqrt",i])}^{${e.serialize(p(r,1))}}`}else if(x(r)==="Power"&&R(p(r,2))===-1){let a=e.rootStyle(n,e.level);return Wn(e,a,i,p(r,1))}}let s=o=>o.startsWith("-")?e.wrapString(o,"normal"):o;if(x(i)==="Power"){let o=p(i,1),a=p(i,2),u=s(e.wrapShort(o)),l=e.wrapShort(a);return`
|
|
6
|
-
${u}^{${bn("^",l,e.serialize(r))}}`}return bn("^",s(e.wrapShort(i)),e.serialize(r))}function Yn(e,n){e.skipSpace();let t=e.index,i=e.parseNumber(),r=null,s=null;if(i!==null&&(e.match("'")||e.match("\\prime"))){r=R(i),e.skipSpace();let u=e.index,l=e.parseNumber();l!==null&&(e.match('"')||e.match("\\doubleprime"))?s=R(l):e.index=u}else return e.index=t,["Degrees",n];let o=R(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 Co=[{name:"CatalanConstant",symbolTrigger:"G"},{name:"GoldenRatio",latexTrigger:"\\varphi"},{name:"EulerGamma",latexTrigger:"\\gamma"},{name:"Degrees",latexTrigger:["\\degree"],kind:"postfix",precedence:880,parse:(e,n)=>Yn(e,n),serialize:(e,n)=>{let t=e.options,i=p(n,1);if(t.dmsFormat||t.angleNormalization&&t.angleNormalization!=="none"){let r=R(i);if(r!==null){let s=r;return t.angleNormalization&&t.angleNormalization!=="none"&&(s=Ct(s,t.angleNormalization)),t.dmsFormat?Rt(s):`${s}\xB0`}}return _([e.serialize(i),"\\degree"])}},{latexTrigger:["\\degree"],kind:"postfix",precedence:880,parse:(e,n)=>Yn(e,n)},{latexTrigger:["^","<{>","\\circ","<}>"],kind:"postfix",parse:(e,n)=>Yn(e,n)},{latexTrigger:["^","\\circ"],kind:"postfix",parse:(e,n)=>Yn(e,n)},{latexTrigger:["\xB0"],kind:"postfix",precedence:880,parse:(e,n)=>Yn(e,n)},{latexTrigger:["\\ang"],parse:e=>{let n=e.parseGroup();return n===null?["Degrees"]:["Degrees",n]}},{name:"DMS",serialize:(e,n)=>{let t=R(p(n,1)),i=R(p(n,2)),r=R(p(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=p(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)=>j(n)?null:["Abs",n]},{kind:"matchfix",openTrigger:["\\vert"],closeTrigger:["\\vert"],parse:(e,n)=>j(n)?null:["Abs",n]},{symbolTrigger:"abs",kind:"function",parse:"Abs"},{name:"Add",latexTrigger:["+"],kind:"infix",associativity:"any",precedence:ee,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:ee});if(i===null)return null;if(x(i)==="Negate"){let r=p(i,1);if(sn(r))return Nn("Add",n,Nl(r))}return Nn("Add",n,i)},serialize:Tl},{kind:"prefix",latexTrigger:["+"],precedence:ee,parse:(e,n)=>e.parseExpression({...n,minPrec:400})},{name:"Ceil",kind:"matchfix",openTrigger:"\\lceil",closeTrigger:"\\rceil",parse:(e,n)=>j(n)?null:["Ceil",n]},{kind:"matchfix",openTrigger:["\u2308"],closeTrigger:["\u2309"],parse:(e,n)=>j(n)?null:["Ceil",n]},{symbolTrigger:"ceil",kind:"function",parse:"Ceil"},{name:"Chop",symbolTrigger:"chop",kind:"function",parse:"Chop"},{name:"Complex",precedence:ee-1,serialize:(e,n)=>{let t=e.serialize(p(n,1)),i=R(p(n,2));if(i===0)return t;let r=i===1?"\\imaginaryI":i===-1?"-\\imaginaryI":_([e.serialize(p(n,2)),"\\imaginaryI"]);return R(p(n,1))===0?r:i!==null&&i<0?_([t,r]):_([t,"+",r])}},{name:"Divide",latexTrigger:"\\frac",precedence:xe,parse:Dt,serialize:_o},{latexTrigger:"\\dfrac",precedence:xe,parse:Dt},{latexTrigger:"\\tfrac",precedence:xe,parse:Dt},{latexTrigger:"\\cfrac",precedence:xe,parse:Dt},{kind:"infix",latexTrigger:"\\over",associativity:"none",precedence:xe,parse:"Divide"},{latexTrigger:["\\/"],kind:"infix",associativity:"left",precedence:xe,parse:"Divide"},{latexTrigger:["/"],kind:"infix",associativity:"left",precedence:xe,parse:"Divide"},{latexTrigger:["\\div"],kind:"infix",associativity:"left",precedence:xe,parse:"Divide"},{name:"Exp",serialize:(e,n)=>{let t=p(n,1);return S(t)||R(t)!==null?_(["\\exponentialE^{",e.serialize(t),"}"]):_(["\\exp",e.wrap(z(t))])}},{name:"Factorial",latexTrigger:["!"],kind:"postfix",precedence:Ii},{name:"Factorial2",latexTrigger:["!","!"],kind:"postfix",precedence:Ii},{name:"Floor",kind:"matchfix",openTrigger:"\\lfloor",closeTrigger:"\\rfloor",parse:(e,n)=>j(n)?null:["Floor",n]},{kind:"matchfix",openTrigger:["\u230A"],closeTrigger:["\u230B"],parse:(e,n)=>j(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=p(n,1),i=p(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=p(n,1),i=p(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=p(n,1),i=p(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=p(n,1),i=p(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=>Ao("Ln",e),serialize:(e,n)=>"\\ln"+e.wrapArguments(n)},{name:"Log",latexTrigger:["\\log"],parse:e=>Ao("Log",e),serialize:(e,n)=>{let[t,i]=N(n);return 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(x(n)!=="To")return null;let t=e.parseArguments("implicit");return t?["Limit",["Function",t[0],p(n,1)],p(n,2)]:null},serialize:(e,n)=>{let t=p(n,1),i=p(t,2),r=p(n,2);return _(["\\lim_{",e.serialize(i),"\\to",e.serialize(r),"}",e.serialize(p(t,1))])}},{name:"MinusPlus",latexTrigger:["\\mp"],kind:"infix",associativity:"any",precedence:Be},{name:"Multiply",latexTrigger:["\\times"],kind:"infix",associativity:"any",precedence:ye,serialize:$o},{latexTrigger:["\\cdot"],kind:"infix",associativity:"any",precedence:ye,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:ye+2});return i===null?null:Nn("Multiply",n,i)}},{latexTrigger:["*"],kind:"infix",associativity:"any",precedence:ye,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:ye+2});return i===null?["Multiply",n,yn]:Nn("Multiply",n,i)}},{name:"Mod",latexTrigger:"\\bmod",kind:"infix",precedence:xe,serialize:(e,n)=>{if(J(n)!==2)return"";let t=e.serialize(p(n,1)),i=e.serialize(p(n,2));return _([t,"\\bmod",i])}},{latexTrigger:"\\mod",kind:"infix",precedence:xe,parse:"Mod"},{latexTrigger:"\\pmod",kind:"prefix",precedence:D,parse:e=>{let n=e.parseGroup()??e.parseToken();return["Mod",z(n)]}},{name:"Congruent",serialize:(e,n)=>{let t=e.serialize(p(n,1)),i=e.serialize(p(n,2));if(p(n,3)===null)return _([t,"\\equiv",i]);let r=e.serialize(p(n,3));return _([t,"\\equiv",i,"\\pmod{",r,"}"])}},{name:"Negate",latexTrigger:["-"],kind:"prefix",precedence:Gn+1,parse:(e,n)=>{e.skipSpace();let t=e.parseExpression({...n,minPrec:Gn+3});return t===null?null:["Negate",t]}},{kind:"matchfix",openTrigger:"||",closeTrigger:"||",parse:(e,n)=>j(n)?null:["Norm",n]},{name:"Norm",kind:"matchfix",openTrigger:["\\left","\\Vert"],closeTrigger:["\\right","\\Vert"],parse:(e,n)=>j(n)?null:["Norm",n],serialize:(e,n)=>{let t=p(n,1);if(x(t)==="Matrix"){let i=p(t,1),r=p(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:Be,serialize:(e,n)=>{let t=p(n,1);if(t===null)return"\\pm";if(J(n)===1)return _(["\\pm",e.serialize(t)]);let i=p(n,2);return _([e.serialize(t),"\\pm",e.serialize(i)])}},{latexTrigger:["\\pm"],kind:"prefix",precedence:Be,parse:(e,n)=>{let t=e.parseExpression({...n,minPrec:400});return["PlusMinus",0,z(t)]}},{latexTrigger:["\\plusmn"],kind:"infix",associativity:"any",precedence:Be,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:400});return["PlusMinus",n,z(i)]}},{latexTrigger:["\\plusmn"],kind:"prefix",precedence:Be,parse:(e,n)=>{let t=e.parseExpression({...n,minPrec:400});return["PlusMinus",z(t)]}},{name:"Power",latexTrigger:["^"],kind:"infix",serialize:Pi},{latexTrigger:"\\prod",precedence:ye,name:"Product",parse:So("Product","Multiply",ye),serialize:wo("\\prod")},{latexTrigger:["*","*"],kind:"infix",associativity:"right",precedence:Gn,parse:(e,n,t)=>{if(e.options.strict!==!1)return null;let i=e.parseExpression({...t,minPrec:Gn});return i===null?null:["Power",n,i]}},{name:"Rational",precedence:xe,serialize:(e,n)=>n&&J(n)===1?"\\operatorname{Rational}"+e.wrapArguments(n):_o(e,n)},{name:"Reduce",serialize:(e,n)=>{let t=p(n,1);if(!t)return"";let i=p(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(p(n,2))}\\right)`}},{name:"Root",serialize:Pi},{name:"Round",symbolTrigger:"round",kind:"function"},{name:"Square",precedence:720,serialize:(e,n)=>{let t=e.wrapShort(p(n,1));return(t.startsWith("-")?e.wrapString(t,"normal"):t)+"^2"}},{latexTrigger:["\\sum"],precedence:ee,name:"Sum",parse:So("Sum","Add",ye),serialize:wo("\\sum")},{name:"Heaviside",symbolTrigger:"Heaviside",kind:"function"},{name:"Sign",symbolTrigger:"sgn",kind:"function"},{name:"Sqrt",latexTrigger:["\\sqrt"],parse:vl,serialize:Pi},{name:"Subtract",latexTrigger:["-"],kind:"infix",associativity:"left",precedence:ee+2,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:ee+3});return i===null?null:["Subtract",n,i]},serialize:(e,n)=>{let t=e.wrap(p(n,1),ee+2),i=e.wrap(p(n,2),ee+3);return _([t,"-",i])}}];function Il(e,n){if(e!==null){if(S(e))return{index:S(e)??"Nothing",upper:n};if(x(e)==="GreaterEqual"){let t=S(p(e,1))??"Nothing",i=p(e,2)??1;return{index:t,lower:i,upper:n}}if(x(e)==="Equal"){let t=S(p(e,1))??"Nothing",i=p(e,2);if(x(i)==="Range"){let s=p(i,1)??1,o=p(i,2)??void 0;return{index:t,lower:s,upper:o}}return{index:t,lower:i??1,upper:n}}if(x(e)==="Element")return{index:S(p(e,1))??"Nothing",element:e}}}function _l(e){let n=x(e);return n?new Set(["Less","LessEqual","Greater","GreaterEqual","NotEqual","And","Or","Not"]).has(n):!1}function ko(e){if(e===null)return[];let n=on(e);if(n)return[...n];if(x(e)==="Tuple"){let t=N(e);return t?[...t]:[e]}return[e]}function kl(e,n){j(e)&&(e=null),j(n)&&(n=null);let t=ko(e),i=ko(n),r=[],s=0;for(;s<t.length;){let o=t[s],a=Il(o,i[s]);if(a){if(a.element&&s+1<t.length){let u=t[s+1];if(_l(u)&&x(u)!=="Element"&&x(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 So(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=kl(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,f=l.upper,d=l.index??"Nothing";f!=null?u.push(["Tuple",d,c??1,f]):c!=null?u.push(["Tuple",d,c]):u.push(["Tuple",d])}return[e,a,...u]}}var Sl=new Set(["Tuple","Triple","Pair","Single","Limits","Element"]);function Mo(e){return e==null||S(e)==="Nothing"?null:e}function Ml(e){let n=[],t=N(e);if(t.length<=1)return n;for(let i of t.slice(1)){let r=x(i);if(r&&Sl.has(r)){n.push(i);continue}break}return n}function wl(e,n){if(x(n)==="Element"){let l=e.serialize(p(n,1)),c=e.serialize(p(n,2));return{sub:`${l}\\in ${c}`}}let t=p(n,1);t!==null&&x(t)==="Hold"&&(t=p(t,1));let i=Mo(p(n,2)),r=Mo(p(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 wo(e){return(n,t)=>{let i=p(t,1);if(!i)return e;let r=Ml(t),s=e;if(r.length>0){let o=[],a=[];for(let u of r){let l=wl(n,u);l.sub&&o.push(l.sub),l.sup&&a.push(l.sup)}o.length>0&&(s=bn("_",s,o.join(", "))),a.length>0&&(s=bn("^",s,a.join(", ")))}return _([s,n.serialize(i)])}}function Ao(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 Hn(e){let n=1,t=e;do{e=t;let i=x(e);if(i==="Negate")n*=-1,t=p(e,1);else if(i==="Multiply"){let[r,s]=Hn(p(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]=Hn(p(e,1));s<0&&(n*=-1,t=[i,r,p(e,2)])}else{let r=R(e);r!==null&&r<0&&(n*=-1,t=-r)}}while(t!==e);return[e,n]}var Ro=[{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 w(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:ye,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 Do=[{name:"Arcsin",latexTrigger:["\\arcsin"],parse:w("Arcsin")},{name:"Arccos",latexTrigger:["\\arccos"],parse:w("Arccos")},{name:"Arctan",latexTrigger:["\\arctan"],parse:w("Arctan")},{latexTrigger:["\\arctg"],parse:w("Arctan")},{symbolTrigger:"arctg",parse:w("Arctan")},{name:"Arccot",symbolTrigger:"arcctg",parse:w("Arccot")},{latexTrigger:["\\arcctg"],parse:w("Arccot")},{name:"Arcoth",symbolTrigger:"arcoth",parse:w("Arcoth")},{symbolTrigger:"arccoth",parse:w("Arcoth")},{latexTrigger:["\\arcoth"],parse:w("Arcoth")},{latexTrigger:["\\arccoth"],parse:w("Arcoth")},{name:"Arcsec",symbolTrigger:"arcsec",parse:w("Arcsec")},{latexTrigger:["\\arcsec"],parse:w("Arcsec")},{name:"Arccsc",symbolTrigger:"arccsc",parse:w("Arccsc")},{latexTrigger:["\\arccsc"],parse:w("Arccsc")},{name:"Arsinh",symbolTrigger:"arsinh",parse:w("Arsinh")},{symbolTrigger:"arcsinh",parse:w("Arsinh")},{latexTrigger:["\\arsinh"],parse:w("Arsinh")},{latexTrigger:["\\arcsinh"],parse:w("Arsinh")},{name:"Arcosh",symbolTrigger:"arcosh",parse:w("Arcosh")},{symbolTrigger:"arccosh",parse:w("Arcosh")},{latexTrigger:"\\arcosh",parse:w("Arcosh")},{latexTrigger:"\\arccosh",parse:w("Arcosh")},{name:"Artanh",symbolTrigger:"artanh",parse:w("Artanh")},{symbolTrigger:"arctanh",parse:w("Artanh")},{latexTrigger:"\\artanh",parse:w("Artanh")},{latexTrigger:["\\arctanh"],parse:w("Artanh")},{name:"Arsech",symbolTrigger:"arsech",parse:w("Arsech")},{symbolTrigger:"arcsech",parse:w("Arsech")},{latexTrigger:["\\arsech"],parse:w("Arsech")},{latexTrigger:["\\arcsech"],parse:w("Arsech")},{name:"Arcsch",symbolTrigger:"arcsch",parse:w("Arcsch")},{symbolTrigger:"arccsch",parse:w("Arcsch")},{latexTrigger:["\\arcsch"],parse:w("Arcsch")},{latexTrigger:["\\arccsch"],parse:w("Arcsch")},{name:"Cosec",symbolTrigger:"cosec",parse:w("Cosec")},{latexTrigger:["\\cosec"],parse:w("Cosec")},{name:"Cosh",latexTrigger:["\\cosh"],parse:w("Cosh")},{latexTrigger:["\\ch"],parse:w("Cosh")},{name:"Cot",latexTrigger:["\\cot"],parse:w("Cot")},{latexTrigger:["\\cotg"],parse:w("Cot")},{latexTrigger:["\\ctg"],parse:w("Cot")},{name:"Csc",latexTrigger:["\\csc"],parse:w("Csc")},{name:"Csch",latexTrigger:["\\csch"],parse:w("Csch")},{name:"Coth",latexTrigger:["\\coth"],parse:w("Coth")},{latexTrigger:["\\cth"],parse:w("Coth")},{symbolTrigger:"cth",parse:w("Coth")},{latexTrigger:["\\coth"],parse:w("Coth")},{name:"Sec",latexTrigger:["\\sec"],parse:w("Sec")},{name:"Sech",symbolTrigger:"sech",parse:w("Sech")},{latexTrigger:["\\sech"],parse:w("Sech")},{name:"Sinh",latexTrigger:["\\sinh"],parse:w("Sinh")},{latexTrigger:["\\sh"],parse:w("Sinh")},{name:"Tan",latexTrigger:["\\tan"],parse:w("Tan")},{latexTrigger:["\\tg"],parse:w("Tan")},{name:"Tanh",latexTrigger:["\\tanh"],parse:w("Tanh")},{latexTrigger:["\\th"],parse:w("Tanh")},{name:"Cos",latexTrigger:["\\cos"],parse:w("Cos")},{name:"Sin",latexTrigger:["\\sin"],parse:w("Sin")},{name:"Sinc",symbolTrigger:"sinc",kind:"function"},{name:"FresnelS",symbolTrigger:"FresnelS",kind:"function"},{name:"FresnelC",symbolTrigger:"FresnelC",kind:"function"}];function _n(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();j(u)&&(u=null),j(a)&&(a=null),i.push(u??"Nothing"),r.push(a??"Nothing"),n.skipVisualSpace(),t=!n.match(e)}let[s,o]=Al(n);if(s&&o.length===0){if(x(s)==="Add"||x(s)==="Subtract"){let a=[],u=[];for(let l of N(s))if(o)u.push(l);else{let c;[c,o]=ze(l),a.push(c??l)}if(o!==null&&u.length>0)return["Add",Po(e,["Add",...a],{indexes:o,subs:i,sups:r})??"Nothing",...u]}else if(x(s)==="Divide"){let a;[a,o]=ze(p(s,1)),a!==null&&o!==null&&(s=["Divide",a,p(s,2)])}}return Po(e,s,{indexes:o,subs:i,sups:r})}}function Po(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?x(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 Al(e){let n=!1,t=e.parseExpression({minPrec:266,condition:()=>{let i=e.index;return n=Oo(e),e.index=i,n}});return t!==null&&!n?ze(t):[t,$l(e)]}function $l(e){let n=[];for(;Oo(e);){e.skipVisualSpace();let t=S(e.parseSymbol());if(t===null)return n;n.push(t)}return n}function ze(e){let n=x(e),t=p(e,1);if(!t)return[e,[]];if(n==="Sequence"&&J(e)===1)return ze(t);if(n==="Multiply"||n==="InvisibleOperator"){let i=N(e);if(i){let[r,s]=Cl(i);return r.length>0?[[n,...r],s]:[null,s]}}else if(n==="Delimiter"){let[i,r]=ze(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]=ze(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]=ze(t);if(r.length>0)return[i?["Negate",i]:null,r]}else if(n==="Divide"){let[i,r]=ze(t);if(r.length>0)return[["Divide",i??1,p(e,2)],r]}else{let i=N(e);if(i.length===1){let[r,s]=ze(i[0]);if(s.length>0)return[[x(e),r],s]}}return[e,[]]}function Fo(e){return(n,t)=>{if(!p(t,1))return e;let i=p(t,1),r=[];x(i)==="BuiltInFunction"?(r=["x"],i=[p(i,1),"x"]):x(i)==="Function"?(r=N(i).slice(1),i=p(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 f=x(l);if(f==="Tuple"||f==="Pair"||f==="Limits"||f==="Range"){if(J(l)===3){let d=p(l,1);o.push(S(d)??"Nothing");let m=p(l,2),b=p(l,3);return S(m)==="Nothing"&&(m=null),S(b)==="Nothing"&&(b=null),m!==null&&b!==null?`_{${n.serialize(m)}}^{${n.serialize(b)}}`:m!==null?`_{${n.serialize(m)}}`:b!==null?`^{${n.serialize(b)}}`:""}return`_{${n.serialize(l)}}`}if(J(l)===2){if(S(p(l,1))){o.push(S(p(l,1))??"Nothing");let b=p(l,2);return S(b)==="Nothing"?"":`_{${n.serialize(b)}}`}o.push(S(r[c])??"Nothing");let d=p(l,1),m=p(l,2);if(S(d)==="Nothing"&&(d=null),S(m)==="Nothing"&&(m=null),d!==null&&m!==null)return`_{${n.serialize(d)}}^{${n.serialize(m)}}`;if(d!==null)return`_{${n.serialize(d)}}`;if(m!==null)return`^{${n.serialize(m)}}`}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 Lo=[{kind:"expression",name:"Integrate",latexTrigger:["\\int"],parse:_n("Integrate"),serialize:Fo("\\int")},{kind:"expression",latexTrigger:["\\iint"],parse:_n("Integrate")},{kind:"expression",latexTrigger:["\\iiint"],parse:_n("Integrate")},{kind:"expression",name:"CircularIntegrate",latexTrigger:["\\oint"],parse:_n("CircularIntegrate"),serialize:Fo("\\oint")},{kind:"expression",latexTrigger:["\\oiint"],parse:_n("CircularIntegrate")},{kind:"expression",latexTrigger:["\\oiiint"],parse:_n("CircularIntegrate")}];function Oo(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 Cl(e){let n=[...e],t=[];for(;n.length>0;){let i;if([n,i]=Rl(n),!i)break;t.push(i)}return[n,t]}function Rl(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 Bo=[{name:"Matrix",serialize:(e,n)=>{let t=N(p(n,1));return Fi(e,t,B(p(n,2)),B(p(n,3)))}},{name:"Vector",serialize:(e,n)=>{let t=N(n);return Fi(e,t.map(i=>["List",i]),B(p(n,2)),B(p(n,3)))}},{kind:"environment",symbolTrigger:"pmatrix",parse:e=>{let n=qe(e),[t,i]=Je(e);return n?[t,i,{str:"()"},{str:n}]:[t,i]}},{kind:"environment",symbolTrigger:"bmatrix",parse:e=>{let n=qe(e),[t,i]=Je(e);return n?[t,i,{str:"[]"},{str:n}]:[t,i,{str:"[]"}]}},{kind:"environment",symbolTrigger:"Bmatrix",parse:e=>{let n=qe(e),[t,i]=Je(e);return n?[t,i,{str:"{}"},{str:n}]:[t,i,{str:"{}"}]}},{kind:"environment",symbolTrigger:"vmatrix",parse:e=>{let n=qe(e),[t,i]=Je(e);return n?["Determinant",[t,i,{str:n}]]:["Determinant",[t,i]]}},{kind:"environment",symbolTrigger:"Vmatrix",parse:e=>{let n=qe(e),[t,i]=Je(e);return n?["Norm",[t,i,{str:n}]]:["Norm",[t,i]]}},{kind:"environment",symbolTrigger:"smallmatrix",parse:e=>{let n=qe(e),[t,i]=Je(e);return n?[t,i,{str:"()"},{str:n}]:[t,i]}},{kind:"environment",symbolTrigger:"array",parse:e=>{let n=qe(e,!1),[t,i]=Je(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{kind:"environment",symbolTrigger:"matrix",parse:e=>{let n=qe(e),[t,i]=Je(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{kind:"environment",symbolTrigger:"matrix*",parse:e=>{let n=qe(e),[t,i]=Je(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(p(n,1))+"^{-1}"},{name:"Trace",kind:"function",latexTrigger:"\\tr",arguments:"implicit",serialize:(e,n)=>kn(e,n,"\\tr")},{symbolTrigger:"tr",kind:"function",parse:"Trace",arguments:"implicit"},{name:"Kernel",kind:"function",latexTrigger:"\\ker",arguments:"implicit",serialize:(e,n)=>kn(e,n,"\\ker")},{symbolTrigger:"ker",kind:"function",parse:"Kernel",arguments:"implicit"},{name:"Dimension",kind:"function",latexTrigger:"\\dim",arguments:"implicit",serialize:(e,n)=>kn(e,n,"\\dim")},{symbolTrigger:"dim",kind:"function",parse:"Dimension",arguments:"implicit"},{name:"Degree",kind:"function",latexTrigger:"\\deg",arguments:"implicit",serialize:(e,n)=>kn(e,n,"\\deg")},{symbolTrigger:"deg",kind:"function",parse:"Degree",arguments:"implicit"},{name:"Hom",kind:"function",latexTrigger:"\\hom",arguments:"implicit",serialize:(e,n)=>kn(e,n,"\\hom")},{symbolTrigger:"hom",kind:"function",parse:"Hom",arguments:"implicit"},{name:"Determinant",kind:"function",latexTrigger:"\\det",arguments:"implicit",serialize:(e,n)=>{let t=p(n,1);if(x(t)==="Matrix"){let i=N(p(t,1));return Fi(e,i,"||",B(p(t,2)))}return kn(e,n,"\\det")}},{symbolTrigger:"det",kind:"function",parse:"Determinant",arguments:"implicit"},{name:"MatrixMultiply",serialize:(e,n)=>{let t=e.serialize(p(n,1)),i=e.serialize(p(n,2));return`${t} \\cdot ${i}`}}];function Je(e){let n=e.parseTabular();return n?["Matrix",["List",...n.map(t=>["List",...t])]]:["",null]}function qe(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 kn(e,n,t){if(N(n).length!==1)return`${t}${e.wrapArguments(n)}`;let r=p(n,1),s=e.serialize(r);return typeof r=="string"||typeof r=="number"?`${t} ${s}`:`${t}\\left(${s}\\right)`}function Fi(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 f=[];for(let d of N(c))f.push(e.serialize(d));a.push(f.join(" & "))}let u=a.join(`\\\\
|
|
7
|
-
`),l=o.length>0?`[${o}]`:"";return r==="("&&s===")"?_(["\\begin{pmatrix}",l,u,"\\end{pmatrix}"]):r==="["&&s==="]"?_(["\\begin{bmatrix}",l,u,"\\end{bmatrix}"]):r==="{"&&s==="}"?_(["\\begin{Bmatrix}",l,u,"\\end{Bmatrix}"]):r==="|"&&s==="|"?_(["\\begin{vmatrix}",l,u,"\\end{vmatrix}"]):r==="\u2016"&&s==="\u2016"?_(["\\begin{Vmatrix}",l,u,"\\end{Vmatrix}"]):r==="{"&&s==="."?_(["\\begin{dcases}",l,u,"\\end{dcases}"]):r==="."&&s==="}"?_(["\\begin{rcases}",l,u,"\\end{rcases}"]):o||r!=="."||s!=="."?_(["\\left",At[r]??r,"\\begin{array}",`{${o}}`,u,"\\end{array}","\\right",At[s]??s]):_(["\\begin{matrix}",u,"\\end{matrix}"])}var Vo=[{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 Pt={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},zo=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"]),Ft={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 Dl(e){if(e.length>2){let n=e.slice(0,2),t=e.slice(2);if(Pt[n]!==void 0&&zo.has(t)){let i=Ft[t];if(i)return{prefixScale:Pt[n],baseEntry:i}}}if(e.length>1){let n=e.slice(0,1),t=e.slice(1);if(Pt[n]!==void 0&&zo.has(t)){let i=Ft[t];if(i)return{prefixScale:Pt[n],baseEntry:i}}}return null}function Pl(e){let n=Ft[e];if(n)return n;let t=Dl(e);return t?{dimension:t.baseEntry.dimension,scale:t.prefixScale*t.baseEntry.scale}:null}function Li(e){let n=Pl(e);return n?n.dimension:null}var Vh=new Map(["N","J","W","Pa","Hz","C","V","F","ohm","S","Wb","T","H","lm","lx","Gy","kat"].map(e=>[Ft[e].dimension.join(","),e]));function Fl(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 Xn(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 Xn(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=Xn(r),a=Xn(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=>Xn(a));return o.some(a=>a===null)?null:o.length===1?o[0]:["Multiply",...o]}return e[0]==="("?null:Fl(e)}function Jo(e){return e=e.trim(),e.length===0?null:/[/*^()]/.test(e)?Xn(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 Ll=new Set(["d"]);function Uo(e){if(!e||e.length===0||Ll.has(e))return null;if(Li(e)!==null)return e;if(/[/*^]/.test(e))try{let n=Jo(e);if(n!==null&&Oi(n))return n}catch{return null}return null}function Oi(e){if(typeof e=="string")return Li(e)!==null;if(!Array.isArray(e))return!1;let n=e[0];return n==="Multiply"||n==="Divide"?e.slice(1).every(t=>Oi(t)):n==="Power"?Oi(e[1]):!1}var qo=e=>{let n=e.index,t=Zo(e);if(t===null)return e.index=n,null;let i=Uo(t);return i===null?(e.index=n,null):["__unit__",i]};function an(e){let n=S(e);if(n!==null)return n;if(typeof e=="number")return String(e);let t=x(e);if(!t)return"";if(t==="Divide"){let i=p(e,1),r=p(e,2);return`${an(i)}/${an(r)}`}if(t==="Multiply"){let i=[];if(Array.isArray(e))for(let r=1;r<e.length;r++)i.push(an(e[r]));return i.join("\\cdot ")}if(t==="Power"){let i=p(e,1),r=p(e,2),s=typeof r=="number"?String(r):S(r)??String(r);return`${an(i)}^{${s}}`}if(t==="Square"){let i=p(e,1);return`${an(i)}^{2}`}return""}function jo(e){let n=e.parseGroup();if(n===null)return null;let t=Yo(e);return t===null?null:["Quantity",n,t]}function Go(e){return Yo(e)}function Yo(e){let n=e.index,t=Zo(e);if(t===null)return e.index=n,null;let i=Uo(t);return i===null?(e.index=n,null):i}var Wo=[{latexTrigger:"\\mathrm",kind:"expression",parse:qo},{latexTrigger:"\\text",kind:"expression",parse:qo},{latexTrigger:"\\qty",parse:jo},{latexTrigger:"\\SI",parse:jo},{latexTrigger:"\\unit",parse:Go},{latexTrigger:"\\si",parse:Go},{name:"Quantity",serialize:(e,n)=>{let t=p(n,1),i=p(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=R(t);if(l===null){let f=e.serialize(t),d=an(i);return _([f,"\\,",`\\mathrm{${d}}`])}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=Ct(c,o.angleNormalization)),o.dmsFormat?Rt(c):`${c}\xB0`}let a=e.serialize(t),u=an(i);return _([a,"\\,",`\\mathrm{${u}}`])}}];function me(e){return n=>{let t=n.parseGroup();return t===null?[e]:[e,t]}}var Ho=[{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=on(i);if(r&&(i=["List",...r]),i===null||t===null)return null;let s=e.parseGroup()??"Nothing";if(!j(s)){let o=e.parseArguments()??["Nothing"];s=[s,...o]}return["PartialDerivative",s,i,t]},serialize:(e,n)=>{let t="\\partial",i=p(n,1),r=p(n,2),s=p(n,3);return r!==null&&r!=="Nothing"&&(x(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:me("OverBar")},{name:"UnderBar",latexTrigger:["\\underline"],parse:me("UnderBar")},{name:"OverVector",latexTrigger:["\\vec"],parse:me("OverVector")},{name:"OverTilde",latexTrigger:["\\tilde"],parse:me("OverTilde")},{name:"OverHat",latexTrigger:["\\hat"],parse:me("OverHat")},{name:"OverRightArrow",latexTrigger:["\\overrightarrow"],parse:me("OverRightArrow")},{name:"OverLeftArrow",latexTrigger:["\\overleftarrow"],parse:me("OverLeftArrow")},{name:"OverRightDoubleArrow",latexTrigger:["\\Overrightarrow"],parse:me("OverRightDoubleArrow")},{name:"OverLeftHarpoon",latexTrigger:["\\overleftharpoon"],parse:me("OverLeftHarpoon")},{name:"OverRightHarpoon",latexTrigger:["\\overrightharpoon"],parse:me("OverRightHarpoon")},{name:"OverLeftRightArrow",latexTrigger:["\\overleftrightarrow"],parse:me("OverLeftRightArrow")},{name:"OverBrace",latexTrigger:["\\overbrace"],parse:me("OverBrace")},{name:"OverLineSegment",latexTrigger:["\\overlinesegment"],parse:me("OverLineSegment")},{name:"OverGroup",latexTrigger:["\\overgroup"],parse:me("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(p(n,1)),i=co(p(n,2));if(i==null)return t;i.dict.mathStyle==="normal"?t=_(["{\\displaystyle",t,"}"]):i.dict.mathStyle==="compact"&&(t=_(["{\\textstyle",t,"}"]));let r=i.dict.size;return r!==null&&r>=1&&r<=10&&(t=_(["{",{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=_(["\\texttt{",t,"}"]):i.dict.fontFamily==="sans-serif"&&(t=_(["\\textsf{",t,"}"])),i.dict.fontWeight==="bold"&&(t=_(["\\textbf{",t,"}"])),i.dict.fontStyle==="italic"?t=_(["\\textit{",t,"}"]):i.dict.fontStyle==="normal"&&(t=_(["\\textup{",t,"}"])),i.dict.color&&(t=_(["\\textcolor{",i.dict.color,"}{",t,"}"])),i.dict.backgroundColor&&(t=_(["\\colorbox{",i.dict.backgroundColor,"}{",t,"}"])),i.dict.border===!0&&(t=_(["\\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(p(n,2)!==null)return e.serialize(p(n,1));let t=R(p(n,1));return t===null?"":{"-3":"\\!",6:"\\ ",3:"\\,",4:"\\:",5:"\\;",9:"\\enspace",18:"\\quad",36:"\\qquad"}[t]??""}}];var Ol=[{name:"Mu0",kind:"symbol",latexTrigger:"\\mu_0"},{name:"VacuumPermittivity",kind:"symbol",latexTrigger:"\\varepsilon_0"}];var Bl=[...yo,...vo,...No,...po,...Io,...rn,...Co,...Ro,...Do,...Lo,...Bo,...Vo,...Wo,...Ho,...Ol];var Vl="\\u{FE0F}",zl="\\u{20E3}",Jl="\\u{200D}",ql="\\p{RI}\\p{RI}",jl="(?:[\\u{E0020}-\\u{E007E}]+\\u{E007F})",Xo=`(?:\\p{EMod}|${Vl}${zl}?|${jl})`,Gl="(?:(?=\\P{XIDC})(?=[^\\x23\\x2a\\x30-\\x39])\\p{Emoji})",Qo=`(?:${Gl}${Xo}*|\\p{Emoji}${Xo}+|${ql})`,Ko=`(?:${Qo})(${Jl}${Qo})*`,fg=new RegExp(`(?:${Ko})+`,"u"),ea=new RegExp(`^(?:${Ko})+$`,"u");function ta(e){return e!==void 0&&"value"in e}function Qn(e){return e!==void 0&&"operator"in e}function Sn(e,n,t=!0){let i=!t||e.every(s=>s.isCanonical)?e:e.map(s=>s.canonical);if(n){let s=a=>k(a,"Nothing")||a.operator===n||a.operator==="Sequence";if(i.every(a=>!s(a)))return i;let o=[];for(let a of i)k(a,"Nothing")||(h(a)&&(a.operator===n||a.operator==="Sequence")?o.push(...Sn(a.ops,n,t)):o.push(a));return o}if(i.every(s=>!(k(s,"Nothing")||s.operator==="Sequence")))return i;let r=[];for(let s of i)k(s,"Nothing")||(h(s,"Sequence")?r.push(...Sn(s.ops,n,t)):r.push(s));return r}function Ot(e,n,t){if(n=Sn(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 He(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 Vi(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(He(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 ia(e){let n={},t=nc(e.engine),i=ec(e.engine);if(k(e)&&!n[e.symbol]&&!e.symbol.startsWith("_")){if(!t.includes(e.symbol)){let r=vt(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=vt(r,i);s&&(n[r]=s)}for(let s of e.ops)n={...n,...ia(s)}}return n}function ec(e){let n=[],t=e.context.lexicalScope;for(;t;){for(let i of t.bindings.keys()){let r=t.bindings.get(i);Qn(r)&&n.push(i)}t=t.parent}return n}function nc(e){let n=[],t=e.context.lexicalScope;for(;t;){for(let i of t.bindings.keys()){let r=t.bindings.get(i);ta(r)&&n.push(i)}t=t.parent}return n}function je(e){let n=ia(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:
|
|
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(He.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 Ys(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 Ei=class{typeResolver;constructor(n){this.typeResolver=n??{forward:()=>{},resolve:()=>{},get names(){return[]}}}buildType(n){return Ys(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 Hs(e,n){return new Ei(n).buildType(e)}function W(e,n){if(e!==void 0){if(Nt(e))return e;if(typeof e=="string")try{let i=new kt(e,{typeResolver:n}).parseType();return Hs(i,n)}catch(t){throw new Error(`Failed to parse type "${e}": ${t instanceof Error?t.message:String(t)}`)}}}var Ku={number:hn,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:He,unknown:[],nothing:[],never:[],error:[],value:yi,scalar:vt,collection:Et,indexed_collection:bi,list:[],set:[],tuple:[],record:[],dictionary:[],function:[],symbol:[],boolean:[],string:[],expression:xi};function Gn(e,n){return n==="any"||e==="never"?!0:e==="unknown"||n==="unknown"?!1:e===n?!0:Ku[n].includes(e)}function A(e,n){if(typeof e=="string"&&!He.includes(e)&&(e=W(e)),typeof n=="string"&&!He.includes(n)&&(n=W(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"?Gn(e,n):e.kind==="value"?typeof e.value=="boolean"?n==="boolean":typeof e.value=="number"?Number.isInteger(e.value)?Gn("integer",n):Gn("number",n):typeof e.value=="boolean"?Gn("boolean",n):typeof e.value=="string"?Gn("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"?Ws(e):n==="symbol"?vi(e):n==="expression"?el(e):n==="function"?no(e):n==="scalar"?Xs(e):n==="value"?eo(e):n==="indexed_collection"?Ks(e):n==="collection"?Qs(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"?vi(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:ge(...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 Ws(e){return typeof e=="string"?hn.includes(e):e.kind==="value"?typeof e.value=="number":e.kind==="numeric"}function Xs(e){return Ws(e)?!0:typeof e=="string"?vt.includes(e):e.kind==="value"?["string","boolean","number"].includes(typeof e.value):!1}function Qs(e){return Ks(e)?!0:typeof e=="string"?Et.includes(e):["collection","set","record","dictionary"].includes(e.kind)}function Ks(e){return typeof e=="string"?!1:["indexed_collection","list","tuple"].includes(e.kind)}function eo(e){return Xs(e)||Qs(e)}function no(e){return e==="function"||typeof e!="string"&&e.kind==="signature"}function el(e){return typeof e=="string"&&["expression","symbol","function"].includes(e)||eo(e)||no(e)||vi(e)?!0:typeof e=="string"?!1:e.kind==="expression"}function vi(e){return e==="symbol"?!0:typeof e=="string"?!1:e.kind==="symbol"?!0:e.kind==="expression"?e.operator==="Symbol":!1}function nl(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:to(e,n)}function tl(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:to(e,n)}function Ni(...e){return e.length===0?"nothing":e.length===1?e[0]:e.reduce((n,t)=>nl(n,t))}function ge(...e){return e.length===0?"nothing":e.length===1?e[0]:e.reduce((n,t)=>tl(n,t))}function to(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:X(e,n,"non_finite_number")?"non_finite_number":X(e,n,"finite_integer")?"finite_integer":X(e,n,"integer")?"integer":X(e,n,"finite_rational")?"finite_rational":X(e,n,"rational")?"rational":X(e,n,"finite_real")?"finite_real":X(e,n,"real")?"real":X(e,n,"imaginary")?"imaginary":X(e,n,"finite_complex")?"finite_complex":X(e,n,"complex")?"complex":X(e,n,"finite_number")?"finite_number":X(e,n,"number")?"number":X(e,n,"list")?"list":X(e,n,"record")?"record":X(e,n,"dictionary")?"dictionary":X(e,n,"set")?"set":X(e,n,"tuple")?"tuple":X(e,n,"indexed_collection")?"indexed_collection":X(e,n,"collection")?"collection":X(e,n,"scalar")?"scalar":X(e,n,"value")?"value":X(e,n,"function")?"function":X(e,n,"expression")?"expression":"any"}function X(e,n,t){return!!(A(e,t)&&A(n,t))}function Ti(e){if(e){if(e==="function")return"any";if(typeof e!="string"&&e.kind==="signature")return e.result}}function _e(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 ge(...e.elements.map(n=>n.type));if(e.kind==="dictionary")return W(`tuple<string, ${e.values}>`);if(e.kind==="record")return W(`tuple<string, ${z(ge(...Object.values(e.elements)))}>`)}}var pe=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(ge(...n.map(t=>t instanceof e?t.type:t)))}static narrow(...n){return new e(Ni(...n.map(t=>t instanceof e?t.type:t)))}constructor(n,t){typeof n=="string"?this.type=W(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 z(this.type)}toJSON(){return z(this.type)}[Symbol.toPrimitive](n){return n==="string"?this.toString():null}valueOf(){return z(this.type)}};function O(e){return e?._kind==="number"}function S(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 be(e){return e?._kind==="string"}function ye(e){return e?._kind==="symbol"?e.symbol:void 0}var Am=[0,-1,1,Math.PI,Math.E,-Math.PI,-Math.E,.5,-.5];function Be(e){if(!e)return;if(e.operator==="Function"&&e.isCanonical||S(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 Be(e.engine._fn("Block",s.ops,{canonical:!1}));return Be(h(e)?e.op1:void 0)}if(h(e,"Function"))return io(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 io(n,[t,...r])}function io(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=>S(r)?r:e.error("expected-a-symbol",r.toString()));t.isScoped;for(let r of i)S(r)&&!t.localScope.bindings.has(r.symbol)&&e.declare(r.symbol,{inferred:!0,type:"unknown"},t.localScope);return e._fn("Function",[t,...i])}function ro(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 so(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 oo(e,n){for(let[t,i]of n)e.bindings.set(t,i)}function ao(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=>S(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=ao(e,s,t);return o!==s&&(i=!0),o});if(i)return e._fn(n.operator,r)}return n}function rl(e){let n=e.engine;if(S(e)){let a=e.symbol;return u=>n.function(a,u).evaluate()}let t=Be(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(ne=>S(ne)?ne.symbol:"")]),w=s.slice(a.length).map((ne,Pe)=>{let Fe=`_${Pe+1}`,dt=0;for(;k.has(Fe);)Fe=`_${Pe+1}_${dt++}`;return k.add(Fe),n.symbol(Fe,{canonical:!1})}),R=Object.fromEntries(s.slice(a.length).map((ne,Pe)=>[S(ne)?ne.symbol:"",w[Pe]])),P=a.map(ne=>ne.evaluate()),Q={parent:o.localScope.parent??n.context.lexicalScope,bindings:new Map};for(let ne=0;ne<a.length;ne++){let Pe=s[ne],Fe=S(Pe)?Pe.symbol:"";Fe&&n.declare(Fe,{value:P[ne],inferred:!0},Q)}let Z=o.localScope,ke=Z.parent;Z.parent=Q;let Y=s.slice(0,a.length).map(ne=>S(ne)?ne.symbol:""),ue=so(Z,Y);n.pushScope(Q);let le;try{le=ro(n,o.ops)}finally{n.popScope(),Z.parent=ke,oo(Z,ue)}return n.function("Function",[le.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=>S(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=so(m,p);n.pushScope(c);let v;try{v=ro(n,o.ops),v=ao(n,v,c)}finally{n.popScope(),m.parent=d,oo(m,b)}return v.isValid?v:void 0}}function te(e){return rl(e)??(n=>e.engine.function("Apply",[e,...n]).evaluate())}function Ii(e){return(e.isFiniteCollection??!1)&&e.isIndexedCollection}function sl(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 ol(e,n){if(h(e)){for(let t=0;t!==e.nops;t+=1)if(n(e.ops[t]))return t+1}}function St(){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:sl,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:ol,eltsgn:e=>{},elttype:e=>!h(e)||e.nops===0?"unknown":e.nops===1?e.ops[0].type.type:ge(...e.ops.map(n=>n.type.type))}}var bn=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 ki(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 bn({value:r,cause:"timeout",message:`Timeout exceeded (${n}ms)`})}}function N(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 yn(e,n,t){return n.includes(e)&&(n=`{${n}}`),/^[0-9]$/.test(t)?`${n}${e}${t}`:`${n}${e}{${t}}`}var D=245,jn=260,Ve=270,ee=275,me=390,xe=600;var Un=700,Si=810;var sn=[{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 _i(e){return typeof e!="string"?!1:sn.some(n=>n.name===e)}function Mi(e){return typeof e!="string"?!1:["Less","LessEqual","Greater","GreaterEqual"].includes(e)}function wi(e){return typeof e!="string"?!1:["Equal","NotEqual"].includes(e)}var xn=["Error","'missing'"];function on(e){return!!(typeof e=="number"||En(e)||typeof e=="string"&&At(e))}function En(e){return e!==null&&typeof e=="object"&&"num"in e}function _t(e){return e!==null&&typeof e=="object"&&"sym"in e}function lo(e){return e!==null&&typeof e=="object"&&"str"in e}function co(e){return e!==null&&typeof e=="object"&&"dict"in e&&typeof e.dict=="object"&&!Array.isArray(e.dict)&&e.dict!==null}function vn(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):At(e)||Ri(e)?null:e}function $i(e){if(e==null||L(e)!==null)return null;let n=y(e);return n?[n,...T(e).map(t=>$i(t)).filter(t=>t!==null)]:e}function y(e){return Array.isArray(e)?e[0]:e==null?"":vn(e)?e.fn[0]:""}function T(e){return Array.isArray(e)?e.slice(1):e!==void 0&&vn(e)?e.fn.slice(1):[]}function f(e,n){return Array.isArray(e)?e[n]??null:e===null||!vn(e)?null:e.fn[n]??null}function G(e){return e==null?0:Array.isArray(e)?Math.max(0,e.length-1):vn(e)?Math.max(0,e.fn.length-1):0}function Ci(e){return e==null?null:y(e)==="Hold"?f(e,1):e}function _(e){return typeof e=="string"&&Ri(e)?e.length>=2&&e.at(0)==="`"&&e.at(-1)==="`"?e.slice(1,-1):e:e==null?null:_t(e)?e.sym:null}function uo(e){let n=y(e);if(n==="KeyValuePair"||n==="Tuple"||n==="Pair"){let[t,i]=T(e),r=L(t);return r?[r,i??"Nothing"]:null}return null}function fo(e){if(e===null)return null;if(co(e))return e;let n=uo(e);if(n)return{[n[0]]:n[1]};if(y(e)==="Dictionary"){let t={},i=T(e);for(let r=1;r<G(e);r++){let s=uo(i[r]);s&&(t[s[0]]=fl(s[1])??"Nothing")}return{dict:t}}return null}function Mt(e){return{dict:Object.fromEntries(Object.entries(e).map(([t,i])=>[t,Ai(i)??"Nothing"]))}}function cl(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"&&At(e)?cl(e):e!==void 0&&En(e)?C(e.num):null}function Nn(e){if(e==null)return null;if(_(e)==="Half")return[1,2];let n=y(e);if(!n)return null;let t=null,i=null;if(n==="Negate"){let r=Nn(T(e)[0]);if(r)return[-r[0],r[1]]}if(n==="Rational"||n==="Divide"){let[r,s]=T(e);t=C(r)??NaN,i=C(s)??NaN}if(n==="Power"){let[r,s]=T(e),o=C(s);o===1?(t=C(r),i=1):o===-1&&(t=1,i=C(r))}if(n==="Multiply"){let[r,s]=T(e);if(y(s)==="Power"){let[o,a]=T(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 wt(e,n){let t=null;if(Array.isArray(e)&&(t=e),vn(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 Tn(e,n,t){let i=y(n),r=y(t);return i===e&&r===e?[e,...T(n),...T(t)]:i===e?[e,...T(n),t]:r===e?[e,n,...T(t)]:[e,n,t]}function an(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:T(e)}function V(e){return e==null||e==="Nothing"?!0:y(e)==="Sequence"&&G(e)===0}function q(e){return V(e)?xn:e}function At(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 Ri(e){return/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)||e.length>=2&&e[0]==="`"&&e[e.length-1]==="`"}function Ai(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=>Ai(n)??"Nothing")];if(e===null)return null;if(typeof e=="object"){let n={};for(let t in e)n[t]=Ai(e[t])??"Nothing";return{dict:n}}return vn(e)||_t(e)||En(e)||lo(e)||co(e)?e:null}function fl(e){return e==null?null:lo(e)?e.str:En(e)?parseFloat(e.num):_t(e)?e.sym:typeof e=="string"||typeof e=="number"?e:Array.isArray(e)?{fn:e}:e}var mo=[{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,q(f(s,1))]:(e.index=r,["Equivalent",n,q(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:Zn("\\forall"),parse:We("ForAll")},{name:"Exists",kind:"prefix",latexTrigger:["\\exists"],precedence:200,serialize:Zn("\\exists"),parse:We("Exists")},{name:"ExistsUnique",kind:"prefix",latexTrigger:["\\exists","!"],precedence:200,serialize:Zn("\\exists!"),parse:We("ExistsUnique")},{name:"NotForAll",kind:"prefix",latexTrigger:["\\lnot","\\forall"],precedence:200,serialize:Zn("\\lnot\\forall"),parse:We("NotForAll")},{name:"NotExists",kind:"prefix",latexTrigger:["\\lnot","\\exists"],precedence:200,serialize:Zn("\\lnot\\exists"),parse:We("NotExists")},{name:"KroneckerDelta",kind:"prefix",latexTrigger:["\\delta","_"],precedence:200,serialize:(e,n)=>{let t=T(n);return t.length===0?"\\delta":t.every(i=>_(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=an(n);return t&&t.length<=2?["KroneckerDelta",...t]:y(n)==="InvisibleOperator"?["KroneckerDelta",...T(n)]:n!==null?["KroneckerDelta",n]:null}},{name:"Boole",kind:"matchfix",openTrigger:"[",closeTrigger:"]",parse:(e,n)=>{let t=y(n);return!t||!sn.some(i=>i.name===t)?null:["Boole",n]}},{kind:"matchfix",openTrigger:"\\llbracket",closeTrigger:"\\rrbracket",parse:(e,n)=>{let t=y(n);return!t||!sn.some(i=>i.name===t)?null:["Boole",n]}},{name:"Predicate",serialize:(e,n)=>{let t=T(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 Zn(e){return(n,t)=>{let i=T(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 po(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 We(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=>po(p,t)}:t;n.enterQuantifierScope();let c=n.parseExpression(l);return n.exitQuantifierScope(),[e,s,q(c)]}n.enterQuantifierScope();let u=n.parseEnclosure();if(n.exitQuantifierScope(),u)return[e,s,q(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=>po(c,t)}:t;n.enterQuantifierScope();let l=n.parseExpression(u);return n.exitQuantifierScope(),[e,a,q(l)]}if(n.match("(")){n.enterQuantifierScope();let u=n.parseExpression(t);return n.exitQuantifierScope(),n.match(")")?[e,a,q(u)]:null}return null}}function Di(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 we(e=""){return(n,t)=>{if(!t)return"";let i=T(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(),N(r)}}var xo=[{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:Ve,parse:(e,n,t)=>{let i=[];if(y(n)==="Delimiter"&&(n=f(n,1)??"Nothing"),y(n)==="Sequence")for(let s of T(n)){if(!_(s))return null;i.push(_(s))}else{if(!_(n))return null;i=[_(n)]}let r=e.parseExpression({minPrec:Ve})??"Nothing";return y(r)==="Delimiter"&&(r=f(r,1)??"Nothing"),y(r)==="Sequence"&&(r=["Block",...T(r)]),["Function",r,...i]},serialize:(e,n)=>{let t=T(n);return t.length<1?"()\\mapsto()":t.length===1?N(["()","\\mapsto",e.serialize(f(n,1))]):t.length===2?N([e.serialize(f(n,2)),"\\mapsto",e.serialize(f(n,1))]):N([e.wrapString(T(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=T(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=T(n).slice(1);return e.serialize(o)}if(G(n)===2)return N([e.wrap(t,20),"\\lhd",e.wrap(r,20)]);let s=e.options.applyFunctionStyle(n,e.level);return N(["\\operatorname{apply}",e.wrapString(e.serialize(i)+", "+e.serialize(["List",...T(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=T(n).slice(1);if(y(t)==="Function"){let r=T(t).slice(1),s=f(t,1);if(y(s)==="Block"&&G(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=Ci(f(n,1));if(y(f(n,2))==="Function"){let i=f(n,2),r=Ci(f(i,1)),s=T(i).slice(1);return N([e.serialize(t),e.wrapString(s.map(o=>e.serialize(o)).join(", "),e.options.applyFunctionStyle(n,e.level)),"\\coloneq",e.serialize(r)])}return N([e.serialize(t),"\\coloneq",e.serialize(f(n,2))])},parse:$t},{latexTrigger:"\\coloneqq",kind:"infix",associativity:"right",precedence:jn,parse:$t},{latexTrigger:"\\colonequals",kind:"infix",associativity:"right",precedence:jn,parse:$t},{latexTrigger:[":","="],kind:"infix",associativity:"right",precedence:jn,parse:$t},{name:"Colon",latexTrigger:":",kind:"infix",associativity:"right",precedence:250,serialize:(e,n)=>N([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:we(" ")},{name:"InvisibleOperator",serialize:we("")},{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??="(,)",G(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?we(a)(e,s):e.serialize(i):"";return e.wrapString(l,t,o+u)}},{name:"Tuple",serialize:(e,n)=>N(["(",we(",")(e,n),")"])},{name:"Pair",serialize:(e,n)=>N(["(",we(",")(e,n),")"])},{name:"Triple",serialize:(e,n)=>N(["(",we(",")(e,n),")"])},{name:"Single",serialize:(e,n)=>N(["(",we(",")(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=ml(e,n)||"\\blacksquare",r=y(t)==="ErrorCode"?L(f(t,1)):L(t);return r==="incompatible-type"?_(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{${ho(L(f(n,1)))}}`},{name:"Latex",serialize:(e,n)=>n===null?"":N(wt(n,t=>L(t)??e.serialize(t)))},{name:"LatexString",serialize:(e,n)=>n===null?"":N(wt(n,t=>e.serialize(t)))},{name:"LatexTokens",serialize:pl},{name:"At",kind:"postfix",precedence:810,latexTrigger:["["],parse:Fi("]"),serialize:(e,n)=>N(["\\lbrack",we(", ")(e,n),"\\rbrack"])},{kind:"postfix",precedence:810,latexTrigger:["\\lbrack"],parse:Fi("\\rbrack")},{kind:"postfix",precedence:810,latexTrigger:["\\left","\\lbrack"],parse:Fi("\\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=_(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,...T(i)]:["At",n,i]):["Subscript",n,i]}},{name:"List",kind:"matchfix",openTrigger:"[",closeTrigger:"]",parse:Eo,serialize:hl},{kind:"matchfix",openTrigger:"(",closeTrigger:")",parse:dl},{latexTrigger:[","],kind:"infix",precedence:20,parse:(e,n,t)=>{let i=Di(e,t,n,20,",");return i===null?null:["Delimiter",["Sequence",...i],{str:","}]}},{latexTrigger:[","],kind:"prefix",precedence:20,parse:(e,n)=>{let t=Di(e,n,null,20,",");return t===null?null:["Delimiter",["Sequence",...t],{str:","}]}},{name:"Range",latexTrigger:[".","."],kind:"infix",precedence:800,parse:gl,serialize:(e,n)=>{let t=T(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),ee)+"+"+e.wrap(f(n,3),ee))+").."+e.wrap(f(n,2),10)}return""}},{latexTrigger:[";"],kind:"infix",precedence:19,parse:(e,n,t)=>{let i=Di(e,t,n,19,";");return i===null?null:i.some(r=>y(r)==="Assign")?bl(i):["Delimiter",["Sequence",...i],"';'"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"none",precedence:21,parse:(e,n,t)=>{let i=e.index;return de(e,"where")?yo(e,n,t):(e.index=i,null)}},{symbolTrigger:"where",kind:"infix",associativity:"none",precedence:21,parse:(e,n,t)=>yo(e,n,t)},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:235,parse:(e,n,t)=>{let i=e.index;if(!de(e,"and"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:235});return["And",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:230,parse:(e,n,t)=>{let i=e.index;if(!de(e,"or"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:230});return["Or",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:219,parse:(e,n,t)=>{let i=e.index;if(!de(e,"iff"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:219});return["Equivalent",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:219,parse:(e,n,t)=>{let i=e.index;if(!de(e,"if and only if"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:219});return["Equivalent",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:21,parse:(e,n,t)=>{let i=e.index;if(!de(e,"such that"))return e.index=i,null;let r=e.parseExpression({...t,minPrec:21});return["Colon",n,r??"Nothing"]}},{latexTrigger:["\\text"],kind:"prefix",precedence:200,parse:(e,n)=>{let t=e.index;return de(e,"for all")?We("ForAll")(e,n):(e.index=t,null)}},{latexTrigger:["\\text"],kind:"prefix",precedence:200,parse:(e,n)=>{let t=e.index;return de(e,"there exists")?We("Exists")(e,n):(e.index=t,null)}},{name:"Block",serialize:(e,n)=>{let t=T(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=T(n);return!t||t.length<3?"":N(["\\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=T(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 N(["\\text{for }",e.serialize(s),"\\text{ from }",e.serialize(a),"\\text{ to }",e.serialize(u),"\\text{ do }",e.serialize(i)])}}return N(["\\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||_(t)==="Nothing"?"\\text{return}":N(["\\text{return }",e.serialize(t)])}},{symbolTrigger:"if",kind:"prefix",precedence:245,parse:(e,n)=>go(e,n)},{symbolTrigger:"for",kind:"prefix",precedence:245,parse:(e,n)=>bo(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:"Text",serialize:(e,n)=>{let t=T(n);if(t.length===0)return"";let i=-1,r=-1;for(let a=0;a<t.length;a++)L(t[a])!==null&&(i<0&&(i=a),r=a);if(i<0)return N(t.map(a=>e.serialize(a)));let s=[];for(let a=0;a<i;a++)s.push(e.serialize(t[a]));let o="";for(let a=i;a<=r;a++){let u=L(t[a]);u!==null?o+=ho(u):y(t[a])==="Annotated"||y(t[a])==="Text"?o+=e.serialize(t[a]):o+="$"+e.serialize(t[a])+"$"}s.push("\\text{"+o+"}");for(let a=r+1;a<t.length;a++)s.push(e.serialize(t[a]));return N(s)}},{name:"String",latexTrigger:["\\text"],parse:(e,n)=>{let t=e.index;return de(e,"if")?go(e,n):(e.index=t,de(e,"for")?bo(e,n):(e.index=t,de(e,"break")?["Break"]:(e.index=t,de(e,"continue")?["Continue"]:(e.index=t,de(e,"return")?["Return",e.parseExpression(n)??"Nothing"]:(e.index=t,Me(e))))))},serialize:(e,n)=>{let t=T(n);return t.length===0?"\\text{}":N(["\\text{",t.map(i=>e.serialize(i)).join(""),"}"])}},{name:"Subscript",latexTrigger:["_"],kind:"infix",serialize:(e,n)=>G(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)=>Je(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)=>Je(e,n,2)},{latexTrigger:"^{\\prime\\prime\\prime}",kind:"postfix",parse:(e,n)=>Je(e,n,3)},{latexTrigger:["^","\\doubleprime"],kind:"postfix",parse:(e,n)=>Je(e,n,2)},{latexTrigger:["^","\\tripleprime"],kind:"postfix",parse:(e,n)=>Je(e,n,3)},{latexTrigger:"'",kind:"postfix",precedence:810,parse:(e,n)=>Je(e,n,1)},{latexTrigger:"\\prime",kind:"postfix",precedence:810,parse:(e,n)=>Je(e,n,1)},{latexTrigger:"\\doubleprime",kind:"postfix",precedence:810,parse:(e,n)=>Je(e,n,2)},{latexTrigger:"\\tripleprime",kind:"postfix",precedence:810,parse:(e,n)=>Je(e,n,3)},{latexTrigger:["^","<{>","("],kind:"postfix",parse:(e,n,t)=>{let i=_(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=_(n);if(!t)return null;let i=e.getSymbolType(t);if(i.matches(new pe("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(_(l)===_(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:Pi,serialize:(e,n)=>{let t=[],i=T(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 N(["\\begin{cases}",t.join("\\\\"),"\\end{cases}"])}},{kind:"environment",symbolTrigger:"dcases",parse:Pi},{kind:"environment",symbolTrigger:"rcases",parse:Pi}];function Me(e,n){if(!e.match("<{>"))return"''";let t=[],i="",r=null,s=()=>{r!==null&&i?t.push(["Annotated",`'${i}'`,Mt(r)]):i&&t.push(`'${i}'`),i="",r=null};for(;!e.atEnd&&!e.match("<}>");)if(e.peek==="<{>")s(),t.push(Me(e));else if(e.match("\\textbf"))s(),t.push(Me(e,{fontWeight:"bold"}));else if(e.match("\\textmd"))s(),t.push(Me(e,{fontStyle:"normal"}));else if(e.match("\\textup"))s(),t.push(Me(e,{fontStyle:"normal"}));else if(e.match("\\textsl"))s(),t.push(Me(e,{fontStyle:"italic"}));else if(e.match("\\textit"))s(),t.push(Me(e,{fontStyle:"italic"}));else if(e.match("\\texttt"))s(),t.push(Me(e,{fontFamily:"monospace"}));else if(e.match("\\textsf"))s(),t.push(Me(e,{fontFamily:"sans-serif"}));else if(e.match("\\textcolor")){let a=e.index,u=e.parseStringGroup();if(u!==null){s();let l=Me(e);t.push(["Annotated",l,Mt({color:u})])}else 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("<$>")?(s(),t.push(u)):(i+="$",e.index=a)}else if(e.match("<$$>")){let a=e.index,u=e.parseExpression()??"Nothing";e.skipSpace(),e.match("<$$>")?(s(),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,Mt(n)]:o}function pl(e,n){return n===null?"":N(wt(n,t=>{let i=L(t);return i===null?e.serialize(t):i==="<{>"?"{":i==="<}>"?"}":i==="<$>"?"$":i==="<$$>"?"$$":i==="<space>"?" ":i}))}function ho(e){return e===null?"":e.replace(/[{}\[\]\\:\-\$%]/g,n=>({"{":"\\lbrace ","}":"\\rbrace ","[":"\\lbrack ","]":"\\rbrack ",":":"\\colon ","\\":"\\backslash "})[n]??"\\"+n)}function ml(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 Je(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,q(f(n,1)),a+t]}let r=_(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=_(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",q(n)]:["Prime",q(n),t]}function dl(e,n){if(V(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 Eo(e,n){if(V(n))return["List"];let t=y(n);if(t==="Range"||t==="Linspace")return n;if(t==="Sequence")return["List",...T(n)];if(t==="Delimiter"){let i=L(f(n,2))??"...";if(i===";"||i===".;.")return["List",...(T(f(n,1))??[]).map(r=>Eo(e,r))];if(i===","||i===".,.")return n=f(n,1),y(n)==="Sequence"?["List",...T(n)]:["List",n??"Nothing"]}return["List",n]}function hl(e,n){return G(n)>1&&T(n).every(t=>{let i=y(t);return wi(i)||Mi(i)})?N(["\\begin{cases}",we("\\\\")(e,n),"\\end{cases}"]):N(["\\bigl\\lbrack",we(", ")(e,n),"\\bigr\\rbrack"])}function gl(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 Ct={"(":"(",")":")","[":"\\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 $t(e,n,t){let i=(t?.minPrec??0)>=19,r=_(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"&&G(n)===2&&y(f(n,2))==="Delimiter"){let a=_(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=[...T(l)]:l&&(c=[l]),["Assign",a,["Function",u,...c??[]]]}if(y(n)==="Subscript"&&_(f(n,1))){let a=_(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]:_(l)?["Assign",n,u]:["Assign",n,u]}let s=y(n);if(s){let a=T(n),u=e.parseExpression({...t??{},minPrec:20});return u===null?null:["Assign",s,["Function",u,...a]]}if(!_(n))return null;let o=e.parseExpression({...t??{},minPrec:20});return o===null?null:["Assign",n,o]}function Pi(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 Mi(r)||wi(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":$i(i[1])??"True"),t.push(i[0])}return["Which",...t]}function de(e,n){let t=e.index;if(!e.match("<{>"))return e.index=t,!1;for(;e.match("<space>"););for(let i=0;i<n.length;i++)if(n[i]===" "){if(!e.match("<space>"))return e.index=t,!1;for(;e.match("<space>"););}else{if(e.peek!==n[i])return e.index=t,!1;e.nextToken()}for(;e.match("<space>"););return e.match("<}>")?!0:(e.index=t,!1)}function In(e,n){let t=e.index;if(e.skipVisualSpace(),e.match("\\text")){if(de(e,n))return!0;e.index=t}let i=e.index,r=e.parseSymbol();return r!==null&&_(r)===n?!0:(e.index=i,!1)}function Yn(e,n){let t=e.index,i=In(e,n);return e.index=t,i}function go(e,n){e.skipVisualSpace();let t=e.parseExpression({minPrec:0,condition:s=>Yn(s,"then")});if(t===null||!In(e,"then"))return null;e.skipVisualSpace();let i=e.parseExpression({minPrec:0,condition:s=>Yn(s,"else")});if(i===null||!In(e,"else"))return null;e.skipVisualSpace();let r=e.parseExpression(n)??"Nothing";return["If",t,i,r]}function bo(e,n){let t=e.parseExpression({minPrec:0,condition:a=>Yn(a,"from")}),i=t?_(t):null;if(!i||!In(e,"from"))return null;let r=e.parseExpression({minPrec:0,condition:a=>Yn(a,"to")});if(r===null||!In(e,"to"))return null;let s=e.parseExpression({minPrec:0,condition:a=>Yn(a,"do")});return s===null||!In(e,"do")?null:["Loop",e.parseExpression(n)??"Nothing",["Element",i,["Range",r,s]]]}function yo(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=vo(o);y(a)==="Assign"&&s.push(["Declare",f(a,1)]),s.push(a)}return s.push(n),["Block",...s]}function bl(e){let n=[];for(let t of e){let i=vo(t);y(i)==="Assign"&&n.push(["Declare",f(i,1)]),n.push(i)}return["Block",...n]}function vo(e){if(y(e)!=="Assign")return e;let n=f(e,1);if(y(n)!=="Subscript")return e;let t=_(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 Fi(...e){return(n,t)=>{if(!_(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,...T(i)]:["At",t,i])}}var Hn=[["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]],No=[...Hn.map(([e,n,t])=>({kind:"symbol",name:e,latexTrigger:[n],parse:e})),...Hn.map(([e,n,t])=>({kind:"symbol",latexTrigger:[String.fromCodePoint(t)],parse:e}))];var To=[{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]}}];function Ae(e,n,t){if(V(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=[...T(c)]:i=c?[c]:[]}else if(r==="Sequence")i=[...T(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 ko=[{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",serialize:(e,n)=>N([e.serialize(f(n,1)),"^\\complement"])},{name:"Intersection",latexTrigger:["\\cap"],kind:"infix",precedence:350},{name:"Interval",serialize:Io},{kind:"matchfix",openTrigger:["["],closeTrigger:[")"],parse:(e,n)=>Ae(n,!1,!0)},{kind:"matchfix",openTrigger:["\\lbrack"],closeTrigger:["\\rparen"],parse:(e,n)=>Ae(n,!1,!0)},{kind:"matchfix",openTrigger:["\\lbrack"],closeTrigger:[")"],parse:(e,n)=>Ae(n,!1,!0)},{kind:"matchfix",openTrigger:["["],closeTrigger:["\\rparen"],parse:(e,n)=>Ae(n,!1,!0)},{kind:"matchfix",openTrigger:["("],closeTrigger:["]"],parse:(e,n)=>Ae(n,!0,!1)},{kind:"matchfix",openTrigger:["\\lparen"],closeTrigger:["\\rbrack"],parse:(e,n)=>Ae(n,!0,!1)},{kind:"matchfix",openTrigger:["\\lparen"],closeTrigger:["]"],parse:(e,n)=>Ae(n,!0,!1)},{kind:"matchfix",openTrigger:["("],closeTrigger:["\\rbrack"],parse:(e,n)=>Ae(n,!0,!1)},{kind:"matchfix",openTrigger:["]"],closeTrigger:["["],parse:(e,n)=>Ae(n,!0,!0)},{kind:"matchfix",openTrigger:["\\rbrack"],closeTrigger:["\\lbrack"],parse:(e,n)=>Ae(n,!0,!0)},{name:"Multiple",serialize:Io},{name:"Union",latexTrigger:["\\cup"],kind:"infix",precedence:350},{name:"Divides",latexTrigger:["\\mid"],kind:"infix",precedence:160},{name:"Set",kind:"matchfix",openTrigger:"{",closeTrigger:"}",parse:(e,n)=>{if(V(n))return"EmptySet";let t=y(n);if(t==="Divides"||t==="Colon"){let i=f(n,1),r=f(n,2);if(i!==null&&r!==null)return["Set",i,["Condition",r]]}return y(n)=="Delimiter"&&L(f(n,2))===","&&(n=f(n,1)),y(n)!=="Sequence"?["Set",n]:["Set",...T(n)]},serialize:(e,n)=>{if(G(n)===2&&y(f(n,2))==="Condition"){let t=f(n,2);return N(["\\lbrace",e.serialize(f(n,1)),"\\mid",e.serialize(f(t,1)),"\\rbrace"])}return N(["\\lbrace",T(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 Io(e,n){if(n===null)return"";let t=y(n);if(!t)return"";if(t==="Range")return N(["\\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),N([o?"\\lparen":"\\lbrack",e.serialize(r),", ",e.serialize(s),a?"\\rparen":"\\rbrack"])}let i=e.numericSetStyle(n,e.level);return""}function kn(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 N(i.map(r=>{switch(r){case"#1":return n;case"#2":return t;default:return r}}))}function Rt(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 yl(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 Dt(e){let{deg:n,min:t,sec:i}=yl(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 xl(e){if(y(e)!=="Multiply")return[[],[]];let n=[],t=[];for(let i of T(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"&&G(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=Nn(i);r!==null?(r[0]!==1&&n.push(r[0]),t.push(r[1])):n.push(i)}return[n,t]}function El(e){let n=e.parseOptionalGroup(),t=e.parseGroup()??e.parseToken();return V(t)?n!==null?["Root",xn,q(n)]:["Sqrt",xn]:n!==null?["Root",t,n]:["Sqrt",t]}function vl(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 Xn(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 Nl(e,n){e.level-=1;let t=y(n),i="",r=f(n,1);if(t==="Negate")i="-"+e.wrap(r,ee+1);else if(t==="Subtract"){i=e.wrap(r,ee);let s=f(n,2);if(s!==null){let o=e.wrap(s,ee);o[0]==="-"?i+="+"+o.slice(1):o[0]==="+"?i+="-"+o.slice(1):i=i+"-"+o}}else if(t==="Add"){if(e.options.prettify&&G(n)===2&&e.options.invisiblePlus!=="+"){let[a,u]=[f(n,1),f(n,2)],[l,c]=[a,u],p=C(l),m=Nn(c);if((p===null||m===null)&&([l,c]=[u,a],p=C(l),m=Nn(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=kn(e.options.invisiblePlus,e.serialize(l),e.serialize(c)),e.level+=1,i}if(e.options.prettify&&G(n)===2){let[a,u]=Qn(r),[l,c]=Qn(f(n,2));if(u<0&&c>0)return i=e.wrap(l,ee)+"-"+e.wrap(a,ee),e.level+=1,i}i=e.serialize(r);let s=G(n)+1,o=T(n);for(let a=2;a<s;a++)if(r=o[a-1],e.options.prettify){let[u,l]=Qn(r),c=e.wrap(u,ee);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,ee);u[0]==="-"||u[0]==="+"?i+=u:i+="+"+u}}return e.level+=1,i}function Co(e,n){if(n===null)return"";e.level-=1;let t="";if(e.options.prettify===!0){let[u,l]=xl(n);l.length>0&&(l.length===1&&l[0]===1?u.length===0?t="1":u.length===1?t=e.serialize(u[0]):t=Co(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=G(n)+1,o=T(n);e.options.prettify===!0&&o.length===2&&on(o[1])&&!on(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(on(r)){l=e.serialize(r),l==="-1"&&!t?(t="",i=!i):(l[0]==="-"&&(l=l.slice(1),i=!i),t?t=kn(e.options.multiply,t,l):t=l),a=!0;continue}if(y(r)==="Power"){let c=Nn(f(r,2));if(c!=null){let[p,m]=c;if(p===1&&m!==null){t+=Xn(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=kn(e.options.multiply,t,l):t=l,a=!0;continue}if(y(r)==="Negate"&&(r=f(r,1),i=!i),l=e.wrap(r,me),!t)t=l;else{let c=y(r);a&&(c==="Divide"||c==="Rational")?t=kn(e.options.multiply,t,l):e.options.invisibleMultiply?t=kn(e.options.invisibleMultiply,t,l):t=N([t,l])}a=!1}return e.level+=1,i?"-"+t:t}function Pt(e){let n=e.parseGroup(),t=null;if(n===null?(n=e.parseToken(),t=e.parseToken()):t=e.parseGroup(),n=q(n),t=q(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=q(e.parseExpression()));let a=[];if(y(t)==="Multiply"){for(let u of T(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=_(n);if(i==="d"||i==="d_upright"||i==="differentialD"){let s=[],o=a=>{if(!a)return;let u=_(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 T(a))o(c)};if(o(t),s.length===0){let a=_(t);a&&a.length>1&&a[0]==="d"&&s.push(a.slice(1))}if(s.length>0)return["D",q(e.parseExpression()),...s]}return["Divide",n,t]}function So(e,n){if(n===null)return"";let t=q(f(n,1)),i=q(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 Oi(e,n){if(!n)return"";let t=y(n),i=q(f(n,1));if(t==="Sqrt")return Xn(e,e.rootStyle(n,e.level-1),i,2);let r=q(f(n,2));if(t==="Root")return Xn(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 Xn(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)??xn]]);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 Xn(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}^{${yn("^",l,e.serialize(r))}}`}return yn("^",s(e.wrapShort(i)),e.serialize(r))}function Wn(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 Ro=[{name:"CatalanConstant",symbolTrigger:"G"},{name:"GoldenRatio",latexTrigger:"\\varphi"},{name:"EulerGamma",latexTrigger:"\\gamma"},{name:"Degrees",latexTrigger:["\\degree"],kind:"postfix",precedence:880,parse:(e,n)=>Wn(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=Rt(s,t.angleNormalization)),t.dmsFormat?Dt(s):`${s}\xB0`}}return N([e.serialize(i),"\\degree"])}},{latexTrigger:["\\degree"],kind:"postfix",precedence:880,parse:(e,n)=>Wn(e,n)},{latexTrigger:["^","<{>","\\circ","<}>"],kind:"postfix",parse:(e,n)=>Wn(e,n)},{latexTrigger:["^","\\circ"],kind:"postfix",parse:(e,n)=>Wn(e,n)},{latexTrigger:["\xB0"],kind:"postfix",precedence:880,parse:(e,n)=>Wn(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)=>V(n)?null:["Abs",n]},{kind:"matchfix",openTrigger:["\\vert"],closeTrigger:["\\vert"],parse:(e,n)=>V(n)?null:["Abs",n]},{symbolTrigger:"abs",kind:"function",parse:"Abs"},{name:"Add",latexTrigger:["+"],kind:"infix",associativity:"any",precedence:ee,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:ee});if(i===null)return null;if(y(i)==="Negate"){let r=f(i,1);if(on(r))return Tn("Add",n,vl(r))}return Tn("Add",n,i)},serialize:Nl},{kind:"prefix",latexTrigger:["+"],precedence:ee,parse:(e,n)=>e.parseExpression({...n,minPrec:400})},{name:"Ceil",kind:"matchfix",openTrigger:"\\lceil",closeTrigger:"\\rceil",parse:(e,n)=>V(n)?null:["Ceil",n]},{kind:"matchfix",openTrigger:["\u2308"],closeTrigger:["\u2309"],parse:(e,n)=>V(n)?null:["Ceil",n]},{symbolTrigger:"ceil",kind:"function",parse:"Ceil"},{name:"Chop",symbolTrigger:"chop",kind:"function",parse:"Chop"},{name:"Complex",precedence:ee-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":N([e.serialize(f(n,2)),"\\imaginaryI"]);return C(f(n,1))===0?r:i!==null&&i<0?N([t,r]):N([t,"+",r])}},{name:"Divide",latexTrigger:"\\frac",precedence:xe,parse:Pt,serialize:So},{latexTrigger:"\\dfrac",precedence:xe,parse:Pt},{latexTrigger:"\\tfrac",precedence:xe,parse:Pt},{latexTrigger:"\\cfrac",precedence:xe,parse:Pt},{kind:"infix",latexTrigger:"\\over",associativity:"none",precedence:xe,parse:"Divide"},{latexTrigger:["\\/"],kind:"infix",associativity:"left",precedence:xe,parse:"Divide"},{latexTrigger:["/"],kind:"infix",associativity:"left",precedence:xe,parse:"Divide"},{latexTrigger:["\\div"],kind:"infix",associativity:"left",precedence:xe,parse:"Divide"},{name:"Exp",serialize:(e,n)=>{let t=f(n,1);return _(t)||C(t)!==null?N(["\\exponentialE^{",e.serialize(t),"}"]):N(["\\exp",e.wrap(q(t))])}},{name:"Factorial",latexTrigger:["!"],kind:"postfix",precedence:Si},{name:"Factorial2",latexTrigger:["!","!"],kind:"postfix",precedence:Si},{name:"Floor",kind:"matchfix",openTrigger:"\\lfloor",closeTrigger:"\\rfloor",parse:(e,n)=>V(n)?null:["Floor",n]},{kind:"matchfix",openTrigger:["\u230A"],closeTrigger:["\u230B"],parse:(e,n)=>V(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]=T(n);return i?N(["\\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.parseExpression({minPrec:me});return t?["Limit",["Function",t,f(n,1)],f(n,2)]:null},serialize:(e,n)=>{let t=f(n,1),i=f(t,2),r=f(n,2);return N(["\\lim_{",e.serialize(i),"\\to",e.serialize(r),"}",e.serialize(f(t,1))])}},{name:"MinusPlus",latexTrigger:["\\mp"],kind:"infix",associativity:"any",precedence:Ve},{name:"Multiply",latexTrigger:["\\times"],kind:"infix",associativity:"any",precedence:me,serialize:Co},{latexTrigger:["\\cdot"],kind:"infix",associativity:"any",precedence:me,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:me+2});return i===null?null:Tn("Multiply",n,i)}},{latexTrigger:["*"],kind:"infix",associativity:"any",precedence:me,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:me+2});return i===null?["Multiply",n,xn]:Tn("Multiply",n,i)}},{name:"Mod",latexTrigger:"\\bmod",kind:"infix",precedence:xe,serialize:(e,n)=>{if(G(n)!==2)return"";let t=e.serialize(f(n,1)),i=e.serialize(f(n,2));return N([t,"\\bmod",i])}},{latexTrigger:"\\mod",kind:"infix",precedence:xe,parse:"Mod"},{latexTrigger:"\\pmod",kind:"prefix",precedence:D,parse:e=>{let n=e.parseGroup()??e.parseToken();return["Mod",q(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 N([t,"\\equiv",i]);let r=e.serialize(f(n,3));return N([t,"\\equiv",i,"\\pmod{",r,"}"])}},{name:"Negate",latexTrigger:["-"],kind:"prefix",precedence:Un+1,parse:(e,n)=>{e.skipSpace();let t=e.parseExpression({...n,minPrec:Un+3});return t===null?null:["Negate",t]}},{kind:"matchfix",openTrigger:"||",closeTrigger:"||",parse:(e,n)=>V(n)?null:["Norm",n]},{name:"Norm",kind:"matchfix",openTrigger:["\\left","\\Vert"],closeTrigger:["\\right","\\Vert"],parse:(e,n)=>V(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:Ve,serialize:(e,n)=>{let t=f(n,1);if(t===null)return"\\pm";if(G(n)===1)return N(["\\pm",e.serialize(t)]);let i=f(n,2);return N([e.serialize(t),"\\pm",e.serialize(i)])}},{latexTrigger:["\\pm"],kind:"prefix",precedence:Ve,parse:(e,n)=>{let t=e.parseExpression({...n,minPrec:400});return["PlusMinus",0,q(t)]}},{latexTrigger:["\\plusmn"],kind:"infix",associativity:"any",precedence:Ve,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:400});return["PlusMinus",n,q(i)]}},{latexTrigger:["\\plusmn"],kind:"prefix",precedence:Ve,parse:(e,n)=>{let t=e.parseExpression({...n,minPrec:400});return["PlusMinus",q(t)]}},{name:"Power",latexTrigger:["^"],kind:"infix",serialize:Oi},{latexTrigger:"\\prod",precedence:me,name:"Product",parse:Mo("Product","Multiply",me),serialize:Ao("\\prod")},{latexTrigger:["*","*"],kind:"infix",associativity:"right",precedence:Un,parse:(e,n,t)=>{if(e.options.strict!==!1)return null;let i=e.parseExpression({...t,minPrec:Un});return i===null?null:["Power",n,i]}},{name:"Rational",precedence:xe,serialize:(e,n)=>n&&G(n)===1?"\\operatorname{Rational}"+e.wrapArguments(n):So(e,n)},{name:"Reduce",serialize:(e,n)=>{let t=f(n,1);if(!t)return"";let i=f(n,2);return _(i)==="Add"?`\\sum ${e.serialize(t)}`:_(i)==="Multiply"?`\\prod ${e.serialize(t)}`:`\\operatorname{Reduce}\\left(${e.serialize(t)}, ${e.serialize(f(n,2))}\\right)`}},{name:"Root",serialize:Oi},{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:ee,name:"Sum",parse:Mo("Sum","Add",me),serialize:Ao("\\sum")},{name:"Heaviside",symbolTrigger:"Heaviside",kind:"function"},{name:"Sign",symbolTrigger:"sgn",kind:"function"},{name:"Sqrt",latexTrigger:["\\sqrt"],parse:El,serialize:Oi},{name:"Subtract",latexTrigger:["-"],kind:"infix",associativity:"left",precedence:ee+2,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:ee+3});return i===null?null:["Subtract",n,i]},serialize:(e,n)=>{let t=e.wrap(f(n,1),ee+2),i=e.wrap(f(n,2),ee+3);return N([t,"-",i])}}];function Tl(e,n){if(e!==null){if(_(e))return{index:_(e)??"Nothing",upper:n};if(y(e)==="GreaterEqual"){let t=_(f(e,1))??"Nothing",i=f(e,2)??1;return{index:t,lower:i,upper:n}}if(y(e)==="Equal"){let t=_(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:_(f(e,1))??"Nothing",element:e}}}function Il(e){let n=y(e);return n?new Set(["Less","LessEqual","Greater","GreaterEqual","NotEqual","And","Or","Not"]).has(n):!1}function _o(e){if(e===null)return[];let n=an(e);if(n)return[...n];if(y(e)==="Tuple"){let t=T(e);return t?[...t]:[e]}return[e]}function kl(e,n){V(e)&&(e=null),V(n)&&(n=null);let t=_o(e),i=_o(n),r=[],s=0;for(;s<t.length;){let o=t[s],a=Tl(o,i[s]);if(a){if(a.element&&s+1<t.length){let u=t[s+1];if(Il(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 Mo(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=kl(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 Sl=new Set(["Tuple","Triple","Pair","Single","Limits","Element"]);function wo(e){return e==null||_(e)==="Nothing"?null:e}function _l(e){let n=[],t=T(e);if(t.length<=1)return n;for(let i of t.slice(1)){let r=y(i);if(r&&Sl.has(r)){n.push(i);continue}break}return n}function Ml(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=wo(f(n,2)),r=wo(f(n,3)),s={},o=t?_(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 Ao(e){return(n,t)=>{let i=f(t,1);if(!i)return e;let r=_l(t),s=e;if(r.length>0){let o=[],a=[];for(let u of r){let l=Ml(n,u);l.sub&&o.push(l.sub),l.sup&&a.push(l.sup)}o.length>0&&(s=yn("_",s,o.join(", "))),a.length>0&&(s=yn("^",s,a.join(", ")))}return N([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 Qn(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]=Qn(f(e,1));s<0&&(n*=-1,r===1?t=["Multiply",...T(e).slice(1)]:t=["Multiply",r,...T(e).slice(1)])}else if(i==="Divide"||i==="Rational"){let[r,s]=Qn(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 Do=[{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:me,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 Po=[{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 Sn(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();V(u)&&(u=null),V(a)&&(a=null),i.push(u??"Nothing"),r.push(a??"Nothing"),n.skipVisualSpace(),t=!n.match(e)}let[s,o]=wl(n);if(s&&o.length===0){if(y(s)==="Add"||y(s)==="Subtract"){let a=[],u=[];for(let l of T(s))if(o)u.push(l);else{let c;[c,o]=qe(l),a.push(c??l)}if(o!==null&&u.length>0)return["Add",Fo(e,["Add",...a],{indexes:o,subs:i,sups:r})??"Nothing",...u]}else if(y(s)==="Divide"){let a;[a,o]=qe(f(s,1)),a!==null&&o!==null&&(s=["Divide",a,f(s,2)])}}return Fo(e,s,{indexes:o,subs:i,sups:r})}}function Fo(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"?T(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 wl(e){let n=!1,t=e.parseExpression({minPrec:266,condition:()=>{let i=e.index;return n=Bo(e),e.index=i,n}});return t!==null&&!n?qe(t):[t,Al(e)]}function Al(e){let n=[];for(;Bo(e);){e.skipVisualSpace();let t=_(e.parseSymbol());if(t===null)return n;n.push(t)}return n}function qe(e){let n=y(e),t=f(e,1);if(!t)return[e,[]];if(n==="Sequence"&&G(e)===1)return qe(t);if(n==="Multiply"||n==="InvisibleOperator"){let i=T(e);if(i){let[r,s]=$l(i);return r.length>0?[[n,...r],s]:[null,s]}}else if(n==="Delimiter"){let[i,r]=qe(t);if(r)return i?[["Delimiter",["Sequence",i],...T(e).slice(1)],r]:[null,r]}else if(n==="Add"){let i=T(e);if(i.length>0){let[r,s]=qe(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]=qe(t);if(r.length>0)return[i?["Negate",i]:null,r]}else if(n==="Divide"){let[i,r]=qe(t);if(r.length>0)return[["Divide",i??1,f(e,2)],r]}else{let i=T(e);if(i.length===1){let[r,s]=qe(i[0]);if(s.length>0)return[[y(e),r],s]}}return[e,[]]}function Oo(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=T(i).slice(1),i=f(i,1)):_(i)?r=[]:r=[];let s=T(t).slice(1),o=[],a=s.map((l,c)=>{if(_(l)==="Nothing")return o.push(_(r[c])??"Nothing"),"";if(_(l))return o.push(_(l)??"Nothing"),"";let p=y(l);if(p==="Tuple"||p==="Pair"||p==="Limits"||p==="Range"){if(G(l)===3){let m=f(l,1);o.push(_(m)??"Nothing");let d=f(l,2),b=f(l,3);return _(d)==="Nothing"&&(d=null),_(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(G(l)===2){if(_(f(l,1))){o.push(_(f(l,1))??"Nothing");let b=f(l,2);return _(b)==="Nothing"?"":`_{${n.serialize(b)}}`}o.push(_(r[c])??"Nothing");let m=f(l,1),d=f(l,2);if(_(m)==="Nothing"&&(m=null),_(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(_(r[c])??"Nothing")}),u=o.filter(l=>_(l)!=="Nothing").map(l=>`\\mathrm{d}${n.serialize(_(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 Lo=[{kind:"expression",name:"Integrate",latexTrigger:["\\int"],parse:Sn("Integrate"),serialize:Oo("\\int")},{kind:"expression",latexTrigger:["\\iint"],parse:Sn("Integrate")},{kind:"expression",latexTrigger:["\\iiint"],parse:Sn("Integrate")},{kind:"expression",name:"CircularIntegrate",latexTrigger:["\\oint"],parse:Sn("CircularIntegrate"),serialize:Oo("\\oint")},{kind:"expression",latexTrigger:["\\oiint"],parse:Sn("CircularIntegrate")},{kind:"expression",latexTrigger:["\\oiiint"],parse:Sn("CircularIntegrate")}];function Bo(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 $l(e){let n=[...e],t=[];for(;n.length>0;){let i;if([n,i]=Cl(n),!i)break;t.push(i)}return[n,t]}function Cl(e){if(e.length<2)return[e,""];let n=e[e.length-2];if(n==="d"||n==="d_upright"){let t=_(e[e.length-1]);if(t)return[e.slice(0,-2),t]}return[e,""]}var Vo=[{name:"Matrix",serialize:(e,n)=>{let t=T(f(n,1));return Li(e,t,L(f(n,2)),L(f(n,3)))}},{name:"Vector",serialize:(e,n)=>{let t=T(n);return Li(e,t.map(i=>["List",i]),L(f(n,2)),L(f(n,3)))}},{kind:"environment",symbolTrigger:"pmatrix",parse:e=>{let n=Ge(e),[t,i]=ze(e);return n?[t,i,{str:"()"},{str:n}]:[t,i]}},{kind:"environment",symbolTrigger:"bmatrix",parse:e=>{let n=Ge(e),[t,i]=ze(e);return n?[t,i,{str:"[]"},{str:n}]:[t,i,{str:"[]"}]}},{kind:"environment",symbolTrigger:"Bmatrix",parse:e=>{let n=Ge(e),[t,i]=ze(e);return n?[t,i,{str:"{}"},{str:n}]:[t,i,{str:"{}"}]}},{kind:"environment",symbolTrigger:"vmatrix",parse:e=>{let n=Ge(e),[t,i]=ze(e);return n?["Determinant",[t,i,{str:n}]]:["Determinant",[t,i]]}},{kind:"environment",symbolTrigger:"Vmatrix",parse:e=>{let n=Ge(e),[t,i]=ze(e);return n?["Norm",[t,i,{str:n}]]:["Norm",[t,i]]}},{kind:"environment",symbolTrigger:"smallmatrix",parse:e=>{let n=Ge(e),[t,i]=ze(e);return n?[t,i,{str:"()"},{str:n}]:[t,i]}},{kind:"environment",symbolTrigger:"array",parse:e=>{let n=Ge(e,!1),[t,i]=ze(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{kind:"environment",symbolTrigger:"matrix",parse:e=>{let n=Ge(e),[t,i]=ze(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{kind:"environment",symbolTrigger:"matrix*",parse:e=>{let n=Ge(e),[t,i]=ze(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)=>_n(e,n,"\\tr")},{symbolTrigger:"tr",kind:"function",parse:"Trace",arguments:"implicit"},{name:"Kernel",kind:"function",latexTrigger:"\\ker",arguments:"implicit",serialize:(e,n)=>_n(e,n,"\\ker")},{symbolTrigger:"ker",kind:"function",parse:"Kernel",arguments:"implicit"},{name:"Dimension",kind:"function",latexTrigger:"\\dim",arguments:"implicit",serialize:(e,n)=>_n(e,n,"\\dim")},{symbolTrigger:"dim",kind:"function",parse:"Dimension",arguments:"implicit"},{name:"Degree",kind:"function",latexTrigger:"\\deg",arguments:"implicit",serialize:(e,n)=>_n(e,n,"\\deg")},{symbolTrigger:"deg",kind:"function",parse:"Degree",arguments:"implicit"},{name:"Hom",kind:"function",latexTrigger:"\\hom",arguments:"implicit",serialize:(e,n)=>_n(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=T(f(t,1));return Li(e,i,"||",L(f(t,2)))}return _n(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 ze(e){let n=e.parseTabular();return n?["Matrix",["List",...n.map(t=>["List",...t])]]:["",null]}function Ge(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 _n(e,n,t){if(T(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 Li(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 T(c))p.push(e.serialize(m));a.push(p.join(" & "))}let u=a.join(`\\\\
|
|
7
|
+
`),l=o.length>0?`[${o}]`:"";return r==="("&&s===")"?N(["\\begin{pmatrix}",l,u,"\\end{pmatrix}"]):r==="["&&s==="]"?N(["\\begin{bmatrix}",l,u,"\\end{bmatrix}"]):r==="{"&&s==="}"?N(["\\begin{Bmatrix}",l,u,"\\end{Bmatrix}"]):r==="|"&&s==="|"?N(["\\begin{vmatrix}",l,u,"\\end{vmatrix}"]):r==="\u2016"&&s==="\u2016"?N(["\\begin{Vmatrix}",l,u,"\\end{Vmatrix}"]):r==="{"&&s==="."?N(["\\begin{dcases}",l,u,"\\end{dcases}"]):r==="."&&s==="}"?N(["\\begin{rcases}",l,u,"\\end{rcases}"]):o||r!=="."||s!=="."?N(["\\left",Ct[r]??r,"\\begin{array}",`{${o}}`,u,"\\end{array}","\\right",Ct[s]??s]):N(["\\begin{matrix}",u,"\\end{matrix}"])}var Jo=[{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||!_(t)?null:["Mean",t]}}];var Ft={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},qo=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"]),Ot={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 Rl(e){if(e.length>2){let n=e.slice(0,2),t=e.slice(2);if(Ft[n]!==void 0&&qo.has(t)){let i=Ot[t];if(i)return{prefixScale:Ft[n],baseEntry:i}}}if(e.length>1){let n=e.slice(0,1),t=e.slice(1);if(Ft[n]!==void 0&&qo.has(t)){let i=Ot[t];if(i)return{prefixScale:Ft[n],baseEntry:i}}}return null}function Dl(e){let n=Ot[e];if(n)return n;let t=Rl(e);return t?{dimension:t.baseEntry.dimension,scale:t.prefixScale*t.baseEntry.scale}:null}function Bi(e){let n=Dl(e);return n?n.dimension:null}var Fh=new Map(["N","J","W","Pa","Hz","C","V","F","ohm","S","Wb","T","H","lm","lx","Gy","kat"].map(e=>[Ot[e].dimension.join(","),e]));function Pl(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 Kn(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 Kn(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=Kn(r),a=Kn(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=>Kn(a));return o.some(a=>a===null)?null:o.length===1?o[0]:["Multiply",...o]}return e[0]==="("?null:Pl(e)}function zo(e){return e=e.trim(),e.length===0?null:/[/*^()]/.test(e)?Kn(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 Fl=new Set(["d"]);function Yo(e){if(!e||e.length===0||Fl.has(e))return null;if(Bi(e)!==null)return e;if(/[/*^]/.test(e))try{let n=zo(e);if(n!==null&&Vi(n))return n}catch{return null}return null}function Vi(e){if(typeof e=="string")return Bi(e)!==null;if(!Array.isArray(e))return!1;let n=e[0];return n==="Multiply"||n==="Divide"?e.slice(1).every(t=>Vi(t)):n==="Power"?Vi(e[1]):!1}var Go=e=>{let n=e.index,t=Zo(e);if(t===null)return e.index=n,null;let i=Yo(t);return i===null?(e.index=n,null):["__unit__",i]};function un(e){let n=_(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`${un(i)}/${un(r)}`}if(t==="Multiply"){let i=[];if(Array.isArray(e))for(let r=1;r<e.length;r++)i.push(un(e[r]));return i.join("\\cdot ")}if(t==="Power"){let i=f(e,1),r=f(e,2),s=typeof r=="number"?String(r):_(r)??String(r);return`${un(i)}^{${s}}`}if(t==="Square"){let i=f(e,1);return`${un(i)}^{2}`}return""}function jo(e){let n=e.parseGroup();if(n===null)return null;let t=Ho(e);return t===null?null:["Quantity",n,t]}function Uo(e){return Ho(e)}function Ho(e){let n=e.index,t=Zo(e);if(t===null)return e.index=n,null;let i=Yo(t);return i===null?(e.index=n,null):i}var Wo=[{latexTrigger:"\\mathrm",kind:"expression",parse:Go},{latexTrigger:"\\text",kind:"expression",parse:Go},{latexTrigger:"\\qty",parse:jo},{latexTrigger:"\\SI",parse:jo},{latexTrigger:"\\unit",parse:Uo},{latexTrigger:"\\si",parse:Uo},{name:"Quantity",serialize:(e,n)=>{let t=f(n,1),i=f(n,2);if(t===null||i===null)return"";let r=_(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=un(i);return N([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=Rt(c,o.angleNormalization)),o.dmsFormat?Dt(c):`${c}\xB0`}let a=e.serialize(t),u=un(i);return N([a,"\\,",`\\mathrm{${u}}`])}}];var Ol=["pt","em","mu","ex","mm","cm","in","bp","sp","dd","cc","pc","nc","nd"];function Xo(e){for(e.skipSpace(),(e.peek==="-"||e.peek==="+")&&e.nextToken();/^[\d.]$/.test(e.peek);)e.nextToken();for(let n of Ol)if(e.matchAll([...n]))return}function he(e){return n=>{let t=n.parseGroup();return t===null?[e]:[e,t]}}function Lt(e){return n=>{let t=n.parseExpression();return t!==null&&!V(t)?["Annotated",t,{dict:{mathStyle:e}}]:"Nothing"}}function $e(e){return n=>{let t=n.parseExpression();return t!==null&&!V(t)?["Annotated",t,{dict:{size:e}}]:"Nothing"}}var Qo=[{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)=>_(n)===null?null:["Increment",n]},{name:"Decrement",latexTrigger:["-","-"],kind:"postfix",precedence:880,parse:(e,n)=>_(n)===null?null:["Decrement",n]},{name:"PreIncrement",latexTrigger:["+","+"],kind:"prefix",precedence:880,parse:(e,n)=>{let t=e.parseExpression(n);return _(t)===null?null:["PreIncrement",t]}},{name:"PreDecrement",latexTrigger:["-","-"],kind:"prefix",precedence:880,parse:(e,n)=>{let t=e.parseExpression(n);return _(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=an(i);if(r&&(i=["List",...r]),i===null||t===null)return null;let s=e.parseGroup()??"Nothing";if(!V(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",...T(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:he("OverBar")},{name:"UnderBar",latexTrigger:["\\underline"],parse:he("UnderBar")},{name:"OverVector",latexTrigger:["\\vec"],parse:he("OverVector")},{name:"OverTilde",latexTrigger:["\\tilde"],parse:he("OverTilde")},{name:"OverHat",latexTrigger:["\\hat"],parse:he("OverHat")},{name:"OverRightArrow",latexTrigger:["\\overrightarrow"],parse:he("OverRightArrow")},{name:"OverLeftArrow",latexTrigger:["\\overleftarrow"],parse:he("OverLeftArrow")},{name:"OverRightDoubleArrow",latexTrigger:["\\Overrightarrow"],parse:he("OverRightDoubleArrow")},{name:"OverLeftHarpoon",latexTrigger:["\\overleftharpoon"],parse:he("OverLeftHarpoon")},{name:"OverRightHarpoon",latexTrigger:["\\overrightharpoon"],parse:he("OverRightHarpoon")},{name:"OverLeftRightArrow",latexTrigger:["\\overleftrightarrow"],parse:he("OverLeftRightArrow")},{name:"OverBrace",latexTrigger:["\\overbrace"],parse:he("OverBrace")},{name:"OverLineSegment",latexTrigger:["\\overlinesegment"],parse:he("OverLineSegment")},{name:"OverGroup",latexTrigger:["\\overgroup"],parse:he("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:Lt("normal")},{latexTrigger:["\\textstyle"],parse:Lt("compact")},{latexTrigger:["\\scriptstyle"],parse:Lt("script")},{latexTrigger:["\\scriptscriptstyle"],parse:Lt("scriptscript")},{latexTrigger:["\\color"],parse:e=>{let n=e.parseStringGroup();if(n!==null){let t=e.parseExpression();if(t!==null&&!V(t))return["Annotated",t,{dict:{color:n}}]}return"Nothing"}},{latexTrigger:["\\tiny"],parse:$e(1)},{latexTrigger:["\\scriptsize"],parse:$e(2)},{latexTrigger:["\\footnotesize"],parse:$e(3)},{latexTrigger:["\\small"],parse:$e(4)},{latexTrigger:["\\normalsize"],parse:$e(5)},{latexTrigger:["\\large"],parse:$e(6)},{latexTrigger:["\\Large"],parse:$e(7)},{latexTrigger:["\\LARGE"],parse:$e(8)},{latexTrigger:["\\huge"],parse:$e(9)},{latexTrigger:["\\Huge"],parse:$e(10)},{name:"Annotated",serialize:(e,n)=>{let t=e.serialize(f(n,1)),i=fo(f(n,2));if(i==null)return t;i.dict.mathStyle==="normal"?t=N(["{\\displaystyle",t,"}"]):i.dict.mathStyle==="compact"?t=N(["{\\textstyle",t,"}"]):i.dict.mathStyle==="script"?t=N(["{\\scriptstyle",t,"}"]):i.dict.mathStyle==="scriptscript"&&(t=N(["{\\scriptscriptstyle",t,"}"]));let r=i.dict.size;return r!==null&&r>=1&&r<=10&&(t=N(["{",{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=N(["\\texttt{",t,"}"]):i.dict.fontFamily==="sans-serif"&&(t=N(["\\textsf{",t,"}"])),i.dict.fontWeight==="bold"&&(t=N(["\\textbf{",t,"}"])),i.dict.fontStyle==="italic"?t=N(["\\textit{",t,"}"]):i.dict.fontStyle==="normal"&&(t=N(["\\textup{",t,"}"])),i.dict.color&&(t=N(["\\textcolor{",i.dict.color,"}{",t,"}"])),i.dict.backgroundColor&&(t=N(["\\colorbox{",i.dict.backgroundColor,"}{",t,"}"])),i.dict.border===!0&&(t=N(["\\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:["\\hspace"],parse:e=>(e.peek==="*"&&e.nextToken(),e.parseStringGroup(),["HorizontalSpacing",0])},{latexTrigger:["\\hskip"],parse:e=>(Xo(e),["HorizontalSpacing",0])},{latexTrigger:["\\kern"],parse:e=>(Xo(e),["HorizontalSpacing",0])},{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){let i=L(f(n,2)),r=e.serialize(f(n,1));return i==="bin"?`\\mathbin{${r}}`:i==="op"?`\\mathop{${r}}`:i==="rel"?`\\mathrel{${r}}`:i==="ord"?`\\mathord{${r}}`:i==="open"?`\\mathopen{${r}}`:i==="close"?`\\mathclose{${r}}`:i==="punct"?`\\mathpunct{${r}}`:i==="inner"?`\\mathinner{${r}}`:r}let t=C(f(n,1));return t===null?"":{"-3":"\\!",6:"\\ ",3:"\\,",4:"\\:",5:"\\;",9:"\\enspace",18:"\\quad",36:"\\qquad"}[t]??""}}];var Ll=[{name:"Mu0",kind:"symbol",latexTrigger:"\\mu_0"},{name:"VacuumPermittivity",kind:"symbol",latexTrigger:"\\varepsilon_0"}];var Bl=[...xo,...No,...To,...mo,...ko,...sn,...Ro,...Do,...Po,...Lo,...Vo,...Jo,...Wo,...Qo,...Ll];var Vl="\\u{FE0F}",Jl="\\u{20E3}",ql="\\u{200D}",zl="\\p{RI}\\p{RI}",Gl="(?:[\\u{E0020}-\\u{E007E}]+\\u{E007F})",Ko=`(?:\\p{EMod}|${Vl}${Jl}?|${Gl})`,jl="(?:(?=\\P{XIDC})(?=[^\\x23\\x2a\\x30-\\x39])\\p{Emoji})",ea=`(?:${jl}${Ko}*|\\p{Emoji}${Ko}+|${zl})`,na=`(?:${ea})(${ql}${ea})*`,ag=new RegExp(`(?:${na})+`,"u"),ta=new RegExp(`^(?:${na})+$`,"u");function ra(e){return e!==void 0&&"value"in e}function et(e){return e!==void 0&&"operator"in e}function Mn(e,n,t=!0){let i=!t||e.every(s=>s.isCanonical)?e:e.map(s=>s.canonical);if(n){let s=a=>S(a,"Nothing")||a.operator===n||a.operator==="Sequence";if(i.every(a=>!s(a)))return i;let o=[];for(let a of i)S(a,"Nothing")||(h(a)&&(a.operator===n||a.operator==="Sequence")?o.push(...Mn(a.ops,n,t)):o.push(a));return o}if(i.every(s=>!(S(s,"Nothing")||s.operator==="Sequence")))return i;let r=[];for(let s of i)S(s,"Nothing")||(h(s,"Sequence")?r.push(...Mn(s.ops,n,t)):r.push(s));return r}function Vt(e,n,t){if(n=Mn(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 Xe(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 qi(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(Xe(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 sa(e){let n={},t=nc(e.engine),i=ec(e.engine);if(S(e)&&!n[e.symbol]&&!e.symbol.startsWith("_")){if(!t.includes(e.symbol)){let r=Tt(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=Tt(r,i);s&&(n[r]=s)}for(let s of e.ops)n={...n,...sa(s)}}return n}function ec(e){let n=[],t=e.context.lexicalScope;for(;t;){for(let i of t.bindings.keys()){let r=t.bindings.get(i);et(r)&&n.push(i)}t=t.parent}return n}function nc(e){let n=[],t=e.context.lexicalScope;for(;t;){for(let i of t.bindings.keys()){let r=t.bindings.get(i);ra(r)&&n.push(i)}t=t.parent}return n}function je(e){let n=sa(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
8
|
${t.join(`
|
|
9
|
-
`)}`}var se=Math.cosh||function(e){return Math.abs(e)<1e-9?1-e:(Math.exp(e)+Math.exp(-e))*.5},Ee=Math.sinh||function(e){return Math.abs(e)<1e-9?e:(Math.exp(e)-Math.exp(-e))*.5},tc=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)},ic=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))},
|
|
10
|
-
`||(a==="+"?r++:a==="-"?s++:a==="i"||a==="I"?(r+s===0&&Mn(),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)))&&Mn(),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&&Mn();break;case"number":t.im=0,t.re=e;break;default:Mn()}return isNaN(t.re)||isNaN(t.im),t},$=class e{constructor(n,t){this.re=0,this.im=0;var i=rc(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=zi(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)+tc(t),Math.exp(n)*Math.sin(t))}log(){var n=this.re,t=this.im;return t===0&&n>0,new e(zi(n,t),Math.atan2(t,n))}abs(){return ic(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)*se(t),Math.cos(n)*Ee(t))}cos(){var n=this.re,t=this.im;return new e(Math.cos(n)*se(t),-Math.sin(n)*Ee(t))}tan(){var n=2*this.re,t=2*this.im,i=Math.cos(n)+se(t);return new e(Math.sin(n)/i,Ee(t)/i)}cot(){var n=2*this.re,t=2*this.im,i=Math.cos(n)-se(t);return new e(-Math.sin(n)/i,Ee(t)/i)}sec(){var n=this.re,t=this.im,i=.5*se(2*t)+.5*Math.cos(2*n);return new e(Math.cos(n)*se(t)/i,Math.sin(n)*Ee(t)/i)}csc(){var n=this.re,t=this.im,i=.5*se(2*t)-.5*Math.cos(2*n);return new e(Math.sin(n)*se(t)/i,-Math.cos(n)*Ee(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(Ee(n)*Math.cos(t),se(n)*Math.sin(t))}cosh(){var n=this.re,t=this.im;return new e(se(n)*Math.cos(t),Ee(n)*Math.sin(t))}tanh(){var n=2*this.re,t=2*this.im,i=se(n)+Math.cos(t);return new e(Ee(n)/i,Math.sin(t)/i)}coth(){var n=2*this.re,t=2*this.im,i=se(n)-Math.cos(t);return new e(Ee(n)/i,-Math.sin(t)/i)}csch(){var n=this.re,t=this.im,i=Math.cos(2*t)-se(2*n);return new e(-2*Ee(n)*Math.cos(t)/i,2*se(n)*Math.sin(t)/i)}sech(){var n=this.re,t=this.im,i=Math.cos(2*t)+se(2*n);return new e(2*se(n)*Math.cos(t)/i,-2*Ee(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=zi(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 W(e){if(!L(e))return null;let n=e.numericValue;return Math.round(typeof n=="number"?n:n.re)}function sa(e){return e?._kind==="number"}function dc(e){return e?._kind==="symbol"}function Kn(e,n){return(e?._kind==="function"||e?._kind==="tensor")&&(n===void 0||e.operator===n)}function Xe(e){if(Kn(e,"Interval")){let n=e.op1,t=e.op2,i=!1,r=!1;Kn(n,"Open")?(i=!0,n=n.op1):Kn(n,"Closed")&&(n=n.op1),Kn(t,"Open")?(r=!0,t=t.op1):Kn(t,"Closed")&&(t=t.op1);let s=n.N(),o=t.N();return!sa(s)||!sa(o)?void 0:{start:s.re,openStart:i,end:o.re,openEnd:r}}if(dc(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 oa(e,n,t){return n.every(i=>i.isCanonical)?n:n.map(i=>e.expr(i,{scope:t}))}var et=50,_b={List:{complexity:8200,signature:"(any*) -> list",type:(e,{engine:n})=>H(`list<${pe.widen(...e.map(t=>t.type))}>`),canonical:mc,lazy:!0,evaluate:(e,{engine:n,materialization:t})=>{if(t)return n._fn("List",ji(e).map(i=>i.evaluate({materialization:t})))},eq:ua,collection:It()},Set:{complexity:8200,signature:"(any*) -> set",type:(e,{engine:n})=>H(`set<${pe.widen(...e.map(t=>t.type))}>`),canonical:hc,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:{...It(),at:void 0,indexWhere:void 0}},Tuple:{description:"A fixed number of heterogeneous elements",complexity:8200,signature:"(any*) -> tuple",type:e=>H(`tuple<${e.map(n=>n.type).join(", ")}>`),canonical:(e,{engine:n})=>n.tuple(...e),eq:ua,collection:{...It(),keys:e=>["first","second","last"]}},KeyValuePair:{description:"A key/value pair",complexity:8200,signature:"(key: string, value: any) -> tuple<string, unknown>",type:([e,n])=>H(`tuple<string, ${n.type}>`),canonical:(e,{engine:n})=>{let[t,i]=Vi(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])=>H(`tuple<${e.type}>`),canonical:(e,{engine:n})=>n.tuple(...Ot(n,e,1))},Pair:{description:"A tuple of two elements",complexity:8200,signature:"(first: any, second: any) -> tuple<any, any>",type:([e,n])=>H(`tuple<${e.type}, ${n.type}>`),canonical:(e,{engine:n})=>n.tuple(...Ot(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])=>H(`tuple<${e.type}, ${n.type}, ${t.type}>`),canonical:(e,{engine:n})=>n.tuple(...Ot(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]=Ge(e),[s,o,a]=Ge(n);return t===s&&i===o&&r===a},collection:{isLazy:e=>!0,count:e=>{let[n,t,i]=Ge(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]=Ge(e);return s===0?!1:s>0?t>=i&&t<=r:t<=i&&t>=r},iterator:e=>{let[n,t,i]=Ge(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]=Ge(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]=Ge(e),[o,a,u]=Ge(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]=Ge(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]=Vi(t,[e.canonical,n.canonical],["number","number"]);return!i.isValid||!r.isValid?null:t._fn("Interval",[i,r])},eq:(e,n)=>{let t=Xe(e),i=Xe(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=Xe(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=Xe(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=Xe(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=Xe(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=Xe(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=et),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=et),!(!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:et):(t=n,n=1,i=et);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=et),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=He(n,e[0]?.canonical,"collection"),i=Oe(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=te(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 te(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=He(n,e[0]?.canonical,"collection"),i=Oe(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=te(e.op2);return be(t([n]))==="True"},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=te(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 gn({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. ${je(e.op2)}`);if(be(a)==="True")return{value:s,done:!1};if(be(a)!=="False")throw new Error(`Filter predicate must return "True" or "False". ${je(e.op2)}`)}}}},at:(e,n)=>{if(typeof n!="number"||!Number.isFinite(n)||n===0||!h(e))return;let t=te(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=be(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". ${je(e.op2)}`)}}}},Reduce:{complexity:8200,lazy:!0,signature:"(collection, function, initial:value?) -> value",canonical:(e,{engine:n})=>{let t=He(n,e[0],"collection"),i=Oe(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=>H(vi(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:Ti((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=te(n);return Ti(fa(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:gc,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)??Se(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=ge(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<${Se(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:ca,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,W(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:bc,at:(e,n)=>{if(typeof n!="number"||n===0||!h(e))return;let t=Math.max(0,W(e.op2)??0);if(t===0)return;if(n>0)return n>t?void 0:e.op1.at(n);let i=ca(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<${Se(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=W(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=W(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=W(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])=>H(`list<${Se(e.type.type)}>`),collection:{isLazy:e=>!0,count:e=>{if(!h(e))return;let n=W(e.op2)??1,t=e.op1.count;if(t===void 0)return;let i=W(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=W(e.op2)??1;if(i<1&&(i=t+1+i),i<1&&(i=1),i>t)return;let r=W(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=W(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=W(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=W(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=W(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=W(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=W(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=te(n);if(!i)return t.Zero;let r=e.indexWhere(s=>{let o=be(i([s]));if(o==="True")return!0;if(o==="False")return!1;throw new Error(`Filter predicate must return "True" or "False". ${je(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=te(n);if(!i)return t.Nothing;for(let r of e.each()){let s=be(i([r]));if(s!=="False"){if(s==="True")return r;throw new Error(`Filter predicate must return "True" or "False". ${je(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=te(n);if(!i)return t.Zero;let r=0;for(let s of e.each()){let o=be(i([s]));if(o!=="False")if(o==="True")r++;else throw new Error(`Filter predicate must return "True" or "False". ${je(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=te(n);if(!i)return t.function("List",[]);let r=[],s=1;for(let o of e.each()){let a=be(i([o]));if(a==="True"&&r.push(t.number(s)),a!=="False")throw new Error(`Filter predicate must return "True" or "False". ${je(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=la(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=la(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=Oe(e[0]);return t?e[2]?n._fn("Tabulate",[t,He(n,e[1]?.canonical,"integer"),He(n,e[2]?.canonical,"integer")]):n._fn("Tabulate",[t,He(n,e[1]?.canonical,"integer")]):null},evaluate:(e,{engine:n})=>{let t=te(e[0]);if(!t)return;if(e.length===1)return n._fn("List",[]);let i=e.slice(1).map(s=>W(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"?H("tuple<list<string>, list<integer>>"):H(`tuple<list<${Se(t)}>, list<integer>>`)},evaluate:(e,{engine:n})=>{if(!e[0].isFiniteCollection)return;let[t,i]=aa(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<${Se(e.type.type)}>`,evaluate:(e,{engine:n})=>{if(!e[0].isFiniteCollection)return;let[t,i]=aa(e[0]);return n.function("List",t)}},Partition:{wikidata:"Q381060",complexity:8200,signature:"(collection, integer | function) -> list",type:([e])=>`list<${Se(e.type.type)}>`,evaluate:([e,n],{engine:t})=>{if(!e.isFiniteCollection)return;let i=W(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 f=a.slice(c*l,(c+1)*l);u.push(t.function("List",f))}return t.function("List",u)}let r=te(n);if(!r)return;let s=[],o=[];for(let a of e.each()){let u=be(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". ${je(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=W(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=te(n);if(!i)return;let r={};for(let s of e.each()){let o=i([s])??t.Nothing,a=(k(o)?o.symbol:void 0)??(ge(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:qi,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=qi(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=qi(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=Oe(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=te(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=te(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=>W(t)??0)[0]??0,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=te(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=>W(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=te(e.op1);if(!t||!h(e.op2))return;let i=e.op2.ops.map(u=>W(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=he(n,Se(t.type.type)??n)}return H(`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=he(n,Se(t.type.type)??n)}return H(`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(!ge(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(!ge(r))throw new Error(`Expected a string key, got ${r.type}`);t.push(n.tuple(r,s))}return n.function("Record",t)}}};function Ge(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 mc(e,{engine:n}){let t=e[0];if(e.length===1&&h(t,"Matrix")){let[i,r,s]=t.ops;if(!r||ge(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",oa(n,i.op1.ops)):n._fn("List",[i.op1?.canonical??n.Nothing]):i.canonical),n._fn("List",e)}function hc(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 aa(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*fa(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 gc(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 ua(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 la(e,n=void 0){let t=n?te(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)be(t)!=="Nothing"&&(h(t,"Sequence")?n.push(...ji([...t.ops])):ge(t)?n.push(t):t.isCollection?n.push(...ji([...t.each()])):n.push(t));return n}function bc(e){if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=Math.max(0,W(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 ca(e){if(!h(e))return;let[n,t]=e.ops,i=n.count;if(i===void 0)return;let r=Math.max(0,W(t)??0);return Number.isFinite(r)?Math.min(i,r):1/0}function qi(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 pa(e){e?.operator,h(e);let n=1,t=n+mi,i,r=!0,s=e,o=s.op1;i=k(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(k(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+mi),{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(k(n)){let r=n.symbol,s=t.operators?.(r);return s!==void 0?`(a,b) => a ${s[0]} b`:t.var?.(r)??r}if(L(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(ge(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(_i(t)&&i.length>2){let f=[];for(let d=0;d<i.length-1;d++)f.push(e.compileExpr(n,t,[i[d],i[d+1]],o[1],s));return`(${f.join(") && (")})`}let c;return i.length===1?c=`${o[0]}${e.compile(i[0],s,o[1])}`:c=i.map(f=>e.compile(f,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=>k(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=k(i[0])?i[0].symbol:"_";return s.declare?s.declare(u):`let ${u}`}if(t==="Assign")return`${k(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 f=i[c],d=i[c+1];return k(f,"True")?`(${e.compile(d,s)})`:`((${e.compile(f,s)}) ? (${e.compile(d,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(Qn(u)&&u.operator.broadcastable&&i.length===1&&Ni(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];k(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")&&k(l.ops[0],u)){let c=l.ops[1];e.isComplexValued(c)?r[u]=a?"vec2f":"vec2":e.isIntegerValued(c)&&(r[u]=a?"i32":"int");break}}let s={...t,var:a=>i.includes(a)?a:t.var(a)},o=n.filter(a=>!k(a,"Nothing")).map(a=>h(a,"Declare")&&k(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(`
|
|
9
|
+
`)}`}var se=Math.cosh||function(e){return Math.abs(e)<1e-9?1-e:(Math.exp(e)+Math.exp(-e))*.5},Ee=Math.sinh||function(e){return Math.abs(e)<1e-9?e:(Math.exp(e)-Math.exp(-e))*.5},tc=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)},ic=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))},wn=function(){throw SyntaxError("Invalid Param")};function zi(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 rc=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]):wn();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&&wn();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&&wn(),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)))&&wn(),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&&wn();break;case"number":t.im=0,t.re=e;break;default:wn()}return isNaN(t.re)||isNaN(t.im),t},$=class e{constructor(n,t){this.re=0,this.im=0;var i=rc(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=zi(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)+tc(t),Math.exp(n)*Math.sin(t))}log(){var n=this.re,t=this.im;return t===0&&n>0,new e(zi(n,t),Math.atan2(t,n))}abs(){return ic(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)*se(t),Math.cos(n)*Ee(t))}cos(){var n=this.re,t=this.im;return new e(Math.cos(n)*se(t),-Math.sin(n)*Ee(t))}tan(){var n=2*this.re,t=2*this.im,i=Math.cos(n)+se(t);return new e(Math.sin(n)/i,Ee(t)/i)}cot(){var n=2*this.re,t=2*this.im,i=Math.cos(n)-se(t);return new e(-Math.sin(n)/i,Ee(t)/i)}sec(){var n=this.re,t=this.im,i=.5*se(2*t)+.5*Math.cos(2*n);return new e(Math.cos(n)*se(t)/i,Math.sin(n)*Ee(t)/i)}csc(){var n=this.re,t=this.im,i=.5*se(2*t)-.5*Math.cos(2*n);return new e(Math.sin(n)*se(t)/i,-Math.cos(n)*Ee(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(Ee(n)*Math.cos(t),se(n)*Math.sin(t))}cosh(){var n=this.re,t=this.im;return new e(se(n)*Math.cos(t),Ee(n)*Math.sin(t))}tanh(){var n=2*this.re,t=2*this.im,i=se(n)+Math.cos(t);return new e(Ee(n)/i,Math.sin(t)/i)}coth(){var n=2*this.re,t=2*this.im,i=se(n)-Math.cos(t);return new e(Ee(n)/i,-Math.sin(t)/i)}csch(){var n=this.re,t=this.im,i=Math.cos(2*t)-se(2*n);return new e(-2*Ee(n)*Math.cos(t)/i,2*se(n)*Math.sin(t)/i)}sech(){var n=this.re,t=this.im,i=Math.cos(2*t)+se(2*n);return new e(2*se(n)*Math.cos(t)/i,-2*Ee(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=zi(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 H(e){if(!O(e))return null;let n=e.numericValue;return Math.round(typeof n=="number"?n:n.re)}function aa(e){return e?._kind==="number"}function mc(e){return e?._kind==="symbol"}function nt(e,n){return(e?._kind==="function"||e?._kind==="tensor")&&(n===void 0||e.operator===n)}function Qe(e){if(nt(e,"Interval")){let n=e.op1,t=e.op2,i=!1,r=!1;nt(n,"Open")?(i=!0,n=n.op1):nt(n,"Closed")&&(n=n.op1),nt(t,"Open")?(r=!0,t=t.op1):nt(t,"Closed")&&(t=t.op1);let s=n.N(),o=t.N();return!aa(s)||!aa(o)?void 0:{start:s.re,openStart:i,end:o.re,openEnd:r}}if(mc(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 ua(e,n,t){return n.every(i=>i.isCanonical)?n:n.map(i=>e.expr(i,{scope:t}))}var tt=50,Tb={List:{complexity:8200,signature:"(any*) -> list",type:(e,{engine:n})=>W(`list<${pe.widen(...e.map(t=>t.type))}>`),canonical:dc,lazy:!0,evaluate:(e,{engine:n,materialization:t})=>{if(t)return n._fn("List",Ui(e).map(i=>i.evaluate({materialization:t})))},eq:ca,collection:St()},Set:{complexity:8200,signature:"(any*) -> set",type:(e,{engine:n})=>W(`set<${pe.widen(...e.map(t=>t.type))}>`),canonical:hc,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:{...St(),at:void 0,indexWhere:void 0}},Tuple:{description:"A fixed number of heterogeneous elements",complexity:8200,signature:"(any*) -> tuple",type:e=>W(`tuple<${e.map(n=>n.type).join(", ")}>`),canonical:(e,{engine:n})=>n.tuple(...e),eq:ca,collection:{...St(),keys:e=>["first","second","last"]}},KeyValuePair:{description:"A key/value pair",complexity:8200,signature:"(key: string, value: any) -> tuple<string, unknown>",type:([e,n])=>W(`tuple<string, ${n.type}>`),canonical:(e,{engine:n})=>{let[t,i]=qi(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])=>W(`tuple<${e.type}>`),canonical:(e,{engine:n})=>n.tuple(...Vt(n,e,1))},Pair:{description:"A tuple of two elements",complexity:8200,signature:"(first: any, second: any) -> tuple<any, any>",type:([e,n])=>W(`tuple<${e.type}, ${n.type}>`),canonical:(e,{engine:n})=>n.tuple(...Vt(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])=>W(`tuple<${e.type}, ${n.type}, ${t.type}>`),canonical:(e,{engine:n})=>n.tuple(...Vt(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]=Ue(e),[s,o,a]=Ue(n);return t===s&&i===o&&r===a},collection:{isLazy:e=>!0,count:e=>{let[n,t,i]=Ue(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]=Ue(e);return s===0?!1:s>0?t>=i&&t<=r:t<=i&&t>=r},iterator:e=>{let[n,t,i]=Ue(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]=Ue(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]=Ue(e),[o,a,u]=Ue(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]=Ue(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]=qi(t,[e.canonical,n.canonical],["number","number"]);return!i.isValid||!r.isValid?null:t._fn("Interval",[i,r])},eq:(e,n)=>{let t=Qe(e),i=Qe(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=Qe(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=Qe(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=Qe(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=Qe(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=Qe(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=tt),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=tt),!(!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:tt):(t=n,n=1,i=tt);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=tt),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=Xe(n,e[0]?.canonical,"collection"),i=Be(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=te(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 te(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=Xe(n,e[0]?.canonical,"collection"),i=Be(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=te(e.op2);return ye(t([n]))==="True"},iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=te(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 bn({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. ${je(e.op2)}`);if(ye(a)==="True")return{value:s,done:!1};if(ye(a)!=="False")throw new Error(`Filter predicate must return "True" or "False". ${je(e.op2)}`)}}}},at:(e,n)=>{if(typeof n!="number"||!Number.isFinite(n)||n===0||!h(e))return;let t=te(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=ye(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". ${je(e.op2)}`)}}}},Reduce:{complexity:8200,lazy:!0,signature:"(collection, function, initial:value?) -> value",canonical:(e,{engine:n})=>{let t=Xe(n,e[0],"collection"),i=Be(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=>W(Ti(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:ki((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=te(n);return ki(ma(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:gc,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)??_e(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=be(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<${_e(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:pa,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,H(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:bc,at:(e,n)=>{if(typeof n!="number"||n===0||!h(e))return;let t=Math.max(0,H(e.op2)??0);if(t===0)return;if(n>0)return n>t?void 0:e.op1.at(n);let i=pa(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<${_e(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=H(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=H(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=H(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])=>W(`list<${_e(e.type.type)}>`),collection:{isLazy:e=>!0,count:e=>{if(!h(e))return;let n=H(e.op2)??1,t=e.op1.count;if(t===void 0)return;let i=H(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=H(e.op2)??1;if(i<1&&(i=t+1+i),i<1&&(i=1),i>t)return;let r=H(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=H(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=H(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=H(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=H(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=H(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=H(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=te(n);if(!i)return t.Zero;let r=e.indexWhere(s=>{let o=ye(i([s]));if(o==="True")return!0;if(o==="False")return!1;throw new Error(`Filter predicate must return "True" or "False". ${je(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=te(n);if(!i)return t.Nothing;for(let r of e.each()){let s=ye(i([r]));if(s!=="False"){if(s==="True")return r;throw new Error(`Filter predicate must return "True" or "False". ${je(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=te(n);if(!i)return t.Zero;let r=0;for(let s of e.each()){let o=ye(i([s]));if(o!=="False")if(o==="True")r++;else throw new Error(`Filter predicate must return "True" or "False". ${je(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=te(n);if(!i)return t.function("List",[]);let r=[],s=1;for(let o of e.each()){let a=ye(i([o]));if(a==="True"&&r.push(t.number(s)),a!=="False")throw new Error(`Filter predicate must return "True" or "False". ${je(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=fa(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=fa(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=Be(e[0]);return t?e[2]?n._fn("Tabulate",[t,Xe(n,e[1]?.canonical,"integer"),Xe(n,e[2]?.canonical,"integer")]):n._fn("Tabulate",[t,Xe(n,e[1]?.canonical,"integer")]):null},evaluate:(e,{engine:n})=>{let t=te(e[0]);if(!t)return;if(e.length===1)return n._fn("List",[]);let i=e.slice(1).map(s=>H(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"?W("tuple<list<string>, list<integer>>"):W(`tuple<list<${_e(t)}>, list<integer>>`)},evaluate:(e,{engine:n})=>{if(!e[0].isFiniteCollection)return;let[t,i]=la(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<${_e(e.type.type)}>`,evaluate:(e,{engine:n})=>{if(!e[0].isFiniteCollection)return;let[t,i]=la(e[0]);return n.function("List",t)}},Partition:{wikidata:"Q381060",complexity:8200,signature:"(collection, integer | function) -> list",type:([e])=>`list<${_e(e.type.type)}>`,evaluate:([e,n],{engine:t})=>{if(!e.isFiniteCollection)return;let i=H(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=te(n);if(!r)return;let s=[],o=[];for(let a of e.each()){let u=ye(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". ${je(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=H(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=te(n);if(!i)return;let r={};for(let s of e.each()){let o=i([s])??t.Nothing,a=(S(o)?o.symbol:void 0)??(be(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:ji,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=ji(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=ji(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=Be(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=te(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=te(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=>H(t)??0)[0]??0,iterator:e=>{if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=te(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=>H(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=te(e.op1);if(!t||!h(e.op2))return;let i=e.op2.ops.map(u=>H(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=ge(n,_e(t.type.type)??n)}return W(`list<${z(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=ge(n,_e(t.type.type)??n)}return W(`set<${z(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(!be(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(!be(r))throw new Error(`Expected a string key, got ${r.type}`);t.push(n.tuple(r,s))}return n.function("Record",t)}}};function Ue(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 dc(e,{engine:n}){let t=e[0];if(e.length===1&&h(t,"Matrix")){let[i,r,s]=t.ops;if(!r||be(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",ua(n,i.op1.ops)):n._fn("List",[i.op1?.canonical??n.Nothing]):i.canonical),n._fn("List",e)}function hc(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 la(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*ma(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 gc(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 ca(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 fa(e,n=void 0){let t=n?te(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 Ui(e){if(e.length===0)return[];let n=[];for(let t of e)ye(t)!=="Nothing"&&(h(t,"Sequence")?n.push(...Ui([...t.ops])):be(t)?n.push(t):t.isCollection?n.push(...Ui([...t.each()])):n.push(t));return n}function bc(e){if(!h(e))return{next:()=>({value:void 0,done:!0})};let n=Math.max(0,H(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 pa(e){if(!h(e))return;let[n,t]=e.ops,i=n.count;if(i===void 0)return;let r=Math.max(0,H(t)??0);return Number.isFinite(r)?Math.min(i,r):1/0}function ji(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 da(e){e?.operator,h(e);let n=1,t=n+gi,i,r=!0,s=e,o=s.op1;i=S(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(S(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+gi),{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(S(n)){let r=n.symbol,s=t.operators?.(r);return s!==void 0?`(a,b) => a ${s[0]} b`:t.var?.(r)??r}if(O(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(be(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(_i(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=>S(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=S(i[0])?i[0].symbol:"_";return s.declare?s.declare(u):`let ${u}`}if(t==="Assign")return`${S(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 S(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(et(u)&&u.operator.broadcastable&&i.length===1&&Ii(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];S(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")&&S(l.ops[0],u)){let c=l.ops[1];e.isComplexValued(c)?r[u]=a?"vec2f":"vec2":e.isIntegerValued(c)&&(r[u]=a?"i32":"int");break}}let s={...t,var:a=>i.includes(a)?a:t.var(a)},o=n.filter(a=>!S(a,"Nothing")).map(a=>h(a,"Declare")&&S(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
11
|
`)}${o.join(`;${t.ws(`
|
|
12
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(!
|
|
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(!S(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
14
|
`)}for (let ${o} = ${a}; ${o} <= ${u}; ${o}++) {${t.ws(`
|
|
15
|
-
`)}${
|
|
15
|
+
`)}${p}${t.ws(`
|
|
16
16
|
`)}}${t.ws(`
|
|
17
|
-
`)}})()`}static compileLoopBody(n,t){if(
|
|
18
|
-
let ${
|
|
17
|
+
`)}})()`}static compileLoopBody(n,t){if(S(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}=da(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
19
|
let ${r} = ${s};
|
|
20
20
|
while (${r} <= ${o}) {
|
|
21
|
-
const ${
|
|
22
|
-
${
|
|
21
|
+
const ${d} = ${p};
|
|
22
|
+
${m} = { re: ${m}.re + ${d}.re, im: ${m}.im + ${d}.im };
|
|
23
23
|
${r}++;
|
|
24
24
|
}
|
|
25
|
-
return ${
|
|
25
|
+
return ${m};
|
|
26
26
|
})()`:`(() => {
|
|
27
|
-
let ${
|
|
27
|
+
let ${m} = { re: 1, im: 0 };
|
|
28
28
|
let ${r} = ${s};
|
|
29
29
|
while (${r} <= ${o}) {
|
|
30
|
-
const ${
|
|
31
|
-
${
|
|
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
32
|
${r}++;
|
|
33
33
|
}
|
|
34
|
-
return ${
|
|
34
|
+
return ${m};
|
|
35
35
|
})()`}return`(() => {
|
|
36
|
-
let ${
|
|
36
|
+
let ${m} = ${u?"0":"1"};
|
|
37
37
|
let ${r} = ${s};
|
|
38
38
|
while (${r} <= ${o}) {
|
|
39
|
-
${
|
|
39
|
+
${m} ${l}= ${p};
|
|
40
40
|
${r}++;
|
|
41
41
|
}
|
|
42
|
-
return ${
|
|
43
|
-
})()`}static isComplexValued(n){if(L(n))return n.im!==0;if(k(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.type;return t.matches("complex")&&!t.matches("real")?!0:t.matches("real")?!1:n.ops.some(i=>e.isComplexValued(i))}return!1}static isIntegerValued(n){if(L(n))return n.im===0&&Number.isInteger(n.re);let t=n.type;return t?t.matches("integer"):!1}static isNonNegative(n){return L(n)?n.im===0&&n.re>=0:n.isNonNegative===!0}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 nt(e){return typeof e=="object"&&e!==null}function da(e){return typeof e=="number"&&Number.isFinite(e)}function yc(e){if(!nt(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(!da(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 xc(e,n){if(n!==void 0&&(!Array.isArray(n)||n.length!==2||typeof n[0]!="string"||!da(n[1])))throw new Error(`Invalid compilation option "operators.${e}": expected [string, number]`)}function Ec(e){if(e!==void 0&&typeof e!="function"){if(!nt(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))xc(n,t)}}function vc(e){if(e!==void 0){if(!nt(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 Nc(e){if(e!==void 0){if(!nt(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 Tc(e){if(e!==void 0&&!Array.isArray(e))throw new Error('Invalid compilation option "imports": expected an array')}function ma(e){if(e!==void 0){if(!nt(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&&yc(e.target),Ec(e.operators),vc(e.functions),Nc(e.vars),Tc(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 Ic(e,n){ma(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){console.warn(`Compilation fallback for "${e.operator}" (target: ${n?.to??"javascript"}): ${t.message}`);let i=e.engine,r=(s=>{i.pushScope();try{if(s&&typeof s=="object")for(let[o,a]of Object.entries(s))i.assign(o,a);return e.evaluate().re}finally{i.popScope()}});return{target:n?.to??"javascript",success:!1,code:"",calling:"expression",run:r}}throw t}}function oe(e){let n=e.toString();return!n.includes(".")&&!n.includes("e")&&!n.includes("E")?`${n}.0`:n}function Z(e){if(!L(e)||e.im!==0)return;let n=e.re;if(isFinite(n))return n}var _c=/^-?\d+(\.\d+)?$/;function Qe(e,n,t){let i=t==="+"?0:1,r=null,s=[];for(let o of e)if(_c.test(o)){let a=parseFloat(o);if(t==="*"&&a===0)return"0.0";r===null?r=a:r=t==="+"?r+a:r*a}else s.push(o);return r!==null&&r!==i&&s.unshift(oe(r)),s.length===0?r!==null?oe(r):n:s.length===1?s[0]:s.join(t==="+"?" + ":" * ")}function ha(e,n){if(k(e,"ImaginaryUnit"))return{re:null,im:"1.0"};if(L(e)&&e.im!==0){let t=e.re,i=e.im;return{re:t!==0?oe(t):null,im:oe(i)}}if(h(e,"Multiply")){let t=e.ops,i=t.findIndex(r=>k(r,"ImaginaryUnit")||L(r)&&r.re===0&&r.im!==0);if(i>=0){let r=t[i],s=k(r,"ImaginaryUnit")?1:r.im,o=t.filter((l,c)=>c!==i);if(o.length===0)return{re:null,im:oe(s)};let a=o.map(l=>n(l));return s!==1&&a.unshift(oe(s)),{re:null,im:Qe(a,"1.0","*")}}}return g.isComplexValued(e)?null:{re:n(e),im:null}}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 Ui(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 Ki(e,n,t){e=e/360;let i,r,s;if(n===0)i=r=s=t;else{let o=(l,c,f)=>(f<0&&(f+=1),f>1&&(f-=1),f<.16666666666666666?l+(c-l)*6*f:f<.5?c:f<.6666666666666666?l+(c-l)*(.6666666666666666-f)*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 er(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 kc(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 qt(e){return typeof e=="number"?{r:e>>>24&255,g:e>>>16&255,b:e>>>8&255,alpha:(e&255)/255}:typeof e=="string"?kc(e):"C"in e?$n(e):"a"in e&&"b"in e?it(e):e}function ga(e){let n=qt(e),t=n.alpha!==void 0?Ce(n.alpha*255):255;return(Ce(n.r)<<24|Ce(n.g)<<16|Ce(n.b)<<8|t)>>>0}function Ce(e){return e<0?0:e>255?255:Math.round(e)}function Qi(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 Ra(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 Jt(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 Yi(e){let[n,t,i]=e;return n>=0&&n<=1&&t>=0&&t<=1&&i>=0&&i<=1}function Wi(e,n){let[t,i,r]=e;return t=Ce(t*255),i=Ce(i*255),r=Ce(r*255),n!==void 0?{r:t,g:i,b:r,alpha:n}:{r:t,g:i,b:r}}function it(e){let[n,t,i]=Jt(e);if(Yi([n,t,i]))return Wi([n,t,i],e.alpha);let r=Ra(e);if(r.C=0,[n,t,i]=Jt(Qi(r)),!Yi([n,t,i]))return Wi([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]=Jt(Qi(r)),Yi([n,t,i])?s=a:o=a;return Wi([n,t,i],e.alpha)}function $n(e){return it(Qi(e))}function nr(e){let[n,t,i]=[e.r,e.g,e.b],r=Ui(n/255),s=Ui(t/255),o=Ui(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),f=Math.cbrt(u),d=Math.cbrt(l),m={L:.2104542553*c+.793617785*f-.0040720468*d,a:1.9779984951*c-2.428592205*f+.4505937099*d,b:.0259040371*c+.7827717662*f-.808675766*d};return e.alpha!==void 0&&(m.alpha=e.alpha),m}function Ke(e){return Ra(nr(e))}function Hi(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]=Jt({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 An(e,n,t){let i=e/100;if(i<=0)return 255;let r=$n({L:i,C:n,H:t});return(Ce(r.r)<<24|Ce(r.g)<<16|Ce(r.b)<<8|255)>>>0}function Sc(e){let{l:n,c:t,h:i}=jt(e);return An(n+2.8,t+.002,i+.46)}function jt(e){let n=e>>>24&255,t=e>>>16&255,i=e>>>8&255,r=Ke({r:n,g:t,b:i});return{l:r.L*100,c:r.C,h:r.H<0?r.H+360:r.H}}function Xi(e,n,t){let{l:i,c:r,h:s}=jt(e),{l:o,c:a,h:u}=jt(n),l=i+(o-i)*t,c=r+(a-r)*t,f=u-s;f>180&&(f-=360),f<-180&&(f+=360);let d=s+f*t,m=e&255,b=n&255,E=Math.round(m+(b-m)*t);return An(l,c,d<0?d+360:d>360?d-360:d)&4294967040|E}function Mc(e,n=.1){let a=.45,u=0;for(let b=.45;b>=.35;b-=.01){let E=Hi(b,e);if(E>=.15){a=b,u=.15;break}else E>u&&(a=b,u=E)}if(u<.15*.8)for(let b=.45+.01;b<=.5;b+=.01){let E=Hi(b,e);if(E>=.15||E>u*1.2){a=b,u=Math.min(.15,E);break}}let l=.96,c=.02,f=Hi(.96,e);f<.02&&(c=f*(1-n)),c=Math.max(.015,Math.min(.02,c));let d=An(a*100,u,e),m=An(l*100,c,e);return{darkest:d,lightest:m}}function wc(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}=jt(r),l=r&255,{darkest:c,lightest:f}=Mc(u);i=c&4294967040|l,s=f&4294967040|l}if(!r&&typeof e=="object"&&!e.mid&&(r=Xi(i,s,.5)),t<=500){let u=t/500,l=u*u*(3-2*u);return Xi(s,r,l)}let o=(t-500)/500,a=o*o*(3-2*o);return Xi(r,i,a)}var Ac=[{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 wn({lightness:e,chroma:n,hue:t}){return An(e,n,t)}function $c(e){let{mid:n,lightest:t,darkest:i}=e.colors;if(t&&i&&n)return{lightest:wn(t),mid:wn(n),darkest:wn(i)};if(t&&i)return{lightest:wn(t),darkest:wn(i)};if(n)return wn(n);throw new Error(`Color scale preset "${e.id}" is missing required anchors.`)}var zt=null;function Cc(){if(!zt){zt=Object.create(null);for(let e of Ac)zt[e.id]=$c(e)}return zt}var ba={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 rt(e,n){let t=e.trim().toLowerCase();if(t.startsWith("#")){let u=t.substring(1),l,c,f,d=255;if(u.length===3)l=parseInt(u[0]+u[0],16),c=parseInt(u[1]+u[1],16),f=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),f=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),f=parseInt(u.substring(4,6),16),d=parseInt(u.substring(6,8),16);else return 0;return(l<<24|c<<16|f<<8|d)>>>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,f=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("%")&&(f=f/100*255)):l<=1&&c<=1&&f<=1&&(l=l*255,c=c*255,f=f*255),l=Math.round(Math.max(0,Math.min(255,l))),c=Math.round(Math.max(0,Math.min(255,c))),f=Math.round(Math.max(0,Math.min(255,f)));let d=255;if(u.length>=4){let m=parseFloat(u[3]);u[3].includes("%")?m=m/100:m>1&&(m=m/255),d=Math.round(Math.max(0,Math.min(255,m*255)))}return(l<<24|c<<16|f<<8|d)>>>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,f=parseFloat(u[2])||0,d=1;u.length>=4&&(d=parseFloat(u[3]),u[3].includes("%")?d=d/100:d>1&&(d=d/255));let m=An(l*100,c,f),b=Math.round(d*255);return m&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,f=parseFloat(u[2])||0,d=1;u.length>=4&&(d=parseFloat(u[3]),u[3].includes("%")?d=d/100:d>1&&(d=d/255));let m=it({L:l,a:c,b:f}),b=m.r,E=m.g,T=m.b,M=Math.round(d*255);return(b<<24|E<<16|T<<8|M)>>>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 f=parseFloat(u[2])||0;u[2].includes("%")?f=f/100:f<=1||(f=f/100);let d=1;u.length>=4&&(d=parseFloat(u[3]),u[3].includes("%")?d=d/100:d>1&&(d=d/255));let{r:m,g:b,b:E}=Ki(l,c,f),T=Math.round(d*255);return(m<<24|b<<16|E<<8|T)>>>0}if(t==="transparent")return 0;let a=t.match(/^([a-z]+)-(\d+)$/);if(a){let u=Cc()[a[1]];if(u){let l=wc(u,parseInt(a[2],10));return n?Sc(l):l}}return t in ba?rt(ba[t]):(console.warn(`parseColor: unrecognized color "${e}"`),0)}function Da(e,n){let t=rt(e,n);return[(t>>>24&255)/255,(t>>>16&255)/255,(t>>>8&255)/255]}function Gt(e,n){let t=qt(e),i=qt(n),r=.56,s=.57,o=.62,a=.65,u=.022,l=1.414,c=.1,f=5e-4,d=1.14,m=.027,b=1.14,E=.027;function T(U){return U>=u?U:U+(u-U)**l}function M(U){return(U<0?-1:1)*Math.pow(Math.abs(U),2.4)}let C=T(M(i.r/255)*.2126729+M(i.g/255)*.7151522+M(i.b/255)*.072175),P=T(M(t.r/255)*.2126729+M(t.g/255)*.7151522+M(t.b/255)*.072175),O,Q;return Math.abs(P-C)<f?Q=0:P>C?(O=P**r-C**s,Q=O*d):(O=P**a-C**o,Q=O*b),Math.abs(Q)<c?0:Q>0?Q-E:Q+m}function tr(e){let n,t,i;typeof e!="object"||!("bg"in e)?(n=qt(e),t="#ffffff",i="#000000"):(n=e.bg,t=e.fg1,i=e.fg2);let r=Math.abs(Gt(t,n)),s=Math.abs(Gt(i,n));return r>=s?ga(t):ga(i)}var Rc=["#4e79a7","#f28e2b","#59a14f","#e15759","#b07aa1","#9c755f","#ff9da7","#edc948","#76b7b2","#6b8fd6","#c07bc4"],Dc=["#78a6d9","#ffae54","#7ddc7a","#ff7a7a","#d29be0","#c49a84","#ffb3bf","#ffe066","#7fd6d0","#8fb4ff","#e199eb"],Pc=["#4e79a7","#f28e2b","#2ca58d","#d13a3c","#b07aa1","#9c755f","#ff9da7","#e3c13b","#5fb8b2","#6b8fd6","#c07bc4"],Fc=["#8fb1d4","#f6b878","#8ecf86","#f08a8b","#d3a9cc","#c3a492","#ffc6cc","#f3e08a","#a8d8d4","#a9c0ea","#e0b4e4"],Lc=["#78a6d9","#ffae54","#7ddc7a","#ff7a7a","#d29be0","#c49a84","#ffb3bf","#ffe066","#7fd6d0","#8fb4ff","#e199eb"],Oc=["#2f6fb0","#ff7a00","#2fa23a","#e02f2f","#9b4db5","#7f4f38","#ff6f86","#f2c200","#2daaa3","#4c79e0","#b84ac6"],Bc=["#4f93ff","#ff8c1a","#33c94a","#ff4f4f","#b86bff","#a86a4a","#ff7f9e","#ffd400","#2ec9c1","#6f9bff","#cc5bd9"],Vc=["#5E81B5","#E19C24","#8FB131","#EB6235","#8778B3","#C56E1A","#5E9EC9","#B23A3A","#4C9F70","#C979B7"],zc=["#1f77b4","#ff7f0e","#2ca02c","#d62728","#9467bd","#8c564b","#e377c2","#7f7f7f","#bcbd22","#17becf"],Jc=["#007AFF","#FF9500","#34C759","#FF3B30","#AF52DE","#FF2D55","#30B0C7","#5856D6","#A2845E","#32ADE6","#00C7BE"],qc=["#0A84FF","#FF9F0A","#30D158","#FF453A","#BF5AF2","#FF375F","#40C8E0","#5E5CE6","#AC8E68","#64D2FF","#00D1C1"],jc=["#fdfdfd","#1d1d1d","#ebce2b","#702c8c","#db6917","#96cde6","#ba1c30","#c0bd7f","#7f7e80","#5fa641","#d485b2","#4277b6","#df8461","#463397","#e1a11a","#91218c","#e8e948","#7e1510","#92ae31","#6f340d","#d32b1e","#2b3514"],Gc=["#4148cc","#db3c80","#12b5b0","#ff8c14","#848aff","#78e16e","#1e78f0","#ebcd00","#beeb3c","#7828d2","#cd5f00","#00915f"],Pa={tycho11:Rc,"tycho-dark11":Dc,"tycho-robust11":Pc,"tycho-soft11":Fc,"tycho-soft-dark11":Lc,"tycho-bold11":Oc,"tycho-bold-dark11":Bc,tableau10:zc,kelly22:jc,mathematica10:Vc,cupertino10:Jc,"cupertino-dark10":qc,spectrum12:Gc},ya=["#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"],xa=["#0b3c78","#2366a8","#4f97cf","#9bc7e4","#f7f7f7","#e88fa0","#c23c6f","#8e1d4d","#5a0c2e"],Ea=["#2c557f","#4a7fa8","#7aa8c9","#b5cfe3","#f7f7f7","#e4b0b0","#c96c72","#9b3d4f","#6b1a2b"],va=["#053061","#11458c","#1f5fa5","#337ab7","#4f94c6","#6baed6","#8bbdd9","#a6cce3","#c1dbec","#dceaf4","#f7f7f7","#fbe3d6","#f9c8b2","#f5a993","#ee8a75","#e36b58","#d64b41","#c72c33","#af212d","#971628","#7f0b23","#67001f"],Na=["#3b4cc0","#465ecf","#5070de","#5c82ea","#6f96f5","#86aafc","#9dbdff","#b6d0f3","#cfe1e8","#e6efe1","#f1f1f1","#f7f7f7","#f6e1d3","#f4cbb3","#f1b594","#ee9f76","#ea8960","#e06b53","#d24f49","#c1363f","#ae2036","#b40426"],tt=e=>e.slice().reverse(),Fa={roma:ya,"roma-reversed":tt(ya),vik:xa,"vik-reversed":tt(xa),broc:Ea,"broc-reversed":tt(Ea),rdbu:va,"rdbu-reversed":tt(va),coolwarm:Na,"coolwarm-reversed":tt(Na)},Ta=["#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"],Ia=["#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"],_a=["#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"],ka=["#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"],Sa=["#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"],Ma=["#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"],wa=["#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"],Aa=["#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"],$a=["#000000","#111111","#222222","#333333","#444444","#555555","#666666","#777777","#888888","#999999","#aaaaaa","#bbbbbb","#cccccc","#dddddd","#eeeeee","#ffffff"],Ca=["#a8780d","#b3701b","#be6828","#c75f35","#cf5643","#d54b53","#db4066","#de357b","#df2a93","#dc25ad","#d529c4","#cc34d7","#c041e5","#b24fef","#a25cf3","#9168f4","#7d73f0","#687ce8","#5285dc","#3d8bcd","#2c90bc","#2093ac","#19959c","#12978c","#0c987c","#119a69","#249a52","#409839","#5e9420","#778d12","#8b860d","#9b7f0d"],$e=e=>e.slice().reverse(),La={turbo:Ta,"turbo-reversed":$e(Ta),grey:$a,"grey-reversed":$e($a),magma:Ia,"magma-reversed":$e(Ia),inferno:_a,"inferno-reversed":$e(_a),plasma:ka,"plasma-reversed":$e(ka),viridis:Sa,"viridis-reversed":$e(Sa),cividis:Ma,"cividis-reversed":$e(Ma),rocket:wa,"rocket-reversed":$e(wa),mako:Aa,"mako-reversed":$e(Aa),"cmocean-phase":Ca,"cmocean-phase-reversed":$e(Ca)};var Oa=7,Ba=[.9999999999998099,676.5203681218851,-1259.1392167224028,771.3234287776531,-176.6150291621406,12.507343278686905,-.13857109526572012,9984369578019572e-21,15056327351493116e-23];function Ie(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 ie(e){if(e<.5)return Math.PI/(Math.sin(Math.PI*e)*ie(1-e));if(e>100)return Math.exp(Ie(e));e-=1;let n=Ba[0];for(let i=1;i<Oa+2;i++)n+=Ba[i]/(e+i);let t=e+Oa+.5;return Math.sqrt(2*Math.PI)*Math.pow(t,e+.5)*Math.exp(-t)*n}function Va(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 st(e){return 1-Dn(e)}function Dn(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 Zt=.5772156649015329,Rn=[1/6,-1/30,1/42,-1/30,5/66,-691/2730,7/6,-3617/510,43867/798,-174611/330];function Yt(e){if(!isFinite(e))return NaN;if(e<0)return Number.isInteger(e)?NaN:Yt(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<Rn.length;r++)n-=Rn[r]/(2*(r+1)*i),i*=t*t;return n}function Wt(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)-Wt(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<Rn.length;r++)n+=Rn[r]/i,i*=t*t;return n}function ir(e,n){if(!Number.isInteger(e)||e<0)return NaN;if(e===0)return Yt(n);if(e===1)return Wt(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*Cn(e)/Math.pow(u,e+1),u+=1;return a+ir(e,u)}let t=0,i=n,r=e%2===0?-1:1;for(;i<7;)t+=r*Cn(e)/Math.pow(i,e+1),i+=1;let s=e%2===0?-1:1;t+=s*Cn(e-1)/Math.pow(i,e),t+=s*Cn(e)/(2*Math.pow(i,e+1));let o=Math.pow(i,e+2);for(let a=0;a<Math.min(Rn.length,6);a++){let u=2*(a+1),l=1;for(let c=0;c<u;c++)l*=e+c;t+=s*Rn[a]*l/(Cn(u)*o),o*=i*i}return t}function Cn(e){if(e<=1)return 1;let n=1;for(let t=2;t<=e;t++)n*=t;return n}function za(e,n){return e>100||n>100||e+n>100?Math.exp(Ie(e)+Ie(n)-Ie(e+n)):ie(e)*ie(n)/ie(e+n)}function rr(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)*ie(1-e)*rr(1-e);let n=22,t=Zc(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 Zc(e){let n=new Array(e+1);n[0]=1;for(let t=1;t<=e;t++)n[t]=n[t-1]+Uc(e,t);return n}function Uc(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 Ja(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 en(e,n){return!isFinite(n)||!Number.isInteger(e)?NaN:n===0?e===0?1:0:e<0?(e=-e,e%2===0?en(e,n):-en(e,n)):n<0?e%2===0?en(e,-n):-en(e,-n):n>25+e*e/2?Wc(e,n):n<5+e?Yc(e,n):Hc(e,n)}function Yc(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 qa(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=Cn(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 Wc(e,n){let t=n-(e/2+.25)*Math.PI,[i,r]=qa(e,n);return Math.sqrt(2/(Math.PI*n))*(i*Math.cos(t)-r*Math.sin(t))}function Hc(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 Ut(e,n){if(!isFinite(n)||!Number.isInteger(e))return NaN;if(n<=0)return NaN;if(e<0)return e=-e,e%2===0?Ut(e,n):-Ut(e,n);if(n>12+e*e/4)return Kc(e,n);let t=Xc(n);if(e===0)return t;let i=Qc(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 Xc(e){let n=e/2,t=n*n,i=en(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)+Zt)+r)}function Qc(e){let n=e/2,t=n*n,i=en(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 E=1;E<=a;E++)l+=1/E;let c=l+1/(a+1),f=-Zt+l,d=-Zt+c,b=(a%2===0?1:-1)*(f+d)*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 Kc(e,n){let t=n-(e/2+.25)*Math.PI,[i,r]=qa(e,n);return Math.sqrt(2/(Math.PI*n))*(i*Math.sin(t)+r*Math.cos(t))}function un(e,n){return!isFinite(n)||!Number.isInteger(e)?NaN:n===0?e===0?1:0:(e<0&&(e=-e),n<0?e%2===0?un(e,-n):-un(e,-n):n>40?nf(e,n):ef(e,n))}function ef(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 nf(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 ja(e,n){if(!isFinite(n)||!Number.isInteger(e))return NaN;if(n<=0)return NaN;if(e<0&&(e=-e),n>40)return rf(e,n);let t=Ga(n);if(e===0)return t;let i=tf(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 Ga(e){let n=e/2,t=n*n,i=un(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)+Zt)*i+r}function tf(e){let n=un(0,e),t=un(1,e),i=Ga(e);return(1/e-t*i)/n}function rf(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 Za(e){if(!isFinite(e))return NaN;if(e>5){let a=.6666666666666666*Math.pow(e,1.5);return sf(e,a)}if(e<-5){let a=-e,u=2/3*Math.pow(a,1.5);return of(a,u)}let n=1/(Math.pow(3,2/3)*ie(2/3)),t=1/(Math.pow(3,1/3)*ie(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 sf(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 of(e,n){let t=Math.pow(e,.25);return Math.sin(n+Math.PI/4)/(Math.sqrt(Math.PI)*t)}function Ua(e){if(!isFinite(e))return NaN;if(e>5){let a=.6666666666666666*Math.pow(e,1.5);return af(e,a)}if(e<-5){let a=-e,u=2/3*Math.pow(a,1.5);return uf(a,u)}let n=1/(Math.pow(3,2/3)*ie(2/3)),t=1/(Math.pow(3,1/3)*ie(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 af(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 uf(e,n){let t=Math.pow(e,.25);return Math.cos(n+Math.PI/4)/(Math.sqrt(Math.PI)*t)}var lf=[-2991.8191940101983,708840.0452577386,-6297414862058625e-8,25489088057337637e-7,-4429795180596978e-5,3180162978765678e-4],cf=[1,281.3762688899943,45584.78108065326,5173438887700964e-9,4193202458981112e-7,22441179564534092e-6,607366389490085e-3],ff=[-49884311457357354e-24,9504280628298596e-21,-.0006451914356839651,.018884331939670384,-.20552590095501388,1],pf=[399982968972496e-26,9154392157746574e-25,12500186247959882e-23,12226278902417902e-21,.0008680295429417843,.04121420907221998,1],Ya=[.4215435550436775,.1434079197807589,.011522095507358577,.000345017939782574,46361374928786735e-22,3055689837902576e-23,10230451416490724e-26,17201074326816183e-29,13428327623306275e-32,3763297112699879e-35],Wa=[1,.7515863983533789,.11688892585919138,.0064405152650885865,.00015593440916415301,18462756734893055e-22,11269922476399903e-24,36014002958937136e-27,5887545336215784e-29,45200143407412973e-33,12544323709001127e-36],Ha=[.5044420736433832,.1971028335255234,.018764858409257526,.0006840793809153931,11513882611188428e-21,9828524436884223e-23,44534441586175015e-26,10826804113902088e-28,1375554606332618e-30,8363544356306774e-34,18695871016278324e-38],Xa=[1,1.4749575992512833,.33774898912002,.02536037414203388,.0008146791071843061,12754507566772912e-21,10431458965757199e-23,46068072851523205e-26,11027321506624028e-28,13879653125957886e-31,8391588162831187e-34,18695871016278324e-38];function ve(e,n){let t=n[0];for(let i=1;i<n.length;i++)t=t*e+n[i];return t}function ln(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*ve(i,lf)/ve(i,cf)}if(e<36){let t=e*e,i=Math.PI*t,r=1/(i*i),s=1-r*ve(r,Ya)/ve(r,Wa),o=1/i*ve(r,Ha)/ve(r,Xa),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 cn(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*ve(i,ff)/ve(i,pf)}if(e<36){let t=e*e,i=Math.PI*t,r=1/(i*i),s=1-r*ve(r,Ya)/ve(r,Wa),o=1/i*ve(r,Ha)/ve(r,Xa),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 Qa(e){return e===0?1:Math.sin(e)/e}var ot=[[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 fn(e,n){for(;e>=ot.length;){let t=ot.length,i=[1],r=ot[t-1];for(let s=1;s<t;s++)i[s]=r[s-1]+r[s];i[t]=1,ot.push(i)}return ot[e][n]}function eu(e){let n=0,t=0;for(let i of e)n+=i,t++;return t===0?NaN:n/t}function pn(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 sr(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 or(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 nu(e){return Math.sqrt(sr(e))}function tu(e){return Math.sqrt(or(e))}function iu(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 ru(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 su(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 ou(e){let n=[...e].sort((o,a)=>o-a),t=Math.floor(n.length/2),i=pn(n.slice(0,t)),r=pn(n),s=pn(n.slice(t));return[i,r,s]}function au(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 pn(r)-pn(i)}function yf(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 uu(e,n,t,i=1e5){let r=0,s=0;if(n===-1/0&&t===1/0)for(let m=0;m<i;m++){let b=Math.random(),E=Math.tan(Math.PI*(b-.5)),T=e(E)*Math.PI*(1+E*E);r+=T,s+=T*T}else if(n===-1/0)for(let m=0;m<i;m++){let b=Math.random(),E=t+Math.log(b),T=e(E)/b;r+=T,s+=T*T}else if(t===1/0)for(let m=0;m<i;m++){let b=Math.random(),E=n-Math.log(b),T=e(E)/b;r+=T,s+=T*T}else for(let m=0;m<i;m++){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,f=u*l;return yf(c,f)}var ar={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]},ur={Abs:(e,n)=>g.isComplexValued(e[0])?`_SYS.cabs(${n(e[0])})`:g.isNonNegative(e[0])?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))){let o=e.map(Z);if(o.every(u=>u!==void 0))return String(o.reduce((u,l)=>u+l,0));let a=e.filter(u=>Z(u)!==0);return a.length===0?"0":a.length===1?n(a[0]):`(${a.map(u=>n(u)).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:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`Math.ceil(${n(e[0])})`,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:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`Math.floor(${n(e[0])})`,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)=>Nf(e,n,t),LCM:"_SYS.lcm",Product:(e,n,t)=>cu("Product",e,n,t),Sum:(e,n,t)=>cu("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=Z(t),s=Z(i);if(r!==void 0&&s!==void 0)return String(Math.pow(r,s));if(s===0)return"1";if(s===1)return n(t);if(s===2&&(k(t)||L(t))){let o=n(t);return`(${o} * ${o})`}return s===-1?`(1 / (${n(t)}))`:s===.5?`Math.sqrt(${n(t)})`:s===1/3?`Math.cbrt(${n(t)})`:s===-.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}
|
|
42
|
+
return ${m};
|
|
43
|
+
})()`}static isComplexValued(n){if(O(n))return n.im!==0;if(S(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.type;return t.matches("complex")&&!t.matches("real")?!0:t.matches("real")?!1:n.ops.some(i=>e.isComplexValued(i))}return!1}static isIntegerValued(n){if(O(n))return n.im===0&&Number.isInteger(n.re);let t=n.type;return t?t.matches("integer"):!1}static isNonNegative(n){return O(n)?n.im===0&&n.re>=0:n.isNonNegative===!0}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 it(e){return typeof e=="object"&&e!==null}function ha(e){return typeof e=="number"&&Number.isFinite(e)}function yc(e){if(!it(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(!ha(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 xc(e,n){if(n!==void 0&&(!Array.isArray(n)||n.length!==2||typeof n[0]!="string"||!ha(n[1])))throw new Error(`Invalid compilation option "operators.${e}": expected [string, number]`)}function Ec(e){if(e!==void 0&&typeof e!="function"){if(!it(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))xc(n,t)}}function vc(e){if(e!==void 0){if(!it(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 Nc(e){if(e!==void 0){if(!it(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 Tc(e){if(e!==void 0&&!Array.isArray(e))throw new Error('Invalid compilation option "imports": expected an array')}function ga(e){if(e!==void 0){if(!it(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&&yc(e.target),Ec(e.operators),vc(e.functions),Nc(e.vars),Tc(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 Ic(e,n){ga(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){console.warn(`Compilation fallback for "${e.operator}" (target: ${n?.to??"javascript"}): ${t.message}`);let i=e.engine,r=(s=>{i.pushScope();try{if(s&&typeof s=="object")for(let[o,a]of Object.entries(s))i.assign(o,a);return e.evaluate().re}finally{i.popScope()}});return{target:n?.to??"javascript",success:!1,code:"",calling:"expression",run:r}}throw t}}function oe(e){let n=e.toString();return!n.includes(".")&&!n.includes("e")&&!n.includes("E")?`${n}.0`:n}function U(e){if(!O(e)||e.im!==0)return;let n=e.re;if(isFinite(n))return n}var kc=/^-?\d+(\.\d+)?$/;function Ke(e,n,t){let i=t==="+"?0:1,r=null,s=[];for(let o of e)if(kc.test(o)){let a=parseFloat(o);if(t==="*"&&a===0)return"0.0";r===null?r=a:r=t==="+"?r+a:r*a}else s.push(o);return r!==null&&r!==i&&s.unshift(oe(r)),s.length===0?r!==null?oe(r):n:s.length===1?s[0]:s.join(t==="+"?" + ":" * ")}function ba(e,n){if(S(e,"ImaginaryUnit"))return{re:null,im:"1.0"};if(O(e)&&e.im!==0){let t=e.re,i=e.im;return{re:t!==0?oe(t):null,im:oe(i)}}if(h(e,"Multiply")){let t=e.ops,i=t.findIndex(r=>S(r,"ImaginaryUnit")||O(r)&&r.re===0&&r.im!==0);if(i>=0){let r=t[i],s=S(r,"ImaginaryUnit")?1:r.im,o=t.filter((l,c)=>c!==i);if(o.length===0)return{re:null,im:oe(s)};let a=o.map(l=>n(l));return s!==1&&a.unshift(oe(s)),{re:null,im:Ke(a,"1.0","*")}}}return g.isComplexValued(e)?null:{re:n(e),im:null}}function Yi(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 Hi(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 nr(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 tr(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 Sc(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 jt(e){return typeof e=="number"?{r:e>>>24&255,g:e>>>16&255,b:e>>>8&255,alpha:(e&255)/255}:typeof e=="string"?Sc(e):"C"in e?Cn(e):"a"in e&&"b"in e?st(e):e}function ya(e){let n=jt(e),t=n.alpha!==void 0?Re(n.alpha*255):255;return(Re(n.r)<<24|Re(n.g)<<16|Re(n.b)<<8|t)>>>0}function Re(e){return e<0?0:e>255?255:Math.round(e)}function er(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 Pa(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 Gt(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[Yi(a),Yi(u),Yi(l)]}function Wi(e){let[n,t,i]=e;return n>=0&&n<=1&&t>=0&&t<=1&&i>=0&&i<=1}function Xi(e,n){let[t,i,r]=e;return t=Re(t*255),i=Re(i*255),r=Re(r*255),n!==void 0?{r:t,g:i,b:r,alpha:n}:{r:t,g:i,b:r}}function st(e){let[n,t,i]=Gt(e);if(Wi([n,t,i]))return Xi([n,t,i],e.alpha);let r=Pa(e);if(r.C=0,[n,t,i]=Gt(er(r)),!Wi([n,t,i]))return Xi([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]=Gt(er(r)),Wi([n,t,i])?s=a:o=a;return Xi([n,t,i],e.alpha)}function Cn(e){return st(er(e))}function ir(e){let[n,t,i]=[e.r,e.g,e.b],r=Hi(n/255),s=Hi(t/255),o=Hi(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 en(e){return Pa(ir(e))}function Qi(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]=Gt({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=Cn({L:i,C:n,H:t});return(Re(r.r)<<24|Re(r.g)<<16|Re(r.b)<<8|255)>>>0}function _c(e){let{l:n,c:t,h:i}=Ut(e);return $n(n+2.8,t+.002,i+.46)}function Ut(e){let n=e>>>24&255,t=e>>>16&255,i=e>>>8&255,r=en({r:n,g:t,b:i});return{l:r.L*100,c:r.C,h:r.H<0?r.H+360:r.H}}function Ki(e,n,t){let{l:i,c:r,h:s}=Ut(e),{l:o,c:a,h:u}=Ut(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 Mc(e,n=.1){let a=.45,u=0;for(let b=.45;b>=.35;b-=.01){let v=Qi(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=Qi(b,e);if(v>=.15||v>u*1.2){a=b,u=Math.min(.15,v);break}}let l=.96,c=.02,p=Qi(.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 wc(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}=Ut(r),l=r&255,{darkest:c,lightest:p}=Mc(u);i=c&4294967040|l,s=p&4294967040|l}if(!r&&typeof e=="object"&&!e.mid&&(r=Ki(i,s,.5)),t<=500){let u=t/500,l=u*u*(3-2*u);return Ki(s,r,l)}let o=(t-500)/500,a=o*o*(3-2*o);return Ki(r,i,a)}var Ac=[{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 An({lightness:e,chroma:n,hue:t}){return $n(e,n,t)}function $c(e){let{mid:n,lightest:t,darkest:i}=e.colors;if(t&&i&&n)return{lightest:An(t),mid:An(n),darkest:An(i)};if(t&&i)return{lightest:An(t),darkest:An(i)};if(n)return An(n);throw new Error(`Color scale preset "${e.id}" is missing required anchors.`)}var zt=null;function Cc(){if(!zt){zt=Object.create(null);for(let e of Ac)zt[e.id]=$c(e)}return zt}var xa={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 ot(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=st({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}=nr(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=Cc()[a[1]];if(u){let l=wc(u,parseInt(a[2],10));return n?_c(l):l}}return t in xa?ot(xa[t]):(console.warn(`parseColor: unrecognized color "${e}"`),0)}function Fa(e,n){let t=ot(e,n);return[(t>>>24&255)/255,(t>>>16&255)/255,(t>>>8&255)/255]}function Zt(e,n){let t=jt(e),i=jt(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(Z){return Z>=u?Z:Z+(u-Z)**l}function w(Z){return(Z<0?-1:1)*Math.pow(Math.abs(Z),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),B,Q;return Math.abs(P-R)<p?Q=0:P>R?(B=P**r-R**s,Q=B*m):(B=P**a-R**o,Q=B*b),Math.abs(Q)<c?0:Q>0?Q-v:Q+d}function rr(e){let n,t,i;typeof e!="object"||!("bg"in e)?(n=jt(e),t="#ffffff",i="#000000"):(n=e.bg,t=e.fg1,i=e.fg2);let r=Math.abs(Zt(t,n)),s=Math.abs(Zt(i,n));return r>=s?ya(t):ya(i)}var Rc=["#4e79a7","#f28e2b","#59a14f","#e15759","#b07aa1","#9c755f","#ff9da7","#edc948","#76b7b2","#6b8fd6","#c07bc4"],Dc=["#78a6d9","#ffae54","#7ddc7a","#ff7a7a","#d29be0","#c49a84","#ffb3bf","#ffe066","#7fd6d0","#8fb4ff","#e199eb"],Pc=["#4e79a7","#f28e2b","#2ca58d","#d13a3c","#b07aa1","#9c755f","#ff9da7","#e3c13b","#5fb8b2","#6b8fd6","#c07bc4"],Fc=["#8fb1d4","#f6b878","#8ecf86","#f08a8b","#d3a9cc","#c3a492","#ffc6cc","#f3e08a","#a8d8d4","#a9c0ea","#e0b4e4"],Oc=["#78a6d9","#ffae54","#7ddc7a","#ff7a7a","#d29be0","#c49a84","#ffb3bf","#ffe066","#7fd6d0","#8fb4ff","#e199eb"],Lc=["#2f6fb0","#ff7a00","#2fa23a","#e02f2f","#9b4db5","#7f4f38","#ff6f86","#f2c200","#2daaa3","#4c79e0","#b84ac6"],Bc=["#4f93ff","#ff8c1a","#33c94a","#ff4f4f","#b86bff","#a86a4a","#ff7f9e","#ffd400","#2ec9c1","#6f9bff","#cc5bd9"],Vc=["#5E81B5","#E19C24","#8FB131","#EB6235","#8778B3","#C56E1A","#5E9EC9","#B23A3A","#4C9F70","#C979B7"],Jc=["#1f77b4","#ff7f0e","#2ca02c","#d62728","#9467bd","#8c564b","#e377c2","#7f7f7f","#bcbd22","#17becf"],qc=["#007AFF","#FF9500","#34C759","#FF3B30","#AF52DE","#FF2D55","#30B0C7","#5856D6","#A2845E","#32ADE6","#00C7BE"],zc=["#0A84FF","#FF9F0A","#30D158","#FF453A","#BF5AF2","#FF375F","#40C8E0","#5E5CE6","#AC8E68","#64D2FF","#00D1C1"],Gc=["#fdfdfd","#1d1d1d","#ebce2b","#702c8c","#db6917","#96cde6","#ba1c30","#c0bd7f","#7f7e80","#5fa641","#d485b2","#4277b6","#df8461","#463397","#e1a11a","#91218c","#e8e948","#7e1510","#92ae31","#6f340d","#d32b1e","#2b3514"],jc=["#4148cc","#db3c80","#12b5b0","#ff8c14","#848aff","#78e16e","#1e78f0","#ebcd00","#beeb3c","#7828d2","#cd5f00","#00915f"],Oa={tycho11:Rc,"tycho-dark11":Dc,"tycho-robust11":Pc,"tycho-soft11":Fc,"tycho-soft-dark11":Oc,"tycho-bold11":Lc,"tycho-bold-dark11":Bc,tableau10:Jc,kelly22:Gc,mathematica10:Vc,cupertino10:qc,"cupertino-dark10":zc,spectrum12:jc},Ea=["#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"],va=["#0b3c78","#2366a8","#4f97cf","#9bc7e4","#f7f7f7","#e88fa0","#c23c6f","#8e1d4d","#5a0c2e"],Na=["#2c557f","#4a7fa8","#7aa8c9","#b5cfe3","#f7f7f7","#e4b0b0","#c96c72","#9b3d4f","#6b1a2b"],Ta=["#053061","#11458c","#1f5fa5","#337ab7","#4f94c6","#6baed6","#8bbdd9","#a6cce3","#c1dbec","#dceaf4","#f7f7f7","#fbe3d6","#f9c8b2","#f5a993","#ee8a75","#e36b58","#d64b41","#c72c33","#af212d","#971628","#7f0b23","#67001f"],Ia=["#3b4cc0","#465ecf","#5070de","#5c82ea","#6f96f5","#86aafc","#9dbdff","#b6d0f3","#cfe1e8","#e6efe1","#f1f1f1","#f7f7f7","#f6e1d3","#f4cbb3","#f1b594","#ee9f76","#ea8960","#e06b53","#d24f49","#c1363f","#ae2036","#b40426"],rt=e=>e.slice().reverse(),La={roma:Ea,"roma-reversed":rt(Ea),vik:va,"vik-reversed":rt(va),broc:Na,"broc-reversed":rt(Na),rdbu:Ta,"rdbu-reversed":rt(Ta),coolwarm:Ia,"coolwarm-reversed":rt(Ia)},ka=["#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"],Sa=["#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"],_a=["#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"],Ma=["#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"],wa=["#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"],Aa=["#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"],$a=["#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"],Ca=["#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"],Ra=["#000000","#111111","#222222","#333333","#444444","#555555","#666666","#777777","#888888","#999999","#aaaaaa","#bbbbbb","#cccccc","#dddddd","#eeeeee","#ffffff"],Da=["#a8780d","#b3701b","#be6828","#c75f35","#cf5643","#d54b53","#db4066","#de357b","#df2a93","#dc25ad","#d529c4","#cc34d7","#c041e5","#b24fef","#a25cf3","#9168f4","#7d73f0","#687ce8","#5285dc","#3d8bcd","#2c90bc","#2093ac","#19959c","#12978c","#0c987c","#119a69","#249a52","#409839","#5e9420","#778d12","#8b860d","#9b7f0d"],Ce=e=>e.slice().reverse(),Ba={turbo:ka,"turbo-reversed":Ce(ka),grey:Ra,"grey-reversed":Ce(Ra),magma:Sa,"magma-reversed":Ce(Sa),inferno:_a,"inferno-reversed":Ce(_a),plasma:Ma,"plasma-reversed":Ce(Ma),viridis:wa,"viridis-reversed":Ce(wa),cividis:Aa,"cividis-reversed":Ce(Aa),rocket:$a,"rocket-reversed":Ce($a),mako:Ca,"mako-reversed":Ce(Ca),"cmocean-phase":Da,"cmocean-phase-reversed":Ce(Da)};var Va=7,Ja=[.9999999999998099,676.5203681218851,-1259.1392167224028,771.3234287776531,-176.6150291621406,12.507343278686905,-.13857109526572012,9984369578019572e-21,15056327351493116e-23];function Ie(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 ie(e){if(e<.5)return Math.PI/(Math.sin(Math.PI*e)*ie(1-e));if(e>100)return Math.exp(Ie(e));e-=1;let n=Ja[0];for(let i=1;i<Va+2;i++)n+=Ja[i]/(e+i);let t=e+Va+.5;return Math.sqrt(2*Math.PI)*Math.pow(t,e+.5)*Math.exp(-t)*n}function qa(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 at(e){return 1-Pn(e)}function Pn(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 Yt=.5772156649015329,Dn=[1/6,-1/30,1/42,-1/30,5/66,-691/2730,7/6,-3617/510,43867/798,-174611/330];function Wt(e){if(!isFinite(e))return NaN;if(e<0)return Number.isInteger(e)?NaN:Wt(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<Dn.length;r++)n-=Dn[r]/(2*(r+1)*i),i*=t*t;return n}function Xt(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)-Xt(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<Dn.length;r++)n+=Dn[r]/i,i*=t*t;return n}function sr(e,n){if(!Number.isInteger(e)||e<0)return NaN;if(e===0)return Wt(n);if(e===1)return Xt(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*Rn(e)/Math.pow(u,e+1),u+=1;return a+sr(e,u)}let t=0,i=n,r=e%2===0?-1:1;for(;i<7;)t+=r*Rn(e)/Math.pow(i,e+1),i+=1;let s=e%2===0?-1:1;t+=s*Rn(e-1)/Math.pow(i,e),t+=s*Rn(e)/(2*Math.pow(i,e+1));let o=Math.pow(i,e+2);for(let a=0;a<Math.min(Dn.length,6);a++){let u=2*(a+1),l=1;for(let c=0;c<u;c++)l*=e+c;t+=s*Dn[a]*l/(Rn(u)*o),o*=i*i}return t}function Rn(e){if(e<=1)return 1;let n=1;for(let t=2;t<=e;t++)n*=t;return n}function za(e,n){return e>100||n>100||e+n>100?Math.exp(Ie(e)+Ie(n)-Ie(e+n)):ie(e)*ie(n)/ie(e+n)}function or(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)*ie(1-e)*or(1-e);let n=22,t=Uc(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 Uc(e){let n=new Array(e+1);n[0]=1;for(let t=1;t<=e;t++)n[t]=n[t-1]+Zc(e,t);return n}function Zc(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 Ga(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 nn(e,n){return!isFinite(n)||!Number.isInteger(e)?NaN:n===0?e===0?1:0:e<0?(e=-e,e%2===0?nn(e,n):-nn(e,n)):n<0?e%2===0?nn(e,-n):-nn(e,-n):n>25+e*e/2?Hc(e,n):n<5+e?Yc(e,n):Wc(e,n)}function Yc(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 ja(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=Rn(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 Hc(e,n){let t=n-(e/2+.25)*Math.PI,[i,r]=ja(e,n);return Math.sqrt(2/(Math.PI*n))*(i*Math.cos(t)-r*Math.sin(t))}function Wc(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 Ht(e,n){if(!isFinite(n)||!Number.isInteger(e))return NaN;if(n<=0)return NaN;if(e<0)return e=-e,e%2===0?Ht(e,n):-Ht(e,n);if(n>12+e*e/4)return Kc(e,n);let t=Xc(n);if(e===0)return t;let i=Qc(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 Xc(e){let n=e/2,t=n*n,i=nn(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)+Yt)+r)}function Qc(e){let n=e/2,t=n*n,i=nn(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=-Yt+l,m=-Yt+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 Kc(e,n){let t=n-(e/2+.25)*Math.PI,[i,r]=ja(e,n);return Math.sqrt(2/(Math.PI*n))*(i*Math.sin(t)+r*Math.cos(t))}function ln(e,n){return!isFinite(n)||!Number.isInteger(e)?NaN:n===0?e===0?1:0:(e<0&&(e=-e),n<0?e%2===0?ln(e,-n):-ln(e,-n):n>40?nf(e,n):ef(e,n))}function ef(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 nf(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 Ua(e,n){if(!isFinite(n)||!Number.isInteger(e))return NaN;if(n<=0)return NaN;if(e<0&&(e=-e),n>40)return rf(e,n);let t=Za(n);if(e===0)return t;let i=tf(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 Za(e){let n=e/2,t=n*n,i=ln(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)+Yt)*i+r}function tf(e){let n=ln(0,e),t=ln(1,e),i=Za(e);return(1/e-t*i)/n}function rf(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 Ya(e){if(!isFinite(e))return NaN;if(e>5){let a=.6666666666666666*Math.pow(e,1.5);return sf(e,a)}if(e<-5){let a=-e,u=2/3*Math.pow(a,1.5);return of(a,u)}let n=1/(Math.pow(3,2/3)*ie(2/3)),t=1/(Math.pow(3,1/3)*ie(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 sf(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 of(e,n){let t=Math.pow(e,.25);return Math.sin(n+Math.PI/4)/(Math.sqrt(Math.PI)*t)}function Ha(e){if(!isFinite(e))return NaN;if(e>5){let a=.6666666666666666*Math.pow(e,1.5);return af(e,a)}if(e<-5){let a=-e,u=2/3*Math.pow(a,1.5);return uf(a,u)}let n=1/(Math.pow(3,2/3)*ie(2/3)),t=1/(Math.pow(3,1/3)*ie(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 af(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 uf(e,n){let t=Math.pow(e,.25);return Math.cos(n+Math.PI/4)/(Math.sqrt(Math.PI)*t)}var lf=[-2991.8191940101983,708840.0452577386,-6297414862058625e-8,25489088057337637e-7,-4429795180596978e-5,3180162978765678e-4],cf=[1,281.3762688899943,45584.78108065326,5173438887700964e-9,4193202458981112e-7,22441179564534092e-6,607366389490085e-3],ff=[-49884311457357354e-24,9504280628298596e-21,-.0006451914356839651,.018884331939670384,-.20552590095501388,1],pf=[399982968972496e-26,9154392157746574e-25,12500186247959882e-23,12226278902417902e-21,.0008680295429417843,.04121420907221998,1],Wa=[.4215435550436775,.1434079197807589,.011522095507358577,.000345017939782574,46361374928786735e-22,3055689837902576e-23,10230451416490724e-26,17201074326816183e-29,13428327623306275e-32,3763297112699879e-35],Xa=[1,.7515863983533789,.11688892585919138,.0064405152650885865,.00015593440916415301,18462756734893055e-22,11269922476399903e-24,36014002958937136e-27,5887545336215784e-29,45200143407412973e-33,12544323709001127e-36],Qa=[.5044420736433832,.1971028335255234,.018764858409257526,.0006840793809153931,11513882611188428e-21,9828524436884223e-23,44534441586175015e-26,10826804113902088e-28,1375554606332618e-30,8363544356306774e-34,18695871016278324e-38],Ka=[1,1.4749575992512833,.33774898912002,.02536037414203388,.0008146791071843061,12754507566772912e-21,10431458965757199e-23,46068072851523205e-26,11027321506624028e-28,13879653125957886e-31,8391588162831187e-34,18695871016278324e-38];function ve(e,n){let t=n[0];for(let i=1;i<n.length;i++)t=t*e+n[i];return t}function cn(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*ve(i,lf)/ve(i,cf)}if(e<36){let t=e*e,i=Math.PI*t,r=1/(i*i),s=1-r*ve(r,Wa)/ve(r,Xa),o=1/i*ve(r,Qa)/ve(r,Ka),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 fn(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*ve(i,ff)/ve(i,pf)}if(e<36){let t=e*e,i=Math.PI*t,r=1/(i*i),s=1-r*ve(r,Wa)/ve(r,Xa),o=1/i*ve(r,Qa)/ve(r,Ka),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 eu(e){return e===0?1:Math.sin(e)/e}var ut=[[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 pn(e,n){for(;e>=ut.length;){let t=ut.length,i=[1],r=ut[t-1];for(let s=1;s<t;s++)i[s]=r[s-1]+r[s];i[t]=1,ut.push(i)}return ut[e][n]}function tu(e){let n=0,t=0;for(let i of e)n+=i,t++;return t===0?NaN:n/t}function mn(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 ar(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 ur(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 iu(e){return Math.sqrt(ar(e))}function ru(e){return Math.sqrt(ur(e))}function su(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 ou(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 au(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 uu(e){let n=[...e].sort((o,a)=>o-a),t=Math.floor(n.length/2),i=mn(n.slice(0,t)),r=mn(n),s=mn(n.slice(t));return[i,r,s]}function lu(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 mn(r)-mn(i)}function yf(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 cu(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 yf(c,p)}var lr={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]},cr={Abs:(e,n)=>g.isComplexValued(e[0])?`_SYS.cabs(${n(e[0])})`:g.isNonNegative(e[0])?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))){let o=e.map(U);if(o.every(u=>u!==void 0))return String(o.reduce((u,l)=>u+l,0));let a=e.filter(u=>U(u)!==0);return a.length===0?"0":a.length===1?n(a[0]):`(${a.map(u=>n(u)).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:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`Math.ceil(${n(e[0])})`,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:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`Math.floor(${n(e[0])})`,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)=>Nf(e,n,t),LCM:"_SYS.lcm",Product:(e,n,t)=>pu("Product",e,n,t),Sum:(e,n,t)=>pu("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=U(t),s=U(i);if(r!==void 0&&s!==void 0)return String(Math.pow(r,s));if(s===0)return"1";if(s===1)return n(t);if(s===2&&(S(t)||O(t))){let o=n(t);return`(${o} * ${o})`}return s===-1?`(1 / (${n(t)}))`:s===.5?`Math.sqrt(${n(t)})`:s===1/3?`Math.cbrt(${n(t)})`:s===-.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
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");if(n===null)return`Math.sqrt(${t(e)})`;let i=Z(e),r=Z(n);return i!==void 0&&r!==void 0&&r!==0?String(Math.pow(i,1/r)):r===2?`Math.sqrt(${t(e)})`:r===3?`Math.cbrt(${t(e)})`:r!==void 0?`Math.pow(${t(e)}, ${1/r})`:`Math.pow(${t(e)}, 1 / (${t(n)}))`},Random:"Math.random",Round:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`Math.round(${n(e[0])})`,Square:(e,n)=>{let t=e[0];if(t===null)throw new Error("Square: no argument");let i=Z(t);if(i!==void 0)return String(i*i);if(k(t)){let r=n(t);return`(${r} * ${r})`}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)=>{if(g.isComplexValued(e[0]))return`_SYS.csqrt(${n(e[0])})`;let t=Z(e[0]);return t!==void 0?String(Math.sqrt(t)):`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 g.isIntegerValued(e)&&g.isIntegerValued(n)&&g.isNonNegative(e)?`(${i} % ${r})`:`((${i} % ${r}) + ${r}) % ${r}`},Truncate:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`Math.trunc(${n(e[0])})`,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)}))`},Divide:([e,n],t)=>{if(e===null||n===null)throw new Error("Divide: missing argument");let i=g.isComplexValued(e),r=g.isComplexValued(n);if(!i&&!r){let s=Z(e),o=Z(n);return s!==void 0&&o!==void 0&&o!==0?String(s/o):o===1?t(e):`(${t(e)} / ${t(n)})`}return 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");if(!g.isComplexValued(e)){let t=Z(e);return t!==void 0?String(-t):`(-${n(e)})`}return`_SYS.cneg(${n(e)})`},Multiply:(e,n)=>{if(e.length===1)return n(e[0]);if(!e.some(o=>g.isComplexValued(o))){if(e.some(u=>Z(u)===0))return"0";let o=e.map(Z);if(o.every(u=>u!==void 0))return String(o.reduce((u,l)=>u*l,1));let a=e.filter(u=>Z(u)!==1);return a.length===0?"1":a.length===1?n(a[0]):`(${a.map(u=>n(u)).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",Mandelbrot:([e,n],t)=>{if(e===null||n===null)throw new Error("Mandelbrot: missing arguments");return`_SYS.mandelbrot(${t(e)}, ${t(n)})`},Julia:([e,n,t],i)=>{if(e===null||n===null||t===null)throw new Error("Julia: missing arguments");return`_SYS.julia(${i(e)}, ${i(n)}, ${i(t)})`},Binomial:(e,n)=>`_SYS.binomial(${n(e[0])}, ${n(e[1])})`,Fibonacci:"_SYS.fibonacci",Real:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).re`:n(e[0]),Imaginary:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).im`:"0",Argument:(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 Ze(e){if(typeof e=="string"){let t=rt(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 lr(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 xf={color(e){return lr(rt(e))},colorToString(e,n){let t=Ze(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=er(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=Ke(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=Ze(e),r=Ze(n);t=Math.max(0,Math.min(1,t));let s=Ke(i),o=Ke(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=$n({L:s.L+(o.L-s.L)*t,C:s.C+(o.C-s.C)*t,H:u}),c=l.r/255,f=l.g/255,d=l.b/255,m=i.alpha??1,b=r.alpha??1,E=m+(b-m)*t;return Math.abs(E-1)>1e-4?[c,f,d,E]:[c,f,d]},colorContrast(e,n){return Gt(Ze(e),Ze(n))},contrastingColor(e,n,t){let i=Ze(e);return lr(n!==void 0&&t!==void 0?tr({bg:i,fg1:Ze(n),fg2:Ze(t)}):tr(i))},colorToColorspace(e,n){let t=Ze(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=er(t.r,t.g,t.b);r=[s.h,s.s,s.l];break}case"oklch":{let s=Ke(t);r=[s.L,s.C,s.H];break}case"oklab":case"lab":{let s=nr(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={...La,...Pa,...Fa}[e];if(!i)throw new Error(`Unknown palette: ${e}`);let r=i.map(o=>Da(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=Ke(s),u=Ke(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 f=$n({L:a.L+(u.L-a.L)*r,C:a.C+(u.C-a.C)*r,H:c});return[f.r/255,f.g/255,f.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=Ki(t,i,r);o=[a.r/255,a.g/255,a.b/255];break}case"oklch":{let a=$n({L:t,C:i,H:r});o=[a.r/255,a.g/255,a.b/255];break}case"oklab":case"lab":{let a=it({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}},fu={chop:Jn,factorial:Vn,factorial2:zn,gamma:ie,gcd:ke,heaviside:e=>e<0?0:e===0?.5:1,integrate:(e,n,t)=>uu(e,n,t,1e7).estimate,lcm:Ue,lngamma:Ie,limit:bt,mean:eu,median:pn,variance:sr,populationVariance:or,standardDeviation:nu,populationStandardDeviation:tu,kurtosis:iu,skewness:ru,mode:su,quartiles:ou,interquartileRange:au,erf:Dn,erfc:st,erfInv:Va,beta:za,digamma:Yt,trigamma:Wt,polygamma:ir,zeta:rr,lambertW:Ja,besselJ:en,besselY:Ut,besselI:un,besselK:ja,airyAi:Za,airyBi:Ua,sinc:Qa,fresnelS:ln,fresnelC:cn,mandelbrot:(e,n)=>{let t=0,i=0,r=typeof e=="number"?e:e.re,s=typeof e=="number"?0:e.im,o=Math.round(n);for(let a=0;a<o;a++){let u=t*t-i*i+r;i=2*t*i+s,t=u;let l=t*t+i*i;if(l>4){let c=(a-Math.log2(Math.log2(l))+4)/o;return Math.max(0,Math.min(1,c))}}return 1},julia:(e,n,t)=>{let i=typeof e=="number"?e:e.re,r=typeof e=="number"?0:e.im,s=typeof n=="number"?n:n.re,o=typeof n=="number"?0:n.im,a=Math.round(t);for(let u=0;u<a;u++){let l=i*i-r*r+s;r=2*i*r+o,i=l;let c=i*i+r*r;if(c>4){let f=(u-Math.log2(Math.log2(c))+4)/a;return Math.max(0,Math.min(1,f))}}return 1},binomial:fn,fibonacci:dr,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}),...xf},fr=class extends Function{SYS=fu;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]})}},Ht=class extends Function{SYS=fu;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]})}},pr=class{getOperators(){return ar}getFunctions(){return ur}createTarget(n={}){return{language:"javascript",operators:t=>ar[t],functions:t=>ur[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
|
-
`),
|
|
47
|
-
`,
|
|
48
|
-
`,
|
|
49
|
-
`)}function hr(e){let n=e.hints?.viewport?.radius;return n===void 0||n>1e-6?"single":n>1e-14?"double":"perturbation"}var _f={Add:(e,n,t)=>{if(e.length===0)return"0.0";if(e.length===1)return n(e[0]);if(!e.some(l=>g.isComplexValued(l)))return Qe(e.map(l=>n(l)),"0.0","+");let r=e.map(l=>ha(l,n));if(r.some(l=>l===null)){let l=Ne(t);return e.map(c=>{let f=n(c);return g.isComplexValued(c)?f:`${l}(${f}, 0.0)`}).join(" + ")}let s=[],o=[];for(let l of r)l.re!==null&&s.push(l.re),l.im!==null&&o.push(l.im);let a=Qe(s,"0.0","+"),u=Qe(o,"0.0","+");return`${Ne(t)}(${a}, ${u})`},Multiply:(e,n,t)=>{if(e.length===0)return"1.0";if(e.length===1)return n(e[0]);if(!e.some(l=>g.isComplexValued(l)))return Qe(e.map(l=>n(l)),"1.0","*");let r=e.findIndex(l=>k(l,"ImaginaryUnit")||L(l)&&l.re===0&&l.im!==0);if(r>=0){let l=e[r],c=k(l,"ImaginaryUnit")?1:l.im,f=e.filter((E,T)=>T!==r),d=Ne(t);if(f.length===0)return`${d}(0.0, ${oe(c)})`;let m=f.map(E=>n(E));c!==1&&m.unshift(oe(c));let b=Qe(m,"1.0","*");return`${d}(0.0, ${b})`}let s=[],o=[];for(let l of e)g.isComplexValued(l)?o.push(n(l)):s.push(n(l));let a=Qe(s,"1.0","*"),u=o[0];for(let l=1;l<o.length;l++)u=`_gpu_cmul(${u}, ${o[l]})`;return a!=="1.0"&&(u=`(${a} * ${u})`),u},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){let a=Z(e[0]),u=Z(e[1]);return a!==void 0&&u!==void 0&&u!==0?oe(a/u):u===1?n(e[0]):`${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(${Ne(t)}(${n(e[0])}, 0.0), ${n(e[1])})`},Negate:([e],n,t)=>{if(e===null)throw new Error("Negate: no argument");let i=Z(e);return i!==void 0?oe(-i):L(e)&&e.im!==0?`${Ne(t)}(${oe(-e.re)}, ${oe(-e.im)})`:k(e,"ImaginaryUnit")?`${Ne(t)}(0.0, -1.0)`:`(-${n(e)})`},Abs:(e,n)=>g.isComplexValued(e[0])?`length(${n(e[0])})`:g.isNonNegative(e[0])?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:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`ceil(${n(e[0])})`,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:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`floor(${n(e[0])})`,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(k(i,"ExponentialE"))return`_gpu_cexp(${n(r)})`;let a=Ne(t),u=g.isComplexValued(i)?n(i):`${a}(${n(i)}, 0.0)`,l=g.isComplexValued(r)?n(r):`${a}(${n(r)}, 0.0)`;return`_gpu_cpow(${u}, ${l})`}let s=Z(i),o=Z(r);if(s!==void 0&&o!==void 0)return oe(Math.pow(s,o));if(o===0)return"1.0";if(o===1)return n(i);if(o===2&&(k(i)||L(i))){let a=n(i);return`(${a} * ${a})`}return o===-1?`(1.0 / ${n(i)})`:o===.5?`sqrt(${n(i)})`:`pow(${n(i)}, ${n(r)})`},Radians:"radians",Round:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`round(${n(e[0])})`,Sign:"sign",Sin:(e,n)=>g.isComplexValued(e[0])?`_gpu_csin(${n(e[0])})`:`sin(${n(e[0])})`,Smoothstep:"smoothstep",Sqrt:(e,n)=>{if(g.isComplexValued(e[0]))return`_gpu_csqrt(${n(e[0])})`;let t=Z(e[0]);return t!==void 0?oe(Math.sqrt(t)):`sqrt(${n(e[0])})`},Step:"step",Tan:(e,n)=>g.isComplexValued(e[0])?`_gpu_ctan(${n(e[0])})`:`tan(${n(e[0])})`,Truncate:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`trunc(${n(e[0])})`,Real:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).x`:n(e[0]),Imaginary:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).y`:"0.0",Argument:(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=Ne(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(${Ne(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(${Ne(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(${Ne(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(${Ne(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");if(k(e)||L(e)){let t=n(e);return`(${t} * ${t})`}return`pow(${n(e)}, 2.0)`},Root:([e,n],t)=>{if(e===null)throw new Error("Root: no argument");if(n==null)return`sqrt(${t(e)})`;let i=Z(n);if(i===2)return`sqrt(${t(e)})`;let r=Z(e);return r!==void 0&&i!==void 0?oe(Math.pow(r,1/i)):`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=hu(n,t,i),s=hr(i);return s==="double"?`_fractal_mandelbrot_dp(vec4(${t(e)}, vec2(0.0)), ${r})`:s==="perturbation"?`_fractal_mandelbrot_pt(${t(e)}, ${r})`:`_fractal_mandelbrot(${t(e)}, ${r})`},Julia:([e,n,t],i,r)=>{if(e===null||n===null||t===null)throw new Error("Julia: missing arguments");let s=hu(t,i,r),o=hr(r);if(o==="double"){let a=i(e),u=i(n);return`_fractal_julia_dp(vec4(${a}, vec2(0.0)), vec4(${u}, vec2(0.0)), ${s})`}if(o==="perturbation"){let a=i(e),u=i(n);return`_fractal_julia_pt(${a}, ${u}, ${s})`}return`_fractal_julia(${i(e)}, ${i(n)}, ${s})`},Cross:"cross",Distance:"distance",Dot:"dot",Length:"length",Normalize:"normalize",Reflect:"reflect",Refract:"refract",Sum:(e,n,t)=>gu("Sum",e,n,t),Product:(e,n,t)=>gu("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(!k(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",f=g.compile(e[0],{...t,var:m=>m===o?o:t.var(m)});return`for (${l?`var ${o}: ${c}`:`${c} ${o}`} = ${a}; ${o} <= ${u}; ${o}++) {
|
|
50
|
-
${
|
|
51
|
-
}`},Function:()=>{throw new Error("Anonymous functions (Function) are not supported in GPU targets")}};function
|
|
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");if(n===null)return`Math.sqrt(${t(e)})`;let i=U(e),r=U(n);return i!==void 0&&r!==void 0&&r!==0?String(Math.pow(i,1/r)):r===2?`Math.sqrt(${t(e)})`:r===3?`Math.cbrt(${t(e)})`:r!==void 0?`Math.pow(${t(e)}, ${1/r})`:`Math.pow(${t(e)}, 1 / (${t(n)}))`},Random:"Math.random",Round:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`Math.round(${n(e[0])})`,Square:(e,n)=>{let t=e[0];if(t===null)throw new Error("Square: no argument");let i=U(t);if(i!==void 0)return String(i*i);if(S(t)){let r=n(t);return`(${r} * ${r})`}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)=>{if(g.isComplexValued(e[0]))return`_SYS.csqrt(${n(e[0])})`;let t=U(e[0]);return t!==void 0?String(Math.sqrt(t)):`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 g.isIntegerValued(e)&&g.isIntegerValued(n)&&g.isNonNegative(e)?`(${i} % ${r})`:`((${i} % ${r}) + ${r}) % ${r}`},Truncate:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`Math.trunc(${n(e[0])})`,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)}))`},Divide:([e,n],t)=>{if(e===null||n===null)throw new Error("Divide: missing argument");let i=g.isComplexValued(e),r=g.isComplexValued(n);if(!i&&!r){let s=U(e),o=U(n);return s!==void 0&&o!==void 0&&o!==0?String(s/o):o===1?t(e):`(${t(e)} / ${t(n)})`}return 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");if(!g.isComplexValued(e)){let t=U(e);return t!==void 0?String(-t):`(-${n(e)})`}return`_SYS.cneg(${n(e)})`},Multiply:(e,n)=>{if(e.length===1)return n(e[0]);if(!e.some(o=>g.isComplexValued(o))){if(e.some(u=>U(u)===0))return"0";let o=e.map(U);if(o.every(u=>u!==void 0))return String(o.reduce((u,l)=>u*l,1));let a=e.filter(u=>U(u)!==1);return a.length===0?"1":a.length===1?n(a[0]):`(${a.map(u=>n(u)).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",Mandelbrot:([e,n],t)=>{if(e===null||n===null)throw new Error("Mandelbrot: missing arguments");return`_SYS.mandelbrot(${t(e)}, ${t(n)})`},Julia:([e,n,t],i)=>{if(e===null||n===null||t===null)throw new Error("Julia: missing arguments");return`_SYS.julia(${i(e)}, ${i(n)}, ${i(t)})`},Binomial:(e,n)=>`_SYS.binomial(${n(e[0])}, ${n(e[1])})`,Fibonacci:"_SYS.fibonacci",Real:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).re`:n(e[0]),Imaginary:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).im`:"0",Argument:(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 j(e){return{re:e.re,im:e.im}}function Ze(e){if(typeof e=="string"){let t=ot(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 fr(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 xf={color(e){return fr(ot(e))},colorToString(e,n){let t=Ze(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=tr(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=en(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=Ze(e),r=Ze(n);t=Math.max(0,Math.min(1,t));let s=en(i),o=en(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=Cn({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 Zt(Ze(e),Ze(n))},contrastingColor(e,n,t){let i=Ze(e);return fr(n!==void 0&&t!==void 0?rr({bg:i,fg1:Ze(n),fg2:Ze(t)}):rr(i))},colorToColorspace(e,n){let t=Ze(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=tr(t.r,t.g,t.b);r=[s.h,s.s,s.l];break}case"oklch":{let s=en(t);r=[s.L,s.C,s.H];break}case"oklab":case"lab":{let s=ir(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={...Ba,...Oa,...La}[e];if(!i)throw new Error(`Unknown palette: ${e}`);let r=i.map(o=>Fa(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=en(s),u=en(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=Cn({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=nr(t,i,r);o=[a.r/255,a.g/255,a.b/255];break}case"oklch":{let a=Cn({L:t,C:i,H:r});o=[a.r/255,a.g/255,a.b/255];break}case"oklab":case"lab":{let a=st({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}},mu={chop:zn,factorial:Jn,factorial2:qn,gamma:ie,gcd:Se,heaviside:e=>e<0?0:e===0?.5:1,integrate:(e,n,t)=>cu(e,n,t,1e7).estimate,lcm:Ye,lngamma:Ie,limit:xt,mean:tu,median:mn,variance:ar,populationVariance:ur,standardDeviation:iu,populationStandardDeviation:ru,kurtosis:su,skewness:ou,mode:au,quartiles:uu,interquartileRange:lu,erf:Pn,erfc:at,erfInv:qa,beta:za,digamma:Wt,trigamma:Xt,polygamma:sr,zeta:or,lambertW:Ga,besselJ:nn,besselY:Ht,besselI:ln,besselK:Ua,airyAi:Ya,airyBi:Ha,sinc:eu,fresnelS:cn,fresnelC:fn,mandelbrot:(e,n)=>{let t=0,i=0,r=typeof e=="number"?e:e.re,s=typeof e=="number"?0:e.im,o=Math.round(n);for(let a=0;a<o;a++){let u=t*t-i*i+r;i=2*t*i+s,t=u;let l=t*t+i*i;if(l>4){let c=(a-Math.log2(Math.log2(l))+4)/o;return Math.max(0,Math.min(1,c))}}return 1},julia:(e,n,t)=>{let i=typeof e=="number"?e:e.re,r=typeof e=="number"?0:e.im,s=typeof n=="number"?n:n.re,o=typeof n=="number"?0:n.im,a=Math.round(t);for(let u=0;u<a;u++){let l=i*i-r*r+s;r=2*i*r+o,i=l;let c=i*i+r*r;if(c>4){let p=(u-Math.log2(Math.log2(c))+4)/a;return Math.max(0,Math.min(1,p))}}return 1},binomial:pn,fibonacci:hr,csin:e=>j(new $(e.re,e.im).sin()),ccos:e=>j(new $(e.re,e.im).cos()),ctan:e=>j(new $(e.re,e.im).tan()),casin:e=>j(new $(e.re,e.im).asin()),cacos:e=>j(new $(e.re,e.im).acos()),catan:e=>j(new $(e.re,e.im).atan()),csinh:e=>j(new $(e.re,e.im).sinh()),ccosh:e=>j(new $(e.re,e.im).cosh()),ctanh:e=>j(new $(e.re,e.im).tanh()),csqrt:e=>j(new $(e.re,e.im).sqrt()),cexp:e=>j(new $(e.re,e.im).exp()),cln:e=>j(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 j(t.pow(i))},ccot:e=>j(new $(e.re,e.im).cot()),csec:e=>j(new $(e.re,e.im).sec()),ccsc:e=>j(new $(e.re,e.im).csc()),ccoth:e=>j(new $(e.re,e.im).coth()),csech:e=>j(new $(e.re,e.im).sech()),ccsch:e=>j(new $(e.re,e.im).csch()),cacot:e=>j(new $(e.re,e.im).acot()),casec:e=>j(new $(e.re,e.im).asec()),cacsc:e=>j(new $(e.re,e.im).acsc()),cacoth:e=>j(new $(e.re,e.im).acoth()),casech:e=>j(new $(e.re,e.im).asech()),cacsch:e=>j(new $(e.re,e.im).acsch()),cabs:e=>new $(e.re,e.im).abs(),carg:e=>new $(e.re,e.im).arg(),cconj:e=>j(new $(e.re,e.im).conjugate()),cneg:e=>({re:-e.re,im:-e.im}),...xf},mr=class extends Function{SYS=mu;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]})}},Qt=class extends Function{SYS=mu;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]})}},dr=class{getOperators(){return lr}getFunctions(){return cr}createTarget(n={}){return{language:"javascript",operators:t=>lr[t],functions:t=>cr[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"?Tf(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 lr[b]},d=this.createTarget({operators:m,functions:b=>p?.[b]?p[b]:cr[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 Ef(n,d,u)}};function pr(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 Ef(e,n,t){if(h(e,"Function")){let o=e.ops,a=o.slice(1).map(p=>S(p)?p.symbol:"_"),u=g.compile(o[0].canonical,{...n,var:p=>a.includes(p)?p:n.var(p)}),l=new Qt(u,a),c={target:"javascript",success:!0,code:`(${a.join(", ")}) => ${u}`,calling:"lambda",run:l};return t?pr(c):c}if(S(e)){let o=n.operators?.(e.symbol);if(o){let a=new Qt(`a ${o[0]} b`,["a","b"]),u={target:"javascript",success:!0,code:`(a, b) => a ${o[0]} b`,calling:"lambda",run:a};return t?pr(u):u}}let i=g.compile(e,n),r=new mr(i,n.preamble),s={target:"javascript",success:!0,code:i,calling:"expression",run:r};return t?pr(s):s}var vf=100;function du(e){e.operator;let n=e,t=S(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 fu(e,n,t){return n!==void 0?String(n):`Math.floor(${g.compile(e,t)})`}function pu(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}=du(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<=vf){let P=[];for(let Y=a;Y<=u;Y++){let ue={...i,var:le=>le===r?String(Y):i.var(le)};P.push(`(${g.compile(n[0],ue)})`)}if(!m)return`(${P.join(` ${c} `)})`;let B=P.map((Y,ue)=>`_t${ue}`),Q=P.map((Y,ue)=>`const ${B[ue]} = ${Y}`).join("; ");if(l){let Y=B.map(le=>`${le}.re`).join(" + "),ue=B.map(le=>`${le}.im`).join(" + ");return`(() => { ${Q}; return { re: ${Y}, im: ${ue} }; })()`}let Z=B[0],ke=[Q];for(let Y=1;Y<B.length;Y++){let ue=Z;Z=`_p${Y}`,ke.push(`const ${Z} = { re: ${ue}.re * ${B[Y]}.re - ${ue}.im * ${B[Y]}.im, im: ${ue}.re * ${B[Y]}.im + ${ue}.im * ${B[Y]}.re }`)}return`(() => { ${ke.join("; ")}; return ${Z}; })()`}let b=fu(s,a,i),v=fu(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 Nf(e,n,t){let{index:i,lowerExpr:r,upperExpr:s,lowerNum:o,upperNum:a}=du(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 Tf(e){let n=e.toString();return n.includes("=>")?!1:n.startsWith("function ")&&n.includes(e.name)}function hr(e){if(!Number.isInteger(e))return NaN;if(e<0)return e%2===0?-hr(-e):hr(-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 hu={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 Ne(e){return e?.language==="wgsl"?"vec2f":"vec2"}function gu(e,n,t){let i=U(e);return i!==void 0&&Number.isInteger(i)?i.toString():`${t?.language==="wgsl"?"i32":"int"}(${n(e)})`}var If=100;function bu(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(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<=If){let le=[];for(let ne=l;ne<=c;ne++){let Pe=Kt(ne),Fe={...i,var:dt=>dt===o?Pe:i.var(dt)};le.push(`(${g.compile(n[0],Fe)})`)}return`(${le.join(` ${m} `)})`}let k=g.tempVar(),w=b?"f32":"float",R=b?"i32":"int",P={...i,var:le=>le===o?b?`f32(${o})`:`float(${o})`:i.var(le)},B=g.compile(n[0],P),Q=l!==void 0?String(l):g.compile(s[1],i),Z=c!==void 0?String(c):g.compile(s[2],i),ke=b?`var ${k}: ${w}`:`${w} ${k}`,Y=b?`var ${o}: ${R}`:`${R} ${o}`;return[`${ke} = ${d};`,`for (${Y} = ${Q}; ${o} <= ${Z}; ${o}++) {`,` ${k} ${m}= ${B};`,"}",`return ${k}`].join(`
|
|
49
|
+
`)}var kf={Add:(e,n,t)=>{if(e.length===0)return"0.0";if(e.length===1)return n(e[0]);if(!e.some(l=>g.isComplexValued(l)))return Ke(e.map(l=>n(l)),"0.0","+");let r=e.map(l=>ba(l,n));if(r.some(l=>l===null)){let l=Ne(t);return e.map(c=>{let p=n(c);return g.isComplexValued(c)?p:`${l}(${p}, 0.0)`}).join(" + ")}let s=[],o=[];for(let l of r)l.re!==null&&s.push(l.re),l.im!==null&&o.push(l.im);let a=Ke(s,"0.0","+"),u=Ke(o,"0.0","+");return`${Ne(t)}(${a}, ${u})`},Multiply:(e,n,t)=>{if(e.length===0)return"1.0";if(e.length===1)return n(e[0]);if(!e.some(l=>g.isComplexValued(l)))return Ke(e.map(l=>n(l)),"1.0","*");let r=e.findIndex(l=>S(l,"ImaginaryUnit")||O(l)&&l.re===0&&l.im!==0);if(r>=0){let l=e[r],c=S(l,"ImaginaryUnit")?1:l.im,p=e.filter((v,k)=>k!==r),m=Ne(t);if(p.length===0)return`${m}(0.0, ${oe(c)})`;let d=p.map(v=>n(v));c!==1&&d.unshift(oe(c));let b=Ke(d,"1.0","*");return`${m}(0.0, ${b})`}let s=[],o=[];for(let l of e)g.isComplexValued(l)?o.push(n(l)):s.push(n(l));let a=Ke(s,"1.0","*"),u=o[0];for(let l=1;l<o.length;l++)u=`_gpu_cmul(${u}, ${o[l]})`;return a!=="1.0"&&(u=`(${a} * ${u})`),u},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){let a=U(e[0]),u=U(e[1]);return a!==void 0&&u!==void 0&&u!==0?oe(a/u):u===1?n(e[0]):`${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(${Ne(t)}(${n(e[0])}, 0.0), ${n(e[1])})`},Negate:([e],n,t)=>{if(e===null)throw new Error("Negate: no argument");let i=U(e);return i!==void 0?oe(-i):O(e)&&e.im!==0?`${Ne(t)}(${oe(-e.re)}, ${oe(-e.im)})`:S(e,"ImaginaryUnit")?`${Ne(t)}(0.0, -1.0)`:`(-${n(e)})`},Abs:(e,n)=>g.isComplexValued(e[0])?`length(${n(e[0])})`:g.isNonNegative(e[0])?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:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`ceil(${n(e[0])})`,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:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`floor(${n(e[0])})`,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(S(i,"ExponentialE"))return`_gpu_cexp(${n(r)})`;let a=Ne(t),u=g.isComplexValued(i)?n(i):`${a}(${n(i)}, 0.0)`,l=g.isComplexValued(r)?n(r):`${a}(${n(r)}, 0.0)`;return`_gpu_cpow(${u}, ${l})`}let s=U(i),o=U(r);if(s!==void 0&&o!==void 0)return oe(Math.pow(s,o));if(o===0)return"1.0";if(o===1)return n(i);if(o===2&&(S(i)||O(i))){let a=n(i);return`(${a} * ${a})`}return o===-1?`(1.0 / ${n(i)})`:o===.5?`sqrt(${n(i)})`:`pow(${n(i)}, ${n(r)})`},Radians:"radians",Round:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`round(${n(e[0])})`,Sign:"sign",Sin:(e,n)=>g.isComplexValued(e[0])?`_gpu_csin(${n(e[0])})`:`sin(${n(e[0])})`,Smoothstep:"smoothstep",Sqrt:(e,n)=>{if(g.isComplexValued(e[0]))return`_gpu_csqrt(${n(e[0])})`;let t=U(e[0]);return t!==void 0?oe(Math.sqrt(t)):`sqrt(${n(e[0])})`},Step:"step",Tan:(e,n)=>g.isComplexValued(e[0])?`_gpu_ctan(${n(e[0])})`:`tan(${n(e[0])})`,Truncate:(e,n)=>g.isIntegerValued(e[0])?n(e[0]):`trunc(${n(e[0])})`,Real:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).x`:n(e[0]),Imaginary:(e,n)=>g.isComplexValued(e[0])?`(${n(e[0])}).y`:"0.0",Argument:(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=Ne(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(${Ne(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(${Ne(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(${Ne(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(${Ne(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");if(S(e)||O(e)){let t=n(e);return`(${t} * ${t})`}return`pow(${n(e)}, 2.0)`},Root:([e,n],t)=>{if(e===null)throw new Error("Root: no argument");if(n==null)return`sqrt(${t(e)})`;let i=U(n);if(i===2)return`sqrt(${t(e)})`;let r=U(e);return r!==void 0&&i!==void 0?oe(Math.pow(r,1/i)):`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=gu(n,t,i);return`_fractal_mandelbrot(${t(e)}, ${r})`},Julia:([e,n,t],i,r)=>{if(e===null||n===null||t===null)throw new Error("Julia: missing arguments");let s=gu(t,i,r);return`_fractal_julia(${i(e)}, ${i(n)}, ${s})`},Cross:"cross",Distance:"distance",Dot:"dot",Length:"length",Normalize:"normalize",Reflect:"reflect",Refract:"refract",Sum:(e,n,t)=>bu("Sum",e,n,t),Product:(e,n,t)=>bu("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(!S(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 ei(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 Sf=`
|
|
52
52
|
float _gpu_gamma(float z) {
|
|
53
53
|
const float PI = 3.14159265358979;
|
|
54
54
|
// For z < 0.5, use reflection formula with inlined Lanczos (non-recursive)
|
|
@@ -79,7 +79,7 @@ float _gpu_gammaln(float z) {
|
|
|
79
79
|
- 1.0 / (360.0 * z3)
|
|
80
80
|
+ 1.0 / (1260.0 * z3 * z * z);
|
|
81
81
|
}
|
|
82
|
-
`,
|
|
82
|
+
`,_f=`
|
|
83
83
|
float _gpu_erf(float x) {
|
|
84
84
|
float ax = abs(x);
|
|
85
85
|
float t = 1.0 / (1.0 + 0.3275911 * ax);
|
|
@@ -332,7 +332,7 @@ float _gpu_fresnelS(float x_in) {
|
|
|
332
332
|
|
|
333
333
|
return sgn * 0.5;
|
|
334
334
|
}
|
|
335
|
-
`,
|
|
335
|
+
`,Of=`
|
|
336
336
|
fn _gpu_fresnelS(x_in: f32) -> f32 {
|
|
337
337
|
let sgn: f32 = select(1.0, -1.0, x_in < 0.0);
|
|
338
338
|
let x = abs(x_in);
|
|
@@ -401,7 +401,7 @@ fn _gpu_fresnelS(x_in: f32) -> f32 {
|
|
|
401
401
|
|
|
402
402
|
return sgn * 0.5;
|
|
403
403
|
}
|
|
404
|
-
`,
|
|
404
|
+
`,Lf=`
|
|
405
405
|
float _gpu_factorial(int n) {
|
|
406
406
|
float f = 1.0;
|
|
407
407
|
for (int i = 2; i <= n; i++) f *= float(i);
|
|
@@ -555,197 +555,7 @@ fn _gpu_besselJ(n_in: i32, x_in: f32) -> f32 {
|
|
|
555
555
|
for (var k2: i32 = 2; k2 <= M; k2 += 2) { norm += 2.0 * vals[k2]; }
|
|
556
556
|
return sgn * vals[n] / norm;
|
|
557
557
|
}
|
|
558
|
-
`,bu=`
|
|
559
|
-
// Split a float into high and low parts for exact multiplication
|
|
560
|
-
vec2 ds_split(float a) {
|
|
561
|
-
const float SPLIT = 4097.0; // 2^12 + 1
|
|
562
|
-
float t = SPLIT * a;
|
|
563
|
-
float hi = t - (t - a);
|
|
564
|
-
float lo = a - hi;
|
|
565
|
-
return vec2(hi, lo);
|
|
566
|
-
}
|
|
567
|
-
|
|
568
|
-
// Create a double-single from a single float
|
|
569
|
-
vec2 ds_from(float a) {
|
|
570
|
-
return vec2(a, 0.0);
|
|
571
|
-
}
|
|
572
|
-
|
|
573
|
-
// Error-free addition (Knuth TwoSum)
|
|
574
|
-
vec2 ds_add(vec2 a, vec2 b) {
|
|
575
|
-
float s = a.x + b.x;
|
|
576
|
-
float v = s - a.x;
|
|
577
|
-
float e = (a.x - (s - v)) + (b.x - v);
|
|
578
|
-
float lo = (a.y + b.y) + e;
|
|
579
|
-
float hi = s + lo;
|
|
580
|
-
lo = lo - (hi - s);
|
|
581
|
-
return vec2(hi, lo);
|
|
582
|
-
}
|
|
583
|
-
|
|
584
|
-
// Double-single subtraction
|
|
585
|
-
vec2 ds_sub(vec2 a, vec2 b) {
|
|
586
|
-
return ds_add(a, vec2(-b.x, -b.y));
|
|
587
|
-
}
|
|
588
|
-
|
|
589
|
-
// Error-free multiplication (Dekker TwoProduct)
|
|
590
|
-
vec2 ds_mul(vec2 a, vec2 b) {
|
|
591
|
-
float p = a.x * b.x;
|
|
592
|
-
vec2 sa = ds_split(a.x);
|
|
593
|
-
vec2 sb = ds_split(b.x);
|
|
594
|
-
float err = ((sa.x * sb.x - p) + sa.x * sb.y + sa.y * sb.x) + sa.y * sb.y;
|
|
595
|
-
err += a.x * b.y + a.y * b.x;
|
|
596
|
-
float hi = p + err;
|
|
597
|
-
float lo = err - (hi - p);
|
|
598
|
-
return vec2(hi, lo);
|
|
599
|
-
}
|
|
600
|
-
|
|
601
|
-
// Optimized self-multiply
|
|
602
|
-
vec2 ds_sqr(vec2 a) {
|
|
603
|
-
float p = a.x * a.x;
|
|
604
|
-
vec2 sa = ds_split(a.x);
|
|
605
|
-
float err = ((sa.x * sa.x - p) + 2.0 * sa.x * sa.y) + sa.y * sa.y;
|
|
606
|
-
err += 2.0 * a.x * a.y;
|
|
607
|
-
float hi = p + err;
|
|
608
|
-
float lo = err - (hi - p);
|
|
609
|
-
return vec2(hi, lo);
|
|
610
|
-
}
|
|
611
|
-
|
|
612
|
-
// Compare magnitude: returns -1, 0, or 1
|
|
613
|
-
float ds_cmp(vec2 a, vec2 b) {
|
|
614
|
-
float d = a.x - b.x;
|
|
615
|
-
if (d != 0.0) return sign(d);
|
|
616
|
-
return sign(a.y - b.y);
|
|
617
|
-
}
|
|
618
|
-
`,yu=`
|
|
619
|
-
fn ds_split(a: f32) -> vec2f {
|
|
620
|
-
const SPLIT: f32 = 4097.0;
|
|
621
|
-
let t = SPLIT * a;
|
|
622
|
-
let hi = t - (t - a);
|
|
623
|
-
let lo = a - hi;
|
|
624
|
-
return vec2f(hi, lo);
|
|
625
|
-
}
|
|
626
|
-
|
|
627
|
-
fn ds_from(a: f32) -> vec2f {
|
|
628
|
-
return vec2f(a, 0.0);
|
|
629
|
-
}
|
|
630
|
-
|
|
631
|
-
fn ds_add(a: vec2f, b: vec2f) -> vec2f {
|
|
632
|
-
let s = a.x + b.x;
|
|
633
|
-
let v = s - a.x;
|
|
634
|
-
let e = (a.x - (s - v)) + (b.x - v);
|
|
635
|
-
let lo_t = (a.y + b.y) + e;
|
|
636
|
-
let hi = s + lo_t;
|
|
637
|
-
let lo = lo_t - (hi - s);
|
|
638
|
-
return vec2f(hi, lo);
|
|
639
|
-
}
|
|
640
|
-
|
|
641
|
-
fn ds_sub(a: vec2f, b: vec2f) -> vec2f {
|
|
642
|
-
return ds_add(a, vec2f(-b.x, -b.y));
|
|
643
|
-
}
|
|
644
|
-
|
|
645
|
-
fn ds_mul(a: vec2f, b: vec2f) -> vec2f {
|
|
646
|
-
let p = a.x * b.x;
|
|
647
|
-
let sa = ds_split(a.x);
|
|
648
|
-
let sb = ds_split(b.x);
|
|
649
|
-
var err = ((sa.x * sb.x - p) + sa.x * sb.y + sa.y * sb.x) + sa.y * sb.y;
|
|
650
|
-
err += a.x * b.y + a.y * b.x;
|
|
651
|
-
let hi = p + err;
|
|
652
|
-
let lo = err - (hi - p);
|
|
653
|
-
return vec2f(hi, lo);
|
|
654
|
-
}
|
|
655
|
-
|
|
656
|
-
fn ds_sqr(a: vec2f) -> vec2f {
|
|
657
|
-
let p = a.x * a.x;
|
|
658
|
-
let sa = ds_split(a.x);
|
|
659
|
-
var err = ((sa.x * sa.x - p) + 2.0 * sa.x * sa.y) + sa.y * sa.y;
|
|
660
|
-
err += 2.0 * a.x * a.y;
|
|
661
|
-
let hi = p + err;
|
|
662
|
-
let lo = err - (hi - p);
|
|
663
|
-
return vec2f(hi, lo);
|
|
664
|
-
}
|
|
665
|
-
|
|
666
|
-
fn ds_cmp(a: vec2f, b: vec2f) -> f32 {
|
|
667
|
-
let d = a.x - b.x;
|
|
668
|
-
if (d != 0.0) { return sign(d); }
|
|
669
|
-
return sign(a.y - b.y);
|
|
670
|
-
}
|
|
671
558
|
`,Vf=`
|
|
672
|
-
float _fractal_mandelbrot_dp(vec4 c, int maxIter) {
|
|
673
|
-
// c = (re_hi, im_hi, re_lo, im_lo)
|
|
674
|
-
vec2 cr = vec2(c.x, c.z); // real part as ds
|
|
675
|
-
vec2 ci = vec2(c.y, c.w); // imag part as ds
|
|
676
|
-
vec2 zr = vec2(0.0, 0.0);
|
|
677
|
-
vec2 zi = vec2(0.0, 0.0);
|
|
678
|
-
for (int i = 0; i < maxIter; i++) {
|
|
679
|
-
vec2 zr2 = ds_sqr(zr);
|
|
680
|
-
vec2 zi2 = ds_sqr(zi);
|
|
681
|
-
// |z|^2 > 4.0 ?
|
|
682
|
-
vec2 mag2 = ds_add(zr2, zi2);
|
|
683
|
-
if (mag2.x > 4.0)
|
|
684
|
-
return clamp((float(i) - log2(log2(mag2.x)) + 4.0) / float(maxIter), 0.0, 1.0);
|
|
685
|
-
// z = z^2 + c
|
|
686
|
-
vec2 new_zi = ds_add(ds_mul(ds_add(zr, zr), zi), ci); // 2*zr*zi + ci
|
|
687
|
-
zr = ds_add(ds_sub(zr2, zi2), cr); // zr^2 - zi^2 + cr
|
|
688
|
-
zi = new_zi;
|
|
689
|
-
}
|
|
690
|
-
return 1.0;
|
|
691
|
-
}
|
|
692
|
-
|
|
693
|
-
float _fractal_julia_dp(vec4 z_in, vec4 c, int maxIter) {
|
|
694
|
-
vec2 zr = vec2(z_in.x, z_in.z);
|
|
695
|
-
vec2 zi = vec2(z_in.y, z_in.w);
|
|
696
|
-
vec2 cr = vec2(c.x, c.z);
|
|
697
|
-
vec2 ci = vec2(c.y, c.w);
|
|
698
|
-
for (int i = 0; i < maxIter; i++) {
|
|
699
|
-
vec2 zr2 = ds_sqr(zr);
|
|
700
|
-
vec2 zi2 = ds_sqr(zi);
|
|
701
|
-
vec2 mag2 = ds_add(zr2, zi2);
|
|
702
|
-
if (mag2.x > 4.0)
|
|
703
|
-
return clamp((float(i) - log2(log2(mag2.x)) + 4.0) / float(maxIter), 0.0, 1.0);
|
|
704
|
-
vec2 new_zi = ds_add(ds_mul(ds_add(zr, zr), zi), ci);
|
|
705
|
-
zr = ds_add(ds_sub(zr2, zi2), cr);
|
|
706
|
-
zi = new_zi;
|
|
707
|
-
}
|
|
708
|
-
return 1.0;
|
|
709
|
-
}
|
|
710
|
-
`,zf=`
|
|
711
|
-
fn _fractal_mandelbrot_dp(c: vec4f, maxIter: i32) -> f32 {
|
|
712
|
-
let cr = vec2f(c.x, c.z);
|
|
713
|
-
let ci = vec2f(c.y, c.w);
|
|
714
|
-
var zr = vec2f(0.0, 0.0);
|
|
715
|
-
var zi = vec2f(0.0, 0.0);
|
|
716
|
-
for (var i: i32 = 0; i < maxIter; i++) {
|
|
717
|
-
let zr2 = ds_sqr(zr);
|
|
718
|
-
let zi2 = ds_sqr(zi);
|
|
719
|
-
let mag2 = ds_add(zr2, zi2);
|
|
720
|
-
if (mag2.x > 4.0) {
|
|
721
|
-
return clamp((f32(i) - log2(log2(mag2.x)) + 4.0) / f32(maxIter), 0.0, 1.0);
|
|
722
|
-
}
|
|
723
|
-
let new_zi = ds_add(ds_mul(ds_add(zr, zr), zi), ci);
|
|
724
|
-
zr = ds_add(ds_sub(zr2, zi2), cr);
|
|
725
|
-
zi = new_zi;
|
|
726
|
-
}
|
|
727
|
-
return 1.0;
|
|
728
|
-
}
|
|
729
|
-
|
|
730
|
-
fn _fractal_julia_dp(z_in: vec4f, c: vec4f, maxIter: i32) -> f32 {
|
|
731
|
-
var zr = vec2f(z_in.x, z_in.z);
|
|
732
|
-
var zi = vec2f(z_in.y, z_in.w);
|
|
733
|
-
let cr = vec2f(c.x, c.z);
|
|
734
|
-
let ci = vec2f(c.y, c.w);
|
|
735
|
-
for (var i: i32 = 0; i < maxIter; i++) {
|
|
736
|
-
let zr2 = ds_sqr(zr);
|
|
737
|
-
let zi2 = ds_sqr(zi);
|
|
738
|
-
let mag2 = ds_add(zr2, zi2);
|
|
739
|
-
if (mag2.x > 4.0) {
|
|
740
|
-
return clamp((f32(i) - log2(log2(mag2.x)) + 4.0) / f32(maxIter), 0.0, 1.0);
|
|
741
|
-
}
|
|
742
|
-
let new_zi = ds_add(ds_mul(ds_add(zr, zr), zi), ci);
|
|
743
|
-
zr = ds_add(ds_sub(zr2, zi2), cr);
|
|
744
|
-
zi = new_zi;
|
|
745
|
-
}
|
|
746
|
-
return 1.0;
|
|
747
|
-
}
|
|
748
|
-
`,Jf=`
|
|
749
559
|
float _fractal_mandelbrot(vec2 c, int maxIter) {
|
|
750
560
|
vec2 z = vec2(0.0, 0.0);
|
|
751
561
|
for (int i = 0; i < maxIter; i++) {
|
|
@@ -764,7 +574,7 @@ float _fractal_julia(vec2 z, vec2 c, int maxIter) {
|
|
|
764
574
|
}
|
|
765
575
|
return 1.0;
|
|
766
576
|
}
|
|
767
|
-
`,
|
|
577
|
+
`,Jf=`
|
|
768
578
|
fn _fractal_mandelbrot(c: vec2f, maxIter: i32) -> f32 {
|
|
769
579
|
var z = vec2f(0.0, 0.0);
|
|
770
580
|
for (var i: i32 = 0; i < maxIter; i++) {
|
|
@@ -786,187 +596,7 @@ fn _fractal_julia(z_in: vec2f, c: vec2f, maxIter: i32) -> f32 {
|
|
|
786
596
|
}
|
|
787
597
|
return 1.0;
|
|
788
598
|
}
|
|
789
|
-
`,
|
|
790
|
-
uniform sampler2D _refOrbit;
|
|
791
|
-
uniform int _refOrbitLen;
|
|
792
|
-
uniform int _refOrbitTexWidth;
|
|
793
|
-
|
|
794
|
-
vec2 _pt_fetch_orbit(int i) {
|
|
795
|
-
int y = i / _refOrbitTexWidth;
|
|
796
|
-
int x = i - y * _refOrbitTexWidth;
|
|
797
|
-
return texelFetch(_refOrbit, ivec2(x, y), 0).rg;
|
|
798
|
-
}
|
|
799
|
-
|
|
800
|
-
float _fractal_mandelbrot_pt(vec2 delta_c, int maxIter) {
|
|
801
|
-
float dr = 0.0;
|
|
802
|
-
float di = 0.0;
|
|
803
|
-
int orbitLen = min(maxIter, _refOrbitLen);
|
|
804
|
-
for (int i = 0; i < orbitLen; i++) {
|
|
805
|
-
vec2 Zn = _pt_fetch_orbit(i);
|
|
806
|
-
// delta_{n+1} = 2*Z_n*delta_n + delta_n^2 + delta_c
|
|
807
|
-
float new_dr = 2.0 * (Zn.x * dr - Zn.y * di) + dr * dr - di * di + delta_c.x;
|
|
808
|
-
float new_di = 2.0 * (Zn.x * di + Zn.y * dr) + 2.0 * dr * di + delta_c.y;
|
|
809
|
-
dr = new_dr;
|
|
810
|
-
di = new_di;
|
|
811
|
-
// Full z = Z_{n+1} + delta for escape check
|
|
812
|
-
vec2 Zn1 = (i + 1 < orbitLen) ? _pt_fetch_orbit(i + 1) : vec2(0.0);
|
|
813
|
-
float zr = Zn1.x + dr;
|
|
814
|
-
float zi = Zn1.y + di;
|
|
815
|
-
float mag2 = zr * zr + zi * zi;
|
|
816
|
-
if (mag2 > 4.0)
|
|
817
|
-
return clamp((float(i) - log2(log2(mag2)) + 4.0) / float(maxIter), 0.0, 1.0);
|
|
818
|
-
// Glitch detection: |delta|^2 > |Z|^2
|
|
819
|
-
float dmag2 = dr * dr + di * di;
|
|
820
|
-
float Zmag2 = Zn.x * Zn.x + Zn.y * Zn.y;
|
|
821
|
-
if (dmag2 > Zmag2 && Zmag2 > 0.0) {
|
|
822
|
-
// Rebase to absolute coordinates and continue with single-float
|
|
823
|
-
float abs_zr = Zn1.x + dr;
|
|
824
|
-
float abs_zi = Zn1.y + di;
|
|
825
|
-
// Reconstruct absolute c from reference + delta
|
|
826
|
-
// (Use ds_from for the concept, but single-float suffices for fallback)
|
|
827
|
-
float cx = abs_zr - dr + delta_c.x;
|
|
828
|
-
float cy = abs_zi - di + delta_c.y;
|
|
829
|
-
for (int j = i + 1; j < maxIter; j++) {
|
|
830
|
-
float new_zr = abs_zr * abs_zr - abs_zi * abs_zi + cx;
|
|
831
|
-
abs_zi = 2.0 * abs_zr * abs_zi + cy;
|
|
832
|
-
abs_zr = new_zr;
|
|
833
|
-
mag2 = abs_zr * abs_zr + abs_zi * abs_zi;
|
|
834
|
-
if (mag2 > 4.0)
|
|
835
|
-
return clamp((float(j) - log2(log2(mag2)) + 4.0) / float(maxIter), 0.0, 1.0);
|
|
836
|
-
}
|
|
837
|
-
return 1.0;
|
|
838
|
-
}
|
|
839
|
-
}
|
|
840
|
-
return 1.0;
|
|
841
|
-
}
|
|
842
|
-
|
|
843
|
-
float _fractal_julia_pt(vec2 z_delta, vec2 delta_c, int maxIter) {
|
|
844
|
-
float dr = z_delta.x;
|
|
845
|
-
float di = z_delta.y;
|
|
846
|
-
int orbitLen = min(maxIter, _refOrbitLen);
|
|
847
|
-
for (int i = 0; i < orbitLen; i++) {
|
|
848
|
-
vec2 Zn = _pt_fetch_orbit(i);
|
|
849
|
-
float new_dr = 2.0 * (Zn.x * dr - Zn.y * di) + dr * dr - di * di + delta_c.x;
|
|
850
|
-
float new_di = 2.0 * (Zn.x * di + Zn.y * dr) + 2.0 * dr * di + delta_c.y;
|
|
851
|
-
dr = new_dr;
|
|
852
|
-
di = new_di;
|
|
853
|
-
vec2 Zn1 = (i + 1 < orbitLen) ? _pt_fetch_orbit(i + 1) : vec2(0.0);
|
|
854
|
-
float zr = Zn1.x + dr;
|
|
855
|
-
float zi = Zn1.y + di;
|
|
856
|
-
float mag2 = zr * zr + zi * zi;
|
|
857
|
-
if (mag2 > 4.0)
|
|
858
|
-
return clamp((float(i) - log2(log2(mag2)) + 4.0) / float(maxIter), 0.0, 1.0);
|
|
859
|
-
float dmag2 = dr * dr + di * di;
|
|
860
|
-
float Zmag2 = Zn.x * Zn.x + Zn.y * Zn.y;
|
|
861
|
-
if (dmag2 > Zmag2 && Zmag2 > 0.0) {
|
|
862
|
-
float abs_zr = Zn1.x + dr;
|
|
863
|
-
float abs_zi = Zn1.y + di;
|
|
864
|
-
float cx = delta_c.x;
|
|
865
|
-
float cy = delta_c.y;
|
|
866
|
-
for (int j = i + 1; j < maxIter; j++) {
|
|
867
|
-
float new_zr = abs_zr * abs_zr - abs_zi * abs_zi + cx;
|
|
868
|
-
abs_zi = 2.0 * abs_zr * abs_zi + cy;
|
|
869
|
-
abs_zr = new_zr;
|
|
870
|
-
mag2 = abs_zr * abs_zr + abs_zi * abs_zi;
|
|
871
|
-
if (mag2 > 4.0)
|
|
872
|
-
return clamp((float(j) - log2(log2(mag2)) + 4.0) / float(maxIter), 0.0, 1.0);
|
|
873
|
-
}
|
|
874
|
-
return 1.0;
|
|
875
|
-
}
|
|
876
|
-
}
|
|
877
|
-
return 1.0;
|
|
878
|
-
}
|
|
879
|
-
`,Gf=`
|
|
880
|
-
@group(0) @binding(1) var _refOrbit: texture_2d<f32>;
|
|
881
|
-
var<uniform> _refOrbitLen: i32;
|
|
882
|
-
var<uniform> _refOrbitTexWidth: i32;
|
|
883
|
-
|
|
884
|
-
fn _pt_fetch_orbit(i: i32) -> vec2f {
|
|
885
|
-
let y = i / _refOrbitTexWidth;
|
|
886
|
-
let x = i - y * _refOrbitTexWidth;
|
|
887
|
-
return textureLoad(_refOrbit, vec2i(x, y), 0).rg;
|
|
888
|
-
}
|
|
889
|
-
|
|
890
|
-
fn _fractal_mandelbrot_pt(delta_c: vec2f, maxIter: i32) -> f32 {
|
|
891
|
-
var dr: f32 = 0.0;
|
|
892
|
-
var di: f32 = 0.0;
|
|
893
|
-
let orbitLen = min(maxIter, _refOrbitLen);
|
|
894
|
-
for (var i: i32 = 0; i < orbitLen; i++) {
|
|
895
|
-
let Zn = _pt_fetch_orbit(i);
|
|
896
|
-
let new_dr = 2.0 * (Zn.x * dr - Zn.y * di) + dr * dr - di * di + delta_c.x;
|
|
897
|
-
let new_di = 2.0 * (Zn.x * di + Zn.y * dr) + 2.0 * dr * di + delta_c.y;
|
|
898
|
-
dr = new_dr;
|
|
899
|
-
di = new_di;
|
|
900
|
-
var Zn1 = vec2f(0.0);
|
|
901
|
-
if (i + 1 < orbitLen) { Zn1 = _pt_fetch_orbit(i + 1); }
|
|
902
|
-
let zr = Zn1.x + dr;
|
|
903
|
-
let zi = Zn1.y + di;
|
|
904
|
-
var mag2 = zr * zr + zi * zi;
|
|
905
|
-
if (mag2 > 4.0) {
|
|
906
|
-
return clamp((f32(i) - log2(log2(mag2)) + 4.0) / f32(maxIter), 0.0, 1.0);
|
|
907
|
-
}
|
|
908
|
-
let dmag2 = dr * dr + di * di;
|
|
909
|
-
let Zmag2 = Zn.x * Zn.x + Zn.y * Zn.y;
|
|
910
|
-
if (dmag2 > Zmag2 && Zmag2 > 0.0) {
|
|
911
|
-
var f_zr = Zn1.x + dr;
|
|
912
|
-
var f_zi = Zn1.y + di;
|
|
913
|
-
let cx = delta_c.x;
|
|
914
|
-
let cy = delta_c.y;
|
|
915
|
-
for (var j: i32 = i + 1; j < maxIter; j++) {
|
|
916
|
-
let t_zr = f_zr * f_zr - f_zi * f_zi + cx;
|
|
917
|
-
f_zi = 2.0 * f_zr * f_zi + cy;
|
|
918
|
-
f_zr = t_zr;
|
|
919
|
-
mag2 = f_zr * f_zr + f_zi * f_zi;
|
|
920
|
-
if (mag2 > 4.0) {
|
|
921
|
-
return clamp((f32(j) - log2(log2(mag2)) + 4.0) / f32(maxIter), 0.0, 1.0);
|
|
922
|
-
}
|
|
923
|
-
}
|
|
924
|
-
return 1.0;
|
|
925
|
-
}
|
|
926
|
-
}
|
|
927
|
-
return 1.0;
|
|
928
|
-
}
|
|
929
|
-
|
|
930
|
-
fn _fractal_julia_pt(z_delta: vec2f, delta_c: vec2f, maxIter: i32) -> f32 {
|
|
931
|
-
var dr = z_delta.x;
|
|
932
|
-
var di = z_delta.y;
|
|
933
|
-
let orbitLen = min(maxIter, _refOrbitLen);
|
|
934
|
-
for (var i: i32 = 0; i < orbitLen; i++) {
|
|
935
|
-
let Zn = _pt_fetch_orbit(i);
|
|
936
|
-
let new_dr = 2.0 * (Zn.x * dr - Zn.y * di) + dr * dr - di * di + delta_c.x;
|
|
937
|
-
let new_di = 2.0 * (Zn.x * di + Zn.y * dr) + 2.0 * dr * di + delta_c.y;
|
|
938
|
-
dr = new_dr;
|
|
939
|
-
di = new_di;
|
|
940
|
-
var Zn1 = vec2f(0.0);
|
|
941
|
-
if (i + 1 < orbitLen) { Zn1 = _pt_fetch_orbit(i + 1); }
|
|
942
|
-
let zr = Zn1.x + dr;
|
|
943
|
-
let zi = Zn1.y + di;
|
|
944
|
-
var mag2 = zr * zr + zi * zi;
|
|
945
|
-
if (mag2 > 4.0) {
|
|
946
|
-
return clamp((f32(i) - log2(log2(mag2)) + 4.0) / f32(maxIter), 0.0, 1.0);
|
|
947
|
-
}
|
|
948
|
-
let dmag2 = dr * dr + di * di;
|
|
949
|
-
let Zmag2 = Zn.x * Zn.x + Zn.y * Zn.y;
|
|
950
|
-
if (dmag2 > Zmag2 && Zmag2 > 0.0) {
|
|
951
|
-
var f_zr = Zn1.x + dr;
|
|
952
|
-
var f_zi = Zn1.y + di;
|
|
953
|
-
let cx = delta_c.x;
|
|
954
|
-
let cy = delta_c.y;
|
|
955
|
-
for (var j: i32 = i + 1; j < maxIter; j++) {
|
|
956
|
-
let t_zr = f_zr * f_zr - f_zi * f_zi + cx;
|
|
957
|
-
f_zi = 2.0 * f_zr * f_zi + cy;
|
|
958
|
-
f_zr = t_zr;
|
|
959
|
-
mag2 = f_zr * f_zr + f_zi * f_zi;
|
|
960
|
-
if (mag2 > 4.0) {
|
|
961
|
-
return clamp((f32(j) - log2(log2(mag2)) + 4.0) / f32(maxIter), 0.0, 1.0);
|
|
962
|
-
}
|
|
963
|
-
}
|
|
964
|
-
return 1.0;
|
|
965
|
-
}
|
|
966
|
-
}
|
|
967
|
-
return 1.0;
|
|
968
|
-
}
|
|
969
|
-
`,Zf=`
|
|
599
|
+
`,qf=`
|
|
970
600
|
float _gpu_srgb_to_linear(float c) {
|
|
971
601
|
if (c <= 0.04045) return c / 12.92;
|
|
972
602
|
return pow((c + 0.055) / 1.055, 2.4);
|
|
@@ -1043,7 +673,7 @@ float _gpu_apca(vec3 bg, vec3 fg) {
|
|
|
1043
673
|
: (bgC - fgC) * 1.14;
|
|
1044
674
|
return contrast * 100.0;
|
|
1045
675
|
}
|
|
1046
|
-
`,
|
|
676
|
+
`,zf=`
|
|
1047
677
|
fn _gpu_srgb_to_linear(c: f32) -> f32 {
|
|
1048
678
|
if (c <= 0.04045) { return c / 12.92; }
|
|
1049
679
|
return pow((c + 0.055) / 1.055, 2.4);
|
|
@@ -1118,7 +748,7 @@ fn _gpu_apca(bg: vec3f, fg: vec3f) -> f32 {
|
|
|
1118
748
|
let contrast = (bgC - fgC) * 1.14;
|
|
1119
749
|
return contrast * 100.0;
|
|
1120
750
|
}
|
|
1121
|
-
`,
|
|
751
|
+
`,gr={_gpu_cmul:{deps:[],glsl:`vec2 _gpu_cmul(vec2 a, vec2 b) {
|
|
1122
752
|
return vec2(a.x * b.x - a.y * b.y, a.x * b.y + a.y * b.x);
|
|
1123
753
|
}`,wgsl:`fn _gpu_cmul(a: vec2f, b: vec2f) -> vec2f {
|
|
1124
754
|
return vec2f(a.x * b.x - a.y * b.y, a.x * b.y + a.y * b.x);
|
|
@@ -1226,12 +856,12 @@ fn _gpu_apca(bg: vec3f, fg: vec3f) -> f32 {
|
|
|
1226
856
|
let a = _gpu_cln(vec2f(1.0 + z.x, z.y));
|
|
1227
857
|
let b = _gpu_cln(vec2f(1.0 - z.x, -z.y));
|
|
1228
858
|
return vec2f(0.5 * (a.x - b.x), 0.5 * (a.y - b.y));
|
|
1229
|
-
}`}};function
|
|
859
|
+
}`}};function Gf(e,n){let t=new Set;for(let a of Object.keys(gr))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=gr[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(gr[a][s]);return`
|
|
1230
860
|
`+o.join(`
|
|
1231
861
|
|
|
1232
862
|
`)+`
|
|
1233
|
-
`}var
|
|
1234
|
-
`)},...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({
|
|
863
|
+
`}var jf={Pi:"3.14159265359",ExponentialE:"2.71828182846",GoldenRatio:"1.61803398875",CatalanConstant:"0.91596559417",EulerGamma:"0.57721566490"};function Kt(e){let n=e.toString();return!n.includes(".")&&!n.includes("e")&&!n.includes("E")?`${n}.0`:n}var dn=class{getOperators(){return hu}getFunctions(){return{...kf,...this.getLanguageSpecificFunctions()}}getConstants(){return jf}createTarget(n={}){let t=this.getFunctions(),i=this.getConstants(),r=this.languageId==="wgsl"?"vec2f":"vec2";return{language:this.languageId,operators:s=>hu[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:Kt,complex:(s,o)=>`${r}(${Kt(s)}, ${Kt(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+=Gf(l,this.languageId),l.includes("_gpu_gamma")&&(p+=Sf),l.includes("_gpu_erf")&&(p+=_f),l.includes("_gpu_heaviside")&&(p+=this.languageId==="wgsl"?wf:Mf),l.includes("_gpu_sinc")&&(p+=this.languageId==="wgsl"?$f:Af),l.includes("_gpu_fresnel")&&(p+=this.languageId==="wgsl"?Rf:Cf),l.includes("_gpu_fresnelC")&&(p+=this.languageId==="wgsl"?Pf:Df),l.includes("_gpu_fresnelS")&&(p+=this.languageId==="wgsl"?Of:Ff),l.includes("_gpu_besselJ")&&(p+=this.languageId==="wgsl"?Bf:Lf),l.includes("_fractal_")&&(p+=this.languageId==="wgsl"?Jf:Vf),(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"?zf:qf),p&&(c.preamble=p),c}compileToSource(n,t={}){let i=this.createTarget();return g.compile(n,i)}};function yu(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 Uf={Inversesqrt:"inversesqrt",Mod:"mod",List:yu,Matrix:(e,n)=>ei(e,n,t=>`vec${t}`,t=>`mat${t}`,t=>`float[${t}]`),Tuple:yu},br=class extends dn{languageId="glsl";getLanguageSpecificFunctions(){return Uf}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(`
|
|
1235
865
|
`)){let u=o.split(`
|
|
1236
866
|
`).map(l=>` ${l}`).join(`
|
|
1237
867
|
`);return`${i} ${t}(${a}) {
|
|
@@ -1242,40 +872,40 @@ ${u};
|
|
|
1242
872
|
|
|
1243
873
|
`;t==="fragment"&&(u+=`precision highp float;
|
|
1244
874
|
|
|
1245
|
-
`);let l=i.startsWith("300")||i.startsWith("3")?"in":t==="vertex"?"attribute":"varying";for(let
|
|
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};
|
|
1246
876
|
`;r.length>0&&(u+=`
|
|
1247
|
-
`);let c=i.startsWith("300")||i.startsWith("3")?"out":"varying";for(let
|
|
877
|
+
`);let c=i.startsWith("300")||i.startsWith("3")?"out":"varying";for(let p of s)u+=`${c} ${p.type} ${p.name};
|
|
1248
878
|
`;s.length>0&&(u+=`
|
|
1249
|
-
`);for(let
|
|
879
|
+
`);for(let p of o)u+=`uniform ${p.type} ${p.name};
|
|
1250
880
|
`;o.length>0&&(u+=`
|
|
1251
881
|
`),u+=`void main() {
|
|
1252
|
-
`;for(let
|
|
882
|
+
`;for(let p of a){let m=this.compileToSource(p.expression);u+=` ${p.variable} = ${m};
|
|
1253
883
|
`}return u+=`}
|
|
1254
|
-
`,u}};function
|
|
884
|
+
`,u}};function xu(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 Zf={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:xu,Matrix:(e,n)=>ei(e,n,t=>`vec${t}f`,t=>`mat${t}x${t}f`,t=>`array<f32, ${t}>`),Tuple:xu},Yf={float:"f32",int:"i32",uint:"u32",bool:"bool",vec2:"vec2f",vec3:"vec3f",vec4:"vec4f",mat2:"mat2x2f",mat3:"mat3x3f",mat4:"mat4x4f"};function Fn(e){return Yf[e]??e}var yr=class extends dn{languageId="wgsl";getLanguageSpecificFunctions(){return Zf}compileFunction(n,t,i,r){let s=this.createTarget(),o=g.compile(n,s),a=r.map(([u,l])=>`${u}: ${Fn(l)}`).join(", ");if(o.includes(`
|
|
1255
885
|
`)){let u=o.split(`
|
|
1256
886
|
`).map(l=>` ${l}`).join(`
|
|
1257
|
-
`);return`fn ${t}(${a}) -> ${
|
|
887
|
+
`);return`fn ${t}(${a}) -> ${Fn(i)} {
|
|
1258
888
|
${u};
|
|
1259
|
-
}`}return`fn ${t}(${a}) -> ${
|
|
889
|
+
}`}return`fn ${t}(${a}) -> ${Fn(i)} {
|
|
1260
890
|
return ${o};
|
|
1261
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 {
|
|
1262
|
-
`;for(let
|
|
892
|
+
`;for(let k of i){let w=k.builtin?`@builtin(${k.builtin})`:`@location(${k.location??0})`;u+=` ${w} ${k.name}: ${Fn(k.type)},
|
|
1263
893
|
`}u+=`};
|
|
1264
894
|
|
|
1265
895
|
`}if(r.length>0){u+=`struct ${t==="vertex"?"VertexOutput":"FragmentOutput"} {
|
|
1266
|
-
`;for(let
|
|
896
|
+
`;for(let w of r){let R=w.builtin?`@builtin(${w.builtin})`:`@location(${w.location??0})`;u+=` ${R} ${w.name}: ${Fn(w.type)},
|
|
1267
897
|
`}u+=`};
|
|
1268
898
|
|
|
1269
|
-
`}for(let
|
|
899
|
+
`}for(let k of s){let w=k.group??0,R=k.binding??0;u+=`@group(${w}) @binding(${R}) var<uniform> ${k.name}: ${Fn(k.type)};
|
|
1270
900
|
`}s.length>0&&(u+=`
|
|
1271
901
|
`);let l=`@${t}`,c=t==="compute"&&o?`@workgroup_size(${o.join(", ")})
|
|
1272
|
-
`:"",
|
|
1273
|
-
${c}fn main(${b})${
|
|
1274
|
-
`,
|
|
1275
|
-
`);for(let
|
|
1276
|
-
`}return
|
|
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;
|
|
1277
907
|
`),u+=`}
|
|
1278
|
-
`,u}};var
|
|
908
|
+
`,u}};var Eu={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]},vu={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(" * "),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"},xr=class{includeImports;useScipy;constructor(n={}){this.includeImports=n.includeImports??!1,this.useScipy=n.useScipy??!1}getOperators(){return Eu}getFunctions(){return vu}createTarget(n={}){return{language:"python",operators:t=>Eu[t],functions:t=>vu[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
|
|
1279
909
|
`;return s+=`import cmath
|
|
1280
910
|
`,this.useScipy&&(s+=`import scipy.special
|
|
1281
911
|
`),`${s}
|
|
@@ -1289,16 +919,16 @@ ${r}`}return r}compileFunction(n,t,i,r){let s=this.createTarget(),o=g.compile(n,
|
|
|
1289
919
|
`,u}compileVectorized(n,t,i,r){let o=this.compileFunction(n,`_${t}_scalar`,i,r)+`
|
|
1290
920
|
`;return o+=`# Vectorized version
|
|
1291
921
|
`,o+=`${t} = np.vectorize(_${t}_scalar)
|
|
1292
|
-
`,o}compileLambda(n,t){let i=this.createTarget(),r=g.compile(n,i);return`lambda ${t.join(", ")}: ${r}`}};function v(e){return{kind:"interval",value:e}}function xr(e){return{lo:e,hi:e}}function ae(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 Fn(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=Kt(r,s);return{kind:"partial",value:o,domainClipped:a}}return{kind:"interval",value:o}}function Kt(e,n){return e==="both"||n==="both"?"both":e===null?n:n===null||e===n?e:"both"}function Er(e){return e.lo===e.hi}function ce(e){return e.lo<=0&&e.hi>=0}function vr(e){return e.lo>0}function at(e){return e.hi<0}function Nr(e){return e.lo>=0}function Tr(e){return e.hi<=0}function Ir(e){return e.hi-e.lo}function _r(e){return(e.lo+e.hi)/2}function kr(e){if(e.kind==="interval"||e.kind==="partial")return e.value}function Sr(e){return"kind"in e?e.kind==="interval"||e.kind==="partial"?e.value:void 0:e}function I(...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 Mr(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return v({lo:i.lo+r.lo,hi:i.hi+r.hi})}function ut(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return v({lo:i.lo-r.hi,hi:i.hi-r.lo})}function wr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:-t.hi,hi:-t.lo})}function Ar(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 lt(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return v(Ar(i,r))}function fe(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return Kf(i,r)}function Kf(e,n){return n.lo>0||n.hi<0?v(Ar(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=I(e);if(!Array.isArray(n))return n;let[t]=n;return ep(t)}function ep(e){return e.hi<0?{kind:"empty"}:e.lo>=0?v({lo:Math.sqrt(e.lo),hi:Math.sqrt(e.hi)}):{kind:"partial",value:{lo:0,hi:Math.sqrt(e.hi)},domainClipped:"lo"}}function Cr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?v({lo:t.lo*t.lo,hi:t.hi*t.hi}):t.hi<=0?v({lo:t.hi*t.hi,hi:t.lo*t.lo}):v({lo:0,hi:Math.max(t.lo*t.lo,t.hi*t.hi)})}function Tu(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 ei(e,n){let t=I(e);if(!Array.isArray(t))return t;let[i]=t;if(Number.isInteger(n)){if(n>=0)return v(Tu(i,n));{if(ce(i))return{kind:"singular"};let r=Tu(i,-n);return v({lo:1/r.hi,hi:1/r.lo})}}else return at(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?v({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"}:v({lo:Math.pow(i.hi,n),hi:Math.pow(i.lo,n)})}function Rr(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(r.lo===r.hi&&Number.isInteger(r.lo))return ei(i,r.lo);if(i.hi<=0)return i.lo===-1&&i.hi===-1&&Math.floor(r.hi)>Math.floor(r.lo)?v({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 v({lo:Math.min(...s),hi:Math.max(...s)})}function Dr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:Math.exp(t.lo),hi:Math.exp(t.hi)})}function Pr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?v({lo:Math.log(t.lo),hi:Math.log(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log(t.hi)},domainClipped:"lo"}}function Fr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?v({lo:Math.log10(t.lo),hi:Math.log10(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log10(t.hi)},domainClipped:"lo"}}function Lr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?v({lo:Math.log2(t.lo),hi:Math.log2(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log2(t.hi)},domainClipped:"lo"}}function Or(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?v(t):t.hi<=0?v({lo:-t.hi,hi:-t.lo}):v({lo:0,hi:Math.max(-t.lo,t.hi)})}function Br(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.floor(t.lo),r=Math.floor(t.hi);return i===r?v({lo:i,hi:r}):{kind:"singular",at:i+1,continuity:"right"}}function Vr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.ceil(t.lo),r=Math.ceil(t.hi);return i===r?v({lo:i,hi:r}):{kind:"singular",at:i,continuity:"left"}}function ni(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.round(t.lo),r=Math.round(t.hi);return i===r?v({lo:i,hi:r}):{kind:"singular",at:i+.5,continuity:"right"}}function zr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.floor(t.lo),r=Math.floor(t.hi);return i===r?v({lo:t.lo-i,hi:t.hi-i}):{kind:"singular",at:i+1,continuity:"right"}}function Jr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.trunc(t.lo),r=Math.trunc(t.hi);if(i===r)return v({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 qr(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return v({lo:Math.min(i.lo,r.lo),hi:Math.min(i.hi,r.hi)})}function jr(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return v({lo:Math.max(i.lo,r.lo),hi:Math.max(i.hi,r.hi)})}function Gr(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(ce(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 v({lo:Math.min(u,l),hi:Math.max(u,l)})}function Zr(e,n){return ut(e,lt(n,ni(fe(e,n))))}function Ur(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>0?v({lo:1,hi:1}):t.hi<0?v({lo:0,hi:0}):t.lo===0&&t.hi===0?v({lo:.5,hi:.5}):{kind:"singular",at:0}}function Yr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>0?v({lo:1,hi:1}):t.hi<0?v({lo:-1,hi:-1}):t.lo===0&&t.hi===0?v({lo:0,hi:0}):{kind:"singular",at:0}}var Iu=1.4616321449683622,np=.8856031944108887;function Wr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return tp(t)}function tp(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=ie(e.lo),r=ie(e.hi);return v({lo:Math.min(i,r),hi:Math.max(i,r)})}return e.lo>=Iu?v({lo:ie(e.lo),hi:ie(e.hi)}):e.hi<=Iu?v({lo:ie(e.hi),hi:ie(e.lo)}):v({lo:np,hi:Math.max(ie(e.lo),ie(e.hi))})}function Hr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ip(t)}function ip(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=Ie(e.lo),r=Ie(e.hi);return v({lo:Math.min(i,r),hi:Math.max(i,r)})}return v({lo:Ie(e.lo),hi:Ie(e.hi)})}function Xr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=Vn(Math.round(t.lo)),r=Vn(Math.round(t.hi));return!Number.isFinite(i)||!Number.isFinite(r)?v({lo:Math.min(i,r),hi:Math.max(i,r)}):v({lo:i,hi:r})}function Qr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=zn(Math.round(t.lo)),r=zn(Math.round(t.hi));return!Number.isFinite(i)||!Number.isFinite(r)?v({lo:Math.min(i,r),hi:Math.max(i,r)}):v({lo:i,hi:r})}function _u(e,n){let t=I(e);if(!Array.isArray(t))return t;let i=I(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[fn(Math.round(r.lo),Math.round(s.lo)),fn(Math.round(r.lo),Math.round(s.hi)),fn(Math.round(r.hi),Math.round(s.lo)),fn(Math.round(r.hi),Math.round(s.hi))];return v({lo:Math.min(...o),hi:Math.max(...o)})}function ku(e,n){let t=I(e);if(!Array.isArray(t))return t;let i=I(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[ke(Math.round(r.lo),Math.round(s.lo)),ke(Math.round(r.lo),Math.round(s.hi)),ke(Math.round(r.hi),Math.round(s.lo)),ke(Math.round(r.hi),Math.round(s.hi))];return v({lo:Math.min(...o),hi:Math.max(...o)})}function Su(e,n){let t=I(e);if(!Array.isArray(t))return t;let i=I(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[Ue(Math.round(r.lo),Math.round(s.lo)),Ue(Math.round(r.lo),Math.round(s.hi)),Ue(Math.round(r.hi),Math.round(s.lo)),Ue(Math.round(r.hi),Math.round(s.hi))];return v({lo:Math.min(...o),hi:Math.max(...o)})}function Mu(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:Jn(t.lo),hi:Jn(t.hi)})}function wu(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:Dn(t.lo),hi:Dn(t.hi)})}function Au(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:st(t.hi),hi:st(t.lo)})}function $u(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:Math.pow(2,t.lo),hi:Math.pow(2,t.hi)})}function Cu(e,n){let t=I(e);if(!Array.isArray(t))return t;let i=I(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),v({lo:a,hi:Math.max(...o)})}var Re=2*Math.PI,re=Math.PI,nn=Math.PI/2,Ru=3*Math.PI/2;function es(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=Re)return v({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 ae(t,nn,Re)&&(o=1),ae(t,Ru,Re)&&(s=-1),v({lo:s,hi:o})}function ns(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=Re)return v({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 ae(t,0,Re)&&(o=1),ae(t,re,Re)&&(s=-1),v({lo:s,hi:o})}function ts(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=re)return{kind:"singular"};if(ae(t,nn,re)){let s=Math.ceil((t.lo-nn)/re);return{kind:"singular",at:nn+s*re}}let i=Math.tan(t.lo),r=Math.tan(t.hi);return i>1e10&&r<-1e10||i<-1e10&&r>1e10?{kind:"singular"}:v({lo:i,hi:r})}function is(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=re)return{kind:"singular"};if(ae(t,0,re))return{kind:"singular",at:Math.ceil(t.lo/re)*re};let i=1/Math.tan(t.lo),r=1/Math.tan(t.hi);return v({lo:Math.min(i,r),hi:Math.max(i,r)})}function rs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=re)return{kind:"singular"};if(ae(t,nn,re)){let a=Math.ceil((t.lo-nn)/re);return{kind:"singular",at:nn+a*re}}let i=1/Math.cos(t.lo),r=1/Math.cos(t.hi),s=Math.min(i,r),o=Math.max(i,r);return ae(t,0,Re)&&(s=Math.min(s,1),o=Math.max(o,1)),ae(t,re,Re)&&(s=Math.min(s,-1),o=Math.max(o,-1)),v({lo:s,hi:o})}function ss(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=re)return{kind:"singular"};if(ae(t,0,re))return{kind:"singular",at:Math.ceil(t.lo/re)*re};let i=1/Math.sin(t.lo),r=1/Math.sin(t.hi),s=Math.min(i,r),o=Math.max(i,r);return ae(t,nn,Re)&&(s=Math.min(s,1),o=Math.max(o,1)),ae(t,Ru,Re)&&(s=Math.min(s,-1),o=Math.max(o,-1)),v({lo:s,hi:o})}function ti(e){let n=I(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 v({lo:Math.asin(t.lo),hi:Math.asin(t.hi)})}function ii(e){let n=I(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 v({lo:Math.acos(t.hi),hi:Math.acos(t.lo)})}function ri(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:Math.atan(t.lo),hi:Math.atan(t.hi)})}function os(e,n){let t=I(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 v({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?v({lo:-re,hi:re}):v({lo:Math.min(...s),hi:Math.max(...s)})}function ct(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:Math.sinh(t.lo),hi:Math.sinh(t.hi)})}function ft(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?v({lo:Math.cosh(t.lo),hi:Math.cosh(t.hi)}):t.hi<=0?v({lo:Math.cosh(t.hi),hi:Math.cosh(t.lo)}):v({lo:1,hi:Math.max(Math.cosh(t.lo),Math.cosh(t.hi))})}function as(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:Math.tanh(t.lo),hi:Math.tanh(t.hi)})}function si(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return v({lo:Math.asinh(t.lo),hi:Math.asinh(t.hi)})}function oi(e){let n=I(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"}:v({lo:Math.acosh(t.lo),hi:Math.acosh(t.hi)})}function ai(e){let n=I(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 v({lo:Math.atanh(t.lo),hi:Math.atanh(t.hi)})}function us(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:ri(fe(v({lo:1,hi:1}),v(t)))}function ls(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:ti(fe(v({lo:1,hi:1}),v(t)))}function cs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:ii(fe(v({lo:1,hi:1}),v(t)))}function fs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:fe(ft(t),ct(t))}function ps(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:fe(v({lo:1,hi:1}),ct(t))}function ds(e){return fe(v({lo:1,hi:1}),ft(e))}function ms(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:ai(fe(v({lo:1,hi:1}),v(t)))}function hs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:si(fe(v({lo:1,hi:1}),v(t)))}function gs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:oi(fe(v({lo:1,hi:1}),v(t)))}var Kr=[4.49341,7.72525,10.90412,14.06619,17.22076,20.3713,23.51945,26.66605,29.8116,32.95639],rp=-.21724;function bs(e){let n=I(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=Kr[Kr.length-1];for(let u of Kr)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(rp),v({lo:r,hi:s})}var Du=[],Pu=[];for(let e=1;e<=20;e++)Du.push(Math.sqrt(2*e)),Pu.push(Math.sqrt(2*e-1));function ys(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=ln(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(ln(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of Du)o>=t.lo&&o<=t.hi&&s(ln(o)),-o>=t.lo&&-o<=t.hi&&s(ln(-o));return v({lo:i,hi:r})}function xs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=cn(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(cn(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of Pu)o>=t.lo&&o<=t.hi&&s(cn(o)),-o>=t.lo&&-o<=t.hi&&s(cn(-o));return v({lo:i,hi:r})}function tn(e){return"kind"in e?e:{kind:"interval",value:e}}function Es(e,n){let t=I(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 vs(e,n){let t=I(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 Ns(e,n){let t=I(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 Ts(e,n){let t=I(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 ui(e,n){let t=I(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 Is(e,n){let t=ui(e,n);return t==="true"?"false":t==="false"?"true":"maybe"}function _s(e,n){return e==="false"||n==="false"?"false":e==="true"&&n==="true"?"true":"maybe"}function ks(e,n){return e==="true"||n==="true"?"true":e==="false"&&n==="false"?"false":"maybe"}function Ss(e){return e==="true"?"false":e==="false"?"true":"maybe"}function Ms(e,n,t,i){if(e==="true"||e==="false"||e==="maybe"){let f=e,d=n,m=t;switch(f){case"true":return tn(d());case"false":return tn(m());case"maybe":return Fn(tn(d()),tn(m()))}}let r=e,s=n,o=t,a=i,u=I(r);if(!Array.isArray(u))return u;let[l]=u;switch(s(l)){case"true":return tn(o(l));case"false":return tn(a(l));case"maybe":let f=tn(o(l)),d=tn(a(l));return Fn(f,d)}}function ws(e,n,t){let i=I(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 Fu={ok:v,point:xr,containsExtremum:ae,unionResults:Fn,mergeDomainClip:Kt,isPoint:Er,containsZero:ce,isPositive:vr,isNegative:at,isNonNegative:Nr,isNonPositive:Tr,width:Ir,midpoint:_r,getValue:kr,unwrap:Sr,unwrapOrPropagate:I,add:Mr,sub:ut,mul:lt,div:fe,negate:wr,sqrt:$r,square:Cr,pow:ei,powInterval:Rr,exp:Dr,ln:Pr,log10:Fr,log2:Lr,abs:Or,floor:Br,ceil:Vr,round:ni,fract:zr,trunc:Jr,min:qr,max:jr,mod:Gr,remainder:Zr,heaviside:Ur,sign:Yr,gamma:Wr,gammaln:Hr,factorial:Xr,factorial2:Qr,binomial:_u,gcd:ku,lcm:Su,chop:Mu,erf:wu,erfc:Au,exp2:$u,hypot:Cu,sin:es,cos:ns,tan:ts,cot:is,sec:rs,csc:ss,asin:ti,acos:ii,atan:ri,atan2:os,sinh:ct,cosh:ft,tanh:as,asinh:si,acosh:oi,atanh:ai,acot:us,acsc:ls,asec:cs,coth:fs,csch:ps,sech:ds,acoth:ms,acsch:hs,asech:gs,sinc:bs,fresnelS:ys,fresnelC:xs,less:Es,lessEqual:vs,greater:Ns,greaterEqual:Ts,equal:ui,notEqual:Is,and:_s,or:ks,not:Ss,piecewise:Ms,clamp:ws};var sp={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]},As={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},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(k(t,"ExponentialE"))return`_IA.exp(${n(i)})`;if(L(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)})`:L(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)=>Ou("Sum",e,n,t),Product:(e,n,t)=>Ou("Product",e,n,t),If:(e,n)=>{if(e.length!==3)throw new Error("If: wrong number of arguments");return`_IA.piecewise(
|
|
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 Er(e){return{lo:e,hi:e}}function ae(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 On(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=ni(r,s);return{kind:"partial",value:o,domainClipped:a}}return{kind:"interval",value:o}}function ni(e,n){return e==="both"||n==="both"?"both":e===null?n:n===null||e===n?e:"both"}function vr(e){return e.lo===e.hi}function ce(e){return e.lo<=0&&e.hi>=0}function Nr(e){return e.lo>0}function lt(e){return e.hi<0}function Tr(e){return e.lo>=0}function Ir(e){return e.hi<=0}function kr(e){return e.hi-e.lo}function Sr(e){return(e.lo+e.hi)/2}function _r(e){if(e.kind==="interval"||e.kind==="partial")return e.value}function Mr(e){return"kind"in e?e.kind==="interval"||e.kind==="partial"?e.value:void 0:e}function I(...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 wr(e,n){let t=I(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 ct(e,n){let t=I(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 Ar(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:-t.hi,hi:-t.lo})}function $r(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 ft(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return E($r(i,r))}function fe(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return Hf(i,r)}function Hf(e,n){return n.lo>0||n.hi<0?E($r(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 Cr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return Wf(t)}function Wf(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 Rr(e){let n=I(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 Nu(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 ti(e,n){let t=I(e);if(!Array.isArray(t))return t;let[i]=t;if(Number.isInteger(n)){if(n>=0)return E(Nu(i,n));{if(ce(i))return{kind:"singular"};let r=Nu(i,-n);return E({lo:1/r.hi,hi:1/r.lo})}}else return lt(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 Dr(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(r.lo===r.hi&&Number.isInteger(r.lo))return ti(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 Pr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.exp(t.lo),hi:Math.exp(t.hi)})}function Fr(e){let n=I(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 Or(e){let n=I(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 Lr(e){let n=I(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 Br(e){let n=I(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 Vr(e){let n=I(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 Jr(e){let n=I(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 ii(e){let n=I(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 qr(e){let n=I(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 zr(e){let n=I(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 Gr(e,n){let t=I(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 jr(e,n){let t=I(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 Ur(e,n){let t=I(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(ce(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 Zr(e,n){return ct(e,ft(n,ii(fe(e,n))))}function Yr(e){let n=I(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 Hr(e){let n=I(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 Tu=1.4616321449683622,Xf=.8856031944108887;function Wr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return Qf(t)}function Qf(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=ie(e.lo),r=ie(e.hi);return E({lo:Math.min(i,r),hi:Math.max(i,r)})}return e.lo>=Tu?E({lo:ie(e.lo),hi:ie(e.hi)}):e.hi<=Tu?E({lo:ie(e.hi),hi:ie(e.lo)}):E({lo:Xf,hi:Math.max(ie(e.lo),ie(e.hi))})}function Xr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return Kf(t)}function Kf(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=Ie(e.lo),r=Ie(e.hi);return E({lo:Math.min(i,r),hi:Math.max(i,r)})}return E({lo:Ie(e.lo),hi:Ie(e.hi)})}function Qr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=Jn(Math.round(t.lo)),r=Jn(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 Kr(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=qn(Math.round(t.lo)),r=qn(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 Iu(e,n){let t=I(e);if(!Array.isArray(t))return t;let i=I(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[pn(Math.round(r.lo),Math.round(s.lo)),pn(Math.round(r.lo),Math.round(s.hi)),pn(Math.round(r.hi),Math.round(s.lo)),pn(Math.round(r.hi),Math.round(s.hi))];return E({lo:Math.min(...o),hi:Math.max(...o)})}function ku(e,n){let t=I(e);if(!Array.isArray(t))return t;let i=I(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[Se(Math.round(r.lo),Math.round(s.lo)),Se(Math.round(r.lo),Math.round(s.hi)),Se(Math.round(r.hi),Math.round(s.lo)),Se(Math.round(r.hi),Math.round(s.hi))];return E({lo:Math.min(...o),hi:Math.max(...o)})}function Su(e,n){let t=I(e);if(!Array.isArray(t))return t;let i=I(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[Ye(Math.round(r.lo),Math.round(s.lo)),Ye(Math.round(r.lo),Math.round(s.hi)),Ye(Math.round(r.hi),Math.round(s.lo)),Ye(Math.round(r.hi),Math.round(s.hi))];return E({lo:Math.min(...o),hi:Math.max(...o)})}function _u(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:zn(t.lo),hi:zn(t.hi)})}function Mu(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Pn(t.lo),hi:Pn(t.hi)})}function wu(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:at(t.hi),hi:at(t.lo)})}function Au(e){let n=I(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 $u(e,n){let t=I(e);if(!Array.isArray(t))return t;let i=I(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 De=2*Math.PI,re=Math.PI,tn=Math.PI/2,Cu=3*Math.PI/2;function ns(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=De)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 ae(t,tn,De)&&(o=1),ae(t,Cu,De)&&(s=-1),E({lo:s,hi:o})}function ts(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=De)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 ae(t,0,De)&&(o=1),ae(t,re,De)&&(s=-1),E({lo:s,hi:o})}function is(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=re)return{kind:"singular"};if(ae(t,tn,re)){let s=Math.ceil((t.lo-tn)/re);return{kind:"singular",at:tn+s*re}}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 rs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=re)return{kind:"singular"};if(ae(t,0,re))return{kind:"singular",at:Math.ceil(t.lo/re)*re};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 ss(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=re)return{kind:"singular"};if(ae(t,tn,re)){let a=Math.ceil((t.lo-tn)/re);return{kind:"singular",at:tn+a*re}}let i=1/Math.cos(t.lo),r=1/Math.cos(t.hi),s=Math.min(i,r),o=Math.max(i,r);return ae(t,0,De)&&(s=Math.min(s,1),o=Math.max(o,1)),ae(t,re,De)&&(s=Math.min(s,-1),o=Math.max(o,-1)),E({lo:s,hi:o})}function os(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=re)return{kind:"singular"};if(ae(t,0,re))return{kind:"singular",at:Math.ceil(t.lo/re)*re};let i=1/Math.sin(t.lo),r=1/Math.sin(t.hi),s=Math.min(i,r),o=Math.max(i,r);return ae(t,tn,De)&&(s=Math.min(s,1),o=Math.max(o,1)),ae(t,Cu,De)&&(s=Math.min(s,-1),o=Math.max(o,-1)),E({lo:s,hi:o})}function ri(e){let n=I(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 si(e){let n=I(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 oi(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.atan(t.lo),hi:Math.atan(t.hi)})}function as(e,n){let t=I(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:-re,hi:re}):E({lo:Math.min(...s),hi:Math.max(...s)})}function pt(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.sinh(t.lo),hi:Math.sinh(t.hi)})}function mt(e){let n=I(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 us(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.tanh(t.lo),hi:Math.tanh(t.hi)})}function ai(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return E({lo:Math.asinh(t.lo),hi:Math.asinh(t.hi)})}function ui(e){let n=I(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 li(e){let n=I(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 ls(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:oi(fe(E({lo:1,hi:1}),E(t)))}function cs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:ri(fe(E({lo:1,hi:1}),E(t)))}function fs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:si(fe(E({lo:1,hi:1}),E(t)))}function ps(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:fe(mt(t),pt(t))}function ms(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:fe(E({lo:1,hi:1}),pt(t))}function ds(e){return fe(E({lo:1,hi:1}),mt(e))}function hs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:li(fe(E({lo:1,hi:1}),E(t)))}function gs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:ai(fe(E({lo:1,hi:1}),E(t)))}function bs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n;return ce(t)?{kind:"singular",at:0}:ui(fe(E({lo:1,hi:1}),E(t)))}var es=[4.49341,7.72525,10.90412,14.06619,17.22076,20.3713,23.51945,26.66605,29.8116,32.95639],ep=-.21724;function ys(e){let n=I(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=es[es.length-1];for(let u of es)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(ep),E({lo:r,hi:s})}var Ru=[],Du=[];for(let e=1;e<=20;e++)Ru.push(Math.sqrt(2*e)),Du.push(Math.sqrt(2*e-1));function xs(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=cn(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(cn(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of Ru)o>=t.lo&&o<=t.hi&&s(cn(o)),-o>=t.lo&&-o<=t.hi&&s(cn(-o));return E({lo:i,hi:r})}function Es(e){let n=I(e);if(!Array.isArray(n))return n;let[t]=n,i=fn(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(fn(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of Du)o>=t.lo&&o<=t.hi&&s(fn(o)),-o>=t.lo&&-o<=t.hi&&s(fn(-o));return E({lo:i,hi:r})}function rn(e){return"kind"in e?e:{kind:"interval",value:e}}function vs(e,n){let t=I(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 Ns(e,n){let t=I(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 Ts(e,n){let t=I(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 Is(e,n){let t=I(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 ci(e,n){let t=I(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 ks(e,n){let t=ci(e,n);return t==="true"?"false":t==="false"?"true":"maybe"}function Ss(e,n){return e==="false"||n==="false"?"false":e==="true"&&n==="true"?"true":"maybe"}function _s(e,n){return e==="true"||n==="true"?"true":e==="false"&&n==="false"?"false":"maybe"}function Ms(e){return e==="true"?"false":e==="false"?"true":"maybe"}function ws(e,n,t,i){if(e==="true"||e==="false"||e==="maybe"){let p=e,m=n,d=t;switch(p){case"true":return rn(m());case"false":return rn(d());case"maybe":return On(rn(m()),rn(d()))}}let r=e,s=n,o=t,a=i,u=I(r);if(!Array.isArray(u))return u;let[l]=u;switch(s(l)){case"true":return rn(o(l));case"false":return rn(a(l));case"maybe":let p=rn(o(l)),m=rn(a(l));return On(p,m)}}function As(e,n,t){let i=I(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 Pu={ok:E,point:Er,containsExtremum:ae,unionResults:On,mergeDomainClip:ni,isPoint:vr,containsZero:ce,isPositive:Nr,isNegative:lt,isNonNegative:Tr,isNonPositive:Ir,width:kr,midpoint:Sr,getValue:_r,unwrap:Mr,unwrapOrPropagate:I,add:wr,sub:ct,mul:ft,div:fe,negate:Ar,sqrt:Cr,square:Rr,pow:ti,powInterval:Dr,exp:Pr,ln:Fr,log10:Or,log2:Lr,abs:Br,floor:Vr,ceil:Jr,round:ii,fract:qr,trunc:zr,min:Gr,max:jr,mod:Ur,remainder:Zr,heaviside:Yr,sign:Hr,gamma:Wr,gammaln:Xr,factorial:Qr,factorial2:Kr,binomial:Iu,gcd:ku,lcm:Su,chop:_u,erf:Mu,erfc:wu,exp2:Au,hypot:$u,sin:ns,cos:ts,tan:is,cot:rs,sec:ss,csc:os,asin:ri,acos:si,atan:oi,atan2:as,sinh:pt,cosh:mt,tanh:us,asinh:ai,acosh:ui,atanh:li,acot:ls,acsc:cs,asec:fs,coth:ps,csch:ms,sech:ds,acoth:hs,acsch:gs,asech:bs,sinc:ys,fresnelS:xs,fresnelC:Es,less:vs,lessEqual:Ns,greater:Ts,greaterEqual:Is,equal:ci,notEqual:ks,and:Ss,or:_s,not:Ms,piecewise:ws,clamp:As};var np={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]},$s={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},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(S(t,"ExponentialE"))return`_IA.exp(${n(i)})`;if(O(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)})`:O(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)=>Ou("Sum",e,n,t),Product:(e,n,t)=>Ou("Product",e,n,t),If:(e,n)=>{if(e.length!==3)throw new Error("If: wrong number of arguments");return`_IA.piecewise(
|
|
1293
923
|
${n(e[0])},
|
|
1294
924
|
() => ${n(e[1])},
|
|
1295
925
|
() => ${n(e[2])}
|
|
1296
|
-
)`},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
|
|
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 S(r,"True")?n(s):`_IA.piecewise(
|
|
1297
927
|
${n(r)},
|
|
1298
928
|
() => ${n(s)},
|
|
1299
929
|
() => ${t(i+2)}
|
|
1300
|
-
)`};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])})`},
|
|
1301
|
-
`,a[c]=c):typeof
|
|
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])})`},tp=100;function ip(e){e.operator;let n=e,t=S(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 Fu(e,n,t){return n!==void 0?String(n):`Math.floor((${g.compile(e,t)}).hi)`}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}=ip(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<=tp){let R=[];for(let B=a;B<=u;B++){let Q={...i,var:Z=>Z===r?`_IA.point(${B})`:i.var(Z)};R.push(g.compile(n[0],Q))}let P=R[R.length-1];for(let B=R.length-2;B>=0;B--)P=`${c}(${R[B]}, ${P})`;return P}let d=Fu(s,a,i),b=Fu(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 Cs=class extends Function{IA=Pu;constructor(n,t=""){return super("_IA","_",t?`${t};return ${n}`:`return ${n}`),new Proxy(this,{apply:(i,r,s)=>{try{let o=s.map(Bu);return super.apply(r,[this.IA,...o])}catch{return{kind:"entire"}}},get:(i,r)=>r==="toString"?()=>n:r==="isCompiled"?!0:i[r]})}};function Lu(e){return e!==null&&typeof e=="object"}function rp(e){return Lu(e)&&"lo"in e&&"hi"in e}function Bu(e){if(e==null||rp(e))return e;if(Lu(e)){let n={};for(let[t,i]of Object.entries(e))n[t]=Bu(i);return n}return typeof e=="number"?{lo:e,hi:e}:e}var Rs=class{getOperators(){return np}getFunctions(){return $s}createTarget(n={}){return{language:"interval-javascript",operators:()=>{},functions:t=>$s[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]:$s[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 sp(n,l)}};function sp(e,n){let t;try{t=g.compile(e,n)}catch{return{target:"interval-js",success:!1,code:""}}let i=new Cs(t,n.preamble);return{target:"interval-js",success:!0,code:t,calling:"expression",run:i}}var L2="0.55.6";export{g as BaseCompiler,br as GLSLTarget,dn as GPUShaderTarget,Rs as IntervalJavaScriptTarget,dr as JavaScriptTarget,xr as PythonTarget,yr as WGSLTarget,Ic as compile,L2 as version};
|
|
1302
932
|
/*! Bundled license information:
|
|
1303
933
|
|
|
1304
934
|
complex-esm/dist/src/complex.js:
|