dielines 0.11.0 → 0.11.1

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.js","sources":["../../pantograph/dist/QuadraticBezier-B2g_Iyyl.js","../../pantograph/dist/models-DdZq-waE.js","../../pantograph/dist/draw-BJW5kfm9.js","../../pantograph/dist/svg-D8vwkQf7.js","../../pantograph/dist/pantograph.js","../src/Dieline.ts","../src/drawFlaps.ts","../src/FoldLockBump.ts","../src/linearDistribution.ts"],"sourcesContent":["var Oe = Object.defineProperty;\nvar Me = (r) => {\n throw TypeError(r);\n};\nvar Be = (r, s, t) => s in r ? Oe(r, s, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[s] = t;\nvar q = (r, s, t) => Be(r, typeof s != \"symbol\" ? s + \"\" : s, t), oe = (r, s, t) => s.has(r) || Me(\"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) ? Me(\"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);\nfunction zt(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 this.xMin = s, this.yMin = t, this.xMax = e, this.yMax = n;\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 zt(this.xMin, this.xMax, t, t) && zt(this.yMin, this.yMax, e, e);\n }\n overlaps(s) {\n return zt(this.xMin, this.xMax, s.xMin, s.xMax) && zt(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 ye = (r, s = 1e-9) => {\n let t = r;\n return Math.abs(r) < s && (t = 0), t.toFixed(-Math.log10(s));\n};\nfunction Te(r, s = 1e-9) {\n return Array.from(\n new Map(\n r.map(([t, e]) => [\n `[${ye(t, s)},${ye(e, s)}]`,\n [t, e]\n ])\n ).values()\n );\n}\nconst fe = Math.PI / 180, Ue = 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], It = ([r, s]) => r * r + s * s, an = ([r, s]) => Math.sqrt(It([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 Pe([r, s], [t, e]) {\n return r * t + s * e;\n}\nfunction un([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 Tt(r, s) {\n const t = Math.cos(s) * r, e = Math.sin(s) * r;\n return [t, e];\n}\nfunction Ye([r, s]) {\n return Math.atan2(s, r);\n}\nfunction We(r) {\n const s = J(r), t = Ye(r);\n return [s, t];\n}\nfunction Ie(r, s, t = 1e-9) {\n const e = St(r, s), n = It(r), i = It(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 Qe(r, s, t) {\n return Y(t, r) || Ie(Q(t, r), s);\n}\nconst Mt = (r, s) => {\n const [t, e, n, i, o, l, h, a, u] = r, [c, g, d, w, p, P, f, M, E] = s;\n return [\n t * c + e * w + n * f,\n t * g + e * p + n * M,\n t * d + e * P + n * E,\n i * c + o * w + l * f,\n i * g + o * p + l * M,\n i * d + o * P + l * E,\n h * c + a * w + u * f,\n h * g + a * p + u * M,\n h * d + a * P + u * E\n ];\n}, Ge = (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}, Xe = (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 s && (this._matrix = [...s]);\n }\n clone() {\n return new et(this._matrix);\n }\n transpose() {\n return this._matrix = Xe(this._matrix), this;\n }\n inverse() {\n return this._matrix = Ge(this._matrix), this;\n }\n translate(s, t) {\n return this._matrix = Mt([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 = Mt(i, this._matrix), t && this.translate(t[0], t[1]), this;\n }\n mirrorX() {\n return this._matrix = Mt([1, 0, 0, 0, -1, 0, 0, 0, 1], this._matrix), this;\n }\n mirrorY() {\n return this._matrix = Mt([-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 = Mt([-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 = Mt([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 Ze {\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 xt extends Ze {\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}\nclass at extends xt {\n constructor() {\n super(...arguments);\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 }\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 t instanceof at ? 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 = Pe(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 (!Ie(this.V, e)) return !1;\n const n = Pe(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 = Te(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 Je(r) {\n return Array.from(Array(r).keys());\n}\nfunction Kt(r) {\n const s = Math.min(...r.map((t) => t.length));\n return Je(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 = It(r.V), i = It(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 cn(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 = Te(\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 Ot = (r, s) => {\n const t = Q(r, s);\n return We(t);\n};\nclass ct extends xt {\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 (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 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 Tt(\n this.radius,\n this.firstAngle + t * this.angularLength * (this.clockwise ? -1 : 1)\n )\n );\n }\n pointToParam(t) {\n const [e, n] = Ot(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 !(t instanceof ct) || !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] = Ot(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] = Ot(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] = Ot(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 = Tt(1, n);\n return (this.clockwise ? Qt : tt)(H(o));\n }\n get tangentAtFirstPoint() {\n const t = Tt(1, this.firstAngle);\n return (this.clockwise ? Qt : tt)(H(t));\n }\n get tangentAtLastPoint() {\n const t = Tt(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 fn(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 mn(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 be = 1e-21, Bt = 1.618034;\nfunction Ee(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 + Bt * (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) < be ? i = 2 * be : 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 + Bt * (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 + Bt * (f - t), l = h, h = u, u = r(p), a += 1)) : (p = f + Bt * (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 _e = 0.381966, Ke = 1e-11;\nclass He {\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] = Ee(h);\n else if (a.length === 2)\n [i, o, l, s, t, e, n] = Ee(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 M = this.tol * Math.abs(o) + Ke, E = 2 * M, R = 0.5 * (g + d);\n if (Math.abs(o - R) < E - 0.5 * (d - g))\n break;\n if (Math.abs(w) <= M)\n o >= R ? w = g - o : w = d - o, P = _e * 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 = M : P = -M)) : (o >= R ? w = g - o : w = d - o, P = _e * w);\n }\n Math.abs(P) < M ? P >= 0 ? f = o + M : f = o - M : 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 Ce(r, s = 1e-8, t = 1e3) {\n const e = new He(r, s, t);\n return e.setBracket([0, 1]), e.run();\n}\nfunction qe(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 ts = Object.prototype.toString;\nfunction Ct(r) {\n const s = ts.call(r);\n return s.endsWith(\"Array]\") && !s.includes(\"Big\");\n}\nconst es = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n isAnyArray: Ct\n}, Symbol.toStringTag, { value: \"Module\" })), ss = /* @__PURE__ */ qe(es);\nfunction ns(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 is(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 rs(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 = is(r), n = ns(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 os = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({\n __proto__: null,\n default: rs\n}, Symbol.toStringTag, { value: \"Module\" })), ls = /* @__PURE__ */ qe(os);\nObject.defineProperty($, \"__esModule\", { value: !0 });\nvar st = ss, je = ls;\nconst Ut = \" \".repeat(2), Fe = \" \".repeat(4);\nfunction hs() {\n return xe(this);\n}\nfunction xe(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${Fe}${as(r, t, e, n, i)}\n${Ut}]\n${Ut}rows: ${r.rows}\n${Ut}columns: ${r.columns}\n}`;\n}\nfunction as(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(us(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${Fe}`);\n}\nfunction us(r, s, t) {\n return (r >= 0 && t ? ` ${Se(r, s - 1)}` : Se(r, s)).padEnd(s);\n}\nfunction Se(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 cs(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 yt(r) {\n if (r.isEmpty())\n throw new Error(\"Empty matrix has no elements to index\");\n}\nfunction fs(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 ms(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 gs(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 ws(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 ps(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 ds(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 Ms(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 ys(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 Ps(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 bs(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 Es(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 _s(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 js(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 Ss(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 ks(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 Rs(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 vs(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 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}\nclass V {\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 V.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 yt(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 yt(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), yt(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), yt(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), yt(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), yt(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 V.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), M = c + w - p + f, E = d + p, R = g + w, v = c - g + d + P;\n return t.set(0, 0, M), 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), M = 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 - M + 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), y = (a + u) * (-g + w), C = (e + n + i - l - h - a - u) * f, F = u * (-g + w + p - P - f - M + E), I = (-i + u + c) * (P + M - E), B = (i - c) * (P - E), x = i * M, N = (u + c) * (-M + E), A = (-i + l + h) * (f + M - R), O = (i - h) * (f - R), U = (l + h) * (-M + R), T = n * p, z = h * E, X = o * w, G = a * d, W = c * R, se = m + x + T, ne = v + k + D + m + I + x + N, ie = m + b + y + C + x + A + U, re = L + S + k + m + x + A + O, At = L + k + D + m + z, Vt = x + A + O + U + X, Nt = m + b + j + F + I + B + x, $t = I + B + x + N + G, Lt = m + b + j + y + 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, At), t.set(1, 2, Vt), t.set(2, 0, Nt), 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 = V.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), M = 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 V.add(f, S),\n V.add(M, k),\n p,\n P\n ), m = u(V.add(v, S), M, p, P), b = u(f, V.sub(R, k), p, P), j = u(S, V.sub(L, M), p, P), y = u(V.add(f, E), k, p, P), C = u(\n V.sub(v, f),\n V.add(M, R),\n p,\n P\n ), F = u(\n V.sub(E, S),\n V.add(L, k),\n p,\n P\n ), I = V.add(D, j);\n I.sub(y), I.add(F);\n let B = V.add(b, y), x = V.add(m, j), N = V.sub(D, m);\n N.add(b), N.add(C);\n let A = V.zeros(2 * I.rows, 2 * I.columns);\n return A = A.setSubMatrix(I, 0, 0), A = A.setSubMatrix(B, I.rows, 0), A = A.setSubMatrix(x, 0, I.columns), A = A.setSubMatrix(N, I.rows, I.columns), A.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 && je(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 && je(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 = ke) {\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 = ke) {\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 fs(this);\n case \"column\":\n return ms(this);\n case void 0:\n return gs(this);\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n product(s) {\n switch (s) {\n case \"row\":\n return ws(this);\n case \"column\":\n return ps(this);\n case void 0:\n return ds(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 Ms(this, e, n);\n }\n case \"column\": {\n if (!st.isAnyArray(n))\n throw new TypeError(\"mean must be an array\");\n return ys(this, e, n);\n }\n case void 0: {\n if (typeof n != \"number\")\n throw new TypeError(\"mean must be a number\");\n return Ps(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 bs(this, e), this;\n }\n case \"column\": {\n if (!st.isAnyArray(e))\n throw new TypeError(\"center must be an array\");\n return Es(this, e), this;\n }\n case void 0: {\n if (typeof e != \"number\")\n throw new TypeError(\"center must be a number\");\n return _s(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 = js(this);\n else if (!st.isAnyArray(e))\n throw new TypeError(\"scale must be an array\");\n return Ss(this, e), this;\n }\n case \"column\": {\n if (e === void 0)\n e = ks(this);\n else if (!st.isAnyArray(e))\n throw new TypeError(\"scale must be an array\");\n return Rs(this, e), this;\n }\n case void 0: {\n if (e === void 0)\n e = vs(this);\n else if (typeof e != \"number\")\n throw new TypeError(\"scale must be a number\");\n return Ts(this, e), this;\n }\n default:\n throw new Error(`invalid option: ${s}`);\n }\n }\n toString(s) {\n return xe(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}\nV.prototype.klass = \"Matrix\";\ntypeof Symbol < \"u\" && (V.prototype[Symbol.for(\"nodejs.util.inspect.custom\")] = hs);\nfunction ke(r, s) {\n return r - s;\n}\nfunction Is(r) {\n return r.every((s) => typeof s == \"number\");\n}\nV.random = V.rand;\nV.randomInt = V.randInt;\nV.diagonal = V.diag;\nV.prototype.diagonal = V.prototype.diag;\nV.identity = V.eye;\nV.prototype.negate = V.prototype.neg;\nV.prototype.tensorProduct = V.prototype.kroneckerProduct;\nvar Ft, ue, dt;\nlet _ = (dt = class extends V {\n constructor(t, e) {\n super();\n le(this, Ft);\n /**\n * @type {Float64Array[]}\n */\n q(this, \"data\");\n if (dt.isMatrix(t))\n he(this, Ft, ue).call(this, t.rows, t.columns), dt.copy(t, this);\n else if (Number.isInteger(t) && t >= 0)\n he(this, Ft, 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 (!Is(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}, Ft = 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);\ncs(V, _);\nvar K;\nconst Jt = class Jt extends V {\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 V {\n constructor(s, t, e) {\n super(), this.matrix = s, this.rows = t, this.columns = e;\n }\n}\nclass Cs 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 qs 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 Fs 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 xs 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 As 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 Vs 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 Ns 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 $s 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 Ae extends V {\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 V {\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 Ls(r, s) {\n if (st.isAnyArray(r))\n return r[0] && st.isAnyArray(r[0]) ? new rt(r) : new Ae(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), M = 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 y = m; y < e; y++)\n j += c.get(y, m) * c.get(y, b);\n j = -j / c.get(m, m);\n for (let y = m; y < e; y++)\n c.set(y, b, c.get(y, b) + j * c.get(y, 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 M[b] = 0;\n for (let b = m + 1; b < e; b++)\n for (let j = m + 1; j < n; j++)\n M[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 y = m + 1; y < e; y++)\n c.set(y, b, c.get(y, b) + j * M[y]);\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 y = m; y < e; y++)\n j += p.get(y, m) * p.get(y, b);\n j = -j / p.get(m, m);\n for (let y = m; y < e; y++)\n p.set(y, b, p.get(y, b) + j * p.get(y, 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 y = m + 1; y < n; y++)\n j += P.get(y, m) * P.get(y, b);\n j = -j / P.get(m + 1, m);\n for (let y = m + 1; y < n; y++)\n P.set(y, b, P.get(y, b) + j * P.get(y, 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 y = (j !== S ? Math.abs(f[j]) : 0) + (j !== m + 1 ? Math.abs(f[j - 1]) : 0);\n if (Math.abs(w[j]) <= D * y) {\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 y = S - 2; y >= m; y--) {\n let C = ut(w[y], j), F = w[y] / C, I = j / C;\n if (w[y] = C, y !== m && (j = -I * f[y - 1], f[y - 1] = F * f[y - 1]), a)\n for (let B = 0; B < n; B++)\n C = F * P.get(B, y) + I * P.get(B, S - 1), P.set(B, S - 1, -I * P.get(B, y) + F * P.get(B, S - 1)), P.set(B, y, C);\n }\n break;\n }\n case 2: {\n let j = f[m - 1];\n f[m - 1] = 0;\n for (let y = m; y < S; y++) {\n let C = ut(w[y], j), F = w[y] / C, I = j / C;\n if (w[y] = C, j = -I * f[y], f[y] = F * f[y], h)\n for (let B = 0; B < e; B++)\n C = F * p.get(B, y) + I * p.get(B, m - 1), p.set(B, m - 1, -I * p.get(B, y) + F * p.get(B, m - 1)), p.set(B, y, 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 ), y = w[S - 1] / j, C = w[S - 2] / j, F = f[S - 2] / j, I = w[m] / j, B = f[m] / j, x = ((C + y) * (C - y) + F * F) / 2, N = y * F * (y * F);\n let A = 0;\n (x !== 0 || N !== 0) && (x < 0 ? A = 0 - Math.sqrt(x * x + N) : A = Math.sqrt(x * x + N), A = N / (x + A));\n let O = (I + y) * (I - y) + A, U = I * B;\n for (let T = m; T < S - 1; T++) {\n let z = ut(O, U);\n z === 0 && (z = Number.MIN_VALUE);\n let X = O / z, G = U / z;\n if (T !== m && (f[T - 1] = z), O = X * w[T] + G * f[T], f[T] = X * f[T] - G * w[T], U = G * w[T + 1], w[T + 1] = X * w[T + 1], a)\n for (let W = 0; W < n; W++)\n z = X * P.get(W, T) + G * P.get(W, T + 1), P.set(W, T + 1, -G * P.get(W, T) + X * P.get(W, T + 1)), P.set(W, T, z);\n if (z = ut(O, U), z === 0 && (z = Number.MIN_VALUE), X = O / z, G = U / z, w[T] = z, O = X * f[T] + G * w[T + 1], w[T + 1] = -G * f[T] + X * w[T + 1], U = G * f[T + 1], f[T + 1] = X * f[T + 1], h && T < e - 1)\n for (let W = 0; W < e; W++)\n z = X * p.get(W, T) + G * p.get(W, T + 1), p.set(W, T + 1, -G * p.get(W, T) + X * p.get(W, T + 1)), p.set(W, T, z);\n }\n f[S - 2] = O;\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 y = 0; y < n; y++)\n j = P.get(y, m + 1), P.set(y, m + 1, P.get(y, m)), P.set(y, m, j);\n if (h && m < e - 1)\n for (let y = 0; y < e; y++)\n j = p.get(y, m + 1), p.set(y, m + 1, p.get(y, m)), p.set(y, 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 Ds(r, s = !1) {\n return r = rt.checkMatrix(r), s ? new vt(r).inverse() : Ve(r, _.eye(r.rows));\n}\nfunction Ve(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 zs(r, s) {\n let t = [];\n for (let e = 0; e < r; e++)\n e !== s && t.push(e);\n return t;\n}\nfunction Os(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 Bs(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(zs(n, o)).transpose(), u = new vt(h).solve(l), c = _.sub(l, h.mmul(u)).abs().max();\n i.setRow(\n o,\n Os(c, u, o, t, e)\n );\n }\n return i;\n}\nfunction Us(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 Ys(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 Ws(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 Ne = 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 Qs(n, l, o, i), Gs(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 Xs(n, g, d, i), Zs(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 Qs(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 Gs(r, s, t, e) {\n let n, i, o, l, h, a, u, c, g, d, w, p, P, f, M, 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], M = 0, E = 0, o = u - 1; o >= a; o--)\n for (P = p, p = w, E = M, n = w * s[o], i = w * c, g = ut(c, s[o]), s[o + 1] = M * g, M = s[o] / g, w = c / g, c = w * t[o] - M * n, t[o + 1] = i + M * (w * n + M * t[o]), h = 0; h < r; h++)\n i = e.get(h, o + 1), e.set(h, o + 1, M * e.get(h, o) + w * i), e.set(h, o, w * e.get(h, o) - M * i);\n c = -M * E * P * f * s[a] / d, s[a] = M * 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 Xs(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 Zs(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, M, E, R, v, L, S, k, D, m, b, j, y, C, F;\n for (f = 0; f < r; f++)\n for ((f < o || f > l) && (t[f] = n.get(f, f), s[f] = 0), M = Math.max(f - 1, 0); M < r; M++)\n u = u + Math.abs(n.get(f, M));\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, M = i - 1; M < r; M++)\n p = n.get(i - 1, M), n.set(i - 1, M, g * p + c * n.get(i, M)), n.set(i, M, g * n.get(i, M) - 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, M = E; M < r; M++)\n c = n.get(E, M) + g * n.get(E + 1, M), C && (c = c + d * n.get(E + 2, M), n.set(E + 2, M, n.get(E + 2, M) - c * p)), n.set(E, M, n.get(E, M) - c * k), n.set(E + 1, M, n.get(E + 1, M) - 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, M = R; M <= i; M++)\n d = d + n.get(f, M) * n.get(M, 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 (M = f; M <= i; M++)\n n.set(M, i, n.get(M, 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))) : (F = Wt(0, -n.get(i - 1, i), n.get(i - 1, i - 1) - c, g), n.set(i - 1, i - 1, F[0]), n.set(i - 1, i, F[1])), n.set(i, i - 1, 0), n.set(i, i, 1), f = i - 2; f >= 0; f--) {\n for (m = 0, b = 0, M = R; M <= i; M++)\n m = m + n.get(f, M) * n.get(M, i - 1), b = b + n.get(f, M) * n.get(M, 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 ? (F = Wt(-m, -b, S, g), n.set(f, i - 1, F[0]), n.set(f, i, F[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, y = (t[f] - c) * 2 * g, j === 0 && y === 0 && (j = h * u * (Math.abs(S) + Math.abs(g) + Math.abs(k) + Math.abs(D) + Math.abs(p))), F = Wt(\n k * d - p * m + g * b,\n k * w - p * b - g * m,\n j,\n y\n ), n.set(f, i - 1, F[0]), n.set(f, i, F[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 )) : (F = 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, F[0]), n.set(f + 1, i, F[1]))), L = Math.max(Math.abs(n.get(f, i - 1)), Math.abs(n.get(f, i))), h * L * L > 1)\n for (M = f; M <= i; M++)\n n.set(M, i - 1, n.get(M, i - 1) / L), n.set(M, i, n.get(M, i) / L);\n }\n for (f = 0; f < r; f++)\n if (f < o || f > l)\n for (M = f; M < r; M++)\n e.set(f, M, n.get(f, M));\n for (M = r - 1; M >= o; M--)\n for (f = o; f <= l; f++) {\n for (p = 0, E = o; E <= Math.min(M, l); E++)\n p = p + e.get(f, E) * n.get(E, M);\n e.set(f, M, 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 $e {\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 Le {\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 = V;\n$.CHO = $e;\n$.CholeskyDecomposition = $e;\n$.DistanceMatrix = te;\n$.EVD = Ne;\nvar Js = $.EigenvalueDecomposition = Ne;\n$.LU = ee;\n$.LuDecomposition = ee;\nvar De = $.Matrix = _;\n$.MatrixColumnSelectionView = qs;\n$.MatrixColumnView = Cs;\n$.MatrixFlipColumnView = Fs;\n$.MatrixFlipRowView = xs;\n$.MatrixRowSelectionView = Vs;\n$.MatrixRowView = As;\n$.MatrixSelectionView = Gt;\n$.MatrixSubView = Ns;\n$.MatrixTransposeView = $s;\n$.NIPALS = Le;\n$.Nipals = Le;\n$.QR = pe;\n$.QrDecomposition = pe;\n$.SVD = vt;\n$.SingularValueDecomposition = vt;\n$.SymmetricMatrix = pt;\n$.WrapperMatrix1D = Ae;\n$.WrapperMatrix2D = rt;\n$.correlation = Ws;\n$.covariance = Ys;\nvar Re = $.default = _;\n$.determinant = Xt;\n$.inverse = Ds;\n$.linearDependencies = Bs;\n$.pseudoInverse = Us;\n$.solve = Ve;\n$.wrap = Ls;\nconst Ks = Js, Hs = De;\nRe.Matrix && Re.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 ze(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 wn(r, s, t, e, n) {\n if (n == 0)\n return ze(r, s, t, e);\n const i = e / n, o = t / n, l = s / n, h = r / n;\n let a = ve(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 = ve(\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 ve(r, s, t, e, n) {\n const i = tn(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 tn(r, s, t, e, n) {\n function i(x, N, A, O) {\n const U = gt(x + A, r), T = gt(N + x * A + O, s), z = gt(N * A + x * O, t);\n return U + T + z;\n }\n function o(x, N, A, O) {\n return i(x, N, A, O) + gt(N * O, 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 x = a / p, N = u / p, A = c / p, O = g / p;\n d = x * A - 4 / p * O - 1 / 3 * N * N, w = (x * A - 8 / p * O - 2 / 9 * N * N) * (1 / 3) * N - A * (A / p) - x * x * O;\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 = en(d, w);\n n && (P *= p);\n const f = r * 0.5, M = 1 / 6 * s + 0.5 * P, E = t - r * M, R = 2 / 3 * s - P - f * f, v = 0.5 * E / R, L = 2 * (e - M * M) / E, S = 0.5 * E / L;\n let k = 0, D = 0, m = 0;\n for (let x = 0; x < 3; x++) {\n const N = x == 1 ? S : R, A = x == 0 ? v : L, O = gt(N + f * f + 2 * M, s), U = gt(2 * (N * A + f * M), t), T = gt(N * A * A + M * M, e), z = O + U + T;\n (x == 0 || z < m) && (k = N, D = A, m = z);\n }\n const b = k, j = D;\n let y = 0, C = 0, F = 0, I = 0;\n if (b < 0) {\n const x = Math.sqrt(-b);\n if (y = f + x, C = M + x * j, F = f - x, I = M - x * j, Math.abs(I) < Math.abs(C) ? I = e / C : Math.abs(I) > Math.abs(C) && (C = e / I), Math.abs(y) != Math.abs(F)) {\n let N = null, A = null;\n if (Math.abs(y) < Math.abs(F)) {\n const U = (t - C * F) / I, T = (s - I - C) / F;\n N = [r - F, U, T], A = [F, F, F];\n } else {\n const U = (t - y * I) / C, T = (s - I - C) / y, z = r - y;\n N = [y, y, y], A = [z, U, T];\n }\n let O = 0;\n for (let U = 0; U < 3; U++) {\n const T = N[U], z = A[U];\n if (isFinite(T) && isFinite(z)) {\n const X = i(T, C, z, I);\n (U == 0 || X < O) && (y = T, F = z, O = X);\n }\n }\n }\n } else if (b == 0) {\n const x = e - M * M;\n y = f, C = M + Math.sqrt(-x), F = f, I = M - Math.sqrt(-x), Math.abs(C) > Math.abs(I) ? I = e / C : Math.abs(I) > Math.abs(C) && (C = e / I);\n } else\n return [];\n let B = o(y, C, F, I);\n for (let x = 0; x < 8 && B != 0; x++) {\n const N = C * I - e, A = C * F + y * I - t, O = C + y * F + I - s, U = y + F - r, T = y - F, z = C * C - C * (F * T + 2 * I) + I * (y * T + I);\n if (z == 0)\n break;\n const X = 1 / z, G = I - C, W = C * F - y * I, se = T * N + G * A + W * O - (C * G + y * W) * U, ne = (y * T + G) * N - C * (T * A + G * O + W * U), ie = -T * N - G * A - W * O + (F * W + I * G) * U, re = -(F * T + G) * N + I * (T * A + G * O + W * U), At = y - X * se, Vt = C - X * ne, Nt = F - X * ie, $t = I - X * re, Lt = o(At, Vt, Nt, $t);\n if (Lt < B)\n y = At, C = Vt, F = Nt, I = $t, B = Lt;\n else\n break;\n }\n return [y, C, F, I];\n}\nfunction en(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 sn(r, s = 1e-9) {\n if (r[r.length - 1] == 0)\n return sn(r.slice(0, -1), s);\n const t = new Hs([\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 Ks(t);\n return e.realEigenvalues.filter(\n (n, i) => Math.abs(e.imaginaryEigenvalues[i]) < s\n );\n}\nconst nn = (r, s, t) => [r[0] * (1 - t) + s[0] * t, r[1] * (1 - t) + s[1] * t];\nfunction rn(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 = rn(r).map(([e, n]) => nn(e, n, s));\n return r.length === 2 ? [t] : [...de(t, s), t];\n}\nclass Et extends xt {\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 this.firstControlPoint = n, this.lastControlPoint = i;\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 = Ce((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 ze(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}\nclass jt extends xt {\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 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 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 * Ue}, ${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 Tt(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 ln(\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 (Qe(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 pn(r, s, t, e, n, i, o) {\n const { center: l, rx: h, ry: a } = on(\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 on([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 M = 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((M * M - 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 ln(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, M = Math.hypot(w, p), E = Math.hypot(P, f);\n i = Math.min(1, Math.max(0, (P * M / E + g) / l)), o = Math.min(1, Math.max(0, (f * M / 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}\nclass _t extends xt {\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 this.controlPoint = n;\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 = Ce((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 cn as F,\n Ze as G,\n Ie as H,\n Z as I,\n at as L,\n _t as Q,\n Ue as R,\n et as T,\n it as a,\n Q as b,\n St as c,\n Pe as d,\n J as e,\n Qt as f,\n Y as g,\n fn as h,\n pn as i,\n We as j,\n Tt as k,\n Te as l,\n me as m,\n H as n,\n Ye as o,\n tt as p,\n Rt as q,\n Je as r,\n nt as s,\n mn as t,\n un as u,\n an as v,\n sn as w,\n wn as x,\n It as y,\n Kt as z\n};\n//# sourceMappingURL=QuadraticBezier-B2g_Iyyl.js.map\n","var nn = Object.defineProperty;\nvar en = (t, n, e) => n in t ? nn(t, n, { enumerable: !0, configurable: !0, writable: !0, value: e }) : t[n] = e;\nvar C = (t, n, e) => en(t, typeof n != \"symbol\" ? n + \"\" : n, e);\nimport { b as k, d as sn, e as Tt, a as z, s as V, n as on, p as Lt, l as U, A as S, g as P, w as qt, E as M, T as rn, x as ln, Q as I, y as $, C as A, c as un, v as cn, L as b, F as zt, G as ut, z as N, H as an, m as fn, q as hn, I as mt, B as pn } from \"./QuadraticBezier-B2g_Iyyl.js\";\nfunction dn(t, n) {\n const e = k(n, t.firstPoint), s = sn(e, t.V) / t.squareLength;\n return t.paramPoint(s);\n}\nfunction K(t, n, e) {\n const s = e || t.precision, i = dn(t, n.center), o = Tt(i, n.center);\n if (o > n.radius + s) return [];\n if (Math.abs(o - n.radius) < s) {\n const c = i;\n return t.isOnSegment(c) && n.isOnSegment(c) ? [c] : [];\n }\n const l = [], r = Math.sqrt(\n n.radius * n.radius - o * o\n ), u = t.tangentAtFirstPoint, a = z(i, V(u, r));\n t.isOnSegment(a) && n.isOnSegment(a) && l.push(a);\n const f = z(i, V(u, -r));\n return t.isOnSegment(f) && n.isOnSegment(f) && l.push(f), l;\n}\nconst mn = (t) => {\n const { firstPoint: n, lastPoint: e, center: s, clockwise: i } = t;\n return new S(e, n, s, i, {\n ignoreChecks: !0\n });\n}, gn = (t, n) => {\n if (t.isSame(n))\n return [t];\n const e = U(\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(mn(n)) ? [] : [new S(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 S(\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 S(e[0], e[1], t.center, t.clockwise),\n new S(e[2], e[3], t.center, t.clockwise)\n ];\n throw new Error(\"Bug in the arc arc overlap algorithm\");\n};\nfunction Dt(t, n, e = !1, s) {\n const i = s || t.precision, o = Tt(t.center, n.center), l = t.radius + n.radius;\n if (o > l + i)\n return [];\n const r = Math.abs(t.radius - n.radius);\n if (o < r - i)\n return [];\n if (o < i)\n return r > i ? [] : e ? gn(t, n) : [];\n const u = on(k(n.center, t.center)), a = o > l - i;\n if (\n // circles are outside each other\n a || // circles are inside each other\n Math.abs(o - r) < i\n ) {\n const g = a || t.radius > n.radius ? 1 : -1, w = z(\n t.center,\n V(u, g * t.radius)\n );\n return t.isOnSegment(w) && n.isOnSegment(w) ? [w] : [];\n }\n const f = t.radius * t.radius / (2 * o) - n.radius * n.radius / (2 * o) + o / 2, c = z(\n t.center,\n V(u, f)\n ), h = Math.sqrt(\n t.radius * t.radius - f * f\n ), p = Lt(u), d = z(c, V(p, h)), m = z(c, V(p, -h)), x = [];\n return t.isOnSegment(d) && n.isOnSegment(d) && x.push(d), t.isOnSegment(m) && n.isOnSegment(m) && x.push(m), x;\n}\nfunction st(t, n, e = 1e-9) {\n const s = t.transform(n.ellipseReferenceFrameTransform), i = s.slope, o = s.yIntercept, l = n.majorRadius * n.majorRadius, r = n.minorRadius * n.minorRadius, u = n.majorRadius * n.minorRadius, a = s.slope * s.slope, f = s.yIntercept * s.yIntercept, c = (g) => g.map(\n (w) => n.reverseEllipseReferenceFrameTransform.transform(w)\n ).filter((w) => t.isOnSegment(w) && n.isOnSegment(w));\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 w = n.minorRadius * Math.sqrt(1 - g * g / l), F = [g, w], y = [g, -w];\n return c([F, y]);\n }\n const h = l * a + r - f;\n if (h < -e)\n return [];\n const p = l * a + r;\n if (Math.abs(h) < e) {\n const g = -(l * i * o) / p, w = r * o / p;\n return c([[g, w]]);\n }\n const d = Math.sqrt(h), m = [\n -(l * i * o + u * d) / p,\n (r * o - u * i * d) / p\n ], x = [\n -(l * i * o - u * d) / p,\n (r * o + u * i * d) / p\n ];\n return c([m, x]);\n}\nfunction Rt(t, n) {\n const e = Math.max(t.precision, n.precision), s = t.coefficients, i = s.x2, o = s.xy, l = s.y2, r = 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, x = f.c, g = {\n z0: a * i * d * d + i * i * x * x - r * i * d * x + c * c * a * a - 2 * i * x * c * a - r * d * c * a + c * r * r * x,\n z1: m * r * r * c - x * d * i * o - 2 * i * x * c * u - a * c * h * r + 2 * d * h * i * a + 2 * m * x * i * i + d * d * i * u - m * d * i * r - 2 * i * m * c * a - a * c * d * o + 2 * a * u * c * c - x * h * i * r - u * c * d * r + 2 * x * o * c * r,\n z2: m * m * i * i + 2 * p * x * i * i - u * c * d * o + x * c * o * o - u * c * h * r - x * h * i * o - 2 * i * m * c * u + 2 * d * h * i * u - p * d * i * r - 2 * i * p * c * a + h * h * i * a + 2 * m * o * c * r + u * u * c * c - l * c * d * r - m * h * i * r + 2 * a * l * c * c - a * c * h * o + p * r * r * c + d * d * i * l - m * d * i * o - 2 * i * x * c * l,\n z3: -2 * i * c * l * m + m * c * o * o + 2 * p * o * c * r - l * c * h * r + h * h * i * u - m * h * i * o - 2 * i * p * c * u - u * c * h * o - p * h * i * r + 2 * m * p * i * i + 2 * u * l * c * c - l * c * d * o + 2 * d * h * i * l - p * d * i * o,\n z4: i * i * p * p - 2 * i * p * c * l + c * c * l * l - o * i * h * p - o * h * c * l + o * o * c * p + l * i * h * h\n }, F = qt(\n [g.z0, g.z1, g.z2, g.z3, g.z4],\n e\n ).flatMap((y) => {\n const R = i * h * y + i * d - c * o * y - c * r;\n if (R)\n return [[-(i * x + i * p * y * y - c * l * y * y + i * m * y - c * u * y - c * a) / R, y]];\n const T = o * y + r, L = -T / (2 * i), j = l * y * y + u * y + a, q = T * T / (4 * i * i) - j / i;\n if (Math.abs(q) < e)\n return [[L, y]];\n if (q > 0) {\n const H = Math.sqrt(q);\n return [[L + H, y], [L - H, y]];\n }\n return [];\n });\n return U(F, e);\n}\nfunction gt(t, n) {\n return Rt(t, n).filter((s) => t.isOnSegment(s) && n.isOnSegment(s));\n}\nconst Pn = (t) => {\n const {\n firstPoint: n,\n lastPoint: e,\n center: s,\n majorRadius: i,\n minorRadius: o,\n tiltAngle: l,\n clockwise: r\n } = t;\n return new M(\n e,\n n,\n s,\n i,\n o,\n l,\n r,\n {\n ignoreChecks: !0,\n angleUnits: \"rad\"\n }\n );\n}, wn = (t, n) => {\n if (t.isSame(n))\n return [t];\n const e = (i, o) => new M(\n i,\n o,\n t.center,\n t.majorRadius,\n t.minorRadius,\n t.tiltAngle,\n t.clockwise,\n { ignoreChecks: !0, angleUnits: \"rad\" }\n ), s = U(\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, o) => t.pointToParam(i) - t.pointToParam(o));\n if (s.length === 0) return [];\n if (s.length === 1) return [];\n if (s.length === 2)\n return t.isSame(Pn(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 xn(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 ? wn(t, n) : [] : Rt(t, n).filter((l) => t.isOnSegment(l) && n.isOnSegment(l));\n}\nfunction Pt(t, n) {\n const [e, s] = t.firstPoint, [i, o] = t.lastPoint, l = new rn().translate(-e, -s).rotate(-Math.atan2(o - s, i - e)), r = l.clone().inverse(), u = n.transform(l);\n return u.paramsAtY(0).map((a) => u.paramPoint(a)).map((a) => r.transform(a)).filter((a) => t.isOnSegment(a));\n}\nconst Sn = (t, n = 1e-9) => {\n let e = t;\n return Math.abs(t) < n && (e = 0), e.toFixed(-Math.log10(n));\n};\nfunction Vt(t, n = 1e-9) {\n return Array.from(\n new Map(t.map((e) => [Sn(e, n), e])).values()\n );\n}\nconst yn = (t, n) => {\n const [[e, s, i, o], [l, r, u, a]] = n.polynomialCoefficients, f = t.coefficients, c = f.x2, h = f.xy, p = f.y2, d = f.x, m = f.y, x = f.c, g = e * e, w = s * s, F = i * i, y = o * o, R = l * l, T = r * r, L = u * u, j = a * a, q = x + d * e + c * g + m * l + h * e * l + p * R, H = d * s + 2 * c * e * s + h * s * l + m * r + h * e * r + 2 * p * l * r, Wt = c * w + d * i + 2 * c * e * i + h * i * l + h * s * r + p * T + m * u + h * e * u + 2 * p * l * u, Jt = 2 * c * s * i + d * o + 2 * c * e * o + h * o * l + h * i * r + h * s * u + 2 * p * r * u + m * a + h * e * a + 2 * p * l * a, Kt = c * F + 2 * c * s * o + h * o * r + h * i * u + p * L + h * s * a + 2 * p * r * a, Zt = 2 * c * i * o + h * o * u + h * i * a + 2 * p * u * a, tn = c * y + h * o * a + p * j;\n return [q, H, Wt, Jt, Kt, Zt, tn];\n};\nfunction wt(t, n) {\n const e = Math.max(t.precision, n.precision), s = yn(t, n), i = qt(s, e).filter((o) => o >= -n.precision && o <= 1 + n.precision);\n return Vt(i, e).map((o) => n.paramPoint(o)).filter((o) => t.isOnSegment(o));\n}\nconst bn = (t, n) => {\n const [[e, s, i], [o, l, r]] = 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, x = s * s, g = i * i, w = o * o, F = l * l, y = r * r, R = a * m + f * e * o + c * w + h * e + p * o + d, T = 2 * a * e * s + f * e * l + f * s * o + 2 * c * o * l + h * s + p * l, L = 2 * a * e * i + a * x + f * e * r + f * s * l + f * i * o + 2 * c * o * r + c * F + h * i + p * r, j = 2 * a * s * i + f * s * r + f * i * l + 2 * c * l * r, q = a * g + f * i * r + c * y;\n return [R, T, L, j, q];\n};\nfunction xt(t, n) {\n const e = Math.max(t.precision, n.precision), s = bn(t, n), i = ln(...s).filter((o) => o >= -n.precision && o <= 1 + n.precision);\n return Vt(i, e).map((o) => n.paramPoint(o)).filter((o) => t.isOnSegment(o));\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] : un(i, k(t, n)) / cn(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 Cn = 3 / 4, Mn = 4 / 9;\nfunction In(t) {\n const n = E(t.firstControlPoint, t), e = E(t.lastControlPoint, t), s = n * e > 0 ? Cn : Mn;\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 An(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 En(t) {\n if (t instanceof A)\n return In(t);\n if (t instanceof I)\n return An(t);\n throw new Error(\"Not implemented\");\n}\nfunction Fn(t) {\n const n = t.paramPoint(0.5), e = Lt(k(n, t.firstPoint)), s = z(n, e), i = {\n firstPoint: n,\n lastPoint: s\n }, o = [\n E(t.firstPoint, i),\n E(t.lastPoint, i)\n ];\n return t instanceof A ? o.push(\n E(t.firstControlPoint, i),\n E(t.lastControlPoint, i)\n ) : t instanceof I && o.push(E(t.controlPoint, i)), new ct(\n n,\n s,\n Math.min(...o),\n Math.max(...o)\n );\n}\nfunction St(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 o = t[s - 1], l = n - o[1], r = n - i[1];\n if (l * r < 0) {\n e.push(\n o[0] + (n - o[1]) * (i[0] - o[0]) / (i[1] - o[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 vn(t, n) {\n if (t instanceof A)\n return new kn([\n E(t.firstPoint, n),\n E(t.firstControlPoint, n),\n E(t.lastControlPoint, n),\n E(t.lastPoint, n)\n ]);\n if (t instanceof I)\n return new Bn([\n E(t.firstPoint, n),\n E(t.controlPoint, n),\n E(t.lastPoint, n)\n ]);\n throw new Error(\"Not implemented\");\n}\nclass Bn {\n constructor(n) {\n C(this, \"topHull\", []);\n C(this, \"bottomHull\", []);\n this.distances = n;\n const [e, s, i] = n, o = [0, e], l = [1 / 2, s], r = [1, i], u = i - e, a = e;\n s - (u * (1 / 2) + a) > 0 ? (this.topHull = [o, l, r], this.bottomHull = [o, r]) : (this.topHull = [o, r], this.bottomHull = [o, l, r]);\n }\n get startDistance() {\n return this.distances[0];\n }\n get endDistance() {\n return this.distances[2];\n }\n}\nclass kn {\n constructor(n) {\n C(this, \"topHull\", []);\n C(this, \"bottomHull\", []);\n this.distances = n;\n const [e, s, i, o] = n, l = [0, e], r = [1 / 3, s], u = [2 / 3, i], a = [1, o], f = o - 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, r, a], m = [l, u, a];\n else {\n const g = h / p;\n g >= 2 ? (d = [l, r, a], m = [l, a]) : g <= 0.5 ? (d = [l, u, a], m = [l, a]) : (d = [l, r, 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 yt(t, n) {\n const e = vn(n, t), s = St(\n e.topHull,\n t.negativeThickness\n ), i = St(\n e.bottomHull,\n t.positiveThickness\n ), o = e.endDistance >= t.negativeThickness && e.endDistance <= t.positiveThickness;\n if (!s.length && !i.length)\n return o ? 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]) : o ? new Y(l[0], \"end\") : new Y(\"start\", l[0]);\n}\nfunction bt(t, n) {\n const e = En(t), s = yt(e, n);\n if (!s)\n return null;\n const i = Fn(t), o = yt(\n i,\n n\n );\n return o ? s.size > o.size ? o.clipCurve(n) : s.clipCurve(n) : null;\n}\nconst W = (t) => t instanceof I ? $(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 o = t, l = n, r = W(o), u = W(l);\n for (let a = 0; a < s; a++) {\n const f = r > i ? bt(l, o) : o;\n if (!f) return [];\n const c = W(f), h = u > i ? bt(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 * r && p > 0.8 * u)\n if (c / r > p / u) {\n const [d, m] = f.splitAtParameters([\n 0.5\n ]);\n return U(\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 U(\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 o = f, l = h, r = c, u = p;\n }\n throw new Error(\"Bézier clip: Maximum number of iterations reached\");\n}\nfunction On(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, o]) => {\n o.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 _n(t, n, e = !1) {\n const s = Math.max(t.precision, n.precision);\n if (e) {\n const i = On(t, n);\n if (i)\n return i;\n }\n return D(t, n, s);\n}\nfunction Tn(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, o]) => {\n o.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 Ln(t, n, e = !1) {\n const s = Math.max(t.precision, n.precision);\n if (e) {\n const i = Tn(t, n);\n if (i)\n return i;\n }\n return D(t, n, s);\n}\nfunction de(t, n, e) {\n if (t instanceof b && n instanceof b) {\n const s = zt(\n t,\n n,\n !1,\n e\n );\n return s === null ? [] : [s];\n }\n if (t instanceof b && n instanceof S)\n return K(t, n, e);\n if (t instanceof S && n instanceof b)\n return K(n, t, e);\n if (t instanceof S && n instanceof S)\n return Dt(t, n, !1, e);\n throw new Error(\"Not implemented\");\n}\nfunction Z(t, n, e) {\n if (t instanceof b && n instanceof b) {\n const s = zt(\n t,\n n,\n !0,\n e\n );\n return s === null ? { intersections: [], overlaps: [], count: 0 } : s instanceof b ? { 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 (t instanceof b && n instanceof S) {\n const s = K(t, n, e);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (t instanceof S && n instanceof b) {\n const s = K(n, t, e);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (t instanceof S && n instanceof S) {\n const s = Dt(\n t,\n n,\n !0,\n e\n );\n return s.length ? s[0] instanceof S ? {\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 (t instanceof b && n instanceof M) {\n const s = st(\n t,\n n,\n e\n );\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (n instanceof b && t instanceof M) {\n const s = st(\n n,\n t,\n e\n );\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (t instanceof S && n instanceof M) {\n const s = gt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (n instanceof S && t instanceof M) {\n const s = gt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (t instanceof M && n instanceof M) {\n const s = xn(\n t,\n n,\n !0\n );\n return s.length ? s[0] instanceof M ? {\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 (t instanceof b && (n instanceof A || n instanceof I)) {\n const s = Pt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (n instanceof b && (t instanceof A || t instanceof I)) {\n const s = Pt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((t instanceof S || t instanceof M) && n instanceof I) {\n const s = xt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((n instanceof S || n instanceof M) && t instanceof I) {\n const s = xt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((t instanceof S || t instanceof M) && n instanceof A) {\n const s = wt(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if ((n instanceof S || n instanceof M) && t instanceof A) {\n const s = wt(n, t);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (t instanceof I && n instanceof I) {\n const s = Ln(\n t,\n n\n );\n return s.length ? s[0] instanceof I ? {\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 (t instanceof I && n instanceof A || n instanceof I && t instanceof A) {\n const s = D(t, n);\n return { intersections: s, overlaps: [], count: s.length };\n }\n if (t instanceof A && n instanceof A) {\n const s = _n(\n t,\n n\n );\n return s.length ? s[0] instanceof A ? {\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 Nt(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 Nt(t.length))\n n !== e && (yield [t[n], t[e]]);\n}\nclass Ut extends ut {\n constructor(e, { ignoreChecks: s = !1 } = {}) {\n super();\n C(this, \"segments\");\n C(this, \"_boundingBox\", null);\n s || jt(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 qn(t, n = \"Stroke\") {\n Nt(t.length).forEach(\n ([e, s]) => {\n if (e === s) return;\n const i = t[e], o = t[s], l = Z(i, o), r = Math.max(i.precision, o.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, r) || u === -1 && P(i.lastPoint, a, r) || u === t.length - 1 && P(i.lastPoint, a, r) && P(o.firstPoint, a, r) || -u === t.length - 1 && P(i.firstPoint, a, r) && P(o.lastPoint, a, r))\n return;\n }\n if (!(l.count === 2 && t.length === 2 && (P(\n i.firstPoint,\n l.intersections[0],\n r\n ) && P(\n i.lastPoint,\n l.intersections[1],\n r\n ) || P(\n i.firstPoint,\n l.intersections[1],\n r\n ) && P(\n i.lastPoint,\n l.intersections[0],\n r\n ))))\n throw new Error(\n `${n} segments must not intersect, but segments ${i.info} and ${o.info} do at ${JSON.stringify(\n l.intersections\n )}`\n );\n }\n }\n );\n}\nfunction jt(t, n = \"Stroke\") {\n if (t.length === 0)\n throw new Error(`${n} must have at least one segment`);\n N([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 ), qn(t, n);\n}\nfunction Ct(t, n) {\n return !!(t instanceof b && n instanceof b && an(t.V, n.V) || t instanceof S && n instanceof S && P(t.center, n.center) && t.radius - n.radius < t.precision);\n}\nfunction Mt(t, n) {\n if (t instanceof b && n instanceof b)\n return new b(t.firstPoint, n.lastPoint);\n if (t instanceof S && n instanceof S)\n return new S(\n t.firstPoint,\n n.lastPoint,\n t.center,\n t.clockwise\n );\n throw new Error(\"Not implemented\");\n}\nfunction Ht(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 Ct(i, s) ? (n = !0, e.pop(), e.push(Mt(i, s))) : e.push(s);\n }\n if (P(t.firstPoint, t.lastPoint) && Ct(\n e[0],\n e[e.length - 1]\n )) {\n n = !0;\n const s = e.pop();\n e[0] = Mt(s, e[0]);\n }\n return n ? e : null;\n}\nclass B extends Ut {\n constructor() {\n super(...arguments);\n C(this, \"strokeType\", \"STRAND\");\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 = Ht(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 zn = (t, n) => {\n const e = fn(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 [, o] = n.midPoint;\n return t[1] - o < 0 ? 1 : 0;\n }\n return 1;\n};\nclass at {\n constructor(n) {\n C(this, \"_count\", 0);\n C(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 Dn = (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 = hn(t, n.center), o = n.radius * n.radius, l = e * e;\n if (Math.abs(i - o) < l && n.isOnSegment(t))\n return 0;\n const r = i - o > l;\n if (r && 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]]), r && a.update([n.center[0] - u, t[1]]), a.count;\n}, Rn = (t, n) => {\n const e = n.boundingBox.xMax + n.boundingBox.width / 2, s = new b(t, [e, t[1]]), i = new at(n);\n return st(s, n).forEach((o) => {\n i.update(o, !0);\n }), i.count;\n}, Vn = (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 Nn(t, n) {\n if (n instanceof b)\n return zn(t, n);\n if (n instanceof S)\n return Dn(t, n);\n if (n instanceof M)\n return Rn(t, n);\n if (n instanceof A || n instanceof I)\n return Vn(t, n);\n throw new Error(\"Not implemented\");\n}\nclass _ extends Ut {\n constructor(e, { ignoreChecks: s = !1 } = {}) {\n super(e, { ignoreChecks: !0 });\n C(this, \"strokeType\", \"LOOP\");\n C(this, \"_clockwise\", null);\n s || Un(e);\n }\n get clockwise() {\n if (this._clockwise === null) {\n const e = this.segments.flatMap((i) => i instanceof b ? [i.firstPoint] : [i.firstPoint, i.paramPoint(0.5)]), s = e.map((i, o) => {\n const l = e[(o + 1) % e.length];\n return (l[0] - i[0]) * (l[1] + i[1]);\n }).reduce((i, o) => i + o, 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((o, l) => o + Nn(e, l), 0) % 2 === 1 : !1;\n }\n simplify() {\n const e = Ht(this);\n return e ? new _(e, { ignoreChecks: !0 }) : this;\n }\n}\nfunction Un(t) {\n if (jt(t, \"Loop\"), !P(t[0].firstPoint, t[t.length - 1].lastPoint))\n throw new Error(\"Loop segment must be closed\");\n}\nconst jn = [\n b,\n S,\n M,\n I,\n A\n];\nfunction Hn(t) {\n return jn.some((n) => t instanceof n);\n}\nfunction $t(t) {\n if (t instanceof b)\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint\n };\n if (t instanceof S)\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 (t instanceof M)\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 (t instanceof I)\n return {\n type: t.segmentType,\n firstPoint: t.firstPoint,\n lastPoint: t.lastPoint,\n controlPoint: t.controlPoint\n };\n if (t instanceof A)\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 ot(t) {\n return {\n type: \"LOOP\",\n segments: t.segments.map($t)\n };\n}\nfunction Yt(t) {\n return {\n type: \"FIGURE\",\n contour: ot(t.contour),\n holes: t.holes.map(ot)\n };\n}\nfunction $n(t) {\n return {\n type: \"DIAGRAM\",\n figures: t.figures.map(Yt)\n };\n}\nfunction It(t) {\n if (t instanceof O)\n return $n(t);\n if (t instanceof v)\n return Yt(t);\n if (t instanceof _)\n return ot(t);\n if (Hn(t))\n return $t(t);\n throw new Error(\"Unknown shape type\");\n}\nclass Yn {\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, o = this.values[i];\n if (e >= o) break;\n this.ids[s] = this.ids[i], this.values[s] = o, 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 o = 0;\n for (; o < i; ) {\n let l = (o << 1) + 1;\n const r = l + 1;\n let u = this.ids[l], a = this.values[l];\n const f = this.values[r];\n if (r < this.length && f < a && (l = r, u = this.ids[r], a = f), a >= s) break;\n this.ids[o] = u, this.values[o] = a, o = l;\n }\n this.ids[o] = e, this.values[o] = 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 At = [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 o = i >> 4;\n if (o !== et)\n throw new Error(`Got v${o} data when expected v${et}.`);\n const l = At[i & 15];\n if (!l)\n throw new Error(\"Unrecognized array type.\");\n const [r] = new Uint16Array(n, e + 2, 1), [u] = new Uint32Array(n, e + 4, 1);\n return new ft(u, r, 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, o, 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 r = n, u = r;\n this._levelBounds = [r * 4];\n do\n r = Math.ceil(r / this.nodeSize), u += r, this._levelBounds.push(u * 4);\n while (r !== 1);\n this.ArrayType = s, this.IndexArrayType = u < 16384 ? Uint16Array : Uint32Array;\n const a = At.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 o && o.byteLength !== void 0 && !o.buffer ? (this.data = o, 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 Yn();\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 o = this._pos >> 2, l = this._boxes;\n return this._indices[o] = o, 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), o;\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), o = 65535;\n for (let l = 0, r = 0; l < this.numItems; l++) {\n const u = n[r++], a = n[r++], f = n[r++], c = n[r++], h = Math.floor(o * ((u + f) / 2 - this.minX) / e), p = Math.floor(o * ((a + c) / 2 - this.minY) / s);\n i[l] = Gn(h, p);\n }\n rt(i, n, this._indices, 0, this.numItems - 1, this.nodeSize);\n for (let l = 0, r = 0; l < this._levelBounds.length - 1; l++) {\n const u = this._levelBounds[l];\n for (; r < u; ) {\n const a = r;\n let f = n[r++], c = n[r++], h = n[r++], p = n[r++];\n for (let d = 1; d < this.nodeSize && r < u; d++)\n f = Math.min(f, n[r++]), c = Math.min(c, n[r++]), h = Math.max(h, n[r++]), p = Math.max(p, n[r++]);\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, o) {\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 r = [], u = [];\n for (; l !== void 0; ) {\n const a = Math.min(l + this.nodeSize * 4, Ft(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 ? r.push(c) : (o === void 0 || o(c)) && u.push(c);\n }\n l = r.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, o) {\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 r = this._queue, u = [], a = i * i;\n t: for (; l !== void 0; ) {\n const f = Math.min(l + this.nodeSize * 4, Ft(l, this._levelBounds));\n for (let c = l; c < f; c += 4) {\n const h = this._indices[c >> 2] | 0, p = Et(n, this._boxes[c], this._boxes[c + 2]), d = Et(e, this._boxes[c + 1], this._boxes[c + 3]), m = p * p + d * d;\n m > a || (l >= this.numItems * 4 ? r.push(h << 1, m) : (o === void 0 || o(h)) && r.push((h << 1) + 1, m));\n }\n for (; r.length && r.peek() & 1; )\n if (r.peekValue() > a || (u.push(r.pop() >> 1), u.length === s)) break t;\n l = r.length ? r.pop() >> 1 : void 0;\n }\n return r.clear(), u;\n }\n}\nfunction Et(t, n, e) {\n return t < n ? n - t : t <= e ? 0 : t - e;\n}\nfunction Ft(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 rt(t, n, e, s, i, o) {\n if (Math.floor(s / o) >= Math.floor(i / o)) return;\n const l = t[s + i >> 1];\n let r = s - 1, u = i + 1;\n for (; ; ) {\n do\n r++;\n while (t[r] < l);\n do\n u--;\n while (t[u] > l);\n if (r >= u) break;\n Xn(t, n, e, r, u);\n }\n rt(t, n, e, s, u, o), rt(t, n, e, u + 1, i, o);\n}\nfunction Xn(t, n, e, s, i) {\n const o = t[s];\n t[s] = t[i], t[i] = o;\n const l = 4 * s, r = 4 * i, u = n[l], a = n[l + 1], f = n[l + 2], c = n[l + 3];\n n[l] = n[r], n[l + 1] = n[r + 1], n[l + 2] = n[r + 2], n[l + 3] = n[r + 3], n[r] = u, n[r + 1] = a, n[r + 2] = f, n[r + 3] = c;\n const h = e[s];\n e[s] = e[i], e[i] = h;\n}\nfunction Gn(t, n) {\n let e = t ^ n, s = 65535 ^ e, i = 65535 ^ (t | n), o = t & (n ^ 65535), l = e | s >> 1, r = e >> 1 ^ e, u = i >> 1 ^ s & o >> 1 ^ i, a = e & i >> 1 ^ o >> 1 ^ o;\n e = l, s = r, i = u, o = a, l = e & e >> 2 ^ s & s >> 2, r = e & s >> 2 ^ s & (e ^ s) >> 2, u ^= e & i >> 2 ^ s & o >> 2, a ^= s & i >> 2 ^ (e ^ s) & o >> 2, e = l, s = r, i = u, o = a, l = e & e >> 4 ^ s & s >> 4, r = e & s >> 4 ^ s & (e ^ s) >> 4, u ^= e & i >> 4 ^ s & o >> 4, a ^= s & i >> 4 ^ (e ^ s) & o >> 4, e = l, s = r, i = u, o = a, u ^= e & i >> 8 ^ s & o >> 8, a ^= s & i >> 8 ^ (e ^ s) & o >> 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 Xt(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((o) => {\n const [l, r] = o.firstPoint;\n e.add(l - n, r - n, l + n, r + n);\n }), e.finish();\n const s = [], i = /* @__PURE__ */ new Set();\n return t.forEach((o, l) => {\n if (i.has(l)) return;\n const r = [o];\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 = r[r.length - 1].lastPoint, [c, h] = f, p = e.search(\n c - n,\n h - n,\n c + n,\n h + n\n ), d = (w) => Math.abs((u - w) % t.length), m = p.filter((w) => !i.has(w)).map((w) => [\n t[w],\n w,\n d(w)\n ]).sort(([, , w], [, , F]) => d(w) - d(F));\n if (m.length === 0) {\n s.push(r);\n break;\n }\n const [x, g] = m[0];\n r.push(x), i.add(g), u = g;\n }\n }), s;\n}\nclass v extends ut {\n constructor(e, s = [], { ignoreChecks: i = !1 } = {}) {\n super();\n C(this, \"contour\");\n C(this, \"holes\");\n i || Qn(e, s), this.contour = e, this.holes = s;\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 = e instanceof v ? e.allLoops : [e], i = this.allLoops.flatMap((o) => s.flatMap((l) => o.overlappingSegments(l)));\n return Xt(i).map((o) => new B(o));\n }\n}\nfunction Qn(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(It(e), It(s)), new Error(\"Holes must not be inside other holes\");\n}\nconst J = (t, n, e = 1e-7) => Math.abs(t - n) <= e, Wn = (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}, Jn = (t, n) => {\n if (t.segmentsCount !== n.segmentsCount || !Wn(t, n)) return !1;\n const e = t.segments, s = n.segments, i = e.length, o = (l, r) => {\n for (let u = 0; u < i; u += 1) {\n const a = (l + r * 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]) && (o(l, 1) || o(l, -1)))\n return !0;\n return !1;\n}, Kn = (t) => {\n const n = [];\n return t.forEach((e) => {\n n.some((s) => Jn(e, s)) || n.push(e);\n }), n;\n}, Zn = (t) => {\n const n = t.map((i, o) => t.slice(o + 1).map((l, r) => [r + o + 1, l]).filter(([, l]) => i.boundingBox.overlaps(l.boundingBox)).map(([l]) => l)), e = [], s = Array(n.length);\n return n.forEach((i, o) => {\n let l = s[o];\n l || (l = [], e.push(l)), l.push(t[o]), i.length && i.forEach((r) => {\n s[r] = l;\n });\n }), e;\n}, Gt = (t) => t.map((n, e) => {\n const i = n.segments[0].midPoint, o = t.filter((l, r) => e === r ? !1 : l.contains(i));\n return {\n loop: n,\n isIn: o\n };\n}), te = (t, n) => t.flatMap(({ loop: e }) => ht(\n n.filter(\n ({ loop: s, isIn: i }) => s === e || i.indexOf(e) !== -1\n )\n)), ne = (t, n) => {\n const e = n.filter(({ isIn: i }) => i.length <= 1), s = ht(\n Gt(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 ? te(n, t) : ne(e, t);\n};\nfunction X(t) {\n const n = Kn(t);\n return Zn(n).map(Gt).flatMap(ht).map((s) => {\n if (s.length === 1) return new v(s[0].loop);\n s.sort((l, r) => l.isIn.length - r.isIn.length);\n const [i, ...o] = s.map(({ loop: l }) => l);\n return new v(i, o);\n });\n}\nfunction ee(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* vt(t, n, e) {\n const s = (r) => n.some((u) => P(u, r.lastPoint)), i = (r, u) => r.segmentType !== u.segmentType || !u.isOnSegment(r.firstPoint) || !u.isOnSegment(r.lastPoint) ? !1 : r.segmentType !== \"LINE\" ? u.isOnSegment(r.midPoint) : !0, o = (r) => e.some((u) => r.isSame(u) || i(r, u));\n let l = [];\n for (const r of t)\n s(r) ? (l.push(r), yield new B(l, { ignoreChecks: !0 }), l = []) : o(r) ? (l.length && (yield new B(l, { ignoreChecks: !0 }), l = []), yield new B([r], { ignoreChecks: !0 })) : l.push(r);\n l.length && (yield new B(l, { ignoreChecks: !0 }));\n}\nconst Bt = (t, n) => {\n const e = t.findIndex((o) => P(n, o.firstPoint)), s = t.slice(0, e);\n return t.slice(e).concat(s);\n}, kt = (t, n) => {\n let e = t;\n const s = (r) => P(r.firstPoint, n.firstPoint) && P(r.lastPoint, n.lastPoint);\n let i = t.findIndex(s);\n if (i === -1) {\n const r = t.map((u) => u.reverse());\n if (r.reverse(), i = r.findIndex(s), i === -1)\n throw console.error(\n r.map((u) => u.repr),\n n.repr\n ), new Error(\"Failed to rotate to segment start\");\n e = r;\n }\n const o = e.slice(0, i);\n return e.slice(i).concat(o);\n};\nfunction se(t, n, e) {\n return t.filter((s) => {\n const i = n.filter((r) => P(r.firstPoint, s) || P(r.lastPoint, s));\n if (i.length % 2)\n throw new Error(\"Bug in the intersection algo on non crossing point\");\n const o = i.map((r) => e.contains(r.midPoint));\n return !(o.every((r) => r) || !o.some((r) => r));\n });\n}\nfunction ie(t, n, e, s = !1) {\n let i = [];\n const o = [], l = new Array(t.segments.length).fill(0).map(() => []), r = new Array(n.segments.length).fill(0).map(() => []);\n if (t.segments.forEach((p, d) => {\n n.segments.forEach((m, x) => {\n const { intersections: g, overlaps: w } = Z(\n p,\n m,\n e\n );\n i.push(...g), l[d].push(...g), r[x].push(...g), o.push(...w);\n const F = w.flatMap((y) => [\n y.firstPoint,\n y.lastPoint\n ]);\n i.push(...F), l[d].push(...F), r[x].push(...F);\n });\n }), i = U(i, e), !i.length || i.length === 1) return null;\n const u = ([p, d]) => d.length ? p.splitAt(d) : [p];\n let a = N([t.segments, l]).flatMap(u), f = N([n.segments, r]).flatMap(u);\n if (i = se(\n i,\n a,\n n\n ), !i.length && !o.length) return null;\n if (o.length) {\n const p = o[0];\n a = kt(\n a,\n p\n ), f = kt(\n f,\n p\n );\n } else {\n const p = i[0];\n a = Bt(a, p), f = Bt(f, p);\n }\n let c = Array.from(\n vt(\n a,\n i,\n o\n )\n ), h = Array.from(\n vt(\n f,\n i,\n o\n )\n );\n return (!P(\n h[0].lastPoint,\n c[0].lastPoint\n ) || o.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())), N([c, h]).map(([p, d]) => {\n if (s) {\n if (((x) => x.segments.every(\n (g) => o.some(\n (w) => g.isSame(w) || g.segmentType === w.segmentType && w.isOnSegment(g.firstPoint) && w.isOnSegment(g.lastPoint) && (g.segmentType === \"LINE\" || w.isOnSegment(g.midPoint))\n )\n ))(p))\n return [p, \"same\"];\n } else if (p.segmentsCount === 1 && o.some((m) => p.segments[0].isSame(m)))\n return [p, \"same\"];\n return [p, d];\n });\n}\nfunction Ot(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 oe(t, n) {\n const e = N([\n n.slice(0, -1),\n n.slice(1)\n ]).map(([i, o]) => Ot(t.slice(i, o)));\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(Ot(s)), e;\n}\nfunction re(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 = N([n, e]).flatMap(\n ([i, o], l) => P(i, o) ? [] : l\n );\n try {\n return oe(t, s);\n } catch {\n return Xt(t.flatMap((o) => o.segments)).filter((o) => o.length > 1).filter((o) => P(o[0].firstPoint, o.at(-1).lastPoint)).map((o) => new _(o));\n }\n}\nconst _t = (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}, le = (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: o = !1\n}) {\n const l = ie(\n t,\n n,\n void 0,\n i || o\n );\n if (!l) {\n const f = t.segments[0].midPoint, c = n.contains(f, {\n strokeIsInside: o\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 r = 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 ? (r ? r = r.extend(f) : r = f, []) : (console.error(\"weird situation\"), []);\n const d = f.segments[0].midPoint, m = n.contains(d, {\n strokeIsInside: o\n });\n (e === \"keep\" && m || e === \"remove\" && !m) && (p += 1, h = _t(h, f));\n const x = c.segments[0].midPoint, g = t.contains(x, {\n strokeIsInside: i\n });\n if (s === \"keep\" && g || s === \"remove\" && !g) {\n const w = c;\n p += 1, p === 2 && h.length ? (h = _t(h, w), r = null) : h = [w];\n }\n return u === null && p === 1 && r && (h = le(h, r)), p === 1 && (u = p, r = null), h.length ? h : (r = null, []);\n });\n return re(a);\n}\nconst ue = (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, o = s || i, l = (u, a, f) => u.segments.every(\n (c) => a.contains(c.midPoint, { strokeIsInside: f })\n );\n if (o) {\n if (l(t, n, i))\n return [t];\n if (l(n, t, s))\n return [n];\n }\n const r = pt(t, n, {\n firstInside: \"keep\",\n secondInside: \"keep\",\n ...e\n });\n return Array.isArray(r) ? r : r.identical ? [t] : r.firstCurveInSecond ? [t] : r.secondCurveInFirst ? [n] : [];\n};\nfunction ce(t) {\n const n = /* @__PURE__ */ new Map(), e = [];\n return t.forEach((s, i) => {\n let o;\n n.has(i) ? o = n.get(i) : (o = { current: [s], fusedWith: /* @__PURE__ */ new Set([i]) }, e.push(o)), t.slice(i + 1).forEach((l, r) => {\n const u = o.current, a = i + r + 1;\n if (o.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 = Qt(u[0], f[0]), o.fusedWith.add(a), o.current = p, c || n.set(a, o);\n });\n }), e.flatMap(({ current: s }) => s);\n}\nfunction Qt(t, n) {\n const e = ue(t.contour, n.contour), s = n.holes.flatMap((l) => tt(l, t.contour)), i = t.holes.flatMap((l) => tt(l, n.contour)), o = ee(t.holes, n.holes).flatMap(\n ([l, r]) => dt(l, r)\n );\n return X([\n ...e,\n ...s,\n ...i,\n ...o\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 (o) => dt(o, 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 ae(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 ce([...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 ? Qt(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 ? ae(t[0], n[0]) : t.length > 1 ? t.flatMap((e) => lt([e], n)) : n.flatMap((e) => lt(t, [e]));\n}\nclass O extends ut {\n constructor(e = [], { ignoreChecks: s = !1 } = {}) {\n super();\n C(this, \"figures\");\n C(this, \"_boundingBox\", null);\n s || fe(e), this.figures = e;\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) => e instanceof O ? 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 fe(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 Dt as d,\n Xt as e,\n de as f,\n Hn as g,\n It as h,\n lt as i,\n K as l,\n dn as p,\n vt as s\n};\n//# sourceMappingURL=models-DdZq-waE.js.map\n","var W = Object.defineProperty;\nvar q = (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) => q(e, typeof t != \"symbol\" ? t + \"\" : t, n);\nimport { a as l, s as u, c as x, b as P, L as d, A as R, Q as w, C as D, p as E, d as G, e as T, t as k, f as Q, g as L, h as j, i as $, j as H, R as J, T as K, k as A, n as F, D as C } from \"./QuadraticBezier-B2g_Iyyl.js\";\nimport { f as U, S as X, D as Z, F as tt, L as nt } from \"./models-DdZq-waE.js\";\nconst B = (e, t, n) => {\n const r = x(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 = x(s, t.V) / r;\n return l(e.firstPoint, u(e.V, o));\n};\nclass S {\n constructor(t, n) {\n this.firstPoint = t, this.lastPoint = n;\n }\n}\nfunction y(e, t) {\n if (e instanceof d)\n return et(e, t);\n if (e instanceof R)\n return rt(e, t);\n if (e instanceof w || e instanceof D)\n return it(e, t);\n throw new Error(\"Not implemented\");\n}\nfunction et(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 rt(e, t) {\n const n = l(\n e.firstPoint,\n u(E(e.tangentAtFirstPoint), t)\n ), r = l(\n e.lastPoint,\n u(E(e.tangentAtLastPoint), t)\n ), i = t * (e.clockwise ? 1 : -1);\n return e.radius + i < e.precision ? new S(n, r) : new R(n, r, e.center, e.clockwise);\n}\nfunction b(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 it(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 ), h = 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 (G(P(o, n), i) * t > 0 && Math.min(\n T(n, o),\n T(r, o)\n ) < t)\n return new S(a, h);\n if (e instanceof w) {\n const g = b(\n o,\n e.controlPoint,\n e.tangentAtFirstPoint,\n a,\n e.precision\n );\n return new w(\n a,\n h,\n g\n );\n }\n const p = b(\n o,\n e.firstControlPoint,\n e.tangentAtFirstPoint,\n a,\n e.precision\n ), f = b(\n o,\n e.lastControlPoint,\n e.tangentAtLastPoint,\n h,\n e.precision\n );\n return new D(\n a,\n h,\n p,\n f\n );\n}\nfunction M(e, t, n) {\n const r = x(\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 = y(e, s), a = y(t, s);\n if (o instanceof S || a instanceof S)\n return null;\n let h;\n try {\n h = U(o, a, 1e-9).at(-1);\n } catch {\n return null;\n }\n if (!h)\n return null;\n const c = h, p = (v, O) => {\n const I = O.tangentAt(c), N = Q(I), Y = l(c, u(N, s));\n return v.splitAt(Y);\n }, [f] = p(e, o), [, g] = p(t, a);\n return { first: f, second: g, center: c };\n}\nfunction V(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 _(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 st = (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 * C) : o = n;\n let a;\n return typeof s == \"number\" ? a = A(1, s * C) : a = s, { endTangent: o, startFactor: r, endFactor: i, startTangent: a };\n};\nfunction z(e, { ignoreChecks: t = !1 } = {}) {\n return new Z([new tt(new nt([...e], { ignoreChecks: t }))]);\n}\nclass ot {\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 (L(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;\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 * C, i = A(t, r);\n return this.lineTo(i);\n }\n polarLine(t, n) {\n const r = n * C, [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(j(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 = E(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 $(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] = H(P(t, this.pointer));\n return this.ellipseTo(\n t,\n r / 2,\n Math.abs(n),\n i * J,\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 } = st(n), a = this.pendingSegments.length ? this.pendingSegments[this.pendingSegments.length - 1] : null, h = T(this.pointer, t) / 3;\n let c;\n i ? c = i : a ? c = a.tangentAtLastPoint : c = [1, 0], c = F(c);\n const p = [\n this.pointer[0] + c[0] * s * h,\n this.pointer[1] + c[1] * s * h\n ];\n let f = r;\n f = F(f);\n const g = [\n t[0] - f[0] * o * h,\n t[1] - f[1] * o * h\n ];\n return this.cubicBezierCurveTo(t, p, g);\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;\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 L(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), z(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 K().mirrorLine(\n i,\n n.firstPoint\n ), o = this.pendingSegments.map(\n (a) => a.transform(s).reverse()\n );\n return o.reverse(), z(\n [...this.pendingSegments, ...o],\n { ignoreChecks: t }\n );\n }\n asStrand() {\n return new X([...this.pendingSegments]);\n }\n get isClosed() {\n var t;\n return L(this.pointer, (t = this.pendingSegments[0]) == null ? void 0 : t.firstPoint);\n }\n}\nfunction lt(e = [0, 0]) {\n return new ot(e);\n}\nexport {\n S as D,\n ot as a,\n lt as d,\n V as f,\n y as o\n};\n//# sourceMappingURL=draw-BJW5kfm9.js.map\n","import { L as $, A as f, E as l, R as u, Q as e, C as h } from \"./QuadraticBezier-B2g_Iyyl.js\";\nfunction i([t, n]) {\n return `${t} ${n}`;\n}\nfunction s(t) {\n if (t instanceof $)\n return `L ${i(t.lastPoint)}`;\n if (t instanceof f)\n return `A ${t.radius} ${t.radius} 0 ${t.angularLength > Math.PI ? \"1\" : \"0\"} ${t.clockwise ? \"0\" : \"1\"} ${i(t.lastPoint)}`;\n if (t instanceof l)\n return `A ${t.majorRadius} ${t.minorRadius} ${t.tiltAngle * u} ${t.deltaAngle > Math.PI ? \"1\" : \"0\"} ${t.clockwise ? \"0\" : \"1\"} ${i(t.lastPoint)}`;\n if (t instanceof e)\n return `Q ${[\n i(t.controlPoint),\n i(t.lastPoint)\n ].join(\" \")}`;\n if (t instanceof h)\n return `C ${[\n i(t.firstControlPoint),\n i(t.lastControlPoint),\n i(t.lastPoint)\n ].join(\" \")}`;\n throw new Error(\"Unknown segment type\");\n}\nfunction w(t) {\n const n = `M ${t.firstPoint.join(\" \")}`, o = t.segments.map(s).join(\" \");\n return `${n} ${o} 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(\" \")}`, o = t.segments.map(s).join(\" \");\n return `${n} ${o}`;\n}\nfunction v(t, n = 1) {\n const o = t.xMin - n, r = t.yMin - n;\n return `${o} ${r} ${t.width + 2 * n} ${t.height + 2 * n}`;\n}\nfunction A(t, n, o = 1, r) {\n const a = v(n, o), c = r ? `width=\"${n.width + 2 * o}${r}\" height=\"${n.height + 2 * o}${r}\"` : \"\";\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 s as d,\n v as e,\n d as s,\n A as w\n};\n//# sourceMappingURL=svg-D8vwkQf7.js.map\n","var Ut = Object.defineProperty;\nvar Vt = (t, n, e) => n in t ? Ut(t, n, { enumerable: !0, configurable: !0, writable: !0, value: e }) : t[n] = e;\nvar M = (t, n, e) => Vt(t, typeof n != \"symbol\" ? n + \"\" : n, e);\nimport { o as Ht, D as U, f as Mt } from \"./draw-BJW5kfm9.js\";\nimport { a as oe, d as ce } from \"./draw-BJW5kfm9.js\";\nimport { F as m, L as P, D as h, a as W, s as Kt, b as Nt, c as qt, i as Xt, S as b, l as Jt, p as Qt, d as Yt, e as St, g as It } from \"./models-DdZq-waE.js\";\nimport { h as fe } from \"./models-DdZq-waE.js\";\nimport { l as Zt, z as Wt, m as jt, e as E, n as j, b as F, a as tn, s as nn, o as en, q as At, L as v, A as y, C as _, p as it, u as N, d as q, T as rn, g as A, E as vt, Q as bt, t as sn, c as on, D as Lt, v as Et, B as cn } from \"./QuadraticBezier-B2g_Iyyl.js\";\nimport { s as an, a as fn, b as un, c as ln, d as hn, w as ot } from \"./svg-D8vwkQf7.js\";\nfunction x(t) {\n if (t instanceof m)\n return [t];\n if (t instanceof P)\n return [new m(t)];\n if (t instanceof h)\n return t.figures;\n throw new Error(\"Unknown shape\");\n}\nfunction kt(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 = Zt(r, e);\n const o = Wt([n.segments, i]).flatMap(([c, f]) => f.length ? c.splitAt(f) : [c]);\n return Array.from(\n Kt(\n o,\n r,\n s\n )\n );\n}\nfunction tt(t, n, e = !1) {\n return kt(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 kt(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 gn(t, n) {\n return new h(\n Nt(x(t), x(n))\n );\n}\nfunction z(t) {\n return t.reduce(\n (n, e) => gn(n, e),\n new h()\n );\n}\nfunction Ft(t, n) {\n return new h(\n qt(x(t), x(n))\n );\n}\nfunction Xn(t, n) {\n return new h(\n Xt(x(t), x(n))\n );\n}\nfunction Jn(t, n, e = !0) {\n if (n instanceof P)\n return tt(t, n, e);\n if (n instanceof m)\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 Qn(t, n, e = !1) {\n if (n instanceof P)\n return nt(t, n, e);\n if (n instanceof m)\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 pn(t, n) {\n const e = jt(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 (Jt(t, n).length > 0)\n return 0;\n const e = Qt(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 = tn(\n n.center,\n nn(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 dn = (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 mn(t, n) {\n if (Yt(t, n, !0).length > 0) return 0;\n const e = E(t.center, n.center);\n if (e < t.precision && dn(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 = en(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 Pn(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 wn(t, n, e) {\n const r = Pn(t, n, e);\n r < 0 ? t.splice(-(r + 1), 0, n) : t.splice(r, 0, n);\n}\nclass Mn {\n constructor() {\n M(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] : wn(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 M(this, \"diagonal\");\n M(this, \"diagonalBucketIndex\");\n M(this, \"xLength\");\n M(this, \"yLength\");\n M(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 In {\n constructor(n, e = 1e-8, r = 1e3, s = 1e-6) {\n M(this, \"rectangles\");\n M(this, \"buckets\");\n M(this, \"fMin\");\n M(this, \"argMin\");\n M(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 An(t, n = 1e-8, e = 1e3, r = 1e-6) {\n return new In(\n t,\n n,\n e,\n r\n ).run();\n}\nfunction vn(t, n, e = 1e-9) {\n const r = An((s) => {\n const i = t.paramPoint(s[0]), o = n.paramPoint(s[1]);\n return At(i, o);\n }, e);\n return Math.sqrt(r.fMin);\n}\nfunction bn(t, n) {\n return t instanceof v && n instanceof v ? pn(t, n) : t instanceof v && n instanceof y ? lt(t, n) : t instanceof y && n instanceof v ? lt(n, t) : t instanceof y && n instanceof y ? mn(t, n) : vn(t, n);\n}\nfunction xt(t) {\n if (t instanceof _) {\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 (xt(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 xt(t) ? [t] : t.splitAtParameters(t.getParametersOfExtrema()).flatMap(X);\n}\nfunction Ln(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, S] = t.center, w = t.minorRadius, I = t.majorRadius, L = new rn().rotate(\n t.tiltAngle,\n t.center\n ), k = ($t) => L.transform($t), D = k([l + I * u, S + w * g]), $ = k([\n l + I * (u - s * g * i),\n S + w * (g + s * u * i)\n ]), Gt = k([\n l + I * (p + s * d * i),\n S + w * (d - s * p * i)\n ]), _t = k([l + I * p, S + w * d]);\n return new _(D, _t, $, Gt);\n });\n}\nconst et = 1e-8, yt = (t) => t.flatMap((n) => n instanceof v ? [n] : n instanceof y ? [n] : n instanceof vt ? Ln(n).flatMap(\n (e) => ht(e)\n) : n instanceof bt || n instanceof _ ? ht(n) : [new v(n.firstPoint, n.lastPoint)]);\nfunction J(t, n, e = !0) {\n const r = t.map((a) => ({\n offset: Ht(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 ? a.offset instanceof U ? 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 (!(o.offset instanceof U) && !(a.offset instanceof U)) {\n const { intersections: w, overlaps: I } = W(\n o.offset,\n a.offset,\n et / 100\n );\n p = [\n ...w,\n ...I.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 ($) => At($, k)\n );\n w = p[D.indexOf(Math.min(...D))];\n }\n const I = 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: I,\n original: o.original\n }), o = { offset: L, original: a.original };\n continue;\n }\n const d = o.original.lastPoint, l = on(\n F(g, d),\n F(u, d)\n ) > 0, S = new y(u, g, d, l);\n c(o), s.push(S), o = a;\n }\n return o && c(o), s;\n}\nfunction Ct(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 Dt(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 Ot(t, n, e) {\n return t.filter((r) => !n.segments.some((i) => bn(i, r) < Math.abs(e) - et));\n}\nfunction G(t, n) {\n const e = t.clockwise ? n : -n, r = yt(t.segments), s = J(r, e);\n if (s.length < 2) return new h();\n const i = Ct(s);\n if (!i.size) {\n const u = new P(s);\n return new h([new m(u)]);\n }\n const o = Dt(\n i,\n s\n ), c = Ot(o, t, n);\n if (!c.length) return new h();\n const a = St(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 En(t, n, e = \"round\") {\n const r = n / 2, s = yt(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, S) => e === \"round\" ? sn(\n l.lastPoint,\n S.firstPoint,\n l.tangentAtLastPoint\n ) : new v(l.lastPoint, S.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 = Ct(f);\n if (!a.size) {\n const l = new P(f);\n return new h([new m(l)]);\n }\n const u = Dt(\n a,\n f\n ), g = Ot(u, t, r);\n if (!g.length) return new h();\n const d = St(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 kn(t, n) {\n const e = t.map((r) => {\n const s = z(\n r.holes.map((i) => G(i, n))\n );\n return Ft(G(r.contour, n), s);\n });\n return z(e);\n}\nfunction Fn(t, n) {\n const e = Math.abs(n / 2), r = t.map(\n (s) => z(\n s.allLoops.map((i) => Ft(G(i, e), G(i, -e)))\n )\n );\n return z(r);\n}\nfunction Yn(t, n) {\n return kn(x(t), n);\n}\nfunction Zn(t, n, { endCap: e = \"round\" } = {}) {\n return t instanceof b ? En(t, n, e) : Fn(x(t), n);\n}\nclass xn {\n constructor() {\n M(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 xn {\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(Lt * 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 Bt(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 (n instanceof P) {\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 (t instanceof P || t instanceof b)\n return Bt(Mt, t, n, s);\n if (t instanceof m) {\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 (t instanceof h) {\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 (t instanceof P || t instanceof b)\n return Bt(Mt, t, n, s);\n if (t instanceof m) {\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 (t instanceof h) {\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 yn 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 Wn(t) {\n return new yn(t);\n}\nconst Cn = 1 * Lt, Dn = 24;\nfunction H(t, n, e, r) {\n const s = t.gradientAt(n);\n return Et(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 = Et(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), S = q(p, d), w = q(d, l);\n if (S >= s && w >= s)\n return [o, c];\n const I = t.paramPoint(g), L = S >= s ? [o, I] : Q(t, n, g, r, s, i + 1), k = w >= s ? [I, 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 ?? Cn,\n maxDepth: n.maxDepth ?? Dn\n }, r = Math.cos(e.maxAngle);\n return Q(t, 0, 1, e, r, 0);\n}\nfunction On(t, n) {\n return new h(\n t.figures.map((e) => Rt(e, n))\n );\n}\nfunction Rt(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 Bn(t, n) {\n return new b(st(t.segments, n));\n}\nfunction st(t, n) {\n return t.flatMap(n);\n}\nfunction Rn(t, n) {\n if (t instanceof h)\n return On(t, n);\n if (t instanceof m)\n return Rt(t, n);\n if (t instanceof P)\n return Y(t, n);\n if (t instanceof b)\n return Bn(t, n);\n if (It(t))\n return st([t], n);\n throw new Error(\"Unsupported shape type\");\n}\nfunction Tn(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 zn(t, n) {\n return Tn(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 Gn(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 || Gn(t) === n ? t : [...t].reverse();\n}\nfunction jn(t, n = {}) {\n return Rn(t, (r) => zn(r, n));\n}\nfunction _n(t, n = {}) {\n if (t instanceof h)\n return t.figures.map((e) => _n(e, n));\n if (t instanceof m) {\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 t instanceof P ? K(B(t.segments, n), !1) : t instanceof b ? B(t.segments, n) : rt(t, n);\n}\nfunction pt(t) {\n if (t instanceof h)\n return an(t);\n if (t instanceof m)\n return fn(t);\n if (t instanceof P)\n return `<path d=\"${un(t)}\" />`;\n if (t instanceof b)\n return `<path d=\"${ln(t)}\" />`;\n if (It(t))\n return `<path d=\"${`M ${t.firstPoint.join(\" \")}`} ${hn(\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 cn(t.xMin, -t.yMax, t.xMax, -t.yMin);\nfunction te(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 Tt = (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 vt(\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 bt(\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(Tt);\n return new P(n);\n}, zt = (t) => {\n const n = Z(t.contour), e = t.holes.map(Z);\n return new m(n, e);\n}, $n = (t) => {\n const n = t.figures.map(zt);\n return new h(n);\n};\nfunction ne(t) {\n if (t.type === \"DIAGRAM\")\n return $n(t);\n if (t.type === \"FIGURE\")\n return zt(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 Tt(t);\n throw new Error(\"Unknown shape type\");\n}\nconst wt = Math.PI / 180, Un = 180 / Math.PI;\nfunction ee(t, n) {\n const e = Math.cos(n * wt) * t, r = Math.sin(n * wt) * t;\n return [e, r];\n}\nfunction re([t, n]) {\n const e = Math.sqrt(t * t + n * n), r = Math.atan2(n, t) * Un;\n return [e, r];\n}\nexport {\n wt as DEG2RAD,\n oe as DrawingPen,\n Un as RAD2DEG,\n re as cartesianToPolar,\n T as chamfer,\n Qn as confineStrand,\n Ft as cut,\n ce as draw,\n Jn as eraseStrand,\n fe as exportJSON,\n te as exportSVG,\n R as fillet,\n gn as fuse,\n z as fuseAll,\n ne as importJSON,\n Xn as intersect,\n Yn as offset,\n Zn as outlineStroke,\n ee as polarToCartesian,\n Wn as selectCorners,\n pt as svgBody,\n jn 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":["Oe","Me","r","Be","s","t","q","oe","ht","le","Dt","e","he","zt","mt$1","mt","n","ce","ye","Te","fe","Ue","Z","Y","it","Q","It","an","nt","Rt","J","St","Pe","H","Tt","Ye","We","Ie","i","tt","Qt","Qe","Mt","l","a","u","c","g","d","w","P","M","E","Ge","Xe","et$2","et","Ze","at","xt","o","h","Je","Kt","wt","Zt","me","cn","Ot","ct","fn","mn","be","Bt","Ee","_e","Ke","He","R","L","S","D","v","Ce","qe","$","ts","Ct","es","ns","is","rs","os","st","je","Ut","Fe","hs","xe","as","us","Se","cs","ot","lt","Pt","bt","ge","we","ae","Yt","Ht","yt","fs","ms","gs","ws","ps","ds","Ms","ys","Ps","bs","Es","_s","js","Ss","ks","Rs","vs","Ts","V$1","V","_","m","b","j","C","F","I","B","x","A","O","U","z","X","G","W","se","ne","ie","re","At","Vt","Nt","$t","Lt","ke","Is","Ft","ue","dt","K","Jt","pt","te","Cs","ft","qs","Fs","xs","As","Vs","$s","Ae","Ls","rt","ee$1","ut","pe","vt$1","vt","Ve","ee","Xt","Gt","zs","Os","Bs","Us","Ys","Ws","Ne","Qs","Gs","Xs","Zs","Wt","$e","Le","Js","De","Re","Ks","Hs","qt","kt","ze","wn","ve","gt","tn","en","sn","nn","rn","de","Et","p","jt","ln","pn","on","_t","dn","k","f","gn","y","T","Pn","xn","Sn","yn","bn","un","ct$1","Cn","Mn","In","An","En","Fn","vn","kn","Bn","On","_n","Tn","Ln","qn","N","zn","Dn","hn","Rn","Vn","Nn","Un","jn","Hn","$n","Yn","Gn","Xn","Qn","Wn","Jn","Kn","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.js","sources":["../../pantograph/dist/QuadraticBezier-BeY2TXKH.js","../../pantograph/dist/models-BHeLX0dj.js","../../pantograph/dist/draw-DzKVhurb.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 ut as d,\n I as f,\n _ as o\n};\n//# sourceMappingURL=draw-DzKVhurb.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 Ut = Object.defineProperty;\nvar Vt = (t, n, e) => n in t ? Ut(t, n, { enumerable: !0, configurable: !0, writable: !0, value: e }) : t[n] = e;\nvar I = (t, n, e) => Vt(t, typeof n != \"symbol\" ? n + \"\" : n, e);\nimport { o as Ht, D as U, f as It } from \"./draw-DzKVhurb.js\";\nimport { a as oe, d as ce } from \"./draw-DzKVhurb.js\";\nimport { F as m, L as P, D as h, a as W, s as Kt, b as Nt, c as qt, i as Xt, S as b, l as Jt, p as Qt, d as Yt, e as Mt, g as St } from \"./models-BHeLX0dj.js\";\nimport { h as fe } from \"./models-BHeLX0dj.js\";\nimport { l as Zt, z as Wt, m as jt, e as E, n as j, b as F, a as tn, s as nn, o as en, q as At, L as v, A as y, C as _, p as it, u as N, d as q, T as rn, g as A, E as vt, Q as bt, t as sn, c as on, D as Lt, v as Et, B as cn } from \"./QuadraticBezier-BeY2TXKH.js\";\nimport { s as an, a as fn, b as un, c as ln, d as hn, 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 kt(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 = Zt(r, e);\n const o = Wt([n.segments, i]).flatMap(([c, f]) => f.length ? c.splitAt(f) : [c]);\n return Array.from(\n Kt(\n o,\n r,\n s\n )\n );\n}\nfunction tt(t, n, e = !1) {\n return kt(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 kt(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 gn(t, n) {\n return new h(\n Nt(x(t), x(n))\n );\n}\nfunction z(t) {\n return t.reduce(\n (n, e) => gn(n, e),\n new h()\n );\n}\nfunction Ft(t, n) {\n return new h(\n qt(x(t), x(n))\n );\n}\nfunction Xn(t, n) {\n return new h(\n Xt(x(t), x(n))\n );\n}\nfunction Jn(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 Qn(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 pn(t, n) {\n const e = jt(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 (Jt(t, n).length > 0)\n return 0;\n const e = Qt(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 = tn(\n n.center,\n nn(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 dn = (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 mn(t, n) {\n if (Yt(t, n, !0).length > 0) return 0;\n const e = E(t.center, n.center);\n if (e < t.precision && dn(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 = en(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 Pn(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 wn(t, n, e) {\n const r = Pn(t, n, e);\n r < 0 ? t.splice(-(r + 1), 0, n) : t.splice(r, 0, n);\n}\nclass In {\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] : wn(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 Mn {\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 Sn {\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 In();\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 Mn(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 An(t, n = 1e-8, e = 1e3, r = 1e-6) {\n return new Sn(\n t,\n n,\n e,\n r\n ).run();\n}\nfunction vn(t, n, e = 1e-9) {\n const r = An((s) => {\n const i = t.paramPoint(s[0]), o = n.paramPoint(s[1]);\n return At(i, o);\n }, e);\n return Math.sqrt(r.fMin);\n}\nfunction bn(t, n) {\n return v.isInstance(t) && v.isInstance(n) ? pn(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) ? mn(t, n) : vn(t, n);\n}\nfunction xt(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 (xt(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 xt(t) ? [t] : t.splitAtParameters(t.getParametersOfExtrema()).flatMap(X);\n}\nfunction Ln(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 rn().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 ]), Gt = k([\n l + S * (p + s * d * i),\n M + w * (d - s * p * i)\n ]), _t = k([l + S * p, M + w * d]);\n return new _(D, _t, $, Gt);\n });\n}\nconst et = 1e-8, yt = (t) => t.flatMap((n) => v.isInstance(n) ? [n] : y.isInstance(n) ? [n] : vt.isInstance(n) ? Ln(n).flatMap(\n (e) => ht(e)\n) : bt.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: Ht(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 ($) => At($, 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 = on(\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 Ct(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 Dt(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 Ot(t, n, e) {\n return t.filter((r) => !n.segments.some((i) => bn(i, r) < Math.abs(e) - et));\n}\nfunction G(t, n) {\n const e = t.clockwise ? n : -n, r = yt(t.segments), s = J(r, e);\n if (s.length < 2) return new h();\n const i = Ct(s);\n if (!i.size) {\n const u = new P(s);\n return new h([new m(u)]);\n }\n const o = Dt(\n i,\n s\n ), c = Ot(o, t, n);\n if (!c.length) return new h();\n const a = Mt(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 En(t, n, e = \"round\") {\n const r = n / 2, s = yt(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\" ? sn(\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 = Ct(f);\n if (!a.size) {\n const l = new P(f);\n return new h([new m(l)]);\n }\n const u = Dt(\n a,\n f\n ), g = Ot(u, t, r);\n if (!g.length) return new h();\n const d = Mt(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 kn(t, n) {\n const e = t.map((r) => {\n const s = z(\n r.holes.map((i) => G(i, n))\n );\n return Ft(G(r.contour, n), s);\n });\n return z(e);\n}\nfunction Fn(t, n) {\n const e = Math.abs(n / 2), r = t.map(\n (s) => z(\n s.allLoops.map((i) => Ft(G(i, e), G(i, -e)))\n )\n );\n return z(r);\n}\nfunction Yn(t, n) {\n return kn(x(t), n);\n}\nfunction Zn(t, n, { endCap: e = \"round\" } = {}) {\n return b.isInstance(t) ? En(t, n, e) : Fn(x(t), n);\n}\nclass xn {\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 xn {\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(Lt * 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 Bt(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 Bt(It, 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 Bt(It, 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 yn 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 Wn(t) {\n return new yn(t);\n}\nconst Cn = 1 * Lt, Dn = 24;\nfunction H(t, n, e, r) {\n const s = t.gradientAt(n);\n return Et(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 = Et(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 ?? Cn,\n maxDepth: n.maxDepth ?? Dn\n }, r = Math.cos(e.maxAngle);\n return Q(t, 0, 1, e, r, 0);\n}\nfunction On(t, n) {\n return new h(\n t.figures.map((e) => Rt(e, n))\n );\n}\nfunction Rt(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 Bn(t, n) {\n return new b(st(t.segments, n));\n}\nfunction st(t, n) {\n return t.flatMap(n);\n}\nfunction Rn(t, n) {\n if (h.isInstance(t))\n return On(t, n);\n if (m.isInstance(t))\n return Rt(t, n);\n if (P.isInstance(t))\n return Y(t, n);\n if (b.isInstance(t))\n return Bn(t, n);\n if (St(t))\n return st([t], n);\n throw new Error(\"Unsupported shape type\");\n}\nfunction Tn(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 zn(t, n) {\n return Tn(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 Gn(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 || Gn(t) === n ? t : [...t].reverse();\n}\nfunction jn(t, n = {}) {\n return Rn(t, (r) => zn(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 an(t);\n if (m.isInstance(t))\n return fn(t);\n if (P.isInstance(t))\n return `<path d=\"${un(t)}\" />`;\n if (b.isInstance(t))\n return `<path d=\"${ln(t)}\" />`;\n if (St(t))\n return `<path d=\"${`M ${t.firstPoint.join(\" \")}`} ${hn(\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 cn(t.xMin, -t.yMax, t.xMax, -t.yMin);\nfunction te(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 Tt = (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 vt(\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 bt(\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(Tt);\n return new P(n);\n}, zt = (t) => {\n const n = Z(t.contour), e = t.holes.map(Z);\n return new m(n, e);\n}, $n = (t) => {\n const n = t.figures.map(zt);\n return new h(n);\n};\nfunction ne(t) {\n if (t.type === \"DIAGRAM\")\n return $n(t);\n if (t.type === \"FIGURE\")\n return zt(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 Tt(t);\n throw new Error(\"Unknown shape type\");\n}\nconst wt = Math.PI / 180, Un = 180 / Math.PI;\nfunction ee(t, n) {\n const e = Math.cos(n * wt) * t, r = Math.sin(n * wt) * t;\n return [e, r];\n}\nfunction re([t, n]) {\n const e = Math.sqrt(t * t + n * n), r = Math.atan2(n, t) * Un;\n return [e, r];\n}\nexport {\n wt as DEG2RAD,\n oe as DrawingPen,\n Un as RAD2DEG,\n re as cartesianToPolar,\n T as chamfer,\n Qn as confineStrand,\n Ft as cut,\n ce as draw,\n Jn as eraseStrand,\n fe as exportJSON,\n te as exportSVG,\n R as fillet,\n gn as fuse,\n z as fuseAll,\n ne as importJSON,\n Xn as intersect,\n Yn as offset,\n Zn as outlineStroke,\n ee as polarToCartesian,\n Wn as selectCorners,\n pt as svgBody,\n jn 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","k","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","qs","As","Fs","xs","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","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","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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"}