@cortex-js/compute-engine 0.55.2 → 0.55.4
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 +908 -176
- package/dist/compile.min.esm.js +441 -71
- package/dist/compile.min.umd.cjs +442 -72
- package/dist/compile.umd.cjs +908 -176
- package/dist/compute-engine.esm.js +954 -185
- package/dist/compute-engine.min.esm.js +444 -74
- package/dist/compute-engine.min.umd.cjs +444 -74
- package/dist/compute-engine.umd.cjs +954 -185
- package/dist/core.esm.js +951 -174
- package/dist/core.min.esm.js +442 -72
- package/dist/core.min.umd.cjs +442 -72
- package/dist/core.umd.cjs +951 -174
- package/dist/interval.esm.js +2 -2
- package/dist/interval.min.esm.js +2 -2
- package/dist/interval.min.umd.cjs +2 -2
- package/dist/interval.umd.cjs +2 -2
- package/dist/latex-syntax.esm.js +43 -13
- package/dist/latex-syntax.min.esm.js +5 -5
- package/dist/latex-syntax.min.umd.cjs +5 -5
- package/dist/latex-syntax.umd.cjs +43 -13
- 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 +8 -7
- package/dist/types/compute-engine/compilation/compile-expression.d.ts +1 -1
- package/dist/types/compute-engine/compilation/constant-folding.d.ts +50 -0
- package/dist/types/compute-engine/compilation/fractal-orbit.d.ts +13 -0
- package/dist/types/compute-engine/compilation/glsl-target.d.ts +1 -1
- package/dist/types/compute-engine/compilation/gpu-target.d.ts +47 -1
- package/dist/types/compute-engine/compilation/interval-javascript-target.d.ts +1 -1
- package/dist/types/compute-engine/compilation/javascript-target.d.ts +23 -1
- package/dist/types/compute-engine/compilation/python-target.d.ts +1 -1
- package/dist/types/compute-engine/compilation/types.d.ts +48 -1
- package/dist/types/compute-engine/compilation/wgsl-target.d.ts +1 -1
- package/dist/types/compute-engine/cost-function.d.ts +1 -1
- package/dist/types/compute-engine/engine-assumptions.d.ts +1 -1
- package/dist/types/compute-engine/engine-cache.d.ts +1 -1
- package/dist/types/compute-engine/engine-common-symbols.d.ts +1 -1
- package/dist/types/compute-engine/engine-compilation-targets.d.ts +1 -1
- package/dist/types/compute-engine/engine-configuration-lifecycle.d.ts +1 -1
- package/dist/types/compute-engine/engine-declarations.d.ts +1 -1
- package/dist/types/compute-engine/engine-expression-entrypoints.d.ts +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 +1 -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 +1 -1
- 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 +1 -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 +3 -3
package/dist/interval.min.esm.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
/** Compute Engine 0.55.
|
|
1
|
+
/** Compute Engine 0.55.4 */
|
|
2
2
|
function d(e){return{kind:"interval",value:e}}function En(e){return{lo:e,hi:e}}function J(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 Ne(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=We(r,s);return{kind:"partial",value:o,domainClipped:a}}return{kind:"interval",value:o}}function We(e,n){return e==="both"||n==="both"?"both":e===null?n:n===null||e===n?e:"both"}function Tn(e){return e.lo===e.hi}function z(e){return e.lo<=0&&e.hi>=0}function vn(e){return e.lo>0}function Se(e){return e.hi<0}function In(e){return e.lo>=0}function kn(e){return e.hi<=0}function Sn(e){return e.hi-e.lo}function Mn(e){return(e.lo+e.hi)/2}function wn(e){if(e.kind==="interval"||e.kind==="partial")return e.value}function Dn(e){return"kind"in e?e.kind==="interval"||e.kind==="partial"?e.value:void 0:e}function y(...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 An(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return d({lo:i.lo+r.lo,hi:i.hi+r.hi})}function Me(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return d({lo:i.lo-r.hi,hi:i.hi-r.lo})}function Pn(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:-t.hi,hi:-t.lo})}function _n(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 we(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return d(_n(i,r))}function G(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return ks(i,r)}function ks(e,n){return n.lo>0||n.hi<0?d(_n(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"}}var Wi=new Map;function S(e){if(e<=100){let n=Wi.get(e);return n===void 0&&(n=10n**BigInt(e),Wi.set(e,n)),n}return 10n**BigInt(e)}function Yi(e,n,t){return e*n/t}function Xi(e,n,t){return e*t/n}function Ye(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 p=Math.sqrt(i/r)*r;Number.isFinite(p)&&p>0?(t=BigInt(Math.floor(p)),t===0n&&(t=1n)):t=Hi(e,n)}else t=Hi(e,n);let s=e*n,o;do o=t,t=(t+s/t)/2n;while(ee(t-o)>1n);let a=(t+s/t)/2n,u=ee(t*t-s);return ee(a*a-s)<u?a:t}function Hi(e,n){let i=O(e),r=Math.max(0,i-15),s=Number(r>0?e/S(r):e),o=O(n),a=Math.max(0,o-15),u=Number(a>0?n/S(a):n),c=r+a,p=Math.floor(c/2),h=Math.sqrt(s*u);c%2!==0&&(h*=3.1622776601683795);let N=BigInt(Math.round(h))*S(p);return N>0n?N:1n}function ee(e){return e<0n?-e:e}function O(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<S(r-1)?r-1:e>=S(r)?r+1:r}function ui(e,n){if(e===0n)return n;let t=0,i=e,r=n/2n;for(;ee(i)>r;)i=i/2n,t++;let s=n,o=i;s+=o;for(let a=2;o=o*i/(BigInt(a)*n),ee(o)!==0n;a++)s+=o;for(let a=0;a<t;a++)s=s*s/n;return s}function Ki(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 c=Math.log(u);Number.isFinite(c)?r=BigInt(Math.round(c*i)):r=oi(e,n)}else r=oi(e,n)}else{s=e;let u=2n*n,c=n/2n;for(;s>u||s<c;)s=Ye(s,n),o++;r=oi(s,n)}let a=0n;for(let u=0;u<100;u++){let c=ui(r,n);if(c===0n){r=r/2n;continue}let p=r+s*n/c-n,h=ee(p-r);if(h<=1n||h<100000n&&a>0n&&a<100000n&&h*4n>=a)break;a=h,r=p}for(let u=0;u<o;u++)r=2n*r;return r}function oi(e,n){let t=O(e),i=O(n);return BigInt(t-i)*2302585n*n/1000000n}var Bn="314159265358979323846264338327950288419716939937510582097494459230781640628620899862803482534211706798214808651328230664709384460955058223172535940812848111745028410270193852110555964462294895493038196442881097566593344612847564823378678316527120190914564856692346034861045432664821339360726024914127372458700660631558817488152092096282925409171536436789259036001133053054882046652138414695194151160943305727036575959195309218611738193261179310511854807446237996274956735188575272489122793818301194912983367336244065664308602139494639522473719070217986094370277053921717629317675238467481846766940513200056812714526356082778577134275778960917363717872146844090122495343014654958537105079227968925892354201995611212902196086403441815981362977477130996051870721134999999837297804995105973173281609631859502445945534690830264252230825334468503526193118817101000313783875288658753320838142061717766914730359825349042875546873115956286388235378759375195778185778053217122680661300192787661119590921642019893809525720106548586327886593615338182796823030195203530185296899577362259941389124972177528347913151557485724245415069595082953311686172785588907509838175463746493931925506040092770167113900984882401285836160356370766010471018194295559619894676783744944825537977472684710404753464620804668425906949129331367702898915210475216205696602405803815019351125338243003558764024749647326391419927260426992279678235478163600934172164121992458631503028618297455570674983850549458858692699569092721079750930295532116534498720275596023648066549911988183479775356636980742654252786255181841757467289097777279380008164706001614524919217321721477235014144197356854816136115735255213347574184946843852332390739414333454776241686251898356948556209921922218427255025425688767179049460165346680498862723279178608578438382796797668145410095388378636095068006422512520511739298489608412848862694560424196528502221066118630674427862203919494504712371378696095636437191728746776465757396241389086583264599581339047802759009946576407895126946839835259570982582262052248940772671947826848260147699090264013639443745530506820349625245174939965143142980919065925093722169646151570985838741059788595977297549893016175392846813826868386894277415599185592524595395943104997252468084598727364469584865383673622262609912460805124388439045124413654976278079771569143599770012961608944169486855584840635",Rn=null;function ai(e){if(Rn!==null&&Rn.scale===e)return Rn.value;let t=O(e)-1+10,i=Bn.slice(0,t+1),r=BigInt(i),s=i.length-1,o=r*e/S(s);return Rn={scale:e,value:o},o}function Cn(e,n){if(e===0n)return[0n,n];let t=ai(n),i=2n*t,r=t/2n,s,o=ee(e);if(o>n*(1n<<30n)){let q=O(o)-O(n)+20,ii=n*S(q),ri=e*S(q),Ui=2n*ai(ii),si=ri%Ui;si<0n&&(si+=Ui),s=si/S(q)}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 c=O(n)-1,p=Math.min(18,Math.max(2,Math.ceil(.87*Math.sqrt(c)))),h=0,N=n>>BigInt(p);for(;s>N;)s=s/2n,h++;let v=s,M=n,B=s,ae=n,Ue=s*s,ti=n*n;for(let q=2;;q+=2){if(ae=ae*Ue/(BigInt(q)*BigInt(q-1)*ti),ae===0n){B=B*Ue/(BigInt(q+1)*BigInt(q)*ti),B!==0n&&(q%4===2?(M-=ae,v-=B):(M+=ae,v+=B));break}if(B=B*Ue/(BigInt(q+1)*BigInt(q)*ti),q%4===2?(M-=ae,v-=B):(M+=ae,v+=B),B===0n)break}for(let q=0;q<h;q++){let ii=2n*v*M/n,ri=2n*M*M/n-n;v=ii,M=ri}return[a*v,u*M]}function He(e,n){if(e===0n)return 0n;if(e<0n)return-He(-e,n);let i=ai(n)/2n;if(e>n){let h=n*n/e;return i-He(h,n)}let r=4n*n/10n,s=0,o=e;for(;o>r;){let h=o*o,N=(n*n+h)/n,v=Ye(N,n);o=o*n/(n+v),s++}let a=o,u=o,c=o*o,p=n*n;for(let h=3;u=u*c/p,u!==0n;h+=2)h%4===3?a-=u/BigInt(h):a+=u/BigInt(h);for(let h=0;h<s;h++)a=2n*a;return a}var li=NaN,m=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(Bn[0]+"."+Bn.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]=On(n,0);return}if(typeof n=="number"){[this.significand,this.exponent]=Ss(n);return}[this.significand,this.exponent]=nr(n)}isNaN(){return Number.isNaN(this.exponent)}isZero(){return this.exponent===0&&this.significand===0n}isFinite(){return Number.isFinite(this.exponent)}isInteger(){return this.isFinite()&&this.exponent>=0}isPositive(){return this.significand>0n}isNegative(){return this.significand<0n}cmp(n){if(typeof n=="number"){if(Number.isNaN(n))return li;let v=this.exponent;if(Number.isNaN(v))return li;if(n===0)return this.significand===0n?0:this.significand>0n?1:-1;if(!Number.isFinite(v))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)&&v>=0&&v<=15){let M=this.significand*S(v),B=BigInt(n);return M<B?-1:M>B?1:0}n=new e(n)}let t=this.exponent,i=n.exponent,r=this.significand,s=n.significand;if(t!==t||i!==i)return li;if(!Number.isFinite(t)||!Number.isFinite(i))return!Number.isFinite(t)&&!Number.isFinite(i)?r===s?0:r>s?1:-1:Number.isFinite(t)?s>0n?-1:1:r>0n?1:-1;if(r===0n)return s===0n?0:s>0n?-1:1;if(s===0n)return r>0n?1:-1;if(r>0n&&s<0n)return 1;if(r<0n&&s>0n)return-1;if(t===i)return r<s?-1:r>s?1:0;let o=O(r),a=O(s),u=o+t,c=a+i;if(u!==c){let v=r>0n?1:-1;return u>c?v:-v}let p=r,h=s,N=Math.abs(t-i);if(N>1e3){let v=o,M=a,B=Math.max(v,M)+1;v<B&&(p=p*S(B-v)),M<B&&(h=h*S(B-M))}else t<i?h=h*S(N):p=p*S(N);return p<h?-1:p>h?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*S(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 D(this.significand+n.significand,t);let o=t-i;return o>0?D(this.significand*S(o)+n.significand,i):D(this.significand+n.significand*S(-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 D(this.significand-n.significand,t);let o=t-i;return o>0?D(this.significand*S(o)-n.significand,i):D(this.significand-n.significand*S(-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 D(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)?D(-n,this.exponent):n>0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY}abs(){return this.significand>=0n?this:Number.isFinite(this.exponent)?D(-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(D(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(D(1n,0)):t}return this}round(){let n=this.exponent;if(n>=0)return this;if(Number.isFinite(n)){let t=D(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/S(-n);return D(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 D(0n,0);let u=e.precision,c=10,p=r<0n?-r:r,h=s<0n?-s:s,N=O(p),v=O(h),M=u+c+Math.max(0,v-N),B=S(M),ae=r*B/s,Ue=t-i-M;return D(ae,Ue).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,c=s>0n?1n:s<0n?-1n:1n;return u*c>0n?e.POSITIVE_INFINITY:e.NEGATIVE_INFINITY}return D(0n,0)}inv(){return D(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?D(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 D(1n,0);if(!this.isFinite())return t>0n?this.significand<0n&&t%2n!==0n?e.NEGATIVE_INFINITY:e.POSITIVE_INFINITY:D(0n,0);if(this.isZero())return t>0n?D(0n,0):e.POSITIVE_INFINITY;if(t<0n)return this.pow(n.neg()).inv();let i=this.significand<0n?-this.significand:this.significand,r=O(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 D(0n,0);let o=e.precision,a=D(1n,0),u=this,c=t;for(;c>0n;)c&1n&&(a=a.mul(u).toPrecision(o)),c>>=1n,c>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),c=r>=0?"+":"";return`${s}${u}e${c}${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),c=t.slice(i-o);return`${s}${u}.${c}`}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*S(s);else{let h=S(-s),N=r/h,v=r%h,M=h/2n;v>M?o=N+1n:v<M||h%2n!==0n||N%2n===0n?o=N:o=N+1n}let a=i&&o!==0n?"-":"",u=o.toString();if(t===0)return`${a}${u}`;if(u.length<=t){let h=u.padStart(t,"0");return`${a}0.${h}`}let c=u.slice(0,u.length-t),p=u.slice(u.length-t);return`${a}${c}.${p}`}toPrecision(n){if(this.significand===0n||!Number.isFinite(this.exponent))return this;let t=this.significand<0n?-this.significand:this.significand,i=O(t);if(i<=n)return this;let r=i-n,s=S(r),o=t/s,a=t%s,u=s/2n;(a>u||a===u&&o%2n!==0n)&&(o+=1n);let c=this.significand<0n?-o:o;return D(c,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*S(this.exponent);let n=S(-this.exponent);return this.significand/n}};function D(e,n){let[t,i]=On(e,n),r=Object.create(m.prototype);return r.significand=t,r.exponent=i,r}var Qi=1000000000n,er=1000n;function On(e,n){if(e===0n)return[0n,0];for(;e%Qi===0n;)e/=Qi,n+=9;for(;e%er===0n;)e/=er,n+=3;for(;e%10n===0n;)e/=10n,n+=1;return[e,n]}function Ss(e){return Number.isNaN(e)?[0n,NaN]:e===1/0?[1n,1/0]:e===-1/0?[-1n,1/0]:Number.isInteger(e)?On(BigInt(e),0):nr(e.toString())}function nr(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 c=BigInt(u);r&&(c=-c);let p=-a.length;return On(c,p+t)}function ue(e,n){let t=S(n),i=e.exponent+n;return i>=0?[e.significand*S(i),t]:[e.significand/S(-i),t]}function le(e,n,t){if(e===0n)return m.ZERO;let i=e<0n,r=i?-e:e,s=O(r);if(s>t){let c=s-t,p=S(c),h=p/2n,N=r%p;r=r/p,N>=h&&(r+=1n);let v=O(n)-1,M=c-v,B=i?-r:r;return D(B,M)}let a=-(O(n)-1),u=i?-r:r;return D(u,a)}m.prototype.sqrt=function(){if(this.isNaN())return m.NAN;if(this.isZero())return m.ZERO;if(!this.isFinite())return this.significand>0n?m.POSITIVE_INFINITY:m.NAN;if(this.significand<0n)return m.NAN;let e=m.precision,n=e+10,[t,i]=ue(this,n),r=Ye(t,i);return le(r,i,e)};m.prototype.cbrt=function(){if(this.isNaN())return m.NAN;if(this.isZero())return m.ZERO;if(!this.isFinite())return this.significand>0n?m.POSITIVE_INFINITY:m.NEGATIVE_INFINITY;if(this.significand<0n)return this.neg().cbrt().neg();let e=m.precision,n=e+10,[t,i]=ue(this,n),r=t*i*i,s,o=this.toNumber(),a=Number(i);if(Number.isFinite(o)&&o>0&&Number.isFinite(a)){let c=Math.cbrt(o);Number.isFinite(c)&&c>0?(s=BigInt(Math.floor(c*a)),s===0n&&(s=1n)):s=tr(t,i)}else s=tr(t,i);let u;do{u=s;let c=s*s;if(c===0n){s=1n;break}s=(2n*s+r/c)/3n}while(ee(s-u)>1n);{let c=(2n*s+r/(s*s))/3n,p=ee(s*s*s-r);ee(c*c*c-r)<p&&(s=c)}return le(s,i,e)};m.sqrt=function(e){return e.sqrt()};m.cbrt=function(e){return e.cbrt()};m.prototype.exp=function(){if(this.isNaN())return m.NAN;if(!this.isFinite())return this.significand>0n?m.POSITIVE_INFINITY:m.ZERO;if(this.isZero())return m.ONE;let e=m.precision,n=e+15,[t,i]=ue(this,n),r=ui(t,i);return le(r,i,e)};m.prototype.ln=function(){if(this.isNaN())return m.NAN;if(!this.isFinite())return this.significand>0n?m.POSITIVE_INFINITY:m.NAN;if(this.isZero())return m.NEGATIVE_INFINITY;if(this.significand<0n)return m.NAN;if(this.eq(1))return m.ZERO;let e=m.precision,n=e+15,[t,i]=ue(this,n),r=Ki(t,i);return le(r,i,e)};m.prototype.log=function(e){let n=e instanceof m?e:new m(e);return this.ln().div(n.ln())};m.exp=function(e){return e.exp()};m.ln=function(e){return e.ln()};m.log10=function(e){return e.log(10)};m.prototype.sin=function(){if(this.isNaN())return m.NAN;if(!this.isFinite())return m.NAN;if(this.isZero())return m.ZERO;let e=m.precision,n=e+15,[t,i]=ue(this,n),[r]=Cn(t,i);return le(r,i,e)};m.prototype.cos=function(){if(this.isNaN())return m.NAN;if(!this.isFinite())return m.NAN;if(this.isZero())return m.ONE;let e=m.precision,n=e+15,[t,i]=ue(this,n),[,r]=Cn(t,i);return le(r,i,e)};m.prototype.tan=function(){if(this.isNaN())return m.NAN;if(!this.isFinite())return m.NAN;if(this.isZero())return m.ZERO;let e=m.precision,n=e+15,[t,i]=ue(this,n),[r,s]=Cn(t,i);if(s===0n)return r>0n?m.POSITIVE_INFINITY:m.NEGATIVE_INFINITY;let o=r*i/s;return le(o,i,e)};m.prototype.atan=function(){if(this.isNaN())return m.NAN;if(this.isZero())return m.ZERO;if(!this.isFinite()){let s=m.PI.div(m.TWO);return this.significand>0n?s:s.neg()}let e=m.precision,n=e+15,[t,i]=ue(this,n),r=He(t,i);return le(r,i,e)};m.prototype.asin=function(){if(this.isNaN())return m.NAN;if(!this.isFinite())return m.NAN;if(this.isZero())return m.ZERO;let e=this.abs(),n=m.ONE;if(e.gt(n))return m.NAN;if(e.eq(n)){let h=m.PI.div(m.TWO);return this.significand>0n?h:h.neg()}let t=m.precision,i=t+20,[r,s]=ue(this,i),o=Yi(r,r,s),a=s-o,u=Ye(a,s),c=Xi(r,u,s),p=He(c,s);return le(p,s,t)};m.prototype.acos=function(){return this.isNaN()?m.NAN:this.isFinite()?this.abs().gt(m.ONE)?m.NAN:this.eq(1)?m.ZERO:this.eq(-1)?m.PI:m.PI.div(m.TWO).sub(this.asin()):m.NAN};m.sin=function(e){return e.sin()};m.cos=function(e){return e.cos()};m.tan=function(e){return e.tan()};m.asin=function(e){return e.asin()};m.acos=function(e){return e.acos()};m.atan=function(e){return e.atan()};m.atan2=function(e,n){let t=e instanceof m?e:new m(e);if(t.isNaN()||n.isNaN())return m.NAN;let i=m.PI,r=i.div(m.TWO);if(n.isZero())return t.isZero()?m.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)};m.prototype.sinh=function(){if(this.isNaN())return m.NAN;if(this.isZero())return m.ZERO;if(!this.isFinite())return this.significand>0n?m.POSITIVE_INFINITY:m.NEGATIVE_INFINITY;let e=this.exp(),n=e.inv();return e.sub(n).div(m.TWO)};m.prototype.cosh=function(){if(this.isNaN())return m.NAN;if(this.isZero())return m.ONE;if(!this.isFinite())return m.POSITIVE_INFINITY;let e=this.exp(),n=e.inv();return e.add(n).div(m.TWO)};m.prototype.tanh=function(){if(this.isNaN())return m.NAN;if(this.isZero())return m.ZERO;if(!this.isFinite())return this.significand>0n?m.ONE:m.NEGATIVE_ONE;let e=this.mul(m.TWO).exp();return e.sub(m.ONE).div(e.add(m.ONE))};m.sinh=function(e){return e.sinh()};m.cosh=function(e){return e.cosh()};m.tanh=function(e){return e.tanh()};function tr(e,n){let i=O(e),r=Math.max(0,i-15),s=Number(r>0?e/S(r):e),o=O(n),a=Math.max(0,o-15),u=Number(a>0?n/S(a):n),c=r+2*a,p=Math.floor(c/3),h=c%3,N=Math.cbrt(s*u*u);h===1&&(N*=2.154434690031882),h===2&&(N*=4.641588833612779);let v=BigInt(Math.round(N))*S(p);return v>0n?v:1n}var ir=7,rr=[.9999999999998099,676.5203681218851,-1259.1392167224028,771.3234287776531,-176.6150291621406,12.507343278686905,-.13857109526572012,9984369578019572e-21,15056327351493116e-23];function De(e){if(e<0)return NaN;let n=Math.PI,t=e*e*e;return e*Math.log(e)-e-.5*Math.log(e)+.5*Math.log(2*n)+1/(12*e)-1/(360*t)+1/(1260*t*e*e)}function te(e){if(e<.5)return Math.PI/(Math.sin(Math.PI*e)*te(1-e));if(e>100)return Math.exp(De(e));e-=1;let n=rr[0];for(let i=1;i<ir+2;i++)n+=rr[i]/(e+i);let t=e+ir+.5;return Math.sqrt(2*Math.PI)*Math.pow(t,e+.5)*Math.exp(-t)*n}function ci(e){return 1-Fn(e)}function Fn(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),c=((((s*u+r)*u+i)*u+t)*u+n)*u;return a*(1-c*Math.exp(-e*e))}var Ea=[1/6,-1/30,1/42,-1/30,5/66,-691/2730,7/6,-3617/510,43867/798,-174611/330];var Ms=[-2991.8191940101983,708840.0452577386,-6297414862058625e-8,25489088057337637e-7,-4429795180596978e-5,3180162978765678e-4],ws=[1,281.3762688899943,45584.78108065326,5173438887700964e-9,4193202458981112e-7,22441179564534092e-6,607366389490085e-3],Ds=[-49884311457357354e-24,9504280628298596e-21,-.0006451914356839651,.018884331939670384,-.20552590095501388,1],As=[399982968972496e-26,9154392157746574e-25,12500186247959882e-23,12226278902417902e-21,.0008680295429417843,.04121420907221998,1],sr=[.4215435550436775,.1434079197807589,.011522095507358577,.000345017939782574,46361374928786735e-22,3055689837902576e-23,10230451416490724e-26,17201074326816183e-29,13428327623306275e-32,3763297112699879e-35],or=[1,.7515863983533789,.11688892585919138,.0064405152650885865,.00015593440916415301,18462756734893055e-22,11269922476399903e-24,36014002958937136e-27,5887545336215784e-29,45200143407412973e-33,12544323709001127e-36],ar=[.5044420736433832,.1971028335255234,.018764858409257526,.0006840793809153931,11513882611188428e-21,9828524436884223e-23,44534441586175015e-26,10826804113902088e-28,1375554606332618e-30,8363544356306774e-34,18695871016278324e-38],ur=[1,1.4749575992512833,.33774898912002,.02536037414203388,.0008146791071843061,12754507566772912e-21,10431458965757199e-23,46068072851523205e-26,11027321506624028e-28,13879653125957886e-31,8391588162831187e-34,18695871016278324e-38];function X(e,n){let t=n[0];for(let i=1;i<n.length;i++)t=t*e+n[i];return t}function Xe(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*X(i,Ms)/X(i,ws)}if(e<36){let t=e*e,i=Math.PI*t,r=1/(i*i),s=1-r*X(r,sr)/X(r,or),o=1/i*X(r,ar)/X(r,ur),a=Math.PI/2*t,u=Math.cos(a),c=Math.sin(a);return n*(.5-(s*u+o*c)/(Math.PI*e))}return n*.5}function Ke(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*X(i,Ds)/X(i,As)}if(e<36){let t=e*e,i=Math.PI*t,r=1/(i*i),s=1-r*X(r,sr)/X(r,or),o=1/i*X(r,ar)/X(r,ur),a=Math.PI/2*t,u=Math.cos(a),c=Math.sin(a);return n*(.5+(s*c-o*u)/(Math.PI*e))}return n*.5}var Ma=[BigInt(4),BigInt(2),BigInt(4),BigInt(2),BigInt(4),BigInt(6),BigInt(2),BigInt(6)];var Ps=53,lr=Math.floor(Math.log10(Math.pow(2,Ps))),_s=1e-10;function he(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 Ae(e,n){if(e===0||n===0)return 0;let t=BigInt(e)*BigInt(n)/BigInt(he(e,n));return Number(t)}function fi(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 pi(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 mi(e,n=_s){return typeof e=="number"&&Math.abs(e)<=n?0:e}function x(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 Pe(e,n,t){return n.includes(e)&&(n=`{${n}}`),/^[0-9]$/.test(t)?`${n}${e}${t}`:`${n}${e}{${t}}`}var k=245,en=260,ce=270,F=275,W=390,K=600;var nn=700,di=810;var _e=[{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:k+5,parse:"LessEqual"},{name:"LessNotEqual",latexTrigger:["\\lneqq"],kind:"infix",associativity:"any",precedence:k},{name:"NotLessNotEqual",latexTrigger:["\\nleqq"],kind:"infix",associativity:"any",precedence:k},{name:"LessOverEqual",latexTrigger:["\\leqq"],kind:"infix",associativity:"any",precedence:k+5},{name:"GreaterOverEqual",latexTrigger:["\\geqq"],kind:"infix",associativity:"any",precedence:k+5,parse:"GreaterEqual"},{name:"Equal",latexTrigger:["="],kind:"infix",associativity:"right",precedence:k},{latexTrigger:["*","="],kind:"infix",associativity:"right",precedence:k,parse:"StarEqual"},{name:"StarEqual",latexTrigger:["\\star","="],kind:"infix",associativity:"right",precedence:k},{name:"PlusEqual",latexTrigger:["+","="],kind:"infix",associativity:"right",precedence:k},{name:"MinusEqual",latexTrigger:["-","="],kind:"infix",associativity:"right",precedence:k},{name:"SlashEqual",latexTrigger:["/","="],kind:"infix",associativity:"right",precedence:k},{name:"EqualEqual",latexTrigger:["=","="],kind:"infix",associativity:"right",precedence:k},{name:"EqualEqualEqual",latexTrigger:["=","=","="],kind:"infix",associativity:"right",precedence:k+5},{name:"TildeFullEqual",latexTrigger:["\\cong"],kind:"infix",associativity:"right",precedence:k},{name:"NotTildeFullEqual",latexTrigger:["\\ncong"],kind:"infix",associativity:"right",precedence:k},{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:k},{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:k},{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:k+5,parse:"GreaterEqual"},{name:"GreaterNotEqual",latexTrigger:["\\gneqq"],kind:"infix",associativity:"right",precedence:k},{name:"NotGreaterNotEqual",latexTrigger:["\\ngeqq"],kind:"infix",associativity:"right",precedence:k},{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:k},{name:"TriangleEqual",latexTrigger:["\\triangleq"],kind:"infix",associativity:"right",precedence:k},{name:"DotEqual",latexTrigger:["\\doteq"],kind:"infix",associativity:"right",precedence:k+5},{name:"DotEqualDot",latexTrigger:["\\doteqdot"],kind:"infix",associativity:"right",precedence:k+5},{name:"FallingDotEqual",latexTrigger:["\\fallingdotseq"],kind:"infix",associativity:"right",precedence:k+5},{name:"RisingDotEqual",latexTrigger:["\\fallingdotseq"],kind:"infix",associativity:"right",precedence:k+5},{name:"QuestionEqual",latexTrigger:["\\questeq"],kind:"infix",associativity:"right",precedence:k},{name:"MuchLess",latexTrigger:["\\ll"],kind:"infix",associativity:"right",precedence:k},{name:"MuchGreater",latexTrigger:["\\gg"],kind:"infix",associativity:"right",precedence:k},{name:"Precedes",latexTrigger:["\\prec"],kind:"infix",associativity:"right",precedence:k},{name:"Succeeds",latexTrigger:["\\succ"],kind:"infix",associativity:"right",precedence:k},{name:"PrecedesEqual",latexTrigger:["\\preccurlyeq"],kind:"infix",associativity:"right",precedence:k},{name:"SucceedsEqual",latexTrigger:["\\curlyeqprec"],kind:"infix",associativity:"right",precedence:k},{name:"NotPrecedes",latexTrigger:["\\nprec"],kind:"infix",associativity:"right",precedence:k},{name:"NotSucceeds",latexTrigger:["\\nsucc"],kind:"infix",associativity:"right",precedence:k},{name:"Between",latexTrigger:["\\between"],kind:"infix",associativity:"right",precedence:k+5}];function hi(e){return typeof e!="string"?!1:["Less","LessEqual","Greater","GreaterEqual"].includes(e)}function gi(e){return typeof e!="string"?!1:["Equal","NotEqual"].includes(e)}var Z=Math.cosh||function(e){return Math.abs(e)<1e-9?1-e:(Math.exp(e)+Math.exp(-e))*.5},Q=Math.sinh||function(e){return Math.abs(e)<1e-9?e:(Math.exp(e)-Math.exp(-e))*.5},Rs=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)},Bs=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))},Re=function(){throw SyntaxError("Invalid Param")};function yi(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 Cs=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 V.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 V.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]):Re();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&&Re();for(var o=0;o<i.length;o++){var a=i[o];a===" "||a===" "||a===`
|
|
3
3
|
`||(a==="+"?r++:a==="-"?s++:a==="i"||a==="I"?(r+s===0&&Re(),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)))&&Re(),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&&Re();break;case"number":t.im=0,t.re=e;break;default:Re()}return isNaN(t.re)||isNaN(t.im),t},V=class e{constructor(n,t){this.re=0,this.im=0;var i=Cs(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=yi(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)+Rs(t),Math.exp(n)*Math.sin(t))}log(){var n=this.re,t=this.im;return t===0&&n>0,new e(yi(n,t),Math.atan2(t,n))}abs(){return Bs(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)*Z(t),Math.cos(n)*Q(t))}cos(){var n=this.re,t=this.im;return new e(Math.cos(n)*Z(t),-Math.sin(n)*Q(t))}tan(){var n=2*this.re,t=2*this.im,i=Math.cos(n)+Z(t);return new e(Math.sin(n)/i,Q(t)/i)}cot(){var n=2*this.re,t=2*this.im,i=Math.cos(n)-Z(t);return new e(-Math.sin(n)/i,Q(t)/i)}sec(){var n=this.re,t=this.im,i=.5*Z(2*t)+.5*Math.cos(2*n);return new e(Math.cos(n)*Z(t)/i,Math.sin(n)*Q(t)/i)}csc(){var n=this.re,t=this.im,i=.5*Z(2*t)-.5*Math.cos(2*n);return new e(Math.sin(n)*Z(t)/i,-Math.cos(n)*Q(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(Q(n)*Math.cos(t),Z(n)*Math.sin(t))}cosh(){var n=this.re,t=this.im;return new e(Z(n)*Math.cos(t),Q(n)*Math.sin(t))}tanh(){var n=2*this.re,t=2*this.im,i=Z(n)+Math.cos(t);return new e(Q(n)/i,Math.sin(t)/i)}coth(){var n=2*this.re,t=2*this.im,i=Z(n)-Math.cos(t);return new e(Q(n)/i,-Math.sin(t)/i)}csch(){var n=this.re,t=this.im,i=Math.cos(2*t)-Z(2*n);return new e(-2*Q(n)*Math.cos(t)/i,2*Z(n)*Math.sin(t)/i)}sech(){var n=this.re,t=this.im,i=Math.cos(2*t)+Z(2*n);return new e(2*Z(n)*Math.cos(t)/i,-2*Q(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=yi(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())}};V.ZERO=new V(0,0);V.ONE=new V(1,0);V.I=new V(0,1);V.PI=new V(Math.PI,0);V.E=new V(Math.E,0);V.INFINITY=new V(1/0,1/0);V.NAN=new V(NaN,NaN);V.EPSILON=1e-15;var Be=["number","finite_number","complex","finite_complex","imaginary","real","finite_real","rational","finite_rational","integer","finite_integer","non_finite_number"],xi=["indexed_collection","list","tuple"],Vn=[...xi,"collection","set","record","dictionary"],Ln=["scalar",...Be,"boolean","string"],bi=["value",...Vn,...Ln],Ni=["expression","symbol","function",...bi],ge=["any","unknown","nothing","never","error",...Ni];function Jn(e){return typeof e=="string"?ge.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 fr=3,pr=1,mr=2,Os=4,Fs=5,Vs=6,Ls=7,Js=8,$s=9,qs=10,zs=11;function C(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=`!${C(e.type,fr)}`;break;case"union":t=e.types.map(u=>C(u,pr)).join(" | ");break;case"intersection":t=e.types.map(u=>C(u,mr)).join(" & ");break;case"expression":t=`expression<${cr(e.operator)}>`;break;case"symbol":t=`symbol<${cr(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"&&Be.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<${C(e.elements)}>`:t=`vector<${C(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<${C(e.elements)}>`:t=`matrix<${C(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<${C(e.elements)}${u}>`}break;case"record":t=`record<${Object.entries(e.elements).map(([u,c])=>`${u}: ${C(c)}`).join(", ")}>`;break;case"dictionary":t=`dictionary<${C(e.values)}>`;break;case"set":t=`set<${C(e.elements)}>`;break;case"collection":t=`collection<${C(e.elements)}>`;break;case"indexed_collection":t=`indexed_collection<${C(e.elements)}>`;break;case"tuple":if(e.elements.length===0)t="tuple";else if(e.elements.length===1){let[u]=e.elements;t=`tuple<${Ce(u)}>`}else t="tuple<"+e.elements.map(u=>Ce(u)).join(", ")+">";break;case"signature":let r=e.args?e.args.map(u=>Ce(u)).join(", "):"",s=e.optArgs?e.optArgs.map(u=>Ce(u)+"?").join(", "):"",o=e.variadicArg?e.variadicMin===0?`${Ce(e.variadicArg)}*`:`${Ce(e.variadicArg)}+`:"";t=`(${[r,s,o].filter(u=>u).join(", ")}) -> ${C(e.result)}`;break;default:t="error"}return n>0&&n>Gs(e.kind)?`(${t})`:t}function Ce(e){return e.name?`${e.name}: ${C(e.type)}`:C(e.type)}function cr(e){return/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)?e:`\`${e}\``}function Gs(e){switch(e){case"negation":return fr;case"union":return pr;case"intersection":return mr;case"list":return Os;case"record":return Fs;case"dictionary":return Vs;case"set":return Ls;case"collection":case"indexed_collection":return Js;case"tuple":return $s;case"signature":return qs;case"value":return zs;default:return 0}}var $n=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===`
|
|
4
4
|
`?(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 qn=class{lexer;typeResolver;current;constructor(n,t){this.lexer=new $n(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(`
|
|
5
5
|
`)[n.line-1]||r,a=n.column,u=" ".repeat(Math.max(0,a-1))+"^",c=["","Invalid type",`| ${o}`,`| ${u}`,"|",`| ${t}`];throw i&&c.push(`| ${i}`),c.push(""),new Error(c.join(`
|
|
6
6
|
`))}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(ge.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 dr(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 dr(n,this)}visitFunctionSignature(n){let t=[],i=[],r,s;for(let u of n.arguments){let c=this.buildNamedElement(u.element);switch(u.modifier){case"optional":i.push(c);break;case"variadic_zero":r=c,s=0;break;case"variadic_one":r=c,s=1;break;default:t.push(c);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 hr(e,n){return new Ei(n).buildType(e)}function Ee(e,n){if(e!==void 0){if(Jn(e))return e;if(typeof e=="string")try{let i=new qn(e,{typeResolver:n}).parseType();return hr(i,n)}catch(t){throw new Error(`Failed to parse type "${e}": ${t instanceof Error?t.message:String(t)}`)}}}var Zs={number:Be,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:ge,unknown:[],nothing:[],never:[],error:[],value:bi,scalar:Ln,collection:Vn,indexed_collection:xi,list:[],set:[],tuple:[],record:[],dictionary:[],function:[],symbol:[],boolean:[],string:[],expression:Ni};function tn(e,n){return n==="any"||e==="never"?!0:e==="unknown"||n==="unknown"?!1:e===n?!0:Zs[n].includes(e)}function T(e,n){if(typeof e=="string"&&!ge.includes(e)&&(e=Ee(e)),typeof n=="string"&&!ge.includes(n)&&(n=Ee(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"?tn(e,n):e.kind==="value"?typeof e.value=="boolean"?n==="boolean":typeof e.value=="number"?Number.isInteger(e.value)?tn("integer",n):tn("number",n):typeof e.value=="boolean"?tn("boolean",n):typeof e.value=="string"?tn("string",n):!1:e.kind==="union"?e.types.every(t=>T(t,n)):e.kind==="intersection"?e.types.some(t=>T(t,n)):e.kind==="negation"?!T(e.type,n):e.kind==="numeric"?!!T(e.type,n):n==="number"?gr(e):n==="symbol"?Ti(e):n==="expression"?js(e):n==="function"?Er(e):n==="scalar"?yr(e):n==="value"?Nr(e):n==="indexed_collection"?br(e):n==="collection"?xr(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=>T(t,i))):n.types.some(t=>T(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"?Ti(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 T(e,n.def)}if(e.kind==="union")return e.types.some(t=>T(t,n));if(e.kind==="intersection"&&n.kind==="intersection")return n.types.every(t=>e.types.some(i=>T(i,t)));if(e.kind==="intersection")return e.types.every(t=>T(t,n));if(n.kind==="intersection")return n.types.every(t=>T(e,t));if(e.kind==="signature"&&n.kind==="signature"){if(!T(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(!T(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(!T(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||!T(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(!T(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(!T(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(!T(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)||!T(e.elements[t],n.elements[t]))return!1;return!0}if(e.kind==="dictionary"&&n.kind==="dictionary")return T(e.values,n.values);if(n.kind==="indexed_collection")return e.kind==="indexed_collection"||e.kind==="list"?T(e.elements,n.elements):e.kind==="tuple"?e.elements.every(t=>T(t.type,n.elements)):!1;if(n.kind==="collection"){if(e.kind==="collection"||e.kind==="indexed_collection"||e.kind==="list")return T(e.elements,n.elements);if(e.kind==="tuple")return e.elements.every(t=>T(t.type,n.elements));if(e.kind==="set")return T(e.elements,n.elements);if(e.kind==="dictionary")return T({kind:"tuple",elements:[{type:"string"},{type:e.values}]},n.elements);if(e.kind==="record")return T({kind:"tuple",elements:[{type:"string"},{type:Te(...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(!T(i.type,r.type)||i.name!==r.name)return!1}return!0}if(n.kind==="list"&&e.kind==="list"){if(!T(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!(!T(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!!T(e.elements,n.elements);if(e.kind==="negation"&&n.kind==="negation")return T(e.type,n.type);if(n.kind==="negation")return!T(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 T("boolean",n);if(typeof e.value=="number")return Number.isInteger(e.value)?T("integer",n):T("real",n);if(typeof e.value=="string")return T("string",n)}return!1}function gr(e){return typeof e=="string"?Be.includes(e):e.kind==="value"?typeof e.value=="number":e.kind==="numeric"}function yr(e){return gr(e)?!0:typeof e=="string"?Ln.includes(e):e.kind==="value"?["string","boolean","number"].includes(typeof e.value):!1}function xr(e){return br(e)?!0:typeof e=="string"?Vn.includes(e):["collection","set","record","dictionary"].includes(e.kind)}function br(e){return typeof e=="string"?!1:["indexed_collection","list","tuple"].includes(e.kind)}function Nr(e){return yr(e)||xr(e)}function Er(e){return e==="function"||typeof e!="string"&&e.kind==="signature"}function js(e){return typeof e=="string"&&["expression","symbol","function"].includes(e)||Nr(e)||Er(e)||Ti(e)?!0:typeof e=="string"?!1:e.kind==="expression"}function Ti(e){return e==="symbol"?!0:typeof e=="string"?!1:e.kind==="symbol"?!0:e.kind==="expression"?e.operator==="Symbol":!1}function Us(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"||T(e,n)?e:T(n,e)?n:Tr(e,n)}function Ws(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:T(e,n)?n:T(n,e)?e:Tr(e,n)}function vi(...e){return e.length===0?"nothing":e.length===1?e[0]:e.reduce((n,t)=>Us(n,t))}function Te(...e){return e.length===0?"nothing":e.length===1?e[0]:e.reduce((n,t)=>Ws(n,t))}function Tr(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:R(e,n,"non_finite_number")?"non_finite_number":R(e,n,"finite_integer")?"finite_integer":R(e,n,"integer")?"integer":R(e,n,"finite_rational")?"finite_rational":R(e,n,"rational")?"rational":R(e,n,"finite_real")?"finite_real":R(e,n,"real")?"real":R(e,n,"imaginary")?"imaginary":R(e,n,"finite_complex")?"finite_complex":R(e,n,"complex")?"complex":R(e,n,"finite_number")?"finite_number":R(e,n,"number")?"number":R(e,n,"list")?"list":R(e,n,"record")?"record":R(e,n,"dictionary")?"dictionary":R(e,n,"set")?"set":R(e,n,"tuple")?"tuple":R(e,n,"indexed_collection")?"indexed_collection":R(e,n,"collection")?"collection":R(e,n,"scalar")?"scalar":R(e,n,"value")?"value":R(e,n,"function")?"function":R(e,n,"expression")?"expression":"any"}function R(e,n,t){return!!(T(e,t)&&T(n,t))}var ne=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(Te(...n.map(t=>t instanceof e?t.type:t)))}static narrow(...n){return new e(vi(...n.map(t=>t instanceof e?t.type:t)))}constructor(n,t){typeof n=="string"?this.type=Ee(n,t):this.type=n}matches(n){return n instanceof e?T(this.type,n.type):T(this.type,n)}is(n){return T(this.type,n)&&T(n,this.type)}get isUnknown(){return this.type==="unknown"}toString(){return C(this.type)}toJSON(){return C(this.type)}[Symbol.toPrimitive](n){return n==="string"?this.toString():null}valueOf(){return C(this.type)}};var Qu=[0,-1,1,Math.PI,Math.E,-Math.PI,-Math.E,.5,-.5];var Oe=["Error","'missing'"];function ve(e){return!!(typeof e=="number"||Fe(e)||typeof e=="string"&&jn(e))}function Fe(e){return e!==null&&typeof e=="object"&&"num"in e}function zn(e){return e!==null&&typeof e=="object"&&"sym"in e}function Ir(e){return e!==null&&typeof e=="object"&&"str"in e}function kr(e){return e!==null&&typeof e=="object"&&"dict"in e&&typeof e.dict=="object"&&!Array.isArray(e.dict)&&e.dict!==null}function Ve(e){return e!==null&&typeof e=="object"&&"fn"in e&&Array.isArray(e.fn)&&e.fn.length>0&&typeof e.fn[0]=="string"}function w(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):jn(e)||wi(e)?null:e}function Si(e){if(e==null||w(e)!==null)return null;let n=f(e);return n?[n,...g(e).map(t=>Si(t)).filter(t=>t!==null)]:e}function f(e){return Array.isArray(e)?e[0]:e==null?"":Ve(e)?e.fn[0]:""}function g(e){return Array.isArray(e)?e.slice(1):e!==void 0&&Ve(e)?e.fn.slice(1):[]}function l(e,n){return Array.isArray(e)?e[n]??null:e===null||!Ve(e)?null:e.fn[n]??null}function P(e){return e==null?0:Array.isArray(e)?Math.max(0,e.length-1):Ve(e)?Math.max(0,e.fn.length-1):0}function Mi(e){return e==null?null:f(e)==="Hold"?l(e,1):e}function b(e){return typeof e=="string"&&wi(e)?e.length>=2&&e.at(0)==="`"&&e.at(-1)==="`"?e.slice(1,-1):e:e==null?null:zn(e)?e.sym:null}function vr(e){let n=f(e);if(n==="KeyValuePair"||n==="Tuple"||n==="Pair"){let[t,i]=g(e),r=w(t);return r?[r,i??"Nothing"]:null}return null}function Sr(e){if(e===null)return null;if(kr(e))return e;let n=vr(e);if(n)return{[n[0]]:n[1]};if(f(e)==="Dictionary"){let t={},i=g(e);for(let r=1;r<P(e);r++){let s=vr(i[r]);s&&(t[s[0]]=eo(s[1])??"Nothing")}return{dict:t}}return null}function Gn(e){return{dict:Object.fromEntries(Object.entries(e).map(([t,i])=>[t,ki(i)??"Nothing"]))}}function Qs(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 I(e){return typeof e=="number"?e:typeof e=="string"&&jn(e)?Qs(e):e!==void 0&&Fe(e)?I(e.num):null}function Le(e){if(e==null)return null;if(b(e)==="Half")return[1,2];let n=f(e);if(!n)return null;let t=null,i=null;if(n==="Negate"){let r=Le(g(e)[0]);if(r)return[-r[0],r[1]]}if(n==="Rational"||n==="Divide"){let[r,s]=g(e);t=I(r)??NaN,i=I(s)??NaN}if(n==="Power"){let[r,s]=g(e),o=I(s);o===1?(t=I(r),i=1):o===-1&&(t=1,i=I(r))}if(n==="Multiply"){let[r,s]=g(e);if(f(s)==="Power"){let[o,a]=g(s);I(a)===-1&&(t=I(r),i=I(o))}}return t===null||i===null?null:Number.isInteger(t)&&Number.isInteger(i)?[t,i]:null}function Zn(e,n){let t=null;if(Array.isArray(e)&&(t=e),Ve(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 Je(e,n,t){let i=f(n),r=f(t);return i===e&&r===e?[e,...g(n),...g(t)]:i===e?[e,...g(n),t]:r===e?[e,n,...g(t)]:[e,n,t]}function Ie(e){if(e==null)return null;let n=f(e);if(n==="Delimiter"){if(e=l(e,1),e===null)return[];if(n=f(e),n!=="Sequence")return[e]}return n!=="Sequence"?null:g(e)}function _(e){return e==null||e==="Nothing"?!0:f(e)==="Sequence"&&P(e)===0}function A(e){return _(e)?Oe:e}function jn(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 wi(e){return/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(e)||e.length>=2&&e[0]==="`"&&e[e.length-1]==="`"}function ki(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=>ki(n)??"Nothing")];if(e===null)return null;if(typeof e=="object"){let n={};for(let t in e)n[t]=ki(e[t])??"Nothing";return{dict:n}}return Ve(e)||zn(e)||Fe(e)||Ir(e)||kr(e)?e:null}function eo(e){return e==null?null:Ir(e)?e.str:Fe(e)?parseFloat(e.num):zn(e)?e.sym:typeof e=="string"||typeof e=="number"?e:Array.isArray(e)?{fn:e}:e}var wr=[{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&&f(s)==="Mod"?["Congruent",n,i,A(l(s,1))]:(e.index=r,["Equivalent",n,A(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:rn("\\forall"),parse:ye("ForAll")},{name:"Exists",kind:"prefix",latexTrigger:["\\exists"],precedence:200,serialize:rn("\\exists"),parse:ye("Exists")},{name:"ExistsUnique",kind:"prefix",latexTrigger:["\\exists","!"],precedence:200,serialize:rn("\\exists!"),parse:ye("ExistsUnique")},{name:"NotForAll",kind:"prefix",latexTrigger:["\\lnot","\\forall"],precedence:200,serialize:rn("\\lnot\\forall"),parse:ye("NotForAll")},{name:"NotExists",kind:"prefix",latexTrigger:["\\lnot","\\exists"],precedence:200,serialize:rn("\\lnot\\exists"),parse:ye("NotExists")},{name:"KroneckerDelta",kind:"prefix",latexTrigger:["\\delta","_"],precedence:200,serialize:(e,n)=>{let t=g(n);return t.length===0?"\\delta":t.every(i=>b(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=Ie(n);return t&&t.length<=2?["KroneckerDelta",...t]:f(n)==="InvisibleOperator"?["KroneckerDelta",...g(n)]:n!==null?["KroneckerDelta",n]:null}},{name:"Boole",kind:"matchfix",openTrigger:"[",closeTrigger:"]",parse:(e,n)=>{let t=f(n);return!t||!_e.some(i=>i.name===t)?null:["Boole",n]}},{kind:"matchfix",openTrigger:"\\llbracket",closeTrigger:"\\rrbracket",parse:(e,n)=>{let t=f(n);return!t||!_e.some(i=>i.name===t)?null:["Boole",n]}},{name:"Predicate",serialize:(e,n)=>{let t=g(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 rn(e){return(n,t)=>{let i=g(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 Mr(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 ye(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 c=r?{...t,condition:h=>Mr(h,t)}:t;n.enterQuantifierScope();let p=n.parseExpression(c);return n.exitQuantifierScope(),[e,s,A(p)]}n.enterQuantifierScope();let u=n.parseEnclosure();if(n.exitQuantifierScope(),u)return[e,s,A(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:p=>Mr(p,t)}:t;n.enterQuantifierScope();let c=n.parseExpression(u);return n.exitQuantifierScope(),[e,a,A(c)]}if(n.match("(")){n.enterQuantifierScope();let u=n.parseExpression(t);return n.exitQuantifierScope(),n.match(")")?[e,a,A(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 re(e=""){return(n,t)=>{if(!t)return"";let i=g(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(),x(r)}}var Rr=[{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:ce,parse:(e,n,t)=>{let i=[];if(f(n)==="Delimiter"&&(n=l(n,1)??"Nothing"),f(n)==="Sequence")for(let s of g(n)){if(!b(s))return null;i.push(b(s))}else{if(!b(n))return null;i=[b(n)]}let r=e.parseExpression({minPrec:ce})??"Nothing";return f(r)==="Delimiter"&&(r=l(r,1)??"Nothing"),f(r)==="Sequence"&&(r=["Block",...g(r)]),["Function",r,...i]},serialize:(e,n)=>{let t=g(n);return t.length<1?"()\\mapsto()":t.length===1?x(["()","\\mapsto",e.serialize(l(n,1))]):t.length===2?x([e.serialize(l(n,2)),"\\mapsto",e.serialize(l(n,1))]):x([e.wrapString(g(n)?.slice(1).map(i=>e.serialize(i)).join(", "),"normal"),"\\mapsto",e.serialize(l(n,1))])}},{name:"Apply",kind:"function",symbolTrigger:"apply",serialize:(e,n)=>{let t=l(n,1),i=f(t);if(i==="InverseFunction"||i==="Derivative"){let o=e.options.applyFunctionStyle(n,e.level),a=g(n).slice(1);return e.serializeFunction(t,e.dictionary.ids.get(i))+e.wrapString(a.map(u=>e.serialize(u)).join(", "),o)}let r=l(n,2);if(typeof t=="string"||!r){let o=g(n).slice(1);return e.serialize(o)}if(P(n)===2)return x([e.wrap(t,20),"\\lhd",e.wrap(r,20)]);let s=e.options.applyFunctionStyle(n,e.level);return x(["\\operatorname{apply}",e.wrapString(e.serialize(i)+", "+e.serialize(["List",...g(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=l(n,1);if(!t)return"";let i=g(n).slice(1);if(f(t)==="Function"){let r=g(t).slice(1),s=l(t,1);if(f(s)==="Block"&&P(s)===1&&(s=l(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:en,serialize:(e,n)=>{let t=Mi(l(n,1));if(f(l(n,2))==="Function"){let i=l(n,2),r=Mi(l(i,1)),s=g(i).slice(1);return x([e.serialize(t),e.wrapString(s.map(o=>e.serialize(o)).join(", "),e.options.applyFunctionStyle(n,e.level)),"\\coloneq",e.serialize(r)])}return x([e.serialize(t),"\\coloneq",e.serialize(l(n,2))])},parse:Un},{latexTrigger:"\\coloneqq",kind:"infix",associativity:"right",precedence:en,parse:Un},{latexTrigger:"\\colonequals",kind:"infix",associativity:"right",precedence:en,parse:Un},{latexTrigger:[":","="],kind:"infix",associativity:"right",precedence:en,parse:Un},{name:"Colon",latexTrigger:":",kind:"infix",associativity:"right",precedence:250,serialize:(e,n)=>x([e.serialize(l(n,1)),"\\colon",e.serialize(l(n,2))])},{latexTrigger:"\\colon",kind:"infix",associativity:"right",precedence:250,parse:"Colon"},{name:"BaseForm",serialize:(e,n)=>{let t=I(l(n,2))??NaN;if(isFinite(t)&&t>=2&&t<=36){let i=I(l(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(l(n,1))+", "+e.serialize(l(n,2))+")"}},{name:"Sequence",serialize:re(" ")},{name:"InvisibleOperator",serialize:re("")},{name:"Delimiter",serialize:(e,n)=>{let t=e.options.groupStyle(n,e.level+1),i=l(n,1),r={Set:"{,}",List:"[,]",Tuple:"(,)",Single:"(,)",Pair:"(,)",Triple:"(,)",Sequence:"(,)",String:'""'}[f(i)],s=r?i:["Sequence",i];if(r??="(,)",P(n)>1){let p=w(l(n,2));typeof p=="string"&&p.length<=3&&(r=p)}let[o,a,u]=["","",""];r.length===3?[o,a,u]=r:r.length===2?[o,u]=r:r.length===1&&(a=r);let c=i?s?re(a)(e,s):e.serialize(i):"";return e.wrapString(c,t,o+u)}},{name:"Tuple",serialize:(e,n)=>x(["(",re(",")(e,n),")"])},{name:"Pair",serialize:(e,n)=>x(["(",re(",")(e,n),")"])},{name:"Triple",serialize:(e,n)=>x(["(",re(",")(e,n),")"])},{name:"Single",serialize:(e,n)=>x(["(",re(",")(e,n),")"])},{name:"Domain",serialize:(e,n)=>f(n)==="Error"?e.serialize(n):`\\mathbf{${e.serialize(l(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=l(n,1);if(w(t)==="missing")return`\\error{${e.options.missingSymbol??"\\placeholder{}"}}`;let i=to(e,n)||"\\blacksquare",r=f(t)==="ErrorCode"?w(l(t,1)):w(t);return r==="incompatible-type"?b(l(t,3))==="Undefined"?`\\mathtip{\\error{${i}}}{\\notin ${e.serialize(l(t,2))}}`:`\\mathtip{\\error{${i}}}{\\in ${e.serialize(l(t,3))}\\notin ${e.serialize(l(t,2))}}`:typeof r=="string"?`\\error{${i}}`:`\\error{${i}}`}},{name:"ErrorCode",serialize:(e,n)=>{let t=w(l(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{${Dr(w(l(n,1)))}}`},{name:"Latex",serialize:(e,n)=>n===null?"":x(Zn(n,t=>w(t)??e.serialize(t)))},{name:"LatexString",serialize:(e,n)=>n===null?"":x(Zn(n,t=>e.serialize(t)))},{name:"LatexTokens",serialize:no},{name:"At",kind:"postfix",precedence:810,latexTrigger:["["],parse:Pi("]"),serialize:(e,n)=>x(["\\lbrack",re(", ")(e,n),"\\rbrack"])},{kind:"postfix",precedence:810,latexTrigger:["\\lbrack"],parse:Pi("\\rbrack")},{kind:"postfix",precedence:810,latexTrigger:["\\left","\\lbrack"],parse:Pi("\\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=b(n);return i!==null&&(r&&e.getSymbolType(r).matches("indexed_collection")||f(n)==="List")?(f(i)==="Delimiter"&&(i=l(i,1)??"Nothing"),f(i)==="Sequence"?["At",n,...g(i)]:["At",n,i]):["Subscript",n,i]}},{name:"List",kind:"matchfix",openTrigger:"[",closeTrigger:"]",parse:Br,serialize:ro},{kind:"matchfix",openTrigger:"(",closeTrigger:")",parse:io},{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:so,serialize:(e,n)=>{let t=g(n);if(t.length===0)return"";if(t.length===1)return"1.."+e.serialize(l(n,1));if(t.length===2)return e.wrap(l(n,1),10)+".."+e.wrap(l(n,2),10);if(t.length===3){let i=I(l(n,3)),r=I(l(n,1));return i!==null&&r!==null?e.wrap(l(n,1),10)+".."+e.wrap(r+i,10)+".."+e.wrap(l(n,2),10):e.wrap(l(n,1),10)+"..("+(e.wrap(l(n,1),F)+"+"+e.wrap(l(n,3),F))+").."+e.wrap(l(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=>f(r)==="Assign")?oo(i):["Delimiter",["Sequence",...i],"';'"]}},{latexTrigger:["\\text"],kind:"infix",associativity:"none",precedence:21,parse:(e,n,t)=>{let i=e.index;return j(e,"where")?_r(e,n,t):(e.index=i,null)}},{symbolTrigger:"where",kind:"infix",associativity:"none",precedence:21,parse:(e,n,t)=>_r(e,n,t)},{latexTrigger:["\\text"],kind:"infix",associativity:"right",precedence:235,parse:(e,n,t)=>{let i=e.index;if(!j(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(!j(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(!j(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(!j(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(!j(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 j(e,"for all")?ye("ForAll")(e,n):(e.index=t,null)}},{latexTrigger:["\\text"],kind:"prefix",precedence:200,parse:(e,n)=>{let t=e.index;return j(e,"there exists")?ye("Exists")(e,n):(e.index=t,null)}},{name:"Block",serialize:(e,n)=>{let t=g(n);return!t||t.length===0?"":t.filter(r=>f(r)!=="Declare").map(r=>e.serialize(r)).join("; ")}},{name:"If",serialize:(e,n)=>{let t=g(n);return!t||t.length<3?"":x(["\\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=g(n);if(!t||t.length<2)return"";let i=t[0],r=t[1];if(f(r)==="Element"){let s=l(r,1),o=l(r,2);if(f(o)==="Range"){let a=l(o,1),u=l(o,2);return x(["\\text{for }",e.serialize(s),"\\text{ from }",e.serialize(a),"\\text{ to }",e.serialize(u),"\\text{ do }",e.serialize(i)])}}return x(["\\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=l(n,1);return!t||b(t)==="Nothing"?"\\text{return}":x(["\\text{return }",e.serialize(t)])}},{symbolTrigger:"if",kind:"prefix",precedence:245,parse:(e,n)=>Ar(e,n)},{symbolTrigger:"for",kind:"prefix",precedence:245,parse:(e,n)=>Pr(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=g(n);if(t.length===0)return"";let i=-1,r=-1;for(let a=0;a<t.length;a++)w(t[a])!==null&&(i<0&&(i=a),r=a);if(i<0)return x(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=w(t[a]);u!==null?o+=Dr(u):f(t[a])==="Annotated"||f(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 x(s)}},{name:"String",latexTrigger:["\\text"],parse:(e,n)=>{let t=e.index;return j(e,"if")?Ar(e,n):(e.index=t,j(e,"for")?Pr(e,n):(e.index=t,j(e,"break")?["Break"]:(e.index=t,j(e,"continue")?["Continue"]:(e.index=t,j(e,"return")?["Return",e.parseExpression(n)??"Nothing"]:(e.index=t,ie(e))))))},serialize:(e,n)=>{let t=g(n);return t.length===0?"\\text{}":x(["\\text{",t.map(i=>e.serialize(i)).join(""),"}"])}},{name:"Subscript",latexTrigger:["_"],kind:"infix",serialize:(e,n)=>P(n)===2?e.serialize(l(n,1))+"_{"+e.serialize(l(n,2))+"}":"_{"+e.serialize(l(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)=>fe(e,n,1),serialize:(e,n)=>{let t=I(l(n,2))??1,i=e.serialize(l(n,1));return t===1?i+"^\\prime":t===2?i+"^\\doubleprime":t===3?i+"^\\tripleprime":i+"^{("+e.serialize(l(n,2))+")}"}},{latexTrigger:"^{\\prime\\prime}",kind:"postfix",parse:(e,n)=>fe(e,n,2)},{latexTrigger:"^{\\prime\\prime\\prime}",kind:"postfix",parse:(e,n)=>fe(e,n,3)},{latexTrigger:["^","\\doubleprime"],kind:"postfix",parse:(e,n)=>fe(e,n,2)},{latexTrigger:["^","\\tripleprime"],kind:"postfix",parse:(e,n)=>fe(e,n,3)},{latexTrigger:"'",kind:"postfix",precedence:810,parse:(e,n)=>fe(e,n,1)},{latexTrigger:"\\prime",kind:"postfix",precedence:810,parse:(e,n)=>fe(e,n,1)},{latexTrigger:"\\doubleprime",kind:"postfix",precedence:810,parse:(e,n)=>fe(e,n,2)},{latexTrigger:"\\tripleprime",kind:"postfix",precedence:810,parse:(e,n)=>fe(e,n,3)},{latexTrigger:["^","<{>","("],kind:"postfix",parse:(e,n,t)=>{let i=b(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(f(n)==="Matrix")return e.match("<}>"),["Inverse",n];let t=b(n);if(!t)return null;let i=e.getSymbolType(t);if(i.matches(new ne("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(l(n,1))+"^{-1}"},{name:"Derivative",serialize:(e,n)=>{let t=I(l(n,2))??1,i=e.serialize(l(n,1));return t===1?i+"^{\\prime}":t===2?i+"^{\\doubleprime}":t===3?i+"^{\\tripleprime}":i+"^{("+e.serialize(l(n,2))+")}"}},{name:"D",serialize:(e,n)=>{if(f(n)!=="D")return"D";let t=l(n,1),i=l(n,2);if(!t||!i)return"D";let r=1,s=t;for(;f(s)==="D";){let c=l(s,2);if(b(c)===b(i))r++,s=l(s,1);else break}let o=s;f(s)==="Function"&&(o=l(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=I(o)??1}else i=!0;if(!t)return null;e.skipSpace();let r=e.parseExpression({minPrec:740});if(!r)return null;let s=r;for(let o=0;o<n;o++)s=["D",s,t];return s}},{kind:"environment",name:"Which",symbolTrigger:"cases",parse:Ai,serialize:(e,n)=>{let t=[],i=g(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 x(["\\begin{cases}",t.join("\\\\"),"\\end{cases}"])}},{kind:"environment",symbolTrigger:"dcases",parse:Ai},{kind:"environment",symbolTrigger:"rcases",parse:Ai}];function ie(e,n){if(!e.match("<{>"))return"''";let t=[],i="",r=null,s=()=>{r!==null&&i?t.push(["Annotated",`'${i}'`,Gn(r)]):i&&t.push(`'${i}'`),i="",r=null};for(;!e.atEnd&&!e.match("<}>");)if(e.peek==="<{>")s(),t.push(ie(e));else if(e.match("\\textbf"))s(),t.push(ie(e,{fontWeight:"bold"}));else if(e.match("\\textmd"))s(),t.push(ie(e,{fontStyle:"normal"}));else if(e.match("\\textup"))s(),t.push(ie(e,{fontStyle:"normal"}));else if(e.match("\\textsl"))s(),t.push(ie(e,{fontStyle:"italic"}));else if(e.match("\\textit"))s(),t.push(ie(e,{fontStyle:"italic"}));else if(e.match("\\texttt"))s(),t.push(ie(e,{fontFamily:"monospace"}));else if(e.match("\\textsf"))s(),t.push(ie(e,{fontFamily:"sans-serif"}));else if(e.match("\\textcolor")){let a=e.index,u=e.parseStringGroup();if(u!==null){s();let c=ie(e);t.push(["Annotated",c,Gn({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=>w(a)!==null)?o="'"+t.map(a=>w(a)).join()+"'":o=["Text",...t],n?["Annotated",o,Gn(n)]:o}function no(e,n){return n===null?"":x(Zn(n,t=>{let i=w(t);return i===null?e.serialize(t):i==="<{>"?"{":i==="<}>"?"}":i==="<$>"?"$":i==="<$$>"?"$$":i==="<space>"?" ":i}))}function Dr(e){return e===null?"":e.replace(/[{}\[\]\\:\-\$%]/g,n=>({"{":"\\lbrace ","}":"\\rbrace ","[":"\\lbrack ","]":"\\rbrack ",":":"\\colon ","\\":"\\backslash "})[n]??"\\"+n)}function to(e,n){let t=l(n,2);return t?f(t)==="LatexString"?w(l(t,1))??"":f(t)==="Hold"?e.serialize(l(t,1)):e.serialize(t):""}function fe(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=f(n);if(i==="Derivative"||i==="Prime"){let a=I(l(n,2))??1;return[i,A(l(n,1)),a+t]}let r=b(n),s=r&&e.getSymbolType(r).matches("function")||f(n);e.skipSpace();let o=e.parseArguments("enclosure");if(o&&o.length>0){let a=o[0],u=b(a)??"x",p=typeof n=="string"?[n,...o]:["Apply",n,...o];for(let h=0;h<t;h++)p=["D",p,u];return p}return s?t===1?["Derivative",n]:["Derivative",n,t]:t===1?["Prime",A(n)]:["Prime",A(n),t]}function io(e,n){if(_(n))return["Delimiter"];let t=f(n);if(t==="Delimiter"&&l(n,2)!==null){let i=w(l(n,2));if(i?.length===1)return["Delimiter",l(n,1)??"Nothing",{str:`(${i})`}]}return t==="Matrix"&&(w(l(n,2))??"..")===".."?["Matrix",l(n,1)]:["Delimiter",n]}function Br(e,n){if(_(n))return["List"];let t=f(n);if(t==="Range"||t==="Linspace")return n;if(t==="Sequence")return["List",...g(n)];if(t==="Delimiter"){let i=w(l(n,2))??"...";if(i===";"||i===".;.")return["List",...(g(l(n,1))??[]).map(r=>Br(e,r))];if(i===","||i===".,.")return n=l(n,1),f(n)==="Sequence"?["List",...g(n)]:["List",n??"Nothing"]}return["List",n]}function ro(e,n){return P(n)>1&&g(n).every(t=>{let i=f(t);return gi(i)||hi(i)})?x(["\\begin{cases}",re("\\\\")(e,n),"\\end{cases}"]):x(["\\bigl\\lbrack",re(", ")(e,n),"\\bigr\\rbrack"])}function so(e,n){if(n===null)return null;let t=e.parseExpression({minPrec:270});if(t===null)return null;if(f(t)==="Range"){let i=l(t,1),r=l(t,2);return i&&r?["Range",n,r,["Subtract",i,n]]:null}return["Range",n,t]}var Wn={"(":"(",")":")","[":"\\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 Un(e,n,t){let i=(t?.minPrec??0)>=19,r=b(n);if(r&&r.includes("_")){let a=r.indexOf("_"),u=r.substring(0,a),c=r.substring(a+1),p=parseInt(c,10),h=!isNaN(p)&&String(p)===c?p:c,N=h!==""&&(typeof h=="number"||typeof h=="string"&&h.length===1);(e.getSymbolType(u).matches("indexed_collection")||!i&&N)&&(n=["Subscript",u,h])}if(f(n)==="InvisibleOperator"&&P(n)===2&&f(l(n,2))==="Delimiter"){let a=b(l(n,1));if(!a)return null;let u=e.parseExpression({...t??{},minPrec:20});if(u===null)return null;let c=l(l(n,2),1),p=[];return f(c)==="Sequence"?p=[...g(c)]:c&&(p=[c]),["Assign",a,["Function",u,...p??[]]]}if(f(n)==="Subscript"&&b(l(n,1))){let a=b(l(n,1));if(!e.getSymbolType(a).matches("indexed_collection")){let p=l(n,2),h=(p!==null&&typeof p=="string"?p:void 0)??(p!==null&&typeof p=="number"?String(p):void 0);if(h&&i){let N=e.parseExpression({...t??{},minPrec:20});return N===null?null:["Assign",a+"_"+h,N]}}let u=e.parseExpression({...t??{},minPrec:20});if(u===null)return null;let c=l(n,2);return w(c)!==null?["Assign",n,u]:b(c)?["Assign",n,u]:["Assign",n,u]}let s=f(n);if(s){let a=g(n),u=e.parseExpression({...t??{},minPrec:20});return u===null?null:["Assign",s,["Function",u,...a]]}if(!b(n))return null;let o=e.parseExpression({...t??{},minPrec:20});return o===null?null:["Assign",n,o]}function Ai(e){let n=e.parseTabular();if(!n)return["List"];if(n.every(i=>{if(i.length!==1)return!1;let r=f(i[0]);return hi(r)||gi(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=w(i[1]);t.push(r?"True":Si(i[1])??"True"),t.push(i[0])}return["Which",...t]}function j(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 $e(e,n){let t=e.index;if(e.skipVisualSpace(),e.match("\\text")){if(j(e,n))return!0;e.index=t}let i=e.index,r=e.parseSymbol();return r!==null&&b(r)===n?!0:(e.index=i,!1)}function sn(e,n){let t=e.index,i=$e(e,n);return e.index=t,i}function Ar(e,n){e.skipVisualSpace();let t=e.parseExpression({minPrec:0,condition:s=>sn(s,"then")});if(t===null||!$e(e,"then"))return null;e.skipVisualSpace();let i=e.parseExpression({minPrec:0,condition:s=>sn(s,"else")});if(i===null||!$e(e,"else"))return null;e.skipVisualSpace();let r=e.parseExpression(n)??"Nothing";return["If",t,i,r]}function Pr(e,n){let t=e.parseExpression({minPrec:0,condition:a=>sn(a,"from")}),i=t?b(t):null;if(!i||!$e(e,"from"))return null;let r=e.parseExpression({minPrec:0,condition:a=>sn(a,"to")});if(r===null||!$e(e,"to"))return null;let s=e.parseExpression({minPrec:0,condition:a=>sn(a,"do")});return s===null||!$e(e,"do")?null:["Loop",e.parseExpression(n)??"Nothing",["Element",i,["Range",r,s]]]}function _r(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=Cr(o);f(a)==="Assign"&&s.push(["Declare",l(a,1)]),s.push(a)}return s.push(n),["Block",...s]}function oo(e){let n=[];for(let t of e){let i=Cr(t);f(i)==="Assign"&&n.push(["Declare",l(i,1)]),n.push(i)}return["Block",...n]}function Cr(e){if(f(e)!=="Assign")return e;let n=l(e,1);if(f(n)!=="Subscript")return e;let t=b(l(n,1));if(!t)return e;let i=l(n,2),r=(typeof i=="string"?i:void 0)??(typeof i=="number"?String(i):void 0);return r?["Assign",`${t}_${r}`,l(e,2)??"Nothing"]:e}function Pi(...e){return(n,t)=>{if(!b(t)&&f(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)||w(i)!==null?null:(f(i)==="Delimiter"&&(i=l(i,1)??"Nothing"),f(i)==="Sequence"?["At",t,...g(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]],Or=[...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 Fr=[{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 se(e,n,t){if(_(e))return null;let i,r=f(e);if(r==="Delimiter"){let c=w(l(e,2));if(c!==","&&c!=="(,)"&&c!=="[,]")return null;let p=l(e,1);f(p)==="Sequence"?i=[...g(p)]:i=p?[p]:[]}else if(r==="Sequence")i=[...g(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 Lr=[{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:Vr},{kind:"matchfix",openTrigger:["["],closeTrigger:[")"],parse:(e,n)=>se(n,!1,!0)},{kind:"matchfix",openTrigger:["\\lbrack"],closeTrigger:["\\rparen"],parse:(e,n)=>se(n,!1,!0)},{kind:"matchfix",openTrigger:["\\lbrack"],closeTrigger:[")"],parse:(e,n)=>se(n,!1,!0)},{kind:"matchfix",openTrigger:["["],closeTrigger:["\\rparen"],parse:(e,n)=>se(n,!1,!0)},{kind:"matchfix",openTrigger:["("],closeTrigger:["]"],parse:(e,n)=>se(n,!0,!1)},{kind:"matchfix",openTrigger:["\\lparen"],closeTrigger:["\\rbrack"],parse:(e,n)=>se(n,!0,!1)},{kind:"matchfix",openTrigger:["\\lparen"],closeTrigger:["]"],parse:(e,n)=>se(n,!0,!1)},{kind:"matchfix",openTrigger:["("],closeTrigger:["\\rbrack"],parse:(e,n)=>se(n,!0,!1)},{kind:"matchfix",openTrigger:["]"],closeTrigger:["["],parse:(e,n)=>se(n,!0,!0)},{kind:"matchfix",openTrigger:["\\rbrack"],closeTrigger:["\\lbrack"],parse:(e,n)=>se(n,!0,!0)},{name:"Multiple",serialize:Vr},{name:"Union",latexTrigger:["\\cup"],kind:"infix",precedence:350},{name:"Set",kind:"matchfix",openTrigger:"{",closeTrigger:"}",parse:(e,n)=>_(n)?"EmptySet":(f(n)=="Delimiter"&&w(l(n,2))===","&&(n=l(n,1)),f(n)!=="Sequence"?["Set",n]:["Set",...g(n)]),serialize:(e,n)=>x(["\\lbrace",g(n).map(t=>e.serialize(t)).join(", "),"\\rbrace"])},{name:"SetMinus",latexTrigger:["\\setminus"],kind:"infix",precedence:650},{name:"SymmetricDifference",latexTrigger:["\\triangle"],kind:"infix",precedence:k},{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 Vr(e,n){if(n===null)return"";let t=f(n);if(!t)return"";if(t==="Set")return P(n)===0?"\\emptyset":P(n)===2&&f(l(n,2))==="Condition"?x(["\\left\\lbrace",e.serialize(l(n,1)),"\\middle\\mid",e.serialize(l(n,2)),"\\right\\rbrace"]):x(["\\left\\lbrace",...g(n).map(r=>e.serialize(r)+" ,"),"\\right\\rbrace"]);if(t==="Range")return x(["\\mathopen\\lbrack",e.serialize(l(n,1)),", ",e.serialize(l(n,2)),"\\mathclose\\rbrack"]);if(t==="Interval"){let r=l(n,1),s=l(n,2),o=!1,a=!1;return f(r)==="Open"&&(r=l(r,1),o=!0),f(s)==="Open"&&(s=l(s,1),a=!0),x([o?"\\lparen":"\\lbrack",e.serialize(r),", ",e.serialize(s),a?"\\rparen":"\\rbrack"])}let i=e.numericSetStyle(n,e.level);return""}function qe(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 x(i.map(r=>{switch(r){case"#1":return n;case"#2":return t;default:return r}}))}function Yn(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 ao(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,c=i;return a>=60&&(a=0,u++),u>=60&&(u=0,c++),{deg:n*c||0,min:n*u||0,sec:a===0?0:n*a}}function Xn(e){let{deg:n,min:t,sec:i}=ao(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 uo(e){if(f(e)!=="Multiply")return[[],[]];let n=[],t=[];for(let i of g(e))if(f(i)==="Power"){let r=l(i,1),s=l(i,2);if(f(s)==="Negate"){let o=l(s,1);r&&o&&t.push(["Power",r,o])}else{let o=I(s)??NaN;o===-1?r&&t.push(r):o<0?r&&t.push(["Power",r,-o]):n.push(i)}}else if(f(i)==="Rational"&&P(i)===2||f(i)==="Divide"){let r=l(i,1),s=l(i,2);I(r)!==1&&n.push(r),I(s)!==1&&t.push(s)}else{let r=Le(i);r!==null?(r[0]!==1&&n.push(r[0]),t.push(r[1])):n.push(i)}return[n,t]}function lo(e){let n=e.parseOptionalGroup(),t=e.parseGroup()??e.parseToken();return _(t)?n!==null?["Root",Oe,A(n)]:["Sqrt",Oe]:n!==null?["Root",t,n]:["Sqrt",t]}function co(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 an(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)+"}}":I(i)===2?"\\sqrt{"+e.serialize(t)+"}":"\\sqrt["+e.serialize(i)+"]{"+e.serialize(t)+"}")}function fo(e,n){e.level-=1;let t=f(n),i="",r=l(n,1);if(t==="Negate")i="-"+e.wrap(r,F+1);else if(t==="Subtract"){i=e.wrap(r,F);let s=l(n,2);if(s!==null){let o=e.wrap(s,F);o[0]==="-"?i+="+"+o.slice(1):o[0]==="+"?i+="-"+o.slice(1):i=i+"-"+o}}else if(t==="Add"){if(e.options.prettify&&P(n)===2&&e.options.invisiblePlus!=="+"){let[a,u]=[l(n,1),l(n,2)],[c,p]=[a,u],h=I(c),N=Le(p);if((h===null||N===null)&&([c,p]=[u,a],h=I(c),N=Le(p)),h!==null&&N!==null&&isFinite(h)&&Number.isInteger(h)&&h>=0&&h<=1e3&&isFinite(N[0])&&isFinite(N[1])&&N[0]>0&&N[0]<=100&&N[1]<=100)return i=qe(e.options.invisiblePlus,e.serialize(c),e.serialize(p)),e.level+=1,i}if(e.options.prettify&&P(n)===2){let[a,u]=un(r),[c,p]=un(l(n,2));if(u<0&&p>0)return i=e.wrap(c,F)+"-"+e.wrap(a,F),e.level+=1,i}i=e.serialize(r);let s=P(n)+1,o=g(n);for(let a=2;a<s;a++)if(r=o[a-1],e.options.prettify){let[u,c]=un(r),p=e.wrap(u,F);c>0?p.startsWith("+")||p.startsWith("-")?i+=p:i+="+"+p:p.startsWith("+")?i+="-"+p.slice(1):p.startsWith("-")?i+="+"+p.slice(1):i+="-"+p}else{let u=e.wrap(r,F);u[0]==="-"||u[0]==="+"?i+=u:i+="+"+u}}return e.level+=1,i}function jr(e,n){if(n===null)return"";e.level-=1;let t="";if(e.options.prettify===!0){let[u,c]=uo(n);c.length>0&&(c.length===1&&c[0]===1?u.length===0?t="1":u.length===1?t=e.serialize(u[0]):t=jr(e,["Multiply",...u]):t=e.serialize(["Divide",u.length===1?u[0]:["Multiply",...u],c.length===1?c[0]:["Multiply",...c]]))}if(t)return e.level+=1,t;let i=!1,r=null,s=P(n)+1,o=g(n);e.options.prettify===!0&&o.length===2&&ve(o[1])&&!ve(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 c;if(ve(r)){c=e.serialize(r),c==="-1"&&!t?(t="",i=!i):(c[0]==="-"&&(c=c.slice(1),i=!i),t?t=qe(e.options.multiply,t,c):t=c),a=!0;continue}if(f(r)==="Power"){let p=Le(l(r,2));if(p!=null){let[h,N]=p;if(h===1&&N!==null){t+=an(e,e.rootStyle(r,e.level),l(r,1),N),a=!1;continue}}}if(f(r)==="Power"&&!isNaN(I(l(r,1))??NaN)){c=e.serialize(r),t?t=qe(e.options.multiply,t,c):t=c,a=!0;continue}if(f(r)==="Negate"&&(r=l(r,1),i=!i),c=e.wrap(r,W),!t)t=c;else{let p=f(r);a&&(p==="Divide"||p==="Rational")?t=qe(e.options.multiply,t,c):e.options.invisibleMultiply?t=qe(e.options.invisibleMultiply,t,c):t=x([t,c])}a=!1}return e.level+=1,i?"-"+t:t}function Kn(e){let n=e.parseGroup(),t=null;if(n===null?(n=e.parseToken(),t=e.parseToken()):t=e.parseGroup(),n=A(n),t=A(t),f(n)==="PartialDerivative"&&(f(t)==="PartialDerivative"||f(t)==="Multiply"&&f(l(t,1))==="PartialDerivative")){let s=l(n,3)??null,o=l(n,1);o==null&&(o=A(e.parseExpression()));let a=[];if(f(t)==="Multiply"){for(let u of g(t))if(f(u)==="PartialDerivative"){let c=l(u,2);c&&a.push(c)}}else{let u=l(t,2);u&&a.push(u)}return a.length>1&&(a=["List",...a]),["PartialDerivative",o,...a,s===null?1:s]}let i=b(n);if(i==="d"||i==="d_upright"||i==="differentialD"){let s=[],o=a=>{if(!a)return;let u=b(a);if(u&&u!=="d"&&u!=="d_upright"&&u!=="differentialD"){s.push(a);return}let c=f(a);if(c==="Sequence"||c==="Multiply"||c==="InvisibleOperator")for(let p of g(a))o(p)};if(o(t),s.length===0){let a=b(t);a&&a.length>1&&a[0]==="d"&&s.push(a.slice(1))}if(s.length>0)return["D",A(e.parseExpression()),...s]}return["Divide",n,t]}function Jr(e,n){if(n===null)return"";let t=A(l(n,1)),i=A(l(n,2)),r=e.options.prettify?e.fractionStyle(n,e.level):"quotient";if(r==="inline-solidus"||r==="nice-solidus"){let u=e.wrapShort(t),c=e.wrapShort(i);return r==="inline-solidus"?`${u}/${c}`:`{}^{${u}}\\!\\!/\\!{}_{${c}}`}else{if(r==="reciprocal")return I(t)===1?e.wrap(i)+"^{-1}":e.wrap(t)+e.wrap(i)+"^{-1}";if(r==="factor")return I(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 _i(e,n){if(!n)return"";let t=f(n),i=A(l(n,1));if(t==="Sqrt")return an(e,e.rootStyle(n,e.level-1),i,2);let r=A(l(n,2));if(t==="Root")return an(e,e.rootStyle(n,e.level-1),i,r);if(e.options.prettify){let o=I(r)??1;if(o===-1)return e.serialize(["Divide","1",i]);if(o<0)return e.serialize(["Divide","1",["Power",i,-o]]);if(f(r)==="Divide"||f(r)==="Rational"){let a=I(l(r,1)),u=I(l(r,2));if(a===1){let c=e.rootStyle(n,e.level);return an(e,c,i,l(r,2))}if(a===-1)return u===2?e.serialize(["Divide","1",["Sqrt",i]]):e.serialize(["Divide","1",["Root",i,l(r,2)??Oe]]);if(u===2)return`${e.serialize(["Sqrt",i])}^{${e.serialize(l(r,1))}}`}else if(f(r)==="Power"&&I(l(r,2))===-1){let a=e.rootStyle(n,e.level);return an(e,a,i,l(r,1))}}let s=o=>o.startsWith("-")?e.wrapString(o,"normal"):o;if(f(i)==="Power"){let o=l(i,1),a=l(i,2),u=s(e.wrapShort(o)),c=e.wrapShort(a);return`
|
|
7
7
|
${u}^{${Pe("^",c,e.serialize(r))}}`}return Pe("^",s(e.wrapShort(i)),e.serialize(r))}function on(e,n){e.skipSpace();let t=e.index,i=e.parseNumber(),r=null,s=null;if(i!==null&&(e.match("'")||e.match("\\prime"))){r=I(i),e.skipSpace();let u=e.index,c=e.parseNumber();c!==null&&(e.match('"')||e.match("\\doubleprime"))?s=I(c):e.index=u}else return e.index=t,["Degrees",n];let o=I(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 Ur=[{name:"CatalanConstant",symbolTrigger:"G"},{name:"GoldenRatio",latexTrigger:"\\varphi"},{name:"EulerGamma",latexTrigger:"\\gamma"},{name:"Degrees",latexTrigger:["\\degree"],kind:"postfix",precedence:880,parse:(e,n)=>on(e,n),serialize:(e,n)=>{let t=e.options,i=l(n,1);if(t.dmsFormat||t.angleNormalization&&t.angleNormalization!=="none"){let r=I(i);if(r!==null){let s=r;return t.angleNormalization&&t.angleNormalization!=="none"&&(s=Yn(s,t.angleNormalization)),t.dmsFormat?Xn(s):`${s}\xB0`}}return x([e.serialize(i),"\\degree"])}},{latexTrigger:["\\degree"],kind:"postfix",precedence:880,parse:(e,n)=>on(e,n)},{latexTrigger:["^","<{>","\\circ","<}>"],kind:"postfix",parse:(e,n)=>on(e,n)},{latexTrigger:["^","\\circ"],kind:"postfix",parse:(e,n)=>on(e,n)},{latexTrigger:["\xB0"],kind:"postfix",precedence:880,parse:(e,n)=>on(e,n)},{latexTrigger:["\\ang"],parse:e=>{let n=e.parseGroup();return n===null?["Degrees"]:["Degrees",n]}},{name:"DMS",serialize:(e,n)=>{let t=I(l(n,1)),i=I(l(n,2)),r=I(l(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=l(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)=>_(n)?null:["Abs",n]},{kind:"matchfix",openTrigger:["\\vert"],closeTrigger:["\\vert"],parse:(e,n)=>_(n)?null:["Abs",n]},{symbolTrigger:"abs",kind:"function",parse:"Abs"},{name:"Add",latexTrigger:["+"],kind:"infix",associativity:"any",precedence:F,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:F});if(i===null)return null;if(f(i)==="Negate"){let r=l(i,1);if(ve(r))return Je("Add",n,co(r))}return Je("Add",n,i)},serialize:fo},{kind:"prefix",latexTrigger:["+"],precedence:F,parse:(e,n)=>e.parseExpression({...n,minPrec:400})},{name:"Ceil",kind:"matchfix",openTrigger:"\\lceil",closeTrigger:"\\rceil",parse:(e,n)=>_(n)?null:["Ceil",n]},{kind:"matchfix",openTrigger:["\u2308"],closeTrigger:["\u2309"],parse:(e,n)=>_(n)?null:["Ceil",n]},{symbolTrigger:"ceil",kind:"function",parse:"Ceil"},{name:"Chop",symbolTrigger:"chop",kind:"function",parse:"Chop"},{name:"Complex",precedence:F-1,serialize:(e,n)=>{let t=e.serialize(l(n,1)),i=I(l(n,2));if(i===0)return t;let r=i===1?"\\imaginaryI":i===-1?"-\\imaginaryI":x([e.serialize(l(n,2)),"\\imaginaryI"]);return I(l(n,1))===0?r:i!==null&&i<0?x([t,r]):x([t,"+",r])}},{name:"Divide",latexTrigger:"\\frac",precedence:K,parse:Kn,serialize:Jr},{latexTrigger:"\\dfrac",precedence:K,parse:Kn},{latexTrigger:"\\tfrac",precedence:K,parse:Kn},{latexTrigger:"\\cfrac",precedence:K,parse:Kn},{kind:"infix",latexTrigger:"\\over",associativity:"none",precedence:K,parse:"Divide"},{latexTrigger:["\\/"],kind:"infix",associativity:"left",precedence:K,parse:"Divide"},{latexTrigger:["/"],kind:"infix",associativity:"left",precedence:K,parse:"Divide"},{latexTrigger:["\\div"],kind:"infix",associativity:"left",precedence:K,parse:"Divide"},{name:"Exp",serialize:(e,n)=>{let t=l(n,1);return b(t)||I(t)!==null?x(["\\exponentialE^{",e.serialize(t),"}"]):x(["\\exp",e.wrap(A(t))])}},{name:"Factorial",latexTrigger:["!"],kind:"postfix",precedence:di},{name:"Factorial2",latexTrigger:["!","!"],kind:"postfix",precedence:di},{name:"Floor",kind:"matchfix",openTrigger:"\\lfloor",closeTrigger:"\\rfloor",parse:(e,n)=>_(n)?null:["Floor",n]},{kind:"matchfix",openTrigger:["\u230A"],closeTrigger:["\u230B"],parse:(e,n)=>_(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=l(n,1),i=l(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=l(n,1),i=l(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=l(n,1),i=l(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=l(n,1),i=l(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=>Zr("Ln",e),serialize:(e,n)=>"\\ln"+e.wrapArguments(n)},{name:"Log",latexTrigger:["\\log"],parse:e=>Zr("Log",e),serialize:(e,n)=>{let[t,i]=g(n);return i?x(["\\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(f(n)!=="To")return null;let t=e.parseArguments("implicit");return t?["Limit",["Function",t[0],l(n,1)],l(n,2)]:null},serialize:(e,n)=>{let t=l(n,1),i=l(t,2),r=l(n,2);return x(["\\lim_{",e.serialize(i),"\\to",e.serialize(r),"}",e.serialize(l(t,1))])}},{name:"MinusPlus",latexTrigger:["\\mp"],kind:"infix",associativity:"any",precedence:ce},{name:"Multiply",latexTrigger:["\\times"],kind:"infix",associativity:"any",precedence:W,serialize:jr},{latexTrigger:["\\cdot"],kind:"infix",associativity:"any",precedence:W,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:W+2});return i===null?null:Je("Multiply",n,i)}},{latexTrigger:["*"],kind:"infix",associativity:"any",precedence:W,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:W+2});return i===null?["Multiply",n,Oe]:Je("Multiply",n,i)}},{name:"Mod",latexTrigger:"\\bmod",kind:"infix",precedence:K,serialize:(e,n)=>{if(P(n)!==2)return"";let t=e.serialize(l(n,1)),i=e.serialize(l(n,2));return x([t,"\\bmod",i])}},{latexTrigger:"\\mod",kind:"infix",precedence:K,parse:"Mod"},{latexTrigger:"\\pmod",kind:"prefix",precedence:k,parse:e=>{let n=e.parseGroup()??e.parseToken();return["Mod",A(n)]}},{name:"Congruent",serialize:(e,n)=>{let t=e.serialize(l(n,1)),i=e.serialize(l(n,2));if(l(n,3)===null)return x([t,"\\equiv",i]);let r=e.serialize(l(n,3));return x([t,"\\equiv",i,"\\pmod{",r,"}"])}},{name:"Negate",latexTrigger:["-"],kind:"prefix",precedence:nn+1,parse:(e,n)=>{e.skipSpace();let t=e.parseExpression({...n,minPrec:nn+3});return t===null?null:["Negate",t]}},{kind:"matchfix",openTrigger:"||",closeTrigger:"||",parse:(e,n)=>_(n)?null:["Norm",n]},{name:"Norm",kind:"matchfix",openTrigger:["\\left","\\Vert"],closeTrigger:["\\right","\\Vert"],parse:(e,n)=>_(n)?null:["Norm",n],serialize:(e,n)=>{let t=l(n,1);if(f(t)==="Matrix"){let i=l(t,1),r=l(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:ce,serialize:(e,n)=>{let t=l(n,1);if(t===null)return"\\pm";if(P(n)===1)return x(["\\pm",e.serialize(t)]);let i=l(n,2);return x([e.serialize(t),"\\pm",e.serialize(i)])}},{latexTrigger:["\\pm"],kind:"prefix",precedence:ce,parse:(e,n)=>{let t=e.parseExpression({...n,minPrec:400});return["PlusMinus",0,A(t)]}},{latexTrigger:["\\plusmn"],kind:"infix",associativity:"any",precedence:ce,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:400});return["PlusMinus",n,A(i)]}},{latexTrigger:["\\plusmn"],kind:"prefix",precedence:ce,parse:(e,n)=>{let t=e.parseExpression({...n,minPrec:400});return["PlusMinus",A(t)]}},{name:"Power",latexTrigger:["^"],kind:"infix",serialize:_i},{latexTrigger:"\\prod",precedence:W,name:"Product",parse:qr("Product","Multiply",W),serialize:Gr("\\prod")},{latexTrigger:["*","*"],kind:"infix",associativity:"right",precedence:nn,parse:(e,n,t)=>{if(e.options.strict!==!1)return null;let i=e.parseExpression({...t,minPrec:nn});return i===null?null:["Power",n,i]}},{name:"Rational",precedence:K,serialize:(e,n)=>n&&P(n)===1?"\\operatorname{Rational}"+e.wrapArguments(n):Jr(e,n)},{name:"Reduce",serialize:(e,n)=>{let t=l(n,1);if(!t)return"";let i=l(n,2);return b(i)==="Add"?`\\sum ${e.serialize(t)}`:b(i)==="Multiply"?`\\prod ${e.serialize(t)}`:`\\operatorname{Reduce}\\left(${e.serialize(t)}, ${e.serialize(l(n,2))}\\right)`}},{name:"Root",serialize:_i},{name:"Round",symbolTrigger:"round",kind:"function"},{name:"Square",precedence:720,serialize:(e,n)=>{let t=e.wrapShort(l(n,1));return(t.startsWith("-")?e.wrapString(t,"normal"):t)+"^2"}},{latexTrigger:["\\sum"],precedence:F,name:"Sum",parse:qr("Sum","Add",W),serialize:Gr("\\sum")},{name:"Heaviside",symbolTrigger:"Heaviside",kind:"function"},{name:"Sign",symbolTrigger:"sgn",kind:"function"},{name:"Sqrt",latexTrigger:["\\sqrt"],parse:lo,serialize:_i},{name:"Subtract",latexTrigger:["-"],kind:"infix",associativity:"left",precedence:F+2,parse:(e,n,t)=>{let i=e.parseExpression({...t,minPrec:F+3});return i===null?null:["Subtract",n,i]},serialize:(e,n)=>{let t=e.wrap(l(n,1),F+2),i=e.wrap(l(n,2),F+3);return x([t,"-",i])}}];function po(e,n){if(e!==null){if(b(e))return{index:b(e)??"Nothing",upper:n};if(f(e)==="GreaterEqual"){let t=b(l(e,1))??"Nothing",i=l(e,2)??1;return{index:t,lower:i,upper:n}}if(f(e)==="Equal"){let t=b(l(e,1))??"Nothing",i=l(e,2);if(f(i)==="Range"){let s=l(i,1)??1,o=l(i,2)??void 0;return{index:t,lower:s,upper:o}}return{index:t,lower:i??1,upper:n}}if(f(e)==="Element")return{index:b(l(e,1))??"Nothing",element:e}}}function mo(e){let n=f(e);return n?new Set(["Less","LessEqual","Greater","GreaterEqual","NotEqual","And","Or","Not"]).has(n):!1}function $r(e){if(e===null)return[];let n=Ie(e);if(n)return[...n];if(f(e)==="Tuple"){let t=g(e);return t?[...t]:[e]}return[e]}function ho(e,n){_(e)&&(e=null),_(n)&&(n=null);let t=$r(e),i=$r(n),r=[],s=0;for(;s<t.length;){let o=t[s],a=po(o,i[s]);if(a){if(a.element&&s+1<t.length){let u=t[s+1];if(mo(u)&&f(u)!=="Element"&&f(u)!=="Equal"){let c=a.element;if(Array.isArray(c)&&c.length>=3){let p=[c[0],...c.slice(1),u];a.element=p}s++}}r.push(a)}s++}return r}function qr(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 c=i.parseExpression({minPrec:t});return i.popSymbolTable(),c?["Reduce",c,n]:null}let o=ho(s,r),a=i.parseExpression({minPrec:t});if(i.popSymbolTable(),a===null)return[e];let u=[];for(let c of o){if(c.element){u.push(c.element);continue}let p=c.lower,h=c.upper,N=c.index??"Nothing";h!=null?u.push(["Tuple",N,p??1,h]):p!=null?u.push(["Tuple",N,p]):u.push(["Tuple",N])}return[e,a,...u]}}var go=new Set(["Tuple","Triple","Pair","Single","Limits","Element"]);function zr(e){return e==null||b(e)==="Nothing"?null:e}function yo(e){let n=[],t=g(e);if(t.length<=1)return n;for(let i of t.slice(1)){let r=f(i);if(r&&go.has(r)){n.push(i);continue}break}return n}function xo(e,n){if(f(n)==="Element"){let c=e.serialize(l(n,1)),p=e.serialize(l(n,2));return{sub:`${c}\\in ${p}`}}let t=l(n,1);t!==null&&f(t)==="Hold"&&(t=l(t,1));let i=zr(l(n,2)),r=zr(l(n,3)),s={},o=t?b(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 Gr(e){return(n,t)=>{let i=l(t,1);if(!i)return e;let r=yo(t),s=e;if(r.length>0){let o=[],a=[];for(let u of r){let c=xo(n,u);c.sub&&o.push(c.sub),c.sup&&a.push(c.sup)}o.length>0&&(s=Pe("_",s,o.join(", "))),a.length>0&&(s=Pe("^",s,a.join(", ")))}return x([s,n.serialize(i)])}}function Zr(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 un(e){let n=1,t=e;do{e=t;let i=f(e);if(i==="Negate")n*=-1,t=l(e,1);else if(i==="Multiply"){let[r,s]=un(l(e,1));s<0&&(n*=-1,r===1?t=["Multiply",...g(e).slice(1)]:t=["Multiply",r,...g(e).slice(1)])}else if(i==="Divide"||i==="Rational"){let[r,s]=un(l(e,1));s<0&&(n*=-1,t=[i,r,l(e,2)])}else{let r=I(e);r!==null&&r<0&&(n*=-1,t=-r)}}while(t!==e);return[e,n]}var Wr=[{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 E(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 c=n.parsePostfixOperator(s,t);if(c===null)break;s=c}while(!0);n.skipSpace();let o=null;n.match("^")&&(o=n.parseGroup()??n.parseToken()),n.skipSpace();let a=n.parseArguments("implicit",{minPrec:W,condition:c=>i[c.peek]||(t?.condition?.(c)??!1)}),u=a===null?s:typeof s=="string"?[s,...a]:["Apply",s,...a];return o===null?u:["Power",u,o]}}var Hr=[{name:"Arcsin",latexTrigger:["\\arcsin"],parse:E("Arcsin")},{name:"Arccos",latexTrigger:["\\arccos"],parse:E("Arccos")},{name:"Arctan",latexTrigger:["\\arctan"],parse:E("Arctan")},{latexTrigger:["\\arctg"],parse:E("Arctan")},{symbolTrigger:"arctg",parse:E("Arctan")},{name:"Arccot",symbolTrigger:"arcctg",parse:E("Arccot")},{latexTrigger:["\\arcctg"],parse:E("Arccot")},{name:"Arcoth",symbolTrigger:"arcoth",parse:E("Arcoth")},{symbolTrigger:"arccoth",parse:E("Arcoth")},{latexTrigger:["\\arcoth"],parse:E("Arcoth")},{latexTrigger:["\\arccoth"],parse:E("Arcoth")},{name:"Arcsec",symbolTrigger:"arcsec",parse:E("Arcsec")},{latexTrigger:["\\arcsec"],parse:E("Arcsec")},{name:"Arccsc",symbolTrigger:"arccsc",parse:E("Arccsc")},{latexTrigger:["\\arccsc"],parse:E("Arccsc")},{name:"Arsinh",symbolTrigger:"arsinh",parse:E("Arsinh")},{symbolTrigger:"arcsinh",parse:E("Arsinh")},{latexTrigger:["\\arsinh"],parse:E("Arsinh")},{latexTrigger:["\\arcsinh"],parse:E("Arsinh")},{name:"Arcosh",symbolTrigger:"arcosh",parse:E("Arcosh")},{symbolTrigger:"arccosh",parse:E("Arcosh")},{latexTrigger:"\\arcosh",parse:E("Arcosh")},{latexTrigger:"\\arccosh",parse:E("Arcosh")},{name:"Artanh",symbolTrigger:"artanh",parse:E("Artanh")},{symbolTrigger:"arctanh",parse:E("Artanh")},{latexTrigger:"\\artanh",parse:E("Artanh")},{latexTrigger:["\\arctanh"],parse:E("Artanh")},{name:"Arsech",symbolTrigger:"arsech",parse:E("Arsech")},{symbolTrigger:"arcsech",parse:E("Arsech")},{latexTrigger:["\\arsech"],parse:E("Arsech")},{latexTrigger:["\\arcsech"],parse:E("Arsech")},{name:"Arcsch",symbolTrigger:"arcsch",parse:E("Arcsch")},{symbolTrigger:"arccsch",parse:E("Arcsch")},{latexTrigger:["\\arcsch"],parse:E("Arcsch")},{latexTrigger:["\\arccsch"],parse:E("Arcsch")},{name:"Cosec",symbolTrigger:"cosec",parse:E("Cosec")},{latexTrigger:["\\cosec"],parse:E("Cosec")},{name:"Cosh",latexTrigger:["\\cosh"],parse:E("Cosh")},{latexTrigger:["\\ch"],parse:E("Cosh")},{name:"Cot",latexTrigger:["\\cot"],parse:E("Cot")},{latexTrigger:["\\cotg"],parse:E("Cot")},{latexTrigger:["\\ctg"],parse:E("Cot")},{name:"Csc",latexTrigger:["\\csc"],parse:E("Csc")},{name:"Csch",latexTrigger:["\\csch"],parse:E("Csch")},{name:"Coth",latexTrigger:["\\coth"],parse:E("Coth")},{latexTrigger:["\\cth"],parse:E("Coth")},{symbolTrigger:"cth",parse:E("Coth")},{latexTrigger:["\\coth"],parse:E("Coth")},{name:"Sec",latexTrigger:["\\sec"],parse:E("Sec")},{name:"Sech",symbolTrigger:"sech",parse:E("Sech")},{latexTrigger:["\\sech"],parse:E("Sech")},{name:"Sinh",latexTrigger:["\\sinh"],parse:E("Sinh")},{latexTrigger:["\\sh"],parse:E("Sinh")},{name:"Tan",latexTrigger:["\\tan"],parse:E("Tan")},{latexTrigger:["\\tg"],parse:E("Tan")},{name:"Tanh",latexTrigger:["\\tanh"],parse:E("Tanh")},{latexTrigger:["\\th"],parse:E("Tanh")},{name:"Cos",latexTrigger:["\\cos"],parse:E("Cos")},{name:"Sin",latexTrigger:["\\sin"],parse:E("Sin")},{name:"Sinc",symbolTrigger:"sinc",kind:"function"},{name:"FresnelS",symbolTrigger:"FresnelS",kind:"function"},{name:"FresnelC",symbolTrigger:"FresnelC",kind:"function"}];function ze(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();_(u)&&(u=null),_(a)&&(a=null),i.push(u??"Nothing"),r.push(a??"Nothing"),n.skipVisualSpace(),t=!n.match(e)}let[s,o]=bo(n);if(s&&o.length===0){if(f(s)==="Add"||f(s)==="Subtract"){let a=[],u=[];for(let c of g(s))if(o)u.push(c);else{let p;[p,o]=pe(c),a.push(p??c)}if(o!==null&&u.length>0)return["Add",Yr(e,["Add",...a],{indexes:o,subs:i,sups:r})??"Nothing",...u]}else if(f(s)==="Divide"){let a;[a,o]=pe(l(s,1)),a!==null&&o!==null&&(s=["Divide",a,l(s,2)])}}return Yr(e,s,{indexes:o,subs:i,sups:r})}}function Yr(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?f(n)==="Function"?g(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],c=t.subs[a];return c==="Nothing"&&u==="Nothing"?o:["Tuple",o,c,u]});return[e,n,...s]}function bo(e){let n=!1,t=e.parseExpression({minPrec:266,condition:()=>{let i=e.index;return n=Qr(e),e.index=i,n}});return t!==null&&!n?pe(t):[t,No(e)]}function No(e){let n=[];for(;Qr(e);){e.skipVisualSpace();let t=b(e.parseSymbol());if(t===null)return n;n.push(t)}return n}function pe(e){let n=f(e),t=l(e,1);if(!t)return[e,[]];if(n==="Sequence"&&P(e)===1)return pe(t);if(n==="Multiply"||n==="InvisibleOperator"){let i=g(e);if(i){let[r,s]=Eo(i);return r.length>0?[[n,...r],s]:[null,s]}}else if(n==="Delimiter"){let[i,r]=pe(t);if(r)return i?[["Delimiter",["Sequence",i],...g(e).slice(1)],r]:[null,r]}else if(n==="Add"){let i=g(e);if(i.length>0){let[r,s]=pe(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]=pe(t);if(r.length>0)return[i?["Negate",i]:null,r]}else if(n==="Divide"){let[i,r]=pe(t);if(r.length>0)return[["Divide",i??1,l(e,2)],r]}else{let i=g(e);if(i.length===1){let[r,s]=pe(i[0]);if(s.length>0)return[[f(e),r],s]}}return[e,[]]}function Xr(e){return(n,t)=>{if(!l(t,1))return e;let i=l(t,1),r=[];f(i)==="BuiltInFunction"?(r=["x"],i=[l(i,1),"x"]):f(i)==="Function"?(r=g(i).slice(1),i=l(i,1)):b(i)?r=[]:r=[];let s=g(t).slice(1),o=[],a=s.map((c,p)=>{if(b(c)==="Nothing")return o.push(b(r[p])??"Nothing"),"";if(b(c))return o.push(b(c)??"Nothing"),"";let h=f(c);if(h==="Tuple"||h==="Pair"||h==="Limits"||h==="Range"){if(P(c)===3){let N=l(c,1);o.push(b(N)??"Nothing");let v=l(c,2),M=l(c,3);return b(v)==="Nothing"&&(v=null),b(M)==="Nothing"&&(M=null),v!==null&&M!==null?`_{${n.serialize(v)}}^{${n.serialize(M)}}`:v!==null?`_{${n.serialize(v)}}`:M!==null?`^{${n.serialize(M)}}`:""}return`_{${n.serialize(c)}}`}if(P(c)===2){if(b(l(c,1))){o.push(b(l(c,1))??"Nothing");let M=l(c,2);return b(M)==="Nothing"?"":`_{${n.serialize(M)}}`}o.push(b(r[p])??"Nothing");let N=l(c,1),v=l(c,2);if(b(N)==="Nothing"&&(N=null),b(v)==="Nothing"&&(v=null),N!==null&&v!==null)return`_{${n.serialize(N)}}^{${n.serialize(v)}}`;if(N!==null)return`_{${n.serialize(N)}}`;if(v!==null)return`^{${n.serialize(v)}}`}else o.push(b(r[p])??"Nothing")}),u=o.filter(c=>b(c)!=="Nothing").map(c=>`\\mathrm{d}${n.serialize(b(c)??"x")}`);return u.length>0&&(u=["\\,",...u]),a.length===0?`${e}\\,${n.serialize(i)}\\!${u.join(" ")}`:a.reverse().map(c=>`${e}${c}`).join("")+"\\!"+n.serialize(i)+u.join(" ")}}var Kr=[{kind:"expression",name:"Integrate",latexTrigger:["\\int"],parse:ze("Integrate"),serialize:Xr("\\int")},{kind:"expression",latexTrigger:["\\iint"],parse:ze("Integrate")},{kind:"expression",latexTrigger:["\\iiint"],parse:ze("Integrate")},{kind:"expression",name:"CircularIntegrate",latexTrigger:["\\oint"],parse:ze("CircularIntegrate"),serialize:Xr("\\oint")},{kind:"expression",latexTrigger:["\\oiint"],parse:ze("CircularIntegrate")},{kind:"expression",latexTrigger:["\\oiiint"],parse:ze("CircularIntegrate")}];function Qr(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 Eo(e){let n=[...e],t=[];for(;n.length>0;){let i;if([n,i]=To(n),!i)break;t.push(i)}return[n,t]}function To(e){if(e.length<2)return[e,""];let n=e[e.length-2];if(n==="d"||n==="d_upright"){let t=b(e[e.length-1]);if(t)return[e.slice(0,-2),t]}return[e,""]}var es=[{name:"Matrix",serialize:(e,n)=>{let t=g(l(n,1));return Ri(e,t,w(l(n,2)),w(l(n,3)))}},{name:"Vector",serialize:(e,n)=>{let t=g(n);return Ri(e,t.map(i=>["List",i]),w(l(n,2)),w(l(n,3)))}},{kind:"environment",symbolTrigger:"pmatrix",parse:e=>{let n=de(e),[t,i]=me(e);return n?[t,i,{str:"()"},{str:n}]:[t,i]}},{kind:"environment",symbolTrigger:"bmatrix",parse:e=>{let n=de(e),[t,i]=me(e);return n?[t,i,{str:"[]"},{str:n}]:[t,i,{str:"[]"}]}},{kind:"environment",symbolTrigger:"Bmatrix",parse:e=>{let n=de(e),[t,i]=me(e);return n?[t,i,{str:"{}"},{str:n}]:[t,i,{str:"{}"}]}},{kind:"environment",symbolTrigger:"vmatrix",parse:e=>{let n=de(e),[t,i]=me(e);return n?["Determinant",[t,i,{str:n}]]:["Determinant",[t,i]]}},{kind:"environment",symbolTrigger:"Vmatrix",parse:e=>{let n=de(e),[t,i]=me(e);return n?["Norm",[t,i,{str:n}]]:["Norm",[t,i]]}},{kind:"environment",symbolTrigger:"smallmatrix",parse:e=>{let n=de(e),[t,i]=me(e);return n?[t,i,{str:"()"},{str:n}]:[t,i]}},{kind:"environment",symbolTrigger:"array",parse:e=>{let n=de(e,!1),[t,i]=me(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{kind:"environment",symbolTrigger:"matrix",parse:e=>{let n=de(e),[t,i]=me(e);return n?[t,i,{str:".."},{str:n}]:[t,i,{str:".."}]}},{kind:"environment",symbolTrigger:"matrix*",parse:e=>{let n=de(e),[t,i]=me(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(l(n,1))+"^{-1}"},{name:"Trace",kind:"function",latexTrigger:"\\tr",arguments:"implicit",serialize:(e,n)=>Ge(e,n,"\\tr")},{symbolTrigger:"tr",kind:"function",parse:"Trace",arguments:"implicit"},{name:"Kernel",kind:"function",latexTrigger:"\\ker",arguments:"implicit",serialize:(e,n)=>Ge(e,n,"\\ker")},{symbolTrigger:"ker",kind:"function",parse:"Kernel",arguments:"implicit"},{name:"Dimension",kind:"function",latexTrigger:"\\dim",arguments:"implicit",serialize:(e,n)=>Ge(e,n,"\\dim")},{symbolTrigger:"dim",kind:"function",parse:"Dimension",arguments:"implicit"},{name:"Degree",kind:"function",latexTrigger:"\\deg",arguments:"implicit",serialize:(e,n)=>Ge(e,n,"\\deg")},{symbolTrigger:"deg",kind:"function",parse:"Degree",arguments:"implicit"},{name:"Hom",kind:"function",latexTrigger:"\\hom",arguments:"implicit",serialize:(e,n)=>Ge(e,n,"\\hom")},{symbolTrigger:"hom",kind:"function",parse:"Hom",arguments:"implicit"},{name:"Determinant",kind:"function",latexTrigger:"\\det",arguments:"implicit",serialize:(e,n)=>{let t=l(n,1);if(f(t)==="Matrix"){let i=g(l(t,1));return Ri(e,i,"||",w(l(t,2)))}return Ge(e,n,"\\det")}},{symbolTrigger:"det",kind:"function",parse:"Determinant",arguments:"implicit"},{name:"MatrixMultiply",serialize:(e,n)=>{let t=e.serialize(l(n,1)),i=e.serialize(l(n,2));return`${t} \\cdot ${i}`}}];function me(e){let n=e.parseTabular();return n?["Matrix",["List",...n.map(t=>["List",...t])]]:["",null]}function de(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 Ge(e,n,t){if(g(n).length!==1)return`${t}${e.wrapArguments(n)}`;let r=l(n,1),s=e.serialize(r);return typeof r=="string"||typeof r=="number"?`${t} ${s}`:`${t}\\left(${s}\\right)`}function Ri(e,n,t,i){t??="()";let[r,s]=["",""];typeof t=="string"&&t.length===2&&([r,s]=t);let o="";if(i)for(let p of i)p==="<"?o+="l":p===">"?o+="r":p==="="?o+="c":p==="|"?o+="|":p===":"&&(o+=":");let a=[];for(let p of n??[]){let h=[];for(let N of g(p))h.push(e.serialize(N));a.push(h.join(" & "))}let u=a.join(`\\\\
|
|
8
|
-
`),c=o.length>0?`[${o}]`:"";return r==="("&&s===")"?x(["\\begin{pmatrix}",c,u,"\\end{pmatrix}"]):r==="["&&s==="]"?x(["\\begin{bmatrix}",c,u,"\\end{bmatrix}"]):r==="{"&&s==="}"?x(["\\begin{Bmatrix}",c,u,"\\end{Bmatrix}"]):r==="|"&&s==="|"?x(["\\begin{vmatrix}",c,u,"\\end{vmatrix}"]):r==="\u2016"&&s==="\u2016"?x(["\\begin{Vmatrix}",c,u,"\\end{Vmatrix}"]):r==="{"&&s==="."?x(["\\begin{dcases}",c,u,"\\end{dcases}"]):r==="."&&s==="}"?x(["\\begin{rcases}",c,u,"\\end{rcases}"]):o||r!=="."||s!=="."?x(["\\left",Wn[r]??r,"\\begin{array}",`{${o}}`,u,"\\end{array}","\\right",Wn[s]??s]):x(["\\begin{matrix}",u,"\\end{matrix}"])}var ns=[{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||!b(t)?null:["Mean",t]}}];var Qn={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},ts=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"]),et={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 vo(e){if(e.length>2){let n=e.slice(0,2),t=e.slice(2);if(Qn[n]!==void 0&&ts.has(t)){let i=et[t];if(i)return{prefixScale:Qn[n],baseEntry:i}}}if(e.length>1){let n=e.slice(0,1),t=e.slice(1);if(Qn[n]!==void 0&&ts.has(t)){let i=et[t];if(i)return{prefixScale:Qn[n],baseEntry:i}}}return null}function Io(e){let n=et[e];if(n)return n;let t=vo(e);return t?{dimension:t.baseEntry.dimension,scale:t.prefixScale*t.baseEntry.scale}:null}function Bi(e){let n=Io(e);return n?n.dimension:null}var Xc=new Map(["N","J","W","Pa","Hz","C","V","F","ohm","S","Wb","T","H","lm","lx","Gy","kat"].map(e=>[et[e].dimension.join(","),e]));function ko(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 ln(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 ln(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=ln(r),a=ln(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=>ln(a));return o.some(a=>a===null)?null:o.length===1?o[0]:["Multiply",...o]}return e[0]==="("?null:ko(e)}function is(e){return e=e.trim(),e.length===0?null:/[/*^()]/.test(e)?ln(e):e}function as(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 So=new Set(["d"]);function us(e){if(!e||e.length===0||So.has(e))return null;if(Bi(e)!==null)return e;if(/[/*^]/.test(e))try{let n=is(e);if(n!==null&&Ci(n))return n}catch{return null}return null}function Ci(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=>Ci(t)):n==="Power"?Ci(e[1]):!1}var rs=e=>{let n=e.index,t=as(e);if(t===null)return e.index=n,null;let i=us(t);return i===null?(e.index=n,null):["__unit__",i]};function ke(e){let n=b(e);if(n!==null)return n;if(typeof e=="number")return String(e);let t=f(e);if(!t)return"";if(t==="Divide"){let i=l(e,1),r=l(e,2);return`${ke(i)}/${ke(r)}`}if(t==="Multiply"){let i=[];if(Array.isArray(e))for(let r=1;r<e.length;r++)i.push(ke(e[r]));return i.join("\\cdot ")}if(t==="Power"){let i=l(e,1),r=l(e,2),s=typeof r=="number"?String(r):b(r)??String(r);return`${ke(i)}^{${s}}`}if(t==="Square"){let i=l(e,1);return`${ke(i)}^{2}`}return""}function ss(e){let n=e.parseGroup();if(n===null)return null;let t=ls(e);return t===null?null:["Quantity",n,t]}function os(e){return ls(e)}function ls(e){let n=e.index,t=as(e);if(t===null)return e.index=n,null;let i=us(t);return i===null?(e.index=n,null):i}var cs=[{latexTrigger:"\\mathrm",kind:"expression",parse:rs},{latexTrigger:"\\text",kind:"expression",parse:rs},{latexTrigger:"\\qty",parse:ss},{latexTrigger:"\\SI",parse:ss},{latexTrigger:"\\unit",parse:os},{latexTrigger:"\\si",parse:os},{name:"Quantity",serialize:(e,n)=>{let t=l(n,1),i=l(n,2);if(t===null||i===null)return"";let r=b(i),s=r==="deg"||r==="rad"||r==="arcmin"||r==="arcsec",o=e.options;if(s&&(o.dmsFormat||o.angleNormalization&&o.angleNormalization!=="none")){let c=I(t);if(c===null){let h=e.serialize(t),N=ke(i);return x([h,"\\,",`\\mathrm{${N}}`])}let p=c;return r==="rad"?p=p*180/Math.PI:r==="arcmin"?p=p/60:r==="arcsec"&&(p=p/3600),o.angleNormalization&&o.angleNormalization!=="none"&&(p=Yn(p,o.angleNormalization)),o.dmsFormat?Xn(p):`${p}\xB0`}let a=e.serialize(t),u=ke(i);return x([a,"\\,",`\\mathrm{${u}}`])}}];function U(e){return n=>{let t=n.parseGroup();return t===null?[e]:[e,t]}}var fs=[{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)=>b(n)===null?null:["Increment",n]},{name:"Decrement",latexTrigger:["-","-"],kind:"postfix",precedence:880,parse:(e,n)=>b(n)===null?null:["Decrement",n]},{name:"PreIncrement",latexTrigger:["+","+"],kind:"prefix",precedence:880,parse:(e,n)=>{let t=e.parseExpression(n);return b(t)===null?null:["PreIncrement",t]}},{name:"PreDecrement",latexTrigger:["-","-"],kind:"prefix",precedence:880,parse:(e,n)=>{let t=e.parseExpression(n);return b(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=Ie(i);if(r&&(i=["List",...r]),i===null||t===null)return null;let s=e.parseGroup()??"Nothing";if(!_(s)){let o=e.parseArguments()??["Nothing"];s=[s,...o]}return["PartialDerivative",s,i,t]},serialize:(e,n)=>{let t="\\partial",i=l(n,1),r=l(n,2),s=l(n,3);return r!==null&&r!=="Nothing"&&(f(r)==="List"?t+="_{"+e.serialize(["Sequence",...g(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:U("OverBar")},{name:"UnderBar",latexTrigger:["\\underline"],parse:U("UnderBar")},{name:"OverVector",latexTrigger:["\\vec"],parse:U("OverVector")},{name:"OverTilde",latexTrigger:["\\tilde"],parse:U("OverTilde")},{name:"OverHat",latexTrigger:["\\hat"],parse:U("OverHat")},{name:"OverRightArrow",latexTrigger:["\\overrightarrow"],parse:U("OverRightArrow")},{name:"OverLeftArrow",latexTrigger:["\\overleftarrow"],parse:U("OverLeftArrow")},{name:"OverRightDoubleArrow",latexTrigger:["\\Overrightarrow"],parse:U("OverRightDoubleArrow")},{name:"OverLeftHarpoon",latexTrigger:["\\overleftharpoon"],parse:U("OverLeftHarpoon")},{name:"OverRightHarpoon",latexTrigger:["\\overrightharpoon"],parse:U("OverRightHarpoon")},{name:"OverLeftRightArrow",latexTrigger:["\\overleftrightarrow"],parse:U("OverLeftRightArrow")},{name:"OverBrace",latexTrigger:["\\overbrace"],parse:U("OverBrace")},{name:"OverLineSegment",latexTrigger:["\\overlinesegment"],parse:U("OverLineSegment")},{name:"OverGroup",latexTrigger:["\\overgroup"],parse:U("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(l(n,1)),i=Sr(l(n,2));if(i==null)return t;i.dict.mathStyle==="normal"?t=x(["{\\displaystyle",t,"}"]):i.dict.mathStyle==="compact"&&(t=x(["{\\textstyle",t,"}"]));let r=i.dict.size;return r!==null&&r>=1&&r<=10&&(t=x(["{",{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=x(["\\texttt{",t,"}"]):i.dict.fontFamily==="sans-serif"&&(t=x(["\\textsf{",t,"}"])),i.dict.fontWeight==="bold"&&(t=x(["\\textbf{",t,"}"])),i.dict.fontStyle==="italic"?t=x(["\\textit{",t,"}"]):i.dict.fontStyle==="normal"&&(t=x(["\\textup{",t,"}"])),i.dict.color&&(t=x(["\\textcolor{",i.dict.color,"}{",t,"}"])),i.dict.backgroundColor&&(t=x(["\\colorbox{",i.dict.backgroundColor,"}{",t,"}"])),i.dict.border===!0&&(t=x(["\\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(l(n,2)!==null)return e.serialize(l(n,1));let t=I(l(n,1));return t===null?"":{"-3":"\\!",6:"\\ ",3:"\\,",4:"\\:",5:"\\;",9:"\\enspace",18:"\\quad",36:"\\qquad"}[t]??""}}];var Mo=[{name:"Mu0",kind:"symbol",latexTrigger:"\\mu_0"},{name:"VacuumPermittivity",kind:"symbol",latexTrigger:"\\varepsilon_0"}];var wo=[...Rr,...Or,...Fr,...wr,...Lr,..._e,...Ur,...Wr,...Hr,...Kr,...es,...ns,...cs,...fs,...Mo];var Do="\\u{FE0F}",Ao="\\u{20E3}",Po="\\u{200D}",_o="\\p{RI}\\p{RI}",Ro="(?:[\\u{E0020}-\\u{E007E}]+\\u{E007F})",ps=`(?:\\p{EMod}|${Do}${Ao}?|${Ro})`,Bo="(?:(?=\\P{XIDC})(?=[^\\x23\\x2a\\x30-\\x39])\\p{Emoji})",ms=`(?:${Bo}${ps}*|\\p{Emoji}${ps}+|${_o})`,ds=`(?:${ms})(${Po}${ms})*`,vf=new RegExp(`(?:${ds})+`,"u"),hs=new RegExp(`^(?:${ds})+$`,"u");var cn=[[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>=cn.length;){let t=cn.length,i=[1],r=cn[t-1];for(let s=1;s<t;s++)i[s]=r[s-1]+r[s];i[t]=1,cn.push(i)}return cn[e][n]}function rt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return ta(t)}function ta(e){return e.hi<0?{kind:"empty"}:e.lo>=0?d({lo:Math.sqrt(e.lo),hi:Math.sqrt(e.hi)}):{kind:"partial",value:{lo:0,hi:Math.sqrt(e.hi)},domainClipped:"lo"}}function st(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?d({lo:t.lo*t.lo,hi:t.hi*t.hi}):t.hi<=0?d({lo:t.hi*t.hi,hi:t.lo*t.lo}):d({lo:0,hi:Math.max(t.lo*t.lo,t.hi*t.hi)})}function Ns(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 pn(e,n){let t=y(e);if(!Array.isArray(t))return t;let[i]=t;if(Number.isInteger(n)){if(n>=0)return d(Ns(i,n));{if(z(i))return{kind:"singular"};let r=Ns(i,-n);return d({lo:1/r.hi,hi:1/r.lo})}}else return Se(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?d({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"}:d({lo:Math.pow(i.hi,n),hi:Math.pow(i.lo,n)})}function ot(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(r.lo===r.hi&&Number.isInteger(r.lo))return pn(i,r.lo);if(i.hi<=0)return i.lo===-1&&i.hi===-1&&Math.floor(r.hi)>Math.floor(r.lo)?d({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 d({lo:Math.min(...s),hi:Math.max(...s)})}function at(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.exp(t.lo),hi:Math.exp(t.hi)})}function ut(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?d({lo:Math.log(t.lo),hi:Math.log(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log(t.hi)},domainClipped:"lo"}}function lt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?d({lo:Math.log10(t.lo),hi:Math.log10(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log10(t.hi)},domainClipped:"lo"}}function ct(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?d({lo:Math.log2(t.lo),hi:Math.log2(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log2(t.hi)},domainClipped:"lo"}}function ft(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?d(t):t.hi<=0?d({lo:-t.hi,hi:-t.lo}):d({lo:0,hi:Math.max(-t.lo,t.hi)})}function pt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.floor(t.lo),r=Math.floor(t.hi);return i===r?d({lo:i,hi:r}):{kind:"singular",at:i+1,continuity:"right"}}function mt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.ceil(t.lo),r=Math.ceil(t.hi);return i===r?d({lo:i,hi:r}):{kind:"singular",at:i,continuity:"left"}}function mn(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.round(t.lo),r=Math.round(t.hi);return i===r?d({lo:i,hi:r}):{kind:"singular",at:i+.5,continuity:"right"}}function dt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.floor(t.lo),r=Math.floor(t.hi);return i===r?d({lo:t.lo-i,hi:t.hi-i}):{kind:"singular",at:i+1,continuity:"right"}}function ht(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.trunc(t.lo),r=Math.trunc(t.hi);if(i===r)return d({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 gt(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return d({lo:Math.min(i.lo,r.lo),hi:Math.min(i.hi,r.hi)})}function yt(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return d({lo:Math.max(i.lo,r.lo),hi:Math.max(i.hi,r.hi)})}function xt(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(z(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,c=i.hi-s*o;return d({lo:Math.min(u,c),hi:Math.max(u,c)})}function bt(e,n){return Me(e,we(n,mn(G(e,n))))}function Nt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>0?d({lo:1,hi:1}):t.hi<0?d({lo:0,hi:0}):t.lo===0&&t.hi===0?d({lo:.5,hi:.5}):{kind:"singular",at:0}}function Et(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>0?d({lo:1,hi:1}):t.hi<0?d({lo:-1,hi:-1}):t.lo===0&&t.hi===0?d({lo:0,hi:0}):{kind:"singular",at:0}}var Es=1.4616321449683622,ia=.8856031944108887;function Tt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return ra(t)}function ra(e){if(e.hi>=0&&e.lo<=0)return{kind:"singular",at:0};if(e.lo<0){let n=Math.ceil(e.lo),t=Math.floor(e.hi);if(n<=t)return{kind:"singular",at:n};let i=te(e.lo),r=te(e.hi);return d({lo:Math.min(i,r),hi:Math.max(i,r)})}return e.lo>=Es?d({lo:te(e.lo),hi:te(e.hi)}):e.hi<=Es?d({lo:te(e.hi),hi:te(e.lo)}):d({lo:ia,hi:Math.max(te(e.lo),te(e.hi))})}function vt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return sa(t)}function sa(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=De(e.lo),r=De(e.hi);return d({lo:Math.min(i,r),hi:Math.max(i,r)})}return d({lo:De(e.lo),hi:De(e.hi)})}function It(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=fi(Math.round(t.lo)),r=fi(Math.round(t.hi));return!Number.isFinite(i)||!Number.isFinite(r)?d({lo:Math.min(i,r),hi:Math.max(i,r)}):d({lo:i,hi:r})}function kt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=pi(Math.round(t.lo)),r=pi(Math.round(t.hi));return!Number.isFinite(i)||!Number.isFinite(r)?d({lo:Math.min(i,r),hi:Math.max(i,r)}):d({lo:i,hi:r})}function Vi(e,n){let t=y(e);if(!Array.isArray(t))return t;let i=y(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 d({lo:Math.min(...o),hi:Math.max(...o)})}function Li(e,n){let t=y(e);if(!Array.isArray(t))return t;let i=y(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[he(Math.round(r.lo),Math.round(s.lo)),he(Math.round(r.lo),Math.round(s.hi)),he(Math.round(r.hi),Math.round(s.lo)),he(Math.round(r.hi),Math.round(s.hi))];return d({lo:Math.min(...o),hi:Math.max(...o)})}function Ji(e,n){let t=y(e);if(!Array.isArray(t))return t;let i=y(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[Ae(Math.round(r.lo),Math.round(s.lo)),Ae(Math.round(r.lo),Math.round(s.hi)),Ae(Math.round(r.hi),Math.round(s.lo)),Ae(Math.round(r.hi),Math.round(s.hi))];return d({lo:Math.min(...o),hi:Math.max(...o)})}function $i(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:mi(t.lo),hi:mi(t.hi)})}function qi(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Fn(t.lo),hi:Fn(t.hi)})}function zi(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:ci(t.hi),hi:ci(t.lo)})}function Gi(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.pow(2,t.lo),hi:Math.pow(2,t.hi)})}function Zi(e,n){let t=y(e);if(!Array.isArray(t))return t;let i=y(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),d({lo:a,hi:Math.max(...o)})}var oe=2*Math.PI,L=Math.PI,xe=Math.PI/2,Ts=3*Math.PI/2;function St(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=oe)return d({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 J(t,xe,oe)&&(o=1),J(t,Ts,oe)&&(s=-1),d({lo:s,hi:o})}function Mt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=oe)return d({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 J(t,0,oe)&&(o=1),J(t,L,oe)&&(s=-1),d({lo:s,hi:o})}function wt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=L)return{kind:"singular"};if(J(t,xe,L)){let s=Math.ceil((t.lo-xe)/L);return{kind:"singular",at:xe+s*L}}let i=Math.tan(t.lo),r=Math.tan(t.hi);return i>1e10&&r<-1e10||i<-1e10&&r>1e10?{kind:"singular"}:d({lo:i,hi:r})}function Dt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=L)return{kind:"singular"};if(J(t,0,L))return{kind:"singular",at:Math.ceil(t.lo/L)*L};let i=1/Math.tan(t.lo),r=1/Math.tan(t.hi);return d({lo:Math.min(i,r),hi:Math.max(i,r)})}function At(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=L)return{kind:"singular"};if(J(t,xe,L)){let a=Math.ceil((t.lo-xe)/L);return{kind:"singular",at:xe+a*L}}let i=1/Math.cos(t.lo),r=1/Math.cos(t.hi),s=Math.min(i,r),o=Math.max(i,r);return J(t,0,oe)&&(s=Math.min(s,1),o=Math.max(o,1)),J(t,L,oe)&&(s=Math.min(s,-1),o=Math.max(o,-1)),d({lo:s,hi:o})}function Pt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=L)return{kind:"singular"};if(J(t,0,L))return{kind:"singular",at:Math.ceil(t.lo/L)*L};let i=1/Math.sin(t.lo),r=1/Math.sin(t.hi),s=Math.min(i,r),o=Math.max(i,r);return J(t,xe,oe)&&(s=Math.min(s,1),o=Math.max(o,1)),J(t,Ts,oe)&&(s=Math.min(s,-1),o=Math.max(o,-1)),d({lo:s,hi:o})}function dn(e){let n=y(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 d({lo:Math.asin(t.lo),hi:Math.asin(t.hi)})}function hn(e){let n=y(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 d({lo:Math.acos(t.hi),hi:Math.acos(t.lo)})}function gn(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.atan(t.lo),hi:Math.atan(t.hi)})}function _t(e,n){let t=y(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 d({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?d({lo:-L,hi:L}):d({lo:Math.min(...s),hi:Math.max(...s)})}function Ze(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.sinh(t.lo),hi:Math.sinh(t.hi)})}function je(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?d({lo:Math.cosh(t.lo),hi:Math.cosh(t.hi)}):t.hi<=0?d({lo:Math.cosh(t.hi),hi:Math.cosh(t.lo)}):d({lo:1,hi:Math.max(Math.cosh(t.lo),Math.cosh(t.hi))})}function Rt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.tanh(t.lo),hi:Math.tanh(t.hi)})}function yn(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.asinh(t.lo),hi:Math.asinh(t.hi)})}function xn(e){let n=y(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"}:d({lo:Math.acosh(t.lo),hi:Math.acosh(t.hi)})}function bn(e){let n=y(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 d({lo:Math.atanh(t.lo),hi:Math.atanh(t.hi)})}function Bt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:gn(G(d({lo:1,hi:1}),d(t)))}function Ct(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:dn(G(d({lo:1,hi:1}),d(t)))}function Ot(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:hn(G(d({lo:1,hi:1}),d(t)))}function Ft(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:G(je(t),Ze(t))}function Vt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:G(d({lo:1,hi:1}),Ze(t))}function Lt(e){return G(d({lo:1,hi:1}),je(e))}function Jt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:bn(G(d({lo:1,hi:1}),d(t)))}function $t(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:yn(G(d({lo:1,hi:1}),d(t)))}function qt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:xn(G(d({lo:1,hi:1}),d(t)))}var ji=[4.49341,7.72525,10.90412,14.06619,17.22076,20.3713,23.51945,26.66605,29.8116,32.95639],oa=-.21724;function zt(e){let n=y(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=ji[ji.length-1];for(let u of ji)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(oa),d({lo:r,hi:s})}var vs=[],Is=[];for(let e=1;e<=20;e++)vs.push(Math.sqrt(2*e)),Is.push(Math.sqrt(2*e-1));function Gt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Xe(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(Xe(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of vs)o>=t.lo&&o<=t.hi&&s(Xe(o)),-o>=t.lo&&-o<=t.hi&&s(Xe(-o));return d({lo:i,hi:r})}function Zt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Ke(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(Ke(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of Is)o>=t.lo&&o<=t.hi&&s(Ke(o)),-o>=t.lo&&-o<=t.hi&&s(Ke(-o));return d({lo:i,hi:r})}function be(e){return"kind"in e?e:{kind:"interval",value:e}}function jt(e,n){let t=y(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 Ut(e,n){let t=y(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 Wt(e,n){let t=y(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 Ht(e,n){let t=y(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 Nn(e,n){let t=y(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 Yt(e,n){let t=Nn(e,n);return t==="true"?"false":t==="false"?"true":"maybe"}function Xt(e,n){return e==="false"||n==="false"?"false":e==="true"&&n==="true"?"true":"maybe"}function Kt(e,n){return e==="true"||n==="true"?"true":e==="false"&&n==="false"?"false":"maybe"}function Qt(e){return e==="true"?"false":e==="false"?"true":"maybe"}function ei(e,n,t,i){if(e==="true"||e==="false"||e==="maybe"){let h=e,N=n,v=t;switch(h){case"true":return be(N());case"false":return be(v());case"maybe":return Ne(be(N()),be(v()))}}let r=e,s=n,o=t,a=i,u=y(r);if(!Array.isArray(u))return u;let[c]=u;switch(s(c)){case"true":return be(o(c));case"false":return be(a(c));case"maybe":let h=be(o(c)),N=be(a(c));return Ne(h,N)}}function ni(e,n,t){let i=y(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 aa={ok:d,point:En,containsExtremum:J,unionResults:Ne,mergeDomainClip:We,isPoint:Tn,containsZero:z,isPositive:vn,isNegative:Se,isNonNegative:In,isNonPositive:kn,width:Sn,midpoint:Mn,getValue:wn,unwrap:Dn,unwrapOrPropagate:y,add:An,sub:Me,mul:we,div:G,negate:Pn,sqrt:rt,square:st,pow:pn,powInterval:ot,exp:at,ln:ut,log10:lt,log2:ct,abs:ft,floor:pt,ceil:mt,round:mn,fract:dt,trunc:ht,min:gt,max:yt,mod:xt,remainder:bt,heaviside:Nt,sign:Et,gamma:Tt,gammaln:vt,factorial:It,factorial2:kt,binomial:Vi,gcd:Li,lcm:Ji,chop:$i,erf:qi,erfc:zi,exp2:Gi,hypot:Zi,sin:St,cos:Mt,tan:wt,cot:Dt,sec:At,csc:Pt,asin:dn,acos:hn,atan:gn,atan2:_t,sinh:Ze,cosh:je,tanh:Rt,asinh:yn,acosh:xn,atanh:bn,acot:Bt,acsc:Ct,asec:Ot,coth:Ft,csch:Vt,sech:Lt,acoth:Jt,acsch:$t,asech:qt,sinc:zt,fresnelS:Gt,fresnelC:Zt,less:jt,lessEqual:Ut,greater:Wt,greaterEqual:Ht,equal:Nn,notEqual:Yt,and:Xt,or:Kt,not:Qt,piecewise:ei,clamp:ni};var mg="0.55.2";export{aa as IntervalArithmetic,_n as _mul,ft as abs,hn as acos,xn as acosh,Bt as acot,Jt as acoth,Ct as acsc,$t as acsch,An as add,Xt as and,Ot as asec,qt as asech,dn as asin,yn as asinh,gn as atan,_t as atan2,bn as atanh,Vi as binomial,mt as ceil,$i as chop,ni as clamp,J as containsExtremum,z as containsZero,Mt as cos,je as cosh,Dt as cot,Ft as coth,Pt as csc,Vt as csch,G as div,Nn as equal,qi as erf,zi as erfc,at as exp,Gi as exp2,It as factorial,kt as factorial2,pt as floor,dt as fract,Zt as fresnelC,Gt as fresnelS,Tt as gamma,vt as gammaln,Li as gcd,wn as getValue,Wt as greater,Ht as greaterEqual,Nt as heaviside,Zi as hypot,Se as isNegative,In as isNonNegative,kn as isNonPositive,Tn as isPoint,vn as isPositive,Ji as lcm,jt as less,Ut as lessEqual,ut as ln,lt as log10,ct as log2,yt as max,We as mergeDomainClip,Mn as midpoint,gt as min,xt as mod,we as mul,Pn as negate,Qt as not,Yt as notEqual,d as ok,Kt as or,ei as piecewise,En as point,pn as pow,ot as powInterval,bt as remainder,mn as round,At as sec,Lt as sech,Et as sign,St as sin,zt as sinc,Ze as sinh,rt as sqrt,st as square,Me as sub,wt as tan,Rt as tanh,ht as trunc,Ne as unionResults,Dn as unwrap,y as unwrapOrPropagate,mg as version,Sn as width};
|
|
8
|
+
`),c=o.length>0?`[${o}]`:"";return r==="("&&s===")"?x(["\\begin{pmatrix}",c,u,"\\end{pmatrix}"]):r==="["&&s==="]"?x(["\\begin{bmatrix}",c,u,"\\end{bmatrix}"]):r==="{"&&s==="}"?x(["\\begin{Bmatrix}",c,u,"\\end{Bmatrix}"]):r==="|"&&s==="|"?x(["\\begin{vmatrix}",c,u,"\\end{vmatrix}"]):r==="\u2016"&&s==="\u2016"?x(["\\begin{Vmatrix}",c,u,"\\end{Vmatrix}"]):r==="{"&&s==="."?x(["\\begin{dcases}",c,u,"\\end{dcases}"]):r==="."&&s==="}"?x(["\\begin{rcases}",c,u,"\\end{rcases}"]):o||r!=="."||s!=="."?x(["\\left",Wn[r]??r,"\\begin{array}",`{${o}}`,u,"\\end{array}","\\right",Wn[s]??s]):x(["\\begin{matrix}",u,"\\end{matrix}"])}var ns=[{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||!b(t)?null:["Mean",t]}}];var Qn={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},ts=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"]),et={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 vo(e){if(e.length>2){let n=e.slice(0,2),t=e.slice(2);if(Qn[n]!==void 0&&ts.has(t)){let i=et[t];if(i)return{prefixScale:Qn[n],baseEntry:i}}}if(e.length>1){let n=e.slice(0,1),t=e.slice(1);if(Qn[n]!==void 0&&ts.has(t)){let i=et[t];if(i)return{prefixScale:Qn[n],baseEntry:i}}}return null}function Io(e){let n=et[e];if(n)return n;let t=vo(e);return t?{dimension:t.baseEntry.dimension,scale:t.prefixScale*t.baseEntry.scale}:null}function Bi(e){let n=Io(e);return n?n.dimension:null}var Xc=new Map(["N","J","W","Pa","Hz","C","V","F","ohm","S","Wb","T","H","lm","lx","Gy","kat"].map(e=>[et[e].dimension.join(","),e]));function ko(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 ln(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 ln(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=ln(r),a=ln(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=>ln(a));return o.some(a=>a===null)?null:o.length===1?o[0]:["Multiply",...o]}return e[0]==="("?null:ko(e)}function is(e){return e=e.trim(),e.length===0?null:/[/*^()]/.test(e)?ln(e):e}function as(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 So=new Set(["d"]);function us(e){if(!e||e.length===0||So.has(e))return null;if(Bi(e)!==null)return e;if(/[/*^]/.test(e))try{let n=is(e);if(n!==null&&Ci(n))return n}catch{return null}return null}function Ci(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=>Ci(t)):n==="Power"?Ci(e[1]):!1}var rs=e=>{let n=e.index,t=as(e);if(t===null)return e.index=n,null;let i=us(t);return i===null?(e.index=n,null):["__unit__",i]};function ke(e){let n=b(e);if(n!==null)return n;if(typeof e=="number")return String(e);let t=f(e);if(!t)return"";if(t==="Divide"){let i=l(e,1),r=l(e,2);return`${ke(i)}/${ke(r)}`}if(t==="Multiply"){let i=[];if(Array.isArray(e))for(let r=1;r<e.length;r++)i.push(ke(e[r]));return i.join("\\cdot ")}if(t==="Power"){let i=l(e,1),r=l(e,2),s=typeof r=="number"?String(r):b(r)??String(r);return`${ke(i)}^{${s}}`}if(t==="Square"){let i=l(e,1);return`${ke(i)}^{2}`}return""}function ss(e){let n=e.parseGroup();if(n===null)return null;let t=ls(e);return t===null?null:["Quantity",n,t]}function os(e){return ls(e)}function ls(e){let n=e.index,t=as(e);if(t===null)return e.index=n,null;let i=us(t);return i===null?(e.index=n,null):i}var cs=[{latexTrigger:"\\mathrm",kind:"expression",parse:rs},{latexTrigger:"\\text",kind:"expression",parse:rs},{latexTrigger:"\\qty",parse:ss},{latexTrigger:"\\SI",parse:ss},{latexTrigger:"\\unit",parse:os},{latexTrigger:"\\si",parse:os},{name:"Quantity",serialize:(e,n)=>{let t=l(n,1),i=l(n,2);if(t===null||i===null)return"";let r=b(i),s=r==="deg"||r==="rad"||r==="arcmin"||r==="arcsec",o=e.options;if(s&&(o.dmsFormat||o.angleNormalization&&o.angleNormalization!=="none")){let c=I(t);if(c===null){let h=e.serialize(t),N=ke(i);return x([h,"\\,",`\\mathrm{${N}}`])}let p=c;return r==="rad"?p=p*180/Math.PI:r==="arcmin"?p=p/60:r==="arcsec"&&(p=p/3600),o.angleNormalization&&o.angleNormalization!=="none"&&(p=Yn(p,o.angleNormalization)),o.dmsFormat?Xn(p):`${p}\xB0`}let a=e.serialize(t),u=ke(i);return x([a,"\\,",`\\mathrm{${u}}`])}}];function U(e){return n=>{let t=n.parseGroup();return t===null?[e]:[e,t]}}var fs=[{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)=>b(n)===null?null:["Increment",n]},{name:"Decrement",latexTrigger:["-","-"],kind:"postfix",precedence:880,parse:(e,n)=>b(n)===null?null:["Decrement",n]},{name:"PreIncrement",latexTrigger:["+","+"],kind:"prefix",precedence:880,parse:(e,n)=>{let t=e.parseExpression(n);return b(t)===null?null:["PreIncrement",t]}},{name:"PreDecrement",latexTrigger:["-","-"],kind:"prefix",precedence:880,parse:(e,n)=>{let t=e.parseExpression(n);return b(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=Ie(i);if(r&&(i=["List",...r]),i===null||t===null)return null;let s=e.parseGroup()??"Nothing";if(!_(s)){let o=e.parseArguments()??["Nothing"];s=[s,...o]}return["PartialDerivative",s,i,t]},serialize:(e,n)=>{let t="\\partial",i=l(n,1),r=l(n,2),s=l(n,3);return r!==null&&r!=="Nothing"&&(f(r)==="List"?t+="_{"+e.serialize(["Sequence",...g(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:U("OverBar")},{name:"UnderBar",latexTrigger:["\\underline"],parse:U("UnderBar")},{name:"OverVector",latexTrigger:["\\vec"],parse:U("OverVector")},{name:"OverTilde",latexTrigger:["\\tilde"],parse:U("OverTilde")},{name:"OverHat",latexTrigger:["\\hat"],parse:U("OverHat")},{name:"OverRightArrow",latexTrigger:["\\overrightarrow"],parse:U("OverRightArrow")},{name:"OverLeftArrow",latexTrigger:["\\overleftarrow"],parse:U("OverLeftArrow")},{name:"OverRightDoubleArrow",latexTrigger:["\\Overrightarrow"],parse:U("OverRightDoubleArrow")},{name:"OverLeftHarpoon",latexTrigger:["\\overleftharpoon"],parse:U("OverLeftHarpoon")},{name:"OverRightHarpoon",latexTrigger:["\\overrightharpoon"],parse:U("OverRightHarpoon")},{name:"OverLeftRightArrow",latexTrigger:["\\overleftrightarrow"],parse:U("OverLeftRightArrow")},{name:"OverBrace",latexTrigger:["\\overbrace"],parse:U("OverBrace")},{name:"OverLineSegment",latexTrigger:["\\overlinesegment"],parse:U("OverLineSegment")},{name:"OverGroup",latexTrigger:["\\overgroup"],parse:U("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(l(n,1)),i=Sr(l(n,2));if(i==null)return t;i.dict.mathStyle==="normal"?t=x(["{\\displaystyle",t,"}"]):i.dict.mathStyle==="compact"&&(t=x(["{\\textstyle",t,"}"]));let r=i.dict.size;return r!==null&&r>=1&&r<=10&&(t=x(["{",{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=x(["\\texttt{",t,"}"]):i.dict.fontFamily==="sans-serif"&&(t=x(["\\textsf{",t,"}"])),i.dict.fontWeight==="bold"&&(t=x(["\\textbf{",t,"}"])),i.dict.fontStyle==="italic"?t=x(["\\textit{",t,"}"]):i.dict.fontStyle==="normal"&&(t=x(["\\textup{",t,"}"])),i.dict.color&&(t=x(["\\textcolor{",i.dict.color,"}{",t,"}"])),i.dict.backgroundColor&&(t=x(["\\colorbox{",i.dict.backgroundColor,"}{",t,"}"])),i.dict.border===!0&&(t=x(["\\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(l(n,2)!==null)return e.serialize(l(n,1));let t=I(l(n,1));return t===null?"":{"-3":"\\!",6:"\\ ",3:"\\,",4:"\\:",5:"\\;",9:"\\enspace",18:"\\quad",36:"\\qquad"}[t]??""}}];var Mo=[{name:"Mu0",kind:"symbol",latexTrigger:"\\mu_0"},{name:"VacuumPermittivity",kind:"symbol",latexTrigger:"\\varepsilon_0"}];var wo=[...Rr,...Or,...Fr,...wr,...Lr,..._e,...Ur,...Wr,...Hr,...Kr,...es,...ns,...cs,...fs,...Mo];var Do="\\u{FE0F}",Ao="\\u{20E3}",Po="\\u{200D}",_o="\\p{RI}\\p{RI}",Ro="(?:[\\u{E0020}-\\u{E007E}]+\\u{E007F})",ps=`(?:\\p{EMod}|${Do}${Ao}?|${Ro})`,Bo="(?:(?=\\P{XIDC})(?=[^\\x23\\x2a\\x30-\\x39])\\p{Emoji})",ms=`(?:${Bo}${ps}*|\\p{Emoji}${ps}+|${_o})`,ds=`(?:${ms})(${Po}${ms})*`,vf=new RegExp(`(?:${ds})+`,"u"),hs=new RegExp(`^(?:${ds})+$`,"u");var cn=[[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>=cn.length;){let t=cn.length,i=[1],r=cn[t-1];for(let s=1;s<t;s++)i[s]=r[s-1]+r[s];i[t]=1,cn.push(i)}return cn[e][n]}function rt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return ta(t)}function ta(e){return e.hi<0?{kind:"empty"}:e.lo>=0?d({lo:Math.sqrt(e.lo),hi:Math.sqrt(e.hi)}):{kind:"partial",value:{lo:0,hi:Math.sqrt(e.hi)},domainClipped:"lo"}}function st(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?d({lo:t.lo*t.lo,hi:t.hi*t.hi}):t.hi<=0?d({lo:t.hi*t.hi,hi:t.lo*t.lo}):d({lo:0,hi:Math.max(t.lo*t.lo,t.hi*t.hi)})}function Ns(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 pn(e,n){let t=y(e);if(!Array.isArray(t))return t;let[i]=t;if(Number.isInteger(n)){if(n>=0)return d(Ns(i,n));{if(z(i))return{kind:"singular"};let r=Ns(i,-n);return d({lo:1/r.hi,hi:1/r.lo})}}else return Se(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?d({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"}:d({lo:Math.pow(i.hi,n),hi:Math.pow(i.lo,n)})}function ot(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(r.lo===r.hi&&Number.isInteger(r.lo))return pn(i,r.lo);if(i.hi<=0)return i.lo===-1&&i.hi===-1&&Math.floor(r.hi)>Math.floor(r.lo)?d({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 d({lo:Math.min(...s),hi:Math.max(...s)})}function at(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.exp(t.lo),hi:Math.exp(t.hi)})}function ut(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?d({lo:Math.log(t.lo),hi:Math.log(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log(t.hi)},domainClipped:"lo"}}function lt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?d({lo:Math.log10(t.lo),hi:Math.log10(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log10(t.hi)},domainClipped:"lo"}}function ct(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.hi<=0?{kind:"empty"}:t.lo>0?d({lo:Math.log2(t.lo),hi:Math.log2(t.hi)}):{kind:"partial",value:{lo:-1/0,hi:Math.log2(t.hi)},domainClipped:"lo"}}function ft(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?d(t):t.hi<=0?d({lo:-t.hi,hi:-t.lo}):d({lo:0,hi:Math.max(-t.lo,t.hi)})}function pt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.floor(t.lo),r=Math.floor(t.hi);return i===r?d({lo:i,hi:r}):{kind:"singular",at:i+1,continuity:"right"}}function mt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.ceil(t.lo),r=Math.ceil(t.hi);return i===r?d({lo:i,hi:r}):{kind:"singular",at:i,continuity:"left"}}function mn(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.round(t.lo),r=Math.round(t.hi);return i===r?d({lo:i,hi:r}):{kind:"singular",at:i+.5,continuity:"right"}}function dt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.floor(t.lo),r=Math.floor(t.hi);return i===r?d({lo:t.lo-i,hi:t.hi-i}):{kind:"singular",at:i+1,continuity:"right"}}function ht(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Math.trunc(t.lo),r=Math.trunc(t.hi);if(i===r)return d({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 gt(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return d({lo:Math.min(i.lo,r.lo),hi:Math.min(i.hi,r.hi)})}function yt(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;return d({lo:Math.max(i.lo,r.lo),hi:Math.max(i.hi,r.hi)})}function xt(e,n){let t=y(e,n);if(!Array.isArray(t))return t;let[i,r]=t;if(z(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,c=i.hi-s*o;return d({lo:Math.min(u,c),hi:Math.max(u,c)})}function bt(e,n){return Me(e,we(n,mn(G(e,n))))}function Nt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>0?d({lo:1,hi:1}):t.hi<0?d({lo:0,hi:0}):t.lo===0&&t.hi===0?d({lo:.5,hi:.5}):{kind:"singular",at:0}}function Et(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>0?d({lo:1,hi:1}):t.hi<0?d({lo:-1,hi:-1}):t.lo===0&&t.hi===0?d({lo:0,hi:0}):{kind:"singular",at:0}}var Es=1.4616321449683622,ia=.8856031944108887;function Tt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return ra(t)}function ra(e){if(e.hi>=0&&e.lo<=0)return{kind:"singular",at:0};if(e.lo<0){let n=Math.ceil(e.lo),t=Math.floor(e.hi);if(n<=t)return{kind:"singular",at:n};let i=te(e.lo),r=te(e.hi);return d({lo:Math.min(i,r),hi:Math.max(i,r)})}return e.lo>=Es?d({lo:te(e.lo),hi:te(e.hi)}):e.hi<=Es?d({lo:te(e.hi),hi:te(e.lo)}):d({lo:ia,hi:Math.max(te(e.lo),te(e.hi))})}function vt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return sa(t)}function sa(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=De(e.lo),r=De(e.hi);return d({lo:Math.min(i,r),hi:Math.max(i,r)})}return d({lo:De(e.lo),hi:De(e.hi)})}function It(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=fi(Math.round(t.lo)),r=fi(Math.round(t.hi));return!Number.isFinite(i)||!Number.isFinite(r)?d({lo:Math.min(i,r),hi:Math.max(i,r)}):d({lo:i,hi:r})}function kt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.lo<0)return{kind:"empty"};let i=pi(Math.round(t.lo)),r=pi(Math.round(t.hi));return!Number.isFinite(i)||!Number.isFinite(r)?d({lo:Math.min(i,r),hi:Math.max(i,r)}):d({lo:i,hi:r})}function Vi(e,n){let t=y(e);if(!Array.isArray(t))return t;let i=y(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 d({lo:Math.min(...o),hi:Math.max(...o)})}function Li(e,n){let t=y(e);if(!Array.isArray(t))return t;let i=y(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[he(Math.round(r.lo),Math.round(s.lo)),he(Math.round(r.lo),Math.round(s.hi)),he(Math.round(r.hi),Math.round(s.lo)),he(Math.round(r.hi),Math.round(s.hi))];return d({lo:Math.min(...o),hi:Math.max(...o)})}function Ji(e,n){let t=y(e);if(!Array.isArray(t))return t;let i=y(n);if(!Array.isArray(i))return i;let[r]=t,[s]=i,o=[Ae(Math.round(r.lo),Math.round(s.lo)),Ae(Math.round(r.lo),Math.round(s.hi)),Ae(Math.round(r.hi),Math.round(s.lo)),Ae(Math.round(r.hi),Math.round(s.hi))];return d({lo:Math.min(...o),hi:Math.max(...o)})}function $i(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:mi(t.lo),hi:mi(t.hi)})}function qi(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Fn(t.lo),hi:Fn(t.hi)})}function zi(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:ci(t.hi),hi:ci(t.lo)})}function Gi(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.pow(2,t.lo),hi:Math.pow(2,t.hi)})}function Zi(e,n){let t=y(e);if(!Array.isArray(t))return t;let i=y(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),d({lo:a,hi:Math.max(...o)})}var oe=2*Math.PI,L=Math.PI,xe=Math.PI/2,Ts=3*Math.PI/2;function St(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=oe)return d({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 J(t,xe,oe)&&(o=1),J(t,Ts,oe)&&(s=-1),d({lo:s,hi:o})}function Mt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=oe)return d({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 J(t,0,oe)&&(o=1),J(t,L,oe)&&(s=-1),d({lo:s,hi:o})}function wt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=L)return{kind:"singular"};if(J(t,xe,L)){let s=Math.ceil((t.lo-xe)/L);return{kind:"singular",at:xe+s*L}}let i=Math.tan(t.lo),r=Math.tan(t.hi);return i>1e10&&r<-1e10||i<-1e10&&r>1e10?{kind:"singular"}:d({lo:i,hi:r})}function Dt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=L)return{kind:"singular"};if(J(t,0,L))return{kind:"singular",at:Math.ceil(t.lo/L)*L};let i=1/Math.tan(t.lo),r=1/Math.tan(t.hi);return d({lo:Math.min(i,r),hi:Math.max(i,r)})}function At(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=L)return{kind:"singular"};if(J(t,xe,L)){let a=Math.ceil((t.lo-xe)/L);return{kind:"singular",at:xe+a*L}}let i=1/Math.cos(t.lo),r=1/Math.cos(t.hi),s=Math.min(i,r),o=Math.max(i,r);return J(t,0,oe)&&(s=Math.min(s,1),o=Math.max(o,1)),J(t,L,oe)&&(s=Math.min(s,-1),o=Math.max(o,-1)),d({lo:s,hi:o})}function Pt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;if(t.hi-t.lo>=L)return{kind:"singular"};if(J(t,0,L))return{kind:"singular",at:Math.ceil(t.lo/L)*L};let i=1/Math.sin(t.lo),r=1/Math.sin(t.hi),s=Math.min(i,r),o=Math.max(i,r);return J(t,xe,oe)&&(s=Math.min(s,1),o=Math.max(o,1)),J(t,Ts,oe)&&(s=Math.min(s,-1),o=Math.max(o,-1)),d({lo:s,hi:o})}function dn(e){let n=y(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 d({lo:Math.asin(t.lo),hi:Math.asin(t.hi)})}function hn(e){let n=y(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 d({lo:Math.acos(t.hi),hi:Math.acos(t.lo)})}function gn(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.atan(t.lo),hi:Math.atan(t.hi)})}function _t(e,n){let t=y(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 d({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?d({lo:-L,hi:L}):d({lo:Math.min(...s),hi:Math.max(...s)})}function Ze(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.sinh(t.lo),hi:Math.sinh(t.hi)})}function je(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return t.lo>=0?d({lo:Math.cosh(t.lo),hi:Math.cosh(t.hi)}):t.hi<=0?d({lo:Math.cosh(t.hi),hi:Math.cosh(t.lo)}):d({lo:1,hi:Math.max(Math.cosh(t.lo),Math.cosh(t.hi))})}function Rt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.tanh(t.lo),hi:Math.tanh(t.hi)})}function yn(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return d({lo:Math.asinh(t.lo),hi:Math.asinh(t.hi)})}function xn(e){let n=y(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"}:d({lo:Math.acosh(t.lo),hi:Math.acosh(t.hi)})}function bn(e){let n=y(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 d({lo:Math.atanh(t.lo),hi:Math.atanh(t.hi)})}function Bt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:gn(G(d({lo:1,hi:1}),d(t)))}function Ct(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:dn(G(d({lo:1,hi:1}),d(t)))}function Ot(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:hn(G(d({lo:1,hi:1}),d(t)))}function Ft(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:G(je(t),Ze(t))}function Vt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:G(d({lo:1,hi:1}),Ze(t))}function Lt(e){return G(d({lo:1,hi:1}),je(e))}function Jt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:bn(G(d({lo:1,hi:1}),d(t)))}function $t(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:yn(G(d({lo:1,hi:1}),d(t)))}function qt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n;return z(t)?{kind:"singular",at:0}:xn(G(d({lo:1,hi:1}),d(t)))}var ji=[4.49341,7.72525,10.90412,14.06619,17.22076,20.3713,23.51945,26.66605,29.8116,32.95639],oa=-.21724;function zt(e){let n=y(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=ji[ji.length-1];for(let u of ji)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(oa),d({lo:r,hi:s})}var vs=[],Is=[];for(let e=1;e<=20;e++)vs.push(Math.sqrt(2*e)),Is.push(Math.sqrt(2*e-1));function Gt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Xe(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(Xe(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of vs)o>=t.lo&&o<=t.hi&&s(Xe(o)),-o>=t.lo&&-o<=t.hi&&s(Xe(-o));return d({lo:i,hi:r})}function Zt(e){let n=y(e);if(!Array.isArray(n))return n;let[t]=n,i=Ke(t.lo),r=i,s=o=>{o<i&&(i=o),o>r&&(r=o)};s(Ke(t.hi)),t.lo<=0&&t.hi>=0&&s(0);for(let o of Is)o>=t.lo&&o<=t.hi&&s(Ke(o)),-o>=t.lo&&-o<=t.hi&&s(Ke(-o));return d({lo:i,hi:r})}function be(e){return"kind"in e?e:{kind:"interval",value:e}}function jt(e,n){let t=y(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 Ut(e,n){let t=y(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 Wt(e,n){let t=y(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 Ht(e,n){let t=y(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 Nn(e,n){let t=y(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 Yt(e,n){let t=Nn(e,n);return t==="true"?"false":t==="false"?"true":"maybe"}function Xt(e,n){return e==="false"||n==="false"?"false":e==="true"&&n==="true"?"true":"maybe"}function Kt(e,n){return e==="true"||n==="true"?"true":e==="false"&&n==="false"?"false":"maybe"}function Qt(e){return e==="true"?"false":e==="false"?"true":"maybe"}function ei(e,n,t,i){if(e==="true"||e==="false"||e==="maybe"){let h=e,N=n,v=t;switch(h){case"true":return be(N());case"false":return be(v());case"maybe":return Ne(be(N()),be(v()))}}let r=e,s=n,o=t,a=i,u=y(r);if(!Array.isArray(u))return u;let[c]=u;switch(s(c)){case"true":return be(o(c));case"false":return be(a(c));case"maybe":let h=be(o(c)),N=be(a(c));return Ne(h,N)}}function ni(e,n,t){let i=y(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 aa={ok:d,point:En,containsExtremum:J,unionResults:Ne,mergeDomainClip:We,isPoint:Tn,containsZero:z,isPositive:vn,isNegative:Se,isNonNegative:In,isNonPositive:kn,width:Sn,midpoint:Mn,getValue:wn,unwrap:Dn,unwrapOrPropagate:y,add:An,sub:Me,mul:we,div:G,negate:Pn,sqrt:rt,square:st,pow:pn,powInterval:ot,exp:at,ln:ut,log10:lt,log2:ct,abs:ft,floor:pt,ceil:mt,round:mn,fract:dt,trunc:ht,min:gt,max:yt,mod:xt,remainder:bt,heaviside:Nt,sign:Et,gamma:Tt,gammaln:vt,factorial:It,factorial2:kt,binomial:Vi,gcd:Li,lcm:Ji,chop:$i,erf:qi,erfc:zi,exp2:Gi,hypot:Zi,sin:St,cos:Mt,tan:wt,cot:Dt,sec:At,csc:Pt,asin:dn,acos:hn,atan:gn,atan2:_t,sinh:Ze,cosh:je,tanh:Rt,asinh:yn,acosh:xn,atanh:bn,acot:Bt,acsc:Ct,asec:Ot,coth:Ft,csch:Vt,sech:Lt,acoth:Jt,acsch:$t,asech:qt,sinc:zt,fresnelS:Gt,fresnelC:Zt,less:jt,lessEqual:Ut,greater:Wt,greaterEqual:Ht,equal:Nn,notEqual:Yt,and:Xt,or:Kt,not:Qt,piecewise:ei,clamp:ni};var mg="0.55.4";export{aa as IntervalArithmetic,_n as _mul,ft as abs,hn as acos,xn as acosh,Bt as acot,Jt as acoth,Ct as acsc,$t as acsch,An as add,Xt as and,Ot as asec,qt as asech,dn as asin,yn as asinh,gn as atan,_t as atan2,bn as atanh,Vi as binomial,mt as ceil,$i as chop,ni as clamp,J as containsExtremum,z as containsZero,Mt as cos,je as cosh,Dt as cot,Ft as coth,Pt as csc,Vt as csch,G as div,Nn as equal,qi as erf,zi as erfc,at as exp,Gi as exp2,It as factorial,kt as factorial2,pt as floor,dt as fract,Zt as fresnelC,Gt as fresnelS,Tt as gamma,vt as gammaln,Li as gcd,wn as getValue,Wt as greater,Ht as greaterEqual,Nt as heaviside,Zi as hypot,Se as isNegative,In as isNonNegative,kn as isNonPositive,Tn as isPoint,vn as isPositive,Ji as lcm,jt as less,Ut as lessEqual,ut as ln,lt as log10,ct as log2,yt as max,We as mergeDomainClip,Mn as midpoint,gt as min,xt as mod,we as mul,Pn as negate,Qt as not,Yt as notEqual,d as ok,Kt as or,ei as piecewise,En as point,pn as pow,ot as powInterval,bt as remainder,mn as round,At as sec,Lt as sech,Et as sign,St as sin,zt as sinc,Ze as sinh,rt as sqrt,st as square,Me as sub,wt as tan,Rt as tanh,ht as trunc,Ne as unionResults,Dn as unwrap,y as unwrapOrPropagate,mg as version,Sn as width};
|
|
9
9
|
/*! Bundled license information:
|
|
10
10
|
|
|
11
11
|
complex-esm/dist/src/complex.js:
|