var t={d:(n,e)=>{for(var r in e)t.o(e,r)&&!t.o(n,r)&&Object.defineProperty(n,r,{enumerable:!0,get:e[r]})},o:(t,n)=>Object.prototype.hasOwnProperty.call(t,n)},n={};function e(t){let n="";for(let e=0;ee,bz:()=>wn,Ev:()=>Sn,$d:()=>Se,zh:()=>Dm,Ls:()=>km,CU:()=>Ym,gM:()=>Lm,xD:()=>Dn,SQ:()=>Kv,f4:()=>Tn,BG:()=>Qm,Ij:()=>qm,tQ:()=>Hd,C_:()=>pm,G:()=>Mn,bx:()=>Xm,DZ:()=>Ad,yc:()=>Cn,wH:()=>In,N0:()=>Nn,EC:()=>Bn,Jt:()=>l,DC:()=>Fn,PF:()=>Vn,tO:()=>_g,Sl:()=>yn,ZN:()=>zn,MY:()=>On,bA:()=>Yn,p8:()=>An,bQ:()=>Ca,WN:()=>En,r0:()=>kn,UW:()=>ib,_T:()=>ub,Dw:()=>ab,xs:()=>hm,vU:()=>Xn,y9:()=>fm,Fw:()=>lm,QE:()=>om,pI:()=>Pn});class r{constructor(){this.initialPoint=void 0,this.vals=void 0,this.prev2ndCubicControlPoint=void 0,this.prev2ndQuadraticControlPoint=void 0,this.p=[0,0]}}function o(t){const n=[t.p,t.initialPoint];return t.prev2ndCubicControlPoint=void 0,t.prev2ndQuadraticControlPoint=void 0,n}function i(t){t.prev2ndCubicControlPoint=void 0,t.prev2ndQuadraticControlPoint=void 0;const n=(e=t.p,t.vals[0],t.vals[1],t.vals[2],t.vals[3],t.vals[4],[[e,[t.vals[5],t.vals[6]]]]);var e;const r=n[n.length-1];return t.p=r[r.length-1],n}const s={c:function(t){const n=[t.p,[t.vals[0],t.vals[1]],[t.vals[2],t.vals[3]],[t.vals[4],t.vals[5]]];return t.prev2ndCubicControlPoint=n[2],t.prev2ndQuadraticControlPoint=void 0,n},h:function(t){const n=[t.p,[t.vals[0],t.p[1]]];return t.prev2ndCubicControlPoint=void 0,t.prev2ndQuadraticControlPoint=void 0,n},l:function(t){const n=[t.p,t.vals];return t.prev2ndCubicControlPoint=void 0,t.prev2ndQuadraticControlPoint=void 0,n},q:function(t){const n=[t.vals[0],t.vals[1]],e=[t.vals[2],t.vals[3]];return t.prev2ndCubicControlPoint=void 0,t.prev2ndQuadraticControlPoint=n,[t.p,n,e]},s:function(t){const n=t.prev2ndCubicControlPoint?[t.p[0]-t.prev2ndCubicControlPoint[0]+t.p[0],t.p[1]-t.prev2ndCubicControlPoint[1]+t.p[1]]:t.p,e=[t.p,n,[t.vals[0],t.vals[1]],[t.vals[2],t.vals[3]]];return t.prev2ndCubicControlPoint=e[2],t.prev2ndQuadraticControlPoint=void 0,e},t:function(t){const n=t.prev2ndQuadraticControlPoint?[t.p[0]-t.prev2ndQuadraticControlPoint[0]+t.p[0],t.p[1]-t.prev2ndQuadraticControlPoint[1]+t.p[1]]:t.p,e=[t.vals[0],t.vals[1]];return t.prev2ndCubicControlPoint=void 0,t.prev2ndQuadraticControlPoint=n,[t.p,n,e]},v:function(t){const n=[t.p,[t.p[0],t.vals[0]]];return t.prev2ndCubicControlPoint=void 0,t.prev2ndQuadraticControlPoint=void 0,n},z:o};function c(t){let n=0,e=0,r=1,o=0,i=1,s=1;const c=t._currentIndex;if(t._skipOptionalSpaces(),t._currentIndex"9")&&"."!==t._string[t._currentIndex])throw new Error("The first character of a number must be one of [0-9+-.].");const u=t._currentIndex;for(;t._currentIndex="0"&&t._string[t._currentIndex]<="9";)t._currentIndex+=1;if(t._currentIndex!==u){let n=t._currentIndex-1,r=1;for(;n>=u;)e+=r*(Number(t._string[n])-0),n-=1,r*=10}if(t._currentIndex=t._endIndex||t._string[t._currentIndex]<"0"||t._string[t._currentIndex]>"9")throw new Error("There must be a least one digit following the .");for(;t._currentIndex="0"&&t._string[t._currentIndex]<="9";)r*=10,o+=Number(t._string.charAt(t._currentIndex))/r,t._currentIndex+=1}if(t._currentIndex!==c&&t._currentIndex+1=t._endIndex||t._string[t._currentIndex]<"0"||t._string[t._currentIndex]>"9")throw new Error("There must be an exponent.");for(;t._currentIndex="0"&&t._string[t._currentIndex]<="9";)n*=10,n+=Number(t._string[t._currentIndex]),t._currentIndex+=1}let f=e+o;if(f*=i,n&&(f*=Math.pow(10,s*n)),c===t._currentIndex)throw new Error("Internal error: startIndex === source._currentIndex");return t._skipOptionalSpacesOrDelimiter(),f}const u={Z:"Z",M:"M",L:"L",C:"C",Q:"Q",A:"A",H:"H",V:"V",S:"S",T:"T",z:"Z",m:"m",l:"l",c:"c",q:"q",a:"a",h:"h",v:"v",s:"s",t:"t"};class f{constructor(t){this._string=t,this._currentIndex=0,this._endIndex=this._string.length,this._prevCommand=void 0,this._skipOptionalSpaces()}parseSegment(){const t=this._string[this._currentIndex];let n,e=u[t];if(void 0===e){if(void 0===this._prevCommand)throw new Error("Implicit command not allowed for first commands.");if(!("+"===t||"-"===t||"."===t||t>="0"&&t<="9")||"Z"===this._prevCommand)throw new Error("Remaining coordinates not found for implicit command");e="M"===this._prevCommand?"L":"m"===this._prevCommand?"l":this._prevCommand}else this._currentIndex+=1;this._prevCommand=e;const r=e.toUpperCase();if("H"===r||"V"===r?n=[c(this)]:"M"===r||"L"===r||"T"===r?n=[c(this),c(this)]:"S"===r||"Q"===r?n=[c(this),c(this),c(this),c(this)]:"C"===r?n=[c(this),c(this),c(this),c(this),c(this),c(this)]:"A"===r?n=[c(this),c(this),c(this),this._parseArcFlag(),this._parseArcFlag(),c(this),c(this)]:"Z"===r&&(this._skipOptionalSpaces(),n=[]),void 0===n)throw new Error("Unknown command");return{type:e,values:n}}hasMoreData(){return this._currentIndex=this._endIndex)throw new Error("Unable to parse arc flag");let t;const n=this._string[this._currentIndex];if(this._currentIndex+=1,"0"===n)t=0;else{if("1"!==n)throw new Error("Unable to parse arc flag - arc flag must be 0 or 1");t=1}return this._skipOptionalSpacesOrDelimiter(),t}}function l(t){return function(t){if(0===t.length)return[];if("m"!==t[0].type.toLowerCase())throw new Error("Invalid SVG - every new path must start with an M or m.");const n=new r,e=[];let c,u=[];for(let r=0;r0&&("z"!==c&&u.push(o(n)),e.push(u)),e}(function(t){if(!t.length)return[];const n=new f(t),e=[];if(!n.initialCommandIsMoveTo())throw new Error("Path must start with m or M");for(;n.hasMoreData();)e.push(n.parseSegment());return e}(t))}function h(t,n){let e=function(t,n){let e;return e=t.curve.idx-n.curve.idx,0!==e||(e=t.t-n.t),e}(t.pointOnShape,n.pointOnShape);return 0!==e?e:(e=t.order-n.order,0!==e?e:t.order2-n.order2)}function a(t,n){const[[e,r],[o,i]]=t,[[s,c],[u,f]]=n,l=o-e,h=i-r,a=u-s,p=f-c,d=a*h-p*l;if(0===d)return;const g=((c-r)*l-(s-e)*h)/d;return[s+g*a,c+g*p]}function p(t,n){const e=n[0]-t[0],r=n[1]-t[1];return e*e+r*r}function d(t,n){return[n[0]-t[0],n[1]-t[1]]}function g(t,n,e){return[t[0]+(n[0]-t[0])*e,t[1]+(n[1]-t[1])*e]}function v(t,n){return t[0]===n[0]&&t[1]===n[1]}function m(t,n,e){let r,o=Number.POSITIVE_INFINITY;for(let i=0;i>7,i=((127&e)<<4)+((240&r)>>4),s=0===i?0:16,c=0===i?i-1022:i-1023,u=n.slice(1);return u[0]=(15&r)+s,{sign:o,exponent:c,significand:u}}function B(t){return z(t).significand}function Y(t){return Math.log2(t&-t)}function F(t){if(0===t||!Number.isFinite(t))return NaN;const n=B(t),e=n.length;for(let t=e-1;t>=0;t--){if(0===n[t])continue;const r=Y(n[t]);if(Number.isFinite(r))return 8*(e-t-1)+r}return NaN}function V(t){return t>=128?7:t>=64?6:t>=32?5:t>=16?4:t>=8?3:t>=4?2:t>=2?1:t>=1?0:NaN}function k(t){if(0===t||!Number.isFinite(t))return NaN;const n=B(t),e=n.length;for(let t=0;t=0;--t){const e=r,i=n[t];r=e+i;const s=i-(r-e);s&&(n[--o]=r,r=s)}let i=0;for(let t=o;t0;){const i=D(t[o-1]);if(e-i>n)break;r=i,o--}const i=Math.min(n-(e-r),53);let s=t[o];s=q(s,i);const c=t.slice(o);return c[0]=s,c}function H(t){let n=t[0];for(let e=1;ee)return i?(o=ct(o,s),o):o.slice(o.length-e,o.length);r=st(r,c),c=ft([2],r),u*=2}}function at(t,n){const e=t.length;let r=n;const o=[];for(let n=0;n=0;o--){const s=t[o],c=Math.round((s-s%e)/e);if(r.push(St(n,c)),0===c)break;i.push(c)}if(t=_t(Et(t,Nt(r))),s===i.length)break;s=i.length}let c=t,u=[0];for(let t=0;t0?o>0?(u=It(u,-1),c=xt(c,n)):(u=It(u,1),c=xt(c,bt(n))):r<0&&(o>0?(u=It(u,1),c=xt(c,bt(n))):(u=It(u,-1),c=xt(c,n)))),{div:u,rem:c}}const Pt=Mt,Tt=Mt;function yt(t,n){return y(rt(t,n))}const Ct=tt;function Ot(t){return t[t.length-1]<0?Ct(t):t}function At(t){const n=[];for(let e=0;e0){if(o<=0)return i;s=r+o}else{if(!(r<0))return i;if(o>=0)return i;s=-r-o}return Math.abs(i)>=Jt*s?i:function(t,n,e,r){const o=t[0]-e[0],i=n[0]-e[0],s=t[1]-e[1],c=n[1]-e[1],u=rt(Ft(o,c),Ft(s,i));let f=H(u);if(Math.abs(f)>=Kt*r)return f;const l=T(t[0],e[0])[0],h=T(n[0],e[0])[0],a=T(t[1],e[1])[0],p=T(n[1],e[1])[0];if(0===l&&0===a&&0===h&&0===p)return f;const d=tn*r+nn*Math.abs(f);if(f+=o*p+c*l-(s*h+i*a),Math.abs(f)>=d)return f;const g=R(u,rt(Ft(l,c),Ft(a,i))),v=R(g,rt(Ft(o,p),Ft(s,h)));let m=R(v,rt(Ft(l,p),Ft(a,h)));return m=X(m),m[m.length-1]}(t,n,e,s)}function rn(t,n){return!function(t,n){if(0===t||0===n)return!0;Math.abs(n)>Math.abs(t)&&([t,n]=[n,t]);const e=F(t),r=k(n);return e+(L(t)-L(n))>r}(t,n)}const on=R,sn=K,cn=j,un={fastTwoDiff:function(t,n){const e=t-n;return[t-e-n,e]},fastTwoSum:function(t,n){const e=t+n;return[n-(e-t),e]},split:function(t){const n=134217729*t,e=n-(n-t);return[e,t-e]},twoDiff:T,twoProduct:Ft,twoSum:pt,reduceSignificand:q,fastExpansionSum:R,eAdd:on,growExpansion:at,eAddDouble:at,expansionProduct:K,eMult:sn,scaleExpansion:Z,eMultDouble1:Z,scaleExpansion2:j,eMultDouble2:cn,eDiv:ht,eLongDivide:Mt,eIntDiv:function(t,n){return Pt(t,n).div},eRem:function(t,n){return Tt(t,n).rem},eCompress:X,eEstimate:H,eDiff:rt,eNegativeOf:tt,eMultBy2:At,eMultByNeg2:zt,eDivBy2:Bt,eSign:y,eCompare:yt,eAbs:Ot,eToBitlength:G,eIntPow:function(t,n){if(0===n)return[1];if(1===n)return t;if(2===n)return Ut(t,t);const e=[];for(let r=0;r=e&&o<=n-1+e},msbExponent:D,lsbExponent:function(t){if(0===t||!Number.isFinite(t))return NaN;const n=L(t);return F(t)-52+n},bitLength:ot,expBitLength:it,doubleToBinaryString:O,doubleToOctets:C,getHighestSetBit:k,getLowestSetBit:F,exponent:L,significand:B,orient2d:en,isAdjacent:function(t,n){return rn(t,n)||rn(t,2*n)||rn(2*t,n)},isNonOverlappingAll:function(t){for(let n=1;n0?0:function(t,n){const[e,r]=fn(t),[o,i]=ln(t),[s,c]=fn(n),[u,f]=ln(n),l=rt(Ft(e,i),Ft(r,o)),h=rt(Ft(s,f),Ft(c,u)),a=y(l),p=y(h);if(a!==p)return a-p;const d=R(Ft(s,s),Ft(c,c)),g=R(Ft(e,e),Ft(r,r)),v=K(d,d),m=K(v,d),b=K(g,g),x=K(b,g);if(0!==a||0!==p){const t=K(l,l),n=K(h,h),e=y(rt(K(t,m),K(n,x)));if(0!==e)return a>0?e:-e}const[[_],[I]]=hn(t),[[N],[S]]=hn(n),E=rt(Ft(e,I),Ft(r,_)),w=R(Ft(e,o),Ft(r,i)),M=rt(Ft(s,S),Ft(c,N)),P=R(Ft(s,u),Ft(c,f)),T=rt(K(g,E),Z(K(l,w),3)),C=rt(K(d,M),Z(K(h,P),3)),O=y(T),A=y(C);if(a!==p)return O-A;if(0===O&&0===A)return 0;const z=K(T,T),B=K(v,m),Y=K(C,C),F=K(b,x),V=y(rt(K(z,B),K(Y,F)));return O>0?V:-V}(t.slice().reverse(),n)}(t,n),r=e<0,o=e>0,i=t[t.length-2],s=t[t.length-1],c=[s[0]-i[0],s[1]-i[1]],u=n[0],f=n[1],l=[f[0]-u[0],f[1]-u[1]],h=[N(c),N(l)],a=_(h[0],h[1]);let p,d;return b(c,l)>0?(p=a<-an,d=a>+an):(p=r,d=o),{tangents:h,crossTangents:a,isSharp:r,isDull:o,isQuiteSharp:p,isQuiteDull:d}}const dn=P((function(t){return pn(t.ps,t.next.ps)}));function gn(t){return dn(1===t.t?t.curve:t.curve.prev)}function vn(t){return 0===t.t||1===t.t}const mn=P((t=>!!vn(t)&&gn(t).isSharp));function bn(t){const n=t.cp.circle.center,e=t,r=t.nextOnCircle,o=e.cp.pointOnShape,i=r.cp.pointOnShape,s=o.p,c=i.p;let u;if(mn(o)){let t,n;0===o.t?(t=o.curve,n=o.curve.prev):1===o.t&&(t=o.curve.next,n=o.curve);const e=N(M(t.ps,0)),r=[-(f=N(M(n.ps,1)))[0],-f[1]],i=b(e,r),s=Math.sqrt((1+i)/2);u=S(Math.sqrt((1-i)/2),s,r)}else u=s[0]===c[0]&&s[1]===c[1]?d(s,n):x(d(s,c));var f;return[n,I(N(u),n)]}const xn=.01,_n=1e-4;function In(t,n){const e=t.cp.circle.center,r=bn(t),o=n.cp.circle.center,i=bn(n.prevOnCircle),s=a(r,i),c=d(e,o);let u;if(s){const t=d(e,s),n=d(o,s);u=b(t,c)<0||b(n,c)>0}else u=!0;if(!u)return[e,s,o];const f=x(c),l=d(r[0],r[1]),h=d(i[0],i[1]),p=Math.abs(_(c,l))/9,v=Math.abs(_(c,h))/9;if(p>xn||v>xn)return[e,o];if(p>_n||v>_n){const t=g(e,o,1/3),n=g(e,o,2/3),s=I(f,t),c=[n,I(f,n)];return[e,a(r,[t,s]),a(i,c),o]}return[e,o]}function Nn(t){return In(t,t.next)}function Sn(t,n,e,r=void 0,o=void 0,i=void 0,s=void 0){return{cp:t,isHoleClosing:n,isIntersection:e,prev:r,next:o,prevOnCircle:i,nextOnCircle:s}}function En(t){return Nn(t)}const wn=(t,n)=>h(t.cp,n.cp);function Mn(t){const n=[],e=t.next;let r=e;do{n.push(r),r=r.nextOnCircle}while(r.nextOnCircle!==e);return n}function Pn(t){if(An(t))return[];const n=[];let e=t;for(;e!==t.prevOnCircle;)An(e)||n.push(e.next),e=e.nextOnCircle;return n}function Tn(t){const n=t,e=[n];let r=t.next;for(;r!==n;)e.push(r),r=r.next;return e}function yn(t,n,e,r,o){const i=Sn(r,t,n);let s,c;return"undefined"!=typeof _debug_&&_debug_.generated.elems.cpNode.push({generated:_debug_.generated,cpNode:i}),o?(s=o,c=s.next):(s=i,c=i),c.prev=i,s.next=i,i.prev=s,i.next=c,e.insert(i),i}function Cn(t,n=!1){const e=t;let r=e;const o=[];do{n?n=!1:o.push(r),r=r.nextOnCircle}while(r!==e);return o}function On(t,n){return Cn(t,!0).indexOf(n)>=0}function An(t){return t===t.next.prevOnCircle}function zn(t){return Cn(t.prevOnCircle,!0).every((t=>An(t)))}function Bn(t){const n=t;let e=n;for(;e.next===e.prevOnCircle;)if(e=e.next,e===n)return;return e}function Yn(t){return 0===t.cp.circle.radius}function Fn(t){const n=t;let e=n,r=0;do{r++,e=e.nextOnCircle}while(e!==n);return r}function Vn(t){return function(t){const n=t;if(0===n.cp.circle.radius)return!0;const e=n.nextOnCircle,r=n.cp.pointOnShape.p,o=e.cp.pointOnShape.p;return r[0]===o[0]&&r[1]===o[1]}(t)?1:Fn(t)}function kn(t,n){const e=t.prev,r=t.next;e.next=r,r.prev=e;const o=r.prevOnCircle,i=e.nextOnCircle;o.next=i,i.prev=o,n&&n.remove(t,!1)}function Ln(t){const n=t.cp,e=n.pointOnShape;return{idx:e.curve.idx,t:e.t,order:n.order,order2:n.order2}}function Dn(t){const n=t.cp.pointOnShape.curve;return{...t,isTerminating:An(t),isFullyTerminating:zn(t),isSharp:Yn(t),prongCount:Fn(t),getRealProngCount:Vn(t),ordering:Ln(t),curve:n,loop:n.loop}}function Xn(t){let n=t;if(n===n.next.prevOnCircle)return[n];const e=[];do{e.push(n);const t=n.next.prevOnCircle;n=n=n===t?n.next.next:t}while(n!==t);return e}function qn(t,n){const e=t[0],r=t[1],o=n[0],i=n[1],s=r-i,c=s-r,u=e-o,f=u-e,l=r-(s-c)+(-i-c)+u,h=s+l,a=e-(u-f)+(-o-f)+(l-(h-s)),p=h+a;return[a-(p-h),p]}const Qn=qn,$n=qn;Number.EPSILON;const Gn=2**27+1;const Hn=134217729,Rn=134217729;function Un(t,n){const e=t[0],r=t[1],o=n[0],i=n[1],s=r/i,c=i*s,u=Rn*i,f=u-(u-i),l=i-f,h=Rn*s,a=h-(h-s),p=s-a,d=o*s,g=c+d,v=d-(g-c)+(l*p-(c-f*a-l*a-f*p)),m=g+v,b=(r-m+(e-(v-(m-g))))/i,x=s+b;return[b-(x-s),x]}const Zn=134217729,jn=Un,Wn=Number.EPSILON/2,Jn=Wn*Wn,Kn=Number.EPSILON/2,te=function(t,n){const e=n[0],r=n[1],o=r*t,i=Hn*r,s=i-(i-r),c=r-s,u=Hn*t,f=u-(u-t),l=t-f,h=c*l-(o-s*f-c*f-s*l)+e*t,a=o+h;return[h-(a-o),a]},ne=function(t){const n=t[0],e=t[1];if(0===e)return[0,0];const r=Math.sqrt(e),o=r*r,i=134217729*r,s=i-(i-r),c=r-s,u=.5*(e-o-(c*c-(o-s*s-s*c*2))+n)/r;return[u-(r+u-r),r+u]},ee=function(t,n){if(t-n<=0){const e=t>0?Math.sqrt(t):0;return{est:e,err:Math.max(Math.sqrt(t+n)-e,e)}}const e=Math.sqrt(t),r=Math.sqrt(t-n),o=Math.sqrt(t+n);return{est:e,err:Math.max(Math.abs(r-e),Math.abs(o-e))}},re=function(t,n){const e=t[0],r=t[1],o=r+n,i=o-r,s=e+(r-(o-i)+(n-i)),c=o+s;return[s-(c-o),c]},oe=function(t,n){const e=t[0],r=t[1],o=n[0],i=n[1],s=r+i,c=s-r,u=e+o,f=u-e,l=r-(s-c)+(i-c)+u,h=s+l,a=e-(u-f)+(o-f)+(l-(h-s)),p=h+a;return[a-(p-h),p]},ie=qn,se=function(t,n){const e=n[0],r=n[1],o=r*t,i=Hn*r,s=i-(i-r),c=r-s,u=Hn*t,f=u-(u-t),l=t-f,h=e*t,a=o+h,p=h-(a-o)+(c*l-(o-s*f-c*f-s*l)),d=a+p;return[p-(d-a),d]},ce=function(t){return[2*t[0],2*t[1]]},ue=function(t){return[4*t[0],4*t[1]]},fe=function(t){return[-2*t[0],-2*t[1]]},le=function(t,n){const e=t[1],r=n[1],o=e*r,i=Gn*e,s=i-(i-e),c=e-s,u=Gn*r,f=u-(u-r),l=r-f,h=c*l-(o-s*f-c*f-s*l)+(e*n[0]+t[0]*r),a=o+h;return[h-(a-o),a]},he=Un,ae=function(t){return[-t[0],-t[1]]},pe=function(t,n){const e=t-n,r=t-e;return[t-(e+r)+(r-n),e]},de=function(t,n){const e=t*n,r=Zn*t,o=r-(r-t),i=t-o,s=Zn*n,c=s-(s-n),u=n-c;return[i*u-(e-o*c-i*c-o*u),e]},ge=function(t,n){const e=t+n,r=e-t;return[t-(e-r)+(n-r),e]},ve=function(t,n,e,r){const o=t/n,i=Math.abs(t),s=Math.abs(n),c=s-r;return c<=0?{est:o,err:Number.POSITIVE_INFINITY}:{est:o,err:(s*e+i*r)/c**2+Kn*Math.abs(i/s)}},me=le,be=oe,xe=ie,_e=pe,Ie=re;function Ne(t,n){if(0===n[0]&&0===n[1])return t[0].map((t=>[0,t]));if(0===n[0]&&1===n[1])return t[t.length-1].map((t=>[0,t]));if(4===t.length){const[[e,r],[o,i],[s,c],[u,f]]=t,l=Ie(me(_e(o,e),n),e),h=Ie(me(_e(s,o),n),o),a=Ie(me(_e(u,s),n),s),p=be(l,me(xe(h,l),n)),d=be(h,me(xe(a,h),n)),g=be(p,me(xe(d,p),n)),v=Ie(me(_e(i,r),n),r),m=Ie(me(_e(c,i),n),i),b=Ie(me(_e(f,c),n),c),x=be(v,me(xe(m,v),n)),_=be(m,me(xe(b,m),n));return[g,be(x,me(xe(_,x),n))]}if(3===t.length){const[[e,r],[o,i],[s,c]]=t,u=be([0,e],me(_e(o,e),n)),f=be([0,o],me(_e(s,o),n)),l=be(u,me(xe(f,u),n)),h=be([0,r],me(_e(i,r),n)),a=be([0,i],me(_e(c,i),n));return[l,be(h,me(xe(a,h),n))]}if(2===t.length){const[[e,r],[o,i]]=t;return[Ie(me(_e(o,e),n),e),Ie(me(_e(i,r),n),r)]}if(1===t.length){const[n,e]=t[0];return[[0,n],[0,e]]}throw new Error("The given bezier curve must be of order <= 3.")}function Se(t,n,e){return{curve:t,t:n,p:Ne(t.ps,[0,n]).map((t=>t[1])),source:e}}const Ee=Number.EPSILON/2,we=Ee*Ee,Me=te,Pe=H,Te=function(t){const n=3*we;return n/(1-n)}(),ye=Z,Ce=pt,Oe=Ft,Ae=Math.abs,ze=Number.EPSILON/2;function Be(t,n){let e=t[0],r=.5*Ae(e);for(let o=1;o1/t(function(t){return t.slice().reverse()}(n))};function rr(t){const n=t.length-1;if(n<1)return 0;t[0]<0&&(t=nr(t));const e=[];for(let t=0;t=0)continue;let n=Number.POSITIVE_INFINITY,i=!1;for(let r=0;rs&&(n=s),i=!0}i&&r-Ir(function(t){const n=t.length-1;if(n<0)return[];const e=t.slice();for(let t=0;tt),r=r||new Array(t.length).fill(0);let s,c,u=0;for(;t.length>0&&xr(t[0][1])<=r[0]&&(c=c||o(),0===vr(c[0]));)(t=t.slice()).shift(),(r=r.slice()).shift(),c.shift();if(0===t.length)return i?void 0:[];if(1===t.length)return[];if(n===Number.NEGATIVE_INFINITY||e===Number.POSITIVE_INFINITY){const r=t.map((t=>t[1]));n===Number.NEGATIVE_INFINITY&&(n=hr(r)),e===Number.POSITIVE_INFINITY&&(e=ar(r))}const f=ur(t);let l,h;const a=t.length-1;let p,d;l=0,h=!1;do{if(p=h?dr(cr(_(),n)):sr(f,n,r),0===p){if(l++,l>=3&&!h){h=!0;continue}n-=2*Number.EPSILON*mr(1,xr(n))}}while(0===p);l=0,h=!1;do{if(d=h?dr(cr(_(),e)):sr(f,e,r),0===d){if(l++,l>=3&&!h){h=!0;continue}e+=2*Number.EPSILON*mr(1,xr(e))}}while(0===d);const g=[{p:t,pE:r}],v=[ur(t)];for(let t=1;t<=a;t++){const n=ir(g[t-1]);g.push(n),v.push(ur(n.p))}let m,b,x=[];for(u=a-1;u>=0;u--)m=g[u].pE,b=v[u],x=I();function _(){if(void 0!==s)return s[u];let t=c||o();for(s=[t];t.length>1;)t=pr(t),s.push(t);return s[u]}return x;function I(){const t=[],r=fr(b,m,n,_);if(!x.length){const t=fr(b,m,e,_);if(r*t>=0)return[];const[o,i]=lr(b,m,n,e,r,t,_);return[{tS:o,tE:i,multiplicity:1}]}let o=x[0].tS,i=fr(b,m,o,_);if(r*i>0);else if(r*i<0){const[e,s]=lr(b,m,n,o,r,i,_);t.push({tS:e,tE:s,multiplicity:1})}let s,c=n,f=r,l=o,h=i;for(let n=0;n0)if(f*h>0)c!==o&&s.multiplicity%2==1&&p();else if(f*h<0){c!==o&&s.multiplicity%2==1&&p();const[n,e]=lr(b,m,c,l,f,h,_);t.push({tS:n,tE:e,multiplicity:1})}else c!==o&&s.multiplicity%2==1&&p();else if(i*f<0){if(t.push({tS:s.tS,tE:s.tE,multiplicity:3}),f*h<0){const[n,e]=lr(b,m,c,l,f,h,_);t.push({tS:n,tE:e,multiplicity:1})}}else if(0===f)0===i?t.push({tS:s.tS,tE:s.tE,multiplicity:s.multiplicity+1}):i*h>0?t.push({tS:s.tS,tE:s.tE,multiplicity:2}):t.push({tS:s.tS,tE:s.tE,multiplicity:3});else{if(f*h<0){const[n,e]=lr(b,m,c,l,f,h,_);t.push({tS:n,tE:e,multiplicity:1})}u*f>0?t.push({tS:s.tS,tE:s.tE,multiplicity:2}):t.push({tS:s.tS,tE:s.tE,multiplicity:3})}}for(let n=0;n=r.tS)return Sr(t)}return t;function p(){const n=(c-o)*_r;let e=1,r=0;for(let t=u+2;t<=a;t++){const i=v[t][0],s=gr(i,o);r+=(xr(s[0])+s[1])*e,e*=n*_r}const l=f>0?br(i,f):mr(i,f),h=2*Number.EPSILON*mr(1,xr(c)),p=r*(2*h);(l+(f>0?2*-p*h:2*p*h))*f<0&&t.push({tS:s.tS,tE:s.tE,multiplicity:2})}}}function Sr(t){const n=[],e=t[0];let r={tS:e.tS,tE:e.tE,multiplicity:e.multiplicity};for(let e=0;e[0,t])),n,e,void 0,void 0,r)}function wr(t){if(4===t.length)return function(t){const[[n,e],[r,o],[i,s],[c,u]]=t;return[[3*(c-n+3*(r-i)),6*(i+n-2*r),3*(r-n)],[3*(u-e+3*(o-s)),6*(s+e-2*o),3*(o-e)]]}(t);if(3===t.length)return function(t){const[[n,e],[r,o],[i,s]]=t;return[[2*(i+n-2*r),2*(r-n)],[2*(s+e-2*o),2*(o-e)]]}(t);if(2===t.length)return function(t){const[[n,e],[r,o]]=t;return[[r-n],[o-e]]}(t);if(1===t.length)return[[0],[0]];throw new Error("The bezier curve must be of order <= 3.")}function Mr(t,n){if(0===n)return t[0];if(1===n)return t[t.length-1];if(4===t.length){const[[e,r],[o,i],[s,c],[u,f]]=t,l=e+(o-e)*n,h=o+(s-o)*n,a=l+(h-l)*n,p=r+(i-r)*n,d=i+(c-i)*n,g=p+(d-p)*n;return[a+(h+(s+(u-s)*n-h)*n-a)*n,g+(d+(c+(f-c)*n-d)*n-g)*n]}if(3===t.length){const[[e,r],[o,i],[s,c]]=t,u=e+(o-e)*n,f=r+(i-r)*n;return[u+(o+(s-o)*n-u)*n,f+(i+(c-i)*n-f)*n]}if(2===t.length){const[[e,r],[o,i]]=t;return[e+(o-e)*n,r+(i-r)*n]}if(1===t.length)return t[0];throw new Error("The given bezier curve must be of order <= 3.")}const Pr=Math.abs;function Tr(t,n){if(0===n[0]&&0===n[1])return[0,0];if(0===n[0]&&1===n[1])return[0,0];const e=Pr(n[1]);if(4===t.length){const[[n,r],[o,i],[s,c],[u,f]]=t,l=Pr(n),h=Pr(r),a=Pr(o),p=Pr(i),d=Pr(s),g=Pr(c),v=l+(a+l)*e,m=a+(d+a)*e,b=v+(m+v)*e,x=h+(p+h)*e,_=p+(g+p)*e,I=x+(_+x)*e;return[b+(m+(d+(Pr(u)+d)*e+m)*e+b)*e,I+(_+(g+(Pr(f)+g)*e+_)*e+I)*e]}if(3===t.length){const[[n,r],[o,i],[s,c]]=t,u=Pr(n),f=Pr(r),l=Pr(o),h=Pr(i),a=u+(l+u)*e,p=f+(h+f)*e;return[a+(l+(Pr(s)+l)*e+a)*e,p+(h+(Pr(c)+h)*e+p)*e]}if(2===t.length){const[[n,r],[o,i]]=t,s=Pr(n),c=Pr(r);return[s+(Pr(o)+s)*e,c+(Pr(i)+c)*e]}if(1===t.length)return[0,0];throw new Error("The given bezier curve must be of order <= 3.")}const yr=Number.EPSILON/2,Cr=yr*yr;function Or(t){const n=t*yr;return n/(1-n)}function Ar(t){const n=t*Cr;return n/(1-n)}Or(1),Ar(3);const zr=Math.abs,Br=[[0,0],[0,0],[0,0],[0,0]];const Yr=Math.abs,Fr=[[0,0],[0,0],[0,0]];const Vr=Math.abs,kr=[[0,0],[0,0]];const Lr=Number.EPSILON/2,Dr=Or(1);function Xr(t,n){return n[0]!==n[1]?4===t.length?function(t,n){const{ps:e,_ps:r}=function(t,n,e){return 0===n?1===e?{ps:t,_ps:Br}:function(t,n){const e=t[0],r=t[1],o=t[2],i=t[3],s=e[0],c=e[1],u=r[0],f=r[1],l=o[0],h=o[1],a=i[0],p=i[1],d=s-n*(s-u),g=u-n*(u-l),v=d-n*(d-g),m=v-n*(v-(g-n*(g-(l-n*(l-a))))),b=c-n*(c-f),x=f-n*(f-h),_=b-n*(b-x),I=_-n*(_-(x-n*(x-(h-n*(h-p))))),N=zr(n),S=zr(s),E=zr(u),w=zr(l),M=zr(a),P=zr(c),T=zr(f),y=zr(h),C=S+N*(S+E),O=E+N*(E+w),A=C+N*(C+O),z=P+N*(P+T),B=T+N*(T+y),Y=z+N*(z+B);return{ps:[[s,c],[d,b],[v,_],[m,I]],_ps:[[0,0],[C,z],[A,Y],[A+N*(A+(O+N*(O+(w+N*(w+M))))),Y+N*(Y+(B+N*(B+(y+N*(y+zr(p))))))]]}}(t,e):1===e?function(t,n){const e=t[0],r=t[1],o=t[2],i=t[3],s=e[0],c=e[1],u=r[0],f=r[1],l=o[0],h=o[1],a=i[0],p=i[1],d=s-n*(s-u),g=u-n*(u-l),v=l-n*(l-a),m=d-n*(d-g),b=g-n*(g-v),x=m-n*(m-b),_=c-n*(c-f),I=f-n*(f-h),N=h-n*(h-p),S=_-n*(_-I),E=I-n*(I-N),w=S-n*(S-E),M=zr(n),P=zr(s),T=zr(u),y=zr(l),C=zr(a),O=zr(c),A=zr(f),z=zr(h),B=P+M*(P+T),Y=T+M*(T+y),F=y+M*(y+C),V=B+M*(B+Y),k=Y+M*(Y+F),L=O+M*(O+A),D=A+M*(A+z),X=z+M*(z+zr(p)),q=L+M*(L+D),Q=D+M*(D+X);return{ps:[[x,w],[b,E],[v,N],[a,p]],_ps:[[V+M*(V+k),q+M*(q+Q)],[k,Q],[F,X],[0,0]]}}(t,n):function(t,n,e){const r=t[0],o=t[1],i=t[2],s=t[3],c=r[0],u=r[1],f=o[0],l=o[1],h=i[0],a=i[1],p=n*n,d=n*p,g=e*e,v=e*g,m=n*e,b=c-f,x=h-f,_=s[0]-c,I=b+x,N=n*b,S=e*b,E=_-3*x,w=u-l,M=a-l,P=s[1]-u,T=w+M,y=n*w,C=e*w,O=P-3*M,A=d*E+(3*n*(n*I-b)+c),z=m*(n*E+2*I)+(p*I+c-(S+2*N)),B=m*(e*E+2*I)+(g*I+c-(2*S+N)),Y=v*E+(3*e*(e*I-b)+c),F=d*O+(3*n*(n*T-w)+u),V=m*(n*O+2*T)+(p*T+u-(C+2*y)),k=m*(e*O+2*T)+(g*T+u-(2*C+y)),L=v*O+(3*e*(e*T-w)+u),D=zr(n),X=zr(e),q=zr(m),Q=zr(d),$=zr(v),G=zr(c),H=zr(f),R=G+H,U=zr(h)+H,Z=R+U,j=D*R,W=X*R,J=zr(_)+3*U,K=zr(u),tt=zr(l),nt=K+tt,et=zr(a)+tt,rt=nt+et,ot=D*nt,it=X*nt,st=zr(P)+3*et;return{ps:[[A,F],[z,V],[B,k],[Y,L]],_ps:[[Q*J+(3*D*(D*Z+R)+G),Q*st+(3*D*(D*rt+nt)+K)],[q*(D*J+2*Z)+(p*Z+G+(W+2*j)),q*(D*st+2*rt)+(p*rt+K+(it+2*ot))],[q*(X*J+2*Z)+(g*Z+G+(2*W+j)),q*(X*st+2*rt)+(g*rt+K+(2*it+ot))],[$*J+(3*X*(X*Z+R)+G),$*st+(3*X*(X*rt+nt)+K)]]}}(t,n,e)}(t,n[0],n[1]),o=e[0][0],i=e[1][0],s=e[2][0],c=e[3][0],u=9*Lr*r[0][0],f=9*Lr*r[1][0],l=9*Lr*r[2][0],h=9*Lr*r[3][0],a=e[0][1],p=e[1][1],d=e[2][1],g=e[3][1],v=9*Lr*r[0][1],m=9*Lr*r[1][1],b=9*Lr*r[2][1],x=9*Lr*r[3][1],_=Math.min(o-u,i-f,s-l,c-h),I=Math.max(o+u,i+f,s+l,c+h);return[[_,Math.min(a-v,p-m,d-b,g-x)],[I,Math.max(a+v,p+m,d+b,g+x)]]}(t,n):3===t.length?function(t,n){const{ps:e,_ps:r}=function(t,n,e){return 0===n?1===e?{ps:t,_ps:Fr}:function(t,n){const e=t[0],r=t[1],o=t[2],i=e[0],s=e[1],c=r[0],u=r[1],f=o[0],l=o[1],h=n*n,a=i-c,p=s-u,d=[[i,s],[-n*a+i,-n*p+s],[h*(a+(f-c))-(2*n*a-i),h*(p+(l-u))-(2*n*p-s)]],g=Yr(n),v=Yr(i),m=Yr(c),b=Yr(f),x=v+m,_=Yr(s),I=Yr(u),N=_+I;return{ps:d,_ps:[[0,0],[g*x+v,g*N+_],[h*(x+(b+m))+(2*g*x+v),h*(N+(Yr(l)+I))+(2*g*N+_)]]}}(t,e):1===e?function(t,n){const e=t[0],r=t[1],o=t[2],i=e[0],s=e[1],c=r[0],u=r[1],f=o[0],l=o[1],h=n*n,a=i-c,p=f-c,d=s-u,g=l-u,v=[[h*(a+p)-(2*n*a-i),h*(d+g)-(2*n*d-s)],[n*p+c,n*g+u],[f,l]],m=Yr(n),b=Yr(i),x=Yr(c),_=b+x,I=Yr(f)+x,N=Yr(s),S=Yr(u),E=N+S;return{ps:v,_ps:[[h*(_+I)+(2*m*_+b),h*(E+(Yr(l)+S))+(2*m*E+N)],[m*I+x,0],[0,0]]}}(t,n):function(t,n,e){const r=t[0],o=t[1],i=t[2],s=r[0],c=r[1],u=o[0],f=o[1],l=i[0],h=i[1],a=n*n,p=e*e,d=n*e,g=s-u,v=g+(l-u),m=c-f,b=m+(h-f),x=a*v-(2*n*g-s),_=d*v-(g*(e+n)-s),I=p*v-(2*e*g-s),N=a*b-(2*n*m-c),S=d*b-(m*(e+n)-c),E=p*b-(2*e*m-c),w=Yr(n),M=Yr(e),P=Yr(d),T=Yr(s),y=Yr(u),C=T+y,O=C+Yr(l)+y,A=Yr(c),z=Yr(f),B=A+z,Y=B+Yr(h)+z;return{ps:[[x,N],[_,S],[I,E]],_ps:[[a*O+(2*w*C+T),a*Y+(2*w*B+A)],[P*O+(C*(M+w)+T),P*b+(B*(M+w)+A)],[p*O+(2*M*C+T),p*Y+(2*M*B+A)]]}}(t,n,e)}(t,n[0],n[1]),o=e[0][0],i=e[1][0],s=e[2][0],c=5*Lr*r[0][0],u=5*Lr*r[1][0],f=5*Lr*r[2][0],l=e[0][1],h=e[1][1],a=e[2][1],p=5*Lr*r[0][1],d=5*Lr*r[1][1],g=5*Lr*r[2][1],v=Math.min(o-c,i-u,s-f),m=Math.max(o+c,i+u,s+f);return[[v,Math.min(l-p,h-d,a-g)],[m,Math.max(l+p,h+d,a+g)]]}(t,n):function(t,n){const{ps:e,_ps:r}=function(t,n,e){return 0===n?1===e?{ps:t,_ps:kr}:function(t,n){const e=t[0],r=t[1],o=e[0],i=e[1],s=r[0],c=r[1],u=[[o,i],[n*(s-o)+o,n*(c-i)+i]],f=Vr(n),l=Vr(o),h=Vr(s),a=Vr(i);return{ps:u,_ps:[[0,0],[f*(h+l)+l,f*(Vr(c)+a)+a]]}}(t,e):1===e?function(t,n){const e=t[0],r=t[1],o=e[0],i=e[1],s=r[0],c=r[1],u=[[n*(s-o)+o,n*(c-i)+i],[s,c]],f=Vr(n),l=Vr(o),h=Vr(s),a=Vr(i);return{ps:u,_ps:[[f*(h+l)+l,f*(Vr(c)+a)+a],[0,0]]}}(t,n):function(t,n,e){const r=t[0],o=t[1],i=r[0],s=r[1],c=o[0],u=o[1],f=[[n*(c-i)+i,n*(u-s)+s],[e*(c-i)+i,e*(u-s)+s]],l=Vr(n),h=Vr(e),a=Vr(i),p=Vr(c),d=Vr(s),g=Vr(u);return{ps:f,_ps:[[l*(p+a)+a,l*(g+d)+d],[h*(p+a)+a,h*(g+d)+d]]}}(t,n,e)}(t,n[0],n[1]),o=e[0][0],i=e[1][0],s=3*Lr*r[0][0],c=3*Lr*r[1][0],u=e[0][1],f=e[1][1],l=3*Lr*r[0][1],h=3*Lr*r[1][1],a=Math.min(o-s,i-c),p=Math.max(o+s,i+c);return[[a,Math.min(u-l,f-h)],[p,Math.max(u+l,f+h)]]}(t,n):function(t,n){const e=t[0],r=t[t.length-1];if(0===n)return[e,e];if(1===n)return[r,r];const o=Mr(t,n);let i;if(4===t.length)i=Tr(t,[0,n]).map((t=>8*Dr*t));else if(3===t.length)i=Tr(t,[0,n]).map((t=>5*Dr*t));else if(2===t.length)i=Tr(t,[0,n]).map((t=>2*Dr*t));else if(1===t.length)return[o,o];return[[o[0]-i[0],o[1]-i[1]],[o[0]+i[0],o[1]+i[1]]]}(t,n[0])}function qr(t){const n=t[0],e=t[t.length-1];let r,o;if(n[1]o.box[0][1]&&(o={ts:i,box:c})}return{minY:r,maxY:o}}function Qr(t){const n=function(t){const n=t[0],e=t[t.length-1];let r,o;if(n[0]o.box[0][0]&&(o={ts:i,box:c})}return{minX:r,maxX:o}}(t),e=qr(t);return[[n.minX.box[0][0],e.minY.box[0][1]],[n.maxX.box[1][0],e.maxY.box[1][1]]]}function $r(t,n){const e=n[0]-t[0],r=n[1]-t[1];return Math.sqrt(e*e+r*r)}function Gr(t){const[n,e]=t[0],[r,o]=t[t.length-1];let i,s;const c=function(t){let n=0;for(let e=0;e-t)));return Qr(t.map((t=>S(-n,e,r(t)))))}(t,i,s),[[f,l],[h,a]]=u,d=[u[0],[h,l],u[1],[f,a]],g=S(i,s);return d.map((n=>I(t[0],g(n))))}function Hr(t,n,e){if(n===e)return;const r=t[n];t[n]=t[e],t[e]=r}function Rr(t,n=!1){if(!t.length)return;function e(t,e,r){const o=en(t,e,r);return n?o<0:o<=0}const r=t.slice(),o=r.length,i=function(t){let n,e=[Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY];for(let r=0;r{let e=-en(s,t,n);return 0!==e?e:(e=t[1]-n[1],0!==e?e:t[0]-n[0])})),r.unshift(s);let c=1;for(let t=2;t1)c-=1;else{if(t===o-1){c-=1;break}t+=1}c+=1,Hr(r,c,t)}return r.slice(0,c+1)}const Ur=Rr,Zr=pe,jr=oe,Wr=te,Jr=le,Kr=ce,to=ue,no=ie,eo=pe,ro=oe,oo=te,io=le,so=ce,co=ie,uo=ue,fo=de,lo=oe,ho=fe,ao=ie,po=T,go=sn,vo=j,mo=At,bo=zt,xo=on,_o=rt,Io=T,No=sn,So=j,Eo=At,wo=on,Mo=rt;function Po(t){const n=[];for(let e=0;e10*qo*t)),(()=>function(t,n){const e=t[0],r=t[1],o=t[2],i=t[3],s=e[0],c=e[1],u=r[0],f=r[1],l=o[0],h=o[1],a=i[0],p=i[1],[d,g]=n,v=po(s,d),m=po(u,d),b=po(l,d),x=po(a,d),_=po(c,g),I=po(f,g),N=po(h,g),S=po(p,g),E=go(v,v),w=vo(6,go(v,m)),M=vo(6,go(v,b)),P=mo(go(v,x)),T=vo(9,go(m,m)),y=vo(18,go(m,b)),C=vo(6,go(m,x)),O=vo(9,go(b,b)),A=vo(6,go(b,x)),z=go(x,x),B=go(_,_),Y=vo(6,go(_,I)),F=vo(6,go(_,N)),V=mo(go(_,S)),k=vo(9,go(I,I)),L=vo(18,go(I,N)),D=vo(6,go(I,S)),X=vo(9,go(N,N)),q=vo(6,go(N,S)),Q=go(S,S),$=xo(C,O),G=xo(P,y),H=xo(M,T),R=xo(D,X),U=xo(V,L),Z=xo(F,k),j=_o(xo(xo(z,E),xo($,H)),xo(xo(G,A),w)),W=_o(xo(xo(Q,B),xo(R,Z)),xo(xo(U,q),Y)),J=vo(6,xo(j,W)),K=xo(bo(xo(xo($,mo(H)),vo(3,E))),xo(xo(A,vo(3,G)),vo(5,w))),tt=xo(bo(xo(xo(R,mo(Z)),vo(3,B))),xo(xo(q,vo(3,U)),vo(5,Y))),nt=vo(5,xo(K,tt)),et=xo(xo($,vo(3,_o(mo(H),G))),vo(5,_o(vo(3,E),mo(w)))),rt=xo(xo(R,vo(3,_o(mo(Z),U))),vo(5,_o(vo(3,B),mo(Y)))),ot=vo(4,xo(et,rt)),it=_o(G,mo(_o(mo(H),vo(5,_o(w,mo(E)))))),st=_o(U,mo(_o(mo(Z),vo(5,_o(Y,mo(B)))))),ct=vo(3,xo(it,st)),ut=_o(H,vo(5,_o(w,vo(3,E)))),ft=_o(Z,vo(5,_o(Y,vo(3,B)))),lt=mo(xo(ut,ft)),ht=_o(w,vo(6,E)),at=_o(Y,vo(6,B));return[J,nt,ot,ct,lt,xo(ht,at)]}(t,n)));else if(2===e)r=Nr(function(t,n){const[[e,r],[o,i],[s,c]]=t,[u,f]=n,l=eo(e,u),h=eo(o,u),a=eo(s,u),p=eo(r,f),d=eo(i,f),g=eo(c,f),v=io(l,l),m=io(l,h),b=io(l,a),x=io(h,h),_=io(h,a),I=io(a,a),N=io(p,p),S=io(p,d),E=io(p,g),w=io(d,d),M=io(d,g),P=io(g,g),T=ro(E,so(w)),y=ro(b,so(x));return[ro(co(ro(ro(P,N),so(T)),uo(ro(M,S))),co(ro(ro(I,v),so(y)),uo(ro(_,m)))),oo(3,ro(ro(co(M,T),co(oo(3,S),N)),ro(co(_,y),co(oo(3,m),v)))),ro(co(T,oo(3,co(so(S),N))),co(y,oo(3,co(so(m),v)))),ro(co(S,N),co(m,v))]}(t,n),0,1,function(t,n){const e=t[0],r=t[1],o=t[2],i=zo(e[0]),s=zo(e[1]),c=zo(r[0]),u=zo(r[1]),f=zo(o[0]),l=zo(o[1]),h=zo(n[0]),a=zo(n[1]),p=i+h,d=c+h,g=f+h,v=s+a,m=u+a,b=l+a,x=p*p,_=p*d,I=d*g,N=v*v,S=v*m,E=m*b,w=v*b+m*m*2,M=p*g+d*d*2;return[b*b+N+2*w+4*(E+S)+(g*g+x+2*M+4*(I+_)),3*(E+w+(3*S+N)+(I+M+(3*_+x))),w+3*(2*S+N)+(M+3*(2*_+x)),S+N+(_+x)]}(t,n).map((t=>8*qo*t)),(()=>function(t,n){const[[e,r],[o,i],[s,c]]=t,[u,f]=n,l=Io(e,u),h=Io(o,u),a=Io(s,u),p=Io(r,f),d=Io(i,f),g=Io(c,f),v=No(l,l),m=No(l,h),b=No(l,a),x=No(h,h),_=No(h,a),I=No(a,a),N=No(p,p),S=No(p,d),E=No(p,g),w=No(d,d),M=No(d,g),P=No(g,g),T=wo(E,Eo(w)),y=wo(b,Eo(x)),C=wo(Mo(wo(I,Eo(y)),Po(wo(_,m))),v),O=wo(Mo(wo(P,Eo(T)),Po(wo(M,S))),N),A=wo(C,O),z=wo(Mo(_,y),Mo(So(3,m),v)),B=wo(Mo(M,T),Mo(So(3,S),N)),Y=So(3,wo(z,B)),F=Mo(T,So(3,Mo(Eo(S),N))),V=Mo(y,So(3,Mo(Eo(m),v))),k=wo(F,V),L=Mo(S,N),D=Mo(m,v);return[A,Y,k,wo(L,D)]}(t,n)));else{if(1!==e){if(0===e)return[];throw new Error("The given bezier curve must be of order <= 3")}r=Nr(function(t,n){const[[e,r],[o,i]]=t,[s,c]=n,u=e-s,f=o-s,l=r-c,h=i-c,a=fo(u,u),p=fo(u,f),d=fo(f,f),g=fo(l,l),v=fo(l,h),m=fo(h,h),b=lo(p,v),x=lo(g,a);return[lo(lo(d,m),lo(x,ho(b))),ao(b,x)]}(t,n),0,1,function(t,n){const e=t[0],r=t[1],o=zo(e[0]),i=zo(e[1]),s=zo(r[0]),c=zo(r[1]),u=zo(n[0]),f=zo(n[1]),l=o+u,h=s+u,a=i+f,p=c+f,d=l*h+a*p,g=a*a+l*l;return[h*h+p*p+2*d+g,d+g]}(t,n).map((t=>6*qo*t)),(()=>function(t,n){const[[e,r],[o,i]]=t,[s,c]=n,u=To(e,s),f=To(o,s),l=To(r,c),h=To(i,c),a=yo(u,u),p=yo(u,f),d=yo(f,f),g=yo(l,l),v=yo(l,h),m=yo(h,h),b=Oo(p,v),x=Oo(g,a);return[Oo(Oo(d,m),Oo(Co(b),x)),Ao(b,x)]}(t,n)))}r.push({tS:0,tE:0,multiplicity:1}),r.push({tS:1,tE:1,multiplicity:1});const o=r.map((e=>{const r=Xr(t,[e.tS,e.tE]),o=function(t,n){const e=t[0],r=t[1],o=e[0],i=e[1],s=r[0],c=r[1],u=n[0],f=n[1];let l=Number.POSITIVE_INFINITY,h=Number.NEGATIVE_INFINITY;for(const[t,n]of[[o,i],[o,c],[s,i],[s,c]]){const e=Vo(t,u),r=Vo(n,f),o=Lo(ko(e,e),ko(r,r)),i=Fo(o),s=i*(1-Do),c=i*(1+Do);s<=l&&(l=s),c>=h&&(h=c)}return[l,h]}(r,n);return{p:Yo(r),t:Bo(e),d:(Xo(o[0])+Xo(o[1]))/2,dSquaredI:o,box:r,ri:e}}));let i=Number.POSITIVE_INFINITY;for(let t=0;t{n.has(r)||r.orientation||(r.orientation=o*t.orientation,r.parent=i,r.windingNum=i.windingNum+r.orientation,e.push(r))}}(e,o,r);let s,c,u=0,f=1,l=n;for(;l=1===e.orientation?l.nextAround:l.prevAround,l!==n;)u=f,f-=l.dir,-1!==l.dir&&(c?1===u&&0===f?i(l,1,e.parent):0===u&&-1===f&&i(l,-1,e.parent):0===f?c=l:1===f&&i(l,1,e));return Uo(0,n.container)||(s=[n.p,c.p]),{out_:c,additionalBezier:s}}function jo(t,n){const e=n.next,r=e._x_.curve,o=e._x_.x.ri.tS;let i=n._x_.curve,s=n._x_.x.ri.tS;Uo(0,n.container)||(s=Bo(Qo(i.ps,n.p)[0].ri));const c=[];let u;for(;;){if(i===r&&(s0&&(c=i,u=r,f=s-i,l=f)}},xi=or,_i=rr,Ii=Ko;function Ni(t,n=Number.NEGATIVE_INFINITY,e=Number.POSITIVE_INFINITY){t=Ii(t);let r=0;for(;0===t[t.length-1];)t=t.slice(0,-1),r++;if(t.length<=1){const t=[];for(let n=0;n=0;r--){const t=o[r],s=[];let c=n,u=mi(t,c);0===u&&0===r&&s.push(n);for(let n=0;n0&&n<=0&&e>=0){const t=[];let n=!1;for(let e=0;e=0){for(let n=0;nf&&(f=s,i=r)}for(let n=0;nh&&(h=o,c=e)}return{ts:[[o,s],[i,c]],box:[[u,l],[f,h]]}})),yi=1e-6;function Ci(t){const n=t.map((t=>Ti(t)));return{minX:Math.min(...n.map((t=>t.box[0][0]))),maxX:Math.max(...n.map((t=>t.box[1][0]))),minY:Math.min(...n.map((t=>t.box[0][1]))),maxY:Math.max(...n.map((t=>t.box[1][1])))}}function Oi(t,n){let e;const r=[t];for(;r.length;)o(r.pop());return e;function o(o){if(o===t||function(t,n){let e=0,r=1231;do{e++;const i=li(1,0,1,r),s=i.p[0];r=i.seed;const c=li(1,0,t.length,r),u=Math.floor(c.p[0]);r=c.seed;const f=o(t,n,Mr(t[u],s));if(void 0!==f)return f}while(e<100);return;function o(t,n,e){if(function(t,n){const e=[t,n].map(Ci);return e[0].minXe[1].maxX||e[0].minYe[1].maxY}(t,n))return!1;const r=function(t,n,e){const[r,o]=n;let i=0;for(let e=0;eo||lr||!1,h)continue;const a=[];let p,d,g;const v=!0;p=t=>Si(t)[1],d=[0,-o],g=0;const m=s.map(I(d)),b=Ni(p(m),0-yi,1+yi);for(let t=0;t=r[g]||!v&&n[g]<=r[g])&&a.push(e)}if(1===a.length||3===a.length)for(const t of a){const n=N(Mi(s,t));if(Math.abs(n[1])s&&([o,s]=[s,o]),u>l&&([u,l]=[l,u]),r>i&&([r,i]=[i,r]),c>f&&([c,f]=[f,c]);const h=t||r===i&&c===f,a=t||o===s&&u===l;return(h?r<=f:r=c:i>c)&&(a?u<=s:u=o:l>o)}function Fi(t,n){return Yi(!0,t.box,n.box)}function Vi(t,n){for(let e=0;eo&&(o=u),f>i&&(i=f),s.push(...n.xs)}const c={box:[[t,r],[o,i]],xs:s,inOuts:void 0};n.push(c)}return n}function Qi(t){return{tS:[0,t.tS],tE:[0,t.tE],multiplicity:t.multiplicity}}const $i=K,Gi=R,Hi=j,Ri=function(t,n,e){const r=t.length-1;if(r<0)return[];const o=[];for(let t=0;tWi*Wi*t[1])),c=Ui(i,0,1,s,(()=>o)),u=[];for(const t of c)u.push({tS:ji(e,t.tS*r),tE:ji(e,t.tE*r),multiplicity:t.multiplicity});return u}const Ki=pe,ts=te,ns=oe,es=re,rs=Math.abs;function os(t){const[[n,e],[r,o],[i,s],[c,u]]=t,f=Ki(c,n),l=Ki(r,i),h=3*(r-i),a=ts(3,l),p=rs(h),d=ns(f,a),g=p+rs(c-n+h),v=Ki(i,2*r),m=es(v,n),b=rs(i-2*r+n),x=ts(3,m),_=6*b,I=Ki(r,n),N=ts(3,I),S=rs(3*(r-n)),E=Ki(u,e),w=Ki(o,s),M=3*(o-s),P=ts(3,w),T=rs(M),y=ns(E,P),C=T+rs(u-e+M),O=Ki(s,2*o),A=es(O,e),z=rs(s-2*o+e),B=ts(3,A),Y=6*z,F=Ki(o,e);return{coeffs:[[d,x,N,[0,n]],[y,B,ts(3,F),[0,e]]],errorBound:[[g,_,S,0],[C,Y,rs(3*(o-e)),0]]}}function is(t){const[[n,e],[r,o],[i,s]]=t,c=i-2*r,u=Ki(i,2*r),f=es(u,n),l=rs(c+n),h=Ki(2*r,2*n),a=s-2*o,p=Ki(s,2*o),d=es(p,e),g=rs(a+e);return{coeffs:[[f,h,[0,n]],[d,Ki(2*o,2*e),[0,e]]],errorBound:[[l,0,0],[g,0,0]]}}function ss(t){const[[n,e],[r,o]]=t;return[[Ki(r,n),[0,n]],[Ki(o,e),[0,e]]]}const cs=ie,us=te,fs=tt,ls=Math.abs;function hs(t){const[[n,[,e]],[r,[,o]]]=ss(t),i=fs(r),s=n,c=us(o,n),u=ls(c[1]),f=us(e,r),l=ls(f[1]),h=cs(f,c);return{coeffs:{vₓ:i,vᵧ:s,v:h},errorBound:{v_:u+l+ls(h[1])}}}const as=oe,ps=te,ds=le,gs=Math.abs,vs=Ar(3),ms=ae,bs=ce,xs=te,_s=le,Is=ie,Ns=Math.abs;function Ss(t){const{coeffs:[[n,e,[,r]],[o,i,[,s]]],errorBound:[[c],[u]]}=is(t),f=n[1],l=e[1],h=o[1],a=i[1],p=Ns(r),d=Ns(l),g=Ns(f),v=Ns(s),m=Ns(a),b=Ns(h),x=_s(n,i),_=c*m+2*Ns(f*a),I=_s(e,o),N=d*u+2*Ns(l*h),S=xs(s,n),E=v*c+Ns(s*f),w=xs(r,o),M=p*u+Ns(r*h),P=xs(s,e),T=Ns(s*l),y=xs(r,i),C=Ns(r*a),O=_s(n,n),A=2*(c*g+Ns(f*f)),z=_s(n,o),B=c*b+g*u+2*Ns(f*h),Y=_s(o,o),F=2*(u*b+Ns(h*h)),V=f*a-l*h,k=f*s-r*h,L=l*s-r*a,D=Is(x,I),X=Ns(V),q=_+N+Ns(V),Q=Is(S,w),$=Ns(k),G=E+M+Ns(k),H=Is(P,y),R=Ns(L),U=T+C+Ns(L),Z=ms(Y),j=F,W=bs(z),J=B,K=ms(O),tt=A,nt=a*V,et=_s(i,D),rt=m*q+2*Ns(nt),ot=2*k*h,it=bs(_s(o,Q)),st=2*(u*$+b*G+2*Ns(ot)),ct=nt-ot,ut=Is(et,it),ft=rt+st+Ns(ct),lt=2*f*k,ht=bs(_s(n,Q)),at=2*(c*$+g*G+2*Ns(lt)),pt=l*V,dt=_s(e,D),gt=d*q+2*Ns(pt),vt=lt-pt,mt=Is(ht,dt),bt=at+gt+Ns(vt),xt=V*L,_t=_s(D,H),It=q*R+X*U+2*Ns(xt),Nt=k*k,St=_s(Q,Q),Et=2*(G*$+Ns(Nt)),wt=xt-Nt;return{coeffs:{vₓₓ:Z,vₓᵧ:W,vᵧᵧ:K,vₓ:ut,vᵧ:mt,v:Is(_t,St)},errorBound:{vₓₓ_:j,vₓᵧ_:J,vᵧᵧ_:tt,vₓ_:ft,vᵧ_:bt,v_:It+Et+Ns(wt)}}}const Es=de,ws=ce,Ms=te,Ps=le,Ts=oe,ys=Math.abs,Cs=Ar(3),Os=Math.abs,As=ae,zs=ce,Bs=function(t){return[t[0]/2,t[1]/2]},Ys=te,Fs=le,Vs=ie,ks=oe;function Ls(t){const{coeffs:[[n,e,r,[,o]],[i,s,c,[,u]]],errorBound:[[f,l,h],[a,p,d]]}=os(t),g=r[1],v=e[1],m=n[1],b=c[1],x=s[1],_=i[1],I=Os(o),N=Os(g),S=Os(v),E=Os(m),w=Os(u),M=Os(b),P=Os(x),T=Os(_),y=Fs(n,c),C=m*b,O=f*M+E*d+2*Os(C),A=Fs(r,i),z=g*_,B=h*T+N*a+2*Os(z),Y=Fs(n,s),F=m*x,V=f*P+E*p+2*Os(F),k=Fs(e,s),L=v*x,D=l*P+S*p+2*Os(L),X=Fs(e,i),q=v*_,Q=l*T+S*a+2*Os(q),$=Fs(n,n),G=m*m,H=Os(G),R=f*E+E*f+2*Os(G),U=Fs(s,s),Z=x*x,j=p*P+P*p+2*Os(Z),W=Fs(i,i),J=_*_,K=Os(J),tt=a*T+T*a+2*Os(J),nt=Fs(r,n),et=g*m,rt=h*E+N*f+2*Os(et),ot=Fs(e,e),it=v*v,st=l*S+S*l+2*Os(it),ct=Fs(c,i),ut=b*_,ft=d*T+M*a+2*Os(ut),lt=Fs(s,i),ht=Os(x*_),at=p*T+P*a+2*ht,pt=Fs(e,n),dt=Os(v*m),gt=l*E+S*f+2*dt,vt=Fs(n,i),mt=Os(m*_),bt=f*T+E*a+2*mt,xt=Ys(u,n),_t=m*u,It=f*w+Os(_t),Nt=Ys(o,i),St=o*_,Et=I*a+Os(St),wt=Ys(u,e),Mt=v*u,Pt=l*w+Os(Mt),Tt=Ys(o,s),yt=o*x,Ct=I*p+Os(yt),Ot=Fs(e,c),At=v*b,zt=l*M+S*d+2*Os(At),Bt=Fs(r,s),Yt=g*x,Ft=h*P+N*p+2*Os(Yt),Vt=Ys(u,r),kt=g*u,Lt=h*w+Os(kt),Dt=Ys(o,c),Xt=o*b,qt=I*d+Os(Xt),Qt=Vs(xt,Nt),$t=It+Et+Os(_t-St),Gt=Vs(y,A),Ht=O+B+Os(C-z),Rt=Vs(Y,X),Ut=V+Q+Os(F-q),Zt=Vs(wt,Tt),jt=Pt+Ct+Os(Mt-yt),Wt=Vs(Ot,Bt),Jt=zt+Ft+Os(At-Yt),Kt=Vs(Vt,Dt),tn=Lt+qt+Os(kt-Xt),nn=Os(ut-Z),en=Vs(ct,U),rn=ft+j+nn,on=Os(et-it),sn=Vs(nt,ot),cn=rt+st+Os(et-it),un=Os(q+F),fn=ks(X,Y),ln=Q+V+Os(q+F),hn=z+C,an=Os(hn),pn=ks(A,y),dn=B+O+an,gn=zs(Gt),vn=2*Ht,mn=_t-St,bn=C-z,xn=F-q,_n=Mt-yt,In=At-Yt,Nn=kt-Xt,Sn=Os(mn),En=Os(bn),wn=Os(xn),Mn=Os(_n),Pn=Os(In),Tn=Os(Nn),yn=2*En,Cn=Fs(Qt,Qt),On=Fs(Qt,Gt),An=Fs(Qt,Rt),zn=Fs(Qt,Wt),Bn=Fs(Gt,Gt),Yn=Fs(gn,Zt),Fn=Fs(Rt,Zt),Vn=Fs(Rt,Wt),kn=Fs(Rt,Kt),Ln=$t*Sn+Sn*$t+2*Os(Cn[1]),Dn=$t*En+Sn*Ht+2*Os(On[1]),Xn=$t*wn+Sn*Ut+2*Os(An[1]),qn=$t*Pn+Sn*Jt+2*Os(zn[1]),Qn=Ht*En+En*Ht+2*Os(Bn[1]),$n=vn*Mn+yn*jt+2*Os(Yn[1]),Gn=Ut*Mn+wn*jt+2*Os(Fn[1]),Hn=Ut*Pn+wn*Jt+2*Os(Vn[1]),Rn=Ut*Tn+wn*tn+2*Os(Fn[1]),Un=Fs(As(i),W),Zn=a*K+T*tt+2*Os(Un[1]),jn=3*E,Wn=Ys(3,n),Jn=3*f+jn,Kn=Fs(Wn,W),te=Jn*K+jn*tt+2*Os(Kn[1]),ne=3*T,ee=Ys(-3,i),re=3*a+ne,oe=Fs(ee,$),ie=re*H+ne*R+2*Os(oe[1]),se=Fs(n,$),ce=f*H+E*R+2*Os(se[1]),ue=-3*mn,fe=3*Sn,le=Ys(-3,Qt),he=3*$t+fe,ae=Vs(le,Wt),pe=Os(ue-In),de=he+Jt+pe,ge=Fs(ae,W),ve=de*K+pe*tt+2*Os(ge[1]),me=Fs(Rt,en),be=Ut*nn+wn*rn+2*Os(me[1]),xe=ks(ge,me),_e=ve+be+Os(xe[1]),Ie=Fs(gn,lt),Ne=vn*ht+yn*at+2*Os(Ie[1]),Se=ks(xe,Ie),Ee=_e+Ne+Os(Se[1]),we=Fs(ae,$),Me=de*H+pe*R+2*Os(we[1]),Pe=Fs(Rt,sn),Te=Ut*on+wn*cn+2*Os(Pe[1]),ye=ks(we,Pe),Ce=Me+Te+Os(ye[1]),Oe=Fs(gn,pt),Ae=vn*dt+yn*gt+2*Os(Oe[1]),ze=ks(ye,Oe),Be=Ce+Ae+Os(ze[1]),Ye=Os(L-hn/2),Fe=Vs(k,Bs(pn)),Ve=D+dn/2+Os(Fe[1]),ke=Fs(ae,vt),Le=de*mt+pe*bt+2*Os(ke[1]),De=Fs(Gt,fn),Xe=Ht*un+En*ln+2*Os(De[1]),qe=ks(ke,De),Qe=Le+Xe+Os(qe[1]),$e=Fs(Rt,Fe),Ge=Ut*Ye+wn*Ve+2*Os($e[1]),He=zs(Vs($e,qe)),Re=2*(Ge+Qe)+Os(He[1]),Ue=Ys(-3,Cn),Ze=3*Ln+Os(Ue[1]),je=Vs(Ue,zs(zn)),We=Ze+2*qn+Os(je[1]),Je=ks(Yn,kn),Ke=$n+Rn+Os(Je[1]),tr=ks(je,Je),nr=Os(tr[1]),er=We+Ke+nr,rr=zs(Vs(On,Fn)),or=Os(rr[1]),ir=2*(Dn+Gn)+or,sr=Vs(An,Bn),cr=Xn+Qn+Os(sr[1]),ur=ks(sr,Vn),fr=Os(ur[1]),lr=cr+Hn+fr,hr=Fs(i,tr),ar=a*nr+T*er+2*Os(hr[1]),pr=Fs(s,rr),dr=p*or+P*ir+2*Os(pr[1]),gr=Fs(c,ur),vr=d*fr+M*lr+2*Os(gr[1]),mr=ks(pr,gr),br=dr+vr+Os(mr[1]),xr=ks(hr,mr),_r=ar+br+Os(xr[1]),Ir=Fs(n,tr),Nr=f*nr+E*er+2*Os(Ir[1]),Sr=Fs(e,rr),Er=l*or+S*ir+2*Os(Sr[1]),wr=Fs(r,ur),Mr=h*fr+N*lr+2*Os(wr[1]),Pr=ks(Sr,wr),Tr=Er+Mr+Os(Pr[1]),yr=As(ks(Ir,Pr)),Cr=Nr+Tr+Os(yr[1]),Or=Vs(Yn,Cn),Ar=Vs(Or,zn),zr=Os(Ar[1]),Br=Fs(ur,Kt),Yr=Fs(Fn,Zt),Fr=Vs(Br,Yr),Vr=lr*Os(Kt[1])+2*Os(Br[1])+Gn*Os(Zt[1])+2*Os(Yr[1])+Os(Fr[1]),kr=Fs(Qt,Ar),Lr=$t*zr+Sn*$n+Ln+Os(Or[1])+qn+zr+2*Os(kr[1]),Dr=ks(kr,Fr);return{coeffs:{vₓₓₓ:Un,vₓₓᵧ:Kn,vₓᵧᵧ:oe,vᵧᵧᵧ:se,vₓₓ:Se,vₓᵧ:He,vᵧᵧ:ze,vₓ:xr,vᵧ:yr,v:Dr},errorBound:{vₓₓₓ_:Zn,vₓₓᵧ_:te,vₓᵧᵧ_:ie,vᵧᵧᵧ_:ce,vₓₓ_:Ee,vₓᵧ_:Re,vᵧᵧ_:Be,vₓ_:_r,vᵧ_:Cr,v_:Lr+Vr+Os(Dr[1])}}}const Ds=de,Xs=ce,qs=te,Qs=le,$s=oe,Gs=Math.abs,Hs=Ar(3),Rs=oe,Us=te,Zs=le,js=Math.abs,Ws=Ar(3),Js=de,Ks=ce,tc=te,nc=le,ec=oe,rc=Math.abs,oc=Ar(3),ic=de,sc=ce,cc=te,uc=le,fc=oe,lc=Math.abs,hc=Ar(3),ac=oe,pc=te,dc=le,gc=Math.abs,vc=Ar(3),mc=de,bc=ce,xc=te,_c=le,Ic=oe,Nc=Math.abs,Sc=Ar(3),Ec=de,wc=ce,Mc=te,Pc=le,Tc=oe,yc=Math.abs,Cc=Ar(3),Oc=T,Ac=pt,zc=j,Bc=at,Yc=on;function Fc(t){if(4===t.length)return Vc(t);if(3===t.length)return kc(t);if(2===t.length)return Lc(t);if(1===t.length)return function(t){const[[n,e]]=t;return[[[n]],[[e]]]}(t);throw new Error("The given bezier curve must be of order <= cubic.")}function Vc(t){const[[n,e],[r,o],[i,s],[c,u]]=t;return[[Yc(Oc(c,n),zc(3,Oc(r,i))),zc(3,Bc(Ac(i,n),-2*r)),zc(3,Oc(r,n)),[n]],[Yc(Oc(u,e),zc(3,Oc(o,s))),zc(3,Bc(Ac(s,e),-2*o)),zc(3,Oc(o,e)),[e]]]}function kc(t){const[[n,e],[r,o],[i,s]]=t;return[[Bc(Ac(i,n),-2*r),Oc(2*r,2*n),[n]],[Bc(Ac(s,e),-2*o),Oc(2*o,2*e),[e]]]}function Lc(t){const[[n,e],[r,o]]=t;return[[Oc(r,n),[n]],[Oc(o,e),[e]]]}const Dc=j,Xc=rt,qc=tt,Qc=y;function $c(t){const[[n,[e]],[r,[o]]]=t;if(0!==Qc(n)||0!==Qc(r))return{vₓ:qc(r),vᵧ:n,v:Xc(Dc(e,r),Dc(o,n))}}const Gc=j,Hc=K,Rc=R;function Uc(t,n){const e=Lc(t),[[r,[o]],[i,[s]]]=Lc(n),{vₓ:c,vᵧ:u,v:f}=$c(e),l=Hc(r,c),h=Hc(i,u),a=Rc(l,h),p=Gc(o,c),d=Gc(s,u),g=Rc(p,d);return[a,Rc(g,f)]}const Zc=j,jc=At,Wc=rt,Jc=K,Kc=tt;function tu(t){const[[n,e,[r]],[o,i,[s]]]=t;if(0===y(n)&&0===y(o))return $c([[e,[r]],[i,[s]]]);const c=Jc(n,i),u=Jc(e,o),f=Zc(s,n),l=Zc(r,o),h=Zc(s,e),a=Zc(r,i),p=Jc(n,n),d=Jc(n,o),g=Jc(o,o),v=Wc(c,u),m=Wc(f,l),b=Wc(h,a),x=Kc(g),_=jc(d),I=Kc(p),N=Jc(i,v),S=jc(Jc(o,m)),E=Wc(N,S),w=jc(Jc(n,m)),M=Jc(e,v),P=Wc(w,M),T=Jc(v,b),C=Jc(m,m);return{vₓₓ:x,vₓᵧ:_,vᵧᵧ:I,vₓ:E,vᵧ:P,v:Wc(T,C)}}const nu=Ft,eu=j,ru=K,ou=R,iu=At,su=y;function cu(t,n){const e=kc(t);if(0===su(e[0][0])&&0===su(e[1][0]))return Uc([t[0],t[2]],n);const[[r,[o]],[i,[s]]]=Lc(n),{vₓₓ:c,vₓᵧ:u,vᵧᵧ:f,vₓ:l,vᵧ:h,v:a}=tu(e),p=nu(o,o),d=eu(o,r),g=nu(o,s),v=eu(o,i),m=ru(r,r),b=eu(s,r),x=ru(r,i),_=nu(s,s),I=eu(s,i),N=ru(i,i),S=ru(m,c),E=ru(N,f),w=ru(x,u),M=ou(S,E),P=ou(M,w),T=ru(d,c),y=ru(I,f),C=ou(v,b),O=ru(C,u),A=iu(ou(T,y)),z=ou(A,O),B=ru(r,l),Y=ru(i,h),F=ou(B,Y),V=ou(z,F),k=ru(p,c),L=ru(g,u),D=ru(_,f),X=ou(k,L),q=ou(X,D),Q=eu(o,l),$=eu(s,h),G=ou(Q,$),H=ou(q,G);return[P,V,ou(H,a)]}const uu=K,fu=T,lu=rt,hu=y,au=H,pu=Z,du=pt;function gu(t,n=!1){if(!n){const[[n,e],[r,o],[i,s],[c,u]]=t;return[[n,e],[au(lu(pu(du(r/4,i/4),3),du(n/4,c/4))),au(lu(pu(du(o/4,s/4),3),du(e/4,u/4)))],[c,u]]}const[e,r,o,i]=t,s=function(t,n){const[[e,r],[o,i]]=t,[[s,c],[u,f]]=n,l=fu(o,e),h=fu(i,r),a=fu(u,s),p=fu(f,c),d=lu(uu(a,h),uu(p,l));if(0===hu(d))return;const g=fu(s,e),v=fu(c,r),m=lu(uu(v,l),uu(g,h)),b=au(m)/au(d);return[s+b*au(a),c+b*au(p)]}([e,r],[i,o]);if(void 0!==s)return[e,s,i]}const vu=j,mu=K,bu=R,xu=rt,_u=tt,Iu=At,Nu=Bt,Su=y;function Eu(t){const[[n,e,r,[o]],[i,s,c,[u]]]=t;if(0===Su(n)&&0===Su(i))return tu([[e,r,[o]],[s,c,[u]]]);const f=mu(n,c),l=mu(r,i),h=mu(n,s),a=mu(e,s),p=mu(e,i),d=mu(n,n),g=mu(s,s),v=mu(i,i),m=mu(r,n),b=mu(e,e),x=mu(c,i),_=mu(s,i),I=mu(e,n),N=mu(n,i),S=vu(u,n),E=vu(o,i),w=vu(u,e),M=vu(o,s),P=mu(e,c),T=mu(r,s),y=vu(u,r),C=vu(o,c),O=xu(S,E),A=xu(f,l),z=xu(h,p),B=xu(w,M),Y=xu(P,T),F=xu(y,C),V=xu(x,g),k=xu(m,b),L=bu(p,h),D=bu(l,f),X=Iu(A),q=mu(O,O),Q=mu(O,A),$=mu(O,z),G=mu(O,Y),H=mu(A,A),R=mu(X,B),U=mu(z,B),Z=mu(z,Y),j=mu(z,F),W=mu(_u(i),v),J=mu(vu(3,n),v),K=mu(vu(-3,i),d),tt=mu(n,d),nt=xu(vu(-3,O),Y),et=mu(nt,v),rt=mu(z,V),ot=bu(et,rt),it=mu(X,_),st=bu(ot,it),ct=mu(nt,d),ut=mu(z,k),ft=bu(ct,ut),lt=mu(X,I),ht=bu(ft,lt),at=xu(a,Nu(D)),pt=mu(nt,N),dt=mu(A,L),gt=bu(pt,dt),vt=mu(z,at),mt=Iu(xu(vt,gt)),bt=vu(-3,q),xt=xu(bt,Iu(G)),_t=bu(R,j),It=bu(xt,_t),Nt=Iu(xu(Q,U)),St=xu($,H),Et=bu(St,Z),wt=mu(i,It),Mt=mu(s,Nt),Pt=mu(c,Et),Tt=bu(Mt,Pt),yt=bu(wt,Tt),Ct=mu(n,It),Ot=mu(e,Nt),At=mu(r,Et),zt=bu(Ot,At),Bt=_u(bu(Ct,zt)),Yt=xu(R,q),Ft=xu(Yt,G),Vt=mu(Et,F),kt=mu(U,B),Lt=xu(Vt,kt),Dt=mu(O,Ft);return{vₓₓₓ:W,vₓₓᵧ:J,vₓᵧᵧ:K,vᵧᵧᵧ:tt,vₓₓ:st,vₓᵧ:mt,vᵧᵧ:ht,vₓ:yt,vᵧ:Bt,v:bu(Dt,Lt)}}const wu=Ft,Mu=j,Pu=K,Tu=R,yu=At,Cu=y;function Ou(t,n){const e=Vc(t);if(0===Cu(e[0][0])&&0===Cu(e[1][0]))return cu(gu(t),n);const[[r,[o]],[i,[s]]]=Lc(n),{vₓₓₓ:c,vₓₓᵧ:u,vₓᵧᵧ:f,vᵧᵧᵧ:l,vₓₓ:h,vₓᵧ:a,vᵧᵧ:p,vₓ:d,vᵧ:g,v}=Eu(e),m=wu(o,o),b=Mu(o,r),x=wu(o,s),_=Mu(o,i),I=Pu(r,r),N=Mu(s,r),S=Pu(r,i),E=wu(s,s),w=Mu(s,i),M=Pu(i,i),P=Mu(o,c),T=Pu(wu(3,o),c),y=Mu(o,u),C=Mu(s,u),O=Mu(o,f),A=Mu(s,f),z=Mu(s,l),B=Pu(wu(3,s),l),Y=Pu(r,c),F=Pu(r,f),V=Pu(i,u),k=Pu(i,l),L=Tu(Y,V),D=Tu(F,k),X=Pu(I,L),q=Pu(M,D),Q=Tu(X,q),$=Tu(T,C),G=yu(Tu(y,A)),H=Tu(O,B),R=Tu($,h),U=Tu(G,a),Z=Tu(H,p),j=Pu(I,R),W=Pu(S,U),J=Pu(M,Z),K=Tu(j,W),tt=Tu(K,J),nt=yu(Tu(C,h)),et=yu(Tu(O,p)),rt=Tu(T,nt),ot=Tu(B,et),it=Tu(y,a),st=Tu(A,a),ct=Pu(b,rt),ut=Pu(w,ot),ft=Pu(_,it),lt=Pu(N,st),ht=Pu(r,d),at=Pu(i,g),pt=Tu(ct,ut),dt=Tu(ft,lt),gt=Tu(pt,dt),vt=Tu(ht,at),mt=Tu(gt,vt),bt=Tu(P,C),xt=Tu(z,O),_t=Tu(bt,h),It=Tu(xt,p),Nt=Pu(m,_t),St=Pu(E,It),Et=Pu(x,a),wt=Tu(Nt,St),Mt=Tu(wt,Et),Pt=Mu(o,d),Tt=Mu(s,g),yt=Tu(Pt,Tt),Ct=Tu(Mt,yt);return[Q,tt,mt,Tu(Ct,v)]}const Au=j,zu=K,Bu=R,Yu=y;function Fu(t,n){const e=Lc(t),[[r,o,[i]],[s,c,[u]]]=kc(n);if(0===Yu(r)&&0===Yu(s))return Uc(t,[n[0],n[2]]);const{vₓ:f,vᵧ:l,v:h}=$c(e),a=zu(r,f),p=zu(s,l),d=Bu(a,p),g=zu(o,f),v=zu(c,l),m=Bu(g,v),b=Au(i,f),x=Au(u,l),_=Bu(b,x);return[d,m,Bu(_,h)]}const Vu=Ft,ku=j,Lu=K,Du=R,Xu=At,qu=y;function Qu(t,n){const e=kc(t);if(0===qu(e[0][0])&&0===qu(e[1][0]))return Fu([t[0],t[2]],n);const[[r,o,[i]],[s,c,[u]]]=kc(n);if(0===qu(r)&&0===qu(s))return cu(t,[n[0],n[2]]);const{vₓₓ:f,vₓᵧ:l,vᵧᵧ:h,vₓ:a,vᵧ:p,v:d}=tu(e),g=Vu(i,i),v=ku(i,o),m=ku(i,r),b=Vu(i,u),x=ku(i,c),_=ku(i,s),I=Lu(o,o),N=Lu(o,r),S=ku(u,o),E=Lu(o,c),w=Lu(o,s),M=Lu(r,c),P=Lu(r,r),T=ku(u,r),y=Lu(r,s),C=Vu(u,u),O=ku(u,c),A=ku(u,s),z=Lu(c,c),B=Lu(c,s),Y=Lu(s,s),F=Lu(P,f),V=Lu(y,l),k=Lu(Y,h),L=Du(F,V),D=Du(L,k),X=Lu(N,f),q=Lu(B,h),Q=Du(w,M),$=Lu(Q,l),G=Xu(Du(X,q)),H=Du(G,$),R=Du(Xu(m),I),U=Du(Xu(A),z),Z=Du(_,E),j=Du(Z,T),W=Lu(R,f),J=Lu(U,h),K=Lu(j,l),tt=Lu(r,a),nt=Lu(s,p),et=Du(W,J),rt=Du(et,K),ot=Du(tt,nt),it=Du(rt,ot),st=Lu(v,f),ct=Lu(O,h),ut=Du(x,S),ft=Lu(ut,l),lt=Xu(Du(st,ct)),ht=Lu(o,a),at=Lu(c,p),pt=Du(lt,ft),dt=Du(ht,at),gt=Du(pt,dt),vt=Lu(g,f),mt=Lu(b,l),bt=Lu(C,h),xt=ku(i,a),_t=ku(u,p),It=Du(vt,mt),Nt=Du(It,bt),St=Du(xt,_t),Et=Du(Nt,St);return[D,H,it,gt,Du(Et,d)]}const $u=Ft,Gu=j,Hu=K,Ru=R,Uu=At,Zu=y;function ju(t,n){const e=Vc(t);if(0===Zu(e[0][0])&&0===Zu(e[1][0]))return Qu(gu(t),n);const[[r,o,[i]],[s,c,[u]]]=kc(n);if(0===Zu(r)&&0===Zu(s))return Ou(t,[n[0],n[2]]);const{vₓₓₓ:f,vₓₓᵧ:l,vₓᵧᵧ:h,vᵧᵧᵧ:a,vₓₓ:p,vₓᵧ:d,vᵧᵧ:g,vₓ:v,vᵧ:m,v:b}=Eu(e),x=$u(i,i),_=Gu(i,o),I=Gu(i,r),N=$u(i,u),S=Gu(i,c),E=Gu(i,s),w=Hu(o,o),M=Hu(o,r),P=Gu(u,o),T=Hu(o,c),y=Hu(o,s),C=Hu(r,c),O=Hu(r,r),A=Gu(u,r),z=Hu(r,s),B=$u(u,u),Y=Gu(u,c),F=Gu(u,s),V=Hu(c,c),k=Hu(c,s),L=Hu(s,s),D=Hu(r,f),X=Hu(r,h),q=Hu(s,l),Q=Hu(s,a),$=Ru(D,q),G=Ru(X,Q),H=Hu(O,$),R=Hu(L,G),U=Ru(H,R),Z=Ru(I,w),j=Ru(F,V),W=Ru(Uu(I),w),J=Ru(Uu(F),V),K=Ru(Uu(T),A),tt=Ru(Uu(T),E),nt=Ru(Uu(A),T),et=Ru(Gu(6,I),w),rt=Ru(Gu(6,F),V),ot=Ru(y,C),it=Ru(E,A),st=Ru(Uu(P),S),ct=Ru(Uu(S),P),ut=Ru(E,T),ft=Ru(ut,A),lt=Gu(3,O),ht=Gu(3,L),at=Hu(lt,f),pt=Hu(O,l),dt=Uu(Hu(z,l)),gt=Uu(Hu(z,h)),vt=Hu(L,h),mt=Hu(ht,a),bt=Ru(at,dt),xt=Ru(pt,gt),_t=Ru(bt,vt),It=Ru(xt,mt),Nt=Hu(o,_t),St=Hu(c,It),Et=Ru(Nt,St),wt=Hu(s,W),Mt=Hu(s,tt),Pt=Hu(r,K),Tt=Hu(r,J),yt=Hu(Gu(3,r),Z),Ct=Hu(Gu(3,s),j),Ot=Ru(wt,Pt),At=Ru(Mt,Tt),zt=Hu(yt,f),Bt=Hu(Ct,a),Yt=Hu(Ot,l),Ft=Hu(At,h),Vt=Ru(zt,Bt),kt=Ru(Yt,Ft),Lt=Hu(O,p),Dt=Hu(L,g),Xt=Hu(z,d),qt=Ru(Lt,Dt),Qt=Ru(Vt,kt),$t=Ru(qt,Xt),Gt=Ru(Qt,$t),Ht=Hu(o,et),Rt=Hu(c,rt),Ut=Gu(2*i,ot),Zt=Hu(Uu(c),it),jt=Hu(o,nt),Wt=Hu(o,J),Jt=Ru(Ut,jt),Kt=Ru(Zt,Wt),tn=Hu(k,g),nn=Hu(M,p),en=Hu(ot,d),rn=Ru(tn,nn),on=Hu(Ht,f),sn=Hu(Jt,l),cn=Hu(Rt,a),un=Hu(Kt,h),fn=Ru(on,cn),ln=Ru(sn,un),hn=Ru(fn,ln),an=Ru(Uu(rn),en),pn=Ru(hn,an),dn=Hu($u(3,i),Z),gn=Hu($u(3,u),j),vn=Gu(i,tt),mn=Gu(i,J),bn=Gu(u,W),xn=Gu(u,K),_n=Ru(vn,bn),In=Ru(mn,xn),Nn=Hu(dn,f),Sn=Hu(gn,a),En=Hu(_n,l),wn=Hu(In,h),Mn=Hu(W,p),Pn=Hu(J,g),Tn=Hu(ft,d),yn=Hu(r,v),Cn=Hu(s,m),On=Ru(Nn,Sn),An=Ru(En,wn),zn=Ru(Mn,Pn),Bn=Ru(On,An),Yn=Ru(zn,Tn),Fn=Ru(yn,Cn),Vn=Ru(Bn,Yn),kn=Ru(Vn,Fn),Ln=Hu($u(3,i),_),Dn=Hu($u(3,u),Y),Xn=Gu(i,st),qn=Gu(u,ct),Qn=Hu(_,p),$n=Hu(Y,g),Gn=Hu(S,d),Hn=Hu(P,d),Rn=Uu(Ru(Qn,$n)),Un=Ru(Gn,Hn),Zn=Hu(o,v),jn=Hu(c,m),Wn=Hu(Ln,f),Jn=Hu(Dn,a),Kn=Hu(Xn,l),te=Hu(qn,h),ne=Ru(Wn,Jn),ee=Ru(Kn,te),re=Ru(ne,ee),oe=Ru(Rn,Un),ie=Ru(Zn,jn),se=Ru(re,oe),ce=Ru(se,ie),ue=Gu(i,f),fe=Gu(i,h),le=Gu(u,l),he=Gu(u,a),ae=Ru(ue,le),pe=Ru(fe,he),de=Ru(ae,p),ge=Ru(pe,g),ve=Hu(x,de),me=Hu(B,ge),be=Hu(N,d),xe=Gu(i,v),_e=Gu(u,m),Ie=Ru(ve,me),Ne=Ru(Ie,be),Se=Ru(xe,_e),Ee=Ru(Ne,Se);return[U,Et,Gt,pn,kn,ce,Ru(Ee,b)]}const Wu=j,Ju=K,Ku=R,tf=y;function nf(t,n){const e=Lc(t),[[r,o,i,[s]],[c,u,f,[l]]]=Vc(n);if(0===tf(r)&&0===tf(c))return Fu(t,gu(n));const{vₓ:h,vᵧ:a,v:p}=$c(e),d=Ju(r,h),g=Ju(c,a),v=Ku(d,g),m=Ju(o,h),b=Ju(u,a),x=Ku(m,b),_=Ju(i,h),I=Ju(f,a),N=Ku(_,I),S=Wu(s,h),E=Wu(l,a),w=Ku(S,E);return[v,x,N,Ku(w,p)]}const ef=Ft,rf=j,of=K,sf=R,cf=At,uf=y;function ff(t,n){const e=kc(t);if(0===uf(e[0][0])&&0===uf(e[1][0]))return nf([t[0],t[2]],n);const[[r,o,i,[s]],[c,u,f,[l]]]=Vc(n);if(0===uf(r)&&0===uf(c))return Qu(t,gu(n));const{vₓₓ:h,vₓᵧ:a,vᵧᵧ:p,vₓ:d,vᵧ:g,v}=tu(e),m=ef(s,s),b=rf(s,i),x=rf(s,o),_=rf(s,r),I=ef(s,l),N=rf(s,f),S=rf(s,u),E=rf(s,c),w=of(i,i),M=of(i,o),P=of(i,r),T=rf(l,i),y=of(i,f),C=of(i,u),O=of(i,c),A=of(o,f),z=of(o,o),B=of(o,r),Y=rf(l,o),F=of(o,u),V=of(o,c),k=of(r,r),L=rf(l,r),D=of(r,f),X=of(r,u),q=of(r,c),Q=ef(l,l),$=rf(l,f),G=rf(l,u),H=rf(l,c),R=of(f,f),U=of(f,u),Z=of(c,c),j=of(u,u),W=of(u,c),J=of(f,c),K=of(k,h),tt=of(q,a),nt=of(Z,p),et=sf(K,tt),rt=sf(et,nt),ot=of(B,h),it=of(W,p),st=sf(ot,it),ct=sf(V,X),ut=of(ct,a),ft=sf(cf(st),ut),lt=sf(cf(P),z),ht=sf(cf(J),j),at=sf(O,F),pt=sf(at,D),dt=of(lt,h),gt=of(ht,p),vt=sf(dt,gt),mt=of(pt,a),bt=sf(vt,mt),xt=sf(_,M),_t=sf(H,U),It=sf(E,C),Nt=sf(A,L),St=sf(It,Nt),Et=of(xt,h),wt=of(_t,p),Mt=cf(sf(Et,wt)),Pt=of(St,a),Tt=of(r,d),yt=of(c,g),Ct=sf(Tt,yt),Ot=sf(Mt,Pt),At=sf(Ot,Ct),zt=sf(cf(x),w),Bt=sf(cf(G),R),Yt=sf(S,y),Ft=sf(Yt,Y),Vt=of(zt,h),kt=of(Bt,p),Lt=of(Ft,a),Dt=sf(Vt,kt),Xt=sf(Dt,Lt),qt=of(o,d),Qt=of(u,g),$t=sf(qt,Qt),Gt=sf(Xt,$t),Ht=of(b,h),Rt=of($,p),Ut=sf(N,T),Zt=of(Ut,a),jt=cf(sf(Ht,Rt)),Wt=sf(jt,Zt),Jt=of(i,d),Kt=of(f,g),tn=sf(Jt,Kt),nn=sf(Wt,tn),en=of(m,h),rn=of(I,a),on=of(Q,p),sn=rf(s,d),cn=rf(l,g),un=sf(en,rn),fn=sf(un,on),ln=sf(sn,cn),hn=sf(fn,ln);return[rt,ft,bt,At,Gt,nn,sf(hn,v)]}const lf=Ft,hf=j,af=K,pf=R,df=At,gf=y,vf=[[function(t,n){const{coeffs:{vₓ:e,vᵧ:r,v:o},errorBound:{v_:i}}=hs(t),[[s,[,c]],[u,[,f]]]=ss(n),l=s[1],h=u[1],a=e[1],p=r[1],d=o[1],g=l*a,v=2*gs(g),m=ds(s,e),b=h*p,x=2*gs(b),_=ds(u,r),I=g+b,N=as(m,_),S=v+x+gs(I),E=c*a,w=ps(c,e),M=gs(E),P=f*p,T=ps(f,r),y=gs(P),C=E+P,O=as(w,T),A=M+y+gs(C),z=as(O,o),B=A+i+gs(C+d);return{coeffs:[N,z],errBound:[vs*S,vs*B]}},function(t,n){const{coeffs:{vₓ:e,vᵧ:r,v:o},errorBound:{v_:i}}=hs(t),{coeffs:[[s,c,[,u]],[f,l,[,h]]],errorBound:[[a],[p]]}=is(n),d=e[1],g=r[1],v=o[1],m=js(d),b=js(g),x=(js(v),c[1]),_=s[1],I=l[1],N=f[1],S=_*d,E=Zs(s,e),w=a*m+2*js(S),M=N*g,P=Zs(f,r),T=p*b+2*js(M),y=S+M,C=Rs(E,P),O=w+T+js(y),A=x*d,z=Zs(c,e),B=2*js(A),Y=I*g,F=Zs(l,r),V=2*js(Y),k=A+Y,L=Rs(z,F),D=B+V+js(k),X=Us(u,e),q=u*d,Q=js(q),$=Us(h,r),G=h*g,H=js(G),R=q+G,U=Rs(X,$),Z=Q+H+js(R),j=R+v,W=Rs(U,o),J=Z+i+js(j);return{coeffs:[C,L,W],errBound:[Ws*O,Ws*D,Ws*J]}},function(t,n){const{coeffs:{vₓ:e,vᵧ:r,v:o},errorBound:{v_:i}}=hs(t),{coeffs:[[s,c,u,[,f]],[l,h,a,[,p]]],errorBound:[[d,g,v],[m,b,x]]}=os(n),_=gc(e[1]),I=gc(r[1]),N=dc(s,e),S=d*_+2*gc(N[1]),E=dc(l,r),w=m*I+2*gc(E[1]),M=ac(N,E),P=S+w+gc(M[1]),T=dc(c,e),y=g*_+2*gc(T[1]),C=dc(h,r),O=b*I+2*gc(C[1]),A=ac(T,C),z=y+O+gc(A[1]),B=dc(u,e),Y=v*_+2*gc(B[1]),F=dc(a,r),V=x*I+2*gc(F[1]),k=ac(B,F),L=Y+V+gc(k[1]),D=pc(f,e),X=gc(D[1]),q=pc(p,r),Q=gc(q[1]),$=ac(D,q),G=X+Q+gc($[1]),H=ac($,o),R=G+i+gc(H[1]);return{coeffs:[M,A,k,H],errBound:[vc*P,vc*z,vc*L,vc*R]}}],[function(t,n){const{coeffs:{vₓₓ:e,vₓᵧ:r,vᵧᵧ:o,vₓ:i,vᵧ:s,v:c},errorBound:{vₓₓ_:u,vₓᵧ_:f,vᵧᵧ_:l,vₓ_:h,vᵧ_:a,v_:p}}=Ss(t),[[d,[,g]],[v,[,m]]]=ss(n),b=e[1],x=r[1],_=o[1],I=i[1],N=s[1],S=c[1],E=ys(b),w=ys(x),M=ys(_),P=d[1],T=v[1],y=ys(g),C=ys(P),O=ys(m),A=ys(T),z=g*g,B=g*P,Y=g*m,F=g*T,V=P*P,k=P*m,L=P*T,D=m*m,X=m*T,q=T*T,Q=Es(g,g),$=Ms(g,d),G=ys(B),H=Es(g,m),R=Ms(g,v),U=ys(F),Z=ys(V),j=Ps(d,d),W=2*Z,J=Ms(m,d),K=ys(k),tt=ys(L),nt=Ps(d,v),et=2*tt,rt=Es(m,m),ot=Ms(m,v),it=ys(X),st=ys(q),ct=Ps(v,v),ut=2*st,ft=V*b,lt=Ps(j,e),ht=W*E*Z*u+2*ys(ft),at=q*_,pt=Ps(ct,o),dt=ut*M*st*l+2*ys(at),gt=L*x,vt=Ps(nt,r),mt=et*w*tt*f+2*ys(gt),bt=ft+at,xt=Ts(lt,pt),_t=ht+dt+ys(bt),It=bt+gt,Nt=Ts(xt,vt),St=_t+mt+ys(It),Et=B*b,wt=Ps($,e),Mt=G*(E+u)+2*ys(Et),Pt=X*_,Tt=Ps(ot,o),yt=it*(M+l)+2*ys(Pt),Ct=F+k,Ot=Ts(R,J),At=U+K+ys(Ct),zt=Ct*x,Bt=Ps(Ot,r),Yt=At*w+ys(Ct)*f+2*ys(zt),Ft=2*(Et+Pt),Vt=ws(Ts(wt,Tt)),kt=2*(Mt+yt)+ys(Ft),Lt=Ft+zt,Dt=Ts(Vt,Bt),Xt=kt+Yt+ys(Lt),qt=P*I,Qt=Ps(d,i),$t=C*h+2*ys(qt),Gt=T*N,Ht=Ps(v,s),Rt=A*a+2*ys(Gt),Ut=qt+Gt,Zt=Ts(Qt,Ht),jt=$t+Rt+ys(Ut),Wt=Lt+Ut,Jt=Ts(Dt,Zt),Kt=Xt+jt+ys(Wt),tn=z*b,nn=Ps(Q,e),en=2*ys(tn),rn=Y*x,on=Ps(H,r),sn=2*ys(rn),cn=D*_,un=Ps(rt,o),fn=2*ys(cn),ln=tn+rn,hn=Ts(nn,on),an=en+sn+ys(ln),pn=ln+cn,dn=Ts(hn,un),gn=an+fn+ys(pn),vn=g*I,mn=Ms(g,i),bn=y*h+ys(vn),xn=m*N,_n=Ms(m,s),In=O*a+ys(xn),Nn=vn+xn,Sn=Ts(mn,_n),En=bn+In+ys(Nn),wn=pn+Nn,Mn=Ts(dn,Sn),Pn=gn+En+ys(wn),Tn=wn+S,yn=Ts(Mn,c),Cn=Pn+p+ys(Tn);return{coeffs:[Nt,Jt,yn],errBound:[Cs*St,Cs*Kt,Cs*Cn]}},function(t,n){const{coeffs:{vₓₓ:e,vₓᵧ:r,vᵧᵧ:o,vₓ:i,vᵧ:s,v:c},errorBound:{vₓₓ_:u,vₓᵧ_:f,vᵧᵧ_:l,vₓ_:h,vᵧ_:a,v_:p}}=Ss(t),{coeffs:[[d,g,[,v]],[m,b,[,x]]],errorBound:[[_],[I]]}=is(n),N=e[1],S=r[1],E=o[1],w=i[1],M=s[1],P=c[1],T=rc(N),y=rc(S),C=rc(E),O=rc(w),A=rc(M),z=g[1],B=d[1],Y=b[1],F=m[1],V=rc(v),k=rc(z),L=rc(B),D=rc(x),X=rc(Y),q=rc(F),Q=v*v,$=v*z,G=v*B,H=v*x,R=v*Y,U=v*F,Z=z*z,j=z*B,W=z*x,J=z*Y,K=z*F,tt=B*Y,nt=B*B,et=B*x,rt=B*F,ot=x*x,it=x*Y,st=x*F,ct=Y*Y,ut=Y*F,ft=F*F,lt=rc(Q),ht=rc(H),at=rc(ot),pt=Js(v,v),dt=tc(v,g),gt=rc($),vt=tc(v,d),mt=rc(G),bt=Js(v,x),xt=tc(v,b),_t=rc(R),It=tc(v,m),Nt=rc(U),St=nc(g,g),Et=2*rc(Z),wt=nc(g,d),Mt=rc(j),Pt=k*_+2*Mt,Tt=tc(x,g),yt=rc(W),Ct=nc(g,b),Ot=2*rc(J),At=nc(g,m),zt=k*I+2*rc(K),Bt=nc(d,b),Yt=_*X+2*rc(tt),Ft=nc(d,d),Vt=rc(nt),kt=2*(_*L+Vt),Lt=tc(x,d),Dt=rc(et),Xt=nc(d,m),qt=rc(rt),Qt=_*q+L*I+2*qt,$t=Js(x,x),Gt=tc(x,b),Ht=rc(it),Rt=tc(x,m),Ut=rc(st),Zt=nc(b,b),jt=2*rc(ct),Wt=nc(b,m),Jt=rc(ut),Kt=X*I+2*Jt,tn=nc(m,m),nn=rc(ft),en=2*(I*q+nn),rn=nt*N,on=nc(Ft,e),sn=kt*T+Vt*u+2*rc(rn),cn=rt*S,un=nc(Xt,r),fn=Qt*y+qt*f+2*rc(cn),ln=ft*E,hn=nc(tn,o),an=en*C+nn*l+2*rc(ln),pn=rn+cn,dn=ec(on,un),gn=sn+fn+rc(pn),vn=pn+ln,mn=ec(dn,hn),bn=gn+an+rc(vn),xn=j*N,_n=nc(wt,e),In=Pt*T+Mt*u+2*rc(xn),Nn=ut*E,Sn=nc(Wt,o),En=Kt*C+Jt*l+2*rc(Nn),wn=K+tt,Mn=ec(At,Bt),Pn=rc(wn),Tn=zt+Yt+Pn,yn=wn*S,Cn=nc(Mn,r),On=Tn*y+Pn*f+2*rc(yn),An=2*(xn+Nn),zn=Ks(ec(_n,Sn)),Bn=2*(In+En)+rc(An),Yn=An+yn,Fn=ec(zn,Cn),Vn=Bn+On+rc(Yn),kn=2*G+Z,Ln=rc(kn),Dn=ec(Ks(vt),St),Xn=2*mt+Et+rc(kn),qn=2*st+ct,Qn=rc(qn),$n=ec(Ks(Rt),Zt),Gn=2*Ut+jt+rc(qn),Hn=U+J,Rn=(rc(Hn),ec(It,Ct)),Un=Nt+Ot+rc(Hn),Zn=Hn+et,jn=ec(Rn,Lt),Wn=rc(Zn),Jn=Un+Dt+Wn,Kn=kn*N,te=nc(Dn,e),ne=Xn*T+Ln*u+2*rc(Kn),ee=qn*E,re=nc($n,o),oe=Gn*C+Qn*l+2*rc(ee),ie=Zn*S,se=nc(jn,r),ce=Jn*y+Wn*f+2*rc(ie),ue=B*w,fe=nc(d,i),le=_*O+L*h+rc(ue),he=F*M,ae=nc(m,s),pe=I*A+q*a+rc(he),de=Kn+ee,ge=ec(te,re),ve=ne+oe+rc(de),me=de+ie,be=ec(ge,se),xe=ve+ce+rc(me),_e=ue+he,Ie=ec(fe,ae),Ne=le+pe+rc(_e),Se=me+_e,Ee=ec(be,Ie),we=xe+Ne+rc(Se),Me=$*N,Pe=nc(dt,e),Te=gt*(T+u)+2*rc(Me),ye=it*E,Ce=nc(Gt,o),Oe=Ht*(C+l)+2*rc(ye),Ae=R+W,ze=ec(xt,Tt),Be=rc(Ae),Ye=_t+yt+Be,Fe=Ae*S,Ve=nc(ze,r),ke=Ye*y+Be*f+2*rc(Fe),Le=2*(Me+ye),De=Ks(ec(Pe,Ce)),Xe=2*(Te+Oe)+rc(Le),qe=z*w,Qe=nc(g,i),$e=k*h+2*rc(qe),Ge=Y*M,He=nc(b,s),Re=X*a+2*rc(Ge),Ue=Le+Fe,Ze=ec(De,Ve),je=Xe+ke+rc(Ue),We=qe+Ge,Je=ec(Qe,He),Ke=$e+Re+rc(We),tr=Ue+We,nr=ec(Ze,Je),er=je+Ke+rc(tr),rr=Q*N,or=nc(pt,e),ir=lt*u+2*rc(rr),sr=H*S,cr=nc(bt,r),ur=ht*f+2*rc(sr),fr=ot*E,lr=nc($t,o),hr=at*l+2*rc(fr),ar=v*w,pr=tc(v,i),dr=V*h+rc(ar),gr=x*M,vr=tc(x,s),mr=D*a+rc(gr),br=rr+sr,xr=ec(or,cr),_r=ir+ur+rc(br),Ir=br+fr,Nr=ec(xr,lr),Sr=_r+hr+rc(Ir),Er=ar+gr,wr=ec(pr,vr),Mr=dr+mr+rc(Er),Pr=Ir+Er,Tr=ec(Nr,wr),yr=Sr+Mr+rc(Pr),Cr=Pr+P,Or=ec(Tr,c),Ar=yr+p+rc(Cr);return{coeffs:[mn,Fn,Ee,nr,Or],errBound:[oc*bn,oc*Vn,oc*we,oc*er,oc*Ar]}},function(t,n){const{coeffs:{vₓₓ:e,vₓᵧ:r,vᵧᵧ:o,vₓ:i,vᵧ:s,v:c},errorBound:{vₓₓ_:u,vₓᵧ_:f,vᵧᵧ_:l,vₓ_:h,vᵧ_:a,v_:p}}=Ss(t),{coeffs:[[d,g,v,[,m]],[b,x,_,[,I]]],errorBound:[[N,S,E],[w,M,P]]}=os(n),T=e[1],y=r[1],C=o[1],O=i[1],A=s[1],z=c[1],B=Nc(T),Y=Nc(y),F=Nc(C),V=Nc(O),k=Nc(A),L=v[1],D=g[1],X=d[1],q=_[1],Q=x[1],$=b[1],G=Nc(m),H=Nc(L),R=Nc(D),U=Nc(X),Z=Nc(I),j=Nc(q),W=Nc(Q),J=Nc($),K=m*m,tt=m*L,nt=m*D,et=m*X,rt=m*I,ot=m*q,it=m*Q,st=m*$,ct=L*L,ut=L*D,ft=L*X,lt=L*I,ht=L*q,at=L*Q,pt=L*$,dt=D*q,gt=D*D,vt=D*X,mt=D*I,bt=D*Q,xt=D*$,_t=X*X,It=X*I,Nt=X*q,St=X*Q,Et=X*$,wt=I*I,Mt=I*q,Pt=I*Q,Tt=I*$,yt=q*q,Ct=q*Q,Ot=$*$,At=Q*Q,zt=Q*$,Bt=q*$,Yt=mc(m,m),Ft=Nc(K),Vt=xc(m,v),kt=Nc(tt),Lt=G*E+kt,Dt=xc(m,g),Xt=G*S+Nc(nt),qt=xc(m,d),Qt=G*N+Nc(et),$t=mc(m,I),Gt=Nc(rt),Ht=xc(m,_),Rt=G*P+Nc(ot),Ut=xc(m,x),Zt=G*M+Nc(it),jt=xc(m,b),Wt=G*w+Nc(st),Jt=_c(v,v),Kt=E*H+H*E+2*Nc(ct),tn=_c(v,g),nn=E*R+H*S+2*Nc(ut),en=_c(v,d),rn=E*U+H*N+2*Nc(ft),on=xc(I,v),sn=Z*E+Nc(lt),cn=_c(v,_),un=E*j+H*P+2*Nc(ht),fn=_c(v,x),ln=E*W+H*M+2*Nc(at),hn=_c(v,b),an=E*J+H*w+2*Nc(pt),pn=_c(g,_),dn=S*j+R*P+2*Nc(dt),gn=_c(g,g),vn=S*R+R*S+2*Nc(gt),mn=_c(g,d),bn=Nc(vt),xn=S*U+R*N+2*bn,_n=xc(I,g),In=Z*S+Nc(mt),Nn=_c(g,x),Sn=S*W+R*M+2*Nc(bt),En=_c(g,b),wn=S*J+R*w+2*Nc(xt),Mn=_c(d,d),Pn=Nc(_t),Tn=N*U+U*N+2*Pn,yn=xc(I,d),Cn=Z*N+Nc(It),On=_c(d,_),An=N*j+U*P+2*Nc(Nt),zn=_c(d,x),Bn=N*W+U*M+2*Nc(St),Yn=_c(d,b),Fn=Nc(Et),Vn=N*J+U*w+2*Fn,kn=mc(I,I),Ln=Nc(wt),Dn=xc(I,_),Xn=Nc(Mt),qn=Z*P+Xn,Qn=xc(I,x),$n=Z*M+Nc(Pt),Gn=xc(I,b),Hn=Z*w+Nc(Tt),Rn=_c(_,_),Un=P*j+j*P+2*Nc(yt),Zn=_c(_,x),jn=P*W+j*M+2*Nc(Ct),Wn=_c(b,b),Jn=Nc(Ot),Kn=w*J+J*w+2*Jn,te=_c(x,x),ne=M*W+W*M+2*Nc(At),ee=_c(x,b),re=Nc(zt),oe=M*J+W*w+2*re,ie=_c(_,b),se=P*J+j*w+2*Nc(Bt),ce=_t*T,ue=_c(Mn,e),fe=Tn*B+Pn*u+2*Nc(ce),le=Et*y,he=_c(Yn,r),ae=Vn*Y+Fn*f+2*Nc(le),pe=Ot*C,de=_c(Wn,o),ge=Kn*F+Jn*l+2*Nc(pe),ve=ce+le,me=Ic(ue,he),be=fe+ae+Nc(ve),xe=ve+pe,_e=Ic(me,de),Ie=be+ge+Nc(xe),Ne=vt*T,Se=_c(mn,e),Ee=xn*B+bn*u+2*Nc(Ne),we=zt*C,Me=_c(ee,o),Pe=oe*F+re*l+2*Nc(we),Te=Ne+we,ye=Ic(Se,Me),Ce=Ee+Pe+Nc(Te),Oe=xt+St,Ae=Ic(En,zn),ze=Nc(Oe),Be=wn+Bn+ze,Ye=Oe*y,Fe=_c(Ae,r),Ve=Be*Y+ze*f+2*Nc(Ye),ke=2*Te+Ye,Le=Ic(bc(ye),Fe),De=2*Ce+Ve+Nc(ke),Xe=2*ft+gt,qe=Ic(bc(en),gn),Qe=Nc(Xe),$e=2*rn+vn+Nc(Xe),Ge=2*Bt+At,He=Ic(bc(ie),te),Re=Nc(Ge),Ue=2*se+ne+Nc(Ge),Ze=pt+bt,je=Ic(hn,Nn),We=an+Sn+Nc(Ze),Je=Ze+Nt,Ke=Ic(je,On),tr=Nc(Je),nr=We+An+tr,er=Xe*T,rr=_c(qe,e),or=$e*B+Qe*u+2*Nc(er),ir=Ge*C,sr=_c(He,o),cr=Ue*F+Re*l+2*Nc(ir),ur=er+ir,fr=Ic(rr,sr),lr=or+cr+Nc(ur),hr=Je*y,ar=_c(Ke,r),pr=nr*Y+tr*f+2*Nc(hr),dr=ur+hr,gr=Ic(fr,ar),vr=lr+pr+Nc(dr),mr=et+ut,br=Ic(qt,tn),xr=Nc(mr),_r=Qt+nn+xr,Ir=Tt+Ct,Nr=Ic(Gn,Zn),Sr=Nc(Ir),Er=Hn+jn+Sr,wr=st+at,Mr=Ic(jt,fn),Pr=Wt+ln+Nc(wr),Tr=dt+It,yr=Ic(pn,yn),Cr=dn+Cn+Nc(Tr),Or=wr+Tr,Ar=Ic(Mr,yr),zr=Nc(Or),Br=Pr+Cr+zr,Yr=mr*T,Fr=_c(br,e),Vr=_r*B+xr*u+2*Nc(Yr),kr=Ir*C,Lr=_c(Nr,o),Dr=Er*F+Sr*l+2*Nc(kr),Xr=2*(Yr+kr),qr=bc(Ic(Fr,Lr)),Qr=2*(Vr+Dr)+Nc(Xr),$r=Or*y,Gr=_c(Ar,r),Hr=Br*Y+zr*f+2*Nc($r),Rr=X*O,Ur=_c(d,i),Zr=N*V+U*h+2*Nc(Rr),jr=$*A,Wr=_c(b,s),Jr=w*k+J*a+2*Nc(jr),Kr=Rr+jr,to=Ic(Ur,Wr),no=Zr+Jr+Nc(Kr),eo=Xr+$r,ro=Ic(qr,Gr),oo=Qr+Hr+Nc(eo),io=eo+Kr,so=Ic(ro,to),co=oo+no+Nc(io),uo=2*nt+ct,fo=Ic(bc(Dt),Jt),lo=Nc(uo),ho=2*Xt+Kt+lo,ao=2*Pt+yt,po=Ic(bc(Qn),Rn),go=Nc(ao),vo=2*$n+Un+go,mo=it+ht,bo=Ic(Ut,cn),xo=Zt+un+Nc(mo),_o=mo+mt,Io=Ic(bo,_n),No=Nc(_o),So=xo+In+No,Eo=uo*T,wo=_c(fo,e),Mo=ho*B+lo*u+2*Nc(Eo),Po=ao*C,To=_c(po,o),yo=vo*F+go*l+2*Nc(Po),Co=_o*y,Oo=_c(Io,r),Ao=So*Y+No*f+2*Nc(Co),zo=Eo+Po,Bo=Ic(wo,To),Yo=Mo+yo+Nc(zo),Fo=zo+Co,Vo=Ic(Bo,Oo),ko=Yo+Ao+Nc(Fo),Lo=D*O,Do=_c(g,i),Xo=S*V+R*h+2*Nc(Lo),qo=Q*A,Qo=_c(x,s),$o=M*k+W*a+2*Nc(qo),Go=Lo+qo,Ho=Ic(Do,Qo),Ro=Xo+$o+Nc(Go),Uo=Fo+Go,Zo=Ic(Vo,Ho),jo=ko+Ro+Nc(Uo),Wo=tt*T,Jo=_c(Vt,e),Ko=Lt*B+kt*u+2*Nc(Wo),ti=Mt*C,ni=_c(Dn,o),ei=qn*F+Xn*l+2*Nc(ti),ri=ot+lt,oi=Ic(Ht,on),ii=Nc(ri),si=Rt+sn+ii,ci=ri*y,ui=_c(oi,r),fi=si*Y+ii*f+2*Nc(ci),li=2*(Wo+ti),hi=bc(Ic(Jo,ni)),ai=2*(Ko+ei)+Nc(li),pi=li+ci,di=Ic(hi,ui),gi=ai+fi+Nc(pi),vi=L*O,mi=_c(v,i),bi=E*V+H*h+2*Nc(vi),xi=q*A,_i=_c(_,s),Ii=P*k+j*a+2*Nc(xi),Ni=vi+xi,Si=Ic(mi,_i),Ei=bi+Ii+Nc(Ni),wi=pi+Ni,Mi=Ic(di,Si),Pi=gi+Ei+Nc(wi),Ti=K*T,yi=_c(Yt,e),Ci=Ft*u+2*Nc(Ti),Oi=rt*y,Ai=_c($t,r),zi=Gt*f+2*Nc(Oi),Bi=wt*C,Yi=_c(kn,o),Fi=Ln*l+2*Nc(Bi),Vi=m*O,ki=xc(m,i),Li=G*h+Nc(Vi),Di=I*A,Xi=xc(I,s),qi=Z*a+Nc(Di),Qi=Ti+Oi,$i=Ic(yi,Ai),Gi=Ci+zi+Nc(Qi),Hi=Qi+Bi,Ri=Ic($i,Yi),Ui=Gi+Fi+Nc(Hi),Zi=Vi+Di,ji=Ic(ki,Xi),Wi=Li+qi+Nc(Zi),Ji=Hi+Zi,Ki=Ic(Ri,ji),ts=Ui+Wi+Nc(Ji),ns=Ji+z,es=Ic(Ki,c),rs=ts+p+Nc(ns);return{coeffs:[_e,Le,gr,so,Zo,Mi,es],errBound:[Sc*Ie,Sc*De,Sc*vr,Sc*co,Sc*jo,Sc*Pi,Sc*rs]}}],[function(t,n){const{coeffs:{vₓₓₓ:e,vₓₓᵧ:r,vₓᵧᵧ:o,vᵧᵧᵧ:i,vₓₓ:s,vₓᵧ:c,vᵧᵧ:u,vₓ:f,vᵧ:l,v:h},errorBound:{vₓₓₓ_:a,vₓₓᵧ_:p,vₓᵧᵧ_:d,vᵧᵧᵧ_:g,vₓₓ_:v,vₓᵧ_:m,vᵧᵧ_:b,vₓ_:x,vᵧ_:_,v_:I}}=Ls(t),[[N,[,S]],[E,[,w]]]=ss(n),M=e[1],P=r[1],T=o[1],y=i[1],C=s[1],O=c[1],A=u[1],z=f[1],B=l[1],Y=h[1],F=N[1],V=E[1],k=Gs(S),L=Gs(F),D=Gs(w),X=Gs(V),q=S*S,Q=S*F,$=S*w,G=S*V,H=F*F,R=F*w,U=F*V,Z=w*w,j=w*V,W=V*V,J=Ds(S,S),K=qs(S,N),tt=Gs(Q),nt=Ds(S,w),et=qs(S,E),rt=Gs(G),ot=Qs(N,N),it=2*Gs(H),st=qs(w,N),ct=Gs(R),ut=Qs(N,E),ft=2*Gs(U),lt=Ds(w,w),ht=qs(w,E),at=Gs(j),pt=Qs(E,E),dt=2*Gs(W),gt=Gs(q),vt=Gs(Q),mt=Gs($),bt=Gs(G),xt=Gs(H),_t=Gs(R),It=Gs(U),Nt=Gs(Z),St=Gs(j),Et=Gs(W),wt=S*M,Mt=qs(S,e),Pt=k*a+Gs(wt),Tt=3*S,yt=Ds(3,S),Ct=Gs(Tt),Ot=Tt*M,At=Qs(yt,e),zt=Ct*a+2*Gs(Ot),Bt=S*P,Yt=qs(S,r),Ft=k*p+Gs(Bt),Vt=w*P,kt=qs(w,r),Lt=D*p+Gs(Vt),Dt=S*T,Xt=qs(S,o),qt=k*d+Gs(Dt),Qt=w*T,$t=qs(w,o),Gt=D*d+Gs(Qt),Ht=w*y,Rt=qs(w,i),Ut=D*g+Gs(Ht),Zt=3*w,jt=Ds(3,w),Wt=Gs(Zt),Jt=Zt*y,Kt=Qs(jt,i),tn=Wt*g+2*Gs(Jt),nn=F*M,en=Qs(N,e),rn=L*a+2*Gs(nn),on=F*T,sn=Qs(N,o),cn=L*d+2*Gs(on),un=V*P,fn=Qs(E,r),ln=X*p+2*Gs(un),hn=V*y,an=Qs(E,i),pn=X*g+2*Gs(hn),dn=nn+un,gn=$s(en,fn),vn=Gs(dn),mn=rn+ln+vn,bn=on+hn,xn=$s(sn,an),_n=Gs(bn),In=cn+pn+_n,Nn=H*dn,Sn=Qs(ot,gn),En=it*vn+xt*mn+2*Gs(Nn),wn=W*bn,Mn=Qs(pt,xn),Pn=dt*_n+Et*In+2*Gs(wn),Tn=Nn+wn,yn=$s(Sn,Mn),Cn=En+Pn+Gs(Tn),On=Ot+Vt,An=$s(At,kt),zn=zt+Lt+Gs(On),Bn=2*(Bt+Qt),Yn=Xs($s(Yt,$t)),Fn=2*(Ft+Gt)+Gs(Bn),Vn=Dt+Jt,kn=$s(Xt,Kt),Ln=qt+tn+Gs(Vn),Dn=On+C,Xn=$s(An,s),qn=Gs(Dn),Qn=zn+v+qn,$n=Bn+O,Gn=$s(Yn,c),Hn=Gs($n),Rn=Fn+m+Hn,Un=Vn+A,Zn=$s(kn,u),jn=Gs(Un),Wn=Ln+b+jn,Jn=H*Dn,Kn=Qs(ot,Xn),te=it*qn+xt*Qn+2*Gs(Jn),ne=U*$n,ee=Qs(ut,Gn),re=ft*Hn+It*Rn+2*Gs(ne),oe=W*Un,ie=Qs(pt,Zn),se=dt*jn+Et*Wn+2*Gs(oe),ce=Jn+ne,ue=$s(Kn,ee),fe=te+re+Gs(ce),le=ce+oe,he=$s(ue,ie),ae=fe+se+Gs(le),pe=2*(Vt+C),de=Xs($s(kt,s)),ge=2*(Lt+v)+Gs(pe),ve=2*(Dt+A),me=Xs($s(Xt,u)),be=2*(qt+b)+Gs(ve),xe=Ot+pe,_e=$s(At,de),Ie=Gs(xe),Ne=zt+ge+Ie,Se=Jt+ve,Ee=$s(Kt,me),we=Gs(Se),Me=tn+be+we,Pe=Bt+O,Te=$s(Yt,c),ye=Gs(Pe),Ce=Ft+m+ye,Oe=Qt+O,Ae=$s($t,c),ze=Gs(Oe),Be=Gt+m+ze,Ye=Q*xe,Fe=Qs(K,_e),Ve=tt*Ie+vt*Ne+2*Gs(Ye),ke=j*Se,Le=Qs(ht,Ee),De=at*we+St*Me+2*Gs(ke),Xe=G*Pe,qe=Qs(et,Te),Qe=rt*ye+bt*Ce+2*Gs(Xe),$e=R*Oe,Ge=Qs(st,Ae),He=ct*ze+_t*Be+2*Gs($e),Re=F*z,Ue=Qs(N,f),Ze=L*x+2*Gs(Re),je=V*B,We=Qs(E,l),Je=X*_+2*Gs(je),Ke=Ye+ke,tr=$s(Fe,Le),nr=Ve+De+Gs(Ke),er=Xe+$e,rr=$s(qe,Ge),or=Qe+He+Gs(er),ir=Ke+er,sr=$s(tr,rr),cr=nr+or+Gs(ir),ur=Re+je,fr=$s(Ue,We),lr=Ze+Je+Gs(ur),hr=ir+ur,ar=$s(sr,fr),pr=cr+lr+Gs(hr),dr=wt+Vt,gr=$s(Mt,kt),vr=Pt+Lt+Gs(dr),mr=Ht+Dt,br=$s(Rt,Xt),xr=Ut+qt+Gs(mr),_r=dr+C,Ir=$s(gr,s),Nr=vr+v+Gs(_r),Sr=mr+A,Er=$s(br,u),wr=xr+b+Gs(Sr),Mr=q*_r,Pr=Qs(J,Ir),Tr=gt*Nr+2*Gs(Mr),yr=Z*Sr,Cr=Qs(lt,Er),Or=Nt*wr+2*Gs(yr),Ar=$*O,zr=Qs(nt,c),Br=mt*m+2*Gs(Ar),Yr=Mr+yr,Fr=$s(Pr,Cr),Vr=Tr+Or+Gs(Yr),kr=Yr+Ar,Lr=$s(Fr,zr),Dr=Vr+Br+Gs(kr),Xr=S*z,qr=qs(S,f),Qr=k*x+Gs(Xr),$r=w*B,Gr=qs(w,l),Hr=D*_+Gs($r),Rr=Xr+$r,Ur=$s(qr,Gr),Zr=Qr+Hr+Gs(Rr),jr=kr+Rr,Wr=$s(Lr,Ur),Jr=Dr+Zr+Gs(jr),Kr=jr+Y,to=$s(Wr,h),no=Jr+I+Gs(Kr);return{coeffs:[yn,he,ar,to],errBound:[Hs*Cn,Hs*ae,Hs*pr,Hs*no]}},function(t,n){const{coeffs:{vₓₓₓ:e,vₓₓᵧ:r,vₓᵧᵧ:o,vᵧᵧᵧ:i,vₓₓ:s,vₓᵧ:c,vᵧᵧ:u,vₓ:f,vᵧ:l,v:h},errorBound:{vₓₓₓ_:a,vₓₓᵧ_:p,vₓᵧᵧ_:d,vᵧᵧᵧ_:g,vₓₓ_:v,vₓᵧ_:m,vᵧᵧ_:b,vₓ_:x,vᵧ_:_,v_:I}}=Ls(t),{coeffs:[[N,S,[,E]],[w,M,[,P]]],errorBound:[[T],[y]]}=is(n),C=e[1],O=r[1],A=o[1],z=i[1],B=s[1],Y=c[1],F=u[1],V=f[1],k=l[1],L=h[1],D=lc(C),X=lc(O),q=lc(A),Q=lc(z),$=lc(B),G=lc(F),H=lc(Y),R=lc(V),U=lc(k),Z=S[1],j=N[1],W=M[1],J=w[1],K=lc(E),tt=lc(Z),nt=lc(j),et=lc(P),rt=lc(W),ot=lc(J),it=E*E,st=E*Z,ct=E*j,ut=E*P,ft=E*W,lt=E*J,ht=Z*Z,at=Z*j,pt=Z*P,dt=Z*W,gt=Z*J,vt=j*W,mt=j*j,bt=j*P,xt=j*J,_t=P*P,It=P*W,Nt=P*J,St=W*W,Et=W*J,wt=J*J,Mt=ic(E,E),Pt=cc(E,S),Tt=lc(st),yt=cc(E,N),Ct=K*T+lc(ct),Ot=ic(E,P),At=cc(E,M),zt=lc(ft),Bt=cc(E,w),Yt=K*y+lc(lt),Ft=uc(S,S),Vt=2*lc(ht),kt=uc(S,N),Lt=tt*T+2*lc(at),Dt=cc(P,S),Xt=lc(pt),qt=uc(S,M),Qt=2*lc(dt),$t=uc(S,w),Gt=tt*y+2*lc(gt),Ht=uc(N,M),Rt=T*rt+2*lc(vt),Ut=uc(N,N),Zt=2*(T*nt+lc(mt)),jt=cc(P,N),Wt=et*T+lc(bt),Jt=uc(N,w),Kt=T*ot+nt*y+2*lc(xt),tn=ic(P,P),nn=cc(P,M),en=lc(It),rn=cc(P,w),on=et*y+lc(Nt),sn=uc(M,M),cn=2*lc(St),un=uc(M,w),fn=rt*y+2*lc(Et),ln=uc(w,w),hn=2*(y*ot+lc(wt)),an=lc(it),pn=lc(st),dn=lc(ut),gn=lc(ft),vn=lc(at),mn=lc(mt),bn=lc(xt),xn=lc(pt),_n=lc(_t),In=lc(It),Nn=lc(Et),Sn=lc(wt),En=uc(N,e),wn=j*C,Mn=T*D+nt*a+2*lc(wn),Pn=uc(N,o),Tn=j*A,yn=T*q+nt*d+2*lc(Tn),Cn=uc(w,r),On=J*O,An=y*X+ot*p+2*lc(On),zn=uc(w,i),Bn=J*z,Yn=y*Q+ot*g+2*lc(Bn),Fn=wn+On,Vn=fc(En,Cn),kn=lc(Fn),Ln=Mn+An+kn,Dn=Tn+Bn,Xn=fc(Pn,zn),qn=lc(Dn),Qn=yn+Yn+qn,$n=mt*Fn,Gn=uc(Ut,Vn),Hn=Zt*kn+mn*Ln+2*lc($n),Rn=wt*Dn,Un=uc(ln,Xn),Zn=hn*qn+Sn*Qn+2*lc(Rn),jn=$n+Rn,Wn=fc(Gn,Un),Jn=Hn+Zn+lc(jn),Kn=ct+ht,te=fc(yt,Ft),ne=lc(Kn),ee=Ct+Vt+ne,re=Nt+St,oe=fc(rn,sn),ie=lc(re),se=on+cn+ie,ce=2*ct+ht,ue=lc(ce),fe=fc(sc(yt),Ft),le=2*Ct+Vt+ue,he=2*Nt+St,ae=fc(sc(rn),sn),pe=lc(he),de=2*on+cn+pe,ge=2*dt+bt,ve=fc(sc(qt),jt),me=lc(ge),be=2*Qt+Wt+me,xe=2*dt+lt,_e=fc(sc(qt),Bt),Ie=lc(xe),Ne=2*Qt+Yt+Ie,Se=2*bt+dt,Ee=fc(sc(jt),qt),we=2*Wt+Qt+lc(Se),Me=6*ct+ht,Pe=6*ct,Te=cc(6,yt),ye=6*Ct+lc(Pe),Ce=fc(Te,Ft),Oe=ye+Vt+lc(Pe+ht),Ae=6*Nt+St,ze=6*Nt,Be=cc(6,rn),Ye=6*on+lc(ze),Fe=fc(Be,sn),Ve=Ye+cn+lc(ze+St),ke=gt+vt,Le=fc($t,Ht),De=lc(ke),Xe=Gt+Rt+De,qe=lt+bt,Qe=fc(Bt,jt),$e=Yt+Wt+lc(qe),Ge=2*pt+ft,He=fc(sc(Dt),At),Re=2*Xt+zt+lc(Ge),Ue=2*ft+pt,Ze=fc(sc(At),Dt),je=2*zt+Xt+lc(Ue),We=lt+dt,Je=fc(Bt,qt),Ke=Yt+Qt+lc(We),tr=We+bt,nr=fc(Je,jt),er=lc(tr),rr=Ke+Wt+er,or=3*mt,ir=cc(3,Ut),sr=3*Zt+lc(or),cr=lc(or),ur=3*wt,fr=cc(3,ln),lr=3*hn+lc(ur),hr=lc(ur),ar=or*C,pr=uc(ir,e),dr=sr*D+cr*a+2*lc(ar),gr=mt*O,vr=uc(Ut,r),mr=Zt*X+mn*p+2*lc(gr),br=2*xt*O,xr=sc(uc(Jt,r)),_r=2*(Kt*X+bn*p+lc(br)),Ir=2*xt*A,Nr=sc(uc(Jt,o)),Sr=2*(Kt*q+bn*d+lc(Ir)),Er=wt*A,wr=uc(ln,o),Mr=hn*q+Sn*d+2*lc(Er),Pr=ur*z,Tr=uc(fr,i),yr=lr*Q+hr*g+2*lc(Pr),Cr=ar+br,Or=fc(pr,xr),Ar=dr+_r+lc(Cr),zr=gr+Ir,Br=fc(vr,Nr),Yr=mr+Sr+lc(zr),Fr=Cr+Er,Vr=fc(Or,wr),kr=Ar+Mr+lc(Fr),Lr=zr+Pr,Dr=fc(Br,Tr),Xr=Yr+yr+lc(Lr),qr=Z*Fr,Qr=uc(S,Vr),$r=tt*kr+lc(qr),Gr=W*Lr,Hr=uc(M,Dr),Rr=rt*Xr+lc(Gr),Ur=qr+Gr,Zr=fc(Qr,Hr),jr=$r+Rr+lc(Ur),Wr=J*ce,Jr=uc(w,fe),Kr=y*ue+ot*le+2*lc(Wr),to=J*xe,no=uc(w,_e),eo=y*Ie+ot*Ne+2*lc(to),ro=j*ge,oo=uc(N,ve),io=T*me+nt*be+2*lc(ro),so=j*he,co=uc(N,ae),uo=T*pe+nt*de+2*lc(so),fo=3*j,lo=cc(3,N),ho=lc(fo),ao=3*T+ho,po=fo*Kn,go=uc(lo,te),vo=lc(po),mo=ao*ne+ho*ee+vo,bo=3*J,xo=cc(3,w),_o=lc(bo),Io=3*y+_o,No=bo*re,So=uc(xo,oe),Eo=lc(No),wo=Io*ie+_o*se+Eo,Mo=Wr+ro,Po=fc(Jr,oo),To=lc(Mo),yo=Kr+io+To,Co=to+so,Oo=fc(no,co),Ao=lc(Co),zo=eo+uo+Ao,Bo=po*C,Yo=uc(go,e),Fo=mo*D+vo*a+2*lc(Bo),Vo=No*z,ko=uc(So,i),Lo=wo*Q+Eo*g+2*lc(Vo),Do=Mo*O,Xo=uc(Po,r),qo=yo*X+To*p+2*lc(Do),Qo=Co*A,$o=uc(Oo,o),Go=zo*q+Ao*d+2*lc(Qo),Ho=Bo+Vo,Ro=fc(Yo,ko),Uo=Fo+Lo+lc(Ho),Zo=Do+Qo,jo=fc(Xo,$o),Wo=qo+Go+lc(Zo),Jo=mt*B,Ko=uc(Ut,s),ti=Zt*$+mn*v+2*lc(Jo),ni=wt*F,ei=uc(ln,u),ri=hn*G+Sn*b+2*lc(ni),oi=xt*Y,ii=uc(Jt,c),si=Kt*H+bn*m+2*lc(oi),ci=Jo+ni,ui=fc(Ko,ei),fi=ti+ri+lc(ci),li=Ho+Zo,hi=fc(Ro,jo),ai=Uo+Wo+lc(li),pi=ci+oi,di=fc(ui,ii),gi=fi+si+lc(pi),vi=li+pi,mi=fc(hi,di),bi=ai+gi+lc(vi),xi=Z*Me,_i=uc(S,Ce),Ii=tt*Oe+2*lc(xi),Ni=2*Ii,Si=W*Ae,Ei=uc(M,Fe),wi=rt*Ve+2*lc(Si),Mi=2*wi,Pi=2*E*ke,Ti=cc(2*E,Le),yi=2*K*Xe+lc(Pi),Ci=2*W*qe,Oi=uc(sc(M),Qe),Ai=2*rt*$e+2*lc(Ci),zi=Z*Se,Bi=uc(S,Ee),Yi=tt*we+2*lc(zi),Fi=Z*he,Vi=uc(S,ae),ki=tt*de+2*lc(Fi),Li=Pi+zi,Di=fc(Ti,Bi),Xi=yi+Yi+lc(Li),qi=yi+Yi+Xi,Qi=Ci+Fi,$i=fc(Oi,Vi),Gi=Ai+ki+lc(Qi),Hi=Ai+ki+Gi,Ri=Et*F,Ui=uc(un,u),Zi=fn*G+Nn*b+2*lc(Ri),ji=at*B,Wi=uc(kt,s),Ji=Lt*$+vn*v+2*lc(ji),Ki=ke*Y,ts=uc(Le,c),ns=Xe*H+De*m+2*lc(Ki),es=Ri+ji,rs=fc(Ui,Wi),os=Zi+Ji+lc(es),ss=xi*C,cs=uc(_i,e),us=Ni*D+Ii*a+2*lc(ss),fs=Li*O,ls=uc(Di,r),hs=qi*X+Xi*p+2*lc(fs),as=Si*z,ps=uc(Ei,i),ds=Mi*Q+wi*g+2*lc(as),gs=Qi*A,vs=uc($i,o),ms=Hi*q+Gi*d+2*lc(gs),bs=ss+as,xs=fc(cs,ps),_s=us+ds+lc(bs),Is=fs+gs,Ns=fc(ls,vs),Ss=hs+ms+lc(Is),Es=bs+Is,ws=fc(xs,Ns),Ms=_s+Ss+lc(Es),Ps=2*es+Ki,Ts=fc(sc(rs),ts),ys=2*os+ns+lc(Ps),Cs=Es+Ps,Os=fc(ws,Ts),As=Ms+ys+lc(Cs),zs=3*E,Bs=lc(zs),Ys=ic(3,E),Fs=zs*Kn,Vs=uc(Ys,te),ks=lc(Fs),Ds=Bs*ee+2*lc(Fs),Xs=3*P,qs=lc(Xs),Qs=ic(3,P),$s=Xs*re,Gs=uc(Qs,oe),Hs=lc($s),Rs=qs*se+2*lc($s),Us=E*xe,Zs=cc(E,_e),js=K*Ne+lc(Us),Ws=E*he,Js=cc(E,ae),Ks=K*de+lc(Ws),tc=P*ce,nc=cc(P,fe),ec=et*le+lc(tc),rc=P*ge,oc=cc(P,ve),ac=et*be+lc(rc),pc=Us+tc,dc=fc(Zs,nc),gc=lc(pc),vc=js+ec+gc,mc=Ws+rc,bc=fc(Js,oc),xc=lc(mc),_c=Ks+ac+xc,Ic=Fs*C,Nc=uc(Vs,e),Sc=Ds*D+ks*a+2*lc(Ic),Ec=$s*z,wc=uc(Gs,i),Mc=Rs*Q+Hs*g+2*lc(Ec),Pc=pc*O,Tc=uc(dc,r),yc=vc*X+gc*p+2*lc(Pc),Cc=mc*A,Oc=uc(bc,o),Ac=_c*q+xc*d+2*lc(Cc),zc=ce*B,Bc=uc(fe,s),Yc=le*$+ue*v+2*lc(zc),Fc=he*F,Vc=uc(ae,u),kc=de*G+pe*b+2*lc(Fc),Lc=tr*Y,Dc=uc(nr,c),Xc=rr*H+er*m+2*lc(Lc),qc=j*V,Qc=uc(N,f),$c=T*R+nt*x+2*lc(qc),Gc=J*k,Hc=uc(w,l),Rc=y*U+ot*_+2*lc(Gc),Uc=Ic+Ec,Zc=fc(Nc,wc),jc=Sc+Mc+lc(Uc),Wc=Pc+Cc,Jc=fc(Tc,Oc),Kc=yc+Ac+lc(Wc),tu=zc+Fc,nu=fc(Bc,Vc),eu=Yc+kc+lc(tu),ru=Uc+Wc,ou=fc(Zc,Jc),iu=jc+Kc+lc(ru),su=tu+Lc,cu=fc(nu,Dc),uu=eu+Xc+lc(su),fu=qc+Gc,lu=fc(Qc,Hc),hu=$c+Rc+lc(fu),au=ru+su,pu=fc(ou,cu),du=iu+uu+lc(au),gu=au+fu,vu=fc(pu,lu),mu=du+hu+lc(gu),bu=zs*st,xu=uc(Ys,Pt),_u=lc(bu),Iu=Bs*Tt+2*_u,Nu=Xs*It,Su=uc(Qs,nn),Eu=lc(Nu),wu=qs*en+2*Eu,Mu=E*Ge,Pu=cc(E,He),Tu=lc(Mu),yu=K*Re+lc(Mu),Cu=P*Ue,Ou=cc(P,Ze),Au=lc(Cu),zu=et*je+lc(Cu),Bu=st*B,Yu=uc(Pt,s),Fu=Tt*$+pn*v+2*lc(Bu),Vu=It*F,ku=uc(nn,u),Lu=en*G+In*b+2*lc(Vu),Du=ft*Y,Xu=uc(At,c),qu=zt*H+gn*m+2*lc(Du),Qu=pt*Y,$u=uc(Dt,c),Gu=Xt*H+xn*m+2*lc(Qu),Hu=2*(Bu+Vu),Ru=sc(fc(Yu,ku)),Uu=2*(Fu+Lu)+lc(Hu),Zu=Du+Qu,ju=fc(Xu,$u),Wu=qu+Gu+lc(Zu),Ju=Z*V,Ku=uc(S,f),tf=tt*x+2*lc(Ju),nf=W*k,ef=uc(M,l),rf=rt*_+2*lc(nf),of=bu*C,sf=uc(xu,e),cf=Iu*D+_u*a+2*lc(of),uf=Nu*z,ff=uc(Su,i),lf=wu*Q+Eu*g+2*lc(uf),hf=Mu*O,af=uc(Pu,r),pf=yu*X+Tu*p+2*lc(hf),df=Cu*A,gf=uc(Ou,o),vf=zu*q+Au*d+2*lc(df),mf=of+uf,bf=fc(sf,ff),xf=cf+lf+lc(mf),_f=hf+df,If=fc(af,gf),Nf=pf+vf+lc(_f),Sf=mf+_f,Ef=fc(bf,If),wf=xf+Nf+lc(Sf),Mf=Hu+Zu,Pf=fc(Ru,ju),Tf=Uu+Wu+lc(Mf),yf=Ju+nf,Cf=fc(Ku,ef),Of=tf+rf+lc(yf),Af=Sf+Mf,zf=fc(Ef,Pf),Bf=wf+Tf+lc(Af),Yf=Af+yf,Ff=fc(zf,Cf),Vf=Bf+Of+lc(Yf),kf=E*C,Lf=cc(E,e),Df=K*a+lc(kf),Xf=E*A,qf=cc(E,o),Qf=K*d+lc(Xf),$f=P*O,Gf=cc(P,r),Hf=et*p+lc($f),Rf=P*z,Uf=cc(P,i),Zf=et*g+lc(Rf),jf=kf+$f,Wf=fc(Lf,Gf),Jf=Df+Hf+lc(jf),Kf=Xf+Rf,tl=fc(qf,Uf),nl=Qf+Zf+lc(Kf),el=jf+B,rl=fc(Wf,s),ol=Jf+v+lc(el),il=Kf+F,sl=fc(tl,u),cl=nl+b+lc(il),ul=it*el,fl=uc(Mt,rl),ll=an*ol+2*lc(ul),hl=_t*il,al=uc(tn,sl),pl=_n*cl+2*lc(hl),dl=ut*Y,gl=uc(Ot,c),vl=dn*m+2*lc(dl),ml=E*V,bl=cc(E,f),xl=K*x+lc(ml),_l=P*k,Il=cc(P,l),Nl=et*_+lc(_l),Sl=ul+hl,El=fc(fl,al),wl=ll+pl+lc(Sl),Ml=Sl+dl,Pl=fc(El,gl),Tl=wl+vl+lc(Ml),yl=ml+_l,Cl=fc(bl,Il),Ol=xl+Nl+lc(yl),Al=Ml+yl,zl=fc(Pl,Cl),Bl=Tl+Ol+lc(Al),Yl=Al+L,Fl=fc(zl,h),Vl=Bl+I+lc(Yl);return{coeffs:[Wn,Zr,mi,Os,vu,Ff,Fl],errBound:[hc*Jn,hc*jr,hc*bi,hc*As,hc*mu,hc*Vf,hc*Vl]}},function(t,n){const{coeffs:{vₓₓₓ:e,vₓₓᵧ:r,vₓᵧᵧ:o,vᵧᵧᵧ:i,vₓₓ:s,vₓᵧ:c,vᵧᵧ:u,vₓ:f,vᵧ:l,v:h},errorBound:{vₓₓₓ_:a,vₓₓᵧ_:p,vₓᵧᵧ_:d,vᵧᵧᵧ_:g,vₓₓ_:v,vₓᵧ_:m,vᵧᵧ_:b,vₓ_:x,vᵧ_:_,v_:I}}=Ls(t),{coeffs:[[N,S,E,[,w]],[M,P,T,[,y]]],errorBound:[[C,O,A],[z,B,Y]]}=os(n),F=e[1],V=r[1],k=o[1],L=i[1],D=s[1],X=c[1],q=u[1],Q=f[1],$=l[1],G=h[1],H=yc(F),R=yc(V),U=yc(k),Z=yc(L),j=yc(D),W=yc(X),J=yc(q),K=yc(Q),tt=yc($),nt=(yc(G),E[1]),et=S[1],rt=N[1],ot=T[1],it=P[1],st=M[1],ct=yc(w),ut=yc(nt),ft=yc(et),lt=yc(rt),ht=yc(y),at=yc(ot),pt=yc(it),dt=yc(st),gt=w*w,vt=w*nt,mt=w*et,bt=w*rt,xt=w*y,_t=w*ot,It=w*it,Nt=w*st,St=nt*nt,Et=nt*et,wt=nt*rt,Mt=nt*y,Pt=nt*ot,Tt=nt*it,yt=nt*st,Ct=et*ot,Ot=et*et,At=et*rt,zt=et*y,Bt=et*it,Yt=et*st,Ft=rt*rt,Vt=rt*y,kt=rt*ot,Lt=rt*it,Dt=rt*st,Xt=y*y,qt=y*ot,Qt=y*it,$t=y*st,Gt=ot*ot,Ht=ot*it,Rt=st*st,Ut=it*it,Zt=it*st,jt=ot*st,Wt=Ec(w,w),Jt=Mc(w,E),Kt=ct*A+yc(vt),tn=Mc(w,S),nn=ct*O+yc(mt),en=Mc(w,N),rn=ct*C+yc(bt),on=Ec(w,y),sn=Mc(w,T),cn=ct*Y+yc(_t),un=Mc(w,P),fn=ct*B+yc(It),ln=Mc(w,M),hn=ct*z+yc(Nt),an=Pc(E,E),pn=yc(St),dn=2*(A*ut+pn),gn=Pc(E,S),vn=A*ft+ut*O+2*yc(Et),mn=Pc(E,N),bn=A*lt+ut*C+2*yc(wt),xn=Mc(y,E),_n=ht*A+yc(Mt),In=Pc(E,T),Nn=A*at+ut*Y+2*yc(Pt),Sn=Pc(E,P),En=A*pt+ut*B+2*yc(Tt),wn=Pc(E,M),Mn=A*dt+ut*z+2*yc(yt),Pn=Pc(S,T),Tn=O*at+ft*Y+2*yc(Ct),yn=Pc(S,S),Cn=yc(Ot),On=2*(O*ft+Cn),An=Pc(S,N),zn=O*lt+ft*C+2*yc(At),Bn=Mc(y,S),Yn=ht*O+yc(zt),Fn=Pc(S,P),Vn=O*pt+ft*B+2*yc(Bt),kn=Pc(S,M),Ln=O*dt+ft*z+2*yc(Yt),Dn=Pc(N,N),Xn=2*(C*lt+yc(Ft)),qn=Mc(y,N),Qn=ht*C+yc(Vt),$n=Pc(N,T),Gn=C*at+lt*Y+2*yc(kt),Hn=Pc(N,P),Rn=yc(Lt),Un=C*pt+lt*B+2*Rn,Zn=Pc(N,M),jn=C*dt+lt*z+2*yc(Dt),Wn=Ec(y,y),Jn=Mc(y,T),Kn=ht*Y+yc(qt),te=Mc(y,P),ne=ht*B+yc(Qt),ee=Mc(y,M),re=ht*z+yc($t),oe=Pc(T,T),ie=yc(Gt),se=2*(Y*at+ie),ce=Pc(T,P),ue=Y*pt+at*B+2*yc(Ht),fe=Pc(M,M),le=2*(z*dt+yc(Rt)),he=Pc(P,P),ae=yc(Ut),pe=2*(B*pt+ae),de=Pc(P,M),ge=B*dt+pt*z+2*yc(Zt),ve=Pc(T,M),me=yc(jt),be=Y*dt+at*z+2*me,xe=yc(gt),_e=yc(vt),Ie=yc(At),Ne=yc(Ft),Se=yc(Dt),Ee=yc(xt),we=yc(Xt),Me=yc(qt),Pe=yc(Zt),Te=yc(Rt),ye=rt*Ft,Ce=Pc(N,Dn),Oe=lt*Ne,Ae=C*Ne+lt*Xn+2*Oe,ze=rt*Rt,Be=Pc(N,fe),Ye=lt*Te,Fe=C*Te+lt*le+2*Ye,Ve=st*Ft,ke=Pc(M,Dn),Le=dt*Ne,De=z*Ne+dt*Xn+2*Le,Xe=st*Rt,qe=Pc(M,fe),Qe=dt*Te,$e=z*Te+dt*le+2*Qe,Ge=ye*F,He=Pc(Ce,e),Re=Ae*H+Oe*a+2*yc(Ge),Ue=ze*k,Ze=Pc(Be,o),je=Fe*U+Ye*d+2*yc(Ue),We=Ve*V,Je=Pc(ke,r),Ke=De*R+Le*p+2*yc(We),tr=Xe*L,nr=Pc(qe,i),er=$e*Z+Qe*g+2*yc(tr),rr=Ge+Ue,or=Tc(He,Ze),ir=Re+je+yc(rr),sr=We+tr,cr=Tc(Je,nr),ur=Ke+er+yc(sr),fr=rr+sr,lr=Tc(or,cr),hr=ir+ur+yc(fr),ar=2*Yt+Lt,pr=yc(ar),dr=Tc(wc(kn),Hn),gr=2*Ln+Un+pr,vr=2*Lt+Yt,mr=yc(vr),br=Tc(wc(Hn),kn),xr=2*Un+Ln+yc(vr),_r=rt*ar,Ir=yc(_r),Nr=Pc(N,dr),Sr=C*pr+lt*gr+2*Ir,Er=st*vr,wr=yc(Er),Mr=Pc(M,br),Pr=z*mr+dt*xr+2*wr,Tr=et*Ft,yr=yc(Tr),Cr=Pc(S,Dn),Or=O*Ne+ft*Xn+2*yr,Ar=it*Rt,zr=yc(Ar),Br=Pc(P,fe),Yr=B*Te+pt*le+2*zr,Fr=F*Tr,Vr=Pc(e,Cr),kr=Or*H+H*Or+2*yc(Fr),Lr=L*Ar,Dr=Pc(i,Br),Xr=Yr*Z+Z*Yr+2*yc(Lr),qr=V*_r,Qr=Pc(r,Nr),$r=Sr*R+R*Sr+2*yc(qr),Gr=k*Er,Hr=Pc(o,Mr),Rr=Pr*U+U*Pr+2*yc(Gr),Ur=qr+Gr,Zr=Tc(Qr,Hr),jr=$r+Rr+yc(Ur),Wr=3*(Fr+Lr),Jr=Mc(3,Tc(Vr,Dr)),Kr=3*(kr+Xr)+2*yc(Wr),to=Ur+Wr,no=Tc(Zr,Jr),eo=jr+Kr+yc(to),ro=nt*Dt,oo=Pc(E,Zn),io=A*Se+ut*jn+2*yc(ro),so=ot*Ft,co=Pc(T,Dn),uo=Y*Ne+at*Xn+2*yc(so),fo=et*Zt,lo=Pc(S,de),ho=O*Pe+ft*ge+2*yc(fo),ao=nt*Rt,po=Pc(E,fe),go=A*Te+ut*le+2*yc(ao),vo=et*Lt,mo=Pc(S,Hn),bo=O*Rn+ft*Un+2*yc(vo),xo=st*Ot,_o=Pc(M,yn),Io=z*Cn+dt*On+2*yc(xo),No=rt*jt,So=Pc(N,ve),Eo=C*me+lt*be+2*yc(No),wo=it*Lt,Mo=Pc(P,Hn),Po=B*Rn+pt*Un+2*yc(wo),To=ro+vo,yo=Tc(oo,mo),Co=io+bo+yc(To),Oo=so+xo,Ao=Tc(co,_o),zo=uo+Io+yc(Oo),Bo=fo+No,Yo=Tc(lo,So),Fo=ho+Eo+yc(Bo),Vo=ao+wo,ko=Tc(po,Mo),Lo=go+Po+yc(Vo),Do=wt+Ot,Xo=Tc(mn,yn),qo=yc(Do),Qo=bn+On+qo,$o=jt+Ut,Go=yc($o),Ho=Tc(ve,he),Ro=be+pe+Go,Uo=2*To+Oo,Zo=Tc(wc(yo),Ao),jo=yc(Uo),Wo=2*Co+zo+jo,Jo=2*Bo+Vo,Ko=Tc(wc(Yo),ko),ti=yc(Jo),ni=2*Fo+Lo+ti,ei=V*Uo,ri=Pc(r,Zo),oi=p*jo+R*Wo+2*yc(ei),ii=k*Jo,si=Pc(o,Ko),ci=d*ti+U*ni+2*yc(ii),ui=rt*Do,fi=Pc(N,Xo),li=yc(ui),hi=C*qo+lt*Qo+2*li,ai=st*$o,pi=Pc(M,Ho),di=yc(ai),gi=z*Go+dt*Ro+2*di,vi=F*ui,mi=Pc(e,fi),bi=a*li+H*hi+2*yc(vi),xi=L*ai,_i=Pc(i,pi),Ii=g*di+Z*gi+2*yc(xi),Ni=ei+ii,Si=Tc(ri,si),Ei=oi+ci+yc(Ni),wi=3*(vi+xi),Mi=Mc(3,Tc(mi,_i)),Pi=3*(bi+Ii)+2*yc(wi),Ti=Ni+wi,yi=Tc(Si,Mi),Ci=Ei+Pi+yc(Ti),Oi=Yt+Lt,Ai=Tc(kn,Hn),zi=yc(Oi),Bi=Ln+Un+zi,Yi=it*Ot,Fi=Pc(P,yn),Vi=B*Cn+pt*On+2*yc(Yi),ki=2*nt*Oi,Li=wc(Pc(E,Ai)),Di=2*(A*zi+ut*Bi+2*yc(ki)),Xi=Yi+ki,qi=Tc(Fi,Li),Qi=Vi+Di+yc(Xi),$i=2*(Nt+Ct),Gi=wc(Tc(ln,Pn)),Hi=2*(hn+Tn)+yc($i),Ri=$i+Vt,Ui=yc(Ri),Zi=Tc(Gi,qn),ji=Hi+Qn+Ui,Wi=rt*Ri,Ji=Pc(N,Zi),Ki=C*Ui+lt*ji+2*yc(Wi),ts=Xi+Wi,ns=Tc(qi,Ji),es=yc(ts),rs=Qi+Ki+es,is=et*Ut,ss=Pc(S,he),cs=O*ae+ft*pe+2*yc(is),us=2*ot*Oi,fs=wc(Pc(T,Ai)),ls=2*(Y*zi+at*Bi+yc(us)),hs=is+us,as=Tc(ss,fs),ps=cs+ls+yc(hs),ds=2*(Tt+Vt),gs=wc(Tc(Sn,qn)),vs=2*(En+Qn)+yc(ds),ms=ds+Nt,bs=Tc(gs,ln),xs=yc(ms),_s=vs+hn+xs,Is=st*ms,Ns=Pc(M,bs),Ss=z*xs+dt*_s+2*yc(Is),Es=hs+Is,ws=Tc(as,Ns),Ms=yc(Es),Ps=ps+Ss+Ms,Ts=et*Ot,ys=Pc(S,yn),Cs=O*Cn+ft*On+2*yc(Ts),Os=2*Et+bt,As=Tc(wc(gn),en),zs=yc(Os),Bs=2*vn+rn+zs,Ys=3*rt,Fs=Mc(3,N),Vs=yc(Ys),ks=3*C+Vs,Ds=Ys*Os,Xs=Pc(Fs,As),qs=ks*zs+Vs*Bs+2*yc(Ds),Qs=Ts+Ds,$s=Tc(ys,Xs),Gs=yc(Qs),Hs=Cs+qs+Gs,Rs=it*Ut,Us=Pc(P,he),Zs=B*ae+pt*pe+2*yc(Rs),js=2*Ht+$t,Ws=Tc(wc(ce),ee),Js=yc(js),Ks=2*ue+re+Js,tc=3*st,nc=Mc(3,M),ec=yc(tc),rc=3*z+ec,oc=tc*js,ic=Pc(nc,Ws),sc=rc*Js+ec*Ks+2*yc(oc),cc=Rs+oc,uc=Tc(Us,ic),fc=yc(cc),lc=Zs+sc+fc,hc=V*ts,ac=Pc(r,ns),pc=p*es+R*rs+2*yc(hc),dc=k*Es,gc=Pc(o,ws),vc=d*Ms+U*Ps+2*yc(dc),mc=hc+dc,bc=Tc(ac,gc),xc=pc+vc+yc(mc),_c=F*Qs,Ic=Pc(e,$s),Nc=a*Gs+H*Hs+2*yc(_c),Sc=L*cc,Oc=Pc(i,uc),Ac=g*fc+Z*lc+2*yc(Sc),zc=_c+Sc,Bc=Tc(Ic,Oc),Yc=Nc+Ac+yc(zc),Fc=D*Ft,Vc=Pc(Dn,s),kc=Xn*j+Ne*v+2*yc(Fc),Lc=q*Rt,Dc=Pc(fe,u),Xc=le*J+Te*b+2*yc(Lc),qc=Fc+Lc,Qc=Tc(Vc,Dc),$c=kc+Xc+yc(qc),Gc=X*Dt,Hc=Pc(Zn,c),Rc=jn*W+Se*m+2*yc(Gc),Uc=mc+zc,Zc=Tc(bc,Bc),jc=xc+Yc+yc(Uc),Wc=qc+Gc,Jc=Tc(Qc,Hc),Kc=$c+Rc+yc(Wc),tu=Uc+Wc,nu=Tc(Zc,Jc),eu=jc+Kc+yc(tu),ru=Bt+kt,ou=Tc(Fn,$n),iu=yc(ru),su=Vn+Gn+iu,cu=yt+Bt,uu=Tc(wn,Fn),fu=yc(cu),lu=Mn+Vn+fu,hu=w*Oi,au=Mc(w,Ai),pu=ct*Bi+yc(hu),du=y*Oi,gu=Mc(y,Ai),vu=ht*Bi+yc(du),mu=nt*ru,bu=Pc(E,ou),xu=A*iu+ut*su+2*yc(mu),_u=ot*cu,Iu=Pc(T,uu),Nu=Y*fu+at*lu+2*yc(_u),Su=2*Vt+Ct,Eu=Tc(wc(qn),Pn),wu=yc(Su),Mu=2*Qn+Tn+wu,Pu=2*Nt+Tt,Tu=Tc(wc(ln),Sn),yu=yc(Pu),Cu=2*hn+En+yu,Ou=st*St,Au=Pc(M,an),zu=z*pn+dt*dn+2*yc(Ou),Bu=rt*Gt,Yu=Pc(N,oe),Fu=C*ie+lt*se+2*yc(Bu),Vu=et*Su,ku=Pc(S,Eu),Lu=O*wu+ft*Mu+2*yc(Vu),Du=it*Pu,Xu=Pc(P,Tu),qu=B*yu+pt*Cu+2*yc(Du),Qu=2*(hu+mu),$u=wc(Tc(au,bu)),Gu=2*(pu+xu)+yc(Qu),Hu=2*(du+_u),Ru=wc(Tc(gu,Iu)),Uu=2*(vu+Nu)+yc(Hu),Zu=2*w*At,ju=wc(Mc(w,An)),Wu=2*ct*zn+yc(Zu),Ju=2*y*Zt,Ku=wc(Mc(y,de)),tf=2*ht*ge+yc(Ju),nf=nt*Do,ef=Pc(E,Xo),rf=A*qo+ut*Qo+2*yc(nf),of=ot*$o,sf=Pc(T,Ho),cf=Y*Go+at*Ro+2*yc(of),uf=D*At,ff=Pc(An,s),lf=zn*j+Ie*v+2*yc(uf),hf=q*Zt,af=Pc(de,u),pf=ge*J+Pe*b+2*yc(hf),df=Qu+Ou,gf=Tc($u,Au),vf=yc(df),mf=Gu+zu+vf,bf=Hu+Bu,xf=Tc(Ru,Yu),_f=yc(bf),If=Uu+Fu+_f,Nf=df+Vu,Sf=Tc(gf,ku),Ef=yc(Nf),wf=mf+Lu+Ef,Mf=bf+Du,Pf=Tc(xf,Xu),Tf=yc(Mf),yf=If+qu+Tf,Cf=Zu+nf,Of=Tc(ju,ef),Af=yc(Cf),zf=Wu+rf+Af,Bf=Ju+of,Yf=Tc(Ku,sf),Ff=yc(Bf),Vf=tf+cf+Ff,kf=2*(uf+hf),Lf=wc(Tc(ff,af)),Df=2*(lf+pf)+yc(kf),Xf=V*Nf,qf=Pc(r,Sf),Qf=p*Ef+R*wf+2*yc(Xf),$f=k*Mf,Gf=Pc(o,Pf),Hf=d*Tf+U*yf+2*yc($f),Rf=F*Cf,Uf=Pc(e,Of),Zf=a*Af+H*zf+2*yc(Rf),jf=L*Bf,Wf=Pc(i,Yf),Jf=g*Ff+Z*Vf+2*yc(jf),Kf=Xf+$f,tl=Tc(qf,Gf),nl=Qf+Hf+yc(Kf),el=3*(Rf+jf),rl=Mc(3,Tc(Uf,Wf)),ol=3*(Zf+Jf)+2*yc(el),il=X*Oi,sl=Pc(c,Ai),cl=m*zi+W*Bi+2*yc(il),ul=Kf+el,fl=Tc(tl,rl),ll=nl+ol+yc(ul),hl=il+kf,al=Tc(sl,Lf),pl=cl+Df+yc(hl),dl=ul+hl,gl=Tc(fl,al),vl=ll+pl+yc(dl),ml=yt+ru,bl=Tc(wn,ou),xl=yc(ml),_l=Mn+su+xl,Il=2*wt+Ot,Nl=Tc(wc(mn),yn),Sl=yc(Il),El=2*bn+On+Sl,wl=2*jt+Ut,Ml=Tc(wc(ve),he),Pl=yc(wl),Tl=2*be+pe+Pl,yl=2*w*ml,Cl=Mc(2*w,bl),Ol=2*ct*_l+yc(yl),Al=2*y*ml,zl=Mc(2*y,bl),Bl=2*ht*_l+yc(Al),Yl=Tt+2*Ct,Fl=Tc(Sn,wc(Pn)),Vl=yc(Yl),kl=En+2*Tn+Vl,Ll=Ct+2*Tt,Dl=Tc(Pn,wc(Sn)),Xl=yc(Ll),ql=Tn+2*En+Xl,Ql=y*Il,$l=Mc(y,Nl),Gl=ht*El+yc(Ql),Hl=w*wl,Rl=Mc(w,Ml),Ul=ct*Tl+yc(Hl),Zl=nt*Yl,jl=Pc(E,Fl),Wl=A*Vl+ut*kl+2*yc(Zl),Jl=ot*Ll,Kl=Pc(T,Dl),th=Y*Xl+at*ql+2*yc(Jl),nh=w*Il,eh=Mc(w,Nl),rh=ct*El+yc(nh),oh=y*wl,ih=Mc(y,Ml),sh=ht*Tl+yc(oh),ch=et*St,uh=Pc(S,an),fh=O*pn+ft*dn+2*yc(ch),lh=it*Gt,hh=Pc(P,oe),ah=B*ie+pt*se+2*yc(lh),ph=yl+Ql,dh=Tc(Cl,$l),gh=Ol+Gl+yc(ph),vh=Al+Hl,mh=Tc(zl,Rl),bh=Bl+Ul+yc(vh),xh=ph+Zl,_h=Tc(dh,jl),Ih=yc(xh),Nh=gh+Wl+Ih,Sh=vh+Jl,Eh=Tc(mh,Kl),wh=yc(Sh),Mh=bh+th+wh,Ph=nh+ch,Th=Tc(eh,uh),yh=yc(Ph),Ch=rh+fh+yh,Oh=oh+lh,Ah=Tc(ih,hh),zh=yc(Oh),Bh=sh+ah+zh,Yh=V*xh,Fh=Pc(r,_h),Vh=p*Ih+R*Nh+2*yc(Yh),kh=k*Sh,Lh=Pc(o,Eh),Dh=d*wh+U*Mh+2*yc(kh),Xh=F*Ph,qh=Pc(e,Th),Qh=a*yh+H*Ch+2*yc(Xh),$h=L*Oh,Gh=Pc(i,Ah),Hh=g*zh+Z*Bh+2*yc($h),Rh=Xh+$h,Uh=yc(Rh),Zh=Tc(qh,Gh),jh=Qh+Hh+Uh,Wh=Yh+kh,Jh=Tc(Fh,Lh),Kh=Vh+Dh+yc(Wh),ta=Wh+3*Rh,na=Tc(Jh,Mc(3,Zh)),ea=Kh+3*(jh+Uh)+yc(ta),ra=X*ml,oa=Pc(c,bl),ia=m*xl+W*_l+2*yc(ra),sa=D*Il,ca=Pc(s,Nl),ua=v*Sl+j*El+2*yc(sa),fa=ra+sa,la=Tc(oa,ca),ha=ia+ua+yc(fa),aa=q*wl,pa=Pc(u,Ml),da=b*Pl+J*Tl+2*yc(aa),ga=fa+aa,va=Tc(la,pa),ma=ha+da+yc(ga),ba=ta+ga,xa=Tc(na,va),_a=ea+ma+yc(ba),Ia=Tt+Ct,Na=Tc(Sn,Pn),Sa=En+Tn+yc(Ia),Ea=Vt+Nt,wa=Tc(qn,ln),Ma=Qn+hn+yc(Ea),Pa=Et+bt,Ta=Tc(gn,en),ya=vn+rn+yc(Pa),Ca=yc(Pa),Oa=Ht+$t,Aa=Tc(ce,ee),za=ue+re+yc(Oa),Ba=yc(Oa),Ya=2*Ia+Vt,Fa=Tc(wc(Na),qn),Va=2*Sa+Qn+yc(Ya),ka=2*Ia+Nt,La=Tc(wc(Na),ln),Da=2*Sa+hn+yc(ka),Xa=2*zt+Pt,qa=Tc(wc(Bn),In),Qa=yc(Xa),$a=2*Yn+Nn+Qa,Ga=2*It+Pt,Ha=Tc(wc(un),In),Ra=yc(Ga),Ua=2*fn+Nn+Ra,Za=Pa+Et,ja=Tc(Ta,gn),Wa=ya+vn+yc(Za),Ja=Oa+Ht,Ka=Tc(Aa,ce),tp=za+ue+yc(Ja),np=3*w,ep=Ec(3,w),rp=np*Za,op=Pc(ep,ja),ip=yc(np)*Wa+2*yc(rp),sp=3*y,cp=Ec(3,y),up=sp*Ja,fp=Pc(cp,Ka),lp=yc(sp)*tp+2*yc(up),hp=nt*St,ap=Pc(E,an),pp=A*pn+ut*dn+2*yc(hp),dp=ot*Gt,gp=Pc(T,oe),vp=Y*ie+at*se+2*yc(dp),mp=D*Pa,bp=Pc(s,Ta),xp=v*Ca+j*ya+yc(mp),_p=q*Oa,Ip=Pc(u,Aa),Np=b*Ba+J*za+yc(_p),Sp=Ya+Ea,Ep=Tc(Fa,wa),wp=Va+Ma+yc(Sp),Mp=ka+Ea,Pp=Tc(La,wa),Tp=Da+Ma+yc(Mp),yp=w*Sp,Cp=Mc(w,Ep),Op=ct*wp+yc(yp),Ap=y*Mp,zp=Mc(y,Pp),Bp=ht*Tp+yc(Ap),Yp=nt*Xa,Fp=Pc(E,qa),Vp=A*Qa+ut*$a+2*yc(Yp),kp=ot*Ga,Lp=Pc(T,Ha),Dp=Y*Ra+at*Ua+2*yc(kp),Xp=rt*Q,qp=Pc(N,f),Qp=C*K+lt*x+2*yc(Xp),$p=st*$,Gp=Pc(M,l),Hp=z*tt+dt*_+2*yc($p),Rp=yp+Yp,Up=Tc(Cp,Fp),Zp=yc(Rp),jp=Op+Vp+Zp,Wp=Ap+kp,Jp=Tc(zp,Lp),Kp=yc(Wp),td=Bp+Dp+Kp,nd=rp+hp,ed=Tc(op,ap),rd=yc(nd),od=ip+pp+rd,id=up+dp,sd=Tc(fp,gp),cd=yc(id),ud=lp+vp+cd,fd=Ea+Ia,ld=Tc(wa,Na),hd=yc(fd),ad=Ma+Sa+hd,pd=2*(mp+_p),dd=wc(Tc(bp,Ip)),gd=2*(xp+Np)+yc(pd),vd=V*Rp,md=Pc(r,Up),bd=p*Zp+R*jp+2*yc(vd),xd=k*Wp,_d=Pc(o,Jp),Id=d*Kp+U*td+2*yc(xd),Nd=F*nd,Sd=Pc(e,ed),Ed=a*rd+H*od+2*yc(Nd),wd=L*id,Md=Pc(i,sd),Pd=g*cd+Z*ud+2*yc(wd),Td=X*fd,yd=Pc(c,ld),Cd=m*hd+W*ad+2*yc(Td),Od=vd+xd,Ad=Tc(md,_d),zd=bd+Id+yc(Od),Bd=Nd+wd,Yd=Tc(Sd,Md),Fd=Ed+Pd+yc(Bd),Vd=Td+pd,kd=Tc(yd,dd),Ld=Cd+gd+yc(Vd),Dd=Xp+$p,Xd=Tc(qp,Gp),qd=Qp+Hp+yc(Dd),Qd=Od+Bd,$d=Tc(Ad,Yd),Gd=zd+Fd+yc(Qd),Hd=Vd+Dd,Rd=Tc(kd,Xd),Ud=Ld+qd+yc(Hd),Zd=Qd+Hd,jd=Tc($d,Rd),Wd=Gd+Ud+yc(Zd),Jd=Pt+zt,Kd=Tc(In,Bn),tg=Nn+Yn+yc(Jd),ng=Pt+It,eg=Tc(In,un),rg=Nn+fn+yc(ng),og=2*Jd+It,ig=Tc(wc(Kd),un),sg=2*tg+fn+yc(og),cg=2*ng+zt,ug=Tc(wc(eg),Bn),fg=2*rg+Yn+yc(cg),lg=w*og,hg=Mc(w,ig),ag=ct*sg+yc(lg),pg=y*St,dg=Mc(y,an),gg=ht*dn+yc(pg),vg=y*cg,mg=Mc(y,ug),bg=ht*fg+yc(vg),xg=w*Gt,_g=Mc(w,oe),Ig=ct*se+yc(xg),Ng=w*St,Sg=Mc(w,an),Eg=ct*dn+yc(Ng),wg=et*gt,Mg=Pc(S,Wt),Pg=O*xe+2*yc(wg),Tg=y*Gt,yg=Mc(y,oe),Cg=ht*se+yc(Tg),Og=it*Xt,Ag=Pc(P,Wn),zg=B*we+2*yc(Og),Bg=lg+pg,Yg=Tc(hg,dg),Fg=ag+gg+yc(Bg),Vg=ag+gg+Fg,kg=vg+xg,Lg=Tc(mg,_g),Dg=bg+Ig+yc(kg),Xg=bg+Ig+Dg,qg=Ng+wg,Qg=Tc(Sg,Mg),$g=yc(qg),Gg=Eg+Pg+$g,Hg=Tg+Og,Rg=Tc(yg,Ag),Ug=yc(Hg),Zg=Cg+zg+Ug,jg=F*qg,Wg=Pc(e,Qg),Jg=a*$g+H*Gg+2*yc(jg),Kg=L*Hg,tv=Pc(i,Rg),nv=g*Ug+Z*Zg+2*yc(Kg),ev=3*(jg+Kg),rv=Mc(3,Tc(Wg,tv)),ov=3*(Jg+nv)+2*yc(ev),iv=Jd+It,sv=Tc(Kd,un),cv=yc(iv),uv=tg+fn+cv,fv=2*mt+St,lv=Tc(wc(tn),an),hv=yc(fv),av=2*nn+dn+hv,pv=2*Qt+Gt,dv=Tc(wc(te),oe),gv=yc(pv),vv=2*ne+se+gv,mv=V*Bg,bv=Pc(r,Yg),xv=p*Fg+R*Vg+2*yc(mv),_v=k*kg,Iv=Pc(o,Lg),Nv=d*Dg+U*Xg+2*yc(_v),Sv=X*iv,Ev=Pc(c,sv),wv=m*cv+W*uv+2*yc(Sv),Mv=D*fv,Pv=Pc(s,lv),Tv=v*hv+j*av+2*yc(Mv),yv=q*pv,Cv=Pc(u,dv),Ov=b*gv+J*vv+2*yc(yv),Av=et*Q,zv=Pc(S,f),Bv=O*K+ft*x+yc(Av),Yv=it*$,Fv=Pc(P,l),Vv=B*tt+pt*_+yc(Yv),kv=Av+Yv,Lv=Tc(zv,Fv),Dv=Bv+Vv+yc(kv),Xv=mv+_v,qv=Tc(bv,Iv),Qv=xv+Nv+yc(Xv),$v=ev+Sv,Gv=Tc(rv,Ev),Hv=ov+wv+yc($v),Rv=Mv+yv,Uv=Tc(Pv,Cv),Zv=Tv+Ov+yc(Rv),jv=Xv+$v,Wv=Tc(qv,Gv),Jv=Qv+Hv+yc(jv),Kv=Rv+kv,tm=Tc(Uv,Lv),nm=Zv+Dv+yc(Kv),em=jv+Kv,rm=Tc(Wv,tm),om=Jv+nm+yc(em),im=Mt+_t,sm=Tc(xn,sn),cm=yc(im),um=_n+cn+cm,fm=w*V,lm=Mc(w,r),hm=yc(fm),am=ct*p+hm,pm=y*k,dm=Mc(y,o),gm=yc(pm),vm=ht*d+gm,mm=im+Mt,bm=Tc(sm,xn),xm=yc(mm),_m=um+_n+xm,Im=im+_t,Nm=Tc(sm,sn),Sm=yc(Im),Em=um+cn+Sm,wm=nt*gt,Mm=Pc(E,Wt),Pm=yc(wm),Tm=A*xe+2*Pm,ym=wm*F,Cm=Pc(Mm,e),Om=Tm*H+Pm*a+2*yc(ym),Am=ot*Xt,zm=Pc(T,Wn),Bm=yc(Am),Ym=Y*we+2*Bm,Fm=Am*L,Vm=Pc(zm,i),km=Ym*Z+Bm*g+2*yc(Fm),Lm=X*im,Dm=Pc(c,sm),Xm=m*cm+W*um+2*yc(Lm),qm=vt*D,Qm=Pc(Jt,s),$m=Kt*j+_e*v+2*yc(qm),Gm=qt*q,Hm=Pc(Jn,u),Rm=Kn*J+Me*b+2*yc(Gm),Um=qm+Gm,Zm=Tc(Qm,Hm),jm=$m+Rm+yc(Um),Wm=nt*Q,Jm=Pc(E,f),Km=A*K+ut*x+yc(Wm),tb=ot*$,nb=Pc(T,l),eb=Y*tt+at*_+yc(tb),rb=Wm+tb,ob=Tc(Jm,nb),ib=Km+eb+yc(rb),sb=fm*mm,cb=Pc(lm,bm),ub=am*xm+hm*_m+2*yc(sb),fb=pm*Im,lb=Pc(dm,Nm),hb=vm*Sm+gm*Em+2*yc(fb),ab=sb+fb,pb=Tc(cb,lb),db=ub+hb+yc(ab),gb=3*(ym+Fm),vb=Mc(3,Tc(Cm,Vm)),mb=3*(Om+km)+2*yc(gb),bb=Lm+2*Um,xb=Tc(Dm,wc(Zm)),_b=Xm+2*jm+yc(bb),Ib=ab+gb,Nb=Tc(pb,vb),Sb=db+mb+yc(Ib),Eb=bb+rb,wb=Tc(xb,ob),Mb=_b+ib+yc(Eb),Pb=Ib+Eb,Tb=Tc(Nb,wb),yb=Sb+Mb+yc(Pb),Cb=w*F,Ob=Mc(w,e),Ab=ct*a+yc(Cb),zb=y*V,Bb=Mc(y,r),Yb=ht*p+yc(zb),Fb=Cb+zb,Vb=Tc(Ob,Bb),kb=Ab+Yb+yc(Fb),Lb=w*k,Db=Mc(w,o),Xb=ct*d+yc(Lb),qb=y*L,Qb=Mc(y,i),$b=ht*g+yc(qb),Gb=Lb+qb,Hb=Tc(Db,Qb),Rb=Xb+$b+yc(Gb),Ub=Fb+D,Zb=Tc(Vb,s),jb=kb+v+yc(Ub),Wb=Gb+q,Jb=Tc(Hb,u),Kb=Rb+b+yc(Wb),tx=gt*Ub,nx=Pc(Wt,Zb),ex=xe*jb+2*yc(tx),rx=Xt*Wb,ox=Pc(Wn,Jb),ix=we*Kb+2*yc(rx),sx=tx+rx,cx=Tc(nx,ox),ux=ex+ix+yc(sx),fx=xt*X,lx=Pc(on,c),hx=Ee*m+yc(fx),ax=sx+fx,px=Tc(cx,lx),dx=ux+hx+yc(ax),gx=w*Q,vx=Mc(w,f),mx=ct*x+yc(gx),bx=y*$,xx=Mc(y,l),_x=ht*_+yc(bx),Ix=gx+bx,Nx=Tc(vx,xx),Sx=mx+_x+yc(Ix),Ex=ax+Ix,wx=Tc(px,Nx),Mx=dx+Sx+yc(Ex),Px=Ex+G,Tx=Tc(wx,h),yx=Mx+I+yc(Px);return{coeffs:[lr,no,yi,nu,gl,xa,jd,rm,Tb,Tx],errBound:[Cc*hr,Cc*eo,Cc*Ci,Cc*eu,Cc*vl,Cc*_a,Cc*Wd,Cc*om,Cc*yb,Cc*yx]}}]],mf=[[Uc,Fu,nf],[cu,Qu,ff],[Ou,ju,function(t,n){const e=Vc(t);if(0===gf(e[0][0])&&0===gf(e[1][0]))return ff(gu(t),n);const[[r,o,i,[s]],[c,u,f,[l]]]=Vc(n);if(0===gf(r)&&0===gf(c))return ju(t,gu(n));const{vₓₓₓ:h,vₓₓᵧ:a,vₓᵧᵧ:p,vᵧᵧᵧ:d,vₓₓ:g,vₓᵧ:v,vᵧᵧ:m,vₓ:b,vᵧ:x,v:_}=Eu(e),I=lf(s,s),N=hf(s,i),S=hf(s,o),E=hf(s,r),w=lf(s,l),M=hf(s,f),P=hf(s,u),T=hf(s,c),y=af(i,i),C=af(i,o),O=af(i,r),A=hf(l,i),z=af(i,f),B=af(i,u),Y=af(i,c),F=af(o,f),V=af(o,o),k=af(o,r),L=hf(l,o),D=af(o,u),X=af(o,c),q=af(r,r),Q=hf(l,r),$=af(r,f),G=af(r,u),H=af(r,c),R=lf(l,l),U=hf(l,f),Z=hf(l,u),j=hf(l,c),W=af(f,f),J=af(f,u),K=af(c,c),tt=af(u,u),nt=af(u,c),et=af(f,c),rt=af(r,q),ot=af(r,K),it=af(c,q),st=af(c,K),ct=af(rt,h),ut=af(ot,p),ft=af(it,a),lt=af(st,d),ht=pf(ct,ut),at=pf(ft,lt),pt=pf(ht,at),dt=pf(df(X),G),gt=pf(df(G),X),vt=af(r,dt),mt=af(c,gt),bt=af(o,q),xt=af(u,K),_t=af(h,bt),It=af(d,xt),Nt=af(a,vt),St=af(p,mt),Et=pf(Nt,St),wt=hf(3,pf(_t,It)),Mt=pf(Et,wt),Pt=af(i,H),Tt=af(f,q),yt=af(o,nt),Ct=af(i,K),Ot=af(o,G),At=af(c,V),zt=af(r,et),Bt=af(u,G),Yt=pf(Pt,Ot),Ft=pf(Tt,At),Vt=pf(yt,zt),kt=pf(Ct,Bt),Lt=pf(O,V),Dt=pf(et,tt),Xt=pf(df(Yt),Ft),qt=pf(df(Vt),kt),Qt=af(a,Xt),$t=af(p,qt),Gt=af(r,Lt),Ht=af(c,Dt),Rt=af(h,Gt),Ut=af(d,Ht),Zt=pf(Qt,$t),jt=hf(3,pf(Rt,Ut)),Wt=pf(Zt,jt),Jt=pf(X,G),Kt=af(u,V),tn=df(af(i,Jt)),nn=pf(Kt,tn),en=df(pf(T,F)),rn=pf(en,Q),on=af(r,rn),sn=pf(nn,on),cn=af(o,tt),un=df(af(f,Jt)),fn=pf(cn,un),ln=df(pf(B,Q)),hn=pf(ln,T),an=af(c,hn),pn=pf(fn,an),dn=af(o,V),gn=pf(df(C),E),vn=af(hf(3,r),gn),mn=pf(dn,vn),bn=af(u,tt),xn=pf(df(J),j),_n=af(hf(3,c),xn),In=pf(bn,_n),Nn=af(a,sn),Sn=af(p,pn),En=pf(Nn,Sn),wn=af(h,mn),Mn=af(d,In),Pn=pf(wn,Mn),Tn=af(q,g),yn=af(K,m),Cn=pf(Tn,yn),On=af(H,v),An=pf(En,Pn),zn=pf(Cn,On),Bn=pf(An,zn),Yn=pf(D,$),Fn=pf(Y,D),Vn=hf(s,Jt),kn=hf(l,Jt),Ln=af(i,Yn),Dn=af(f,Fn),Xn=pf(df(Q),F),qn=pf(df(T),B),Qn=af(c,y),$n=af(r,W),Gn=af(o,Xn),Hn=af(u,qn),Rn=df(pf(Vn,Ln)),Un=df(pf(kn,Dn)),Zn=df(hf(s,k)),jn=df(hf(l,nt)),Wn=af(i,Lt),Jn=af(f,Dt),Kn=af(k,g),te=af(nt,m),ne=pf(Rn,Qn),ee=pf(Un,$n),re=pf(ne,Gn),oe=pf(ee,Hn),ie=pf(Zn,Wn),se=pf(jn,Jn),ce=df(pf(Kn,te)),ue=af(a,re),fe=af(p,oe),le=af(h,ie),he=af(d,se),ae=pf(ue,fe),pe=hf(3,pf(le,he)),de=af(v,Jt),ge=pf(ae,pe),ve=pf(de,ce),me=pf(ge,ve),be=pf(Y,Yn),xe=pf(df(O),V),_e=pf(df(et),tt),Ie=hf(2*s,be),Ne=hf(2*l,be),Se=pf(B,df(F)),Ee=pf(F,df(B)),we=hf(l,xe),Me=hf(s,_e),Pe=af(i,Se),Te=af(f,Ee),ye=hf(s,xe),Ce=hf(l,_e),Oe=af(o,y),Ae=af(u,W),ze=pf(Ie,we),Be=pf(Ne,Me),Ye=pf(ze,Pe),Fe=pf(Be,Te),Ve=pf(ye,Oe),ke=pf(Ce,Ae),Le=af(a,Ye),De=af(p,Fe),Xe=af(h,Ve),qe=af(d,ke),Qe=pf(Xe,qe),$e=pf(Le,De),Ge=pf($e,hf(3,Qe)),He=af(v,be),Re=af(g,xe),Ue=pf(He,Re),Ze=af(m,_e),je=pf(Ue,Ze),We=pf(Ge,je),Je=pf(B,F),Ke=pf(Q,T),tr=pf(C,E),nr=pf(J,j),er=pf(df(Je),Q),rr=pf(df(Je),T),or=pf(df(L),z),ir=pf(df(P),z),sr=pf(tr,C),cr=pf(nr,J),ur=af(lf(3,s),sr),fr=af(lf(3,l),cr),lr=af(i,y),hr=af(f,W),ar=af(g,tr),pr=af(m,nr),dr=pf(er,Ke),gr=pf(rr,Ke),vr=hf(s,dr),mr=hf(l,gr),br=af(i,or),xr=af(f,ir),_r=af(r,b),Ir=af(c,x),Nr=pf(vr,br),Sr=pf(mr,xr),Er=pf(ur,lr),wr=pf(fr,hr),Mr=pf(Ke,Je),Pr=df(pf(ar,pr)),Tr=af(a,Nr),yr=af(p,Sr),Cr=af(h,Er),Or=af(d,wr),Ar=af(v,Mr),zr=pf(Tr,yr),Br=pf(Cr,Or),Yr=pf(Ar,Pr),Fr=pf(_r,Ir),Vr=pf(zr,Br),kr=pf(Yr,Fr),Lr=pf(Vr,kr),Dr=pf(z,L),Xr=pf(z,P),qr=pf(df(Dr),P),Qr=pf(df(Xr),L),$r=hf(s,qr),Gr=hf(l,y),Hr=hf(l,Qr),Rr=hf(s,W),Ur=hf(s,y),Zr=af(o,I),jr=hf(l,W),Wr=af(u,R),Jr=pf($r,Gr),Kr=pf(Hr,Rr),to=pf(Ur,Zr),no=pf(jr,Wr),eo=af(h,to),ro=af(d,no),oo=hf(3,pf(eo,ro)),io=pf(Dr,P),so=pf(df(S),y),co=pf(df(Z),W),uo=af(a,Jr),fo=af(p,Kr),lo=af(v,io),ho=af(g,so),ao=af(m,co),po=af(o,b),go=af(u,x),vo=pf(po,go),mo=pf(uo,fo),bo=pf(oo,lo),xo=pf(ho,ao),_o=pf(mo,bo),Io=pf(xo,vo),No=pf(_o,Io),So=pf(A,M),Eo=hf(s,a),wo=hf(l,p),Mo=pf(So,A),Po=pf(So,M),To=af(i,I),yo=af(To,h),Co=af(f,R),Oo=af(Co,d),Ao=af(v,So),zo=af(N,g),Bo=af(U,m),Yo=pf(zo,Bo),Fo=af(i,b),Vo=af(f,x),ko=pf(Fo,Vo),Lo=af(Eo,Mo),Do=af(wo,Po),Xo=pf(Lo,Do),qo=hf(3,pf(yo,Oo)),Qo=pf(Ao,df(Yo)),$o=pf(Xo,qo),Go=pf(Qo,ko),Ho=pf($o,Go),Ro=hf(s,h),Uo=hf(l,a),Zo=pf(Ro,Uo),jo=hf(s,p),Wo=hf(l,d),Jo=pf(jo,Wo),Ko=pf(Zo,g),ti=pf(Jo,m),ni=af(I,Ko),ei=af(R,ti),ri=pf(ni,ei),oi=af(w,v),ii=pf(ri,oi),si=hf(s,b),ci=hf(l,x),ui=pf(si,ci),fi=pf(ii,ui);return[pt,Mt,Wt,Bn,me,We,Lr,No,Ho,pf(fi,_)]}]];function bf(t,n){const{coeffs:e,errBound:r}=vf[t.length-2][n.length-2](t,n);return{coeffs:e,errBound:r,getPExact:()=>mf[t.length-2][n.length-2](t,n)}}const xf=le,_f=oe,If=ie,Nf=pe,Sf=re,Ef=ie,wf=function(t,n,e,r){const o=t[0],i=t[1],s=n[0],c=n[1],u=jn(t,n),f=Math.abs(o+i),l=Math.abs(s+c),h=l-Wn*l-r;return h<=0?{est:u,err:Number.POSITIVE_INFINITY}:{est:u,err:(l*e+f*r)/h**2+9*Jn*Math.abs(f/l)}},Mf=re,Pf=le,Tf=te,yf=oe,Cf=ce,Of=function(t,n){return Qn(t,n)[1]>0?n:t},Af=function(t,n){return $n(t,n)[1]>0?t:n},zf=Number.EPSILON/2,Bf=zf*zf,Yf=Math.abs,Ff=Ef,Vf=[0,1],kf=Mf,Lf=yf,Df=Pf,Xf=Tf,qf=Cf,Qf=wf,$f=Of,Gf=Af,Hf=Ar(3);function Rf(t,n){return n[0][0]!==n[1][0]||n[0][1]!==n[1][1]?4===t.length?function([[t,n],[e,r],[o,i],[s,c]],[u,f]){const l=Ff(f,u),h=3*Bf*Yf(l[1]),a=Ff(Vf,u),p=3*Bf*Yf(a[1]),d=Qf(l,a,h,p);f=kf(d.est,d.err);const g=Ff(Vf,u),v=Df(u,u),m=Df(u,g),b=Df(g,g),x=Df(v,u),_=Df(v,g),I=Df(b,u),N=Df(b,g),S=Ff(Vf,f),E=Df(f,f),w=Df(f,S),M=Df(S,S),P=Df(E,f),T=Df(E,S),y=Df(M,f),C=Df(M,S),O=Yf(u[1]),A=Yf(g[1]),z=Yf(v[1]),B=Yf(m[1]),Y=Yf(b[1]),F=Yf(x[1]),V=Yf(_[1]),k=Yf(I[1]),L=Yf(N[1]),D=Yf(f[1]),X=Yf(S[1]),q=Yf(E[1]),Q=Yf(w[1]),$=Yf(M[1]),G=Yf(P[1]),H=Yf(T[1]),R=Yf(y[1]),U=Yf(C[1]);let Z=Yf(t),j=Yf(n),W=Yf(e),J=Yf(r),K=Yf(o),tt=Yf(i),nt=Yf(s),et=Yf(c);const rt=Lf(Xf(s,u),Xf(o,g)),ot=Lf(Lf(Xf(s,v),Xf(2*o,m)),Xf(e,b)),it=Lf(Lf(Xf(s,x),Xf(t,N)),Xf(3,Lf(Xf(o,_),Xf(e,I)))),st=Lf(Df(ot,f),Df(it,S)),ct=Lf(Lf(Df(rt,E),Df(it,M)),Df(qf(ot),w)),ut=Lf(Lf(Xf(s,P),Df(it,C)),Xf(3,Lf(Df(rt,T),Df(ot,y)))),ft=Yf(it[1]),lt=nt*O+K*A,ht=nt*z+2*K*B+W*Y;Z=nt*F+Z*L+3*(K*V+W*k),W=ht*D+ft*X,K=lt*q+ft*$+2*ht*Q,nt=nt*G+ft*U+3*(lt*H+ht*R),Z*=11*Bf,W*=15*Bf,K*=20*Bf,nt*=22*Bf;const at=Lf(Xf(c,u),Xf(i,g)),pt=Lf(Lf(Xf(c,v),Xf(2*i,m)),Xf(r,b)),dt=Lf(Lf(Xf(c,x),Xf(n,N)),Xf(3,Lf(Xf(i,_),Xf(r,I)))),gt=Lf(Df(pt,f),Df(dt,S)),vt=Lf(Lf(Df(at,E),Df(dt,M)),Df(qf(pt),w)),mt=Lf(Lf(Xf(c,P),Df(dt,C)),Xf(3,Lf(Df(at,T),Df(pt,y)))),bt=Yf(dt[1]),xt=et*O+tt*A,_t=et*z+2*tt*B+J*Y;j=et*F+j*L+3*(tt*V+J*k),J=_t*D+bt*X,tt=xt*q+bt*$+2*_t*Q,et=et*G+bt*U+3*(xt*H+_t*R),j*=11*Bf,J*=15*Bf,tt*=20*Bf,et*=22*Bf;const It=$f($f(kf(it,-Z),kf(st,-W)),$f(kf(ct,-K),kf(ut,-nt))),Nt=Gf(Gf(kf(it,+Z),kf(st,+W)),Gf(kf(ct,+K),kf(ut,+nt)));return[[It,$f($f(kf(dt,-j),kf(gt,-J)),$f(kf(vt,-tt),kf(mt,-et)))],[Nt,Gf(Gf(kf(dt,+j),kf(gt,+J)),Gf(kf(vt,+tt),kf(mt,+et)))]]}(t,n):3===t.length?function([[t,n],[e,r],[o,i]],[s,c]){const u=Ff(c,s),f=3*Bf*Yf(u[1]),l=Ff(Vf,s),h=3*Bf*Yf(l[1]),a=Qf(u,l,f,h);c=kf(a.est,a.err);const p=Ff(Vf,s),d=Df(s,s),g=Df(s,p),v=Df(p,p),m=Ff(Vf,c),b=Df(c,c),x=Df(c,m),_=Df(m,m),I=Yf(s[1]),N=Yf(p[1]),S=Yf(d[1]),E=Yf(g[1]),w=Yf(v[1]),M=Yf(c[1]),P=Yf(m[1]),T=Yf(b[1]),y=Yf(x[1]),C=Yf(_[1]);let O=Yf(t),A=Yf(n),z=Yf(e),B=Yf(r),Y=Yf(o),F=Yf(i);const V=Lf(Lf(Xf(o,d),Xf(2*e,g)),Xf(t,v)),k=Lf(Xf(o,s),Xf(e,p)),L=V,D=Lf(Df(c,k),Df(m,V)),X=Lf(Lf(Xf(o,b),Df(qf(x),k)),Df(_,V)),q=Y*S+2*z*E+O*w,Q=Y*I+z*N;O=q,z=M*Q+P*q,Y=T*o+2*y*Q+C*q,O*=7*Bf,z*=11*Bf,Y*=14*Bf;const $=Lf(Lf(Xf(i,d),Xf(2*r,g)),Xf(n,v)),G=Lf(Xf(i,s),Xf(r,p)),H=$,R=Lf(Df(c,G),Df(m,$)),U=Lf(Lf(Xf(i,b),Df(qf(x),G)),Df(_,$)),Z=F*S+2*B*E+A*w,j=F*I+B*N;A=Z,B=M*j+P*Z,F=T*i+2*y*j+C*Z,A*=7*Bf,B*=11*Bf,F*=14*Bf;const W=$f($f(kf(L,-O),kf(D,-z)),kf(X,-Y)),J=Gf(Gf(kf(L,+O),kf(D,+z)),kf(X,+Y));return[[W,$f($f(kf(H,-A),kf(R,-B)),kf(U,-F))],[J,Gf(Gf(kf(H,+A),kf(R,+B)),kf(U,+F))]]}(t,n):function([[t,n],[e,r]],[o,i]){const s=Ff(i,o),c=3*Bf*Yf(s[1]),u=Ff(Vf,o),f=3*Bf*Yf(u[1]),l=Qf(s,u,c,f);i=kf(l.est,l.err);const h=Ff(Vf,o),a=Ff(Vf,i),p=Yf(o[1]),d=Yf(h[1]),g=Yf(i[1]),v=Yf(a[1]);let m=Yf(t),b=Yf(n),x=Yf(e),_=Yf(r);const I=Lf(Xf(e,o),Xf(t,h)),N=Lf(Xf(e,i),Df(I,a));m=x*p+m*d,x=x*g+m*v,m*=3*zf,x*=7*zf;const S=Lf(Xf(r,o),Xf(n,h)),E=Lf(Xf(r,i),Df(S,a));b=_*p+b*d,_=_*g+b*v,b*=3*zf,_*=7*zf;const w=$f(kf(I,-m),kf(N,-x)),M=Gf(kf(I,+m),kf(N,+x));return[[w,$f(kf(S,-b),kf(E,-_))],[M,Gf(kf(S,+b),kf(E,+_))]]}(t,n):function(t,n){const e=t[0],r=t[t.length-1];if(0===n[0]&&0===n[1]){const t=[0,e[0]],n=[0,e[1]];return[[t,n],[t,n]]}if(0===n[0]&&1===n[1]){const t=[0,r[0]],n=[0,r[1]];return[[t,n],[t,n]]}const o=function(t,n){if(0===n[0]&&0===n[1])return t[0].map((t=>[t]));if(0===n[0]&&1===n[1])return t[t.length-1].map((t=>[t]));if(4===t.length){const[[e,r],[o,i],[s,c],[u,f]]=t,l=Sf(xf(Nf(o,e),n),e),h=Sf(xf(Nf(s,o),n),o),a=Sf(xf(Nf(u,s),n),s),p=_f(l,xf(If(h,l),n)),d=_f(h,xf(If(a,h),n)),g=_f(p,xf(If(d,p),n)),v=Sf(xf(Nf(i,r),n),r),m=Sf(xf(Nf(c,i),n),i),b=Sf(xf(Nf(f,c),n),c),x=_f(v,xf(If(m,v),n)),_=_f(m,xf(If(b,m),n));return[g,_f(x,xf(If(_,x),n))]}if(3===t.length){const[[e,r],[o,i],[s,c]]=t,u=_f([0,e],xf(Nf(o,e),n)),f=_f([0,o],xf(Nf(s,o),n)),l=_f(u,xf(If(f,u),n)),h=_f([0,r],xf(Nf(i,r),n)),a=_f([0,i],xf(Nf(c,i),n));return[l,_f(h,xf(If(a,h),n))]}if(2===t.length){const[[e,r],[o,i]]=t;return[Sf(xf(Nf(o,e),n),e),Sf(xf(Nf(i,r),n),r)]}if(1===t.length){const[n,e]=t[0];return[[0,n],[0,e]]}throw new Error("The given bezier curve must be of order <= 3.")}(t,n);let i;if(4===t.length)i=Tr(t,n).map((t=>16*Hf*t));else if(3===t.length)i=Tr(t,n).map((t=>10*Hf*t));else if(2===t.length)i=Tr(t,n).map((t=>4*Hf*t));else if(1===t.length)return[o,o];return[[kf(o[0],-i[0]),kf(o[1],-i[1])],[kf(o[0],+i[0]),kf(o[1],+i[1])]]}(t,n[0])}function Uf(t){return(n,e)=>{let[[r,o],[i,s]]=n,[[c,u],[f,l]]=e;return(o[1]>s[1]||o[1]===s[1]&&o[0]>s[0])&&([o,s]=[s,o]),(u[1]>l[1]||u[1]===l[1]&&u[0]>l[0])&&([u,l]=[l,u]),(r[1]>i[1]||r[1]===i[1]&&r[0]>i[0])&&([r,i]=[i,r]),(c[1]>f[1]||c[1]===f[1]&&c[0]>f[0])&&([c,f]=[f,c]),t?(r[1]c[1]||i[1]===c[1]&&i[0]>=c[0])&&(u[1]o[1]||l[1]===o[1]&&l[0]>=o[0]):(r[1]c[1]||i[1]===c[1]&&i[0]>c[0])&&(u[1]o[1]||l[1]===o[1]&&l[0]>o[0])}}function Zf(t){return[(t.x.box[0][0]+t.x.box[1][0])/2,(t.x.box[0][1]+t.x.box[1][1])/2]}function jf(t,n){const e=bf(t,n);if(void 0===e)return;const{coeffs:r,errBound:o,getPExact:i}=e,s=Nr(r,0,1,o,i);return 0!==s.length?{ris:s.map(Qi),getPExact:i}:void 0}function Wf(t){return{tS:H(t.tS),tE:H(t.tE),multiplicity:t.multiplicity}}function Jf(t,n){const e=jf(t,n);if(void 0===e)return[];const{getPExact:r}=e;let o,{ris:i}=e;const s=jf(n,t);if(void 0===s)return[];let{ris:c}=s;const{getPExact:u}=s;let f,l;l=1;let h,a=0;t:for(;aRf(t,[n.tS,n.tE])));for(let t=0;tRf(n,[t.tS,t.tE])));for(let t=0;tt.map(H)))}function tl(t,n){const e=t.xs,r=[],o=new Map;for(const t of e){const n=t.curve,e=o.get(n);e?e.push(t):o.set(n,[t])}const i=function(t){const[[n,e],[r,o]]=t.box,i=[[[r,e],[n,e]],[[n,e],[n,o]],[[n,o],[r,o]],[[r,o],[r,e]]];return(n,e,r)=>{const o=n.ps,s=e.slice();for(let t=0;tt.x.ri.tS-n.x.ri.tS));const c=[],u=[];let f,l;for(const n of s)void 0!==n.side?(!0===l&&u.push({dir:1,p:Zf(n),_x_:f,container:t,idx:++r,side:n.side,sideX:n.sideX}),l=!1):(!1===l&&(c.push({dir:-1,p:Zf(f),_x_:n,container:t,idx:++r,side:f.side,sideX:f.sideX}),n.in_=c[c.length-1]),l=!0),f=n;return{ins:c,outs:u,ioIdx:r}}}(t);for(const t of o){const[e,o]=t;let s,c;({ins:s,outs:c,ioIdx:n}=i(e,o,n)),r.push(...s),r.push(...c)}return{inOuts:r,ioIdx:n}}function nl(t){if(4===t.length){const[[n,e],[r,o],[i,s],[c,u]]=t;return[[3*(r-n),3*(o-e)],[3*(i-r),3*(s-o)],[3*(c-i),3*(u-s)]]}if(3===t.length){const[[n,e],[r,o],[i,s]]=t;return[[2*(r-n),2*(o-e)],[2*(i-r),2*(s-o)]]}if(2===t.length){const[[n,e],[r,o]]=t;return[[r-n,o-e]]}throw new Error("The given bezier curve must be of order 1, 2 or 3.")}function el(t,n){const e=t.xs;return 2===e.length&&1===e[0].x.kind&&1===e[1].x.kind&&e[0].x.ri.multiplicity%2==1&&e[1].x.ri.multiplicity%2==1?function(t,n){const e=t.xs,r=[],o=e[0],i=e[1],s=o.curve.ps,c=i.curve.ps,u=Mr(s,o.x.ri.tS),f=o.x.ri.tS,l=o.x.ri.tE,h=i.x.ri.tS,a=i.x.ri.tE;let p,d,g;p=4===s.length||3===s.length?Xr(nl(s),[f,l]):nl(s),d=4===c.length||3===c.length?Xr(nl(c),[h,a]):nl(c);for(let e=0;e0?(r.push({dir:-1,p:u,_x_:o,container:t}),r.push({dir:1,p:u,_x_:i,container:t}),r.push({dir:1,p:u,_x_:o,container:t}),r.push({dir:-1,p:u,_x_:i,container:t}),o.in_=r[0],i.in_=r[3]):(r.push({dir:-1,p:u,_x_:o,container:t}),r.push({dir:-1,p:u,_x_:i,container:t}),r.push({dir:1,p:u,_x_:o,container:t}),r.push({dir:1,p:u,_x_:i,container:t}),o.in_=r[0],i.in_=r[1]),{inOuts:r,ioIdx:n}}(t,n):tl(t,n)}const rl=-1,ol=1;function il(t,n,e,r){const o=[];for(const r of t)o.push({type:rl,item:r,x:n(r)}),o.push({type:ol,item:r,x:e(r)});o.sort(sl);const i=new Set,s=[];for(const t of o){const n=t.item;if(t.type===rl){for(const t of i.values()){const e=r(n,t);e&&s.push({a:n,b:t,u:e})}i.add(n)}else t.type===ol&&i.delete(t.item)}return s}function sl(t,n){const e=t.x-n.x;return 0!==e?e:t.type}const cl=oe,ul=K,fl=R,ll=y,hl=H,al=le,pl=Wt,dl=Math.abs,gl=Ar(3);const vl=Math.abs;const ml=Math.abs,bl=le,xl=oe,_l=K,Il=R,Nl=y,Sl=H,El=Wt,wl=Math.abs,Ml=Or(1),Pl=Ar(3);function Tl(t,n){const[e,r]=n,o=e.length,i=r.length,s=e[o-1],c=r[i-1],u=1===o&&1===i;{const{vₓₓ:n,vₓᵧ:e,vᵧᵧ:r,vₓ:o,vᵧ:i,v:f}=function(t){const[[n,e,r],[o,i,s]]=wi(t),c=n*i-e*o,u=n*s-r*o;return{vₓₓ:-o*o,vₓᵧ:2*n*o,vᵧᵧ:-n*n,vₓ:i*c-2*o*u,vᵧ:2*n*u-e*c,v:c*(e*s-r*i)-u*u}}(t),{vₓₓ_:l,vₓᵧ_:h,vᵧᵧ_:a,vₓ_:p,vᵧ_:d,v_:g}=function(t){const[n,e]=t[0],[[r,o],[i,s]]=function(t){const[[n,e],[r,o],[i,s]]=t,c=vl(n),u=vl(r),f=vl(i),l=vl(e),h=vl(o);return[[f+c+2*u,2*(u+c),0],[vl(s)+l+2*h,2*(h+l),0]]}(t),c=ml(n),u=ml(e),f=r*s+o*i,l=r*u+c*i;return{vₓₓ_:i*i,vₓᵧ_:2*r*i,vᵧᵧ_:r*r,vₓ_:s*f+2*i*l,vᵧ_:2*r*l+o*f,v_:f*(o*u+c*s)+l*l}}(t),v=u?0:1,m=wl(s),b=wl(c);if((v+12)*Ml*(l*(m*m)+h*(m*b)+a*(b*b)+(p*m+d*b)+g)o&&([e,o]=[o,e]),s>u&&([s,u]=[u,s]),r>i&&([r,i]=[i,r]),c>f&&([c,f]=[f,c]),e<=u&&o>=s&&c<=i&&f>=r)return[[Ql(e,s),Ql(r,c)],[ql(o,u),ql(i,f)]]}function Gl(t,n,e){if(void 0===e)return;if(0===e.length)return[];const r=Xl(n,t);if(void 0===r)return;if(0===r.length)return[];const o=r.map((n=>Xr(t,[n.tS,n.tE]))),i=e.map((t=>Xr(n,[t.tS,t.tE]))),s=[];for(let t=0;tl&&(l=e)}let h=Number.POSITIVE_INFINITY,a=Number.NEGATIVE_INFINITY;for(let t=0;ta&&(a=e)}if(e&&(l0)return!1;const p=u+3*o,d=e+3*s,g=p-d,v=Jl(3*o)+Jl(p)+(Jl(3*s)+Jl(d))+Jl(g);return!(Jl(g)-Wl*v>0)&&0===Zl(jl(Ul([c],Rl(3,r)),Ul([n],Rl(3,i))))&&0===Zl(jl(Ul([u],Rl(3,o)),Ul([e],Rl(3,s))))}const th=rt,nh=y,eh=pt,{abs:rh}=Math;function oh(t){const n=t[0][0],e=t[0][1];for(let r=1;r0)return!1;const l=e+s,h=l-2*o,a=rh(l)+rh(h);return!(rh(h)-a>0)&&0===nh(th(eh(n,i),[2*r]))&&0===nh(th(eh(e,s),[2*o]))}(t)&&(t=[t[0],t[2]]),2===t.length&&oh(t)&&(t=[t[0]]),t}const sh=Number.EPSILON,ch=sh/2;function uh(t,n){return n<0?t<1?t:1-ch:0===n?1:t>1?t:1+sh}function fh(t){return H(ht(t[0],t[1],2))}function lh(t){return y(t[0])*y(t[1])}function hh(t){return(n,e)=>{const r=Fc(n),o=Fc(e),i=Fc(n.slice().reverse()),s=Fc(e.slice().reverse()),c=t(r,o),u=t(i,o),f=t(r,s),l=t(i,s),h=-lh(u),a=-lh(l),p=fh(c),d=fh(f);return[uh(p,h),uh(d,a)]}}const ah=hh((function(t,n){const e=0===y(t[0][0])?1:0;return function(t,n){const[e,r]=t,[,o]=n;return[rt(o,r),e]}(t[e],n[e])}));function ph(t,n){return yt(sn(t[0],n[1]),sn(t[1],n[0]))*y(t[1])*y(n[1])}const dh=L,gh=ot,vh=0n;function mh(t){let n=-1024;for(let e=0;en&&(n=o)}}return 0===n?t.map((t=>t.map((t=>BigInt(t))))):n>0?t.map((t=>t.map((t=>{if(0===t)return vh;const e=-dh(t)+gh(t)-1;return BigInt(t*2**e)*2n**BigInt(n-e)})))):t.map((t=>t.map((t=>BigInt(t*2**n)))))}function bh(t,n){if(n=n<0n?-n:n,0n===(t=t<0n?-t:t))return n;if(0n===n)return t;for(;0n!==n;){const e=n;n=t%n,t=e}return t}const xh=BigInt(2**53);function _h(t){if(0n===t)return[0];const n=[];let e=0,r=t;for(;0n!==r;){r=t/xh;const o=t%xh;n.push(Number(o)*2**(53*e)),t=r,e++}return X(n)}const{round:Ih,sqrt:Nh}=Math;function Sh(t){if(t<=1n){if(t<0n)throw new Error("square root of negative numbers are not allowed");return t}let n=BigInt(Ih(Nh(Number(t))));for(;;){const e=n+t/n>>1n;if(e===n)return n;n=e}}function Eh(t){return t<0n?-t:t}function wh(t){let n=0n;for(let e=0;e0n?1n:e<0n?-1n:0n;var e;if((t=Eh(t))<=1n)return n*t;let r=BigInt(yh(Ch(Number(t))));for(;;){const e=(2n*r+t/(r*r))/3n;if(e===r)return n*r;r=e}}function Ah(t){return sn(t,t)}const zh=hh((function(t,n){const e=0===y(t[0][0])?1:0;return function(t,n){const[e,r]=t,[o,i]=n,s=function(t){const[n,e]=mh(t).map(wh),r=bh(n,e);return[_h(Oh(n/r)),_h(Oh(e/r))]}([o,e]),c=Ah(s[0]);return[rt(sn(i,Ah(s[1])),sn(r,c)),sn(j(3,e),c)]}(t[e],n[e])})),{EPSILON:Bh}=Number,Yh=Bh/2+Bh**2/2;function Fh(t){return t>0?t-t*Yh:t+t*Yh}const{EPSILON:Vh}=Number,kh=Vh/2+Vh**2/2;function Lh(t){return t>0?t+t*kh:t-t*kh}function Dh(t){if(0===t||1===t)return[t,t];const n=Fh(Fh(t)),e=function(t){return Lh(Lh(t))}(t);return[n,e]}function Xh(t,n,e,r){const o=t.ps,i=n.ps,s=[];let c=Xl(o,i);if(void 0===c){const r=2**(e-47),c=function(t,n,e=!1){e||(t=ih(t),n=ih(n));const r=[,,ah,Th,zh],[o,i]=r[t.length](t,n),[s,c]=r[t.length](n,t),u=[{tA:o,tB:0,bez:"B",start:!0},{tA:i,tB:1,bez:"B",start:!1},{tA:0,tB:s,bez:"A",start:!0},{tA:1,tB:c,bez:"A",start:!1}].sort(((t,n)=>t.tA-n.tA));if(u[1].tA===u[2].tA){const n=u[1],e=n.tA,r=n.tB,o=Xr(t,[e,e]);return[{p:o[0],kind:4,box:o,t1:e,ri1:{tS:e,tE:e,multiplicity:1},t2:r,ri2:{tS:r,tE:r,multiplicity:1}}]}if(u[0].bez===u[1].bez)return[];const f=u[1],l=u[2],[h,a]=Dh(f.tA),[p,d]=Dh(f.tB),[g,v]=Dh(l.tA),[m,b]=Dh(l.tB),x=Xr(t,[h,a]),_=Xr(n,[p,d]),I=Xr(t,[g,v]),N=Xr(n,[m,b]),S=$l(x,_),E=$l(I,N),w={tS:h,tE:a,multiplicity:1},M={tS:p,tE:d,multiplicity:1},P={tS:g,tE:v,multiplicity:1},T={tS:m,tE:b,multiplicity:1};return[{p:Yo(S),kind:5,box:S,t1:Bo(w),ri1:w,t2:Bo(M),ri2:M},{p:Yo(E),kind:5,box:E,t1:Bo(P),ri1:P,t2:Bo(T),ri2:T}]}(o,i);for(const e of c){const i=Mr(o,e.ri1.tS),c=[[i[0]-r,i[1]-r],[i[0]+r,i[1]+r]],u={x:{ri:e.ri1,kind:5,box:c},curve:t},f={x:{ri:e.ri2,kind:5,box:c},curve:n};s.push([u,f])}return s}if(r&&(c=c.filter((t=>t.tS>0))),0===c.length)return[];const u=Gl(o,i,c);if(void 0===u||0===u.length)return[];for(const e of u){const r={x:e[0],curve:t},o={x:e[1],curve:n};s.push([r,o])}return s}const qh=Mr,Qh=Tr,$h=Or(1);function Gh(t,n,e){const r=n.ps;if(0===t)return r[0],{x:{ri:{tS:t,tE:t,multiplicity:1},box:[r[0],r[0]],kind:e},curve:n};if(1===t){const o=r[r.length-1];return{x:{ri:{tS:t,tE:t,multiplicity:1},box:[o,o],kind:e},curve:n}}const{p:o,pE:i}=function(t,n){const e=qh(t,n),r=Qh(t,[0,n]);if(4===t.length)return{p:e,pE:r.map((t=>9*$h*t))};if(3===t.length)return{p:e,pE:r.map((t=>6*$h*t))};if(2===t.length)return{p:e,pE:r.map((t=>3*$h*t))};if(1===t.length)return{p:t[0],pE:[0,0]};throw new Error("The given bezier curve must be of order <= 3.")}(r,t);return{x:{ri:{tS:t,tE:t,multiplicity:1},box:[[o[0]-i[0],o[1]-i[1]],[o[0]+i[0],o[1]+i[1]]],kind:e},curve:n}}function Hh(t,n){if(n.next===t){if(t.next===n)return;[t,n]=[n,t]}const e=t.ps,r=n.ps;if(function(t,n){if(4===t.length)return Dl(t,n);if(3===t.length)return Tl(t,n);if(2===t.length)return function(t,n){const[e,r]=n,o=e.length,i=r.length,s=e[o-1],c=r[i-1],u=1===o&&1===i;{const{coeffs:{vₓ:n,vᵧ:o,v:i},errorBound:{v_:u}}=hs(t),f=pl(e),l=pl(r),h=dl(s),a=dl(c),p=dl(n[1]),d=dl(o[1]),g=h/3,v=a/3,m=n[1]*s,b=al(f,n),x=p*g+2*dl(m),_=o[1]*c,I=al(l,o),N=d*v+2*dl(_),S=cl(b,I),E=x+N+dl(S[1]),w=cl(S,i),M=E+u+dl(w[1]);if(gl*M[t])))){const i=Gl(e,r,[(o=1,{tS:o,tE:o,multiplicity:1})]);if(void 0===i||0===i.length)return;return[[{x:i[0][0],curve:t},Gh(1,n,1)]]}var o}const Rh=Math.abs;const Uh=Math.abs,Zh=Or(1),jh=K,Wh=R,Jh=rt,Kh=rt,ta=K,na=j,ea=pe,ra=ge,oa=ae,ia=oe,sa=ce,ca=he,ua=R,fa=at,la=2*Number.EPSILON,ha=Math.abs,aa=Or(1);function pa(t,n=!0){if(t.length<4)return[];const{coeffs:[e,r,o],errBound:[i,s,c]}=function(t){const{coeffs:[[n,e,r],[o,i,s]],errorBound:[[c,u],[f,l]]}=function(t){const[[n,e],[r,o],[i,s],[c,u]]=t,f=c-n,l=r-i,h=f+3*l,a=i+n,p=a-2*r,d=r-n,g=u-e,v=o-s,m=g+3*v,b=s+e,x=b-2*o,_=o-e;return{coeffs:[[h,3*p,3*d,n],[m,3*x,3*_,e]],errorBound:[[Rh(f)+6*Rh(l)+Rh(h),6*(Rh(a)+Rh(p)),6*Rh(d),0],[Rh(g)+6*Rh(v)+Rh(m),6*(Rh(b)+Rh(x)),6*Rh(_),0]]}}(t),h=Uh(n),a=Uh(e),p=Uh(r),d=Uh(o),g=Uh(i),v=Uh(s),m=e*o,b=n*i,x=n*s,_=r*o,I=e*s,N=r*i,S=u*d+a*f+Uh(m),E=c*g+h*l+Uh(b),w=c*v+Uh(x),M=p*f+Uh(_),P=u*v+Uh(I),T=p*l+Uh(N),y=m-b,C=Uh(y),O=S+E+C,A=_-x,z=Uh(A),B=M+w+z,Y=I-N,F=Uh(Y),V=P+T+F,k=y*y,L=y*A,D=Y*y,X=A*A,q=D+X;return{coeffs:[k,L,q],errBound:[2*O*C+Uh(k),O*z+C*B+Uh(L),V*C+F*O+Uh(D)+(2*z*B+Uh(X))+Uh(q)].map((t=>Zh*t))}}(t);if(ha(e)<=i){const[[n,e],[r,o],[i,s],[c,u]]=t,f=ua(ea(c,n),na(3,ea(r,i))),l=fa(ra(i,n),-2*r),h=ua(ea(u,e),na(3,ea(o,s))),a=fa(ra(s,e),-2*o);if(0===yt(ta(l,h),ta(f,a)))return[]}const u=r*r,f=4*e*o,l=u-f,h=2*s*ha(r)+aa*u+(4*(i*ha(o)+ha(e)*c)+aa*ha(f))+aa*ha(l);if(l<-h)return[];if(l>h){const{est:t,err:u}=ee(l,h);let f;f=r>=0?-r-t:-r+t;const a=s+u+aa*ha(f),{est:p,err:d}=ve(f,2*e,a,2*i),{est:g,err:v}=ve(2*o,f,2*c,a);if(n){if(p+d<0||p-d>1||g+v<0||g-v>1)return[]}else if((p+d<0||p-d>1)&&(g+v<0||g-v>1))return[]}let[a,p,d]=function(t){const[[n,e,r],[o,i,s]]=Vc(t),c=jh(e,o),u=jh(n,i),f=jh(n,s),l=jh(r,o),h=jh(e,s),a=jh(r,i),p=Jh(c,u),d=Jh(l,f),g=Jh(h,a),v=jh(p,p),m=jh(p,d),b=jh(p,g),x=jh(d,d);return[v,m,Wh(b,x)]}(t);const g=Kh(ta(p,p),na(4,ta(a,d))),v=y(g);if(v<0)return[];if(v>0){const t=ne(Wt(g));let e;a=Wt(a),p=Wt(p),d=Wt(d),e=y(p)>=0?oa(ia(p,t)):ia(oa(p),t);let r=H(ca(e,sa(a))),o=H(ca(sa(d),e));if(n){if(r<-la||r>1+la||o<-la||o>1+la)return[]}else if((r<-la||r>1+la)&&(o<-la||o>1+la))return[];return[r,o]=r=0-la&&r<=1+la?o>=0-la&&o<=1+la?[r,o]:[r]:o>=0-la&&o<=1+la?[o]:[]}const m=zt(a);if(y(p)*y(m)<0)return[];if(yt(Ot(p),Ot(m))>0)return[];const b=Wt(p),x=Wt(m),_=ca(b,x),I=_[1]+_[0];return[I,I]}const da=Number.EPSILON;function ga(t){if(4===t.length){const[[n,e],[r,o],[i,s],[c,u]]=t;return[[6*(c-n+3*(r-i)),6*(i+n-2*r)],[6*(u-e+3*(o-s)),6*(s+e-2*o)]]}if(3===t.length){const[[n,e],[r,o],[i,s]]=t;return[[2*(i-2*r+n)],[2*(s-2*o+e)]]}if(t.length<=2)return[[0],[0]];throw new Error("The given bezier curve must be of order <= 3.")}const{orient2d:va}=un;function ma(t){if(4===t.length)return 0===va(t[0],t[1],t[2])&&0===va(t[1],t[2],t[3])&&0===va(t[0],t[2],t[3]);if(3===t.length)return 0===va(t[0],t[1],t[2]);if(t.length<=2)return!0;throw new Error("The given bezier curve must be of order <= 3.")}function ba(t){if(ma(t))return{minima:[],maxima:[],inflections:[]};if(4===t.length&&Kl(t)&&(t=gu(t)),3===t.length){const n=function(t){const[[n,e],[r,o],[i,s]]=t,c=i-r,u=c-(r-n),f=s-o,l=f-(o-e);return[u*u+l*l,-(n*(u-r)-r*(c-r)+e*(l-o)-o*(f-o))]}(t);return{minima:[],maxima:Ni(n,0,1),inflections:[]}}const n=function(t){const[[n,e,r],[o,i,s]]=wr(t),[[c,u],[f,l]]=ga(t),[h,a]=function(t){if(4===t.length){const[[n,e],[r,o],[i,s],[c,u]]=t;return[6*(c-n+3*(r-i)),6*(u-e+3*(o-s))]}if(t.length<=3)return[0,0];throw new Error("The given bezier curve must be of order <= 3.")}(t),p=h*i,d=a*e,g=u*s,v=u*i,m=f*f,b=c*s,x=l*r,_=l*e,I=f*r,N=r*e,S=r*n,E=r*o,w=e*e,M=e*n,P=e*i,T=n*s,y=n*o,C=n*n,O=s*i,A=s*o,z=i*i,B=i*o,Y=o*o,F=h*s-a*r,V=u*r+l*s,k=g-x,L=r*r+s*s,D=P+T,X=A+z,q=S+w,Q=e*o+n*i,$=C-Y,G=M-B,H=N-O,R=r*i+e*s,U=A+X,Z=S+q,j=E+D,W=P+D,J=Z-U,K=D+T,tt=E+P+T,nt=2*_+I;return{inflectionPoly:[c*o-f*n,u*o+c*i-l*n-f*e,v+b-_-I,g-x],otherExtremaPoly:[C*(p-3*d)+Y*(3*p-d)+2*(y*(h*e-a*i+3*(l*f-u*c))+3*c*f*G)+3*(Q*(m-c*c)+$*(u*f+l*c)),h*(o*(Z+3*X)+n*W)-a*(r*(3*C+Y)+e*(3*M+2*B)+n*U)+3*(u*(l*$-u*y+2*(f*G-c*Q))+c*(2*l*G+f*(2*(S-A)+(w-z))-c*tt)+l*(l*y+2*f*Q)+m*j),h*(2*r*Q+e*K+i*(4*A+U))-a*(2*r*(3*M+B)+e*(w+2*A)+i*K)+3*(u*(2*(l*G-c*tt)+f*J-u*Q)+c*(2*f*H-c*R)+l*(l*Q+2*f*j+c*J)+m*R),h*(r*(E+2*D)+s*(w+3*X))-a*(r*(3*q+U)+s*W)+3*(u*(l*J-u*j+2*(f*H-c*R))+c*(r*(nt-c*s)-s*(2*l*i+f*s))+l*(l*D+r*(2*f*i+l*o))+f*s*nt),L*(p-d)+2*(N+O)*F-3*(V*(v+b-_-I)+(u*e+c*r+l*i+f*s)*k),F*L-3*V*k]}}(t),e=n.inflectionPoly,r=n.otherExtremaPoly,o=Ni(r,0,1),i=hi(r),s=[],c=[];for(let t=0;t=0?s.push(n):c.push(n)}return{minima:s,maxima:c,inflections:Ni(e,0,1)}}function xa(t,n){const[e,r]=wr(t),[o,i]=ga(t),s=E(e,n),c=E(r,n),u=E(o,n);return(s*E(i,n)-c*u)/Math.sqrt((s*s+c*c)**3)}const{abs:_a}=Math,Ia=P((function(t){const n=t.curves;let e=qr(n[0].ps).minY,r=n[0];for(let o=1;oe.ts[0])&&(e=n,r=t.curves[o])}return{curve:r,y:e}}));function Na(t){const{curve:n,y:e}=Ia(t),r=e.ts;return r[0]<=0?[Gh(0,n,0),Gh(1,n.prev,0)]:r[1]>=1?[Gh(1,n,0),Gh(0,n.next,0)]:[{x:{ri:{tS:r[0],tE:r[1],multiplicity:1},kind:0,box:e.box},curve:n},{x:{ri:{tS:r[0],tE:r[1],multiplicity:1},kind:0,box:e.box},curve:n}]}function Sa(t,n,e){const r=e-(n-Math.floor(Math.log2(Math.abs(t))))+1;return r<=0?0:e>=53?t:q(t,r)}const{abs:Ea}=Math;function wa(t,n){let e=t.side-n.side;if(0!==e)return e;const r=t.sideX,o=n.sideX;e=r.ri.tS-o.ri.tS;const i=8*Number.EPSILON;return Ea(e)>=i?e:(r.compensated||(r.compensated=1,r.riExp=Ji(r.ri,r.getPExact())[0]),o.compensated||(o.compensated=1,o.riExp=Ji(o.ri,o.getPExact())[0]),e=yt(r.riExp.tS,o.riExp.tS),0!==e?e:(e=n.dir-t.dir,0!==e?e:1===t.dir?t.idx-n.idx:n.idx-t.idx))}function Ma(t,n,e){const r=function(t,n){const e=[];for(const n of t)for(const t of n.curves)e.push(t);const r=il(e,(t=>Pi(t.ps)[0][0]),(t=>Pi(t.ps)[1][0]),function(t){return(n,e)=>{const r=n.ps,o=e.ps;if(2===r.length&&2===o.length)return function(t,n,e){let r=t.ps,o=n.ps;const i=Pi(r),s=Pi(o);if(t.next!==n&&n.next!==t){if(Yi(!0,i,s)){const r=Xh(t,n,e,!1);return r.length?r:void 0}return}if(n.next===t&&([t,n]=[n,t],[r,o]=[o,r]),0!==en(r[0],r[1],o[1]))return;if(!Yi(!1,i,s))return;let c;return c=p(r[0],r[1])>p(o[0],o[1])?[Bo(Qo(r,o[1])[0].ri),1]:[0,Bo(Qo(o,r[0])[0].ri)],[[Gh(1,t,5),Gh(0,n,5)],[Gh(c[0],t,5),Gh(c[1],n,5)]]}(n,e,t);if(n.next===e||e.next===n)return Yi(!1,Pi(r),Pi(o))&&Hl(Ur(r),Ur(o),!1)?e.next===n?Xh(e,n,t,!0):Xh(n,e,t,!0):Hh(n,e);let i=Yi(!0,Pi(r),Pi(o));return i?(i=Hl(Ur(r),Ur(o),!0),i?Xh(n,e,t,!1):void 0):void 0}}(n)),o=[];for(const t of r)for(const n of t.u)o.push(n);return o}(t,e),o=function(t){const n=[];for(const e of t)for(const t of e.curves){const e=t.ps,r=pa(e);if(0===r.length)continue;const o=r[0]===r[1]?3:2,i=r[0]-da,s=r[0]+da,c=r[1]-da,u=r[1]+da,f=Xr(e,[i,s]),l=Xr(e,[c,u]);n.push([{x:{ri:{tS:i,tE:s,multiplicity:1},box:f,kind:o},curve:t},{x:{ri:{tS:c,tE:u,multiplicity:1},box:l,kind:o},curve:t}])}return n}(t),i=function(t){const n=[];for(const e of t)for(const t of e.curves)n.push([Gh(1,t,4),Gh(0,t.next,4)]);return n}(t),{extremes:s,xs:c}=function(t){const n=new Map,e=[];for(const r of t){const t=Na(r);e.push(t),n.set(r,t)}return{extremes:n,xs:e}}(t),u=function(t,n){const e=[];for(const r of n)for(const n of r.curves){const r=n.ps,o=ba(r),{minima:i,maxima:s}=o,c=[0,1,...i,...s];for(let o of c)_a(xa(r,o))>1e7*2**-t&&e.push([Gh(o,n,7),Gh(o,n,7)])}return e}(e,t);let f=[...r,...o,...i,...c,...u];if("undefined"!=typeof _debug_){for(const t of r)_debug_.generated.elems.intersection.push(...t);for(const t of o)_debug_.generated.elems.intersection.push(...t);for(const t of i)_debug_.generated.elems.intersection.push(...t);for(const t of c)_debug_.generated.elems.intersection.push(...t);for(const t of u)_debug_.generated.elems.intersection.push(...t)}let l=f.map((t=>({xs:t,box:[[t[0].x.box[0][0]-n,t[0].x.box[0][1]-n],[t[0].x.box[1][0]+n,t[0].x.box[1][1]+n]],inOuts:void 0})));for(;;){const t=il(l,Pa,Ta,Fi);if(!t.length)break;const n=new Map;Vi(n,t);const e=Di(n),r=Xi(l,e);l=[...qi(e),...r]}l=function(t){return t.filter((t=>{const n=t.xs;if(2===t.xs.length){const t=n[0];if(1===t.x.kind&&t.x.ri.multiplicity%2==0)return!1}for(const n of t.xs)if(4!==n.x.kind)return!0;return!1}))}(l),l=function(t,n,e){const r=Math.log2(e)-3;return t.map((t=>{const e=t.box.map((t=>t.map((t=>Sa(t,n,n-r)))));return{...t,box:e}}))}(l,e,n),"undefined"!=typeof _debug_&&(_debug_.generated.elems.container=l);let h=0;for(const t of l){for(const n of t.xs)n.container=t;let n;({inOuts:n,ioIdx:h}=el(t,h)),t.inOuts=n}f=f.filter((t=>void 0!==t[0].container)),function(t){const n=new Map;for(const e of t)for(const t of e){const e=t.curve.loop,r=n.get(e)||[];r.length||n.set(e,r),r.push(t)}for(const t of n){const n=t[1];if(!n||!n.length)continue;n.sort(((t,n)=>{let e=t.curve.idx-n.curve.idx;return 0!==e?e:(e=t.x.ri.tS-n.x.ri.tS,0!==e?e:void 0!==t.in_?-1:1)}));const e=n.length;for(let t=0;tt[0])),e=t.map((t=>t[1]));return!(Aa(n)&&Aa(e))}function Aa(t){return function(t){for(let n=1;nt[n])return!1;return!0}(t)||function(t){for(let n=1;n[Sa(e[0],t,n),Sa(e[1],t,n)]}(t,n):La;return t=>{const n=[];for(let e=0;eo(t))),Oa(i)&&(i=[i[0],i[i.length-1]]),i=Fa(i,r,o),void 0!==i&&n.push(i)}const e=n.length;if(!e)return[];const i=n[e-1];return i[i.length-1]=n[0][0],n}}(e,n,o);let s=t.slice();return s=r?function(t,n,e,r=.02){const o=[];for(const i of t){const t=[];for(const o of i){const i=o.map((t=>t.map((t=>{let o,i=0,s=0,c=0;for(;!(++s>10);){i=(t+Math.random())*(1+(Math.random()-.7)*r),i=Sa(i,e,n);const s=ot(i);s>c&&(c=s,o=i)}return o}))));t.push(i)}o.push(t)}return o}(s,n,e,1):s,s=s.map(i),s=s.filter((t=>t.length>0)),s}const Xa=P((t=>{let n=0;for(const e of t)for(const t of e)for(const e of t)for(const t of e){const e=Math.abs(t);e>n&&(n=e)}return n}));function qa(t,n){const e=[],r=t.length-1;for(let n=0;n0?-o:0,c=Math.max(e,r),u=[];for(let e=0;e!!vn(t)&&gn(t).isDull));function Ua(t,n){return vn(n)&&Ra(n)?-b(Ha(gn(n).tangents[0]),N(d(n.p,t.center))):0}const Za=function(t,n,e){return 0===n?1===e?t:function(t,n){const e=t[0],r=t[1],o=t[2],i=t[3],s=e[0],c=e[1],u=r[0],f=r[1],l=o[0],h=o[1],a=s-n*(s-u),p=u-n*(u-l),d=a-n*(a-p),g=c-n*(c-f),v=f-n*(f-h),m=g-n*(g-v);return[[s,c],[a,g],[d,m],[d-n*(d-(p-n*(p-(l-n*(l-i[0]))))),m-n*(m-(v-n*(v-(h-n*(h-i[1])))))]]}(t,e):1===e?function(t,n){const e=t[0],r=t[1],o=t[2],i=t[3],s=e[0],c=e[1],u=r[0],f=r[1],l=o[0],h=o[1],a=i[0],p=i[1],d=s-n*(s-u),g=u-n*(u-l),v=l-n*(l-a),m=d-n*(d-g),b=g-n*(g-v),x=c-n*(c-f),_=f-n*(f-h),I=h-n*(h-p),N=x-n*(x-_),S=_-n*(_-I);return[[m-n*(m-b),N-n*(N-S)],[b,S],[v,I],[a,p]]}(t,n):function(t,n,e){const r=t[0],o=t[1],i=t[2],s=t[3],c=r[0],u=r[1],f=o[0],l=o[1],h=i[0],a=i[1],p=n*n,d=n*p,g=e*e,v=e*g,m=n*e,b=c-f,x=h-f,_=b+x,I=n*b,N=e*b,S=s[0]-c-3*x,E=u-l,w=a-l,M=E+w,P=n*E,T=e*E,y=s[1]-u-3*w;return[[d*S+(3*n*(n*_-b)+c),d*y+(3*n*(n*M-E)+u)],[m*(n*S+2*_)+(p*_+c-(N+2*I)),m*(n*y+2*M)+(p*M+u-(T+2*P))],[m*(e*S+2*_)+(g*_+c-(2*N+I)),m*(e*y+2*M)+(g*M+u-(2*T+P))],[v*S+(3*e*(e*_-b)+c),v*y+(3*e*(e*M-E)+u)]]}(t,n,e)},ja=function(t,n,e){return 0===n?1===e?t:function(t,n){const e=t[0],r=t[1],o=t[2],i=e[0],s=e[1],c=r[0],u=r[1],f=n*n,l=i-c,h=s-u;return[[i,s],[-n*l+i,-n*h+s],[f*(l+(o[0]-c))-(2*n*l-i),f*(h+(o[1]-u))-(2*n*h-s)]]}(t,e):1===e?function(t,n){const e=t[0],r=t[1],o=t[2],i=e[0],s=e[1],c=r[0],u=r[1],f=o[0],l=o[1],h=n*n,a=i-c,p=f-c,d=s-u,g=l-u;return[[h*(a+p)-(2*n*a-i),h*(d+g)-(2*n*d-s)],[n*p+c,n*g+u],[f,l]]}(t,n):function(t,n,e){const r=t[0],o=t[1],i=t[2],s=r[0],c=r[1],u=o[0],f=o[1],l=n*n,h=e*e,a=n*e,p=s-u,d=p+(i[0]-u),g=c-f,v=g+(i[1]-f);return[[l*d-(2*n*p-s),l*v-(2*n*g-c)],[a*d-(p*(e+n)-s),a*v-(g*(e+n)-c)],[h*d-(2*e*p-s),h*v-(2*e*g-c)]]}(t,n,e)},Wa=function(t,n,e){return 0===n?1===e?t:function(t,n){const e=t[0],r=t[1],o=e[0],i=e[1];return[[o,i],[n*(r[0]-o)+o,n*(r[1]-i)+i]]}(t,e):1===e?function(t,n){const e=t[0],r=t[1],o=e[0],i=e[1],s=r[0],c=r[1];return[[n*(s-o)+o,n*(c-i)+i],[s,c]]}(t,n):function(t,n,e){const r=t[0],o=t[1],i=r[0],s=r[1],c=o[0],u=o[1];return[[n*(c-i)+i,n*(u-s)+s],[e*(c-i)+i,e*(u-s)+s]]}(t,n,e)};function Ja(t,n,e){if(4===t.length)return Za(t,n,e);if(3===t.length)return ja(t,n,e);if(2===t.length)return Wa(t,n,e);if(1===t.length)return t;throw new Error("The given bezier curve must be of order <= 3.")}function Ka(t){return t[0]*t[0]+t[1]*t[1]}function tp(t,n,e){return t[0]*(n[1]*e[2]-n[2]*e[1])-t[1]*(n[0]*e[2]-n[2]*e[0])+t[2]*(n[0]*e[1]-n[1]*e[0])}function np(t){const n=t[0],e=t[1],r=t[2],o=Ka,i=.5*tp([o(n),n[1],1],[o(e),e[1],1],[o(r),r[1],1]),s=.5*tp([n[0],o(n),1],[e[0],o(e),1],[r[0],o(r),1]),c=tp([n[0],n[1],1],[e[0],e[1],1],[r[0],r[1],1]);return[i/c,s/c]}function ep(t){return Math.sqrt(t[0]*t[0]+t[1]*t[1])}const rp=pe,op=oe,ip=te,sp=le,cp=ce,up=ue,fp=ie;function lp(t,n){const e=t[0],r=t[1],o=t[2],i=t[3],s=e[0],c=e[1],u=r[0],f=r[1],l=o[0],h=o[1],a=i[0],p=i[1],[d,g]=n,v=rp(s,d),m=rp(u,d),b=rp(l,d),x=rp(a,d),_=rp(c,g),I=rp(f,g),N=rp(h,g),S=rp(p,g),E=sp(v,v),w=ip(6,sp(v,m)),M=ip(6,sp(v,b)),P=cp(sp(v,x)),T=ip(9,sp(m,m)),y=ip(18,sp(m,b)),C=ip(6,sp(m,x)),O=ip(9,sp(b,b)),A=ip(6,sp(b,x)),z=sp(x,x),B=sp(_,_),Y=ip(6,sp(_,I)),F=ip(6,sp(_,N)),V=cp(sp(_,S)),k=ip(9,sp(I,I)),L=ip(18,sp(I,N)),D=ip(6,sp(I,S)),X=ip(9,sp(N,N)),q=ip(6,sp(N,S)),Q=sp(S,S),$=op(C,O),G=op(P,y),H=op(M,T),R=op(D,X),U=op(V,L),Z=op(F,k);return[ip(6,op(op(op(op(fp(z,A),fp(E,w)),$),fp(H,G)),op(op(op(fp(Q,q),fp(B,Y)),R),fp(Z,U)))),ip(5,op(fp(op(op(A,ip(5,w)),ip(3,G)),cp(op(op($,cp(H)),ip(3,E)))),fp(op(op(q,ip(5,Y)),ip(3,U)),cp(op(op(R,cp(Z)),ip(3,B)))))),up(op(fp(fp($,ip(3,fp(G,cp(H)))),ip(5,fp(cp(w),ip(3,E)))),fp(fp(R,ip(3,fp(U,cp(Z)))),ip(5,fp(cp(Y),ip(3,B)))))),ip(3,op(fp(G,cp(fp(cp(H),ip(5,fp(w,cp(E)))))),fp(U,cp(fp(cp(Z),ip(5,fp(Y,cp(B)))))))),cp(op(fp(H,ip(5,fp(w,ip(3,E)))),fp(Z,ip(5,fp(Y,ip(3,B)))))),op(fp(w,ip(6,E)),fp(Y,ip(6,B)))]}const hp=pe,ap=oe,pp=te,dp=le,gp=ce,vp=ie,mp=ue;function bp(t,n){const[[e,r],[o,i],[s,c]]=t,[u,f]=n,l=hp(e,u),h=hp(o,u),a=hp(s,u),p=hp(r,f),d=hp(i,f),g=hp(c,f),v=dp(l,l),m=dp(l,h),b=dp(l,a),x=dp(h,h),_=dp(h,a),I=dp(a,a),N=dp(p,p),S=dp(p,d),E=dp(p,g),w=dp(d,d),M=dp(d,g),P=dp(g,g),T=ap(E,gp(w)),y=ap(b,gp(x));return[ap(vp(ap(ap(P,N),gp(T)),mp(ap(M,S))),vp(ap(ap(I,v),gp(y)),mp(ap(_,m)))),pp(3,ap(ap(vp(M,T),vp(pp(3,S),N)),ap(vp(_,y),vp(pp(3,m),v)))),ap(vp(T,pp(3,vp(gp(S),N))),vp(y,pp(3,vp(gp(m),v)))),ap(vp(S,N),vp(m,v))]}const xp=de,_p=oe,Ip=fe,Np=ie;function Sp(t,n){const[[e,r],[o,i]]=t,[s,c]=n,u=e-s,f=o-s,l=r-c,h=i-c,a=xp(u,u),p=xp(u,f),d=xp(f,f),g=xp(l,l),v=xp(l,h),m=xp(h,h),b=_p(p,v),x=_p(g,a);return[_p(_p(d,m),_p(x,Ip(b))),Np(b,x)]}const Ep=T,wp=sn,Mp=j,Pp=At,Tp=zt,yp=on,Cp=rt,Op=T,Ap=sn,zp=j,Bp=At,Yp=on,Fp=rt;function Vp(t){const n=[];for(let e=0;e8*ld*t));else if(3===t.length)i=td(t,[0,n]).map((t=>5*ld*t));else if(2===t.length)i=td(t,[0,n]).map((t=>2*ld*t));else if(1===t.length)return[o,o];return[[o[0]-i[0],o[1]-i[1]],[o[0]+i[0],o[1]+i[1]]]}(t,n[0])}const ad=Number.EPSILON/2,pd=ad*ad;function dd(t){const n=t*pd;return n/(1-n)}const gd=te,vd=oe,{abs:md}=Math,bd=dd(3);function xd(t,n,e){const r=t.length-1,o=[t[0]];let i=n[0];const s=[i];for(let c=1;cbd*t))}}const _d=cn,Id=on;function Nd(t,n){const e=t.length-1,r=[t[0]];for(let o=1;o10*Wp*t)),getPolyExact:()=>function(t,n){const e=t[0],r=t[1],o=t[2],i=t[3],s=e[0],c=e[1],u=r[0],f=r[1],l=o[0],h=o[1],a=i[0],p=i[1],[d,g]=n,v=Ep(s,d),m=Ep(u,d),b=Ep(l,d),x=Ep(a,d),_=Ep(c,g),I=Ep(f,g),N=Ep(h,g),S=Ep(p,g),E=wp(v,v),w=Mp(6,wp(v,m)),M=Mp(6,wp(v,b)),P=Pp(wp(v,x)),T=Mp(9,wp(m,m)),y=Mp(18,wp(m,b)),C=Mp(6,wp(m,x)),O=Mp(9,wp(b,b)),A=Mp(6,wp(b,x)),z=wp(x,x),B=wp(_,_),Y=Mp(6,wp(_,I)),F=Mp(6,wp(_,N)),V=Pp(wp(_,S)),k=Mp(9,wp(I,I)),L=Mp(18,wp(I,N)),D=Mp(6,wp(I,S)),X=Mp(9,wp(N,N)),q=Mp(6,wp(N,S)),Q=wp(S,S),$=yp(C,O),G=yp(P,y),H=yp(M,T),R=yp(D,X),U=yp(V,L),Z=yp(F,k),j=Cp(yp(yp(z,E),yp($,H)),yp(yp(G,A),w)),W=Cp(yp(yp(Q,B),yp(R,Z)),yp(yp(U,q),Y)),J=Mp(6,yp(j,W)),K=yp(Tp(yp(yp($,Pp(H)),Mp(3,E))),yp(yp(A,Mp(3,G)),Mp(5,w))),tt=yp(Tp(yp(yp(R,Pp(Z)),Mp(3,B))),yp(yp(q,Mp(3,U)),Mp(5,Y))),nt=Mp(5,yp(K,tt)),et=yp(yp($,Mp(3,Cp(Pp(H),G))),Mp(5,Cp(Mp(3,E),Pp(w)))),rt=yp(yp(R,Mp(3,Cp(Pp(Z),U))),Mp(5,Cp(Mp(3,B),Pp(Y)))),ot=Mp(4,yp(et,rt)),it=Cp(G,Pp(Cp(Pp(H),Mp(5,Cp(w,Pp(E)))))),st=Cp(U,Pp(Cp(Pp(Z),Mp(5,Cp(Y,Pp(B)))))),ct=Mp(3,yp(it,st)),ut=Cp(H,Mp(5,Cp(w,Mp(3,E)))),ft=Cp(Z,Mp(5,Cp(Y,Mp(3,B)))),lt=Pp(yp(ut,ft)),ht=Cp(w,Mp(6,E)),at=Cp(Y,Mp(6,B));return[J,nt,ot,ct,lt,yp(ht,at)]}(t,n)};if(2===e)return{polyDd:bp(t,n),polyE:Gp(t,n).map((t=>8*Wp*t)),getPolyExact:()=>function(t,n){const[[e,r],[o,i],[s,c]]=t,[u,f]=n,l=Op(e,u),h=Op(o,u),a=Op(s,u),p=Op(r,f),d=Op(i,f),g=Op(c,f),v=Ap(l,l),m=Ap(l,h),b=Ap(l,a),x=Ap(h,h),_=Ap(h,a),I=Ap(a,a),N=Ap(p,p),S=Ap(p,d),E=Ap(p,g),w=Ap(d,d),M=Ap(d,g),P=Ap(g,g),T=Yp(E,Bp(w)),y=Yp(b,Bp(x)),C=Yp(Fp(Yp(I,Bp(y)),Vp(Yp(_,m))),v),O=Yp(Fp(Yp(P,Bp(T)),Vp(Yp(M,S))),N),A=Yp(C,O),z=Yp(Fp(_,y),Fp(zp(3,m),v)),B=Yp(Fp(M,T),Fp(zp(3,S),N)),Y=zp(3,Yp(z,B)),F=Fp(T,zp(3,Fp(Bp(S),N))),V=Fp(y,zp(3,Fp(Bp(m),v))),k=Yp(F,V),L=Fp(S,N),D=Fp(m,v);return[A,Y,k,Yp(L,D)]}(t,n)};if(1===e)return{polyDd:Sp(t,n),polyE:Hp(t,n).map((t=>6*Wp*t)),getPolyExact:()=>function(t,n){const[[e,r],[o,i]]=t,[s,c]=n,u=kp(e,s),f=kp(o,s),l=kp(r,c),h=kp(i,c),a=Lp(u,u),p=Lp(u,f),d=Lp(f,f),g=Lp(l,l),v=Lp(l,h),m=Lp(h,h),b=Xp(p,v),x=Xp(g,a);return[Xp(Xp(d,m),Xp(Dp(b),x)),qp(b,x)]}(t,n)};if(0===e)return{polyDd:[[0,1]],polyE:[0],getPolyExact:()=>[[1]]};throw new Error("The given bezier curve must be of order <= 3")}(u,n);const p=f?xd(l,h.map((t=>t/Td)),i):void 0,d=s&&f?xd(p.coeffs,p.errBound.map((t=>t/Td)),i):void 0,g=s&&f?xd(d.coeffs,d.errBound.map((t=>t/Td)),i):void 0,{polyDd:v,polyE:m,getPolyExact:b}=void 0!==g?{polyDd:g.coeffs,polyE:g.errBound.map((t=>t/Td)),getPolyExact:()=>Nd(Nd(Nd(a(),i),i),i)}:void 0!==p?{polyDd:p.coeffs,polyE:p.errBound.map((t=>t/Td)),getPolyExact:()=>Nd(a(),i)}:{polyDd:l,polyE:h,getPolyExact:a},x=Nr(v,e,r,m,b),_=1===i&&t===o.next||0===i&&t===o,I=0===i&&t===o.prev||1===i&&t===o;0===e?_||x.push({tS:0,tE:0,multiplicity:1}):1===e?I||x.push({tS:1,tE:1,multiplicity:1}):x.push({tS:e,tE:e,multiplicity:1}),0===r?_||x.push({tS:0,tE:0,multiplicity:1}):1===r?I||x.push({tS:1,tE:1,multiplicity:1}):x.push({tS:r,tE:r,multiplicity:1});const N=x.map((o=>{const{tS:i,tE:s}=o;if(sr)return;const c=(i+s)/2,f=c<0?0:c>1?1:c,l=hd(u,[i,s]),h=function(t){const n=t[0],e=t[1];return[(n[0]+e[0])/2,(n[1]+e[1])/2]}(l),a=function(t,n){const e=t[0],r=t[1],o=e[0],i=e[1],s=r[0],c=r[1],u=n[0],f=n[1];let l=Number.POSITIVE_INFINITY,h=Number.NEGATIVE_INFINITY;for(const[t,n]of[[o,i],[o,c],[s,i],[s,c]]){const e=Ed(t,u),r=Ed(n,f),o=Md(wd(e,e),wd(r,r)),i=Sd(o),s=i*(1-Pd),c=i*(1+Pd);s<=l&&(l=s),c>=h&&(h=c)}return[l,h]}(l,n),p=0===f?1:f;return{curve:0===f?t.prev:t,p:h,t:p,d:(yd(a[0])+yd(a[1]))/2,dSquaredI:a,box:l}}));return N.filter((t=>void 0!==t))}const Od=p;function Ad(t,n){const e=t[0],r=t[1],o=e[0],i=e[1],s=r[0],c=r[1],u=n[0],f=n[1];return uc?Od([o,c],n):(o-u)**2:u>s?fc?Od(t[1],n):(u-s)**2:fc?(f-c)**2:0}function zd(t){const n=function(t){const n=t[0],e=t[t.length-1];let r,o;if(n[0]o.box[0][0]&&(o={ts:i,box:c})}return{minX:r,maxX:o}}(t),e=function(t){const n=t[0],e=t[t.length-1];let r,o;if(n[1]o.box[0][1]&&(o={ts:i,box:c})}return{minY:r,maxY:o}}(t);return[[n.minX.box[0][0],e.minY.box[0][1]],[n.maxX.box[1][0],e.maxY.box[1][1]]]}const Bd=P(zd);function Yd(t){let n=0;for(let e=0;e-t)));return zd(t.map((t=>S(-n,e,r(t)))))}(t,i,s),[[f,l],[h,a]]=u,d=[u[0],[h,l],u[1],[f,a]],g=S(i,s);return d.map((n=>I(t[0],g(n))))}function Vd(t,n){const e=[0,1,2,3].map((e=>function(t,n){const e=p,r=n[0],o=n[1],i=e(r,o);if(0==i)return e(t,r);let s=((t[0]-r[0])*(o[0]-r[0])+(t[1]-r[1])*(o[1]-r[1]))/i;return s=Math.max(0,Math.min(1,s)),e(t,[r[0]+s*(o[0]-r[0]),r[1]+s*(o[1]-r[1])])}(n,[t[e],t[(e+1)%4]]))),r=p(t[0],t[1]),o=p(t[0],t[3]);return e[0]<=o&&e[2]<=o&&e[1]<=r&&e[3]<=r?0:Math.min(...e)}const kd=P(Fd);function Ld(t,n){const e=function(t,n){let e=Number.POSITIVE_INFINITY;for(let r=0;rSe(t.curve,t.t,!1)))}function Xd(t,n){return n.map((n=>Dd(n,t)[0]))}function qd(t,n,e){const r=ep(e);let o,i,s,c,u=1,f=0;do{i=I([(h=u)*(l=e)[0],h*l[1]],n),s=Xd(i,t),c=ep(d(i,np(s.map((t=>t.p))))),o=ci&&a<10;){if(a++,l=Xd(p,f),!Number.isFinite(p[0])||!Number.isFinite(p[1]))return;h=np(l.map((t=>t.p)));const t=Qd(p,h);if(!Number.isFinite(t[0])||!Number.isFinite(t[1]))return;const n=qd(f,p,t);if(p=n.newX,l=n.newPs,"undefined"!=typeof _debug_){const t=_debug_.generated.elems.threeProng,n=t[t.length-1];n.traces[n.traces.length-1].push(p)}const e=ep(t);g=Math.abs(e-n.newV)}const v=($r(p,l[0].p)+$r(p,l[1].p)+$r(p,l[2].p))/3,m={center:p,radius:v};let b=0;for(let t=0;t<3;t++){const n=l[t],e=N(d(n.p,p)),r=x(e);if(Ra(n)){const t=dn(n.curve).tangents.map(x),r=Math.asin(_(t[0],e)),o=Math.asin(_(e,t[1]));let i=0;r>0&&(i+=r),o>0&&(i+=o),b+=i}else{const t=N(M(n.curve.ps,n.t));b+=Math.abs(Math.asin(_(r,t)))}}const I=[];for(let t=0;t!!vn(t)&&gn(t).isQuiteSharp));function Hd(t){let n=t[0];const e=t[1],r=[];let o=!0;do{if(!o){o=!0,n=n.prevOnCircle;continue}o=!1;const t=n.cp.pointOnShape,e=n.next.cp.pointOnShape;e.curve===t.curve&&Gd(t)&&Gd(e)||(e.curve===t.curve&&h(n.next.cp,n.cp)>0?r.push({curve:t.curve,ts:[t.t,e.t]}):(r.push({curve:t.curve,ts:[t.t,1]}),n.cp.pointOnShape.curve.loop===n.next.cp.pointOnShape.curve.loop&&Rd(r,t.curve,e.curve,e.t))),n=n.next}while(n!==e);return r}function Rd(t,n,e,r){let o=n;do{o=o.next;const n=o===e?r:1;t.push({curve:o,ts:[0,n]})}while(o!==e)}function Ud(){if("undefined"!=typeof _debug_){const t=_debug_.generated.elems.threeProng,n=[];t[t.length-1].traces.push(n)}}function Zd(t,n,e){"undefined"!=typeof _debug_&&t.push({circle:n,ps:e})}function jd(t,n,e,r){const o=t.findBounds(Sn({pointOnShape:n,circle:void 0,order:e,order2:r},!1,!1));return o[0]||o[1]?o[0]&&o[1]?[o[0].datum,o[1].datum]:[t.max(t.root),t.min(t.root)]:[void 0,void 0]}function Wd(t,n,e,r,o){const i=r.map(((r,i)=>{const s=e.get(r.curve.loop);return yn(!1,!1,s,{pointOnShape:r,circle:t,order:n[i],order2:0},(o?o[i]:jd(s,r,n[i],0))[0])})),s=r.length;for(let t=0;ts)&&(b(N(d(n,t.cp.circle.center)),N(d(f,e.center)))>Jd||r2){const n=eg(t,r,e);1===n.length&&n[0],tg++}if("undefined"!=typeof _debug_&&tg===_debug_.directives.stopAfterThreeProngsNum)return}while(r.length>2);return r}function eg(t,n,e){const r=[];for(const t of n)r.push([t,t.next]);const o=function(t,n){const e=t.map(Hd);!function(t){if("undefined"!=typeof _debug_){const n=_debug_.generated.elems.threeProng;n.push({generated:void 0,circle:void 0,poss:void 0,cp3ss:void 0,cpss:void 0,bestIndx:void 0,candidateThreeProngs:void 0,visitedCps:void 0,boundaries:void 0,traces:void 0});const e=n[n.length-1];e.boundaries=[];for(const n of t){const t=[];e.boundaries.push(t);for(const e of n){const n=Ja(e.curve.ps,e.ts[0],e.ts[1]);t.push(n)}}e.traces=[]}}(e);const r=[];let o,i,s=Number.POSITIVE_INFINITY;for(let c=1;c0?sg:ig]}}toArrayInOrder(){const t=[];return function n(e){e&&(n(e[ig]),t.push(e.datum),void 0!==e.extras&&t.push(...e.extras),n(e[sg]))}(this.root),t}insertMulti(t){const n=this;for(const e of t)n.insert(e)}insert(t){const n=this;n.root=function t(e,r){if(void 0===e)return n.valueCount++,n.nodeCount++,new ug(r);const o=n.compare(r,e.datum);if(0===o&&(n.duplicatesAllowed?(n.valueCount++,void 0===e.extras?e.extras=[r]:e.extras.push(r)):e.datum=r),0!==o){const n=o>0?sg:ig;e[n]=t(e[n],r),e[n].parent=e}return fg(e[sg])&&!fg(e[ig])&&(e=hg(ig,e)),fg(e[ig])&&fg(e[ig][ig])&&(e=hg(sg,e)),fg(e[ig])&&fg(e[sg])&&pg(e),e}(n.root,t),n.root.color=1,n.root.parent=void 0}remove(t,n=!1,e){const r=this;if(void 0===r.root)return;let o;const i=function t(i,s){const c=r.duplicatesAllowed&&void 0!==i.extras;let u=r.compare(s,i.datum);if(u<0&&!i[ig]||u>0&&!i[sg])return i;if(u<0){fg(i[ig])||fg(i[ig][ig])||(i=dg(i));const n=t(i[ig],s);return null===n?null:(i[ig]=n,i[ig]&&(i[ig].parent=i),gg(i))}if(fg(i[ig])&&(i=hg(sg,i),u=r.compare(s,i.datum)),0===u&&!i[sg]){if(c&&!n){if(void 0===e||!0===e(s,i.datum))return o=i.datum,i.datum=i.extras.pop(),r.valueCount--,0===i.extras.length&&(i.extras=void 0),i;{const t=i.extras;for(let n=0;n=0?r[0]=e:r[1]=e,e=e[o>=0?sg:ig]}return r}findBoundsExcl(t){const n=this,e=n.root,r=[void 0,void 0];return void 0===e||function e(o){for(;o;){const i=n.compare(t,o.datum);if(0===i)return e(o[ig]),void e(o[sg]);i>0?r[0]=o:i<0&&(r[1]=o),o=o[i>0?sg:ig]}}(e),r}findAll(t){const n=this;let e=this.root;for(;e;){const r=n.compare(t,e.datum);if(0===r)return[e.datum,...e.extras?e.extras:[]];e=e[r>0?sg:ig]}return[]}getMinOrMaxNode(t){return n=>{if(void 0===n&&(n=this.root),n){for(;n[t];)n=n[t];return n}}}min(t){void 0===t&&(t=this.root);const n=this.getMinNode(t);if(void 0!==n)return n.datum}max(t){void 0===t&&(t=this.root);const n=this.getMaxNode(t);if(void 0!==n)return n.datum}}function hg(t,n){const e=n[-t];return n[-t]=e[t],e[t]&&(e[t].parent=n),e[t]=n,n.parent=e,e.color=n.color,n.color=cg,e}function ag(t){if(t[ig])return fg(t[ig])||fg(t[ig][ig])||(t=dg(t)),t[ig]=ag(t[ig]),t[ig]&&(t[ig].parent=t),gg(t)}function pg(t){t.color=(t.color+1)%2,t[ig].color=(t[ig].color+1)%2,t[sg].color=(t[sg].color+1)%2}function dg(t){if(pg(t),fg(t[sg][ig])){const n=hg(sg,t[sg]);t[sg]=n,n.parent=t,pg(t=hg(ig,t))}return t}function gg(t){return fg(t[sg])&&(t=hg(ig,t)),fg(t[ig])&&fg(t[ig][ig])&&(t=hg(sg,t)),fg(t[ig])&&fg(t[sg])&&pg(t),t}const vg=Rr;let mg;const bg=Number.POSITIVE_INFINITY,xg=P((function(t){const n=[[{bezier:void 0,t:void 0,val:bg},{bezier:void 0,t:void 0,val:bg}],[{bezier:void 0,t:void 0,val:-bg},{bezier:void 0,t:void 0,val:-bg}]];return t.curves.forEach((function(t){const e=function(t){const n=w(t),e=Ni(n[0],0,1),r=Ni(n[1],0,1);e.push(0,1),r.push(0,1);let o,i,s,c,u=Number.POSITIVE_INFINITY,f=Number.NEGATIVE_INFINITY,l=Number.POSITIVE_INFINITY,h=Number.NEGATIVE_INFINITY;for(let n=0;nf&&(f=s,i=r)}for(let n=0;nh&&(h=o,c=e)}return{ts:[[o,s],[i,c]],box:[[u,l],[f,h]]}}(t.ps);{const r=e.box[0][0],o=n[0][0].val;(rn[0][0].t)&&(n[0][0]={bezier:t,t:e.ts[0][0],val:r})}{const r=e.box[0][1],o=n[0][1].val;(rn[0][1].t)&&(n[0][1]={bezier:t,t:e.ts[0][1],val:r})}{const r=e.box[1][0],o=n[1][0].val;(r>o||r===o&&e.ts[1][0]>n[1][0].t)&&(n[1][0]={bezier:t,t:e.ts[1][0],val:r})}{const r=e.box[1][1],o=n[1][1].val;(r>o||r===o&&e.ts[1][1]>n[1][1].t)&&(n[1][1]={bezier:t,t:e.ts[1][1],val:r})}})),{minY:Se(n[0][1].bezier,n[0][1].t,!0),minX:Se(n[0][0].bezier,n[0][0].t,!0),maxX:Se(n[1][0].bezier,n[1][0].t,!0),maxY:Se(n[1][1].bezier,n[1][1].t,!0)}})),_g=P((function(t){let n,e,r,o,i=Number.POSITIVE_INFINITY,s=Number.NEGATIVE_INFINITY,c=Number.POSITIVE_INFINITY,u=Number.NEGATIVE_INFINITY;for(const f of t){const t=xg(f);t.minX.p[0]s&&(e=t.maxX,s=t.maxX.p[0]),t.minY.p[1]u&&(o=t.maxY,u=t.maxY.p[1])}return{minX:n,minY:r,maxX:e,maxY:o}})),Ig=oe,Ng=te;function Sg(t,n){let e=[0,0];for(let r=0;rt[t.length-1])),u=[-c[1],c[0]],f=Math.sqrt(u[0]**2+u[1]**2);return{center:[o[0]-u[0]/(s*f),o[1]-u[1]/(s*f)],radius:1/s}}function $g(t){return t.holeClosing?"twoProng_holeClosing":"twoProng_regular"}const{abs:Gg}=Math,Hg=pe,Rg=de;function Ug(t,n,e){const r=Gg(t[1]-n[1])>Gg(t[0]-n[0]);let o,i,s,c,u,f;r?(o=t[1],i=t[0],s=n[1],c=n[0],u=e[1],f=e[0]):(o=t[0],i=t[1],s=n[0],c=n[1],u=e[0],f=e[1]);const l=he(Hg(i,c),Hg(o,s)),h=ie([0,c],se(s,l)),a=oe(ie(oe(Rg(s,s),Rg(c,c)),oe(Rg(u,u),Rg(f,f))),ce(le(h,Hg(f,c)))),p=oe(Hg(s,u),le(l,Hg(c,f))),d=he(a,ce(p)),g=oe(le(l,d),h);return r?[g[1],d[1]]:[d[1],g[1]]}function Zg(t,n,e,r){const o=(2**-14*t)**2;if(p(n,r)({curve:t,ts:[0,1]})));t.push(...e)}return{bezierPieces:t,δ:void 0}}let c;const u=Ra(i)?1===i.t&&0===t?-1:0===i.t?1:Ua(s,i):0,f=r[e],l=jd(o.get(f),i,u,0)[0],h=[l,l];return c=l&&l!==l.next.next?Hd(h):f.curves.map((t=>({curve:t,ts:[0,1]}))),{bezierPieces:c,δ:h}}(t,s,c,n,o,i,{center:v,radius:b});let N=v;const E=Kg(function(t,n,e,r){let o,i=Number.POSITIVE_INFINITY;for(let s=0;sE&&(N=g(m,v,E/b));const w=[];let M,P,T=x,y=0;for(;y<25;){const n=jg(N,i.p);if(y<5&&(T=Wg(T,N,n)),M=Dd(T,N,i.curve,i.t,u&&0==y&&b!==1/a,t).map((t=>Se(t.curve,t.t,!1))),P=M[0],void 0===P)return void ov(s);const e=jg(N,P.p),r=jg(i.p,P.p);if(0===y&&b<(1-2**-6)*Kg(e))return void Jg(b,v,o,i);if("undefined"!=typeof _debug_&&w.push({x:N,y:i,z:Se(P.curve,P.t,!1),t:i.t}),!s&&r<=f)return;if(N=Ug(N,i.p,P.p),tv(Kg(n)-Kg(e))Ua(n,t)));let f=!1;for(let e=0;e0)return!1;const p=u+3*o,d=e+3*s,g=p-d,v=Yv(3*o)+Yv(p)+(Yv(3*s)+Yv(d))+Yv(g);return!(Yv(g)-Bv*v>0)&&0===Av(zv(Ov([c],Cv(3,r)),Ov([n],Cv(3,i))))&&0===Av(zv(Ov([u],Cv(3,o)),Ov([e],Cv(3,s))))}(t)&&(t=function(t,n=!1){if(!n){const[[n,e],[r,o],[i,s],[c,u]]=t;return[[n,e],[Dv(kv(Xv(qv(r/4,i/4),3),qv(n/4,c/4))),Dv(kv(Xv(qv(o/4,s/4),3),qv(e/4,u/4)))],[c,u]]}const[e,r,o,i]=t,s=function(t,n){const[[e,r],[o,i]]=t,[[s,c],[u,f]]=n,l=Vv(o,e),h=Vv(i,r),a=Vv(u,s),p=Vv(f,c),d=kv(Fv(a,h),Fv(p,l));if(0===Lv(d))return;const g=Vv(s,e),v=Vv(c,r),m=kv(Fv(v,l),Fv(g,h)),b=Dv(m)/Dv(d);return[s+b*Dv(a),c+b*Dv(p)]}([e,r],[i,o]);if(void 0!==s)return[e,s,i]}(t)),3===t.length){const n=function(t){const[[n,e],[r,o],[i,s]]=t,c=Qv(r,n),u=Qv(i,r),f=Rv(u,c),l=Qv(o,e),h=Qv(s,o),a=Rv(h,l),p=Hv(Rv($v(n,Rv(f,[0,-r])),$v(r,Rv(u,[0,-r]))),Rv($v(e,Rv(a,[0,-o])),$v(o,Rv(h,[0,-o]))));return[Hv(Gv(f,f),Gv(a,a)),ae(p)]}(t);return{minima:[],maxima:Nr(n,0,1).map((t=>(t.tS+t.tE)/2)),inflections:[]}}const n=function(t){const[[n,e,r],[o,i,s]]=yg(t),[[c,u],[f,l]]=Bg(t),[[h],[a]]=function(t){if(4===t.length){const[[n,e],[r,o],[i,s],[c,u]]=t;return[[Nv(6,Iv(_v(c,n),Nv(3,_v(r,i))))],[Nv(6,Iv(_v(u,e),Nv(3,_v(o,s))))]]}if(t.length<=3)return[[[0,0]],[[0,0]]];throw new Error("The given bezier curve must be of order <= 3.")}(t),p=Mv(h,i),d=Mv(a,e),g=Mv(u,s),v=Mv(u,i),m=Mv(f,f),b=Mv(c,s),x=Mv(l,r),_=Mv(l,e),I=Mv(f,r),N=Mv(r,e),S=Mv(r,n),E=Mv(r,o),w=Mv(e,e),M=Mv(e,n),P=Mv(e,i),T=Mv(n,s),y=Mv(n,o),C=Mv(n,n),O=Mv(s,i),A=Mv(s,o),z=Mv(i,i),B=Mv(i,o),Y=Mv(o,o),F=Tv(Mv(h,s),Mv(a,r)),V=Tv(p,d),k=Pv(Mv(u,r),Mv(l,s)),L=Pv(Pv(Mv(u,e),Mv(c,r)),Pv(Mv(l,i),Mv(f,s))),D=Tv(g,x),X=Tv(Pv(v,b),Pv(_,I)),q=Pv(Mv(r,r),Mv(s,s)),Q=Pv(N,O),$=Pv(P,T),G=Pv(A,z),H=Pv(S,w),R=Pv(Mv(e,o),Mv(n,i)),U=Tv(C,Y),Z=Tv(M,B),j=Pv(E,P),W=Tv(N,O),J=Pv(Mv(r,i),Mv(e,s)),K=Pv(A,G),tt=Pv(S,H),nt=Pv(E,$),et=Pv(P,$),rt=Tv(tt,K),ot=Pv($,T),it=Pv(j,T),st=Pv(ce(_),I),ct=Mv(C,Tv(p,wv(3,d))),ut=Mv(Y,Tv(wv(3,p),d)),ft=ce(Pv(Mv(y,Pv(Tv(Mv(h,e),Mv(a,i)),wv(3,Tv(Mv(l,f),Mv(u,c))))),wv(3,Mv(Mv(c,f),Z)))),lt=wv(3,Pv(Mv(R,Tv(m,Mv(c,c))),Mv(U,Pv(Mv(u,f),Mv(l,c))))),ht=Pv(Pv(ct,ut),Pv(ft,lt)),at=Mv(h,Pv(Mv(o,Pv(tt,wv(3,G))),Mv(n,et))),pt=Mv(a,Pv(Pv(Mv(r,Pv(wv(3,C),Y)),Mv(e,Pv(wv(3,M),Sv(B)))),Mv(n,K))),dt=wv(3,Pv(Pv(Mv(u,Pv(Tv(Mv(l,U),Mv(u,y)),Sv(Tv(Mv(f,Z),Mv(c,R))))),Mv(c,Tv(Pv(Sv(Mv(l,Z)),Mv(f,Pv(Sv(Tv(S,A)),Tv(w,z)))),Mv(c,it)))),Pv(Mv(l,Pv(Mv(l,y),Sv(Mv(f,R)))),Mv(m,nt)))),gt=Pv(Tv(at,pt),dt),vt=Mv(h,Pv(Pv(Sv(Mv(r,R)),Mv(e,ot)),Mv(i,Pv(Ev(A),K)))),mt=Mv(a,Pv(Pv(Sv(Mv(r,Pv(wv(3,M),B))),Mv(e,Pv(w,Sv(A)))),Mv(i,ot))),bt=wv(3,Pv(Pv(Mv(u,Tv(Pv(Sv(Tv(Mv(l,Z),Mv(c,it))),Mv(f,rt)),Mv(u,R))),Mv(c,Tv(Sv(Mv(f,W)),Mv(c,J)))),Pv(Mv(l,Pv(Pv(Mv(l,R),Sv(Mv(f,nt))),Mv(c,rt))),Mv(m,J)))),xt=Pv(Tv(vt,mt),bt),_t=Mv(h,Pv(Mv(r,Pv(E,Sv($))),Mv(s,Pv(w,wv(3,G))))),It=Mv(a,Pv(Mv(r,Pv(wv(3,H),K)),Mv(s,et))),Nt=wv(3,Pv(Pv(Mv(u,Pv(Tv(Mv(l,rt),Mv(u,nt)),Sv(Tv(Mv(f,W),Mv(c,J))))),Mv(c,Tv(Mv(r,Tv(st,Mv(c,s))),Mv(s,Pv(Sv(Mv(l,i)),Mv(f,s)))))),Pv(Mv(l,Pv(Mv(l,$),Mv(r,Pv(Sv(Mv(f,i)),Mv(l,o))))),Mv(f,Mv(s,st))))),St=Pv(Tv(_t,It),Nt),Et=Tv(Pv(Mv(q,V),Sv(Mv(Q,F))),wv(3,Pv(Mv(k,X),Mv(L,D)))),wt=Tv(Mv(F,q),wv(3,Mv(k,D)));return{inflectionPoly:[Tv(Mv(c,o),Mv(f,n)),Tv(Pv(Mv(u,o),Mv(c,i)),Pv(Mv(l,n),Mv(f,e))),Tv(Pv(v,b),Pv(_,I)),Tv(g,x)],otherExtremaPoly:[ht,gt,xt,St,Et,wt]}}(t),e=n.inflectionPoly,r=n.otherExtremaPoly,o=Nr(r,0,1),i=function(t){const n=[],e=t.length-1;for(let r=0;r=0?s.push(n):c.push(n)}return{minima:s,maxima:c,inflections:Nr(e,0,1).map((t=>(t.tS+t.tE)/2))}}function Zv(t){return xg(t).minY}function jv(t,n,e,r,o){!function(t){if("undefined"==typeof _debug_)return;mg=performance.now();for(const n of t)_debug_.fs.nameObj(n,"l|");const n=_debug_.generated;for(const e of t){let t=0;e.curves.forEach((function(e){const r=e.ps,o=vg(r);n.elems.boundingHull.push(o);const i=Bd(r);n.elems.looseBoundingBox.push(i);const s=Fd(r);n.elems.tightBoundingBox.push(s);const c=dn(e);c.isQuiteSharp?n.elems.sharpCorner.push(e):c.isQuiteDull&&n.elems.dullCorner.push(e),t++}))}}(t);const i=function(t){return n=>{const e=[];for(let r=0;r{const e=[];for(let r=0;rSe(o,t,!0)));e.push(...c)}return e}}(n)),h=t.map(function(t,n,e){return function(r){const o=[];for(let i=0;iSe(s,t,!0)));o.push(...u)}return o}}(n,e,r));let a;if(a=lv(a,t,f,u,o,!1),a=lv(a,t,f,l,o,!0),a=lv(a,t,f,h,o,!1),function(){if("undefined"==typeof _debug_)return;const t=_debug_.generated.timing,n=performance.now();t.oneAnd2Prongs+=n-mg,mg=n}(),"undefined"!=typeof _debug_&&_debug_.directives.stopAfterTwoProngs)return;if(void 0===a)return;if(function(t,n,e){const r=new Map,o=[{fromCpNode:void 0,cpStart:n}];for(;o.length;){const{fromCpNode:n,cpStart:i}=o.shift();rg(r,n,i);for(const n of Cn(i)){if(!mn(n.cp.pointOnShape)&&void 0===ng(t,n,e))return void console.log("Unable to find 3-prong");og(r,n,n.next)||o.push({fromCpNode:i,cpStart:n.next})}}}(f,a,o),"undefined"!=typeof _debug_&&_debug_.directives.stopAfterThreeProngs)return;const p={cpNode:a,cpTrees:f};return function(t){if("undefined"==typeof _debug_)return;const n=_debug_.generated,e=n.timing;n.elems.mat.push(t),e.threeProngs+=performance.now()-mg}(p),p}const Wv=Math.max,Jv=Math.abs;function Kv(t,n=.4,r=4){let o,i;({maxCurviness:n,maxLength:r,maxCoordinate:o,minBezLength:i}=function(t,n,e){const{maxCoordinate:r,maxRadius:o}=function(t){let n=0,e=Number.POSITIVE_INFINITY,r=Number.NEGATIVE_INFINITY,o=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY;for(const s of t)for(const t of s)for(const s of t){const t=s[0],c=s[1],u=Wv(Jv(t),Jv(c));u>n&&(n=u),tr&&(r=t),ci&&(i=c)}return{maxCoordinate:n,maxRadius:Wv(r-e,i-o)}}(t),i=2**Math.ceil(Math.log2(r))*2**-16;return n<.05&&(n=.05),n>3&&(n=3),e<.1&&(e=.1),e>100&&(e=100),{maxCurviness:n,maxLength:e*=2**Math.ceil(Math.log2(o))*2**-10,maxCoordinate:r,minBezLength:i}}(t,n,r));const s=function(t,n){let r;"undefined"!=typeof _debug_&&(r=performance.now()),n=n||Xa(t);const o=Math.ceil(Math.log2(n)),i=2**o*2**-46*64;(function(t){if("undefined"!=typeof _debug_){if("undefined"!=typeof document){const n=function(t){let n="";for(const r of t)n=n+e(r)+"\n";return n}(t);document.getElementsByClassName("shape")[0].setAttributeNS(null,"d",n)}for(const n of t){_debug_.generated.elems.loopPre.push(...t),_debug_.generated.elems.loopsPre.push(t);for(const t of n){const n=Pi(t),e=Gr(t),r=Ur(t);_debug_.generated.elems.bezier_.push(t),_debug_.generated.elems.looseBoundingBox_.push(n),_debug_.generated.elems.tightBoundingBox_.push(e),_debug_.generated.elems.boundingHull_.push(r)}}}})(t=Da(t,46,o,!1,!0)),t.sort(Ai);const s=t.map(((t,n)=>Ca(t,n))),{extremes:c}=Ma(s,i,o),u={dir:void 0,idx:0,parent:void 0,children:new Set,windingNum:0,p:void 0,_x_:void 0,container:void 0},f=new Set,l=new Set;for(const t of s){if(f.has(t))continue;f.add(t);const n=Oi(u,t),e=c.get(t)[0].container;if(!e.inOuts.length)continue;const r=ya(e);r.parent=n,r.windingNum=n.windingNum+r.orientation,r.children=new Set,Jo(0,ya(e),f,l)}const h=function(t){const n=[],e=[t];for(;e.length;){const t=e.pop();t.children=t.children||new Set;for(const r of t.children)0===t.windingNum&&n.push(r),e.push(r);0===t.windingNum&&(t.children=new Set)}return n}(u).map(Bi).map((t=>t.map(((n,e)=>function(t,n,e){const r=n<0?Ca(t.beziers,e):function(t){const n=[],e=t.curves;for(let t=e.length-1;t>=0;t--){const r=e[t].ps.slice().reverse();n.push(r)}return Ca(n,void 0)}(Ca(t.beziers,e));return r}(n,t[0].orientation,e))))),a=(2**o*2**-12)**2,p=[];for(let t=0;tMath.abs(Ga(t))>a));n.length&&(n.sort(((t,n)=>Ai(t.beziers,n.beziers))),p.push(n))}return function(t){if("undefined"!=typeof _debug_)for(const n of t)_debug_.generated.elems.loop.push(...n),_debug_.generated.elems.loops.push(n)}(p),"undefined"!=typeof _debug_&&(_debug_.generated.timing.simplifyPaths=performance.now()-r),p}(t),c=[];for(const t of s){const e=jv(t,i,n,r,o);e&&c.push(e)}return c}function tm(t){const n=new Map;return Tn(t).forEach((function(t){const e=t.cp.pointOnShape.curve.loop;let r=n.get(e);r||(r=new lg(wn,!1),n.set(e,r)),r.insert(t)})),n}function nm(t){const n=[],e=Tn(t);for(const t of e)An(t)&&n.push(t);return n}const em=["prev","next","prevOnCircle","nextOnCircle"];function rm(t){const n=new Map,e=Sn(t.cp,t.isHoleClosing,t.isIntersection);n.set(t,e);const r=[{cpNode:t,newCpNode:e}];for(;r.length;){const{cpNode:t,newCpNode:e}=r.pop();for(const o of em){const i=t[o];let s=n.get(i);s||(s=Sn(i.cp,i.isHoleClosing,i.isIntersection),n.set(i,s),r.push({cpNode:i,newCpNode:s})),e[o]=s}}return e}function om(t){const n=function(t){let n=t;const e=nm(t);for(;e.length;){const r=e.pop();if(r.isHoleClosing||r.isIntersection)continue;let o=r.next;for(;;){o=o.next;let e=!1;const r=o.prevOnCircle;if(Fn(o)>2){const n=o.nextOnCircle;On(o,t)?e=!0:o.next===n?o=n:n.next!==r&&(e=!0)}else if(An(o)&&!o.isIntersection)return void(n=o);if(e){r.next=o,o.prev=r,n=o;break}}}return n}(rm(t.cpNode));if(n)return{cpNode:n,cpTrees:tm(n)}}function im(t,n,e=16){if(n[0]===n[1])return 0;const{weights:r,abscissas:o}=sm[e],[i,s]=n;let c=0;const u=(s-i)/2,f=(s+i)/2;for(let n=0;n<=e-1;n++)c+=r[n]*t(u*o[n]+f);return u*c}const sm={2:{weights:[1,1],abscissas:[-.5773502691896257,.5773502691896257]},4:{weights:[.6521451548625461,.6521451548625461,.3478548451374538,.3478548451374538],abscissas:[-.3399810435848563,.3399810435848563,-.8611363115940526,.8611363115940526]},8:{weights:[.362683783378362,.362683783378362,.3137066458778873,.3137066458778873,.2223810344533745,.2223810344533745,.1012285362903763,.1012285362903763],abscissas:[-.1834346424956498,.1834346424956498,-.525532409916329,.525532409916329,-.7966664774136267,.7966664774136267,-.9602898564975363,.9602898564975363]},16:{weights:[.027152459411754096,.062253523938647894,.09515851168249279,.12462897125553388,.14959598881657674,.16915651939500254,.18260341504492358,.1894506104550685,.1894506104550685,.18260341504492358,.16915651939500254,.14959598881657674,.12462897125553388,.09515851168249279,.062253523938647894,.027152459411754096],abscissas:[-.9894009349916499,-.9445750230732326,-.8656312023878318,-.755404408355003,-.6178762444026438,-.45801677765722737,-.2816035507792589,-.09501250983763744,.09501250983763744,.2816035507792589,.45801677765722737,.6178762444026438,.755404408355003,.8656312023878318,.9445750230732326,.9894009349916499]},64:{weights:[.048690957009139724,.048690957009139724,.04857546744150343,.04857546744150343,.048344762234802954,.048344762234802954,.04799938859645831,.04799938859645831,.04754016571483031,.04754016571483031,.04696818281621002,.04696818281621002,.046284796581314416,.046284796581314416,.04549162792741814,.04549162792741814,.044590558163756566,.044590558163756566,.04358372452932345,.04358372452932345,.04247351512365359,.04247351512365359,.04126256324262353,.04126256324262353,.03995374113272034,.03995374113272034,.038550153178615626,.038550153178615626,.03705512854024005,.03705512854024005,.035472213256882386,.035472213256882386,.033805161837141606,.033805161837141606,.03205792835485155,.03205792835485155,.030234657072402478,.030234657072402478,.028339672614259483,.028339672614259483,.02637746971505466,.02637746971505466,.024352702568710874,.024352702568710874,.022270173808383253,.022270173808383253,.02013482315353021,.02013482315353021,.017951715775697343,.017951715775697343,.015726030476024718,.015726030476024718,.013463047896718643,.013463047896718643,.011168139460131128,.011168139460131128,.008846759826363947,.008846759826363947,.006504457968978363,.006504457968978363,.004147033260562468,.004147033260562468,.001783280721696433,.001783280721696433],abscissas:[-.024350292663424433,.024350292663424433,-.07299312178779904,.07299312178779904,-.12146281929612056,.12146281929612056,-.16964442042399283,.16964442042399283,-.21742364374000708,.21742364374000708,-.2646871622087674,.2646871622087674,-.31132287199021097,.31132287199021097,-.3572201583376681,.3572201583376681,-.4022701579639916,.4022701579639916,-.4463660172534641,.4463660172534641,-.48940314570705296,.48940314570705296,-.5312794640198946,.5312794640198946,-.571895646202634,.571895646202634,-.6111553551723933,.6111553551723933,-.6489654712546573,.6489654712546573,-.6852363130542333,.6852363130542333,-.7198818501716109,.7198818501716109,-.7528199072605319,.7528199072605319,-.7839723589433414,.7839723589433414,-.8132653151227975,.8132653151227975,-.8406292962525803,.8406292962525803,-.8659993981540928,.8659993981540928,-.8893154459951141,.8893154459951141,-.9105221370785028,.9105221370785028,-.9295691721319396,.9295691721319396,-.9464113748584028,.9464113748584028,-.9610087996520538,.9610087996520538,-.973326827789911,.973326827789911,-.983336253884626,.983336253884626,-.9910133714767443,.9910133714767443,-.9963401167719553,.9963401167719553,-.9993050417357722,.9993050417357722]}};function cm(t){const[n,e]=w(t);return function(t){const r=E(n,t),o=E(e,t);return Math.sqrt(r*r+o*o)}}function um(t,n=.4,e=2**-16){const r={r:[0,1]};let o=r;for(;void 0!==o;){const r=o.r;if(mv(Ja(t,r[0],r[1]))<=n||r[1]-r[0]<=e){o=o.next;continue}const i=(r[0]+r[1])/2,s=[r[0],i],c=[i,r[1]];o.r=s,o.next={r:c,next:o.next}}o=r;const i=[];for(;void 0!==o;)i.push(o.r[0]),void 0===o.next&&i.push(o.r[1]),o=o.next;return i}function fm(t,n){const e=Cn(t);for(;e.length;){const t=e.pop();n(t),An(t)||e.push(...Mn(t))}}function lm(t,n){n(t),Cn(t).filter((t=>!An(t))).map((t=>t.next)).forEach((function(t){const e=[t];for(;e.length;){const t=e.pop();n(t),e.push(...Pn(t))}}))}function hm(t,n){let e=0;if("undefined"!=typeof _debug_){e=performance.now();const n=nm(t.cpNode);_debug_.generated.elems.leaves.push(n)}const r=[];lm(rm(t.cpNode),(t=>{r.push(t)}));const o=function(t){return t.reduce((function(t,n){return t.cp.circle.radius>=n.cp.circle.radius?t:n}),t[0])}(r);"undefined"!=typeof _debug_&&_debug_.generated.elems.maxVertex.push(o);const i=new Set,s=new Map;fm(o,(function(t){const e=s.get(t)||n*t.cp.circle.radius,r=t.next,o=function(t,n,e=.4,r=16){if(4===n.length)return function(t,n,e=.4,r=16){const o=t[0],i=t[1];if(o===i)return 0;const[[s,c],[u,f],[l,h],[a,p]]=n;if(s===u&&u===l&&l===a&&c===f&&f===h&&h===p)return 0;const d=rd(n,o,i).ps,g=um(d,e);let v=0;for(let t=0;tn*c){for(const t of Cn(r))s.set(t,e-o);i.add(r.cp.circle)}})),function(t,n){const e=nm(n);function r(t){let n=t;const e=[];do{n.next!==n.nextOnCircle&&e.push(n),n=n.nextOnCircle}while(n!==t.prevOnCircle);return e}for(;e.length;){const o=e.pop();if(o.isHoleClosing||o.isIntersection)continue;if(!t.has(o.cp.circle))continue;let i=o.next;for(;;){i=i.next;let e=!1;const o=i.prevOnCircle;if(t.has(i.cp.circle))if(On(i,n))e=!0;else{const t=r(i);1===t.length?i=t[0]:e=!0}else e=!0;if(e){o.next=i,i.prev=o;break}}}}(i,o),"undefined"!=typeof _debug_&&_debug_.generated.elems.culls.push(Array.from(i));const c={cpNode:o,cpTrees:void 0};return function(t,n){"undefined"!=typeof _debug_&&(_debug_.generated.elems.sat.push(t),_debug_.generated.timing.sats=performance.now()-n)}(c,e),c}const am=1;function pm(t,n=am){for(;!zn(t);)t=t.next;const e=[],r=[t.prevOnCircle];let o=[];for(;r.length;){const t=r.pop();o.push(t);let i=Mn(t);if(zn(t)){o.length>1&&e.push(o),o=[];continue}if(1===i.length){r.push(i[0]);continue}if(i=i.filter((t=>!An(t))),0===i.length){e.push(o),o=[];continue}if(i.length>1){e.push(o),o=[],r.push(...i);continue}const s=_(N(M(Nn(t.next.prevOnCircle),0)),N(M(Nn(i[0]),0)));Math.abs(Math.asin(s)*(180/Math.PI))>n&&(e.push(o),o=[]),r.push(i[0])}return o.length&&e.push(o),e}let dm=0;function gm(t){return t.map((t=>{return(n=t.cp.pointOnShape).p[0]+", "+n.p[1]+" | bz: "+n.curve.idx+" | t: "+n.t;var n}))}function vm(t,n=3){return t[0].toFixed(n)+", "+t[1].toFixed(n)}const mm={δToString:gm,δsToString:function(t){return t.map(gm)},pointToStr:vm,pointsToStr:function(t,n=3){return t.map((t=>vm(t,n)))},nameObj:function(t,n=""){t.name=""+n+dm++}},bm="red thin10 nofill ",xm="http://www.w3.org/2000/svg";function _m(t,n,e=bm,r){const o=n.center,i=n.radius,s=document.createElementNS(xm,"circle");return s.setAttributeNS(null,"cx",o[0].toString()),s.setAttributeNS(null,"cy",o[1].toString()),s.setAttributeNS(null,"r",i.toString()),s.setAttributeNS(null,"class",e),t.appendChild(s),r&&setTimeout((()=>s.remove()),r),[s]}function Im(t,n,e=bm,r){const o=document.createElementNS(xm,"line");return o.setAttributeNS(null,"x1",n[0][0].toString()),o.setAttributeNS(null,"y1",n[0][1].toString()),o.setAttributeNS(null,"x2",n[1][0].toString()),o.setAttributeNS(null,"y2",n[1][1].toString()),o.setAttributeNS(null,"class",e),t.appendChild(o),r&&setTimeout((()=>o.remove()),r),[o]}function Nm(t,n,e=bm,r=3,o){const i=_m(t,{center:n,radius:r},e),s=[[n[0]-r,n[1]],[n[0]+r,n[1]]],c=[[n[0],n[1]-r],[n[0],n[1]+r]],u=Im(t,s,e),f=Im(t,c,e);return o&&setTimeout((()=>{i.forEach((t=>t.remove())),u.forEach((t=>t.remove())),f.forEach((t=>t.remove()))}),o),[...i,...u,...f]}function Sm(t){return 2===t?"L":3===t?"Q":4===t?"C":void 0}function Em(t,n,e=bm,r){const[[o,i],[s,c],[u,f]]=n,l=document.createElementNS(xm,"path");return l.setAttributeNS(null,"d",`M${o} ${i} Q${s} ${c} ${u} ${f}`),e&&l.setAttributeNS(null,"class",e),t.appendChild(l),r&&setTimeout((()=>l.remove()),r),[l]}function wm(t,n,e=bm,r){const[[o,i],[s,c],[u,f],[l,h]]=n;if(o===l&&s===l&&u===l&&i===h&&c===h&&f===h)return Nm(t,[o,i],e,.2,r);const a=document.createElementNS(xm,"path");return a.setAttributeNS(null,"d",`M${o} ${i} C${s} ${c} ${u} ${f} ${l} ${h}`),a.setAttributeNS(null,"class",e),t.appendChild(a),r&&setTimeout((()=>a.remove()),r),[a]}function Mm(t,n,e=bm,r){return 2===n.length?Im(t,n,e,r):3===n.length?Em(t,n,e,r):4===n.length?wm(t,n,e,r):[]}const Pm=["red","green","cyan","blue"];function Tm(t,n){const e=1-n;if(4===t.length){const[[r,o],[i,s],[c,u],[f,l]]=t;return[r*e**3+3*i*e**2*n+3*c*e*n**2+f*n**3,o*e**3+3*s*e**2*n+3*u*e*n**2+l*n**3]}if(3===t.length){const[[r,o],[i,s],[c,u]]=t;return[r*e**2+2*i*e*n+c*n**2,o*e**2+2*s*e*n+u*n**2]}if(2===t.length){const[[r,o],[i,s]]=t;return[r*e+i*n,o*e+s*n]}return[NaN,NaN]}function ym(t,n){return 2===t.length?function(t,n){const[[e,r],[o,i]]=t,s=1-n,c=[s*e+n*o,s*r+n*i];return[[[e,r],c],[c,[o,i]]]}(t,n):3===t.length?function(t,n){const[[e,r],[o,i],[s,c]]=t,u=1-n,f=[u*u*e+2*u*n*o+n*n*s,u*u*r+2*u*n*i+n*n*c];return[[[e,r],[u*e+n*o,u*r+n*i],f],[f,[u*o+n*s,u*i+n*c],[s,c]]]}(t,n):4===t.length?function(t,n){const[[e,r],[o,i],[s,c],[u,f]]=t,l=1-n,h=n*n,a=h*n,p=l*l,d=p*l,g=[a*u+3*l*h*s+3*p*n*o+d*e,a*f+3*l*h*c+3*p*n*i+d*r];return[[[e,r],[n*o+l*e,n*i+l*r],[h*s+2*l*n*o+p*e,h*c+2*l*n*i+p*r],g],[g,[h*u+2*n*l*s+p*o,h*f+2*n*l*c+p*i],[n*u+l*s,n*f+l*c],[u,f]]]}(t,n):[]}const Cm={circle:_m,crossHair:Nm,dot:function(t,n,e=3,r="red",o){const[i]=_m(t,{center:n,radius:e},"dot "+r,o);return o&&setTimeout((()=>i.remove()),o),[i]},line:Im,rect:function(t,n,e=bm,r){const[[o,i],[s,c]]=n,u=oa.remove()),r),[a]},beziers:function(t,n,e,r){const o=void 0===e,i=[];for(let r=0;ri.forEach((t=>t.remove()))),r),i},bezier:Mm,bezierPiece:function(t,n,e,r=bm,o){const i=e[0]===e[1]?Nm(t,Tm(n,e[0]),r,1.5):Mm(t,function(t,n){if(0===n[0]&&1===n[1])return t;if(n[0]===n[1]){const e=Tm(t,n[0]);return[e,e,e,e]}return 0===n[0]?ym(t,n[1])[0]:1===n[1]?ym(t,n[0])[1]:ym(ym(t,n[0])[1],(n[1]-n[0])/(1-n[0]))[0]}(n,e),r);return o&&setTimeout((()=>i.forEach((t=>t.remove()))),o),i},quadBezier:Em,cubicBezier:wm,polygon:function(t,n,e=bm,r){const o=document.createElementNS(xm,"path");let i=`M${n[0][0]} ${n[0][1]} L`;for(let t=0;to.remove()),r),[o]},loop:function(t,n,e=bm,r){if(!n.length)return[];const o=document.createElementNS(xm,"path");let i=`M${n[0][0][0]} ${n[0][0][1]} `;for(let t=0;to.remove()),r),[o]},polyline:function(t,n,e=bm,r){if(n.length<2)return[];const o=document.createElementNS(xm,"path");let i=`M${n[0][0]} ${n[0][1]} L`;for(let t=0;to.remove()),r),[o]},text:function(t,n,e,r,o=bm,i){const s=document.createElementNS(xm,"text");return s.setAttributeNS(null,"x",n[0].toString()),s.setAttributeNS(null,"y",n[1].toString()),s.setAttributeNS(null,"font-size",r.toString()),s.setAttributeNS(null,"class",o),s.textContent=e,t.appendChild(s),i&&setTimeout((()=>s.remove()),i),[s]}};function Om(t,n,e=1e3,r=1){const o=n.xs;console.log(n),console.log(n.xs.map((t=>({x:t.x,y:t.y,z:t.z,d:t.z?p(t.y.p,t.z.p):0,t:t.t})))),console.log(o.length);for(let i=0;i{const s=m(r,_debug_.generated.elems.twoProng_regular,(t=>t.circle.center));let c;[].push(s),console.log(s);for(let t=0;t<_debug_.generated.elems.twoProng_regular.length;t++)if(_debug_.generated.elems.twoProng_regular[t]===s){c=t;break}t&&function(t,n,e=1e3){const r=n.circle.center,{pos:o,circle:i,cpNode:s,xs:c,z:u,δ:f}=n;Cm.line(t,[o.p,r],"thin5 red",e),Cm.line(t,[u,r],"thin5 red",e)}(e,s,o),void 0!==c&&n&&Om(e,s,o,i)}}},zm={drawSpokes:function(t,n){const e=_debug_.generated.elems.threeProng[n],r=e.circle.center,o=e.poss;for(let n=0;n=i&&u<=s)){u++;continue}const e=[c[0],c[n],c[c.length-1]];for(let n=0;n<3;n++){const r=e[n],o=r[0],i=r[1],s=o.cp.pointOnShape,c=i.cp.pointOnShape,u=s.p,f=c.p,l=1+.5*n;v(u,f)?Cm.crossHair(t,u,"red thin10 nofill",l):(Cm.crossHair(t,u,"green thin10 nofill",l),Cm.crossHair(t,f,"blue thin10 nofill",l))}u++}},logδs:function(t){const n=_debug_.generated.elems.threeProng[t];console.log(n.cpss)},logNearest:function(t=!0,n=!0,e=!0){return function(r,o,i=1e3){const s=m(o,_debug_.generated.elems.threeProng,(t=>t.circle?t.circle.center:[0,0])),c=s.circle;console.log(s);const u={center:c.center,radius:c.radius||1};if(Cm.circle(r,u,"blue thin10 nofill",i),Cm.crossHair(r,c.center,"red thin2 nofill",2,i),t&&(Cm.line(r,[s.poss[0].p,c.center],"blue thin5 nofill",i),Cm.line(r,[s.poss[1].p,c.center],"blue thin5 nofill",i),Cm.line(r,[s.poss[2].p,c.center],"blue thin5 nofill",i)),e){const t=s.boundaries,n=t[0],e=t[t.length-1];Cm.beziers(r,n,"red thin20 nofill",i);for(let n=1;n{const s=e.cpNode;if(!s)return[];const c=[];return fm(s,(e=>{if(An(e))return;const r=Nn(e);r&&c.push(...Cm.bezier(t,r,n,o))})),c}}function Fm(t,n,e,r){const o=document.createElementNS("http://www.w3.org/2000/svg","circle");return o.setAttributeNS(null,"cx",n[0].toString()),o.setAttributeNS(null,"cy",n[1].toString()),o.setAttributeNS(null,"r",e.toString()+"%"),o.setAttributeNS(null,"class",r),t.appendChild(o),o}function Vm(t,n,e,r){const o=document.createElementNS("http://www.w3.org/2000/svg","circle");return o.setAttributeNS(null,"cx",n[0].toString()),o.setAttributeNS(null,"cy",n[1].toString()),o.setAttributeNS(null,"r",e.toString()+"%"),o.setAttributeNS(null,"class",r),t.appendChild(o),o}const km={oneProng:function(t,n,e,r=0,o=1){const i=n[0].cp,{circle:s,pointOnShape:c}=i;return[...Cm.dot(t,c.p,.02*o,"deeppink",r),...Cm.dot(t,s.center,.05*o,"deeppink",r),...Cm.circle(t,s,"deeppink thin5 nofill",r)]},oneProngAtDullCorner:function(t,n,e,r=1e3,o=1){const i=Qg(Number.POSITIVE_INFINITY,n);return[...Cm.dot(t,n.p,.1,"orange"),...Cm.dot(t,i.center,.25,"orange"),...Cm.circle(t,i,"orange thin10 nofill")]},twoProng_regular:Bm,twoProng_failed:Bm,twoProng_notAdded:Bm,twoProng_deleted:Bm,twoProng_holeClosing:Bm,threeProng:function(t,n,e,r=0,o=1){const i=function(t,n){return{center:t.center,radius:1*t.radius}}(n.circle),s=n.poss,c=Cm.dot(t,s[0].p,.01*o,"blue",r),u=Cm.dot(t,s[1].p,.02*o,"blue",r),f=Cm.dot(t,s[2].p,.03*o,"blue",r);return[...Cm.dot(t,i.center,.03*o,"blue",r),...c,...u,...f,...Cm.circle(t,i,"blue thin2 nofill",r)]},boundingHull:function(t,n,e="thin5 black nofill",r=0,o=1){return Cm.polygon(t,n,e,r)},looseBoundingBox:function(t,n,e="thin5 brown nofill",r=0,o=1){const[[i,s],[c,u]]=n;return n=[[i,s],[c,s],[c,u],[i,u]],Cm.polygon(t,n,e,r)},tightBoundingBox:function(t,n,e="thin5 pinker nofill",r=0,o=1){return Cm.polygon(t,n,"thin5 pinker nofill",r)},sharpCorner:function(t,n,e="green",r=0,o=1){const i=n.ps[n.ps.length-1];return Cm.dot(t,i,.6*o,"green",r)},dullCorner:function(t,n,e="orange",r=0,o=1){const i=n.ps,s=n.ps[i.length-1];return Cm.dot(t,s,.05*o,e,r)},vertex:function(t,n,e,r,o=1){const i=n.cp.circle,s="thin20",c=Cn(n);console.log(c);let u=[];u=[...Cm.circle(t,i,"red "+s+" nofill ",r),...Cm.crossHair(t,i.center,"red "+s+" nofill ",3,r)];for(let n=0;nt.p));if(void 0===l)continue;const h=jg(l.p,e);let a=f.curve,p=l.t;hn&&(n=o),i>n&&(n=i)}return n}function Wm(t){return Math.max(t.hL+t.hEL,t.hR+t.hER)}function Jm(t,n){const e=Wm(t)-Wm(n);return 0!==e?e:t.tS-n.tS}class Km{compare;heap=[];constructor(t){this.compare=t}insert(t){const n=this.heap;n.push(t);let e=n.length-1;for(;;){const r=(e-1-(e+1)%2)/2;if(-1===r)return;const o=n[r];if(this.compare(t,o)<0)break;n[r]=t,n[e]=o,e=r}}popMax(){const t=this.heap,n=t[0];return t[0]=t[t.length-1],t.length--,this.swimDown(),n}swimDown(){const t=this.heap,n=t.length;let e=0;for(;;){const r=2*e+1;if(r>=n)break;const o=2*e+2,i=o>=n||this.compare(t[r],t[o])>0?r:o,s=t[i],c=t[e];if(this.compare(c,s)>0)break;t[i]=c,t[e]=s,e=i}}swapMinOrMax(t){this.heap[0]=t,this.swimDown()}static getParentIdx(t){return(t-1-(t+1)%2)/2}static getLeftChild(t){return 2*t+1}static getRightChild(t){return 2*t+2}}const tb=Math.max;function nb(t,n,e,r=50){if(1===t.length)return Um(n,t[0]).d;if(1===n.length)return function(t,n){let e;if(4===t.length)e=$m(t,n);else if(3===t.length)e=Gm(t,n);else{if(2!==t.length){if(1===t.length)return{p:t[0],t:0,d:$r(t[0],n)};throw new Error("The given bezier curve must be of order <= 3.")}e=Hm(t,n)}const r=Ni(e,0,1);r.push(0),r.push(1);let o,i=Number.NEGATIVE_INFINITY;for(const e of r){const r=Jp(t,e),s=p(r,n);s>i&&(i=s,o={p:r,t:e,d:Zm(s)})}return o}(t,n[0]).d;if(2===t.length&&2===n.length){const e=Um(n,t[0]).d,r=Um(n,t[t.length-1]).d;return e>r?e:r}const o=tb(jm(t),jm(n));e=e||o/1e6;const[i,s]=eb(t,0,1),c={tS:0,tE:1,hL:Um(n,t[0]).d,hR:Um(n,t[t.length-1]).d,hEL:i,hER:s},u=new Km(Jm);u.insert(c);let f=0,l=Number.POSITIVE_INFINITY,h=Number.NEGATIVE_INFINITY;for(;;){const o=u.heap[0],{tS:i,tE:s,hL:c,hR:a}=o,p=(i+s)/2,[d,g]=eb(t,i,p),[v,m]=eb(t,p,s),b=Jp(t,p),x=$r(b,Um(n,b).p),_=tb(c,x,a);if(_>h&&(h=_),l=Wm(o),l-hr)return h;const I={tS:i,tE:p,hL:c,hR:x,hEL:d,hER:g},N={tS:p,tE:s,hL:x,hR:a,hEL:v,hER:m};u.swapMinOrMax(I),u.insert(N)}}function eb(t,n,e){const r=(e+n)/2,o=Ja(t,n,r),i=Ja(t,r,e);return[Yd(o),Yd(i)]}const rb=Math.max;function ob(t,n,e,r){const o=nb(t,n,e,r),i=nb(n,t,e,r);return rb(o,i)}function ib(t,n=15,e=.125,r=50){let o=t.cpNode;for(;!An(o);)o=o.next;const i=pm(o,n),s=[];for(let t=0;te);)s.push(n[o]);if(t+1===o)break}}for(const t of s){const n=An(t),e=Cn(t).length;n||2!==e||kn(t)}return{cpNode:o,cpTrees:void 0}}function sb(t,n,e,r){const o=[],i=In(e[t],e[n].next);for(;te);)s.push(n[c]);if(t+1===c);else{const e=n[t],r=n[c-1],i=cb(In(e,r.next)),s=i.slice().reverse();let u=e,f=0;for(;u!==r;){const t=Um(i,u.next.cp.circle.center).t;o.set(u,{ps:i,ts:[f,t]});const n=u.nextOnCircle.prev;o.set(n,{ps:s,ts:[1-t,1-f]}),f=t,u=u.next}o.set(u,{ps:i,ts:[f,1]});const l=u.nextOnCircle.prev;o.set(l,{ps:s,ts:[0,1-f]})}}}return{simpleMap:o,cpNode:t}}function fb(t,n,e,r){const o=[],i=In(e[t],e[n].next);for(let s=t;s