w-gis 1.0.22 → 1.0.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/README.md +2 -2
  2. package/dist/interp2.wk.umd.js +1 -0
  3. package/dist/w-gis.umd.js +2 -2
  4. package/dist/w-gis.umd.js.map +1 -1
  5. package/docs/-_class.mjs.html +1 -1
  6. package/docs/convertCoordinate.mjs.html +1 -1
  7. package/docs/examples/ex-getCenterOfMassMultiPolygon.html +1 -1
  8. package/docs/examples/ex-getCentroidMultiPolygon.html +1 -1
  9. package/docs/fixCloseMultiPolygon.mjs.html +1 -1
  10. package/docs/getAreaMultiPolygon.mjs.html +1 -1
  11. package/docs/getAreaMultiPolygonSm.mjs.html +1 -1
  12. package/docs/getAreaPolygon.mjs.html +1 -1
  13. package/docs/getAreaRingString.mjs.html +1 -1
  14. package/docs/getCenterOfMassMultiPolygon.mjs.html +1 -1
  15. package/docs/getCentroidMultiPolygon.mjs.html +1 -1
  16. package/docs/importTurf.mjs.html +1 -1
  17. package/docs/index.html +1 -1
  18. package/docs/interp2.mjs.html +146 -81
  19. package/docs/interp2Kriging.mjs.html +86 -86
  20. package/docs/interp2NaturalNeighbor.mjs.html +21 -18
  21. package/docs/normalizeArray.mjs.html +4 -4
  22. package/docs/ptsXYZtoArr.mjs.html +1 -1
  23. package/docs/ptsXYtoArr.mjs.html +1 -1
  24. package/docs/toMultiPolygon.mjs.html +1 -1
  25. package/docs/toPolygon.mjs.html +1 -1
  26. package/docs/w-gis.html +94 -13
  27. package/g.mjs +91 -73
  28. package/package.json +1 -1
  29. package/src/interp2.mjs +145 -80
  30. package/src/interp2Kriging.mjs +85 -85
  31. package/src/interp2NaturalNeighbor.mjs +20 -17
  32. package/src/interp2Normalize.mjs +53 -24
  33. package/src/normalizeArray.mjs +3 -3
  34. package/toolg/gDistRollup.mjs +34 -12
  35. package/_kriging/kriging-111440-townshipInt-All.txt.xlsx +0 -0
  36. package/_kriging/kriging-111442-townshipInt-All.txt.xlsx +0 -0
