dielines 0.11.2 → 0.11.3

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.
@@ -1 +1 @@
1
- {"version":3,"file":"dielines.umd.cjs","sources":["../../pantograph/dist/QuadraticBezier-BeY2TXKH.js","../../pantograph/dist/models-BHeLX0dj.js","../../pantograph/dist/draw-B3EaXatz.js","../../pantograph/dist/svg-BTO7h1ix.js","../../pantograph/dist/pantograph.js","../src/Dieline.ts","../src/drawFlaps.ts","../src/FoldLockBump.ts","../src/linearDistribution.ts"],"sourcesContent":["var Xe = Object.defineProperty;\nvar ye = (r) => {\n throw TypeError(r);\n};\nvar Ze = (r, s, t) => s in r ? Xe(r, s, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[s] = t;\nvar q = (r, s, t) => Ze(r, typeof s != \"symbol\" ? s + \"\" : s, t), oe = (r, s, t) => s.has(r) || ye(\"Cannot \" + t);\nvar ht = (r, s, t) => (oe(r, s, \"read from private field\"), t ? t.call(r) : s.get(r)), le = (r, s, t) => s.has(r) ? ye(\"Cannot add the same private member more than once\") : s instanceof WeakSet ? s.add(r) : s.set(r, t), Dt = (r, s, t, e) => (oe(r, s, \"write to private field\"), e ? e.call(r, t) : s.set(r, t), t), he = (r, s, t) => (oe(r, s, \"access private method\"), t);\nconst Me = Symbol.for(\"pantograph:BoundingBox\");\nfunction Ot(r, s, t, e) {\n return r <= e && s >= t;\n}\nclass mt {\n constructor(s = 1 / 0, t = 1 / 0, e = -1 / 0, n = -1 / 0) {\n q(this, \"xMin\");\n q(this, \"yMin\");\n q(this, \"xMax\");\n q(this, \"yMax\");\n Object.defineProperty(this, Me, { value: !0 }), this.xMin = s, this.yMin = t, this.xMax = e, this.yMax = n;\n }\n static isInstance(s) {\n return !!s && s[Me] === !0;\n }\n get width() {\n return this.xMax - this.xMin;\n }\n get height() {\n return this.yMax - this.yMin;\n }\n get center() {\n return [(this.xMin + this.xMax) / 2, (this.yMin + this.yMax) / 2];\n }\n grow(s) {\n return new mt(\n this.xMin - s,\n this.yMin - s,\n this.xMax + s,\n this.yMax + s\n );\n }\n contains(s) {\n const [t, e] = s;\n return Ot(this.xMin, this.xMax, t, t) && Ot(this.yMin, this.yMax, e, e);\n }\n overlaps(s) {\n return Ot(this.xMin, this.xMax, s.xMin, s.xMax) && Ot(this.yMin, this.yMax, s.yMin, s.yMax);\n }\n addPoint(s) {\n const [t, e] = s;\n return new mt(\n Math.min(this.xMin, t),\n Math.min(this.yMin, e),\n Math.max(this.xMax, t),\n Math.max(this.yMax, e)\n );\n }\n merge(s) {\n return new mt(\n Math.min(this.xMin, s.xMin),\n Math.min(this.yMin, s.yMin),\n Math.max(this.xMax, s.xMax),\n Math.max(this.yMax, s.yMax)\n );\n }\n intersection(s) {\n return new mt(\n Math.max(this.xMin, s.xMin),\n Math.max(this.yMin, s.yMin),\n Math.min(this.xMax, s.xMax),\n Math.min(this.yMax, s.yMax)\n );\n }\n}\nfunction ce(r) {\n return r.reduce((s, t) => s.addPoint(t), new mt());\n}\nconst Pe = (r, s = 1e-9) => {\n let t = r;\n return Math.abs(r) < s && (t = 0), t.toFixed(-Math.log10(s));\n};\nfunction Ne(r, s = 1e-9) {\n return Array.from(\n new Map(\n r.map(([t, e]) => [\n `[${Pe(t, s)},${Pe(e, s)}]`,\n [t, e]\n ])\n ).values()\n );\n}\nconst fe = Math.PI / 180, Je = 180 / Math.PI, Z = (r) => `[${r[0]}, ${r[1]}]`, Y = ([r, s], [t, e], n = 1e-9) => Math.abs(r - t) <= n && Math.abs(s - e) <= n, it = ([r, s], [t, e]) => [r + t, s + e], Q = ([r, s], [t, e]) => [r - t, s - e], Tt = ([r, s]) => r * r + s * s, pn = ([r, s]) => Math.sqrt(Tt([r, s])), nt = ([r, s], t) => [r * t, s * t], Rt = ([r, s], [t, e] = [0, 0]) => (r - t) ** 2 + (s - e) ** 2, J = (r, s = [0, 0]) => Math.sqrt(Rt(r, s));\nfunction St([r, s], [t, e]) {\n return r * e - s * t;\n}\nfunction be([r, s], [t, e]) {\n return r * t + s * e;\n}\nfunction dn([r, s], [t, e] = [0, 0]) {\n return Math.atan2(e * r - s * t, r * t + s * e);\n}\nfunction H([r, s]) {\n const t = J([r, s]);\n return [r / t, s / t];\n}\nfunction It(r, s) {\n const t = Math.cos(s) * r, e = Math.sin(s) * r;\n return [t, e];\n}\nfunction Ke([r, s]) {\n return Math.atan2(s, r);\n}\nfunction He(r) {\n const s = J(r), t = Ke(r);\n return [s, t];\n}\nfunction Ve(r, s, t = 1e-9) {\n const e = St(r, s), n = Tt(r), i = Tt(s);\n return e * e < n * i * t * t;\n}\nfunction tt(r) {\n return [-r[1], r[0]];\n}\nfunction Qt(r) {\n return [r[1], -r[0]];\n}\nfunction ts(r, s, t) {\n return Y(t, r) || Ve(Q(t, r), s);\n}\nconst Ee = Symbol.for(\n \"pantograph:TransformationMatrix\"\n), yt = (r, s) => {\n const [t, e, n, i, o, l, h, a, u] = r, [c, g, d, w, p, P, f, y, E] = s;\n return [\n t * c + e * w + n * f,\n t * g + e * p + n * y,\n t * d + e * P + n * E,\n i * c + o * w + l * f,\n i * g + o * p + l * y,\n i * d + o * P + l * E,\n h * c + a * w + u * f,\n h * g + a * p + u * y,\n h * d + a * P + u * E\n ];\n}, es = (r) => {\n const [s, t, e, n, i, o, l, h, a] = r, u = s * (i * a - o * h) - t * (n * a - o * l) + e * (n * h - i * l);\n return [\n (i * a - o * h) / u,\n (e * h - t * a) / u,\n (t * o - e * i) / u,\n (o * l - n * a) / u,\n (s * a - e * l) / u,\n (e * n - s * o) / u,\n (n * h - i * l) / u,\n (t * l - s * h) / u,\n (s * i - t * n) / u\n ];\n}, ss = (r) => {\n const [s, t, e, n, i, o, l, h, a] = r;\n return [s, n, l, t, i, h, e, o, a];\n};\nclass et {\n constructor(s) {\n q(this, \"_matrix\", [1, 0, 0, 0, 1, 0, 0, 0, 1]);\n Object.defineProperty(this, Ee, {\n value: !0\n }), s && (this._matrix = [...s]);\n }\n static isInstance(s) {\n return !!s && s[Ee] === !0;\n }\n clone() {\n return new et(this._matrix);\n }\n transpose() {\n return this._matrix = ss(this._matrix), this;\n }\n inverse() {\n return this._matrix = es(this._matrix), this;\n }\n translate(s, t) {\n return this._matrix = yt([1, 0, s, 0, 1, t, 0, 0, 1], this._matrix), this;\n }\n rotate(s, t) {\n const e = Math.cos(s), n = Math.sin(s), i = [e, -n, 0, n, e, 0, 0, 0, 1];\n return t && this.translate(-t[0], -t[1]), this._matrix = yt(i, this._matrix), t && this.translate(t[0], t[1]), this;\n }\n mirrorX() {\n return this._matrix = yt([1, 0, 0, 0, -1, 0, 0, 0, 1], this._matrix), this;\n }\n mirrorY() {\n return this._matrix = yt([-1, 0, 0, 0, 1, 0, 0, 0, 1], this._matrix), this;\n }\n mirrorLine(s, t) {\n const [e, n] = s, i = Math.atan2(n, e);\n return t && this.translate(-t[0], -t[1]), this.rotate(-i), this.mirrorX(), this.rotate(i), t && this.translate(t[0], t[1]), this;\n }\n mirrorCenter(s) {\n return s && this.translate(-s[0], -s[1]), this._matrix = yt([-1, 0, 0, 0, -1, 0, 0, 0, 1], this._matrix), s && this.translate(s[0], s[1]), this;\n }\n scale(s, t) {\n return t && this.translate(-t[0], -t[1]), this._matrix = yt([s, 0, 0, 0, s, 0, 0, 0, 1], this._matrix), t && this.translate(t[0], t[1]), this;\n }\n transform(s) {\n const [t, e] = s, [n, i, o, l, h, a] = this._matrix;\n return [n * t + i * e + o, l * t + h * e + a];\n }\n transformAngle(s) {\n const [t, e] = this.transform([Math.cos(s), Math.sin(s)]), [n, i] = this.transform([0, 0]);\n return Math.atan2(e - i, t - n);\n }\n keepsOrientation() {\n const [s, , , , t] = this._matrix;\n return s * t > 0;\n }\n scaleFactor() {\n const [s, , , t] = this._matrix;\n return Math.sqrt(s * s + t * t);\n }\n}\nclass ns {\n translateX(s) {\n const t = new et().translate(s, 0);\n return this.transform(t);\n }\n translateY(s) {\n const t = new et().translate(0, s);\n return this.transform(t);\n }\n translate(s, t) {\n const e = new et().translate(s, t);\n return this.transform(e);\n }\n translateTo([s, t]) {\n const e = new et().translate(s, t);\n return this.transform(e);\n }\n rotate(s, t) {\n const e = new et().rotate(\n s * fe,\n t\n );\n return this.transform(e);\n }\n scale(s, t) {\n const e = new et().scale(s, t);\n return this.transform(e);\n }\n mirrorCenter(s) {\n const t = new et().mirrorCenter(s);\n return this.transform(t);\n }\n mirror(s = \"x\", t) {\n const e = new et();\n return s === \"x\" ? e.mirrorX() : s === \"y\" ? e.mirrorY() : e.mirrorLine(s, t), this.transform(e);\n }\n}\nclass Ft extends ns {\n constructor(t, e) {\n super();\n q(this, \"precision\", 1e-9);\n this.firstPoint = t, this.lastPoint = e, this.firstPoint = t, this.lastPoint = e;\n }\n get repr() {\n return `${this.segmentType} ${Z(this.firstPoint)} - ${Z(\n this.lastPoint\n )}`;\n }\n get info() {\n return this.repr;\n }\n [Symbol.for(\"nodejs.util.inspect.custom\")]() {\n return this.repr;\n }\n}\nconst _e = Symbol.for(\"pantograph:Line\");\nclass at extends Ft {\n constructor(t, e) {\n super(t, e);\n q(this, \"segmentType\", \"LINE\");\n q(this, \"_V\", null);\n q(this, \"_slope\", null);\n q(this, \"_yIntercept\", null);\n q(this, \"_boundingBox\", null);\n Object.defineProperty(this, _e, { value: !0 });\n }\n static isInstance(t) {\n return !!t && t[_e] === !0;\n }\n isValidParameter(t) {\n const e = this.length * this.precision;\n return t >= -e && 1 - t >= -e;\n }\n paramPoint(t) {\n return it(this.firstPoint, nt(this.V, t));\n }\n get length() {\n return J(this.firstPoint, this.lastPoint);\n }\n get squareLength() {\n return Rt(this.firstPoint, this.lastPoint);\n }\n get V() {\n return this._V === null && (this._V = Q(this.lastPoint, this.firstPoint)), this._V;\n }\n get slope() {\n if (this._slope === null) {\n const [t, e] = this.V;\n this._slope = e / t;\n }\n return this._slope;\n }\n get yIntercept() {\n return this._yIntercept === null && (this._yIntercept = this.firstPoint[1] - this.slope * this.firstPoint[0]), this._yIntercept;\n }\n get midPoint() {\n return it(this.firstPoint, nt(this.V, 0.5));\n }\n isSame(t) {\n return at.isInstance(t) ? Y(this.firstPoint, t.firstPoint) && Y(this.lastPoint, t.lastPoint) || Y(this.lastPoint, t.firstPoint) && Y(this.firstPoint, t.lastPoint) : !1;\n }\n clone() {\n return new at(this.firstPoint, this.lastPoint);\n }\n reverse() {\n return new at(this.lastPoint, this.firstPoint);\n }\n get boundingBox() {\n return this._boundingBox === null && (this._boundingBox = new mt(\n Math.min(this.firstPoint[0], this.lastPoint[0]) - this.precision,\n Math.min(this.firstPoint[1], this.lastPoint[1]) - this.precision,\n Math.max(this.firstPoint[0], this.lastPoint[0]) + this.precision,\n Math.max(this.firstPoint[1], this.lastPoint[1]) + this.precision\n )), this._boundingBox;\n }\n distanceFrom(t) {\n const e = Q(t, this.firstPoint), n = be(e, this.V) / this.squareLength;\n if (n < 0)\n return J(t, this.firstPoint);\n if (n > 1)\n return J(t, this.lastPoint);\n const i = this.paramPoint(n);\n return J(t, i);\n }\n isOnSegment(t) {\n if (Y(t, this.firstPoint, this.precision)) return !0;\n const e = Q(t, this.firstPoint);\n if (!Ve(this.V, e)) return !1;\n const n = be(e, this.V) / this.squareLength;\n return this.isValidParameter(n);\n }\n gradientAt(t) {\n return this.V;\n }\n tangentAt(t) {\n if (!this.isOnSegment(t)) throw new Error(\"Point is not on segment\");\n return H(this.V);\n }\n get normalVector() {\n return tt(H(this.V));\n }\n get tangentAtFirstPoint() {\n return H(this.V);\n }\n get tangentAtLastPoint() {\n return H(this.V);\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t], e.forEach((a) => {\n if (!this.isOnSegment(a))\n throw new Error(\n `Point ${Z(a)} is not on segment ${this.repr}`\n );\n });\n const n = [this.firstPoint, ...e, this.lastPoint], i = Ne(n), o = this.lastPoint[0] - this.firstPoint[0];\n let l = Math.sign(o), h = 0;\n return Math.abs(o) < this.precision && (l = Math.sign(this.lastPoint[1] - this.firstPoint[1]), h = 1), i.sort(\n (a, u) => l * (a[h] - u[h])\n ), i.flatMap((a, u) => u === i.length - 1 ? [] : new at(a, i[u + 1]));\n }\n transform(t) {\n return new at(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint)\n );\n }\n}\nfunction is(r) {\n return Array.from(Array(r).keys());\n}\nfunction Kt(r) {\n const s = Math.min(...r.map((t) => t.length));\n return is(s).map((t) => r.map((e) => e[t]));\n}\nfunction wt(r, s = 1e-9) {\n return r < 0 ? r + 2 * Math.PI : r >= 2 * Math.PI ? r % (2 * Math.PI) : r > 2 * Math.PI - s ? 0 : r;\n}\nfunction Zt(r, s, t, e = 1e-9) {\n let n = s - r;\n return t && (n = -n), n < 0 && (n += 2 * Math.PI), n > 2 * Math.PI - e ? 0 : n;\n}\nconst me = (r, s, t) => {\n const e = St(r.V, s.V), n = Tt(r.V), i = Tt(s.V), o = t ? t * t : r.precision * s.precision;\n if (e * e < n * i * o)\n return \"parallel\";\n const l = Q(s.firstPoint, r.firstPoint), h = St(l, s.V) / e, a = St(l, r.V) / e;\n return {\n intersectionParam1: h,\n intersectionParam2: a\n };\n};\nfunction yn(r, s, t = !1, e) {\n const n = me(r, s, e);\n if (n === \"parallel\") {\n if (!t) return null;\n if (r.isSame(s)) return r;\n const l = Ne(\n [\n s.isOnSegment(r.firstPoint) ? r.firstPoint : null,\n s.isOnSegment(r.lastPoint) ? r.lastPoint : null,\n r.isOnSegment(s.firstPoint) ? s.firstPoint : null,\n r.isOnSegment(s.lastPoint) ? s.lastPoint : null\n ].filter((h) => h !== null)\n ).sort((h, a) => h[0] - a[0]);\n if (l.length === 0) return null;\n if (l.length === 1) return null;\n if (l.length === 2) return new at(l[0], l[1]);\n throw console.error(l), new Error(\n \"Unexpected number of points while intersecting parallel lines\"\n );\n }\n const { intersectionParam1: i, intersectionParam2: o } = n;\n return !r.isValidParameter(i) || !s.isValidParameter(o) ? null : r.paramPoint(i);\n}\nconst Bt = (r, s) => {\n const t = Q(r, s);\n return He(t);\n}, je = Symbol.for(\"pantograph:Arc\");\nclass ct extends Ft {\n constructor(t, e, n, i = !1, { ignoreChecks: o = !1 } = {}) {\n super(t, e);\n q(this, \"segmentType\", \"ARC\");\n q(this, \"center\");\n q(this, \"clockwise\");\n q(this, \"_coefficients\", null);\n q(this, \"_angularLength\", null);\n q(this, \"_radius\", null);\n q(this, \"_firstAngle\", null);\n q(this, \"_lastAngle\", null);\n q(this, \"_boundingBox\", null);\n if (Object.defineProperty(this, je, { value: !0 }), this.center = n, this.clockwise = i, !o) {\n if (Y(t, e))\n throw new Error(\"Invalid arc, cannot be a full circle\");\n if (Math.abs(this.radius - J(this.lastPoint, this.center)) > this.precision)\n throw new Error(\n `Invalid arc, radius does not match between ${Z(\n t\n )} and ${Z(e)}} (center ${Z(n)})`\n );\n }\n }\n static isInstance(t) {\n return !!t && t[je] === !0;\n }\n get info() {\n return `ARC(${Z(this.firstPoint)}, ${Z(\n this.lastPoint\n )}, ${Z(this.center)}, ${this.clockwise ? \"CW\" : \"CCW\"})`;\n }\n get coefficients() {\n if (this._coefficients === null) {\n const [t, e] = this.center, n = this.radius * this.radius;\n this._coefficients = {\n x2: 1 / n,\n xy: 0,\n y2: 1 / n,\n x: -(2 * t) / n,\n y: -(2 * e) / n,\n c: (t * t + e * e - n) / n\n };\n }\n return this._coefficients;\n }\n isValidParameter(t) {\n return 1 - t >= -this.precision && t >= -this.precision;\n }\n angleToParam(t) {\n return Zt(this.firstAngle, wt(t), this.clockwise) / this.angularLength;\n }\n get angularLength() {\n return this._angularLength || (this._angularLength = Zt(\n this.firstAngle,\n this.lastAngle,\n this.clockwise\n )), this._angularLength;\n }\n paramPoint(t) {\n return it(\n this.center,\n It(\n this.radius,\n this.firstAngle + t * this.angularLength * (this.clockwise ? -1 : 1)\n )\n );\n }\n pointToParam(t) {\n const [e, n] = Bt(t, this.center);\n if (Math.abs(e - this.radius) > this.precision)\n throw new Error(\n `Point ${Z(t)} is not on segment ${this.repr}`\n );\n const i = this.angleToParam(n);\n if (!this.isValidParameter(i))\n throw new Error(\n `Point ${Z(t)} is not on segment ${this.repr}`\n );\n return i;\n }\n get radius() {\n return this._radius === null && (this._radius = J(this.firstPoint, this.center)), this._radius;\n }\n get firstAngle() {\n if (this._firstAngle === null) {\n const [t, e] = Q(this.firstPoint, this.center);\n this._firstAngle = wt(Math.atan2(e, t));\n }\n return this._firstAngle;\n }\n get lastAngle() {\n if (this._lastAngle === null) {\n const [t, e] = Q(this.lastPoint, this.center);\n this._lastAngle = wt(Math.atan2(e, t));\n }\n return this._lastAngle;\n }\n get length() {\n return this.radius * this.angularLength;\n }\n get squareLength() {\n return this.length * this.length;\n }\n get midPoint() {\n return this.paramPoint(0.5);\n }\n isSame(t) {\n return !ct.isInstance(t) || !Y(this.center, t.center) ? !1 : Y(this.firstPoint, t.firstPoint) && Y(this.lastPoint, t.lastPoint) && this.clockwise === t.clockwise || Y(this.lastPoint, t.firstPoint) && Y(this.firstPoint, t.lastPoint) && this.clockwise === !t.clockwise;\n }\n clone() {\n return new ct(\n this.firstPoint,\n this.lastPoint,\n this.center,\n this.clockwise\n );\n }\n reverse() {\n return new ct(\n this.lastPoint,\n this.firstPoint,\n this.center,\n !this.clockwise\n );\n }\n get boundingBox() {\n if (this._boundingBox === null) {\n const t = this.radius + this.precision, e = (n) => this.isValidParameter(this.angleToParam(n));\n this._boundingBox = new mt(\n e(Math.PI) ? this.center[0] - t : Math.min(this.firstPoint[0], this.lastPoint[0]) - this.precision,\n e(Math.PI * 1.5) ? this.center[1] - t : Math.min(this.firstPoint[1], this.lastPoint[1]) - this.precision,\n e(0) ? this.center[0] + t : Math.max(this.firstPoint[0], this.lastPoint[0]) + this.precision,\n e(Math.PI / 2) ? this.center[1] + t : Math.max(this.firstPoint[1], this.lastPoint[1]) + this.precision\n );\n }\n return this._boundingBox;\n }\n distanceFrom(t) {\n const [e, n] = Bt(t, this.center);\n return this.isValidParameter(this.angleToParam(n)) ? Math.abs(e - this.radius) : Math.sqrt(\n Math.min(\n Rt(t, this.firstPoint),\n Rt(t, this.lastPoint)\n )\n );\n }\n isOnSegment(t) {\n if (Y(t, this.firstPoint) || Y(t, this.lastPoint))\n return !0;\n const [e, n] = Bt(t, this.center);\n if (Math.abs(e - this.radius) > this.precision) return !1;\n const i = this.angleToParam(n);\n return this.isValidParameter(i);\n }\n gradientAt(t) {\n const e = this.firstAngle + t * this.angularLength * (this.clockwise ? -1 : 1), n = this.radius * this.angularLength, i = -n * Math.sin(e), o = n * Math.cos(e);\n return this.clockwise ? [-i, -o] : [i, o];\n }\n tangentAt(t) {\n const [e, n] = Bt(t, this.center);\n if (Math.abs(e - this.radius) > this.precision)\n throw new Error(\"Point is not on the arc\");\n const i = this.angleToParam(n);\n if (!this.isValidParameter(i))\n throw new Error(\"Point is not on the arc\");\n const o = It(1, n);\n return (this.clockwise ? Qt : tt)(H(o));\n }\n get tangentAtFirstPoint() {\n const t = It(1, this.firstAngle);\n return (this.clockwise ? Qt : tt)(H(t));\n }\n get tangentAtLastPoint() {\n const t = It(1, this.lastAngle);\n return (this.clockwise ? Qt : tt)(H(t));\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t];\n const i = [0, 1, ...e.map((h) => this.pointToParam(h))], o = new Map(\n Kt([i, [this.firstPoint, this.lastPoint, ...e]])\n );\n i.sort((h, a) => h - a);\n let l = null;\n return i.flatMap((h, a) => {\n if (a === i.length - 1) return [];\n const u = i[a + 1];\n if (u - h < this.precision)\n return l === null && (l = h), [];\n const c = l === null ? h : l, g = new ct(\n o.get(c) || this.paramPoint(c),\n o.get(u) || this.paramPoint(u),\n this.center,\n this.clockwise\n );\n return l = null, g;\n });\n }\n transform(t) {\n return new ct(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint),\n t.transform(this.center),\n t.keepsOrientation() ? this.clockwise : !this.clockwise\n );\n }\n}\nfunction Mn(r, s, t) {\n const e = new at(s, r), n = new at(s, t), i = tt(e.tangentAtFirstPoint), o = tt(n.tangentAtLastPoint), l = me(\n { firstPoint: e.midPoint, V: i, precision: 1e-9 },\n { firstPoint: n.midPoint, V: o, precision: 1e-9 }\n );\n if (l === \"parallel\")\n throw new Error(\"Cannot create an arc from three colinear points\");\n const h = St(\n Q(r, s),\n Q(t, s)\n ) > 0;\n return new ct(\n r,\n t,\n it(e.midPoint, nt(i, l.intersectionParam1)),\n h,\n { ignoreChecks: !0 }\n );\n}\nfunction Pn(r, s, t) {\n const e = new at(r, s), n = tt(e.tangentAtFirstPoint), i = me(\n { firstPoint: e.midPoint, V: n, precision: 1e-9 },\n {\n firstPoint: r,\n V: tt(t),\n precision: 1e-9\n }\n );\n if (i === \"parallel\")\n throw new Error(\"Cannot create an arc from three colinear points\");\n const o = it(\n e.midPoint,\n nt(n, i.intersectionParam1)\n ), l = St(\n Q(o, r),\n Q(o, it(r, t))\n ) < 0;\n return new ct(r, s, o, l, {\n ignoreChecks: !0\n });\n}\nconst Se = 1e-21, zt = 1.618034;\nfunction ke(r, s = 0, t = 1, e = 110, n = 1e3) {\n let i, o, l, h, a, u, c, g, d, w, p, P, f;\n for (o = r(s), l = r(t), o < l && ([s, t] = [t, s], [o, l] = [l, o]), f = t + zt * (t - s), h = r(f), a = 3, c = 0; h < l; ) {\n if (g = (t - s) * (l - h), d = (t - f) * (l - o), w = d - g, Math.abs(w) < Se ? i = 2 * Se : i = 2 * w, p = t - ((t - f) * d - (t - s) * g) / i, P = t + e * (f - t), c > n)\n throw new Error(\"Too many iterations.\");\n if (c += 1, (p - f) * (t - p) > 0) {\n if (u = r(p), a += 1, u < h)\n return s = t, t = p, o = l, l = u, [s, t, f, o, l, h, a];\n if (u > l)\n return f = p, h = u, [s, t, f, o, l, h, a];\n p = f + zt * (f - t), u = r(p), a += 1;\n } else\n (p - P) * (P - f) >= 0 ? (p = P, u = r(p), a += 1) : (p - P) * (f - p) > 0 ? (u = r(p), a += 1, u < h && (t = f, f = p, p = f + zt * (f - t), l = h, h = u, u = r(p), a += 1)) : (p = f + zt * (f - t), u = r(p), a += 1);\n s = t, t = f, f = p, o = l, l = h, h = u;\n }\n return [s, t, f, o, l, h, a];\n}\nconst Re = 0.381966, rs = 1e-11;\nclass os {\n constructor(s, t = 148e-10, e = 500) {\n q(this, \"xmin\");\n q(this, \"fval\");\n q(this, \"iter\");\n q(this, \"funcalls\");\n q(this, \"brack\");\n this.func = s, this.tol = t, this.maxiter = e, this.func = s, this.tol = t, this.maxiter = e, this.xmin = 1 / 0, this.fval = 1 / 0, this.iter = 0, this.funcalls = 0, this.brack = null;\n }\n setBracket(s = null) {\n this.brack = s;\n }\n getBracketInfo() {\n let s, t, e, n, i, o, l;\n const h = this.func, a = this.brack;\n if (a === null)\n [i, o, l, s, t, e, n] = ke(h);\n else if (a.length === 2)\n [i, o, l, s, t, e, n] = ke(h, a[0], a[1]);\n else if (a.length === 3) {\n if ([i, o, l] = a, i > l && ([l, i] = [i, l]), !(i < o && o < l))\n throw new Error(\"Not a bracketing interval.\");\n if (s = h(i), t = h(o), e = h(l), !(t < s && t < e))\n throw new Error(\"Not a bracketing interval.\");\n n = 3;\n } else\n throw new Error(\n \"Bracketing interval must be length 2 or 3 sequence.\"\n );\n return [i, o, l, s, t, e, n];\n }\n optimize() {\n const s = this.func;\n let [t, e, n, , , , i] = this.getBracketInfo(), o = e, l = e, h = e, a = s(o), u = a, c = a, g, d;\n t < n ? (g = t, d = n) : (g = n, d = t);\n let w = 0;\n i = 1;\n let p = 0, P = 0, f;\n for (; p < this.maxiter; ) {\n const y = this.tol * Math.abs(o) + rs, E = 2 * y, R = 0.5 * (g + d);\n if (Math.abs(o - R) < E - 0.5 * (d - g))\n break;\n if (Math.abs(w) <= y)\n o >= R ? w = g - o : w = d - o, P = Re * w;\n else {\n const L = (o - l) * (c - u);\n let S = (o - h) * (c - a), k = (o - h) * S - (o - l) * L;\n S = 2 * (S - L), S > 0 && (k = -k), S = Math.abs(S);\n const D = w;\n w = P, k > S * (g - o) && k < S * (d - o) && Math.abs(k) < Math.abs(0.5 * S * D) ? (P = k * 1 / S, f = o + P, (f - g < E || d - f < E) && (R - o >= 0 ? P = y : P = -y)) : (o >= R ? w = g - o : w = d - o, P = Re * w);\n }\n Math.abs(P) < y ? P >= 0 ? f = o + y : f = o - y : f = o + P;\n const v = s(f);\n i += 1, v > c ? (f < o ? g = f : d = f, v <= a || l === o ? (h = l, l = f, u = a, a = v) : (v <= u || h === o || h === l) && (h = f, u = v)) : (f >= o ? g = o : d = o, h = l, l = o, o = f, u = a, a = c, c = v), p += 1;\n }\n this.xmin = o, this.fval = c, this.iter = p, this.funcalls = i;\n }\n results() {\n return {\n argMin: this.xmin,\n fMin: this.fval,\n iterations: this.iter,\n funcCalls: this.funcalls\n };\n }\n run() {\n return this.optimize(), this.results();\n }\n}\nfunction $e(r, s = 1e-8, t = 1e3) {\n const e = new os(r, s, t);\n return e.setBracket([0, 1]), e.run();\n}\nfunction Le(r) {\n if (r.__esModule) return r;\n var s = r.default;\n if (typeof s == \"function\") {\n var t = function e() {\n return this instanceof e ? Reflect.construct(s, arguments, this.constructor) : s.apply(this, arguments);\n };\n t.prototype = s.prototype;\n } else t = {};\n return Object.defineProperty(t, \"__esModule\", { value: !0 }), Object.keys(r).forEach(function(e) {\n var n = Object.getOwnPropertyDescriptor(r, e);\n Object.defineProperty(t, e, n.get ? n : {\n enumerable: !0,\n get: function() {\n return r[e];\n }\n });\n }), t;\n}\nvar $ = {};\nconst ls = Object.prototype.toString;\nfunction Ct(r) {\n const s = ls.call(r);\n return s.endsWith(\"Array]\") && !s.includes(\"Big\");\n}\nconst hs = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n isAnyArray: Ct\n}, Symbol.toStringTag, { value: \"Module\" })), as = /* @__PURE__ */ Le(hs);\nfunction us(r) {\n var s = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n if (!Ct(r))\n throw new TypeError(\"input must be an array\");\n if (r.length === 0)\n throw new TypeError(\"input must not be empty\");\n var t = s.fromIndex, e = t === void 0 ? 0 : t, n = s.toIndex, i = n === void 0 ? r.length : n;\n if (e < 0 || e >= r.length || !Number.isInteger(e))\n throw new Error(\"fromIndex must be a positive integer smaller than length\");\n if (i <= e || i > r.length || !Number.isInteger(i))\n throw new Error(\"toIndex must be an integer greater than fromIndex and at most equal to length\");\n for (var o = r[e], l = e + 1; l < i; l++)\n r[l] > o && (o = r[l]);\n return o;\n}\nfunction cs(r) {\n var s = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n if (!Ct(r))\n throw new TypeError(\"input must be an array\");\n if (r.length === 0)\n throw new TypeError(\"input must not be empty\");\n var t = s.fromIndex, e = t === void 0 ? 0 : t, n = s.toIndex, i = n === void 0 ? r.length : n;\n if (e < 0 || e >= r.length || !Number.isInteger(e))\n throw new Error(\"fromIndex must be a positive integer smaller than length\");\n if (i <= e || i > r.length || !Number.isInteger(i))\n throw new Error(\"toIndex must be an integer greater than fromIndex and at most equal to length\");\n for (var o = r[e], l = e + 1; l < i; l++)\n r[l] < o && (o = r[l]);\n return o;\n}\nfunction fs(r) {\n var s = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n if (Ct(r)) {\n if (r.length === 0)\n throw new TypeError(\"input must not be empty\");\n } else throw new TypeError(\"input must be an array\");\n var t;\n if (s.output !== void 0) {\n if (!Ct(s.output))\n throw new TypeError(\"output option must be an array if specified\");\n t = s.output;\n } else\n t = new Array(r.length);\n var e = cs(r), n = us(r);\n if (e === n)\n throw new RangeError(\"minimum and maximum input values are equal. Cannot rescale a constant array\");\n var i = s.min, o = i === void 0 ? s.autoMinMax ? e : 0 : i, l = s.max, h = l === void 0 ? s.autoMinMax ? n : 1 : l;\n if (o >= h)\n throw new RangeError(\"min option must be smaller than max option\");\n for (var a = (h - o) / (n - e), u = 0; u < r.length; u++)\n t[u] = (r[u] - e) * a + o;\n return t;\n}\nconst ms = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n default: fs\n}, Symbol.toStringTag, { value: \"Module\" })), gs = /* @__PURE__ */ Le(ms);\nObject.defineProperty($, \"__esModule\", { value: !0 });\nvar st = as, ve = gs;\nconst Ut = \" \".repeat(2), De = \" \".repeat(4);\nfunction ws() {\n return Oe(this);\n}\nfunction Oe(r, s = {}) {\n const {\n maxRows: t = 15,\n maxColumns: e = 10,\n maxNumSize: n = 8,\n padMinus: i = \"auto\"\n } = s;\n return `${r.constructor.name} {\n${Ut}[\n${De}${ps(r, t, e, n, i)}\n${Ut}]\n${Ut}rows: ${r.rows}\n${Ut}columns: ${r.columns}\n}`;\n}\nfunction ps(r, s, t, e, n) {\n const { rows: i, columns: o } = r, l = Math.min(i, s), h = Math.min(o, t), a = [];\n if (n === \"auto\") {\n n = !1;\n t: for (let u = 0; u < l; u++)\n for (let c = 0; c < h; c++)\n if (r.get(u, c) < 0) {\n n = !0;\n break t;\n }\n }\n for (let u = 0; u < l; u++) {\n let c = [];\n for (let g = 0; g < h; g++)\n c.push(ds(r.get(u, g), e, n));\n a.push(`${c.join(\" \")}`);\n }\n return h !== o && (a[a.length - 1] += ` ... ${o - t} more columns`), l !== i && a.push(`... ${i - s} more rows`), a.join(`\n${De}`);\n}\nfunction ds(r, s, t) {\n return (r >= 0 && t ? ` ${Ie(r, s - 1)}` : Ie(r, s)).padEnd(s);\n}\nfunction Ie(r, s) {\n let t = r.toString();\n if (t.length <= s) return t;\n let e = r.toFixed(s);\n if (e.length > s && (e = r.toFixed(Math.max(0, s - (e.length - s)))), e.length <= s && !e.startsWith(\"0.000\") && !e.startsWith(\"-0.000\"))\n return e;\n let n = r.toExponential(s);\n return n.length > s && (n = r.toExponential(Math.max(0, s - (n.length - s)))), n.slice(0);\n}\nfunction ys(r, s) {\n r.prototype.add = function(e) {\n return typeof e == \"number\" ? this.addS(e) : this.addM(e);\n }, r.prototype.addS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) + e);\n return this;\n }, r.prototype.addM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) + e.get(n, i));\n return this;\n }, r.add = function(e, n) {\n return new s(e).add(n);\n }, r.prototype.sub = function(e) {\n return typeof e == \"number\" ? this.subS(e) : this.subM(e);\n }, r.prototype.subS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) - e);\n return this;\n }, r.prototype.subM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) - e.get(n, i));\n return this;\n }, r.sub = function(e, n) {\n return new s(e).sub(n);\n }, r.prototype.subtract = r.prototype.sub, r.prototype.subtractS = r.prototype.subS, r.prototype.subtractM = r.prototype.subM, r.subtract = r.sub, r.prototype.mul = function(e) {\n return typeof e == \"number\" ? this.mulS(e) : this.mulM(e);\n }, r.prototype.mulS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) * e);\n return this;\n }, r.prototype.mulM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) * e.get(n, i));\n return this;\n }, r.mul = function(e, n) {\n return new s(e).mul(n);\n }, r.prototype.multiply = r.prototype.mul, r.prototype.multiplyS = r.prototype.mulS, r.prototype.multiplyM = r.prototype.mulM, r.multiply = r.mul, r.prototype.div = function(e) {\n return typeof e == \"number\" ? this.divS(e) : this.divM(e);\n }, r.prototype.divS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) / e);\n return this;\n }, r.prototype.divM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) / e.get(n, i));\n return this;\n }, r.div = function(e, n) {\n return new s(e).div(n);\n }, r.prototype.divide = r.prototype.div, r.prototype.divideS = r.prototype.divS, r.prototype.divideM = r.prototype.divM, r.divide = r.div, r.prototype.mod = function(e) {\n return typeof e == \"number\" ? this.modS(e) : this.modM(e);\n }, r.prototype.modS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) % e);\n return this;\n }, r.prototype.modM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) % e.get(n, i));\n return this;\n }, r.mod = function(e, n) {\n return new s(e).mod(n);\n }, r.prototype.modulus = r.prototype.mod, r.prototype.modulusS = r.prototype.modS, r.prototype.modulusM = r.prototype.modM, r.modulus = r.mod, r.prototype.and = function(e) {\n return typeof e == \"number\" ? this.andS(e) : this.andM(e);\n }, r.prototype.andS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) & e);\n return this;\n }, r.prototype.andM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) & e.get(n, i));\n return this;\n }, r.and = function(e, n) {\n return new s(e).and(n);\n }, r.prototype.or = function(e) {\n return typeof e == \"number\" ? this.orS(e) : this.orM(e);\n }, r.prototype.orS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) | e);\n return this;\n }, r.prototype.orM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) | e.get(n, i));\n return this;\n }, r.or = function(e, n) {\n return new s(e).or(n);\n }, r.prototype.xor = function(e) {\n return typeof e == \"number\" ? this.xorS(e) : this.xorM(e);\n }, r.prototype.xorS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) ^ e);\n return this;\n }, r.prototype.xorM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) ^ e.get(n, i));\n return this;\n }, r.xor = function(e, n) {\n return new s(e).xor(n);\n }, r.prototype.leftShift = function(e) {\n return typeof e == \"number\" ? this.leftShiftS(e) : this.leftShiftM(e);\n }, r.prototype.leftShiftS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) << e);\n return this;\n }, r.prototype.leftShiftM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) << e.get(n, i));\n return this;\n }, r.leftShift = function(e, n) {\n return new s(e).leftShift(n);\n }, r.prototype.signPropagatingRightShift = function(e) {\n return typeof e == \"number\" ? this.signPropagatingRightShiftS(e) : this.signPropagatingRightShiftM(e);\n }, r.prototype.signPropagatingRightShiftS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) >> e);\n return this;\n }, r.prototype.signPropagatingRightShiftM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) >> e.get(n, i));\n return this;\n }, r.signPropagatingRightShift = function(e, n) {\n return new s(e).signPropagatingRightShift(n);\n }, r.prototype.rightShift = function(e) {\n return typeof e == \"number\" ? this.rightShiftS(e) : this.rightShiftM(e);\n }, r.prototype.rightShiftS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) >>> e);\n return this;\n }, r.prototype.rightShiftM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) >>> e.get(n, i));\n return this;\n }, r.rightShift = function(e, n) {\n return new s(e).rightShift(n);\n }, r.prototype.zeroFillRightShift = r.prototype.rightShift, r.prototype.zeroFillRightShiftS = r.prototype.rightShiftS, r.prototype.zeroFillRightShiftM = r.prototype.rightShiftM, r.zeroFillRightShift = r.rightShift, r.prototype.not = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, ~this.get(e, n));\n return this;\n }, r.not = function(e) {\n return new s(e).not();\n }, r.prototype.abs = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.abs(this.get(e, n)));\n return this;\n }, r.abs = function(e) {\n return new s(e).abs();\n }, r.prototype.acos = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.acos(this.get(e, n)));\n return this;\n }, r.acos = function(e) {\n return new s(e).acos();\n }, r.prototype.acosh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.acosh(this.get(e, n)));\n return this;\n }, r.acosh = function(e) {\n return new s(e).acosh();\n }, r.prototype.asin = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.asin(this.get(e, n)));\n return this;\n }, r.asin = function(e) {\n return new s(e).asin();\n }, r.prototype.asinh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.asinh(this.get(e, n)));\n return this;\n }, r.asinh = function(e) {\n return new s(e).asinh();\n }, r.prototype.atan = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.atan(this.get(e, n)));\n return this;\n }, r.atan = function(e) {\n return new s(e).atan();\n }, r.prototype.atanh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.atanh(this.get(e, n)));\n return this;\n }, r.atanh = function(e) {\n return new s(e).atanh();\n }, r.prototype.cbrt = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.cbrt(this.get(e, n)));\n return this;\n }, r.cbrt = function(e) {\n return new s(e).cbrt();\n }, r.prototype.ceil = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.ceil(this.get(e, n)));\n return this;\n }, r.ceil = function(e) {\n return new s(e).ceil();\n }, r.prototype.clz32 = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.clz32(this.get(e, n)));\n return this;\n }, r.clz32 = function(e) {\n return new s(e).clz32();\n }, r.prototype.cos = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.cos(this.get(e, n)));\n return this;\n }, r.cos = function(e) {\n return new s(e).cos();\n }, r.prototype.cosh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.cosh(this.get(e, n)));\n return this;\n }, r.cosh = function(e) {\n return new s(e).cosh();\n }, r.prototype.exp = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.exp(this.get(e, n)));\n return this;\n }, r.exp = function(e) {\n return new s(e).exp();\n }, r.prototype.expm1 = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.expm1(this.get(e, n)));\n return this;\n }, r.expm1 = function(e) {\n return new s(e).expm1();\n }, r.prototype.floor = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.floor(this.get(e, n)));\n return this;\n }, r.floor = function(e) {\n return new s(e).floor();\n }, r.prototype.fround = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.fround(this.get(e, n)));\n return this;\n }, r.fround = function(e) {\n return new s(e).fround();\n }, r.prototype.log = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.log(this.get(e, n)));\n return this;\n }, r.log = function(e) {\n return new s(e).log();\n }, r.prototype.log1p = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.log1p(this.get(e, n)));\n return this;\n }, r.log1p = function(e) {\n return new s(e).log1p();\n }, r.prototype.log10 = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.log10(this.get(e, n)));\n return this;\n }, r.log10 = function(e) {\n return new s(e).log10();\n }, r.prototype.log2 = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.log2(this.get(e, n)));\n return this;\n }, r.log2 = function(e) {\n return new s(e).log2();\n }, r.prototype.round = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.round(this.get(e, n)));\n return this;\n }, r.round = function(e) {\n return new s(e).round();\n }, r.prototype.sign = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.sign(this.get(e, n)));\n return this;\n }, r.sign = function(e) {\n return new s(e).sign();\n }, r.prototype.sin = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.sin(this.get(e, n)));\n return this;\n }, r.sin = function(e) {\n return new s(e).sin();\n }, r.prototype.sinh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.sinh(this.get(e, n)));\n return this;\n }, r.sinh = function(e) {\n return new s(e).sinh();\n }, r.prototype.sqrt = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.sqrt(this.get(e, n)));\n return this;\n }, r.sqrt = function(e) {\n return new s(e).sqrt();\n }, r.prototype.tan = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.tan(this.get(e, n)));\n return this;\n }, r.tan = function(e) {\n return new s(e).tan();\n }, r.prototype.tanh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.tanh(this.get(e, n)));\n return this;\n }, r.tanh = function(e) {\n return new s(e).tanh();\n }, r.prototype.trunc = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.trunc(this.get(e, n)));\n return this;\n }, r.trunc = function(e) {\n return new s(e).trunc();\n }, r.pow = function(e, n) {\n return new s(e).pow(n);\n }, r.prototype.pow = function(e) {\n return typeof e == \"number\" ? this.powS(e) : this.powM(e);\n }, r.prototype.powS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) ** e);\n return this;\n }, r.prototype.powM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) ** e.get(n, i));\n return this;\n };\n}\nfunction ot(r, s, t) {\n let e = t ? r.rows : r.rows - 1;\n if (s < 0 || s > e)\n throw new RangeError(\"Row index out of range\");\n}\nfunction lt(r, s, t) {\n let e = t ? r.columns : r.columns - 1;\n if (s < 0 || s > e)\n throw new RangeError(\"Column index out of range\");\n}\nfunction Pt(r, s) {\n if (s.to1DArray && (s = s.to1DArray()), s.length !== r.columns)\n throw new RangeError(\n \"vector size must be the same as the number of columns\"\n );\n return s;\n}\nfunction bt(r, s) {\n if (s.to1DArray && (s = s.to1DArray()), s.length !== r.rows)\n throw new RangeError(\"vector size must be the same as the number of rows\");\n return s;\n}\nfunction ge(r, s) {\n if (!st.isAnyArray(s))\n throw new TypeError(\"row indices must be an array\");\n for (let t = 0; t < s.length; t++)\n if (s[t] < 0 || s[t] >= r.rows)\n throw new RangeError(\"row indices are out of range\");\n}\nfunction we(r, s) {\n if (!st.isAnyArray(s))\n throw new TypeError(\"column indices must be an array\");\n for (let t = 0; t < s.length; t++)\n if (s[t] < 0 || s[t] >= r.columns)\n throw new RangeError(\"column indices are out of range\");\n}\nfunction ae(r, s, t, e, n) {\n if (arguments.length !== 5)\n throw new RangeError(\"expected 4 arguments\");\n if (Yt(\"startRow\", s), Yt(\"endRow\", t), Yt(\"startColumn\", e), Yt(\"endColumn\", n), s > t || e > n || s < 0 || s >= r.rows || t < 0 || t >= r.rows || e < 0 || e >= r.columns || n < 0 || n >= r.columns)\n throw new RangeError(\"Submatrix indices are out of range\");\n}\nfunction Ht(r, s = 0) {\n let t = [];\n for (let e = 0; e < r; e++)\n t.push(s);\n return t;\n}\nfunction Yt(r, s) {\n if (typeof s != \"number\")\n throw new TypeError(`${r} must be a number`);\n}\nfunction Mt(r) {\n if (r.isEmpty())\n throw new Error(\"Empty matrix has no elements to index\");\n}\nfunction Ms(r) {\n let s = Ht(r.rows);\n for (let t = 0; t < r.rows; ++t)\n for (let e = 0; e < r.columns; ++e)\n s[t] += r.get(t, e);\n return s;\n}\nfunction Ps(r) {\n let s = Ht(r.columns);\n for (let t = 0; t < r.rows; ++t)\n for (let e = 0; e < r.columns; ++e)\n s[e] += r.get(t, e);\n return s;\n}\nfunction bs(r) {\n let s = 0;\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n s += r.get(t, e);\n return s;\n}\nfunction Es(r) {\n let s = Ht(r.rows, 1);\n for (let t = 0; t < r.rows; ++t)\n for (let e = 0; e < r.columns; ++e)\n s[t] *= r.get(t, e);\n return s;\n}\nfunction _s(r) {\n let s = Ht(r.columns, 1);\n for (let t = 0; t < r.rows; ++t)\n for (let e = 0; e < r.columns; ++e)\n s[e] *= r.get(t, e);\n return s;\n}\nfunction js(r) {\n let s = 1;\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n s *= r.get(t, e);\n return s;\n}\nfunction Ss(r, s, t) {\n const e = r.rows, n = r.columns, i = [];\n for (let o = 0; o < e; o++) {\n let l = 0, h = 0, a = 0;\n for (let u = 0; u < n; u++)\n a = r.get(o, u) - t[o], l += a, h += a * a;\n s ? i.push((h - l * l / n) / (n - 1)) : i.push((h - l * l / n) / n);\n }\n return i;\n}\nfunction ks(r, s, t) {\n const e = r.rows, n = r.columns, i = [];\n for (let o = 0; o < n; o++) {\n let l = 0, h = 0, a = 0;\n for (let u = 0; u < e; u++)\n a = r.get(u, o) - t[o], l += a, h += a * a;\n s ? i.push((h - l * l / e) / (e - 1)) : i.push((h - l * l / e) / e);\n }\n return i;\n}\nfunction Rs(r, s, t) {\n const e = r.rows, n = r.columns, i = e * n;\n let o = 0, l = 0, h = 0;\n for (let a = 0; a < e; a++)\n for (let u = 0; u < n; u++)\n h = r.get(a, u) - t, o += h, l += h * h;\n return s ? (l - o * o / i) / (i - 1) : (l - o * o / i) / i;\n}\nfunction vs(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) - s[t]);\n}\nfunction Is(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) - s[e]);\n}\nfunction Ts(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) - s);\n}\nfunction Cs(r) {\n const s = [];\n for (let t = 0; t < r.rows; t++) {\n let e = 0;\n for (let n = 0; n < r.columns; n++)\n e += r.get(t, n) ** 2 / (r.columns - 1);\n s.push(Math.sqrt(e));\n }\n return s;\n}\nfunction qs(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) / s[t]);\n}\nfunction As(r) {\n const s = [];\n for (let t = 0; t < r.columns; t++) {\n let e = 0;\n for (let n = 0; n < r.rows; n++)\n e += r.get(n, t) ** 2 / (r.rows - 1);\n s.push(Math.sqrt(e));\n }\n return s;\n}\nfunction Fs(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) / s[e]);\n}\nfunction xs(r) {\n const s = r.size - 1;\n let t = 0;\n for (let e = 0; e < r.columns; e++)\n for (let n = 0; n < r.rows; n++)\n t += r.get(n, e) ** 2 / s;\n return Math.sqrt(t);\n}\nfunction Ns(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) / s);\n}\nclass N {\n static from1DArray(s, t, e) {\n if (s * t !== e.length)\n throw new RangeError(\"data length does not match given dimensions\");\n let i = new _(s, t);\n for (let o = 0; o < s; o++)\n for (let l = 0; l < t; l++)\n i.set(o, l, e[o * t + l]);\n return i;\n }\n static rowVector(s) {\n let t = new _(1, s.length);\n for (let e = 0; e < s.length; e++)\n t.set(0, e, s[e]);\n return t;\n }\n static columnVector(s) {\n let t = new _(s.length, 1);\n for (let e = 0; e < s.length; e++)\n t.set(e, 0, s[e]);\n return t;\n }\n static zeros(s, t) {\n return new _(s, t);\n }\n static ones(s, t) {\n return new _(s, t).fill(1);\n }\n static rand(s, t, e = {}) {\n if (typeof e != \"object\")\n throw new TypeError(\"options must be an object\");\n const { random: n = Math.random } = e;\n let i = new _(s, t);\n for (let o = 0; o < s; o++)\n for (let l = 0; l < t; l++)\n i.set(o, l, n());\n return i;\n }\n static randInt(s, t, e = {}) {\n if (typeof e != \"object\")\n throw new TypeError(\"options must be an object\");\n const { min: n = 0, max: i = 1e3, random: o = Math.random } = e;\n if (!Number.isInteger(n)) throw new TypeError(\"min must be an integer\");\n if (!Number.isInteger(i)) throw new TypeError(\"max must be an integer\");\n if (n >= i) throw new RangeError(\"min must be smaller than max\");\n let l = i - n, h = new _(s, t);\n for (let a = 0; a < s; a++)\n for (let u = 0; u < t; u++) {\n let c = n + Math.round(o() * l);\n h.set(a, u, c);\n }\n return h;\n }\n static eye(s, t, e) {\n t === void 0 && (t = s), e === void 0 && (e = 1);\n let n = Math.min(s, t), i = this.zeros(s, t);\n for (let o = 0; o < n; o++)\n i.set(o, o, e);\n return i;\n }\n static diag(s, t, e) {\n let n = s.length;\n t === void 0 && (t = n), e === void 0 && (e = t);\n let i = Math.min(n, t, e), o = this.zeros(t, e);\n for (let l = 0; l < i; l++)\n o.set(l, l, s[l]);\n return o;\n }\n static min(s, t) {\n s = this.checkMatrix(s), t = this.checkMatrix(t);\n let e = s.rows, n = s.columns, i = new _(e, n);\n for (let o = 0; o < e; o++)\n for (let l = 0; l < n; l++)\n i.set(o, l, Math.min(s.get(o, l), t.get(o, l)));\n return i;\n }\n static max(s, t) {\n s = this.checkMatrix(s), t = this.checkMatrix(t);\n let e = s.rows, n = s.columns, i = new this(e, n);\n for (let o = 0; o < e; o++)\n for (let l = 0; l < n; l++)\n i.set(o, l, Math.max(s.get(o, l), t.get(o, l)));\n return i;\n }\n static checkMatrix(s) {\n return N.isMatrix(s) ? s : new _(s);\n }\n static isMatrix(s) {\n return s != null && s.klass === \"Matrix\";\n }\n get size() {\n return this.rows * this.columns;\n }\n apply(s) {\n if (typeof s != \"function\")\n throw new TypeError(\"callback must be a function\");\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n s.call(this, t, e);\n return this;\n }\n to1DArray() {\n let s = [];\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n s.push(this.get(t, e));\n return s;\n }\n to2DArray() {\n let s = [];\n for (let t = 0; t < this.rows; t++) {\n s.push([]);\n for (let e = 0; e < this.columns; e++)\n s[t].push(this.get(t, e));\n }\n return s;\n }\n toJSON() {\n return this.to2DArray();\n }\n isRowVector() {\n return this.rows === 1;\n }\n isColumnVector() {\n return this.columns === 1;\n }\n isVector() {\n return this.rows === 1 || this.columns === 1;\n }\n isSquare() {\n return this.rows === this.columns;\n }\n isEmpty() {\n return this.rows === 0 || this.columns === 0;\n }\n isSymmetric() {\n if (this.isSquare()) {\n for (let s = 0; s < this.rows; s++)\n for (let t = 0; t <= s; t++)\n if (this.get(s, t) !== this.get(t, s))\n return !1;\n return !0;\n }\n return !1;\n }\n isDistance() {\n if (!this.isSymmetric()) return !1;\n for (let s = 0; s < this.rows; s++)\n if (this.get(s, s) !== 0) return !1;\n return !0;\n }\n isEchelonForm() {\n let s = 0, t = 0, e = -1, n = !0, i = !1;\n for (; s < this.rows && n; ) {\n for (t = 0, i = !1; t < this.columns && i === !1; )\n this.get(s, t) === 0 ? t++ : this.get(s, t) === 1 && t > e ? (i = !0, e = t) : (n = !1, i = !0);\n s++;\n }\n return n;\n }\n isReducedEchelonForm() {\n let s = 0, t = 0, e = -1, n = !0, i = !1;\n for (; s < this.rows && n; ) {\n for (t = 0, i = !1; t < this.columns && i === !1; )\n this.get(s, t) === 0 ? t++ : this.get(s, t) === 1 && t > e ? (i = !0, e = t) : (n = !1, i = !0);\n for (let o = t + 1; o < this.rows; o++)\n this.get(s, o) !== 0 && (n = !1);\n s++;\n }\n return n;\n }\n echelonForm() {\n let s = this.clone(), t = 0, e = 0;\n for (; t < s.rows && e < s.columns; ) {\n let n = t;\n for (let i = t; i < s.rows; i++)\n s.get(i, e) > s.get(n, e) && (n = i);\n if (s.get(n, e) === 0)\n e++;\n else {\n s.swapRows(t, n);\n let i = s.get(t, e);\n for (let o = e; o < s.columns; o++)\n s.set(t, o, s.get(t, o) / i);\n for (let o = t + 1; o < s.rows; o++) {\n let l = s.get(o, e) / s.get(t, e);\n s.set(o, e, 0);\n for (let h = e + 1; h < s.columns; h++)\n s.set(o, h, s.get(o, h) - s.get(t, h) * l);\n }\n t++, e++;\n }\n }\n return s;\n }\n reducedEchelonForm() {\n let s = this.echelonForm(), t = s.columns, e = s.rows, n = e - 1;\n for (; n >= 0; )\n if (s.maxRow(n) === 0)\n n--;\n else {\n let i = 0, o = !1;\n for (; i < e && o === !1; )\n s.get(n, i) === 1 ? o = !0 : i++;\n for (let l = 0; l < n; l++) {\n let h = s.get(l, i);\n for (let a = i; a < t; a++) {\n let u = s.get(l, a) - h * s.get(n, a);\n s.set(l, a, u);\n }\n }\n n--;\n }\n return s;\n }\n set() {\n throw new Error(\"set method is unimplemented\");\n }\n get() {\n throw new Error(\"get method is unimplemented\");\n }\n repeat(s = {}) {\n if (typeof s != \"object\")\n throw new TypeError(\"options must be an object\");\n const { rows: t = 1, columns: e = 1 } = s;\n if (!Number.isInteger(t) || t <= 0)\n throw new TypeError(\"rows must be a positive integer\");\n if (!Number.isInteger(e) || e <= 0)\n throw new TypeError(\"columns must be a positive integer\");\n let n = new _(this.rows * t, this.columns * e);\n for (let i = 0; i < t; i++)\n for (let o = 0; o < e; o++)\n n.setSubMatrix(this, this.rows * i, this.columns * o);\n return n;\n }\n fill(s) {\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, s);\n return this;\n }\n neg() {\n return this.mulS(-1);\n }\n getRow(s) {\n ot(this, s);\n let t = [];\n for (let e = 0; e < this.columns; e++)\n t.push(this.get(s, e));\n return t;\n }\n getRowVector(s) {\n return _.rowVector(this.getRow(s));\n }\n setRow(s, t) {\n ot(this, s), t = Pt(this, t);\n for (let e = 0; e < this.columns; e++)\n this.set(s, e, t[e]);\n return this;\n }\n swapRows(s, t) {\n ot(this, s), ot(this, t);\n for (let e = 0; e < this.columns; e++) {\n let n = this.get(s, e);\n this.set(s, e, this.get(t, e)), this.set(t, e, n);\n }\n return this;\n }\n getColumn(s) {\n lt(this, s);\n let t = [];\n for (let e = 0; e < this.rows; e++)\n t.push(this.get(e, s));\n return t;\n }\n getColumnVector(s) {\n return _.columnVector(this.getColumn(s));\n }\n setColumn(s, t) {\n lt(this, s), t = bt(this, t);\n for (let e = 0; e < this.rows; e++)\n this.set(e, s, t[e]);\n return this;\n }\n swapColumns(s, t) {\n lt(this, s), lt(this, t);\n for (let e = 0; e < this.rows; e++) {\n let n = this.get(e, s);\n this.set(e, s, this.get(e, t)), this.set(e, t, n);\n }\n return this;\n }\n addRowVector(s) {\n s = Pt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) + s[e]);\n return this;\n }\n subRowVector(s) {\n s = Pt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) - s[e]);\n return this;\n }\n mulRowVector(s) {\n s = Pt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) * s[e]);\n return this;\n }\n divRowVector(s) {\n s = Pt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) / s[e]);\n return this;\n }\n addColumnVector(s) {\n s = bt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) + s[t]);\n return this;\n }\n subColumnVector(s) {\n s = bt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) - s[t]);\n return this;\n }\n mulColumnVector(s) {\n s = bt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) * s[t]);\n return this;\n }\n divColumnVector(s) {\n s = bt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) / s[t]);\n return this;\n }\n mulRow(s, t) {\n ot(this, s);\n for (let e = 0; e < this.columns; e++)\n this.set(s, e, this.get(s, e) * t);\n return this;\n }\n mulColumn(s, t) {\n lt(this, s);\n for (let e = 0; e < this.rows; e++)\n this.set(e, s, this.get(e, s) * t);\n return this;\n }\n max(s) {\n if (this.isEmpty())\n return NaN;\n switch (s) {\n case \"row\": {\n const t = new Array(this.rows).fill(Number.NEGATIVE_INFINITY);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) > t[e] && (t[e] = this.get(e, n));\n return t;\n }\n case \"column\": {\n const t = new Array(this.columns).fill(Number.NEGATIVE_INFINITY);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) > t[n] && (t[n] = this.get(e, n));\n return t;\n }\n case void 0: {\n let t = this.get(0, 0);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) > t && (t = this.get(e, n));\n return t;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n maxIndex() {\n Mt(this);\n let s = this.get(0, 0), t = [0, 0];\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) > s && (s = this.get(e, n), t[0] = e, t[1] = n);\n return t;\n }\n min(s) {\n if (this.isEmpty())\n return NaN;\n switch (s) {\n case \"row\": {\n const t = new Array(this.rows).fill(Number.POSITIVE_INFINITY);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) < t[e] && (t[e] = this.get(e, n));\n return t;\n }\n case \"column\": {\n const t = new Array(this.columns).fill(Number.POSITIVE_INFINITY);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) < t[n] && (t[n] = this.get(e, n));\n return t;\n }\n case void 0: {\n let t = this.get(0, 0);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) < t && (t = this.get(e, n));\n return t;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n minIndex() {\n Mt(this);\n let s = this.get(0, 0), t = [0, 0];\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) < s && (s = this.get(e, n), t[0] = e, t[1] = n);\n return t;\n }\n maxRow(s) {\n if (ot(this, s), this.isEmpty())\n return NaN;\n let t = this.get(s, 0);\n for (let e = 1; e < this.columns; e++)\n this.get(s, e) > t && (t = this.get(s, e));\n return t;\n }\n maxRowIndex(s) {\n ot(this, s), Mt(this);\n let t = this.get(s, 0), e = [s, 0];\n for (let n = 1; n < this.columns; n++)\n this.get(s, n) > t && (t = this.get(s, n), e[1] = n);\n return e;\n }\n minRow(s) {\n if (ot(this, s), this.isEmpty())\n return NaN;\n let t = this.get(s, 0);\n for (let e = 1; e < this.columns; e++)\n this.get(s, e) < t && (t = this.get(s, e));\n return t;\n }\n minRowIndex(s) {\n ot(this, s), Mt(this);\n let t = this.get(s, 0), e = [s, 0];\n for (let n = 1; n < this.columns; n++)\n this.get(s, n) < t && (t = this.get(s, n), e[1] = n);\n return e;\n }\n maxColumn(s) {\n if (lt(this, s), this.isEmpty())\n return NaN;\n let t = this.get(0, s);\n for (let e = 1; e < this.rows; e++)\n this.get(e, s) > t && (t = this.get(e, s));\n return t;\n }\n maxColumnIndex(s) {\n lt(this, s), Mt(this);\n let t = this.get(0, s), e = [0, s];\n for (let n = 1; n < this.rows; n++)\n this.get(n, s) > t && (t = this.get(n, s), e[0] = n);\n return e;\n }\n minColumn(s) {\n if (lt(this, s), this.isEmpty())\n return NaN;\n let t = this.get(0, s);\n for (let e = 1; e < this.rows; e++)\n this.get(e, s) < t && (t = this.get(e, s));\n return t;\n }\n minColumnIndex(s) {\n lt(this, s), Mt(this);\n let t = this.get(0, s), e = [0, s];\n for (let n = 1; n < this.rows; n++)\n this.get(n, s) < t && (t = this.get(n, s), e[0] = n);\n return e;\n }\n diag() {\n let s = Math.min(this.rows, this.columns), t = [];\n for (let e = 0; e < s; e++)\n t.push(this.get(e, e));\n return t;\n }\n norm(s = \"frobenius\") {\n switch (s) {\n case \"max\":\n return this.max();\n case \"frobenius\":\n return Math.sqrt(this.dot(this));\n default:\n throw new RangeError(`unknown norm type: ${s}`);\n }\n }\n cumulativeSum() {\n let s = 0;\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n s += this.get(t, e), this.set(t, e, s);\n return this;\n }\n dot(s) {\n N.isMatrix(s) && (s = s.to1DArray());\n let t = this.to1DArray();\n if (t.length !== s.length)\n throw new RangeError(\"vectors do not have the same size\");\n let e = 0;\n for (let n = 0; n < t.length; n++)\n e += t[n] * s[n];\n return e;\n }\n mmul(s) {\n s = _.checkMatrix(s);\n let t = this.rows, e = this.columns, n = s.columns, i = new _(t, n), o = new Float64Array(e);\n for (let l = 0; l < n; l++) {\n for (let h = 0; h < e; h++)\n o[h] = s.get(h, l);\n for (let h = 0; h < t; h++) {\n let a = 0;\n for (let u = 0; u < e; u++)\n a += this.get(h, u) * o[u];\n i.set(h, l, a);\n }\n }\n return i;\n }\n mpow(s) {\n if (!this.isSquare())\n throw new RangeError(\"Matrix must be square\");\n if (!Number.isInteger(s) || s < 0)\n throw new RangeError(\"Exponent must be a non-negative integer\");\n let t = _.eye(this.rows), e = this;\n for (let n = s; n > 1; n /= 2)\n n & 1 && (t = t.mmul(e)), e = e.mmul(e);\n return t;\n }\n strassen2x2(s) {\n s = _.checkMatrix(s);\n let t = new _(2, 2);\n const e = this.get(0, 0), n = s.get(0, 0), i = this.get(0, 1), o = s.get(0, 1), l = this.get(1, 0), h = s.get(1, 0), a = this.get(1, 1), u = s.get(1, 1), c = (e + a) * (n + u), g = (l + a) * n, d = e * (o - u), w = a * (h - n), p = (e + i) * u, P = (l - e) * (n + o), f = (i - a) * (h + u), y = c + w - p + f, E = d + p, R = g + w, v = c - g + d + P;\n return t.set(0, 0, y), t.set(0, 1, E), t.set(1, 0, R), t.set(1, 1, v), t;\n }\n strassen3x3(s) {\n s = _.checkMatrix(s);\n let t = new _(3, 3);\n const e = this.get(0, 0), n = this.get(0, 1), i = this.get(0, 2), o = this.get(1, 0), l = this.get(1, 1), h = this.get(1, 2), a = this.get(2, 0), u = this.get(2, 1), c = this.get(2, 2), g = s.get(0, 0), d = s.get(0, 1), w = s.get(0, 2), p = s.get(1, 0), P = s.get(1, 1), f = s.get(1, 2), y = s.get(2, 0), E = s.get(2, 1), R = s.get(2, 2), v = (e + n + i - o - l - u - c) * P, L = (e - o) * (-d + P), S = l * (-g + d + p - P - f - y + R), k = (-e + o + l) * (g - d + P), D = (o + l) * (-g + d), m = e * g, b = (-e + a + u) * (g - w + f), j = (-e + a) * (w - f), M = (a + u) * (-g + w), C = (e + n + i - l - h - a - u) * f, A = u * (-g + w + p - P - f - y + E), T = (-i + u + c) * (P + y - E), z = (i - c) * (P - E), F = i * y, V = (u + c) * (-y + E), x = (-i + l + h) * (f + y - R), B = (i - h) * (f - R), U = (l + h) * (-y + R), I = n * p, O = h * E, X = o * w, G = a * d, W = c * R, se = m + F + I, ne = v + k + D + m + T + F + V, ie = m + b + M + C + F + x + U, re = L + S + k + m + F + x + B, xt = L + k + D + m + O, Nt = F + x + B + U + X, Vt = m + b + j + A + T + z + F, $t = T + z + F + V + G, Lt = m + b + j + M + W;\n return t.set(0, 0, se), t.set(0, 1, ne), t.set(0, 2, ie), t.set(1, 0, re), t.set(1, 1, xt), t.set(1, 2, Nt), t.set(2, 0, Vt), t.set(2, 1, $t), t.set(2, 2, Lt), t;\n }\n mmulStrassen(s) {\n s = _.checkMatrix(s);\n let t = this.clone(), e = t.rows, n = t.columns, i = s.rows, o = s.columns;\n n !== i && console.warn(\n `Multiplying ${e} x ${n} and ${i} x ${o} matrix: dimensions do not match.`\n );\n function l(c, g, d) {\n let w = c.rows, p = c.columns;\n if (w === g && p === d)\n return c;\n {\n let P = N.zeros(g, d);\n return P = P.setSubMatrix(c, 0, 0), P;\n }\n }\n let h = Math.max(e, i), a = Math.max(n, o);\n t = l(t, h, a), s = l(s, h, a);\n function u(c, g, d, w) {\n if (d <= 512 || w <= 512)\n return c.mmul(g);\n d % 2 === 1 && w % 2 === 1 ? (c = l(c, d + 1, w + 1), g = l(g, d + 1, w + 1)) : d % 2 === 1 ? (c = l(c, d + 1, w), g = l(g, d + 1, w)) : w % 2 === 1 && (c = l(c, d, w + 1), g = l(g, d, w + 1));\n let p = parseInt(c.rows / 2, 10), P = parseInt(c.columns / 2, 10), f = c.subMatrix(0, p - 1, 0, P - 1), y = g.subMatrix(0, p - 1, 0, P - 1), E = c.subMatrix(0, p - 1, P, c.columns - 1), R = g.subMatrix(0, p - 1, P, g.columns - 1), v = c.subMatrix(p, c.rows - 1, 0, P - 1), L = g.subMatrix(p, g.rows - 1, 0, P - 1), S = c.subMatrix(p, c.rows - 1, P, c.columns - 1), k = g.subMatrix(p, g.rows - 1, P, g.columns - 1), D = u(\n N.add(f, S),\n N.add(y, k),\n p,\n P\n ), m = u(N.add(v, S), y, p, P), b = u(f, N.sub(R, k), p, P), j = u(S, N.sub(L, y), p, P), M = u(N.add(f, E), k, p, P), C = u(\n N.sub(v, f),\n N.add(y, R),\n p,\n P\n ), A = u(\n N.sub(E, S),\n N.add(L, k),\n p,\n P\n ), T = N.add(D, j);\n T.sub(M), T.add(A);\n let z = N.add(b, M), F = N.add(m, j), V = N.sub(D, m);\n V.add(b), V.add(C);\n let x = N.zeros(2 * T.rows, 2 * T.columns);\n return x = x.setSubMatrix(T, 0, 0), x = x.setSubMatrix(z, T.rows, 0), x = x.setSubMatrix(F, 0, T.columns), x = x.setSubMatrix(V, T.rows, T.columns), x.subMatrix(0, d - 1, 0, w - 1);\n }\n return u(t, s, h, a);\n }\n scaleRows(s = {}) {\n if (typeof s != \"object\")\n throw new TypeError(\"options must be an object\");\n const { min: t = 0, max: e = 1 } = s;\n if (!Number.isFinite(t)) throw new TypeError(\"min must be a number\");\n if (!Number.isFinite(e)) throw new TypeError(\"max must be a number\");\n if (t >= e) throw new RangeError(\"min must be smaller than max\");\n let n = new _(this.rows, this.columns);\n for (let i = 0; i < this.rows; i++) {\n const o = this.getRow(i);\n o.length > 0 && ve(o, { min: t, max: e, output: o }), n.setRow(i, o);\n }\n return n;\n }\n scaleColumns(s = {}) {\n if (typeof s != \"object\")\n throw new TypeError(\"options must be an object\");\n const { min: t = 0, max: e = 1 } = s;\n if (!Number.isFinite(t)) throw new TypeError(\"min must be a number\");\n if (!Number.isFinite(e)) throw new TypeError(\"max must be a number\");\n if (t >= e) throw new RangeError(\"min must be smaller than max\");\n let n = new _(this.rows, this.columns);\n for (let i = 0; i < this.columns; i++) {\n const o = this.getColumn(i);\n o.length && ve(o, {\n min: t,\n max: e,\n output: o\n }), n.setColumn(i, o);\n }\n return n;\n }\n flipRows() {\n const s = Math.ceil(this.columns / 2);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < s; e++) {\n let n = this.get(t, e), i = this.get(t, this.columns - 1 - e);\n this.set(t, e, i), this.set(t, this.columns - 1 - e, n);\n }\n return this;\n }\n flipColumns() {\n const s = Math.ceil(this.rows / 2);\n for (let t = 0; t < this.columns; t++)\n for (let e = 0; e < s; e++) {\n let n = this.get(e, t), i = this.get(this.rows - 1 - e, t);\n this.set(e, t, i), this.set(this.rows - 1 - e, t, n);\n }\n return this;\n }\n kroneckerProduct(s) {\n s = _.checkMatrix(s);\n let t = this.rows, e = this.columns, n = s.rows, i = s.columns, o = new _(t * n, e * i);\n for (let l = 0; l < t; l++)\n for (let h = 0; h < e; h++)\n for (let a = 0; a < n; a++)\n for (let u = 0; u < i; u++)\n o.set(n * l + a, i * h + u, this.get(l, h) * s.get(a, u));\n return o;\n }\n kroneckerSum(s) {\n if (s = _.checkMatrix(s), !this.isSquare() || !s.isSquare())\n throw new Error(\"Kronecker Sum needs two Square Matrices\");\n let t = this.rows, e = s.rows, n = this.kroneckerProduct(_.eye(e, e)), i = _.eye(t, t).kroneckerProduct(s);\n return n.add(i);\n }\n transpose() {\n let s = new _(this.columns, this.rows);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n s.set(e, t, this.get(t, e));\n return s;\n }\n sortRows(s = Te) {\n for (let t = 0; t < this.rows; t++)\n this.setRow(t, this.getRow(t).sort(s));\n return this;\n }\n sortColumns(s = Te) {\n for (let t = 0; t < this.columns; t++)\n this.setColumn(t, this.getColumn(t).sort(s));\n return this;\n }\n subMatrix(s, t, e, n) {\n ae(this, s, t, e, n);\n let i = new _(\n t - s + 1,\n n - e + 1\n );\n for (let o = s; o <= t; o++)\n for (let l = e; l <= n; l++)\n i.set(o - s, l - e, this.get(o, l));\n return i;\n }\n subMatrixRow(s, t, e) {\n if (t === void 0 && (t = 0), e === void 0 && (e = this.columns - 1), t > e || t < 0 || t >= this.columns || e < 0 || e >= this.columns)\n throw new RangeError(\"Argument out of range\");\n let n = new _(s.length, e - t + 1);\n for (let i = 0; i < s.length; i++)\n for (let o = t; o <= e; o++) {\n if (s[i] < 0 || s[i] >= this.rows)\n throw new RangeError(`Row index out of range: ${s[i]}`);\n n.set(i, o - t, this.get(s[i], o));\n }\n return n;\n }\n subMatrixColumn(s, t, e) {\n if (t === void 0 && (t = 0), e === void 0 && (e = this.rows - 1), t > e || t < 0 || t >= this.rows || e < 0 || e >= this.rows)\n throw new RangeError(\"Argument out of range\");\n let n = new _(e - t + 1, s.length);\n for (let i = 0; i < s.length; i++)\n for (let o = t; o <= e; o++) {\n if (s[i] < 0 || s[i] >= this.columns)\n throw new RangeError(`Column index out of range: ${s[i]}`);\n n.set(o - t, i, this.get(o, s[i]));\n }\n return n;\n }\n setSubMatrix(s, t, e) {\n if (s = _.checkMatrix(s), s.isEmpty())\n return this;\n let n = t + s.rows - 1, i = e + s.columns - 1;\n ae(this, t, n, e, i);\n for (let o = 0; o < s.rows; o++)\n for (let l = 0; l < s.columns; l++)\n this.set(t + o, e + l, s.get(o, l));\n return this;\n }\n selection(s, t) {\n ge(this, s), we(this, t);\n let e = new _(s.length, t.length);\n for (let n = 0; n < s.length; n++) {\n let i = s[n];\n for (let o = 0; o < t.length; o++) {\n let l = t[o];\n e.set(n, o, this.get(i, l));\n }\n }\n return e;\n }\n trace() {\n let s = Math.min(this.rows, this.columns), t = 0;\n for (let e = 0; e < s; e++)\n t += this.get(e, e);\n return t;\n }\n clone() {\n return this.constructor.copy(this, new _(this.rows, this.columns));\n }\n /**\n * @template {AbstractMatrix} M\n * @param {AbstractMatrix} from\n * @param {M} to\n * @return {M}\n */\n static copy(s, t) {\n for (const [e, n, i] of s.entries())\n t.set(e, n, i);\n return t;\n }\n sum(s) {\n switch (s) {\n case \"row\":\n return Ms(this);\n case \"column\":\n return Ps(this);\n case void 0:\n return bs(this);\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n product(s) {\n switch (s) {\n case \"row\":\n return Es(this);\n case \"column\":\n return _s(this);\n case void 0:\n return js(this);\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n mean(s) {\n const t = this.sum(s);\n switch (s) {\n case \"row\": {\n for (let e = 0; e < this.rows; e++)\n t[e] /= this.columns;\n return t;\n }\n case \"column\": {\n for (let e = 0; e < this.columns; e++)\n t[e] /= this.rows;\n return t;\n }\n case void 0:\n return t / this.size;\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n variance(s, t = {}) {\n if (typeof s == \"object\" && (t = s, s = void 0), typeof t != \"object\")\n throw new TypeError(\"options must be an object\");\n const { unbiased: e = !0, mean: n = this.mean(s) } = t;\n if (typeof e != \"boolean\")\n throw new TypeError(\"unbiased must be a boolean\");\n switch (s) {\n case \"row\": {\n if (!st.isAnyArray(n))\n throw new TypeError(\"mean must be an array\");\n return Ss(this, e, n);\n }\n case \"column\": {\n if (!st.isAnyArray(n))\n throw new TypeError(\"mean must be an array\");\n return ks(this, e, n);\n }\n case void 0: {\n if (typeof n != \"number\")\n throw new TypeError(\"mean must be a number\");\n return Rs(this, e, n);\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n standardDeviation(s, t) {\n typeof s == \"object\" && (t = s, s = void 0);\n const e = this.variance(s, t);\n if (s === void 0)\n return Math.sqrt(e);\n for (let n = 0; n < e.length; n++)\n e[n] = Math.sqrt(e[n]);\n return e;\n }\n center(s, t = {}) {\n if (typeof s == \"object\" && (t = s, s = void 0), typeof t != \"object\")\n throw new TypeError(\"options must be an object\");\n const { center: e = this.mean(s) } = t;\n switch (s) {\n case \"row\": {\n if (!st.isAnyArray(e))\n throw new TypeError(\"center must be an array\");\n return vs(this, e), this;\n }\n case \"column\": {\n if (!st.isAnyArray(e))\n throw new TypeError(\"center must be an array\");\n return Is(this, e), this;\n }\n case void 0: {\n if (typeof e != \"number\")\n throw new TypeError(\"center must be a number\");\n return Ts(this, e), this;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n scale(s, t = {}) {\n if (typeof s == \"object\" && (t = s, s = void 0), typeof t != \"object\")\n throw new TypeError(\"options must be an object\");\n let e = t.scale;\n switch (s) {\n case \"row\": {\n if (e === void 0)\n e = Cs(this);\n else if (!st.isAnyArray(e))\n throw new TypeError(\"scale must be an array\");\n return qs(this, e), this;\n }\n case \"column\": {\n if (e === void 0)\n e = As(this);\n else if (!st.isAnyArray(e))\n throw new TypeError(\"scale must be an array\");\n return Fs(this, e), this;\n }\n case void 0: {\n if (e === void 0)\n e = xs(this);\n else if (typeof e != \"number\")\n throw new TypeError(\"scale must be a number\");\n return Ns(this, e), this;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n toString(s) {\n return Oe(this, s);\n }\n [Symbol.iterator]() {\n return this.entries();\n }\n /**\n * iterator from left to right, from top to bottom\n * yield [row, column, value]\n * @returns {Generator<[number, number, number], void, void>}\n */\n *entries() {\n for (let s = 0; s < this.rows; s++)\n for (let t = 0; t < this.columns; t++)\n yield [s, t, this.get(s, t)];\n }\n /**\n * iterator from left to right, from top to bottom\n * yield value\n * @returns {Generator<number, void, void>}\n */\n *values() {\n for (let s = 0; s < this.rows; s++)\n for (let t = 0; t < this.columns; t++)\n yield this.get(s, t);\n }\n}\nN.prototype.klass = \"Matrix\";\ntypeof Symbol < \"u\" && (N.prototype[Symbol.for(\"nodejs.util.inspect.custom\")] = ws);\nfunction Te(r, s) {\n return r - s;\n}\nfunction Vs(r) {\n return r.every((s) => typeof s == \"number\");\n}\nN.random = N.rand;\nN.randomInt = N.randInt;\nN.diagonal = N.diag;\nN.prototype.diagonal = N.prototype.diag;\nN.identity = N.eye;\nN.prototype.negate = N.prototype.neg;\nN.prototype.tensorProduct = N.prototype.kroneckerProduct;\nvar At, ue, dt;\nlet _ = (dt = class extends N {\n constructor(t, e) {\n super();\n le(this, At);\n /**\n * @type {Float64Array[]}\n */\n q(this, \"data\");\n if (dt.isMatrix(t))\n he(this, At, ue).call(this, t.rows, t.columns), dt.copy(t, this);\n else if (Number.isInteger(t) && t >= 0)\n he(this, At, ue).call(this, t, e);\n else if (st.isAnyArray(t)) {\n const n = t;\n if (t = n.length, e = t ? n[0].length : 0, typeof e != \"number\")\n throw new TypeError(\n \"Data must be a 2D array with at least one element\"\n );\n this.data = [];\n for (let i = 0; i < t; i++) {\n if (n[i].length !== e)\n throw new RangeError(\"Inconsistent array dimensions\");\n if (!Vs(n[i]))\n throw new TypeError(\"Input data contains non-numeric values\");\n this.data.push(Float64Array.from(n[i]));\n }\n this.rows = t, this.columns = e;\n } else\n throw new TypeError(\n \"First argument must be a positive number or an array\"\n );\n }\n set(t, e, n) {\n return this.data[t][e] = n, this;\n }\n get(t, e) {\n return this.data[t][e];\n }\n removeRow(t) {\n return ot(this, t), this.data.splice(t, 1), this.rows -= 1, this;\n }\n addRow(t, e) {\n return e === void 0 && (e = t, t = this.rows), ot(this, t, !0), e = Float64Array.from(Pt(this, e)), this.data.splice(t, 0, e), this.rows += 1, this;\n }\n removeColumn(t) {\n lt(this, t);\n for (let e = 0; e < this.rows; e++) {\n const n = new Float64Array(this.columns - 1);\n for (let i = 0; i < t; i++)\n n[i] = this.data[e][i];\n for (let i = t + 1; i < this.columns; i++)\n n[i - 1] = this.data[e][i];\n this.data[e] = n;\n }\n return this.columns -= 1, this;\n }\n addColumn(t, e) {\n typeof e > \"u\" && (e = t, t = this.columns), lt(this, t, !0), e = bt(this, e);\n for (let n = 0; n < this.rows; n++) {\n const i = new Float64Array(this.columns + 1);\n let o = 0;\n for (; o < t; o++)\n i[o] = this.data[n][o];\n for (i[o++] = e[n]; o < this.columns + 1; o++)\n i[o] = this.data[n][o - 1];\n this.data[n] = i;\n }\n return this.columns += 1, this;\n }\n}, At = new WeakSet(), /**\n * Init an empty matrix\n * @param {number} nRows\n * @param {number} nColumns\n */\nue = function(t, e) {\n if (this.data = [], Number.isInteger(e) && e >= 0)\n for (let n = 0; n < t; n++)\n this.data.push(new Float64Array(e));\n else\n throw new TypeError(\"nColumns must be a positive integer\");\n this.rows = t, this.columns = e;\n}, dt);\nys(N, _);\nvar K;\nconst Jt = class Jt extends N {\n /**\n * @param {number | AbstractMatrix | ArrayLike<ArrayLike<number>>} diagonalSize\n * @return {this}\n */\n constructor(t) {\n super();\n /** @type {Matrix} */\n le(this, K);\n if (_.isMatrix(t)) {\n if (!t.isSymmetric())\n throw new TypeError(\"not symmetric data\");\n Dt(this, K, _.copy(\n t,\n new _(t.rows, t.rows)\n ));\n } else if (Number.isInteger(t) && t >= 0)\n Dt(this, K, new _(t, t));\n else if (Dt(this, K, new _(t)), !this.isSymmetric())\n throw new TypeError(\"not symmetric data\");\n }\n get size() {\n return ht(this, K).size;\n }\n get rows() {\n return ht(this, K).rows;\n }\n get columns() {\n return ht(this, K).columns;\n }\n get diagonalSize() {\n return this.rows;\n }\n /**\n * not the same as matrix.isSymmetric()\n * Here is to check if it's instanceof SymmetricMatrix without bundling issues\n *\n * @param value\n * @returns {boolean}\n */\n static isSymmetricMatrix(t) {\n return _.isMatrix(t) && t.klassType === \"SymmetricMatrix\";\n }\n /**\n * @param diagonalSize\n * @return {SymmetricMatrix}\n */\n static zeros(t) {\n return new this(t);\n }\n /**\n * @param diagonalSize\n * @return {SymmetricMatrix}\n */\n static ones(t) {\n return new this(t).fill(1);\n }\n clone() {\n const t = new Jt(this.diagonalSize);\n for (const [e, n, i] of this.upperRightEntries())\n t.set(e, n, i);\n return t;\n }\n toMatrix() {\n return new _(this);\n }\n get(t, e) {\n return ht(this, K).get(t, e);\n }\n set(t, e, n) {\n return ht(this, K).set(t, e, n), ht(this, K).set(e, t, n), this;\n }\n removeCross(t) {\n return ht(this, K).removeRow(t), ht(this, K).removeColumn(t), this;\n }\n addCross(t, e) {\n e === void 0 && (e = t, t = this.diagonalSize);\n const n = e.slice();\n return n.splice(t, 1), ht(this, K).addRow(t, n), ht(this, K).addColumn(t, e), this;\n }\n /**\n * @param {Mask[]} mask\n */\n applyMask(t) {\n if (t.length !== this.diagonalSize)\n throw new RangeError(\"Mask size do not match with matrix size\");\n const e = [];\n for (const [n, i] of t.entries())\n i || e.push(n);\n e.reverse();\n for (const n of e)\n this.removeCross(n);\n return this;\n }\n /**\n * Compact format upper-right corner of matrix\n * iterate from left to right, from top to bottom.\n *\n * ```\n * A B C D\n * A 1 2 3 4\n * B 2 5 6 7\n * C 3 6 8 9\n * D 4 7 9 10\n * ```\n *\n * will return compact 1D array `[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]`\n *\n * length is S(i=0, n=sideSize) => 10 for a 4 sideSized matrix\n *\n * @returns {number[]}\n */\n toCompact() {\n const { diagonalSize: t } = this, e = new Array(t * (t + 1) / 2);\n for (let n = 0, i = 0, o = 0; o < e.length; o++)\n e[o] = this.get(i, n), ++n >= t && (n = ++i);\n return e;\n }\n /**\n * @param {number[]} compact\n * @return {SymmetricMatrix}\n */\n static fromCompact(t) {\n const e = t.length, n = (Math.sqrt(8 * e + 1) - 1) / 2;\n if (!Number.isInteger(n))\n throw new TypeError(\n `This array is not a compact representation of a Symmetric Matrix, ${JSON.stringify(\n t\n )}`\n );\n const i = new Jt(n);\n for (let o = 0, l = 0, h = 0; h < e; h++)\n i.set(o, l, t[h]), ++o >= n && (o = ++l);\n return i;\n }\n /**\n * half iterator upper-right-corner from left to right, from top to bottom\n * yield [row, column, value]\n *\n * @returns {Generator<[number, number, number], void, void>}\n */\n *upperRightEntries() {\n for (let t = 0, e = 0; t < this.diagonalSize; void 0) {\n const n = this.get(t, e);\n yield [t, e, n], ++e >= this.diagonalSize && (e = ++t);\n }\n }\n /**\n * half iterator upper-right-corner from left to right, from top to bottom\n * yield value\n *\n * @returns {Generator<[number, number, number], void, void>}\n */\n *upperRightValues() {\n for (let t = 0, e = 0; t < this.diagonalSize; void 0)\n yield this.get(t, e), ++e >= this.diagonalSize && (e = ++t);\n }\n};\nK = new WeakMap();\nlet pt = Jt;\npt.prototype.klassType = \"SymmetricMatrix\";\nclass te extends pt {\n /**\n * not the same as matrix.isSymmetric()\n * Here is to check if it's instanceof SymmetricMatrix without bundling issues\n *\n * @param value\n * @returns {boolean}\n */\n static isDistanceMatrix(s) {\n return pt.isSymmetricMatrix(s) && s.klassSubType === \"DistanceMatrix\";\n }\n constructor(s) {\n if (super(s), !this.isDistance())\n throw new TypeError(\"Provided arguments do no produce a distance matrix\");\n }\n set(s, t, e) {\n return s === t && (e = 0), super.set(s, t, e);\n }\n addCross(s, t) {\n return t === void 0 && (t = s, s = this.diagonalSize), t = t.slice(), t[s] = 0, super.addCross(s, t);\n }\n toSymmetricMatrix() {\n return new pt(this);\n }\n clone() {\n const s = new te(this.diagonalSize);\n for (const [t, e, n] of this.upperRightEntries())\n t !== e && s.set(t, e, n);\n return s;\n }\n /**\n * Compact format upper-right corner of matrix\n * no diagonal (only zeros)\n * iterable from left to right, from top to bottom.\n *\n * ```\n * A B C D\n * A 0 1 2 3\n * B 1 0 4 5\n * C 2 4 0 6\n * D 3 5 6 0\n * ```\n *\n * will return compact 1D array `[1, 2, 3, 4, 5, 6]`\n *\n * length is S(i=0, n=sideSize-1) => 6 for a 4 side sized matrix\n *\n * @returns {number[]}\n */\n toCompact() {\n const { diagonalSize: s } = this, t = (s - 1) * s / 2, e = new Array(t);\n for (let n = 1, i = 0, o = 0; o < e.length; o++)\n e[o] = this.get(i, n), ++n >= s && (n = ++i + 1);\n return e;\n }\n /**\n * @param {number[]} compact\n */\n static fromCompact(s) {\n const t = s.length;\n if (t === 0)\n return new this(0);\n const e = (Math.sqrt(8 * t + 1) + 1) / 2;\n if (!Number.isInteger(e))\n throw new TypeError(\n `This array is not a compact representation of a DistanceMatrix, ${JSON.stringify(\n s\n )}`\n );\n const n = new this(e);\n for (let i = 1, o = 0, l = 0; l < t; l++)\n n.set(i, o, s[l]), ++i >= e && (i = ++o + 1);\n return n;\n }\n}\nte.prototype.klassSubType = \"DistanceMatrix\";\nclass ft extends N {\n constructor(s, t, e) {\n super(), this.matrix = s, this.rows = t, this.columns = e;\n }\n}\nclass $s extends ft {\n constructor(s, t) {\n lt(s, t), super(s, s.rows, 1), this.column = t;\n }\n set(s, t, e) {\n return this.matrix.set(s, this.column, e), this;\n }\n get(s) {\n return this.matrix.get(s, this.column);\n }\n}\nclass Ls extends ft {\n constructor(s, t) {\n we(s, t), super(s, s.rows, t.length), this.columnIndices = t;\n }\n set(s, t, e) {\n return this.matrix.set(s, this.columnIndices[t], e), this;\n }\n get(s, t) {\n return this.matrix.get(s, this.columnIndices[t]);\n }\n}\nclass Ds extends ft {\n constructor(s) {\n super(s, s.rows, s.columns);\n }\n set(s, t, e) {\n return this.matrix.set(s, this.columns - t - 1, e), this;\n }\n get(s, t) {\n return this.matrix.get(s, this.columns - t - 1);\n }\n}\nclass Os extends ft {\n constructor(s) {\n super(s, s.rows, s.columns);\n }\n set(s, t, e) {\n return this.matrix.set(this.rows - s - 1, t, e), this;\n }\n get(s, t) {\n return this.matrix.get(this.rows - s - 1, t);\n }\n}\nclass Bs extends ft {\n constructor(s, t) {\n ot(s, t), super(s, 1, s.columns), this.row = t;\n }\n set(s, t, e) {\n return this.matrix.set(this.row, t, e), this;\n }\n get(s, t) {\n return this.matrix.get(this.row, t);\n }\n}\nclass zs extends ft {\n constructor(s, t) {\n ge(s, t), super(s, t.length, s.columns), this.rowIndices = t;\n }\n set(s, t, e) {\n return this.matrix.set(this.rowIndices[s], t, e), this;\n }\n get(s, t) {\n return this.matrix.get(this.rowIndices[s], t);\n }\n}\nclass Gt extends ft {\n constructor(s, t, e) {\n ge(s, t), we(s, e), super(s, t.length, e.length), this.rowIndices = t, this.columnIndices = e;\n }\n set(s, t, e) {\n return this.matrix.set(\n this.rowIndices[s],\n this.columnIndices[t],\n e\n ), this;\n }\n get(s, t) {\n return this.matrix.get(\n this.rowIndices[s],\n this.columnIndices[t]\n );\n }\n}\nclass Us extends ft {\n constructor(s, t, e, n, i) {\n ae(s, t, e, n, i), super(s, e - t + 1, i - n + 1), this.startRow = t, this.startColumn = n;\n }\n set(s, t, e) {\n return this.matrix.set(\n this.startRow + s,\n this.startColumn + t,\n e\n ), this;\n }\n get(s, t) {\n return this.matrix.get(\n this.startRow + s,\n this.startColumn + t\n );\n }\n}\nclass Ys extends ft {\n constructor(s) {\n super(s, s.columns, s.rows);\n }\n set(s, t, e) {\n return this.matrix.set(t, s, e), this;\n }\n get(s, t) {\n return this.matrix.get(t, s);\n }\n}\nclass Be extends N {\n constructor(s, t = {}) {\n const { rows: e = 1 } = t;\n if (s.length % e !== 0)\n throw new Error(\"the data length is not divisible by the number of rows\");\n super(), this.rows = e, this.columns = s.length / e, this.data = s;\n }\n set(s, t, e) {\n let n = this._calculateIndex(s, t);\n return this.data[n] = e, this;\n }\n get(s, t) {\n let e = this._calculateIndex(s, t);\n return this.data[e];\n }\n _calculateIndex(s, t) {\n return s * this.columns + t;\n }\n}\nclass rt extends N {\n constructor(s) {\n super(), this.data = s, this.rows = s.length, this.columns = s[0].length;\n }\n set(s, t, e) {\n return this.data[s][t] = e, this;\n }\n get(s, t) {\n return this.data[s][t];\n }\n}\nfunction Ws(r, s) {\n if (st.isAnyArray(r))\n return r[0] && st.isAnyArray(r[0]) ? new rt(r) : new Be(r, s);\n throw new Error(\"the argument is not an array\");\n}\nclass ee {\n constructor(s) {\n s = rt.checkMatrix(s);\n let t = s.clone(), e = t.rows, n = t.columns, i = new Float64Array(e), o = 1, l, h, a, u, c, g, d, w, p;\n for (l = 0; l < e; l++)\n i[l] = l;\n for (w = new Float64Array(e), h = 0; h < n; h++) {\n for (l = 0; l < e; l++)\n w[l] = t.get(l, h);\n for (l = 0; l < e; l++) {\n for (p = Math.min(l, h), c = 0, a = 0; a < p; a++)\n c += t.get(l, a) * w[a];\n w[l] -= c, t.set(l, h, w[l]);\n }\n for (u = h, l = h + 1; l < e; l++)\n Math.abs(w[l]) > Math.abs(w[u]) && (u = l);\n if (u !== h) {\n for (a = 0; a < n; a++)\n g = t.get(u, a), t.set(u, a, t.get(h, a)), t.set(h, a, g);\n d = i[u], i[u] = i[h], i[h] = d, o = -o;\n }\n if (h < e && t.get(h, h) !== 0)\n for (l = h + 1; l < e; l++)\n t.set(l, h, t.get(l, h) / t.get(h, h));\n }\n this.LU = t, this.pivotVector = i, this.pivotSign = o;\n }\n isSingular() {\n let s = this.LU, t = s.columns;\n for (let e = 0; e < t; e++)\n if (s.get(e, e) === 0)\n return !0;\n return !1;\n }\n solve(s) {\n s = _.checkMatrix(s);\n let t = this.LU;\n if (t.rows !== s.rows)\n throw new Error(\"Invalid matrix dimensions\");\n if (this.isSingular())\n throw new Error(\"LU matrix is singular\");\n let n = s.columns, i = s.subMatrixRow(this.pivotVector, 0, n - 1), o = t.columns, l, h, a;\n for (a = 0; a < o; a++)\n for (l = a + 1; l < o; l++)\n for (h = 0; h < n; h++)\n i.set(l, h, i.get(l, h) - i.get(a, h) * t.get(l, a));\n for (a = o - 1; a >= 0; a--) {\n for (h = 0; h < n; h++)\n i.set(a, h, i.get(a, h) / t.get(a, a));\n for (l = 0; l < a; l++)\n for (h = 0; h < n; h++)\n i.set(l, h, i.get(l, h) - i.get(a, h) * t.get(l, a));\n }\n return i;\n }\n get determinant() {\n let s = this.LU;\n if (!s.isSquare())\n throw new Error(\"Matrix must be square\");\n let t = this.pivotSign, e = s.columns;\n for (let n = 0; n < e; n++)\n t *= s.get(n, n);\n return t;\n }\n get lowerTriangularMatrix() {\n let s = this.LU, t = s.rows, e = s.columns, n = new _(t, e);\n for (let i = 0; i < t; i++)\n for (let o = 0; o < e; o++)\n i > o ? n.set(i, o, s.get(i, o)) : i === o ? n.set(i, o, 1) : n.set(i, o, 0);\n return n;\n }\n get upperTriangularMatrix() {\n let s = this.LU, t = s.rows, e = s.columns, n = new _(t, e);\n for (let i = 0; i < t; i++)\n for (let o = 0; o < e; o++)\n i <= o ? n.set(i, o, s.get(i, o)) : n.set(i, o, 0);\n return n;\n }\n get pivotPermutationVector() {\n return Array.from(this.pivotVector);\n }\n}\nfunction ut(r, s) {\n let t = 0;\n return Math.abs(r) > Math.abs(s) ? (t = s / r, Math.abs(r) * Math.sqrt(1 + t * t)) : s !== 0 ? (t = r / s, Math.abs(s) * Math.sqrt(1 + t * t)) : 0;\n}\nclass pe {\n constructor(s) {\n s = rt.checkMatrix(s);\n let t = s.clone(), e = s.rows, n = s.columns, i = new Float64Array(n), o, l, h, a;\n for (h = 0; h < n; h++) {\n let u = 0;\n for (o = h; o < e; o++)\n u = ut(u, t.get(o, h));\n if (u !== 0) {\n for (t.get(h, h) < 0 && (u = -u), o = h; o < e; o++)\n t.set(o, h, t.get(o, h) / u);\n for (t.set(h, h, t.get(h, h) + 1), l = h + 1; l < n; l++) {\n for (a = 0, o = h; o < e; o++)\n a += t.get(o, h) * t.get(o, l);\n for (a = -a / t.get(h, h), o = h; o < e; o++)\n t.set(o, l, t.get(o, l) + a * t.get(o, h));\n }\n }\n i[h] = -u;\n }\n this.QR = t, this.Rdiag = i;\n }\n solve(s) {\n s = _.checkMatrix(s);\n let t = this.QR, e = t.rows;\n if (s.rows !== e)\n throw new Error(\"Matrix row dimensions must agree\");\n if (!this.isFullRank())\n throw new Error(\"Matrix is rank deficient\");\n let n = s.columns, i = s.clone(), o = t.columns, l, h, a, u;\n for (a = 0; a < o; a++)\n for (h = 0; h < n; h++) {\n for (u = 0, l = a; l < e; l++)\n u += t.get(l, a) * i.get(l, h);\n for (u = -u / t.get(a, a), l = a; l < e; l++)\n i.set(l, h, i.get(l, h) + u * t.get(l, a));\n }\n for (a = o - 1; a >= 0; a--) {\n for (h = 0; h < n; h++)\n i.set(a, h, i.get(a, h) / this.Rdiag[a]);\n for (l = 0; l < a; l++)\n for (h = 0; h < n; h++)\n i.set(l, h, i.get(l, h) - i.get(a, h) * t.get(l, a));\n }\n return i.subMatrix(0, o - 1, 0, n - 1);\n }\n isFullRank() {\n let s = this.QR.columns;\n for (let t = 0; t < s; t++)\n if (this.Rdiag[t] === 0)\n return !1;\n return !0;\n }\n get upperTriangularMatrix() {\n let s = this.QR, t = s.columns, e = new _(t, t), n, i;\n for (n = 0; n < t; n++)\n for (i = 0; i < t; i++)\n n < i ? e.set(n, i, s.get(n, i)) : n === i ? e.set(n, i, this.Rdiag[n]) : e.set(n, i, 0);\n return e;\n }\n get orthogonalMatrix() {\n let s = this.QR, t = s.rows, e = s.columns, n = new _(t, e), i, o, l, h;\n for (l = e - 1; l >= 0; l--) {\n for (i = 0; i < t; i++)\n n.set(i, l, 0);\n for (n.set(l, l, 1), o = l; o < e; o++)\n if (s.get(l, l) !== 0) {\n for (h = 0, i = l; i < t; i++)\n h += s.get(i, l) * n.get(i, o);\n for (h = -h / s.get(l, l), i = l; i < t; i++)\n n.set(i, o, n.get(i, o) + h * s.get(i, l));\n }\n }\n return n;\n }\n}\nclass vt {\n constructor(s, t = {}) {\n if (s = rt.checkMatrix(s), s.isEmpty())\n throw new Error(\"Matrix must be non-empty\");\n let e = s.rows, n = s.columns;\n const {\n computeLeftSingularVectors: i = !0,\n computeRightSingularVectors: o = !0,\n autoTranspose: l = !1\n } = t;\n let h = !!i, a = !!o, u = !1, c;\n if (e < n)\n if (!l)\n c = s.clone(), console.warn(\n \"Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose\"\n );\n else {\n c = s.transpose(), e = c.rows, n = c.columns, u = !0;\n let m = h;\n h = a, a = m;\n }\n else\n c = s.clone();\n let g = Math.min(e, n), d = Math.min(e + 1, n), w = new Float64Array(d), p = new _(e, g), P = new _(n, n), f = new Float64Array(n), y = new Float64Array(e), E = new Float64Array(d);\n for (let m = 0; m < d; m++) E[m] = m;\n let R = Math.min(e - 1, n), v = Math.max(0, Math.min(n - 2, e)), L = Math.max(R, v);\n for (let m = 0; m < L; m++) {\n if (m < R) {\n w[m] = 0;\n for (let b = m; b < e; b++)\n w[m] = ut(w[m], c.get(b, m));\n if (w[m] !== 0) {\n c.get(m, m) < 0 && (w[m] = -w[m]);\n for (let b = m; b < e; b++)\n c.set(b, m, c.get(b, m) / w[m]);\n c.set(m, m, c.get(m, m) + 1);\n }\n w[m] = -w[m];\n }\n for (let b = m + 1; b < n; b++) {\n if (m < R && w[m] !== 0) {\n let j = 0;\n for (let M = m; M < e; M++)\n j += c.get(M, m) * c.get(M, b);\n j = -j / c.get(m, m);\n for (let M = m; M < e; M++)\n c.set(M, b, c.get(M, b) + j * c.get(M, m));\n }\n f[b] = c.get(m, b);\n }\n if (h && m < R)\n for (let b = m; b < e; b++)\n p.set(b, m, c.get(b, m));\n if (m < v) {\n f[m] = 0;\n for (let b = m + 1; b < n; b++)\n f[m] = ut(f[m], f[b]);\n if (f[m] !== 0) {\n f[m + 1] < 0 && (f[m] = 0 - f[m]);\n for (let b = m + 1; b < n; b++)\n f[b] /= f[m];\n f[m + 1] += 1;\n }\n if (f[m] = -f[m], m + 1 < e && f[m] !== 0) {\n for (let b = m + 1; b < e; b++)\n y[b] = 0;\n for (let b = m + 1; b < e; b++)\n for (let j = m + 1; j < n; j++)\n y[b] += f[j] * c.get(b, j);\n for (let b = m + 1; b < n; b++) {\n let j = -f[b] / f[m + 1];\n for (let M = m + 1; M < e; M++)\n c.set(M, b, c.get(M, b) + j * y[M]);\n }\n }\n if (a)\n for (let b = m + 1; b < n; b++)\n P.set(b, m, f[b]);\n }\n }\n let S = Math.min(n, e + 1);\n if (R < n && (w[R] = c.get(R, R)), e < S && (w[S - 1] = 0), v + 1 < S && (f[v] = c.get(v, S - 1)), f[S - 1] = 0, h) {\n for (let m = R; m < g; m++) {\n for (let b = 0; b < e; b++)\n p.set(b, m, 0);\n p.set(m, m, 1);\n }\n for (let m = R - 1; m >= 0; m--)\n if (w[m] !== 0) {\n for (let b = m + 1; b < g; b++) {\n let j = 0;\n for (let M = m; M < e; M++)\n j += p.get(M, m) * p.get(M, b);\n j = -j / p.get(m, m);\n for (let M = m; M < e; M++)\n p.set(M, b, p.get(M, b) + j * p.get(M, m));\n }\n for (let b = m; b < e; b++)\n p.set(b, m, -p.get(b, m));\n p.set(m, m, 1 + p.get(m, m));\n for (let b = 0; b < m - 1; b++)\n p.set(b, m, 0);\n } else {\n for (let b = 0; b < e; b++)\n p.set(b, m, 0);\n p.set(m, m, 1);\n }\n }\n if (a)\n for (let m = n - 1; m >= 0; m--) {\n if (m < v && f[m] !== 0)\n for (let b = m + 1; b < n; b++) {\n let j = 0;\n for (let M = m + 1; M < n; M++)\n j += P.get(M, m) * P.get(M, b);\n j = -j / P.get(m + 1, m);\n for (let M = m + 1; M < n; M++)\n P.set(M, b, P.get(M, b) + j * P.get(M, m));\n }\n for (let b = 0; b < n; b++)\n P.set(b, m, 0);\n P.set(m, m, 1);\n }\n let k = S - 1, D = Number.EPSILON;\n for (; S > 0; ) {\n let m, b;\n for (m = S - 2; m >= -1 && m !== -1; m--) {\n const j = Number.MIN_VALUE + D * Math.abs(w[m] + Math.abs(w[m + 1]));\n if (Math.abs(f[m]) <= j || Number.isNaN(f[m])) {\n f[m] = 0;\n break;\n }\n }\n if (m === S - 2)\n b = 4;\n else {\n let j;\n for (j = S - 1; j >= m && j !== m; j--) {\n let M = (j !== S ? Math.abs(f[j]) : 0) + (j !== m + 1 ? Math.abs(f[j - 1]) : 0);\n if (Math.abs(w[j]) <= D * M) {\n w[j] = 0;\n break;\n }\n }\n j === m ? b = 3 : j === S - 1 ? b = 1 : (b = 2, m = j);\n }\n switch (m++, b) {\n case 1: {\n let j = f[S - 2];\n f[S - 2] = 0;\n for (let M = S - 2; M >= m; M--) {\n let C = ut(w[M], j), A = w[M] / C, T = j / C;\n if (w[M] = C, M !== m && (j = -T * f[M - 1], f[M - 1] = A * f[M - 1]), a)\n for (let z = 0; z < n; z++)\n C = A * P.get(z, M) + T * P.get(z, S - 1), P.set(z, S - 1, -T * P.get(z, M) + A * P.get(z, S - 1)), P.set(z, M, C);\n }\n break;\n }\n case 2: {\n let j = f[m - 1];\n f[m - 1] = 0;\n for (let M = m; M < S; M++) {\n let C = ut(w[M], j), A = w[M] / C, T = j / C;\n if (w[M] = C, j = -T * f[M], f[M] = A * f[M], h)\n for (let z = 0; z < e; z++)\n C = A * p.get(z, M) + T * p.get(z, m - 1), p.set(z, m - 1, -T * p.get(z, M) + A * p.get(z, m - 1)), p.set(z, M, C);\n }\n break;\n }\n case 3: {\n const j = Math.max(\n Math.abs(w[S - 1]),\n Math.abs(w[S - 2]),\n Math.abs(f[S - 2]),\n Math.abs(w[m]),\n Math.abs(f[m])\n ), M = w[S - 1] / j, C = w[S - 2] / j, A = f[S - 2] / j, T = w[m] / j, z = f[m] / j, F = ((C + M) * (C - M) + A * A) / 2, V = M * A * (M * A);\n let x = 0;\n (F !== 0 || V !== 0) && (F < 0 ? x = 0 - Math.sqrt(F * F + V) : x = Math.sqrt(F * F + V), x = V / (F + x));\n let B = (T + M) * (T - M) + x, U = T * z;\n for (let I = m; I < S - 1; I++) {\n let O = ut(B, U);\n O === 0 && (O = Number.MIN_VALUE);\n let X = B / O, G = U / O;\n if (I !== m && (f[I - 1] = O), B = X * w[I] + G * f[I], f[I] = X * f[I] - G * w[I], U = G * w[I + 1], w[I + 1] = X * w[I + 1], a)\n for (let W = 0; W < n; W++)\n O = X * P.get(W, I) + G * P.get(W, I + 1), P.set(W, I + 1, -G * P.get(W, I) + X * P.get(W, I + 1)), P.set(W, I, O);\n if (O = ut(B, U), O === 0 && (O = Number.MIN_VALUE), X = B / O, G = U / O, w[I] = O, B = X * f[I] + G * w[I + 1], w[I + 1] = -G * f[I] + X * w[I + 1], U = G * f[I + 1], f[I + 1] = X * f[I + 1], h && I < e - 1)\n for (let W = 0; W < e; W++)\n O = X * p.get(W, I) + G * p.get(W, I + 1), p.set(W, I + 1, -G * p.get(W, I) + X * p.get(W, I + 1)), p.set(W, I, O);\n }\n f[S - 2] = B;\n break;\n }\n case 4: {\n if (w[m] <= 0 && (w[m] = w[m] < 0 ? -w[m] : 0, a))\n for (let j = 0; j <= k; j++)\n P.set(j, m, -P.get(j, m));\n for (; m < k && !(w[m] >= w[m + 1]); ) {\n let j = w[m];\n if (w[m] = w[m + 1], w[m + 1] = j, a && m < n - 1)\n for (let M = 0; M < n; M++)\n j = P.get(M, m + 1), P.set(M, m + 1, P.get(M, m)), P.set(M, m, j);\n if (h && m < e - 1)\n for (let M = 0; M < e; M++)\n j = p.get(M, m + 1), p.set(M, m + 1, p.get(M, m)), p.set(M, m, j);\n m++;\n }\n S--;\n break;\n }\n }\n }\n if (u) {\n let m = P;\n P = p, p = m;\n }\n this.m = e, this.n = n, this.s = w, this.U = p, this.V = P;\n }\n solve(s) {\n let t = s, e = this.threshold, n = this.s.length, i = _.zeros(n, n);\n for (let g = 0; g < n; g++)\n Math.abs(this.s[g]) <= e ? i.set(g, g, 0) : i.set(g, g, 1 / this.s[g]);\n let o = this.U, l = this.rightSingularVectors, h = l.mmul(i), a = l.rows, u = o.rows, c = _.zeros(a, u);\n for (let g = 0; g < a; g++)\n for (let d = 0; d < u; d++) {\n let w = 0;\n for (let p = 0; p < n; p++)\n w += h.get(g, p) * o.get(d, p);\n c.set(g, d, w);\n }\n return c.mmul(t);\n }\n solveForDiagonal(s) {\n return this.solve(_.diag(s));\n }\n inverse() {\n let s = this.V, t = this.threshold, e = s.rows, n = s.columns, i = new _(e, this.s.length);\n for (let u = 0; u < e; u++)\n for (let c = 0; c < n; c++)\n Math.abs(this.s[c]) > t && i.set(u, c, s.get(u, c) / this.s[c]);\n let o = this.U, l = o.rows, h = o.columns, a = new _(e, l);\n for (let u = 0; u < e; u++)\n for (let c = 0; c < l; c++) {\n let g = 0;\n for (let d = 0; d < h; d++)\n g += i.get(u, d) * o.get(c, d);\n a.set(u, c, g);\n }\n return a;\n }\n get condition() {\n return this.s[0] / this.s[Math.min(this.m, this.n) - 1];\n }\n get norm2() {\n return this.s[0];\n }\n get rank() {\n let s = Math.max(this.m, this.n) * this.s[0] * Number.EPSILON, t = 0, e = this.s;\n for (let n = 0, i = e.length; n < i; n++)\n e[n] > s && t++;\n return t;\n }\n get diagonal() {\n return Array.from(this.s);\n }\n get threshold() {\n return Number.EPSILON / 2 * Math.max(this.m, this.n) * this.s[0];\n }\n get leftSingularVectors() {\n return this.U;\n }\n get rightSingularVectors() {\n return this.V;\n }\n get diagonalMatrix() {\n return _.diag(this.s);\n }\n}\nfunction Qs(r, s = !1) {\n return r = rt.checkMatrix(r), s ? new vt(r).inverse() : ze(r, _.eye(r.rows));\n}\nfunction ze(r, s, t = !1) {\n return r = rt.checkMatrix(r), s = rt.checkMatrix(s), t ? new vt(r).solve(s) : r.isSquare() ? new ee(r).solve(s) : new pe(r).solve(s);\n}\nfunction Xt(r) {\n if (r = _.checkMatrix(r), r.isSquare()) {\n if (r.columns === 0)\n return 1;\n let s, t, e, n;\n if (r.columns === 2)\n return s = r.get(0, 0), t = r.get(0, 1), e = r.get(1, 0), n = r.get(1, 1), s * n - t * e;\n if (r.columns === 3) {\n let i, o, l;\n return i = new Gt(r, [1, 2], [1, 2]), o = new Gt(r, [1, 2], [0, 2]), l = new Gt(r, [1, 2], [0, 1]), s = r.get(0, 0), t = r.get(0, 1), e = r.get(0, 2), s * Xt(i) - t * Xt(o) + e * Xt(l);\n } else\n return new ee(r).determinant;\n } else\n throw Error(\"determinant can only be calculated for a square matrix\");\n}\nfunction Gs(r, s) {\n let t = [];\n for (let e = 0; e < r; e++)\n e !== s && t.push(e);\n return t;\n}\nfunction Xs(r, s, t, e = 1e-9, n = 1e-9) {\n if (r > n)\n return new Array(s.rows + 1).fill(0);\n {\n let i = s.addRow(t, [0]);\n for (let o = 0; o < i.rows; o++)\n Math.abs(i.get(o, 0)) < e && i.set(o, 0, 0);\n return i.to1DArray();\n }\n}\nfunction Zs(r, s = {}) {\n const { thresholdValue: t = 1e-9, thresholdError: e = 1e-9 } = s;\n r = _.checkMatrix(r);\n let n = r.rows, i = new _(n, n);\n for (let o = 0; o < n; o++) {\n let l = _.columnVector(r.getRow(o)), h = r.subMatrixRow(Gs(n, o)).transpose(), u = new vt(h).solve(l), c = _.sub(l, h.mmul(u)).abs().max();\n i.setRow(\n o,\n Xs(c, u, o, t, e)\n );\n }\n return i;\n}\nfunction Js(r, s = Number.EPSILON) {\n if (r = _.checkMatrix(r), r.isEmpty())\n return r.transpose();\n let t = new vt(r, { autoTranspose: !0 }), e = t.leftSingularVectors, n = t.rightSingularVectors, i = t.diagonal;\n for (let o = 0; o < i.length; o++)\n Math.abs(i[o]) > s ? i[o] = 1 / i[o] : i[o] = 0;\n return n.mmul(_.diag(i).mmul(e.transpose()));\n}\nfunction Ks(r, s = r, t = {}) {\n r = new _(r);\n let e = !1;\n if (typeof s == \"object\" && !_.isMatrix(s) && !st.isAnyArray(s) ? (t = s, s = r, e = !0) : s = new _(s), r.rows !== s.rows)\n throw new TypeError(\"Both matrices must have the same number of rows\");\n const { center: n = !0 } = t;\n n && (r = r.center(\"column\"), e || (s = s.center(\"column\")));\n const i = r.transpose().mmul(s);\n for (let o = 0; o < i.rows; o++)\n for (let l = 0; l < i.columns; l++)\n i.set(o, l, i.get(o, l) * (1 / (r.rows - 1)));\n return i;\n}\nfunction Hs(r, s = r, t = {}) {\n r = new _(r);\n let e = !1;\n if (typeof s == \"object\" && !_.isMatrix(s) && !st.isAnyArray(s) ? (t = s, s = r, e = !0) : s = new _(s), r.rows !== s.rows)\n throw new TypeError(\"Both matrices must have the same number of rows\");\n const { center: n = !0, scale: i = !0 } = t;\n n && (r.center(\"column\"), e || s.center(\"column\")), i && (r.scale(\"column\"), e || s.scale(\"column\"));\n const o = r.standardDeviation(\"column\", { unbiased: !0 }), l = e ? o : s.standardDeviation(\"column\", { unbiased: !0 }), h = r.transpose().mmul(s);\n for (let a = 0; a < h.rows; a++)\n for (let u = 0; u < h.columns; u++)\n h.set(\n a,\n u,\n h.get(a, u) * (1 / (o[a] * l[u])) * (1 / (r.rows - 1))\n );\n return h;\n}\nlet Ue = class {\n constructor(s, t = {}) {\n const { assumeSymmetric: e = !1 } = t;\n if (s = rt.checkMatrix(s), !s.isSquare())\n throw new Error(\"Matrix is not a square matrix\");\n if (s.isEmpty())\n throw new Error(\"Matrix must be non-empty\");\n let n = s.columns, i = new _(n, n), o = new Float64Array(n), l = new Float64Array(n), h = s, a, u, c = !1;\n if (e ? c = !0 : c = s.isSymmetric(), c) {\n for (a = 0; a < n; a++)\n for (u = 0; u < n; u++)\n i.set(a, u, h.get(a, u));\n tn(n, l, o, i), en(n, l, o, i);\n } else {\n let g = new _(n, n), d = new Float64Array(n);\n for (u = 0; u < n; u++)\n for (a = 0; a < n; a++)\n g.set(a, u, h.get(a, u));\n sn(n, g, d, i), nn(n, l, o, i, g);\n }\n this.n = n, this.e = l, this.d = o, this.V = i;\n }\n get realEigenvalues() {\n return Array.from(this.d);\n }\n get imaginaryEigenvalues() {\n return Array.from(this.e);\n }\n get eigenvectorMatrix() {\n return this.V;\n }\n get diagonalMatrix() {\n let s = this.n, t = this.e, e = this.d, n = new _(s, s), i, o;\n for (i = 0; i < s; i++) {\n for (o = 0; o < s; o++)\n n.set(i, o, 0);\n n.set(i, i, e[i]), t[i] > 0 ? n.set(i, i + 1, t[i]) : t[i] < 0 && n.set(i, i - 1, t[i]);\n }\n return n;\n }\n};\nfunction tn(r, s, t, e) {\n let n, i, o, l, h, a, u, c;\n for (h = 0; h < r; h++)\n t[h] = e.get(r - 1, h);\n for (l = r - 1; l > 0; l--) {\n for (c = 0, o = 0, a = 0; a < l; a++)\n c = c + Math.abs(t[a]);\n if (c === 0)\n for (s[l] = t[l - 1], h = 0; h < l; h++)\n t[h] = e.get(l - 1, h), e.set(l, h, 0), e.set(h, l, 0);\n else {\n for (a = 0; a < l; a++)\n t[a] /= c, o += t[a] * t[a];\n for (n = t[l - 1], i = Math.sqrt(o), n > 0 && (i = -i), s[l] = c * i, o = o - n * i, t[l - 1] = n - i, h = 0; h < l; h++)\n s[h] = 0;\n for (h = 0; h < l; h++) {\n for (n = t[h], e.set(h, l, n), i = s[h] + e.get(h, h) * n, a = h + 1; a <= l - 1; a++)\n i += e.get(a, h) * t[a], s[a] += e.get(a, h) * n;\n s[h] = i;\n }\n for (n = 0, h = 0; h < l; h++)\n s[h] /= o, n += s[h] * t[h];\n for (u = n / (o + o), h = 0; h < l; h++)\n s[h] -= u * t[h];\n for (h = 0; h < l; h++) {\n for (n = t[h], i = s[h], a = h; a <= l - 1; a++)\n e.set(a, h, e.get(a, h) - (n * s[a] + i * t[a]));\n t[h] = e.get(l - 1, h), e.set(l, h, 0);\n }\n }\n t[l] = o;\n }\n for (l = 0; l < r - 1; l++) {\n if (e.set(r - 1, l, e.get(l, l)), e.set(l, l, 1), o = t[l + 1], o !== 0) {\n for (a = 0; a <= l; a++)\n t[a] = e.get(a, l + 1) / o;\n for (h = 0; h <= l; h++) {\n for (i = 0, a = 0; a <= l; a++)\n i += e.get(a, l + 1) * e.get(a, h);\n for (a = 0; a <= l; a++)\n e.set(a, h, e.get(a, h) - i * t[a]);\n }\n }\n for (a = 0; a <= l; a++)\n e.set(a, l + 1, 0);\n }\n for (h = 0; h < r; h++)\n t[h] = e.get(r - 1, h), e.set(r - 1, h, 0);\n e.set(r - 1, r - 1, 1), s[0] = 0;\n}\nfunction en(r, s, t, e) {\n let n, i, o, l, h, a, u, c, g, d, w, p, P, f, y, E;\n for (o = 1; o < r; o++)\n s[o - 1] = s[o];\n s[r - 1] = 0;\n let R = 0, v = 0, L = Number.EPSILON;\n for (a = 0; a < r; a++) {\n for (v = Math.max(v, Math.abs(t[a]) + Math.abs(s[a])), u = a; u < r && !(Math.abs(s[u]) <= L * v); )\n u++;\n if (u > a)\n do {\n for (n = t[a], c = (t[a + 1] - n) / (2 * s[a]), g = ut(c, 1), c < 0 && (g = -g), t[a] = s[a] / (c + g), t[a + 1] = s[a] * (c + g), d = t[a + 1], i = n - t[a], o = a + 2; o < r; o++)\n t[o] -= i;\n for (R = R + i, c = t[u], w = 1, p = w, P = w, f = s[a + 1], y = 0, E = 0, o = u - 1; o >= a; o--)\n for (P = p, p = w, E = y, n = w * s[o], i = w * c, g = ut(c, s[o]), s[o + 1] = y * g, y = s[o] / g, w = c / g, c = w * t[o] - y * n, t[o + 1] = i + y * (w * n + y * t[o]), h = 0; h < r; h++)\n i = e.get(h, o + 1), e.set(h, o + 1, y * e.get(h, o) + w * i), e.set(h, o, w * e.get(h, o) - y * i);\n c = -y * E * P * f * s[a] / d, s[a] = y * c, t[a] = w * c;\n } while (Math.abs(s[a]) > L * v);\n t[a] = t[a] + R, s[a] = 0;\n }\n for (o = 0; o < r - 1; o++) {\n for (h = o, c = t[o], l = o + 1; l < r; l++)\n t[l] < c && (h = l, c = t[l]);\n if (h !== o)\n for (t[h] = t[o], t[o] = c, l = 0; l < r; l++)\n c = e.get(l, o), e.set(l, o, e.get(l, h)), e.set(l, h, c);\n }\n}\nfunction sn(r, s, t, e) {\n let n = 0, i = r - 1, o, l, h, a, u, c, g;\n for (c = n + 1; c <= i - 1; c++) {\n for (g = 0, a = c; a <= i; a++)\n g = g + Math.abs(s.get(a, c - 1));\n if (g !== 0) {\n for (h = 0, a = i; a >= c; a--)\n t[a] = s.get(a, c - 1) / g, h += t[a] * t[a];\n for (l = Math.sqrt(h), t[c] > 0 && (l = -l), h = h - t[c] * l, t[c] = t[c] - l, u = c; u < r; u++) {\n for (o = 0, a = i; a >= c; a--)\n o += t[a] * s.get(a, u);\n for (o = o / h, a = c; a <= i; a++)\n s.set(a, u, s.get(a, u) - o * t[a]);\n }\n for (a = 0; a <= i; a++) {\n for (o = 0, u = i; u >= c; u--)\n o += t[u] * s.get(a, u);\n for (o = o / h, u = c; u <= i; u++)\n s.set(a, u, s.get(a, u) - o * t[u]);\n }\n t[c] = g * t[c], s.set(c, c - 1, g * l);\n }\n }\n for (a = 0; a < r; a++)\n for (u = 0; u < r; u++)\n e.set(a, u, a === u ? 1 : 0);\n for (c = i - 1; c >= n + 1; c--)\n if (s.get(c, c - 1) !== 0) {\n for (a = c + 1; a <= i; a++)\n t[a] = s.get(a, c - 1);\n for (u = c; u <= i; u++) {\n for (l = 0, a = c; a <= i; a++)\n l += t[a] * e.get(a, u);\n for (l = l / t[c] / s.get(c, c - 1), a = c; a <= i; a++)\n e.set(a, u, e.get(a, u) + l * t[a]);\n }\n }\n}\nfunction nn(r, s, t, e, n) {\n let i = r - 1, o = 0, l = r - 1, h = Number.EPSILON, a = 0, u = 0, c = 0, g = 0, d = 0, w = 0, p = 0, P = 0, f, y, E, R, v, L, S, k, D, m, b, j, M, C, A;\n for (f = 0; f < r; f++)\n for ((f < o || f > l) && (t[f] = n.get(f, f), s[f] = 0), y = Math.max(f - 1, 0); y < r; y++)\n u = u + Math.abs(n.get(f, y));\n for (; i >= o; ) {\n for (R = i; R > o && (w = Math.abs(n.get(R - 1, R - 1)) + Math.abs(n.get(R, R)), w === 0 && (w = u), !(Math.abs(n.get(R, R - 1)) < h * w)); )\n R--;\n if (R === i)\n n.set(i, i, n.get(i, i) + a), t[i] = n.get(i, i), s[i] = 0, i--, P = 0;\n else if (R === i - 1) {\n if (S = n.get(i, i - 1) * n.get(i - 1, i), c = (n.get(i - 1, i - 1) - n.get(i, i)) / 2, g = c * c + S, p = Math.sqrt(Math.abs(g)), n.set(i, i, n.get(i, i) + a), n.set(i - 1, i - 1, n.get(i - 1, i - 1) + a), k = n.get(i, i), g >= 0) {\n for (p = c >= 0 ? c + p : c - p, t[i - 1] = k + p, t[i] = t[i - 1], p !== 0 && (t[i] = k - S / p), s[i - 1] = 0, s[i] = 0, k = n.get(i, i - 1), w = Math.abs(k) + Math.abs(p), c = k / w, g = p / w, d = Math.sqrt(c * c + g * g), c = c / d, g = g / d, y = i - 1; y < r; y++)\n p = n.get(i - 1, y), n.set(i - 1, y, g * p + c * n.get(i, y)), n.set(i, y, g * n.get(i, y) - c * p);\n for (f = 0; f <= i; f++)\n p = n.get(f, i - 1), n.set(f, i - 1, g * p + c * n.get(f, i)), n.set(f, i, g * n.get(f, i) - c * p);\n for (f = o; f <= l; f++)\n p = e.get(f, i - 1), e.set(f, i - 1, g * p + c * e.get(f, i)), e.set(f, i, g * e.get(f, i) - c * p);\n } else\n t[i - 1] = k + c, t[i] = k + c, s[i - 1] = p, s[i] = -p;\n i = i - 2, P = 0;\n } else {\n if (k = n.get(i, i), D = 0, S = 0, R < i && (D = n.get(i - 1, i - 1), S = n.get(i, i - 1) * n.get(i - 1, i)), P === 10) {\n for (a += k, f = o; f <= i; f++)\n n.set(f, f, n.get(f, f) - k);\n w = Math.abs(n.get(i, i - 1)) + Math.abs(n.get(i - 1, i - 2)), k = D = 0.75 * w, S = -0.4375 * w * w;\n }\n if (P === 30 && (w = (D - k) / 2, w = w * w + S, w > 0)) {\n for (w = Math.sqrt(w), D < k && (w = -w), w = k - S / ((D - k) / 2 + w), f = o; f <= i; f++)\n n.set(f, f, n.get(f, f) - w);\n a += w, k = D = S = 0.964;\n }\n for (P = P + 1, v = i - 2; v >= R && (p = n.get(v, v), d = k - p, w = D - p, c = (d * w - S) / n.get(v + 1, v) + n.get(v, v + 1), g = n.get(v + 1, v + 1) - p - d - w, d = n.get(v + 2, v + 1), w = Math.abs(c) + Math.abs(g) + Math.abs(d), c = c / w, g = g / w, d = d / w, !(v === R || Math.abs(n.get(v, v - 1)) * (Math.abs(g) + Math.abs(d)) < h * (Math.abs(c) * (Math.abs(n.get(v - 1, v - 1)) + Math.abs(p) + Math.abs(n.get(v + 1, v + 1)))))); )\n v--;\n for (f = v + 2; f <= i; f++)\n n.set(f, f - 2, 0), f > v + 2 && n.set(f, f - 3, 0);\n for (E = v; E <= i - 1 && (C = E !== i - 1, E !== v && (c = n.get(E, E - 1), g = n.get(E + 1, E - 1), d = C ? n.get(E + 2, E - 1) : 0, k = Math.abs(c) + Math.abs(g) + Math.abs(d), k !== 0 && (c = c / k, g = g / k, d = d / k)), k !== 0); E++)\n if (w = Math.sqrt(c * c + g * g + d * d), c < 0 && (w = -w), w !== 0) {\n for (E !== v ? n.set(E, E - 1, -w * k) : R !== v && n.set(E, E - 1, -n.get(E, E - 1)), c = c + w, k = c / w, D = g / w, p = d / w, g = g / c, d = d / c, y = E; y < r; y++)\n c = n.get(E, y) + g * n.get(E + 1, y), C && (c = c + d * n.get(E + 2, y), n.set(E + 2, y, n.get(E + 2, y) - c * p)), n.set(E, y, n.get(E, y) - c * k), n.set(E + 1, y, n.get(E + 1, y) - c * D);\n for (f = 0; f <= Math.min(i, E + 3); f++)\n c = k * n.get(f, E) + D * n.get(f, E + 1), C && (c = c + p * n.get(f, E + 2), n.set(f, E + 2, n.get(f, E + 2) - c * d)), n.set(f, E, n.get(f, E) - c), n.set(f, E + 1, n.get(f, E + 1) - c * g);\n for (f = o; f <= l; f++)\n c = k * e.get(f, E) + D * e.get(f, E + 1), C && (c = c + p * e.get(f, E + 2), e.set(f, E + 2, e.get(f, E + 2) - c * d)), e.set(f, E, e.get(f, E) - c), e.set(f, E + 1, e.get(f, E + 1) - c * g);\n }\n }\n }\n if (u !== 0) {\n for (i = r - 1; i >= 0; i--)\n if (c = t[i], g = s[i], g === 0)\n for (R = i, n.set(i, i, 1), f = i - 1; f >= 0; f--) {\n for (S = n.get(f, f) - c, d = 0, y = R; y <= i; y++)\n d = d + n.get(f, y) * n.get(y, i);\n if (s[f] < 0)\n p = S, w = d;\n else if (R = f, s[f] === 0 ? n.set(f, i, S !== 0 ? -d / S : -d / (h * u)) : (k = n.get(f, f + 1), D = n.get(f + 1, f), g = (t[f] - c) * (t[f] - c) + s[f] * s[f], L = (k * w - p * d) / g, n.set(f, i, L), n.set(\n f + 1,\n i,\n Math.abs(k) > Math.abs(p) ? (-d - S * L) / k : (-w - D * L) / p\n )), L = Math.abs(n.get(f, i)), h * L * L > 1)\n for (y = f; y <= i; y++)\n n.set(y, i, n.get(y, i) / L);\n }\n else if (g < 0)\n for (R = i - 1, Math.abs(n.get(i, i - 1)) > Math.abs(n.get(i - 1, i)) ? (n.set(i - 1, i - 1, g / n.get(i, i - 1)), n.set(i - 1, i, -(n.get(i, i) - c) / n.get(i, i - 1))) : (A = Wt(0, -n.get(i - 1, i), n.get(i - 1, i - 1) - c, g), n.set(i - 1, i - 1, A[0]), n.set(i - 1, i, A[1])), n.set(i, i - 1, 0), n.set(i, i, 1), f = i - 2; f >= 0; f--) {\n for (m = 0, b = 0, y = R; y <= i; y++)\n m = m + n.get(f, y) * n.get(y, i - 1), b = b + n.get(f, y) * n.get(y, i);\n if (S = n.get(f, f) - c, s[f] < 0)\n p = S, d = m, w = b;\n else if (R = f, s[f] === 0 ? (A = Wt(-m, -b, S, g), n.set(f, i - 1, A[0]), n.set(f, i, A[1])) : (k = n.get(f, f + 1), D = n.get(f + 1, f), j = (t[f] - c) * (t[f] - c) + s[f] * s[f] - g * g, M = (t[f] - c) * 2 * g, j === 0 && M === 0 && (j = h * u * (Math.abs(S) + Math.abs(g) + Math.abs(k) + Math.abs(D) + Math.abs(p))), A = Wt(\n k * d - p * m + g * b,\n k * w - p * b - g * m,\n j,\n M\n ), n.set(f, i - 1, A[0]), n.set(f, i, A[1]), Math.abs(k) > Math.abs(p) + Math.abs(g) ? (n.set(\n f + 1,\n i - 1,\n (-m - S * n.get(f, i - 1) + g * n.get(f, i)) / k\n ), n.set(\n f + 1,\n i,\n (-b - S * n.get(f, i) - g * n.get(f, i - 1)) / k\n )) : (A = Wt(\n -d - D * n.get(f, i - 1),\n -w - D * n.get(f, i),\n p,\n g\n ), n.set(f + 1, i - 1, A[0]), n.set(f + 1, i, A[1]))), L = Math.max(Math.abs(n.get(f, i - 1)), Math.abs(n.get(f, i))), h * L * L > 1)\n for (y = f; y <= i; y++)\n n.set(y, i - 1, n.get(y, i - 1) / L), n.set(y, i, n.get(y, i) / L);\n }\n for (f = 0; f < r; f++)\n if (f < o || f > l)\n for (y = f; y < r; y++)\n e.set(f, y, n.get(f, y));\n for (y = r - 1; y >= o; y--)\n for (f = o; f <= l; f++) {\n for (p = 0, E = o; E <= Math.min(y, l); E++)\n p = p + e.get(f, E) * n.get(E, y);\n e.set(f, y, p);\n }\n }\n}\nfunction Wt(r, s, t, e) {\n let n, i;\n return Math.abs(t) > Math.abs(e) ? (n = e / t, i = t + n * e, [(r + n * s) / i, (s - n * r) / i]) : (n = t / e, i = e + n * t, [(n * r + s) / i, (n * s - r) / i]);\n}\nclass Ye {\n constructor(s) {\n if (s = rt.checkMatrix(s), !s.isSymmetric())\n throw new Error(\"Matrix is not symmetric\");\n let t = s, e = t.rows, n = new _(e, e), i = !0, o, l, h;\n for (l = 0; l < e; l++) {\n let a = 0;\n for (h = 0; h < l; h++) {\n let u = 0;\n for (o = 0; o < h; o++)\n u += n.get(h, o) * n.get(l, o);\n u = (t.get(l, h) - u) / n.get(h, h), n.set(l, h, u), a = a + u * u;\n }\n for (a = t.get(l, l) - a, i && (i = a > 0), n.set(l, l, Math.sqrt(Math.max(a, 0))), h = l + 1; h < e; h++)\n n.set(l, h, 0);\n }\n this.L = n, this.positiveDefinite = i;\n }\n isPositiveDefinite() {\n return this.positiveDefinite;\n }\n solve(s) {\n s = rt.checkMatrix(s);\n let t = this.L, e = t.rows;\n if (s.rows !== e)\n throw new Error(\"Matrix dimensions do not match\");\n if (this.isPositiveDefinite() === !1)\n throw new Error(\"Matrix is not positive definite\");\n let n = s.columns, i = s.clone(), o, l, h;\n for (h = 0; h < e; h++)\n for (l = 0; l < n; l++) {\n for (o = 0; o < h; o++)\n i.set(h, l, i.get(h, l) - i.get(o, l) * t.get(h, o));\n i.set(h, l, i.get(h, l) / t.get(h, h));\n }\n for (h = e - 1; h >= 0; h--)\n for (l = 0; l < n; l++) {\n for (o = h + 1; o < e; o++)\n i.set(h, l, i.get(h, l) - i.get(o, l) * t.get(o, h));\n i.set(h, l, i.get(h, l) / t.get(h, h));\n }\n return i;\n }\n get lowerTriangularMatrix() {\n return this.L;\n }\n}\nclass We {\n constructor(s, t = {}) {\n s = rt.checkMatrix(s);\n let { Y: e } = t;\n const {\n scaleScores: n = !1,\n maxIterations: i = 1e3,\n terminationCriteria: o = 1e-10\n } = t;\n let l;\n if (e) {\n if (st.isAnyArray(e) && typeof e[0] == \"number\" ? e = _.columnVector(e) : e = rt.checkMatrix(e), e.rows !== s.rows)\n throw new Error(\"Y should have the same number of rows as X\");\n l = e.getColumnVector(0);\n } else\n l = s.getColumnVector(0);\n let h = 1, a, u, c, g;\n for (let d = 0; d < i && h > o; d++)\n c = s.transpose().mmul(l).div(l.transpose().mmul(l).get(0, 0)), c = c.div(c.norm()), a = s.mmul(c).div(c.transpose().mmul(c).get(0, 0)), d > 0 && (h = a.clone().sub(g).pow(2).sum()), g = a.clone(), e ? (u = e.transpose().mmul(a).div(a.transpose().mmul(a).get(0, 0)), u = u.div(u.norm()), l = e.mmul(u).div(u.transpose().mmul(u).get(0, 0))) : l = a;\n if (e) {\n let d = s.transpose().mmul(a).div(a.transpose().mmul(a).get(0, 0));\n d = d.div(d.norm());\n let w = s.clone().sub(a.clone().mmul(d.transpose())), p = l.transpose().mmul(a).div(a.transpose().mmul(a).get(0, 0)), P = e.clone().sub(\n a.clone().mulS(p.get(0, 0)).mmul(u.transpose())\n );\n this.t = a, this.p = d.transpose(), this.w = c.transpose(), this.q = u, this.u = l, this.s = a.transpose().mmul(a), this.xResidual = w, this.yResidual = P, this.betas = p;\n } else\n this.w = c.transpose(), this.s = a.transpose().mmul(a).sqrt(), n ? this.t = a.clone().div(this.s.get(0, 0)) : this.t = a, this.xResidual = s.sub(a.mmul(c.transpose()));\n }\n}\n$.AbstractMatrix = N;\n$.CHO = Ye;\n$.CholeskyDecomposition = Ye;\n$.DistanceMatrix = te;\n$.EVD = Ue;\nvar rn = $.EigenvalueDecomposition = Ue;\n$.LU = ee;\n$.LuDecomposition = ee;\nvar Qe = $.Matrix = _;\n$.MatrixColumnSelectionView = Ls;\n$.MatrixColumnView = $s;\n$.MatrixFlipColumnView = Ds;\n$.MatrixFlipRowView = Os;\n$.MatrixRowSelectionView = zs;\n$.MatrixRowView = Bs;\n$.MatrixSelectionView = Gt;\n$.MatrixSubView = Us;\n$.MatrixTransposeView = Ys;\n$.NIPALS = We;\n$.Nipals = We;\n$.QR = pe;\n$.QrDecomposition = pe;\n$.SVD = vt;\n$.SingularValueDecomposition = vt;\n$.SymmetricMatrix = pt;\n$.WrapperMatrix1D = Be;\n$.WrapperMatrix2D = rt;\n$.correlation = Hs;\n$.covariance = Ks;\nvar Ce = $.default = _;\n$.determinant = Xt;\n$.inverse = Qs;\n$.linearDependencies = Zs;\n$.pseudoInverse = Js;\n$.solve = ze;\n$.wrap = Ws;\nconst on = rn, ln = Qe;\nCe.Matrix && Ce.Matrix;\nfunction qt(r, s, t) {\n const e = r / t, n = s / t;\n if (!(isFinite(e) && isFinite(n))) {\n const h = -r / s;\n return isFinite(h) ? [h] : r == 0 && s == 0 ? [0] : [];\n }\n const i = n * n - 4 * e;\n let o = 0;\n if (isFinite(i)) {\n if (i < 0)\n return [];\n if (i == 0)\n return [-0.5 * n];\n o = -0.5 * (n + kt(Math.sqrt(i), n));\n } else\n o = -n;\n const l = e / o;\n return isFinite(l) ? l > o ? [o, l] : [l, o] : [o];\n}\nfunction Ge(r, s, t, e) {\n const n = t / (3 * e), i = s / (3 * e), o = r / e;\n if (!(isFinite(o) && isFinite(i) && isFinite(n)))\n return qt(r, s, t);\n const l = -n * n + i, h = -i * n + o, a = n * o - i * i, u = 4 * l * a - h * h, c = -2 * n * l + h;\n if (u < 0) {\n const g = Math.sqrt(-0.25 * u), d = -0.5 * c;\n return [Math.cbrt(d + g) + Math.cbrt(d - g) - n];\n } else if (u == 0) {\n const g = kt(Math.sqrt(-l), c);\n return [g - n, -2 * g - n];\n } else {\n const g = Math.atan2(Math.sqrt(u), -c) / 3, d = Math.cos(g), w = Math.sin(g) * Math.sqrt(3), p = 0.5 * (-d + w), P = 0.5 * (-d - w), f = 2 * Math.sqrt(-l);\n return [f * d - n, f * p - n, f * P - n];\n }\n}\nfunction En(r, s, t, e, n) {\n if (n == 0)\n return Ge(r, s, t, e);\n const i = e / n, o = t / n, l = s / n, h = r / n;\n let a = qe(i, o, l, h, !1);\n if (a !== null)\n return a;\n const u = 716e74;\n for (let c = 0; c < 2; c++)\n if (a = qe(\n i / u,\n o / (u * u),\n l / (u * u * u),\n h / (u * u * u * u),\n c != 0\n ), a !== null) {\n for (let g = 0; g < a.length; g++)\n a[g] *= u;\n return a;\n }\n return [];\n}\nfunction gt(r, s) {\n return s == 0 ? Math.abs(r) : Math.abs((r - s) / s);\n}\nfunction qe(r, s, t, e, n) {\n const i = hn(r, s, t, e, n);\n if (i !== null && i.length == 4) {\n let o = [];\n for (let l = 0; l < 2; l++) {\n const h = i[l * 2], a = i[l * 2 + 1];\n o = o.concat(qt(a, h, 1));\n }\n return o;\n }\n return null;\n}\nfunction hn(r, s, t, e, n) {\n function i(F, V, x, B) {\n const U = gt(F + x, r), I = gt(V + F * x + B, s), O = gt(V * x + F * B, t);\n return U + I + O;\n }\n function o(F, V, x, B) {\n return i(F, V, x, B) + gt(V * B, e);\n }\n const l = 9 * r * r - 24 * s, h = l >= 0 ? -2 * s / (3 * r + kt(Math.sqrt(l), r)) : -0.25 * r, a = r + 4 * h, u = s + 3 * h * (r + 2 * h), c = t + h * (2 * s + h * (3 * r + 4 * h)), g = e + h * (t + h * (s + h * (r + h)));\n let d = 0, w = 0;\n const p = 349e100;\n if (n) {\n const F = a / p, V = u / p, x = c / p, B = g / p;\n d = F * x - 4 / p * B - 1 / 3 * V * V, w = (F * x - 8 / p * B - 2 / 9 * V * V) * (1 / 3) * V - x * (x / p) - F * F * B;\n } else\n d = a * c - 4 * g - 1 / 3 * u * u, w = (a * c + 8 * g - 2 / 9 * u * u) * (1 / 3) * u - c * c - a * a * g;\n if (!isFinite(d) && isFinite(w))\n return null;\n let P = an(d, w);\n n && (P *= p);\n const f = r * 0.5, y = 1 / 6 * s + 0.5 * P, E = t - r * y, R = 2 / 3 * s - P - f * f, v = 0.5 * E / R, L = 2 * (e - y * y) / E, S = 0.5 * E / L;\n let k = 0, D = 0, m = 0;\n for (let F = 0; F < 3; F++) {\n const V = F == 1 ? S : R, x = F == 0 ? v : L, B = gt(V + f * f + 2 * y, s), U = gt(2 * (V * x + f * y), t), I = gt(V * x * x + y * y, e), O = B + U + I;\n (F == 0 || O < m) && (k = V, D = x, m = O);\n }\n const b = k, j = D;\n let M = 0, C = 0, A = 0, T = 0;\n if (b < 0) {\n const F = Math.sqrt(-b);\n if (M = f + F, C = y + F * j, A = f - F, T = y - F * j, Math.abs(T) < Math.abs(C) ? T = e / C : Math.abs(T) > Math.abs(C) && (C = e / T), Math.abs(M) != Math.abs(A)) {\n let V = null, x = null;\n if (Math.abs(M) < Math.abs(A)) {\n const U = (t - C * A) / T, I = (s - T - C) / A;\n V = [r - A, U, I], x = [A, A, A];\n } else {\n const U = (t - M * T) / C, I = (s - T - C) / M, O = r - M;\n V = [M, M, M], x = [O, U, I];\n }\n let B = 0;\n for (let U = 0; U < 3; U++) {\n const I = V[U], O = x[U];\n if (isFinite(I) && isFinite(O)) {\n const X = i(I, C, O, T);\n (U == 0 || X < B) && (M = I, A = O, B = X);\n }\n }\n }\n } else if (b == 0) {\n const F = e - y * y;\n M = f, C = y + Math.sqrt(-F), A = f, T = y - Math.sqrt(-F), Math.abs(C) > Math.abs(T) ? T = e / C : Math.abs(T) > Math.abs(C) && (C = e / T);\n } else\n return [];\n let z = o(M, C, A, T);\n for (let F = 0; F < 8 && z != 0; F++) {\n const V = C * T - e, x = C * A + M * T - t, B = C + M * A + T - s, U = M + A - r, I = M - A, O = C * C - C * (A * I + 2 * T) + T * (M * I + T);\n if (O == 0)\n break;\n const X = 1 / O, G = T - C, W = C * A - M * T, se = I * V + G * x + W * B - (C * G + M * W) * U, ne = (M * I + G) * V - C * (I * x + G * B + W * U), ie = -I * V - G * x - W * B + (A * W + T * G) * U, re = -(A * I + G) * V + T * (I * x + G * B + W * U), xt = M - X * se, Nt = C - X * ne, Vt = A - X * ie, $t = T - X * re, Lt = o(xt, Nt, Vt, $t);\n if (Lt < z)\n M = xt, C = Nt, A = Vt, T = $t, z = Lt;\n else\n break;\n }\n return [M, C, A, T];\n}\nfunction an(r, s) {\n const t = -0.3333333333333333 * r, e = 0.5 * s;\n let n, i = null;\n if ((Math.abs(t) >= 1e102 || Math.abs(e) >= 1e164) && (Math.abs(t) < Math.abs(e) ? i = 1 - t * (t / e) * (t / e) : i = Math.sign(t) * (e / t * (e / t) / t - 1)), i !== null && e == 0)\n r > 0 ? n = 0 : n = Math.sqrt(-r);\n else if (i !== null ? i < 0 : e * e < t * t * t) {\n const a = i !== null ? e / t / Math.sqrt(t) : e / Math.sqrt(t * t * t);\n n = -2 * Math.sqrt(t) * kt(Math.cos(Math.acos(Math.abs(a)) * (1 / 3)), a);\n } else {\n let a;\n i !== null ? Math.abs(t) < Math.abs(e) ? a = -e * (1 + Math.sqrt(i)) : a = -e - kt(Math.sqrt(Math.abs(t)) * t * Math.sqrt(i), e) : a = Math.cbrt(-e - kt(Math.sqrt(e * e - t * t * t), e));\n const u = a == 0 ? 0 : t / a;\n n = a + u;\n }\n let o = n, l = (o * o + r) * o + s;\n if (Math.abs(l) < 222045e-21 * Math.max(o * o * o, r * o, s))\n return o;\n for (let a = 0; a < 8; a++) {\n const u = 3 * o * o + r;\n if (u == 0)\n break;\n const c = o - l / u, g = (c * c + r) * c + s;\n if (g == 0)\n return c;\n if (Math.abs(g) >= Math.abs(l))\n break;\n o = c, l = g;\n }\n return o;\n}\nfunction kt(r, s) {\n const t = Math.abs(r);\n return s < 0 ? -t : t;\n}\nfunction un(r, s = 1e-9) {\n if (r[r.length - 1] == 0)\n return un(r.slice(0, -1), s);\n const t = new ln([\n r.slice(0, -1).reverse().map((n) => -n / r[r.length - 1]),\n ...Array.from({ length: r.length - 2 }, (n, i) => {\n const o = new Array(r.length - 1).fill(0);\n return o[i] = 1, o;\n })\n ]), e = new on(t);\n return e.realEigenvalues.filter(\n (n, i) => Math.abs(e.imaginaryEigenvalues[i]) < s\n );\n}\nconst cn = (r, s, t) => [r[0] * (1 - t) + s[0] * t, r[1] * (1 - t) + s[1] * t];\nfunction fn(r) {\n const s = [];\n for (let t = 0; t < r.length - 1; t++)\n s.push([r[t], r[t + 1]]);\n return s;\n}\nfunction de(r, s) {\n const t = fn(r).map(([e, n]) => cn(e, n, s));\n return r.length === 2 ? [t] : [...de(t, s), t];\n}\nconst Ae = Symbol.for(\"pantograph:CubicBezier\");\nclass Et extends Ft {\n constructor(t, e, n, i) {\n super(t, e);\n q(this, \"segmentType\", \"CUBIC_BEZIER\");\n q(this, \"firstControlPoint\");\n q(this, \"lastControlPoint\");\n q(this, \"_boundingBox\", null);\n q(this, \"_polynomialCoefficients\", null);\n Object.defineProperty(this, Ae, { value: !0 }), this.firstControlPoint = n, this.lastControlPoint = i;\n }\n static isInstance(t) {\n return !!t && t[Ae] === !0;\n }\n get midPoint() {\n return this.paramPoint(0.5);\n }\n _extremaInDirection(t) {\n const [e, n, i, o] = [\n this.firstPoint[t],\n this.firstControlPoint[t],\n this.lastControlPoint[t],\n this.lastPoint[t]\n ], l = -e + 3 * n - 3 * i + o, h = 2 * e - 4 * n + 2 * i, a = -e + n;\n return qt(a, h, l).filter(\n (u) => u >= -this.precision && u <= 1 + this.precision\n );\n }\n getParametersOfExtrema() {\n return Array.from(\n new Set(this._extremaInDirection(0).concat(this._extremaInDirection(1)))\n );\n }\n get alignedCurve() {\n const t = [-this.firstPoint[0], -this.firstPoint[1]], e = Q(this.lastPoint, this.firstPoint), n = Math.atan2(e[1], e[0]), i = new et();\n return i.translate(t[0], t[1]), i.rotate(-n), this.transform(i);\n }\n getInflexionParameters() {\n const t = this.alignedCurve, [e, n] = t.firstControlPoint, [i, o] = t.lastControlPoint, [l, h] = t.lastPoint, a = i * n, u = l * n, c = e * o, g = l * o, d = -3 * a + 2 * u + 3 * c - g, w = 3 * a - u - 3 * c, p = c - a;\n return qt(p, w, d).filter((P) => P >= 0 && P <= 1);\n }\n get boundingBox() {\n return this._boundingBox === null && (this._boundingBox = ce([\n this.firstPoint,\n ...this.getParametersOfExtrema().map((t) => this.paramPoint(t)),\n this.lastPoint\n ]).grow(this.precision)), this._boundingBox;\n }\n clone() {\n return new Et(\n this.firstPoint,\n this.lastPoint,\n this.firstControlPoint,\n this.lastControlPoint\n );\n }\n reverse() {\n return new Et(\n this.lastPoint,\n this.firstPoint,\n this.lastControlPoint,\n this.firstControlPoint\n );\n }\n isSame(t) {\n return t.segmentType !== \"CUBIC_BEZIER\" ? !1 : Y(this.firstPoint, t.firstPoint) && Y(this.lastPoint, t.lastPoint) && Y(this.firstControlPoint, t.firstControlPoint) && Y(this.lastControlPoint, t.lastControlPoint);\n }\n distanceFrom(t) {\n const n = $e((i) => Rt(this.paramPoint(i), t), this.precision);\n return n.argMin < -this.precision || n.argMin > 1 + this.precision ? Math.min(\n J(this.firstPoint, t),\n J(this.lastPoint, t)\n ) : Math.sqrt(n.fMin);\n }\n isOnSegment(t) {\n if (!this.boundingBox.contains(t))\n return !1;\n try {\n const e = this.pointToParam(t);\n return e >= -this.precision && e <= 1 + this.precision;\n } catch {\n return !1;\n }\n }\n gradientAt(t) {\n const e = 1 - t, n = e * e, i = t * t, o = 3 * n, l = 6 * e * t, h = 3 * i, a = Q(this.firstControlPoint, this.firstPoint), u = Q(this.lastControlPoint, this.firstControlPoint), c = Q(this.lastPoint, this.lastControlPoint);\n return [\n o * a[0] + l * u[0] + h * c[0],\n o * a[1] + l * u[1] + h * c[1]\n ];\n }\n secondDerivativeAt(t) {\n const e = it(this.firstPoint, this.lastControlPoint), n = nt(this.firstControlPoint, 2), i = it(this.firstControlPoint, this.lastPoint), o = nt(this.lastControlPoint, 2), l = nt(Q(e, n), 6 * (1 - t)), h = nt(Q(i, o), 6 * t);\n return it(l, h);\n }\n tangentAt(t) {\n const e = this.pointToParam(t);\n return H(this.gradientAt(e));\n }\n get tangentAtFirstPoint() {\n return H(Q(this.firstControlPoint, this.firstPoint));\n }\n get tangentAtLastPoint() {\n return H(Q(this.lastPoint, this.lastControlPoint));\n }\n normalAt(t) {\n const e = this.tangentAt(t);\n return tt(e);\n }\n get normalAtFirstPoint() {\n return tt(this.tangentAtFirstPoint);\n }\n get normalAtLastPoint() {\n return tt(this.tangentAtLastPoint);\n }\n splitAtParameters(t, e = null) {\n const n = [...t];\n n.sort((o, l) => o - l);\n let i = {\n originalParam: 0,\n param: 0,\n p0: this.firstPoint,\n p1: this.firstControlPoint,\n p2: this.lastControlPoint\n };\n return n.flatMap((o, l) => {\n if (o - i.originalParam < this.precision)\n return [];\n let h = !1;\n o > 1 - this.precision && (h = !0);\n const a = (o - i.originalParam) / (1 - i.originalParam), u = de(\n [\n i.p0,\n i.p1,\n i.p2,\n this.lastPoint\n ],\n h ? 1 : a\n ), c = h ? this.lastPoint : (e == null ? void 0 : e.get(o)) ?? u[0][0], g = u[1][0], d = u[2][0], w = u[1][1], p = u[2][2], P = new Et(\n i.p0,\n c,\n d,\n g\n );\n return i = {\n param: a,\n originalParam: o,\n p0: c,\n p1: w,\n p2: p\n }, l === n.length - 1 && !h ? [\n P,\n new Et(\n i.p0,\n this.lastPoint,\n i.p1,\n i.p2\n )\n ] : P;\n });\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t];\n const n = e.map((o) => this.pointToParam(o)), i = new Map(\n Kt([n, e])\n );\n return this.splitAtParameters(n, i);\n }\n transform(t) {\n return new Et(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint),\n t.transform(this.firstControlPoint),\n t.transform(this.lastControlPoint)\n );\n }\n paramPoint(t) {\n const e = 1 - t, n = e * e, i = t * t, o = n * e, l = 3 * n * t, h = 3 * e * i, a = i * t;\n return [\n o * this.firstPoint[0] + l * this.firstControlPoint[0] + h * this.lastControlPoint[0] + a * this.lastPoint[0],\n o * this.firstPoint[1] + l * this.firstControlPoint[1] + h * this.lastControlPoint[1] + a * this.lastPoint[1]\n ];\n }\n get polynomialCoefficients() {\n if (this._polynomialCoefficients === null) {\n const t = (e) => {\n const n = this.firstPoint[e], i = this.firstControlPoint[e], o = this.lastControlPoint[e], l = this.lastPoint[e], h = -n + 3 * i - 3 * o + l, a = 3 * n - 6 * i + 3 * o, u = -3 * n + 3 * i;\n return [n, u, a, h];\n };\n this._polynomialCoefficients = [t(0), t(1)];\n }\n return this._polynomialCoefficients;\n }\n paramsAtY(t) {\n const [e, n, i, o] = this.polynomialCoefficients[1];\n return Ge(e - t, n, i, o).filter((l) => l >= -this.precision && l <= 1 + this.precision);\n }\n pointToParam(t) {\n if (Y(t, this.firstPoint, this.precision)) return 0;\n if (Y(t, this.lastPoint, this.precision)) return 1;\n const e = this.paramsAtY(t[1]);\n if (e.length === 0)\n throw new Error(\"Point is not on the curve\");\n const n = (o) => Math.abs(this.paramPoint(o)[0] - t[0]) <= this.precision, i = e.find(n);\n if (i === void 0)\n throw new Error(\"Point is not on the curve\");\n return i;\n }\n}\nconst Fe = Symbol.for(\"pantograph:EllipseArc\");\nclass jt extends Ft {\n constructor(t, e, n, i, o, l, h = !1, {\n ignoreChecks: a = !1,\n angleUnits: u = \"deg\"\n } = {}) {\n super(t, e);\n q(this, \"segmentType\", \"ELLIPSE_ARC\");\n // I would need to do some more work to improve the precision that I can have\n // on an ellipse with intersection algorithms\n q(this, \"precision\", 1e-6);\n q(this, \"majorRadius\");\n q(this, \"minorRadius\");\n q(this, \"center\");\n q(this, \"tiltAngle\");\n q(this, \"clockwise\");\n q(this, \"_coefficients\", null);\n q(this, \"_boundingBox\");\n q(this, \"_linearExentricity\");\n q(this, \"_exentricity\");\n q(this, \"_focals\");\n q(this, \"_ellipseReferenceFrameTransform\");\n q(this, \"_reverseEllipseReferenceFrameTransform\");\n q(this, \"_rotateFromEllipseReferenceFrame\");\n q(this, \"_firstAngle\");\n q(this, \"_lastAngle\");\n q(this, \"_deltaAngle\");\n Object.defineProperty(this, Fe, { value: !0 }), this.center = n;\n const c = i >= o;\n this.majorRadius = c ? i : o, this.minorRadius = c ? o : i;\n const g = u === \"deg\" ? l * fe : l;\n if (this.tiltAngle = wt(\n c ? g : g + Math.PI / 2\n ), this.clockwise = h, !a) {\n if (Y(t, e))\n throw new Error(\"Invalid arc, cannot be a full circle\");\n if (!this.isPointOnEllipse(t))\n throw new Error(\n `First point ${Z(\n t\n )} not on the ellipse defined by ${this.info}`\n );\n if (!this.isPointOnEllipse(e))\n throw new Error(\n `Last point ${Z(e)} not on the ellipse defined by ${this.info}`\n );\n if (Math.abs(this.majorRadius - this.minorRadius) < this.precision)\n throw new Error(\n \"Both radii should be different, create an arc instead\"\n );\n }\n }\n static isInstance(t) {\n return !!t && t[Fe] === !0;\n }\n get coefficients() {\n if (this._coefficients === null) {\n const [t, e] = this.center, n = this.majorRadius * this.majorRadius, i = this.minorRadius * this.minorRadius, o = Math.cos(this.tiltAngle), l = Math.sin(this.tiltAngle), h = n * l * l + i * o * o, a = 2 * (i - n) * l * o, u = n * o * o + i * l * l;\n this._coefficients = {\n x2: h,\n xy: a,\n y2: u,\n x: -2 * h * t - a * e,\n y: -2 * u * e - a * t,\n c: h * t * t + a * t * e + u * e * e - n * i\n };\n }\n return this._coefficients;\n }\n get info() {\n return `ELLIPSE_ARC(${Z(this.firstPoint)}, ${Z(\n this.lastPoint\n )}, ${Z(this.center)}, ${this.majorRadius}, ${this.minorRadius}, ${this.tiltAngle * Je}, ${this.clockwise ? \"CW\" : \"CCW\"})`;\n }\n reverse() {\n return new jt(\n this.lastPoint,\n this.firstPoint,\n this.center,\n this.majorRadius,\n this.minorRadius,\n this.tiltAngle,\n !this.clockwise,\n { ignoreChecks: !0, angleUnits: \"rad\" }\n );\n }\n clone() {\n return new jt(\n this.firstPoint,\n this.lastPoint,\n this.center,\n this.majorRadius,\n this.minorRadius,\n this.tiltAngle,\n this.clockwise,\n { ignoreChecks: !0, angleUnits: \"rad\" }\n );\n }\n computeEllipseExtrema() {\n const t = Math.tan(this.tiltAngle), e = this.minorRadius / this.majorRadius, n = -Math.atan(e * t), i = Math.atan(e / t);\n return [n, Math.PI + n, i, Math.PI + i].map((l) => this.thetaToParam(l)).filter((l) => this.isValidParameter(l)).map((l) => this.paramPoint(l));\n }\n get boundingBox() {\n if (this._boundingBox === void 0) {\n const t = this.computeEllipseExtrema(), e = [\n this.firstPoint,\n this.lastPoint,\n ...t\n ];\n this._boundingBox = ce(e).grow(this.precision);\n }\n return this._boundingBox;\n }\n get linearExentricity() {\n return this._linearExentricity === void 0 && (this._linearExentricity = Math.sqrt(\n this.majorRadius * this.majorRadius - this.minorRadius * this.minorRadius\n )), this._linearExentricity;\n }\n get exentricity() {\n return this._exentricity === void 0 && (this._exentricity = this.linearExentricity / this.majorRadius), this._exentricity;\n }\n get focals() {\n if (this._focals === void 0) {\n const t = this.majorAxis;\n this._focals = [\n it(this.center, nt(t, this.linearExentricity)),\n it(this.center, nt(t, -this.linearExentricity))\n ];\n }\n return this._focals;\n }\n get majorAxis() {\n return It(1, this.tiltAngle);\n }\n paramPoint(t) {\n const e = this.firstAngle + t * this.deltaAngle * (this.clockwise ? -1 : 1);\n return this.reverseEllipseReferenceFrameTransform.transform([\n this.majorRadius * Math.cos(e),\n this.minorRadius * Math.sin(e)\n ]);\n }\n pointToParam(t) {\n if (!this.isPointOnEllipse(t))\n throw new Error(\n `Point ${Z(t)} not on the ellipse defined by ${this.repr}`\n );\n const e = this.thetaToParam(this.pointTheta(t));\n if (!this.isValidParameter(e))\n throw new Error(\n `Point ${Z(t)} is not on segment ${this.repr}`\n );\n return e;\n }\n get midPoint() {\n return this.paramPoint(0.5);\n }\n isValidParameter(t) {\n return 1 - t >= -this.precision && t >= -this.precision;\n }\n isSame(t) {\n return Y(this.center, t.center) && Math.abs(this.majorRadius - t.majorRadius) < this.precision && Math.abs(this.minorRadius - t.minorRadius) < this.precision && (Math.abs(this.tiltAngle - t.tiltAngle) < this.precision || Math.abs(Math.abs(this.tiltAngle - t.tiltAngle) - Math.PI) < this.precision) && (Y(this.firstPoint, t.firstPoint) && this.clockwise === t.clockwise || Y(this.firstPoint, t.lastPoint) && this.clockwise !== t.clockwise);\n }\n pointTheta(t) {\n const e = this.ellipseReferenceFrameTransform.transform(t), n = Math.atan2(\n e[1] / this.minorRadius,\n e[0] / this.majorRadius\n );\n return wt(n);\n }\n thetaToParam(t) {\n return Zt(this.firstAngle, wt(t), this.clockwise) / this.deltaAngle;\n }\n isPointOnEllipse(t) {\n const [e, n] = this.focals, i = J(t, e), o = J(t, n);\n return Math.abs(2 * this.majorRadius - i - o) < this.precision;\n }\n isOnSegment(t) {\n return this.isPointOnEllipse(t) ? this.isValidParameter(this.thetaToParam(this.pointTheta(t))) : !1;\n }\n distanceFrom(t) {\n let e;\n if (Y(t, this.center) ? e = it(\n this.center,\n nt(tt(this.majorAxis), this.minorRadius)\n ) : e = this.reverseEllipseReferenceFrameTransform.transform(\n gn(\n this.majorRadius,\n this.minorRadius,\n this.ellipseReferenceFrameTransform.transform(t)\n )\n ), this.isValidParameter(this.thetaToParam(this.pointTheta(t))))\n return J(t, e);\n if (ts(t, this.majorAxis, this.center)) {\n const n = wt(\n 2 * Math.PI - this.pointTheta(t)\n ), i = this.thetaToParam(n);\n if (this.isValidParameter(i))\n return J(t, this.paramPoint(i));\n }\n return Math.min(\n J(t, this.firstPoint),\n J(t, this.lastPoint)\n );\n }\n get ellipseReferenceFrameTransform() {\n return this._ellipseReferenceFrameTransform === void 0 && (this._ellipseReferenceFrameTransform = new et().translate(-this.center[0], -this.center[1]).rotate(-this.tiltAngle)), this._ellipseReferenceFrameTransform;\n }\n get reverseEllipseReferenceFrameTransform() {\n return this._reverseEllipseReferenceFrameTransform === void 0 && (this._reverseEllipseReferenceFrameTransform = new et().rotate(this.tiltAngle).translate(this.center[0], this.center[1])), this._reverseEllipseReferenceFrameTransform;\n }\n get rotateFromEllipseReferenceFrame() {\n return this._rotateFromEllipseReferenceFrame === void 0 && (this._rotateFromEllipseReferenceFrame = new et().rotate(\n this.tiltAngle\n )), this._rotateFromEllipseReferenceFrame;\n }\n get firstAngle() {\n return this._firstAngle === void 0 && (this._firstAngle = this.pointTheta(this.firstPoint)), this._firstAngle;\n }\n get lastAngle() {\n return this._lastAngle === void 0 && (this._lastAngle = this.pointTheta(this.lastPoint)), this._lastAngle;\n }\n get deltaAngle() {\n return this._deltaAngle === void 0 && (this._deltaAngle = Zt(\n this.firstAngle,\n this.lastAngle,\n this.clockwise\n )), this._deltaAngle;\n }\n normalAt(t) {\n const e = this.tangentAt(t);\n return this.clockwise ? tt(e) : Qt(e);\n }\n gradientAt(t) {\n const e = this.firstAngle + t * this.deltaAngle * (this.clockwise ? -1 : 1), n = -this.majorRadius * this.deltaAngle * Math.sin(e), i = this.minorRadius * this.deltaAngle * Math.cos(e), o = this.clockwise ? [-n, -i] : [n, i];\n return this.rotateFromEllipseReferenceFrame.transform(o);\n }\n tangentAt(t) {\n const e = this.pointTheta(t), n = -this.majorRadius * Math.sin(e), i = this.minorRadius * Math.cos(e), o = this.clockwise ? [-n, -i] : [n, i];\n return H(this.rotateFromEllipseReferenceFrame.transform(o));\n }\n get tangentAtFirstPoint() {\n const t = -this.majorRadius * Math.sin(this.firstAngle), e = this.minorRadius * Math.cos(this.firstAngle), n = this.clockwise ? [-t, -e] : [t, e];\n return H(this.rotateFromEllipseReferenceFrame.transform(n));\n }\n get tangentAtLastPoint() {\n const t = -this.majorRadius * Math.sin(this.lastAngle), e = this.minorRadius * Math.cos(this.lastAngle), n = this.clockwise ? [-t, -e] : [t, e];\n return H(this.rotateFromEllipseReferenceFrame.transform(n));\n }\n transform(t) {\n const e = t.transformAngle(this.tiltAngle), n = t.scaleFactor();\n return new jt(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint),\n t.transform(this.center),\n this.majorRadius * n,\n this.minorRadius * n,\n e,\n t.keepsOrientation() ? this.clockwise : !this.clockwise,\n { angleUnits: \"rad\" }\n );\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t];\n const i = [0, 1, ...e.map((h) => this.pointToParam(h))], o = new Map(\n Kt([i, [this.firstPoint, this.lastPoint, ...e]])\n );\n i.sort((h, a) => h - a);\n let l = null;\n return i.flatMap((h, a) => {\n if (a === i.length - 1) return [];\n const u = i[a + 1];\n if (u - h < this.precision)\n return l === null && (l = h), [];\n const c = l === null ? h : l, g = new jt(\n o.get(c) || this.paramPoint(c),\n o.get(u) || this.paramPoint(u),\n this.center,\n this.majorRadius,\n this.minorRadius,\n this.tiltAngle,\n this.clockwise,\n { angleUnits: \"rad\" }\n );\n return l = null, g;\n });\n }\n}\nfunction _n(r, s, t, e, n, i, o) {\n const { center: l, rx: h, ry: a } = mn(\n r,\n s,\n t,\n e,\n n * fe,\n !i,\n o\n );\n return Math.abs(h - a) < 1e-9 ? new ct(r, s, l, o) : new jt(r, s, l, h, a, n, o);\n}\nfunction mn([r, s], [t, e], n, i, o, l, h) {\n if (n < 0 && (n = -n), i < 0 && (i = -i), n == 0 || i == 0)\n throw Error(\"rx and ry can not be 0\");\n const a = Math.sin(o), u = Math.cos(o), c = (r - t) / 2, g = (s - e) / 2, d = (r + t) / 2, w = (s + e) / 2, p = u * c + a * g, P = u * g - a * c, f = p * p / (n * n) + P * P / (i * i);\n f > 1 && (n = n * Math.sqrt(f), i = i * Math.sqrt(f));\n const y = n * i, E = n * P, R = i * p, v = E * E + R * R;\n if (!v)\n throw Error(\"start point can not be same as end point\");\n let L = Math.sqrt(Math.abs((y * y - v) / v));\n l == h && (L = -L);\n const S = L * E / i, k = -L * R / n, D = u * S - a * k + d, m = a * S + u * k + w;\n return {\n center: [D, m],\n rx: n,\n ry: i\n };\n}\nfunction gn(r, s, t) {\n const e = Math.abs(t[0]), n = Math.abs(t[1]);\n let i = 0.707, o = 0.707;\n const l = r, h = s;\n for (let a = 0; a < 3; a++) {\n const u = l * i, c = h * o, g = (l * l - h * h) * i ** 3 / l, d = (h * h - l * l) * o ** 3 / h, w = u - g, p = c - d, P = e - g, f = n - d, y = Math.hypot(w, p), E = Math.hypot(P, f);\n i = Math.min(1, Math.max(0, (P * y / E + g) / l)), o = Math.min(1, Math.max(0, (f * y / E + d) / h));\n const R = Math.hypot(i, o);\n i /= R, o /= R;\n }\n return [l * i * Math.sign(t[0]), h * o * Math.sign(t[1])];\n}\nconst xe = Symbol.for(\"pantograph:QuadraticBezier\");\nclass _t extends Ft {\n constructor(t, e, n) {\n super(t, e);\n q(this, \"segmentType\", \"QUADRATIC_BEZIER\");\n q(this, \"controlPoint\");\n q(this, \"_boundingBox\", null);\n q(this, \"_polynomialCoefficients\", null);\n Object.defineProperty(this, xe, { value: !0 }), this.controlPoint = n;\n }\n static isInstance(t) {\n return !!t && t[xe] === !0;\n }\n get midPoint() {\n return this.paramPoint(0.5);\n }\n _extremaInDirection(t) {\n const [e, n, i] = [\n this.firstPoint[t],\n this.controlPoint[t],\n this.lastPoint[t]\n ], o = e - 2 * n + i;\n if (!o)\n return [];\n const l = (e - n) / o;\n return l >= -this.precision && l <= 1 + this.precision ? [l] : [];\n }\n getParametersOfExtrema() {\n return Array.from(\n new Set(this._extremaInDirection(0).concat(this._extremaInDirection(1)))\n );\n }\n get boundingBox() {\n return this._boundingBox === null && (this._boundingBox = ce([\n this.firstPoint,\n // There is either one or zero extrema in each direction\n ...this.getParametersOfExtrema().map((t) => this.paramPoint(t)),\n this.lastPoint\n ]).grow(this.precision)), this._boundingBox;\n }\n clone() {\n return new _t(\n this.firstPoint,\n this.lastPoint,\n this.controlPoint\n );\n }\n reverse() {\n return new _t(\n this.lastPoint,\n this.firstPoint,\n this.controlPoint\n );\n }\n isSame(t) {\n return t.segmentType !== \"QUADRATIC_BEZIER\" ? !1 : Y(this.firstPoint, t.firstPoint) && Y(this.lastPoint, t.lastPoint) && Y(this.controlPoint, t.controlPoint);\n }\n distanceFrom(t) {\n const n = $e((i) => Rt(this.paramPoint(i), t), this.precision);\n return n.argMin < -this.precision || n.argMin > 1 + this.precision ? Math.min(\n J(this.firstPoint, t),\n J(this.lastPoint, t)\n ) : Math.sqrt(n.fMin);\n }\n isOnSegment(t) {\n if (!this.boundingBox.contains(t))\n return !1;\n try {\n const e = this.pointToParam(t);\n return e >= -this.precision && e <= 1 + this.precision;\n } catch {\n return !1;\n }\n }\n gradientAt(t) {\n const e = (n) => {\n const i = this.firstPoint[n], o = this.controlPoint[n], l = this.lastPoint[n];\n return 2 * (t * (i - 2 * o + l) - i + o);\n };\n return [e(0), e(1)];\n }\n secondDerivativeAt(t) {\n return nt(\n Q(\n it(this.firstPoint, this.lastPoint),\n nt(this.controlPoint, 2)\n ),\n 2\n );\n }\n tangentAt(t) {\n const e = this.pointToParam(t);\n return H(this.gradientAt(e));\n }\n get tangentAtFirstPoint() {\n return H(Q(this.controlPoint, this.firstPoint));\n }\n get tangentAtLastPoint() {\n return H(Q(this.lastPoint, this.controlPoint));\n }\n normalAt(t) {\n const e = this.tangentAt(t);\n return tt(e);\n }\n get normalAtFirstPoint() {\n return tt(this.tangentAtFirstPoint);\n }\n get normalAtLastPoint() {\n return tt(this.tangentAtLastPoint);\n }\n splitAtParameters(t, e = null) {\n const n = [...t];\n n.sort((o, l) => o - l);\n let i = {\n originalParam: 0,\n param: 0,\n p0: this.firstPoint,\n p1: this.controlPoint\n };\n return n.flatMap((o, l) => {\n if (o - i.originalParam < this.precision)\n return [];\n let h = !1;\n o > 1 - this.precision && (h = !0);\n const a = (o - i.originalParam) / (1 - i.originalParam), u = de(\n [i.p0, i.p1, this.lastPoint],\n h ? 1 : a\n ), c = h ? this.lastPoint : (e == null ? void 0 : e.get(o)) ?? u[0][0], g = u[1][0], d = u[1][1], w = new _t(\n i.p0,\n c,\n g\n );\n return i = {\n param: a,\n originalParam: o,\n p0: c,\n p1: d\n }, l === n.length - 1 && !h ? [\n w,\n new _t(\n i.p0,\n this.lastPoint,\n i.p1\n )\n ] : w;\n });\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t];\n const n = e.map((o) => this.pointToParam(o)), i = new Map(\n Kt([n, e])\n );\n return this.splitAtParameters(n, i);\n }\n transform(t) {\n return new _t(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint),\n t.transform(this.controlPoint)\n );\n }\n paramPoint(t) {\n const e = 1 - t, n = e * e, i = 2 * e * t, o = t * t;\n return [\n n * this.firstPoint[0] + i * this.controlPoint[0] + o * this.lastPoint[0],\n n * this.firstPoint[1] + i * this.controlPoint[1] + o * this.lastPoint[1]\n ];\n }\n get polynomialCoefficients() {\n if (this._polynomialCoefficients === null) {\n const t = (e) => {\n const n = this.firstPoint[e], i = this.controlPoint[e], o = this.lastPoint[e], l = n - 2 * i + o, h = 2 * (i - n);\n return [n, h, l];\n };\n this._polynomialCoefficients = [t(0), t(1)];\n }\n return this._polynomialCoefficients;\n }\n paramsAtY(t) {\n const [e, n, i] = this.polynomialCoefficients[1];\n return qt(e - t, n, i).filter(\n (o) => o >= -this.precision && o <= 1 + this.precision\n );\n }\n pointToParam(t) {\n const e = this.paramsAtY(t[1]);\n if (e.length === 0)\n throw new Error(\"Point is not on the curve!\");\n const n = (o) => Math.abs(this.paramPoint(o)[0] - t[0]) <= this.precision, i = e.find(n);\n if (i === void 0)\n throw new Error(\"Point is not on the curve\");\n return i;\n }\n}\nexport {\n ct as A,\n mt as B,\n Et as C,\n fe as D,\n jt as E,\n yn as F,\n ns as G,\n Ve as H,\n Z as I,\n at as L,\n _t as Q,\n Je as R,\n et as T,\n it as a,\n Q as b,\n St as c,\n be as d,\n J as e,\n Qt as f,\n Y as g,\n Mn as h,\n _n as i,\n He as j,\n It as k,\n Ne as l,\n me as m,\n H as n,\n Ke as o,\n tt as p,\n Rt as q,\n is as r,\n nt as s,\n Pn as t,\n dn as u,\n pn as v,\n un as w,\n En as x,\n Tt as y,\n Kt as z\n};\n//# sourceMappingURL=QuadraticBezier-BeY2TXKH.js.map\n","var on = Object.defineProperty;\nvar ln = (t, n, e) => n in t ? on(t, n, { enumerable: !0, configurable: !0, writable: !0, value: e }) : t[n] = e;\nvar b = (t, n, e) => ln(t, typeof n != \"symbol\" ? n + \"\" : n, e);\nimport { b as k, d as un, e as Dt, a as z, s as N, n as cn, p as Rt, l as j, A as x, g as P, w as Nt, E as C, T as an, x as fn, Q as M, y as $, C as A, c as hn, v as pn, L as y, F as Vt, G as ut, z as V, H as dn, m as mn, q as gn, I as mt, B as Pn } from \"./QuadraticBezier-BeY2TXKH.js\";\nfunction In(t, n) {\n const e = k(n, t.firstPoint), s = un(e, t.V) / t.squareLength;\n return t.paramPoint(s);\n}\nfunction K(t, n, e) {\n const s = e || t.precision, i = In(t, n.center), r = Dt(i, n.center);\n if (r > n.radius + s) return [];\n if (Math.abs(r - n.radius) < s) {\n const c = i;\n return t.isOnSegment(c) && n.isOnSegment(c) ? [c] : [];\n }\n const l = [], o = Math.sqrt(\n n.radius * n.radius - r * r\n ), u = t.tangentAtFirstPoint, a = z(i, N(u, o));\n t.isOnSegment(a) && n.isOnSegment(a) && l.push(a);\n const f = z(i, N(u, -o));\n return t.isOnSegment(f) && n.isOnSegment(f) && l.push(f), l;\n}\nconst wn = (t) => {\n const { firstPoint: n, lastPoint: e, center: s, clockwise: i } = t;\n return new x(e, n, s, i, {\n ignoreChecks: !0\n });\n}, xn = (t, n) => {\n if (t.isSame(n))\n return [t];\n const e = j(\n [\n n.isOnSegment(t.firstPoint) ? t.firstPoint : null,\n n.isOnSegment(t.lastPoint) ? t.lastPoint : null,\n t.isOnSegment(n.firstPoint) ? n.firstPoint : null,\n t.isOnSegment(n.lastPoint) ? n.lastPoint : null\n ].filter((s) => s !== null)\n // We sort by the param value of the first arc. This means that the points\n // will be sorted with the same orientation than arc1\n ).sort((s, i) => t.pointToParam(s) - t.pointToParam(i));\n if (e.length === 0) return [];\n if (e.length === 1) return [];\n if (e.length === 2)\n return t.isSame(wn(n)) ? [] : [new x(e[0], e[1], t.center, t.clockwise)];\n if (e.length === 3) {\n const s = P(e[0], n.lastPoint) || P(e[0], n.firstPoint) ? 1 : 0;\n return [\n new x(\n e[0 + s],\n e[1 + s],\n t.center,\n t.clockwise\n )\n ];\n } else if (e.length === 4)\n return [\n new x(e[0], e[1], t.center, t.clockwise),\n new x(e[2], e[3], t.center, t.clockwise)\n ];\n throw new Error(\"Bug in the arc arc overlap algorithm\");\n};\nfunction jt(t, n, e = !1, s) {\n const i = s || t.precision, r = Dt(t.center, n.center), l = t.radius + n.radius;\n if (r > l + i)\n return [];\n const o = Math.abs(t.radius - n.radius);\n if (r < o - i)\n return [];\n if (r < i)\n return o > i ? [] : e ? xn(t, n) : [];\n const u = cn(k(n.center, t.center)), a = r > l - i;\n if (\n // circles are outside each other\n a || // circles are inside each other\n Math.abs(r - o) < i\n ) {\n const g = a || t.radius > n.radius ? 1 : -1, I = z(\n t.center,\n N(u, g * t.radius)\n );\n return t.isOnSegment(I) && n.isOnSegment(I) ? [I] : [];\n }\n const f = t.radius * t.radius / (2 * r) - n.radius * n.radius / (2 * r) + r / 2, c = z(\n t.center,\n N(u, f)\n ), h = Math.sqrt(\n t.radius * t.radius - f * f\n ), p = Rt(u), d = z(c, N(p, h)), m = z(c, N(p, -h)), w = [];\n return t.isOnSegment(d) && n.isOnSegment(d) && w.push(d), t.isOnSegment(m) && n.isOnSegment(m) && w.push(m), w;\n}\nfunction st(t, n, e = 1e-9) {\n const s = t.transform(n.ellipseReferenceFrameTransform), i = s.slope, r = s.yIntercept, l = n.majorRadius * n.majorRadius, o = n.minorRadius * n.minorRadius, u = n.majorRadius * n.minorRadius, a = s.slope * s.slope, f = s.yIntercept * s.yIntercept, c = (g) => g.map(\n (I) => n.reverseEllipseReferenceFrameTransform.transform(I)\n ).filter((I) => t.isOnSegment(I) && n.isOnSegment(I));\n if (!Number.isFinite(i)) {\n const g = s.firstPoint[0];\n if (Math.abs(g) - n.majorRadius > e) return [];\n if (Math.abs(Math.abs(g) - n.majorRadius) < e)\n return c([[g, 0]]);\n const I = n.minorRadius * Math.sqrt(1 - g * g / l), F = [g, I], S = [g, -I];\n return c([F, S]);\n }\n const h = l * a + o - f;\n if (h < -e)\n return [];\n const p = l * a + o;\n if (Math.abs(h) < e) {\n const g = -(l * i * r) / p, I = o * r / p;\n return c([[g, I]]);\n }\n const d = Math.sqrt(h), m = [\n -(l * i * r + u * d) / p,\n (o * r - u * i * d) / p\n ], w = [\n -(l * i * r - u * d) / p,\n (o * r + u * i * d) / p\n ];\n return c([m, w]);\n}\nfunction Ut(t, n) {\n const e = Math.max(t.precision, n.precision), s = t.coefficients, i = s.x2, r = s.xy, l = s.y2, o = s.x, u = s.y, a = s.c, f = n.coefficients, c = f.x2, h = f.xy, p = f.y2, d = f.x, m = f.y, w = f.c, g = {\n z0: a * i * d * d + i * i * w * w - o * i * d * w + c * c * a * a - 2 * i * w * c * a - o * d * c * a + c * o * o * w,\n z1: m * o * o * c - w * d * i * r - 2 * i * w * c * u - a * c * h * o + 2 * d * h * i * a + 2 * m * w * i * i + d * d * i * u - m * d * i * o - 2 * i * m * c * a - a * c * d * r + 2 * a * u * c * c - w * h * i * o - u * c * d * o + 2 * w * r * c * o,\n z2: m * m * i * i + 2 * p * w * i * i - u * c * d * r + w * c * r * r - u * c * h * o - w * h * i * r - 2 * i * m * c * u + 2 * d * h * i * u - p * d * i * o - 2 * i * p * c * a + h * h * i * a + 2 * m * r * c * o + u * u * c * c - l * c * d * o - m * h * i * o + 2 * a * l * c * c - a * c * h * r + p * o * o * c + d * d * i * l - m * d * i * r - 2 * i * w * c * l,\n z3: -2 * i * c * l * m + m * c * r * r + 2 * p * r * c * o - l * c * h * o + h * h * i * u - m * h * i * r - 2 * i * p * c * u - u * c * h * r - p * h * i * o + 2 * m * p * i * i + 2 * u * l * c * c - l * c * d * r + 2 * d * h * i * l - p * d * i * r,\n z4: i * i * p * p - 2 * i * p * c * l + c * c * l * l - r * i * h * p - r * h * c * l + r * r * c * p + l * i * h * h\n }, F = Nt(\n [g.z0, g.z1, g.z2, g.z3, g.z4],\n e\n ).flatMap((S) => {\n const R = i * h * S + i * d - c * r * S - c * o;\n if (R)\n return [[-(i * w + i * p * S * S - c * l * S * S + i * m * S - c * u * S - c * a) / R, S]];\n const T = r * S + o, L = -T / (2 * i), U = l * S * S + u * S + a, q = T * T / (4 * i * i) - U / i;\n if (Math.abs(q) < e)\n return [[L, S]];\n if (q > 0) {\n const H = Math.sqrt(q);\n return [[L + H, S], [L - H, S]];\n }\n return [];\n });\n return j(F, e);\n}\nfunction gt(t, n) {\n return Ut(t, n).filter((s) => t.isOnSegment(s) && n.isOnSegment(s));\n}\nconst Sn = (t) => {\n const {\n firstPoint: n,\n lastPoint: e,\n center: s,\n majorRadius: i,\n minorRadius: r,\n tiltAngle: l,\n clockwise: o\n } = t;\n return new C(\n e,\n n,\n s,\n i,\n r,\n l,\n o,\n {\n ignoreChecks: !0,\n angleUnits: \"rad\"\n }\n );\n}, yn = (t, n) => {\n if (t.isSame(n))\n return [t];\n const e = (i, r) => new C(\n i,\n r,\n t.center,\n t.majorRadius,\n t.minorRadius,\n t.tiltAngle,\n t.clockwise,\n { ignoreChecks: !0, angleUnits: \"rad\" }\n ), s = j(\n [\n n.isOnSegment(t.firstPoint) ? t.firstPoint : null,\n n.isOnSegment(t.lastPoint) ? t.lastPoint : null,\n t.isOnSegment(n.firstPoint) ? n.firstPoint : null,\n t.isOnSegment(n.lastPoint) ? n.lastPoint : null\n ].filter((i) => i !== null)\n // We sort by the param value of the first arc. This means that the points\n // will be sorted with the same orientation than arc1\n ).sort((i, r) => t.pointToParam(i) - t.pointToParam(r));\n if (s.length === 0) return [];\n if (s.length === 1) return [];\n if (s.length === 2)\n return t.isSame(Sn(n)) ? [] : [e(s[0], s[1])];\n if (s.length === 3) {\n const i = P(s[0], n.lastPoint) || P(s[0], n.firstPoint) ? 1 : 0;\n return [e(s[0 + i], s[1 + i])];\n } else if (s.length === 4)\n return [e(s[0], s[1]), e(s[2], s[3])];\n throw new Error(\"Bug in the ellipse arc ellipse arc overlap algorithm\");\n};\nfunction bn(t, n, e = !1) {\n const s = Math.max(t.precision, n.precision);\n return P(t.center, n.center) && Math.abs(t.majorRadius - n.majorRadius) < s && Math.abs(t.minorRadius - n.minorRadius) < s && (Math.abs(t.tiltAngle - n.tiltAngle) < s || Math.abs(Math.abs(t.tiltAngle - n.tiltAngle) - Math.PI) < s) ? e ? yn(t, n) : [] : Ut(t, n).filter((l) => t.isOnSegment(l) && n.isOnSegment(l));\n}\nfunction Pt(t, n) {\n const [e, s] = t.firstPoint, [i, r] = t.lastPoint, l = new an().translate(-e, -s).rotate(-Math.atan2(r - s, i - e)), o = l.clone().inverse(), u = n.transform(l);\n return u.paramsAtY(0).map((a) => u.paramPoint(a)).map((a) => o.transform(a)).filter((a) => t.isOnSegment(a));\n}\nconst Cn = (t, n = 1e-9) => {\n let e = t;\n return Math.abs(t) < n && (e = 0), e.toFixed(-Math.log10(n));\n};\nfunction Ht(t, n = 1e-9) {\n return Array.from(\n new Map(t.map((e) => [Cn(e, n), e])).values()\n );\n}\nconst Mn = (t, n) => {\n const [[e, s, i, r], [l, o, u, a]] = n.polynomialCoefficients, f = t.coefficients, c = f.x2, h = f.xy, p = f.y2, d = f.x, m = f.y, w = f.c, g = e * e, I = s * s, F = i * i, S = r * r, R = l * l, T = o * o, L = u * u, U = a * a, q = w + d * e + c * g + m * l + h * e * l + p * R, H = d * s + 2 * c * e * s + h * s * l + m * o + h * e * o + 2 * p * l * o, tn = c * I + d * i + 2 * c * e * i + h * i * l + h * s * o + p * T + m * u + h * e * u + 2 * p * l * u, nn = 2 * c * s * i + d * r + 2 * c * e * r + h * r * l + h * i * o + h * s * u + 2 * p * o * u + m * a + h * e * a + 2 * p * l * a, en = c * F + 2 * c * s * r + h * r * o + h * i * u + p * L + h * s * a + 2 * p * o * a, sn = 2 * c * i * r + h * r * u + h * i * a + 2 * p * u * a, rn = c * S + h * r * a + p * U;\n return [q, H, tn, nn, en, sn, rn];\n};\nfunction It(t, n) {\n const e = Math.max(t.precision, n.precision), s = Mn(t, n), i = Nt(s, e).filter((r) => r >= -n.precision && r <= 1 + n.precision);\n return Ht(i, e).map((r) => n.paramPoint(r)).filter((r) => t.isOnSegment(r));\n}\nconst An = (t, n) => {\n const [[e, s, i], [r, l, o]] = n.polynomialCoefficients, u = t.coefficients, a = u.x2, f = u.xy, c = u.y2, h = u.x, p = u.y, d = u.c, m = e * e, w = s * s, g = i * i, I = r * r, F = l * l, S = o * o, R = a * m + f * e * r + c * I + h * e + p * r + d, T = 2 * a * e * s + f * e * l + f * s * r + 2 * c * r * l + h * s + p * l, L = 2 * a * e * i + a * w + f * e * o + f * s * l + f * i * r + 2 * c * r * o + c * F + h * i + p * o, U = 2 * a * s * i + f * s * o + f * i * l + 2 * c * l * o, q = a * g + f * i * o + c * S;\n return [R, T, L, U, q];\n};\nfunction wt(t, n) {\n const e = Math.max(t.precision, n.precision), s = An(t, n), i = fn(...s).filter((r) => r >= -n.precision && r <= 1 + n.precision);\n return Ht(i, e).map((r) => n.paramPoint(r)).filter((r) => t.isOnSegment(r));\n}\nfunction E(t, { firstPoint: n, lastPoint: e }, s = 1e-9) {\n const i = k(e, n);\n return Math.abs(i[0]) < s ? i[1] > 0 ? n[0] - t[0] : t[0] - n[0] : Math.abs(i[1]) < s ? i[0] > 0 ? t[1] - n[1] : n[1] - t[1] : hn(i, k(t, n)) / pn(i);\n}\nclass ct {\n constructor(n, e, s, i) {\n this.firstPoint = n, this.lastPoint = e, this.negativeThickness = s, this.positiveThickness = i;\n }\n get width() {\n return this.positiveThickness - this.negativeThickness;\n }\n}\nconst En = 3 / 4, Fn = 4 / 9;\nfunction vn(t) {\n const n = E(t.firstControlPoint, t), e = E(t.lastControlPoint, t), s = n * e > 0 ? En : Fn;\n return new ct(\n t.firstPoint,\n t.lastPoint,\n s * Math.min(0, n, e),\n s * Math.max(0, n, e)\n );\n}\nfunction Bn(t) {\n const n = E(t.controlPoint, t);\n return new ct(\n t.firstPoint,\n t.lastPoint,\n Math.min(0, n / 2),\n Math.max(0, n / 2)\n );\n}\nfunction kn(t) {\n if (A.isInstance(t))\n return vn(t);\n if (M.isInstance(t))\n return Bn(t);\n throw new Error(\"Not implemented\");\n}\nfunction On(t) {\n const n = t.paramPoint(0.5), e = Rt(k(n, t.firstPoint)), s = z(n, e), i = {\n firstPoint: n,\n lastPoint: s\n }, r = [\n E(t.firstPoint, i),\n E(t.lastPoint, i)\n ];\n return A.isInstance(t) ? r.push(\n E(t.firstControlPoint, i),\n E(t.lastControlPoint, i)\n ) : M.isInstance(t) && r.push(E(t.controlPoint, i)), new ct(\n n,\n s,\n Math.min(...r),\n Math.max(...r)\n );\n}\nfunction xt(t, n) {\n const e = [];\n for (let s = 1; s < t.length; s++) {\n const i = t[s];\n if (i[1] === n) {\n e.push(i[0]);\n continue;\n }\n const r = t[s - 1], l = n - r[1], o = n - i[1];\n if (l * o < 0) {\n e.push(\n r[0] + (n - r[1]) * (i[0] - r[0]) / (i[1] - r[1])\n );\n continue;\n }\n }\n return e;\n}\nclass Y {\n constructor(n, e) {\n this.from = n, this.to = e;\n }\n get size() {\n return this.from === \"start\" ? this.to === \"end\" ? 1 : this.to : this.to === \"end\" ? 1 - this.from : Math.abs(this.from - this.to);\n }\n clipCurve(n) {\n return this.from === \"start\" ? this.to === \"end\" ? n : n.splitAtParameters([this.to])[0] : this.to === \"end\" ? n.splitAtParameters([this.from])[1] : n.splitAtParameters([this.from, this.to])[1];\n }\n}\nfunction _n(t, n) {\n if (A.isInstance(t))\n return new Ln([\n E(t.firstPoint, n),\n E(t.firstControlPoint, n),\n E(t.lastControlPoint, n),\n E(t.lastPoint, n)\n ]);\n if (M.isInstance(t))\n return new Tn([\n E(t.firstPoint, n),\n E(t.controlPoint, n),\n E(t.lastPoint, n)\n ]);\n throw new Error(\"Not implemented\");\n}\nclass Tn {\n constructor(n) {\n b(this, \"topHull\", []);\n b(this, \"bottomHull\", []);\n this.distances = n;\n const [e, s, i] = n, r = [0, e], l = [1 / 2, s], o = [1, i], u = i - e, a = e;\n s - (u * (1 / 2) + a) > 0 ? (this.topHull = [r, l, o], this.bottomHull = [r, o]) : (this.topHull = [r, o], this.bottomHull = [r, l, o]);\n }\n get startDistance() {\n return this.distances[0];\n }\n get endDistance() {\n return this.distances[2];\n }\n}\nclass Ln {\n constructor(n) {\n b(this, \"topHull\", []);\n b(this, \"bottomHull\", []);\n this.distances = n;\n const [e, s, i, r] = n, l = [0, e], o = [1 / 3, s], u = [2 / 3, i], a = [1, r], f = r - e, c = e, h = s - (f * (1 / 3) + c), p = i - (f * (2 / 3) + c);\n let d = null, m = null;\n if (h * p < 0)\n d = [l, o, a], m = [l, u, a];\n else {\n const g = h / p;\n g >= 2 ? (d = [l, o, a], m = [l, a]) : g <= 0.5 ? (d = [l, u, a], m = [l, a]) : (d = [l, o, u, a], m = [l, a]);\n }\n h < 0 && ([d, m] = [m, d]), this.topHull = d, this.bottomHull = m;\n }\n get startDistance() {\n return this.distances[0];\n }\n get endDistance() {\n return this.distances[3];\n }\n}\nfunction St(t, n) {\n const e = _n(n, t), s = xt(\n e.topHull,\n t.negativeThickness\n ), i = xt(\n e.bottomHull,\n t.positiveThickness\n ), r = e.endDistance >= t.negativeThickness && e.endDistance <= t.positiveThickness;\n if (!s.length && !i.length)\n return r ? new Y(\"start\", \"end\") : null;\n if (s.length === 1 && i.length === 1)\n return new Y(s[0], i[0]);\n if (s.length === 2 && i.length === 2)\n throw new Error(\n \"Bug in the clipping algorithm, unexpected number of crossing points\"\n );\n const l = s.length ? s : i;\n return l.length === 2 ? new Y(l[0], l[1]) : r ? new Y(l[0], \"end\") : new Y(\"start\", l[0]);\n}\nfunction yt(t, n) {\n const e = kn(t), s = St(e, n);\n if (!s)\n return null;\n const i = On(t), r = St(\n i,\n n\n );\n return r ? s.size > r.size ? r.clipCurve(n) : s.clipCurve(n) : null;\n}\nconst W = (t) => M.isInstance(t) ? $(k(t.controlPoint, t.firstPoint)) + $(k(t.controlPoint, t.lastPoint)) : $(k(t.firstControlPoint, t.firstPoint)) + $(k(t.lastControlPoint, t.firstControlPoint)) + $(k(t.lastControlPoint, t.lastPoint));\nfunction D(t, n, e = 1e-9, { maxIterations: s = 100 } = {}) {\n const i = Math.max(e * e, Number.EPSILON * 10);\n let r = t, l = n, o = W(r), u = W(l);\n for (let a = 0; a < s; a++) {\n const f = o > i ? yt(l, r) : r;\n if (!f) return [];\n const c = W(f), h = u > i ? yt(f, l) : l;\n if (!h) return [];\n const p = W(h);\n if (c <= i && p <= i)\n return [\n f.boundingBox.intersection(h.boundingBox).center\n ];\n if (P(f.firstPoint, f.lastPoint) && h.isOnSegment(f.firstPoint))\n return [f.firstPoint];\n if (P(h.firstPoint, h.lastPoint) && f.isOnSegment(h.firstPoint))\n return [h.firstPoint];\n if (c > 0.8 * o && p > 0.8 * u)\n if (c / o > p / u) {\n const [d, m] = f.splitAtParameters([\n 0.5\n ]);\n return j(\n [\n ...D(d, h, e, {\n maxIterations: s - a\n }),\n ...D(m, h, e, {\n maxIterations: s - a\n })\n ],\n e\n );\n } else {\n const [d, m] = h.splitAtParameters([\n 0.5\n ]);\n return j(\n [\n ...D(f, d, e, {\n maxIterations: s - a\n }),\n ...D(f, m, e, {\n maxIterations: s - a\n })\n ],\n e\n );\n }\n r = f, l = h, o = c, u = p;\n }\n throw new Error(\"Bézier clip: Maximum number of iterations reached\");\n}\nfunction qn(t, n) {\n const e = [];\n if ([\n [t.firstPoint, n],\n [t.lastPoint, n],\n [n.firstPoint, t],\n [n.lastPoint, t]\n ].forEach(([i, r]) => {\n r.isOnSegment(i) && e.push(i);\n }), e.length < 2)\n return null;\n if (e.length === 2)\n return [t.splitAt(e)[1]];\n if (e.length === 3)\n return P(e[0], t.firstPoint) && P(e[1], t.lastPoint) ? [t] : [n];\n if (e.length === 4)\n return [t];\n}\nfunction zn(t, n, e = !1) {\n const s = Math.max(t.precision, n.precision);\n if (e) {\n const i = qn(t, n);\n if (i)\n return i;\n }\n return D(t, n, s);\n}\nfunction Dn(t, n) {\n const e = [];\n if ([\n [t.firstPoint, n],\n [t.lastPoint, n],\n [n.firstPoint, t],\n [n.lastPoint, t]\n ].forEach(([i, r]) => {\n r.isOnSegment(i) && e.push(i);\n }), e.length < 2)\n return null;\n if (e.length === 2)\n return [t.splitAt(e)[1]];\n if (e.length === 3)\n return P(e[0], t.firstPoint) && P(e[1], t.lastPoint) ? [t] : [n];\n if (e.length === 4)\n return [t];\n}\nfunction Rn(t, n, e = !1) {\n const s = Math.max(t.precision, n.precision);\n if (e) {\n const i = Dn(t, n);\n if (i)\n return i;\n }\n return D(t, n, s);\n}\nfunction Ie(t, n, e) {\n if (y.isInstance(t) && y.isInstance(n)) {\n const s = Vt(\n t,\n n,\n !1,\n e\n );\n return s === null ? [] : [s];\n }\n if (y.isInstance(t) && x.isInstance(n))\n return K(t, n, e);\n if (x.isInstance(t) && y.isInstance(n))\n return K(n, t, e);\n if (x.isInstance(t) && x.isInstance(n))\n return jt(t, n, !1, e);\n throw new Error(\"Not implemented\");\n}\nfunction Z(t, n, e) {\n if (y.isInstance(t) && y.isInstance(n)) {\n const s = Vt(\n t,\n n,\n !0,\n e\n );\n return s === null ? { intersections: [], overlaps: [], count: 0 } : y.isInstance(s) ? { intersections: [], overlaps: [s], count: 1 } : { intersections: [s], overlaps: [], count: 1 };\n }\n if (!t.boundingBox.overlaps(n.boundingBox))\n return { intersections: [], overlaps: [], count: 0 };\n if (y.isInstance(t) && x.isInstance(n)) {\n const s = K(t, n, e);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (x.isInstance(t) && y.isInstance(n)) {\n const s = K(n, t, e);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (x.isInstance(t) && x.isInstance(n)) {\n const s = jt(\n t,\n n,\n !0,\n e\n );\n return s.length ? x.isInstance(s[0]) ? {\n intersections: [],\n overlaps: s,\n count: s.length\n } : {\n intersections: s,\n overlaps: [],\n count: s.length\n } : { intersections: [], overlaps: [], count: 0 };\n }\n if (y.isInstance(t) && C.isInstance(n)) {\n const s = st(\n t,\n n,\n e\n );\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (y.isInstance(n) && C.isInstance(t)) {\n const s = st(\n n,\n t,\n e\n );\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (x.isInstance(t) && C.isInstance(n)) {\n const s = gt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (x.isInstance(n) && C.isInstance(t)) {\n const s = gt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (C.isInstance(t) && C.isInstance(n)) {\n const s = bn(\n t,\n n,\n !0\n );\n return s.length ? C.isInstance(s[0]) ? {\n intersections: [],\n overlaps: s,\n count: s.length\n } : {\n intersections: s,\n overlaps: [],\n count: s.length\n } : { intersections: [], overlaps: [], count: 0 };\n }\n if (y.isInstance(t) && (A.isInstance(n) || M.isInstance(n))) {\n const s = Pt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (y.isInstance(n) && (A.isInstance(t) || M.isInstance(t))) {\n const s = Pt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((x.isInstance(t) || C.isInstance(t)) && M.isInstance(n)) {\n const s = wt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((x.isInstance(n) || C.isInstance(n)) && M.isInstance(t)) {\n const s = wt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((x.isInstance(t) || C.isInstance(t)) && A.isInstance(n)) {\n const s = It(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((x.isInstance(n) || C.isInstance(n)) && A.isInstance(t)) {\n const s = It(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (M.isInstance(t) && M.isInstance(n)) {\n const s = Rn(\n t,\n n\n );\n return s.length ? M.isInstance(s[0]) ? {\n intersections: [],\n overlaps: s,\n count: s.length\n } : {\n intersections: s,\n overlaps: [],\n count: s.length\n } : { intersections: [], overlaps: [], count: 0 };\n }\n if (M.isInstance(t) && A.isInstance(n) || M.isInstance(n) && A.isInstance(t)) {\n const s = D(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (A.isInstance(t) && A.isInstance(n)) {\n const s = zn(\n t,\n n\n );\n return s.length ? A.isInstance(s[0]) ? {\n intersections: [],\n overlaps: s,\n count: s.length\n } : {\n intersections: s,\n overlaps: [],\n count: s.length\n } : { intersections: [], overlaps: [], count: 0 };\n }\n throw new Error(\"Not implemented\");\n}\nfunction $t(t) {\n const n = [];\n for (let e = 0; e < t; e++)\n for (let s = 0; s <= e; s++)\n n.push([e, s]);\n return n;\n}\nfunction* it(t) {\n for (const [n, e] of $t(t.length))\n n !== e && (yield [t[n], t[e]]);\n}\nclass Yt extends ut {\n constructor(e, { ignoreChecks: s = !1 } = {}) {\n super();\n b(this, \"segments\");\n b(this, \"_boundingBox\", null);\n s || Xt(e), this.segments = e;\n }\n get repr() {\n return this.segments.map((e) => e.repr).join(`\n`) + `\n`;\n }\n get info() {\n return this.repr;\n }\n get firstPoint() {\n return this.segments[0].firstPoint;\n }\n get lastPoint() {\n return this.segments[this.segments.length - 1].lastPoint;\n }\n get segmentsCount() {\n return this.segments.length;\n }\n onStroke(e) {\n return this.segments.some((s) => s.isOnSegment(e));\n }\n intersects(e) {\n return this.boundingBox.overlaps(e.boundingBox) ? this.segments.some(\n (s) => e.segments.some(\n (i) => Z(s, i).count > 0\n )\n ) : !1;\n }\n overlappingSegments(e) {\n return this.segments.flatMap((s) => e.segments.flatMap((i) => s.boundingBox.overlaps(i.boundingBox) ? Z(s, i).overlaps : []));\n }\n get boundingBox() {\n if (this._boundingBox === null) {\n let e = this.segments[0].boundingBox;\n this.segments.slice(1).forEach((s) => {\n e = e.merge(s.boundingBox);\n }), this._boundingBox = e;\n }\n return this._boundingBox;\n }\n [Symbol.for(\"nodejs.util.inspect.custom\")]() {\n return this.repr;\n }\n}\nfunction Nn(t, n = \"Stroke\") {\n $t(t.length).forEach(\n ([e, s]) => {\n if (e === s) return;\n const i = t[e], r = t[s], l = Z(i, r), o = Math.max(i.precision, r.precision);\n if (l.count !== 0) {\n if (l.count === 1 && !l.overlaps.length) {\n const u = e - s, a = l.intersections[0];\n if (u === 1 && P(i.firstPoint, a, o) || u === -1 && P(i.lastPoint, a, o) || u === t.length - 1 && P(i.lastPoint, a, o) && P(r.firstPoint, a, o) || -u === t.length - 1 && P(i.firstPoint, a, o) && P(r.lastPoint, a, o))\n return;\n }\n if (!(l.count === 2 && t.length === 2 && (P(\n i.firstPoint,\n l.intersections[0],\n o\n ) && P(\n i.lastPoint,\n l.intersections[1],\n o\n ) || P(\n i.firstPoint,\n l.intersections[1],\n o\n ) && P(\n i.lastPoint,\n l.intersections[0],\n o\n ))))\n throw new Error(\n `${n} segments must not intersect, but segments ${i.info} and ${r.info} do at ${JSON.stringify(\n l.intersections\n )}`\n );\n }\n }\n );\n}\nfunction Xt(t, n = \"Stroke\") {\n if (t.length === 0)\n throw new Error(`${n} must have at least one segment`);\n V([t.slice(0, -1), t.slice(1)]).forEach(\n ([e, s]) => {\n if (!P(e.lastPoint, s.firstPoint))\n throw new Error(\n `${n} segments must be connected, but ${e.info} and ${s.info} are not`\n );\n }\n ), Nn(t, n);\n}\nfunction bt(t, n) {\n return !!(y.isInstance(t) && y.isInstance(n) && dn(t.V, n.V) || x.isInstance(t) && x.isInstance(n) && P(t.center, n.center) && t.radius - n.radius < t.precision);\n}\nfunction Ct(t, n) {\n if (y.isInstance(t) && y.isInstance(n))\n return new y(t.firstPoint, n.lastPoint);\n if (x.isInstance(t) && x.isInstance(n))\n return new x(\n t.firstPoint,\n n.lastPoint,\n t.center,\n t.clockwise\n );\n throw new Error(\"Not implemented\");\n}\nfunction Gt(t) {\n let n = !1;\n const e = [];\n for (const s of t.segments) {\n if (e.length === 0) {\n e.push(s);\n continue;\n }\n const i = e[e.length - 1];\n bt(i, s) ? (n = !0, e.pop(), e.push(Ct(i, s))) : e.push(s);\n }\n if (P(t.firstPoint, t.lastPoint) && bt(\n e[0],\n e[e.length - 1]\n )) {\n n = !0;\n const s = e.pop();\n e[0] = Ct(s, e[0]);\n }\n return n ? e : null;\n}\nconst Mt = Symbol.for(\"pantograph:Strand\");\nclass B extends Yt {\n constructor(e, { ignoreChecks: s = !1 } = {}) {\n super(e, { ignoreChecks: s });\n b(this, \"strokeType\", \"STRAND\");\n Object.defineProperty(this, Mt, { value: !0 });\n }\n static isInstance(e) {\n return !!e && e[Mt] === !0;\n }\n reverse() {\n const e = this.segments.map((s) => s.reverse());\n return e.reverse(), new B(e, { ignoreChecks: !0 });\n }\n clone() {\n return new B(\n this.segments.map((e) => e.clone()),\n { ignoreChecks: !0 }\n );\n }\n extend(e) {\n if (!P(this.lastPoint, e.firstPoint))\n throw console.error(this.repr, e.repr), new Error(\"Cannot extend strand: connection point is not the same\");\n return new B([...this.segments, ...e.segments]);\n }\n simplify() {\n const e = Gt(this);\n return e ? new B(e, { ignoreChecks: !0 }) : this;\n }\n transform(e) {\n return new B(\n this.segments.map((s) => s.transform(e)),\n { ignoreChecks: !0 }\n );\n }\n}\nconst Vn = (t, n) => {\n const e = mn(n, {\n V: [1, 0],\n firstPoint: t,\n precision: n.precision\n });\n if (e === \"parallel\")\n return 0;\n const { intersectionParam1: s, intersectionParam2: i } = e;\n if (!n.isValidParameter(s) || i <= -n.precision) return 0;\n if (Math.abs(s) < n.precision || Math.abs(s - 1) < n.precision) {\n const [, r] = n.midPoint;\n return t[1] - r < 0 ? 1 : 0;\n }\n return 1;\n};\nclass at {\n constructor(n) {\n b(this, \"_count\", 0);\n b(this, \"segment\");\n this.segment = n;\n }\n update(n, e = !1) {\n !e && !this.segment.isOnSegment(n) || (P(n, this.segment.firstPoint) ? this._count += this.segment.tangentAtFirstPoint[1] > 0 ? 1 : 0 : P(n, this.segment.lastPoint) ? this._count += this.segment.tangentAtLastPoint[1] > 0 ? 0 : 1 : this._count += 1);\n }\n get count() {\n return this._count;\n }\n}\nconst jn = (t, n) => {\n const e = n.precision, s = Math.abs(t[1] - n.center[1]);\n if (s > n.radius + e) return 0;\n const i = gn(t, n.center), r = n.radius * n.radius, l = e * e;\n if (Math.abs(i - r) < l && n.isOnSegment(t))\n return 0;\n const o = i - r > l;\n if (o && n.center[0] < t[0]) return 0;\n const u = Math.sqrt(\n n.radius * n.radius - s * s\n ), a = new at(n);\n return a.update([n.center[0] + u, t[1]]), o && a.update([n.center[0] - u, t[1]]), a.count;\n}, Un = (t, n) => {\n const e = n.boundingBox.xMax + n.boundingBox.width / 2, s = new y(t, [e, t[1]]), i = new at(n);\n return st(s, n).forEach((r) => {\n i.update(r, !0);\n }), i.count;\n}, Hn = (t, n) => {\n const e = new at(n);\n return n.paramsAtY(t[1]).map((s) => {\n try {\n return n.paramPoint(s);\n } catch {\n return null;\n }\n }).filter((s) => s !== null).filter((s) => {\n const [i] = s;\n return i >= t[0];\n }).forEach((s) => {\n e.update(s, !0);\n }), e.count;\n};\nfunction $n(t, n) {\n if (y.isInstance(n))\n return Vn(t, n);\n if (x.isInstance(n))\n return jn(t, n);\n if (C.isInstance(n))\n return Un(t, n);\n if (A.isInstance(n) || M.isInstance(n))\n return Hn(t, n);\n throw new Error(\"Not implemented\");\n}\nconst At = Symbol.for(\"pantograph:Loop\");\nclass _ extends Yt {\n constructor(e, { ignoreChecks: s = !1 } = {}) {\n super(e, { ignoreChecks: !0 });\n b(this, \"strokeType\", \"LOOP\");\n b(this, \"_clockwise\", null);\n Object.defineProperty(this, At, { value: !0 }), s || Yn(e);\n }\n static isInstance(e) {\n return !!e && e[At] === !0;\n }\n get clockwise() {\n if (this._clockwise === null) {\n const e = this.segments.flatMap((i) => y.isInstance(i) ? [i.firstPoint] : [i.firstPoint, i.paramPoint(0.5)]), s = e.map((i, r) => {\n const l = e[(r + 1) % e.length];\n return (l[0] - i[0]) * (l[1] + i[1]);\n }).reduce((i, r) => i + r, 0);\n this._clockwise = s > 0;\n }\n return this._clockwise;\n }\n clone() {\n return new _(\n this.segments.map((e) => e.clone()),\n { ignoreChecks: !0 }\n );\n }\n reverse() {\n const e = this.segments.map((s) => s.reverse());\n return e.reverse(), new _(e, { ignoreChecks: !0 });\n }\n transform(e) {\n return new _(\n this.segments.map((s) => s.transform(e)),\n { ignoreChecks: !0 }\n );\n }\n contains(e, { strokeIsInside: s = !1 } = {}) {\n return this.onStroke(e) ? s : this.boundingBox.contains(e) ? this.segments.reduce((r, l) => r + $n(e, l), 0) % 2 === 1 : !1;\n }\n simplify() {\n const e = Gt(this);\n return e ? new _(e, { ignoreChecks: !0 }) : this;\n }\n}\nfunction Yn(t) {\n if (Xt(t, \"Loop\"), !P(t[0].firstPoint, t[t.length - 1].lastPoint))\n throw new Error(\"Loop segment must be closed\");\n}\nconst Xn = [\n y,\n x,\n C,\n M,\n A\n];\nfunction Gn(t) {\n return Xn.some((n) => n.isInstance(t));\n}\nfunction Qt(t) {\n if (y.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint\n };\n if (x.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n center: t.center,\n clockwise: t.clockwise\n };\n if (C.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n center: t.center,\n clockwise: t.clockwise,\n majorRadius: t.majorRadius,\n minorRadius: t.minorRadius,\n tiltAngle: t.tiltAngle\n };\n if (M.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n controlPoint: t.controlPoint\n };\n if (A.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n firstControlPoint: t.firstControlPoint,\n lastControlPoint: t.lastControlPoint\n };\n throw new Error(\"Unknown segment type\");\n}\nfunction rt(t) {\n return {\n type: \"LOOP\",\n segments: t.segments.map(Qt)\n };\n}\nfunction Wt(t) {\n return {\n type: \"FIGURE\",\n contour: rt(t.contour),\n holes: t.holes.map(rt)\n };\n}\nfunction Qn(t) {\n return {\n type: \"DIAGRAM\",\n figures: t.figures.map(Wt)\n };\n}\nfunction Et(t) {\n if (O.isInstance(t))\n return Qn(t);\n if (v.isInstance(t))\n return Wt(t);\n if (_.isInstance(t))\n return rt(t);\n if (Gn(t))\n return Qt(t);\n throw new Error(\"Unknown shape type\");\n}\nclass Wn {\n constructor() {\n this.ids = [], this.values = [], this.length = 0;\n }\n clear() {\n this.length = 0;\n }\n push(n, e) {\n let s = this.length++;\n for (; s > 0; ) {\n const i = s - 1 >> 1, r = this.values[i];\n if (e >= r) break;\n this.ids[s] = this.ids[i], this.values[s] = r, s = i;\n }\n this.ids[s] = n, this.values[s] = e;\n }\n pop() {\n if (this.length === 0) return;\n const n = this.ids[0];\n if (this.length--, this.length > 0) {\n const e = this.ids[0] = this.ids[this.length], s = this.values[0] = this.values[this.length], i = this.length >> 1;\n let r = 0;\n for (; r < i; ) {\n let l = (r << 1) + 1;\n const o = l + 1;\n let u = this.ids[l], a = this.values[l];\n const f = this.values[o];\n if (o < this.length && f < a && (l = o, u = this.ids[o], a = f), a >= s) break;\n this.ids[r] = u, this.values[r] = a, r = l;\n }\n this.ids[r] = e, this.values[r] = s;\n }\n return n;\n }\n peek() {\n if (this.length !== 0)\n return this.ids[0];\n }\n peekValue() {\n if (this.length !== 0)\n return this.values[0];\n }\n shrink() {\n this.ids.length = this.values.length = this.length;\n }\n}\nconst Ft = [Int8Array, Uint8Array, Uint8ClampedArray, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array], et = 3;\nclass ft {\n /**\n * Recreate a Flatbush index from raw `ArrayBuffer` or `SharedArrayBuffer` data.\n * @param {ArrayBuffer | SharedArrayBuffer} data\n * @param {number} [byteOffset=0] byte offset to the start of the Flatbush buffer in the referenced ArrayBuffer.\n * @returns {Flatbush} index\n */\n static from(n, e = 0) {\n if (e % 8 !== 0)\n throw new Error(\"byteOffset must be 8-byte aligned.\");\n if (!n || n.byteLength === void 0 || n.buffer)\n throw new Error(\"Data must be an instance of ArrayBuffer or SharedArrayBuffer.\");\n const [s, i] = new Uint8Array(n, e + 0, 2);\n if (s !== 251)\n throw new Error(\"Data does not appear to be in a Flatbush format.\");\n const r = i >> 4;\n if (r !== et)\n throw new Error(`Got v${r} data when expected v${et}.`);\n const l = Ft[i & 15];\n if (!l)\n throw new Error(\"Unrecognized array type.\");\n const [o] = new Uint16Array(n, e + 2, 1), [u] = new Uint32Array(n, e + 4, 1);\n return new ft(u, o, l, void 0, n, e);\n }\n /**\n * Create a Flatbush index that will hold a given number of items.\n * @param {number} numItems\n * @param {number} [nodeSize=16] Size of the tree node (16 by default).\n * @param {TypedArrayConstructor} [ArrayType=Float64Array] The array type used for coordinates storage (`Float64Array` by default).\n * @param {ArrayBufferConstructor | SharedArrayBufferConstructor} [ArrayBufferType=ArrayBuffer] The array buffer type used to store data (`ArrayBuffer` by default).\n * @param {ArrayBuffer | SharedArrayBuffer} [data] (Only used internally)\n * @param {number} [byteOffset=0] (Only used internally)\n */\n constructor(n, e = 16, s = Float64Array, i = ArrayBuffer, r, l = 0) {\n if (n === void 0) throw new Error(\"Missing required argument: numItems.\");\n if (isNaN(n) || n <= 0) throw new Error(`Unexpected numItems value: ${n}.`);\n this.numItems = +n, this.nodeSize = Math.min(Math.max(+e, 2), 65535), this.byteOffset = l;\n let o = n, u = o;\n this._levelBounds = [o * 4];\n do\n o = Math.ceil(o / this.nodeSize), u += o, this._levelBounds.push(u * 4);\n while (o !== 1);\n this.ArrayType = s, this.IndexArrayType = u < 16384 ? Uint16Array : Uint32Array;\n const a = Ft.indexOf(this.ArrayType), f = u * 4 * this.ArrayType.BYTES_PER_ELEMENT;\n if (a < 0)\n throw new Error(`Unexpected typed array class: ${s}.`);\n r && r.byteLength !== void 0 && !r.buffer ? (this.data = r, this._boxes = new this.ArrayType(this.data, l + 8, u * 4), this._indices = new this.IndexArrayType(this.data, l + 8 + f, u), this._pos = u * 4, this.minX = this._boxes[this._pos - 4], this.minY = this._boxes[this._pos - 3], this.maxX = this._boxes[this._pos - 2], this.maxY = this._boxes[this._pos - 1]) : (this.data = new i(8 + f + u * this.IndexArrayType.BYTES_PER_ELEMENT), this._boxes = new this.ArrayType(this.data, 8, u * 4), this._indices = new this.IndexArrayType(this.data, 8 + f, u), this._pos = 0, this.minX = 1 / 0, this.minY = 1 / 0, this.maxX = -1 / 0, this.maxY = -1 / 0, new Uint8Array(this.data, 0, 2).set([251, (et << 4) + a]), new Uint16Array(this.data, 2, 1)[0] = e, new Uint32Array(this.data, 4, 1)[0] = n), this._queue = new Wn();\n }\n /**\n * Add a given rectangle to the index.\n * @param {number} minX\n * @param {number} minY\n * @param {number} maxX\n * @param {number} maxY\n * @returns {number} A zero-based, incremental number that represents the newly added rectangle.\n */\n add(n, e, s = n, i = e) {\n const r = this._pos >> 2, l = this._boxes;\n return this._indices[r] = r, l[this._pos++] = n, l[this._pos++] = e, l[this._pos++] = s, l[this._pos++] = i, n < this.minX && (this.minX = n), e < this.minY && (this.minY = e), s > this.maxX && (this.maxX = s), i > this.maxY && (this.maxY = i), r;\n }\n /** Perform indexing of the added rectangles. */\n finish() {\n if (this._pos >> 2 !== this.numItems)\n throw new Error(`Added ${this._pos >> 2} items when expected ${this.numItems}.`);\n const n = this._boxes;\n if (this.numItems <= this.nodeSize) {\n n[this._pos++] = this.minX, n[this._pos++] = this.minY, n[this._pos++] = this.maxX, n[this._pos++] = this.maxY;\n return;\n }\n const e = this.maxX - this.minX || 1, s = this.maxY - this.minY || 1, i = new Uint32Array(this.numItems), r = 65535;\n for (let l = 0, o = 0; l < this.numItems; l++) {\n const u = n[o++], a = n[o++], f = n[o++], c = n[o++], h = Math.floor(r * ((u + f) / 2 - this.minX) / e), p = Math.floor(r * ((a + c) / 2 - this.minY) / s);\n i[l] = Kn(h, p);\n }\n ot(i, n, this._indices, 0, this.numItems - 1, this.nodeSize);\n for (let l = 0, o = 0; l < this._levelBounds.length - 1; l++) {\n const u = this._levelBounds[l];\n for (; o < u; ) {\n const a = o;\n let f = n[o++], c = n[o++], h = n[o++], p = n[o++];\n for (let d = 1; d < this.nodeSize && o < u; d++)\n f = Math.min(f, n[o++]), c = Math.min(c, n[o++]), h = Math.max(h, n[o++]), p = Math.max(p, n[o++]);\n this._indices[this._pos >> 2] = a, n[this._pos++] = f, n[this._pos++] = c, n[this._pos++] = h, n[this._pos++] = p;\n }\n }\n }\n /**\n * Search the index by a bounding box.\n * @param {number} minX\n * @param {number} minY\n * @param {number} maxX\n * @param {number} maxY\n * @param {(index: number) => boolean} [filterFn] An optional function for filtering the results.\n * @returns {number[]} An array of indices of items intersecting or touching the given bounding box.\n */\n search(n, e, s, i, r) {\n if (this._pos !== this._boxes.length)\n throw new Error(\"Data not yet indexed - call index.finish().\");\n let l = this._boxes.length - 4;\n const o = [], u = [];\n for (; l !== void 0; ) {\n const a = Math.min(l + this.nodeSize * 4, Bt(l, this._levelBounds));\n for (let f = l; f < a; f += 4) {\n if (s < this._boxes[f] || i < this._boxes[f + 1] || n > this._boxes[f + 2] || e > this._boxes[f + 3]) continue;\n const c = this._indices[f >> 2] | 0;\n l >= this.numItems * 4 ? o.push(c) : (r === void 0 || r(c)) && u.push(c);\n }\n l = o.pop();\n }\n return u;\n }\n /**\n * Search items in order of distance from the given point.\n * @param {number} x\n * @param {number} y\n * @param {number} [maxResults=Infinity]\n * @param {number} [maxDistance=Infinity]\n * @param {(index: number) => boolean} [filterFn] An optional function for filtering the results.\n * @returns {number[]} An array of indices of items found.\n */\n neighbors(n, e, s = 1 / 0, i = 1 / 0, r) {\n if (this._pos !== this._boxes.length)\n throw new Error(\"Data not yet indexed - call index.finish().\");\n let l = this._boxes.length - 4;\n const o = this._queue, u = [], a = i * i;\n t: for (; l !== void 0; ) {\n const f = Math.min(l + this.nodeSize * 4, Bt(l, this._levelBounds));\n for (let c = l; c < f; c += 4) {\n const h = this._indices[c >> 2] | 0, p = vt(n, this._boxes[c], this._boxes[c + 2]), d = vt(e, this._boxes[c + 1], this._boxes[c + 3]), m = p * p + d * d;\n m > a || (l >= this.numItems * 4 ? o.push(h << 1, m) : (r === void 0 || r(h)) && o.push((h << 1) + 1, m));\n }\n for (; o.length && o.peek() & 1; )\n if (o.peekValue() > a || (u.push(o.pop() >> 1), u.length === s)) break t;\n l = o.length ? o.pop() >> 1 : void 0;\n }\n return o.clear(), u;\n }\n}\nfunction vt(t, n, e) {\n return t < n ? n - t : t <= e ? 0 : t - e;\n}\nfunction Bt(t, n) {\n let e = 0, s = n.length - 1;\n for (; e < s; ) {\n const i = e + s >> 1;\n n[i] > t ? s = i : e = i + 1;\n }\n return n[e];\n}\nfunction ot(t, n, e, s, i, r) {\n if (Math.floor(s / r) >= Math.floor(i / r)) return;\n const l = t[s + i >> 1];\n let o = s - 1, u = i + 1;\n for (; ; ) {\n do\n o++;\n while (t[o] < l);\n do\n u--;\n while (t[u] > l);\n if (o >= u) break;\n Jn(t, n, e, o, u);\n }\n ot(t, n, e, s, u, r), ot(t, n, e, u + 1, i, r);\n}\nfunction Jn(t, n, e, s, i) {\n const r = t[s];\n t[s] = t[i], t[i] = r;\n const l = 4 * s, o = 4 * i, u = n[l], a = n[l + 1], f = n[l + 2], c = n[l + 3];\n n[l] = n[o], n[l + 1] = n[o + 1], n[l + 2] = n[o + 2], n[l + 3] = n[o + 3], n[o] = u, n[o + 1] = a, n[o + 2] = f, n[o + 3] = c;\n const h = e[s];\n e[s] = e[i], e[i] = h;\n}\nfunction Kn(t, n) {\n let e = t ^ n, s = 65535 ^ e, i = 65535 ^ (t | n), r = t & (n ^ 65535), l = e | s >> 1, o = e >> 1 ^ e, u = i >> 1 ^ s & r >> 1 ^ i, a = e & i >> 1 ^ r >> 1 ^ r;\n e = l, s = o, i = u, r = a, l = e & e >> 2 ^ s & s >> 2, o = e & s >> 2 ^ s & (e ^ s) >> 2, u ^= e & i >> 2 ^ s & r >> 2, a ^= s & i >> 2 ^ (e ^ s) & r >> 2, e = l, s = o, i = u, r = a, l = e & e >> 4 ^ s & s >> 4, o = e & s >> 4 ^ s & (e ^ s) >> 4, u ^= e & i >> 4 ^ s & r >> 4, a ^= s & i >> 4 ^ (e ^ s) & r >> 4, e = l, s = o, i = u, r = a, u ^= e & i >> 8 ^ s & r >> 8, a ^= s & i >> 8 ^ (e ^ s) & r >> 8, e = u ^ u >> 1, s = a ^ a >> 1;\n let f = t ^ n, c = s | 65535 ^ (f | e);\n return f = (f | f << 8) & 16711935, f = (f | f << 4) & 252645135, f = (f | f << 2) & 858993459, f = (f | f << 1) & 1431655765, c = (c | c << 8) & 16711935, c = (c | c << 4) & 252645135, c = (c | c << 2) & 858993459, c = (c | c << 1) & 1431655765, (c << 1 | f) >>> 0;\n}\nfunction Jt(t, n = 1e-7) {\n if (t.length === 0) return [];\n if (t.length === 1) return [t];\n const e = new ft(t.length);\n t.forEach((r) => {\n const [l, o] = r.firstPoint;\n e.add(l - n, o - n, l + n, o + n);\n }), e.finish();\n const s = [], i = /* @__PURE__ */ new Set();\n return t.forEach((r, l) => {\n if (i.has(l)) return;\n const o = [r];\n let u = l;\n i.add(l);\n let a = t.length;\n for (; ; ) {\n if (a-- < 0)\n throw new Error(\"Infinite loop detected\");\n const f = o[o.length - 1].lastPoint, [c, h] = f, p = e.search(\n c - n,\n h - n,\n c + n,\n h + n\n ), d = (I) => Math.abs((u - I) % t.length), m = p.filter((I) => !i.has(I)).map((I) => [\n t[I],\n I,\n d(I)\n ]).sort(([, , I], [, , F]) => d(I) - d(F));\n if (m.length === 0) {\n s.push(o);\n break;\n }\n const [w, g] = m[0];\n o.push(w), i.add(g), u = g;\n }\n }), s;\n}\nconst kt = Symbol.for(\"pantograph:Figure\");\nclass v extends ut {\n constructor(e, s = [], { ignoreChecks: i = !1 } = {}) {\n super();\n b(this, \"contour\");\n b(this, \"holes\");\n Object.defineProperty(this, kt, { value: !0 }), i || Zn(e, s), this.contour = e, this.holes = s;\n }\n static isInstance(e) {\n return !!e && e[kt] === !0;\n }\n get boundingBox() {\n return this.contour.boundingBox;\n }\n get isFull() {\n return this.holes.length === 0;\n }\n get allLoops() {\n return [this.contour, ...this.holes];\n }\n clone() {\n return new v(\n this.contour.clone(),\n this.holes.map((e) => e.clone())\n );\n }\n transform(e) {\n return new v(\n this.contour.transform(e),\n this.holes.map((s) => s.transform(e))\n );\n }\n contains(e, { strokeIsInside: s = !1 } = {}) {\n return this.contour.contains(e, { strokeIsInside: s }) && !this.holes.some((i) => i.contains(e, { strokeIsInside: s }));\n }\n intersects(e) {\n return this.allLoops.some(\n (s) => e.allLoops.some((i) => s.intersects(i))\n );\n }\n overlappingStrands(e) {\n const s = v.isInstance(e) ? e.allLoops : [e], i = this.allLoops.flatMap((r) => s.flatMap((l) => r.overlappingSegments(l)));\n return Jt(i).map((r) => new B(r));\n }\n}\nfunction Zn(t, n = []) {\n if (!t) throw new Error(\"Figure must have a contour\");\n for (const [e, s] of it([t, ...n]))\n if (e.intersects(s))\n throw new Error(\"Loops in a figure must not intersect\");\n if (n.some(\n (e) => !t.contains(e.firstPoint) && !t.onStroke(e.firstPoint)\n ))\n throw new Error(\"Holes must be inside the contour\");\n for (const [e, s] of it(n))\n if (e.contains(s.firstPoint))\n throw console.error(Et(e), Et(s)), new Error(\"Holes must not be inside other holes\");\n}\nconst J = (t, n, e = 1e-7) => Math.abs(t - n) <= e, te = (t, n) => {\n const e = t.boundingBox, s = n.boundingBox;\n return J(e.xMin, s.xMin) && J(e.yMin, s.yMin) && J(e.xMax, s.xMax) && J(e.yMax, s.yMax);\n}, ne = (t, n) => {\n if (t.segmentsCount !== n.segmentsCount || !te(t, n)) return !1;\n const e = t.segments, s = n.segments, i = e.length, r = (l, o) => {\n for (let u = 0; u < i; u += 1) {\n const a = (l + o * u + i) % i;\n if (!e[u].isSame(s[a])) return !1;\n }\n return !0;\n };\n for (let l = 0; l < i; l += 1)\n if (e[0].isSame(s[l]) && (r(l, 1) || r(l, -1)))\n return !0;\n return !1;\n}, ee = (t) => {\n const n = [];\n return t.forEach((e) => {\n n.some((s) => ne(e, s)) || n.push(e);\n }), n;\n}, se = (t) => {\n const n = t.map((i, r) => t.slice(r + 1).map((l, o) => [o + r + 1, l]).filter(([, l]) => i.boundingBox.overlaps(l.boundingBox)).map(([l]) => l)), e = [], s = Array(n.length);\n return n.forEach((i, r) => {\n let l = s[r];\n l || (l = [], e.push(l)), l.push(t[r]), i.length && i.forEach((o) => {\n s[o] = l;\n });\n }), e;\n}, Kt = (t) => t.map((n, e) => {\n const i = n.segments[0].midPoint, r = t.filter((l, o) => e === o ? !1 : l.contains(i));\n return {\n loop: n,\n isIn: r\n };\n}), ie = (t, n) => t.flatMap(({ loop: e }) => ht(\n n.filter(\n ({ loop: s, isIn: i }) => s === e || i.indexOf(e) !== -1\n )\n)), re = (t, n) => {\n const e = n.filter(({ isIn: i }) => i.length <= 1), s = ht(\n Kt(t.map(({ loop: i }) => i))\n );\n return [e, ...s];\n}, ht = (t) => {\n if (!t.length) return [];\n const n = t.filter(({ isIn: s }) => !s.length), e = t.filter(({ isIn: s }) => s.length > 1);\n return n.length === 1 && e.length === 0 ? [t] : n.length > 1 ? ie(n, t) : re(e, t);\n};\nfunction X(t) {\n const n = ee(t);\n return se(n).map(Kt).flatMap(ht).map((s) => {\n if (s.length === 1) return new v(s[0].loop);\n s.sort((l, o) => l.isIn.length - o.isIn.length);\n const [i, ...r] = s.map(({ loop: l }) => l);\n return new v(i, r);\n });\n}\nfunction oe(t, n) {\n const e = [];\n for (const s of t)\n for (const i of n)\n e.push([s, i]);\n return e;\n}\nfunction* Ot(t, n, e) {\n const s = (o) => n.some((u) => P(u, o.lastPoint)), i = (o, u) => o.segmentType !== u.segmentType || !u.isOnSegment(o.firstPoint) || !u.isOnSegment(o.lastPoint) ? !1 : o.segmentType !== \"LINE\" ? u.isOnSegment(o.midPoint) : !0, r = (o) => e.some((u) => o.isSame(u) || i(o, u));\n let l = [];\n for (const o of t)\n s(o) ? (l.push(o), yield new B(l, { ignoreChecks: !0 }), l = []) : r(o) ? (l.length && (yield new B(l, { ignoreChecks: !0 }), l = []), yield new B([o], { ignoreChecks: !0 })) : l.push(o);\n l.length && (yield new B(l, { ignoreChecks: !0 }));\n}\nconst _t = (t, n) => {\n const e = t.findIndex((r) => P(n, r.firstPoint)), s = t.slice(0, e);\n return t.slice(e).concat(s);\n}, Tt = (t, n) => {\n let e = t;\n const s = (o) => P(o.firstPoint, n.firstPoint) && P(o.lastPoint, n.lastPoint);\n let i = t.findIndex(s);\n if (i === -1) {\n const o = t.map((u) => u.reverse());\n if (o.reverse(), i = o.findIndex(s), i === -1)\n throw console.error(\n o.map((u) => u.repr),\n n.repr\n ), new Error(\"Failed to rotate to segment start\");\n e = o;\n }\n const r = e.slice(0, i);\n return e.slice(i).concat(r);\n};\nfunction le(t, n, e) {\n return t.filter((s) => {\n const i = n.filter((o) => P(o.firstPoint, s) || P(o.lastPoint, s));\n if (i.length % 2)\n throw new Error(\"Bug in the intersection algo on non crossing point\");\n const r = i.map((o) => e.contains(o.midPoint));\n return !(r.every((o) => o) || !r.some((o) => o));\n });\n}\nfunction ue(t, n, e, s = !1) {\n let i = [];\n const r = [], l = new Array(t.segments.length).fill(0).map(() => []), o = new Array(n.segments.length).fill(0).map(() => []);\n if (t.segments.forEach((p, d) => {\n n.segments.forEach((m, w) => {\n const { intersections: g, overlaps: I } = Z(\n p,\n m,\n e\n );\n i.push(...g), l[d].push(...g), o[w].push(...g), r.push(...I);\n const F = I.flatMap((S) => [\n S.firstPoint,\n S.lastPoint\n ]);\n i.push(...F), l[d].push(...F), o[w].push(...F);\n });\n }), i = j(i, e), !i.length || i.length === 1) return null;\n const u = ([p, d]) => d.length ? p.splitAt(d) : [p];\n let a = V([t.segments, l]).flatMap(u), f = V([n.segments, o]).flatMap(u);\n if (i = le(\n i,\n a,\n n\n ), !i.length && !r.length) return null;\n if (r.length) {\n const p = r[0];\n a = Tt(\n a,\n p\n ), f = Tt(\n f,\n p\n );\n } else {\n const p = i[0];\n a = _t(a, p), f = _t(f, p);\n }\n let c = Array.from(\n Ot(\n a,\n i,\n r\n )\n ), h = Array.from(\n Ot(\n f,\n i,\n r\n )\n );\n return (!P(\n h[0].lastPoint,\n c[0].lastPoint\n ) || r.length > 0 && h[0].segmentsCount !== 1) && (h = h.map((p) => p.reverse()).reverse(), P(h[0].lastPoint, c[0].lastPoint) || (c = c.map((p) => p.reverse()).reverse())), V([c, h]).map(([p, d]) => {\n if (s) {\n if (((w) => w.segments.every(\n (g) => r.some(\n (I) => g.isSame(I) || g.segmentType === I.segmentType && I.isOnSegment(g.firstPoint) && I.isOnSegment(g.lastPoint) && (g.segmentType === \"LINE\" || I.isOnSegment(g.midPoint))\n )\n ))(p))\n return [p, \"same\"];\n } else if (p.segmentsCount === 1 && r.some((m) => p.segments[0].isSame(m)))\n return [p, \"same\"];\n return [p, d];\n });\n}\nfunction Lt(t) {\n let n = t[0];\n for (const e of t.slice(1))\n n = n.extend(e);\n if (!P(n.firstPoint, n.lastPoint))\n throw console.error(\n mt(n.firstPoint),\n mt(n.lastPoint)\n ), new Error(\"Bug in the intersection algo on non closing strand\");\n return new _(n.segments);\n}\nfunction ce(t, n) {\n const e = V([\n n.slice(0, -1),\n n.slice(1)\n ]).map(([i, r]) => Lt(t.slice(i, r)));\n let s = t.slice(\n n[n.length - 1]\n );\n return n[0] !== 0 && (s = s.concat(t.slice(0, n[0]))), e.push(Lt(s)), e;\n}\nfunction ae(t) {\n if (!t.length) return [];\n const n = t.map((i) => i.firstPoint);\n let e = t.map((i) => i.lastPoint);\n e = e.slice(-1).concat(e.slice(0, -1));\n const s = V([n, e]).flatMap(\n ([i, r], l) => P(i, r) ? [] : l\n );\n try {\n return ce(t, s);\n } catch {\n return Jt(t.flatMap((r) => r.segments)).filter((r) => r.length > 1).filter((r) => P(r[0].firstPoint, r.at(-1).lastPoint)).map((r) => new _(r));\n }\n}\nconst qt = (t, n) => {\n if (t.length === 0) return [n];\n const e = t.at(-1);\n return P(e.lastPoint, n.firstPoint) ? t.slice(0, -1).concat([e.extend(n)]) : P(e.lastPoint, n.lastPoint) ? t.slice(0, -1).concat([e.extend(n.reverse())]) : t.concat([n]);\n}, fe = (t, n) => t.length === 0 ? [n] : P(t[0].firstPoint, n.lastPoint) ? [n.extend(t[0])].concat(t.slice(1)) : [n].concat(t);\nfunction pt(t, n, {\n firstInside: e,\n secondInside: s,\n firstBoundaryInside: i = !1,\n secondBoundaryInside: r = !1\n}) {\n const l = ue(\n t,\n n,\n void 0,\n i || r\n );\n if (!l) {\n const f = t.segments[0].midPoint, c = n.contains(f, {\n strokeIsInside: r\n }), h = n.segments[0].midPoint, p = t.contains(h, {\n strokeIsInside: i\n });\n return {\n identical: !1,\n firstCurveInSecond: c,\n secondCurveInFirst: p\n };\n }\n if (l.every(([, f]) => f === \"same\"))\n return { identical: !0 };\n let o = null, u = null;\n const a = l.flatMap(([f, c]) => {\n let h = [], p = 0;\n if (c === \"same\")\n return u === 1 ? (u = 1, f) : u === 2 || u === 0 ? (u = null, []) : u === null ? (o ? o = o.extend(f) : o = f, []) : (console.error(\"weird situation\"), []);\n const d = f.segments[0].midPoint, m = n.contains(d, {\n strokeIsInside: r\n });\n (e === \"keep\" && m || e === \"remove\" && !m) && (p += 1, h = qt(h, f));\n const w = c.segments[0].midPoint, g = t.contains(w, {\n strokeIsInside: i\n });\n if (s === \"keep\" && g || s === \"remove\" && !g) {\n const I = c;\n p += 1, p === 2 && h.length ? (h = qt(h, I), o = null) : h = [I];\n }\n return u === null && p === 1 && o && (h = fe(h, o)), p === 1 && (u = p, o = null), h.length ? h : (o = null, []);\n });\n return ae(a);\n}\nconst he = (t, n, e) => {\n const s = pt(t, n, {\n firstInside: \"remove\",\n secondInside: \"remove\",\n ...e\n });\n return Array.isArray(s) ? s : s.identical ? [t] : s.firstCurveInSecond ? [n] : s.secondCurveInFirst ? [t] : [t, n];\n}, tt = (t, n, e) => {\n const s = pt(t, n, {\n firstInside: \"remove\",\n secondInside: \"keep\",\n ...e\n });\n return Array.isArray(s) ? s : s.identical ? [] : s.firstCurveInSecond ? [] : s.secondCurveInFirst ? [t, n] : [t];\n}, dt = (t, n, e) => {\n const s = (e == null ? void 0 : e.firstBoundaryInside) ?? !1, i = (e == null ? void 0 : e.secondBoundaryInside) ?? !1, r = s || i, l = (u, a, f) => u.segments.every(\n (c) => a.contains(c.midPoint, { strokeIsInside: f })\n );\n if (r) {\n if (l(t, n, i))\n return [t];\n if (l(n, t, s))\n return [n];\n }\n const o = pt(t, n, {\n firstInside: \"keep\",\n secondInside: \"keep\",\n ...e\n });\n return Array.isArray(o) ? o : o.identical ? [t] : o.firstCurveInSecond ? [t] : o.secondCurveInFirst ? [n] : [];\n};\nfunction pe(t) {\n const n = /* @__PURE__ */ new Map(), e = [];\n return t.forEach((s, i) => {\n let r;\n n.has(i) ? r = n.get(i) : (r = { current: [s], fusedWith: /* @__PURE__ */ new Set([i]) }, e.push(r)), t.slice(i + 1).forEach((l, o) => {\n const u = r.current, a = i + o + 1;\n if (r.fusedWith.has(a)) return;\n let f = [l], c = !1;\n if (n.has(a) && (f = n.get(a).current, c = !0), !u.some(\n (d) => f.some((m) => d.intersects(m))\n )) return;\n let p;\n u.length > 1 || f.length > 1 ? p = G(u, f) : p = Zt(u[0], f[0]), r.fusedWith.add(a), r.current = p, c || n.set(a, r);\n });\n }), e.flatMap(({ current: s }) => s);\n}\nfunction Zt(t, n) {\n const e = he(t.contour, n.contour), s = n.holes.flatMap((l) => tt(l, t.contour)), i = t.holes.flatMap((l) => tt(l, n.contour)), r = oe(t.holes, n.holes).flatMap(\n ([l, o]) => dt(l, o)\n );\n return X([\n ...e,\n ...s,\n ...i,\n ...r\n ]);\n}\nfunction nt(t, n) {\n if (t.isFull && n.isFull)\n return X(tt(t.contour, n.contour));\n if (t.isFull) {\n const s = tt(t.contour, n.contour), i = n.holes.flatMap(\n (r) => dt(r, t.contour, { firstBoundaryInside: !0 })\n );\n return X([...s, ...i]);\n } else if (n.isFull && !t.contour.intersects(n.contour))\n if (t.contour.contains(n.contour.firstPoint)) {\n const s = G(\n t.holes.map((i) => new v(i)),\n [n]\n );\n return X([\n t.contour,\n ...s.flatMap((i) => i.allLoops)\n ]);\n } else\n return [t];\n let e = nt(new v(t.contour), n);\n return t.holes.forEach((s) => {\n e = e.flatMap((i) => nt(i, new v(s)));\n }), e;\n}\nfunction de(t, n) {\n const e = dt(t.contour, n.contour);\n if (!e.length) return [];\n let s = X(e);\n return s = Q(\n s,\n t.holes.map((i) => new v(i))\n ), Q(\n s,\n n.holes.map((i) => new v(i))\n );\n}\nfunction G(t, n) {\n if (!t.length) return n;\n if (!n.length) return t;\n if (t.length === 1 && n.length > 1 || n.length === 1 && t.length > 1)\n return pe([...t, ...n]);\n if (t.length > 1 && n.length > 1) {\n let e = G([t[0]], n);\n return t.slice(1).forEach((s) => {\n e = G([s], e);\n }), e;\n }\n return t.length === 1 && n.length === 1 ? Zt(t[0], n[0]) : [];\n}\nfunction Q(t, n) {\n if (!t.length) return [];\n if (!n.length) return t;\n if (t.length === 1 && n.length === 1)\n return nt(t[0], n[0]);\n if (t.length > 1)\n return t.flatMap((s) => Q([s], n));\n let e = nt(t[0], n[0]);\n return n.slice(1).forEach((s) => {\n e = Q(e, [s]);\n }), e;\n}\nfunction lt(t, n) {\n return !t.length || !n.length ? [] : t.length === 1 && n.length === 1 ? de(t[0], n[0]) : t.length > 1 ? t.flatMap((e) => lt([e], n)) : n.flatMap((e) => lt(t, [e]));\n}\nconst zt = Symbol.for(\"pantograph:Diagram\");\nclass O extends ut {\n constructor(e = [], { ignoreChecks: s = !1 } = {}) {\n super();\n b(this, \"figures\");\n b(this, \"_boundingBox\", null);\n Object.defineProperty(this, zt, { value: !0 }), s || me(e), this.figures = e;\n }\n static isInstance(e) {\n return !!e && e[zt] === !0;\n }\n get isEmpty() {\n return this.figures.length === 0;\n }\n get boundingBox() {\n if (this.isEmpty) return new Pn();\n if (this._boundingBox === null) {\n let e = this.figures[0].boundingBox;\n for (const s of this.figures.slice(1))\n e = e.merge(s.boundingBox);\n this._boundingBox = e;\n }\n return this._boundingBox;\n }\n clone() {\n return new O(this.figures.map((e) => e.clone()));\n }\n transform(e) {\n return new O(this.figures.map((s) => s.transform(e)));\n }\n contains(e, { strokeIsInside: s = !1 } = {}) {\n return this.figures.some(\n (i) => i.contains(e, { strokeIsInside: s })\n );\n }\n intersects(e) {\n return this.figures.some(\n (s) => e.figures.some((i) => s.intersects(i))\n );\n }\n overlappingStrands(e) {\n return this.figures.flatMap((s) => O.isInstance(e) ? e.figures.flatMap(\n (i) => s.overlappingStrands(i)\n ) : s.overlappingStrands(e));\n }\n fuse(e) {\n return new O(G(this.figures, e.figures));\n }\n cut(e) {\n return new O(Q(this.figures, e.figures));\n }\n intersect(e) {\n return new O(lt(this.figures, e.figures));\n }\n}\nfunction me(t) {\n for (const [n, e] of it(t))\n if (n.intersects(e))\n throw new Error(\"Diagram figures must not intersect\");\n}\nexport {\n O as D,\n v as F,\n _ as L,\n B as S,\n Z as a,\n G as b,\n Q as c,\n jt as d,\n Jt as e,\n Ie as f,\n Gn as g,\n Et as h,\n lt as i,\n K as l,\n In as p,\n Ot as s\n};\n//# sourceMappingURL=models-BHeLX0dj.js.map\n","var W = Object.defineProperty;\nvar j = (e, t, n) => t in e ? W(e, t, { enumerable: !0, configurable: !0, writable: !0, value: n }) : e[t] = n;\nvar m = (e, t, n) => j(e, typeof t != \"symbol\" ? t + \"\" : t, n);\nimport { a as l, s as u, c as b, b as P, L as d, A as z, Q as w, C as D, p as x, d as q, e as T, t as k, f as Q, g as v, h as $, i as H, j as J, R as K, T as U, k as A, n as F, D as S } from \"./QuadraticBezier-BeY2TXKH.js\";\nimport { f as X, S as Z, D as tt, F as nt, L as et } from \"./models-BHeLX0dj.js\";\nconst B = (e, t, n) => {\n const r = b(e.V, t.V), i = e.precision * t.precision;\n if (r * r < i)\n return \"parallel\";\n const s = P(t.firstPoint, e.firstPoint), o = b(s, t.V) / r;\n return l(e.firstPoint, u(e.V, o));\n}, y = Symbol.for(\n \"pantograph:DegenerateSegment\"\n);\nclass C {\n constructor(t, n) {\n this.firstPoint = t, this.lastPoint = n, Object.defineProperty(this, y, { value: !0 });\n }\n static isInstance(t) {\n return !!t && t[y] === !0;\n }\n}\nfunction _(e, t) {\n if (d.isInstance(e))\n return rt(e, t);\n if (z.isInstance(e))\n return it(e, t);\n if (w.isInstance(e) || D.isInstance(e))\n return st(e, t);\n throw new Error(\"Not implemented\");\n}\nfunction rt(e, t) {\n const { firstPoint: n, lastPoint: r } = e, i = e.normalVector;\n return new d(\n l(n, u(i, t)),\n l(r, u(i, t))\n );\n}\nfunction it(e, t) {\n const n = l(\n e.firstPoint,\n u(x(e.tangentAtFirstPoint), t)\n ), r = l(\n e.lastPoint,\n u(x(e.tangentAtLastPoint), t)\n ), i = t * (e.clockwise ? 1 : -1);\n return e.radius + i < e.precision ? new C(n, r) : new z(n, r, e.center, e.clockwise);\n}\nfunction L(e, t, n, r, i) {\n const s = B(\n {\n V: n,\n firstPoint: r,\n precision: i\n },\n {\n V: P(t, e),\n firstPoint: e,\n precision: i\n }\n );\n if (s === \"parallel\")\n throw new Error(\n \"Parallel lines not expected in safe bezier offset control point calculation\"\n );\n return s;\n}\nfunction st(e, t) {\n const { firstPoint: n, lastPoint: r, normalAtFirstPoint: i, normalAtLastPoint: s } = e, o = B(\n { V: i, firstPoint: n, precision: e.precision },\n { V: s, firstPoint: r, precision: e.precision }\n ), a = l(\n n,\n u(i, t)\n ), c = l(\n r,\n u(s, t)\n );\n if (o === \"parallel\")\n throw new Error(\"Parallel lines not expected in safe bezier offset\");\n if (q(P(o, n), i) * t > 0 && Math.min(\n T(n, o),\n T(r, o)\n ) < t)\n return new C(a, c);\n if (w.isInstance(e)) {\n const f = L(\n o,\n e.controlPoint,\n e.tangentAtFirstPoint,\n a,\n e.precision\n );\n return new w(\n a,\n c,\n f\n );\n }\n const g = L(\n o,\n e.firstControlPoint,\n e.tangentAtFirstPoint,\n a,\n e.precision\n ), p = L(\n o,\n e.lastControlPoint,\n e.tangentAtLastPoint,\n c,\n e.precision\n );\n return new D(\n a,\n c,\n g,\n p\n );\n}\nfunction M(e, t, n) {\n const r = b(\n e.tangentAtLastPoint,\n t.tangentAtFirstPoint\n );\n if (Math.abs(r) < 1e-10) return null;\n const i = r > 0 ? 1 : -1, s = Math.abs(n) * i, o = _(e, s), a = _(t, s);\n if (C.isInstance(o) || C.isInstance(a))\n return null;\n let c;\n try {\n c = X(o, a, 1e-9).at(-1);\n } catch {\n return null;\n }\n if (!c)\n return null;\n const h = c, g = (E, N) => {\n const O = N.tangentAt(h), G = Q(O), Y = l(h, u(G, s));\n return E.splitAt(Y);\n }, [p] = g(e, o), [, f] = g(t, a);\n return { first: p, second: f, center: h };\n}\nfunction I(e, t, n) {\n const r = M(e, t, n);\n if (!r)\n return console.warn(\n \"Cannot fillet between segments\",\n e.repr,\n t.repr\n ), [e, t];\n const { first: i, second: s } = r;\n return [\n i,\n k(i.lastPoint, s.firstPoint, i.tangentAtLastPoint),\n s\n ];\n}\nfunction V(e, t, n) {\n const r = M(e, t, n);\n if (!r)\n return console.warn(\n \"Cannot chamfer between segments\",\n e.repr,\n t.repr\n ), [e, t];\n const { first: i, second: s } = r;\n return [i, new d(i.lastPoint, s.firstPoint), s];\n}\nconst ot = (e) => {\n let t;\n e ? typeof e == \"number\" || Array.isArray(e) && e.length === 2 ? t = { endTangent: e } : t = { endTangent: 0, ...e } : t = { endTangent: [1, 0] };\n const {\n endTangent: n,\n startFactor: r = 1,\n endFactor: i = 1,\n startTangent: s\n } = t;\n let o;\n typeof n == \"number\" ? o = A(1, n * S) : o = n;\n let a;\n return typeof s == \"number\" ? a = A(1, s * S) : a = s, { endTangent: o, startFactor: r, endFactor: i, startTangent: a };\n};\nfunction R(e, { ignoreChecks: t = !1 } = {}) {\n return new tt([new nt(new et([...e], { ignoreChecks: t }))]);\n}\nclass at {\n constructor(t = [0, 0]) {\n m(this, \"pointer\");\n m(this, \"firstPoint\");\n m(this, \"pendingSegments\");\n m(this, \"_nextCorner\");\n this.pointer = t, this.firstPoint = t, this.pendingSegments = [], this._nextCorner = null;\n }\n movePointerTo(t) {\n if (this.pendingSegments.length)\n throw new Error(\n \"You can only move the pointer if there is no segment defined\"\n );\n return this.pointer = t, this.firstPoint = t, this;\n }\n saveSegment(t) {\n if (v(t.firstPoint, t.lastPoint))\n throw new Error(`Segment has no length, ${t.repr}`);\n if (!this._nextCorner)\n return this.pendingSegments.push(t), this;\n const n = this.pendingSegments.pop();\n if (!n) throw new Error(\"bug in the custom corner algorithm\");\n const r = this._nextCorner.mode === \"chamfer\" ? V : I;\n return this.pendingSegments.push(\n ...r(n, t, this._nextCorner.radius)\n ), this._nextCorner = null, this;\n }\n lineTo(t) {\n const n = new d(this.pointer, t);\n return this.pointer = t, this.saveSegment(n);\n }\n line(t, n) {\n return this.lineTo([this.pointer[0] + t, this.pointer[1] + n]);\n }\n vLine(t) {\n return this.line(0, t);\n }\n hLine(t) {\n return this.line(t, 0);\n }\n vLineTo(t) {\n return this.lineTo([this.pointer[0], t]);\n }\n hLineTo(t) {\n return this.lineTo([t, this.pointer[1]]);\n }\n polarLineTo([t, n]) {\n const r = n * S, i = A(t, r);\n return this.lineTo(i);\n }\n polarLine(t, n) {\n const r = n * S, [i, s] = A(t, r);\n return this.line(i, s);\n }\n tangentLine(t) {\n const n = this.pendingSegments.at(-1);\n if (!n)\n throw new Error(\"You need a previous segment to sketch a tangent line\");\n const [r, i] = n.tangentAtLastPoint;\n return this.line(r * t, i * t);\n }\n threePointsArcTo(t, n) {\n return this.saveSegment($(this.pointer, n, t)), this.pointer = t, this;\n }\n threePointsArc(t, n, r, i) {\n const [s, o] = this.pointer;\n return this.threePointsArcTo(\n [s + t, o + n],\n [s + r, o + i]\n );\n }\n sagittaArcTo(t, n) {\n if (!n) return this.lineTo(t);\n const r = new d(this.pointer, t), i = x(r.tangentAtFirstPoint), s = l(r.midPoint, u(i, n));\n return this.threePointsArcTo(t, s);\n }\n sagittaArc(t, n, r) {\n return this.sagittaArcTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r\n );\n }\n vSagittaArc(t, n) {\n return this.sagittaArc(0, t, n);\n }\n hSagittaArc(t, n) {\n return this.sagittaArc(t, 0, n);\n }\n bulgeArcTo(t, n) {\n if (!n) return this.lineTo(t);\n const r = T(this.pointer, t) / 2, i = -n * r;\n return this.sagittaArcTo(t, i);\n }\n bulgeArc(t, n, r) {\n return this.bulgeArcTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r\n );\n }\n vBulgeArc(t, n) {\n return this.bulgeArc(0, t, n);\n }\n hBulgeArc(t, n) {\n return this.bulgeArc(t, 0, n);\n }\n tangentArcTo(t, n) {\n const r = this.pendingSegments.at(-1);\n if (!r)\n throw new Error(\"You need a previous curve to sketch a tangent arc\");\n return this.saveSegment(\n k(\n this.pointer,\n t,\n n ?? r.tangentAtLastPoint\n )\n ), this.pointer = t, this;\n }\n tangentArc(t, n, r) {\n const [i, s] = this.pointer;\n return this.tangentArcTo([t + i, n + s], r);\n }\n ellipseTo(t, n, r, i, s, o) {\n return this.saveSegment(\n H(this.pointer, t, n, r, i, s, o)\n ), this.pointer = t, this;\n }\n ellipse(t, n, r, i, s, o, a) {\n return this.ellipseTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r,\n i,\n s,\n o,\n a\n );\n }\n halfEllipseTo(t, n) {\n const [r, i] = J(P(t, this.pointer));\n return this.ellipseTo(\n t,\n r / 2,\n Math.abs(n),\n i * K,\n !0,\n n > 0\n );\n }\n halfEllipse(t, n, r) {\n return this.halfEllipseTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r\n );\n }\n cubicBezierCurveTo(t, n, r) {\n return this.saveSegment(\n new D(this.pointer, t, n, r)\n ), this.pointer = t, this;\n }\n quadraticBezierCurveTo(t, n) {\n return this.saveSegment(new w(this.pointer, t, n)), this.pointer = t, this;\n }\n smoothCurveTo(t, n) {\n const { endTangent: r, startTangent: i, startFactor: s, endFactor: o } = ot(n), a = this.pendingSegments.length ? this.pendingSegments[this.pendingSegments.length - 1] : null, c = T(this.pointer, t) / 3;\n let h;\n i ? h = i : a ? h = a.tangentAtLastPoint : h = [1, 0], h = F(h);\n const g = [\n this.pointer[0] + h[0] * s * c,\n this.pointer[1] + h[1] * s * c\n ];\n let p = r;\n p = F(p);\n const f = [\n t[0] - p[0] * o * c,\n t[1] - p[1] * o * c\n ];\n return this.cubicBezierCurveTo(t, g, f);\n }\n smoothCurve(t, n, r) {\n return this.smoothCurveTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r\n );\n }\n customCorner(t, n = \"fillet\") {\n if (!this.pendingSegments.length)\n throw new Error(\"You need a segment defined to fillet the angle\");\n return t ? (this._nextCorner = { mode: n, radius: t }, this) : this;\n }\n _customCornerLastWithFirst(t, n = \"fillet\") {\n if (!t) return;\n const r = this.pendingSegments.pop(), i = this.pendingSegments.shift();\n if (!r || !i)\n throw new Error(\"Not enough curves to close and fillet\");\n const s = n === \"chamfer\" ? V : I;\n this.pendingSegments.push(...s(r, i, t));\n }\n close(t = !1) {\n if (!this.pendingSegments.length) throw new Error(\"No segments to close\");\n const n = this.pendingSegments[0], r = this.pendingSegments.at(-1);\n return v(n.firstPoint, r.lastPoint) || this.lineTo(n.firstPoint), this._nextCorner !== null && (this._customCornerLastWithFirst(\n this._nextCorner.radius,\n this._nextCorner.mode\n ), this._nextCorner = null), R(this.pendingSegments, { ignoreChecks: t });\n }\n closeWithMirror(t = !1) {\n if (!this.pendingSegments.length) throw new Error(\"No segments to close\");\n const n = this.pendingSegments[0], r = this.pendingSegments.at(-1), i = P(\n r.lastPoint,\n n.firstPoint\n ), s = new U().mirrorLine(\n i,\n n.firstPoint\n ), o = this.pendingSegments.map(\n (a) => a.transform(s).reverse()\n );\n return o.reverse(), R(\n [...this.pendingSegments, ...o],\n { ignoreChecks: t }\n );\n }\n asStrand() {\n return new Z([...this.pendingSegments]);\n }\n get isClosed() {\n var t;\n return v(this.pointer, (t = this.pendingSegments[0]) == null ? void 0 : t.firstPoint);\n }\n}\nfunction ut(e = [0, 0]) {\n return new at(e);\n}\nexport {\n C as D,\n at as a,\n V as c,\n ut as d,\n I as f,\n _ as o\n};\n//# sourceMappingURL=draw-B3EaXatz.js.map\n","import { L as $, A as l, E as u, R as e, Q as f, C as h } from \"./QuadraticBezier-BeY2TXKH.js\";\nfunction o([t, n]) {\n return `${t} ${n}`;\n}\nfunction r(t) {\n if ($.isInstance(t))\n return `L ${o(t.lastPoint)}`;\n if (l.isInstance(t))\n return `A ${t.radius} ${t.radius} 0 ${t.angularLength > Math.PI ? \"1\" : \"0\"} ${t.clockwise ? \"0\" : \"1\"} ${o(t.lastPoint)}`;\n if (u.isInstance(t))\n return `A ${t.majorRadius} ${t.minorRadius} ${t.tiltAngle * e} ${t.deltaAngle > Math.PI ? \"1\" : \"0\"} ${t.clockwise ? \"0\" : \"1\"} ${o(t.lastPoint)}`;\n if (f.isInstance(t))\n return `Q ${[\n o(t.controlPoint),\n o(t.lastPoint)\n ].join(\" \")}`;\n if (h.isInstance(t))\n return `C ${[\n o(t.firstControlPoint),\n o(t.lastControlPoint),\n o(t.lastPoint)\n ].join(\" \")}`;\n throw new Error(\"Unknown segment type\");\n}\nfunction w(t) {\n const n = `M ${t.firstPoint.join(\" \")}`, i = t.segments.map(r).join(\" \");\n return `${n} ${i} Z`;\n}\nfunction p(t) {\n return `<path d=\"${t.allLoops.map(w).join(\" \")}\" />`;\n}\nfunction d(t) {\n return `<g>\n ${t.figures.map(p).join(`\n`)}\n</g>`;\n}\nfunction j(t) {\n const n = `M ${t.firstPoint.join(\" \")}`, i = t.segments.map(r).join(\" \");\n return `${n} ${i}`;\n}\nfunction v(t, n = 1) {\n const i = t.xMin - n, s = t.yMin - n;\n return `${i} ${s} ${t.width + 2 * n} ${t.height + 2 * n}`;\n}\nfunction A(t, n, i = 1, s) {\n const a = v(n, i), c = s ? `width=\"${n.width + 2 * i}${s}\" height=\"${n.height + 2 * i}${s}\"` : \"\";\n return `<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"${a}\" fill=\"none\" stroke=\"grey\" stroke-width=\"0.2%\" vector-effect=\"non-scaling-stroke\" ${c}>\n ${t}\n</svg>`;\n}\nexport {\n p as a,\n w as b,\n j as c,\n r as d,\n v as e,\n d as s,\n A as w\n};\n//# sourceMappingURL=svg-BTO7h1ix.js.map\n","var $t = Object.defineProperty;\nvar Ut = (t, n, e) => n in t ? $t(t, n, { enumerable: !0, configurable: !0, writable: !0, value: e }) : t[n] = e;\nvar I = (t, n, e) => Ut(t, typeof n != \"symbol\" ? n + \"\" : n, e);\nimport { o as Vt, D as U, f as Ht, c as Kt } from \"./draw-B3EaXatz.js\";\nimport { a as ce, d as ae } from \"./draw-B3EaXatz.js\";\nimport { F as m, L as P, D as h, a as W, s as Nt, b as qt, c as Xt, i as Jt, S as b, l as Qt, p as Yt, d as Zt, e as It, g as Mt } from \"./models-BHeLX0dj.js\";\nimport { h as ue } from \"./models-BHeLX0dj.js\";\nimport { l as Wt, z as jt, m as tn, e as E, n as j, b as F, a as nn, s as en, o as rn, q as St, L as v, A as y, C as _, p as it, u as N, d as q, T as sn, g as A, E as At, Q as vt, t as on, c as cn, D as bt, v as Lt, B as an } from \"./QuadraticBezier-BeY2TXKH.js\";\nimport { s as fn, a as un, b as ln, c as hn, d as gn, w as ot } from \"./svg-BTO7h1ix.js\";\nfunction x(t) {\n if (m.isInstance(t))\n return [t];\n if (P.isInstance(t))\n return [new m(t)];\n if (h.isInstance(t))\n return t.figures;\n throw new Error(\"Unknown shape\");\n}\nfunction Et(t, n, e = 1e-9) {\n let r = [];\n const s = [], i = new Array(n.segments.length).fill(0).map(() => []);\n n.segments.forEach((c, f) => {\n t.segments.forEach((a) => {\n const { intersections: u, overlaps: g } = W(\n c,\n a,\n e\n );\n r.push(...u), i[f].push(...u), s.push(...g);\n const p = g.flatMap((d) => [\n d.firstPoint,\n d.lastPoint\n ]);\n r.push(...p), i[f].push(...p);\n });\n }), r = Wt(r, e);\n const o = jt([n.segments, i]).flatMap(([c, f]) => f.length ? c.splitAt(f) : [c]);\n return Array.from(\n Nt(\n o,\n r,\n s\n )\n );\n}\nfunction tt(t, n, e = !1) {\n return Et(n, t).filter((s) => {\n const i = s.segments[0].midPoint;\n return n.onStroke(i) ? !e : !n.contains(i);\n });\n}\nfunction nt(t, n, e = !1) {\n return Et(n, t).filter((s) => {\n const i = s.segments[0].midPoint;\n return n.onStroke(i) ? !e : n.contains(i);\n });\n}\nfunction ct(t, n, e = !1) {\n const r = tt(\n t,\n n.contour,\n e\n ), s = n.holes.flatMap(\n (i) => nt(t, i, e)\n );\n return [...r, ...s];\n}\nfunction at(t, n, e = !1) {\n let r = nt(\n t,\n n.contour,\n e\n );\n return n.holes.forEach((s) => {\n r = r.flatMap(\n (i) => tt(i, s, e)\n );\n }), r;\n}\nfunction pn(t, n) {\n return new h(\n qt(x(t), x(n))\n );\n}\nfunction z(t) {\n return t.reduce(\n (n, e) => pn(n, e),\n new h()\n );\n}\nfunction kt(t, n) {\n return new h(\n Xt(x(t), x(n))\n );\n}\nfunction Jn(t, n) {\n return new h(\n Jt(x(t), x(n))\n );\n}\nfunction Qn(t, n, e = !0) {\n if (P.isInstance(n))\n return tt(t, n, e);\n if (m.isInstance(n))\n return ct(t, n, e);\n let r = [new b([...t.segments])];\n return n.figures.forEach((s) => {\n r = r.flatMap((i) => ct(i, s, e));\n }), r;\n}\nfunction Yn(t, n, e = !1) {\n if (P.isInstance(n))\n return nt(t, n, e);\n if (m.isInstance(n))\n return at(t, n, e);\n let r = [new b([...t.segments])];\n return n.figures.forEach((s) => {\n r = r.flatMap((i) => at(i, s, e));\n }), r;\n}\nfunction ft(t) {\n return t < 0 ? \"before\" : t > 1 ? \"after\" : \"between\";\n}\nconst ut = (t, n, e) => {\n if (e === \"before\")\n return t.distanceFrom(n.firstPoint);\n if (e === \"after\")\n return t.distanceFrom(n.lastPoint);\n throw new Error(\"Invalid position\");\n};\nfunction dn(t, n) {\n const e = tn(t, n);\n if (e === \"parallel\")\n return Math.min(\n t.distanceFrom(n.firstPoint),\n t.distanceFrom(n.lastPoint)\n );\n const { intersectionParam1: r, intersectionParam2: s } = e, i = ft(r), o = ft(s);\n if (i === \"between\" && o === \"between\")\n return 0;\n if (i === \"between\" && o !== \"between\")\n return ut(t, n, o);\n if (o === \"between\" && i !== \"between\")\n return ut(n, t, i);\n if (i === \"before\" && o === \"before\")\n return E(t.firstPoint, n.firstPoint);\n if (i === \"after\" && o === \"after\")\n return E(t.lastPoint, n.lastPoint);\n if (i === \"before\" && o === \"after\")\n return E(t.firstPoint, n.lastPoint);\n if (i === \"after\" && o === \"before\")\n return E(t.lastPoint, n.firstPoint);\n throw new Error(\"Invalid position\");\n}\nfunction lt(t, n) {\n if (Qt(t, n).length > 0)\n return 0;\n const e = Yt(t, n.center);\n if (t.isOnSegment(e)) {\n const r = E(e, n.center);\n if (Math.abs(r - n.radius) < t.precision && n.isOnSegment(e))\n return 0;\n if (r - n.radius > t.precision) {\n const s = j(\n F(e, n.center)\n ), i = nn(\n n.center,\n en(s, n.radius)\n );\n if (n.isOnSegment(i))\n return E(i, e);\n }\n }\n return Math.min(\n n.distanceFrom(t.firstPoint),\n n.distanceFrom(t.lastPoint),\n t.distanceFrom(n.firstPoint),\n t.distanceFrom(n.lastPoint)\n );\n}\nconst mn = (t, n) => {\n const e = t.angleToParam(n.firstAngle);\n if (t.isValidParameter(e)) return !0;\n const r = t.angleToParam(n.lastAngle);\n return !!t.isValidParameter(r);\n};\nfunction Pn(t, n) {\n if (Zt(t, n, !0).length > 0) return 0;\n const e = E(t.center, n.center);\n if (e < t.precision && mn(t, n))\n return Math.abs(t.radius - n.radius);\n const r = j(F(n.center, t.center)), s = e - Math.abs(t.radius - n.radius) < t.precision;\n let i = rn(r);\n s && n.radius > t.radius && (i += Math.PI);\n const o = s ? i : i + Math.PI, c = t.angleToParam(i), f = n.angleToParam(o);\n return t.isValidParameter(c) && n.isValidParameter(f) ? E(t.paramPoint(c), n.paramPoint(f)) : Math.min(\n t.distanceFrom(n.firstPoint),\n t.distanceFrom(n.lastPoint),\n n.distanceFrom(t.firstPoint),\n n.distanceFrom(t.lastPoint)\n );\n}\nfunction wn(t, n, e) {\n let r = 0, s = t.length - 1;\n for (; r <= s; ) {\n const i = Math.floor((r + s) / 2), o = e(t[i], n);\n if (o < 0)\n r = i + 1;\n else if (o > 0)\n s = i - 1;\n else\n return i;\n }\n return -(r + 1);\n}\nfunction In(t, n, e) {\n const r = wn(t, n, e);\n r < 0 ? t.splice(-(r + 1), 0, n) : t.splice(r, 0, n);\n}\nclass Mn {\n constructor() {\n I(this, \"buckets\");\n this.buckets = [];\n }\n addInterval(n) {\n const e = this.buckets[n.rectangle.diagonalBucketIndex];\n e === void 0 ? this.buckets[n.rectangle.diagonalBucketIndex] = [n] : In(e, n, (r, s) => r.value - s.value);\n }\n removeInterval(n) {\n const e = this.buckets[n.rectangle.diagonalBucketIndex];\n if (e === void 0)\n throw new Error(\"Interval not found\");\n e.shift();\n }\n getBottomRightHullIntervals() {\n const n = [];\n for (let e = this.buckets.length - 1; e >= 0; e--) {\n const r = this.buckets[e];\n if (!r === void 0) continue;\n const s = r[0];\n if (s !== void 0) {\n if (!n.length) {\n n.push(s);\n continue;\n }\n for (; n.length && n[n.length - 1].value >= s.value; )\n n.pop();\n for (; n.length >= 2; ) {\n const i = n[n.length - 1], o = n[n.length - 2], c = (s.value - o.value) / ((s.rectangle.diagonal - o.rectangle.diagonal) * 2);\n if (o.value + (i.rectangle.diagonal - o.rectangle.diagonal) / 2 * c < i.value)\n n.pop();\n else\n break;\n }\n n.push(s);\n }\n }\n return n;\n }\n}\nclass Sn {\n constructor(n, e) {\n I(this, \"diagonal\");\n I(this, \"diagonalBucketIndex\");\n I(this, \"xLength\");\n I(this, \"yLength\");\n I(this, \"index\");\n this.x = n, this.y = e, this.xLength = Math.pow(3, -n), this.yLength = Math.pow(3, -e), this.diagonal = Math.sqrt(\n this.xLength * this.xLength + this.yLength * this.yLength\n ), this.diagonalBucketIndex = n + e, this.index = `${n},${e}`;\n }\n}\nclass An {\n constructor(n, e = 1e-8, r = 1e3, s = 1e-6) {\n I(this, \"rectangles\");\n I(this, \"buckets\");\n I(this, \"fMin\");\n I(this, \"argMin\");\n I(this, \"tol\");\n this.fcn = n, this.endTolerance = e, this.maxIterations = r, this.epsilon = s, this.fcn = n, this.epsilon = s, this.endTolerance = e, this.maxIterations = r, this.rectangles = /* @__PURE__ */ new Map(), this.buckets = new Mn();\n const i = [0.5, 0.5], o = this.rect(0, 0), c = this.fcn(i);\n this.buckets.addInterval(new O(i, c, o)), this.fMin = c, this.argMin = i, this.tol = o.diagonal;\n }\n registerInterval(n) {\n this.buckets.addInterval(n), n.value <= this.fMin && (this.fMin = n.value, this.argMin = n.center, this.tol = n.rectangle.diagonal);\n }\n rect(n, e) {\n const r = `${n},${e}`;\n return this.rectangles.has(r) || this.rectangles.set(r, new Sn(n, e)), this.rectangles.get(r);\n }\n splitInterval(n) {\n let e, r, s;\n const [i, o] = n.center;\n return n.rectangle.x <= n.rectangle.y ? (e = this.rect(n.rectangle.x + 1, n.rectangle.y), r = [i - e.xLength, o], s = [i + e.xLength, o]) : (e = this.rect(n.rectangle.x, n.rectangle.y + 1), r = [i, o - e.yLength], s = [i, o + e.yLength]), [\n new O(r, this.fcn(r), e),\n new O(n.center, n.value, e),\n new O(s, this.fcn(s), e)\n ];\n }\n single_iteration() {\n const n = this.buckets.getBottomRightHullIntervals();\n for (; n.length >= 2; ) {\n const e = n[0], r = n[1], s = (r.value - e.value) / ((r.rectangle.diagonal - e.rectangle.diagonal) / 2), i = e.value - s * r.value / 2;\n if ((this.fMin - i) / Math.abs(this.fMin) < this.epsilon)\n n.shift();\n else\n break;\n }\n n.forEach((e) => {\n this.buckets.removeInterval(e);\n });\n for (const e of n) {\n const [r, s, i] = this.splitInterval(e);\n this.registerInterval(r), this.registerInterval(s), this.registerInterval(i);\n }\n }\n run() {\n let n = 0;\n for (; this.tol > this.endTolerance / 2 && (this.single_iteration(), n++, !(n > this.maxIterations)); )\n ;\n return {\n fMin: this.fMin,\n argMin: this.argMin,\n tol: this.tol,\n iterations: n\n };\n }\n}\nclass O {\n constructor(n, e, r) {\n this.center = n, this.value = e, this.rectangle = r;\n }\n}\nfunction vn(t, n = 1e-8, e = 1e3, r = 1e-6) {\n return new An(\n t,\n n,\n e,\n r\n ).run();\n}\nfunction bn(t, n, e = 1e-9) {\n const r = vn((s) => {\n const i = t.paramPoint(s[0]), o = n.paramPoint(s[1]);\n return St(i, o);\n }, e);\n return Math.sqrt(r.fMin);\n}\nfunction Ln(t, n) {\n return v.isInstance(t) && v.isInstance(n) ? dn(t, n) : v.isInstance(t) && y.isInstance(n) ? lt(t, n) : y.isInstance(t) && v.isInstance(n) ? lt(n, t) : y.isInstance(t) && y.isInstance(n) ? Pn(t, n) : bn(t, n);\n}\nfunction Ft(t) {\n if (_.isInstance(t)) {\n const s = F(t.lastPoint, t.firstPoint), i = F(t.firstControlPoint, t.firstPoint), o = F(t.lastControlPoint, t.firstPoint), c = N(s, i), f = N(s, o);\n if (c > 0 && f < 0 || c < 0 && f > 0) return !1;\n }\n const n = it(t.tangentAtFirstPoint), e = it(t.tangentAtLastPoint);\n let r = q(n, e);\n return Math.abs(Math.acos(r)) < Math.PI / 3;\n}\nfunction X(t) {\n if (Ft(t)) return [t];\n const [n, e] = t.splitAtParameters([0.5]);\n return [\n ...X(n),\n ...X(e)\n ];\n}\nfunction ht(t) {\n return Ft(t) ? [t] : t.splitAtParameters(t.getParametersOfExtrema()).flatMap(X);\n}\nfunction En(t) {\n const n = t.deltaAngle, e = Math.ceil(Math.abs(n) / (Math.PI / 2)), r = n / e, s = 4 * Math.tan(r / 4) / 3, i = t.clockwise ? -1 : 1, o = Array.from(\n { length: e + 1 },\n (f, a) => t.firstAngle + a * r * i\n );\n return o.slice(0, -1).map((f, a) => [f, o[a + 1]]).map(([f, a]) => {\n const u = Math.cos(f), g = Math.sin(f), p = Math.cos(a), d = Math.sin(a), [l, M] = t.center, w = t.minorRadius, S = t.majorRadius, L = new sn().rotate(\n t.tiltAngle,\n t.center\n ), k = (_t) => L.transform(_t), D = k([l + S * u, M + w * g]), $ = k([\n l + S * (u - s * g * i),\n M + w * (g + s * u * i)\n ]), zt = k([\n l + S * (p + s * d * i),\n M + w * (d - s * p * i)\n ]), Gt = k([l + S * p, M + w * d]);\n return new _(D, Gt, $, zt);\n });\n}\nconst et = 1e-8, xt = (t) => t.flatMap((n) => v.isInstance(n) ? [n] : y.isInstance(n) ? [n] : At.isInstance(n) ? En(n).flatMap(\n (e) => ht(e)\n) : vt.isInstance(n) || _.isInstance(n) ? ht(n) : [new v(n.firstPoint, n.lastPoint)]);\nfunction J(t, n, e = !0) {\n const r = t.map((a) => ({\n offset: Vt(a, n),\n original: a\n })), s = [];\n let i = e ? null : r.at(-1), o = e ? r.at(-1) : null;\n if (s.length === 1) return s;\n const c = (a) => {\n i ? U.isInstance(a.offset) ? A(a.offset.firstPoint, a.offset.lastPoint) || s.push(\n new v(a.offset.firstPoint, a.offset.lastPoint)\n ) : s.push(a.offset) : i = a;\n }, f = function* () {\n for (const a of r.slice(0, -1))\n yield a;\n if (!i) throw new Error(\"Bug in the offset algorithm\");\n yield i;\n };\n for (const a of f()) {\n if (!o) {\n o = a;\n continue;\n }\n const u = o.offset.lastPoint, g = a.offset.firstPoint;\n if (A(u, g)) {\n c(o), o = a;\n continue;\n }\n let p = [];\n if (!U.isInstance(o.offset) && !U.isInstance(a.offset)) {\n const { intersections: w, overlaps: S } = W(\n o.offset,\n a.offset,\n et / 100\n );\n p = [\n ...w,\n ...S.flatMap((L) => [L.firstPoint, L.lastPoint])\n ];\n }\n if (p.length > 0) {\n let w = p[0];\n if (p.length > 1) {\n const k = o == null ? void 0 : o.original.lastPoint, D = p.map(\n ($) => St($, k)\n );\n w = p[D.indexOf(Math.min(...D))];\n }\n const S = o.offset.splitAt([\n w\n ])[0], L = a.offset.splitAt([w]).at(-1);\n if (!L) throw new Error(\"Bug in the splitting algo in offset\");\n c({\n offset: S,\n original: o.original\n }), o = { offset: L, original: a.original };\n continue;\n }\n const d = o.original.lastPoint, l = cn(\n F(g, d),\n F(u, d)\n ) > 0, M = new y(u, g, d, l);\n c(o), s.push(M), o = a;\n }\n return o && c(o), s;\n}\nfunction yt(t) {\n const n = /* @__PURE__ */ new Map(), e = (r, s) => {\n const i = n.get(r) || [];\n n.set(r, [...i, ...s]);\n };\n return t.forEach((r, s) => {\n t.slice(s + 1).forEach((i, o) => {\n const { intersections: c, overlaps: f } = W(r, i, et), a = [\n ...c,\n ...f.flatMap((u) => [u.firstPoint, u.lastPoint])\n ].filter((u) => {\n const g = A(u, r.firstPoint) || A(u, r.lastPoint), p = A(u, i.firstPoint) || A(u, i.lastPoint);\n return !(g && p);\n });\n a.length && (e(s, a), e(o + s + 1, a));\n });\n }), n;\n}\nfunction Ct(t, n) {\n return n.flatMap((e, r) => {\n if (!t.has(r)) return e;\n const s = t.get(r);\n return s ? e.splitAt(s) : e;\n });\n}\nfunction Dt(t, n, e) {\n return t.filter((r) => !n.segments.some((i) => Ln(i, r) < Math.abs(e) - et));\n}\nfunction G(t, n) {\n const e = t.clockwise ? n : -n, r = xt(t.segments), s = J(r, e);\n if (s.length < 2) return new h();\n const i = yt(s);\n if (!i.size) {\n const u = new P(s);\n return new h([new m(u)]);\n }\n const o = Ct(\n i,\n s\n ), c = Dt(o, t, n);\n if (!c.length) return new h();\n const a = It(c).filter((u) => u.length > 1).filter((u) => A(u[0].firstPoint, u.at(-1).lastPoint)).map((u) => new P(u));\n return a.length ? new h(a.map((u) => new m(u))) : new h();\n}\nfunction kn(t, n, e = \"round\") {\n const r = n / 2, s = xt(t.segments), i = J(s, r, !1), o = J(\n s,\n -r,\n !1\n ).map((l) => l.reverse());\n o.reverse();\n const c = (l, M) => e === \"round\" ? on(\n l.lastPoint,\n M.firstPoint,\n l.tangentAtLastPoint\n ) : new v(l.lastPoint, M.firstPoint), f = [\n ...i,\n c(\n i[i.length - 1],\n o[0]\n ),\n ...o,\n c(\n o[o.length - 1],\n i[0]\n )\n ], a = yt(f);\n if (!a.size) {\n const l = new P(f);\n return new h([new m(l)]);\n }\n const u = Ct(\n a,\n f\n ), g = Dt(u, t, r);\n if (!g.length) return new h();\n const d = It(g).filter((l) => l.length > 1).filter((l) => A(l[0].firstPoint, l.at(-1).lastPoint)).map((l) => new P(l));\n return d.length ? new h(d.map((l) => new m(l))) : new h();\n}\nfunction Fn(t, n) {\n const e = t.map((r) => {\n const s = z(\n r.holes.map((i) => G(i, n))\n );\n return kt(G(r.contour, n), s);\n });\n return z(e);\n}\nfunction xn(t, n) {\n const e = Math.abs(n / 2), r = t.map(\n (s) => z(\n s.allLoops.map((i) => kt(G(i, e), G(i, -e)))\n )\n );\n return z(r);\n}\nfunction Zn(t, n) {\n return Fn(x(t), n);\n}\nfunction Wn(t, n, { endCap: e = \"round\" } = {}) {\n return b.isInstance(t) ? kn(t, n, e) : xn(x(t), n);\n}\nclass yn {\n constructor() {\n I(this, \"filters\");\n this.filters = [];\n }\n delete() {\n this.filters = [];\n }\n /**\n * Combine logically a set of filter with an AND operation.\n *\n */\n and(n) {\n return n.forEach((e) => e(this)), this;\n }\n /**\n * Invert the result of a particular filter\n *\n */\n not(n) {\n const e = new this.constructor();\n n(e);\n const r = ({ element: s }) => !e.shouldKeep(s);\n return this.filters.push(r), this;\n }\n /**\n * Combine logically a set of filter with an OR operation.\n *\n */\n either(n) {\n const e = n.map((s) => {\n const i = new this.constructor();\n return s(i), i;\n }), r = ({ element: s }) => e.some((i) => i.shouldKeep(s));\n return this.filters.push(r), this;\n }\n}\nconst V = 2 * Math.PI, gt = (t) => {\n const n = t % V, e = n < 0 ? n + V : n;\n return e < Math.PI ? e : e === Math.PI ? 0 : Math.abs(e - V);\n};\nclass C extends yn {\n clone() {\n const n = new C();\n return n.filters = [...this.filters], n;\n }\n /**\n * Filter to find corner that have their point are in the list.\n *\n */\n inList(n) {\n const e = ({ element: r }) => !!n.find((s) => A(s, r.point));\n return this.filters.push(e), this;\n }\n /**\n * Filter to find elements that are at a specified distance from a point.\n *\n */\n atDistance(n, e = [0, 0]) {\n function r({ element: s }) {\n return Math.abs(E(e, s.point) - n) < 1e-9;\n }\n return this.filters.push(r), this;\n }\n /**\n * Filter to find elements that contain a certain point\n *\n * @category Filter\n */\n atPoint(n) {\n function e({ element: r }) {\n return A(n, r.point);\n }\n return this.filters.push(e), this;\n }\n /**\n * Filter to find elements that are within a box\n *\n * @category Filter\n */\n inBox(n, e) {\n const [r, s] = n, [i, o] = e, c = Math.min(r, i), f = Math.max(r, i), a = Math.min(s, o), u = Math.max(s, o);\n function g({ element: p }) {\n const [d, l] = p.point;\n return d >= c && d <= f && l >= a && l <= u;\n }\n return this.filters.push(g), this;\n }\n /**\n * Filter to find corner that a certain angle between them - only between\n * 0 and 180.\n *\n */\n ofAngle(n) {\n function e({ element: r }) {\n const s = r.firstCurve.tangentAtLastPoint, i = r.secondCurve.tangentAtFirstPoint;\n return Math.abs(\n gt(N(s, i)) - gt(bt * n)\n ) < 1e-9;\n }\n return this.filters.push(e), this;\n }\n above(n = 0) {\n function e({ element: r }) {\n return r.point[1] > n;\n }\n return this.filters.push(e), this;\n }\n below(n = 0) {\n function e({ element: r }) {\n return r.point[1] < n;\n }\n return this.filters.push(e), this;\n }\n leftOf(n = 0) {\n function e({ element: r }) {\n return r.point[0] < n;\n }\n return this.filters.push(e), this;\n }\n rightOf(n = 0) {\n function e({ element: r }) {\n return r.point[0] > n;\n }\n return this.filters.push(e), this;\n }\n shouldKeep(n) {\n return this.filters.every((r) => r({ element: n }));\n }\n asFilterFun() {\n return this.shouldKeep.bind(this);\n }\n}\nfunction Ot(t, n, e, r = () => !0) {\n const s = [n.segments[0]], i = (c, f) => {\n r({ firstCurve: c, secondCurve: f, point: c.lastPoint }) ? s.push(...t(c, f, e)) : s.push(c, f);\n };\n if (n.segments.slice(1).forEach((c) => {\n const f = s.pop();\n if (!f) throw new Error(\"Bug in the stroke filletting algo\");\n i(f, c);\n }), !s.at(-1)) throw new Error(\"Bug in the stroke corner algo\");\n if (P.isInstance(n)) {\n const c = s.pop(), f = s.shift();\n if (!c || !f)\n throw new Error(\"Bug in the filletting algo\");\n return i(c, f), new P(s, { ignoreChecks: !0 });\n } else\n return new b(s, { ignoreChecks: !0 });\n}\nfunction R(t, n, e) {\n const r = typeof e == \"function\" ? e(new C()) : e, s = r && r.asFilterFun();\n if (P.isInstance(t) || b.isInstance(t))\n return Ot(Ht, t, n, s);\n if (m.isInstance(t)) {\n const i = R(t.contour, n, r), o = t.holes.map((c) => R(c, n, r));\n return new m(i, o, { ignoreChecks: !0 });\n }\n if (h.isInstance(t)) {\n const i = t.figures.map((o) => R(o, n, r));\n return new h(i, { ignoreChecks: !0 });\n }\n throw new Error(\"invalid shape to fillet\");\n}\nfunction T(t, n, e) {\n const r = typeof e == \"function\" ? e(new C()) : e, s = r && r.asFilterFun();\n if (P.isInstance(t) || b.isInstance(t))\n return Ot(Kt, t, n, s);\n if (m.isInstance(t)) {\n const i = T(t.contour, n, r), o = t.holes.map((c) => T(c, n, r));\n return new m(i, o, { ignoreChecks: !0 });\n }\n if (h.isInstance(t)) {\n const i = t.figures.map((o) => T(o, n, r));\n return new h(i, { ignoreChecks: !0 });\n }\n throw new Error(\"invalid shape to chamfer\");\n}\nclass Cn extends C {\n constructor(n) {\n super(), this.shape = n;\n }\n fillet(n) {\n return R(this.shape, n, this.clone());\n }\n chamfer(n) {\n return T(this.shape, n, this.clone());\n }\n}\nfunction jn(t) {\n return new Cn(t);\n}\nconst Dn = 1 * bt, On = 24;\nfunction H(t, n, e, r) {\n const s = t.gradientAt(n);\n return Lt(s) <= r ? e : j(s);\n}\nfunction Q(t, n, e, r, s, i) {\n const o = t.paramPoint(n), c = t.paramPoint(e), f = F(c, o), a = Lt(f);\n if (a <= t.precision || i >= r.maxDepth)\n return [o, c];\n const u = [f[0] / a, f[1] / a], g = (n + e) * 0.5, p = H(t, n, u, t.precision), d = H(t, g, u, t.precision), l = H(t, e, u, t.precision), M = q(p, d), w = q(d, l);\n if (M >= s && w >= s)\n return [o, c];\n const S = t.paramPoint(g), L = M >= s ? [o, S] : Q(t, n, g, r, s, i + 1), k = w >= s ? [S, c] : Q(t, g, e, r, s, i + 1);\n return [...L.slice(0, -1), ...k];\n}\nfunction rt(t, n = {}) {\n const e = {\n maxAngle: n.maxAngle ?? Dn,\n maxDepth: n.maxDepth ?? On\n }, r = Math.cos(e.maxAngle);\n return Q(t, 0, 1, e, r, 0);\n}\nfunction Bn(t, n) {\n return new h(\n t.figures.map((e) => Bt(e, n))\n );\n}\nfunction Bt(t, n) {\n return new m(\n Y(t.contour, n),\n t.holes.map((e) => Y(e, n))\n );\n}\nfunction Y(t, n) {\n return new P(st(t.segments, n));\n}\nfunction Rn(t, n) {\n return new b(st(t.segments, n));\n}\nfunction st(t, n) {\n return t.flatMap(n);\n}\nfunction Tn(t, n) {\n if (h.isInstance(t))\n return Bn(t, n);\n if (m.isInstance(t))\n return Bt(t, n);\n if (P.isInstance(t))\n return Y(t, n);\n if (b.isInstance(t))\n return Rn(t, n);\n if (Mt(t))\n return st([t], n);\n throw new Error(\"Unsupported shape type\");\n}\nfunction zn(t) {\n if (t.length < 2) return [];\n const n = [];\n for (let e = 0; e < t.length - 1; e += 1)\n n.push(new v(t[e], t[e + 1]));\n return n;\n}\nfunction Gn(t, n) {\n return zn(rt(t, n));\n}\nfunction B(t, n) {\n const e = [];\n return t.forEach((r, s) => {\n const i = rt(r, n);\n if (i.length !== 0) {\n if (s === 0) {\n e.push(...i);\n return;\n }\n e.push(...i.slice(1));\n }\n }), e.length > 1 && A(e[0], e[e.length - 1]) && e.pop(), e;\n}\nfunction _n(t) {\n return t.length < 3 ? !1 : t.map((e, r) => {\n const s = t[(r + 1) % t.length];\n return (s[0] - e[0]) * (s[1] + e[1]);\n }).reduce((e, r) => e + r, 0) > 0;\n}\nfunction K(t, n) {\n return t.length < 3 || _n(t) === n ? t : [...t].reverse();\n}\nfunction te(t, n = {}) {\n return Tn(t, (r) => Gn(r, n));\n}\nfunction $n(t, n = {}) {\n if (h.isInstance(t))\n return t.figures.flatMap((e) => $n(e, n));\n if (m.isInstance(t)) {\n const e = K(\n B(t.contour.segments, n),\n !1\n ), r = t.holes.map(\n (s) => K(B(s.segments, n), !0)\n );\n return [e, ...r];\n }\n return P.isInstance(t) ? [K(B(t.segments, n), !1)] : b.isInstance(t) ? [B(t.segments, n)] : [rt(t, n)];\n}\nfunction pt(t) {\n if (h.isInstance(t))\n return fn(t);\n if (m.isInstance(t))\n return un(t);\n if (P.isInstance(t))\n return `<path d=\"${ln(t)}\" />`;\n if (b.isInstance(t))\n return `<path d=\"${hn(t)}\" />`;\n if (Mt(t))\n return `<path d=\"${`M ${t.firstPoint.join(\" \")}`} ${gn(\n t\n )}\" />`;\n throw new Error(\"Unknown shape type\");\n}\nconst dt = (t) => \"shape\" in t ? t.shape : t, mt = (t, n) => {\n if (!(\"shape\" in t)) return n;\n const { color: e } = t;\n return e ? `<g stroke=\"${e}\">${n}</g>` : n;\n}, Pt = (t) => new an(t.xMin, -t.yMax, t.xMax, -t.yMin);\nfunction ne(t, {\n margin: n = 1,\n unit: e = null,\n viewBox: r\n} = {}) {\n if (Array.isArray(t)) {\n const i = t.map((f) => dt(f).mirror()), o = i.map((f, a) => mt(t[a], pt(f))).join(`\n`), c = i.slice(1).reduce((f, a) => f.merge(a.boundingBox), i[0].boundingBox);\n return ot(o, r ? Pt(r) : c, n, e);\n }\n const s = dt(t).mirror();\n return ot(\n mt(t, pt(s)),\n r ? Pt(r) : s.boundingBox,\n n,\n e\n );\n}\nconst Rt = (t) => {\n if (t.type === \"LINE\")\n return new v(t.firstPoint, t.lastPoint);\n if (t.type === \"ARC\")\n return new y(\n t.firstPoint,\n t.lastPoint,\n t.center,\n t.clockwise\n );\n if (t.type === \"ELLIPSE_ARC\")\n return new At(\n t.firstPoint,\n t.lastPoint,\n t.center,\n t.majorRadius,\n t.minorRadius,\n t.tiltAngle,\n t.clockwise,\n { angleUnits: \"rad\" }\n );\n if (t.type === \"QUADRATIC_BEZIER\")\n return new vt(\n t.firstPoint,\n t.lastPoint,\n t.controlPoint\n );\n if (t.type === \"CUBIC_BEZIER\")\n return new _(\n t.firstPoint,\n t.lastPoint,\n t.firstControlPoint,\n t.lastControlPoint\n );\n throw new Error(\"Unknown segment type\");\n}, Z = (t) => {\n const n = t.segments.map(Rt);\n return new P(n);\n}, Tt = (t) => {\n const n = Z(t.contour), e = t.holes.map(Z);\n return new m(n, e);\n}, Un = (t) => {\n const n = t.figures.map(Tt);\n return new h(n);\n};\nfunction ee(t) {\n if (t.type === \"DIAGRAM\")\n return Un(t);\n if (t.type === \"FIGURE\")\n return Tt(t);\n if (t.type === \"LOOP\")\n return Z(t);\n if (t.type === \"LINE\" || t.type === \"ARC\" || t.type === \"ELLIPSE_ARC\" || t.type === \"CUBIC_BEZIER\")\n return Rt(t);\n throw new Error(\"Unknown shape type\");\n}\nconst wt = Math.PI / 180, Vn = 180 / Math.PI;\nfunction re(t, n) {\n const e = Math.cos(n * wt) * t, r = Math.sin(n * wt) * t;\n return [e, r];\n}\nfunction se([t, n]) {\n const e = Math.sqrt(t * t + n * n), r = Math.atan2(n, t) * Vn;\n return [e, r];\n}\nexport {\n wt as DEG2RAD,\n ce as DrawingPen,\n Vn as RAD2DEG,\n se as cartesianToPolar,\n T as chamfer,\n Yn as confineStrand,\n kt as cut,\n ae as draw,\n Qn as eraseStrand,\n ue as exportJSON,\n ne as exportSVG,\n R as fillet,\n pn as fuse,\n z as fuseAll,\n ee as importJSON,\n Jn as intersect,\n Zn as offset,\n Wn as outlineStroke,\n re as polarToCartesian,\n jn as selectCorners,\n pt as svgBody,\n te as tesselate,\n $n as tesselatePoints\n};\n//# sourceMappingURL=pantograph.js.map\n","import { cut, eraseStrand, exportSVG } from \"pantograph2d\";\nimport {\n Transformable,\n Diagram,\n Strand,\n TransformationMatrix,\n Stroke,\n} from \"pantograph2d/models\";\n\nexport class Dieline extends Transformable<Dieline> {\n public body: Diagram;\n public cutLines: Stroke[];\n public foldLinesBackwards: Stroke[];\n public foldLinesForwards: Stroke[];\n\n constructor(\n body: Diagram,\n {\n cutLines = [],\n foldLines = [],\n foldLinesForwards = [],\n foldLinesBackwards = [],\n }: {\n cutLines?: Stroke[];\n foldLines?: Stroke[];\n foldLinesBackwards?: Stroke[];\n foldLinesForwards?: Stroke[];\n } = {},\n ) {\n super();\n this.body = body;\n this.cutLines = [...cutLines];\n this.foldLinesBackwards = [...foldLines, ...foldLinesBackwards];\n this.foldLinesForwards = [...foldLinesForwards];\n }\n\n get foldLines() {\n return [...this.foldLinesForwards, ...this.foldLinesBackwards];\n }\n\n clone() {\n return new Dieline(this.body, {\n cutLines: [...this.cutLines],\n foldLinesForwards: [...this.foldLinesForwards],\n foldLinesBackwards: [...this.foldLinesBackwards],\n });\n }\n\n addCutLine(cut: Strand) {\n this.cutLines.push(cut);\n return this;\n }\n\n addFoldLine(fold: Strand, direction: \"forwards\" | \"backwards\" = \"backwards\") {\n if (direction === \"forwards\") {\n this.foldLinesForwards.push(fold);\n } else {\n this.foldLinesBackwards.push(fold);\n }\n }\n\n fuseFold(\n fold: Diagram | Dieline,\n direction: \"forwards\" | \"backwards\" = \"backwards\",\n ) {\n const otherBody: Diagram = fold instanceof Dieline ? fold.body : fold;\n\n const commonLines = this.body.overlappingStrands(otherBody);\n if (direction === \"forwards\") {\n this.foldLinesForwards.push(...commonLines);\n } else {\n this.foldLinesBackwards.push(...commonLines);\n }\n\n this.fuseBody(fold);\n return this;\n }\n\n fuseBody(other: Dieline | Diagram) {\n let otherBody: Diagram;\n\n if (other instanceof Dieline) {\n otherBody = other.body;\n this.cutLines.push(...other.cutLines);\n this.foldLinesForwards.push(...other.foldLinesForwards);\n this.foldLinesBackwards.push(...other.foldLinesBackwards);\n } else {\n otherBody = other;\n }\n\n this.body = this.body.fuse(otherBody);\n return this;\n }\n\n cutShape(shape: Diagram) {\n this.body = cut(this.body, shape);\n this.cutLines = this.cutLines.flatMap((cut) =>\n eraseStrand(cut, shape, true),\n );\n this.eraseFolds(shape);\n return this;\n }\n\n eraseFolds(shape: Diagram) {\n this.foldLinesBackwards = this.foldLinesBackwards.flatMap((fold) =>\n eraseStrand(fold, shape, true),\n );\n this.foldLinesForwards = this.foldLinesForwards.flatMap((fold) =>\n eraseStrand(fold, shape, true),\n );\n }\n\n transform(matrix: TransformationMatrix) {\n const newDieline = new Dieline(this.body.transform(matrix), {\n cutLines: this.cutLines.map((cut) => cut.transform(matrix)),\n foldLinesForwards: this.foldLinesForwards.map((fold) =>\n fold.transform(matrix),\n ),\n foldLinesBackwards: this.foldLinesBackwards.map((fold) =>\n fold.transform(matrix),\n ),\n });\n\n return newDieline;\n }\n\n asSVG() {\n const shapes: { shape: Diagram | Stroke; color: string }[] = [];\n if (this.body) {\n shapes.push({ shape: this.body, color: \"red\" });\n }\n if (this.cutLines.length) {\n this.cutLines.map((shape) => shapes.push({ shape, color: \"red\" }));\n }\n\n if (this.foldLinesBackwards.length) {\n this.foldLinesBackwards.map((shape) =>\n shapes.push({ shape, color: \"green\" }),\n );\n }\n\n if (this.foldLinesForwards.length) {\n this.foldLinesForwards.map((shape) =>\n shapes.push({ shape, color: \"blue\" }),\n );\n }\n\n return exportSVG(shapes, { unit: \"mm\" });\n }\n}\n","import { draw } from \"pantograph2d\";\n\nexport type FlapContractionMode = \"rounded\" | \"sharp\";\nexport type HorizontalFlapOptions = {\n fillet?: number;\n contraction?: number;\n contractionMode?: FlapContractionMode;\n contractionLeft?: number;\n contractionRight?: number;\n leftContractionMode?: FlapContractionMode;\n rightContractionMode?: FlapContractionMode;\n};\nexport type VerticalFlapTopOptions = HorizontalFlapOptions & {\n contractionTop?: number;\n contractionBottom?: number;\n topContractionMode?: FlapContractionMode;\n bottomContractionMode?: FlapContractionMode;\n};\n\nfunction drawFlap(\n width: number,\n height: number,\n {\n fillet = 1,\n contraction = 1,\n contractionMode = \"rounded\",\n contractionLeft: contractionLeftInput,\n contractionRight: contractionRightInput,\n leftContractionMode,\n rightContractionMode,\n }: HorizontalFlapOptions = {},\n) {\n const contractionLeft = contractionLeftInput ?? contraction;\n const contractionRight = contractionRightInput ?? contraction;\n\n const flapMaker = draw([-width / 2, 0]).hLine(width);\n\n if (contractionRight) {\n if ((rightContractionMode ?? contractionMode) === \"rounded\") {\n flapMaker.tangentArc(-contractionRight, contractionRight, [-1, 0]);\n flapMaker.vLine(height - contractionRight);\n } else {\n flapMaker.line(-contractionRight, height);\n }\n } else {\n flapMaker.vLine(height);\n }\n\n flapMaker.customCorner(fillet);\n flapMaker.hLine(-width + contractionLeft + contractionRight);\n flapMaker.customCorner(fillet);\n\n if (contractionLeft) {\n if ((leftContractionMode ?? contractionMode) === \"rounded\") {\n flapMaker.vLine(-height + contractionLeft);\n flapMaker.tangentArcTo([-width / 2, 0]);\n } else {\n flapMaker.lineTo([-width / 2, 0]);\n }\n } else {\n flapMaker.vLine(-height);\n }\n\n return flapMaker.close();\n}\n\nexport function topFlap(\n width: number,\n height: number,\n options: HorizontalFlapOptions = {},\n) {\n return drawFlap(width, height, options);\n}\n\nexport function bottomFlap(\n width: number,\n height: number,\n options: HorizontalFlapOptions = {},\n) {\n return drawFlap(width, height, options).mirror(\"x\");\n}\n\nexport function leftFlap(\n width: number,\n height: number,\n {\n contractionTop,\n contractionBottom,\n topContractionMode,\n bottomContractionMode,\n ...options\n }: VerticalFlapTopOptions = {},\n) {\n return drawFlap(width, height, {\n contractionLeft: contractionTop,\n contractionRight: contractionBottom,\n leftContractionMode: topContractionMode,\n rightContractionMode: bottomContractionMode,\n ...options,\n }).rotate(90);\n}\n\nexport function rightFlap(\n width: number,\n height: number,\n options: VerticalFlapTopOptions = {},\n) {\n return leftFlap(width, height, options).mirror(\"y\");\n}\n\nexport const drawFlaps = {\n right: rightFlap,\n left: leftFlap,\n top: topFlap,\n bottom: bottomFlap,\n};\n","import { draw } from \"pantograph2d\";\nimport {\n Diagram,\n Strand,\n Transformable,\n TransformationMatrix,\n} from \"pantograph2d/models\";\nimport { Dieline } from \"./Dieline.js\";\n\nconst drawBump = (width: number, height: number) => {\n return draw([-width / 2, 0])\n .line(height, -height)\n .hLine(width - 2 * height)\n .line(height, height);\n};\n\n// A helper class to create bumps for locking parts together without glue\nexport class FoldLockBump extends Transformable<FoldLockBump> {\n cut: Strand;\n unfold: Diagram;\n bump: Diagram;\n constructor(\n width: number | { cut: Strand; unfold: Diagram; bump: Diagram },\n paperThickness = 0.2,\n ) {\n super();\n\n if (typeof width !== \"number\") {\n this.cut = width.cut;\n this.unfold = width.unfold;\n this.bump = width.bump;\n return;\n }\n\n const pen = drawBump(width, paperThickness * 2.5);\n\n this.cut = pen.asStrand();\n this.unfold = pen.close();\n\n this.bump = drawBump(width - 5 * paperThickness, 5 * paperThickness)\n .close()\n .mirror(\"x\");\n }\n\n clone() {\n return new FoldLockBump(this);\n }\n\n transform(matrix: TransformationMatrix) {\n return new FoldLockBump({\n cut: this.cut.transform(matrix),\n unfold: this.unfold.transform(matrix),\n bump: this.bump.transform(matrix),\n });\n }\n\n makeCut(dieline: Dieline) {\n dieline.eraseFolds(this.unfold);\n dieline.addCutLine(this.cut);\n }\n\n fuseBump(dieline: Dieline) {\n dieline.fuseBody(this.bump);\n }\n}\n","import { Vector } from \"pantograph2d\";\nimport { Transformable, TransformationMatrix } from \"pantograph2d/models\";\n\ninterface Clonable {\n clone(): this;\n}\n\ninterface Translatable {\n translateTo(point: Vector): this;\n}\n\nclass PointsDistribution extends Transformable<PointsDistribution> {\n constructor(public points: Vector[]) {\n super();\n this.points = points;\n }\n\n transform(matrix: TransformationMatrix) {\n return new PointsDistribution(this.points.map(matrix.transform));\n }\n\n distribute<T extends Translatable>(s: T): T[] {\n return this.points.map((p) => s.translateTo(p));\n }\n\n cloneDistribute<T extends Translatable & Clonable>(s: T): T[] {\n return this.points.map((p) => s.clone().translateTo(p));\n }\n}\n\nexport function linearDistribution(\n totalWidth: number,\n objectWidth: number,\n gapShare = 3,\n margin = 0,\n) {\n if (totalWidth <= objectWidth * 2) {\n throw new Error(\"totalWidth must be greater than twice the objectWidth\");\n }\n\n const objectsCount = Math.max(\n Math.floor((totalWidth - 2 * margin) / (objectWidth * (gapShare + 1))),\n 2,\n );\n const freeSpace = totalWidth - 2 * margin - objectsCount * objectWidth;\n const gapSize = freeSpace / (objectsCount - 1);\n const points: number[] = [];\n for (let i = 0; i < objectsCount; i++) {\n points.push(\n margin + i * (objectWidth + gapSize) - totalWidth / 2 + objectWidth / 2,\n );\n }\n return new PointsDistribution(points.map((p) => [p, 0]));\n}\n\nexport function linearSpread(\n gap: number,\n count: number,\n direction: \"x\" | \"y\" = \"x\",\n) {\n const totalLength = gap * (count - 1);\n const points: number[] = [];\n for (let i = 0; i < count; i++) {\n points.push(i * gap - totalLength / 2);\n }\n return new PointsDistribution(\n points.map((p) => (direction.toLowerCase() === \"x\" ? [p, 0] : [0, p])),\n );\n}\n"],"names":["Xe","ye","r","Ze","s","t","q","oe","ht","le","Dt","e","he","Me","Ot","mt$1","mt","n","ce","Pe","Ne","fe","Je","Z","Y","it","Q","Tt","pn","nt","Rt","J","St","be","H","It","Ke","He","Ve","i","tt","Qt","ts","Ee","yt","l","a","u","c","g","d","w","P","y","E","es","ss","et$1","et","ns","_e","at","Ft","o","h","is","Kt","wt","Zt","me","yn","Bt","je","ct","Mn","Pn","Se","zt","ke","Re","rs","os","R","L","S","D","v","$e","Le","$","ls","Ct","hs","as","us","cs","fs","ms","gs","st","ve","Ut","De","ws","Oe","ps","ds","Ie","ys","ot","lt","Pt","bt","ge","we","ae","Yt","Ht","Mt","Ms","Ps","bs","Es","_s","js","Ss","ks","Rs","vs","Is","Ts","Cs","As","Fs","xs","Ns","N","_","m","b","j","M","C","A","T","z","F","V","x","B","U","I","O","X","G","W","se","ne","ie","re","xt","Nt","Vt","$t","Lt","Te","Vs","At","ue","dt","K","Jt","K$1","pt","te","$s","ft","Ls","Ds","Os","Bs","zs","Us","Ys","Be","Ws","rt","ee$1","ut","pe$1","vt$1","Qs","vt","ze","ee","pe","Xt","Gt","Gs","Xs","Zs","Js","Ks","Hs","Ue","tn","en","sn","nn","Wt","Ye","We","rn","Qe","Ce","on","ln","qt","kt","Ge","En","qe","gt","hn","an","un","cn","fn","de","Ae","Et","p","Fe","jt","gn","_n","mn","xe","_t","In","k","f","wn","xn","Sn","bn","Cn","An","ct$1","Fn","vn","Bn","kn","On","Ln","Tn","qn","zn","Dn","Rn","Nn","dn","Vn","at$1","jn","Un","Hn","$n","Yn","Xn","Gn","Qn","Wn","Kn","Jn","Zn","Dieline","Transformable","body","cutLines","foldLines","foldLinesForwards","foldLinesBackwards","__publicField","cut","fold","direction","otherBody","commonLines","other","shape","eraseStrand","matrix","shapes","exportSVG","drawFlap","width","height","fillet","contraction","contractionMode","contractionLeftInput","contractionRightInput","leftContractionMode","rightContractionMode","contractionLeft","contractionRight","flapMaker","draw","topFlap","options","bottomFlap","leftFlap","contractionTop","contractionBottom","topContractionMode","bottomContractionMode","rightFlap","drawFlaps","drawBump","FoldLockBump","paperThickness","pen","dieline","PointsDistribution","points","linearDistribution","totalWidth","objectWidth","gapShare","margin","objectsCount","gapSize","linearSpread","gap","count","totalLength"],"mappings":"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"}
1
+ {"version":3,"file":"dielines.umd.cjs","sources":["../../pantograph/dist/QuadraticBezier-BeY2TXKH.js","../../pantograph/dist/models-DfOxeufK.js","../../pantograph/dist/draw-DaKl45lJ.js","../../pantograph/dist/svg-BTO7h1ix.js","../../pantograph/dist/pantograph.js","../src/Dieline.ts","../src/drawFlaps.ts","../src/FoldLockBump.ts","../src/linearDistribution.ts"],"sourcesContent":["var Xe = Object.defineProperty;\nvar ye = (r) => {\n throw TypeError(r);\n};\nvar Ze = (r, s, t) => s in r ? Xe(r, s, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[s] = t;\nvar q = (r, s, t) => Ze(r, typeof s != \"symbol\" ? s + \"\" : s, t), oe = (r, s, t) => s.has(r) || ye(\"Cannot \" + t);\nvar ht = (r, s, t) => (oe(r, s, \"read from private field\"), t ? t.call(r) : s.get(r)), le = (r, s, t) => s.has(r) ? ye(\"Cannot add the same private member more than once\") : s instanceof WeakSet ? s.add(r) : s.set(r, t), Dt = (r, s, t, e) => (oe(r, s, \"write to private field\"), e ? e.call(r, t) : s.set(r, t), t), he = (r, s, t) => (oe(r, s, \"access private method\"), t);\nconst Me = Symbol.for(\"pantograph:BoundingBox\");\nfunction Ot(r, s, t, e) {\n return r <= e && s >= t;\n}\nclass mt {\n constructor(s = 1 / 0, t = 1 / 0, e = -1 / 0, n = -1 / 0) {\n q(this, \"xMin\");\n q(this, \"yMin\");\n q(this, \"xMax\");\n q(this, \"yMax\");\n Object.defineProperty(this, Me, { value: !0 }), this.xMin = s, this.yMin = t, this.xMax = e, this.yMax = n;\n }\n static isInstance(s) {\n return !!s && s[Me] === !0;\n }\n get width() {\n return this.xMax - this.xMin;\n }\n get height() {\n return this.yMax - this.yMin;\n }\n get center() {\n return [(this.xMin + this.xMax) / 2, (this.yMin + this.yMax) / 2];\n }\n grow(s) {\n return new mt(\n this.xMin - s,\n this.yMin - s,\n this.xMax + s,\n this.yMax + s\n );\n }\n contains(s) {\n const [t, e] = s;\n return Ot(this.xMin, this.xMax, t, t) && Ot(this.yMin, this.yMax, e, e);\n }\n overlaps(s) {\n return Ot(this.xMin, this.xMax, s.xMin, s.xMax) && Ot(this.yMin, this.yMax, s.yMin, s.yMax);\n }\n addPoint(s) {\n const [t, e] = s;\n return new mt(\n Math.min(this.xMin, t),\n Math.min(this.yMin, e),\n Math.max(this.xMax, t),\n Math.max(this.yMax, e)\n );\n }\n merge(s) {\n return new mt(\n Math.min(this.xMin, s.xMin),\n Math.min(this.yMin, s.yMin),\n Math.max(this.xMax, s.xMax),\n Math.max(this.yMax, s.yMax)\n );\n }\n intersection(s) {\n return new mt(\n Math.max(this.xMin, s.xMin),\n Math.max(this.yMin, s.yMin),\n Math.min(this.xMax, s.xMax),\n Math.min(this.yMax, s.yMax)\n );\n }\n}\nfunction ce(r) {\n return r.reduce((s, t) => s.addPoint(t), new mt());\n}\nconst Pe = (r, s = 1e-9) => {\n let t = r;\n return Math.abs(r) < s && (t = 0), t.toFixed(-Math.log10(s));\n};\nfunction Ne(r, s = 1e-9) {\n return Array.from(\n new Map(\n r.map(([t, e]) => [\n `[${Pe(t, s)},${Pe(e, s)}]`,\n [t, e]\n ])\n ).values()\n );\n}\nconst fe = Math.PI / 180, Je = 180 / Math.PI, Z = (r) => `[${r[0]}, ${r[1]}]`, Y = ([r, s], [t, e], n = 1e-9) => Math.abs(r - t) <= n && Math.abs(s - e) <= n, it = ([r, s], [t, e]) => [r + t, s + e], Q = ([r, s], [t, e]) => [r - t, s - e], Tt = ([r, s]) => r * r + s * s, pn = ([r, s]) => Math.sqrt(Tt([r, s])), nt = ([r, s], t) => [r * t, s * t], Rt = ([r, s], [t, e] = [0, 0]) => (r - t) ** 2 + (s - e) ** 2, J = (r, s = [0, 0]) => Math.sqrt(Rt(r, s));\nfunction St([r, s], [t, e]) {\n return r * e - s * t;\n}\nfunction be([r, s], [t, e]) {\n return r * t + s * e;\n}\nfunction dn([r, s], [t, e] = [0, 0]) {\n return Math.atan2(e * r - s * t, r * t + s * e);\n}\nfunction H([r, s]) {\n const t = J([r, s]);\n return [r / t, s / t];\n}\nfunction It(r, s) {\n const t = Math.cos(s) * r, e = Math.sin(s) * r;\n return [t, e];\n}\nfunction Ke([r, s]) {\n return Math.atan2(s, r);\n}\nfunction He(r) {\n const s = J(r), t = Ke(r);\n return [s, t];\n}\nfunction Ve(r, s, t = 1e-9) {\n const e = St(r, s), n = Tt(r), i = Tt(s);\n return e * e < n * i * t * t;\n}\nfunction tt(r) {\n return [-r[1], r[0]];\n}\nfunction Qt(r) {\n return [r[1], -r[0]];\n}\nfunction ts(r, s, t) {\n return Y(t, r) || Ve(Q(t, r), s);\n}\nconst Ee = Symbol.for(\n \"pantograph:TransformationMatrix\"\n), yt = (r, s) => {\n const [t, e, n, i, o, l, h, a, u] = r, [c, g, d, w, p, P, f, y, E] = s;\n return [\n t * c + e * w + n * f,\n t * g + e * p + n * y,\n t * d + e * P + n * E,\n i * c + o * w + l * f,\n i * g + o * p + l * y,\n i * d + o * P + l * E,\n h * c + a * w + u * f,\n h * g + a * p + u * y,\n h * d + a * P + u * E\n ];\n}, es = (r) => {\n const [s, t, e, n, i, o, l, h, a] = r, u = s * (i * a - o * h) - t * (n * a - o * l) + e * (n * h - i * l);\n return [\n (i * a - o * h) / u,\n (e * h - t * a) / u,\n (t * o - e * i) / u,\n (o * l - n * a) / u,\n (s * a - e * l) / u,\n (e * n - s * o) / u,\n (n * h - i * l) / u,\n (t * l - s * h) / u,\n (s * i - t * n) / u\n ];\n}, ss = (r) => {\n const [s, t, e, n, i, o, l, h, a] = r;\n return [s, n, l, t, i, h, e, o, a];\n};\nclass et {\n constructor(s) {\n q(this, \"_matrix\", [1, 0, 0, 0, 1, 0, 0, 0, 1]);\n Object.defineProperty(this, Ee, {\n value: !0\n }), s && (this._matrix = [...s]);\n }\n static isInstance(s) {\n return !!s && s[Ee] === !0;\n }\n clone() {\n return new et(this._matrix);\n }\n transpose() {\n return this._matrix = ss(this._matrix), this;\n }\n inverse() {\n return this._matrix = es(this._matrix), this;\n }\n translate(s, t) {\n return this._matrix = yt([1, 0, s, 0, 1, t, 0, 0, 1], this._matrix), this;\n }\n rotate(s, t) {\n const e = Math.cos(s), n = Math.sin(s), i = [e, -n, 0, n, e, 0, 0, 0, 1];\n return t && this.translate(-t[0], -t[1]), this._matrix = yt(i, this._matrix), t && this.translate(t[0], t[1]), this;\n }\n mirrorX() {\n return this._matrix = yt([1, 0, 0, 0, -1, 0, 0, 0, 1], this._matrix), this;\n }\n mirrorY() {\n return this._matrix = yt([-1, 0, 0, 0, 1, 0, 0, 0, 1], this._matrix), this;\n }\n mirrorLine(s, t) {\n const [e, n] = s, i = Math.atan2(n, e);\n return t && this.translate(-t[0], -t[1]), this.rotate(-i), this.mirrorX(), this.rotate(i), t && this.translate(t[0], t[1]), this;\n }\n mirrorCenter(s) {\n return s && this.translate(-s[0], -s[1]), this._matrix = yt([-1, 0, 0, 0, -1, 0, 0, 0, 1], this._matrix), s && this.translate(s[0], s[1]), this;\n }\n scale(s, t) {\n return t && this.translate(-t[0], -t[1]), this._matrix = yt([s, 0, 0, 0, s, 0, 0, 0, 1], this._matrix), t && this.translate(t[0], t[1]), this;\n }\n transform(s) {\n const [t, e] = s, [n, i, o, l, h, a] = this._matrix;\n return [n * t + i * e + o, l * t + h * e + a];\n }\n transformAngle(s) {\n const [t, e] = this.transform([Math.cos(s), Math.sin(s)]), [n, i] = this.transform([0, 0]);\n return Math.atan2(e - i, t - n);\n }\n keepsOrientation() {\n const [s, , , , t] = this._matrix;\n return s * t > 0;\n }\n scaleFactor() {\n const [s, , , t] = this._matrix;\n return Math.sqrt(s * s + t * t);\n }\n}\nclass ns {\n translateX(s) {\n const t = new et().translate(s, 0);\n return this.transform(t);\n }\n translateY(s) {\n const t = new et().translate(0, s);\n return this.transform(t);\n }\n translate(s, t) {\n const e = new et().translate(s, t);\n return this.transform(e);\n }\n translateTo([s, t]) {\n const e = new et().translate(s, t);\n return this.transform(e);\n }\n rotate(s, t) {\n const e = new et().rotate(\n s * fe,\n t\n );\n return this.transform(e);\n }\n scale(s, t) {\n const e = new et().scale(s, t);\n return this.transform(e);\n }\n mirrorCenter(s) {\n const t = new et().mirrorCenter(s);\n return this.transform(t);\n }\n mirror(s = \"x\", t) {\n const e = new et();\n return s === \"x\" ? e.mirrorX() : s === \"y\" ? e.mirrorY() : e.mirrorLine(s, t), this.transform(e);\n }\n}\nclass Ft extends ns {\n constructor(t, e) {\n super();\n q(this, \"precision\", 1e-9);\n this.firstPoint = t, this.lastPoint = e, this.firstPoint = t, this.lastPoint = e;\n }\n get repr() {\n return `${this.segmentType} ${Z(this.firstPoint)} - ${Z(\n this.lastPoint\n )}`;\n }\n get info() {\n return this.repr;\n }\n [Symbol.for(\"nodejs.util.inspect.custom\")]() {\n return this.repr;\n }\n}\nconst _e = Symbol.for(\"pantograph:Line\");\nclass at extends Ft {\n constructor(t, e) {\n super(t, e);\n q(this, \"segmentType\", \"LINE\");\n q(this, \"_V\", null);\n q(this, \"_slope\", null);\n q(this, \"_yIntercept\", null);\n q(this, \"_boundingBox\", null);\n Object.defineProperty(this, _e, { value: !0 });\n }\n static isInstance(t) {\n return !!t && t[_e] === !0;\n }\n isValidParameter(t) {\n const e = this.length * this.precision;\n return t >= -e && 1 - t >= -e;\n }\n paramPoint(t) {\n return it(this.firstPoint, nt(this.V, t));\n }\n get length() {\n return J(this.firstPoint, this.lastPoint);\n }\n get squareLength() {\n return Rt(this.firstPoint, this.lastPoint);\n }\n get V() {\n return this._V === null && (this._V = Q(this.lastPoint, this.firstPoint)), this._V;\n }\n get slope() {\n if (this._slope === null) {\n const [t, e] = this.V;\n this._slope = e / t;\n }\n return this._slope;\n }\n get yIntercept() {\n return this._yIntercept === null && (this._yIntercept = this.firstPoint[1] - this.slope * this.firstPoint[0]), this._yIntercept;\n }\n get midPoint() {\n return it(this.firstPoint, nt(this.V, 0.5));\n }\n isSame(t) {\n return at.isInstance(t) ? Y(this.firstPoint, t.firstPoint) && Y(this.lastPoint, t.lastPoint) || Y(this.lastPoint, t.firstPoint) && Y(this.firstPoint, t.lastPoint) : !1;\n }\n clone() {\n return new at(this.firstPoint, this.lastPoint);\n }\n reverse() {\n return new at(this.lastPoint, this.firstPoint);\n }\n get boundingBox() {\n return this._boundingBox === null && (this._boundingBox = new mt(\n Math.min(this.firstPoint[0], this.lastPoint[0]) - this.precision,\n Math.min(this.firstPoint[1], this.lastPoint[1]) - this.precision,\n Math.max(this.firstPoint[0], this.lastPoint[0]) + this.precision,\n Math.max(this.firstPoint[1], this.lastPoint[1]) + this.precision\n )), this._boundingBox;\n }\n distanceFrom(t) {\n const e = Q(t, this.firstPoint), n = be(e, this.V) / this.squareLength;\n if (n < 0)\n return J(t, this.firstPoint);\n if (n > 1)\n return J(t, this.lastPoint);\n const i = this.paramPoint(n);\n return J(t, i);\n }\n isOnSegment(t) {\n if (Y(t, this.firstPoint, this.precision)) return !0;\n const e = Q(t, this.firstPoint);\n if (!Ve(this.V, e)) return !1;\n const n = be(e, this.V) / this.squareLength;\n return this.isValidParameter(n);\n }\n gradientAt(t) {\n return this.V;\n }\n tangentAt(t) {\n if (!this.isOnSegment(t)) throw new Error(\"Point is not on segment\");\n return H(this.V);\n }\n get normalVector() {\n return tt(H(this.V));\n }\n get tangentAtFirstPoint() {\n return H(this.V);\n }\n get tangentAtLastPoint() {\n return H(this.V);\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t], e.forEach((a) => {\n if (!this.isOnSegment(a))\n throw new Error(\n `Point ${Z(a)} is not on segment ${this.repr}`\n );\n });\n const n = [this.firstPoint, ...e, this.lastPoint], i = Ne(n), o = this.lastPoint[0] - this.firstPoint[0];\n let l = Math.sign(o), h = 0;\n return Math.abs(o) < this.precision && (l = Math.sign(this.lastPoint[1] - this.firstPoint[1]), h = 1), i.sort(\n (a, u) => l * (a[h] - u[h])\n ), i.flatMap((a, u) => u === i.length - 1 ? [] : new at(a, i[u + 1]));\n }\n transform(t) {\n return new at(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint)\n );\n }\n}\nfunction is(r) {\n return Array.from(Array(r).keys());\n}\nfunction Kt(r) {\n const s = Math.min(...r.map((t) => t.length));\n return is(s).map((t) => r.map((e) => e[t]));\n}\nfunction wt(r, s = 1e-9) {\n return r < 0 ? r + 2 * Math.PI : r >= 2 * Math.PI ? r % (2 * Math.PI) : r > 2 * Math.PI - s ? 0 : r;\n}\nfunction Zt(r, s, t, e = 1e-9) {\n let n = s - r;\n return t && (n = -n), n < 0 && (n += 2 * Math.PI), n > 2 * Math.PI - e ? 0 : n;\n}\nconst me = (r, s, t) => {\n const e = St(r.V, s.V), n = Tt(r.V), i = Tt(s.V), o = t ? t * t : r.precision * s.precision;\n if (e * e < n * i * o)\n return \"parallel\";\n const l = Q(s.firstPoint, r.firstPoint), h = St(l, s.V) / e, a = St(l, r.V) / e;\n return {\n intersectionParam1: h,\n intersectionParam2: a\n };\n};\nfunction yn(r, s, t = !1, e) {\n const n = me(r, s, e);\n if (n === \"parallel\") {\n if (!t) return null;\n if (r.isSame(s)) return r;\n const l = Ne(\n [\n s.isOnSegment(r.firstPoint) ? r.firstPoint : null,\n s.isOnSegment(r.lastPoint) ? r.lastPoint : null,\n r.isOnSegment(s.firstPoint) ? s.firstPoint : null,\n r.isOnSegment(s.lastPoint) ? s.lastPoint : null\n ].filter((h) => h !== null)\n ).sort((h, a) => h[0] - a[0]);\n if (l.length === 0) return null;\n if (l.length === 1) return null;\n if (l.length === 2) return new at(l[0], l[1]);\n throw console.error(l), new Error(\n \"Unexpected number of points while intersecting parallel lines\"\n );\n }\n const { intersectionParam1: i, intersectionParam2: o } = n;\n return !r.isValidParameter(i) || !s.isValidParameter(o) ? null : r.paramPoint(i);\n}\nconst Bt = (r, s) => {\n const t = Q(r, s);\n return He(t);\n}, je = Symbol.for(\"pantograph:Arc\");\nclass ct extends Ft {\n constructor(t, e, n, i = !1, { ignoreChecks: o = !1 } = {}) {\n super(t, e);\n q(this, \"segmentType\", \"ARC\");\n q(this, \"center\");\n q(this, \"clockwise\");\n q(this, \"_coefficients\", null);\n q(this, \"_angularLength\", null);\n q(this, \"_radius\", null);\n q(this, \"_firstAngle\", null);\n q(this, \"_lastAngle\", null);\n q(this, \"_boundingBox\", null);\n if (Object.defineProperty(this, je, { value: !0 }), this.center = n, this.clockwise = i, !o) {\n if (Y(t, e))\n throw new Error(\"Invalid arc, cannot be a full circle\");\n if (Math.abs(this.radius - J(this.lastPoint, this.center)) > this.precision)\n throw new Error(\n `Invalid arc, radius does not match between ${Z(\n t\n )} and ${Z(e)}} (center ${Z(n)})`\n );\n }\n }\n static isInstance(t) {\n return !!t && t[je] === !0;\n }\n get info() {\n return `ARC(${Z(this.firstPoint)}, ${Z(\n this.lastPoint\n )}, ${Z(this.center)}, ${this.clockwise ? \"CW\" : \"CCW\"})`;\n }\n get coefficients() {\n if (this._coefficients === null) {\n const [t, e] = this.center, n = this.radius * this.radius;\n this._coefficients = {\n x2: 1 / n,\n xy: 0,\n y2: 1 / n,\n x: -(2 * t) / n,\n y: -(2 * e) / n,\n c: (t * t + e * e - n) / n\n };\n }\n return this._coefficients;\n }\n isValidParameter(t) {\n return 1 - t >= -this.precision && t >= -this.precision;\n }\n angleToParam(t) {\n return Zt(this.firstAngle, wt(t), this.clockwise) / this.angularLength;\n }\n get angularLength() {\n return this._angularLength || (this._angularLength = Zt(\n this.firstAngle,\n this.lastAngle,\n this.clockwise\n )), this._angularLength;\n }\n paramPoint(t) {\n return it(\n this.center,\n It(\n this.radius,\n this.firstAngle + t * this.angularLength * (this.clockwise ? -1 : 1)\n )\n );\n }\n pointToParam(t) {\n const [e, n] = Bt(t, this.center);\n if (Math.abs(e - this.radius) > this.precision)\n throw new Error(\n `Point ${Z(t)} is not on segment ${this.repr}`\n );\n const i = this.angleToParam(n);\n if (!this.isValidParameter(i))\n throw new Error(\n `Point ${Z(t)} is not on segment ${this.repr}`\n );\n return i;\n }\n get radius() {\n return this._radius === null && (this._radius = J(this.firstPoint, this.center)), this._radius;\n }\n get firstAngle() {\n if (this._firstAngle === null) {\n const [t, e] = Q(this.firstPoint, this.center);\n this._firstAngle = wt(Math.atan2(e, t));\n }\n return this._firstAngle;\n }\n get lastAngle() {\n if (this._lastAngle === null) {\n const [t, e] = Q(this.lastPoint, this.center);\n this._lastAngle = wt(Math.atan2(e, t));\n }\n return this._lastAngle;\n }\n get length() {\n return this.radius * this.angularLength;\n }\n get squareLength() {\n return this.length * this.length;\n }\n get midPoint() {\n return this.paramPoint(0.5);\n }\n isSame(t) {\n return !ct.isInstance(t) || !Y(this.center, t.center) ? !1 : Y(this.firstPoint, t.firstPoint) && Y(this.lastPoint, t.lastPoint) && this.clockwise === t.clockwise || Y(this.lastPoint, t.firstPoint) && Y(this.firstPoint, t.lastPoint) && this.clockwise === !t.clockwise;\n }\n clone() {\n return new ct(\n this.firstPoint,\n this.lastPoint,\n this.center,\n this.clockwise\n );\n }\n reverse() {\n return new ct(\n this.lastPoint,\n this.firstPoint,\n this.center,\n !this.clockwise\n );\n }\n get boundingBox() {\n if (this._boundingBox === null) {\n const t = this.radius + this.precision, e = (n) => this.isValidParameter(this.angleToParam(n));\n this._boundingBox = new mt(\n e(Math.PI) ? this.center[0] - t : Math.min(this.firstPoint[0], this.lastPoint[0]) - this.precision,\n e(Math.PI * 1.5) ? this.center[1] - t : Math.min(this.firstPoint[1], this.lastPoint[1]) - this.precision,\n e(0) ? this.center[0] + t : Math.max(this.firstPoint[0], this.lastPoint[0]) + this.precision,\n e(Math.PI / 2) ? this.center[1] + t : Math.max(this.firstPoint[1], this.lastPoint[1]) + this.precision\n );\n }\n return this._boundingBox;\n }\n distanceFrom(t) {\n const [e, n] = Bt(t, this.center);\n return this.isValidParameter(this.angleToParam(n)) ? Math.abs(e - this.radius) : Math.sqrt(\n Math.min(\n Rt(t, this.firstPoint),\n Rt(t, this.lastPoint)\n )\n );\n }\n isOnSegment(t) {\n if (Y(t, this.firstPoint) || Y(t, this.lastPoint))\n return !0;\n const [e, n] = Bt(t, this.center);\n if (Math.abs(e - this.radius) > this.precision) return !1;\n const i = this.angleToParam(n);\n return this.isValidParameter(i);\n }\n gradientAt(t) {\n const e = this.firstAngle + t * this.angularLength * (this.clockwise ? -1 : 1), n = this.radius * this.angularLength, i = -n * Math.sin(e), o = n * Math.cos(e);\n return this.clockwise ? [-i, -o] : [i, o];\n }\n tangentAt(t) {\n const [e, n] = Bt(t, this.center);\n if (Math.abs(e - this.radius) > this.precision)\n throw new Error(\"Point is not on the arc\");\n const i = this.angleToParam(n);\n if (!this.isValidParameter(i))\n throw new Error(\"Point is not on the arc\");\n const o = It(1, n);\n return (this.clockwise ? Qt : tt)(H(o));\n }\n get tangentAtFirstPoint() {\n const t = It(1, this.firstAngle);\n return (this.clockwise ? Qt : tt)(H(t));\n }\n get tangentAtLastPoint() {\n const t = It(1, this.lastAngle);\n return (this.clockwise ? Qt : tt)(H(t));\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t];\n const i = [0, 1, ...e.map((h) => this.pointToParam(h))], o = new Map(\n Kt([i, [this.firstPoint, this.lastPoint, ...e]])\n );\n i.sort((h, a) => h - a);\n let l = null;\n return i.flatMap((h, a) => {\n if (a === i.length - 1) return [];\n const u = i[a + 1];\n if (u - h < this.precision)\n return l === null && (l = h), [];\n const c = l === null ? h : l, g = new ct(\n o.get(c) || this.paramPoint(c),\n o.get(u) || this.paramPoint(u),\n this.center,\n this.clockwise\n );\n return l = null, g;\n });\n }\n transform(t) {\n return new ct(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint),\n t.transform(this.center),\n t.keepsOrientation() ? this.clockwise : !this.clockwise\n );\n }\n}\nfunction Mn(r, s, t) {\n const e = new at(s, r), n = new at(s, t), i = tt(e.tangentAtFirstPoint), o = tt(n.tangentAtLastPoint), l = me(\n { firstPoint: e.midPoint, V: i, precision: 1e-9 },\n { firstPoint: n.midPoint, V: o, precision: 1e-9 }\n );\n if (l === \"parallel\")\n throw new Error(\"Cannot create an arc from three colinear points\");\n const h = St(\n Q(r, s),\n Q(t, s)\n ) > 0;\n return new ct(\n r,\n t,\n it(e.midPoint, nt(i, l.intersectionParam1)),\n h,\n { ignoreChecks: !0 }\n );\n}\nfunction Pn(r, s, t) {\n const e = new at(r, s), n = tt(e.tangentAtFirstPoint), i = me(\n { firstPoint: e.midPoint, V: n, precision: 1e-9 },\n {\n firstPoint: r,\n V: tt(t),\n precision: 1e-9\n }\n );\n if (i === \"parallel\")\n throw new Error(\"Cannot create an arc from three colinear points\");\n const o = it(\n e.midPoint,\n nt(n, i.intersectionParam1)\n ), l = St(\n Q(o, r),\n Q(o, it(r, t))\n ) < 0;\n return new ct(r, s, o, l, {\n ignoreChecks: !0\n });\n}\nconst Se = 1e-21, zt = 1.618034;\nfunction ke(r, s = 0, t = 1, e = 110, n = 1e3) {\n let i, o, l, h, a, u, c, g, d, w, p, P, f;\n for (o = r(s), l = r(t), o < l && ([s, t] = [t, s], [o, l] = [l, o]), f = t + zt * (t - s), h = r(f), a = 3, c = 0; h < l; ) {\n if (g = (t - s) * (l - h), d = (t - f) * (l - o), w = d - g, Math.abs(w) < Se ? i = 2 * Se : i = 2 * w, p = t - ((t - f) * d - (t - s) * g) / i, P = t + e * (f - t), c > n)\n throw new Error(\"Too many iterations.\");\n if (c += 1, (p - f) * (t - p) > 0) {\n if (u = r(p), a += 1, u < h)\n return s = t, t = p, o = l, l = u, [s, t, f, o, l, h, a];\n if (u > l)\n return f = p, h = u, [s, t, f, o, l, h, a];\n p = f + zt * (f - t), u = r(p), a += 1;\n } else\n (p - P) * (P - f) >= 0 ? (p = P, u = r(p), a += 1) : (p - P) * (f - p) > 0 ? (u = r(p), a += 1, u < h && (t = f, f = p, p = f + zt * (f - t), l = h, h = u, u = r(p), a += 1)) : (p = f + zt * (f - t), u = r(p), a += 1);\n s = t, t = f, f = p, o = l, l = h, h = u;\n }\n return [s, t, f, o, l, h, a];\n}\nconst Re = 0.381966, rs = 1e-11;\nclass os {\n constructor(s, t = 148e-10, e = 500) {\n q(this, \"xmin\");\n q(this, \"fval\");\n q(this, \"iter\");\n q(this, \"funcalls\");\n q(this, \"brack\");\n this.func = s, this.tol = t, this.maxiter = e, this.func = s, this.tol = t, this.maxiter = e, this.xmin = 1 / 0, this.fval = 1 / 0, this.iter = 0, this.funcalls = 0, this.brack = null;\n }\n setBracket(s = null) {\n this.brack = s;\n }\n getBracketInfo() {\n let s, t, e, n, i, o, l;\n const h = this.func, a = this.brack;\n if (a === null)\n [i, o, l, s, t, e, n] = ke(h);\n else if (a.length === 2)\n [i, o, l, s, t, e, n] = ke(h, a[0], a[1]);\n else if (a.length === 3) {\n if ([i, o, l] = a, i > l && ([l, i] = [i, l]), !(i < o && o < l))\n throw new Error(\"Not a bracketing interval.\");\n if (s = h(i), t = h(o), e = h(l), !(t < s && t < e))\n throw new Error(\"Not a bracketing interval.\");\n n = 3;\n } else\n throw new Error(\n \"Bracketing interval must be length 2 or 3 sequence.\"\n );\n return [i, o, l, s, t, e, n];\n }\n optimize() {\n const s = this.func;\n let [t, e, n, , , , i] = this.getBracketInfo(), o = e, l = e, h = e, a = s(o), u = a, c = a, g, d;\n t < n ? (g = t, d = n) : (g = n, d = t);\n let w = 0;\n i = 1;\n let p = 0, P = 0, f;\n for (; p < this.maxiter; ) {\n const y = this.tol * Math.abs(o) + rs, E = 2 * y, R = 0.5 * (g + d);\n if (Math.abs(o - R) < E - 0.5 * (d - g))\n break;\n if (Math.abs(w) <= y)\n o >= R ? w = g - o : w = d - o, P = Re * w;\n else {\n const L = (o - l) * (c - u);\n let S = (o - h) * (c - a), k = (o - h) * S - (o - l) * L;\n S = 2 * (S - L), S > 0 && (k = -k), S = Math.abs(S);\n const D = w;\n w = P, k > S * (g - o) && k < S * (d - o) && Math.abs(k) < Math.abs(0.5 * S * D) ? (P = k * 1 / S, f = o + P, (f - g < E || d - f < E) && (R - o >= 0 ? P = y : P = -y)) : (o >= R ? w = g - o : w = d - o, P = Re * w);\n }\n Math.abs(P) < y ? P >= 0 ? f = o + y : f = o - y : f = o + P;\n const v = s(f);\n i += 1, v > c ? (f < o ? g = f : d = f, v <= a || l === o ? (h = l, l = f, u = a, a = v) : (v <= u || h === o || h === l) && (h = f, u = v)) : (f >= o ? g = o : d = o, h = l, l = o, o = f, u = a, a = c, c = v), p += 1;\n }\n this.xmin = o, this.fval = c, this.iter = p, this.funcalls = i;\n }\n results() {\n return {\n argMin: this.xmin,\n fMin: this.fval,\n iterations: this.iter,\n funcCalls: this.funcalls\n };\n }\n run() {\n return this.optimize(), this.results();\n }\n}\nfunction $e(r, s = 1e-8, t = 1e3) {\n const e = new os(r, s, t);\n return e.setBracket([0, 1]), e.run();\n}\nfunction Le(r) {\n if (r.__esModule) return r;\n var s = r.default;\n if (typeof s == \"function\") {\n var t = function e() {\n return this instanceof e ? Reflect.construct(s, arguments, this.constructor) : s.apply(this, arguments);\n };\n t.prototype = s.prototype;\n } else t = {};\n return Object.defineProperty(t, \"__esModule\", { value: !0 }), Object.keys(r).forEach(function(e) {\n var n = Object.getOwnPropertyDescriptor(r, e);\n Object.defineProperty(t, e, n.get ? n : {\n enumerable: !0,\n get: function() {\n return r[e];\n }\n });\n }), t;\n}\nvar $ = {};\nconst ls = Object.prototype.toString;\nfunction Ct(r) {\n const s = ls.call(r);\n return s.endsWith(\"Array]\") && !s.includes(\"Big\");\n}\nconst hs = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n isAnyArray: Ct\n}, Symbol.toStringTag, { value: \"Module\" })), as = /* @__PURE__ */ Le(hs);\nfunction us(r) {\n var s = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n if (!Ct(r))\n throw new TypeError(\"input must be an array\");\n if (r.length === 0)\n throw new TypeError(\"input must not be empty\");\n var t = s.fromIndex, e = t === void 0 ? 0 : t, n = s.toIndex, i = n === void 0 ? r.length : n;\n if (e < 0 || e >= r.length || !Number.isInteger(e))\n throw new Error(\"fromIndex must be a positive integer smaller than length\");\n if (i <= e || i > r.length || !Number.isInteger(i))\n throw new Error(\"toIndex must be an integer greater than fromIndex and at most equal to length\");\n for (var o = r[e], l = e + 1; l < i; l++)\n r[l] > o && (o = r[l]);\n return o;\n}\nfunction cs(r) {\n var s = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n if (!Ct(r))\n throw new TypeError(\"input must be an array\");\n if (r.length === 0)\n throw new TypeError(\"input must not be empty\");\n var t = s.fromIndex, e = t === void 0 ? 0 : t, n = s.toIndex, i = n === void 0 ? r.length : n;\n if (e < 0 || e >= r.length || !Number.isInteger(e))\n throw new Error(\"fromIndex must be a positive integer smaller than length\");\n if (i <= e || i > r.length || !Number.isInteger(i))\n throw new Error(\"toIndex must be an integer greater than fromIndex and at most equal to length\");\n for (var o = r[e], l = e + 1; l < i; l++)\n r[l] < o && (o = r[l]);\n return o;\n}\nfunction fs(r) {\n var s = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n if (Ct(r)) {\n if (r.length === 0)\n throw new TypeError(\"input must not be empty\");\n } else throw new TypeError(\"input must be an array\");\n var t;\n if (s.output !== void 0) {\n if (!Ct(s.output))\n throw new TypeError(\"output option must be an array if specified\");\n t = s.output;\n } else\n t = new Array(r.length);\n var e = cs(r), n = us(r);\n if (e === n)\n throw new RangeError(\"minimum and maximum input values are equal. Cannot rescale a constant array\");\n var i = s.min, o = i === void 0 ? s.autoMinMax ? e : 0 : i, l = s.max, h = l === void 0 ? s.autoMinMax ? n : 1 : l;\n if (o >= h)\n throw new RangeError(\"min option must be smaller than max option\");\n for (var a = (h - o) / (n - e), u = 0; u < r.length; u++)\n t[u] = (r[u] - e) * a + o;\n return t;\n}\nconst ms = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n default: fs\n}, Symbol.toStringTag, { value: \"Module\" })), gs = /* @__PURE__ */ Le(ms);\nObject.defineProperty($, \"__esModule\", { value: !0 });\nvar st = as, ve = gs;\nconst Ut = \" \".repeat(2), De = \" \".repeat(4);\nfunction ws() {\n return Oe(this);\n}\nfunction Oe(r, s = {}) {\n const {\n maxRows: t = 15,\n maxColumns: e = 10,\n maxNumSize: n = 8,\n padMinus: i = \"auto\"\n } = s;\n return `${r.constructor.name} {\n${Ut}[\n${De}${ps(r, t, e, n, i)}\n${Ut}]\n${Ut}rows: ${r.rows}\n${Ut}columns: ${r.columns}\n}`;\n}\nfunction ps(r, s, t, e, n) {\n const { rows: i, columns: o } = r, l = Math.min(i, s), h = Math.min(o, t), a = [];\n if (n === \"auto\") {\n n = !1;\n t: for (let u = 0; u < l; u++)\n for (let c = 0; c < h; c++)\n if (r.get(u, c) < 0) {\n n = !0;\n break t;\n }\n }\n for (let u = 0; u < l; u++) {\n let c = [];\n for (let g = 0; g < h; g++)\n c.push(ds(r.get(u, g), e, n));\n a.push(`${c.join(\" \")}`);\n }\n return h !== o && (a[a.length - 1] += ` ... ${o - t} more columns`), l !== i && a.push(`... ${i - s} more rows`), a.join(`\n${De}`);\n}\nfunction ds(r, s, t) {\n return (r >= 0 && t ? ` ${Ie(r, s - 1)}` : Ie(r, s)).padEnd(s);\n}\nfunction Ie(r, s) {\n let t = r.toString();\n if (t.length <= s) return t;\n let e = r.toFixed(s);\n if (e.length > s && (e = r.toFixed(Math.max(0, s - (e.length - s)))), e.length <= s && !e.startsWith(\"0.000\") && !e.startsWith(\"-0.000\"))\n return e;\n let n = r.toExponential(s);\n return n.length > s && (n = r.toExponential(Math.max(0, s - (n.length - s)))), n.slice(0);\n}\nfunction ys(r, s) {\n r.prototype.add = function(e) {\n return typeof e == \"number\" ? this.addS(e) : this.addM(e);\n }, r.prototype.addS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) + e);\n return this;\n }, r.prototype.addM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) + e.get(n, i));\n return this;\n }, r.add = function(e, n) {\n return new s(e).add(n);\n }, r.prototype.sub = function(e) {\n return typeof e == \"number\" ? this.subS(e) : this.subM(e);\n }, r.prototype.subS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) - e);\n return this;\n }, r.prototype.subM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) - e.get(n, i));\n return this;\n }, r.sub = function(e, n) {\n return new s(e).sub(n);\n }, r.prototype.subtract = r.prototype.sub, r.prototype.subtractS = r.prototype.subS, r.prototype.subtractM = r.prototype.subM, r.subtract = r.sub, r.prototype.mul = function(e) {\n return typeof e == \"number\" ? this.mulS(e) : this.mulM(e);\n }, r.prototype.mulS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) * e);\n return this;\n }, r.prototype.mulM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) * e.get(n, i));\n return this;\n }, r.mul = function(e, n) {\n return new s(e).mul(n);\n }, r.prototype.multiply = r.prototype.mul, r.prototype.multiplyS = r.prototype.mulS, r.prototype.multiplyM = r.prototype.mulM, r.multiply = r.mul, r.prototype.div = function(e) {\n return typeof e == \"number\" ? this.divS(e) : this.divM(e);\n }, r.prototype.divS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) / e);\n return this;\n }, r.prototype.divM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) / e.get(n, i));\n return this;\n }, r.div = function(e, n) {\n return new s(e).div(n);\n }, r.prototype.divide = r.prototype.div, r.prototype.divideS = r.prototype.divS, r.prototype.divideM = r.prototype.divM, r.divide = r.div, r.prototype.mod = function(e) {\n return typeof e == \"number\" ? this.modS(e) : this.modM(e);\n }, r.prototype.modS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) % e);\n return this;\n }, r.prototype.modM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) % e.get(n, i));\n return this;\n }, r.mod = function(e, n) {\n return new s(e).mod(n);\n }, r.prototype.modulus = r.prototype.mod, r.prototype.modulusS = r.prototype.modS, r.prototype.modulusM = r.prototype.modM, r.modulus = r.mod, r.prototype.and = function(e) {\n return typeof e == \"number\" ? this.andS(e) : this.andM(e);\n }, r.prototype.andS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) & e);\n return this;\n }, r.prototype.andM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) & e.get(n, i));\n return this;\n }, r.and = function(e, n) {\n return new s(e).and(n);\n }, r.prototype.or = function(e) {\n return typeof e == \"number\" ? this.orS(e) : this.orM(e);\n }, r.prototype.orS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) | e);\n return this;\n }, r.prototype.orM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) | e.get(n, i));\n return this;\n }, r.or = function(e, n) {\n return new s(e).or(n);\n }, r.prototype.xor = function(e) {\n return typeof e == \"number\" ? this.xorS(e) : this.xorM(e);\n }, r.prototype.xorS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) ^ e);\n return this;\n }, r.prototype.xorM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) ^ e.get(n, i));\n return this;\n }, r.xor = function(e, n) {\n return new s(e).xor(n);\n }, r.prototype.leftShift = function(e) {\n return typeof e == \"number\" ? this.leftShiftS(e) : this.leftShiftM(e);\n }, r.prototype.leftShiftS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) << e);\n return this;\n }, r.prototype.leftShiftM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) << e.get(n, i));\n return this;\n }, r.leftShift = function(e, n) {\n return new s(e).leftShift(n);\n }, r.prototype.signPropagatingRightShift = function(e) {\n return typeof e == \"number\" ? this.signPropagatingRightShiftS(e) : this.signPropagatingRightShiftM(e);\n }, r.prototype.signPropagatingRightShiftS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) >> e);\n return this;\n }, r.prototype.signPropagatingRightShiftM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) >> e.get(n, i));\n return this;\n }, r.signPropagatingRightShift = function(e, n) {\n return new s(e).signPropagatingRightShift(n);\n }, r.prototype.rightShift = function(e) {\n return typeof e == \"number\" ? this.rightShiftS(e) : this.rightShiftM(e);\n }, r.prototype.rightShiftS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) >>> e);\n return this;\n }, r.prototype.rightShiftM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) >>> e.get(n, i));\n return this;\n }, r.rightShift = function(e, n) {\n return new s(e).rightShift(n);\n }, r.prototype.zeroFillRightShift = r.prototype.rightShift, r.prototype.zeroFillRightShiftS = r.prototype.rightShiftS, r.prototype.zeroFillRightShiftM = r.prototype.rightShiftM, r.zeroFillRightShift = r.rightShift, r.prototype.not = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, ~this.get(e, n));\n return this;\n }, r.not = function(e) {\n return new s(e).not();\n }, r.prototype.abs = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.abs(this.get(e, n)));\n return this;\n }, r.abs = function(e) {\n return new s(e).abs();\n }, r.prototype.acos = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.acos(this.get(e, n)));\n return this;\n }, r.acos = function(e) {\n return new s(e).acos();\n }, r.prototype.acosh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.acosh(this.get(e, n)));\n return this;\n }, r.acosh = function(e) {\n return new s(e).acosh();\n }, r.prototype.asin = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.asin(this.get(e, n)));\n return this;\n }, r.asin = function(e) {\n return new s(e).asin();\n }, r.prototype.asinh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.asinh(this.get(e, n)));\n return this;\n }, r.asinh = function(e) {\n return new s(e).asinh();\n }, r.prototype.atan = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.atan(this.get(e, n)));\n return this;\n }, r.atan = function(e) {\n return new s(e).atan();\n }, r.prototype.atanh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.atanh(this.get(e, n)));\n return this;\n }, r.atanh = function(e) {\n return new s(e).atanh();\n }, r.prototype.cbrt = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.cbrt(this.get(e, n)));\n return this;\n }, r.cbrt = function(e) {\n return new s(e).cbrt();\n }, r.prototype.ceil = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.ceil(this.get(e, n)));\n return this;\n }, r.ceil = function(e) {\n return new s(e).ceil();\n }, r.prototype.clz32 = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.clz32(this.get(e, n)));\n return this;\n }, r.clz32 = function(e) {\n return new s(e).clz32();\n }, r.prototype.cos = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.cos(this.get(e, n)));\n return this;\n }, r.cos = function(e) {\n return new s(e).cos();\n }, r.prototype.cosh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.cosh(this.get(e, n)));\n return this;\n }, r.cosh = function(e) {\n return new s(e).cosh();\n }, r.prototype.exp = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.exp(this.get(e, n)));\n return this;\n }, r.exp = function(e) {\n return new s(e).exp();\n }, r.prototype.expm1 = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.expm1(this.get(e, n)));\n return this;\n }, r.expm1 = function(e) {\n return new s(e).expm1();\n }, r.prototype.floor = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.floor(this.get(e, n)));\n return this;\n }, r.floor = function(e) {\n return new s(e).floor();\n }, r.prototype.fround = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.fround(this.get(e, n)));\n return this;\n }, r.fround = function(e) {\n return new s(e).fround();\n }, r.prototype.log = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.log(this.get(e, n)));\n return this;\n }, r.log = function(e) {\n return new s(e).log();\n }, r.prototype.log1p = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.log1p(this.get(e, n)));\n return this;\n }, r.log1p = function(e) {\n return new s(e).log1p();\n }, r.prototype.log10 = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.log10(this.get(e, n)));\n return this;\n }, r.log10 = function(e) {\n return new s(e).log10();\n }, r.prototype.log2 = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.log2(this.get(e, n)));\n return this;\n }, r.log2 = function(e) {\n return new s(e).log2();\n }, r.prototype.round = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.round(this.get(e, n)));\n return this;\n }, r.round = function(e) {\n return new s(e).round();\n }, r.prototype.sign = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.sign(this.get(e, n)));\n return this;\n }, r.sign = function(e) {\n return new s(e).sign();\n }, r.prototype.sin = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.sin(this.get(e, n)));\n return this;\n }, r.sin = function(e) {\n return new s(e).sin();\n }, r.prototype.sinh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.sinh(this.get(e, n)));\n return this;\n }, r.sinh = function(e) {\n return new s(e).sinh();\n }, r.prototype.sqrt = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.sqrt(this.get(e, n)));\n return this;\n }, r.sqrt = function(e) {\n return new s(e).sqrt();\n }, r.prototype.tan = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.tan(this.get(e, n)));\n return this;\n }, r.tan = function(e) {\n return new s(e).tan();\n }, r.prototype.tanh = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.tanh(this.get(e, n)));\n return this;\n }, r.tanh = function(e) {\n return new s(e).tanh();\n }, r.prototype.trunc = function() {\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.set(e, n, Math.trunc(this.get(e, n)));\n return this;\n }, r.trunc = function(e) {\n return new s(e).trunc();\n }, r.pow = function(e, n) {\n return new s(e).pow(n);\n }, r.prototype.pow = function(e) {\n return typeof e == \"number\" ? this.powS(e) : this.powM(e);\n }, r.prototype.powS = function(e) {\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) ** e);\n return this;\n }, r.prototype.powM = function(e) {\n if (e = s.checkMatrix(e), this.rows !== e.rows || this.columns !== e.columns)\n throw new RangeError(\"Matrices dimensions must be equal\");\n for (let n = 0; n < this.rows; n++)\n for (let i = 0; i < this.columns; i++)\n this.set(n, i, this.get(n, i) ** e.get(n, i));\n return this;\n };\n}\nfunction ot(r, s, t) {\n let e = t ? r.rows : r.rows - 1;\n if (s < 0 || s > e)\n throw new RangeError(\"Row index out of range\");\n}\nfunction lt(r, s, t) {\n let e = t ? r.columns : r.columns - 1;\n if (s < 0 || s > e)\n throw new RangeError(\"Column index out of range\");\n}\nfunction Pt(r, s) {\n if (s.to1DArray && (s = s.to1DArray()), s.length !== r.columns)\n throw new RangeError(\n \"vector size must be the same as the number of columns\"\n );\n return s;\n}\nfunction bt(r, s) {\n if (s.to1DArray && (s = s.to1DArray()), s.length !== r.rows)\n throw new RangeError(\"vector size must be the same as the number of rows\");\n return s;\n}\nfunction ge(r, s) {\n if (!st.isAnyArray(s))\n throw new TypeError(\"row indices must be an array\");\n for (let t = 0; t < s.length; t++)\n if (s[t] < 0 || s[t] >= r.rows)\n throw new RangeError(\"row indices are out of range\");\n}\nfunction we(r, s) {\n if (!st.isAnyArray(s))\n throw new TypeError(\"column indices must be an array\");\n for (let t = 0; t < s.length; t++)\n if (s[t] < 0 || s[t] >= r.columns)\n throw new RangeError(\"column indices are out of range\");\n}\nfunction ae(r, s, t, e, n) {\n if (arguments.length !== 5)\n throw new RangeError(\"expected 4 arguments\");\n if (Yt(\"startRow\", s), Yt(\"endRow\", t), Yt(\"startColumn\", e), Yt(\"endColumn\", n), s > t || e > n || s < 0 || s >= r.rows || t < 0 || t >= r.rows || e < 0 || e >= r.columns || n < 0 || n >= r.columns)\n throw new RangeError(\"Submatrix indices are out of range\");\n}\nfunction Ht(r, s = 0) {\n let t = [];\n for (let e = 0; e < r; e++)\n t.push(s);\n return t;\n}\nfunction Yt(r, s) {\n if (typeof s != \"number\")\n throw new TypeError(`${r} must be a number`);\n}\nfunction Mt(r) {\n if (r.isEmpty())\n throw new Error(\"Empty matrix has no elements to index\");\n}\nfunction Ms(r) {\n let s = Ht(r.rows);\n for (let t = 0; t < r.rows; ++t)\n for (let e = 0; e < r.columns; ++e)\n s[t] += r.get(t, e);\n return s;\n}\nfunction Ps(r) {\n let s = Ht(r.columns);\n for (let t = 0; t < r.rows; ++t)\n for (let e = 0; e < r.columns; ++e)\n s[e] += r.get(t, e);\n return s;\n}\nfunction bs(r) {\n let s = 0;\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n s += r.get(t, e);\n return s;\n}\nfunction Es(r) {\n let s = Ht(r.rows, 1);\n for (let t = 0; t < r.rows; ++t)\n for (let e = 0; e < r.columns; ++e)\n s[t] *= r.get(t, e);\n return s;\n}\nfunction _s(r) {\n let s = Ht(r.columns, 1);\n for (let t = 0; t < r.rows; ++t)\n for (let e = 0; e < r.columns; ++e)\n s[e] *= r.get(t, e);\n return s;\n}\nfunction js(r) {\n let s = 1;\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n s *= r.get(t, e);\n return s;\n}\nfunction Ss(r, s, t) {\n const e = r.rows, n = r.columns, i = [];\n for (let o = 0; o < e; o++) {\n let l = 0, h = 0, a = 0;\n for (let u = 0; u < n; u++)\n a = r.get(o, u) - t[o], l += a, h += a * a;\n s ? i.push((h - l * l / n) / (n - 1)) : i.push((h - l * l / n) / n);\n }\n return i;\n}\nfunction ks(r, s, t) {\n const e = r.rows, n = r.columns, i = [];\n for (let o = 0; o < n; o++) {\n let l = 0, h = 0, a = 0;\n for (let u = 0; u < e; u++)\n a = r.get(u, o) - t[o], l += a, h += a * a;\n s ? i.push((h - l * l / e) / (e - 1)) : i.push((h - l * l / e) / e);\n }\n return i;\n}\nfunction Rs(r, s, t) {\n const e = r.rows, n = r.columns, i = e * n;\n let o = 0, l = 0, h = 0;\n for (let a = 0; a < e; a++)\n for (let u = 0; u < n; u++)\n h = r.get(a, u) - t, o += h, l += h * h;\n return s ? (l - o * o / i) / (i - 1) : (l - o * o / i) / i;\n}\nfunction vs(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) - s[t]);\n}\nfunction Is(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) - s[e]);\n}\nfunction Ts(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) - s);\n}\nfunction Cs(r) {\n const s = [];\n for (let t = 0; t < r.rows; t++) {\n let e = 0;\n for (let n = 0; n < r.columns; n++)\n e += r.get(t, n) ** 2 / (r.columns - 1);\n s.push(Math.sqrt(e));\n }\n return s;\n}\nfunction qs(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) / s[t]);\n}\nfunction As(r) {\n const s = [];\n for (let t = 0; t < r.columns; t++) {\n let e = 0;\n for (let n = 0; n < r.rows; n++)\n e += r.get(n, t) ** 2 / (r.rows - 1);\n s.push(Math.sqrt(e));\n }\n return s;\n}\nfunction Fs(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) / s[e]);\n}\nfunction xs(r) {\n const s = r.size - 1;\n let t = 0;\n for (let e = 0; e < r.columns; e++)\n for (let n = 0; n < r.rows; n++)\n t += r.get(n, e) ** 2 / s;\n return Math.sqrt(t);\n}\nfunction Ns(r, s) {\n for (let t = 0; t < r.rows; t++)\n for (let e = 0; e < r.columns; e++)\n r.set(t, e, r.get(t, e) / s);\n}\nclass N {\n static from1DArray(s, t, e) {\n if (s * t !== e.length)\n throw new RangeError(\"data length does not match given dimensions\");\n let i = new _(s, t);\n for (let o = 0; o < s; o++)\n for (let l = 0; l < t; l++)\n i.set(o, l, e[o * t + l]);\n return i;\n }\n static rowVector(s) {\n let t = new _(1, s.length);\n for (let e = 0; e < s.length; e++)\n t.set(0, e, s[e]);\n return t;\n }\n static columnVector(s) {\n let t = new _(s.length, 1);\n for (let e = 0; e < s.length; e++)\n t.set(e, 0, s[e]);\n return t;\n }\n static zeros(s, t) {\n return new _(s, t);\n }\n static ones(s, t) {\n return new _(s, t).fill(1);\n }\n static rand(s, t, e = {}) {\n if (typeof e != \"object\")\n throw new TypeError(\"options must be an object\");\n const { random: n = Math.random } = e;\n let i = new _(s, t);\n for (let o = 0; o < s; o++)\n for (let l = 0; l < t; l++)\n i.set(o, l, n());\n return i;\n }\n static randInt(s, t, e = {}) {\n if (typeof e != \"object\")\n throw new TypeError(\"options must be an object\");\n const { min: n = 0, max: i = 1e3, random: o = Math.random } = e;\n if (!Number.isInteger(n)) throw new TypeError(\"min must be an integer\");\n if (!Number.isInteger(i)) throw new TypeError(\"max must be an integer\");\n if (n >= i) throw new RangeError(\"min must be smaller than max\");\n let l = i - n, h = new _(s, t);\n for (let a = 0; a < s; a++)\n for (let u = 0; u < t; u++) {\n let c = n + Math.round(o() * l);\n h.set(a, u, c);\n }\n return h;\n }\n static eye(s, t, e) {\n t === void 0 && (t = s), e === void 0 && (e = 1);\n let n = Math.min(s, t), i = this.zeros(s, t);\n for (let o = 0; o < n; o++)\n i.set(o, o, e);\n return i;\n }\n static diag(s, t, e) {\n let n = s.length;\n t === void 0 && (t = n), e === void 0 && (e = t);\n let i = Math.min(n, t, e), o = this.zeros(t, e);\n for (let l = 0; l < i; l++)\n o.set(l, l, s[l]);\n return o;\n }\n static min(s, t) {\n s = this.checkMatrix(s), t = this.checkMatrix(t);\n let e = s.rows, n = s.columns, i = new _(e, n);\n for (let o = 0; o < e; o++)\n for (let l = 0; l < n; l++)\n i.set(o, l, Math.min(s.get(o, l), t.get(o, l)));\n return i;\n }\n static max(s, t) {\n s = this.checkMatrix(s), t = this.checkMatrix(t);\n let e = s.rows, n = s.columns, i = new this(e, n);\n for (let o = 0; o < e; o++)\n for (let l = 0; l < n; l++)\n i.set(o, l, Math.max(s.get(o, l), t.get(o, l)));\n return i;\n }\n static checkMatrix(s) {\n return N.isMatrix(s) ? s : new _(s);\n }\n static isMatrix(s) {\n return s != null && s.klass === \"Matrix\";\n }\n get size() {\n return this.rows * this.columns;\n }\n apply(s) {\n if (typeof s != \"function\")\n throw new TypeError(\"callback must be a function\");\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n s.call(this, t, e);\n return this;\n }\n to1DArray() {\n let s = [];\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n s.push(this.get(t, e));\n return s;\n }\n to2DArray() {\n let s = [];\n for (let t = 0; t < this.rows; t++) {\n s.push([]);\n for (let e = 0; e < this.columns; e++)\n s[t].push(this.get(t, e));\n }\n return s;\n }\n toJSON() {\n return this.to2DArray();\n }\n isRowVector() {\n return this.rows === 1;\n }\n isColumnVector() {\n return this.columns === 1;\n }\n isVector() {\n return this.rows === 1 || this.columns === 1;\n }\n isSquare() {\n return this.rows === this.columns;\n }\n isEmpty() {\n return this.rows === 0 || this.columns === 0;\n }\n isSymmetric() {\n if (this.isSquare()) {\n for (let s = 0; s < this.rows; s++)\n for (let t = 0; t <= s; t++)\n if (this.get(s, t) !== this.get(t, s))\n return !1;\n return !0;\n }\n return !1;\n }\n isDistance() {\n if (!this.isSymmetric()) return !1;\n for (let s = 0; s < this.rows; s++)\n if (this.get(s, s) !== 0) return !1;\n return !0;\n }\n isEchelonForm() {\n let s = 0, t = 0, e = -1, n = !0, i = !1;\n for (; s < this.rows && n; ) {\n for (t = 0, i = !1; t < this.columns && i === !1; )\n this.get(s, t) === 0 ? t++ : this.get(s, t) === 1 && t > e ? (i = !0, e = t) : (n = !1, i = !0);\n s++;\n }\n return n;\n }\n isReducedEchelonForm() {\n let s = 0, t = 0, e = -1, n = !0, i = !1;\n for (; s < this.rows && n; ) {\n for (t = 0, i = !1; t < this.columns && i === !1; )\n this.get(s, t) === 0 ? t++ : this.get(s, t) === 1 && t > e ? (i = !0, e = t) : (n = !1, i = !0);\n for (let o = t + 1; o < this.rows; o++)\n this.get(s, o) !== 0 && (n = !1);\n s++;\n }\n return n;\n }\n echelonForm() {\n let s = this.clone(), t = 0, e = 0;\n for (; t < s.rows && e < s.columns; ) {\n let n = t;\n for (let i = t; i < s.rows; i++)\n s.get(i, e) > s.get(n, e) && (n = i);\n if (s.get(n, e) === 0)\n e++;\n else {\n s.swapRows(t, n);\n let i = s.get(t, e);\n for (let o = e; o < s.columns; o++)\n s.set(t, o, s.get(t, o) / i);\n for (let o = t + 1; o < s.rows; o++) {\n let l = s.get(o, e) / s.get(t, e);\n s.set(o, e, 0);\n for (let h = e + 1; h < s.columns; h++)\n s.set(o, h, s.get(o, h) - s.get(t, h) * l);\n }\n t++, e++;\n }\n }\n return s;\n }\n reducedEchelonForm() {\n let s = this.echelonForm(), t = s.columns, e = s.rows, n = e - 1;\n for (; n >= 0; )\n if (s.maxRow(n) === 0)\n n--;\n else {\n let i = 0, o = !1;\n for (; i < e && o === !1; )\n s.get(n, i) === 1 ? o = !0 : i++;\n for (let l = 0; l < n; l++) {\n let h = s.get(l, i);\n for (let a = i; a < t; a++) {\n let u = s.get(l, a) - h * s.get(n, a);\n s.set(l, a, u);\n }\n }\n n--;\n }\n return s;\n }\n set() {\n throw new Error(\"set method is unimplemented\");\n }\n get() {\n throw new Error(\"get method is unimplemented\");\n }\n repeat(s = {}) {\n if (typeof s != \"object\")\n throw new TypeError(\"options must be an object\");\n const { rows: t = 1, columns: e = 1 } = s;\n if (!Number.isInteger(t) || t <= 0)\n throw new TypeError(\"rows must be a positive integer\");\n if (!Number.isInteger(e) || e <= 0)\n throw new TypeError(\"columns must be a positive integer\");\n let n = new _(this.rows * t, this.columns * e);\n for (let i = 0; i < t; i++)\n for (let o = 0; o < e; o++)\n n.setSubMatrix(this, this.rows * i, this.columns * o);\n return n;\n }\n fill(s) {\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, s);\n return this;\n }\n neg() {\n return this.mulS(-1);\n }\n getRow(s) {\n ot(this, s);\n let t = [];\n for (let e = 0; e < this.columns; e++)\n t.push(this.get(s, e));\n return t;\n }\n getRowVector(s) {\n return _.rowVector(this.getRow(s));\n }\n setRow(s, t) {\n ot(this, s), t = Pt(this, t);\n for (let e = 0; e < this.columns; e++)\n this.set(s, e, t[e]);\n return this;\n }\n swapRows(s, t) {\n ot(this, s), ot(this, t);\n for (let e = 0; e < this.columns; e++) {\n let n = this.get(s, e);\n this.set(s, e, this.get(t, e)), this.set(t, e, n);\n }\n return this;\n }\n getColumn(s) {\n lt(this, s);\n let t = [];\n for (let e = 0; e < this.rows; e++)\n t.push(this.get(e, s));\n return t;\n }\n getColumnVector(s) {\n return _.columnVector(this.getColumn(s));\n }\n setColumn(s, t) {\n lt(this, s), t = bt(this, t);\n for (let e = 0; e < this.rows; e++)\n this.set(e, s, t[e]);\n return this;\n }\n swapColumns(s, t) {\n lt(this, s), lt(this, t);\n for (let e = 0; e < this.rows; e++) {\n let n = this.get(e, s);\n this.set(e, s, this.get(e, t)), this.set(e, t, n);\n }\n return this;\n }\n addRowVector(s) {\n s = Pt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) + s[e]);\n return this;\n }\n subRowVector(s) {\n s = Pt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) - s[e]);\n return this;\n }\n mulRowVector(s) {\n s = Pt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) * s[e]);\n return this;\n }\n divRowVector(s) {\n s = Pt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) / s[e]);\n return this;\n }\n addColumnVector(s) {\n s = bt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) + s[t]);\n return this;\n }\n subColumnVector(s) {\n s = bt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) - s[t]);\n return this;\n }\n mulColumnVector(s) {\n s = bt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) * s[t]);\n return this;\n }\n divColumnVector(s) {\n s = bt(this, s);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n this.set(t, e, this.get(t, e) / s[t]);\n return this;\n }\n mulRow(s, t) {\n ot(this, s);\n for (let e = 0; e < this.columns; e++)\n this.set(s, e, this.get(s, e) * t);\n return this;\n }\n mulColumn(s, t) {\n lt(this, s);\n for (let e = 0; e < this.rows; e++)\n this.set(e, s, this.get(e, s) * t);\n return this;\n }\n max(s) {\n if (this.isEmpty())\n return NaN;\n switch (s) {\n case \"row\": {\n const t = new Array(this.rows).fill(Number.NEGATIVE_INFINITY);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) > t[e] && (t[e] = this.get(e, n));\n return t;\n }\n case \"column\": {\n const t = new Array(this.columns).fill(Number.NEGATIVE_INFINITY);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) > t[n] && (t[n] = this.get(e, n));\n return t;\n }\n case void 0: {\n let t = this.get(0, 0);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) > t && (t = this.get(e, n));\n return t;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n maxIndex() {\n Mt(this);\n let s = this.get(0, 0), t = [0, 0];\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) > s && (s = this.get(e, n), t[0] = e, t[1] = n);\n return t;\n }\n min(s) {\n if (this.isEmpty())\n return NaN;\n switch (s) {\n case \"row\": {\n const t = new Array(this.rows).fill(Number.POSITIVE_INFINITY);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) < t[e] && (t[e] = this.get(e, n));\n return t;\n }\n case \"column\": {\n const t = new Array(this.columns).fill(Number.POSITIVE_INFINITY);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) < t[n] && (t[n] = this.get(e, n));\n return t;\n }\n case void 0: {\n let t = this.get(0, 0);\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) < t && (t = this.get(e, n));\n return t;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n minIndex() {\n Mt(this);\n let s = this.get(0, 0), t = [0, 0];\n for (let e = 0; e < this.rows; e++)\n for (let n = 0; n < this.columns; n++)\n this.get(e, n) < s && (s = this.get(e, n), t[0] = e, t[1] = n);\n return t;\n }\n maxRow(s) {\n if (ot(this, s), this.isEmpty())\n return NaN;\n let t = this.get(s, 0);\n for (let e = 1; e < this.columns; e++)\n this.get(s, e) > t && (t = this.get(s, e));\n return t;\n }\n maxRowIndex(s) {\n ot(this, s), Mt(this);\n let t = this.get(s, 0), e = [s, 0];\n for (let n = 1; n < this.columns; n++)\n this.get(s, n) > t && (t = this.get(s, n), e[1] = n);\n return e;\n }\n minRow(s) {\n if (ot(this, s), this.isEmpty())\n return NaN;\n let t = this.get(s, 0);\n for (let e = 1; e < this.columns; e++)\n this.get(s, e) < t && (t = this.get(s, e));\n return t;\n }\n minRowIndex(s) {\n ot(this, s), Mt(this);\n let t = this.get(s, 0), e = [s, 0];\n for (let n = 1; n < this.columns; n++)\n this.get(s, n) < t && (t = this.get(s, n), e[1] = n);\n return e;\n }\n maxColumn(s) {\n if (lt(this, s), this.isEmpty())\n return NaN;\n let t = this.get(0, s);\n for (let e = 1; e < this.rows; e++)\n this.get(e, s) > t && (t = this.get(e, s));\n return t;\n }\n maxColumnIndex(s) {\n lt(this, s), Mt(this);\n let t = this.get(0, s), e = [0, s];\n for (let n = 1; n < this.rows; n++)\n this.get(n, s) > t && (t = this.get(n, s), e[0] = n);\n return e;\n }\n minColumn(s) {\n if (lt(this, s), this.isEmpty())\n return NaN;\n let t = this.get(0, s);\n for (let e = 1; e < this.rows; e++)\n this.get(e, s) < t && (t = this.get(e, s));\n return t;\n }\n minColumnIndex(s) {\n lt(this, s), Mt(this);\n let t = this.get(0, s), e = [0, s];\n for (let n = 1; n < this.rows; n++)\n this.get(n, s) < t && (t = this.get(n, s), e[0] = n);\n return e;\n }\n diag() {\n let s = Math.min(this.rows, this.columns), t = [];\n for (let e = 0; e < s; e++)\n t.push(this.get(e, e));\n return t;\n }\n norm(s = \"frobenius\") {\n switch (s) {\n case \"max\":\n return this.max();\n case \"frobenius\":\n return Math.sqrt(this.dot(this));\n default:\n throw new RangeError(`unknown norm type: ${s}`);\n }\n }\n cumulativeSum() {\n let s = 0;\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n s += this.get(t, e), this.set(t, e, s);\n return this;\n }\n dot(s) {\n N.isMatrix(s) && (s = s.to1DArray());\n let t = this.to1DArray();\n if (t.length !== s.length)\n throw new RangeError(\"vectors do not have the same size\");\n let e = 0;\n for (let n = 0; n < t.length; n++)\n e += t[n] * s[n];\n return e;\n }\n mmul(s) {\n s = _.checkMatrix(s);\n let t = this.rows, e = this.columns, n = s.columns, i = new _(t, n), o = new Float64Array(e);\n for (let l = 0; l < n; l++) {\n for (let h = 0; h < e; h++)\n o[h] = s.get(h, l);\n for (let h = 0; h < t; h++) {\n let a = 0;\n for (let u = 0; u < e; u++)\n a += this.get(h, u) * o[u];\n i.set(h, l, a);\n }\n }\n return i;\n }\n mpow(s) {\n if (!this.isSquare())\n throw new RangeError(\"Matrix must be square\");\n if (!Number.isInteger(s) || s < 0)\n throw new RangeError(\"Exponent must be a non-negative integer\");\n let t = _.eye(this.rows), e = this;\n for (let n = s; n > 1; n /= 2)\n n & 1 && (t = t.mmul(e)), e = e.mmul(e);\n return t;\n }\n strassen2x2(s) {\n s = _.checkMatrix(s);\n let t = new _(2, 2);\n const e = this.get(0, 0), n = s.get(0, 0), i = this.get(0, 1), o = s.get(0, 1), l = this.get(1, 0), h = s.get(1, 0), a = this.get(1, 1), u = s.get(1, 1), c = (e + a) * (n + u), g = (l + a) * n, d = e * (o - u), w = a * (h - n), p = (e + i) * u, P = (l - e) * (n + o), f = (i - a) * (h + u), y = c + w - p + f, E = d + p, R = g + w, v = c - g + d + P;\n return t.set(0, 0, y), t.set(0, 1, E), t.set(1, 0, R), t.set(1, 1, v), t;\n }\n strassen3x3(s) {\n s = _.checkMatrix(s);\n let t = new _(3, 3);\n const e = this.get(0, 0), n = this.get(0, 1), i = this.get(0, 2), o = this.get(1, 0), l = this.get(1, 1), h = this.get(1, 2), a = this.get(2, 0), u = this.get(2, 1), c = this.get(2, 2), g = s.get(0, 0), d = s.get(0, 1), w = s.get(0, 2), p = s.get(1, 0), P = s.get(1, 1), f = s.get(1, 2), y = s.get(2, 0), E = s.get(2, 1), R = s.get(2, 2), v = (e + n + i - o - l - u - c) * P, L = (e - o) * (-d + P), S = l * (-g + d + p - P - f - y + R), k = (-e + o + l) * (g - d + P), D = (o + l) * (-g + d), m = e * g, b = (-e + a + u) * (g - w + f), j = (-e + a) * (w - f), M = (a + u) * (-g + w), C = (e + n + i - l - h - a - u) * f, A = u * (-g + w + p - P - f - y + E), T = (-i + u + c) * (P + y - E), z = (i - c) * (P - E), F = i * y, V = (u + c) * (-y + E), x = (-i + l + h) * (f + y - R), B = (i - h) * (f - R), U = (l + h) * (-y + R), I = n * p, O = h * E, X = o * w, G = a * d, W = c * R, se = m + F + I, ne = v + k + D + m + T + F + V, ie = m + b + M + C + F + x + U, re = L + S + k + m + F + x + B, xt = L + k + D + m + O, Nt = F + x + B + U + X, Vt = m + b + j + A + T + z + F, $t = T + z + F + V + G, Lt = m + b + j + M + W;\n return t.set(0, 0, se), t.set(0, 1, ne), t.set(0, 2, ie), t.set(1, 0, re), t.set(1, 1, xt), t.set(1, 2, Nt), t.set(2, 0, Vt), t.set(2, 1, $t), t.set(2, 2, Lt), t;\n }\n mmulStrassen(s) {\n s = _.checkMatrix(s);\n let t = this.clone(), e = t.rows, n = t.columns, i = s.rows, o = s.columns;\n n !== i && console.warn(\n `Multiplying ${e} x ${n} and ${i} x ${o} matrix: dimensions do not match.`\n );\n function l(c, g, d) {\n let w = c.rows, p = c.columns;\n if (w === g && p === d)\n return c;\n {\n let P = N.zeros(g, d);\n return P = P.setSubMatrix(c, 0, 0), P;\n }\n }\n let h = Math.max(e, i), a = Math.max(n, o);\n t = l(t, h, a), s = l(s, h, a);\n function u(c, g, d, w) {\n if (d <= 512 || w <= 512)\n return c.mmul(g);\n d % 2 === 1 && w % 2 === 1 ? (c = l(c, d + 1, w + 1), g = l(g, d + 1, w + 1)) : d % 2 === 1 ? (c = l(c, d + 1, w), g = l(g, d + 1, w)) : w % 2 === 1 && (c = l(c, d, w + 1), g = l(g, d, w + 1));\n let p = parseInt(c.rows / 2, 10), P = parseInt(c.columns / 2, 10), f = c.subMatrix(0, p - 1, 0, P - 1), y = g.subMatrix(0, p - 1, 0, P - 1), E = c.subMatrix(0, p - 1, P, c.columns - 1), R = g.subMatrix(0, p - 1, P, g.columns - 1), v = c.subMatrix(p, c.rows - 1, 0, P - 1), L = g.subMatrix(p, g.rows - 1, 0, P - 1), S = c.subMatrix(p, c.rows - 1, P, c.columns - 1), k = g.subMatrix(p, g.rows - 1, P, g.columns - 1), D = u(\n N.add(f, S),\n N.add(y, k),\n p,\n P\n ), m = u(N.add(v, S), y, p, P), b = u(f, N.sub(R, k), p, P), j = u(S, N.sub(L, y), p, P), M = u(N.add(f, E), k, p, P), C = u(\n N.sub(v, f),\n N.add(y, R),\n p,\n P\n ), A = u(\n N.sub(E, S),\n N.add(L, k),\n p,\n P\n ), T = N.add(D, j);\n T.sub(M), T.add(A);\n let z = N.add(b, M), F = N.add(m, j), V = N.sub(D, m);\n V.add(b), V.add(C);\n let x = N.zeros(2 * T.rows, 2 * T.columns);\n return x = x.setSubMatrix(T, 0, 0), x = x.setSubMatrix(z, T.rows, 0), x = x.setSubMatrix(F, 0, T.columns), x = x.setSubMatrix(V, T.rows, T.columns), x.subMatrix(0, d - 1, 0, w - 1);\n }\n return u(t, s, h, a);\n }\n scaleRows(s = {}) {\n if (typeof s != \"object\")\n throw new TypeError(\"options must be an object\");\n const { min: t = 0, max: e = 1 } = s;\n if (!Number.isFinite(t)) throw new TypeError(\"min must be a number\");\n if (!Number.isFinite(e)) throw new TypeError(\"max must be a number\");\n if (t >= e) throw new RangeError(\"min must be smaller than max\");\n let n = new _(this.rows, this.columns);\n for (let i = 0; i < this.rows; i++) {\n const o = this.getRow(i);\n o.length > 0 && ve(o, { min: t, max: e, output: o }), n.setRow(i, o);\n }\n return n;\n }\n scaleColumns(s = {}) {\n if (typeof s != \"object\")\n throw new TypeError(\"options must be an object\");\n const { min: t = 0, max: e = 1 } = s;\n if (!Number.isFinite(t)) throw new TypeError(\"min must be a number\");\n if (!Number.isFinite(e)) throw new TypeError(\"max must be a number\");\n if (t >= e) throw new RangeError(\"min must be smaller than max\");\n let n = new _(this.rows, this.columns);\n for (let i = 0; i < this.columns; i++) {\n const o = this.getColumn(i);\n o.length && ve(o, {\n min: t,\n max: e,\n output: o\n }), n.setColumn(i, o);\n }\n return n;\n }\n flipRows() {\n const s = Math.ceil(this.columns / 2);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < s; e++) {\n let n = this.get(t, e), i = this.get(t, this.columns - 1 - e);\n this.set(t, e, i), this.set(t, this.columns - 1 - e, n);\n }\n return this;\n }\n flipColumns() {\n const s = Math.ceil(this.rows / 2);\n for (let t = 0; t < this.columns; t++)\n for (let e = 0; e < s; e++) {\n let n = this.get(e, t), i = this.get(this.rows - 1 - e, t);\n this.set(e, t, i), this.set(this.rows - 1 - e, t, n);\n }\n return this;\n }\n kroneckerProduct(s) {\n s = _.checkMatrix(s);\n let t = this.rows, e = this.columns, n = s.rows, i = s.columns, o = new _(t * n, e * i);\n for (let l = 0; l < t; l++)\n for (let h = 0; h < e; h++)\n for (let a = 0; a < n; a++)\n for (let u = 0; u < i; u++)\n o.set(n * l + a, i * h + u, this.get(l, h) * s.get(a, u));\n return o;\n }\n kroneckerSum(s) {\n if (s = _.checkMatrix(s), !this.isSquare() || !s.isSquare())\n throw new Error(\"Kronecker Sum needs two Square Matrices\");\n let t = this.rows, e = s.rows, n = this.kroneckerProduct(_.eye(e, e)), i = _.eye(t, t).kroneckerProduct(s);\n return n.add(i);\n }\n transpose() {\n let s = new _(this.columns, this.rows);\n for (let t = 0; t < this.rows; t++)\n for (let e = 0; e < this.columns; e++)\n s.set(e, t, this.get(t, e));\n return s;\n }\n sortRows(s = Te) {\n for (let t = 0; t < this.rows; t++)\n this.setRow(t, this.getRow(t).sort(s));\n return this;\n }\n sortColumns(s = Te) {\n for (let t = 0; t < this.columns; t++)\n this.setColumn(t, this.getColumn(t).sort(s));\n return this;\n }\n subMatrix(s, t, e, n) {\n ae(this, s, t, e, n);\n let i = new _(\n t - s + 1,\n n - e + 1\n );\n for (let o = s; o <= t; o++)\n for (let l = e; l <= n; l++)\n i.set(o - s, l - e, this.get(o, l));\n return i;\n }\n subMatrixRow(s, t, e) {\n if (t === void 0 && (t = 0), e === void 0 && (e = this.columns - 1), t > e || t < 0 || t >= this.columns || e < 0 || e >= this.columns)\n throw new RangeError(\"Argument out of range\");\n let n = new _(s.length, e - t + 1);\n for (let i = 0; i < s.length; i++)\n for (let o = t; o <= e; o++) {\n if (s[i] < 0 || s[i] >= this.rows)\n throw new RangeError(`Row index out of range: ${s[i]}`);\n n.set(i, o - t, this.get(s[i], o));\n }\n return n;\n }\n subMatrixColumn(s, t, e) {\n if (t === void 0 && (t = 0), e === void 0 && (e = this.rows - 1), t > e || t < 0 || t >= this.rows || e < 0 || e >= this.rows)\n throw new RangeError(\"Argument out of range\");\n let n = new _(e - t + 1, s.length);\n for (let i = 0; i < s.length; i++)\n for (let o = t; o <= e; o++) {\n if (s[i] < 0 || s[i] >= this.columns)\n throw new RangeError(`Column index out of range: ${s[i]}`);\n n.set(o - t, i, this.get(o, s[i]));\n }\n return n;\n }\n setSubMatrix(s, t, e) {\n if (s = _.checkMatrix(s), s.isEmpty())\n return this;\n let n = t + s.rows - 1, i = e + s.columns - 1;\n ae(this, t, n, e, i);\n for (let o = 0; o < s.rows; o++)\n for (let l = 0; l < s.columns; l++)\n this.set(t + o, e + l, s.get(o, l));\n return this;\n }\n selection(s, t) {\n ge(this, s), we(this, t);\n let e = new _(s.length, t.length);\n for (let n = 0; n < s.length; n++) {\n let i = s[n];\n for (let o = 0; o < t.length; o++) {\n let l = t[o];\n e.set(n, o, this.get(i, l));\n }\n }\n return e;\n }\n trace() {\n let s = Math.min(this.rows, this.columns), t = 0;\n for (let e = 0; e < s; e++)\n t += this.get(e, e);\n return t;\n }\n clone() {\n return this.constructor.copy(this, new _(this.rows, this.columns));\n }\n /**\n * @template {AbstractMatrix} M\n * @param {AbstractMatrix} from\n * @param {M} to\n * @return {M}\n */\n static copy(s, t) {\n for (const [e, n, i] of s.entries())\n t.set(e, n, i);\n return t;\n }\n sum(s) {\n switch (s) {\n case \"row\":\n return Ms(this);\n case \"column\":\n return Ps(this);\n case void 0:\n return bs(this);\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n product(s) {\n switch (s) {\n case \"row\":\n return Es(this);\n case \"column\":\n return _s(this);\n case void 0:\n return js(this);\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n mean(s) {\n const t = this.sum(s);\n switch (s) {\n case \"row\": {\n for (let e = 0; e < this.rows; e++)\n t[e] /= this.columns;\n return t;\n }\n case \"column\": {\n for (let e = 0; e < this.columns; e++)\n t[e] /= this.rows;\n return t;\n }\n case void 0:\n return t / this.size;\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n variance(s, t = {}) {\n if (typeof s == \"object\" && (t = s, s = void 0), typeof t != \"object\")\n throw new TypeError(\"options must be an object\");\n const { unbiased: e = !0, mean: n = this.mean(s) } = t;\n if (typeof e != \"boolean\")\n throw new TypeError(\"unbiased must be a boolean\");\n switch (s) {\n case \"row\": {\n if (!st.isAnyArray(n))\n throw new TypeError(\"mean must be an array\");\n return Ss(this, e, n);\n }\n case \"column\": {\n if (!st.isAnyArray(n))\n throw new TypeError(\"mean must be an array\");\n return ks(this, e, n);\n }\n case void 0: {\n if (typeof n != \"number\")\n throw new TypeError(\"mean must be a number\");\n return Rs(this, e, n);\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n standardDeviation(s, t) {\n typeof s == \"object\" && (t = s, s = void 0);\n const e = this.variance(s, t);\n if (s === void 0)\n return Math.sqrt(e);\n for (let n = 0; n < e.length; n++)\n e[n] = Math.sqrt(e[n]);\n return e;\n }\n center(s, t = {}) {\n if (typeof s == \"object\" && (t = s, s = void 0), typeof t != \"object\")\n throw new TypeError(\"options must be an object\");\n const { center: e = this.mean(s) } = t;\n switch (s) {\n case \"row\": {\n if (!st.isAnyArray(e))\n throw new TypeError(\"center must be an array\");\n return vs(this, e), this;\n }\n case \"column\": {\n if (!st.isAnyArray(e))\n throw new TypeError(\"center must be an array\");\n return Is(this, e), this;\n }\n case void 0: {\n if (typeof e != \"number\")\n throw new TypeError(\"center must be a number\");\n return Ts(this, e), this;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n scale(s, t = {}) {\n if (typeof s == \"object\" && (t = s, s = void 0), typeof t != \"object\")\n throw new TypeError(\"options must be an object\");\n let e = t.scale;\n switch (s) {\n case \"row\": {\n if (e === void 0)\n e = Cs(this);\n else if (!st.isAnyArray(e))\n throw new TypeError(\"scale must be an array\");\n return qs(this, e), this;\n }\n case \"column\": {\n if (e === void 0)\n e = As(this);\n else if (!st.isAnyArray(e))\n throw new TypeError(\"scale must be an array\");\n return Fs(this, e), this;\n }\n case void 0: {\n if (e === void 0)\n e = xs(this);\n else if (typeof e != \"number\")\n throw new TypeError(\"scale must be a number\");\n return Ns(this, e), this;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n toString(s) {\n return Oe(this, s);\n }\n [Symbol.iterator]() {\n return this.entries();\n }\n /**\n * iterator from left to right, from top to bottom\n * yield [row, column, value]\n * @returns {Generator<[number, number, number], void, void>}\n */\n *entries() {\n for (let s = 0; s < this.rows; s++)\n for (let t = 0; t < this.columns; t++)\n yield [s, t, this.get(s, t)];\n }\n /**\n * iterator from left to right, from top to bottom\n * yield value\n * @returns {Generator<number, void, void>}\n */\n *values() {\n for (let s = 0; s < this.rows; s++)\n for (let t = 0; t < this.columns; t++)\n yield this.get(s, t);\n }\n}\nN.prototype.klass = \"Matrix\";\ntypeof Symbol < \"u\" && (N.prototype[Symbol.for(\"nodejs.util.inspect.custom\")] = ws);\nfunction Te(r, s) {\n return r - s;\n}\nfunction Vs(r) {\n return r.every((s) => typeof s == \"number\");\n}\nN.random = N.rand;\nN.randomInt = N.randInt;\nN.diagonal = N.diag;\nN.prototype.diagonal = N.prototype.diag;\nN.identity = N.eye;\nN.prototype.negate = N.prototype.neg;\nN.prototype.tensorProduct = N.prototype.kroneckerProduct;\nvar At, ue, dt;\nlet _ = (dt = class extends N {\n constructor(t, e) {\n super();\n le(this, At);\n /**\n * @type {Float64Array[]}\n */\n q(this, \"data\");\n if (dt.isMatrix(t))\n he(this, At, ue).call(this, t.rows, t.columns), dt.copy(t, this);\n else if (Number.isInteger(t) && t >= 0)\n he(this, At, ue).call(this, t, e);\n else if (st.isAnyArray(t)) {\n const n = t;\n if (t = n.length, e = t ? n[0].length : 0, typeof e != \"number\")\n throw new TypeError(\n \"Data must be a 2D array with at least one element\"\n );\n this.data = [];\n for (let i = 0; i < t; i++) {\n if (n[i].length !== e)\n throw new RangeError(\"Inconsistent array dimensions\");\n if (!Vs(n[i]))\n throw new TypeError(\"Input data contains non-numeric values\");\n this.data.push(Float64Array.from(n[i]));\n }\n this.rows = t, this.columns = e;\n } else\n throw new TypeError(\n \"First argument must be a positive number or an array\"\n );\n }\n set(t, e, n) {\n return this.data[t][e] = n, this;\n }\n get(t, e) {\n return this.data[t][e];\n }\n removeRow(t) {\n return ot(this, t), this.data.splice(t, 1), this.rows -= 1, this;\n }\n addRow(t, e) {\n return e === void 0 && (e = t, t = this.rows), ot(this, t, !0), e = Float64Array.from(Pt(this, e)), this.data.splice(t, 0, e), this.rows += 1, this;\n }\n removeColumn(t) {\n lt(this, t);\n for (let e = 0; e < this.rows; e++) {\n const n = new Float64Array(this.columns - 1);\n for (let i = 0; i < t; i++)\n n[i] = this.data[e][i];\n for (let i = t + 1; i < this.columns; i++)\n n[i - 1] = this.data[e][i];\n this.data[e] = n;\n }\n return this.columns -= 1, this;\n }\n addColumn(t, e) {\n typeof e > \"u\" && (e = t, t = this.columns), lt(this, t, !0), e = bt(this, e);\n for (let n = 0; n < this.rows; n++) {\n const i = new Float64Array(this.columns + 1);\n let o = 0;\n for (; o < t; o++)\n i[o] = this.data[n][o];\n for (i[o++] = e[n]; o < this.columns + 1; o++)\n i[o] = this.data[n][o - 1];\n this.data[n] = i;\n }\n return this.columns += 1, this;\n }\n}, At = new WeakSet(), /**\n * Init an empty matrix\n * @param {number} nRows\n * @param {number} nColumns\n */\nue = function(t, e) {\n if (this.data = [], Number.isInteger(e) && e >= 0)\n for (let n = 0; n < t; n++)\n this.data.push(new Float64Array(e));\n else\n throw new TypeError(\"nColumns must be a positive integer\");\n this.rows = t, this.columns = e;\n}, dt);\nys(N, _);\nvar K;\nconst Jt = class Jt extends N {\n /**\n * @param {number | AbstractMatrix | ArrayLike<ArrayLike<number>>} diagonalSize\n * @return {this}\n */\n constructor(t) {\n super();\n /** @type {Matrix} */\n le(this, K);\n if (_.isMatrix(t)) {\n if (!t.isSymmetric())\n throw new TypeError(\"not symmetric data\");\n Dt(this, K, _.copy(\n t,\n new _(t.rows, t.rows)\n ));\n } else if (Number.isInteger(t) && t >= 0)\n Dt(this, K, new _(t, t));\n else if (Dt(this, K, new _(t)), !this.isSymmetric())\n throw new TypeError(\"not symmetric data\");\n }\n get size() {\n return ht(this, K).size;\n }\n get rows() {\n return ht(this, K).rows;\n }\n get columns() {\n return ht(this, K).columns;\n }\n get diagonalSize() {\n return this.rows;\n }\n /**\n * not the same as matrix.isSymmetric()\n * Here is to check if it's instanceof SymmetricMatrix without bundling issues\n *\n * @param value\n * @returns {boolean}\n */\n static isSymmetricMatrix(t) {\n return _.isMatrix(t) && t.klassType === \"SymmetricMatrix\";\n }\n /**\n * @param diagonalSize\n * @return {SymmetricMatrix}\n */\n static zeros(t) {\n return new this(t);\n }\n /**\n * @param diagonalSize\n * @return {SymmetricMatrix}\n */\n static ones(t) {\n return new this(t).fill(1);\n }\n clone() {\n const t = new Jt(this.diagonalSize);\n for (const [e, n, i] of this.upperRightEntries())\n t.set(e, n, i);\n return t;\n }\n toMatrix() {\n return new _(this);\n }\n get(t, e) {\n return ht(this, K).get(t, e);\n }\n set(t, e, n) {\n return ht(this, K).set(t, e, n), ht(this, K).set(e, t, n), this;\n }\n removeCross(t) {\n return ht(this, K).removeRow(t), ht(this, K).removeColumn(t), this;\n }\n addCross(t, e) {\n e === void 0 && (e = t, t = this.diagonalSize);\n const n = e.slice();\n return n.splice(t, 1), ht(this, K).addRow(t, n), ht(this, K).addColumn(t, e), this;\n }\n /**\n * @param {Mask[]} mask\n */\n applyMask(t) {\n if (t.length !== this.diagonalSize)\n throw new RangeError(\"Mask size do not match with matrix size\");\n const e = [];\n for (const [n, i] of t.entries())\n i || e.push(n);\n e.reverse();\n for (const n of e)\n this.removeCross(n);\n return this;\n }\n /**\n * Compact format upper-right corner of matrix\n * iterate from left to right, from top to bottom.\n *\n * ```\n * A B C D\n * A 1 2 3 4\n * B 2 5 6 7\n * C 3 6 8 9\n * D 4 7 9 10\n * ```\n *\n * will return compact 1D array `[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]`\n *\n * length is S(i=0, n=sideSize) => 10 for a 4 sideSized matrix\n *\n * @returns {number[]}\n */\n toCompact() {\n const { diagonalSize: t } = this, e = new Array(t * (t + 1) / 2);\n for (let n = 0, i = 0, o = 0; o < e.length; o++)\n e[o] = this.get(i, n), ++n >= t && (n = ++i);\n return e;\n }\n /**\n * @param {number[]} compact\n * @return {SymmetricMatrix}\n */\n static fromCompact(t) {\n const e = t.length, n = (Math.sqrt(8 * e + 1) - 1) / 2;\n if (!Number.isInteger(n))\n throw new TypeError(\n `This array is not a compact representation of a Symmetric Matrix, ${JSON.stringify(\n t\n )}`\n );\n const i = new Jt(n);\n for (let o = 0, l = 0, h = 0; h < e; h++)\n i.set(o, l, t[h]), ++o >= n && (o = ++l);\n return i;\n }\n /**\n * half iterator upper-right-corner from left to right, from top to bottom\n * yield [row, column, value]\n *\n * @returns {Generator<[number, number, number], void, void>}\n */\n *upperRightEntries() {\n for (let t = 0, e = 0; t < this.diagonalSize; void 0) {\n const n = this.get(t, e);\n yield [t, e, n], ++e >= this.diagonalSize && (e = ++t);\n }\n }\n /**\n * half iterator upper-right-corner from left to right, from top to bottom\n * yield value\n *\n * @returns {Generator<[number, number, number], void, void>}\n */\n *upperRightValues() {\n for (let t = 0, e = 0; t < this.diagonalSize; void 0)\n yield this.get(t, e), ++e >= this.diagonalSize && (e = ++t);\n }\n};\nK = new WeakMap();\nlet pt = Jt;\npt.prototype.klassType = \"SymmetricMatrix\";\nclass te extends pt {\n /**\n * not the same as matrix.isSymmetric()\n * Here is to check if it's instanceof SymmetricMatrix without bundling issues\n *\n * @param value\n * @returns {boolean}\n */\n static isDistanceMatrix(s) {\n return pt.isSymmetricMatrix(s) && s.klassSubType === \"DistanceMatrix\";\n }\n constructor(s) {\n if (super(s), !this.isDistance())\n throw new TypeError(\"Provided arguments do no produce a distance matrix\");\n }\n set(s, t, e) {\n return s === t && (e = 0), super.set(s, t, e);\n }\n addCross(s, t) {\n return t === void 0 && (t = s, s = this.diagonalSize), t = t.slice(), t[s] = 0, super.addCross(s, t);\n }\n toSymmetricMatrix() {\n return new pt(this);\n }\n clone() {\n const s = new te(this.diagonalSize);\n for (const [t, e, n] of this.upperRightEntries())\n t !== e && s.set(t, e, n);\n return s;\n }\n /**\n * Compact format upper-right corner of matrix\n * no diagonal (only zeros)\n * iterable from left to right, from top to bottom.\n *\n * ```\n * A B C D\n * A 0 1 2 3\n * B 1 0 4 5\n * C 2 4 0 6\n * D 3 5 6 0\n * ```\n *\n * will return compact 1D array `[1, 2, 3, 4, 5, 6]`\n *\n * length is S(i=0, n=sideSize-1) => 6 for a 4 side sized matrix\n *\n * @returns {number[]}\n */\n toCompact() {\n const { diagonalSize: s } = this, t = (s - 1) * s / 2, e = new Array(t);\n for (let n = 1, i = 0, o = 0; o < e.length; o++)\n e[o] = this.get(i, n), ++n >= s && (n = ++i + 1);\n return e;\n }\n /**\n * @param {number[]} compact\n */\n static fromCompact(s) {\n const t = s.length;\n if (t === 0)\n return new this(0);\n const e = (Math.sqrt(8 * t + 1) + 1) / 2;\n if (!Number.isInteger(e))\n throw new TypeError(\n `This array is not a compact representation of a DistanceMatrix, ${JSON.stringify(\n s\n )}`\n );\n const n = new this(e);\n for (let i = 1, o = 0, l = 0; l < t; l++)\n n.set(i, o, s[l]), ++i >= e && (i = ++o + 1);\n return n;\n }\n}\nte.prototype.klassSubType = \"DistanceMatrix\";\nclass ft extends N {\n constructor(s, t, e) {\n super(), this.matrix = s, this.rows = t, this.columns = e;\n }\n}\nclass $s extends ft {\n constructor(s, t) {\n lt(s, t), super(s, s.rows, 1), this.column = t;\n }\n set(s, t, e) {\n return this.matrix.set(s, this.column, e), this;\n }\n get(s) {\n return this.matrix.get(s, this.column);\n }\n}\nclass Ls extends ft {\n constructor(s, t) {\n we(s, t), super(s, s.rows, t.length), this.columnIndices = t;\n }\n set(s, t, e) {\n return this.matrix.set(s, this.columnIndices[t], e), this;\n }\n get(s, t) {\n return this.matrix.get(s, this.columnIndices[t]);\n }\n}\nclass Ds extends ft {\n constructor(s) {\n super(s, s.rows, s.columns);\n }\n set(s, t, e) {\n return this.matrix.set(s, this.columns - t - 1, e), this;\n }\n get(s, t) {\n return this.matrix.get(s, this.columns - t - 1);\n }\n}\nclass Os extends ft {\n constructor(s) {\n super(s, s.rows, s.columns);\n }\n set(s, t, e) {\n return this.matrix.set(this.rows - s - 1, t, e), this;\n }\n get(s, t) {\n return this.matrix.get(this.rows - s - 1, t);\n }\n}\nclass Bs extends ft {\n constructor(s, t) {\n ot(s, t), super(s, 1, s.columns), this.row = t;\n }\n set(s, t, e) {\n return this.matrix.set(this.row, t, e), this;\n }\n get(s, t) {\n return this.matrix.get(this.row, t);\n }\n}\nclass zs extends ft {\n constructor(s, t) {\n ge(s, t), super(s, t.length, s.columns), this.rowIndices = t;\n }\n set(s, t, e) {\n return this.matrix.set(this.rowIndices[s], t, e), this;\n }\n get(s, t) {\n return this.matrix.get(this.rowIndices[s], t);\n }\n}\nclass Gt extends ft {\n constructor(s, t, e) {\n ge(s, t), we(s, e), super(s, t.length, e.length), this.rowIndices = t, this.columnIndices = e;\n }\n set(s, t, e) {\n return this.matrix.set(\n this.rowIndices[s],\n this.columnIndices[t],\n e\n ), this;\n }\n get(s, t) {\n return this.matrix.get(\n this.rowIndices[s],\n this.columnIndices[t]\n );\n }\n}\nclass Us extends ft {\n constructor(s, t, e, n, i) {\n ae(s, t, e, n, i), super(s, e - t + 1, i - n + 1), this.startRow = t, this.startColumn = n;\n }\n set(s, t, e) {\n return this.matrix.set(\n this.startRow + s,\n this.startColumn + t,\n e\n ), this;\n }\n get(s, t) {\n return this.matrix.get(\n this.startRow + s,\n this.startColumn + t\n );\n }\n}\nclass Ys extends ft {\n constructor(s) {\n super(s, s.columns, s.rows);\n }\n set(s, t, e) {\n return this.matrix.set(t, s, e), this;\n }\n get(s, t) {\n return this.matrix.get(t, s);\n }\n}\nclass Be extends N {\n constructor(s, t = {}) {\n const { rows: e = 1 } = t;\n if (s.length % e !== 0)\n throw new Error(\"the data length is not divisible by the number of rows\");\n super(), this.rows = e, this.columns = s.length / e, this.data = s;\n }\n set(s, t, e) {\n let n = this._calculateIndex(s, t);\n return this.data[n] = e, this;\n }\n get(s, t) {\n let e = this._calculateIndex(s, t);\n return this.data[e];\n }\n _calculateIndex(s, t) {\n return s * this.columns + t;\n }\n}\nclass rt extends N {\n constructor(s) {\n super(), this.data = s, this.rows = s.length, this.columns = s[0].length;\n }\n set(s, t, e) {\n return this.data[s][t] = e, this;\n }\n get(s, t) {\n return this.data[s][t];\n }\n}\nfunction Ws(r, s) {\n if (st.isAnyArray(r))\n return r[0] && st.isAnyArray(r[0]) ? new rt(r) : new Be(r, s);\n throw new Error(\"the argument is not an array\");\n}\nclass ee {\n constructor(s) {\n s = rt.checkMatrix(s);\n let t = s.clone(), e = t.rows, n = t.columns, i = new Float64Array(e), o = 1, l, h, a, u, c, g, d, w, p;\n for (l = 0; l < e; l++)\n i[l] = l;\n for (w = new Float64Array(e), h = 0; h < n; h++) {\n for (l = 0; l < e; l++)\n w[l] = t.get(l, h);\n for (l = 0; l < e; l++) {\n for (p = Math.min(l, h), c = 0, a = 0; a < p; a++)\n c += t.get(l, a) * w[a];\n w[l] -= c, t.set(l, h, w[l]);\n }\n for (u = h, l = h + 1; l < e; l++)\n Math.abs(w[l]) > Math.abs(w[u]) && (u = l);\n if (u !== h) {\n for (a = 0; a < n; a++)\n g = t.get(u, a), t.set(u, a, t.get(h, a)), t.set(h, a, g);\n d = i[u], i[u] = i[h], i[h] = d, o = -o;\n }\n if (h < e && t.get(h, h) !== 0)\n for (l = h + 1; l < e; l++)\n t.set(l, h, t.get(l, h) / t.get(h, h));\n }\n this.LU = t, this.pivotVector = i, this.pivotSign = o;\n }\n isSingular() {\n let s = this.LU, t = s.columns;\n for (let e = 0; e < t; e++)\n if (s.get(e, e) === 0)\n return !0;\n return !1;\n }\n solve(s) {\n s = _.checkMatrix(s);\n let t = this.LU;\n if (t.rows !== s.rows)\n throw new Error(\"Invalid matrix dimensions\");\n if (this.isSingular())\n throw new Error(\"LU matrix is singular\");\n let n = s.columns, i = s.subMatrixRow(this.pivotVector, 0, n - 1), o = t.columns, l, h, a;\n for (a = 0; a < o; a++)\n for (l = a + 1; l < o; l++)\n for (h = 0; h < n; h++)\n i.set(l, h, i.get(l, h) - i.get(a, h) * t.get(l, a));\n for (a = o - 1; a >= 0; a--) {\n for (h = 0; h < n; h++)\n i.set(a, h, i.get(a, h) / t.get(a, a));\n for (l = 0; l < a; l++)\n for (h = 0; h < n; h++)\n i.set(l, h, i.get(l, h) - i.get(a, h) * t.get(l, a));\n }\n return i;\n }\n get determinant() {\n let s = this.LU;\n if (!s.isSquare())\n throw new Error(\"Matrix must be square\");\n let t = this.pivotSign, e = s.columns;\n for (let n = 0; n < e; n++)\n t *= s.get(n, n);\n return t;\n }\n get lowerTriangularMatrix() {\n let s = this.LU, t = s.rows, e = s.columns, n = new _(t, e);\n for (let i = 0; i < t; i++)\n for (let o = 0; o < e; o++)\n i > o ? n.set(i, o, s.get(i, o)) : i === o ? n.set(i, o, 1) : n.set(i, o, 0);\n return n;\n }\n get upperTriangularMatrix() {\n let s = this.LU, t = s.rows, e = s.columns, n = new _(t, e);\n for (let i = 0; i < t; i++)\n for (let o = 0; o < e; o++)\n i <= o ? n.set(i, o, s.get(i, o)) : n.set(i, o, 0);\n return n;\n }\n get pivotPermutationVector() {\n return Array.from(this.pivotVector);\n }\n}\nfunction ut(r, s) {\n let t = 0;\n return Math.abs(r) > Math.abs(s) ? (t = s / r, Math.abs(r) * Math.sqrt(1 + t * t)) : s !== 0 ? (t = r / s, Math.abs(s) * Math.sqrt(1 + t * t)) : 0;\n}\nclass pe {\n constructor(s) {\n s = rt.checkMatrix(s);\n let t = s.clone(), e = s.rows, n = s.columns, i = new Float64Array(n), o, l, h, a;\n for (h = 0; h < n; h++) {\n let u = 0;\n for (o = h; o < e; o++)\n u = ut(u, t.get(o, h));\n if (u !== 0) {\n for (t.get(h, h) < 0 && (u = -u), o = h; o < e; o++)\n t.set(o, h, t.get(o, h) / u);\n for (t.set(h, h, t.get(h, h) + 1), l = h + 1; l < n; l++) {\n for (a = 0, o = h; o < e; o++)\n a += t.get(o, h) * t.get(o, l);\n for (a = -a / t.get(h, h), o = h; o < e; o++)\n t.set(o, l, t.get(o, l) + a * t.get(o, h));\n }\n }\n i[h] = -u;\n }\n this.QR = t, this.Rdiag = i;\n }\n solve(s) {\n s = _.checkMatrix(s);\n let t = this.QR, e = t.rows;\n if (s.rows !== e)\n throw new Error(\"Matrix row dimensions must agree\");\n if (!this.isFullRank())\n throw new Error(\"Matrix is rank deficient\");\n let n = s.columns, i = s.clone(), o = t.columns, l, h, a, u;\n for (a = 0; a < o; a++)\n for (h = 0; h < n; h++) {\n for (u = 0, l = a; l < e; l++)\n u += t.get(l, a) * i.get(l, h);\n for (u = -u / t.get(a, a), l = a; l < e; l++)\n i.set(l, h, i.get(l, h) + u * t.get(l, a));\n }\n for (a = o - 1; a >= 0; a--) {\n for (h = 0; h < n; h++)\n i.set(a, h, i.get(a, h) / this.Rdiag[a]);\n for (l = 0; l < a; l++)\n for (h = 0; h < n; h++)\n i.set(l, h, i.get(l, h) - i.get(a, h) * t.get(l, a));\n }\n return i.subMatrix(0, o - 1, 0, n - 1);\n }\n isFullRank() {\n let s = this.QR.columns;\n for (let t = 0; t < s; t++)\n if (this.Rdiag[t] === 0)\n return !1;\n return !0;\n }\n get upperTriangularMatrix() {\n let s = this.QR, t = s.columns, e = new _(t, t), n, i;\n for (n = 0; n < t; n++)\n for (i = 0; i < t; i++)\n n < i ? e.set(n, i, s.get(n, i)) : n === i ? e.set(n, i, this.Rdiag[n]) : e.set(n, i, 0);\n return e;\n }\n get orthogonalMatrix() {\n let s = this.QR, t = s.rows, e = s.columns, n = new _(t, e), i, o, l, h;\n for (l = e - 1; l >= 0; l--) {\n for (i = 0; i < t; i++)\n n.set(i, l, 0);\n for (n.set(l, l, 1), o = l; o < e; o++)\n if (s.get(l, l) !== 0) {\n for (h = 0, i = l; i < t; i++)\n h += s.get(i, l) * n.get(i, o);\n for (h = -h / s.get(l, l), i = l; i < t; i++)\n n.set(i, o, n.get(i, o) + h * s.get(i, l));\n }\n }\n return n;\n }\n}\nclass vt {\n constructor(s, t = {}) {\n if (s = rt.checkMatrix(s), s.isEmpty())\n throw new Error(\"Matrix must be non-empty\");\n let e = s.rows, n = s.columns;\n const {\n computeLeftSingularVectors: i = !0,\n computeRightSingularVectors: o = !0,\n autoTranspose: l = !1\n } = t;\n let h = !!i, a = !!o, u = !1, c;\n if (e < n)\n if (!l)\n c = s.clone(), console.warn(\n \"Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose\"\n );\n else {\n c = s.transpose(), e = c.rows, n = c.columns, u = !0;\n let m = h;\n h = a, a = m;\n }\n else\n c = s.clone();\n let g = Math.min(e, n), d = Math.min(e + 1, n), w = new Float64Array(d), p = new _(e, g), P = new _(n, n), f = new Float64Array(n), y = new Float64Array(e), E = new Float64Array(d);\n for (let m = 0; m < d; m++) E[m] = m;\n let R = Math.min(e - 1, n), v = Math.max(0, Math.min(n - 2, e)), L = Math.max(R, v);\n for (let m = 0; m < L; m++) {\n if (m < R) {\n w[m] = 0;\n for (let b = m; b < e; b++)\n w[m] = ut(w[m], c.get(b, m));\n if (w[m] !== 0) {\n c.get(m, m) < 0 && (w[m] = -w[m]);\n for (let b = m; b < e; b++)\n c.set(b, m, c.get(b, m) / w[m]);\n c.set(m, m, c.get(m, m) + 1);\n }\n w[m] = -w[m];\n }\n for (let b = m + 1; b < n; b++) {\n if (m < R && w[m] !== 0) {\n let j = 0;\n for (let M = m; M < e; M++)\n j += c.get(M, m) * c.get(M, b);\n j = -j / c.get(m, m);\n for (let M = m; M < e; M++)\n c.set(M, b, c.get(M, b) + j * c.get(M, m));\n }\n f[b] = c.get(m, b);\n }\n if (h && m < R)\n for (let b = m; b < e; b++)\n p.set(b, m, c.get(b, m));\n if (m < v) {\n f[m] = 0;\n for (let b = m + 1; b < n; b++)\n f[m] = ut(f[m], f[b]);\n if (f[m] !== 0) {\n f[m + 1] < 0 && (f[m] = 0 - f[m]);\n for (let b = m + 1; b < n; b++)\n f[b] /= f[m];\n f[m + 1] += 1;\n }\n if (f[m] = -f[m], m + 1 < e && f[m] !== 0) {\n for (let b = m + 1; b < e; b++)\n y[b] = 0;\n for (let b = m + 1; b < e; b++)\n for (let j = m + 1; j < n; j++)\n y[b] += f[j] * c.get(b, j);\n for (let b = m + 1; b < n; b++) {\n let j = -f[b] / f[m + 1];\n for (let M = m + 1; M < e; M++)\n c.set(M, b, c.get(M, b) + j * y[M]);\n }\n }\n if (a)\n for (let b = m + 1; b < n; b++)\n P.set(b, m, f[b]);\n }\n }\n let S = Math.min(n, e + 1);\n if (R < n && (w[R] = c.get(R, R)), e < S && (w[S - 1] = 0), v + 1 < S && (f[v] = c.get(v, S - 1)), f[S - 1] = 0, h) {\n for (let m = R; m < g; m++) {\n for (let b = 0; b < e; b++)\n p.set(b, m, 0);\n p.set(m, m, 1);\n }\n for (let m = R - 1; m >= 0; m--)\n if (w[m] !== 0) {\n for (let b = m + 1; b < g; b++) {\n let j = 0;\n for (let M = m; M < e; M++)\n j += p.get(M, m) * p.get(M, b);\n j = -j / p.get(m, m);\n for (let M = m; M < e; M++)\n p.set(M, b, p.get(M, b) + j * p.get(M, m));\n }\n for (let b = m; b < e; b++)\n p.set(b, m, -p.get(b, m));\n p.set(m, m, 1 + p.get(m, m));\n for (let b = 0; b < m - 1; b++)\n p.set(b, m, 0);\n } else {\n for (let b = 0; b < e; b++)\n p.set(b, m, 0);\n p.set(m, m, 1);\n }\n }\n if (a)\n for (let m = n - 1; m >= 0; m--) {\n if (m < v && f[m] !== 0)\n for (let b = m + 1; b < n; b++) {\n let j = 0;\n for (let M = m + 1; M < n; M++)\n j += P.get(M, m) * P.get(M, b);\n j = -j / P.get(m + 1, m);\n for (let M = m + 1; M < n; M++)\n P.set(M, b, P.get(M, b) + j * P.get(M, m));\n }\n for (let b = 0; b < n; b++)\n P.set(b, m, 0);\n P.set(m, m, 1);\n }\n let k = S - 1, D = Number.EPSILON;\n for (; S > 0; ) {\n let m, b;\n for (m = S - 2; m >= -1 && m !== -1; m--) {\n const j = Number.MIN_VALUE + D * Math.abs(w[m] + Math.abs(w[m + 1]));\n if (Math.abs(f[m]) <= j || Number.isNaN(f[m])) {\n f[m] = 0;\n break;\n }\n }\n if (m === S - 2)\n b = 4;\n else {\n let j;\n for (j = S - 1; j >= m && j !== m; j--) {\n let M = (j !== S ? Math.abs(f[j]) : 0) + (j !== m + 1 ? Math.abs(f[j - 1]) : 0);\n if (Math.abs(w[j]) <= D * M) {\n w[j] = 0;\n break;\n }\n }\n j === m ? b = 3 : j === S - 1 ? b = 1 : (b = 2, m = j);\n }\n switch (m++, b) {\n case 1: {\n let j = f[S - 2];\n f[S - 2] = 0;\n for (let M = S - 2; M >= m; M--) {\n let C = ut(w[M], j), A = w[M] / C, T = j / C;\n if (w[M] = C, M !== m && (j = -T * f[M - 1], f[M - 1] = A * f[M - 1]), a)\n for (let z = 0; z < n; z++)\n C = A * P.get(z, M) + T * P.get(z, S - 1), P.set(z, S - 1, -T * P.get(z, M) + A * P.get(z, S - 1)), P.set(z, M, C);\n }\n break;\n }\n case 2: {\n let j = f[m - 1];\n f[m - 1] = 0;\n for (let M = m; M < S; M++) {\n let C = ut(w[M], j), A = w[M] / C, T = j / C;\n if (w[M] = C, j = -T * f[M], f[M] = A * f[M], h)\n for (let z = 0; z < e; z++)\n C = A * p.get(z, M) + T * p.get(z, m - 1), p.set(z, m - 1, -T * p.get(z, M) + A * p.get(z, m - 1)), p.set(z, M, C);\n }\n break;\n }\n case 3: {\n const j = Math.max(\n Math.abs(w[S - 1]),\n Math.abs(w[S - 2]),\n Math.abs(f[S - 2]),\n Math.abs(w[m]),\n Math.abs(f[m])\n ), M = w[S - 1] / j, C = w[S - 2] / j, A = f[S - 2] / j, T = w[m] / j, z = f[m] / j, F = ((C + M) * (C - M) + A * A) / 2, V = M * A * (M * A);\n let x = 0;\n (F !== 0 || V !== 0) && (F < 0 ? x = 0 - Math.sqrt(F * F + V) : x = Math.sqrt(F * F + V), x = V / (F + x));\n let B = (T + M) * (T - M) + x, U = T * z;\n for (let I = m; I < S - 1; I++) {\n let O = ut(B, U);\n O === 0 && (O = Number.MIN_VALUE);\n let X = B / O, G = U / O;\n if (I !== m && (f[I - 1] = O), B = X * w[I] + G * f[I], f[I] = X * f[I] - G * w[I], U = G * w[I + 1], w[I + 1] = X * w[I + 1], a)\n for (let W = 0; W < n; W++)\n O = X * P.get(W, I) + G * P.get(W, I + 1), P.set(W, I + 1, -G * P.get(W, I) + X * P.get(W, I + 1)), P.set(W, I, O);\n if (O = ut(B, U), O === 0 && (O = Number.MIN_VALUE), X = B / O, G = U / O, w[I] = O, B = X * f[I] + G * w[I + 1], w[I + 1] = -G * f[I] + X * w[I + 1], U = G * f[I + 1], f[I + 1] = X * f[I + 1], h && I < e - 1)\n for (let W = 0; W < e; W++)\n O = X * p.get(W, I) + G * p.get(W, I + 1), p.set(W, I + 1, -G * p.get(W, I) + X * p.get(W, I + 1)), p.set(W, I, O);\n }\n f[S - 2] = B;\n break;\n }\n case 4: {\n if (w[m] <= 0 && (w[m] = w[m] < 0 ? -w[m] : 0, a))\n for (let j = 0; j <= k; j++)\n P.set(j, m, -P.get(j, m));\n for (; m < k && !(w[m] >= w[m + 1]); ) {\n let j = w[m];\n if (w[m] = w[m + 1], w[m + 1] = j, a && m < n - 1)\n for (let M = 0; M < n; M++)\n j = P.get(M, m + 1), P.set(M, m + 1, P.get(M, m)), P.set(M, m, j);\n if (h && m < e - 1)\n for (let M = 0; M < e; M++)\n j = p.get(M, m + 1), p.set(M, m + 1, p.get(M, m)), p.set(M, m, j);\n m++;\n }\n S--;\n break;\n }\n }\n }\n if (u) {\n let m = P;\n P = p, p = m;\n }\n this.m = e, this.n = n, this.s = w, this.U = p, this.V = P;\n }\n solve(s) {\n let t = s, e = this.threshold, n = this.s.length, i = _.zeros(n, n);\n for (let g = 0; g < n; g++)\n Math.abs(this.s[g]) <= e ? i.set(g, g, 0) : i.set(g, g, 1 / this.s[g]);\n let o = this.U, l = this.rightSingularVectors, h = l.mmul(i), a = l.rows, u = o.rows, c = _.zeros(a, u);\n for (let g = 0; g < a; g++)\n for (let d = 0; d < u; d++) {\n let w = 0;\n for (let p = 0; p < n; p++)\n w += h.get(g, p) * o.get(d, p);\n c.set(g, d, w);\n }\n return c.mmul(t);\n }\n solveForDiagonal(s) {\n return this.solve(_.diag(s));\n }\n inverse() {\n let s = this.V, t = this.threshold, e = s.rows, n = s.columns, i = new _(e, this.s.length);\n for (let u = 0; u < e; u++)\n for (let c = 0; c < n; c++)\n Math.abs(this.s[c]) > t && i.set(u, c, s.get(u, c) / this.s[c]);\n let o = this.U, l = o.rows, h = o.columns, a = new _(e, l);\n for (let u = 0; u < e; u++)\n for (let c = 0; c < l; c++) {\n let g = 0;\n for (let d = 0; d < h; d++)\n g += i.get(u, d) * o.get(c, d);\n a.set(u, c, g);\n }\n return a;\n }\n get condition() {\n return this.s[0] / this.s[Math.min(this.m, this.n) - 1];\n }\n get norm2() {\n return this.s[0];\n }\n get rank() {\n let s = Math.max(this.m, this.n) * this.s[0] * Number.EPSILON, t = 0, e = this.s;\n for (let n = 0, i = e.length; n < i; n++)\n e[n] > s && t++;\n return t;\n }\n get diagonal() {\n return Array.from(this.s);\n }\n get threshold() {\n return Number.EPSILON / 2 * Math.max(this.m, this.n) * this.s[0];\n }\n get leftSingularVectors() {\n return this.U;\n }\n get rightSingularVectors() {\n return this.V;\n }\n get diagonalMatrix() {\n return _.diag(this.s);\n }\n}\nfunction Qs(r, s = !1) {\n return r = rt.checkMatrix(r), s ? new vt(r).inverse() : ze(r, _.eye(r.rows));\n}\nfunction ze(r, s, t = !1) {\n return r = rt.checkMatrix(r), s = rt.checkMatrix(s), t ? new vt(r).solve(s) : r.isSquare() ? new ee(r).solve(s) : new pe(r).solve(s);\n}\nfunction Xt(r) {\n if (r = _.checkMatrix(r), r.isSquare()) {\n if (r.columns === 0)\n return 1;\n let s, t, e, n;\n if (r.columns === 2)\n return s = r.get(0, 0), t = r.get(0, 1), e = r.get(1, 0), n = r.get(1, 1), s * n - t * e;\n if (r.columns === 3) {\n let i, o, l;\n return i = new Gt(r, [1, 2], [1, 2]), o = new Gt(r, [1, 2], [0, 2]), l = new Gt(r, [1, 2], [0, 1]), s = r.get(0, 0), t = r.get(0, 1), e = r.get(0, 2), s * Xt(i) - t * Xt(o) + e * Xt(l);\n } else\n return new ee(r).determinant;\n } else\n throw Error(\"determinant can only be calculated for a square matrix\");\n}\nfunction Gs(r, s) {\n let t = [];\n for (let e = 0; e < r; e++)\n e !== s && t.push(e);\n return t;\n}\nfunction Xs(r, s, t, e = 1e-9, n = 1e-9) {\n if (r > n)\n return new Array(s.rows + 1).fill(0);\n {\n let i = s.addRow(t, [0]);\n for (let o = 0; o < i.rows; o++)\n Math.abs(i.get(o, 0)) < e && i.set(o, 0, 0);\n return i.to1DArray();\n }\n}\nfunction Zs(r, s = {}) {\n const { thresholdValue: t = 1e-9, thresholdError: e = 1e-9 } = s;\n r = _.checkMatrix(r);\n let n = r.rows, i = new _(n, n);\n for (let o = 0; o < n; o++) {\n let l = _.columnVector(r.getRow(o)), h = r.subMatrixRow(Gs(n, o)).transpose(), u = new vt(h).solve(l), c = _.sub(l, h.mmul(u)).abs().max();\n i.setRow(\n o,\n Xs(c, u, o, t, e)\n );\n }\n return i;\n}\nfunction Js(r, s = Number.EPSILON) {\n if (r = _.checkMatrix(r), r.isEmpty())\n return r.transpose();\n let t = new vt(r, { autoTranspose: !0 }), e = t.leftSingularVectors, n = t.rightSingularVectors, i = t.diagonal;\n for (let o = 0; o < i.length; o++)\n Math.abs(i[o]) > s ? i[o] = 1 / i[o] : i[o] = 0;\n return n.mmul(_.diag(i).mmul(e.transpose()));\n}\nfunction Ks(r, s = r, t = {}) {\n r = new _(r);\n let e = !1;\n if (typeof s == \"object\" && !_.isMatrix(s) && !st.isAnyArray(s) ? (t = s, s = r, e = !0) : s = new _(s), r.rows !== s.rows)\n throw new TypeError(\"Both matrices must have the same number of rows\");\n const { center: n = !0 } = t;\n n && (r = r.center(\"column\"), e || (s = s.center(\"column\")));\n const i = r.transpose().mmul(s);\n for (let o = 0; o < i.rows; o++)\n for (let l = 0; l < i.columns; l++)\n i.set(o, l, i.get(o, l) * (1 / (r.rows - 1)));\n return i;\n}\nfunction Hs(r, s = r, t = {}) {\n r = new _(r);\n let e = !1;\n if (typeof s == \"object\" && !_.isMatrix(s) && !st.isAnyArray(s) ? (t = s, s = r, e = !0) : s = new _(s), r.rows !== s.rows)\n throw new TypeError(\"Both matrices must have the same number of rows\");\n const { center: n = !0, scale: i = !0 } = t;\n n && (r.center(\"column\"), e || s.center(\"column\")), i && (r.scale(\"column\"), e || s.scale(\"column\"));\n const o = r.standardDeviation(\"column\", { unbiased: !0 }), l = e ? o : s.standardDeviation(\"column\", { unbiased: !0 }), h = r.transpose().mmul(s);\n for (let a = 0; a < h.rows; a++)\n for (let u = 0; u < h.columns; u++)\n h.set(\n a,\n u,\n h.get(a, u) * (1 / (o[a] * l[u])) * (1 / (r.rows - 1))\n );\n return h;\n}\nlet Ue = class {\n constructor(s, t = {}) {\n const { assumeSymmetric: e = !1 } = t;\n if (s = rt.checkMatrix(s), !s.isSquare())\n throw new Error(\"Matrix is not a square matrix\");\n if (s.isEmpty())\n throw new Error(\"Matrix must be non-empty\");\n let n = s.columns, i = new _(n, n), o = new Float64Array(n), l = new Float64Array(n), h = s, a, u, c = !1;\n if (e ? c = !0 : c = s.isSymmetric(), c) {\n for (a = 0; a < n; a++)\n for (u = 0; u < n; u++)\n i.set(a, u, h.get(a, u));\n tn(n, l, o, i), en(n, l, o, i);\n } else {\n let g = new _(n, n), d = new Float64Array(n);\n for (u = 0; u < n; u++)\n for (a = 0; a < n; a++)\n g.set(a, u, h.get(a, u));\n sn(n, g, d, i), nn(n, l, o, i, g);\n }\n this.n = n, this.e = l, this.d = o, this.V = i;\n }\n get realEigenvalues() {\n return Array.from(this.d);\n }\n get imaginaryEigenvalues() {\n return Array.from(this.e);\n }\n get eigenvectorMatrix() {\n return this.V;\n }\n get diagonalMatrix() {\n let s = this.n, t = this.e, e = this.d, n = new _(s, s), i, o;\n for (i = 0; i < s; i++) {\n for (o = 0; o < s; o++)\n n.set(i, o, 0);\n n.set(i, i, e[i]), t[i] > 0 ? n.set(i, i + 1, t[i]) : t[i] < 0 && n.set(i, i - 1, t[i]);\n }\n return n;\n }\n};\nfunction tn(r, s, t, e) {\n let n, i, o, l, h, a, u, c;\n for (h = 0; h < r; h++)\n t[h] = e.get(r - 1, h);\n for (l = r - 1; l > 0; l--) {\n for (c = 0, o = 0, a = 0; a < l; a++)\n c = c + Math.abs(t[a]);\n if (c === 0)\n for (s[l] = t[l - 1], h = 0; h < l; h++)\n t[h] = e.get(l - 1, h), e.set(l, h, 0), e.set(h, l, 0);\n else {\n for (a = 0; a < l; a++)\n t[a] /= c, o += t[a] * t[a];\n for (n = t[l - 1], i = Math.sqrt(o), n > 0 && (i = -i), s[l] = c * i, o = o - n * i, t[l - 1] = n - i, h = 0; h < l; h++)\n s[h] = 0;\n for (h = 0; h < l; h++) {\n for (n = t[h], e.set(h, l, n), i = s[h] + e.get(h, h) * n, a = h + 1; a <= l - 1; a++)\n i += e.get(a, h) * t[a], s[a] += e.get(a, h) * n;\n s[h] = i;\n }\n for (n = 0, h = 0; h < l; h++)\n s[h] /= o, n += s[h] * t[h];\n for (u = n / (o + o), h = 0; h < l; h++)\n s[h] -= u * t[h];\n for (h = 0; h < l; h++) {\n for (n = t[h], i = s[h], a = h; a <= l - 1; a++)\n e.set(a, h, e.get(a, h) - (n * s[a] + i * t[a]));\n t[h] = e.get(l - 1, h), e.set(l, h, 0);\n }\n }\n t[l] = o;\n }\n for (l = 0; l < r - 1; l++) {\n if (e.set(r - 1, l, e.get(l, l)), e.set(l, l, 1), o = t[l + 1], o !== 0) {\n for (a = 0; a <= l; a++)\n t[a] = e.get(a, l + 1) / o;\n for (h = 0; h <= l; h++) {\n for (i = 0, a = 0; a <= l; a++)\n i += e.get(a, l + 1) * e.get(a, h);\n for (a = 0; a <= l; a++)\n e.set(a, h, e.get(a, h) - i * t[a]);\n }\n }\n for (a = 0; a <= l; a++)\n e.set(a, l + 1, 0);\n }\n for (h = 0; h < r; h++)\n t[h] = e.get(r - 1, h), e.set(r - 1, h, 0);\n e.set(r - 1, r - 1, 1), s[0] = 0;\n}\nfunction en(r, s, t, e) {\n let n, i, o, l, h, a, u, c, g, d, w, p, P, f, y, E;\n for (o = 1; o < r; o++)\n s[o - 1] = s[o];\n s[r - 1] = 0;\n let R = 0, v = 0, L = Number.EPSILON;\n for (a = 0; a < r; a++) {\n for (v = Math.max(v, Math.abs(t[a]) + Math.abs(s[a])), u = a; u < r && !(Math.abs(s[u]) <= L * v); )\n u++;\n if (u > a)\n do {\n for (n = t[a], c = (t[a + 1] - n) / (2 * s[a]), g = ut(c, 1), c < 0 && (g = -g), t[a] = s[a] / (c + g), t[a + 1] = s[a] * (c + g), d = t[a + 1], i = n - t[a], o = a + 2; o < r; o++)\n t[o] -= i;\n for (R = R + i, c = t[u], w = 1, p = w, P = w, f = s[a + 1], y = 0, E = 0, o = u - 1; o >= a; o--)\n for (P = p, p = w, E = y, n = w * s[o], i = w * c, g = ut(c, s[o]), s[o + 1] = y * g, y = s[o] / g, w = c / g, c = w * t[o] - y * n, t[o + 1] = i + y * (w * n + y * t[o]), h = 0; h < r; h++)\n i = e.get(h, o + 1), e.set(h, o + 1, y * e.get(h, o) + w * i), e.set(h, o, w * e.get(h, o) - y * i);\n c = -y * E * P * f * s[a] / d, s[a] = y * c, t[a] = w * c;\n } while (Math.abs(s[a]) > L * v);\n t[a] = t[a] + R, s[a] = 0;\n }\n for (o = 0; o < r - 1; o++) {\n for (h = o, c = t[o], l = o + 1; l < r; l++)\n t[l] < c && (h = l, c = t[l]);\n if (h !== o)\n for (t[h] = t[o], t[o] = c, l = 0; l < r; l++)\n c = e.get(l, o), e.set(l, o, e.get(l, h)), e.set(l, h, c);\n }\n}\nfunction sn(r, s, t, e) {\n let n = 0, i = r - 1, o, l, h, a, u, c, g;\n for (c = n + 1; c <= i - 1; c++) {\n for (g = 0, a = c; a <= i; a++)\n g = g + Math.abs(s.get(a, c - 1));\n if (g !== 0) {\n for (h = 0, a = i; a >= c; a--)\n t[a] = s.get(a, c - 1) / g, h += t[a] * t[a];\n for (l = Math.sqrt(h), t[c] > 0 && (l = -l), h = h - t[c] * l, t[c] = t[c] - l, u = c; u < r; u++) {\n for (o = 0, a = i; a >= c; a--)\n o += t[a] * s.get(a, u);\n for (o = o / h, a = c; a <= i; a++)\n s.set(a, u, s.get(a, u) - o * t[a]);\n }\n for (a = 0; a <= i; a++) {\n for (o = 0, u = i; u >= c; u--)\n o += t[u] * s.get(a, u);\n for (o = o / h, u = c; u <= i; u++)\n s.set(a, u, s.get(a, u) - o * t[u]);\n }\n t[c] = g * t[c], s.set(c, c - 1, g * l);\n }\n }\n for (a = 0; a < r; a++)\n for (u = 0; u < r; u++)\n e.set(a, u, a === u ? 1 : 0);\n for (c = i - 1; c >= n + 1; c--)\n if (s.get(c, c - 1) !== 0) {\n for (a = c + 1; a <= i; a++)\n t[a] = s.get(a, c - 1);\n for (u = c; u <= i; u++) {\n for (l = 0, a = c; a <= i; a++)\n l += t[a] * e.get(a, u);\n for (l = l / t[c] / s.get(c, c - 1), a = c; a <= i; a++)\n e.set(a, u, e.get(a, u) + l * t[a]);\n }\n }\n}\nfunction nn(r, s, t, e, n) {\n let i = r - 1, o = 0, l = r - 1, h = Number.EPSILON, a = 0, u = 0, c = 0, g = 0, d = 0, w = 0, p = 0, P = 0, f, y, E, R, v, L, S, k, D, m, b, j, M, C, A;\n for (f = 0; f < r; f++)\n for ((f < o || f > l) && (t[f] = n.get(f, f), s[f] = 0), y = Math.max(f - 1, 0); y < r; y++)\n u = u + Math.abs(n.get(f, y));\n for (; i >= o; ) {\n for (R = i; R > o && (w = Math.abs(n.get(R - 1, R - 1)) + Math.abs(n.get(R, R)), w === 0 && (w = u), !(Math.abs(n.get(R, R - 1)) < h * w)); )\n R--;\n if (R === i)\n n.set(i, i, n.get(i, i) + a), t[i] = n.get(i, i), s[i] = 0, i--, P = 0;\n else if (R === i - 1) {\n if (S = n.get(i, i - 1) * n.get(i - 1, i), c = (n.get(i - 1, i - 1) - n.get(i, i)) / 2, g = c * c + S, p = Math.sqrt(Math.abs(g)), n.set(i, i, n.get(i, i) + a), n.set(i - 1, i - 1, n.get(i - 1, i - 1) + a), k = n.get(i, i), g >= 0) {\n for (p = c >= 0 ? c + p : c - p, t[i - 1] = k + p, t[i] = t[i - 1], p !== 0 && (t[i] = k - S / p), s[i - 1] = 0, s[i] = 0, k = n.get(i, i - 1), w = Math.abs(k) + Math.abs(p), c = k / w, g = p / w, d = Math.sqrt(c * c + g * g), c = c / d, g = g / d, y = i - 1; y < r; y++)\n p = n.get(i - 1, y), n.set(i - 1, y, g * p + c * n.get(i, y)), n.set(i, y, g * n.get(i, y) - c * p);\n for (f = 0; f <= i; f++)\n p = n.get(f, i - 1), n.set(f, i - 1, g * p + c * n.get(f, i)), n.set(f, i, g * n.get(f, i) - c * p);\n for (f = o; f <= l; f++)\n p = e.get(f, i - 1), e.set(f, i - 1, g * p + c * e.get(f, i)), e.set(f, i, g * e.get(f, i) - c * p);\n } else\n t[i - 1] = k + c, t[i] = k + c, s[i - 1] = p, s[i] = -p;\n i = i - 2, P = 0;\n } else {\n if (k = n.get(i, i), D = 0, S = 0, R < i && (D = n.get(i - 1, i - 1), S = n.get(i, i - 1) * n.get(i - 1, i)), P === 10) {\n for (a += k, f = o; f <= i; f++)\n n.set(f, f, n.get(f, f) - k);\n w = Math.abs(n.get(i, i - 1)) + Math.abs(n.get(i - 1, i - 2)), k = D = 0.75 * w, S = -0.4375 * w * w;\n }\n if (P === 30 && (w = (D - k) / 2, w = w * w + S, w > 0)) {\n for (w = Math.sqrt(w), D < k && (w = -w), w = k - S / ((D - k) / 2 + w), f = o; f <= i; f++)\n n.set(f, f, n.get(f, f) - w);\n a += w, k = D = S = 0.964;\n }\n for (P = P + 1, v = i - 2; v >= R && (p = n.get(v, v), d = k - p, w = D - p, c = (d * w - S) / n.get(v + 1, v) + n.get(v, v + 1), g = n.get(v + 1, v + 1) - p - d - w, d = n.get(v + 2, v + 1), w = Math.abs(c) + Math.abs(g) + Math.abs(d), c = c / w, g = g / w, d = d / w, !(v === R || Math.abs(n.get(v, v - 1)) * (Math.abs(g) + Math.abs(d)) < h * (Math.abs(c) * (Math.abs(n.get(v - 1, v - 1)) + Math.abs(p) + Math.abs(n.get(v + 1, v + 1)))))); )\n v--;\n for (f = v + 2; f <= i; f++)\n n.set(f, f - 2, 0), f > v + 2 && n.set(f, f - 3, 0);\n for (E = v; E <= i - 1 && (C = E !== i - 1, E !== v && (c = n.get(E, E - 1), g = n.get(E + 1, E - 1), d = C ? n.get(E + 2, E - 1) : 0, k = Math.abs(c) + Math.abs(g) + Math.abs(d), k !== 0 && (c = c / k, g = g / k, d = d / k)), k !== 0); E++)\n if (w = Math.sqrt(c * c + g * g + d * d), c < 0 && (w = -w), w !== 0) {\n for (E !== v ? n.set(E, E - 1, -w * k) : R !== v && n.set(E, E - 1, -n.get(E, E - 1)), c = c + w, k = c / w, D = g / w, p = d / w, g = g / c, d = d / c, y = E; y < r; y++)\n c = n.get(E, y) + g * n.get(E + 1, y), C && (c = c + d * n.get(E + 2, y), n.set(E + 2, y, n.get(E + 2, y) - c * p)), n.set(E, y, n.get(E, y) - c * k), n.set(E + 1, y, n.get(E + 1, y) - c * D);\n for (f = 0; f <= Math.min(i, E + 3); f++)\n c = k * n.get(f, E) + D * n.get(f, E + 1), C && (c = c + p * n.get(f, E + 2), n.set(f, E + 2, n.get(f, E + 2) - c * d)), n.set(f, E, n.get(f, E) - c), n.set(f, E + 1, n.get(f, E + 1) - c * g);\n for (f = o; f <= l; f++)\n c = k * e.get(f, E) + D * e.get(f, E + 1), C && (c = c + p * e.get(f, E + 2), e.set(f, E + 2, e.get(f, E + 2) - c * d)), e.set(f, E, e.get(f, E) - c), e.set(f, E + 1, e.get(f, E + 1) - c * g);\n }\n }\n }\n if (u !== 0) {\n for (i = r - 1; i >= 0; i--)\n if (c = t[i], g = s[i], g === 0)\n for (R = i, n.set(i, i, 1), f = i - 1; f >= 0; f--) {\n for (S = n.get(f, f) - c, d = 0, y = R; y <= i; y++)\n d = d + n.get(f, y) * n.get(y, i);\n if (s[f] < 0)\n p = S, w = d;\n else if (R = f, s[f] === 0 ? n.set(f, i, S !== 0 ? -d / S : -d / (h * u)) : (k = n.get(f, f + 1), D = n.get(f + 1, f), g = (t[f] - c) * (t[f] - c) + s[f] * s[f], L = (k * w - p * d) / g, n.set(f, i, L), n.set(\n f + 1,\n i,\n Math.abs(k) > Math.abs(p) ? (-d - S * L) / k : (-w - D * L) / p\n )), L = Math.abs(n.get(f, i)), h * L * L > 1)\n for (y = f; y <= i; y++)\n n.set(y, i, n.get(y, i) / L);\n }\n else if (g < 0)\n for (R = i - 1, Math.abs(n.get(i, i - 1)) > Math.abs(n.get(i - 1, i)) ? (n.set(i - 1, i - 1, g / n.get(i, i - 1)), n.set(i - 1, i, -(n.get(i, i) - c) / n.get(i, i - 1))) : (A = Wt(0, -n.get(i - 1, i), n.get(i - 1, i - 1) - c, g), n.set(i - 1, i - 1, A[0]), n.set(i - 1, i, A[1])), n.set(i, i - 1, 0), n.set(i, i, 1), f = i - 2; f >= 0; f--) {\n for (m = 0, b = 0, y = R; y <= i; y++)\n m = m + n.get(f, y) * n.get(y, i - 1), b = b + n.get(f, y) * n.get(y, i);\n if (S = n.get(f, f) - c, s[f] < 0)\n p = S, d = m, w = b;\n else if (R = f, s[f] === 0 ? (A = Wt(-m, -b, S, g), n.set(f, i - 1, A[0]), n.set(f, i, A[1])) : (k = n.get(f, f + 1), D = n.get(f + 1, f), j = (t[f] - c) * (t[f] - c) + s[f] * s[f] - g * g, M = (t[f] - c) * 2 * g, j === 0 && M === 0 && (j = h * u * (Math.abs(S) + Math.abs(g) + Math.abs(k) + Math.abs(D) + Math.abs(p))), A = Wt(\n k * d - p * m + g * b,\n k * w - p * b - g * m,\n j,\n M\n ), n.set(f, i - 1, A[0]), n.set(f, i, A[1]), Math.abs(k) > Math.abs(p) + Math.abs(g) ? (n.set(\n f + 1,\n i - 1,\n (-m - S * n.get(f, i - 1) + g * n.get(f, i)) / k\n ), n.set(\n f + 1,\n i,\n (-b - S * n.get(f, i) - g * n.get(f, i - 1)) / k\n )) : (A = Wt(\n -d - D * n.get(f, i - 1),\n -w - D * n.get(f, i),\n p,\n g\n ), n.set(f + 1, i - 1, A[0]), n.set(f + 1, i, A[1]))), L = Math.max(Math.abs(n.get(f, i - 1)), Math.abs(n.get(f, i))), h * L * L > 1)\n for (y = f; y <= i; y++)\n n.set(y, i - 1, n.get(y, i - 1) / L), n.set(y, i, n.get(y, i) / L);\n }\n for (f = 0; f < r; f++)\n if (f < o || f > l)\n for (y = f; y < r; y++)\n e.set(f, y, n.get(f, y));\n for (y = r - 1; y >= o; y--)\n for (f = o; f <= l; f++) {\n for (p = 0, E = o; E <= Math.min(y, l); E++)\n p = p + e.get(f, E) * n.get(E, y);\n e.set(f, y, p);\n }\n }\n}\nfunction Wt(r, s, t, e) {\n let n, i;\n return Math.abs(t) > Math.abs(e) ? (n = e / t, i = t + n * e, [(r + n * s) / i, (s - n * r) / i]) : (n = t / e, i = e + n * t, [(n * r + s) / i, (n * s - r) / i]);\n}\nclass Ye {\n constructor(s) {\n if (s = rt.checkMatrix(s), !s.isSymmetric())\n throw new Error(\"Matrix is not symmetric\");\n let t = s, e = t.rows, n = new _(e, e), i = !0, o, l, h;\n for (l = 0; l < e; l++) {\n let a = 0;\n for (h = 0; h < l; h++) {\n let u = 0;\n for (o = 0; o < h; o++)\n u += n.get(h, o) * n.get(l, o);\n u = (t.get(l, h) - u) / n.get(h, h), n.set(l, h, u), a = a + u * u;\n }\n for (a = t.get(l, l) - a, i && (i = a > 0), n.set(l, l, Math.sqrt(Math.max(a, 0))), h = l + 1; h < e; h++)\n n.set(l, h, 0);\n }\n this.L = n, this.positiveDefinite = i;\n }\n isPositiveDefinite() {\n return this.positiveDefinite;\n }\n solve(s) {\n s = rt.checkMatrix(s);\n let t = this.L, e = t.rows;\n if (s.rows !== e)\n throw new Error(\"Matrix dimensions do not match\");\n if (this.isPositiveDefinite() === !1)\n throw new Error(\"Matrix is not positive definite\");\n let n = s.columns, i = s.clone(), o, l, h;\n for (h = 0; h < e; h++)\n for (l = 0; l < n; l++) {\n for (o = 0; o < h; o++)\n i.set(h, l, i.get(h, l) - i.get(o, l) * t.get(h, o));\n i.set(h, l, i.get(h, l) / t.get(h, h));\n }\n for (h = e - 1; h >= 0; h--)\n for (l = 0; l < n; l++) {\n for (o = h + 1; o < e; o++)\n i.set(h, l, i.get(h, l) - i.get(o, l) * t.get(o, h));\n i.set(h, l, i.get(h, l) / t.get(h, h));\n }\n return i;\n }\n get lowerTriangularMatrix() {\n return this.L;\n }\n}\nclass We {\n constructor(s, t = {}) {\n s = rt.checkMatrix(s);\n let { Y: e } = t;\n const {\n scaleScores: n = !1,\n maxIterations: i = 1e3,\n terminationCriteria: o = 1e-10\n } = t;\n let l;\n if (e) {\n if (st.isAnyArray(e) && typeof e[0] == \"number\" ? e = _.columnVector(e) : e = rt.checkMatrix(e), e.rows !== s.rows)\n throw new Error(\"Y should have the same number of rows as X\");\n l = e.getColumnVector(0);\n } else\n l = s.getColumnVector(0);\n let h = 1, a, u, c, g;\n for (let d = 0; d < i && h > o; d++)\n c = s.transpose().mmul(l).div(l.transpose().mmul(l).get(0, 0)), c = c.div(c.norm()), a = s.mmul(c).div(c.transpose().mmul(c).get(0, 0)), d > 0 && (h = a.clone().sub(g).pow(2).sum()), g = a.clone(), e ? (u = e.transpose().mmul(a).div(a.transpose().mmul(a).get(0, 0)), u = u.div(u.norm()), l = e.mmul(u).div(u.transpose().mmul(u).get(0, 0))) : l = a;\n if (e) {\n let d = s.transpose().mmul(a).div(a.transpose().mmul(a).get(0, 0));\n d = d.div(d.norm());\n let w = s.clone().sub(a.clone().mmul(d.transpose())), p = l.transpose().mmul(a).div(a.transpose().mmul(a).get(0, 0)), P = e.clone().sub(\n a.clone().mulS(p.get(0, 0)).mmul(u.transpose())\n );\n this.t = a, this.p = d.transpose(), this.w = c.transpose(), this.q = u, this.u = l, this.s = a.transpose().mmul(a), this.xResidual = w, this.yResidual = P, this.betas = p;\n } else\n this.w = c.transpose(), this.s = a.transpose().mmul(a).sqrt(), n ? this.t = a.clone().div(this.s.get(0, 0)) : this.t = a, this.xResidual = s.sub(a.mmul(c.transpose()));\n }\n}\n$.AbstractMatrix = N;\n$.CHO = Ye;\n$.CholeskyDecomposition = Ye;\n$.DistanceMatrix = te;\n$.EVD = Ue;\nvar rn = $.EigenvalueDecomposition = Ue;\n$.LU = ee;\n$.LuDecomposition = ee;\nvar Qe = $.Matrix = _;\n$.MatrixColumnSelectionView = Ls;\n$.MatrixColumnView = $s;\n$.MatrixFlipColumnView = Ds;\n$.MatrixFlipRowView = Os;\n$.MatrixRowSelectionView = zs;\n$.MatrixRowView = Bs;\n$.MatrixSelectionView = Gt;\n$.MatrixSubView = Us;\n$.MatrixTransposeView = Ys;\n$.NIPALS = We;\n$.Nipals = We;\n$.QR = pe;\n$.QrDecomposition = pe;\n$.SVD = vt;\n$.SingularValueDecomposition = vt;\n$.SymmetricMatrix = pt;\n$.WrapperMatrix1D = Be;\n$.WrapperMatrix2D = rt;\n$.correlation = Hs;\n$.covariance = Ks;\nvar Ce = $.default = _;\n$.determinant = Xt;\n$.inverse = Qs;\n$.linearDependencies = Zs;\n$.pseudoInverse = Js;\n$.solve = ze;\n$.wrap = Ws;\nconst on = rn, ln = Qe;\nCe.Matrix && Ce.Matrix;\nfunction qt(r, s, t) {\n const e = r / t, n = s / t;\n if (!(isFinite(e) && isFinite(n))) {\n const h = -r / s;\n return isFinite(h) ? [h] : r == 0 && s == 0 ? [0] : [];\n }\n const i = n * n - 4 * e;\n let o = 0;\n if (isFinite(i)) {\n if (i < 0)\n return [];\n if (i == 0)\n return [-0.5 * n];\n o = -0.5 * (n + kt(Math.sqrt(i), n));\n } else\n o = -n;\n const l = e / o;\n return isFinite(l) ? l > o ? [o, l] : [l, o] : [o];\n}\nfunction Ge(r, s, t, e) {\n const n = t / (3 * e), i = s / (3 * e), o = r / e;\n if (!(isFinite(o) && isFinite(i) && isFinite(n)))\n return qt(r, s, t);\n const l = -n * n + i, h = -i * n + o, a = n * o - i * i, u = 4 * l * a - h * h, c = -2 * n * l + h;\n if (u < 0) {\n const g = Math.sqrt(-0.25 * u), d = -0.5 * c;\n return [Math.cbrt(d + g) + Math.cbrt(d - g) - n];\n } else if (u == 0) {\n const g = kt(Math.sqrt(-l), c);\n return [g - n, -2 * g - n];\n } else {\n const g = Math.atan2(Math.sqrt(u), -c) / 3, d = Math.cos(g), w = Math.sin(g) * Math.sqrt(3), p = 0.5 * (-d + w), P = 0.5 * (-d - w), f = 2 * Math.sqrt(-l);\n return [f * d - n, f * p - n, f * P - n];\n }\n}\nfunction En(r, s, t, e, n) {\n if (n == 0)\n return Ge(r, s, t, e);\n const i = e / n, o = t / n, l = s / n, h = r / n;\n let a = qe(i, o, l, h, !1);\n if (a !== null)\n return a;\n const u = 716e74;\n for (let c = 0; c < 2; c++)\n if (a = qe(\n i / u,\n o / (u * u),\n l / (u * u * u),\n h / (u * u * u * u),\n c != 0\n ), a !== null) {\n for (let g = 0; g < a.length; g++)\n a[g] *= u;\n return a;\n }\n return [];\n}\nfunction gt(r, s) {\n return s == 0 ? Math.abs(r) : Math.abs((r - s) / s);\n}\nfunction qe(r, s, t, e, n) {\n const i = hn(r, s, t, e, n);\n if (i !== null && i.length == 4) {\n let o = [];\n for (let l = 0; l < 2; l++) {\n const h = i[l * 2], a = i[l * 2 + 1];\n o = o.concat(qt(a, h, 1));\n }\n return o;\n }\n return null;\n}\nfunction hn(r, s, t, e, n) {\n function i(F, V, x, B) {\n const U = gt(F + x, r), I = gt(V + F * x + B, s), O = gt(V * x + F * B, t);\n return U + I + O;\n }\n function o(F, V, x, B) {\n return i(F, V, x, B) + gt(V * B, e);\n }\n const l = 9 * r * r - 24 * s, h = l >= 0 ? -2 * s / (3 * r + kt(Math.sqrt(l), r)) : -0.25 * r, a = r + 4 * h, u = s + 3 * h * (r + 2 * h), c = t + h * (2 * s + h * (3 * r + 4 * h)), g = e + h * (t + h * (s + h * (r + h)));\n let d = 0, w = 0;\n const p = 349e100;\n if (n) {\n const F = a / p, V = u / p, x = c / p, B = g / p;\n d = F * x - 4 / p * B - 1 / 3 * V * V, w = (F * x - 8 / p * B - 2 / 9 * V * V) * (1 / 3) * V - x * (x / p) - F * F * B;\n } else\n d = a * c - 4 * g - 1 / 3 * u * u, w = (a * c + 8 * g - 2 / 9 * u * u) * (1 / 3) * u - c * c - a * a * g;\n if (!isFinite(d) && isFinite(w))\n return null;\n let P = an(d, w);\n n && (P *= p);\n const f = r * 0.5, y = 1 / 6 * s + 0.5 * P, E = t - r * y, R = 2 / 3 * s - P - f * f, v = 0.5 * E / R, L = 2 * (e - y * y) / E, S = 0.5 * E / L;\n let k = 0, D = 0, m = 0;\n for (let F = 0; F < 3; F++) {\n const V = F == 1 ? S : R, x = F == 0 ? v : L, B = gt(V + f * f + 2 * y, s), U = gt(2 * (V * x + f * y), t), I = gt(V * x * x + y * y, e), O = B + U + I;\n (F == 0 || O < m) && (k = V, D = x, m = O);\n }\n const b = k, j = D;\n let M = 0, C = 0, A = 0, T = 0;\n if (b < 0) {\n const F = Math.sqrt(-b);\n if (M = f + F, C = y + F * j, A = f - F, T = y - F * j, Math.abs(T) < Math.abs(C) ? T = e / C : Math.abs(T) > Math.abs(C) && (C = e / T), Math.abs(M) != Math.abs(A)) {\n let V = null, x = null;\n if (Math.abs(M) < Math.abs(A)) {\n const U = (t - C * A) / T, I = (s - T - C) / A;\n V = [r - A, U, I], x = [A, A, A];\n } else {\n const U = (t - M * T) / C, I = (s - T - C) / M, O = r - M;\n V = [M, M, M], x = [O, U, I];\n }\n let B = 0;\n for (let U = 0; U < 3; U++) {\n const I = V[U], O = x[U];\n if (isFinite(I) && isFinite(O)) {\n const X = i(I, C, O, T);\n (U == 0 || X < B) && (M = I, A = O, B = X);\n }\n }\n }\n } else if (b == 0) {\n const F = e - y * y;\n M = f, C = y + Math.sqrt(-F), A = f, T = y - Math.sqrt(-F), Math.abs(C) > Math.abs(T) ? T = e / C : Math.abs(T) > Math.abs(C) && (C = e / T);\n } else\n return [];\n let z = o(M, C, A, T);\n for (let F = 0; F < 8 && z != 0; F++) {\n const V = C * T - e, x = C * A + M * T - t, B = C + M * A + T - s, U = M + A - r, I = M - A, O = C * C - C * (A * I + 2 * T) + T * (M * I + T);\n if (O == 0)\n break;\n const X = 1 / O, G = T - C, W = C * A - M * T, se = I * V + G * x + W * B - (C * G + M * W) * U, ne = (M * I + G) * V - C * (I * x + G * B + W * U), ie = -I * V - G * x - W * B + (A * W + T * G) * U, re = -(A * I + G) * V + T * (I * x + G * B + W * U), xt = M - X * se, Nt = C - X * ne, Vt = A - X * ie, $t = T - X * re, Lt = o(xt, Nt, Vt, $t);\n if (Lt < z)\n M = xt, C = Nt, A = Vt, T = $t, z = Lt;\n else\n break;\n }\n return [M, C, A, T];\n}\nfunction an(r, s) {\n const t = -0.3333333333333333 * r, e = 0.5 * s;\n let n, i = null;\n if ((Math.abs(t) >= 1e102 || Math.abs(e) >= 1e164) && (Math.abs(t) < Math.abs(e) ? i = 1 - t * (t / e) * (t / e) : i = Math.sign(t) * (e / t * (e / t) / t - 1)), i !== null && e == 0)\n r > 0 ? n = 0 : n = Math.sqrt(-r);\n else if (i !== null ? i < 0 : e * e < t * t * t) {\n const a = i !== null ? e / t / Math.sqrt(t) : e / Math.sqrt(t * t * t);\n n = -2 * Math.sqrt(t) * kt(Math.cos(Math.acos(Math.abs(a)) * (1 / 3)), a);\n } else {\n let a;\n i !== null ? Math.abs(t) < Math.abs(e) ? a = -e * (1 + Math.sqrt(i)) : a = -e - kt(Math.sqrt(Math.abs(t)) * t * Math.sqrt(i), e) : a = Math.cbrt(-e - kt(Math.sqrt(e * e - t * t * t), e));\n const u = a == 0 ? 0 : t / a;\n n = a + u;\n }\n let o = n, l = (o * o + r) * o + s;\n if (Math.abs(l) < 222045e-21 * Math.max(o * o * o, r * o, s))\n return o;\n for (let a = 0; a < 8; a++) {\n const u = 3 * o * o + r;\n if (u == 0)\n break;\n const c = o - l / u, g = (c * c + r) * c + s;\n if (g == 0)\n return c;\n if (Math.abs(g) >= Math.abs(l))\n break;\n o = c, l = g;\n }\n return o;\n}\nfunction kt(r, s) {\n const t = Math.abs(r);\n return s < 0 ? -t : t;\n}\nfunction un(r, s = 1e-9) {\n if (r[r.length - 1] == 0)\n return un(r.slice(0, -1), s);\n const t = new ln([\n r.slice(0, -1).reverse().map((n) => -n / r[r.length - 1]),\n ...Array.from({ length: r.length - 2 }, (n, i) => {\n const o = new Array(r.length - 1).fill(0);\n return o[i] = 1, o;\n })\n ]), e = new on(t);\n return e.realEigenvalues.filter(\n (n, i) => Math.abs(e.imaginaryEigenvalues[i]) < s\n );\n}\nconst cn = (r, s, t) => [r[0] * (1 - t) + s[0] * t, r[1] * (1 - t) + s[1] * t];\nfunction fn(r) {\n const s = [];\n for (let t = 0; t < r.length - 1; t++)\n s.push([r[t], r[t + 1]]);\n return s;\n}\nfunction de(r, s) {\n const t = fn(r).map(([e, n]) => cn(e, n, s));\n return r.length === 2 ? [t] : [...de(t, s), t];\n}\nconst Ae = Symbol.for(\"pantograph:CubicBezier\");\nclass Et extends Ft {\n constructor(t, e, n, i) {\n super(t, e);\n q(this, \"segmentType\", \"CUBIC_BEZIER\");\n q(this, \"firstControlPoint\");\n q(this, \"lastControlPoint\");\n q(this, \"_boundingBox\", null);\n q(this, \"_polynomialCoefficients\", null);\n Object.defineProperty(this, Ae, { value: !0 }), this.firstControlPoint = n, this.lastControlPoint = i;\n }\n static isInstance(t) {\n return !!t && t[Ae] === !0;\n }\n get midPoint() {\n return this.paramPoint(0.5);\n }\n _extremaInDirection(t) {\n const [e, n, i, o] = [\n this.firstPoint[t],\n this.firstControlPoint[t],\n this.lastControlPoint[t],\n this.lastPoint[t]\n ], l = -e + 3 * n - 3 * i + o, h = 2 * e - 4 * n + 2 * i, a = -e + n;\n return qt(a, h, l).filter(\n (u) => u >= -this.precision && u <= 1 + this.precision\n );\n }\n getParametersOfExtrema() {\n return Array.from(\n new Set(this._extremaInDirection(0).concat(this._extremaInDirection(1)))\n );\n }\n get alignedCurve() {\n const t = [-this.firstPoint[0], -this.firstPoint[1]], e = Q(this.lastPoint, this.firstPoint), n = Math.atan2(e[1], e[0]), i = new et();\n return i.translate(t[0], t[1]), i.rotate(-n), this.transform(i);\n }\n getInflexionParameters() {\n const t = this.alignedCurve, [e, n] = t.firstControlPoint, [i, o] = t.lastControlPoint, [l, h] = t.lastPoint, a = i * n, u = l * n, c = e * o, g = l * o, d = -3 * a + 2 * u + 3 * c - g, w = 3 * a - u - 3 * c, p = c - a;\n return qt(p, w, d).filter((P) => P >= 0 && P <= 1);\n }\n get boundingBox() {\n return this._boundingBox === null && (this._boundingBox = ce([\n this.firstPoint,\n ...this.getParametersOfExtrema().map((t) => this.paramPoint(t)),\n this.lastPoint\n ]).grow(this.precision)), this._boundingBox;\n }\n clone() {\n return new Et(\n this.firstPoint,\n this.lastPoint,\n this.firstControlPoint,\n this.lastControlPoint\n );\n }\n reverse() {\n return new Et(\n this.lastPoint,\n this.firstPoint,\n this.lastControlPoint,\n this.firstControlPoint\n );\n }\n isSame(t) {\n return t.segmentType !== \"CUBIC_BEZIER\" ? !1 : Y(this.firstPoint, t.firstPoint) && Y(this.lastPoint, t.lastPoint) && Y(this.firstControlPoint, t.firstControlPoint) && Y(this.lastControlPoint, t.lastControlPoint);\n }\n distanceFrom(t) {\n const n = $e((i) => Rt(this.paramPoint(i), t), this.precision);\n return n.argMin < -this.precision || n.argMin > 1 + this.precision ? Math.min(\n J(this.firstPoint, t),\n J(this.lastPoint, t)\n ) : Math.sqrt(n.fMin);\n }\n isOnSegment(t) {\n if (!this.boundingBox.contains(t))\n return !1;\n try {\n const e = this.pointToParam(t);\n return e >= -this.precision && e <= 1 + this.precision;\n } catch {\n return !1;\n }\n }\n gradientAt(t) {\n const e = 1 - t, n = e * e, i = t * t, o = 3 * n, l = 6 * e * t, h = 3 * i, a = Q(this.firstControlPoint, this.firstPoint), u = Q(this.lastControlPoint, this.firstControlPoint), c = Q(this.lastPoint, this.lastControlPoint);\n return [\n o * a[0] + l * u[0] + h * c[0],\n o * a[1] + l * u[1] + h * c[1]\n ];\n }\n secondDerivativeAt(t) {\n const e = it(this.firstPoint, this.lastControlPoint), n = nt(this.firstControlPoint, 2), i = it(this.firstControlPoint, this.lastPoint), o = nt(this.lastControlPoint, 2), l = nt(Q(e, n), 6 * (1 - t)), h = nt(Q(i, o), 6 * t);\n return it(l, h);\n }\n tangentAt(t) {\n const e = this.pointToParam(t);\n return H(this.gradientAt(e));\n }\n get tangentAtFirstPoint() {\n return H(Q(this.firstControlPoint, this.firstPoint));\n }\n get tangentAtLastPoint() {\n return H(Q(this.lastPoint, this.lastControlPoint));\n }\n normalAt(t) {\n const e = this.tangentAt(t);\n return tt(e);\n }\n get normalAtFirstPoint() {\n return tt(this.tangentAtFirstPoint);\n }\n get normalAtLastPoint() {\n return tt(this.tangentAtLastPoint);\n }\n splitAtParameters(t, e = null) {\n const n = [...t];\n n.sort((o, l) => o - l);\n let i = {\n originalParam: 0,\n param: 0,\n p0: this.firstPoint,\n p1: this.firstControlPoint,\n p2: this.lastControlPoint\n };\n return n.flatMap((o, l) => {\n if (o - i.originalParam < this.precision)\n return [];\n let h = !1;\n o > 1 - this.precision && (h = !0);\n const a = (o - i.originalParam) / (1 - i.originalParam), u = de(\n [\n i.p0,\n i.p1,\n i.p2,\n this.lastPoint\n ],\n h ? 1 : a\n ), c = h ? this.lastPoint : (e == null ? void 0 : e.get(o)) ?? u[0][0], g = u[1][0], d = u[2][0], w = u[1][1], p = u[2][2], P = new Et(\n i.p0,\n c,\n d,\n g\n );\n return i = {\n param: a,\n originalParam: o,\n p0: c,\n p1: w,\n p2: p\n }, l === n.length - 1 && !h ? [\n P,\n new Et(\n i.p0,\n this.lastPoint,\n i.p1,\n i.p2\n )\n ] : P;\n });\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t];\n const n = e.map((o) => this.pointToParam(o)), i = new Map(\n Kt([n, e])\n );\n return this.splitAtParameters(n, i);\n }\n transform(t) {\n return new Et(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint),\n t.transform(this.firstControlPoint),\n t.transform(this.lastControlPoint)\n );\n }\n paramPoint(t) {\n const e = 1 - t, n = e * e, i = t * t, o = n * e, l = 3 * n * t, h = 3 * e * i, a = i * t;\n return [\n o * this.firstPoint[0] + l * this.firstControlPoint[0] + h * this.lastControlPoint[0] + a * this.lastPoint[0],\n o * this.firstPoint[1] + l * this.firstControlPoint[1] + h * this.lastControlPoint[1] + a * this.lastPoint[1]\n ];\n }\n get polynomialCoefficients() {\n if (this._polynomialCoefficients === null) {\n const t = (e) => {\n const n = this.firstPoint[e], i = this.firstControlPoint[e], o = this.lastControlPoint[e], l = this.lastPoint[e], h = -n + 3 * i - 3 * o + l, a = 3 * n - 6 * i + 3 * o, u = -3 * n + 3 * i;\n return [n, u, a, h];\n };\n this._polynomialCoefficients = [t(0), t(1)];\n }\n return this._polynomialCoefficients;\n }\n paramsAtY(t) {\n const [e, n, i, o] = this.polynomialCoefficients[1];\n return Ge(e - t, n, i, o).filter((l) => l >= -this.precision && l <= 1 + this.precision);\n }\n pointToParam(t) {\n if (Y(t, this.firstPoint, this.precision)) return 0;\n if (Y(t, this.lastPoint, this.precision)) return 1;\n const e = this.paramsAtY(t[1]);\n if (e.length === 0)\n throw new Error(\"Point is not on the curve\");\n const n = (o) => Math.abs(this.paramPoint(o)[0] - t[0]) <= this.precision, i = e.find(n);\n if (i === void 0)\n throw new Error(\"Point is not on the curve\");\n return i;\n }\n}\nconst Fe = Symbol.for(\"pantograph:EllipseArc\");\nclass jt extends Ft {\n constructor(t, e, n, i, o, l, h = !1, {\n ignoreChecks: a = !1,\n angleUnits: u = \"deg\"\n } = {}) {\n super(t, e);\n q(this, \"segmentType\", \"ELLIPSE_ARC\");\n // I would need to do some more work to improve the precision that I can have\n // on an ellipse with intersection algorithms\n q(this, \"precision\", 1e-6);\n q(this, \"majorRadius\");\n q(this, \"minorRadius\");\n q(this, \"center\");\n q(this, \"tiltAngle\");\n q(this, \"clockwise\");\n q(this, \"_coefficients\", null);\n q(this, \"_boundingBox\");\n q(this, \"_linearExentricity\");\n q(this, \"_exentricity\");\n q(this, \"_focals\");\n q(this, \"_ellipseReferenceFrameTransform\");\n q(this, \"_reverseEllipseReferenceFrameTransform\");\n q(this, \"_rotateFromEllipseReferenceFrame\");\n q(this, \"_firstAngle\");\n q(this, \"_lastAngle\");\n q(this, \"_deltaAngle\");\n Object.defineProperty(this, Fe, { value: !0 }), this.center = n;\n const c = i >= o;\n this.majorRadius = c ? i : o, this.minorRadius = c ? o : i;\n const g = u === \"deg\" ? l * fe : l;\n if (this.tiltAngle = wt(\n c ? g : g + Math.PI / 2\n ), this.clockwise = h, !a) {\n if (Y(t, e))\n throw new Error(\"Invalid arc, cannot be a full circle\");\n if (!this.isPointOnEllipse(t))\n throw new Error(\n `First point ${Z(\n t\n )} not on the ellipse defined by ${this.info}`\n );\n if (!this.isPointOnEllipse(e))\n throw new Error(\n `Last point ${Z(e)} not on the ellipse defined by ${this.info}`\n );\n if (Math.abs(this.majorRadius - this.minorRadius) < this.precision)\n throw new Error(\n \"Both radii should be different, create an arc instead\"\n );\n }\n }\n static isInstance(t) {\n return !!t && t[Fe] === !0;\n }\n get coefficients() {\n if (this._coefficients === null) {\n const [t, e] = this.center, n = this.majorRadius * this.majorRadius, i = this.minorRadius * this.minorRadius, o = Math.cos(this.tiltAngle), l = Math.sin(this.tiltAngle), h = n * l * l + i * o * o, a = 2 * (i - n) * l * o, u = n * o * o + i * l * l;\n this._coefficients = {\n x2: h,\n xy: a,\n y2: u,\n x: -2 * h * t - a * e,\n y: -2 * u * e - a * t,\n c: h * t * t + a * t * e + u * e * e - n * i\n };\n }\n return this._coefficients;\n }\n get info() {\n return `ELLIPSE_ARC(${Z(this.firstPoint)}, ${Z(\n this.lastPoint\n )}, ${Z(this.center)}, ${this.majorRadius}, ${this.minorRadius}, ${this.tiltAngle * Je}, ${this.clockwise ? \"CW\" : \"CCW\"})`;\n }\n reverse() {\n return new jt(\n this.lastPoint,\n this.firstPoint,\n this.center,\n this.majorRadius,\n this.minorRadius,\n this.tiltAngle,\n !this.clockwise,\n { ignoreChecks: !0, angleUnits: \"rad\" }\n );\n }\n clone() {\n return new jt(\n this.firstPoint,\n this.lastPoint,\n this.center,\n this.majorRadius,\n this.minorRadius,\n this.tiltAngle,\n this.clockwise,\n { ignoreChecks: !0, angleUnits: \"rad\" }\n );\n }\n computeEllipseExtrema() {\n const t = Math.tan(this.tiltAngle), e = this.minorRadius / this.majorRadius, n = -Math.atan(e * t), i = Math.atan(e / t);\n return [n, Math.PI + n, i, Math.PI + i].map((l) => this.thetaToParam(l)).filter((l) => this.isValidParameter(l)).map((l) => this.paramPoint(l));\n }\n get boundingBox() {\n if (this._boundingBox === void 0) {\n const t = this.computeEllipseExtrema(), e = [\n this.firstPoint,\n this.lastPoint,\n ...t\n ];\n this._boundingBox = ce(e).grow(this.precision);\n }\n return this._boundingBox;\n }\n get linearExentricity() {\n return this._linearExentricity === void 0 && (this._linearExentricity = Math.sqrt(\n this.majorRadius * this.majorRadius - this.minorRadius * this.minorRadius\n )), this._linearExentricity;\n }\n get exentricity() {\n return this._exentricity === void 0 && (this._exentricity = this.linearExentricity / this.majorRadius), this._exentricity;\n }\n get focals() {\n if (this._focals === void 0) {\n const t = this.majorAxis;\n this._focals = [\n it(this.center, nt(t, this.linearExentricity)),\n it(this.center, nt(t, -this.linearExentricity))\n ];\n }\n return this._focals;\n }\n get majorAxis() {\n return It(1, this.tiltAngle);\n }\n paramPoint(t) {\n const e = this.firstAngle + t * this.deltaAngle * (this.clockwise ? -1 : 1);\n return this.reverseEllipseReferenceFrameTransform.transform([\n this.majorRadius * Math.cos(e),\n this.minorRadius * Math.sin(e)\n ]);\n }\n pointToParam(t) {\n if (!this.isPointOnEllipse(t))\n throw new Error(\n `Point ${Z(t)} not on the ellipse defined by ${this.repr}`\n );\n const e = this.thetaToParam(this.pointTheta(t));\n if (!this.isValidParameter(e))\n throw new Error(\n `Point ${Z(t)} is not on segment ${this.repr}`\n );\n return e;\n }\n get midPoint() {\n return this.paramPoint(0.5);\n }\n isValidParameter(t) {\n return 1 - t >= -this.precision && t >= -this.precision;\n }\n isSame(t) {\n return Y(this.center, t.center) && Math.abs(this.majorRadius - t.majorRadius) < this.precision && Math.abs(this.minorRadius - t.minorRadius) < this.precision && (Math.abs(this.tiltAngle - t.tiltAngle) < this.precision || Math.abs(Math.abs(this.tiltAngle - t.tiltAngle) - Math.PI) < this.precision) && (Y(this.firstPoint, t.firstPoint) && this.clockwise === t.clockwise || Y(this.firstPoint, t.lastPoint) && this.clockwise !== t.clockwise);\n }\n pointTheta(t) {\n const e = this.ellipseReferenceFrameTransform.transform(t), n = Math.atan2(\n e[1] / this.minorRadius,\n e[0] / this.majorRadius\n );\n return wt(n);\n }\n thetaToParam(t) {\n return Zt(this.firstAngle, wt(t), this.clockwise) / this.deltaAngle;\n }\n isPointOnEllipse(t) {\n const [e, n] = this.focals, i = J(t, e), o = J(t, n);\n return Math.abs(2 * this.majorRadius - i - o) < this.precision;\n }\n isOnSegment(t) {\n return this.isPointOnEllipse(t) ? this.isValidParameter(this.thetaToParam(this.pointTheta(t))) : !1;\n }\n distanceFrom(t) {\n let e;\n if (Y(t, this.center) ? e = it(\n this.center,\n nt(tt(this.majorAxis), this.minorRadius)\n ) : e = this.reverseEllipseReferenceFrameTransform.transform(\n gn(\n this.majorRadius,\n this.minorRadius,\n this.ellipseReferenceFrameTransform.transform(t)\n )\n ), this.isValidParameter(this.thetaToParam(this.pointTheta(t))))\n return J(t, e);\n if (ts(t, this.majorAxis, this.center)) {\n const n = wt(\n 2 * Math.PI - this.pointTheta(t)\n ), i = this.thetaToParam(n);\n if (this.isValidParameter(i))\n return J(t, this.paramPoint(i));\n }\n return Math.min(\n J(t, this.firstPoint),\n J(t, this.lastPoint)\n );\n }\n get ellipseReferenceFrameTransform() {\n return this._ellipseReferenceFrameTransform === void 0 && (this._ellipseReferenceFrameTransform = new et().translate(-this.center[0], -this.center[1]).rotate(-this.tiltAngle)), this._ellipseReferenceFrameTransform;\n }\n get reverseEllipseReferenceFrameTransform() {\n return this._reverseEllipseReferenceFrameTransform === void 0 && (this._reverseEllipseReferenceFrameTransform = new et().rotate(this.tiltAngle).translate(this.center[0], this.center[1])), this._reverseEllipseReferenceFrameTransform;\n }\n get rotateFromEllipseReferenceFrame() {\n return this._rotateFromEllipseReferenceFrame === void 0 && (this._rotateFromEllipseReferenceFrame = new et().rotate(\n this.tiltAngle\n )), this._rotateFromEllipseReferenceFrame;\n }\n get firstAngle() {\n return this._firstAngle === void 0 && (this._firstAngle = this.pointTheta(this.firstPoint)), this._firstAngle;\n }\n get lastAngle() {\n return this._lastAngle === void 0 && (this._lastAngle = this.pointTheta(this.lastPoint)), this._lastAngle;\n }\n get deltaAngle() {\n return this._deltaAngle === void 0 && (this._deltaAngle = Zt(\n this.firstAngle,\n this.lastAngle,\n this.clockwise\n )), this._deltaAngle;\n }\n normalAt(t) {\n const e = this.tangentAt(t);\n return this.clockwise ? tt(e) : Qt(e);\n }\n gradientAt(t) {\n const e = this.firstAngle + t * this.deltaAngle * (this.clockwise ? -1 : 1), n = -this.majorRadius * this.deltaAngle * Math.sin(e), i = this.minorRadius * this.deltaAngle * Math.cos(e), o = this.clockwise ? [-n, -i] : [n, i];\n return this.rotateFromEllipseReferenceFrame.transform(o);\n }\n tangentAt(t) {\n const e = this.pointTheta(t), n = -this.majorRadius * Math.sin(e), i = this.minorRadius * Math.cos(e), o = this.clockwise ? [-n, -i] : [n, i];\n return H(this.rotateFromEllipseReferenceFrame.transform(o));\n }\n get tangentAtFirstPoint() {\n const t = -this.majorRadius * Math.sin(this.firstAngle), e = this.minorRadius * Math.cos(this.firstAngle), n = this.clockwise ? [-t, -e] : [t, e];\n return H(this.rotateFromEllipseReferenceFrame.transform(n));\n }\n get tangentAtLastPoint() {\n const t = -this.majorRadius * Math.sin(this.lastAngle), e = this.minorRadius * Math.cos(this.lastAngle), n = this.clockwise ? [-t, -e] : [t, e];\n return H(this.rotateFromEllipseReferenceFrame.transform(n));\n }\n transform(t) {\n const e = t.transformAngle(this.tiltAngle), n = t.scaleFactor();\n return new jt(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint),\n t.transform(this.center),\n this.majorRadius * n,\n this.minorRadius * n,\n e,\n t.keepsOrientation() ? this.clockwise : !this.clockwise,\n { angleUnits: \"rad\" }\n );\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t];\n const i = [0, 1, ...e.map((h) => this.pointToParam(h))], o = new Map(\n Kt([i, [this.firstPoint, this.lastPoint, ...e]])\n );\n i.sort((h, a) => h - a);\n let l = null;\n return i.flatMap((h, a) => {\n if (a === i.length - 1) return [];\n const u = i[a + 1];\n if (u - h < this.precision)\n return l === null && (l = h), [];\n const c = l === null ? h : l, g = new jt(\n o.get(c) || this.paramPoint(c),\n o.get(u) || this.paramPoint(u),\n this.center,\n this.majorRadius,\n this.minorRadius,\n this.tiltAngle,\n this.clockwise,\n { angleUnits: \"rad\" }\n );\n return l = null, g;\n });\n }\n}\nfunction _n(r, s, t, e, n, i, o) {\n const { center: l, rx: h, ry: a } = mn(\n r,\n s,\n t,\n e,\n n * fe,\n !i,\n o\n );\n return Math.abs(h - a) < 1e-9 ? new ct(r, s, l, o) : new jt(r, s, l, h, a, n, o);\n}\nfunction mn([r, s], [t, e], n, i, o, l, h) {\n if (n < 0 && (n = -n), i < 0 && (i = -i), n == 0 || i == 0)\n throw Error(\"rx and ry can not be 0\");\n const a = Math.sin(o), u = Math.cos(o), c = (r - t) / 2, g = (s - e) / 2, d = (r + t) / 2, w = (s + e) / 2, p = u * c + a * g, P = u * g - a * c, f = p * p / (n * n) + P * P / (i * i);\n f > 1 && (n = n * Math.sqrt(f), i = i * Math.sqrt(f));\n const y = n * i, E = n * P, R = i * p, v = E * E + R * R;\n if (!v)\n throw Error(\"start point can not be same as end point\");\n let L = Math.sqrt(Math.abs((y * y - v) / v));\n l == h && (L = -L);\n const S = L * E / i, k = -L * R / n, D = u * S - a * k + d, m = a * S + u * k + w;\n return {\n center: [D, m],\n rx: n,\n ry: i\n };\n}\nfunction gn(r, s, t) {\n const e = Math.abs(t[0]), n = Math.abs(t[1]);\n let i = 0.707, o = 0.707;\n const l = r, h = s;\n for (let a = 0; a < 3; a++) {\n const u = l * i, c = h * o, g = (l * l - h * h) * i ** 3 / l, d = (h * h - l * l) * o ** 3 / h, w = u - g, p = c - d, P = e - g, f = n - d, y = Math.hypot(w, p), E = Math.hypot(P, f);\n i = Math.min(1, Math.max(0, (P * y / E + g) / l)), o = Math.min(1, Math.max(0, (f * y / E + d) / h));\n const R = Math.hypot(i, o);\n i /= R, o /= R;\n }\n return [l * i * Math.sign(t[0]), h * o * Math.sign(t[1])];\n}\nconst xe = Symbol.for(\"pantograph:QuadraticBezier\");\nclass _t extends Ft {\n constructor(t, e, n) {\n super(t, e);\n q(this, \"segmentType\", \"QUADRATIC_BEZIER\");\n q(this, \"controlPoint\");\n q(this, \"_boundingBox\", null);\n q(this, \"_polynomialCoefficients\", null);\n Object.defineProperty(this, xe, { value: !0 }), this.controlPoint = n;\n }\n static isInstance(t) {\n return !!t && t[xe] === !0;\n }\n get midPoint() {\n return this.paramPoint(0.5);\n }\n _extremaInDirection(t) {\n const [e, n, i] = [\n this.firstPoint[t],\n this.controlPoint[t],\n this.lastPoint[t]\n ], o = e - 2 * n + i;\n if (!o)\n return [];\n const l = (e - n) / o;\n return l >= -this.precision && l <= 1 + this.precision ? [l] : [];\n }\n getParametersOfExtrema() {\n return Array.from(\n new Set(this._extremaInDirection(0).concat(this._extremaInDirection(1)))\n );\n }\n get boundingBox() {\n return this._boundingBox === null && (this._boundingBox = ce([\n this.firstPoint,\n // There is either one or zero extrema in each direction\n ...this.getParametersOfExtrema().map((t) => this.paramPoint(t)),\n this.lastPoint\n ]).grow(this.precision)), this._boundingBox;\n }\n clone() {\n return new _t(\n this.firstPoint,\n this.lastPoint,\n this.controlPoint\n );\n }\n reverse() {\n return new _t(\n this.lastPoint,\n this.firstPoint,\n this.controlPoint\n );\n }\n isSame(t) {\n return t.segmentType !== \"QUADRATIC_BEZIER\" ? !1 : Y(this.firstPoint, t.firstPoint) && Y(this.lastPoint, t.lastPoint) && Y(this.controlPoint, t.controlPoint);\n }\n distanceFrom(t) {\n const n = $e((i) => Rt(this.paramPoint(i), t), this.precision);\n return n.argMin < -this.precision || n.argMin > 1 + this.precision ? Math.min(\n J(this.firstPoint, t),\n J(this.lastPoint, t)\n ) : Math.sqrt(n.fMin);\n }\n isOnSegment(t) {\n if (!this.boundingBox.contains(t))\n return !1;\n try {\n const e = this.pointToParam(t);\n return e >= -this.precision && e <= 1 + this.precision;\n } catch {\n return !1;\n }\n }\n gradientAt(t) {\n const e = (n) => {\n const i = this.firstPoint[n], o = this.controlPoint[n], l = this.lastPoint[n];\n return 2 * (t * (i - 2 * o + l) - i + o);\n };\n return [e(0), e(1)];\n }\n secondDerivativeAt(t) {\n return nt(\n Q(\n it(this.firstPoint, this.lastPoint),\n nt(this.controlPoint, 2)\n ),\n 2\n );\n }\n tangentAt(t) {\n const e = this.pointToParam(t);\n return H(this.gradientAt(e));\n }\n get tangentAtFirstPoint() {\n return H(Q(this.controlPoint, this.firstPoint));\n }\n get tangentAtLastPoint() {\n return H(Q(this.lastPoint, this.controlPoint));\n }\n normalAt(t) {\n const e = this.tangentAt(t);\n return tt(e);\n }\n get normalAtFirstPoint() {\n return tt(this.tangentAtFirstPoint);\n }\n get normalAtLastPoint() {\n return tt(this.tangentAtLastPoint);\n }\n splitAtParameters(t, e = null) {\n const n = [...t];\n n.sort((o, l) => o - l);\n let i = {\n originalParam: 0,\n param: 0,\n p0: this.firstPoint,\n p1: this.controlPoint\n };\n return n.flatMap((o, l) => {\n if (o - i.originalParam < this.precision)\n return [];\n let h = !1;\n o > 1 - this.precision && (h = !0);\n const a = (o - i.originalParam) / (1 - i.originalParam), u = de(\n [i.p0, i.p1, this.lastPoint],\n h ? 1 : a\n ), c = h ? this.lastPoint : (e == null ? void 0 : e.get(o)) ?? u[0][0], g = u[1][0], d = u[1][1], w = new _t(\n i.p0,\n c,\n g\n );\n return i = {\n param: a,\n originalParam: o,\n p0: c,\n p1: d\n }, l === n.length - 1 && !h ? [\n w,\n new _t(\n i.p0,\n this.lastPoint,\n i.p1\n )\n ] : w;\n });\n }\n splitAt(t) {\n let e;\n if (Array.isArray(t) && t.length === 0)\n return [this];\n Array.isArray(t[0]) ? e = t : e = [t];\n const n = e.map((o) => this.pointToParam(o)), i = new Map(\n Kt([n, e])\n );\n return this.splitAtParameters(n, i);\n }\n transform(t) {\n return new _t(\n t.transform(this.firstPoint),\n t.transform(this.lastPoint),\n t.transform(this.controlPoint)\n );\n }\n paramPoint(t) {\n const e = 1 - t, n = e * e, i = 2 * e * t, o = t * t;\n return [\n n * this.firstPoint[0] + i * this.controlPoint[0] + o * this.lastPoint[0],\n n * this.firstPoint[1] + i * this.controlPoint[1] + o * this.lastPoint[1]\n ];\n }\n get polynomialCoefficients() {\n if (this._polynomialCoefficients === null) {\n const t = (e) => {\n const n = this.firstPoint[e], i = this.controlPoint[e], o = this.lastPoint[e], l = n - 2 * i + o, h = 2 * (i - n);\n return [n, h, l];\n };\n this._polynomialCoefficients = [t(0), t(1)];\n }\n return this._polynomialCoefficients;\n }\n paramsAtY(t) {\n const [e, n, i] = this.polynomialCoefficients[1];\n return qt(e - t, n, i).filter(\n (o) => o >= -this.precision && o <= 1 + this.precision\n );\n }\n pointToParam(t) {\n const e = this.paramsAtY(t[1]);\n if (e.length === 0)\n throw new Error(\"Point is not on the curve!\");\n const n = (o) => Math.abs(this.paramPoint(o)[0] - t[0]) <= this.precision, i = e.find(n);\n if (i === void 0)\n throw new Error(\"Point is not on the curve\");\n return i;\n }\n}\nexport {\n ct as A,\n mt as B,\n Et as C,\n fe as D,\n jt as E,\n yn as F,\n ns as G,\n Ve as H,\n Z as I,\n at as L,\n _t as Q,\n Je as R,\n et as T,\n it as a,\n Q as b,\n St as c,\n be as d,\n J as e,\n Qt as f,\n Y as g,\n Mn as h,\n _n as i,\n He as j,\n It as k,\n Ne as l,\n me as m,\n H as n,\n Ke as o,\n tt as p,\n Rt as q,\n is as r,\n nt as s,\n Pn as t,\n dn as u,\n pn as v,\n un as w,\n En as x,\n Tt as y,\n Kt as z\n};\n//# sourceMappingURL=QuadraticBezier-BeY2TXKH.js.map\n","var on = Object.defineProperty;\nvar ln = (t, n, e) => n in t ? on(t, n, { enumerable: !0, configurable: !0, writable: !0, value: e }) : t[n] = e;\nvar b = (t, n, e) => ln(t, typeof n != \"symbol\" ? n + \"\" : n, e);\nimport { b as k, d as un, e as Dt, a as z, s as N, n as cn, p as Rt, l as j, A as x, g as P, w as Nt, E as C, T as an, x as fn, Q as M, y as $, C as A, c as hn, v as pn, L as y, F as Vt, G as ut, z as V, H as dn, m as mn, q as gn, I as mt, B as Pn } from \"./QuadraticBezier-BeY2TXKH.js\";\nfunction In(t, n) {\n const e = k(n, t.firstPoint), s = un(e, t.V) / t.squareLength;\n return t.paramPoint(s);\n}\nfunction K(t, n, e) {\n const s = e || t.precision, i = In(t, n.center), r = Dt(i, n.center);\n if (r > n.radius + s) return [];\n if (Math.abs(r - n.radius) < s) {\n const c = i;\n return t.isOnSegment(c) && n.isOnSegment(c) ? [c] : [];\n }\n const l = [], o = Math.sqrt(\n n.radius * n.radius - r * r\n ), u = t.tangentAtFirstPoint, a = z(i, N(u, o));\n t.isOnSegment(a) && n.isOnSegment(a) && l.push(a);\n const f = z(i, N(u, -o));\n return t.isOnSegment(f) && n.isOnSegment(f) && l.push(f), l;\n}\nconst wn = (t) => {\n const { firstPoint: n, lastPoint: e, center: s, clockwise: i } = t;\n return new x(e, n, s, i, {\n ignoreChecks: !0\n });\n}, xn = (t, n) => {\n if (t.isSame(n))\n return [t];\n const e = j(\n [\n n.isOnSegment(t.firstPoint) ? t.firstPoint : null,\n n.isOnSegment(t.lastPoint) ? t.lastPoint : null,\n t.isOnSegment(n.firstPoint) ? n.firstPoint : null,\n t.isOnSegment(n.lastPoint) ? n.lastPoint : null\n ].filter((s) => s !== null)\n // We sort by the param value of the first arc. This means that the points\n // will be sorted with the same orientation than arc1\n ).sort((s, i) => t.pointToParam(s) - t.pointToParam(i));\n if (e.length === 0) return [];\n if (e.length === 1) return [];\n if (e.length === 2)\n return t.isSame(wn(n)) ? [] : [new x(e[0], e[1], t.center, t.clockwise)];\n if (e.length === 3) {\n const s = P(e[0], n.lastPoint) || P(e[0], n.firstPoint) ? 1 : 0;\n return [\n new x(\n e[0 + s],\n e[1 + s],\n t.center,\n t.clockwise\n )\n ];\n } else if (e.length === 4)\n return [\n new x(e[0], e[1], t.center, t.clockwise),\n new x(e[2], e[3], t.center, t.clockwise)\n ];\n throw new Error(\"Bug in the arc arc overlap algorithm\");\n};\nfunction jt(t, n, e = !1, s) {\n const i = s || t.precision, r = Dt(t.center, n.center), l = t.radius + n.radius;\n if (r > l + i)\n return [];\n const o = Math.abs(t.radius - n.radius);\n if (r < o - i)\n return [];\n if (r < i)\n return o > i ? [] : e ? xn(t, n) : [];\n const u = cn(k(n.center, t.center)), a = r > l - i;\n if (\n // circles are outside each other\n a || // circles are inside each other\n Math.abs(r - o) < i\n ) {\n const g = a || t.radius > n.radius ? 1 : -1, I = z(\n t.center,\n N(u, g * t.radius)\n );\n return t.isOnSegment(I) && n.isOnSegment(I) ? [I] : [];\n }\n const f = t.radius * t.radius / (2 * r) - n.radius * n.radius / (2 * r) + r / 2, c = z(\n t.center,\n N(u, f)\n ), h = Math.sqrt(\n t.radius * t.radius - f * f\n ), p = Rt(u), d = z(c, N(p, h)), m = z(c, N(p, -h)), w = [];\n return t.isOnSegment(d) && n.isOnSegment(d) && w.push(d), t.isOnSegment(m) && n.isOnSegment(m) && w.push(m), w;\n}\nfunction st(t, n, e = 1e-9) {\n const s = t.transform(n.ellipseReferenceFrameTransform), i = s.slope, r = s.yIntercept, l = n.majorRadius * n.majorRadius, o = n.minorRadius * n.minorRadius, u = n.majorRadius * n.minorRadius, a = s.slope * s.slope, f = s.yIntercept * s.yIntercept, c = (g) => g.map(\n (I) => n.reverseEllipseReferenceFrameTransform.transform(I)\n ).filter((I) => t.isOnSegment(I) && n.isOnSegment(I));\n if (!Number.isFinite(i)) {\n const g = s.firstPoint[0];\n if (Math.abs(g) - n.majorRadius > e) return [];\n if (Math.abs(Math.abs(g) - n.majorRadius) < e)\n return c([[g, 0]]);\n const I = n.minorRadius * Math.sqrt(1 - g * g / l), F = [g, I], S = [g, -I];\n return c([F, S]);\n }\n const h = l * a + o - f;\n if (h < -e)\n return [];\n const p = l * a + o;\n if (Math.abs(h) < e) {\n const g = -(l * i * r) / p, I = o * r / p;\n return c([[g, I]]);\n }\n const d = Math.sqrt(h), m = [\n -(l * i * r + u * d) / p,\n (o * r - u * i * d) / p\n ], w = [\n -(l * i * r - u * d) / p,\n (o * r + u * i * d) / p\n ];\n return c([m, w]);\n}\nfunction Ut(t, n) {\n const e = Math.max(t.precision, n.precision), s = t.coefficients, i = s.x2, r = s.xy, l = s.y2, o = s.x, u = s.y, a = s.c, f = n.coefficients, c = f.x2, h = f.xy, p = f.y2, d = f.x, m = f.y, w = f.c, g = {\n z0: a * i * d * d + i * i * w * w - o * i * d * w + c * c * a * a - 2 * i * w * c * a - o * d * c * a + c * o * o * w,\n z1: m * o * o * c - w * d * i * r - 2 * i * w * c * u - a * c * h * o + 2 * d * h * i * a + 2 * m * w * i * i + d * d * i * u - m * d * i * o - 2 * i * m * c * a - a * c * d * r + 2 * a * u * c * c - w * h * i * o - u * c * d * o + 2 * w * r * c * o,\n z2: m * m * i * i + 2 * p * w * i * i - u * c * d * r + w * c * r * r - u * c * h * o - w * h * i * r - 2 * i * m * c * u + 2 * d * h * i * u - p * d * i * o - 2 * i * p * c * a + h * h * i * a + 2 * m * r * c * o + u * u * c * c - l * c * d * o - m * h * i * o + 2 * a * l * c * c - a * c * h * r + p * o * o * c + d * d * i * l - m * d * i * r - 2 * i * w * c * l,\n z3: -2 * i * c * l * m + m * c * r * r + 2 * p * r * c * o - l * c * h * o + h * h * i * u - m * h * i * r - 2 * i * p * c * u - u * c * h * r - p * h * i * o + 2 * m * p * i * i + 2 * u * l * c * c - l * c * d * r + 2 * d * h * i * l - p * d * i * r,\n z4: i * i * p * p - 2 * i * p * c * l + c * c * l * l - r * i * h * p - r * h * c * l + r * r * c * p + l * i * h * h\n }, F = Nt(\n [g.z0, g.z1, g.z2, g.z3, g.z4],\n e\n ).flatMap((S) => {\n const R = i * h * S + i * d - c * r * S - c * o;\n if (R)\n return [[-(i * w + i * p * S * S - c * l * S * S + i * m * S - c * u * S - c * a) / R, S]];\n const T = r * S + o, L = -T / (2 * i), U = l * S * S + u * S + a, q = T * T / (4 * i * i) - U / i;\n if (Math.abs(q) < e)\n return [[L, S]];\n if (q > 0) {\n const H = Math.sqrt(q);\n return [[L + H, S], [L - H, S]];\n }\n return [];\n });\n return j(F, e);\n}\nfunction gt(t, n) {\n return Ut(t, n).filter((s) => t.isOnSegment(s) && n.isOnSegment(s));\n}\nconst Sn = (t) => {\n const {\n firstPoint: n,\n lastPoint: e,\n center: s,\n majorRadius: i,\n minorRadius: r,\n tiltAngle: l,\n clockwise: o\n } = t;\n return new C(\n e,\n n,\n s,\n i,\n r,\n l,\n o,\n {\n ignoreChecks: !0,\n angleUnits: \"rad\"\n }\n );\n}, yn = (t, n) => {\n if (t.isSame(n))\n return [t];\n const e = (i, r) => new C(\n i,\n r,\n t.center,\n t.majorRadius,\n t.minorRadius,\n t.tiltAngle,\n t.clockwise,\n { ignoreChecks: !0, angleUnits: \"rad\" }\n ), s = j(\n [\n n.isOnSegment(t.firstPoint) ? t.firstPoint : null,\n n.isOnSegment(t.lastPoint) ? t.lastPoint : null,\n t.isOnSegment(n.firstPoint) ? n.firstPoint : null,\n t.isOnSegment(n.lastPoint) ? n.lastPoint : null\n ].filter((i) => i !== null)\n // We sort by the param value of the first arc. This means that the points\n // will be sorted with the same orientation than arc1\n ).sort((i, r) => t.pointToParam(i) - t.pointToParam(r));\n if (s.length === 0) return [];\n if (s.length === 1) return [];\n if (s.length === 2)\n return t.isSame(Sn(n)) ? [] : [e(s[0], s[1])];\n if (s.length === 3) {\n const i = P(s[0], n.lastPoint) || P(s[0], n.firstPoint) ? 1 : 0;\n return [e(s[0 + i], s[1 + i])];\n } else if (s.length === 4)\n return [e(s[0], s[1]), e(s[2], s[3])];\n throw new Error(\"Bug in the ellipse arc ellipse arc overlap algorithm\");\n};\nfunction bn(t, n, e = !1) {\n const s = Math.max(t.precision, n.precision);\n return P(t.center, n.center) && Math.abs(t.majorRadius - n.majorRadius) < s && Math.abs(t.minorRadius - n.minorRadius) < s && (Math.abs(t.tiltAngle - n.tiltAngle) < s || Math.abs(Math.abs(t.tiltAngle - n.tiltAngle) - Math.PI) < s) ? e ? yn(t, n) : [] : Ut(t, n).filter((l) => t.isOnSegment(l) && n.isOnSegment(l));\n}\nfunction Pt(t, n) {\n const [e, s] = t.firstPoint, [i, r] = t.lastPoint, l = new an().translate(-e, -s).rotate(-Math.atan2(r - s, i - e)), o = l.clone().inverse(), u = n.transform(l);\n return u.paramsAtY(0).map((a) => u.paramPoint(a)).map((a) => o.transform(a)).filter((a) => t.isOnSegment(a));\n}\nconst Cn = (t, n = 1e-9) => {\n let e = t;\n return Math.abs(t) < n && (e = 0), e.toFixed(-Math.log10(n));\n};\nfunction Ht(t, n = 1e-9) {\n return Array.from(\n new Map(t.map((e) => [Cn(e, n), e])).values()\n );\n}\nconst Mn = (t, n) => {\n const [[e, s, i, r], [l, o, u, a]] = n.polynomialCoefficients, f = t.coefficients, c = f.x2, h = f.xy, p = f.y2, d = f.x, m = f.y, w = f.c, g = e * e, I = s * s, F = i * i, S = r * r, R = l * l, T = o * o, L = u * u, U = a * a, q = w + d * e + c * g + m * l + h * e * l + p * R, H = d * s + 2 * c * e * s + h * s * l + m * o + h * e * o + 2 * p * l * o, tn = c * I + d * i + 2 * c * e * i + h * i * l + h * s * o + p * T + m * u + h * e * u + 2 * p * l * u, nn = 2 * c * s * i + d * r + 2 * c * e * r + h * r * l + h * i * o + h * s * u + 2 * p * o * u + m * a + h * e * a + 2 * p * l * a, en = c * F + 2 * c * s * r + h * r * o + h * i * u + p * L + h * s * a + 2 * p * o * a, sn = 2 * c * i * r + h * r * u + h * i * a + 2 * p * u * a, rn = c * S + h * r * a + p * U;\n return [q, H, tn, nn, en, sn, rn];\n};\nfunction It(t, n) {\n const e = Math.max(t.precision, n.precision), s = Mn(t, n), i = Nt(s, e).filter((r) => r >= -n.precision && r <= 1 + n.precision);\n return Ht(i, e).map((r) => n.paramPoint(r)).filter((r) => t.isOnSegment(r));\n}\nconst An = (t, n) => {\n const [[e, s, i], [r, l, o]] = n.polynomialCoefficients, u = t.coefficients, a = u.x2, f = u.xy, c = u.y2, h = u.x, p = u.y, d = u.c, m = e * e, w = s * s, g = i * i, I = r * r, F = l * l, S = o * o, R = a * m + f * e * r + c * I + h * e + p * r + d, T = 2 * a * e * s + f * e * l + f * s * r + 2 * c * r * l + h * s + p * l, L = 2 * a * e * i + a * w + f * e * o + f * s * l + f * i * r + 2 * c * r * o + c * F + h * i + p * o, U = 2 * a * s * i + f * s * o + f * i * l + 2 * c * l * o, q = a * g + f * i * o + c * S;\n return [R, T, L, U, q];\n};\nfunction wt(t, n) {\n const e = Math.max(t.precision, n.precision), s = An(t, n), i = fn(...s).filter((r) => r >= -n.precision && r <= 1 + n.precision);\n return Ht(i, e).map((r) => n.paramPoint(r)).filter((r) => t.isOnSegment(r));\n}\nfunction E(t, { firstPoint: n, lastPoint: e }, s = 1e-9) {\n const i = k(e, n);\n return Math.abs(i[0]) < s ? i[1] > 0 ? n[0] - t[0] : t[0] - n[0] : Math.abs(i[1]) < s ? i[0] > 0 ? t[1] - n[1] : n[1] - t[1] : hn(i, k(t, n)) / pn(i);\n}\nclass ct {\n constructor(n, e, s, i) {\n this.firstPoint = n, this.lastPoint = e, this.negativeThickness = s, this.positiveThickness = i;\n }\n get width() {\n return this.positiveThickness - this.negativeThickness;\n }\n}\nconst En = 3 / 4, Fn = 4 / 9;\nfunction vn(t) {\n const n = E(t.firstControlPoint, t), e = E(t.lastControlPoint, t), s = n * e > 0 ? En : Fn;\n return new ct(\n t.firstPoint,\n t.lastPoint,\n s * Math.min(0, n, e),\n s * Math.max(0, n, e)\n );\n}\nfunction Bn(t) {\n const n = E(t.controlPoint, t);\n return new ct(\n t.firstPoint,\n t.lastPoint,\n Math.min(0, n / 2),\n Math.max(0, n / 2)\n );\n}\nfunction kn(t) {\n if (A.isInstance(t))\n return vn(t);\n if (M.isInstance(t))\n return Bn(t);\n throw new Error(\"Not implemented\");\n}\nfunction On(t) {\n const n = t.paramPoint(0.5), e = Rt(k(n, t.firstPoint)), s = z(n, e), i = {\n firstPoint: n,\n lastPoint: s\n }, r = [\n E(t.firstPoint, i),\n E(t.lastPoint, i)\n ];\n return A.isInstance(t) ? r.push(\n E(t.firstControlPoint, i),\n E(t.lastControlPoint, i)\n ) : M.isInstance(t) && r.push(E(t.controlPoint, i)), new ct(\n n,\n s,\n Math.min(...r),\n Math.max(...r)\n );\n}\nfunction xt(t, n) {\n const e = [];\n for (let s = 1; s < t.length; s++) {\n const i = t[s];\n if (i[1] === n) {\n e.push(i[0]);\n continue;\n }\n const r = t[s - 1], l = n - r[1], o = n - i[1];\n if (l * o < 0) {\n e.push(\n r[0] + (n - r[1]) * (i[0] - r[0]) / (i[1] - r[1])\n );\n continue;\n }\n }\n return e;\n}\nclass Y {\n constructor(n, e) {\n this.from = n, this.to = e;\n }\n get size() {\n return this.from === \"start\" ? this.to === \"end\" ? 1 : this.to : this.to === \"end\" ? 1 - this.from : Math.abs(this.from - this.to);\n }\n clipCurve(n) {\n return this.from === \"start\" ? this.to === \"end\" ? n : n.splitAtParameters([this.to])[0] : this.to === \"end\" ? n.splitAtParameters([this.from])[1] : n.splitAtParameters([this.from, this.to])[1];\n }\n}\nfunction _n(t, n) {\n if (A.isInstance(t))\n return new Ln([\n E(t.firstPoint, n),\n E(t.firstControlPoint, n),\n E(t.lastControlPoint, n),\n E(t.lastPoint, n)\n ]);\n if (M.isInstance(t))\n return new Tn([\n E(t.firstPoint, n),\n E(t.controlPoint, n),\n E(t.lastPoint, n)\n ]);\n throw new Error(\"Not implemented\");\n}\nclass Tn {\n constructor(n) {\n b(this, \"topHull\", []);\n b(this, \"bottomHull\", []);\n this.distances = n;\n const [e, s, i] = n, r = [0, e], l = [1 / 2, s], o = [1, i], u = i - e, a = e;\n s - (u * (1 / 2) + a) > 0 ? (this.topHull = [r, l, o], this.bottomHull = [r, o]) : (this.topHull = [r, o], this.bottomHull = [r, l, o]);\n }\n get startDistance() {\n return this.distances[0];\n }\n get endDistance() {\n return this.distances[2];\n }\n}\nclass Ln {\n constructor(n) {\n b(this, \"topHull\", []);\n b(this, \"bottomHull\", []);\n this.distances = n;\n const [e, s, i, r] = n, l = [0, e], o = [1 / 3, s], u = [2 / 3, i], a = [1, r], f = r - e, c = e, h = s - (f * (1 / 3) + c), p = i - (f * (2 / 3) + c);\n let d = null, m = null;\n if (h * p < 0)\n d = [l, o, a], m = [l, u, a];\n else {\n const g = h / p;\n g >= 2 ? (d = [l, o, a], m = [l, a]) : g <= 0.5 ? (d = [l, u, a], m = [l, a]) : (d = [l, o, u, a], m = [l, a]);\n }\n h < 0 && ([d, m] = [m, d]), this.topHull = d, this.bottomHull = m;\n }\n get startDistance() {\n return this.distances[0];\n }\n get endDistance() {\n return this.distances[3];\n }\n}\nfunction St(t, n) {\n const e = _n(n, t), s = xt(\n e.topHull,\n t.negativeThickness\n ), i = xt(\n e.bottomHull,\n t.positiveThickness\n ), r = e.endDistance >= t.negativeThickness && e.endDistance <= t.positiveThickness;\n if (!s.length && !i.length)\n return r ? new Y(\"start\", \"end\") : null;\n if (s.length === 1 && i.length === 1)\n return new Y(s[0], i[0]);\n if (s.length === 2 && i.length === 2)\n throw new Error(\n \"Bug in the clipping algorithm, unexpected number of crossing points\"\n );\n const l = s.length ? s : i;\n return l.length === 2 ? new Y(l[0], l[1]) : r ? new Y(l[0], \"end\") : new Y(\"start\", l[0]);\n}\nfunction yt(t, n) {\n const e = kn(t), s = St(e, n);\n if (!s)\n return null;\n const i = On(t), r = St(\n i,\n n\n );\n return r ? s.size > r.size ? r.clipCurve(n) : s.clipCurve(n) : null;\n}\nconst W = (t) => M.isInstance(t) ? $(k(t.controlPoint, t.firstPoint)) + $(k(t.controlPoint, t.lastPoint)) : $(k(t.firstControlPoint, t.firstPoint)) + $(k(t.lastControlPoint, t.firstControlPoint)) + $(k(t.lastControlPoint, t.lastPoint));\nfunction D(t, n, e = 1e-9, { maxIterations: s = 100 } = {}) {\n const i = Math.max(e * e, Number.EPSILON * 10);\n let r = t, l = n, o = W(r), u = W(l);\n for (let a = 0; a < s; a++) {\n const f = o > i ? yt(l, r) : r;\n if (!f) return [];\n const c = W(f), h = u > i ? yt(f, l) : l;\n if (!h) return [];\n const p = W(h);\n if (c <= i && p <= i)\n return [\n f.boundingBox.intersection(h.boundingBox).center\n ];\n if (P(f.firstPoint, f.lastPoint) && h.isOnSegment(f.firstPoint))\n return [f.firstPoint];\n if (P(h.firstPoint, h.lastPoint) && f.isOnSegment(h.firstPoint))\n return [h.firstPoint];\n if (c > 0.8 * o && p > 0.8 * u)\n if (c / o > p / u) {\n const [d, m] = f.splitAtParameters([\n 0.5\n ]);\n return j(\n [\n ...D(d, h, e, {\n maxIterations: s - a\n }),\n ...D(m, h, e, {\n maxIterations: s - a\n })\n ],\n e\n );\n } else {\n const [d, m] = h.splitAtParameters([\n 0.5\n ]);\n return j(\n [\n ...D(f, d, e, {\n maxIterations: s - a\n }),\n ...D(f, m, e, {\n maxIterations: s - a\n })\n ],\n e\n );\n }\n r = f, l = h, o = c, u = p;\n }\n throw new Error(\"Bézier clip: Maximum number of iterations reached\");\n}\nfunction qn(t, n) {\n const e = [];\n if ([\n [t.firstPoint, n],\n [t.lastPoint, n],\n [n.firstPoint, t],\n [n.lastPoint, t]\n ].forEach(([i, r]) => {\n r.isOnSegment(i) && e.push(i);\n }), e.length < 2)\n return null;\n if (e.length === 2)\n return [t.splitAt(e)[1]];\n if (e.length === 3)\n return P(e[0], t.firstPoint) && P(e[1], t.lastPoint) ? [t] : [n];\n if (e.length === 4)\n return [t];\n}\nfunction zn(t, n, e = !1) {\n const s = Math.max(t.precision, n.precision);\n if (e) {\n const i = qn(t, n);\n if (i)\n return i;\n }\n return D(t, n, s);\n}\nfunction Dn(t, n) {\n const e = [];\n if ([\n [t.firstPoint, n],\n [t.lastPoint, n],\n [n.firstPoint, t],\n [n.lastPoint, t]\n ].forEach(([i, r]) => {\n r.isOnSegment(i) && e.push(i);\n }), e.length < 2)\n return null;\n if (e.length === 2)\n return [t.splitAt(e)[1]];\n if (e.length === 3)\n return P(e[0], t.firstPoint) && P(e[1], t.lastPoint) ? [t] : [n];\n if (e.length === 4)\n return [t];\n}\nfunction Rn(t, n, e = !1) {\n const s = Math.max(t.precision, n.precision);\n if (e) {\n const i = Dn(t, n);\n if (i)\n return i;\n }\n return D(t, n, s);\n}\nfunction Ie(t, n, e) {\n if (y.isInstance(t) && y.isInstance(n)) {\n const s = Vt(\n t,\n n,\n !1,\n e\n );\n return s === null ? [] : [s];\n }\n if (y.isInstance(t) && x.isInstance(n))\n return K(t, n, e);\n if (x.isInstance(t) && y.isInstance(n))\n return K(n, t, e);\n if (x.isInstance(t) && x.isInstance(n))\n return jt(t, n, !1, e);\n throw new Error(\"Not implemented\");\n}\nfunction Z(t, n, e) {\n if (y.isInstance(t) && y.isInstance(n)) {\n const s = Vt(\n t,\n n,\n !0,\n e\n );\n return s === null ? { intersections: [], overlaps: [], count: 0 } : y.isInstance(s) ? { intersections: [], overlaps: [s], count: 1 } : { intersections: [s], overlaps: [], count: 1 };\n }\n if (!t.boundingBox.overlaps(n.boundingBox))\n return { intersections: [], overlaps: [], count: 0 };\n if (y.isInstance(t) && x.isInstance(n)) {\n const s = K(t, n, e);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (x.isInstance(t) && y.isInstance(n)) {\n const s = K(n, t, e);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (x.isInstance(t) && x.isInstance(n)) {\n const s = jt(\n t,\n n,\n !0,\n e\n );\n return s.length ? x.isInstance(s[0]) ? {\n intersections: [],\n overlaps: s,\n count: s.length\n } : {\n intersections: s,\n overlaps: [],\n count: s.length\n } : { intersections: [], overlaps: [], count: 0 };\n }\n if (y.isInstance(t) && C.isInstance(n)) {\n const s = st(\n t,\n n,\n e\n );\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (y.isInstance(n) && C.isInstance(t)) {\n const s = st(\n n,\n t,\n e\n );\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (x.isInstance(t) && C.isInstance(n)) {\n const s = gt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (x.isInstance(n) && C.isInstance(t)) {\n const s = gt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (C.isInstance(t) && C.isInstance(n)) {\n const s = bn(\n t,\n n,\n !0\n );\n return s.length ? C.isInstance(s[0]) ? {\n intersections: [],\n overlaps: s,\n count: s.length\n } : {\n intersections: s,\n overlaps: [],\n count: s.length\n } : { intersections: [], overlaps: [], count: 0 };\n }\n if (y.isInstance(t) && (A.isInstance(n) || M.isInstance(n))) {\n const s = Pt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (y.isInstance(n) && (A.isInstance(t) || M.isInstance(t))) {\n const s = Pt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((x.isInstance(t) || C.isInstance(t)) && M.isInstance(n)) {\n const s = wt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((x.isInstance(n) || C.isInstance(n)) && M.isInstance(t)) {\n const s = wt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((x.isInstance(t) || C.isInstance(t)) && A.isInstance(n)) {\n const s = It(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((x.isInstance(n) || C.isInstance(n)) && A.isInstance(t)) {\n const s = It(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (M.isInstance(t) && M.isInstance(n)) {\n const s = Rn(\n t,\n n\n );\n return s.length ? M.isInstance(s[0]) ? {\n intersections: [],\n overlaps: s,\n count: s.length\n } : {\n intersections: s,\n overlaps: [],\n count: s.length\n } : { intersections: [], overlaps: [], count: 0 };\n }\n if (M.isInstance(t) && A.isInstance(n) || M.isInstance(n) && A.isInstance(t)) {\n const s = D(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (A.isInstance(t) && A.isInstance(n)) {\n const s = zn(\n t,\n n\n );\n return s.length ? A.isInstance(s[0]) ? {\n intersections: [],\n overlaps: s,\n count: s.length\n } : {\n intersections: s,\n overlaps: [],\n count: s.length\n } : { intersections: [], overlaps: [], count: 0 };\n }\n throw new Error(\"Not implemented\");\n}\nfunction $t(t) {\n const n = [];\n for (let e = 0; e < t; e++)\n for (let s = 0; s <= e; s++)\n n.push([e, s]);\n return n;\n}\nfunction* it(t) {\n for (const [n, e] of $t(t.length))\n n !== e && (yield [t[n], t[e]]);\n}\nclass Yt extends ut {\n constructor(e, { ignoreChecks: s = !1 } = {}) {\n super();\n b(this, \"segments\");\n b(this, \"_boundingBox\", null);\n s || Xt(e), this.segments = e;\n }\n get repr() {\n return this.segments.map((e) => e.repr).join(`\n`) + `\n`;\n }\n get info() {\n return this.repr;\n }\n get firstPoint() {\n return this.segments[0].firstPoint;\n }\n get lastPoint() {\n return this.segments[this.segments.length - 1].lastPoint;\n }\n get segmentsCount() {\n return this.segments.length;\n }\n onStroke(e) {\n return this.segments.some((s) => s.isOnSegment(e));\n }\n intersects(e) {\n return this.boundingBox.overlaps(e.boundingBox) ? this.segments.some(\n (s) => e.segments.some(\n (i) => Z(s, i).count > 0\n )\n ) : !1;\n }\n overlappingSegments(e) {\n return this.segments.flatMap((s) => e.segments.flatMap((i) => s.boundingBox.overlaps(i.boundingBox) ? Z(s, i).overlaps : []));\n }\n get boundingBox() {\n if (this._boundingBox === null) {\n let e = this.segments[0].boundingBox;\n this.segments.slice(1).forEach((s) => {\n e = e.merge(s.boundingBox);\n }), this._boundingBox = e;\n }\n return this._boundingBox;\n }\n [Symbol.for(\"nodejs.util.inspect.custom\")]() {\n return this.repr;\n }\n}\nfunction Nn(t, n = \"Stroke\") {\n $t(t.length).forEach(\n ([e, s]) => {\n if (e === s) return;\n const i = t[e], r = t[s], l = Z(i, r), o = Math.max(i.precision, r.precision);\n if (l.count !== 0) {\n if (l.count === 1 && !l.overlaps.length) {\n const u = e - s, a = l.intersections[0];\n if (u === 1 && P(i.firstPoint, a, o) || u === -1 && P(i.lastPoint, a, o) || u === t.length - 1 && P(i.lastPoint, a, o) && P(r.firstPoint, a, o) || -u === t.length - 1 && P(i.firstPoint, a, o) && P(r.lastPoint, a, o))\n return;\n }\n if (!(l.count === 2 && t.length === 2 && (P(\n i.firstPoint,\n l.intersections[0],\n o\n ) && P(\n i.lastPoint,\n l.intersections[1],\n o\n ) || P(\n i.firstPoint,\n l.intersections[1],\n o\n ) && P(\n i.lastPoint,\n l.intersections[0],\n o\n ))))\n throw new Error(\n `${n} segments must not intersect, but segments ${i.info} and ${r.info} do at ${JSON.stringify(\n l.intersections\n )}`\n );\n }\n }\n );\n}\nfunction Xt(t, n = \"Stroke\") {\n if (t.length === 0)\n throw new Error(`${n} must have at least one segment`);\n V([t.slice(0, -1), t.slice(1)]).forEach(\n ([e, s]) => {\n if (!P(e.lastPoint, s.firstPoint))\n throw new Error(\n `${n} segments must be connected, but ${e.info} and ${s.info} are not`\n );\n }\n ), Nn(t, n);\n}\nfunction bt(t, n) {\n return !!(y.isInstance(t) && y.isInstance(n) && dn(t.V, n.V) || x.isInstance(t) && x.isInstance(n) && P(t.center, n.center) && t.radius - n.radius < t.precision);\n}\nfunction Ct(t, n) {\n if (y.isInstance(t) && y.isInstance(n))\n return new y(t.firstPoint, n.lastPoint);\n if (x.isInstance(t) && x.isInstance(n))\n return new x(\n t.firstPoint,\n n.lastPoint,\n t.center,\n t.clockwise\n );\n throw new Error(\"Not implemented\");\n}\nfunction Gt(t) {\n let n = !1;\n const e = [];\n for (const s of t.segments) {\n if (e.length === 0) {\n e.push(s);\n continue;\n }\n const i = e[e.length - 1];\n bt(i, s) ? (n = !0, e.pop(), e.push(Ct(i, s))) : e.push(s);\n }\n if (P(t.firstPoint, t.lastPoint) && bt(\n e[0],\n e[e.length - 1]\n )) {\n n = !0;\n const s = e.pop();\n e[0] = Ct(s, e[0]);\n }\n return n ? e : null;\n}\nconst Mt = Symbol.for(\"pantograph:Strand\");\nclass B extends Yt {\n constructor(e, { ignoreChecks: s = !1 } = {}) {\n super(e, { ignoreChecks: s });\n b(this, \"strokeType\", \"STRAND\");\n Object.defineProperty(this, Mt, { value: !0 });\n }\n static isInstance(e) {\n return !!e && e[Mt] === !0;\n }\n reverse() {\n const e = this.segments.map((s) => s.reverse());\n return e.reverse(), new B(e, { ignoreChecks: !0 });\n }\n clone() {\n return new B(\n this.segments.map((e) => e.clone()),\n { ignoreChecks: !0 }\n );\n }\n extend(e) {\n if (!P(this.lastPoint, e.firstPoint))\n throw console.error(this.repr, e.repr), new Error(\"Cannot extend strand: connection point is not the same\");\n return new B([...this.segments, ...e.segments]);\n }\n simplify() {\n const e = Gt(this);\n return e ? new B(e, { ignoreChecks: !0 }) : this;\n }\n transform(e) {\n return new B(\n this.segments.map((s) => s.transform(e)),\n { ignoreChecks: !0 }\n );\n }\n}\nconst Vn = (t, n) => {\n const e = mn(n, {\n V: [1, 0],\n firstPoint: t,\n precision: n.precision\n });\n if (e === \"parallel\")\n return 0;\n const { intersectionParam1: s, intersectionParam2: i } = e;\n if (!n.isValidParameter(s) || i <= -n.precision) return 0;\n if (Math.abs(s) < n.precision || Math.abs(s - 1) < n.precision) {\n const [, r] = n.midPoint;\n return t[1] - r < 0 ? 1 : 0;\n }\n return 1;\n};\nclass at {\n constructor(n) {\n b(this, \"_count\", 0);\n b(this, \"segment\");\n this.segment = n;\n }\n update(n, e = !1) {\n !e && !this.segment.isOnSegment(n) || (P(n, this.segment.firstPoint) ? this._count += this.segment.tangentAtFirstPoint[1] > 0 ? 1 : 0 : P(n, this.segment.lastPoint) ? this._count += this.segment.tangentAtLastPoint[1] > 0 ? 0 : 1 : this._count += 1);\n }\n get count() {\n return this._count;\n }\n}\nconst jn = (t, n) => {\n const e = n.precision, s = Math.abs(t[1] - n.center[1]);\n if (s > n.radius + e) return 0;\n const i = gn(t, n.center), r = n.radius * n.radius, l = e * e;\n if (Math.abs(i - r) < l && n.isOnSegment(t))\n return 0;\n const o = i - r > l;\n if (o && n.center[0] < t[0]) return 0;\n const u = Math.sqrt(\n n.radius * n.radius - s * s\n ), a = new at(n);\n return a.update([n.center[0] + u, t[1]]), o && a.update([n.center[0] - u, t[1]]), a.count;\n}, Un = (t, n) => {\n const e = n.boundingBox.xMax + n.boundingBox.width / 2, s = new y(t, [e, t[1]]), i = new at(n);\n return st(s, n).forEach((r) => {\n i.update(r, !0);\n }), i.count;\n}, Hn = (t, n) => {\n const e = new at(n);\n return n.paramsAtY(t[1]).map((s) => {\n try {\n return n.paramPoint(s);\n } catch {\n return null;\n }\n }).filter((s) => s !== null).filter((s) => {\n const [i] = s;\n return i >= t[0];\n }).forEach((s) => {\n e.update(s, !0);\n }), e.count;\n};\nfunction $n(t, n) {\n if (y.isInstance(n))\n return Vn(t, n);\n if (x.isInstance(n))\n return jn(t, n);\n if (C.isInstance(n))\n return Un(t, n);\n if (A.isInstance(n) || M.isInstance(n))\n return Hn(t, n);\n throw new Error(\"Not implemented\");\n}\nconst At = Symbol.for(\"pantograph:Loop\");\nclass _ extends Yt {\n constructor(e, { ignoreChecks: s = !1 } = {}) {\n super(e, { ignoreChecks: !0 });\n b(this, \"strokeType\", \"LOOP\");\n b(this, \"_clockwise\", null);\n Object.defineProperty(this, At, { value: !0 }), s || Yn(e);\n }\n static isInstance(e) {\n return !!e && e[At] === !0;\n }\n get clockwise() {\n if (this._clockwise === null) {\n const e = this.segments.flatMap((i) => y.isInstance(i) ? [i.firstPoint] : [i.firstPoint, i.paramPoint(0.5)]), s = e.map((i, r) => {\n const l = e[(r + 1) % e.length];\n return (l[0] - i[0]) * (l[1] + i[1]);\n }).reduce((i, r) => i + r, 0);\n this._clockwise = s > 0;\n }\n return this._clockwise;\n }\n clone() {\n return new _(\n this.segments.map((e) => e.clone()),\n { ignoreChecks: !0 }\n );\n }\n reverse() {\n const e = this.segments.map((s) => s.reverse());\n return e.reverse(), new _(e, { ignoreChecks: !0 });\n }\n transform(e) {\n return new _(\n this.segments.map((s) => s.transform(e)),\n { ignoreChecks: !0 }\n );\n }\n contains(e, { strokeIsInside: s = !1 } = {}) {\n return this.onStroke(e) ? s : this.boundingBox.contains(e) ? this.segments.reduce((r, l) => r + $n(e, l), 0) % 2 === 1 : !1;\n }\n simplify() {\n const e = Gt(this);\n return e ? new _(e, { ignoreChecks: !0 }) : this;\n }\n}\nfunction Yn(t) {\n if (Xt(t, \"Loop\"), !P(t[0].firstPoint, t[t.length - 1].lastPoint))\n throw new Error(\"Loop segment must be closed\");\n}\nconst Xn = [\n y,\n x,\n C,\n M,\n A\n];\nfunction Gn(t) {\n return Xn.some((n) => n.isInstance(t));\n}\nfunction Qt(t) {\n if (y.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint\n };\n if (x.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n center: t.center,\n clockwise: t.clockwise\n };\n if (C.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n center: t.center,\n clockwise: t.clockwise,\n majorRadius: t.majorRadius,\n minorRadius: t.minorRadius,\n tiltAngle: t.tiltAngle\n };\n if (M.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n controlPoint: t.controlPoint\n };\n if (A.isInstance(t))\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n firstControlPoint: t.firstControlPoint,\n lastControlPoint: t.lastControlPoint\n };\n throw new Error(\"Unknown segment type\");\n}\nfunction rt(t) {\n return {\n type: \"LOOP\",\n segments: t.segments.map(Qt)\n };\n}\nfunction Wt(t) {\n return {\n type: \"FIGURE\",\n contour: rt(t.contour),\n holes: t.holes.map(rt)\n };\n}\nfunction Qn(t) {\n return {\n type: \"DIAGRAM\",\n figures: t.figures.map(Wt)\n };\n}\nfunction Et(t) {\n if (O.isInstance(t))\n return Qn(t);\n if (v.isInstance(t))\n return Wt(t);\n if (_.isInstance(t))\n return rt(t);\n if (Gn(t))\n return Qt(t);\n throw new Error(\"Unknown shape type\");\n}\nclass Wn {\n constructor() {\n this.ids = [], this.values = [], this.length = 0;\n }\n clear() {\n this.length = 0;\n }\n push(n, e) {\n let s = this.length++;\n for (; s > 0; ) {\n const i = s - 1 >> 1, r = this.values[i];\n if (e >= r) break;\n this.ids[s] = this.ids[i], this.values[s] = r, s = i;\n }\n this.ids[s] = n, this.values[s] = e;\n }\n pop() {\n if (this.length === 0) return;\n const n = this.ids[0];\n if (this.length--, this.length > 0) {\n const e = this.ids[0] = this.ids[this.length], s = this.values[0] = this.values[this.length], i = this.length >> 1;\n let r = 0;\n for (; r < i; ) {\n let l = (r << 1) + 1;\n const o = l + 1;\n let u = this.ids[l], a = this.values[l];\n const f = this.values[o];\n if (o < this.length && f < a && (l = o, u = this.ids[o], a = f), a >= s) break;\n this.ids[r] = u, this.values[r] = a, r = l;\n }\n this.ids[r] = e, this.values[r] = s;\n }\n return n;\n }\n peek() {\n if (this.length !== 0)\n return this.ids[0];\n }\n peekValue() {\n if (this.length !== 0)\n return this.values[0];\n }\n shrink() {\n this.ids.length = this.values.length = this.length;\n }\n}\nconst Ft = [Int8Array, Uint8Array, Uint8ClampedArray, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array], et = 3;\nclass ft {\n /**\n * Recreate a Flatbush index from raw `ArrayBuffer` or `SharedArrayBuffer` data.\n * @param {ArrayBuffer | SharedArrayBuffer} data\n * @param {number} [byteOffset=0] byte offset to the start of the Flatbush buffer in the referenced ArrayBuffer.\n * @returns {Flatbush} index\n */\n static from(n, e = 0) {\n if (e % 8 !== 0)\n throw new Error(\"byteOffset must be 8-byte aligned.\");\n if (!n || n.byteLength === void 0 || n.buffer)\n throw new Error(\"Data must be an instance of ArrayBuffer or SharedArrayBuffer.\");\n const [s, i] = new Uint8Array(n, e + 0, 2);\n if (s !== 251)\n throw new Error(\"Data does not appear to be in a Flatbush format.\");\n const r = i >> 4;\n if (r !== et)\n throw new Error(`Got v${r} data when expected v${et}.`);\n const l = Ft[i & 15];\n if (!l)\n throw new Error(\"Unrecognized array type.\");\n const [o] = new Uint16Array(n, e + 2, 1), [u] = new Uint32Array(n, e + 4, 1);\n return new ft(u, o, l, void 0, n, e);\n }\n /**\n * Create a Flatbush index that will hold a given number of items.\n * @param {number} numItems\n * @param {number} [nodeSize=16] Size of the tree node (16 by default).\n * @param {TypedArrayConstructor} [ArrayType=Float64Array] The array type used for coordinates storage (`Float64Array` by default).\n * @param {ArrayBufferConstructor | SharedArrayBufferConstructor} [ArrayBufferType=ArrayBuffer] The array buffer type used to store data (`ArrayBuffer` by default).\n * @param {ArrayBuffer | SharedArrayBuffer} [data] (Only used internally)\n * @param {number} [byteOffset=0] (Only used internally)\n */\n constructor(n, e = 16, s = Float64Array, i = ArrayBuffer, r, l = 0) {\n if (n === void 0) throw new Error(\"Missing required argument: numItems.\");\n if (isNaN(n) || n <= 0) throw new Error(`Unexpected numItems value: ${n}.`);\n this.numItems = +n, this.nodeSize = Math.min(Math.max(+e, 2), 65535), this.byteOffset = l;\n let o = n, u = o;\n this._levelBounds = [o * 4];\n do\n o = Math.ceil(o / this.nodeSize), u += o, this._levelBounds.push(u * 4);\n while (o !== 1);\n this.ArrayType = s, this.IndexArrayType = u < 16384 ? Uint16Array : Uint32Array;\n const a = Ft.indexOf(this.ArrayType), f = u * 4 * this.ArrayType.BYTES_PER_ELEMENT;\n if (a < 0)\n throw new Error(`Unexpected typed array class: ${s}.`);\n r && r.byteLength !== void 0 && !r.buffer ? (this.data = r, this._boxes = new this.ArrayType(this.data, l + 8, u * 4), this._indices = new this.IndexArrayType(this.data, l + 8 + f, u), this._pos = u * 4, this.minX = this._boxes[this._pos - 4], this.minY = this._boxes[this._pos - 3], this.maxX = this._boxes[this._pos - 2], this.maxY = this._boxes[this._pos - 1]) : (this.data = new i(8 + f + u * this.IndexArrayType.BYTES_PER_ELEMENT), this._boxes = new this.ArrayType(this.data, 8, u * 4), this._indices = new this.IndexArrayType(this.data, 8 + f, u), this._pos = 0, this.minX = 1 / 0, this.minY = 1 / 0, this.maxX = -1 / 0, this.maxY = -1 / 0, new Uint8Array(this.data, 0, 2).set([251, (et << 4) + a]), new Uint16Array(this.data, 2, 1)[0] = e, new Uint32Array(this.data, 4, 1)[0] = n), this._queue = new Wn();\n }\n /**\n * Add a given rectangle to the index.\n * @param {number} minX\n * @param {number} minY\n * @param {number} maxX\n * @param {number} maxY\n * @returns {number} A zero-based, incremental number that represents the newly added rectangle.\n */\n add(n, e, s = n, i = e) {\n const r = this._pos >> 2, l = this._boxes;\n return this._indices[r] = r, l[this._pos++] = n, l[this._pos++] = e, l[this._pos++] = s, l[this._pos++] = i, n < this.minX && (this.minX = n), e < this.minY && (this.minY = e), s > this.maxX && (this.maxX = s), i > this.maxY && (this.maxY = i), r;\n }\n /** Perform indexing of the added rectangles. */\n finish() {\n if (this._pos >> 2 !== this.numItems)\n throw new Error(`Added ${this._pos >> 2} items when expected ${this.numItems}.`);\n const n = this._boxes;\n if (this.numItems <= this.nodeSize) {\n n[this._pos++] = this.minX, n[this._pos++] = this.minY, n[this._pos++] = this.maxX, n[this._pos++] = this.maxY;\n return;\n }\n const e = this.maxX - this.minX || 1, s = this.maxY - this.minY || 1, i = new Uint32Array(this.numItems), r = 65535;\n for (let l = 0, o = 0; l < this.numItems; l++) {\n const u = n[o++], a = n[o++], f = n[o++], c = n[o++], h = Math.floor(r * ((u + f) / 2 - this.minX) / e), p = Math.floor(r * ((a + c) / 2 - this.minY) / s);\n i[l] = Kn(h, p);\n }\n ot(i, n, this._indices, 0, this.numItems - 1, this.nodeSize);\n for (let l = 0, o = 0; l < this._levelBounds.length - 1; l++) {\n const u = this._levelBounds[l];\n for (; o < u; ) {\n const a = o;\n let f = n[o++], c = n[o++], h = n[o++], p = n[o++];\n for (let d = 1; d < this.nodeSize && o < u; d++)\n f = Math.min(f, n[o++]), c = Math.min(c, n[o++]), h = Math.max(h, n[o++]), p = Math.max(p, n[o++]);\n this._indices[this._pos >> 2] = a, n[this._pos++] = f, n[this._pos++] = c, n[this._pos++] = h, n[this._pos++] = p;\n }\n }\n }\n /**\n * Search the index by a bounding box.\n * @param {number} minX\n * @param {number} minY\n * @param {number} maxX\n * @param {number} maxY\n * @param {(index: number) => boolean} [filterFn] An optional function for filtering the results.\n * @returns {number[]} An array of indices of items intersecting or touching the given bounding box.\n */\n search(n, e, s, i, r) {\n if (this._pos !== this._boxes.length)\n throw new Error(\"Data not yet indexed - call index.finish().\");\n let l = this._boxes.length - 4;\n const o = [], u = [];\n for (; l !== void 0; ) {\n const a = Math.min(l + this.nodeSize * 4, Bt(l, this._levelBounds));\n for (let f = l; f < a; f += 4) {\n if (s < this._boxes[f] || i < this._boxes[f + 1] || n > this._boxes[f + 2] || e > this._boxes[f + 3]) continue;\n const c = this._indices[f >> 2] | 0;\n l >= this.numItems * 4 ? o.push(c) : (r === void 0 || r(c)) && u.push(c);\n }\n l = o.pop();\n }\n return u;\n }\n /**\n * Search items in order of distance from the given point.\n * @param {number} x\n * @param {number} y\n * @param {number} [maxResults=Infinity]\n * @param {number} [maxDistance=Infinity]\n * @param {(index: number) => boolean} [filterFn] An optional function for filtering the results.\n * @returns {number[]} An array of indices of items found.\n */\n neighbors(n, e, s = 1 / 0, i = 1 / 0, r) {\n if (this._pos !== this._boxes.length)\n throw new Error(\"Data not yet indexed - call index.finish().\");\n let l = this._boxes.length - 4;\n const o = this._queue, u = [], a = i * i;\n t: for (; l !== void 0; ) {\n const f = Math.min(l + this.nodeSize * 4, Bt(l, this._levelBounds));\n for (let c = l; c < f; c += 4) {\n const h = this._indices[c >> 2] | 0, p = vt(n, this._boxes[c], this._boxes[c + 2]), d = vt(e, this._boxes[c + 1], this._boxes[c + 3]), m = p * p + d * d;\n m > a || (l >= this.numItems * 4 ? o.push(h << 1, m) : (r === void 0 || r(h)) && o.push((h << 1) + 1, m));\n }\n for (; o.length && o.peek() & 1; )\n if (o.peekValue() > a || (u.push(o.pop() >> 1), u.length === s)) break t;\n l = o.length ? o.pop() >> 1 : void 0;\n }\n return o.clear(), u;\n }\n}\nfunction vt(t, n, e) {\n return t < n ? n - t : t <= e ? 0 : t - e;\n}\nfunction Bt(t, n) {\n let e = 0, s = n.length - 1;\n for (; e < s; ) {\n const i = e + s >> 1;\n n[i] > t ? s = i : e = i + 1;\n }\n return n[e];\n}\nfunction ot(t, n, e, s, i, r) {\n if (Math.floor(s / r) >= Math.floor(i / r)) return;\n const l = t[s + i >> 1];\n let o = s - 1, u = i + 1;\n for (; ; ) {\n do\n o++;\n while (t[o] < l);\n do\n u--;\n while (t[u] > l);\n if (o >= u) break;\n Jn(t, n, e, o, u);\n }\n ot(t, n, e, s, u, r), ot(t, n, e, u + 1, i, r);\n}\nfunction Jn(t, n, e, s, i) {\n const r = t[s];\n t[s] = t[i], t[i] = r;\n const l = 4 * s, o = 4 * i, u = n[l], a = n[l + 1], f = n[l + 2], c = n[l + 3];\n n[l] = n[o], n[l + 1] = n[o + 1], n[l + 2] = n[o + 2], n[l + 3] = n[o + 3], n[o] = u, n[o + 1] = a, n[o + 2] = f, n[o + 3] = c;\n const h = e[s];\n e[s] = e[i], e[i] = h;\n}\nfunction Kn(t, n) {\n let e = t ^ n, s = 65535 ^ e, i = 65535 ^ (t | n), r = t & (n ^ 65535), l = e | s >> 1, o = e >> 1 ^ e, u = i >> 1 ^ s & r >> 1 ^ i, a = e & i >> 1 ^ r >> 1 ^ r;\n e = l, s = o, i = u, r = a, l = e & e >> 2 ^ s & s >> 2, o = e & s >> 2 ^ s & (e ^ s) >> 2, u ^= e & i >> 2 ^ s & r >> 2, a ^= s & i >> 2 ^ (e ^ s) & r >> 2, e = l, s = o, i = u, r = a, l = e & e >> 4 ^ s & s >> 4, o = e & s >> 4 ^ s & (e ^ s) >> 4, u ^= e & i >> 4 ^ s & r >> 4, a ^= s & i >> 4 ^ (e ^ s) & r >> 4, e = l, s = o, i = u, r = a, u ^= e & i >> 8 ^ s & r >> 8, a ^= s & i >> 8 ^ (e ^ s) & r >> 8, e = u ^ u >> 1, s = a ^ a >> 1;\n let f = t ^ n, c = s | 65535 ^ (f | e);\n return f = (f | f << 8) & 16711935, f = (f | f << 4) & 252645135, f = (f | f << 2) & 858993459, f = (f | f << 1) & 1431655765, c = (c | c << 8) & 16711935, c = (c | c << 4) & 252645135, c = (c | c << 2) & 858993459, c = (c | c << 1) & 1431655765, (c << 1 | f) >>> 0;\n}\nfunction Jt(t, n = 1e-7) {\n if (t.length === 0) return [];\n if (t.length === 1) return [t];\n const e = new ft(t.length);\n t.forEach((r) => {\n const [l, o] = r.firstPoint;\n e.add(l - n, o - n, l + n, o + n);\n }), e.finish();\n const s = [], i = /* @__PURE__ */ new Set();\n return t.forEach((r, l) => {\n if (i.has(l)) return;\n const o = [r];\n let u = l;\n i.add(l);\n let a = t.length;\n for (; ; ) {\n if (a-- < 0)\n throw new Error(\"Infinite loop detected\");\n const f = o[o.length - 1].lastPoint, [c, h] = f, p = e.search(\n c - n,\n h - n,\n c + n,\n h + n\n ), d = (I) => Math.abs((u - I) % t.length), m = p.filter((I) => !i.has(I)).map((I) => [\n t[I],\n I,\n d(I)\n ]).sort(([, , I], [, , F]) => d(I) - d(F));\n if (m.length === 0) {\n s.push(o);\n break;\n }\n const [w, g] = m[0];\n o.push(w), i.add(g), u = g;\n }\n }), s;\n}\nconst kt = Symbol.for(\"pantograph:Figure\");\nclass v extends ut {\n constructor(e, s = [], { ignoreChecks: i = !1 } = {}) {\n super();\n b(this, \"contour\");\n b(this, \"holes\");\n Object.defineProperty(this, kt, { value: !0 }), i || Zn(e, s), this.contour = e, this.holes = s;\n }\n static isInstance(e) {\n return !!e && e[kt] === !0;\n }\n get boundingBox() {\n return this.contour.boundingBox;\n }\n get isFull() {\n return this.holes.length === 0;\n }\n get allLoops() {\n return [this.contour, ...this.holes];\n }\n clone() {\n return new v(\n this.contour.clone(),\n this.holes.map((e) => e.clone())\n );\n }\n transform(e) {\n return new v(\n this.contour.transform(e),\n this.holes.map((s) => s.transform(e))\n );\n }\n contains(e, { strokeIsInside: s = !1 } = {}) {\n return this.contour.contains(e, { strokeIsInside: s }) && !this.holes.some((i) => i.contains(e, { strokeIsInside: s }));\n }\n intersects(e) {\n return this.allLoops.some(\n (s) => e.allLoops.some((i) => s.intersects(i))\n );\n }\n overlappingStrands(e) {\n const s = v.isInstance(e) ? e.allLoops : [e], i = this.allLoops.flatMap((r) => s.flatMap((l) => r.overlappingSegments(l)));\n return Jt(i).map((r) => new B(r));\n }\n}\nfunction Zn(t, n = []) {\n if (!t) throw new Error(\"Figure must have a contour\");\n for (const [e, s] of it([t, ...n]))\n if (e.intersects(s))\n throw new Error(\"Loops in a figure must not intersect\");\n if (n.some(\n (e) => !t.contains(e.firstPoint) && !t.onStroke(e.firstPoint)\n ))\n throw new Error(\"Holes must be inside the contour\");\n for (const [e, s] of it(n))\n if (e.contains(s.firstPoint))\n throw console.error(Et(e), Et(s)), new Error(\"Holes must not be inside other holes\");\n}\nconst J = (t, n, e = 1e-7) => Math.abs(t - n) <= e, te = (t, n) => {\n const e = t.boundingBox, s = n.boundingBox;\n return J(e.xMin, s.xMin) && J(e.yMin, s.yMin) && J(e.xMax, s.xMax) && J(e.yMax, s.yMax);\n}, ne = (t, n) => {\n if (t.segmentsCount !== n.segmentsCount || !te(t, n)) return !1;\n const e = t.segments, s = n.segments, i = e.length, r = (l, o) => {\n for (let u = 0; u < i; u += 1) {\n const a = (l + o * u + i) % i;\n if (!e[u].isSame(s[a])) return !1;\n }\n return !0;\n };\n for (let l = 0; l < i; l += 1)\n if (e[0].isSame(s[l]) && (r(l, 1) || r(l, -1)))\n return !0;\n return !1;\n}, ee = (t) => {\n const n = [];\n return t.forEach((e) => {\n n.some((s) => ne(e, s)) || n.push(e);\n }), n;\n}, se = (t) => {\n const n = t.map((i, r) => t.slice(r + 1).map((l, o) => [o + r + 1, l]).filter(([, l]) => i.boundingBox.overlaps(l.boundingBox)).map(([l]) => l)), e = [], s = Array(n.length);\n return n.forEach((i, r) => {\n let l = s[r];\n l || (l = [], e.push(l)), l.push(t[r]), i.length && i.forEach((o) => {\n s[o] = l;\n });\n }), e;\n}, Kt = (t) => t.map((n, e) => {\n const i = n.segments[0].midPoint, r = t.filter((l, o) => e === o ? !1 : l.contains(i));\n return {\n loop: n,\n isIn: r\n };\n}), ie = (t, n) => t.flatMap(({ loop: e }) => ht(\n n.filter(\n ({ loop: s, isIn: i }) => s === e || i.indexOf(e) !== -1\n )\n)), re = (t, n) => {\n const e = n.filter(({ isIn: i }) => i.length <= 1), s = ht(\n Kt(t.map(({ loop: i }) => i))\n );\n return [e, ...s];\n}, ht = (t) => {\n if (!t.length) return [];\n const n = t.filter(({ isIn: s }) => !s.length), e = t.filter(({ isIn: s }) => s.length > 1);\n return n.length === 1 && e.length === 0 ? [t] : n.length > 1 ? ie(n, t) : re(e, t);\n};\nfunction X(t) {\n const n = ee(t);\n return se(n).map(Kt).flatMap(ht).map((s) => {\n if (s.length === 1) return new v(s[0].loop);\n s.sort((l, o) => l.isIn.length - o.isIn.length);\n const [i, ...r] = s.map(({ loop: l }) => l);\n return new v(i, r);\n });\n}\nfunction oe(t, n) {\n const e = [];\n for (const s of t)\n for (const i of n)\n e.push([s, i]);\n return e;\n}\nfunction* Ot(t, n, e) {\n const s = (o) => n.some((u) => P(u, o.lastPoint)), i = (o, u) => o.segmentType !== u.segmentType || !u.isOnSegment(o.firstPoint) || !u.isOnSegment(o.lastPoint) ? !1 : o.segmentType !== \"LINE\" ? u.isOnSegment(o.midPoint) : !0, r = (o) => e.some((u) => o.isSame(u) || i(o, u));\n let l = [];\n for (const o of t)\n s(o) ? (l.push(o), yield new B(l, { ignoreChecks: !0 }), l = []) : r(o) ? (l.length && (yield new B(l, { ignoreChecks: !0 }), l = []), yield new B([o], { ignoreChecks: !0 })) : l.push(o);\n l.length && (yield new B(l, { ignoreChecks: !0 }));\n}\nconst _t = (t, n) => {\n const e = t.findIndex((r) => P(n, r.firstPoint)), s = t.slice(0, e);\n return t.slice(e).concat(s);\n}, Tt = (t, n) => {\n let e = t;\n const s = (o) => P(o.firstPoint, n.firstPoint) && P(o.lastPoint, n.lastPoint);\n let i = t.findIndex(s);\n if (i === -1) {\n const o = t.map((u) => u.reverse());\n if (o.reverse(), i = o.findIndex(s), i === -1)\n throw console.error(\n o.map((u) => u.repr),\n n.repr\n ), new Error(\"Failed to rotate to segment start\");\n e = o;\n }\n const r = e.slice(0, i);\n return e.slice(i).concat(r);\n};\nfunction le(t, n, e) {\n return t.filter((s) => {\n const i = n.filter((o) => P(o.firstPoint, s) || P(o.lastPoint, s));\n if (i.length % 2)\n throw new Error(\"Bug in the intersection algo on non crossing point\");\n const r = i.map((o) => e.contains(o.midPoint));\n return !(r.every((o) => o) || !r.some((o) => o));\n });\n}\nfunction ue(t, n, e, s = !1) {\n let i = [];\n const r = [], l = new Array(t.segments.length).fill(0).map(() => []), o = new Array(n.segments.length).fill(0).map(() => []);\n if (t.segments.forEach((p, d) => {\n n.segments.forEach((m, w) => {\n const { intersections: g, overlaps: I } = Z(\n p,\n m,\n e\n );\n i.push(...g), l[d].push(...g), o[w].push(...g), r.push(...I);\n const F = I.flatMap((S) => [\n S.firstPoint,\n S.lastPoint\n ]);\n i.push(...F), l[d].push(...F), o[w].push(...F);\n });\n }), i = j(i, e), !i.length || i.length === 1) return null;\n const u = ([p, d]) => d.length ? p.splitAt(d) : [p];\n let a = V([t.segments, l]).flatMap(u), f = V([n.segments, o]).flatMap(u);\n if (i = le(\n i,\n a,\n n\n ), !i.length && !r.length) return null;\n if (r.length) {\n const p = r[0];\n a = Tt(\n a,\n p\n ), f = Tt(\n f,\n p\n );\n } else {\n const p = i[0];\n a = _t(a, p), f = _t(f, p);\n }\n let c = Array.from(\n Ot(\n a,\n i,\n r\n )\n ), h = Array.from(\n Ot(\n f,\n i,\n r\n )\n );\n return (!P(\n h[0].lastPoint,\n c[0].lastPoint\n ) || r.length > 0 && h[0].segmentsCount !== 1) && (h = h.map((p) => p.reverse()).reverse(), P(h[0].lastPoint, c[0].lastPoint) || (c = c.map((p) => p.reverse()).reverse())), V([c, h]).map(([p, d]) => {\n if (s) {\n if (((w) => w.segments.every(\n (g) => r.some(\n (I) => g.isSame(I) || g.segmentType === I.segmentType && I.isOnSegment(g.firstPoint) && I.isOnSegment(g.lastPoint) && (g.segmentType === \"LINE\" || I.isOnSegment(g.midPoint))\n )\n ))(p))\n return [p, \"same\"];\n } else if (p.segmentsCount === 1 && r.some((m) => p.segments[0].isSame(m)))\n return [p, \"same\"];\n return [p, d];\n });\n}\nfunction Lt(t) {\n let n = t[0];\n for (const e of t.slice(1))\n n = n.extend(e);\n if (!P(n.firstPoint, n.lastPoint))\n throw console.error(\n mt(n.firstPoint),\n mt(n.lastPoint)\n ), new Error(\"Bug in the intersection algo on non closing strand\");\n return new _(n.segments);\n}\nfunction ce(t, n) {\n const e = V([\n n.slice(0, -1),\n n.slice(1)\n ]).map(([i, r]) => Lt(t.slice(i, r)));\n let s = t.slice(\n n[n.length - 1]\n );\n return n[0] !== 0 && (s = s.concat(t.slice(0, n[0]))), e.push(Lt(s)), e;\n}\nfunction ae(t) {\n if (!t.length) return [];\n const n = t.map((i) => i.firstPoint);\n let e = t.map((i) => i.lastPoint);\n e = e.slice(-1).concat(e.slice(0, -1));\n const s = V([n, e]).flatMap(\n ([i, r], l) => P(i, r) ? [] : l\n );\n try {\n return ce(t, s);\n } catch {\n return Jt(t.flatMap((r) => r.segments)).filter((r) => r.length > 1).filter((r) => P(r[0].firstPoint, r.at(-1).lastPoint)).map((r) => new _(r));\n }\n}\nconst qt = (t, n) => {\n if (t.length === 0) return [n];\n const e = t.at(-1);\n return P(e.lastPoint, n.firstPoint) ? t.slice(0, -1).concat([e.extend(n)]) : P(e.lastPoint, n.lastPoint) ? t.slice(0, -1).concat([e.extend(n.reverse())]) : t.concat([n]);\n}, fe = (t, n) => t.length === 0 ? [n] : P(t[0].firstPoint, n.lastPoint) ? [n.extend(t[0])].concat(t.slice(1)) : [n].concat(t);\nfunction pt(t, n, {\n firstInside: e,\n secondInside: s,\n firstBoundaryInside: i = !1,\n secondBoundaryInside: r = !1\n}) {\n const l = ue(\n t,\n n,\n void 0,\n i || r\n );\n if (!l) {\n const f = t.segments[0].midPoint, c = n.contains(f, {\n strokeIsInside: r\n }), h = n.segments[0].midPoint, p = t.contains(h, {\n strokeIsInside: i\n });\n return {\n identical: !1,\n firstCurveInSecond: c,\n secondCurveInFirst: p\n };\n }\n if (l.every(([, f]) => f === \"same\"))\n return { identical: !0 };\n let o = null, u = null;\n const a = l.flatMap(([f, c]) => {\n let h = [], p = 0;\n if (c === \"same\")\n return u === 1 ? (u = 1, f) : u === 2 || u === 0 ? (u = null, []) : u === null ? (o ? o = o.extend(f) : o = f, []) : (console.error(\"weird situation\"), []);\n const d = f.segments[0].midPoint, m = n.contains(d, {\n strokeIsInside: r\n });\n (e === \"keep\" && m || e === \"remove\" && !m) && (p += 1, h = qt(h, f));\n const w = c.segments[0].midPoint, g = t.contains(w, {\n strokeIsInside: i\n });\n if (s === \"keep\" && g || s === \"remove\" && !g) {\n const I = c;\n p += 1, p === 2 && h.length ? (h = qt(h, I), o = null) : h = [I];\n }\n return u === null && p === 1 && o && (h = fe(h, o)), p === 1 && (u = p, o = null), h.length ? h : (o = null, []);\n });\n return ae(a);\n}\nconst he = (t, n, e) => {\n const s = pt(t, n, {\n firstInside: \"remove\",\n secondInside: \"remove\",\n ...e\n });\n return Array.isArray(s) ? s : s.identical ? [t] : s.firstCurveInSecond ? [n] : s.secondCurveInFirst ? [t] : [t, n];\n}, tt = (t, n, e) => {\n const s = pt(t, n, {\n firstInside: \"remove\",\n secondInside: \"keep\",\n ...e\n });\n return Array.isArray(s) ? s : s.identical ? [] : s.firstCurveInSecond ? [] : s.secondCurveInFirst ? [t, n] : [t];\n}, dt = (t, n, e) => {\n const s = (e == null ? void 0 : e.firstBoundaryInside) ?? !1, i = (e == null ? void 0 : e.secondBoundaryInside) ?? !1, r = s || i, l = (u, a, f) => u.segments.every(\n (c) => a.contains(c.midPoint, {\n strokeIsInside: f\n }) && a.contains(c.firstPoint, {\n strokeIsInside: f\n })\n );\n if (r) {\n if (l(t, n, i))\n return [t];\n if (l(n, t, s))\n return [n];\n }\n const o = pt(t, n, {\n firstInside: \"keep\",\n secondInside: \"keep\",\n ...e\n });\n return Array.isArray(o) ? o : o.identical ? [t] : o.firstCurveInSecond ? [t] : o.secondCurveInFirst ? [n] : [];\n};\nfunction pe(t) {\n const n = /* @__PURE__ */ new Map(), e = [];\n return t.forEach((s, i) => {\n let r;\n n.has(i) ? r = n.get(i) : (r = { current: [s], fusedWith: /* @__PURE__ */ new Set([i]) }, e.push(r)), t.slice(i + 1).forEach((l, o) => {\n const u = r.current, a = i + o + 1;\n if (r.fusedWith.has(a)) return;\n let f = [l], c = !1;\n if (n.has(a) && (f = n.get(a).current, c = !0), !u.some(\n (d) => f.some((m) => d.intersects(m))\n )) return;\n let p;\n u.length > 1 || f.length > 1 ? p = G(u, f) : p = Zt(u[0], f[0]), r.fusedWith.add(a), r.current = p, c || n.set(a, r);\n });\n }), e.flatMap(({ current: s }) => s);\n}\nfunction Zt(t, n) {\n const e = he(t.contour, n.contour), s = n.holes.flatMap((l) => tt(l, t.contour)), i = t.holes.flatMap((l) => tt(l, n.contour)), r = oe(t.holes, n.holes).flatMap(\n ([l, o]) => dt(l, o)\n );\n return X([\n ...e,\n ...s,\n ...i,\n ...r\n ]);\n}\nfunction nt(t, n) {\n if (t.isFull && n.isFull)\n return X(tt(t.contour, n.contour));\n if (t.isFull) {\n const s = tt(t.contour, n.contour), i = n.holes.flatMap(\n (r) => dt(r, t.contour, { firstBoundaryInside: !0 })\n );\n return X([...s, ...i]);\n } else if (n.isFull && !t.contour.intersects(n.contour))\n if (t.contour.contains(n.contour.firstPoint)) {\n const s = G(\n t.holes.map((i) => new v(i)),\n [n]\n );\n return X([\n t.contour,\n ...s.flatMap((i) => i.allLoops)\n ]);\n } else\n return [t];\n let e = nt(new v(t.contour), n);\n return t.holes.forEach((s) => {\n e = e.flatMap((i) => nt(i, new v(s)));\n }), e;\n}\nfunction de(t, n) {\n const e = dt(t.contour, n.contour);\n if (!e.length) return [];\n let s = X(e);\n return s = Q(\n s,\n t.holes.map((i) => new v(i))\n ), Q(\n s,\n n.holes.map((i) => new v(i))\n );\n}\nfunction G(t, n) {\n if (!t.length) return n;\n if (!n.length) return t;\n if (t.length === 1 && n.length > 1 || n.length === 1 && t.length > 1)\n return pe([...t, ...n]);\n if (t.length > 1 && n.length > 1) {\n let e = G([t[0]], n);\n return t.slice(1).forEach((s) => {\n e = G([s], e);\n }), e;\n }\n return t.length === 1 && n.length === 1 ? Zt(t[0], n[0]) : [];\n}\nfunction Q(t, n) {\n if (!t.length) return [];\n if (!n.length) return t;\n if (t.length === 1 && n.length === 1)\n return nt(t[0], n[0]);\n if (t.length > 1)\n return t.flatMap((s) => Q([s], n));\n let e = nt(t[0], n[0]);\n return n.slice(1).forEach((s) => {\n e = Q(e, [s]);\n }), e;\n}\nfunction lt(t, n) {\n return !t.length || !n.length ? [] : t.length === 1 && n.length === 1 ? de(t[0], n[0]) : t.length > 1 ? t.flatMap((e) => lt([e], n)) : n.flatMap((e) => lt(t, [e]));\n}\nconst zt = Symbol.for(\"pantograph:Diagram\");\nclass O extends ut {\n constructor(e = [], { ignoreChecks: s = !1 } = {}) {\n super();\n b(this, \"figures\");\n b(this, \"_boundingBox\", null);\n Object.defineProperty(this, zt, { value: !0 }), s || me(e), this.figures = e;\n }\n static isInstance(e) {\n return !!e && e[zt] === !0;\n }\n get isEmpty() {\n return this.figures.length === 0;\n }\n get boundingBox() {\n if (this.isEmpty) return new Pn();\n if (this._boundingBox === null) {\n let e = this.figures[0].boundingBox;\n for (const s of this.figures.slice(1))\n e = e.merge(s.boundingBox);\n this._boundingBox = e;\n }\n return this._boundingBox;\n }\n clone() {\n return new O(this.figures.map((e) => e.clone()));\n }\n transform(e) {\n return new O(this.figures.map((s) => s.transform(e)));\n }\n contains(e, { strokeIsInside: s = !1 } = {}) {\n return this.figures.some(\n (i) => i.contains(e, { strokeIsInside: s })\n );\n }\n intersects(e) {\n return this.figures.some(\n (s) => e.figures.some((i) => s.intersects(i))\n );\n }\n overlappingStrands(e) {\n return this.figures.flatMap((s) => O.isInstance(e) ? e.figures.flatMap(\n (i) => s.overlappingStrands(i)\n ) : s.overlappingStrands(e));\n }\n fuse(e) {\n return new O(G(this.figures, e.figures));\n }\n cut(e) {\n return new O(Q(this.figures, e.figures));\n }\n intersect(e) {\n return new O(lt(this.figures, e.figures));\n }\n}\nfunction me(t) {\n for (const [n, e] of it(t))\n if (n.intersects(e))\n throw new Error(\"Diagram figures must not intersect\");\n}\nexport {\n O as D,\n v as F,\n _ as L,\n B as S,\n Z as a,\n G as b,\n Q as c,\n jt as d,\n Jt as e,\n Ie as f,\n Gn as g,\n Et as h,\n lt as i,\n K as l,\n In as p,\n Ot as s\n};\n//# sourceMappingURL=models-DfOxeufK.js.map\n","var W = Object.defineProperty;\nvar j = (e, t, n) => t in e ? W(e, t, { enumerable: !0, configurable: !0, writable: !0, value: n }) : e[t] = n;\nvar m = (e, t, n) => j(e, typeof t != \"symbol\" ? t + \"\" : t, n);\nimport { a as l, s as u, c as b, b as P, L as d, A as z, Q as w, C as D, p as x, d as q, e as T, t as k, f as Q, g as v, h as $, i as H, j as J, R as K, T as U, k as A, n as F, D as S } from \"./QuadraticBezier-BeY2TXKH.js\";\nimport { f as X, S as Z, D as tt, F as nt, L as et } from \"./models-DfOxeufK.js\";\nconst B = (e, t, n) => {\n const r = b(e.V, t.V), i = e.precision * t.precision;\n if (r * r < i)\n return \"parallel\";\n const s = P(t.firstPoint, e.firstPoint), o = b(s, t.V) / r;\n return l(e.firstPoint, u(e.V, o));\n}, y = Symbol.for(\n \"pantograph:DegenerateSegment\"\n);\nclass C {\n constructor(t, n) {\n this.firstPoint = t, this.lastPoint = n, Object.defineProperty(this, y, { value: !0 });\n }\n static isInstance(t) {\n return !!t && t[y] === !0;\n }\n}\nfunction _(e, t) {\n if (d.isInstance(e))\n return rt(e, t);\n if (z.isInstance(e))\n return it(e, t);\n if (w.isInstance(e) || D.isInstance(e))\n return st(e, t);\n throw new Error(\"Not implemented\");\n}\nfunction rt(e, t) {\n const { firstPoint: n, lastPoint: r } = e, i = e.normalVector;\n return new d(\n l(n, u(i, t)),\n l(r, u(i, t))\n );\n}\nfunction it(e, t) {\n const n = l(\n e.firstPoint,\n u(x(e.tangentAtFirstPoint), t)\n ), r = l(\n e.lastPoint,\n u(x(e.tangentAtLastPoint), t)\n ), i = t * (e.clockwise ? 1 : -1);\n return e.radius + i < e.precision ? new C(n, r) : new z(n, r, e.center, e.clockwise);\n}\nfunction L(e, t, n, r, i) {\n const s = B(\n {\n V: n,\n firstPoint: r,\n precision: i\n },\n {\n V: P(t, e),\n firstPoint: e,\n precision: i\n }\n );\n if (s === \"parallel\")\n throw new Error(\n \"Parallel lines not expected in safe bezier offset control point calculation\"\n );\n return s;\n}\nfunction st(e, t) {\n const { firstPoint: n, lastPoint: r, normalAtFirstPoint: i, normalAtLastPoint: s } = e, o = B(\n { V: i, firstPoint: n, precision: e.precision },\n { V: s, firstPoint: r, precision: e.precision }\n ), a = l(\n n,\n u(i, t)\n ), c = l(\n r,\n u(s, t)\n );\n if (o === \"parallel\")\n throw new Error(\"Parallel lines not expected in safe bezier offset\");\n if (q(P(o, n), i) * t > 0 && Math.min(\n T(n, o),\n T(r, o)\n ) < t)\n return new C(a, c);\n if (w.isInstance(e)) {\n const f = L(\n o,\n e.controlPoint,\n e.tangentAtFirstPoint,\n a,\n e.precision\n );\n return new w(\n a,\n c,\n f\n );\n }\n const g = L(\n o,\n e.firstControlPoint,\n e.tangentAtFirstPoint,\n a,\n e.precision\n ), p = L(\n o,\n e.lastControlPoint,\n e.tangentAtLastPoint,\n c,\n e.precision\n );\n return new D(\n a,\n c,\n g,\n p\n );\n}\nfunction M(e, t, n) {\n const r = b(\n e.tangentAtLastPoint,\n t.tangentAtFirstPoint\n );\n if (Math.abs(r) < 1e-10) return null;\n const i = r > 0 ? 1 : -1, s = Math.abs(n) * i, o = _(e, s), a = _(t, s);\n if (C.isInstance(o) || C.isInstance(a))\n return null;\n let c;\n try {\n c = X(o, a, 1e-9).at(-1);\n } catch {\n return null;\n }\n if (!c)\n return null;\n const h = c, g = (E, N) => {\n const O = N.tangentAt(h), G = Q(O), Y = l(h, u(G, s));\n return E.splitAt(Y);\n }, [p] = g(e, o), [, f] = g(t, a);\n return { first: p, second: f, center: h };\n}\nfunction I(e, t, n) {\n const r = M(e, t, n);\n if (!r)\n return console.warn(\n \"Cannot fillet between segments\",\n e.repr,\n t.repr\n ), [e, t];\n const { first: i, second: s } = r;\n return [\n i,\n k(i.lastPoint, s.firstPoint, i.tangentAtLastPoint),\n s\n ];\n}\nfunction V(e, t, n) {\n const r = M(e, t, n);\n if (!r)\n return console.warn(\n \"Cannot chamfer between segments\",\n e.repr,\n t.repr\n ), [e, t];\n const { first: i, second: s } = r;\n return [i, new d(i.lastPoint, s.firstPoint), s];\n}\nconst ot = (e) => {\n let t;\n e ? typeof e == \"number\" || Array.isArray(e) && e.length === 2 ? t = { endTangent: e } : t = { endTangent: 0, ...e } : t = { endTangent: [1, 0] };\n const {\n endTangent: n,\n startFactor: r = 1,\n endFactor: i = 1,\n startTangent: s\n } = t;\n let o;\n typeof n == \"number\" ? o = A(1, n * S) : o = n;\n let a;\n return typeof s == \"number\" ? a = A(1, s * S) : a = s, { endTangent: o, startFactor: r, endFactor: i, startTangent: a };\n};\nfunction R(e, { ignoreChecks: t = !1 } = {}) {\n return new tt([new nt(new et([...e], { ignoreChecks: t }))]);\n}\nclass at {\n constructor(t = [0, 0]) {\n m(this, \"pointer\");\n m(this, \"firstPoint\");\n m(this, \"pendingSegments\");\n m(this, \"_nextCorner\");\n this.pointer = t, this.firstPoint = t, this.pendingSegments = [], this._nextCorner = null;\n }\n movePointerTo(t) {\n if (this.pendingSegments.length)\n throw new Error(\n \"You can only move the pointer if there is no segment defined\"\n );\n return this.pointer = t, this.firstPoint = t, this;\n }\n saveSegment(t) {\n if (v(t.firstPoint, t.lastPoint))\n throw new Error(`Segment has no length, ${t.repr}`);\n if (!this._nextCorner)\n return this.pendingSegments.push(t), this;\n const n = this.pendingSegments.pop();\n if (!n) throw new Error(\"bug in the custom corner algorithm\");\n const r = this._nextCorner.mode === \"chamfer\" ? V : I;\n return this.pendingSegments.push(\n ...r(n, t, this._nextCorner.radius)\n ), this._nextCorner = null, this;\n }\n lineTo(t) {\n const n = new d(this.pointer, t);\n return this.pointer = t, this.saveSegment(n);\n }\n line(t, n) {\n return this.lineTo([this.pointer[0] + t, this.pointer[1] + n]);\n }\n vLine(t) {\n return this.line(0, t);\n }\n hLine(t) {\n return this.line(t, 0);\n }\n vLineTo(t) {\n return this.lineTo([this.pointer[0], t]);\n }\n hLineTo(t) {\n return this.lineTo([t, this.pointer[1]]);\n }\n polarLineTo([t, n]) {\n const r = n * S, i = A(t, r);\n return this.lineTo(i);\n }\n polarLine(t, n) {\n const r = n * S, [i, s] = A(t, r);\n return this.line(i, s);\n }\n tangentLine(t) {\n const n = this.pendingSegments.at(-1);\n if (!n)\n throw new Error(\"You need a previous segment to sketch a tangent line\");\n const [r, i] = n.tangentAtLastPoint;\n return this.line(r * t, i * t);\n }\n threePointsArcTo(t, n) {\n return this.saveSegment($(this.pointer, n, t)), this.pointer = t, this;\n }\n threePointsArc(t, n, r, i) {\n const [s, o] = this.pointer;\n return this.threePointsArcTo(\n [s + t, o + n],\n [s + r, o + i]\n );\n }\n sagittaArcTo(t, n) {\n if (!n) return this.lineTo(t);\n const r = new d(this.pointer, t), i = x(r.tangentAtFirstPoint), s = l(r.midPoint, u(i, n));\n return this.threePointsArcTo(t, s);\n }\n sagittaArc(t, n, r) {\n return this.sagittaArcTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r\n );\n }\n vSagittaArc(t, n) {\n return this.sagittaArc(0, t, n);\n }\n hSagittaArc(t, n) {\n return this.sagittaArc(t, 0, n);\n }\n bulgeArcTo(t, n) {\n if (!n) return this.lineTo(t);\n const r = T(this.pointer, t) / 2, i = -n * r;\n return this.sagittaArcTo(t, i);\n }\n bulgeArc(t, n, r) {\n return this.bulgeArcTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r\n );\n }\n vBulgeArc(t, n) {\n return this.bulgeArc(0, t, n);\n }\n hBulgeArc(t, n) {\n return this.bulgeArc(t, 0, n);\n }\n tangentArcTo(t, n) {\n const r = this.pendingSegments.at(-1);\n if (!r)\n throw new Error(\"You need a previous curve to sketch a tangent arc\");\n return this.saveSegment(\n k(\n this.pointer,\n t,\n n ?? r.tangentAtLastPoint\n )\n ), this.pointer = t, this;\n }\n tangentArc(t, n, r) {\n const [i, s] = this.pointer;\n return this.tangentArcTo([t + i, n + s], r);\n }\n ellipseTo(t, n, r, i, s, o) {\n return this.saveSegment(\n H(this.pointer, t, n, r, i, s, o)\n ), this.pointer = t, this;\n }\n ellipse(t, n, r, i, s, o, a) {\n return this.ellipseTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r,\n i,\n s,\n o,\n a\n );\n }\n halfEllipseTo(t, n) {\n const [r, i] = J(P(t, this.pointer));\n return this.ellipseTo(\n t,\n r / 2,\n Math.abs(n),\n i * K,\n !0,\n n > 0\n );\n }\n halfEllipse(t, n, r) {\n return this.halfEllipseTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r\n );\n }\n cubicBezierCurveTo(t, n, r) {\n return this.saveSegment(\n new D(this.pointer, t, n, r)\n ), this.pointer = t, this;\n }\n quadraticBezierCurveTo(t, n) {\n return this.saveSegment(new w(this.pointer, t, n)), this.pointer = t, this;\n }\n smoothCurveTo(t, n) {\n const { endTangent: r, startTangent: i, startFactor: s, endFactor: o } = ot(n), a = this.pendingSegments.length ? this.pendingSegments[this.pendingSegments.length - 1] : null, c = T(this.pointer, t) / 3;\n let h;\n i ? h = i : a ? h = a.tangentAtLastPoint : h = [1, 0], h = F(h);\n const g = [\n this.pointer[0] + h[0] * s * c,\n this.pointer[1] + h[1] * s * c\n ];\n let p = r;\n p = F(p);\n const f = [\n t[0] - p[0] * o * c,\n t[1] - p[1] * o * c\n ];\n return this.cubicBezierCurveTo(t, g, f);\n }\n smoothCurve(t, n, r) {\n return this.smoothCurveTo(\n [t + this.pointer[0], n + this.pointer[1]],\n r\n );\n }\n customCorner(t, n = \"fillet\") {\n if (!this.pendingSegments.length)\n throw new Error(\"You need a segment defined to fillet the angle\");\n return t ? (this._nextCorner = { mode: n, radius: t }, this) : this;\n }\n _customCornerLastWithFirst(t, n = \"fillet\") {\n if (!t) return;\n const r = this.pendingSegments.pop(), i = this.pendingSegments.shift();\n if (!r || !i)\n throw new Error(\"Not enough curves to close and fillet\");\n const s = n === \"chamfer\" ? V : I;\n this.pendingSegments.push(...s(r, i, t));\n }\n close(t = !1) {\n if (!this.pendingSegments.length) throw new Error(\"No segments to close\");\n const n = this.pendingSegments[0], r = this.pendingSegments.at(-1);\n return v(n.firstPoint, r.lastPoint) || this.lineTo(n.firstPoint), this._nextCorner !== null && (this._customCornerLastWithFirst(\n this._nextCorner.radius,\n this._nextCorner.mode\n ), this._nextCorner = null), R(this.pendingSegments, { ignoreChecks: t });\n }\n closeWithMirror(t = !1) {\n if (!this.pendingSegments.length) throw new Error(\"No segments to close\");\n const n = this.pendingSegments[0], r = this.pendingSegments.at(-1), i = P(\n r.lastPoint,\n n.firstPoint\n ), s = new U().mirrorLine(\n i,\n n.firstPoint\n ), o = this.pendingSegments.map(\n (a) => a.transform(s).reverse()\n );\n return o.reverse(), R(\n [...this.pendingSegments, ...o],\n { ignoreChecks: t }\n );\n }\n asStrand() {\n return new Z([...this.pendingSegments]);\n }\n get isClosed() {\n var t;\n return v(this.pointer, (t = this.pendingSegments[0]) == null ? void 0 : t.firstPoint);\n }\n}\nfunction ut(e = [0, 0]) {\n return new at(e);\n}\nexport {\n C as D,\n at as a,\n V as c,\n ut as d,\n I as f,\n _ as o\n};\n//# sourceMappingURL=draw-DaKl45lJ.js.map\n","import { L as $, A as l, E as u, R as e, Q as f, C as h } from \"./QuadraticBezier-BeY2TXKH.js\";\nfunction o([t, n]) {\n return `${t} ${n}`;\n}\nfunction r(t) {\n if ($.isInstance(t))\n return `L ${o(t.lastPoint)}`;\n if (l.isInstance(t))\n return `A ${t.radius} ${t.radius} 0 ${t.angularLength > Math.PI ? \"1\" : \"0\"} ${t.clockwise ? \"0\" : \"1\"} ${o(t.lastPoint)}`;\n if (u.isInstance(t))\n return `A ${t.majorRadius} ${t.minorRadius} ${t.tiltAngle * e} ${t.deltaAngle > Math.PI ? \"1\" : \"0\"} ${t.clockwise ? \"0\" : \"1\"} ${o(t.lastPoint)}`;\n if (f.isInstance(t))\n return `Q ${[\n o(t.controlPoint),\n o(t.lastPoint)\n ].join(\" \")}`;\n if (h.isInstance(t))\n return `C ${[\n o(t.firstControlPoint),\n o(t.lastControlPoint),\n o(t.lastPoint)\n ].join(\" \")}`;\n throw new Error(\"Unknown segment type\");\n}\nfunction w(t) {\n const n = `M ${t.firstPoint.join(\" \")}`, i = t.segments.map(r).join(\" \");\n return `${n} ${i} Z`;\n}\nfunction p(t) {\n return `<path d=\"${t.allLoops.map(w).join(\" \")}\" />`;\n}\nfunction d(t) {\n return `<g>\n ${t.figures.map(p).join(`\n`)}\n</g>`;\n}\nfunction j(t) {\n const n = `M ${t.firstPoint.join(\" \")}`, i = t.segments.map(r).join(\" \");\n return `${n} ${i}`;\n}\nfunction v(t, n = 1) {\n const i = t.xMin - n, s = t.yMin - n;\n return `${i} ${s} ${t.width + 2 * n} ${t.height + 2 * n}`;\n}\nfunction A(t, n, i = 1, s) {\n const a = v(n, i), c = s ? `width=\"${n.width + 2 * i}${s}\" height=\"${n.height + 2 * i}${s}\"` : \"\";\n return `<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<svg version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"${a}\" fill=\"none\" stroke=\"grey\" stroke-width=\"0.2%\" vector-effect=\"non-scaling-stroke\" ${c}>\n ${t}\n</svg>`;\n}\nexport {\n p as a,\n w as b,\n j as c,\n r as d,\n v as e,\n d as s,\n A as w\n};\n//# sourceMappingURL=svg-BTO7h1ix.js.map\n","var $t = Object.defineProperty;\nvar Ut = (t, n, e) => n in t ? $t(t, n, { enumerable: !0, configurable: !0, writable: !0, value: e }) : t[n] = e;\nvar I = (t, n, e) => Ut(t, typeof n != \"symbol\" ? n + \"\" : n, e);\nimport { o as Vt, D as U, f as Ht, c as Kt } from \"./draw-DaKl45lJ.js\";\nimport { a as ce, d as ae } from \"./draw-DaKl45lJ.js\";\nimport { F as m, L as P, D as h, a as W, s as Nt, b as qt, c as Xt, i as Jt, S as b, l as Qt, p as Yt, d as Zt, e as It, g as Mt } from \"./models-DfOxeufK.js\";\nimport { h as ue } from \"./models-DfOxeufK.js\";\nimport { l as Wt, z as jt, m as tn, e as E, n as j, b as F, a as nn, s as en, o as rn, q as St, L as v, A as y, C as _, p as it, u as N, d as q, T as sn, g as A, E as At, Q as vt, t as on, c as cn, D as bt, v as Lt, B as an } from \"./QuadraticBezier-BeY2TXKH.js\";\nimport { s as fn, a as un, b as ln, c as hn, d as gn, w as ot } from \"./svg-BTO7h1ix.js\";\nfunction x(t) {\n if (m.isInstance(t))\n return [t];\n if (P.isInstance(t))\n return [new m(t)];\n if (h.isInstance(t))\n return t.figures;\n throw new Error(\"Unknown shape\");\n}\nfunction Et(t, n, e = 1e-9) {\n let r = [];\n const s = [], i = new Array(n.segments.length).fill(0).map(() => []);\n n.segments.forEach((c, f) => {\n t.segments.forEach((a) => {\n const { intersections: u, overlaps: g } = W(\n c,\n a,\n e\n );\n r.push(...u), i[f].push(...u), s.push(...g);\n const p = g.flatMap((d) => [\n d.firstPoint,\n d.lastPoint\n ]);\n r.push(...p), i[f].push(...p);\n });\n }), r = Wt(r, e);\n const o = jt([n.segments, i]).flatMap(([c, f]) => f.length ? c.splitAt(f) : [c]);\n return Array.from(\n Nt(\n o,\n r,\n s\n )\n );\n}\nfunction tt(t, n, e = !1) {\n return Et(n, t).filter((s) => {\n const i = s.segments[0].midPoint;\n return n.onStroke(i) ? !e : !n.contains(i);\n });\n}\nfunction nt(t, n, e = !1) {\n return Et(n, t).filter((s) => {\n const i = s.segments[0].midPoint;\n return n.onStroke(i) ? !e : n.contains(i);\n });\n}\nfunction ct(t, n, e = !1) {\n const r = tt(\n t,\n n.contour,\n e\n ), s = n.holes.flatMap(\n (i) => nt(t, i, e)\n );\n return [...r, ...s];\n}\nfunction at(t, n, e = !1) {\n let r = nt(\n t,\n n.contour,\n e\n );\n return n.holes.forEach((s) => {\n r = r.flatMap(\n (i) => tt(i, s, e)\n );\n }), r;\n}\nfunction pn(t, n) {\n return new h(\n qt(x(t), x(n))\n );\n}\nfunction z(t) {\n return t.reduce(\n (n, e) => pn(n, e),\n new h()\n );\n}\nfunction kt(t, n) {\n return new h(\n Xt(x(t), x(n))\n );\n}\nfunction Jn(t, n) {\n return new h(\n Jt(x(t), x(n))\n );\n}\nfunction Qn(t, n, e = !0) {\n if (P.isInstance(n))\n return tt(t, n, e);\n if (m.isInstance(n))\n return ct(t, n, e);\n let r = [new b([...t.segments])];\n return n.figures.forEach((s) => {\n r = r.flatMap((i) => ct(i, s, e));\n }), r;\n}\nfunction Yn(t, n, e = !1) {\n if (P.isInstance(n))\n return nt(t, n, e);\n if (m.isInstance(n))\n return at(t, n, e);\n let r = [new b([...t.segments])];\n return n.figures.forEach((s) => {\n r = r.flatMap((i) => at(i, s, e));\n }), r;\n}\nfunction ft(t) {\n return t < 0 ? \"before\" : t > 1 ? \"after\" : \"between\";\n}\nconst ut = (t, n, e) => {\n if (e === \"before\")\n return t.distanceFrom(n.firstPoint);\n if (e === \"after\")\n return t.distanceFrom(n.lastPoint);\n throw new Error(\"Invalid position\");\n};\nfunction dn(t, n) {\n const e = tn(t, n);\n if (e === \"parallel\")\n return Math.min(\n t.distanceFrom(n.firstPoint),\n t.distanceFrom(n.lastPoint)\n );\n const { intersectionParam1: r, intersectionParam2: s } = e, i = ft(r), o = ft(s);\n if (i === \"between\" && o === \"between\")\n return 0;\n if (i === \"between\" && o !== \"between\")\n return ut(t, n, o);\n if (o === \"between\" && i !== \"between\")\n return ut(n, t, i);\n if (i === \"before\" && o === \"before\")\n return E(t.firstPoint, n.firstPoint);\n if (i === \"after\" && o === \"after\")\n return E(t.lastPoint, n.lastPoint);\n if (i === \"before\" && o === \"after\")\n return E(t.firstPoint, n.lastPoint);\n if (i === \"after\" && o === \"before\")\n return E(t.lastPoint, n.firstPoint);\n throw new Error(\"Invalid position\");\n}\nfunction lt(t, n) {\n if (Qt(t, n).length > 0)\n return 0;\n const e = Yt(t, n.center);\n if (t.isOnSegment(e)) {\n const r = E(e, n.center);\n if (Math.abs(r - n.radius) < t.precision && n.isOnSegment(e))\n return 0;\n if (r - n.radius > t.precision) {\n const s = j(\n F(e, n.center)\n ), i = nn(\n n.center,\n en(s, n.radius)\n );\n if (n.isOnSegment(i))\n return E(i, e);\n }\n }\n return Math.min(\n n.distanceFrom(t.firstPoint),\n n.distanceFrom(t.lastPoint),\n t.distanceFrom(n.firstPoint),\n t.distanceFrom(n.lastPoint)\n );\n}\nconst mn = (t, n) => {\n const e = t.angleToParam(n.firstAngle);\n if (t.isValidParameter(e)) return !0;\n const r = t.angleToParam(n.lastAngle);\n return !!t.isValidParameter(r);\n};\nfunction Pn(t, n) {\n if (Zt(t, n, !0).length > 0) return 0;\n const e = E(t.center, n.center);\n if (e < t.precision && mn(t, n))\n return Math.abs(t.radius - n.radius);\n const r = j(F(n.center, t.center)), s = e - Math.abs(t.radius - n.radius) < t.precision;\n let i = rn(r);\n s && n.radius > t.radius && (i += Math.PI);\n const o = s ? i : i + Math.PI, c = t.angleToParam(i), f = n.angleToParam(o);\n return t.isValidParameter(c) && n.isValidParameter(f) ? E(t.paramPoint(c), n.paramPoint(f)) : Math.min(\n t.distanceFrom(n.firstPoint),\n t.distanceFrom(n.lastPoint),\n n.distanceFrom(t.firstPoint),\n n.distanceFrom(t.lastPoint)\n );\n}\nfunction wn(t, n, e) {\n let r = 0, s = t.length - 1;\n for (; r <= s; ) {\n const i = Math.floor((r + s) / 2), o = e(t[i], n);\n if (o < 0)\n r = i + 1;\n else if (o > 0)\n s = i - 1;\n else\n return i;\n }\n return -(r + 1);\n}\nfunction In(t, n, e) {\n const r = wn(t, n, e);\n r < 0 ? t.splice(-(r + 1), 0, n) : t.splice(r, 0, n);\n}\nclass Mn {\n constructor() {\n I(this, \"buckets\");\n this.buckets = [];\n }\n addInterval(n) {\n const e = this.buckets[n.rectangle.diagonalBucketIndex];\n e === void 0 ? this.buckets[n.rectangle.diagonalBucketIndex] = [n] : In(e, n, (r, s) => r.value - s.value);\n }\n removeInterval(n) {\n const e = this.buckets[n.rectangle.diagonalBucketIndex];\n if (e === void 0)\n throw new Error(\"Interval not found\");\n e.shift();\n }\n getBottomRightHullIntervals() {\n const n = [];\n for (let e = this.buckets.length - 1; e >= 0; e--) {\n const r = this.buckets[e];\n if (!r === void 0) continue;\n const s = r[0];\n if (s !== void 0) {\n if (!n.length) {\n n.push(s);\n continue;\n }\n for (; n.length && n[n.length - 1].value >= s.value; )\n n.pop();\n for (; n.length >= 2; ) {\n const i = n[n.length - 1], o = n[n.length - 2], c = (s.value - o.value) / ((s.rectangle.diagonal - o.rectangle.diagonal) * 2);\n if (o.value + (i.rectangle.diagonal - o.rectangle.diagonal) / 2 * c < i.value)\n n.pop();\n else\n break;\n }\n n.push(s);\n }\n }\n return n;\n }\n}\nclass Sn {\n constructor(n, e) {\n I(this, \"diagonal\");\n I(this, \"diagonalBucketIndex\");\n I(this, \"xLength\");\n I(this, \"yLength\");\n I(this, \"index\");\n this.x = n, this.y = e, this.xLength = Math.pow(3, -n), this.yLength = Math.pow(3, -e), this.diagonal = Math.sqrt(\n this.xLength * this.xLength + this.yLength * this.yLength\n ), this.diagonalBucketIndex = n + e, this.index = `${n},${e}`;\n }\n}\nclass An {\n constructor(n, e = 1e-8, r = 1e3, s = 1e-6) {\n I(this, \"rectangles\");\n I(this, \"buckets\");\n I(this, \"fMin\");\n I(this, \"argMin\");\n I(this, \"tol\");\n this.fcn = n, this.endTolerance = e, this.maxIterations = r, this.epsilon = s, this.fcn = n, this.epsilon = s, this.endTolerance = e, this.maxIterations = r, this.rectangles = /* @__PURE__ */ new Map(), this.buckets = new Mn();\n const i = [0.5, 0.5], o = this.rect(0, 0), c = this.fcn(i);\n this.buckets.addInterval(new O(i, c, o)), this.fMin = c, this.argMin = i, this.tol = o.diagonal;\n }\n registerInterval(n) {\n this.buckets.addInterval(n), n.value <= this.fMin && (this.fMin = n.value, this.argMin = n.center, this.tol = n.rectangle.diagonal);\n }\n rect(n, e) {\n const r = `${n},${e}`;\n return this.rectangles.has(r) || this.rectangles.set(r, new Sn(n, e)), this.rectangles.get(r);\n }\n splitInterval(n) {\n let e, r, s;\n const [i, o] = n.center;\n return n.rectangle.x <= n.rectangle.y ? (e = this.rect(n.rectangle.x + 1, n.rectangle.y), r = [i - e.xLength, o], s = [i + e.xLength, o]) : (e = this.rect(n.rectangle.x, n.rectangle.y + 1), r = [i, o - e.yLength], s = [i, o + e.yLength]), [\n new O(r, this.fcn(r), e),\n new O(n.center, n.value, e),\n new O(s, this.fcn(s), e)\n ];\n }\n single_iteration() {\n const n = this.buckets.getBottomRightHullIntervals();\n for (; n.length >= 2; ) {\n const e = n[0], r = n[1], s = (r.value - e.value) / ((r.rectangle.diagonal - e.rectangle.diagonal) / 2), i = e.value - s * r.value / 2;\n if ((this.fMin - i) / Math.abs(this.fMin) < this.epsilon)\n n.shift();\n else\n break;\n }\n n.forEach((e) => {\n this.buckets.removeInterval(e);\n });\n for (const e of n) {\n const [r, s, i] = this.splitInterval(e);\n this.registerInterval(r), this.registerInterval(s), this.registerInterval(i);\n }\n }\n run() {\n let n = 0;\n for (; this.tol > this.endTolerance / 2 && (this.single_iteration(), n++, !(n > this.maxIterations)); )\n ;\n return {\n fMin: this.fMin,\n argMin: this.argMin,\n tol: this.tol,\n iterations: n\n };\n }\n}\nclass O {\n constructor(n, e, r) {\n this.center = n, this.value = e, this.rectangle = r;\n }\n}\nfunction vn(t, n = 1e-8, e = 1e3, r = 1e-6) {\n return new An(\n t,\n n,\n e,\n r\n ).run();\n}\nfunction bn(t, n, e = 1e-9) {\n const r = vn((s) => {\n const i = t.paramPoint(s[0]), o = n.paramPoint(s[1]);\n return St(i, o);\n }, e);\n return Math.sqrt(r.fMin);\n}\nfunction Ln(t, n) {\n return v.isInstance(t) && v.isInstance(n) ? dn(t, n) : v.isInstance(t) && y.isInstance(n) ? lt(t, n) : y.isInstance(t) && v.isInstance(n) ? lt(n, t) : y.isInstance(t) && y.isInstance(n) ? Pn(t, n) : bn(t, n);\n}\nfunction Ft(t) {\n if (_.isInstance(t)) {\n const s = F(t.lastPoint, t.firstPoint), i = F(t.firstControlPoint, t.firstPoint), o = F(t.lastControlPoint, t.firstPoint), c = N(s, i), f = N(s, o);\n if (c > 0 && f < 0 || c < 0 && f > 0) return !1;\n }\n const n = it(t.tangentAtFirstPoint), e = it(t.tangentAtLastPoint);\n let r = q(n, e);\n return Math.abs(Math.acos(r)) < Math.PI / 3;\n}\nfunction X(t) {\n if (Ft(t)) return [t];\n const [n, e] = t.splitAtParameters([0.5]);\n return [\n ...X(n),\n ...X(e)\n ];\n}\nfunction ht(t) {\n return Ft(t) ? [t] : t.splitAtParameters(t.getParametersOfExtrema()).flatMap(X);\n}\nfunction En(t) {\n const n = t.deltaAngle, e = Math.ceil(Math.abs(n) / (Math.PI / 2)), r = n / e, s = 4 * Math.tan(r / 4) / 3, i = t.clockwise ? -1 : 1, o = Array.from(\n { length: e + 1 },\n (f, a) => t.firstAngle + a * r * i\n );\n return o.slice(0, -1).map((f, a) => [f, o[a + 1]]).map(([f, a]) => {\n const u = Math.cos(f), g = Math.sin(f), p = Math.cos(a), d = Math.sin(a), [l, M] = t.center, w = t.minorRadius, S = t.majorRadius, L = new sn().rotate(\n t.tiltAngle,\n t.center\n ), k = (_t) => L.transform(_t), D = k([l + S * u, M + w * g]), $ = k([\n l + S * (u - s * g * i),\n M + w * (g + s * u * i)\n ]), zt = k([\n l + S * (p + s * d * i),\n M + w * (d - s * p * i)\n ]), Gt = k([l + S * p, M + w * d]);\n return new _(D, Gt, $, zt);\n });\n}\nconst et = 1e-8, xt = (t) => t.flatMap((n) => v.isInstance(n) ? [n] : y.isInstance(n) ? [n] : At.isInstance(n) ? En(n).flatMap(\n (e) => ht(e)\n) : vt.isInstance(n) || _.isInstance(n) ? ht(n) : [new v(n.firstPoint, n.lastPoint)]);\nfunction J(t, n, e = !0) {\n const r = t.map((a) => ({\n offset: Vt(a, n),\n original: a\n })), s = [];\n let i = e ? null : r.at(-1), o = e ? r.at(-1) : null;\n if (s.length === 1) return s;\n const c = (a) => {\n i ? U.isInstance(a.offset) ? A(a.offset.firstPoint, a.offset.lastPoint) || s.push(\n new v(a.offset.firstPoint, a.offset.lastPoint)\n ) : s.push(a.offset) : i = a;\n }, f = function* () {\n for (const a of r.slice(0, -1))\n yield a;\n if (!i) throw new Error(\"Bug in the offset algorithm\");\n yield i;\n };\n for (const a of f()) {\n if (!o) {\n o = a;\n continue;\n }\n const u = o.offset.lastPoint, g = a.offset.firstPoint;\n if (A(u, g)) {\n c(o), o = a;\n continue;\n }\n let p = [];\n if (!U.isInstance(o.offset) && !U.isInstance(a.offset)) {\n const { intersections: w, overlaps: S } = W(\n o.offset,\n a.offset,\n et / 100\n );\n p = [\n ...w,\n ...S.flatMap((L) => [L.firstPoint, L.lastPoint])\n ];\n }\n if (p.length > 0) {\n let w = p[0];\n if (p.length > 1) {\n const k = o == null ? void 0 : o.original.lastPoint, D = p.map(\n ($) => St($, k)\n );\n w = p[D.indexOf(Math.min(...D))];\n }\n const S = o.offset.splitAt([\n w\n ])[0], L = a.offset.splitAt([w]).at(-1);\n if (!L) throw new Error(\"Bug in the splitting algo in offset\");\n c({\n offset: S,\n original: o.original\n }), o = { offset: L, original: a.original };\n continue;\n }\n const d = o.original.lastPoint, l = cn(\n F(g, d),\n F(u, d)\n ) > 0, M = new y(u, g, d, l);\n c(o), s.push(M), o = a;\n }\n return o && c(o), s;\n}\nfunction yt(t) {\n const n = /* @__PURE__ */ new Map(), e = (r, s) => {\n const i = n.get(r) || [];\n n.set(r, [...i, ...s]);\n };\n return t.forEach((r, s) => {\n t.slice(s + 1).forEach((i, o) => {\n const { intersections: c, overlaps: f } = W(r, i, et), a = [\n ...c,\n ...f.flatMap((u) => [u.firstPoint, u.lastPoint])\n ].filter((u) => {\n const g = A(u, r.firstPoint) || A(u, r.lastPoint), p = A(u, i.firstPoint) || A(u, i.lastPoint);\n return !(g && p);\n });\n a.length && (e(s, a), e(o + s + 1, a));\n });\n }), n;\n}\nfunction Ct(t, n) {\n return n.flatMap((e, r) => {\n if (!t.has(r)) return e;\n const s = t.get(r);\n return s ? e.splitAt(s) : e;\n });\n}\nfunction Dt(t, n, e) {\n return t.filter((r) => !n.segments.some((i) => Ln(i, r) < Math.abs(e) - et));\n}\nfunction G(t, n) {\n const e = t.clockwise ? n : -n, r = xt(t.segments), s = J(r, e);\n if (s.length < 2) return new h();\n const i = yt(s);\n if (!i.size) {\n const u = new P(s);\n return new h([new m(u)]);\n }\n const o = Ct(\n i,\n s\n ), c = Dt(o, t, n);\n if (!c.length) return new h();\n const a = It(c).filter((u) => u.length > 1).filter((u) => A(u[0].firstPoint, u.at(-1).lastPoint)).map((u) => new P(u));\n return a.length ? new h(a.map((u) => new m(u))) : new h();\n}\nfunction kn(t, n, e = \"round\") {\n const r = n / 2, s = xt(t.segments), i = J(s, r, !1), o = J(\n s,\n -r,\n !1\n ).map((l) => l.reverse());\n o.reverse();\n const c = (l, M) => e === \"round\" ? on(\n l.lastPoint,\n M.firstPoint,\n l.tangentAtLastPoint\n ) : new v(l.lastPoint, M.firstPoint), f = [\n ...i,\n c(\n i[i.length - 1],\n o[0]\n ),\n ...o,\n c(\n o[o.length - 1],\n i[0]\n )\n ], a = yt(f);\n if (!a.size) {\n const l = new P(f);\n return new h([new m(l)]);\n }\n const u = Ct(\n a,\n f\n ), g = Dt(u, t, r);\n if (!g.length) return new h();\n const d = It(g).filter((l) => l.length > 1).filter((l) => A(l[0].firstPoint, l.at(-1).lastPoint)).map((l) => new P(l));\n return d.length ? new h(d.map((l) => new m(l))) : new h();\n}\nfunction Fn(t, n) {\n const e = t.map((r) => {\n const s = z(\n r.holes.map((i) => G(i, n))\n );\n return kt(G(r.contour, n), s);\n });\n return z(e);\n}\nfunction xn(t, n) {\n const e = Math.abs(n / 2), r = t.map(\n (s) => z(\n s.allLoops.map((i) => kt(G(i, e), G(i, -e)))\n )\n );\n return z(r);\n}\nfunction Zn(t, n) {\n return Fn(x(t), n);\n}\nfunction Wn(t, n, { endCap: e = \"round\" } = {}) {\n return b.isInstance(t) ? kn(t, n, e) : xn(x(t), n);\n}\nclass yn {\n constructor() {\n I(this, \"filters\");\n this.filters = [];\n }\n delete() {\n this.filters = [];\n }\n /**\n * Combine logically a set of filter with an AND operation.\n *\n */\n and(n) {\n return n.forEach((e) => e(this)), this;\n }\n /**\n * Invert the result of a particular filter\n *\n */\n not(n) {\n const e = new this.constructor();\n n(e);\n const r = ({ element: s }) => !e.shouldKeep(s);\n return this.filters.push(r), this;\n }\n /**\n * Combine logically a set of filter with an OR operation.\n *\n */\n either(n) {\n const e = n.map((s) => {\n const i = new this.constructor();\n return s(i), i;\n }), r = ({ element: s }) => e.some((i) => i.shouldKeep(s));\n return this.filters.push(r), this;\n }\n}\nconst V = 2 * Math.PI, gt = (t) => {\n const n = t % V, e = n < 0 ? n + V : n;\n return e < Math.PI ? e : e === Math.PI ? 0 : Math.abs(e - V);\n};\nclass C extends yn {\n clone() {\n const n = new C();\n return n.filters = [...this.filters], n;\n }\n /**\n * Filter to find corner that have their point are in the list.\n *\n */\n inList(n) {\n const e = ({ element: r }) => !!n.find((s) => A(s, r.point));\n return this.filters.push(e), this;\n }\n /**\n * Filter to find elements that are at a specified distance from a point.\n *\n */\n atDistance(n, e = [0, 0]) {\n function r({ element: s }) {\n return Math.abs(E(e, s.point) - n) < 1e-9;\n }\n return this.filters.push(r), this;\n }\n /**\n * Filter to find elements that contain a certain point\n *\n * @category Filter\n */\n atPoint(n) {\n function e({ element: r }) {\n return A(n, r.point);\n }\n return this.filters.push(e), this;\n }\n /**\n * Filter to find elements that are within a box\n *\n * @category Filter\n */\n inBox(n, e) {\n const [r, s] = n, [i, o] = e, c = Math.min(r, i), f = Math.max(r, i), a = Math.min(s, o), u = Math.max(s, o);\n function g({ element: p }) {\n const [d, l] = p.point;\n return d >= c && d <= f && l >= a && l <= u;\n }\n return this.filters.push(g), this;\n }\n /**\n * Filter to find corner that a certain angle between them - only between\n * 0 and 180.\n *\n */\n ofAngle(n) {\n function e({ element: r }) {\n const s = r.firstCurve.tangentAtLastPoint, i = r.secondCurve.tangentAtFirstPoint;\n return Math.abs(\n gt(N(s, i)) - gt(bt * n)\n ) < 1e-9;\n }\n return this.filters.push(e), this;\n }\n above(n = 0) {\n function e({ element: r }) {\n return r.point[1] > n;\n }\n return this.filters.push(e), this;\n }\n below(n = 0) {\n function e({ element: r }) {\n return r.point[1] < n;\n }\n return this.filters.push(e), this;\n }\n leftOf(n = 0) {\n function e({ element: r }) {\n return r.point[0] < n;\n }\n return this.filters.push(e), this;\n }\n rightOf(n = 0) {\n function e({ element: r }) {\n return r.point[0] > n;\n }\n return this.filters.push(e), this;\n }\n shouldKeep(n) {\n return this.filters.every((r) => r({ element: n }));\n }\n asFilterFun() {\n return this.shouldKeep.bind(this);\n }\n}\nfunction Ot(t, n, e, r = () => !0) {\n const s = [n.segments[0]], i = (c, f) => {\n r({ firstCurve: c, secondCurve: f, point: c.lastPoint }) ? s.push(...t(c, f, e)) : s.push(c, f);\n };\n if (n.segments.slice(1).forEach((c) => {\n const f = s.pop();\n if (!f) throw new Error(\"Bug in the stroke filletting algo\");\n i(f, c);\n }), !s.at(-1)) throw new Error(\"Bug in the stroke corner algo\");\n if (P.isInstance(n)) {\n const c = s.pop(), f = s.shift();\n if (!c || !f)\n throw new Error(\"Bug in the filletting algo\");\n return i(c, f), new P(s, { ignoreChecks: !0 });\n } else\n return new b(s, { ignoreChecks: !0 });\n}\nfunction R(t, n, e) {\n const r = typeof e == \"function\" ? e(new C()) : e, s = r && r.asFilterFun();\n if (P.isInstance(t) || b.isInstance(t))\n return Ot(Ht, t, n, s);\n if (m.isInstance(t)) {\n const i = R(t.contour, n, r), o = t.holes.map((c) => R(c, n, r));\n return new m(i, o, { ignoreChecks: !0 });\n }\n if (h.isInstance(t)) {\n const i = t.figures.map((o) => R(o, n, r));\n return new h(i, { ignoreChecks: !0 });\n }\n throw new Error(\"invalid shape to fillet\");\n}\nfunction T(t, n, e) {\n const r = typeof e == \"function\" ? e(new C()) : e, s = r && r.asFilterFun();\n if (P.isInstance(t) || b.isInstance(t))\n return Ot(Kt, t, n, s);\n if (m.isInstance(t)) {\n const i = T(t.contour, n, r), o = t.holes.map((c) => T(c, n, r));\n return new m(i, o, { ignoreChecks: !0 });\n }\n if (h.isInstance(t)) {\n const i = t.figures.map((o) => T(o, n, r));\n return new h(i, { ignoreChecks: !0 });\n }\n throw new Error(\"invalid shape to chamfer\");\n}\nclass Cn extends C {\n constructor(n) {\n super(), this.shape = n;\n }\n fillet(n) {\n return R(this.shape, n, this.clone());\n }\n chamfer(n) {\n return T(this.shape, n, this.clone());\n }\n}\nfunction jn(t) {\n return new Cn(t);\n}\nconst Dn = 1 * bt, On = 24;\nfunction H(t, n, e, r) {\n const s = t.gradientAt(n);\n return Lt(s) <= r ? e : j(s);\n}\nfunction Q(t, n, e, r, s, i) {\n const o = t.paramPoint(n), c = t.paramPoint(e), f = F(c, o), a = Lt(f);\n if (a <= t.precision || i >= r.maxDepth)\n return [o, c];\n const u = [f[0] / a, f[1] / a], g = (n + e) * 0.5, p = H(t, n, u, t.precision), d = H(t, g, u, t.precision), l = H(t, e, u, t.precision), M = q(p, d), w = q(d, l);\n if (M >= s && w >= s)\n return [o, c];\n const S = t.paramPoint(g), L = M >= s ? [o, S] : Q(t, n, g, r, s, i + 1), k = w >= s ? [S, c] : Q(t, g, e, r, s, i + 1);\n return [...L.slice(0, -1), ...k];\n}\nfunction rt(t, n = {}) {\n const e = {\n maxAngle: n.maxAngle ?? Dn,\n maxDepth: n.maxDepth ?? On\n }, r = Math.cos(e.maxAngle);\n return Q(t, 0, 1, e, r, 0);\n}\nfunction Bn(t, n) {\n return new h(\n t.figures.map((e) => Bt(e, n))\n );\n}\nfunction Bt(t, n) {\n return new m(\n Y(t.contour, n),\n t.holes.map((e) => Y(e, n))\n );\n}\nfunction Y(t, n) {\n return new P(st(t.segments, n));\n}\nfunction Rn(t, n) {\n return new b(st(t.segments, n));\n}\nfunction st(t, n) {\n return t.flatMap(n);\n}\nfunction Tn(t, n) {\n if (h.isInstance(t))\n return Bn(t, n);\n if (m.isInstance(t))\n return Bt(t, n);\n if (P.isInstance(t))\n return Y(t, n);\n if (b.isInstance(t))\n return Rn(t, n);\n if (Mt(t))\n return st([t], n);\n throw new Error(\"Unsupported shape type\");\n}\nfunction zn(t) {\n if (t.length < 2) return [];\n const n = [];\n for (let e = 0; e < t.length - 1; e += 1)\n n.push(new v(t[e], t[e + 1]));\n return n;\n}\nfunction Gn(t, n) {\n return zn(rt(t, n));\n}\nfunction B(t, n) {\n const e = [];\n return t.forEach((r, s) => {\n const i = rt(r, n);\n if (i.length !== 0) {\n if (s === 0) {\n e.push(...i);\n return;\n }\n e.push(...i.slice(1));\n }\n }), e.length > 1 && A(e[0], e[e.length - 1]) && e.pop(), e;\n}\nfunction _n(t) {\n return t.length < 3 ? !1 : t.map((e, r) => {\n const s = t[(r + 1) % t.length];\n return (s[0] - e[0]) * (s[1] + e[1]);\n }).reduce((e, r) => e + r, 0) > 0;\n}\nfunction K(t, n) {\n return t.length < 3 || _n(t) === n ? t : [...t].reverse();\n}\nfunction te(t, n = {}) {\n return Tn(t, (r) => Gn(r, n));\n}\nfunction $n(t, n = {}) {\n if (h.isInstance(t))\n return t.figures.flatMap((e) => $n(e, n));\n if (m.isInstance(t)) {\n const e = K(\n B(t.contour.segments, n),\n !1\n ), r = t.holes.map(\n (s) => K(B(s.segments, n), !0)\n );\n return [e, ...r];\n }\n return P.isInstance(t) ? [K(B(t.segments, n), !1)] : b.isInstance(t) ? [B(t.segments, n)] : [rt(t, n)];\n}\nfunction pt(t) {\n if (h.isInstance(t))\n return fn(t);\n if (m.isInstance(t))\n return un(t);\n if (P.isInstance(t))\n return `<path d=\"${ln(t)}\" />`;\n if (b.isInstance(t))\n return `<path d=\"${hn(t)}\" />`;\n if (Mt(t))\n return `<path d=\"${`M ${t.firstPoint.join(\" \")}`} ${gn(\n t\n )}\" />`;\n throw new Error(\"Unknown shape type\");\n}\nconst dt = (t) => \"shape\" in t ? t.shape : t, mt = (t, n) => {\n if (!(\"shape\" in t)) return n;\n const { color: e } = t;\n return e ? `<g stroke=\"${e}\">${n}</g>` : n;\n}, Pt = (t) => new an(t.xMin, -t.yMax, t.xMax, -t.yMin);\nfunction ne(t, {\n margin: n = 1,\n unit: e = null,\n viewBox: r\n} = {}) {\n if (Array.isArray(t)) {\n const i = t.map((f) => dt(f).mirror()), o = i.map((f, a) => mt(t[a], pt(f))).join(`\n`), c = i.slice(1).reduce((f, a) => f.merge(a.boundingBox), i[0].boundingBox);\n return ot(o, r ? Pt(r) : c, n, e);\n }\n const s = dt(t).mirror();\n return ot(\n mt(t, pt(s)),\n r ? Pt(r) : s.boundingBox,\n n,\n e\n );\n}\nconst Rt = (t) => {\n if (t.type === \"LINE\")\n return new v(t.firstPoint, t.lastPoint);\n if (t.type === \"ARC\")\n return new y(\n t.firstPoint,\n t.lastPoint,\n t.center,\n t.clockwise\n );\n if (t.type === \"ELLIPSE_ARC\")\n return new At(\n t.firstPoint,\n t.lastPoint,\n t.center,\n t.majorRadius,\n t.minorRadius,\n t.tiltAngle,\n t.clockwise,\n { angleUnits: \"rad\" }\n );\n if (t.type === \"QUADRATIC_BEZIER\")\n return new vt(\n t.firstPoint,\n t.lastPoint,\n t.controlPoint\n );\n if (t.type === \"CUBIC_BEZIER\")\n return new _(\n t.firstPoint,\n t.lastPoint,\n t.firstControlPoint,\n t.lastControlPoint\n );\n throw new Error(\"Unknown segment type\");\n}, Z = (t) => {\n const n = t.segments.map(Rt);\n return new P(n);\n}, Tt = (t) => {\n const n = Z(t.contour), e = t.holes.map(Z);\n return new m(n, e);\n}, Un = (t) => {\n const n = t.figures.map(Tt);\n return new h(n);\n};\nfunction ee(t) {\n if (t.type === \"DIAGRAM\")\n return Un(t);\n if (t.type === \"FIGURE\")\n return Tt(t);\n if (t.type === \"LOOP\")\n return Z(t);\n if (t.type === \"LINE\" || t.type === \"ARC\" || t.type === \"ELLIPSE_ARC\" || t.type === \"CUBIC_BEZIER\")\n return Rt(t);\n throw new Error(\"Unknown shape type\");\n}\nconst wt = Math.PI / 180, Vn = 180 / Math.PI;\nfunction re(t, n) {\n const e = Math.cos(n * wt) * t, r = Math.sin(n * wt) * t;\n return [e, r];\n}\nfunction se([t, n]) {\n const e = Math.sqrt(t * t + n * n), r = Math.atan2(n, t) * Vn;\n return [e, r];\n}\nexport {\n wt as DEG2RAD,\n ce as DrawingPen,\n Vn as RAD2DEG,\n se as cartesianToPolar,\n T as chamfer,\n Yn as confineStrand,\n kt as cut,\n ae as draw,\n Qn as eraseStrand,\n ue as exportJSON,\n ne as exportSVG,\n R as fillet,\n pn as fuse,\n z as fuseAll,\n ee as importJSON,\n Jn as intersect,\n Zn as offset,\n Wn as outlineStroke,\n re as polarToCartesian,\n jn as selectCorners,\n pt as svgBody,\n te as tesselate,\n $n as tesselatePoints\n};\n//# sourceMappingURL=pantograph.js.map\n","import { cut, eraseStrand, exportSVG } from \"pantograph2d\";\nimport {\n Transformable,\n Diagram,\n Strand,\n TransformationMatrix,\n Stroke,\n} from \"pantograph2d/models\";\n\nexport class Dieline extends Transformable<Dieline> {\n public body: Diagram;\n public cutLines: Stroke[];\n public foldLinesBackwards: Stroke[];\n public foldLinesForwards: Stroke[];\n\n constructor(\n body: Diagram,\n {\n cutLines = [],\n foldLines = [],\n foldLinesForwards = [],\n foldLinesBackwards = [],\n }: {\n cutLines?: Stroke[];\n foldLines?: Stroke[];\n foldLinesBackwards?: Stroke[];\n foldLinesForwards?: Stroke[];\n } = {},\n ) {\n super();\n this.body = body;\n this.cutLines = [...cutLines];\n this.foldLinesBackwards = [...foldLines, ...foldLinesBackwards];\n this.foldLinesForwards = [...foldLinesForwards];\n }\n\n get foldLines() {\n return [...this.foldLinesForwards, ...this.foldLinesBackwards];\n }\n\n clone() {\n return new Dieline(this.body, {\n cutLines: [...this.cutLines],\n foldLinesForwards: [...this.foldLinesForwards],\n foldLinesBackwards: [...this.foldLinesBackwards],\n });\n }\n\n addCutLine(cut: Strand) {\n this.cutLines.push(cut);\n return this;\n }\n\n addFoldLine(fold: Strand, direction: \"forwards\" | \"backwards\" = \"backwards\") {\n if (direction === \"forwards\") {\n this.foldLinesForwards.push(fold);\n } else {\n this.foldLinesBackwards.push(fold);\n }\n }\n\n fuseFold(\n fold: Diagram | Dieline,\n direction: \"forwards\" | \"backwards\" = \"backwards\",\n ) {\n const otherBody: Diagram = fold instanceof Dieline ? fold.body : fold;\n\n const commonLines = this.body.overlappingStrands(otherBody);\n if (direction === \"forwards\") {\n this.foldLinesForwards.push(...commonLines);\n } else {\n this.foldLinesBackwards.push(...commonLines);\n }\n\n this.fuseBody(fold);\n return this;\n }\n\n fuseBody(other: Dieline | Diagram) {\n let otherBody: Diagram;\n\n if (other instanceof Dieline) {\n otherBody = other.body;\n this.cutLines.push(...other.cutLines);\n this.foldLinesForwards.push(...other.foldLinesForwards);\n this.foldLinesBackwards.push(...other.foldLinesBackwards);\n } else {\n otherBody = other;\n }\n\n this.body = this.body.fuse(otherBody);\n return this;\n }\n\n cutShape(shape: Diagram) {\n this.body = cut(this.body, shape);\n this.cutLines = this.cutLines.flatMap((cut) =>\n eraseStrand(cut, shape, true),\n );\n this.eraseFolds(shape);\n return this;\n }\n\n eraseFolds(shape: Diagram) {\n this.foldLinesBackwards = this.foldLinesBackwards.flatMap((fold) =>\n eraseStrand(fold, shape, true),\n );\n this.foldLinesForwards = this.foldLinesForwards.flatMap((fold) =>\n eraseStrand(fold, shape, true),\n );\n }\n\n transform(matrix: TransformationMatrix) {\n const newDieline = new Dieline(this.body.transform(matrix), {\n cutLines: this.cutLines.map((cut) => cut.transform(matrix)),\n foldLinesForwards: this.foldLinesForwards.map((fold) =>\n fold.transform(matrix),\n ),\n foldLinesBackwards: this.foldLinesBackwards.map((fold) =>\n fold.transform(matrix),\n ),\n });\n\n return newDieline;\n }\n\n asSVG() {\n const shapes: { shape: Diagram | Stroke; color: string }[] = [];\n if (this.body) {\n shapes.push({ shape: this.body, color: \"red\" });\n }\n if (this.cutLines.length) {\n this.cutLines.map((shape) => shapes.push({ shape, color: \"red\" }));\n }\n\n if (this.foldLinesBackwards.length) {\n this.foldLinesBackwards.map((shape) =>\n shapes.push({ shape, color: \"green\" }),\n );\n }\n\n if (this.foldLinesForwards.length) {\n this.foldLinesForwards.map((shape) =>\n shapes.push({ shape, color: \"blue\" }),\n );\n }\n\n return exportSVG(shapes, { unit: \"mm\" });\n }\n}\n","import { draw } from \"pantograph2d\";\n\nexport type FlapContractionMode = \"rounded\" | \"sharp\";\nexport type HorizontalFlapOptions = {\n fillet?: number;\n contraction?: number;\n contractionMode?: FlapContractionMode;\n contractionLeft?: number;\n contractionRight?: number;\n leftContractionMode?: FlapContractionMode;\n rightContractionMode?: FlapContractionMode;\n};\nexport type VerticalFlapTopOptions = HorizontalFlapOptions & {\n contractionTop?: number;\n contractionBottom?: number;\n topContractionMode?: FlapContractionMode;\n bottomContractionMode?: FlapContractionMode;\n};\n\nfunction drawFlap(\n width: number,\n height: number,\n {\n fillet = 1,\n contraction = 1,\n contractionMode = \"rounded\",\n contractionLeft: contractionLeftInput,\n contractionRight: contractionRightInput,\n leftContractionMode,\n rightContractionMode,\n }: HorizontalFlapOptions = {},\n) {\n const contractionLeft = contractionLeftInput ?? contraction;\n const contractionRight = contractionRightInput ?? contraction;\n\n const flapMaker = draw([-width / 2, 0]).hLine(width);\n\n if (contractionRight) {\n if ((rightContractionMode ?? contractionMode) === \"rounded\") {\n flapMaker.tangentArc(-contractionRight, contractionRight, [-1, 0]);\n flapMaker.vLine(height - contractionRight);\n } else {\n flapMaker.line(-contractionRight, height);\n }\n } else {\n flapMaker.vLine(height);\n }\n\n flapMaker.customCorner(fillet);\n flapMaker.hLine(-width + contractionLeft + contractionRight);\n flapMaker.customCorner(fillet);\n\n if (contractionLeft) {\n if ((leftContractionMode ?? contractionMode) === \"rounded\") {\n flapMaker.vLine(-height + contractionLeft);\n flapMaker.tangentArcTo([-width / 2, 0]);\n } else {\n flapMaker.lineTo([-width / 2, 0]);\n }\n } else {\n flapMaker.vLine(-height);\n }\n\n return flapMaker.close();\n}\n\nexport function topFlap(\n width: number,\n height: number,\n options: HorizontalFlapOptions = {},\n) {\n return drawFlap(width, height, options);\n}\n\nexport function bottomFlap(\n width: number,\n height: number,\n options: HorizontalFlapOptions = {},\n) {\n return drawFlap(width, height, options).mirror(\"x\");\n}\n\nexport function leftFlap(\n width: number,\n height: number,\n {\n contractionTop,\n contractionBottom,\n topContractionMode,\n bottomContractionMode,\n ...options\n }: VerticalFlapTopOptions = {},\n) {\n return drawFlap(width, height, {\n contractionLeft: contractionTop,\n contractionRight: contractionBottom,\n leftContractionMode: topContractionMode,\n rightContractionMode: bottomContractionMode,\n ...options,\n }).rotate(90);\n}\n\nexport function rightFlap(\n width: number,\n height: number,\n options: VerticalFlapTopOptions = {},\n) {\n return leftFlap(width, height, options).mirror(\"y\");\n}\n\nexport const drawFlaps = {\n right: rightFlap,\n left: leftFlap,\n top: topFlap,\n bottom: bottomFlap,\n};\n","import { draw } from \"pantograph2d\";\nimport {\n Diagram,\n Strand,\n Transformable,\n TransformationMatrix,\n} from \"pantograph2d/models\";\nimport { Dieline } from \"./Dieline.js\";\n\nconst drawBump = (width: number, height: number) => {\n return draw([-width / 2, 0])\n .line(height, -height)\n .hLine(width - 2 * height)\n .line(height, height);\n};\n\n// A helper class to create bumps for locking parts together without glue\nexport class FoldLockBump extends Transformable<FoldLockBump> {\n cut: Strand;\n unfold: Diagram;\n bump: Diagram;\n constructor(\n width: number | { cut: Strand; unfold: Diagram; bump: Diagram },\n paperThickness = 0.2,\n ) {\n super();\n\n if (typeof width !== \"number\") {\n this.cut = width.cut;\n this.unfold = width.unfold;\n this.bump = width.bump;\n return;\n }\n\n const pen = drawBump(width, paperThickness * 2.5);\n\n this.cut = pen.asStrand();\n this.unfold = pen.close();\n\n this.bump = drawBump(width - 5 * paperThickness, 5 * paperThickness)\n .close()\n .mirror(\"x\");\n }\n\n clone() {\n return new FoldLockBump(this);\n }\n\n transform(matrix: TransformationMatrix) {\n return new FoldLockBump({\n cut: this.cut.transform(matrix),\n unfold: this.unfold.transform(matrix),\n bump: this.bump.transform(matrix),\n });\n }\n\n makeCut(dieline: Dieline) {\n dieline.eraseFolds(this.unfold);\n dieline.addCutLine(this.cut);\n }\n\n fuseBump(dieline: Dieline) {\n dieline.fuseBody(this.bump);\n }\n}\n","import { Vector } from \"pantograph2d\";\nimport { Transformable, TransformationMatrix } from \"pantograph2d/models\";\n\ninterface Clonable {\n clone(): this;\n}\n\ninterface Translatable {\n translateTo(point: Vector): this;\n}\n\nclass PointsDistribution extends Transformable<PointsDistribution> {\n constructor(public points: Vector[]) {\n super();\n this.points = points;\n }\n\n transform(matrix: TransformationMatrix) {\n return new PointsDistribution(this.points.map(matrix.transform));\n }\n\n distribute<T extends Translatable>(s: T): T[] {\n return this.points.map((p) => s.translateTo(p));\n }\n\n cloneDistribute<T extends Translatable & Clonable>(s: T): T[] {\n return this.points.map((p) => s.clone().translateTo(p));\n }\n}\n\nexport function linearDistribution(\n totalWidth: number,\n objectWidth: number,\n gapShare = 3,\n margin = 0,\n) {\n if (totalWidth <= objectWidth * 2) {\n throw new Error(\"totalWidth must be greater than twice the objectWidth\");\n }\n\n const objectsCount = Math.max(\n Math.floor((totalWidth - 2 * margin) / (objectWidth * (gapShare + 1))),\n 2,\n );\n const freeSpace = totalWidth - 2 * margin - objectsCount * objectWidth;\n const gapSize = freeSpace / (objectsCount - 1);\n const points: number[] = [];\n for (let i = 0; i < objectsCount; i++) {\n points.push(\n margin + i * (objectWidth + gapSize) - totalWidth / 2 + objectWidth / 2,\n );\n }\n return new PointsDistribution(points.map((p) => [p, 0]));\n}\n\nexport function linearSpread(\n gap: number,\n count: number,\n direction: \"x\" | \"y\" = \"x\",\n) {\n const totalLength = gap * (count - 1);\n const points: number[] = [];\n for (let i = 0; i < count; i++) {\n points.push(i * gap - totalLength / 2);\n }\n return new PointsDistribution(\n points.map((p) => (direction.toLowerCase() === \"x\" ? [p, 0] : [0, p])),\n );\n}\n"],"names":["Xe","ye","r","Ze","s","t","q","oe","ht","le","Dt","e","he","Me","Ot","mt$1","mt","n","ce","Pe","Ne","fe","Je","Z","Y","it","Q","Tt","pn","nt","Rt","J","St","be","H","It","Ke","He","Ve","i","tt","Qt","ts","Ee","yt","l","a","u","c","g","d","w","P","y","E","es","ss","et$1","et","ns","_e","at","Ft","o","h","is","Kt","wt","Zt","me","yn","Bt","je","ct","Mn","Pn","Se","zt","ke","Re","rs","os","R","L","S","D","v","$e","Le","$","ls","Ct","hs","as","us","cs","fs","ms","gs","st","ve","Ut","De","ws","Oe","ps","ds","Ie","ys","ot","lt","Pt","bt","ge","we","ae","Yt","Ht","Mt","Ms","Ps","bs","Es","_s","js","Ss","ks","Rs","vs","Is","Ts","Cs","As","Fs","xs","Ns","N","_","m","b","j","M","C","A","T","z","F","V","x","B","U","I","O","X","G","W","se","ne","ie","re","xt","Nt","Vt","$t","Lt","Te","Vs","At","ue","dt","K","Jt","K$1","pt","te","$s","ft","Ls","Ds","Os","Bs","zs","Us","Ys","Be","Ws","rt","ee$1","ut","pe$1","vt$1","Qs","vt","ze","ee","pe","Xt","Gt","Gs","Xs","Zs","Js","Ks","Hs","Ue","tn","en","sn","nn","Wt","Ye","We","rn","Qe","Ce","on","ln","qt","kt","Ge","En","qe","gt","hn","an","un","cn","fn","de","Ae","Et","p","Fe","jt","gn","_n","mn","xe","_t","In","k","f","wn","xn","Sn","bn","Cn","An","ct$1","Fn","vn","Bn","kn","On","Ln","Tn","qn","zn","Dn","Rn","Nn","dn","Vn","at$1","jn","Un","Hn","$n","Yn","Xn","Gn","Qn","Wn","Kn","Jn","Zn","Dieline","Transformable","body","cutLines","foldLines","foldLinesForwards","foldLinesBackwards","__publicField","cut","fold","direction","otherBody","commonLines","other","shape","eraseStrand","matrix","shapes","exportSVG","drawFlap","width","height","fillet","contraction","contractionMode","contractionLeftInput","contractionRightInput","leftContractionMode","rightContractionMode","contractionLeft","contractionRight","flapMaker","draw","topFlap","options","bottomFlap","leftFlap","contractionTop","contractionBottom","topContractionMode","bottomContractionMode","rightFlap","drawFlaps","drawBump","FoldLockBump","paperThickness","pen","dieline","PointsDistribution","points","linearDistribution","totalWidth","objectWidth","gapShare","margin","objectsCount","gapSize","linearSpread","gap","count","totalLength"],"mappings":"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"}