package/README.md CHANGED
@@ -13,7 +13,7 @@ To view documentation or get support, visit [docs](https://yuda-lyu.github.io/w-
13
13
 
14
14
  ## Installation
15
15
  ### Using npm(ES6 module):
16
- > **Note:** w-gis is mainly dependent on `@turf`, `proj4`, `d3-tricontour`, `lodash` and `wsemi`.
16
+ > **Note:** w-gis is mainly dependent on `@turf`, `proj4`, `d3-tricontour`, `d3-delaunay`, `polybooljs`, `lodash` and `wsemi`.
17
17
  ```alias
18
18
  npm i w-gis
19
19
  ```
@@ -23,6 +23,6 @@ npm i w-gis
23
23
 
24
24
  Add script for w-gis.
25
25
  ```alias
26
- <script src="https://cdn.jsdelivr.net/npm/w-gis@1.0.22/dist/w-gis.umd.js"></script>
26
+ <script src="https://cdn.jsdelivr.net/npm/w-gis@1.0.25/dist/w-gis.umd.js"></script>
27
27
 
28
28
  ```
@@ -0,0 +1 @@
1
+ !function(l,b){"object"==typeof exports&&"undefined"!=typeof module?module.exports=b(require("worker_threads")):"function"==typeof define&&define.amd?define(["worker_threads"],b):(l="undefined"!=typeof globalThis?globalThis:l||self).interp2=b(l.worker_threads)}(this,(function(l){"use strict";function b(l){return l&&"object"==typeof l&&"default"in l?l:{default:l}}var d=b(l);function Z(l){return Z="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(l){return typeof l}:function(l){return l&&"function"==typeof Symbol&&l.constructor===Symbol&&l!==Symbol.prototype?"symbol":typeof l},Z(l)}"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self&&self;function m(l){var b={exports:{}};return l(b,b.exports),b.exports}var X=m((function(l,b){l.exports=function(l){function b(l,b){(null==b||b>l.length)&&(b=l.length);for(var d=0,Z=new Array(b);d<b;d++)Z[d]=l[d];return Z}function d(l){return function(l){if(Array.isArray(l))return b(l)}(l)||function(l){if("undefined"!=typeof Symbol&&null!=l[Symbol.iterator]||null!=l["@@iterator"])return Array.from(l)}(l)||function(l,d){if(l){if("string"==typeof l)return b(l,d);var Z=Object.prototype.toString.call(l).slice(8,-1);return"Object"===Z&&l.constructor&&(Z=l.constructor.name),"Map"===Z||"Set"===Z?Array.from(l):"Arguments"===Z||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(Z)?b(l,d):void 0}}(l)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function m(l,b,d,Z,m,X,c){try{var G=l[X](c),i=G.value}catch(l){return void d(l)}G.done?b(i):Promise.resolve(i).then(Z,m)}function X(l){return X="function"==typeof Symbol&&"symbol"==Z(Symbol.iterator)?function(l){return Z(l)}:function(l){return l&&"function"==typeof Symbol&&l.constructor===Symbol&&l!==Symbol.prototype?"symbol":Z(l)},X(l)}function c(l){var b={exports:{}};return l(b,b.exports),b.exports}var G,i=c((function(l){var b=function(l){var b,d=Object.prototype,Z=d.hasOwnProperty,m="function"==typeof Symbol?Symbol:{},c=m.iterator||"@@iterator",G=m.asyncIterator||"@@asyncIterator",i=m.toStringTag||"@@toStringTag";function W(l,b,d){return Object.defineProperty(l,b,{value:d,enumerable:!0,configurable:!0,writable:!0}),l[b]}try{W({},"")}catch(l){W=function(l,b,d){return l[b]=d}}function p(l,b,d,Z){var m=b&&b.prototype instanceof o?b:o,X=Object.create(m.prototype),c=new T(Z||[]);return X._invoke=function(l,b,d){var Z=s;return function(m,X){if(Z===K)throw new Error("Generator is already running");if(Z===y){if("throw"===m)throw X;return J()}for(d.method=m,d.arg=X;;){var c=d.delegate;if(c){var G=S(c,d);if(G){if(G===h)continue;return G}}if("next"===d.method)d.sent=d._sent=d.arg;else if("throw"===d.method){if(Z===s)throw Z=y,d.arg;d.dispatchException(d.arg)}else"return"===d.method&&d.abrupt("return",d.arg);Z=K;var i=t(l,b,d);if("normal"===i.type){if(Z=d.done?y:u,i.arg===h)continue;return{value:i.arg,done:d.done}}"throw"===i.type&&(Z=y,d.method="throw",d.arg=i.arg)}}}(l,d,c),X}function t(l,b,d){try{return{type:"normal",arg:l.call(b,d)}}catch(l){return{type:"throw",arg:l}}}l.wrap=p;var s="suspendedStart",u="suspendedYield",K="executing",y="completed",h={};function o(){}function n(){}function I(){}var L={};W(L,c,(function(){return this}));var V=Object.getPrototypeOf,a=V&&V(V(g([])));a&&a!==d&&Z.call(a,c)&&(L=a);var x=I.prototype=o.prototype=Object.create(L);function Y(l){["next","throw","return"].forEach((function(b){W(l,b,(function(l){return this._invoke(b,l)}))}))}function C(l,b){function d(m,c,G,i){var W=t(l[m],l,c);if("throw"!==W.type){var p=W.arg,s=p.value;return s&&"object"===X(s)&&Z.call(s,"__await")?b.resolve(s.__await).then((function(l){d("next",l,G,i)}),(function(l){d("throw",l,G,i)})):b.resolve(s).then((function(l){p.value=l,G(p)}),(function(l){return d("throw",l,G,i)}))}i(W.arg)}var m;this._invoke=function(l,Z){function X(){return new b((function(b,m){d(l,Z,b,m)}))}return m=m?m.then(X,X):X()}}function S(l,d){var Z=l.iterator[d.method];if(Z===b){if(d.delegate=null,"throw"===d.method){if(l.iterator.return&&(d.method="return",d.arg=b,S(l,d),"throw"===d.method))return h;d.method="throw",d.arg=new TypeError("The iterator does not provide a 'throw' method")}return h}var m=t(Z,l.iterator,d.arg);if("throw"===m.type)return d.method="throw",d.arg=m.arg,d.delegate=null,h;var X=m.arg;return X?X.done?(d[l.resultName]=X.value,d.next=l.nextLoc,"return"!==d.method&&(d.method="next",d.arg=b),d.delegate=null,h):X:(d.method="throw",d.arg=new TypeError("iterator result is not an object"),d.delegate=null,h)}function H(l){var b={tryLoc:l[0]};1 in l&&(b.catchLoc=l[1]),2 in l&&(b.finallyLoc=l[2],b.afterLoc=l[3]),this.tryEntries.push(b)}function e(l){var b=l.completion||{};b.type="normal",delete b.arg,l.completion=b}function T(l){this.tryEntries=[{tryLoc:"root"}],l.forEach(H,this),this.reset(!0)}function g(l){if(l){var d=l[c];if(d)return d.call(l);if("function"==typeof l.next)return l;if(!isNaN(l.length)){var m=-1,X=function d(){for(;++m<l.length;)if(Z.call(l,m))return d.value=l[m],d.done=!1,d;return d.value=b,d.done=!0,d};return X.next=X}}return{next:J}}function J(){return{value:b,done:!0}}return n.prototype=I,W(x,"constructor",I),W(I,"constructor",n),n.displayName=W(I,i,"GeneratorFunction"),l.isGeneratorFunction=function(l){var b="function"==typeof l&&l.constructor;return!!b&&(b===n||"GeneratorFunction"===(b.displayName||b.name))},l.mark=function(l){return Object.setPrototypeOf?Object.setPrototypeOf(l,I):(l.__proto__=I,W(l,i,"GeneratorFunction")),l.prototype=Object.create(x),l},l.awrap=function(l){return{__await:l}},Y(C.prototype),W(C.prototype,G,(function(){return this})),l.AsyncIterator=C,l.async=function(b,d,Z,m,X){void 0===X&&(X=Promise);var c=new C(p(b,d,Z,m),X);return l.isGeneratorFunction(d)?c:c.next().then((function(l){return l.done?l.value:c.next()}))},Y(x),W(x,i,"Generator"),W(x,c,(function(){return this})),W(x,"toString",(function(){return"[object Generator]"})),l.keys=function(l){var b=[];for(var d in l)b.push(d);return b.reverse(),function d(){for(;b.length;){var Z=b.pop();if(Z in l)return d.value=Z,d.done=!1,d}return d.done=!0,d}},l.values=g,T.prototype={constructor:T,reset:function(l){if(this.prev=0,this.next=0,this.sent=this._sent=b,this.done=!1,this.delegate=null,this.method="next",this.arg=b,this.tryEntries.forEach(e),!l)for(var d in this)"t"===d.charAt(0)&&Z.call(this,d)&&!isNaN(+d.slice(1))&&(this[d]=b)},stop:function(){this.done=!0;var l=this.tryEntries[0].completion;if("throw"===l.type)throw l.arg;return this.rval},dispatchException:function(l){if(this.done)throw l;var d=this;function m(Z,m){return G.type="throw",G.arg=l,d.next=Z,m&&(d.method="next",d.arg=b),!!m}for(var X=this.tryEntries.length-1;X>=0;--X){var c=this.tryEntries[X],G=c.completion;if("root"===c.tryLoc)return m("end");if(c.tryLoc<=this.prev){var i=Z.call(c,"catchLoc"),W=Z.call(c,"finallyLoc");if(i&&W){if(this.prev<c.catchLoc)return m(c.catchLoc,!0);if(this.prev<c.finallyLoc)return m(c.finallyLoc)}else if(i){if(this.prev<c.catchLoc)return m(c.catchLoc,!0)}else{if(!W)throw new Error("try statement without catch or finally");if(this.prev<c.finallyLoc)return m(c.finallyLoc)}}}},abrupt:function(l,b){for(var d=this.tryEntries.length-1;d>=0;--d){var m=this.tryEntries[d];if(m.tryLoc<=this.prev&&Z.call(m,"finallyLoc")&&this.prev<m.finallyLoc){var X=m;break}}X&&("break"===l||"continue"===l)&&X.tryLoc<=b&&b<=X.finallyLoc&&(X=null);var c=X?X.completion:{};return c.type=l,c.arg=b,X?(this.method="next",this.next=X.finallyLoc,h):this.complete(c)},complete:function(l,b){if("throw"===l.type)throw l.arg;return"break"===l.type||"continue"===l.type?this.next=l.arg:"return"===l.type?(this.rval=this.arg=l.arg,this.method="return",this.next="end"):"normal"===l.type&&b&&(this.next=b),h},finish:function(l){for(var b=this.tryEntries.length-1;b>=0;--b){var d=this.tryEntries[b];if(d.finallyLoc===l)return this.complete(d.completion,d.afterLoc),e(d),h}},catch:function(l){for(var b=this.tryEntries.length-1;b>=0;--b){var d=this.tryEntries[b];if(d.tryLoc===l){var Z=d.completion;if("throw"===Z.type){var m=Z.arg;e(d)}return m}}throw new Error("illegal catch attempt")},delegateYield:function(l,d,Z){return this.delegate={iterator:g(l),resultName:d,nextLoc:Z},"next"===this.method&&(this.arg=b),h}},l}(l.exports);try{regeneratorRuntime=b}catch(l){"object"===("undefined"==typeof globalThis?"undefined":X(globalThis))?globalThis.regeneratorRuntime=b:Function("r","regeneratorRuntime = r")(b)}})),W=c((function(l){var b=Object.prototype.hasOwnProperty,d="~";function Z(){}function m(l,b,d){this.fn=l,this.context=b,this.once=d||!1}function X(l,b,Z,X,c){if("function"!=typeof Z)throw new TypeError("The listener must be a function");var G=new m(Z,X||l,c),i=d?d+b:b;return l._events[i]?l._events[i].fn?l._events[i]=[l._events[i],G]:l._events[i].push(G):(l._events[i]=G,l._eventsCount++),l}function c(l,b){0==--l._eventsCount?l._events=new Z:delete l._events[b]}function G(){this._events=new Z,this._eventsCount=0}Object.create&&(Z.prototype=Object.create(null),(new Z).__proto__||(d=!1)),G.prototype.eventNames=function(){var l,Z,m=[];if(0===this._eventsCount)return m;for(Z in l=this._events)b.call(l,Z)&&m.push(d?Z.slice(1):Z);return Object.getOwnPropertySymbols?m.concat(Object.getOwnPropertySymbols(l)):m},G.prototype.listeners=function(l){var b=d?d+l:l,Z=this._events[b];if(!Z)return[];if(Z.fn)return[Z.fn];for(var m=0,X=Z.length,c=new Array(X);m<X;m++)c[m]=Z[m].fn;return c},G.prototype.listenerCount=function(l){var b=d?d+l:l,Z=this._events[b];return Z?Z.fn?1:Z.length:0},G.prototype.emit=function(l,b,Z,m,X,c){var G=d?d+l:l;if(!this._events[G])return!1;var i,W,p=this._events[G],t=arguments.length;if(p.fn){switch(p.once&&this.removeListener(l,p.fn,void 0,!0),t){case 1:return p.fn.call(p.context),!0;case 2:return p.fn.call(p.context,b),!0;case 3:return p.fn.call(p.context,b,Z),!0;case 4:return p.fn.call(p.context,b,Z,m),!0;case 5:return p.fn.call(p.context,b,Z,m,X),!0;case 6:return p.fn.call(p.context,b,Z,m,X,c),!0}for(W=1,i=new Array(t-1);W<t;W++)i[W-1]=arguments[W];p.fn.apply(p.context,i)}else{var s,u=p.length;for(W=0;W<u;W++)switch(p[W].once&&this.removeListener(l,p[W].fn,void 0,!0),t){case 1:p[W].fn.call(p[W].context);break;case 2:p[W].fn.call(p[W].context,b);break;case 3:p[W].fn.call(p[W].context,b,Z);break;case 4:p[W].fn.call(p[W].context,b,Z,m);break;default:if(!i)for(s=1,i=new Array(t-1);s<t;s++)i[s-1]=arguments[s];p[W].fn.apply(p[W].context,i)}}return!0},G.prototype.on=function(l,b,d){return X(this,l,b,d,!1)},G.prototype.once=function(l,b,d){return X(this,l,b,d,!0)},G.prototype.removeListener=function(l,b,Z,m){var X=d?d+l:l;if(!this._events[X])return this;if(!b)return c(this,X),this;var G=this._events[X];if(G.fn)G.fn!==b||m&&!G.once||Z&&G.context!==Z||c(this,X);else{for(var i=0,W=[],p=G.length;i<p;i++)(G[i].fn!==b||m&&!G[i].once||Z&&G[i].context!==Z)&&W.push(G[i]);W.length?this._events[X]=1===W.length?W[0]:W:c(this,X)}return this},G.prototype.removeAllListeners=function(l){var b;return l?(b=d?d+l:l,this._events[b]&&c(this,b)):(this._events=new Z,this._eventsCount=0),this},G.prototype.off=G.prototype.removeListener,G.prototype.addListener=G.prototype.on,G.prefixed=d,G.EventEmitter=G,l.exports=G}));return function(){if("nodejs"!=("undefined"!=typeof window&&void 0!==window.document?"browser":"nodejs"))return null;function b(){return new W}function Z(){var l,b,d=new Promise((function(){l=arguments[0],b=arguments[1]}));return d.resolve=l,d.reject=b,d}function X(){for(var l=arguments.length>0&&void 0!==arguments[0]?arguments[0]:10,b=[],d="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(""),Z=d.length,m=0;m<l;m++)b[m]=d[0|Math.random()*Z];return b.join("")}var c,p=(c="

        let { parentPort } = require('worker_threads')
        

var t=Array.isArray,e="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function n(t){var e={exports:{}};return t(e,e.exports),e.exports}var r="object"==typeof e&&e&&e.Object===Object&&e,i="object"==typeof self&&self&&self.Object===Object&&self,o=r||i||Function("return this")(),l=o.Symbol,a=Object.prototype,s=a.hasOwnProperty,u=a.toString,c=l?l.toStringTag:void 0;var f=function(t){var e=s.call(t,c),n=t[c];try{t[c]=void 0;var r=!0}catch(t){}var i=u.call(t);return r&&(e?t[c]=n:delete t[c]),i},h=Object.prototype.toString;var g=function(t){return h.call(t)},v=l?l.toStringTag:void 0;var d=function(t){return null==t?void 0===t?"[object Undefined]":"[object Null]":v&&v in Object(t)?f(t):g(t)};var p=function(t){return null!=t&&"object"==typeof t};var y=function(t){return"symbol"==typeof t||p(t)&&"[object Symbol]"==d(t)},_=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,m=/^\w*$/;var b=function(e,n){if(t(e))return!1;var r=typeof e;return!("number"!=r&&"symbol"!=r&&"boolean"!=r&&null!=e&&!y(e))||(m.test(e)||!_.test(e)||null!=n&&e in Object(n))};var x=function(t){var e=typeof t;return null!=t&&("object"==e||"function"==e)};var w,j=function(t){if(!x(t))return!1;var e=d(t);return"[object Function]"==e||"[object GeneratorFunction]"==e||"[object AsyncFunction]"==e||"[object Proxy]"==e},A=o["__core-js_shared__"],O=(w=/[^.]+$/.exec(A&&A.keys&&A.keys.IE_PROTO||""))?"Symbol(src)_1."+w:"";var S=function(t){return!!O&&O in t},M=Function.prototype.toString;var P=function(t){if(null!=t){try{return M.call(t)}catch(t){}try{return t+""}catch(t){}}return""},k=/^\[object .+?Constructor\]$/,F=Function.prototype,T=Object.prototype,z=F.toString,$=T.hasOwnProperty,I=RegExp("^"+z.call($).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");var E=function(t){return!(!x(t)||S(t))&&(j(t)?I:k).test(P(t))};var N=function(t,e){return null==t?void 0:t[e]};var R=function(t,e){var n=N(t,e);return E(n)?n:void 0},C=R(Object,"create");var B=function(){this.__data__=C?C(null):{},this.size=0};var U=function(t){var e=this.has(t)&&delete this.__data__[t];return this.size-=e?1:0,e},L=Object.prototype.hasOwnProperty;var D=function(t){var e=this.__data__;if(C){var n=e[t];return"__lodash_hash_undefined__"===n?void 0:n}return L.call(e,t)?e[t]:void 0},H=Object.prototype.hasOwnProperty;var K=function(t){var e=this.__data__;return C?void 0!==e[t]:H.call(e,t)};var X=function(t,e){var n=this.__data__;return this.size+=this.has(t)?0:1,n[t]=C&&void 0===e?"__lodash_hash_undefined__":e,this};function J(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var r=t[e];this.set(r[0],r[1])}}J.prototype.clear=B,J.prototype.delete=U,J.prototype.get=D,J.prototype.has=K,J.prototype.set=X;var Y=J;var Z=function(){this.__data__=[],this.size=0};var V=function(t,e){return t===e||t!=t&&e!=e};var W=function(t,e){for(var n=t.length;n--;)if(V(t[n][0],e))return n;return-1},q=Array.prototype.splice;var G=function(t){var e=this.__data__,n=W(e,t);return!(n<0)&&(n==e.length-1?e.pop():q.call(e,n,1),--this.size,!0)};var Q=function(t){var e=this.__data__,n=W(e,t);return n<0?void 0:e[n][1]};var tt=function(t){return W(this.__data__,t)>-1};var et=function(t,e){var n=this.__data__,r=W(n,t);return r<0?(++this.size,n.push([t,e])):n[r][1]=e,this};function nt(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var r=t[e];this.set(r[0],r[1])}}nt.prototype.clear=Z,nt.prototype.delete=G,nt.prototype.get=Q,nt.prototype.has=tt,nt.prototype.set=et;var rt=nt,it=R(o,"Map");var ot=function(){this.size=0,this.__data__={hash:new Y,map:new(it||rt),string:new Y}};var lt=function(t){var e=typeof t;return"string"==e||"number"==e||"symbol"==e||"boolean"==e?"__proto__"!==t:null===t};var at=function(t,e){var n=t.__data__;return lt(e)?n["string"==typeof e?"string":"hash"]:n.map};var st=function(t){var e=at(this,t).delete(t);return this.size-=e?1:0,e};var ut=function(t){return at(this,t).get(t)};var ct=function(t){return at(this,t).has(t)};var ft=function(t,e){var n=at(this,t),r=n.size;return n.set(t,e),this.size+=n.size==r?0:1,this};function ht(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var r=t[e];this.set(r[0],r[1])}}ht.prototype.clear=ot,ht.prototype.delete=st,ht.prototype.get=ut,ht.prototype.has=ct,ht.prototype.set=ft;var gt=ht;function vt(t,e){if("function"!=typeof t||null!=e&&"function"!=typeof e)throw new TypeError("Expected a function");var n=function(){var r=arguments,i=e?e.apply(this,r):r[0],o=n.cache;if(o.has(i))return o.get(i);var l=t.apply(this,r);return n.cache=o.set(i,l)||o,l};return n.cache=new(vt.Cache||gt),n}vt.Cache=gt;var dt=vt;var pt=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,yt=/\\(\\)?/g,_t=function(t){var e=dt(t,(function(t){return 500===n.size&&n.clear(),t})),n=e.cache;return e}((function(t){var e=[];return 46===t.charCodeAt(0)&&e.push(""),t.replace(pt,(function(t,n,r,i){e.push(r?i.replace(yt,"$1"):n||t)})),e}));var mt=function(t,e){for(var n=-1,r=null==t?0:t.length,i=Array(r);++n<r;)i[n]=e(t[n],n,t);return i},bt=l?l.prototype:void 0,xt=bt?bt.toString:void 0;var wt=function e(n){if("string"==typeof n)return n;if(t(n))return mt(n,e)+"";if(y(n))return xt?xt.call(n):"";var r=n+"";return"0"==r&&1/n==-Infinity?"-0":r};var jt=function(t){return null==t?"":wt(t)};var At=function(e,n){return t(e)?e:b(e,n)?[e]:_t(jt(e))};var Ot=function(t){if("string"==typeof t||y(t))return t;var e=t+"";return"0"==e&&1/t==-Infinity?"-0":e};var St=function(t,e){for(var n=0,r=(e=At(e,t)).length;null!=t&&n<r;)t=t[Ot(e[n++])];return n&&n==r?t:void 0};var Mt=function(t,e,n){var r=null==t?void 0:St(t,e);return void 0===r?n:r};var Pt=function(t){return!0===t||!1===t||p(t)&&"[object Boolean]"==d(t)};function kt(t){return Pt(t)}function Ft(t){return"[object String]"===Object.prototype.toString.call(t)}function Tt(t){return!(!Ft(t)||""===t)}var zt=function(t,e){for(var n=-1,r=null==t?0:t.length;++n<r&&!1!==e(t[n],n,t););return t};var $t=function(t){return function(e,n,r){for(var i=-1,o=Object(e),l=r(e),a=l.length;a--;){var s=l[t?a:++i];if(!1===n(o[s],s,o))break}return e}}();var It=function(t,e){for(var n=-1,r=Array(t);++n<t;)r[n]=e(n);return r};var Et=function(t){return p(t)&&"[object Arguments]"==d(t)},Nt=Object.prototype,Rt=Nt.hasOwnProperty,Ct=Nt.propertyIsEnumerable,Bt=Et(function(){return arguments}())?Et:function(t){return p(t)&&Rt.call(t,"callee")&&!Ct.call(t,"callee")};var Ut=function(){return!1},Lt=n((function(t,e){var n=e&&!e.nodeType&&e,r=n&&t&&!t.nodeType&&t,i=r&&r.exports===n?o.Buffer:void 0,l=(i?i.isBuffer:void 0)||Ut;t.exports=l})),Dt=/^(?:0|[1-9]\d*)$/;var Ht=function(t,e){var n=typeof t;return!!(e=null==e?9007199254740991:e)&&("number"==n||"symbol"!=n&&Dt.test(t))&&t>-1&&t%1==0&&t<e};var Kt=function(t){return"number"==typeof t&&t>-1&&t%1==0&&t<=9007199254740991},Xt={};Xt["[object Float32Array]"]=Xt["[object Float64Array]"]=Xt["[object Int8Array]"]=Xt["[object Int16Array]"]=Xt["[object Int32Array]"]=Xt["[object Uint8Array]"]=Xt["[object Uint8ClampedArray]"]=Xt["[object Uint16Array]"]=Xt["[object Uint32Array]"]=!0,Xt["[object Arguments]"]=Xt["[object Array]"]=Xt["[object ArrayBuffer]"]=Xt["[object Boolean]"]=Xt["[object DataView]"]=Xt["[object Date]"]=Xt["[object Error]"]=Xt["[object Function]"]=Xt["[object Map]"]=Xt["[object Number]"]=Xt["[object Object]"]=Xt["[object RegExp]"]=Xt["[object Set]"]=Xt["[object String]"]=Xt["[object WeakMap]"]=!1;var Jt=function(t){return p(t)&&Kt(t.length)&&!!Xt[d(t)]};var Yt=function(t){return function(e){return t(e)}},Zt=n((function(t,e){var n=e&&!e.nodeType&&e,i=n&&t&&!t.nodeType&&t,o=i&&i.exports===n&&r.process,l=function(){try{var t=i&&i.require&&i.require("util").types;return t||o&&o.binding&&o.binding("util")}catch(t){}}();t.exports=l})),Vt=Zt&&Zt.isTypedArray,Wt=Vt?Yt(Vt):Jt,qt=Object.prototype.hasOwnProperty;var Gt=function(e,n){var r=t(e),i=!r&&Bt(e),o=!r&&!i&&Lt(e),l=!r&&!i&&!o&&Wt(e),a=r||i||o||l,s=a?It(e.length,String):[],u=s.length;for(var c in e)!n&&!qt.call(e,c)||a&&("length"==c||o&&("offset"==c||"parent"==c)||l&&("buffer"==c||"byteLength"==c||"byteOffset"==c)||Ht(c,u))||s.push(c);return s},Qt=Object.prototype;var te=function(t){var e=t&&t.constructor;return t===("function"==typeof e&&e.prototype||Qt)};var ee=function(t,e){return function(n){return t(e(n))}}(Object.keys,Object),ne=Object.prototype.hasOwnProperty;var re=function(t){if(!te(t))return ee(t);var e=[];for(var n in Object(t))ne.call(t,n)&&"constructor"!=n&&e.push(n);return e};var ie=function(t){return null!=t&&Kt(t.length)&&!j(t)};var oe=function(t){return ie(t)?Gt(t):re(t)};var le=function(t,e){return function(n,r){if(null==n)return n;if(!ie(n))return t(n,r);for(var i=n.length,o=e?i:-1,l=Object(n);(e?o--:++o<i)&&!1!==r(l[o],o,l););return n}}((function(t,e){return t&&$t(t,e,oe)}));var ae=function(t){return t};var se=function(t){return"function"==typeof t?t:ae};var ue=function(e,n){return(t(e)?zt:le)(e,se(n))};var ce=function(){this.__data__=new rt,this.size=0};var fe=function(t){var e=this.__data__,n=e.delete(t);return this.size=e.size,n};var he=function(t){return this.__data__.get(t)};var ge=function(t){return this.__data__.has(t)};var ve=function(t,e){var n=this.__data__;if(n instanceof rt){var r=n.__data__;if(!it||r.length<199)return r.push([t,e]),this.size=++n.size,this;n=this.__data__=new gt(r)}return n.set(t,e),this.size=n.size,this};function de(t){var e=this.__data__=new rt(t);this.size=e.size}de.prototype.clear=ce,de.prototype.delete=fe,de.prototype.get=he,de.prototype.has=ge,de.prototype.set=ve;var pe=de;var ye=function(t){return this.__data__.set(t,"__lodash_hash_undefined__"),this};var _e=function(t){return this.__data__.has(t)};function me(t){var e=-1,n=null==t?0:t.length;for(this.__data__=new gt;++e<n;)this.add(t[e])}me.prototype.add=me.prototype.push=ye,me.prototype.has=_e;var be=me;var xe=function(t,e){for(var n=-1,r=null==t?0:t.length;++n<r;)if(e(t[n],n,t))return!0;return!1};var we=function(t,e){return t.has(e)};var je=function(t,e,n,r,i,o){var l=1&n,a=t.length,s=e.length;if(a!=s&&!(l&&s>a))return!1;var u=o.get(t),c=o.get(e);if(u&&c)return u==e&&c==t;var f=-1,h=!0,g=2&n?new be:void 0;for(o.set(t,e),o.set(e,t);++f<a;){var v=t[f],d=e[f];if(r)var p=l?r(d,v,f,e,t,o):r(v,d,f,t,e,o);if(void 0!==p){if(p)continue;h=!1;break}if(g){if(!xe(e,(function(t,e){if(!we(g,e)&&(v===t||i(v,t,n,r,o)))return g.push(e)}))){h=!1;break}}else if(v!==d&&!i(v,d,n,r,o)){h=!1;break}}return o.delete(t),o.delete(e),h},Ae=o.Uint8Array;var Oe=function(t){var e=-1,n=Array(t.size);return t.forEach((function(t,r){n[++e]=[r,t]})),n};var Se=function(t){var e=-1,n=Array(t.size);return t.forEach((function(t){n[++e]=t})),n},Me=l?l.prototype:void 0,Pe=Me?Me.valueOf:void 0;var ke=function(t,e,n,r,i,o,l){switch(n){case"[object DataView]":if(t.byteLength!=e.byteLength||t.byteOffset!=e.byteOffset)return!1;t=t.buffer,e=e.buffer;case"[object ArrayBuffer]":return!(t.byteLength!=e.byteLength||!o(new Ae(t),new Ae(e)));case"[object Boolean]":case"[object Date]":case"[object Number]":return V(+t,+e);case"[object Error]":return t.name==e.name&&t.message==e.message;case"[object RegExp]":case"[object String]":return t==e+"";case"[object Map]":var a=Oe;case"[object Set]":var s=1&r;if(a||(a=Se),t.size!=e.size&&!s)return!1;var u=l.get(t);if(u)return u==e;r|=2,l.set(t,e);var c=je(a(t),a(e),r,i,o,l);return l.delete(t),c;case"[object Symbol]":if(Pe)return Pe.call(t)==Pe.call(e)}return!1};var Fe=function(t,e){for(var n=-1,r=e.length,i=t.length;++n<r;)t[i+n]=e[n];return t};var Te=function(e,n,r){var i=n(e);return t(e)?i:Fe(i,r(e))};var ze=function(t,e){for(var n=-1,r=null==t?0:t.length,i=0,o=[];++n<r;){var l=t[n];e(l,n,t)&&(o[i++]=l)}return o};var $e=function(){return[]},Ie=Object.prototype.propertyIsEnumerable,Ee=Object.getOwnPropertySymbols,Ne=Ee?function(t){return null==t?[]:(t=Object(t),ze(Ee(t),(function(e){return Ie.call(t,e)})))}:$e;var Re=function(t){return Te(t,oe,Ne)},Ce=Object.prototype.hasOwnProperty;var Be=function(t,e,n,r,i,o){var l=1&n,a=Re(t),s=a.length;if(s!=Re(e).length&&!l)return!1;for(var u=s;u--;){var c=a[u];if(!(l?c in e:Ce.call(e,c)))return!1}var f=o.get(t),h=o.get(e);if(f&&h)return f==e&&h==t;var g=!0;o.set(t,e),o.set(e,t);for(var v=l;++u<s;){var d=t[c=a[u]],p=e[c];if(r)var y=l?r(p,d,c,e,t,o):r(d,p,c,t,e,o);if(!(void 0===y?d===p||i(d,p,n,r,o):y)){g=!1;break}v||(v="constructor"==c)}if(g&&!v){var _=t.constructor,m=e.constructor;_==m||!("constructor"in t)||!("constructor"in e)||"function"==typeof _&&_ instanceof _&&"function"==typeof m&&m instanceof m||(g=!1)}return o.delete(t),o.delete(e),g},Ue=R(o,"DataView"),Le=R(o,"Promise"),De=R(o,"Set"),He=R(o,"WeakMap"),Ke=P(Ue),Xe=P(it),Je=P(Le),Ye=P(De),Ze=P(He),Ve=d;(Ue&&"[object DataView]"!=Ve(new Ue(new ArrayBuffer(1)))||it&&"[object Map]"!=Ve(new it)||Le&&"[object Promise]"!=Ve(Le.resolve())||De&&"[object Set]"!=Ve(new De)||He&&"[object WeakMap]"!=Ve(new He))&&(Ve=function(t){var e=d(t),n="[object Object]"==e?t.constructor:void 0,r=n?P(n):"";if(r)switch(r){case Ke:return"[object DataView]";case Xe:return"[object Map]";case Je:return"[object Promise]";case Ye:return"[object Set]";case Ze:return"[object WeakMap]"}return e});var We=Ve,qe="[object Object]",Ge=Object.prototype.hasOwnProperty;var Qe=function(e,n,r,i,o,l){var a=t(e),s=t(n),u=a?"[object Array]":We(e),c=s?"[object Array]":We(n),f=(u="[object Arguments]"==u?qe:u)==qe,h=(c="[object Arguments]"==c?qe:c)==qe,g=u==c;if(g&&Lt(e)){if(!Lt(n))return!1;a=!0,f=!1}if(g&&!f)return l||(l=new pe),a||Wt(e)?je(e,n,r,i,o,l):ke(e,n,u,r,i,o,l);if(!(1&r)){var v=f&&Ge.call(e,"__wrapped__"),d=h&&Ge.call(n,"__wrapped__");if(v||d){var p=v?e.value():e,y=d?n.value():n;return l||(l=new pe),o(p,y,r,i,l)}}return!!g&&(l||(l=new pe),Be(e,n,r,i,o,l))};var tn=function t(e,n,r,i,o){return e===n||(null==e||null==n||!p(e)&&!p(n)?e!=e&&n!=n:Qe(e,n,r,i,t,o))};var en=function(t,e,n,r){var i=n.length,o=i,l=!r;if(null==t)return!o;for(t=Object(t);i--;){var a=n[i];if(l&&a[2]?a[1]!==t[a[0]]:!(a[0]in t))return!1}for(;++i<o;){var s=(a=n[i])[0],u=t[s],c=a[1];if(l&&a[2]){if(void 0===u&&!(s in t))return!1}else{var f=new pe;if(r)var h=r(u,c,s,t,e,f);if(!(void 0===h?tn(c,u,3,r,f):h))return!1}}return!0};var nn=function(t){return t==t&&!x(t)};var rn=function(t){for(var e=oe(t),n=e.length;n--;){var r=e[n],i=t[r];e[n]=[r,i,nn(i)]}return e};var on=function(t,e){return function(n){return null!=n&&(n[t]===e&&(void 0!==e||t in Object(n)))}};var ln=function(t){var e=rn(t);return 1==e.length&&e[0][2]?on(e[0][0],e[0][1]):function(n){return n===t||en(n,t,e)}};var an=function(t,e){return null!=t&&e in Object(t)};var sn=function(e,n,r){for(var i=-1,o=(n=At(n,e)).length,l=!1;++i<o;){var a=Ot(n[i]);if(!(l=null!=e&&r(e,a)))break;e=e[a]}return l||++i!=o?l:!!(o=null==e?0:e.length)&&Kt(o)&&Ht(a,o)&&(t(e)||Bt(e))};var un=function(t,e){return null!=t&&sn(t,e,an)};var cn=function(t,e){return b(t)&&nn(e)?on(Ot(t),e):function(n){var r=Mt(n,t);return void 0===r&&r===e?un(n,t):tn(e,r,3)}};var fn=function(t){return function(e){return null==e?void 0:e[t]}};var hn=function(t){return function(e){return St(e,t)}};var gn=function(t){return b(t)?fn(Ot(t)):hn(t)};var vn=function(e){return"function"==typeof e?e:null==e?ae:"object"==typeof e?t(e)?cn(e[0],e[1]):ln(e):gn(e)};var dn=function(t,e){var n=-1,r=ie(t)?Array(t.length):[];return le(t,(function(t,i,o){r[++n]=e(t,i,o)})),r};var pn=function(e,n){return(t(e)?mt:dn)(e,vn(n))};var yn=function(t,e){for(var n,r=-1,i=t.length;++r<i;){var o=e(t[r]);void 0!==o&&(n=void 0===n?o:n+o)}return n};var _n=function(t){return t&&t.length?yn(t,ae):0};var mn=function(e){return"string"==typeof e||!t(e)&&p(e)&&"[object String]"==d(e)},bn=fn("length"),xn=RegExp("[\\u200d\\ud800-\\udfff\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff\\ufe0e\\ufe0f]");var wn=function(t){return xn.test(t)},jn="[\\ud800-\\udfff]",An="[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]",On="\\ud83c[\\udffb-\\udfff]",Sn="[^\\ud800-\\udfff]",Mn="(?:\\ud83c[\\udde6-\\uddff]){2}",Pn="[\\ud800-\\udbff][\\udc00-\\udfff]",kn="(?:"+An+"|"+On+")"+"?",Fn="[\\ufe0e\\ufe0f]?"+kn+("(?:\\u200d(?:"+[Sn,Mn,Pn].join("|")+")[\\ufe0e\\ufe0f]?"+kn+")*"),Tn="(?:"+[Sn+An+"?",An,Mn,Pn,jn].join("|")+")",zn=RegExp(On+"(?="+On+")|"+Tn+Fn,"g");var $n=function(t){for(var e=zn.lastIndex=0;zn.test(t);)++e;return e};var In=function(t){return wn(t)?$n(t):bn(t)};var En=function(t){if(null==t)return 0;if(ie(t))return mn(t)?In(t):t.length;var e=We(t);return"[object Map]"==e||"[object Set]"==e?t.size:re(t).length};var Nn=function(t){return"number"==typeof t||p(t)&&"[object Number]"==d(t)};function Rn(t){return"[object Object]"===Object.prototype.toString.call(t)}function Cn(t){if(Rn(t)){for(let e in t)return!0;return!1}return!1}function Bn(t){return"[object Array]"===Object.prototype.toString.call(t)}function Un(t){return!!function(t){return"[object Undefined]"===Object.prototype.toString.call(t)}(t)||(!!function(t){return"[object Null]"===Object.prototype.toString.call(t)}(t)||(!!function(t){if(Rn(t)){for(let e in t)return!1;return!0}return!1}(t)||(!!function(t){return!(!Ft(t)||""!==t)}(t)||!!function(t){return!!Bn(t)&&0===t.length}(t))))}function Ln(t){return!!Bn(t)&&(0!==t.length&&(1!==t.length||!Un(t[0])))}function Dn(t){let e=!1;return Tt(t)?e=!isNaN(Number(t)):function(t){return"[object Number]"===Object.prototype.toString.call(t)}(t)&&(e=!0),e}var Hn=/\s/;var Kn=function(t){for(var e=t.length;e--&&Hn.test(t.charAt(e)););return e},Xn=/^\s+/;var Jn=function(t){return t?t.slice(0,Kn(t)+1).replace(Xn,""):t},Yn=/^[-+]0x[0-9a-f]+$/i,Zn=/^0b[01]+$/i,Vn=/^0o[0-7]+$/i,Wn=parseInt;var qn=function(t){if("number"==typeof t)return t;if(y(t))return NaN;if(x(t)){var e="function"==typeof t.valueOf?t.valueOf():t;t=x(e)?e+"":e}if("string"!=typeof t)return 0===t?t:+t;t=Jn(t);var n=Zn.test(t);return n||Vn.test(t)?Wn(t.slice(2),n?2:8):Yn.test(t)?NaN:+t};var Gn=function(t){return t?Infinity===(t=qn(t))||-Infinity===t?17976931348623157e292*(t<0?-1:1):t==t?t:0:0===t?t:0};function Qn(t){if(!Dn(t))return 0;return Gn(t)}function tr(t,e){return!!Rn(t)&&(!(!Tt(e)&&!Dn(e))&&e in t)}function er(t,e={}){if(En(t)<=0)return[];let n=Mt(e,"keyX");Tt(n)||(n="x");let r=Mt(e,"keyY");Tt(r)||(r="y");let i=[];return ue(t,(t=>{let e=null,o=null;Bn(t)&&En(t)>=2?(e=Mt(t,0),o=Mt(t,1)):(e=Mt(t,n,null),o=Mt(t,r,null)),Dn(e)&&Dn(o)&&(e=qn(e),o=qn(o),i.push({x:e,y:o}))})),i}function nr(t,e={}){if(En(t)<=0)return[];let n=Mt(e,"keyX");Tt(n)||(n="x");let r=Mt(e,"keyY");Tt(r)||(r="y");let i=Mt(e,"keyZ","");Tt(i)||(i="z");let o=[];return ue(t,(t=>{let e=null,l=null,a=null;Bn(t)&&En(t)>=3?(e=Mt(t,0),l=Mt(t,1),a=Mt(t,2)):(e=Mt(t,n,null),l=Mt(t,r,null),a=Mt(t,i,null)),Dn(e)&&Dn(l)&&Dn(a)&&(e=qn(e),l=qn(l),a=qn(a),o.push({x:e,y:l,z:a}))})),o}var rr=function(t,e,n){for(var r=-1,i=t.length;++r<i;){var o=t[r],l=e(o);if(null!=l&&(void 0===a?l==l&&!y(l):n(l,a)))var a=l,s=o}return s};var ir=function(t,e){return t<e};var or=function(t){return t&&t.length?rr(t,ae,ir):void 0};var lr=function(t,e){return t>e};var ar=function(t){return t&&t.length?rr(t,ae,lr):void 0};function sr(t,e,n){return e in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}var ur=function(t,e){var n=[];return le(t,(function(t,r,i){e(t,r,i)&&n.push(t)})),n};var cr=function(e,n){return(t(e)?ze:ur)(e,vn(n))},fr=Math.ceil,hr=Math.max;var gr=function(t,e,n,r){for(var i=-1,o=hr(fr((e-t)/(n||1)),0),l=Array(o);o--;)l[r?o:++i]=t,t+=n;return l};var vr=function(t,e,n){if(!x(n))return!1;var r=typeof e;return!!("number"==r?ie(n)&&Ht(e,n.length):"string"==r&&e in n)&&V(n[e],t)};var dr=function(t){return function(e,n,r){return r&&"number"!=typeof r&&vr(e,n,r)&&(n=r=void 0),e=Gn(e),void 0===n?(n=e,e=0):n=Gn(n),r=void 0===r?e<n?1:-1:Gn(r),gr(e,n,r,t)}}();var pr=function(t,e){var n=null==t?0:t.length;return n?yn(t,e)/n:NaN};var yr=function(t){return pr(t,ae)};function _r(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function mr(t){if(!Ln(t))return{err:"arr is not an effective array"};let e=Mt(t,0),n=0;Ln(e)&&(n=En(e));let r=[];if(0===n?(r=cr(t,Dn),r=pn(r,Qn)):ue(t,(t=>{let e=!0,i=[];ue(dr(n),(n=>{let r=Mt(t,n);Dn(r)||(e=!1),i.push(Qn(r))})),e&&r.push(i)})),0===En(r))return{err:"arr has no effective data"};let i=t=>{let e=(t=>{let e=or(t),n=ar(t);return{min:e,max:n,range:n-e,mid:(n+e)/2,avg:yr(t)}})(t),n=((t,e,n,r)=>pn(t,(t=>(t-e)/r)))(t,e.min,e.max,e.range);return function(t){for(var e=1;e<arguments.length;e++){var n=null!=arguments[e]?arguments[e]:{};e%2?_r(Object(n),!0).forEach((function(e){sr(t,e,n[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(n)):_r(Object(n)).forEach((function(e){Object.defineProperty(t,e,Object.getOwnPropertyDescriptor(n,e))}))}return t}({arr:n},e)},o=null;return o=0===n?i(r):pn(dr(n),(t=>{let e=pn(r,t);return i(e)})),o}function br(t,e=[]){if(!Ln(t))return{err:"arr is not an effective array"};if(En(e)>0){if(!Cn(Mt(t,0)))return{err:"arr is not an effective array of objects"};let n=[];ue(t,(t=>{let r=[];ue(e,(e=>{r.push(Mt(t,e,""))})),n.push(r)})),t=n}return mr(t)}function xr(t,e={}){let n=Mt(e,"scale");Dn(n)||(n=1),n=Qn(n);let r=br(pn(t,"x")),i=br(pn(t,"y")),o=br(pn(t,"z")),l=Math.max(r.range,i.range),a=l/2,s=[{min:r.mid-a,max:r.mid+a,range:l},{min:i.mid-a,max:i.mid+a,range:l},{min:o.min,max:o.max,range:o.range}],u=(t,e)=>Nn(t)?(t-s[e].min)/s[e].range*n:null;t=pn(t,(t=>({x:u(t.x,0),y:u(t.y,1),z:u(t.z,2)})));let c=pn(t,"x"),f=or(c),h=ar(c),g=pn(t,"y"),v=or(g),d=ar(g),p=pn(t,"z");return{ps:t,psMinMax:{xmin:f,xmax:h,ymin:v,ymax:d,zmin:or(p),zmax:ar(p)},st:s,nv:u,inv:(t,e)=>Nn(t)?t/n*s[e].range+s[e].min:null}}var wr=l?l.isConcatSpreadable:void 0;var jr=function(e){return t(e)||Bt(e)||!!(wr&&e&&e[wr])};var Ar=function t(e,n,r,i,o){var l=-1,a=e.length;for(r||(r=jr),o||(o=[]);++l<a;){var s=e[l];n>0&&r(s)?n>1?t(s,n-1,r,i,o):Fe(o,s):i||(o[o.length]=s)}return o};var Or=function(t){return(null==t?0:t.length)?Ar(t,1):[]};function Sr(t){let e=function(t){let e=En(Mt(t,"0",null)),n=En(Mt(t,"0.0",null));return 2===En(Mt(t,"0.0.0",null))?3:2===n?2:2===e?1:0===e?0:(console.log("invalid point depth",t),null)}(t);return 3===e?Or(t):2===e?t:1===e?[t]:0===e?[]:t}function Mr(t){if(!Ln(t))return 0;t=Sr(t);let e=0;return ue(t,((t,n)=>{let r=function(t,e={}){let n=Mt(e,"useAbs");if(kt(n)||(n=!0),!Ln(t))return 0;let r=[];if(ue(t,(t=>{2===En(t)&&Dn(t[0])&&Dn(t[1])&&r.push([Qn(t[0]),Qn(t[1])])})),!Ln(r))return 0;let i,o=-1,l=En(r),a=r[l-1],s=0;for(;++o<l;)i=a,a=r[o],s+=i[1]*a[0]-i[0]*a[1];let u=s/2;return n&&(u=Math.abs(u)),u}(t);0===n?e=r:e-=r})),e<0?0:e}var Pr=function(){var t,e=0,n=!1;function r(e,n){return t.list.push({type:e,data:n?JSON.parse(JSON.stringify(n)):void 0}),t}return t={list:[],segmentId:function(){return e++},checkIntersection:function(t,e){return r("check",{seg1:t,seg2:e})},segmentChop:function(t,e){return r("div_seg",{seg:t,pt:e}),r("chop",{seg:t,pt:e})},statusRemove:function(t){return r("pop_seg",{seg:t})},segmentUpdate:function(t){return r("seg_update",{seg:t})},segmentNew:function(t,e){return r("new_seg",{seg:t,primary:e})},segmentRemove:function(t){return r("rem_seg",{seg:t})},tempStatus:function(t,e,n){return r("temp_status",{seg:t,above:e,below:n})},rewind:function(t){return r("rewind",{seg:t})},status:function(t,e,n){return r("status",{seg:t,above:e,below:n})},vert:function(e){return e===n?t:(n=e,r("vert",{x:e}))},log:function(t){return"string"!=typeof t&&(t=JSON.stringify(t,!1,"  ")),r("log",{txt:t})},reset:function(){return r("reset")},selected:function(t){return r("selected",{segs:t})},chainStart:function(t){return r("chain_start",{seg:t})},chainRemoveHead:function(t,e){return r("chain_rem_head",{index:t,pt:e})},chainRemoveTail:function(t,e){return r("chain_rem_tail",{index:t,pt:e})},chainNew:function(t,e){return r("chain_new",{pt1:t,pt2:e})},chainMatch:function(t){return r("chain_match",{index:t})},chainClose:function(t){return r("chain_close",{index:t})},chainAddHead:function(t,e){return r("chain_add_head",{index:t,pt:e})},chainAddTail:function(t,e){return r("chain_add_tail",{index:t,pt:e})},chainConnect:function(t,e){return r("chain_con",{index1:t,index2:e})},chainReverse:function(t){return r("chain_rev",{index:t})},chainJoin:function(t,e){return r("chain_join",{index1:t,index2:e})},done:function(){return r("done")}}};var kr=function(t){"number"!=typeof t&&(t=1e-10);var e={epsilon:function(e){return"number"==typeof e&&(t=e),t},pointAboveOrOnLine:function(e,n,r){var i=n[0],o=n[1],l=r[0],a=r[1],s=e[0];return(l-i)*(e[1]-o)-(a-o)*(s-i)>=-t},pointBetween:function(e,n,r){var i=e[1]-n[1],o=r[0]-n[0],l=e[0]-n[0],a=r[1]-n[1],s=l*o+i*a;return!(s<t)&&!(s-(o*o+a*a)>-t)},pointsSameX:function(e,n){return Math.abs(e[0]-n[0])<t},pointsSameY:function(e,n){return Math.abs(e[1]-n[1])<t},pointsSame:function(t,n){return e.pointsSameX(t,n)&&e.pointsSameY(t,n)},pointsCompare:function(t,n){return e.pointsSameX(t,n)?e.pointsSameY(t,n)?0:t[1]<n[1]?-1:1:t[0]<n[0]?-1:1},pointsCollinear:function(e,n,r){var i=e[0]-n[0],o=e[1]-n[1],l=n[0]-r[0],a=n[1]-r[1];return Math.abs(i*a-l*o)<t},linesIntersect:function(e,n,r,i){var o=n[0]-e[0],l=n[1]-e[1],a=i[0]-r[0],s=i[1]-r[1],u=o*s-l*a;if(Math.abs(u)<t)return!1;var c=e[0]-r[0],f=e[1]-r[1],h=(a*f-s*c)/u,g=(o*f-l*c)/u,v={alongA:0,alongB:0,pt:[e[0]+h*o,e[1]+h*l]};return v.alongA=h<=-t?-2:h<t?-1:h-1<=-t?0:h-1<t?1:2,v.alongB=g<=-t?-2:g<t?-1:g-1<=-t?0:g-1<t?1:2,v},pointInsideRegion:function(e,n){for(var r=e[0],i=e[1],o=n[n.length-1][0],l=n[n.length-1][1],a=!1,s=0;s<n.length;s++){var u=n[s][0],c=n[s][1];c-i>t!=l-i>t&&(o-u)*(i-c)/(l-c)+u-r>t&&(a=!a),o=u,l=c}return a}};return e},Fr={create:function(){var t={root:{root:!0,next:null},exists:function(e){return null!==e&&e!==t.root},isEmpty:function(){return null===t.root.next},getHead:function(){return t.root.next},insertBefore:function(e,n){for(var r=t.root,i=t.root.next;null!==i;){if(n(i))return e.prev=i.prev,e.next=i,i.prev.next=e,void(i.prev=e);r=i,i=i.next}r.next=e,e.prev=r,e.next=null},findTransition:function(e){for(var n=t.root,r=t.root.next;null!==r&&!e(r);)n=r,r=r.next;return{before:n===t.root?null:n,after:r,insert:function(t){return t.prev=n,t.next=r,n.next=t,null!==r&&(r.prev=t),t}}}};return t},node:function(t){return t.prev=null,t.next=null,t.remove=function(){t.prev.next=t.next,t.next&&(t.next.prev=t.prev),t.prev=null,t.next=null},t}};var Tr=function(t,e,n){function r(t,e,r){return{id:n?n.segmentId():-1,start:t,end:e,myFill:{above:r.myFill.above,below:r.myFill.below},otherFill:null}}var i=Fr.create();function o(t,n){i.insertBefore(t,(function(r){return function(t,n,r,i,o,l){var a=e.pointsCompare(n,o);return 0!==a?a:e.pointsSame(r,l)?0:t!==i?t?1:-1:e.pointAboveOrOnLine(r,i?o:l,i?l:o)?1:-1}(t.isStart,t.pt,n,r.isStart,r.pt,r.other.pt)<0}))}function l(t,e){var n=function(t,e){var n=Fr.node({isStart:!0,pt:t.start,seg:t,primary:e,other:null,status:null});return o(n,t.end),n}(t,e);return function(t,e,n){var r=Fr.node({isStart:!1,pt:e.end,seg:e,primary:n,other:t,status:null});t.other=r,o(r,t.pt)}(n,t,e),n}function a(t,e){var i=r(e,t.seg.end,t.seg);return function(t,e){n&&n.segmentChop(t.seg,e),t.other.remove(),t.seg.end=e,t.other.pt=e,o(t.other,t.pt)}(t,e),l(i,t.primary)}function s(r,o){var l=Fr.create();function s(t){return l.findTransition((function(n){var r,i,o,l,a,s;return(r=t,i=n.ev,o=r.seg.start,l=r.seg.end,a=i.seg.start,s=i.seg.end,e.pointsCollinear(o,a,s)?e.pointsCollinear(l,a,s)||e.pointAboveOrOnLine(l,a,s)?1:-1:e.pointAboveOrOnLine(o,a,s)?1:-1)>0}))}function u(t,r){var i=t.seg,o=r.seg,l=i.start,s=i.end,u=o.start,c=o.end;n&&n.checkIntersection(i,o);var f=e.linesIntersect(l,s,u,c);if(!1===f){if(!e.pointsCollinear(l,s,u))return!1;if(e.pointsSame(l,c)||e.pointsSame(s,u))return!1;var h=e.pointsSame(l,u),g=e.pointsSame(s,c);if(h&&g)return r;var v=!h&&e.pointBetween(l,u,c),d=!g&&e.pointBetween(s,u,c);if(h)return d?a(r,s):a(t,c),r;v&&(g||(d?a(r,s):a(t,c)),a(r,l))}else 0===f.alongA&&(-1===f.alongB?a(t,u):0===f.alongB?a(t,f.pt):1===f.alongB&&a(t,c)),0===f.alongB&&(-1===f.alongA?a(r,l):0===f.alongA?a(r,f.pt):1===f.alongA&&a(r,s));return!1}for(var c=[];!i.isEmpty();){var f=i.getHead();if(n&&n.vert(f.pt[0]),f.isStart){n&&n.segmentNew(f.seg,f.primary);var h=s(f),g=h.before?h.before.ev:null,v=h.after?h.after.ev:null;function d(){if(g){var t=u(f,g);if(t)return t}return!!v&&u(f,v)}n&&n.tempStatus(f.seg,!!g&&g.seg,!!v&&v.seg);var p,y=d();if(y){var _;if(t)(_=null===f.seg.myFill.below||f.seg.myFill.above!==f.seg.myFill.below)&&(y.seg.myFill.above=!y.seg.myFill.above);else y.seg.otherFill=f.seg.myFill;n&&n.segmentUpdate(y.seg),f.other.remove(),f.remove()}if(i.getHead()!==f){n&&n.rewind(f.seg);continue}if(t)_=null===f.seg.myFill.below||f.seg.myFill.above!==f.seg.myFill.below,f.seg.myFill.below=v?v.seg.myFill.above:r,f.seg.myFill.above=_?!f.seg.myFill.below:f.seg.myFill.below;else if(null===f.seg.otherFill)p=v?f.primary===v.primary?v.seg.otherFill.above:v.seg.myFill.above:f.primary?o:r,f.seg.otherFill={above:p,below:p};n&&n.status(f.seg,!!g&&g.seg,!!v&&v.seg),f.other.status=h.insert(Fr.node({ev:f}))}else{var m=f.status;if(null===m)throw new Error("PolyBool: Zero-length segment detected; your epsilon is probably too small or too large");if(l.exists(m.prev)&&l.exists(m.next)&&u(m.prev.ev,m.next.ev),n&&n.statusRemove(m.ev.seg),m.remove(),!f.primary){var b=f.seg.myFill;f.seg.myFill=f.seg.otherFill,f.seg.otherFill=b}c.push(f.seg)}i.getHead().remove()}return n&&n.done(),c}return t?{addRegion:function(t){for(var r,i,o,a=t[t.length-1],s=0;s<t.length;s++){r=a,a=t[s];var u=e.pointsCompare(r,a);0!==u&&l((i=u<0?r:a,o=u<0?a:r,{id:n?n.segmentId():-1,start:i,end:o,myFill:{above:null,below:null},otherFill:null}),!0)}},calculate:function(t){return s(t,!1)}}:{calculate:function(t,e,n,i){return t.forEach((function(t){l(r(t.start,t.end,t),!0)})),n.forEach((function(t){l(r(t.start,t.end,t),!1)})),s(e,i)}}};var zr=function(t,e,n){var r=[],i=[];return t.forEach((function(t){var o=t.start,l=t.end;if(e.pointsSame(o,l))console.warn("PolyBool: Warning: Zero-length segment detected; your epsilon is probably too small or too large");else{n&&n.chainStart(t);for(var a={index:0,matches_head:!1,matches_pt1:!1},s={index:0,matches_head:!1,matches_pt1:!1},u=a,c=0;c<r.length;c++){var f=(p=r[c])[0];p[1];var h=p[p.length-1];if(p[p.length-2],e.pointsSame(f,o)){if(A(c,!0,!0))break}else if(e.pointsSame(f,l)){if(A(c,!0,!1))break}else if(e.pointsSame(h,o)){if(A(c,!1,!0))break}else if(e.pointsSame(h,l)&&A(c,!1,!1))break}if(u===a)return r.push([o,l]),void(n&&n.chainNew(o,l));if(u===s){n&&n.chainMatch(a.index);var g=a.index,v=a.matches_pt1?l:o,d=a.matches_head,p=r[g],y=d?p[0]:p[p.length-1],_=d?p[1]:p[p.length-2],m=d?p[p.length-1]:p[0],b=d?p[p.length-2]:p[1];return e.pointsCollinear(_,y,v)&&(d?(n&&n.chainRemoveHead(a.index,v),p.shift()):(n&&n.chainRemoveTail(a.index,v),p.pop()),y=_),e.pointsSame(m,v)?(r.splice(g,1),e.pointsCollinear(b,m,y)&&(d?(n&&n.chainRemoveTail(a.index,y),p.pop()):(n&&n.chainRemoveHead(a.index,y),p.shift())),n&&n.chainClose(a.index),void i.push(p)):void(d?(n&&n.chainAddHead(a.index,v),p.unshift(v)):(n&&n.chainAddTail(a.index,v),p.push(v)))}var x=a.index,w=s.index;n&&n.chainConnect(x,w);var j=r[x].length<r[w].length;a.matches_head?s.matches_head?j?(O(x),S(x,w)):(O(w),S(w,x)):S(w,x):s.matches_head?S(x,w):j?(O(x),S(w,x)):(O(w),S(x,w))}function A(t,e,n){return u.index=t,u.matches_head=e,u.matches_pt1=n,u===a?(u=s,!1):(u=null,!0)}function O(t){n&&n.chainReverse(t),r[t].reverse()}function S(t,i){var o=r[t],l=r[i],a=o[o.length-1],s=o[o.length-2],u=l[0],c=l[1];e.pointsCollinear(s,a,u)&&(n&&n.chainRemoveTail(t,a),o.pop(),a=s),e.pointsCollinear(a,u,c)&&(n&&n.chainRemoveHead(i,u),l.shift()),n&&n.chainJoin(t,i),r[t]=o.concat(l),r.splice(i,1)}})),i};function $r(t,e,n){var r=[];return t.forEach((function(t){var i=(t.myFill.above?8:0)+(t.myFill.below?4:0)+(t.otherFill&&t.otherFill.above?2:0)+(t.otherFill&&t.otherFill.below?1:0);0!==e[i]&&r.push({id:n?n.segmentId():-1,start:t.start,end:t.end,myFill:{above:1===e[i],below:2===e[i]},otherFill:null})})),n&&n.selected(r),r}var Ir,Er={union:function(t,e){return $r(t,[0,2,1,0,2,2,0,0,1,0,1,0,0,0,0,0],e)},intersect:function(t,e){return $r(t,[0,0,0,0,0,2,0,2,0,0,1,1,0,2,1,0],e)},difference:function(t,e){return $r(t,[0,0,0,0,2,0,2,0,1,1,0,0,0,1,2,0],e)},differenceRev:function(t,e){return $r(t,[0,2,1,0,0,0,1,1,0,2,0,2,0,0,0,0],e)},xor:function(t,e){return $r(t,[0,2,1,0,2,0,0,1,1,0,0,2,0,1,2,0],e)}},Nr=Er,Rr={toPolygon:function(t,e){function n(e){if(e.length<=0)return t.segments({inverted:!1,regions:[]});function n(e){var n=e.slice(0,e.length-1);return t.segments({inverted:!1,regions:[n]})}for(var r=n(e[0]),i=1;i<e.length;i++)r=t.selectDifference(t.combine(r,n(e[i])));return r}if("Polygon"===e.type)return t.polygon(n(e.coordinates));if("MultiPolygon"===e.type){for(var r=t.segments({inverted:!1,regions:[]}),i=0;i<e.coordinates.length;i++)r=t.selectUnion(t.combine(r,n(e.coordinates[i])));return t.polygon(r)}throw new Error("PolyBool: Cannot convert GeoJSON object to PolyBool polygon")},fromPolygon:function(t,e,n){function r(t,n){return e.pointInsideRegion([.5*(t[0][0]+t[1][0]),.5*(t[0][1]+t[1][1])],n)}function i(t){return{region:t,children:[]}}n=t.polygon(t.segments(n));var o=i(null);function l(t,e){for(var n=0;n<t.children.length;n++){if(r(e,(a=t.children[n]).region))return void l(a,e)}var o=i(e);for(n=0;n<t.children.length;n++){var a;r((a=t.children[n]).region,e)&&(o.children.push(a),t.children.splice(n,1),n--)}t.children.push(o)}for(var a=0;a<n.regions.length;a++){var s=n.regions[a];s.length<3||l(o,s)}function u(t,e){for(var n=0,r=t[t.length-1][0],i=t[t.length-1][1],o=[],l=0;l<t.length;l++){var a=t[l][0],s=t[l][1];o.push([a,s]),n+=s*r-a*i,r=a,i=s}return n<0!==e&&o.reverse(),o.push([o[0][0],o[0][1]]),o}var c=[];function f(t){var e=[u(t.region,!1)];c.push(e);for(var n=0;n<t.children.length;n++)e.push(h(t.children[n]))}function h(t){for(var e=0;e<t.children.length;e++)f(t.children[e]);return u(t.region,!0)}for(a=0;a<o.children.length;a++)f(o.children[a]);return c.length<=0?{type:"Polygon",coordinates:[]}:1==c.length?{type:"Polygon",coordinates:c[0]}:{type:"MultiPolygon",coordinates:c}}},Cr=Rr,Br=!1,Ur=kr();function Lr(t,e,n){var r=Ir.segments(t),i=Ir.segments(e),o=n(Ir.combine(r,i));return Ir.polygon(o)}Ir={buildLog:function(t){return!0===t?Br=Pr():!1===t&&(Br=!1),!1!==Br&&Br.list},epsilon:function(t){return Ur.epsilon(t)},segments:function(t){var e=Tr(!0,Ur,Br);return t.regions.forEach(e.addRegion),{segments:e.calculate(t.inverted),inverted:t.inverted}},combine:function(t,e){return{combined:Tr(!1,Ur,Br).calculate(t.segments,t.inverted,e.segments,e.inverted),inverted1:t.inverted,inverted2:e.inverted}},selectUnion:function(t){return{segments:Nr.union(t.combined,Br),inverted:t.inverted1||t.inverted2}},selectIntersect:function(t){return{segments:Nr.intersect(t.combined,Br),inverted:t.inverted1&&t.inverted2}},selectDifference:function(t){return{segments:Nr.difference(t.combined,Br),inverted:t.inverted1&&!t.inverted2}},selectDifferenceRev:function(t){return{segments:Nr.differenceRev(t.combined,Br),inverted:!t.inverted1&&t.inverted2}},selectXor:function(t){return{segments:Nr.xor(t.combined,Br),inverted:t.inverted1!==t.inverted2}},polygon:function(t){return{regions:zr(t.segments,Ur,Br),inverted:t.inverted}},polygonFromGeoJSON:function(t){return Cr.toPolygon(Ir,t)},polygonToGeoJSON:function(t){return Cr.fromPolygon(Ir,Ur,t)},union:function(t,e){return Lr(t,e,Ir.selectUnion)},intersect:function(t,e){return Lr(t,e,Ir.selectIntersect)},difference:function(t,e){return Lr(t,e,Ir.selectDifference)},differenceRev:function(t,e){return Lr(t,e,Ir.selectDifferenceRev)},xor:function(t,e){return Lr(t,e,Ir.selectXor)}},"object"==typeof window&&(window.PolyBool=Ir);var Dr=Ir;function Hr(t,e,n,r,i){let o,l,a,s,u=e[0],c=r[0],f=0,h=0;c>u==c>-u?(o=u,u=e[++f]):(o=c,c=r[++h]);let g=0;if(f<t&&h<n)for(c>u==c>-u?(l=u+o,a=o-(l-u),u=e[++f]):(l=c+o,a=o-(l-c),c=r[++h]),o=l,0!==a&&(i[g++]=a);f<t&&h<n;)c>u==c>-u?(l=o+u,s=l-o,a=o-(l-s)+(u-s),u=e[++f]):(l=o+c,s=l-o,a=o-(l-s)+(c-s),c=r[++h]),o=l,0!==a&&(i[g++]=a);for(;f<t;)l=o+u,s=l-o,a=o-(l-s)+(u-s),u=e[++f],o=l,0!==a&&(i[g++]=a);for(;h<n;)l=o+c,s=l-o,a=o-(l-s)+(c-s),c=r[++h],o=l,0!==a&&(i[g++]=a);return 0===o&&0!==g||(i[g++]=o),g}function Kr(t){return new Float64Array(t)}const Xr=Kr(4),Jr=Kr(8),Yr=Kr(12),Zr=Kr(16),Vr=Kr(4);function Wr(t,e,n,r,i,o){const l=(e-o)*(n-i),a=(t-i)*(r-o),s=l-a;if(0===l||0===a||l>0!=a>0)return s;const u=Math.abs(l+a);return Math.abs(s)>=33306690738754716e-32*u?s:-function(t,e,n,r,i,o,l){let a,s,u,c,f,h,g,v,d,p,y,_,m,b,x,w,j,A;const O=t-i,S=n-i,M=e-o,P=r-o;b=O*P,h=134217729*O,g=h-(h-O),v=O-g,h=134217729*P,d=h-(h-P),p=P-d,x=v*p-(b-g*d-v*d-g*p),w=M*S,h=134217729*M,g=h-(h-M),v=M-g,h=134217729*S,d=h-(h-S),p=S-d,j=v*p-(w-g*d-v*d-g*p),y=x-j,f=x-y,Xr[0]=x-(y+f)+(f-j),_=b+y,f=_-b,m=b-(_-f)+(y-f),y=m-w,f=m-y,Xr[1]=m-(y+f)+(f-w),A=_+y,f=A-_,Xr[2]=_-(A-f)+(y-f),Xr[3]=A;let k=function(t,e){let n=e[0];for(let r=1;r<t;r++)n+=e[r];return n}(4,Xr),F=22204460492503146e-32*l;if(k>=F||-k>=F)return k;if(f=t-O,a=t-(O+f)+(f-i),f=n-S,u=n-(S+f)+(f-i),f=e-M,s=e-(M+f)+(f-o),f=r-P,c=r-(P+f)+(f-o),0===a&&0===s&&0===u&&0===c)return k;if(F=11093356479670487e-47*l+33306690738754706e-32*Math.abs(k),k+=O*c+P*a-(M*u+S*s),k>=F||-k>=F)return k;b=a*P,h=134217729*a,g=h-(h-a),v=a-g,h=134217729*P,d=h-(h-P),p=P-d,x=v*p-(b-g*d-v*d-g*p),w=s*S,h=134217729*s,g=h-(h-s),v=s-g,h=134217729*S,d=h-(h-S),p=S-d,j=v*p-(w-g*d-v*d-g*p),y=x-j,f=x-y,Vr[0]=x-(y+f)+(f-j),_=b+y,f=_-b,m=b-(_-f)+(y-f),y=m-w,f=m-y,Vr[1]=m-(y+f)+(f-w),A=_+y,f=A-_,Vr[2]=_-(A-f)+(y-f),Vr[3]=A;const T=Hr(4,Xr,4,Vr,Jr);b=O*c,h=134217729*O,g=h-(h-O),v=O-g,h=134217729*c,d=h-(h-c),p=c-d,x=v*p-(b-g*d-v*d-g*p),w=M*u,h=134217729*M,g=h-(h-M),v=M-g,h=134217729*u,d=h-(h-u),p=u-d,j=v*p-(w-g*d-v*d-g*p),y=x-j,f=x-y,Vr[0]=x-(y+f)+(f-j),_=b+y,f=_-b,m=b-(_-f)+(y-f),y=m-w,f=m-y,Vr[1]=m-(y+f)+(f-w),A=_+y,f=A-_,Vr[2]=_-(A-f)+(y-f),Vr[3]=A;const z=Hr(T,Jr,4,Vr,Yr);b=a*c,h=134217729*a,g=h-(h-a),v=a-g,h=134217729*c,d=h-(h-c),p=c-d,x=v*p-(b-g*d-v*d-g*p),w=s*u,h=134217729*s,g=h-(h-s),v=s-g,h=134217729*u,d=h-(h-u),p=u-d,j=v*p-(w-g*d-v*d-g*p),y=x-j,f=x-y,Vr[0]=x-(y+f)+(f-j),_=b+y,f=_-b,m=b-(_-f)+(y-f),y=m-w,f=m-y,Vr[1]=m-(y+f)+(f-w),A=_+y,f=A-_,Vr[2]=_-(A-f)+(y-f),Vr[3]=A;const $=Hr(z,Yr,4,Vr,Zr);return Zr[$-1]}(t,e,n,r,i,o,u)}const qr=Math.pow(2,-52),Gr=new Uint32Array(512);class Qr{static from(t,e=oi,n=li){const r=t.length,i=new Float64Array(2*r);for(let o=0;o<r;o++){const r=t[o];i[2*o]=e(r),i[2*o+1]=n(r)}return new Qr(i)}constructor(t){const e=t.length>>1;if(e>0&&"number"!=typeof t[0])throw new Error("Expected coords to contain numbers.");this.coords=t;const n=Math.max(2*e-5,0);this._triangles=new Uint32Array(3*n),this._halfedges=new Int32Array(3*n),this._hashSize=Math.ceil(Math.sqrt(e)),this._hullPrev=new Uint32Array(e),this._hullNext=new Uint32Array(e),this._hullTri=new Uint32Array(e),this._hullHash=new Int32Array(this._hashSize).fill(-1),this._ids=new Uint32Array(e),this._dists=new Float64Array(e),this.update()}update(){const{coords:t,_hullPrev:e,_hullNext:n,_hullTri:r,_hullHash:i}=this,o=t.length>>1;let l=1/0,a=1/0,s=-1/0,u=-1/0;for(let e=0;e<o;e++){const n=t[2*e],r=t[2*e+1];n<l&&(l=n),r<a&&(a=r),n>s&&(s=n),r>u&&(u=r),this._ids[e]=e}const c=(l+s)/2,f=(a+u)/2;let h,g,v,d=1/0;for(let e=0;e<o;e++){const n=ti(c,f,t[2*e],t[2*e+1]);n<d&&(h=e,d=n)}const p=t[2*h],y=t[2*h+1];d=1/0;for(let e=0;e<o;e++){if(e===h)continue;const n=ti(p,y,t[2*e],t[2*e+1]);n<d&&n>0&&(g=e,d=n)}let _=t[2*g],m=t[2*g+1],b=1/0;for(let e=0;e<o;e++){if(e===h||e===g)continue;const n=ni(p,y,_,m,t[2*e],t[2*e+1]);n<b&&(v=e,b=n)}let x=t[2*v],w=t[2*v+1];if(b===1/0){for(let e=0;e<o;e++)this._dists[e]=t[2*e]-t[0]||t[2*e+1]-t[1];ri(this._ids,this._dists,0,o-1);const e=new Uint32Array(o);let n=0;for(let t=0,r=-1/0;t<o;t++){const i=this._ids[t];this._dists[i]>r&&(e[n++]=i,r=this._dists[i])}return this.hull=e.subarray(0,n),this.triangles=new Uint32Array(0),void(this.halfedges=new Uint32Array(0))}if(Wr(p,y,_,m,x,w)<0){const t=g,e=_,n=m;g=v,_=x,m=w,v=t,x=e,w=n}const j=function(t,e,n,r,i,o){const l=n-t,a=r-e,s=i-t,u=o-e,c=l*l+a*a,f=s*s+u*u,h=.5/(l*u-a*s);return{x:t+(u*c-a*f)*h,y:e+(l*f-s*c)*h}}(p,y,_,m,x,w);this._cx=j.x,this._cy=j.y;for(let e=0;e<o;e++)this._dists[e]=ti(t[2*e],t[2*e+1],j.x,j.y);ri(this._ids,this._dists,0,o-1),this._hullStart=h;let A=3;n[h]=e[v]=g,n[g]=e[h]=v,n[v]=e[g]=h,r[h]=0,r[g]=1,r[v]=2,i.fill(-1),i[this._hashKey(p,y)]=h,i[this._hashKey(_,m)]=g,i[this._hashKey(x,w)]=v,this.trianglesLen=0,this._addTriangle(h,g,v,-1,-1,-1);for(let o,l,a=0;a<this._ids.length;a++){const s=this._ids[a],u=t[2*s],c=t[2*s+1];if(a>0&&Math.abs(u-o)<=qr&&Math.abs(c-l)<=qr)continue;if(o=u,l=c,s===h||s===g||s===v)continue;let f=0;for(let t=0,e=this._hashKey(u,c);t<this._hashSize&&(f=i[(e+t)%this._hashSize],-1===f||f===n[f]);t++);f=e[f];let d,p=f;for(;d=n[p],Wr(u,c,t[2*p],t[2*p+1],t[2*d],t[2*d+1])>=0;)if(p=d,p===f){p=-1;break}if(-1===p)continue;let y=this._addTriangle(p,s,n[p],-1,-1,r[p]);r[s]=this._legalize(y+2),r[p]=y,A++;let _=n[p];for(;d=n[_],Wr(u,c,t[2*_],t[2*_+1],t[2*d],t[2*d+1])<0;)y=this._addTriangle(_,s,d,r[s],-1,r[_]),r[s]=this._legalize(y+2),n[_]=_,A--,_=d;if(p===f)for(;d=e[p],Wr(u,c,t[2*d],t[2*d+1],t[2*p],t[2*p+1])<0;)y=this._addTriangle(d,s,p,-1,r[p],r[d]),this._legalize(y+2),r[d]=y,n[p]=p,A--,p=d;this._hullStart=e[s]=p,n[p]=e[_]=s,n[s]=_,i[this._hashKey(u,c)]=s,i[this._hashKey(t[2*p],t[2*p+1])]=p}this.hull=new Uint32Array(A);for(let t=0,e=this._hullStart;t<A;t++)this.hull[t]=e,e=n[e];this.triangles=this._triangles.subarray(0,this.trianglesLen),this.halfedges=this._halfedges.subarray(0,this.trianglesLen)}_hashKey(t,e){return Math.floor(function(t,e){const n=t/(Math.abs(t)+Math.abs(e));return(e>0?3-n:1+n)/4}(t-this._cx,e-this._cy)*this._hashSize)%this._hashSize}_legalize(t){const{_triangles:e,_halfedges:n,coords:r}=this;let i=0,o=0;for(;;){const l=n[t],a=t-t%3;if(o=a+(t+2)%3,-1===l){if(0===i)break;t=Gr[--i];continue}const s=l-l%3,u=a+(t+1)%3,c=s+(l+2)%3,f=e[o],h=e[t],g=e[u],v=e[c];if(ei(r[2*f],r[2*f+1],r[2*h],r[2*h+1],r[2*g],r[2*g+1],r[2*v],r[2*v+1])){e[t]=v,e[l]=f;const r=n[c];if(-1===r){let e=this._hullStart;do{if(this._hullTri[e]===c){this._hullTri[e]=t;break}e=this._hullPrev[e]}while(e!==this._hullStart)}this._link(t,r),this._link(l,n[o]),this._link(o,c);const a=s+(l+1)%3;i<Gr.length&&(Gr[i++]=a)}else{if(0===i)break;t=Gr[--i]}}return o}_link(t,e){this._halfedges[t]=e,-1!==e&&(this._halfedges[e]=t)}_addTriangle(t,e,n,r,i,o){const l=this.trianglesLen;return this._triangles[l]=t,this._triangles[l+1]=e,this._triangles[l+2]=n,this._link(l,r),this._link(l+1,i),this._link(l+2,o),this.trianglesLen+=3,l}}function ti(t,e,n,r){const i=t-n,o=e-r;return i*i+o*o}function ei(t,e,n,r,i,o,l,a){const s=t-l,u=e-a,c=n-l,f=r-a,h=i-l,g=o-a,v=c*c+f*f,d=h*h+g*g;return s*(f*d-v*g)-u*(c*d-v*h)+(s*s+u*u)*(c*g-f*h)<0}function ni(t,e,n,r,i,o){const l=n-t,a=r-e,s=i-t,u=o-e,c=l*l+a*a,f=s*s+u*u,h=.5/(l*u-a*s),g=(u*c-a*f)*h,v=(l*f-s*c)*h;return g*g+v*v}function ri(t,e,n,r){if(r-n<=20)for(let i=n+1;i<=r;i++){const r=t[i],o=e[r];let l=i-1;for(;l>=n&&e[t[l]]>o;)t[l+1]=t[l--];t[l+1]=r}else{let i=n+1,o=r;ii(t,n+r>>1,i),e[t[n]]>e[t[r]]&&ii(t,n,r),e[t[i]]>e[t[r]]&&ii(t,i,r),e[t[n]]>e[t[i]]&&ii(t,n,i);const l=t[i],a=e[l];for(;;){do{i++}while(e[t[i]]<a);do{o--}while(e[t[o]]>a);if(o<i)break;ii(t,i,o)}t[n+1]=t[o],t[o]=l,r-i+1>=o-n?(ri(t,e,i,r),ri(t,e,n,o-1)):(ri(t,e,n,o-1),ri(t,e,i,r))}}function ii(t,e,n){const r=t[e];t[e]=t[n],t[n]=r}function oi(t){return t[0]}function li(t){return t[1]}class ai{constructor(){this._x0=this._y0=this._x1=this._y1=null,this._=""}moveTo(t,e){this._+=`M${this._x0=this._x1=+t},${this._y0=this._y1=+e}`}closePath(){null!==this._x1&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")}lineTo(t,e){this._+=`L${this._x1=+t},${this._y1=+e}`}arc(t,e,n){const r=(t=+t)+(n=+n),i=e=+e;if(n<0)throw new Error("negative radius");null===this._x1?this._+=`M${r},${i}`:(Math.abs(this._x1-r)>1e-6||Math.abs(this._y1-i)>1e-6)&&(this._+="L"+r+","+i),n&&(this._+=`A${n},${n},0,1,1,${t-n},${e}A${n},${n},0,1,1,${this._x1=r},${this._y1=i}`)}rect(t,e,n,r){this._+=`M${this._x0=this._x1=+t},${this._y0=this._y1=+e}h${+n}v${+r}h${-n}Z`}value(){return this._||null}}class si{constructor(){this._=[]}moveTo(t,e){this._.push([t,e])}closePath(){this._.push(this._[0].slice())}lineTo(t,e){this._.push([t,e])}value(){return this._.length?this._:null}}class ui{constructor(t,[e,n,r,i]=[0,0,960,500]){if(!((r=+r)>=(e=+e)&&(i=+i)>=(n=+n)))throw new Error("invalid bounds");this.delaunay=t,this._circumcenters=new Float64Array(2*t.points.length),this.vectors=new Float64Array(2*t.points.length),this.xmax=r,this.xmin=e,this.ymax=i,this.ymin=n,this._init()}update(){return this.delaunay.update(),this._init(),this}_init(){const{delaunay:{points:t,hull:e,triangles:n},vectors:r}=this,i=this.circumcenters=this._circumcenters.subarray(0,n.length/3*2);for(let e,r,o=0,l=0,a=n.length;o<a;o+=3,l+=2){const a=2*n[o],s=2*n[o+1],u=2*n[o+2],c=t[a],f=t[a+1],h=t[s],g=t[s+1],v=t[u],d=t[u+1],p=h-c,y=g-f,_=v-c,m=d-f,b=2*(p*m-y*_);if(Math.abs(b)<1e-9){let i=1e9;const o=2*n[0];i*=Math.sign((t[o]-c)*m-(t[o+1]-f)*_),e=(c+v)/2-i*m,r=(f+d)/2+i*_}else{const t=1/b,n=p*p+y*y,i=_*_+m*m;e=c+(m*n-y*i)*t,r=f+(p*i-_*n)*t}i[l]=e,i[l+1]=r}let o,l,a,s=e[e.length-1],u=4*s,c=t[2*s],f=t[2*s+1];r.fill(0);for(let n=0;n<e.length;++n)s=e[n],o=u,l=c,a=f,u=4*s,c=t[2*s],f=t[2*s+1],r[o+2]=r[u]=a-f,r[o+3]=r[u+1]=c-l}render(t){const e=null==t?t=new ai:void 0,{delaunay:{halfedges:n,inedges:r,hull:i},circumcenters:o,vectors:l}=this;if(i.length<=1)return null;for(let e=0,r=n.length;e<r;++e){const r=n[e];if(r<e)continue;const i=2*Math.floor(e/3),l=2*Math.floor(r/3),a=o[i],s=o[i+1],u=o[l],c=o[l+1];this._renderSegment(a,s,u,c,t)}let a,s=i[i.length-1];for(let e=0;e<i.length;++e){a=s,s=i[e];const n=2*Math.floor(r[s]/3),u=o[n],c=o[n+1],f=4*a,h=this._project(u,c,l[f+2],l[f+3]);h&&this._renderSegment(u,c,h[0],h[1],t)}return e&&e.value()}renderBounds(t){const e=null==t?t=new ai:void 0;return t.rect(this.xmin,this.ymin,this.xmax-this.xmin,this.ymax-this.ymin),e&&e.value()}renderCell(t,e){const n=null==e?e=new ai:void 0,r=this._clip(t);if(null===r||!r.length)return;e.moveTo(r[0],r[1]);let i=r.length;for(;r[0]===r[i-2]&&r[1]===r[i-1]&&i>1;)i-=2;for(let t=2;t<i;t+=2)r[t]===r[t-2]&&r[t+1]===r[t-1]||e.lineTo(r[t],r[t+1]);return e.closePath(),n&&n.value()}*cellPolygons(){const{delaunay:{points:t}}=this;for(let e=0,n=t.length/2;e<n;++e){const t=this.cellPolygon(e);t&&(t.index=e,yield t)}}cellPolygon(t){const e=new si;return this.renderCell(t,e),e.value()}_renderSegment(t,e,n,r,i){let o;const l=this._regioncode(t,e),a=this._regioncode(n,r);0===l&&0===a?(i.moveTo(t,e),i.lineTo(n,r)):(o=this._clipSegment(t,e,n,r,l,a))&&(i.moveTo(o[0],o[1]),i.lineTo(o[2],o[3]))}contains(t,e,n){return(e=+e)==e&&(n=+n)==n&&this.delaunay._step(t,e,n)===t}*neighbors(t){const e=this._clip(t);if(e)for(const n of this.delaunay.neighbors(t)){const t=this._clip(n);if(t)t:for(let r=0,i=e.length;r<i;r+=2)for(let o=0,l=t.length;o<l;o+=2)if(e[r]==t[o]&&e[r+1]==t[o+1]&&e[(r+2)%i]==t[(o+l-2)%l]&&e[(r+3)%i]==t[(o+l-1)%l]){yield n;break t}}}_cell(t){const{circumcenters:e,delaunay:{inedges:n,halfedges:r,triangles:i}}=this,o=n[t];if(-1===o)return null;const l=[];let a=o;do{const n=Math.floor(a/3);if(l.push(e[2*n],e[2*n+1]),a=a%3==2?a-2:a+1,i[a]!==t)break;a=r[a]}while(a!==o&&-1!==a);return l}_clip(t){if(0===t&&1===this.delaunay.hull.length)return[this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax,this.xmin,this.ymin];const e=this._cell(t);if(null===e)return null;const{vectors:n}=this,r=4*t;return n[r]||n[r+1]?this._clipInfinite(t,e,n[r],n[r+1],n[r+2],n[r+3]):this._clipFinite(t,e)}_clipFinite(t,e){const n=e.length;let r,i,o,l,a=null,s=e[n-2],u=e[n-1],c=this._regioncode(s,u),f=0;for(let h=0;h<n;h+=2)if(r=s,i=u,s=e[h],u=e[h+1],o=c,c=this._regioncode(s,u),0===o&&0===c)l=f,f=0,a?a.push(s,u):a=[s,u];else{let e,n,h,g,v;if(0===o){if(null===(e=this._clipSegment(r,i,s,u,o,c)))continue;[n,h,g,v]=e}else{if(null===(e=this._clipSegment(s,u,r,i,c,o)))continue;[g,v,n,h]=e,l=f,f=this._edgecode(n,h),l&&f&&this._edge(t,l,f,a,a.length),a?a.push(n,h):a=[n,h]}l=f,f=this._edgecode(g,v),l&&f&&this._edge(t,l,f,a,a.length),a?a.push(g,v):a=[g,v]}if(a)l=f,f=this._edgecode(a[0],a[1]),l&&f&&this._edge(t,l,f,a,a.length);else if(this.contains(t,(this.xmin+this.xmax)/2,(this.ymin+this.ymax)/2))return[this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax,this.xmin,this.ymin];return a}_clipSegment(t,e,n,r,i,o){for(;;){if(0===i&&0===o)return[t,e,n,r];if(i&o)return null;let l,a,s=i||o;8&s?(l=t+(n-t)*(this.ymax-e)/(r-e),a=this.ymax):4&s?(l=t+(n-t)*(this.ymin-e)/(r-e),a=this.ymin):2&s?(a=e+(r-e)*(this.xmax-t)/(n-t),l=this.xmax):(a=e+(r-e)*(this.xmin-t)/(n-t),l=this.xmin),i?(t=l,e=a,i=this._regioncode(t,e)):(n=l,r=a,o=this._regioncode(n,r))}}_clipInfinite(t,e,n,r,i,o){let l,a=Array.from(e);if((l=this._project(a[0],a[1],n,r))&&a.unshift(l[0],l[1]),(l=this._project(a[a.length-2],a[a.length-1],i,o))&&a.push(l[0],l[1]),a=this._clipFinite(t,a))for(let e,n=0,r=a.length,i=this._edgecode(a[r-2],a[r-1]);n<r;n+=2)e=i,i=this._edgecode(a[n],a[n+1]),e&&i&&(n=this._edge(t,e,i,a,n),r=a.length);else this.contains(t,(this.xmin+this.xmax)/2,(this.ymin+this.ymax)/2)&&(a=[this.xmin,this.ymin,this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax]);return a}_edge(t,e,n,r,i){for(;e!==n;){let n,o;switch(e){case 5:e=4;continue;case 4:e=6,n=this.xmax,o=this.ymin;break;case 6:e=2;continue;case 2:e=10,n=this.xmax,o=this.ymax;break;case 10:e=8;continue;case 8:e=9,n=this.xmin,o=this.ymax;break;case 9:e=1;continue;case 1:e=5,n=this.xmin,o=this.ymin}r[i]===n&&r[i+1]===o||!this.contains(t,n,o)||(r.splice(i,0,n,o),i+=2)}if(r.length>4)for(let t=0;t<r.length;t+=2){const e=(t+2)%r.length,n=(t+4)%r.length;(r[t]===r[e]&&r[e]===r[n]||r[t+1]===r[e+1]&&r[e+1]===r[n+1])&&(r.splice(e,2),t-=2)}return i}_project(t,e,n,r){let i,o,l,a=1/0;if(r<0){if(e<=this.ymin)return null;(i=(this.ymin-e)/r)<a&&(l=this.ymin,o=t+(a=i)*n)}else if(r>0){if(e>=this.ymax)return null;(i=(this.ymax-e)/r)<a&&(l=this.ymax,o=t+(a=i)*n)}if(n>0){if(t>=this.xmax)return null;(i=(this.xmax-t)/n)<a&&(o=this.xmax,l=e+(a=i)*r)}else if(n<0){if(t<=this.xmin)return null;(i=(this.xmin-t)/n)<a&&(o=this.xmin,l=e+(a=i)*r)}return[o,l]}_edgecode(t,e){return(t===this.xmin?1:t===this.xmax?2:0)|(e===this.ymin?4:e===this.ymax?8:0)}_regioncode(t,e){return(t<this.xmin?1:t>this.xmax?2:0)|(e<this.ymin?4:e>this.ymax?8:0)}}const ci=2*Math.PI,fi=Math.pow;function hi(t){return t[0]}function gi(t){return t[1]}function vi(t,e,n){return[t+Math.sin(t+e)*n,e+Math.cos(t-e)*n]}class di{static from(t,e=hi,n=gi,r){return new di("length"in t?function(t,e,n,r){const i=t.length,o=new Float64Array(2*i);for(let l=0;l<i;++l){const i=t[l];o[2*l]=e.call(r,i,l,t),o[2*l+1]=n.call(r,i,l,t)}return o}(t,e,n,r):Float64Array.from(function*(t,e,n,r){let i=0;for(const o of t)yield e.call(r,o,i,t),yield n.call(r,o,i,t),++i}(t,e,n,r)))}constructor(t){this._delaunator=new Qr(t),this.inedges=new Int32Array(t.length/2),this._hullIndex=new Int32Array(t.length/2),this.points=this._delaunator.coords,this._init()}update(){return this._delaunator.update(),this._init(),this}_init(){const t=this._delaunator,e=this.points;if(t.hull&&t.hull.length>2&&function(t){const{triangles:e,coords:n}=t;for(let t=0;t<e.length;t+=3){const r=2*e[t],i=2*e[t+1],o=2*e[t+2];if((n[o]-n[r])*(n[i+1]-n[r+1])-(n[i]-n[r])*(n[o+1]-n[r+1])>1e-10)return!1}return!0}(t)){this.collinear=Int32Array.from({length:e.length/2},((t,e)=>e)).sort(((t,n)=>e[2*t]-e[2*n]||e[2*t+1]-e[2*n+1]));const t=this.collinear[0],n=this.collinear[this.collinear.length-1],r=[e[2*t],e[2*t+1],e[2*n],e[2*n+1]],i=1e-8*Math.hypot(r[3]-r[1],r[2]-r[0]);for(let t=0,n=e.length/2;t<n;++t){const n=vi(e[2*t],e[2*t+1],i);e[2*t]=n[0],e[2*t+1]=n[1]}this._delaunator=new Qr(e)}else delete this.collinear;const n=this.halfedges=this._delaunator.halfedges,r=this.hull=this._delaunator.hull,i=this.triangles=this._delaunator.triangles,o=this.inedges.fill(-1),l=this._hullIndex.fill(-1);for(let t=0,e=n.length;t<e;++t){const e=i[t%3==2?t-2:t+1];-1!==n[t]&&-1!==o[e]||(o[e]=t)}for(let t=0,e=r.length;t<e;++t)l[r[t]]=t;r.length<=2&&r.length>0&&(this.triangles=new Int32Array(3).fill(-1),this.halfedges=new Int32Array(3).fill(-1),this.triangles[0]=r[0],o[r[0]]=1,2===r.length&&(o[r[1]]=0,this.triangles[1]=r[1],this.triangles[2]=r[1]))}voronoi(t){return new ui(this,t)}*neighbors(t){const{inedges:e,hull:n,_hullIndex:r,halfedges:i,triangles:o,collinear:l}=this;if(l){const e=l.indexOf(t);return e>0&&(yield l[e-1]),void(e<l.length-1&&(yield l[e+1]))}const a=e[t];if(-1===a)return;let s=a,u=-1;do{if(yield u=o[s],s=s%3==2?s-2:s+1,o[s]!==t)return;if(s=i[s],-1===s){const e=n[(r[t]+1)%n.length];return void(e!==u&&(yield e))}}while(s!==a)}find(t,e,n=0){if((t=+t)!=t||(e=+e)!=e)return-1;const r=n;let i;for(;(i=this._step(n,t,e))>=0&&i!==n&&i!==r;)n=i;return i}_step(t,e,n){const{inedges:r,hull:i,_hullIndex:o,halfedges:l,triangles:a,points:s}=this;if(-1===r[t]||!s.length)return(t+1)%(s.length>>1);let u=t,c=fi(e-s[2*t],2)+fi(n-s[2*t+1],2);const f=r[t];let h=f;do{let r=a[h];const f=fi(e-s[2*r],2)+fi(n-s[2*r+1],2);if(f<c&&(c=f,u=r),h=h%3==2?h-2:h+1,a[h]!==t)break;if(h=l[h],-1===h){if(h=i[(o[t]+1)%i.length],h!==r&&fi(e-s[2*h],2)+fi(n-s[2*h+1],2)<c)return h;break}}while(h!==f);return u}render(t){const e=null==t?t=new ai:void 0,{points:n,halfedges:r,triangles:i}=this;for(let e=0,o=r.length;e<o;++e){const o=r[e];if(o<e)continue;const l=2*i[e],a=2*i[o];t.moveTo(n[l],n[l+1]),t.lineTo(n[a],n[a+1])}return this.renderHull(t),e&&e.value()}renderPoints(t,e){void 0!==e||t&&"function"==typeof t.moveTo||(e=t,t=null),e=null==e?2:+e;const n=null==t?t=new ai:void 0,{points:r}=this;for(let n=0,i=r.length;n<i;n+=2){const i=r[n],o=r[n+1];t.moveTo(i+e,o),t.arc(i,o,e,0,ci)}return n&&n.value()}renderHull(t){const e=null==t?t=new ai:void 0,{hull:n,points:r}=this,i=2*n[0],o=n.length;t.moveTo(r[i],r[i+1]);for(let e=1;e<o;++e){const i=2*n[e];t.lineTo(r[i],r[i+1])}return t.closePath(),e&&e.value()}hullPolygon(){const t=new si;return this.renderHull(t),t.value()}renderTriangle(t,e){const n=null==e?e=new ai:void 0,{points:r,triangles:i}=this,o=2*i[t*=3],l=2*i[t+1],a=2*i[t+2];return e.moveTo(r[o],r[o+1]),e.lineTo(r[l],r[l+1]),e.lineTo(r[a],r[a+1]),e.closePath(),n&&n.value()}*trianglePolygons(){const{triangles:t}=this;for(let e=0,n=t.length/3;e<n;++e)yield this.trianglePolygon(e)}trianglePolygon(t){const e=new si;return this.renderTriangle(t,e),e.value()}}function pi(t,e,n={}){if(!Ln(t))return{err:"psSrc is not an array"};if(!Cn(e)&&!Ln(e))return{err:"psTar is not an object or array"};let r=Cn(e);r&&(e=[e]);let i=Mt(n,"keyX");Tt(i)||(i="x");let o=Mt(n,"keyY");Tt(o)||(o="y");let l=Mt(n,"keyZ");Tt(l)||(l="z");let a=Mt(n,"scale");if(Dn(a)||(a=1),a=Qn(a),t=nr(t,n),0===En(t))return{err:"psSrc has no effective data"};if(e=er(e,n),0===En(e))return{err:"psTar has no effective data"};let s=xr(t,{scale:a});t=s.ps;let u=s.nv,c=s.inv,f=[...t],h=[...t],g={};ue(t,(t=>{let e=`${t.x}-${t.y}`;g[e]=t.z}));let v,d=di.from(h,(t=>t.x),(t=>t.y)),p=[0,0,a,a],y=d.voronoi(p),_=(e,n,r)=>{let i=[...t],o={x:n,y:r,z:0};i.push(o),e.push(o);let l=di.from(i,(t=>t.x),(t=>t.y)).voronoi(p),a=i.length-1,s=l.cellPolygon(a),u=Mr(s),c=null;if(u>0){let t=[],n=l.delaunay.neighbors(a),r=n.next();for(;!r.done;){let e=r.value;t.push(e),r=n.next()}let i=pn(t,(t=>{let e=[s],n=[y.cellPolygon(t)],r=[];try{r=function(t,e){if(!Ln(t))return null;if(!Ln(e))return null;t=Sr(t),e=Sr(e);let n=Dr.intersect({regions:t},{regions:e});return Mt(n,"regions",[])}(e,n)}catch(t){console.log("pgs1",e),console.log("pgs2",n),console.log(t)}let i=0;if(1===En(r))try{i=Mr(r[0])}catch(t){console.log("ints",r),console.log(t)}return{ia:i,idx:t}}));c=pn(i,(t=>t.ia/u*e[t.idx].z)),c=_n(c)}return e[e.length-1].z=c,c},m=(t,e)=>{let n=`${t}-${e}`;if(tr(g,n))return g[n];if(t<p[0]||t>p[2]||e<p[1]||e>p[3])return null;let r=((t,e,n)=>{let r;try{r=_(t,e,n)}catch(e){console.log(e),r=null,t.pop()}return r})(f,t,e);return g[n]=r,r},b=t=>{let e=t.x,n=u(e,0);if(!Nn(n))throw new Error(`invalid nx[${n}]`);let r=t.y,a=u(r,1);if(!Nn(a))throw new Error(`invalid ny[${a}]`);let s=m(n,a),f=c(s,2);return Nn(f)||(f=null),{[i]:e,[o]:r,[l]:f}};if(r){let t=e[0];v=b(t)}else v=[],ue(e,(t=>{v.push(b(t))}));return v}let yi={},_i=function(t,e){let n=[];for(let r=0;r<e;r++)n.push(t);return n},mi=function(t,e){let n=_i(0,e*e);for(let r=0;r<e;r++)n[r*e+r]=t;return n},bi=function(t,e,n,r){let i,o,l=Array(n*r);for(i=0;i<n;i++)for(o=0;o<r;o++)l[i*r+o]=t[i*r+o]+e[i*r+o];return l},xi=function(t,e,n,r,i){let o,l,a,s=Array(n*i);for(o=0;o<n;o++)for(l=0;l<i;l++)for(s[o*i+l]=0,a=0;a<r;a++)s[o*i+l]+=t[o*r+a]*e[a*i+l];return s},wi=function(t,e){let n,r,i,o=Array(e);for(n=0;n<e;n++)o[n]=t[n*e+n];for(n=0;n<e;n++){for(r=0;r<n;r++)o[n]-=t[n*e+r]*t[n*e+r];if(o[n]<=0)return!1;for(o[n]=Math.sqrt(o[n]),r=n+1;r<e;r++){for(i=0;i<n;i++)t[r*e+n]-=t[r*e+i]*t[n*e+i];t[r*e+n]/=o[n]}}for(n=0;n<e;n++)t[n*e+n]=o[n];return!0},ji=function(t,e){let n,r,i,o;for(n=0;n<e;n++)for(t[n*e+n]=1/t[n*e+n],r=n+1;r<e;r++){for(o=0,i=n;i<r;i++)o-=t[r*e+i]*t[i*e+n];t[r*e+n]=o/t[r*e+r]}for(n=0;n<e;n++)for(r=n+1;r<e;r++)t[n*e+r]=0;for(n=0;n<e;n++){for(t[n*e+n]*=t[n*e+n],i=n+1;i<e;i++)t[n*e+n]+=t[i*e+n]*t[i*e+n];for(r=n+1;r<e;r++)for(i=r;i<e;i++)t[n*e+r]+=t[i*e+n]*t[i*e+r]}for(n=0;n<e;n++)for(r=0;r<n;r++)t[n*e+r]=t[r*e+n]},Ai=function(t,e){let n,r,i,o,l,a,s,u,c,f,h,g=e,v=Array(e*e),d=Array(e),p=Array(e),y=Array(e);for(n=0;n<e;n++)for(o=0;o<e;o++)v[n*e+o]=n===o?1:0;for(o=0;o<e;o++)y[o]=0;for(n=0;n<e;n++){for(u=0,o=0;o<e;o++)if(1!==y[o])for(l=0;l<e;l++)0===y[l]&&Math.abs(t[o*e+l])>=u&&(u=Math.abs(t[o*e+l]),i=o,r=l);if(++y[r],i!==r){for(a=0;a<e;a++)h=t[i*e+a],t[i*e+a]=t[r*e+a],t[r*e+a]=h;for(a=0;a<g;a++)h=v[i*e+a],v[i*e+a]=v[r*e+a],v[r*e+a]=h}if(p[n]=i,d[n]=r,0===t[r*e+r])return!1;for(f=1/t[r*e+r],t[r*e+r]=1,a=0;a<e;a++)t[r*e+a]*=f;for(a=0;a<g;a++)v[r*e+a]*=f;for(s=0;s<e;s++)if(s!==r){for(c=t[s*e+r],t[s*e+r]=0,a=0;a<e;a++)t[s*e+a]-=t[r*e+a]*c;for(a=0;a<g;a++)v[s*e+a]-=v[r*e+a]*c}}for(a=e-1;a>=0;a--)if(p[a]!==d[a])for(l=0;l<e;l++)h=t[l*e+p[a]],t[l*e+p[a]]=t[l*e+d[a]],t[l*e+d[a]]=h;return!0},Oi=function(t,e,n,r,i){return e+(r-e)/n*(1-Math.exp(-1/i*Math.pow(t/n,2)))},Si=function(t,e,n,r,i){return e+(r-e)/n*(1-Math.exp(-1/i*(t/n)))},Mi=function(t,e,n,r,i){return t>n?e+(r-e)/n:e+(r-e)/n*(t/n*1.5-.5*Math.pow(t/n,3))};function Pi(t,e,n={}){if(!Ln(t))return{err:"psSrc is not an array"};if(!Cn(e)&&!Ln(e))return{err:"psTar is not an object or array"};let r=Cn(e);r&&(e=[e]);let i=Mt(n,"keyX");Tt(i)||(i="x");let o=Mt(n,"keyY");Tt(o)||(o="y");let l=Mt(n,"keyZ");Tt(l)||(l="z");let a=Mt(n,"scale");Dn(a)||(a=1),a=Qn(a);let s=Mt(n,"model");"exponential"!==s&&"gaussian"!==s&&"spherical"!==s&&(s="exponential");let u=Mt(n,"sigma2");Dn(u)||(u=0),u=Qn(u);let c=Mt(n,"alpha");Dn(c)||(c=100),c=Qn(c);let f=Mt(n,"returnWithVariogram");if(kt(f)||(f=!1),t=nr(t,n),0===En(t))return{err:"psSrc has no effective data"};if(e=er(e,n),0===En(e))return{err:"psTar has no effective data"};let h=xr(t,{scale:a});t=h.ps;let g=h.nv,v=h.inv,d={};ue(t,(t=>{let e=`${t.x}-${t.y}`;d[e]=t.z}));let p=[],y=[],_=[];ue(t,(t=>{p.push(t.x),y.push(t.y),_.push(t.z)}));let m,b=yi.train(_,p,y,s,u,c),x=t=>{let e=t.x,n=g(e,0);if(!Nn(n))throw new Error(`invalid nx[${n}]`);let r=t.y,a=g(r,1);if(!Nn(a))throw new Error(`invalid ny[${a}]`);let s=((t,e)=>{let n=`${t}-${e}`;if(tr(d,n))return d[n];let r=yi.predict(t,e,b);return d[n]=r,r})(n,a),u=v(s,2);return Nn(u)||(u=null),{[i]:e,[o]:r,[l]:u}};if(r){let t=e[0];m=x(t)}else m=[],ue(e,(t=>{m.push(x(t))}));return f&&(m={result:m,variogram:b}),m}function interp2(t,e,n={}){let r=Mt(n,"method");"naturalNeighbor"!==r&&"kriging"!==r&&(r="naturalNeighbor");let i=Mt(n,"useSync");kt(i)||(i=!1);let o=()=>{let i=null;try{"naturalNeighbor"===r?i=pi(t,e,n):"kriging"===r&&(i=Pi(t,e,n))}catch(t){i={err:t.toString()}}return i};return i?o():(async()=>{let t=null;try{t=o();let e=Mt(t,"err");return Tt(e)?Promise.reject(e):t}catch(t){return console.log(t),Promise.reject(t.toString())}})()}yi.train=function(t,e,n,r,i,o){let l,a,s,u,c={t:t,x:e,y:n,nugget:0,range:0,sill:0,A:1/3,n:0};switch(r){case"gaussian":c.model=Oi;break;case"exponential":c.model=Si;break;case"spherical":c.model=Mi}let f=t.length,h=Array((f*f-f)/2);for(l=0,s=0;l<f;l++)for(a=0;a<l;a++,s++)h[s]=Array(2),h[s][0]=Math.pow(Math.pow(e[l]-e[a],2)+Math.pow(n[l]-n[a],2),.5),h[s][1]=Math.abs(t[l]-t[a]);h.sort((function(t,e){return t[0]-e[0]})),c.range=h[(f*f-f)/2-1][0];let g=(f*f-f)/2>30?30:(f*f-f)/2,v=c.range/g,d=_i(0,g),p=_i(0,g);if(g<30)for(u=0;u<g;u++)d[u]=h[u][0],p[u]=h[u][1];else{for(l=0,a=0,s=0,u=0;l<g&&a<(f*f-f)/2;l++,s=0){for(;h[a][0]<=(l+1)*v&&(d[u]+=h[a][0],p[u]+=h[a][1],a++,s++,!(a>=(f*f-f)/2)););s>0&&(d[u]/=s,p[u]/=s,u++)}if(u<2)return c}let y=[];for(l=0;l<u;l++){let t=d[l],e=p[l];y.push([t,e])}let _={data:h,bars:y};c.svpd=_,f=u,c.range=d[f-1]-d[0];let m=_i(1,2*f),b=Array(f),x=c.A;for(l=0;l<f;l++){switch(r){case"gaussian":m[2*l+1]=1-Math.exp(-1/x*Math.pow(d[l]/c.range,2));break;case"exponential":m[2*l+1]=1-Math.exp(-1/x*d[l]/c.range);break;case"spherical":m[2*l+1]=d[l]/c.range*1.5-.5*Math.pow(d[l]/c.range,3)}b[l]=p[l]}let w=function(t,e,n){let r,i,o=Array(n*e);for(r=0;r<e;r++)for(i=0;i<n;i++)o[i*e+r]=t[r*n+i];return o}(m,f,2),j=xi(w,m,2,f,2);j=bi(j,mi(1/o,2),2,2);let A=j.slice(0);wi(j,2)?ji(j,2):(Ai(A,2),j=A);let O=xi(xi(j,w,2,2,f),b,2,f,1);c.nugget=O[0],c.sill=O[1]*c.range+c.nugget,c.n=e.length,f=e.length;let S=Array(f*f);for(l=0;l<f;l++){for(a=0;a<l;a++)S[l*f+a]=c.model(Math.pow(Math.pow(e[l]-e[a],2)+Math.pow(n[l]-n[a],2),.5),c.nugget,c.range,c.sill,c.A),S[a*f+l]=S[l*f+a];S[l*f+l]=c.model(0,c.nugget,c.range,c.sill,c.A)}let M=bi(S,mi(i,f),f,f),P=M.slice(0);wi(M,f)?ji(M,f):(Ai(P,f),M=P);let k=M.slice(0),F=xi(M,t,f,f,1);return c.K=k,c.M=F,c},yi.predict=function(t,e,n){let r,i=Array(n.n);for(r=0;r<n.n;r++)i[r]=n.model(Math.pow(Math.pow(t-n.x[r],2)+Math.pow(e-n.y[r],2),.5),n.nugget,n.range,n.sill,n.A);return xi(i,n.M,1,n.n,1)[0]},yi.variance=function(t,e,n){let r,i=Array(n.n);for(r=0;r<n.n;r++)i[r]=n.model(Math.pow(Math.pow(t-n.x[r],2)+Math.pow(e-n.y[r],2),.5),n.nugget,n.range,n.sill,n.A);return n.model(0,n.nugget,n.range,n.sill,n.A)+xi(xi(i,n.K,1,n.n,n.n),i,1,n.n,1)[0]};

let instance = null
function init(input){

    //init
    let r
    
        r = {
            main: interp2
        }
        

    //on
    

    //save
    instance = r

}

function sendMessage(data) {
    
        parentPort.postMessage(data)
        
}

async function run(data) {
    // console.log('inner worker run',data)

    //mode
    let mode = data.mode

    //check
    if(mode !== 'init' && mode !== 'call'){
        return
    }

    //init
    if(mode === 'init'){
        
        try{

            //type
            let type = data.type

            //input
            let input = data.input
    
            //instance
            if(type === 'function'){
                init(...input)
            }
            else if(type === 'object'){
                instance = interp2
            }

        }
        catch(err){
        
            //sendMessage
            let res = {
                mode: 'emit',
                evName: 'error',
                msg: err,
            }
            sendMessage(res)

        }
            
    }

    //check
    if(mode === 'call'){
        let state = ''
        let msg = null

        try{

            //fun
            let fun = instance[data.fun]

            //input
            let input = data.input

            //exec
            await fun(...input)
                .then((suc) => {
                    state='success'
                    msg=suc
                })
                .catch((err) => {
                    state='error'
                    msg=err
                })

        }
        catch(err){
            state = 'error'
            msg = err
        }
        
        //sendMessage
        let res = {
            mode: 'return',
            id: data.id,
            fun: data.fun,
            state,
            msg,
        }
        sendMessage(res)

    }

}

function recvMessage(data) {
    // console.log('inner worker recv:', data)

    //dataRecv
    let dataRecv = data

    //run
    run(dataRecv)

}


        parentPort.on('message', recvMessage)
        

",Buffer.from(c,"base64").toString("utf8"));function t(){var d=b();function m(b){try{return new l.Worker(b,{eval:!0})}catch(l){s(l)}}var c=m(p);if(!c)return s("invalid worker"),null;function G(){c?(c.terminate(),c=void 0):s("worker has been terminated")}function i(){var l={mode:"init",type:"function",input:Array.prototype.slice.call(arguments)};c.postMessage(l)}function W(){var l=Z(),b=X(),m={mode:"call",id:b,fun:"main",input:Array.prototype.slice.call(arguments)};return c.postMessage(m),d.once(b,(function(b){"success"===b.state?l.resolve(b.msg):l.reject(b.msg)})),l}function t(l){var b=l,Z=b.mode;"emit"!==Z&&"return"!==Z||("emit"===Z&&d.emit(b.evName,b.msg),"return"===Z&&d.emit(b.id,b))}function s(l){d.emit("error",l)}return c.on("message",t),c.on("error",s),i(Array.prototype.slice.call(arguments)),d.main=W,d.main=W,d.terminate=G,d}G=function(){var l,b=(l=i.mark((function l(){var b,Z,m,X=arguments;return i.wrap((function(l){for(;;)switch(l.prev=l.next){case 0:return b=Array.prototype.slice.call(X),Z=t(),l.next=4,Z.main.apply(Z,d(b)).finally((function(){Z.terminate()}));case 4:return m=l.sent,l.abrupt("return",m);case 6:case"end":return l.stop()}}),l)})),function(){var b=this,d=arguments;return new Promise((function(Z,X){var c=l.apply(b,d);function G(l){m(c,Z,X,G,i,"next",l)}function i(l){m(c,Z,X,G,i,"throw",l)}G(void 0)}))});return function(){return b.apply(this,arguments)}}()}(),G}(d.default)})),c=m((function(l,b){l.exports=function(){function l(l,b){(null==b||b>l.length)&&(b=l.length);for(var d=0,Z=new Array(b);d<b;d++)Z[d]=l[d];return Z}function b(b){return function(b){if(Array.isArray(b))return l(b)}(b)||function(l){if("undefined"!=typeof Symbol&&null!=l[Symbol.iterator]||null!=l["@@iterator"])return Array.from(l)}(b)||function(b,d){if(b){if("string"==typeof b)return l(b,d);var Z=Object.prototype.toString.call(b).slice(8,-1);return"Object"===Z&&b.constructor&&(Z=b.constructor.name),"Map"===Z||"Set"===Z?Array.from(b):"Arguments"===Z||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(Z)?l(b,d):void 0}}(b)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function d(l,b,d,Z,m,X,c){try{var G=l[X](c),i=G.value}catch(l){return void d(l)}G.done?b(i):Promise.resolve(i).then(Z,m)}function m(l){return m="function"==typeof Symbol&&"symbol"==Z(Symbol.iterator)?function(l){return Z(l)}:function(l){return l&&"function"==typeof Symbol&&l.constructor===Symbol&&l!==Symbol.prototype?"symbol":Z(l)},m(l)}function X(l){var b={exports:{}};return l(b,b.exports),b.exports}var c,G,i=X((function(l){var b=function(l){var b,d=Object.prototype,Z=d.hasOwnProperty,X="function"==typeof Symbol?Symbol:{},c=X.iterator||"@@iterator",G=X.asyncIterator||"@@asyncIterator",i=X.toStringTag||"@@toStringTag";function W(l,b,d){return Object.defineProperty(l,b,{value:d,enumerable:!0,configurable:!0,writable:!0}),l[b]}try{W({},"")}catch(l){W=function(l,b,d){return l[b]=d}}function p(l,b,d,Z){var m=b&&b.prototype instanceof o?b:o,X=Object.create(m.prototype),c=new T(Z||[]);return X._invoke=function(l,b,d){var Z=s;return function(m,X){if(Z===K)throw new Error("Generator is already running");if(Z===y){if("throw"===m)throw X;return J()}for(d.method=m,d.arg=X;;){var c=d.delegate;if(c){var G=S(c,d);if(G){if(G===h)continue;return G}}if("next"===d.method)d.sent=d._sent=d.arg;else if("throw"===d.method){if(Z===s)throw Z=y,d.arg;d.dispatchException(d.arg)}else"return"===d.method&&d.abrupt("return",d.arg);Z=K;var i=t(l,b,d);if("normal"===i.type){if(Z=d.done?y:u,i.arg===h)continue;return{value:i.arg,done:d.done}}"throw"===i.type&&(Z=y,d.method="throw",d.arg=i.arg)}}}(l,d,c),X}function t(l,b,d){try{return{type:"normal",arg:l.call(b,d)}}catch(l){return{type:"throw",arg:l}}}l.wrap=p;var s="suspendedStart",u="suspendedYield",K="executing",y="completed",h={};function o(){}function n(){}function I(){}var L={};W(L,c,(function(){return this}));var V=Object.getPrototypeOf,a=V&&V(V(g([])));a&&a!==d&&Z.call(a,c)&&(L=a);var x=I.prototype=o.prototype=Object.create(L);function Y(l){["next","throw","return"].forEach((function(b){W(l,b,(function(l){return this._invoke(b,l)}))}))}function C(l,b){function d(X,c,G,i){var W=t(l[X],l,c);if("throw"!==W.type){var p=W.arg,s=p.value;return s&&"object"===m(s)&&Z.call(s,"__await")?b.resolve(s.__await).then((function(l){d("next",l,G,i)}),(function(l){d("throw",l,G,i)})):b.resolve(s).then((function(l){p.value=l,G(p)}),(function(l){return d("throw",l,G,i)}))}i(W.arg)}var X;this._invoke=function(l,Z){function m(){return new b((function(b,m){d(l,Z,b,m)}))}return X=X?X.then(m,m):m()}}function S(l,d){var Z=l.iterator[d.method];if(Z===b){if(d.delegate=null,"throw"===d.method){if(l.iterator.return&&(d.method="return",d.arg=b,S(l,d),"throw"===d.method))return h;d.method="throw",d.arg=new TypeError("The iterator does not provide a 'throw' method")}return h}var m=t(Z,l.iterator,d.arg);if("throw"===m.type)return d.method="throw",d.arg=m.arg,d.delegate=null,h;var X=m.arg;return X?X.done?(d[l.resultName]=X.value,d.next=l.nextLoc,"return"!==d.method&&(d.method="next",d.arg=b),d.delegate=null,h):X:(d.method="throw",d.arg=new TypeError("iterator result is not an object"),d.delegate=null,h)}function H(l){var b={tryLoc:l[0]};1 in l&&(b.catchLoc=l[1]),2 in l&&(b.finallyLoc=l[2],b.afterLoc=l[3]),this.tryEntries.push(b)}function e(l){var b=l.completion||{};b.type="normal",delete b.arg,l.completion=b}function T(l){this.tryEntries=[{tryLoc:"root"}],l.forEach(H,this),this.reset(!0)}function g(l){if(l){var d=l[c];if(d)return d.call(l);if("function"==typeof l.next)return l;if(!isNaN(l.length)){var m=-1,X=function d(){for(;++m<l.length;)if(Z.call(l,m))return d.value=l[m],d.done=!1,d;return d.value=b,d.done=!0,d};return X.next=X}}return{next:J}}function J(){return{value:b,done:!0}}return n.prototype=I,W(x,"constructor",I),W(I,"constructor",n),n.displayName=W(I,i,"GeneratorFunction"),l.isGeneratorFunction=function(l){var b="function"==typeof l&&l.constructor;return!!b&&(b===n||"GeneratorFunction"===(b.displayName||b.name))},l.mark=function(l){return Object.setPrototypeOf?Object.setPrototypeOf(l,I):(l.__proto__=I,W(l,i,"GeneratorFunction")),l.prototype=Object.create(x),l},l.awrap=function(l){return{__await:l}},Y(C.prototype),W(C.prototype,G,(function(){return this})),l.AsyncIterator=C,l.async=function(b,d,Z,m,X){void 0===X&&(X=Promise);var c=new C(p(b,d,Z,m),X);return l.isGeneratorFunction(d)?c:c.next().then((function(l){return l.done?l.value:c.next()}))},Y(x),W(x,i,"Generator"),W(x,c,(function(){return this})),W(x,"toString",(function(){return"[object Generator]"})),l.keys=function(l){var b=[];for(var d in l)b.push(d);return b.reverse(),function d(){for(;b.length;){var Z=b.pop();if(Z in l)return d.value=Z,d.done=!1,d}return d.done=!0,d}},l.values=g,T.prototype={constructor:T,reset:function(l){if(this.prev=0,this.next=0,this.sent=this._sent=b,this.done=!1,this.delegate=null,this.method="next",this.arg=b,this.tryEntries.forEach(e),!l)for(var d in this)"t"===d.charAt(0)&&Z.call(this,d)&&!isNaN(+d.slice(1))&&(this[d]=b)},stop:function(){this.done=!0;var l=this.tryEntries[0].completion;if("throw"===l.type)throw l.arg;return this.rval},dispatchException:function(l){if(this.done)throw l;var d=this;function m(Z,m){return G.type="throw",G.arg=l,d.next=Z,m&&(d.method="next",d.arg=b),!!m}for(var X=this.tryEntries.length-1;X>=0;--X){var c=this.tryEntries[X],G=c.completion;if("root"===c.tryLoc)return m("end");if(c.tryLoc<=this.prev){var i=Z.call(c,"catchLoc"),W=Z.call(c,"finallyLoc");if(i&&W){if(this.prev<c.catchLoc)return m(c.catchLoc,!0);if(this.prev<c.finallyLoc)return m(c.finallyLoc)}else if(i){if(this.prev<c.catchLoc)return m(c.catchLoc,!0)}else{if(!W)throw new Error("try statement without catch or finally");if(this.prev<c.finallyLoc)return m(c.finallyLoc)}}}},abrupt:function(l,b){for(var d=this.tryEntries.length-1;d>=0;--d){var m=this.tryEntries[d];if(m.tryLoc<=this.prev&&Z.call(m,"finallyLoc")&&this.prev<m.finallyLoc){var X=m;break}}X&&("break"===l||"continue"===l)&&X.tryLoc<=b&&b<=X.finallyLoc&&(X=null);var c=X?X.completion:{};return c.type=l,c.arg=b,X?(this.method="next",this.next=X.finallyLoc,h):this.complete(c)},complete:function(l,b){if("throw"===l.type)throw l.arg;return"break"===l.type||"continue"===l.type?this.next=l.arg:"return"===l.type?(this.rval=this.arg=l.arg,this.method="return",this.next="end"):"normal"===l.type&&b&&(this.next=b),h},finish:function(l){for(var b=this.tryEntries.length-1;b>=0;--b){var d=this.tryEntries[b];if(d.finallyLoc===l)return this.complete(d.completion,d.afterLoc),e(d),h}},catch:function(l){for(var b=this.tryEntries.length-1;b>=0;--b){var d=this.tryEntries[b];if(d.tryLoc===l){var Z=d.completion;if("throw"===Z.type){var m=Z.arg;e(d)}return m}}throw new Error("illegal catch attempt")},delegateYield:function(l,d,Z){return this.delegate={iterator:g(l),resultName:d,nextLoc:Z},"next"===this.method&&(this.arg=b),h}},l}(l.exports);try{regeneratorRuntime=b}catch(l){"object"===("undefined"==typeof globalThis?"undefined":m(globalThis))?globalThis.regeneratorRuntime=b:Function("r","regeneratorRuntime = r")(b)}})),W="function"==typeof atob,p="function"==typeof Buffer,t="function"==typeof TextDecoder?new TextDecoder:void 0,s=("function"==typeof TextEncoder&&new TextEncoder,Array.prototype.slice.call("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=")),u=(c={},s.forEach((function(l,b){return c[l]=b})),c),K=/^(?:[A-Za-z\d+\/]{4})*?(?:[A-Za-z\d+\/]{2}(?:==)?|[A-Za-z\d+\/]{3}=?)?$/,y=String.fromCharCode.bind(String),h="function"==typeof Uint8Array.from?Uint8Array.from.bind(Uint8Array):function(l){var b=arguments.length>1&&void 0!==arguments[1]?arguments[1]:function(l){return l};return new Uint8Array(Array.prototype.slice.call(l,0).map(b))},o=function(l){return l.replace(/[^A-Za-z0-9\+\/]/g,"")},n=/[\xC0-\xDF][\x80-\xBF]|[\xE0-\xEF][\x80-\xBF]{2}|[\xF0-\xF7][\x80-\xBF]{3}/g,I=function(l){switch(l.length){case 4:var b=((7&l.charCodeAt(0))<<18|(63&l.charCodeAt(1))<<12|(63&l.charCodeAt(2))<<6|63&l.charCodeAt(3))-65536;return y(55296+(b>>>10))+y(56320+(1023&b));case 3:return y((15&l.charCodeAt(0))<<12|(63&l.charCodeAt(1))<<6|63&l.charCodeAt(2));default:return y((31&l.charCodeAt(0))<<6|63&l.charCodeAt(1))}},L=function(l){return l.replace(n,I)},V=function(l){if(l=l.replace(/\s+/g,""),!K.test(l))throw new TypeError("malformed base64.");l+="==".slice(2-(3&l.length));for(var b,d,Z,m="",X=0;X<l.length;)b=u[l.charAt(X++)]<<18|u[l.charAt(X++)]<<12|(d=u[l.charAt(X++)])<<6|(Z=u[l.charAt(X++)]),m+=64===d?y(b>>16&255):64===Z?y(b>>16&255,b>>8&255):y(b>>16&255,b>>8&255,255&b);return m},a=W?function(l){return atob(o(l))}:p?function(l){return Buffer.from(l,"base64").toString("binary")}:V,x=p?function(l){return h(Buffer.from(l,"base64"))}:function(l){return h(a(l),(function(l){return l.charCodeAt(0)}))},Y=p?function(l){return Buffer.from(l,"base64").toString("utf8")}:t?function(l){return t.decode(x(l))}:function(l){return L(a(l))},C=function(l){return o(l.replace(/[-_]/g,(function(l){return"-"==l?"+":"/"})))},S=function(l){return Y(C(l))},H=S,e=X((function(l){var b=Object.prototype.hasOwnProperty,d="~";function Z(){}function m(l,b,d){this.fn=l,this.context=b,this.once=d||!1}function X(l,b,Z,X,c){if("function"!=typeof Z)throw new TypeError("The listener must be a function");var G=new m(Z,X||l,c),i=d?d+b:b;return l._events[i]?l._events[i].fn?l._events[i]=[l._events[i],G]:l._events[i].push(G):(l._events[i]=G,l._eventsCount++),l}function c(l,b){0==--l._eventsCount?l._events=new Z:delete l._events[b]}function G(){this._events=new Z,this._eventsCount=0}Object.create&&(Z.prototype=Object.create(null),(new Z).__proto__||(d=!1)),G.prototype.eventNames=function(){var l,Z,m=[];if(0===this._eventsCount)return m;for(Z in l=this._events)b.call(l,Z)&&m.push(d?Z.slice(1):Z);return Object.getOwnPropertySymbols?m.concat(Object.getOwnPropertySymbols(l)):m},G.prototype.listeners=function(l){var b=d?d+l:l,Z=this._events[b];if(!Z)return[];if(Z.fn)return[Z.fn];for(var m=0,X=Z.length,c=new Array(X);m<X;m++)c[m]=Z[m].fn;return c},G.prototype.listenerCount=function(l){var b=d?d+l:l,Z=this._events[b];return Z?Z.fn?1:Z.length:0},G.prototype.emit=function(l,b,Z,m,X,c){var G=d?d+l:l;if(!this._events[G])return!1;var i,W,p=this._events[G],t=arguments.length;if(p.fn){switch(p.once&&this.removeListener(l,p.fn,void 0,!0),t){case 1:return p.fn.call(p.context),!0;case 2:return p.fn.call(p.context,b),!0;case 3:return p.fn.call(p.context,b,Z),!0;case 4:return p.fn.call(p.context,b,Z,m),!0;case 5:return p.fn.call(p.context,b,Z,m,X),!0;case 6:return p.fn.call(p.context,b,Z,m,X,c),!0}for(W=1,i=new Array(t-1);W<t;W++)i[W-1]=arguments[W];p.fn.apply(p.context,i)}else{var s,u=p.length;for(W=0;W<u;W++)switch(p[W].once&&this.removeListener(l,p[W].fn,void 0,!0),t){case 1:p[W].fn.call(p[W].context);break;case 2:p[W].fn.call(p[W].context,b);break;case 3:p[W].fn.call(p[W].context,b,Z);break;case 4:p[W].fn.call(p[W].context,b,Z,m);break;default:if(!i)for(s=1,i=new Array(t-1);s<t;s++)i[s-1]=arguments[s];p[W].fn.apply(p[W].context,i)}}return!0},G.prototype.on=function(l,b,d){return X(this,l,b,d,!1)},G.prototype.once=function(l,b,d){return X(this,l,b,d,!0)},G.prototype.removeListener=function(l,b,Z,m){var X=d?d+l:l;if(!this._events[X])return this;if(!b)return c(this,X),this;var G=this._events[X];if(G.fn)G.fn!==b||m&&!G.once||Z&&G.context!==Z||c(this,X);else{for(var i=0,W=[],p=G.length;i<p;i++)(G[i].fn!==b||m&&!G[i].once||Z&&G[i].context!==Z)&&W.push(G[i]);W.length?this._events[X]=1===W.length?W[0]:W:c(this,X)}return this},G.prototype.removeAllListeners=function(l){var b;return l?(b=d?d+l:l,this._events[b]&&c(this,b)):(this._events=new Z,this._eventsCount=0),this},G.prototype.off=G.prototype.removeListener,G.prototype.addListener=G.prototype.on,G.prefixed=d,G.EventEmitter=G,l.exports=G}));return function(){if("browser"!=("undefined"!=typeof window&&void 0!==window.document?"browser":"nodejs"))return null;function l(){return new e}function Z(){var l,b,d=new Promise((function(){l=arguments[0],b=arguments[1]}));return d.resolve=l,d.reject=b,d}function m(){for(var l=arguments.length>0&&void 0!==arguments[0]?arguments[0]:10,b=[],d="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(""),Z=d.length,m=0;m<l;m++)b[m]=d[0|Math.random()*Z];return b.join("")}var X=H("


var t=Array.isArray,e="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{};function n(t){var e={exports:{}};return t(e,e.exports),e.exports}var r="object"==typeof e&&e&&e.Object===Object&&e,i="object"==typeof self&&self&&self.Object===Object&&self,o=r||i||Function("return this")(),l=o.Symbol,a=Object.prototype,s=a.hasOwnProperty,u=a.toString,c=l?l.toStringTag:void 0;var f=function(t){var e=s.call(t,c),n=t[c];try{t[c]=void 0;var r=!0}catch(t){}var i=u.call(t);return r&&(e?t[c]=n:delete t[c]),i},h=Object.prototype.toString;var g=function(t){return h.call(t)},v=l?l.toStringTag:void 0;var d=function(t){return null==t?void 0===t?"[object Undefined]":"[object Null]":v&&v in Object(t)?f(t):g(t)};var p=function(t){return null!=t&&"object"==typeof t};var y=function(t){return"symbol"==typeof t||p(t)&&"[object Symbol]"==d(t)},_=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,m=/^\w*$/;var b=function(e,n){if(t(e))return!1;var r=typeof e;return!("number"!=r&&"symbol"!=r&&"boolean"!=r&&null!=e&&!y(e))||(m.test(e)||!_.test(e)||null!=n&&e in Object(n))};var x=function(t){var e=typeof t;return null!=t&&("object"==e||"function"==e)};var w,j=function(t){if(!x(t))return!1;var e=d(t);return"[object Function]"==e||"[object GeneratorFunction]"==e||"[object AsyncFunction]"==e||"[object Proxy]"==e},A=o["__core-js_shared__"],O=(w=/[^.]+$/.exec(A&&A.keys&&A.keys.IE_PROTO||""))?"Symbol(src)_1."+w:"";var S=function(t){return!!O&&O in t},M=Function.prototype.toString;var P=function(t){if(null!=t){try{return M.call(t)}catch(t){}try{return t+""}catch(t){}}return""},k=/^\[object .+?Constructor\]$/,F=Function.prototype,T=Object.prototype,z=F.toString,$=T.hasOwnProperty,I=RegExp("^"+z.call($).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");var E=function(t){return!(!x(t)||S(t))&&(j(t)?I:k).test(P(t))};var N=function(t,e){return null==t?void 0:t[e]};var R=function(t,e){var n=N(t,e);return E(n)?n:void 0},C=R(Object,"create");var B=function(){this.__data__=C?C(null):{},this.size=0};var U=function(t){var e=this.has(t)&&delete this.__data__[t];return this.size-=e?1:0,e},L=Object.prototype.hasOwnProperty;var D=function(t){var e=this.__data__;if(C){var n=e[t];return"__lodash_hash_undefined__"===n?void 0:n}return L.call(e,t)?e[t]:void 0},H=Object.prototype.hasOwnProperty;var K=function(t){var e=this.__data__;return C?void 0!==e[t]:H.call(e,t)};var X=function(t,e){var n=this.__data__;return this.size+=this.has(t)?0:1,n[t]=C&&void 0===e?"__lodash_hash_undefined__":e,this};function J(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var r=t[e];this.set(r[0],r[1])}}J.prototype.clear=B,J.prototype.delete=U,J.prototype.get=D,J.prototype.has=K,J.prototype.set=X;var Y=J;var Z=function(){this.__data__=[],this.size=0};var V=function(t,e){return t===e||t!=t&&e!=e};var W=function(t,e){for(var n=t.length;n--;)if(V(t[n][0],e))return n;return-1},q=Array.prototype.splice;var G=function(t){var e=this.__data__,n=W(e,t);return!(n<0)&&(n==e.length-1?e.pop():q.call(e,n,1),--this.size,!0)};var Q=function(t){var e=this.__data__,n=W(e,t);return n<0?void 0:e[n][1]};var tt=function(t){return W(this.__data__,t)>-1};var et=function(t,e){var n=this.__data__,r=W(n,t);return r<0?(++this.size,n.push([t,e])):n[r][1]=e,this};function nt(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var r=t[e];this.set(r[0],r[1])}}nt.prototype.clear=Z,nt.prototype.delete=G,nt.prototype.get=Q,nt.prototype.has=tt,nt.prototype.set=et;var rt=nt,it=R(o,"Map");var ot=function(){this.size=0,this.__data__={hash:new Y,map:new(it||rt),string:new Y}};var lt=function(t){var e=typeof t;return"string"==e||"number"==e||"symbol"==e||"boolean"==e?"__proto__"!==t:null===t};var at=function(t,e){var n=t.__data__;return lt(e)?n["string"==typeof e?"string":"hash"]:n.map};var st=function(t){var e=at(this,t).delete(t);return this.size-=e?1:0,e};var ut=function(t){return at(this,t).get(t)};var ct=function(t){return at(this,t).has(t)};var ft=function(t,e){var n=at(this,t),r=n.size;return n.set(t,e),this.size+=n.size==r?0:1,this};function ht(t){var e=-1,n=null==t?0:t.length;for(this.clear();++e<n;){var r=t[e];this.set(r[0],r[1])}}ht.prototype.clear=ot,ht.prototype.delete=st,ht.prototype.get=ut,ht.prototype.has=ct,ht.prototype.set=ft;var gt=ht;function vt(t,e){if("function"!=typeof t||null!=e&&"function"!=typeof e)throw new TypeError("Expected a function");var n=function(){var r=arguments,i=e?e.apply(this,r):r[0],o=n.cache;if(o.has(i))return o.get(i);var l=t.apply(this,r);return n.cache=o.set(i,l)||o,l};return n.cache=new(vt.Cache||gt),n}vt.Cache=gt;var dt=vt;var pt=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,yt=/\\(\\)?/g,_t=function(t){var e=dt(t,(function(t){return 500===n.size&&n.clear(),t})),n=e.cache;return e}((function(t){var e=[];return 46===t.charCodeAt(0)&&e.push(""),t.replace(pt,(function(t,n,r,i){e.push(r?i.replace(yt,"$1"):n||t)})),e}));var mt=function(t,e){for(var n=-1,r=null==t?0:t.length,i=Array(r);++n<r;)i[n]=e(t[n],n,t);return i},bt=l?l.prototype:void 0,xt=bt?bt.toString:void 0;var wt=function e(n){if("string"==typeof n)return n;if(t(n))return mt(n,e)+"";if(y(n))return xt?xt.call(n):"";var r=n+"";return"0"==r&&1/n==-Infinity?"-0":r};var jt=function(t){return null==t?"":wt(t)};var At=function(e,n){return t(e)?e:b(e,n)?[e]:_t(jt(e))};var Ot=function(t){if("string"==typeof t||y(t))return t;var e=t+"";return"0"==e&&1/t==-Infinity?"-0":e};var St=function(t,e){for(var n=0,r=(e=At(e,t)).length;null!=t&&n<r;)t=t[Ot(e[n++])];return n&&n==r?t:void 0};var Mt=function(t,e,n){var r=null==t?void 0:St(t,e);return void 0===r?n:r};var Pt=function(t){return!0===t||!1===t||p(t)&&"[object Boolean]"==d(t)};function kt(t){return Pt(t)}function Ft(t){return"[object String]"===Object.prototype.toString.call(t)}function Tt(t){return!(!Ft(t)||""===t)}var zt=function(t,e){for(var n=-1,r=null==t?0:t.length;++n<r&&!1!==e(t[n],n,t););return t};var $t=function(t){return function(e,n,r){for(var i=-1,o=Object(e),l=r(e),a=l.length;a--;){var s=l[t?a:++i];if(!1===n(o[s],s,o))break}return e}}();var It=function(t,e){for(var n=-1,r=Array(t);++n<t;)r[n]=e(n);return r};var Et=function(t){return p(t)&&"[object Arguments]"==d(t)},Nt=Object.prototype,Rt=Nt.hasOwnProperty,Ct=Nt.propertyIsEnumerable,Bt=Et(function(){return arguments}())?Et:function(t){return p(t)&&Rt.call(t,"callee")&&!Ct.call(t,"callee")};var Ut=function(){return!1},Lt=n((function(t,e){var n=e&&!e.nodeType&&e,r=n&&t&&!t.nodeType&&t,i=r&&r.exports===n?o.Buffer:void 0,l=(i?i.isBuffer:void 0)||Ut;t.exports=l})),Dt=/^(?:0|[1-9]\d*)$/;var Ht=function(t,e){var n=typeof t;return!!(e=null==e?9007199254740991:e)&&("number"==n||"symbol"!=n&&Dt.test(t))&&t>-1&&t%1==0&&t<e};var Kt=function(t){return"number"==typeof t&&t>-1&&t%1==0&&t<=9007199254740991},Xt={};Xt["[object Float32Array]"]=Xt["[object Float64Array]"]=Xt["[object Int8Array]"]=Xt["[object Int16Array]"]=Xt["[object Int32Array]"]=Xt["[object Uint8Array]"]=Xt["[object Uint8ClampedArray]"]=Xt["[object Uint16Array]"]=Xt["[object Uint32Array]"]=!0,Xt["[object Arguments]"]=Xt["[object Array]"]=Xt["[object ArrayBuffer]"]=Xt["[object Boolean]"]=Xt["[object DataView]"]=Xt["[object Date]"]=Xt["[object Error]"]=Xt["[object Function]"]=Xt["[object Map]"]=Xt["[object Number]"]=Xt["[object Object]"]=Xt["[object RegExp]"]=Xt["[object Set]"]=Xt["[object String]"]=Xt["[object WeakMap]"]=!1;var Jt=function(t){return p(t)&&Kt(t.length)&&!!Xt[d(t)]};var Yt=function(t){return function(e){return t(e)}},Zt=n((function(t,e){var n=e&&!e.nodeType&&e,i=n&&t&&!t.nodeType&&t,o=i&&i.exports===n&&r.process,l=function(){try{var t=i&&i.require&&i.require("util").types;return t||o&&o.binding&&o.binding("util")}catch(t){}}();t.exports=l})),Vt=Zt&&Zt.isTypedArray,Wt=Vt?Yt(Vt):Jt,qt=Object.prototype.hasOwnProperty;var Gt=function(e,n){var r=t(e),i=!r&&Bt(e),o=!r&&!i&&Lt(e),l=!r&&!i&&!o&&Wt(e),a=r||i||o||l,s=a?It(e.length,String):[],u=s.length;for(var c in e)!n&&!qt.call(e,c)||a&&("length"==c||o&&("offset"==c||"parent"==c)||l&&("buffer"==c||"byteLength"==c||"byteOffset"==c)||Ht(c,u))||s.push(c);return s},Qt=Object.prototype;var te=function(t){var e=t&&t.constructor;return t===("function"==typeof e&&e.prototype||Qt)};var ee=function(t,e){return function(n){return t(e(n))}}(Object.keys,Object),ne=Object.prototype.hasOwnProperty;var re=function(t){if(!te(t))return ee(t);var e=[];for(var n in Object(t))ne.call(t,n)&&"constructor"!=n&&e.push(n);return e};var ie=function(t){return null!=t&&Kt(t.length)&&!j(t)};var oe=function(t){return ie(t)?Gt(t):re(t)};var le=function(t,e){return function(n,r){if(null==n)return n;if(!ie(n))return t(n,r);for(var i=n.length,o=e?i:-1,l=Object(n);(e?o--:++o<i)&&!1!==r(l[o],o,l););return n}}((function(t,e){return t&&$t(t,e,oe)}));var ae=function(t){return t};var se=function(t){return"function"==typeof t?t:ae};var ue=function(e,n){return(t(e)?zt:le)(e,se(n))};var ce=function(){this.__data__=new rt,this.size=0};var fe=function(t){var e=this.__data__,n=e.delete(t);return this.size=e.size,n};var he=function(t){return this.__data__.get(t)};var ge=function(t){return this.__data__.has(t)};var ve=function(t,e){var n=this.__data__;if(n instanceof rt){var r=n.__data__;if(!it||r.length<199)return r.push([t,e]),this.size=++n.size,this;n=this.__data__=new gt(r)}return n.set(t,e),this.size=n.size,this};function de(t){var e=this.__data__=new rt(t);this.size=e.size}de.prototype.clear=ce,de.prototype.delete=fe,de.prototype.get=he,de.prototype.has=ge,de.prototype.set=ve;var pe=de;var ye=function(t){return this.__data__.set(t,"__lodash_hash_undefined__"),this};var _e=function(t){return this.__data__.has(t)};function me(t){var e=-1,n=null==t?0:t.length;for(this.__data__=new gt;++e<n;)this.add(t[e])}me.prototype.add=me.prototype.push=ye,me.prototype.has=_e;var be=me;var xe=function(t,e){for(var n=-1,r=null==t?0:t.length;++n<r;)if(e(t[n],n,t))return!0;return!1};var we=function(t,e){return t.has(e)};var je=function(t,e,n,r,i,o){var l=1&n,a=t.length,s=e.length;if(a!=s&&!(l&&s>a))return!1;var u=o.get(t),c=o.get(e);if(u&&c)return u==e&&c==t;var f=-1,h=!0,g=2&n?new be:void 0;for(o.set(t,e),o.set(e,t);++f<a;){var v=t[f],d=e[f];if(r)var p=l?r(d,v,f,e,t,o):r(v,d,f,t,e,o);if(void 0!==p){if(p)continue;h=!1;break}if(g){if(!xe(e,(function(t,e){if(!we(g,e)&&(v===t||i(v,t,n,r,o)))return g.push(e)}))){h=!1;break}}else if(v!==d&&!i(v,d,n,r,o)){h=!1;break}}return o.delete(t),o.delete(e),h},Ae=o.Uint8Array;var Oe=function(t){var e=-1,n=Array(t.size);return t.forEach((function(t,r){n[++e]=[r,t]})),n};var Se=function(t){var e=-1,n=Array(t.size);return t.forEach((function(t){n[++e]=t})),n},Me=l?l.prototype:void 0,Pe=Me?Me.valueOf:void 0;var ke=function(t,e,n,r,i,o,l){switch(n){case"[object DataView]":if(t.byteLength!=e.byteLength||t.byteOffset!=e.byteOffset)return!1;t=t.buffer,e=e.buffer;case"[object ArrayBuffer]":return!(t.byteLength!=e.byteLength||!o(new Ae(t),new Ae(e)));case"[object Boolean]":case"[object Date]":case"[object Number]":return V(+t,+e);case"[object Error]":return t.name==e.name&&t.message==e.message;case"[object RegExp]":case"[object String]":return t==e+"";case"[object Map]":var a=Oe;case"[object Set]":var s=1&r;if(a||(a=Se),t.size!=e.size&&!s)return!1;var u=l.get(t);if(u)return u==e;r|=2,l.set(t,e);var c=je(a(t),a(e),r,i,o,l);return l.delete(t),c;case"[object Symbol]":if(Pe)return Pe.call(t)==Pe.call(e)}return!1};var Fe=function(t,e){for(var n=-1,r=e.length,i=t.length;++n<r;)t[i+n]=e[n];return t};var Te=function(e,n,r){var i=n(e);return t(e)?i:Fe(i,r(e))};var ze=function(t,e){for(var n=-1,r=null==t?0:t.length,i=0,o=[];++n<r;){var l=t[n];e(l,n,t)&&(o[i++]=l)}return o};var $e=function(){return[]},Ie=Object.prototype.propertyIsEnumerable,Ee=Object.getOwnPropertySymbols,Ne=Ee?function(t){return null==t?[]:(t=Object(t),ze(Ee(t),(function(e){return Ie.call(t,e)})))}:$e;var Re=function(t){return Te(t,oe,Ne)},Ce=Object.prototype.hasOwnProperty;var Be=function(t,e,n,r,i,o){var l=1&n,a=Re(t),s=a.length;if(s!=Re(e).length&&!l)return!1;for(var u=s;u--;){var c=a[u];if(!(l?c in e:Ce.call(e,c)))return!1}var f=o.get(t),h=o.get(e);if(f&&h)return f==e&&h==t;var g=!0;o.set(t,e),o.set(e,t);for(var v=l;++u<s;){var d=t[c=a[u]],p=e[c];if(r)var y=l?r(p,d,c,e,t,o):r(d,p,c,t,e,o);if(!(void 0===y?d===p||i(d,p,n,r,o):y)){g=!1;break}v||(v="constructor"==c)}if(g&&!v){var _=t.constructor,m=e.constructor;_==m||!("constructor"in t)||!("constructor"in e)||"function"==typeof _&&_ instanceof _&&"function"==typeof m&&m instanceof m||(g=!1)}return o.delete(t),o.delete(e),g},Ue=R(o,"DataView"),Le=R(o,"Promise"),De=R(o,"Set"),He=R(o,"WeakMap"),Ke=P(Ue),Xe=P(it),Je=P(Le),Ye=P(De),Ze=P(He),Ve=d;(Ue&&"[object DataView]"!=Ve(new Ue(new ArrayBuffer(1)))||it&&"[object Map]"!=Ve(new it)||Le&&"[object Promise]"!=Ve(Le.resolve())||De&&"[object Set]"!=Ve(new De)||He&&"[object WeakMap]"!=Ve(new He))&&(Ve=function(t){var e=d(t),n="[object Object]"==e?t.constructor:void 0,r=n?P(n):"";if(r)switch(r){case Ke:return"[object DataView]";case Xe:return"[object Map]";case Je:return"[object Promise]";case Ye:return"[object Set]";case Ze:return"[object WeakMap]"}return e});var We=Ve,qe="[object Object]",Ge=Object.prototype.hasOwnProperty;var Qe=function(e,n,r,i,o,l){var a=t(e),s=t(n),u=a?"[object Array]":We(e),c=s?"[object Array]":We(n),f=(u="[object Arguments]"==u?qe:u)==qe,h=(c="[object Arguments]"==c?qe:c)==qe,g=u==c;if(g&&Lt(e)){if(!Lt(n))return!1;a=!0,f=!1}if(g&&!f)return l||(l=new pe),a||Wt(e)?je(e,n,r,i,o,l):ke(e,n,u,r,i,o,l);if(!(1&r)){var v=f&&Ge.call(e,"__wrapped__"),d=h&&Ge.call(n,"__wrapped__");if(v||d){var p=v?e.value():e,y=d?n.value():n;return l||(l=new pe),o(p,y,r,i,l)}}return!!g&&(l||(l=new pe),Be(e,n,r,i,o,l))};var tn=function t(e,n,r,i,o){return e===n||(null==e||null==n||!p(e)&&!p(n)?e!=e&&n!=n:Qe(e,n,r,i,t,o))};var en=function(t,e,n,r){var i=n.length,o=i,l=!r;if(null==t)return!o;for(t=Object(t);i--;){var a=n[i];if(l&&a[2]?a[1]!==t[a[0]]:!(a[0]in t))return!1}for(;++i<o;){var s=(a=n[i])[0],u=t[s],c=a[1];if(l&&a[2]){if(void 0===u&&!(s in t))return!1}else{var f=new pe;if(r)var h=r(u,c,s,t,e,f);if(!(void 0===h?tn(c,u,3,r,f):h))return!1}}return!0};var nn=function(t){return t==t&&!x(t)};var rn=function(t){for(var e=oe(t),n=e.length;n--;){var r=e[n],i=t[r];e[n]=[r,i,nn(i)]}return e};var on=function(t,e){return function(n){return null!=n&&(n[t]===e&&(void 0!==e||t in Object(n)))}};var ln=function(t){var e=rn(t);return 1==e.length&&e[0][2]?on(e[0][0],e[0][1]):function(n){return n===t||en(n,t,e)}};var an=function(t,e){return null!=t&&e in Object(t)};var sn=function(e,n,r){for(var i=-1,o=(n=At(n,e)).length,l=!1;++i<o;){var a=Ot(n[i]);if(!(l=null!=e&&r(e,a)))break;e=e[a]}return l||++i!=o?l:!!(o=null==e?0:e.length)&&Kt(o)&&Ht(a,o)&&(t(e)||Bt(e))};var un=function(t,e){return null!=t&&sn(t,e,an)};var cn=function(t,e){return b(t)&&nn(e)?on(Ot(t),e):function(n){var r=Mt(n,t);return void 0===r&&r===e?un(n,t):tn(e,r,3)}};var fn=function(t){return function(e){return null==e?void 0:e[t]}};var hn=function(t){return function(e){return St(e,t)}};var gn=function(t){return b(t)?fn(Ot(t)):hn(t)};var vn=function(e){return"function"==typeof e?e:null==e?ae:"object"==typeof e?t(e)?cn(e[0],e[1]):ln(e):gn(e)};var dn=function(t,e){var n=-1,r=ie(t)?Array(t.length):[];return le(t,(function(t,i,o){r[++n]=e(t,i,o)})),r};var pn=function(e,n){return(t(e)?mt:dn)(e,vn(n))};var yn=function(t,e){for(var n,r=-1,i=t.length;++r<i;){var o=e(t[r]);void 0!==o&&(n=void 0===n?o:n+o)}return n};var _n=function(t){return t&&t.length?yn(t,ae):0};var mn=function(e){return"string"==typeof e||!t(e)&&p(e)&&"[object String]"==d(e)},bn=fn("length"),xn=RegExp("[\\u200d\\ud800-\\udfff\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff\\ufe0e\\ufe0f]");var wn=function(t){return xn.test(t)},jn="[\\ud800-\\udfff]",An="[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]",On="\\ud83c[\\udffb-\\udfff]",Sn="[^\\ud800-\\udfff]",Mn="(?:\\ud83c[\\udde6-\\uddff]){2}",Pn="[\\ud800-\\udbff][\\udc00-\\udfff]",kn="(?:"+An+"|"+On+")"+"?",Fn="[\\ufe0e\\ufe0f]?"+kn+("(?:\\u200d(?:"+[Sn,Mn,Pn].join("|")+")[\\ufe0e\\ufe0f]?"+kn+")*"),Tn="(?:"+[Sn+An+"?",An,Mn,Pn,jn].join("|")+")",zn=RegExp(On+"(?="+On+")|"+Tn+Fn,"g");var $n=function(t){for(var e=zn.lastIndex=0;zn.test(t);)++e;return e};var In=function(t){return wn(t)?$n(t):bn(t)};var En=function(t){if(null==t)return 0;if(ie(t))return mn(t)?In(t):t.length;var e=We(t);return"[object Map]"==e||"[object Set]"==e?t.size:re(t).length};var Nn=function(t){return"number"==typeof t||p(t)&&"[object Number]"==d(t)};function Rn(t){return"[object Object]"===Object.prototype.toString.call(t)}function Cn(t){if(Rn(t)){for(let e in t)return!0;return!1}return!1}function Bn(t){return"[object Array]"===Object.prototype.toString.call(t)}function Un(t){return!!function(t){return"[object Undefined]"===Object.prototype.toString.call(t)}(t)||(!!function(t){return"[object Null]"===Object.prototype.toString.call(t)}(t)||(!!function(t){if(Rn(t)){for(let e in t)return!1;return!0}return!1}(t)||(!!function(t){return!(!Ft(t)||""!==t)}(t)||!!function(t){return!!Bn(t)&&0===t.length}(t))))}function Ln(t){return!!Bn(t)&&(0!==t.length&&(1!==t.length||!Un(t[0])))}function Dn(t){let e=!1;return Tt(t)?e=!isNaN(Number(t)):function(t){return"[object Number]"===Object.prototype.toString.call(t)}(t)&&(e=!0),e}var Hn=/\s/;var Kn=function(t){for(var e=t.length;e--&&Hn.test(t.charAt(e)););return e},Xn=/^\s+/;var Jn=function(t){return t?t.slice(0,Kn(t)+1).replace(Xn,""):t},Yn=/^[-+]0x[0-9a-f]+$/i,Zn=/^0b[01]+$/i,Vn=/^0o[0-7]+$/i,Wn=parseInt;var qn=function(t){if("number"==typeof t)return t;if(y(t))return NaN;if(x(t)){var e="function"==typeof t.valueOf?t.valueOf():t;t=x(e)?e+"":e}if("string"!=typeof t)return 0===t?t:+t;t=Jn(t);var n=Zn.test(t);return n||Vn.test(t)?Wn(t.slice(2),n?2:8):Yn.test(t)?NaN:+t};var Gn=function(t){return t?Infinity===(t=qn(t))||-Infinity===t?17976931348623157e292*(t<0?-1:1):t==t?t:0:0===t?t:0};function Qn(t){if(!Dn(t))return 0;return Gn(t)}function tr(t,e){return!!Rn(t)&&(!(!Tt(e)&&!Dn(e))&&e in t)}function er(t,e={}){if(En(t)<=0)return[];let n=Mt(e,"keyX");Tt(n)||(n="x");let r=Mt(e,"keyY");Tt(r)||(r="y");let i=[];return ue(t,(t=>{let e=null,o=null;Bn(t)&&En(t)>=2?(e=Mt(t,0),o=Mt(t,1)):(e=Mt(t,n,null),o=Mt(t,r,null)),Dn(e)&&Dn(o)&&(e=qn(e),o=qn(o),i.push({x:e,y:o}))})),i}function nr(t,e={}){if(En(t)<=0)return[];let n=Mt(e,"keyX");Tt(n)||(n="x");let r=Mt(e,"keyY");Tt(r)||(r="y");let i=Mt(e,"keyZ","");Tt(i)||(i="z");let o=[];return ue(t,(t=>{let e=null,l=null,a=null;Bn(t)&&En(t)>=3?(e=Mt(t,0),l=Mt(t,1),a=Mt(t,2)):(e=Mt(t,n,null),l=Mt(t,r,null),a=Mt(t,i,null)),Dn(e)&&Dn(l)&&Dn(a)&&(e=qn(e),l=qn(l),a=qn(a),o.push({x:e,y:l,z:a}))})),o}var rr=function(t,e,n){for(var r=-1,i=t.length;++r<i;){var o=t[r],l=e(o);if(null!=l&&(void 0===a?l==l&&!y(l):n(l,a)))var a=l,s=o}return s};var ir=function(t,e){return t<e};var or=function(t){return t&&t.length?rr(t,ae,ir):void 0};var lr=function(t,e){return t>e};var ar=function(t){return t&&t.length?rr(t,ae,lr):void 0};function sr(t,e,n){return e in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}var ur=function(t,e){var n=[];return le(t,(function(t,r,i){e(t,r,i)&&n.push(t)})),n};var cr=function(e,n){return(t(e)?ze:ur)(e,vn(n))},fr=Math.ceil,hr=Math.max;var gr=function(t,e,n,r){for(var i=-1,o=hr(fr((e-t)/(n||1)),0),l=Array(o);o--;)l[r?o:++i]=t,t+=n;return l};var vr=function(t,e,n){if(!x(n))return!1;var r=typeof e;return!!("number"==r?ie(n)&&Ht(e,n.length):"string"==r&&e in n)&&V(n[e],t)};var dr=function(t){return function(e,n,r){return r&&"number"!=typeof r&&vr(e,n,r)&&(n=r=void 0),e=Gn(e),void 0===n?(n=e,e=0):n=Gn(n),r=void 0===r?e<n?1:-1:Gn(r),gr(e,n,r,t)}}();var pr=function(t,e){var n=null==t?0:t.length;return n?yn(t,e)/n:NaN};var yr=function(t){return pr(t,ae)};function _r(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function mr(t){if(!Ln(t))return{err:"arr is not an effective array"};let e=Mt(t,0),n=0;Ln(e)&&(n=En(e));let r=[];if(0===n?(r=cr(t,Dn),r=pn(r,Qn)):ue(t,(t=>{let e=!0,i=[];ue(dr(n),(n=>{let r=Mt(t,n);Dn(r)||(e=!1),i.push(Qn(r))})),e&&r.push(i)})),0===En(r))return{err:"arr has no effective data"};let i=t=>{let e=(t=>{let e=or(t),n=ar(t);return{min:e,max:n,range:n-e,mid:(n+e)/2,avg:yr(t)}})(t),n=((t,e,n,r)=>pn(t,(t=>(t-e)/r)))(t,e.min,e.max,e.range);return function(t){for(var e=1;e<arguments.length;e++){var n=null!=arguments[e]?arguments[e]:{};e%2?_r(Object(n),!0).forEach((function(e){sr(t,e,n[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(n)):_r(Object(n)).forEach((function(e){Object.defineProperty(t,e,Object.getOwnPropertyDescriptor(n,e))}))}return t}({arr:n},e)},o=null;return o=0===n?i(r):pn(dr(n),(t=>{let e=pn(r,t);return i(e)})),o}function br(t,e=[]){if(!Ln(t))return{err:"arr is not an effective array"};if(En(e)>0){if(!Cn(Mt(t,0)))return{err:"arr is not an effective array of objects"};let n=[];ue(t,(t=>{let r=[];ue(e,(e=>{r.push(Mt(t,e,""))})),n.push(r)})),t=n}return mr(t)}function xr(t,e={}){let n=Mt(e,"scale");Dn(n)||(n=1),n=Qn(n);let r=br(pn(t,"x")),i=br(pn(t,"y")),o=br(pn(t,"z")),l=Math.max(r.range,i.range),a=l/2,s=[{min:r.mid-a,max:r.mid+a,range:l},{min:i.mid-a,max:i.mid+a,range:l},{min:o.min,max:o.max,range:o.range}],u=(t,e)=>Nn(t)?(t-s[e].min)/s[e].range*n:null;t=pn(t,(t=>({x:u(t.x,0),y:u(t.y,1),z:u(t.z,2)})));let c=pn(t,"x"),f=or(c),h=ar(c),g=pn(t,"y"),v=or(g),d=ar(g),p=pn(t,"z");return{ps:t,psMinMax:{xmin:f,xmax:h,ymin:v,ymax:d,zmin:or(p),zmax:ar(p)},st:s,nv:u,inv:(t,e)=>Nn(t)?t/n*s[e].range+s[e].min:null}}var wr=l?l.isConcatSpreadable:void 0;var jr=function(e){return t(e)||Bt(e)||!!(wr&&e&&e[wr])};var Ar=function t(e,n,r,i,o){var l=-1,a=e.length;for(r||(r=jr),o||(o=[]);++l<a;){var s=e[l];n>0&&r(s)?n>1?t(s,n-1,r,i,o):Fe(o,s):i||(o[o.length]=s)}return o};var Or=function(t){return(null==t?0:t.length)?Ar(t,1):[]};function Sr(t){let e=function(t){let e=En(Mt(t,"0",null)),n=En(Mt(t,"0.0",null));return 2===En(Mt(t,"0.0.0",null))?3:2===n?2:2===e?1:0===e?0:(console.log("invalid point depth",t),null)}(t);return 3===e?Or(t):2===e?t:1===e?[t]:0===e?[]:t}function Mr(t){if(!Ln(t))return 0;t=Sr(t);let e=0;return ue(t,((t,n)=>{let r=function(t,e={}){let n=Mt(e,"useAbs");if(kt(n)||(n=!0),!Ln(t))return 0;let r=[];if(ue(t,(t=>{2===En(t)&&Dn(t[0])&&Dn(t[1])&&r.push([Qn(t[0]),Qn(t[1])])})),!Ln(r))return 0;let i,o=-1,l=En(r),a=r[l-1],s=0;for(;++o<l;)i=a,a=r[o],s+=i[1]*a[0]-i[0]*a[1];let u=s/2;return n&&(u=Math.abs(u)),u}(t);0===n?e=r:e-=r})),e<0?0:e}var Pr=function(){var t,e=0,n=!1;function r(e,n){return t.list.push({type:e,data:n?JSON.parse(JSON.stringify(n)):void 0}),t}return t={list:[],segmentId:function(){return e++},checkIntersection:function(t,e){return r("check",{seg1:t,seg2:e})},segmentChop:function(t,e){return r("div_seg",{seg:t,pt:e}),r("chop",{seg:t,pt:e})},statusRemove:function(t){return r("pop_seg",{seg:t})},segmentUpdate:function(t){return r("seg_update",{seg:t})},segmentNew:function(t,e){return r("new_seg",{seg:t,primary:e})},segmentRemove:function(t){return r("rem_seg",{seg:t})},tempStatus:function(t,e,n){return r("temp_status",{seg:t,above:e,below:n})},rewind:function(t){return r("rewind",{seg:t})},status:function(t,e,n){return r("status",{seg:t,above:e,below:n})},vert:function(e){return e===n?t:(n=e,r("vert",{x:e}))},log:function(t){return"string"!=typeof t&&(t=JSON.stringify(t,!1,"  ")),r("log",{txt:t})},reset:function(){return r("reset")},selected:function(t){return r("selected",{segs:t})},chainStart:function(t){return r("chain_start",{seg:t})},chainRemoveHead:function(t,e){return r("chain_rem_head",{index:t,pt:e})},chainRemoveTail:function(t,e){return r("chain_rem_tail",{index:t,pt:e})},chainNew:function(t,e){return r("chain_new",{pt1:t,pt2:e})},chainMatch:function(t){return r("chain_match",{index:t})},chainClose:function(t){return r("chain_close",{index:t})},chainAddHead:function(t,e){return r("chain_add_head",{index:t,pt:e})},chainAddTail:function(t,e){return r("chain_add_tail",{index:t,pt:e})},chainConnect:function(t,e){return r("chain_con",{index1:t,index2:e})},chainReverse:function(t){return r("chain_rev",{index:t})},chainJoin:function(t,e){return r("chain_join",{index1:t,index2:e})},done:function(){return r("done")}}};var kr=function(t){"number"!=typeof t&&(t=1e-10);var e={epsilon:function(e){return"number"==typeof e&&(t=e),t},pointAboveOrOnLine:function(e,n,r){var i=n[0],o=n[1],l=r[0],a=r[1],s=e[0];return(l-i)*(e[1]-o)-(a-o)*(s-i)>=-t},pointBetween:function(e,n,r){var i=e[1]-n[1],o=r[0]-n[0],l=e[0]-n[0],a=r[1]-n[1],s=l*o+i*a;return!(s<t)&&!(s-(o*o+a*a)>-t)},pointsSameX:function(e,n){return Math.abs(e[0]-n[0])<t},pointsSameY:function(e,n){return Math.abs(e[1]-n[1])<t},pointsSame:function(t,n){return e.pointsSameX(t,n)&&e.pointsSameY(t,n)},pointsCompare:function(t,n){return e.pointsSameX(t,n)?e.pointsSameY(t,n)?0:t[1]<n[1]?-1:1:t[0]<n[0]?-1:1},pointsCollinear:function(e,n,r){var i=e[0]-n[0],o=e[1]-n[1],l=n[0]-r[0],a=n[1]-r[1];return Math.abs(i*a-l*o)<t},linesIntersect:function(e,n,r,i){var o=n[0]-e[0],l=n[1]-e[1],a=i[0]-r[0],s=i[1]-r[1],u=o*s-l*a;if(Math.abs(u)<t)return!1;var c=e[0]-r[0],f=e[1]-r[1],h=(a*f-s*c)/u,g=(o*f-l*c)/u,v={alongA:0,alongB:0,pt:[e[0]+h*o,e[1]+h*l]};return v.alongA=h<=-t?-2:h<t?-1:h-1<=-t?0:h-1<t?1:2,v.alongB=g<=-t?-2:g<t?-1:g-1<=-t?0:g-1<t?1:2,v},pointInsideRegion:function(e,n){for(var r=e[0],i=e[1],o=n[n.length-1][0],l=n[n.length-1][1],a=!1,s=0;s<n.length;s++){var u=n[s][0],c=n[s][1];c-i>t!=l-i>t&&(o-u)*(i-c)/(l-c)+u-r>t&&(a=!a),o=u,l=c}return a}};return e},Fr={create:function(){var t={root:{root:!0,next:null},exists:function(e){return null!==e&&e!==t.root},isEmpty:function(){return null===t.root.next},getHead:function(){return t.root.next},insertBefore:function(e,n){for(var r=t.root,i=t.root.next;null!==i;){if(n(i))return e.prev=i.prev,e.next=i,i.prev.next=e,void(i.prev=e);r=i,i=i.next}r.next=e,e.prev=r,e.next=null},findTransition:function(e){for(var n=t.root,r=t.root.next;null!==r&&!e(r);)n=r,r=r.next;return{before:n===t.root?null:n,after:r,insert:function(t){return t.prev=n,t.next=r,n.next=t,null!==r&&(r.prev=t),t}}}};return t},node:function(t){return t.prev=null,t.next=null,t.remove=function(){t.prev.next=t.next,t.next&&(t.next.prev=t.prev),t.prev=null,t.next=null},t}};var Tr=function(t,e,n){function r(t,e,r){return{id:n?n.segmentId():-1,start:t,end:e,myFill:{above:r.myFill.above,below:r.myFill.below},otherFill:null}}var i=Fr.create();function o(t,n){i.insertBefore(t,(function(r){return function(t,n,r,i,o,l){var a=e.pointsCompare(n,o);return 0!==a?a:e.pointsSame(r,l)?0:t!==i?t?1:-1:e.pointAboveOrOnLine(r,i?o:l,i?l:o)?1:-1}(t.isStart,t.pt,n,r.isStart,r.pt,r.other.pt)<0}))}function l(t,e){var n=function(t,e){var n=Fr.node({isStart:!0,pt:t.start,seg:t,primary:e,other:null,status:null});return o(n,t.end),n}(t,e);return function(t,e,n){var r=Fr.node({isStart:!1,pt:e.end,seg:e,primary:n,other:t,status:null});t.other=r,o(r,t.pt)}(n,t,e),n}function a(t,e){var i=r(e,t.seg.end,t.seg);return function(t,e){n&&n.segmentChop(t.seg,e),t.other.remove(),t.seg.end=e,t.other.pt=e,o(t.other,t.pt)}(t,e),l(i,t.primary)}function s(r,o){var l=Fr.create();function s(t){return l.findTransition((function(n){var r,i,o,l,a,s;return(r=t,i=n.ev,o=r.seg.start,l=r.seg.end,a=i.seg.start,s=i.seg.end,e.pointsCollinear(o,a,s)?e.pointsCollinear(l,a,s)||e.pointAboveOrOnLine(l,a,s)?1:-1:e.pointAboveOrOnLine(o,a,s)?1:-1)>0}))}function u(t,r){var i=t.seg,o=r.seg,l=i.start,s=i.end,u=o.start,c=o.end;n&&n.checkIntersection(i,o);var f=e.linesIntersect(l,s,u,c);if(!1===f){if(!e.pointsCollinear(l,s,u))return!1;if(e.pointsSame(l,c)||e.pointsSame(s,u))return!1;var h=e.pointsSame(l,u),g=e.pointsSame(s,c);if(h&&g)return r;var v=!h&&e.pointBetween(l,u,c),d=!g&&e.pointBetween(s,u,c);if(h)return d?a(r,s):a(t,c),r;v&&(g||(d?a(r,s):a(t,c)),a(r,l))}else 0===f.alongA&&(-1===f.alongB?a(t,u):0===f.alongB?a(t,f.pt):1===f.alongB&&a(t,c)),0===f.alongB&&(-1===f.alongA?a(r,l):0===f.alongA?a(r,f.pt):1===f.alongA&&a(r,s));return!1}for(var c=[];!i.isEmpty();){var f=i.getHead();if(n&&n.vert(f.pt[0]),f.isStart){n&&n.segmentNew(f.seg,f.primary);var h=s(f),g=h.before?h.before.ev:null,v=h.after?h.after.ev:null;function d(){if(g){var t=u(f,g);if(t)return t}return!!v&&u(f,v)}n&&n.tempStatus(f.seg,!!g&&g.seg,!!v&&v.seg);var p,y=d();if(y){var _;if(t)(_=null===f.seg.myFill.below||f.seg.myFill.above!==f.seg.myFill.below)&&(y.seg.myFill.above=!y.seg.myFill.above);else y.seg.otherFill=f.seg.myFill;n&&n.segmentUpdate(y.seg),f.other.remove(),f.remove()}if(i.getHead()!==f){n&&n.rewind(f.seg);continue}if(t)_=null===f.seg.myFill.below||f.seg.myFill.above!==f.seg.myFill.below,f.seg.myFill.below=v?v.seg.myFill.above:r,f.seg.myFill.above=_?!f.seg.myFill.below:f.seg.myFill.below;else if(null===f.seg.otherFill)p=v?f.primary===v.primary?v.seg.otherFill.above:v.seg.myFill.above:f.primary?o:r,f.seg.otherFill={above:p,below:p};n&&n.status(f.seg,!!g&&g.seg,!!v&&v.seg),f.other.status=h.insert(Fr.node({ev:f}))}else{var m=f.status;if(null===m)throw new Error("PolyBool: Zero-length segment detected; your epsilon is probably too small or too large");if(l.exists(m.prev)&&l.exists(m.next)&&u(m.prev.ev,m.next.ev),n&&n.statusRemove(m.ev.seg),m.remove(),!f.primary){var b=f.seg.myFill;f.seg.myFill=f.seg.otherFill,f.seg.otherFill=b}c.push(f.seg)}i.getHead().remove()}return n&&n.done(),c}return t?{addRegion:function(t){for(var r,i,o,a=t[t.length-1],s=0;s<t.length;s++){r=a,a=t[s];var u=e.pointsCompare(r,a);0!==u&&l((i=u<0?r:a,o=u<0?a:r,{id:n?n.segmentId():-1,start:i,end:o,myFill:{above:null,below:null},otherFill:null}),!0)}},calculate:function(t){return s(t,!1)}}:{calculate:function(t,e,n,i){return t.forEach((function(t){l(r(t.start,t.end,t),!0)})),n.forEach((function(t){l(r(t.start,t.end,t),!1)})),s(e,i)}}};var zr=function(t,e,n){var r=[],i=[];return t.forEach((function(t){var o=t.start,l=t.end;if(e.pointsSame(o,l))console.warn("PolyBool: Warning: Zero-length segment detected; your epsilon is probably too small or too large");else{n&&n.chainStart(t);for(var a={index:0,matches_head:!1,matches_pt1:!1},s={index:0,matches_head:!1,matches_pt1:!1},u=a,c=0;c<r.length;c++){var f=(p=r[c])[0];p[1];var h=p[p.length-1];if(p[p.length-2],e.pointsSame(f,o)){if(A(c,!0,!0))break}else if(e.pointsSame(f,l)){if(A(c,!0,!1))break}else if(e.pointsSame(h,o)){if(A(c,!1,!0))break}else if(e.pointsSame(h,l)&&A(c,!1,!1))break}if(u===a)return r.push([o,l]),void(n&&n.chainNew(o,l));if(u===s){n&&n.chainMatch(a.index);var g=a.index,v=a.matches_pt1?l:o,d=a.matches_head,p=r[g],y=d?p[0]:p[p.length-1],_=d?p[1]:p[p.length-2],m=d?p[p.length-1]:p[0],b=d?p[p.length-2]:p[1];return e.pointsCollinear(_,y,v)&&(d?(n&&n.chainRemoveHead(a.index,v),p.shift()):(n&&n.chainRemoveTail(a.index,v),p.pop()),y=_),e.pointsSame(m,v)?(r.splice(g,1),e.pointsCollinear(b,m,y)&&(d?(n&&n.chainRemoveTail(a.index,y),p.pop()):(n&&n.chainRemoveHead(a.index,y),p.shift())),n&&n.chainClose(a.index),void i.push(p)):void(d?(n&&n.chainAddHead(a.index,v),p.unshift(v)):(n&&n.chainAddTail(a.index,v),p.push(v)))}var x=a.index,w=s.index;n&&n.chainConnect(x,w);var j=r[x].length<r[w].length;a.matches_head?s.matches_head?j?(O(x),S(x,w)):(O(w),S(w,x)):S(w,x):s.matches_head?S(x,w):j?(O(x),S(w,x)):(O(w),S(x,w))}function A(t,e,n){return u.index=t,u.matches_head=e,u.matches_pt1=n,u===a?(u=s,!1):(u=null,!0)}function O(t){n&&n.chainReverse(t),r[t].reverse()}function S(t,i){var o=r[t],l=r[i],a=o[o.length-1],s=o[o.length-2],u=l[0],c=l[1];e.pointsCollinear(s,a,u)&&(n&&n.chainRemoveTail(t,a),o.pop(),a=s),e.pointsCollinear(a,u,c)&&(n&&n.chainRemoveHead(i,u),l.shift()),n&&n.chainJoin(t,i),r[t]=o.concat(l),r.splice(i,1)}})),i};function $r(t,e,n){var r=[];return t.forEach((function(t){var i=(t.myFill.above?8:0)+(t.myFill.below?4:0)+(t.otherFill&&t.otherFill.above?2:0)+(t.otherFill&&t.otherFill.below?1:0);0!==e[i]&&r.push({id:n?n.segmentId():-1,start:t.start,end:t.end,myFill:{above:1===e[i],below:2===e[i]},otherFill:null})})),n&&n.selected(r),r}var Ir,Er={union:function(t,e){return $r(t,[0,2,1,0,2,2,0,0,1,0,1,0,0,0,0,0],e)},intersect:function(t,e){return $r(t,[0,0,0,0,0,2,0,2,0,0,1,1,0,2,1,0],e)},difference:function(t,e){return $r(t,[0,0,0,0,2,0,2,0,1,1,0,0,0,1,2,0],e)},differenceRev:function(t,e){return $r(t,[0,2,1,0,0,0,1,1,0,2,0,2,0,0,0,0],e)},xor:function(t,e){return $r(t,[0,2,1,0,2,0,0,1,1,0,0,2,0,1,2,0],e)}},Nr=Er,Rr={toPolygon:function(t,e){function n(e){if(e.length<=0)return t.segments({inverted:!1,regions:[]});function n(e){var n=e.slice(0,e.length-1);return t.segments({inverted:!1,regions:[n]})}for(var r=n(e[0]),i=1;i<e.length;i++)r=t.selectDifference(t.combine(r,n(e[i])));return r}if("Polygon"===e.type)return t.polygon(n(e.coordinates));if("MultiPolygon"===e.type){for(var r=t.segments({inverted:!1,regions:[]}),i=0;i<e.coordinates.length;i++)r=t.selectUnion(t.combine(r,n(e.coordinates[i])));return t.polygon(r)}throw new Error("PolyBool: Cannot convert GeoJSON object to PolyBool polygon")},fromPolygon:function(t,e,n){function r(t,n){return e.pointInsideRegion([.5*(t[0][0]+t[1][0]),.5*(t[0][1]+t[1][1])],n)}function i(t){return{region:t,children:[]}}n=t.polygon(t.segments(n));var o=i(null);function l(t,e){for(var n=0;n<t.children.length;n++){if(r(e,(a=t.children[n]).region))return void l(a,e)}var o=i(e);for(n=0;n<t.children.length;n++){var a;r((a=t.children[n]).region,e)&&(o.children.push(a),t.children.splice(n,1),n--)}t.children.push(o)}for(var a=0;a<n.regions.length;a++){var s=n.regions[a];s.length<3||l(o,s)}function u(t,e){for(var n=0,r=t[t.length-1][0],i=t[t.length-1][1],o=[],l=0;l<t.length;l++){var a=t[l][0],s=t[l][1];o.push([a,s]),n+=s*r-a*i,r=a,i=s}return n<0!==e&&o.reverse(),o.push([o[0][0],o[0][1]]),o}var c=[];function f(t){var e=[u(t.region,!1)];c.push(e);for(var n=0;n<t.children.length;n++)e.push(h(t.children[n]))}function h(t){for(var e=0;e<t.children.length;e++)f(t.children[e]);return u(t.region,!0)}for(a=0;a<o.children.length;a++)f(o.children[a]);return c.length<=0?{type:"Polygon",coordinates:[]}:1==c.length?{type:"Polygon",coordinates:c[0]}:{type:"MultiPolygon",coordinates:c}}},Cr=Rr,Br=!1,Ur=kr();function Lr(t,e,n){var r=Ir.segments(t),i=Ir.segments(e),o=n(Ir.combine(r,i));return Ir.polygon(o)}Ir={buildLog:function(t){return!0===t?Br=Pr():!1===t&&(Br=!1),!1!==Br&&Br.list},epsilon:function(t){return Ur.epsilon(t)},segments:function(t){var e=Tr(!0,Ur,Br);return t.regions.forEach(e.addRegion),{segments:e.calculate(t.inverted),inverted:t.inverted}},combine:function(t,e){return{combined:Tr(!1,Ur,Br).calculate(t.segments,t.inverted,e.segments,e.inverted),inverted1:t.inverted,inverted2:e.inverted}},selectUnion:function(t){return{segments:Nr.union(t.combined,Br),inverted:t.inverted1||t.inverted2}},selectIntersect:function(t){return{segments:Nr.intersect(t.combined,Br),inverted:t.inverted1&&t.inverted2}},selectDifference:function(t){return{segments:Nr.difference(t.combined,Br),inverted:t.inverted1&&!t.inverted2}},selectDifferenceRev:function(t){return{segments:Nr.differenceRev(t.combined,Br),inverted:!t.inverted1&&t.inverted2}},selectXor:function(t){return{segments:Nr.xor(t.combined,Br),inverted:t.inverted1!==t.inverted2}},polygon:function(t){return{regions:zr(t.segments,Ur,Br),inverted:t.inverted}},polygonFromGeoJSON:function(t){return Cr.toPolygon(Ir,t)},polygonToGeoJSON:function(t){return Cr.fromPolygon(Ir,Ur,t)},union:function(t,e){return Lr(t,e,Ir.selectUnion)},intersect:function(t,e){return Lr(t,e,Ir.selectIntersect)},difference:function(t,e){return Lr(t,e,Ir.selectDifference)},differenceRev:function(t,e){return Lr(t,e,Ir.selectDifferenceRev)},xor:function(t,e){return Lr(t,e,Ir.selectXor)}},"object"==typeof window&&(window.PolyBool=Ir);var Dr=Ir;function Hr(t,e,n,r,i){let o,l,a,s,u=e[0],c=r[0],f=0,h=0;c>u==c>-u?(o=u,u=e[++f]):(o=c,c=r[++h]);let g=0;if(f<t&&h<n)for(c>u==c>-u?(l=u+o,a=o-(l-u),u=e[++f]):(l=c+o,a=o-(l-c),c=r[++h]),o=l,0!==a&&(i[g++]=a);f<t&&h<n;)c>u==c>-u?(l=o+u,s=l-o,a=o-(l-s)+(u-s),u=e[++f]):(l=o+c,s=l-o,a=o-(l-s)+(c-s),c=r[++h]),o=l,0!==a&&(i[g++]=a);for(;f<t;)l=o+u,s=l-o,a=o-(l-s)+(u-s),u=e[++f],o=l,0!==a&&(i[g++]=a);for(;h<n;)l=o+c,s=l-o,a=o-(l-s)+(c-s),c=r[++h],o=l,0!==a&&(i[g++]=a);return 0===o&&0!==g||(i[g++]=o),g}function Kr(t){return new Float64Array(t)}const Xr=Kr(4),Jr=Kr(8),Yr=Kr(12),Zr=Kr(16),Vr=Kr(4);function Wr(t,e,n,r,i,o){const l=(e-o)*(n-i),a=(t-i)*(r-o),s=l-a;if(0===l||0===a||l>0!=a>0)return s;const u=Math.abs(l+a);return Math.abs(s)>=33306690738754716e-32*u?s:-function(t,e,n,r,i,o,l){let a,s,u,c,f,h,g,v,d,p,y,_,m,b,x,w,j,A;const O=t-i,S=n-i,M=e-o,P=r-o;b=O*P,h=134217729*O,g=h-(h-O),v=O-g,h=134217729*P,d=h-(h-P),p=P-d,x=v*p-(b-g*d-v*d-g*p),w=M*S,h=134217729*M,g=h-(h-M),v=M-g,h=134217729*S,d=h-(h-S),p=S-d,j=v*p-(w-g*d-v*d-g*p),y=x-j,f=x-y,Xr[0]=x-(y+f)+(f-j),_=b+y,f=_-b,m=b-(_-f)+(y-f),y=m-w,f=m-y,Xr[1]=m-(y+f)+(f-w),A=_+y,f=A-_,Xr[2]=_-(A-f)+(y-f),Xr[3]=A;let k=function(t,e){let n=e[0];for(let r=1;r<t;r++)n+=e[r];return n}(4,Xr),F=22204460492503146e-32*l;if(k>=F||-k>=F)return k;if(f=t-O,a=t-(O+f)+(f-i),f=n-S,u=n-(S+f)+(f-i),f=e-M,s=e-(M+f)+(f-o),f=r-P,c=r-(P+f)+(f-o),0===a&&0===s&&0===u&&0===c)return k;if(F=11093356479670487e-47*l+33306690738754706e-32*Math.abs(k),k+=O*c+P*a-(M*u+S*s),k>=F||-k>=F)return k;b=a*P,h=134217729*a,g=h-(h-a),v=a-g,h=134217729*P,d=h-(h-P),p=P-d,x=v*p-(b-g*d-v*d-g*p),w=s*S,h=134217729*s,g=h-(h-s),v=s-g,h=134217729*S,d=h-(h-S),p=S-d,j=v*p-(w-g*d-v*d-g*p),y=x-j,f=x-y,Vr[0]=x-(y+f)+(f-j),_=b+y,f=_-b,m=b-(_-f)+(y-f),y=m-w,f=m-y,Vr[1]=m-(y+f)+(f-w),A=_+y,f=A-_,Vr[2]=_-(A-f)+(y-f),Vr[3]=A;const T=Hr(4,Xr,4,Vr,Jr);b=O*c,h=134217729*O,g=h-(h-O),v=O-g,h=134217729*c,d=h-(h-c),p=c-d,x=v*p-(b-g*d-v*d-g*p),w=M*u,h=134217729*M,g=h-(h-M),v=M-g,h=134217729*u,d=h-(h-u),p=u-d,j=v*p-(w-g*d-v*d-g*p),y=x-j,f=x-y,Vr[0]=x-(y+f)+(f-j),_=b+y,f=_-b,m=b-(_-f)+(y-f),y=m-w,f=m-y,Vr[1]=m-(y+f)+(f-w),A=_+y,f=A-_,Vr[2]=_-(A-f)+(y-f),Vr[3]=A;const z=Hr(T,Jr,4,Vr,Yr);b=a*c,h=134217729*a,g=h-(h-a),v=a-g,h=134217729*c,d=h-(h-c),p=c-d,x=v*p-(b-g*d-v*d-g*p),w=s*u,h=134217729*s,g=h-(h-s),v=s-g,h=134217729*u,d=h-(h-u),p=u-d,j=v*p-(w-g*d-v*d-g*p),y=x-j,f=x-y,Vr[0]=x-(y+f)+(f-j),_=b+y,f=_-b,m=b-(_-f)+(y-f),y=m-w,f=m-y,Vr[1]=m-(y+f)+(f-w),A=_+y,f=A-_,Vr[2]=_-(A-f)+(y-f),Vr[3]=A;const $=Hr(z,Yr,4,Vr,Zr);return Zr[$-1]}(t,e,n,r,i,o,u)}const qr=Math.pow(2,-52),Gr=new Uint32Array(512);class Qr{static from(t,e=oi,n=li){const r=t.length,i=new Float64Array(2*r);for(let o=0;o<r;o++){const r=t[o];i[2*o]=e(r),i[2*o+1]=n(r)}return new Qr(i)}constructor(t){const e=t.length>>1;if(e>0&&"number"!=typeof t[0])throw new Error("Expected coords to contain numbers.");this.coords=t;const n=Math.max(2*e-5,0);this._triangles=new Uint32Array(3*n),this._halfedges=new Int32Array(3*n),this._hashSize=Math.ceil(Math.sqrt(e)),this._hullPrev=new Uint32Array(e),this._hullNext=new Uint32Array(e),this._hullTri=new Uint32Array(e),this._hullHash=new Int32Array(this._hashSize).fill(-1),this._ids=new Uint32Array(e),this._dists=new Float64Array(e),this.update()}update(){const{coords:t,_hullPrev:e,_hullNext:n,_hullTri:r,_hullHash:i}=this,o=t.length>>1;let l=1/0,a=1/0,s=-1/0,u=-1/0;for(let e=0;e<o;e++){const n=t[2*e],r=t[2*e+1];n<l&&(l=n),r<a&&(a=r),n>s&&(s=n),r>u&&(u=r),this._ids[e]=e}const c=(l+s)/2,f=(a+u)/2;let h,g,v,d=1/0;for(let e=0;e<o;e++){const n=ti(c,f,t[2*e],t[2*e+1]);n<d&&(h=e,d=n)}const p=t[2*h],y=t[2*h+1];d=1/0;for(let e=0;e<o;e++){if(e===h)continue;const n=ti(p,y,t[2*e],t[2*e+1]);n<d&&n>0&&(g=e,d=n)}let _=t[2*g],m=t[2*g+1],b=1/0;for(let e=0;e<o;e++){if(e===h||e===g)continue;const n=ni(p,y,_,m,t[2*e],t[2*e+1]);n<b&&(v=e,b=n)}let x=t[2*v],w=t[2*v+1];if(b===1/0){for(let e=0;e<o;e++)this._dists[e]=t[2*e]-t[0]||t[2*e+1]-t[1];ri(this._ids,this._dists,0,o-1);const e=new Uint32Array(o);let n=0;for(let t=0,r=-1/0;t<o;t++){const i=this._ids[t];this._dists[i]>r&&(e[n++]=i,r=this._dists[i])}return this.hull=e.subarray(0,n),this.triangles=new Uint32Array(0),void(this.halfedges=new Uint32Array(0))}if(Wr(p,y,_,m,x,w)<0){const t=g,e=_,n=m;g=v,_=x,m=w,v=t,x=e,w=n}const j=function(t,e,n,r,i,o){const l=n-t,a=r-e,s=i-t,u=o-e,c=l*l+a*a,f=s*s+u*u,h=.5/(l*u-a*s);return{x:t+(u*c-a*f)*h,y:e+(l*f-s*c)*h}}(p,y,_,m,x,w);this._cx=j.x,this._cy=j.y;for(let e=0;e<o;e++)this._dists[e]=ti(t[2*e],t[2*e+1],j.x,j.y);ri(this._ids,this._dists,0,o-1),this._hullStart=h;let A=3;n[h]=e[v]=g,n[g]=e[h]=v,n[v]=e[g]=h,r[h]=0,r[g]=1,r[v]=2,i.fill(-1),i[this._hashKey(p,y)]=h,i[this._hashKey(_,m)]=g,i[this._hashKey(x,w)]=v,this.trianglesLen=0,this._addTriangle(h,g,v,-1,-1,-1);for(let o,l,a=0;a<this._ids.length;a++){const s=this._ids[a],u=t[2*s],c=t[2*s+1];if(a>0&&Math.abs(u-o)<=qr&&Math.abs(c-l)<=qr)continue;if(o=u,l=c,s===h||s===g||s===v)continue;let f=0;for(let t=0,e=this._hashKey(u,c);t<this._hashSize&&(f=i[(e+t)%this._hashSize],-1===f||f===n[f]);t++);f=e[f];let d,p=f;for(;d=n[p],Wr(u,c,t[2*p],t[2*p+1],t[2*d],t[2*d+1])>=0;)if(p=d,p===f){p=-1;break}if(-1===p)continue;let y=this._addTriangle(p,s,n[p],-1,-1,r[p]);r[s]=this._legalize(y+2),r[p]=y,A++;let _=n[p];for(;d=n[_],Wr(u,c,t[2*_],t[2*_+1],t[2*d],t[2*d+1])<0;)y=this._addTriangle(_,s,d,r[s],-1,r[_]),r[s]=this._legalize(y+2),n[_]=_,A--,_=d;if(p===f)for(;d=e[p],Wr(u,c,t[2*d],t[2*d+1],t[2*p],t[2*p+1])<0;)y=this._addTriangle(d,s,p,-1,r[p],r[d]),this._legalize(y+2),r[d]=y,n[p]=p,A--,p=d;this._hullStart=e[s]=p,n[p]=e[_]=s,n[s]=_,i[this._hashKey(u,c)]=s,i[this._hashKey(t[2*p],t[2*p+1])]=p}this.hull=new Uint32Array(A);for(let t=0,e=this._hullStart;t<A;t++)this.hull[t]=e,e=n[e];this.triangles=this._triangles.subarray(0,this.trianglesLen),this.halfedges=this._halfedges.subarray(0,this.trianglesLen)}_hashKey(t,e){return Math.floor(function(t,e){const n=t/(Math.abs(t)+Math.abs(e));return(e>0?3-n:1+n)/4}(t-this._cx,e-this._cy)*this._hashSize)%this._hashSize}_legalize(t){const{_triangles:e,_halfedges:n,coords:r}=this;let i=0,o=0;for(;;){const l=n[t],a=t-t%3;if(o=a+(t+2)%3,-1===l){if(0===i)break;t=Gr[--i];continue}const s=l-l%3,u=a+(t+1)%3,c=s+(l+2)%3,f=e[o],h=e[t],g=e[u],v=e[c];if(ei(r[2*f],r[2*f+1],r[2*h],r[2*h+1],r[2*g],r[2*g+1],r[2*v],r[2*v+1])){e[t]=v,e[l]=f;const r=n[c];if(-1===r){let e=this._hullStart;do{if(this._hullTri[e]===c){this._hullTri[e]=t;break}e=this._hullPrev[e]}while(e!==this._hullStart)}this._link(t,r),this._link(l,n[o]),this._link(o,c);const a=s+(l+1)%3;i<Gr.length&&(Gr[i++]=a)}else{if(0===i)break;t=Gr[--i]}}return o}_link(t,e){this._halfedges[t]=e,-1!==e&&(this._halfedges[e]=t)}_addTriangle(t,e,n,r,i,o){const l=this.trianglesLen;return this._triangles[l]=t,this._triangles[l+1]=e,this._triangles[l+2]=n,this._link(l,r),this._link(l+1,i),this._link(l+2,o),this.trianglesLen+=3,l}}function ti(t,e,n,r){const i=t-n,o=e-r;return i*i+o*o}function ei(t,e,n,r,i,o,l,a){const s=t-l,u=e-a,c=n-l,f=r-a,h=i-l,g=o-a,v=c*c+f*f,d=h*h+g*g;return s*(f*d-v*g)-u*(c*d-v*h)+(s*s+u*u)*(c*g-f*h)<0}function ni(t,e,n,r,i,o){const l=n-t,a=r-e,s=i-t,u=o-e,c=l*l+a*a,f=s*s+u*u,h=.5/(l*u-a*s),g=(u*c-a*f)*h,v=(l*f-s*c)*h;return g*g+v*v}function ri(t,e,n,r){if(r-n<=20)for(let i=n+1;i<=r;i++){const r=t[i],o=e[r];let l=i-1;for(;l>=n&&e[t[l]]>o;)t[l+1]=t[l--];t[l+1]=r}else{let i=n+1,o=r;ii(t,n+r>>1,i),e[t[n]]>e[t[r]]&&ii(t,n,r),e[t[i]]>e[t[r]]&&ii(t,i,r),e[t[n]]>e[t[i]]&&ii(t,n,i);const l=t[i],a=e[l];for(;;){do{i++}while(e[t[i]]<a);do{o--}while(e[t[o]]>a);if(o<i)break;ii(t,i,o)}t[n+1]=t[o],t[o]=l,r-i+1>=o-n?(ri(t,e,i,r),ri(t,e,n,o-1)):(ri(t,e,n,o-1),ri(t,e,i,r))}}function ii(t,e,n){const r=t[e];t[e]=t[n],t[n]=r}function oi(t){return t[0]}function li(t){return t[1]}class ai{constructor(){this._x0=this._y0=this._x1=this._y1=null,this._=""}moveTo(t,e){this._+=`M${this._x0=this._x1=+t},${this._y0=this._y1=+e}`}closePath(){null!==this._x1&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")}lineTo(t,e){this._+=`L${this._x1=+t},${this._y1=+e}`}arc(t,e,n){const r=(t=+t)+(n=+n),i=e=+e;if(n<0)throw new Error("negative radius");null===this._x1?this._+=`M${r},${i}`:(Math.abs(this._x1-r)>1e-6||Math.abs(this._y1-i)>1e-6)&&(this._+="L"+r+","+i),n&&(this._+=`A${n},${n},0,1,1,${t-n},${e}A${n},${n},0,1,1,${this._x1=r},${this._y1=i}`)}rect(t,e,n,r){this._+=`M${this._x0=this._x1=+t},${this._y0=this._y1=+e}h${+n}v${+r}h${-n}Z`}value(){return this._||null}}class si{constructor(){this._=[]}moveTo(t,e){this._.push([t,e])}closePath(){this._.push(this._[0].slice())}lineTo(t,e){this._.push([t,e])}value(){return this._.length?this._:null}}class ui{constructor(t,[e,n,r,i]=[0,0,960,500]){if(!((r=+r)>=(e=+e)&&(i=+i)>=(n=+n)))throw new Error("invalid bounds");this.delaunay=t,this._circumcenters=new Float64Array(2*t.points.length),this.vectors=new Float64Array(2*t.points.length),this.xmax=r,this.xmin=e,this.ymax=i,this.ymin=n,this._init()}update(){return this.delaunay.update(),this._init(),this}_init(){const{delaunay:{points:t,hull:e,triangles:n},vectors:r}=this,i=this.circumcenters=this._circumcenters.subarray(0,n.length/3*2);for(let e,r,o=0,l=0,a=n.length;o<a;o+=3,l+=2){const a=2*n[o],s=2*n[o+1],u=2*n[o+2],c=t[a],f=t[a+1],h=t[s],g=t[s+1],v=t[u],d=t[u+1],p=h-c,y=g-f,_=v-c,m=d-f,b=2*(p*m-y*_);if(Math.abs(b)<1e-9){let i=1e9;const o=2*n[0];i*=Math.sign((t[o]-c)*m-(t[o+1]-f)*_),e=(c+v)/2-i*m,r=(f+d)/2+i*_}else{const t=1/b,n=p*p+y*y,i=_*_+m*m;e=c+(m*n-y*i)*t,r=f+(p*i-_*n)*t}i[l]=e,i[l+1]=r}let o,l,a,s=e[e.length-1],u=4*s,c=t[2*s],f=t[2*s+1];r.fill(0);for(let n=0;n<e.length;++n)s=e[n],o=u,l=c,a=f,u=4*s,c=t[2*s],f=t[2*s+1],r[o+2]=r[u]=a-f,r[o+3]=r[u+1]=c-l}render(t){const e=null==t?t=new ai:void 0,{delaunay:{halfedges:n,inedges:r,hull:i},circumcenters:o,vectors:l}=this;if(i.length<=1)return null;for(let e=0,r=n.length;e<r;++e){const r=n[e];if(r<e)continue;const i=2*Math.floor(e/3),l=2*Math.floor(r/3),a=o[i],s=o[i+1],u=o[l],c=o[l+1];this._renderSegment(a,s,u,c,t)}let a,s=i[i.length-1];for(let e=0;e<i.length;++e){a=s,s=i[e];const n=2*Math.floor(r[s]/3),u=o[n],c=o[n+1],f=4*a,h=this._project(u,c,l[f+2],l[f+3]);h&&this._renderSegment(u,c,h[0],h[1],t)}return e&&e.value()}renderBounds(t){const e=null==t?t=new ai:void 0;return t.rect(this.xmin,this.ymin,this.xmax-this.xmin,this.ymax-this.ymin),e&&e.value()}renderCell(t,e){const n=null==e?e=new ai:void 0,r=this._clip(t);if(null===r||!r.length)return;e.moveTo(r[0],r[1]);let i=r.length;for(;r[0]===r[i-2]&&r[1]===r[i-1]&&i>1;)i-=2;for(let t=2;t<i;t+=2)r[t]===r[t-2]&&r[t+1]===r[t-1]||e.lineTo(r[t],r[t+1]);return e.closePath(),n&&n.value()}*cellPolygons(){const{delaunay:{points:t}}=this;for(let e=0,n=t.length/2;e<n;++e){const t=this.cellPolygon(e);t&&(t.index=e,yield t)}}cellPolygon(t){const e=new si;return this.renderCell(t,e),e.value()}_renderSegment(t,e,n,r,i){let o;const l=this._regioncode(t,e),a=this._regioncode(n,r);0===l&&0===a?(i.moveTo(t,e),i.lineTo(n,r)):(o=this._clipSegment(t,e,n,r,l,a))&&(i.moveTo(o[0],o[1]),i.lineTo(o[2],o[3]))}contains(t,e,n){return(e=+e)==e&&(n=+n)==n&&this.delaunay._step(t,e,n)===t}*neighbors(t){const e=this._clip(t);if(e)for(const n of this.delaunay.neighbors(t)){const t=this._clip(n);if(t)t:for(let r=0,i=e.length;r<i;r+=2)for(let o=0,l=t.length;o<l;o+=2)if(e[r]==t[o]&&e[r+1]==t[o+1]&&e[(r+2)%i]==t[(o+l-2)%l]&&e[(r+3)%i]==t[(o+l-1)%l]){yield n;break t}}}_cell(t){const{circumcenters:e,delaunay:{inedges:n,halfedges:r,triangles:i}}=this,o=n[t];if(-1===o)return null;const l=[];let a=o;do{const n=Math.floor(a/3);if(l.push(e[2*n],e[2*n+1]),a=a%3==2?a-2:a+1,i[a]!==t)break;a=r[a]}while(a!==o&&-1!==a);return l}_clip(t){if(0===t&&1===this.delaunay.hull.length)return[this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax,this.xmin,this.ymin];const e=this._cell(t);if(null===e)return null;const{vectors:n}=this,r=4*t;return n[r]||n[r+1]?this._clipInfinite(t,e,n[r],n[r+1],n[r+2],n[r+3]):this._clipFinite(t,e)}_clipFinite(t,e){const n=e.length;let r,i,o,l,a=null,s=e[n-2],u=e[n-1],c=this._regioncode(s,u),f=0;for(let h=0;h<n;h+=2)if(r=s,i=u,s=e[h],u=e[h+1],o=c,c=this._regioncode(s,u),0===o&&0===c)l=f,f=0,a?a.push(s,u):a=[s,u];else{let e,n,h,g,v;if(0===o){if(null===(e=this._clipSegment(r,i,s,u,o,c)))continue;[n,h,g,v]=e}else{if(null===(e=this._clipSegment(s,u,r,i,c,o)))continue;[g,v,n,h]=e,l=f,f=this._edgecode(n,h),l&&f&&this._edge(t,l,f,a,a.length),a?a.push(n,h):a=[n,h]}l=f,f=this._edgecode(g,v),l&&f&&this._edge(t,l,f,a,a.length),a?a.push(g,v):a=[g,v]}if(a)l=f,f=this._edgecode(a[0],a[1]),l&&f&&this._edge(t,l,f,a,a.length);else if(this.contains(t,(this.xmin+this.xmax)/2,(this.ymin+this.ymax)/2))return[this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax,this.xmin,this.ymin];return a}_clipSegment(t,e,n,r,i,o){for(;;){if(0===i&&0===o)return[t,e,n,r];if(i&o)return null;let l,a,s=i||o;8&s?(l=t+(n-t)*(this.ymax-e)/(r-e),a=this.ymax):4&s?(l=t+(n-t)*(this.ymin-e)/(r-e),a=this.ymin):2&s?(a=e+(r-e)*(this.xmax-t)/(n-t),l=this.xmax):(a=e+(r-e)*(this.xmin-t)/(n-t),l=this.xmin),i?(t=l,e=a,i=this._regioncode(t,e)):(n=l,r=a,o=this._regioncode(n,r))}}_clipInfinite(t,e,n,r,i,o){let l,a=Array.from(e);if((l=this._project(a[0],a[1],n,r))&&a.unshift(l[0],l[1]),(l=this._project(a[a.length-2],a[a.length-1],i,o))&&a.push(l[0],l[1]),a=this._clipFinite(t,a))for(let e,n=0,r=a.length,i=this._edgecode(a[r-2],a[r-1]);n<r;n+=2)e=i,i=this._edgecode(a[n],a[n+1]),e&&i&&(n=this._edge(t,e,i,a,n),r=a.length);else this.contains(t,(this.xmin+this.xmax)/2,(this.ymin+this.ymax)/2)&&(a=[this.xmin,this.ymin,this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax]);return a}_edge(t,e,n,r,i){for(;e!==n;){let n,o;switch(e){case 5:e=4;continue;case 4:e=6,n=this.xmax,o=this.ymin;break;case 6:e=2;continue;case 2:e=10,n=this.xmax,o=this.ymax;break;case 10:e=8;continue;case 8:e=9,n=this.xmin,o=this.ymax;break;case 9:e=1;continue;case 1:e=5,n=this.xmin,o=this.ymin}r[i]===n&&r[i+1]===o||!this.contains(t,n,o)||(r.splice(i,0,n,o),i+=2)}if(r.length>4)for(let t=0;t<r.length;t+=2){const e=(t+2)%r.length,n=(t+4)%r.length;(r[t]===r[e]&&r[e]===r[n]||r[t+1]===r[e+1]&&r[e+1]===r[n+1])&&(r.splice(e,2),t-=2)}return i}_project(t,e,n,r){let i,o,l,a=1/0;if(r<0){if(e<=this.ymin)return null;(i=(this.ymin-e)/r)<a&&(l=this.ymin,o=t+(a=i)*n)}else if(r>0){if(e>=this.ymax)return null;(i=(this.ymax-e)/r)<a&&(l=this.ymax,o=t+(a=i)*n)}if(n>0){if(t>=this.xmax)return null;(i=(this.xmax-t)/n)<a&&(o=this.xmax,l=e+(a=i)*r)}else if(n<0){if(t<=this.xmin)return null;(i=(this.xmin-t)/n)<a&&(o=this.xmin,l=e+(a=i)*r)}return[o,l]}_edgecode(t,e){return(t===this.xmin?1:t===this.xmax?2:0)|(e===this.ymin?4:e===this.ymax?8:0)}_regioncode(t,e){return(t<this.xmin?1:t>this.xmax?2:0)|(e<this.ymin?4:e>this.ymax?8:0)}}const ci=2*Math.PI,fi=Math.pow;function hi(t){return t[0]}function gi(t){return t[1]}function vi(t,e,n){return[t+Math.sin(t+e)*n,e+Math.cos(t-e)*n]}class di{static from(t,e=hi,n=gi,r){return new di("length"in t?function(t,e,n,r){const i=t.length,o=new Float64Array(2*i);for(let l=0;l<i;++l){const i=t[l];o[2*l]=e.call(r,i,l,t),o[2*l+1]=n.call(r,i,l,t)}return o}(t,e,n,r):Float64Array.from(function*(t,e,n,r){let i=0;for(const o of t)yield e.call(r,o,i,t),yield n.call(r,o,i,t),++i}(t,e,n,r)))}constructor(t){this._delaunator=new Qr(t),this.inedges=new Int32Array(t.length/2),this._hullIndex=new Int32Array(t.length/2),this.points=this._delaunator.coords,this._init()}update(){return this._delaunator.update(),this._init(),this}_init(){const t=this._delaunator,e=this.points;if(t.hull&&t.hull.length>2&&function(t){const{triangles:e,coords:n}=t;for(let t=0;t<e.length;t+=3){const r=2*e[t],i=2*e[t+1],o=2*e[t+2];if((n[o]-n[r])*(n[i+1]-n[r+1])-(n[i]-n[r])*(n[o+1]-n[r+1])>1e-10)return!1}return!0}(t)){this.collinear=Int32Array.from({length:e.length/2},((t,e)=>e)).sort(((t,n)=>e[2*t]-e[2*n]||e[2*t+1]-e[2*n+1]));const t=this.collinear[0],n=this.collinear[this.collinear.length-1],r=[e[2*t],e[2*t+1],e[2*n],e[2*n+1]],i=1e-8*Math.hypot(r[3]-r[1],r[2]-r[0]);for(let t=0,n=e.length/2;t<n;++t){const n=vi(e[2*t],e[2*t+1],i);e[2*t]=n[0],e[2*t+1]=n[1]}this._delaunator=new Qr(e)}else delete this.collinear;const n=this.halfedges=this._delaunator.halfedges,r=this.hull=this._delaunator.hull,i=this.triangles=this._delaunator.triangles,o=this.inedges.fill(-1),l=this._hullIndex.fill(-1);for(let t=0,e=n.length;t<e;++t){const e=i[t%3==2?t-2:t+1];-1!==n[t]&&-1!==o[e]||(o[e]=t)}for(let t=0,e=r.length;t<e;++t)l[r[t]]=t;r.length<=2&&r.length>0&&(this.triangles=new Int32Array(3).fill(-1),this.halfedges=new Int32Array(3).fill(-1),this.triangles[0]=r[0],o[r[0]]=1,2===r.length&&(o[r[1]]=0,this.triangles[1]=r[1],this.triangles[2]=r[1]))}voronoi(t){return new ui(this,t)}*neighbors(t){const{inedges:e,hull:n,_hullIndex:r,halfedges:i,triangles:o,collinear:l}=this;if(l){const e=l.indexOf(t);return e>0&&(yield l[e-1]),void(e<l.length-1&&(yield l[e+1]))}const a=e[t];if(-1===a)return;let s=a,u=-1;do{if(yield u=o[s],s=s%3==2?s-2:s+1,o[s]!==t)return;if(s=i[s],-1===s){const e=n[(r[t]+1)%n.length];return void(e!==u&&(yield e))}}while(s!==a)}find(t,e,n=0){if((t=+t)!=t||(e=+e)!=e)return-1;const r=n;let i;for(;(i=this._step(n,t,e))>=0&&i!==n&&i!==r;)n=i;return i}_step(t,e,n){const{inedges:r,hull:i,_hullIndex:o,halfedges:l,triangles:a,points:s}=this;if(-1===r[t]||!s.length)return(t+1)%(s.length>>1);let u=t,c=fi(e-s[2*t],2)+fi(n-s[2*t+1],2);const f=r[t];let h=f;do{let r=a[h];const f=fi(e-s[2*r],2)+fi(n-s[2*r+1],2);if(f<c&&(c=f,u=r),h=h%3==2?h-2:h+1,a[h]!==t)break;if(h=l[h],-1===h){if(h=i[(o[t]+1)%i.length],h!==r&&fi(e-s[2*h],2)+fi(n-s[2*h+1],2)<c)return h;break}}while(h!==f);return u}render(t){const e=null==t?t=new ai:void 0,{points:n,halfedges:r,triangles:i}=this;for(let e=0,o=r.length;e<o;++e){const o=r[e];if(o<e)continue;const l=2*i[e],a=2*i[o];t.moveTo(n[l],n[l+1]),t.lineTo(n[a],n[a+1])}return this.renderHull(t),e&&e.value()}renderPoints(t,e){void 0!==e||t&&"function"==typeof t.moveTo||(e=t,t=null),e=null==e?2:+e;const n=null==t?t=new ai:void 0,{points:r}=this;for(let n=0,i=r.length;n<i;n+=2){const i=r[n],o=r[n+1];t.moveTo(i+e,o),t.arc(i,o,e,0,ci)}return n&&n.value()}renderHull(t){const e=null==t?t=new ai:void 0,{hull:n,points:r}=this,i=2*n[0],o=n.length;t.moveTo(r[i],r[i+1]);for(let e=1;e<o;++e){const i=2*n[e];t.lineTo(r[i],r[i+1])}return t.closePath(),e&&e.value()}hullPolygon(){const t=new si;return this.renderHull(t),t.value()}renderTriangle(t,e){const n=null==e?e=new ai:void 0,{points:r,triangles:i}=this,o=2*i[t*=3],l=2*i[t+1],a=2*i[t+2];return e.moveTo(r[o],r[o+1]),e.lineTo(r[l],r[l+1]),e.lineTo(r[a],r[a+1]),e.closePath(),n&&n.value()}*trianglePolygons(){const{triangles:t}=this;for(let e=0,n=t.length/3;e<n;++e)yield this.trianglePolygon(e)}trianglePolygon(t){const e=new si;return this.renderTriangle(t,e),e.value()}}function pi(t,e,n={}){if(!Ln(t))return{err:"psSrc is not an array"};if(!Cn(e)&&!Ln(e))return{err:"psTar is not an object or array"};let r=Cn(e);r&&(e=[e]);let i=Mt(n,"keyX");Tt(i)||(i="x");let o=Mt(n,"keyY");Tt(o)||(o="y");let l=Mt(n,"keyZ");Tt(l)||(l="z");let a=Mt(n,"scale");if(Dn(a)||(a=1),a=Qn(a),t=nr(t,n),0===En(t))return{err:"psSrc has no effective data"};if(e=er(e,n),0===En(e))return{err:"psTar has no effective data"};let s=xr(t,{scale:a});t=s.ps;let u=s.nv,c=s.inv,f=[...t],h=[...t],g={};ue(t,(t=>{let e=`${t.x}-${t.y}`;g[e]=t.z}));let v,d=di.from(h,(t=>t.x),(t=>t.y)),p=[0,0,a,a],y=d.voronoi(p),_=(e,n,r)=>{let i=[...t],o={x:n,y:r,z:0};i.push(o),e.push(o);let l=di.from(i,(t=>t.x),(t=>t.y)).voronoi(p),a=i.length-1,s=l.cellPolygon(a),u=Mr(s),c=null;if(u>0){let t=[],n=l.delaunay.neighbors(a),r=n.next();for(;!r.done;){let e=r.value;t.push(e),r=n.next()}let i=pn(t,(t=>{let e=[s],n=[y.cellPolygon(t)],r=[];try{r=function(t,e){if(!Ln(t))return null;if(!Ln(e))return null;t=Sr(t),e=Sr(e);let n=Dr.intersect({regions:t},{regions:e});return Mt(n,"regions",[])}(e,n)}catch(t){console.log("pgs1",e),console.log("pgs2",n),console.log(t)}let i=0;if(1===En(r))try{i=Mr(r[0])}catch(t){console.log("ints",r),console.log(t)}return{ia:i,idx:t}}));c=pn(i,(t=>t.ia/u*e[t.idx].z)),c=_n(c)}return e[e.length-1].z=c,c},m=(t,e)=>{let n=`${t}-${e}`;if(tr(g,n))return g[n];if(t<p[0]||t>p[2]||e<p[1]||e>p[3])return null;let r=((t,e,n)=>{let r;try{r=_(t,e,n)}catch(e){console.log(e),r=null,t.pop()}return r})(f,t,e);return g[n]=r,r},b=t=>{let e=t.x,n=u(e,0);if(!Nn(n))throw new Error(`invalid nx[${n}]`);let r=t.y,a=u(r,1);if(!Nn(a))throw new Error(`invalid ny[${a}]`);let s=m(n,a),f=c(s,2);return Nn(f)||(f=null),{[i]:e,[o]:r,[l]:f}};if(r){let t=e[0];v=b(t)}else v=[],ue(e,(t=>{v.push(b(t))}));return v}let yi={},_i=function(t,e){let n=[];for(let r=0;r<e;r++)n.push(t);return n},mi=function(t,e){let n=_i(0,e*e);for(let r=0;r<e;r++)n[r*e+r]=t;return n},bi=function(t,e,n,r){let i,o,l=Array(n*r);for(i=0;i<n;i++)for(o=0;o<r;o++)l[i*r+o]=t[i*r+o]+e[i*r+o];return l},xi=function(t,e,n,r,i){let o,l,a,s=Array(n*i);for(o=0;o<n;o++)for(l=0;l<i;l++)for(s[o*i+l]=0,a=0;a<r;a++)s[o*i+l]+=t[o*r+a]*e[a*i+l];return s},wi=function(t,e){let n,r,i,o=Array(e);for(n=0;n<e;n++)o[n]=t[n*e+n];for(n=0;n<e;n++){for(r=0;r<n;r++)o[n]-=t[n*e+r]*t[n*e+r];if(o[n]<=0)return!1;for(o[n]=Math.sqrt(o[n]),r=n+1;r<e;r++){for(i=0;i<n;i++)t[r*e+n]-=t[r*e+i]*t[n*e+i];t[r*e+n]/=o[n]}}for(n=0;n<e;n++)t[n*e+n]=o[n];return!0},ji=function(t,e){let n,r,i,o;for(n=0;n<e;n++)for(t[n*e+n]=1/t[n*e+n],r=n+1;r<e;r++){for(o=0,i=n;i<r;i++)o-=t[r*e+i]*t[i*e+n];t[r*e+n]=o/t[r*e+r]}for(n=0;n<e;n++)for(r=n+1;r<e;r++)t[n*e+r]=0;for(n=0;n<e;n++){for(t[n*e+n]*=t[n*e+n],i=n+1;i<e;i++)t[n*e+n]+=t[i*e+n]*t[i*e+n];for(r=n+1;r<e;r++)for(i=r;i<e;i++)t[n*e+r]+=t[i*e+n]*t[i*e+r]}for(n=0;n<e;n++)for(r=0;r<n;r++)t[n*e+r]=t[r*e+n]},Ai=function(t,e){let n,r,i,o,l,a,s,u,c,f,h,g=e,v=Array(e*e),d=Array(e),p=Array(e),y=Array(e);for(n=0;n<e;n++)for(o=0;o<e;o++)v[n*e+o]=n===o?1:0;for(o=0;o<e;o++)y[o]=0;for(n=0;n<e;n++){for(u=0,o=0;o<e;o++)if(1!==y[o])for(l=0;l<e;l++)0===y[l]&&Math.abs(t[o*e+l])>=u&&(u=Math.abs(t[o*e+l]),i=o,r=l);if(++y[r],i!==r){for(a=0;a<e;a++)h=t[i*e+a],t[i*e+a]=t[r*e+a],t[r*e+a]=h;for(a=0;a<g;a++)h=v[i*e+a],v[i*e+a]=v[r*e+a],v[r*e+a]=h}if(p[n]=i,d[n]=r,0===t[r*e+r])return!1;for(f=1/t[r*e+r],t[r*e+r]=1,a=0;a<e;a++)t[r*e+a]*=f;for(a=0;a<g;a++)v[r*e+a]*=f;for(s=0;s<e;s++)if(s!==r){for(c=t[s*e+r],t[s*e+r]=0,a=0;a<e;a++)t[s*e+a]-=t[r*e+a]*c;for(a=0;a<g;a++)v[s*e+a]-=v[r*e+a]*c}}for(a=e-1;a>=0;a--)if(p[a]!==d[a])for(l=0;l<e;l++)h=t[l*e+p[a]],t[l*e+p[a]]=t[l*e+d[a]],t[l*e+d[a]]=h;return!0},Oi=function(t,e,n,r,i){return e+(r-e)/n*(1-Math.exp(-1/i*Math.pow(t/n,2)))},Si=function(t,e,n,r,i){return e+(r-e)/n*(1-Math.exp(-1/i*(t/n)))},Mi=function(t,e,n,r,i){return t>n?e+(r-e)/n:e+(r-e)/n*(t/n*1.5-.5*Math.pow(t/n,3))};function Pi(t,e,n={}){if(!Ln(t))return{err:"psSrc is not an array"};if(!Cn(e)&&!Ln(e))return{err:"psTar is not an object or array"};let r=Cn(e);r&&(e=[e]);let i=Mt(n,"keyX");Tt(i)||(i="x");let o=Mt(n,"keyY");Tt(o)||(o="y");let l=Mt(n,"keyZ");Tt(l)||(l="z");let a=Mt(n,"scale");Dn(a)||(a=1),a=Qn(a);let s=Mt(n,"model");"exponential"!==s&&"gaussian"!==s&&"spherical"!==s&&(s="exponential");let u=Mt(n,"sigma2");Dn(u)||(u=0),u=Qn(u);let c=Mt(n,"alpha");Dn(c)||(c=100),c=Qn(c);let f=Mt(n,"returnWithVariogram");if(kt(f)||(f=!1),t=nr(t,n),0===En(t))return{err:"psSrc has no effective data"};if(e=er(e,n),0===En(e))return{err:"psTar has no effective data"};let h=xr(t,{scale:a});t=h.ps;let g=h.nv,v=h.inv,d={};ue(t,(t=>{let e=`${t.x}-${t.y}`;d[e]=t.z}));let p=[],y=[],_=[];ue(t,(t=>{p.push(t.x),y.push(t.y),_.push(t.z)}));let m,b=yi.train(_,p,y,s,u,c),x=t=>{let e=t.x,n=g(e,0);if(!Nn(n))throw new Error(`invalid nx[${n}]`);let r=t.y,a=g(r,1);if(!Nn(a))throw new Error(`invalid ny[${a}]`);let s=((t,e)=>{let n=`${t}-${e}`;if(tr(d,n))return d[n];let r=yi.predict(t,e,b);return d[n]=r,r})(n,a),u=v(s,2);return Nn(u)||(u=null),{[i]:e,[o]:r,[l]:u}};if(r){let t=e[0];m=x(t)}else m=[],ue(e,(t=>{m.push(x(t))}));return f&&(m={result:m,variogram:b}),m}function interp2(t,e,n={}){let r=Mt(n,"method");"naturalNeighbor"!==r&&"kriging"!==r&&(r="naturalNeighbor");let i=Mt(n,"useSync");kt(i)||(i=!1);let o=()=>{let i=null;try{"naturalNeighbor"===r?i=pi(t,e,n):"kriging"===r&&(i=Pi(t,e,n))}catch(t){i={err:t.toString()}}return i};return i?o():(async()=>{let t=null;try{t=o();let e=Mt(t,"err");return Tt(e)?Promise.reject(e):t}catch(t){return console.log(t),Promise.reject(t.toString())}})()}yi.train=function(t,e,n,r,i,o){let l,a,s,u,c={t:t,x:e,y:n,nugget:0,range:0,sill:0,A:1/3,n:0};switch(r){case"gaussian":c.model=Oi;break;case"exponential":c.model=Si;break;case"spherical":c.model=Mi}let f=t.length,h=Array((f*f-f)/2);for(l=0,s=0;l<f;l++)for(a=0;a<l;a++,s++)h[s]=Array(2),h[s][0]=Math.pow(Math.pow(e[l]-e[a],2)+Math.pow(n[l]-n[a],2),.5),h[s][1]=Math.abs(t[l]-t[a]);h.sort((function(t,e){return t[0]-e[0]})),c.range=h[(f*f-f)/2-1][0];let g=(f*f-f)/2>30?30:(f*f-f)/2,v=c.range/g,d=_i(0,g),p=_i(0,g);if(g<30)for(u=0;u<g;u++)d[u]=h[u][0],p[u]=h[u][1];else{for(l=0,a=0,s=0,u=0;l<g&&a<(f*f-f)/2;l++,s=0){for(;h[a][0]<=(l+1)*v&&(d[u]+=h[a][0],p[u]+=h[a][1],a++,s++,!(a>=(f*f-f)/2)););s>0&&(d[u]/=s,p[u]/=s,u++)}if(u<2)return c}let y=[];for(l=0;l<u;l++){let t=d[l],e=p[l];y.push([t,e])}let _={data:h,bars:y};c.svpd=_,f=u,c.range=d[f-1]-d[0];let m=_i(1,2*f),b=Array(f),x=c.A;for(l=0;l<f;l++){switch(r){case"gaussian":m[2*l+1]=1-Math.exp(-1/x*Math.pow(d[l]/c.range,2));break;case"exponential":m[2*l+1]=1-Math.exp(-1/x*d[l]/c.range);break;case"spherical":m[2*l+1]=d[l]/c.range*1.5-.5*Math.pow(d[l]/c.range,3)}b[l]=p[l]}let w=function(t,e,n){let r,i,o=Array(n*e);for(r=0;r<e;r++)for(i=0;i<n;i++)o[i*e+r]=t[r*n+i];return o}(m,f,2),j=xi(w,m,2,f,2);j=bi(j,mi(1/o,2),2,2);let A=j.slice(0);wi(j,2)?ji(j,2):(Ai(A,2),j=A);let O=xi(xi(j,w,2,2,f),b,2,f,1);c.nugget=O[0],c.sill=O[1]*c.range+c.nugget,c.n=e.length,f=e.length;let S=Array(f*f);for(l=0;l<f;l++){for(a=0;a<l;a++)S[l*f+a]=c.model(Math.pow(Math.pow(e[l]-e[a],2)+Math.pow(n[l]-n[a],2),.5),c.nugget,c.range,c.sill,c.A),S[a*f+l]=S[l*f+a];S[l*f+l]=c.model(0,c.nugget,c.range,c.sill,c.A)}let M=bi(S,mi(i,f),f,f),P=M.slice(0);wi(M,f)?ji(M,f):(Ai(P,f),M=P);let k=M.slice(0),F=xi(M,t,f,f,1);return c.K=k,c.M=F,c},yi.predict=function(t,e,n){let r,i=Array(n.n);for(r=0;r<n.n;r++)i[r]=n.model(Math.pow(Math.pow(t-n.x[r],2)+Math.pow(e-n.y[r],2),.5),n.nugget,n.range,n.sill,n.A);return xi(i,n.M,1,n.n,1)[0]},yi.variance=function(t,e,n){let r,i=Array(n.n);for(r=0;r<n.n;r++)i[r]=n.model(Math.pow(Math.pow(t-n.x[r],2)+Math.pow(e-n.y[r],2),.5),n.nugget,n.range,n.sill,n.A);return n.model(0,n.nugget,n.range,n.sill,n.A)+xi(xi(i,n.K,1,n.n,n.n),i,1,n.n,1)[0]};

let instance = null
function init(input){

    //init
    let r
    
        r = {
            main: interp2
        }
        

    //on
    

    //save
    instance = r

}

function sendMessage(data) {
    
        self.postMessage(data)
        
}

async function run(data) {
    // console.log('inner worker run',data)

    //mode
    let mode = data.mode

    //check
    if(mode !== 'init' && mode !== 'call'){
        return
    }

    //init
    if(mode === 'init'){
        
        try{

            //type
            let type = data.type

            //input
            let input = data.input
    
            //instance
            if(type === 'function'){
                init(...input)
            }
            else if(type === 'object'){
                instance = interp2
            }

        }
        catch(err){
        
            //sendMessage
            let res = {
                mode: 'emit',
                evName: 'error',
                msg: err,
            }
            sendMessage(res)

        }
            
    }

    //check
    if(mode === 'call'){
        let state = ''
        let msg = null

        try{

            //fun
            let fun = instance[data.fun]

            //input
            let input = data.input

            //exec
            await fun(...input)
                .then((suc) => {
                    state='success'
                    msg=suc
                })
                .catch((err) => {
                    state='error'
                    msg=err
                })

        }
        catch(err){
            state = 'error'
            msg = err
        }
        
        //sendMessage
        let res = {
            mode: 'return',
            id: data.id,
            fun: data.fun,
            state,
            msg,
        }
        sendMessage(res)

    }

}

function recvMessage(data) {
    // console.log('inner worker recv:', data)

    //dataRecv
    let dataRecv = data

    //run
    run(dataRecv)

}


        self.onmessage = function (e) {
            recvMessage(e.data)
        }
        

");function c(){var b=l();function d(l){try{var b=new Blob([l]),d=window.URL||window.webkitURL;return new Worker(d.createObjectURL(b))}catch(l){t(l)}}var c=d(X);if(!c)return t("invalid worker"),null;function G(){c?(c.terminate(),c=void 0):t("worker has been terminated")}function i(){var l={mode:"init",type:"function",input:Array.prototype.slice.call(arguments)};c.postMessage(l)}function W(){var l=Z(),d=m(),X={mode:"call",id:d,fun:"main",input:Array.prototype.slice.call(arguments)};return c.postMessage(X),b.once(d,(function(b){"success"===b.state?l.resolve(b.msg):l.reject(b.msg)})),l}function p(l){var d=l,Z=d.mode;"emit"!==Z&&"return"!==Z||("emit"===Z&&b.emit(d.evName,d.msg),"return"===Z&&b.emit(d.id,d))}function t(l){b.emit("error",l)}return c.onmessage=function(l){p(l.data)},c.onerror=t,i(Array.prototype.slice.call(arguments)),b.main=W,b.main=W,b.terminate=G,b}G=function(){var l,Z=(l=i.mark((function l(){var d,Z,m,X=arguments;return i.wrap((function(l){for(;;)switch(l.prev=l.next){case 0:return d=Array.prototype.slice.call(X),Z=c(),l.next=4,Z.main.apply(Z,b(d)).finally((function(){Z.terminate()}));case 4:return m=l.sent,l.abrupt("return",m);case 6:case"end":return l.stop()}}),l)})),function(){var b=this,Z=arguments;return new Promise((function(m,X){var c=l.apply(b,Z);function G(l){d(c,m,X,G,i,"next",l)}function i(l){d(c,m,X,G,i,"throw",l)}G(void 0)}))});return function(){return Z.apply(this,arguments)}}()}(),G}()}));return"undefined"!=typeof window&&void 0!==window.document?c:X}));