@uwdata/mosaic-spec 0.7.0 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/mosaic-schema.json +186153 -0
- package/dist/mosaic-spec.js +3387 -4641
- package/dist/mosaic-spec.min.js +23 -23
- package/dist/types/ast/ASTNode.d.ts +26 -0
- package/dist/types/ast/DataNode.d.ts +60 -0
- package/dist/types/ast/ExpressionNode.d.ts +15 -0
- package/dist/types/ast/HConcatNode.d.ts +10 -0
- package/dist/types/ast/HSpaceNode.d.ts +11 -0
- package/dist/types/ast/InputNode.d.ts +8 -0
- package/dist/types/ast/LiteralNode.d.ts +7 -0
- package/dist/types/ast/OptionsNode.d.ts +10 -0
- package/dist/types/ast/ParamNode.d.ts +9 -0
- package/dist/types/ast/ParamRefNode.d.ts +8 -0
- package/dist/types/ast/PlotAttributeNode.d.ts +18 -0
- package/dist/types/ast/PlotFromNode.d.ts +9 -0
- package/dist/types/ast/PlotInteractorNode.d.ts +8 -0
- package/dist/types/ast/PlotLegendNode.d.ts +10 -0
- package/dist/types/ast/PlotMarkNode.d.ts +10 -0
- package/dist/types/ast/PlotNode.d.ts +11 -0
- package/dist/types/ast/SelectionNode.d.ts +12 -0
- package/dist/types/ast/SpecNode.d.ts +10 -0
- package/dist/types/ast/TransformNode.d.ts +13 -0
- package/dist/types/ast/VConcatNode.d.ts +10 -0
- package/dist/types/ast/VSpaceNode.d.ts +11 -0
- package/dist/types/ast-to-dom.d.ts +38 -0
- package/dist/types/ast-to-esm.d.ts +64 -0
- package/dist/types/config/components.d.ts +4 -0
- package/dist/types/config/extensions.d.ts +9 -0
- package/dist/types/config/inputs.d.ts +5 -0
- package/dist/types/config/plots.d.ts +34 -0
- package/dist/types/config/transforms.d.ts +4 -0
- package/dist/types/constants.d.ts +30 -0
- package/dist/types/index.d.ts +29 -0
- package/dist/types/parse-spec.d.ts +86 -0
- package/dist/types/spec/CSSStyles.d.ts +3 -0
- package/dist/types/spec/Data.d.ts +165 -0
- package/dist/types/spec/Expression.d.ts +27 -0
- package/dist/types/spec/HConcat.d.ts +8 -0
- package/dist/types/spec/HSpace.d.ts +9 -0
- package/dist/types/spec/Input.d.ts +182 -0
- package/dist/types/spec/Param.d.ts +51 -0
- package/dist/types/spec/Plot.d.ts +14 -0
- package/dist/types/spec/PlotAttribute.d.ts +1522 -0
- package/dist/types/spec/PlotFrom.d.ts +20 -0
- package/dist/types/spec/PlotInteractor.d.ts +8 -0
- package/dist/types/spec/PlotLegend.d.ts +68 -0
- package/dist/types/spec/PlotMark.d.ts +26 -0
- package/dist/types/spec/PlotTypes.d.ts +293 -0
- package/dist/types/spec/Spec.d.ts +45 -0
- package/dist/types/spec/Transform.d.ts +278 -0
- package/dist/types/spec/VConcat.d.ts +8 -0
- package/dist/types/spec/VSpace.d.ts +9 -0
- package/dist/types/spec/interactors/Highlight.d.ts +37 -0
- package/dist/types/spec/interactors/Interval1D.d.ts +63 -0
- package/dist/types/spec/interactors/Interval2D.d.ts +46 -0
- package/dist/types/spec/interactors/Nearest.d.ts +25 -0
- package/dist/types/spec/interactors/PanZoom.d.ts +58 -0
- package/dist/types/spec/interactors/Toggle.d.ts +51 -0
- package/dist/types/spec/marks/Area.d.ts +139 -0
- package/dist/types/spec/marks/Arrow.d.ts +94 -0
- package/dist/types/spec/marks/Axis.d.ts +281 -0
- package/dist/types/spec/marks/Bar.d.ts +150 -0
- package/dist/types/spec/marks/Cell.d.ts +57 -0
- package/dist/types/spec/marks/Contour.d.ts +23 -0
- package/dist/types/spec/marks/Delaunay.d.ts +86 -0
- package/dist/types/spec/marks/DenseLine.d.ts +27 -0
- package/dist/types/spec/marks/Density.d.ts +121 -0
- package/dist/types/spec/marks/Dot.d.ts +129 -0
- package/dist/types/spec/marks/Frame.d.ts +21 -0
- package/dist/types/spec/marks/Geo.d.ts +53 -0
- package/dist/types/spec/marks/Hexbin.d.ts +30 -0
- package/dist/types/spec/marks/Hexgrid.d.ts +25 -0
- package/dist/types/spec/marks/Image.d.ts +89 -0
- package/dist/types/spec/marks/Line.d.ts +82 -0
- package/dist/types/spec/marks/Link.d.ts +60 -0
- package/dist/types/spec/marks/Marks.d.ts +890 -0
- package/dist/types/spec/marks/Raster.d.ts +124 -0
- package/dist/types/spec/marks/Rect.d.ts +166 -0
- package/dist/types/spec/marks/Regression.d.ts +58 -0
- package/dist/types/spec/marks/Rule.d.ts +100 -0
- package/dist/types/spec/marks/Text.d.ts +106 -0
- package/dist/types/spec/marks/Tick.d.ts +61 -0
- package/dist/types/spec/marks/Vector.d.ts +99 -0
- package/dist/types/util.d.ts +12 -0
- package/jsconfig.json +10 -0
- package/package.json +16 -9
- package/src/ast/ASTNode.js +23 -2
- package/src/ast/DataNode.js +79 -21
- package/src/ast/HSpaceNode.js +1 -1
- package/src/ast/InputNode.js +1 -2
- package/src/ast/ParamNode.js +1 -2
- package/src/ast/PlotAttributeNode.js +1 -2
- package/src/ast/PlotInteractorNode.js +1 -2
- package/src/ast/PlotLegendNode.js +1 -2
- package/src/ast/PlotMarkNode.js +3 -2
- package/src/ast/TransformNode.js +1 -2
- package/src/ast/VSpaceNode.js +1 -1
- package/src/ast-to-dom.js +16 -7
- package/src/ast-to-esm.js +41 -12
- package/src/config/inputs.js +1 -0
- package/src/config/plots.js +4 -0
- package/src/index.js +4 -0
- package/src/parse-spec.js +38 -5
- package/src/spec/CSSStyles.ts +9 -0
- package/src/spec/Data.ts +184 -0
- package/src/spec/Expression.ts +31 -0
- package/src/spec/HConcat.ts +9 -0
- package/src/spec/HSpace.ts +9 -0
- package/src/spec/Input.ts +182 -0
- package/src/spec/Param.ts +68 -0
- package/src/spec/Plot.ts +15 -0
- package/src/spec/PlotAttribute.ts +1783 -0
- package/src/spec/PlotFrom.ts +23 -0
- package/src/spec/PlotInteractor.ts +25 -0
- package/src/spec/PlotLegend.ts +70 -0
- package/src/spec/PlotMark.ts +51 -0
- package/src/spec/PlotTypes.ts +519 -0
- package/src/spec/Spec.ts +63 -0
- package/src/spec/Transform.ts +394 -0
- package/src/spec/VConcat.ts +9 -0
- package/src/spec/VSpace.ts +9 -0
- package/src/spec/interactors/Highlight.ts +38 -0
- package/src/spec/interactors/Interval1D.ts +67 -0
- package/src/spec/interactors/Interval2D.ts +48 -0
- package/src/spec/interactors/Nearest.ts +28 -0
- package/src/spec/interactors/PanZoom.ts +65 -0
- package/src/spec/interactors/Toggle.ts +56 -0
- package/src/spec/marks/Area.ts +154 -0
- package/src/spec/marks/Arrow.ts +108 -0
- package/src/spec/marks/Axis.ts +305 -0
- package/src/spec/marks/Bar.ts +160 -0
- package/src/spec/marks/Cell.ts +62 -0
- package/src/spec/marks/Contour.ts +25 -0
- package/src/spec/marks/Delaunay.ts +95 -0
- package/src/spec/marks/DenseLine.ts +30 -0
- package/src/spec/marks/Density.ts +145 -0
- package/src/spec/marks/Dot.ts +147 -0
- package/src/spec/marks/Frame.ts +23 -0
- package/src/spec/marks/Geo.ts +58 -0
- package/src/spec/marks/Hexbin.ts +34 -0
- package/src/spec/marks/Hexgrid.ts +27 -0
- package/src/spec/marks/Image.ts +101 -0
- package/src/spec/marks/Line.ts +93 -0
- package/src/spec/marks/Link.ts +70 -0
- package/src/spec/marks/Marks.ts +1062 -0
- package/src/spec/marks/Raster.ts +145 -0
- package/src/spec/marks/Rect.ts +183 -0
- package/src/spec/marks/Regression.ts +63 -0
- package/src/spec/marks/Rule.ts +113 -0
- package/src/spec/marks/Text.ts +122 -0
- package/src/spec/marks/Tick.ts +69 -0
- package/src/spec/marks/Vector.ts +113 -0
- package/src/util.js +8 -0
- package/tsconfig.json +11 -0
package/dist/mosaic-spec.min.js
CHANGED
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
var uz=Object.create;var I_=Object.defineProperty;var fz=Object.getOwnPropertyDescriptor;var dz=Object.getOwnPropertyNames;var hz=Object.getPrototypeOf,pz=Object.prototype.hasOwnProperty;var TD=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Ir=(e,t)=>{for(var n in t)I_(e,n,{get:t[n],enumerable:!0})},mz=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of dz(t))!pz.call(e,i)&&i!==n&&I_(e,i,{get:()=>t[i],enumerable:!(r=fz(t,i))||r.enumerable});return e};var yz=(e,t,n)=>(n=e!=null?uz(hz(e)):{},mz(t||!e||!e.__esModule?I_(n,"default",{value:e,enumerable:!0}):n,e));var aP=TD((U9t,sP)=>{"use strict";function Gtt(e,t,n,r,i){for(var o=i+1;r<=i;){var s=r+i>>>1,a=e[s],c=n!==void 0?n(a,t):a-t;c>=0?(o=s,i=s-1):r=s+1}return o}function Wtt(e,t,n,r,i){for(var o=i+1;r<=i;){var s=r+i>>>1,a=e[s],c=n!==void 0?n(a,t):a-t;c>0?(o=s,i=s-1):r=s+1}return o}function Htt(e,t,n,r,i){for(var o=r-1;r<=i;){var s=r+i>>>1,a=e[s],c=n!==void 0?n(a,t):a-t;c<0?(o=s,r=s+1):i=s-1}return o}function Ztt(e,t,n,r,i){for(var o=r-1;r<=i;){var s=r+i>>>1,a=e[s],c=n!==void 0?n(a,t):a-t;c<=0?(o=s,r=s+1):i=s-1}return o}function Jtt(e,t,n,r,i){for(;r<=i;){var o=r+i>>>1,s=e[o],a=n!==void 0?n(s,t):s-t;if(a===0)return o;a<=0?r=o+1:i=o-1}return-1}function Ay(e,t,n,r,i,o){return typeof n=="function"?o(e,t,n,r===void 0?0:r|0,i===void 0?e.length-1:i|0):o(e,t,void 0,n===void 0?0:n|0,r===void 0?e.length-1:r|0)}sP.exports={ge:function(e,t,n,r,i){return Ay(e,t,n,r,i,Gtt)},gt:function(e,t,n,r,i){return Ay(e,t,n,r,i,Wtt)},lt:function(e,t,n,r,i){return Ay(e,t,n,r,i,Htt)},le:function(e,t,n,r,i){return Ay(e,t,n,r,i,Ztt)},eq:function(e,t,n,r,i){return Ay(e,t,n,r,i,Jtt)}}});var mP=TD((z9t,pP)=>{"use strict";var Tv=aP(),hd=0,zl=1,Av=2;pP.exports=Ktt;function N3(e,t,n,r,i){this.mid=e,this.left=t,this.right=n,this.leftPoints=r,this.rightPoints=i,this.count=(t?t.count:0)+(n?n.count:0)+r.length}var Ty=N3.prototype;function T3(e,t){e.mid=t.mid,e.left=t.left,e.right=t.right,e.leftPoints=t.leftPoints,e.rightPoints=t.rightPoints,e.count=t.count}function uP(e,t){var n=pd(t);e.mid=n.mid,e.left=n.left,e.right=n.right,e.leftPoints=n.leftPoints,e.rightPoints=n.rightPoints,e.count=n.count}function cP(e,t){var n=e.intervals([]);n.push(t),uP(e,n)}function lP(e,t){var n=e.intervals([]),r=n.indexOf(t);return r<0?hd:(n.splice(r,1),uP(e,n),zl)}Ty.intervals=function(e){return e.push.apply(e,this.leftPoints),this.left&&this.left.intervals(e),this.right&&this.right.intervals(e),e};Ty.insert=function(e){var t=this.count-this.leftPoints.length;if(this.count+=1,e[1]<this.mid)this.left?4*(this.left.count+1)>3*(t+1)?cP(this,e):this.left.insert(e):this.left=pd([e]);else if(e[0]>this.mid)this.right?4*(this.right.count+1)>3*(t+1)?cP(this,e):this.right.insert(e):this.right=pd([e]);else{var n=Tv.ge(this.leftPoints,e,D3),r=Tv.ge(this.rightPoints,e,O3);this.leftPoints.splice(n,0,e),this.rightPoints.splice(r,0,e)}};Ty.remove=function(e){var t=this.count-this.leftPoints;if(e[1]<this.mid){if(!this.left)return hd;var n=this.right?this.right.count:0;if(4*n>3*(t-1))return lP(this,e);var r=this.left.remove(e);return r===Av?(this.left=null,this.count-=1,zl):(r===zl&&(this.count-=1),r)}else if(e[0]>this.mid){if(!this.right)return hd;var i=this.left?this.left.count:0;if(4*i>3*(t-1))return lP(this,e);var r=this.right.remove(e);return r===Av?(this.right=null,this.count-=1,zl):(r===zl&&(this.count-=1),r)}else{if(this.count===1)return this.leftPoints[0]===e?Av:hd;if(this.leftPoints.length===1&&this.leftPoints[0]===e){if(this.left&&this.right){for(var o=this,s=this.left;s.right;)o=s,s=s.right;if(o===this)s.right=this.right;else{var a=this.left,r=this.right;o.count-=s.count,o.right=s.left,s.left=a,s.right=r}T3(this,s),this.count=(this.left?this.left.count:0)+(this.right?this.right.count:0)+this.leftPoints.length}else this.left?T3(this,this.left):T3(this,this.right);return zl}for(var a=Tv.ge(this.leftPoints,e,D3);a<this.leftPoints.length&&this.leftPoints[a][0]===e[0];++a)if(this.leftPoints[a]===e){this.count-=1,this.leftPoints.splice(a,1);for(var r=Tv.ge(this.rightPoints,e,O3);r<this.rightPoints.length&&this.rightPoints[r][1]===e[1];++r)if(this.rightPoints[r]===e)return this.rightPoints.splice(r,1),zl}return hd}};function fP(e,t,n){for(var r=0;r<e.length&&e[r][0]<=t;++r){var i=n(e[r]);if(i)return i}}function dP(e,t,n){for(var r=e.length-1;r>=0&&e[r][1]>=t;--r){var i=n(e[r]);if(i)return i}}function hP(e,t){for(var n=0;n<e.length;++n){var r=t(e[n]);if(r)return r}}Ty.queryPoint=function(e,t){if(e<this.mid){if(this.left){var n=this.left.queryPoint(e,t);if(n)return n}return fP(this.leftPoints,e,t)}else if(e>this.mid){if(this.right){var n=this.right.queryPoint(e,t);if(n)return n}return dP(this.rightPoints,e,t)}else return hP(this.leftPoints,t)};Ty.queryInterval=function(e,t,n){if(e<this.mid&&this.left){var r=this.left.queryInterval(e,t,n);if(r)return r}if(t>this.mid&&this.right){var r=this.right.queryInterval(e,t,n);if(r)return r}return t<this.mid?fP(this.leftPoints,t,n):e>this.mid?dP(this.rightPoints,e,n):hP(this.leftPoints,n)};function Qtt(e,t){return e-t}function D3(e,t){var n=e[0]-t[0];return n||e[1]-t[1]}function O3(e,t){var n=e[1]-t[1];return n||e[0]-t[0]}function pd(e){if(e.length===0)return null;for(var t=[],n=0;n<e.length;++n)t.push(e[n][0],e[n][1]);t.sort(Qtt);for(var r=t[t.length>>1],i=[],o=[],s=[],n=0;n<e.length;++n){var a=e[n];a[1]<r?i.push(a):r<a[0]?o.push(a):s.push(a)}var c=s,l=s.slice();return c.sort(D3),l.sort(O3),new N3(r,pd(i),pd(o),c,l)}function E3(e){this.root=e}var md=E3.prototype;md.insert=function(e){this.root?this.root.insert(e):this.root=new N3(e[0],null,null,[e],[e])};md.remove=function(e){if(this.root){var t=this.root.remove(e);return t===Av&&(this.root=null),t!==hd}return!1};md.queryPoint=function(e,t){if(this.root)return this.root.queryPoint(e,t)};md.queryInterval=function(e,t,n){if(e<=t&&this.root)return this.root.queryInterval(e,t,n)};Object.defineProperty(md,"count",{get:function(){return this.root?this.root.count:0}});Object.defineProperty(md,"intervals",{get:function(){return this.root?this.root.intervals([]):[]}});function Ktt(e){return!e||e.length===0?new E3(null):new E3(pd(e))}});var ED={};function kd(e,t=!1){let n,r,i=ED;function o(l){n=e(l).then(()=>{if(r){let{value:u}=r;r=null,o(u)}else n=null})}function s(l){r={event:l}}function a(l){n?s(l):o(l)}function c(l){i!==l&&requestAnimationFrame(()=>{let u=i;i=ED,a(u)}),i=l}return t?c:a}var ur=class{constructor(t){this._filterBy=t,this._requestUpdate=kd(()=>this.requestQuery(),!0),this._coordinator=null}get coordinator(){return this._coordinator}set coordinator(t){this._coordinator=t}get filterBy(){return this._filterBy}get filterIndexable(){return!0}fields(){return null}fieldInfo(){return this}query(){return null}queryPending(){return this}queryResult(){return this}queryError(t){return console.error(t),this}requestQuery(t){let n=t||this.query(this.filterBy?.predicate(this));return this._coordinator.requestQuery(this,n)}requestUpdate(){this._requestUpdate()}update(){return this}};function DD(e,t){var n={};for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,r=Object.getOwnPropertySymbols(e);i<r.length;i++)t.indexOf(r[i])<0&&Object.prototype.propertyIsEnumerable.call(e,r[i])&&(n[r[i]]=e[r[i]]);return n}function Z(e,t,n,r){function i(o){return o instanceof n?o:new n(function(s){s(o)})}return new(n||(n=Promise))(function(o,s){function a(u){try{l(r.next(u))}catch(f){s(f)}}function c(u){try{l(r.throw(u))}catch(f){s(f)}}function l(u){u.done?o(u.value):i(u.value).then(a,c)}l((r=r.apply(e,t||[])).next())})}function ND(e){var t=typeof Symbol=="function"&&Symbol.iterator,n=t&&e[t],r=0;if(n)return n.call(e);if(e&&typeof e.length=="number")return{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function Ft(e){return this instanceof Ft?(this.v=e,this):new Ft(e)}function Mr(e,t,n){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var r=n.apply(e,t||[]),i,o=[];return i={},s("next"),s("throw"),s("return"),i[Symbol.asyncIterator]=function(){return this},i;function s(d){r[d]&&(i[d]=function(h){return new Promise(function(p,m){o.push([d,h,p,m])>1||a(d,h)})})}function a(d,h){try{c(r[d](h))}catch(p){f(o[0][3],p)}}function c(d){d.value instanceof Ft?Promise.resolve(d.value.v).then(l,u):f(o[0][2],d)}function l(d){a("next",d)}function u(d){a("throw",d)}function f(d,h){d(h),o.shift(),o.length&&a(o[0][0],o[0][1])}}function Hl(e){var t,n;return t={},r("next"),r("throw",function(i){throw i}),r("return"),t[Symbol.iterator]=function(){return this},t;function r(i,o){t[i]=e[i]?function(s){return(n=!n)?{value:Ft(e[i](s)),done:!1}:o?o(s):s}:o}}function bi(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t=e[Symbol.asyncIterator],n;return t?t.call(e):(e=typeof ND=="function"?ND(e):e[Symbol.iterator](),n={},r("next"),r("throw"),r("return"),n[Symbol.asyncIterator]=function(){return this},n);function r(o){n[o]=e[o]&&function(s){return new Promise(function(a,c){s=e[o](s),i(a,c,s.done,s.value)})}}function i(o,s,a,c){Promise.resolve(c).then(function(l){o({value:l,done:a})},s)}}var D_={};Ir(D_,{compareArrayLike:()=>N_,joinUint8Arrays:()=>Tr,memcpy:()=>$d,rebaseValueOffsets:()=>hg,toArrayBufferView:()=>Pt,toArrayBufferViewAsyncIterator:()=>vi,toArrayBufferViewIterator:()=>Ji,toBigInt64Array:()=>dg,toBigUint64Array:()=>Mz,toFloat32Array:()=>Az,toFloat32ArrayAsyncIterator:()=>qz,toFloat32ArrayIterator:()=>Cz,toFloat64Array:()=>Tz,toFloat64ArrayAsyncIterator:()=>jz,toFloat64ArrayIterator:()=>kz,toInt16Array:()=>_z,toInt16ArrayAsyncIterator:()=>$z,toInt16ArrayIterator:()=>Dz,toInt32Array:()=>wc,toInt32ArrayAsyncIterator:()=>Pz,toInt32ArrayIterator:()=>Oz,toInt8Array:()=>vz,toInt8ArrayAsyncIterator:()=>Rz,toInt8ArrayIterator:()=>Nz,toUint16Array:()=>Sz,toUint16ArrayAsyncIterator:()=>Uz,toUint16ArrayIterator:()=>Bz,toUint32Array:()=>Iz,toUint32ArrayAsyncIterator:()=>zz,toUint32ArrayIterator:()=>Lz,toUint8Array:()=>_t,toUint8ArrayAsyncIterator:()=>E_,toUint8ArrayIterator:()=>T_,toUint8ClampedArray:()=>Ez,toUint8ClampedArrayAsyncIterator:()=>Vz,toUint8ClampedArrayIterator:()=>Fz});var gz=new TextDecoder("utf-8"),Fd=e=>gz.decode(e),xz=new TextEncoder,Zi=e=>xz.encode(e);var bz=e=>typeof e=="number",OD=e=>typeof e=="boolean",nn=e=>typeof e=="function",Yn=e=>e!=null&&Object(e)===e,Ar=e=>Yn(e)&&nn(e.then);var wi=e=>Yn(e)&&nn(e[Symbol.iterator]),Wr=e=>Yn(e)&&nn(e[Symbol.asyncIterator]),sg=e=>Yn(e)&&Yn(e.schema);var ag=e=>Yn(e)&&"done"in e&&"value"in e;var cg=e=>Yn(e)&&nn(e.stat)&&bz(e.fd);var lg=e=>Yn(e)&&Rd(e.body),ug=e=>"_getDOMStream"in e&&"_getNodeStream"in e,BD=e=>Yn(e)&&nn(e.abort)&&nn(e.getWriter)&&!ug(e),Rd=e=>Yn(e)&&nn(e.cancel)&&nn(e.getReader)&&!ug(e),LD=e=>Yn(e)&&nn(e.end)&&nn(e.write)&&OD(e.writable)&&!ug(e),fg=e=>Yn(e)&&nn(e.read)&&nn(e.pipe)&&OD(e.readable)&&!ug(e),CD=e=>Yn(e)&&nn(e.clear)&&nn(e.bytes)&&nn(e.position)&&nn(e.setPosition)&&nn(e.capacity)&&nn(e.getBufferIdentifier)&&nn(e.createLong);var A_=typeof SharedArrayBuffer<"u"?SharedArrayBuffer:ArrayBuffer;function wz(e){let t=e[0]?[e[0]]:[],n,r,i,o;for(let s,a,c=0,l=0,u=e.length;++c<u;){if(s=t[l],a=e[c],!s||!a||s.buffer!==a.buffer||a.byteOffset<s.byteOffset){a&&(t[++l]=a);continue}if({byteOffset:n,byteLength:i}=s,{byteOffset:r,byteLength:o}=a,n+i<r||r+o<n){a&&(t[++l]=a);continue}t[l]=new Uint8Array(s.buffer,n,r-n+o)}return t}function $d(e,t,n=0,r=t.byteLength){let i=e.byteLength,o=new Uint8Array(e.buffer,e.byteOffset,i),s=new Uint8Array(t.buffer,t.byteOffset,Math.min(r,i));return o.set(s,n),e}function Tr(e,t){let n=wz(e),r=n.reduce((u,f)=>u+f.byteLength,0),i,o,s,a=0,c=-1,l=Math.min(t||Number.POSITIVE_INFINITY,r);for(let u=n.length;++c<u;){if(i=n[c],o=i.subarray(0,Math.min(i.length,l-a)),l<=a+o.length){o.length<i.length?n[c]=i.subarray(o.length):o.length===i.length&&c++,s?$d(s,o,a):s=o;break}$d(s||(s=new Uint8Array(l)),o,a),a+=o.length}return[s||new Uint8Array(0),n.slice(c),r-(s?s.byteLength:0)]}function Pt(e,t){let n=ag(t)?t.value:t;return n instanceof e?e===Uint8Array?new e(n.buffer,n.byteOffset,n.byteLength):n:n?(typeof n=="string"&&(n=Zi(n)),n instanceof ArrayBuffer?new e(n):n instanceof A_?new e(n):CD(n)?Pt(e,n.bytes()):ArrayBuffer.isView(n)?n.byteLength<=0?new e(0):new e(n.buffer,n.byteOffset,n.byteLength/e.BYTES_PER_ELEMENT):e.from(n)):new e(0)}var vz=e=>Pt(Int8Array,e),_z=e=>Pt(Int16Array,e),wc=e=>Pt(Int32Array,e),dg=e=>Pt(BigInt64Array,e),_t=e=>Pt(Uint8Array,e),Sz=e=>Pt(Uint16Array,e),Iz=e=>Pt(Uint32Array,e),Mz=e=>Pt(BigUint64Array,e),Az=e=>Pt(Float32Array,e),Tz=e=>Pt(Float64Array,e),Ez=e=>Pt(Uint8ClampedArray,e),M_=e=>(e.next(),e);function*Ji(e,t){let n=function*(i){yield i},r=typeof t=="string"||ArrayBuffer.isView(t)||t instanceof ArrayBuffer||t instanceof A_?n(t):wi(t)?t:n(t);return yield*M_(function*(i){let o=null;do o=i.next(yield Pt(e,o));while(!o.done)}(r[Symbol.iterator]())),new e}var Nz=e=>Ji(Int8Array,e),Dz=e=>Ji(Int16Array,e),Oz=e=>Ji(Int32Array,e),T_=e=>Ji(Uint8Array,e),Bz=e=>Ji(Uint16Array,e),Lz=e=>Ji(Uint32Array,e),Cz=e=>Ji(Float32Array,e),kz=e=>Ji(Float64Array,e),Fz=e=>Ji(Uint8ClampedArray,e);function vi(e,t){return Mr(this,arguments,function*(){if(Ar(t))return yield Ft(yield Ft(yield*Hl(bi(vi(e,yield Ft(t))))));let r=function(s){return Mr(this,arguments,function*(){yield yield Ft(yield Ft(s))})},i=function(s){return Mr(this,arguments,function*(){yield Ft(yield*Hl(bi(M_(function*(a){let c=null;do c=a.next(yield c?.value);while(!c.done)}(s[Symbol.iterator]())))))})},o=typeof t=="string"||ArrayBuffer.isView(t)||t instanceof ArrayBuffer||t instanceof A_?r(t):wi(t)?i(t):Wr(t)?t:r(t);return yield Ft(yield*Hl(bi(M_(function(s){return Mr(this,arguments,function*(){let a=null;do a=yield Ft(s.next(yield yield Ft(Pt(e,a))));while(!a.done)})}(o[Symbol.asyncIterator]()))))),yield Ft(new e)})}var Rz=e=>vi(Int8Array,e),$z=e=>vi(Int16Array,e),Pz=e=>vi(Int32Array,e),E_=e=>vi(Uint8Array,e),Uz=e=>vi(Uint16Array,e),zz=e=>vi(Uint32Array,e),qz=e=>vi(Float32Array,e),jz=e=>vi(Float64Array,e),Vz=e=>vi(Uint8ClampedArray,e);function hg(e,t,n){if(e!==0){n=n.slice(0,t);for(let r=-1,i=n.length;++r<i;)n[r]+=e}return n.subarray(0,t)}function N_(e,t){let n=0,r=e.length;if(r!==t.length)return!1;if(r>0)do if(e[n]!==t[n])return!1;while(++n<r);return!0}var bn={fromIterable(e){return pg(Yz(e))},fromAsyncIterable(e){return pg(Xz(e))},fromDOMStream(e){return pg(Gz(e))},fromNodeStream(e){return pg(Wz(e))},toDOMStream(e,t){throw new Error('"toDOMStream" not available in this environment')},toNodeStream(e,t){throw new Error('"toNodeStream" not available in this environment')}},pg=e=>(e.next(),e);function*Yz(e){let t,n=!1,r=[],i,o,s,a=0;function c(){return o==="peek"?Tr(r,s)[0]:([i,r,a]=Tr(r,s),i)}({cmd:o,size:s}=(yield null)||{cmd:"read",size:0});let l=T_(e)[Symbol.iterator]();try{do if({done:t,value:i}=Number.isNaN(s-a)?l.next():l.next(s-a),!t&&i.byteLength>0&&(r.push(i),a+=i.byteLength),t||s<=a)do({cmd:o,size:s}=yield c());while(s<a);while(!t)}catch(u){(n=!0)&&typeof l.throw=="function"&&l.throw(u)}finally{n===!1&&typeof l.return=="function"&&l.return(null)}return null}function Xz(e){return Mr(this,arguments,function*(){let n,r=!1,i=[],o,s,a,c=0;function l(){return s==="peek"?Tr(i,a)[0]:([o,i,c]=Tr(i,a),o)}({cmd:s,size:a}=(yield yield Ft(null))||{cmd:"read",size:0});let u=E_(e)[Symbol.asyncIterator]();try{do if({done:n,value:o}=Number.isNaN(a-c)?yield Ft(u.next()):yield Ft(u.next(a-c)),!n&&o.byteLength>0&&(i.push(o),c+=o.byteLength),n||a<=c)do({cmd:s,size:a}=yield yield Ft(l()));while(a<c);while(!n)}catch(f){(r=!0)&&typeof u.throw=="function"&&(yield Ft(u.throw(f)))}finally{r===!1&&typeof u.return=="function"&&(yield Ft(u.return(new Uint8Array(0))))}return yield Ft(null)})}function Gz(e){return Mr(this,arguments,function*(){let n=!1,r=!1,i=[],o,s,a,c=0;function l(){return s==="peek"?Tr(i,a)[0]:([o,i,c]=Tr(i,a),o)}({cmd:s,size:a}=(yield yield Ft(null))||{cmd:"read",size:0});let u=new B_(e);try{do if({done:n,value:o}=Number.isNaN(a-c)?yield Ft(u.read()):yield Ft(u.read(a-c)),!n&&o.byteLength>0&&(i.push(_t(o)),c+=o.byteLength),n||a<=c)do({cmd:s,size:a}=yield yield Ft(l()));while(a<c);while(!n)}catch(f){(r=!0)&&(yield Ft(u.cancel(f)))}finally{r===!1?yield Ft(u.cancel()):e.locked&&u.releaseLock()}return yield Ft(null)})}var B_=class{constructor(t){this.source=t,this.reader=null,this.reader=this.source.getReader(),this.reader.closed.catch(()=>{})}get closed(){return this.reader?this.reader.closed.catch(()=>{}):Promise.resolve()}releaseLock(){this.reader&&this.reader.releaseLock(),this.reader=null}cancel(t){return Z(this,void 0,void 0,function*(){let{reader:n,source:r}=this;n&&(yield n.cancel(t).catch(()=>{})),r&&r.locked&&this.releaseLock()})}read(t){return Z(this,void 0,void 0,function*(){if(t===0)return{done:this.reader==null,value:new Uint8Array(0)};let n=yield this.reader.read();return!n.done&&(n.value=_t(n)),n})}},O_=(e,t)=>{let n=i=>r([t,i]),r;return[t,n,new Promise(i=>(r=i)&&e.once(t,n))]};function Wz(e){return Mr(this,arguments,function*(){let n=[],r="error",i=!1,o=null,s,a,c=0,l=[],u;function f(){return s==="peek"?Tr(l,a)[0]:([u,l,c]=Tr(l,a),u)}if({cmd:s,size:a}=(yield yield Ft(null))||{cmd:"read",size:0},e.isTTY)return yield yield Ft(new Uint8Array(0)),yield Ft(null);try{n[0]=O_(e,"end"),n[1]=O_(e,"error");do{if(n[2]=O_(e,"readable"),[r,o]=yield Ft(Promise.race(n.map(h=>h[2]))),r==="error")break;if((i=r==="end")||(Number.isFinite(a-c)?(u=_t(e.read(a-c)),u.byteLength<a-c&&(u=_t(e.read()))):u=_t(e.read()),u.byteLength>0&&(l.push(u),c+=u.byteLength)),i||a<=c)do({cmd:s,size:a}=yield yield Ft(f()));while(a<c)}while(!i)}finally{yield Ft(d(n,r==="error"?o:null))}return yield Ft(null);function d(h,p){return u=l=null,new Promise((m,g)=>{for(let[y,x]of h)e.off(y,x);try{let y=e.destroy;y&&y.call(e,p),p=void 0}catch(y){p=y||p}finally{p!=null?g(p):m()}})}})}var ce;(function(e){e[e.V1=0]="V1",e[e.V2=1]="V2",e[e.V3=2]="V3",e[e.V4=3]="V4",e[e.V5=4]="V5"})(ce||(ce={}));var ge;(function(e){e[e.Sparse=0]="Sparse",e[e.Dense=1]="Dense"})(ge||(ge={}));var he;(function(e){e[e.HALF=0]="HALF",e[e.SINGLE=1]="SINGLE",e[e.DOUBLE=2]="DOUBLE"})(he||(he={}));var Ve;(function(e){e[e.DAY=0]="DAY",e[e.MILLISECOND=1]="MILLISECOND"})(Ve||(Ve={}));var ct;(function(e){e[e.SECOND=0]="SECOND",e[e.MILLISECOND=1]="MILLISECOND",e[e.MICROSECOND=2]="MICROSECOND",e[e.NANOSECOND=3]="NANOSECOND"})(ct||(ct={}));var an;(function(e){e[e.YEAR_MONTH=0]="YEAR_MONTH",e[e.DAY_TIME=1]="DAY_TIME",e[e.MONTH_DAY_NANO=2]="MONTH_DAY_NANO"})(an||(an={}));var Qi=new Int32Array(2),mg=new Float32Array(Qi.buffer),yg=new Float64Array(Qi.buffer),Zl=new Uint16Array(new Uint8Array([1,0]).buffer)[0]===1;var Pd;(function(e){e[e.UTF8_BYTES=1]="UTF8_BYTES",e[e.UTF16_STRING=2]="UTF16_STRING"})(Pd||(Pd={}));var Er=class e{constructor(t){this.bytes_=t,this.position_=0,this.text_decoder_=new TextDecoder}static allocate(t){return new e(new Uint8Array(t))}clear(){this.position_=0}bytes(){return this.bytes_}position(){return this.position_}setPosition(t){this.position_=t}capacity(){return this.bytes_.length}readInt8(t){return this.readUint8(t)<<24>>24}readUint8(t){return this.bytes_[t]}readInt16(t){return this.readUint16(t)<<16>>16}readUint16(t){return this.bytes_[t]|this.bytes_[t+1]<<8}readInt32(t){return this.bytes_[t]|this.bytes_[t+1]<<8|this.bytes_[t+2]<<16|this.bytes_[t+3]<<24}readUint32(t){return this.readInt32(t)>>>0}readInt64(t){return BigInt.asIntN(64,BigInt(this.readUint32(t))+(BigInt(this.readUint32(t+4))<<BigInt(32)))}readUint64(t){return BigInt.asUintN(64,BigInt(this.readUint32(t))+(BigInt(this.readUint32(t+4))<<BigInt(32)))}readFloat32(t){return Qi[0]=this.readInt32(t),mg[0]}readFloat64(t){return Qi[Zl?0:1]=this.readInt32(t),Qi[Zl?1:0]=this.readInt32(t+4),yg[0]}writeInt8(t,n){this.bytes_[t]=n}writeUint8(t,n){this.bytes_[t]=n}writeInt16(t,n){this.bytes_[t]=n,this.bytes_[t+1]=n>>8}writeUint16(t,n){this.bytes_[t]=n,this.bytes_[t+1]=n>>8}writeInt32(t,n){this.bytes_[t]=n,this.bytes_[t+1]=n>>8,this.bytes_[t+2]=n>>16,this.bytes_[t+3]=n>>24}writeUint32(t,n){this.bytes_[t]=n,this.bytes_[t+1]=n>>8,this.bytes_[t+2]=n>>16,this.bytes_[t+3]=n>>24}writeInt64(t,n){this.writeInt32(t,Number(BigInt.asIntN(32,n))),this.writeInt32(t+4,Number(BigInt.asIntN(32,n>>BigInt(32))))}writeUint64(t,n){this.writeUint32(t,Number(BigInt.asUintN(32,n))),this.writeUint32(t+4,Number(BigInt.asUintN(32,n>>BigInt(32))))}writeFloat32(t,n){mg[0]=n,this.writeInt32(t,Qi[0])}writeFloat64(t,n){yg[0]=n,this.writeInt32(t,Qi[Zl?0:1]),this.writeInt32(t+4,Qi[Zl?1:0])}getBufferIdentifier(){if(this.bytes_.length<this.position_+4+4)throw new Error("FlatBuffers: ByteBuffer is too short to contain an identifier.");let t="";for(let n=0;n<4;n++)t+=String.fromCharCode(this.readInt8(this.position_+4+n));return t}__offset(t,n){let r=t-this.readInt32(t);return n<this.readInt16(r)?this.readInt16(r+n):0}__union(t,n){return t.bb_pos=n+this.readInt32(n),t.bb=this,t}__string(t,n){t+=this.readInt32(t);let r=this.readInt32(t);t+=4;let i=this.bytes_.subarray(t,t+r);return n===Pd.UTF8_BYTES?i:this.text_decoder_.decode(i)}__union_with_string(t,n){return typeof t=="string"?this.__string(n):this.__union(t,n)}__indirect(t){return t+this.readInt32(t)}__vector(t){return t+this.readInt32(t)+4}__vector_len(t){return this.readInt32(t+this.readInt32(t))}__has_identifier(t){if(t.length!=4)throw new Error("FlatBuffers: file identifier must be length "+4);for(let n=0;n<4;n++)if(t.charCodeAt(n)!=this.readInt8(this.position()+4+n))return!1;return!0}createScalarList(t,n){let r=[];for(let i=0;i<n;++i){let o=t(i);o!==null&&r.push(o)}return r}createObjList(t,n){let r=[];for(let i=0;i<n;++i){let o=t(i);o!==null&&r.push(o.unpack())}return r}};var vc=class e{constructor(t){this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1,this.string_maps=null,this.text_encoder=new TextEncoder;let n;t?n=t:n=1024,this.bb=Er.allocate(n),this.space=n}clear(){this.bb.clear(),this.space=this.bb.capacity(),this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1,this.string_maps=null}forceDefaults(t){this.force_defaults=t}dataBuffer(){return this.bb}asUint8Array(){return this.bb.bytes().subarray(this.bb.position(),this.bb.position()+this.offset())}prep(t,n){t>this.minalign&&(this.minalign=t);let r=~(this.bb.capacity()-this.space+n)+1&t-1;for(;this.space<r+t+n;){let i=this.bb.capacity();this.bb=e.growByteBuffer(this.bb),this.space+=this.bb.capacity()-i}this.pad(r)}pad(t){for(let n=0;n<t;n++)this.bb.writeInt8(--this.space,0)}writeInt8(t){this.bb.writeInt8(this.space-=1,t)}writeInt16(t){this.bb.writeInt16(this.space-=2,t)}writeInt32(t){this.bb.writeInt32(this.space-=4,t)}writeInt64(t){this.bb.writeInt64(this.space-=8,t)}writeFloat32(t){this.bb.writeFloat32(this.space-=4,t)}writeFloat64(t){this.bb.writeFloat64(this.space-=8,t)}addInt8(t){this.prep(1,0),this.writeInt8(t)}addInt16(t){this.prep(2,0),this.writeInt16(t)}addInt32(t){this.prep(4,0),this.writeInt32(t)}addInt64(t){this.prep(8,0),this.writeInt64(t)}addFloat32(t){this.prep(4,0),this.writeFloat32(t)}addFloat64(t){this.prep(8,0),this.writeFloat64(t)}addFieldInt8(t,n,r){(this.force_defaults||n!=r)&&(this.addInt8(n),this.slot(t))}addFieldInt16(t,n,r){(this.force_defaults||n!=r)&&(this.addInt16(n),this.slot(t))}addFieldInt32(t,n,r){(this.force_defaults||n!=r)&&(this.addInt32(n),this.slot(t))}addFieldInt64(t,n,r){(this.force_defaults||n!==r)&&(this.addInt64(n),this.slot(t))}addFieldFloat32(t,n,r){(this.force_defaults||n!=r)&&(this.addFloat32(n),this.slot(t))}addFieldFloat64(t,n,r){(this.force_defaults||n!=r)&&(this.addFloat64(n),this.slot(t))}addFieldOffset(t,n,r){(this.force_defaults||n!=r)&&(this.addOffset(n),this.slot(t))}addFieldStruct(t,n,r){n!=r&&(this.nested(n),this.slot(t))}nested(t){if(t!=this.offset())throw new TypeError("FlatBuffers: struct must be serialized inline.")}notNested(){if(this.isNested)throw new TypeError("FlatBuffers: object serialization must not be nested.")}slot(t){this.vtable!==null&&(this.vtable[t]=this.offset())}offset(){return this.bb.capacity()-this.space}static growByteBuffer(t){let n=t.capacity();if(n&3221225472)throw new Error("FlatBuffers: cannot grow buffer beyond 2 gigabytes.");let r=n<<1,i=Er.allocate(r);return i.setPosition(r-n),i.bytes().set(t.bytes(),r-n),i}addOffset(t){this.prep(4,0),this.writeInt32(this.offset()-t+4)}startObject(t){this.notNested(),this.vtable==null&&(this.vtable=[]),this.vtable_in_use=t;for(let n=0;n<t;n++)this.vtable[n]=0;this.isNested=!0,this.object_start=this.offset()}endObject(){if(this.vtable==null||!this.isNested)throw new Error("FlatBuffers: endObject called without startObject");this.addInt32(0);let t=this.offset(),n=this.vtable_in_use-1;for(;n>=0&&this.vtable[n]==0;n--);let r=n+1;for(;n>=0;n--)this.addInt16(this.vtable[n]!=0?t-this.vtable[n]:0);let i=2;this.addInt16(t-this.object_start);let o=(r+i)*2;this.addInt16(o);let s=0,a=this.space;t:for(n=0;n<this.vtables.length;n++){let c=this.bb.capacity()-this.vtables[n];if(o==this.bb.readInt16(c)){for(let l=2;l<o;l+=2)if(this.bb.readInt16(a+l)!=this.bb.readInt16(c+l))continue t;s=this.vtables[n];break}}return s?(this.space=this.bb.capacity()-t,this.bb.writeInt32(this.space,s-t)):(this.vtables.push(this.offset()),this.bb.writeInt32(this.bb.capacity()-t,this.offset()-t)),this.isNested=!1,t}finish(t,n,r){let i=r?4:0;if(n){let o=n;if(this.prep(this.minalign,8+i),o.length!=4)throw new TypeError("FlatBuffers: file identifier must be length "+4);for(let s=3;s>=0;s--)this.writeInt8(o.charCodeAt(s))}this.prep(this.minalign,4+i),this.addOffset(t),i&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)}finishSizePrefixed(t,n){this.finish(t,n,!0)}requiredField(t,n){let r=this.bb.capacity()-t,i=r-this.bb.readInt32(r);if(!(n<this.bb.readInt16(i)&&this.bb.readInt16(i+n)!=0))throw new TypeError("FlatBuffers: field "+n+" must be set")}startVector(t,n,r){this.notNested(),this.vector_num_elems=n,this.prep(4,t*n),this.prep(r,t*n)}endVector(){return this.writeInt32(this.vector_num_elems),this.offset()}createSharedString(t){if(!t)return 0;if(this.string_maps||(this.string_maps=new Map),this.string_maps.has(t))return this.string_maps.get(t);let n=this.createString(t);return this.string_maps.set(t,n),n}createString(t){if(t==null)return 0;let n;t instanceof Uint8Array?n=t:n=this.text_encoder.encode(t),this.addInt8(0),this.startVector(1,n.length,1),this.bb.setPosition(this.space-=n.length);for(let r=0,i=this.space,o=this.bb.bytes();r<n.length;r++)o[i++]=n[r];return this.endVector()}createObjectOffset(t){return t===null?0:typeof t=="string"?this.createString(t):t.pack(this)}createObjectOffsetList(t){let n=[];for(let r=0;r<t.length;++r){let i=t[r];if(i!==null)n.push(this.createObjectOffset(i));else throw new TypeError("FlatBuffers: Argument for createObjectOffsetList cannot contain null.")}return n}createStructOffsetList(t,n){return n(this,t.length),this.createObjectOffsetList(t.slice().reverse()),this.endVector()}};var Ud;(function(e){e[e.BUFFER=0]="BUFFER"})(Ud||(Ud={}));var zd;(function(e){e[e.LZ4_FRAME=0]="LZ4_FRAME",e[e.ZSTD=1]="ZSTD"})(zd||(zd={}));var xg=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsBodyCompression(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsBodyCompression(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}codec(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt8(this.bb_pos+t):zd.LZ4_FRAME}method(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.readInt8(this.bb_pos+t):Ud.BUFFER}static startBodyCompression(t){t.startObject(2)}static addCodec(t,n){t.addFieldInt8(0,n,zd.LZ4_FRAME)}static addMethod(t,n){t.addFieldInt8(1,n,Ud.BUFFER)}static endBodyCompression(t){return t.endObject()}static createBodyCompression(t,n,r){return e.startBodyCompression(t),e.addCodec(t,n),e.addMethod(t,r),e.endBodyCompression(t)}};var Jl=class{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}offset(){return this.bb.readInt64(this.bb_pos)}length(){return this.bb.readInt64(this.bb_pos+8)}static sizeOf(){return 16}static createBuffer(t,n,r){return t.prep(8,16),t.writeInt64(BigInt(r??0)),t.writeInt64(BigInt(n??0)),t.offset()}};var Ql=class{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}length(){return this.bb.readInt64(this.bb_pos)}nullCount(){return this.bb.readInt64(this.bb_pos+8)}static sizeOf(){return 16}static createFieldNode(t,n,r){return t.prep(8,16),t.writeInt64(BigInt(r??0)),t.writeInt64(BigInt(n??0)),t.offset()}};var Nr=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsRecordBatch(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsRecordBatch(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}length(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt64(this.bb_pos+t):BigInt("0")}nodes(t,n){let r=this.bb.__offset(this.bb_pos,6);return r?(n||new Ql).__init(this.bb.__vector(this.bb_pos+r)+t*16,this.bb):null}nodesLength(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.__vector_len(this.bb_pos+t):0}buffers(t,n){let r=this.bb.__offset(this.bb_pos,8);return r?(n||new Jl).__init(this.bb.__vector(this.bb_pos+r)+t*16,this.bb):null}buffersLength(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.__vector_len(this.bb_pos+t):0}compression(t){let n=this.bb.__offset(this.bb_pos,10);return n?(t||new xg).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}static startRecordBatch(t){t.startObject(4)}static addLength(t,n){t.addFieldInt64(0,n,BigInt("0"))}static addNodes(t,n){t.addFieldOffset(1,n,0)}static startNodesVector(t,n){t.startVector(16,n,8)}static addBuffers(t,n){t.addFieldOffset(2,n,0)}static startBuffersVector(t,n){t.startVector(16,n,8)}static addCompression(t,n){t.addFieldOffset(3,n,0)}static endRecordBatch(t){return t.endObject()}};var Wo=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDictionaryBatch(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDictionaryBatch(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}id(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt64(this.bb_pos+t):BigInt("0")}data(t){let n=this.bb.__offset(this.bb_pos,6);return n?(t||new Nr).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}isDelta(){let t=this.bb.__offset(this.bb_pos,8);return t?!!this.bb.readInt8(this.bb_pos+t):!1}static startDictionaryBatch(t){t.startObject(3)}static addId(t,n){t.addFieldInt64(0,n,BigInt("0"))}static addData(t,n){t.addFieldOffset(1,n,0)}static addIsDelta(t,n){t.addFieldInt8(2,+n,0)}static endDictionaryBatch(t){return t.endObject()}};var da;(function(e){e[e.Little=0]="Little",e[e.Big=1]="Big"})(da||(da={}));var qd;(function(e){e[e.DenseArray=0]="DenseArray"})(qd||(qd={}));var Si=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsInt(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsInt(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}bitWidth(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt32(this.bb_pos+t):0}isSigned(){let t=this.bb.__offset(this.bb_pos,6);return t?!!this.bb.readInt8(this.bb_pos+t):!1}static startInt(t){t.startObject(2)}static addBitWidth(t,n){t.addFieldInt32(0,n,0)}static addIsSigned(t,n){t.addFieldInt8(1,+n,0)}static endInt(t){return t.endObject()}static createInt(t,n,r){return e.startInt(t),e.addBitWidth(t,n),e.addIsSigned(t,r),e.endInt(t)}};var Ki=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDictionaryEncoding(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDictionaryEncoding(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}id(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt64(this.bb_pos+t):BigInt("0")}indexType(t){let n=this.bb.__offset(this.bb_pos,6);return n?(t||new Si).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}isOrdered(){let t=this.bb.__offset(this.bb_pos,8);return t?!!this.bb.readInt8(this.bb_pos+t):!1}dictionaryKind(){let t=this.bb.__offset(this.bb_pos,10);return t?this.bb.readInt16(this.bb_pos+t):qd.DenseArray}static startDictionaryEncoding(t){t.startObject(4)}static addId(t,n){t.addFieldInt64(0,n,BigInt("0"))}static addIndexType(t,n){t.addFieldOffset(1,n,0)}static addIsOrdered(t,n){t.addFieldInt8(2,+n,0)}static addDictionaryKind(t,n){t.addFieldInt16(3,n,qd.DenseArray)}static endDictionaryEncoding(t){return t.endObject()}};var rn=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsKeyValue(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsKeyValue(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}key(t){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,t):null}value(t){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,t):null}static startKeyValue(t){t.startObject(2)}static addKey(t,n){t.addFieldOffset(0,n,0)}static addValue(t,n){t.addFieldOffset(1,n,0)}static endKeyValue(t){return t.endObject()}static createKeyValue(t,n,r){return e.startKeyValue(t),e.addKey(t,n),e.addValue(t,r),e.endKeyValue(t)}};var jd=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsBinary(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsBinary(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startBinary(t){t.startObject(0)}static endBinary(t){return t.endObject()}static createBinary(t){return e.startBinary(t),e.endBinary(t)}};var Vd=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsBool(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsBool(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startBool(t){t.startObject(0)}static endBool(t){return t.endObject()}static createBool(t){return e.startBool(t),e.endBool(t)}};var ha=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDate(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDate(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):Ve.MILLISECOND}static startDate(t){t.startObject(1)}static addUnit(t,n){t.addFieldInt16(0,n,Ve.MILLISECOND)}static endDate(t){return t.endObject()}static createDate(t,n){return e.startDate(t),e.addUnit(t,n),e.endDate(t)}};var to=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDecimal(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDecimal(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}precision(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt32(this.bb_pos+t):0}scale(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.readInt32(this.bb_pos+t):0}bitWidth(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.readInt32(this.bb_pos+t):128}static startDecimal(t){t.startObject(3)}static addPrecision(t,n){t.addFieldInt32(0,n,0)}static addScale(t,n){t.addFieldInt32(1,n,0)}static addBitWidth(t,n){t.addFieldInt32(2,n,128)}static endDecimal(t){return t.endObject()}static createDecimal(t,n,r,i){return e.startDecimal(t),e.addPrecision(t,n),e.addScale(t,r),e.addBitWidth(t,i),e.endDecimal(t)}};var pa=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDuration(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDuration(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ct.MILLISECOND}static startDuration(t){t.startObject(1)}static addUnit(t,n){t.addFieldInt16(0,n,ct.MILLISECOND)}static endDuration(t){return t.endObject()}static createDuration(t,n){return e.startDuration(t),e.addUnit(t,n),e.endDuration(t)}};var ma=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsFixedSizeBinary(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsFixedSizeBinary(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}byteWidth(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt32(this.bb_pos+t):0}static startFixedSizeBinary(t){t.startObject(1)}static addByteWidth(t,n){t.addFieldInt32(0,n,0)}static endFixedSizeBinary(t){return t.endObject()}static createFixedSizeBinary(t,n){return e.startFixedSizeBinary(t),e.addByteWidth(t,n),e.endFixedSizeBinary(t)}};var ya=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsFixedSizeList(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsFixedSizeList(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}listSize(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt32(this.bb_pos+t):0}static startFixedSizeList(t){t.startObject(1)}static addListSize(t,n){t.addFieldInt32(0,n,0)}static endFixedSizeList(t){return t.endObject()}static createFixedSizeList(t,n){return e.startFixedSizeList(t),e.addListSize(t,n),e.endFixedSizeList(t)}};var ga=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsFloatingPoint(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsFloatingPoint(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}precision(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):he.HALF}static startFloatingPoint(t){t.startObject(1)}static addPrecision(t,n){t.addFieldInt16(0,n,he.HALF)}static endFloatingPoint(t){return t.endObject()}static createFloatingPoint(t,n){return e.startFloatingPoint(t),e.addPrecision(t,n),e.endFloatingPoint(t)}};var xa=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsInterval(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsInterval(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):an.YEAR_MONTH}static startInterval(t){t.startObject(1)}static addUnit(t,n){t.addFieldInt16(0,n,an.YEAR_MONTH)}static endInterval(t){return t.endObject()}static createInterval(t,n){return e.startInterval(t),e.addUnit(t,n),e.endInterval(t)}};var Yd=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsLargeBinary(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsLargeBinary(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startLargeBinary(t){t.startObject(0)}static endLargeBinary(t){return t.endObject()}static createLargeBinary(t){return e.startLargeBinary(t),e.endLargeBinary(t)}};var Xd=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsLargeUtf8(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsLargeUtf8(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startLargeUtf8(t){t.startObject(0)}static endLargeUtf8(t){return t.endObject()}static createLargeUtf8(t){return e.startLargeUtf8(t),e.endLargeUtf8(t)}};var Gd=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsList(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsList(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startList(t){t.startObject(0)}static endList(t){return t.endObject()}static createList(t){return e.startList(t),e.endList(t)}};var ba=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsMap(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsMap(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}keysSorted(){let t=this.bb.__offset(this.bb_pos,4);return t?!!this.bb.readInt8(this.bb_pos+t):!1}static startMap(t){t.startObject(1)}static addKeysSorted(t,n){t.addFieldInt8(0,+n,0)}static endMap(t){return t.endObject()}static createMap(t,n){return e.startMap(t),e.addKeysSorted(t,n),e.endMap(t)}};var Wd=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsNull(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsNull(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startNull(t){t.startObject(0)}static endNull(t){return t.endObject()}static createNull(t){return e.startNull(t),e.endNull(t)}};var Hd=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsStruct_(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsStruct_(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startStruct_(t){t.startObject(0)}static endStruct_(t){return t.endObject()}static createStruct_(t){return e.startStruct_(t),e.endStruct_(t)}};var Ho=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsTime(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsTime(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ct.MILLISECOND}bitWidth(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.readInt32(this.bb_pos+t):32}static startTime(t){t.startObject(2)}static addUnit(t,n){t.addFieldInt16(0,n,ct.MILLISECOND)}static addBitWidth(t,n){t.addFieldInt32(1,n,32)}static endTime(t){return t.endObject()}static createTime(t,n,r){return e.startTime(t),e.addUnit(t,n),e.addBitWidth(t,r),e.endTime(t)}};var Zo=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsTimestamp(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsTimestamp(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ct.SECOND}timezone(t){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,t):null}static startTimestamp(t){t.startObject(2)}static addUnit(t,n){t.addFieldInt16(0,n,ct.SECOND)}static addTimezone(t,n){t.addFieldOffset(1,n,0)}static endTimestamp(t){return t.endObject()}static createTimestamp(t,n,r){return e.startTimestamp(t),e.addUnit(t,n),e.addTimezone(t,r),e.endTimestamp(t)}};var Ii=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsUnion(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsUnion(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}mode(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ge.Sparse}typeIds(t){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.readInt32(this.bb.__vector(this.bb_pos+n)+t*4):0}typeIdsLength(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.__vector_len(this.bb_pos+t):0}typeIdsArray(){let t=this.bb.__offset(this.bb_pos,6);return t?new Int32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+t),this.bb.__vector_len(this.bb_pos+t)):null}static startUnion(t){t.startObject(2)}static addMode(t,n){t.addFieldInt16(0,n,ge.Sparse)}static addTypeIds(t,n){t.addFieldOffset(1,n,0)}static createTypeIdsVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addInt32(n[r]);return t.endVector()}static startTypeIdsVector(t,n){t.startVector(4,n,4)}static endUnion(t){return t.endObject()}static createUnion(t,n,r){return e.startUnion(t),e.addMode(t,n),e.addTypeIds(t,r),e.endUnion(t)}};var Zd=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsUtf8(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsUtf8(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startUtf8(t){t.startObject(0)}static endUtf8(t){return t.endObject()}static createUtf8(t){return e.startUtf8(t),e.endUtf8(t)}};var pe;(function(e){e[e.NONE=0]="NONE",e[e.Null=1]="Null",e[e.Int=2]="Int",e[e.FloatingPoint=3]="FloatingPoint",e[e.Binary=4]="Binary",e[e.Utf8=5]="Utf8",e[e.Bool=6]="Bool",e[e.Decimal=7]="Decimal",e[e.Date=8]="Date",e[e.Time=9]="Time",e[e.Timestamp=10]="Timestamp",e[e.Interval=11]="Interval",e[e.List=12]="List",e[e.Struct_=13]="Struct_",e[e.Union=14]="Union",e[e.FixedSizeBinary=15]="FixedSizeBinary",e[e.FixedSizeList=16]="FixedSizeList",e[e.Map=17]="Map",e[e.Duration=18]="Duration",e[e.LargeBinary=19]="LargeBinary",e[e.LargeUtf8=20]="LargeUtf8",e[e.LargeList=21]="LargeList",e[e.RunEndEncoded=22]="RunEndEncoded"})(pe||(pe={}));var Cn=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsField(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsField(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}name(t){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,t):null}nullable(){let t=this.bb.__offset(this.bb_pos,6);return t?!!this.bb.readInt8(this.bb_pos+t):!1}typeType(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.readUint8(this.bb_pos+t):pe.NONE}type(t){let n=this.bb.__offset(this.bb_pos,10);return n?this.bb.__union(t,this.bb_pos+n):null}dictionary(t){let n=this.bb.__offset(this.bb_pos,12);return n?(t||new Ki).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}children(t,n){let r=this.bb.__offset(this.bb_pos,14);return r?(n||new e).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}childrenLength(){let t=this.bb.__offset(this.bb_pos,14);return t?this.bb.__vector_len(this.bb_pos+t):0}customMetadata(t,n){let r=this.bb.__offset(this.bb_pos,16);return r?(n||new rn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}customMetadataLength(){let t=this.bb.__offset(this.bb_pos,16);return t?this.bb.__vector_len(this.bb_pos+t):0}static startField(t){t.startObject(7)}static addName(t,n){t.addFieldOffset(0,n,0)}static addNullable(t,n){t.addFieldInt8(1,+n,0)}static addTypeType(t,n){t.addFieldInt8(2,n,pe.NONE)}static addType(t,n){t.addFieldOffset(3,n,0)}static addDictionary(t,n){t.addFieldOffset(4,n,0)}static addChildren(t,n){t.addFieldOffset(5,n,0)}static createChildrenVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startChildrenVector(t,n){t.startVector(4,n,4)}static addCustomMetadata(t,n){t.addFieldOffset(6,n,0)}static createCustomMetadataVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startCustomMetadataVector(t,n){t.startVector(4,n,4)}static endField(t){return t.endObject()}};var fr=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsSchema(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsSchema(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}endianness(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):da.Little}fields(t,n){let r=this.bb.__offset(this.bb_pos,6);return r?(n||new Cn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}fieldsLength(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.__vector_len(this.bb_pos+t):0}customMetadata(t,n){let r=this.bb.__offset(this.bb_pos,8);return r?(n||new rn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}customMetadataLength(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.__vector_len(this.bb_pos+t):0}features(t){let n=this.bb.__offset(this.bb_pos,10);return n?this.bb.readInt64(this.bb.__vector(this.bb_pos+n)+t*8):BigInt(0)}featuresLength(){let t=this.bb.__offset(this.bb_pos,10);return t?this.bb.__vector_len(this.bb_pos+t):0}static startSchema(t){t.startObject(4)}static addEndianness(t,n){t.addFieldInt16(0,n,da.Little)}static addFields(t,n){t.addFieldOffset(1,n,0)}static createFieldsVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startFieldsVector(t,n){t.startVector(4,n,4)}static addCustomMetadata(t,n){t.addFieldOffset(2,n,0)}static createCustomMetadataVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startCustomMetadataVector(t,n){t.startVector(4,n,4)}static addFeatures(t,n){t.addFieldOffset(3,n,0)}static createFeaturesVector(t,n){t.startVector(8,n.length,8);for(let r=n.length-1;r>=0;r--)t.addInt64(n[r]);return t.endVector()}static startFeaturesVector(t,n){t.startVector(8,n,8)}static endSchema(t){return t.endObject()}static finishSchemaBuffer(t,n){t.finish(n)}static finishSizePrefixedSchemaBuffer(t,n){t.finish(n,void 0,!0)}static createSchema(t,n,r,i,o){return e.startSchema(t),e.addEndianness(t,n),e.addFields(t,r),e.addCustomMetadata(t,i),e.addFeatures(t,o),e.endSchema(t)}};var qt;(function(e){e[e.NONE=0]="NONE",e[e.Schema=1]="Schema",e[e.DictionaryBatch=2]="DictionaryBatch",e[e.RecordBatch=3]="RecordBatch",e[e.Tensor=4]="Tensor",e[e.SparseTensor=5]="SparseTensor"})(qt||(qt={}));var B;(function(e){e[e.NONE=0]="NONE",e[e.Null=1]="Null",e[e.Int=2]="Int",e[e.Float=3]="Float",e[e.Binary=4]="Binary",e[e.Utf8=5]="Utf8",e[e.Bool=6]="Bool",e[e.Decimal=7]="Decimal",e[e.Date=8]="Date",e[e.Time=9]="Time",e[e.Timestamp=10]="Timestamp",e[e.Interval=11]="Interval",e[e.List=12]="List",e[e.Struct=13]="Struct",e[e.Union=14]="Union",e[e.FixedSizeBinary=15]="FixedSizeBinary",e[e.FixedSizeList=16]="FixedSizeList",e[e.Map=17]="Map",e[e.Duration=18]="Duration",e[e.LargeBinary=19]="LargeBinary",e[e.LargeUtf8=20]="LargeUtf8",e[e.Dictionary=-1]="Dictionary",e[e.Int8=-2]="Int8",e[e.Int16=-3]="Int16",e[e.Int32=-4]="Int32",e[e.Int64=-5]="Int64",e[e.Uint8=-6]="Uint8",e[e.Uint16=-7]="Uint16",e[e.Uint32=-8]="Uint32",e[e.Uint64=-9]="Uint64",e[e.Float16=-10]="Float16",e[e.Float32=-11]="Float32",e[e.Float64=-12]="Float64",e[e.DateDay=-13]="DateDay",e[e.DateMillisecond=-14]="DateMillisecond",e[e.TimestampSecond=-15]="TimestampSecond",e[e.TimestampMillisecond=-16]="TimestampMillisecond",e[e.TimestampMicrosecond=-17]="TimestampMicrosecond",e[e.TimestampNanosecond=-18]="TimestampNanosecond",e[e.TimeSecond=-19]="TimeSecond",e[e.TimeMillisecond=-20]="TimeMillisecond",e[e.TimeMicrosecond=-21]="TimeMicrosecond",e[e.TimeNanosecond=-22]="TimeNanosecond",e[e.DenseUnion=-23]="DenseUnion",e[e.SparseUnion=-24]="SparseUnion",e[e.IntervalDayTime=-25]="IntervalDayTime",e[e.IntervalYearMonth=-26]="IntervalYearMonth",e[e.DurationSecond=-27]="DurationSecond",e[e.DurationMillisecond=-28]="DurationMillisecond",e[e.DurationMicrosecond=-29]="DurationMicrosecond",e[e.DurationNanosecond=-30]="DurationNanosecond"})(B||(B={}));var Mi;(function(e){e[e.OFFSET=0]="OFFSET",e[e.DATA=1]="DATA",e[e.VALIDITY=2]="VALIDITY",e[e.TYPE=3]="TYPE"})(Mi||(Mi={}));var J_={};Ir(J_,{clampIndex:()=>kq,clampRange:()=>th,createElementComparator:()=>_a});var L_={};Ir(L_,{valueToString:()=>Ai});function Ai(e){if(e===null)return"null";if(e===void 0)return"undefined";switch(typeof e){case"number":return`${e}`;case"bigint":return`${e}`;case"string":return`"${e}"`}return typeof e[Symbol.toPrimitive]=="function"?e[Symbol.toPrimitive]("string"):ArrayBuffer.isView(e)?e instanceof BigInt64Array||e instanceof BigUint64Array?`[${[...e].map(t=>Ai(t))}]`:`[${e}]`:ArrayBuffer.isView(e)?`[${e}]`:JSON.stringify(e,(t,n)=>typeof n=="bigint"?`${n}`:n)}var k_={};Ir(k_,{BN:()=>Qd,bigNumToBigInt:()=>RD,bigNumToString:()=>eu,isArrowBigNumSymbol:()=>kD});var kD=Symbol.for("isArrowBigNum");function Ti(e,...t){return t.length===0?Object.setPrototypeOf(Pt(this.TypedArray,e),this.constructor.prototype):Object.setPrototypeOf(new this.TypedArray(e,...t),this.constructor.prototype)}Ti.prototype[kD]=!0;Ti.prototype.toJSON=function(){return`"${eu(this)}"`};Ti.prototype.valueOf=function(){return FD(this)};Ti.prototype.toString=function(){return eu(this)};Ti.prototype[Symbol.toPrimitive]=function(e="default"){switch(e){case"number":return FD(this);case"string":return eu(this);case"default":return RD(this)}return eu(this)};function Kl(...e){return Ti.apply(this,e)}function tu(...e){return Ti.apply(this,e)}function Jd(...e){return Ti.apply(this,e)}Object.setPrototypeOf(Kl.prototype,Object.create(Int32Array.prototype));Object.setPrototypeOf(tu.prototype,Object.create(Uint32Array.prototype));Object.setPrototypeOf(Jd.prototype,Object.create(Uint32Array.prototype));Object.assign(Kl.prototype,Ti.prototype,{constructor:Kl,signed:!0,TypedArray:Int32Array,BigIntArray:BigInt64Array});Object.assign(tu.prototype,Ti.prototype,{constructor:tu,signed:!1,TypedArray:Uint32Array,BigIntArray:BigUint64Array});Object.assign(Jd.prototype,Ti.prototype,{constructor:Jd,signed:!0,TypedArray:Uint32Array,BigIntArray:BigUint64Array});function FD(e){let{buffer:t,byteOffset:n,length:r,signed:i}=e,o=new BigUint64Array(t,n,r),s=i&&o.at(-1)&BigInt(1)<<BigInt(63),a=BigInt(s?1:0),c=BigInt(0);if(s){for(let l of o)a+=~l*(BigInt(1)<<BigInt(32)*c++);a*=BigInt(-1)}else for(let l of o)a+=l*(BigInt(1)<<BigInt(32)*c++);return a}var eu=e=>{if(e.byteLength===8)return`${new e.BigIntArray(e.buffer,e.byteOffset,1)[0]}`;if(!e.signed)return C_(e);let t=new Uint16Array(e.buffer,e.byteOffset,e.byteLength/2);if(new Int16Array([t.at(-1)])[0]>=0)return C_(e);t=t.slice();let r=1;for(let o=0;o<t.length;o++){let s=t[o],a=~s+r;t[o]=a,r&=s===0?1:0}return`-${C_(t)}`},RD=e=>e.byteLength===8?new e.BigIntArray(e.buffer,e.byteOffset,1)[0]:eu(e);function C_(e){let t="",n=new Uint32Array(2),r=new Uint16Array(e.buffer,e.byteOffset,e.byteLength/2),i=new Uint32Array((r=new Uint16Array(r).reverse()).buffer),o=-1,s=r.length-1;do{for(n[0]=r[o=0];o<s;)r[o++]=n[1]=n[0]/10,n[0]=(n[0]-n[1]*10<<16)+r[o];r[o]=n[1]=n[0]/10,n[0]=n[0]-n[1]*10,t=`${n[0]}${t}`}while(i[0]||i[1]||i[2]||i[3]);return t??"0"}var Qd=class e{static new(t,n){switch(n){case!0:return new Kl(t);case!1:return new tu(t)}switch(t.constructor){case Int8Array:case Int16Array:case Int32Array:case BigInt64Array:return new Kl(t)}return t.byteLength===16?new Jd(t):new tu(t)}static signed(t){return new Kl(t)}static unsigned(t){return new tu(t)}static decimal(t){return new Jd(t)}constructor(t,n){return e.new(t,n)}};function De(e){if(typeof e=="bigint"&&(e<Number.MIN_SAFE_INTEGER||e>Number.MAX_SAFE_INTEGER))throw new TypeError(`${e} is not safe to convert to a number.`);return Number(e)}var $D,PD,UD,zD,qD,jD,VD,YD,XD,GD,WD,HD,ZD,JD,QD,KD,tO,eO,nO,rO,iO,oO,st=class e{static isNull(t){return t?.typeId===B.Null}static isInt(t){return t?.typeId===B.Int}static isFloat(t){return t?.typeId===B.Float}static isBinary(t){return t?.typeId===B.Binary}static isLargeBinary(t){return t?.typeId===B.LargeBinary}static isUtf8(t){return t?.typeId===B.Utf8}static isLargeUtf8(t){return t?.typeId===B.LargeUtf8}static isBool(t){return t?.typeId===B.Bool}static isDecimal(t){return t?.typeId===B.Decimal}static isDate(t){return t?.typeId===B.Date}static isTime(t){return t?.typeId===B.Time}static isTimestamp(t){return t?.typeId===B.Timestamp}static isInterval(t){return t?.typeId===B.Interval}static isDuration(t){return t?.typeId===B.Duration}static isList(t){return t?.typeId===B.List}static isStruct(t){return t?.typeId===B.Struct}static isUnion(t){return t?.typeId===B.Union}static isFixedSizeBinary(t){return t?.typeId===B.FixedSizeBinary}static isFixedSizeList(t){return t?.typeId===B.FixedSizeList}static isMap(t){return t?.typeId===B.Map}static isDictionary(t){return t?.typeId===B.Dictionary}static isDenseUnion(t){return e.isUnion(t)&&t.mode===ge.Dense}static isSparseUnion(t){return e.isUnion(t)&&t.mode===ge.Sparse}constructor(t){this.typeId=t}};$D=Symbol.toStringTag;st[$D]=(e=>(e.children=null,e.ArrayType=Array,e.OffsetArrayType=Int32Array,e[Symbol.toStringTag]="DataType"))(st.prototype);var Xn=class extends st{constructor(){super(B.Null)}toString(){return"Null"}};PD=Symbol.toStringTag;Xn[PD]=(e=>e[Symbol.toStringTag]="Null")(Xn.prototype);var Pe=class extends st{constructor(t,n){super(B.Int),this.isSigned=t,this.bitWidth=n}get ArrayType(){switch(this.bitWidth){case 8:return this.isSigned?Int8Array:Uint8Array;case 16:return this.isSigned?Int16Array:Uint16Array;case 32:return this.isSigned?Int32Array:Uint32Array;case 64:return this.isSigned?BigInt64Array:BigUint64Array}throw new Error(`Unrecognized ${this[Symbol.toStringTag]} type`)}toString(){return`${this.isSigned?"I":"Ui"}nt${this.bitWidth}`}};UD=Symbol.toStringTag;Pe[UD]=(e=>(e.isSigned=null,e.bitWidth=null,e[Symbol.toStringTag]="Int"))(Pe.prototype);var bg=class extends Pe{constructor(){super(!0,8)}get ArrayType(){return Int8Array}},wg=class extends Pe{constructor(){super(!0,16)}get ArrayType(){return Int16Array}},eo=class extends Pe{constructor(){super(!0,32)}get ArrayType(){return Int32Array}},vg=class extends Pe{constructor(){super(!0,64)}get ArrayType(){return BigInt64Array}},_g=class extends Pe{constructor(){super(!1,8)}get ArrayType(){return Uint8Array}},Sg=class extends Pe{constructor(){super(!1,16)}get ArrayType(){return Uint16Array}},Ig=class extends Pe{constructor(){super(!1,32)}get ArrayType(){return Uint32Array}},Mg=class extends Pe{constructor(){super(!1,64)}get ArrayType(){return BigUint64Array}};Object.defineProperty(bg.prototype,"ArrayType",{value:Int8Array});Object.defineProperty(wg.prototype,"ArrayType",{value:Int16Array});Object.defineProperty(eo.prototype,"ArrayType",{value:Int32Array});Object.defineProperty(vg.prototype,"ArrayType",{value:BigInt64Array});Object.defineProperty(_g.prototype,"ArrayType",{value:Uint8Array});Object.defineProperty(Sg.prototype,"ArrayType",{value:Uint16Array});Object.defineProperty(Ig.prototype,"ArrayType",{value:Uint32Array});Object.defineProperty(Mg.prototype,"ArrayType",{value:BigUint64Array});var dr=class extends st{constructor(t){super(B.Float),this.precision=t}get ArrayType(){switch(this.precision){case he.HALF:return Uint16Array;case he.SINGLE:return Float32Array;case he.DOUBLE:return Float64Array}throw new Error(`Unrecognized ${this[Symbol.toStringTag]} type`)}toString(){return`Float${this.precision<<5||16}`}};zD=Symbol.toStringTag;dr[zD]=(e=>(e.precision=null,e[Symbol.toStringTag]="Float"))(dr.prototype);var Ag=class extends dr{constructor(){super(he.HALF)}},Tg=class extends dr{constructor(){super(he.SINGLE)}},Eg=class extends dr{constructor(){super(he.DOUBLE)}};Object.defineProperty(Ag.prototype,"ArrayType",{value:Uint16Array});Object.defineProperty(Tg.prototype,"ArrayType",{value:Float32Array});Object.defineProperty(Eg.prototype,"ArrayType",{value:Float64Array});var Jo=class extends st{constructor(){super(B.Binary)}toString(){return"Binary"}};qD=Symbol.toStringTag;Jo[qD]=(e=>(e.ArrayType=Uint8Array,e[Symbol.toStringTag]="Binary"))(Jo.prototype);var Qo=class extends st{constructor(){super(B.LargeBinary)}toString(){return"LargeBinary"}};jD=Symbol.toStringTag;Qo[jD]=(e=>(e.ArrayType=Uint8Array,e.OffsetArrayType=BigInt64Array,e[Symbol.toStringTag]="LargeBinary"))(Qo.prototype);var Ko=class extends st{constructor(){super(B.Utf8)}toString(){return"Utf8"}};VD=Symbol.toStringTag;Ko[VD]=(e=>(e.ArrayType=Uint8Array,e[Symbol.toStringTag]="Utf8"))(Ko.prototype);var ts=class extends st{constructor(){super(B.LargeUtf8)}toString(){return"LargeUtf8"}};YD=Symbol.toStringTag;ts[YD]=(e=>(e.ArrayType=Uint8Array,e.OffsetArrayType=BigInt64Array,e[Symbol.toStringTag]="LargeUtf8"))(ts.prototype);var es=class extends st{constructor(){super(B.Bool)}toString(){return"Bool"}};XD=Symbol.toStringTag;es[XD]=(e=>(e.ArrayType=Uint8Array,e[Symbol.toStringTag]="Bool"))(es.prototype);var ns=class extends st{constructor(t,n,r=128){super(B.Decimal),this.scale=t,this.precision=n,this.bitWidth=r}toString(){return`Decimal[${this.precision}e${this.scale>0?"+":""}${this.scale}]`}};GD=Symbol.toStringTag;ns[GD]=(e=>(e.scale=null,e.precision=null,e.ArrayType=Uint32Array,e[Symbol.toStringTag]="Decimal"))(ns.prototype);var rs=class extends st{constructor(t){super(B.Date),this.unit=t}toString(){return`Date${(this.unit+1)*32}<${Ve[this.unit]}>`}};WD=Symbol.toStringTag;rs[WD]=(e=>(e.unit=null,e.ArrayType=Int32Array,e[Symbol.toStringTag]="Date"))(rs.prototype);var Ei=class extends st{constructor(t,n){super(B.Time),this.unit=t,this.bitWidth=n}toString(){return`Time${this.bitWidth}<${ct[this.unit]}>`}get ArrayType(){switch(this.bitWidth){case 32:return Int32Array;case 64:return BigInt64Array}throw new Error(`Unrecognized ${this[Symbol.toStringTag]} type`)}};HD=Symbol.toStringTag;Ei[HD]=(e=>(e.unit=null,e.bitWidth=null,e[Symbol.toStringTag]="Time"))(Ei.prototype);var is=class extends st{constructor(t,n){super(B.Timestamp),this.unit=t,this.timezone=n}toString(){return`Timestamp<${ct[this.unit]}${this.timezone?`, ${this.timezone}`:""}>`}};ZD=Symbol.toStringTag;is[ZD]=(e=>(e.unit=null,e.timezone=null,e.ArrayType=Int32Array,e[Symbol.toStringTag]="Timestamp"))(is.prototype);var os=class extends st{constructor(t){super(B.Interval),this.unit=t}toString(){return`Interval<${an[this.unit]}>`}};JD=Symbol.toStringTag;os[JD]=(e=>(e.unit=null,e.ArrayType=Int32Array,e[Symbol.toStringTag]="Interval"))(os.prototype);var ss=class extends st{constructor(t){super(B.Duration),this.unit=t}toString(){return`Duration<${ct[this.unit]}>`}};QD=Symbol.toStringTag;ss[QD]=(e=>(e.unit=null,e.ArrayType=BigInt64Array,e[Symbol.toStringTag]="Duration"))(ss.prototype);var Ni=class extends st{constructor(t){super(B.List),this.children=[t]}toString(){return`List<${this.valueType}>`}get valueType(){return this.children[0].type}get valueField(){return this.children[0]}get ArrayType(){return this.valueType.ArrayType}};KD=Symbol.toStringTag;Ni[KD]=(e=>(e.children=null,e[Symbol.toStringTag]="List"))(Ni.prototype);var be=class extends st{constructor(t){super(B.Struct),this.children=t}toString(){return`Struct<{${this.children.map(t=>`${t.name}:${t.type}`).join(", ")}}>`}};tO=Symbol.toStringTag;be[tO]=(e=>(e.children=null,e[Symbol.toStringTag]="Struct"))(be.prototype);var Di=class extends st{constructor(t,n,r){super(B.Union),this.mode=t,this.children=r,this.typeIds=n=Int32Array.from(n),this.typeIdToChildIndex=n.reduce((i,o,s)=>(i[o]=s)&&i||i,Object.create(null))}toString(){return`${this[Symbol.toStringTag]}<${this.children.map(t=>`${t.type}`).join(" | ")}>`}};eO=Symbol.toStringTag;Di[eO]=(e=>(e.mode=null,e.typeIds=null,e.children=null,e.typeIdToChildIndex=null,e.ArrayType=Int8Array,e[Symbol.toStringTag]="Union"))(Di.prototype);var as=class extends st{constructor(t){super(B.FixedSizeBinary),this.byteWidth=t}toString(){return`FixedSizeBinary[${this.byteWidth}]`}};nO=Symbol.toStringTag;as[nO]=(e=>(e.byteWidth=null,e.ArrayType=Uint8Array,e[Symbol.toStringTag]="FixedSizeBinary"))(as.prototype);var Oi=class extends st{constructor(t,n){super(B.FixedSizeList),this.listSize=t,this.children=[n]}get valueType(){return this.children[0].type}get valueField(){return this.children[0]}get ArrayType(){return this.valueType.ArrayType}toString(){return`FixedSizeList[${this.listSize}]<${this.valueType}>`}};rO=Symbol.toStringTag;Oi[rO]=(e=>(e.children=null,e.listSize=null,e[Symbol.toStringTag]="FixedSizeList"))(Oi.prototype);var Bi=class extends st{constructor(t,n=!1){var r,i,o;if(super(B.Map),this.children=[t],this.keysSorted=n,t&&(t.name="entries",!((r=t?.type)===null||r===void 0)&&r.children)){let s=(i=t?.type)===null||i===void 0?void 0:i.children[0];s&&(s.name="key");let a=(o=t?.type)===null||o===void 0?void 0:o.children[1];a&&(a.name="value")}}get keyType(){return this.children[0].type.children[0].type}get valueType(){return this.children[0].type.children[1].type}get childType(){return this.children[0].type}toString(){return`Map<{${this.children[0].type.children.map(t=>`${t.name}:${t.type}`).join(", ")}}>`}};iO=Symbol.toStringTag;Bi[iO]=(e=>(e.children=null,e.keysSorted=null,e[Symbol.toStringTag]="Map_"))(Bi.prototype);var Hz=(e=>()=>++e)(-1),Dr=class extends st{constructor(t,n,r,i){super(B.Dictionary),this.indices=n,this.dictionary=t,this.isOrdered=i||!1,this.id=r==null?Hz():De(r)}get children(){return this.dictionary.children}get valueType(){return this.dictionary}get ArrayType(){return this.dictionary.ArrayType}toString(){return`Dictionary<${this.indices}, ${this.dictionary}>`}};oO=Symbol.toStringTag;Dr[oO]=(e=>(e.id=null,e.indices=null,e.isOrdered=null,e.dictionary=null,e[Symbol.toStringTag]="Dictionary"))(Dr.prototype);function Or(e){let t=e;switch(e.typeId){case B.Decimal:return e.bitWidth/32;case B.Timestamp:return 2;case B.Date:return 1+t.unit;case B.Interval:return 1+t.unit;case B.FixedSizeList:return t.listSize;case B.FixedSizeBinary:return t.byteWidth;default:return 1}}var mt=class{visitMany(t,...n){return t.map((r,i)=>this.visit(r,...n.map(o=>o[i])))}visit(...t){return this.getVisitFn(t[0],!1).apply(this,t)}getVisitFn(t,n=!0){return Zz(this,t,n)}getVisitFnByTypeId(t,n=!0){return nu(this,t,n)}visitNull(t,...n){return null}visitBool(t,...n){return null}visitInt(t,...n){return null}visitFloat(t,...n){return null}visitUtf8(t,...n){return null}visitLargeUtf8(t,...n){return null}visitBinary(t,...n){return null}visitLargeBinary(t,...n){return null}visitFixedSizeBinary(t,...n){return null}visitDate(t,...n){return null}visitTimestamp(t,...n){return null}visitTime(t,...n){return null}visitDecimal(t,...n){return null}visitList(t,...n){return null}visitStruct(t,...n){return null}visitUnion(t,...n){return null}visitDictionary(t,...n){return null}visitInterval(t,...n){return null}visitDuration(t,...n){return null}visitFixedSizeList(t,...n){return null}visitMap(t,...n){return null}};function Zz(e,t,n=!0){return typeof t=="number"?nu(e,t,n):typeof t=="string"&&t in B?nu(e,B[t],n):t&&t instanceof st?nu(e,sO(t),n):t?.type&&t.type instanceof st?nu(e,sO(t.type),n):nu(e,B.NONE,n)}function nu(e,t,n=!0){let r=null;switch(t){case B.Null:r=e.visitNull;break;case B.Bool:r=e.visitBool;break;case B.Int:r=e.visitInt;break;case B.Int8:r=e.visitInt8||e.visitInt;break;case B.Int16:r=e.visitInt16||e.visitInt;break;case B.Int32:r=e.visitInt32||e.visitInt;break;case B.Int64:r=e.visitInt64||e.visitInt;break;case B.Uint8:r=e.visitUint8||e.visitInt;break;case B.Uint16:r=e.visitUint16||e.visitInt;break;case B.Uint32:r=e.visitUint32||e.visitInt;break;case B.Uint64:r=e.visitUint64||e.visitInt;break;case B.Float:r=e.visitFloat;break;case B.Float16:r=e.visitFloat16||e.visitFloat;break;case B.Float32:r=e.visitFloat32||e.visitFloat;break;case B.Float64:r=e.visitFloat64||e.visitFloat;break;case B.Utf8:r=e.visitUtf8;break;case B.LargeUtf8:r=e.visitLargeUtf8;break;case B.Binary:r=e.visitBinary;break;case B.LargeBinary:r=e.visitLargeBinary;break;case B.FixedSizeBinary:r=e.visitFixedSizeBinary;break;case B.Date:r=e.visitDate;break;case B.DateDay:r=e.visitDateDay||e.visitDate;break;case B.DateMillisecond:r=e.visitDateMillisecond||e.visitDate;break;case B.Timestamp:r=e.visitTimestamp;break;case B.TimestampSecond:r=e.visitTimestampSecond||e.visitTimestamp;break;case B.TimestampMillisecond:r=e.visitTimestampMillisecond||e.visitTimestamp;break;case B.TimestampMicrosecond:r=e.visitTimestampMicrosecond||e.visitTimestamp;break;case B.TimestampNanosecond:r=e.visitTimestampNanosecond||e.visitTimestamp;break;case B.Time:r=e.visitTime;break;case B.TimeSecond:r=e.visitTimeSecond||e.visitTime;break;case B.TimeMillisecond:r=e.visitTimeMillisecond||e.visitTime;break;case B.TimeMicrosecond:r=e.visitTimeMicrosecond||e.visitTime;break;case B.TimeNanosecond:r=e.visitTimeNanosecond||e.visitTime;break;case B.Decimal:r=e.visitDecimal;break;case B.List:r=e.visitList;break;case B.Struct:r=e.visitStruct;break;case B.Union:r=e.visitUnion;break;case B.DenseUnion:r=e.visitDenseUnion||e.visitUnion;break;case B.SparseUnion:r=e.visitSparseUnion||e.visitUnion;break;case B.Dictionary:r=e.visitDictionary;break;case B.Interval:r=e.visitInterval;break;case B.IntervalDayTime:r=e.visitIntervalDayTime||e.visitInterval;break;case B.IntervalYearMonth:r=e.visitIntervalYearMonth||e.visitInterval;break;case B.Duration:r=e.visitDuration;break;case B.DurationSecond:r=e.visitDurationSecond||e.visitDuration;break;case B.DurationMillisecond:r=e.visitDurationMillisecond||e.visitDuration;break;case B.DurationMicrosecond:r=e.visitDurationMicrosecond||e.visitDuration;break;case B.DurationNanosecond:r=e.visitDurationNanosecond||e.visitDuration;break;case B.FixedSizeList:r=e.visitFixedSizeList;break;case B.Map:r=e.visitMap;break}if(typeof r=="function")return r;if(!n)return()=>null;throw new Error(`Unrecognized type '${B[t]}'`)}function sO(e){switch(e.typeId){case B.Null:return B.Null;case B.Int:{let{bitWidth:t,isSigned:n}=e;switch(t){case 8:return n?B.Int8:B.Uint8;case 16:return n?B.Int16:B.Uint16;case 32:return n?B.Int32:B.Uint32;case 64:return n?B.Int64:B.Uint64}return B.Int}case B.Float:switch(e.precision){case he.HALF:return B.Float16;case he.SINGLE:return B.Float32;case he.DOUBLE:return B.Float64}return B.Float;case B.Binary:return B.Binary;case B.LargeBinary:return B.LargeBinary;case B.Utf8:return B.Utf8;case B.LargeUtf8:return B.LargeUtf8;case B.Bool:return B.Bool;case B.Decimal:return B.Decimal;case B.Time:switch(e.unit){case ct.SECOND:return B.TimeSecond;case ct.MILLISECOND:return B.TimeMillisecond;case ct.MICROSECOND:return B.TimeMicrosecond;case ct.NANOSECOND:return B.TimeNanosecond}return B.Time;case B.Timestamp:switch(e.unit){case ct.SECOND:return B.TimestampSecond;case ct.MILLISECOND:return B.TimestampMillisecond;case ct.MICROSECOND:return B.TimestampMicrosecond;case ct.NANOSECOND:return B.TimestampNanosecond}return B.Timestamp;case B.Date:switch(e.unit){case Ve.DAY:return B.DateDay;case Ve.MILLISECOND:return B.DateMillisecond}return B.Date;case B.Interval:switch(e.unit){case an.DAY_TIME:return B.IntervalDayTime;case an.YEAR_MONTH:return B.IntervalYearMonth}return B.Interval;case B.Duration:switch(e.unit){case ct.SECOND:return B.DurationSecond;case ct.MILLISECOND:return B.DurationMillisecond;case ct.MICROSECOND:return B.DurationMicrosecond;case ct.NANOSECOND:return B.DurationNanosecond}return B.Duration;case B.Map:return B.Map;case B.List:return B.List;case B.Struct:return B.Struct;case B.Union:switch(e.mode){case ge.Dense:return B.DenseUnion;case ge.Sparse:return B.SparseUnion}return B.Union;case B.FixedSizeBinary:return B.FixedSizeBinary;case B.FixedSizeList:return B.FixedSizeList;case B.Dictionary:return B.Dictionary}throw new Error(`Unrecognized type '${B[e.typeId]}'`)}mt.prototype.visitInt8=null;mt.prototype.visitInt16=null;mt.prototype.visitInt32=null;mt.prototype.visitInt64=null;mt.prototype.visitUint8=null;mt.prototype.visitUint16=null;mt.prototype.visitUint32=null;mt.prototype.visitUint64=null;mt.prototype.visitFloat16=null;mt.prototype.visitFloat32=null;mt.prototype.visitFloat64=null;mt.prototype.visitDateDay=null;mt.prototype.visitDateMillisecond=null;mt.prototype.visitTimestampSecond=null;mt.prototype.visitTimestampMillisecond=null;mt.prototype.visitTimestampMicrosecond=null;mt.prototype.visitTimestampNanosecond=null;mt.prototype.visitTimeSecond=null;mt.prototype.visitTimeMillisecond=null;mt.prototype.visitTimeMicrosecond=null;mt.prototype.visitTimeNanosecond=null;mt.prototype.visitDenseUnion=null;mt.prototype.visitSparseUnion=null;mt.prototype.visitIntervalDayTime=null;mt.prototype.visitIntervalYearMonth=null;mt.prototype.visitDuration=null;mt.prototype.visitDurationSecond=null;mt.prototype.visitDurationMillisecond=null;mt.prototype.visitDurationMicrosecond=null;mt.prototype.visitDurationNanosecond=null;var F_={};Ir(F_,{float64ToUint16:()=>Kd,uint16ToFloat64:()=>Ng});var aO=new Float64Array(1),ru=new Uint32Array(aO.buffer);function Ng(e){let t=(e&31744)>>10,n=(e&1023)/1024,r=Math.pow(-1,(e&32768)>>15);switch(t){case 31:return r*(n?Number.NaN:1/0);case 0:return r*(n?6103515625e-14*n:0)}return r*Math.pow(2,t-15)*(1+n)}function Kd(e){if(e!==e)return 32256;aO[0]=e;let t=(ru[1]&2147483648)>>16&65535,n=ru[1]&2146435072,r=0;return n>=1089470464?ru[0]>0?n=31744:(n=(n&2080374784)>>16,r=(ru[1]&1048575)>>10):n<=1056964608?(r=1048576+(ru[1]&1048575),r=1048576+(r<<(n>>20)-998)>>21,n=0):(n=n-1056964608>>10,r=(ru[1]&1048575)+512>>10),t|n|r&65535}var vt=class extends mt{};function Tt(e){return(t,n,r)=>{if(t.setValid(n,r!=null))return e(t,n,r)}}var Jz=(e,t,n)=>{e[t]=Math.trunc(n/864e5)},R_=(e,t,n)=>{e[t]=Math.trunc(n%4294967296),e[t+1]=Math.trunc(n/4294967296)},Qz=(e,t,n)=>{e[t]=Math.trunc(n*1e3%4294967296),e[t+1]=Math.trunc(n*1e3/4294967296)},Kz=(e,t,n)=>{e[t]=Math.trunc(n*1e6%4294967296),e[t+1]=Math.trunc(n*1e6/4294967296)},cO=(e,t,n,r)=>{if(n+1<t.length){let i=De(t[n]),o=De(t[n+1]);e.set(r.subarray(0,o-i),i)}},tq=({offset:e,values:t},n,r)=>{let i=e+n;r?t[i>>3]|=1<<i%8:t[i>>3]&=~(1<<i%8)},cs=({values:e},t,n)=>{e[t]=n},$_=({values:e},t,n)=>{e[t]=n},lO=({values:e},t,n)=>{e[t]=Kd(n)},eq=(e,t,n)=>{switch(e.type.precision){case he.HALF:return lO(e,t,n);case he.SINGLE:case he.DOUBLE:return $_(e,t,n)}},Dg=({values:e},t,n)=>{Jz(e,t,n.valueOf())},Og=({values:e},t,n)=>{R_(e,t*2,n.valueOf())},P_=({stride:e,values:t},n,r)=>{t.set(r.subarray(0,e),e*n)},uO=({values:e,valueOffsets:t},n,r)=>cO(e,t,n,r),fO=({values:e,valueOffsets:t},n,r)=>cO(e,t,n,Zi(r)),U_=(e,t,n)=>{e.type.unit===Ve.DAY?Dg(e,t,n):Og(e,t,n)},Bg=({values:e},t,n)=>R_(e,t*2,n/1e3),Lg=({values:e},t,n)=>R_(e,t*2,n),Cg=({values:e},t,n)=>Qz(e,t*2,n),kg=({values:e},t,n)=>Kz(e,t*2,n),z_=(e,t,n)=>{switch(e.type.unit){case ct.SECOND:return Bg(e,t,n);case ct.MILLISECOND:return Lg(e,t,n);case ct.MICROSECOND:return Cg(e,t,n);case ct.NANOSECOND:return kg(e,t,n)}},Fg=({values:e},t,n)=>{e[t]=n},Rg=({values:e},t,n)=>{e[t]=n},$g=({values:e},t,n)=>{e[t]=n},Pg=({values:e},t,n)=>{e[t]=n},q_=(e,t,n)=>{switch(e.type.unit){case ct.SECOND:return Fg(e,t,n);case ct.MILLISECOND:return Rg(e,t,n);case ct.MICROSECOND:return $g(e,t,n);case ct.NANOSECOND:return Pg(e,t,n)}},j_=({values:e,stride:t},n,r)=>{e.set(r.subarray(0,t),t*n)},nq=(e,t,n)=>{let r=e.children[0],i=e.valueOffsets,o=wn.getVisitFn(r);if(Array.isArray(n))for(let s=-1,a=i[t],c=i[t+1];a<c;)o(r,a++,n[++s]);else for(let s=-1,a=i[t],c=i[t+1];a<c;)o(r,a++,n.get(++s))},rq=(e,t,n)=>{let r=e.children[0],{valueOffsets:i}=e,o=wn.getVisitFn(r),{[t]:s,[t+1]:a}=i,c=n instanceof Map?n.entries():Object.entries(n);for(let l of c)if(o(r,s,l),++s>=a)break},iq=(e,t)=>(n,r,i,o)=>r&&n(r,e,t[o]),oq=(e,t)=>(n,r,i,o)=>r&&n(r,e,t.get(o)),sq=(e,t)=>(n,r,i,o)=>r&&n(r,e,t.get(i.name)),aq=(e,t)=>(n,r,i,o)=>r&&n(r,e,t[i.name]),cq=(e,t,n)=>{let r=e.type.children.map(o=>wn.getVisitFn(o.type)),i=n instanceof Map?sq(t,n):n instanceof Xt?oq(t,n):Array.isArray(n)?iq(t,n):aq(t,n);e.type.children.forEach((o,s)=>i(r[s],e.children[s],o,s))},lq=(e,t,n)=>{e.type.mode===ge.Dense?dO(e,t,n):hO(e,t,n)},dO=(e,t,n)=>{let r=e.type.typeIdToChildIndex[e.typeIds[t]],i=e.children[r];wn.visit(i,e.valueOffsets[t],n)},hO=(e,t,n)=>{let r=e.type.typeIdToChildIndex[e.typeIds[t]],i=e.children[r];wn.visit(i,t,n)},uq=(e,t,n)=>{var r;(r=e.dictionary)===null||r===void 0||r.set(e.values[t],n)},V_=(e,t,n)=>{e.type.unit===an.DAY_TIME?Ug(e,t,n):zg(e,t,n)},Ug=({values:e},t,n)=>{e.set(n.subarray(0,2),2*t)},zg=({values:e},t,n)=>{e[t]=n[0]*12+n[1]%12},qg=({values:e},t,n)=>{e[t]=n},jg=({values:e},t,n)=>{e[t]=n},Vg=({values:e},t,n)=>{e[t]=n},Yg=({values:e},t,n)=>{e[t]=n},Y_=(e,t,n)=>{switch(e.type.unit){case ct.SECOND:return qg(e,t,n);case ct.MILLISECOND:return jg(e,t,n);case ct.MICROSECOND:return Vg(e,t,n);case ct.NANOSECOND:return Yg(e,t,n)}},fq=(e,t,n)=>{let{stride:r}=e,i=e.children[0],o=wn.getVisitFn(i);if(Array.isArray(n))for(let s=-1,a=t*r;++s<r;)o(i,a+s,n[s]);else for(let s=-1,a=t*r;++s<r;)o(i,a+s,n.get(s))};vt.prototype.visitBool=Tt(tq);vt.prototype.visitInt=Tt(cs);vt.prototype.visitInt8=Tt(cs);vt.prototype.visitInt16=Tt(cs);vt.prototype.visitInt32=Tt(cs);vt.prototype.visitInt64=Tt(cs);vt.prototype.visitUint8=Tt(cs);vt.prototype.visitUint16=Tt(cs);vt.prototype.visitUint32=Tt(cs);vt.prototype.visitUint64=Tt(cs);vt.prototype.visitFloat=Tt(eq);vt.prototype.visitFloat16=Tt(lO);vt.prototype.visitFloat32=Tt($_);vt.prototype.visitFloat64=Tt($_);vt.prototype.visitUtf8=Tt(fO);vt.prototype.visitLargeUtf8=Tt(fO);vt.prototype.visitBinary=Tt(uO);vt.prototype.visitLargeBinary=Tt(uO);vt.prototype.visitFixedSizeBinary=Tt(P_);vt.prototype.visitDate=Tt(U_);vt.prototype.visitDateDay=Tt(Dg);vt.prototype.visitDateMillisecond=Tt(Og);vt.prototype.visitTimestamp=Tt(z_);vt.prototype.visitTimestampSecond=Tt(Bg);vt.prototype.visitTimestampMillisecond=Tt(Lg);vt.prototype.visitTimestampMicrosecond=Tt(Cg);vt.prototype.visitTimestampNanosecond=Tt(kg);vt.prototype.visitTime=Tt(q_);vt.prototype.visitTimeSecond=Tt(Fg);vt.prototype.visitTimeMillisecond=Tt(Rg);vt.prototype.visitTimeMicrosecond=Tt($g);vt.prototype.visitTimeNanosecond=Tt(Pg);vt.prototype.visitDecimal=Tt(j_);vt.prototype.visitList=Tt(nq);vt.prototype.visitStruct=Tt(cq);vt.prototype.visitUnion=Tt(lq);vt.prototype.visitDenseUnion=Tt(dO);vt.prototype.visitSparseUnion=Tt(hO);vt.prototype.visitDictionary=Tt(uq);vt.prototype.visitInterval=Tt(V_);vt.prototype.visitIntervalDayTime=Tt(Ug);vt.prototype.visitIntervalYearMonth=Tt(zg);vt.prototype.visitDuration=Tt(Y_);vt.prototype.visitDurationSecond=Tt(qg);vt.prototype.visitDurationMillisecond=Tt(jg);vt.prototype.visitDurationMicrosecond=Tt(Vg);vt.prototype.visitDurationNanosecond=Tt(Yg);vt.prototype.visitFixedSizeList=Tt(fq);vt.prototype.visitMap=Tt(rq);var wn=new vt;var Li=Symbol.for("parent"),iu=Symbol.for("rowIndex"),wa=class{constructor(t,n){return this[Li]=t,this[iu]=n,new Proxy(this,new G_)}toArray(){return Object.values(this.toJSON())}toJSON(){let t=this[iu],n=this[Li],r=n.type.children,i={};for(let o=-1,s=r.length;++o<s;)i[r[o].name]=Ye.visit(n.children[o],t);return i}toString(){return`{${[...this].map(([t,n])=>`${Ai(t)}: ${Ai(n)}`).join(", ")}}`}[Symbol.for("nodejs.util.inspect.custom")](){return this.toString()}[Symbol.iterator](){return new X_(this[Li],this[iu])}},X_=class{constructor(t,n){this.childIndex=0,this.children=t.children,this.rowIndex=n,this.childFields=t.type.children,this.numChildren=this.childFields.length}[Symbol.iterator](){return this}next(){let t=this.childIndex;return t<this.numChildren?(this.childIndex=t+1,{done:!1,value:[this.childFields[t].name,Ye.visit(this.children[t],this.rowIndex)]}):{done:!0,value:null}}};Object.defineProperties(wa.prototype,{[Symbol.toStringTag]:{enumerable:!1,configurable:!1,value:"Row"},[Li]:{writable:!0,enumerable:!1,configurable:!1,value:null},[iu]:{writable:!0,enumerable:!1,configurable:!1,value:-1}});var G_=class{isExtensible(){return!1}deleteProperty(){return!1}preventExtensions(){return!0}ownKeys(t){return t[Li].type.children.map(n=>n.name)}has(t,n){return t[Li].type.children.findIndex(r=>r.name===n)!==-1}getOwnPropertyDescriptor(t,n){if(t[Li].type.children.findIndex(r=>r.name===n)!==-1)return{writable:!0,enumerable:!0,configurable:!0}}get(t,n){if(Reflect.has(t,n))return t[n];let r=t[Li].type.children.findIndex(i=>i.name===n);if(r!==-1){let i=Ye.visit(t[Li].children[r],t[iu]);return Reflect.set(t,n,i),i}}set(t,n,r){let i=t[Li].type.children.findIndex(o=>o.name===n);return i!==-1?(wn.visit(t[Li].children[i],t[iu],r),Reflect.set(t,n,r)):Reflect.has(t,n)||typeof n=="symbol"?Reflect.set(t,n,r):!1}};var yt=class extends mt{};function It(e){return(t,n)=>t.getValid(n)?e(t,n):null}var dq=(e,t)=>864e5*e[t],W_=(e,t)=>4294967296*e[t+1]+(e[t]>>>0),hq=(e,t)=>4294967296*(e[t+1]/1e3)+(e[t]>>>0)/1e3,pq=(e,t)=>4294967296*(e[t+1]/1e6)+(e[t]>>>0)/1e6,pO=e=>new Date(e),mq=(e,t)=>pO(dq(e,t)),yq=(e,t)=>pO(W_(e,t)),gq=(e,t)=>null,mO=(e,t,n)=>{if(n+1>=t.length)return null;let r=De(t[n]),i=De(t[n+1]);return e.subarray(r,i)},xq=({offset:e,values:t},n)=>{let r=e+n;return(t[r>>3]&1<<r%8)!==0},yO=({values:e},t)=>mq(e,t),gO=({values:e},t)=>yq(e,t*2),va=({stride:e,values:t},n)=>t[e*n],bq=({stride:e,values:t},n)=>Ng(t[e*n]),xO=({values:e},t)=>e[t],wq=({stride:e,values:t},n)=>t.subarray(e*n,e*(n+1)),bO=({values:e,valueOffsets:t},n)=>mO(e,t,n),wO=({values:e,valueOffsets:t},n)=>{let r=mO(e,t,n);return r!==null?Fd(r):null},vq=({values:e},t)=>e[t],_q=({type:e,values:t},n)=>e.precision!==he.HALF?t[n]:Ng(t[n]),Sq=(e,t)=>e.type.unit===Ve.DAY?yO(e,t):gO(e,t),vO=({values:e},t)=>1e3*W_(e,t*2),_O=({values:e},t)=>W_(e,t*2),SO=({values:e},t)=>hq(e,t*2),IO=({values:e},t)=>pq(e,t*2),Iq=(e,t)=>{switch(e.type.unit){case ct.SECOND:return vO(e,t);case ct.MILLISECOND:return _O(e,t);case ct.MICROSECOND:return SO(e,t);case ct.NANOSECOND:return IO(e,t)}},MO=({values:e},t)=>e[t],AO=({values:e},t)=>e[t],TO=({values:e},t)=>e[t],EO=({values:e},t)=>e[t],Mq=(e,t)=>{switch(e.type.unit){case ct.SECOND:return MO(e,t);case ct.MILLISECOND:return AO(e,t);case ct.MICROSECOND:return TO(e,t);case ct.NANOSECOND:return EO(e,t)}},Aq=({values:e,stride:t},n)=>Qd.decimal(e.subarray(t*n,t*(n+1))),Tq=(e,t)=>{let{valueOffsets:n,stride:r,children:i}=e,{[t*r]:o,[t*r+1]:s}=n,c=i[0].slice(o,s-o);return new Xt([c])},Eq=(e,t)=>{let{valueOffsets:n,children:r}=e,{[t]:i,[t+1]:o}=n,s=r[0];return new no(s.slice(i,o-i))},Nq=(e,t)=>new wa(e,t),Dq=(e,t)=>e.type.mode===ge.Dense?NO(e,t):DO(e,t),NO=(e,t)=>{let n=e.type.typeIdToChildIndex[e.typeIds[t]],r=e.children[n];return Ye.visit(r,e.valueOffsets[t])},DO=(e,t)=>{let n=e.type.typeIdToChildIndex[e.typeIds[t]],r=e.children[n];return Ye.visit(r,t)},Oq=(e,t)=>{var n;return(n=e.dictionary)===null||n===void 0?void 0:n.get(e.values[t])},Bq=(e,t)=>e.type.unit===an.DAY_TIME?OO(e,t):BO(e,t),OO=({values:e},t)=>e.subarray(2*t,2*(t+1)),BO=({values:e},t)=>{let n=e[t],r=new Int32Array(2);return r[0]=Math.trunc(n/12),r[1]=Math.trunc(n%12),r},LO=({values:e},t)=>e[t],CO=({values:e},t)=>e[t],kO=({values:e},t)=>e[t],FO=({values:e},t)=>e[t],Lq=(e,t)=>{switch(e.type.unit){case ct.SECOND:return LO(e,t);case ct.MILLISECOND:return CO(e,t);case ct.MICROSECOND:return kO(e,t);case ct.NANOSECOND:return FO(e,t)}},Cq=(e,t)=>{let{stride:n,children:r}=e,o=r[0].slice(t*n,n);return new Xt([o])};yt.prototype.visitNull=It(gq);yt.prototype.visitBool=It(xq);yt.prototype.visitInt=It(vq);yt.prototype.visitInt8=It(va);yt.prototype.visitInt16=It(va);yt.prototype.visitInt32=It(va);yt.prototype.visitInt64=It(xO);yt.prototype.visitUint8=It(va);yt.prototype.visitUint16=It(va);yt.prototype.visitUint32=It(va);yt.prototype.visitUint64=It(xO);yt.prototype.visitFloat=It(_q);yt.prototype.visitFloat16=It(bq);yt.prototype.visitFloat32=It(va);yt.prototype.visitFloat64=It(va);yt.prototype.visitUtf8=It(wO);yt.prototype.visitLargeUtf8=It(wO);yt.prototype.visitBinary=It(bO);yt.prototype.visitLargeBinary=It(bO);yt.prototype.visitFixedSizeBinary=It(wq);yt.prototype.visitDate=It(Sq);yt.prototype.visitDateDay=It(yO);yt.prototype.visitDateMillisecond=It(gO);yt.prototype.visitTimestamp=It(Iq);yt.prototype.visitTimestampSecond=It(vO);yt.prototype.visitTimestampMillisecond=It(_O);yt.prototype.visitTimestampMicrosecond=It(SO);yt.prototype.visitTimestampNanosecond=It(IO);yt.prototype.visitTime=It(Mq);yt.prototype.visitTimeSecond=It(MO);yt.prototype.visitTimeMillisecond=It(AO);yt.prototype.visitTimeMicrosecond=It(TO);yt.prototype.visitTimeNanosecond=It(EO);yt.prototype.visitDecimal=It(Aq);yt.prototype.visitList=It(Tq);yt.prototype.visitStruct=It(Nq);yt.prototype.visitUnion=It(Dq);yt.prototype.visitDenseUnion=It(NO);yt.prototype.visitSparseUnion=It(DO);yt.prototype.visitDictionary=It(Oq);yt.prototype.visitInterval=It(Bq);yt.prototype.visitIntervalDayTime=It(OO);yt.prototype.visitIntervalYearMonth=It(BO);yt.prototype.visitDuration=It(Lq);yt.prototype.visitDurationSecond=It(LO);yt.prototype.visitDurationMillisecond=It(CO);yt.prototype.visitDurationMicrosecond=It(kO);yt.prototype.visitDurationNanosecond=It(FO);yt.prototype.visitFixedSizeList=It(Cq);yt.prototype.visitMap=It(Eq);var Ye=new yt;var Zr=Symbol.for("keys"),ou=Symbol.for("vals"),no=class{constructor(t){return this[Zr]=new Xt([t.children[0]]).memoize(),this[ou]=t.children[1],new Proxy(this,new Z_)}[Symbol.iterator](){return new H_(this[Zr],this[ou])}get size(){return this[Zr].length}toArray(){return Object.values(this.toJSON())}toJSON(){let t=this[Zr],n=this[ou],r={};for(let i=-1,o=t.length;++i<o;)r[t.get(i)]=Ye.visit(n,i);return r}toString(){return`{${[...this].map(([t,n])=>`${Ai(t)}: ${Ai(n)}`).join(", ")}}`}[Symbol.for("nodejs.util.inspect.custom")](){return this.toString()}},H_=class{constructor(t,n){this.keys=t,this.vals=n,this.keyIndex=0,this.numKeys=t.length}[Symbol.iterator](){return this}next(){let t=this.keyIndex;return t===this.numKeys?{done:!0,value:null}:(this.keyIndex++,{done:!1,value:[this.keys.get(t),Ye.visit(this.vals,t)]})}},Z_=class{isExtensible(){return!1}deleteProperty(){return!1}preventExtensions(){return!0}ownKeys(t){return t[Zr].toArray().map(String)}has(t,n){return t[Zr].includes(n)}getOwnPropertyDescriptor(t,n){if(t[Zr].indexOf(n)!==-1)return{writable:!0,enumerable:!0,configurable:!0}}get(t,n){if(Reflect.has(t,n))return t[n];let r=t[Zr].indexOf(n);if(r!==-1){let i=Ye.visit(Reflect.get(t,ou),r);return Reflect.set(t,n,i),i}}set(t,n,r){let i=t[Zr].indexOf(n);return i!==-1?(wn.visit(Reflect.get(t,ou),i,r),Reflect.set(t,n,r)):Reflect.has(t,n)?Reflect.set(t,n,r):!1}};Object.defineProperties(no.prototype,{[Symbol.toStringTag]:{enumerable:!1,configurable:!1,value:"Row"},[Zr]:{writable:!0,enumerable:!1,configurable:!1,value:null},[ou]:{writable:!0,enumerable:!1,configurable:!1,value:null}});function kq(e,t,n){let r=e.length,i=t>-1?t:r+t%r;return n?n(e,i):i}var RO;function th(e,t,n,r){let{length:i=0}=e,o=typeof t!="number"?0:t,s=typeof n!="number"?i:n;return o<0&&(o=(o%i+i)%i),s<0&&(s=(s%i+i)%i),s<o&&(RO=o,o=s,s=RO),s>i&&(s=i),r?r(e,o,s):[o,s]}var $O=e=>e!==e;function _a(e){if(typeof e!=="object"||e===null)return $O(e)?$O:n=>n===e;if(e instanceof Date){let n=e.valueOf();return r=>r instanceof Date?r.valueOf()===n:!1}return ArrayBuffer.isView(e)?n=>n?N_(e,n):!1:e instanceof Map?Rq(e):Array.isArray(e)?Fq(e):e instanceof Xt?$q(e):Pq(e,!0)}function Fq(e){let t=[];for(let n=-1,r=e.length;++n<r;)t[n]=_a(e[n]);return Xg(t)}function Rq(e){let t=-1,n=[];for(let r of e.values())n[++t]=_a(r);return Xg(n)}function $q(e){let t=[];for(let n=-1,r=e.length;++n<r;)t[n]=_a(e.get(n));return Xg(t)}function Pq(e,t=!1){let n=Object.keys(e);if(!t&&n.length===0)return()=>!1;let r=[];for(let i=-1,o=n.length;++i<o;)r[i]=_a(e[n[i]]);return Xg(r,n)}function Xg(e,t){return n=>{if(!n||typeof n!="object")return!1;switch(n.constructor){case Array:return Uq(e,n);case Map:return PO(e,n,n.keys());case no:case wa:case Object:case void 0:return PO(e,n,t||Object.keys(n))}return n instanceof Xt?zq(e,n):!1}}function Uq(e,t){let n=e.length;if(t.length!==n)return!1;for(let r=-1;++r<n;)if(!e[r](t[r]))return!1;return!0}function zq(e,t){let n=e.length;if(t.length!==n)return!1;for(let r=-1;++r<n;)if(!e[r](t.get(r)))return!1;return!0}function PO(e,t,n){let r=n[Symbol.iterator](),i=t instanceof Map?t.keys():Object.keys(t)[Symbol.iterator](),o=t instanceof Map?t.values():Object.values(t)[Symbol.iterator](),s=0,a=e.length,c=o.next(),l=r.next(),u=i.next();for(;s<a&&!l.done&&!u.done&&!c.done&&!(l.value!==u.value||!e[s](c.value));++s,l=r.next(),u=i.next(),c=o.next());return s===a&&l.done&&u.done&&c.done?!0:(r.return&&r.return(),i.return&&i.return(),o.return&&o.return(),!1)}var Q_={};Ir(Q_,{BitIterator:()=>_c,getBit:()=>UO,getBool:()=>Wg,packBools:()=>Ic,popcnt_array:()=>zO,popcnt_bit_range:()=>eh,popcnt_uint32:()=>Gg,setBool:()=>qq,truncateBitmap:()=>Sc});function Wg(e,t,n,r){return(n&1<<r)!==0}function UO(e,t,n,r){return(n&1<<r)>>r}function qq(e,t,n){return n?!!(e[t>>3]|=1<<t%8)||!0:!(e[t>>3]&=~(1<<t%8))&&!1}function Sc(e,t,n){let r=n.byteLength+7&-8;if(e>0||n.byteLength<r){let i=new Uint8Array(r);return i.set(e%8===0?n.subarray(e>>3):Ic(new _c(n,e,t,null,Wg)).subarray(0,r)),i}return n}function Ic(e){let t=[],n=0,r=0,i=0;for(let s of e)s&&(i|=1<<r),++r===8&&(t[n++]=i,i=r=0);(n===0||r>0)&&(t[n++]=i);let o=new Uint8Array(t.length+7&-8);return o.set(t),o}var _c=class{constructor(t,n,r,i,o){this.bytes=t,this.length=r,this.context=i,this.get=o,this.bit=n%8,this.byteIndex=n>>3,this.byte=t[this.byteIndex++],this.index=0}next(){return this.index<this.length?(this.bit===8&&(this.bit=0,this.byte=this.bytes[this.byteIndex++]),{value:this.get(this.context,this.index++,this.byte,this.bit++)}):{done:!0,value:null}}[Symbol.iterator](){return this}};function eh(e,t,n){if(n-t<=0)return 0;if(n-t<8){let o=0;for(let s of new _c(e,t,n-t,e,UO))o+=s;return o}let r=n>>3<<3,i=t+(t%8===0?0:8-t%8);return eh(e,t,i)+eh(e,r,n)+zO(e,i>>3,r-i>>3)}function zO(e,t,n){let r=0,i=Math.trunc(t),o=new DataView(e.buffer,e.byteOffset,e.byteLength),s=n===void 0?e.byteLength:i+n;for(;s-i>=4;)r+=Gg(o.getUint32(i)),i+=4;for(;s-i>=2;)r+=Gg(o.getUint16(i)),i+=2;for(;s-i>=1;)r+=Gg(o.getUint8(i)),i+=1;return r}function Gg(e){let t=Math.trunc(e);return t=t-(t>>>1&1431655765),t=(t&858993459)+(t>>>2&858993459),(t+(t>>>4)&252645135)*16843009>>>24}var jq=-1,te=class e{get typeId(){return this.type.typeId}get ArrayType(){return this.type.ArrayType}get buffers(){return[this.valueOffsets,this.values,this.nullBitmap,this.typeIds]}get nullable(){if(this._nullCount!==0){let{type:t}=this;return st.isSparseUnion(t)?this.children.some(n=>n.nullable):st.isDenseUnion(t)?this.children.some(n=>n.nullable):this.nullBitmap&&this.nullBitmap.byteLength>0}return!0}get byteLength(){let t=0,{valueOffsets:n,values:r,nullBitmap:i,typeIds:o}=this;return n&&(t+=n.byteLength),r&&(t+=r.byteLength),i&&(t+=i.byteLength),o&&(t+=o.byteLength),this.children.reduce((s,a)=>s+a.byteLength,t)}get nullCount(){if(st.isUnion(this.type))return this.children.reduce((r,i)=>r+i.nullCount,0);let t=this._nullCount,n;return t<=jq&&(n=this.nullBitmap)&&(this._nullCount=t=this.length-eh(n,this.offset,this.offset+this.length)),t}constructor(t,n,r,i,o,s=[],a){this.type=t,this.children=s,this.dictionary=a,this.offset=Math.floor(Math.max(n||0,0)),this.length=Math.floor(Math.max(r||0,0)),this._nullCount=Math.floor(Math.max(i||0,-1));let c;o instanceof e?(this.stride=o.stride,this.values=o.values,this.typeIds=o.typeIds,this.nullBitmap=o.nullBitmap,this.valueOffsets=o.valueOffsets):(this.stride=Or(t),o&&((c=o[0])&&(this.valueOffsets=c),(c=o[1])&&(this.values=c),(c=o[2])&&(this.nullBitmap=c),(c=o[3])&&(this.typeIds=c)))}getValid(t){let{type:n}=this;if(st.isUnion(n)){let r=n,i=this.children[r.typeIdToChildIndex[this.typeIds[t]]],o=r.mode===ge.Dense?this.valueOffsets[t]:t;return i.getValid(o)}if(this.nullable&&this.nullCount>0){let r=this.offset+t;return(this.nullBitmap[r>>3]&1<<r%8)!==0}return!0}setValid(t,n){let r,{type:i}=this;if(st.isUnion(i)){let o=i,s=this.children[o.typeIdToChildIndex[this.typeIds[t]]],a=o.mode===ge.Dense?this.valueOffsets[t]:t;r=s.getValid(a),s.setValid(a,n)}else{let{nullBitmap:o}=this,{offset:s,length:a}=this,c=s+t,l=1<<c%8,u=c>>3;(!o||o.byteLength<=u)&&(o=new Uint8Array((s+a+63&-64)>>3).fill(255),this.nullCount>0&&o.set(Sc(s,a,this.nullBitmap),0),Object.assign(this,{nullBitmap:o,_nullCount:-1}));let f=o[u];r=(f&l)!==0,n?o[u]=f|l:o[u]=f&~l}return r!==!!n&&(this._nullCount=this.nullCount+(n?-1:1)),n}clone(t=this.type,n=this.offset,r=this.length,i=this._nullCount,o=this,s=this.children){return new e(t,n,r,i,o,s,this.dictionary)}slice(t,n){let{stride:r,typeId:i,children:o}=this,s=+(this._nullCount===0)-1,a=i===16?r:1,c=this._sliceBuffers(t,n,r,i);return this.clone(this.type,this.offset+t,n,s,c,o.length===0||this.valueOffsets?o:this._sliceChildren(o,a*t,a*n))}_changeLengthAndBackfillNullBitmap(t){if(this.typeId===B.Null)return this.clone(this.type,0,t,0);let{length:n,nullCount:r}=this,i=new Uint8Array((t+63&-64)>>3).fill(255,0,n>>3);i[n>>3]=(1<<n-(n&-8))-1,r>0&&i.set(Sc(this.offset,n,this.nullBitmap),0);let o=this.buffers;return o[Mi.VALIDITY]=i,this.clone(this.type,0,t,r+(t-n),o)}_sliceBuffers(t,n,r,i){let o,{buffers:s}=this;return(o=s[Mi.TYPE])&&(s[Mi.TYPE]=o.subarray(t,t+n)),(o=s[Mi.OFFSET])&&(s[Mi.OFFSET]=o.subarray(t,t+n+1))||(o=s[Mi.DATA])&&(s[Mi.DATA]=i===6?o:o.subarray(r*t,r*(t+n))),s}_sliceChildren(t,n,r){return t.map(i=>i.slice(n,r))}};te.prototype.children=Object.freeze([]);var K_=class e extends mt{visit(t){return this.getVisitFn(t.type).call(this,t)}visitNull(t){let{["type"]:n,["offset"]:r=0,["length"]:i=0}=t;return new te(n,r,i,i)}visitBool(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length>>3,["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitInt(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length,["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitFloat(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length,["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitUtf8(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.data),o=_t(t.nullBitmap),s=wc(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,i,o])}visitLargeUtf8(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.data),o=_t(t.nullBitmap),s=dg(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,i,o])}visitBinary(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.data),o=_t(t.nullBitmap),s=wc(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,i,o])}visitLargeBinary(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.data),o=_t(t.nullBitmap),s=dg(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,i,o])}visitFixedSizeBinary(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitDate(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitTimestamp(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitTime(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitDecimal(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitList(t){let{["type"]:n,["offset"]:r=0,["child"]:i}=t,o=_t(t.nullBitmap),s=wc(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,void 0,o],[i])}visitStruct(t){let{["type"]:n,["offset"]:r=0,["children"]:i=[]}=t,o=_t(t.nullBitmap),{length:s=i.reduce((c,{length:l})=>Math.max(c,l),0),nullCount:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,void 0,o],i)}visitUnion(t){let{["type"]:n,["offset"]:r=0,["children"]:i=[]}=t,o=Pt(n.ArrayType,t.typeIds),{["length"]:s=o.length,["nullCount"]:a=-1}=t;if(st.isSparseUnion(n))return new te(n,r,s,a,[void 0,void 0,void 0,o],i);let c=wc(t.valueOffsets);return new te(n,r,s,a,[c,void 0,void 0,o],i)}visitDictionary(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.indices.ArrayType,t.data),{["dictionary"]:s=new Xt([new e().visit({type:n.dictionary})])}=t,{["length"]:a=o.length,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[void 0,o,i],[],s)}visitInterval(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitDuration(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length,["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitFixedSizeList(t){let{["type"]:n,["offset"]:r=0,["child"]:i=new e().visit({type:n.valueType})}=t,o=_t(t.nullBitmap),{["length"]:s=i.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,void 0,o],[i])}visitMap(t){let{["type"]:n,["offset"]:r=0,["child"]:i=new e().visit({type:n.childType})}=t,o=_t(t.nullBitmap),s=wc(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,void 0,o],[i])}},Vq=new K_;function Nt(e){return Vq.visit(e)}var nh=class{constructor(t=0,n){this.numChunks=t,this.getChunkIterator=n,this.chunkIndex=0,this.chunkIterator=this.getChunkIterator(0)}next(){for(;this.chunkIndex<this.numChunks;){let t=this.chunkIterator.next();if(!t.done)return t;++this.chunkIndex<this.numChunks&&(this.chunkIterator=this.getChunkIterator(this.chunkIndex))}return{done:!0,value:null}}[Symbol.iterator](){return this}};function qO(e){return e.some(t=>t.nullable)}function Hg(e){return e.reduce((t,n)=>t+n.nullCount,0)}function Zg(e){return e.reduce((t,n,r)=>(t[r+1]=t[r]+n.length,t),new Uint32Array(e.length+1))}function Jg(e,t,n,r){let i=[];for(let o=-1,s=e.length;++o<s;){let a=e[o],c=t[o],{length:l}=a;if(c>=r)break;if(n>=c+l)continue;if(c>=n&&c+l<=r){i.push(a);continue}let u=Math.max(0,n-c),f=Math.min(r-c,l);i.push(a.slice(u,f-u))}return i.length===0&&i.push(e[0].slice(0,0)),i}function t2(e,t,n,r){let i=0,o=0,s=t.length-1;do{if(i>=s-1)return n<t[s]?r(e,i,n-t[i]):null;o=i+Math.trunc((s-i)*.5),n<t[o]?s=o:i=o}while(i<s)}function rh(e,t){return e.getValid(t)}function su(e){function t(n,r,i){return e(n[r],i)}return function(n){let r=this.data;return t2(r,this._offsets,n,t)}}function Qg(e){let t;function n(r,i,o){return e(r[i],o,t)}return function(r,i){let o=this.data;t=i;let s=t2(o,this._offsets,r,n);return t=void 0,s}}function Kg(e){let t;function n(r,i,o){let s=o,a=0,c=0;for(let l=i-1,u=r.length;++l<u;){let f=r[l];if(~(a=e(f,t,s)))return c+a;s=0,c+=f.length}return-1}return function(r,i){t=r;let o=this.data,s=typeof i!="number"?n(o,0,0):t2(o,this._offsets,i,n);return t=void 0,s}}var gt=class extends mt{};function Yq(e,t){return t===null&&e.length>0?0:-1}function Xq(e,t){let{nullBitmap:n}=e;if(!n||e.nullCount<=0)return-1;let r=0;for(let i of new _c(n,e.offset+(t||0),e.length,n,Wg)){if(!i)return r;++r}return-1}function Dt(e,t,n){if(t===void 0)return-1;if(t===null)switch(e.typeId){case B.Union:break;case B.Dictionary:break;default:return Xq(e,n)}let r=Ye.getVisitFn(e),i=_a(t);for(let o=(n||0)-1,s=e.length;++o<s;)if(i(r(e,o)))return o;return-1}function jO(e,t,n){let r=Ye.getVisitFn(e),i=_a(t);for(let o=(n||0)-1,s=e.length;++o<s;)if(i(r(e,o)))return o;return-1}gt.prototype.visitNull=Yq;gt.prototype.visitBool=Dt;gt.prototype.visitInt=Dt;gt.prototype.visitInt8=Dt;gt.prototype.visitInt16=Dt;gt.prototype.visitInt32=Dt;gt.prototype.visitInt64=Dt;gt.prototype.visitUint8=Dt;gt.prototype.visitUint16=Dt;gt.prototype.visitUint32=Dt;gt.prototype.visitUint64=Dt;gt.prototype.visitFloat=Dt;gt.prototype.visitFloat16=Dt;gt.prototype.visitFloat32=Dt;gt.prototype.visitFloat64=Dt;gt.prototype.visitUtf8=Dt;gt.prototype.visitLargeUtf8=Dt;gt.prototype.visitBinary=Dt;gt.prototype.visitLargeBinary=Dt;gt.prototype.visitFixedSizeBinary=Dt;gt.prototype.visitDate=Dt;gt.prototype.visitDateDay=Dt;gt.prototype.visitDateMillisecond=Dt;gt.prototype.visitTimestamp=Dt;gt.prototype.visitTimestampSecond=Dt;gt.prototype.visitTimestampMillisecond=Dt;gt.prototype.visitTimestampMicrosecond=Dt;gt.prototype.visitTimestampNanosecond=Dt;gt.prototype.visitTime=Dt;gt.prototype.visitTimeSecond=Dt;gt.prototype.visitTimeMillisecond=Dt;gt.prototype.visitTimeMicrosecond=Dt;gt.prototype.visitTimeNanosecond=Dt;gt.prototype.visitDecimal=Dt;gt.prototype.visitList=Dt;gt.prototype.visitStruct=Dt;gt.prototype.visitUnion=Dt;gt.prototype.visitDenseUnion=jO;gt.prototype.visitSparseUnion=jO;gt.prototype.visitDictionary=Dt;gt.prototype.visitInterval=Dt;gt.prototype.visitIntervalDayTime=Dt;gt.prototype.visitIntervalYearMonth=Dt;gt.prototype.visitDuration=Dt;gt.prototype.visitDurationSecond=Dt;gt.prototype.visitDurationMillisecond=Dt;gt.prototype.visitDurationMicrosecond=Dt;gt.prototype.visitDurationNanosecond=Dt;gt.prototype.visitFixedSizeList=Dt;gt.prototype.visitMap=Dt;var Mc=new gt;var xt=class extends mt{};function Mt(e){let{type:t}=e;if(e.nullCount===0&&e.stride===1&&(t.typeId===B.Timestamp||t instanceof Pe&&t.bitWidth!==64||t instanceof Ei&&t.bitWidth!==64||t instanceof dr&&t.precision!==he.HALF))return new nh(e.data.length,r=>{let i=e.data[r];return i.values.subarray(0,i.length)[Symbol.iterator]()});let n=0;return new nh(e.data.length,r=>{let o=e.data[r].length,s=e.slice(n,n+o);return n+=o,new e2(s)})}var e2=class{constructor(t){this.vector=t,this.index=0}next(){return this.index<this.vector.length?{value:this.vector.get(this.index++)}:{done:!0,value:null}}[Symbol.iterator](){return this}};xt.prototype.visitNull=Mt;xt.prototype.visitBool=Mt;xt.prototype.visitInt=Mt;xt.prototype.visitInt8=Mt;xt.prototype.visitInt16=Mt;xt.prototype.visitInt32=Mt;xt.prototype.visitInt64=Mt;xt.prototype.visitUint8=Mt;xt.prototype.visitUint16=Mt;xt.prototype.visitUint32=Mt;xt.prototype.visitUint64=Mt;xt.prototype.visitFloat=Mt;xt.prototype.visitFloat16=Mt;xt.prototype.visitFloat32=Mt;xt.prototype.visitFloat64=Mt;xt.prototype.visitUtf8=Mt;xt.prototype.visitLargeUtf8=Mt;xt.prototype.visitBinary=Mt;xt.prototype.visitLargeBinary=Mt;xt.prototype.visitFixedSizeBinary=Mt;xt.prototype.visitDate=Mt;xt.prototype.visitDateDay=Mt;xt.prototype.visitDateMillisecond=Mt;xt.prototype.visitTimestamp=Mt;xt.prototype.visitTimestampSecond=Mt;xt.prototype.visitTimestampMillisecond=Mt;xt.prototype.visitTimestampMicrosecond=Mt;xt.prototype.visitTimestampNanosecond=Mt;xt.prototype.visitTime=Mt;xt.prototype.visitTimeSecond=Mt;xt.prototype.visitTimeMillisecond=Mt;xt.prototype.visitTimeMicrosecond=Mt;xt.prototype.visitTimeNanosecond=Mt;xt.prototype.visitDecimal=Mt;xt.prototype.visitList=Mt;xt.prototype.visitStruct=Mt;xt.prototype.visitUnion=Mt;xt.prototype.visitDenseUnion=Mt;xt.prototype.visitSparseUnion=Mt;xt.prototype.visitDictionary=Mt;xt.prototype.visitInterval=Mt;xt.prototype.visitIntervalDayTime=Mt;xt.prototype.visitIntervalYearMonth=Mt;xt.prototype.visitDuration=Mt;xt.prototype.visitDurationSecond=Mt;xt.prototype.visitDurationMillisecond=Mt;xt.prototype.visitDurationMicrosecond=Mt;xt.prototype.visitDurationNanosecond=Mt;xt.prototype.visitFixedSizeList=Mt;xt.prototype.visitMap=Mt;var au=new xt;var VO,YO={},XO={},Xt=class e{constructor(t){var n,r,i;let o=t[0]instanceof e?t.flatMap(a=>a.data):t;if(o.length===0||o.some(a=>!(a instanceof te)))throw new TypeError("Vector constructor expects an Array of Data instances.");let s=(n=o[0])===null||n===void 0?void 0:n.type;switch(o.length){case 0:this._offsets=[0];break;case 1:{let{get:a,set:c,indexOf:l}=YO[s.typeId],u=o[0];this.isValid=f=>rh(u,f),this.get=f=>a(u,f),this.set=(f,d)=>c(u,f,d),this.indexOf=f=>l(u,f),this._offsets=[0,u.length];break}default:Object.setPrototypeOf(this,XO[s.typeId]),this._offsets=Zg(o);break}this.data=o,this.type=s,this.stride=Or(s),this.numChildren=(i=(r=s.children)===null||r===void 0?void 0:r.length)!==null&&i!==void 0?i:0,this.length=this._offsets.at(-1)}get byteLength(){return this.data.reduce((t,n)=>t+n.byteLength,0)}get nullable(){return qO(this.data)}get nullCount(){return Hg(this.data)}get ArrayType(){return this.type.ArrayType}get[Symbol.toStringTag](){return`${this.VectorName}<${this.type[Symbol.toStringTag]}>`}get VectorName(){return`${B[this.type.typeId]}Vector`}isValid(t){return!1}get(t){return null}set(t,n){}indexOf(t,n){return-1}includes(t,n){return this.indexOf(t,n)>-1}[Symbol.iterator](){return au.visit(this)}concat(...t){return new e(this.data.concat(t.flatMap(n=>n.data).flat(Number.POSITIVE_INFINITY)))}slice(t,n){return new e(th(this,t,n,({data:r,_offsets:i},o,s)=>Jg(r,i,o,s)))}toJSON(){return[...this]}toArray(){let{type:t,data:n,length:r,stride:i,ArrayType:o}=this;switch(t.typeId){case B.Int:case B.Float:case B.Decimal:case B.Time:case B.Timestamp:switch(n.length){case 0:return new o;case 1:return n[0].values.subarray(0,r*i);default:return n.reduce((s,{values:a,length:c})=>(s.array.set(a.subarray(0,c*i),s.offset),s.offset+=c*i,s),{array:new o(r*i),offset:0}).array}}return[...this]}toString(){return`[${[...this].join(",")}]`}getChild(t){var n;return this.getChildAt((n=this.type.children)===null||n===void 0?void 0:n.findIndex(r=>r.name===t))}getChildAt(t){return t>-1&&t<this.numChildren?new e(this.data.map(({children:n})=>n[t])):null}get isMemoized(){return st.isDictionary(this.type)?this.data[0].dictionary.isMemoized:!1}memoize(){if(st.isDictionary(this.type)){let t=new t0(this.data[0].dictionary),n=this.data.map(r=>{let i=r.clone();return i.dictionary=t,i});return new e(n)}return new t0(this)}unmemoize(){if(st.isDictionary(this.type)&&this.isMemoized){let t=this.data[0].dictionary.unmemoize(),n=this.data.map(r=>{let i=r.clone();return i.dictionary=t,i});return new e(n)}return this}};VO=Symbol.toStringTag;Xt[VO]=(e=>{e.type=st.prototype,e.data=[],e.length=0,e.stride=1,e.numChildren=0,e._offsets=new Uint32Array([0]),e[Symbol.isConcatSpreadable]=!0;let t=Object.keys(B).map(n=>B[n]).filter(n=>typeof n=="number"&&n!==B.NONE);for(let n of t){let r=Ye.getVisitFnByTypeId(n),i=wn.getVisitFnByTypeId(n),o=Mc.getVisitFnByTypeId(n);YO[n]={get:r,set:i,indexOf:o},XO[n]=Object.create(e,{isValid:{value:su(rh)},get:{value:su(Ye.getVisitFnByTypeId(n))},set:{value:Qg(wn.getVisitFnByTypeId(n))},indexOf:{value:Kg(Mc.getVisitFnByTypeId(n))}})}return"Vector"})(Xt.prototype);var t0=class e extends Xt{constructor(t){super(t.data);let n=this.get,r=this.set,i=this.slice,o=new Array(this.length);Object.defineProperty(this,"get",{value(s){let a=o[s];if(a!==void 0)return a;let c=n.call(this,s);return o[s]=c,c}}),Object.defineProperty(this,"set",{value(s,a){r.call(this,s,a),o[s]=a}}),Object.defineProperty(this,"slice",{value:(s,a)=>new e(i.call(this,s,a))}),Object.defineProperty(this,"isMemoized",{value:!0}),Object.defineProperty(this,"unmemoize",{value:()=>new Xt(this.data)}),Object.defineProperty(this,"memoize",{value:()=>this})}};function GO(e){if(!e||e.length<=0)return function(i){return!0};let t="",n=e.filter(r=>r===r);return n.length>0&&(t=`
|
|
1
|
+
var wz=Object.create;var A_=Object.defineProperty;var vz=Object.getOwnPropertyDescriptor;var _z=Object.getOwnPropertyNames;var Sz=Object.getPrototypeOf,Iz=Object.prototype.hasOwnProperty;var RD=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Mr=(e,t)=>{for(var n in t)A_(e,n,{get:t[n],enumerable:!0})},Mz=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of _z(t))!Iz.call(e,i)&&i!==n&&A_(e,i,{get:()=>t[i],enumerable:!(r=vz(t,i))||r.enumerable});return e};var Az=(e,t,n)=>(n=e!=null?wz(Sz(e)):{},Mz(t||!e||!e.__esModule?A_(n,"default",{value:e,enumerable:!0}):n,e));var gP=RD((iPt,yP)=>{"use strict";function vet(e,t,n,r,i){for(var o=i+1;r<=i;){var s=r+i>>>1,a=e[s],c=n!==void 0?n(a,t):a-t;c>=0?(o=s,i=s-1):r=s+1}return o}function _et(e,t,n,r,i){for(var o=i+1;r<=i;){var s=r+i>>>1,a=e[s],c=n!==void 0?n(a,t):a-t;c>0?(o=s,i=s-1):r=s+1}return o}function Iet(e,t,n,r,i){for(var o=r-1;r<=i;){var s=r+i>>>1,a=e[s],c=n!==void 0?n(a,t):a-t;c<0?(o=s,r=s+1):i=s-1}return o}function Met(e,t,n,r,i){for(var o=r-1;r<=i;){var s=r+i>>>1,a=e[s],c=n!==void 0?n(a,t):a-t;c<=0?(o=s,r=s+1):i=s-1}return o}function Aet(e,t,n,r,i){for(;r<=i;){var o=r+i>>>1,s=e[o],a=n!==void 0?n(s,t):s-t;if(a===0)return o;a<=0?r=o+1:i=o-1}return-1}function Py(e,t,n,r,i,o){return typeof n=="function"?o(e,t,n,r===void 0?0:r|0,i===void 0?e.length-1:i|0):o(e,t,void 0,n===void 0?0:n|0,r===void 0?e.length-1:r|0)}yP.exports={ge:function(e,t,n,r,i){return Py(e,t,n,r,i,vet)},gt:function(e,t,n,r,i){return Py(e,t,n,r,i,_et)},lt:function(e,t,n,r,i){return Py(e,t,n,r,i,Iet)},le:function(e,t,n,r,i){return Py(e,t,n,r,i,Met)},eq:function(e,t,n,r,i){return Py(e,t,n,r,i,Aet)}}});var MP=RD((oPt,IP)=>{"use strict";var Nv=gP(),dh=0,jl=1,Ev=2;IP.exports=Eet;function O3(e,t,n,r,i){this.mid=e,this.left=t,this.right=n,this.leftPoints=r,this.rightPoints=i,this.count=(t?t.count:0)+(n?n.count:0)+r.length}var Uy=O3.prototype;function N3(e,t){e.mid=t.mid,e.left=t.left,e.right=t.right,e.leftPoints=t.leftPoints,e.rightPoints=t.rightPoints,e.count=t.count}function wP(e,t){var n=ph(t);e.mid=n.mid,e.left=n.left,e.right=n.right,e.leftPoints=n.leftPoints,e.rightPoints=n.rightPoints,e.count=n.count}function xP(e,t){var n=e.intervals([]);n.push(t),wP(e,n)}function bP(e,t){var n=e.intervals([]),r=n.indexOf(t);return r<0?dh:(n.splice(r,1),wP(e,n),jl)}Uy.intervals=function(e){return e.push.apply(e,this.leftPoints),this.left&&this.left.intervals(e),this.right&&this.right.intervals(e),e};Uy.insert=function(e){var t=this.count-this.leftPoints.length;if(this.count+=1,e[1]<this.mid)this.left?4*(this.left.count+1)>3*(t+1)?xP(this,e):this.left.insert(e):this.left=ph([e]);else if(e[0]>this.mid)this.right?4*(this.right.count+1)>3*(t+1)?xP(this,e):this.right.insert(e):this.right=ph([e]);else{var n=Nv.ge(this.leftPoints,e,B3),r=Nv.ge(this.rightPoints,e,L3);this.leftPoints.splice(n,0,e),this.rightPoints.splice(r,0,e)}};Uy.remove=function(e){var t=this.count-this.leftPoints;if(e[1]<this.mid){if(!this.left)return dh;var n=this.right?this.right.count:0;if(4*n>3*(t-1))return bP(this,e);var r=this.left.remove(e);return r===Ev?(this.left=null,this.count-=1,jl):(r===jl&&(this.count-=1),r)}else if(e[0]>this.mid){if(!this.right)return dh;var i=this.left?this.left.count:0;if(4*i>3*(t-1))return bP(this,e);var r=this.right.remove(e);return r===Ev?(this.right=null,this.count-=1,jl):(r===jl&&(this.count-=1),r)}else{if(this.count===1)return this.leftPoints[0]===e?Ev:dh;if(this.leftPoints.length===1&&this.leftPoints[0]===e){if(this.left&&this.right){for(var o=this,s=this.left;s.right;)o=s,s=s.right;if(o===this)s.right=this.right;else{var a=this.left,r=this.right;o.count-=s.count,o.right=s.left,s.left=a,s.right=r}N3(this,s),this.count=(this.left?this.left.count:0)+(this.right?this.right.count:0)+this.leftPoints.length}else this.left?N3(this,this.left):N3(this,this.right);return jl}for(var a=Nv.ge(this.leftPoints,e,B3);a<this.leftPoints.length&&this.leftPoints[a][0]===e[0];++a)if(this.leftPoints[a]===e){this.count-=1,this.leftPoints.splice(a,1);for(var r=Nv.ge(this.rightPoints,e,L3);r<this.rightPoints.length&&this.rightPoints[r][1]===e[1];++r)if(this.rightPoints[r]===e)return this.rightPoints.splice(r,1),jl}return dh}};function vP(e,t,n){for(var r=0;r<e.length&&e[r][0]<=t;++r){var i=n(e[r]);if(i)return i}}function _P(e,t,n){for(var r=e.length-1;r>=0&&e[r][1]>=t;--r){var i=n(e[r]);if(i)return i}}function SP(e,t){for(var n=0;n<e.length;++n){var r=t(e[n]);if(r)return r}}Uy.queryPoint=function(e,t){if(e<this.mid){if(this.left){var n=this.left.queryPoint(e,t);if(n)return n}return vP(this.leftPoints,e,t)}else if(e>this.mid){if(this.right){var n=this.right.queryPoint(e,t);if(n)return n}return _P(this.rightPoints,e,t)}else return SP(this.leftPoints,t)};Uy.queryInterval=function(e,t,n){if(e<this.mid&&this.left){var r=this.left.queryInterval(e,t,n);if(r)return r}if(t>this.mid&&this.right){var r=this.right.queryInterval(e,t,n);if(r)return r}return t<this.mid?vP(this.leftPoints,t,n):e>this.mid?_P(this.rightPoints,e,n):SP(this.leftPoints,n)};function Tet(e,t){return e-t}function B3(e,t){var n=e[0]-t[0];return n||e[1]-t[1]}function L3(e,t){var n=e[1]-t[1];return n||e[0]-t[0]}function ph(e){if(e.length===0)return null;for(var t=[],n=0;n<e.length;++n)t.push(e[n][0],e[n][1]);t.sort(Tet);for(var r=t[t.length>>1],i=[],o=[],s=[],n=0;n<e.length;++n){var a=e[n];a[1]<r?i.push(a):r<a[0]?o.push(a):s.push(a)}var c=s,l=s.slice();return c.sort(B3),l.sort(L3),new O3(r,ph(i),ph(o),c,l)}function D3(e){this.root=e}var mh=D3.prototype;mh.insert=function(e){this.root?this.root.insert(e):this.root=new O3(e[0],null,null,[e],[e])};mh.remove=function(e){if(this.root){var t=this.root.remove(e);return t===Ev&&(this.root=null),t!==dh}return!1};mh.queryPoint=function(e,t){if(this.root)return this.root.queryPoint(e,t)};mh.queryInterval=function(e,t,n){if(e<=t&&this.root)return this.root.queryInterval(e,t,n)};Object.defineProperty(mh,"count",{get:function(){return this.root?this.root.count:0}});Object.defineProperty(mh,"intervals",{get:function(){return this.root?this.root.intervals([]):[]}});function Eet(e){return!e||e.length===0?new D3(null):new D3(ph(e))}});var $D={};function Ch(e,t=!1){let n,r,i=$D;function o(l){n=e(l).then(()=>{if(r){let{value:u}=r;r=null,o(u)}else n=null})}function s(l){r={event:l}}function a(l){n?s(l):o(l)}function c(l){i!==l&&requestAnimationFrame(()=>{let u=i;i=$D,a(u)}),i=l}return t?c:a}var fr=class{constructor(t){this._filterBy=t,this._requestUpdate=Ch(()=>this.requestQuery(),!0),this._coordinator=null}get coordinator(){return this._coordinator}set coordinator(t){this._coordinator=t}get filterBy(){return this._filterBy}get filterIndexable(){return!0}fields(){return null}fieldInfo(t){return this}query(t){return null}queryPending(){return this}queryResult(t){return this}queryError(t){return console.error(t),this}requestQuery(t){let n=t||this.query(this.filterBy?.predicate(this));return this._coordinator.requestQuery(this,n)}requestUpdate(){this._requestUpdate()}update(){return this}};function UD(e,t){var n={};for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var i=0,r=Object.getOwnPropertySymbols(e);i<r.length;i++)t.indexOf(r[i])<0&&Object.prototype.propertyIsEnumerable.call(e,r[i])&&(n[r[i]]=e[r[i]]);return n}function J(e,t,n,r){function i(o){return o instanceof n?o:new n(function(s){s(o)})}return new(n||(n=Promise))(function(o,s){function a(u){try{l(r.next(u))}catch(f){s(f)}}function c(u){try{l(r.throw(u))}catch(f){s(f)}}function l(u){u.done?o(u.value):i(u.value).then(a,c)}l((r=r.apply(e,t||[])).next())})}function PD(e){var t=typeof Symbol=="function"&&Symbol.iterator,n=t&&e[t],r=0;if(n)return n.call(e);if(e&&typeof e.length=="number")return{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function Ft(e){return this instanceof Ft?(this.v=e,this):new Ft(e)}function Ar(e,t,n){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var r=n.apply(e,t||[]),i,o=[];return i={},s("next"),s("throw"),s("return"),i[Symbol.asyncIterator]=function(){return this},i;function s(h){r[h]&&(i[h]=function(d){return new Promise(function(p,m){o.push([h,d,p,m])>1||a(h,d)})})}function a(h,d){try{c(r[h](d))}catch(p){f(o[0][3],p)}}function c(h){h.value instanceof Ft?Promise.resolve(h.value.v).then(l,u):f(o[0][2],h)}function l(h){a("next",h)}function u(h){a("throw",h)}function f(h,d){h(d),o.shift(),o.length&&a(o[0][0],o[0][1])}}function Ql(e){var t,n;return t={},r("next"),r("throw",function(i){throw i}),r("return"),t[Symbol.iterator]=function(){return this},t;function r(i,o){t[i]=e[i]?function(s){return(n=!n)?{value:Ft(e[i](s)),done:!1}:o?o(s):s}:o}}function Ii(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t=e[Symbol.asyncIterator],n;return t?t.call(e):(e=typeof PD=="function"?PD(e):e[Symbol.iterator](),n={},r("next"),r("throw"),r("return"),n[Symbol.asyncIterator]=function(){return this},n);function r(o){n[o]=e[o]&&function(s){return new Promise(function(a,c){s=e[o](s),i(a,c,s.done,s.value)})}}function i(o,s,a,c){Promise.resolve(c).then(function(l){o({value:l,done:a})},s)}}var B_={};Mr(B_,{compareArrayLike:()=>O_,joinUint8Arrays:()=>Er,memcpy:()=>Rh,rebaseValueOffsets:()=>Mg,toArrayBufferView:()=>Pt,toArrayBufferViewAsyncIterator:()=>Ai,toArrayBufferViewIterator:()=>Qi,toBigInt64Array:()=>Ig,toBigUint64Array:()=>kz,toFloat32Array:()=>Fz,toFloat32ArrayAsyncIterator:()=>Qz,toFloat32ArrayIterator:()=>Vz,toFloat64Array:()=>Rz,toFloat64ArrayAsyncIterator:()=>Kz,toFloat64ArrayIterator:()=>Yz,toInt16Array:()=>Bz,toInt16ArrayAsyncIterator:()=>Wz,toInt16ArrayIterator:()=>Uz,toInt32Array:()=>vc,toInt32ArrayAsyncIterator:()=>Hz,toInt32ArrayIterator:()=>zz,toInt8Array:()=>Oz,toInt8ArrayAsyncIterator:()=>Gz,toInt8ArrayIterator:()=>Pz,toUint16Array:()=>Lz,toUint16ArrayAsyncIterator:()=>Zz,toUint16ArrayIterator:()=>qz,toUint32Array:()=>Cz,toUint32ArrayAsyncIterator:()=>Jz,toUint32ArrayIterator:()=>jz,toUint8Array:()=>_t,toUint8ArrayAsyncIterator:()=>D_,toUint8ArrayIterator:()=>N_,toUint8ClampedArray:()=>$z,toUint8ClampedArrayAsyncIterator:()=>tq,toUint8ClampedArrayIterator:()=>Xz});var Tz=new TextDecoder("utf-8"),kh=e=>Tz.decode(e),Ez=new TextEncoder,Ji=e=>Ez.encode(e);var Nz=e=>typeof e=="number",zD=e=>typeof e=="boolean",en=e=>typeof e=="function",Xn=e=>e!=null&&Object(e)===e,Tr=e=>Xn(e)&&en(e.then);var Mi=e=>Xn(e)&&en(e[Symbol.iterator]),Wr=e=>Xn(e)&&en(e[Symbol.asyncIterator]),xg=e=>Xn(e)&&Xn(e.schema);var bg=e=>Xn(e)&&"done"in e&&"value"in e;var wg=e=>Xn(e)&&en(e.stat)&&Nz(e.fd);var vg=e=>Xn(e)&&Fh(e.body),_g=e=>"_getDOMStream"in e&&"_getNodeStream"in e,qD=e=>Xn(e)&&en(e.abort)&&en(e.getWriter)&&!_g(e),Fh=e=>Xn(e)&&en(e.cancel)&&en(e.getReader)&&!_g(e),jD=e=>Xn(e)&&en(e.end)&&en(e.write)&&zD(e.writable)&&!_g(e),Sg=e=>Xn(e)&&en(e.read)&&en(e.pipe)&&zD(e.readable)&&!_g(e),VD=e=>Xn(e)&&en(e.clear)&&en(e.bytes)&&en(e.position)&&en(e.setPosition)&&en(e.capacity)&&en(e.getBufferIdentifier)&&en(e.createLong);var E_=typeof SharedArrayBuffer<"u"?SharedArrayBuffer:ArrayBuffer;function Dz(e){let t=e[0]?[e[0]]:[],n,r,i,o;for(let s,a,c=0,l=0,u=e.length;++c<u;){if(s=t[l],a=e[c],!s||!a||s.buffer!==a.buffer||a.byteOffset<s.byteOffset){a&&(t[++l]=a);continue}if({byteOffset:n,byteLength:i}=s,{byteOffset:r,byteLength:o}=a,n+i<r||r+o<n){a&&(t[++l]=a);continue}t[l]=new Uint8Array(s.buffer,n,r-n+o)}return t}function Rh(e,t,n=0,r=t.byteLength){let i=e.byteLength,o=new Uint8Array(e.buffer,e.byteOffset,i),s=new Uint8Array(t.buffer,t.byteOffset,Math.min(r,i));return o.set(s,n),e}function Er(e,t){let n=Dz(e),r=n.reduce((u,f)=>u+f.byteLength,0),i,o,s,a=0,c=-1,l=Math.min(t||Number.POSITIVE_INFINITY,r);for(let u=n.length;++c<u;){if(i=n[c],o=i.subarray(0,Math.min(i.length,l-a)),l<=a+o.length){o.length<i.length?n[c]=i.subarray(o.length):o.length===i.length&&c++,s?Rh(s,o,a):s=o;break}Rh(s||(s=new Uint8Array(l)),o,a),a+=o.length}return[s||new Uint8Array(0),n.slice(c),r-(s?s.byteLength:0)]}function Pt(e,t){let n=bg(t)?t.value:t;return n instanceof e?e===Uint8Array?new e(n.buffer,n.byteOffset,n.byteLength):n:n?(typeof n=="string"&&(n=Ji(n)),n instanceof ArrayBuffer?new e(n):n instanceof E_?new e(n):VD(n)?Pt(e,n.bytes()):ArrayBuffer.isView(n)?n.byteLength<=0?new e(0):new e(n.buffer,n.byteOffset,n.byteLength/e.BYTES_PER_ELEMENT):e.from(n)):new e(0)}var Oz=e=>Pt(Int8Array,e),Bz=e=>Pt(Int16Array,e),vc=e=>Pt(Int32Array,e),Ig=e=>Pt(BigInt64Array,e),_t=e=>Pt(Uint8Array,e),Lz=e=>Pt(Uint16Array,e),Cz=e=>Pt(Uint32Array,e),kz=e=>Pt(BigUint64Array,e),Fz=e=>Pt(Float32Array,e),Rz=e=>Pt(Float64Array,e),$z=e=>Pt(Uint8ClampedArray,e),T_=e=>(e.next(),e);function*Qi(e,t){let n=function*(i){yield i},r=typeof t=="string"||ArrayBuffer.isView(t)||t instanceof ArrayBuffer||t instanceof E_?n(t):Mi(t)?t:n(t);return yield*T_(function*(i){let o=null;do o=i.next(yield Pt(e,o));while(!o.done)}(r[Symbol.iterator]())),new e}var Pz=e=>Qi(Int8Array,e),Uz=e=>Qi(Int16Array,e),zz=e=>Qi(Int32Array,e),N_=e=>Qi(Uint8Array,e),qz=e=>Qi(Uint16Array,e),jz=e=>Qi(Uint32Array,e),Vz=e=>Qi(Float32Array,e),Yz=e=>Qi(Float64Array,e),Xz=e=>Qi(Uint8ClampedArray,e);function Ai(e,t){return Ar(this,arguments,function*(){if(Tr(t))return yield Ft(yield Ft(yield*Ql(Ii(Ai(e,yield Ft(t))))));let r=function(s){return Ar(this,arguments,function*(){yield yield Ft(yield Ft(s))})},i=function(s){return Ar(this,arguments,function*(){yield Ft(yield*Ql(Ii(T_(function*(a){let c=null;do c=a.next(yield c?.value);while(!c.done)}(s[Symbol.iterator]())))))})},o=typeof t=="string"||ArrayBuffer.isView(t)||t instanceof ArrayBuffer||t instanceof E_?r(t):Mi(t)?i(t):Wr(t)?t:r(t);return yield Ft(yield*Ql(Ii(T_(function(s){return Ar(this,arguments,function*(){let a=null;do a=yield Ft(s.next(yield yield Ft(Pt(e,a))));while(!a.done)})}(o[Symbol.asyncIterator]()))))),yield Ft(new e)})}var Gz=e=>Ai(Int8Array,e),Wz=e=>Ai(Int16Array,e),Hz=e=>Ai(Int32Array,e),D_=e=>Ai(Uint8Array,e),Zz=e=>Ai(Uint16Array,e),Jz=e=>Ai(Uint32Array,e),Qz=e=>Ai(Float32Array,e),Kz=e=>Ai(Float64Array,e),tq=e=>Ai(Uint8ClampedArray,e);function Mg(e,t,n){if(e!==0){n=n.slice(0,t);for(let r=-1,i=n.length;++r<i;)n[r]+=e}return n.subarray(0,t)}function O_(e,t){let n=0,r=e.length;if(r!==t.length)return!1;if(r>0)do if(e[n]!==t[n])return!1;while(++n<r);return!0}var wn={fromIterable(e){return Ag(eq(e))},fromAsyncIterable(e){return Ag(nq(e))},fromDOMStream(e){return Ag(rq(e))},fromNodeStream(e){return Ag(iq(e))},toDOMStream(e,t){throw new Error('"toDOMStream" not available in this environment')},toNodeStream(e,t){throw new Error('"toNodeStream" not available in this environment')}},Ag=e=>(e.next(),e);function*eq(e){let t,n=!1,r=[],i,o,s,a=0;function c(){return o==="peek"?Er(r,s)[0]:([i,r,a]=Er(r,s),i)}({cmd:o,size:s}=(yield null)||{cmd:"read",size:0});let l=N_(e)[Symbol.iterator]();try{do if({done:t,value:i}=Number.isNaN(s-a)?l.next():l.next(s-a),!t&&i.byteLength>0&&(r.push(i),a+=i.byteLength),t||s<=a)do({cmd:o,size:s}=yield c());while(s<a);while(!t)}catch(u){(n=!0)&&typeof l.throw=="function"&&l.throw(u)}finally{n===!1&&typeof l.return=="function"&&l.return(null)}return null}function nq(e){return Ar(this,arguments,function*(){let n,r=!1,i=[],o,s,a,c=0;function l(){return s==="peek"?Er(i,a)[0]:([o,i,c]=Er(i,a),o)}({cmd:s,size:a}=(yield yield Ft(null))||{cmd:"read",size:0});let u=D_(e)[Symbol.asyncIterator]();try{do if({done:n,value:o}=Number.isNaN(a-c)?yield Ft(u.next()):yield Ft(u.next(a-c)),!n&&o.byteLength>0&&(i.push(o),c+=o.byteLength),n||a<=c)do({cmd:s,size:a}=yield yield Ft(l()));while(a<c);while(!n)}catch(f){(r=!0)&&typeof u.throw=="function"&&(yield Ft(u.throw(f)))}finally{r===!1&&typeof u.return=="function"&&(yield Ft(u.return(new Uint8Array(0))))}return yield Ft(null)})}function rq(e){return Ar(this,arguments,function*(){let n=!1,r=!1,i=[],o,s,a,c=0;function l(){return s==="peek"?Er(i,a)[0]:([o,i,c]=Er(i,a),o)}({cmd:s,size:a}=(yield yield Ft(null))||{cmd:"read",size:0});let u=new C_(e);try{do if({done:n,value:o}=Number.isNaN(a-c)?yield Ft(u.read()):yield Ft(u.read(a-c)),!n&&o.byteLength>0&&(i.push(_t(o)),c+=o.byteLength),n||a<=c)do({cmd:s,size:a}=yield yield Ft(l()));while(a<c);while(!n)}catch(f){(r=!0)&&(yield Ft(u.cancel(f)))}finally{r===!1?yield Ft(u.cancel()):e.locked&&u.releaseLock()}return yield Ft(null)})}var C_=class{constructor(t){this.source=t,this.reader=null,this.reader=this.source.getReader(),this.reader.closed.catch(()=>{})}get closed(){return this.reader?this.reader.closed.catch(()=>{}):Promise.resolve()}releaseLock(){this.reader&&this.reader.releaseLock(),this.reader=null}cancel(t){return J(this,void 0,void 0,function*(){let{reader:n,source:r}=this;n&&(yield n.cancel(t).catch(()=>{})),r&&r.locked&&this.releaseLock()})}read(t){return J(this,void 0,void 0,function*(){if(t===0)return{done:this.reader==null,value:new Uint8Array(0)};let n=yield this.reader.read();return!n.done&&(n.value=_t(n)),n})}},L_=(e,t)=>{let n=i=>r([t,i]),r;return[t,n,new Promise(i=>(r=i)&&e.once(t,n))]};function iq(e){return Ar(this,arguments,function*(){let n=[],r="error",i=!1,o=null,s,a,c=0,l=[],u;function f(){return s==="peek"?Er(l,a)[0]:([u,l,c]=Er(l,a),u)}if({cmd:s,size:a}=(yield yield Ft(null))||{cmd:"read",size:0},e.isTTY)return yield yield Ft(new Uint8Array(0)),yield Ft(null);try{n[0]=L_(e,"end"),n[1]=L_(e,"error");do{if(n[2]=L_(e,"readable"),[r,o]=yield Ft(Promise.race(n.map(d=>d[2]))),r==="error")break;if((i=r==="end")||(Number.isFinite(a-c)?(u=_t(e.read(a-c)),u.byteLength<a-c&&(u=_t(e.read()))):u=_t(e.read()),u.byteLength>0&&(l.push(u),c+=u.byteLength)),i||a<=c)do({cmd:s,size:a}=yield yield Ft(f()));while(a<c)}while(!i)}finally{yield Ft(h(n,r==="error"?o:null))}return yield Ft(null);function h(d,p){return u=l=null,new Promise((m,y)=>{for(let[g,x]of d)e.off(g,x);try{let g=e.destroy;g&&g.call(e,p),p=void 0}catch(g){p=g||p}finally{p!=null?y(p):m()}})}})}var ce;(function(e){e[e.V1=0]="V1",e[e.V2=1]="V2",e[e.V3=2]="V3",e[e.V4=3]="V4",e[e.V5=4]="V5"})(ce||(ce={}));var ge;(function(e){e[e.Sparse=0]="Sparse",e[e.Dense=1]="Dense"})(ge||(ge={}));var de;(function(e){e[e.HALF=0]="HALF",e[e.SINGLE=1]="SINGLE",e[e.DOUBLE=2]="DOUBLE"})(de||(de={}));var Ve;(function(e){e[e.DAY=0]="DAY",e[e.MILLISECOND=1]="MILLISECOND"})(Ve||(Ve={}));var ct;(function(e){e[e.SECOND=0]="SECOND",e[e.MILLISECOND=1]="MILLISECOND",e[e.MICROSECOND=2]="MICROSECOND",e[e.NANOSECOND=3]="NANOSECOND"})(ct||(ct={}));var cn;(function(e){e[e.YEAR_MONTH=0]="YEAR_MONTH",e[e.DAY_TIME=1]="DAY_TIME",e[e.MONTH_DAY_NANO=2]="MONTH_DAY_NANO"})(cn||(cn={}));var Ki=new Int32Array(2),Tg=new Float32Array(Ki.buffer),Eg=new Float64Array(Ki.buffer),Kl=new Uint16Array(new Uint8Array([1,0]).buffer)[0]===1;var $h;(function(e){e[e.UTF8_BYTES=1]="UTF8_BYTES",e[e.UTF16_STRING=2]="UTF16_STRING"})($h||($h={}));var Nr=class e{constructor(t){this.bytes_=t,this.position_=0,this.text_decoder_=new TextDecoder}static allocate(t){return new e(new Uint8Array(t))}clear(){this.position_=0}bytes(){return this.bytes_}position(){return this.position_}setPosition(t){this.position_=t}capacity(){return this.bytes_.length}readInt8(t){return this.readUint8(t)<<24>>24}readUint8(t){return this.bytes_[t]}readInt16(t){return this.readUint16(t)<<16>>16}readUint16(t){return this.bytes_[t]|this.bytes_[t+1]<<8}readInt32(t){return this.bytes_[t]|this.bytes_[t+1]<<8|this.bytes_[t+2]<<16|this.bytes_[t+3]<<24}readUint32(t){return this.readInt32(t)>>>0}readInt64(t){return BigInt.asIntN(64,BigInt(this.readUint32(t))+(BigInt(this.readUint32(t+4))<<BigInt(32)))}readUint64(t){return BigInt.asUintN(64,BigInt(this.readUint32(t))+(BigInt(this.readUint32(t+4))<<BigInt(32)))}readFloat32(t){return Ki[0]=this.readInt32(t),Tg[0]}readFloat64(t){return Ki[Kl?0:1]=this.readInt32(t),Ki[Kl?1:0]=this.readInt32(t+4),Eg[0]}writeInt8(t,n){this.bytes_[t]=n}writeUint8(t,n){this.bytes_[t]=n}writeInt16(t,n){this.bytes_[t]=n,this.bytes_[t+1]=n>>8}writeUint16(t,n){this.bytes_[t]=n,this.bytes_[t+1]=n>>8}writeInt32(t,n){this.bytes_[t]=n,this.bytes_[t+1]=n>>8,this.bytes_[t+2]=n>>16,this.bytes_[t+3]=n>>24}writeUint32(t,n){this.bytes_[t]=n,this.bytes_[t+1]=n>>8,this.bytes_[t+2]=n>>16,this.bytes_[t+3]=n>>24}writeInt64(t,n){this.writeInt32(t,Number(BigInt.asIntN(32,n))),this.writeInt32(t+4,Number(BigInt.asIntN(32,n>>BigInt(32))))}writeUint64(t,n){this.writeUint32(t,Number(BigInt.asUintN(32,n))),this.writeUint32(t+4,Number(BigInt.asUintN(32,n>>BigInt(32))))}writeFloat32(t,n){Tg[0]=n,this.writeInt32(t,Ki[0])}writeFloat64(t,n){Eg[0]=n,this.writeInt32(t,Ki[Kl?0:1]),this.writeInt32(t+4,Ki[Kl?1:0])}getBufferIdentifier(){if(this.bytes_.length<this.position_+4+4)throw new Error("FlatBuffers: ByteBuffer is too short to contain an identifier.");let t="";for(let n=0;n<4;n++)t+=String.fromCharCode(this.readInt8(this.position_+4+n));return t}__offset(t,n){let r=t-this.readInt32(t);return n<this.readInt16(r)?this.readInt16(r+n):0}__union(t,n){return t.bb_pos=n+this.readInt32(n),t.bb=this,t}__string(t,n){t+=this.readInt32(t);let r=this.readInt32(t);t+=4;let i=this.bytes_.subarray(t,t+r);return n===$h.UTF8_BYTES?i:this.text_decoder_.decode(i)}__union_with_string(t,n){return typeof t=="string"?this.__string(n):this.__union(t,n)}__indirect(t){return t+this.readInt32(t)}__vector(t){return t+this.readInt32(t)+4}__vector_len(t){return this.readInt32(t+this.readInt32(t))}__has_identifier(t){if(t.length!=4)throw new Error("FlatBuffers: file identifier must be length "+4);for(let n=0;n<4;n++)if(t.charCodeAt(n)!=this.readInt8(this.position()+4+n))return!1;return!0}createScalarList(t,n){let r=[];for(let i=0;i<n;++i){let o=t(i);o!==null&&r.push(o)}return r}createObjList(t,n){let r=[];for(let i=0;i<n;++i){let o=t(i);o!==null&&r.push(o.unpack())}return r}};var _c=class e{constructor(t){this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1,this.string_maps=null,this.text_encoder=new TextEncoder;let n;t?n=t:n=1024,this.bb=Nr.allocate(n),this.space=n}clear(){this.bb.clear(),this.space=this.bb.capacity(),this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1,this.string_maps=null}forceDefaults(t){this.force_defaults=t}dataBuffer(){return this.bb}asUint8Array(){return this.bb.bytes().subarray(this.bb.position(),this.bb.position()+this.offset())}prep(t,n){t>this.minalign&&(this.minalign=t);let r=~(this.bb.capacity()-this.space+n)+1&t-1;for(;this.space<r+t+n;){let i=this.bb.capacity();this.bb=e.growByteBuffer(this.bb),this.space+=this.bb.capacity()-i}this.pad(r)}pad(t){for(let n=0;n<t;n++)this.bb.writeInt8(--this.space,0)}writeInt8(t){this.bb.writeInt8(this.space-=1,t)}writeInt16(t){this.bb.writeInt16(this.space-=2,t)}writeInt32(t){this.bb.writeInt32(this.space-=4,t)}writeInt64(t){this.bb.writeInt64(this.space-=8,t)}writeFloat32(t){this.bb.writeFloat32(this.space-=4,t)}writeFloat64(t){this.bb.writeFloat64(this.space-=8,t)}addInt8(t){this.prep(1,0),this.writeInt8(t)}addInt16(t){this.prep(2,0),this.writeInt16(t)}addInt32(t){this.prep(4,0),this.writeInt32(t)}addInt64(t){this.prep(8,0),this.writeInt64(t)}addFloat32(t){this.prep(4,0),this.writeFloat32(t)}addFloat64(t){this.prep(8,0),this.writeFloat64(t)}addFieldInt8(t,n,r){(this.force_defaults||n!=r)&&(this.addInt8(n),this.slot(t))}addFieldInt16(t,n,r){(this.force_defaults||n!=r)&&(this.addInt16(n),this.slot(t))}addFieldInt32(t,n,r){(this.force_defaults||n!=r)&&(this.addInt32(n),this.slot(t))}addFieldInt64(t,n,r){(this.force_defaults||n!==r)&&(this.addInt64(n),this.slot(t))}addFieldFloat32(t,n,r){(this.force_defaults||n!=r)&&(this.addFloat32(n),this.slot(t))}addFieldFloat64(t,n,r){(this.force_defaults||n!=r)&&(this.addFloat64(n),this.slot(t))}addFieldOffset(t,n,r){(this.force_defaults||n!=r)&&(this.addOffset(n),this.slot(t))}addFieldStruct(t,n,r){n!=r&&(this.nested(n),this.slot(t))}nested(t){if(t!=this.offset())throw new TypeError("FlatBuffers: struct must be serialized inline.")}notNested(){if(this.isNested)throw new TypeError("FlatBuffers: object serialization must not be nested.")}slot(t){this.vtable!==null&&(this.vtable[t]=this.offset())}offset(){return this.bb.capacity()-this.space}static growByteBuffer(t){let n=t.capacity();if(n&3221225472)throw new Error("FlatBuffers: cannot grow buffer beyond 2 gigabytes.");let r=n<<1,i=Nr.allocate(r);return i.setPosition(r-n),i.bytes().set(t.bytes(),r-n),i}addOffset(t){this.prep(4,0),this.writeInt32(this.offset()-t+4)}startObject(t){this.notNested(),this.vtable==null&&(this.vtable=[]),this.vtable_in_use=t;for(let n=0;n<t;n++)this.vtable[n]=0;this.isNested=!0,this.object_start=this.offset()}endObject(){if(this.vtable==null||!this.isNested)throw new Error("FlatBuffers: endObject called without startObject");this.addInt32(0);let t=this.offset(),n=this.vtable_in_use-1;for(;n>=0&&this.vtable[n]==0;n--);let r=n+1;for(;n>=0;n--)this.addInt16(this.vtable[n]!=0?t-this.vtable[n]:0);let i=2;this.addInt16(t-this.object_start);let o=(r+i)*2;this.addInt16(o);let s=0,a=this.space;t:for(n=0;n<this.vtables.length;n++){let c=this.bb.capacity()-this.vtables[n];if(o==this.bb.readInt16(c)){for(let l=2;l<o;l+=2)if(this.bb.readInt16(a+l)!=this.bb.readInt16(c+l))continue t;s=this.vtables[n];break}}return s?(this.space=this.bb.capacity()-t,this.bb.writeInt32(this.space,s-t)):(this.vtables.push(this.offset()),this.bb.writeInt32(this.bb.capacity()-t,this.offset()-t)),this.isNested=!1,t}finish(t,n,r){let i=r?4:0;if(n){let o=n;if(this.prep(this.minalign,8+i),o.length!=4)throw new TypeError("FlatBuffers: file identifier must be length "+4);for(let s=3;s>=0;s--)this.writeInt8(o.charCodeAt(s))}this.prep(this.minalign,4+i),this.addOffset(t),i&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)}finishSizePrefixed(t,n){this.finish(t,n,!0)}requiredField(t,n){let r=this.bb.capacity()-t,i=r-this.bb.readInt32(r);if(!(n<this.bb.readInt16(i)&&this.bb.readInt16(i+n)!=0))throw new TypeError("FlatBuffers: field "+n+" must be set")}startVector(t,n,r){this.notNested(),this.vector_num_elems=n,this.prep(4,t*n),this.prep(r,t*n)}endVector(){return this.writeInt32(this.vector_num_elems),this.offset()}createSharedString(t){if(!t)return 0;if(this.string_maps||(this.string_maps=new Map),this.string_maps.has(t))return this.string_maps.get(t);let n=this.createString(t);return this.string_maps.set(t,n),n}createString(t){if(t==null)return 0;let n;t instanceof Uint8Array?n=t:n=this.text_encoder.encode(t),this.addInt8(0),this.startVector(1,n.length,1),this.bb.setPosition(this.space-=n.length);for(let r=0,i=this.space,o=this.bb.bytes();r<n.length;r++)o[i++]=n[r];return this.endVector()}createObjectOffset(t){return t===null?0:typeof t=="string"?this.createString(t):t.pack(this)}createObjectOffsetList(t){let n=[];for(let r=0;r<t.length;++r){let i=t[r];if(i!==null)n.push(this.createObjectOffset(i));else throw new TypeError("FlatBuffers: Argument for createObjectOffsetList cannot contain null.")}return n}createStructOffsetList(t,n){return n(this,t.length),this.createObjectOffsetList(t.slice().reverse()),this.endVector()}};var Ph;(function(e){e[e.BUFFER=0]="BUFFER"})(Ph||(Ph={}));var Uh;(function(e){e[e.LZ4_FRAME=0]="LZ4_FRAME",e[e.ZSTD=1]="ZSTD"})(Uh||(Uh={}));var Dg=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsBodyCompression(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsBodyCompression(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}codec(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt8(this.bb_pos+t):Uh.LZ4_FRAME}method(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.readInt8(this.bb_pos+t):Ph.BUFFER}static startBodyCompression(t){t.startObject(2)}static addCodec(t,n){t.addFieldInt8(0,n,Uh.LZ4_FRAME)}static addMethod(t,n){t.addFieldInt8(1,n,Ph.BUFFER)}static endBodyCompression(t){return t.endObject()}static createBodyCompression(t,n,r){return e.startBodyCompression(t),e.addCodec(t,n),e.addMethod(t,r),e.endBodyCompression(t)}};var tu=class{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}offset(){return this.bb.readInt64(this.bb_pos)}length(){return this.bb.readInt64(this.bb_pos+8)}static sizeOf(){return 16}static createBuffer(t,n,r){return t.prep(8,16),t.writeInt64(BigInt(r??0)),t.writeInt64(BigInt(n??0)),t.offset()}};var eu=class{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}length(){return this.bb.readInt64(this.bb_pos)}nullCount(){return this.bb.readInt64(this.bb_pos+8)}static sizeOf(){return 16}static createFieldNode(t,n,r){return t.prep(8,16),t.writeInt64(BigInt(r??0)),t.writeInt64(BigInt(n??0)),t.offset()}};var Dr=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsRecordBatch(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsRecordBatch(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}length(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt64(this.bb_pos+t):BigInt("0")}nodes(t,n){let r=this.bb.__offset(this.bb_pos,6);return r?(n||new eu).__init(this.bb.__vector(this.bb_pos+r)+t*16,this.bb):null}nodesLength(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.__vector_len(this.bb_pos+t):0}buffers(t,n){let r=this.bb.__offset(this.bb_pos,8);return r?(n||new tu).__init(this.bb.__vector(this.bb_pos+r)+t*16,this.bb):null}buffersLength(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.__vector_len(this.bb_pos+t):0}compression(t){let n=this.bb.__offset(this.bb_pos,10);return n?(t||new Dg).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}static startRecordBatch(t){t.startObject(4)}static addLength(t,n){t.addFieldInt64(0,n,BigInt("0"))}static addNodes(t,n){t.addFieldOffset(1,n,0)}static startNodesVector(t,n){t.startVector(16,n,8)}static addBuffers(t,n){t.addFieldOffset(2,n,0)}static startBuffersVector(t,n){t.startVector(16,n,8)}static addCompression(t,n){t.addFieldOffset(3,n,0)}static endRecordBatch(t){return t.endObject()}};var rs=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDictionaryBatch(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDictionaryBatch(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}id(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt64(this.bb_pos+t):BigInt("0")}data(t){let n=this.bb.__offset(this.bb_pos,6);return n?(t||new Dr).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}isDelta(){let t=this.bb.__offset(this.bb_pos,8);return t?!!this.bb.readInt8(this.bb_pos+t):!1}static startDictionaryBatch(t){t.startObject(3)}static addId(t,n){t.addFieldInt64(0,n,BigInt("0"))}static addData(t,n){t.addFieldOffset(1,n,0)}static addIsDelta(t,n){t.addFieldInt8(2,+n,0)}static endDictionaryBatch(t){return t.endObject()}};var fa;(function(e){e[e.Little=0]="Little",e[e.Big=1]="Big"})(fa||(fa={}));var zh;(function(e){e[e.DenseArray=0]="DenseArray"})(zh||(zh={}));var Ei=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsInt(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsInt(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}bitWidth(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt32(this.bb_pos+t):0}isSigned(){let t=this.bb.__offset(this.bb_pos,6);return t?!!this.bb.readInt8(this.bb_pos+t):!1}static startInt(t){t.startObject(2)}static addBitWidth(t,n){t.addFieldInt32(0,n,0)}static addIsSigned(t,n){t.addFieldInt8(1,+n,0)}static endInt(t){return t.endObject()}static createInt(t,n,r){return e.startInt(t),e.addBitWidth(t,n),e.addIsSigned(t,r),e.endInt(t)}};var to=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDictionaryEncoding(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDictionaryEncoding(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}id(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt64(this.bb_pos+t):BigInt("0")}indexType(t){let n=this.bb.__offset(this.bb_pos,6);return n?(t||new Ei).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}isOrdered(){let t=this.bb.__offset(this.bb_pos,8);return t?!!this.bb.readInt8(this.bb_pos+t):!1}dictionaryKind(){let t=this.bb.__offset(this.bb_pos,10);return t?this.bb.readInt16(this.bb_pos+t):zh.DenseArray}static startDictionaryEncoding(t){t.startObject(4)}static addId(t,n){t.addFieldInt64(0,n,BigInt("0"))}static addIndexType(t,n){t.addFieldOffset(1,n,0)}static addIsOrdered(t,n){t.addFieldInt8(2,+n,0)}static addDictionaryKind(t,n){t.addFieldInt16(3,n,zh.DenseArray)}static endDictionaryEncoding(t){return t.endObject()}};var nn=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsKeyValue(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsKeyValue(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}key(t){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,t):null}value(t){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,t):null}static startKeyValue(t){t.startObject(2)}static addKey(t,n){t.addFieldOffset(0,n,0)}static addValue(t,n){t.addFieldOffset(1,n,0)}static endKeyValue(t){return t.endObject()}static createKeyValue(t,n,r){return e.startKeyValue(t),e.addKey(t,n),e.addValue(t,r),e.endKeyValue(t)}};var qh=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsBinary(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsBinary(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startBinary(t){t.startObject(0)}static endBinary(t){return t.endObject()}static createBinary(t){return e.startBinary(t),e.endBinary(t)}};var jh=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsBool(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsBool(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startBool(t){t.startObject(0)}static endBool(t){return t.endObject()}static createBool(t){return e.startBool(t),e.endBool(t)}};var ha=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDate(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDate(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):Ve.MILLISECOND}static startDate(t){t.startObject(1)}static addUnit(t,n){t.addFieldInt16(0,n,Ve.MILLISECOND)}static endDate(t){return t.endObject()}static createDate(t,n){return e.startDate(t),e.addUnit(t,n),e.endDate(t)}};var eo=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDecimal(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDecimal(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}precision(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt32(this.bb_pos+t):0}scale(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.readInt32(this.bb_pos+t):0}bitWidth(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.readInt32(this.bb_pos+t):128}static startDecimal(t){t.startObject(3)}static addPrecision(t,n){t.addFieldInt32(0,n,0)}static addScale(t,n){t.addFieldInt32(1,n,0)}static addBitWidth(t,n){t.addFieldInt32(2,n,128)}static endDecimal(t){return t.endObject()}static createDecimal(t,n,r,i){return e.startDecimal(t),e.addPrecision(t,n),e.addScale(t,r),e.addBitWidth(t,i),e.endDecimal(t)}};var da=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsDuration(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsDuration(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ct.MILLISECOND}static startDuration(t){t.startObject(1)}static addUnit(t,n){t.addFieldInt16(0,n,ct.MILLISECOND)}static endDuration(t){return t.endObject()}static createDuration(t,n){return e.startDuration(t),e.addUnit(t,n),e.endDuration(t)}};var pa=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsFixedSizeBinary(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsFixedSizeBinary(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}byteWidth(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt32(this.bb_pos+t):0}static startFixedSizeBinary(t){t.startObject(1)}static addByteWidth(t,n){t.addFieldInt32(0,n,0)}static endFixedSizeBinary(t){return t.endObject()}static createFixedSizeBinary(t,n){return e.startFixedSizeBinary(t),e.addByteWidth(t,n),e.endFixedSizeBinary(t)}};var ma=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsFixedSizeList(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsFixedSizeList(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}listSize(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt32(this.bb_pos+t):0}static startFixedSizeList(t){t.startObject(1)}static addListSize(t,n){t.addFieldInt32(0,n,0)}static endFixedSizeList(t){return t.endObject()}static createFixedSizeList(t,n){return e.startFixedSizeList(t),e.addListSize(t,n),e.endFixedSizeList(t)}};var ya=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsFloatingPoint(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsFloatingPoint(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}precision(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):de.HALF}static startFloatingPoint(t){t.startObject(1)}static addPrecision(t,n){t.addFieldInt16(0,n,de.HALF)}static endFloatingPoint(t){return t.endObject()}static createFloatingPoint(t,n){return e.startFloatingPoint(t),e.addPrecision(t,n),e.endFloatingPoint(t)}};var ga=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsInterval(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsInterval(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):cn.YEAR_MONTH}static startInterval(t){t.startObject(1)}static addUnit(t,n){t.addFieldInt16(0,n,cn.YEAR_MONTH)}static endInterval(t){return t.endObject()}static createInterval(t,n){return e.startInterval(t),e.addUnit(t,n),e.endInterval(t)}};var Vh=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsLargeBinary(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsLargeBinary(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startLargeBinary(t){t.startObject(0)}static endLargeBinary(t){return t.endObject()}static createLargeBinary(t){return e.startLargeBinary(t),e.endLargeBinary(t)}};var Yh=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsLargeUtf8(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsLargeUtf8(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startLargeUtf8(t){t.startObject(0)}static endLargeUtf8(t){return t.endObject()}static createLargeUtf8(t){return e.startLargeUtf8(t),e.endLargeUtf8(t)}};var Xh=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsList(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsList(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startList(t){t.startObject(0)}static endList(t){return t.endObject()}static createList(t){return e.startList(t),e.endList(t)}};var xa=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsMap(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsMap(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}keysSorted(){let t=this.bb.__offset(this.bb_pos,4);return t?!!this.bb.readInt8(this.bb_pos+t):!1}static startMap(t){t.startObject(1)}static addKeysSorted(t,n){t.addFieldInt8(0,+n,0)}static endMap(t){return t.endObject()}static createMap(t,n){return e.startMap(t),e.addKeysSorted(t,n),e.endMap(t)}};var Gh=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsNull(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsNull(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startNull(t){t.startObject(0)}static endNull(t){return t.endObject()}static createNull(t){return e.startNull(t),e.endNull(t)}};var Wh=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsStruct_(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsStruct_(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startStruct_(t){t.startObject(0)}static endStruct_(t){return t.endObject()}static createStruct_(t){return e.startStruct_(t),e.endStruct_(t)}};var is=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsTime(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsTime(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ct.MILLISECOND}bitWidth(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.readInt32(this.bb_pos+t):32}static startTime(t){t.startObject(2)}static addUnit(t,n){t.addFieldInt16(0,n,ct.MILLISECOND)}static addBitWidth(t,n){t.addFieldInt32(1,n,32)}static endTime(t){return t.endObject()}static createTime(t,n,r){return e.startTime(t),e.addUnit(t,n),e.addBitWidth(t,r),e.endTime(t)}};var os=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsTimestamp(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsTimestamp(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}unit(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ct.SECOND}timezone(t){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.__string(this.bb_pos+n,t):null}static startTimestamp(t){t.startObject(2)}static addUnit(t,n){t.addFieldInt16(0,n,ct.SECOND)}static addTimezone(t,n){t.addFieldOffset(1,n,0)}static endTimestamp(t){return t.endObject()}static createTimestamp(t,n,r){return e.startTimestamp(t),e.addUnit(t,n),e.addTimezone(t,r),e.endTimestamp(t)}};var Ni=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsUnion(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsUnion(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}mode(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ge.Sparse}typeIds(t){let n=this.bb.__offset(this.bb_pos,6);return n?this.bb.readInt32(this.bb.__vector(this.bb_pos+n)+t*4):0}typeIdsLength(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.__vector_len(this.bb_pos+t):0}typeIdsArray(){let t=this.bb.__offset(this.bb_pos,6);return t?new Int32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+t),this.bb.__vector_len(this.bb_pos+t)):null}static startUnion(t){t.startObject(2)}static addMode(t,n){t.addFieldInt16(0,n,ge.Sparse)}static addTypeIds(t,n){t.addFieldOffset(1,n,0)}static createTypeIdsVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addInt32(n[r]);return t.endVector()}static startTypeIdsVector(t,n){t.startVector(4,n,4)}static endUnion(t){return t.endObject()}static createUnion(t,n,r){return e.startUnion(t),e.addMode(t,n),e.addTypeIds(t,r),e.endUnion(t)}};var Hh=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsUtf8(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsUtf8(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static startUtf8(t){t.startObject(0)}static endUtf8(t){return t.endObject()}static createUtf8(t){return e.startUtf8(t),e.endUtf8(t)}};var pe;(function(e){e[e.NONE=0]="NONE",e[e.Null=1]="Null",e[e.Int=2]="Int",e[e.FloatingPoint=3]="FloatingPoint",e[e.Binary=4]="Binary",e[e.Utf8=5]="Utf8",e[e.Bool=6]="Bool",e[e.Decimal=7]="Decimal",e[e.Date=8]="Date",e[e.Time=9]="Time",e[e.Timestamp=10]="Timestamp",e[e.Interval=11]="Interval",e[e.List=12]="List",e[e.Struct_=13]="Struct_",e[e.Union=14]="Union",e[e.FixedSizeBinary=15]="FixedSizeBinary",e[e.FixedSizeList=16]="FixedSizeList",e[e.Map=17]="Map",e[e.Duration=18]="Duration",e[e.LargeBinary=19]="LargeBinary",e[e.LargeUtf8=20]="LargeUtf8",e[e.LargeList=21]="LargeList",e[e.RunEndEncoded=22]="RunEndEncoded"})(pe||(pe={}));var Cn=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsField(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsField(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}name(t){let n=this.bb.__offset(this.bb_pos,4);return n?this.bb.__string(this.bb_pos+n,t):null}nullable(){let t=this.bb.__offset(this.bb_pos,6);return t?!!this.bb.readInt8(this.bb_pos+t):!1}typeType(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.readUint8(this.bb_pos+t):pe.NONE}type(t){let n=this.bb.__offset(this.bb_pos,10);return n?this.bb.__union(t,this.bb_pos+n):null}dictionary(t){let n=this.bb.__offset(this.bb_pos,12);return n?(t||new to).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}children(t,n){let r=this.bb.__offset(this.bb_pos,14);return r?(n||new e).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}childrenLength(){let t=this.bb.__offset(this.bb_pos,14);return t?this.bb.__vector_len(this.bb_pos+t):0}customMetadata(t,n){let r=this.bb.__offset(this.bb_pos,16);return r?(n||new nn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}customMetadataLength(){let t=this.bb.__offset(this.bb_pos,16);return t?this.bb.__vector_len(this.bb_pos+t):0}static startField(t){t.startObject(7)}static addName(t,n){t.addFieldOffset(0,n,0)}static addNullable(t,n){t.addFieldInt8(1,+n,0)}static addTypeType(t,n){t.addFieldInt8(2,n,pe.NONE)}static addType(t,n){t.addFieldOffset(3,n,0)}static addDictionary(t,n){t.addFieldOffset(4,n,0)}static addChildren(t,n){t.addFieldOffset(5,n,0)}static createChildrenVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startChildrenVector(t,n){t.startVector(4,n,4)}static addCustomMetadata(t,n){t.addFieldOffset(6,n,0)}static createCustomMetadataVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startCustomMetadataVector(t,n){t.startVector(4,n,4)}static endField(t){return t.endObject()}};var hr=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsSchema(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsSchema(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}endianness(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):fa.Little}fields(t,n){let r=this.bb.__offset(this.bb_pos,6);return r?(n||new Cn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}fieldsLength(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.__vector_len(this.bb_pos+t):0}customMetadata(t,n){let r=this.bb.__offset(this.bb_pos,8);return r?(n||new nn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}customMetadataLength(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.__vector_len(this.bb_pos+t):0}features(t){let n=this.bb.__offset(this.bb_pos,10);return n?this.bb.readInt64(this.bb.__vector(this.bb_pos+n)+t*8):BigInt(0)}featuresLength(){let t=this.bb.__offset(this.bb_pos,10);return t?this.bb.__vector_len(this.bb_pos+t):0}static startSchema(t){t.startObject(4)}static addEndianness(t,n){t.addFieldInt16(0,n,fa.Little)}static addFields(t,n){t.addFieldOffset(1,n,0)}static createFieldsVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startFieldsVector(t,n){t.startVector(4,n,4)}static addCustomMetadata(t,n){t.addFieldOffset(2,n,0)}static createCustomMetadataVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startCustomMetadataVector(t,n){t.startVector(4,n,4)}static addFeatures(t,n){t.addFieldOffset(3,n,0)}static createFeaturesVector(t,n){t.startVector(8,n.length,8);for(let r=n.length-1;r>=0;r--)t.addInt64(n[r]);return t.endVector()}static startFeaturesVector(t,n){t.startVector(8,n,8)}static endSchema(t){return t.endObject()}static finishSchemaBuffer(t,n){t.finish(n)}static finishSizePrefixedSchemaBuffer(t,n){t.finish(n,void 0,!0)}static createSchema(t,n,r,i,o){return e.startSchema(t),e.addEndianness(t,n),e.addFields(t,r),e.addCustomMetadata(t,i),e.addFeatures(t,o),e.endSchema(t)}};var qt;(function(e){e[e.NONE=0]="NONE",e[e.Schema=1]="Schema",e[e.DictionaryBatch=2]="DictionaryBatch",e[e.RecordBatch=3]="RecordBatch",e[e.Tensor=4]="Tensor",e[e.SparseTensor=5]="SparseTensor"})(qt||(qt={}));var L;(function(e){e[e.NONE=0]="NONE",e[e.Null=1]="Null",e[e.Int=2]="Int",e[e.Float=3]="Float",e[e.Binary=4]="Binary",e[e.Utf8=5]="Utf8",e[e.Bool=6]="Bool",e[e.Decimal=7]="Decimal",e[e.Date=8]="Date",e[e.Time=9]="Time",e[e.Timestamp=10]="Timestamp",e[e.Interval=11]="Interval",e[e.List=12]="List",e[e.Struct=13]="Struct",e[e.Union=14]="Union",e[e.FixedSizeBinary=15]="FixedSizeBinary",e[e.FixedSizeList=16]="FixedSizeList",e[e.Map=17]="Map",e[e.Duration=18]="Duration",e[e.LargeBinary=19]="LargeBinary",e[e.LargeUtf8=20]="LargeUtf8",e[e.Dictionary=-1]="Dictionary",e[e.Int8=-2]="Int8",e[e.Int16=-3]="Int16",e[e.Int32=-4]="Int32",e[e.Int64=-5]="Int64",e[e.Uint8=-6]="Uint8",e[e.Uint16=-7]="Uint16",e[e.Uint32=-8]="Uint32",e[e.Uint64=-9]="Uint64",e[e.Float16=-10]="Float16",e[e.Float32=-11]="Float32",e[e.Float64=-12]="Float64",e[e.DateDay=-13]="DateDay",e[e.DateMillisecond=-14]="DateMillisecond",e[e.TimestampSecond=-15]="TimestampSecond",e[e.TimestampMillisecond=-16]="TimestampMillisecond",e[e.TimestampMicrosecond=-17]="TimestampMicrosecond",e[e.TimestampNanosecond=-18]="TimestampNanosecond",e[e.TimeSecond=-19]="TimeSecond",e[e.TimeMillisecond=-20]="TimeMillisecond",e[e.TimeMicrosecond=-21]="TimeMicrosecond",e[e.TimeNanosecond=-22]="TimeNanosecond",e[e.DenseUnion=-23]="DenseUnion",e[e.SparseUnion=-24]="SparseUnion",e[e.IntervalDayTime=-25]="IntervalDayTime",e[e.IntervalYearMonth=-26]="IntervalYearMonth",e[e.DurationSecond=-27]="DurationSecond",e[e.DurationMillisecond=-28]="DurationMillisecond",e[e.DurationMicrosecond=-29]="DurationMicrosecond",e[e.DurationNanosecond=-30]="DurationNanosecond"})(L||(L={}));var Di;(function(e){e[e.OFFSET=0]="OFFSET",e[e.DATA=1]="DATA",e[e.VALIDITY=2]="VALIDITY",e[e.TYPE=3]="TYPE"})(Di||(Di={}));var K_={};Mr(K_,{clampIndex:()=>Yq,clampRange:()=>ld,createElementComparator:()=>va});var k_={};Mr(k_,{valueToString:()=>Oi});function Oi(e){if(e===null)return"null";if(e===void 0)return"undefined";switch(typeof e){case"number":return`${e}`;case"bigint":return`${e}`;case"string":return`"${e}"`}return typeof e[Symbol.toPrimitive]=="function"?e[Symbol.toPrimitive]("string"):ArrayBuffer.isView(e)?e instanceof BigInt64Array||e instanceof BigUint64Array?`[${[...e].map(t=>Oi(t))}]`:`[${e}]`:ArrayBuffer.isView(e)?`[${e}]`:JSON.stringify(e,(t,n)=>typeof n=="bigint"?`${n}`:n)}var R_={};Mr(R_,{BN:()=>Jh,bigNumToBigInt:()=>GD,bigNumToString:()=>iu,isArrowBigNumSymbol:()=>YD});var YD=Symbol.for("isArrowBigNum");function Bi(e,...t){return t.length===0?Object.setPrototypeOf(Pt(this.TypedArray,e),this.constructor.prototype):Object.setPrototypeOf(new this.TypedArray(e,...t),this.constructor.prototype)}Bi.prototype[YD]=!0;Bi.prototype.toJSON=function(){return`"${iu(this)}"`};Bi.prototype.valueOf=function(){return XD(this)};Bi.prototype.toString=function(){return iu(this)};Bi.prototype[Symbol.toPrimitive]=function(e="default"){switch(e){case"number":return XD(this);case"string":return iu(this);case"default":return GD(this)}return iu(this)};function nu(...e){return Bi.apply(this,e)}function ru(...e){return Bi.apply(this,e)}function Zh(...e){return Bi.apply(this,e)}Object.setPrototypeOf(nu.prototype,Object.create(Int32Array.prototype));Object.setPrototypeOf(ru.prototype,Object.create(Uint32Array.prototype));Object.setPrototypeOf(Zh.prototype,Object.create(Uint32Array.prototype));Object.assign(nu.prototype,Bi.prototype,{constructor:nu,signed:!0,TypedArray:Int32Array,BigIntArray:BigInt64Array});Object.assign(ru.prototype,Bi.prototype,{constructor:ru,signed:!1,TypedArray:Uint32Array,BigIntArray:BigUint64Array});Object.assign(Zh.prototype,Bi.prototype,{constructor:Zh,signed:!0,TypedArray:Uint32Array,BigIntArray:BigUint64Array});function XD(e){let{buffer:t,byteOffset:n,length:r,signed:i}=e,o=new BigUint64Array(t,n,r),s=i&&o.at(-1)&BigInt(1)<<BigInt(63),a=BigInt(s?1:0),c=BigInt(0);if(s){for(let l of o)a+=~l*(BigInt(1)<<BigInt(32)*c++);a*=BigInt(-1)}else for(let l of o)a+=l*(BigInt(1)<<BigInt(32)*c++);return a}var iu=e=>{if(e.byteLength===8)return`${new e.BigIntArray(e.buffer,e.byteOffset,1)[0]}`;if(!e.signed)return F_(e);let t=new Uint16Array(e.buffer,e.byteOffset,e.byteLength/2);if(new Int16Array([t.at(-1)])[0]>=0)return F_(e);t=t.slice();let r=1;for(let o=0;o<t.length;o++){let s=t[o],a=~s+r;t[o]=a,r&=s===0?1:0}return`-${F_(t)}`},GD=e=>e.byteLength===8?new e.BigIntArray(e.buffer,e.byteOffset,1)[0]:iu(e);function F_(e){let t="",n=new Uint32Array(2),r=new Uint16Array(e.buffer,e.byteOffset,e.byteLength/2),i=new Uint32Array((r=new Uint16Array(r).reverse()).buffer),o=-1,s=r.length-1;do{for(n[0]=r[o=0];o<s;)r[o++]=n[1]=n[0]/10,n[0]=(n[0]-n[1]*10<<16)+r[o];r[o]=n[1]=n[0]/10,n[0]=n[0]-n[1]*10,t=`${n[0]}${t}`}while(i[0]||i[1]||i[2]||i[3]);return t??"0"}var Jh=class e{static new(t,n){switch(n){case!0:return new nu(t);case!1:return new ru(t)}switch(t.constructor){case Int8Array:case Int16Array:case Int32Array:case BigInt64Array:return new nu(t)}return t.byteLength===16?new Zh(t):new ru(t)}static signed(t){return new nu(t)}static unsigned(t){return new ru(t)}static decimal(t){return new Zh(t)}constructor(t,n){return e.new(t,n)}};function De(e){if(typeof e=="bigint"&&(e<Number.MIN_SAFE_INTEGER||e>Number.MAX_SAFE_INTEGER))throw new TypeError(`${e} is not safe to convert to a number.`);return Number(e)}var WD,HD,ZD,JD,QD,KD,tO,eO,nO,rO,iO,oO,sO,aO,cO,lO,uO,fO,hO,dO,pO,mO,H=class e{static isNull(t){return t?.typeId===L.Null}static isInt(t){return t?.typeId===L.Int}static isFloat(t){return t?.typeId===L.Float}static isBinary(t){return t?.typeId===L.Binary}static isLargeBinary(t){return t?.typeId===L.LargeBinary}static isUtf8(t){return t?.typeId===L.Utf8}static isLargeUtf8(t){return t?.typeId===L.LargeUtf8}static isBool(t){return t?.typeId===L.Bool}static isDecimal(t){return t?.typeId===L.Decimal}static isDate(t){return t?.typeId===L.Date}static isTime(t){return t?.typeId===L.Time}static isTimestamp(t){return t?.typeId===L.Timestamp}static isInterval(t){return t?.typeId===L.Interval}static isDuration(t){return t?.typeId===L.Duration}static isList(t){return t?.typeId===L.List}static isStruct(t){return t?.typeId===L.Struct}static isUnion(t){return t?.typeId===L.Union}static isFixedSizeBinary(t){return t?.typeId===L.FixedSizeBinary}static isFixedSizeList(t){return t?.typeId===L.FixedSizeList}static isMap(t){return t?.typeId===L.Map}static isDictionary(t){return t?.typeId===L.Dictionary}static isDenseUnion(t){return e.isUnion(t)&&t.mode===ge.Dense}static isSparseUnion(t){return e.isUnion(t)&&t.mode===ge.Sparse}constructor(t){this.typeId=t}};WD=Symbol.toStringTag;H[WD]=(e=>(e.children=null,e.ArrayType=Array,e.OffsetArrayType=Int32Array,e[Symbol.toStringTag]="DataType"))(H.prototype);var kn=class extends H{constructor(){super(L.Null)}toString(){return"Null"}};HD=Symbol.toStringTag;kn[HD]=(e=>e[Symbol.toStringTag]="Null")(kn.prototype);var ke=class extends H{constructor(t,n){super(L.Int),this.isSigned=t,this.bitWidth=n}get ArrayType(){switch(this.bitWidth){case 8:return this.isSigned?Int8Array:Uint8Array;case 16:return this.isSigned?Int16Array:Uint16Array;case 32:return this.isSigned?Int32Array:Uint32Array;case 64:return this.isSigned?BigInt64Array:BigUint64Array}throw new Error(`Unrecognized ${this[Symbol.toStringTag]} type`)}toString(){return`${this.isSigned?"I":"Ui"}nt${this.bitWidth}`}};ZD=Symbol.toStringTag;ke[ZD]=(e=>(e.isSigned=null,e.bitWidth=null,e[Symbol.toStringTag]="Int"))(ke.prototype);var Qh=class extends ke{constructor(){super(!0,8)}get ArrayType(){return Int8Array}},Kh=class extends ke{constructor(){super(!0,16)}get ArrayType(){return Int16Array}},Li=class extends ke{constructor(){super(!0,32)}get ArrayType(){return Int32Array}},td=class extends ke{constructor(){super(!0,64)}get ArrayType(){return BigInt64Array}},ed=class extends ke{constructor(){super(!1,8)}get ArrayType(){return Uint8Array}},nd=class extends ke{constructor(){super(!1,16)}get ArrayType(){return Uint16Array}},rd=class extends ke{constructor(){super(!1,32)}get ArrayType(){return Uint32Array}},id=class extends ke{constructor(){super(!1,64)}get ArrayType(){return BigUint64Array}};Object.defineProperty(Qh.prototype,"ArrayType",{value:Int8Array});Object.defineProperty(Kh.prototype,"ArrayType",{value:Int16Array});Object.defineProperty(Li.prototype,"ArrayType",{value:Int32Array});Object.defineProperty(td.prototype,"ArrayType",{value:BigInt64Array});Object.defineProperty(ed.prototype,"ArrayType",{value:Uint8Array});Object.defineProperty(nd.prototype,"ArrayType",{value:Uint16Array});Object.defineProperty(rd.prototype,"ArrayType",{value:Uint32Array});Object.defineProperty(id.prototype,"ArrayType",{value:BigUint64Array});var Gn=class extends H{constructor(t){super(L.Float),this.precision=t}get ArrayType(){switch(this.precision){case de.HALF:return Uint16Array;case de.SINGLE:return Float32Array;case de.DOUBLE:return Float64Array}throw new Error(`Unrecognized ${this[Symbol.toStringTag]} type`)}toString(){return`Float${this.precision<<5||16}`}};JD=Symbol.toStringTag;Gn[JD]=(e=>(e.precision=null,e[Symbol.toStringTag]="Float"))(Gn.prototype);var od=class extends Gn{constructor(){super(de.HALF)}},sd=class extends Gn{constructor(){super(de.SINGLE)}},ad=class extends Gn{constructor(){super(de.DOUBLE)}};Object.defineProperty(od.prototype,"ArrayType",{value:Uint16Array});Object.defineProperty(sd.prototype,"ArrayType",{value:Float32Array});Object.defineProperty(ad.prototype,"ArrayType",{value:Float64Array});var no=class extends H{constructor(){super(L.Binary)}toString(){return"Binary"}};QD=Symbol.toStringTag;no[QD]=(e=>(e.ArrayType=Uint8Array,e[Symbol.toStringTag]="Binary"))(no.prototype);var ro=class extends H{constructor(){super(L.LargeBinary)}toString(){return"LargeBinary"}};KD=Symbol.toStringTag;ro[KD]=(e=>(e.ArrayType=Uint8Array,e.OffsetArrayType=BigInt64Array,e[Symbol.toStringTag]="LargeBinary"))(ro.prototype);var io=class extends H{constructor(){super(L.Utf8)}toString(){return"Utf8"}};tO=Symbol.toStringTag;io[tO]=(e=>(e.ArrayType=Uint8Array,e[Symbol.toStringTag]="Utf8"))(io.prototype);var oo=class extends H{constructor(){super(L.LargeUtf8)}toString(){return"LargeUtf8"}};eO=Symbol.toStringTag;oo[eO]=(e=>(e.ArrayType=Uint8Array,e.OffsetArrayType=BigInt64Array,e[Symbol.toStringTag]="LargeUtf8"))(oo.prototype);var so=class extends H{constructor(){super(L.Bool)}toString(){return"Bool"}};nO=Symbol.toStringTag;so[nO]=(e=>(e.ArrayType=Uint8Array,e[Symbol.toStringTag]="Bool"))(so.prototype);var ao=class extends H{constructor(t,n,r=128){super(L.Decimal),this.scale=t,this.precision=n,this.bitWidth=r}toString(){return`Decimal[${this.precision}e${this.scale>0?"+":""}${this.scale}]`}};rO=Symbol.toStringTag;ao[rO]=(e=>(e.scale=null,e.precision=null,e.ArrayType=Uint32Array,e[Symbol.toStringTag]="Decimal"))(ao.prototype);var co=class extends H{constructor(t){super(L.Date),this.unit=t}toString(){return`Date${(this.unit+1)*32}<${Ve[this.unit]}>`}};iO=Symbol.toStringTag;co[iO]=(e=>(e.unit=null,e.ArrayType=Int32Array,e[Symbol.toStringTag]="Date"))(co.prototype);var Zr=class extends H{constructor(t,n){super(L.Time),this.unit=t,this.bitWidth=n}toString(){return`Time${this.bitWidth}<${ct[this.unit]}>`}get ArrayType(){switch(this.bitWidth){case 32:return Int32Array;case 64:return BigInt64Array}throw new Error(`Unrecognized ${this[Symbol.toStringTag]} type`)}};oO=Symbol.toStringTag;Zr[oO]=(e=>(e.unit=null,e.bitWidth=null,e[Symbol.toStringTag]="Time"))(Zr.prototype);var lo=class extends H{constructor(t,n){super(L.Timestamp),this.unit=t,this.timezone=n}toString(){return`Timestamp<${ct[this.unit]}${this.timezone?`, ${this.timezone}`:""}>`}};sO=Symbol.toStringTag;lo[sO]=(e=>(e.unit=null,e.timezone=null,e.ArrayType=Int32Array,e[Symbol.toStringTag]="Timestamp"))(lo.prototype);var uo=class extends H{constructor(t){super(L.Interval),this.unit=t}toString(){return`Interval<${cn[this.unit]}>`}};aO=Symbol.toStringTag;uo[aO]=(e=>(e.unit=null,e.ArrayType=Int32Array,e[Symbol.toStringTag]="Interval"))(uo.prototype);var fo=class extends H{constructor(t){super(L.Duration),this.unit=t}toString(){return`Duration<${ct[this.unit]}>`}};cO=Symbol.toStringTag;fo[cO]=(e=>(e.unit=null,e.ArrayType=BigInt64Array,e[Symbol.toStringTag]="Duration"))(fo.prototype);var Jr=class extends H{constructor(t){super(L.List),this.children=[t]}toString(){return`List<${this.valueType}>`}get valueType(){return this.children[0].type}get valueField(){return this.children[0]}get ArrayType(){return this.valueType.ArrayType}};lO=Symbol.toStringTag;Jr[lO]=(e=>(e.children=null,e[Symbol.toStringTag]="List"))(Jr.prototype);var xe=class extends H{constructor(t){super(L.Struct),this.children=t}toString(){return`Struct<{${this.children.map(t=>`${t.name}:${t.type}`).join(", ")}}>`}};uO=Symbol.toStringTag;xe[uO]=(e=>(e.children=null,e[Symbol.toStringTag]="Struct"))(xe.prototype);var Qr=class extends H{constructor(t,n,r){super(L.Union),this.mode=t,this.children=r,this.typeIds=n=Int32Array.from(n),this.typeIdToChildIndex=n.reduce((i,o,s)=>(i[o]=s)&&i||i,Object.create(null))}toString(){return`${this[Symbol.toStringTag]}<${this.children.map(t=>`${t.type}`).join(" | ")}>`}};fO=Symbol.toStringTag;Qr[fO]=(e=>(e.mode=null,e.typeIds=null,e.children=null,e.typeIdToChildIndex=null,e.ArrayType=Int8Array,e[Symbol.toStringTag]="Union"))(Qr.prototype);var ho=class extends H{constructor(t){super(L.FixedSizeBinary),this.byteWidth=t}toString(){return`FixedSizeBinary[${this.byteWidth}]`}};hO=Symbol.toStringTag;ho[hO]=(e=>(e.byteWidth=null,e.ArrayType=Uint8Array,e[Symbol.toStringTag]="FixedSizeBinary"))(ho.prototype);var Kr=class extends H{constructor(t,n){super(L.FixedSizeList),this.listSize=t,this.children=[n]}get valueType(){return this.children[0].type}get valueField(){return this.children[0]}get ArrayType(){return this.valueType.ArrayType}toString(){return`FixedSizeList[${this.listSize}]<${this.valueType}>`}};dO=Symbol.toStringTag;Kr[dO]=(e=>(e.children=null,e.listSize=null,e[Symbol.toStringTag]="FixedSizeList"))(Kr.prototype);var ti=class extends H{constructor(t,n=!1){var r,i,o;if(super(L.Map),this.children=[t],this.keysSorted=n,t&&(t.name="entries",!((r=t?.type)===null||r===void 0)&&r.children)){let s=(i=t?.type)===null||i===void 0?void 0:i.children[0];s&&(s.name="key");let a=(o=t?.type)===null||o===void 0?void 0:o.children[1];a&&(a.name="value")}}get keyType(){return this.children[0].type.children[0].type}get valueType(){return this.children[0].type.children[1].type}get childType(){return this.children[0].type}toString(){return`Map<{${this.children[0].type.children.map(t=>`${t.name}:${t.type}`).join(", ")}}>`}};pO=Symbol.toStringTag;ti[pO]=(e=>(e.children=null,e.keysSorted=null,e[Symbol.toStringTag]="Map_"))(ti.prototype);var oq=(e=>()=>++e)(-1),dr=class extends H{constructor(t,n,r,i){super(L.Dictionary),this.indices=n,this.dictionary=t,this.isOrdered=i||!1,this.id=r==null?oq():De(r)}get children(){return this.dictionary.children}get valueType(){return this.dictionary}get ArrayType(){return this.dictionary.ArrayType}toString(){return`Dictionary<${this.indices}, ${this.dictionary}>`}};mO=Symbol.toStringTag;dr[mO]=(e=>(e.id=null,e.indices=null,e.isOrdered=null,e.dictionary=null,e[Symbol.toStringTag]="Dictionary"))(dr.prototype);function Or(e){let t=e;switch(e.typeId){case L.Decimal:return e.bitWidth/32;case L.Timestamp:return 2;case L.Date:return 1+t.unit;case L.Interval:return 1+t.unit;case L.FixedSizeList:return t.listSize;case L.FixedSizeBinary:return t.byteWidth;default:return 1}}var mt=class{visitMany(t,...n){return t.map((r,i)=>this.visit(r,...n.map(o=>o[i])))}visit(...t){return this.getVisitFn(t[0],!1).apply(this,t)}getVisitFn(t,n=!0){return sq(this,t,n)}getVisitFnByTypeId(t,n=!0){return ou(this,t,n)}visitNull(t,...n){return null}visitBool(t,...n){return null}visitInt(t,...n){return null}visitFloat(t,...n){return null}visitUtf8(t,...n){return null}visitLargeUtf8(t,...n){return null}visitBinary(t,...n){return null}visitLargeBinary(t,...n){return null}visitFixedSizeBinary(t,...n){return null}visitDate(t,...n){return null}visitTimestamp(t,...n){return null}visitTime(t,...n){return null}visitDecimal(t,...n){return null}visitList(t,...n){return null}visitStruct(t,...n){return null}visitUnion(t,...n){return null}visitDictionary(t,...n){return null}visitInterval(t,...n){return null}visitDuration(t,...n){return null}visitFixedSizeList(t,...n){return null}visitMap(t,...n){return null}};function sq(e,t,n=!0){return typeof t=="number"?ou(e,t,n):typeof t=="string"&&t in L?ou(e,L[t],n):t&&t instanceof H?ou(e,yO(t),n):t?.type&&t.type instanceof H?ou(e,yO(t.type),n):ou(e,L.NONE,n)}function ou(e,t,n=!0){let r=null;switch(t){case L.Null:r=e.visitNull;break;case L.Bool:r=e.visitBool;break;case L.Int:r=e.visitInt;break;case L.Int8:r=e.visitInt8||e.visitInt;break;case L.Int16:r=e.visitInt16||e.visitInt;break;case L.Int32:r=e.visitInt32||e.visitInt;break;case L.Int64:r=e.visitInt64||e.visitInt;break;case L.Uint8:r=e.visitUint8||e.visitInt;break;case L.Uint16:r=e.visitUint16||e.visitInt;break;case L.Uint32:r=e.visitUint32||e.visitInt;break;case L.Uint64:r=e.visitUint64||e.visitInt;break;case L.Float:r=e.visitFloat;break;case L.Float16:r=e.visitFloat16||e.visitFloat;break;case L.Float32:r=e.visitFloat32||e.visitFloat;break;case L.Float64:r=e.visitFloat64||e.visitFloat;break;case L.Utf8:r=e.visitUtf8;break;case L.LargeUtf8:r=e.visitLargeUtf8;break;case L.Binary:r=e.visitBinary;break;case L.LargeBinary:r=e.visitLargeBinary;break;case L.FixedSizeBinary:r=e.visitFixedSizeBinary;break;case L.Date:r=e.visitDate;break;case L.DateDay:r=e.visitDateDay||e.visitDate;break;case L.DateMillisecond:r=e.visitDateMillisecond||e.visitDate;break;case L.Timestamp:r=e.visitTimestamp;break;case L.TimestampSecond:r=e.visitTimestampSecond||e.visitTimestamp;break;case L.TimestampMillisecond:r=e.visitTimestampMillisecond||e.visitTimestamp;break;case L.TimestampMicrosecond:r=e.visitTimestampMicrosecond||e.visitTimestamp;break;case L.TimestampNanosecond:r=e.visitTimestampNanosecond||e.visitTimestamp;break;case L.Time:r=e.visitTime;break;case L.TimeSecond:r=e.visitTimeSecond||e.visitTime;break;case L.TimeMillisecond:r=e.visitTimeMillisecond||e.visitTime;break;case L.TimeMicrosecond:r=e.visitTimeMicrosecond||e.visitTime;break;case L.TimeNanosecond:r=e.visitTimeNanosecond||e.visitTime;break;case L.Decimal:r=e.visitDecimal;break;case L.List:r=e.visitList;break;case L.Struct:r=e.visitStruct;break;case L.Union:r=e.visitUnion;break;case L.DenseUnion:r=e.visitDenseUnion||e.visitUnion;break;case L.SparseUnion:r=e.visitSparseUnion||e.visitUnion;break;case L.Dictionary:r=e.visitDictionary;break;case L.Interval:r=e.visitInterval;break;case L.IntervalDayTime:r=e.visitIntervalDayTime||e.visitInterval;break;case L.IntervalYearMonth:r=e.visitIntervalYearMonth||e.visitInterval;break;case L.Duration:r=e.visitDuration;break;case L.DurationSecond:r=e.visitDurationSecond||e.visitDuration;break;case L.DurationMillisecond:r=e.visitDurationMillisecond||e.visitDuration;break;case L.DurationMicrosecond:r=e.visitDurationMicrosecond||e.visitDuration;break;case L.DurationNanosecond:r=e.visitDurationNanosecond||e.visitDuration;break;case L.FixedSizeList:r=e.visitFixedSizeList;break;case L.Map:r=e.visitMap;break}if(typeof r=="function")return r;if(!n)return()=>null;throw new Error(`Unrecognized type '${L[t]}'`)}function yO(e){switch(e.typeId){case L.Null:return L.Null;case L.Int:{let{bitWidth:t,isSigned:n}=e;switch(t){case 8:return n?L.Int8:L.Uint8;case 16:return n?L.Int16:L.Uint16;case 32:return n?L.Int32:L.Uint32;case 64:return n?L.Int64:L.Uint64}return L.Int}case L.Float:switch(e.precision){case de.HALF:return L.Float16;case de.SINGLE:return L.Float32;case de.DOUBLE:return L.Float64}return L.Float;case L.Binary:return L.Binary;case L.LargeBinary:return L.LargeBinary;case L.Utf8:return L.Utf8;case L.LargeUtf8:return L.LargeUtf8;case L.Bool:return L.Bool;case L.Decimal:return L.Decimal;case L.Time:switch(e.unit){case ct.SECOND:return L.TimeSecond;case ct.MILLISECOND:return L.TimeMillisecond;case ct.MICROSECOND:return L.TimeMicrosecond;case ct.NANOSECOND:return L.TimeNanosecond}return L.Time;case L.Timestamp:switch(e.unit){case ct.SECOND:return L.TimestampSecond;case ct.MILLISECOND:return L.TimestampMillisecond;case ct.MICROSECOND:return L.TimestampMicrosecond;case ct.NANOSECOND:return L.TimestampNanosecond}return L.Timestamp;case L.Date:switch(e.unit){case Ve.DAY:return L.DateDay;case Ve.MILLISECOND:return L.DateMillisecond}return L.Date;case L.Interval:switch(e.unit){case cn.DAY_TIME:return L.IntervalDayTime;case cn.YEAR_MONTH:return L.IntervalYearMonth}return L.Interval;case L.Duration:switch(e.unit){case ct.SECOND:return L.DurationSecond;case ct.MILLISECOND:return L.DurationMillisecond;case ct.MICROSECOND:return L.DurationMicrosecond;case ct.NANOSECOND:return L.DurationNanosecond}return L.Duration;case L.Map:return L.Map;case L.List:return L.List;case L.Struct:return L.Struct;case L.Union:switch(e.mode){case ge.Dense:return L.DenseUnion;case ge.Sparse:return L.SparseUnion}return L.Union;case L.FixedSizeBinary:return L.FixedSizeBinary;case L.FixedSizeList:return L.FixedSizeList;case L.Dictionary:return L.Dictionary}throw new Error(`Unrecognized type '${L[e.typeId]}'`)}mt.prototype.visitInt8=null;mt.prototype.visitInt16=null;mt.prototype.visitInt32=null;mt.prototype.visitInt64=null;mt.prototype.visitUint8=null;mt.prototype.visitUint16=null;mt.prototype.visitUint32=null;mt.prototype.visitUint64=null;mt.prototype.visitFloat16=null;mt.prototype.visitFloat32=null;mt.prototype.visitFloat64=null;mt.prototype.visitDateDay=null;mt.prototype.visitDateMillisecond=null;mt.prototype.visitTimestampSecond=null;mt.prototype.visitTimestampMillisecond=null;mt.prototype.visitTimestampMicrosecond=null;mt.prototype.visitTimestampNanosecond=null;mt.prototype.visitTimeSecond=null;mt.prototype.visitTimeMillisecond=null;mt.prototype.visitTimeMicrosecond=null;mt.prototype.visitTimeNanosecond=null;mt.prototype.visitDenseUnion=null;mt.prototype.visitSparseUnion=null;mt.prototype.visitIntervalDayTime=null;mt.prototype.visitIntervalYearMonth=null;mt.prototype.visitDuration=null;mt.prototype.visitDurationSecond=null;mt.prototype.visitDurationMillisecond=null;mt.prototype.visitDurationMicrosecond=null;mt.prototype.visitDurationNanosecond=null;var $_={};Mr($_,{float64ToUint16:()=>cd,uint16ToFloat64:()=>Og});var gO=new Float64Array(1),su=new Uint32Array(gO.buffer);function Og(e){let t=(e&31744)>>10,n=(e&1023)/1024,r=Math.pow(-1,(e&32768)>>15);switch(t){case 31:return r*(n?Number.NaN:1/0);case 0:return r*(n?6103515625e-14*n:0)}return r*Math.pow(2,t-15)*(1+n)}function cd(e){if(e!==e)return 32256;gO[0]=e;let t=(su[1]&2147483648)>>16&65535,n=su[1]&2146435072,r=0;return n>=1089470464?su[0]>0?n=31744:(n=(n&2080374784)>>16,r=(su[1]&1048575)>>10):n<=1056964608?(r=1048576+(su[1]&1048575),r=1048576+(r<<(n>>20)-998)>>21,n=0):(n=n-1056964608>>10,r=(su[1]&1048575)+512>>10),t|n|r&65535}var vt=class extends mt{};function Tt(e){return(t,n,r)=>{if(t.setValid(n,r!=null))return e(t,n,r)}}var aq=(e,t,n)=>{e[t]=Math.trunc(n/864e5)},P_=(e,t,n)=>{e[t]=Math.trunc(n%4294967296),e[t+1]=Math.trunc(n/4294967296)},cq=(e,t,n)=>{e[t]=Math.trunc(n*1e3%4294967296),e[t+1]=Math.trunc(n*1e3/4294967296)},lq=(e,t,n)=>{e[t]=Math.trunc(n*1e6%4294967296),e[t+1]=Math.trunc(n*1e6/4294967296)},xO=(e,t,n,r)=>{if(n+1<t.length){let i=De(t[n]),o=De(t[n+1]);e.set(r.subarray(0,o-i),i)}},uq=({offset:e,values:t},n,r)=>{let i=e+n;r?t[i>>3]|=1<<i%8:t[i>>3]&=~(1<<i%8)},ss=({values:e},t,n)=>{e[t]=n},U_=({values:e},t,n)=>{e[t]=n},bO=({values:e},t,n)=>{e[t]=cd(n)},fq=(e,t,n)=>{switch(e.type.precision){case de.HALF:return bO(e,t,n);case de.SINGLE:case de.DOUBLE:return U_(e,t,n)}},Bg=({values:e},t,n)=>{aq(e,t,n.valueOf())},Lg=({values:e},t,n)=>{P_(e,t*2,n.valueOf())},z_=({stride:e,values:t},n,r)=>{t.set(r.subarray(0,e),e*n)},wO=({values:e,valueOffsets:t},n,r)=>xO(e,t,n,r),vO=({values:e,valueOffsets:t},n,r)=>xO(e,t,n,Ji(r)),q_=(e,t,n)=>{e.type.unit===Ve.DAY?Bg(e,t,n):Lg(e,t,n)},Cg=({values:e},t,n)=>P_(e,t*2,n/1e3),kg=({values:e},t,n)=>P_(e,t*2,n),Fg=({values:e},t,n)=>cq(e,t*2,n),Rg=({values:e},t,n)=>lq(e,t*2,n),j_=(e,t,n)=>{switch(e.type.unit){case ct.SECOND:return Cg(e,t,n);case ct.MILLISECOND:return kg(e,t,n);case ct.MICROSECOND:return Fg(e,t,n);case ct.NANOSECOND:return Rg(e,t,n)}},$g=({values:e},t,n)=>{e[t]=n},Pg=({values:e},t,n)=>{e[t]=n},Ug=({values:e},t,n)=>{e[t]=n},zg=({values:e},t,n)=>{e[t]=n},V_=(e,t,n)=>{switch(e.type.unit){case ct.SECOND:return $g(e,t,n);case ct.MILLISECOND:return Pg(e,t,n);case ct.MICROSECOND:return Ug(e,t,n);case ct.NANOSECOND:return zg(e,t,n)}},Y_=({values:e,stride:t},n,r)=>{e.set(r.subarray(0,t),t*n)},hq=(e,t,n)=>{let r=e.children[0],i=e.valueOffsets,o=vn.getVisitFn(r);if(Array.isArray(n))for(let s=-1,a=i[t],c=i[t+1];a<c;)o(r,a++,n[++s]);else for(let s=-1,a=i[t],c=i[t+1];a<c;)o(r,a++,n.get(++s))},dq=(e,t,n)=>{let r=e.children[0],{valueOffsets:i}=e,o=vn.getVisitFn(r),{[t]:s,[t+1]:a}=i,c=n instanceof Map?n.entries():Object.entries(n);for(let l of c)if(o(r,s,l),++s>=a)break},pq=(e,t)=>(n,r,i,o)=>r&&n(r,e,t[o]),mq=(e,t)=>(n,r,i,o)=>r&&n(r,e,t.get(o)),yq=(e,t)=>(n,r,i,o)=>r&&n(r,e,t.get(i.name)),gq=(e,t)=>(n,r,i,o)=>r&&n(r,e,t[i.name]),xq=(e,t,n)=>{let r=e.type.children.map(o=>vn.getVisitFn(o.type)),i=n instanceof Map?yq(t,n):n instanceof Xt?mq(t,n):Array.isArray(n)?pq(t,n):gq(t,n);e.type.children.forEach((o,s)=>i(r[s],e.children[s],o,s))},bq=(e,t,n)=>{e.type.mode===ge.Dense?_O(e,t,n):SO(e,t,n)},_O=(e,t,n)=>{let r=e.type.typeIdToChildIndex[e.typeIds[t]],i=e.children[r];vn.visit(i,e.valueOffsets[t],n)},SO=(e,t,n)=>{let r=e.type.typeIdToChildIndex[e.typeIds[t]],i=e.children[r];vn.visit(i,t,n)},wq=(e,t,n)=>{var r;(r=e.dictionary)===null||r===void 0||r.set(e.values[t],n)},X_=(e,t,n)=>{e.type.unit===cn.DAY_TIME?qg(e,t,n):jg(e,t,n)},qg=({values:e},t,n)=>{e.set(n.subarray(0,2),2*t)},jg=({values:e},t,n)=>{e[t]=n[0]*12+n[1]%12},Vg=({values:e},t,n)=>{e[t]=n},Yg=({values:e},t,n)=>{e[t]=n},Xg=({values:e},t,n)=>{e[t]=n},Gg=({values:e},t,n)=>{e[t]=n},G_=(e,t,n)=>{switch(e.type.unit){case ct.SECOND:return Vg(e,t,n);case ct.MILLISECOND:return Yg(e,t,n);case ct.MICROSECOND:return Xg(e,t,n);case ct.NANOSECOND:return Gg(e,t,n)}},vq=(e,t,n)=>{let{stride:r}=e,i=e.children[0],o=vn.getVisitFn(i);if(Array.isArray(n))for(let s=-1,a=t*r;++s<r;)o(i,a+s,n[s]);else for(let s=-1,a=t*r;++s<r;)o(i,a+s,n.get(s))};vt.prototype.visitBool=Tt(uq);vt.prototype.visitInt=Tt(ss);vt.prototype.visitInt8=Tt(ss);vt.prototype.visitInt16=Tt(ss);vt.prototype.visitInt32=Tt(ss);vt.prototype.visitInt64=Tt(ss);vt.prototype.visitUint8=Tt(ss);vt.prototype.visitUint16=Tt(ss);vt.prototype.visitUint32=Tt(ss);vt.prototype.visitUint64=Tt(ss);vt.prototype.visitFloat=Tt(fq);vt.prototype.visitFloat16=Tt(bO);vt.prototype.visitFloat32=Tt(U_);vt.prototype.visitFloat64=Tt(U_);vt.prototype.visitUtf8=Tt(vO);vt.prototype.visitLargeUtf8=Tt(vO);vt.prototype.visitBinary=Tt(wO);vt.prototype.visitLargeBinary=Tt(wO);vt.prototype.visitFixedSizeBinary=Tt(z_);vt.prototype.visitDate=Tt(q_);vt.prototype.visitDateDay=Tt(Bg);vt.prototype.visitDateMillisecond=Tt(Lg);vt.prototype.visitTimestamp=Tt(j_);vt.prototype.visitTimestampSecond=Tt(Cg);vt.prototype.visitTimestampMillisecond=Tt(kg);vt.prototype.visitTimestampMicrosecond=Tt(Fg);vt.prototype.visitTimestampNanosecond=Tt(Rg);vt.prototype.visitTime=Tt(V_);vt.prototype.visitTimeSecond=Tt($g);vt.prototype.visitTimeMillisecond=Tt(Pg);vt.prototype.visitTimeMicrosecond=Tt(Ug);vt.prototype.visitTimeNanosecond=Tt(zg);vt.prototype.visitDecimal=Tt(Y_);vt.prototype.visitList=Tt(hq);vt.prototype.visitStruct=Tt(xq);vt.prototype.visitUnion=Tt(bq);vt.prototype.visitDenseUnion=Tt(_O);vt.prototype.visitSparseUnion=Tt(SO);vt.prototype.visitDictionary=Tt(wq);vt.prototype.visitInterval=Tt(X_);vt.prototype.visitIntervalDayTime=Tt(qg);vt.prototype.visitIntervalYearMonth=Tt(jg);vt.prototype.visitDuration=Tt(G_);vt.prototype.visitDurationSecond=Tt(Vg);vt.prototype.visitDurationMillisecond=Tt(Yg);vt.prototype.visitDurationMicrosecond=Tt(Xg);vt.prototype.visitDurationNanosecond=Tt(Gg);vt.prototype.visitFixedSizeList=Tt(vq);vt.prototype.visitMap=Tt(dq);var vn=new vt;var Ci=Symbol.for("parent"),au=Symbol.for("rowIndex"),ba=class{constructor(t,n){return this[Ci]=t,this[au]=n,new Proxy(this,new H_)}toArray(){return Object.values(this.toJSON())}toJSON(){let t=this[au],n=this[Ci],r=n.type.children,i={};for(let o=-1,s=r.length;++o<s;)i[r[o].name]=Ye.visit(n.children[o],t);return i}toString(){return`{${[...this].map(([t,n])=>`${Oi(t)}: ${Oi(n)}`).join(", ")}}`}[Symbol.for("nodejs.util.inspect.custom")](){return this.toString()}[Symbol.iterator](){return new W_(this[Ci],this[au])}},W_=class{constructor(t,n){this.childIndex=0,this.children=t.children,this.rowIndex=n,this.childFields=t.type.children,this.numChildren=this.childFields.length}[Symbol.iterator](){return this}next(){let t=this.childIndex;return t<this.numChildren?(this.childIndex=t+1,{done:!1,value:[this.childFields[t].name,Ye.visit(this.children[t],this.rowIndex)]}):{done:!0,value:null}}};Object.defineProperties(ba.prototype,{[Symbol.toStringTag]:{enumerable:!1,configurable:!1,value:"Row"},[Ci]:{writable:!0,enumerable:!1,configurable:!1,value:null},[au]:{writable:!0,enumerable:!1,configurable:!1,value:-1}});var H_=class{isExtensible(){return!1}deleteProperty(){return!1}preventExtensions(){return!0}ownKeys(t){return t[Ci].type.children.map(n=>n.name)}has(t,n){return t[Ci].type.children.findIndex(r=>r.name===n)!==-1}getOwnPropertyDescriptor(t,n){if(t[Ci].type.children.findIndex(r=>r.name===n)!==-1)return{writable:!0,enumerable:!0,configurable:!0}}get(t,n){if(Reflect.has(t,n))return t[n];let r=t[Ci].type.children.findIndex(i=>i.name===n);if(r!==-1){let i=Ye.visit(t[Ci].children[r],t[au]);return Reflect.set(t,n,i),i}}set(t,n,r){let i=t[Ci].type.children.findIndex(o=>o.name===n);return i!==-1?(vn.visit(t[Ci].children[i],t[au],r),Reflect.set(t,n,r)):Reflect.has(t,n)||typeof n=="symbol"?Reflect.set(t,n,r):!1}};var yt=class extends mt{};function It(e){return(t,n)=>t.getValid(n)?e(t,n):null}var _q=(e,t)=>864e5*e[t],Z_=(e,t)=>4294967296*e[t+1]+(e[t]>>>0),Sq=(e,t)=>4294967296*(e[t+1]/1e3)+(e[t]>>>0)/1e3,Iq=(e,t)=>4294967296*(e[t+1]/1e6)+(e[t]>>>0)/1e6,IO=e=>new Date(e),Mq=(e,t)=>IO(_q(e,t)),Aq=(e,t)=>IO(Z_(e,t)),Tq=(e,t)=>null,MO=(e,t,n)=>{if(n+1>=t.length)return null;let r=De(t[n]),i=De(t[n+1]);return e.subarray(r,i)},Eq=({offset:e,values:t},n)=>{let r=e+n;return(t[r>>3]&1<<r%8)!==0},AO=({values:e},t)=>Mq(e,t),TO=({values:e},t)=>Aq(e,t*2),wa=({stride:e,values:t},n)=>t[e*n],Nq=({stride:e,values:t},n)=>Og(t[e*n]),EO=({values:e},t)=>e[t],Dq=({stride:e,values:t},n)=>t.subarray(e*n,e*(n+1)),NO=({values:e,valueOffsets:t},n)=>MO(e,t,n),DO=({values:e,valueOffsets:t},n)=>{let r=MO(e,t,n);return r!==null?kh(r):null},Oq=({values:e},t)=>e[t],Bq=({type:e,values:t},n)=>e.precision!==de.HALF?t[n]:Og(t[n]),Lq=(e,t)=>e.type.unit===Ve.DAY?AO(e,t):TO(e,t),OO=({values:e},t)=>1e3*Z_(e,t*2),BO=({values:e},t)=>Z_(e,t*2),LO=({values:e},t)=>Sq(e,t*2),CO=({values:e},t)=>Iq(e,t*2),Cq=(e,t)=>{switch(e.type.unit){case ct.SECOND:return OO(e,t);case ct.MILLISECOND:return BO(e,t);case ct.MICROSECOND:return LO(e,t);case ct.NANOSECOND:return CO(e,t)}},kO=({values:e},t)=>e[t],FO=({values:e},t)=>e[t],RO=({values:e},t)=>e[t],$O=({values:e},t)=>e[t],kq=(e,t)=>{switch(e.type.unit){case ct.SECOND:return kO(e,t);case ct.MILLISECOND:return FO(e,t);case ct.MICROSECOND:return RO(e,t);case ct.NANOSECOND:return $O(e,t)}},Fq=({values:e,stride:t},n)=>Jh.decimal(e.subarray(t*n,t*(n+1))),Rq=(e,t)=>{let{valueOffsets:n,stride:r,children:i}=e,{[t*r]:o,[t*r+1]:s}=n,c=i[0].slice(o,s-o);return new Xt([c])},$q=(e,t)=>{let{valueOffsets:n,children:r}=e,{[t]:i,[t+1]:o}=n,s=r[0];return new po(s.slice(i,o-i))},Pq=(e,t)=>new ba(e,t),Uq=(e,t)=>e.type.mode===ge.Dense?PO(e,t):UO(e,t),PO=(e,t)=>{let n=e.type.typeIdToChildIndex[e.typeIds[t]],r=e.children[n];return Ye.visit(r,e.valueOffsets[t])},UO=(e,t)=>{let n=e.type.typeIdToChildIndex[e.typeIds[t]],r=e.children[n];return Ye.visit(r,t)},zq=(e,t)=>{var n;return(n=e.dictionary)===null||n===void 0?void 0:n.get(e.values[t])},qq=(e,t)=>e.type.unit===cn.DAY_TIME?zO(e,t):qO(e,t),zO=({values:e},t)=>e.subarray(2*t,2*(t+1)),qO=({values:e},t)=>{let n=e[t],r=new Int32Array(2);return r[0]=Math.trunc(n/12),r[1]=Math.trunc(n%12),r},jO=({values:e},t)=>e[t],VO=({values:e},t)=>e[t],YO=({values:e},t)=>e[t],XO=({values:e},t)=>e[t],jq=(e,t)=>{switch(e.type.unit){case ct.SECOND:return jO(e,t);case ct.MILLISECOND:return VO(e,t);case ct.MICROSECOND:return YO(e,t);case ct.NANOSECOND:return XO(e,t)}},Vq=(e,t)=>{let{stride:n,children:r}=e,o=r[0].slice(t*n,n);return new Xt([o])};yt.prototype.visitNull=It(Tq);yt.prototype.visitBool=It(Eq);yt.prototype.visitInt=It(Oq);yt.prototype.visitInt8=It(wa);yt.prototype.visitInt16=It(wa);yt.prototype.visitInt32=It(wa);yt.prototype.visitInt64=It(EO);yt.prototype.visitUint8=It(wa);yt.prototype.visitUint16=It(wa);yt.prototype.visitUint32=It(wa);yt.prototype.visitUint64=It(EO);yt.prototype.visitFloat=It(Bq);yt.prototype.visitFloat16=It(Nq);yt.prototype.visitFloat32=It(wa);yt.prototype.visitFloat64=It(wa);yt.prototype.visitUtf8=It(DO);yt.prototype.visitLargeUtf8=It(DO);yt.prototype.visitBinary=It(NO);yt.prototype.visitLargeBinary=It(NO);yt.prototype.visitFixedSizeBinary=It(Dq);yt.prototype.visitDate=It(Lq);yt.prototype.visitDateDay=It(AO);yt.prototype.visitDateMillisecond=It(TO);yt.prototype.visitTimestamp=It(Cq);yt.prototype.visitTimestampSecond=It(OO);yt.prototype.visitTimestampMillisecond=It(BO);yt.prototype.visitTimestampMicrosecond=It(LO);yt.prototype.visitTimestampNanosecond=It(CO);yt.prototype.visitTime=It(kq);yt.prototype.visitTimeSecond=It(kO);yt.prototype.visitTimeMillisecond=It(FO);yt.prototype.visitTimeMicrosecond=It(RO);yt.prototype.visitTimeNanosecond=It($O);yt.prototype.visitDecimal=It(Fq);yt.prototype.visitList=It(Rq);yt.prototype.visitStruct=It(Pq);yt.prototype.visitUnion=It(Uq);yt.prototype.visitDenseUnion=It(PO);yt.prototype.visitSparseUnion=It(UO);yt.prototype.visitDictionary=It(zq);yt.prototype.visitInterval=It(qq);yt.prototype.visitIntervalDayTime=It(zO);yt.prototype.visitIntervalYearMonth=It(qO);yt.prototype.visitDuration=It(jq);yt.prototype.visitDurationSecond=It(jO);yt.prototype.visitDurationMillisecond=It(VO);yt.prototype.visitDurationMicrosecond=It(YO);yt.prototype.visitDurationNanosecond=It(XO);yt.prototype.visitFixedSizeList=It(Vq);yt.prototype.visitMap=It($q);var Ye=new yt;var ei=Symbol.for("keys"),cu=Symbol.for("vals"),po=class{constructor(t){return this[ei]=new Xt([t.children[0]]).memoize(),this[cu]=t.children[1],new Proxy(this,new Q_)}[Symbol.iterator](){return new J_(this[ei],this[cu])}get size(){return this[ei].length}toArray(){return Object.values(this.toJSON())}toJSON(){let t=this[ei],n=this[cu],r={};for(let i=-1,o=t.length;++i<o;)r[t.get(i)]=Ye.visit(n,i);return r}toString(){return`{${[...this].map(([t,n])=>`${Oi(t)}: ${Oi(n)}`).join(", ")}}`}[Symbol.for("nodejs.util.inspect.custom")](){return this.toString()}},J_=class{constructor(t,n){this.keys=t,this.vals=n,this.keyIndex=0,this.numKeys=t.length}[Symbol.iterator](){return this}next(){let t=this.keyIndex;return t===this.numKeys?{done:!0,value:null}:(this.keyIndex++,{done:!1,value:[this.keys.get(t),Ye.visit(this.vals,t)]})}},Q_=class{isExtensible(){return!1}deleteProperty(){return!1}preventExtensions(){return!0}ownKeys(t){return t[ei].toArray().map(String)}has(t,n){return t[ei].includes(n)}getOwnPropertyDescriptor(t,n){if(t[ei].indexOf(n)!==-1)return{writable:!0,enumerable:!0,configurable:!0}}get(t,n){if(Reflect.has(t,n))return t[n];let r=t[ei].indexOf(n);if(r!==-1){let i=Ye.visit(Reflect.get(t,cu),r);return Reflect.set(t,n,i),i}}set(t,n,r){let i=t[ei].indexOf(n);return i!==-1?(vn.visit(Reflect.get(t,cu),i,r),Reflect.set(t,n,r)):Reflect.has(t,n)?Reflect.set(t,n,r):!1}};Object.defineProperties(po.prototype,{[Symbol.toStringTag]:{enumerable:!1,configurable:!1,value:"Row"},[ei]:{writable:!0,enumerable:!1,configurable:!1,value:null},[cu]:{writable:!0,enumerable:!1,configurable:!1,value:null}});function Yq(e,t,n){let r=e.length,i=t>-1?t:r+t%r;return n?n(e,i):i}var GO;function ld(e,t,n,r){let{length:i=0}=e,o=typeof t!="number"?0:t,s=typeof n!="number"?i:n;return o<0&&(o=(o%i+i)%i),s<0&&(s=(s%i+i)%i),s<o&&(GO=o,o=s,s=GO),s>i&&(s=i),r?r(e,o,s):[o,s]}var WO=e=>e!==e;function va(e){if(typeof e!=="object"||e===null)return WO(e)?WO:n=>n===e;if(e instanceof Date){let n=e.valueOf();return r=>r instanceof Date?r.valueOf()===n:!1}return ArrayBuffer.isView(e)?n=>n?O_(e,n):!1:e instanceof Map?Gq(e):Array.isArray(e)?Xq(e):e instanceof Xt?Wq(e):Hq(e,!0)}function Xq(e){let t=[];for(let n=-1,r=e.length;++n<r;)t[n]=va(e[n]);return Wg(t)}function Gq(e){let t=-1,n=[];for(let r of e.values())n[++t]=va(r);return Wg(n)}function Wq(e){let t=[];for(let n=-1,r=e.length;++n<r;)t[n]=va(e.get(n));return Wg(t)}function Hq(e,t=!1){let n=Object.keys(e);if(!t&&n.length===0)return()=>!1;let r=[];for(let i=-1,o=n.length;++i<o;)r[i]=va(e[n[i]]);return Wg(r,n)}function Wg(e,t){return n=>{if(!n||typeof n!="object")return!1;switch(n.constructor){case Array:return Zq(e,n);case Map:return HO(e,n,n.keys());case po:case ba:case Object:case void 0:return HO(e,n,t||Object.keys(n))}return n instanceof Xt?Jq(e,n):!1}}function Zq(e,t){let n=e.length;if(t.length!==n)return!1;for(let r=-1;++r<n;)if(!e[r](t[r]))return!1;return!0}function Jq(e,t){let n=e.length;if(t.length!==n)return!1;for(let r=-1;++r<n;)if(!e[r](t.get(r)))return!1;return!0}function HO(e,t,n){let r=n[Symbol.iterator](),i=t instanceof Map?t.keys():Object.keys(t)[Symbol.iterator](),o=t instanceof Map?t.values():Object.values(t)[Symbol.iterator](),s=0,a=e.length,c=o.next(),l=r.next(),u=i.next();for(;s<a&&!l.done&&!u.done&&!c.done&&!(l.value!==u.value||!e[s](c.value));++s,l=r.next(),u=i.next(),c=o.next());return s===a&&l.done&&u.done&&c.done?!0:(r.return&&r.return(),i.return&&i.return(),o.return&&o.return(),!1)}var t2={};Mr(t2,{BitIterator:()=>Sc,getBit:()=>ZO,getBool:()=>Zg,packBools:()=>Mc,popcnt_array:()=>JO,popcnt_bit_range:()=>ud,popcnt_uint32:()=>Hg,setBool:()=>Qq,truncateBitmap:()=>Ic});function Zg(e,t,n,r){return(n&1<<r)!==0}function ZO(e,t,n,r){return(n&1<<r)>>r}function Qq(e,t,n){return n?!!(e[t>>3]|=1<<t%8)||!0:!(e[t>>3]&=~(1<<t%8))&&!1}function Ic(e,t,n){let r=n.byteLength+7&-8;if(e>0||n.byteLength<r){let i=new Uint8Array(r);return i.set(e%8===0?n.subarray(e>>3):Mc(new Sc(n,e,t,null,Zg)).subarray(0,r)),i}return n}function Mc(e){let t=[],n=0,r=0,i=0;for(let s of e)s&&(i|=1<<r),++r===8&&(t[n++]=i,i=r=0);(n===0||r>0)&&(t[n++]=i);let o=new Uint8Array(t.length+7&-8);return o.set(t),o}var Sc=class{constructor(t,n,r,i,o){this.bytes=t,this.length=r,this.context=i,this.get=o,this.bit=n%8,this.byteIndex=n>>3,this.byte=t[this.byteIndex++],this.index=0}next(){return this.index<this.length?(this.bit===8&&(this.bit=0,this.byte=this.bytes[this.byteIndex++]),{value:this.get(this.context,this.index++,this.byte,this.bit++)}):{done:!0,value:null}}[Symbol.iterator](){return this}};function ud(e,t,n){if(n-t<=0)return 0;if(n-t<8){let o=0;for(let s of new Sc(e,t,n-t,e,ZO))o+=s;return o}let r=n>>3<<3,i=t+(t%8===0?0:8-t%8);return ud(e,t,i)+ud(e,r,n)+JO(e,i>>3,r-i>>3)}function JO(e,t,n){let r=0,i=Math.trunc(t),o=new DataView(e.buffer,e.byteOffset,e.byteLength),s=n===void 0?e.byteLength:i+n;for(;s-i>=4;)r+=Hg(o.getUint32(i)),i+=4;for(;s-i>=2;)r+=Hg(o.getUint16(i)),i+=2;for(;s-i>=1;)r+=Hg(o.getUint8(i)),i+=1;return r}function Hg(e){let t=Math.trunc(e);return t=t-(t>>>1&1431655765),t=(t&858993459)+(t>>>2&858993459),(t+(t>>>4)&252645135)*16843009>>>24}var Kq=-1,te=class e{get typeId(){return this.type.typeId}get ArrayType(){return this.type.ArrayType}get buffers(){return[this.valueOffsets,this.values,this.nullBitmap,this.typeIds]}get nullable(){if(this._nullCount!==0){let{type:t}=this;return H.isSparseUnion(t)?this.children.some(n=>n.nullable):H.isDenseUnion(t)?this.children.some(n=>n.nullable):this.nullBitmap&&this.nullBitmap.byteLength>0}return!0}get byteLength(){let t=0,{valueOffsets:n,values:r,nullBitmap:i,typeIds:o}=this;return n&&(t+=n.byteLength),r&&(t+=r.byteLength),i&&(t+=i.byteLength),o&&(t+=o.byteLength),this.children.reduce((s,a)=>s+a.byteLength,t)}get nullCount(){if(H.isUnion(this.type))return this.children.reduce((r,i)=>r+i.nullCount,0);let t=this._nullCount,n;return t<=Kq&&(n=this.nullBitmap)&&(this._nullCount=t=this.length-ud(n,this.offset,this.offset+this.length)),t}constructor(t,n,r,i,o,s=[],a){this.type=t,this.children=s,this.dictionary=a,this.offset=Math.floor(Math.max(n||0,0)),this.length=Math.floor(Math.max(r||0,0)),this._nullCount=Math.floor(Math.max(i||0,-1));let c;o instanceof e?(this.stride=o.stride,this.values=o.values,this.typeIds=o.typeIds,this.nullBitmap=o.nullBitmap,this.valueOffsets=o.valueOffsets):(this.stride=Or(t),o&&((c=o[0])&&(this.valueOffsets=c),(c=o[1])&&(this.values=c),(c=o[2])&&(this.nullBitmap=c),(c=o[3])&&(this.typeIds=c)))}getValid(t){let{type:n}=this;if(H.isUnion(n)){let r=n,i=this.children[r.typeIdToChildIndex[this.typeIds[t]]],o=r.mode===ge.Dense?this.valueOffsets[t]:t;return i.getValid(o)}if(this.nullable&&this.nullCount>0){let r=this.offset+t;return(this.nullBitmap[r>>3]&1<<r%8)!==0}return!0}setValid(t,n){let r,{type:i}=this;if(H.isUnion(i)){let o=i,s=this.children[o.typeIdToChildIndex[this.typeIds[t]]],a=o.mode===ge.Dense?this.valueOffsets[t]:t;r=s.getValid(a),s.setValid(a,n)}else{let{nullBitmap:o}=this,{offset:s,length:a}=this,c=s+t,l=1<<c%8,u=c>>3;(!o||o.byteLength<=u)&&(o=new Uint8Array((s+a+63&-64)>>3).fill(255),this.nullCount>0&&o.set(Ic(s,a,this.nullBitmap),0),Object.assign(this,{nullBitmap:o,_nullCount:-1}));let f=o[u];r=(f&l)!==0,n?o[u]=f|l:o[u]=f&~l}return r!==!!n&&(this._nullCount=this.nullCount+(n?-1:1)),n}clone(t=this.type,n=this.offset,r=this.length,i=this._nullCount,o=this,s=this.children){return new e(t,n,r,i,o,s,this.dictionary)}slice(t,n){let{stride:r,typeId:i,children:o}=this,s=+(this._nullCount===0)-1,a=i===16?r:1,c=this._sliceBuffers(t,n,r,i);return this.clone(this.type,this.offset+t,n,s,c,o.length===0||this.valueOffsets?o:this._sliceChildren(o,a*t,a*n))}_changeLengthAndBackfillNullBitmap(t){if(this.typeId===L.Null)return this.clone(this.type,0,t,0);let{length:n,nullCount:r}=this,i=new Uint8Array((t+63&-64)>>3).fill(255,0,n>>3);i[n>>3]=(1<<n-(n&-8))-1,r>0&&i.set(Ic(this.offset,n,this.nullBitmap),0);let o=this.buffers;return o[Di.VALIDITY]=i,this.clone(this.type,0,t,r+(t-n),o)}_sliceBuffers(t,n,r,i){let o,{buffers:s}=this;return(o=s[Di.TYPE])&&(s[Di.TYPE]=o.subarray(t,t+n)),(o=s[Di.OFFSET])&&(s[Di.OFFSET]=o.subarray(t,t+n+1))||(o=s[Di.DATA])&&(s[Di.DATA]=i===6?o:o.subarray(r*t,r*(t+n))),s}_sliceChildren(t,n,r){return t.map(i=>i.slice(n,r))}};te.prototype.children=Object.freeze([]);var e2=class e extends mt{visit(t){return this.getVisitFn(t.type).call(this,t)}visitNull(t){let{["type"]:n,["offset"]:r=0,["length"]:i=0}=t;return new te(n,r,i,i)}visitBool(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length>>3,["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitInt(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length,["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitFloat(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length,["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitUtf8(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.data),o=_t(t.nullBitmap),s=vc(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,i,o])}visitLargeUtf8(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.data),o=_t(t.nullBitmap),s=Ig(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,i,o])}visitBinary(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.data),o=_t(t.nullBitmap),s=vc(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,i,o])}visitLargeBinary(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.data),o=_t(t.nullBitmap),s=Ig(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,i,o])}visitFixedSizeBinary(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitDate(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitTimestamp(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitTime(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitDecimal(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitList(t){let{["type"]:n,["offset"]:r=0,["child"]:i}=t,o=_t(t.nullBitmap),s=vc(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,void 0,o],[i])}visitStruct(t){let{["type"]:n,["offset"]:r=0,["children"]:i=[]}=t,o=_t(t.nullBitmap),{length:s=i.reduce((c,{length:l})=>Math.max(c,l),0),nullCount:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,void 0,o],i)}visitUnion(t){let{["type"]:n,["offset"]:r=0,["children"]:i=[]}=t,o=Pt(n.ArrayType,t.typeIds),{["length"]:s=o.length,["nullCount"]:a=-1}=t;if(H.isSparseUnion(n))return new te(n,r,s,a,[void 0,void 0,void 0,o],i);let c=vc(t.valueOffsets);return new te(n,r,s,a,[c,void 0,void 0,o],i)}visitDictionary(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.indices.ArrayType,t.data),{["dictionary"]:s=new Xt([new e().visit({type:n.dictionary})])}=t,{["length"]:a=o.length,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[void 0,o,i],[],s)}visitInterval(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitDuration(t){let{["type"]:n,["offset"]:r=0}=t,i=_t(t.nullBitmap),o=Pt(n.ArrayType,t.data),{["length"]:s=o.length,["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,o,i])}visitFixedSizeList(t){let{["type"]:n,["offset"]:r=0,["child"]:i=new e().visit({type:n.valueType})}=t,o=_t(t.nullBitmap),{["length"]:s=i.length/Or(n),["nullCount"]:a=t.nullBitmap?-1:0}=t;return new te(n,r,s,a,[void 0,void 0,o],[i])}visitMap(t){let{["type"]:n,["offset"]:r=0,["child"]:i=new e().visit({type:n.childType})}=t,o=_t(t.nullBitmap),s=vc(t.valueOffsets),{["length"]:a=s.length-1,["nullCount"]:c=t.nullBitmap?-1:0}=t;return new te(n,r,a,c,[s,void 0,o],[i])}},tj=new e2;function Nt(e){return tj.visit(e)}var fd=class{constructor(t=0,n){this.numChunks=t,this.getChunkIterator=n,this.chunkIndex=0,this.chunkIterator=this.getChunkIterator(0)}next(){for(;this.chunkIndex<this.numChunks;){let t=this.chunkIterator.next();if(!t.done)return t;++this.chunkIndex<this.numChunks&&(this.chunkIterator=this.getChunkIterator(this.chunkIndex))}return{done:!0,value:null}}[Symbol.iterator](){return this}};function QO(e){return e.some(t=>t.nullable)}function Jg(e){return e.reduce((t,n)=>t+n.nullCount,0)}function Qg(e){return e.reduce((t,n,r)=>(t[r+1]=t[r]+n.length,t),new Uint32Array(e.length+1))}function Kg(e,t,n,r){let i=[];for(let o=-1,s=e.length;++o<s;){let a=e[o],c=t[o],{length:l}=a;if(c>=r)break;if(n>=c+l)continue;if(c>=n&&c+l<=r){i.push(a);continue}let u=Math.max(0,n-c),f=Math.min(r-c,l);i.push(a.slice(u,f-u))}return i.length===0&&i.push(e[0].slice(0,0)),i}function n2(e,t,n,r){let i=0,o=0,s=t.length-1;do{if(i>=s-1)return n<t[s]?r(e,i,n-t[i]):null;o=i+Math.trunc((s-i)*.5),n<t[o]?s=o:i=o}while(i<s)}function hd(e,t){return e.getValid(t)}function lu(e){function t(n,r,i){return e(n[r],i)}return function(n){let r=this.data;return n2(r,this._offsets,n,t)}}function t0(e){let t;function n(r,i,o){return e(r[i],o,t)}return function(r,i){let o=this.data;t=i;let s=n2(o,this._offsets,r,n);return t=void 0,s}}function e0(e){let t;function n(r,i,o){let s=o,a=0,c=0;for(let l=i-1,u=r.length;++l<u;){let f=r[l];if(~(a=e(f,t,s)))return c+a;s=0,c+=f.length}return-1}return function(r,i){t=r;let o=this.data,s=typeof i!="number"?n(o,0,0):n2(o,this._offsets,i,n);return t=void 0,s}}var gt=class extends mt{};function ej(e,t){return t===null&&e.length>0?0:-1}function nj(e,t){let{nullBitmap:n}=e;if(!n||e.nullCount<=0)return-1;let r=0;for(let i of new Sc(n,e.offset+(t||0),e.length,n,Zg)){if(!i)return r;++r}return-1}function Dt(e,t,n){if(t===void 0)return-1;if(t===null)switch(e.typeId){case L.Union:break;case L.Dictionary:break;default:return nj(e,n)}let r=Ye.getVisitFn(e),i=va(t);for(let o=(n||0)-1,s=e.length;++o<s;)if(i(r(e,o)))return o;return-1}function KO(e,t,n){let r=Ye.getVisitFn(e),i=va(t);for(let o=(n||0)-1,s=e.length;++o<s;)if(i(r(e,o)))return o;return-1}gt.prototype.visitNull=ej;gt.prototype.visitBool=Dt;gt.prototype.visitInt=Dt;gt.prototype.visitInt8=Dt;gt.prototype.visitInt16=Dt;gt.prototype.visitInt32=Dt;gt.prototype.visitInt64=Dt;gt.prototype.visitUint8=Dt;gt.prototype.visitUint16=Dt;gt.prototype.visitUint32=Dt;gt.prototype.visitUint64=Dt;gt.prototype.visitFloat=Dt;gt.prototype.visitFloat16=Dt;gt.prototype.visitFloat32=Dt;gt.prototype.visitFloat64=Dt;gt.prototype.visitUtf8=Dt;gt.prototype.visitLargeUtf8=Dt;gt.prototype.visitBinary=Dt;gt.prototype.visitLargeBinary=Dt;gt.prototype.visitFixedSizeBinary=Dt;gt.prototype.visitDate=Dt;gt.prototype.visitDateDay=Dt;gt.prototype.visitDateMillisecond=Dt;gt.prototype.visitTimestamp=Dt;gt.prototype.visitTimestampSecond=Dt;gt.prototype.visitTimestampMillisecond=Dt;gt.prototype.visitTimestampMicrosecond=Dt;gt.prototype.visitTimestampNanosecond=Dt;gt.prototype.visitTime=Dt;gt.prototype.visitTimeSecond=Dt;gt.prototype.visitTimeMillisecond=Dt;gt.prototype.visitTimeMicrosecond=Dt;gt.prototype.visitTimeNanosecond=Dt;gt.prototype.visitDecimal=Dt;gt.prototype.visitList=Dt;gt.prototype.visitStruct=Dt;gt.prototype.visitUnion=Dt;gt.prototype.visitDenseUnion=KO;gt.prototype.visitSparseUnion=KO;gt.prototype.visitDictionary=Dt;gt.prototype.visitInterval=Dt;gt.prototype.visitIntervalDayTime=Dt;gt.prototype.visitIntervalYearMonth=Dt;gt.prototype.visitDuration=Dt;gt.prototype.visitDurationSecond=Dt;gt.prototype.visitDurationMillisecond=Dt;gt.prototype.visitDurationMicrosecond=Dt;gt.prototype.visitDurationNanosecond=Dt;gt.prototype.visitFixedSizeList=Dt;gt.prototype.visitMap=Dt;var Ac=new gt;var xt=class extends mt{};function Mt(e){let{type:t}=e;if(e.nullCount===0&&e.stride===1&&(t.typeId===L.Timestamp||t instanceof ke&&t.bitWidth!==64||t instanceof Zr&&t.bitWidth!==64||t instanceof Gn&&t.precision!==de.HALF))return new fd(e.data.length,r=>{let i=e.data[r];return i.values.subarray(0,i.length)[Symbol.iterator]()});let n=0;return new fd(e.data.length,r=>{let o=e.data[r].length,s=e.slice(n,n+o);return n+=o,new r2(s)})}var r2=class{constructor(t){this.vector=t,this.index=0}next(){return this.index<this.vector.length?{value:this.vector.get(this.index++)}:{done:!0,value:null}}[Symbol.iterator](){return this}};xt.prototype.visitNull=Mt;xt.prototype.visitBool=Mt;xt.prototype.visitInt=Mt;xt.prototype.visitInt8=Mt;xt.prototype.visitInt16=Mt;xt.prototype.visitInt32=Mt;xt.prototype.visitInt64=Mt;xt.prototype.visitUint8=Mt;xt.prototype.visitUint16=Mt;xt.prototype.visitUint32=Mt;xt.prototype.visitUint64=Mt;xt.prototype.visitFloat=Mt;xt.prototype.visitFloat16=Mt;xt.prototype.visitFloat32=Mt;xt.prototype.visitFloat64=Mt;xt.prototype.visitUtf8=Mt;xt.prototype.visitLargeUtf8=Mt;xt.prototype.visitBinary=Mt;xt.prototype.visitLargeBinary=Mt;xt.prototype.visitFixedSizeBinary=Mt;xt.prototype.visitDate=Mt;xt.prototype.visitDateDay=Mt;xt.prototype.visitDateMillisecond=Mt;xt.prototype.visitTimestamp=Mt;xt.prototype.visitTimestampSecond=Mt;xt.prototype.visitTimestampMillisecond=Mt;xt.prototype.visitTimestampMicrosecond=Mt;xt.prototype.visitTimestampNanosecond=Mt;xt.prototype.visitTime=Mt;xt.prototype.visitTimeSecond=Mt;xt.prototype.visitTimeMillisecond=Mt;xt.prototype.visitTimeMicrosecond=Mt;xt.prototype.visitTimeNanosecond=Mt;xt.prototype.visitDecimal=Mt;xt.prototype.visitList=Mt;xt.prototype.visitStruct=Mt;xt.prototype.visitUnion=Mt;xt.prototype.visitDenseUnion=Mt;xt.prototype.visitSparseUnion=Mt;xt.prototype.visitDictionary=Mt;xt.prototype.visitInterval=Mt;xt.prototype.visitIntervalDayTime=Mt;xt.prototype.visitIntervalYearMonth=Mt;xt.prototype.visitDuration=Mt;xt.prototype.visitDurationSecond=Mt;xt.prototype.visitDurationMillisecond=Mt;xt.prototype.visitDurationMicrosecond=Mt;xt.prototype.visitDurationNanosecond=Mt;xt.prototype.visitFixedSizeList=Mt;xt.prototype.visitMap=Mt;var uu=new xt;var tB,eB={},nB={},Xt=class e{constructor(t){var n,r,i;let o=t[0]instanceof e?t.flatMap(a=>a.data):t;if(o.length===0||o.some(a=>!(a instanceof te)))throw new TypeError("Vector constructor expects an Array of Data instances.");let s=(n=o[0])===null||n===void 0?void 0:n.type;switch(o.length){case 0:this._offsets=[0];break;case 1:{let{get:a,set:c,indexOf:l}=eB[s.typeId],u=o[0];this.isValid=f=>hd(u,f),this.get=f=>a(u,f),this.set=(f,h)=>c(u,f,h),this.indexOf=f=>l(u,f),this._offsets=[0,u.length];break}default:Object.setPrototypeOf(this,nB[s.typeId]),this._offsets=Qg(o);break}this.data=o,this.type=s,this.stride=Or(s),this.numChildren=(i=(r=s.children)===null||r===void 0?void 0:r.length)!==null&&i!==void 0?i:0,this.length=this._offsets.at(-1)}get byteLength(){return this.data.reduce((t,n)=>t+n.byteLength,0)}get nullable(){return QO(this.data)}get nullCount(){return Jg(this.data)}get ArrayType(){return this.type.ArrayType}get[Symbol.toStringTag](){return`${this.VectorName}<${this.type[Symbol.toStringTag]}>`}get VectorName(){return`${L[this.type.typeId]}Vector`}isValid(t){return!1}get(t){return null}set(t,n){}indexOf(t,n){return-1}includes(t,n){return this.indexOf(t,n)>-1}[Symbol.iterator](){return uu.visit(this)}concat(...t){return new e(this.data.concat(t.flatMap(n=>n.data).flat(Number.POSITIVE_INFINITY)))}slice(t,n){return new e(ld(this,t,n,({data:r,_offsets:i},o,s)=>Kg(r,i,o,s)))}toJSON(){return[...this]}toArray(){let{type:t,data:n,length:r,stride:i,ArrayType:o}=this;switch(t.typeId){case L.Int:case L.Float:case L.Decimal:case L.Time:case L.Timestamp:switch(n.length){case 0:return new o;case 1:return n[0].values.subarray(0,r*i);default:return n.reduce((s,{values:a,length:c})=>(s.array.set(a.subarray(0,c*i),s.offset),s.offset+=c*i,s),{array:new o(r*i),offset:0}).array}}return[...this]}toString(){return`[${[...this].join(",")}]`}getChild(t){var n;return this.getChildAt((n=this.type.children)===null||n===void 0?void 0:n.findIndex(r=>r.name===t))}getChildAt(t){return t>-1&&t<this.numChildren?new e(this.data.map(({children:n})=>n[t])):null}get isMemoized(){return H.isDictionary(this.type)?this.data[0].dictionary.isMemoized:!1}memoize(){if(H.isDictionary(this.type)){let t=new n0(this.data[0].dictionary),n=this.data.map(r=>{let i=r.clone();return i.dictionary=t,i});return new e(n)}return new n0(this)}unmemoize(){if(H.isDictionary(this.type)&&this.isMemoized){let t=this.data[0].dictionary.unmemoize(),n=this.data.map(r=>{let i=r.clone();return i.dictionary=t,i});return new e(n)}return this}};tB=Symbol.toStringTag;Xt[tB]=(e=>{e.type=H.prototype,e.data=[],e.length=0,e.stride=1,e.numChildren=0,e._offsets=new Uint32Array([0]),e[Symbol.isConcatSpreadable]=!0;let t=Object.keys(L).map(n=>L[n]).filter(n=>typeof n=="number"&&n!==L.NONE);for(let n of t){let r=Ye.getVisitFnByTypeId(n),i=vn.getVisitFnByTypeId(n),o=Ac.getVisitFnByTypeId(n);eB[n]={get:r,set:i,indexOf:o},nB[n]=Object.create(e,{isValid:{value:lu(hd)},get:{value:lu(Ye.getVisitFnByTypeId(n))},set:{value:t0(vn.getVisitFnByTypeId(n))},indexOf:{value:e0(Ac.getVisitFnByTypeId(n))}})}return"Vector"})(Xt.prototype);var n0=class e extends Xt{constructor(t){super(t.data);let n=this.get,r=this.set,i=this.slice,o=new Array(this.length);Object.defineProperty(this,"get",{value(s){let a=o[s];if(a!==void 0)return a;let c=n.call(this,s);return o[s]=c,c}}),Object.defineProperty(this,"set",{value(s,a){r.call(this,s,a),o[s]=a}}),Object.defineProperty(this,"slice",{value:(s,a)=>new e(i.call(this,s,a))}),Object.defineProperty(this,"isMemoized",{value:!0}),Object.defineProperty(this,"unmemoize",{value:()=>new Xt(this.data)}),Object.defineProperty(this,"memoize",{value:()=>this})}};function rB(e){if(!e||e.length<=0)return function(i){return!0};let t="",n=e.filter(r=>r===r);return n.length>0&&(t=`
|
|
2
2
|
switch (x) {${n.map(r=>`
|
|
3
|
-
case ${
|
|
3
|
+
case ${rj(r)}:`).join("")}
|
|
4
4
|
return false;
|
|
5
5
|
}`),e.length!==n.length&&(t=`if (x !== x) return false;
|
|
6
6
|
${t}`),new Function("x",`${t}
|
|
7
|
-
return true;`)}function Gq(e){return typeof e!="bigint"?Ai(e):`${Ai(e)}n`}function n2(e,t){let n=Math.ceil(e)*t-1;return(n-n%64+64||64)/t}function WO(e,t=0){return e.length>=t?e.subarray(0,t):$d(new e.constructor(t),e,0)}var Ci=class{constructor(t,n=0,r=1){this.length=Math.ceil(n/r),this.buffer=new t(this.length),this.stride=r,this.BYTES_PER_ELEMENT=t.BYTES_PER_ELEMENT,this.ArrayType=t}get byteLength(){return Math.ceil(this.length*this.stride)*this.BYTES_PER_ELEMENT}get reservedLength(){return this.buffer.length/this.stride}get reservedByteLength(){return this.buffer.byteLength}set(t,n){return this}append(t){return this.set(this.length,t)}reserve(t){if(t>0){this.length+=t;let n=this.stride,r=this.length*n,i=this.buffer.length;r>=i&&this._resize(i===0?n2(r*1,this.BYTES_PER_ELEMENT):n2(r*2,this.BYTES_PER_ELEMENT))}return this}flush(t=this.length){t=n2(t*this.stride,this.BYTES_PER_ELEMENT);let n=WO(this.buffer,t);return this.clear(),n}clear(){return this.length=0,this.buffer=new this.ArrayType,this}_resize(t){return this.buffer=WO(this.buffer,t)}},ls=class extends Ci{last(){return this.get(this.length-1)}get(t){return this.buffer[t]}set(t,n){return this.reserve(t-this.length+1),this.buffer[t*this.stride]=n,this}},cu=class extends ls{constructor(){super(Uint8Array,0,1/8),this.numValid=0}get numInvalid(){return this.length-this.numValid}get(t){return this.buffer[t>>3]>>t%8&1}set(t,n){let{buffer:r}=this.reserve(t-this.length+1),i=t>>3,o=t%8,s=r[i]>>o&1;return n?s===0&&(r[i]|=1<<o,++this.numValid):s===1&&(r[i]&=~(1<<o),--this.numValid),this}clear(){return this.numValid=0,super.clear()}},lu=class extends ls{constructor(t){super(t.OffsetArrayType,1,1)}append(t){return this.set(this.length-1,t)}set(t,n){let r=this.length-1,i=this.reserve(t-r+1).buffer;return r<t++&&r>=0&&i.fill(i[r],r,t),i[t]=i[t-1]+n,this}flush(t=this.length-1){return t>this.length&&this.set(t-1,this.BYTES_PER_ELEMENT>4?BigInt(0):0),super.flush(t+1)}};var ve=class{static throughNode(t){throw new Error('"throughNode" not available in this environment')}static throughDOM(t){throw new Error('"throughDOM" not available in this environment')}constructor({type:t,nullValues:n}){this.length=0,this.finished=!1,this.type=t,this.children=[],this.nullValues=n,this.stride=Or(t),this._nulls=new cu,n&&n.length>0&&(this._isValid=GO(n))}toVector(){return new Xt([this.flush()])}get ArrayType(){return this.type.ArrayType}get nullCount(){return this._nulls.numInvalid}get numChildren(){return this.children.length}get byteLength(){let t=0,{_offsets:n,_values:r,_nulls:i,_typeIds:o,children:s}=this;return n&&(t+=n.byteLength),r&&(t+=r.byteLength),i&&(t+=i.byteLength),o&&(t+=o.byteLength),s.reduce((a,c)=>a+c.byteLength,t)}get reservedLength(){return this._nulls.reservedLength}get reservedByteLength(){let t=0;return this._offsets&&(t+=this._offsets.reservedByteLength),this._values&&(t+=this._values.reservedByteLength),this._nulls&&(t+=this._nulls.reservedByteLength),this._typeIds&&(t+=this._typeIds.reservedByteLength),this.children.reduce((n,r)=>n+r.reservedByteLength,t)}get valueOffsets(){return this._offsets?this._offsets.buffer:null}get values(){return this._values?this._values.buffer:null}get nullBitmap(){return this._nulls?this._nulls.buffer:null}get typeIds(){return this._typeIds?this._typeIds.buffer:null}append(t){return this.set(this.length,t)}isValid(t){return this._isValid(t)}set(t,n){return this.setValid(t,this.isValid(n))&&this.setValue(t,n),this}setValue(t,n){this._setValue(this,t,n)}setValid(t,n){return this.length=this._nulls.set(t,+n).length,n}addChild(t,n=`${this.numChildren}`){throw new Error(`Cannot append children to non-nested type "${this.type}"`)}getChildAt(t){return this.children[t]||null}flush(){let t,n,r,i,{type:o,length:s,nullCount:a,_typeIds:c,_offsets:l,_values:u,_nulls:f}=this;(n=c?.flush(s))?i=l?.flush(s):(i=l?.flush(s))?t=u?.flush(l.last()):t=u?.flush(s),a>0&&(r=f?.flush(s));let d=this.children.map(h=>h.flush());return this.clear(),Nt({type:o,length:s,nullCount:a,children:d,child:d[0],data:t,typeIds:n,nullBitmap:r,valueOffsets:i})}finish(){this.finished=!0;for(let t of this.children)t.finish();return this}clear(){var t,n,r,i;this.length=0,(t=this._nulls)===null||t===void 0||t.clear(),(n=this._values)===null||n===void 0||n.clear(),(r=this._offsets)===null||r===void 0||r.clear(),(i=this._typeIds)===null||i===void 0||i.clear();for(let o of this.children)o.clear();return this}};ve.prototype.length=1;ve.prototype.stride=1;ve.prototype.children=null;ve.prototype.finished=!1;ve.prototype.nullValues=null;ve.prototype._isValid=()=>!0;var Xe=class extends ve{constructor(t){super(t),this._values=new ls(this.ArrayType,0,this.stride)}setValue(t,n){let r=this._values;return r.reserve(t-r.length+1),super.setValue(t,n)}},hr=class extends ve{constructor(t){super(t),this._pendingLength=0,this._offsets=new lu(t.type)}setValue(t,n){let r=this._pending||(this._pending=new Map),i=r.get(t);i&&(this._pendingLength-=i.length),this._pendingLength+=n instanceof no?n[Zr].length:n.length,r.set(t,n)}setValid(t,n){return super.setValid(t,n)?!0:((this._pending||(this._pending=new Map)).set(t,void 0),!1)}clear(){return this._pendingLength=0,this._pending=void 0,super.clear()}flush(){return this._flush(),super.flush()}finish(){return this._flush(),super.finish()}_flush(){let t=this._pending,n=this._pendingLength;return this._pendingLength=0,this._pending=void 0,t&&t.size>0&&this._flushPending(t,n),this}};var Ac=class{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}offset(){return this.bb.readInt64(this.bb_pos)}metaDataLength(){return this.bb.readInt32(this.bb_pos+8)}bodyLength(){return this.bb.readInt64(this.bb_pos+16)}static sizeOf(){return 24}static createBlock(t,n,r,i){return t.prep(8,24),t.writeInt64(BigInt(i??0)),t.pad(4),t.writeInt32(r),t.writeInt64(BigInt(n??0)),t.offset()}};var Br=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsFooter(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsFooter(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}version(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ce.V1}schema(t){let n=this.bb.__offset(this.bb_pos,6);return n?(t||new fr).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}dictionaries(t,n){let r=this.bb.__offset(this.bb_pos,8);return r?(n||new Ac).__init(this.bb.__vector(this.bb_pos+r)+t*24,this.bb):null}dictionariesLength(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.__vector_len(this.bb_pos+t):0}recordBatches(t,n){let r=this.bb.__offset(this.bb_pos,10);return r?(n||new Ac).__init(this.bb.__vector(this.bb_pos+r)+t*24,this.bb):null}recordBatchesLength(){let t=this.bb.__offset(this.bb_pos,10);return t?this.bb.__vector_len(this.bb_pos+t):0}customMetadata(t,n){let r=this.bb.__offset(this.bb_pos,12);return r?(n||new rn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}customMetadataLength(){let t=this.bb.__offset(this.bb_pos,12);return t?this.bb.__vector_len(this.bb_pos+t):0}static startFooter(t){t.startObject(5)}static addVersion(t,n){t.addFieldInt16(0,n,ce.V1)}static addSchema(t,n){t.addFieldOffset(1,n,0)}static addDictionaries(t,n){t.addFieldOffset(2,n,0)}static startDictionariesVector(t,n){t.startVector(24,n,8)}static addRecordBatches(t,n){t.addFieldOffset(3,n,0)}static startRecordBatchesVector(t,n){t.startVector(24,n,8)}static addCustomMetadata(t,n){t.addFieldOffset(4,n,0)}static createCustomMetadataVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startCustomMetadataVector(t,n){t.startVector(4,n,4)}static endFooter(t){return t.endObject()}static finishFooterBuffer(t,n){t.finish(n)}static finishSizePrefixedFooterBuffer(t,n){t.finish(n,void 0,!0)}};var oe=class e{constructor(t=[],n,r,i=ce.V5){this.fields=t||[],this.metadata=n||new Map,r||(r=r2(t)),this.dictionaries=r,this.metadataVersion=i}get[Symbol.toStringTag](){return"Schema"}get names(){return this.fields.map(t=>t.name)}toString(){return`Schema<{ ${this.fields.map((t,n)=>`${n}: ${t}`).join(", ")} }>`}select(t){let n=new Set(t),r=this.fields.filter(i=>n.has(i.name));return new e(r,this.metadata)}selectAt(t){let n=t.map(r=>this.fields[r]).filter(Boolean);return new e(n,this.metadata)}assign(...t){let n=t[0]instanceof e?t[0]:Array.isArray(t[0])?new e(t[0]):new e(t),r=[...this.fields],i=e0(e0(new Map,this.metadata),n.metadata),o=n.fields.filter(a=>{let c=r.findIndex(l=>l.name===a.name);return~c?(r[c]=a.clone({metadata:e0(e0(new Map,r[c].metadata),a.metadata)}))&&!1:!0}),s=r2(o,new Map);return new e([...r,...o],i,new Map([...this.dictionaries,...s]))}};oe.prototype.fields=null;oe.prototype.metadata=null;oe.prototype.dictionaries=null;var Ut=class e{static new(...t){let[n,r,i,o]=t;return t[0]&&typeof t[0]=="object"&&({name:n}=t[0],r===void 0&&(r=t[0].type),i===void 0&&(i=t[0].nullable),o===void 0&&(o=t[0].metadata)),new e(`${n}`,r,i,o)}constructor(t,n,r=!1,i){this.name=t,this.type=n,this.nullable=r,this.metadata=i||new Map}get typeId(){return this.type.typeId}get[Symbol.toStringTag](){return"Field"}toString(){return`${this.name}: ${this.type}`}clone(...t){let[n,r,i,o]=t;return!t[0]||typeof t[0]!="object"?[n=this.name,r=this.type,i=this.nullable,o=this.metadata]=t:{name:n=this.name,type:r=this.type,nullable:i=this.nullable,metadata:o=this.metadata}=t[0],e.new(n,r,i,o)}};Ut.prototype.type=null;Ut.prototype.name=null;Ut.prototype.nullable=null;Ut.prototype.metadata=null;function e0(e,t){return new Map([...e||new Map,...t||new Map])}function r2(e,t=new Map){for(let n=-1,r=e.length;++n<r;){let o=e[n].type;if(st.isDictionary(o)){if(!t.has(o.id))t.set(o.id,o.dictionary);else if(t.get(o.id)!==o.dictionary)throw new Error("Cannot create Schema containing two different dictionaries with the same Id")}o.children&&o.children.length>0&&r2(o.children,t)}return t}var Wq=vc,Hq=Er,us=class{static decode(t){t=new Hq(_t(t));let n=Br.getRootAsFooter(t),r=oe.decode(n.schema(),new Map,n.version());return new i2(r,n)}static encode(t){let n=new Wq,r=oe.encode(n,t.schema);Br.startRecordBatchesVector(n,t.numRecordBatches);for(let s of[...t.recordBatches()].slice().reverse())fs.encode(n,s);let i=n.endVector();Br.startDictionariesVector(n,t.numDictionaries);for(let s of[...t.dictionaryBatches()].slice().reverse())fs.encode(n,s);let o=n.endVector();return Br.startFooter(n),Br.addSchema(n,r),Br.addVersion(n,ce.V5),Br.addRecordBatches(n,i),Br.addDictionaries(n,o),Br.finishFooterBuffer(n,Br.endFooter(n)),n.asUint8Array()}get numRecordBatches(){return this._recordBatches.length}get numDictionaries(){return this._dictionaryBatches.length}constructor(t,n=ce.V5,r,i){this.schema=t,this.version=n,r&&(this._recordBatches=r),i&&(this._dictionaryBatches=i)}*recordBatches(){for(let t,n=-1,r=this.numRecordBatches;++n<r;)(t=this.getRecordBatch(n))&&(yield t)}*dictionaryBatches(){for(let t,n=-1,r=this.numDictionaries;++n<r;)(t=this.getDictionaryBatch(n))&&(yield t)}getRecordBatch(t){return t>=0&&t<this.numRecordBatches&&this._recordBatches[t]||null}getDictionaryBatch(t){return t>=0&&t<this.numDictionaries&&this._dictionaryBatches[t]||null}};var i2=class extends us{get numRecordBatches(){return this._footer.recordBatchesLength()}get numDictionaries(){return this._footer.dictionariesLength()}constructor(t,n){super(t,n.version()),this._footer=n}getRecordBatch(t){if(t>=0&&t<this.numRecordBatches){let n=this._footer.recordBatches(t);if(n)return fs.decode(n)}return null}getDictionaryBatch(t){if(t>=0&&t<this.numDictionaries){let n=this._footer.dictionaries(t);if(n)return fs.decode(n)}return null}},fs=class e{static decode(t){return new e(t.metaDataLength(),t.bodyLength(),t.offset())}static encode(t,n){let{metaDataLength:r}=n,i=BigInt(n.offset),o=BigInt(n.bodyLength);return Ac.createBlock(t,i,r,o)}constructor(t,n,r){this.metaDataLength=t,this.offset=De(r),this.bodyLength=De(n)}};var we=Object.freeze({done:!0,value:void 0}),ih=class{constructor(t){this._json=t}get schema(){return this._json.schema}get batches(){return this._json.batches||[]}get dictionaries(){return this._json.dictionaries||[]}},Tc=class{tee(){return this._getDOMStream().tee()}pipe(t,n){return this._getNodeStream().pipe(t,n)}pipeTo(t,n){return this._getDOMStream().pipeTo(t,n)}pipeThrough(t,n){return this._getDOMStream().pipeThrough(t,n)}_getDOMStream(){return this._DOMStream||(this._DOMStream=this.toDOMStream())}_getNodeStream(){return this._nodeStream||(this._nodeStream=this.toNodeStream())}},n0=class extends Tc{constructor(){super(),this._values=[],this.resolvers=[],this._closedPromise=new Promise(t=>this._closedPromiseResolve=t)}get closed(){return this._closedPromise}cancel(t){return Z(this,void 0,void 0,function*(){yield this.return(t)})}write(t){this._ensureOpen()&&(this.resolvers.length<=0?this._values.push(t):this.resolvers.shift().resolve({done:!1,value:t}))}abort(t){this._closedPromiseResolve&&(this.resolvers.length<=0?this._error={error:t}:this.resolvers.shift().reject({done:!0,value:t}))}close(){if(this._closedPromiseResolve){let{resolvers:t}=this;for(;t.length>0;)t.shift().resolve(we);this._closedPromiseResolve(),this._closedPromiseResolve=void 0}}[Symbol.asyncIterator](){return this}toDOMStream(t){return bn.toDOMStream(this._closedPromiseResolve||this._error?this:this._values,t)}toNodeStream(t){return bn.toNodeStream(this._closedPromiseResolve||this._error?this:this._values,t)}throw(t){return Z(this,void 0,void 0,function*(){return yield this.abort(t),we})}return(t){return Z(this,void 0,void 0,function*(){return yield this.close(),we})}read(t){return Z(this,void 0,void 0,function*(){return(yield this.next(t,"read")).value})}peek(t){return Z(this,void 0,void 0,function*(){return(yield this.next(t,"peek")).value})}next(...t){return this._values.length>0?Promise.resolve({done:!1,value:this._values.shift()}):this._error?Promise.reject({done:!0,value:this._error.error}):this._closedPromiseResolve?new Promise((n,r)=>{this.resolvers.push({resolve:n,reject:r})}):Promise.resolve(we)}_ensureOpen(){if(this._closedPromiseResolve)return!0;throw new Error("AsyncQueue is closed")}};var ro=class extends n0{write(t){if((t=_t(t)).byteLength>0)return super.write(t)}toString(t=!1){return t?Fd(this.toUint8Array(!0)):this.toUint8Array(!1).then(Fd)}toUint8Array(t=!1){return t?Tr(this._values)[0]:Z(this,void 0,void 0,function*(){var n,r,i,o;let s=[],a=0;try{for(var c=!0,l=bi(this),u;u=yield l.next(),n=u.done,!n;c=!0){o=u.value,c=!1;let f=o;s.push(f),a+=f.byteLength}}catch(f){r={error:f}}finally{try{!c&&!n&&(i=l.return)&&(yield i.call(l))}finally{if(r)throw r.error}}return Tr(s,a)[0]})}},io=class{constructor(t){t&&(this.source=new o2(bn.fromIterable(t)))}[Symbol.iterator](){return this}next(t){return this.source.next(t)}throw(t){return this.source.throw(t)}return(t){return this.source.return(t)}peek(t){return this.source.peek(t)}read(t){return this.source.read(t)}},Jr=class e{constructor(t){t instanceof e?this.source=t.source:t instanceof ro?this.source=new ds(bn.fromAsyncIterable(t)):fg(t)?this.source=new ds(bn.fromNodeStream(t)):Rd(t)?this.source=new ds(bn.fromDOMStream(t)):lg(t)?this.source=new ds(bn.fromDOMStream(t.body)):wi(t)?this.source=new ds(bn.fromIterable(t)):Ar(t)?this.source=new ds(bn.fromAsyncIterable(t)):Wr(t)&&(this.source=new ds(bn.fromAsyncIterable(t)))}[Symbol.asyncIterator](){return this}next(t){return this.source.next(t)}throw(t){return this.source.throw(t)}return(t){return this.source.return(t)}get closed(){return this.source.closed}cancel(t){return this.source.cancel(t)}peek(t){return this.source.peek(t)}read(t){return this.source.read(t)}},o2=class{constructor(t){this.source=t}cancel(t){this.return(t)}peek(t){return this.next(t,"peek").value}read(t){return this.next(t,"read").value}next(t,n="read"){return this.source.next({cmd:n,size:t})}throw(t){return Object.create(this.source.throw&&this.source.throw(t)||we)}return(t){return Object.create(this.source.return&&this.source.return(t)||we)}},ds=class{constructor(t){this.source=t,this._closedPromise=new Promise(n=>this._closedPromiseResolve=n)}cancel(t){return Z(this,void 0,void 0,function*(){yield this.return(t)})}get closed(){return this._closedPromise}read(t){return Z(this,void 0,void 0,function*(){return(yield this.next(t,"read")).value})}peek(t){return Z(this,void 0,void 0,function*(){return(yield this.next(t,"peek")).value})}next(t,n="read"){return Z(this,void 0,void 0,function*(){return yield this.source.next({cmd:n,size:t})})}throw(t){return Z(this,void 0,void 0,function*(){let n=this.source.throw&&(yield this.source.throw(t))||we;return this._closedPromiseResolve&&this._closedPromiseResolve(),this._closedPromiseResolve=void 0,Object.create(n)})}return(t){return Z(this,void 0,void 0,function*(){let n=this.source.return&&(yield this.source.return(t))||we;return this._closedPromiseResolve&&this._closedPromiseResolve(),this._closedPromiseResolve=void 0,Object.create(n)})}};var oh=class extends io{constructor(t,n){super(),this.position=0,this.buffer=_t(t),this.size=n===void 0?this.buffer.byteLength:n}readInt32(t){let{buffer:n,byteOffset:r}=this.readAt(t,4);return new DataView(n,r).getInt32(0,!0)}seek(t){return this.position=Math.min(t,this.size),t<this.size}read(t){let{buffer:n,size:r,position:i}=this;return n&&i<r?(typeof t!="number"&&(t=Number.POSITIVE_INFINITY),this.position=Math.min(r,i+Math.min(r-i,t)),n.subarray(i,this.position)):null}readAt(t,n){let r=this.buffer,i=Math.min(this.size,t+n);return r?r.subarray(t,i):new Uint8Array(n)}close(){this.buffer&&(this.buffer=null)}throw(t){return this.close(),{done:!0,value:t}}return(t){return this.close(),{done:!0,value:t}}},Sa=class extends Jr{constructor(t,n){super(),this.position=0,this._handle=t,typeof n=="number"?this.size=n:this._pending=Z(this,void 0,void 0,function*(){this.size=(yield t.stat()).size,delete this._pending})}readInt32(t){return Z(this,void 0,void 0,function*(){let{buffer:n,byteOffset:r}=yield this.readAt(t,4);return new DataView(n,r).getInt32(0,!0)})}seek(t){return Z(this,void 0,void 0,function*(){return this._pending&&(yield this._pending),this.position=Math.min(t,this.size),t<this.size})}read(t){return Z(this,void 0,void 0,function*(){this._pending&&(yield this._pending);let{_handle:n,size:r,position:i}=this;if(n&&i<r){typeof t!="number"&&(t=Number.POSITIVE_INFINITY);let o=i,s=0,a=0,c=Math.min(r,o+Math.min(r-o,t)),l=new Uint8Array(Math.max(0,(this.position=c)-o));for(;(o+=a)<c&&(s+=a)<l.byteLength;)({bytesRead:a}=yield n.read(l,s,l.byteLength-s,o));return l}return null})}readAt(t,n){return Z(this,void 0,void 0,function*(){this._pending&&(yield this._pending);let{_handle:r,size:i}=this;if(r&&t+n<i){let o=Math.min(i,t+n),s=new Uint8Array(o-t);return(yield r.read(s,0,n,t)).buffer}return new Uint8Array(n)})}close(){return Z(this,void 0,void 0,function*(){let t=this._handle;this._handle=null,t&&(yield t.close())})}throw(t){return Z(this,void 0,void 0,function*(){return yield this.close(),{done:!0,value:t}})}return(t){return Z(this,void 0,void 0,function*(){return yield this.close(),{done:!0,value:t}})}};var a2={};Ir(a2,{BaseInt64:()=>sh,Int128:()=>ah,Int64:()=>hs,Uint64:()=>Oe});function uu(e){return e<0&&(e=4294967295+e+1),`0x${e.toString(16)}`}var fu=8,s2=[1,10,100,1e3,1e4,1e5,1e6,1e7,1e8],sh=class{constructor(t){this.buffer=t}high(){return this.buffer[1]}low(){return this.buffer[0]}_times(t){let n=new Uint32Array([this.buffer[1]>>>16,this.buffer[1]&65535,this.buffer[0]>>>16,this.buffer[0]&65535]),r=new Uint32Array([t.buffer[1]>>>16,t.buffer[1]&65535,t.buffer[0]>>>16,t.buffer[0]&65535]),i=n[3]*r[3];this.buffer[0]=i&65535;let o=i>>>16;return i=n[2]*r[3],o+=i,i=n[3]*r[2]>>>0,o+=i,this.buffer[0]+=o<<16,this.buffer[1]=o>>>0<i?65536:0,this.buffer[1]+=o>>>16,this.buffer[1]+=n[1]*r[3]+n[2]*r[2]+n[3]*r[1],this.buffer[1]+=n[0]*r[3]+n[1]*r[2]+n[2]*r[1]+n[3]*r[0]<<16,this}_plus(t){let n=this.buffer[0]+t.buffer[0]>>>0;this.buffer[1]+=t.buffer[1],n<this.buffer[0]>>>0&&++this.buffer[1],this.buffer[0]=n}lessThan(t){return this.buffer[1]<t.buffer[1]||this.buffer[1]===t.buffer[1]&&this.buffer[0]<t.buffer[0]}equals(t){return this.buffer[1]===t.buffer[1]&&this.buffer[0]==t.buffer[0]}greaterThan(t){return t.lessThan(this)}hex(){return`${uu(this.buffer[1])} ${uu(this.buffer[0])}`}},Oe=class e extends sh{times(t){return this._times(t),this}plus(t){return this._plus(t),this}static from(t,n=new Uint32Array(2)){return e.fromString(typeof t=="string"?t:t.toString(),n)}static fromNumber(t,n=new Uint32Array(2)){return e.fromString(t.toString(),n)}static fromString(t,n=new Uint32Array(2)){let r=t.length,i=new e(n);for(let o=0;o<r;){let s=fu<r-o?fu:r-o,a=new e(new Uint32Array([Number.parseInt(t.slice(o,o+s),10),0])),c=new e(new Uint32Array([s2[s],0]));i.times(c),i.plus(a),o+=s}return i}static convertArray(t){let n=new Uint32Array(t.length*2);for(let r=-1,i=t.length;++r<i;)e.from(t[r],new Uint32Array(n.buffer,n.byteOffset+2*r*4,2));return n}static multiply(t,n){return new e(new Uint32Array(t.buffer)).times(n)}static add(t,n){return new e(new Uint32Array(t.buffer)).plus(n)}},hs=class e extends sh{negate(){return this.buffer[0]=~this.buffer[0]+1,this.buffer[1]=~this.buffer[1],this.buffer[0]==0&&++this.buffer[1],this}times(t){return this._times(t),this}plus(t){return this._plus(t),this}lessThan(t){let n=this.buffer[1]<<0,r=t.buffer[1]<<0;return n<r||n===r&&this.buffer[0]<t.buffer[0]}static from(t,n=new Uint32Array(2)){return e.fromString(typeof t=="string"?t:t.toString(),n)}static fromNumber(t,n=new Uint32Array(2)){return e.fromString(t.toString(),n)}static fromString(t,n=new Uint32Array(2)){let r=t.startsWith("-"),i=t.length,o=new e(n);for(let s=r?1:0;s<i;){let a=fu<i-s?fu:i-s,c=new e(new Uint32Array([Number.parseInt(t.slice(s,s+a),10),0])),l=new e(new Uint32Array([s2[a],0]));o.times(l),o.plus(c),s+=a}return r?o.negate():o}static convertArray(t){let n=new Uint32Array(t.length*2);for(let r=-1,i=t.length;++r<i;)e.from(t[r],new Uint32Array(n.buffer,n.byteOffset+2*r*4,2));return n}static multiply(t,n){return new e(new Uint32Array(t.buffer)).times(n)}static add(t,n){return new e(new Uint32Array(t.buffer)).plus(n)}},ah=class e{constructor(t){this.buffer=t}high(){return new hs(new Uint32Array(this.buffer.buffer,this.buffer.byteOffset+8,2))}low(){return new hs(new Uint32Array(this.buffer.buffer,this.buffer.byteOffset,2))}negate(){return this.buffer[0]=~this.buffer[0]+1,this.buffer[1]=~this.buffer[1],this.buffer[2]=~this.buffer[2],this.buffer[3]=~this.buffer[3],this.buffer[0]==0&&++this.buffer[1],this.buffer[1]==0&&++this.buffer[2],this.buffer[2]==0&&++this.buffer[3],this}times(t){let n=new Oe(new Uint32Array([this.buffer[3],0])),r=new Oe(new Uint32Array([this.buffer[2],0])),i=new Oe(new Uint32Array([this.buffer[1],0])),o=new Oe(new Uint32Array([this.buffer[0],0])),s=new Oe(new Uint32Array([t.buffer[3],0])),a=new Oe(new Uint32Array([t.buffer[2],0])),c=new Oe(new Uint32Array([t.buffer[1],0])),l=new Oe(new Uint32Array([t.buffer[0],0])),u=Oe.multiply(o,l);this.buffer[0]=u.low();let f=new Oe(new Uint32Array([u.high(),0]));return u=Oe.multiply(i,l),f.plus(u),u=Oe.multiply(o,c),f.plus(u),this.buffer[1]=f.low(),this.buffer[3]=f.lessThan(u)?1:0,this.buffer[2]=f.high(),new Oe(new Uint32Array(this.buffer.buffer,this.buffer.byteOffset+8,2)).plus(Oe.multiply(r,l)).plus(Oe.multiply(i,c)).plus(Oe.multiply(o,a)),this.buffer[3]+=Oe.multiply(n,l).plus(Oe.multiply(r,c)).plus(Oe.multiply(i,a)).plus(Oe.multiply(o,s)).low(),this}plus(t){let n=new Uint32Array(4);return n[3]=this.buffer[3]+t.buffer[3]>>>0,n[2]=this.buffer[2]+t.buffer[2]>>>0,n[1]=this.buffer[1]+t.buffer[1]>>>0,n[0]=this.buffer[0]+t.buffer[0]>>>0,n[0]<this.buffer[0]>>>0&&++n[1],n[1]<this.buffer[1]>>>0&&++n[2],n[2]<this.buffer[2]>>>0&&++n[3],this.buffer[3]=n[3],this.buffer[2]=n[2],this.buffer[1]=n[1],this.buffer[0]=n[0],this}hex(){return`${uu(this.buffer[3])} ${uu(this.buffer[2])} ${uu(this.buffer[1])} ${uu(this.buffer[0])}`}static multiply(t,n){return new e(new Uint32Array(t.buffer)).times(n)}static add(t,n){return new e(new Uint32Array(t.buffer)).plus(n)}static from(t,n=new Uint32Array(4)){return e.fromString(typeof t=="string"?t:t.toString(),n)}static fromNumber(t,n=new Uint32Array(4)){return e.fromString(t.toString(),n)}static fromString(t,n=new Uint32Array(4)){let r=t.startsWith("-"),i=t.length,o=new e(n);for(let s=r?1:0;s<i;){let a=fu<i-s?fu:i-s,c=new e(new Uint32Array([Number.parseInt(t.slice(s,s+a),10),0,0,0])),l=new e(new Uint32Array([s2[a],0,0,0]));o.times(l),o.plus(c),s+=a}return r?o.negate():o}static convertArray(t){let n=new Uint32Array(t.length*4);for(let r=-1,i=t.length;++r<i;)e.from(t[r],new Uint32Array(n.buffer,n.byteOffset+4*4*r,4));return n}};var ch=class extends mt{constructor(t,n,r,i,o=ce.V5){super(),this.nodesIndex=-1,this.buffersIndex=-1,this.bytes=t,this.nodes=n,this.buffers=r,this.dictionaries=i,this.metadataVersion=o}visit(t){return super.visit(t instanceof Ut?t.type:t)}visitNull(t,{length:n}=this.nextFieldNode()){return Nt({type:t,length:n})}visitBool(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitInt(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitFloat(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitUtf8(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),data:this.readData(t)})}visitLargeUtf8(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),data:this.readData(t)})}visitBinary(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),data:this.readData(t)})}visitLargeBinary(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),data:this.readData(t)})}visitFixedSizeBinary(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitDate(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitTimestamp(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitTime(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitDecimal(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitList(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),child:this.visit(t.children[0])})}visitStruct(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),children:this.visitMany(t.children)})}visitUnion(t,{length:n,nullCount:r}=this.nextFieldNode()){return this.metadataVersion<ce.V5&&this.readNullBitmap(t,r),t.mode===ge.Sparse?this.visitSparseUnion(t,{length:n,nullCount:r}):this.visitDenseUnion(t,{length:n,nullCount:r})}visitDenseUnion(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,typeIds:this.readTypeIds(t),valueOffsets:this.readOffsets(t),children:this.visitMany(t.children)})}visitSparseUnion(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,typeIds:this.readTypeIds(t),children:this.visitMany(t.children)})}visitDictionary(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t.indices),dictionary:this.readDictionary(t)})}visitInterval(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitDuration(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitFixedSizeList(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),child:this.visit(t.children[0])})}visitMap(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),child:this.visit(t.children[0])})}nextFieldNode(){return this.nodes[++this.nodesIndex]}nextBufferRange(){return this.buffers[++this.buffersIndex]}readNullBitmap(t,n,r=this.nextBufferRange()){return n>0&&this.readData(t,r)||new Uint8Array(0)}readOffsets(t,n){return this.readData(t,n)}readTypeIds(t,n){return this.readData(t,n)}readData(t,{length:n,offset:r}=this.nextBufferRange()){return this.bytes.subarray(r,r+n)}readDictionary(t){return this.dictionaries.get(t.id)}},r0=class extends ch{constructor(t,n,r,i,o){super(new Uint8Array(0),n,r,i,o),this.sources=t}readNullBitmap(t,n,{offset:r}=this.nextBufferRange()){return n<=0?new Uint8Array(0):Ic(this.sources[r])}readOffsets(t,{offset:n}=this.nextBufferRange()){return Pt(Uint8Array,Pt(t.OffsetArrayType,this.sources[n]))}readTypeIds(t,{offset:n}=this.nextBufferRange()){return Pt(Uint8Array,Pt(t.ArrayType,this.sources[n]))}readData(t,{offset:n}=this.nextBufferRange()){let{sources:r}=this;return st.isTimestamp(t)?Pt(Uint8Array,hs.convertArray(r[n])):(st.isInt(t)||st.isTime(t))&&t.bitWidth===64||st.isDuration(t)?Pt(Uint8Array,hs.convertArray(r[n])):st.isDate(t)&&t.unit===Ve.MILLISECOND?Pt(Uint8Array,hs.convertArray(r[n])):st.isDecimal(t)?Pt(Uint8Array,ah.convertArray(r[n])):st.isBinary(t)||st.isLargeBinary(t)||st.isFixedSizeBinary(t)?Zq(r[n]):st.isBool(t)?Ic(r[n]):st.isUtf8(t)||st.isLargeUtf8(t)?Zi(r[n].join("")):Pt(Uint8Array,Pt(t.ArrayType,r[n].map(i=>+i)))}};function Zq(e){let t=e.join(""),n=new Uint8Array(t.length/2);for(let r=0;r<t.length;r+=2)n[r>>1]=Number.parseInt(t.slice(r,r+2),16);return n}var du=class extends hr{constructor(t){super(t),this._values=new Ci(Uint8Array)}get byteLength(){let t=this._pendingLength+this.length*4;return this._offsets&&(t+=this._offsets.byteLength),this._values&&(t+=this._values.byteLength),this._nulls&&(t+=this._nulls.byteLength),t}setValue(t,n){return super.setValue(t,_t(n))}_flushPending(t,n){let r=this._offsets,i=this._values.reserve(n).buffer,o=0;for(let[s,a]of t)if(a===void 0)r.set(s,0);else{let c=a.length;i.set(a,o),r.set(s,c),o+=c}}};var hu=class extends hr{constructor(t){super(t),this._values=new Ci(Uint8Array)}get byteLength(){let t=this._pendingLength+this.length*4;return this._offsets&&(t+=this._offsets.byteLength),this._values&&(t+=this._values.byteLength),this._nulls&&(t+=this._nulls.byteLength),t}setValue(t,n){return super.setValue(t,_t(n))}_flushPending(t,n){let r=this._offsets,i=this._values.reserve(n).buffer,o=0;for(let[s,a]of t)if(a===void 0)r.set(s,BigInt(0));else{let c=a.length;i.set(a,o),r.set(s,BigInt(c)),o+=c}}};var i0=class extends ve{constructor(t){super(t),this._values=new cu}setValue(t,n){this._values.set(t,+n)}};var Ec=class extends Xe{};Ec.prototype._setValue=U_;var lh=class extends Ec{};lh.prototype._setValue=Dg;var uh=class extends Ec{};uh.prototype._setValue=Og;var fh=class extends Xe{};fh.prototype._setValue=j_;var o0=class extends ve{constructor({type:t,nullValues:n,dictionaryHashFunction:r}){super({type:new Dr(t.dictionary,t.indices,t.id,t.isOrdered)}),this._nulls=null,this._dictionaryOffset=0,this._keysToIndices=Object.create(null),this.indices=Nc({type:this.type.indices,nullValues:n}),this.dictionary=Nc({type:this.type.dictionary,nullValues:null}),typeof r=="function"&&(this.valueToKey=r)}get values(){return this.indices.values}get nullCount(){return this.indices.nullCount}get nullBitmap(){return this.indices.nullBitmap}get byteLength(){return this.indices.byteLength+this.dictionary.byteLength}get reservedLength(){return this.indices.reservedLength+this.dictionary.reservedLength}get reservedByteLength(){return this.indices.reservedByteLength+this.dictionary.reservedByteLength}isValid(t){return this.indices.isValid(t)}setValid(t,n){let r=this.indices;return n=r.setValid(t,n),this.length=r.length,n}setValue(t,n){let r=this._keysToIndices,i=this.valueToKey(n),o=r[i];return o===void 0&&(r[i]=o=this._dictionaryOffset+this.dictionary.append(n).length-1),this.indices.setValue(t,o)}flush(){let t=this.type,n=this._dictionary,r=this.dictionary.toVector(),i=this.indices.flush().clone(t);return i.dictionary=n?n.concat(r):r,this.finished||(this._dictionaryOffset+=r.length),this._dictionary=i.dictionary,this.clear(),i}finish(){return this.indices.finish(),this.dictionary.finish(),this._dictionaryOffset=0,this._keysToIndices=Object.create(null),super.finish()}clear(){return this.indices.clear(),this.dictionary.clear(),super.clear()}valueToKey(t){return typeof t=="string"?t:`${t}`}};var dh=class extends Xe{};dh.prototype._setValue=P_;var s0=class extends ve{setValue(t,n){let[r]=this.children,i=t*this.stride;for(let o=-1,s=n.length;++o<s;)r.set(i+o,n[o])}addChild(t,n="0"){if(this.numChildren>0)throw new Error("FixedSizeListBuilder can only have one child.");let r=this.children.push(t);return this.type=new Oi(this.type.listSize,new Ut(n,t.type,!0)),r}};var Dc=class extends Xe{setValue(t,n){this._values.set(t,n)}},a0=class extends Dc{setValue(t,n){super.setValue(t,Kd(n))}},c0=class extends Dc{},l0=class extends Dc{};var Oc=class extends Xe{};Oc.prototype._setValue=V_;var hh=class extends Oc{};hh.prototype._setValue=Ug;var ph=class extends Oc{};ph.prototype._setValue=zg;var ps=class extends Xe{};ps.prototype._setValue=Y_;var mh=class extends ps{};mh.prototype._setValue=qg;var yh=class extends ps{};yh.prototype._setValue=jg;var gh=class extends ps{};gh.prototype._setValue=Vg;var xh=class extends ps{};xh.prototype._setValue=Yg;var Qr=class extends Xe{setValue(t,n){this._values.set(t,n)}},u0=class extends Qr{},f0=class extends Qr{},d0=class extends Qr{},h0=class extends Qr{},p0=class extends Qr{},m0=class extends Qr{},y0=class extends Qr{},g0=class extends Qr{};var x0=class extends hr{constructor(t){super(t),this._offsets=new lu(t.type)}addChild(t,n="0"){if(this.numChildren>0)throw new Error("ListBuilder can only have one child.");return this.children[this.numChildren]=t,this.type=new Ni(new Ut(n,t.type,!0)),this.numChildren-1}_flushPending(t){let n=this._offsets,[r]=this.children;for(let[i,o]of t)if(typeof o>"u")n.set(i,0);else{let s=o,a=s.length,c=n.set(i,a).buffer[i];for(let l=-1;++l<a;)r.set(c+l,s[l])}}};var b0=class extends hr{set(t,n){return super.set(t,n)}setValue(t,n){let r=n instanceof Map?n:new Map(Object.entries(n)),i=this._pending||(this._pending=new Map),o=i.get(t);o&&(this._pendingLength-=o.size),this._pendingLength+=r.size,i.set(t,r)}addChild(t,n=`${this.numChildren}`){if(this.numChildren>0)throw new Error("ListBuilder can only have one child.");return this.children[this.numChildren]=t,this.type=new Bi(new Ut(n,t.type,!0),this.type.keysSorted),this.numChildren-1}_flushPending(t){let n=this._offsets,[r]=this.children;for(let[i,o]of t)if(o===void 0)n.set(i,0);else{let{[i]:s,[i+1]:a}=n.set(i,o.size).buffer;for(let c of o.entries())if(r.set(s,c),++s>=a)break}}};var w0=class extends ve{setValue(t,n){}setValid(t,n){return this.length=Math.max(t+1,this.length),n}};var v0=class extends ve{setValue(t,n){let{children:r,type:i}=this;switch(Array.isArray(n)||n.constructor){case!0:return i.children.forEach((o,s)=>r[s].set(t,n[s]));case Map:return i.children.forEach((o,s)=>r[s].set(t,n.get(o.name)));default:return i.children.forEach((o,s)=>r[s].set(t,n[o.name]))}}setValid(t,n){return super.setValid(t,n)||this.children.forEach(r=>r.setValid(t,n)),n}addChild(t,n=`${this.numChildren}`){let r=this.children.push(t);return this.type=new be([...this.type.children,new Ut(n,t.type,!0)]),r}};var ms=class extends Xe{};ms.prototype._setValue=z_;var bh=class extends ms{};bh.prototype._setValue=Bg;var wh=class extends ms{};wh.prototype._setValue=Lg;var vh=class extends ms{};vh.prototype._setValue=Cg;var _h=class extends ms{};_h.prototype._setValue=kg;var ys=class extends Xe{};ys.prototype._setValue=q_;var Sh=class extends ys{};Sh.prototype._setValue=Fg;var Ih=class extends ys{};Ih.prototype._setValue=Rg;var Mh=class extends ys{};Mh.prototype._setValue=$g;var Ah=class extends ys{};Ah.prototype._setValue=Pg;var pu=class extends ve{constructor(t){super(t),this._typeIds=new ls(Int8Array,0,1),typeof t.valueToChildTypeId=="function"&&(this._valueToChildTypeId=t.valueToChildTypeId)}get typeIdToChildIndex(){return this.type.typeIdToChildIndex}append(t,n){return this.set(this.length,t,n)}set(t,n,r){return r===void 0&&(r=this._valueToChildTypeId(this,n,t)),this.setValue(t,n,r),this}setValue(t,n,r){this._typeIds.set(t,r);let i=this.type.typeIdToChildIndex[r],o=this.children[i];o?.set(t,n)}addChild(t,n=`${this.children.length}`){let r=this.children.push(t),{type:{children:i,mode:o,typeIds:s}}=this,a=[...i,new Ut(n,t.type)];return this.type=new Di(o,[...s,r],a),r}_valueToChildTypeId(t,n,r){throw new Error("Cannot map UnionBuilder value to child typeId. Pass the `childTypeId` as the second argument to unionBuilder.append(), or supply a `valueToChildTypeId` function as part of the UnionBuilder constructor options.")}},_0=class extends pu{},S0=class extends pu{constructor(t){super(t),this._offsets=new ls(Int32Array)}setValue(t,n,r){let i=this._typeIds.set(t,r).buffer[t],o=this.getChildAt(this.type.typeIdToChildIndex[i]),s=this._offsets.set(t,o.length).buffer[t];o?.set(s,n)}};var Th=class extends hr{constructor(t){super(t),this._values=new Ci(Uint8Array)}get byteLength(){let t=this._pendingLength+this.length*4;return this._offsets&&(t+=this._offsets.byteLength),this._values&&(t+=this._values.byteLength),this._nulls&&(t+=this._nulls.byteLength),t}setValue(t,n){return super.setValue(t,Zi(n))}_flushPending(t,n){}};Th.prototype._flushPending=du.prototype._flushPending;var Eh=class extends hr{constructor(t){super(t),this._values=new Ci(Uint8Array)}get byteLength(){let t=this._pendingLength+this.length*4;return this._offsets&&(t+=this._offsets.byteLength),this._values&&(t+=this._values.byteLength),this._nulls&&(t+=this._nulls.byteLength),t}setValue(t,n){return super.setValue(t,Zi(n))}_flushPending(t,n){}};Eh.prototype._flushPending=hu.prototype._flushPending;var c2=class extends mt{visitNull(){return w0}visitBool(){return i0}visitInt(){return Qr}visitInt8(){return u0}visitInt16(){return f0}visitInt32(){return d0}visitInt64(){return h0}visitUint8(){return p0}visitUint16(){return m0}visitUint32(){return y0}visitUint64(){return g0}visitFloat(){return Dc}visitFloat16(){return a0}visitFloat32(){return c0}visitFloat64(){return l0}visitUtf8(){return Th}visitLargeUtf8(){return Eh}visitBinary(){return du}visitLargeBinary(){return hu}visitFixedSizeBinary(){return dh}visitDate(){return Ec}visitDateDay(){return lh}visitDateMillisecond(){return uh}visitTimestamp(){return ms}visitTimestampSecond(){return bh}visitTimestampMillisecond(){return wh}visitTimestampMicrosecond(){return vh}visitTimestampNanosecond(){return _h}visitTime(){return ys}visitTimeSecond(){return Sh}visitTimeMillisecond(){return Ih}visitTimeMicrosecond(){return Mh}visitTimeNanosecond(){return Ah}visitDecimal(){return fh}visitList(){return x0}visitStruct(){return v0}visitUnion(){return pu}visitDenseUnion(){return S0}visitSparseUnion(){return _0}visitDictionary(){return o0}visitInterval(){return Oc}visitIntervalDayTime(){return hh}visitIntervalYearMonth(){return ph}visitDuration(){return ps}visitDurationSecond(){return mh}visitDurationMillisecond(){return yh}visitDurationMicrosecond(){return gh}visitDurationNanosecond(){return xh}visitFixedSizeList(){return s0}visitMap(){return b0}},HO=new c2;var bt=class extends mt{compareSchemas(t,n){return t===n||n instanceof t.constructor&&this.compareManyFields(t.fields,n.fields)}compareManyFields(t,n){return t===n||Array.isArray(t)&&Array.isArray(n)&&t.length===n.length&&t.every((r,i)=>this.compareFields(r,n[i]))}compareFields(t,n){return t===n||n instanceof t.constructor&&t.name===n.name&&t.nullable===n.nullable&&this.visit(t.type,n.type)}};function Gn(e,t){return t instanceof e.constructor}function Bc(e,t){return e===t||Gn(e,t)}function gs(e,t){return e===t||Gn(e,t)&&e.bitWidth===t.bitWidth&&e.isSigned===t.isSigned}function I0(e,t){return e===t||Gn(e,t)&&e.precision===t.precision}function Jq(e,t){return e===t||Gn(e,t)&&e.byteWidth===t.byteWidth}function l2(e,t){return e===t||Gn(e,t)&&e.unit===t.unit}function Nh(e,t){return e===t||Gn(e,t)&&e.unit===t.unit&&e.timezone===t.timezone}function Dh(e,t){return e===t||Gn(e,t)&&e.unit===t.unit&&e.bitWidth===t.bitWidth}function Qq(e,t){return e===t||Gn(e,t)&&e.children.length===t.children.length&&oo.compareManyFields(e.children,t.children)}function Kq(e,t){return e===t||Gn(e,t)&&e.children.length===t.children.length&&oo.compareManyFields(e.children,t.children)}function u2(e,t){return e===t||Gn(e,t)&&e.mode===t.mode&&e.typeIds.every((n,r)=>n===t.typeIds[r])&&oo.compareManyFields(e.children,t.children)}function tj(e,t){return e===t||Gn(e,t)&&e.id===t.id&&e.isOrdered===t.isOrdered&&oo.visit(e.indices,t.indices)&&oo.visit(e.dictionary,t.dictionary)}function f2(e,t){return e===t||Gn(e,t)&&e.unit===t.unit}function Oh(e,t){return e===t||Gn(e,t)&&e.unit===t.unit}function ej(e,t){return e===t||Gn(e,t)&&e.listSize===t.listSize&&e.children.length===t.children.length&&oo.compareManyFields(e.children,t.children)}function nj(e,t){return e===t||Gn(e,t)&&e.keysSorted===t.keysSorted&&e.children.length===t.children.length&&oo.compareManyFields(e.children,t.children)}bt.prototype.visitNull=Bc;bt.prototype.visitBool=Bc;bt.prototype.visitInt=gs;bt.prototype.visitInt8=gs;bt.prototype.visitInt16=gs;bt.prototype.visitInt32=gs;bt.prototype.visitInt64=gs;bt.prototype.visitUint8=gs;bt.prototype.visitUint16=gs;bt.prototype.visitUint32=gs;bt.prototype.visitUint64=gs;bt.prototype.visitFloat=I0;bt.prototype.visitFloat16=I0;bt.prototype.visitFloat32=I0;bt.prototype.visitFloat64=I0;bt.prototype.visitUtf8=Bc;bt.prototype.visitLargeUtf8=Bc;bt.prototype.visitBinary=Bc;bt.prototype.visitLargeBinary=Bc;bt.prototype.visitFixedSizeBinary=Jq;bt.prototype.visitDate=l2;bt.prototype.visitDateDay=l2;bt.prototype.visitDateMillisecond=l2;bt.prototype.visitTimestamp=Nh;bt.prototype.visitTimestampSecond=Nh;bt.prototype.visitTimestampMillisecond=Nh;bt.prototype.visitTimestampMicrosecond=Nh;bt.prototype.visitTimestampNanosecond=Nh;bt.prototype.visitTime=Dh;bt.prototype.visitTimeSecond=Dh;bt.prototype.visitTimeMillisecond=Dh;bt.prototype.visitTimeMicrosecond=Dh;bt.prototype.visitTimeNanosecond=Dh;bt.prototype.visitDecimal=Bc;bt.prototype.visitList=Qq;bt.prototype.visitStruct=Kq;bt.prototype.visitUnion=u2;bt.prototype.visitDenseUnion=u2;bt.prototype.visitSparseUnion=u2;bt.prototype.visitDictionary=tj;bt.prototype.visitInterval=f2;bt.prototype.visitIntervalDayTime=f2;bt.prototype.visitIntervalYearMonth=f2;bt.prototype.visitDuration=Oh;bt.prototype.visitDurationSecond=Oh;bt.prototype.visitDurationMillisecond=Oh;bt.prototype.visitDurationMicrosecond=Oh;bt.prototype.visitDurationNanosecond=Oh;bt.prototype.visitFixedSizeList=ej;bt.prototype.visitMap=nj;var oo=new bt;function Lc(e,t){return oo.compareSchemas(e,t)}function ZO(e,t){return oo.compareFields(e,t)}function JO(e,t){return oo.visit(e,t)}function Nc(e){let t=e.type,n=new(HO.getVisitFn(t)())(e);if(t.children&&t.children.length>0){let r=e.children||[],i={nullValues:e.nullValues},o=Array.isArray(r)?(s,a)=>r[a]||i:({name:s})=>r[s]||i;for(let[s,a]of t.children.entries()){let{type:c}=a,l=o(a,s);n.children.push(Nc(Object.assign(Object.assign({},l),{type:c})))}}return n}function M0(e,t){return rj(e,t.map(n=>n.data.concat()))}function rj(e,t){let n=[...e.fields],r=[],i={numBatches:t.reduce((f,d)=>Math.max(f,d.length),0)},o=0,s=0,a=-1,c=t.length,l,u=[];for(;i.numBatches-- >0;){for(s=Number.POSITIVE_INFINITY,a=-1;++a<c;)u[a]=l=t[a].shift(),s=Math.min(s,l?l.length:s);Number.isFinite(s)&&(u=ij(n,s,u,t,i),s>0&&(r[o++]=Nt({type:new be(n),length:s,nullCount:0,children:u.slice()})))}return[e=e.assign(n),r.map(f=>new ke(e,f))]}function ij(e,t,n,r,i){var o;let s=(t+63&-64)>>3;for(let a=-1,c=r.length;++a<c;){let l=n[a],u=l?.length;if(u>=t)u===t?n[a]=l:(n[a]=l.slice(0,t),i.numBatches=Math.max(i.numBatches,r[a].unshift(l.slice(t,u-t))));else{let f=e[a];e[a]=f.clone({nullable:!0}),n[a]=(o=l?._changeLengthAndBackfillNullBitmap(t))!==null&&o!==void 0?o:Nt({type:f.type,length:t,nullCount:t,nullBitmap:new Uint8Array(s)})}}return n}var QO,pr=class e{constructor(...t){var n,r;if(t.length===0)return this.batches=[],this.schema=new oe([]),this._offsets=[0],this;let i,o;t[0]instanceof oe&&(i=t.shift()),t.at(-1)instanceof Uint32Array&&(o=t.pop());let s=c=>{if(c){if(c instanceof ke)return[c];if(c instanceof e)return c.batches;if(c instanceof te){if(c.type instanceof be)return[new ke(new oe(c.type.children),c)]}else{if(Array.isArray(c))return c.flatMap(l=>s(l));if(typeof c[Symbol.iterator]=="function")return[...c].flatMap(l=>s(l));if(typeof c=="object"){let l=Object.keys(c),u=l.map(h=>new Xt([c[h]])),f=i??new oe(l.map((h,p)=>new Ut(String(h),u[p].type,u[p].nullable))),[,d]=M0(f,u);return d.length===0?[new ke(c)]:d}}}return[]},a=t.flatMap(c=>s(c));if(i=(r=i??((n=a[0])===null||n===void 0?void 0:n.schema))!==null&&r!==void 0?r:new oe([]),!(i instanceof oe))throw new TypeError("Table constructor expects a [Schema, RecordBatch[]] pair.");for(let c of a){if(!(c instanceof ke))throw new TypeError("Table constructor expects a [Schema, RecordBatch[]] pair.");if(!Lc(i,c.schema))throw new TypeError("Table and inner RecordBatch schemas must be equivalent.")}this.schema=i,this.batches=a,this._offsets=o??Zg(this.data)}get data(){return this.batches.map(({data:t})=>t)}get numCols(){return this.schema.fields.length}get numRows(){return this.data.reduce((t,n)=>t+n.length,0)}get nullCount(){return this._nullCount===-1&&(this._nullCount=Hg(this.data)),this._nullCount}isValid(t){return!1}get(t){return null}set(t,n){}indexOf(t,n){return-1}[Symbol.iterator](){return this.batches.length>0?au.visit(new Xt(this.data)):new Array(0)[Symbol.iterator]()}toArray(){return[...this]}toString(){return`[
|
|
7
|
+
return true;`)}function rj(e){return typeof e!="bigint"?Oi(e):`${Oi(e)}n`}function i2(e,t){let n=Math.ceil(e)*t-1;return(n-n%64+64||64)/t}function iB(e,t=0){return e.length>=t?e.subarray(0,t):Rh(new e.constructor(t),e,0)}var ki=class{constructor(t,n=0,r=1){this.length=Math.ceil(n/r),this.buffer=new t(this.length),this.stride=r,this.BYTES_PER_ELEMENT=t.BYTES_PER_ELEMENT,this.ArrayType=t}get byteLength(){return Math.ceil(this.length*this.stride)*this.BYTES_PER_ELEMENT}get reservedLength(){return this.buffer.length/this.stride}get reservedByteLength(){return this.buffer.byteLength}set(t,n){return this}append(t){return this.set(this.length,t)}reserve(t){if(t>0){this.length+=t;let n=this.stride,r=this.length*n,i=this.buffer.length;r>=i&&this._resize(i===0?i2(r*1,this.BYTES_PER_ELEMENT):i2(r*2,this.BYTES_PER_ELEMENT))}return this}flush(t=this.length){t=i2(t*this.stride,this.BYTES_PER_ELEMENT);let n=iB(this.buffer,t);return this.clear(),n}clear(){return this.length=0,this.buffer=new this.ArrayType,this}_resize(t){return this.buffer=iB(this.buffer,t)}},as=class extends ki{last(){return this.get(this.length-1)}get(t){return this.buffer[t]}set(t,n){return this.reserve(t-this.length+1),this.buffer[t*this.stride]=n,this}},fu=class extends as{constructor(){super(Uint8Array,0,1/8),this.numValid=0}get numInvalid(){return this.length-this.numValid}get(t){return this.buffer[t>>3]>>t%8&1}set(t,n){let{buffer:r}=this.reserve(t-this.length+1),i=t>>3,o=t%8,s=r[i]>>o&1;return n?s===0&&(r[i]|=1<<o,++this.numValid):s===1&&(r[i]&=~(1<<o),--this.numValid),this}clear(){return this.numValid=0,super.clear()}},hu=class extends as{constructor(t){super(t.OffsetArrayType,1,1)}append(t){return this.set(this.length-1,t)}set(t,n){let r=this.length-1,i=this.reserve(t-r+1).buffer;return r<t++&&r>=0&&i.fill(i[r],r,t),i[t]=i[t-1]+n,this}flush(t=this.length-1){return t>this.length&&this.set(t-1,this.BYTES_PER_ELEMENT>4?BigInt(0):0),super.flush(t+1)}};var ve=class{static throughNode(t){throw new Error('"throughNode" not available in this environment')}static throughDOM(t){throw new Error('"throughDOM" not available in this environment')}constructor({type:t,nullValues:n}){this.length=0,this.finished=!1,this.type=t,this.children=[],this.nullValues=n,this.stride=Or(t),this._nulls=new fu,n&&n.length>0&&(this._isValid=rB(n))}toVector(){return new Xt([this.flush()])}get ArrayType(){return this.type.ArrayType}get nullCount(){return this._nulls.numInvalid}get numChildren(){return this.children.length}get byteLength(){let t=0,{_offsets:n,_values:r,_nulls:i,_typeIds:o,children:s}=this;return n&&(t+=n.byteLength),r&&(t+=r.byteLength),i&&(t+=i.byteLength),o&&(t+=o.byteLength),s.reduce((a,c)=>a+c.byteLength,t)}get reservedLength(){return this._nulls.reservedLength}get reservedByteLength(){let t=0;return this._offsets&&(t+=this._offsets.reservedByteLength),this._values&&(t+=this._values.reservedByteLength),this._nulls&&(t+=this._nulls.reservedByteLength),this._typeIds&&(t+=this._typeIds.reservedByteLength),this.children.reduce((n,r)=>n+r.reservedByteLength,t)}get valueOffsets(){return this._offsets?this._offsets.buffer:null}get values(){return this._values?this._values.buffer:null}get nullBitmap(){return this._nulls?this._nulls.buffer:null}get typeIds(){return this._typeIds?this._typeIds.buffer:null}append(t){return this.set(this.length,t)}isValid(t){return this._isValid(t)}set(t,n){return this.setValid(t,this.isValid(n))&&this.setValue(t,n),this}setValue(t,n){this._setValue(this,t,n)}setValid(t,n){return this.length=this._nulls.set(t,+n).length,n}addChild(t,n=`${this.numChildren}`){throw new Error(`Cannot append children to non-nested type "${this.type}"`)}getChildAt(t){return this.children[t]||null}flush(){let t,n,r,i,{type:o,length:s,nullCount:a,_typeIds:c,_offsets:l,_values:u,_nulls:f}=this;(n=c?.flush(s))?i=l?.flush(s):(i=l?.flush(s))?t=u?.flush(l.last()):t=u?.flush(s),a>0&&(r=f?.flush(s));let h=this.children.map(d=>d.flush());return this.clear(),Nt({type:o,length:s,nullCount:a,children:h,child:h[0],data:t,typeIds:n,nullBitmap:r,valueOffsets:i})}finish(){this.finished=!0;for(let t of this.children)t.finish();return this}clear(){var t,n,r,i;this.length=0,(t=this._nulls)===null||t===void 0||t.clear(),(n=this._values)===null||n===void 0||n.clear(),(r=this._offsets)===null||r===void 0||r.clear(),(i=this._typeIds)===null||i===void 0||i.clear();for(let o of this.children)o.clear();return this}};ve.prototype.length=1;ve.prototype.stride=1;ve.prototype.children=null;ve.prototype.finished=!1;ve.prototype.nullValues=null;ve.prototype._isValid=()=>!0;var Xe=class extends ve{constructor(t){super(t),this._values=new as(this.ArrayType,0,this.stride)}setValue(t,n){let r=this._values;return r.reserve(t-r.length+1),super.setValue(t,n)}},pr=class extends ve{constructor(t){super(t),this._pendingLength=0,this._offsets=new hu(t.type)}setValue(t,n){let r=this._pending||(this._pending=new Map),i=r.get(t);i&&(this._pendingLength-=i.length),this._pendingLength+=n instanceof po?n[ei].length:n.length,r.set(t,n)}setValid(t,n){return super.setValid(t,n)?!0:((this._pending||(this._pending=new Map)).set(t,void 0),!1)}clear(){return this._pendingLength=0,this._pending=void 0,super.clear()}flush(){return this._flush(),super.flush()}finish(){return this._flush(),super.finish()}_flush(){let t=this._pending,n=this._pendingLength;return this._pendingLength=0,this._pending=void 0,t&&t.size>0&&this._flushPending(t,n),this}};var Tc=class{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}offset(){return this.bb.readInt64(this.bb_pos)}metaDataLength(){return this.bb.readInt32(this.bb_pos+8)}bodyLength(){return this.bb.readInt64(this.bb_pos+16)}static sizeOf(){return 24}static createBlock(t,n,r,i){return t.prep(8,24),t.writeInt64(BigInt(i??0)),t.pad(4),t.writeInt32(r),t.writeInt64(BigInt(n??0)),t.offset()}};var Br=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsFooter(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsFooter(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}version(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ce.V1}schema(t){let n=this.bb.__offset(this.bb_pos,6);return n?(t||new hr).__init(this.bb.__indirect(this.bb_pos+n),this.bb):null}dictionaries(t,n){let r=this.bb.__offset(this.bb_pos,8);return r?(n||new Tc).__init(this.bb.__vector(this.bb_pos+r)+t*24,this.bb):null}dictionariesLength(){let t=this.bb.__offset(this.bb_pos,8);return t?this.bb.__vector_len(this.bb_pos+t):0}recordBatches(t,n){let r=this.bb.__offset(this.bb_pos,10);return r?(n||new Tc).__init(this.bb.__vector(this.bb_pos+r)+t*24,this.bb):null}recordBatchesLength(){let t=this.bb.__offset(this.bb_pos,10);return t?this.bb.__vector_len(this.bb_pos+t):0}customMetadata(t,n){let r=this.bb.__offset(this.bb_pos,12);return r?(n||new nn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}customMetadataLength(){let t=this.bb.__offset(this.bb_pos,12);return t?this.bb.__vector_len(this.bb_pos+t):0}static startFooter(t){t.startObject(5)}static addVersion(t,n){t.addFieldInt16(0,n,ce.V1)}static addSchema(t,n){t.addFieldOffset(1,n,0)}static addDictionaries(t,n){t.addFieldOffset(2,n,0)}static startDictionariesVector(t,n){t.startVector(24,n,8)}static addRecordBatches(t,n){t.addFieldOffset(3,n,0)}static startRecordBatchesVector(t,n){t.startVector(24,n,8)}static addCustomMetadata(t,n){t.addFieldOffset(4,n,0)}static createCustomMetadataVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startCustomMetadataVector(t,n){t.startVector(4,n,4)}static endFooter(t){return t.endObject()}static finishFooterBuffer(t,n){t.finish(n)}static finishSizePrefixedFooterBuffer(t,n){t.finish(n,void 0,!0)}};var oe=class e{constructor(t=[],n,r,i=ce.V5){this.fields=t||[],this.metadata=n||new Map,r||(r=o2(t)),this.dictionaries=r,this.metadataVersion=i}get[Symbol.toStringTag](){return"Schema"}get names(){return this.fields.map(t=>t.name)}toString(){return`Schema<{ ${this.fields.map((t,n)=>`${n}: ${t}`).join(", ")} }>`}select(t){let n=new Set(t),r=this.fields.filter(i=>n.has(i.name));return new e(r,this.metadata)}selectAt(t){let n=t.map(r=>this.fields[r]).filter(Boolean);return new e(n,this.metadata)}assign(...t){let n=t[0]instanceof e?t[0]:Array.isArray(t[0])?new e(t[0]):new e(t),r=[...this.fields],i=r0(r0(new Map,this.metadata),n.metadata),o=n.fields.filter(a=>{let c=r.findIndex(l=>l.name===a.name);return~c?(r[c]=a.clone({metadata:r0(r0(new Map,r[c].metadata),a.metadata)}))&&!1:!0}),s=o2(o,new Map);return new e([...r,...o],i,new Map([...this.dictionaries,...s]))}};oe.prototype.fields=null;oe.prototype.metadata=null;oe.prototype.dictionaries=null;var Ut=class e{static new(...t){let[n,r,i,o]=t;return t[0]&&typeof t[0]=="object"&&({name:n}=t[0],r===void 0&&(r=t[0].type),i===void 0&&(i=t[0].nullable),o===void 0&&(o=t[0].metadata)),new e(`${n}`,r,i,o)}constructor(t,n,r=!1,i){this.name=t,this.type=n,this.nullable=r,this.metadata=i||new Map}get typeId(){return this.type.typeId}get[Symbol.toStringTag](){return"Field"}toString(){return`${this.name}: ${this.type}`}clone(...t){let[n,r,i,o]=t;return!t[0]||typeof t[0]!="object"?[n=this.name,r=this.type,i=this.nullable,o=this.metadata]=t:{name:n=this.name,type:r=this.type,nullable:i=this.nullable,metadata:o=this.metadata}=t[0],e.new(n,r,i,o)}};Ut.prototype.type=null;Ut.prototype.name=null;Ut.prototype.nullable=null;Ut.prototype.metadata=null;function r0(e,t){return new Map([...e||new Map,...t||new Map])}function o2(e,t=new Map){for(let n=-1,r=e.length;++n<r;){let o=e[n].type;if(H.isDictionary(o)){if(!t.has(o.id))t.set(o.id,o.dictionary);else if(t.get(o.id)!==o.dictionary)throw new Error("Cannot create Schema containing two different dictionaries with the same Id")}o.children&&o.children.length>0&&o2(o.children,t)}return t}var ij=_c,oj=Nr,cs=class{static decode(t){t=new oj(_t(t));let n=Br.getRootAsFooter(t),r=oe.decode(n.schema(),new Map,n.version());return new s2(r,n)}static encode(t){let n=new ij,r=oe.encode(n,t.schema);Br.startRecordBatchesVector(n,t.numRecordBatches);for(let s of[...t.recordBatches()].slice().reverse())ls.encode(n,s);let i=n.endVector();Br.startDictionariesVector(n,t.numDictionaries);for(let s of[...t.dictionaryBatches()].slice().reverse())ls.encode(n,s);let o=n.endVector();return Br.startFooter(n),Br.addSchema(n,r),Br.addVersion(n,ce.V5),Br.addRecordBatches(n,i),Br.addDictionaries(n,o),Br.finishFooterBuffer(n,Br.endFooter(n)),n.asUint8Array()}get numRecordBatches(){return this._recordBatches.length}get numDictionaries(){return this._dictionaryBatches.length}constructor(t,n=ce.V5,r,i){this.schema=t,this.version=n,r&&(this._recordBatches=r),i&&(this._dictionaryBatches=i)}*recordBatches(){for(let t,n=-1,r=this.numRecordBatches;++n<r;)(t=this.getRecordBatch(n))&&(yield t)}*dictionaryBatches(){for(let t,n=-1,r=this.numDictionaries;++n<r;)(t=this.getDictionaryBatch(n))&&(yield t)}getRecordBatch(t){return t>=0&&t<this.numRecordBatches&&this._recordBatches[t]||null}getDictionaryBatch(t){return t>=0&&t<this.numDictionaries&&this._dictionaryBatches[t]||null}};var s2=class extends cs{get numRecordBatches(){return this._footer.recordBatchesLength()}get numDictionaries(){return this._footer.dictionariesLength()}constructor(t,n){super(t,n.version()),this._footer=n}getRecordBatch(t){if(t>=0&&t<this.numRecordBatches){let n=this._footer.recordBatches(t);if(n)return ls.decode(n)}return null}getDictionaryBatch(t){if(t>=0&&t<this.numDictionaries){let n=this._footer.dictionaries(t);if(n)return ls.decode(n)}return null}},ls=class e{static decode(t){return new e(t.metaDataLength(),t.bodyLength(),t.offset())}static encode(t,n){let{metaDataLength:r}=n,i=BigInt(n.offset),o=BigInt(n.bodyLength);return Tc.createBlock(t,i,r,o)}constructor(t,n,r){this.metaDataLength=t,this.offset=De(r),this.bodyLength=De(n)}};var we=Object.freeze({done:!0,value:void 0}),dd=class{constructor(t){this._json=t}get schema(){return this._json.schema}get batches(){return this._json.batches||[]}get dictionaries(){return this._json.dictionaries||[]}},Ec=class{tee(){return this._getDOMStream().tee()}pipe(t,n){return this._getNodeStream().pipe(t,n)}pipeTo(t,n){return this._getDOMStream().pipeTo(t,n)}pipeThrough(t,n){return this._getDOMStream().pipeThrough(t,n)}_getDOMStream(){return this._DOMStream||(this._DOMStream=this.toDOMStream())}_getNodeStream(){return this._nodeStream||(this._nodeStream=this.toNodeStream())}},i0=class extends Ec{constructor(){super(),this._values=[],this.resolvers=[],this._closedPromise=new Promise(t=>this._closedPromiseResolve=t)}get closed(){return this._closedPromise}cancel(t){return J(this,void 0,void 0,function*(){yield this.return(t)})}write(t){this._ensureOpen()&&(this.resolvers.length<=0?this._values.push(t):this.resolvers.shift().resolve({done:!1,value:t}))}abort(t){this._closedPromiseResolve&&(this.resolvers.length<=0?this._error={error:t}:this.resolvers.shift().reject({done:!0,value:t}))}close(){if(this._closedPromiseResolve){let{resolvers:t}=this;for(;t.length>0;)t.shift().resolve(we);this._closedPromiseResolve(),this._closedPromiseResolve=void 0}}[Symbol.asyncIterator](){return this}toDOMStream(t){return wn.toDOMStream(this._closedPromiseResolve||this._error?this:this._values,t)}toNodeStream(t){return wn.toNodeStream(this._closedPromiseResolve||this._error?this:this._values,t)}throw(t){return J(this,void 0,void 0,function*(){return yield this.abort(t),we})}return(t){return J(this,void 0,void 0,function*(){return yield this.close(),we})}read(t){return J(this,void 0,void 0,function*(){return(yield this.next(t,"read")).value})}peek(t){return J(this,void 0,void 0,function*(){return(yield this.next(t,"peek")).value})}next(...t){return this._values.length>0?Promise.resolve({done:!1,value:this._values.shift()}):this._error?Promise.reject({done:!0,value:this._error.error}):this._closedPromiseResolve?new Promise((n,r)=>{this.resolvers.push({resolve:n,reject:r})}):Promise.resolve(we)}_ensureOpen(){if(this._closedPromiseResolve)return!0;throw new Error("AsyncQueue is closed")}};var mo=class extends i0{write(t){if((t=_t(t)).byteLength>0)return super.write(t)}toString(t=!1){return t?kh(this.toUint8Array(!0)):this.toUint8Array(!1).then(kh)}toUint8Array(t=!1){return t?Er(this._values)[0]:J(this,void 0,void 0,function*(){var n,r,i,o;let s=[],a=0;try{for(var c=!0,l=Ii(this),u;u=yield l.next(),n=u.done,!n;c=!0){o=u.value,c=!1;let f=o;s.push(f),a+=f.byteLength}}catch(f){r={error:f}}finally{try{!c&&!n&&(i=l.return)&&(yield i.call(l))}finally{if(r)throw r.error}}return Er(s,a)[0]})}},yo=class{constructor(t){t&&(this.source=new a2(wn.fromIterable(t)))}[Symbol.iterator](){return this}next(t){return this.source.next(t)}throw(t){return this.source.throw(t)}return(t){return this.source.return(t)}peek(t){return this.source.peek(t)}read(t){return this.source.read(t)}},ni=class e{constructor(t){t instanceof e?this.source=t.source:t instanceof mo?this.source=new us(wn.fromAsyncIterable(t)):Sg(t)?this.source=new us(wn.fromNodeStream(t)):Fh(t)?this.source=new us(wn.fromDOMStream(t)):vg(t)?this.source=new us(wn.fromDOMStream(t.body)):Mi(t)?this.source=new us(wn.fromIterable(t)):Tr(t)?this.source=new us(wn.fromAsyncIterable(t)):Wr(t)&&(this.source=new us(wn.fromAsyncIterable(t)))}[Symbol.asyncIterator](){return this}next(t){return this.source.next(t)}throw(t){return this.source.throw(t)}return(t){return this.source.return(t)}get closed(){return this.source.closed}cancel(t){return this.source.cancel(t)}peek(t){return this.source.peek(t)}read(t){return this.source.read(t)}},a2=class{constructor(t){this.source=t}cancel(t){this.return(t)}peek(t){return this.next(t,"peek").value}read(t){return this.next(t,"read").value}next(t,n="read"){return this.source.next({cmd:n,size:t})}throw(t){return Object.create(this.source.throw&&this.source.throw(t)||we)}return(t){return Object.create(this.source.return&&this.source.return(t)||we)}},us=class{constructor(t){this.source=t,this._closedPromise=new Promise(n=>this._closedPromiseResolve=n)}cancel(t){return J(this,void 0,void 0,function*(){yield this.return(t)})}get closed(){return this._closedPromise}read(t){return J(this,void 0,void 0,function*(){return(yield this.next(t,"read")).value})}peek(t){return J(this,void 0,void 0,function*(){return(yield this.next(t,"peek")).value})}next(t,n="read"){return J(this,void 0,void 0,function*(){return yield this.source.next({cmd:n,size:t})})}throw(t){return J(this,void 0,void 0,function*(){let n=this.source.throw&&(yield this.source.throw(t))||we;return this._closedPromiseResolve&&this._closedPromiseResolve(),this._closedPromiseResolve=void 0,Object.create(n)})}return(t){return J(this,void 0,void 0,function*(){let n=this.source.return&&(yield this.source.return(t))||we;return this._closedPromiseResolve&&this._closedPromiseResolve(),this._closedPromiseResolve=void 0,Object.create(n)})}};var pd=class extends yo{constructor(t,n){super(),this.position=0,this.buffer=_t(t),this.size=n===void 0?this.buffer.byteLength:n}readInt32(t){let{buffer:n,byteOffset:r}=this.readAt(t,4);return new DataView(n,r).getInt32(0,!0)}seek(t){return this.position=Math.min(t,this.size),t<this.size}read(t){let{buffer:n,size:r,position:i}=this;return n&&i<r?(typeof t!="number"&&(t=Number.POSITIVE_INFINITY),this.position=Math.min(r,i+Math.min(r-i,t)),n.subarray(i,this.position)):null}readAt(t,n){let r=this.buffer,i=Math.min(this.size,t+n);return r?r.subarray(t,i):new Uint8Array(n)}close(){this.buffer&&(this.buffer=null)}throw(t){return this.close(),{done:!0,value:t}}return(t){return this.close(),{done:!0,value:t}}},_a=class extends ni{constructor(t,n){super(),this.position=0,this._handle=t,typeof n=="number"?this.size=n:this._pending=J(this,void 0,void 0,function*(){this.size=(yield t.stat()).size,delete this._pending})}readInt32(t){return J(this,void 0,void 0,function*(){let{buffer:n,byteOffset:r}=yield this.readAt(t,4);return new DataView(n,r).getInt32(0,!0)})}seek(t){return J(this,void 0,void 0,function*(){return this._pending&&(yield this._pending),this.position=Math.min(t,this.size),t<this.size})}read(t){return J(this,void 0,void 0,function*(){this._pending&&(yield this._pending);let{_handle:n,size:r,position:i}=this;if(n&&i<r){typeof t!="number"&&(t=Number.POSITIVE_INFINITY);let o=i,s=0,a=0,c=Math.min(r,o+Math.min(r-o,t)),l=new Uint8Array(Math.max(0,(this.position=c)-o));for(;(o+=a)<c&&(s+=a)<l.byteLength;)({bytesRead:a}=yield n.read(l,s,l.byteLength-s,o));return l}return null})}readAt(t,n){return J(this,void 0,void 0,function*(){this._pending&&(yield this._pending);let{_handle:r,size:i}=this;if(r&&t+n<i){let o=Math.min(i,t+n),s=new Uint8Array(o-t);return(yield r.read(s,0,n,t)).buffer}return new Uint8Array(n)})}close(){return J(this,void 0,void 0,function*(){let t=this._handle;this._handle=null,t&&(yield t.close())})}throw(t){return J(this,void 0,void 0,function*(){return yield this.close(),{done:!0,value:t}})}return(t){return J(this,void 0,void 0,function*(){return yield this.close(),{done:!0,value:t}})}};var l2={};Mr(l2,{BaseInt64:()=>md,Int128:()=>yd,Int64:()=>fs,Uint64:()=>Oe});function du(e){return e<0&&(e=4294967295+e+1),`0x${e.toString(16)}`}var pu=8,c2=[1,10,100,1e3,1e4,1e5,1e6,1e7,1e8],md=class{constructor(t){this.buffer=t}high(){return this.buffer[1]}low(){return this.buffer[0]}_times(t){let n=new Uint32Array([this.buffer[1]>>>16,this.buffer[1]&65535,this.buffer[0]>>>16,this.buffer[0]&65535]),r=new Uint32Array([t.buffer[1]>>>16,t.buffer[1]&65535,t.buffer[0]>>>16,t.buffer[0]&65535]),i=n[3]*r[3];this.buffer[0]=i&65535;let o=i>>>16;return i=n[2]*r[3],o+=i,i=n[3]*r[2]>>>0,o+=i,this.buffer[0]+=o<<16,this.buffer[1]=o>>>0<i?65536:0,this.buffer[1]+=o>>>16,this.buffer[1]+=n[1]*r[3]+n[2]*r[2]+n[3]*r[1],this.buffer[1]+=n[0]*r[3]+n[1]*r[2]+n[2]*r[1]+n[3]*r[0]<<16,this}_plus(t){let n=this.buffer[0]+t.buffer[0]>>>0;this.buffer[1]+=t.buffer[1],n<this.buffer[0]>>>0&&++this.buffer[1],this.buffer[0]=n}lessThan(t){return this.buffer[1]<t.buffer[1]||this.buffer[1]===t.buffer[1]&&this.buffer[0]<t.buffer[0]}equals(t){return this.buffer[1]===t.buffer[1]&&this.buffer[0]==t.buffer[0]}greaterThan(t){return t.lessThan(this)}hex(){return`${du(this.buffer[1])} ${du(this.buffer[0])}`}},Oe=class e extends md{times(t){return this._times(t),this}plus(t){return this._plus(t),this}static from(t,n=new Uint32Array(2)){return e.fromString(typeof t=="string"?t:t.toString(),n)}static fromNumber(t,n=new Uint32Array(2)){return e.fromString(t.toString(),n)}static fromString(t,n=new Uint32Array(2)){let r=t.length,i=new e(n);for(let o=0;o<r;){let s=pu<r-o?pu:r-o,a=new e(new Uint32Array([Number.parseInt(t.slice(o,o+s),10),0])),c=new e(new Uint32Array([c2[s],0]));i.times(c),i.plus(a),o+=s}return i}static convertArray(t){let n=new Uint32Array(t.length*2);for(let r=-1,i=t.length;++r<i;)e.from(t[r],new Uint32Array(n.buffer,n.byteOffset+2*r*4,2));return n}static multiply(t,n){return new e(new Uint32Array(t.buffer)).times(n)}static add(t,n){return new e(new Uint32Array(t.buffer)).plus(n)}},fs=class e extends md{negate(){return this.buffer[0]=~this.buffer[0]+1,this.buffer[1]=~this.buffer[1],this.buffer[0]==0&&++this.buffer[1],this}times(t){return this._times(t),this}plus(t){return this._plus(t),this}lessThan(t){let n=this.buffer[1]<<0,r=t.buffer[1]<<0;return n<r||n===r&&this.buffer[0]<t.buffer[0]}static from(t,n=new Uint32Array(2)){return e.fromString(typeof t=="string"?t:t.toString(),n)}static fromNumber(t,n=new Uint32Array(2)){return e.fromString(t.toString(),n)}static fromString(t,n=new Uint32Array(2)){let r=t.startsWith("-"),i=t.length,o=new e(n);for(let s=r?1:0;s<i;){let a=pu<i-s?pu:i-s,c=new e(new Uint32Array([Number.parseInt(t.slice(s,s+a),10),0])),l=new e(new Uint32Array([c2[a],0]));o.times(l),o.plus(c),s+=a}return r?o.negate():o}static convertArray(t){let n=new Uint32Array(t.length*2);for(let r=-1,i=t.length;++r<i;)e.from(t[r],new Uint32Array(n.buffer,n.byteOffset+2*r*4,2));return n}static multiply(t,n){return new e(new Uint32Array(t.buffer)).times(n)}static add(t,n){return new e(new Uint32Array(t.buffer)).plus(n)}},yd=class e{constructor(t){this.buffer=t}high(){return new fs(new Uint32Array(this.buffer.buffer,this.buffer.byteOffset+8,2))}low(){return new fs(new Uint32Array(this.buffer.buffer,this.buffer.byteOffset,2))}negate(){return this.buffer[0]=~this.buffer[0]+1,this.buffer[1]=~this.buffer[1],this.buffer[2]=~this.buffer[2],this.buffer[3]=~this.buffer[3],this.buffer[0]==0&&++this.buffer[1],this.buffer[1]==0&&++this.buffer[2],this.buffer[2]==0&&++this.buffer[3],this}times(t){let n=new Oe(new Uint32Array([this.buffer[3],0])),r=new Oe(new Uint32Array([this.buffer[2],0])),i=new Oe(new Uint32Array([this.buffer[1],0])),o=new Oe(new Uint32Array([this.buffer[0],0])),s=new Oe(new Uint32Array([t.buffer[3],0])),a=new Oe(new Uint32Array([t.buffer[2],0])),c=new Oe(new Uint32Array([t.buffer[1],0])),l=new Oe(new Uint32Array([t.buffer[0],0])),u=Oe.multiply(o,l);this.buffer[0]=u.low();let f=new Oe(new Uint32Array([u.high(),0]));return u=Oe.multiply(i,l),f.plus(u),u=Oe.multiply(o,c),f.plus(u),this.buffer[1]=f.low(),this.buffer[3]=f.lessThan(u)?1:0,this.buffer[2]=f.high(),new Oe(new Uint32Array(this.buffer.buffer,this.buffer.byteOffset+8,2)).plus(Oe.multiply(r,l)).plus(Oe.multiply(i,c)).plus(Oe.multiply(o,a)),this.buffer[3]+=Oe.multiply(n,l).plus(Oe.multiply(r,c)).plus(Oe.multiply(i,a)).plus(Oe.multiply(o,s)).low(),this}plus(t){let n=new Uint32Array(4);return n[3]=this.buffer[3]+t.buffer[3]>>>0,n[2]=this.buffer[2]+t.buffer[2]>>>0,n[1]=this.buffer[1]+t.buffer[1]>>>0,n[0]=this.buffer[0]+t.buffer[0]>>>0,n[0]<this.buffer[0]>>>0&&++n[1],n[1]<this.buffer[1]>>>0&&++n[2],n[2]<this.buffer[2]>>>0&&++n[3],this.buffer[3]=n[3],this.buffer[2]=n[2],this.buffer[1]=n[1],this.buffer[0]=n[0],this}hex(){return`${du(this.buffer[3])} ${du(this.buffer[2])} ${du(this.buffer[1])} ${du(this.buffer[0])}`}static multiply(t,n){return new e(new Uint32Array(t.buffer)).times(n)}static add(t,n){return new e(new Uint32Array(t.buffer)).plus(n)}static from(t,n=new Uint32Array(4)){return e.fromString(typeof t=="string"?t:t.toString(),n)}static fromNumber(t,n=new Uint32Array(4)){return e.fromString(t.toString(),n)}static fromString(t,n=new Uint32Array(4)){let r=t.startsWith("-"),i=t.length,o=new e(n);for(let s=r?1:0;s<i;){let a=pu<i-s?pu:i-s,c=new e(new Uint32Array([Number.parseInt(t.slice(s,s+a),10),0,0,0])),l=new e(new Uint32Array([c2[a],0,0,0]));o.times(l),o.plus(c),s+=a}return r?o.negate():o}static convertArray(t){let n=new Uint32Array(t.length*4);for(let r=-1,i=t.length;++r<i;)e.from(t[r],new Uint32Array(n.buffer,n.byteOffset+4*4*r,4));return n}};var gd=class extends mt{constructor(t,n,r,i,o=ce.V5){super(),this.nodesIndex=-1,this.buffersIndex=-1,this.bytes=t,this.nodes=n,this.buffers=r,this.dictionaries=i,this.metadataVersion=o}visit(t){return super.visit(t instanceof Ut?t.type:t)}visitNull(t,{length:n}=this.nextFieldNode()){return Nt({type:t,length:n})}visitBool(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitInt(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitFloat(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitUtf8(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),data:this.readData(t)})}visitLargeUtf8(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),data:this.readData(t)})}visitBinary(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),data:this.readData(t)})}visitLargeBinary(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),data:this.readData(t)})}visitFixedSizeBinary(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitDate(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitTimestamp(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitTime(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitDecimal(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitList(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),child:this.visit(t.children[0])})}visitStruct(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),children:this.visitMany(t.children)})}visitUnion(t,{length:n,nullCount:r}=this.nextFieldNode()){return this.metadataVersion<ce.V5&&this.readNullBitmap(t,r),t.mode===ge.Sparse?this.visitSparseUnion(t,{length:n,nullCount:r}):this.visitDenseUnion(t,{length:n,nullCount:r})}visitDenseUnion(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,typeIds:this.readTypeIds(t),valueOffsets:this.readOffsets(t),children:this.visitMany(t.children)})}visitSparseUnion(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,typeIds:this.readTypeIds(t),children:this.visitMany(t.children)})}visitDictionary(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t.indices),dictionary:this.readDictionary(t)})}visitInterval(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitDuration(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),data:this.readData(t)})}visitFixedSizeList(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),child:this.visit(t.children[0])})}visitMap(t,{length:n,nullCount:r}=this.nextFieldNode()){return Nt({type:t,length:n,nullCount:r,nullBitmap:this.readNullBitmap(t,r),valueOffsets:this.readOffsets(t),child:this.visit(t.children[0])})}nextFieldNode(){return this.nodes[++this.nodesIndex]}nextBufferRange(){return this.buffers[++this.buffersIndex]}readNullBitmap(t,n,r=this.nextBufferRange()){return n>0&&this.readData(t,r)||new Uint8Array(0)}readOffsets(t,n){return this.readData(t,n)}readTypeIds(t,n){return this.readData(t,n)}readData(t,{length:n,offset:r}=this.nextBufferRange()){return this.bytes.subarray(r,r+n)}readDictionary(t){return this.dictionaries.get(t.id)}},o0=class extends gd{constructor(t,n,r,i,o){super(new Uint8Array(0),n,r,i,o),this.sources=t}readNullBitmap(t,n,{offset:r}=this.nextBufferRange()){return n<=0?new Uint8Array(0):Mc(this.sources[r])}readOffsets(t,{offset:n}=this.nextBufferRange()){return Pt(Uint8Array,Pt(t.OffsetArrayType,this.sources[n]))}readTypeIds(t,{offset:n}=this.nextBufferRange()){return Pt(Uint8Array,Pt(t.ArrayType,this.sources[n]))}readData(t,{offset:n}=this.nextBufferRange()){let{sources:r}=this;return H.isTimestamp(t)?Pt(Uint8Array,fs.convertArray(r[n])):(H.isInt(t)||H.isTime(t))&&t.bitWidth===64||H.isDuration(t)?Pt(Uint8Array,fs.convertArray(r[n])):H.isDate(t)&&t.unit===Ve.MILLISECOND?Pt(Uint8Array,fs.convertArray(r[n])):H.isDecimal(t)?Pt(Uint8Array,yd.convertArray(r[n])):H.isBinary(t)||H.isLargeBinary(t)||H.isFixedSizeBinary(t)?sj(r[n]):H.isBool(t)?Mc(r[n]):H.isUtf8(t)||H.isLargeUtf8(t)?Ji(r[n].join("")):Pt(Uint8Array,Pt(t.ArrayType,r[n].map(i=>+i)))}};function sj(e){let t=e.join(""),n=new Uint8Array(t.length/2);for(let r=0;r<t.length;r+=2)n[r>>1]=Number.parseInt(t.slice(r,r+2),16);return n}var mu=class extends pr{constructor(t){super(t),this._values=new ki(Uint8Array)}get byteLength(){let t=this._pendingLength+this.length*4;return this._offsets&&(t+=this._offsets.byteLength),this._values&&(t+=this._values.byteLength),this._nulls&&(t+=this._nulls.byteLength),t}setValue(t,n){return super.setValue(t,_t(n))}_flushPending(t,n){let r=this._offsets,i=this._values.reserve(n).buffer,o=0;for(let[s,a]of t)if(a===void 0)r.set(s,0);else{let c=a.length;i.set(a,o),r.set(s,c),o+=c}}};var yu=class extends pr{constructor(t){super(t),this._values=new ki(Uint8Array)}get byteLength(){let t=this._pendingLength+this.length*4;return this._offsets&&(t+=this._offsets.byteLength),this._values&&(t+=this._values.byteLength),this._nulls&&(t+=this._nulls.byteLength),t}setValue(t,n){return super.setValue(t,_t(n))}_flushPending(t,n){let r=this._offsets,i=this._values.reserve(n).buffer,o=0;for(let[s,a]of t)if(a===void 0)r.set(s,BigInt(0));else{let c=a.length;i.set(a,o),r.set(s,BigInt(c)),o+=c}}};var s0=class extends ve{constructor(t){super(t),this._values=new fu}setValue(t,n){this._values.set(t,+n)}};var Nc=class extends Xe{};Nc.prototype._setValue=q_;var xd=class extends Nc{};xd.prototype._setValue=Bg;var bd=class extends Nc{};bd.prototype._setValue=Lg;var wd=class extends Xe{};wd.prototype._setValue=Y_;var a0=class extends ve{constructor({type:t,nullValues:n,dictionaryHashFunction:r}){super({type:new dr(t.dictionary,t.indices,t.id,t.isOrdered)}),this._nulls=null,this._dictionaryOffset=0,this._keysToIndices=Object.create(null),this.indices=Dc({type:this.type.indices,nullValues:n}),this.dictionary=Dc({type:this.type.dictionary,nullValues:null}),typeof r=="function"&&(this.valueToKey=r)}get values(){return this.indices.values}get nullCount(){return this.indices.nullCount}get nullBitmap(){return this.indices.nullBitmap}get byteLength(){return this.indices.byteLength+this.dictionary.byteLength}get reservedLength(){return this.indices.reservedLength+this.dictionary.reservedLength}get reservedByteLength(){return this.indices.reservedByteLength+this.dictionary.reservedByteLength}isValid(t){return this.indices.isValid(t)}setValid(t,n){let r=this.indices;return n=r.setValid(t,n),this.length=r.length,n}setValue(t,n){let r=this._keysToIndices,i=this.valueToKey(n),o=r[i];return o===void 0&&(r[i]=o=this._dictionaryOffset+this.dictionary.append(n).length-1),this.indices.setValue(t,o)}flush(){let t=this.type,n=this._dictionary,r=this.dictionary.toVector(),i=this.indices.flush().clone(t);return i.dictionary=n?n.concat(r):r,this.finished||(this._dictionaryOffset+=r.length),this._dictionary=i.dictionary,this.clear(),i}finish(){return this.indices.finish(),this.dictionary.finish(),this._dictionaryOffset=0,this._keysToIndices=Object.create(null),super.finish()}clear(){return this.indices.clear(),this.dictionary.clear(),super.clear()}valueToKey(t){return typeof t=="string"?t:`${t}`}};var vd=class extends Xe{};vd.prototype._setValue=z_;var c0=class extends ve{setValue(t,n){let[r]=this.children,i=t*this.stride;for(let o=-1,s=n.length;++o<s;)r.set(i+o,n[o])}addChild(t,n="0"){if(this.numChildren>0)throw new Error("FixedSizeListBuilder can only have one child.");let r=this.children.push(t);return this.type=new Kr(this.type.listSize,new Ut(n,t.type,!0)),r}};var Oc=class extends Xe{setValue(t,n){this._values.set(t,n)}},l0=class extends Oc{setValue(t,n){super.setValue(t,cd(n))}},u0=class extends Oc{},f0=class extends Oc{};var Bc=class extends Xe{};Bc.prototype._setValue=X_;var _d=class extends Bc{};_d.prototype._setValue=qg;var Sd=class extends Bc{};Sd.prototype._setValue=jg;var hs=class extends Xe{};hs.prototype._setValue=G_;var Id=class extends hs{};Id.prototype._setValue=Vg;var Md=class extends hs{};Md.prototype._setValue=Yg;var Ad=class extends hs{};Ad.prototype._setValue=Xg;var Td=class extends hs{};Td.prototype._setValue=Gg;var ri=class extends Xe{setValue(t,n){this._values.set(t,n)}},h0=class extends ri{},d0=class extends ri{},p0=class extends ri{},m0=class extends ri{},y0=class extends ri{},g0=class extends ri{},x0=class extends ri{},b0=class extends ri{};var w0=class extends pr{constructor(t){super(t),this._offsets=new hu(t.type)}addChild(t,n="0"){if(this.numChildren>0)throw new Error("ListBuilder can only have one child.");return this.children[this.numChildren]=t,this.type=new Jr(new Ut(n,t.type,!0)),this.numChildren-1}_flushPending(t){let n=this._offsets,[r]=this.children;for(let[i,o]of t)if(typeof o>"u")n.set(i,0);else{let s=o,a=s.length,c=n.set(i,a).buffer[i];for(let l=-1;++l<a;)r.set(c+l,s[l])}}};var v0=class extends pr{set(t,n){return super.set(t,n)}setValue(t,n){let r=n instanceof Map?n:new Map(Object.entries(n)),i=this._pending||(this._pending=new Map),o=i.get(t);o&&(this._pendingLength-=o.size),this._pendingLength+=r.size,i.set(t,r)}addChild(t,n=`${this.numChildren}`){if(this.numChildren>0)throw new Error("ListBuilder can only have one child.");return this.children[this.numChildren]=t,this.type=new ti(new Ut(n,t.type,!0),this.type.keysSorted),this.numChildren-1}_flushPending(t){let n=this._offsets,[r]=this.children;for(let[i,o]of t)if(o===void 0)n.set(i,0);else{let{[i]:s,[i+1]:a}=n.set(i,o.size).buffer;for(let c of o.entries())if(r.set(s,c),++s>=a)break}}};var _0=class extends ve{setValue(t,n){}setValid(t,n){return this.length=Math.max(t+1,this.length),n}};var S0=class extends ve{setValue(t,n){let{children:r,type:i}=this;switch(Array.isArray(n)||n.constructor){case!0:return i.children.forEach((o,s)=>r[s].set(t,n[s]));case Map:return i.children.forEach((o,s)=>r[s].set(t,n.get(o.name)));default:return i.children.forEach((o,s)=>r[s].set(t,n[o.name]))}}setValid(t,n){return super.setValid(t,n)||this.children.forEach(r=>r.setValid(t,n)),n}addChild(t,n=`${this.numChildren}`){let r=this.children.push(t);return this.type=new xe([...this.type.children,new Ut(n,t.type,!0)]),r}};var ds=class extends Xe{};ds.prototype._setValue=j_;var Ed=class extends ds{};Ed.prototype._setValue=Cg;var Nd=class extends ds{};Nd.prototype._setValue=kg;var Dd=class extends ds{};Dd.prototype._setValue=Fg;var Od=class extends ds{};Od.prototype._setValue=Rg;var ps=class extends Xe{};ps.prototype._setValue=V_;var Bd=class extends ps{};Bd.prototype._setValue=$g;var Ld=class extends ps{};Ld.prototype._setValue=Pg;var Cd=class extends ps{};Cd.prototype._setValue=Ug;var kd=class extends ps{};kd.prototype._setValue=zg;var gu=class extends ve{constructor(t){super(t),this._typeIds=new as(Int8Array,0,1),typeof t.valueToChildTypeId=="function"&&(this._valueToChildTypeId=t.valueToChildTypeId)}get typeIdToChildIndex(){return this.type.typeIdToChildIndex}append(t,n){return this.set(this.length,t,n)}set(t,n,r){return r===void 0&&(r=this._valueToChildTypeId(this,n,t)),this.setValue(t,n,r),this}setValue(t,n,r){this._typeIds.set(t,r);let i=this.type.typeIdToChildIndex[r],o=this.children[i];o?.set(t,n)}addChild(t,n=`${this.children.length}`){let r=this.children.push(t),{type:{children:i,mode:o,typeIds:s}}=this,a=[...i,new Ut(n,t.type)];return this.type=new Qr(o,[...s,r],a),r}_valueToChildTypeId(t,n,r){throw new Error("Cannot map UnionBuilder value to child typeId. Pass the `childTypeId` as the second argument to unionBuilder.append(), or supply a `valueToChildTypeId` function as part of the UnionBuilder constructor options.")}},I0=class extends gu{},M0=class extends gu{constructor(t){super(t),this._offsets=new as(Int32Array)}setValue(t,n,r){let i=this._typeIds.set(t,r).buffer[t],o=this.getChildAt(this.type.typeIdToChildIndex[i]),s=this._offsets.set(t,o.length).buffer[t];o?.set(s,n)}};var Fd=class extends pr{constructor(t){super(t),this._values=new ki(Uint8Array)}get byteLength(){let t=this._pendingLength+this.length*4;return this._offsets&&(t+=this._offsets.byteLength),this._values&&(t+=this._values.byteLength),this._nulls&&(t+=this._nulls.byteLength),t}setValue(t,n){return super.setValue(t,Ji(n))}_flushPending(t,n){}};Fd.prototype._flushPending=mu.prototype._flushPending;var Rd=class extends pr{constructor(t){super(t),this._values=new ki(Uint8Array)}get byteLength(){let t=this._pendingLength+this.length*4;return this._offsets&&(t+=this._offsets.byteLength),this._values&&(t+=this._values.byteLength),this._nulls&&(t+=this._nulls.byteLength),t}setValue(t,n){return super.setValue(t,Ji(n))}_flushPending(t,n){}};Rd.prototype._flushPending=yu.prototype._flushPending;var u2=class extends mt{visitNull(){return _0}visitBool(){return s0}visitInt(){return ri}visitInt8(){return h0}visitInt16(){return d0}visitInt32(){return p0}visitInt64(){return m0}visitUint8(){return y0}visitUint16(){return g0}visitUint32(){return x0}visitUint64(){return b0}visitFloat(){return Oc}visitFloat16(){return l0}visitFloat32(){return u0}visitFloat64(){return f0}visitUtf8(){return Fd}visitLargeUtf8(){return Rd}visitBinary(){return mu}visitLargeBinary(){return yu}visitFixedSizeBinary(){return vd}visitDate(){return Nc}visitDateDay(){return xd}visitDateMillisecond(){return bd}visitTimestamp(){return ds}visitTimestampSecond(){return Ed}visitTimestampMillisecond(){return Nd}visitTimestampMicrosecond(){return Dd}visitTimestampNanosecond(){return Od}visitTime(){return ps}visitTimeSecond(){return Bd}visitTimeMillisecond(){return Ld}visitTimeMicrosecond(){return Cd}visitTimeNanosecond(){return kd}visitDecimal(){return wd}visitList(){return w0}visitStruct(){return S0}visitUnion(){return gu}visitDenseUnion(){return M0}visitSparseUnion(){return I0}visitDictionary(){return a0}visitInterval(){return Bc}visitIntervalDayTime(){return _d}visitIntervalYearMonth(){return Sd}visitDuration(){return hs}visitDurationSecond(){return Id}visitDurationMillisecond(){return Md}visitDurationMicrosecond(){return Ad}visitDurationNanosecond(){return Td}visitFixedSizeList(){return c0}visitMap(){return v0}},oB=new u2;var bt=class extends mt{compareSchemas(t,n){return t===n||n instanceof t.constructor&&this.compareManyFields(t.fields,n.fields)}compareManyFields(t,n){return t===n||Array.isArray(t)&&Array.isArray(n)&&t.length===n.length&&t.every((r,i)=>this.compareFields(r,n[i]))}compareFields(t,n){return t===n||n instanceof t.constructor&&t.name===n.name&&t.nullable===n.nullable&&this.visit(t.type,n.type)}};function Wn(e,t){return t instanceof e.constructor}function Lc(e,t){return e===t||Wn(e,t)}function ms(e,t){return e===t||Wn(e,t)&&e.bitWidth===t.bitWidth&&e.isSigned===t.isSigned}function A0(e,t){return e===t||Wn(e,t)&&e.precision===t.precision}function aj(e,t){return e===t||Wn(e,t)&&e.byteWidth===t.byteWidth}function f2(e,t){return e===t||Wn(e,t)&&e.unit===t.unit}function $d(e,t){return e===t||Wn(e,t)&&e.unit===t.unit&&e.timezone===t.timezone}function Pd(e,t){return e===t||Wn(e,t)&&e.unit===t.unit&&e.bitWidth===t.bitWidth}function cj(e,t){return e===t||Wn(e,t)&&e.children.length===t.children.length&&go.compareManyFields(e.children,t.children)}function lj(e,t){return e===t||Wn(e,t)&&e.children.length===t.children.length&&go.compareManyFields(e.children,t.children)}function h2(e,t){return e===t||Wn(e,t)&&e.mode===t.mode&&e.typeIds.every((n,r)=>n===t.typeIds[r])&&go.compareManyFields(e.children,t.children)}function uj(e,t){return e===t||Wn(e,t)&&e.id===t.id&&e.isOrdered===t.isOrdered&&go.visit(e.indices,t.indices)&&go.visit(e.dictionary,t.dictionary)}function d2(e,t){return e===t||Wn(e,t)&&e.unit===t.unit}function Ud(e,t){return e===t||Wn(e,t)&&e.unit===t.unit}function fj(e,t){return e===t||Wn(e,t)&&e.listSize===t.listSize&&e.children.length===t.children.length&&go.compareManyFields(e.children,t.children)}function hj(e,t){return e===t||Wn(e,t)&&e.keysSorted===t.keysSorted&&e.children.length===t.children.length&&go.compareManyFields(e.children,t.children)}bt.prototype.visitNull=Lc;bt.prototype.visitBool=Lc;bt.prototype.visitInt=ms;bt.prototype.visitInt8=ms;bt.prototype.visitInt16=ms;bt.prototype.visitInt32=ms;bt.prototype.visitInt64=ms;bt.prototype.visitUint8=ms;bt.prototype.visitUint16=ms;bt.prototype.visitUint32=ms;bt.prototype.visitUint64=ms;bt.prototype.visitFloat=A0;bt.prototype.visitFloat16=A0;bt.prototype.visitFloat32=A0;bt.prototype.visitFloat64=A0;bt.prototype.visitUtf8=Lc;bt.prototype.visitLargeUtf8=Lc;bt.prototype.visitBinary=Lc;bt.prototype.visitLargeBinary=Lc;bt.prototype.visitFixedSizeBinary=aj;bt.prototype.visitDate=f2;bt.prototype.visitDateDay=f2;bt.prototype.visitDateMillisecond=f2;bt.prototype.visitTimestamp=$d;bt.prototype.visitTimestampSecond=$d;bt.prototype.visitTimestampMillisecond=$d;bt.prototype.visitTimestampMicrosecond=$d;bt.prototype.visitTimestampNanosecond=$d;bt.prototype.visitTime=Pd;bt.prototype.visitTimeSecond=Pd;bt.prototype.visitTimeMillisecond=Pd;bt.prototype.visitTimeMicrosecond=Pd;bt.prototype.visitTimeNanosecond=Pd;bt.prototype.visitDecimal=Lc;bt.prototype.visitList=cj;bt.prototype.visitStruct=lj;bt.prototype.visitUnion=h2;bt.prototype.visitDenseUnion=h2;bt.prototype.visitSparseUnion=h2;bt.prototype.visitDictionary=uj;bt.prototype.visitInterval=d2;bt.prototype.visitIntervalDayTime=d2;bt.prototype.visitIntervalYearMonth=d2;bt.prototype.visitDuration=Ud;bt.prototype.visitDurationSecond=Ud;bt.prototype.visitDurationMillisecond=Ud;bt.prototype.visitDurationMicrosecond=Ud;bt.prototype.visitDurationNanosecond=Ud;bt.prototype.visitFixedSizeList=fj;bt.prototype.visitMap=hj;var go=new bt;function Cc(e,t){return go.compareSchemas(e,t)}function sB(e,t){return go.compareFields(e,t)}function aB(e,t){return go.visit(e,t)}function Dc(e){let t=e.type,n=new(oB.getVisitFn(t)())(e);if(t.children&&t.children.length>0){let r=e.children||[],i={nullValues:e.nullValues},o=Array.isArray(r)?(s,a)=>r[a]||i:({name:s})=>r[s]||i;for(let[s,a]of t.children.entries()){let{type:c}=a,l=o(a,s);n.children.push(Dc(Object.assign(Object.assign({},l),{type:c})))}}return n}function T0(e,t){return dj(e,t.map(n=>n.data.concat()))}function dj(e,t){let n=[...e.fields],r=[],i={numBatches:t.reduce((f,h)=>Math.max(f,h.length),0)},o=0,s=0,a=-1,c=t.length,l,u=[];for(;i.numBatches-- >0;){for(s=Number.POSITIVE_INFINITY,a=-1;++a<c;)u[a]=l=t[a].shift(),s=Math.min(s,l?l.length:s);Number.isFinite(s)&&(u=pj(n,s,u,t,i),s>0&&(r[o++]=Nt({type:new xe(n),length:s,nullCount:0,children:u.slice()})))}return[e=e.assign(n),r.map(f=>new Fe(e,f))]}function pj(e,t,n,r,i){var o;let s=(t+63&-64)>>3;for(let a=-1,c=r.length;++a<c;){let l=n[a],u=l?.length;if(u>=t)u===t?n[a]=l:(n[a]=l.slice(0,t),i.numBatches=Math.max(i.numBatches,r[a].unshift(l.slice(t,u-t))));else{let f=e[a];e[a]=f.clone({nullable:!0}),n[a]=(o=l?._changeLengthAndBackfillNullBitmap(t))!==null&&o!==void 0?o:Nt({type:f.type,length:t,nullCount:t,nullBitmap:new Uint8Array(s)})}}return n}var cB,mr=class e{constructor(...t){var n,r;if(t.length===0)return this.batches=[],this.schema=new oe([]),this._offsets=[0],this;let i,o;t[0]instanceof oe&&(i=t.shift()),t.at(-1)instanceof Uint32Array&&(o=t.pop());let s=c=>{if(c){if(c instanceof Fe)return[c];if(c instanceof e)return c.batches;if(c instanceof te){if(c.type instanceof xe)return[new Fe(new oe(c.type.children),c)]}else{if(Array.isArray(c))return c.flatMap(l=>s(l));if(typeof c[Symbol.iterator]=="function")return[...c].flatMap(l=>s(l));if(typeof c=="object"){let l=Object.keys(c),u=l.map(d=>new Xt([c[d]])),f=i??new oe(l.map((d,p)=>new Ut(String(d),u[p].type,u[p].nullable))),[,h]=T0(f,u);return h.length===0?[new Fe(c)]:h}}}return[]},a=t.flatMap(c=>s(c));if(i=(r=i??((n=a[0])===null||n===void 0?void 0:n.schema))!==null&&r!==void 0?r:new oe([]),!(i instanceof oe))throw new TypeError("Table constructor expects a [Schema, RecordBatch[]] pair.");for(let c of a){if(!(c instanceof Fe))throw new TypeError("Table constructor expects a [Schema, RecordBatch[]] pair.");if(!Cc(i,c.schema))throw new TypeError("Table and inner RecordBatch schemas must be equivalent.")}this.schema=i,this.batches=a,this._offsets=o??Qg(this.data)}get data(){return this.batches.map(({data:t})=>t)}get numCols(){return this.schema.fields.length}get numRows(){return this.data.reduce((t,n)=>t+n.length,0)}get nullCount(){return this._nullCount===-1&&(this._nullCount=Jg(this.data)),this._nullCount}isValid(t){return!1}get(t){return null}set(t,n){}indexOf(t,n){return-1}[Symbol.iterator](){return this.batches.length>0?uu.visit(new Xt(this.data)):new Array(0)[Symbol.iterator]()}toArray(){return[...this]}toString(){return`[
|
|
8
8
|
${this.toArray().join(`,
|
|
9
9
|
`)}
|
|
10
|
-
]`}concat(...t){let n=this.schema,r=this.data.concat(t.flatMap(({data:i})=>i));return new e(n,r.map(i=>new ke(n,i)))}slice(t,n){let r=this.schema;[t,n]=th({length:this.numRows},t,n);let i=Jg(this.data,this._offsets,t,n);return new e(r,i.map(o=>new ke(r,o)))}getChild(t){return this.getChildAt(this.schema.fields.findIndex(n=>n.name===t))}getChildAt(t){if(t>-1&&t<this.schema.fields.length){let n=this.data.map(r=>r.children[t]);if(n.length===0){let{type:r}=this.schema.fields[t],i=Nt({type:r,length:0,nullCount:0});n.push(i._changeLengthAndBackfillNullBitmap(this.numRows))}return new Xt(n)}return null}setChild(t,n){var r;return this.setChildAt((r=this.schema.fields)===null||r===void 0?void 0:r.findIndex(i=>i.name===t),n)}setChildAt(t,n){let r=this.schema,i=[...this.batches];if(t>-1&&t<this.numCols){n||(n=new Xt([Nt({type:new Xn,length:this.numRows})]));let o=r.fields.slice(),s=o[t].clone({type:n.type}),a=this.schema.fields.map((c,l)=>this.getChildAt(l));[o[t],a[t]]=[s,n],[r,i]=M0(r,a)}return new e(r,i)}select(t){let n=this.schema.fields.reduce((r,i,o)=>r.set(i.name,o),new Map);return this.selectAt(t.map(r=>n.get(r)).filter(r=>r>-1))}selectAt(t){let n=this.schema.selectAt(t),r=this.batches.map(i=>i.selectAt(t));return new e(n,r)}assign(t){let n=this.schema.fields,[r,i]=t.schema.fields.reduce((a,c,l)=>{let[u,f]=a,d=n.findIndex(h=>h.name===c.name);return~d?f[d]=l:u.push(l),a},[[],[]]),o=this.schema.assign(t.schema),s=[...n.map((a,c)=>[c,i[c]]).map(([a,c])=>c===void 0?this.getChildAt(a):t.getChildAt(c)),...r.map(a=>t.getChildAt(a))].filter(Boolean);return new e(...M0(o,s))}};QO=Symbol.toStringTag;pr[QO]=(e=>(e.schema=null,e.batches=[],e._offsets=new Uint32Array([0]),e._nullCount=-1,e[Symbol.isConcatSpreadable]=!0,e.isValid=su(rh),e.get=su(Ye.getVisitFn(B.Struct)),e.set=Qg(wn.getVisitFn(B.Struct)),e.indexOf=Kg(Mc.getVisitFn(B.Struct)),"Table"))(pr.prototype);var tB,ke=class e{constructor(...t){switch(t.length){case 2:{if([this.schema]=t,!(this.schema instanceof oe))throw new TypeError("RecordBatch constructor expects a [Schema, Data] pair.");if([,this.data=Nt({nullCount:0,type:new be(this.schema.fields),children:this.schema.fields.map(n=>Nt({type:n.type,nullCount:0}))})]=t,!(this.data instanceof te))throw new TypeError("RecordBatch constructor expects a [Schema, Data] pair.");[this.schema,this.data]=KO(this.schema,this.data.children);break}case 1:{let[n]=t,{fields:r,children:i,length:o}=Object.keys(n).reduce((c,l,u)=>(c.children[u]=n[l],c.length=Math.max(c.length,n[l].length),c.fields[u]=Ut.new({name:l,type:n[l].type,nullable:!0}),c),{length:0,fields:new Array,children:new Array}),s=new oe(r),a=Nt({type:new be(r),length:o,children:i,nullCount:0});[this.schema,this.data]=KO(s,a.children,o);break}default:throw new TypeError("RecordBatch constructor expects an Object mapping names to child Data, or a [Schema, Data] pair.")}}get dictionaries(){return this._dictionaries||(this._dictionaries=eB(this.schema.fields,this.data.children))}get numCols(){return this.schema.fields.length}get numRows(){return this.data.length}get nullCount(){return this.data.nullCount}isValid(t){return this.data.getValid(t)}get(t){return Ye.visit(this.data,t)}set(t,n){return wn.visit(this.data,t,n)}indexOf(t,n){return Mc.visit(this.data,t,n)}[Symbol.iterator](){return au.visit(new Xt([this.data]))}toArray(){return[...this]}concat(...t){return new pr(this.schema,[this,...t])}slice(t,n){let[r]=new Xt([this.data]).slice(t,n).data;return new e(this.schema,r)}getChild(t){var n;return this.getChildAt((n=this.schema.fields)===null||n===void 0?void 0:n.findIndex(r=>r.name===t))}getChildAt(t){return t>-1&&t<this.schema.fields.length?new Xt([this.data.children[t]]):null}setChild(t,n){var r;return this.setChildAt((r=this.schema.fields)===null||r===void 0?void 0:r.findIndex(i=>i.name===t),n)}setChildAt(t,n){let r=this.schema,i=this.data;if(t>-1&&t<this.numCols){n||(n=new Xt([Nt({type:new Xn,length:this.numRows})]));let o=r.fields.slice(),s=i.children.slice(),a=o[t].clone({type:n.type});[o[t],s[t]]=[a,n.data[0]],r=new oe(o,new Map(this.schema.metadata)),i=Nt({type:new be(o),children:s})}return new e(r,i)}select(t){let n=this.schema.select(t),r=new be(n.fields),i=[];for(let o of t){let s=this.schema.fields.findIndex(a=>a.name===o);~s&&(i[s]=this.data.children[s])}return new e(n,Nt({type:r,length:this.numRows,children:i}))}selectAt(t){let n=this.schema.selectAt(t),r=t.map(o=>this.data.children[o]).filter(Boolean),i=Nt({type:new be(n.fields),length:this.numRows,children:r});return new e(n,i)}};tB=Symbol.toStringTag;ke[tB]=(e=>(e._nullCount=-1,e[Symbol.isConcatSpreadable]=!0,"RecordBatch"))(ke.prototype);function KO(e,t,n=t.reduce((r,i)=>Math.max(r,i.length),0)){var r;let i=[...e.fields],o=[...t],s=(n+63&-64)>>3;for(let[a,c]of e.fields.entries()){let l=t[a];(!l||l.length!==n)&&(i[a]=c.clone({nullable:!0}),o[a]=(r=l?._changeLengthAndBackfillNullBitmap(n))!==null&&r!==void 0?r:Nt({type:c.type,length:n,nullCount:n,nullBitmap:new Uint8Array(s)}))}return[e.assign(i),Nt({type:new be(i),length:n,children:o})]}function eB(e,t,n=new Map){var r,i;if(((r=e?.length)!==null&&r!==void 0?r:0)>0&&e?.length===t?.length)for(let o=-1,s=e.length;++o<s;){let{type:a}=e[o],c=t[o];for(let l of[c,...((i=c?.dictionary)===null||i===void 0?void 0:i.data)||[]])eB(a.children,l?.children,n);if(st.isDictionary(a)){let{id:l}=a;if(!n.has(l))c?.dictionary&&n.set(l,c.dictionary);else if(n.get(l)!==c.dictionary)throw new Error("Cannot create Schema containing two different dictionaries with the same Id")}}return n}var Cc=class extends ke{constructor(t){let n=t.fields.map(i=>Nt({type:i.type})),r=Nt({type:new be(t.fields),nullCount:0,children:n});super(t,r)}};var ki=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsMessage(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsMessage(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}version(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ce.V1}headerType(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.readUint8(this.bb_pos+t):qt.NONE}header(t){let n=this.bb.__offset(this.bb_pos,8);return n?this.bb.__union(t,this.bb_pos+n):null}bodyLength(){let t=this.bb.__offset(this.bb_pos,10);return t?this.bb.readInt64(this.bb_pos+t):BigInt("0")}customMetadata(t,n){let r=this.bb.__offset(this.bb_pos,12);return r?(n||new rn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}customMetadataLength(){let t=this.bb.__offset(this.bb_pos,12);return t?this.bb.__vector_len(this.bb_pos+t):0}static startMessage(t){t.startObject(5)}static addVersion(t,n){t.addFieldInt16(0,n,ce.V1)}static addHeaderType(t,n){t.addFieldInt8(1,n,qt.NONE)}static addHeader(t,n){t.addFieldOffset(2,n,0)}static addBodyLength(t,n){t.addFieldInt64(3,n,BigInt("0"))}static addCustomMetadata(t,n){t.addFieldOffset(4,n,0)}static createCustomMetadataVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startCustomMetadataVector(t,n){t.startVector(4,n,4)}static endMessage(t){return t.endObject()}static finishMessageBuffer(t,n){t.finish(n)}static finishSizePrefixedMessageBuffer(t,n){t.finish(n,void 0,!0)}static createMessage(t,n,r,i,o,s){return e.startMessage(t),e.addVersion(t,n),e.addHeaderType(t,r),e.addHeader(t,i),e.addBodyLength(t,o),e.addCustomMetadata(t,s),e.endMessage(t)}};var d2=class extends mt{visit(t,n){return t==null||n==null?void 0:super.visit(t,n)}visitNull(t,n){return Wd.startNull(n),Wd.endNull(n)}visitInt(t,n){return Si.startInt(n),Si.addBitWidth(n,t.bitWidth),Si.addIsSigned(n,t.isSigned),Si.endInt(n)}visitFloat(t,n){return ga.startFloatingPoint(n),ga.addPrecision(n,t.precision),ga.endFloatingPoint(n)}visitBinary(t,n){return jd.startBinary(n),jd.endBinary(n)}visitLargeBinary(t,n){return Yd.startLargeBinary(n),Yd.endLargeBinary(n)}visitBool(t,n){return Vd.startBool(n),Vd.endBool(n)}visitUtf8(t,n){return Zd.startUtf8(n),Zd.endUtf8(n)}visitLargeUtf8(t,n){return Xd.startLargeUtf8(n),Xd.endLargeUtf8(n)}visitDecimal(t,n){return to.startDecimal(n),to.addScale(n,t.scale),to.addPrecision(n,t.precision),to.addBitWidth(n,t.bitWidth),to.endDecimal(n)}visitDate(t,n){return ha.startDate(n),ha.addUnit(n,t.unit),ha.endDate(n)}visitTime(t,n){return Ho.startTime(n),Ho.addUnit(n,t.unit),Ho.addBitWidth(n,t.bitWidth),Ho.endTime(n)}visitTimestamp(t,n){let r=t.timezone&&n.createString(t.timezone)||void 0;return Zo.startTimestamp(n),Zo.addUnit(n,t.unit),r!==void 0&&Zo.addTimezone(n,r),Zo.endTimestamp(n)}visitInterval(t,n){return xa.startInterval(n),xa.addUnit(n,t.unit),xa.endInterval(n)}visitDuration(t,n){return pa.startDuration(n),pa.addUnit(n,t.unit),pa.endDuration(n)}visitList(t,n){return Gd.startList(n),Gd.endList(n)}visitStruct(t,n){return Hd.startStruct_(n),Hd.endStruct_(n)}visitUnion(t,n){Ii.startTypeIdsVector(n,t.typeIds.length);let r=Ii.createTypeIdsVector(n,t.typeIds);return Ii.startUnion(n),Ii.addMode(n,t.mode),Ii.addTypeIds(n,r),Ii.endUnion(n)}visitDictionary(t,n){let r=this.visit(t.indices,n);return Ki.startDictionaryEncoding(n),Ki.addId(n,BigInt(t.id)),Ki.addIsOrdered(n,t.isOrdered),r!==void 0&&Ki.addIndexType(n,r),Ki.endDictionaryEncoding(n)}visitFixedSizeBinary(t,n){return ma.startFixedSizeBinary(n),ma.addByteWidth(n,t.byteWidth),ma.endFixedSizeBinary(n)}visitFixedSizeList(t,n){return ya.startFixedSizeList(n),ya.addListSize(n,t.listSize),ya.endFixedSizeList(n)}visitMap(t,n){return ba.startMap(n),ba.addKeysSorted(n,t.keysSorted),ba.endMap(n)}},A0=new d2;function oB(e,t=new Map){return new oe(sj(e,t),T0(e.metadata),t)}function h2(e){return new vn(e.count,aB(e.columns),cB(e.columns))}function sB(e){return new yr(h2(e.data),e.id,e.isDelta)}function sj(e,t){return(e.fields||[]).filter(Boolean).map(n=>Ut.fromJSON(n,t))}function nB(e,t){return(e.children||[]).filter(Boolean).map(n=>Ut.fromJSON(n,t))}function aB(e){return(e||[]).reduce((t,n)=>[...t,new Kr(n.count,aj(n.VALIDITY)),...aB(n.children)],[])}function cB(e,t=[]){for(let n=-1,r=(e||[]).length;++n<r;){let i=e[n];i.VALIDITY&&t.push(new mr(t.length,i.VALIDITY.length)),i.TYPE_ID&&t.push(new mr(t.length,i.TYPE_ID.length)),i.OFFSET&&t.push(new mr(t.length,i.OFFSET.length)),i.DATA&&t.push(new mr(t.length,i.DATA.length)),t=cB(i.children,t)}return t}function aj(e){return(e||[]).reduce((t,n)=>t+ +(n===0),0)}function lB(e,t){let n,r,i,o,s,a;return!t||!(o=e.dictionary)?(s=iB(e,nB(e,t)),i=new Ut(e.name,s,e.nullable,T0(e.metadata))):t.has(n=o.id)?(r=(r=o.indexType)?rB(r):new eo,a=new Dr(t.get(n),r,n,o.isOrdered),i=new Ut(e.name,a,e.nullable,T0(e.metadata))):(r=(r=o.indexType)?rB(r):new eo,t.set(n,s=iB(e,nB(e,t))),a=new Dr(s,r,n,o.isOrdered),i=new Ut(e.name,a,e.nullable,T0(e.metadata))),i||null}function T0(e=[]){return new Map(e.map(({key:t,value:n})=>[t,n]))}function rB(e){return new Pe(e.isSigned,e.bitWidth)}function iB(e,t){let n=e.type.name;switch(n){case"NONE":return new Xn;case"null":return new Xn;case"binary":return new Jo;case"largebinary":return new Qo;case"utf8":return new Ko;case"largeutf8":return new ts;case"bool":return new es;case"list":return new Ni((t||[])[0]);case"struct":return new be(t||[]);case"struct_":return new be(t||[])}switch(n){case"int":{let r=e.type;return new Pe(r.isSigned,r.bitWidth)}case"floatingpoint":{let r=e.type;return new dr(he[r.precision])}case"decimal":{let r=e.type;return new ns(r.scale,r.precision,r.bitWidth)}case"date":{let r=e.type;return new rs(Ve[r.unit])}case"time":{let r=e.type;return new Ei(ct[r.unit],r.bitWidth)}case"timestamp":{let r=e.type;return new is(ct[r.unit],r.timezone)}case"interval":{let r=e.type;return new os(an[r.unit])}case"duration":{let r=e.type;return new ss(ct[r.unit])}case"union":{let r=e.type,[i,...o]=(r.mode+"").toLowerCase(),s=i.toUpperCase()+o.join("");return new Di(ge[s],r.typeIds||[],t||[])}case"fixedsizebinary":{let r=e.type;return new as(r.byteWidth)}case"fixedsizelist":{let r=e.type;return new Oi(r.listSize,(t||[])[0])}case"map":{let r=e.type;return new Bi((t||[])[0],r.keysSorted)}}throw new Error(`Unrecognized type: "${n}"`)}var cj=vc,lj=Er,gr=class e{static fromJSON(t,n){let r=new e(0,ce.V5,n);return r._createHeader=uj(t,n),r}static decode(t){t=new lj(_t(t));let n=ki.getRootAsMessage(t),r=n.bodyLength(),i=n.version(),o=n.headerType(),s=new e(r,i,o);return s._createHeader=fj(n,o),s}static encode(t){let n=new cj,r=-1;return t.isSchema()?r=oe.encode(n,t.header()):t.isRecordBatch()?r=vn.encode(n,t.header()):t.isDictionaryBatch()&&(r=yr.encode(n,t.header())),ki.startMessage(n),ki.addVersion(n,ce.V5),ki.addHeader(n,r),ki.addHeaderType(n,t.headerType),ki.addBodyLength(n,BigInt(t.bodyLength)),ki.finishMessageBuffer(n,ki.endMessage(n)),n.asUint8Array()}static from(t,n=0){if(t instanceof oe)return new e(0,ce.V5,qt.Schema,t);if(t instanceof vn)return new e(n,ce.V5,qt.RecordBatch,t);if(t instanceof yr)return new e(n,ce.V5,qt.DictionaryBatch,t);throw new Error(`Unrecognized Message header: ${t}`)}get type(){return this.headerType}get version(){return this._version}get headerType(){return this._headerType}get bodyLength(){return this._bodyLength}header(){return this._createHeader()}isSchema(){return this.headerType===qt.Schema}isRecordBatch(){return this.headerType===qt.RecordBatch}isDictionaryBatch(){return this.headerType===qt.DictionaryBatch}constructor(t,n,r,i){this._version=n,this._headerType=r,this.body=new Uint8Array(0),i&&(this._createHeader=()=>i),this._bodyLength=De(t)}},vn=class{get nodes(){return this._nodes}get length(){return this._length}get buffers(){return this._buffers}constructor(t,n,r){this._nodes=n,this._buffers=r,this._length=De(t)}},yr=class{get id(){return this._id}get data(){return this._data}get isDelta(){return this._isDelta}get length(){return this.data.length}get nodes(){return this.data.nodes}get buffers(){return this.data.buffers}constructor(t,n,r=!1){this._data=t,this._isDelta=r,this._id=De(n)}},mr=class{constructor(t,n){this.offset=De(t),this.length=De(n)}},Kr=class{constructor(t,n){this.length=De(t),this.nullCount=De(n)}};function uj(e,t){return()=>{switch(t){case qt.Schema:return oe.fromJSON(e);case qt.RecordBatch:return vn.fromJSON(e);case qt.DictionaryBatch:return yr.fromJSON(e)}throw new Error(`Unrecognized Message type: { name: ${qt[t]}, type: ${t} }`)}}function fj(e,t){return()=>{switch(t){case qt.Schema:return oe.decode(e.header(new fr),new Map,e.version());case qt.RecordBatch:return vn.decode(e.header(new Nr),e.version());case qt.DictionaryBatch:return yr.decode(e.header(new Wo),e.version())}throw new Error(`Unrecognized Message type: { name: ${qt[t]}, type: ${t} }`)}}Ut.encode=_j;Ut.decode=wj;Ut.fromJSON=lB;oe.encode=vj;oe.decode=dj;oe.fromJSON=oB;vn.encode=Sj;vn.decode=hj;vn.fromJSON=h2;yr.encode=Ij;yr.decode=pj;yr.fromJSON=sB;Kr.encode=Mj;Kr.decode=yj;mr.encode=Aj;mr.decode=mj;function dj(e,t=new Map,n=ce.V5){let r=bj(e,t);return new oe(r,E0(e),t,n)}function hj(e,t=ce.V5){if(e.compression()!==null)throw new Error("Record batch compression not implemented");return new vn(e.length(),gj(e),xj(e,t))}function pj(e,t=ce.V5){return new yr(vn.decode(e.data(),t),e.id(),e.isDelta())}function mj(e){return new mr(e.offset(),e.length())}function yj(e){return new Kr(e.length(),e.nullCount())}function gj(e){let t=[];for(let n,r=-1,i=-1,o=e.nodesLength();++r<o;)(n=e.nodes(r))&&(t[++i]=Kr.decode(n));return t}function xj(e,t){let n=[];for(let r,i=-1,o=-1,s=e.buffersLength();++i<s;)(r=e.buffers(i))&&(t<ce.V4&&(r.bb_pos+=8*(i+1)),n[++o]=mr.decode(r));return n}function bj(e,t){let n=[];for(let r,i=-1,o=-1,s=e.fieldsLength();++i<s;)(r=e.fields(i))&&(n[++o]=Ut.decode(r,t));return n}function uB(e,t){let n=[];for(let r,i=-1,o=-1,s=e.childrenLength();++i<s;)(r=e.children(i))&&(n[++o]=Ut.decode(r,t));return n}function wj(e,t){let n,r,i,o,s,a;return!t||!(a=e.dictionary())?(i=dB(e,uB(e,t)),r=new Ut(e.name(),i,e.nullable(),E0(e))):t.has(n=De(a.id()))?(o=(o=a.indexType())?fB(o):new eo,s=new Dr(t.get(n),o,n,a.isOrdered()),r=new Ut(e.name(),s,e.nullable(),E0(e))):(o=(o=a.indexType())?fB(o):new eo,t.set(n,i=dB(e,uB(e,t))),s=new Dr(i,o,n,a.isOrdered()),r=new Ut(e.name(),s,e.nullable(),E0(e))),r||null}function E0(e){let t=new Map;if(e)for(let n,r,i=-1,o=Math.trunc(e.customMetadataLength());++i<o;)(n=e.customMetadata(i))&&(r=n.key())!=null&&t.set(r,n.value());return t}function fB(e){return new Pe(e.isSigned(),e.bitWidth())}function dB(e,t){let n=e.typeType();switch(n){case pe.NONE:return new Xn;case pe.Null:return new Xn;case pe.Binary:return new Jo;case pe.LargeBinary:return new Qo;case pe.Utf8:return new Ko;case pe.LargeUtf8:return new ts;case pe.Bool:return new es;case pe.List:return new Ni((t||[])[0]);case pe.Struct_:return new be(t||[])}switch(n){case pe.Int:{let r=e.type(new Si);return new Pe(r.isSigned(),r.bitWidth())}case pe.FloatingPoint:{let r=e.type(new ga);return new dr(r.precision())}case pe.Decimal:{let r=e.type(new to);return new ns(r.scale(),r.precision(),r.bitWidth())}case pe.Date:{let r=e.type(new ha);return new rs(r.unit())}case pe.Time:{let r=e.type(new Ho);return new Ei(r.unit(),r.bitWidth())}case pe.Timestamp:{let r=e.type(new Zo);return new is(r.unit(),r.timezone())}case pe.Interval:{let r=e.type(new xa);return new os(r.unit())}case pe.Duration:{let r=e.type(new pa);return new ss(r.unit())}case pe.Union:{let r=e.type(new Ii);return new Di(r.mode(),r.typeIdsArray()||[],t||[])}case pe.FixedSizeBinary:{let r=e.type(new ma);return new as(r.byteWidth())}case pe.FixedSizeList:{let r=e.type(new ya);return new Oi(r.listSize(),(t||[])[0])}case pe.Map:{let r=e.type(new ba);return new Bi((t||[])[0],r.keysSorted())}}throw new Error(`Unrecognized type: "${pe[n]}" (${n})`)}function vj(e,t){let n=t.fields.map(o=>Ut.encode(e,o));fr.startFieldsVector(e,n.length);let r=fr.createFieldsVector(e,n),i=t.metadata&&t.metadata.size>0?fr.createCustomMetadataVector(e,[...t.metadata].map(([o,s])=>{let a=e.createString(`${o}`),c=e.createString(`${s}`);return rn.startKeyValue(e),rn.addKey(e,a),rn.addValue(e,c),rn.endKeyValue(e)})):-1;return fr.startSchema(e),fr.addFields(e,r),fr.addEndianness(e,Tj?da.Little:da.Big),i!==-1&&fr.addCustomMetadata(e,i),fr.endSchema(e)}function _j(e,t){let n=-1,r=-1,i=-1,o=t.type,s=t.typeId;st.isDictionary(o)?(s=o.dictionary.typeId,i=A0.visit(o,e),r=A0.visit(o.dictionary,e)):r=A0.visit(o,e);let a=(o.children||[]).map(u=>Ut.encode(e,u)),c=Cn.createChildrenVector(e,a),l=t.metadata&&t.metadata.size>0?Cn.createCustomMetadataVector(e,[...t.metadata].map(([u,f])=>{let d=e.createString(`${u}`),h=e.createString(`${f}`);return rn.startKeyValue(e),rn.addKey(e,d),rn.addValue(e,h),rn.endKeyValue(e)})):-1;return t.name&&(n=e.createString(t.name)),Cn.startField(e),Cn.addType(e,r),Cn.addTypeType(e,s),Cn.addChildren(e,c),Cn.addNullable(e,!!t.nullable),n!==-1&&Cn.addName(e,n),i!==-1&&Cn.addDictionary(e,i),l!==-1&&Cn.addCustomMetadata(e,l),Cn.endField(e)}function Sj(e,t){let n=t.nodes||[],r=t.buffers||[];Nr.startNodesVector(e,n.length);for(let s of n.slice().reverse())Kr.encode(e,s);let i=e.endVector();Nr.startBuffersVector(e,r.length);for(let s of r.slice().reverse())mr.encode(e,s);let o=e.endVector();return Nr.startRecordBatch(e),Nr.addLength(e,BigInt(t.length)),Nr.addNodes(e,i),Nr.addBuffers(e,o),Nr.endRecordBatch(e)}function Ij(e,t){let n=vn.encode(e,t.data);return Wo.startDictionaryBatch(e),Wo.addId(e,BigInt(t.id)),Wo.addIsDelta(e,t.isDelta),Wo.addData(e,n),Wo.endDictionaryBatch(e)}function Mj(e,t){return Ql.createFieldNode(e,BigInt(t.length),BigInt(t.nullCount))}function Aj(e,t){return Jl.createBuffer(e,BigInt(t.offset),BigInt(t.length))}var Tj=(()=>{let e=new ArrayBuffer(2);return new DataView(e).setInt16(0,256,!0),new Int16Array(e)[0]===256})();var m2=e=>`Expected ${qt[e]} Message in stream, but was null or length 0.`,y2=e=>`Header pointer of flatbuffer-encoded ${qt[e]} Message is null or length 0.`,hB=(e,t)=>`Expected to read ${e} metadata bytes, but only read ${t}.`,pB=(e,t)=>`Expected to read ${e} bytes for message body, but only read ${t}.`,mu=class{constructor(t){this.source=t instanceof io?t:new io(t)}[Symbol.iterator](){return this}next(){let t;return(t=this.readMetadataLength()).done?we:t.value===-1&&(t=this.readMetadataLength()).done?we:(t=this.readMetadata(t.value)).done?we:t}throw(t){return this.source.throw(t)}return(t){return this.source.return(t)}readMessage(t){let n;if((n=this.next()).done)return null;if(t!=null&&n.value.headerType!==t)throw new Error(m2(t));return n.value}readMessageBody(t){if(t<=0)return new Uint8Array(0);let n=_t(this.source.read(t));if(n.byteLength<t)throw new Error(pB(t,n.byteLength));return n.byteOffset%8===0&&n.byteOffset+n.byteLength<=n.buffer.byteLength?n:n.slice()}readSchema(t=!1){let n=qt.Schema,r=this.readMessage(n),i=r?.header();if(t&&!i)throw new Error(y2(n));return i}readMetadataLength(){let t=this.source.read(N0),n=t&&new Er(t),r=n?.readInt32(0)||0;return{done:r===0,value:r}}readMetadata(t){let n=this.source.read(t);if(!n)return we;if(n.byteLength<t)throw new Error(hB(t,n.byteLength));return{done:!1,value:gr.decode(n)}}},Bh=class{constructor(t,n){this.source=t instanceof Jr?t:cg(t)?new Sa(t,n):new Jr(t)}[Symbol.asyncIterator](){return this}next(){return Z(this,void 0,void 0,function*(){let t;return(t=yield this.readMetadataLength()).done?we:t.value===-1&&(t=yield this.readMetadataLength()).done?we:(t=yield this.readMetadata(t.value)).done?we:t})}throw(t){return Z(this,void 0,void 0,function*(){return yield this.source.throw(t)})}return(t){return Z(this,void 0,void 0,function*(){return yield this.source.return(t)})}readMessage(t){return Z(this,void 0,void 0,function*(){let n;if((n=yield this.next()).done)return null;if(t!=null&&n.value.headerType!==t)throw new Error(m2(t));return n.value})}readMessageBody(t){return Z(this,void 0,void 0,function*(){if(t<=0)return new Uint8Array(0);let n=_t(yield this.source.read(t));if(n.byteLength<t)throw new Error(pB(t,n.byteLength));return n.byteOffset%8===0&&n.byteOffset+n.byteLength<=n.buffer.byteLength?n:n.slice()})}readSchema(t=!1){return Z(this,void 0,void 0,function*(){let n=qt.Schema,r=yield this.readMessage(n),i=r?.header();if(t&&!i)throw new Error(y2(n));return i})}readMetadataLength(){return Z(this,void 0,void 0,function*(){let t=yield this.source.read(N0),n=t&&new Er(t),r=n?.readInt32(0)||0;return{done:r===0,value:r}})}readMetadata(t){return Z(this,void 0,void 0,function*(){let n=yield this.source.read(t);if(!n)return we;if(n.byteLength<t)throw new Error(hB(t,n.byteLength));return{done:!1,value:gr.decode(n)}})}},Lh=class extends mu{constructor(t){super(new Uint8Array(0)),this._schema=!1,this._body=[],this._batchIndex=0,this._dictionaryIndex=0,this._json=t instanceof ih?t:new ih(t)}next(){let{_json:t}=this;if(!this._schema)return this._schema=!0,{done:!1,value:gr.fromJSON(t.schema,qt.Schema)};if(this._dictionaryIndex<t.dictionaries.length){let n=t.dictionaries[this._dictionaryIndex++];return this._body=n.data.columns,{done:!1,value:gr.fromJSON(n,qt.DictionaryBatch)}}if(this._batchIndex<t.batches.length){let n=t.batches[this._batchIndex++];return this._body=n.columns,{done:!1,value:gr.fromJSON(n,qt.RecordBatch)}}return this._body=[],we}readMessageBody(t){return n(this._body);function n(r){return(r||[]).reduce((i,o)=>[...i,...o.VALIDITY&&[o.VALIDITY]||[],...o.TYPE_ID&&[o.TYPE_ID]||[],...o.OFFSET&&[o.OFFSET]||[],...o.DATA&&[o.DATA]||[],...n(o.children)],[])}}readMessage(t){let n;if((n=this.next()).done)return null;if(t!=null&&n.value.headerType!==t)throw new Error(m2(t));return n.value}readSchema(){let t=qt.Schema,n=this.readMessage(t),r=n?.header();if(!n||!r)throw new Error(y2(t));return r}},N0=4,p2="ARROW1",yu=new Uint8Array(p2.length);for(let e=0;e<p2.length;e+=1)yu[e]=p2.codePointAt(e);function D0(e,t=0){for(let n=-1,r=yu.length;++n<r;)if(yu[n]!==e[t+n])return!1;return!0}var gu=yu.length,g2=gu+N0,mB=gu*2+N0;var Lr=class e extends Tc{constructor(t){super(),this._impl=t}get closed(){return this._impl.closed}get schema(){return this._impl.schema}get autoDestroy(){return this._impl.autoDestroy}get dictionaries(){return this._impl.dictionaries}get numDictionaries(){return this._impl.numDictionaries}get numRecordBatches(){return this._impl.numRecordBatches}get footer(){return this._impl.isFile()?this._impl.footer:null}isSync(){return this._impl.isSync()}isAsync(){return this._impl.isAsync()}isFile(){return this._impl.isFile()}isStream(){return this._impl.isStream()}next(){return this._impl.next()}throw(t){return this._impl.throw(t)}return(t){return this._impl.return(t)}cancel(){return this._impl.cancel()}reset(t){return this._impl.reset(t),this._DOMStream=void 0,this._nodeStream=void 0,this}open(t){let n=this._impl.open(t);return Ar(n)?n.then(()=>this):this}readRecordBatch(t){return this._impl.isFile()?this._impl.readRecordBatch(t):null}[Symbol.iterator](){return this._impl[Symbol.iterator]()}[Symbol.asyncIterator](){return this._impl[Symbol.asyncIterator]()}toDOMStream(){return bn.toDOMStream(this.isSync()?{[Symbol.iterator]:()=>this}:{[Symbol.asyncIterator]:()=>this})}toNodeStream(){return bn.toNodeStream(this.isSync()?{[Symbol.iterator]:()=>this}:{[Symbol.asyncIterator]:()=>this},{objectMode:!0})}static throughNode(t){throw new Error('"throughNode" not available in this environment')}static throughDOM(t,n){throw new Error('"throughDOM" not available in this environment')}static from(t){return t instanceof e?t:sg(t)?Nj(t):cg(t)?Bj(t):Ar(t)?Z(this,void 0,void 0,function*(){return yield e.from(yield t)}):lg(t)||Rd(t)||fg(t)||Wr(t)?Oj(new Jr(t)):Dj(new io(t))}static readAll(t){return t instanceof e?t.isSync()?yB(t):gB(t):sg(t)||ArrayBuffer.isView(t)||wi(t)||ag(t)?yB(t):gB(t)}},xs=class extends Lr{constructor(t){super(t),this._impl=t}readAll(){return[...this]}[Symbol.iterator](){return this._impl[Symbol.iterator]()}[Symbol.asyncIterator](){return Mr(this,arguments,function*(){yield Ft(yield*Hl(bi(this[Symbol.iterator]())))})}},kc=class extends Lr{constructor(t){super(t),this._impl=t}readAll(){var t,n,r,i;return Z(this,void 0,void 0,function*(){let o=new Array;try{for(var s=!0,a=bi(this),c;c=yield a.next(),t=c.done,!t;s=!0){i=c.value,s=!1;let l=i;o.push(l)}}catch(l){n={error:l}}finally{try{!s&&!t&&(r=a.return)&&(yield r.call(a))}finally{if(n)throw n.error}}return o})}[Symbol.iterator](){throw new Error("AsyncRecordBatchStreamReader is not Iterable")}[Symbol.asyncIterator](){return this._impl[Symbol.asyncIterator]()}},Fc=class extends xs{constructor(t){super(t),this._impl=t}},O0=class extends kc{constructor(t){super(t),this._impl=t}},B0=class{get numDictionaries(){return this._dictionaryIndex}get numRecordBatches(){return this._recordBatchIndex}constructor(t=new Map){this.closed=!1,this.autoDestroy=!0,this._dictionaryIndex=0,this._recordBatchIndex=0,this.dictionaries=t}isSync(){return!1}isAsync(){return!1}isFile(){return!1}isStream(){return!1}reset(t){return this._dictionaryIndex=0,this._recordBatchIndex=0,this.schema=t,this.dictionaries=new Map,this}_loadRecordBatch(t,n){let r=this._loadVectors(t,n,this.schema.fields),i=Nt({type:new be(this.schema.fields),length:t.length,children:r});return new ke(this.schema,i)}_loadDictionaryBatch(t,n){let{id:r,isDelta:i}=t,{dictionaries:o,schema:s}=this,a=o.get(r);if(i||!a){let c=s.dictionaries.get(r),l=this._loadVectors(t.data,n,[c]);return(a&&i?a.concat(new Xt(l)):new Xt(l)).memoize()}return a.memoize()}_loadVectors(t,n,r){return new ch(n,t.nodes,t.buffers,this.dictionaries,this.schema.metadataVersion).visitMany(r)}},xu=class extends B0{constructor(t,n){super(n),this._reader=sg(t)?new Lh(this._handle=t):new mu(this._handle=t)}isSync(){return!0}isStream(){return!0}[Symbol.iterator](){return this}cancel(){!this.closed&&(this.closed=!0)&&(this.reset()._reader.return(),this._reader=null,this.dictionaries=null)}open(t){return this.closed||(this.autoDestroy=xB(this,t),this.schema||(this.schema=this._reader.readSchema())||this.cancel()),this}throw(t){return!this.closed&&this.autoDestroy&&(this.closed=!0)?this.reset()._reader.throw(t):we}return(t){return!this.closed&&this.autoDestroy&&(this.closed=!0)?this.reset()._reader.return(t):we}next(){if(this.closed)return we;let t,{_reader:n}=this;for(;t=this._readNextMessageAndValidate();)if(t.isSchema())this.reset(t.header());else if(t.isRecordBatch()){this._recordBatchIndex++;let r=t.header(),i=n.readMessageBody(t.bodyLength);return{done:!1,value:this._loadRecordBatch(r,i)}}else if(t.isDictionaryBatch()){this._dictionaryIndex++;let r=t.header(),i=n.readMessageBody(t.bodyLength),o=this._loadDictionaryBatch(r,i);this.dictionaries.set(r.id,o)}return this.schema&&this._recordBatchIndex===0?(this._recordBatchIndex++,{done:!1,value:new Cc(this.schema)}):this.return()}_readNextMessageAndValidate(t){return this._reader.readMessage(t)}},bu=class extends B0{constructor(t,n){super(n),this._reader=new Bh(this._handle=t)}isAsync(){return!0}isStream(){return!0}[Symbol.asyncIterator](){return this}cancel(){return Z(this,void 0,void 0,function*(){!this.closed&&(this.closed=!0)&&(yield this.reset()._reader.return(),this._reader=null,this.dictionaries=null)})}open(t){return Z(this,void 0,void 0,function*(){return this.closed||(this.autoDestroy=xB(this,t),this.schema||(this.schema=yield this._reader.readSchema())||(yield this.cancel())),this})}throw(t){return Z(this,void 0,void 0,function*(){return!this.closed&&this.autoDestroy&&(this.closed=!0)?yield this.reset()._reader.throw(t):we})}return(t){return Z(this,void 0,void 0,function*(){return!this.closed&&this.autoDestroy&&(this.closed=!0)?yield this.reset()._reader.return(t):we})}next(){return Z(this,void 0,void 0,function*(){if(this.closed)return we;let t,{_reader:n}=this;for(;t=yield this._readNextMessageAndValidate();)if(t.isSchema())yield this.reset(t.header());else if(t.isRecordBatch()){this._recordBatchIndex++;let r=t.header(),i=yield n.readMessageBody(t.bodyLength);return{done:!1,value:this._loadRecordBatch(r,i)}}else if(t.isDictionaryBatch()){this._dictionaryIndex++;let r=t.header(),i=yield n.readMessageBody(t.bodyLength),o=this._loadDictionaryBatch(r,i);this.dictionaries.set(r.id,o)}return this.schema&&this._recordBatchIndex===0?(this._recordBatchIndex++,{done:!1,value:new Cc(this.schema)}):yield this.return()})}_readNextMessageAndValidate(t){return Z(this,void 0,void 0,function*(){return yield this._reader.readMessage(t)})}},L0=class extends xu{get footer(){return this._footer}get numDictionaries(){return this._footer?this._footer.numDictionaries:0}get numRecordBatches(){return this._footer?this._footer.numRecordBatches:0}constructor(t,n){super(t instanceof oh?t:new oh(t),n)}isSync(){return!0}isFile(){return!0}open(t){if(!this.closed&&!this._footer){this.schema=(this._footer=this._readFooter()).schema;for(let n of this._footer.dictionaryBatches())n&&this._readDictionaryBatch(this._dictionaryIndex++)}return super.open(t)}readRecordBatch(t){var n;if(this.closed)return null;this._footer||this.open();let r=(n=this._footer)===null||n===void 0?void 0:n.getRecordBatch(t);if(r&&this._handle.seek(r.offset)){let i=this._reader.readMessage(qt.RecordBatch);if(i?.isRecordBatch()){let o=i.header(),s=this._reader.readMessageBody(i.bodyLength);return this._loadRecordBatch(o,s)}}return null}_readDictionaryBatch(t){var n;let r=(n=this._footer)===null||n===void 0?void 0:n.getDictionaryBatch(t);if(r&&this._handle.seek(r.offset)){let i=this._reader.readMessage(qt.DictionaryBatch);if(i?.isDictionaryBatch()){let o=i.header(),s=this._reader.readMessageBody(i.bodyLength),a=this._loadDictionaryBatch(o,s);this.dictionaries.set(o.id,a)}}}_readFooter(){let{_handle:t}=this,n=t.size-g2,r=t.readInt32(n),i=t.readAt(n-r,r);return us.decode(i)}_readNextMessageAndValidate(t){var n;if(this._footer||this.open(),this._footer&&this._recordBatchIndex<this.numRecordBatches){let r=(n=this._footer)===null||n===void 0?void 0:n.getRecordBatch(this._recordBatchIndex);if(r&&this._handle.seek(r.offset))return this._reader.readMessage(t)}return null}},x2=class extends bu{get footer(){return this._footer}get numDictionaries(){return this._footer?this._footer.numDictionaries:0}get numRecordBatches(){return this._footer?this._footer.numRecordBatches:0}constructor(t,...n){let r=typeof n[0]!="number"?n.shift():void 0,i=n[0]instanceof Map?n.shift():void 0;super(t instanceof Sa?t:new Sa(t,r),i)}isFile(){return!0}isAsync(){return!0}open(t){let n=Object.create(null,{open:{get:()=>super.open}});return Z(this,void 0,void 0,function*(){if(!this.closed&&!this._footer){this.schema=(this._footer=yield this._readFooter()).schema;for(let r of this._footer.dictionaryBatches())r&&(yield this._readDictionaryBatch(this._dictionaryIndex++))}return yield n.open.call(this,t)})}readRecordBatch(t){var n;return Z(this,void 0,void 0,function*(){if(this.closed)return null;this._footer||(yield this.open());let r=(n=this._footer)===null||n===void 0?void 0:n.getRecordBatch(t);if(r&&(yield this._handle.seek(r.offset))){let i=yield this._reader.readMessage(qt.RecordBatch);if(i?.isRecordBatch()){let o=i.header(),s=yield this._reader.readMessageBody(i.bodyLength);return this._loadRecordBatch(o,s)}}return null})}_readDictionaryBatch(t){var n;return Z(this,void 0,void 0,function*(){let r=(n=this._footer)===null||n===void 0?void 0:n.getDictionaryBatch(t);if(r&&(yield this._handle.seek(r.offset))){let i=yield this._reader.readMessage(qt.DictionaryBatch);if(i?.isDictionaryBatch()){let o=i.header(),s=yield this._reader.readMessageBody(i.bodyLength),a=this._loadDictionaryBatch(o,s);this.dictionaries.set(o.id,a)}}})}_readFooter(){return Z(this,void 0,void 0,function*(){let{_handle:t}=this;t._pending&&(yield t._pending);let n=t.size-g2,r=yield t.readInt32(n),i=yield t.readAt(n-r,r);return us.decode(i)})}_readNextMessageAndValidate(t){return Z(this,void 0,void 0,function*(){if(this._footer||(yield this.open()),this._footer&&this._recordBatchIndex<this.numRecordBatches){let n=this._footer.getRecordBatch(this._recordBatchIndex);if(n&&(yield this._handle.seek(n.offset)))return yield this._reader.readMessage(t)}return null})}},b2=class extends xu{constructor(t,n){super(t,n)}_loadVectors(t,n,r){return new r0(n,t.nodes,t.buffers,this.dictionaries,this.schema.metadataVersion).visitMany(r)}};function xB(e,t){return t&&typeof t.autoDestroy=="boolean"?t.autoDestroy:e.autoDestroy}function*yB(e){let t=Lr.from(e);try{if(!t.open({autoDestroy:!1}).closed)do yield t;while(!t.reset().open().closed)}finally{t.cancel()}}function gB(e){return Mr(this,arguments,function*(){let n=yield Ft(Lr.from(e));try{if(!(yield Ft(n.open({autoDestroy:!1}))).closed)do yield yield Ft(n);while(!(yield Ft(n.reset().open())).closed)}finally{yield Ft(n.cancel())}})}function Nj(e){return new xs(new b2(e))}function Dj(e){let t=e.peek(gu+7&-8);return t&&t.byteLength>=4?D0(t)?new Fc(new L0(e.read())):new xs(new xu(e)):new xs(new xu(function*(){}()))}function Oj(e){return Z(this,void 0,void 0,function*(){let t=yield e.peek(gu+7&-8);return t&&t.byteLength>=4?D0(t)?new Fc(new L0(yield e.read())):new kc(new bu(e)):new kc(new bu(function(){return Mr(this,arguments,function*(){})}()))})}function Bj(e){return Z(this,void 0,void 0,function*(){let{size:t}=yield e.stat(),n=new Sa(e,t);return t>=mB&&D0(yield n.readAt(0,gu+7&-8))?new O0(new x2(n)):new kc(new bu(n))})}var Me=class e extends mt{static assemble(...t){let n=i=>i.flatMap(o=>Array.isArray(o)?n(o):o instanceof ke?o.data.children:o.data),r=new e;return r.visitMany(n(t)),r}constructor(){super(),this._byteLength=0,this._nodes=[],this._buffers=[],this._bufferRegions=[]}visit(t){if(t instanceof Xt)return this.visitMany(t.data),this;let{type:n}=t;if(!st.isDictionary(n)){let{length:r}=t;if(r>2147483647)throw new RangeError("Cannot write arrays larger than 2^31 - 1 in length");if(st.isUnion(n))this.nodes.push(new Kr(r,0));else{let{nullCount:i}=t;st.isNull(n)||Fi.call(this,i<=0?new Uint8Array(0):Sc(t.offset,r,t.nullBitmap)),this.nodes.push(new Kr(r,i))}}return super.visit(t)}visitNull(t){return this}visitDictionary(t){return this.visit(t.clone(t.type.indices))}get nodes(){return this._nodes}get buffers(){return this._buffers}get byteLength(){return this._byteLength}get bufferRegions(){return this._bufferRegions}};function Fi(e){let t=e.byteLength+7&-8;return this.buffers.push(e),this.bufferRegions.push(new mr(this._byteLength,t)),this._byteLength+=t,this}function Lj(e){var t;let{type:n,length:r,typeIds:i,valueOffsets:o}=e;if(Fi.call(this,i),n.mode===ge.Sparse)return w2.call(this,e);if(n.mode===ge.Dense){if(e.offset<=0)return Fi.call(this,o),w2.call(this,e);{let s=new Int32Array(r),a=Object.create(null),c=Object.create(null);for(let l,u,f=-1;++f<r;)(l=i[f])!==void 0&&((u=a[l])===void 0&&(u=a[l]=o[f]),s[f]=o[f]-u,c[l]=((t=c[l])!==null&&t!==void 0?t:0)+1);Fi.call(this,s),this.visitMany(e.children.map((l,u)=>{let f=n.typeIds[u],d=a[f],h=c[f];return l.slice(d,Math.min(r,h))}))}}return this}function Cj(e){let t;return e.nullCount>=e.length?Fi.call(this,new Uint8Array(0)):(t=e.values)instanceof Uint8Array?Fi.call(this,Sc(e.offset,e.length,t)):Fi.call(this,Ic(e.values))}function bs(e){return Fi.call(this,e.values.subarray(0,e.length*e.stride))}function C0(e){let{length:t,values:n,valueOffsets:r}=e,i=De(r[0]),o=De(r[t]),s=Math.min(o-i,n.byteLength-i);return Fi.call(this,hg(-i,t+1,r)),Fi.call(this,n.subarray(i,i+s)),this}function v2(e){let{length:t,valueOffsets:n}=e;if(n){let{[0]:r,[t]:i}=n;return Fi.call(this,hg(-r,t+1,n)),this.visit(e.children[0].slice(r,i-r))}return this.visit(e.children[0])}function w2(e){return this.visitMany(e.type.children.map((t,n)=>e.children[n]).filter(Boolean))[0]}Me.prototype.visitBool=Cj;Me.prototype.visitInt=bs;Me.prototype.visitFloat=bs;Me.prototype.visitUtf8=C0;Me.prototype.visitLargeUtf8=C0;Me.prototype.visitBinary=C0;Me.prototype.visitLargeBinary=C0;Me.prototype.visitFixedSizeBinary=bs;Me.prototype.visitDate=bs;Me.prototype.visitTimestamp=bs;Me.prototype.visitTime=bs;Me.prototype.visitDecimal=bs;Me.prototype.visitList=v2;Me.prototype.visitStruct=w2;Me.prototype.visitUnion=Lj;Me.prototype.visitInterval=bs;Me.prototype.visitDuration=bs;Me.prototype.visitFixedSizeList=v2;Me.prototype.visitMap=v2;var Rc=class extends Tc{static throughNode(t){throw new Error('"throughNode" not available in this environment')}static throughDOM(t,n){throw new Error('"throughDOM" not available in this environment')}constructor(t){super(),this._position=0,this._started=!1,this._sink=new ro,this._schema=null,this._dictionaryBlocks=[],this._recordBatchBlocks=[],this._dictionaryDeltaOffsets=new Map,Yn(t)||(t={autoDestroy:!0,writeLegacyIpcFormat:!1}),this._autoDestroy=typeof t.autoDestroy=="boolean"?t.autoDestroy:!0,this._writeLegacyIpcFormat=typeof t.writeLegacyIpcFormat=="boolean"?t.writeLegacyIpcFormat:!1}toString(t=!1){return this._sink.toString(t)}toUint8Array(t=!1){return this._sink.toUint8Array(t)}writeAll(t){return Ar(t)?t.then(n=>this.writeAll(n)):Wr(t)?S2(this,t):_2(this,t)}get closed(){return this._sink.closed}[Symbol.asyncIterator](){return this._sink[Symbol.asyncIterator]()}toDOMStream(t){return this._sink.toDOMStream(t)}toNodeStream(t){return this._sink.toNodeStream(t)}close(){return this.reset()._sink.close()}abort(t){return this.reset()._sink.abort(t)}finish(){return this._autoDestroy?this.close():this.reset(this._sink,this._schema),this}reset(t=this._sink,n=null){return t===this._sink||t instanceof ro?this._sink=t:(this._sink=new ro,t&&BD(t)?this.toDOMStream({type:"bytes"}).pipeTo(t):t&&LD(t)&&this.toNodeStream({objectMode:!1}).pipe(t)),this._started&&this._schema&&this._writeFooter(this._schema),this._started=!1,this._dictionaryBlocks=[],this._recordBatchBlocks=[],this._dictionaryDeltaOffsets=new Map,(!n||!Lc(n,this._schema))&&(n==null?(this._position=0,this._schema=null):(this._started=!0,this._schema=n,this._writeSchema(n))),this}write(t){let n=null;if(this._sink){if(t==null)return this.finish()&&void 0;if(t instanceof pr&&!(n=t.schema))return this.finish()&&void 0;if(t instanceof ke&&!(n=t.schema))return this.finish()&&void 0}else throw new Error("RecordBatchWriter is closed");if(n&&!Lc(n,this._schema)){if(this._started&&this._autoDestroy)return this.close();this.reset(this._sink,n)}t instanceof ke?t instanceof Cc||this._writeRecordBatch(t):t instanceof pr?this.writeAll(t.batches):wi(t)&&this.writeAll(t)}_writeMessage(t,n=8){let r=n-1,i=gr.encode(t),o=i.byteLength,s=this._writeLegacyIpcFormat?4:8,a=o+s+r&~r,c=a-o-s;return t.headerType===qt.RecordBatch?this._recordBatchBlocks.push(new fs(a,t.bodyLength,this._position)):t.headerType===qt.DictionaryBatch&&this._dictionaryBlocks.push(new fs(a,t.bodyLength,this._position)),this._writeLegacyIpcFormat||this._write(Int32Array.of(-1)),this._write(Int32Array.of(a-s)),o>0&&this._write(i),this._writePadding(c)}_write(t){if(this._started){let n=_t(t);n&&n.byteLength>0&&(this._sink.write(n),this._position+=n.byteLength)}return this}_writeSchema(t){return this._writeMessage(gr.from(t))}_writeFooter(t){return this._writeLegacyIpcFormat?this._write(Int32Array.of(0)):this._write(Int32Array.of(-1,0))}_writeMagic(){return this._write(yu)}_writePadding(t){return t>0?this._write(new Uint8Array(t)):this}_writeRecordBatch(t){let{byteLength:n,nodes:r,bufferRegions:i,buffers:o}=Me.assemble(t),s=new vn(t.numRows,r,i),a=gr.from(s,n);return this._writeDictionaries(t)._writeMessage(a)._writeBodyBuffers(o)}_writeDictionaryBatch(t,n,r=!1){this._dictionaryDeltaOffsets.set(n,t.length+(this._dictionaryDeltaOffsets.get(n)||0));let{byteLength:i,nodes:o,bufferRegions:s,buffers:a}=Me.assemble(new Xt([t])),c=new vn(t.length,o,s),l=new yr(c,n,r),u=gr.from(l,i);return this._writeMessage(u)._writeBodyBuffers(a)}_writeBodyBuffers(t){let n,r,i;for(let o=-1,s=t.length;++o<s;)(n=t[o])&&(r=n.byteLength)>0&&(this._write(n),(i=(r+7&-8)-r)>0&&this._writePadding(i));return this}_writeDictionaries(t){for(let[n,r]of t.dictionaries){let i=this._dictionaryDeltaOffsets.get(n)||0;if(i===0||(r=r?.slice(i)).length>0)for(let o of r.data)this._writeDictionaryBatch(o,n,i>0),i+=o.length}return this}},Ch=class e extends Rc{static writeAll(t,n){let r=new e(n);return Ar(t)?t.then(i=>r.writeAll(i)):Wr(t)?S2(r,t):_2(r,t)}},kh=class e extends Rc{static writeAll(t){let n=new e;return Ar(t)?t.then(r=>n.writeAll(r)):Wr(t)?S2(n,t):_2(n,t)}constructor(){super(),this._autoDestroy=!0}_writeSchema(t){return this._writeMagic()._writePadding(2)}_writeFooter(t){let n=us.encode(new us(t,ce.V5,this._recordBatchBlocks,this._dictionaryBlocks));return super._writeFooter(t)._write(n)._write(Int32Array.of(n.byteLength))._writeMagic()}};function _2(e,t){let n=t;t instanceof pr&&(n=t.batches,e.reset(void 0,t.schema));for(let r of n)e.write(r);return e.finish()}function S2(e,t){var n,r,i,o,s,a,c;return Z(this,void 0,void 0,function*(){try{for(n=!0,r=bi(t);i=yield r.next(),o=i.done,!o;n=!0){c=i.value,n=!1;let l=c;e.write(l)}}catch(l){s={error:l}}finally{try{!n&&!o&&(a=r.return)&&(yield a.call(r))}finally{if(s)throw s.error}}return e.finish()})}function bB(e,t){if(Wr(e))return Fj(e,t);if(wi(e))return kj(e,t);throw new Error("toDOMStream() must be called with an Iterable or AsyncIterable")}function kj(e,t){let n=null,r=t?.type==="bytes"||!1,i=t?.highWaterMark||Math.pow(2,24);return new ReadableStream(Object.assign(Object.assign({},t),{start(s){o(s,n||(n=e[Symbol.iterator]()))},pull(s){n?o(s,n):s.close()},cancel(){(n?.return&&n.return()||!0)&&(n=null)}}),Object.assign({highWaterMark:r?i:void 0},t));function o(s,a){let c,l=null,u=s.desiredSize||null;for(;!(l=a.next(r?u:null)).done;)if(ArrayBuffer.isView(l.value)&&(c=_t(l.value))&&(u!=null&&r&&(u=u-c.byteLength+1),l.value=c),s.enqueue(l.value),u!=null&&--u<=0)return;s.close()}}function Fj(e,t){let n=null,r=t?.type==="bytes"||!1,i=t?.highWaterMark||Math.pow(2,24);return new ReadableStream(Object.assign(Object.assign({},t),{start(s){return Z(this,void 0,void 0,function*(){yield o(s,n||(n=e[Symbol.asyncIterator]()))})},pull(s){return Z(this,void 0,void 0,function*(){n?yield o(s,n):s.close()})},cancel(){return Z(this,void 0,void 0,function*(){(n?.return&&(yield n.return())||!0)&&(n=null)})}}),Object.assign({highWaterMark:r?i:void 0},t));function o(s,a){return Z(this,void 0,void 0,function*(){let c,l=null,u=s.desiredSize||null;for(;!(l=yield a.next(r?u:null)).done;)if(ArrayBuffer.isView(l.value)&&(c=_t(l.value))&&(u!=null&&r&&(u=u-c.byteLength+1),l.value=c),s.enqueue(l.value),u!=null&&--u<=0)return;s.close()})}}function _B(e){return new I2(e)}var I2=class{constructor(t){this._numChunks=0,this._finished=!1,this._bufferedSize=0;let{["readableStrategy"]:n,["writableStrategy"]:r,["queueingStrategy"]:i="count"}=t,o=DD(t,["readableStrategy","writableStrategy","queueingStrategy"]);this._controller=null,this._builder=Nc(o),this._getSize=i!=="bytes"?wB:vB;let{["highWaterMark"]:s=i==="bytes"?Math.pow(2,14):1e3}=Object.assign({},n),{["highWaterMark"]:a=i==="bytes"?Math.pow(2,14):1e3}=Object.assign({},r);this.readable=new ReadableStream({cancel:()=>{this._builder.clear()},pull:c=>{this._maybeFlush(this._builder,this._controller=c)},start:c=>{this._maybeFlush(this._builder,this._controller=c)}},{highWaterMark:s,size:i!=="bytes"?wB:vB}),this.writable=new WritableStream({abort:()=>{this._builder.clear()},write:()=>{this._maybeFlush(this._builder,this._controller)},close:()=>{this._maybeFlush(this._builder.finish(),this._controller)}},{highWaterMark:a,size:c=>this._writeValueAndReturnChunkSize(c)})}_writeValueAndReturnChunkSize(t){let n=this._bufferedSize;return this._bufferedSize=this._getSize(this._builder.append(t)),this._bufferedSize-n}_maybeFlush(t,n){n!=null&&(this._bufferedSize>=n.desiredSize&&++this._numChunks&&this._enqueue(n,t.toVector()),t.finished&&((t.length>0||this._numChunks===0)&&++this._numChunks&&this._enqueue(n,t.toVector()),!this._finished&&(this._finished=!0)&&this._enqueue(n,null)))}_enqueue(t,n){this._bufferedSize=0,this._controller=null,n==null?t.close():t.enqueue(n)}},wB=e=>{var t;return(t=e?.length)!==null&&t!==void 0?t:0},vB=e=>{var t;return(t=e?.byteLength)!==null&&t!==void 0?t:0};function k0(e,t){let n=new ro,r=null,i=new ReadableStream({cancel(){return Z(this,void 0,void 0,function*(){yield n.close()})},start(a){return Z(this,void 0,void 0,function*(){yield s(a,r||(r=yield o()))})},pull(a){return Z(this,void 0,void 0,function*(){r?yield s(a,r):a.close()})}});return{writable:new WritableStream(n,Object.assign({highWaterMark:Math.pow(2,14)},e)),readable:i};function o(){return Z(this,void 0,void 0,function*(){return yield(yield Lr.from(n)).open(t)})}function s(a,c){return Z(this,void 0,void 0,function*(){let l=a.desiredSize,u=null;for(;!(u=yield c.next()).done;)if(a.enqueue(u.value),l!=null&&--l<=0)return;a.close()})}}function F0(e,t){let n=new this(e),r=new Jr(n),i=new ReadableStream({cancel(){return Z(this,void 0,void 0,function*(){yield r.cancel()})},pull(s){return Z(this,void 0,void 0,function*(){yield o(s)})},start(s){return Z(this,void 0,void 0,function*(){yield o(s)})}},Object.assign({highWaterMark:Math.pow(2,14)},t));return{writable:new WritableStream(n,e),readable:i};function o(s){return Z(this,void 0,void 0,function*(){let a=null,c=s.desiredSize;for(;a=yield r.read(c||null);)if(s.enqueue(a),c!=null&&(c-=a.byteLength)<=0)return;s.close()})}}function Fh(e){let t=Lr.from(e);return Ar(t)?t.then(n=>Fh(n)):t.isAsync()?t.readAll().then(n=>new pr(n)):new pr(t.readAll())}var $j=Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},k_),a2),Q_),F_),D_),J_),L_),{compareSchemas:Lc,compareFields:ZO,compareTypes:JO});bn.toDOMStream=bB;ve.throughDOM=_B;Lr.throughDOM=k0;Fc.throughDOM=k0;xs.throughDOM=k0;Rc.throughDOM=F0;kh.throughDOM=F0;Ch.throughDOM=F0;function R0(e="ws://localhost:3000/"){let t=[],n=!1,r=null,i,o={open(){n=!0,c()},close(){for(n=!1,r=null,i=null;t.length;)t.shift().reject("Socket closed")},error(l){if(r){let{reject:u}=r;r=null,c(),u(l)}else console.error("WebSocket error: ",l)},message({data:l}){if(r){let{query:u,resolve:f,reject:d}=r;if(r=null,c(),typeof l=="string"){let h=JSON.parse(l);h.error?d(h.error):f(h)}else if(u.type==="exec")f();else if(u.type==="arrow")f(Fh(l.arrayBuffer()));else throw new Error(`Unexpected socket data: ${l}`)}else console.log("WebSocket message: ",l)}};function s(){i=new WebSocket(e);for(let l in o)i.addEventListener(l,o[l])}function a(l,u,f){i==null&&s(),t.push({query:l,resolve:u,reject:f}),n&&!r&&c()}function c(){t.length&&(r=t.shift(),i.send(JSON.stringify(r.query)))}return{get connected(){return n},query(l){return new Promise((u,f)=>a(l,u,f))}}}var xr=class{constructor(t,n){t&&(this.table=String(t)),n&&(this.column=n)}get columns(){return this.column?[this.column]:[]}toString(){let{table:t,column:n}=this;if(n){let r=n.startsWith("*")?n:`"${n}"`;return`${t?`${SB(t)}.`:""}${r}`}else return t?SB(t):"NULL"}};function SB(e){return e.split(".").map(n=>`"${n}"`).join(".")}function IB(e,t){return e instanceof xr&&e.column===t}function jt(e){return typeof e=="string"?Ia(e):e}function $c(e){return typeof e=="string"?MB(e):e}function MB(e){return new xr(e)}function Ia(e,t){return arguments.length===1&&(t=e,e=null),new xr(e,t)}function so(e){switch(typeof e){case"boolean":return e?"TRUE":"FALSE";case"string":return`'${e}'`;case"number":return Number.isFinite(e)?String(e):"NULL";default:if(e==null)return"NULL";if(e instanceof Date){let t=+e;if(Number.isNaN(t))return"NULL";let n=e.getUTCFullYear(),r=e.getUTCMonth(),i=e.getUTCDate();return t===Date.UTC(n,r,i)?`MAKE_DATE(${n}, ${r+1}, ${i})`:`EPOCH_MS(${t})`}else return e instanceof RegExp?`'${e.source}'`:String(e)}}var ws=e=>typeof e?.addEventListener=="function";function $0(e){return e instanceof Ma}var Ma=class{constructor(t,n,r){this._expr=Array.isArray(t)?t:[t],this._deps=n||[],this.annotate(r);let i=this._expr.filter(o=>ws(o));i.length>0?(this._params=Array.from(new Set(i)),this._params.forEach(o=>{o.addEventListener("value",()=>Pj(this,this.map?.get("value")))})):this.addEventListener=void 0}get value(){return this}get columns(){let{_params:t,_deps:n}=this;if(t){let r=new Set(t.flatMap(i=>{let o=i.value?.columns;return Array.isArray(o)?o:[]}));if(r.size){let i=new Set(n);return r.forEach(o=>i.add(o)),Array.from(i)}}return n}get column(){return this._deps.length?this._deps[0]:this.columns[0]}annotate(...t){return Object.assign(this,...t)}toString(){return this._expr.map(t=>ws(t)&&!$0(t)?so(t.value):t).join("")}addEventListener(t,n){let r=this.map||(this.map=new Map);(r.get(t)||(r.set(t,new Set),r.get(t))).add(n)}};function Pj(e,t){if(t?.size)return Promise.allSettled(Array.from(t,n=>n(e)))}function M2(e,t){let n=[e[0]],r=new Set,i=t.length;for(let o=0,s=0;o<i;){let a=t[o];ws(a)?n[++s]=a:(Array.isArray(a?.columns)&&a.columns.forEach(l=>r.add(l)),n[s]+=typeof a=="string"?a:so(a));let c=e[++o];ws(n[s])?n[++s]=c:n[s]+=c}return{spans:n,cols:Array.from(r)}}function q(e,...t){let{spans:n,cols:r}=M2(e,t);return new Ma(n,r)}function A2(e){let t=jt(e);return q`${t} DESC NULLS LAST`.annotate({label:t?.label,desc:!0})}var Cr=e=>({value:e,toString:()=>so(e)});function Rh(e){e(this.op,this),this.children?.forEach(t=>t.visit(e))}function AB(e,t){let n=t.filter(i=>i!=null).map(jt),r=n.map((i,o)=>o?` ${e} `:"");return n.length===1?r.push(""):n.length>1&&(r[0]="(",r.push(")")),q(r,...n).annotate({op:e,children:n,visit:Rh})}var Wn=(...e)=>AB("AND",e.flat()),Pc=(...e)=>AB("OR",e.flat()),Uj=e=>t=>q`(${e} ${jt(t)})`.annotate({op:e,a:t,visit:Rh}),T2=Uj("NOT"),TB=e=>t=>q`(${jt(t)} ${e})`.annotate({op:e,a:t,visit:Rh}),Uc=TB("IS NULL"),vs=TB("IS NOT NULL"),Aa=e=>(t,n)=>q`(${jt(t)} ${e} ${jt(n)})`.annotate({op:e,a:t,b:n,visit:Rh}),_s=Aa("="),zc=Aa("<>"),Ss=Aa("<"),$h=Aa(">"),Is=Aa("<="),E2=Aa(">="),N2=Aa("IS DISTINCT FROM"),Ph=Aa("IS NOT DISTINCT FROM");function EB(e,t,n,r){t=jt(t);let i=e.startsWith("NOT ")?"NOT ":"";return(n?r?q`${i}(${n[0]} <= ${t} AND ${t} < ${n[1]})`:q`(${t} ${e} ${n[0]} AND ${n[1]})`:q``).annotate({op:e,visit:Rh,field:t,range:n})}var Ae=(e,t,n)=>EB("BETWEEN",e,t,n),D2=(e,t,n)=>EB("NOT BETWEEN",e,t,n);function qc(e,t){return Array.from({length:e},()=>t)}function _n(e,t){return(...n)=>{let r=n.map(jt),i=t?`::${t}`:"";return(r.length?q([`${e}(`,...qc(r.length-1,", "),`)${i}`],...r):q`${e}()${i}`).annotate({func:e,args:r})}}var O2=_n("REGEXP_MATCHES"),B2=_n("CONTAINS"),L2=_n("PREFIX"),C2=_n("SUFFIX"),zj=_n("LOWER"),qj=_n("UPPER"),jj=_n("LENGTH"),Vj=_n("ISNAN"),Yj=_n("ISFINITE"),Xj=_n("ISINF");var Uh=class e extends Ma{constructor(t,n,r,i,o="",s="",a=""){let c;if(i&&!(o||s||a))c=i?q`${n} OVER "${i}"`:q`${n} OVER ()`;else{let d=o&&s?" ":"",h=(o||s)&&a?" ":"";c=q`${n} OVER (${i?`"${i}" `:""}${o}${d}${s}${h}${a})`}r&&(c=q`(${c})::${r}`);let{_expr:u,_deps:f}=c;super(u,f,{window:t,func:n,type:r,name:i,group:o,order:s,frame:a})}get basis(){return this.column}get label(){let{func:t}=this;return t.label??t.toString()}over(t){let{window:n,func:r,type:i,group:o,order:s,frame:a}=this;return new e(n,r,i,t,o,s,a)}partitionby(...t){let n=t.flat().filter(u=>u).map(jt),r=q(["PARTITION BY ",qc(n.length-1,", "),""],...n),{window:i,func:o,type:s,name:a,order:c,frame:l}=this;return new e(i,o,s,a,r,c,l)}orderby(...t){let n=t.flat().filter(u=>u).map(jt),r=q(["ORDER BY ",qc(n.length-1,", "),""],...n),{window:i,func:o,type:s,name:a,group:c,frame:l}=this;return new e(i,o,s,a,c,r,l)}rows(t){let n=NB("ROWS",t),{window:r,func:i,type:o,name:s,group:a,order:c}=this;return new e(r,i,o,s,a,c,n)}range(t){let n=NB("RANGE",t),{window:r,func:i,type:o,name:s,group:a,order:c}=this;return new e(r,i,o,s,a,c,n)}};function NB(e,t){if(ws(t)){let n=q`${t}`;return n.toString=()=>`${e} ${DB(t.value)}`,n}return`${e} ${DB(t)}`}function DB(e){let[t,n]=e,r=t===0?"CURRENT ROW":Number.isFinite(t)?`${Math.abs(t)} PRECEDING`:"UNBOUNDED PRECEDING",i=n===0?"CURRENT ROW":Number.isFinite(n)?`${Math.abs(n)} FOLLOWING`:"UNBOUNDED FOLLOWING";return`BETWEEN ${r} AND ${i}`}function Ri(e,t){return(...n)=>{let r=_n(e)(...n);return new Uh(e,r,t)}}var k2=Ri("ROW_NUMBER","INTEGER"),F2=Ri("RANK","INTEGER"),R2=Ri("DENSE_RANK","INTEGER"),$2=Ri("PERCENT_RANK"),P2=Ri("CUME_DIST"),U2=Ri("NTILE"),z2=Ri("LAG"),q2=Ri("LEAD"),j2=Ri("FIRST_VALUE"),V2=Ri("LAST_VALUE"),Y2=Ri("NTH_VALUE");function G2(e,...t){return q(e,...t).annotate({aggregate:!0})}var X2=class e extends Ma{constructor(t,n,r,i,o){n=(n||[]).map(jt);let{strings:s,exprs:a}=Gj(t,n,r,i,o),{spans:c,cols:l}=M2(s,a);super(c,l,{aggregate:t,args:n,type:r,isDistinct:i,filter:o})}get basis(){return this.column}get label(){let{aggregate:t,args:n,isDistinct:r}=this,i=r?"DISTINCT"+(n.length?" ":""):"",o=n.length?`(${i}${n.map(Wj).join(", ")})`:"";return`${t.toLowerCase()}${o}`}distinct(){let{aggregate:t,args:n,type:r,filter:i}=this;return new e(t,n,r,!0,i)}where(t){let{aggregate:n,args:r,type:i,isDistinct:o}=this;return new e(n,r,i,o,t)}window(){let{aggregate:t,args:n,type:r,isDistinct:i}=this,o=new e(t,n,null,i);return new Uh(t,o,r)}partitionby(...t){return this.window().partitionby(...t)}orderby(...t){return this.window().orderby(...t)}rows(t,n){return this.window().rows(t,n)}range(t,n){return this.window().range(t,n)}};function Gj(e,t,n,r,i){let o=`)${n?`::${n}`:""}`,s=[`${e}(${r?"DISTINCT ":""}`],a=[];return t.length?(s=s.concat([...qc(t.length-1,", "),`${o}${i?" FILTER (WHERE ":""}`,...i?[")"]:[]]),a=[...t,...i?[i]:[]]):s[0]+="*"+o,{exprs:a,strings:s}}function Wj(e){let t=so(e);return t&&t.startsWith('"')&&t.endsWith('"')?t.slice(1,-1):t}function Jt(e,t){return(...n)=>new X2(e,n,t)}var kr=Jt("COUNT","INTEGER"),W2=Jt("AVG"),Hj=Jt("AVG"),H2=Jt("MAD"),ti=Jt("MAX"),ei=Jt("MIN"),Fr=Jt("SUM","DOUBLE"),Z2=Jt("PRODUCT"),J2=Jt("MEDIAN"),Q2=Jt("QUANTILE"),K2=Jt("MODE"),tS=Jt("VARIANCE"),eS=Jt("STDDEV"),nS=Jt("SKEWNESS"),rS=Jt("KURTOSIS"),iS=Jt("ENTROPY"),oS=Jt("VAR_POP"),sS=Jt("STDDEV_POP"),aS=Jt("CORR"),cS=Jt("COVAR_POP"),lS=Jt("REGR_INTERCEPT"),uS=Jt("REGR_SLOPE"),fS=Jt("REGR_COUNT"),Zj=Jt("REGR_R2"),dS=Jt("REGR_SYY"),hS=Jt("REGR_SXX"),Jj=Jt("REGR_SXY"),pS=Jt("REGR_AVGX"),Qj=Jt("REGR_AVGY"),mS=Jt("FIRST"),yS=Jt("LAST"),wu=Jt("ARG_MIN"),vu=Jt("ARG_MAX"),gS=Jt("STRING_AGG"),xS=Jt("ARRAY_AGG");function zh(e,t){let n=jt(e),r=q`CAST(${n} AS ${t})`;return Object.defineProperty(r,"label",{enumerable:!0,get(){return e.label}}),Object.defineProperty(r,"aggregate",{enumerable:!0,get(){return e.aggregate||!1}}),r}var _u=e=>zh(e,"DOUBLE"),bS=e=>zh(e,"INTEGER");var wS=e=>q`epoch_ms(${jt(e)})`,vS=e=>{let t=jt(e);return q`MAKE_DATE(2012, MONTH(${t}), 1)`.annotate({label:"month"})},_S=e=>{let t=jt(e);return q`MAKE_DATE(2012, MONTH(${t}), DAY(${t}))`.annotate({label:"date"})},SS=e=>{let t=jt(e);return q`MAKE_DATE(2012, 1, DAY(${t}))`.annotate({label:"date"})};var qh=_n("ST_AsGeoJSON"),OB=_n("ST_X"),BB=_n("ST_Y"),jh=_n("ST_CENTROID"),IS=e=>OB(jh(e)),MS=e=>BB(jh(e));var ht=class e{static select(...t){return new e().select(...t)}static from(...t){return new e().from(...t)}static with(...t){return new e().with(...t)}static union(...t){return new jc("UNION",t.flat())}static unionAll(...t){return new jc("UNION ALL",t.flat())}static intersect(...t){return new jc("INTERSECT",t.flat())}static except(...t){return new jc("EXCEPT",t.flat())}static describe(t){let n=t.clone(),{clone:r,toString:i}=n;return Object.assign(n,{describe:!0,clone:()=>e.describe(r.call(n)),toString:()=>`DESCRIBE ${i.call(n)}`})}constructor(){this.query={with:[],select:[],from:[],where:[],groupby:[],having:[],window:[],qualify:[],orderby:[]}}clone(){let t=new e;return t.query={...this.query},t}with(...t){let{query:n}=this;if(t.length===0)return n.with;{let r=[],i=(o,s)=>{let a=s.clone();a.cteFor=this,r.push({as:o,query:a})};return t.flat().forEach(o=>{if(o!=null)if(o.as&&o.query)i(o.as,o.query);else for(let s in o)i(s,o[s])}),n.with=n.with.concat(r),this}}select(...t){let{query:n}=this;if(t.length===0)return n.select;{let r=[];for(let i of t.flat())if(i!=null)if(typeof i=="string")r.push({as:i,expr:jt(i)});else if(i instanceof xr)r.push({as:i.column,expr:i});else if(Array.isArray(i))r.push({as:i[0],expr:i[1]});else for(let o in i)r.push({as:P0(o),expr:jt(i[o])});return n.select=n.select.concat(r),this}}$select(...t){return this.query.select=[],this.select(...t)}distinct(t=!0){return this.query.distinct=!!t,this}from(...t){let{query:n}=this;if(t.length===0)return n.from;{let r=[];return t.flat().forEach(i=>{if(i!=null)if(typeof i=="string")r.push({as:i,from:$c(i)});else if(i instanceof xr)r.push({as:i.table,from:i});else if(Vh(i)||$0(i))r.push({from:i});else if(Array.isArray(i))r.push({as:P0(i[0]),from:$c(i[1])});else for(let o in i)r.push({as:P0(o),from:$c(i[o])})}),n.from=n.from.concat(r),this}}$from(...t){return this.query.from=[],this.from(...t)}sample(t,n){let{query:r}=this;if(arguments.length===0)return r.sample;{let i=t;return typeof t=="number"&&(i=t>0&&t<1?{perc:100*t,method:n}:{rows:Math.round(t),method:n}),r.sample=i,this}}where(...t){let{query:n}=this;return t.length===0?n.where:(n.where=n.where.concat(t.flat().filter(r=>r)),this)}$where(...t){return this.query.where=[],this.where(...t)}groupby(...t){let{query:n}=this;return t.length===0?n.groupby:(n.groupby=n.groupby.concat(t.flat().filter(r=>r).map(jt)),this)}$groupby(...t){return this.query.groupby=[],this.groupby(...t)}having(...t){let{query:n}=this;return t.length===0?n.having:(n.having=n.having.concat(t.flat().filter(r=>r)),this)}window(...t){let{query:n}=this;if(t.length===0)return n.window;{let r=[];return t.flat().forEach(i=>{if(i!=null)for(let o in i)r.push({as:P0(o),expr:i[o]})}),n.window=n.window.concat(r),this}}qualify(...t){let{query:n}=this;return t.length===0?n.qualify:(n.qualify=n.qualify.concat(t.flat().filter(r=>r)),this)}orderby(...t){let{query:n}=this;return t.length===0?n.orderby:(n.orderby=n.orderby.concat(t.flat().filter(r=>r).map(jt)),this)}limit(t){let{query:n}=this;return arguments.length===0?n.limit:(n.limit=Number.isFinite(t)?t:void 0,this)}offset(t){let{query:n}=this;return arguments.length===0?n.offset:(n.offset=Number.isFinite(t)?t:void 0,this)}get subqueries(){let{query:t,cteFor:n}=this,i=(n?.query||t).with?.reduce((s,{as:a,query:c})=>(s[a]=c,s),{}),o=[];return t.from.forEach(({from:s})=>{if(Vh(s))o.push(s);else if(i[s.table]){let a=i[s.table];o.push(a)}}),o}toString(){let{with:t,select:n,distinct:r,from:i,sample:o,where:s,groupby:a,having:c,window:l,qualify:u,orderby:f,limit:d,offset:h}=this.query,p=[];if(t.length){let g=t.map(({as:y,query:x})=>`"${y}" AS (${x})`);p.push(`WITH ${g.join(", ")}`)}let m=n.map(({as:g,expr:y})=>IB(y,g)&&!y.table?`${y}`:`${y} AS "${g}"`);if(p.push(`SELECT${r?" DISTINCT":""} ${m.join(", ")}`),i.length){let g=i.map(({as:y,from:x})=>{let b=Vh(x)?`(${x})`:`${x}`;return!y||y===x.table?b:`${b} AS "${y}"`});p.push(`FROM ${g.join(", ")}`)}if(s.length){let g=s.map(String).filter(y=>y).join(" AND ");g&&p.push(`WHERE ${g}`)}if(o){let{rows:g,perc:y,method:x,seed:b}=o,w=g?`${g} ROWS`:`${y} PERCENT`,v=x?` (${x}${b!=null?`, ${b}`:""})`:"";p.push(`USING SAMPLE ${w}${v}`)}if(a.length&&p.push(`GROUP BY ${a.join(", ")}`),c.length){let g=c.map(String).filter(y=>y).join(" AND ");g&&p.push(`HAVING ${g}`)}if(l.length){let g=l.map(({as:y,expr:x})=>`"${y}" AS (${x})`);p.push(`WINDOW ${g.join(", ")}`)}if(u.length){let g=u.map(String).filter(y=>y).join(" AND ");g&&p.push(`QUALIFY ${g}`)}return f.length&&p.push(`ORDER BY ${f.join(", ")}`),Number.isFinite(d)&&p.push(`LIMIT ${d}`),Number.isFinite(h)&&p.push(`OFFSET ${h}`),p.join(" ")}},jc=class e{constructor(t,n){this.op=t,this.queries=n.map(r=>r.clone()),this.query={orderby:[]}}clone(){let t=new e(this.op,this.queries);return t.query={...this.query},t}orderby(...t){let{query:n}=this;return t.length===0?n.orderby:(n.orderby=n.orderby.concat(t.flat().filter(r=>r).map(jt)),this)}limit(t){let{query:n}=this;return arguments.length===0?n.limit:(n.limit=Number.isFinite(t)?t:void 0,this)}offset(t){let{query:n}=this;return arguments.length===0?n.offset:(n.offset=Number.isFinite(t)?t:void 0,this)}get subqueries(){let{queries:t,cteFor:n}=this;return n&&t.forEach(r=>r.cteFor=n),t}toString(){let{op:t,queries:n,query:{orderby:r,limit:i,offset:o}}=this,s=[n.join(` ${t} `)];return r.length&&s.push(`ORDER BY ${r.join(", ")}`),Number.isFinite(i)&&s.push(`LIMIT ${i}`),Number.isFinite(o)&&s.push(`OFFSET ${o}`),s.join(" ")}};function Vh(e){return e instanceof ht||e instanceof jc}function AS(e){return Vh(e)&&e.describe}function P0(e){return Kj(e)?e.slice(1,-1):e}function Kj(e){return e[0]==='"'&&e[e.length-1]==='"'}var U0=e=>e;function tV(){return{apply:U0,invert:U0,sqlApply:jt,sqlInvert:U0}}function eV({base:e}={}){if(e==null||e===Math.E)return{apply:Math.log,invert:Math.exp,sqlApply:t=>q`LN(${jt(t)})`,sqlInvert:t=>q`EXP(${t})`};if(e===10)return{apply:Math.log10,invert:t=>Math.pow(10,t),sqlApply:t=>q`LOG(${jt(t)})`,sqlInvert:t=>q`POW(10, ${t})`};{let t=+e;return{apply:n=>Math.log(n)/Math.log(t),invert:n=>Math.pow(t,n),sqlApply:n=>q`LN(${jt(n)}) / LN(${t})`,sqlInvert:n=>q`POW(${t}, ${n})`}}}function nV({constant:e=1}={}){let t=+e;return{apply:n=>Math.sign(n)*Math.log1p(Math.abs(n)),invert:n=>Math.sign(n)*Math.exp(Math.abs(n)-t),sqlApply:n=>(n=jt(n),q`SIGN(${n}) * LN(${t} + ABS(${n}))`),sqlInvert:n=>q`SIGN(${n}) * (EXP(ABS(${n})) - ${t})`}}function rV(){return{apply:e=>Math.sign(e)*Math.sqrt(Math.abs(e)),invert:e=>Math.sign(e)*e*e,sqlApply:e=>(e=jt(e),q`SIGN(${e}) * SQRT(ABS(${e}))`),sqlInvert:e=>q`SIGN(${e}) * (${e}) ** 2`}}function iV({exponent:e=1}={}){let t=+e;return{apply:n=>Math.sign(n)*Math.pow(Math.abs(n),t),invert:n=>Math.sign(n)*Math.pow(Math.abs(n),1/t),sqlApply:n=>(n=jt(n),q`SIGN(${n}) * POW(ABS(${n}), ${t})`),sqlInvert:n=>q`SIGN(${n}) * POW(ABS(${n}), 1/${t})`}}function LB(){return{apply:e=>+e,invert:e=>new Date(e),sqlApply:e=>e instanceof Date?+e:wS(jt(e)),sqlInvert:U0}}var oV={linear:tV,log:eV,symlog:nV,sqrt:rV,pow:iV,time:LB,utc:LB};function Yh(e){let t=oV[e.type];return t?{...e,...t(e)}:null}function ao(e,t,{replace:n=!1,temp:r=!0,view:i=!1}={}){return"CREATE"+(n?" OR REPLACE ":" ")+(r?"TEMP ":"")+(i?"VIEW":"TABLE")+(n?" ":" IF NOT EXISTS ")+e+" AS "+t}function Xh(e){return`INSTALL ${e}; LOAD ${e}`}function CB(e,{columns:t=Object.keys(e?.[0]||{})}={}){let n=[];if(Array.isArray(t)?(n=t,t=n.reduce((i,o)=>(i[o]=o,i),{})):t&&(n=Object.keys(t)),!n.length)throw new Error("Can not create table from empty column set.");let r=[];for(let i of e){let o=n.map(s=>`${so(i[s])} AS "${t[s]}"`);r.push(`(SELECT ${o.join(", ")})`)}return r.join(" UNION ALL ")}function z0(e,t,n,r={},i={}){let{select:o=["*"],where:s,view:a,temp:c,replace:l,...u}=r,f=sV({...i,...u}),d=`${e}('${n}'${f?", "+f:""})`,h=s?` WHERE ${s}`:"",p=`SELECT ${o.join(", ")} FROM ${d}${h}`;return ao(t,p,{view:a,temp:c,replace:l})}function ES(e,t,n){return z0("read_csv",e,t,n,{auto_detect:!0,sample_size:-1})}function NS(e,t,n){return z0("read_json",e,t,n,{auto_detect:!0,json_format:"auto"})}function DS(e,t,n){return z0("read_parquet",e,t,n)}function OS(e,t,n={}){let{options:r,...i}=n;if(r){let o=Array.isArray(r)?r.join(", "):typeof r=="string"?r:Object.entries(r).map(([s,a])=>`${s}=${a}`).join(", ");i.open_options=o.toUpperCase()}return z0("st_read",e,t,i)}function BS(e,t,n={}){let{select:r=["*"],...i}=n,o=CB(t),s=r.length===1&&r[0]==="*"?o:`SELECT ${r} FROM ${o}`;return ao(e,s,i)}function sV(e){return Object.entries(e).map(([t,n])=>`${t}=${TS(n)}`).join(", ")}function TS(e){switch(typeof e){case"boolean":return String(e);case"string":return`'${e}'`;case"undefined":case"object":return e==null?"NULL":Array.isArray(e)?"["+e.map(t=>TS(t)).join(", ")+"]":"{"+Object.entries(e).map(([t,n])=>`'${t}': ${TS(n)}`).join(", ")+"}";default:return e}}function FB(e){let t=2166136261;for(let n=0,r=e.length;n<r;++n){let i=e.charCodeAt(n),o=i&65280;o&&(t=kB(t^o>>8)),t=kB(t^i&255)}return aV(t)}function kB(e){return e+(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24)}function aV(e){return e+=e<<13,e^=e>>>7,e+=e<<3,e^=e>>>17,e+=e<<5,e&4294967295}var q0=class{constructor(t,{selection:n,temp:r=!0}){this.mc=t,this.selection=n,this.temp=r,this.reset()}reset(){this.enabled=!1,this.clients=null,this.indices=null,this.activeView=null}clear(){this.indices&&(this.mc.cancel(Array.from(this.indices.values(),t=>t.result)),this.indices=null)}index(t,n){if(this.clients!==t){let l=Array.from(t,$B),u=l[0]?.from;this.enabled=l.every(f=>f&&f.from===u),this.clients=t,this.activeView=null,this.clear()}if(!this.enabled)return!1;n=n||this.selection.active;let{source:r}=n;if(r&&r===this.activeView?.source)return!0;if(this.clear(),!r)return!1;let i=this.activeView=cV(n);if(!i)return!1;this.mc.logger().warn("DATA CUBE INDEX CONSTRUCTION");let o=this.selection.remove(r),s=this.indices=new Map,{mc:a,temp:c}=this;for(let l of t){if(o.skip(l,n))continue;let u=$B(l),f=l.query(o.predicate(l)).select({...i.columns,...u.count}).groupby(Object.keys(i.columns)),[d]=f.subqueries;if(d){let x=Object.values(i.columns).map(b=>b.columns[0]);uV(d,x)}let h=f.orderby();f.query.orderby=[];let p=f.toString(),g=`cube_index_${(FB(p)>>>0).toString(16)}`,y=a.exec(ao(g,p,{temp:c}));s.set(l,{table:g,result:y,order:h,...u})}}async update(){let{clients:t,selection:n,activeView:r}=this,i=r.predicate(n.active.predicate);return Promise.all(Array.from(t).map(o=>this.updateClient(o,i)))}async updateClient(t,n){let r=this.indices.get(t);if(!r)return;n||(n=this.activeView.predicate(this.selection.active.predicate));let{table:i,dims:o,aggr:s,order:a=[]}=r,c=ht.select(o,s).from(i).groupby(o).where(n).orderby(a);return this.mc.updateClient(t,c)}};function cV(e){let{source:t,schema:n}=e,r=e.predicate?.columns;if(!n||!r)return null;let{type:i,scales:o,pixelSize:s=1}=n,a;if(i==="interval"&&o){let c=o.map(l=>lV(l,s));if(c.some(l=>l==null))return null;c.length===1?(a=l=>l?Ae("active0",l.range.map(c[0])):[],r={active0:c[0](e.predicate.field)}):(a=l=>l?Wn(l.children.map(({range:u},f)=>Ae(`active${f}`,u.map(c[f])))):[],r=Object.fromEntries(e.predicate.children.map((l,u)=>[`active${u}`,c[u](l.field)])))}else if(i==="point")a=c=>c,r=Object.fromEntries(r.map(c=>[c.toString(),c]));else return null;return{source:t,columns:r,predicate:a}}function lV(e,t){let{apply:n,sqlApply:r}=Yh(e);if(n){let{domain:i,range:o}=e,s=n(Math.min(...i)),a=n(Math.max(...i)),c=Math.abs(o[1]-o[0])/(a-s)/t,l=t===1?"":`${t}::INTEGER * `;return u=>q`${l}FLOOR(${c}::DOUBLE * (${r(u)} - ${s}::DOUBLE))::INTEGER`}}var RB={from:NaN};function $B(e){if(!e.filterIndexable)return RB;let t=e.query(),n=LS(t);if(!n||!t.groupby)return RB;let r=new Set(t.groupby().map(a=>a.column)),i=[],o=[],s;for(let{as:a,expr:{aggregate:c}}of t.select())switch(c?.toUpperCase?.()){case"COUNT":case"SUM":i.push({[a]:q`SUM("${a}")::DOUBLE`});break;case"AVG":s="_count_",i.push({[a]:q`(SUM("${a}" * ${s}) / SUM(${s}))::DOUBLE`});break;case"MAX":i.push({[a]:q`MAX("${a}")`});break;case"MIN":i.push({[a]:q`MIN("${a}")`});break;default:if(r.has(a))o.push(a);else return null}return{aggr:i,dims:o,count:s?{[s]:q`COUNT(*)`}:{},from:n}}function LS(e){let t=e.subqueries;if(e.select){let r=e.from();if(!r.length)return;if(t.length===0)return r[0].from.table}let n=LS(t[0]);for(let r=1;r<t.length;++r){let i=LS(t[r]);if(i!==void 0&&i!==n)return NaN}return n}function uV(e,t){let n=new Set,r=i=>{n.has(i)||(n.add(i),i.select&&i.from().length&&i.select(t),i.subqueries.forEach(r))};r(e)}var j0=class{constructor(t,n,r=!0){this.mc=t,this.selection=n,this.clients=new Set,this.indexer=r?new q0(this.mc,{...r,selection:n}):null;let{value:i,activate:o}=this.handlers={value:()=>this.update(),activate:s=>this.indexer?.index(this.clients,s)};n.addEventListener("value",i),n.addEventListener("activate",o)}finalize(){let{value:t,activate:n}=this.handlers;this.selection.removeEventListener("value",t),this.selection.removeEventListener("activate",n)}reset(){this.indexer?.reset()}add(t){return(this.clients=new Set(this.clients)).add(t),this}remove(t){return this.clients.has(t)&&(this.clients=new Set(this.clients)).delete(t),this}update(){let{mc:t,indexer:n,clients:r,selection:i}=this;return n?.index(r)?n.update():fV(t,r,i)}};function fV(e,t,n){return Promise.all(Array.from(t).map(r=>{let i=n.predicate(r);if(i!=null)return e.updateClient(r,r.query(i))}))}function V0(){let e,t,n=new Promise((r,i)=>{e=r,t=i});return n.fulfill=r=>(e(r),n),n.reject=r=>(t(r),n),n}function dV(e){return(typeof requestAnimationFrame<"u"?requestAnimationFrame:typeof setImmediate<"u"?setImmediate:setTimeout)(e)}function PB(e,t,n){let r=[],i=0;function o(){let s=hV(r,t);r=[],i=0;for(let a of s)mV(a,e,n),xV(a,t)}return{add(s,a){s.request.type==="arrow"?(i=i||dV(()=>o()),r.push({entry:s,priority:a,index:r.length})):e(s,a)}}}function hV(e,t){let n=[],r=new Map;for(let i of e){let{entry:{request:o}}=i,s=pV(o.query,t);if(!r.has(s)){let a=[];n.push(a),r.set(s,a)}r.get(s).push(i)}return n}function pV(e,t){let n=`${e}`;if(e instanceof ht&&!t.get(n)){if(e.orderby().length||e.where().length||e.qualify().length||e.having().length)return n;let r=e.clone().$select("*"),i=e.groupby();if(i.length){let o={};e.select().forEach(({as:s,expr:a})=>o[s]=a),r.$groupby(i.map(s=>s instanceof xr&&o[s.column]||s))}return`${r}`}else return n}function mV(e,t,n){if(yV(e))t({request:{type:"arrow",cache:!1,record:!1,query:e.query=gV(e,n)},result:e.result=V0()});else for(let{entry:r,priority:i}of e)t(r,i)}function yV(e){if(e.length>1){let t=`${e[0].entry.request.query}`;for(let n=1;n<e.length;++n)if(t!==`${e[n].entry.request.query}`)return!0}return!1}function gV(e,t){let n=e.maps=[],r=new Map;for(let s of e){let{query:a}=s.entry.request,c=[];n.push(c);for(let{as:l,expr:u}of a.select()){let f=`${u}`;r.has(f)||r.set(f,[`col${r.size}`,u]);let[d]=r.get(f);c.push([d,l])}t(`${a}`)}let i=e[0].entry.request.query.clone(),o=i.groupby();if(o.length){let s={};e.maps[0].forEach(([a,c])=>s[c]=a),i.$groupby(o.map(a=>a instanceof xr&&s[a.column]||a))}return i.$select(Array.from(r.values()))}async function xV(e,t){let{maps:n,query:r,result:i}=e;if(!n)return;let o;try{o=await i}catch(a){for(let{entry:c}of e)c.result.reject(a);return}let s=AS(r);e.forEach(({entry:a},c)=>{let{request:l,result:u}=a,f=n[c],d=s&&f?wV(o,f):f?bV(o,f):o;l.cache&&t.set(String(l.query),d),u.fulfill(d)})}function bV(e,t){let n={};for(let[r,i]of t)n[i]=e.getChild(r);return new e.constructor(n)}function wV(e,t){let n=new Map(t),r=[];for(let i of e)n.has(i.column_name)&&r.push({...i,column_name:n.get(i.column_name)});return r}var vV=typeof requestIdleCallback<"u"?requestIdleCallback:setTimeout,UB=()=>({get:()=>{},set:(e,t)=>t,clear:()=>{}});function zB({max:e=1e3,ttl:t=3*60*60*1e3}={}){let n=new Map;function r(){let i=performance.now()-t,o=null,s=1/0;for(let[a,c]of n){let{last:l}=c;l<s&&(o=a,s=l),i>l&&n.delete(a)}o&&n.delete(o)}return{get(i){let o=n.get(i);if(o)return o.last=performance.now(),o.value},set(i,o){return n.set(i,{last:performance.now(),value:o}),n.size>e&&vV(r),o},clear(){n=new Map}}}function qB(e){let t=Array.from({length:e},()=>({head:null,tail:null}));return{isEmpty(){return t.every(n=>!n.head)},insert(n,r){let i=t[r];if(!i)throw new Error(`Invalid queue priority rank: ${r}`);let o={item:n,next:null};i.head===null?i.head=i.tail=o:i.tail=i.tail.next=o},remove(n){for(let r of t){let{head:i,tail:o}=r;for(let s=null,a=i;a;s=a,a=a.next)n(a.item)&&(a===i?i=a.next:s.next=a.next,a===o&&(o=s||i));r.head=i,r.tail=o}},next(){for(let n of t){let{head:r}=n;if(r!==null)return n.head=r.next,n.tail===r&&(n.tail=null),r.item}}}}var co={High:0,Normal:1,Low:2};function jB(){let e=qB(3),t,n,r,i=[],o=null,s;function a(){if(o||e.isEmpty())return;let{request:f,result:d}=e.next();o=u(f,d),o.finally(()=>{o=null,a()})}function c(f,d=co.Normal){e.insert(f,d),a()}function l(f){i.length&&f&&i.forEach(d=>d.add(f))}async function u(f,d){try{let{query:h,type:p,cache:m=!1,record:g=!0,options:y}=f,x=h?`${h}`:null;if(g&&l(x),m){let v=n.get(x);if(v){r.debug("Cache"),d.fulfill(v);return}}let b=performance.now(),w=await t.query({type:p,sql:x,...y});m&&n.set(x,w),r.debug(`Request: ${(performance.now()-b).toFixed(1)}`),d.fulfill(w)}catch(h){d.reject(h)}}return{cache(f){return f!==void 0?n=f===!0?zB():f||UB():n},logger(f){return f?r=f:r},connector(f){return f?t=f:t},consolidate(f){f&&!s?s=PB(c,n,l):!f&&s&&(s=null)},request(f,d=co.Normal){let h=V0(),p={request:f,result:h};return s?s.add(p,d):c(p,d),h},cancel(f){let d=new Set(f);e.remove(({result:h})=>d.has(h))},clear(){e.remove(({result:f})=>(f.reject("Cleared"),!0))},record(){let f=[],d={add(h){f.push(h)},reset(){f=[]},snapshot(){return f.slice()},stop(){return i=i.filter(h=>h!==d),f}};return i.push(d),d}}}function CS(e){switch(e){case"BIGINT":case"HUGEINT":case"INTEGER":case"SMALLINT":case"TINYINT":case"UBIGINT":case"UINTEGER":case"USMALLINT":case"UTINYINT":case"DOUBLE":case"FLOAT":case"REAL":return"number";case"DATE":case"TIMESTAMP":case"TIMESTAMPTZ":case"TIMESTAMP WITH TIME ZONE":case"TIME":case"TIMESTAMP_NS":return"date";case"BOOLEAN":return"boolean";case"VARCHAR":case"UUID":return"string";case"ARRAY":case"LIST":return"array";case"BLOB":case"STRUCT":case"MAP":case"GEOMETRY":return"object";default:if(e.startsWith("DECIMAL"))return"number";if(e.startsWith("STRUCT")||e.startsWith("MAP"))return"object";if(e.endsWith("]"))return"array";throw new Error(`Unsupported type: ${e}`)}}function Su(e){return typeof e?.getChild=="function"}function kS(e){switch(e.typeId){case 2:case 3:case 7:return Float64Array;default:return Array}}function Gh(e){let{typeId:t}=e;if(t===10)return n=>n==null?n:new Date(n);if(t===2&&e.bitWidth>=64)return n=>n==null?n:Number(n);if(t===7){let n=1/Math.pow(10,e.scale);return r=>r==null?r:YB(r,n)}return n=>n}function Iu(e){let{type:t}=e,{typeId:n}=t;if(n===10){let r=e.length,i=new Array(r);for(let o=0;o<r;++o){let s=e.get(o);i[o]=s==null?null:new Date(s)}return i}if(n===2&&t.bitWidth>=64){let r=e.length,i=new Float64Array(r);for(let o=0;o<r;++o){let s=e.get(o);i[o]=s==null?NaN:Number(s)}return i}if(n===7){let r=1/Math.pow(10,t.scale),i=e.length,o=new Float64Array(i);for(let s=0;s<i;++s){let a=e.get(s);o[s]=a==null?NaN:YB(a,r)}return o}return e.toArray()}var VB=Array.from({length:8},(e,t)=>Math.pow(2,t*32));function YB(e,t){let n=e.length,r=0;if(e.signed&&(e[n-1]|0)<0){for(let i=0;i<n;++i)r+=~(e[i]|0)*VB[i];r=-(r+1)}else for(let i=0;i<n;++i)r+=e[i]*VB[i];return r*t}var _V="count",SV="nulls",IV="max",MV="min",AV="distinct";var TV={[_V]:kr,[AV]:e=>kr(e).distinct(),[IV]:ti,[MV]:ei,[SV]:e=>kr().where(Uc(e))};function EV(e,t,n){return ht.from(e).select(Array.from(n,r=>[r,TV[r](t)]))}async function XB(e,t){return t.length===1&&`${t[0].column}`=="*"?DV(e,t[0].table):(await Promise.all(t.map(n=>NV(e,n)))).filter(n=>n)}async function NV(e,{table:t,column:n,stats:r}){let i=ht.from({source:t}).select({column:n}).groupby(n.aggregate?q`ALL`:[]),[o]=Array.from(await e.query(ht.describe(i))),s={table:t,column:`${n}`,sqlType:o.column_type,type:CS(o.column_type),nullable:o.null==="YES"};if(!(r?.length||r?.size))return s;let a=await e.query(EV(t,n,r),{persist:!0});for(let c=0;c<a.numCols;++c){let{name:l}=a.schema.fields[c],u=a.getChildAt(c),f=Gh(u.type);s[l]=f(u.get(0))}return s}async function DV(e,t){let n=await e.query(`DESCRIBE ${$c(t)}`);return Array.from(n).map(r=>({table:t,column:r.column_name,sqlType:r.column_type,type:CS(r.column_type),nullable:r.null==="YES"}))}function GB(){return{debug(){},info(){},log(){},warn(){},error(){}}}var Y0;function ni(e){return e?Y0=e:Y0==null&&(Y0=new Wh),Y0}var Wh=class{constructor(t=R0(),n={}){let{logger:r=console,manager:i=jB()}=n;this.manager=i,this.logger(r),this.configure(n),this.databaseConnector(t),this.clear()}logger(t){return arguments.length&&(this._logger=t||GB(),this.manager.logger(this._logger)),this._logger}configure({cache:t=!0,consolidate:n=!0,indexes:r=!0}){this.manager.cache(t),this.manager.consolidate(n),this.indexes=r}clear({clients:t=!0,cache:n=!0}={}){this.manager.clear(),t&&(this.clients?.forEach(r=>this.disconnect(r)),this.filterGroups?.forEach(r=>r.finalize()),this.clients=new Set,this.filterGroups=new Map),n&&this.manager.cache().clear()}databaseConnector(t){return this.manager.connector(t)}cancel(t){this.manager.cancel(t)}exec(t,{priority:n=co.Normal}={}){return t=Array.isArray(t)?t.join(`;
|
|
11
|
-
`):t,this.manager.request({type:"exec",query:t},n)}query(t,{type:n="arrow",cache:r=!0,priority:i=co.Normal,...o}={}){return this.manager.request({type:n,query:t,cache:r,options:o},i)}prefetch(t,n={}){return this.query(t,{...n,cache:!0,priority:co.Low})}createBundle(t,n,r=co.Low){let i={name:t,queries:n};return this.manager.request({type:"create-bundle",options:i},r)}loadBundle(t,n=co.High){let r={name:t};return this.manager.request({type:"load-bundle",options:r},n)}updateClient(t,n,r=co.Normal){return t.queryPending(),this.query(n,{priority:r}).then(i=>t.queryResult(i).update(),i=>{t.queryError(i),this._logger.error(i)})}requestQuery(t,n){return this.filterGroups.get(t.filterBy)?.reset(),n?this.updateClient(t,n):t.update()}async connect(t){let{clients:n,filterGroups:r,indexes:i}=this;if(n.has(t))throw new Error("Client already connected.");n.add(t),t.coordinator=this;let o=t.fields();o?.length&&t.fieldInfo(await XB(this,o));let s=t.filterBy;if(s)if(r.has(s))r.get(s).add(t);else{let a=new j0(this,s,i);r.set(s,a.add(t))}t.requestQuery()}disconnect(t){let{clients:n,filterGroups:r}=this;n.has(t)&&(n.delete(t),r.get(t.filterBy)?.remove(t),t.coordinator=null)}};var X0=class{constructor(){this._callbacks=new Map}addEventListener(t,n){this._callbacks.has(t)||this._callbacks.set(t,{callbacks:new Set,pending:null,queue:new FS}),this._callbacks.get(t).callbacks.add(n)}removeEventListener(t,n){let r=this._callbacks.get(t);r&&r.callbacks.delete(n)}willEmit(t,n){return n}emitQueueFilter(){return null}cancel(t){this._callbacks.get(t)?.queue.clear()}emit(t,n){let r=this._callbacks.get(t)||{};if(r.pending)r.queue.enqueue(n,this.emitQueueFilter(t,n));else{let i=this.willEmit(t,n),{callbacks:o,queue:s}=r;if(o?.size){let a=Promise.allSettled(Array.from(o,c=>c(i))).then(()=>{r.pending=null,s.isEmpty()||this.emit(t,s.dequeue())});r.pending=a}}}},FS=class{constructor(){this.clear()}clear(){this.next=null}isEmpty(){return!this.next}enqueue(t,n){let r={value:t};if(n&&this.next){let i=this;for(;i.next;)n(i.next.value)?i=i.next:i.next=i.next.next;i.next=r}else this.next=r}dequeue(){let{next:t}=this;return this.next=t?.next,t?.value}};function Hh(e,t){return e===t?!1:e instanceof Date&&t instanceof Date?+e!=+t:Array.isArray(e)&&Array.isArray(t)?OV(e,t):!0}function OV(e,t){if(e.length!==t.length)return!0;for(let n=0;n<e.length;++n)if(e[n]!==t[n])return!0;return!1}function br(e){return e instanceof Ta}var Ta=class e extends X0{constructor(t){super(),this._value=t}static value(t){return new e(t)}static array(t){if(t.some(n=>br(n))){let n=new e,r=()=>n.update(t.map(i=>br(i)?i.value:i));return r(),t.forEach(i=>br(i)?i.addEventListener("value",r):0),n}return new e(t)}get value(){return this._value}update(t,{force:n}={}){return Hh(this._value,t)||n?this.emit("value",t):this.cancel("value"),this}willEmit(t,n){return t==="value"&&(this._value=n),n}};function ri(e){return e instanceof Ms}var Ms=class e extends Ta{static intersect({cross:t=!1}={}){return new e(new Vc({cross:t}))}static union({cross:t=!1}={}){return new e(new Vc({cross:t,union:!0}))}static single({cross:t=!1}={}){return new e(new Vc({cross:t,single:!0}))}static crossfilter(){return new e(new Vc({cross:!0}))}constructor(t=new Vc){super([]),this._resolved=this._value,this._resolver=t}clone(){let t=new e(this._resolver);return t._value=t._resolved=this._value,t}remove(t){let n=this.clone();return n._value=n._resolved=n._resolver.resolve(this._resolved,{source:t}),n._value.active={source:t},n}get active(){return this.clauses.active}get value(){return this.active?.value}get clauses(){return super.value}get single(){return this._resolver.single}activate(t){this.emit("activate",t)}update(t){return this._resolved=this._resolver.resolve(this._resolved,t,!0),this._resolved.active=t,super.update(this._resolved)}willEmit(t,n){return t==="value"?(this._value=n,this.value):n}emitQueueFilter(t,n){return t==="value"?this._resolver.queueFilter(n):null}skip(t,n){return this._resolver.skip(t,n)}predicate(t,n=!1){let{clauses:r}=this,i=n?null:r.active;return this._resolver.predicate(r,i,t)}},Vc=class{constructor({union:t,cross:n,single:r}={}){this.union=!!t,this.cross=!!n,this.single=!!r}resolve(t,n,r=!1){let{source:i,predicate:o}=n,s=t.filter(c=>i!==c.source),a=this.single?[]:s;return this.single&&r&&s.forEach(c=>c.source?.reset?.()),o&&a.push(n),a}skip(t,n){return this.cross&&n?.clients?.has(t)}predicate(t,n,r){let{union:i}=this;if(this.skip(r,n))return;let o=t.filter(s=>!this.skip(r,s)).map(s=>s.predicate);return i&&o.length>1?Pc(o):o}queueFilter(t){if(this.cross){let n=t.active?.source;return r=>r.active?.source!==n}}};function RS(){let e=new Set,t,n=new Promise(r=>t=r);return{pending(r){e.add(r)},ready(r){return e.delete(r),e.size===0},resolve(){n=new Promise(r=>{t(),t=r})},get promise(){return n}}}var mD={};Ir(mD,{Fixed:()=>lo,Param:()=>Ta,Query:()=>ht,Selection:()=>Ms,agg:()=>G2,align:()=>f6,and:()=>Wn,area:()=>j8,areaX:()=>V8,areaY:()=>Y8,argmax:()=>vu,argmin:()=>wu,arrayAgg:()=>xS,arrow:()=>FN,aspectRatio:()=>d6,avg:()=>W2,axis:()=>h6,axisFx:()=>zN,axisFy:()=>qN,axisX:()=>PN,axisY:()=>UN,barX:()=>H8,barY:()=>Z8,bin:()=>Uv,cast:()=>zh,castDouble:()=>_u,castInteger:()=>bS,cell:()=>J8,cellX:()=>Q8,cellY:()=>K8,centroid:()=>jh,centroidX:()=>IS,centroidY:()=>MS,circle:()=>sN,colorBase:()=>QE,colorClamp:()=>zE,colorConstant:()=>t8,colorDomain:()=>PE,colorExponent:()=>KE,colorInterpolate:()=>YE,colorLabel:()=>WE,colorLegend:()=>dD,colorN:()=>qE,colorNice:()=>jE,colorPivot:()=>XE,colorRange:()=>UE,colorReverse:()=>HE,colorScale:()=>$E,colorScheme:()=>VE,colorSymmetric:()=>GE,colorTickFormat:()=>JE,colorZero:()=>ZE,column:()=>Ia,contour:()=>IN,coordinator:()=>ni,corr:()=>aS,count:()=>kr,covarPop:()=>cS,create:()=>ao,cume_dist:()=>P2,dateDay:()=>SS,dateMonth:()=>vS,dateMonthDay:()=>_S,delaunayLink:()=>LN,delaunayMesh:()=>CN,denseLine:()=>SN,dense_rank:()=>R2,density:()=>_N,densityX:()=>wN,densityY:()=>vN,dot:()=>rN,dotX:()=>iN,dotY:()=>oN,entropy:()=>iS,eq:()=>_s,facetGrid:()=>F4,facetLabel:()=>R4,facetMargin:()=>O4,facetMarginBottom:()=>L4,facetMarginLeft:()=>C4,facetMarginRight:()=>k4,facetMarginTop:()=>B4,first:()=>mS,first_value:()=>j2,frame:()=>$N,from:()=>gU,fxAlign:()=>Y4,fxAriaDescription:()=>lE,fxAriaLabel:()=>cE,fxAxis:()=>H4,fxDomain:()=>$4,fxFontVariant:()=>aE,fxGrid:()=>nE,fxInset:()=>z4,fxInsetLeft:()=>q4,fxInsetRight:()=>j4,fxLabel:()=>iE,fxLabelAnchor:()=>oE,fxLabelOffset:()=>sE,fxLine:()=>rE,fxNice:()=>U4,fxPadding:()=>X4,fxPaddingInner:()=>G4,fxPaddingOuter:()=>W4,fxRange:()=>P4,fxReverse:()=>uE,fxRound:()=>V4,fxTickFormat:()=>tE,fxTickPadding:()=>K4,fxTickRotate:()=>eE,fxTickSize:()=>J4,fxTickSpacing:()=>Q4,fxTicks:()=>Z4,fyAlign:()=>xE,fyAriaDescription:()=>FE,fyAriaLabel:()=>kE,fyAxis:()=>_E,fyDomain:()=>fE,fyFontVariant:()=>CE,fyGrid:()=>NE,fyInset:()=>pE,fyInsetBottom:()=>yE,fyInsetTop:()=>mE,fyLabel:()=>OE,fyLabelAnchor:()=>BE,fyLabelOffset:()=>LE,fyLine:()=>DE,fyNice:()=>hE,fyPadding:()=>bE,fyPaddingInner:()=>wE,fyPaddingOuter:()=>vE,fyRange:()=>dE,fyReverse:()=>RE,fyRound:()=>gE,fyTickFormat:()=>TE,fyTickPadding:()=>AE,fyTickRotate:()=>EE,fyTickSize:()=>IE,fyTickSpacing:()=>ME,fyTicks:()=>SE,geo:()=>GN,geojson:()=>qh,graticule:()=>HN,grid:()=>m6,gridFx:()=>YN,gridFy:()=>XN,gridX:()=>jN,gridY:()=>VN,gt:()=>$h,gte:()=>E2,hconcat:()=>fU,heatmap:()=>MN,height:()=>s6,hexagon:()=>aN,hexbin:()=>EN,hexgrid:()=>NN,highlight:()=>ZN,hspace:()=>pU,hull:()=>kN,image:()=>bN,inset:()=>p6,intervalX:()=>nD,intervalXY:()=>iD,intervalY:()=>rD,isBetween:()=>Ae,isDistinct:()=>N2,isNotBetween:()=>D2,isNotDistinct:()=>Ph,isNotNull:()=>vs,isNull:()=>Uc,kurtosis:()=>rS,label:()=>y6,lag:()=>z2,last:()=>yS,last_value:()=>V2,lead:()=>q2,lengthBase:()=>E8,lengthClamp:()=>M8,lengthConstant:()=>D8,lengthDomain:()=>S8,lengthExponent:()=>N8,lengthNice:()=>A8,lengthRange:()=>I8,lengthScale:()=>_8,lengthZero:()=>T8,line:()=>X8,lineX:()=>G8,lineY:()=>W8,link:()=>RN,literal:()=>Cr,loadCSV:()=>ES,loadExtension:()=>Xh,loadJSON:()=>NS,loadObjects:()=>BS,loadParquet:()=>DS,loadSpatial:()=>OS,lt:()=>Ss,lte:()=>Is,mad:()=>H2,margin:()=>n6,marginBottom:()=>u6,marginLeft:()=>a6,marginRight:()=>c6,marginTop:()=>l6,margins:()=>e6,max:()=>ti,median:()=>J2,menu:()=>oU,min:()=>ei,mode:()=>K2,name:()=>K3,nearestX:()=>tD,nearestY:()=>eD,neq:()=>zc,not:()=>T2,nth_value:()=>Y2,ntile:()=>U2,opacityBase:()=>u8,opacityClamp:()=>i8,opacityConstant:()=>d8,opacityDomain:()=>n8,opacityExponent:()=>f8,opacityLabel:()=>s8,opacityLegend:()=>hD,opacityNice:()=>o8,opacityRange:()=>r8,opacityReverse:()=>a8,opacityScale:()=>e8,opacityTickFormat:()=>l8,opacityZero:()=>c8,or:()=>Pc,padding:()=>g6,pan:()=>oD,panX:()=>sD,panY:()=>aD,panZoom:()=>cD,panZoomX:()=>lD,panZoomY:()=>uD,percent_rank:()=>$2,plot:()=>xU,product:()=>Z2,projectionClip:()=>z8,projectionDomain:()=>k8,projectionInset:()=>F8,projectionInsetBottom:()=>U8,projectionInsetLeft:()=>R8,projectionInsetRight:()=>$8,projectionInsetTop:()=>P8,projectionParallels:()=>B8,projectionPrecision:()=>L8,projectionRotate:()=>C8,projectionType:()=>O8,quantile:()=>Q2,rBase:()=>b8,rClamp:()=>y8,rConstant:()=>v8,rDomain:()=>p8,rExponent:()=>w8,rNice:()=>g8,rRange:()=>m8,rScale:()=>h8,rZero:()=>x8,rank:()=>F2,raster:()=>AN,rasterTile:()=>TN,rect:()=>tN,rectX:()=>eN,rectY:()=>nN,regressionY:()=>DN,round:()=>x6,row_number:()=>k2,ruleX:()=>fN,ruleY:()=>dN,search:()=>sU,skewness:()=>nS,slider:()=>aU,sphere:()=>WN,spike:()=>xN,sql:()=>q,stddev:()=>eS,stddevPop:()=>sS,stringAgg:()=>gS,style:()=>i6,sum:()=>Fr,symbolLegend:()=>pD,table:()=>cU,text:()=>cN,textX:()=>lN,textY:()=>uN,tickX:()=>hN,tickY:()=>pN,toggle:()=>Sd,toggleColor:()=>KN,toggleX:()=>JN,toggleY:()=>QN,varPop:()=>oS,variance:()=>tS,vconcat:()=>uU,vector:()=>mN,vectorX:()=>yN,vectorY:()=>gN,voronoi:()=>ON,voronoiMesh:()=>BN,vspace:()=>hU,width:()=>o6,xAlign:()=>E6,xAriaDescription:()=>X6,xAriaLabel:()=>Y6,xAxis:()=>B6,xBase:()=>H6,xClamp:()=>A6,xConstant:()=>J6,xDomain:()=>w6,xExponent:()=>Z6,xFontVariant:()=>V6,xGrid:()=>P6,xInset:()=>S6,xInsetLeft:()=>I6,xInsetRight:()=>M6,xLabel:()=>z6,xLabelAnchor:()=>q6,xLabelOffset:()=>j6,xLine:()=>U6,xNice:()=>_6,xPadding:()=>N6,xPaddingInner:()=>D6,xPaddingOuter:()=>O6,xRange:()=>v6,xReverse:()=>G6,xRound:()=>T6,xScale:()=>b6,xTickFormat:()=>R6,xTickPadding:()=>F6,xTickRotate:()=>$6,xTickSize:()=>C6,xTickSpacing:()=>k6,xTicks:()=>L6,xZero:()=>W6,xyDomain:()=>r6,yAlign:()=>a4,yAriaDescription:()=>M4,yAriaLabel:()=>I4,yAxis:()=>f4,yBase:()=>E4,yClamp:()=>o4,yConstant:()=>D4,yDomain:()=>K6,yExponent:()=>N4,yFontVariant:()=>S4,yGrid:()=>x4,yInset:()=>n4,yInsetBottom:()=>i4,yInsetTop:()=>r4,yLabel:()=>w4,yLabelAnchor:()=>v4,yLabelOffset:()=>_4,yLine:()=>b4,yNice:()=>e4,yPadding:()=>c4,yPaddingInner:()=>l4,yPaddingOuter:()=>u4,yRange:()=>t4,yReverse:()=>A4,yRound:()=>s4,yScale:()=>Q6,yTickFormat:()=>y4,yTickPadding:()=>m4,yTickRotate:()=>g4,yTickSize:()=>h4,yTickSpacing:()=>p4,yTicks:()=>d4,yZero:()=>T4});var lo=Symbol("Fixed"),Sn=Symbol("Transient"),Zh=Symbol("Transform");var Dv={};Ir(Dv,{Area:()=>kl,Arrow:()=>ay,BarX:()=>cy,BarY:()=>ly,Cell:()=>Fl,Contour:()=>xy,Density:()=>vy,Dot:()=>Rl,Frame:()=>Km,Geo:()=>_y,Hexgrid:()=>Sy,Image:()=>Iy,Line:()=>$l,Link:()=>oy,Mark:()=>St,Raster:()=>gy,Rect:()=>Ul,RuleX:()=>Wm,RuleY:()=>Hm,Text:()=>Bl,TickX:()=>hy,TickY:()=>py,Tip:()=>ty,Vector:()=>Cl,area:()=>iy,areaX:()=>cc,areaY:()=>aa,arrow:()=>q$,auto:()=>K$,autoSpec:()=>r3,axisFx:()=>Hw,axisFy:()=>Ww,axisX:()=>Jm,axisY:()=>Zm,barX:()=>qo,barY:()=>jo,bin:()=>sa,binX:()=>Uo,binY:()=>zo,bollinger:()=>dc,bollingerX:()=>o9,bollingerY:()=>s9,boxX:()=>a9,boxY:()=>c9,cell:()=>lc,cellX:()=>V$,cellY:()=>Y$,centroid:()=>iP,circle:()=>W$,cluster:()=>rP,column:()=>mn,contour:()=>g9,crosshair:()=>w9,crosshairX:()=>v9,crosshairY:()=>_9,delaunayLink:()=>M9,delaunayMesh:()=>A9,density:()=>O9,differenceY:()=>C9,dodgeX:()=>xP,dodgeY:()=>bP,dot:()=>yi,dotX:()=>X$,dotY:()=>G$,filter:()=>eR,find:()=>uR,formatIsoDate:()=>dT,formatMonth:()=>mR,formatWeekday:()=>yR,frame:()=>Gf,geo:()=>bv,geoCentroid:()=>oP,graticule:()=>F9,gridFx:()=>Kw,gridFy:()=>Jw,gridX:()=>Qw,gridY:()=>Zw,group:()=>Um,groupX:()=>tc,groupY:()=>ec,groupZ:()=>Pm,hexagon:()=>H$,hexbin:()=>R9,hexgrid:()=>$9,hull:()=>T9,identity:()=>G,image:()=>U9,indexOf:()=>Ee,initializer:()=>Ie,interpolateNearest:()=>u3,interpolateNone:()=>xv,interpolatorBarycentric:()=>l3,interpolatorRandomWalk:()=>f3,legend:()=>u$,line:()=>Pl,lineX:()=>uc,lineY:()=>fc,linearRegressionX:()=>j9,linearRegressionY:()=>V9,link:()=>lv,map:()=>vr,mapX:()=>sd,mapY:()=>ad,marks:()=>en,normalize:()=>Ev,normalizeX:()=>SP,normalizeY:()=>IP,plot:()=>ny,pointer:()=>qf,pointerX:()=>jf,pointerY:()=>El,raster:()=>h9,rect:()=>fy,rectX:()=>rd,rectY:()=>id,reverse:()=>nR,ruleX:()=>Yr,ruleY:()=>Xr,scale:()=>Uf,select:()=>AP,selectFirst:()=>B3,selectLast:()=>L3,selectMaxX:()=>NP,selectMaxY:()=>DP,selectMinX:()=>TP,selectMinY:()=>EP,shiftX:()=>MP,shuffle:()=>rR,sort:()=>dw,sphere:()=>k9,spike:()=>V7,stackX:()=>t3,stackX1:()=>L$,stackX2:()=>C$,stackY:()=>e3,stackY1:()=>k$,stackY2:()=>F$,text:()=>Po,textX:()=>zw,textY:()=>qw,tickX:()=>mv,tickY:()=>yv,tip:()=>nv,transform:()=>yn,tree:()=>A3,treeLink:()=>Iv,treeNode:()=>My,valueof:()=>wt,vector:()=>jT,vectorX:()=>Yw,vectorY:()=>Xw,voronoi:()=>E9,voronoiMesh:()=>N9,window:()=>cd,windowX:()=>t9,windowY:()=>e9});function zt(e,t){return e==null||t==null?NaN:e<t?-1:e>t?1:e>=t?0:NaN}function Hn(e,t){return e==null||t==null?NaN:t<e?-1:t>e?1:t>=e?0:NaN}function As(e){let t,n,r;e.length!==2?(t=zt,n=(a,c)=>zt(e(a),c),r=(a,c)=>e(a)-c):(t=e===zt||e===Hn?e:CV,n=e,r=e);function i(a,c,l=0,u=a.length){if(l<u){if(t(c,c)!==0)return u;do{let f=l+u>>>1;n(a[f],c)<0?l=f+1:u=f}while(l<u)}return l}function o(a,c,l=0,u=a.length){if(l<u){if(t(c,c)!==0)return u;do{let f=l+u>>>1;n(a[f],c)<=0?l=f+1:u=f}while(l<u)}return l}function s(a,c,l=0,u=a.length){let f=i(a,c,l,u-1);return f>l&&r(a[f-1],c)>-r(a[f],c)?f-1:f}return{left:i,center:s,right:o}}function CV(){return 0}function Jh(e){return e===null?NaN:+e}function*WB(e,t){if(t===void 0)for(let n of e)n!=null&&(n=+n)>=n&&(yield n);else{let n=-1;for(let r of e)(r=t(r,++n,e))!=null&&(r=+r)>=r&&(yield r)}}var HB=As(zt),ZB=HB.right,kV=HB.left,FV=As(Jh).center,Ts=ZB;var Qh=JB(QB),$S=JB(RV);function JB(e){return function(t,n,r=n){if(!((n=+n)>=0))throw new RangeError("invalid rx");if(!((r=+r)>=0))throw new RangeError("invalid ry");let{data:i,width:o,height:s}=t;if(!((o=Math.floor(o))>=0))throw new RangeError("invalid width");if(!((s=Math.floor(s!==void 0?s:i.length/o))>=0))throw new RangeError("invalid height");if(!o||!s||!n&&!r)return t;let a=n&&e(n),c=r&&e(r),l=i.slice();return a&&c?(Mu(a,l,i,o,s),Mu(a,i,l,o,s),Mu(a,l,i,o,s),Au(c,i,l,o,s),Au(c,l,i,o,s),Au(c,i,l,o,s)):a?(Mu(a,i,l,o,s),Mu(a,l,i,o,s),Mu(a,i,l,o,s)):c&&(Au(c,i,l,o,s),Au(c,l,i,o,s),Au(c,i,l,o,s)),t}}function Mu(e,t,n,r,i){for(let o=0,s=r*i;o<s;)e(t,n,o,o+=r,1)}function Au(e,t,n,r,i){for(let o=0,s=r*i;o<r;++o)e(t,n,o,o+s,r)}function RV(e){let t=QB(e);return(n,r,i,o,s)=>{i<<=2,o<<=2,s<<=2,t(n,r,i+0,o+0,s),t(n,r,i+1,o+1,s),t(n,r,i+2,o+2,s),t(n,r,i+3,o+3,s)}}function QB(e){let t=Math.floor(e);if(t===e)return $V(e);let n=e-t,r=2*e+1;return(i,o,s,a,c)=>{if(!((a-=c)>=s))return;let l=t*o[s],u=c*t,f=u+c;for(let d=s,h=s+u;d<h;d+=c)l+=o[Math.min(a,d)];for(let d=s,h=a;d<=h;d+=c)l+=o[Math.min(a,d+u)],i[d]=(l+n*(o[Math.max(s,d-f)]+o[Math.min(a,d+f)]))/r,l-=o[Math.max(s,d-u)]}}function $V(e){let t=2*e+1;return(n,r,i,o,s)=>{if(!((o-=s)>=i))return;let a=e*r[i],c=s*e;for(let l=i,u=i+c;l<u;l+=s)a+=r[Math.min(o,l)];for(let l=i,u=o;l<=u;l+=s)a+=r[Math.min(o,l+c)],n[l]=a/t,a-=r[Math.max(i,l-c)]}}function uo(e,t){let n=0;if(t===void 0)for(let r of e)r!=null&&(r=+r)>=r&&++n;else{let r=-1;for(let i of e)(i=t(i,++r,e))!=null&&(i=+i)>=i&&++n}return n}function PV(e){return e.length|0}function UV(e){return!(e>0)}function zV(e){return typeof e!="object"||"length"in e?e:Array.from(e)}function qV(e){return t=>e(...t)}function G0(...e){let t=typeof e[e.length-1]=="function"&&qV(e.pop());e=e.map(zV);let n=e.map(PV),r=e.length-1,i=new Array(r+1).fill(0),o=[];if(r<0||n.some(UV))return o;for(;;){o.push(i.map((a,c)=>e[c][a]));let s=r;for(;++i[s]===n[s];){if(s===0)return t?o.map(t):o;i[s--]=0}}}function W0(e,t){var n=0,r=0;return Float64Array.from(e,t===void 0?i=>n+=+i||0:i=>n+=+t(i,r++,e)||0)}function Ea(e,t){let n=0,r,i=0,o=0;if(t===void 0)for(let s of e)s!=null&&(s=+s)>=s&&(r=s-i,i+=r/++n,o+=r*(s-i));else{let s=-1;for(let a of e)(a=t(a,++s,e))!=null&&(a=+a)>=a&&(r=a-i,i+=r/++n,o+=r*(a-i))}if(n>1)return o/(n-1)}function ii(e,t){let n=Ea(e,t);return n&&Math.sqrt(n)}function le(e,t){let n,r;if(t===void 0)for(let i of e)i!=null&&(n===void 0?i>=i&&(n=r=i):(n>i&&(n=i),r<i&&(r=i)));else{let i=-1;for(let o of e)(o=t(o,++i,e))!=null&&(n===void 0?o>=o&&(n=r=o):(n>o&&(n=o),r<o&&(r=o)))}return[n,r]}var In=class{constructor(){this._partials=new Float64Array(32),this._n=0}add(t){let n=this._partials,r=0;for(let i=0;i<this._n&&i<32;i++){let o=n[i],s=t+o,a=Math.abs(t)<Math.abs(o)?t-(s-o):o-(s-t);a&&(n[r++]=a),t=s}return n[r]=t,this._n=r+1,this}valueOf(){let t=this._partials,n=this._n,r,i,o,s=0;if(n>0){for(s=t[--n];n>0&&(r=s,i=t[--n],s=r+i,o=i-(s-r),!o););n>0&&(o<0&&t[n-1]<0||o>0&&t[n-1]>0)&&(i=o*2,r=s+i,i==r-s&&(s=r))}return s}};var Zn=class extends Map{constructor(t,n=e5){if(super(),Object.defineProperties(this,{_intern:{value:new Map},_key:{value:n}}),t!=null)for(let[r,i]of t)this.set(r,i)}get(t){return super.get(PS(this,t))}has(t){return super.has(PS(this,t))}set(t,n){return super.set(KB(this,t),n)}delete(t){return super.delete(t5(this,t))}},Jn=class extends Set{constructor(t,n=e5){if(super(),Object.defineProperties(this,{_intern:{value:new Map},_key:{value:n}}),t!=null)for(let r of t)this.add(r)}has(t){return super.has(PS(this,t))}add(t){return super.add(KB(this,t))}delete(t){return super.delete(t5(this,t))}};function PS({_intern:e,_key:t},n){let r=t(n);return e.has(r)?e.get(r):n}function KB({_intern:e,_key:t},n){let r=t(n);return e.has(r)?e.get(r):(e.set(r,n),n)}function t5({_intern:e,_key:t},n){let r=t(n);return e.has(r)&&(n=e.get(r),e.delete(r)),n}function e5(e){return e!==null&&typeof e=="object"?e.valueOf():e}function Kh(e){return e}function cn(e,...t){return zS(e,Kh,Kh,t)}function $i(e,t,...n){return zS(e,Kh,t,n)}function US(e,t,...n){return zS(e,Array.from,t,n)}function zS(e,t,n,r){return function i(o,s){if(s>=r.length)return n(o);let a=new Zn,c=r[s++],l=-1;for(let u of o){let f=c(u,++l,o),d=a.get(f);d?d.push(u):a.set(f,[u])}for(let[u,f]of a)a.set(u,i(f,s));return t(a)}(e,0)}function qS(e,t){return Array.from(t,n=>e[n])}function fo(e,...t){if(typeof e[Symbol.iterator]!="function")throw new TypeError("values is not iterable");e=Array.from(e);let[n]=t;if(n&&n.length!==2||t.length>1){let r=Uint32Array.from(e,(i,o)=>o);return t.length>1?(t=t.map(i=>e.map(i)),r.sort((i,o)=>{for(let s of t){let a=Yc(s[i],s[o]);if(a)return a}})):(n=e.map(n),r.sort((i,o)=>Yc(n[i],n[o]))),qS(e,r)}return e.sort(tp(n))}function tp(e=zt){if(e===zt)return Yc;if(typeof e!="function")throw new TypeError("compare is not a function");return(t,n)=>{let r=e(t,n);return r||r===0?r:(e(n,n)===0)-(e(t,t)===0)}}function Yc(e,t){return(e==null||!(e>=e))-(t==null||!(t>=t))||(e<t?-1:e>t?1:0)}function Tu(e,t,n){return(t.length!==2?fo($i(e,t,n),([r,i],[o,s])=>zt(i,s)||zt(r,o)):fo(cn(e,n),([r,i],[o,s])=>t(i,s)||zt(r,o))).map(([r])=>r)}var jV=Math.sqrt(50),VV=Math.sqrt(10),YV=Math.sqrt(2);function H0(e,t,n){let r=(t-e)/Math.max(0,n),i=Math.floor(Math.log10(r)),o=r/Math.pow(10,i),s=o>=jV?10:o>=VV?5:o>=YV?2:1,a,c,l;return i<0?(l=Math.pow(10,-i)/s,a=Math.round(e*l),c=Math.round(t*l),a/l<e&&++a,c/l>t&&--c,l=-l):(l=Math.pow(10,i)*s,a=Math.round(e/l),c=Math.round(t/l),a*l<e&&++a,c*l>t&&--c),c<a&&.5<=n&&n<2?H0(e,t,n*2):[a,c,l]}function Mn(e,t,n){if(t=+t,e=+e,n=+n,!(n>0))return[];if(e===t)return[e];let r=t<e,[i,o,s]=r?H0(t,e,n):H0(e,t,n);if(!(o>=i))return[];let a=o-i+1,c=new Array(a);if(r)if(s<0)for(let l=0;l<a;++l)c[l]=(o-l)/-s;else for(let l=0;l<a;++l)c[l]=(o-l)*s;else if(s<0)for(let l=0;l<a;++l)c[l]=(i+l)/-s;else for(let l=0;l<a;++l)c[l]=(i+l)*s;return c}function Es(e,t,n){return t=+t,e=+e,n=+n,H0(e,t,n)[2]}function Eu(e,t,n){t=+t,e=+e,n=+n;let r=t<e,i=r?Es(t,e,n):Es(e,t,n);return(r?-1:1)*(i<0?1/-i:i)}function Nu(e,t,n){let r;for(;;){let i=Es(e,t,n);if(i===r||i===0||!isFinite(i))return[e,t];i>0?(e=Math.floor(e/i)*i,t=Math.ceil(t/i)*i):i<0&&(e=Math.ceil(e*i)/i,t=Math.floor(t*i)/i),r=i}}function Na(e){return Math.max(1,Math.ceil(Math.log(uo(e))/Math.LN2)+1)}function Wt(e,t){let n;if(t===void 0)for(let r of e)r!=null&&(n<r||n===void 0&&r>=r)&&(n=r);else{let r=-1;for(let i of e)(i=t(i,++r,e))!=null&&(n<i||n===void 0&&i>=i)&&(n=i)}return n}function Z0(e,t){let n,r=-1,i=-1;if(t===void 0)for(let o of e)++i,o!=null&&(n<o||n===void 0&&o>=o)&&(n=o,r=i);else for(let o of e)(o=t(o,++i,e))!=null&&(n<o||n===void 0&&o>=o)&&(n=o,r=i);return r}function ue(e,t){let n;if(t===void 0)for(let r of e)r!=null&&(n>r||n===void 0&&r>=r)&&(n=r);else{let r=-1;for(let i of e)(i=t(i,++r,e))!=null&&(n>i||n===void 0&&i>=i)&&(n=i)}return n}function J0(e,t){let n,r=-1,i=-1;if(t===void 0)for(let o of e)++i,o!=null&&(n>o||n===void 0&&o>=o)&&(n=o,r=i);else for(let o of e)(o=t(o,++i,e))!=null&&(n>o||n===void 0&&o>=o)&&(n=o,r=i);return r}function Q0(e,t,n=0,r=1/0,i){if(t=Math.floor(t),n=Math.floor(Math.max(0,n)),r=Math.floor(Math.min(e.length-1,r)),!(n<=t&&t<=r))return e;for(i=i===void 0?Yc:tp(i);r>n;){if(r-n>600){let c=r-n+1,l=t-n+1,u=Math.log(c),f=.5*Math.exp(2*u/3),d=.5*Math.sqrt(u*f*(c-f)/c)*(l-c/2<0?-1:1),h=Math.max(n,Math.floor(t-l*f/c+d)),p=Math.min(r,Math.floor(t+(c-l)*f/c+d));Q0(e,t,h,p,i)}let o=e[t],s=n,a=r;for(ep(e,n,t),i(e[r],o)>0&&ep(e,n,r);s<a;){for(ep(e,s,a),++s,--a;i(e[s],o)<0;)++s;for(;i(e[a],o)>0;)--a}i(e[n],o)===0?ep(e,n,a):(++a,ep(e,a,r)),a<=t&&(n=a+1),t<=a&&(r=a-1)}return e}function ep(e,t,n){let r=e[t];e[t]=e[n],e[n]=r}function Xc(e,t=zt){let n,r=!1;if(t.length===1){let i;for(let o of e){let s=t(o);(r?zt(s,i)>0:zt(s,s)===0)&&(n=o,i=s,r=!0)}}else for(let i of e)(r?t(i,n)>0:t(i,i)===0)&&(n=i,r=!0);return n}function Qn(e,t,n){if(e=Float64Array.from(WB(e,n)),!(!(r=e.length)||isNaN(t=+t))){if(t<=0||r<2)return ue(e);if(t>=1)return Wt(e);var r,i=(r-1)*t,o=Math.floor(i),s=Wt(Q0(e,o).subarray(0,o+1)),a=ue(e.subarray(o+1));return s+(a-s)*(i-o)}}function jS(e,t,n=Jh){if(!(!(r=e.length)||isNaN(t=+t))){if(t<=0||r<2)return+n(e[0],0,e);if(t>=1)return+n(e[r-1],r-1,e);var r,i=(r-1)*t,o=Math.floor(i),s=+n(e[o],o,e),a=+n(e[o+1],o+1,e);return s+(a-s)*(i-o)}}function K0(e,t,n){let r=uo(e),i=Qn(e,.75)-Qn(e,.25);return r&&i?Math.ceil((n-t)/(2*i*Math.pow(r,-1/3))):1}function np(e,t,n){let r=uo(e),i=ii(e);return r&&i?Math.ceil((n-t)*Math.cbrt(r)/(3.49*i)):1}function Ns(e,t){let n=0,r=0;if(t===void 0)for(let i of e)i!=null&&(i=+i)>=i&&(++n,r+=i);else{let i=-1;for(let o of e)(o=t(o,++i,e))!=null&&(o=+o)>=o&&(++n,r+=o)}if(n)return r/n}function Pi(e,t){return Qn(e,.5,t)}function*GV(e){for(let t of e)yield*t}function Du(e){return Array.from(GV(e))}function Ou(e,t){let n=new Zn;if(t===void 0)for(let o of e)o!=null&&o>=o&&n.set(o,(n.get(o)||0)+1);else{let o=-1;for(let s of e)(s=t(s,++o,e))!=null&&s>=s&&n.set(s,(n.get(s)||0)+1)}let r,i=0;for(let[o,s]of n)s>i&&(i=s,r=o);return r}function tx(e,t=WV){let n=[],r,i=!1;for(let o of e)i&&n.push(t(r,o)),r=o,i=!0;return n}function WV(e,t){return[e,t]}function Ue(e,t,n){e=+e,t=+t,n=(i=arguments.length)<2?(t=e,e=0,1):i<3?1:+n;for(var r=-1,i=Math.max(0,Math.ceil((t-e)/n))|0,o=new Array(i);++r<i;)o[r]=e+r*n;return o}function rp(e,t=zt){if(typeof e[Symbol.iterator]!="function")throw new TypeError("values is not iterable");let n=Array.from(e),r=new Float64Array(n.length);t.length!==2&&(n=n.map(t),t=zt);let i=(a,c)=>t(n[a],n[c]),o,s;return e=Uint32Array.from(n,(a,c)=>c),e.sort(t===zt?(a,c)=>Yc(n[a],n[c]):tp(i)),e.forEach((a,c)=>{let l=i(a,o===void 0?a:o);l>=0?((o===void 0||l>0)&&(o=a,s=c),r[a]=s):r[a]=NaN}),r}function ex(e,t=zt){let n,r=!1;if(t.length===1){let i;for(let o of e){let s=t(o);(r?zt(s,i)<0:zt(s,s)===0)&&(n=o,i=s,r=!0)}}else for(let i of e)(r?t(i,n)<0:t(i,i)===0)&&(n=i,r=!0);return n}function An(e,t){let n=0;if(t===void 0)for(let r of e)(r=+r)&&(n+=r);else{let r=-1;for(let i of e)(i=+t(i,++r,e))&&(n+=i)}return n}function Da(e){if(typeof e[Symbol.iterator]!="function")throw new TypeError("values is not iterable");return Array.from(e).reverse()}function n5(e){return e}var VS=1,YS=2,XS=3,nx=4,r5=1e-6;function HV(e){return"translate("+e+",0)"}function ZV(e){return"translate(0,"+e+")"}function JV(e){return t=>+e(t)}function QV(e,t){return t=Math.max(0,e.bandwidth()-t*2)/2,e.round()&&(t=Math.round(t)),n=>+e(n)+t}function KV(){return!this.__axis}function tY(e,t){var n=[],r=null,i=null,o=6,s=6,a=3,c=typeof window<"u"&&window.devicePixelRatio>1?0:.5,l=e===VS||e===nx?-1:1,u=e===nx||e===YS?"x":"y",f=e===VS||e===XS?HV:ZV;function d(h){var p=r??(t.ticks?t.ticks.apply(t,n):t.domain()),m=i??(t.tickFormat?t.tickFormat.apply(t,n):n5),g=Math.max(o,0)+a,y=t.range(),x=+y[0]+c,b=+y[y.length-1]+c,w=(t.bandwidth?QV:JV)(t.copy(),c),v=h.selection?h.selection():h,_=v.selectAll(".domain").data([null]),I=v.selectAll(".tick").data(p,t).order(),D=I.exit(),A=I.enter().append("g").attr("class","tick"),E=I.select("line"),T=I.select("text");_=_.merge(_.enter().insert("path",".tick").attr("class","domain").attr("stroke","currentColor")),I=I.merge(A),E=E.merge(A.append("line").attr("stroke","currentColor").attr(u+"2",l*o)),T=T.merge(A.append("text").attr("fill","currentColor").attr(u,l*g).attr("dy",e===VS?"0em":e===XS?"0.71em":"0.32em")),h!==v&&(_=_.transition(h),I=I.transition(h),E=E.transition(h),T=T.transition(h),D=D.transition(h).attr("opacity",r5).attr("transform",function(O){return isFinite(O=w(O))?f(O+c):this.getAttribute("transform")}),A.attr("opacity",r5).attr("transform",function(O){var C=this.parentNode.__axis;return f((C&&isFinite(C=C(O))?C:w(O))+c)})),D.remove(),_.attr("d",e===nx||e===YS?s?"M"+l*s+","+x+"H"+c+"V"+b+"H"+l*s:"M"+c+","+x+"V"+b:s?"M"+x+","+l*s+"V"+c+"H"+b+"V"+l*s:"M"+x+","+c+"H"+b),I.attr("opacity",1).attr("transform",function(O){return f(w(O)+c)}),E.attr(u+"2",l*o),T.attr(u,l*g).text(m),v.filter(KV).attr("fill","none").attr("font-size",10).attr("font-family","sans-serif").attr("text-anchor",e===YS?"start":e===nx?"end":"middle"),v.each(function(){this.__axis=w})}return d.scale=function(h){return arguments.length?(t=h,d):t},d.ticks=function(){return n=Array.from(arguments),d},d.tickArguments=function(h){return arguments.length?(n=h==null?[]:Array.from(h),d):n.slice()},d.tickValues=function(h){return arguments.length?(r=h==null?null:Array.from(h),d):r&&r.slice()},d.tickFormat=function(h){return arguments.length?(i=h,d):i},d.tickSize=function(h){return arguments.length?(o=s=+h,d):o},d.tickSizeInner=function(h){return arguments.length?(o=+h,d):o},d.tickSizeOuter=function(h){return arguments.length?(s=+h,d):s},d.tickPadding=function(h){return arguments.length?(a=+h,d):a},d.offset=function(h){return arguments.length?(c=+h,d):c},d}function GS(e){return tY(XS,e)}var eY={value:()=>{}};function o5(){for(var e=0,t=arguments.length,n={},r;e<t;++e){if(!(r=arguments[e]+"")||r in n||/[\s.]/.test(r))throw new Error("illegal type: "+r);n[r]=[]}return new rx(n)}function rx(e){this._=e}function nY(e,t){return e.trim().split(/^|\s+/).map(function(n){var r="",i=n.indexOf(".");if(i>=0&&(r=n.slice(i+1),n=n.slice(0,i)),n&&!t.hasOwnProperty(n))throw new Error("unknown type: "+n);return{type:n,name:r}})}rx.prototype=o5.prototype={constructor:rx,on:function(e,t){var n=this._,r=nY(e+"",n),i,o=-1,s=r.length;if(arguments.length<2){for(;++o<s;)if((i=(e=r[o]).type)&&(i=rY(n[i],e.name)))return i;return}if(t!=null&&typeof t!="function")throw new Error("invalid callback: "+t);for(;++o<s;)if(i=(e=r[o]).type)n[i]=i5(n[i],e.name,t);else if(t==null)for(i in n)n[i]=i5(n[i],e.name,null);return this},copy:function(){var e={},t=this._;for(var n in t)e[n]=t[n].slice();return new rx(e)},call:function(e,t){if((i=arguments.length-2)>0)for(var n=new Array(i),r=0,i,o;r<i;++r)n[r]=arguments[r+2];if(!this._.hasOwnProperty(e))throw new Error("unknown type: "+e);for(o=this._[e],r=0,i=o.length;r<i;++r)o[r].value.apply(t,n)},apply:function(e,t,n){if(!this._.hasOwnProperty(e))throw new Error("unknown type: "+e);for(var r=this._[e],i=0,o=r.length;i<o;++i)r[i].value.apply(t,n)}};function rY(e,t){for(var n=0,r=e.length,i;n<r;++n)if((i=e[n]).name===t)return i.value}function i5(e,t,n){for(var r=0,i=e.length;r<i;++r)if(e[r].name===t){e[r]=eY,e=e.slice(0,r).concat(e.slice(r+1));break}return n!=null&&e.push({name:t,value:n}),e}var Gc=o5;var ix="http://www.w3.org/1999/xhtml",oi={svg:"http://www.w3.org/2000/svg",xhtml:ix,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function Ds(e){var t=e+="",n=t.indexOf(":");return n>=0&&(t=e.slice(0,n))!=="xmlns"&&(e=e.slice(n+1)),oi.hasOwnProperty(t)?{space:oi[t],local:e}:e}function iY(e){return function(){var t=this.ownerDocument,n=this.namespaceURI;return n===ix&&t.documentElement.namespaceURI===ix?t.createElement(e):t.createElementNS(n,e)}}function oY(e){return function(){return this.ownerDocument.createElementNS(e.space,e.local)}}function Os(e){var t=Ds(e);return(t.local?oY:iY)(t)}function sY(){}function Wc(e){return e==null?sY:function(){return this.querySelector(e)}}function s5(e){typeof e!="function"&&(e=Wc(e));for(var t=this._groups,n=t.length,r=new Array(n),i=0;i<n;++i)for(var o=t[i],s=o.length,a=r[i]=new Array(s),c,l,u=0;u<s;++u)(c=o[u])&&(l=e.call(c,c.__data__,u,o))&&("__data__"in c&&(l.__data__=c.__data__),a[u]=l);return new Fe(r,this._parents)}function WS(e){return e==null?[]:Array.isArray(e)?e:Array.from(e)}function aY(){return[]}function ip(e){return e==null?aY:function(){return this.querySelectorAll(e)}}function cY(e){return function(){return WS(e.apply(this,arguments))}}function a5(e){typeof e=="function"?e=cY(e):e=ip(e);for(var t=this._groups,n=t.length,r=[],i=[],o=0;o<n;++o)for(var s=t[o],a=s.length,c,l=0;l<a;++l)(c=s[l])&&(r.push(e.call(c,c.__data__,l,s)),i.push(c));return new Fe(r,i)}function op(e){return function(){return this.matches(e)}}function ox(e){return function(t){return t.matches(e)}}var lY=Array.prototype.find;function uY(e){return function(){return lY.call(this.children,e)}}function fY(){return this.firstElementChild}function c5(e){return this.select(e==null?fY:uY(typeof e=="function"?e:ox(e)))}var dY=Array.prototype.filter;function hY(){return Array.from(this.children)}function pY(e){return function(){return dY.call(this.children,e)}}function l5(e){return this.selectAll(e==null?hY:pY(typeof e=="function"?e:ox(e)))}function u5(e){typeof e!="function"&&(e=op(e));for(var t=this._groups,n=t.length,r=new Array(n),i=0;i<n;++i)for(var o=t[i],s=o.length,a=r[i]=[],c,l=0;l<s;++l)(c=o[l])&&e.call(c,c.__data__,l,o)&&a.push(c);return new Fe(r,this._parents)}function sx(e){return new Array(e.length)}function f5(){return new Fe(this._enter||this._groups.map(sx),this._parents)}function sp(e,t){this.ownerDocument=e.ownerDocument,this.namespaceURI=e.namespaceURI,this._next=null,this._parent=e,this.__data__=t}sp.prototype={constructor:sp,appendChild:function(e){return this._parent.insertBefore(e,this._next)},insertBefore:function(e,t){return this._parent.insertBefore(e,t)},querySelector:function(e){return this._parent.querySelector(e)},querySelectorAll:function(e){return this._parent.querySelectorAll(e)}};function d5(e){return function(){return e}}function mY(e,t,n,r,i,o){for(var s=0,a,c=t.length,l=o.length;s<l;++s)(a=t[s])?(a.__data__=o[s],r[s]=a):n[s]=new sp(e,o[s]);for(;s<c;++s)(a=t[s])&&(i[s]=a)}function yY(e,t,n,r,i,o,s){var a,c,l=new Map,u=t.length,f=o.length,d=new Array(u),h;for(a=0;a<u;++a)(c=t[a])&&(d[a]=h=s.call(c,c.__data__,a,t)+"",l.has(h)?i[a]=c:l.set(h,c));for(a=0;a<f;++a)h=s.call(e,o[a],a,o)+"",(c=l.get(h))?(r[a]=c,c.__data__=o[a],l.delete(h)):n[a]=new sp(e,o[a]);for(a=0;a<u;++a)(c=t[a])&&l.get(d[a])===c&&(i[a]=c)}function gY(e){return e.__data__}function h5(e,t){if(!arguments.length)return Array.from(this,gY);var n=t?yY:mY,r=this._parents,i=this._groups;typeof e!="function"&&(e=d5(e));for(var o=i.length,s=new Array(o),a=new Array(o),c=new Array(o),l=0;l<o;++l){var u=r[l],f=i[l],d=f.length,h=xY(e.call(u,u&&u.__data__,l,r)),p=h.length,m=a[l]=new Array(p),g=s[l]=new Array(p),y=c[l]=new Array(d);n(u,f,m,g,y,h,t);for(var x=0,b=0,w,v;x<p;++x)if(w=m[x]){for(x>=b&&(b=x+1);!(v=g[b])&&++b<p;);w._next=v||null}}return s=new Fe(s,r),s._enter=a,s._exit=c,s}function xY(e){return typeof e=="object"&&"length"in e?e:Array.from(e)}function p5(){return new Fe(this._exit||this._groups.map(sx),this._parents)}function m5(e,t,n){var r=this.enter(),i=this,o=this.exit();return typeof e=="function"?(r=e(r),r&&(r=r.selection())):r=r.append(e+""),t!=null&&(i=t(i),i&&(i=i.selection())),n==null?o.remove():n(o),r&&i?r.merge(i).order():i}function y5(e){for(var t=e.selection?e.selection():e,n=this._groups,r=t._groups,i=n.length,o=r.length,s=Math.min(i,o),a=new Array(i),c=0;c<s;++c)for(var l=n[c],u=r[c],f=l.length,d=a[c]=new Array(f),h,p=0;p<f;++p)(h=l[p]||u[p])&&(d[p]=h);for(;c<i;++c)a[c]=n[c];return new Fe(a,this._parents)}function g5(){for(var e=this._groups,t=-1,n=e.length;++t<n;)for(var r=e[t],i=r.length-1,o=r[i],s;--i>=0;)(s=r[i])&&(o&&s.compareDocumentPosition(o)^4&&o.parentNode.insertBefore(s,o),o=s);return this}function x5(e){e||(e=bY);function t(f,d){return f&&d?e(f.__data__,d.__data__):!f-!d}for(var n=this._groups,r=n.length,i=new Array(r),o=0;o<r;++o){for(var s=n[o],a=s.length,c=i[o]=new Array(a),l,u=0;u<a;++u)(l=s[u])&&(c[u]=l);c.sort(t)}return new Fe(i,this._parents).order()}function bY(e,t){return e<t?-1:e>t?1:e>=t?0:NaN}function b5(){var e=arguments[0];return arguments[0]=this,e.apply(null,arguments),this}function w5(){return Array.from(this)}function v5(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var r=e[t],i=0,o=r.length;i<o;++i){var s=r[i];if(s)return s}return null}function _5(){let e=0;for(let t of this)++e;return e}function S5(){return!this.node()}function I5(e){for(var t=this._groups,n=0,r=t.length;n<r;++n)for(var i=t[n],o=0,s=i.length,a;o<s;++o)(a=i[o])&&e.call(a,a.__data__,o,i);return this}function wY(e){return function(){this.removeAttribute(e)}}function vY(e){return function(){this.removeAttributeNS(e.space,e.local)}}function _Y(e,t){return function(){this.setAttribute(e,t)}}function SY(e,t){return function(){this.setAttributeNS(e.space,e.local,t)}}function IY(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttribute(e):this.setAttribute(e,n)}}function MY(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttributeNS(e.space,e.local):this.setAttributeNS(e.space,e.local,n)}}function M5(e,t){var n=Ds(e);if(arguments.length<2){var r=this.node();return n.local?r.getAttributeNS(n.space,n.local):r.getAttribute(n)}return this.each((t==null?n.local?vY:wY:typeof t=="function"?n.local?MY:IY:n.local?SY:_Y)(n,t))}function ax(e){return e.ownerDocument&&e.ownerDocument.defaultView||e.document&&e||e.defaultView}function AY(e){return function(){this.style.removeProperty(e)}}function TY(e,t,n){return function(){this.style.setProperty(e,t,n)}}function EY(e,t,n){return function(){var r=t.apply(this,arguments);r==null?this.style.removeProperty(e):this.style.setProperty(e,r,n)}}function A5(e,t,n){return arguments.length>1?this.each((t==null?AY:typeof t=="function"?EY:TY)(e,t,n??"")):Oa(this.node(),e)}function Oa(e,t){return e.style.getPropertyValue(t)||ax(e).getComputedStyle(e,null).getPropertyValue(t)}function NY(e){return function(){delete this[e]}}function DY(e,t){return function(){this[e]=t}}function OY(e,t){return function(){var n=t.apply(this,arguments);n==null?delete this[e]:this[e]=n}}function T5(e,t){return arguments.length>1?this.each((t==null?NY:typeof t=="function"?OY:DY)(e,t)):this.node()[e]}function E5(e){return e.trim().split(/^|\s+/)}function HS(e){return e.classList||new N5(e)}function N5(e){this._node=e,this._names=E5(e.getAttribute("class")||"")}N5.prototype={add:function(e){var t=this._names.indexOf(e);t<0&&(this._names.push(e),this._node.setAttribute("class",this._names.join(" ")))},remove:function(e){var t=this._names.indexOf(e);t>=0&&(this._names.splice(t,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(e){return this._names.indexOf(e)>=0}};function D5(e,t){for(var n=HS(e),r=-1,i=t.length;++r<i;)n.add(t[r])}function O5(e,t){for(var n=HS(e),r=-1,i=t.length;++r<i;)n.remove(t[r])}function BY(e){return function(){D5(this,e)}}function LY(e){return function(){O5(this,e)}}function CY(e,t){return function(){(t.apply(this,arguments)?D5:O5)(this,e)}}function B5(e,t){var n=E5(e+"");if(arguments.length<2){for(var r=HS(this.node()),i=-1,o=n.length;++i<o;)if(!r.contains(n[i]))return!1;return!0}return this.each((typeof t=="function"?CY:t?BY:LY)(n,t))}function kY(){this.textContent=""}function FY(e){return function(){this.textContent=e}}function RY(e){return function(){var t=e.apply(this,arguments);this.textContent=t??""}}function L5(e){return arguments.length?this.each(e==null?kY:(typeof e=="function"?RY:FY)(e)):this.node().textContent}function $Y(){this.innerHTML=""}function PY(e){return function(){this.innerHTML=e}}function UY(e){return function(){var t=e.apply(this,arguments);this.innerHTML=t??""}}function C5(e){return arguments.length?this.each(e==null?$Y:(typeof e=="function"?UY:PY)(e)):this.node().innerHTML}function zY(){this.nextSibling&&this.parentNode.appendChild(this)}function k5(){return this.each(zY)}function qY(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function F5(){return this.each(qY)}function R5(e){var t=typeof e=="function"?e:Os(e);return this.select(function(){return this.appendChild(t.apply(this,arguments))})}function jY(){return null}function $5(e,t){var n=typeof e=="function"?e:Os(e),r=t==null?jY:typeof t=="function"?t:Wc(t);return this.select(function(){return this.insertBefore(n.apply(this,arguments),r.apply(this,arguments)||null)})}function VY(){var e=this.parentNode;e&&e.removeChild(this)}function P5(){return this.each(VY)}function YY(){var e=this.cloneNode(!1),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function XY(){var e=this.cloneNode(!0),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function U5(e){return this.select(e?XY:YY)}function z5(e){return arguments.length?this.property("__data__",e):this.node().__data__}function GY(e){return function(t){e.call(this,t,this.__data__)}}function WY(e){return e.trim().split(/^|\s+/).map(function(t){var n="",r=t.indexOf(".");return r>=0&&(n=t.slice(r+1),t=t.slice(0,r)),{type:t,name:n}})}function HY(e){return function(){var t=this.__on;if(t){for(var n=0,r=-1,i=t.length,o;n<i;++n)o=t[n],(!e.type||o.type===e.type)&&o.name===e.name?this.removeEventListener(o.type,o.listener,o.options):t[++r]=o;++r?t.length=r:delete this.__on}}}function ZY(e,t,n){return function(){var r=this.__on,i,o=GY(t);if(r){for(var s=0,a=r.length;s<a;++s)if((i=r[s]).type===e.type&&i.name===e.name){this.removeEventListener(i.type,i.listener,i.options),this.addEventListener(i.type,i.listener=o,i.options=n),i.value=t;return}}this.addEventListener(e.type,o,n),i={type:e.type,name:e.name,value:t,listener:o,options:n},r?r.push(i):this.__on=[i]}}function q5(e,t,n){var r=WY(e+""),i,o=r.length,s;if(arguments.length<2){var a=this.node().__on;if(a){for(var c=0,l=a.length,u;c<l;++c)for(i=0,u=a[c];i<o;++i)if((s=r[i]).type===u.type&&s.name===u.name)return u.value}return}for(a=t?ZY:HY,i=0;i<o;++i)this.each(a(r[i],t,n));return this}function j5(e,t,n){var r=ax(e),i=r.CustomEvent;typeof i=="function"?i=new i(t,n):(i=r.document.createEvent("Event"),n?(i.initEvent(t,n.bubbles,n.cancelable),i.detail=n.detail):i.initEvent(t,!1,!1)),e.dispatchEvent(i)}function JY(e,t){return function(){return j5(this,e,t)}}function QY(e,t){return function(){return j5(this,e,t.apply(this,arguments))}}function V5(e,t){return this.each((typeof t=="function"?QY:JY)(e,t))}function*Y5(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var r=e[t],i=0,o=r.length,s;i<o;++i)(s=r[i])&&(yield s)}var ZS=[null];function Fe(e,t){this._groups=e,this._parents=t}function X5(){return new Fe([[document.documentElement]],ZS)}function KY(){return this}Fe.prototype=X5.prototype={constructor:Fe,select:s5,selectAll:a5,selectChild:c5,selectChildren:l5,filter:u5,data:h5,enter:f5,exit:p5,join:m5,merge:y5,selection:KY,order:g5,sort:x5,call:b5,nodes:w5,node:v5,size:_5,empty:S5,each:I5,attr:M5,style:A5,property:T5,classed:B5,text:L5,html:C5,raise:k5,lower:F5,append:R5,insert:$5,remove:P5,clone:U5,datum:z5,on:q5,dispatch:V5,[Symbol.iterator]:Y5};var Bs=X5;function Vt(e){return typeof e=="string"?new Fe([[document.querySelector(e)]],[document.documentElement]):new Fe([[e]],ZS)}function G5(e){let t;for(;t=e.sourceEvent;)e=t;return e}function kn(e,t){if(e=G5(e),t===void 0&&(t=e.currentTarget),t){var n=t.ownerSVGElement||t;if(n.createSVGPoint){var r=n.createSVGPoint();return r.x=e.clientX,r.y=e.clientY,r=r.matrixTransform(t.getScreenCTM().inverse()),[r.x,r.y]}if(t.getBoundingClientRect){var i=t.getBoundingClientRect();return[e.clientX-i.left-t.clientLeft,e.clientY-i.top-t.clientTop]}}return[e.pageX,e.pageY]}var cx={capture:!0,passive:!1};function lx(e){e.preventDefault(),e.stopImmediatePropagation()}function ap(e){var t=e.document.documentElement,n=Vt(e).on("dragstart.drag",lx,cx);"onselectstart"in t?n.on("selectstart.drag",lx,cx):(t.__noselect=t.style.MozUserSelect,t.style.MozUserSelect="none")}function cp(e,t){var n=e.document.documentElement,r=Vt(e).on("dragstart.drag",null);t&&(r.on("click.drag",lx,cx),setTimeout(function(){r.on("click.drag",null)},0)),"onselectstart"in n?r.on("selectstart.drag",null):(n.style.MozUserSelect=n.__noselect,delete n.__noselect)}function Ls(e,t,n){e.prototype=t.prototype=n,n.constructor=e}function Ba(e,t){var n=Object.create(e.prototype);for(var r in t)n[r]=t[r];return n}function po(){}var La=.7,Jc=1/La,Bu="\\s*([+-]?\\d+)\\s*",lp="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",ho="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",tX=/^#([0-9a-f]{3,8})$/,eX=new RegExp(`^rgb\\(${Bu},${Bu},${Bu}\\)$`),nX=new RegExp(`^rgb\\(${ho},${ho},${ho}\\)$`),rX=new RegExp(`^rgba\\(${Bu},${Bu},${Bu},${lp}\\)$`),iX=new RegExp(`^rgba\\(${ho},${ho},${ho},${lp}\\)$`),oX=new RegExp(`^hsl\\(${lp},${ho},${ho}\\)$`),sX=new RegExp(`^hsla\\(${lp},${ho},${ho},${lp}\\)$`),W5={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};Ls(po,Rr,{copy(e){return Object.assign(new this.constructor,this,e)},displayable(){return this.rgb().displayable()},hex:H5,formatHex:H5,formatHex8:aX,formatHsl:cX,formatRgb:Z5,toString:Z5});function H5(){return this.rgb().formatHex()}function aX(){return this.rgb().formatHex8()}function cX(){return nL(this).formatHsl()}function Z5(){return this.rgb().formatRgb()}function Rr(e){var t,n;return e=(e+"").trim().toLowerCase(),(t=tX.exec(e))?(n=t[1].length,t=parseInt(t[1],16),n===6?J5(t):n===3?new Ge(t>>8&15|t>>4&240,t>>4&15|t&240,(t&15)<<4|t&15,1):n===8?ux(t>>24&255,t>>16&255,t>>8&255,(t&255)/255):n===4?ux(t>>12&15|t>>8&240,t>>8&15|t>>4&240,t>>4&15|t&240,((t&15)<<4|t&15)/255):null):(t=eX.exec(e))?new Ge(t[1],t[2],t[3],1):(t=nX.exec(e))?new Ge(t[1]*255/100,t[2]*255/100,t[3]*255/100,1):(t=rX.exec(e))?ux(t[1],t[2],t[3],t[4]):(t=iX.exec(e))?ux(t[1]*255/100,t[2]*255/100,t[3]*255/100,t[4]):(t=oX.exec(e))?tL(t[1],t[2]/100,t[3]/100,1):(t=sX.exec(e))?tL(t[1],t[2]/100,t[3]/100,t[4]):W5.hasOwnProperty(e)?J5(W5[e]):e==="transparent"?new Ge(NaN,NaN,NaN,0):null}function J5(e){return new Ge(e>>16&255,e>>8&255,e&255,1)}function ux(e,t,n,r){return r<=0&&(e=t=n=NaN),new Ge(e,t,n,r)}function up(e){return e instanceof po||(e=Rr(e)),e?(e=e.rgb(),new Ge(e.r,e.g,e.b,e.opacity)):new Ge}function on(e,t,n,r){return arguments.length===1?up(e):new Ge(e,t,n,r??1)}function Ge(e,t,n,r){this.r=+e,this.g=+t,this.b=+n,this.opacity=+r}Ls(Ge,on,Ba(po,{brighter(e){return e=e==null?Jc:Math.pow(Jc,e),new Ge(this.r*e,this.g*e,this.b*e,this.opacity)},darker(e){return e=e==null?La:Math.pow(La,e),new Ge(this.r*e,this.g*e,this.b*e,this.opacity)},rgb(){return this},clamp(){return new Ge(Zc(this.r),Zc(this.g),Zc(this.b),dx(this.opacity))},displayable(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:Q5,formatHex:Q5,formatHex8:lX,formatRgb:K5,toString:K5}));function Q5(){return`#${Hc(this.r)}${Hc(this.g)}${Hc(this.b)}`}function lX(){return`#${Hc(this.r)}${Hc(this.g)}${Hc(this.b)}${Hc((isNaN(this.opacity)?1:this.opacity)*255)}`}function K5(){let e=dx(this.opacity);return`${e===1?"rgb(":"rgba("}${Zc(this.r)}, ${Zc(this.g)}, ${Zc(this.b)}${e===1?")":`, ${e})`}`}function dx(e){return isNaN(e)?1:Math.max(0,Math.min(1,e))}function Zc(e){return Math.max(0,Math.min(255,Math.round(e)||0))}function Hc(e){return e=Zc(e),(e<16?"0":"")+e.toString(16)}function tL(e,t,n,r){return r<=0?e=t=n=NaN:n<=0||n>=1?e=t=NaN:t<=0&&(e=NaN),new Ui(e,t,n,r)}function nL(e){if(e instanceof Ui)return new Ui(e.h,e.s,e.l,e.opacity);if(e instanceof po||(e=Rr(e)),!e)return new Ui;if(e instanceof Ui)return e;e=e.rgb();var t=e.r/255,n=e.g/255,r=e.b/255,i=Math.min(t,n,r),o=Math.max(t,n,r),s=NaN,a=o-i,c=(o+i)/2;return a?(t===o?s=(n-r)/a+(n<r)*6:n===o?s=(r-t)/a+2:s=(t-n)/a+4,a/=c<.5?o+i:2-o-i,s*=60):a=c>0&&c<1?0:s,new Ui(s,a,c,e.opacity)}function fp(e,t,n,r){return arguments.length===1?nL(e):new Ui(e,t,n,r??1)}function Ui(e,t,n,r){this.h=+e,this.s=+t,this.l=+n,this.opacity=+r}Ls(Ui,fp,Ba(po,{brighter(e){return e=e==null?Jc:Math.pow(Jc,e),new Ui(this.h,this.s,this.l*e,this.opacity)},darker(e){return e=e==null?La:Math.pow(La,e),new Ui(this.h,this.s,this.l*e,this.opacity)},rgb(){var e=this.h%360+(this.h<0)*360,t=isNaN(e)||isNaN(this.s)?0:this.s,n=this.l,r=n+(n<.5?n:1-n)*t,i=2*n-r;return new Ge(JS(e>=240?e-240:e+120,i,r),JS(e,i,r),JS(e<120?e+240:e-120,i,r),this.opacity)},clamp(){return new Ui(eL(this.h),fx(this.s),fx(this.l),dx(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){let e=dx(this.opacity);return`${e===1?"hsl(":"hsla("}${eL(this.h)}, ${fx(this.s)*100}%, ${fx(this.l)*100}%${e===1?")":`, ${e})`}`}}));function eL(e){return e=(e||0)%360,e<0?e+360:e}function fx(e){return Math.max(0,Math.min(1,e||0))}function JS(e,t,n){return(e<60?t+(n-t)*e/60:e<180?n:e<240?t+(n-t)*(240-e)/60:t)*255}var hx=Math.PI/180,px=180/Math.PI;var mx=18,rL=.96422,iL=1,oL=.82521,sL=4/29,Lu=6/29,aL=3*Lu*Lu,uX=Lu*Lu*Lu;function cL(e){if(e instanceof mo)return new mo(e.l,e.a,e.b,e.opacity);if(e instanceof Cs)return lL(e);e instanceof Ge||(e=up(e));var t=eI(e.r),n=eI(e.g),r=eI(e.b),i=QS((.2225045*t+.7168786*n+.0606169*r)/iL),o,s;return t===n&&n===r?o=s=i:(o=QS((.4360747*t+.3850649*n+.1430804*r)/rL),s=QS((.0139322*t+.0971045*n+.7141733*r)/oL)),new mo(116*i-16,500*(o-i),200*(i-s),e.opacity)}function Cu(e,t,n,r){return arguments.length===1?cL(e):new mo(e,t,n,r??1)}function mo(e,t,n,r){this.l=+e,this.a=+t,this.b=+n,this.opacity=+r}Ls(mo,Cu,Ba(po,{brighter(e){return new mo(this.l+mx*(e??1),this.a,this.b,this.opacity)},darker(e){return new mo(this.l-mx*(e??1),this.a,this.b,this.opacity)},rgb(){var e=(this.l+16)/116,t=isNaN(this.a)?e:e+this.a/500,n=isNaN(this.b)?e:e-this.b/200;return t=rL*KS(t),e=iL*KS(e),n=oL*KS(n),new Ge(tI(3.1338561*t-1.6168667*e-.4906146*n),tI(-.9787684*t+1.9161415*e+.033454*n),tI(.0719453*t-.2289914*e+1.4052427*n),this.opacity)}}));function QS(e){return e>uX?Math.pow(e,1/3):e/aL+sL}function KS(e){return e>Lu?e*e*e:aL*(e-sL)}function tI(e){return 255*(e<=.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055)}function eI(e){return(e/=255)<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}function fX(e){if(e instanceof Cs)return new Cs(e.h,e.c,e.l,e.opacity);if(e instanceof mo||(e=cL(e)),e.a===0&&e.b===0)return new Cs(NaN,0<e.l&&e.l<100?0:NaN,e.l,e.opacity);var t=Math.atan2(e.b,e.a)*px;return new Cs(t<0?t+360:t,Math.sqrt(e.a*e.a+e.b*e.b),e.l,e.opacity)}function dp(e,t,n,r){return arguments.length===1?fX(e):new Cs(e,t,n,r??1)}function Cs(e,t,n,r){this.h=+e,this.c=+t,this.l=+n,this.opacity=+r}function lL(e){if(isNaN(e.h))return new mo(e.l,0,0,e.opacity);var t=e.h*hx;return new mo(e.l,Math.cos(t)*e.c,Math.sin(t)*e.c,e.opacity)}Ls(Cs,dp,Ba(po,{brighter(e){return new Cs(this.h,this.c,this.l+mx*(e??1),this.opacity)},darker(e){return new Cs(this.h,this.c,this.l-mx*(e??1),this.opacity)},rgb(){return lL(this).rgb()}}));var hL=-.14861,nI=1.78277,rI=-.29227,yx=-.90649,hp=1.97294,uL=hp*yx,fL=hp*nI,dL=nI*rI-yx*hL;function dX(e){if(e instanceof Qc)return new Qc(e.h,e.s,e.l,e.opacity);e instanceof Ge||(e=up(e));var t=e.r/255,n=e.g/255,r=e.b/255,i=(dL*r+uL*t-fL*n)/(dL+uL-fL),o=r-i,s=(hp*(n-i)-rI*o)/yx,a=Math.sqrt(s*s+o*o)/(hp*i*(1-i)),c=a?Math.atan2(s,o)*px-120:NaN;return new Qc(c<0?c+360:c,a,i,e.opacity)}function Kn(e,t,n,r){return arguments.length===1?dX(e):new Qc(e,t,n,r??1)}function Qc(e,t,n,r){this.h=+e,this.s=+t,this.l=+n,this.opacity=+r}Ls(Qc,Kn,Ba(po,{brighter(e){return e=e==null?Jc:Math.pow(Jc,e),new Qc(this.h,this.s,this.l*e,this.opacity)},darker(e){return e=e==null?La:Math.pow(La,e),new Qc(this.h,this.s,this.l*e,this.opacity)},rgb(){var e=isNaN(this.h)?0:(this.h+120)*hx,t=+this.l,n=isNaN(this.s)?0:this.s*t*(1-t),r=Math.cos(e),i=Math.sin(e);return new Ge(255*(t+n*(hL*r+nI*i)),255*(t+n*(rI*r+yx*i)),255*(t+n*(hp*r)),this.opacity)}}));function iI(e,t,n,r,i){var o=e*e,s=o*e;return((1-3*e+3*o-s)*t+(4-6*o+3*s)*n+(1+3*e+3*o-3*s)*r+s*i)/6}function pL(e){var t=e.length-1;return function(n){var r=n<=0?n=0:n>=1?(n=1,t-1):Math.floor(n*t),i=e[r],o=e[r+1],s=r>0?e[r-1]:2*i-o,a=r<t-1?e[r+2]:2*o-i;return iI((n-r/t)*t,s,i,o,a)}}function mL(e){var t=e.length;return function(n){var r=Math.floor(((n%=1)<0?++n:n)*t),i=e[(r+t-1)%t],o=e[r%t],s=e[(r+1)%t],a=e[(r+2)%t];return iI((n-r/t)*t,i,o,s,a)}}var ku=e=>()=>e;function yL(e,t){return function(n){return e+n*t}}function hX(e,t,n){return e=Math.pow(e,n),t=Math.pow(t,n)-e,n=1/n,function(r){return Math.pow(e+r*t,n)}}function Fu(e,t){var n=t-e;return n?yL(e,n>180||n<-180?n-360*Math.round(n/360):n):ku(isNaN(e)?t:e)}function gL(e){return(e=+e)==1?Te:function(t,n){return n-t?hX(t,n,e):ku(isNaN(t)?n:t)}}function Te(e,t){var n=t-e;return n?yL(e,n):ku(isNaN(e)?t:e)}var si=function e(t){var n=gL(t);function r(i,o){var s=n((i=on(i)).r,(o=on(o)).r),a=n(i.g,o.g),c=n(i.b,o.b),l=Te(i.opacity,o.opacity);return function(u){return i.r=s(u),i.g=a(u),i.b=c(u),i.opacity=l(u),i+""}}return r.gamma=e,r}(1);function xL(e){return function(t){var n=t.length,r=new Array(n),i=new Array(n),o=new Array(n),s,a;for(s=0;s<n;++s)a=on(t[s]),r[s]=a.r||0,i[s]=a.g||0,o[s]=a.b||0;return r=e(r),i=e(i),o=e(o),a.opacity=1,function(c){return a.r=r(c),a.g=i(c),a.b=o(c),a+""}}}var oI=xL(pL),pX=xL(mL);function bL(e,t){t||(t=[]);var n=e?Math.min(t.length,e.length):0,r=t.slice(),i;return function(o){for(i=0;i<n;++i)r[i]=e[i]*(1-o)+t[i]*o;return r}}function wL(e){return ArrayBuffer.isView(e)&&!(e instanceof DataView)}function vL(e,t){var n=t?t.length:0,r=e?Math.min(n,e.length):0,i=new Array(r),o=new Array(n),s;for(s=0;s<r;++s)i[s]=$r(e[s],t[s]);for(;s<n;++s)o[s]=t[s];return function(a){for(s=0;s<r;++s)o[s]=i[s](a);return o}}function _L(e,t){var n=new Date;return e=+e,t=+t,function(r){return n.setTime(e*(1-r)+t*r),n}}function _e(e,t){return e=+e,t=+t,function(n){return e*(1-n)+t*n}}function SL(e,t){var n={},r={},i;(e===null||typeof e!="object")&&(e={}),(t===null||typeof t!="object")&&(t={});for(i in t)i in e?n[i]=$r(e[i],t[i]):r[i]=t[i];return function(o){for(i in n)r[i]=n[i](o);return r}}var aI=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,sI=new RegExp(aI.source,"g");function mX(e){return function(){return e}}function yX(e){return function(t){return e(t)+""}}function pp(e,t){var n=aI.lastIndex=sI.lastIndex=0,r,i,o,s=-1,a=[],c=[];for(e=e+"",t=t+"";(r=aI.exec(e))&&(i=sI.exec(t));)(o=i.index)>n&&(o=t.slice(n,o),a[s]?a[s]+=o:a[++s]=o),(r=r[0])===(i=i[0])?a[s]?a[s]+=i:a[++s]=i:(a[++s]=null,c.push({i:s,x:_e(r,i)})),n=sI.lastIndex;return n<t.length&&(o=t.slice(n),a[s]?a[s]+=o:a[++s]=o),a.length<2?c[0]?yX(c[0].x):mX(t):(t=c.length,function(l){for(var u=0,f;u<t;++u)a[(f=c[u]).i]=f.x(l);return a.join("")})}function $r(e,t){var n=typeof t,r;return t==null||n==="boolean"?ku(t):(n==="number"?_e:n==="string"?(r=Rr(t))?(t=r,si):pp:t instanceof Rr?si:t instanceof Date?_L:wL(t)?bL:Array.isArray(t)?vL:typeof t.valueOf!="function"&&typeof t.toString!="function"||isNaN(t)?SL:_e)(e,t)}function Kc(e,t){return e=+e,t=+t,function(n){return Math.round(e*(1-n)+t*n)}}var IL=180/Math.PI,gx={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function cI(e,t,n,r,i,o){var s,a,c;return(s=Math.sqrt(e*e+t*t))&&(e/=s,t/=s),(c=e*n+t*r)&&(n-=e*c,r-=t*c),(a=Math.sqrt(n*n+r*r))&&(n/=a,r/=a,c/=a),e*r<t*n&&(e=-e,t=-t,c=-c,s=-s),{translateX:i,translateY:o,rotate:Math.atan2(t,e)*IL,skewX:Math.atan(c)*IL,scaleX:s,scaleY:a}}var xx;function ML(e){let t=new(typeof DOMMatrix=="function"?DOMMatrix:WebKitCSSMatrix)(e+"");return t.isIdentity?gx:cI(t.a,t.b,t.c,t.d,t.e,t.f)}function AL(e){return e==null?gx:(xx||(xx=document.createElementNS("http://www.w3.org/2000/svg","g")),xx.setAttribute("transform",e),(e=xx.transform.baseVal.consolidate())?(e=e.matrix,cI(e.a,e.b,e.c,e.d,e.e,e.f)):gx)}function TL(e,t,n,r){function i(l){return l.length?l.pop()+" ":""}function o(l,u,f,d,h,p){if(l!==f||u!==d){var m=h.push("translate(",null,t,null,n);p.push({i:m-4,x:_e(l,f)},{i:m-2,x:_e(u,d)})}else(f||d)&&h.push("translate("+f+t+d+n)}function s(l,u,f,d){l!==u?(l-u>180?u+=360:u-l>180&&(l+=360),d.push({i:f.push(i(f)+"rotate(",null,r)-2,x:_e(l,u)})):u&&f.push(i(f)+"rotate("+u+r)}function a(l,u,f,d){l!==u?d.push({i:f.push(i(f)+"skewX(",null,r)-2,x:_e(l,u)}):u&&f.push(i(f)+"skewX("+u+r)}function c(l,u,f,d,h,p){if(l!==f||u!==d){var m=h.push(i(h)+"scale(",null,",",null,")");p.push({i:m-4,x:_e(l,f)},{i:m-2,x:_e(u,d)})}else(f!==1||d!==1)&&h.push(i(h)+"scale("+f+","+d+")")}return function(l,u){var f=[],d=[];return l=e(l),u=e(u),o(l.translateX,l.translateY,u.translateX,u.translateY,f,d),s(l.rotate,u.rotate,f,d),a(l.skewX,u.skewX,f,d),c(l.scaleX,l.scaleY,u.scaleX,u.scaleY,f,d),l=u=null,function(h){for(var p=-1,m=d.length,g;++p<m;)f[(g=d[p]).i]=g.x(h);return f.join("")}}}var lI=TL(ML,"px, ","px)","deg)"),uI=TL(AL,", ",")",")");var gX=1e-12;function EL(e){return((e=Math.exp(e))+1/e)/2}function xX(e){return((e=Math.exp(e))-1/e)/2}function bX(e){return((e=Math.exp(2*e))-1)/(e+1)}var fI=function e(t,n,r){function i(o,s){var a=o[0],c=o[1],l=o[2],u=s[0],f=s[1],d=s[2],h=u-a,p=f-c,m=h*h+p*p,g,y;if(m<gX)y=Math.log(d/l)/t,g=function(I){return[a+I*h,c+I*p,l*Math.exp(t*I*y)]};else{var x=Math.sqrt(m),b=(d*d-l*l+r*m)/(2*l*n*x),w=(d*d-l*l-r*m)/(2*d*n*x),v=Math.log(Math.sqrt(b*b+1)-b),_=Math.log(Math.sqrt(w*w+1)-w);y=(_-v)/t,g=function(I){var D=I*y,A=EL(v),E=l/(n*x)*(A*bX(t*D+v)-xX(v));return[a+E*h,c+E*p,l*A/EL(t*D+v)]}}return g.duration=y*1e3*t/Math.SQRT2,g}return i.rho=function(o){var s=Math.max(.001,+o),a=s*s,c=a*a;return e(s,a,c)},i}(Math.SQRT2,2,4);function NL(e){return function(t,n){var r=e((t=fp(t)).h,(n=fp(n)).h),i=Te(t.s,n.s),o=Te(t.l,n.l),s=Te(t.opacity,n.opacity);return function(a){return t.h=r(a),t.s=i(a),t.l=o(a),t.opacity=s(a),t+""}}}var dI=NL(Fu),wX=NL(Te);function bx(e,t){var n=Te((e=Cu(e)).l,(t=Cu(t)).l),r=Te(e.a,t.a),i=Te(e.b,t.b),o=Te(e.opacity,t.opacity);return function(s){return e.l=n(s),e.a=r(s),e.b=i(s),e.opacity=o(s),e+""}}function DL(e){return function(t,n){var r=e((t=dp(t)).h,(n=dp(n)).h),i=Te(t.c,n.c),o=Te(t.l,n.l),s=Te(t.opacity,n.opacity);return function(a){return t.h=r(a),t.c=i(a),t.l=o(a),t.opacity=s(a),t+""}}}var hI=DL(Fu),vX=DL(Te);function OL(e){return function t(n){n=+n;function r(i,o){var s=e((i=Kn(i)).h,(o=Kn(o)).h),a=Te(i.s,o.s),c=Te(i.l,o.l),l=Te(i.opacity,o.opacity);return function(u){return i.h=s(u),i.s=a(u),i.l=c(Math.pow(u,n)),i.opacity=l(u),i+""}}return r.gamma=t,r}(1)}var _X=OL(Fu),Ru=OL(Te);function yo(e,t){t===void 0&&(t=e,e=$r);for(var n=0,r=t.length-1,i=t[0],o=new Array(r<0?0:r);n<r;)o[n]=e(i,i=t[++n]);return function(s){var a=Math.max(0,Math.min(r-1,Math.floor(s*=r)));return o[a](s-a)}}function Fn(e,t){for(var n=new Array(t),r=0;r<t;++r)n[r]=e(r/(t-1));return n}var $u=0,yp=0,mp=0,LL=1e3,wx,gp,vx=0,tl=0,_x=0,xp=typeof performance=="object"&&performance.now?performance:Date,CL=typeof window=="object"&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(e){setTimeout(e,17)};function wp(){return tl||(CL(SX),tl=xp.now()+_x)}function SX(){tl=0}function bp(){this._call=this._time=this._next=null}bp.prototype=Sx.prototype={constructor:bp,restart:function(e,t,n){if(typeof e!="function")throw new TypeError("callback is not a function");n=(n==null?wp():+n)+(t==null?0:+t),!this._next&&gp!==this&&(gp?gp._next=this:wx=this,gp=this),this._call=e,this._time=n,pI()},stop:function(){this._call&&(this._call=null,this._time=1/0,pI())}};function Sx(e,t,n){var r=new bp;return r.restart(e,t,n),r}function kL(){wp(),++$u;for(var e=wx,t;e;)(t=tl-e._time)>=0&&e._call.call(void 0,t),e=e._next;--$u}function BL(){tl=(vx=xp.now())+_x,$u=yp=0;try{kL()}finally{$u=0,MX(),tl=0}}function IX(){var e=xp.now(),t=e-vx;t>LL&&(_x-=t,vx=e)}function MX(){for(var e,t=wx,n,r=1/0;t;)t._call?(r>t._time&&(r=t._time),e=t,t=t._next):(n=t._next,t._next=null,t=e?e._next=n:wx=n);gp=e,pI(r)}function pI(e){if(!$u){yp&&(yp=clearTimeout(yp));var t=e-tl;t>24?(e<1/0&&(yp=setTimeout(BL,e-xp.now()-_x)),mp&&(mp=clearInterval(mp))):(mp||(vx=xp.now(),mp=setInterval(IX,LL)),$u=1,CL(BL))}}function Ix(e,t,n){var r=new bp;return t=t==null?0:+t,r.restart(i=>{r.stop(),e(i+t)},t,n),r}var AX=Gc("start","end","cancel","interrupt"),TX=[],$L=0,FL=1,Ax=2,Mx=3,RL=4,Tx=5,vp=6;function Ca(e,t,n,r,i,o){var s=e.__transition;if(!s)e.__transition={};else if(n in s)return;EX(e,n,{name:t,index:r,group:i,on:AX,tween:TX,time:o.time,delay:o.delay,duration:o.duration,ease:o.ease,timer:null,state:$L})}function _p(e,t){var n=sn(e,t);if(n.state>$L)throw new Error("too late; already scheduled");return n}function Tn(e,t){var n=sn(e,t);if(n.state>Mx)throw new Error("too late; already running");return n}function sn(e,t){var n=e.__transition;if(!n||!(n=n[t]))throw new Error("transition not found");return n}function EX(e,t,n){var r=e.__transition,i;r[t]=n,n.timer=Sx(o,0,n.time);function o(l){n.state=FL,n.timer.restart(s,n.delay,n.time),n.delay<=l&&s(l-n.delay)}function s(l){var u,f,d,h;if(n.state!==FL)return c();for(u in r)if(h=r[u],h.name===n.name){if(h.state===Mx)return Ix(s);h.state===RL?(h.state=vp,h.timer.stop(),h.on.call("interrupt",e,e.__data__,h.index,h.group),delete r[u]):+u<t&&(h.state=vp,h.timer.stop(),h.on.call("cancel",e,e.__data__,h.index,h.group),delete r[u])}if(Ix(function(){n.state===Mx&&(n.state=RL,n.timer.restart(a,n.delay,n.time),a(l))}),n.state=Ax,n.on.call("start",e,e.__data__,n.index,n.group),n.state===Ax){for(n.state=Mx,i=new Array(d=n.tween.length),u=0,f=-1;u<d;++u)(h=n.tween[u].value.call(e,e.__data__,n.index,n.group))&&(i[++f]=h);i.length=f+1}}function a(l){for(var u=l<n.duration?n.ease.call(null,l/n.duration):(n.timer.restart(c),n.state=Tx,1),f=-1,d=i.length;++f<d;)i[f].call(e,u);n.state===Tx&&(n.on.call("end",e,e.__data__,n.index,n.group),c())}function c(){n.state=vp,n.timer.stop(),delete r[t];for(var l in r)return;delete e.__transition}}function go(e,t){var n=e.__transition,r,i,o=!0,s;if(n){t=t==null?null:t+"";for(s in n){if((r=n[s]).name!==t){o=!1;continue}i=r.state>Ax&&r.state<Tx,r.state=vp,r.timer.stop(),r.on.call(i?"interrupt":"cancel",e,e.__data__,r.index,r.group),delete n[s]}o&&delete e.__transition}}function PL(e){return this.each(function(){go(this,e)})}function NX(e,t){var n,r;return function(){var i=Tn(this,e),o=i.tween;if(o!==n){r=n=o;for(var s=0,a=r.length;s<a;++s)if(r[s].name===t){r=r.slice(),r.splice(s,1);break}}i.tween=r}}function DX(e,t,n){var r,i;if(typeof n!="function")throw new Error;return function(){var o=Tn(this,e),s=o.tween;if(s!==r){i=(r=s).slice();for(var a={name:t,value:n},c=0,l=i.length;c<l;++c)if(i[c].name===t){i[c]=a;break}c===l&&i.push(a)}o.tween=i}}function UL(e,t){var n=this._id;if(e+="",arguments.length<2){for(var r=sn(this.node(),n).tween,i=0,o=r.length,s;i<o;++i)if((s=r[i]).name===e)return s.value;return null}return this.each((t==null?NX:DX)(n,e,t))}function Pu(e,t,n){var r=e._id;return e.each(function(){var i=Tn(this,r);(i.value||(i.value={}))[t]=n.apply(this,arguments)}),function(i){return sn(i,r).value[t]}}function Ex(e,t){var n;return(typeof t=="number"?_e:t instanceof Rr?si:(n=Rr(t))?(t=n,si):pp)(e,t)}function OX(e){return function(){this.removeAttribute(e)}}function BX(e){return function(){this.removeAttributeNS(e.space,e.local)}}function LX(e,t,n){var r,i=n+"",o;return function(){var s=this.getAttribute(e);return s===i?null:s===r?o:o=t(r=s,n)}}function CX(e,t,n){var r,i=n+"",o;return function(){var s=this.getAttributeNS(e.space,e.local);return s===i?null:s===r?o:o=t(r=s,n)}}function kX(e,t,n){var r,i,o;return function(){var s,a=n(this),c;return a==null?void this.removeAttribute(e):(s=this.getAttribute(e),c=a+"",s===c?null:s===r&&c===i?o:(i=c,o=t(r=s,a)))}}function FX(e,t,n){var r,i,o;return function(){var s,a=n(this),c;return a==null?void this.removeAttributeNS(e.space,e.local):(s=this.getAttributeNS(e.space,e.local),c=a+"",s===c?null:s===r&&c===i?o:(i=c,o=t(r=s,a)))}}function zL(e,t){var n=Ds(e),r=n==="transform"?uI:Ex;return this.attrTween(e,typeof t=="function"?(n.local?FX:kX)(n,r,Pu(this,"attr."+e,t)):t==null?(n.local?BX:OX)(n):(n.local?CX:LX)(n,r,t))}function RX(e,t){return function(n){this.setAttribute(e,t.call(this,n))}}function $X(e,t){return function(n){this.setAttributeNS(e.space,e.local,t.call(this,n))}}function PX(e,t){var n,r;function i(){var o=t.apply(this,arguments);return o!==r&&(n=(r=o)&&$X(e,o)),n}return i._value=t,i}function UX(e,t){var n,r;function i(){var o=t.apply(this,arguments);return o!==r&&(n=(r=o)&&RX(e,o)),n}return i._value=t,i}function qL(e,t){var n="attr."+e;if(arguments.length<2)return(n=this.tween(n))&&n._value;if(t==null)return this.tween(n,null);if(typeof t!="function")throw new Error;var r=Ds(e);return this.tween(n,(r.local?PX:UX)(r,t))}function zX(e,t){return function(){_p(this,e).delay=+t.apply(this,arguments)}}function qX(e,t){return t=+t,function(){_p(this,e).delay=t}}function jL(e){var t=this._id;return arguments.length?this.each((typeof e=="function"?zX:qX)(t,e)):sn(this.node(),t).delay}function jX(e,t){return function(){Tn(this,e).duration=+t.apply(this,arguments)}}function VX(e,t){return t=+t,function(){Tn(this,e).duration=t}}function VL(e){var t=this._id;return arguments.length?this.each((typeof e=="function"?jX:VX)(t,e)):sn(this.node(),t).duration}function YX(e,t){if(typeof t!="function")throw new Error;return function(){Tn(this,e).ease=t}}function YL(e){var t=this._id;return arguments.length?this.each(YX(t,e)):sn(this.node(),t).ease}function XX(e,t){return function(){var n=t.apply(this,arguments);if(typeof n!="function")throw new Error;Tn(this,e).ease=n}}function XL(e){if(typeof e!="function")throw new Error;return this.each(XX(this._id,e))}function GL(e){typeof e!="function"&&(e=op(e));for(var t=this._groups,n=t.length,r=new Array(n),i=0;i<n;++i)for(var o=t[i],s=o.length,a=r[i]=[],c,l=0;l<s;++l)(c=o[l])&&e.call(c,c.__data__,l,o)&&a.push(c);return new tr(r,this._parents,this._name,this._id)}function WL(e){if(e._id!==this._id)throw new Error;for(var t=this._groups,n=e._groups,r=t.length,i=n.length,o=Math.min(r,i),s=new Array(r),a=0;a<o;++a)for(var c=t[a],l=n[a],u=c.length,f=s[a]=new Array(u),d,h=0;h<u;++h)(d=c[h]||l[h])&&(f[h]=d);for(;a<r;++a)s[a]=t[a];return new tr(s,this._parents,this._name,this._id)}function GX(e){return(e+"").trim().split(/^|\s+/).every(function(t){var n=t.indexOf(".");return n>=0&&(t=t.slice(0,n)),!t||t==="start"})}function WX(e,t,n){var r,i,o=GX(t)?_p:Tn;return function(){var s=o(this,e),a=s.on;a!==r&&(i=(r=a).copy()).on(t,n),s.on=i}}function HL(e,t){var n=this._id;return arguments.length<2?sn(this.node(),n).on.on(e):this.each(WX(n,e,t))}function HX(e){return function(){var t=this.parentNode;for(var n in this.__transition)if(+n!==e)return;t&&t.removeChild(this)}}function ZL(){return this.on("end.remove",HX(this._id))}function JL(e){var t=this._name,n=this._id;typeof e!="function"&&(e=Wc(e));for(var r=this._groups,i=r.length,o=new Array(i),s=0;s<i;++s)for(var a=r[s],c=a.length,l=o[s]=new Array(c),u,f,d=0;d<c;++d)(u=a[d])&&(f=e.call(u,u.__data__,d,a))&&("__data__"in u&&(f.__data__=u.__data__),l[d]=f,Ca(l[d],t,n,d,l,sn(u,n)));return new tr(o,this._parents,t,n)}function QL(e){var t=this._name,n=this._id;typeof e!="function"&&(e=ip(e));for(var r=this._groups,i=r.length,o=[],s=[],a=0;a<i;++a)for(var c=r[a],l=c.length,u,f=0;f<l;++f)if(u=c[f]){for(var d=e.call(u,u.__data__,f,c),h,p=sn(u,n),m=0,g=d.length;m<g;++m)(h=d[m])&&Ca(h,t,n,m,d,p);o.push(d),s.push(u)}return new tr(o,s,t,n)}var ZX=Bs.prototype.constructor;function KL(){return new ZX(this._groups,this._parents)}function JX(e,t){var n,r,i;return function(){var o=Oa(this,e),s=(this.style.removeProperty(e),Oa(this,e));return o===s?null:o===n&&s===r?i:i=t(n=o,r=s)}}function tC(e){return function(){this.style.removeProperty(e)}}function QX(e,t,n){var r,i=n+"",o;return function(){var s=Oa(this,e);return s===i?null:s===r?o:o=t(r=s,n)}}function KX(e,t,n){var r,i,o;return function(){var s=Oa(this,e),a=n(this),c=a+"";return a==null&&(c=a=(this.style.removeProperty(e),Oa(this,e))),s===c?null:s===r&&c===i?o:(i=c,o=t(r=s,a))}}function tG(e,t){var n,r,i,o="style."+t,s="end."+o,a;return function(){var c=Tn(this,e),l=c.on,u=c.value[o]==null?a||(a=tC(t)):void 0;(l!==n||i!==u)&&(r=(n=l).copy()).on(s,i=u),c.on=r}}function eC(e,t,n){var r=(e+="")=="transform"?lI:Ex;return t==null?this.styleTween(e,JX(e,r)).on("end.style."+e,tC(e)):typeof t=="function"?this.styleTween(e,KX(e,r,Pu(this,"style."+e,t))).each(tG(this._id,e)):this.styleTween(e,QX(e,r,t),n).on("end.style."+e,null)}function eG(e,t,n){return function(r){this.style.setProperty(e,t.call(this,r),n)}}function nG(e,t,n){var r,i;function o(){var s=t.apply(this,arguments);return s!==i&&(r=(i=s)&&eG(e,s,n)),r}return o._value=t,o}function nC(e,t,n){var r="style."+(e+="");if(arguments.length<2)return(r=this.tween(r))&&r._value;if(t==null)return this.tween(r,null);if(typeof t!="function")throw new Error;return this.tween(r,nG(e,t,n??""))}function rG(e){return function(){this.textContent=e}}function iG(e){return function(){var t=e(this);this.textContent=t??""}}function rC(e){return this.tween("text",typeof e=="function"?iG(Pu(this,"text",e)):rG(e==null?"":e+""))}function oG(e){return function(t){this.textContent=e.call(this,t)}}function sG(e){var t,n;function r(){var i=e.apply(this,arguments);return i!==n&&(t=(n=i)&&oG(i)),t}return r._value=e,r}function iC(e){var t="text";if(arguments.length<1)return(t=this.tween(t))&&t._value;if(e==null)return this.tween(t,null);if(typeof e!="function")throw new Error;return this.tween(t,sG(e))}function oC(){for(var e=this._name,t=this._id,n=Nx(),r=this._groups,i=r.length,o=0;o<i;++o)for(var s=r[o],a=s.length,c,l=0;l<a;++l)if(c=s[l]){var u=sn(c,t);Ca(c,e,n,l,s,{time:u.time+u.delay+u.duration,delay:0,duration:u.duration,ease:u.ease})}return new tr(r,this._parents,e,n)}function sC(){var e,t,n=this,r=n._id,i=n.size();return new Promise(function(o,s){var a={value:s},c={value:function(){--i===0&&o()}};n.each(function(){var l=Tn(this,r),u=l.on;u!==e&&(t=(e=u).copy(),t._.cancel.push(a),t._.interrupt.push(a),t._.end.push(c)),l.on=t}),i===0&&o()})}var aG=0;function tr(e,t,n,r){this._groups=e,this._parents=t,this._name=n,this._id=r}function aC(e){return Bs().transition(e)}function Nx(){return++aG}var ks=Bs.prototype;tr.prototype=aC.prototype={constructor:tr,select:JL,selectAll:QL,selectChild:ks.selectChild,selectChildren:ks.selectChildren,filter:GL,merge:WL,selection:KL,transition:oC,call:ks.call,nodes:ks.nodes,node:ks.node,size:ks.size,empty:ks.empty,each:ks.each,on:HL,attr:zL,attrTween:qL,style:eC,styleTween:nC,text:rC,textTween:iC,remove:ZL,tween:UL,delay:jL,duration:VL,ease:YL,easeVarying:XL,end:sC,[Symbol.iterator]:ks[Symbol.iterator]};function Dx(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}var cG={time:null,delay:0,duration:250,ease:Dx};function lG(e,t){for(var n;!(n=e.__transition)||!(n=n[t]);)if(!(e=e.parentNode))throw new Error(`transition ${t} not found`);return n}function cC(e){var t,n;e instanceof tr?(t=e._id,e=e._name):(t=Nx(),(n=cG).time=wp(),e=e==null?null:e+"");for(var r=this._groups,i=r.length,o=0;o<i;++o)for(var s=r[o],a=s.length,c,l=0;l<a;++l)(c=s[l])&&Ca(c,e,t,l,s,n||lG(c,t));return new tr(r,this._parents,e,t)}Bs.prototype.interrupt=PL;Bs.prototype.transition=cC;var Ox=e=>()=>e;function mI(e,{sourceEvent:t,target:n,selection:r,mode:i,dispatch:o}){Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},selection:{value:r,enumerable:!0,configurable:!0},mode:{value:i,enumerable:!0,configurable:!0},_:{value:o}})}function lC(e){e.stopImmediatePropagation()}function Bx(e){e.preventDefault(),e.stopImmediatePropagation()}var uC={name:"drag"},yI={name:"space"},Uu={name:"handle"},zu={name:"center"},{abs:fC,max:Rn,min:$n}=Math;function dC(e){return[+e[0],+e[1]]}function xI(e){return[dC(e[0]),dC(e[1])]}var Lx={name:"x",handles:["w","e"].map(Sp),input:function(e,t){return e==null?null:[[+e[0],t[0][1]],[+e[1],t[1][1]]]},output:function(e){return e&&[e[0][0],e[1][0]]}},Cx={name:"y",handles:["n","s"].map(Sp),input:function(e,t){return e==null?null:[[t[0][0],+e[0]],[t[1][0],+e[1]]]},output:function(e){return e&&[e[0][1],e[1][1]]}},uG={name:"xy",handles:["n","w","e","s","nw","ne","sw","se"].map(Sp),input:function(e){return e==null?null:xI(e)},output:function(e){return e}},Fs={overlay:"crosshair",selection:"move",n:"ns-resize",e:"ew-resize",s:"ns-resize",w:"ew-resize",nw:"nwse-resize",ne:"nesw-resize",se:"nwse-resize",sw:"nesw-resize"},hC={e:"w",w:"e",nw:"ne",ne:"nw",se:"sw",sw:"se"},pC={n:"s",s:"n",nw:"sw",ne:"se",se:"ne",sw:"nw"},fG={overlay:1,selection:1,n:null,e:1,s:null,w:-1,nw:-1,ne:1,se:1,sw:-1},dG={overlay:1,selection:1,n:-1,e:null,s:1,w:null,nw:-1,ne:-1,se:1,sw:1};function Sp(e){return{type:e}}function hG(e){return!e.ctrlKey&&!e.button}function pG(){var e=this.ownerSVGElement||this;return e.hasAttribute("viewBox")?(e=e.viewBox.baseVal,[[e.x,e.y],[e.x+e.width,e.y+e.height]]):[[0,0],[e.width.baseVal.value,e.height.baseVal.value]]}function mG(){return navigator.maxTouchPoints||"ontouchstart"in this}function gI(e){for(;!e.__brush;)if(!(e=e.parentNode))return;return e.__brush}function yG(e){return e[0][0]===e[1][0]||e[0][1]===e[1][1]}function bI(){return _I(Lx)}function wI(){return _I(Cx)}function vI(){return _I(uG)}function _I(e){var t=pG,n=hG,r=mG,i=!0,o=Gc("start","brush","end"),s=6,a;function c(g){var y=g.property("__brush",m).selectAll(".overlay").data([Sp("overlay")]);y.enter().append("rect").attr("class","overlay").attr("pointer-events","all").attr("cursor",Fs.overlay).merge(y).each(function(){var b=gI(this).extent;Vt(this).attr("x",b[0][0]).attr("y",b[0][1]).attr("width",b[1][0]-b[0][0]).attr("height",b[1][1]-b[0][1])}),g.selectAll(".selection").data([Sp("selection")]).enter().append("rect").attr("class","selection").attr("cursor",Fs.selection).attr("fill","#777").attr("fill-opacity",.3).attr("stroke","#fff").attr("shape-rendering","crispEdges");var x=g.selectAll(".handle").data(e.handles,function(b){return b.type});x.exit().remove(),x.enter().append("rect").attr("class",function(b){return"handle handle--"+b.type}).attr("cursor",function(b){return Fs[b.type]}),g.each(l).attr("fill","none").attr("pointer-events","all").on("mousedown.brush",d).filter(r).on("touchstart.brush",d).on("touchmove.brush",h).on("touchend.brush touchcancel.brush",p).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}c.move=function(g,y,x){g.tween?g.on("start.brush",function(b){u(this,arguments).beforestart().start(b)}).on("interrupt.brush end.brush",function(b){u(this,arguments).end(b)}).tween("brush",function(){var b=this,w=b.__brush,v=u(b,arguments),_=w.selection,I=e.input(typeof y=="function"?y.apply(this,arguments):y,w.extent),D=$r(_,I);function A(E){w.selection=E===1&&I===null?null:D(E),l.call(b),v.brush()}return _!==null&&I!==null?A:A(1)}):g.each(function(){var b=this,w=arguments,v=b.__brush,_=e.input(typeof y=="function"?y.apply(b,w):y,v.extent),I=u(b,w).beforestart();go(b),v.selection=_===null?null:_,l.call(b),I.start(x).brush(x).end(x)})},c.clear=function(g,y){c.move(g,null,y)};function l(){var g=Vt(this),y=gI(this).selection;y?(g.selectAll(".selection").style("display",null).attr("x",y[0][0]).attr("y",y[0][1]).attr("width",y[1][0]-y[0][0]).attr("height",y[1][1]-y[0][1]),g.selectAll(".handle").style("display",null).attr("x",function(x){return x.type[x.type.length-1]==="e"?y[1][0]-s/2:y[0][0]-s/2}).attr("y",function(x){return x.type[0]==="s"?y[1][1]-s/2:y[0][1]-s/2}).attr("width",function(x){return x.type==="n"||x.type==="s"?y[1][0]-y[0][0]+s:s}).attr("height",function(x){return x.type==="e"||x.type==="w"?y[1][1]-y[0][1]+s:s})):g.selectAll(".selection,.handle").style("display","none").attr("x",null).attr("y",null).attr("width",null).attr("height",null)}function u(g,y,x){var b=g.__brush.emitter;return b&&(!x||!b.clean)?b:new f(g,y,x)}function f(g,y,x){this.that=g,this.args=y,this.state=g.__brush,this.active=0,this.clean=x}f.prototype={beforestart:function(){return++this.active===1&&(this.state.emitter=this,this.starting=!0),this},start:function(g,y){return this.starting?(this.starting=!1,this.emit("start",g,y)):this.emit("brush",g),this},brush:function(g,y){return this.emit("brush",g,y),this},end:function(g,y){return--this.active===0&&(delete this.state.emitter,this.emit("end",g,y)),this},emit:function(g,y,x){var b=Vt(this.that).datum();o.call(g,this.that,new mI(g,{sourceEvent:y,target:c,selection:e.output(this.state.selection),mode:x,dispatch:o}),b)}};function d(g){if(a&&!g.touches||!n.apply(this,arguments))return;var y=this,x=g.target.__data__.type,b=(i&&g.metaKey?x="overlay":x)==="selection"?uC:i&&g.altKey?zu:Uu,w=e===Cx?null:fG[x],v=e===Lx?null:dG[x],_=gI(y),I=_.extent,D=_.selection,A=I[0][0],E,T,O=I[0][1],C,S,M=I[1][0],N,F,R=I[1][1],k,$,P=0,U=0,W,tt=w&&v&&i&&g.shiftKey,nt,at,Y=Array.from(g.touches||[g],et=>{let ae=et.identifier;return et=kn(et,y),et.point0=et.slice(),et.identifier=ae,et});go(y);var rt=u(y,arguments,!0).beforestart();if(x==="overlay"){D&&(W=!0);let et=[Y[0],Y[1]||Y[0]];_.selection=D=[[E=e===Cx?A:$n(et[0][0],et[1][0]),C=e===Lx?O:$n(et[0][1],et[1][1])],[N=e===Cx?M:Rn(et[0][0],et[1][0]),k=e===Lx?R:Rn(et[0][1],et[1][1])]],Y.length>1&&kt(g)}else E=D[0][0],C=D[0][1],N=D[1][0],k=D[1][1];T=E,S=C,F=N,$=k;var j=Vt(y).attr("pointer-events","none"),H=j.selectAll(".overlay").attr("cursor",Fs[x]);if(g.touches)rt.moved=z,rt.ended=dt;else{var ot=Vt(g.view).on("mousemove.brush",z,!0).on("mouseup.brush",dt,!0);i&&ot.on("keydown.brush",Ht,!0).on("keyup.brush",Zt,!0),ap(g.view)}l.call(y),rt.start(g,b.name);function z(et){for(let ae of et.changedTouches||[et])for(let Sr of Y)Sr.identifier===ae.identifier&&(Sr.cur=kn(ae,y));if(tt&&!nt&&!at&&Y.length===1){let ae=Y[0];fC(ae.cur[0]-ae[0])>fC(ae.cur[1]-ae[1])?at=!0:nt=!0}for(let ae of Y)ae.cur&&(ae[0]=ae.cur[0],ae[1]=ae.cur[1]);W=!0,Bx(et),kt(et)}function kt(et){let ae=Y[0],Sr=ae.point0;var Wi;switch(P=ae[0]-Sr[0],U=ae[1]-Sr[1],b){case yI:case uC:{w&&(P=Rn(A-E,$n(M-N,P)),T=E+P,F=N+P),v&&(U=Rn(O-C,$n(R-k,U)),S=C+U,$=k+U);break}case Uu:{Y[1]?(w&&(T=Rn(A,$n(M,Y[0][0])),F=Rn(A,$n(M,Y[1][0])),w=1),v&&(S=Rn(O,$n(R,Y[0][1])),$=Rn(O,$n(R,Y[1][1])),v=1)):(w<0?(P=Rn(A-E,$n(M-E,P)),T=E+P,F=N):w>0&&(P=Rn(A-N,$n(M-N,P)),T=E,F=N+P),v<0?(U=Rn(O-C,$n(R-C,U)),S=C+U,$=k):v>0&&(U=Rn(O-k,$n(R-k,U)),S=C,$=k+U));break}case zu:{w&&(T=Rn(A,$n(M,E-P*w)),F=Rn(A,$n(M,N+P*w))),v&&(S=Rn(O,$n(R,C-U*v)),$=Rn(O,$n(R,k+U*v)));break}}F<T&&(w*=-1,Wi=E,E=N,N=Wi,Wi=T,T=F,F=Wi,x in hC&&H.attr("cursor",Fs[x=hC[x]])),$<S&&(v*=-1,Wi=C,C=k,k=Wi,Wi=S,S=$,$=Wi,x in pC&&H.attr("cursor",Fs[x=pC[x]])),_.selection&&(D=_.selection),nt&&(T=D[0][0],F=D[1][0]),at&&(S=D[0][1],$=D[1][1]),(D[0][0]!==T||D[0][1]!==S||D[1][0]!==F||D[1][1]!==$)&&(_.selection=[[T,S],[F,$]],l.call(y),rt.brush(et,b.name))}function dt(et){if(lC(et),et.touches){if(et.touches.length)return;a&&clearTimeout(a),a=setTimeout(function(){a=null},500)}else cp(et.view,W),ot.on("keydown.brush keyup.brush mousemove.brush mouseup.brush",null);j.attr("pointer-events","all"),H.attr("cursor",Fs.overlay),_.selection&&(D=_.selection),yG(D)&&(_.selection=null,l.call(y)),rt.end(et,b.name)}function Ht(et){switch(et.keyCode){case 16:{tt=w&&v;break}case 18:{b===Uu&&(w&&(N=F-P*w,E=T+P*w),v&&(k=$-U*v,C=S+U*v),b=zu,kt(et));break}case 32:{(b===Uu||b===zu)&&(w<0?N=F-P:w>0&&(E=T-P),v<0?k=$-U:v>0&&(C=S-U),b=yI,H.attr("cursor",Fs.selection),kt(et));break}default:return}Bx(et)}function Zt(et){switch(et.keyCode){case 16:{tt&&(nt=at=tt=!1,kt(et));break}case 18:{b===zu&&(w<0?N=F:w>0&&(E=T),v<0?k=$:v>0&&(C=S),b=Uu,kt(et));break}case 32:{b===yI&&(et.altKey?(w&&(N=F-P*w,E=T+P*w),v&&(k=$-U*v,C=S+U*v),b=zu):(w<0?N=F:w>0&&(E=T),v<0?k=$:v>0&&(C=S),b=Uu),H.attr("cursor",Fs[x]),kt(et));break}default:return}Bx(et)}}function h(g){u(this,arguments).moved(g)}function p(g){u(this,arguments).ended(g)}function m(){var g=this.__brush||{selection:null};return g.extent=xI(t.apply(this,arguments)),g.dim=e,g}return c.extent=function(g){return arguments.length?(t=typeof g=="function"?g:Ox(xI(g)),c):t},c.filter=function(g){return arguments.length?(n=typeof g=="function"?g:Ox(!!g),c):n},c.touchable=function(g){return arguments.length?(r=typeof g=="function"?g:Ox(!!g),c):r},c.handleSize=function(g){return arguments.length?(s=+g,c):s},c.keyModifiers=function(g){return arguments.length?(i=!!g,c):i},c.on=function(){var g=o.on.apply(o,arguments);return g===o?c:g},c}var SI=Math.PI,II=2*SI,el=1e-6,gG=II-el;function mC(e){this._+=e[0];for(let t=1,n=e.length;t<n;++t)this._+=arguments[t]+e[t]}function xG(e){let t=Math.floor(e);if(!(t>=0))throw new Error(`invalid digits: ${e}`);if(t>15)return mC;let n=10**t;return function(r){this._+=r[0];for(let i=1,o=r.length;i<o;++i)this._+=Math.round(arguments[i]*n)/n+r[i]}}var ka=class{constructor(t){this._x0=this._y0=this._x1=this._y1=null,this._="",this._append=t==null?mC:xG(t)}moveTo(t,n){this._append`M${this._x0=this._x1=+t},${this._y0=this._y1=+n}`}closePath(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._append`Z`)}lineTo(t,n){this._append`L${this._x1=+t},${this._y1=+n}`}quadraticCurveTo(t,n,r,i){this._append`Q${+t},${+n},${this._x1=+r},${this._y1=+i}`}bezierCurveTo(t,n,r,i,o,s){this._append`C${+t},${+n},${+r},${+i},${this._x1=+o},${this._y1=+s}`}arcTo(t,n,r,i,o){if(t=+t,n=+n,r=+r,i=+i,o=+o,o<0)throw new Error(`negative radius: ${o}`);let s=this._x1,a=this._y1,c=r-t,l=i-n,u=s-t,f=a-n,d=u*u+f*f;if(this._x1===null)this._append`M${this._x1=t},${this._y1=n}`;else if(d>el)if(!(Math.abs(f*c-l*u)>el)||!o)this._append`L${this._x1=t},${this._y1=n}`;else{let h=r-s,p=i-a,m=c*c+l*l,g=h*h+p*p,y=Math.sqrt(m),x=Math.sqrt(d),b=o*Math.tan((SI-Math.acos((m+d-g)/(2*y*x)))/2),w=b/x,v=b/y;Math.abs(w-1)>el&&this._append`L${t+w*u},${n+w*f}`,this._append`A${o},${o},0,0,${+(f*h>u*p)},${this._x1=t+v*c},${this._y1=n+v*l}`}}arc(t,n,r,i,o,s){if(t=+t,n=+n,r=+r,s=!!s,r<0)throw new Error(`negative radius: ${r}`);let a=r*Math.cos(i),c=r*Math.sin(i),l=t+a,u=n+c,f=1^s,d=s?i-o:o-i;this._x1===null?this._append`M${l},${u}`:(Math.abs(this._x1-l)>el||Math.abs(this._y1-u)>el)&&this._append`L${l},${u}`,r&&(d<0&&(d=d%II+II),d>gG?this._append`A${r},${r},0,1,${f},${t-a},${n-c}A${r},${r},0,1,${f},${this._x1=l},${this._y1=u}`:d>el&&this._append`A${r},${r},0,${+(d>=SI)},${f},${this._x1=t+r*Math.cos(o)},${this._y1=n+r*Math.sin(o)}`)}rect(t,n,r,i){this._append`M${this._x0=this._x1=+t},${this._y0=this._y1=+n}h${r=+r}v${+i}h${-r}Z`}toString(){return this._}};function yC(){return new ka}yC.prototype=ka.prototype;function er(e=3){return new ka(+e)}var bG=Array.prototype,kx=bG.slice;function gC(e,t){return e-t}function xC(e){for(var t=0,n=e.length,r=e[n-1][1]*e[0][0]-e[n-1][0]*e[0][1];++t<n;)r+=e[t-1][1]*e[t][0]-e[t-1][0]*e[t][1];return r}var xo=e=>()=>e;function bC(e,t){for(var n=-1,r=t.length,i;++n<r;)if(i=wG(e,t[n]))return i;return 0}function wG(e,t){for(var n=t[0],r=t[1],i=-1,o=0,s=e.length,a=s-1;o<s;a=o++){var c=e[o],l=c[0],u=c[1],f=e[a],d=f[0],h=f[1];if(vG(c,f,t))return 0;u>r!=h>r&&n<(d-l)*(r-u)/(h-u)+l&&(i=-i)}return i}function vG(e,t,n){var r;return _G(e,t,n)&&SG(e[r=+(e[0]===t[0])],n[r],t[r])}function _G(e,t,n){return(t[0]-e[0])*(n[1]-e[1])===(n[0]-e[0])*(t[1]-e[1])}function SG(e,t,n){return e<=t&&t<=n||n<=t&&t<=e}function wC(){}var Rs=[[],[[[1,1.5],[.5,1]]],[[[1.5,1],[1,1.5]]],[[[1.5,1],[.5,1]]],[[[1,.5],[1.5,1]]],[[[1,1.5],[.5,1]],[[1,.5],[1.5,1]]],[[[1,.5],[1,1.5]]],[[[1,.5],[.5,1]]],[[[.5,1],[1,.5]]],[[[1,1.5],[1,.5]]],[[[.5,1],[1,.5]],[[1.5,1],[1,1.5]]],[[[1.5,1],[1,.5]]],[[[.5,1],[1.5,1]]],[[[1,1.5],[1.5,1]]],[[[.5,1],[1,1.5]]],[]];function Fa(){var e=1,t=1,n=Na,r=c;function i(l){var u=n(l);if(Array.isArray(u))u=u.slice().sort(gC);else{let f=le(l,IG);for(u=Mn(...Nu(f[0],f[1],u),u);u[u.length-1]>=f[1];)u.pop();for(;u[1]<f[0];)u.shift()}return u.map(f=>o(l,f))}function o(l,u){let f=u==null?NaN:+u;if(isNaN(f))throw new Error(`invalid value: ${u}`);var d=[],h=[];return s(l,f,function(p){r(p,l,f),xC(p)>0?d.push([p]):h.push(p)}),h.forEach(function(p){for(var m=0,g=d.length,y;m<g;++m)if(bC((y=d[m])[0],p)!==-1){y.push(p);return}}),{type:"MultiPolygon",value:u,coordinates:d}}function s(l,u,f){var d=new Array,h=new Array,p,m,g,y,x,b;for(p=m=-1,y=nl(l[0],u),Rs[y<<1].forEach(w);++p<e-1;)g=y,y=nl(l[p+1],u),Rs[g|y<<1].forEach(w);for(Rs[y<<0].forEach(w);++m<t-1;){for(p=-1,y=nl(l[m*e+e],u),x=nl(l[m*e],u),Rs[y<<1|x<<2].forEach(w);++p<e-1;)g=y,y=nl(l[m*e+e+p+1],u),b=x,x=nl(l[m*e+p+1],u),Rs[g|y<<1|x<<2|b<<3].forEach(w);Rs[y|x<<3].forEach(w)}for(p=-1,x=l[m*e]>=u,Rs[x<<2].forEach(w);++p<e-1;)b=x,x=nl(l[m*e+p+1],u),Rs[x<<2|b<<3].forEach(w);Rs[x<<3].forEach(w);function w(v){var _=[v[0][0]+p,v[0][1]+m],I=[v[1][0]+p,v[1][1]+m],D=a(_),A=a(I),E,T;(E=h[D])?(T=d[A])?(delete h[E.end],delete d[T.start],E===T?(E.ring.push(I),f(E.ring)):d[E.start]=h[T.end]={start:E.start,end:T.end,ring:E.ring.concat(T.ring)}):(delete h[E.end],E.ring.push(I),h[E.end=A]=E):(E=d[A])?(T=h[D])?(delete d[E.start],delete h[T.end],E===T?(E.ring.push(I),f(E.ring)):d[T.start]=h[E.end]={start:T.start,end:E.end,ring:T.ring.concat(E.ring)}):(delete d[E.start],E.ring.unshift(_),d[E.start=D]=E):d[D]=h[A]={start:D,end:A,ring:[_,I]}}}function a(l){return l[0]*2+l[1]*(e+1)*4}function c(l,u,f){l.forEach(function(d){var h=d[0],p=d[1],m=h|0,g=p|0,y=MI(u[g*e+m]);h>0&&h<e&&m===h&&(d[0]=vC(h,MI(u[g*e+m-1]),y,f)),p>0&&p<t&&g===p&&(d[1]=vC(p,MI(u[(g-1)*e+m]),y,f))})}return i.contour=o,i.size=function(l){if(!arguments.length)return[e,t];var u=Math.floor(l[0]),f=Math.floor(l[1]);if(!(u>=0&&f>=0))throw new Error("invalid size");return e=u,t=f,i},i.thresholds=function(l){return arguments.length?(n=typeof l=="function"?l:Array.isArray(l)?xo(kx.call(l)):xo(l),i):n},i.smooth=function(l){return arguments.length?(r=l?c:wC,i):r===c},i}function IG(e){return isFinite(e)?e:NaN}function nl(e,t){return e==null?!1:+e>=t}function MI(e){return e==null||isNaN(e=+e)?-1/0:e}function vC(e,t,n,r){let i=r-t,o=n-t,s=isFinite(i)||isFinite(o)?i/o:Math.sign(i)/Math.sign(o);return isNaN(s)?e:e+s-.5}function MG(e){return e[0]}function AG(e){return e[1]}function TG(){return 1}function AI(){var e=MG,t=AG,n=TG,r=960,i=500,o=20,s=2,a=o*3,c=r+a*2>>s,l=i+a*2>>s,u=xo(20);function f(x){var b=new Float32Array(c*l),w=Math.pow(2,-s),v=-1;for(let C of x){var _=(e(C,++v,x)+a)*w,I=(t(C,v,x)+a)*w,D=+n(C,v,x);if(D&&_>=0&&_<c&&I>=0&&I<l){var A=Math.floor(_),E=Math.floor(I),T=_-A-.5,O=I-E-.5;b[A+E*c]+=(1-T)*(1-O)*D,b[A+1+E*c]+=T*(1-O)*D,b[A+1+(E+1)*c]+=T*O*D,b[A+(E+1)*c]+=(1-T)*O*D}}return Qh({data:b,width:c,height:l},o*w),b}function d(x){var b=f(x),w=u(b),v=Math.pow(2,2*s);return Array.isArray(w)||(w=Mn(Number.MIN_VALUE,Wt(b)/v,w)),Fa().size([c,l]).thresholds(w.map(_=>_*v))(b).map((_,I)=>(_.value=+w[I],h(_)))}d.contours=function(x){var b=f(x),w=Fa().size([c,l]),v=Math.pow(2,2*s),_=I=>{I=+I;var D=h(w.contour(b,I*v));return D.value=I,D};return Object.defineProperty(_,"max",{get:()=>Wt(b)/v}),_};function h(x){return x.coordinates.forEach(p),x}function p(x){x.forEach(m)}function m(x){x.forEach(g)}function g(x){x[0]=x[0]*Math.pow(2,s)-a,x[1]=x[1]*Math.pow(2,s)-a}function y(){return a=o*3,c=r+a*2>>s,l=i+a*2>>s,d}return d.x=function(x){return arguments.length?(e=typeof x=="function"?x:xo(+x),d):e},d.y=function(x){return arguments.length?(t=typeof x=="function"?x:xo(+x),d):t},d.weight=function(x){return arguments.length?(n=typeof x=="function"?x:xo(+x),d):n},d.size=function(x){if(!arguments.length)return[r,i];var b=+x[0],w=+x[1];if(!(b>=0&&w>=0))throw new Error("invalid size");return r=b,i=w,y()},d.cellSize=function(x){if(!arguments.length)return 1<<s;if(!((x=+x)>=1))throw new Error("invalid cell size");return s=Math.floor(Math.log(x)/Math.LN2),y()},d.thresholds=function(x){return arguments.length?(u=typeof x=="function"?x:Array.isArray(x)?xo(kx.call(x)):xo(x),d):u},d.bandwidth=function(x){if(!arguments.length)return Math.sqrt(o*(o+1));if(!((x=+x)>=0))throw new Error("invalid bandwidth");return o=(Math.sqrt(4*x*x+1)-1)/2,y()},d}var Kt=11102230246251565e-32,We=134217729,Ip=(3+8*Kt)*Kt;function rl(e,t,n,r,i){let o,s,a,c,l=t[0],u=r[0],f=0,d=0;u>l==u>-l?(o=l,l=t[++f]):(o=u,u=r[++d]);let h=0;if(f<e&&d<n)for(u>l==u>-l?(s=l+o,a=o-(s-l),l=t[++f]):(s=u+o,a=o-(s-u),u=r[++d]),o=s,a!==0&&(i[h++]=a);f<e&&d<n;)u>l==u>-l?(s=o+l,c=s-o,a=o-(s-c)+(l-c),l=t[++f]):(s=o+u,c=s-o,a=o-(s-c)+(u-c),u=r[++d]),o=s,a!==0&&(i[h++]=a);for(;f<e;)s=o+l,c=s-o,a=o-(s-c)+(l-c),l=t[++f],o=s,a!==0&&(i[h++]=a);for(;d<n;)s=o+u,c=s-o,a=o-(s-c)+(u-c),u=r[++d],o=s,a!==0&&(i[h++]=a);return(o!==0||h===0)&&(i[h++]=o),h}function Mp(e,t){let n=t[0];for(let r=1;r<e;r++)n+=t[r];return n}function V(e){return new Float64Array(e)}var EG=(3+16*Kt)*Kt,NG=(2+12*Kt)*Kt,DG=(9+64*Kt)*Kt*Kt,qu=V(4),_C=V(8),SC=V(12),IC=V(16),nr=V(4);function OG(e,t,n,r,i,o,s){let a,c,l,u,f,d,h,p,m,g,y,x,b,w,v,_,I,D,A=e-i,E=n-i,T=t-o,O=r-o;w=A*O,d=We*A,h=d-(d-A),p=A-h,d=We*O,m=d-(d-O),g=O-m,v=p*g-(w-h*m-p*m-h*g),_=T*E,d=We*T,h=d-(d-T),p=T-h,d=We*E,m=d-(d-E),g=E-m,I=p*g-(_-h*m-p*m-h*g),y=v-I,f=v-y,qu[0]=v-(y+f)+(f-I),x=w+y,f=x-w,b=w-(x-f)+(y-f),y=b-_,f=b-y,qu[1]=b-(y+f)+(f-_),D=x+y,f=D-x,qu[2]=x-(D-f)+(y-f),qu[3]=D;let C=Mp(4,qu),S=NG*s;if(C>=S||-C>=S||(f=e-A,a=e-(A+f)+(f-i),f=n-E,l=n-(E+f)+(f-i),f=t-T,c=t-(T+f)+(f-o),f=r-O,u=r-(O+f)+(f-o),a===0&&c===0&&l===0&&u===0)||(S=DG*s+Ip*Math.abs(C),C+=A*u+O*a-(T*l+E*c),C>=S||-C>=S))return C;w=a*O,d=We*a,h=d-(d-a),p=a-h,d=We*O,m=d-(d-O),g=O-m,v=p*g-(w-h*m-p*m-h*g),_=c*E,d=We*c,h=d-(d-c),p=c-h,d=We*E,m=d-(d-E),g=E-m,I=p*g-(_-h*m-p*m-h*g),y=v-I,f=v-y,nr[0]=v-(y+f)+(f-I),x=w+y,f=x-w,b=w-(x-f)+(y-f),y=b-_,f=b-y,nr[1]=b-(y+f)+(f-_),D=x+y,f=D-x,nr[2]=x-(D-f)+(y-f),nr[3]=D;let M=rl(4,qu,4,nr,_C);w=A*u,d=We*A,h=d-(d-A),p=A-h,d=We*u,m=d-(d-u),g=u-m,v=p*g-(w-h*m-p*m-h*g),_=T*l,d=We*T,h=d-(d-T),p=T-h,d=We*l,m=d-(d-l),g=l-m,I=p*g-(_-h*m-p*m-h*g),y=v-I,f=v-y,nr[0]=v-(y+f)+(f-I),x=w+y,f=x-w,b=w-(x-f)+(y-f),y=b-_,f=b-y,nr[1]=b-(y+f)+(f-_),D=x+y,f=D-x,nr[2]=x-(D-f)+(y-f),nr[3]=D;let N=rl(M,_C,4,nr,SC);w=a*u,d=We*a,h=d-(d-a),p=a-h,d=We*u,m=d-(d-u),g=u-m,v=p*g-(w-h*m-p*m-h*g),_=c*l,d=We*c,h=d-(d-c),p=c-h,d=We*l,m=d-(d-l),g=l-m,I=p*g-(_-h*m-p*m-h*g),y=v-I,f=v-y,nr[0]=v-(y+f)+(f-I),x=w+y,f=x-w,b=w-(x-f)+(y-f),y=b-_,f=b-y,nr[1]=b-(y+f)+(f-_),D=x+y,f=D-x,nr[2]=x-(D-f)+(y-f),nr[3]=D;let F=rl(N,SC,4,nr,IC);return IC[F-1]}function ju(e,t,n,r,i,o){let s=(t-o)*(n-i),a=(e-i)*(r-o),c=s-a,l=Math.abs(s+a);return Math.abs(c)>=EG*l?c:-OG(e,t,n,r,i,o,l)}var n_t=(7+56*Kt)*Kt,r_t=(3+28*Kt)*Kt,i_t=(26+288*Kt)*Kt*Kt,o_t=V(4),s_t=V(4),a_t=V(4),c_t=V(4),l_t=V(4),u_t=V(4),f_t=V(4),d_t=V(4),h_t=V(4),p_t=V(8),m_t=V(8),y_t=V(8),g_t=V(4),x_t=V(8),b_t=V(8),w_t=V(8),v_t=V(12),__t=V(192),S_t=V(192);var A_t=(10+96*Kt)*Kt,T_t=(4+48*Kt)*Kt,E_t=(44+576*Kt)*Kt*Kt,N_t=V(4),D_t=V(4),O_t=V(4),B_t=V(4),L_t=V(4),C_t=V(4),k_t=V(4),F_t=V(4),R_t=V(8),$_t=V(8),P_t=V(8),U_t=V(8),z_t=V(8),q_t=V(8),j_t=V(8),V_t=V(8),Y_t=V(8),X_t=V(4),G_t=V(4),W_t=V(4),H_t=V(8),Z_t=V(16),J_t=V(16),Q_t=V(16),K_t=V(32),t2t=V(32),e2t=V(48),n2t=V(64),r2t=V(1152),i2t=V(1152);var c2t=(16+224*Kt)*Kt,l2t=(5+72*Kt)*Kt,u2t=(71+1408*Kt)*Kt*Kt,f2t=V(4),d2t=V(4),h2t=V(4),p2t=V(4),m2t=V(4),y2t=V(4),g2t=V(4),x2t=V(4),b2t=V(4),w2t=V(4),v2t=V(24),_2t=V(24),S2t=V(24),I2t=V(24),M2t=V(24),A2t=V(24),T2t=V(24),E2t=V(24),N2t=V(24),D2t=V(24),O2t=V(1152),B2t=V(1152),L2t=V(1152),C2t=V(1152),k2t=V(1152),F2t=V(2304),R2t=V(2304),$2t=V(3456),P2t=V(5760),U2t=V(8),z2t=V(8),q2t=V(8),j2t=V(16),V2t=V(24),Y2t=V(48),X2t=V(48),G2t=V(96),W2t=V(192),H2t=V(384),Z2t=V(384),J2t=V(384),Q2t=V(768);var K2t=V(96),tSt=V(96),eSt=V(96),nSt=V(1152);var AC=Math.pow(2,-52),Fx=new Uint32Array(512),Yu=class e{static from(t,n=RG,r=$G){let i=t.length,o=new Float64Array(i*2);for(let s=0;s<i;s++){let a=t[s];o[2*s]=n(a),o[2*s+1]=r(a)}return new e(o)}constructor(t){let n=t.length>>1;if(n>0&&typeof t[0]!="number")throw new Error("Expected coords to contain numbers.");this.coords=t;let r=Math.max(2*n-5,0);this._triangles=new Uint32Array(r*3),this._halfedges=new Int32Array(r*3),this._hashSize=Math.ceil(Math.sqrt(n)),this._hullPrev=new Uint32Array(n),this._hullNext=new Uint32Array(n),this._hullTri=new Uint32Array(n),this._hullHash=new Int32Array(this._hashSize),this._ids=new Uint32Array(n),this._dists=new Float64Array(n),this.update()}update(){let{coords:t,_hullPrev:n,_hullNext:r,_hullTri:i,_hullHash:o}=this,s=t.length>>1,a=1/0,c=1/0,l=-1/0,u=-1/0;for(let A=0;A<s;A++){let E=t[2*A],T=t[2*A+1];E<a&&(a=E),T<c&&(c=T),E>l&&(l=E),T>u&&(u=T),this._ids[A]=A}let f=(a+l)/2,d=(c+u)/2,h,p,m;for(let A=0,E=1/0;A<s;A++){let T=TI(f,d,t[2*A],t[2*A+1]);T<E&&(h=A,E=T)}let g=t[2*h],y=t[2*h+1];for(let A=0,E=1/0;A<s;A++){if(A===h)continue;let T=TI(g,y,t[2*A],t[2*A+1]);T<E&&T>0&&(p=A,E=T)}let x=t[2*p],b=t[2*p+1],w=1/0;for(let A=0;A<s;A++){if(A===h||A===p)continue;let E=kG(g,y,x,b,t[2*A],t[2*A+1]);E<w&&(m=A,w=E)}let v=t[2*m],_=t[2*m+1];if(w===1/0){for(let T=0;T<s;T++)this._dists[T]=t[2*T]-t[0]||t[2*T+1]-t[1];Vu(this._ids,this._dists,0,s-1);let A=new Uint32Array(s),E=0;for(let T=0,O=-1/0;T<s;T++){let C=this._ids[T],S=this._dists[C];S>O&&(A[E++]=C,O=S)}this.hull=A.subarray(0,E),this.triangles=new Uint32Array(0),this.halfedges=new Uint32Array(0);return}if(ju(g,y,x,b,v,_)<0){let A=p,E=x,T=b;p=m,x=v,b=_,m=A,v=E,_=T}let I=FG(g,y,x,b,v,_);this._cx=I.x,this._cy=I.y;for(let A=0;A<s;A++)this._dists[A]=TI(t[2*A],t[2*A+1],I.x,I.y);Vu(this._ids,this._dists,0,s-1),this._hullStart=h;let D=3;r[h]=n[m]=p,r[p]=n[h]=m,r[m]=n[p]=h,i[h]=0,i[p]=1,i[m]=2,o.fill(-1),o[this._hashKey(g,y)]=h,o[this._hashKey(x,b)]=p,o[this._hashKey(v,_)]=m,this.trianglesLen=0,this._addTriangle(h,p,m,-1,-1,-1);for(let A=0,E,T;A<this._ids.length;A++){let O=this._ids[A],C=t[2*O],S=t[2*O+1];if(A>0&&Math.abs(C-E)<=AC&&Math.abs(S-T)<=AC||(E=C,T=S,O===h||O===p||O===m))continue;let M=0;for(let $=0,P=this._hashKey(C,S);$<this._hashSize&&(M=o[(P+$)%this._hashSize],!(M!==-1&&M!==r[M]));$++);M=n[M];let N=M,F;for(;F=r[N],ju(C,S,t[2*N],t[2*N+1],t[2*F],t[2*F+1])>=0;)if(N=F,N===M){N=-1;break}if(N===-1)continue;let R=this._addTriangle(N,O,r[N],-1,-1,i[N]);i[O]=this._legalize(R+2),i[N]=R,D++;let k=r[N];for(;F=r[k],ju(C,S,t[2*k],t[2*k+1],t[2*F],t[2*F+1])<0;)R=this._addTriangle(k,O,F,i[O],-1,i[k]),i[O]=this._legalize(R+2),r[k]=k,D--,k=F;if(N===M)for(;F=n[N],ju(C,S,t[2*F],t[2*F+1],t[2*N],t[2*N+1])<0;)R=this._addTriangle(F,O,N,-1,i[N],i[F]),this._legalize(R+2),i[F]=R,r[N]=N,D--,N=F;this._hullStart=n[O]=N,r[N]=n[k]=O,r[O]=k,o[this._hashKey(C,S)]=O,o[this._hashKey(t[2*N],t[2*N+1])]=N}this.hull=new Uint32Array(D);for(let A=0,E=this._hullStart;A<D;A++)this.hull[A]=E,E=r[E];this.triangles=this._triangles.subarray(0,this.trianglesLen),this.halfedges=this._halfedges.subarray(0,this.trianglesLen)}_hashKey(t,n){return Math.floor(LG(t-this._cx,n-this._cy)*this._hashSize)%this._hashSize}_legalize(t){let{_triangles:n,_halfedges:r,coords:i}=this,o=0,s=0;for(;;){let a=r[t],c=t-t%3;if(s=c+(t+2)%3,a===-1){if(o===0)break;t=Fx[--o];continue}let l=a-a%3,u=c+(t+1)%3,f=l+(a+2)%3,d=n[s],h=n[t],p=n[u],m=n[f];if(CG(i[2*d],i[2*d+1],i[2*h],i[2*h+1],i[2*p],i[2*p+1],i[2*m],i[2*m+1])){n[t]=m,n[a]=d;let y=r[f];if(y===-1){let b=this._hullStart;do{if(this._hullTri[b]===f){this._hullTri[b]=t;break}b=this._hullPrev[b]}while(b!==this._hullStart)}this._link(t,y),this._link(a,r[s]),this._link(s,f);let x=l+(a+1)%3;o<Fx.length&&(Fx[o++]=x)}else{if(o===0)break;t=Fx[--o]}}return s}_link(t,n){this._halfedges[t]=n,n!==-1&&(this._halfedges[n]=t)}_addTriangle(t,n,r,i,o,s){let a=this.trianglesLen;return this._triangles[a]=t,this._triangles[a+1]=n,this._triangles[a+2]=r,this._link(a,i),this._link(a+1,o),this._link(a+2,s),this.trianglesLen+=3,a}};function LG(e,t){let n=e/(Math.abs(e)+Math.abs(t));return(t>0?3-n:1+n)/4}function TI(e,t,n,r){let i=e-n,o=t-r;return i*i+o*o}function CG(e,t,n,r,i,o,s,a){let c=e-s,l=t-a,u=n-s,f=r-a,d=i-s,h=o-a,p=c*c+l*l,m=u*u+f*f,g=d*d+h*h;return c*(f*g-m*h)-l*(u*g-m*d)+p*(u*h-f*d)<0}function kG(e,t,n,r,i,o){let s=n-e,a=r-t,c=i-e,l=o-t,u=s*s+a*a,f=c*c+l*l,d=.5/(s*l-a*c),h=(l*u-a*f)*d,p=(s*f-c*u)*d;return h*h+p*p}function FG(e,t,n,r,i,o){let s=n-e,a=r-t,c=i-e,l=o-t,u=s*s+a*a,f=c*c+l*l,d=.5/(s*l-a*c),h=e+(l*u-a*f)*d,p=t+(s*f-c*u)*d;return{x:h,y:p}}function Vu(e,t,n,r){if(r-n<=20)for(let i=n+1;i<=r;i++){let o=e[i],s=t[o],a=i-1;for(;a>=n&&t[e[a]]>s;)e[a+1]=e[a--];e[a+1]=o}else{let i=n+r>>1,o=n+1,s=r;Ap(e,i,o),t[e[n]]>t[e[r]]&&Ap(e,n,r),t[e[o]]>t[e[r]]&&Ap(e,o,r),t[e[n]]>t[e[o]]&&Ap(e,n,o);let a=e[o],c=t[a];for(;;){do o++;while(t[e[o]]<c);do s--;while(t[e[s]]>c);if(s<o)break;Ap(e,o,s)}e[n+1]=e[s],e[s]=a,r-o+1>=s-n?(Vu(e,t,o,r),Vu(e,t,n,s-1)):(Vu(e,t,n,s-1),Vu(e,t,o,r))}}function Ap(e,t,n){let r=e[t];e[t]=e[n],e[n]=r}function RG(e){return e[0]}function $G(e){return e[1]}var ai=class{constructor(){this._x0=this._y0=this._x1=this._y1=null,this._=""}moveTo(t,n){this._+=`M${this._x0=this._x1=+t},${this._y0=this._y1=+n}`}closePath(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")}lineTo(t,n){this._+=`L${this._x1=+t},${this._y1=+n}`}arc(t,n,r){t=+t,n=+n,r=+r;let i=t+r,o=n;if(r<0)throw new Error("negative radius");this._x1===null?this._+=`M${i},${o}`:(Math.abs(this._x1-i)>1e-6||Math.abs(this._y1-o)>1e-6)&&(this._+="L"+i+","+o),r&&(this._+=`A${r},${r},0,1,1,${t-r},${n}A${r},${r},0,1,1,${this._x1=i},${this._y1=o}`)}rect(t,n,r,i){this._+=`M${this._x0=this._x1=+t},${this._y0=this._y1=+n}h${+r}v${+i}h${-r}Z`}value(){return this._||null}};var Ra=class{constructor(){this._=[]}moveTo(t,n){this._.push([t,n])}closePath(){this._.push(this._[0].slice())}lineTo(t,n){this._.push([t,n])}value(){return this._.length?this._:null}};var Tp=class{constructor(t,[n,r,i,o]=[0,0,960,500]){if(!((i=+i)>=(n=+n))||!((o=+o)>=(r=+r)))throw new Error("invalid bounds");this.delaunay=t,this._circumcenters=new Float64Array(t.points.length*2),this.vectors=new Float64Array(t.points.length*2),this.xmax=i,this.xmin=n,this.ymax=o,this.ymin=r,this._init()}update(){return this.delaunay.update(),this._init(),this}_init(){let{delaunay:{points:t,hull:n,triangles:r},vectors:i}=this,o,s,a=this.circumcenters=this._circumcenters.subarray(0,r.length/3*2);for(let m=0,g=0,y=r.length,x,b;m<y;m+=3,g+=2){let w=r[m]*2,v=r[m+1]*2,_=r[m+2]*2,I=t[w],D=t[w+1],A=t[v],E=t[v+1],T=t[_],O=t[_+1],C=A-I,S=E-D,M=T-I,N=O-D,F=(C*N-S*M)*2;if(Math.abs(F)<1e-9){if(o===void 0){o=s=0;for(let k of n)o+=t[k*2],s+=t[k*2+1];o/=n.length,s/=n.length}let R=1e9*Math.sign((o-I)*N-(s-D)*M);x=(I+T)/2-R*N,b=(D+O)/2+R*M}else{let R=1/F,k=C*C+S*S,$=M*M+N*N;x=I+(N*k-S*$)*R,b=D+(C*$-M*k)*R}a[g]=x,a[g+1]=b}let c=n[n.length-1],l,u=c*4,f,d=t[2*c],h,p=t[2*c+1];i.fill(0);for(let m=0;m<n.length;++m)c=n[m],l=u,f=d,h=p,u=c*4,d=t[2*c],p=t[2*c+1],i[l+2]=i[u]=h-p,i[l+3]=i[u+1]=d-f}render(t){let n=t==null?t=new ai:void 0,{delaunay:{halfedges:r,inedges:i,hull:o},circumcenters:s,vectors:a}=this;if(o.length<=1)return null;for(let u=0,f=r.length;u<f;++u){let d=r[u];if(d<u)continue;let h=Math.floor(u/3)*2,p=Math.floor(d/3)*2,m=s[h],g=s[h+1],y=s[p],x=s[p+1];this._renderSegment(m,g,y,x,t)}let c,l=o[o.length-1];for(let u=0;u<o.length;++u){c=l,l=o[u];let f=Math.floor(i[l]/3)*2,d=s[f],h=s[f+1],p=c*4,m=this._project(d,h,a[p+2],a[p+3]);m&&this._renderSegment(d,h,m[0],m[1],t)}return n&&n.value()}renderBounds(t){let n=t==null?t=new ai:void 0;return t.rect(this.xmin,this.ymin,this.xmax-this.xmin,this.ymax-this.ymin),n&&n.value()}renderCell(t,n){let r=n==null?n=new ai:void 0,i=this._clip(t);if(i===null||!i.length)return;n.moveTo(i[0],i[1]);let o=i.length;for(;i[0]===i[o-2]&&i[1]===i[o-1]&&o>1;)o-=2;for(let s=2;s<o;s+=2)(i[s]!==i[s-2]||i[s+1]!==i[s-1])&&n.lineTo(i[s],i[s+1]);return n.closePath(),r&&r.value()}*cellPolygons(){let{delaunay:{points:t}}=this;for(let n=0,r=t.length/2;n<r;++n){let i=this.cellPolygon(n);i&&(i.index=n,yield i)}}cellPolygon(t){let n=new Ra;return this.renderCell(t,n),n.value()}_renderSegment(t,n,r,i,o){let s,a=this._regioncode(t,n),c=this._regioncode(r,i);a===0&&c===0?(o.moveTo(t,n),o.lineTo(r,i)):(s=this._clipSegment(t,n,r,i,a,c))&&(o.moveTo(s[0],s[1]),o.lineTo(s[2],s[3]))}contains(t,n,r){return n=+n,n!==n||(r=+r,r!==r)?!1:this.delaunay._step(t,n,r)===t}*neighbors(t){let n=this._clip(t);if(n)for(let r of this.delaunay.neighbors(t)){let i=this._clip(r);if(i){t:for(let o=0,s=n.length;o<s;o+=2)for(let a=0,c=i.length;a<c;a+=2)if(n[o]===i[a]&&n[o+1]===i[a+1]&&n[(o+2)%s]===i[(a+c-2)%c]&&n[(o+3)%s]===i[(a+c-1)%c]){yield r;break t}}}}_cell(t){let{circumcenters:n,delaunay:{inedges:r,halfedges:i,triangles:o}}=this,s=r[t];if(s===-1)return null;let a=[],c=s;do{let l=Math.floor(c/3);if(a.push(n[l*2],n[l*2+1]),c=c%3===2?c-2:c+1,o[c]!==t)break;c=i[c]}while(c!==s&&c!==-1);return a}_clip(t){if(t===0&&this.delaunay.hull.length===1)return[this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax,this.xmin,this.ymin];let n=this._cell(t);if(n===null)return null;let{vectors:r}=this,i=t*4;return this._simplify(r[i]||r[i+1]?this._clipInfinite(t,n,r[i],r[i+1],r[i+2],r[i+3]):this._clipFinite(t,n))}_clipFinite(t,n){let r=n.length,i=null,o,s,a=n[r-2],c=n[r-1],l,u=this._regioncode(a,c),f,d=0;for(let h=0;h<r;h+=2)if(o=a,s=c,a=n[h],c=n[h+1],l=u,u=this._regioncode(a,c),l===0&&u===0)f=d,d=0,i?i.push(a,c):i=[a,c];else{let p,m,g,y,x;if(l===0){if((p=this._clipSegment(o,s,a,c,l,u))===null)continue;[m,g,y,x]=p}else{if((p=this._clipSegment(a,c,o,s,u,l))===null)continue;[y,x,m,g]=p,f=d,d=this._edgecode(m,g),f&&d&&this._edge(t,f,d,i,i.length),i?i.push(m,g):i=[m,g]}f=d,d=this._edgecode(y,x),f&&d&&this._edge(t,f,d,i,i.length),i?i.push(y,x):i=[y,x]}if(i)f=d,d=this._edgecode(i[0],i[1]),f&&d&&this._edge(t,f,d,i,i.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 i}_clipSegment(t,n,r,i,o,s){let a=o<s;for(a&&([t,n,r,i,o,s]=[r,i,t,n,s,o]);;){if(o===0&&s===0)return a?[r,i,t,n]:[t,n,r,i];if(o&s)return null;let c,l,u=o||s;u&8?(c=t+(r-t)*(this.ymax-n)/(i-n),l=this.ymax):u&4?(c=t+(r-t)*(this.ymin-n)/(i-n),l=this.ymin):u&2?(l=n+(i-n)*(this.xmax-t)/(r-t),c=this.xmax):(l=n+(i-n)*(this.xmin-t)/(r-t),c=this.xmin),o?(t=c,n=l,o=this._regioncode(t,n)):(r=c,i=l,s=this._regioncode(r,i))}}_clipInfinite(t,n,r,i,o,s){let a=Array.from(n),c;if((c=this._project(a[0],a[1],r,i))&&a.unshift(c[0],c[1]),(c=this._project(a[a.length-2],a[a.length-1],o,s))&&a.push(c[0],c[1]),a=this._clipFinite(t,a))for(let l=0,u=a.length,f,d=this._edgecode(a[u-2],a[u-1]);l<u;l+=2)f=d,d=this._edgecode(a[l],a[l+1]),f&&d&&(l=this._edge(t,f,d,a,l),u=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,n,r,i,o){for(;n!==r;){let s,a;switch(n){case 5:n=4;continue;case 4:n=6,s=this.xmax,a=this.ymin;break;case 6:n=2;continue;case 2:n=10,s=this.xmax,a=this.ymax;break;case 10:n=8;continue;case 8:n=9,s=this.xmin,a=this.ymax;break;case 9:n=1;continue;case 1:n=5,s=this.xmin,a=this.ymin;break}(i[o]!==s||i[o+1]!==a)&&this.contains(t,s,a)&&(i.splice(o,0,s,a),o+=2)}return o}_project(t,n,r,i){let o=1/0,s,a,c;if(i<0){if(n<=this.ymin)return null;(s=(this.ymin-n)/i)<o&&(c=this.ymin,a=t+(o=s)*r)}else if(i>0){if(n>=this.ymax)return null;(s=(this.ymax-n)/i)<o&&(c=this.ymax,a=t+(o=s)*r)}if(r>0){if(t>=this.xmax)return null;(s=(this.xmax-t)/r)<o&&(a=this.xmax,c=n+(o=s)*i)}else if(r<0){if(t<=this.xmin)return null;(s=(this.xmin-t)/r)<o&&(a=this.xmin,c=n+(o=s)*i)}return[a,c]}_edgecode(t,n){return(t===this.xmin?1:t===this.xmax?2:0)|(n===this.ymin?4:n===this.ymax?8:0)}_regioncode(t,n){return(t<this.xmin?1:t>this.xmax?2:0)|(n<this.ymin?4:n>this.ymax?8:0)}_simplify(t){if(t&&t.length>4){for(let n=0;n<t.length;n+=2){let r=(n+2)%t.length,i=(n+4)%t.length;(t[n]===t[r]&&t[r]===t[i]||t[n+1]===t[r+1]&&t[r+1]===t[i+1])&&(t.splice(r,2),n-=2)}t.length||(t=null)}return t}};var PG=2*Math.PI,Xu=Math.pow;function UG(e){return e[0]}function zG(e){return e[1]}function qG(e){let{triangles:t,coords:n}=e;for(let r=0;r<t.length;r+=3){let i=2*t[r],o=2*t[r+1],s=2*t[r+2];if((n[s]-n[i])*(n[o+1]-n[i+1])-(n[o]-n[i])*(n[s+1]-n[i+1])>1e-10)return!1}return!0}function jG(e,t,n){return[e+Math.sin(e+t)*n,t+Math.cos(e-t)*n]}var Pn=class e{static from(t,n=UG,r=zG,i){return new e("length"in t?VG(t,n,r,i):Float64Array.from(YG(t,n,r,i)))}constructor(t){this._delaunator=new Yu(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(){let t=this._delaunator,n=this.points;if(t.hull&&t.hull.length>2&&qG(t)){this.collinear=Int32Array.from({length:n.length/2},(d,h)=>h).sort((d,h)=>n[2*d]-n[2*h]||n[2*d+1]-n[2*h+1]);let c=this.collinear[0],l=this.collinear[this.collinear.length-1],u=[n[2*c],n[2*c+1],n[2*l],n[2*l+1]],f=1e-8*Math.hypot(u[3]-u[1],u[2]-u[0]);for(let d=0,h=n.length/2;d<h;++d){let p=jG(n[2*d],n[2*d+1],f);n[2*d]=p[0],n[2*d+1]=p[1]}this._delaunator=new Yu(n)}else delete this.collinear;let r=this.halfedges=this._delaunator.halfedges,i=this.hull=this._delaunator.hull,o=this.triangles=this._delaunator.triangles,s=this.inedges.fill(-1),a=this._hullIndex.fill(-1);for(let c=0,l=r.length;c<l;++c){let u=o[c%3===2?c-2:c+1];(r[c]===-1||s[u]===-1)&&(s[u]=c)}for(let c=0,l=i.length;c<l;++c)a[i[c]]=c;i.length<=2&&i.length>0&&(this.triangles=new Int32Array(3).fill(-1),this.halfedges=new Int32Array(3).fill(-1),this.triangles[0]=i[0],s[i[0]]=1,i.length===2&&(s[i[1]]=0,this.triangles[1]=i[1],this.triangles[2]=i[1]))}voronoi(t){return new Tp(this,t)}*neighbors(t){let{inedges:n,hull:r,_hullIndex:i,halfedges:o,triangles:s,collinear:a}=this;if(a){let f=a.indexOf(t);f>0&&(yield a[f-1]),f<a.length-1&&(yield a[f+1]);return}let c=n[t];if(c===-1)return;let l=c,u=-1;do{if(yield u=s[l],l=l%3===2?l-2:l+1,s[l]!==t)return;if(l=o[l],l===-1){let f=r[(i[t]+1)%r.length];f!==u&&(yield f);return}}while(l!==c)}find(t,n,r=0){if(t=+t,t!==t||(n=+n,n!==n))return-1;let i=r,o;for(;(o=this._step(r,t,n))>=0&&o!==r&&o!==i;)r=o;return o}_step(t,n,r){let{inedges:i,hull:o,_hullIndex:s,halfedges:a,triangles:c,points:l}=this;if(i[t]===-1||!l.length)return(t+1)%(l.length>>1);let u=t,f=Xu(n-l[t*2],2)+Xu(r-l[t*2+1],2),d=i[t],h=d;do{let p=c[h],m=Xu(n-l[p*2],2)+Xu(r-l[p*2+1],2);if(m<f&&(f=m,u=p),h=h%3===2?h-2:h+1,c[h]!==t)break;if(h=a[h],h===-1){if(h=o[(s[t]+1)%o.length],h!==p&&Xu(n-l[h*2],2)+Xu(r-l[h*2+1],2)<f)return h;break}}while(h!==d);return u}render(t){let n=t==null?t=new ai:void 0,{points:r,halfedges:i,triangles:o}=this;for(let s=0,a=i.length;s<a;++s){let c=i[s];if(c<s)continue;let l=o[s]*2,u=o[c]*2;t.moveTo(r[l],r[l+1]),t.lineTo(r[u],r[u+1])}return this.renderHull(t),n&&n.value()}renderPoints(t,n){n===void 0&&(!t||typeof t.moveTo!="function")&&(n=t,t=null),n=n==null?2:+n;let r=t==null?t=new ai:void 0,{points:i}=this;for(let o=0,s=i.length;o<s;o+=2){let a=i[o],c=i[o+1];t.moveTo(a+n,c),t.arc(a,c,n,0,PG)}return r&&r.value()}renderHull(t){let n=t==null?t=new ai:void 0,{hull:r,points:i}=this,o=r[0]*2,s=r.length;t.moveTo(i[o],i[o+1]);for(let a=1;a<s;++a){let c=2*r[a];t.lineTo(i[c],i[c+1])}return t.closePath(),n&&n.value()}hullPolygon(){let t=new Ra;return this.renderHull(t),t.value()}renderTriangle(t,n){let r=n==null?n=new ai:void 0,{points:i,triangles:o}=this,s=o[t*=3]*2,a=o[t+1]*2,c=o[t+2]*2;return n.moveTo(i[s],i[s+1]),n.lineTo(i[a],i[a+1]),n.lineTo(i[c],i[c+1]),n.closePath(),r&&r.value()}*trianglePolygons(){let{triangles:t}=this;for(let n=0,r=t.length/3;n<r;++n)yield this.trianglePolygon(n)}trianglePolygon(t){let n=new Ra;return this.renderTriangle(t,n),n.value()}};function VG(e,t,n,r){let i=e.length,o=new Float64Array(i*2);for(let s=0;s<i;++s){let a=e[s];o[s*2]=t.call(r,a,s,e),o[s*2+1]=n.call(r,a,s,e)}return o}function*YG(e,t,n,r){let i=0;for(let o of e)yield t.call(r,o,i,e),yield n.call(r,o,i,e),++i}function TC(e){return Math.abs(e=Math.round(e))>=1e21?e.toLocaleString("en").replace(/,/g,""):e.toString(10)}function il(e,t){if((n=(e=t?e.toExponential(t-1):e.toExponential()).indexOf("e"))<0)return null;var n,r=e.slice(0,n);return[r.length>1?r[0]+r.slice(2):r,+e.slice(n+1)]}function bo(e){return e=il(Math.abs(e)),e?e[1]:NaN}function EC(e,t){return function(n,r){for(var i=n.length,o=[],s=0,a=e[0],c=0;i>0&&a>0&&(c+a+1>r&&(a=Math.max(1,r-c)),o.push(n.substring(i-=a,i+a)),!((c+=a+1)>r));)a=e[s=(s+1)%e.length];return o.reverse().join(t)}}function NC(e){return function(t){return t.replace(/[0-9]/g,function(n){return e[+n]})}}var XG=/^(?:(.)?([<>=^]))?([+\-( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?(~)?([a-z%])?$/i;function wo(e){if(!(t=XG.exec(e)))throw new Error("invalid format: "+e);var t;return new Rx({fill:t[1],align:t[2],sign:t[3],symbol:t[4],zero:t[5],width:t[6],comma:t[7],precision:t[8]&&t[8].slice(1),trim:t[9],type:t[10]})}wo.prototype=Rx.prototype;function Rx(e){this.fill=e.fill===void 0?" ":e.fill+"",this.align=e.align===void 0?">":e.align+"",this.sign=e.sign===void 0?"-":e.sign+"",this.symbol=e.symbol===void 0?"":e.symbol+"",this.zero=!!e.zero,this.width=e.width===void 0?void 0:+e.width,this.comma=!!e.comma,this.precision=e.precision===void 0?void 0:+e.precision,this.trim=!!e.trim,this.type=e.type===void 0?"":e.type+""}Rx.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?"0":"")+(this.width===void 0?"":Math.max(1,this.width|0))+(this.comma?",":"")+(this.precision===void 0?"":"."+Math.max(0,this.precision|0))+(this.trim?"~":"")+this.type};function DC(e){t:for(var t=e.length,n=1,r=-1,i;n<t;++n)switch(e[n]){case".":r=i=n;break;case"0":r===0&&(r=n),i=n;break;default:if(!+e[n])break t;r>0&&(r=0);break}return r>0?e.slice(0,r)+e.slice(i+1):e}var EI;function OC(e,t){var n=il(e,t);if(!n)return e+"";var r=n[0],i=n[1],o=i-(EI=Math.max(-8,Math.min(8,Math.floor(i/3)))*3)+1,s=r.length;return o===s?r:o>s?r+new Array(o-s+1).join("0"):o>0?r.slice(0,o)+"."+r.slice(o):"0."+new Array(1-o).join("0")+il(e,Math.max(0,t+o-1))[0]}function NI(e,t){var n=il(e,t);if(!n)return e+"";var r=n[0],i=n[1];return i<0?"0."+new Array(-i).join("0")+r:r.length>i+1?r.slice(0,i+1)+"."+r.slice(i+1):r+new Array(i-r.length+2).join("0")}var DI={"%":(e,t)=>(e*100).toFixed(t),b:e=>Math.round(e).toString(2),c:e=>e+"",d:TC,e:(e,t)=>e.toExponential(t),f:(e,t)=>e.toFixed(t),g:(e,t)=>e.toPrecision(t),o:e=>Math.round(e).toString(8),p:(e,t)=>NI(e*100,t),r:NI,s:OC,X:e=>Math.round(e).toString(16).toUpperCase(),x:e=>Math.round(e).toString(16)};function OI(e){return e}var BC=Array.prototype.map,LC=["y","z","a","f","p","n","\xB5","m","","k","M","G","T","P","E","Z","Y"];function CC(e){var t=e.grouping===void 0||e.thousands===void 0?OI:EC(BC.call(e.grouping,Number),e.thousands+""),n=e.currency===void 0?"":e.currency[0]+"",r=e.currency===void 0?"":e.currency[1]+"",i=e.decimal===void 0?".":e.decimal+"",o=e.numerals===void 0?OI:NC(BC.call(e.numerals,String)),s=e.percent===void 0?"%":e.percent+"",a=e.minus===void 0?"\u2212":e.minus+"",c=e.nan===void 0?"NaN":e.nan+"";function l(f){f=wo(f);var d=f.fill,h=f.align,p=f.sign,m=f.symbol,g=f.zero,y=f.width,x=f.comma,b=f.precision,w=f.trim,v=f.type;v==="n"?(x=!0,v="g"):DI[v]||(b===void 0&&(b=12),w=!0,v="g"),(g||d==="0"&&h==="=")&&(g=!0,d="0",h="=");var _=m==="$"?n:m==="#"&&/[boxX]/.test(v)?"0"+v.toLowerCase():"",I=m==="$"?r:/[%p]/.test(v)?s:"",D=DI[v],A=/[defgprs%]/.test(v);b=b===void 0?6:/[gprs]/.test(v)?Math.max(1,Math.min(21,b)):Math.max(0,Math.min(20,b));function E(T){var O=_,C=I,S,M,N;if(v==="c")C=D(T)+C,T="";else{T=+T;var F=T<0||1/T<0;if(T=isNaN(T)?c:D(Math.abs(T),b),w&&(T=DC(T)),F&&+T==0&&p!=="+"&&(F=!1),O=(F?p==="("?p:a:p==="-"||p==="("?"":p)+O,C=(v==="s"?LC[8+EI/3]:"")+C+(F&&p==="("?")":""),A){for(S=-1,M=T.length;++S<M;)if(N=T.charCodeAt(S),48>N||N>57){C=(N===46?i+T.slice(S+1):T.slice(S))+C,T=T.slice(0,S);break}}}x&&!g&&(T=t(T,1/0));var R=O.length+T.length+C.length,k=R<y?new Array(y-R+1).join(d):"";switch(x&&g&&(T=t(k+T,k.length?y-C.length:1/0),k=""),h){case"<":T=O+T+C+k;break;case"=":T=O+k+T+C;break;case"^":T=k.slice(0,R=k.length>>1)+O+T+C+k.slice(R);break;default:T=k+O+T+C;break}return o(T)}return E.toString=function(){return f+""},E}function u(f,d){var h=l((f=wo(f),f.type="f",f)),p=Math.max(-8,Math.min(8,Math.floor(bo(d)/3)))*3,m=Math.pow(10,-p),g=LC[8+p/3];return function(y){return h(m*y)+g}}return{format:l,formatPrefix:u}}var $x,ci,Px;BI({thousands:",",grouping:[3],currency:["$",""]});function BI(e){return $x=CC(e),ci=$x.format,Px=$x.formatPrefix,$x}function LI(e){return Math.max(0,-bo(Math.abs(e)))}function CI(e,t){return Math.max(0,Math.max(-8,Math.min(8,Math.floor(bo(t)/3)))*3-bo(Math.abs(e)))}function kI(e,t){return e=Math.abs(e),t=Math.abs(t)-e,Math.max(0,bo(t)-bo(e))+1}var K=1e-6,ol=1e-12,Ot=Math.PI,me=Ot/2,FI=Ot/4,ln=Ot*2,Re=180/Ot,Yt=Ot/180,Rt=Math.abs,li=Math.atan,He=Math.atan2,Q=Math.cos,Ep=Math.ceil,Ux=Math.exp;var zx=Math.hypot,sl=Math.log,qx=Math.pow,J=Math.sin,Un=Math.sign||function(e){return e>0?1:e<0?-1:0},ye=Math.sqrt,Gu=Math.tan;function jx(e){return e>1?0:e<-1?Ot:Math.acos(e)}function Se(e){return e>1?me:e<-1?-me:Math.asin(e)}function Ze(){}function Vx(e,t){e&&FC.hasOwnProperty(e.type)&&FC[e.type](e,t)}var kC={Feature:function(e,t){Vx(e.geometry,t)},FeatureCollection:function(e,t){for(var n=e.features,r=-1,i=n.length;++r<i;)Vx(n[r].geometry,t)}},FC={Sphere:function(e,t){t.sphere()},Point:function(e,t){e=e.coordinates,t.point(e[0],e[1],e[2])},MultiPoint:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)e=n[r],t.point(e[0],e[1],e[2])},LineString:function(e,t){RI(e.coordinates,t,0)},MultiLineString:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)RI(n[r],t,0)},Polygon:function(e,t){RC(e.coordinates,t)},MultiPolygon:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)RC(n[r],t)},GeometryCollection:function(e,t){for(var n=e.geometries,r=-1,i=n.length;++r<i;)Vx(n[r],t)}};function RI(e,t,n){var r=-1,i=e.length-n,o;for(t.lineStart();++r<i;)o=e[r],t.point(o[0],o[1],o[2]);t.lineEnd()}function RC(e,t){var n=-1,r=e.length;for(t.polygonStart();++n<r;)RI(e[n],t,1);t.polygonEnd()}function Pr(e,t){e&&kC.hasOwnProperty(e.type)?kC[e.type](e,t):Vx(e,t)}function Np(e){return[He(e[1],e[0]),Se(e[2])]}function vo(e){var t=e[0],n=e[1],r=Q(n);return[r*Q(t),r*J(t),J(n)]}function Dp(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function Wu(e,t){return[e[1]*t[2]-e[2]*t[1],e[2]*t[0]-e[0]*t[2],e[0]*t[1]-e[1]*t[0]]}function Yx(e,t){e[0]+=t[0],e[1]+=t[1],e[2]+=t[2]}function Op(e,t){return[e[0]*t,e[1]*t,e[2]*t]}function Bp(e){var t=ye(e[0]*e[0]+e[1]*e[1]+e[2]*e[2]);e[0]/=t,e[1]/=t,e[2]/=t}var Lp,Xx,Gx,Wx,Hx,Zx,Jx,Qx,$I,PI,UI,UC,zC,rr,ir,or,zi={sphere:Ze,point:zI,lineStart:$C,lineEnd:PC,polygonStart:function(){zi.lineStart=HG,zi.lineEnd=ZG},polygonEnd:function(){zi.lineStart=$C,zi.lineEnd=PC}};function zI(e,t){e*=Yt,t*=Yt;var n=Q(t);Cp(n*Q(e),n*J(e),J(t))}function Cp(e,t,n){++Lp,Gx+=(e-Gx)/Lp,Wx+=(t-Wx)/Lp,Hx+=(n-Hx)/Lp}function $C(){zi.point=GG}function GG(e,t){e*=Yt,t*=Yt;var n=Q(t);rr=n*Q(e),ir=n*J(e),or=J(t),zi.point=WG,Cp(rr,ir,or)}function WG(e,t){e*=Yt,t*=Yt;var n=Q(t),r=n*Q(e),i=n*J(e),o=J(t),s=He(ye((s=ir*o-or*i)*s+(s=or*r-rr*o)*s+(s=rr*i-ir*r)*s),rr*r+ir*i+or*o);Xx+=s,Zx+=s*(rr+(rr=r)),Jx+=s*(ir+(ir=i)),Qx+=s*(or+(or=o)),Cp(rr,ir,or)}function PC(){zi.point=zI}function HG(){zi.point=JG}function ZG(){qC(UC,zC),zi.point=zI}function JG(e,t){UC=e,zC=t,e*=Yt,t*=Yt,zi.point=qC;var n=Q(t);rr=n*Q(e),ir=n*J(e),or=J(t),Cp(rr,ir,or)}function qC(e,t){e*=Yt,t*=Yt;var n=Q(t),r=n*Q(e),i=n*J(e),o=J(t),s=ir*o-or*i,a=or*r-rr*o,c=rr*i-ir*r,l=zx(s,a,c),u=Se(l),f=l&&-u/l;$I.add(f*s),PI.add(f*a),UI.add(f*c),Xx+=u,Zx+=u*(rr+(rr=r)),Jx+=u*(ir+(ir=i)),Qx+=u*(or+(or=o)),Cp(rr,ir,or)}function qI(e){Lp=Xx=Gx=Wx=Hx=Zx=Jx=Qx=0,$I=new In,PI=new In,UI=new In,Pr(e,zi);var t=+$I,n=+PI,r=+UI,i=zx(t,n,r);return i<ol&&(t=Zx,n=Jx,r=Qx,Xx<K&&(t=Gx,n=Wx,r=Hx),i=zx(t,n,r),i<ol)?[NaN,NaN]:[He(n,t)*Re,Se(r/i)*Re]}function kp(e,t){function n(r,i){return r=e(r,i),t(r[0],r[1])}return e.invert&&t.invert&&(n.invert=function(r,i){return r=t.invert(r,i),r&&e.invert(r[0],r[1])}),n}function jI(e,t){return Rt(e)>Ot&&(e-=Math.round(e/ln)*ln),[e,t]}jI.invert=jI;function VI(e,t,n){return(e%=ln)?t||n?kp(VC(e),YC(t,n)):VC(e):t||n?YC(t,n):jI}function jC(e){return function(t,n){return t+=e,Rt(t)>Ot&&(t-=Math.round(t/ln)*ln),[t,n]}}function VC(e){var t=jC(e);return t.invert=jC(-e),t}function YC(e,t){var n=Q(e),r=J(e),i=Q(t),o=J(t);function s(a,c){var l=Q(c),u=Q(a)*l,f=J(a)*l,d=J(c),h=d*n+u*r;return[He(f*i-h*o,u*n-d*r),Se(h*i+f*o)]}return s.invert=function(a,c){var l=Q(c),u=Q(a)*l,f=J(a)*l,d=J(c),h=d*i-f*o;return[He(f*i+d*o,u*n+h*r),Se(h*n-u*r)]},s}function XC(e){e=VI(e[0]*Yt,e[1]*Yt,e.length>2?e[2]*Yt:0);function t(n){return n=e(n[0]*Yt,n[1]*Yt),n[0]*=Re,n[1]*=Re,n}return t.invert=function(n){return n=e.invert(n[0]*Yt,n[1]*Yt),n[0]*=Re,n[1]*=Re,n},t}function WC(e,t,n,r,i,o){if(n){var s=Q(t),a=J(t),c=r*n;i==null?(i=t+r*ln,o=t-c/2):(i=GC(s,i),o=GC(s,o),(r>0?i<o:i>o)&&(i+=r*ln));for(var l,u=i;r>0?u>o:u<o;u-=c)l=Np([s,-a*Q(u),-a*J(u)]),e.point(l[0],l[1])}}function GC(e,t){t=vo(t),t[0]-=e,Bp(t);var n=jx(-t[1]);return((-t[2]<0?-n:n)+ln-K)%ln}function Kx(){var e=[],t;return{point:function(n,r,i){t.push([n,r,i])},lineStart:function(){e.push(t=[])},lineEnd:Ze,rejoin:function(){e.length>1&&e.push(e.pop().concat(e.shift()))},result:function(){var n=e;return e=[],t=null,n}}}function Hu(e,t){return Rt(e[0]-t[0])<K&&Rt(e[1]-t[1])<K}function tb(e,t,n,r){this.x=e,this.z=t,this.o=n,this.e=r,this.v=!1,this.n=this.p=null}function eb(e,t,n,r,i){var o=[],s=[],a,c;if(e.forEach(function(p){if(!((m=p.length-1)<=0)){var m,g=p[0],y=p[m],x;if(Hu(g,y)){if(!g[2]&&!y[2]){for(i.lineStart(),a=0;a<m;++a)i.point((g=p[a])[0],g[1]);i.lineEnd();return}y[0]+=2*K}o.push(x=new tb(g,p,null,!0)),s.push(x.o=new tb(g,null,x,!1)),o.push(x=new tb(y,p,null,!1)),s.push(x.o=new tb(y,null,x,!0))}}),!!o.length){for(s.sort(t),HC(o),HC(s),a=0,c=s.length;a<c;++a)s[a].e=n=!n;for(var l=o[0],u,f;;){for(var d=l,h=!0;d.v;)if((d=d.n)===l)return;u=d.z,i.lineStart();do{if(d.v=d.o.v=!0,d.e){if(h)for(a=0,c=u.length;a<c;++a)i.point((f=u[a])[0],f[1]);else r(d.x,d.n.x,1,i);d=d.n}else{if(h)for(u=d.p.z,a=u.length-1;a>=0;--a)i.point((f=u[a])[0],f[1]);else r(d.x,d.p.x,-1,i);d=d.p}d=d.o,u=d.z,h=!h}while(!d.v);i.lineEnd()}}}function HC(e){if(t=e.length){for(var t,n=0,r=e[0],i;++n<t;)r.n=i=e[n],i.p=r,r=i;r.n=i=e[0],i.p=r}}function YI(e){return Rt(e[0])<=Ot?e[0]:Un(e[0])*((Rt(e[0])+Ot)%ln-Ot)}function ZC(e,t){var n=YI(t),r=t[1],i=J(r),o=[J(n),-Q(n),0],s=0,a=0,c=new In;i===1?r=me+K:i===-1&&(r=-me-K);for(var l=0,u=e.length;l<u;++l)if(d=(f=e[l]).length)for(var f,d,h=f[d-1],p=YI(h),m=h[1]/2+FI,g=J(m),y=Q(m),x=0;x<d;++x,p=w,g=_,y=I,h=b){var b=f[x],w=YI(b),v=b[1]/2+FI,_=J(v),I=Q(v),D=w-p,A=D>=0?1:-1,E=A*D,T=E>Ot,O=g*_;if(c.add(He(O*A*J(E),y*I+O*Q(E))),s+=T?D+A*ln:D,T^p>=n^w>=n){var C=Wu(vo(h),vo(b));Bp(C);var S=Wu(o,C);Bp(S);var M=(T^D>=0?-1:1)*Se(S[2]);(r>M||r===M&&(C[0]||C[1]))&&(a+=T^D>=0?1:-1)}}return(s<-K||s<K&&c<-ol)^a&1}function nb(e,t,n,r){return function(i){var o=t(i),s=Kx(),a=t(s),c=!1,l,u,f,d={point:h,lineStart:m,lineEnd:g,polygonStart:function(){d.point=y,d.lineStart=x,d.lineEnd=b,u=[],l=[]},polygonEnd:function(){d.point=h,d.lineStart=m,d.lineEnd=g,u=Du(u);var w=ZC(l,r);u.length?(c||(i.polygonStart(),c=!0),eb(u,KG,w,n,i)):w&&(c||(i.polygonStart(),c=!0),i.lineStart(),n(null,null,1,i),i.lineEnd()),c&&(i.polygonEnd(),c=!1),u=l=null},sphere:function(){i.polygonStart(),i.lineStart(),n(null,null,1,i),i.lineEnd(),i.polygonEnd()}};function h(w,v){e(w,v)&&i.point(w,v)}function p(w,v){o.point(w,v)}function m(){d.point=p,o.lineStart()}function g(){d.point=h,o.lineEnd()}function y(w,v){f.push([w,v]),a.point(w,v)}function x(){a.lineStart(),f=[]}function b(){y(f[0][0],f[0][1]),a.lineEnd();var w=a.clean(),v=s.result(),_,I=v.length,D,A,E;if(f.pop(),l.push(f),f=null,!!I){if(w&1){if(A=v[0],(D=A.length-1)>0){for(c||(i.polygonStart(),c=!0),i.lineStart(),_=0;_<D;++_)i.point((E=A[_])[0],E[1]);i.lineEnd()}return}I>1&&w&2&&v.push(v.pop().concat(v.shift())),u.push(v.filter(QG))}}return d}}function QG(e){return e.length>1}function KG(e,t){return((e=e.x)[0]<0?e[1]-me-K:me-e[1])-((t=t.x)[0]<0?t[1]-me-K:me-t[1])}var XI=nb(function(){return!0},tW,nW,[-Ot,-me]);function tW(e){var t=NaN,n=NaN,r=NaN,i;return{lineStart:function(){e.lineStart(),i=1},point:function(o,s){var a=o>0?Ot:-Ot,c=Rt(o-t);Rt(c-Ot)<K?(e.point(t,n=(n+s)/2>0?me:-me),e.point(r,n),e.lineEnd(),e.lineStart(),e.point(a,n),e.point(o,n),i=0):r!==a&&c>=Ot&&(Rt(t-r)<K&&(t-=r*K),Rt(o-a)<K&&(o-=a*K),n=eW(t,n,o,s),e.point(r,n),e.lineEnd(),e.lineStart(),e.point(a,n),i=0),e.point(t=o,n=s),r=a},lineEnd:function(){e.lineEnd(),t=n=NaN},clean:function(){return 2-i}}}function eW(e,t,n,r){var i,o,s=J(e-n);return Rt(s)>K?li((J(t)*(o=Q(r))*J(n)-J(r)*(i=Q(t))*J(e))/(i*o*s)):(t+r)/2}function nW(e,t,n,r){var i;if(e==null)i=n*me,r.point(-Ot,i),r.point(0,i),r.point(Ot,i),r.point(Ot,0),r.point(Ot,-i),r.point(0,-i),r.point(-Ot,-i),r.point(-Ot,0),r.point(-Ot,i);else if(Rt(e[0]-t[0])>K){var o=e[0]<t[0]?Ot:-Ot;i=n*o/2,r.point(-o,i),r.point(0,i),r.point(o,i)}else r.point(t[0],t[1])}function JC(e){var t=Q(e),n=6*Yt,r=t>0,i=Rt(t)>K;function o(u,f,d,h){WC(h,e,n,d,u,f)}function s(u,f){return Q(u)*Q(f)>t}function a(u){var f,d,h,p,m;return{lineStart:function(){p=h=!1,m=1},point:function(g,y){var x=[g,y],b,w=s(g,y),v=r?w?0:l(g,y):w?l(g+(g<0?Ot:-Ot),y):0;if(!f&&(p=h=w)&&u.lineStart(),w!==h&&(b=c(f,x),(!b||Hu(f,b)||Hu(x,b))&&(x[2]=1)),w!==h)m=0,w?(u.lineStart(),b=c(x,f),u.point(b[0],b[1])):(b=c(f,x),u.point(b[0],b[1],2),u.lineEnd()),f=b;else if(i&&f&&r^w){var _;!(v&d)&&(_=c(x,f,!0))&&(m=0,r?(u.lineStart(),u.point(_[0][0],_[0][1]),u.point(_[1][0],_[1][1]),u.lineEnd()):(u.point(_[1][0],_[1][1]),u.lineEnd(),u.lineStart(),u.point(_[0][0],_[0][1],3)))}w&&(!f||!Hu(f,x))&&u.point(x[0],x[1]),f=x,h=w,d=v},lineEnd:function(){h&&u.lineEnd(),f=null},clean:function(){return m|(p&&h)<<1}}}function c(u,f,d){var h=vo(u),p=vo(f),m=[1,0,0],g=Wu(h,p),y=Dp(g,g),x=g[0],b=y-x*x;if(!b)return!d&&u;var w=t*y/b,v=-t*x/b,_=Wu(m,g),I=Op(m,w),D=Op(g,v);Yx(I,D);var A=_,E=Dp(I,A),T=Dp(A,A),O=E*E-T*(Dp(I,I)-1);if(!(O<0)){var C=ye(O),S=Op(A,(-E-C)/T);if(Yx(S,I),S=Np(S),!d)return S;var M=u[0],N=f[0],F=u[1],R=f[1],k;N<M&&(k=M,M=N,N=k);var $=N-M,P=Rt($-Ot)<K,U=P||$<K;if(!P&&R<F&&(k=F,F=R,R=k),U?P?F+R>0^S[1]<(Rt(S[0]-M)<K?F:R):F<=S[1]&&S[1]<=R:$>Ot^(M<=S[0]&&S[0]<=N)){var W=Op(A,(-E+C)/T);return Yx(W,I),[S,Np(W)]}}}function l(u,f){var d=r?e:Ot-e,h=0;return u<-d?h|=1:u>d&&(h|=2),f<-d?h|=4:f>d&&(h|=8),h}return nb(s,a,o,r?[0,-e]:[-Ot,e-Ot])}function QC(e,t,n,r,i,o){var s=e[0],a=e[1],c=t[0],l=t[1],u=0,f=1,d=c-s,h=l-a,p;if(p=n-s,!(!d&&p>0)){if(p/=d,d<0){if(p<u)return;p<f&&(f=p)}else if(d>0){if(p>f)return;p>u&&(u=p)}if(p=i-s,!(!d&&p<0)){if(p/=d,d<0){if(p>f)return;p>u&&(u=p)}else if(d>0){if(p<u)return;p<f&&(f=p)}if(p=r-a,!(!h&&p>0)){if(p/=h,h<0){if(p<u)return;p<f&&(f=p)}else if(h>0){if(p>f)return;p>u&&(u=p)}if(p=o-a,!(!h&&p<0)){if(p/=h,h<0){if(p>f)return;p>u&&(u=p)}else if(h>0){if(p<u)return;p<f&&(f=p)}return u>0&&(e[0]=s+u*d,e[1]=a+u*h),f<1&&(t[0]=s+f*d,t[1]=a+f*h),!0}}}}}var Fp=1e9,rb=-Fp;function Zu(e,t,n,r){function i(l,u){return e<=l&&l<=n&&t<=u&&u<=r}function o(l,u,f,d){var h=0,p=0;if(l==null||(h=s(l,f))!==(p=s(u,f))||c(l,u)<0^f>0)do d.point(h===0||h===3?e:n,h>1?r:t);while((h=(h+f+4)%4)!==p);else d.point(u[0],u[1])}function s(l,u){return Rt(l[0]-e)<K?u>0?0:3:Rt(l[0]-n)<K?u>0?2:1:Rt(l[1]-t)<K?u>0?1:0:u>0?3:2}function a(l,u){return c(l.x,u.x)}function c(l,u){var f=s(l,1),d=s(u,1);return f!==d?f-d:f===0?u[1]-l[1]:f===1?l[0]-u[0]:f===2?l[1]-u[1]:u[0]-l[0]}return function(l){var u=l,f=Kx(),d,h,p,m,g,y,x,b,w,v,_,I={point:D,lineStart:O,lineEnd:C,polygonStart:E,polygonEnd:T};function D(M,N){i(M,N)&&u.point(M,N)}function A(){for(var M=0,N=0,F=h.length;N<F;++N)for(var R=h[N],k=1,$=R.length,P=R[0],U,W,tt=P[0],nt=P[1];k<$;++k)U=tt,W=nt,P=R[k],tt=P[0],nt=P[1],W<=r?nt>r&&(tt-U)*(r-W)>(nt-W)*(e-U)&&++M:nt<=r&&(tt-U)*(r-W)<(nt-W)*(e-U)&&--M;return M}function E(){u=f,d=[],h=[],_=!0}function T(){var M=A(),N=_&&M,F=(d=Du(d)).length;(N||F)&&(l.polygonStart(),N&&(l.lineStart(),o(null,null,1,l),l.lineEnd()),F&&eb(d,a,M,o,l),l.polygonEnd()),u=l,d=h=p=null}function O(){I.point=S,h&&h.push(p=[]),v=!0,w=!1,x=b=NaN}function C(){d&&(S(m,g),y&&w&&f.rejoin(),d.push(f.result())),I.point=D,w&&u.lineEnd()}function S(M,N){var F=i(M,N);if(h&&p.push([M,N]),v)m=M,g=N,y=F,v=!1,F&&(u.lineStart(),u.point(M,N));else if(F&&w)u.point(M,N);else{var R=[x=Math.max(rb,Math.min(Fp,x)),b=Math.max(rb,Math.min(Fp,b))],k=[M=Math.max(rb,Math.min(Fp,M)),N=Math.max(rb,Math.min(Fp,N))];QC(R,k,e,t,n,r)?(w||(u.lineStart(),u.point(R[0],R[1])),u.point(k[0],k[1]),F||u.lineEnd(),_=!1):F&&(u.lineStart(),u.point(M,N),_=!1)}x=M,b=N,w=F}return I}}function KC(e,t,n){var r=Ue(e,t-K,n).concat(t);return function(i){return r.map(function(o){return[i,o]})}}function tk(e,t,n){var r=Ue(e,t-K,n).concat(t);return function(i){return r.map(function(o){return[o,i]})}}function GI(){var e,t,n,r,i,o,s,a,c=10,l=c,u=90,f=360,d,h,p,m,g=2.5;function y(){return{type:"MultiLineString",coordinates:x()}}function x(){return Ue(Ep(r/u)*u,n,u).map(p).concat(Ue(Ep(a/f)*f,s,f).map(m)).concat(Ue(Ep(t/c)*c,e,c).filter(function(b){return Rt(b%u)>K}).map(d)).concat(Ue(Ep(o/l)*l,i,l).filter(function(b){return Rt(b%f)>K}).map(h))}return y.lines=function(){return x().map(function(b){return{type:"LineString",coordinates:b}})},y.outline=function(){return{type:"Polygon",coordinates:[p(r).concat(m(s).slice(1),p(n).reverse().slice(1),m(a).reverse().slice(1))]}},y.extent=function(b){return arguments.length?y.extentMajor(b).extentMinor(b):y.extentMinor()},y.extentMajor=function(b){return arguments.length?(r=+b[0][0],n=+b[1][0],a=+b[0][1],s=+b[1][1],r>n&&(b=r,r=n,n=b),a>s&&(b=a,a=s,s=b),y.precision(g)):[[r,a],[n,s]]},y.extentMinor=function(b){return arguments.length?(t=+b[0][0],e=+b[1][0],o=+b[0][1],i=+b[1][1],t>e&&(b=t,t=e,e=b),o>i&&(b=o,o=i,i=b),y.precision(g)):[[t,o],[e,i]]},y.step=function(b){return arguments.length?y.stepMajor(b).stepMinor(b):y.stepMinor()},y.stepMajor=function(b){return arguments.length?(u=+b[0],f=+b[1],y):[u,f]},y.stepMinor=function(b){return arguments.length?(c=+b[0],l=+b[1],y):[c,l]},y.precision=function(b){return arguments.length?(g=+b,d=KC(o,i,90),h=tk(t,e,g),p=KC(a,s,90),m=tk(r,n,g),y):g},y.extentMajor([[-180,-90+K],[180,90-K]]).extentMinor([[-180,-80-K],[180,80+K]])}function WI(){return GI()()}var Rp=e=>e;var HI=new In,ZI=new In,ek,nk,JI,QI,$a={point:Ze,lineStart:Ze,lineEnd:Ze,polygonStart:function(){$a.lineStart=rW,$a.lineEnd=oW},polygonEnd:function(){$a.lineStart=$a.lineEnd=$a.point=Ze,HI.add(Rt(ZI)),ZI=new In},result:function(){var e=HI/2;return HI=new In,e}};function rW(){$a.point=iW}function iW(e,t){$a.point=rk,ek=JI=e,nk=QI=t}function rk(e,t){ZI.add(QI*e-JI*t),JI=e,QI=t}function oW(){rk(ek,nk)}var KI=$a;var Ju=1/0,ib=Ju,$p=-Ju,ob=$p,sW={point:aW,lineStart:Ze,lineEnd:Ze,polygonStart:Ze,polygonEnd:Ze,result:function(){var e=[[Ju,ib],[$p,ob]];return $p=ob=-(ib=Ju=1/0),e}};function aW(e,t){e<Ju&&(Ju=e),e>$p&&($p=e),t<ib&&(ib=t),t>ob&&(ob=t)}var Qu=sW;var tM=0,eM=0,Pp=0,sb=0,ab=0,Ku=0,nM=0,rM=0,Up=0,sk,ak,_o,So,qi={point:al,lineStart:ik,lineEnd:ok,polygonStart:function(){qi.lineStart=uW,qi.lineEnd=fW},polygonEnd:function(){qi.point=al,qi.lineStart=ik,qi.lineEnd=ok},result:function(){var e=Up?[nM/Up,rM/Up]:Ku?[sb/Ku,ab/Ku]:Pp?[tM/Pp,eM/Pp]:[NaN,NaN];return tM=eM=Pp=sb=ab=Ku=nM=rM=Up=0,e}};function al(e,t){tM+=e,eM+=t,++Pp}function ik(){qi.point=cW}function cW(e,t){qi.point=lW,al(_o=e,So=t)}function lW(e,t){var n=e-_o,r=t-So,i=ye(n*n+r*r);sb+=i*(_o+e)/2,ab+=i*(So+t)/2,Ku+=i,al(_o=e,So=t)}function ok(){qi.point=al}function uW(){qi.point=dW}function fW(){ck(sk,ak)}function dW(e,t){qi.point=ck,al(sk=_o=e,ak=So=t)}function ck(e,t){var n=e-_o,r=t-So,i=ye(n*n+r*r);sb+=i*(_o+e)/2,ab+=i*(So+t)/2,Ku+=i,i=So*e-_o*t,nM+=i*(_o+e),rM+=i*(So+t),Up+=i*3,al(_o=e,So=t)}var iM=qi;function cb(e){this._context=e}cb.prototype={_radius:4.5,pointRadius:function(e){return this._radius=e,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){this._line===0&&this._context.closePath(),this._point=NaN},point:function(e,t){switch(this._point){case 0:{this._context.moveTo(e,t),this._point=1;break}case 1:{this._context.lineTo(e,t);break}default:{this._context.moveTo(e+this._radius,t),this._context.arc(e,t,this._radius,0,ln);break}}},result:Ze};var sM=new In,oM,lk,uk,zp,qp,lb={point:Ze,lineStart:function(){lb.point=hW},lineEnd:function(){oM&&fk(lk,uk),lb.point=Ze},polygonStart:function(){oM=!0},polygonEnd:function(){oM=null},result:function(){var e=+sM;return sM=new In,e}};function hW(e,t){lb.point=fk,lk=zp=e,uk=qp=t}function fk(e,t){zp-=e,qp-=t,sM.add(ye(zp*zp+qp*qp)),zp=e,qp=t}var aM=lb;var dk,ub,hk,pk,tf=class{constructor(t){this._append=t==null?mk:pW(t),this._radius=4.5,this._=""}pointRadius(t){return this._radius=+t,this}polygonStart(){this._line=0}polygonEnd(){this._line=NaN}lineStart(){this._point=0}lineEnd(){this._line===0&&(this._+="Z"),this._point=NaN}point(t,n){switch(this._point){case 0:{this._append`M${t},${n}`,this._point=1;break}case 1:{this._append`L${t},${n}`;break}default:{if(this._append`M${t},${n}`,this._radius!==hk||this._append!==ub){let r=this._radius,i=this._;this._="",this._append`m0,${r}a${r},${r} 0 1,1 0,${-2*r}a${r},${r} 0 1,1 0,${2*r}z`,hk=r,ub=this._append,pk=this._,this._=i}this._+=pk;break}}}result(){let t=this._;return this._="",t.length?t:null}};function mk(e){let t=1;this._+=e[0];for(let n=e.length;t<n;++t)this._+=arguments[t]+e[t]}function pW(e){let t=Math.floor(e);if(!(t>=0))throw new RangeError(`invalid digits: ${e}`);if(t>15)return mk;if(t!==dk){let n=10**t;dk=t,ub=function(i){let o=1;this._+=i[0];for(let s=i.length;o<s;++o)this._+=Math.round(arguments[o]*n)/n+i[o]}}return ub}function En(e,t){let n=3,r=4.5,i,o;function s(a){return a&&(typeof r=="function"&&o.pointRadius(+r.apply(this,arguments)),Pr(a,i(o))),o.result()}return s.area=function(a){return Pr(a,i(KI)),KI.result()},s.measure=function(a){return Pr(a,i(aM)),aM.result()},s.bounds=function(a){return Pr(a,i(Qu)),Qu.result()},s.centroid=function(a){return Pr(a,i(iM)),iM.result()},s.projection=function(a){return arguments.length?(i=a==null?(e=null,Rp):(e=a).stream,s):e},s.context=function(a){return arguments.length?(o=a==null?(t=null,new tf(n)):new cb(t=a),typeof r!="function"&&o.pointRadius(r),s):t},s.pointRadius=function(a){return arguments.length?(r=typeof a=="function"?a:(o.pointRadius(+a),+a),s):r},s.digits=function(a){if(!arguments.length)return n;if(a==null)n=null;else{let c=Math.floor(a);if(!(c>=0))throw new RangeError(`invalid digits: ${a}`);n=c}return t===null&&(o=new tf(n)),s},s.projection(e).digits(n).context(t)}function cl(e){return{stream:ef(e)}}function ef(e){return function(t){var n=new cM;for(var r in e)n[r]=e[r];return n.stream=t,n}}function cM(){}cM.prototype={constructor:cM,point:function(e,t){this.stream.point(e,t)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}};function lM(e,t,n){var r=e.clipExtent&&e.clipExtent();return e.scale(150).translate([0,0]),r!=null&&e.clipExtent(null),Pr(n,e.stream(Qu)),t(Qu.result()),r!=null&&e.clipExtent(r),e}function jp(e,t,n){return lM(e,function(r){var i=t[1][0]-t[0][0],o=t[1][1]-t[0][1],s=Math.min(i/(r[1][0]-r[0][0]),o/(r[1][1]-r[0][1])),a=+t[0][0]+(i-s*(r[1][0]+r[0][0]))/2,c=+t[0][1]+(o-s*(r[1][1]+r[0][1]))/2;e.scale(150*s).translate([a,c])},n)}function fb(e,t,n){return jp(e,[[0,0],t],n)}function db(e,t,n){return lM(e,function(r){var i=+t,o=i/(r[1][0]-r[0][0]),s=(i-o*(r[1][0]+r[0][0]))/2,a=-o*r[0][1];e.scale(150*o).translate([s,a])},n)}function hb(e,t,n){return lM(e,function(r){var i=+t,o=i/(r[1][1]-r[0][1]),s=-o*r[0][0],a=(i-o*(r[1][1]+r[0][1]))/2;e.scale(150*o).translate([s,a])},n)}var yk=16,mW=Q(30*Yt);function uM(e,t){return+t?gW(e,t):yW(e)}function yW(e){return ef({point:function(t,n){t=e(t,n),this.stream.point(t[0],t[1])}})}function gW(e,t){function n(r,i,o,s,a,c,l,u,f,d,h,p,m,g){var y=l-r,x=u-i,b=y*y+x*x;if(b>4*t&&m--){var w=s+d,v=a+h,_=c+p,I=ye(w*w+v*v+_*_),D=Se(_/=I),A=Rt(Rt(_)-1)<K||Rt(o-f)<K?(o+f)/2:He(v,w),E=e(A,D),T=E[0],O=E[1],C=T-r,S=O-i,M=x*C-y*S;(M*M/b>t||Rt((y*C+x*S)/b-.5)>.3||s*d+a*h+c*p<mW)&&(n(r,i,o,s,a,c,T,O,A,w/=I,v/=I,_,m,g),g.point(T,O),n(T,O,A,w,v,_,l,u,f,d,h,p,m,g))}}return function(r){var i,o,s,a,c,l,u,f,d,h,p,m,g={point:y,lineStart:x,lineEnd:w,polygonStart:function(){r.polygonStart(),g.lineStart=v},polygonEnd:function(){r.polygonEnd(),g.lineStart=x}};function y(D,A){D=e(D,A),r.point(D[0],D[1])}function x(){f=NaN,g.point=b,r.lineStart()}function b(D,A){var E=vo([D,A]),T=e(D,A);n(f,d,u,h,p,m,f=T[0],d=T[1],u=D,h=E[0],p=E[1],m=E[2],yk,r),r.point(f,d)}function w(){g.point=y,r.lineEnd()}function v(){x(),g.point=_,g.lineEnd=I}function _(D,A){b(i=D,A),o=f,s=d,a=h,c=p,l=m,g.point=b}function I(){n(f,d,u,h,p,m,o,s,i,a,c,l,yk,r),g.lineEnd=w,w()}return g}}var xW=ef({point:function(e,t){this.stream.point(e*Yt,t*Yt)}});function bW(e){return ef({point:function(t,n){var r=e(t,n);return this.stream.point(r[0],r[1])}})}function wW(e,t,n,r,i){function o(s,a){return s*=r,a*=i,[t+e*s,n-e*a]}return o.invert=function(s,a){return[(s-t)/e*r,(n-a)/e*i]},o}function gk(e,t,n,r,i,o){if(!o)return wW(e,t,n,r,i);var s=Q(o),a=J(o),c=s*e,l=a*e,u=s/e,f=a/e,d=(a*n-s*t)/e,h=(a*t+s*n)/e;function p(m,g){return m*=r,g*=i,[c*m-l*g+t,n-l*m-c*g]}return p.invert=function(m,g){return[r*(u*m-f*g+d),i*(h-f*m-u*g)]},p}function Nn(e){return fM(function(){return e})()}function fM(e){var t,n=150,r=480,i=250,o=0,s=0,a=0,c=0,l=0,u,f=0,d=1,h=1,p=null,m=XI,g=null,y,x,b,w=Rp,v=.5,_,I,D,A,E;function T(M){return D(M[0]*Yt,M[1]*Yt)}function O(M){return M=D.invert(M[0],M[1]),M&&[M[0]*Re,M[1]*Re]}T.stream=function(M){return A&&E===M?A:A=xW(bW(u)(m(_(w(E=M)))))},T.preclip=function(M){return arguments.length?(m=M,p=void 0,S()):m},T.postclip=function(M){return arguments.length?(w=M,g=y=x=b=null,S()):w},T.clipAngle=function(M){return arguments.length?(m=+M?JC(p=M*Yt):(p=null,XI),S()):p*Re},T.clipExtent=function(M){return arguments.length?(w=M==null?(g=y=x=b=null,Rp):Zu(g=+M[0][0],y=+M[0][1],x=+M[1][0],b=+M[1][1]),S()):g==null?null:[[g,y],[x,b]]},T.scale=function(M){return arguments.length?(n=+M,C()):n},T.translate=function(M){return arguments.length?(r=+M[0],i=+M[1],C()):[r,i]},T.center=function(M){return arguments.length?(o=M[0]%360*Yt,s=M[1]%360*Yt,C()):[o*Re,s*Re]},T.rotate=function(M){return arguments.length?(a=M[0]%360*Yt,c=M[1]%360*Yt,l=M.length>2?M[2]%360*Yt:0,C()):[a*Re,c*Re,l*Re]},T.angle=function(M){return arguments.length?(f=M%360*Yt,C()):f*Re},T.reflectX=function(M){return arguments.length?(d=M?-1:1,C()):d<0},T.reflectY=function(M){return arguments.length?(h=M?-1:1,C()):h<0},T.precision=function(M){return arguments.length?(_=uM(I,v=M*M),S()):ye(v)},T.fitExtent=function(M,N){return jp(T,M,N)},T.fitSize=function(M,N){return fb(T,M,N)},T.fitWidth=function(M,N){return db(T,M,N)},T.fitHeight=function(M,N){return hb(T,M,N)};function C(){var M=gk(n,0,0,d,h,f).apply(null,t(o,s)),N=gk(n,r-M[0],i-M[1],d,h,f);return u=VI(a,c,l),I=kp(t,N),D=kp(u,I),_=uM(I,v),S()}function S(){return A=E=null,T}return function(){return t=e.apply(this,arguments),T.invert=t.invert&&O,C()}}function nf(e){var t=0,n=Ot/3,r=fM(e),i=r(t,n);return i.parallels=function(o){return arguments.length?r(t=o[0]*Yt,n=o[1]*Yt):[t*Re,n*Re]},i}function xk(e){var t=Q(e);function n(r,i){return[r*t,J(i)/t]}return n.invert=function(r,i){return[r/t,Se(i*t)]},n}function bk(e,t){var n=J(e),r=(n+J(t))/2;if(Rt(r)<K)return xk(e);var i=1+n*(2*r-n),o=ye(i)/r;function s(a,c){var l=ye(i-2*r*J(c))/r;return[l*J(a*=r),o-l*Q(a)]}return s.invert=function(a,c){var l=o-c,u=He(a,Rt(l))*Un(l);return l*r<0&&(u-=Ot*Un(a)*Un(l)),[u/r,Se((i-(a*a+l*l)*r*r)/(2*r))]},s}function Pa(){return nf(bk).scale(155.424).center([0,33.6442])}function Vp(){return Pa().parallels([29.5,45.5]).scale(1070).translate([480,250]).rotate([96,0]).center([-.6,38.7])}function vW(e){var t=e.length;return{point:function(n,r){for(var i=-1;++i<t;)e[i].point(n,r)},sphere:function(){for(var n=-1;++n<t;)e[n].sphere()},lineStart:function(){for(var n=-1;++n<t;)e[n].lineStart()},lineEnd:function(){for(var n=-1;++n<t;)e[n].lineEnd()},polygonStart:function(){for(var n=-1;++n<t;)e[n].polygonStart()},polygonEnd:function(){for(var n=-1;++n<t;)e[n].polygonEnd()}}}function dM(){var e,t,n=Vp(),r,i=Pa().rotate([154,0]).center([-2,58.5]).parallels([55,65]),o,s=Pa().rotate([157,0]).center([-3,19.9]).parallels([8,18]),a,c,l={point:function(d,h){c=[d,h]}};function u(d){var h=d[0],p=d[1];return c=null,r.point(h,p),c||(o.point(h,p),c)||(a.point(h,p),c)}u.invert=function(d){var h=n.scale(),p=n.translate(),m=(d[0]-p[0])/h,g=(d[1]-p[1])/h;return(g>=.12&&g<.234&&m>=-.425&&m<-.214?i:g>=.166&&g<.234&&m>=-.214&&m<-.115?s:n).invert(d)},u.stream=function(d){return e&&t===d?e:e=vW([n.stream(t=d),i.stream(d),s.stream(d)])},u.precision=function(d){return arguments.length?(n.precision(d),i.precision(d),s.precision(d),f()):n.precision()},u.scale=function(d){return arguments.length?(n.scale(d),i.scale(d*.35),s.scale(d),u.translate(n.translate())):n.scale()},u.translate=function(d){if(!arguments.length)return n.translate();var h=n.scale(),p=+d[0],m=+d[1];return r=n.translate(d).clipExtent([[p-.455*h,m-.238*h],[p+.455*h,m+.238*h]]).stream(l),o=i.translate([p-.307*h,m+.201*h]).clipExtent([[p-.425*h+K,m+.12*h+K],[p-.214*h-K,m+.234*h-K]]).stream(l),a=s.translate([p-.205*h,m+.212*h]).clipExtent([[p-.214*h+K,m+.166*h+K],[p-.115*h-K,m+.234*h-K]]).stream(l),f()},u.fitExtent=function(d,h){return jp(u,d,h)},u.fitSize=function(d,h){return fb(u,d,h)},u.fitWidth=function(d,h){return db(u,d,h)},u.fitHeight=function(d,h){return hb(u,d,h)};function f(){return e=t=null,u}return u.scale(1070)}function pb(e){return function(t,n){var r=Q(t),i=Q(n),o=e(r*i);return o===1/0?[2,0]:[o*i*J(t),o*J(n)]}}function Io(e){return function(t,n){var r=ye(t*t+n*n),i=e(r),o=J(i),s=Q(i);return[He(t*o,r*s),Se(r&&n*o/r)]}}var hM=pb(function(e){return ye(2/(1+e))});hM.invert=Io(function(e){return 2*Se(e/2)});function pM(){return Nn(hM).scale(124.75).clipAngle(180-.001)}var mM=pb(function(e){return(e=jx(e))&&e/J(e)});mM.invert=Io(function(e){return e});function yM(){return Nn(mM).scale(79.4188).clipAngle(180-.001)}function rf(e,t){return[e,sl(Gu((me+t)/2))]}rf.invert=function(e,t){return[e,2*li(Ux(t))-me]};function gM(){return xM(rf).scale(961/ln)}function xM(e){var t=Nn(e),n=t.center,r=t.scale,i=t.translate,o=t.clipExtent,s=null,a,c,l;t.scale=function(f){return arguments.length?(r(f),u()):r()},t.translate=function(f){return arguments.length?(i(f),u()):i()},t.center=function(f){return arguments.length?(n(f),u()):n()},t.clipExtent=function(f){return arguments.length?(f==null?s=a=c=l=null:(s=+f[0][0],a=+f[0][1],c=+f[1][0],l=+f[1][1]),u()):s==null?null:[[s,a],[c,l]]};function u(){var f=Ot*r(),d=t(XC(t.rotate()).invert([0,0]));return o(s==null?[[d[0]-f,d[1]-f],[d[0]+f,d[1]+f]]:e===rf?[[Math.max(d[0]-f,s),a],[Math.min(d[0]+f,c),l]]:[[s,Math.max(d[1]-f,a)],[c,Math.min(d[1]+f,l)]])}return u()}function mb(e){return Gu((me+e)/2)}function wk(e,t){var n=Q(e),r=e===t?J(e):sl(n/Q(t))/sl(mb(t)/mb(e)),i=n*qx(mb(e),r)/r;if(!r)return rf;function o(s,a){i>0?a<-me+K&&(a=-me+K):a>me-K&&(a=me-K);var c=i/qx(mb(a),r);return[c*J(r*s),i-c*Q(r*s)]}return o.invert=function(s,a){var c=i-a,l=Un(r)*ye(s*s+c*c),u=He(s,Rt(c))*Un(c);return c*r<0&&(u-=Ot*Un(s)*Un(c)),[u/r,2*li(qx(i/l,1/r))-me]},o}function bM(){return nf(wk).scale(109.5).parallels([30,30])}function of(e,t){return[e,t]}of.invert=of;function wM(){return Nn(of).scale(152.63)}function vk(e,t){var n=Q(e),r=e===t?J(e):(n-Q(t))/(t-e),i=n/r+e;if(Rt(r)<K)return of;function o(s,a){var c=i-a,l=r*s;return[c*J(l),i-c*Q(l)]}return o.invert=function(s,a){var c=i-a,l=He(s,Rt(c))*Un(c);return c*r<0&&(l-=Ot*Un(s)*Un(c)),[l/r,i-Un(r)*ye(s*s+c*c)]},o}function vM(){return nf(vk).scale(131.154).center([0,13.9389])}var Yp=1.340264,Xp=-.081106,Gp=893e-6,Wp=.003796,yb=ye(3)/2,_W=12;function _M(e,t){var n=Se(yb*J(t)),r=n*n,i=r*r*r;return[e*Q(n)/(yb*(Yp+3*Xp*r+i*(7*Gp+9*Wp*r))),n*(Yp+Xp*r+i*(Gp+Wp*r))]}_M.invert=function(e,t){for(var n=t,r=n*n,i=r*r*r,o=0,s,a,c;o<_W&&(a=n*(Yp+Xp*r+i*(Gp+Wp*r))-t,c=Yp+3*Xp*r+i*(7*Gp+9*Wp*r),n-=s=a/c,r=n*n,i=r*r*r,!(Rt(s)<ol));++o);return[yb*e*(Yp+3*Xp*r+i*(7*Gp+9*Wp*r))/Q(n),Se(J(n)/yb)]};function SM(){return Nn(_M).scale(177.158)}function IM(e,t){var n=Q(t),r=Q(e)*n;return[n*J(e)/r,J(t)/r]}IM.invert=Io(li);function MM(){return Nn(IM).scale(144.049).clipAngle(60)}function AM(e,t){return[Q(t)*J(e),J(t)]}AM.invert=Io(Se);function TM(){return Nn(AM).scale(249.5).clipAngle(90+K)}function EM(e,t){var n=Q(t),r=1+Q(e)*n;return[n*J(e)/r,J(t)/r]}EM.invert=Io(function(e){return 2*li(e)});function NM(){return Nn(EM).scale(250).clipAngle(142)}function DM(e,t){return[sl(Gu((me+t)/2)),-e]}DM.invert=function(e,t){return[-t,2*li(Ux(e))-me]};function OM(){var e=xM(DM),t=e.center,n=e.rotate;return e.center=function(r){return arguments.length?t([-r[1],r[0]]):(r=t(),[r[1],-r[0]])},e.rotate=function(r){return arguments.length?n([r[0],r[1],r.length>2?r[2]+90:90]):(r=n(),[r[0],r[1],r[2]-90])},n([0,0,90]).scale(159.155)}function SW(e,t){return e.parent===t.parent?1:2}function IW(e){return e.reduce(MW,0)/e.length}function MW(e,t){return e+t.x}function AW(e){return 1+e.reduce(TW,0)}function TW(e,t){return Math.max(e,t.y)}function EW(e){for(var t;t=e.children;)e=t[0];return e}function NW(e){for(var t;t=e.children;)e=t[t.length-1];return e}function gb(){var e=SW,t=1,n=1,r=!1;function i(o){var s,a=0;o.eachAfter(function(d){var h=d.children;h?(d.x=IW(h),d.y=AW(h)):(d.x=s?a+=e(d,s):0,d.y=0,s=d)});var c=EW(o),l=NW(o),u=c.x-e(c,l)/2,f=l.x+e(l,c)/2;return o.eachAfter(r?function(d){d.x=(d.x-o.x)*t,d.y=(o.y-d.y)*n}:function(d){d.x=(d.x-u)/(f-u)*t,d.y=(1-(o.y?d.y/o.y:1))*n})}return i.separation=function(o){return arguments.length?(e=o,i):e},i.size=function(o){return arguments.length?(r=!1,t=+o[0],n=+o[1],i):r?null:[t,n]},i.nodeSize=function(o){return arguments.length?(r=!0,t=+o[0],n=+o[1],i):r?[t,n]:null},i}function DW(e){var t=0,n=e.children,r=n&&n.length;if(!r)t=1;else for(;--r>=0;)t+=n[r].value;e.value=t}function _k(){return this.eachAfter(DW)}function Sk(e,t){let n=-1;for(let r of this)e.call(t,r,++n,this);return this}function Ik(e,t){for(var n=this,r=[n],i,o,s=-1;n=r.pop();)if(e.call(t,n,++s,this),i=n.children)for(o=i.length-1;o>=0;--o)r.push(i[o]);return this}function Mk(e,t){for(var n=this,r=[n],i=[],o,s,a,c=-1;n=r.pop();)if(i.push(n),o=n.children)for(s=0,a=o.length;s<a;++s)r.push(o[s]);for(;n=i.pop();)e.call(t,n,++c,this);return this}function Ak(e,t){let n=-1;for(let r of this)if(e.call(t,r,++n,this))return r}function Tk(e){return this.eachAfter(function(t){for(var n=+e(t.data)||0,r=t.children,i=r&&r.length;--i>=0;)n+=r[i].value;t.value=n})}function Ek(e){return this.eachBefore(function(t){t.children&&t.children.sort(e)})}function Nk(e){for(var t=this,n=OW(t,e),r=[t];t!==n;)t=t.parent,r.push(t);for(var i=r.length;e!==n;)r.splice(i,0,e),e=e.parent;return r}function OW(e,t){if(e===t)return e;var n=e.ancestors(),r=t.ancestors(),i=null;for(e=n.pop(),t=r.pop();e===t;)i=e,e=n.pop(),t=r.pop();return i}function Dk(){for(var e=this,t=[e];e=e.parent;)t.push(e);return t}function Ok(){return Array.from(this)}function Bk(){var e=[];return this.eachBefore(function(t){t.children||e.push(t)}),e}function Lk(){var e=this,t=[];return e.each(function(n){n!==e&&t.push({source:n.parent,target:n})}),t}function*Ck(){var e=this,t,n=[e],r,i,o;do for(t=n.reverse(),n=[];e=t.pop();)if(yield e,r=e.children)for(i=0,o=r.length;i<o;++i)n.push(r[i]);while(n.length)}function BM(e,t){e instanceof Map?(e=[void 0,e],t===void 0&&(t=CW)):t===void 0&&(t=LW);for(var n=new Ua(e),r,i=[n],o,s,a,c;r=i.pop();)if((s=t(r.data))&&(c=(s=Array.from(s)).length))for(r.children=s,a=c-1;a>=0;--a)i.push(o=s[a]=new Ua(s[a])),o.parent=r,o.depth=r.depth+1;return n.eachBefore(LM)}function BW(){return BM(this).eachBefore(kW)}function LW(e){return e.children}function CW(e){return Array.isArray(e)?e[1]:null}function kW(e){e.data.value!==void 0&&(e.value=e.data.value),e.data=e.data.data}function LM(e){var t=0;do e.height=t;while((e=e.parent)&&e.height<++t)}function Ua(e){this.data=e,this.depth=this.height=0,this.parent=null}Ua.prototype=BM.prototype={constructor:Ua,count:_k,each:Sk,eachAfter:Mk,eachBefore:Ik,find:Ak,sum:Tk,sort:Ek,path:Nk,ancestors:Dk,descendants:Ok,leaves:Bk,links:Lk,copy:BW,[Symbol.iterator]:Ck};function xb(e){return e==null?null:FW(e)}function FW(e){if(typeof e!="function")throw new Error;return e}var RW={depth:-1},kk={},CM={};function $W(e){return e.id}function PW(e){return e.parentId}function bb(){var e=$W,t=PW,n;function r(i){var o=Array.from(i),s=e,a=t,c,l,u,f,d,h,p,m,g=new Map;if(n!=null){let y=o.map((w,v)=>UW(n(w,v,i))),x=y.map(Fk),b=new Set(y).add("");for(let w of x)b.has(w)||(b.add(w),y.push(w),x.push(Fk(w)),o.push(CM));s=(w,v)=>y[v],a=(w,v)=>x[v]}for(u=0,c=o.length;u<c;++u)l=o[u],h=o[u]=new Ua(l),(p=s(l,u,i))!=null&&(p+="")&&(m=h.id=p,g.set(m,g.has(m)?kk:h)),(p=a(l,u,i))!=null&&(p+="")&&(h.parent=p);for(u=0;u<c;++u)if(h=o[u],p=h.parent){if(d=g.get(p),!d)throw new Error("missing: "+p);if(d===kk)throw new Error("ambiguous: "+p);d.children?d.children.push(h):d.children=[h],h.parent=d}else{if(f)throw new Error("multiple roots");f=h}if(!f)throw new Error("no root");if(n!=null){for(;f.data===CM&&f.children.length===1;)f=f.children[0],--c;for(let y=o.length-1;y>=0&&(h=o[y],h.data===CM);--y)h.data=null}if(f.parent=RW,f.eachBefore(function(y){y.depth=y.parent.depth+1,--c}).eachBefore(LM),f.parent=null,c>0)throw new Error("cycle");return f}return r.id=function(i){return arguments.length?(e=xb(i),r):e},r.parentId=function(i){return arguments.length?(t=xb(i),r):t},r.path=function(i){return arguments.length?(n=xb(i),r):n},r}function UW(e){e=`${e}`;let t=e.length;return kM(e,t-1)&&!kM(e,t-2)&&(e=e.slice(0,-1)),e[0]==="/"?e:`/${e}`}function Fk(e){let t=e.length;if(t<2)return"";for(;--t>1&&!kM(e,t););return e.slice(0,t)}function kM(e,t){if(e[t]==="/"){let n=0;for(;t>0&&e[--t]==="\\";)++n;if(!(n&1))return!0}return!1}function zW(e,t){return e.parent===t.parent?1:2}function FM(e){var t=e.children;return t?t[0]:e.t}function RM(e){var t=e.children;return t?t[t.length-1]:e.t}function qW(e,t,n){var r=n/(t.i-e.i);t.c-=r,t.s+=n,e.c+=r,t.z+=n,t.m+=n}function jW(e){for(var t=0,n=0,r=e.children,i=r.length,o;--i>=0;)o=r[i],o.z+=t,o.m+=t,t+=o.s+(n+=o.c)}function VW(e,t,n){return e.a.parent===t.parent?e.a:n}function wb(e,t){this._=e,this.parent=null,this.children=null,this.A=null,this.a=this,this.z=0,this.m=0,this.c=0,this.s=0,this.t=null,this.i=t}wb.prototype=Object.create(Ua.prototype);function YW(e){for(var t=new wb(e,0),n,r=[t],i,o,s,a;n=r.pop();)if(o=n._.children)for(n.children=new Array(a=o.length),s=a-1;s>=0;--s)r.push(i=n.children[s]=new wb(o[s],s)),i.parent=n;return(t.parent=new wb(null,0)).children=[t],t}function ll(){var e=zW,t=1,n=1,r=null;function i(l){var u=YW(l);if(u.eachAfter(o),u.parent.m=-u.z,u.eachBefore(s),r)l.eachBefore(c);else{var f=l,d=l,h=l;l.eachBefore(function(x){x.x<f.x&&(f=x),x.x>d.x&&(d=x),x.depth>h.depth&&(h=x)});var p=f===d?1:e(f,d)/2,m=p-f.x,g=t/(d.x+p+m),y=n/(h.depth||1);l.eachBefore(function(x){x.x=(x.x+m)*g,x.y=x.depth*y})}return l}function o(l){var u=l.children,f=l.parent.children,d=l.i?f[l.i-1]:null;if(u){jW(l);var h=(u[0].z+u[u.length-1].z)/2;d?(l.z=d.z+e(l._,d._),l.m=l.z-h):l.z=h}else d&&(l.z=d.z+e(l._,d._));l.parent.A=a(l,d,l.parent.A||f[0])}function s(l){l._.x=l.z+l.parent.m,l.m+=l.parent.m}function a(l,u,f){if(u){for(var d=l,h=l,p=u,m=d.parent.children[0],g=d.m,y=h.m,x=p.m,b=m.m,w;p=RM(p),d=FM(d),p&&d;)m=FM(m),h=RM(h),h.a=l,w=p.z+x-d.z-g+e(p._,d._),w>0&&(qW(VW(p,l,f),l,w),g+=w,y+=w),x+=p.m,g+=d.m,b+=m.m,y+=h.m;p&&!RM(h)&&(h.t=p,h.m+=x-y),d&&!FM(m)&&(m.t=d,m.m+=g-b,f=l)}return f}function c(l){l.x*=t,l.y=l.depth*n}return i.separation=function(l){return arguments.length?(e=l,i):e},i.size=function(l){return arguments.length?(r=!1,t=+l[0],n=+l[1],i):r?null:[t,n]},i.nodeSize=function(l){return arguments.length?(r=!0,t=+l[0],n=+l[1],i):r?[t,n]:null},i}var Rk=23283064365386963e-26;function Mo(e=Math.random()){let t=(0<=e&&e<1?e/Rk:Math.abs(e))|0;return()=>(t=1664525*t+1013904223|0,Rk*(t>>>0))}function Je(e,t){switch(arguments.length){case 0:break;case 1:this.range(e);break;default:this.range(t).domain(e);break}return this}function Hp(e,t){switch(arguments.length){case 0:break;case 1:{typeof e=="function"?this.interpolator(e):this.range(e);break}default:{this.domain(e),typeof t=="function"?this.interpolator(t):this.range(t);break}}return this}var Zp=Symbol("implicit");function ul(){var e=new Zn,t=[],n=[],r=Zp;function i(o){let s=e.get(o);if(s===void 0){if(r!==Zp)return r;e.set(o,s=t.push(o)-1)}return n[s%n.length]}return i.domain=function(o){if(!arguments.length)return t.slice();t=[],e=new Zn;for(let s of o)e.has(s)||e.set(s,t.push(s)-1);return i},i.range=function(o){return arguments.length?(n=Array.from(o),i):n.slice()},i.unknown=function(o){return arguments.length?(r=o,i):r},i.copy=function(){return ul(t,n).unknown(r)},Je.apply(i,arguments),i}function za(){var e=ul().unknown(void 0),t=e.domain,n=e.range,r=0,i=1,o,s,a=!1,c=0,l=0,u=.5;delete e.unknown;function f(){var d=t().length,h=i<r,p=h?i:r,m=h?r:i;o=(m-p)/Math.max(1,d-c+l*2),a&&(o=Math.floor(o)),p+=(m-p-o*(d-c))*u,s=o*(1-c),a&&(p=Math.round(p),s=Math.round(s));var g=Ue(d).map(function(y){return p+o*y});return n(h?g.reverse():g)}return e.domain=function(d){return arguments.length?(t(d),f()):t()},e.range=function(d){return arguments.length?([r,i]=d,r=+r,i=+i,f()):[r,i]},e.rangeRound=function(d){return[r,i]=d,r=+r,i=+i,a=!0,f()},e.bandwidth=function(){return s},e.step=function(){return o},e.round=function(d){return arguments.length?(a=!!d,f()):a},e.padding=function(d){return arguments.length?(c=Math.min(1,l=+d),f()):c},e.paddingInner=function(d){return arguments.length?(c=Math.min(1,d),f()):c},e.paddingOuter=function(d){return arguments.length?(l=+d,f()):l},e.align=function(d){return arguments.length?(u=Math.max(0,Math.min(1,d)),f()):u},e.copy=function(){return za(t(),[r,i]).round(a).paddingInner(c).paddingOuter(l).align(u)},Je.apply(f(),arguments)}function $k(e){var t=e.copy;return e.padding=e.paddingOuter,delete e.paddingInner,delete e.paddingOuter,e.copy=function(){return $k(t())},e}function $M(){return $k(za.apply(null,arguments).paddingInner(1))}function PM(e){return function(){return e}}function sf(e){return+e}var Pk=[0,1];function wr(e){return e}function UM(e,t){return(t-=e=+e)?function(n){return(n-e)/t}:PM(isNaN(t)?NaN:.5)}function XW(e,t){var n;return e>t&&(n=e,e=t,t=n),function(r){return Math.max(e,Math.min(t,r))}}function GW(e,t,n){var r=e[0],i=e[1],o=t[0],s=t[1];return i<r?(r=UM(i,r),o=n(s,o)):(r=UM(r,i),o=n(o,s)),function(a){return o(r(a))}}function WW(e,t,n){var r=Math.min(e.length,t.length)-1,i=new Array(r),o=new Array(r),s=-1;for(e[r]<e[0]&&(e=e.slice().reverse(),t=t.slice().reverse());++s<r;)i[s]=UM(e[s],e[s+1]),o[s]=n(t[s],t[s+1]);return function(a){var c=Ts(e,a,1,r)-1;return o[c](i[c](a))}}function Ao(e,t){return t.domain(e.domain()).range(e.range()).interpolate(e.interpolate()).clamp(e.clamp()).unknown(e.unknown())}function fl(){var e=Pk,t=Pk,n=$r,r,i,o,s=wr,a,c,l;function u(){var d=Math.min(e.length,t.length);return s!==wr&&(s=XW(e[0],e[d-1])),a=d>2?WW:GW,c=l=null,f}function f(d){return d==null||isNaN(d=+d)?o:(c||(c=a(e.map(r),t,n)))(r(s(d)))}return f.invert=function(d){return s(i((l||(l=a(t,e.map(r),_e)))(d)))},f.domain=function(d){return arguments.length?(e=Array.from(d,sf),u()):e.slice()},f.range=function(d){return arguments.length?(t=Array.from(d),u()):t.slice()},f.rangeRound=function(d){return t=Array.from(d),n=Kc,u()},f.clamp=function(d){return arguments.length?(s=d?!0:wr,u()):s!==wr},f.interpolate=function(d){return arguments.length?(n=d,u()):n},f.unknown=function(d){return arguments.length?(o=d,f):o},function(d,h){return r=d,i=h,u()}}function Jp(){return fl()(wr,wr)}function zM(e,t,n,r){var i=Eu(e,t,n),o;switch(r=wo(r??",f"),r.type){case"s":{var s=Math.max(Math.abs(e),Math.abs(t));return r.precision==null&&!isNaN(o=CI(i,s))&&(r.precision=o),Px(r,s)}case"":case"e":case"g":case"p":case"r":{r.precision==null&&!isNaN(o=kI(i,Math.max(Math.abs(e),Math.abs(t))))&&(r.precision=o-(r.type==="e"));break}case"f":case"%":{r.precision==null&&!isNaN(o=LI(i))&&(r.precision=o-(r.type==="%")*2);break}}return ci(r)}function $s(e){var t=e.domain;return e.ticks=function(n){var r=t();return Mn(r[0],r[r.length-1],n??10)},e.tickFormat=function(n,r){var i=t();return zM(i[0],i[i.length-1],n??10,r)},e.nice=function(n){n==null&&(n=10);var r=t(),i=0,o=r.length-1,s=r[i],a=r[o],c,l,u=10;for(a<s&&(l=s,s=a,a=l,l=i,i=o,o=l);u-- >0;){if(l=Es(s,a,n),l===c)return r[i]=s,r[o]=a,t(r);if(l>0)s=Math.floor(s/l)*l,a=Math.ceil(a/l)*l;else if(l<0)s=Math.ceil(s*l)/l,a=Math.floor(a*l)/l;else break;c=l}return e},e}function Ps(){var e=Jp();return e.copy=function(){return Ao(e,Ps())},Je.apply(e,arguments),$s(e)}function Qp(e){var t;function n(r){return r==null||isNaN(r=+r)?t:r}return n.invert=n,n.domain=n.range=function(r){return arguments.length?(e=Array.from(r,sf),n):e.slice()},n.unknown=function(r){return arguments.length?(t=r,n):t},n.copy=function(){return Qp(e).unknown(t)},e=arguments.length?Array.from(e,sf):[0,1],$s(n)}function Kp(e,t){e=e.slice();var n=0,r=e.length-1,i=e[n],o=e[r],s;return o<i&&(s=n,n=r,r=s,s=i,i=o,o=s),e[n]=t.floor(i),e[r]=t.ceil(o),e}function Uk(e){return Math.log(e)}function zk(e){return Math.exp(e)}function HW(e){return-Math.log(-e)}function ZW(e){return-Math.exp(-e)}function JW(e){return isFinite(e)?+("1e"+e):e<0?0:e}function QW(e){return e===10?JW:e===Math.E?Math.exp:t=>Math.pow(e,t)}function KW(e){return e===Math.E?Math.log:e===10&&Math.log10||e===2&&Math.log2||(e=Math.log(e),t=>Math.log(t)/e)}function qk(e){return(t,n)=>-e(-t,n)}function qM(e){let t=e(Uk,zk),n=t.domain,r=10,i,o;function s(){return i=KW(r),o=QW(r),n()[0]<0?(i=qk(i),o=qk(o),e(HW,ZW)):e(Uk,zk),t}return t.base=function(a){return arguments.length?(r=+a,s()):r},t.domain=function(a){return arguments.length?(n(a),s()):n()},t.ticks=a=>{let c=n(),l=c[0],u=c[c.length-1],f=u<l;f&&([l,u]=[u,l]);let d=i(l),h=i(u),p,m,g=a==null?10:+a,y=[];if(!(r%1)&&h-d<g){if(d=Math.floor(d),h=Math.ceil(h),l>0){for(;d<=h;++d)for(p=1;p<r;++p)if(m=d<0?p/o(-d):p*o(d),!(m<l)){if(m>u)break;y.push(m)}}else for(;d<=h;++d)for(p=r-1;p>=1;--p)if(m=d>0?p/o(-d):p*o(d),!(m<l)){if(m>u)break;y.push(m)}y.length*2<g&&(y=Mn(l,u,g))}else y=Mn(d,h,Math.min(h-d,g)).map(o);return f?y.reverse():y},t.tickFormat=(a,c)=>{if(a==null&&(a=10),c==null&&(c=r===10?"s":","),typeof c!="function"&&(!(r%1)&&(c=wo(c)).precision==null&&(c.trim=!0),c=ci(c)),a===1/0)return c;let l=Math.max(1,r*a/t.ticks().length);return u=>{let f=u/o(Math.round(i(u)));return f*r<r-.5&&(f*=r),f<=l?c(u):""}},t.nice=()=>n(Kp(n(),{floor:a=>o(Math.floor(i(a))),ceil:a=>o(Math.ceil(i(a)))})),t}function tm(){let e=qM(fl()).domain([1,10]);return e.copy=()=>Ao(e,tm()).base(e.base()),Je.apply(e,arguments),e}function jk(e){return function(t){return Math.sign(t)*Math.log1p(Math.abs(t/e))}}function Vk(e){return function(t){return Math.sign(t)*Math.expm1(Math.abs(t))*e}}function jM(e){var t=1,n=e(jk(t),Vk(t));return n.constant=function(r){return arguments.length?e(jk(t=+r),Vk(t)):t},$s(n)}function em(){var e=jM(fl());return e.copy=function(){return Ao(e,em()).constant(e.constant())},Je.apply(e,arguments)}function Yk(e){return function(t){return t<0?-Math.pow(-t,e):Math.pow(t,e)}}function tH(e){return e<0?-Math.sqrt(-e):Math.sqrt(e)}function eH(e){return e<0?-e*e:e*e}function VM(e){var t=e(wr,wr),n=1;function r(){return n===1?e(wr,wr):n===.5?e(tH,eH):e(Yk(n),Yk(1/n))}return t.exponent=function(i){return arguments.length?(n=+i,r()):n},$s(t)}function nm(){var e=VM(fl());return e.copy=function(){return Ao(e,nm()).exponent(e.exponent())},Je.apply(e,arguments),e}function rm(){var e=[],t=[],n=[],r;function i(){var s=0,a=Math.max(1,t.length);for(n=new Array(a-1);++s<a;)n[s-1]=jS(e,s/a);return o}function o(s){return s==null||isNaN(s=+s)?r:t[Ts(n,s)]}return o.invertExtent=function(s){var a=t.indexOf(s);return a<0?[NaN,NaN]:[a>0?n[a-1]:e[0],a<n.length?n[a]:e[e.length-1]]},o.domain=function(s){if(!arguments.length)return e.slice();e=[];for(let a of s)a!=null&&!isNaN(a=+a)&&e.push(a);return e.sort(zt),i()},o.range=function(s){return arguments.length?(t=Array.from(s),i()):t.slice()},o.unknown=function(s){return arguments.length?(r=s,o):r},o.quantiles=function(){return n.slice()},o.copy=function(){return rm().domain(e).range(t).unknown(r)},Je.apply(o,arguments)}function im(){var e=[.5],t=[0,1],n,r=1;function i(o){return o!=null&&o<=o?t[Ts(e,o,0,r)]:n}return i.domain=function(o){return arguments.length?(e=Array.from(o),r=Math.min(e.length,t.length-1),i):e.slice()},i.range=function(o){return arguments.length?(t=Array.from(o),r=Math.min(e.length,t.length-1),i):t.slice()},i.invertExtent=function(o){var s=t.indexOf(o);return[e[s-1],e[s]]},i.unknown=function(o){return arguments.length?(n=o,i):n},i.copy=function(){return im().domain(e).range(t).unknown(n)},Je.apply(i,arguments)}var YM=new Date,XM=new Date;function xe(e,t,n,r){function i(o){return e(o=arguments.length===0?new Date:new Date(+o)),o}return i.floor=o=>(e(o=new Date(+o)),o),i.ceil=o=>(e(o=new Date(o-1)),t(o,1),e(o),o),i.round=o=>{let s=i(o),a=i.ceil(o);return o-s<a-o?s:a},i.offset=(o,s)=>(t(o=new Date(+o),s==null?1:Math.floor(s)),o),i.range=(o,s,a)=>{let c=[];if(o=i.ceil(o),a=a==null?1:Math.floor(a),!(o<s)||!(a>0))return c;let l;do c.push(l=new Date(+o)),t(o,a),e(o);while(l<o&&o<s);return c},i.filter=o=>xe(s=>{if(s>=s)for(;e(s),!o(s);)s.setTime(s-1)},(s,a)=>{if(s>=s)if(a<0)for(;++a<=0;)for(;t(s,-1),!o(s););else for(;--a>=0;)for(;t(s,1),!o(s););}),n&&(i.count=(o,s)=>(YM.setTime(+o),XM.setTime(+s),e(YM),e(XM),Math.floor(n(YM,XM))),i.every=o=>(o=Math.floor(o),!isFinite(o)||!(o>0)?null:o>1?i.filter(r?s=>r(s)%o===0:s=>i.count(0,s)%o===0):i)),i}var om=xe(()=>{},(e,t)=>{e.setTime(+e+t)},(e,t)=>t-e);om.every=e=>(e=Math.floor(e),!isFinite(e)||!(e>0)?null:e>1?xe(t=>{t.setTime(Math.floor(t/e)*e)},(t,n)=>{t.setTime(+t+n*e)},(t,n)=>(n-t)/e):om);var d6t=om.range;var un=xe(e=>{e.setTime(e-e.getMilliseconds())},(e,t)=>{e.setTime(+e+t*1e3)},(e,t)=>(t-e)/1e3,e=>e.getUTCSeconds()),Xk=un.range;var Us=xe(e=>{e.setTime(e-e.getMilliseconds()-e.getSeconds()*1e3)},(e,t)=>{e.setTime(+e+t*6e4)},(e,t)=>(t-e)/6e4,e=>e.getMinutes()),nH=Us.range,zs=xe(e=>{e.setUTCSeconds(0,0)},(e,t)=>{e.setTime(+e+t*6e4)},(e,t)=>(t-e)/6e4,e=>e.getUTCMinutes()),rH=zs.range;var qs=xe(e=>{e.setTime(e-e.getMilliseconds()-e.getSeconds()*1e3-e.getMinutes()*6e4)},(e,t)=>{e.setTime(+e+t*36e5)},(e,t)=>(t-e)/36e5,e=>e.getHours()),iH=qs.range,js=xe(e=>{e.setUTCMinutes(0,0,0)},(e,t)=>{e.setTime(+e+t*36e5)},(e,t)=>(t-e)/36e5,e=>e.getUTCHours()),oH=js.range;var ui=xe(e=>e.setHours(0,0,0,0),(e,t)=>e.setDate(e.getDate()+t),(e,t)=>(t-e-(t.getTimezoneOffset()-e.getTimezoneOffset())*6e4)/864e5,e=>e.getDate()-1),sH=ui.range,pl=xe(e=>{e.setUTCHours(0,0,0,0)},(e,t)=>{e.setUTCDate(e.getUTCDate()+t)},(e,t)=>(t-e)/864e5,e=>e.getUTCDate()-1),aH=pl.range,ml=xe(e=>{e.setUTCHours(0,0,0,0)},(e,t)=>{e.setUTCDate(e.getUTCDate()+t)},(e,t)=>(t-e)/864e5,e=>Math.floor(e/864e5)),cH=ml.range;function yl(e){return xe(t=>{t.setDate(t.getDate()-(t.getDay()+7-e)%7),t.setHours(0,0,0,0)},(t,n)=>{t.setDate(t.getDate()+n*7)},(t,n)=>(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*6e4)/6048e5)}var Ur=yl(0),qa=yl(1),vb=yl(2),_b=yl(3),Eo=yl(4),Sb=yl(5),Ib=yl(6),Wk=Ur.range,lH=qa.range,uH=vb.range,fH=_b.range,dH=Eo.range,hH=Sb.range,pH=Ib.range;function gl(e){return xe(t=>{t.setUTCDate(t.getUTCDate()-(t.getUTCDay()+7-e)%7),t.setUTCHours(0,0,0,0)},(t,n)=>{t.setUTCDate(t.getUTCDate()+n*7)},(t,n)=>(n-t)/6048e5)}var zr=gl(0),ja=gl(1),Mb=gl(2),Ab=gl(3),No=gl(4),Tb=gl(5),Eb=gl(6),Hk=zr.range,mH=ja.range,yH=Mb.range,gH=Ab.range,xH=No.range,bH=Tb.range,wH=Eb.range;var Vs=xe(e=>{e.setDate(1),e.setHours(0,0,0,0)},(e,t)=>{e.setMonth(e.getMonth()+t)},(e,t)=>t.getMonth()-e.getMonth()+(t.getFullYear()-e.getFullYear())*12,e=>e.getMonth()),vH=Vs.range,Ys=xe(e=>{e.setUTCDate(1),e.setUTCHours(0,0,0,0)},(e,t)=>{e.setUTCMonth(e.getUTCMonth()+t)},(e,t)=>t.getUTCMonth()-e.getUTCMonth()+(t.getUTCFullYear()-e.getUTCFullYear())*12,e=>e.getUTCMonth()),_H=Ys.range;var zn=xe(e=>{e.setMonth(0,1),e.setHours(0,0,0,0)},(e,t)=>{e.setFullYear(e.getFullYear()+t)},(e,t)=>t.getFullYear()-e.getFullYear(),e=>e.getFullYear());zn.every=e=>!isFinite(e=Math.floor(e))||!(e>0)?null:xe(t=>{t.setFullYear(Math.floor(t.getFullYear()/e)*e),t.setMonth(0,1),t.setHours(0,0,0,0)},(t,n)=>{t.setFullYear(t.getFullYear()+n*e)});var SH=zn.range,qn=xe(e=>{e.setUTCMonth(0,1),e.setUTCHours(0,0,0,0)},(e,t)=>{e.setUTCFullYear(e.getUTCFullYear()+t)},(e,t)=>t.getUTCFullYear()-e.getUTCFullYear(),e=>e.getUTCFullYear());qn.every=e=>!isFinite(e=Math.floor(e))||!(e>0)?null:xe(t=>{t.setUTCFullYear(Math.floor(t.getUTCFullYear()/e)*e),t.setUTCMonth(0,1),t.setUTCHours(0,0,0,0)},(t,n)=>{t.setUTCFullYear(t.getUTCFullYear()+n*e)});var IH=qn.range;function Jk(e,t,n,r,i,o){let s=[[un,1,1e3],[un,5,5*1e3],[un,15,15*1e3],[un,30,30*1e3],[o,1,6e4],[o,5,5*6e4],[o,15,15*6e4],[o,30,30*6e4],[i,1,36e5],[i,3,3*36e5],[i,6,6*36e5],[i,12,12*36e5],[r,1,864e5],[r,2,2*864e5],[n,1,6048e5],[t,1,2592e6],[t,3,3*2592e6],[e,1,31536e6]];function a(l,u,f){let d=u<l;d&&([l,u]=[u,l]);let h=f&&typeof f.range=="function"?f:c(l,u,f),p=h?h.range(l,+u+1):[];return d?p.reverse():p}function c(l,u,f){let d=Math.abs(u-l)/f,h=As(([,,g])=>g).right(s,d);if(h===s.length)return e.every(Eu(l/31536e6,u/31536e6,f));if(h===0)return om.every(Math.max(Eu(l,u,f),1));let[p,m]=s[d/s[h-1][2]<s[h][2]/d?h-1:h];return p.every(m)}return[a,c]}var[GM,am]=Jk(qn,Ys,zr,ml,js,zs),[WM,HM]=Jk(zn,Vs,Ur,ui,qs,Us);function ZM(e){if(0<=e.y&&e.y<100){var t=new Date(-1,e.m,e.d,e.H,e.M,e.S,e.L);return t.setFullYear(e.y),t}return new Date(e.y,e.m,e.d,e.H,e.M,e.S,e.L)}function JM(e){if(0<=e.y&&e.y<100){var t=new Date(Date.UTC(-1,e.m,e.d,e.H,e.M,e.S,e.L));return t.setUTCFullYear(e.y),t}return new Date(Date.UTC(e.y,e.m,e.d,e.H,e.M,e.S,e.L))}function cm(e,t,n){return{y:e,m:t,d:n,H:0,M:0,S:0,L:0}}function QM(e){var t=e.dateTime,n=e.date,r=e.time,i=e.periods,o=e.days,s=e.shortDays,a=e.months,c=e.shortMonths,l=lm(i),u=um(i),f=lm(o),d=um(o),h=lm(s),p=um(s),m=lm(a),g=um(a),y=lm(c),x=um(c),b={a:F,A:R,b:k,B:$,c:null,d:rF,e:rF,f:WH,g:iZ,G:sZ,H:YH,I:XH,j:GH,L:cF,m:HH,M:ZH,p:P,q:U,Q:sF,s:aF,S:JH,u:QH,U:KH,V:tZ,w:eZ,W:nZ,x:null,X:null,y:rZ,Y:oZ,Z:aZ,"%":oF},w={a:W,A:tt,b:nt,B:at,c:null,d:iF,e:iF,f:fZ,g:vZ,G:SZ,H:cZ,I:lZ,j:uZ,L:uF,m:dZ,M:hZ,p:Y,q:rt,Q:sF,s:aF,S:pZ,u:mZ,U:yZ,V:gZ,w:xZ,W:bZ,x:null,X:null,y:wZ,Y:_Z,Z:IZ,"%":oF},v={a:E,A:T,b:O,B:C,c:S,d:eF,e:eF,f:zH,g:tF,G:Kk,H:nF,I:nF,j:RH,L:UH,m:FH,M:$H,p:A,q:kH,Q:jH,s:VH,S:PH,u:DH,U:OH,V:BH,w:NH,W:LH,x:M,X:N,y:tF,Y:Kk,Z:CH,"%":qH};b.x=_(n,b),b.X=_(r,b),b.c=_(t,b),w.x=_(n,w),w.X=_(r,w),w.c=_(t,w);function _(j,H){return function(ot){var z=[],kt=-1,dt=0,Ht=j.length,Zt,et,ae;for(ot instanceof Date||(ot=new Date(+ot));++kt<Ht;)j.charCodeAt(kt)===37&&(z.push(j.slice(dt,kt)),(et=Qk[Zt=j.charAt(++kt)])!=null?Zt=j.charAt(++kt):et=Zt==="e"?" ":"0",(ae=H[Zt])&&(Zt=ae(ot,et)),z.push(Zt),dt=kt+1);return z.push(j.slice(dt,kt)),z.join("")}}function I(j,H){return function(ot){var z=cm(1900,void 0,1),kt=D(z,j,ot+="",0),dt,Ht;if(kt!=ot.length)return null;if("Q"in z)return new Date(z.Q);if("s"in z)return new Date(z.s*1e3+("L"in z?z.L:0));if(H&&!("Z"in z)&&(z.Z=0),"p"in z&&(z.H=z.H%12+z.p*12),z.m===void 0&&(z.m="q"in z?z.q:0),"V"in z){if(z.V<1||z.V>53)return null;"w"in z||(z.w=1),"Z"in z?(dt=JM(cm(z.y,0,1)),Ht=dt.getUTCDay(),dt=Ht>4||Ht===0?ja.ceil(dt):ja(dt),dt=pl.offset(dt,(z.V-1)*7),z.y=dt.getUTCFullYear(),z.m=dt.getUTCMonth(),z.d=dt.getUTCDate()+(z.w+6)%7):(dt=ZM(cm(z.y,0,1)),Ht=dt.getDay(),dt=Ht>4||Ht===0?qa.ceil(dt):qa(dt),dt=ui.offset(dt,(z.V-1)*7),z.y=dt.getFullYear(),z.m=dt.getMonth(),z.d=dt.getDate()+(z.w+6)%7)}else("W"in z||"U"in z)&&("w"in z||(z.w="u"in z?z.u%7:"W"in z?1:0),Ht="Z"in z?JM(cm(z.y,0,1)).getUTCDay():ZM(cm(z.y,0,1)).getDay(),z.m=0,z.d="W"in z?(z.w+6)%7+z.W*7-(Ht+5)%7:z.w+z.U*7-(Ht+6)%7);return"Z"in z?(z.H+=z.Z/100|0,z.M+=z.Z%100,JM(z)):ZM(z)}}function D(j,H,ot,z){for(var kt=0,dt=H.length,Ht=ot.length,Zt,et;kt<dt;){if(z>=Ht)return-1;if(Zt=H.charCodeAt(kt++),Zt===37){if(Zt=H.charAt(kt++),et=v[Zt in Qk?H.charAt(kt++):Zt],!et||(z=et(j,ot,z))<0)return-1}else if(Zt!=ot.charCodeAt(z++))return-1}return z}function A(j,H,ot){var z=l.exec(H.slice(ot));return z?(j.p=u.get(z[0].toLowerCase()),ot+z[0].length):-1}function E(j,H,ot){var z=h.exec(H.slice(ot));return z?(j.w=p.get(z[0].toLowerCase()),ot+z[0].length):-1}function T(j,H,ot){var z=f.exec(H.slice(ot));return z?(j.w=d.get(z[0].toLowerCase()),ot+z[0].length):-1}function O(j,H,ot){var z=y.exec(H.slice(ot));return z?(j.m=x.get(z[0].toLowerCase()),ot+z[0].length):-1}function C(j,H,ot){var z=m.exec(H.slice(ot));return z?(j.m=g.get(z[0].toLowerCase()),ot+z[0].length):-1}function S(j,H,ot){return D(j,t,H,ot)}function M(j,H,ot){return D(j,n,H,ot)}function N(j,H,ot){return D(j,r,H,ot)}function F(j){return s[j.getDay()]}function R(j){return o[j.getDay()]}function k(j){return c[j.getMonth()]}function $(j){return a[j.getMonth()]}function P(j){return i[+(j.getHours()>=12)]}function U(j){return 1+~~(j.getMonth()/3)}function W(j){return s[j.getUTCDay()]}function tt(j){return o[j.getUTCDay()]}function nt(j){return c[j.getUTCMonth()]}function at(j){return a[j.getUTCMonth()]}function Y(j){return i[+(j.getUTCHours()>=12)]}function rt(j){return 1+~~(j.getUTCMonth()/3)}return{format:function(j){var H=_(j+="",b);return H.toString=function(){return j},H},parse:function(j){var H=I(j+="",!1);return H.toString=function(){return j},H},utcFormat:function(j){var H=_(j+="",w);return H.toString=function(){return j},H},utcParse:function(j){var H=I(j+="",!0);return H.toString=function(){return j},H}}}var Qk={"-":"",_:" ",0:"0"},fn=/^\s*\d+/,AH=/^%/,TH=/[\\^$*+?|[\]().{}]/g;function ee(e,t,n){var r=e<0?"-":"",i=(r?-e:e)+"",o=i.length;return r+(o<n?new Array(n-o+1).join(t)+i:i)}function EH(e){return e.replace(TH,"\\$&")}function lm(e){return new RegExp("^(?:"+e.map(EH).join("|")+")","i")}function um(e){return new Map(e.map((t,n)=>[t.toLowerCase(),n]))}function NH(e,t,n){var r=fn.exec(t.slice(n,n+1));return r?(e.w=+r[0],n+r[0].length):-1}function DH(e,t,n){var r=fn.exec(t.slice(n,n+1));return r?(e.u=+r[0],n+r[0].length):-1}function OH(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.U=+r[0],n+r[0].length):-1}function BH(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.V=+r[0],n+r[0].length):-1}function LH(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.W=+r[0],n+r[0].length):-1}function Kk(e,t,n){var r=fn.exec(t.slice(n,n+4));return r?(e.y=+r[0],n+r[0].length):-1}function tF(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.y=+r[0]+(+r[0]>68?1900:2e3),n+r[0].length):-1}function CH(e,t,n){var r=/^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(t.slice(n,n+6));return r?(e.Z=r[1]?0:-(r[2]+(r[3]||"00")),n+r[0].length):-1}function kH(e,t,n){var r=fn.exec(t.slice(n,n+1));return r?(e.q=r[0]*3-3,n+r[0].length):-1}function FH(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.m=r[0]-1,n+r[0].length):-1}function eF(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.d=+r[0],n+r[0].length):-1}function RH(e,t,n){var r=fn.exec(t.slice(n,n+3));return r?(e.m=0,e.d=+r[0],n+r[0].length):-1}function nF(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.H=+r[0],n+r[0].length):-1}function $H(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.M=+r[0],n+r[0].length):-1}function PH(e,t,n){var r=fn.exec(t.slice(n,n+2));return r?(e.S=+r[0],n+r[0].length):-1}function UH(e,t,n){var r=fn.exec(t.slice(n,n+3));return r?(e.L=+r[0],n+r[0].length):-1}function zH(e,t,n){var r=fn.exec(t.slice(n,n+6));return r?(e.L=Math.floor(r[0]/1e3),n+r[0].length):-1}function qH(e,t,n){var r=AH.exec(t.slice(n,n+1));return r?n+r[0].length:-1}function jH(e,t,n){var r=fn.exec(t.slice(n));return r?(e.Q=+r[0],n+r[0].length):-1}function VH(e,t,n){var r=fn.exec(t.slice(n));return r?(e.s=+r[0],n+r[0].length):-1}function rF(e,t){return ee(e.getDate(),t,2)}function YH(e,t){return ee(e.getHours(),t,2)}function XH(e,t){return ee(e.getHours()%12||12,t,2)}function GH(e,t){return ee(1+ui.count(zn(e),e),t,3)}function cF(e,t){return ee(e.getMilliseconds(),t,3)}function WH(e,t){return cF(e,t)+"000"}function HH(e,t){return ee(e.getMonth()+1,t,2)}function ZH(e,t){return ee(e.getMinutes(),t,2)}function JH(e,t){return ee(e.getSeconds(),t,2)}function QH(e){var t=e.getDay();return t===0?7:t}function KH(e,t){return ee(Ur.count(zn(e)-1,e),t,2)}function lF(e){var t=e.getDay();return t>=4||t===0?Eo(e):Eo.ceil(e)}function tZ(e,t){return e=lF(e),ee(Eo.count(zn(e),e)+(zn(e).getDay()===4),t,2)}function eZ(e){return e.getDay()}function nZ(e,t){return ee(qa.count(zn(e)-1,e),t,2)}function rZ(e,t){return ee(e.getFullYear()%100,t,2)}function iZ(e,t){return e=lF(e),ee(e.getFullYear()%100,t,2)}function oZ(e,t){return ee(e.getFullYear()%1e4,t,4)}function sZ(e,t){var n=e.getDay();return e=n>=4||n===0?Eo(e):Eo.ceil(e),ee(e.getFullYear()%1e4,t,4)}function aZ(e){var t=e.getTimezoneOffset();return(t>0?"-":(t*=-1,"+"))+ee(t/60|0,"0",2)+ee(t%60,"0",2)}function iF(e,t){return ee(e.getUTCDate(),t,2)}function cZ(e,t){return ee(e.getUTCHours(),t,2)}function lZ(e,t){return ee(e.getUTCHours()%12||12,t,2)}function uZ(e,t){return ee(1+pl.count(qn(e),e),t,3)}function uF(e,t){return ee(e.getUTCMilliseconds(),t,3)}function fZ(e,t){return uF(e,t)+"000"}function dZ(e,t){return ee(e.getUTCMonth()+1,t,2)}function hZ(e,t){return ee(e.getUTCMinutes(),t,2)}function pZ(e,t){return ee(e.getUTCSeconds(),t,2)}function mZ(e){var t=e.getUTCDay();return t===0?7:t}function yZ(e,t){return ee(zr.count(qn(e)-1,e),t,2)}function fF(e){var t=e.getUTCDay();return t>=4||t===0?No(e):No.ceil(e)}function gZ(e,t){return e=fF(e),ee(No.count(qn(e),e)+(qn(e).getUTCDay()===4),t,2)}function xZ(e){return e.getUTCDay()}function bZ(e,t){return ee(ja.count(qn(e)-1,e),t,2)}function wZ(e,t){return ee(e.getUTCFullYear()%100,t,2)}function vZ(e,t){return e=fF(e),ee(e.getUTCFullYear()%100,t,2)}function _Z(e,t){return ee(e.getUTCFullYear()%1e4,t,4)}function SZ(e,t){var n=e.getUTCDay();return e=n>=4||n===0?No(e):No.ceil(e),ee(e.getUTCFullYear()%1e4,t,4)}function IZ(){return"+0000"}function oF(){return"%"}function sF(e){return+e}function aF(e){return Math.floor(+e/1e3)}var af,cf,dF,Do,hF;KM({dateTime:"%x, %X",date:"%-m/%-d/%Y",time:"%-I:%M:%S %p",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});function KM(e){return af=QM(e),cf=af.format,dF=af.parse,Do=af.utcFormat,hF=af.utcParse,af}function MZ(e){return new Date(e)}function AZ(e){return e instanceof Date?+e:+new Date(+e)}function Nb(e,t,n,r,i,o,s,a,c,l){var u=Jp(),f=u.invert,d=u.domain,h=l(".%L"),p=l(":%S"),m=l("%I:%M"),g=l("%I %p"),y=l("%a %d"),x=l("%b %d"),b=l("%B"),w=l("%Y");function v(_){return(c(_)<_?h:a(_)<_?p:s(_)<_?m:o(_)<_?g:r(_)<_?i(_)<_?y:x:n(_)<_?b:w)(_)}return u.invert=function(_){return new Date(f(_))},u.domain=function(_){return arguments.length?d(Array.from(_,AZ)):d().map(MZ)},u.ticks=function(_){var I=d();return e(I[0],I[I.length-1],_??10)},u.tickFormat=function(_,I){return I==null?v:l(I)},u.nice=function(_){var I=d();return(!_||typeof _.range!="function")&&(_=t(I[0],I[I.length-1],_??10)),_?d(Kp(I,_)):u},u.copy=function(){return Ao(u,Nb(e,t,n,r,i,o,s,a,c,l))},u}function Db(){return Je.apply(Nb(WM,HM,zn,Vs,Ur,ui,qs,Us,un,cf).domain([new Date(2e3,0,1),new Date(2e3,0,2)]),arguments)}function Ob(){return Je.apply(Nb(GM,am,qn,Ys,zr,pl,js,zs,un,Do).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)]),arguments)}function fm(e,t){return t.domain(e.domain()).interpolator(e.interpolator()).clamp(e.clamp()).unknown(e.unknown())}function Bb(){var e=0,t=.5,n=1,r=1,i,o,s,a,c,l=wr,u,f=!1,d;function h(m){return isNaN(m=+m)?d:(m=.5+((m=+u(m))-o)*(r*m<r*o?a:c),l(f?Math.max(0,Math.min(1,m)):m))}h.domain=function(m){return arguments.length?([e,t,n]=m,i=u(e=+e),o=u(t=+t),s=u(n=+n),a=i===o?0:.5/(o-i),c=o===s?0:.5/(s-o),r=o<i?-1:1,h):[e,t,n]},h.clamp=function(m){return arguments.length?(f=!!m,h):f},h.interpolator=function(m){return arguments.length?(l=m,h):l};function p(m){return function(g){var y,x,b;return arguments.length?([y,x,b]=g,l=yo(m,[y,x,b]),h):[l(0),l(.5),l(1)]}}return h.range=p($r),h.rangeRound=p(Kc),h.unknown=function(m){return arguments.length?(d=m,h):d},function(m){return u=m,i=m(e),o=m(t),s=m(n),a=i===o?0:.5/(o-i),c=o===s?0:.5/(s-o),r=o<i?-1:1,h}}function dm(){var e=$s(Bb()(wr));return e.copy=function(){return fm(e,dm())},Hp.apply(e,arguments)}function Lb(){var e=qM(Bb()).domain([.1,1,10]);return e.copy=function(){return fm(e,Lb()).base(e.base())},Hp.apply(e,arguments)}function Cb(){var e=jM(Bb());return e.copy=function(){return fm(e,Cb()).constant(e.constant())},Hp.apply(e,arguments)}function kb(){var e=VM(Bb());return e.copy=function(){return fm(e,kb()).exponent(e.exponent())},Hp.apply(e,arguments)}function X(e){for(var t=e.length/6|0,n=new Array(t),r=0;r<t;)n[r]="#"+e.slice(r*6,++r*6);return n}var tA=X("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf");var eA=X("7fc97fbeaed4fdc086ffff99386cb0f0027fbf5b17666666");var nA=X("1b9e77d95f027570b3e7298a66a61ee6ab02a6761d666666");var rA=X("a6cee31f78b4b2df8a33a02cfb9a99e31a1cfdbf6fff7f00cab2d66a3d9affff99b15928");var iA=X("fbb4aeb3cde3ccebc5decbe4fed9a6ffffcce5d8bdfddaecf2f2f2");var oA=X("b3e2cdfdcdaccbd5e8f4cae4e6f5c9fff2aef1e2cccccccc");var sA=X("e41a1c377eb84daf4a984ea3ff7f00ffff33a65628f781bf999999");var aA=X("66c2a5fc8d628da0cbe78ac3a6d854ffd92fe5c494b3b3b3");var cA=X("8dd3c7ffffb3bebadafb807280b1d3fdb462b3de69fccde5d9d9d9bc80bdccebc5ffed6f");var lA=X("4e79a7f28e2ce1575976b7b259a14fedc949af7aa1ff9da79c755fbab0ab");var pt=e=>oI(e[e.length-1]);var Fb=new Array(3).concat("d8b365f5f5f55ab4ac","a6611adfc27d80cdc1018571","a6611adfc27df5f5f580cdc1018571","8c510ad8b365f6e8c3c7eae55ab4ac01665e","8c510ad8b365f6e8c3f5f5f5c7eae55ab4ac01665e","8c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e","8c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e","5430058c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e003c30","5430058c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e003c30").map(X),Rb=pt(Fb);var $b=new Array(3).concat("af8dc3f7f7f77fbf7b","7b3294c2a5cfa6dba0008837","7b3294c2a5cff7f7f7a6dba0008837","762a83af8dc3e7d4e8d9f0d37fbf7b1b7837","762a83af8dc3e7d4e8f7f7f7d9f0d37fbf7b1b7837","762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b7837","762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b7837","40004b762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b783700441b","40004b762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b783700441b").map(X),Pb=pt($b);var Ub=new Array(3).concat("e9a3c9f7f7f7a1d76a","d01c8bf1b6dab8e1864dac26","d01c8bf1b6daf7f7f7b8e1864dac26","c51b7de9a3c9fde0efe6f5d0a1d76a4d9221","c51b7de9a3c9fde0eff7f7f7e6f5d0a1d76a4d9221","c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221","c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221","8e0152c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221276419","8e0152c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221276419").map(X),zb=pt(Ub);var qb=new Array(3).concat("998ec3f7f7f7f1a340","5e3c99b2abd2fdb863e66101","5e3c99b2abd2f7f7f7fdb863e66101","542788998ec3d8daebfee0b6f1a340b35806","542788998ec3d8daebf7f7f7fee0b6f1a340b35806","5427888073acb2abd2d8daebfee0b6fdb863e08214b35806","5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b35806","2d004b5427888073acb2abd2d8daebfee0b6fdb863e08214b358067f3b08","2d004b5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b358067f3b08").map(X),jb=pt(qb);var hm=new Array(3).concat("ef8a62f7f7f767a9cf","ca0020f4a58292c5de0571b0","ca0020f4a582f7f7f792c5de0571b0","b2182bef8a62fddbc7d1e5f067a9cf2166ac","b2182bef8a62fddbc7f7f7f7d1e5f067a9cf2166ac","b2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac","b2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac","67001fb2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac053061","67001fb2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac053061").map(X),lf=pt(hm);var Vb=new Array(3).concat("ef8a62ffffff999999","ca0020f4a582bababa404040","ca0020f4a582ffffffbababa404040","b2182bef8a62fddbc7e0e0e09999994d4d4d","b2182bef8a62fddbc7ffffffe0e0e09999994d4d4d","b2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d","b2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d","67001fb2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d1a1a1a","67001fb2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d1a1a1a").map(X),Yb=pt(Vb);var pm=new Array(3).concat("fc8d59ffffbf91bfdb","d7191cfdae61abd9e92c7bb6","d7191cfdae61ffffbfabd9e92c7bb6","d73027fc8d59fee090e0f3f891bfdb4575b4","d73027fc8d59fee090ffffbfe0f3f891bfdb4575b4","d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4","d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4","a50026d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4313695","a50026d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4313695").map(X),uf=pt(pm);var Xb=new Array(3).concat("fc8d59ffffbf91cf60","d7191cfdae61a6d96a1a9641","d7191cfdae61ffffbfa6d96a1a9641","d73027fc8d59fee08bd9ef8b91cf601a9850","d73027fc8d59fee08bffffbfd9ef8b91cf601a9850","d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850","d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850","a50026d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850006837","a50026d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850006837").map(X),Gb=pt(Xb);var Wb=new Array(3).concat("fc8d59ffffbf99d594","d7191cfdae61abdda42b83ba","d7191cfdae61ffffbfabdda42b83ba","d53e4ffc8d59fee08be6f59899d5943288bd","d53e4ffc8d59fee08bffffbfe6f59899d5943288bd","d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd","d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd","9e0142d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd5e4fa2","9e0142d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd5e4fa2").map(X),Hb=pt(Wb);var Zb=new Array(3).concat("e5f5f999d8c92ca25f","edf8fbb2e2e266c2a4238b45","edf8fbb2e2e266c2a42ca25f006d2c","edf8fbccece699d8c966c2a42ca25f006d2c","edf8fbccece699d8c966c2a441ae76238b45005824","f7fcfde5f5f9ccece699d8c966c2a441ae76238b45005824","f7fcfde5f5f9ccece699d8c966c2a441ae76238b45006d2c00441b").map(X),Jb=pt(Zb);var Qb=new Array(3).concat("e0ecf49ebcda8856a7","edf8fbb3cde38c96c688419d","edf8fbb3cde38c96c68856a7810f7c","edf8fbbfd3e69ebcda8c96c68856a7810f7c","edf8fbbfd3e69ebcda8c96c68c6bb188419d6e016b","f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d6e016b","f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d810f7c4d004b").map(X),Kb=pt(Qb);var t1=new Array(3).concat("e0f3dba8ddb543a2ca","f0f9e8bae4bc7bccc42b8cbe","f0f9e8bae4bc7bccc443a2ca0868ac","f0f9e8ccebc5a8ddb57bccc443a2ca0868ac","f0f9e8ccebc5a8ddb57bccc44eb3d32b8cbe08589e","f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe08589e","f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe0868ac084081").map(X),e1=pt(t1);var n1=new Array(3).concat("fee8c8fdbb84e34a33","fef0d9fdcc8afc8d59d7301f","fef0d9fdcc8afc8d59e34a33b30000","fef0d9fdd49efdbb84fc8d59e34a33b30000","fef0d9fdd49efdbb84fc8d59ef6548d7301f990000","fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301f990000","fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301fb300007f0000").map(X),r1=pt(n1);var i1=new Array(3).concat("ece2f0a6bddb1c9099","f6eff7bdc9e167a9cf02818a","f6eff7bdc9e167a9cf1c9099016c59","f6eff7d0d1e6a6bddb67a9cf1c9099016c59","f6eff7d0d1e6a6bddb67a9cf3690c002818a016450","fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016450","fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016c59014636").map(X),o1=pt(i1);var s1=new Array(3).concat("ece7f2a6bddb2b8cbe","f1eef6bdc9e174a9cf0570b0","f1eef6bdc9e174a9cf2b8cbe045a8d","f1eef6d0d1e6a6bddb74a9cf2b8cbe045a8d","f1eef6d0d1e6a6bddb74a9cf3690c00570b0034e7b","fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0034e7b","fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0045a8d023858").map(X),a1=pt(s1);var c1=new Array(3).concat("e7e1efc994c7dd1c77","f1eef6d7b5d8df65b0ce1256","f1eef6d7b5d8df65b0dd1c77980043","f1eef6d4b9dac994c7df65b0dd1c77980043","f1eef6d4b9dac994c7df65b0e7298ace125691003f","f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125691003f","f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125698004367001f").map(X),l1=pt(c1);var u1=new Array(3).concat("fde0ddfa9fb5c51b8a","feebe2fbb4b9f768a1ae017e","feebe2fbb4b9f768a1c51b8a7a0177","feebe2fcc5c0fa9fb5f768a1c51b8a7a0177","feebe2fcc5c0fa9fb5f768a1dd3497ae017e7a0177","fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a0177","fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a017749006a").map(X),f1=pt(u1);var d1=new Array(3).concat("edf8b17fcdbb2c7fb8","ffffcca1dab441b6c4225ea8","ffffcca1dab441b6c42c7fb8253494","ffffccc7e9b47fcdbb41b6c42c7fb8253494","ffffccc7e9b47fcdbb41b6c41d91c0225ea80c2c84","ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea80c2c84","ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea8253494081d58").map(X),h1=pt(d1);var p1=new Array(3).concat("f7fcb9addd8e31a354","ffffccc2e69978c679238443","ffffccc2e69978c67931a354006837","ffffccd9f0a3addd8e78c67931a354006837","ffffccd9f0a3addd8e78c67941ab5d238443005a32","ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443005a32","ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443006837004529").map(X),m1=pt(p1);var y1=new Array(3).concat("fff7bcfec44fd95f0e","ffffd4fed98efe9929cc4c02","ffffd4fed98efe9929d95f0e993404","ffffd4fee391fec44ffe9929d95f0e993404","ffffd4fee391fec44ffe9929ec7014cc4c028c2d04","ffffe5fff7bcfee391fec44ffe9929ec7014cc4c028c2d04","ffffe5fff7bcfee391fec44ffe9929ec7014cc4c02993404662506").map(X),g1=pt(y1);var x1=new Array(3).concat("ffeda0feb24cf03b20","ffffb2fecc5cfd8d3ce31a1c","ffffb2fecc5cfd8d3cf03b20bd0026","ffffb2fed976feb24cfd8d3cf03b20bd0026","ffffb2fed976feb24cfd8d3cfc4e2ae31a1cb10026","ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cb10026","ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cbd0026800026").map(X),b1=pt(x1);var w1=new Array(3).concat("deebf79ecae13182bd","eff3ffbdd7e76baed62171b5","eff3ffbdd7e76baed63182bd08519c","eff3ffc6dbef9ecae16baed63182bd08519c","eff3ffc6dbef9ecae16baed64292c62171b5084594","f7fbffdeebf7c6dbef9ecae16baed64292c62171b5084594","f7fbffdeebf7c6dbef9ecae16baed64292c62171b508519c08306b").map(X),v1=pt(w1);var _1=new Array(3).concat("e5f5e0a1d99b31a354","edf8e9bae4b374c476238b45","edf8e9bae4b374c47631a354006d2c","edf8e9c7e9c0a1d99b74c47631a354006d2c","edf8e9c7e9c0a1d99b74c47641ab5d238b45005a32","f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45005a32","f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45006d2c00441b").map(X),S1=pt(_1);var I1=new Array(3).concat("f0f0f0bdbdbd636363","f7f7f7cccccc969696525252","f7f7f7cccccc969696636363252525","f7f7f7d9d9d9bdbdbd969696636363252525","f7f7f7d9d9d9bdbdbd969696737373525252252525","fffffff0f0f0d9d9d9bdbdbd969696737373525252252525","fffffff0f0f0d9d9d9bdbdbd969696737373525252252525000000").map(X),M1=pt(I1);var A1=new Array(3).concat("efedf5bcbddc756bb1","f2f0f7cbc9e29e9ac86a51a3","f2f0f7cbc9e29e9ac8756bb154278f","f2f0f7dadaebbcbddc9e9ac8756bb154278f","f2f0f7dadaebbcbddc9e9ac8807dba6a51a34a1486","fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a34a1486","fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a354278f3f007d").map(X),T1=pt(A1);var E1=new Array(3).concat("fee0d2fc9272de2d26","fee5d9fcae91fb6a4acb181d","fee5d9fcae91fb6a4ade2d26a50f15","fee5d9fcbba1fc9272fb6a4ade2d26a50f15","fee5d9fcbba1fc9272fb6a4aef3b2ccb181d99000d","fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181d99000d","fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181da50f1567000d").map(X),N1=pt(E1);var D1=new Array(3).concat("fee6cefdae6be6550d","feeddefdbe85fd8d3cd94701","feeddefdbe85fd8d3ce6550da63603","feeddefdd0a2fdae6bfd8d3ce6550da63603","feeddefdd0a2fdae6bfd8d3cf16913d948018c2d04","fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d948018c2d04","fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d94801a636037f2704").map(X),O1=pt(D1);function B1(e){return e=Math.max(0,Math.min(1,e)),"rgb("+Math.max(0,Math.min(255,Math.round(-4.54-e*(35.34-e*(2381.73-e*(6402.7-e*(7024.72-e*2710.57)))))))+", "+Math.max(0,Math.min(255,Math.round(32.49+e*(170.73+e*(52.82-e*(131.46-e*(176.58-e*67.37)))))))+", "+Math.max(0,Math.min(255,Math.round(81.24+e*(442.36-e*(2482.43-e*(6167.24-e*(6614.94-e*2475.67)))))))+")"}var L1=Ru(Kn(300,.5,0),Kn(-240,.5,1));var k1=Ru(Kn(-100,.75,.35),Kn(80,1.5,.8)),F1=Ru(Kn(260,.75,.35),Kn(80,1.5,.8)),C1=Kn();function R1(e){(e<0||e>1)&&(e-=Math.floor(e));var t=Math.abs(e-.5);return C1.h=360*e-100,C1.s=1.5-1.5*t,C1.l=.8-.9*t,C1+""}var $1=on(),TZ=Math.PI/3,EZ=Math.PI*2/3;function P1(e){var t;return e=(.5-e)*Math.PI,$1.r=255*(t=Math.sin(e))*t,$1.g=255*(t=Math.sin(e+TZ))*t,$1.b=255*(t=Math.sin(e+EZ))*t,$1+""}function U1(e){return e=Math.max(0,Math.min(1,e)),"rgb("+Math.max(0,Math.min(255,Math.round(34.61+e*(1172.33-e*(10793.56-e*(33300.12-e*(38394.49-e*14825.05)))))))+", "+Math.max(0,Math.min(255,Math.round(23.31+e*(557.33+e*(1225.33-e*(3574.96-e*(1073.77+e*707.56)))))))+", "+Math.max(0,Math.min(255,Math.round(27.2+e*(3211.1-e*(15327.97-e*(27814-e*(22569.18-e*6838.66)))))))+")"}function z1(e){var t=e.length;return function(n){return e[Math.max(0,Math.min(t-1,Math.floor(n*t)))]}}var q1=z1(X("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725")),j1=z1(X("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf")),V1=z1(X("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4")),Y1=z1(X("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"));function Qe(e){return function(){return e}}var uA=Math.cos;var ff=Math.min,mm=Math.sin,ne=Math.sqrt,fA=1e-12,xl=Math.PI,CNt=xl/2,df=2*xl;function X1(e){let t=3;return e.digits=function(n){if(!arguments.length)return t;if(n==null)t=null;else{let r=Math.floor(n);if(!(r>=0))throw new RangeError(`invalid digits: ${n}`);t=r}return e},()=>new ka(t)}var $Nt=Array.prototype.slice;function G1(e){return typeof e=="object"&&"length"in e?e:Array.from(e)}function pF(e){this._context=e}pF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;default:this._context.lineTo(e,t);break}}};function Xs(e){return new pF(e)}function W1(e){return e[0]}function H1(e){return e[1]}function ym(e,t){var n=Qe(!0),r=null,i=Xs,o=null,s=X1(a);e=typeof e=="function"?e:e===void 0?W1:Qe(e),t=typeof t=="function"?t:t===void 0?H1:Qe(t);function a(c){var l,u=(c=G1(c)).length,f,d=!1,h;for(r==null&&(o=i(h=s())),l=0;l<=u;++l)!(l<u&&n(f=c[l],l,c))===d&&((d=!d)?o.lineStart():o.lineEnd()),d&&o.point(+e(f,l,c),+t(f,l,c));if(h)return o=null,h+""||null}return a.x=function(c){return arguments.length?(e=typeof c=="function"?c:Qe(+c),a):e},a.y=function(c){return arguments.length?(t=typeof c=="function"?c:Qe(+c),a):t},a.defined=function(c){return arguments.length?(n=typeof c=="function"?c:Qe(!!c),a):n},a.curve=function(c){return arguments.length?(i=c,r!=null&&(o=i(r)),a):i},a.context=function(c){return arguments.length?(c==null?r=o=null:o=i(r=c),a):r},a}function hf(e,t,n){var r=null,i=Qe(!0),o=null,s=Xs,a=null,c=X1(l);e=typeof e=="function"?e:e===void 0?W1:Qe(+e),t=typeof t=="function"?t:t===void 0?Qe(0):Qe(+t),n=typeof n=="function"?n:n===void 0?H1:Qe(+n);function l(f){var d,h,p,m=(f=G1(f)).length,g,y=!1,x,b=new Array(m),w=new Array(m);for(o==null&&(a=s(x=c())),d=0;d<=m;++d){if(!(d<m&&i(g=f[d],d,f))===y)if(y=!y)h=d,a.areaStart(),a.lineStart();else{for(a.lineEnd(),a.lineStart(),p=d-1;p>=h;--p)a.point(b[p],w[p]);a.lineEnd(),a.areaEnd()}y&&(b[d]=+e(g,d,f),w[d]=+t(g,d,f),a.point(r?+r(g,d,f):b[d],n?+n(g,d,f):w[d]))}if(x)return a=null,x+""||null}function u(){return ym().defined(i).curve(s).context(o)}return l.x=function(f){return arguments.length?(e=typeof f=="function"?f:Qe(+f),r=null,l):e},l.x0=function(f){return arguments.length?(e=typeof f=="function"?f:Qe(+f),l):e},l.x1=function(f){return arguments.length?(r=f==null?null:typeof f=="function"?f:Qe(+f),l):r},l.y=function(f){return arguments.length?(t=typeof f=="function"?f:Qe(+f),n=null,l):t},l.y0=function(f){return arguments.length?(t=typeof f=="function"?f:Qe(+f),l):t},l.y1=function(f){return arguments.length?(n=f==null?null:typeof f=="function"?f:Qe(+f),l):n},l.lineX0=l.lineY0=function(){return u().x(e).y(t)},l.lineY1=function(){return u().x(e).y(n)},l.lineX1=function(){return u().x(r).y(t)},l.defined=function(f){return arguments.length?(i=typeof f=="function"?f:Qe(!!f),l):i},l.curve=function(f){return arguments.length?(s=f,o!=null&&(a=s(o)),l):s},l.context=function(f){return arguments.length?(f==null?o=a=null:a=s(o=f),l):o},l}var Z1=class{constructor(t,n){this._context=t,this._x=n}areaStart(){this._line=0}areaEnd(){this._line=NaN}lineStart(){this._point=0}lineEnd(){(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line}point(t,n){switch(t=+t,n=+n,this._point){case 0:{this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break}case 1:this._point=2;default:{this._x?this._context.bezierCurveTo(this._x0=(this._x0+t)/2,this._y0,this._x0,n,t,n):this._context.bezierCurveTo(this._x0,this._y0=(this._y0+n)/2,t,this._y0,t,n);break}}this._x0=t,this._y0=n}};function dA(e){return new Z1(e,!0)}function hA(e){return new Z1(e,!1)}var NZ=ne(3),gm={draw(e,t){let n=ne(t+ff(t/28,.75))*.59436,r=n/2,i=r*NZ;e.moveTo(0,n),e.lineTo(0,-n),e.moveTo(-i,-r),e.lineTo(i,r),e.moveTo(-i,r),e.lineTo(i,-r)}};var Gs={draw(e,t){let n=ne(t/xl);e.moveTo(n,0),e.arc(0,0,n,0,df)}};var xm={draw(e,t){let n=ne(t/5)/2;e.moveTo(-3*n,-n),e.lineTo(-n,-n),e.lineTo(-n,-3*n),e.lineTo(n,-3*n),e.lineTo(n,-n),e.lineTo(3*n,-n),e.lineTo(3*n,n),e.lineTo(n,n),e.lineTo(n,3*n),e.lineTo(-n,3*n),e.lineTo(-n,n),e.lineTo(-3*n,n),e.closePath()}};var mF=ne(1/3),DZ=mF*2,bm={draw(e,t){let n=ne(t/DZ),r=n*mF;e.moveTo(0,-n),e.lineTo(r,0),e.lineTo(0,n),e.lineTo(-r,0),e.closePath()}};var wm={draw(e,t){let n=ne(t)*.62625;e.moveTo(0,-n),e.lineTo(n,0),e.lineTo(0,n),e.lineTo(-n,0),e.closePath()}};var vm={draw(e,t){let n=ne(t-ff(t/7,2))*.87559;e.moveTo(-n,0),e.lineTo(n,0),e.moveTo(0,n),e.lineTo(0,-n)}};var _m={draw(e,t){let n=ne(t),r=-n/2;e.rect(r,r,n,n)}};var Sm={draw(e,t){let n=ne(t)*.4431;e.moveTo(n,n),e.lineTo(n,-n),e.lineTo(-n,-n),e.lineTo(-n,n),e.closePath()}};var OZ=.8908130915292852,yF=mm(xl/10)/mm(7*xl/10),BZ=mm(df/10)*yF,LZ=-uA(df/10)*yF,Im={draw(e,t){let n=ne(t*OZ),r=BZ*n,i=LZ*n;e.moveTo(0,-n),e.lineTo(r,i);for(let o=1;o<5;++o){let s=df*o/5,a=uA(s),c=mm(s);e.lineTo(c*n,-a*n),e.lineTo(a*r-c*i,c*r+a*i)}e.closePath()}};var pA=ne(3),Mm={draw(e,t){let n=-ne(t/(pA*3));e.moveTo(0,n*2),e.lineTo(-pA*n,-n),e.lineTo(pA*n,-n),e.closePath()}};var CZ=ne(3),Am={draw(e,t){let n=ne(t)*.6824,r=n/2,i=n*CZ/2;e.moveTo(0,-n),e.lineTo(i,r),e.lineTo(-i,r),e.closePath()}};var fi=-.5,di=ne(3)/2,mA=1/ne(12),kZ=(mA/2+1)*3,Tm={draw(e,t){let n=ne(t/kZ),r=n/2,i=n*mA,o=r,s=n*mA+n,a=-o,c=s;e.moveTo(r,i),e.lineTo(o,s),e.lineTo(a,c),e.lineTo(fi*r-di*i,di*r+fi*i),e.lineTo(fi*o-di*s,di*o+fi*s),e.lineTo(fi*a-di*c,di*a+fi*c),e.lineTo(fi*r+di*i,fi*i-di*r),e.lineTo(fi*o+di*s,fi*s-di*o),e.lineTo(fi*a+di*c,fi*c-di*a),e.closePath()}};var pf={draw(e,t){let n=ne(t-ff(t/6,1.7))*.6189;e.moveTo(-n,-n),e.lineTo(n,n),e.moveTo(-n,n),e.lineTo(n,-n)}};var J1=[Gs,xm,bm,_m,Im,Mm,Tm],yA=[Gs,vm,pf,Am,gm,Sm,wm];function hi(){}function mf(e,t,n){e._context.bezierCurveTo((2*e._x0+e._x1)/3,(2*e._y0+e._y1)/3,(e._x0+2*e._x1)/3,(e._y0+2*e._y1)/3,(e._x0+4*e._x1+t)/6,(e._y0+4*e._y1+n)/6)}function Em(e){this._context=e}Em.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){switch(this._point){case 3:mf(this,this._x1,this._y1);case 2:this._context.lineTo(this._x1,this._y1);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;break;case 2:this._point=3,this._context.lineTo((5*this._x0+this._x1)/6,(5*this._y0+this._y1)/6);default:mf(this,e,t);break}this._x0=this._x1,this._x1=e,this._y0=this._y1,this._y1=t}};function gA(e){return new Em(e)}function gF(e){this._context=e}gF.prototype={areaStart:hi,areaEnd:hi,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._y0=this._y1=this._y2=this._y3=this._y4=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x2,this._y2),this._context.closePath();break}case 2:{this._context.moveTo((this._x2+2*this._x3)/3,(this._y2+2*this._y3)/3),this._context.lineTo((this._x3+2*this._x2)/3,(this._y3+2*this._y2)/3),this._context.closePath();break}case 3:{this.point(this._x2,this._y2),this.point(this._x3,this._y3),this.point(this._x4,this._y4);break}}},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._x2=e,this._y2=t;break;case 1:this._point=2,this._x3=e,this._y3=t;break;case 2:this._point=3,this._x4=e,this._y4=t,this._context.moveTo((this._x0+4*this._x1+e)/6,(this._y0+4*this._y1+t)/6);break;default:mf(this,e,t);break}this._x0=this._x1,this._x1=e,this._y0=this._y1,this._y1=t}};function xA(e){return new gF(e)}function xF(e){this._context=e}xF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3;var n=(this._x0+4*this._x1+e)/6,r=(this._y0+4*this._y1+t)/6;this._line?this._context.lineTo(n,r):this._context.moveTo(n,r);break;case 3:this._point=4;default:mf(this,e,t);break}this._x0=this._x1,this._x1=e,this._y0=this._y1,this._y1=t}};function bA(e){return new xF(e)}function bF(e,t){this._basis=new Em(e),this._beta=t}bF.prototype={lineStart:function(){this._x=[],this._y=[],this._basis.lineStart()},lineEnd:function(){var e=this._x,t=this._y,n=e.length-1;if(n>0)for(var r=e[0],i=t[0],o=e[n]-r,s=t[n]-i,a=-1,c;++a<=n;)c=a/n,this._basis.point(this._beta*e[a]+(1-this._beta)*(r+c*o),this._beta*t[a]+(1-this._beta)*(i+c*s));this._x=this._y=null,this._basis.lineEnd()},point:function(e,t){this._x.push(+e),this._y.push(+t)}};var wA=function e(t){function n(r){return t===1?new Em(r):new bF(r,t)}return n.beta=function(r){return e(+r)},n}(.85);function yf(e,t,n){e._context.bezierCurveTo(e._x1+e._k*(e._x2-e._x0),e._y1+e._k*(e._y2-e._y0),e._x2+e._k*(e._x1-t),e._y2+e._k*(e._y1-n),e._x2,e._y2)}function Q1(e,t){this._context=e,this._k=(1-t)/6}Q1.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:yf(this,this._x1,this._y1);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2,this._x1=e,this._y1=t;break;case 2:this._point=3;default:yf(this,e,t);break}this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var vA=function e(t){function n(r){return new Q1(r,t)}return n.tension=function(r){return e(+r)},n}(0);function K1(e,t){this._context=e,this._k=(1-t)/6}K1.prototype={areaStart:hi,areaEnd:hi,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x3,this._y3),this._context.closePath();break}case 2:{this._context.lineTo(this._x3,this._y3),this._context.closePath();break}case 3:{this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5);break}}},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._x3=e,this._y3=t;break;case 1:this._point=2,this._context.moveTo(this._x4=e,this._y4=t);break;case 2:this._point=3,this._x5=e,this._y5=t;break;default:yf(this,e,t);break}this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var _A=function e(t){function n(r){return new K1(r,t)}return n.tension=function(r){return e(+r)},n}(0);function tw(e,t){this._context=e,this._k=(1-t)/6}tw.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:yf(this,e,t);break}this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var SA=function e(t){function n(r){return new tw(r,t)}return n.tension=function(r){return e(+r)},n}(0);function Nm(e,t,n){var r=e._x1,i=e._y1,o=e._x2,s=e._y2;if(e._l01_a>fA){var a=2*e._l01_2a+3*e._l01_a*e._l12_a+e._l12_2a,c=3*e._l01_a*(e._l01_a+e._l12_a);r=(r*a-e._x0*e._l12_2a+e._x2*e._l01_2a)/c,i=(i*a-e._y0*e._l12_2a+e._y2*e._l01_2a)/c}if(e._l23_a>fA){var l=2*e._l23_2a+3*e._l23_a*e._l12_a+e._l12_2a,u=3*e._l23_a*(e._l23_a+e._l12_a);o=(o*l+e._x1*e._l23_2a-t*e._l12_2a)/u,s=(s*l+e._y1*e._l23_2a-n*e._l12_2a)/u}e._context.bezierCurveTo(r,i,o,s,e._x2,e._y2)}function wF(e,t){this._context=e,this._alpha=t}wF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:this.point(this._x2,this._y2);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){if(e=+e,t=+t,this._point){var n=this._x2-e,r=this._y2-t;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(n*n+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;break;case 2:this._point=3;default:Nm(this,e,t);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var IA=function e(t){function n(r){return t?new wF(r,t):new Q1(r,0)}return n.alpha=function(r){return e(+r)},n}(.5);function vF(e,t){this._context=e,this._alpha=t}vF.prototype={areaStart:hi,areaEnd:hi,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x3,this._y3),this._context.closePath();break}case 2:{this._context.lineTo(this._x3,this._y3),this._context.closePath();break}case 3:{this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5);break}}},point:function(e,t){if(e=+e,t=+t,this._point){var n=this._x2-e,r=this._y2-t;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(n*n+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._x3=e,this._y3=t;break;case 1:this._point=2,this._context.moveTo(this._x4=e,this._y4=t);break;case 2:this._point=3,this._x5=e,this._y5=t;break;default:Nm(this,e,t);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var MA=function e(t){function n(r){return t?new vF(r,t):new K1(r,0)}return n.alpha=function(r){return e(+r)},n}(.5);function _F(e,t){this._context=e,this._alpha=t}_F.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){if(e=+e,t=+t,this._point){var n=this._x2-e,r=this._y2-t;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(n*n+r*r,this._alpha))}switch(this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:Nm(this,e,t);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var AA=function e(t){function n(r){return t?new _F(r,t):new tw(r,0)}return n.alpha=function(r){return e(+r)},n}(.5);function SF(e){this._context=e}SF.prototype={areaStart:hi,areaEnd:hi,lineStart:function(){this._point=0},lineEnd:function(){this._point&&this._context.closePath()},point:function(e,t){e=+e,t=+t,this._point?this._context.lineTo(e,t):(this._point=1,this._context.moveTo(e,t))}};function TA(e){return new SF(e)}function IF(e){return e<0?-1:1}function MF(e,t,n){var r=e._x1-e._x0,i=t-e._x1,o=(e._y1-e._y0)/(r||i<0&&-0),s=(n-e._y1)/(i||r<0&&-0),a=(o*i+s*r)/(r+i);return(IF(o)+IF(s))*Math.min(Math.abs(o),Math.abs(s),.5*Math.abs(a))||0}function AF(e,t){var n=e._x1-e._x0;return n?(3*(e._y1-e._y0)/n-t)/2:t}function EA(e,t,n){var r=e._x0,i=e._y0,o=e._x1,s=e._y1,a=(o-r)/3;e._context.bezierCurveTo(r+a,i+a*t,o-a,s-a*n,o,s)}function ew(e){this._context=e}ew.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=this._t0=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x1,this._y1);break;case 3:EA(this,this._t0,AF(this,this._t0));break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){var n=NaN;if(e=+e,t=+t,!(e===this._x1&&t===this._y1)){switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;break;case 2:this._point=3,EA(this,AF(this,n=MF(this,e,t)),n);break;default:EA(this,this._t0,n=MF(this,e,t));break}this._x0=this._x1,this._x1=e,this._y0=this._y1,this._y1=t,this._t0=n}}};function TF(e){this._context=new EF(e)}(TF.prototype=Object.create(ew.prototype)).point=function(e,t){ew.prototype.point.call(this,t,e)};function EF(e){this._context=e}EF.prototype={moveTo:function(e,t){this._context.moveTo(t,e)},closePath:function(){this._context.closePath()},lineTo:function(e,t){this._context.lineTo(t,e)},bezierCurveTo:function(e,t,n,r,i,o){this._context.bezierCurveTo(t,e,r,n,o,i)}};function NA(e){return new ew(e)}function DA(e){return new TF(e)}function DF(e){this._context=e}DF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=[],this._y=[]},lineEnd:function(){var e=this._x,t=this._y,n=e.length;if(n)if(this._line?this._context.lineTo(e[0],t[0]):this._context.moveTo(e[0],t[0]),n===2)this._context.lineTo(e[1],t[1]);else for(var r=NF(e),i=NF(t),o=0,s=1;s<n;++o,++s)this._context.bezierCurveTo(r[0][o],i[0][o],r[1][o],i[1][o],e[s],t[s]);(this._line||this._line!==0&&n===1)&&this._context.closePath(),this._line=1-this._line,this._x=this._y=null},point:function(e,t){this._x.push(+e),this._y.push(+t)}};function NF(e){var t,n=e.length-1,r,i=new Array(n),o=new Array(n),s=new Array(n);for(i[0]=0,o[0]=2,s[0]=e[0]+2*e[1],t=1;t<n-1;++t)i[t]=1,o[t]=4,s[t]=4*e[t]+2*e[t+1];for(i[n-1]=2,o[n-1]=7,s[n-1]=8*e[n-1]+e[n],t=1;t<n;++t)r=i[t]/o[t-1],o[t]-=r,s[t]-=r*s[t-1];for(i[n-1]=s[n-1]/o[n-1],t=n-2;t>=0;--t)i[t]=(s[t]-i[t+1])/o[t];for(o[n-1]=(e[n]+i[n-1])/2,t=0;t<n-1;++t)o[t]=2*e[t+1]-i[t+1];return[i,o]}function OA(e){return new DF(e)}function nw(e,t){this._context=e,this._t=t}nw.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=this._y=NaN,this._point=0},lineEnd:function(){0<this._t&&this._t<1&&this._point===2&&this._context.lineTo(this._x,this._y),(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line>=0&&(this._t=1-this._t,this._line=1-this._line)},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;default:{if(this._t<=0)this._context.lineTo(this._x,t),this._context.lineTo(e,t);else{var n=this._x*(1-this._t)+e*this._t;this._context.lineTo(n,this._y),this._context.lineTo(n,t)}break}}this._x=e,this._y=t}};function BA(e){return new nw(e,.5)}function LA(e){return new nw(e,0)}function CA(e){return new nw(e,1)}var Dm=e=>()=>e;function kA(e,{sourceEvent:t,target:n,transform:r,dispatch:i}){Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},transform:{value:r,enumerable:!0,configurable:!0},_:{value:i}})}function qr(e,t,n){this.k=e,this.x=t,this.y=n}qr.prototype={constructor:qr,scale:function(e){return e===1?this:new qr(this.k*e,this.x,this.y)},translate:function(e,t){return e===0&t===0?this:new qr(this.k,this.x+this.k*e,this.y+this.k*t)},apply:function(e){return[e[0]*this.k+this.x,e[1]*this.k+this.y]},applyX:function(e){return e*this.k+this.x},applyY:function(e){return e*this.k+this.y},invert:function(e){return[(e[0]-this.x)/this.k,(e[1]-this.y)/this.k]},invertX:function(e){return(e-this.x)/this.k},invertY:function(e){return(e-this.y)/this.k},rescaleX:function(e){return e.copy().domain(e.range().map(this.invertX,this).map(e.invert,e))},rescaleY:function(e){return e.copy().domain(e.range().map(this.invertY,this).map(e.invert,e))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var Om=new qr(1,0,0);FA.prototype=qr.prototype;function FA(e){for(;!e.__zoom;)if(!(e=e.parentNode))return Om;return e.__zoom}function rw(e){e.stopImmediatePropagation()}function gf(e){e.preventDefault(),e.stopImmediatePropagation()}function FZ(e){return(!e.ctrlKey||e.type==="wheel")&&!e.button}function RZ(){var e=this;return e instanceof SVGElement?(e=e.ownerSVGElement||e,e.hasAttribute("viewBox")?(e=e.viewBox.baseVal,[[e.x,e.y],[e.x+e.width,e.y+e.height]]):[[0,0],[e.width.baseVal.value,e.height.baseVal.value]]):[[0,0],[e.clientWidth,e.clientHeight]]}function OF(){return this.__zoom||Om}function $Z(e){return-e.deltaY*(e.deltaMode===1?.05:e.deltaMode?1:.002)*(e.ctrlKey?10:1)}function PZ(){return navigator.maxTouchPoints||"ontouchstart"in this}function UZ(e,t,n){var r=e.invertX(t[0][0])-n[0][0],i=e.invertX(t[1][0])-n[1][0],o=e.invertY(t[0][1])-n[0][1],s=e.invertY(t[1][1])-n[1][1];return e.translate(i>r?(r+i)/2:Math.min(0,r)||Math.max(0,i),s>o?(o+s)/2:Math.min(0,o)||Math.max(0,s))}function RA(){var e=FZ,t=RZ,n=UZ,r=$Z,i=PZ,o=[0,1/0],s=[[-1/0,-1/0],[1/0,1/0]],a=250,c=fI,l=Gc("start","zoom","end"),u,f,d,h=500,p=150,m=0,g=10;function y(S){S.property("__zoom",OF).on("wheel.zoom",D,{passive:!1}).on("mousedown.zoom",A).on("dblclick.zoom",E).filter(i).on("touchstart.zoom",T).on("touchmove.zoom",O).on("touchend.zoom touchcancel.zoom",C).style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}y.transform=function(S,M,N,F){var R=S.selection?S.selection():S;R.property("__zoom",OF),S!==R?v(S,M,N,F):R.interrupt().each(function(){_(this,arguments).event(F).start().zoom(null,typeof M=="function"?M.apply(this,arguments):M).end()})},y.scaleBy=function(S,M,N,F){y.scaleTo(S,function(){var R=this.__zoom.k,k=typeof M=="function"?M.apply(this,arguments):M;return R*k},N,F)},y.scaleTo=function(S,M,N,F){y.transform(S,function(){var R=t.apply(this,arguments),k=this.__zoom,$=N==null?w(R):typeof N=="function"?N.apply(this,arguments):N,P=k.invert($),U=typeof M=="function"?M.apply(this,arguments):M;return n(b(x(k,U),$,P),R,s)},N,F)},y.translateBy=function(S,M,N,F){y.transform(S,function(){return n(this.__zoom.translate(typeof M=="function"?M.apply(this,arguments):M,typeof N=="function"?N.apply(this,arguments):N),t.apply(this,arguments),s)},null,F)},y.translateTo=function(S,M,N,F,R){y.transform(S,function(){var k=t.apply(this,arguments),$=this.__zoom,P=F==null?w(k):typeof F=="function"?F.apply(this,arguments):F;return n(Om.translate(P[0],P[1]).scale($.k).translate(typeof M=="function"?-M.apply(this,arguments):-M,typeof N=="function"?-N.apply(this,arguments):-N),k,s)},F,R)};function x(S,M){return M=Math.max(o[0],Math.min(o[1],M)),M===S.k?S:new qr(M,S.x,S.y)}function b(S,M,N){var F=M[0]-N[0]*S.k,R=M[1]-N[1]*S.k;return F===S.x&&R===S.y?S:new qr(S.k,F,R)}function w(S){return[(+S[0][0]+ +S[1][0])/2,(+S[0][1]+ +S[1][1])/2]}function v(S,M,N,F){S.on("start.zoom",function(){_(this,arguments).event(F).start()}).on("interrupt.zoom end.zoom",function(){_(this,arguments).event(F).end()}).tween("zoom",function(){var R=this,k=arguments,$=_(R,k).event(F),P=t.apply(R,k),U=N==null?w(P):typeof N=="function"?N.apply(R,k):N,W=Math.max(P[1][0]-P[0][0],P[1][1]-P[0][1]),tt=R.__zoom,nt=typeof M=="function"?M.apply(R,k):M,at=c(tt.invert(U).concat(W/tt.k),nt.invert(U).concat(W/nt.k));return function(Y){if(Y===1)Y=nt;else{var rt=at(Y),j=W/rt[2];Y=new qr(j,U[0]-rt[0]*j,U[1]-rt[1]*j)}$.zoom(null,Y)}})}function _(S,M,N){return!N&&S.__zooming||new I(S,M)}function I(S,M){this.that=S,this.args=M,this.active=0,this.sourceEvent=null,this.extent=t.apply(S,M),this.taps=0}I.prototype={event:function(S){return S&&(this.sourceEvent=S),this},start:function(){return++this.active===1&&(this.that.__zooming=this,this.emit("start")),this},zoom:function(S,M){return this.mouse&&S!=="mouse"&&(this.mouse[1]=M.invert(this.mouse[0])),this.touch0&&S!=="touch"&&(this.touch0[1]=M.invert(this.touch0[0])),this.touch1&&S!=="touch"&&(this.touch1[1]=M.invert(this.touch1[0])),this.that.__zoom=M,this.emit("zoom"),this},end:function(){return--this.active===0&&(delete this.that.__zooming,this.emit("end")),this},emit:function(S){var M=Vt(this.that).datum();l.call(S,this.that,new kA(S,{sourceEvent:this.sourceEvent,target:y,type:S,transform:this.that.__zoom,dispatch:l}),M)}};function D(S,...M){if(!e.apply(this,arguments))return;var N=_(this,M).event(S),F=this.__zoom,R=Math.max(o[0],Math.min(o[1],F.k*Math.pow(2,r.apply(this,arguments)))),k=kn(S);if(N.wheel)(N.mouse[0][0]!==k[0]||N.mouse[0][1]!==k[1])&&(N.mouse[1]=F.invert(N.mouse[0]=k)),clearTimeout(N.wheel);else{if(F.k===R)return;N.mouse=[k,F.invert(k)],go(this),N.start()}gf(S),N.wheel=setTimeout($,p),N.zoom("mouse",n(b(x(F,R),N.mouse[0],N.mouse[1]),N.extent,s));function $(){N.wheel=null,N.end()}}function A(S,...M){if(d||!e.apply(this,arguments))return;var N=S.currentTarget,F=_(this,M,!0).event(S),R=Vt(S.view).on("mousemove.zoom",U,!0).on("mouseup.zoom",W,!0),k=kn(S,N),$=S.clientX,P=S.clientY;ap(S.view),rw(S),F.mouse=[k,this.__zoom.invert(k)],go(this),F.start();function U(tt){if(gf(tt),!F.moved){var nt=tt.clientX-$,at=tt.clientY-P;F.moved=nt*nt+at*at>m}F.event(tt).zoom("mouse",n(b(F.that.__zoom,F.mouse[0]=kn(tt,N),F.mouse[1]),F.extent,s))}function W(tt){R.on("mousemove.zoom mouseup.zoom",null),cp(tt.view,F.moved),gf(tt),F.event(tt).end()}}function E(S,...M){if(e.apply(this,arguments)){var N=this.__zoom,F=kn(S.changedTouches?S.changedTouches[0]:S,this),R=N.invert(F),k=N.k*(S.shiftKey?.5:2),$=n(b(x(N,k),F,R),t.apply(this,M),s);gf(S),a>0?Vt(this).transition().duration(a).call(v,$,F,S):Vt(this).call(y.transform,$,F,S)}}function T(S,...M){if(e.apply(this,arguments)){var N=S.touches,F=N.length,R=_(this,M,S.changedTouches.length===F).event(S),k,$,P,U;for(rw(S),$=0;$<F;++$)P=N[$],U=kn(P,this),U=[U,this.__zoom.invert(U),P.identifier],R.touch0?!R.touch1&&R.touch0[2]!==U[2]&&(R.touch1=U,R.taps=0):(R.touch0=U,k=!0,R.taps=1+!!u);u&&(u=clearTimeout(u)),k&&(R.taps<2&&(f=U[0],u=setTimeout(function(){u=null},h)),go(this),R.start())}}function O(S,...M){if(this.__zooming){var N=_(this,M).event(S),F=S.changedTouches,R=F.length,k,$,P,U;for(gf(S),k=0;k<R;++k)$=F[k],P=kn($,this),N.touch0&&N.touch0[2]===$.identifier?N.touch0[0]=P:N.touch1&&N.touch1[2]===$.identifier&&(N.touch1[0]=P);if($=N.that.__zoom,N.touch1){var W=N.touch0[0],tt=N.touch0[1],nt=N.touch1[0],at=N.touch1[1],Y=(Y=nt[0]-W[0])*Y+(Y=nt[1]-W[1])*Y,rt=(rt=at[0]-tt[0])*rt+(rt=at[1]-tt[1])*rt;$=x($,Math.sqrt(Y/rt)),P=[(W[0]+nt[0])/2,(W[1]+nt[1])/2],U=[(tt[0]+at[0])/2,(tt[1]+at[1])/2]}else if(N.touch0)P=N.touch0[0],U=N.touch0[1];else return;N.zoom("touch",n(b($,P,U),N.extent,s))}}function C(S,...M){if(this.__zooming){var N=_(this,M).event(S),F=S.changedTouches,R=F.length,k,$;for(rw(S),d&&clearTimeout(d),d=setTimeout(function(){d=null},h),k=0;k<R;++k)$=F[k],N.touch0&&N.touch0[2]===$.identifier?delete N.touch0:N.touch1&&N.touch1[2]===$.identifier&&delete N.touch1;if(N.touch1&&!N.touch0&&(N.touch0=N.touch1,delete N.touch1),N.touch0)N.touch0[1]=this.__zoom.invert(N.touch0[0]);else if(N.end(),N.taps===2&&($=kn($,this),Math.hypot(f[0]-$[0],f[1]-$[1])<g)){var P=Vt(this).on("dblclick.zoom");P&&P.apply(this,arguments)}}}return y.wheelDelta=function(S){return arguments.length?(r=typeof S=="function"?S:Dm(+S),y):r},y.filter=function(S){return arguments.length?(e=typeof S=="function"?S:Dm(!!S),y):e},y.touchable=function(S){return arguments.length?(i=typeof S=="function"?S:Dm(!!S),y):i},y.extent=function(S){return arguments.length?(t=typeof S=="function"?S:Dm([[+S[0][0],+S[0][1]],[+S[1][0],+S[1][1]]]),y):t},y.scaleExtent=function(S){return arguments.length?(o[0]=+S[0],o[1]=+S[1],y):[o[0],o[1]]},y.translateExtent=function(S){return arguments.length?(s[0][0]=+S[0][0],s[1][0]=+S[1][0],s[0][1]=+S[0][1],s[1][1]=+S[1][1],y):[[s[0][0],s[0][1]],[s[1][0],s[1][1]]]},y.constrain=function(S){return arguments.length?(n=S,y):n},y.duration=function(S){return arguments.length?(a=+S,y):a},y.interpolate=function(S){return arguments.length?(c=S,y):c},y.on=function(){var S=l.on.apply(l,arguments);return S===l?y:S},y.clickDistance=function(S){return arguments.length?(m=(S=+S)*S,y):Math.sqrt(m)},y.tapDistance=function(S){return arguments.length?(g=+S,y):g},y}function ze(e){return e!=null&&!Number.isNaN(e)}function dn(e,t){return+ze(t)-+ze(e)||zt(e,t)}function bl(e,t){return+ze(t)-+ze(e)||Hn(e,t)}function Bm(e){return e!=null&&`${e}`!=""}function xf(e){return isFinite(e)?e:NaN}function sr(e){return e>0&&isFinite(e)?e:NaN}function Va(e){return e<0&&isFinite(e)?e:NaN}function bf(e,t){if(e instanceof Date||(e=new Date(+e)),isNaN(e))return typeof t=="function"?t(e):t;let n=e.getUTCHours(),r=e.getUTCMinutes(),i=e.getUTCSeconds(),o=e.getUTCMilliseconds();return`${zZ(e.getUTCFullYear(),4)}-${Ws(e.getUTCMonth()+1,2)}-${Ws(e.getUTCDate(),2)}${n||r||i||o?`T${Ws(n,2)}:${Ws(r,2)}${i||o?`:${Ws(i,2)}${o?`.${Ws(o,3)}`:""}`:""}Z`:""}`}function zZ(e){return e<0?`-${Ws(-e,6)}`:e>9999?`+${Ws(e,6)}`:Ws(e,4)}function Ws(e,t){return`${e}`.padStart(t,"0")}var qZ=/^(?:[-+]\d{2})?\d{4}(?:-\d{2}(?:-\d{2})?)?(?:T\d{2}:\d{2}(?::\d{2}(?:\.\d{3})?)?(?:Z|[-+]\d{2}:?\d{2})?)?$/;function wl(e,t){return qZ.test(e+="")?new Date(e):typeof t=="function"?t(e):t}var vf=1e3,Xa=vf*60,Ga=Xa*60,Bo=Ga*24,Oo=Bo*7,vl=Bo*30,Ya=Bo*365,$A=[["millisecond",1],["2 milliseconds",2],["5 milliseconds",5],["10 milliseconds",10],["20 milliseconds",20],["50 milliseconds",50],["100 milliseconds",100],["200 milliseconds",200],["500 milliseconds",500],["second",vf],["5 seconds",5*vf],["15 seconds",15*vf],["30 seconds",30*vf],["minute",Xa],["5 minutes",5*Xa],["15 minutes",15*Xa],["30 minutes",30*Xa],["hour",Ga],["3 hours",3*Ga],["6 hours",6*Ga],["12 hours",12*Ga],["day",Bo],["2 days",2*Bo],["week",Oo],["2 weeks",2*Oo],["month",vl],["3 months",3*vl],["6 months",6*vl],["year",Ya],["2 years",2*Ya],["5 years",5*Ya],["10 years",10*Ya],["20 years",20*Ya],["50 years",50*Ya],["100 years",100*Ya]],PA=new Map([["second",vf],["minute",Xa],["hour",Ga],["day",Bo],["monday",Oo],["tuesday",Oo],["wednesday",Oo],["thursday",Oo],["friday",Oo],["saturday",Oo],["sunday",Oo],["week",Oo],["month",vl],["year",Ya]]),LF=new Map([["second",un],["minute",Us],["hour",qs],["day",ui],["monday",qa],["tuesday",vb],["wednesday",_b],["thursday",Eo],["friday",Sb],["saturday",Ib],["sunday",Ur],["week",Ur],["month",Vs],["year",zn]]),UA=new Map([["second",un],["minute",zs],["hour",js],["day",ml],["monday",ja],["tuesday",Mb],["wednesday",Ab],["thursday",No],["friday",Tb],["saturday",Eb],["sunday",zr],["week",zr],["month",Ys],["year",qn]]),_f=Symbol("intervalDuration"),ow=Symbol("intervalType");for(let[e,t]of LF)t[_f]=PA.get(e),t[ow]="time";for(let[e,t]of UA)t[_f]=PA.get(e),t[ow]="utc";var Lm=[["year",qn,"utc"],["month",Ys,"utc"],["day",ml,"utc",6*vl],["hour",js,"utc",3*Bo],["minute",zs,"utc",6*Ga],["second",un,"utc",30*Xa]],iw=[["year",zn,"time"],["month",Vs,"time"],["day",ui,"time",6*vl],["hour",qs,"time",3*Bo],["minute",Us,"time",6*Ga],["second",un,"time",30*Xa]],jZ=[Lm[0],iw[0],Lm[1],iw[1],Lm[2],iw[2],...Lm.slice(3)];function sw(e){let t=`${e}`.toLowerCase();t.endsWith("s")&&(t=t.slice(0,-1));let n=1,r=/^(?:(\d+)\s+)/.exec(t);switch(r&&(t=t.slice(r[0].length),n=+r[1]),t){case"quarter":t="month",n*=3;break;case"half":t="month",n*=6;break}let i=UA.get(t);if(!i)throw new Error(`unknown interval: ${e}`);if(n>1&&!i.every)throw new Error(`non-periodic interval: ${t}`);return[t,n]}function zA(e){return CF(sw(e),"time")}function Cm(e){return CF(sw(e),"utc")}function CF([e,t],n){let r=(n==="time"?LF:UA).get(e);return t>1&&(r=r.every(t),r[_f]=PA.get(e)*t,r[ow]=n),r}function qA(e,t){if(!(t>1))return;let n=e[_f];if(!$A.some(([,i])=>i===n)||n%Bo===0&&Bo<n&&n<vl)return;let[r]=$A[As(([,i])=>Math.log(i)).center($A,Math.log(n*t))];return(e[ow]==="time"?zA:Cm)(r)}function BF(e,t,n){let r=t==="time"?cf:Do;if(n==null)return r(e==="year"?"%Y":e==="month"?"%Y-%m":e==="day"?"%Y-%m-%d":e==="hour"||e==="minute"?"%Y-%m-%dT%H:%M":e==="second"?"%Y-%m-%dT%H:%M:%S":"%Y-%m-%dT%H:%M:%S.%L");let i=VZ(n);switch(e){case"millisecond":return wf(r(".%L"),r(":%M:%S"),i);case"second":return wf(r(":%S"),r("%-I:%M"),i);case"minute":return wf(r("%-I:%M"),r("%p"),i);case"hour":return wf(r("%-I %p"),r("%b %-d"),i);case"day":return wf(r("%-d"),r("%b"),i);case"month":return wf(r("%b"),r("%Y"),i);case"year":return r("%Y")}throw new Error("unable to format time ticks")}function VZ(e){return e==="left"||e==="right"?(t,n)=>`
|
|
10
|
+
]`}concat(...t){let n=this.schema,r=this.data.concat(t.flatMap(({data:i})=>i));return new e(n,r.map(i=>new Fe(n,i)))}slice(t,n){let r=this.schema;[t,n]=ld({length:this.numRows},t,n);let i=Kg(this.data,this._offsets,t,n);return new e(r,i.map(o=>new Fe(r,o)))}getChild(t){return this.getChildAt(this.schema.fields.findIndex(n=>n.name===t))}getChildAt(t){if(t>-1&&t<this.schema.fields.length){let n=this.data.map(r=>r.children[t]);if(n.length===0){let{type:r}=this.schema.fields[t],i=Nt({type:r,length:0,nullCount:0});n.push(i._changeLengthAndBackfillNullBitmap(this.numRows))}return new Xt(n)}return null}setChild(t,n){var r;return this.setChildAt((r=this.schema.fields)===null||r===void 0?void 0:r.findIndex(i=>i.name===t),n)}setChildAt(t,n){let r=this.schema,i=[...this.batches];if(t>-1&&t<this.numCols){n||(n=new Xt([Nt({type:new kn,length:this.numRows})]));let o=r.fields.slice(),s=o[t].clone({type:n.type}),a=this.schema.fields.map((c,l)=>this.getChildAt(l));[o[t],a[t]]=[s,n],[r,i]=T0(r,a)}return new e(r,i)}select(t){let n=this.schema.fields.reduce((r,i,o)=>r.set(i.name,o),new Map);return this.selectAt(t.map(r=>n.get(r)).filter(r=>r>-1))}selectAt(t){let n=this.schema.selectAt(t),r=this.batches.map(i=>i.selectAt(t));return new e(n,r)}assign(t){let n=this.schema.fields,[r,i]=t.schema.fields.reduce((a,c,l)=>{let[u,f]=a,h=n.findIndex(d=>d.name===c.name);return~h?f[h]=l:u.push(l),a},[[],[]]),o=this.schema.assign(t.schema),s=[...n.map((a,c)=>[c,i[c]]).map(([a,c])=>c===void 0?this.getChildAt(a):t.getChildAt(c)),...r.map(a=>t.getChildAt(a))].filter(Boolean);return new e(...T0(o,s))}};cB=Symbol.toStringTag;mr[cB]=(e=>(e.schema=null,e.batches=[],e._offsets=new Uint32Array([0]),e._nullCount=-1,e[Symbol.isConcatSpreadable]=!0,e.isValid=lu(hd),e.get=lu(Ye.getVisitFn(L.Struct)),e.set=t0(vn.getVisitFn(L.Struct)),e.indexOf=e0(Ac.getVisitFn(L.Struct)),"Table"))(mr.prototype);var uB,Fe=class e{constructor(...t){switch(t.length){case 2:{if([this.schema]=t,!(this.schema instanceof oe))throw new TypeError("RecordBatch constructor expects a [Schema, Data] pair.");if([,this.data=Nt({nullCount:0,type:new xe(this.schema.fields),children:this.schema.fields.map(n=>Nt({type:n.type,nullCount:0}))})]=t,!(this.data instanceof te))throw new TypeError("RecordBatch constructor expects a [Schema, Data] pair.");[this.schema,this.data]=lB(this.schema,this.data.children);break}case 1:{let[n]=t,{fields:r,children:i,length:o}=Object.keys(n).reduce((c,l,u)=>(c.children[u]=n[l],c.length=Math.max(c.length,n[l].length),c.fields[u]=Ut.new({name:l,type:n[l].type,nullable:!0}),c),{length:0,fields:new Array,children:new Array}),s=new oe(r),a=Nt({type:new xe(r),length:o,children:i,nullCount:0});[this.schema,this.data]=lB(s,a.children,o);break}default:throw new TypeError("RecordBatch constructor expects an Object mapping names to child Data, or a [Schema, Data] pair.")}}get dictionaries(){return this._dictionaries||(this._dictionaries=fB(this.schema.fields,this.data.children))}get numCols(){return this.schema.fields.length}get numRows(){return this.data.length}get nullCount(){return this.data.nullCount}isValid(t){return this.data.getValid(t)}get(t){return Ye.visit(this.data,t)}set(t,n){return vn.visit(this.data,t,n)}indexOf(t,n){return Ac.visit(this.data,t,n)}[Symbol.iterator](){return uu.visit(new Xt([this.data]))}toArray(){return[...this]}concat(...t){return new mr(this.schema,[this,...t])}slice(t,n){let[r]=new Xt([this.data]).slice(t,n).data;return new e(this.schema,r)}getChild(t){var n;return this.getChildAt((n=this.schema.fields)===null||n===void 0?void 0:n.findIndex(r=>r.name===t))}getChildAt(t){return t>-1&&t<this.schema.fields.length?new Xt([this.data.children[t]]):null}setChild(t,n){var r;return this.setChildAt((r=this.schema.fields)===null||r===void 0?void 0:r.findIndex(i=>i.name===t),n)}setChildAt(t,n){let r=this.schema,i=this.data;if(t>-1&&t<this.numCols){n||(n=new Xt([Nt({type:new kn,length:this.numRows})]));let o=r.fields.slice(),s=i.children.slice(),a=o[t].clone({type:n.type});[o[t],s[t]]=[a,n.data[0]],r=new oe(o,new Map(this.schema.metadata)),i=Nt({type:new xe(o),children:s})}return new e(r,i)}select(t){let n=this.schema.select(t),r=new xe(n.fields),i=[];for(let o of t){let s=this.schema.fields.findIndex(a=>a.name===o);~s&&(i[s]=this.data.children[s])}return new e(n,Nt({type:r,length:this.numRows,children:i}))}selectAt(t){let n=this.schema.selectAt(t),r=t.map(o=>this.data.children[o]).filter(Boolean),i=Nt({type:new xe(n.fields),length:this.numRows,children:r});return new e(n,i)}};uB=Symbol.toStringTag;Fe[uB]=(e=>(e._nullCount=-1,e[Symbol.isConcatSpreadable]=!0,"RecordBatch"))(Fe.prototype);function lB(e,t,n=t.reduce((r,i)=>Math.max(r,i.length),0)){var r;let i=[...e.fields],o=[...t],s=(n+63&-64)>>3;for(let[a,c]of e.fields.entries()){let l=t[a];(!l||l.length!==n)&&(i[a]=c.clone({nullable:!0}),o[a]=(r=l?._changeLengthAndBackfillNullBitmap(n))!==null&&r!==void 0?r:Nt({type:c.type,length:n,nullCount:n,nullBitmap:new Uint8Array(s)}))}return[e.assign(i),Nt({type:new xe(i),length:n,children:o})]}function fB(e,t,n=new Map){var r,i;if(((r=e?.length)!==null&&r!==void 0?r:0)>0&&e?.length===t?.length)for(let o=-1,s=e.length;++o<s;){let{type:a}=e[o],c=t[o];for(let l of[c,...((i=c?.dictionary)===null||i===void 0?void 0:i.data)||[]])fB(a.children,l?.children,n);if(H.isDictionary(a)){let{id:l}=a;if(!n.has(l))c?.dictionary&&n.set(l,c.dictionary);else if(n.get(l)!==c.dictionary)throw new Error("Cannot create Schema containing two different dictionaries with the same Id")}}return n}var kc=class extends Fe{constructor(t){let n=t.fields.map(i=>Nt({type:i.type})),r=Nt({type:new xe(t.fields),nullCount:0,children:n});super(t,r)}};var Fi=class e{constructor(){this.bb=null,this.bb_pos=0}__init(t,n){return this.bb_pos=t,this.bb=n,this}static getRootAsMessage(t,n){return(n||new e).__init(t.readInt32(t.position())+t.position(),t)}static getSizePrefixedRootAsMessage(t,n){return t.setPosition(t.position()+4),(n||new e).__init(t.readInt32(t.position())+t.position(),t)}version(){let t=this.bb.__offset(this.bb_pos,4);return t?this.bb.readInt16(this.bb_pos+t):ce.V1}headerType(){let t=this.bb.__offset(this.bb_pos,6);return t?this.bb.readUint8(this.bb_pos+t):qt.NONE}header(t){let n=this.bb.__offset(this.bb_pos,8);return n?this.bb.__union(t,this.bb_pos+n):null}bodyLength(){let t=this.bb.__offset(this.bb_pos,10);return t?this.bb.readInt64(this.bb_pos+t):BigInt("0")}customMetadata(t,n){let r=this.bb.__offset(this.bb_pos,12);return r?(n||new nn).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+r)+t*4),this.bb):null}customMetadataLength(){let t=this.bb.__offset(this.bb_pos,12);return t?this.bb.__vector_len(this.bb_pos+t):0}static startMessage(t){t.startObject(5)}static addVersion(t,n){t.addFieldInt16(0,n,ce.V1)}static addHeaderType(t,n){t.addFieldInt8(1,n,qt.NONE)}static addHeader(t,n){t.addFieldOffset(2,n,0)}static addBodyLength(t,n){t.addFieldInt64(3,n,BigInt("0"))}static addCustomMetadata(t,n){t.addFieldOffset(4,n,0)}static createCustomMetadataVector(t,n){t.startVector(4,n.length,4);for(let r=n.length-1;r>=0;r--)t.addOffset(n[r]);return t.endVector()}static startCustomMetadataVector(t,n){t.startVector(4,n,4)}static endMessage(t){return t.endObject()}static finishMessageBuffer(t,n){t.finish(n)}static finishSizePrefixedMessageBuffer(t,n){t.finish(n,void 0,!0)}static createMessage(t,n,r,i,o,s){return e.startMessage(t),e.addVersion(t,n),e.addHeaderType(t,r),e.addHeader(t,i),e.addBodyLength(t,o),e.addCustomMetadata(t,s),e.endMessage(t)}};var p2=class extends mt{visit(t,n){return t==null||n==null?void 0:super.visit(t,n)}visitNull(t,n){return Gh.startNull(n),Gh.endNull(n)}visitInt(t,n){return Ei.startInt(n),Ei.addBitWidth(n,t.bitWidth),Ei.addIsSigned(n,t.isSigned),Ei.endInt(n)}visitFloat(t,n){return ya.startFloatingPoint(n),ya.addPrecision(n,t.precision),ya.endFloatingPoint(n)}visitBinary(t,n){return qh.startBinary(n),qh.endBinary(n)}visitLargeBinary(t,n){return Vh.startLargeBinary(n),Vh.endLargeBinary(n)}visitBool(t,n){return jh.startBool(n),jh.endBool(n)}visitUtf8(t,n){return Hh.startUtf8(n),Hh.endUtf8(n)}visitLargeUtf8(t,n){return Yh.startLargeUtf8(n),Yh.endLargeUtf8(n)}visitDecimal(t,n){return eo.startDecimal(n),eo.addScale(n,t.scale),eo.addPrecision(n,t.precision),eo.addBitWidth(n,t.bitWidth),eo.endDecimal(n)}visitDate(t,n){return ha.startDate(n),ha.addUnit(n,t.unit),ha.endDate(n)}visitTime(t,n){return is.startTime(n),is.addUnit(n,t.unit),is.addBitWidth(n,t.bitWidth),is.endTime(n)}visitTimestamp(t,n){let r=t.timezone&&n.createString(t.timezone)||void 0;return os.startTimestamp(n),os.addUnit(n,t.unit),r!==void 0&&os.addTimezone(n,r),os.endTimestamp(n)}visitInterval(t,n){return ga.startInterval(n),ga.addUnit(n,t.unit),ga.endInterval(n)}visitDuration(t,n){return da.startDuration(n),da.addUnit(n,t.unit),da.endDuration(n)}visitList(t,n){return Xh.startList(n),Xh.endList(n)}visitStruct(t,n){return Wh.startStruct_(n),Wh.endStruct_(n)}visitUnion(t,n){Ni.startTypeIdsVector(n,t.typeIds.length);let r=Ni.createTypeIdsVector(n,t.typeIds);return Ni.startUnion(n),Ni.addMode(n,t.mode),Ni.addTypeIds(n,r),Ni.endUnion(n)}visitDictionary(t,n){let r=this.visit(t.indices,n);return to.startDictionaryEncoding(n),to.addId(n,BigInt(t.id)),to.addIsOrdered(n,t.isOrdered),r!==void 0&&to.addIndexType(n,r),to.endDictionaryEncoding(n)}visitFixedSizeBinary(t,n){return pa.startFixedSizeBinary(n),pa.addByteWidth(n,t.byteWidth),pa.endFixedSizeBinary(n)}visitFixedSizeList(t,n){return ma.startFixedSizeList(n),ma.addListSize(n,t.listSize),ma.endFixedSizeList(n)}visitMap(t,n){return xa.startMap(n),xa.addKeysSorted(n,t.keysSorted),xa.endMap(n)}},E0=new p2;function mB(e,t=new Map){return new oe(yj(e,t),N0(e.metadata),t)}function m2(e){return new _n(e.count,gB(e.columns),xB(e.columns))}function yB(e){return new gr(m2(e.data),e.id,e.isDelta)}function yj(e,t){return(e.fields||[]).filter(Boolean).map(n=>Ut.fromJSON(n,t))}function hB(e,t){return(e.children||[]).filter(Boolean).map(n=>Ut.fromJSON(n,t))}function gB(e){return(e||[]).reduce((t,n)=>[...t,new ii(n.count,gj(n.VALIDITY)),...gB(n.children)],[])}function xB(e,t=[]){for(let n=-1,r=(e||[]).length;++n<r;){let i=e[n];i.VALIDITY&&t.push(new yr(t.length,i.VALIDITY.length)),i.TYPE_ID&&t.push(new yr(t.length,i.TYPE_ID.length)),i.OFFSET&&t.push(new yr(t.length,i.OFFSET.length)),i.DATA&&t.push(new yr(t.length,i.DATA.length)),t=xB(i.children,t)}return t}function gj(e){return(e||[]).reduce((t,n)=>t+ +(n===0),0)}function bB(e,t){let n,r,i,o,s,a;return!t||!(o=e.dictionary)?(s=pB(e,hB(e,t)),i=new Ut(e.name,s,e.nullable,N0(e.metadata))):t.has(n=o.id)?(r=(r=o.indexType)?dB(r):new Li,a=new dr(t.get(n),r,n,o.isOrdered),i=new Ut(e.name,a,e.nullable,N0(e.metadata))):(r=(r=o.indexType)?dB(r):new Li,t.set(n,s=pB(e,hB(e,t))),a=new dr(s,r,n,o.isOrdered),i=new Ut(e.name,a,e.nullable,N0(e.metadata))),i||null}function N0(e=[]){return new Map(e.map(({key:t,value:n})=>[t,n]))}function dB(e){return new ke(e.isSigned,e.bitWidth)}function pB(e,t){let n=e.type.name;switch(n){case"NONE":return new kn;case"null":return new kn;case"binary":return new no;case"largebinary":return new ro;case"utf8":return new io;case"largeutf8":return new oo;case"bool":return new so;case"list":return new Jr((t||[])[0]);case"struct":return new xe(t||[]);case"struct_":return new xe(t||[])}switch(n){case"int":{let r=e.type;return new ke(r.isSigned,r.bitWidth)}case"floatingpoint":{let r=e.type;return new Gn(de[r.precision])}case"decimal":{let r=e.type;return new ao(r.scale,r.precision,r.bitWidth)}case"date":{let r=e.type;return new co(Ve[r.unit])}case"time":{let r=e.type;return new Zr(ct[r.unit],r.bitWidth)}case"timestamp":{let r=e.type;return new lo(ct[r.unit],r.timezone)}case"interval":{let r=e.type;return new uo(cn[r.unit])}case"duration":{let r=e.type;return new fo(ct[r.unit])}case"union":{let r=e.type,[i,...o]=(r.mode+"").toLowerCase(),s=i.toUpperCase()+o.join("");return new Qr(ge[s],r.typeIds||[],t||[])}case"fixedsizebinary":{let r=e.type;return new ho(r.byteWidth)}case"fixedsizelist":{let r=e.type;return new Kr(r.listSize,(t||[])[0])}case"map":{let r=e.type;return new ti((t||[])[0],r.keysSorted)}}throw new Error(`Unrecognized type: "${n}"`)}var xj=_c,bj=Nr,xr=class e{static fromJSON(t,n){let r=new e(0,ce.V5,n);return r._createHeader=wj(t,n),r}static decode(t){t=new bj(_t(t));let n=Fi.getRootAsMessage(t),r=n.bodyLength(),i=n.version(),o=n.headerType(),s=new e(r,i,o);return s._createHeader=vj(n,o),s}static encode(t){let n=new xj,r=-1;return t.isSchema()?r=oe.encode(n,t.header()):t.isRecordBatch()?r=_n.encode(n,t.header()):t.isDictionaryBatch()&&(r=gr.encode(n,t.header())),Fi.startMessage(n),Fi.addVersion(n,ce.V5),Fi.addHeader(n,r),Fi.addHeaderType(n,t.headerType),Fi.addBodyLength(n,BigInt(t.bodyLength)),Fi.finishMessageBuffer(n,Fi.endMessage(n)),n.asUint8Array()}static from(t,n=0){if(t instanceof oe)return new e(0,ce.V5,qt.Schema,t);if(t instanceof _n)return new e(n,ce.V5,qt.RecordBatch,t);if(t instanceof gr)return new e(n,ce.V5,qt.DictionaryBatch,t);throw new Error(`Unrecognized Message header: ${t}`)}get type(){return this.headerType}get version(){return this._version}get headerType(){return this._headerType}get bodyLength(){return this._bodyLength}header(){return this._createHeader()}isSchema(){return this.headerType===qt.Schema}isRecordBatch(){return this.headerType===qt.RecordBatch}isDictionaryBatch(){return this.headerType===qt.DictionaryBatch}constructor(t,n,r,i){this._version=n,this._headerType=r,this.body=new Uint8Array(0),i&&(this._createHeader=()=>i),this._bodyLength=De(t)}},_n=class{get nodes(){return this._nodes}get length(){return this._length}get buffers(){return this._buffers}constructor(t,n,r){this._nodes=n,this._buffers=r,this._length=De(t)}},gr=class{get id(){return this._id}get data(){return this._data}get isDelta(){return this._isDelta}get length(){return this.data.length}get nodes(){return this.data.nodes}get buffers(){return this.data.buffers}constructor(t,n,r=!1){this._data=t,this._isDelta=r,this._id=De(n)}},yr=class{constructor(t,n){this.offset=De(t),this.length=De(n)}},ii=class{constructor(t,n){this.length=De(t),this.nullCount=De(n)}};function wj(e,t){return()=>{switch(t){case qt.Schema:return oe.fromJSON(e);case qt.RecordBatch:return _n.fromJSON(e);case qt.DictionaryBatch:return gr.fromJSON(e)}throw new Error(`Unrecognized Message type: { name: ${qt[t]}, type: ${t} }`)}}function vj(e,t){return()=>{switch(t){case qt.Schema:return oe.decode(e.header(new hr),new Map,e.version());case qt.RecordBatch:return _n.decode(e.header(new Dr),e.version());case qt.DictionaryBatch:return gr.decode(e.header(new rs),e.version())}throw new Error(`Unrecognized Message type: { name: ${qt[t]}, type: ${t} }`)}}Ut.encode=Bj;Ut.decode=Dj;Ut.fromJSON=bB;oe.encode=Oj;oe.decode=_j;oe.fromJSON=mB;_n.encode=Lj;_n.decode=Sj;_n.fromJSON=m2;gr.encode=Cj;gr.decode=Ij;gr.fromJSON=yB;ii.encode=kj;ii.decode=Aj;yr.encode=Fj;yr.decode=Mj;function _j(e,t=new Map,n=ce.V5){let r=Nj(e,t);return new oe(r,D0(e),t,n)}function Sj(e,t=ce.V5){if(e.compression()!==null)throw new Error("Record batch compression not implemented");return new _n(e.length(),Tj(e),Ej(e,t))}function Ij(e,t=ce.V5){return new gr(_n.decode(e.data(),t),e.id(),e.isDelta())}function Mj(e){return new yr(e.offset(),e.length())}function Aj(e){return new ii(e.length(),e.nullCount())}function Tj(e){let t=[];for(let n,r=-1,i=-1,o=e.nodesLength();++r<o;)(n=e.nodes(r))&&(t[++i]=ii.decode(n));return t}function Ej(e,t){let n=[];for(let r,i=-1,o=-1,s=e.buffersLength();++i<s;)(r=e.buffers(i))&&(t<ce.V4&&(r.bb_pos+=8*(i+1)),n[++o]=yr.decode(r));return n}function Nj(e,t){let n=[];for(let r,i=-1,o=-1,s=e.fieldsLength();++i<s;)(r=e.fields(i))&&(n[++o]=Ut.decode(r,t));return n}function wB(e,t){let n=[];for(let r,i=-1,o=-1,s=e.childrenLength();++i<s;)(r=e.children(i))&&(n[++o]=Ut.decode(r,t));return n}function Dj(e,t){let n,r,i,o,s,a;return!t||!(a=e.dictionary())?(i=_B(e,wB(e,t)),r=new Ut(e.name(),i,e.nullable(),D0(e))):t.has(n=De(a.id()))?(o=(o=a.indexType())?vB(o):new Li,s=new dr(t.get(n),o,n,a.isOrdered()),r=new Ut(e.name(),s,e.nullable(),D0(e))):(o=(o=a.indexType())?vB(o):new Li,t.set(n,i=_B(e,wB(e,t))),s=new dr(i,o,n,a.isOrdered()),r=new Ut(e.name(),s,e.nullable(),D0(e))),r||null}function D0(e){let t=new Map;if(e)for(let n,r,i=-1,o=Math.trunc(e.customMetadataLength());++i<o;)(n=e.customMetadata(i))&&(r=n.key())!=null&&t.set(r,n.value());return t}function vB(e){return new ke(e.isSigned(),e.bitWidth())}function _B(e,t){let n=e.typeType();switch(n){case pe.NONE:return new kn;case pe.Null:return new kn;case pe.Binary:return new no;case pe.LargeBinary:return new ro;case pe.Utf8:return new io;case pe.LargeUtf8:return new oo;case pe.Bool:return new so;case pe.List:return new Jr((t||[])[0]);case pe.Struct_:return new xe(t||[])}switch(n){case pe.Int:{let r=e.type(new Ei);return new ke(r.isSigned(),r.bitWidth())}case pe.FloatingPoint:{let r=e.type(new ya);return new Gn(r.precision())}case pe.Decimal:{let r=e.type(new eo);return new ao(r.scale(),r.precision(),r.bitWidth())}case pe.Date:{let r=e.type(new ha);return new co(r.unit())}case pe.Time:{let r=e.type(new is);return new Zr(r.unit(),r.bitWidth())}case pe.Timestamp:{let r=e.type(new os);return new lo(r.unit(),r.timezone())}case pe.Interval:{let r=e.type(new ga);return new uo(r.unit())}case pe.Duration:{let r=e.type(new da);return new fo(r.unit())}case pe.Union:{let r=e.type(new Ni);return new Qr(r.mode(),r.typeIdsArray()||[],t||[])}case pe.FixedSizeBinary:{let r=e.type(new pa);return new ho(r.byteWidth())}case pe.FixedSizeList:{let r=e.type(new ma);return new Kr(r.listSize(),(t||[])[0])}case pe.Map:{let r=e.type(new xa);return new ti((t||[])[0],r.keysSorted())}}throw new Error(`Unrecognized type: "${pe[n]}" (${n})`)}function Oj(e,t){let n=t.fields.map(o=>Ut.encode(e,o));hr.startFieldsVector(e,n.length);let r=hr.createFieldsVector(e,n),i=t.metadata&&t.metadata.size>0?hr.createCustomMetadataVector(e,[...t.metadata].map(([o,s])=>{let a=e.createString(`${o}`),c=e.createString(`${s}`);return nn.startKeyValue(e),nn.addKey(e,a),nn.addValue(e,c),nn.endKeyValue(e)})):-1;return hr.startSchema(e),hr.addFields(e,r),hr.addEndianness(e,Rj?fa.Little:fa.Big),i!==-1&&hr.addCustomMetadata(e,i),hr.endSchema(e)}function Bj(e,t){let n=-1,r=-1,i=-1,o=t.type,s=t.typeId;H.isDictionary(o)?(s=o.dictionary.typeId,i=E0.visit(o,e),r=E0.visit(o.dictionary,e)):r=E0.visit(o,e);let a=(o.children||[]).map(u=>Ut.encode(e,u)),c=Cn.createChildrenVector(e,a),l=t.metadata&&t.metadata.size>0?Cn.createCustomMetadataVector(e,[...t.metadata].map(([u,f])=>{let h=e.createString(`${u}`),d=e.createString(`${f}`);return nn.startKeyValue(e),nn.addKey(e,h),nn.addValue(e,d),nn.endKeyValue(e)})):-1;return t.name&&(n=e.createString(t.name)),Cn.startField(e),Cn.addType(e,r),Cn.addTypeType(e,s),Cn.addChildren(e,c),Cn.addNullable(e,!!t.nullable),n!==-1&&Cn.addName(e,n),i!==-1&&Cn.addDictionary(e,i),l!==-1&&Cn.addCustomMetadata(e,l),Cn.endField(e)}function Lj(e,t){let n=t.nodes||[],r=t.buffers||[];Dr.startNodesVector(e,n.length);for(let s of n.slice().reverse())ii.encode(e,s);let i=e.endVector();Dr.startBuffersVector(e,r.length);for(let s of r.slice().reverse())yr.encode(e,s);let o=e.endVector();return Dr.startRecordBatch(e),Dr.addLength(e,BigInt(t.length)),Dr.addNodes(e,i),Dr.addBuffers(e,o),Dr.endRecordBatch(e)}function Cj(e,t){let n=_n.encode(e,t.data);return rs.startDictionaryBatch(e),rs.addId(e,BigInt(t.id)),rs.addIsDelta(e,t.isDelta),rs.addData(e,n),rs.endDictionaryBatch(e)}function kj(e,t){return eu.createFieldNode(e,BigInt(t.length),BigInt(t.nullCount))}function Fj(e,t){return tu.createBuffer(e,BigInt(t.offset),BigInt(t.length))}var Rj=(()=>{let e=new ArrayBuffer(2);return new DataView(e).setInt16(0,256,!0),new Int16Array(e)[0]===256})();var g2=e=>`Expected ${qt[e]} Message in stream, but was null or length 0.`,x2=e=>`Header pointer of flatbuffer-encoded ${qt[e]} Message is null or length 0.`,SB=(e,t)=>`Expected to read ${e} metadata bytes, but only read ${t}.`,IB=(e,t)=>`Expected to read ${e} bytes for message body, but only read ${t}.`,xu=class{constructor(t){this.source=t instanceof yo?t:new yo(t)}[Symbol.iterator](){return this}next(){let t;return(t=this.readMetadataLength()).done?we:t.value===-1&&(t=this.readMetadataLength()).done?we:(t=this.readMetadata(t.value)).done?we:t}throw(t){return this.source.throw(t)}return(t){return this.source.return(t)}readMessage(t){let n;if((n=this.next()).done)return null;if(t!=null&&n.value.headerType!==t)throw new Error(g2(t));return n.value}readMessageBody(t){if(t<=0)return new Uint8Array(0);let n=_t(this.source.read(t));if(n.byteLength<t)throw new Error(IB(t,n.byteLength));return n.byteOffset%8===0&&n.byteOffset+n.byteLength<=n.buffer.byteLength?n:n.slice()}readSchema(t=!1){let n=qt.Schema,r=this.readMessage(n),i=r?.header();if(t&&!i)throw new Error(x2(n));return i}readMetadataLength(){let t=this.source.read(O0),n=t&&new Nr(t),r=n?.readInt32(0)||0;return{done:r===0,value:r}}readMetadata(t){let n=this.source.read(t);if(!n)return we;if(n.byteLength<t)throw new Error(SB(t,n.byteLength));return{done:!1,value:xr.decode(n)}}},zd=class{constructor(t,n){this.source=t instanceof ni?t:wg(t)?new _a(t,n):new ni(t)}[Symbol.asyncIterator](){return this}next(){return J(this,void 0,void 0,function*(){let t;return(t=yield this.readMetadataLength()).done?we:t.value===-1&&(t=yield this.readMetadataLength()).done?we:(t=yield this.readMetadata(t.value)).done?we:t})}throw(t){return J(this,void 0,void 0,function*(){return yield this.source.throw(t)})}return(t){return J(this,void 0,void 0,function*(){return yield this.source.return(t)})}readMessage(t){return J(this,void 0,void 0,function*(){let n;if((n=yield this.next()).done)return null;if(t!=null&&n.value.headerType!==t)throw new Error(g2(t));return n.value})}readMessageBody(t){return J(this,void 0,void 0,function*(){if(t<=0)return new Uint8Array(0);let n=_t(yield this.source.read(t));if(n.byteLength<t)throw new Error(IB(t,n.byteLength));return n.byteOffset%8===0&&n.byteOffset+n.byteLength<=n.buffer.byteLength?n:n.slice()})}readSchema(t=!1){return J(this,void 0,void 0,function*(){let n=qt.Schema,r=yield this.readMessage(n),i=r?.header();if(t&&!i)throw new Error(x2(n));return i})}readMetadataLength(){return J(this,void 0,void 0,function*(){let t=yield this.source.read(O0),n=t&&new Nr(t),r=n?.readInt32(0)||0;return{done:r===0,value:r}})}readMetadata(t){return J(this,void 0,void 0,function*(){let n=yield this.source.read(t);if(!n)return we;if(n.byteLength<t)throw new Error(SB(t,n.byteLength));return{done:!1,value:xr.decode(n)}})}},qd=class extends xu{constructor(t){super(new Uint8Array(0)),this._schema=!1,this._body=[],this._batchIndex=0,this._dictionaryIndex=0,this._json=t instanceof dd?t:new dd(t)}next(){let{_json:t}=this;if(!this._schema)return this._schema=!0,{done:!1,value:xr.fromJSON(t.schema,qt.Schema)};if(this._dictionaryIndex<t.dictionaries.length){let n=t.dictionaries[this._dictionaryIndex++];return this._body=n.data.columns,{done:!1,value:xr.fromJSON(n,qt.DictionaryBatch)}}if(this._batchIndex<t.batches.length){let n=t.batches[this._batchIndex++];return this._body=n.columns,{done:!1,value:xr.fromJSON(n,qt.RecordBatch)}}return this._body=[],we}readMessageBody(t){return n(this._body);function n(r){return(r||[]).reduce((i,o)=>[...i,...o.VALIDITY&&[o.VALIDITY]||[],...o.TYPE_ID&&[o.TYPE_ID]||[],...o.OFFSET&&[o.OFFSET]||[],...o.DATA&&[o.DATA]||[],...n(o.children)],[])}}readMessage(t){let n;if((n=this.next()).done)return null;if(t!=null&&n.value.headerType!==t)throw new Error(g2(t));return n.value}readSchema(){let t=qt.Schema,n=this.readMessage(t),r=n?.header();if(!n||!r)throw new Error(x2(t));return r}},O0=4,y2="ARROW1",bu=new Uint8Array(y2.length);for(let e=0;e<y2.length;e+=1)bu[e]=y2.codePointAt(e);function B0(e,t=0){for(let n=-1,r=bu.length;++n<r;)if(bu[n]!==e[t+n])return!1;return!0}var wu=bu.length,b2=wu+O0,MB=wu*2+O0;var Lr=class e extends Ec{constructor(t){super(),this._impl=t}get closed(){return this._impl.closed}get schema(){return this._impl.schema}get autoDestroy(){return this._impl.autoDestroy}get dictionaries(){return this._impl.dictionaries}get numDictionaries(){return this._impl.numDictionaries}get numRecordBatches(){return this._impl.numRecordBatches}get footer(){return this._impl.isFile()?this._impl.footer:null}isSync(){return this._impl.isSync()}isAsync(){return this._impl.isAsync()}isFile(){return this._impl.isFile()}isStream(){return this._impl.isStream()}next(){return this._impl.next()}throw(t){return this._impl.throw(t)}return(t){return this._impl.return(t)}cancel(){return this._impl.cancel()}reset(t){return this._impl.reset(t),this._DOMStream=void 0,this._nodeStream=void 0,this}open(t){let n=this._impl.open(t);return Tr(n)?n.then(()=>this):this}readRecordBatch(t){return this._impl.isFile()?this._impl.readRecordBatch(t):null}[Symbol.iterator](){return this._impl[Symbol.iterator]()}[Symbol.asyncIterator](){return this._impl[Symbol.asyncIterator]()}toDOMStream(){return wn.toDOMStream(this.isSync()?{[Symbol.iterator]:()=>this}:{[Symbol.asyncIterator]:()=>this})}toNodeStream(){return wn.toNodeStream(this.isSync()?{[Symbol.iterator]:()=>this}:{[Symbol.asyncIterator]:()=>this},{objectMode:!0})}static throughNode(t){throw new Error('"throughNode" not available in this environment')}static throughDOM(t,n){throw new Error('"throughDOM" not available in this environment')}static from(t){return t instanceof e?t:xg(t)?Pj(t):wg(t)?qj(t):Tr(t)?J(this,void 0,void 0,function*(){return yield e.from(yield t)}):vg(t)||Fh(t)||Sg(t)||Wr(t)?zj(new ni(t)):Uj(new yo(t))}static readAll(t){return t instanceof e?t.isSync()?AB(t):TB(t):xg(t)||ArrayBuffer.isView(t)||Mi(t)||bg(t)?AB(t):TB(t)}},ys=class extends Lr{constructor(t){super(t),this._impl=t}readAll(){return[...this]}[Symbol.iterator](){return this._impl[Symbol.iterator]()}[Symbol.asyncIterator](){return Ar(this,arguments,function*(){yield Ft(yield*Ql(Ii(this[Symbol.iterator]())))})}},Fc=class extends Lr{constructor(t){super(t),this._impl=t}readAll(){var t,n,r,i;return J(this,void 0,void 0,function*(){let o=new Array;try{for(var s=!0,a=Ii(this),c;c=yield a.next(),t=c.done,!t;s=!0){i=c.value,s=!1;let l=i;o.push(l)}}catch(l){n={error:l}}finally{try{!s&&!t&&(r=a.return)&&(yield r.call(a))}finally{if(n)throw n.error}}return o})}[Symbol.iterator](){throw new Error("AsyncRecordBatchStreamReader is not Iterable")}[Symbol.asyncIterator](){return this._impl[Symbol.asyncIterator]()}},Rc=class extends ys{constructor(t){super(t),this._impl=t}},L0=class extends Fc{constructor(t){super(t),this._impl=t}},C0=class{get numDictionaries(){return this._dictionaryIndex}get numRecordBatches(){return this._recordBatchIndex}constructor(t=new Map){this.closed=!1,this.autoDestroy=!0,this._dictionaryIndex=0,this._recordBatchIndex=0,this.dictionaries=t}isSync(){return!1}isAsync(){return!1}isFile(){return!1}isStream(){return!1}reset(t){return this._dictionaryIndex=0,this._recordBatchIndex=0,this.schema=t,this.dictionaries=new Map,this}_loadRecordBatch(t,n){let r=this._loadVectors(t,n,this.schema.fields),i=Nt({type:new xe(this.schema.fields),length:t.length,children:r});return new Fe(this.schema,i)}_loadDictionaryBatch(t,n){let{id:r,isDelta:i}=t,{dictionaries:o,schema:s}=this,a=o.get(r);if(i||!a){let c=s.dictionaries.get(r),l=this._loadVectors(t.data,n,[c]);return(a&&i?a.concat(new Xt(l)):new Xt(l)).memoize()}return a.memoize()}_loadVectors(t,n,r){return new gd(n,t.nodes,t.buffers,this.dictionaries,this.schema.metadataVersion).visitMany(r)}},vu=class extends C0{constructor(t,n){super(n),this._reader=xg(t)?new qd(this._handle=t):new xu(this._handle=t)}isSync(){return!0}isStream(){return!0}[Symbol.iterator](){return this}cancel(){!this.closed&&(this.closed=!0)&&(this.reset()._reader.return(),this._reader=null,this.dictionaries=null)}open(t){return this.closed||(this.autoDestroy=EB(this,t),this.schema||(this.schema=this._reader.readSchema())||this.cancel()),this}throw(t){return!this.closed&&this.autoDestroy&&(this.closed=!0)?this.reset()._reader.throw(t):we}return(t){return!this.closed&&this.autoDestroy&&(this.closed=!0)?this.reset()._reader.return(t):we}next(){if(this.closed)return we;let t,{_reader:n}=this;for(;t=this._readNextMessageAndValidate();)if(t.isSchema())this.reset(t.header());else if(t.isRecordBatch()){this._recordBatchIndex++;let r=t.header(),i=n.readMessageBody(t.bodyLength);return{done:!1,value:this._loadRecordBatch(r,i)}}else if(t.isDictionaryBatch()){this._dictionaryIndex++;let r=t.header(),i=n.readMessageBody(t.bodyLength),o=this._loadDictionaryBatch(r,i);this.dictionaries.set(r.id,o)}return this.schema&&this._recordBatchIndex===0?(this._recordBatchIndex++,{done:!1,value:new kc(this.schema)}):this.return()}_readNextMessageAndValidate(t){return this._reader.readMessage(t)}},_u=class extends C0{constructor(t,n){super(n),this._reader=new zd(this._handle=t)}isAsync(){return!0}isStream(){return!0}[Symbol.asyncIterator](){return this}cancel(){return J(this,void 0,void 0,function*(){!this.closed&&(this.closed=!0)&&(yield this.reset()._reader.return(),this._reader=null,this.dictionaries=null)})}open(t){return J(this,void 0,void 0,function*(){return this.closed||(this.autoDestroy=EB(this,t),this.schema||(this.schema=yield this._reader.readSchema())||(yield this.cancel())),this})}throw(t){return J(this,void 0,void 0,function*(){return!this.closed&&this.autoDestroy&&(this.closed=!0)?yield this.reset()._reader.throw(t):we})}return(t){return J(this,void 0,void 0,function*(){return!this.closed&&this.autoDestroy&&(this.closed=!0)?yield this.reset()._reader.return(t):we})}next(){return J(this,void 0,void 0,function*(){if(this.closed)return we;let t,{_reader:n}=this;for(;t=yield this._readNextMessageAndValidate();)if(t.isSchema())yield this.reset(t.header());else if(t.isRecordBatch()){this._recordBatchIndex++;let r=t.header(),i=yield n.readMessageBody(t.bodyLength);return{done:!1,value:this._loadRecordBatch(r,i)}}else if(t.isDictionaryBatch()){this._dictionaryIndex++;let r=t.header(),i=yield n.readMessageBody(t.bodyLength),o=this._loadDictionaryBatch(r,i);this.dictionaries.set(r.id,o)}return this.schema&&this._recordBatchIndex===0?(this._recordBatchIndex++,{done:!1,value:new kc(this.schema)}):yield this.return()})}_readNextMessageAndValidate(t){return J(this,void 0,void 0,function*(){return yield this._reader.readMessage(t)})}},k0=class extends vu{get footer(){return this._footer}get numDictionaries(){return this._footer?this._footer.numDictionaries:0}get numRecordBatches(){return this._footer?this._footer.numRecordBatches:0}constructor(t,n){super(t instanceof pd?t:new pd(t),n)}isSync(){return!0}isFile(){return!0}open(t){if(!this.closed&&!this._footer){this.schema=(this._footer=this._readFooter()).schema;for(let n of this._footer.dictionaryBatches())n&&this._readDictionaryBatch(this._dictionaryIndex++)}return super.open(t)}readRecordBatch(t){var n;if(this.closed)return null;this._footer||this.open();let r=(n=this._footer)===null||n===void 0?void 0:n.getRecordBatch(t);if(r&&this._handle.seek(r.offset)){let i=this._reader.readMessage(qt.RecordBatch);if(i?.isRecordBatch()){let o=i.header(),s=this._reader.readMessageBody(i.bodyLength);return this._loadRecordBatch(o,s)}}return null}_readDictionaryBatch(t){var n;let r=(n=this._footer)===null||n===void 0?void 0:n.getDictionaryBatch(t);if(r&&this._handle.seek(r.offset)){let i=this._reader.readMessage(qt.DictionaryBatch);if(i?.isDictionaryBatch()){let o=i.header(),s=this._reader.readMessageBody(i.bodyLength),a=this._loadDictionaryBatch(o,s);this.dictionaries.set(o.id,a)}}}_readFooter(){let{_handle:t}=this,n=t.size-b2,r=t.readInt32(n),i=t.readAt(n-r,r);return cs.decode(i)}_readNextMessageAndValidate(t){var n;if(this._footer||this.open(),this._footer&&this._recordBatchIndex<this.numRecordBatches){let r=(n=this._footer)===null||n===void 0?void 0:n.getRecordBatch(this._recordBatchIndex);if(r&&this._handle.seek(r.offset))return this._reader.readMessage(t)}return null}},w2=class extends _u{get footer(){return this._footer}get numDictionaries(){return this._footer?this._footer.numDictionaries:0}get numRecordBatches(){return this._footer?this._footer.numRecordBatches:0}constructor(t,...n){let r=typeof n[0]!="number"?n.shift():void 0,i=n[0]instanceof Map?n.shift():void 0;super(t instanceof _a?t:new _a(t,r),i)}isFile(){return!0}isAsync(){return!0}open(t){let n=Object.create(null,{open:{get:()=>super.open}});return J(this,void 0,void 0,function*(){if(!this.closed&&!this._footer){this.schema=(this._footer=yield this._readFooter()).schema;for(let r of this._footer.dictionaryBatches())r&&(yield this._readDictionaryBatch(this._dictionaryIndex++))}return yield n.open.call(this,t)})}readRecordBatch(t){var n;return J(this,void 0,void 0,function*(){if(this.closed)return null;this._footer||(yield this.open());let r=(n=this._footer)===null||n===void 0?void 0:n.getRecordBatch(t);if(r&&(yield this._handle.seek(r.offset))){let i=yield this._reader.readMessage(qt.RecordBatch);if(i?.isRecordBatch()){let o=i.header(),s=yield this._reader.readMessageBody(i.bodyLength);return this._loadRecordBatch(o,s)}}return null})}_readDictionaryBatch(t){var n;return J(this,void 0,void 0,function*(){let r=(n=this._footer)===null||n===void 0?void 0:n.getDictionaryBatch(t);if(r&&(yield this._handle.seek(r.offset))){let i=yield this._reader.readMessage(qt.DictionaryBatch);if(i?.isDictionaryBatch()){let o=i.header(),s=yield this._reader.readMessageBody(i.bodyLength),a=this._loadDictionaryBatch(o,s);this.dictionaries.set(o.id,a)}}})}_readFooter(){return J(this,void 0,void 0,function*(){let{_handle:t}=this;t._pending&&(yield t._pending);let n=t.size-b2,r=yield t.readInt32(n),i=yield t.readAt(n-r,r);return cs.decode(i)})}_readNextMessageAndValidate(t){return J(this,void 0,void 0,function*(){if(this._footer||(yield this.open()),this._footer&&this._recordBatchIndex<this.numRecordBatches){let n=this._footer.getRecordBatch(this._recordBatchIndex);if(n&&(yield this._handle.seek(n.offset)))return yield this._reader.readMessage(t)}return null})}},v2=class extends vu{constructor(t,n){super(t,n)}_loadVectors(t,n,r){return new o0(n,t.nodes,t.buffers,this.dictionaries,this.schema.metadataVersion).visitMany(r)}};function EB(e,t){return t&&typeof t.autoDestroy=="boolean"?t.autoDestroy:e.autoDestroy}function*AB(e){let t=Lr.from(e);try{if(!t.open({autoDestroy:!1}).closed)do yield t;while(!t.reset().open().closed)}finally{t.cancel()}}function TB(e){return Ar(this,arguments,function*(){let n=yield Ft(Lr.from(e));try{if(!(yield Ft(n.open({autoDestroy:!1}))).closed)do yield yield Ft(n);while(!(yield Ft(n.reset().open())).closed)}finally{yield Ft(n.cancel())}})}function Pj(e){return new ys(new v2(e))}function Uj(e){let t=e.peek(wu+7&-8);return t&&t.byteLength>=4?B0(t)?new Rc(new k0(e.read())):new ys(new vu(e)):new ys(new vu(function*(){}()))}function zj(e){return J(this,void 0,void 0,function*(){let t=yield e.peek(wu+7&-8);return t&&t.byteLength>=4?B0(t)?new Rc(new k0(yield e.read())):new Fc(new _u(e)):new Fc(new _u(function(){return Ar(this,arguments,function*(){})}()))})}function qj(e){return J(this,void 0,void 0,function*(){let{size:t}=yield e.stat(),n=new _a(e,t);return t>=MB&&B0(yield n.readAt(0,wu+7&-8))?new L0(new w2(n)):new Fc(new _u(n))})}var Me=class e extends mt{static assemble(...t){let n=i=>i.flatMap(o=>Array.isArray(o)?n(o):o instanceof Fe?o.data.children:o.data),r=new e;return r.visitMany(n(t)),r}constructor(){super(),this._byteLength=0,this._nodes=[],this._buffers=[],this._bufferRegions=[]}visit(t){if(t instanceof Xt)return this.visitMany(t.data),this;let{type:n}=t;if(!H.isDictionary(n)){let{length:r}=t;if(r>2147483647)throw new RangeError("Cannot write arrays larger than 2^31 - 1 in length");if(H.isUnion(n))this.nodes.push(new ii(r,0));else{let{nullCount:i}=t;H.isNull(n)||Ri.call(this,i<=0?new Uint8Array(0):Ic(t.offset,r,t.nullBitmap)),this.nodes.push(new ii(r,i))}}return super.visit(t)}visitNull(t){return this}visitDictionary(t){return this.visit(t.clone(t.type.indices))}get nodes(){return this._nodes}get buffers(){return this._buffers}get byteLength(){return this._byteLength}get bufferRegions(){return this._bufferRegions}};function Ri(e){let t=e.byteLength+7&-8;return this.buffers.push(e),this.bufferRegions.push(new yr(this._byteLength,t)),this._byteLength+=t,this}function jj(e){var t;let{type:n,length:r,typeIds:i,valueOffsets:o}=e;if(Ri.call(this,i),n.mode===ge.Sparse)return _2.call(this,e);if(n.mode===ge.Dense){if(e.offset<=0)return Ri.call(this,o),_2.call(this,e);{let s=new Int32Array(r),a=Object.create(null),c=Object.create(null);for(let l,u,f=-1;++f<r;)(l=i[f])!==void 0&&((u=a[l])===void 0&&(u=a[l]=o[f]),s[f]=o[f]-u,c[l]=((t=c[l])!==null&&t!==void 0?t:0)+1);Ri.call(this,s),this.visitMany(e.children.map((l,u)=>{let f=n.typeIds[u],h=a[f],d=c[f];return l.slice(h,Math.min(r,d))}))}}return this}function Vj(e){let t;return e.nullCount>=e.length?Ri.call(this,new Uint8Array(0)):(t=e.values)instanceof Uint8Array?Ri.call(this,Ic(e.offset,e.length,t)):Ri.call(this,Mc(e.values))}function gs(e){return Ri.call(this,e.values.subarray(0,e.length*e.stride))}function F0(e){let{length:t,values:n,valueOffsets:r}=e,i=De(r[0]),o=De(r[t]),s=Math.min(o-i,n.byteLength-i);return Ri.call(this,Mg(-i,t+1,r)),Ri.call(this,n.subarray(i,i+s)),this}function S2(e){let{length:t,valueOffsets:n}=e;if(n){let{[0]:r,[t]:i}=n;return Ri.call(this,Mg(-r,t+1,n)),this.visit(e.children[0].slice(r,i-r))}return this.visit(e.children[0])}function _2(e){return this.visitMany(e.type.children.map((t,n)=>e.children[n]).filter(Boolean))[0]}Me.prototype.visitBool=Vj;Me.prototype.visitInt=gs;Me.prototype.visitFloat=gs;Me.prototype.visitUtf8=F0;Me.prototype.visitLargeUtf8=F0;Me.prototype.visitBinary=F0;Me.prototype.visitLargeBinary=F0;Me.prototype.visitFixedSizeBinary=gs;Me.prototype.visitDate=gs;Me.prototype.visitTimestamp=gs;Me.prototype.visitTime=gs;Me.prototype.visitDecimal=gs;Me.prototype.visitList=S2;Me.prototype.visitStruct=_2;Me.prototype.visitUnion=jj;Me.prototype.visitInterval=gs;Me.prototype.visitDuration=gs;Me.prototype.visitFixedSizeList=S2;Me.prototype.visitMap=S2;var $c=class extends Ec{static throughNode(t){throw new Error('"throughNode" not available in this environment')}static throughDOM(t,n){throw new Error('"throughDOM" not available in this environment')}constructor(t){super(),this._position=0,this._started=!1,this._sink=new mo,this._schema=null,this._dictionaryBlocks=[],this._recordBatchBlocks=[],this._dictionaryDeltaOffsets=new Map,Xn(t)||(t={autoDestroy:!0,writeLegacyIpcFormat:!1}),this._autoDestroy=typeof t.autoDestroy=="boolean"?t.autoDestroy:!0,this._writeLegacyIpcFormat=typeof t.writeLegacyIpcFormat=="boolean"?t.writeLegacyIpcFormat:!1}toString(t=!1){return this._sink.toString(t)}toUint8Array(t=!1){return this._sink.toUint8Array(t)}writeAll(t){return Tr(t)?t.then(n=>this.writeAll(n)):Wr(t)?M2(this,t):I2(this,t)}get closed(){return this._sink.closed}[Symbol.asyncIterator](){return this._sink[Symbol.asyncIterator]()}toDOMStream(t){return this._sink.toDOMStream(t)}toNodeStream(t){return this._sink.toNodeStream(t)}close(){return this.reset()._sink.close()}abort(t){return this.reset()._sink.abort(t)}finish(){return this._autoDestroy?this.close():this.reset(this._sink,this._schema),this}reset(t=this._sink,n=null){return t===this._sink||t instanceof mo?this._sink=t:(this._sink=new mo,t&&qD(t)?this.toDOMStream({type:"bytes"}).pipeTo(t):t&&jD(t)&&this.toNodeStream({objectMode:!1}).pipe(t)),this._started&&this._schema&&this._writeFooter(this._schema),this._started=!1,this._dictionaryBlocks=[],this._recordBatchBlocks=[],this._dictionaryDeltaOffsets=new Map,(!n||!Cc(n,this._schema))&&(n==null?(this._position=0,this._schema=null):(this._started=!0,this._schema=n,this._writeSchema(n))),this}write(t){let n=null;if(this._sink){if(t==null)return this.finish()&&void 0;if(t instanceof mr&&!(n=t.schema))return this.finish()&&void 0;if(t instanceof Fe&&!(n=t.schema))return this.finish()&&void 0}else throw new Error("RecordBatchWriter is closed");if(n&&!Cc(n,this._schema)){if(this._started&&this._autoDestroy)return this.close();this.reset(this._sink,n)}t instanceof Fe?t instanceof kc||this._writeRecordBatch(t):t instanceof mr?this.writeAll(t.batches):Mi(t)&&this.writeAll(t)}_writeMessage(t,n=8){let r=n-1,i=xr.encode(t),o=i.byteLength,s=this._writeLegacyIpcFormat?4:8,a=o+s+r&~r,c=a-o-s;return t.headerType===qt.RecordBatch?this._recordBatchBlocks.push(new ls(a,t.bodyLength,this._position)):t.headerType===qt.DictionaryBatch&&this._dictionaryBlocks.push(new ls(a,t.bodyLength,this._position)),this._writeLegacyIpcFormat||this._write(Int32Array.of(-1)),this._write(Int32Array.of(a-s)),o>0&&this._write(i),this._writePadding(c)}_write(t){if(this._started){let n=_t(t);n&&n.byteLength>0&&(this._sink.write(n),this._position+=n.byteLength)}return this}_writeSchema(t){return this._writeMessage(xr.from(t))}_writeFooter(t){return this._writeLegacyIpcFormat?this._write(Int32Array.of(0)):this._write(Int32Array.of(-1,0))}_writeMagic(){return this._write(bu)}_writePadding(t){return t>0?this._write(new Uint8Array(t)):this}_writeRecordBatch(t){let{byteLength:n,nodes:r,bufferRegions:i,buffers:o}=Me.assemble(t),s=new _n(t.numRows,r,i),a=xr.from(s,n);return this._writeDictionaries(t)._writeMessage(a)._writeBodyBuffers(o)}_writeDictionaryBatch(t,n,r=!1){this._dictionaryDeltaOffsets.set(n,t.length+(this._dictionaryDeltaOffsets.get(n)||0));let{byteLength:i,nodes:o,bufferRegions:s,buffers:a}=Me.assemble(new Xt([t])),c=new _n(t.length,o,s),l=new gr(c,n,r),u=xr.from(l,i);return this._writeMessage(u)._writeBodyBuffers(a)}_writeBodyBuffers(t){let n,r,i;for(let o=-1,s=t.length;++o<s;)(n=t[o])&&(r=n.byteLength)>0&&(this._write(n),(i=(r+7&-8)-r)>0&&this._writePadding(i));return this}_writeDictionaries(t){for(let[n,r]of t.dictionaries){let i=this._dictionaryDeltaOffsets.get(n)||0;if(i===0||(r=r?.slice(i)).length>0)for(let o of r.data)this._writeDictionaryBatch(o,n,i>0),i+=o.length}return this}},jd=class e extends $c{static writeAll(t,n){let r=new e(n);return Tr(t)?t.then(i=>r.writeAll(i)):Wr(t)?M2(r,t):I2(r,t)}},Vd=class e extends $c{static writeAll(t){let n=new e;return Tr(t)?t.then(r=>n.writeAll(r)):Wr(t)?M2(n,t):I2(n,t)}constructor(){super(),this._autoDestroy=!0}_writeSchema(t){return this._writeMagic()._writePadding(2)}_writeFooter(t){let n=cs.encode(new cs(t,ce.V5,this._recordBatchBlocks,this._dictionaryBlocks));return super._writeFooter(t)._write(n)._write(Int32Array.of(n.byteLength))._writeMagic()}};function I2(e,t){let n=t;t instanceof mr&&(n=t.batches,e.reset(void 0,t.schema));for(let r of n)e.write(r);return e.finish()}function M2(e,t){var n,r,i,o,s,a,c;return J(this,void 0,void 0,function*(){try{for(n=!0,r=Ii(t);i=yield r.next(),o=i.done,!o;n=!0){c=i.value,n=!1;let l=c;e.write(l)}}catch(l){s={error:l}}finally{try{!n&&!o&&(a=r.return)&&(yield a.call(r))}finally{if(s)throw s.error}}return e.finish()})}function NB(e,t){if(Wr(e))return Xj(e,t);if(Mi(e))return Yj(e,t);throw new Error("toDOMStream() must be called with an Iterable or AsyncIterable")}function Yj(e,t){let n=null,r=t?.type==="bytes"||!1,i=t?.highWaterMark||Math.pow(2,24);return new ReadableStream(Object.assign(Object.assign({},t),{start(s){o(s,n||(n=e[Symbol.iterator]()))},pull(s){n?o(s,n):s.close()},cancel(){(n?.return&&n.return()||!0)&&(n=null)}}),Object.assign({highWaterMark:r?i:void 0},t));function o(s,a){let c,l=null,u=s.desiredSize||null;for(;!(l=a.next(r?u:null)).done;)if(ArrayBuffer.isView(l.value)&&(c=_t(l.value))&&(u!=null&&r&&(u=u-c.byteLength+1),l.value=c),s.enqueue(l.value),u!=null&&--u<=0)return;s.close()}}function Xj(e,t){let n=null,r=t?.type==="bytes"||!1,i=t?.highWaterMark||Math.pow(2,24);return new ReadableStream(Object.assign(Object.assign({},t),{start(s){return J(this,void 0,void 0,function*(){yield o(s,n||(n=e[Symbol.asyncIterator]()))})},pull(s){return J(this,void 0,void 0,function*(){n?yield o(s,n):s.close()})},cancel(){return J(this,void 0,void 0,function*(){(n?.return&&(yield n.return())||!0)&&(n=null)})}}),Object.assign({highWaterMark:r?i:void 0},t));function o(s,a){return J(this,void 0,void 0,function*(){let c,l=null,u=s.desiredSize||null;for(;!(l=yield a.next(r?u:null)).done;)if(ArrayBuffer.isView(l.value)&&(c=_t(l.value))&&(u!=null&&r&&(u=u-c.byteLength+1),l.value=c),s.enqueue(l.value),u!=null&&--u<=0)return;s.close()})}}function BB(e){return new A2(e)}var A2=class{constructor(t){this._numChunks=0,this._finished=!1,this._bufferedSize=0;let{["readableStrategy"]:n,["writableStrategy"]:r,["queueingStrategy"]:i="count"}=t,o=UD(t,["readableStrategy","writableStrategy","queueingStrategy"]);this._controller=null,this._builder=Dc(o),this._getSize=i!=="bytes"?DB:OB;let{["highWaterMark"]:s=i==="bytes"?Math.pow(2,14):1e3}=Object.assign({},n),{["highWaterMark"]:a=i==="bytes"?Math.pow(2,14):1e3}=Object.assign({},r);this.readable=new ReadableStream({cancel:()=>{this._builder.clear()},pull:c=>{this._maybeFlush(this._builder,this._controller=c)},start:c=>{this._maybeFlush(this._builder,this._controller=c)}},{highWaterMark:s,size:i!=="bytes"?DB:OB}),this.writable=new WritableStream({abort:()=>{this._builder.clear()},write:()=>{this._maybeFlush(this._builder,this._controller)},close:()=>{this._maybeFlush(this._builder.finish(),this._controller)}},{highWaterMark:a,size:c=>this._writeValueAndReturnChunkSize(c)})}_writeValueAndReturnChunkSize(t){let n=this._bufferedSize;return this._bufferedSize=this._getSize(this._builder.append(t)),this._bufferedSize-n}_maybeFlush(t,n){n!=null&&(this._bufferedSize>=n.desiredSize&&++this._numChunks&&this._enqueue(n,t.toVector()),t.finished&&((t.length>0||this._numChunks===0)&&++this._numChunks&&this._enqueue(n,t.toVector()),!this._finished&&(this._finished=!0)&&this._enqueue(n,null)))}_enqueue(t,n){this._bufferedSize=0,this._controller=null,n==null?t.close():t.enqueue(n)}},DB=e=>{var t;return(t=e?.length)!==null&&t!==void 0?t:0},OB=e=>{var t;return(t=e?.byteLength)!==null&&t!==void 0?t:0};function R0(e,t){let n=new mo,r=null,i=new ReadableStream({cancel(){return J(this,void 0,void 0,function*(){yield n.close()})},start(a){return J(this,void 0,void 0,function*(){yield s(a,r||(r=yield o()))})},pull(a){return J(this,void 0,void 0,function*(){r?yield s(a,r):a.close()})}});return{writable:new WritableStream(n,Object.assign({highWaterMark:Math.pow(2,14)},e)),readable:i};function o(){return J(this,void 0,void 0,function*(){return yield(yield Lr.from(n)).open(t)})}function s(a,c){return J(this,void 0,void 0,function*(){let l=a.desiredSize,u=null;for(;!(u=yield c.next()).done;)if(a.enqueue(u.value),l!=null&&--l<=0)return;a.close()})}}function $0(e,t){let n=new this(e),r=new ni(n),i=new ReadableStream({cancel(){return J(this,void 0,void 0,function*(){yield r.cancel()})},pull(s){return J(this,void 0,void 0,function*(){yield o(s)})},start(s){return J(this,void 0,void 0,function*(){yield o(s)})}},Object.assign({highWaterMark:Math.pow(2,14)},t));return{writable:new WritableStream(n,e),readable:i};function o(s){return J(this,void 0,void 0,function*(){let a=null,c=s.desiredSize;for(;a=yield r.read(c||null);)if(s.enqueue(a),c!=null&&(c-=a.byteLength)<=0)return;s.close()})}}function Yd(e){let t=Lr.from(e);return Tr(t)?t.then(n=>Yd(n)):t.isAsync()?t.readAll().then(n=>new mr(n)):new mr(t.readAll())}var hV=Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},R_),l2),t2),$_),B_),K_),k_),{compareSchemas:Cc,compareFields:sB,compareTypes:aB});wn.toDOMStream=NB;ve.throughDOM=BB;Lr.throughDOM=R0;Rc.throughDOM=R0;ys.throughDOM=R0;$c.throughDOM=$0;Vd.throughDOM=$0;jd.throughDOM=$0;function P0(e="ws://localhost:3000/"){let t=[],n=!1,r=null,i,o={open(){n=!0,c()},close(){for(n=!1,r=null,i=null;t.length;)t.shift().reject("Socket closed")},error(l){if(r){let{reject:u}=r;r=null,c(),u(l)}else console.error("WebSocket error: ",l)},message({data:l}){if(r){let{query:u,resolve:f,reject:h}=r;if(r=null,c(),typeof l=="string"){let d=JSON.parse(l);d.error?h(d.error):f(d)}else if(u.type==="exec")f();else if(u.type==="arrow")f(Yd(l.arrayBuffer()));else throw new Error(`Unexpected socket data: ${l}`)}else console.log("WebSocket message: ",l)}};function s(){i=new WebSocket(e);for(let l in o)i.addEventListener(l,o[l])}function a(l,u,f){i==null&&s(),t.push({query:l,resolve:u,reject:f}),n&&!r&&c()}function c(){t.length&&(r=t.shift(),i.send(JSON.stringify(r.query)))}return{get connected(){return n},query(l){return new Promise((u,f)=>a(l,u,f))}}}var br=class{constructor(t,n){t&&(this.table=String(t)),n&&(this.column=n)}get columns(){return this.column?[this.column]:[]}toString(){let{table:t,column:n}=this;if(n){let r=n.startsWith("*")?n:`"${n}"`;return`${t?`${LB(t)}.`:""}${r}`}else return t?LB(t):"NULL"}};function LB(e){return e.split(".").map(n=>`"${n}"`).join(".")}function CB(e,t){return e instanceof br&&e.column===t}function jt(e){return typeof e=="string"?Sa(e):e}function Pc(e){return typeof e=="string"?kB(e):e}function kB(e){return new br(e)}function Sa(e,t=null){return arguments.length===1&&(t=e,e=null),new br(e,t)}function xo(e){switch(typeof e){case"boolean":return e?"TRUE":"FALSE";case"string":return`'${e}'`;case"number":return Number.isFinite(e)?String(e):"NULL";default:if(e==null)return"NULL";if(e instanceof Date){let t=+e;if(Number.isNaN(t))return"NULL";let n=e.getUTCFullYear(),r=e.getUTCMonth(),i=e.getUTCDate();return t===Date.UTC(n,r,i)?`MAKE_DATE(${n}, ${r+1}, ${i})`:`EPOCH_MS(${t})`}else return e instanceof RegExp?`'${e.source}'`:String(e)}}var xs=e=>typeof e?.addEventListener=="function";function U0(e){return e instanceof Ia}var Ia=class{constructor(t,n,r){this._expr=Array.isArray(t)?t:[t],this._deps=n||[],this.annotate(r);let i=this._expr.filter(o=>xs(o));i.length>0?(this._params=Array.from(new Set(i)),this._params.forEach(o=>{o.addEventListener("value",()=>dV(this,this.map?.get("value")))})):this.addEventListener=void 0}get value(){return this}get columns(){let{_params:t,_deps:n}=this;if(t){let r=new Set(t.flatMap(i=>{let o=i.value?.columns;return Array.isArray(o)?o:[]}));if(r.size){let i=new Set(n);return r.forEach(o=>i.add(o)),Array.from(i)}}return n}get column(){return this._deps.length?this._deps[0]:this.columns[0]}annotate(...t){return Object.assign(this,...t)}toString(){return this._expr.map(t=>xs(t)&&!U0(t)?xo(t.value):t).join("")}addEventListener(t,n){let r=this.map||(this.map=new Map);(r.get(t)||(r.set(t,new Set),r.get(t))).add(n)}};function dV(e,t){if(t?.size)return Promise.allSettled(Array.from(t,n=>n(e)))}function T2(e,t){let n=[e[0]],r=new Set,i=t.length;for(let o=0,s=0;o<i;){let a=t[o];xs(a)?n[++s]=a:(Array.isArray(a?.columns)&&a.columns.forEach(l=>r.add(l)),n[s]+=typeof a=="string"?a:xo(a));let c=e[++o];xs(n[s])?n[++s]=c:n[s]+=c}return{spans:n,cols:Array.from(r)}}function q(e,...t){let{spans:n,cols:r}=T2(e,t);return new Ia(n,r)}function E2(e){let t=jt(e);return q`${t} DESC NULLS LAST`.annotate({label:t?.label,desc:!0})}var Cr=e=>({value:e,toString:()=>xo(e)});function Xd(e){e(this.op,this),this.children?.forEach(t=>t.visit(e))}function FB(e,t){let n=t.filter(i=>i!=null).map(jt),r=n.map((i,o)=>o?` ${e} `:"");return n.length===1?r.push(""):n.length>1&&(r[0]="(",r.push(")")),q(r,...n).annotate({op:e,children:n,visit:Xd})}var Hn=(...e)=>FB("AND",e.flat()),Uc=(...e)=>FB("OR",e.flat()),pV=e=>t=>q`(${e} ${jt(t)})`.annotate({op:e,a:t,visit:Xd}),N2=pV("NOT"),RB=e=>t=>q`(${jt(t)} ${e})`.annotate({op:e,a:t,visit:Xd}),zc=RB("IS NULL"),bs=RB("IS NOT NULL"),Ma=e=>(t,n)=>q`(${jt(t)} ${e} ${jt(n)})`.annotate({op:e,a:t,b:n,visit:Xd}),ws=Ma("="),qc=Ma("<>"),vs=Ma("<"),Gd=Ma(">"),_s=Ma("<="),D2=Ma(">="),O2=Ma("IS DISTINCT FROM"),Wd=Ma("IS NOT DISTINCT FROM");function $B(e,t,n,r){t=jt(t);let i=e.startsWith("NOT ")?"NOT ":"";return(n?r?q`${i}(${n[0]} <= ${t} AND ${t} < ${n[1]})`:q`(${t} ${e} ${n[0]} AND ${n[1]})`:q``).annotate({op:e,visit:Xd,field:t,range:n})}var Ae=(e,t,n)=>$B("BETWEEN",e,t,n),B2=(e,t,n)=>$B("NOT BETWEEN",e,t,n);function jc(e,t){return Array.from({length:e},()=>t)}function Sn(e,t){return(...n)=>{let r=n.map(jt),i=t?`::${t}`:"";return(r.length?q([`${e}(`,...jc(r.length-1,", "),`)${i}`],...r):q`${e}()${i}`).annotate({func:e,args:r})}}var L2=Sn("REGEXP_MATCHES"),C2=Sn("CONTAINS"),k2=Sn("PREFIX"),F2=Sn("SUFFIX"),mV=Sn("LOWER"),yV=Sn("UPPER"),gV=Sn("LENGTH"),xV=Sn("ISNAN"),bV=Sn("ISFINITE"),wV=Sn("ISINF");var Hd=class e extends Ia{constructor(t,n,r,i,o="",s="",a=""){let c;if(i&&!(o||s||a))c=i?q`${n} OVER "${i}"`:q`${n} OVER ()`;else{let h=o&&s?" ":"",d=(o||s)&&a?" ":"";c=q`${n} OVER (${i?`"${i}" `:""}${o}${h}${s}${d}${a})`}r&&(c=q`(${c})::${r}`);let{_expr:u,_deps:f}=c;super(u,f),this.window=t,this.func=n,this.type=r,this.name=i,this.group=o,this.order=s,this.frame=a}get basis(){return this.column}get label(){let{func:t}=this;return t.label??t.toString()}over(t){let{window:n,func:r,type:i,group:o,order:s,frame:a}=this;return new e(n,r,i,t,o,s,a)}partitionby(...t){let n=t.flat().filter(u=>u).map(jt),r=q(["PARTITION BY ",jc(n.length-1,", "),""],...n),{window:i,func:o,type:s,name:a,order:c,frame:l}=this;return new e(i,o,s,a,r,c,l)}orderby(...t){let n=t.flat().filter(u=>u).map(jt),r=q(["ORDER BY ",jc(n.length-1,", "),""],...n),{window:i,func:o,type:s,name:a,group:c,frame:l}=this;return new e(i,o,s,a,c,r,l)}rows(t){let n=PB("ROWS",t),{window:r,func:i,type:o,name:s,group:a,order:c}=this;return new e(r,i,o,s,a,c,n)}range(t){let n=PB("RANGE",t),{window:r,func:i,type:o,name:s,group:a,order:c}=this;return new e(r,i,o,s,a,c,n)}};function PB(e,t){if(xs(t)){let n=q`${t}`;return n.toString=()=>`${e} ${UB(t.value)}`,n}return`${e} ${UB(t)}`}function UB(e){let[t,n]=e,r=t===0?"CURRENT ROW":Number.isFinite(t)?`${Math.abs(t)} PRECEDING`:"UNBOUNDED PRECEDING",i=n===0?"CURRENT ROW":Number.isFinite(n)?`${Math.abs(n)} FOLLOWING`:"UNBOUNDED FOLLOWING";return`BETWEEN ${r} AND ${i}`}function $i(e,t){return(...n)=>{let r=Sn(e)(...n);return new Hd(e,r,t)}}var R2=$i("ROW_NUMBER","INTEGER"),$2=$i("RANK","INTEGER"),P2=$i("DENSE_RANK","INTEGER"),U2=$i("PERCENT_RANK"),z2=$i("CUME_DIST"),q2=$i("NTILE"),j2=$i("LAG"),V2=$i("LEAD"),Y2=$i("FIRST_VALUE"),X2=$i("LAST_VALUE"),G2=$i("NTH_VALUE");function H2(e,...t){return q(e,...t).annotate({aggregate:!0})}var W2=class e extends Ia{constructor(t,n,r,i,o){n=(n||[]).map(jt);let{strings:s,exprs:a}=vV(t,n,r,i,o),{spans:c,cols:l}=T2(s,a);super(c,l),this.aggregate=t,this.args=n,this.type=r,this.isDistinct=i,this.filter=o}get basis(){return this.column}get label(){let{aggregate:t,args:n,isDistinct:r}=this,i=r?"DISTINCT"+(n.length?" ":""):"",o=n.length?`(${i}${n.map(_V).join(", ")})`:"";return`${t.toLowerCase()}${o}`}distinct(){let{aggregate:t,args:n,type:r,filter:i}=this;return new e(t,n,r,!0,i)}where(t){let{aggregate:n,args:r,type:i,isDistinct:o}=this;return new e(n,r,i,o,t)}window(){let{aggregate:t,args:n,type:r,isDistinct:i}=this,o=new e(t,n,null,i);return new Hd(t,o,r)}partitionby(...t){return this.window().partitionby(...t)}orderby(...t){return this.window().orderby(...t)}rows(t){return this.window().rows(t)}range(t){return this.window().range(t)}};function vV(e,t,n,r,i){let o=`)${n?`::${n}`:""}`,s=[`${e}(${r?"DISTINCT ":""}`],a=[];return t.length?(s=s.concat([...jc(t.length-1,", "),`${o}${i?" FILTER (WHERE ":""}`,...i?[")"]:[]]),a=[...t,...i?[i]:[]]):s[0]+="*"+o,{exprs:a,strings:s}}function _V(e){let t=xo(e);return t&&t.startsWith('"')&&t.endsWith('"')?t.slice(1,-1):t}function Jt(e,t){return(...n)=>new W2(e,n,t)}var kr=Jt("COUNT","INTEGER"),Z2=Jt("AVG"),SV=Jt("AVG"),J2=Jt("MAD"),oi=Jt("MAX"),si=Jt("MIN"),Fr=Jt("SUM","DOUBLE"),Q2=Jt("PRODUCT"),K2=Jt("MEDIAN"),tS=Jt("QUANTILE"),eS=Jt("MODE"),nS=Jt("VARIANCE"),rS=Jt("STDDEV"),iS=Jt("SKEWNESS"),oS=Jt("KURTOSIS"),sS=Jt("ENTROPY"),aS=Jt("VAR_POP"),cS=Jt("STDDEV_POP"),lS=Jt("CORR"),uS=Jt("COVAR_POP"),fS=Jt("REGR_INTERCEPT"),hS=Jt("REGR_SLOPE"),dS=Jt("REGR_COUNT"),IV=Jt("REGR_R2"),pS=Jt("REGR_SYY"),mS=Jt("REGR_SXX"),MV=Jt("REGR_SXY"),yS=Jt("REGR_AVGX"),AV=Jt("REGR_AVGY"),gS=Jt("FIRST"),xS=Jt("LAST"),Su=Jt("ARG_MIN"),Iu=Jt("ARG_MAX"),bS=Jt("STRING_AGG"),wS=Jt("ARRAY_AGG");function Zd(e,t){let n=jt(e),r=q`CAST(${n} AS ${t})`;return Object.defineProperty(r,"label",{enumerable:!0,get(){return e.label}}),Object.defineProperty(r,"aggregate",{enumerable:!0,get(){return e.aggregate||!1}}),r}var Mu=e=>Zd(e,"DOUBLE"),vS=e=>Zd(e,"INTEGER");var _S=e=>q`epoch_ms(${jt(e)})`,SS=e=>{let t=jt(e);return q`MAKE_DATE(2012, MONTH(${t}), 1)`.annotate({label:"month"})},IS=e=>{let t=jt(e);return q`MAKE_DATE(2012, MONTH(${t}), DAY(${t}))`.annotate({label:"date"})},MS=e=>{let t=jt(e);return q`MAKE_DATE(2012, 1, DAY(${t}))`.annotate({label:"date"})};var Jd=Sn("ST_AsGeoJSON"),zB=Sn("ST_X"),qB=Sn("ST_Y"),Qd=Sn("ST_CENTROID"),AS=e=>zB(Qd(e)),TS=e=>qB(Qd(e));var dt=class e{static select(...t){return new e().select(...t)}static from(...t){return new e().from(...t)}static with(...t){return new e().with(...t)}static union(...t){return new Vc("UNION",t.flat())}static unionAll(...t){return new Vc("UNION ALL",t.flat())}static intersect(...t){return new Vc("INTERSECT",t.flat())}static except(...t){return new Vc("EXCEPT",t.flat())}static describe(t){let n=t.clone(),{clone:r,toString:i}=n;return Object.assign(n,{describe:!0,clone:()=>e.describe(r.call(n)),toString:()=>`DESCRIBE ${i.call(n)}`})}constructor(){this.query={with:[],select:[],from:[],where:[],groupby:[],having:[],window:[],qualify:[],orderby:[]},this.cteFor=null}clone(){let t=new e;return t.query={...this.query},t}with(...t){let{query:n}=this;if(t.length===0)return n.with;{let r=[],i=(o,s)=>{let a=s.clone();a.cteFor=this,r.push({as:o,query:a})};return t.flat().forEach(o=>{if(o!=null)if(o.as&&o.query)i(o.as,o.query);else for(let s in o)i(s,o[s])}),n.with=n.with.concat(r),this}}select(...t){let{query:n}=this;if(t.length===0)return n.select;{let r=[];for(let i of t.flat())if(i!=null)if(typeof i=="string")r.push({as:i,expr:jt(i)});else if(i instanceof br)r.push({as:i.column,expr:i});else if(Array.isArray(i))r.push({as:i[0],expr:i[1]});else for(let o in i)r.push({as:z0(o),expr:jt(i[o])});return n.select=n.select.concat(r),this}}$select(...t){return this.query.select=[],this.select(...t)}distinct(t=!0){return this.query.distinct=!!t,this}from(...t){let{query:n}=this;if(t.length===0)return n.from;{let r=[];return t.flat().forEach(i=>{if(i!=null)if(typeof i=="string")r.push({as:i,from:Pc(i)});else if(i instanceof br)r.push({as:i.table,from:i});else if(Kd(i)||U0(i))r.push({from:i});else if(Array.isArray(i))r.push({as:z0(i[0]),from:Pc(i[1])});else for(let o in i)r.push({as:z0(o),from:Pc(i[o])})}),n.from=n.from.concat(r),this}}$from(...t){return this.query.from=[],this.from(...t)}sample(t,n){let{query:r}=this;if(arguments.length===0)return r.sample;{let i=t;return typeof t=="number"&&(i=t>0&&t<1?{perc:100*t,method:n}:{rows:Math.round(t),method:n}),r.sample=i,this}}where(...t){let{query:n}=this;return t.length===0?n.where:(n.where=n.where.concat(t.flat().filter(r=>r)),this)}$where(...t){return this.query.where=[],this.where(...t)}groupby(...t){let{query:n}=this;return t.length===0?n.groupby:(n.groupby=n.groupby.concat(t.flat().filter(r=>r).map(jt)),this)}$groupby(...t){return this.query.groupby=[],this.groupby(...t)}having(...t){let{query:n}=this;return t.length===0?n.having:(n.having=n.having.concat(t.flat().filter(r=>r)),this)}window(...t){let{query:n}=this;if(t.length===0)return n.window;{let r=[];return t.flat().forEach(i=>{if(i!=null)for(let o in i)r.push({as:z0(o),expr:i[o]})}),n.window=n.window.concat(r),this}}qualify(...t){let{query:n}=this;return t.length===0?n.qualify:(n.qualify=n.qualify.concat(t.flat().filter(r=>r)),this)}orderby(...t){let{query:n}=this;return t.length===0?n.orderby:(n.orderby=n.orderby.concat(t.flat().filter(r=>r).map(jt)),this)}limit(t){let{query:n}=this;return arguments.length===0?n.limit:(n.limit=Number.isFinite(t)?t:void 0,this)}offset(t){let{query:n}=this;return arguments.length===0?n.offset:(n.offset=Number.isFinite(t)?t:void 0,this)}get subqueries(){let{query:t,cteFor:n}=this,i=(n?.query||t).with?.reduce((s,{as:a,query:c})=>(s[a]=c,s),{}),o=[];return t.from.forEach(({from:s})=>{if(Kd(s))o.push(s);else if(i[s.table]){let a=i[s.table];o.push(a)}}),o}toString(){let{with:t,select:n,distinct:r,from:i,sample:o,where:s,groupby:a,having:c,window:l,qualify:u,orderby:f,limit:h,offset:d}=this.query,p=[];if(t.length){let y=t.map(({as:g,query:x})=>`"${g}" AS (${x})`);p.push(`WITH ${y.join(", ")}`)}let m=n.map(({as:y,expr:g})=>CB(g,y)&&!g.table?`${g}`:`${g} AS "${y}"`);if(p.push(`SELECT${r?" DISTINCT":""} ${m.join(", ")}`),i.length){let y=i.map(({as:g,from:x})=>{let b=Kd(x)?`(${x})`:`${x}`;return!g||g===x.table?b:`${b} AS "${g}"`});p.push(`FROM ${y.join(", ")}`)}if(s.length){let y=s.map(String).filter(g=>g).join(" AND ");y&&p.push(`WHERE ${y}`)}if(o){let{rows:y,perc:g,method:x,seed:b}=o,w=y?`${y} ROWS`:`${g} PERCENT`,_=x?` (${x}${b!=null?`, ${b}`:""})`:"";p.push(`USING SAMPLE ${w}${_}`)}if(a.length&&p.push(`GROUP BY ${a.join(", ")}`),c.length){let y=c.map(String).filter(g=>g).join(" AND ");y&&p.push(`HAVING ${y}`)}if(l.length){let y=l.map(({as:g,expr:x})=>`"${g}" AS (${x})`);p.push(`WINDOW ${y.join(", ")}`)}if(u.length){let y=u.map(String).filter(g=>g).join(" AND ");y&&p.push(`QUALIFY ${y}`)}return f.length&&p.push(`ORDER BY ${f.join(", ")}`),Number.isFinite(h)&&p.push(`LIMIT ${h}`),Number.isFinite(d)&&p.push(`OFFSET ${d}`),p.join(" ")}},Vc=class e{constructor(t,n){this.op=t,this.queries=n.map(r=>r.clone()),this.query={orderby:[]},this.cteFor=null}clone(){let t=new e(this.op,this.queries);return t.query={...this.query},t}orderby(...t){let{query:n}=this;return t.length===0?n.orderby:(n.orderby=n.orderby.concat(t.flat().filter(r=>r).map(jt)),this)}limit(t){let{query:n}=this;return arguments.length===0?n.limit:(n.limit=Number.isFinite(t)?t:void 0,this)}offset(t){let{query:n}=this;return arguments.length===0?n.offset:(n.offset=Number.isFinite(t)?t:void 0,this)}get subqueries(){let{queries:t,cteFor:n}=this;return n&&t.forEach(r=>r.cteFor=n),t}toString(){let{op:t,queries:n,query:{orderby:r,limit:i,offset:o}}=this,s=[n.join(` ${t} `)];return r.length&&s.push(`ORDER BY ${r.join(", ")}`),Number.isFinite(i)&&s.push(`LIMIT ${i}`),Number.isFinite(o)&&s.push(`OFFSET ${o}`),s.join(" ")}};function Kd(e){return e instanceof dt||e instanceof Vc}function ES(e){return Kd(e)&&e.describe}function z0(e){return TV(e)?e.slice(1,-1):e}function TV(e){return e[0]==='"'&&e[e.length-1]==='"'}var q0=e=>e;function EV(){return{apply:q0,invert:q0,sqlApply:jt,sqlInvert:q0}}function NV({base:e=null}={}){if(e==null||e===Math.E)return{apply:Math.log,invert:Math.exp,sqlApply:t=>q`LN(${jt(t)})`,sqlInvert:t=>q`EXP(${t})`};if(e===10)return{apply:Math.log10,invert:t=>Math.pow(10,t),sqlApply:t=>q`LOG(${jt(t)})`,sqlInvert:t=>q`POW(10, ${t})`};{let t=+e;return{apply:n=>Math.log(n)/Math.log(t),invert:n=>Math.pow(t,n),sqlApply:n=>q`LN(${jt(n)}) / LN(${t})`,sqlInvert:n=>q`POW(${t}, ${n})`}}}function DV({constant:e=1}={}){let t=+e;return{apply:n=>Math.sign(n)*Math.log1p(Math.abs(n)),invert:n=>Math.sign(n)*Math.exp(Math.abs(n)-t),sqlApply:n=>(n=jt(n),q`SIGN(${n}) * LN(${t} + ABS(${n}))`),sqlInvert:n=>q`SIGN(${n}) * (EXP(ABS(${n})) - ${t})`}}function OV(){return{apply:e=>Math.sign(e)*Math.sqrt(Math.abs(e)),invert:e=>Math.sign(e)*e*e,sqlApply:e=>(e=jt(e),q`SIGN(${e}) * SQRT(ABS(${e}))`),sqlInvert:e=>q`SIGN(${e}) * (${e}) ** 2`}}function BV({exponent:e=1}={}){let t=+e;return{apply:n=>Math.sign(n)*Math.pow(Math.abs(n),t),invert:n=>Math.sign(n)*Math.pow(Math.abs(n),1/t),sqlApply:n=>(n=jt(n),q`SIGN(${n}) * POW(ABS(${n}), ${t})`),sqlInvert:n=>q`SIGN(${n}) * POW(ABS(${n}), 1/${t})`}}function jB(){return{apply:e=>+e,invert:e=>new Date(e),sqlApply:e=>e instanceof Date?+e:_S(jt(e)),sqlInvert:q0}}var LV={linear:EV,log:NV,symlog:DV,sqrt:OV,pow:BV,time:jB,utc:jB};function tp(e){let t=LV[e.type];return t?{...e,...t(e)}:null}function bo(e,t,{replace:n=!1,temp:r=!0,view:i=!1}={}){return"CREATE"+(n?" OR REPLACE ":" ")+(r?"TEMP ":"")+(i?"VIEW":"TABLE")+(n?" ":" IF NOT EXISTS ")+e+" AS "+t}function ep(e){return`INSTALL ${e}; LOAD ${e}`}function VB(e,{columns:t=Object.keys(e?.[0]||{})}={}){let n=[];if(Array.isArray(t)?(n=t,t=n.reduce((i,o)=>(i[o]=o,i),{})):t&&(n=Object.keys(t)),!n.length)throw new Error("Can not create table from empty column set.");let r=[];for(let i of e){let o=n.map(s=>`${xo(i[s])} AS "${t[s]}"`);r.push(`(SELECT ${o.join(", ")})`)}return r.join(" UNION ALL ")}function j0(e,t,n,r={},i={}){let{select:o=["*"],where:s,view:a,temp:c,replace:l,...u}=r,f=CV({...i,...u}),h=`${e}('${n}'${f?", "+f:""})`,d=s?` WHERE ${s}`:"",p=`SELECT ${o.join(", ")} FROM ${h}${d}`;return bo(t,p,{view:a,temp:c,replace:l})}function DS(e,t,n){return j0("read_csv",e,t,n,{auto_detect:!0,sample_size:-1})}function OS(e,t,n){return j0("read_json",e,t,n,{auto_detect:!0,json_format:"auto"})}function BS(e,t,n){return j0("read_parquet",e,t,n)}function LS(e,t,n={}){let{options:r,...i}=n;if(r){let o=Array.isArray(r)?r.join(", "):typeof r=="string"?r:Object.entries(r).map(([s,a])=>`${s}=${a}`).join(", ");Object.assign(i,{open_options:o.toUpperCase()})}return j0("st_read",e,t,i)}function CS(e,t,n={}){let{select:r=["*"],...i}=n,o=VB(t),s=r.length===1&&r[0]==="*"?o:`SELECT ${r} FROM ${o}`;return bo(e,s,i)}function CV(e){return Object.entries(e).map(([t,n])=>`${t}=${NS(n)}`).join(", ")}function NS(e){switch(typeof e){case"boolean":return String(e);case"string":return`'${e}'`;case"undefined":case"object":return e==null?"NULL":Array.isArray(e)?"["+e.map(t=>NS(t)).join(", ")+"]":"{"+Object.entries(e).map(([t,n])=>`'${t}': ${NS(n)}`).join(", ")+"}";default:return e}}function XB(e){let t=2166136261;for(let n=0,r=e.length;n<r;++n){let i=e.charCodeAt(n),o=i&65280;o&&(t=YB(t^o>>8)),t=YB(t^i&255)}return kV(t)}function YB(e){return e+(e<<1)+(e<<4)+(e<<7)+(e<<8)+(e<<24)}function kV(e){return e+=e<<13,e^=e>>>7,e+=e<<3,e^=e>>>17,e+=e<<5,e&4294967295}var V0=class{constructor(t,{selection:n,temp:r=!0}){this.mc=t,this.selection=n,this.temp=r,this.reset()}reset(){this.enabled=!1,this.clients=null,this.indices=null,this.activeView=null}clear(){this.indices&&(this.mc.cancel(Array.from(this.indices.values(),t=>t.result)),this.indices=null)}index(t,n){if(this.clients!==t){let l=Array.from(t,WB),u=l[0]?.from;this.enabled=l.every(f=>f&&f.from===u),this.clients=t,this.activeView=null,this.clear()}if(!this.enabled)return!1;n=n||this.selection.active;let{source:r}=n;if(r&&r===this.activeView?.source)return!0;if(this.clear(),!r)return!1;let i=this.activeView=FV(n);if(!i)return!1;this.mc.logger().warn("DATA CUBE INDEX CONSTRUCTION");let o=this.selection.remove(r),s=this.indices=new Map,{mc:a,temp:c}=this;for(let l of t){if(o.skip(l,n))continue;let u=WB(l),f=l.query(o.predicate(l)).select({...i.columns,...u.aux}).groupby(Object.keys(i.columns)),[h]=f.subqueries;if(h){let x=Object.values(i.columns).map(b=>b.columns[0]);$V(h,x)}let d=f.orderby();f.query.orderby=[];let p=f.toString(),y=`cube_index_${(XB(p)>>>0).toString(16)}`,g=a.exec(bo(y,p,{temp:c}));s.set(l,{table:y,result:g,order:d,...u})}return!0}async update(){let{clients:t,selection:n,activeView:r}=this,i=r.predicate(n.active.predicate);return Promise.all(Array.from(t).map(o=>this.updateClient(o,i)))}async updateClient(t,n){let r=this.indices.get(t);if(!r)return;n||(n=this.activeView.predicate(this.selection.active.predicate));let{table:i,dims:o,aggr:s,order:a=[]}=r,c=dt.select(o,s).from(i).groupby(o).where(n).orderby(a);return this.mc.updateClient(t,c)}};function FV(e){let{source:t,schema:n}=e,r=e.predicate?.columns;if(!n||!r)return null;let{type:i,scales:o,pixelSize:s=1}=n,a;if(i==="interval"&&o){let c=o.map(l=>RV(l,s));if(c.some(l=>l==null))return null;c.length===1?(a=l=>l?Ae("active0",l.range.map(c[0])):[],r={active0:c[0](e.predicate.field)}):(a=l=>l?Hn(l.children.map(({range:u},f)=>Ae(`active${f}`,u.map(c[f])))):[],r=Object.fromEntries(e.predicate.children.map((l,u)=>[`active${u}`,c[u](l.field)])))}else if(i==="point")a=c=>c,r=Object.fromEntries(r.map(c=>[c.toString(),c]));else return null;return{source:t,columns:r,predicate:a}}function RV(e,t){let{apply:n,sqlApply:r}=tp(e);if(n){let{domain:i,range:o}=e,s=n(Math.min(...i)),a=n(Math.max(...i)),c=Math.abs(o[1]-o[0])/(a-s)/t,l=t===1?"":`${t}::INTEGER * `;return u=>q`${l}FLOOR(${c}::DOUBLE * (${r(u)} - ${s}::DOUBLE))::INTEGER`}}var GB={from:NaN};function WB(e){if(!e.filterIndexable)return GB;let t=e.query(),n=kS(t);if(!n||!t.groupby)return GB;let r=new Set(t.groupby().map(c=>c.column)),i=[],o=[],s={},a;for(let c of t.select()){let{as:l,expr:{aggregate:u,args:f}}=c,h=u?.toUpperCase?.();switch(h){case"COUNT":case"SUM":i.push({[l]:q`SUM("${l}")::DOUBLE`});break;case"AVG":s[a="__count__"]=q`COUNT(*)`,i.push({[l]:q`(SUM("${l}" * ${a}) / SUM(${a}))::DOUBLE`});break;case"ARG_MAX":s[a=`__max_${l}__`]=q`MAX(${f[1]})`,i.push({[l]:q`ARG_MAX("${l}", ${a})`});break;case"ARG_MIN":s[a=`__min_${l}__`]=q`MIN(${f[1]})`,i.push({[l]:q`ARG_MIN("${l}", ${a})`});break;case"MAX":case"MIN":case"BIT_AND":case"BIT_OR":case"BIT_XOR":case"BOOL_AND":case"BOOL_OR":case"PRODUCT":i.push({[l]:q`${h}("${l}")`});break;default:if(r.has(l))o.push(l);else return null}}return{aggr:i,dims:o,aux:s,from:n}}function kS(e){let t=e.subqueries;if(e.select){let r=e.from();if(!r.length)return;if(t.length===0)return r[0].from.table}let n=kS(t[0]);for(let r=1;r<t.length;++r){let i=kS(t[r]);if(i!==void 0&&i!==n)return NaN}return n}function $V(e,t){let n=new Set,r=i=>{n.has(i)||(n.add(i),i.select&&i.from().length&&i.select(t),i.subqueries.forEach(r))};r(e)}var Y0=class{constructor(t,n,r=!0){this.mc=t,this.selection=n,this.clients=new Set,this.indexer=r?new V0(this.mc,{...r,selection:n}):null;let{value:i,activate:o}=this.handlers={value:()=>this.update(),activate:s=>this.indexer?.index(this.clients,s)};n.addEventListener("value",i),n.addEventListener("activate",o)}finalize(){let{value:t,activate:n}=this.handlers;this.selection.removeEventListener("value",t),this.selection.removeEventListener("activate",n)}reset(){this.indexer?.reset()}add(t){return(this.clients=new Set(this.clients)).add(t),this}remove(t){return this.clients.has(t)&&(this.clients=new Set(this.clients)).delete(t),this}update(){let{mc:t,indexer:n,clients:r,selection:i}=this;return n?.index(r)?n.update():PV(t,r,i)}};function PV(e,t,n){return Promise.all(Array.from(t).map(r=>{let i=n.predicate(r);if(i!=null)return e.updateClient(r,r.query(i))}))}function X0(){let e,t,n=new Promise((r,i)=>{e=r,t=i});return Object.assign(n,{fulfill:r=>(e(r),n),reject:r=>(t(r),n)})}function UV(e){return(typeof requestAnimationFrame<"u"?requestAnimationFrame:typeof setImmediate<"u"?setImmediate:setTimeout)(e)}function HB(e,t,n){let r=[],i=0;function o(){let s=zV(r,t);r=[],i=0;for(let a of s)jV(a,e,n),XV(a,t)}return{add(s,a){s.request.type==="arrow"?(i=i||UV(()=>o()),r.push({entry:s,priority:a,index:r.length})):e(s,a)}}}function zV(e,t){let n=[],r=new Map;for(let i of e){let{entry:{request:o}}=i,s=qV(o.query,t);if(!r.has(s)){let a=[];n.push(a),r.set(s,a)}r.get(s).push(i)}return n}function qV(e,t){let n=`${e}`;if(e instanceof dt&&!t.get(n)){if(e.orderby().length||e.where().length||e.qualify().length||e.having().length)return n;let r=e.clone().$select("*"),i=e.groupby();if(i.length){let o={};e.select().forEach(({as:s,expr:a})=>o[s]=a),r.$groupby(i.map(s=>s instanceof br&&o[s.column]||s))}return`${r}`}else return n}function jV(e,t,n){if(VV(e))t({request:{type:"arrow",cache:!1,record:!1,query:e.query=YV(e,n)},result:e.result=X0()});else for(let{entry:r,priority:i}of e)t(r,i)}function VV(e){if(e.length>1){let t=`${e[0].entry.request.query}`;for(let n=1;n<e.length;++n)if(t!==`${e[n].entry.request.query}`)return!0}return!1}function YV(e,t){let n=e.maps=[],r=new Map;for(let s of e){let{query:a}=s.entry.request,c=[];n.push(c);for(let{as:l,expr:u}of a.select()){let f=`${u}`;r.has(f)||r.set(f,[`col${r.size}`,u]);let[h]=r.get(f);c.push([h,l])}t(`${a}`)}let i=e[0].entry.request.query.clone(),o=i.groupby();if(o.length){let s={};e.maps[0].forEach(([a,c])=>s[c]=a),i.$groupby(o.map(a=>a instanceof br&&s[a.column]||a))}return i.$select(Array.from(r.values()))}async function XV(e,t){let{maps:n,query:r,result:i}=e;if(!n)return;let o;try{o=await i}catch(a){for(let{entry:c}of e)c.result.reject(a);return}let s=ES(r);e.forEach(({entry:a},c)=>{let{request:l,result:u}=a,f=n[c],h=s&&f?WV(o,f):f?GV(o,f):o;l.cache&&t.set(String(l.query),h),u.fulfill(h)})}function GV(e,t){let n={};for(let[r,i]of t)n[i]=e.getChild(r);return new e.constructor(n)}function WV(e,t){let n=new Map(t),r=[];for(let i of e)n.has(i.column_name)&&r.push({...i,column_name:n.get(i.column_name)});return r}var HV=typeof requestIdleCallback<"u"?requestIdleCallback:setTimeout,ZB=()=>({get:()=>{},set:(e,t)=>t,clear:()=>{}});function JB({max:e=1e3,ttl:t=3*60*60*1e3}={}){let n=new Map;function r(){let i=performance.now()-t,o=null,s=1/0;for(let[a,c]of n){let{last:l}=c;l<s&&(o=a,s=l),i>l&&n.delete(a)}o&&n.delete(o)}return{get(i){let o=n.get(i);if(o)return o.last=performance.now(),o.value},set(i,o){return n.set(i,{last:performance.now(),value:o}),n.size>e&&HV(r),o},clear(){n=new Map}}}function QB(e){let t=Array.from({length:e},()=>({head:null,tail:null}));return{isEmpty(){return t.every(n=>!n.head)},insert(n,r){let i=t[r];if(!i)throw new Error(`Invalid queue priority rank: ${r}`);let o={item:n,next:null};i.head===null?i.head=i.tail=o:i.tail=i.tail.next=o},remove(n){for(let r of t){let{head:i,tail:o}=r;for(let s=null,a=i;a;s=a,a=a.next)n(a.item)&&(a===i?i=a.next:s.next=a.next,a===o&&(o=s||i));r.head=i,r.tail=o}},next(){for(let n of t){let{head:r}=n;if(r!==null)return n.head=r.next,n.tail===r&&(n.tail=null),r.item}}}}var wo={High:0,Normal:1,Low:2};function KB(){let e=QB(3),t,n,r,i=[],o=null,s;function a(){if(o||e.isEmpty())return;let{request:f,result:h}=e.next();o=u(f,h),o.finally(()=>{o=null,a()})}function c(f,h=wo.Normal){e.insert(f,h),a()}function l(f){i.length&&f&&i.forEach(h=>h.add(f))}async function u(f,h){try{let{query:d,type:p,cache:m=!1,record:y=!0,options:g}=f,x=d?`${d}`:null;if(y&&l(x),m){let _=n.get(x);if(_){r.debug("Cache"),h.fulfill(_);return}}let b=performance.now(),w=await t.query({type:p,sql:x,...g});m&&n.set(x,w),r.debug(`Request: ${(performance.now()-b).toFixed(1)}`),h.fulfill(w)}catch(d){h.reject(d)}}return{cache(f){return f!==void 0?n=f===!0?JB():f||ZB():n},logger(f){return f?r=f:r},connector(f){return f?t=f:t},consolidate(f){f&&!s?s=HB(c,n,l):!f&&s&&(s=null)},request(f,h=wo.Normal){let d=X0(),p={request:f,result:d};return s?s.add(p,h):c(p,h),d},cancel(f){let h=new Set(f);e.remove(({result:d})=>h.has(d))},clear(){e.remove(({result:f})=>(f.reject("Cleared"),!0))},record(){let f=[],h={add(d){f.push(d)},reset(){f=[]},snapshot(){return f.slice()},stop(){return i=i.filter(d=>d!==h),f}};return i.push(h),h}}}function FS(e){switch(e){case"BIGINT":case"HUGEINT":case"INTEGER":case"SMALLINT":case"TINYINT":case"UBIGINT":case"UINTEGER":case"USMALLINT":case"UTINYINT":case"DOUBLE":case"FLOAT":case"REAL":return"number";case"DATE":case"TIMESTAMP":case"TIMESTAMPTZ":case"TIMESTAMP WITH TIME ZONE":case"TIME":case"TIMESTAMP_NS":return"date";case"BOOLEAN":return"boolean";case"VARCHAR":case"UUID":case"JSON":return"string";case"ARRAY":case"LIST":return"array";case"BLOB":case"STRUCT":case"MAP":case"GEOMETRY":return"object";default:if(e.startsWith("DECIMAL"))return"number";if(e.startsWith("STRUCT")||e.startsWith("MAP"))return"object";if(e.endsWith("]"))return"array";throw new Error(`Unsupported type: ${e}`)}}function np(e){return typeof e?.getChild=="function"}function RS(e){if(H.isTimestamp(e))return t=>t==null?t:new Date(t);if(H.isInt(e)&&e.bitWidth>=64)return t=>t==null?t:Number(t);if(H.isDecimal(e)){let t=1/Math.pow(10,e.scale);return n=>n==null?n:eL(n,t)}return t=>t}function $S(e){let{type:t}=e;if(H.isTimestamp(t)){let n=e.length,r=new Array(n);for(let i=0;i<n;++i){let o=e.get(i);r[i]=o==null?null:new Date(o)}return r}if(H.isInt(t)&&t.bitWidth>=64){let n=e.length,r=new Float64Array(n);for(let i=0;i<n;++i){let o=e.get(i);r[i]=o==null?NaN:Number(o)}return r}if(H.isDecimal(t)){let n=1/Math.pow(10,t.scale),r=e.length,i=new Float64Array(r);for(let o=0;o<r;++o){let s=e.get(o);i[o]=s==null?NaN:eL(s,n)}return i}return e.toArray()}var tL=Array.from({length:8},(e,t)=>Math.pow(2,t*32));function eL(e,t){let n=e.length,r=0;if(e.signed&&(e[n-1]|0)<0){for(let i=0;i<n;++i)r+=~e[i]*tL[i];r=-(r+1)}else for(let i=0;i<n;++i)r+=e[i]*tL[i];return r*t}var ZV="count",JV="nulls",QV="max",KV="min",tY="distinct";var eY={[ZV]:kr,[tY]:e=>kr(e).distinct(),[QV]:oi,[KV]:si,[JV]:e=>kr().where(zc(e))};function nY(e,t,n){return dt.from(e).select(Array.from(n,r=>[r,eY[r](t)]))}async function nL(e,t){return t.length===1&&`${t[0].column}`=="*"?iY(e,t[0].table):(await Promise.all(t.map(n=>rY(e,n)))).filter(n=>n)}async function rY(e,{table:t,column:n,stats:r}){let i=dt.from({source:t}).select({column:n}).groupby(n.aggregate?q`ALL`:[]),[o]=Array.from(await e.query(dt.describe(i))),s={table:t,column:`${n}`,sqlType:o.column_type,type:FS(o.column_type),nullable:o.null==="YES"};if(!(r?.length||r?.size))return s;let a=await e.query(nY(t,n,r),{persist:!0});for(let c=0;c<a.numCols;++c){let{name:l}=a.schema.fields[c],u=a.getChildAt(c),f=RS(u.type);s[l]=f(u.get(0))}return s}async function iY(e,t){let n=await e.query(`DESCRIBE ${Pc(t)}`);return Array.from(n).map(r=>({table:t,column:r.column_name,sqlType:r.column_type,type:FS(r.column_type),nullable:r.null==="YES"}))}function rL(){return{debug(){},info(){},log(){},warn(){},error(){}}}var G0;function ai(e){return e?G0=e:G0==null&&(G0=new rp),G0}var rp=class{constructor(t=P0(),n={}){let{logger:r=console,manager:i=KB()}=n;this.manager=i,this.logger(r),this.configure(n),this.databaseConnector(t),this.clear()}logger(t){return arguments.length&&(this._logger=t||rL(),this.manager.logger(this._logger)),this._logger}configure({cache:t=!0,consolidate:n=!0,indexes:r=!0}={}){this.manager.cache(t),this.manager.consolidate(n),this.indexes=r}clear({clients:t=!0,cache:n=!0}={}){this.manager.clear(),t&&(this.clients?.forEach(r=>this.disconnect(r)),this.filterGroups?.forEach(r=>r.finalize()),this.clients=new Set,this.filterGroups=new Map),n&&this.manager.cache().clear()}databaseConnector(t){return this.manager.connector(t)}cancel(t){this.manager.cancel(t)}exec(t,{priority:n=wo.Normal}={}){return t=Array.isArray(t)?t.join(`;
|
|
11
|
+
`):t,this.manager.request({type:"exec",query:t},n)}query(t,{type:n="arrow",cache:r=!0,priority:i=wo.Normal,...o}={}){return this.manager.request({type:n,query:t,cache:r,options:o},i)}prefetch(t,n={}){return this.query(t,{...n,cache:!0,priority:wo.Low})}createBundle(t,n,r=wo.Low){let i={name:t,queries:n};return this.manager.request({type:"create-bundle",options:i},r)}loadBundle(t,n=wo.High){let r={name:t};return this.manager.request({type:"load-bundle",options:r},n)}updateClient(t,n,r=wo.Normal){return t.queryPending(),this.query(n,{priority:r}).then(i=>t.queryResult(i).update(),i=>{t.queryError(i),this._logger.error(i)})}requestQuery(t,n){return this.filterGroups.get(t.filterBy)?.reset(),n?this.updateClient(t,n):t.update()}async connect(t){let{clients:n,filterGroups:r,indexes:i}=this;if(n.has(t))throw new Error("Client already connected.");n.add(t),t.coordinator=this;let o=t.fields();o?.length&&t.fieldInfo(await nL(this,o));let s=t.filterBy;if(s)if(r.has(s))r.get(s).add(t);else{let a=new Y0(this,s,i);r.set(s,a.add(t))}t.requestQuery()}disconnect(t){let{clients:n,filterGroups:r}=this;n.has(t)&&(n.delete(t),r.get(t.filterBy)?.remove(t),t.coordinator=null)}};var W0=class{constructor(){this._callbacks=new Map}addEventListener(t,n){this._callbacks.has(t)||this._callbacks.set(t,{callbacks:new Set,pending:null,queue:new PS}),this._callbacks.get(t).callbacks.add(n)}removeEventListener(t,n){let r=this._callbacks.get(t);r&&r.callbacks.delete(n)}willEmit(t,n){return n}emitQueueFilter(t,n){return null}cancel(t){this._callbacks.get(t)?.queue.clear()}emit(t,n){let r=this._callbacks.get(t)||{};if(r.pending)r.queue.enqueue(n,this.emitQueueFilter(t,n));else{let i=this.willEmit(t,n),{callbacks:o,queue:s}=r;if(o?.size){let a=Array.from(o,c=>c(i));r.pending=Promise.allSettled(a).then(()=>{r.pending=null,s.isEmpty()||this.emit(t,s.dequeue())})}}}},PS=class{constructor(){this.clear()}clear(){this.next=null}isEmpty(){return!this.next}enqueue(t,n){let r={value:t};if(n&&this.next){let i=this;for(;i.next;)n(i.next.value)?i=i.next:i.next=i.next.next;i.next=r}else this.next=r}dequeue(){let{next:t}=this;return this.next=t?.next,t?.value}};function ip(e,t){return e===t?!1:e instanceof Date&&t instanceof Date?+e!=+t:Array.isArray(e)&&Array.isArray(t)?oY(e,t):!0}function oY(e,t){if(e.length!==t.length)return!0;for(let n=0;n<e.length;++n)if(e[n]!==t[n])return!0;return!1}function wr(e){return e instanceof Aa}var Aa=class e extends W0{constructor(t){super(),this._value=t}static value(t){return new e(t)}static array(t){if(t.some(n=>wr(n))){let n=new e,r=()=>{n.update(t.map(i=>wr(i)?i.value:i))};return r(),t.forEach(i=>wr(i)?i.addEventListener("value",r):0),n}return new e(t)}get value(){return this._value}update(t,{force:n}={}){return ip(this._value,t)||n?this.emit("value",t):this.cancel("value"),this}willEmit(t,n){return t==="value"&&(this._value=n),n}};function ci(e){return e instanceof Ss}var Ss=class e extends Aa{static intersect({cross:t=!1}={}){return new e(new Yc({cross:t}))}static union({cross:t=!1}={}){return new e(new Yc({cross:t,union:!0}))}static single({cross:t=!1}={}){return new e(new Yc({cross:t,single:!0}))}static crossfilter(){return new e(new Yc({cross:!0}))}constructor(t=new Yc){super([]),this._resolved=this._value,this._resolver=t}clone(){let t=new e(this._resolver);return t._value=t._resolved=this._value,t}remove(t){let n=this.clone();return n._value=n._resolved=n._resolver.resolve(this._resolved,{source:t}),n._value.active={source:t},n}get active(){return this.clauses.active}get value(){return this.active?.value}get clauses(){return super.value}get single(){return this._resolver.single}activate(t){this.emit("activate",t)}update(t){return this._resolved=this._resolver.resolve(this._resolved,t,!0),this._resolved.active=t,super.update(this._resolved)}willEmit(t,n){return t==="value"?(this._value=n,this.value):n}emitQueueFilter(t,n){return t==="value"?this._resolver.queueFilter(n):null}skip(t,n){return this._resolver.skip(t,n)}predicate(t,n=!1){let{clauses:r}=this,i=n?null:r.active;return this._resolver.predicate(r,i,t)}},Yc=class{constructor({union:t,cross:n,single:r}={}){this.union=!!t,this.cross=!!n,this.single=!!r}resolve(t,n,r=!1){let{source:i,predicate:o}=n,s=t.filter(c=>i!==c.source),a=this.single?[]:s;return this.single&&r&&s.forEach(c=>c.source?.reset?.()),o&&a.push(n),a}skip(t,n){return this.cross&&n?.clients?.has(t)}predicate(t,n,r){let{union:i}=this;if(this.skip(r,n))return;let o=t.filter(s=>!this.skip(r,s)).map(s=>s.predicate);return i&&o.length>1?Uc(o):o}queueFilter(t){if(this.cross){let n=t.active?.source;return r=>r.active?.source!==n}return null}};function US(){let e=new Set,t,n=new Promise(r=>t=r);return{pending(r){e.add(r)},ready(r){return e.delete(r),e.size===0},resolve(){n=new Promise(r=>{t(),t=r})},get promise(){return n}}}var MD={};Mr(MD,{Fixed:()=>vo,Param:()=>Aa,Query:()=>dt,Selection:()=>Ss,agg:()=>H2,align:()=>d6,and:()=>Hn,area:()=>K8,areaX:()=>tN,areaY:()=>eN,argmax:()=>Iu,argmin:()=>Su,arrayAgg:()=>wS,arrow:()=>XN,aspectRatio:()=>p6,avg:()=>Z2,axis:()=>m6,axisFx:()=>JN,axisFy:()=>QN,axisX:()=>HN,axisY:()=>ZN,barX:()=>oN,barY:()=>sN,bin:()=>zv,cast:()=>Zd,castDouble:()=>Mu,castInteger:()=>vS,cell:()=>aN,cellX:()=>cN,cellY:()=>lN,centroid:()=>Qd,centroidX:()=>AS,centroidY:()=>TS,circle:()=>yN,colorBase:()=>n8,colorClamp:()=>VE,colorConstant:()=>i8,colorDomain:()=>qE,colorExponent:()=>r8,colorInterpolate:()=>WE,colorLabel:()=>JE,colorLegend:()=>_D,colorN:()=>YE,colorNice:()=>XE,colorPercent:()=>QE,colorPivot:()=>HE,colorRange:()=>jE,colorReverse:()=>KE,colorScale:()=>zE,colorScheme:()=>GE,colorSymmetric:()=>ZE,colorTickFormat:()=>e8,colorZero:()=>t8,column:()=>Sa,contour:()=>CN,coordinator:()=>ai,corr:()=>lS,count:()=>kr,covarPop:()=>uS,create:()=>bo,cume_dist:()=>z2,dateDay:()=>MS,dateMonth:()=>SS,dateMonthDay:()=>IS,delaunayLink:()=>jN,delaunayMesh:()=>VN,denseLine:()=>LN,dense_rank:()=>P2,density:()=>BN,densityX:()=>DN,densityY:()=>ON,dot:()=>dN,dotX:()=>pN,dotY:()=>mN,entropy:()=>sS,eq:()=>ws,facetGrid:()=>z4,facetLabel:()=>q4,facetMargin:()=>F4,facetMarginBottom:()=>$4,facetMarginLeft:()=>P4,facetMarginRight:()=>U4,facetMarginTop:()=>R4,first:()=>gS,first_value:()=>Y2,frame:()=>WN,from:()=>TU,fxAlign:()=>H4,fxAriaDescription:()=>dE,fxAriaLabel:()=>hE,fxAxis:()=>K4,fxDomain:()=>j4,fxFontVariant:()=>fE,fxGrid:()=>sE,fxInset:()=>Y4,fxInsetLeft:()=>X4,fxInsetRight:()=>G4,fxLabel:()=>cE,fxLabelAnchor:()=>lE,fxLabelOffset:()=>uE,fxLine:()=>aE,fxPadding:()=>Z4,fxPaddingInner:()=>J4,fxPaddingOuter:()=>Q4,fxRange:()=>V4,fxReverse:()=>pE,fxRound:()=>W4,fxTickFormat:()=>iE,fxTickPadding:()=>rE,fxTickRotate:()=>oE,fxTickSize:()=>eE,fxTickSpacing:()=>nE,fxTicks:()=>tE,fyAlign:()=>vE,fyAriaDescription:()=>PE,fyAriaLabel:()=>$E,fyAxis:()=>ME,fyDomain:()=>mE,fyFontVariant:()=>RE,fyGrid:()=>BE,fyInset:()=>gE,fyInsetBottom:()=>bE,fyInsetTop:()=>xE,fyLabel:()=>CE,fyLabelAnchor:()=>kE,fyLabelOffset:()=>FE,fyLine:()=>LE,fyPadding:()=>_E,fyPaddingInner:()=>SE,fyPaddingOuter:()=>IE,fyRange:()=>yE,fyReverse:()=>UE,fyRound:()=>wE,fyTickFormat:()=>DE,fyTickPadding:()=>NE,fyTickRotate:()=>OE,fyTickSize:()=>TE,fyTickSpacing:()=>EE,fyTicks:()=>AE,geo:()=>rD,geojson:()=>Jd,graticule:()=>oD,grid:()=>g6,gridFx:()=>eD,gridFy:()=>nD,gridX:()=>KN,gridY:()=>tD,gt:()=>Gd,gte:()=>D2,hconcat:()=>vU,heatmap:()=>kN,height:()=>c6,hexagon:()=>gN,hexbin:()=>$N,hexgrid:()=>PN,highlight:()=>sD,hspace:()=>IU,hull:()=>YN,image:()=>NN,inset:()=>y6,intervalX:()=>hD,intervalXY:()=>pD,intervalY:()=>dD,isBetween:()=>Ae,isDistinct:()=>O2,isNotBetween:()=>B2,isNotDistinct:()=>Wd,isNotNull:()=>bs,isNull:()=>zc,kurtosis:()=>oS,label:()=>x6,lag:()=>j2,last:()=>xS,last_value:()=>X2,lead:()=>V2,lengthBase:()=>$8,lengthClamp:()=>C8,lengthConstant:()=>U8,lengthDomain:()=>B8,lengthExponent:()=>P8,lengthNice:()=>k8,lengthPercent:()=>F8,lengthRange:()=>L8,lengthScale:()=>O8,lengthZero:()=>R8,line:()=>nN,lineX:()=>rN,lineY:()=>iN,link:()=>GN,literal:()=>Cr,loadCSV:()=>DS,loadExtension:()=>ep,loadJSON:()=>OS,loadObjects:()=>CS,loadParquet:()=>BS,loadSpatial:()=>LS,lt:()=>vs,lte:()=>_s,mad:()=>J2,margin:()=>i6,marginBottom:()=>h6,marginLeft:()=>l6,marginRight:()=>u6,marginTop:()=>f6,margins:()=>r6,max:()=>oi,median:()=>K2,menu:()=>mU,min:()=>si,mode:()=>eS,name:()=>e6,nearestX:()=>uD,nearestY:()=>fD,neq:()=>qc,not:()=>N2,nth_value:()=>G2,ntile:()=>q2,opacityBase:()=>m8,opacityClamp:()=>c8,opacityConstant:()=>g8,opacityDomain:()=>s8,opacityExponent:()=>y8,opacityLabel:()=>u8,opacityLegend:()=>SD,opacityNice:()=>l8,opacityPercent:()=>f8,opacityRange:()=>a8,opacityReverse:()=>h8,opacityScale:()=>o8,opacityTickFormat:()=>p8,opacityZero:()=>d8,or:()=>Uc,padding:()=>b6,pan:()=>mD,panX:()=>yD,panY:()=>gD,panZoom:()=>xD,panZoomX:()=>bD,panZoomY:()=>wD,percent_rank:()=>U2,plot:()=>EU,product:()=>Q2,projectionClip:()=>J8,projectionDomain:()=>Y8,projectionInset:()=>X8,projectionInsetBottom:()=>Z8,projectionInsetLeft:()=>G8,projectionInsetRight:()=>W8,projectionInsetTop:()=>H8,projectionParallels:()=>q8,projectionPrecision:()=>j8,projectionRotate:()=>V8,projectionType:()=>z8,quantile:()=>tS,rBase:()=>E8,rClamp:()=>I8,rConstant:()=>D8,rDomain:()=>_8,rExponent:()=>N8,rNice:()=>M8,rPercent:()=>A8,rRange:()=>S8,rScale:()=>v8,rZero:()=>T8,rank:()=>$2,raster:()=>FN,rasterTile:()=>RN,rect:()=>uN,rectX:()=>fN,rectY:()=>hN,regressionY:()=>UN,row_number:()=>R2,ruleX:()=>vN,ruleY:()=>_N,search:()=>yU,skewness:()=>iS,slider:()=>gU,sphere:()=>iD,spike:()=>EN,sql:()=>q,stddev:()=>rS,stddevPop:()=>cS,stringAgg:()=>bS,style:()=>s6,sum:()=>Fr,symbolDomain:()=>b8,symbolLegend:()=>ID,symbolRange:()=>w8,symbolScale:()=>x8,table:()=>xU,text:()=>xN,textX:()=>bN,textY:()=>wN,tickX:()=>SN,tickY:()=>IN,toggle:()=>_h,toggleColor:()=>lD,toggleX:()=>aD,toggleY:()=>cD,varPop:()=>aS,variance:()=>nS,vconcat:()=>wU,vector:()=>MN,vectorX:()=>AN,vectorY:()=>TN,voronoi:()=>zN,voronoiMesh:()=>qN,vspace:()=>SU,width:()=>a6,xAlign:()=>N6,xAriaDescription:()=>W6,xAriaLabel:()=>G6,xAxis:()=>L6,xBase:()=>Q6,xClamp:()=>T6,xConstant:()=>t4,xDomain:()=>v6,xExponent:()=>K6,xFontVariant:()=>X6,xGrid:()=>U6,xInset:()=>I6,xInsetLeft:()=>M6,xInsetRight:()=>A6,xLabel:()=>q6,xLabelAnchor:()=>j6,xLabelArrow:()=>V6,xLabelOffset:()=>Y6,xLine:()=>z6,xNice:()=>S6,xPadding:()=>D6,xPaddingInner:()=>O6,xPaddingOuter:()=>B6,xPercent:()=>H6,xRange:()=>_6,xReverse:()=>Z6,xRound:()=>E6,xScale:()=>w6,xTickFormat:()=>$6,xTickPadding:()=>R6,xTickRotate:()=>P6,xTickSize:()=>k6,xTickSpacing:()=>F6,xTicks:()=>C6,xZero:()=>J6,xyDomain:()=>o6,yAlign:()=>u4,yAriaDescription:()=>N4,yAriaLabel:()=>E4,yAxis:()=>p4,yBase:()=>L4,yClamp:()=>c4,yConstant:()=>k4,yDomain:()=>n4,yExponent:()=>C4,yFontVariant:()=>T4,yGrid:()=>v4,yInset:()=>o4,yInsetBottom:()=>a4,yInsetTop:()=>s4,yLabel:()=>S4,yLabelAnchor:()=>I4,yLabelArrow:()=>M4,yLabelOffset:()=>A4,yLine:()=>_4,yNice:()=>i4,yPadding:()=>f4,yPaddingInner:()=>h4,yPaddingOuter:()=>d4,yPercent:()=>D4,yRange:()=>r4,yReverse:()=>O4,yRound:()=>l4,yScale:()=>e4,yTickFormat:()=>b4,yTickPadding:()=>x4,yTickRotate:()=>w4,yTickSize:()=>y4,yTickSpacing:()=>g4,yTicks:()=>m4,yZero:()=>B4});var vo=Symbol("Fixed"),In=Symbol("Transient"),op=Symbol("Transform");var zy={};Mr(zy,{Area:()=>Rl,Arrow:()=>gy,BarX:()=>xy,BarY:()=>by,Cell:()=>$l,Contour:()=>Oy,Density:()=>Cy,Dot:()=>Pl,Frame:()=>ly,Geo:()=>ky,Hexgrid:()=>Fy,Image:()=>Ry,Line:()=>Ul,Link:()=>my,Mark:()=>St,Raster:()=>Ty,Rect:()=>ql,RuleX:()=>iy,RuleY:()=>oy,Text:()=>Cl,TickX:()=>Sy,TickY:()=>Iy,Tip:()=>uy,Vector:()=>Fl,area:()=>py,areaX:()=>cc,areaY:()=>oa,arrow:()=>Q$,auto:()=>l9,autoSpec:()=>c3,axisFx:()=>Jw,axisFy:()=>Zw,axisX:()=>ay,axisY:()=>sy,barX:()=>Jo,barY:()=>Qo,bin:()=>ia,binX:()=>Ho,binY:()=>Zo,bollinger:()=>hc,bollingerX:()=>m9,bollingerY:()=>y9,boxX:()=>g9,boxY:()=>x9,cell:()=>lc,cellX:()=>t9,cellY:()=>e9,centroid:()=>pP,circle:()=>i9,cluster:()=>dP,column:()=>yn,contour:()=>T9,crosshair:()=>D9,crosshairX:()=>O9,crosshairY:()=>B9,delaunayLink:()=>k9,delaunayMesh:()=>F9,density:()=>z9,differenceY:()=>V9,dodgeX:()=>EP,dodgeY:()=>NP,dot:()=>_i,dotX:()=>n9,dotY:()=>r9,filter:()=>fR,find:()=>wR,formatIsoDate:()=>DT,formatMonth:()=>v7,formatWeekday:()=>_7,frame:()=>Gf,geo:()=>vv,geoCentroid:()=>mP,graticule:()=>X9,gridFx:()=>ev,gridFy:()=>Kw,gridX:()=>tv,gridY:()=>Qw,group:()=>Zm,groupX:()=>Ka,groupY:()=>tc,groupZ:()=>Hm,hexagon:()=>o9,hexbin:()=>G9,hexgrid:()=>W9,hull:()=>R9,identity:()=>G,image:()=>Z9,indexOf:()=>Ee,initializer:()=>Ie,interpolateNearest:()=>Ny,interpolateNone:()=>wv,interpolatorBarycentric:()=>Ey,interpolatorRandomWalk:()=>Dy,legend:()=>w$,line:()=>zl,lineX:()=>uc,lineY:()=>fc,linearRegressionX:()=>K9,linearRegressionY:()=>tP,link:()=>fv,map:()=>_r,mapX:()=>sh,mapY:()=>ah,marks:()=>tn,normalize:()=>Dv,normalizeX:()=>LP,normalizeY:()=>CP,plot:()=>hy,pointer:()=>qf,pointerX:()=>jf,pointerY:()=>Dl,raster:()=>S9,rect:()=>vy,rectX:()=>rh,rectY:()=>ih,reverse:()=>hR,ruleX:()=>Yr,ruleY:()=>Xr,scale:()=>rc,select:()=>FP,selectFirst:()=>C3,selectLast:()=>k3,selectMaxX:()=>PP,selectMaxY:()=>UP,selectMinX:()=>RP,selectMinY:()=>$P,shiftX:()=>kP,shuffle:()=>dR,sort:()=>mw,sphere:()=>Y9,spike:()=>t$,stackX:()=>o3,stackX1:()=>j$,stackX2:()=>V$,stackY:()=>s3,stackY1:()=>Y$,stackY2:()=>X$,text:()=>Wo,textX:()=>jw,textY:()=>Vw,tickX:()=>gv,tickY:()=>xv,tip:()=>iv,transform:()=>gn,tree:()=>E3,treeLink:()=>Av,treeNode:()=>$y,valueof:()=>wt,vector:()=>WT,vectorX:()=>Gw,vectorY:()=>Ww,voronoi:()=>$9,voronoiMesh:()=>P9,window:()=>ch,windowX:()=>u9,windowY:()=>f9});function zt(e,t){return e==null||t==null?NaN:e<t?-1:e>t?1:e>=t?0:NaN}function Zn(e,t){return e==null||t==null?NaN:t<e?-1:t>e?1:t>=e?0:NaN}function Is(e){let t,n,r;e.length!==2?(t=zt,n=(a,c)=>zt(e(a),c),r=(a,c)=>e(a)-c):(t=e===zt||e===Zn?e:cY,n=e,r=e);function i(a,c,l=0,u=a.length){if(l<u){if(t(c,c)!==0)return u;do{let f=l+u>>>1;n(a[f],c)<0?l=f+1:u=f}while(l<u)}return l}function o(a,c,l=0,u=a.length){if(l<u){if(t(c,c)!==0)return u;do{let f=l+u>>>1;n(a[f],c)<=0?l=f+1:u=f}while(l<u)}return l}function s(a,c,l=0,u=a.length){let f=i(a,c,l,u-1);return f>l&&r(a[f-1],c)>-r(a[f],c)?f-1:f}return{left:i,center:s,right:o}}function cY(){return 0}function sp(e){return e===null?NaN:+e}function*iL(e,t){if(t===void 0)for(let n of e)n!=null&&(n=+n)>=n&&(yield n);else{let n=-1;for(let r of e)(r=t(r,++n,e))!=null&&(r=+r)>=r&&(yield r)}}var oL=Is(zt),sL=oL.right,lY=oL.left,uY=Is(sp).center,Ms=sL;var ap=aL(cL),zS=aL(fY);function aL(e){return function(t,n,r=n){if(!((n=+n)>=0))throw new RangeError("invalid rx");if(!((r=+r)>=0))throw new RangeError("invalid ry");let{data:i,width:o,height:s}=t;if(!((o=Math.floor(o))>=0))throw new RangeError("invalid width");if(!((s=Math.floor(s!==void 0?s:i.length/o))>=0))throw new RangeError("invalid height");if(!o||!s||!n&&!r)return t;let a=n&&e(n),c=r&&e(r),l=i.slice();return a&&c?(Au(a,l,i,o,s),Au(a,i,l,o,s),Au(a,l,i,o,s),Tu(c,i,l,o,s),Tu(c,l,i,o,s),Tu(c,i,l,o,s)):a?(Au(a,i,l,o,s),Au(a,l,i,o,s),Au(a,i,l,o,s)):c&&(Tu(c,i,l,o,s),Tu(c,l,i,o,s),Tu(c,i,l,o,s)),t}}function Au(e,t,n,r,i){for(let o=0,s=r*i;o<s;)e(t,n,o,o+=r,1)}function Tu(e,t,n,r,i){for(let o=0,s=r*i;o<r;++o)e(t,n,o,o+s,r)}function fY(e){let t=cL(e);return(n,r,i,o,s)=>{i<<=2,o<<=2,s<<=2,t(n,r,i+0,o+0,s),t(n,r,i+1,o+1,s),t(n,r,i+2,o+2,s),t(n,r,i+3,o+3,s)}}function cL(e){let t=Math.floor(e);if(t===e)return hY(e);let n=e-t,r=2*e+1;return(i,o,s,a,c)=>{if(!((a-=c)>=s))return;let l=t*o[s],u=c*t,f=u+c;for(let h=s,d=s+u;h<d;h+=c)l+=o[Math.min(a,h)];for(let h=s,d=a;h<=d;h+=c)l+=o[Math.min(a,h+u)],i[h]=(l+n*(o[Math.max(s,h-f)]+o[Math.min(a,h+f)]))/r,l-=o[Math.max(s,h-u)]}}function hY(e){let t=2*e+1;return(n,r,i,o,s)=>{if(!((o-=s)>=i))return;let a=e*r[i],c=s*e;for(let l=i,u=i+c;l<u;l+=s)a+=r[Math.min(o,l)];for(let l=i,u=o;l<=u;l+=s)a+=r[Math.min(o,l+c)],n[l]=a/t,a-=r[Math.max(i,l-c)]}}function _o(e,t){let n=0;if(t===void 0)for(let r of e)r!=null&&(r=+r)>=r&&++n;else{let r=-1;for(let i of e)(i=t(i,++r,e))!=null&&(i=+i)>=i&&++n}return n}function dY(e){return e.length|0}function pY(e){return!(e>0)}function mY(e){return typeof e!="object"||"length"in e?e:Array.from(e)}function yY(e){return t=>e(...t)}function H0(...e){let t=typeof e[e.length-1]=="function"&&yY(e.pop());e=e.map(mY);let n=e.map(dY),r=e.length-1,i=new Array(r+1).fill(0),o=[];if(r<0||n.some(pY))return o;for(;;){o.push(i.map((a,c)=>e[c][a]));let s=r;for(;++i[s]===n[s];){if(s===0)return t?o.map(t):o;i[s--]=0}}}function Z0(e,t){var n=0,r=0;return Float64Array.from(e,t===void 0?i=>n+=+i||0:i=>n+=+t(i,r++,e)||0)}function Ta(e,t){let n=0,r,i=0,o=0;if(t===void 0)for(let s of e)s!=null&&(s=+s)>=s&&(r=s-i,i+=r/++n,o+=r*(s-i));else{let s=-1;for(let a of e)(a=t(a,++s,e))!=null&&(a=+a)>=a&&(r=a-i,i+=r/++n,o+=r*(a-i))}if(n>1)return o/(n-1)}function li(e,t){let n=Ta(e,t);return n&&Math.sqrt(n)}function le(e,t){let n,r;if(t===void 0)for(let i of e)i!=null&&(n===void 0?i>=i&&(n=r=i):(n>i&&(n=i),r<i&&(r=i)));else{let i=-1;for(let o of e)(o=t(o,++i,e))!=null&&(n===void 0?o>=o&&(n=r=o):(n>o&&(n=o),r<o&&(r=o)))}return[n,r]}var Mn=class{constructor(){this._partials=new Float64Array(32),this._n=0}add(t){let n=this._partials,r=0;for(let i=0;i<this._n&&i<32;i++){let o=n[i],s=t+o,a=Math.abs(t)<Math.abs(o)?t-(s-o):o-(s-t);a&&(n[r++]=a),t=s}return n[r]=t,this._n=r+1,this}valueOf(){let t=this._partials,n=this._n,r,i,o,s=0;if(n>0){for(s=t[--n];n>0&&(r=s,i=t[--n],s=r+i,o=i-(s-r),!o););n>0&&(o<0&&t[n-1]<0||o>0&&t[n-1]>0)&&(i=o*2,r=s+i,i==r-s&&(s=r))}return s}};var Jn=class extends Map{constructor(t,n=fL){if(super(),Object.defineProperties(this,{_intern:{value:new Map},_key:{value:n}}),t!=null)for(let[r,i]of t)this.set(r,i)}get(t){return super.get(qS(this,t))}has(t){return super.has(qS(this,t))}set(t,n){return super.set(lL(this,t),n)}delete(t){return super.delete(uL(this,t))}},Qn=class extends Set{constructor(t,n=fL){if(super(),Object.defineProperties(this,{_intern:{value:new Map},_key:{value:n}}),t!=null)for(let r of t)this.add(r)}has(t){return super.has(qS(this,t))}add(t){return super.add(lL(this,t))}delete(t){return super.delete(uL(this,t))}};function qS({_intern:e,_key:t},n){let r=t(n);return e.has(r)?e.get(r):n}function lL({_intern:e,_key:t},n){let r=t(n);return e.has(r)?e.get(r):(e.set(r,n),n)}function uL({_intern:e,_key:t},n){let r=t(n);return e.has(r)&&(n=e.get(r),e.delete(r)),n}function fL(e){return e!==null&&typeof e=="object"?e.valueOf():e}function cp(e){return e}function ln(e,...t){return VS(e,cp,cp,t)}function Pi(e,t,...n){return VS(e,cp,t,n)}function jS(e,t,...n){return VS(e,Array.from,t,n)}function VS(e,t,n,r){return function i(o,s){if(s>=r.length)return n(o);let a=new Jn,c=r[s++],l=-1;for(let u of o){let f=c(u,++l,o),h=a.get(f);h?h.push(u):a.set(f,[u])}for(let[u,f]of a)a.set(u,i(f,s));return t(a)}(e,0)}function YS(e,t){return Array.from(t,n=>e[n])}function As(e,...t){if(typeof e[Symbol.iterator]!="function")throw new TypeError("values is not iterable");e=Array.from(e);let[n]=t;if(n&&n.length!==2||t.length>1){let r=Uint32Array.from(e,(i,o)=>o);return t.length>1?(t=t.map(i=>e.map(i)),r.sort((i,o)=>{for(let s of t){let a=Xc(s[i],s[o]);if(a)return a}})):(n=e.map(n),r.sort((i,o)=>Xc(n[i],n[o]))),YS(e,r)}return e.sort(lp(n))}function lp(e=zt){if(e===zt)return Xc;if(typeof e!="function")throw new TypeError("compare is not a function");return(t,n)=>{let r=e(t,n);return r||r===0?r:(e(n,n)===0)-(e(t,t)===0)}}function Xc(e,t){return(e==null||!(e>=e))-(t==null||!(t>=t))||(e<t?-1:e>t?1:0)}function Eu(e,t,n){return(t.length!==2?As(Pi(e,t,n),([r,i],[o,s])=>zt(i,s)||zt(r,o)):As(ln(e,n),([r,i],[o,s])=>t(i,s)||zt(r,o))).map(([r])=>r)}var gY=Math.sqrt(50),xY=Math.sqrt(10),bY=Math.sqrt(2);function J0(e,t,n){let r=(t-e)/Math.max(0,n),i=Math.floor(Math.log10(r)),o=r/Math.pow(10,i),s=o>=gY?10:o>=xY?5:o>=bY?2:1,a,c,l;return i<0?(l=Math.pow(10,-i)/s,a=Math.round(e*l),c=Math.round(t*l),a/l<e&&++a,c/l>t&&--c,l=-l):(l=Math.pow(10,i)*s,a=Math.round(e/l),c=Math.round(t/l),a*l<e&&++a,c*l>t&&--c),c<a&&.5<=n&&n<2?J0(e,t,n*2):[a,c,l]}function An(e,t,n){if(t=+t,e=+e,n=+n,!(n>0))return[];if(e===t)return[e];let r=t<e,[i,o,s]=r?J0(t,e,n):J0(e,t,n);if(!(o>=i))return[];let a=o-i+1,c=new Array(a);if(r)if(s<0)for(let l=0;l<a;++l)c[l]=(o-l)/-s;else for(let l=0;l<a;++l)c[l]=(o-l)*s;else if(s<0)for(let l=0;l<a;++l)c[l]=(i+l)/-s;else for(let l=0;l<a;++l)c[l]=(i+l)*s;return c}function Ts(e,t,n){return t=+t,e=+e,n=+n,J0(e,t,n)[2]}function Nu(e,t,n){t=+t,e=+e,n=+n;let r=t<e,i=r?Ts(t,e,n):Ts(e,t,n);return(r?-1:1)*(i<0?1/-i:i)}function Du(e,t,n){let r;for(;;){let i=Ts(e,t,n);if(i===r||i===0||!isFinite(i))return[e,t];i>0?(e=Math.floor(e/i)*i,t=Math.ceil(t/i)*i):i<0&&(e=Math.ceil(e*i)/i,t=Math.floor(t*i)/i),r=i}}function Ea(e){return Math.max(1,Math.ceil(Math.log(_o(e))/Math.LN2)+1)}function Ht(e,t){let n;if(t===void 0)for(let r of e)r!=null&&(n<r||n===void 0&&r>=r)&&(n=r);else{let r=-1;for(let i of e)(i=t(i,++r,e))!=null&&(n<i||n===void 0&&i>=i)&&(n=i)}return n}function Q0(e,t){let n,r=-1,i=-1;if(t===void 0)for(let o of e)++i,o!=null&&(n<o||n===void 0&&o>=o)&&(n=o,r=i);else for(let o of e)(o=t(o,++i,e))!=null&&(n<o||n===void 0&&o>=o)&&(n=o,r=i);return r}function ue(e,t){let n;if(t===void 0)for(let r of e)r!=null&&(n>r||n===void 0&&r>=r)&&(n=r);else{let r=-1;for(let i of e)(i=t(i,++r,e))!=null&&(n>i||n===void 0&&i>=i)&&(n=i)}return n}function K0(e,t){let n,r=-1,i=-1;if(t===void 0)for(let o of e)++i,o!=null&&(n>o||n===void 0&&o>=o)&&(n=o,r=i);else for(let o of e)(o=t(o,++i,e))!=null&&(n>o||n===void 0&&o>=o)&&(n=o,r=i);return r}function tx(e,t,n=0,r=1/0,i){if(t=Math.floor(t),n=Math.floor(Math.max(0,n)),r=Math.floor(Math.min(e.length-1,r)),!(n<=t&&t<=r))return e;for(i=i===void 0?Xc:lp(i);r>n;){if(r-n>600){let c=r-n+1,l=t-n+1,u=Math.log(c),f=.5*Math.exp(2*u/3),h=.5*Math.sqrt(u*f*(c-f)/c)*(l-c/2<0?-1:1),d=Math.max(n,Math.floor(t-l*f/c+h)),p=Math.min(r,Math.floor(t+(c-l)*f/c+h));tx(e,t,d,p,i)}let o=e[t],s=n,a=r;for(up(e,n,t),i(e[r],o)>0&&up(e,n,r);s<a;){for(up(e,s,a),++s,--a;i(e[s],o)<0;)++s;for(;i(e[a],o)>0;)--a}i(e[n],o)===0?up(e,n,a):(++a,up(e,a,r)),a<=t&&(n=a+1),t<=a&&(r=a-1)}return e}function up(e,t,n){let r=e[t];e[t]=e[n],e[n]=r}function Gc(e,t=zt){let n,r=!1;if(t.length===1){let i;for(let o of e){let s=t(o);(r?zt(s,i)>0:zt(s,s)===0)&&(n=o,i=s,r=!0)}}else for(let i of e)(r?t(i,n)>0:t(i,i)===0)&&(n=i,r=!0);return n}function Kn(e,t,n){if(e=Float64Array.from(iL(e,n)),!(!(r=e.length)||isNaN(t=+t))){if(t<=0||r<2)return ue(e);if(t>=1)return Ht(e);var r,i=(r-1)*t,o=Math.floor(i),s=Ht(tx(e,o).subarray(0,o+1)),a=ue(e.subarray(o+1));return s+(a-s)*(i-o)}}function XS(e,t,n=sp){if(!(!(r=e.length)||isNaN(t=+t))){if(t<=0||r<2)return+n(e[0],0,e);if(t>=1)return+n(e[r-1],r-1,e);var r,i=(r-1)*t,o=Math.floor(i),s=+n(e[o],o,e),a=+n(e[o+1],o+1,e);return s+(a-s)*(i-o)}}function ex(e,t,n){let r=_o(e),i=Kn(e,.75)-Kn(e,.25);return r&&i?Math.ceil((n-t)/(2*i*Math.pow(r,-1/3))):1}function fp(e,t,n){let r=_o(e),i=li(e);return r&&i?Math.ceil((n-t)*Math.cbrt(r)/(3.49*i)):1}function Es(e,t){let n=0,r=0;if(t===void 0)for(let i of e)i!=null&&(i=+i)>=i&&(++n,r+=i);else{let i=-1;for(let o of e)(o=t(o,++i,e))!=null&&(o=+o)>=o&&(++n,r+=o)}if(n)return r/n}function Ui(e,t){return Kn(e,.5,t)}function*vY(e){for(let t of e)yield*t}function Ou(e){return Array.from(vY(e))}function Bu(e,t){let n=new Jn;if(t===void 0)for(let o of e)o!=null&&o>=o&&n.set(o,(n.get(o)||0)+1);else{let o=-1;for(let s of e)(s=t(s,++o,e))!=null&&s>=s&&n.set(s,(n.get(s)||0)+1)}let r,i=0;for(let[o,s]of n)s>i&&(i=s,r=o);return r}function nx(e,t=_Y){let n=[],r,i=!1;for(let o of e)i&&n.push(t(r,o)),r=o,i=!0;return n}function _Y(e,t){return[e,t]}function Ue(e,t,n){e=+e,t=+t,n=(i=arguments.length)<2?(t=e,e=0,1):i<3?1:+n;for(var r=-1,i=Math.max(0,Math.ceil((t-e)/n))|0,o=new Array(i);++r<i;)o[r]=e+r*n;return o}function hp(e,t=zt){if(typeof e[Symbol.iterator]!="function")throw new TypeError("values is not iterable");let n=Array.from(e),r=new Float64Array(n.length);t.length!==2&&(n=n.map(t),t=zt);let i=(a,c)=>t(n[a],n[c]),o,s;return e=Uint32Array.from(n,(a,c)=>c),e.sort(t===zt?(a,c)=>Xc(n[a],n[c]):lp(i)),e.forEach((a,c)=>{let l=i(a,o===void 0?a:o);l>=0?((o===void 0||l>0)&&(o=a,s=c),r[a]=s):r[a]=NaN}),r}function rx(e,t=zt){let n,r=!1;if(t.length===1){let i;for(let o of e){let s=t(o);(r?zt(s,i)<0:zt(s,s)===0)&&(n=o,i=s,r=!0)}}else for(let i of e)(r?t(i,n)<0:t(i,i)===0)&&(n=i,r=!0);return n}function Tn(e,t){let n=0;if(t===void 0)for(let r of e)(r=+r)&&(n+=r);else{let r=-1;for(let i of e)(i=+t(i,++r,e))&&(n+=i)}return n}function Na(e){if(typeof e[Symbol.iterator]!="function")throw new TypeError("values is not iterable");return Array.from(e).reverse()}function hL(e){return e}var GS=1,WS=2,HS=3,ix=4,dL=1e-6;function SY(e){return"translate("+e+",0)"}function IY(e){return"translate(0,"+e+")"}function MY(e){return t=>+e(t)}function AY(e,t){return t=Math.max(0,e.bandwidth()-t*2)/2,e.round()&&(t=Math.round(t)),n=>+e(n)+t}function TY(){return!this.__axis}function EY(e,t){var n=[],r=null,i=null,o=6,s=6,a=3,c=typeof window<"u"&&window.devicePixelRatio>1?0:.5,l=e===GS||e===ix?-1:1,u=e===ix||e===WS?"x":"y",f=e===GS||e===HS?SY:IY;function h(d){var p=r??(t.ticks?t.ticks.apply(t,n):t.domain()),m=i??(t.tickFormat?t.tickFormat.apply(t,n):hL),y=Math.max(o,0)+a,g=t.range(),x=+g[0]+c,b=+g[g.length-1]+c,w=(t.bandwidth?AY:MY)(t.copy(),c),_=d.selection?d.selection():d,v=_.selectAll(".domain").data([null]),M=_.selectAll(".tick").data(p,t).order(),E=M.exit(),I=M.enter().append("g").attr("class","tick"),D=M.select("line"),A=M.select("text");v=v.merge(v.enter().insert("path",".tick").attr("class","domain").attr("stroke","currentColor")),M=M.merge(I),D=D.merge(I.append("line").attr("stroke","currentColor").attr(u+"2",l*o)),A=A.merge(I.append("text").attr("fill","currentColor").attr(u,l*y).attr("dy",e===GS?"0em":e===HS?"0.71em":"0.32em")),d!==_&&(v=v.transition(d),M=M.transition(d),D=D.transition(d),A=A.transition(d),E=E.transition(d).attr("opacity",dL).attr("transform",function(O){return isFinite(O=w(O))?f(O+c):this.getAttribute("transform")}),I.attr("opacity",dL).attr("transform",function(O){var C=this.parentNode.__axis;return f((C&&isFinite(C=C(O))?C:w(O))+c)})),E.remove(),v.attr("d",e===ix||e===WS?s?"M"+l*s+","+x+"H"+c+"V"+b+"H"+l*s:"M"+c+","+x+"V"+b:s?"M"+x+","+l*s+"V"+c+"H"+b+"V"+l*s:"M"+x+","+c+"H"+b),M.attr("opacity",1).attr("transform",function(O){return f(w(O)+c)}),D.attr(u+"2",l*o),A.attr(u,l*y).text(m),_.filter(TY).attr("fill","none").attr("font-size",10).attr("font-family","sans-serif").attr("text-anchor",e===WS?"start":e===ix?"end":"middle"),_.each(function(){this.__axis=w})}return h.scale=function(d){return arguments.length?(t=d,h):t},h.ticks=function(){return n=Array.from(arguments),h},h.tickArguments=function(d){return arguments.length?(n=d==null?[]:Array.from(d),h):n.slice()},h.tickValues=function(d){return arguments.length?(r=d==null?null:Array.from(d),h):r&&r.slice()},h.tickFormat=function(d){return arguments.length?(i=d,h):i},h.tickSize=function(d){return arguments.length?(o=s=+d,h):o},h.tickSizeInner=function(d){return arguments.length?(o=+d,h):o},h.tickSizeOuter=function(d){return arguments.length?(s=+d,h):s},h.tickPadding=function(d){return arguments.length?(a=+d,h):a},h.offset=function(d){return arguments.length?(c=+d,h):c},h}function ZS(e){return EY(HS,e)}var NY={value:()=>{}};function mL(){for(var e=0,t=arguments.length,n={},r;e<t;++e){if(!(r=arguments[e]+"")||r in n||/[\s.]/.test(r))throw new Error("illegal type: "+r);n[r]=[]}return new ox(n)}function ox(e){this._=e}function DY(e,t){return e.trim().split(/^|\s+/).map(function(n){var r="",i=n.indexOf(".");if(i>=0&&(r=n.slice(i+1),n=n.slice(0,i)),n&&!t.hasOwnProperty(n))throw new Error("unknown type: "+n);return{type:n,name:r}})}ox.prototype=mL.prototype={constructor:ox,on:function(e,t){var n=this._,r=DY(e+"",n),i,o=-1,s=r.length;if(arguments.length<2){for(;++o<s;)if((i=(e=r[o]).type)&&(i=OY(n[i],e.name)))return i;return}if(t!=null&&typeof t!="function")throw new Error("invalid callback: "+t);for(;++o<s;)if(i=(e=r[o]).type)n[i]=pL(n[i],e.name,t);else if(t==null)for(i in n)n[i]=pL(n[i],e.name,null);return this},copy:function(){var e={},t=this._;for(var n in t)e[n]=t[n].slice();return new ox(e)},call:function(e,t){if((i=arguments.length-2)>0)for(var n=new Array(i),r=0,i,o;r<i;++r)n[r]=arguments[r+2];if(!this._.hasOwnProperty(e))throw new Error("unknown type: "+e);for(o=this._[e],r=0,i=o.length;r<i;++r)o[r].value.apply(t,n)},apply:function(e,t,n){if(!this._.hasOwnProperty(e))throw new Error("unknown type: "+e);for(var r=this._[e],i=0,o=r.length;i<o;++i)r[i].value.apply(t,n)}};function OY(e,t){for(var n=0,r=e.length,i;n<r;++n)if((i=e[n]).name===t)return i.value}function pL(e,t,n){for(var r=0,i=e.length;r<i;++r)if(e[r].name===t){e[r]=NY,e=e.slice(0,r).concat(e.slice(r+1));break}return n!=null&&e.push({name:t,value:n}),e}var Wc=mL;var sx="http://www.w3.org/1999/xhtml",ui={svg:"http://www.w3.org/2000/svg",xhtml:sx,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"};function Ns(e){var t=e+="",n=t.indexOf(":");return n>=0&&(t=e.slice(0,n))!=="xmlns"&&(e=e.slice(n+1)),ui.hasOwnProperty(t)?{space:ui[t],local:e}:e}function BY(e){return function(){var t=this.ownerDocument,n=this.namespaceURI;return n===sx&&t.documentElement.namespaceURI===sx?t.createElement(e):t.createElementNS(n,e)}}function LY(e){return function(){return this.ownerDocument.createElementNS(e.space,e.local)}}function Ds(e){var t=Ns(e);return(t.local?LY:BY)(t)}function CY(){}function Hc(e){return e==null?CY:function(){return this.querySelector(e)}}function yL(e){typeof e!="function"&&(e=Hc(e));for(var t=this._groups,n=t.length,r=new Array(n),i=0;i<n;++i)for(var o=t[i],s=o.length,a=r[i]=new Array(s),c,l,u=0;u<s;++u)(c=o[u])&&(l=e.call(c,c.__data__,u,o))&&("__data__"in c&&(l.__data__=c.__data__),a[u]=l);return new Re(r,this._parents)}function JS(e){return e==null?[]:Array.isArray(e)?e:Array.from(e)}function kY(){return[]}function dp(e){return e==null?kY:function(){return this.querySelectorAll(e)}}function FY(e){return function(){return JS(e.apply(this,arguments))}}function gL(e){typeof e=="function"?e=FY(e):e=dp(e);for(var t=this._groups,n=t.length,r=[],i=[],o=0;o<n;++o)for(var s=t[o],a=s.length,c,l=0;l<a;++l)(c=s[l])&&(r.push(e.call(c,c.__data__,l,s)),i.push(c));return new Re(r,i)}function pp(e){return function(){return this.matches(e)}}function ax(e){return function(t){return t.matches(e)}}var RY=Array.prototype.find;function $Y(e){return function(){return RY.call(this.children,e)}}function PY(){return this.firstElementChild}function xL(e){return this.select(e==null?PY:$Y(typeof e=="function"?e:ax(e)))}var UY=Array.prototype.filter;function zY(){return Array.from(this.children)}function qY(e){return function(){return UY.call(this.children,e)}}function bL(e){return this.selectAll(e==null?zY:qY(typeof e=="function"?e:ax(e)))}function wL(e){typeof e!="function"&&(e=pp(e));for(var t=this._groups,n=t.length,r=new Array(n),i=0;i<n;++i)for(var o=t[i],s=o.length,a=r[i]=[],c,l=0;l<s;++l)(c=o[l])&&e.call(c,c.__data__,l,o)&&a.push(c);return new Re(r,this._parents)}function cx(e){return new Array(e.length)}function vL(){return new Re(this._enter||this._groups.map(cx),this._parents)}function mp(e,t){this.ownerDocument=e.ownerDocument,this.namespaceURI=e.namespaceURI,this._next=null,this._parent=e,this.__data__=t}mp.prototype={constructor:mp,appendChild:function(e){return this._parent.insertBefore(e,this._next)},insertBefore:function(e,t){return this._parent.insertBefore(e,t)},querySelector:function(e){return this._parent.querySelector(e)},querySelectorAll:function(e){return this._parent.querySelectorAll(e)}};function _L(e){return function(){return e}}function jY(e,t,n,r,i,o){for(var s=0,a,c=t.length,l=o.length;s<l;++s)(a=t[s])?(a.__data__=o[s],r[s]=a):n[s]=new mp(e,o[s]);for(;s<c;++s)(a=t[s])&&(i[s]=a)}function VY(e,t,n,r,i,o,s){var a,c,l=new Map,u=t.length,f=o.length,h=new Array(u),d;for(a=0;a<u;++a)(c=t[a])&&(h[a]=d=s.call(c,c.__data__,a,t)+"",l.has(d)?i[a]=c:l.set(d,c));for(a=0;a<f;++a)d=s.call(e,o[a],a,o)+"",(c=l.get(d))?(r[a]=c,c.__data__=o[a],l.delete(d)):n[a]=new mp(e,o[a]);for(a=0;a<u;++a)(c=t[a])&&l.get(h[a])===c&&(i[a]=c)}function YY(e){return e.__data__}function SL(e,t){if(!arguments.length)return Array.from(this,YY);var n=t?VY:jY,r=this._parents,i=this._groups;typeof e!="function"&&(e=_L(e));for(var o=i.length,s=new Array(o),a=new Array(o),c=new Array(o),l=0;l<o;++l){var u=r[l],f=i[l],h=f.length,d=XY(e.call(u,u&&u.__data__,l,r)),p=d.length,m=a[l]=new Array(p),y=s[l]=new Array(p),g=c[l]=new Array(h);n(u,f,m,y,g,d,t);for(var x=0,b=0,w,_;x<p;++x)if(w=m[x]){for(x>=b&&(b=x+1);!(_=y[b])&&++b<p;);w._next=_||null}}return s=new Re(s,r),s._enter=a,s._exit=c,s}function XY(e){return typeof e=="object"&&"length"in e?e:Array.from(e)}function IL(){return new Re(this._exit||this._groups.map(cx),this._parents)}function ML(e,t,n){var r=this.enter(),i=this,o=this.exit();return typeof e=="function"?(r=e(r),r&&(r=r.selection())):r=r.append(e+""),t!=null&&(i=t(i),i&&(i=i.selection())),n==null?o.remove():n(o),r&&i?r.merge(i).order():i}function AL(e){for(var t=e.selection?e.selection():e,n=this._groups,r=t._groups,i=n.length,o=r.length,s=Math.min(i,o),a=new Array(i),c=0;c<s;++c)for(var l=n[c],u=r[c],f=l.length,h=a[c]=new Array(f),d,p=0;p<f;++p)(d=l[p]||u[p])&&(h[p]=d);for(;c<i;++c)a[c]=n[c];return new Re(a,this._parents)}function TL(){for(var e=this._groups,t=-1,n=e.length;++t<n;)for(var r=e[t],i=r.length-1,o=r[i],s;--i>=0;)(s=r[i])&&(o&&s.compareDocumentPosition(o)^4&&o.parentNode.insertBefore(s,o),o=s);return this}function EL(e){e||(e=GY);function t(f,h){return f&&h?e(f.__data__,h.__data__):!f-!h}for(var n=this._groups,r=n.length,i=new Array(r),o=0;o<r;++o){for(var s=n[o],a=s.length,c=i[o]=new Array(a),l,u=0;u<a;++u)(l=s[u])&&(c[u]=l);c.sort(t)}return new Re(i,this._parents).order()}function GY(e,t){return e<t?-1:e>t?1:e>=t?0:NaN}function NL(){var e=arguments[0];return arguments[0]=this,e.apply(null,arguments),this}function DL(){return Array.from(this)}function OL(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var r=e[t],i=0,o=r.length;i<o;++i){var s=r[i];if(s)return s}return null}function BL(){let e=0;for(let t of this)++e;return e}function LL(){return!this.node()}function CL(e){for(var t=this._groups,n=0,r=t.length;n<r;++n)for(var i=t[n],o=0,s=i.length,a;o<s;++o)(a=i[o])&&e.call(a,a.__data__,o,i);return this}function WY(e){return function(){this.removeAttribute(e)}}function HY(e){return function(){this.removeAttributeNS(e.space,e.local)}}function ZY(e,t){return function(){this.setAttribute(e,t)}}function JY(e,t){return function(){this.setAttributeNS(e.space,e.local,t)}}function QY(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttribute(e):this.setAttribute(e,n)}}function KY(e,t){return function(){var n=t.apply(this,arguments);n==null?this.removeAttributeNS(e.space,e.local):this.setAttributeNS(e.space,e.local,n)}}function kL(e,t){var n=Ns(e);if(arguments.length<2){var r=this.node();return n.local?r.getAttributeNS(n.space,n.local):r.getAttribute(n)}return this.each((t==null?n.local?HY:WY:typeof t=="function"?n.local?KY:QY:n.local?JY:ZY)(n,t))}function lx(e){return e.ownerDocument&&e.ownerDocument.defaultView||e.document&&e||e.defaultView}function tX(e){return function(){this.style.removeProperty(e)}}function eX(e,t,n){return function(){this.style.setProperty(e,t,n)}}function nX(e,t,n){return function(){var r=t.apply(this,arguments);r==null?this.style.removeProperty(e):this.style.setProperty(e,r,n)}}function FL(e,t,n){return arguments.length>1?this.each((t==null?tX:typeof t=="function"?nX:eX)(e,t,n??"")):Da(this.node(),e)}function Da(e,t){return e.style.getPropertyValue(t)||lx(e).getComputedStyle(e,null).getPropertyValue(t)}function rX(e){return function(){delete this[e]}}function iX(e,t){return function(){this[e]=t}}function oX(e,t){return function(){var n=t.apply(this,arguments);n==null?delete this[e]:this[e]=n}}function RL(e,t){return arguments.length>1?this.each((t==null?rX:typeof t=="function"?oX:iX)(e,t)):this.node()[e]}function $L(e){return e.trim().split(/^|\s+/)}function QS(e){return e.classList||new PL(e)}function PL(e){this._node=e,this._names=$L(e.getAttribute("class")||"")}PL.prototype={add:function(e){var t=this._names.indexOf(e);t<0&&(this._names.push(e),this._node.setAttribute("class",this._names.join(" ")))},remove:function(e){var t=this._names.indexOf(e);t>=0&&(this._names.splice(t,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(e){return this._names.indexOf(e)>=0}};function UL(e,t){for(var n=QS(e),r=-1,i=t.length;++r<i;)n.add(t[r])}function zL(e,t){for(var n=QS(e),r=-1,i=t.length;++r<i;)n.remove(t[r])}function sX(e){return function(){UL(this,e)}}function aX(e){return function(){zL(this,e)}}function cX(e,t){return function(){(t.apply(this,arguments)?UL:zL)(this,e)}}function qL(e,t){var n=$L(e+"");if(arguments.length<2){for(var r=QS(this.node()),i=-1,o=n.length;++i<o;)if(!r.contains(n[i]))return!1;return!0}return this.each((typeof t=="function"?cX:t?sX:aX)(n,t))}function lX(){this.textContent=""}function uX(e){return function(){this.textContent=e}}function fX(e){return function(){var t=e.apply(this,arguments);this.textContent=t??""}}function jL(e){return arguments.length?this.each(e==null?lX:(typeof e=="function"?fX:uX)(e)):this.node().textContent}function hX(){this.innerHTML=""}function dX(e){return function(){this.innerHTML=e}}function pX(e){return function(){var t=e.apply(this,arguments);this.innerHTML=t??""}}function VL(e){return arguments.length?this.each(e==null?hX:(typeof e=="function"?pX:dX)(e)):this.node().innerHTML}function mX(){this.nextSibling&&this.parentNode.appendChild(this)}function YL(){return this.each(mX)}function yX(){this.previousSibling&&this.parentNode.insertBefore(this,this.parentNode.firstChild)}function XL(){return this.each(yX)}function GL(e){var t=typeof e=="function"?e:Ds(e);return this.select(function(){return this.appendChild(t.apply(this,arguments))})}function gX(){return null}function WL(e,t){var n=typeof e=="function"?e:Ds(e),r=t==null?gX:typeof t=="function"?t:Hc(t);return this.select(function(){return this.insertBefore(n.apply(this,arguments),r.apply(this,arguments)||null)})}function xX(){var e=this.parentNode;e&&e.removeChild(this)}function HL(){return this.each(xX)}function bX(){var e=this.cloneNode(!1),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function wX(){var e=this.cloneNode(!0),t=this.parentNode;return t?t.insertBefore(e,this.nextSibling):e}function ZL(e){return this.select(e?wX:bX)}function JL(e){return arguments.length?this.property("__data__",e):this.node().__data__}function vX(e){return function(t){e.call(this,t,this.__data__)}}function _X(e){return e.trim().split(/^|\s+/).map(function(t){var n="",r=t.indexOf(".");return r>=0&&(n=t.slice(r+1),t=t.slice(0,r)),{type:t,name:n}})}function SX(e){return function(){var t=this.__on;if(t){for(var n=0,r=-1,i=t.length,o;n<i;++n)o=t[n],(!e.type||o.type===e.type)&&o.name===e.name?this.removeEventListener(o.type,o.listener,o.options):t[++r]=o;++r?t.length=r:delete this.__on}}}function IX(e,t,n){return function(){var r=this.__on,i,o=vX(t);if(r){for(var s=0,a=r.length;s<a;++s)if((i=r[s]).type===e.type&&i.name===e.name){this.removeEventListener(i.type,i.listener,i.options),this.addEventListener(i.type,i.listener=o,i.options=n),i.value=t;return}}this.addEventListener(e.type,o,n),i={type:e.type,name:e.name,value:t,listener:o,options:n},r?r.push(i):this.__on=[i]}}function QL(e,t,n){var r=_X(e+""),i,o=r.length,s;if(arguments.length<2){var a=this.node().__on;if(a){for(var c=0,l=a.length,u;c<l;++c)for(i=0,u=a[c];i<o;++i)if((s=r[i]).type===u.type&&s.name===u.name)return u.value}return}for(a=t?IX:SX,i=0;i<o;++i)this.each(a(r[i],t,n));return this}function KL(e,t,n){var r=lx(e),i=r.CustomEvent;typeof i=="function"?i=new i(t,n):(i=r.document.createEvent("Event"),n?(i.initEvent(t,n.bubbles,n.cancelable),i.detail=n.detail):i.initEvent(t,!1,!1)),e.dispatchEvent(i)}function MX(e,t){return function(){return KL(this,e,t)}}function AX(e,t){return function(){return KL(this,e,t.apply(this,arguments))}}function t5(e,t){return this.each((typeof t=="function"?AX:MX)(e,t))}function*e5(){for(var e=this._groups,t=0,n=e.length;t<n;++t)for(var r=e[t],i=0,o=r.length,s;i<o;++i)(s=r[i])&&(yield s)}var KS=[null];function Re(e,t){this._groups=e,this._parents=t}function n5(){return new Re([[document.documentElement]],KS)}function TX(){return this}Re.prototype=n5.prototype={constructor:Re,select:yL,selectAll:gL,selectChild:xL,selectChildren:bL,filter:wL,data:SL,enter:vL,exit:IL,join:ML,merge:AL,selection:TX,order:TL,sort:EL,call:NL,nodes:DL,node:OL,size:BL,empty:LL,each:CL,attr:kL,style:FL,property:RL,classed:qL,text:jL,html:VL,raise:YL,lower:XL,append:GL,insert:WL,remove:HL,clone:ZL,datum:JL,on:QL,dispatch:t5,[Symbol.iterator]:e5};var Os=n5;function Vt(e){return typeof e=="string"?new Re([[document.querySelector(e)]],[document.documentElement]):new Re([[e]],KS)}function r5(e){let t;for(;t=e.sourceEvent;)e=t;return e}function Fn(e,t){if(e=r5(e),t===void 0&&(t=e.currentTarget),t){var n=t.ownerSVGElement||t;if(n.createSVGPoint){var r=n.createSVGPoint();return r.x=e.clientX,r.y=e.clientY,r=r.matrixTransform(t.getScreenCTM().inverse()),[r.x,r.y]}if(t.getBoundingClientRect){var i=t.getBoundingClientRect();return[e.clientX-i.left-t.clientLeft,e.clientY-i.top-t.clientTop]}}return[e.pageX,e.pageY]}var ux={capture:!0,passive:!1};function fx(e){e.preventDefault(),e.stopImmediatePropagation()}function yp(e){var t=e.document.documentElement,n=Vt(e).on("dragstart.drag",fx,ux);"onselectstart"in t?n.on("selectstart.drag",fx,ux):(t.__noselect=t.style.MozUserSelect,t.style.MozUserSelect="none")}function gp(e,t){var n=e.document.documentElement,r=Vt(e).on("dragstart.drag",null);t&&(r.on("click.drag",fx,ux),setTimeout(function(){r.on("click.drag",null)},0)),"onselectstart"in n?r.on("selectstart.drag",null):(n.style.MozUserSelect=n.__noselect,delete n.__noselect)}function Bs(e,t,n){e.prototype=t.prototype=n,n.constructor=e}function Oa(e,t){var n=Object.create(e.prototype);for(var r in t)n[r]=t[r];return n}function Io(){}var Ba=.7,Qc=1/Ba,Lu="\\s*([+-]?\\d+)\\s*",xp="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)\\s*",So="\\s*([+-]?(?:\\d*\\.)?\\d+(?:[eE][+-]?\\d+)?)%\\s*",EX=/^#([0-9a-f]{3,8})$/,NX=new RegExp(`^rgb\\(${Lu},${Lu},${Lu}\\)$`),DX=new RegExp(`^rgb\\(${So},${So},${So}\\)$`),OX=new RegExp(`^rgba\\(${Lu},${Lu},${Lu},${xp}\\)$`),BX=new RegExp(`^rgba\\(${So},${So},${So},${xp}\\)$`),LX=new RegExp(`^hsl\\(${xp},${So},${So}\\)$`),CX=new RegExp(`^hsla\\(${xp},${So},${So},${xp}\\)$`),i5={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};Bs(Io,Rr,{copy(e){return Object.assign(new this.constructor,this,e)},displayable(){return this.rgb().displayable()},hex:o5,formatHex:o5,formatHex8:kX,formatHsl:FX,formatRgb:s5,toString:s5});function o5(){return this.rgb().formatHex()}function kX(){return this.rgb().formatHex8()}function FX(){return h5(this).formatHsl()}function s5(){return this.rgb().formatRgb()}function Rr(e){var t,n;return e=(e+"").trim().toLowerCase(),(t=EX.exec(e))?(n=t[1].length,t=parseInt(t[1],16),n===6?a5(t):n===3?new Ge(t>>8&15|t>>4&240,t>>4&15|t&240,(t&15)<<4|t&15,1):n===8?hx(t>>24&255,t>>16&255,t>>8&255,(t&255)/255):n===4?hx(t>>12&15|t>>8&240,t>>8&15|t>>4&240,t>>4&15|t&240,((t&15)<<4|t&15)/255):null):(t=NX.exec(e))?new Ge(t[1],t[2],t[3],1):(t=DX.exec(e))?new Ge(t[1]*255/100,t[2]*255/100,t[3]*255/100,1):(t=OX.exec(e))?hx(t[1],t[2],t[3],t[4]):(t=BX.exec(e))?hx(t[1]*255/100,t[2]*255/100,t[3]*255/100,t[4]):(t=LX.exec(e))?u5(t[1],t[2]/100,t[3]/100,1):(t=CX.exec(e))?u5(t[1],t[2]/100,t[3]/100,t[4]):i5.hasOwnProperty(e)?a5(i5[e]):e==="transparent"?new Ge(NaN,NaN,NaN,0):null}function a5(e){return new Ge(e>>16&255,e>>8&255,e&255,1)}function hx(e,t,n,r){return r<=0&&(e=t=n=NaN),new Ge(e,t,n,r)}function bp(e){return e instanceof Io||(e=Rr(e)),e?(e=e.rgb(),new Ge(e.r,e.g,e.b,e.opacity)):new Ge}function rn(e,t,n,r){return arguments.length===1?bp(e):new Ge(e,t,n,r??1)}function Ge(e,t,n,r){this.r=+e,this.g=+t,this.b=+n,this.opacity=+r}Bs(Ge,rn,Oa(Io,{brighter(e){return e=e==null?Qc:Math.pow(Qc,e),new Ge(this.r*e,this.g*e,this.b*e,this.opacity)},darker(e){return e=e==null?Ba:Math.pow(Ba,e),new Ge(this.r*e,this.g*e,this.b*e,this.opacity)},rgb(){return this},clamp(){return new Ge(Jc(this.r),Jc(this.g),Jc(this.b),px(this.opacity))},displayable(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:c5,formatHex:c5,formatHex8:RX,formatRgb:l5,toString:l5}));function c5(){return`#${Zc(this.r)}${Zc(this.g)}${Zc(this.b)}`}function RX(){return`#${Zc(this.r)}${Zc(this.g)}${Zc(this.b)}${Zc((isNaN(this.opacity)?1:this.opacity)*255)}`}function l5(){let e=px(this.opacity);return`${e===1?"rgb(":"rgba("}${Jc(this.r)}, ${Jc(this.g)}, ${Jc(this.b)}${e===1?")":`, ${e})`}`}function px(e){return isNaN(e)?1:Math.max(0,Math.min(1,e))}function Jc(e){return Math.max(0,Math.min(255,Math.round(e)||0))}function Zc(e){return e=Jc(e),(e<16?"0":"")+e.toString(16)}function u5(e,t,n,r){return r<=0?e=t=n=NaN:n<=0||n>=1?e=t=NaN:t<=0&&(e=NaN),new zi(e,t,n,r)}function h5(e){if(e instanceof zi)return new zi(e.h,e.s,e.l,e.opacity);if(e instanceof Io||(e=Rr(e)),!e)return new zi;if(e instanceof zi)return e;e=e.rgb();var t=e.r/255,n=e.g/255,r=e.b/255,i=Math.min(t,n,r),o=Math.max(t,n,r),s=NaN,a=o-i,c=(o+i)/2;return a?(t===o?s=(n-r)/a+(n<r)*6:n===o?s=(r-t)/a+2:s=(t-n)/a+4,a/=c<.5?o+i:2-o-i,s*=60):a=c>0&&c<1?0:s,new zi(s,a,c,e.opacity)}function wp(e,t,n,r){return arguments.length===1?h5(e):new zi(e,t,n,r??1)}function zi(e,t,n,r){this.h=+e,this.s=+t,this.l=+n,this.opacity=+r}Bs(zi,wp,Oa(Io,{brighter(e){return e=e==null?Qc:Math.pow(Qc,e),new zi(this.h,this.s,this.l*e,this.opacity)},darker(e){return e=e==null?Ba:Math.pow(Ba,e),new zi(this.h,this.s,this.l*e,this.opacity)},rgb(){var e=this.h%360+(this.h<0)*360,t=isNaN(e)||isNaN(this.s)?0:this.s,n=this.l,r=n+(n<.5?n:1-n)*t,i=2*n-r;return new Ge(tI(e>=240?e-240:e+120,i,r),tI(e,i,r),tI(e<120?e+240:e-120,i,r),this.opacity)},clamp(){return new zi(f5(this.h),dx(this.s),dx(this.l),px(this.opacity))},displayable(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl(){let e=px(this.opacity);return`${e===1?"hsl(":"hsla("}${f5(this.h)}, ${dx(this.s)*100}%, ${dx(this.l)*100}%${e===1?")":`, ${e})`}`}}));function f5(e){return e=(e||0)%360,e<0?e+360:e}function dx(e){return Math.max(0,Math.min(1,e||0))}function tI(e,t,n){return(e<60?t+(n-t)*e/60:e<180?n:e<240?t+(n-t)*(240-e)/60:t)*255}var mx=Math.PI/180,yx=180/Math.PI;var gx=18,d5=.96422,p5=1,m5=.82521,y5=4/29,Cu=6/29,g5=3*Cu*Cu,$X=Cu*Cu*Cu;function x5(e){if(e instanceof Mo)return new Mo(e.l,e.a,e.b,e.opacity);if(e instanceof Ls)return b5(e);e instanceof Ge||(e=bp(e));var t=iI(e.r),n=iI(e.g),r=iI(e.b),i=eI((.2225045*t+.7168786*n+.0606169*r)/p5),o,s;return t===n&&n===r?o=s=i:(o=eI((.4360747*t+.3850649*n+.1430804*r)/d5),s=eI((.0139322*t+.0971045*n+.7141733*r)/m5)),new Mo(116*i-16,500*(o-i),200*(i-s),e.opacity)}function ku(e,t,n,r){return arguments.length===1?x5(e):new Mo(e,t,n,r??1)}function Mo(e,t,n,r){this.l=+e,this.a=+t,this.b=+n,this.opacity=+r}Bs(Mo,ku,Oa(Io,{brighter(e){return new Mo(this.l+gx*(e??1),this.a,this.b,this.opacity)},darker(e){return new Mo(this.l-gx*(e??1),this.a,this.b,this.opacity)},rgb(){var e=(this.l+16)/116,t=isNaN(this.a)?e:e+this.a/500,n=isNaN(this.b)?e:e-this.b/200;return t=d5*nI(t),e=p5*nI(e),n=m5*nI(n),new Ge(rI(3.1338561*t-1.6168667*e-.4906146*n),rI(-.9787684*t+1.9161415*e+.033454*n),rI(.0719453*t-.2289914*e+1.4052427*n),this.opacity)}}));function eI(e){return e>$X?Math.pow(e,1/3):e/g5+y5}function nI(e){return e>Cu?e*e*e:g5*(e-y5)}function rI(e){return 255*(e<=.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055)}function iI(e){return(e/=255)<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}function PX(e){if(e instanceof Ls)return new Ls(e.h,e.c,e.l,e.opacity);if(e instanceof Mo||(e=x5(e)),e.a===0&&e.b===0)return new Ls(NaN,0<e.l&&e.l<100?0:NaN,e.l,e.opacity);var t=Math.atan2(e.b,e.a)*yx;return new Ls(t<0?t+360:t,Math.sqrt(e.a*e.a+e.b*e.b),e.l,e.opacity)}function vp(e,t,n,r){return arguments.length===1?PX(e):new Ls(e,t,n,r??1)}function Ls(e,t,n,r){this.h=+e,this.c=+t,this.l=+n,this.opacity=+r}function b5(e){if(isNaN(e.h))return new Mo(e.l,0,0,e.opacity);var t=e.h*mx;return new Mo(e.l,Math.cos(t)*e.c,Math.sin(t)*e.c,e.opacity)}Bs(Ls,vp,Oa(Io,{brighter(e){return new Ls(this.h,this.c,this.l+gx*(e??1),this.opacity)},darker(e){return new Ls(this.h,this.c,this.l-gx*(e??1),this.opacity)},rgb(){return b5(this).rgb()}}));var S5=-.14861,oI=1.78277,sI=-.29227,xx=-.90649,_p=1.97294,w5=_p*xx,v5=_p*oI,_5=oI*sI-xx*S5;function UX(e){if(e instanceof Kc)return new Kc(e.h,e.s,e.l,e.opacity);e instanceof Ge||(e=bp(e));var t=e.r/255,n=e.g/255,r=e.b/255,i=(_5*r+w5*t-v5*n)/(_5+w5-v5),o=r-i,s=(_p*(n-i)-sI*o)/xx,a=Math.sqrt(s*s+o*o)/(_p*i*(1-i)),c=a?Math.atan2(s,o)*yx-120:NaN;return new Kc(c<0?c+360:c,a,i,e.opacity)}function tr(e,t,n,r){return arguments.length===1?UX(e):new Kc(e,t,n,r??1)}function Kc(e,t,n,r){this.h=+e,this.s=+t,this.l=+n,this.opacity=+r}Bs(Kc,tr,Oa(Io,{brighter(e){return e=e==null?Qc:Math.pow(Qc,e),new Kc(this.h,this.s,this.l*e,this.opacity)},darker(e){return e=e==null?Ba:Math.pow(Ba,e),new Kc(this.h,this.s,this.l*e,this.opacity)},rgb(){var e=isNaN(this.h)?0:(this.h+120)*mx,t=+this.l,n=isNaN(this.s)?0:this.s*t*(1-t),r=Math.cos(e),i=Math.sin(e);return new Ge(255*(t+n*(S5*r+oI*i)),255*(t+n*(sI*r+xx*i)),255*(t+n*(_p*r)),this.opacity)}}));function aI(e,t,n,r,i){var o=e*e,s=o*e;return((1-3*e+3*o-s)*t+(4-6*o+3*s)*n+(1+3*e+3*o-3*s)*r+s*i)/6}function I5(e){var t=e.length-1;return function(n){var r=n<=0?n=0:n>=1?(n=1,t-1):Math.floor(n*t),i=e[r],o=e[r+1],s=r>0?e[r-1]:2*i-o,a=r<t-1?e[r+2]:2*o-i;return aI((n-r/t)*t,s,i,o,a)}}function M5(e){var t=e.length;return function(n){var r=Math.floor(((n%=1)<0?++n:n)*t),i=e[(r+t-1)%t],o=e[r%t],s=e[(r+1)%t],a=e[(r+2)%t];return aI((n-r/t)*t,i,o,s,a)}}var Fu=e=>()=>e;function A5(e,t){return function(n){return e+n*t}}function zX(e,t,n){return e=Math.pow(e,n),t=Math.pow(t,n)-e,n=1/n,function(r){return Math.pow(e+r*t,n)}}function Ru(e,t){var n=t-e;return n?A5(e,n>180||n<-180?n-360*Math.round(n/360):n):Fu(isNaN(e)?t:e)}function T5(e){return(e=+e)==1?Te:function(t,n){return n-t?zX(t,n,e):Fu(isNaN(t)?n:t)}}function Te(e,t){var n=t-e;return n?A5(e,n):Fu(isNaN(e)?t:e)}var fi=function e(t){var n=T5(t);function r(i,o){var s=n((i=rn(i)).r,(o=rn(o)).r),a=n(i.g,o.g),c=n(i.b,o.b),l=Te(i.opacity,o.opacity);return function(u){return i.r=s(u),i.g=a(u),i.b=c(u),i.opacity=l(u),i+""}}return r.gamma=e,r}(1);function E5(e){return function(t){var n=t.length,r=new Array(n),i=new Array(n),o=new Array(n),s,a;for(s=0;s<n;++s)a=rn(t[s]),r[s]=a.r||0,i[s]=a.g||0,o[s]=a.b||0;return r=e(r),i=e(i),o=e(o),a.opacity=1,function(c){return a.r=r(c),a.g=i(c),a.b=o(c),a+""}}}var cI=E5(I5),qX=E5(M5);function N5(e,t){t||(t=[]);var n=e?Math.min(t.length,e.length):0,r=t.slice(),i;return function(o){for(i=0;i<n;++i)r[i]=e[i]*(1-o)+t[i]*o;return r}}function D5(e){return ArrayBuffer.isView(e)&&!(e instanceof DataView)}function O5(e,t){var n=t?t.length:0,r=e?Math.min(n,e.length):0,i=new Array(r),o=new Array(n),s;for(s=0;s<r;++s)i[s]=$r(e[s],t[s]);for(;s<n;++s)o[s]=t[s];return function(a){for(s=0;s<r;++s)o[s]=i[s](a);return o}}function B5(e,t){var n=new Date;return e=+e,t=+t,function(r){return n.setTime(e*(1-r)+t*r),n}}function _e(e,t){return e=+e,t=+t,function(n){return e*(1-n)+t*n}}function L5(e,t){var n={},r={},i;(e===null||typeof e!="object")&&(e={}),(t===null||typeof t!="object")&&(t={});for(i in t)i in e?n[i]=$r(e[i],t[i]):r[i]=t[i];return function(o){for(i in n)r[i]=n[i](o);return r}}var uI=/[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,lI=new RegExp(uI.source,"g");function jX(e){return function(){return e}}function VX(e){return function(t){return e(t)+""}}function Sp(e,t){var n=uI.lastIndex=lI.lastIndex=0,r,i,o,s=-1,a=[],c=[];for(e=e+"",t=t+"";(r=uI.exec(e))&&(i=lI.exec(t));)(o=i.index)>n&&(o=t.slice(n,o),a[s]?a[s]+=o:a[++s]=o),(r=r[0])===(i=i[0])?a[s]?a[s]+=i:a[++s]=i:(a[++s]=null,c.push({i:s,x:_e(r,i)})),n=lI.lastIndex;return n<t.length&&(o=t.slice(n),a[s]?a[s]+=o:a[++s]=o),a.length<2?c[0]?VX(c[0].x):jX(t):(t=c.length,function(l){for(var u=0,f;u<t;++u)a[(f=c[u]).i]=f.x(l);return a.join("")})}function $r(e,t){var n=typeof t,r;return t==null||n==="boolean"?Fu(t):(n==="number"?_e:n==="string"?(r=Rr(t))?(t=r,fi):Sp:t instanceof Rr?fi:t instanceof Date?B5:D5(t)?N5:Array.isArray(t)?O5:typeof t.valueOf!="function"&&typeof t.toString!="function"||isNaN(t)?L5:_e)(e,t)}function tl(e,t){return e=+e,t=+t,function(n){return Math.round(e*(1-n)+t*n)}}var C5=180/Math.PI,bx={translateX:0,translateY:0,rotate:0,skewX:0,scaleX:1,scaleY:1};function fI(e,t,n,r,i,o){var s,a,c;return(s=Math.sqrt(e*e+t*t))&&(e/=s,t/=s),(c=e*n+t*r)&&(n-=e*c,r-=t*c),(a=Math.sqrt(n*n+r*r))&&(n/=a,r/=a,c/=a),e*r<t*n&&(e=-e,t=-t,c=-c,s=-s),{translateX:i,translateY:o,rotate:Math.atan2(t,e)*C5,skewX:Math.atan(c)*C5,scaleX:s,scaleY:a}}var wx;function k5(e){let t=new(typeof DOMMatrix=="function"?DOMMatrix:WebKitCSSMatrix)(e+"");return t.isIdentity?bx:fI(t.a,t.b,t.c,t.d,t.e,t.f)}function F5(e){return e==null?bx:(wx||(wx=document.createElementNS("http://www.w3.org/2000/svg","g")),wx.setAttribute("transform",e),(e=wx.transform.baseVal.consolidate())?(e=e.matrix,fI(e.a,e.b,e.c,e.d,e.e,e.f)):bx)}function R5(e,t,n,r){function i(l){return l.length?l.pop()+" ":""}function o(l,u,f,h,d,p){if(l!==f||u!==h){var m=d.push("translate(",null,t,null,n);p.push({i:m-4,x:_e(l,f)},{i:m-2,x:_e(u,h)})}else(f||h)&&d.push("translate("+f+t+h+n)}function s(l,u,f,h){l!==u?(l-u>180?u+=360:u-l>180&&(l+=360),h.push({i:f.push(i(f)+"rotate(",null,r)-2,x:_e(l,u)})):u&&f.push(i(f)+"rotate("+u+r)}function a(l,u,f,h){l!==u?h.push({i:f.push(i(f)+"skewX(",null,r)-2,x:_e(l,u)}):u&&f.push(i(f)+"skewX("+u+r)}function c(l,u,f,h,d,p){if(l!==f||u!==h){var m=d.push(i(d)+"scale(",null,",",null,")");p.push({i:m-4,x:_e(l,f)},{i:m-2,x:_e(u,h)})}else(f!==1||h!==1)&&d.push(i(d)+"scale("+f+","+h+")")}return function(l,u){var f=[],h=[];return l=e(l),u=e(u),o(l.translateX,l.translateY,u.translateX,u.translateY,f,h),s(l.rotate,u.rotate,f,h),a(l.skewX,u.skewX,f,h),c(l.scaleX,l.scaleY,u.scaleX,u.scaleY,f,h),l=u=null,function(d){for(var p=-1,m=h.length,y;++p<m;)f[(y=h[p]).i]=y.x(d);return f.join("")}}}var hI=R5(k5,"px, ","px)","deg)"),dI=R5(F5,", ",")",")");var YX=1e-12;function $5(e){return((e=Math.exp(e))+1/e)/2}function XX(e){return((e=Math.exp(e))-1/e)/2}function GX(e){return((e=Math.exp(2*e))-1)/(e+1)}var pI=function e(t,n,r){function i(o,s){var a=o[0],c=o[1],l=o[2],u=s[0],f=s[1],h=s[2],d=u-a,p=f-c,m=d*d+p*p,y,g;if(m<YX)g=Math.log(h/l)/t,y=function(M){return[a+M*d,c+M*p,l*Math.exp(t*M*g)]};else{var x=Math.sqrt(m),b=(h*h-l*l+r*m)/(2*l*n*x),w=(h*h-l*l-r*m)/(2*h*n*x),_=Math.log(Math.sqrt(b*b+1)-b),v=Math.log(Math.sqrt(w*w+1)-w);g=(v-_)/t,y=function(M){var E=M*g,I=$5(_),D=l/(n*x)*(I*GX(t*E+_)-XX(_));return[a+D*d,c+D*p,l*I/$5(t*E+_)]}}return y.duration=g*1e3*t/Math.SQRT2,y}return i.rho=function(o){var s=Math.max(.001,+o),a=s*s,c=a*a;return e(s,a,c)},i}(Math.SQRT2,2,4);function P5(e){return function(t,n){var r=e((t=wp(t)).h,(n=wp(n)).h),i=Te(t.s,n.s),o=Te(t.l,n.l),s=Te(t.opacity,n.opacity);return function(a){return t.h=r(a),t.s=i(a),t.l=o(a),t.opacity=s(a),t+""}}}var mI=P5(Ru),WX=P5(Te);function vx(e,t){var n=Te((e=ku(e)).l,(t=ku(t)).l),r=Te(e.a,t.a),i=Te(e.b,t.b),o=Te(e.opacity,t.opacity);return function(s){return e.l=n(s),e.a=r(s),e.b=i(s),e.opacity=o(s),e+""}}function U5(e){return function(t,n){var r=e((t=vp(t)).h,(n=vp(n)).h),i=Te(t.c,n.c),o=Te(t.l,n.l),s=Te(t.opacity,n.opacity);return function(a){return t.h=r(a),t.c=i(a),t.l=o(a),t.opacity=s(a),t+""}}}var yI=U5(Ru),HX=U5(Te);function z5(e){return function t(n){n=+n;function r(i,o){var s=e((i=tr(i)).h,(o=tr(o)).h),a=Te(i.s,o.s),c=Te(i.l,o.l),l=Te(i.opacity,o.opacity);return function(u){return i.h=s(u),i.s=a(u),i.l=c(Math.pow(u,n)),i.opacity=l(u),i+""}}return r.gamma=t,r}(1)}var ZX=z5(Ru),$u=z5(Te);function Ao(e,t){t===void 0&&(t=e,e=$r);for(var n=0,r=t.length-1,i=t[0],o=new Array(r<0?0:r);n<r;)o[n]=e(i,i=t[++n]);return function(s){var a=Math.max(0,Math.min(r-1,Math.floor(s*=r)));return o[a](s-a)}}function Rn(e,t){for(var n=new Array(t),r=0;r<t;++r)n[r]=e(r/(t-1));return n}var Pu=0,Mp=0,Ip=0,j5=1e3,_x,Ap,Sx=0,el=0,Ix=0,Tp=typeof performance=="object"&&performance.now?performance:Date,V5=typeof window=="object"&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(e){setTimeout(e,17)};function Np(){return el||(V5(JX),el=Tp.now()+Ix)}function JX(){el=0}function Ep(){this._call=this._time=this._next=null}Ep.prototype=Mx.prototype={constructor:Ep,restart:function(e,t,n){if(typeof e!="function")throw new TypeError("callback is not a function");n=(n==null?Np():+n)+(t==null?0:+t),!this._next&&Ap!==this&&(Ap?Ap._next=this:_x=this,Ap=this),this._call=e,this._time=n,gI()},stop:function(){this._call&&(this._call=null,this._time=1/0,gI())}};function Mx(e,t,n){var r=new Ep;return r.restart(e,t,n),r}function Y5(){Np(),++Pu;for(var e=_x,t;e;)(t=el-e._time)>=0&&e._call.call(void 0,t),e=e._next;--Pu}function q5(){el=(Sx=Tp.now())+Ix,Pu=Mp=0;try{Y5()}finally{Pu=0,KX(),el=0}}function QX(){var e=Tp.now(),t=e-Sx;t>j5&&(Ix-=t,Sx=e)}function KX(){for(var e,t=_x,n,r=1/0;t;)t._call?(r>t._time&&(r=t._time),e=t,t=t._next):(n=t._next,t._next=null,t=e?e._next=n:_x=n);Ap=e,gI(r)}function gI(e){if(!Pu){Mp&&(Mp=clearTimeout(Mp));var t=e-el;t>24?(e<1/0&&(Mp=setTimeout(q5,e-Tp.now()-Ix)),Ip&&(Ip=clearInterval(Ip))):(Ip||(Sx=Tp.now(),Ip=setInterval(QX,j5)),Pu=1,V5(q5))}}function Ax(e,t,n){var r=new Ep;return t=t==null?0:+t,r.restart(i=>{r.stop(),e(i+t)},t,n),r}var tG=Wc("start","end","cancel","interrupt"),eG=[],W5=0,X5=1,Ex=2,Tx=3,G5=4,Nx=5,Dp=6;function La(e,t,n,r,i,o){var s=e.__transition;if(!s)e.__transition={};else if(n in s)return;nG(e,n,{name:t,index:r,group:i,on:tG,tween:eG,time:o.time,delay:o.delay,duration:o.duration,ease:o.ease,timer:null,state:W5})}function Op(e,t){var n=on(e,t);if(n.state>W5)throw new Error("too late; already scheduled");return n}function En(e,t){var n=on(e,t);if(n.state>Tx)throw new Error("too late; already running");return n}function on(e,t){var n=e.__transition;if(!n||!(n=n[t]))throw new Error("transition not found");return n}function nG(e,t,n){var r=e.__transition,i;r[t]=n,n.timer=Mx(o,0,n.time);function o(l){n.state=X5,n.timer.restart(s,n.delay,n.time),n.delay<=l&&s(l-n.delay)}function s(l){var u,f,h,d;if(n.state!==X5)return c();for(u in r)if(d=r[u],d.name===n.name){if(d.state===Tx)return Ax(s);d.state===G5?(d.state=Dp,d.timer.stop(),d.on.call("interrupt",e,e.__data__,d.index,d.group),delete r[u]):+u<t&&(d.state=Dp,d.timer.stop(),d.on.call("cancel",e,e.__data__,d.index,d.group),delete r[u])}if(Ax(function(){n.state===Tx&&(n.state=G5,n.timer.restart(a,n.delay,n.time),a(l))}),n.state=Ex,n.on.call("start",e,e.__data__,n.index,n.group),n.state===Ex){for(n.state=Tx,i=new Array(h=n.tween.length),u=0,f=-1;u<h;++u)(d=n.tween[u].value.call(e,e.__data__,n.index,n.group))&&(i[++f]=d);i.length=f+1}}function a(l){for(var u=l<n.duration?n.ease.call(null,l/n.duration):(n.timer.restart(c),n.state=Nx,1),f=-1,h=i.length;++f<h;)i[f].call(e,u);n.state===Nx&&(n.on.call("end",e,e.__data__,n.index,n.group),c())}function c(){n.state=Dp,n.timer.stop(),delete r[t];for(var l in r)return;delete e.__transition}}function To(e,t){var n=e.__transition,r,i,o=!0,s;if(n){t=t==null?null:t+"";for(s in n){if((r=n[s]).name!==t){o=!1;continue}i=r.state>Ex&&r.state<Nx,r.state=Dp,r.timer.stop(),r.on.call(i?"interrupt":"cancel",e,e.__data__,r.index,r.group),delete n[s]}o&&delete e.__transition}}function H5(e){return this.each(function(){To(this,e)})}function rG(e,t){var n,r;return function(){var i=En(this,e),o=i.tween;if(o!==n){r=n=o;for(var s=0,a=r.length;s<a;++s)if(r[s].name===t){r=r.slice(),r.splice(s,1);break}}i.tween=r}}function iG(e,t,n){var r,i;if(typeof n!="function")throw new Error;return function(){var o=En(this,e),s=o.tween;if(s!==r){i=(r=s).slice();for(var a={name:t,value:n},c=0,l=i.length;c<l;++c)if(i[c].name===t){i[c]=a;break}c===l&&i.push(a)}o.tween=i}}function Z5(e,t){var n=this._id;if(e+="",arguments.length<2){for(var r=on(this.node(),n).tween,i=0,o=r.length,s;i<o;++i)if((s=r[i]).name===e)return s.value;return null}return this.each((t==null?rG:iG)(n,e,t))}function Uu(e,t,n){var r=e._id;return e.each(function(){var i=En(this,r);(i.value||(i.value={}))[t]=n.apply(this,arguments)}),function(i){return on(i,r).value[t]}}function Dx(e,t){var n;return(typeof t=="number"?_e:t instanceof Rr?fi:(n=Rr(t))?(t=n,fi):Sp)(e,t)}function oG(e){return function(){this.removeAttribute(e)}}function sG(e){return function(){this.removeAttributeNS(e.space,e.local)}}function aG(e,t,n){var r,i=n+"",o;return function(){var s=this.getAttribute(e);return s===i?null:s===r?o:o=t(r=s,n)}}function cG(e,t,n){var r,i=n+"",o;return function(){var s=this.getAttributeNS(e.space,e.local);return s===i?null:s===r?o:o=t(r=s,n)}}function lG(e,t,n){var r,i,o;return function(){var s,a=n(this),c;return a==null?void this.removeAttribute(e):(s=this.getAttribute(e),c=a+"",s===c?null:s===r&&c===i?o:(i=c,o=t(r=s,a)))}}function uG(e,t,n){var r,i,o;return function(){var s,a=n(this),c;return a==null?void this.removeAttributeNS(e.space,e.local):(s=this.getAttributeNS(e.space,e.local),c=a+"",s===c?null:s===r&&c===i?o:(i=c,o=t(r=s,a)))}}function J5(e,t){var n=Ns(e),r=n==="transform"?dI:Dx;return this.attrTween(e,typeof t=="function"?(n.local?uG:lG)(n,r,Uu(this,"attr."+e,t)):t==null?(n.local?sG:oG)(n):(n.local?cG:aG)(n,r,t))}function fG(e,t){return function(n){this.setAttribute(e,t.call(this,n))}}function hG(e,t){return function(n){this.setAttributeNS(e.space,e.local,t.call(this,n))}}function dG(e,t){var n,r;function i(){var o=t.apply(this,arguments);return o!==r&&(n=(r=o)&&hG(e,o)),n}return i._value=t,i}function pG(e,t){var n,r;function i(){var o=t.apply(this,arguments);return o!==r&&(n=(r=o)&&fG(e,o)),n}return i._value=t,i}function Q5(e,t){var n="attr."+e;if(arguments.length<2)return(n=this.tween(n))&&n._value;if(t==null)return this.tween(n,null);if(typeof t!="function")throw new Error;var r=Ns(e);return this.tween(n,(r.local?dG:pG)(r,t))}function mG(e,t){return function(){Op(this,e).delay=+t.apply(this,arguments)}}function yG(e,t){return t=+t,function(){Op(this,e).delay=t}}function K5(e){var t=this._id;return arguments.length?this.each((typeof e=="function"?mG:yG)(t,e)):on(this.node(),t).delay}function gG(e,t){return function(){En(this,e).duration=+t.apply(this,arguments)}}function xG(e,t){return t=+t,function(){En(this,e).duration=t}}function tC(e){var t=this._id;return arguments.length?this.each((typeof e=="function"?gG:xG)(t,e)):on(this.node(),t).duration}function bG(e,t){if(typeof t!="function")throw new Error;return function(){En(this,e).ease=t}}function eC(e){var t=this._id;return arguments.length?this.each(bG(t,e)):on(this.node(),t).ease}function wG(e,t){return function(){var n=t.apply(this,arguments);if(typeof n!="function")throw new Error;En(this,e).ease=n}}function nC(e){if(typeof e!="function")throw new Error;return this.each(wG(this._id,e))}function rC(e){typeof e!="function"&&(e=pp(e));for(var t=this._groups,n=t.length,r=new Array(n),i=0;i<n;++i)for(var o=t[i],s=o.length,a=r[i]=[],c,l=0;l<s;++l)(c=o[l])&&e.call(c,c.__data__,l,o)&&a.push(c);return new er(r,this._parents,this._name,this._id)}function iC(e){if(e._id!==this._id)throw new Error;for(var t=this._groups,n=e._groups,r=t.length,i=n.length,o=Math.min(r,i),s=new Array(r),a=0;a<o;++a)for(var c=t[a],l=n[a],u=c.length,f=s[a]=new Array(u),h,d=0;d<u;++d)(h=c[d]||l[d])&&(f[d]=h);for(;a<r;++a)s[a]=t[a];return new er(s,this._parents,this._name,this._id)}function vG(e){return(e+"").trim().split(/^|\s+/).every(function(t){var n=t.indexOf(".");return n>=0&&(t=t.slice(0,n)),!t||t==="start"})}function _G(e,t,n){var r,i,o=vG(t)?Op:En;return function(){var s=o(this,e),a=s.on;a!==r&&(i=(r=a).copy()).on(t,n),s.on=i}}function oC(e,t){var n=this._id;return arguments.length<2?on(this.node(),n).on.on(e):this.each(_G(n,e,t))}function SG(e){return function(){var t=this.parentNode;for(var n in this.__transition)if(+n!==e)return;t&&t.removeChild(this)}}function sC(){return this.on("end.remove",SG(this._id))}function aC(e){var t=this._name,n=this._id;typeof e!="function"&&(e=Hc(e));for(var r=this._groups,i=r.length,o=new Array(i),s=0;s<i;++s)for(var a=r[s],c=a.length,l=o[s]=new Array(c),u,f,h=0;h<c;++h)(u=a[h])&&(f=e.call(u,u.__data__,h,a))&&("__data__"in u&&(f.__data__=u.__data__),l[h]=f,La(l[h],t,n,h,l,on(u,n)));return new er(o,this._parents,t,n)}function cC(e){var t=this._name,n=this._id;typeof e!="function"&&(e=dp(e));for(var r=this._groups,i=r.length,o=[],s=[],a=0;a<i;++a)for(var c=r[a],l=c.length,u,f=0;f<l;++f)if(u=c[f]){for(var h=e.call(u,u.__data__,f,c),d,p=on(u,n),m=0,y=h.length;m<y;++m)(d=h[m])&&La(d,t,n,m,h,p);o.push(h),s.push(u)}return new er(o,s,t,n)}var IG=Os.prototype.constructor;function lC(){return new IG(this._groups,this._parents)}function MG(e,t){var n,r,i;return function(){var o=Da(this,e),s=(this.style.removeProperty(e),Da(this,e));return o===s?null:o===n&&s===r?i:i=t(n=o,r=s)}}function uC(e){return function(){this.style.removeProperty(e)}}function AG(e,t,n){var r,i=n+"",o;return function(){var s=Da(this,e);return s===i?null:s===r?o:o=t(r=s,n)}}function TG(e,t,n){var r,i,o;return function(){var s=Da(this,e),a=n(this),c=a+"";return a==null&&(c=a=(this.style.removeProperty(e),Da(this,e))),s===c?null:s===r&&c===i?o:(i=c,o=t(r=s,a))}}function EG(e,t){var n,r,i,o="style."+t,s="end."+o,a;return function(){var c=En(this,e),l=c.on,u=c.value[o]==null?a||(a=uC(t)):void 0;(l!==n||i!==u)&&(r=(n=l).copy()).on(s,i=u),c.on=r}}function fC(e,t,n){var r=(e+="")=="transform"?hI:Dx;return t==null?this.styleTween(e,MG(e,r)).on("end.style."+e,uC(e)):typeof t=="function"?this.styleTween(e,TG(e,r,Uu(this,"style."+e,t))).each(EG(this._id,e)):this.styleTween(e,AG(e,r,t),n).on("end.style."+e,null)}function NG(e,t,n){return function(r){this.style.setProperty(e,t.call(this,r),n)}}function DG(e,t,n){var r,i;function o(){var s=t.apply(this,arguments);return s!==i&&(r=(i=s)&&NG(e,s,n)),r}return o._value=t,o}function hC(e,t,n){var r="style."+(e+="");if(arguments.length<2)return(r=this.tween(r))&&r._value;if(t==null)return this.tween(r,null);if(typeof t!="function")throw new Error;return this.tween(r,DG(e,t,n??""))}function OG(e){return function(){this.textContent=e}}function BG(e){return function(){var t=e(this);this.textContent=t??""}}function dC(e){return this.tween("text",typeof e=="function"?BG(Uu(this,"text",e)):OG(e==null?"":e+""))}function LG(e){return function(t){this.textContent=e.call(this,t)}}function CG(e){var t,n;function r(){var i=e.apply(this,arguments);return i!==n&&(t=(n=i)&&LG(i)),t}return r._value=e,r}function pC(e){var t="text";if(arguments.length<1)return(t=this.tween(t))&&t._value;if(e==null)return this.tween(t,null);if(typeof e!="function")throw new Error;return this.tween(t,CG(e))}function mC(){for(var e=this._name,t=this._id,n=Ox(),r=this._groups,i=r.length,o=0;o<i;++o)for(var s=r[o],a=s.length,c,l=0;l<a;++l)if(c=s[l]){var u=on(c,t);La(c,e,n,l,s,{time:u.time+u.delay+u.duration,delay:0,duration:u.duration,ease:u.ease})}return new er(r,this._parents,e,n)}function yC(){var e,t,n=this,r=n._id,i=n.size();return new Promise(function(o,s){var a={value:s},c={value:function(){--i===0&&o()}};n.each(function(){var l=En(this,r),u=l.on;u!==e&&(t=(e=u).copy(),t._.cancel.push(a),t._.interrupt.push(a),t._.end.push(c)),l.on=t}),i===0&&o()})}var kG=0;function er(e,t,n,r){this._groups=e,this._parents=t,this._name=n,this._id=r}function gC(e){return Os().transition(e)}function Ox(){return++kG}var Cs=Os.prototype;er.prototype=gC.prototype={constructor:er,select:aC,selectAll:cC,selectChild:Cs.selectChild,selectChildren:Cs.selectChildren,filter:rC,merge:iC,selection:lC,transition:mC,call:Cs.call,nodes:Cs.nodes,node:Cs.node,size:Cs.size,empty:Cs.empty,each:Cs.each,on:oC,attr:J5,attrTween:Q5,style:fC,styleTween:hC,text:dC,textTween:pC,remove:sC,tween:Z5,delay:K5,duration:tC,ease:eC,easeVarying:nC,end:yC,[Symbol.iterator]:Cs[Symbol.iterator]};function Bx(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}var FG={time:null,delay:0,duration:250,ease:Bx};function RG(e,t){for(var n;!(n=e.__transition)||!(n=n[t]);)if(!(e=e.parentNode))throw new Error(`transition ${t} not found`);return n}function xC(e){var t,n;e instanceof er?(t=e._id,e=e._name):(t=Ox(),(n=FG).time=Np(),e=e==null?null:e+"");for(var r=this._groups,i=r.length,o=0;o<i;++o)for(var s=r[o],a=s.length,c,l=0;l<a;++l)(c=s[l])&&La(c,e,t,l,s,n||RG(c,t));return new er(r,this._parents,e,t)}Os.prototype.interrupt=H5;Os.prototype.transition=xC;var Lx=e=>()=>e;function xI(e,{sourceEvent:t,target:n,selection:r,mode:i,dispatch:o}){Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},selection:{value:r,enumerable:!0,configurable:!0},mode:{value:i,enumerable:!0,configurable:!0},_:{value:o}})}function bC(e){e.stopImmediatePropagation()}function Cx(e){e.preventDefault(),e.stopImmediatePropagation()}var wC={name:"drag"},bI={name:"space"},zu={name:"handle"},qu={name:"center"},{abs:vC,max:$n,min:Pn}=Math;function _C(e){return[+e[0],+e[1]]}function vI(e){return[_C(e[0]),_C(e[1])]}var kx={name:"x",handles:["w","e"].map(Bp),input:function(e,t){return e==null?null:[[+e[0],t[0][1]],[+e[1],t[1][1]]]},output:function(e){return e&&[e[0][0],e[1][0]]}},Fx={name:"y",handles:["n","s"].map(Bp),input:function(e,t){return e==null?null:[[t[0][0],+e[0]],[t[1][0],+e[1]]]},output:function(e){return e&&[e[0][1],e[1][1]]}},$G={name:"xy",handles:["n","w","e","s","nw","ne","sw","se"].map(Bp),input:function(e){return e==null?null:vI(e)},output:function(e){return e}},ks={overlay:"crosshair",selection:"move",n:"ns-resize",e:"ew-resize",s:"ns-resize",w:"ew-resize",nw:"nwse-resize",ne:"nesw-resize",se:"nwse-resize",sw:"nesw-resize"},SC={e:"w",w:"e",nw:"ne",ne:"nw",se:"sw",sw:"se"},IC={n:"s",s:"n",nw:"sw",ne:"se",se:"ne",sw:"nw"},PG={overlay:1,selection:1,n:null,e:1,s:null,w:-1,nw:-1,ne:1,se:1,sw:-1},UG={overlay:1,selection:1,n:-1,e:null,s:1,w:null,nw:-1,ne:-1,se:1,sw:1};function Bp(e){return{type:e}}function zG(e){return!e.ctrlKey&&!e.button}function qG(){var e=this.ownerSVGElement||this;return e.hasAttribute("viewBox")?(e=e.viewBox.baseVal,[[e.x,e.y],[e.x+e.width,e.y+e.height]]):[[0,0],[e.width.baseVal.value,e.height.baseVal.value]]}function jG(){return navigator.maxTouchPoints||"ontouchstart"in this}function wI(e){for(;!e.__brush;)if(!(e=e.parentNode))return;return e.__brush}function VG(e){return e[0][0]===e[1][0]||e[0][1]===e[1][1]}function _I(){return MI(kx)}function SI(){return MI(Fx)}function II(){return MI($G)}function MI(e){var t=qG,n=zG,r=jG,i=!0,o=Wc("start","brush","end"),s=6,a;function c(y){var g=y.property("__brush",m).selectAll(".overlay").data([Bp("overlay")]);g.enter().append("rect").attr("class","overlay").attr("pointer-events","all").attr("cursor",ks.overlay).merge(g).each(function(){var b=wI(this).extent;Vt(this).attr("x",b[0][0]).attr("y",b[0][1]).attr("width",b[1][0]-b[0][0]).attr("height",b[1][1]-b[0][1])}),y.selectAll(".selection").data([Bp("selection")]).enter().append("rect").attr("class","selection").attr("cursor",ks.selection).attr("fill","#777").attr("fill-opacity",.3).attr("stroke","#fff").attr("shape-rendering","crispEdges");var x=y.selectAll(".handle").data(e.handles,function(b){return b.type});x.exit().remove(),x.enter().append("rect").attr("class",function(b){return"handle handle--"+b.type}).attr("cursor",function(b){return ks[b.type]}),y.each(l).attr("fill","none").attr("pointer-events","all").on("mousedown.brush",h).filter(r).on("touchstart.brush",h).on("touchmove.brush",d).on("touchend.brush touchcancel.brush",p).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}c.move=function(y,g,x){y.tween?y.on("start.brush",function(b){u(this,arguments).beforestart().start(b)}).on("interrupt.brush end.brush",function(b){u(this,arguments).end(b)}).tween("brush",function(){var b=this,w=b.__brush,_=u(b,arguments),v=w.selection,M=e.input(typeof g=="function"?g.apply(this,arguments):g,w.extent),E=$r(v,M);function I(D){w.selection=D===1&&M===null?null:E(D),l.call(b),_.brush()}return v!==null&&M!==null?I:I(1)}):y.each(function(){var b=this,w=arguments,_=b.__brush,v=e.input(typeof g=="function"?g.apply(b,w):g,_.extent),M=u(b,w).beforestart();To(b),_.selection=v===null?null:v,l.call(b),M.start(x).brush(x).end(x)})},c.clear=function(y,g){c.move(y,null,g)};function l(){var y=Vt(this),g=wI(this).selection;g?(y.selectAll(".selection").style("display",null).attr("x",g[0][0]).attr("y",g[0][1]).attr("width",g[1][0]-g[0][0]).attr("height",g[1][1]-g[0][1]),y.selectAll(".handle").style("display",null).attr("x",function(x){return x.type[x.type.length-1]==="e"?g[1][0]-s/2:g[0][0]-s/2}).attr("y",function(x){return x.type[0]==="s"?g[1][1]-s/2:g[0][1]-s/2}).attr("width",function(x){return x.type==="n"||x.type==="s"?g[1][0]-g[0][0]+s:s}).attr("height",function(x){return x.type==="e"||x.type==="w"?g[1][1]-g[0][1]+s:s})):y.selectAll(".selection,.handle").style("display","none").attr("x",null).attr("y",null).attr("width",null).attr("height",null)}function u(y,g,x){var b=y.__brush.emitter;return b&&(!x||!b.clean)?b:new f(y,g,x)}function f(y,g,x){this.that=y,this.args=g,this.state=y.__brush,this.active=0,this.clean=x}f.prototype={beforestart:function(){return++this.active===1&&(this.state.emitter=this,this.starting=!0),this},start:function(y,g){return this.starting?(this.starting=!1,this.emit("start",y,g)):this.emit("brush",y),this},brush:function(y,g){return this.emit("brush",y,g),this},end:function(y,g){return--this.active===0&&(delete this.state.emitter,this.emit("end",y,g)),this},emit:function(y,g,x){var b=Vt(this.that).datum();o.call(y,this.that,new xI(y,{sourceEvent:g,target:c,selection:e.output(this.state.selection),mode:x,dispatch:o}),b)}};function h(y){if(a&&!y.touches||!n.apply(this,arguments))return;var g=this,x=y.target.__data__.type,b=(i&&y.metaKey?x="overlay":x)==="selection"?wC:i&&y.altKey?qu:zu,w=e===Fx?null:PG[x],_=e===kx?null:UG[x],v=wI(g),M=v.extent,E=v.selection,I=M[0][0],D,A,O=M[0][1],C,S,T=M[1][0],N,F,R=M[1][1],k,$,P=0,U=0,W,nt=w&&_&&i&&y.shiftKey,ot,at,Y=Array.from(y.touches||[y],tt=>{let ae=tt.identifier;return tt=Fn(tt,g),tt.point0=tt.slice(),tt.identifier=ae,tt});To(g);var st=u(g,arguments,!0).beforestart();if(x==="overlay"){E&&(W=!0);let tt=[Y[0],Y[1]||Y[0]];v.selection=E=[[D=e===Fx?I:Pn(tt[0][0],tt[1][0]),C=e===kx?O:Pn(tt[0][1],tt[1][1])],[N=e===Fx?T:$n(tt[0][0],tt[1][0]),k=e===kx?R:$n(tt[0][1],tt[1][1])]],Y.length>1&&kt(y)}else D=E[0][0],C=E[0][1],N=E[1][0],k=E[1][1];A=D,S=C,F=N,$=k;var j=Vt(g).attr("pointer-events","none"),Z=j.selectAll(".overlay").attr("cursor",ks[x]);if(y.touches)st.moved=z,st.ended=ht;else{var rt=Vt(y.view).on("mousemove.brush",z,!0).on("mouseup.brush",ht,!0);i&&rt.on("keydown.brush",Wt,!0).on("keyup.brush",Zt,!0),yp(y.view)}l.call(g),st.start(y,b.name);function z(tt){for(let ae of tt.changedTouches||[tt])for(let Ir of Y)Ir.identifier===ae.identifier&&(Ir.cur=Fn(ae,g));if(nt&&!ot&&!at&&Y.length===1){let ae=Y[0];vC(ae.cur[0]-ae[0])>vC(ae.cur[1]-ae[1])?at=!0:ot=!0}for(let ae of Y)ae.cur&&(ae[0]=ae.cur[0],ae[1]=ae.cur[1]);W=!0,Cx(tt),kt(tt)}function kt(tt){let ae=Y[0],Ir=ae.point0;var Hi;switch(P=ae[0]-Ir[0],U=ae[1]-Ir[1],b){case bI:case wC:{w&&(P=$n(I-D,Pn(T-N,P)),A=D+P,F=N+P),_&&(U=$n(O-C,Pn(R-k,U)),S=C+U,$=k+U);break}case zu:{Y[1]?(w&&(A=$n(I,Pn(T,Y[0][0])),F=$n(I,Pn(T,Y[1][0])),w=1),_&&(S=$n(O,Pn(R,Y[0][1])),$=$n(O,Pn(R,Y[1][1])),_=1)):(w<0?(P=$n(I-D,Pn(T-D,P)),A=D+P,F=N):w>0&&(P=$n(I-N,Pn(T-N,P)),A=D,F=N+P),_<0?(U=$n(O-C,Pn(R-C,U)),S=C+U,$=k):_>0&&(U=$n(O-k,Pn(R-k,U)),S=C,$=k+U));break}case qu:{w&&(A=$n(I,Pn(T,D-P*w)),F=$n(I,Pn(T,N+P*w))),_&&(S=$n(O,Pn(R,C-U*_)),$=$n(O,Pn(R,k+U*_)));break}}F<A&&(w*=-1,Hi=D,D=N,N=Hi,Hi=A,A=F,F=Hi,x in SC&&Z.attr("cursor",ks[x=SC[x]])),$<S&&(_*=-1,Hi=C,C=k,k=Hi,Hi=S,S=$,$=Hi,x in IC&&Z.attr("cursor",ks[x=IC[x]])),v.selection&&(E=v.selection),ot&&(A=E[0][0],F=E[1][0]),at&&(S=E[0][1],$=E[1][1]),(E[0][0]!==A||E[0][1]!==S||E[1][0]!==F||E[1][1]!==$)&&(v.selection=[[A,S],[F,$]],l.call(g),st.brush(tt,b.name))}function ht(tt){if(bC(tt),tt.touches){if(tt.touches.length)return;a&&clearTimeout(a),a=setTimeout(function(){a=null},500)}else gp(tt.view,W),rt.on("keydown.brush keyup.brush mousemove.brush mouseup.brush",null);j.attr("pointer-events","all"),Z.attr("cursor",ks.overlay),v.selection&&(E=v.selection),VG(E)&&(v.selection=null,l.call(g)),st.end(tt,b.name)}function Wt(tt){switch(tt.keyCode){case 16:{nt=w&&_;break}case 18:{b===zu&&(w&&(N=F-P*w,D=A+P*w),_&&(k=$-U*_,C=S+U*_),b=qu,kt(tt));break}case 32:{(b===zu||b===qu)&&(w<0?N=F-P:w>0&&(D=A-P),_<0?k=$-U:_>0&&(C=S-U),b=bI,Z.attr("cursor",ks.selection),kt(tt));break}default:return}Cx(tt)}function Zt(tt){switch(tt.keyCode){case 16:{nt&&(ot=at=nt=!1,kt(tt));break}case 18:{b===qu&&(w<0?N=F:w>0&&(D=A),_<0?k=$:_>0&&(C=S),b=zu,kt(tt));break}case 32:{b===bI&&(tt.altKey?(w&&(N=F-P*w,D=A+P*w),_&&(k=$-U*_,C=S+U*_),b=qu):(w<0?N=F:w>0&&(D=A),_<0?k=$:_>0&&(C=S),b=zu),Z.attr("cursor",ks[x]),kt(tt));break}default:return}Cx(tt)}}function d(y){u(this,arguments).moved(y)}function p(y){u(this,arguments).ended(y)}function m(){var y=this.__brush||{selection:null};return y.extent=vI(t.apply(this,arguments)),y.dim=e,y}return c.extent=function(y){return arguments.length?(t=typeof y=="function"?y:Lx(vI(y)),c):t},c.filter=function(y){return arguments.length?(n=typeof y=="function"?y:Lx(!!y),c):n},c.touchable=function(y){return arguments.length?(r=typeof y=="function"?y:Lx(!!y),c):r},c.handleSize=function(y){return arguments.length?(s=+y,c):s},c.keyModifiers=function(y){return arguments.length?(i=!!y,c):i},c.on=function(){var y=o.on.apply(o,arguments);return y===o?c:y},c}var AI=Math.PI,TI=2*AI,nl=1e-6,YG=TI-nl;function MC(e){this._+=e[0];for(let t=1,n=e.length;t<n;++t)this._+=arguments[t]+e[t]}function XG(e){let t=Math.floor(e);if(!(t>=0))throw new Error(`invalid digits: ${e}`);if(t>15)return MC;let n=10**t;return function(r){this._+=r[0];for(let i=1,o=r.length;i<o;++i)this._+=Math.round(arguments[i]*n)/n+r[i]}}var Ca=class{constructor(t){this._x0=this._y0=this._x1=this._y1=null,this._="",this._append=t==null?MC:XG(t)}moveTo(t,n){this._append`M${this._x0=this._x1=+t},${this._y0=this._y1=+n}`}closePath(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._append`Z`)}lineTo(t,n){this._append`L${this._x1=+t},${this._y1=+n}`}quadraticCurveTo(t,n,r,i){this._append`Q${+t},${+n},${this._x1=+r},${this._y1=+i}`}bezierCurveTo(t,n,r,i,o,s){this._append`C${+t},${+n},${+r},${+i},${this._x1=+o},${this._y1=+s}`}arcTo(t,n,r,i,o){if(t=+t,n=+n,r=+r,i=+i,o=+o,o<0)throw new Error(`negative radius: ${o}`);let s=this._x1,a=this._y1,c=r-t,l=i-n,u=s-t,f=a-n,h=u*u+f*f;if(this._x1===null)this._append`M${this._x1=t},${this._y1=n}`;else if(h>nl)if(!(Math.abs(f*c-l*u)>nl)||!o)this._append`L${this._x1=t},${this._y1=n}`;else{let d=r-s,p=i-a,m=c*c+l*l,y=d*d+p*p,g=Math.sqrt(m),x=Math.sqrt(h),b=o*Math.tan((AI-Math.acos((m+h-y)/(2*g*x)))/2),w=b/x,_=b/g;Math.abs(w-1)>nl&&this._append`L${t+w*u},${n+w*f}`,this._append`A${o},${o},0,0,${+(f*d>u*p)},${this._x1=t+_*c},${this._y1=n+_*l}`}}arc(t,n,r,i,o,s){if(t=+t,n=+n,r=+r,s=!!s,r<0)throw new Error(`negative radius: ${r}`);let a=r*Math.cos(i),c=r*Math.sin(i),l=t+a,u=n+c,f=1^s,h=s?i-o:o-i;this._x1===null?this._append`M${l},${u}`:(Math.abs(this._x1-l)>nl||Math.abs(this._y1-u)>nl)&&this._append`L${l},${u}`,r&&(h<0&&(h=h%TI+TI),h>YG?this._append`A${r},${r},0,1,${f},${t-a},${n-c}A${r},${r},0,1,${f},${this._x1=l},${this._y1=u}`:h>nl&&this._append`A${r},${r},0,${+(h>=AI)},${f},${this._x1=t+r*Math.cos(o)},${this._y1=n+r*Math.sin(o)}`)}rect(t,n,r,i){this._append`M${this._x0=this._x1=+t},${this._y0=this._y1=+n}h${r=+r}v${+i}h${-r}Z`}toString(){return this._}};function AC(){return new Ca}AC.prototype=Ca.prototype;function nr(e=3){return new Ca(+e)}var GG=Array.prototype,Rx=GG.slice;function TC(e,t){return e-t}function EC(e){for(var t=0,n=e.length,r=e[n-1][1]*e[0][0]-e[n-1][0]*e[0][1];++t<n;)r+=e[t-1][1]*e[t][0]-e[t-1][0]*e[t][1];return r}var Eo=e=>()=>e;function NC(e,t){for(var n=-1,r=t.length,i;++n<r;)if(i=WG(e,t[n]))return i;return 0}function WG(e,t){for(var n=t[0],r=t[1],i=-1,o=0,s=e.length,a=s-1;o<s;a=o++){var c=e[o],l=c[0],u=c[1],f=e[a],h=f[0],d=f[1];if(HG(c,f,t))return 0;u>r!=d>r&&n<(h-l)*(r-u)/(d-u)+l&&(i=-i)}return i}function HG(e,t,n){var r;return ZG(e,t,n)&&JG(e[r=+(e[0]===t[0])],n[r],t[r])}function ZG(e,t,n){return(t[0]-e[0])*(n[1]-e[1])===(n[0]-e[0])*(t[1]-e[1])}function JG(e,t,n){return e<=t&&t<=n||n<=t&&t<=e}function DC(){}var Fs=[[],[[[1,1.5],[.5,1]]],[[[1.5,1],[1,1.5]]],[[[1.5,1],[.5,1]]],[[[1,.5],[1.5,1]]],[[[1,1.5],[.5,1]],[[1,.5],[1.5,1]]],[[[1,.5],[1,1.5]]],[[[1,.5],[.5,1]]],[[[.5,1],[1,.5]]],[[[1,1.5],[1,.5]]],[[[.5,1],[1,.5]],[[1.5,1],[1,1.5]]],[[[1.5,1],[1,.5]]],[[[.5,1],[1.5,1]]],[[[1,1.5],[1.5,1]]],[[[.5,1],[1,1.5]]],[]];function ka(){var e=1,t=1,n=Ea,r=c;function i(l){var u=n(l);if(Array.isArray(u))u=u.slice().sort(TC);else{let f=le(l,QG);for(u=An(...Du(f[0],f[1],u),u);u[u.length-1]>=f[1];)u.pop();for(;u[1]<f[0];)u.shift()}return u.map(f=>o(l,f))}function o(l,u){let f=u==null?NaN:+u;if(isNaN(f))throw new Error(`invalid value: ${u}`);var h=[],d=[];return s(l,f,function(p){r(p,l,f),EC(p)>0?h.push([p]):d.push(p)}),d.forEach(function(p){for(var m=0,y=h.length,g;m<y;++m)if(NC((g=h[m])[0],p)!==-1){g.push(p);return}}),{type:"MultiPolygon",value:u,coordinates:h}}function s(l,u,f){var h=new Array,d=new Array,p,m,y,g,x,b;for(p=m=-1,g=rl(l[0],u),Fs[g<<1].forEach(w);++p<e-1;)y=g,g=rl(l[p+1],u),Fs[y|g<<1].forEach(w);for(Fs[g<<0].forEach(w);++m<t-1;){for(p=-1,g=rl(l[m*e+e],u),x=rl(l[m*e],u),Fs[g<<1|x<<2].forEach(w);++p<e-1;)y=g,g=rl(l[m*e+e+p+1],u),b=x,x=rl(l[m*e+p+1],u),Fs[y|g<<1|x<<2|b<<3].forEach(w);Fs[g|x<<3].forEach(w)}for(p=-1,x=l[m*e]>=u,Fs[x<<2].forEach(w);++p<e-1;)b=x,x=rl(l[m*e+p+1],u),Fs[x<<2|b<<3].forEach(w);Fs[x<<3].forEach(w);function w(_){var v=[_[0][0]+p,_[0][1]+m],M=[_[1][0]+p,_[1][1]+m],E=a(v),I=a(M),D,A;(D=d[E])?(A=h[I])?(delete d[D.end],delete h[A.start],D===A?(D.ring.push(M),f(D.ring)):h[D.start]=d[A.end]={start:D.start,end:A.end,ring:D.ring.concat(A.ring)}):(delete d[D.end],D.ring.push(M),d[D.end=I]=D):(D=h[I])?(A=d[E])?(delete h[D.start],delete d[A.end],D===A?(D.ring.push(M),f(D.ring)):h[A.start]=d[D.end]={start:A.start,end:D.end,ring:A.ring.concat(D.ring)}):(delete h[D.start],D.ring.unshift(v),h[D.start=E]=D):h[E]=d[I]={start:E,end:I,ring:[v,M]}}}function a(l){return l[0]*2+l[1]*(e+1)*4}function c(l,u,f){l.forEach(function(h){var d=h[0],p=h[1],m=d|0,y=p|0,g=EI(u[y*e+m]);d>0&&d<e&&m===d&&(h[0]=OC(d,EI(u[y*e+m-1]),g,f)),p>0&&p<t&&y===p&&(h[1]=OC(p,EI(u[(y-1)*e+m]),g,f))})}return i.contour=o,i.size=function(l){if(!arguments.length)return[e,t];var u=Math.floor(l[0]),f=Math.floor(l[1]);if(!(u>=0&&f>=0))throw new Error("invalid size");return e=u,t=f,i},i.thresholds=function(l){return arguments.length?(n=typeof l=="function"?l:Array.isArray(l)?Eo(Rx.call(l)):Eo(l),i):n},i.smooth=function(l){return arguments.length?(r=l?c:DC,i):r===c},i}function QG(e){return isFinite(e)?e:NaN}function rl(e,t){return e==null?!1:+e>=t}function EI(e){return e==null||isNaN(e=+e)?-1/0:e}function OC(e,t,n,r){let i=r-t,o=n-t,s=isFinite(i)||isFinite(o)?i/o:Math.sign(i)/Math.sign(o);return isNaN(s)?e:e+s-.5}function KG(e){return e[0]}function tW(e){return e[1]}function eW(){return 1}function NI(){var e=KG,t=tW,n=eW,r=960,i=500,o=20,s=2,a=o*3,c=r+a*2>>s,l=i+a*2>>s,u=Eo(20);function f(x){var b=new Float32Array(c*l),w=Math.pow(2,-s),_=-1;for(let C of x){var v=(e(C,++_,x)+a)*w,M=(t(C,_,x)+a)*w,E=+n(C,_,x);if(E&&v>=0&&v<c&&M>=0&&M<l){var I=Math.floor(v),D=Math.floor(M),A=v-I-.5,O=M-D-.5;b[I+D*c]+=(1-A)*(1-O)*E,b[I+1+D*c]+=A*(1-O)*E,b[I+1+(D+1)*c]+=A*O*E,b[I+(D+1)*c]+=(1-A)*O*E}}return ap({data:b,width:c,height:l},o*w),b}function h(x){var b=f(x),w=u(b),_=Math.pow(2,2*s);return Array.isArray(w)||(w=An(Number.MIN_VALUE,Ht(b)/_,w)),ka().size([c,l]).thresholds(w.map(v=>v*_))(b).map((v,M)=>(v.value=+w[M],d(v)))}h.contours=function(x){var b=f(x),w=ka().size([c,l]),_=Math.pow(2,2*s),v=M=>{M=+M;var E=d(w.contour(b,M*_));return E.value=M,E};return Object.defineProperty(v,"max",{get:()=>Ht(b)/_}),v};function d(x){return x.coordinates.forEach(p),x}function p(x){x.forEach(m)}function m(x){x.forEach(y)}function y(x){x[0]=x[0]*Math.pow(2,s)-a,x[1]=x[1]*Math.pow(2,s)-a}function g(){return a=o*3,c=r+a*2>>s,l=i+a*2>>s,h}return h.x=function(x){return arguments.length?(e=typeof x=="function"?x:Eo(+x),h):e},h.y=function(x){return arguments.length?(t=typeof x=="function"?x:Eo(+x),h):t},h.weight=function(x){return arguments.length?(n=typeof x=="function"?x:Eo(+x),h):n},h.size=function(x){if(!arguments.length)return[r,i];var b=+x[0],w=+x[1];if(!(b>=0&&w>=0))throw new Error("invalid size");return r=b,i=w,g()},h.cellSize=function(x){if(!arguments.length)return 1<<s;if(!((x=+x)>=1))throw new Error("invalid cell size");return s=Math.floor(Math.log(x)/Math.LN2),g()},h.thresholds=function(x){return arguments.length?(u=typeof x=="function"?x:Array.isArray(x)?Eo(Rx.call(x)):Eo(x),h):u},h.bandwidth=function(x){if(!arguments.length)return Math.sqrt(o*(o+1));if(!((x=+x)>=0))throw new Error("invalid bandwidth");return o=(Math.sqrt(4*x*x+1)-1)/2,g()},h}var Kt=11102230246251565e-32,We=134217729,Lp=(3+8*Kt)*Kt;function il(e,t,n,r,i){let o,s,a,c,l=t[0],u=r[0],f=0,h=0;u>l==u>-l?(o=l,l=t[++f]):(o=u,u=r[++h]);let d=0;if(f<e&&h<n)for(u>l==u>-l?(s=l+o,a=o-(s-l),l=t[++f]):(s=u+o,a=o-(s-u),u=r[++h]),o=s,a!==0&&(i[d++]=a);f<e&&h<n;)u>l==u>-l?(s=o+l,c=s-o,a=o-(s-c)+(l-c),l=t[++f]):(s=o+u,c=s-o,a=o-(s-c)+(u-c),u=r[++h]),o=s,a!==0&&(i[d++]=a);for(;f<e;)s=o+l,c=s-o,a=o-(s-c)+(l-c),l=t[++f],o=s,a!==0&&(i[d++]=a);for(;h<n;)s=o+u,c=s-o,a=o-(s-c)+(u-c),u=r[++h],o=s,a!==0&&(i[d++]=a);return(o!==0||d===0)&&(i[d++]=o),d}function Cp(e,t){let n=t[0];for(let r=1;r<e;r++)n+=t[r];return n}function V(e){return new Float64Array(e)}var nW=(3+16*Kt)*Kt,rW=(2+12*Kt)*Kt,iW=(9+64*Kt)*Kt*Kt,ju=V(4),BC=V(8),LC=V(12),CC=V(16),rr=V(4);function oW(e,t,n,r,i,o,s){let a,c,l,u,f,h,d,p,m,y,g,x,b,w,_,v,M,E,I=e-i,D=n-i,A=t-o,O=r-o;w=I*O,h=We*I,d=h-(h-I),p=I-d,h=We*O,m=h-(h-O),y=O-m,_=p*y-(w-d*m-p*m-d*y),v=A*D,h=We*A,d=h-(h-A),p=A-d,h=We*D,m=h-(h-D),y=D-m,M=p*y-(v-d*m-p*m-d*y),g=_-M,f=_-g,ju[0]=_-(g+f)+(f-M),x=w+g,f=x-w,b=w-(x-f)+(g-f),g=b-v,f=b-g,ju[1]=b-(g+f)+(f-v),E=x+g,f=E-x,ju[2]=x-(E-f)+(g-f),ju[3]=E;let C=Cp(4,ju),S=rW*s;if(C>=S||-C>=S||(f=e-I,a=e-(I+f)+(f-i),f=n-D,l=n-(D+f)+(f-i),f=t-A,c=t-(A+f)+(f-o),f=r-O,u=r-(O+f)+(f-o),a===0&&c===0&&l===0&&u===0)||(S=iW*s+Lp*Math.abs(C),C+=I*u+O*a-(A*l+D*c),C>=S||-C>=S))return C;w=a*O,h=We*a,d=h-(h-a),p=a-d,h=We*O,m=h-(h-O),y=O-m,_=p*y-(w-d*m-p*m-d*y),v=c*D,h=We*c,d=h-(h-c),p=c-d,h=We*D,m=h-(h-D),y=D-m,M=p*y-(v-d*m-p*m-d*y),g=_-M,f=_-g,rr[0]=_-(g+f)+(f-M),x=w+g,f=x-w,b=w-(x-f)+(g-f),g=b-v,f=b-g,rr[1]=b-(g+f)+(f-v),E=x+g,f=E-x,rr[2]=x-(E-f)+(g-f),rr[3]=E;let T=il(4,ju,4,rr,BC);w=I*u,h=We*I,d=h-(h-I),p=I-d,h=We*u,m=h-(h-u),y=u-m,_=p*y-(w-d*m-p*m-d*y),v=A*l,h=We*A,d=h-(h-A),p=A-d,h=We*l,m=h-(h-l),y=l-m,M=p*y-(v-d*m-p*m-d*y),g=_-M,f=_-g,rr[0]=_-(g+f)+(f-M),x=w+g,f=x-w,b=w-(x-f)+(g-f),g=b-v,f=b-g,rr[1]=b-(g+f)+(f-v),E=x+g,f=E-x,rr[2]=x-(E-f)+(g-f),rr[3]=E;let N=il(T,BC,4,rr,LC);w=a*u,h=We*a,d=h-(h-a),p=a-d,h=We*u,m=h-(h-u),y=u-m,_=p*y-(w-d*m-p*m-d*y),v=c*l,h=We*c,d=h-(h-c),p=c-d,h=We*l,m=h-(h-l),y=l-m,M=p*y-(v-d*m-p*m-d*y),g=_-M,f=_-g,rr[0]=_-(g+f)+(f-M),x=w+g,f=x-w,b=w-(x-f)+(g-f),g=b-v,f=b-g,rr[1]=b-(g+f)+(f-v),E=x+g,f=E-x,rr[2]=x-(E-f)+(g-f),rr[3]=E;let F=il(N,LC,4,rr,CC);return CC[F-1]}function Vu(e,t,n,r,i,o){let s=(t-o)*(n-i),a=(e-i)*(r-o),c=s-a,l=Math.abs(s+a);return Math.abs(c)>=nW*l?c:-oW(e,t,n,r,i,o,l)}var d_t=(7+56*Kt)*Kt,p_t=(3+28*Kt)*Kt,m_t=(26+288*Kt)*Kt*Kt,y_t=V(4),g_t=V(4),x_t=V(4),b_t=V(4),w_t=V(4),v_t=V(4),__t=V(4),S_t=V(4),I_t=V(4),M_t=V(8),A_t=V(8),T_t=V(8),E_t=V(4),N_t=V(8),D_t=V(8),O_t=V(8),B_t=V(12),L_t=V(192),C_t=V(192);var R_t=(10+96*Kt)*Kt,$_t=(4+48*Kt)*Kt,P_t=(44+576*Kt)*Kt*Kt,U_t=V(4),z_t=V(4),q_t=V(4),j_t=V(4),V_t=V(4),Y_t=V(4),X_t=V(4),G_t=V(4),W_t=V(8),H_t=V(8),Z_t=V(8),J_t=V(8),Q_t=V(8),K_t=V(8),t2t=V(8),e2t=V(8),n2t=V(8),r2t=V(4),i2t=V(4),o2t=V(4),s2t=V(8),a2t=V(16),c2t=V(16),l2t=V(16),u2t=V(32),f2t=V(32),h2t=V(48),d2t=V(64),p2t=V(1152),m2t=V(1152);var b2t=(16+224*Kt)*Kt,w2t=(5+72*Kt)*Kt,v2t=(71+1408*Kt)*Kt*Kt,_2t=V(4),S2t=V(4),I2t=V(4),M2t=V(4),A2t=V(4),T2t=V(4),E2t=V(4),N2t=V(4),D2t=V(4),O2t=V(4),B2t=V(24),L2t=V(24),C2t=V(24),k2t=V(24),F2t=V(24),R2t=V(24),$2t=V(24),P2t=V(24),U2t=V(24),z2t=V(24),q2t=V(1152),j2t=V(1152),V2t=V(1152),Y2t=V(1152),X2t=V(1152),G2t=V(2304),W2t=V(2304),H2t=V(3456),Z2t=V(5760),J2t=V(8),Q2t=V(8),K2t=V(8),tSt=V(16),eSt=V(24),nSt=V(48),rSt=V(48),iSt=V(96),oSt=V(192),sSt=V(384),aSt=V(384),cSt=V(384),lSt=V(768);var uSt=V(96),fSt=V(96),hSt=V(96),dSt=V(1152);var FC=Math.pow(2,-52),$x=new Uint32Array(512),Xu=class e{static from(t,n=fW,r=hW){let i=t.length,o=new Float64Array(i*2);for(let s=0;s<i;s++){let a=t[s];o[2*s]=n(a),o[2*s+1]=r(a)}return new e(o)}constructor(t){let n=t.length>>1;if(n>0&&typeof t[0]!="number")throw new Error("Expected coords to contain numbers.");this.coords=t;let r=Math.max(2*n-5,0);this._triangles=new Uint32Array(r*3),this._halfedges=new Int32Array(r*3),this._hashSize=Math.ceil(Math.sqrt(n)),this._hullPrev=new Uint32Array(n),this._hullNext=new Uint32Array(n),this._hullTri=new Uint32Array(n),this._hullHash=new Int32Array(this._hashSize),this._ids=new Uint32Array(n),this._dists=new Float64Array(n),this.update()}update(){let{coords:t,_hullPrev:n,_hullNext:r,_hullTri:i,_hullHash:o}=this,s=t.length>>1,a=1/0,c=1/0,l=-1/0,u=-1/0;for(let I=0;I<s;I++){let D=t[2*I],A=t[2*I+1];D<a&&(a=D),A<c&&(c=A),D>l&&(l=D),A>u&&(u=A),this._ids[I]=I}let f=(a+l)/2,h=(c+u)/2,d,p,m;for(let I=0,D=1/0;I<s;I++){let A=DI(f,h,t[2*I],t[2*I+1]);A<D&&(d=I,D=A)}let y=t[2*d],g=t[2*d+1];for(let I=0,D=1/0;I<s;I++){if(I===d)continue;let A=DI(y,g,t[2*I],t[2*I+1]);A<D&&A>0&&(p=I,D=A)}let x=t[2*p],b=t[2*p+1],w=1/0;for(let I=0;I<s;I++){if(I===d||I===p)continue;let D=lW(y,g,x,b,t[2*I],t[2*I+1]);D<w&&(m=I,w=D)}let _=t[2*m],v=t[2*m+1];if(w===1/0){for(let A=0;A<s;A++)this._dists[A]=t[2*A]-t[0]||t[2*A+1]-t[1];Yu(this._ids,this._dists,0,s-1);let I=new Uint32Array(s),D=0;for(let A=0,O=-1/0;A<s;A++){let C=this._ids[A],S=this._dists[C];S>O&&(I[D++]=C,O=S)}this.hull=I.subarray(0,D),this.triangles=new Uint32Array(0),this.halfedges=new Uint32Array(0);return}if(Vu(y,g,x,b,_,v)<0){let I=p,D=x,A=b;p=m,x=_,b=v,m=I,_=D,v=A}let M=uW(y,g,x,b,_,v);this._cx=M.x,this._cy=M.y;for(let I=0;I<s;I++)this._dists[I]=DI(t[2*I],t[2*I+1],M.x,M.y);Yu(this._ids,this._dists,0,s-1),this._hullStart=d;let E=3;r[d]=n[m]=p,r[p]=n[d]=m,r[m]=n[p]=d,i[d]=0,i[p]=1,i[m]=2,o.fill(-1),o[this._hashKey(y,g)]=d,o[this._hashKey(x,b)]=p,o[this._hashKey(_,v)]=m,this.trianglesLen=0,this._addTriangle(d,p,m,-1,-1,-1);for(let I=0,D,A;I<this._ids.length;I++){let O=this._ids[I],C=t[2*O],S=t[2*O+1];if(I>0&&Math.abs(C-D)<=FC&&Math.abs(S-A)<=FC||(D=C,A=S,O===d||O===p||O===m))continue;let T=0;for(let $=0,P=this._hashKey(C,S);$<this._hashSize&&(T=o[(P+$)%this._hashSize],!(T!==-1&&T!==r[T]));$++);T=n[T];let N=T,F;for(;F=r[N],Vu(C,S,t[2*N],t[2*N+1],t[2*F],t[2*F+1])>=0;)if(N=F,N===T){N=-1;break}if(N===-1)continue;let R=this._addTriangle(N,O,r[N],-1,-1,i[N]);i[O]=this._legalize(R+2),i[N]=R,E++;let k=r[N];for(;F=r[k],Vu(C,S,t[2*k],t[2*k+1],t[2*F],t[2*F+1])<0;)R=this._addTriangle(k,O,F,i[O],-1,i[k]),i[O]=this._legalize(R+2),r[k]=k,E--,k=F;if(N===T)for(;F=n[N],Vu(C,S,t[2*F],t[2*F+1],t[2*N],t[2*N+1])<0;)R=this._addTriangle(F,O,N,-1,i[N],i[F]),this._legalize(R+2),i[F]=R,r[N]=N,E--,N=F;this._hullStart=n[O]=N,r[N]=n[k]=O,r[O]=k,o[this._hashKey(C,S)]=O,o[this._hashKey(t[2*N],t[2*N+1])]=N}this.hull=new Uint32Array(E);for(let I=0,D=this._hullStart;I<E;I++)this.hull[I]=D,D=r[D];this.triangles=this._triangles.subarray(0,this.trianglesLen),this.halfedges=this._halfedges.subarray(0,this.trianglesLen)}_hashKey(t,n){return Math.floor(aW(t-this._cx,n-this._cy)*this._hashSize)%this._hashSize}_legalize(t){let{_triangles:n,_halfedges:r,coords:i}=this,o=0,s=0;for(;;){let a=r[t],c=t-t%3;if(s=c+(t+2)%3,a===-1){if(o===0)break;t=$x[--o];continue}let l=a-a%3,u=c+(t+1)%3,f=l+(a+2)%3,h=n[s],d=n[t],p=n[u],m=n[f];if(cW(i[2*h],i[2*h+1],i[2*d],i[2*d+1],i[2*p],i[2*p+1],i[2*m],i[2*m+1])){n[t]=m,n[a]=h;let g=r[f];if(g===-1){let b=this._hullStart;do{if(this._hullTri[b]===f){this._hullTri[b]=t;break}b=this._hullPrev[b]}while(b!==this._hullStart)}this._link(t,g),this._link(a,r[s]),this._link(s,f);let x=l+(a+1)%3;o<$x.length&&($x[o++]=x)}else{if(o===0)break;t=$x[--o]}}return s}_link(t,n){this._halfedges[t]=n,n!==-1&&(this._halfedges[n]=t)}_addTriangle(t,n,r,i,o,s){let a=this.trianglesLen;return this._triangles[a]=t,this._triangles[a+1]=n,this._triangles[a+2]=r,this._link(a,i),this._link(a+1,o),this._link(a+2,s),this.trianglesLen+=3,a}};function aW(e,t){let n=e/(Math.abs(e)+Math.abs(t));return(t>0?3-n:1+n)/4}function DI(e,t,n,r){let i=e-n,o=t-r;return i*i+o*o}function cW(e,t,n,r,i,o,s,a){let c=e-s,l=t-a,u=n-s,f=r-a,h=i-s,d=o-a,p=c*c+l*l,m=u*u+f*f,y=h*h+d*d;return c*(f*y-m*d)-l*(u*y-m*h)+p*(u*d-f*h)<0}function lW(e,t,n,r,i,o){let s=n-e,a=r-t,c=i-e,l=o-t,u=s*s+a*a,f=c*c+l*l,h=.5/(s*l-a*c),d=(l*u-a*f)*h,p=(s*f-c*u)*h;return d*d+p*p}function uW(e,t,n,r,i,o){let s=n-e,a=r-t,c=i-e,l=o-t,u=s*s+a*a,f=c*c+l*l,h=.5/(s*l-a*c),d=e+(l*u-a*f)*h,p=t+(s*f-c*u)*h;return{x:d,y:p}}function Yu(e,t,n,r){if(r-n<=20)for(let i=n+1;i<=r;i++){let o=e[i],s=t[o],a=i-1;for(;a>=n&&t[e[a]]>s;)e[a+1]=e[a--];e[a+1]=o}else{let i=n+r>>1,o=n+1,s=r;kp(e,i,o),t[e[n]]>t[e[r]]&&kp(e,n,r),t[e[o]]>t[e[r]]&&kp(e,o,r),t[e[n]]>t[e[o]]&&kp(e,n,o);let a=e[o],c=t[a];for(;;){do o++;while(t[e[o]]<c);do s--;while(t[e[s]]>c);if(s<o)break;kp(e,o,s)}e[n+1]=e[s],e[s]=a,r-o+1>=s-n?(Yu(e,t,o,r),Yu(e,t,n,s-1)):(Yu(e,t,n,s-1),Yu(e,t,o,r))}}function kp(e,t,n){let r=e[t];e[t]=e[n],e[n]=r}function fW(e){return e[0]}function hW(e){return e[1]}var hi=class{constructor(){this._x0=this._y0=this._x1=this._y1=null,this._=""}moveTo(t,n){this._+=`M${this._x0=this._x1=+t},${this._y0=this._y1=+n}`}closePath(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")}lineTo(t,n){this._+=`L${this._x1=+t},${this._y1=+n}`}arc(t,n,r){t=+t,n=+n,r=+r;let i=t+r,o=n;if(r<0)throw new Error("negative radius");this._x1===null?this._+=`M${i},${o}`:(Math.abs(this._x1-i)>1e-6||Math.abs(this._y1-o)>1e-6)&&(this._+="L"+i+","+o),r&&(this._+=`A${r},${r},0,1,1,${t-r},${n}A${r},${r},0,1,1,${this._x1=i},${this._y1=o}`)}rect(t,n,r,i){this._+=`M${this._x0=this._x1=+t},${this._y0=this._y1=+n}h${+r}v${+i}h${-r}Z`}value(){return this._||null}};var Fa=class{constructor(){this._=[]}moveTo(t,n){this._.push([t,n])}closePath(){this._.push(this._[0].slice())}lineTo(t,n){this._.push([t,n])}value(){return this._.length?this._:null}};var Fp=class{constructor(t,[n,r,i,o]=[0,0,960,500]){if(!((i=+i)>=(n=+n))||!((o=+o)>=(r=+r)))throw new Error("invalid bounds");this.delaunay=t,this._circumcenters=new Float64Array(t.points.length*2),this.vectors=new Float64Array(t.points.length*2),this.xmax=i,this.xmin=n,this.ymax=o,this.ymin=r,this._init()}update(){return this.delaunay.update(),this._init(),this}_init(){let{delaunay:{points:t,hull:n,triangles:r},vectors:i}=this,o,s,a=this.circumcenters=this._circumcenters.subarray(0,r.length/3*2);for(let m=0,y=0,g=r.length,x,b;m<g;m+=3,y+=2){let w=r[m]*2,_=r[m+1]*2,v=r[m+2]*2,M=t[w],E=t[w+1],I=t[_],D=t[_+1],A=t[v],O=t[v+1],C=I-M,S=D-E,T=A-M,N=O-E,F=(C*N-S*T)*2;if(Math.abs(F)<1e-9){if(o===void 0){o=s=0;for(let k of n)o+=t[k*2],s+=t[k*2+1];o/=n.length,s/=n.length}let R=1e9*Math.sign((o-M)*N-(s-E)*T);x=(M+A)/2-R*N,b=(E+O)/2+R*T}else{let R=1/F,k=C*C+S*S,$=T*T+N*N;x=M+(N*k-S*$)*R,b=E+(C*$-T*k)*R}a[y]=x,a[y+1]=b}let c=n[n.length-1],l,u=c*4,f,h=t[2*c],d,p=t[2*c+1];i.fill(0);for(let m=0;m<n.length;++m)c=n[m],l=u,f=h,d=p,u=c*4,h=t[2*c],p=t[2*c+1],i[l+2]=i[u]=d-p,i[l+3]=i[u+1]=h-f}render(t){let n=t==null?t=new hi:void 0,{delaunay:{halfedges:r,inedges:i,hull:o},circumcenters:s,vectors:a}=this;if(o.length<=1)return null;for(let u=0,f=r.length;u<f;++u){let h=r[u];if(h<u)continue;let d=Math.floor(u/3)*2,p=Math.floor(h/3)*2,m=s[d],y=s[d+1],g=s[p],x=s[p+1];this._renderSegment(m,y,g,x,t)}let c,l=o[o.length-1];for(let u=0;u<o.length;++u){c=l,l=o[u];let f=Math.floor(i[l]/3)*2,h=s[f],d=s[f+1],p=c*4,m=this._project(h,d,a[p+2],a[p+3]);m&&this._renderSegment(h,d,m[0],m[1],t)}return n&&n.value()}renderBounds(t){let n=t==null?t=new hi:void 0;return t.rect(this.xmin,this.ymin,this.xmax-this.xmin,this.ymax-this.ymin),n&&n.value()}renderCell(t,n){let r=n==null?n=new hi:void 0,i=this._clip(t);if(i===null||!i.length)return;n.moveTo(i[0],i[1]);let o=i.length;for(;i[0]===i[o-2]&&i[1]===i[o-1]&&o>1;)o-=2;for(let s=2;s<o;s+=2)(i[s]!==i[s-2]||i[s+1]!==i[s-1])&&n.lineTo(i[s],i[s+1]);return n.closePath(),r&&r.value()}*cellPolygons(){let{delaunay:{points:t}}=this;for(let n=0,r=t.length/2;n<r;++n){let i=this.cellPolygon(n);i&&(i.index=n,yield i)}}cellPolygon(t){let n=new Fa;return this.renderCell(t,n),n.value()}_renderSegment(t,n,r,i,o){let s,a=this._regioncode(t,n),c=this._regioncode(r,i);a===0&&c===0?(o.moveTo(t,n),o.lineTo(r,i)):(s=this._clipSegment(t,n,r,i,a,c))&&(o.moveTo(s[0],s[1]),o.lineTo(s[2],s[3]))}contains(t,n,r){return n=+n,n!==n||(r=+r,r!==r)?!1:this.delaunay._step(t,n,r)===t}*neighbors(t){let n=this._clip(t);if(n)for(let r of this.delaunay.neighbors(t)){let i=this._clip(r);if(i){t:for(let o=0,s=n.length;o<s;o+=2)for(let a=0,c=i.length;a<c;a+=2)if(n[o]===i[a]&&n[o+1]===i[a+1]&&n[(o+2)%s]===i[(a+c-2)%c]&&n[(o+3)%s]===i[(a+c-1)%c]){yield r;break t}}}}_cell(t){let{circumcenters:n,delaunay:{inedges:r,halfedges:i,triangles:o}}=this,s=r[t];if(s===-1)return null;let a=[],c=s;do{let l=Math.floor(c/3);if(a.push(n[l*2],n[l*2+1]),c=c%3===2?c-2:c+1,o[c]!==t)break;c=i[c]}while(c!==s&&c!==-1);return a}_clip(t){if(t===0&&this.delaunay.hull.length===1)return[this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax,this.xmin,this.ymin];let n=this._cell(t);if(n===null)return null;let{vectors:r}=this,i=t*4;return this._simplify(r[i]||r[i+1]?this._clipInfinite(t,n,r[i],r[i+1],r[i+2],r[i+3]):this._clipFinite(t,n))}_clipFinite(t,n){let r=n.length,i=null,o,s,a=n[r-2],c=n[r-1],l,u=this._regioncode(a,c),f,h=0;for(let d=0;d<r;d+=2)if(o=a,s=c,a=n[d],c=n[d+1],l=u,u=this._regioncode(a,c),l===0&&u===0)f=h,h=0,i?i.push(a,c):i=[a,c];else{let p,m,y,g,x;if(l===0){if((p=this._clipSegment(o,s,a,c,l,u))===null)continue;[m,y,g,x]=p}else{if((p=this._clipSegment(a,c,o,s,u,l))===null)continue;[g,x,m,y]=p,f=h,h=this._edgecode(m,y),f&&h&&this._edge(t,f,h,i,i.length),i?i.push(m,y):i=[m,y]}f=h,h=this._edgecode(g,x),f&&h&&this._edge(t,f,h,i,i.length),i?i.push(g,x):i=[g,x]}if(i)f=h,h=this._edgecode(i[0],i[1]),f&&h&&this._edge(t,f,h,i,i.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 i}_clipSegment(t,n,r,i,o,s){let a=o<s;for(a&&([t,n,r,i,o,s]=[r,i,t,n,s,o]);;){if(o===0&&s===0)return a?[r,i,t,n]:[t,n,r,i];if(o&s)return null;let c,l,u=o||s;u&8?(c=t+(r-t)*(this.ymax-n)/(i-n),l=this.ymax):u&4?(c=t+(r-t)*(this.ymin-n)/(i-n),l=this.ymin):u&2?(l=n+(i-n)*(this.xmax-t)/(r-t),c=this.xmax):(l=n+(i-n)*(this.xmin-t)/(r-t),c=this.xmin),o?(t=c,n=l,o=this._regioncode(t,n)):(r=c,i=l,s=this._regioncode(r,i))}}_clipInfinite(t,n,r,i,o,s){let a=Array.from(n),c;if((c=this._project(a[0],a[1],r,i))&&a.unshift(c[0],c[1]),(c=this._project(a[a.length-2],a[a.length-1],o,s))&&a.push(c[0],c[1]),a=this._clipFinite(t,a))for(let l=0,u=a.length,f,h=this._edgecode(a[u-2],a[u-1]);l<u;l+=2)f=h,h=this._edgecode(a[l],a[l+1]),f&&h&&(l=this._edge(t,f,h,a,l),u=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,n,r,i,o){for(;n!==r;){let s,a;switch(n){case 5:n=4;continue;case 4:n=6,s=this.xmax,a=this.ymin;break;case 6:n=2;continue;case 2:n=10,s=this.xmax,a=this.ymax;break;case 10:n=8;continue;case 8:n=9,s=this.xmin,a=this.ymax;break;case 9:n=1;continue;case 1:n=5,s=this.xmin,a=this.ymin;break}(i[o]!==s||i[o+1]!==a)&&this.contains(t,s,a)&&(i.splice(o,0,s,a),o+=2)}return o}_project(t,n,r,i){let o=1/0,s,a,c;if(i<0){if(n<=this.ymin)return null;(s=(this.ymin-n)/i)<o&&(c=this.ymin,a=t+(o=s)*r)}else if(i>0){if(n>=this.ymax)return null;(s=(this.ymax-n)/i)<o&&(c=this.ymax,a=t+(o=s)*r)}if(r>0){if(t>=this.xmax)return null;(s=(this.xmax-t)/r)<o&&(a=this.xmax,c=n+(o=s)*i)}else if(r<0){if(t<=this.xmin)return null;(s=(this.xmin-t)/r)<o&&(a=this.xmin,c=n+(o=s)*i)}return[a,c]}_edgecode(t,n){return(t===this.xmin?1:t===this.xmax?2:0)|(n===this.ymin?4:n===this.ymax?8:0)}_regioncode(t,n){return(t<this.xmin?1:t>this.xmax?2:0)|(n<this.ymin?4:n>this.ymax?8:0)}_simplify(t){if(t&&t.length>4){for(let n=0;n<t.length;n+=2){let r=(n+2)%t.length,i=(n+4)%t.length;(t[n]===t[r]&&t[r]===t[i]||t[n+1]===t[r+1]&&t[r+1]===t[i+1])&&(t.splice(r,2),n-=2)}t.length||(t=null)}return t}};var dW=2*Math.PI,Gu=Math.pow;function pW(e){return e[0]}function mW(e){return e[1]}function yW(e){let{triangles:t,coords:n}=e;for(let r=0;r<t.length;r+=3){let i=2*t[r],o=2*t[r+1],s=2*t[r+2];if((n[s]-n[i])*(n[o+1]-n[i+1])-(n[o]-n[i])*(n[s+1]-n[i+1])>1e-10)return!1}return!0}function gW(e,t,n){return[e+Math.sin(e+t)*n,t+Math.cos(e-t)*n]}var di=class e{static from(t,n=pW,r=mW,i){return new e("length"in t?xW(t,n,r,i):Float64Array.from(bW(t,n,r,i)))}constructor(t){this._delaunator=new Xu(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(){let t=this._delaunator,n=this.points;if(t.hull&&t.hull.length>2&&yW(t)){this.collinear=Int32Array.from({length:n.length/2},(h,d)=>d).sort((h,d)=>n[2*h]-n[2*d]||n[2*h+1]-n[2*d+1]);let c=this.collinear[0],l=this.collinear[this.collinear.length-1],u=[n[2*c],n[2*c+1],n[2*l],n[2*l+1]],f=1e-8*Math.hypot(u[3]-u[1],u[2]-u[0]);for(let h=0,d=n.length/2;h<d;++h){let p=gW(n[2*h],n[2*h+1],f);n[2*h]=p[0],n[2*h+1]=p[1]}this._delaunator=new Xu(n)}else delete this.collinear;let r=this.halfedges=this._delaunator.halfedges,i=this.hull=this._delaunator.hull,o=this.triangles=this._delaunator.triangles,s=this.inedges.fill(-1),a=this._hullIndex.fill(-1);for(let c=0,l=r.length;c<l;++c){let u=o[c%3===2?c-2:c+1];(r[c]===-1||s[u]===-1)&&(s[u]=c)}for(let c=0,l=i.length;c<l;++c)a[i[c]]=c;i.length<=2&&i.length>0&&(this.triangles=new Int32Array(3).fill(-1),this.halfedges=new Int32Array(3).fill(-1),this.triangles[0]=i[0],s[i[0]]=1,i.length===2&&(s[i[1]]=0,this.triangles[1]=i[1],this.triangles[2]=i[1]))}voronoi(t){return new Fp(this,t)}*neighbors(t){let{inedges:n,hull:r,_hullIndex:i,halfedges:o,triangles:s,collinear:a}=this;if(a){let f=a.indexOf(t);f>0&&(yield a[f-1]),f<a.length-1&&(yield a[f+1]);return}let c=n[t];if(c===-1)return;let l=c,u=-1;do{if(yield u=s[l],l=l%3===2?l-2:l+1,s[l]!==t)return;if(l=o[l],l===-1){let f=r[(i[t]+1)%r.length];f!==u&&(yield f);return}}while(l!==c)}find(t,n,r=0){if(t=+t,t!==t||(n=+n,n!==n))return-1;let i=r,o;for(;(o=this._step(r,t,n))>=0&&o!==r&&o!==i;)r=o;return o}_step(t,n,r){let{inedges:i,hull:o,_hullIndex:s,halfedges:a,triangles:c,points:l}=this;if(i[t]===-1||!l.length)return(t+1)%(l.length>>1);let u=t,f=Gu(n-l[t*2],2)+Gu(r-l[t*2+1],2),h=i[t],d=h;do{let p=c[d],m=Gu(n-l[p*2],2)+Gu(r-l[p*2+1],2);if(m<f&&(f=m,u=p),d=d%3===2?d-2:d+1,c[d]!==t)break;if(d=a[d],d===-1){if(d=o[(s[t]+1)%o.length],d!==p&&Gu(n-l[d*2],2)+Gu(r-l[d*2+1],2)<f)return d;break}}while(d!==h);return u}render(t){let n=t==null?t=new hi:void 0,{points:r,halfedges:i,triangles:o}=this;for(let s=0,a=i.length;s<a;++s){let c=i[s];if(c<s)continue;let l=o[s]*2,u=o[c]*2;t.moveTo(r[l],r[l+1]),t.lineTo(r[u],r[u+1])}return this.renderHull(t),n&&n.value()}renderPoints(t,n){n===void 0&&(!t||typeof t.moveTo!="function")&&(n=t,t=null),n=n==null?2:+n;let r=t==null?t=new hi:void 0,{points:i}=this;for(let o=0,s=i.length;o<s;o+=2){let a=i[o],c=i[o+1];t.moveTo(a+n,c),t.arc(a,c,n,0,dW)}return r&&r.value()}renderHull(t){let n=t==null?t=new hi:void 0,{hull:r,points:i}=this,o=r[0]*2,s=r.length;t.moveTo(i[o],i[o+1]);for(let a=1;a<s;++a){let c=2*r[a];t.lineTo(i[c],i[c+1])}return t.closePath(),n&&n.value()}hullPolygon(){let t=new Fa;return this.renderHull(t),t.value()}renderTriangle(t,n){let r=n==null?n=new hi:void 0,{points:i,triangles:o}=this,s=o[t*=3]*2,a=o[t+1]*2,c=o[t+2]*2;return n.moveTo(i[s],i[s+1]),n.lineTo(i[a],i[a+1]),n.lineTo(i[c],i[c+1]),n.closePath(),r&&r.value()}*trianglePolygons(){let{triangles:t}=this;for(let n=0,r=t.length/3;n<r;++n)yield this.trianglePolygon(n)}trianglePolygon(t){let n=new Fa;return this.renderTriangle(t,n),n.value()}};function xW(e,t,n,r){let i=e.length,o=new Float64Array(i*2);for(let s=0;s<i;++s){let a=e[s];o[s*2]=t.call(r,a,s,e),o[s*2+1]=n.call(r,a,s,e)}return o}function*bW(e,t,n,r){let i=0;for(let o of e)yield t.call(r,o,i,e),yield n.call(r,o,i,e),++i}function RC(e){return Math.abs(e=Math.round(e))>=1e21?e.toLocaleString("en").replace(/,/g,""):e.toString(10)}function ol(e,t){if((n=(e=t?e.toExponential(t-1):e.toExponential()).indexOf("e"))<0)return null;var n,r=e.slice(0,n);return[r.length>1?r[0]+r.slice(2):r,+e.slice(n+1)]}function No(e){return e=ol(Math.abs(e)),e?e[1]:NaN}function $C(e,t){return function(n,r){for(var i=n.length,o=[],s=0,a=e[0],c=0;i>0&&a>0&&(c+a+1>r&&(a=Math.max(1,r-c)),o.push(n.substring(i-=a,i+a)),!((c+=a+1)>r));)a=e[s=(s+1)%e.length];return o.reverse().join(t)}}function PC(e){return function(t){return t.replace(/[0-9]/g,function(n){return e[+n]})}}var wW=/^(?:(.)?([<>=^]))?([+\-( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?(~)?([a-z%])?$/i;function Do(e){if(!(t=wW.exec(e)))throw new Error("invalid format: "+e);var t;return new Px({fill:t[1],align:t[2],sign:t[3],symbol:t[4],zero:t[5],width:t[6],comma:t[7],precision:t[8]&&t[8].slice(1),trim:t[9],type:t[10]})}Do.prototype=Px.prototype;function Px(e){this.fill=e.fill===void 0?" ":e.fill+"",this.align=e.align===void 0?">":e.align+"",this.sign=e.sign===void 0?"-":e.sign+"",this.symbol=e.symbol===void 0?"":e.symbol+"",this.zero=!!e.zero,this.width=e.width===void 0?void 0:+e.width,this.comma=!!e.comma,this.precision=e.precision===void 0?void 0:+e.precision,this.trim=!!e.trim,this.type=e.type===void 0?"":e.type+""}Px.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?"0":"")+(this.width===void 0?"":Math.max(1,this.width|0))+(this.comma?",":"")+(this.precision===void 0?"":"."+Math.max(0,this.precision|0))+(this.trim?"~":"")+this.type};function UC(e){t:for(var t=e.length,n=1,r=-1,i;n<t;++n)switch(e[n]){case".":r=i=n;break;case"0":r===0&&(r=n),i=n;break;default:if(!+e[n])break t;r>0&&(r=0);break}return r>0?e.slice(0,r)+e.slice(i+1):e}var OI;function zC(e,t){var n=ol(e,t);if(!n)return e+"";var r=n[0],i=n[1],o=i-(OI=Math.max(-8,Math.min(8,Math.floor(i/3)))*3)+1,s=r.length;return o===s?r:o>s?r+new Array(o-s+1).join("0"):o>0?r.slice(0,o)+"."+r.slice(o):"0."+new Array(1-o).join("0")+ol(e,Math.max(0,t+o-1))[0]}function BI(e,t){var n=ol(e,t);if(!n)return e+"";var r=n[0],i=n[1];return i<0?"0."+new Array(-i).join("0")+r:r.length>i+1?r.slice(0,i+1)+"."+r.slice(i+1):r+new Array(i-r.length+2).join("0")}var LI={"%":(e,t)=>(e*100).toFixed(t),b:e=>Math.round(e).toString(2),c:e=>e+"",d:RC,e:(e,t)=>e.toExponential(t),f:(e,t)=>e.toFixed(t),g:(e,t)=>e.toPrecision(t),o:e=>Math.round(e).toString(8),p:(e,t)=>BI(e*100,t),r:BI,s:zC,X:e=>Math.round(e).toString(16).toUpperCase(),x:e=>Math.round(e).toString(16)};function CI(e){return e}var qC=Array.prototype.map,jC=["y","z","a","f","p","n","\xB5","m","","k","M","G","T","P","E","Z","Y"];function VC(e){var t=e.grouping===void 0||e.thousands===void 0?CI:$C(qC.call(e.grouping,Number),e.thousands+""),n=e.currency===void 0?"":e.currency[0]+"",r=e.currency===void 0?"":e.currency[1]+"",i=e.decimal===void 0?".":e.decimal+"",o=e.numerals===void 0?CI:PC(qC.call(e.numerals,String)),s=e.percent===void 0?"%":e.percent+"",a=e.minus===void 0?"\u2212":e.minus+"",c=e.nan===void 0?"NaN":e.nan+"";function l(f){f=Do(f);var h=f.fill,d=f.align,p=f.sign,m=f.symbol,y=f.zero,g=f.width,x=f.comma,b=f.precision,w=f.trim,_=f.type;_==="n"?(x=!0,_="g"):LI[_]||(b===void 0&&(b=12),w=!0,_="g"),(y||h==="0"&&d==="=")&&(y=!0,h="0",d="=");var v=m==="$"?n:m==="#"&&/[boxX]/.test(_)?"0"+_.toLowerCase():"",M=m==="$"?r:/[%p]/.test(_)?s:"",E=LI[_],I=/[defgprs%]/.test(_);b=b===void 0?6:/[gprs]/.test(_)?Math.max(1,Math.min(21,b)):Math.max(0,Math.min(20,b));function D(A){var O=v,C=M,S,T,N;if(_==="c")C=E(A)+C,A="";else{A=+A;var F=A<0||1/A<0;if(A=isNaN(A)?c:E(Math.abs(A),b),w&&(A=UC(A)),F&&+A==0&&p!=="+"&&(F=!1),O=(F?p==="("?p:a:p==="-"||p==="("?"":p)+O,C=(_==="s"?jC[8+OI/3]:"")+C+(F&&p==="("?")":""),I){for(S=-1,T=A.length;++S<T;)if(N=A.charCodeAt(S),48>N||N>57){C=(N===46?i+A.slice(S+1):A.slice(S))+C,A=A.slice(0,S);break}}}x&&!y&&(A=t(A,1/0));var R=O.length+A.length+C.length,k=R<g?new Array(g-R+1).join(h):"";switch(x&&y&&(A=t(k+A,k.length?g-C.length:1/0),k=""),d){case"<":A=O+A+C+k;break;case"=":A=O+k+A+C;break;case"^":A=k.slice(0,R=k.length>>1)+O+A+C+k.slice(R);break;default:A=k+O+A+C;break}return o(A)}return D.toString=function(){return f+""},D}function u(f,h){var d=l((f=Do(f),f.type="f",f)),p=Math.max(-8,Math.min(8,Math.floor(No(h)/3)))*3,m=Math.pow(10,-p),y=jC[8+p/3];return function(g){return d(m*g)+y}}return{format:l,formatPrefix:u}}var Ux,pi,zx;kI({thousands:",",grouping:[3],currency:["$",""]});function kI(e){return Ux=VC(e),pi=Ux.format,zx=Ux.formatPrefix,Ux}function FI(e){return Math.max(0,-No(Math.abs(e)))}function RI(e,t){return Math.max(0,Math.max(-8,Math.min(8,Math.floor(No(t)/3)))*3-No(Math.abs(e)))}function $I(e,t){return e=Math.abs(e),t=Math.abs(t)-e,Math.max(0,No(t)-No(e))+1}var et=1e-6,sl=1e-12,Ot=Math.PI,me=Ot/2,PI=Ot/4,un=Ot*2,$e=180/Ot,Yt=Ot/180,Rt=Math.abs,mi=Math.atan,He=Math.atan2,K=Math.cos,Rp=Math.ceil,qx=Math.exp;var jx=Math.hypot,al=Math.log,Vx=Math.pow,Q=Math.sin,Un=Math.sign||function(e){return e>0?1:e<0?-1:0},ye=Math.sqrt,Wu=Math.tan;function Yx(e){return e>1?0:e<-1?Ot:Math.acos(e)}function Se(e){return e>1?me:e<-1?-me:Math.asin(e)}function Ze(){}function Xx(e,t){e&&XC.hasOwnProperty(e.type)&&XC[e.type](e,t)}var YC={Feature:function(e,t){Xx(e.geometry,t)},FeatureCollection:function(e,t){for(var n=e.features,r=-1,i=n.length;++r<i;)Xx(n[r].geometry,t)}},XC={Sphere:function(e,t){t.sphere()},Point:function(e,t){e=e.coordinates,t.point(e[0],e[1],e[2])},MultiPoint:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)e=n[r],t.point(e[0],e[1],e[2])},LineString:function(e,t){UI(e.coordinates,t,0)},MultiLineString:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)UI(n[r],t,0)},Polygon:function(e,t){GC(e.coordinates,t)},MultiPolygon:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)GC(n[r],t)},GeometryCollection:function(e,t){for(var n=e.geometries,r=-1,i=n.length;++r<i;)Xx(n[r],t)}};function UI(e,t,n){var r=-1,i=e.length-n,o;for(t.lineStart();++r<i;)o=e[r],t.point(o[0],o[1],o[2]);t.lineEnd()}function GC(e,t){var n=-1,r=e.length;for(t.polygonStart();++n<r;)UI(e[n],t,1);t.polygonEnd()}function Pr(e,t){e&&YC.hasOwnProperty(e.type)?YC[e.type](e,t):Xx(e,t)}function $p(e){return[He(e[1],e[0]),Se(e[2])]}function Oo(e){var t=e[0],n=e[1],r=K(n);return[r*K(t),r*Q(t),Q(n)]}function Pp(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function Hu(e,t){return[e[1]*t[2]-e[2]*t[1],e[2]*t[0]-e[0]*t[2],e[0]*t[1]-e[1]*t[0]]}function Gx(e,t){e[0]+=t[0],e[1]+=t[1],e[2]+=t[2]}function Up(e,t){return[e[0]*t,e[1]*t,e[2]*t]}function zp(e){var t=ye(e[0]*e[0]+e[1]*e[1]+e[2]*e[2]);e[0]/=t,e[1]/=t,e[2]/=t}var qp,Wx,Hx,Zx,Jx,Qx,Kx,tb,zI,qI,jI,ZC,JC,ir,or,sr,qi={sphere:Ze,point:VI,lineStart:WC,lineEnd:HC,polygonStart:function(){qi.lineStart=SW,qi.lineEnd=IW},polygonEnd:function(){qi.lineStart=WC,qi.lineEnd=HC}};function VI(e,t){e*=Yt,t*=Yt;var n=K(t);jp(n*K(e),n*Q(e),Q(t))}function jp(e,t,n){++qp,Hx+=(e-Hx)/qp,Zx+=(t-Zx)/qp,Jx+=(n-Jx)/qp}function WC(){qi.point=vW}function vW(e,t){e*=Yt,t*=Yt;var n=K(t);ir=n*K(e),or=n*Q(e),sr=Q(t),qi.point=_W,jp(ir,or,sr)}function _W(e,t){e*=Yt,t*=Yt;var n=K(t),r=n*K(e),i=n*Q(e),o=Q(t),s=He(ye((s=or*o-sr*i)*s+(s=sr*r-ir*o)*s+(s=ir*i-or*r)*s),ir*r+or*i+sr*o);Wx+=s,Qx+=s*(ir+(ir=r)),Kx+=s*(or+(or=i)),tb+=s*(sr+(sr=o)),jp(ir,or,sr)}function HC(){qi.point=VI}function SW(){qi.point=MW}function IW(){QC(ZC,JC),qi.point=VI}function MW(e,t){ZC=e,JC=t,e*=Yt,t*=Yt,qi.point=QC;var n=K(t);ir=n*K(e),or=n*Q(e),sr=Q(t),jp(ir,or,sr)}function QC(e,t){e*=Yt,t*=Yt;var n=K(t),r=n*K(e),i=n*Q(e),o=Q(t),s=or*o-sr*i,a=sr*r-ir*o,c=ir*i-or*r,l=jx(s,a,c),u=Se(l),f=l&&-u/l;zI.add(f*s),qI.add(f*a),jI.add(f*c),Wx+=u,Qx+=u*(ir+(ir=r)),Kx+=u*(or+(or=i)),tb+=u*(sr+(sr=o)),jp(ir,or,sr)}function YI(e){qp=Wx=Hx=Zx=Jx=Qx=Kx=tb=0,zI=new Mn,qI=new Mn,jI=new Mn,Pr(e,qi);var t=+zI,n=+qI,r=+jI,i=jx(t,n,r);return i<sl&&(t=Qx,n=Kx,r=tb,Wx<et&&(t=Hx,n=Zx,r=Jx),i=jx(t,n,r),i<sl)?[NaN,NaN]:[He(n,t)*$e,Se(r/i)*$e]}function Vp(e,t){function n(r,i){return r=e(r,i),t(r[0],r[1])}return e.invert&&t.invert&&(n.invert=function(r,i){return r=t.invert(r,i),r&&e.invert(r[0],r[1])}),n}function XI(e,t){return Rt(e)>Ot&&(e-=Math.round(e/un)*un),[e,t]}XI.invert=XI;function GI(e,t,n){return(e%=un)?t||n?Vp(tk(e),ek(t,n)):tk(e):t||n?ek(t,n):XI}function KC(e){return function(t,n){return t+=e,Rt(t)>Ot&&(t-=Math.round(t/un)*un),[t,n]}}function tk(e){var t=KC(e);return t.invert=KC(-e),t}function ek(e,t){var n=K(e),r=Q(e),i=K(t),o=Q(t);function s(a,c){var l=K(c),u=K(a)*l,f=Q(a)*l,h=Q(c),d=h*n+u*r;return[He(f*i-d*o,u*n-h*r),Se(d*i+f*o)]}return s.invert=function(a,c){var l=K(c),u=K(a)*l,f=Q(a)*l,h=Q(c),d=h*i-f*o;return[He(f*i+h*o,u*n+d*r),Se(d*n-u*r)]},s}function nk(e){e=GI(e[0]*Yt,e[1]*Yt,e.length>2?e[2]*Yt:0);function t(n){return n=e(n[0]*Yt,n[1]*Yt),n[0]*=$e,n[1]*=$e,n}return t.invert=function(n){return n=e.invert(n[0]*Yt,n[1]*Yt),n[0]*=$e,n[1]*=$e,n},t}function ik(e,t,n,r,i,o){if(n){var s=K(t),a=Q(t),c=r*n;i==null?(i=t+r*un,o=t-c/2):(i=rk(s,i),o=rk(s,o),(r>0?i<o:i>o)&&(i+=r*un));for(var l,u=i;r>0?u>o:u<o;u-=c)l=$p([s,-a*K(u),-a*Q(u)]),e.point(l[0],l[1])}}function rk(e,t){t=Oo(t),t[0]-=e,zp(t);var n=Yx(-t[1]);return((-t[2]<0?-n:n)+un-et)%un}function eb(){var e=[],t;return{point:function(n,r,i){t.push([n,r,i])},lineStart:function(){e.push(t=[])},lineEnd:Ze,rejoin:function(){e.length>1&&e.push(e.pop().concat(e.shift()))},result:function(){var n=e;return e=[],t=null,n}}}function Zu(e,t){return Rt(e[0]-t[0])<et&&Rt(e[1]-t[1])<et}function nb(e,t,n,r){this.x=e,this.z=t,this.o=n,this.e=r,this.v=!1,this.n=this.p=null}function rb(e,t,n,r,i){var o=[],s=[],a,c;if(e.forEach(function(p){if(!((m=p.length-1)<=0)){var m,y=p[0],g=p[m],x;if(Zu(y,g)){if(!y[2]&&!g[2]){for(i.lineStart(),a=0;a<m;++a)i.point((y=p[a])[0],y[1]);i.lineEnd();return}g[0]+=2*et}o.push(x=new nb(y,p,null,!0)),s.push(x.o=new nb(y,null,x,!1)),o.push(x=new nb(g,p,null,!1)),s.push(x.o=new nb(g,null,x,!0))}}),!!o.length){for(s.sort(t),ok(o),ok(s),a=0,c=s.length;a<c;++a)s[a].e=n=!n;for(var l=o[0],u,f;;){for(var h=l,d=!0;h.v;)if((h=h.n)===l)return;u=h.z,i.lineStart();do{if(h.v=h.o.v=!0,h.e){if(d)for(a=0,c=u.length;a<c;++a)i.point((f=u[a])[0],f[1]);else r(h.x,h.n.x,1,i);h=h.n}else{if(d)for(u=h.p.z,a=u.length-1;a>=0;--a)i.point((f=u[a])[0],f[1]);else r(h.x,h.p.x,-1,i);h=h.p}h=h.o,u=h.z,d=!d}while(!h.v);i.lineEnd()}}}function ok(e){if(t=e.length){for(var t,n=0,r=e[0],i;++n<t;)r.n=i=e[n],i.p=r,r=i;r.n=i=e[0],i.p=r}}function WI(e){return Rt(e[0])<=Ot?e[0]:Un(e[0])*((Rt(e[0])+Ot)%un-Ot)}function sk(e,t){var n=WI(t),r=t[1],i=Q(r),o=[Q(n),-K(n),0],s=0,a=0,c=new Mn;i===1?r=me+et:i===-1&&(r=-me-et);for(var l=0,u=e.length;l<u;++l)if(h=(f=e[l]).length)for(var f,h,d=f[h-1],p=WI(d),m=d[1]/2+PI,y=Q(m),g=K(m),x=0;x<h;++x,p=w,y=v,g=M,d=b){var b=f[x],w=WI(b),_=b[1]/2+PI,v=Q(_),M=K(_),E=w-p,I=E>=0?1:-1,D=I*E,A=D>Ot,O=y*v;if(c.add(He(O*I*Q(D),g*M+O*K(D))),s+=A?E+I*un:E,A^p>=n^w>=n){var C=Hu(Oo(d),Oo(b));zp(C);var S=Hu(o,C);zp(S);var T=(A^E>=0?-1:1)*Se(S[2]);(r>T||r===T&&(C[0]||C[1]))&&(a+=A^E>=0?1:-1)}}return(s<-et||s<et&&c<-sl)^a&1}function ib(e,t,n,r){return function(i){var o=t(i),s=eb(),a=t(s),c=!1,l,u,f,h={point:d,lineStart:m,lineEnd:y,polygonStart:function(){h.point=g,h.lineStart=x,h.lineEnd=b,u=[],l=[]},polygonEnd:function(){h.point=d,h.lineStart=m,h.lineEnd=y,u=Ou(u);var w=sk(l,r);u.length?(c||(i.polygonStart(),c=!0),rb(u,TW,w,n,i)):w&&(c||(i.polygonStart(),c=!0),i.lineStart(),n(null,null,1,i),i.lineEnd()),c&&(i.polygonEnd(),c=!1),u=l=null},sphere:function(){i.polygonStart(),i.lineStart(),n(null,null,1,i),i.lineEnd(),i.polygonEnd()}};function d(w,_){e(w,_)&&i.point(w,_)}function p(w,_){o.point(w,_)}function m(){h.point=p,o.lineStart()}function y(){h.point=d,o.lineEnd()}function g(w,_){f.push([w,_]),a.point(w,_)}function x(){a.lineStart(),f=[]}function b(){g(f[0][0],f[0][1]),a.lineEnd();var w=a.clean(),_=s.result(),v,M=_.length,E,I,D;if(f.pop(),l.push(f),f=null,!!M){if(w&1){if(I=_[0],(E=I.length-1)>0){for(c||(i.polygonStart(),c=!0),i.lineStart(),v=0;v<E;++v)i.point((D=I[v])[0],D[1]);i.lineEnd()}return}M>1&&w&2&&_.push(_.pop().concat(_.shift())),u.push(_.filter(AW))}}return h}}function AW(e){return e.length>1}function TW(e,t){return((e=e.x)[0]<0?e[1]-me-et:me-e[1])-((t=t.x)[0]<0?t[1]-me-et:me-t[1])}var HI=ib(function(){return!0},EW,DW,[-Ot,-me]);function EW(e){var t=NaN,n=NaN,r=NaN,i;return{lineStart:function(){e.lineStart(),i=1},point:function(o,s){var a=o>0?Ot:-Ot,c=Rt(o-t);Rt(c-Ot)<et?(e.point(t,n=(n+s)/2>0?me:-me),e.point(r,n),e.lineEnd(),e.lineStart(),e.point(a,n),e.point(o,n),i=0):r!==a&&c>=Ot&&(Rt(t-r)<et&&(t-=r*et),Rt(o-a)<et&&(o-=a*et),n=NW(t,n,o,s),e.point(r,n),e.lineEnd(),e.lineStart(),e.point(a,n),i=0),e.point(t=o,n=s),r=a},lineEnd:function(){e.lineEnd(),t=n=NaN},clean:function(){return 2-i}}}function NW(e,t,n,r){var i,o,s=Q(e-n);return Rt(s)>et?mi((Q(t)*(o=K(r))*Q(n)-Q(r)*(i=K(t))*Q(e))/(i*o*s)):(t+r)/2}function DW(e,t,n,r){var i;if(e==null)i=n*me,r.point(-Ot,i),r.point(0,i),r.point(Ot,i),r.point(Ot,0),r.point(Ot,-i),r.point(0,-i),r.point(-Ot,-i),r.point(-Ot,0),r.point(-Ot,i);else if(Rt(e[0]-t[0])>et){var o=e[0]<t[0]?Ot:-Ot;i=n*o/2,r.point(-o,i),r.point(0,i),r.point(o,i)}else r.point(t[0],t[1])}function ak(e){var t=K(e),n=6*Yt,r=t>0,i=Rt(t)>et;function o(u,f,h,d){ik(d,e,n,h,u,f)}function s(u,f){return K(u)*K(f)>t}function a(u){var f,h,d,p,m;return{lineStart:function(){p=d=!1,m=1},point:function(y,g){var x=[y,g],b,w=s(y,g),_=r?w?0:l(y,g):w?l(y+(y<0?Ot:-Ot),g):0;if(!f&&(p=d=w)&&u.lineStart(),w!==d&&(b=c(f,x),(!b||Zu(f,b)||Zu(x,b))&&(x[2]=1)),w!==d)m=0,w?(u.lineStart(),b=c(x,f),u.point(b[0],b[1])):(b=c(f,x),u.point(b[0],b[1],2),u.lineEnd()),f=b;else if(i&&f&&r^w){var v;!(_&h)&&(v=c(x,f,!0))&&(m=0,r?(u.lineStart(),u.point(v[0][0],v[0][1]),u.point(v[1][0],v[1][1]),u.lineEnd()):(u.point(v[1][0],v[1][1]),u.lineEnd(),u.lineStart(),u.point(v[0][0],v[0][1],3)))}w&&(!f||!Zu(f,x))&&u.point(x[0],x[1]),f=x,d=w,h=_},lineEnd:function(){d&&u.lineEnd(),f=null},clean:function(){return m|(p&&d)<<1}}}function c(u,f,h){var d=Oo(u),p=Oo(f),m=[1,0,0],y=Hu(d,p),g=Pp(y,y),x=y[0],b=g-x*x;if(!b)return!h&&u;var w=t*g/b,_=-t*x/b,v=Hu(m,y),M=Up(m,w),E=Up(y,_);Gx(M,E);var I=v,D=Pp(M,I),A=Pp(I,I),O=D*D-A*(Pp(M,M)-1);if(!(O<0)){var C=ye(O),S=Up(I,(-D-C)/A);if(Gx(S,M),S=$p(S),!h)return S;var T=u[0],N=f[0],F=u[1],R=f[1],k;N<T&&(k=T,T=N,N=k);var $=N-T,P=Rt($-Ot)<et,U=P||$<et;if(!P&&R<F&&(k=F,F=R,R=k),U?P?F+R>0^S[1]<(Rt(S[0]-T)<et?F:R):F<=S[1]&&S[1]<=R:$>Ot^(T<=S[0]&&S[0]<=N)){var W=Up(I,(-D+C)/A);return Gx(W,M),[S,$p(W)]}}}function l(u,f){var h=r?e:Ot-e,d=0;return u<-h?d|=1:u>h&&(d|=2),f<-h?d|=4:f>h&&(d|=8),d}return ib(s,a,o,r?[0,-e]:[-Ot,e-Ot])}function ck(e,t,n,r,i,o){var s=e[0],a=e[1],c=t[0],l=t[1],u=0,f=1,h=c-s,d=l-a,p;if(p=n-s,!(!h&&p>0)){if(p/=h,h<0){if(p<u)return;p<f&&(f=p)}else if(h>0){if(p>f)return;p>u&&(u=p)}if(p=i-s,!(!h&&p<0)){if(p/=h,h<0){if(p>f)return;p>u&&(u=p)}else if(h>0){if(p<u)return;p<f&&(f=p)}if(p=r-a,!(!d&&p>0)){if(p/=d,d<0){if(p<u)return;p<f&&(f=p)}else if(d>0){if(p>f)return;p>u&&(u=p)}if(p=o-a,!(!d&&p<0)){if(p/=d,d<0){if(p>f)return;p>u&&(u=p)}else if(d>0){if(p<u)return;p<f&&(f=p)}return u>0&&(e[0]=s+u*h,e[1]=a+u*d),f<1&&(t[0]=s+f*h,t[1]=a+f*d),!0}}}}}var Yp=1e9,ob=-Yp;function Ju(e,t,n,r){function i(l,u){return e<=l&&l<=n&&t<=u&&u<=r}function o(l,u,f,h){var d=0,p=0;if(l==null||(d=s(l,f))!==(p=s(u,f))||c(l,u)<0^f>0)do h.point(d===0||d===3?e:n,d>1?r:t);while((d=(d+f+4)%4)!==p);else h.point(u[0],u[1])}function s(l,u){return Rt(l[0]-e)<et?u>0?0:3:Rt(l[0]-n)<et?u>0?2:1:Rt(l[1]-t)<et?u>0?1:0:u>0?3:2}function a(l,u){return c(l.x,u.x)}function c(l,u){var f=s(l,1),h=s(u,1);return f!==h?f-h:f===0?u[1]-l[1]:f===1?l[0]-u[0]:f===2?l[1]-u[1]:u[0]-l[0]}return function(l){var u=l,f=eb(),h,d,p,m,y,g,x,b,w,_,v,M={point:E,lineStart:O,lineEnd:C,polygonStart:D,polygonEnd:A};function E(T,N){i(T,N)&&u.point(T,N)}function I(){for(var T=0,N=0,F=d.length;N<F;++N)for(var R=d[N],k=1,$=R.length,P=R[0],U,W,nt=P[0],ot=P[1];k<$;++k)U=nt,W=ot,P=R[k],nt=P[0],ot=P[1],W<=r?ot>r&&(nt-U)*(r-W)>(ot-W)*(e-U)&&++T:ot<=r&&(nt-U)*(r-W)<(ot-W)*(e-U)&&--T;return T}function D(){u=f,h=[],d=[],v=!0}function A(){var T=I(),N=v&&T,F=(h=Ou(h)).length;(N||F)&&(l.polygonStart(),N&&(l.lineStart(),o(null,null,1,l),l.lineEnd()),F&&rb(h,a,T,o,l),l.polygonEnd()),u=l,h=d=p=null}function O(){M.point=S,d&&d.push(p=[]),_=!0,w=!1,x=b=NaN}function C(){h&&(S(m,y),g&&w&&f.rejoin(),h.push(f.result())),M.point=E,w&&u.lineEnd()}function S(T,N){var F=i(T,N);if(d&&p.push([T,N]),_)m=T,y=N,g=F,_=!1,F&&(u.lineStart(),u.point(T,N));else if(F&&w)u.point(T,N);else{var R=[x=Math.max(ob,Math.min(Yp,x)),b=Math.max(ob,Math.min(Yp,b))],k=[T=Math.max(ob,Math.min(Yp,T)),N=Math.max(ob,Math.min(Yp,N))];ck(R,k,e,t,n,r)?(w||(u.lineStart(),u.point(R[0],R[1])),u.point(k[0],k[1]),F||u.lineEnd(),v=!1):F&&(u.lineStart(),u.point(T,N),v=!1)}x=T,b=N,w=F}return M}}function lk(e,t,n){var r=Ue(e,t-et,n).concat(t);return function(i){return r.map(function(o){return[i,o]})}}function uk(e,t,n){var r=Ue(e,t-et,n).concat(t);return function(i){return r.map(function(o){return[o,i]})}}function ZI(){var e,t,n,r,i,o,s,a,c=10,l=c,u=90,f=360,h,d,p,m,y=2.5;function g(){return{type:"MultiLineString",coordinates:x()}}function x(){return Ue(Rp(r/u)*u,n,u).map(p).concat(Ue(Rp(a/f)*f,s,f).map(m)).concat(Ue(Rp(t/c)*c,e,c).filter(function(b){return Rt(b%u)>et}).map(h)).concat(Ue(Rp(o/l)*l,i,l).filter(function(b){return Rt(b%f)>et}).map(d))}return g.lines=function(){return x().map(function(b){return{type:"LineString",coordinates:b}})},g.outline=function(){return{type:"Polygon",coordinates:[p(r).concat(m(s).slice(1),p(n).reverse().slice(1),m(a).reverse().slice(1))]}},g.extent=function(b){return arguments.length?g.extentMajor(b).extentMinor(b):g.extentMinor()},g.extentMajor=function(b){return arguments.length?(r=+b[0][0],n=+b[1][0],a=+b[0][1],s=+b[1][1],r>n&&(b=r,r=n,n=b),a>s&&(b=a,a=s,s=b),g.precision(y)):[[r,a],[n,s]]},g.extentMinor=function(b){return arguments.length?(t=+b[0][0],e=+b[1][0],o=+b[0][1],i=+b[1][1],t>e&&(b=t,t=e,e=b),o>i&&(b=o,o=i,i=b),g.precision(y)):[[t,o],[e,i]]},g.step=function(b){return arguments.length?g.stepMajor(b).stepMinor(b):g.stepMinor()},g.stepMajor=function(b){return arguments.length?(u=+b[0],f=+b[1],g):[u,f]},g.stepMinor=function(b){return arguments.length?(c=+b[0],l=+b[1],g):[c,l]},g.precision=function(b){return arguments.length?(y=+b,h=lk(o,i,90),d=uk(t,e,y),p=lk(a,s,90),m=uk(r,n,y),g):y},g.extentMajor([[-180,-90+et],[180,90-et]]).extentMinor([[-180,-80-et],[180,80+et]])}function JI(){return ZI()()}var Xp=e=>e;var QI=new Mn,KI=new Mn,fk,hk,tM,eM,Ra={point:Ze,lineStart:Ze,lineEnd:Ze,polygonStart:function(){Ra.lineStart=OW,Ra.lineEnd=LW},polygonEnd:function(){Ra.lineStart=Ra.lineEnd=Ra.point=Ze,QI.add(Rt(KI)),KI=new Mn},result:function(){var e=QI/2;return QI=new Mn,e}};function OW(){Ra.point=BW}function BW(e,t){Ra.point=dk,fk=tM=e,hk=eM=t}function dk(e,t){KI.add(eM*e-tM*t),tM=e,eM=t}function LW(){dk(fk,hk)}var nM=Ra;var Qu=1/0,sb=Qu,Gp=-Qu,ab=Gp,CW={point:kW,lineStart:Ze,lineEnd:Ze,polygonStart:Ze,polygonEnd:Ze,result:function(){var e=[[Qu,sb],[Gp,ab]];return Gp=ab=-(sb=Qu=1/0),e}};function kW(e,t){e<Qu&&(Qu=e),e>Gp&&(Gp=e),t<sb&&(sb=t),t>ab&&(ab=t)}var Ku=CW;var rM=0,iM=0,Wp=0,cb=0,lb=0,tf=0,oM=0,sM=0,Hp=0,yk,gk,Bo,Lo,ji={point:cl,lineStart:pk,lineEnd:mk,polygonStart:function(){ji.lineStart=$W,ji.lineEnd=PW},polygonEnd:function(){ji.point=cl,ji.lineStart=pk,ji.lineEnd=mk},result:function(){var e=Hp?[oM/Hp,sM/Hp]:tf?[cb/tf,lb/tf]:Wp?[rM/Wp,iM/Wp]:[NaN,NaN];return rM=iM=Wp=cb=lb=tf=oM=sM=Hp=0,e}};function cl(e,t){rM+=e,iM+=t,++Wp}function pk(){ji.point=FW}function FW(e,t){ji.point=RW,cl(Bo=e,Lo=t)}function RW(e,t){var n=e-Bo,r=t-Lo,i=ye(n*n+r*r);cb+=i*(Bo+e)/2,lb+=i*(Lo+t)/2,tf+=i,cl(Bo=e,Lo=t)}function mk(){ji.point=cl}function $W(){ji.point=UW}function PW(){xk(yk,gk)}function UW(e,t){ji.point=xk,cl(yk=Bo=e,gk=Lo=t)}function xk(e,t){var n=e-Bo,r=t-Lo,i=ye(n*n+r*r);cb+=i*(Bo+e)/2,lb+=i*(Lo+t)/2,tf+=i,i=Lo*e-Bo*t,oM+=i*(Bo+e),sM+=i*(Lo+t),Hp+=i*3,cl(Bo=e,Lo=t)}var aM=ji;function ub(e){this._context=e}ub.prototype={_radius:4.5,pointRadius:function(e){return this._radius=e,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){this._line===0&&this._context.closePath(),this._point=NaN},point:function(e,t){switch(this._point){case 0:{this._context.moveTo(e,t),this._point=1;break}case 1:{this._context.lineTo(e,t);break}default:{this._context.moveTo(e+this._radius,t),this._context.arc(e,t,this._radius,0,un);break}}},result:Ze};var lM=new Mn,cM,bk,wk,Zp,Jp,fb={point:Ze,lineStart:function(){fb.point=zW},lineEnd:function(){cM&&vk(bk,wk),fb.point=Ze},polygonStart:function(){cM=!0},polygonEnd:function(){cM=null},result:function(){var e=+lM;return lM=new Mn,e}};function zW(e,t){fb.point=vk,bk=Zp=e,wk=Jp=t}function vk(e,t){Zp-=e,Jp-=t,lM.add(ye(Zp*Zp+Jp*Jp)),Zp=e,Jp=t}var uM=fb;var _k,hb,Sk,Ik,ef=class{constructor(t){this._append=t==null?Mk:qW(t),this._radius=4.5,this._=""}pointRadius(t){return this._radius=+t,this}polygonStart(){this._line=0}polygonEnd(){this._line=NaN}lineStart(){this._point=0}lineEnd(){this._line===0&&(this._+="Z"),this._point=NaN}point(t,n){switch(this._point){case 0:{this._append`M${t},${n}`,this._point=1;break}case 1:{this._append`L${t},${n}`;break}default:{if(this._append`M${t},${n}`,this._radius!==Sk||this._append!==hb){let r=this._radius,i=this._;this._="",this._append`m0,${r}a${r},${r} 0 1,1 0,${-2*r}a${r},${r} 0 1,1 0,${2*r}z`,Sk=r,hb=this._append,Ik=this._,this._=i}this._+=Ik;break}}}result(){let t=this._;return this._="",t.length?t:null}};function Mk(e){let t=1;this._+=e[0];for(let n=e.length;t<n;++t)this._+=arguments[t]+e[t]}function qW(e){let t=Math.floor(e);if(!(t>=0))throw new RangeError(`invalid digits: ${e}`);if(t>15)return Mk;if(t!==_k){let n=10**t;_k=t,hb=function(i){let o=1;this._+=i[0];for(let s=i.length;o<s;++o)this._+=Math.round(arguments[o]*n)/n+i[o]}}return hb}function Nn(e,t){let n=3,r=4.5,i,o;function s(a){return a&&(typeof r=="function"&&o.pointRadius(+r.apply(this,arguments)),Pr(a,i(o))),o.result()}return s.area=function(a){return Pr(a,i(nM)),nM.result()},s.measure=function(a){return Pr(a,i(uM)),uM.result()},s.bounds=function(a){return Pr(a,i(Ku)),Ku.result()},s.centroid=function(a){return Pr(a,i(aM)),aM.result()},s.projection=function(a){return arguments.length?(i=a==null?(e=null,Xp):(e=a).stream,s):e},s.context=function(a){return arguments.length?(o=a==null?(t=null,new ef(n)):new ub(t=a),typeof r!="function"&&o.pointRadius(r),s):t},s.pointRadius=function(a){return arguments.length?(r=typeof a=="function"?a:(o.pointRadius(+a),+a),s):r},s.digits=function(a){if(!arguments.length)return n;if(a==null)n=null;else{let c=Math.floor(a);if(!(c>=0))throw new RangeError(`invalid digits: ${a}`);n=c}return t===null&&(o=new ef(n)),s},s.projection(e).digits(n).context(t)}function ll(e){return{stream:nf(e)}}function nf(e){return function(t){var n=new fM;for(var r in e)n[r]=e[r];return n.stream=t,n}}function fM(){}fM.prototype={constructor:fM,point:function(e,t){this.stream.point(e,t)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}};function hM(e,t,n){var r=e.clipExtent&&e.clipExtent();return e.scale(150).translate([0,0]),r!=null&&e.clipExtent(null),Pr(n,e.stream(Ku)),t(Ku.result()),r!=null&&e.clipExtent(r),e}function Qp(e,t,n){return hM(e,function(r){var i=t[1][0]-t[0][0],o=t[1][1]-t[0][1],s=Math.min(i/(r[1][0]-r[0][0]),o/(r[1][1]-r[0][1])),a=+t[0][0]+(i-s*(r[1][0]+r[0][0]))/2,c=+t[0][1]+(o-s*(r[1][1]+r[0][1]))/2;e.scale(150*s).translate([a,c])},n)}function db(e,t,n){return Qp(e,[[0,0],t],n)}function pb(e,t,n){return hM(e,function(r){var i=+t,o=i/(r[1][0]-r[0][0]),s=(i-o*(r[1][0]+r[0][0]))/2,a=-o*r[0][1];e.scale(150*o).translate([s,a])},n)}function mb(e,t,n){return hM(e,function(r){var i=+t,o=i/(r[1][1]-r[0][1]),s=-o*r[0][0],a=(i-o*(r[1][1]+r[0][1]))/2;e.scale(150*o).translate([s,a])},n)}var Ak=16,jW=K(30*Yt);function dM(e,t){return+t?YW(e,t):VW(e)}function VW(e){return nf({point:function(t,n){t=e(t,n),this.stream.point(t[0],t[1])}})}function YW(e,t){function n(r,i,o,s,a,c,l,u,f,h,d,p,m,y){var g=l-r,x=u-i,b=g*g+x*x;if(b>4*t&&m--){var w=s+h,_=a+d,v=c+p,M=ye(w*w+_*_+v*v),E=Se(v/=M),I=Rt(Rt(v)-1)<et||Rt(o-f)<et?(o+f)/2:He(_,w),D=e(I,E),A=D[0],O=D[1],C=A-r,S=O-i,T=x*C-g*S;(T*T/b>t||Rt((g*C+x*S)/b-.5)>.3||s*h+a*d+c*p<jW)&&(n(r,i,o,s,a,c,A,O,I,w/=M,_/=M,v,m,y),y.point(A,O),n(A,O,I,w,_,v,l,u,f,h,d,p,m,y))}}return function(r){var i,o,s,a,c,l,u,f,h,d,p,m,y={point:g,lineStart:x,lineEnd:w,polygonStart:function(){r.polygonStart(),y.lineStart=_},polygonEnd:function(){r.polygonEnd(),y.lineStart=x}};function g(E,I){E=e(E,I),r.point(E[0],E[1])}function x(){f=NaN,y.point=b,r.lineStart()}function b(E,I){var D=Oo([E,I]),A=e(E,I);n(f,h,u,d,p,m,f=A[0],h=A[1],u=E,d=D[0],p=D[1],m=D[2],Ak,r),r.point(f,h)}function w(){y.point=g,r.lineEnd()}function _(){x(),y.point=v,y.lineEnd=M}function v(E,I){b(i=E,I),o=f,s=h,a=d,c=p,l=m,y.point=b}function M(){n(f,h,u,d,p,m,o,s,i,a,c,l,Ak,r),y.lineEnd=w,w()}return y}}var XW=nf({point:function(e,t){this.stream.point(e*Yt,t*Yt)}});function GW(e){return nf({point:function(t,n){var r=e(t,n);return this.stream.point(r[0],r[1])}})}function WW(e,t,n,r,i){function o(s,a){return s*=r,a*=i,[t+e*s,n-e*a]}return o.invert=function(s,a){return[(s-t)/e*r,(n-a)/e*i]},o}function Tk(e,t,n,r,i,o){if(!o)return WW(e,t,n,r,i);var s=K(o),a=Q(o),c=s*e,l=a*e,u=s/e,f=a/e,h=(a*n-s*t)/e,d=(a*t+s*n)/e;function p(m,y){return m*=r,y*=i,[c*m-l*y+t,n-l*m-c*y]}return p.invert=function(m,y){return[r*(u*m-f*y+h),i*(d-f*m-u*y)]},p}function Dn(e){return pM(function(){return e})()}function pM(e){var t,n=150,r=480,i=250,o=0,s=0,a=0,c=0,l=0,u,f=0,h=1,d=1,p=null,m=HI,y=null,g,x,b,w=Xp,_=.5,v,M,E,I,D;function A(T){return E(T[0]*Yt,T[1]*Yt)}function O(T){return T=E.invert(T[0],T[1]),T&&[T[0]*$e,T[1]*$e]}A.stream=function(T){return I&&D===T?I:I=XW(GW(u)(m(v(w(D=T)))))},A.preclip=function(T){return arguments.length?(m=T,p=void 0,S()):m},A.postclip=function(T){return arguments.length?(w=T,y=g=x=b=null,S()):w},A.clipAngle=function(T){return arguments.length?(m=+T?ak(p=T*Yt):(p=null,HI),S()):p*$e},A.clipExtent=function(T){return arguments.length?(w=T==null?(y=g=x=b=null,Xp):Ju(y=+T[0][0],g=+T[0][1],x=+T[1][0],b=+T[1][1]),S()):y==null?null:[[y,g],[x,b]]},A.scale=function(T){return arguments.length?(n=+T,C()):n},A.translate=function(T){return arguments.length?(r=+T[0],i=+T[1],C()):[r,i]},A.center=function(T){return arguments.length?(o=T[0]%360*Yt,s=T[1]%360*Yt,C()):[o*$e,s*$e]},A.rotate=function(T){return arguments.length?(a=T[0]%360*Yt,c=T[1]%360*Yt,l=T.length>2?T[2]%360*Yt:0,C()):[a*$e,c*$e,l*$e]},A.angle=function(T){return arguments.length?(f=T%360*Yt,C()):f*$e},A.reflectX=function(T){return arguments.length?(h=T?-1:1,C()):h<0},A.reflectY=function(T){return arguments.length?(d=T?-1:1,C()):d<0},A.precision=function(T){return arguments.length?(v=dM(M,_=T*T),S()):ye(_)},A.fitExtent=function(T,N){return Qp(A,T,N)},A.fitSize=function(T,N){return db(A,T,N)},A.fitWidth=function(T,N){return pb(A,T,N)},A.fitHeight=function(T,N){return mb(A,T,N)};function C(){var T=Tk(n,0,0,h,d,f).apply(null,t(o,s)),N=Tk(n,r-T[0],i-T[1],h,d,f);return u=GI(a,c,l),M=Vp(t,N),E=Vp(u,M),v=dM(M,_),S()}function S(){return I=D=null,A}return function(){return t=e.apply(this,arguments),A.invert=t.invert&&O,C()}}function rf(e){var t=0,n=Ot/3,r=pM(e),i=r(t,n);return i.parallels=function(o){return arguments.length?r(t=o[0]*Yt,n=o[1]*Yt):[t*$e,n*$e]},i}function Ek(e){var t=K(e);function n(r,i){return[r*t,Q(i)/t]}return n.invert=function(r,i){return[r/t,Se(i*t)]},n}function Nk(e,t){var n=Q(e),r=(n+Q(t))/2;if(Rt(r)<et)return Ek(e);var i=1+n*(2*r-n),o=ye(i)/r;function s(a,c){var l=ye(i-2*r*Q(c))/r;return[l*Q(a*=r),o-l*K(a)]}return s.invert=function(a,c){var l=o-c,u=He(a,Rt(l))*Un(l);return l*r<0&&(u-=Ot*Un(a)*Un(l)),[u/r,Se((i-(a*a+l*l)*r*r)/(2*r))]},s}function $a(){return rf(Nk).scale(155.424).center([0,33.6442])}function Kp(){return $a().parallels([29.5,45.5]).scale(1070).translate([480,250]).rotate([96,0]).center([-.6,38.7])}function HW(e){var t=e.length;return{point:function(n,r){for(var i=-1;++i<t;)e[i].point(n,r)},sphere:function(){for(var n=-1;++n<t;)e[n].sphere()},lineStart:function(){for(var n=-1;++n<t;)e[n].lineStart()},lineEnd:function(){for(var n=-1;++n<t;)e[n].lineEnd()},polygonStart:function(){for(var n=-1;++n<t;)e[n].polygonStart()},polygonEnd:function(){for(var n=-1;++n<t;)e[n].polygonEnd()}}}function mM(){var e,t,n=Kp(),r,i=$a().rotate([154,0]).center([-2,58.5]).parallels([55,65]),o,s=$a().rotate([157,0]).center([-3,19.9]).parallels([8,18]),a,c,l={point:function(h,d){c=[h,d]}};function u(h){var d=h[0],p=h[1];return c=null,r.point(d,p),c||(o.point(d,p),c)||(a.point(d,p),c)}u.invert=function(h){var d=n.scale(),p=n.translate(),m=(h[0]-p[0])/d,y=(h[1]-p[1])/d;return(y>=.12&&y<.234&&m>=-.425&&m<-.214?i:y>=.166&&y<.234&&m>=-.214&&m<-.115?s:n).invert(h)},u.stream=function(h){return e&&t===h?e:e=HW([n.stream(t=h),i.stream(h),s.stream(h)])},u.precision=function(h){return arguments.length?(n.precision(h),i.precision(h),s.precision(h),f()):n.precision()},u.scale=function(h){return arguments.length?(n.scale(h),i.scale(h*.35),s.scale(h),u.translate(n.translate())):n.scale()},u.translate=function(h){if(!arguments.length)return n.translate();var d=n.scale(),p=+h[0],m=+h[1];return r=n.translate(h).clipExtent([[p-.455*d,m-.238*d],[p+.455*d,m+.238*d]]).stream(l),o=i.translate([p-.307*d,m+.201*d]).clipExtent([[p-.425*d+et,m+.12*d+et],[p-.214*d-et,m+.234*d-et]]).stream(l),a=s.translate([p-.205*d,m+.212*d]).clipExtent([[p-.214*d+et,m+.166*d+et],[p-.115*d-et,m+.234*d-et]]).stream(l),f()},u.fitExtent=function(h,d){return Qp(u,h,d)},u.fitSize=function(h,d){return db(u,h,d)},u.fitWidth=function(h,d){return pb(u,h,d)},u.fitHeight=function(h,d){return mb(u,h,d)};function f(){return e=t=null,u}return u.scale(1070)}function yb(e){return function(t,n){var r=K(t),i=K(n),o=e(r*i);return o===1/0?[2,0]:[o*i*Q(t),o*Q(n)]}}function Co(e){return function(t,n){var r=ye(t*t+n*n),i=e(r),o=Q(i),s=K(i);return[He(t*o,r*s),Se(r&&n*o/r)]}}var yM=yb(function(e){return ye(2/(1+e))});yM.invert=Co(function(e){return 2*Se(e/2)});function gM(){return Dn(yM).scale(124.75).clipAngle(180-.001)}var xM=yb(function(e){return(e=Yx(e))&&e/Q(e)});xM.invert=Co(function(e){return e});function bM(){return Dn(xM).scale(79.4188).clipAngle(180-.001)}function of(e,t){return[e,al(Wu((me+t)/2))]}of.invert=function(e,t){return[e,2*mi(qx(t))-me]};function wM(){return vM(of).scale(961/un)}function vM(e){var t=Dn(e),n=t.center,r=t.scale,i=t.translate,o=t.clipExtent,s=null,a,c,l;t.scale=function(f){return arguments.length?(r(f),u()):r()},t.translate=function(f){return arguments.length?(i(f),u()):i()},t.center=function(f){return arguments.length?(n(f),u()):n()},t.clipExtent=function(f){return arguments.length?(f==null?s=a=c=l=null:(s=+f[0][0],a=+f[0][1],c=+f[1][0],l=+f[1][1]),u()):s==null?null:[[s,a],[c,l]]};function u(){var f=Ot*r(),h=t(nk(t.rotate()).invert([0,0]));return o(s==null?[[h[0]-f,h[1]-f],[h[0]+f,h[1]+f]]:e===of?[[Math.max(h[0]-f,s),a],[Math.min(h[0]+f,c),l]]:[[s,Math.max(h[1]-f,a)],[c,Math.min(h[1]+f,l)]])}return u()}function gb(e){return Wu((me+e)/2)}function Dk(e,t){var n=K(e),r=e===t?Q(e):al(n/K(t))/al(gb(t)/gb(e)),i=n*Vx(gb(e),r)/r;if(!r)return of;function o(s,a){i>0?a<-me+et&&(a=-me+et):a>me-et&&(a=me-et);var c=i/Vx(gb(a),r);return[c*Q(r*s),i-c*K(r*s)]}return o.invert=function(s,a){var c=i-a,l=Un(r)*ye(s*s+c*c),u=He(s,Rt(c))*Un(c);return c*r<0&&(u-=Ot*Un(s)*Un(c)),[u/r,2*mi(Vx(i/l,1/r))-me]},o}function _M(){return rf(Dk).scale(109.5).parallels([30,30])}function sf(e,t){return[e,t]}sf.invert=sf;function SM(){return Dn(sf).scale(152.63)}function Ok(e,t){var n=K(e),r=e===t?Q(e):(n-K(t))/(t-e),i=n/r+e;if(Rt(r)<et)return sf;function o(s,a){var c=i-a,l=r*s;return[c*Q(l),i-c*K(l)]}return o.invert=function(s,a){var c=i-a,l=He(s,Rt(c))*Un(c);return c*r<0&&(l-=Ot*Un(s)*Un(c)),[l/r,i-Un(r)*ye(s*s+c*c)]},o}function IM(){return rf(Ok).scale(131.154).center([0,13.9389])}var tm=1.340264,em=-.081106,nm=893e-6,rm=.003796,xb=ye(3)/2,ZW=12;function MM(e,t){var n=Se(xb*Q(t)),r=n*n,i=r*r*r;return[e*K(n)/(xb*(tm+3*em*r+i*(7*nm+9*rm*r))),n*(tm+em*r+i*(nm+rm*r))]}MM.invert=function(e,t){for(var n=t,r=n*n,i=r*r*r,o=0,s,a,c;o<ZW&&(a=n*(tm+em*r+i*(nm+rm*r))-t,c=tm+3*em*r+i*(7*nm+9*rm*r),n-=s=a/c,r=n*n,i=r*r*r,!(Rt(s)<sl));++o);return[xb*e*(tm+3*em*r+i*(7*nm+9*rm*r))/K(n),Se(Q(n)/xb)]};function AM(){return Dn(MM).scale(177.158)}function TM(e,t){var n=K(t),r=K(e)*n;return[n*Q(e)/r,Q(t)/r]}TM.invert=Co(mi);function EM(){return Dn(TM).scale(144.049).clipAngle(60)}function NM(e,t){return[K(t)*Q(e),Q(t)]}NM.invert=Co(Se);function DM(){return Dn(NM).scale(249.5).clipAngle(90+et)}function OM(e,t){var n=K(t),r=1+K(e)*n;return[n*Q(e)/r,Q(t)/r]}OM.invert=Co(function(e){return 2*mi(e)});function BM(){return Dn(OM).scale(250).clipAngle(142)}function LM(e,t){return[al(Wu((me+t)/2)),-e]}LM.invert=function(e,t){return[-t,2*mi(qx(e))-me]};function CM(){var e=vM(LM),t=e.center,n=e.rotate;return e.center=function(r){return arguments.length?t([-r[1],r[0]]):(r=t(),[r[1],-r[0]])},e.rotate=function(r){return arguments.length?n([r[0],r[1],r.length>2?r[2]+90:90]):(r=n(),[r[0],r[1],r[2]-90])},n([0,0,90]).scale(159.155)}function JW(e,t){return e.parent===t.parent?1:2}function QW(e){return e.reduce(KW,0)/e.length}function KW(e,t){return e+t.x}function tH(e){return 1+e.reduce(eH,0)}function eH(e,t){return Math.max(e,t.y)}function nH(e){for(var t;t=e.children;)e=t[0];return e}function rH(e){for(var t;t=e.children;)e=t[t.length-1];return e}function bb(){var e=JW,t=1,n=1,r=!1;function i(o){var s,a=0;o.eachAfter(function(h){var d=h.children;d?(h.x=QW(d),h.y=tH(d)):(h.x=s?a+=e(h,s):0,h.y=0,s=h)});var c=nH(o),l=rH(o),u=c.x-e(c,l)/2,f=l.x+e(l,c)/2;return o.eachAfter(r?function(h){h.x=(h.x-o.x)*t,h.y=(o.y-h.y)*n}:function(h){h.x=(h.x-u)/(f-u)*t,h.y=(1-(o.y?h.y/o.y:1))*n})}return i.separation=function(o){return arguments.length?(e=o,i):e},i.size=function(o){return arguments.length?(r=!1,t=+o[0],n=+o[1],i):r?null:[t,n]},i.nodeSize=function(o){return arguments.length?(r=!0,t=+o[0],n=+o[1],i):r?[t,n]:null},i}function iH(e){var t=0,n=e.children,r=n&&n.length;if(!r)t=1;else for(;--r>=0;)t+=n[r].value;e.value=t}function Bk(){return this.eachAfter(iH)}function Lk(e,t){let n=-1;for(let r of this)e.call(t,r,++n,this);return this}function Ck(e,t){for(var n=this,r=[n],i,o,s=-1;n=r.pop();)if(e.call(t,n,++s,this),i=n.children)for(o=i.length-1;o>=0;--o)r.push(i[o]);return this}function kk(e,t){for(var n=this,r=[n],i=[],o,s,a,c=-1;n=r.pop();)if(i.push(n),o=n.children)for(s=0,a=o.length;s<a;++s)r.push(o[s]);for(;n=i.pop();)e.call(t,n,++c,this);return this}function Fk(e,t){let n=-1;for(let r of this)if(e.call(t,r,++n,this))return r}function Rk(e){return this.eachAfter(function(t){for(var n=+e(t.data)||0,r=t.children,i=r&&r.length;--i>=0;)n+=r[i].value;t.value=n})}function $k(e){return this.eachBefore(function(t){t.children&&t.children.sort(e)})}function Pk(e){for(var t=this,n=oH(t,e),r=[t];t!==n;)t=t.parent,r.push(t);for(var i=r.length;e!==n;)r.splice(i,0,e),e=e.parent;return r}function oH(e,t){if(e===t)return e;var n=e.ancestors(),r=t.ancestors(),i=null;for(e=n.pop(),t=r.pop();e===t;)i=e,e=n.pop(),t=r.pop();return i}function Uk(){for(var e=this,t=[e];e=e.parent;)t.push(e);return t}function zk(){return Array.from(this)}function qk(){var e=[];return this.eachBefore(function(t){t.children||e.push(t)}),e}function jk(){var e=this,t=[];return e.each(function(n){n!==e&&t.push({source:n.parent,target:n})}),t}function*Vk(){var e=this,t,n=[e],r,i,o;do for(t=n.reverse(),n=[];e=t.pop();)if(yield e,r=e.children)for(i=0,o=r.length;i<o;++i)n.push(r[i]);while(n.length)}function kM(e,t){e instanceof Map?(e=[void 0,e],t===void 0&&(t=cH)):t===void 0&&(t=aH);for(var n=new Pa(e),r,i=[n],o,s,a,c;r=i.pop();)if((s=t(r.data))&&(c=(s=Array.from(s)).length))for(r.children=s,a=c-1;a>=0;--a)i.push(o=s[a]=new Pa(s[a])),o.parent=r,o.depth=r.depth+1;return n.eachBefore(FM)}function sH(){return kM(this).eachBefore(lH)}function aH(e){return e.children}function cH(e){return Array.isArray(e)?e[1]:null}function lH(e){e.data.value!==void 0&&(e.value=e.data.value),e.data=e.data.data}function FM(e){var t=0;do e.height=t;while((e=e.parent)&&e.height<++t)}function Pa(e){this.data=e,this.depth=this.height=0,this.parent=null}Pa.prototype=kM.prototype={constructor:Pa,count:Bk,each:Lk,eachAfter:kk,eachBefore:Ck,find:Fk,sum:Rk,sort:$k,path:Pk,ancestors:Uk,descendants:zk,leaves:qk,links:jk,copy:sH,[Symbol.iterator]:Vk};function wb(e){return e==null?null:uH(e)}function uH(e){if(typeof e!="function")throw new Error;return e}var fH={depth:-1},Yk={},RM={};function hH(e){return e.id}function dH(e){return e.parentId}function vb(){var e=hH,t=dH,n;function r(i){var o=Array.from(i),s=e,a=t,c,l,u,f,h,d,p,m,y=new Map;if(n!=null){let g=o.map((w,_)=>pH(n(w,_,i))),x=g.map(Xk),b=new Set(g).add("");for(let w of x)b.has(w)||(b.add(w),g.push(w),x.push(Xk(w)),o.push(RM));s=(w,_)=>g[_],a=(w,_)=>x[_]}for(u=0,c=o.length;u<c;++u)l=o[u],d=o[u]=new Pa(l),(p=s(l,u,i))!=null&&(p+="")&&(m=d.id=p,y.set(m,y.has(m)?Yk:d)),(p=a(l,u,i))!=null&&(p+="")&&(d.parent=p);for(u=0;u<c;++u)if(d=o[u],p=d.parent){if(h=y.get(p),!h)throw new Error("missing: "+p);if(h===Yk)throw new Error("ambiguous: "+p);h.children?h.children.push(d):h.children=[d],d.parent=h}else{if(f)throw new Error("multiple roots");f=d}if(!f)throw new Error("no root");if(n!=null){for(;f.data===RM&&f.children.length===1;)f=f.children[0],--c;for(let g=o.length-1;g>=0&&(d=o[g],d.data===RM);--g)d.data=null}if(f.parent=fH,f.eachBefore(function(g){g.depth=g.parent.depth+1,--c}).eachBefore(FM),f.parent=null,c>0)throw new Error("cycle");return f}return r.id=function(i){return arguments.length?(e=wb(i),r):e},r.parentId=function(i){return arguments.length?(t=wb(i),r):t},r.path=function(i){return arguments.length?(n=wb(i),r):n},r}function pH(e){e=`${e}`;let t=e.length;return $M(e,t-1)&&!$M(e,t-2)&&(e=e.slice(0,-1)),e[0]==="/"?e:`/${e}`}function Xk(e){let t=e.length;if(t<2)return"";for(;--t>1&&!$M(e,t););return e.slice(0,t)}function $M(e,t){if(e[t]==="/"){let n=0;for(;t>0&&e[--t]==="\\";)++n;if(!(n&1))return!0}return!1}function mH(e,t){return e.parent===t.parent?1:2}function PM(e){var t=e.children;return t?t[0]:e.t}function UM(e){var t=e.children;return t?t[t.length-1]:e.t}function yH(e,t,n){var r=n/(t.i-e.i);t.c-=r,t.s+=n,e.c+=r,t.z+=n,t.m+=n}function gH(e){for(var t=0,n=0,r=e.children,i=r.length,o;--i>=0;)o=r[i],o.z+=t,o.m+=t,t+=o.s+(n+=o.c)}function xH(e,t,n){return e.a.parent===t.parent?e.a:n}function _b(e,t){this._=e,this.parent=null,this.children=null,this.A=null,this.a=this,this.z=0,this.m=0,this.c=0,this.s=0,this.t=null,this.i=t}_b.prototype=Object.create(Pa.prototype);function bH(e){for(var t=new _b(e,0),n,r=[t],i,o,s,a;n=r.pop();)if(o=n._.children)for(n.children=new Array(a=o.length),s=a-1;s>=0;--s)r.push(i=n.children[s]=new _b(o[s],s)),i.parent=n;return(t.parent=new _b(null,0)).children=[t],t}function ul(){var e=mH,t=1,n=1,r=null;function i(l){var u=bH(l);if(u.eachAfter(o),u.parent.m=-u.z,u.eachBefore(s),r)l.eachBefore(c);else{var f=l,h=l,d=l;l.eachBefore(function(x){x.x<f.x&&(f=x),x.x>h.x&&(h=x),x.depth>d.depth&&(d=x)});var p=f===h?1:e(f,h)/2,m=p-f.x,y=t/(h.x+p+m),g=n/(d.depth||1);l.eachBefore(function(x){x.x=(x.x+m)*y,x.y=x.depth*g})}return l}function o(l){var u=l.children,f=l.parent.children,h=l.i?f[l.i-1]:null;if(u){gH(l);var d=(u[0].z+u[u.length-1].z)/2;h?(l.z=h.z+e(l._,h._),l.m=l.z-d):l.z=d}else h&&(l.z=h.z+e(l._,h._));l.parent.A=a(l,h,l.parent.A||f[0])}function s(l){l._.x=l.z+l.parent.m,l.m+=l.parent.m}function a(l,u,f){if(u){for(var h=l,d=l,p=u,m=h.parent.children[0],y=h.m,g=d.m,x=p.m,b=m.m,w;p=UM(p),h=PM(h),p&&h;)m=PM(m),d=UM(d),d.a=l,w=p.z+x-h.z-y+e(p._,h._),w>0&&(yH(xH(p,l,f),l,w),y+=w,g+=w),x+=p.m,y+=h.m,b+=m.m,g+=d.m;p&&!UM(d)&&(d.t=p,d.m+=x-g),h&&!PM(m)&&(m.t=h,m.m+=y-b,f=l)}return f}function c(l){l.x*=t,l.y=l.depth*n}return i.separation=function(l){return arguments.length?(e=l,i):e},i.size=function(l){return arguments.length?(r=!1,t=+l[0],n=+l[1],i):r?null:[t,n]},i.nodeSize=function(l){return arguments.length?(r=!0,t=+l[0],n=+l[1],i):r?[t,n]:null},i}var Gk=23283064365386963e-26;function fl(e=Math.random()){let t=(0<=e&&e<1?e/Gk:Math.abs(e))|0;return()=>(t=1664525*t+1013904223|0,Gk*(t>>>0))}function Je(e,t){switch(arguments.length){case 0:break;case 1:this.range(e);break;default:this.range(t).domain(e);break}return this}function im(e,t){switch(arguments.length){case 0:break;case 1:{typeof e=="function"?this.interpolator(e):this.range(e);break}default:{this.domain(e),typeof t=="function"?this.interpolator(t):this.range(t);break}}return this}var om=Symbol("implicit");function hl(){var e=new Jn,t=[],n=[],r=om;function i(o){let s=e.get(o);if(s===void 0){if(r!==om)return r;e.set(o,s=t.push(o)-1)}return n[s%n.length]}return i.domain=function(o){if(!arguments.length)return t.slice();t=[],e=new Jn;for(let s of o)e.has(s)||e.set(s,t.push(s)-1);return i},i.range=function(o){return arguments.length?(n=Array.from(o),i):n.slice()},i.unknown=function(o){return arguments.length?(r=o,i):r},i.copy=function(){return hl(t,n).unknown(r)},Je.apply(i,arguments),i}function Ua(){var e=hl().unknown(void 0),t=e.domain,n=e.range,r=0,i=1,o,s,a=!1,c=0,l=0,u=.5;delete e.unknown;function f(){var h=t().length,d=i<r,p=d?i:r,m=d?r:i;o=(m-p)/Math.max(1,h-c+l*2),a&&(o=Math.floor(o)),p+=(m-p-o*(h-c))*u,s=o*(1-c),a&&(p=Math.round(p),s=Math.round(s));var y=Ue(h).map(function(g){return p+o*g});return n(d?y.reverse():y)}return e.domain=function(h){return arguments.length?(t(h),f()):t()},e.range=function(h){return arguments.length?([r,i]=h,r=+r,i=+i,f()):[r,i]},e.rangeRound=function(h){return[r,i]=h,r=+r,i=+i,a=!0,f()},e.bandwidth=function(){return s},e.step=function(){return o},e.round=function(h){return arguments.length?(a=!!h,f()):a},e.padding=function(h){return arguments.length?(c=Math.min(1,l=+h),f()):c},e.paddingInner=function(h){return arguments.length?(c=Math.min(1,h),f()):c},e.paddingOuter=function(h){return arguments.length?(l=+h,f()):l},e.align=function(h){return arguments.length?(u=Math.max(0,Math.min(1,h)),f()):u},e.copy=function(){return Ua(t(),[r,i]).round(a).paddingInner(c).paddingOuter(l).align(u)},Je.apply(f(),arguments)}function Wk(e){var t=e.copy;return e.padding=e.paddingOuter,delete e.paddingInner,delete e.paddingOuter,e.copy=function(){return Wk(t())},e}function zM(){return Wk(Ua.apply(null,arguments).paddingInner(1))}function qM(e){return function(){return e}}function af(e){return+e}var Hk=[0,1];function vr(e){return e}function jM(e,t){return(t-=e=+e)?function(n){return(n-e)/t}:qM(isNaN(t)?NaN:.5)}function wH(e,t){var n;return e>t&&(n=e,e=t,t=n),function(r){return Math.max(e,Math.min(t,r))}}function vH(e,t,n){var r=e[0],i=e[1],o=t[0],s=t[1];return i<r?(r=jM(i,r),o=n(s,o)):(r=jM(r,i),o=n(o,s)),function(a){return o(r(a))}}function _H(e,t,n){var r=Math.min(e.length,t.length)-1,i=new Array(r),o=new Array(r),s=-1;for(e[r]<e[0]&&(e=e.slice().reverse(),t=t.slice().reverse());++s<r;)i[s]=jM(e[s],e[s+1]),o[s]=n(t[s],t[s+1]);return function(a){var c=Ms(e,a,1,r)-1;return o[c](i[c](a))}}function ko(e,t){return t.domain(e.domain()).range(e.range()).interpolate(e.interpolate()).clamp(e.clamp()).unknown(e.unknown())}function dl(){var e=Hk,t=Hk,n=$r,r,i,o,s=vr,a,c,l;function u(){var h=Math.min(e.length,t.length);return s!==vr&&(s=wH(e[0],e[h-1])),a=h>2?_H:vH,c=l=null,f}function f(h){return h==null||isNaN(h=+h)?o:(c||(c=a(e.map(r),t,n)))(r(s(h)))}return f.invert=function(h){return s(i((l||(l=a(t,e.map(r),_e)))(h)))},f.domain=function(h){return arguments.length?(e=Array.from(h,af),u()):e.slice()},f.range=function(h){return arguments.length?(t=Array.from(h),u()):t.slice()},f.rangeRound=function(h){return t=Array.from(h),n=tl,u()},f.clamp=function(h){return arguments.length?(s=h?!0:vr,u()):s!==vr},f.interpolate=function(h){return arguments.length?(n=h,u()):n},f.unknown=function(h){return arguments.length?(o=h,f):o},function(h,d){return r=h,i=d,u()}}function sm(){return dl()(vr,vr)}function VM(e,t,n,r){var i=Nu(e,t,n),o;switch(r=Do(r??",f"),r.type){case"s":{var s=Math.max(Math.abs(e),Math.abs(t));return r.precision==null&&!isNaN(o=RI(i,s))&&(r.precision=o),zx(r,s)}case"":case"e":case"g":case"p":case"r":{r.precision==null&&!isNaN(o=$I(i,Math.max(Math.abs(e),Math.abs(t))))&&(r.precision=o-(r.type==="e"));break}case"f":case"%":{r.precision==null&&!isNaN(o=FI(i))&&(r.precision=o-(r.type==="%")*2);break}}return pi(r)}function Rs(e){var t=e.domain;return e.ticks=function(n){var r=t();return An(r[0],r[r.length-1],n??10)},e.tickFormat=function(n,r){var i=t();return VM(i[0],i[i.length-1],n??10,r)},e.nice=function(n){n==null&&(n=10);var r=t(),i=0,o=r.length-1,s=r[i],a=r[o],c,l,u=10;for(a<s&&(l=s,s=a,a=l,l=i,i=o,o=l);u-- >0;){if(l=Ts(s,a,n),l===c)return r[i]=s,r[o]=a,t(r);if(l>0)s=Math.floor(s/l)*l,a=Math.ceil(a/l)*l;else if(l<0)s=Math.ceil(s*l)/l,a=Math.floor(a*l)/l;else break;c=l}return e},e}function $s(){var e=sm();return e.copy=function(){return ko(e,$s())},Je.apply(e,arguments),Rs(e)}function am(e){var t;function n(r){return r==null||isNaN(r=+r)?t:r}return n.invert=n,n.domain=n.range=function(r){return arguments.length?(e=Array.from(r,af),n):e.slice()},n.unknown=function(r){return arguments.length?(t=r,n):t},n.copy=function(){return am(e).unknown(t)},e=arguments.length?Array.from(e,af):[0,1],Rs(n)}function cm(e,t){e=e.slice();var n=0,r=e.length-1,i=e[n],o=e[r],s;return o<i&&(s=n,n=r,r=s,s=i,i=o,o=s),e[n]=t.floor(i),e[r]=t.ceil(o),e}function Zk(e){return Math.log(e)}function Jk(e){return Math.exp(e)}function SH(e){return-Math.log(-e)}function IH(e){return-Math.exp(-e)}function MH(e){return isFinite(e)?+("1e"+e):e<0?0:e}function AH(e){return e===10?MH:e===Math.E?Math.exp:t=>Math.pow(e,t)}function TH(e){return e===Math.E?Math.log:e===10&&Math.log10||e===2&&Math.log2||(e=Math.log(e),t=>Math.log(t)/e)}function Qk(e){return(t,n)=>-e(-t,n)}function YM(e){let t=e(Zk,Jk),n=t.domain,r=10,i,o;function s(){return i=TH(r),o=AH(r),n()[0]<0?(i=Qk(i),o=Qk(o),e(SH,IH)):e(Zk,Jk),t}return t.base=function(a){return arguments.length?(r=+a,s()):r},t.domain=function(a){return arguments.length?(n(a),s()):n()},t.ticks=a=>{let c=n(),l=c[0],u=c[c.length-1],f=u<l;f&&([l,u]=[u,l]);let h=i(l),d=i(u),p,m,y=a==null?10:+a,g=[];if(!(r%1)&&d-h<y){if(h=Math.floor(h),d=Math.ceil(d),l>0){for(;h<=d;++h)for(p=1;p<r;++p)if(m=h<0?p/o(-h):p*o(h),!(m<l)){if(m>u)break;g.push(m)}}else for(;h<=d;++h)for(p=r-1;p>=1;--p)if(m=h>0?p/o(-h):p*o(h),!(m<l)){if(m>u)break;g.push(m)}g.length*2<y&&(g=An(l,u,y))}else g=An(h,d,Math.min(d-h,y)).map(o);return f?g.reverse():g},t.tickFormat=(a,c)=>{if(a==null&&(a=10),c==null&&(c=r===10?"s":","),typeof c!="function"&&(!(r%1)&&(c=Do(c)).precision==null&&(c.trim=!0),c=pi(c)),a===1/0)return c;let l=Math.max(1,r*a/t.ticks().length);return u=>{let f=u/o(Math.round(i(u)));return f*r<r-.5&&(f*=r),f<=l?c(u):""}},t.nice=()=>n(cm(n(),{floor:a=>o(Math.floor(i(a))),ceil:a=>o(Math.ceil(i(a)))})),t}function lm(){let e=YM(dl()).domain([1,10]);return e.copy=()=>ko(e,lm()).base(e.base()),Je.apply(e,arguments),e}function Kk(e){return function(t){return Math.sign(t)*Math.log1p(Math.abs(t/e))}}function tF(e){return function(t){return Math.sign(t)*Math.expm1(Math.abs(t))*e}}function XM(e){var t=1,n=e(Kk(t),tF(t));return n.constant=function(r){return arguments.length?e(Kk(t=+r),tF(t)):t},Rs(n)}function um(){var e=XM(dl());return e.copy=function(){return ko(e,um()).constant(e.constant())},Je.apply(e,arguments)}function eF(e){return function(t){return t<0?-Math.pow(-t,e):Math.pow(t,e)}}function EH(e){return e<0?-Math.sqrt(-e):Math.sqrt(e)}function NH(e){return e<0?-e*e:e*e}function GM(e){var t=e(vr,vr),n=1;function r(){return n===1?e(vr,vr):n===.5?e(EH,NH):e(eF(n),eF(1/n))}return t.exponent=function(i){return arguments.length?(n=+i,r()):n},Rs(t)}function fm(){var e=GM(dl());return e.copy=function(){return ko(e,fm()).exponent(e.exponent())},Je.apply(e,arguments),e}function hm(){var e=[],t=[],n=[],r;function i(){var s=0,a=Math.max(1,t.length);for(n=new Array(a-1);++s<a;)n[s-1]=XS(e,s/a);return o}function o(s){return s==null||isNaN(s=+s)?r:t[Ms(n,s)]}return o.invertExtent=function(s){var a=t.indexOf(s);return a<0?[NaN,NaN]:[a>0?n[a-1]:e[0],a<n.length?n[a]:e[e.length-1]]},o.domain=function(s){if(!arguments.length)return e.slice();e=[];for(let a of s)a!=null&&!isNaN(a=+a)&&e.push(a);return e.sort(zt),i()},o.range=function(s){return arguments.length?(t=Array.from(s),i()):t.slice()},o.unknown=function(s){return arguments.length?(r=s,o):r},o.quantiles=function(){return n.slice()},o.copy=function(){return hm().domain(e).range(t).unknown(r)},Je.apply(o,arguments)}function dm(){var e=[.5],t=[0,1],n,r=1;function i(o){return o!=null&&o<=o?t[Ms(e,o,0,r)]:n}return i.domain=function(o){return arguments.length?(e=Array.from(o),r=Math.min(e.length,t.length-1),i):e.slice()},i.range=function(o){return arguments.length?(t=Array.from(o),r=Math.min(e.length,t.length-1),i):t.slice()},i.invertExtent=function(o){var s=t.indexOf(o);return[e[s-1],e[s]]},i.unknown=function(o){return arguments.length?(n=o,i):n},i.copy=function(){return dm().domain(e).range(t).unknown(n)},Je.apply(i,arguments)}var WM=new Date,HM=new Date;function be(e,t,n,r){function i(o){return e(o=arguments.length===0?new Date:new Date(+o)),o}return i.floor=o=>(e(o=new Date(+o)),o),i.ceil=o=>(e(o=new Date(o-1)),t(o,1),e(o),o),i.round=o=>{let s=i(o),a=i.ceil(o);return o-s<a-o?s:a},i.offset=(o,s)=>(t(o=new Date(+o),s==null?1:Math.floor(s)),o),i.range=(o,s,a)=>{let c=[];if(o=i.ceil(o),a=a==null?1:Math.floor(a),!(o<s)||!(a>0))return c;let l;do c.push(l=new Date(+o)),t(o,a),e(o);while(l<o&&o<s);return c},i.filter=o=>be(s=>{if(s>=s)for(;e(s),!o(s);)s.setTime(s-1)},(s,a)=>{if(s>=s)if(a<0)for(;++a<=0;)for(;t(s,-1),!o(s););else for(;--a>=0;)for(;t(s,1),!o(s););}),n&&(i.count=(o,s)=>(WM.setTime(+o),HM.setTime(+s),e(WM),e(HM),Math.floor(n(WM,HM))),i.every=o=>(o=Math.floor(o),!isFinite(o)||!(o>0)?null:o>1?i.filter(r?s=>r(s)%o===0:s=>i.count(0,s)%o===0):i)),i}var pm=be(()=>{},(e,t)=>{e.setTime(+e+t)},(e,t)=>t-e);pm.every=e=>(e=Math.floor(e),!isFinite(e)||!(e>0)?null:e>1?be(t=>{t.setTime(Math.floor(t/e)*e)},(t,n)=>{t.setTime(+t+n*e)},(t,n)=>(n-t)/e):pm);var S6t=pm.range;var fn=be(e=>{e.setTime(e-e.getMilliseconds())},(e,t)=>{e.setTime(+e+t*1e3)},(e,t)=>(t-e)/1e3,e=>e.getUTCSeconds()),nF=fn.range;var Ps=be(e=>{e.setTime(e-e.getMilliseconds()-e.getSeconds()*1e3)},(e,t)=>{e.setTime(+e+t*6e4)},(e,t)=>(t-e)/6e4,e=>e.getMinutes()),DH=Ps.range,Us=be(e=>{e.setUTCSeconds(0,0)},(e,t)=>{e.setTime(+e+t*6e4)},(e,t)=>(t-e)/6e4,e=>e.getUTCMinutes()),OH=Us.range;var zs=be(e=>{e.setTime(e-e.getMilliseconds()-e.getSeconds()*1e3-e.getMinutes()*6e4)},(e,t)=>{e.setTime(+e+t*36e5)},(e,t)=>(t-e)/36e5,e=>e.getHours()),BH=zs.range,qs=be(e=>{e.setUTCMinutes(0,0,0)},(e,t)=>{e.setTime(+e+t*36e5)},(e,t)=>(t-e)/36e5,e=>e.getUTCHours()),LH=qs.range;var yi=be(e=>e.setHours(0,0,0,0),(e,t)=>e.setDate(e.getDate()+t),(e,t)=>(t-e-(t.getTimezoneOffset()-e.getTimezoneOffset())*6e4)/864e5,e=>e.getDate()-1),CH=yi.range,yl=be(e=>{e.setUTCHours(0,0,0,0)},(e,t)=>{e.setUTCDate(e.getUTCDate()+t)},(e,t)=>(t-e)/864e5,e=>e.getUTCDate()-1),kH=yl.range,gl=be(e=>{e.setUTCHours(0,0,0,0)},(e,t)=>{e.setUTCDate(e.getUTCDate()+t)},(e,t)=>(t-e)/864e5,e=>Math.floor(e/864e5)),FH=gl.range;function xl(e){return be(t=>{t.setDate(t.getDate()-(t.getDay()+7-e)%7),t.setHours(0,0,0,0)},(t,n)=>{t.setDate(t.getDate()+n*7)},(t,n)=>(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*6e4)/6048e5)}var Ur=xl(0),za=xl(1),Sb=xl(2),Ib=xl(3),Ro=xl(4),Mb=xl(5),Ab=xl(6),iF=Ur.range,RH=za.range,$H=Sb.range,PH=Ib.range,UH=Ro.range,zH=Mb.range,qH=Ab.range;function bl(e){return be(t=>{t.setUTCDate(t.getUTCDate()-(t.getUTCDay()+7-e)%7),t.setUTCHours(0,0,0,0)},(t,n)=>{t.setUTCDate(t.getUTCDate()+n*7)},(t,n)=>(n-t)/6048e5)}var zr=bl(0),qa=bl(1),Tb=bl(2),Eb=bl(3),$o=bl(4),Nb=bl(5),Db=bl(6),oF=zr.range,jH=qa.range,VH=Tb.range,YH=Eb.range,XH=$o.range,GH=Nb.range,WH=Db.range;var js=be(e=>{e.setDate(1),e.setHours(0,0,0,0)},(e,t)=>{e.setMonth(e.getMonth()+t)},(e,t)=>t.getMonth()-e.getMonth()+(t.getFullYear()-e.getFullYear())*12,e=>e.getMonth()),HH=js.range,Vs=be(e=>{e.setUTCDate(1),e.setUTCHours(0,0,0,0)},(e,t)=>{e.setUTCMonth(e.getUTCMonth()+t)},(e,t)=>t.getUTCMonth()-e.getUTCMonth()+(t.getUTCFullYear()-e.getUTCFullYear())*12,e=>e.getUTCMonth()),ZH=Vs.range;var zn=be(e=>{e.setMonth(0,1),e.setHours(0,0,0,0)},(e,t)=>{e.setFullYear(e.getFullYear()+t)},(e,t)=>t.getFullYear()-e.getFullYear(),e=>e.getFullYear());zn.every=e=>!isFinite(e=Math.floor(e))||!(e>0)?null:be(t=>{t.setFullYear(Math.floor(t.getFullYear()/e)*e),t.setMonth(0,1),t.setHours(0,0,0,0)},(t,n)=>{t.setFullYear(t.getFullYear()+n*e)});var JH=zn.range,qn=be(e=>{e.setUTCMonth(0,1),e.setUTCHours(0,0,0,0)},(e,t)=>{e.setUTCFullYear(e.getUTCFullYear()+t)},(e,t)=>t.getUTCFullYear()-e.getUTCFullYear(),e=>e.getUTCFullYear());qn.every=e=>!isFinite(e=Math.floor(e))||!(e>0)?null:be(t=>{t.setUTCFullYear(Math.floor(t.getUTCFullYear()/e)*e),t.setUTCMonth(0,1),t.setUTCHours(0,0,0,0)},(t,n)=>{t.setUTCFullYear(t.getUTCFullYear()+n*e)});var QH=qn.range;function aF(e,t,n,r,i,o){let s=[[fn,1,1e3],[fn,5,5*1e3],[fn,15,15*1e3],[fn,30,30*1e3],[o,1,6e4],[o,5,5*6e4],[o,15,15*6e4],[o,30,30*6e4],[i,1,36e5],[i,3,3*36e5],[i,6,6*36e5],[i,12,12*36e5],[r,1,864e5],[r,2,2*864e5],[n,1,6048e5],[t,1,2592e6],[t,3,3*2592e6],[e,1,31536e6]];function a(l,u,f){let h=u<l;h&&([l,u]=[u,l]);let d=f&&typeof f.range=="function"?f:c(l,u,f),p=d?d.range(l,+u+1):[];return h?p.reverse():p}function c(l,u,f){let h=Math.abs(u-l)/f,d=Is(([,,y])=>y).right(s,h);if(d===s.length)return e.every(Nu(l/31536e6,u/31536e6,f));if(d===0)return pm.every(Math.max(Nu(l,u,f),1));let[p,m]=s[h/s[d-1][2]<s[d][2]/h?d-1:d];return p.every(m)}return[a,c]}var[ZM,ym]=aF(qn,Vs,zr,gl,qs,Us),[JM,QM]=aF(zn,js,Ur,yi,zs,Ps);function KM(e){if(0<=e.y&&e.y<100){var t=new Date(-1,e.m,e.d,e.H,e.M,e.S,e.L);return t.setFullYear(e.y),t}return new Date(e.y,e.m,e.d,e.H,e.M,e.S,e.L)}function tA(e){if(0<=e.y&&e.y<100){var t=new Date(Date.UTC(-1,e.m,e.d,e.H,e.M,e.S,e.L));return t.setUTCFullYear(e.y),t}return new Date(Date.UTC(e.y,e.m,e.d,e.H,e.M,e.S,e.L))}function gm(e,t,n){return{y:e,m:t,d:n,H:0,M:0,S:0,L:0}}function eA(e){var t=e.dateTime,n=e.date,r=e.time,i=e.periods,o=e.days,s=e.shortDays,a=e.months,c=e.shortMonths,l=xm(i),u=bm(i),f=xm(o),h=bm(o),d=xm(s),p=bm(s),m=xm(a),y=bm(a),g=xm(c),x=bm(c),b={a:F,A:R,b:k,B:$,c:null,d:dF,e:dF,f:_Z,g:BZ,G:CZ,H:bZ,I:wZ,j:vZ,L:xF,m:SZ,M:IZ,p:P,q:U,Q:yF,s:gF,S:MZ,u:AZ,U:TZ,V:EZ,w:NZ,W:DZ,x:null,X:null,y:OZ,Y:LZ,Z:kZ,"%":mF},w={a:W,A:nt,b:ot,B:at,c:null,d:pF,e:pF,f:PZ,g:HZ,G:JZ,H:FZ,I:RZ,j:$Z,L:wF,m:UZ,M:zZ,p:Y,q:st,Q:yF,s:gF,S:qZ,u:jZ,U:VZ,V:YZ,w:XZ,W:GZ,x:null,X:null,y:WZ,Y:ZZ,Z:QZ,"%":mF},_={a:D,A,b:O,B:C,c:S,d:fF,e:fF,f:mZ,g:uF,G:lF,H:hF,I:hF,j:fZ,L:pZ,m:uZ,M:hZ,p:I,q:lZ,Q:gZ,s:xZ,S:dZ,u:iZ,U:oZ,V:sZ,w:rZ,W:aZ,x:T,X:N,y:uF,Y:lF,Z:cZ,"%":yZ};b.x=v(n,b),b.X=v(r,b),b.c=v(t,b),w.x=v(n,w),w.X=v(r,w),w.c=v(t,w);function v(j,Z){return function(rt){var z=[],kt=-1,ht=0,Wt=j.length,Zt,tt,ae;for(rt instanceof Date||(rt=new Date(+rt));++kt<Wt;)j.charCodeAt(kt)===37&&(z.push(j.slice(ht,kt)),(tt=cF[Zt=j.charAt(++kt)])!=null?Zt=j.charAt(++kt):tt=Zt==="e"?" ":"0",(ae=Z[Zt])&&(Zt=ae(rt,tt)),z.push(Zt),ht=kt+1);return z.push(j.slice(ht,kt)),z.join("")}}function M(j,Z){return function(rt){var z=gm(1900,void 0,1),kt=E(z,j,rt+="",0),ht,Wt;if(kt!=rt.length)return null;if("Q"in z)return new Date(z.Q);if("s"in z)return new Date(z.s*1e3+("L"in z?z.L:0));if(Z&&!("Z"in z)&&(z.Z=0),"p"in z&&(z.H=z.H%12+z.p*12),z.m===void 0&&(z.m="q"in z?z.q:0),"V"in z){if(z.V<1||z.V>53)return null;"w"in z||(z.w=1),"Z"in z?(ht=tA(gm(z.y,0,1)),Wt=ht.getUTCDay(),ht=Wt>4||Wt===0?qa.ceil(ht):qa(ht),ht=yl.offset(ht,(z.V-1)*7),z.y=ht.getUTCFullYear(),z.m=ht.getUTCMonth(),z.d=ht.getUTCDate()+(z.w+6)%7):(ht=KM(gm(z.y,0,1)),Wt=ht.getDay(),ht=Wt>4||Wt===0?za.ceil(ht):za(ht),ht=yi.offset(ht,(z.V-1)*7),z.y=ht.getFullYear(),z.m=ht.getMonth(),z.d=ht.getDate()+(z.w+6)%7)}else("W"in z||"U"in z)&&("w"in z||(z.w="u"in z?z.u%7:"W"in z?1:0),Wt="Z"in z?tA(gm(z.y,0,1)).getUTCDay():KM(gm(z.y,0,1)).getDay(),z.m=0,z.d="W"in z?(z.w+6)%7+z.W*7-(Wt+5)%7:z.w+z.U*7-(Wt+6)%7);return"Z"in z?(z.H+=z.Z/100|0,z.M+=z.Z%100,tA(z)):KM(z)}}function E(j,Z,rt,z){for(var kt=0,ht=Z.length,Wt=rt.length,Zt,tt;kt<ht;){if(z>=Wt)return-1;if(Zt=Z.charCodeAt(kt++),Zt===37){if(Zt=Z.charAt(kt++),tt=_[Zt in cF?Z.charAt(kt++):Zt],!tt||(z=tt(j,rt,z))<0)return-1}else if(Zt!=rt.charCodeAt(z++))return-1}return z}function I(j,Z,rt){var z=l.exec(Z.slice(rt));return z?(j.p=u.get(z[0].toLowerCase()),rt+z[0].length):-1}function D(j,Z,rt){var z=d.exec(Z.slice(rt));return z?(j.w=p.get(z[0].toLowerCase()),rt+z[0].length):-1}function A(j,Z,rt){var z=f.exec(Z.slice(rt));return z?(j.w=h.get(z[0].toLowerCase()),rt+z[0].length):-1}function O(j,Z,rt){var z=g.exec(Z.slice(rt));return z?(j.m=x.get(z[0].toLowerCase()),rt+z[0].length):-1}function C(j,Z,rt){var z=m.exec(Z.slice(rt));return z?(j.m=y.get(z[0].toLowerCase()),rt+z[0].length):-1}function S(j,Z,rt){return E(j,t,Z,rt)}function T(j,Z,rt){return E(j,n,Z,rt)}function N(j,Z,rt){return E(j,r,Z,rt)}function F(j){return s[j.getDay()]}function R(j){return o[j.getDay()]}function k(j){return c[j.getMonth()]}function $(j){return a[j.getMonth()]}function P(j){return i[+(j.getHours()>=12)]}function U(j){return 1+~~(j.getMonth()/3)}function W(j){return s[j.getUTCDay()]}function nt(j){return o[j.getUTCDay()]}function ot(j){return c[j.getUTCMonth()]}function at(j){return a[j.getUTCMonth()]}function Y(j){return i[+(j.getUTCHours()>=12)]}function st(j){return 1+~~(j.getUTCMonth()/3)}return{format:function(j){var Z=v(j+="",b);return Z.toString=function(){return j},Z},parse:function(j){var Z=M(j+="",!1);return Z.toString=function(){return j},Z},utcFormat:function(j){var Z=v(j+="",w);return Z.toString=function(){return j},Z},utcParse:function(j){var Z=M(j+="",!0);return Z.toString=function(){return j},Z}}}var cF={"-":"",_:" ",0:"0"},hn=/^\s*\d+/,tZ=/^%/,eZ=/[\\^$*+?|[\]().{}]/g;function ee(e,t,n){var r=e<0?"-":"",i=(r?-e:e)+"",o=i.length;return r+(o<n?new Array(n-o+1).join(t)+i:i)}function nZ(e){return e.replace(eZ,"\\$&")}function xm(e){return new RegExp("^(?:"+e.map(nZ).join("|")+")","i")}function bm(e){return new Map(e.map((t,n)=>[t.toLowerCase(),n]))}function rZ(e,t,n){var r=hn.exec(t.slice(n,n+1));return r?(e.w=+r[0],n+r[0].length):-1}function iZ(e,t,n){var r=hn.exec(t.slice(n,n+1));return r?(e.u=+r[0],n+r[0].length):-1}function oZ(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.U=+r[0],n+r[0].length):-1}function sZ(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.V=+r[0],n+r[0].length):-1}function aZ(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.W=+r[0],n+r[0].length):-1}function lF(e,t,n){var r=hn.exec(t.slice(n,n+4));return r?(e.y=+r[0],n+r[0].length):-1}function uF(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.y=+r[0]+(+r[0]>68?1900:2e3),n+r[0].length):-1}function cZ(e,t,n){var r=/^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(t.slice(n,n+6));return r?(e.Z=r[1]?0:-(r[2]+(r[3]||"00")),n+r[0].length):-1}function lZ(e,t,n){var r=hn.exec(t.slice(n,n+1));return r?(e.q=r[0]*3-3,n+r[0].length):-1}function uZ(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.m=r[0]-1,n+r[0].length):-1}function fF(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.d=+r[0],n+r[0].length):-1}function fZ(e,t,n){var r=hn.exec(t.slice(n,n+3));return r?(e.m=0,e.d=+r[0],n+r[0].length):-1}function hF(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.H=+r[0],n+r[0].length):-1}function hZ(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.M=+r[0],n+r[0].length):-1}function dZ(e,t,n){var r=hn.exec(t.slice(n,n+2));return r?(e.S=+r[0],n+r[0].length):-1}function pZ(e,t,n){var r=hn.exec(t.slice(n,n+3));return r?(e.L=+r[0],n+r[0].length):-1}function mZ(e,t,n){var r=hn.exec(t.slice(n,n+6));return r?(e.L=Math.floor(r[0]/1e3),n+r[0].length):-1}function yZ(e,t,n){var r=tZ.exec(t.slice(n,n+1));return r?n+r[0].length:-1}function gZ(e,t,n){var r=hn.exec(t.slice(n));return r?(e.Q=+r[0],n+r[0].length):-1}function xZ(e,t,n){var r=hn.exec(t.slice(n));return r?(e.s=+r[0],n+r[0].length):-1}function dF(e,t){return ee(e.getDate(),t,2)}function bZ(e,t){return ee(e.getHours(),t,2)}function wZ(e,t){return ee(e.getHours()%12||12,t,2)}function vZ(e,t){return ee(1+yi.count(zn(e),e),t,3)}function xF(e,t){return ee(e.getMilliseconds(),t,3)}function _Z(e,t){return xF(e,t)+"000"}function SZ(e,t){return ee(e.getMonth()+1,t,2)}function IZ(e,t){return ee(e.getMinutes(),t,2)}function MZ(e,t){return ee(e.getSeconds(),t,2)}function AZ(e){var t=e.getDay();return t===0?7:t}function TZ(e,t){return ee(Ur.count(zn(e)-1,e),t,2)}function bF(e){var t=e.getDay();return t>=4||t===0?Ro(e):Ro.ceil(e)}function EZ(e,t){return e=bF(e),ee(Ro.count(zn(e),e)+(zn(e).getDay()===4),t,2)}function NZ(e){return e.getDay()}function DZ(e,t){return ee(za.count(zn(e)-1,e),t,2)}function OZ(e,t){return ee(e.getFullYear()%100,t,2)}function BZ(e,t){return e=bF(e),ee(e.getFullYear()%100,t,2)}function LZ(e,t){return ee(e.getFullYear()%1e4,t,4)}function CZ(e,t){var n=e.getDay();return e=n>=4||n===0?Ro(e):Ro.ceil(e),ee(e.getFullYear()%1e4,t,4)}function kZ(e){var t=e.getTimezoneOffset();return(t>0?"-":(t*=-1,"+"))+ee(t/60|0,"0",2)+ee(t%60,"0",2)}function pF(e,t){return ee(e.getUTCDate(),t,2)}function FZ(e,t){return ee(e.getUTCHours(),t,2)}function RZ(e,t){return ee(e.getUTCHours()%12||12,t,2)}function $Z(e,t){return ee(1+yl.count(qn(e),e),t,3)}function wF(e,t){return ee(e.getUTCMilliseconds(),t,3)}function PZ(e,t){return wF(e,t)+"000"}function UZ(e,t){return ee(e.getUTCMonth()+1,t,2)}function zZ(e,t){return ee(e.getUTCMinutes(),t,2)}function qZ(e,t){return ee(e.getUTCSeconds(),t,2)}function jZ(e){var t=e.getUTCDay();return t===0?7:t}function VZ(e,t){return ee(zr.count(qn(e)-1,e),t,2)}function vF(e){var t=e.getUTCDay();return t>=4||t===0?$o(e):$o.ceil(e)}function YZ(e,t){return e=vF(e),ee($o.count(qn(e),e)+(qn(e).getUTCDay()===4),t,2)}function XZ(e){return e.getUTCDay()}function GZ(e,t){return ee(qa.count(qn(e)-1,e),t,2)}function WZ(e,t){return ee(e.getUTCFullYear()%100,t,2)}function HZ(e,t){return e=vF(e),ee(e.getUTCFullYear()%100,t,2)}function ZZ(e,t){return ee(e.getUTCFullYear()%1e4,t,4)}function JZ(e,t){var n=e.getUTCDay();return e=n>=4||n===0?$o(e):$o.ceil(e),ee(e.getUTCFullYear()%1e4,t,4)}function QZ(){return"+0000"}function mF(){return"%"}function yF(e){return+e}function gF(e){return Math.floor(+e/1e3)}var cf,lf,_F,Po,SF;nA({dateTime:"%x, %X",date:"%-m/%-d/%Y",time:"%-I:%M:%S %p",periods:["AM","PM"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]});function nA(e){return cf=eA(e),lf=cf.format,_F=cf.parse,Po=cf.utcFormat,SF=cf.utcParse,cf}function KZ(e){return new Date(e)}function tJ(e){return e instanceof Date?+e:+new Date(+e)}function Ob(e,t,n,r,i,o,s,a,c,l){var u=sm(),f=u.invert,h=u.domain,d=l(".%L"),p=l(":%S"),m=l("%I:%M"),y=l("%I %p"),g=l("%a %d"),x=l("%b %d"),b=l("%B"),w=l("%Y");function _(v){return(c(v)<v?d:a(v)<v?p:s(v)<v?m:o(v)<v?y:r(v)<v?i(v)<v?g:x:n(v)<v?b:w)(v)}return u.invert=function(v){return new Date(f(v))},u.domain=function(v){return arguments.length?h(Array.from(v,tJ)):h().map(KZ)},u.ticks=function(v){var M=h();return e(M[0],M[M.length-1],v??10)},u.tickFormat=function(v,M){return M==null?_:l(M)},u.nice=function(v){var M=h();return(!v||typeof v.range!="function")&&(v=t(M[0],M[M.length-1],v??10)),v?h(cm(M,v)):u},u.copy=function(){return ko(u,Ob(e,t,n,r,i,o,s,a,c,l))},u}function Bb(){return Je.apply(Ob(JM,QM,zn,js,Ur,yi,zs,Ps,fn,lf).domain([new Date(2e3,0,1),new Date(2e3,0,2)]),arguments)}function Lb(){return Je.apply(Ob(ZM,ym,qn,Vs,zr,yl,qs,Us,fn,Po).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)]),arguments)}function wm(e,t){return t.domain(e.domain()).interpolator(e.interpolator()).clamp(e.clamp()).unknown(e.unknown())}function Cb(){var e=0,t=.5,n=1,r=1,i,o,s,a,c,l=vr,u,f=!1,h;function d(m){return isNaN(m=+m)?h:(m=.5+((m=+u(m))-o)*(r*m<r*o?a:c),l(f?Math.max(0,Math.min(1,m)):m))}d.domain=function(m){return arguments.length?([e,t,n]=m,i=u(e=+e),o=u(t=+t),s=u(n=+n),a=i===o?0:.5/(o-i),c=o===s?0:.5/(s-o),r=o<i?-1:1,d):[e,t,n]},d.clamp=function(m){return arguments.length?(f=!!m,d):f},d.interpolator=function(m){return arguments.length?(l=m,d):l};function p(m){return function(y){var g,x,b;return arguments.length?([g,x,b]=y,l=Ao(m,[g,x,b]),d):[l(0),l(.5),l(1)]}}return d.range=p($r),d.rangeRound=p(tl),d.unknown=function(m){return arguments.length?(h=m,d):h},function(m){return u=m,i=m(e),o=m(t),s=m(n),a=i===o?0:.5/(o-i),c=o===s?0:.5/(s-o),r=o<i?-1:1,d}}function vm(){var e=Rs(Cb()(vr));return e.copy=function(){return wm(e,vm())},im.apply(e,arguments)}function kb(){var e=YM(Cb()).domain([.1,1,10]);return e.copy=function(){return wm(e,kb()).base(e.base())},im.apply(e,arguments)}function Fb(){var e=XM(Cb());return e.copy=function(){return wm(e,Fb()).constant(e.constant())},im.apply(e,arguments)}function Rb(){var e=GM(Cb());return e.copy=function(){return wm(e,Rb()).exponent(e.exponent())},im.apply(e,arguments)}function X(e){for(var t=e.length/6|0,n=new Array(t),r=0;r<t;)n[r]="#"+e.slice(r*6,++r*6);return n}var rA=X("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf");var iA=X("7fc97fbeaed4fdc086ffff99386cb0f0027fbf5b17666666");var oA=X("1b9e77d95f027570b3e7298a66a61ee6ab02a6761d666666");var sA=X("4269d0efb118ff725c6cc5b03ca951ff8ab7a463f297bbf59c6b4e9498a0");var aA=X("a6cee31f78b4b2df8a33a02cfb9a99e31a1cfdbf6fff7f00cab2d66a3d9affff99b15928");var cA=X("fbb4aeb3cde3ccebc5decbe4fed9a6ffffcce5d8bdfddaecf2f2f2");var lA=X("b3e2cdfdcdaccbd5e8f4cae4e6f5c9fff2aef1e2cccccccc");var uA=X("e41a1c377eb84daf4a984ea3ff7f00ffff33a65628f781bf999999");var fA=X("66c2a5fc8d628da0cbe78ac3a6d854ffd92fe5c494b3b3b3");var hA=X("8dd3c7ffffb3bebadafb807280b1d3fdb462b3de69fccde5d9d9d9bc80bdccebc5ffed6f");var dA=X("4e79a7f28e2ce1575976b7b259a14fedc949af7aa1ff9da79c755fbab0ab");var pt=e=>cI(e[e.length-1]);var $b=new Array(3).concat("d8b365f5f5f55ab4ac","a6611adfc27d80cdc1018571","a6611adfc27df5f5f580cdc1018571","8c510ad8b365f6e8c3c7eae55ab4ac01665e","8c510ad8b365f6e8c3f5f5f5c7eae55ab4ac01665e","8c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e","8c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e","5430058c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e003c30","5430058c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e003c30").map(X),Pb=pt($b);var Ub=new Array(3).concat("af8dc3f7f7f77fbf7b","7b3294c2a5cfa6dba0008837","7b3294c2a5cff7f7f7a6dba0008837","762a83af8dc3e7d4e8d9f0d37fbf7b1b7837","762a83af8dc3e7d4e8f7f7f7d9f0d37fbf7b1b7837","762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b7837","762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b7837","40004b762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b783700441b","40004b762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b783700441b").map(X),zb=pt(Ub);var qb=new Array(3).concat("e9a3c9f7f7f7a1d76a","d01c8bf1b6dab8e1864dac26","d01c8bf1b6daf7f7f7b8e1864dac26","c51b7de9a3c9fde0efe6f5d0a1d76a4d9221","c51b7de9a3c9fde0eff7f7f7e6f5d0a1d76a4d9221","c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221","c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221","8e0152c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221276419","8e0152c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221276419").map(X),jb=pt(qb);var Vb=new Array(3).concat("998ec3f7f7f7f1a340","5e3c99b2abd2fdb863e66101","5e3c99b2abd2f7f7f7fdb863e66101","542788998ec3d8daebfee0b6f1a340b35806","542788998ec3d8daebf7f7f7fee0b6f1a340b35806","5427888073acb2abd2d8daebfee0b6fdb863e08214b35806","5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b35806","2d004b5427888073acb2abd2d8daebfee0b6fdb863e08214b358067f3b08","2d004b5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b358067f3b08").map(X),Yb=pt(Vb);var _m=new Array(3).concat("ef8a62f7f7f767a9cf","ca0020f4a58292c5de0571b0","ca0020f4a582f7f7f792c5de0571b0","b2182bef8a62fddbc7d1e5f067a9cf2166ac","b2182bef8a62fddbc7f7f7f7d1e5f067a9cf2166ac","b2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac","b2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac","67001fb2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac053061","67001fb2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac053061").map(X),uf=pt(_m);var Xb=new Array(3).concat("ef8a62ffffff999999","ca0020f4a582bababa404040","ca0020f4a582ffffffbababa404040","b2182bef8a62fddbc7e0e0e09999994d4d4d","b2182bef8a62fddbc7ffffffe0e0e09999994d4d4d","b2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d","b2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d","67001fb2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d1a1a1a","67001fb2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d1a1a1a").map(X),Gb=pt(Xb);var Sm=new Array(3).concat("fc8d59ffffbf91bfdb","d7191cfdae61abd9e92c7bb6","d7191cfdae61ffffbfabd9e92c7bb6","d73027fc8d59fee090e0f3f891bfdb4575b4","d73027fc8d59fee090ffffbfe0f3f891bfdb4575b4","d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4","d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4","a50026d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4313695","a50026d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4313695").map(X),ff=pt(Sm);var Wb=new Array(3).concat("fc8d59ffffbf91cf60","d7191cfdae61a6d96a1a9641","d7191cfdae61ffffbfa6d96a1a9641","d73027fc8d59fee08bd9ef8b91cf601a9850","d73027fc8d59fee08bffffbfd9ef8b91cf601a9850","d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850","d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850","a50026d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850006837","a50026d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850006837").map(X),Hb=pt(Wb);var Zb=new Array(3).concat("fc8d59ffffbf99d594","d7191cfdae61abdda42b83ba","d7191cfdae61ffffbfabdda42b83ba","d53e4ffc8d59fee08be6f59899d5943288bd","d53e4ffc8d59fee08bffffbfe6f59899d5943288bd","d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd","d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd","9e0142d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd5e4fa2","9e0142d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd5e4fa2").map(X),Jb=pt(Zb);var Qb=new Array(3).concat("e5f5f999d8c92ca25f","edf8fbb2e2e266c2a4238b45","edf8fbb2e2e266c2a42ca25f006d2c","edf8fbccece699d8c966c2a42ca25f006d2c","edf8fbccece699d8c966c2a441ae76238b45005824","f7fcfde5f5f9ccece699d8c966c2a441ae76238b45005824","f7fcfde5f5f9ccece699d8c966c2a441ae76238b45006d2c00441b").map(X),Kb=pt(Qb);var t1=new Array(3).concat("e0ecf49ebcda8856a7","edf8fbb3cde38c96c688419d","edf8fbb3cde38c96c68856a7810f7c","edf8fbbfd3e69ebcda8c96c68856a7810f7c","edf8fbbfd3e69ebcda8c96c68c6bb188419d6e016b","f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d6e016b","f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d810f7c4d004b").map(X),e1=pt(t1);var n1=new Array(3).concat("e0f3dba8ddb543a2ca","f0f9e8bae4bc7bccc42b8cbe","f0f9e8bae4bc7bccc443a2ca0868ac","f0f9e8ccebc5a8ddb57bccc443a2ca0868ac","f0f9e8ccebc5a8ddb57bccc44eb3d32b8cbe08589e","f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe08589e","f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe0868ac084081").map(X),r1=pt(n1);var i1=new Array(3).concat("fee8c8fdbb84e34a33","fef0d9fdcc8afc8d59d7301f","fef0d9fdcc8afc8d59e34a33b30000","fef0d9fdd49efdbb84fc8d59e34a33b30000","fef0d9fdd49efdbb84fc8d59ef6548d7301f990000","fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301f990000","fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301fb300007f0000").map(X),o1=pt(i1);var s1=new Array(3).concat("ece2f0a6bddb1c9099","f6eff7bdc9e167a9cf02818a","f6eff7bdc9e167a9cf1c9099016c59","f6eff7d0d1e6a6bddb67a9cf1c9099016c59","f6eff7d0d1e6a6bddb67a9cf3690c002818a016450","fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016450","fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016c59014636").map(X),a1=pt(s1);var c1=new Array(3).concat("ece7f2a6bddb2b8cbe","f1eef6bdc9e174a9cf0570b0","f1eef6bdc9e174a9cf2b8cbe045a8d","f1eef6d0d1e6a6bddb74a9cf2b8cbe045a8d","f1eef6d0d1e6a6bddb74a9cf3690c00570b0034e7b","fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0034e7b","fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0045a8d023858").map(X),l1=pt(c1);var u1=new Array(3).concat("e7e1efc994c7dd1c77","f1eef6d7b5d8df65b0ce1256","f1eef6d7b5d8df65b0dd1c77980043","f1eef6d4b9dac994c7df65b0dd1c77980043","f1eef6d4b9dac994c7df65b0e7298ace125691003f","f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125691003f","f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125698004367001f").map(X),f1=pt(u1);var h1=new Array(3).concat("fde0ddfa9fb5c51b8a","feebe2fbb4b9f768a1ae017e","feebe2fbb4b9f768a1c51b8a7a0177","feebe2fcc5c0fa9fb5f768a1c51b8a7a0177","feebe2fcc5c0fa9fb5f768a1dd3497ae017e7a0177","fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a0177","fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a017749006a").map(X),d1=pt(h1);var p1=new Array(3).concat("edf8b17fcdbb2c7fb8","ffffcca1dab441b6c4225ea8","ffffcca1dab441b6c42c7fb8253494","ffffccc7e9b47fcdbb41b6c42c7fb8253494","ffffccc7e9b47fcdbb41b6c41d91c0225ea80c2c84","ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea80c2c84","ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea8253494081d58").map(X),m1=pt(p1);var y1=new Array(3).concat("f7fcb9addd8e31a354","ffffccc2e69978c679238443","ffffccc2e69978c67931a354006837","ffffccd9f0a3addd8e78c67931a354006837","ffffccd9f0a3addd8e78c67941ab5d238443005a32","ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443005a32","ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443006837004529").map(X),g1=pt(y1);var x1=new Array(3).concat("fff7bcfec44fd95f0e","ffffd4fed98efe9929cc4c02","ffffd4fed98efe9929d95f0e993404","ffffd4fee391fec44ffe9929d95f0e993404","ffffd4fee391fec44ffe9929ec7014cc4c028c2d04","ffffe5fff7bcfee391fec44ffe9929ec7014cc4c028c2d04","ffffe5fff7bcfee391fec44ffe9929ec7014cc4c02993404662506").map(X),b1=pt(x1);var w1=new Array(3).concat("ffeda0feb24cf03b20","ffffb2fecc5cfd8d3ce31a1c","ffffb2fecc5cfd8d3cf03b20bd0026","ffffb2fed976feb24cfd8d3cf03b20bd0026","ffffb2fed976feb24cfd8d3cfc4e2ae31a1cb10026","ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cb10026","ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cbd0026800026").map(X),v1=pt(w1);var _1=new Array(3).concat("deebf79ecae13182bd","eff3ffbdd7e76baed62171b5","eff3ffbdd7e76baed63182bd08519c","eff3ffc6dbef9ecae16baed63182bd08519c","eff3ffc6dbef9ecae16baed64292c62171b5084594","f7fbffdeebf7c6dbef9ecae16baed64292c62171b5084594","f7fbffdeebf7c6dbef9ecae16baed64292c62171b508519c08306b").map(X),S1=pt(_1);var I1=new Array(3).concat("e5f5e0a1d99b31a354","edf8e9bae4b374c476238b45","edf8e9bae4b374c47631a354006d2c","edf8e9c7e9c0a1d99b74c47631a354006d2c","edf8e9c7e9c0a1d99b74c47641ab5d238b45005a32","f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45005a32","f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45006d2c00441b").map(X),M1=pt(I1);var A1=new Array(3).concat("f0f0f0bdbdbd636363","f7f7f7cccccc969696525252","f7f7f7cccccc969696636363252525","f7f7f7d9d9d9bdbdbd969696636363252525","f7f7f7d9d9d9bdbdbd969696737373525252252525","fffffff0f0f0d9d9d9bdbdbd969696737373525252252525","fffffff0f0f0d9d9d9bdbdbd969696737373525252252525000000").map(X),T1=pt(A1);var E1=new Array(3).concat("efedf5bcbddc756bb1","f2f0f7cbc9e29e9ac86a51a3","f2f0f7cbc9e29e9ac8756bb154278f","f2f0f7dadaebbcbddc9e9ac8756bb154278f","f2f0f7dadaebbcbddc9e9ac8807dba6a51a34a1486","fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a34a1486","fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a354278f3f007d").map(X),N1=pt(E1);var D1=new Array(3).concat("fee0d2fc9272de2d26","fee5d9fcae91fb6a4acb181d","fee5d9fcae91fb6a4ade2d26a50f15","fee5d9fcbba1fc9272fb6a4ade2d26a50f15","fee5d9fcbba1fc9272fb6a4aef3b2ccb181d99000d","fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181d99000d","fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181da50f1567000d").map(X),O1=pt(D1);var B1=new Array(3).concat("fee6cefdae6be6550d","feeddefdbe85fd8d3cd94701","feeddefdbe85fd8d3ce6550da63603","feeddefdd0a2fdae6bfd8d3ce6550da63603","feeddefdd0a2fdae6bfd8d3cf16913d948018c2d04","fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d948018c2d04","fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d94801a636037f2704").map(X),L1=pt(B1);function C1(e){return e=Math.max(0,Math.min(1,e)),"rgb("+Math.max(0,Math.min(255,Math.round(-4.54-e*(35.34-e*(2381.73-e*(6402.7-e*(7024.72-e*2710.57)))))))+", "+Math.max(0,Math.min(255,Math.round(32.49+e*(170.73+e*(52.82-e*(131.46-e*(176.58-e*67.37)))))))+", "+Math.max(0,Math.min(255,Math.round(81.24+e*(442.36-e*(2482.43-e*(6167.24-e*(6614.94-e*2475.67)))))))+")"}var k1=$u(tr(300,.5,0),tr(-240,.5,1));var R1=$u(tr(-100,.75,.35),tr(80,1.5,.8)),$1=$u(tr(260,.75,.35),tr(80,1.5,.8)),F1=tr();function P1(e){(e<0||e>1)&&(e-=Math.floor(e));var t=Math.abs(e-.5);return F1.h=360*e-100,F1.s=1.5-1.5*t,F1.l=.8-.9*t,F1+""}var U1=rn(),eJ=Math.PI/3,nJ=Math.PI*2/3;function z1(e){var t;return e=(.5-e)*Math.PI,U1.r=255*(t=Math.sin(e))*t,U1.g=255*(t=Math.sin(e+eJ))*t,U1.b=255*(t=Math.sin(e+nJ))*t,U1+""}function q1(e){return e=Math.max(0,Math.min(1,e)),"rgb("+Math.max(0,Math.min(255,Math.round(34.61+e*(1172.33-e*(10793.56-e*(33300.12-e*(38394.49-e*14825.05)))))))+", "+Math.max(0,Math.min(255,Math.round(23.31+e*(557.33+e*(1225.33-e*(3574.96-e*(1073.77+e*707.56)))))))+", "+Math.max(0,Math.min(255,Math.round(27.2+e*(3211.1-e*(15327.97-e*(27814-e*(22569.18-e*6838.66)))))))+")"}function j1(e){var t=e.length;return function(n){return e[Math.max(0,Math.min(t-1,Math.floor(n*t)))]}}var V1=j1(X("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725")),Y1=j1(X("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf")),X1=j1(X("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4")),G1=j1(X("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"));function Qe(e){return function(){return e}}var pA=Math.cos;var hf=Math.min,Im=Math.sin,ne=Math.sqrt,mA=1e-12,wl=Math.PI,WNt=wl/2,df=2*wl;function W1(e){let t=3;return e.digits=function(n){if(!arguments.length)return t;if(n==null)t=null;else{let r=Math.floor(n);if(!(r>=0))throw new RangeError(`invalid digits: ${n}`);t=r}return e},()=>new Ca(t)}var QNt=Array.prototype.slice;function H1(e){return typeof e=="object"&&"length"in e?e:Array.from(e)}function IF(e){this._context=e}IF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;default:this._context.lineTo(e,t);break}}};function Ys(e){return new IF(e)}function Z1(e){return e[0]}function J1(e){return e[1]}function Mm(e,t){var n=Qe(!0),r=null,i=Ys,o=null,s=W1(a);e=typeof e=="function"?e:e===void 0?Z1:Qe(e),t=typeof t=="function"?t:t===void 0?J1:Qe(t);function a(c){var l,u=(c=H1(c)).length,f,h=!1,d;for(r==null&&(o=i(d=s())),l=0;l<=u;++l)!(l<u&&n(f=c[l],l,c))===h&&((h=!h)?o.lineStart():o.lineEnd()),h&&o.point(+e(f,l,c),+t(f,l,c));if(d)return o=null,d+""||null}return a.x=function(c){return arguments.length?(e=typeof c=="function"?c:Qe(+c),a):e},a.y=function(c){return arguments.length?(t=typeof c=="function"?c:Qe(+c),a):t},a.defined=function(c){return arguments.length?(n=typeof c=="function"?c:Qe(!!c),a):n},a.curve=function(c){return arguments.length?(i=c,r!=null&&(o=i(r)),a):i},a.context=function(c){return arguments.length?(c==null?r=o=null:o=i(r=c),a):r},a}function pf(e,t,n){var r=null,i=Qe(!0),o=null,s=Ys,a=null,c=W1(l);e=typeof e=="function"?e:e===void 0?Z1:Qe(+e),t=typeof t=="function"?t:t===void 0?Qe(0):Qe(+t),n=typeof n=="function"?n:n===void 0?J1:Qe(+n);function l(f){var h,d,p,m=(f=H1(f)).length,y,g=!1,x,b=new Array(m),w=new Array(m);for(o==null&&(a=s(x=c())),h=0;h<=m;++h){if(!(h<m&&i(y=f[h],h,f))===g)if(g=!g)d=h,a.areaStart(),a.lineStart();else{for(a.lineEnd(),a.lineStart(),p=h-1;p>=d;--p)a.point(b[p],w[p]);a.lineEnd(),a.areaEnd()}g&&(b[h]=+e(y,h,f),w[h]=+t(y,h,f),a.point(r?+r(y,h,f):b[h],n?+n(y,h,f):w[h]))}if(x)return a=null,x+""||null}function u(){return Mm().defined(i).curve(s).context(o)}return l.x=function(f){return arguments.length?(e=typeof f=="function"?f:Qe(+f),r=null,l):e},l.x0=function(f){return arguments.length?(e=typeof f=="function"?f:Qe(+f),l):e},l.x1=function(f){return arguments.length?(r=f==null?null:typeof f=="function"?f:Qe(+f),l):r},l.y=function(f){return arguments.length?(t=typeof f=="function"?f:Qe(+f),n=null,l):t},l.y0=function(f){return arguments.length?(t=typeof f=="function"?f:Qe(+f),l):t},l.y1=function(f){return arguments.length?(n=f==null?null:typeof f=="function"?f:Qe(+f),l):n},l.lineX0=l.lineY0=function(){return u().x(e).y(t)},l.lineY1=function(){return u().x(e).y(n)},l.lineX1=function(){return u().x(r).y(t)},l.defined=function(f){return arguments.length?(i=typeof f=="function"?f:Qe(!!f),l):i},l.curve=function(f){return arguments.length?(s=f,o!=null&&(a=s(o)),l):s},l.context=function(f){return arguments.length?(f==null?o=a=null:a=s(o=f),l):o},l}var Q1=class{constructor(t,n){this._context=t,this._x=n}areaStart(){this._line=0}areaEnd(){this._line=NaN}lineStart(){this._point=0}lineEnd(){(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line}point(t,n){switch(t=+t,n=+n,this._point){case 0:{this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break}case 1:this._point=2;default:{this._x?this._context.bezierCurveTo(this._x0=(this._x0+t)/2,this._y0,this._x0,n,t,n):this._context.bezierCurveTo(this._x0,this._y0=(this._y0+n)/2,t,this._y0,t,n);break}}this._x0=t,this._y0=n}};function yA(e){return new Q1(e,!0)}function gA(e){return new Q1(e,!1)}var rJ=ne(3),Am={draw(e,t){let n=ne(t+hf(t/28,.75))*.59436,r=n/2,i=r*rJ;e.moveTo(0,n),e.lineTo(0,-n),e.moveTo(-i,-r),e.lineTo(i,r),e.moveTo(-i,r),e.lineTo(i,-r)}};var Xs={draw(e,t){let n=ne(t/wl);e.moveTo(n,0),e.arc(0,0,n,0,df)}};var Tm={draw(e,t){let n=ne(t/5)/2;e.moveTo(-3*n,-n),e.lineTo(-n,-n),e.lineTo(-n,-3*n),e.lineTo(n,-3*n),e.lineTo(n,-n),e.lineTo(3*n,-n),e.lineTo(3*n,n),e.lineTo(n,n),e.lineTo(n,3*n),e.lineTo(-n,3*n),e.lineTo(-n,n),e.lineTo(-3*n,n),e.closePath()}};var MF=ne(1/3),iJ=MF*2,Em={draw(e,t){let n=ne(t/iJ),r=n*MF;e.moveTo(0,-n),e.lineTo(r,0),e.lineTo(0,n),e.lineTo(-r,0),e.closePath()}};var Nm={draw(e,t){let n=ne(t)*.62625;e.moveTo(0,-n),e.lineTo(n,0),e.lineTo(0,n),e.lineTo(-n,0),e.closePath()}};var Dm={draw(e,t){let n=ne(t-hf(t/7,2))*.87559;e.moveTo(-n,0),e.lineTo(n,0),e.moveTo(0,n),e.lineTo(0,-n)}};var Om={draw(e,t){let n=ne(t),r=-n/2;e.rect(r,r,n,n)}};var Bm={draw(e,t){let n=ne(t)*.4431;e.moveTo(n,n),e.lineTo(n,-n),e.lineTo(-n,-n),e.lineTo(-n,n),e.closePath()}};var oJ=.8908130915292852,AF=Im(wl/10)/Im(7*wl/10),sJ=Im(df/10)*AF,aJ=-pA(df/10)*AF,Lm={draw(e,t){let n=ne(t*oJ),r=sJ*n,i=aJ*n;e.moveTo(0,-n),e.lineTo(r,i);for(let o=1;o<5;++o){let s=df*o/5,a=pA(s),c=Im(s);e.lineTo(c*n,-a*n),e.lineTo(a*r-c*i,c*r+a*i)}e.closePath()}};var xA=ne(3),Cm={draw(e,t){let n=-ne(t/(xA*3));e.moveTo(0,n*2),e.lineTo(-xA*n,-n),e.lineTo(xA*n,-n),e.closePath()}};var cJ=ne(3),km={draw(e,t){let n=ne(t)*.6824,r=n/2,i=n*cJ/2;e.moveTo(0,-n),e.lineTo(i,r),e.lineTo(-i,r),e.closePath()}};var gi=-.5,xi=ne(3)/2,bA=1/ne(12),lJ=(bA/2+1)*3,Fm={draw(e,t){let n=ne(t/lJ),r=n/2,i=n*bA,o=r,s=n*bA+n,a=-o,c=s;e.moveTo(r,i),e.lineTo(o,s),e.lineTo(a,c),e.lineTo(gi*r-xi*i,xi*r+gi*i),e.lineTo(gi*o-xi*s,xi*o+gi*s),e.lineTo(gi*a-xi*c,xi*a+gi*c),e.lineTo(gi*r+xi*i,gi*i-xi*r),e.lineTo(gi*o+xi*s,gi*s-xi*o),e.lineTo(gi*a+xi*c,gi*c-xi*a),e.closePath()}};var mf={draw(e,t){let n=ne(t-hf(t/6,1.7))*.6189;e.moveTo(-n,-n),e.lineTo(n,n),e.moveTo(-n,n),e.lineTo(n,-n)}};var K1=[Xs,Tm,Em,Om,Lm,Cm,Fm],wA=[Xs,Dm,mf,km,Am,Bm,Nm];function bi(){}function yf(e,t,n){e._context.bezierCurveTo((2*e._x0+e._x1)/3,(2*e._y0+e._y1)/3,(e._x0+2*e._x1)/3,(e._y0+2*e._y1)/3,(e._x0+4*e._x1+t)/6,(e._y0+4*e._y1+n)/6)}function Rm(e){this._context=e}Rm.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){switch(this._point){case 3:yf(this,this._x1,this._y1);case 2:this._context.lineTo(this._x1,this._y1);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;break;case 2:this._point=3,this._context.lineTo((5*this._x0+this._x1)/6,(5*this._y0+this._y1)/6);default:yf(this,e,t);break}this._x0=this._x1,this._x1=e,this._y0=this._y1,this._y1=t}};function vA(e){return new Rm(e)}function TF(e){this._context=e}TF.prototype={areaStart:bi,areaEnd:bi,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._y0=this._y1=this._y2=this._y3=this._y4=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x2,this._y2),this._context.closePath();break}case 2:{this._context.moveTo((this._x2+2*this._x3)/3,(this._y2+2*this._y3)/3),this._context.lineTo((this._x3+2*this._x2)/3,(this._y3+2*this._y2)/3),this._context.closePath();break}case 3:{this.point(this._x2,this._y2),this.point(this._x3,this._y3),this.point(this._x4,this._y4);break}}},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._x2=e,this._y2=t;break;case 1:this._point=2,this._x3=e,this._y3=t;break;case 2:this._point=3,this._x4=e,this._y4=t,this._context.moveTo((this._x0+4*this._x1+e)/6,(this._y0+4*this._y1+t)/6);break;default:yf(this,e,t);break}this._x0=this._x1,this._x1=e,this._y0=this._y1,this._y1=t}};function _A(e){return new TF(e)}function EF(e){this._context=e}EF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3;var n=(this._x0+4*this._x1+e)/6,r=(this._y0+4*this._y1+t)/6;this._line?this._context.lineTo(n,r):this._context.moveTo(n,r);break;case 3:this._point=4;default:yf(this,e,t);break}this._x0=this._x1,this._x1=e,this._y0=this._y1,this._y1=t}};function SA(e){return new EF(e)}function NF(e,t){this._basis=new Rm(e),this._beta=t}NF.prototype={lineStart:function(){this._x=[],this._y=[],this._basis.lineStart()},lineEnd:function(){var e=this._x,t=this._y,n=e.length-1;if(n>0)for(var r=e[0],i=t[0],o=e[n]-r,s=t[n]-i,a=-1,c;++a<=n;)c=a/n,this._basis.point(this._beta*e[a]+(1-this._beta)*(r+c*o),this._beta*t[a]+(1-this._beta)*(i+c*s));this._x=this._y=null,this._basis.lineEnd()},point:function(e,t){this._x.push(+e),this._y.push(+t)}};var IA=function e(t){function n(r){return t===1?new Rm(r):new NF(r,t)}return n.beta=function(r){return e(+r)},n}(.85);function gf(e,t,n){e._context.bezierCurveTo(e._x1+e._k*(e._x2-e._x0),e._y1+e._k*(e._y2-e._y0),e._x2+e._k*(e._x1-t),e._y2+e._k*(e._y1-n),e._x2,e._y2)}function tw(e,t){this._context=e,this._k=(1-t)/6}tw.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:gf(this,this._x1,this._y1);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2,this._x1=e,this._y1=t;break;case 2:this._point=3;default:gf(this,e,t);break}this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var MA=function e(t){function n(r){return new tw(r,t)}return n.tension=function(r){return e(+r)},n}(0);function ew(e,t){this._context=e,this._k=(1-t)/6}ew.prototype={areaStart:bi,areaEnd:bi,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x3,this._y3),this._context.closePath();break}case 2:{this._context.lineTo(this._x3,this._y3),this._context.closePath();break}case 3:{this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5);break}}},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._x3=e,this._y3=t;break;case 1:this._point=2,this._context.moveTo(this._x4=e,this._y4=t);break;case 2:this._point=3,this._x5=e,this._y5=t;break;default:gf(this,e,t);break}this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var AA=function e(t){function n(r){return new ew(r,t)}return n.tension=function(r){return e(+r)},n}(0);function nw(e,t){this._context=e,this._k=(1-t)/6}nw.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:gf(this,e,t);break}this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var TA=function e(t){function n(r){return new nw(r,t)}return n.tension=function(r){return e(+r)},n}(0);function $m(e,t,n){var r=e._x1,i=e._y1,o=e._x2,s=e._y2;if(e._l01_a>mA){var a=2*e._l01_2a+3*e._l01_a*e._l12_a+e._l12_2a,c=3*e._l01_a*(e._l01_a+e._l12_a);r=(r*a-e._x0*e._l12_2a+e._x2*e._l01_2a)/c,i=(i*a-e._y0*e._l12_2a+e._y2*e._l01_2a)/c}if(e._l23_a>mA){var l=2*e._l23_2a+3*e._l23_a*e._l12_a+e._l12_2a,u=3*e._l23_a*(e._l23_a+e._l12_a);o=(o*l+e._x1*e._l23_2a-t*e._l12_2a)/u,s=(s*l+e._y1*e._l23_2a-n*e._l12_2a)/u}e._context.bezierCurveTo(r,i,o,s,e._x2,e._y2)}function DF(e,t){this._context=e,this._alpha=t}DF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:this.point(this._x2,this._y2);break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){if(e=+e,t=+t,this._point){var n=this._x2-e,r=this._y2-t;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(n*n+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;break;case 2:this._point=3;default:$m(this,e,t);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var EA=function e(t){function n(r){return t?new DF(r,t):new tw(r,0)}return n.alpha=function(r){return e(+r)},n}(.5);function OF(e,t){this._context=e,this._alpha=t}OF.prototype={areaStart:bi,areaEnd:bi,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 1:{this._context.moveTo(this._x3,this._y3),this._context.closePath();break}case 2:{this._context.lineTo(this._x3,this._y3),this._context.closePath();break}case 3:{this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5);break}}},point:function(e,t){if(e=+e,t=+t,this._point){var n=this._x2-e,r=this._y2-t;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(n*n+r*r,this._alpha))}switch(this._point){case 0:this._point=1,this._x3=e,this._y3=t;break;case 1:this._point=2,this._context.moveTo(this._x4=e,this._y4=t);break;case 2:this._point=3,this._x5=e,this._y5=t;break;default:$m(this,e,t);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var NA=function e(t){function n(r){return t?new OF(r,t):new ew(r,0)}return n.alpha=function(r){return e(+r)},n}(.5);function BF(e,t){this._context=e,this._alpha=t}BF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){(this._line||this._line!==0&&this._point===3)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){if(e=+e,t=+t,this._point){var n=this._x2-e,r=this._y2-t;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(n*n+r*r,this._alpha))}switch(this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:$m(this,e,t);break}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=e,this._y0=this._y1,this._y1=this._y2,this._y2=t}};var DA=function e(t){function n(r){return t?new BF(r,t):new nw(r,0)}return n.alpha=function(r){return e(+r)},n}(.5);function LF(e){this._context=e}LF.prototype={areaStart:bi,areaEnd:bi,lineStart:function(){this._point=0},lineEnd:function(){this._point&&this._context.closePath()},point:function(e,t){e=+e,t=+t,this._point?this._context.lineTo(e,t):(this._point=1,this._context.moveTo(e,t))}};function OA(e){return new LF(e)}function CF(e){return e<0?-1:1}function kF(e,t,n){var r=e._x1-e._x0,i=t-e._x1,o=(e._y1-e._y0)/(r||i<0&&-0),s=(n-e._y1)/(i||r<0&&-0),a=(o*i+s*r)/(r+i);return(CF(o)+CF(s))*Math.min(Math.abs(o),Math.abs(s),.5*Math.abs(a))||0}function FF(e,t){var n=e._x1-e._x0;return n?(3*(e._y1-e._y0)/n-t)/2:t}function BA(e,t,n){var r=e._x0,i=e._y0,o=e._x1,s=e._y1,a=(o-r)/3;e._context.bezierCurveTo(r+a,i+a*t,o-a,s-a*n,o,s)}function rw(e){this._context=e}rw.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=this._t0=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x1,this._y1);break;case 3:BA(this,this._t0,FF(this,this._t0));break}(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line=1-this._line},point:function(e,t){var n=NaN;if(e=+e,t=+t,!(e===this._x1&&t===this._y1)){switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;break;case 2:this._point=3,BA(this,FF(this,n=kF(this,e,t)),n);break;default:BA(this,this._t0,n=kF(this,e,t));break}this._x0=this._x1,this._x1=e,this._y0=this._y1,this._y1=t,this._t0=n}}};function RF(e){this._context=new $F(e)}(RF.prototype=Object.create(rw.prototype)).point=function(e,t){rw.prototype.point.call(this,t,e)};function $F(e){this._context=e}$F.prototype={moveTo:function(e,t){this._context.moveTo(t,e)},closePath:function(){this._context.closePath()},lineTo:function(e,t){this._context.lineTo(t,e)},bezierCurveTo:function(e,t,n,r,i,o){this._context.bezierCurveTo(t,e,r,n,o,i)}};function LA(e){return new rw(e)}function CA(e){return new RF(e)}function UF(e){this._context=e}UF.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=[],this._y=[]},lineEnd:function(){var e=this._x,t=this._y,n=e.length;if(n)if(this._line?this._context.lineTo(e[0],t[0]):this._context.moveTo(e[0],t[0]),n===2)this._context.lineTo(e[1],t[1]);else for(var r=PF(e),i=PF(t),o=0,s=1;s<n;++o,++s)this._context.bezierCurveTo(r[0][o],i[0][o],r[1][o],i[1][o],e[s],t[s]);(this._line||this._line!==0&&n===1)&&this._context.closePath(),this._line=1-this._line,this._x=this._y=null},point:function(e,t){this._x.push(+e),this._y.push(+t)}};function PF(e){var t,n=e.length-1,r,i=new Array(n),o=new Array(n),s=new Array(n);for(i[0]=0,o[0]=2,s[0]=e[0]+2*e[1],t=1;t<n-1;++t)i[t]=1,o[t]=4,s[t]=4*e[t]+2*e[t+1];for(i[n-1]=2,o[n-1]=7,s[n-1]=8*e[n-1]+e[n],t=1;t<n;++t)r=i[t]/o[t-1],o[t]-=r,s[t]-=r*s[t-1];for(i[n-1]=s[n-1]/o[n-1],t=n-2;t>=0;--t)i[t]=(s[t]-i[t+1])/o[t];for(o[n-1]=(e[n]+i[n-1])/2,t=0;t<n-1;++t)o[t]=2*e[t+1]-i[t+1];return[i,o]}function kA(e){return new UF(e)}function iw(e,t){this._context=e,this._t=t}iw.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x=this._y=NaN,this._point=0},lineEnd:function(){0<this._t&&this._t<1&&this._point===2&&this._context.lineTo(this._x,this._y),(this._line||this._line!==0&&this._point===1)&&this._context.closePath(),this._line>=0&&(this._t=1-this._t,this._line=1-this._line)},point:function(e,t){switch(e=+e,t=+t,this._point){case 0:this._point=1,this._line?this._context.lineTo(e,t):this._context.moveTo(e,t);break;case 1:this._point=2;default:{if(this._t<=0)this._context.lineTo(this._x,t),this._context.lineTo(e,t);else{var n=this._x*(1-this._t)+e*this._t;this._context.lineTo(n,this._y),this._context.lineTo(n,t)}break}}this._x=e,this._y=t}};function FA(e){return new iw(e,.5)}function RA(e){return new iw(e,0)}function $A(e){return new iw(e,1)}var Pm=e=>()=>e;function PA(e,{sourceEvent:t,target:n,transform:r,dispatch:i}){Object.defineProperties(this,{type:{value:e,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},transform:{value:r,enumerable:!0,configurable:!0},_:{value:i}})}function qr(e,t,n){this.k=e,this.x=t,this.y=n}qr.prototype={constructor:qr,scale:function(e){return e===1?this:new qr(this.k*e,this.x,this.y)},translate:function(e,t){return e===0&t===0?this:new qr(this.k,this.x+this.k*e,this.y+this.k*t)},apply:function(e){return[e[0]*this.k+this.x,e[1]*this.k+this.y]},applyX:function(e){return e*this.k+this.x},applyY:function(e){return e*this.k+this.y},invert:function(e){return[(e[0]-this.x)/this.k,(e[1]-this.y)/this.k]},invertX:function(e){return(e-this.x)/this.k},invertY:function(e){return(e-this.y)/this.k},rescaleX:function(e){return e.copy().domain(e.range().map(this.invertX,this).map(e.invert,e))},rescaleY:function(e){return e.copy().domain(e.range().map(this.invertY,this).map(e.invert,e))},toString:function(){return"translate("+this.x+","+this.y+") scale("+this.k+")"}};var Um=new qr(1,0,0);UA.prototype=qr.prototype;function UA(e){for(;!e.__zoom;)if(!(e=e.parentNode))return Um;return e.__zoom}function ow(e){e.stopImmediatePropagation()}function xf(e){e.preventDefault(),e.stopImmediatePropagation()}function uJ(e){return(!e.ctrlKey||e.type==="wheel")&&!e.button}function fJ(){var e=this;return e instanceof SVGElement?(e=e.ownerSVGElement||e,e.hasAttribute("viewBox")?(e=e.viewBox.baseVal,[[e.x,e.y],[e.x+e.width,e.y+e.height]]):[[0,0],[e.width.baseVal.value,e.height.baseVal.value]]):[[0,0],[e.clientWidth,e.clientHeight]]}function zF(){return this.__zoom||Um}function hJ(e){return-e.deltaY*(e.deltaMode===1?.05:e.deltaMode?1:.002)*(e.ctrlKey?10:1)}function dJ(){return navigator.maxTouchPoints||"ontouchstart"in this}function pJ(e,t,n){var r=e.invertX(t[0][0])-n[0][0],i=e.invertX(t[1][0])-n[1][0],o=e.invertY(t[0][1])-n[0][1],s=e.invertY(t[1][1])-n[1][1];return e.translate(i>r?(r+i)/2:Math.min(0,r)||Math.max(0,i),s>o?(o+s)/2:Math.min(0,o)||Math.max(0,s))}function zA(){var e=uJ,t=fJ,n=pJ,r=hJ,i=dJ,o=[0,1/0],s=[[-1/0,-1/0],[1/0,1/0]],a=250,c=pI,l=Wc("start","zoom","end"),u,f,h,d=500,p=150,m=0,y=10;function g(S){S.property("__zoom",zF).on("wheel.zoom",E,{passive:!1}).on("mousedown.zoom",I).on("dblclick.zoom",D).filter(i).on("touchstart.zoom",A).on("touchmove.zoom",O).on("touchend.zoom touchcancel.zoom",C).style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}g.transform=function(S,T,N,F){var R=S.selection?S.selection():S;R.property("__zoom",zF),S!==R?_(S,T,N,F):R.interrupt().each(function(){v(this,arguments).event(F).start().zoom(null,typeof T=="function"?T.apply(this,arguments):T).end()})},g.scaleBy=function(S,T,N,F){g.scaleTo(S,function(){var R=this.__zoom.k,k=typeof T=="function"?T.apply(this,arguments):T;return R*k},N,F)},g.scaleTo=function(S,T,N,F){g.transform(S,function(){var R=t.apply(this,arguments),k=this.__zoom,$=N==null?w(R):typeof N=="function"?N.apply(this,arguments):N,P=k.invert($),U=typeof T=="function"?T.apply(this,arguments):T;return n(b(x(k,U),$,P),R,s)},N,F)},g.translateBy=function(S,T,N,F){g.transform(S,function(){return n(this.__zoom.translate(typeof T=="function"?T.apply(this,arguments):T,typeof N=="function"?N.apply(this,arguments):N),t.apply(this,arguments),s)},null,F)},g.translateTo=function(S,T,N,F,R){g.transform(S,function(){var k=t.apply(this,arguments),$=this.__zoom,P=F==null?w(k):typeof F=="function"?F.apply(this,arguments):F;return n(Um.translate(P[0],P[1]).scale($.k).translate(typeof T=="function"?-T.apply(this,arguments):-T,typeof N=="function"?-N.apply(this,arguments):-N),k,s)},F,R)};function x(S,T){return T=Math.max(o[0],Math.min(o[1],T)),T===S.k?S:new qr(T,S.x,S.y)}function b(S,T,N){var F=T[0]-N[0]*S.k,R=T[1]-N[1]*S.k;return F===S.x&&R===S.y?S:new qr(S.k,F,R)}function w(S){return[(+S[0][0]+ +S[1][0])/2,(+S[0][1]+ +S[1][1])/2]}function _(S,T,N,F){S.on("start.zoom",function(){v(this,arguments).event(F).start()}).on("interrupt.zoom end.zoom",function(){v(this,arguments).event(F).end()}).tween("zoom",function(){var R=this,k=arguments,$=v(R,k).event(F),P=t.apply(R,k),U=N==null?w(P):typeof N=="function"?N.apply(R,k):N,W=Math.max(P[1][0]-P[0][0],P[1][1]-P[0][1]),nt=R.__zoom,ot=typeof T=="function"?T.apply(R,k):T,at=c(nt.invert(U).concat(W/nt.k),ot.invert(U).concat(W/ot.k));return function(Y){if(Y===1)Y=ot;else{var st=at(Y),j=W/st[2];Y=new qr(j,U[0]-st[0]*j,U[1]-st[1]*j)}$.zoom(null,Y)}})}function v(S,T,N){return!N&&S.__zooming||new M(S,T)}function M(S,T){this.that=S,this.args=T,this.active=0,this.sourceEvent=null,this.extent=t.apply(S,T),this.taps=0}M.prototype={event:function(S){return S&&(this.sourceEvent=S),this},start:function(){return++this.active===1&&(this.that.__zooming=this,this.emit("start")),this},zoom:function(S,T){return this.mouse&&S!=="mouse"&&(this.mouse[1]=T.invert(this.mouse[0])),this.touch0&&S!=="touch"&&(this.touch0[1]=T.invert(this.touch0[0])),this.touch1&&S!=="touch"&&(this.touch1[1]=T.invert(this.touch1[0])),this.that.__zoom=T,this.emit("zoom"),this},end:function(){return--this.active===0&&(delete this.that.__zooming,this.emit("end")),this},emit:function(S){var T=Vt(this.that).datum();l.call(S,this.that,new PA(S,{sourceEvent:this.sourceEvent,target:g,type:S,transform:this.that.__zoom,dispatch:l}),T)}};function E(S,...T){if(!e.apply(this,arguments))return;var N=v(this,T).event(S),F=this.__zoom,R=Math.max(o[0],Math.min(o[1],F.k*Math.pow(2,r.apply(this,arguments)))),k=Fn(S);if(N.wheel)(N.mouse[0][0]!==k[0]||N.mouse[0][1]!==k[1])&&(N.mouse[1]=F.invert(N.mouse[0]=k)),clearTimeout(N.wheel);else{if(F.k===R)return;N.mouse=[k,F.invert(k)],To(this),N.start()}xf(S),N.wheel=setTimeout($,p),N.zoom("mouse",n(b(x(F,R),N.mouse[0],N.mouse[1]),N.extent,s));function $(){N.wheel=null,N.end()}}function I(S,...T){if(h||!e.apply(this,arguments))return;var N=S.currentTarget,F=v(this,T,!0).event(S),R=Vt(S.view).on("mousemove.zoom",U,!0).on("mouseup.zoom",W,!0),k=Fn(S,N),$=S.clientX,P=S.clientY;yp(S.view),ow(S),F.mouse=[k,this.__zoom.invert(k)],To(this),F.start();function U(nt){if(xf(nt),!F.moved){var ot=nt.clientX-$,at=nt.clientY-P;F.moved=ot*ot+at*at>m}F.event(nt).zoom("mouse",n(b(F.that.__zoom,F.mouse[0]=Fn(nt,N),F.mouse[1]),F.extent,s))}function W(nt){R.on("mousemove.zoom mouseup.zoom",null),gp(nt.view,F.moved),xf(nt),F.event(nt).end()}}function D(S,...T){if(e.apply(this,arguments)){var N=this.__zoom,F=Fn(S.changedTouches?S.changedTouches[0]:S,this),R=N.invert(F),k=N.k*(S.shiftKey?.5:2),$=n(b(x(N,k),F,R),t.apply(this,T),s);xf(S),a>0?Vt(this).transition().duration(a).call(_,$,F,S):Vt(this).call(g.transform,$,F,S)}}function A(S,...T){if(e.apply(this,arguments)){var N=S.touches,F=N.length,R=v(this,T,S.changedTouches.length===F).event(S),k,$,P,U;for(ow(S),$=0;$<F;++$)P=N[$],U=Fn(P,this),U=[U,this.__zoom.invert(U),P.identifier],R.touch0?!R.touch1&&R.touch0[2]!==U[2]&&(R.touch1=U,R.taps=0):(R.touch0=U,k=!0,R.taps=1+!!u);u&&(u=clearTimeout(u)),k&&(R.taps<2&&(f=U[0],u=setTimeout(function(){u=null},d)),To(this),R.start())}}function O(S,...T){if(this.__zooming){var N=v(this,T).event(S),F=S.changedTouches,R=F.length,k,$,P,U;for(xf(S),k=0;k<R;++k)$=F[k],P=Fn($,this),N.touch0&&N.touch0[2]===$.identifier?N.touch0[0]=P:N.touch1&&N.touch1[2]===$.identifier&&(N.touch1[0]=P);if($=N.that.__zoom,N.touch1){var W=N.touch0[0],nt=N.touch0[1],ot=N.touch1[0],at=N.touch1[1],Y=(Y=ot[0]-W[0])*Y+(Y=ot[1]-W[1])*Y,st=(st=at[0]-nt[0])*st+(st=at[1]-nt[1])*st;$=x($,Math.sqrt(Y/st)),P=[(W[0]+ot[0])/2,(W[1]+ot[1])/2],U=[(nt[0]+at[0])/2,(nt[1]+at[1])/2]}else if(N.touch0)P=N.touch0[0],U=N.touch0[1];else return;N.zoom("touch",n(b($,P,U),N.extent,s))}}function C(S,...T){if(this.__zooming){var N=v(this,T).event(S),F=S.changedTouches,R=F.length,k,$;for(ow(S),h&&clearTimeout(h),h=setTimeout(function(){h=null},d),k=0;k<R;++k)$=F[k],N.touch0&&N.touch0[2]===$.identifier?delete N.touch0:N.touch1&&N.touch1[2]===$.identifier&&delete N.touch1;if(N.touch1&&!N.touch0&&(N.touch0=N.touch1,delete N.touch1),N.touch0)N.touch0[1]=this.__zoom.invert(N.touch0[0]);else if(N.end(),N.taps===2&&($=Fn($,this),Math.hypot(f[0]-$[0],f[1]-$[1])<y)){var P=Vt(this).on("dblclick.zoom");P&&P.apply(this,arguments)}}}return g.wheelDelta=function(S){return arguments.length?(r=typeof S=="function"?S:Pm(+S),g):r},g.filter=function(S){return arguments.length?(e=typeof S=="function"?S:Pm(!!S),g):e},g.touchable=function(S){return arguments.length?(i=typeof S=="function"?S:Pm(!!S),g):i},g.extent=function(S){return arguments.length?(t=typeof S=="function"?S:Pm([[+S[0][0],+S[0][1]],[+S[1][0],+S[1][1]]]),g):t},g.scaleExtent=function(S){return arguments.length?(o[0]=+S[0],o[1]=+S[1],g):[o[0],o[1]]},g.translateExtent=function(S){return arguments.length?(s[0][0]=+S[0][0],s[1][0]=+S[1][0],s[0][1]=+S[0][1],s[1][1]=+S[1][1],g):[[s[0][0],s[0][1]],[s[1][0],s[1][1]]]},g.constrain=function(S){return arguments.length?(n=S,g):n},g.duration=function(S){return arguments.length?(a=+S,g):a},g.interpolate=function(S){return arguments.length?(c=S,g):c},g.on=function(){var S=l.on.apply(l,arguments);return S===l?g:S},g.clickDistance=function(S){return arguments.length?(m=(S=+S)*S,g):Math.sqrt(m)},g.tapDistance=function(S){return arguments.length?(y=+S,g):y},g}function ze(e){return e!=null&&!Number.isNaN(e)}function dn(e,t){return+ze(t)-+ze(e)||zt(e,t)}function vl(e,t){return+ze(t)-+ze(e)||Zn(e,t)}function zm(e){return e!=null&&`${e}`!=""}function bf(e){return isFinite(e)?e:NaN}function ar(e){return e>0&&isFinite(e)?e:NaN}function ja(e){return e<0&&isFinite(e)?e:NaN}function wf(e,t){if(e instanceof Date||(e=new Date(+e)),isNaN(e))return typeof t=="function"?t(e):t;let n=e.getUTCHours(),r=e.getUTCMinutes(),i=e.getUTCSeconds(),o=e.getUTCMilliseconds();return`${mJ(e.getUTCFullYear(),4)}-${Gs(e.getUTCMonth()+1,2)}-${Gs(e.getUTCDate(),2)}${n||r||i||o?`T${Gs(n,2)}:${Gs(r,2)}${i||o?`:${Gs(i,2)}${o?`.${Gs(o,3)}`:""}`:""}Z`:""}`}function mJ(e){return e<0?`-${Gs(-e,6)}`:e>9999?`+${Gs(e,6)}`:Gs(e,4)}function Gs(e,t){return`${e}`.padStart(t,"0")}var yJ=/^(?:[-+]\d{2})?\d{4}(?:-\d{2}(?:-\d{2})?)?(?:T\d{2}:\d{2}(?::\d{2}(?:\.\d{3})?)?(?:Z|[-+]\d{2}:?\d{2})?)?$/;function qm(e,t){return yJ.test(e+="")?new Date(e):typeof t=="function"?t(e):t}function Ws(e){if(e==null)return;let t=e[0],n=e[e.length-1];return Zn(t,n)}var _f=1e3,Ya=_f*60,Xa=Ya*60,zo=Xa*24,Uo=zo*7,_l=zo*30,Va=zo*365,qA=[["millisecond",1],["2 milliseconds",2],["5 milliseconds",5],["10 milliseconds",10],["20 milliseconds",20],["50 milliseconds",50],["100 milliseconds",100],["200 milliseconds",200],["500 milliseconds",500],["second",_f],["5 seconds",5*_f],["15 seconds",15*_f],["30 seconds",30*_f],["minute",Ya],["5 minutes",5*Ya],["15 minutes",15*Ya],["30 minutes",30*Ya],["hour",Xa],["3 hours",3*Xa],["6 hours",6*Xa],["12 hours",12*Xa],["day",zo],["2 days",2*zo],["week",Uo],["2 weeks",2*Uo],["month",_l],["3 months",3*_l],["6 months",6*_l],["year",Va],["2 years",2*Va],["5 years",5*Va],["10 years",10*Va],["20 years",20*Va],["50 years",50*Va],["100 years",100*Va]],jA=new Map([["second",_f],["minute",Ya],["hour",Xa],["day",zo],["monday",Uo],["tuesday",Uo],["wednesday",Uo],["thursday",Uo],["friday",Uo],["saturday",Uo],["sunday",Uo],["week",Uo],["month",_l],["year",Va]]),jF=new Map([["second",fn],["minute",Ps],["hour",zs],["day",yi],["monday",za],["tuesday",Sb],["wednesday",Ib],["thursday",Ro],["friday",Mb],["saturday",Ab],["sunday",Ur],["week",Ur],["month",js],["year",zn]]),VA=new Map([["second",fn],["minute",Us],["hour",qs],["day",gl],["monday",qa],["tuesday",Tb],["wednesday",Eb],["thursday",$o],["friday",Nb],["saturday",Db],["sunday",zr],["week",zr],["month",Vs],["year",qn]]),Sf=Symbol("intervalDuration"),aw=Symbol("intervalType");for(let[e,t]of jF)t[Sf]=jA.get(e),t[aw]="time";for(let[e,t]of VA)t[Sf]=jA.get(e),t[aw]="utc";var jm=[["year",qn,"utc"],["month",Vs,"utc"],["day",gl,"utc",6*_l],["hour",qs,"utc",3*zo],["minute",Us,"utc",6*Xa],["second",fn,"utc",30*Ya]],sw=[["year",zn,"time"],["month",js,"time"],["day",yi,"time",6*_l],["hour",zs,"time",3*zo],["minute",Ps,"time",6*Xa],["second",fn,"time",30*Ya]],gJ=[jm[0],sw[0],jm[1],sw[1],jm[2],sw[2],...jm.slice(3)];function cw(e){let t=`${e}`.toLowerCase();t.endsWith("s")&&(t=t.slice(0,-1));let n=1,r=/^(?:(\d+)\s+)/.exec(t);switch(r&&(t=t.slice(r[0].length),n=+r[1]),t){case"quarter":t="month",n*=3;break;case"half":t="month",n*=6;break}let i=VA.get(t);if(!i)throw new Error(`unknown interval: ${e}`);if(n>1&&!i.every)throw new Error(`non-periodic interval: ${t}`);return[t,n]}function YA(e){return VF(cw(e),"time")}function Vm(e){return VF(cw(e),"utc")}function VF([e,t],n){let r=(n==="time"?jF:VA).get(e);return t>1&&(r=r.every(t),r[Sf]=jA.get(e)*t,r[aw]=n),r}function XA(e,t){if(!(t>1))return;let n=e[Sf];if(!qA.some(([,i])=>i===n)||n%zo===0&&zo<n&&n<_l)return;let[r]=qA[Is(([,i])=>Math.log(i)).center(qA,Math.log(n*t))];return(e[aw]==="time"?YA:Vm)(r)}function qF(e,t,n){let r=t==="time"?lf:Po;if(n==null)return r(e==="year"?"%Y":e==="month"?"%Y-%m":e==="day"?"%Y-%m-%d":e==="hour"||e==="minute"?"%Y-%m-%dT%H:%M":e==="second"?"%Y-%m-%dT%H:%M:%S":"%Y-%m-%dT%H:%M:%S.%L");let i=xJ(n);switch(e){case"millisecond":return vf(r(".%L"),r(":%M:%S"),i);case"second":return vf(r(":%S"),r("%-I:%M"),i);case"minute":return vf(r("%-I:%M"),r("%p"),i);case"hour":return vf(r("%-I %p"),r("%b %-d"),i);case"day":return vf(r("%-d"),r("%b"),i);case"month":return vf(r("%b"),r("%Y"),i);case"year":return r("%Y")}throw new Error("unable to format time ticks")}function xJ(e){return e==="left"||e==="right"?(t,n)=>`
|
|
12
12
|
${t}
|
|
13
13
|
${n}`:e==="top"?(t,n)=>`${n}
|
|
14
14
|
${t}`:(t,n)=>`${t}
|
|
15
|
-
${n}`}function YZ(e){return e==="time"?iw:e==="utc"?Lm:jZ}function kF(e,t,n){let r=Wt(tx(t,(i,o)=>Math.abs(o-i)));if(r<1e3)return BF("millisecond","utc",n);for(let[i,o,s,a]of YZ(e)){if(r>a||i==="hour"&&!r)break;if(t.every(c=>o.floor(c)>=c))return BF(i,s,n)}}function wf(e,t,n){return(r,i,o)=>{let s=e(r,i),a=t(r,i),c=i-Hs(o);return i!==c&&o[c]!==void 0&&a===t(o[c],c)?s:n(s,a)}}var _l=Object.getPrototypeOf(Uint8Array),XZ=Object.prototype.toString,jA=Symbol("reindex");function wt(e,t,n){let r=typeof t;return r==="string"?FF(e,VA(t),n):r==="function"?FF(e,t,n):r==="number"||t instanceof Date||r==="boolean"?Gt(e,hn(t),n):typeof t?.transform=="function"?RF(t.transform(e),n):GZ(RF(t,n),e?.[jA])}function GZ(e,t){return t?Fm(e,t):e}function FF(e,t,n){return Gt(e,n?.prototype instanceof _l?WZ(t):t,n)}function RF(e,t){return t===void 0?je(e):e instanceof t?e:t.prototype instanceof _l&&!(e instanceof _l)?t.from(e,YA):t.from(e)}function WZ(e){return(t,n)=>YA(e(t,n))}var Wa=[null],VA=e=>t=>t[e],Ee={transform:ar},G={transform:e=>e};var km=()=>1,$F=()=>!0,qe=e=>e==null?e:`${e}`,Bt=e=>e==null?e:+e;var Zs=e=>e?e[0]:void 0,Ha=e=>e?e[1]:void 0,PF=e=>e?e[2]:void 0,hn=e=>()=>e;function Sf(e){let t=+`${e}`.slice(1)/100;return(n,r)=>Qn(n,t,r)}function Ke(e){return e instanceof _l?e:Gt(e,YA,Float64Array)}function YA(e){return e==null?NaN:Number(e)}function UF(e){return Gt(e,XA)}function XA(e){return e instanceof Date&&!isNaN(e)?e:typeof e=="string"?wl(e):e==null||isNaN(e=+e)?void 0:new Date(e)}function Be(e,t){return e===void 0&&(e=t),e===null?[void 0,"none"]:Qa(e)?[void 0,e]:[e,void 0]}function se(e,t){return e===void 0&&(e=t),e===null||typeof e=="number"?[void 0,e]:[e,void 0]}function GA(e,t,n){if(e!=null)return tn(e,t,n)}function tn(e,t,n){let r=`${e}`.toLowerCase();if(!n.includes(r))throw new Error(`invalid ${t}: ${e}`);return r}function je(e){return e==null||e instanceof Array||e instanceof _l?e:Array.from(e)}function Gt(e,t,n=Array){return e==null?e:e instanceof n?e.map(t):n.from(e,t)}function Za(e,t=Array){return e instanceof t?e.slice():t.from(e)}function WA({x:e,x1:t,x2:n}){return e!==void 0||t!==void 0||n!==void 0}function HA({y:e,y1:t,y2:n}){return e!==void 0||t!==void 0||n!==void 0}function If(e){return WA(e)||HA(e)||e.interval!==void 0}function pn(e){return e?.toString===XZ}function Lo(e){return pn(e)&&(e.type!==void 0||e.domain!==void 0)}function jr(e){return pn(e)&&typeof e.transform!="function"}function Co(e){return jr(e)&&e.value===void 0&&e.channel===void 0}function ZA(e,t,n,r=G){return t===void 0&&n===void 0?(t=0,n=e===void 0?r:e):t===void 0?t=e===void 0?0:e:n===void 0&&(n=e===void 0?0:e),[t,n]}function $e(e,t){return e===void 0&&t===void 0?[Zs,Ha]:[e,t]}function jn({z:e,fill:t,stroke:n}={}){return e===void 0&&([e]=Be(t)),e===void 0&&([e]=Be(n)),e}function ar(e){let t=e.length,n=new Uint32Array(t);for(let r=0;r<t;++r)n[r]=r;return n}function Fm(e,t){return Gt(t,n=>e[n],e.constructor)}function Mf(e){return e.length===1?(t,n)=>e(Fm(n,t)):e}function Js(e,t,n){return e.subarray?e.subarray(t,n):e.slice(t,n)}function Qs(e){return e!==null&&typeof e=="object"?e.valueOf():e}function aw(e,t){if(t[e]!==void 0)return t[e];switch(e){case"x1":case"x2":e="x";break;case"y1":case"y2":e="y";break}return t[e]}function mn(e){let t;return[{transform:()=>t,label:On(e)},n=>t=n]}function Dn(e){return e==null?[e]:mn(e)}function On(e,t){return typeof e=="string"?e:e&&e.label!==void 0?e.label:t}function Af(e,t){return{transform(n){let r=e.transform(n),i=t.transform(n);return Le(r)||Le(i)?Gt(r,(o,s)=>new Date((+r[s]+ +i[s])/2)):Gt(r,(o,s)=>(+r[s]+ +i[s])/2,Float64Array)},label:e.label}}function Sl(e,t){let n=JA(t?.interval,t?.type);return n?Gt(e,n):e}function JA(e,t){let n=Tf(e,t);return n&&(r=>ze(r)?n.floor(r):r)}function Tf(e,t){if(e!=null){if(typeof e=="number"){0<e&&e<1&&Number.isInteger(1/e)&&(e=-1/e);let n=Math.abs(e);return e<0?{floor:r=>Math.floor(r*n)/n,offset:r=>(r*n+1)/n,range:(r,i)=>Ue(Math.ceil(r*n),i*n).map(o=>o/n)}:{floor:r=>Math.floor(r/n)*n,offset:r=>r+n,range:(r,i)=>Ue(Math.ceil(r/n),i/n).map(o=>o*n)}}if(typeof e=="string")return(t==="time"?zA:Cm)(e);if(typeof e.floor!="function")throw new Error("invalid interval; missing floor method");if(typeof e.offset!="function")throw new Error("invalid interval; missing offset method");return e}}function ko(e,t){if(e=Tf(e,t),e&&typeof e.range!="function")throw new Error("invalid interval: missing range method");return e}function zF(e,t){if(e=ko(e,t),e&&typeof e.ceil!="function")throw new Error("invalid interval: missing ceil method");return e}function qF(e){return Ja(e)&&typeof e?.floor=="function"&&e.floor()instanceof Date}function Ja(e){return typeof e?.range=="function"}function pi(e){return e===void 0||jr(e)?e:{value:e}}function jF(e){return e==null?null:{transform:t=>wt(t,e,Float64Array),label:On(e)}}function VF(e){if(!cr(e))return!1;for(let t of e)if(t!=null)return typeof t=="object"&&"0"in t&&"1"in t}function cr(e){return e&&typeof e[Symbol.iterator]=="function"}function cw(e){for(let t of e)if(t!=null)return typeof t!="object"||t instanceof Date}function Ne(e){for(let t of e){if(t==null)continue;let n=typeof t;return n==="string"||n==="boolean"}}function Le(e){for(let t of e)if(t!=null)return t instanceof Date}function YF(e){for(let t of e)if(t!=null)return typeof t=="string"&&isNaN(t)&&wl(t)}function XF(e){for(let t of e)if(t!=null){if(typeof t!="string")return!1;if(t.trim())return!isNaN(t)}}function Ks(e){for(let t of e)if(t!=null)return typeof t=="number"}function lw(e,t){let n;for(let r of e)if(r!=null){if(!t(r))return!1;n=!0}return n}var HZ=new Set("none,currentcolor,transparent,aliceblue,antiquewhite,aqua,aquamarine,azure,beige,bisque,black,blanchedalmond,blue,blueviolet,brown,burlywood,cadetblue,chartreuse,chocolate,coral,cornflowerblue,cornsilk,crimson,cyan,darkblue,darkcyan,darkgoldenrod,darkgray,darkgreen,darkgrey,darkkhaki,darkmagenta,darkolivegreen,darkorange,darkorchid,darkred,darksalmon,darkseagreen,darkslateblue,darkslategray,darkslategrey,darkturquoise,darkviolet,deeppink,deepskyblue,dimgray,dimgrey,dodgerblue,firebrick,floralwhite,forestgreen,fuchsia,gainsboro,ghostwhite,gold,goldenrod,gray,green,greenyellow,grey,honeydew,hotpink,indianred,indigo,ivory,khaki,lavender,lavenderblush,lawngreen,lemonchiffon,lightblue,lightcoral,lightcyan,lightgoldenrodyellow,lightgray,lightgreen,lightgrey,lightpink,lightsalmon,lightseagreen,lightskyblue,lightslategray,lightslategrey,lightsteelblue,lightyellow,lime,limegreen,linen,magenta,maroon,mediumaquamarine,mediumblue,mediumorchid,mediumpurple,mediumseagreen,mediumslateblue,mediumspringgreen,mediumturquoise,mediumvioletred,midnightblue,mintcream,mistyrose,moccasin,navajowhite,navy,oldlace,olive,olivedrab,orange,orangered,orchid,palegoldenrod,palegreen,paleturquoise,palevioletred,papayawhip,peachpuff,peru,pink,plum,powderblue,purple,rebeccapurple,red,rosybrown,royalblue,saddlebrown,salmon,sandybrown,seagreen,seashell,sienna,silver,skyblue,slateblue,slategray,slategrey,snow,springgreen,steelblue,tan,teal,thistle,tomato,turquoise,violet,wheat,white,whitesmoke,yellow".split(","));function Qa(e){return typeof e!="string"?!1:(e=e.toLowerCase().trim(),/^#[0-9a-f]{3,8}$/.test(e)||/^(?:url|var|rgb|rgba|hsl|hsla|hwb|lab|lch|oklab|oklch|color|color-mix)\(.*\)$/.test(e)||HZ.has(e))}function GF(e){return typeof e=="number"&&(0<=e&&e<=1||isNaN(e))}function re(e){return e==null||ta(e)}function ta(e){return/^\s*none\s*$/i.test(e)}function WF(e){return/^\s*round\s*$/i.test(e)}function uw(e,t){return GA(e,t,["middle","top-left","top","top-right","right","bottom-right","bottom","bottom-left","left"])}function Fo(e="middle"){return uw(e,"frameAnchor")}function Hs(e){if(e==null)return;let t=e[0],n=e[e.length-1];return Hn(t,n)}function HF(e={},...t){let n=e;for(let r of t)for(let i in r)if(n[i]===void 0){let o=r[i];n===e?n={...n,[i]:o}:n[i]=o}return n}function ZZ(e){console.warn("named iterables are deprecated; please use an object instead");let t=new Set;return Object.fromEntries(Array.from(e,n=>{let{name:r}=n;if(r==null)throw new Error("missing name");let i=`${r}`;if(i==="__proto__")throw new Error(`illegal name: ${i}`);if(t.has(i))throw new Error(`duplicate name: ${i}`);return t.add(i),[r,n]}))}function Rm(e){return cr(e)?ZZ(e):e}var mi=Symbol("position"),Vr=Symbol("color"),Il=Symbol("radius"),Ml=Symbol("length"),Al=Symbol("opacity"),Ef=Symbol("symbol"),ZF=Symbol("projection"),de=new Map([["x",mi],["y",mi],["fx",mi],["fy",mi],["r",Il],["color",Vr],["opacity",Al],["symbol",Ef],["length",Ml],["projection",ZF]]);function JF(e){return e===mi||e===ZF}function QF(e){return e===mi||e===Il||e===Ml||e===Al}var QA=Math.sqrt(3),KA=2/QA,JZ={draw(e,t){let n=Math.sqrt(t/Math.PI),r=n*KA,i=r/2;e.moveTo(0,r),e.lineTo(n,i),e.lineTo(n,-i),e.lineTo(0,-r),e.lineTo(-n,-i),e.lineTo(-n,i),e.closePath()}},tT=new Map([["asterisk",gm],["circle",Gs],["cross",xm],["diamond",bm],["diamond2",wm],["hexagon",JZ],["plus",vm],["square",_m],["square2",Sm],["star",Im],["times",pf],["triangle",Mm],["triangle2",Am],["wye",Tm]]);function eT(e){return e&&typeof e.draw=="function"}function KF(e){return eT(e)?!0:typeof e!="string"?!1:tT.has(e.toLowerCase())}function Nf(e){if(e==null||eT(e))return e;let t=tT.get(`${e}`.toLowerCase());if(t)return t;throw new Error(`invalid symbol: ${e}`)}function tR(e){if(e==null||eT(e))return[void 0,e];if(typeof e=="string"){let t=tT.get(`${e}`.toLowerCase());if(t)return[void 0,t]}return[e,void 0]}function yn({filter:e,sort:t,reverse:n,transform:r,initializer:i,...o}={},s){if(r===void 0&&(e!=null&&(r=iT(e)),t!=null&&!Co(t)&&(r=nT(r,sT(t))),n&&(r=nT(r,oT))),s!=null&&i!=null)throw new Error("transforms cannot be applied after initializers");return{...o,...(t===null||Co(t))&&{sort:t},transform:nT(r,s)}}function Ie({filter:e,sort:t,reverse:n,initializer:r,...i}={},o){return r===void 0&&(e!=null&&(r=iT(e)),t!=null&&!Co(t)&&(r=rT(r,sT(t))),n&&(r=rT(r,oT))),{...i,...(t===null||Co(t))&&{sort:t},initializer:rT(r,o)}}function nT(e,t){return e==null?t===null?void 0:t:t==null?e===null?void 0:e:function(n,r,i){return{data:n,facets:r}=e.call(this,n,r,i),t.call(this,je(n),r,i)}}function rT(e,t){return e==null?t===null?void 0:t:t==null?e===null?void 0:e:function(n,r,i,...o){let s,a,c,l,u,f;return{data:a=n,facets:c=r,channels:s}=e.call(this,n,r,i,...o),{data:u=a,facets:f=c,channels:l}=t.call(this,a,c,{...i,...s},...o),{data:u,facets:f,channels:{...s,...l}}}}function fw(e,t){return(e.initializer!=null?Ie:yn)(e,t)}function eR(e,t){return fw(t,iT(e))}function iT(e){return(t,n)=>{let r=wt(t,e);return{data:t,facets:n.map(i=>i.filter(o=>r[o]))}}}function nR({sort:e,...t}={}){return{...fw(t,oT),sort:Co(e)?e:null}}function oT(e,t){return{data:e,facets:t.map(n=>n.slice().reverse())}}function rR({seed:e,sort:t,...n}={}){return{...fw(n,iR(e==null?Math.random:Mo(e))),sort:Co(t)?t:null}}function dw(e,{sort:t,...n}={}){return{...(jr(e)&&e.channel!==void 0?Ie:fw)(n,sT(e)),sort:Co(t)?t:null}}function sT(e){return(typeof e=="function"&&e.length!==1?QZ:iR)(e)}function QZ(e){return(t,n)=>{let r=(i,o)=>e(t[i],t[o]);return{data:t,facets:n.map(i=>i.slice().sort(r))}}}function iR(e){let t,n;({channel:t,value:e,order:n}={...pi(e)});let r=t?.startsWith("-");if(r&&(t=t.slice(1)),n===void 0&&(n=r?bl:dn),typeof n!="function")switch(`${n}`.toLowerCase()){case"ascending":n=dn;break;case"descending":n=bl;break;default:throw new Error(`invalid order: ${n}`)}return(i,o,s)=>{let a;if(t===void 0)a=wt(i,e);else{if(s===void 0)throw new Error("channel sort requires an initializer");if(a=s[t],!a)return{};a=a.value}let c=(l,u)=>n(a[l],a[u]);return{data:i,facets:o.map(l=>l.slice().sort(c))}}}function Pm(e,t){return hw(null,null,e,t)}function tc(e={y:"count"},t={}){let{x:n=G}=t;if(n==null)throw new Error("missing channel: x");return hw(n,null,e,t)}function ec(e={x:"count"},t={}){let{y:n=G}=t;if(n==null)throw new Error("missing channel: y");return hw(null,n,e,t)}function Um(e={fill:"count"},t={}){let{x:n,y:r}=t;if([n,r]=$e(n,r),n==null)throw new Error("missing channel: x");if(r==null)throw new Error("missing channel: y");return hw(n,r,e,t)}function hw(e,t,{data:n=yw,filter:r,sort:i,reverse:o,...s}={},a={}){s=cT(s,a),n=lR(n,G),i=i==null?void 0:aR("sort",i,a),r=r==null?void 0:cR("filter",r,a);let[c,l]=Dn(e),[u,f]=Dn(t),{z:d,fill:h,stroke:p,x1:m,x2:g,y1:y,y2:x,...b}=a,[w,v]=Dn(d),[_]=Be(h),[I]=Be(p),[D,A]=Dn(_),[E,T]=Dn(I);return{..."z"in a&&{z:w||d},..."fill"in a&&{fill:D||h},..."stroke"in a&&{stroke:E||p},...yn(b,(O,C,S)=>{let M=Sl(wt(O,e),S?.x),N=Sl(wt(O,t),S?.y),F=wt(O,d),R=wt(O,_),k=wt(O,I),$=zm(s,{z:F,fill:R,stroke:k}),P=[],U=[],W=M&&l([]),tt=N&&f([]),nt=F&&v([]),at=R&&A([]),Y=k&&T([]),rt=0;for(let j of s)j.initialize(O);i&&i.initialize(O),r&&r.initialize(O);for(let j of C){let H=[];for(let ot of s)ot.scope("facet",j);i&&i.scope("facet",j),r&&r.scope("facet",j);for(let[ot,z]of Ka(j,$))for(let[kt,dt]of Ka(z,N))for(let[Ht,Zt]of Ka(dt,M)){let et={data:O};if(M&&(et.x=Ht),N&&(et.y=kt),!(r&&!r.reduce(Zt,et))){H.push(rt++),U.push(n.reduceIndex(Zt,O,et)),M&&W.push(Ht),N&&tt.push(kt),F&&nt.push($===F?ot:F[Zt[0]]),R&&at.push($===R?ot:R[Zt[0]]),k&&Y.push($===k?ot:k[Zt[0]]);for(let ae of s)ae.reduce(Zt,et);i&&i.reduce(Zt,et)}}P.push(H)}return lT(P,i,o),{data:U,facets:P}}),...!Ro(s,"x")&&(c?{x:c}:{x1:m,x2:g}),...!Ro(s,"y")&&(u?{y:u}:{y1:y,y2:x}),...Object.fromEntries(s.map(({name:O,output:C})=>[O,C]))}}function Ro(e,...t){for(let{name:n}of e)if(t.includes(n))return!0;return!1}function aT(e,t,n=pw){let r=Object.entries(e);return t.title!=null&&e.title===void 0&&r.push(["title",iJ]),t.href!=null&&e.href===void 0&&r.push(["href",gw]),r.filter(([,i])=>i!==void 0).map(([i,o])=>o===null?KZ(i):n(i,o,t))}function pw(e,t,n,r=mw){let i;pn(t)&&"reduce"in t&&(i=t.scale,t=t.reduce);let o=r(e,t,n),[s,a]=mn(o.label),c;return{name:e,output:i===void 0?s:{value:s,scale:i},initialize(l){o.initialize(l),c=a([])},scope(l,u){o.scope(l,u)},reduce(l,u){c.push(o.reduce(l,u))}}}function KZ(e){return{name:e,initialize(){},scope(){},reduce(){}}}function mw(e,t,n,r=Df){let i=aw(e,n),o=r(t,i),s,a;return{label:On(o===$m?null:i,o.label),initialize(c){s=i===void 0?c:wt(c,i),o.scope==="data"&&(a=o.reduceIndex(ar(c),s))},scope(c,l){o.scope===c&&(a=o.reduceIndex(l,s))},reduce(c,l){return o.scope==null?o.reduceIndex(c,s,l):o.reduceIndex(c,s,a,l)}}}function Ka(e,t){return t?fo(cn(e,n=>t[n]),Zs):[[,e]]}function Df(e,t,n=tJ){if(e==null)return n(e);if(typeof e.reduceIndex=="function")return e;if(typeof e.reduce=="function"&&pn(e))return nJ(e);if(typeof e=="function")return rJ(e);if(/^p\d{2}$/i.test(e))return ea(Sf(e));switch(`${e}`.toLowerCase()){case"first":return gw;case"last":return oJ;case"identity":return yw;case"count":return $m;case"distinct":return sJ;case"sum":return t==null?$m:aJ;case"proportion":return sR(t,"data");case"proportion-facet":return sR(t,"facet");case"deviation":return ea(ii);case"min":return ea(ue);case"min-index":return ea(J0);case"max":return ea(Wt);case"max-index":return ea(Z0);case"mean":return oR(Ns);case"median":return oR(Pi);case"variance":return ea(Ea);case"mode":return ea(Ou)}return n(e)}function tJ(e){throw new Error(`invalid reduce: ${e}`)}function cT(e,t){return aT(e,t,aR)}function aR(e,t,n){return pw(e,t,n,cR)}function cR(e,t,n){return mw(e,t,n,lR)}function lR(e,t){return Df(e,t,eJ)}function eJ(e){switch(`${e}`.toLowerCase()){case"x":return cJ;case"y":return lJ}throw new Error(`invalid group reduce: ${e}`)}function zm(e,t){for(let n in t){let r=t[n];if(r!==void 0&&!e.some(i=>i.name===n))return r}}function lT(e,t,n){if(t){let r=t.output.transform(),i=(o,s)=>dn(r[o],r[s]);e.forEach(o=>o.sort(i))}n&&e.forEach(r=>r.reverse())}function nJ(e){return console.warn("deprecated reduce interface; implement reduceIndex instead."),{...e,reduceIndex:e.reduce.bind(e)}}function rJ(e){return{reduceIndex(t,n,r){return e(Fm(n,t),r)}}}function ea(e){return{reduceIndex(t,n){return e(t,r=>n[r])}}}function oR(e){return{reduceIndex(t,n){let r=e(t,i=>n[i]);return Le(n)?new Date(r):r}}}var yw={reduceIndex(e,t){return Fm(t,e)}},gw={reduceIndex(e,t){return t[e[0]]}},iJ={reduceIndex(e,t){let r=fo($i(e,o=>o.length,o=>t[o]),Ha),i=r.slice(-5).reverse();if(i.length<r.length){let o=r.slice(0,-4);i[4]=[`\u2026 ${o.length.toLocaleString("en-US")} more`,An(o,Ha)]}return i.map(([o,s])=>`${o} (${s.toLocaleString("en-US")})`).join(`
|
|
16
|
-
`)}},oJ={reduceIndex(e,t){return t[e[e.length-1]]}},$m={label:"Frequency",reduceIndex(e){return e.length}},sJ={label:"Distinct",reduceIndex(e,t){let n=new Jn;for(let r of e)n.add(t[r]);return n.size}},aJ=ea(An);function sR(e,t){return e==null?{scope:t,label:"Frequency",reduceIndex:(n,r,i=1)=>n.length/i}:{scope:t,reduceIndex:(n,r,i=1)=>An(n,o=>r[o])/i}}var cJ={reduceIndex(e,t,{x:n}){return n}},lJ={reduceIndex(e,t,{y:n}){return n}};function uR(e){if(typeof e!="function")throw new Error(`invalid test function: ${e}`);return{reduceIndex(t,n,{data:r}){return n[t.find(i=>e(r[i],i,r))]}}}function Of(e,{scale:t,type:n,value:r,filter:i,hint:o,label:s=On(r)},a){return o===void 0&&typeof r?.transform=="function"&&(o=r.hint),fT(a,{scale:t,type:n,value:wt(e,r),label:s,filter:i,hint:o})}function xw(e,t){return Object.fromEntries(Object.entries(e).map(([n,r])=>[n,Of(t,r,n)]))}function Bf(e,t){let n=Object.fromEntries(Object.entries(e).map(([r,{scale:i,value:o}])=>{let s=i==null?null:t[i];return[r,s==null?o:Gt(o,s)]}));return n.channels=e,n}function fT(e,t){let{scale:n,value:r}=t;if(n===!0||n==="auto")switch(e){case"fill":case"stroke":case"color":t.scale=n!==!0&&lw(r,Qa)?null:"color";break;case"fillOpacity":case"strokeOpacity":case"opacity":t.scale=n!==!0&&lw(r,GF)?null:"opacity";break;case"symbol":n!==!0&&lw(r,KF)?(t.scale=null,t.value=Gt(r,Nf)):t.scale="symbol";break;default:t.scale=de.has(e)?e:null;break}else if(n===!1)t.scale=null;else if(n!=null&&!de.has(n))throw new Error(`unknown scale: ${n}`);return t}function dR(e,t,n,r,i){let{order:o,reverse:s,reduce:a=!0,limit:c}=i;for(let l in i){if(!de.has(l))continue;let{value:u,order:f=o,reverse:d=s,reduce:h=a,limit:p=c}=pi(i[l]),m=u?.startsWith("-");if(m&&(u=u.slice(1)),f=f===void 0?m!==(u==="width"||u==="height")?pR:hR:dJ(f),h==null||h===!1)continue;let g=l==="fx"||l==="fy"?fJ(t,r[l]):uJ(n,l);if(!g)throw new Error(`missing channel for scale: ${l}`);let y=g.value,[x=0,b=1/0]=cr(p)?p:p<0?[p]:[0,p];if(u==null)g.domain=()=>{let w=Array.from(new Jn(y));return d&&(w=w.reverse()),(x!==0||b!==1/0)&&(w=w.slice(x,b)),w};else{let w=u==="data"?e:u==="height"?fR(n,"y1","y2"):u==="width"?fR(n,"x1","x2"):uT(n,u,u==="y"?"y2":u==="x"?"x2":void 0),v=Df(h===!0?"max":h,w);g.domain=()=>{let _=US(ar(y),I=>v.reduceIndex(I,w),I=>y[I]);return f&&_.sort(f),d&&_.reverse(),(x!==0||b!==1/0)&&(_=_.slice(x,b)),_.map(Zs)}}}}function uJ(e,t){for(let n in e){let r=e[n];if(r.scale===t)return r}}function fJ(e,t){let n=e.original;if(n===e)return t;let r=t.value,i=t.value=[];for(let o=0;o<n.length;++o){let s=r[n[o][0]];for(let a of e[o])i[a]=s}return t}function fR(e,t,n){let r=uT(e,t),i=uT(e,n);return Gt(i,(o,s)=>Math.abs(o-r[s]),Float64Array)}function uT(e,t,n){let r=e[t];if(!r&&n!==void 0&&(r=e[n]),r)return r.value;throw new Error(`missing channel: ${t}`)}function dJ(e){if(e==null||typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"ascending":return hR;case"descending":return pR}throw new Error(`invalid order: ${e}`)}function hR([e,t],[n,r]){return dn(t,r)||dn(e,n)}function pR([e,t],[n,r]){return bl(t,r)||dn(e,n)}function qm(e,t){let n=e[t];if(n){for(;n.source;)n=n.source;return n.source===null?null:n}}function bw(e){let t,n;return(...r)=>((n?.length!==r.length||n.some((i,o)=>i!==r[o]))&&(n=r,t=e(...r)),t)}var hJ=bw(e=>new Intl.NumberFormat(e)),pJ=bw((e,t)=>new Intl.DateTimeFormat(e,{timeZone:"UTC",...t&&{month:t}})),mJ=bw((e,t)=>new Intl.DateTimeFormat(e,{timeZone:"UTC",...t&&{weekday:t}}));function yJ(e="en-US"){let t=hJ(e);return n=>n!=null&&!isNaN(n)?t.format(n):void 0}function mR(e="en-US",t="short"){let n=pJ(e,t);return r=>r!=null&&!isNaN(r=+new Date(Date.UTC(2e3,+r)))?n.format(r):void 0}function yR(e="en-US",t="short"){let n=mJ(e,t);return r=>r!=null&&!isNaN(r=+new Date(Date.UTC(2001,0,+r)))?n.format(r):void 0}function dT(e){return bf(e,"Invalid Date")}function gJ(e="en-US"){let t=yJ(e);return n=>(n instanceof Date?dT:typeof n=="number"?t:qe)(n)}var ji=gJ();var hT=0,pT;function gR(){let e=hT;return hT=0,pT=void 0,e}function Vn(e){e!==pT&&(pT=e,console.warn(e),++hT)}var Ce=(typeof window<"u"?window.devicePixelRatio>1:typeof it>"u")?0:.5,xJ=0;function ww(){return`plot-clip-${++xJ}`}function vw(e,{title:t,href:n,ariaLabel:r,ariaDescription:i,ariaHidden:o,target:s,fill:a,fillOpacity:c,stroke:l,strokeWidth:u,strokeOpacity:f,strokeLinejoin:d,strokeLinecap:h,strokeMiterlimit:p,strokeDasharray:m,strokeDashoffset:g,opacity:y,mixBlendMode:x,imageFilter:b,paintOrder:w,pointerEvents:v,shapeRendering:_,channels:I},{ariaLabel:D,fill:A="currentColor",fillOpacity:E,stroke:T="none",strokeOpacity:O,strokeWidth:C,strokeLinecap:S,strokeLinejoin:M,strokeMiterlimit:N,paintOrder:F}){A===null&&(a=null,c=null),T===null&&(l=null,f=null),re(A)?!re(T)&&(!re(a)||I?.fill)&&(T="none"):re(T)&&(!re(l)||I?.stroke)&&(A="none");let[R,k]=Be(a,A),[$,P]=se(c,E),[U,W]=Be(l,T),[tt,nt]=se(f,O),[at,Y]=se(y);ta(W)||(u===void 0&&(u=C),h===void 0&&(h=S),d===void 0&&(d=M),p===void 0&&!WF(d)&&(p=N),!ta(k)&&w===void 0&&(w=F));let[rt,j]=se(u);return A!==null&&(e.fill=fe(k,"currentColor"),e.fillOpacity=jm(P,1)),T!==null&&(e.stroke=fe(W,"none"),e.strokeWidth=jm(j,1),e.strokeOpacity=jm(nt,1),e.strokeLinejoin=fe(d,"miter"),e.strokeLinecap=fe(h,"butt"),e.strokeMiterlimit=jm(p,4),e.strokeDasharray=fe(m,"none"),e.strokeDashoffset=fe(g,"0")),e.target=qe(s),e.ariaLabel=qe(D),e.ariaDescription=qe(i),e.ariaHidden=qe(o),e.opacity=jm(Y,1),e.mixBlendMode=fe(x,"normal"),e.imageFilter=fe(b,"none"),e.paintOrder=fe(w,"normal"),e.pointerEvents=fe(v,"auto"),e.shapeRendering=fe(_,"auto"),{title:{value:t,optional:!0,filter:null},href:{value:n,optional:!0,filter:null},ariaLabel:{value:r,optional:!0,filter:null},fill:{value:R,scale:"auto",optional:!0},fillOpacity:{value:$,scale:"auto",optional:!0},stroke:{value:U,scale:"auto",optional:!0},strokeOpacity:{value:tt,scale:"auto",optional:!0},strokeWidth:{value:rt,optional:!0},opacity:{value:at,scale:"auto",optional:!0}}}function bJ(e,t){t&&e.filter(n=>Bm(t[n])).append("title").call(vJ,t)}function wJ(e,t){t&&e.filter(([n])=>Bm(t[n])).append("title").call(_J,t)}function vJ(e,t){t&&e.text(n=>ji(t[n]))}function _J(e,t){t&&e.text(([n])=>ji(t[n]))}function Qt(e,{target:t,tip:n},{ariaLabel:r,title:i,fill:o,fillOpacity:s,stroke:a,strokeOpacity:c,strokeWidth:l,opacity:u,href:f}){r&&ft(e,"aria-label",d=>r[d]),o&&ft(e,"fill",d=>o[d]),s&&ft(e,"fill-opacity",d=>s[d]),a&&ft(e,"stroke",d=>a[d]),c&&ft(e,"stroke-opacity",d=>c[d]),l&&ft(e,"stroke-width",d=>l[d]),u&&ft(e,"opacity",d=>u[d]),f&&xR(e,d=>f[d],t),n||bJ(e,i)}function Tl(e,{target:t,tip:n},{ariaLabel:r,title:i,fill:o,fillOpacity:s,stroke:a,strokeOpacity:c,strokeWidth:l,opacity:u,href:f}){r&&ft(e,"aria-label",([d])=>r[d]),o&&ft(e,"fill",([d])=>o[d]),s&&ft(e,"fill-opacity",([d])=>s[d]),a&&ft(e,"stroke",([d])=>a[d]),c&&ft(e,"stroke-opacity",([d])=>c[d]),l&&ft(e,"stroke-width",([d])=>l[d]),u&&ft(e,"opacity",([d])=>u[d]),f&&xR(e,([d])=>f[d],t),n||wJ(e,i)}function SJ({ariaLabel:e,title:t,fill:n,fillOpacity:r,stroke:i,strokeOpacity:o,strokeWidth:s,opacity:a,href:c},{tip:l}){return[e,l?void 0:t,n,r,i,o,s,a,c].filter(u=>u!==void 0)}function Vm(e,t,n){let r=cn(e,i=>t[i]);return n===void 0&&r.size>1+e.length>>1&&Vn("Warning: the implicit z channel has high cardinality. This may occur when the fill or stroke channel is associated with quantitative data rather than ordinal or categorical data. You can suppress this warning by setting the z option explicitly; if this data represents a single series, set z to null."),r.values()}function*_w(e,t,n,r){let{z:i}=n,{z:o}=r,s=SJ(r,n),a=[...t,...s];for(let c of o?Vm(e,o,i):[e]){let l,u;t:for(let f of c){for(let d of a)if(!ze(d[f])){u&&u.push(-1);continue t}if(l===void 0){u&&(yield u),l=s.map(d=>Qs(d[f])),u=[f];continue}u.push(f);for(let d=0;d<s.length;++d)if(Qs(s[d][f])!==l[d]){yield u,l=s.map(p=>Qs(p[f])),u=[f];continue t}}u&&(yield u)}}function Sw(e){return e===!0?e="frame":e===!1?e=null:e!=null&&(e=tn(e,"clip",["frame","sphere"])),e}function IJ(e,t,n,r){let i,{clip:o=r.clip}=t;switch(o){case"frame":{let{width:s,height:a,marginLeft:c,marginRight:l,marginTop:u,marginBottom:f}=n,d=ww();i=`url(#${d})`,e=ut("svg:g",r).call(h=>h.append("svg:clipPath").attr("id",d).append("rect").attr("x",c).attr("y",u).attr("width",s-l-c).attr("height",a-u-f)).each(function(){this.appendChild(e.node()),e.node=()=>this});break}case"sphere":{let{projection:s}=r;if(!s)throw new Error('the "sphere" clip option requires a projection');let a=ww();i=`url(#${a})`,e.append("clipPath").attr("id",a).append("path").attr("d",En(s)({type:"Sphere"}));break}}ft(e,"aria-label",t.ariaLabel),ft(e,"aria-description",t.ariaDescription),ft(e,"aria-hidden",t.ariaHidden),ft(e,"clip-path",i)}function Ct(e,t,n,r){IJ(e,t,n,r),ft(e,"fill",t.fill),ft(e,"fill-opacity",t.fillOpacity),ft(e,"stroke",t.stroke),ft(e,"stroke-width",t.strokeWidth),ft(e,"stroke-opacity",t.strokeOpacity),ft(e,"stroke-linejoin",t.strokeLinejoin),ft(e,"stroke-linecap",t.strokeLinecap),ft(e,"stroke-miterlimit",t.strokeMiterlimit),ft(e,"stroke-dasharray",t.strokeDasharray),ft(e,"stroke-dashoffset",t.strokeDashoffset),ft(e,"shape-rendering",t.shapeRendering),ft(e,"filter",t.imageFilter),ft(e,"paint-order",t.paintOrder);let{pointerEvents:i=r.pointerSticky===!1?"none":void 0}=t;ft(e,"pointer-events",i)}function Lt(e,t){MJ(e,"mix-blend-mode",t.mixBlendMode),ft(e,"opacity",t.opacity)}function xR(e,t,n){e.each(function(r){let i=t(r);if(i!=null){let o=this.ownerDocument.createElementNS(oi.svg,"a");o.setAttribute("fill","inherit"),o.setAttributeNS(oi.xlink,"href",i),n!=null&&o.setAttribute("target",n),this.parentNode.insertBefore(o,this).appendChild(this)}})}function ft(e,t,n){n!=null&&e.attr(t,n)}function MJ(e,t,n){n!=null&&e.style(t,n)}function Et(e,t,{x:n,y:r},i=Ce,o=Ce){i+=t.dx,o+=t.dy,n?.bandwidth&&(i+=n.bandwidth()/2),r?.bandwidth&&(o+=r.bandwidth()/2),(i||o)&&e.attr("transform",`translate(${i},${o})`)}function fe(e,t){if((e=qe(e))!==t)return e}function jm(e,t){if((e=Bt(e))!==t)return e}var AJ=/^-?([_a-z]|[\240-\377]|\\[0-9a-f]{1,6}(\r\n|[ \t\r\n\f])?|\\[^\r\n\f0-9a-f])([_a-z0-9-]|[\240-\377]|\\[0-9a-f]{1,6}(\r\n|[ \t\r\n\f])?|\\[^\r\n\f0-9a-f])*$/i;function Lf(e){if(e===void 0)return"plot-d6a7b5";if(e=`${e}`,!AJ.test(e))throw new Error(`invalid class name: ${e}`);return e}function Cf(e,t){if(typeof t=="string")e.property("style",t);else if(t!=null)for(let n of e)Object.assign(n.style,t)}function gn({frameAnchor:e},{width:t,height:n,marginTop:r,marginRight:i,marginBottom:o,marginLeft:s}){return[/left$/.test(e)?s:/right$/.test(e)?t-i:(s+t-i)/2,/^top/.test(e)?r:/^bottom/.test(e)?n-o:(r+n-o)/2]}function nc(e={}){let{document:t=typeof window<"u"?window.document:void 0,clip:n}=e;return{document:t,clip:Sw(n)}}function ut(e,{document:t}){return Vt(Os(e).call(t.documentElement))}var wR=Math.PI,na=2*wR,bR=.618;function vR({projection:e,inset:t=0,insetTop:n=t,insetRight:r=t,insetBottom:i=t,insetLeft:o=t}={},s){if(e==null)return;if(typeof e.stream=="function")return e;let a,c,l="frame";if(pn(e)){let v;if({type:e,domain:c,inset:v,insetTop:n=v!==void 0?v:n,insetRight:r=v!==void 0?v:r,insetBottom:i=v!==void 0?v:i,insetLeft:o=v!==void 0?v:o,clip:l=l,...a}=e,e==null)return}typeof e!="function"&&({type:e}=_R(e));let{width:u,height:f,marginLeft:d,marginRight:h,marginTop:p,marginBottom:m}=s,g=u-d-h-o-r,y=f-p-m-n-i;if(e=e?.({width:g,height:y,clip:l,...a}),e==null)return;l=TJ(l,d,p,u-h,f-m);let x=d+o,b=p+n,w;if(c!=null){let[[v,_],[I,D]]=En(e).bounds(c),A=Math.min(g/(I-v),y/(D-_));A>0?(x-=(A*(v+I)-g)/2,b-=(A*(_+D)-y)/2,w=Object.assign(cl({point(E,T){this.stream.point(E*A+x,T*A+b)}}),{invert:([E,T])=>[(E-x)/A,(T-b)/A]})):Vn("Warning: the projection could not be fit to the specified domain; using the default scale.")}return w??=x===0&&b===0?SR():Object.assign(cl({point(v,_){this.stream.point(v+x,_+b)}}),{invert:([v,_])=>[v-x,_-b]}),{stream:v=>e.stream(w.stream(l(v))),invert:v=>e.invert(w.invert(v))}}function _R(e){switch(`${e}`.toLowerCase()){case"albers-usa":return Vi(dM,.7463,.4673);case"albers":return Iw(Vp,.7463,.4673);case"azimuthal-equal-area":return Vi(pM,4,4);case"azimuthal-equidistant":return Vi(yM,na,na);case"conic-conformal":return Iw(bM,na,na);case"conic-equal-area":return Iw(Pa,6.1702,2.9781);case"conic-equidistant":return Iw(vM,7.312,3.6282);case"equal-earth":return Vi(SM,5.4133,2.6347);case"equirectangular":return Vi(wM,na,wR);case"gnomonic":return Vi(MM,3.4641,3.4641);case"identity":return{type:SR};case"reflect-y":return{type:EJ};case"mercator":return Vi(gM,na,na);case"orthographic":return Vi(TM,2,2);case"stereographic":return Vi(NM,2,2);case"transverse-mercator":return Vi(OM,na,na);default:throw new Error(`unknown projection type: ${e}`)}}function TJ(e,t,n,r,i){if(e===!1||e==null||typeof e=="number")return o=>o;switch(e===!0&&(e="frame"),`${e}`.toLowerCase()){case"frame":return Zu(t,n,r,i);default:throw new Error(`unknown projection clip type: ${e}`)}}function Vi(e,t,n){return{type:({width:r,height:i,rotate:o,precision:s=.15,clip:a})=>{let c=e();return s!=null&&c.precision?.(s),o!=null&&c.rotate?.(o),typeof a=="number"&&c.clipAngle?.(a),c.scale(Math.min(r/t,i/n)),c.translate([r/2,i/2]),c},aspectRatio:n/t}}function Iw(e,t,n){let{type:r,aspectRatio:i}=Vi(e,t,n);return{type:o=>{let{parallels:s,domain:a,width:c,height:l}=o,u=r(o);return s!=null&&(u.parallels(s),a===void 0&&u.fitSize([c,l],{type:"Sphere"})),u},aspectRatio:i}}var SR=hn({stream:e=>e,invert:e=>e}),EJ=hn(Object.assign(cl({point(e,t){this.stream.point(e,-t)}}),{invert:([e,t])=>[e,-t]}));function mT(e,t,n,r){let i=n[e],o=n[t],s=i.length,a=n[e]=new Float64Array(s).fill(NaN),c=n[t]=new Float64Array(s).fill(NaN),l,u=r.stream({point(f,d){a[l]=f,c[l]=d}});for(l=0;l<s;++l)u.point(i[l],o[l])}function IR({projection:e}={}){return e==null?!1:typeof e.stream=="function"?!0:(pn(e)&&(e=e.type),e!=null)}function MR(e){if(typeof e?.stream=="function")return bR;if(pn(e)&&(e=e.type),e!=null){if(typeof e!="function"){let{aspectRatio:t}=_R(e);if(t)return t}return bR}}function rc(e,t,{projection:n}){let{x:r,y:i}=e,o={};return r&&(o.x=r),i&&(o.y=i),o=Bf(o,t),n&&r?.scale==="x"&&i?.scale==="y"&&mT("x","y",o,n),r&&(o.x=Ke(o.x)),i&&(o.y=Ke(o.y)),o}function AR(e){let t=[],n=[],r={scale:"x",value:t},i={scale:"y",value:n},o={point(s,a){t.push(s),n.push(a)},lineStart(){},lineEnd(){},polygonStart(){},polygonEnd(){},sphere(){}};for(let s of e.value)Pr(s,o);return[r,i]}var NJ=["#4269d0","#efb118","#ff725c","#6cc5b0","#3ca951","#ff8ab7","#a463f2","#97bbf5","#9c6b4e","#9498a0"],OR=new Map([["accent",eA],["category10",tA],["dark2",nA],["observable10",NJ],["paired",rA],["pastel1",iA],["pastel2",oA],["set1",sA],["set2",aA],["set3",cA],["tableau10",lA]]);function BR(e){return e!=null&&OR.has(`${e}`.toLowerCase())}var TR=new Map([...OR,["brbg",ra(Fb,Rb)],["prgn",ra($b,Pb)],["piyg",ra(Ub,zb)],["puor",ra(qb,jb)],["rdbu",ra(hm,lf)],["rdgy",ra(Vb,Yb)],["rdylbu",ra(pm,uf)],["rdylgn",ra(Xb,Gb)],["spectral",ra(Wb,Hb)],["burd",ER(hm,lf)],["buylrd",ER(pm,uf)],["blues",xn(w1,v1)],["greens",xn(_1,S1)],["greys",xn(I1,M1)],["oranges",xn(D1,O1)],["purples",xn(A1,T1)],["reds",xn(E1,N1)],["turbo",ia(U1)],["viridis",ia(q1)],["magma",ia(j1)],["inferno",ia(V1)],["plasma",ia(Y1)],["cividis",ia(B1)],["cubehelix",ia(L1)],["warm",ia(k1)],["cool",ia(F1)],["bugn",xn(Zb,Jb)],["bupu",xn(Qb,Kb)],["gnbu",xn(t1,e1)],["orrd",xn(n1,r1)],["pubu",xn(s1,a1)],["pubugn",xn(i1,o1)],["purd",xn(c1,l1)],["rdpu",xn(u1,f1)],["ylgn",xn(p1,m1)],["ylgnbu",xn(d1,h1)],["ylorbr",xn(y1,g1)],["ylorrd",xn(x1,b1)],["rainbow",NR(R1)],["sinebow",NR(P1)]]);function xn(e,t){return({length:n})=>n===1?[e[3][1]]:n===2?[e[3][1],e[3][2]]:(n=Math.max(3,Math.floor(n)),n>9?Fn(t,n):e[n])}function ra(e,t){return({length:n})=>n===2?[e[3][0],e[3][2]]:(n=Math.max(3,Math.floor(n)),n>11?Fn(t,n):e[n])}function ER(e,t){return({length:n})=>n===2?[e[3][2],e[3][0]]:(n=Math.max(3,Math.floor(n)),n>11?Fn(r=>t(1-r),n):e[n].slice().reverse())}function ia(e){return({length:t})=>Fn(e,Math.max(2,Math.floor(t)))}function NR(e){return({length:t})=>Fn(e,Math.floor(t)+1).slice(0,-1)}function yT(e){let t=`${e}`.toLowerCase();if(!TR.has(t))throw new Error(`unknown ordinal scheme: ${t}`);return TR.get(t)}function Ym(e,t){let n=yT(e),r=typeof n=="function"?n({length:t}):n;return r.length!==t?r.slice(0,t):r}function LR(e,t="greys"){let n=new Set,[r,i]=Ym(t,2);for(let o of e)if(o!=null)if(o===!0)n.add(i);else if(o===!1)n.add(r);else return;return[...n]}var DR=new Map([["brbg",Rb],["prgn",Pb],["piyg",zb],["puor",jb],["rdbu",lf],["rdgy",Yb],["rdylbu",uf],["rdylgn",Gb],["spectral",Hb],["burd",e=>lf(1-e)],["buylrd",e=>uf(1-e)],["blues",v1],["greens",S1],["greys",M1],["purples",T1],["reds",N1],["oranges",O1],["turbo",U1],["viridis",q1],["magma",j1],["inferno",V1],["plasma",Y1],["cividis",B1],["cubehelix",L1],["warm",k1],["cool",F1],["bugn",Jb],["bupu",Kb],["gnbu",e1],["orrd",r1],["pubugn",o1],["pubu",a1],["purd",l1],["rdpu",f1],["ylgnbu",h1],["ylgn",m1],["ylorbr",g1],["ylorrd",b1],["rainbow",R1],["sinebow",P1]]);function kf(e){let t=`${e}`.toLowerCase();if(!DR.has(t))throw new Error(`unknown quantitative scheme: ${t}`);return DR.get(t)}var DJ=new Set(["brbg","prgn","piyg","puor","rdbu","rdgy","rdylbu","rdylgn","spectral","burd","buylrd"]);function CR(e){return e!=null&&DJ.has(`${e}`.toLowerCase())}var xT=e=>t=>e(1-t),gT=[0,1],kR=new Map([["number",_e],["rgb",si],["hsl",dI],["hcl",hI],["lab",bx]]);function bT(e){let t=`${e}`.toLowerCase();if(!kR.has(t))throw new Error(`unknown interpolator: ${t}`);return kR.get(t)}function Rf(e,t,n,{type:r,nice:i,clamp:o,zero:s,domain:a=jR(e,n),unknown:c,round:l,scheme:u,interval:f,range:d=de.get(e)===Il?CJ(n,a):de.get(e)===Ml?kJ(n,a):de.get(e)===Al?gT:void 0,interpolate:h=de.get(e)===Vr?u==null&&d!==void 0?si:kf(u!==void 0?u:r==="cyclical"?"rainbow":"turbo"):l?Kc:_e,reverse:p}){if(f=ko(f,r),(r==="cyclical"||r==="sequential")&&(r="linear"),typeof h!="function"&&(h=bT(h)),p=!!p,d!==void 0){let m=(a=je(a)).length,g=(d=je(d)).length;if(m!==g){if(h.length===1)throw new Error("invalid piecewise interpolator");h=yo(h,d),d=void 0}}if(h.length===1?(p&&(h=xT(h),p=!1),d===void 0&&(d=Float64Array.from(a,(m,g)=>g/(a.length-1)),d.length===2&&(d=gT)),t.interpolate((d===gT?hn:Xm)(h))):t.interpolate(h),s){let[m,g]=le(a);(m>0||g<0)&&(a=Za(a),Hs(a)!==Math.sign(m)?a[a.length-1]=0:a[0]=0)}return p&&(a=Da(a)),t.domain(a).unknown(c),i&&(t.nice(OJ(i,r)),a=t.domain()),d!==void 0&&t.range(d),o&&t.clamp(o),{type:r,domain:a,range:d,scale:t,interpolate:h,interval:f}}function OJ(e,t){return e===!0?void 0:typeof e=="number"?e:zF(e,t)}function FR(e,t,n){return Rf(e,Ps(),t,n)}function RR(e,t,n){return wT(e,t,{...n,exponent:.5})}function wT(e,t,{exponent:n=1,...r}){return Rf(e,nm().exponent(n),t,{...r,type:"pow"})}function $R(e,t,{base:n=10,domain:r=FJ(t),...i}){return Rf(e,tm().base(n),t,{...i,domain:r})}function PR(e,t,{constant:n=1,...r}){return Rf(e,em().constant(n),t,r)}function UR(e,t,{range:n,quantiles:r=n===void 0?5:(n=[...n]).length,n:i=r,scheme:o="rdylbu",domain:s=RJ(t),unknown:a,interpolate:c,reverse:l}){return n===void 0&&(n=c!==void 0?Fn(c,i):de.get(e)===Vr?Ym(o,i):void 0),s.length>0&&(s=rm(s,n===void 0?{length:i}:n).quantiles()),Mw(e,t,{domain:s,range:n,reverse:l,unknown:a})}function zR(e,t,{range:n,n:r=n===void 0?5:(n=[...n]).length,scheme:i="rdylbu",domain:o=jR(e,t),unknown:s,interpolate:a,reverse:c}){let[l,u]=le(o),f;return n===void 0?(f=Mn(l,u,r),f[0]<=l&&f.splice(0,1),f[f.length-1]>=u&&f.pop(),r=f.length+1,n=a!==void 0?Fn(a,r):de.get(e)===Vr?Ym(i,r):void 0):(f=Fn(_e(l,u),r+1).slice(1,-1),l instanceof Date&&(f=f.map(d=>new Date(d)))),Hs(je(o))<0&&f.reverse(),Mw(e,t,{domain:f,range:n,reverse:c,unknown:s})}function Mw(e,t,{domain:n=[0],unknown:r,scheme:i="rdylbu",interpolate:o,range:s=o!==void 0?Fn(o,n.length+1):de.get(e)===Vr?Ym(i,n.length+1):void 0,reverse:a}){n=je(n);let c=Hs(n);if(!isNaN(c)&&!BJ(n,c))throw new Error(`the ${e} scale has a non-monotonic domain`);return a&&(s=Da(s)),{type:"threshold",scale:im(c<0?Da(n):n,s===void 0?[]:s).unknown(r),domain:n,range:s}}function BJ(e,t){for(let n=1,r=e.length,i=e[0];n<r;++n){let o=Hn(i,i=e[n]);if(o!==0&&o!==t)return!1}return!0}function qR(e){return{type:"identity",scale:QF(de.get(e))?Qp():t=>t}}function Ff(e,t=xf){return e.length?[ue(e,({value:n})=>n===void 0?n:ue(n,t)),Wt(e,({value:n})=>n===void 0?n:Wt(n,t))]:[0,1]}function jR(e,t){let n=de.get(e);return(n===Il||n===Al||n===Ml?LJ:Ff)(t)}function LJ(e){return[0,e.length?Wt(e,({value:t})=>t===void 0?t:Wt(t,xf)):1]}function CJ(e,t){let n=e.find(({radius:s})=>s!==void 0);if(n!==void 0)return[0,n.radius];let r=Qn(e,.5,({value:s})=>s===void 0?NaN:Qn(s,.25,sr)),i=t.map(s=>3*Math.sqrt(s/r)),o=30/Wt(i);return o<1?i.map(s=>s*o):i}function kJ(e,t){let n=Pi(e,({value:o})=>o===void 0?NaN:Pi(o,Math.abs)),r=t.map(o=>12*o/n),i=60/Wt(r);return i<1?r.map(o=>o*i):r}function FJ(e){for(let{value:t}of e)if(t!==void 0)for(let n of t){if(n>0)return Ff(e,sr);if(n<0)return Ff(e,Va)}return[1,10]}function RJ(e){let t=[];for(let{value:n}of e)if(n!==void 0)for(let r of n)t.push(r);return t}function Xm(e){return(t,n)=>r=>e(t+r*(n-t))}function Aw(e,t,n,r,{type:i,nice:o,clamp:s,domain:a=Ff(r),unknown:c,pivot:l=0,scheme:u,range:f,symmetric:d=!0,interpolate:h=de.get(e)===Vr?u==null&&f!==void 0?si:kf(u!==void 0?u:"rdbu"):_e,reverse:p}){l=+l,a=je(a);let[m,g]=a;if(a.length>2&&Vn(`Warning: the diverging ${e} scale domain contains extra elements.`),Hn(m,g)<0&&([m,g]=[g,m],p=!p),m=Math.min(m,l),g=Math.max(g,l),typeof h!="function"&&(h=bT(h)),f!==void 0&&(h=h.length===1?Xm(h)(...f):yo(h,f)),p&&(h=xT(h)),d){let y=n.apply(l),x=y-n.apply(m),b=n.apply(g)-y;x<b?m=n.invert(y-b):x>b&&(g=n.invert(y+x))}return t.domain([m,l,g]).unknown(c).interpolator(h),s&&t.clamp(s),o&&t.nice(o),{type:i,domain:[m,g],pivot:l,interpolate:h,scale:t}}function VR(e,t,n){return Aw(e,dm(),$J,t,n)}function YR(e,t,n){return vT(e,t,{...n,exponent:.5})}function vT(e,t,{exponent:n=1,...r}){return Aw(e,kb().exponent(n=+n),zJ(n),t,{...r,type:"diverging-pow"})}function XR(e,t,{base:n=10,pivot:r=1,domain:i=Ff(t,r<0?Va:sr),...o}){return Aw(e,Lb().base(n=+n),PJ,t,{domain:i,pivot:r,...o})}function GR(e,t,{constant:n=1,...r}){return Aw(e,Cb().constant(n=+n),qJ(n),t,r)}var $J={apply(e){return e},invert(e){return e}},PJ={apply:Math.log,invert:Math.exp},UJ={apply(e){return Math.sign(e)*Math.sqrt(Math.abs(e))},invert(e){return Math.sign(e)*(e*e)}};function zJ(e){return e===.5?UJ:{apply(t){return Math.sign(t)*Math.pow(Math.abs(t),e)},invert(t){return Math.sign(t)*Math.pow(Math.abs(t),1/e)}}}function qJ(e){return{apply(t){return Math.sign(t)*Math.log1p(Math.abs(t/e))},invert(t){return Math.sign(t)*Math.expm1(Math.abs(t))*e}}}function WR(e,t,n,r){return Rf(e,t,n,r)}function HR(e,t,n){return WR(e,Db(),t,n)}function ZR(e,t,n){return WR(e,Ob(),t,n)}var $f=Symbol("ordinal");function QR(e,t,n,{type:r,interval:i,domain:o,range:s,reverse:a,hint:c}){return i=ko(i,r),o===void 0&&(o=r7(n,i,e)),(r==="categorical"||r===$f)&&(r="ordinal"),a&&(o=Da(o)),o=t.domain(o).domain(),s!==void 0&&(typeof s=="function"&&(s=s(o)),t.range(s)),{type:r,domain:o,range:s,scale:t,hint:c,interval:i}}function KR(e,t,{type:n,interval:r,domain:i,range:o,scheme:s,unknown:a,...c}){r=ko(r,n),i===void 0&&(i=r7(t,r,e));let l;if(de.get(e)===Ef)l=jJ(t),o=o===void 0?VJ(l):Gt(o,Nf);else if(de.get(e)===Vr&&(o===void 0&&(n==="ordinal"||n===$f)&&(o=LR(i,s),o!==void 0&&(s=void 0)),s===void 0&&o===void 0&&(s=n==="ordinal"?"turbo":"observable10"),s!==void 0))if(o!==void 0){let u=kf(s),f=o[0],d=o[1]-o[0];o=({length:h})=>Fn(p=>u(f+d*p),h)}else o=yT(s);if(a===Zp)throw new Error(`implicit unknown on ${e} scale is not supported`);return QR(e,ul().unknown(a),t,{...c,type:n,domain:i,range:o,hint:l})}function t7(e,t,{align:n=.5,padding:r=.5,...i}){return n7($M().align(n).padding(r),t,i,e)}function e7(e,t,{align:n=.5,padding:r=.1,paddingInner:i=r,paddingOuter:o=e==="fx"||e==="fy"?0:r,...s}){return n7(za().align(n).paddingInner(i).paddingOuter(o),t,s,e)}function n7(e,t,n,r){let{round:i}=n;return i!==void 0&&e.round(i=!!i),e=QR(r,e,t,n),e.round=i,e}function r7(e,t,n){let r=new Jn;for(let{value:i,domain:o}of e){if(o!==void 0)return o();if(i!==void 0)for(let s of i)r.add(s)}if(t!==void 0){let[i,o]=le(r).map(t.floor,t);return t.range(i,t.offset(o))}if(r.size>1e4&&de.get(n)===mi)throw new Error(`implicit ordinal domain of ${n} scale has more than 10,000 values`);return fo(r,dn)}function JR(e,t){let n;for(let{hint:r}of e){let i=r?.[t];if(i!==void 0){if(n===void 0)n=i;else if(n!==i)return}}return n}function jJ(e){return{fill:JR(e,"fill"),stroke:JR(e,"stroke")}}function VJ(e){return re(e.fill)?yA:J1}function Gm(e,{label:t,inset:n=0,insetTop:r=n,insetRight:i=n,insetBottom:o=n,insetLeft:s=n,round:a,nice:c,clamp:l,zero:u,align:f,padding:d,projection:h,facet:{label:p=t}={},...m}={}){let g={};for(let[y,x]of e){let b=m[y],w=f7(y,x,{round:de.get(y)===mi?a:void 0,nice:c,clamp:l,zero:u,align:f,padding:d,projection:h,...b});if(w){let{label:v=y==="fx"||y==="fy"?p:t,percent:_,transform:I,inset:D,insetTop:A=D!==void 0?D:y==="y"?r:0,insetRight:E=D!==void 0?D:y==="x"?i:0,insetBottom:T=D!==void 0?D:y==="y"?o:0,insetLeft:O=D!==void 0?D:y==="x"?s:0}=b||{};if(I==null)I=void 0;else if(typeof I!="function")throw new Error("invalid scale transform; not a function");w.percent=!!_,w.label=v===void 0?YJ(x,w):v,w.transform=I,y==="x"||y==="fx"?(w.insetLeft=+O,w.insetRight=+E):(y==="y"||y==="fy")&&(w.insetTop=+A,w.insetBottom=+T),g[y]=w}}return g}function ST(e){let t={},n={scales:t};for(let[r,i]of Object.entries(e)){let{scale:o,type:s,interval:a,label:c}=i;t[r]=h7(i),n[r]=o,o.type=s,a!=null&&(o.interval=a),c!=null&&(o.label=c)}return n}function c7(e,t){let{x:n,y:r,fx:i,fy:o}=e,s=i||o?Nw(t):t;i&&i7(i,s),o&&o7(o,s);let a=i||o?IT(e,t):t;n&&i7(n,a),r&&o7(r,a)}function YJ(e=[],t){let n;for(let{label:r}of e)if(r!==void 0){if(n===void 0)n=r;else if(n!==r)return}if(n!==void 0)return!$o(t)&&t.percent&&(n=`${n} (%)`),{inferred:!0,toString:()=>n}}function Ew(e){return Math.sign(Hs(e.domain()))*Math.sign(Hs(e.range()))}function Nw(e){let{marginTop:t,marginRight:n,marginBottom:r,marginLeft:i,width:o,height:s,facet:{marginTop:a,marginRight:c,marginBottom:l,marginLeft:u}}=e;return{marginTop:Math.max(t,a),marginRight:Math.max(n,c),marginBottom:Math.max(r,l),marginLeft:Math.max(i,u),width:o,height:s}}function IT({fx:e,fy:t},n){let{marginTop:r,marginRight:i,marginBottom:o,marginLeft:s,width:a,height:c}=Nw(n);return{marginTop:r,marginRight:i,marginBottom:o,marginLeft:s,width:e?e.scale.bandwidth()+s+i:a,height:t?t.scale.bandwidth()+r+o:c,facet:{width:a,height:c}}}function i7(e,t){if(e.range===void 0){let{insetLeft:n,insetRight:r}=e,{width:i,marginLeft:o=0,marginRight:s=0}=t,a=o+n,c=i-s-r;e.range=[a,Math.max(a,c)],$o(e)||(e.range=u7(e)),e.scale.range(e.range)}l7(e)}function o7(e,t){if(e.range===void 0){let{insetTop:n,insetBottom:r}=e,{height:i,marginTop:o=0,marginBottom:s=0}=t,a=o+n,c=i-s-r;e.range=[Math.max(a,c),a],$o(e)?e.range.reverse():e.range=u7(e),e.scale.range(e.range)}l7(e)}function l7(e){e.round===void 0&&WJ(e)&&XJ(e)<=30&&e.scale.round(!0)}function XJ({scale:e}){let t=e.domain().length,[n,r]=e.range(),i=e.paddingInner?e.paddingInner():1,o=e.paddingOuter?e.paddingOuter():e.padding(),s=t-i,a=Math.abs(r-n)/Math.max(1,s+o*2);return(a-Math.floor(a))*s}function u7(e){let t=e.scale.domain().length+MT(e);if(!(t>2))return e.range;let[n,r]=e.range;return Array.from({length:t},(i,o)=>n+o/(t-1)*(r-n))}function Dw(e,t,n){return f7(e,n===void 0?void 0:[{hint:n}],{...t})}function f7(e,t=[],n={}){let r=GJ(e,t,n);if(n.type===void 0&&n.domain===void 0&&n.range===void 0&&n.interval==null&&e!=="fx"&&e!=="fy"&&$o({type:r})){let i=t.map(({value:o})=>o).filter(o=>o!==void 0);i.some(Le)?Vn(`Warning: some data associated with the ${e} scale are dates. Dates are typically associated with a "utc" or "time" scale rather than a "${Pf(r)}" scale. If you are using a bar mark, you probably want a rect mark with the interval option instead; if you are using a group transform, you probably want a bin transform instead. If you want to treat this data as ordinal, you can specify the interval of the ${e} scale (e.g., d3.utcDay), or you can suppress this warning by setting the type of the ${e} scale to "${Pf(r)}".`):i.some(YF)?Vn(`Warning: some data associated with the ${e} scale are strings that appear to be dates (e.g., YYYY-MM-DD). If these strings represent dates, you should parse them to Date objects. Dates are typically associated with a "utc" or "time" scale rather than a "${Pf(r)}" scale. If you are using a bar mark, you probably want a rect mark with the interval option instead; if you are using a group transform, you probably want a bin transform instead. If you want to treat this data as ordinal, you can suppress this warning by setting the type of the ${e} scale to "${Pf(r)}".`):i.some(XF)&&Vn(`Warning: some data associated with the ${e} scale are strings that appear to be numbers. If these strings represent numbers, you should parse or coerce them to numbers. Numbers are typically associated with a "linear" scale rather than a "${Pf(r)}" scale. If you want to treat this data as ordinal, you can specify the interval of the ${e} scale (e.g., 1 for integers), or you can suppress this warning by setting the type of the ${e} scale to "${Pf(r)}".`)}switch(n.type=r,r){case"diverging":case"diverging-sqrt":case"diverging-pow":case"diverging-log":case"diverging-symlog":case"cyclical":case"sequential":case"linear":case"sqrt":case"threshold":case"quantile":case"pow":case"log":case"symlog":n=Tw(t,n,Ke);break;case"identity":switch(de.get(e)){case mi:n=Tw(t,n,Ke);break;case Ef:n=Tw(t,n,HJ);break}break;case"utc":case"time":n=Tw(t,n,UF);break}switch(r){case"diverging":return VR(e,t,n);case"diverging-sqrt":return YR(e,t,n);case"diverging-pow":return vT(e,t,n);case"diverging-log":return XR(e,t,n);case"diverging-symlog":return GR(e,t,n);case"categorical":case"ordinal":case $f:return KR(e,t,n);case"cyclical":case"sequential":case"linear":return FR(e,t,n);case"sqrt":return RR(e,t,n);case"threshold":return Mw(e,t,n);case"quantile":return UR(e,t,n);case"quantize":return zR(e,t,n);case"pow":return wT(e,t,n);case"log":return $R(e,t,n);case"symlog":return PR(e,t,n);case"utc":return ZR(e,t,n);case"time":return HR(e,t,n);case"point":return t7(e,t,n);case"band":return e7(e,t,n);case"identity":return qR(e);case void 0:return;default:throw new Error(`unknown scale type: ${r}`)}}function Pf(e){return typeof e=="symbol"?e.description:e}function s7(e){return typeof e=="string"?`${e}`.toLowerCase():e}var a7={toString:()=>"projection"};function GJ(e,t,{type:n,domain:r,range:i,scheme:o,pivot:s,projection:a}){if(n=s7(n),e==="fx"||e==="fy")return"band";(e==="x"||e==="y")&&a!=null&&(n=a7);for(let l of t){let u=s7(l.type);if(u!==void 0){if(n===void 0)n=u;else if(n!==u)throw new Error(`scale incompatible with channel: ${n} !== ${u}`)}}if(n===a7)return;if(n!==void 0)return n;if(r===void 0&&!t.some(({value:l})=>l!==void 0))return;let c=de.get(e);if(c===Il)return"sqrt";if(c===Al||c===Ml)return"linear";if(c===Ef)return"ordinal";if((r||i||[]).length>2)return _T(c);if(r!==void 0){if(Ne(r))return _T(c);if(Le(r))return"utc"}else{let l=t.map(({value:u})=>u).filter(u=>u!==void 0);if(l.some(Ne))return _T(c);if(l.some(Le))return"utc"}if(c===Vr){if(s!=null||CR(o))return"diverging";if(BR(o))return"categorical"}return"linear"}function _T(e){switch(e){case mi:return"point";case Vr:return $f;default:return"ordinal"}}function $o({type:e}){return e==="ordinal"||e==="point"||e==="band"||e===$f}function MT({type:e}){return e==="threshold"}function WJ({type:e}){return e==="point"||e==="band"}function lr(e){if(e===void 0)return!0;let t=e.domain(),n=e(t[0]);for(let r=1,i=t.length;r<i;++r)if(e(t[r])-n)return!1;return!0}function Tw(e,{domain:t,...n},r){for(let i of e)i.value!==void 0&&(t===void 0&&(t=i.value?.domain),i.value=r(i.value));return{domain:t===void 0?t:r(t),...n}}function HJ(e){return Gt(e,Nf)}function Uf(e={}){let t;for(let n in e)if(de.has(n)&&Lo(e[n])){if(t!==void 0)throw new Error("ambiguous scale definition; multiple scales found");t=h7(Dw(n,e[n]))}if(t===void 0)throw new Error("invalid scale definition; no scale found");return t}function d7(e){return t=>{if(!de.has(t=`${t}`))throw new Error(`unknown scale: ${t}`);return e[t]}}function h7({scale:e,type:t,domain:n,range:r,interpolate:i,interval:o,transform:s,percent:a,pivot:c}){if(t==="identity")return{type:"identity",apply:u=>u,invert:u=>u};let l=e.unknown?e.unknown():void 0;return{type:t,domain:Za(n),...r!==void 0&&{range:Za(r)},...s!==void 0&&{transform:s},...a&&{percent:a},...l!==void 0&&{unknown:l},...o!==void 0&&{interval:o},...i!==void 0&&{interpolate:i},...e.clamp&&{clamp:e.clamp()},...c!==void 0&&{pivot:c,symmetric:!1},...e.base&&{base:e.base()},...e.exponent&&{exponent:e.exponent()},...e.constant&&{constant:e.constant()},...e.align&&{align:e.align(),round:e.round()},...e.padding&&(e.paddingInner?{paddingInner:e.paddingInner(),paddingOuter:e.paddingOuter()}:{padding:e.padding()}),...e.bandwidth&&{bandwidth:e.bandwidth(),step:e.step()},apply:u=>e(u),...e.invert&&{invert:u=>e.invert(u)}}}function m7(e,t,n={}){let r=.5-Ce,i=.5+Ce,o=.5+Ce,s=.5-Ce;for(let{marginTop:m,marginRight:g,marginBottom:y,marginLeft:x}of t)m>r&&(r=m),g>i&&(i=g),y>o&&(o=y),x>s&&(s=x);let{margin:a,marginTop:c=a!==void 0?a:r,marginRight:l=a!==void 0?a:i,marginBottom:u=a!==void 0?a:o,marginLeft:f=a!==void 0?a:s}=n;c=+c,l=+l,u=+u,f=+f;let{width:d=640,height:h=ZJ(e,n,{width:d,marginTopDefault:r,marginRightDefault:i,marginBottomDefault:o,marginLeftDefault:s})+Math.max(0,c-r+u-o)}=n;d=+d,h=+h;let p={width:d,height:h,marginTop:c,marginRight:l,marginBottom:u,marginLeft:f};if(e.fx||e.fy){let{margin:m,marginTop:g=m!==void 0?m:c,marginRight:y=m!==void 0?m:l,marginBottom:x=m!==void 0?m:u,marginLeft:b=m!==void 0?m:f}=n.facet??{};g=+g,y=+y,x=+x,b=+b,p.facet={marginTop:g,marginRight:y,marginBottom:x,marginLeft:b}}return p}function ZJ({x:e,y:t,fy:n,fx:r},{projection:i,aspectRatio:o},{width:s,marginTopDefault:a,marginRightDefault:c,marginBottomDefault:l,marginLeftDefault:u}){let f=n?n.scale.domain().length:1,d=MR(i);if(d){let p=r?r.scale.domain().length:1,m=(1.1*f-.1)/(1.1*p-.1)*d,g=Math.max(.1,Math.min(10,m));return Math.round((s-u-c)*g+a+l)}let h=t?$o(t)?t.scale.domain().length:Math.max(7,17/f):1;if(o!=null){if(o=+o,!(isFinite(o)&&o>0))throw new Error(`invalid aspectRatio: ${o}`);let p=p7("y",t)/(p7("x",e)*o),m=r?r.scale.bandwidth():1,g=n?n.scale.bandwidth():1,y=m*(s-u-c)-e.insetLeft-e.insetRight;return(p*y+t.insetTop+t.insetBottom)/g+a+l}return!!(t||n)*Math.max(1,Math.min(60,h*f))*20+!!r*30+60}function p7(e,t){if(!t)throw new Error(`aspectRatio requires ${e} scale`);let{type:n,domain:r}=t,i;switch(n){case"linear":case"utc":case"time":i=Number;break;case"pow":{let a=t.scale.exponent();i=c=>Math.pow(c,a);break}case"log":i=Math.log;break;case"point":case"band":return r.length;default:throw new Error(`unsupported ${e} scale for aspectRatio: ${n}`)}let[o,s]=le(r);return Math.abs(i(s)-i(o))}function g7(e,t){let{fx:n,fy:r}=Gm(e,t),i=n?.scale.domain(),o=r?.scale.domain();return i&&o?G0(i,o).map(([s,a],c)=>({x:s,y:a,i:c})):i?i.map((s,a)=>({x:s,i:a})):o?o.map((s,a)=>({y:s,i:a})):void 0}function x7(e,{x:t,y:n}){return t&&=DT(t),n&&=DT(n),e.filter(t&&n?r=>t.has(r.x)&&n.has(r.y):t?r=>t.has(r.x):r=>n.has(r.y)).sort(t&&n?(r,i)=>t.get(r.x)-t.get(i.x)||n.get(r.y)-n.get(i.y):t?(r,i)=>t.get(r.x)-t.get(i.x):(r,i)=>n.get(r.y)-n.get(i.y))}function Bw(e,{fx:t,fy:n}){let r=ar(e),i=t?.value,o=n?.value;return t&&n?$i(r,s=>(s.fx=i[s[0]],s.fy=o[s[0]],s),s=>i[s],s=>o[s]):t?$i(r,s=>(s.fx=i[s[0]],s),s=>i[s]):$i(r,s=>(s.fy=o[s[0]],s),s=>o[s])}function b7(e,t,{marginTop:n,marginLeft:r}){return e&&t?({x:i,y:o})=>`translate(${e(i)-r},${t(o)-n})`:e?({x:i})=>`translate(${e(i)-r},0)`:({y:i})=>`translate(0,${t(i)-n})`}function w7(e){let t=[],n=new Uint32Array(An(e,r=>r.length));for(let r of e){let i=0;for(let o of e)r!==o&&(n.set(o,i),i+=o.length);t.push(n.slice(0,i))}return t}var JJ=new Map([["top",AT],["right",NT],["bottom",TT],["left",ET],["top-left",Ow(AT,ET)],["top-right",Ow(AT,NT)],["bottom-left",Ow(TT,ET)],["bottom-right",Ow(TT,NT)],["top-empty",KJ],["right-empty",nQ],["bottom-empty",tQ],["left-empty",eQ],["empty",rQ]]);function v7(e){if(e==null)return null;let t=JJ.get(`${e}`.toLowerCase());if(t)return t;throw new Error(`invalid facet anchor: ${e}`)}var y7=new WeakMap;function DT(e){let t=y7.get(e);return t||y7.set(e,t=new Zn(Gt(e,(n,r)=>[n,r]))),t}function ic(e,t){return DT(e).get(t)}function QJ(e,t,n){return t=Qs(t),n=Qs(n),e.find(r=>Object.is(Qs(r.x),t)&&Object.is(Qs(r.y),n))}function Lw(e,t,n){return QJ(e,t,n)?.empty}function AT(e,{y:t},{y:n}){return t?ic(t,n)===0:!0}function TT(e,{y:t},{y:n}){return t?ic(t,n)===t.length-1:!0}function ET(e,{x:t},{x:n}){return t?ic(t,n)===0:!0}function NT(e,{x:t},{x:n}){return t?ic(t,n)===t.length-1:!0}function KJ(e,{y:t},{x:n,y:r,empty:i}){if(i)return!1;if(!t)return;let o=ic(t,r);if(o>0)return Lw(e,n,t[o-1])}function tQ(e,{y:t},{x:n,y:r,empty:i}){if(i)return!1;if(!t)return;let o=ic(t,r);if(o<t.length-1)return Lw(e,n,t[o+1])}function eQ(e,{x:t},{x:n,y:r,empty:i}){if(i)return!1;if(!t)return;let o=ic(t,n);if(o>0)return Lw(e,t[o-1],r)}function nQ(e,{x:t},{x:n,y:r,empty:i}){if(i)return!1;if(!t)return;let o=ic(t,n);if(o<t.length-1)return Lw(e,t[o+1],r)}function rQ(e,t,{empty:n}){return n}function Ow(e,t){return function(){return e.apply(null,arguments)&&t.apply(null,arguments)}}function Cw(e,{channels:{fx:t,fy:n},groups:r}){return t&&n?e.map(({x:i,y:o})=>r.get(i)?.get(o)??[]):t?e.map(({x:i})=>r.get(i)??[]):e.map(({y:i})=>r.get(i)??[])}var St=class{constructor(t,n={},r={},i){let{facet:o="auto",facetAnchor:s,fx:a,fy:c,sort:l,dx:u=0,dy:f=0,margin:d=0,marginTop:h=d,marginRight:p=d,marginBottom:m=d,marginLeft:g=d,clip:y=i?.clip,channels:x,tip:b,render:w}=r;if(this.data=t,this.sort=Co(l)?l:null,this.initializer=Ie(r).initializer,this.transform=this.initializer?r.transform:yn(r).transform,o===null||o===!1?this.facet=null:(this.facet=tn(o===!0?"include":o,"facet",["auto","include","exclude","super"]),this.fx=t===Wa&&typeof a=="string"?[a]:a,this.fy=t===Wa&&typeof c=="string"?[c]:c),this.facetAnchor=v7(s),n=Rm(n),x!==void 0&&(n={...iQ(x),...n}),i!==void 0&&(n={...vw(this,r,i),...n}),this.channels=Object.fromEntries(Object.entries(n).map(([v,_])=>{if(jr(_.value)){let{value:I,label:D=_.label,scale:A=_.scale}=_.value;_={..._,label:D,scale:A,value:I}}if(t===Wa&&typeof _.value=="string"){let{value:I}=_;_={..._,value:[I]}}return[v,_]}).filter(([v,{value:_,optional:I}])=>{if(_!=null)return!0;if(I)return!1;throw new Error(`missing channel value: ${v}`)})),this.dx=+u,this.dy=+f,this.marginTop=+h,this.marginRight=+p,this.marginBottom=+m,this.marginLeft=+g,this.clip=Sw(y),this.tip=oQ(b),this.facet==="super"){if(a||c)throw new Error("super-faceting cannot use fx or fy");for(let v in this.channels){let{scale:_}=n[v];if(!(_!=="x"&&_!=="y"))throw new Error("super-faceting cannot use x or y")}}w!=null&&(this.render=zf(w,this.render))}initialize(t,n,r){let i=je(this.data);t===void 0&&i!=null&&(t=[ar(i)]);let o=t;this.transform!=null&&({facets:t,data:i}=this.transform(i,t,r),i=je(i)),t!==void 0&&(t.original=o);let s=xw(this.channels,i);return this.sort!=null&&dR(i,t,s,n,this.sort),{data:i,facets:t,channels:s}}filter(t,n,r){for(let i in n){let{filter:o=ze}=n[i];if(o!==null){let s=r[i];t=t.filter(a=>o(s[a]))}}return t}project(t,n,r){for(let i in t)if(t[i].scale==="x"&&/^x|x$/.test(i)){let o=i.replace(/^x|x$/,"y");o in t&&t[o].scale==="y"&&mT(i,o,n,r.projection)}}scale(t,n,r){let i=Bf(t,n);return r.projection&&this.project(t,i,r),i}};function en(...e){return e.plot=St.prototype.plot,e}function zf(e,t){if(e==null)return t===null?void 0:t;if(t==null)return e===null?void 0:e;if(typeof e!="function")throw new TypeError(`invalid render transform: ${e}`);if(typeof t!="function")throw new TypeError(`invalid render transform: ${t}`);return function(n,r,i,o,s,a){return e.call(this,n,r,i,o,s,(c,l,u,f,d)=>t.call(this,c,l,u,f,d,a))}}function iQ(e){return Object.fromEntries(Object.entries(Rm(e)).map(([t,n])=>(n=typeof n=="string"?{value:n,label:t}:pi(n),n.filter===void 0&&n.scale==null&&(n={...n,filter:null}),[t,n])))}function oQ(e){return e===!0?"xy":e===!1||e==null?null:typeof e=="string"?tn(e,"tip",["x","y","xy"]):e}function Yi(e,t){return e?.tip===!0?{...e,tip:t}:pn(e?.tip)&&e.tip.pointer===void 0?{...e,tip:{...e.tip,pointer:t}}:e}var _7=new WeakMap;function OT(e,t,{x:n,y:r,px:i,py:o,maxRadius:s=40,channels:a,render:c,...l}={}){return s=+s,i!=null&&(n??=null,a={...a,px:{value:i,scale:"x"}}),o!=null&&(r??=null,a={...a,py:{value:o,scale:"y"}}),{x:n,y:r,channels:a,...l,render:zf(function(u,f,d,h,p,m){p={...p,pointerSticky:!1};let g=p.ownerSVGElement,{data:y}=p.getMarkState(this),x=_7.get(g);x||_7.set(g,x={sticky:!1,roots:[],renders:[]});let b=x.renders.push(W)-1,{x:w,y:v,fx:_,fy:I}=f,D=_?_(u.fx)-h.marginLeft:0,A=I?I(u.fy)-h.marginTop:0;w?.bandwidth&&(D+=w.bandwidth()/2),v?.bandwidth&&(A+=v.bandwidth()/2);let E=u.fi!=null,T;if(E){let Y=x.facetStates;Y||(x.facetStates=Y=new Map),T=Y.get(this),T||Y.set(this,T=new Map)}let[O,C]=gn(this,h),{px:S,py:M}=d,N=S?Y=>S[Y]:BT(d,O),F=M?Y=>M[Y]:LT(d,C),R,k,$,P;function U(Y,rt){if(E)if(P&&(P=cancelAnimationFrame(P)),Y==null)T.delete(u.fi);else{T.set(u.fi,rt),P=requestAnimationFrame(()=>{P=null;for(let[j,H]of T)if(H<rt||H===rt&&j<u.fi){Y=null;break}W(Y)});return}W(Y)}function W(Y){if(R===Y&&$===x.sticky)return;R=Y,$=p.pointerSticky=x.sticky;let rt=R==null?[]:[R];E&&(rt.fx=u.fx,rt.fy=u.fy,rt.fi=u.fi);let j=m(rt,f,d,h,p);if(k){if(E){let H=k.parentNode,ot=k.getAttribute("transform"),z=j.getAttribute("transform");ot?j.setAttribute("transform",ot):j.removeAttribute("transform"),z?H.setAttribute("transform",z):H.removeAttribute("transform"),j.removeAttribute("aria-label"),j.removeAttribute("aria-description"),j.removeAttribute("aria-hidden")}k.replaceWith(j)}return x.roots[b]=k=j,R==null&&T?.size>1||p.dispatchValue(R==null?null:y[R]),j}function tt(Y){if(x.sticky||Y.pointerType==="mouse"&&Y.buttons===1)return;let[rt,j]=kn(Y);rt-=D,j-=A;let H=rt<h.marginLeft||rt>h.width-h.marginRight?1:e,ot=j<h.marginTop||j>h.height-h.marginBottom?1:t,z=null,kt=s*s;for(let dt of u){let Ht=H*(N(dt)-rt),Zt=ot*(F(dt)-j),et=Ht*Ht+Zt*Zt;et<=kt&&(z=dt,kt=et)}if(z!=null&&(e!==1||t!==1)){let dt=N(z)-rt,Ht=F(z)-j;kt=dt*dt+Ht*Ht}U(z,kt)}function nt(Y){Y.pointerType==="mouse"&&R!=null&&(x.sticky&&x.roots.some(rt=>rt?.contains(Y.target))||(x.sticky?(x.sticky=!1,x.renders.forEach(rt=>rt(null))):(x.sticky=!0,W(R)),Y.stopImmediatePropagation()))}function at(Y){Y.pointerType==="mouse"&&(x.sticky||U(null))}return g.addEventListener("pointerenter",tt),g.addEventListener("pointermove",tt),g.addEventListener("pointerdown",nt),g.addEventListener("pointerleave",at),W(null)},c)}}function qf(e){return OT(1,1,e)}function jf(e){return OT(1,.01,e)}function El(e){return OT(.01,1,e)}function BT({x1:e,x2:t,x:n=e},r){return e&&t?i=>(e[i]+t[i])/2:n?i=>n[i]:()=>r}function LT({y1:e,y2:t,y:n=e},r){return e&&t?i=>(e[i]+t[i])/2:n?i=>n[i]:()=>r}function kw(e){return $o(e)&&e.interval===void 0?void 0:"tabular-nums"}function S7(e,t){let{label:n=e.label,tickSize:r=6,width:i=240,height:o=44+r,marginTop:s=18,marginRight:a=0,marginBottom:c=16+r,marginLeft:l=0,style:u,ticks:f=(i-l-a)/64,tickFormat:d,fontVariant:h=kw(e),round:p=!0,opacity:m,className:g}=t,y=nc(t);g=Lf(g),m=se(m)[1],d===null&&(d=()=>null);let x=ut("svg",y).attr("class",`${g}-ramp`).attr("font-family","system-ui, sans-serif").attr("font-size",10).attr("width",i).attr("height",o).attr("viewBox",`0 0 ${i} ${o}`).call(O=>O.append("style").text(`:where(.${g}-ramp) {
|
|
15
|
+
${n}`}function bJ(e){return e==="time"?sw:e==="utc"?jm:gJ}function YF(e,t,n){let r=Ht(nx(t,(i,o)=>Math.abs(o-i)));if(r<1e3)return qF("millisecond","utc",n);for(let[i,o,s,a]of bJ(e)){if(r>a||i==="hour"&&!r)break;if(t.every(c=>o.floor(c)>=c))return qF(i,s,n)}}function vf(e,t,n){return(r,i,o)=>{let s=e(r,i),a=t(r,i),c=i-Ws(o);return i!==c&&o[c]!==void 0&&a===t(o[c],c)?s:n(s,a)}}var Sl=Object.getPrototypeOf(Uint8Array),wJ=Object.prototype.toString,GA=Symbol("reindex");function wt(e,t,n){let r=typeof t;return r==="string"?XF(e,WA(t),n):r==="function"?XF(e,t,n):r==="number"||t instanceof Date||r==="boolean"?Gt(e,pn(t),n):typeof t?.transform=="function"?GF(t.transform(e),n):vJ(GF(t,n),e?.[GA])}function vJ(e,t){return t?Xm(e,t):e}function XF(e,t,n){return Gt(e,n?.prototype instanceof Sl?_J(t):t,n)}function GF(e,t){return t===void 0?je(e):e instanceof t?e:t.prototype instanceof Sl&&!(e instanceof Sl)?t.from(e,HA):t.from(e)}function _J(e){return(t,n)=>HA(e(t,n))}var Ga=[null],WA=e=>t=>t[e],Ee={transform:cr},G={transform:e=>e};var Ym=()=>1,WF=()=>!0,qe=e=>e==null?e:`${e}`,Bt=e=>e==null?e:+e;var Il=e=>e?e[0]:void 0,Wa=e=>e?e[1]:void 0,HF=e=>e?e[2]:void 0,pn=e=>()=>e;function If(e){let t=+`${e}`.slice(1)/100;return(n,r)=>Kn(n,t,r)}function Ke(e){return e instanceof Sl?e:Gt(e,HA,Float64Array)}function HA(e){return e==null?NaN:Number(e)}function ZF(e){return Gt(e,ZA)}function ZA(e){return e instanceof Date&&!isNaN(e)?e:typeof e=="string"?qm(e):e==null||isNaN(e=+e)?void 0:new Date(e)}function Be(e,t){return e===void 0&&(e=t),e===null?[void 0,"none"]:Ja(e)?[void 0,e]:[e,void 0]}function se(e,t){return e===void 0&&(e=t),e===null||typeof e=="number"?[void 0,e]:[e,void 0]}function JA(e,t,n){if(e!=null)return sn(e,t,n)}function sn(e,t,n){let r=`${e}`.toLowerCase();if(!n.includes(r))throw new Error(`invalid ${t}: ${e}`);return r}function je(e){return e==null||e instanceof Array||e instanceof Sl?e:Array.from(e)}function Gt(e,t,n=Array){return e==null?e:e instanceof n?e.map(t):n.from(e,t)}function Ha(e,t=Array){return e instanceof t?e.slice():t.from(e)}function QA({x:e,x1:t,x2:n}){return e!==void 0||t!==void 0||n!==void 0}function KA({y:e,y1:t,y2:n}){return e!==void 0||t!==void 0||n!==void 0}function Mf(e){return QA(e)||KA(e)||e.interval!==void 0}function mn(e){return e?.toString===wJ}function qo(e){return mn(e)&&(e.type!==void 0||e.domain!==void 0)}function jr(e){return mn(e)&&typeof e.transform!="function"}function jo(e){return jr(e)&&e.value===void 0&&e.channel===void 0}function tT(e,t,n,r=G){return t===void 0&&n===void 0?(t=0,n=e===void 0?r:e):t===void 0?t=e===void 0?0:e:n===void 0&&(n=e===void 0?0:e),[t,n]}function Pe(e,t){return e===void 0&&t===void 0?[Il,Wa]:[e,t]}function jn({z:e,fill:t,stroke:n}={}){return e===void 0&&([e]=Be(t)),e===void 0&&([e]=Be(n)),e}function cr(e){let t=e.length,n=new Uint32Array(t);for(let r=0;r<t;++r)n[r]=r;return n}function Xm(e,t){return Gt(t,n=>e[n],e.constructor)}function Af(e){return e.length===1?(t,n)=>e(Xm(n,t)):e}function Hs(e,t,n){return e.subarray?e.subarray(t,n):e.slice(t,n)}function Zs(e){return e!==null&&typeof e=="object"?e.valueOf():e}function lw(e,t){if(t[e]!==void 0)return t[e];switch(e){case"x1":case"x2":e="x";break;case"y1":case"y2":e="y";break}return t[e]}function yn(e){let t;return[{transform:()=>t,label:Bn(e)},n=>t=n]}function On(e){return e==null?[e]:yn(e)}function Bn(e,t){return typeof e=="string"?e:e&&e.label!==void 0?e.label:t}function Tf(e,t){return{transform(n){let r=e.transform(n),i=t.transform(n);return Le(r)||Le(i)?Gt(r,(o,s)=>new Date((+r[s]+ +i[s])/2)):Gt(r,(o,s)=>(+r[s]+ +i[s])/2,Float64Array)},label:e.label}}function Ml(e,t){let n=eT(t?.interval,t?.type);return n?Gt(e,n):e}function eT(e,t){let n=Ef(e,t);return n&&(r=>ze(r)?n.floor(r):r)}function Ef(e,t){if(e!=null){if(typeof e=="number"){0<e&&e<1&&Number.isInteger(1/e)&&(e=-1/e);let n=Math.abs(e);return e<0?{floor:r=>Math.floor(r*n)/n,offset:r=>(r*n+1)/n,range:(r,i)=>Ue(Math.ceil(r*n),i*n).map(o=>o/n)}:{floor:r=>Math.floor(r/n)*n,offset:r=>r+n,range:(r,i)=>Ue(Math.ceil(r/n),i/n).map(o=>o*n)}}if(typeof e=="string")return(t==="time"?YA:Vm)(e);if(typeof e.floor!="function")throw new Error("invalid interval; missing floor method");if(typeof e.offset!="function")throw new Error("invalid interval; missing offset method");return e}}function Vo(e,t){if(e=Ef(e,t),e&&typeof e.range!="function")throw new Error("invalid interval: missing range method");return e}function JF(e,t){if(e=Vo(e,t),e&&typeof e.ceil!="function")throw new Error("invalid interval: missing ceil method");return e}function QF(e){return Za(e)&&typeof e?.floor=="function"&&e.floor()instanceof Date}function Za(e){return typeof e?.range=="function"}function wi(e){return e===void 0||jr(e)?e:{value:e}}function KF(e){return e==null?null:{transform:t=>wt(t,e,Float64Array),label:Bn(e)}}function tR(e){if(!lr(e))return!1;for(let t of e)if(t!=null)return typeof t=="object"&&"0"in t&&"1"in t}function lr(e){return e&&typeof e[Symbol.iterator]=="function"}function uw(e){for(let t of e)if(t!=null)return typeof t!="object"||t instanceof Date}function Ne(e){for(let t of e){if(t==null)continue;let n=typeof t;return n==="string"||n==="boolean"}}function Le(e){for(let t of e)if(t!=null)return t instanceof Date}function eR(e){for(let t of e)if(t!=null)return typeof t=="string"&&isNaN(t)&&qm(t)}function nR(e){for(let t of e)if(t!=null){if(typeof t!="string")return!1;if(t.trim())return!isNaN(t)}}function Js(e){for(let t of e)if(t!=null)return typeof t=="number"}function fw(e,t){let n;for(let r of e)if(r!=null){if(!t(r))return!1;n=!0}return n}var SJ=new Set("none,currentcolor,transparent,aliceblue,antiquewhite,aqua,aquamarine,azure,beige,bisque,black,blanchedalmond,blue,blueviolet,brown,burlywood,cadetblue,chartreuse,chocolate,coral,cornflowerblue,cornsilk,crimson,cyan,darkblue,darkcyan,darkgoldenrod,darkgray,darkgreen,darkgrey,darkkhaki,darkmagenta,darkolivegreen,darkorange,darkorchid,darkred,darksalmon,darkseagreen,darkslateblue,darkslategray,darkslategrey,darkturquoise,darkviolet,deeppink,deepskyblue,dimgray,dimgrey,dodgerblue,firebrick,floralwhite,forestgreen,fuchsia,gainsboro,ghostwhite,gold,goldenrod,gray,green,greenyellow,grey,honeydew,hotpink,indianred,indigo,ivory,khaki,lavender,lavenderblush,lawngreen,lemonchiffon,lightblue,lightcoral,lightcyan,lightgoldenrodyellow,lightgray,lightgreen,lightgrey,lightpink,lightsalmon,lightseagreen,lightskyblue,lightslategray,lightslategrey,lightsteelblue,lightyellow,lime,limegreen,linen,magenta,maroon,mediumaquamarine,mediumblue,mediumorchid,mediumpurple,mediumseagreen,mediumslateblue,mediumspringgreen,mediumturquoise,mediumvioletred,midnightblue,mintcream,mistyrose,moccasin,navajowhite,navy,oldlace,olive,olivedrab,orange,orangered,orchid,palegoldenrod,palegreen,paleturquoise,palevioletred,papayawhip,peachpuff,peru,pink,plum,powderblue,purple,rebeccapurple,red,rosybrown,royalblue,saddlebrown,salmon,sandybrown,seagreen,seashell,sienna,silver,skyblue,slateblue,slategray,slategrey,snow,springgreen,steelblue,tan,teal,thistle,tomato,turquoise,violet,wheat,white,whitesmoke,yellow".split(","));function Ja(e){return typeof e!="string"?!1:(e=e.toLowerCase().trim(),/^#[0-9a-f]{3,8}$/.test(e)||/^(?:url|var|rgb|rgba|hsl|hsla|hwb|lab|lch|oklab|oklch|color|color-mix)\(.*\)$/.test(e)||SJ.has(e))}function rR(e){return typeof e=="number"&&(0<=e&&e<=1||isNaN(e))}function re(e){return e==null||Qs(e)}function Qs(e){return/^\s*none\s*$/i.test(e)}function iR(e){return/^\s*round\s*$/i.test(e)}function hw(e,t){return JA(e,t,["middle","top-left","top","top-right","right","bottom-right","bottom","bottom-left","left"])}function Yo(e="middle"){return hw(e,"frameAnchor")}function oR(e={},...t){let n=e;for(let r of t)for(let i in r)if(n[i]===void 0){let o=r[i];n===e?n={...n,[i]:o}:n[i]=o}return n}function IJ(e){console.warn("named iterables are deprecated; please use an object instead");let t=new Set;return Object.fromEntries(Array.from(e,n=>{let{name:r}=n;if(r==null)throw new Error("missing name");let i=`${r}`;if(i==="__proto__")throw new Error(`illegal name: ${i}`);if(t.has(i))throw new Error(`duplicate name: ${i}`);return t.add(i),[r,n]}))}function Gm(e){return lr(e)?IJ(e):e}function dw(e){return e===!0?e="frame":e===!1?e=null:e!=null&&(e=sn(e,"clip",["frame","sphere"])),e}var vi=Symbol("position"),Vr=Symbol("color"),Al=Symbol("radius"),Tl=Symbol("length"),El=Symbol("opacity"),Nf=Symbol("symbol"),sR=Symbol("projection"),he=new Map([["x",vi],["y",vi],["fx",vi],["fy",vi],["r",Al],["color",Vr],["opacity",El],["symbol",Nf],["length",Tl],["projection",sR]]);function aR(e){return e===vi||e===sR}function cR(e){return e===vi||e===Al||e===Tl||e===El}var nT=Math.sqrt(3),rT=2/nT,MJ={draw(e,t){let n=Math.sqrt(t/Math.PI),r=n*rT,i=r/2;e.moveTo(0,r),e.lineTo(n,i),e.lineTo(n,-i),e.lineTo(0,-r),e.lineTo(-n,-i),e.lineTo(-n,i),e.closePath()}},iT=new Map([["asterisk",Am],["circle",Xs],["cross",Tm],["diamond",Em],["diamond2",Nm],["hexagon",MJ],["plus",Dm],["square",Om],["square2",Bm],["star",Lm],["times",mf],["triangle",Cm],["triangle2",km],["wye",Fm]]);function oT(e){return e&&typeof e.draw=="function"}function lR(e){return oT(e)?!0:typeof e!="string"?!1:iT.has(e.toLowerCase())}function Df(e){if(e==null||oT(e))return e;let t=iT.get(`${e}`.toLowerCase());if(t)return t;throw new Error(`invalid symbol: ${e}`)}function uR(e){if(e==null||oT(e))return[void 0,e];if(typeof e=="string"){let t=iT.get(`${e}`.toLowerCase());if(t)return[void 0,t]}return[e,void 0]}function gn({filter:e,sort:t,reverse:n,transform:r,initializer:i,...o}={},s){if(r===void 0&&(e!=null&&(r=cT(e)),t!=null&&!jo(t)&&(r=sT(r,uT(t))),n&&(r=sT(r,lT))),s!=null&&i!=null)throw new Error("transforms cannot be applied after initializers");return{...o,...(t===null||jo(t))&&{sort:t},transform:sT(r,s)}}function Ie({filter:e,sort:t,reverse:n,initializer:r,...i}={},o){return r===void 0&&(e!=null&&(r=cT(e)),t!=null&&!jo(t)&&(r=aT(r,uT(t))),n&&(r=aT(r,lT))),{...i,...(t===null||jo(t))&&{sort:t},initializer:aT(r,o)}}function sT(e,t){return e==null?t===null?void 0:t:t==null?e===null?void 0:e:function(n,r,i){return{data:n,facets:r}=e.call(this,n,r,i),t.call(this,je(n),r,i)}}function aT(e,t){return e==null?t===null?void 0:t:t==null?e===null?void 0:e:function(n,r,i,...o){let s,a,c,l,u,f;return{data:a=n,facets:c=r,channels:s}=e.call(this,n,r,i,...o),{data:u=a,facets:f=c,channels:l}=t.call(this,a,c,{...i,...s},...o),{data:u,facets:f,channels:{...s,...l}}}}function pw(e,t){return(e.initializer!=null?Ie:gn)(e,t)}function fR(e,t){return pw(t,cT(e))}function cT(e){return(t,n)=>{let r=wt(t,e);return{data:t,facets:n.map(i=>i.filter(o=>r[o]))}}}function hR({sort:e,...t}={}){return{...pw(t,lT),sort:jo(e)?e:null}}function lT(e,t){return{data:e,facets:t.map(n=>n.slice().reverse())}}function dR({seed:e,sort:t,...n}={}){return{...pw(n,pR(e==null?Math.random:fl(e))),sort:jo(t)?t:null}}function mw(e,{sort:t,...n}={}){return{...(jr(e)&&e.channel!==void 0?Ie:pw)(n,uT(e)),sort:jo(t)?t:null}}function uT(e){return(typeof e=="function"&&e.length!==1?AJ:pR)(e)}function AJ(e){return(t,n)=>{let r=(i,o)=>e(t[i],t[o]);return{data:t,facets:n.map(i=>i.slice().sort(r))}}}function pR(e){let t,n;({channel:t,value:e,order:n}={...wi(e)});let r=t?.startsWith("-");if(r&&(t=t.slice(1)),n===void 0&&(n=r?vl:dn),typeof n!="function")switch(`${n}`.toLowerCase()){case"ascending":n=dn;break;case"descending":n=vl;break;default:throw new Error(`invalid order: ${n}`)}return(i,o,s)=>{let a;if(t===void 0)a=wt(i,e);else{if(s===void 0)throw new Error("channel sort requires an initializer");if(a=s[t],!a)return{};a=a.value}let c=(l,u)=>n(a[l],a[u]);return{data:i,facets:o.map(l=>l.slice().sort(c))}}}function Hm(e,t){return yw(null,null,e,t)}function Ka(e={y:"count"},t={}){let{x:n=G}=t;if(n==null)throw new Error("missing channel: x");return yw(n,null,e,t)}function tc(e={x:"count"},t={}){let{y:n=G}=t;if(n==null)throw new Error("missing channel: y");return yw(null,n,e,t)}function Zm(e={fill:"count"},t={}){let{x:n,y:r}=t;if([n,r]=Pe(n,r),n==null)throw new Error("missing channel: x");if(r==null)throw new Error("missing channel: y");return yw(n,r,e,t)}function yw(e,t,{data:n=bw,filter:r,sort:i,reverse:o,...s}={},a={}){s=hT(s,a),n=bR(n,G),i=i==null?void 0:gR("sort",i,a),r=r==null?void 0:xR("filter",r,a);let[c,l]=On(e),[u,f]=On(t),{z:h,fill:d,stroke:p,x1:m,x2:y,y1:g,y2:x,...b}=a,[w,_]=On(h),[v]=Be(d),[M]=Be(p),[E,I]=On(v),[D,A]=On(M);return{..."z"in a&&{z:w||h},..."fill"in a&&{fill:E||d},..."stroke"in a&&{stroke:D||p},...gn(b,(O,C,S)=>{let T=Ml(wt(O,e),S?.x),N=Ml(wt(O,t),S?.y),F=wt(O,h),R=wt(O,v),k=wt(O,M),$=Jm(s,{z:F,fill:R,stroke:k}),P=[],U=[],W=T&&l([]),nt=N&&f([]),ot=F&&_([]),at=R&&I([]),Y=k&&A([]),st=0;for(let j of s)j.initialize(O);i&&i.initialize(O),r&&r.initialize(O);for(let j of C){let Z=[];for(let rt of s)rt.scope("facet",j);i&&i.scope("facet",j),r&&r.scope("facet",j);for(let[rt,z]of Qa(j,$))for(let[kt,ht]of Qa(z,N))for(let[Wt,Zt]of Qa(ht,T)){let tt={data:O};if(T&&(tt.x=Wt),N&&(tt.y=kt),$&&(tt.z=rt),!(r&&!r.reduce(Zt,tt))){Z.push(st++),U.push(n.reduceIndex(Zt,O,tt)),T&&W.push(Wt),N&&nt.push(kt),F&&ot.push($===F?rt:F[Zt[0]]),R&&at.push($===R?rt:R[Zt[0]]),k&&Y.push($===k?rt:k[Zt[0]]);for(let ae of s)ae.reduce(Zt,tt);i&&i.reduce(Zt,tt)}}P.push(Z)}return dT(P,i,o),{data:U,facets:P}}),...!Xo(s,"x")&&(c?{x:c}:{x1:m,x2:y}),...!Xo(s,"y")&&(u?{y:u}:{y1:g,y2:x}),...Object.fromEntries(s.map(({name:O,output:C})=>[O,C]))}}function Xo(e,...t){for(let{name:n}of e)if(t.includes(n))return!0;return!1}function fT(e,t,n=gw){let r=Object.entries(e);return t.title!=null&&e.title===void 0&&r.push(["title",BJ]),t.href!=null&&e.href===void 0&&r.push(["href",ww]),r.filter(([,i])=>i!==void 0).map(([i,o])=>o===null?TJ(i):n(i,o,t))}function gw(e,t,n,r=xw){let i;mn(t)&&"reduce"in t&&(i=t.scale,t=t.reduce);let o=r(e,t,n),[s,a]=yn(o.label),c;return{name:e,output:i===void 0?s:{value:s,scale:i},initialize(l){o.initialize(l),c=a([])},scope(l,u){o.scope(l,u)},reduce(l,u){c.push(o.reduce(l,u))}}}function TJ(e){return{name:e,initialize(){},scope(){},reduce(){}}}function xw(e,t,n,r=Of){let i=lw(e,n),o=r(t,i),s,a;return{label:Bn(o===Wm?null:i,o.label),initialize(c){s=i===void 0?c:wt(c,i),o.scope==="data"&&(a=o.reduceIndex(cr(c),s))},scope(c,l){o.scope===c&&(a=o.reduceIndex(l,s))},reduce(c,l){return o.scope==null?o.reduceIndex(c,s,l):o.reduceIndex(c,s,a,l)}}}function Qa(e,t){return t?ln(e,n=>t[n]):[[,e]]}function Of(e,t,n=EJ){if(e==null)return n(e);if(typeof e.reduceIndex=="function")return e;if(typeof e.reduce=="function"&&mn(e))return DJ(e);if(typeof e=="function")return OJ(e);if(/^p\d{2}$/i.test(e))return Ks(If(e));switch(`${e}`.toLowerCase()){case"first":return ww;case"last":return LJ;case"identity":return bw;case"count":return Wm;case"distinct":return CJ;case"sum":return t==null?Wm:kJ;case"proportion":return yR(t,"data");case"proportion-facet":return yR(t,"facet");case"deviation":return Ks(li);case"min":return Ks(ue);case"min-index":return Ks(K0);case"max":return Ks(Ht);case"max-index":return Ks(Q0);case"mean":return mR(Es);case"median":return mR(Ui);case"variance":return Ks(Ta);case"mode":return Ks(Bu)}return n(e)}function EJ(e){throw new Error(`invalid reduce: ${e}`)}function hT(e,t){return fT(e,t,gR)}function gR(e,t,n){return gw(e,t,n,xR)}function xR(e,t,n){return xw(e,t,n,bR)}function bR(e,t){return Of(e,t,NJ)}function NJ(e){switch(`${e}`.toLowerCase()){case"x":return FJ;case"y":return RJ;case"z":return pT}throw new Error(`invalid group reduce: ${e}`)}function Jm(e,t){for(let n in t){let r=t[n];if(r!==void 0&&!e.some(i=>i.name===n))return r}}function dT(e,t,n){if(t){let r=t.output.transform(),i=(o,s)=>dn(r[o],r[s]);e.forEach(o=>o.sort(i))}n&&e.forEach(r=>r.reverse())}function DJ(e){return console.warn("deprecated reduce interface; implement reduceIndex instead."),{...e,reduceIndex:e.reduce.bind(e)}}function OJ(e){return{reduceIndex(t,n,r){return e(Xm(n,t),r)}}}function Ks(e){return{reduceIndex(t,n){return e(t,r=>n[r])}}}function mR(e){return{reduceIndex(t,n){let r=e(t,i=>n[i]);return Le(n)?new Date(r):r}}}var bw={reduceIndex(e,t){return Xm(t,e)}},ww={reduceIndex(e,t){return t[e[0]]}},BJ={reduceIndex(e,t){let r=As(Pi(e,o=>o.length,o=>t[o]),Wa),i=r.slice(-5).reverse();if(i.length<r.length){let o=r.slice(0,-4);i[4]=[`\u2026 ${o.length.toLocaleString("en-US")} more`,Tn(o,Wa)]}return i.map(([o,s])=>`${o} (${s.toLocaleString("en-US")})`).join(`
|
|
16
|
+
`)}},LJ={reduceIndex(e,t){return t[e[e.length-1]]}},Wm={label:"Frequency",reduceIndex(e){return e.length}},CJ={label:"Distinct",reduceIndex(e,t){let n=new Qn;for(let r of e)n.add(t[r]);return n.size}},kJ=Ks(Tn);function yR(e,t){return e==null?{scope:t,label:"Frequency",reduceIndex:(n,r,i=1)=>n.length/i}:{scope:t,reduceIndex:(n,r,i=1)=>Tn(n,o=>r[o])/i}}var FJ={reduceIndex(e,t,{x:n}){return n}},RJ={reduceIndex(e,t,{y:n}){return n}},pT={reduceIndex(e,t,{z:n}){return n}};function wR(e){if(typeof e!="function")throw new Error(`invalid test function: ${e}`);return{reduceIndex(t,n,{data:r}){return n[t.find(i=>e(r[i],i,r))]}}}function Bf(e,{scale:t,type:n,value:r,filter:i,hint:o,label:s=Bn(r)},a){return o===void 0&&typeof r?.transform=="function"&&(o=r.hint),yT(a,{scale:t,type:n,value:wt(e,r),label:s,filter:i,hint:o})}function vw(e,t){return Object.fromEntries(Object.entries(e).map(([n,r])=>[n,Bf(t,r,n)]))}function Lf(e,t){let n=Object.fromEntries(Object.entries(e).map(([r,{scale:i,value:o}])=>{let s=i==null?null:t[i];return[r,s==null?o:Gt(o,s)]}));return n.channels=e,n}function yT(e,t){let{scale:n,value:r}=t;if(n===!0||n==="auto")switch(e){case"fill":case"stroke":case"color":t.scale=n!==!0&&fw(r,Ja)?null:"color";break;case"fillOpacity":case"strokeOpacity":case"opacity":t.scale=n!==!0&&fw(r,rR)?null:"opacity";break;case"symbol":n!==!0&&fw(r,lR)?(t.scale=null,t.value=Gt(r,Df)):t.scale="symbol";break;default:t.scale=he.has(e)?e:null;break}else if(n===!1)t.scale=null;else if(n!=null&&!he.has(n))throw new Error(`unknown scale: ${n}`);return t}function _R(e,t,n,r,i){let{order:o,reverse:s,reduce:a=!0,limit:c}=i;for(let l in i){if(!he.has(l))continue;let{value:u,order:f=o,reverse:h=s,reduce:d=a,limit:p=c}=wi(i[l]),m=u?.startsWith("-");if(m&&(u=u.slice(1)),f=f===void 0?m!==(u==="width"||u==="height")?IR:SR:UJ(f),d==null||d===!1)continue;let y=l==="fx"||l==="fy"?PJ(t,r[l]):$J(n,l);if(!y)throw new Error(`missing channel for scale: ${l}`);let g=y.value,[x=0,b=1/0]=lr(p)?p:p<0?[p]:[0,p];if(u==null)y.domain=()=>{let w=Array.from(new Qn(g));return h&&(w=w.reverse()),(x!==0||b!==1/0)&&(w=w.slice(x,b)),w};else{let w=u==="data"?e:u==="height"?vR(n,"y1","y2"):u==="width"?vR(n,"x1","x2"):mT(n,u,u==="y"?"y2":u==="x"?"x2":void 0),_=Of(d===!0?"max":d,w);y.domain=()=>{let v=jS(cr(g),M=>_.reduceIndex(M,w),M=>g[M]);return f&&v.sort(f),h&&v.reverse(),(x!==0||b!==1/0)&&(v=v.slice(x,b)),v.map(Il)}}}}function $J(e,t){for(let n in e){let r=e[n];if(r.scale===t)return r}}function PJ(e,t){let n=e.original;if(n===e)return t;let r=t.value,i=t.value=[];for(let o=0;o<n.length;++o){let s=r[n[o][0]];for(let a of e[o])i[a]=s}return t}function vR(e,t,n){let r=mT(e,t),i=mT(e,n);return Gt(i,(o,s)=>Math.abs(o-r[s]),Float64Array)}function mT(e,t,n){let r=e[t];if(!r&&n!==void 0&&(r=e[n]),r)return r.value;throw new Error(`missing channel: ${t}`)}function UJ(e){if(e==null||typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"ascending":return SR;case"descending":return IR}throw new Error(`invalid order: ${e}`)}function SR([e,t],[n,r]){return dn(t,r)||dn(e,n)}function IR([e,t],[n,r]){return vl(t,r)||dn(e,n)}function Qm(e,t){let n=e[t];if(n){for(;n.source;)n=n.source;return n.source===null?null:n}}function ec(e={}){let{document:t=typeof window<"u"?window.document:void 0,clip:n}=e;return{document:t,clip:dw(n)}}function ut(e,{document:t}){return Vt(Ds(e).call(t.documentElement))}var gT=0,xT;function MR(){let e=gT;return gT=0,xT=void 0,e}function Vn(e){e!==xT&&(xT=e,console.warn(e),++gT)}var TR=Math.PI,ta=2*TR,AR=.618;function ER({projection:e,inset:t=0,insetTop:n=t,insetRight:r=t,insetBottom:i=t,insetLeft:o=t}={},s){if(e==null)return;if(typeof e.stream=="function")return e;let a,c,l="frame";if(mn(e)){let _;if({type:e,domain:c,inset:_,insetTop:n=_!==void 0?_:n,insetRight:r=_!==void 0?_:r,insetBottom:i=_!==void 0?_:i,insetLeft:o=_!==void 0?_:o,clip:l=l,...a}=e,e==null)return}typeof e!="function"&&({type:e}=NR(e));let{width:u,height:f,marginLeft:h,marginRight:d,marginTop:p,marginBottom:m}=s,y=u-h-d-o-r,g=f-p-m-n-i;if(e=e?.({width:y,height:g,clip:l,...a}),e==null)return;l=zJ(l,h,p,u-d,f-m);let x=h+o,b=p+n,w;if(c!=null){let[[_,v],[M,E]]=Nn(e).bounds(c),I=Math.min(y/(M-_),g/(E-v));I>0?(x-=(I*(_+M)-y)/2,b-=(I*(v+E)-g)/2,w=ll({point(D,A){this.stream.point(D*I+x,A*I+b)}})):Vn("Warning: the projection could not be fit to the specified domain; using the default scale.")}return w??=x===0&&b===0?DR():ll({point(_,v){this.stream.point(_+x,v+b)}}),{stream:_=>e.stream(w.stream(l(_)))}}function NR(e){switch(`${e}`.toLowerCase()){case"albers-usa":return Vi(mM,.7463,.4673);case"albers":return _w(Kp,.7463,.4673);case"azimuthal-equal-area":return Vi(gM,4,4);case"azimuthal-equidistant":return Vi(bM,ta,ta);case"conic-conformal":return _w(_M,ta,ta);case"conic-equal-area":return _w($a,6.1702,2.9781);case"conic-equidistant":return _w(IM,7.312,3.6282);case"equal-earth":return Vi(AM,5.4133,2.6347);case"equirectangular":return Vi(SM,ta,TR);case"gnomonic":return Vi(EM,3.4641,3.4641);case"identity":return{type:DR};case"reflect-y":return{type:qJ};case"mercator":return Vi(wM,ta,ta);case"orthographic":return Vi(DM,2,2);case"stereographic":return Vi(BM,2,2);case"transverse-mercator":return Vi(CM,ta,ta);default:throw new Error(`unknown projection type: ${e}`)}}function zJ(e,t,n,r,i){if(e===!1||e==null||typeof e=="number")return o=>o;switch(e===!0&&(e="frame"),`${e}`.toLowerCase()){case"frame":return Ju(t,n,r,i);default:throw new Error(`unknown projection clip type: ${e}`)}}function Vi(e,t,n){return{type:({width:r,height:i,rotate:o,precision:s=.15,clip:a})=>{let c=e();return s!=null&&c.precision?.(s),o!=null&&c.rotate?.(o),typeof a=="number"&&c.clipAngle?.(a),c.scale(Math.min(r/t,i/n)),c.translate([r/2,i/2]),c},aspectRatio:n/t}}function _w(e,t,n){let{type:r,aspectRatio:i}=Vi(e,t,n);return{type:o=>{let{parallels:s,domain:a,width:c,height:l}=o,u=r(o);return s!=null&&(u.parallels(s),a===void 0&&u.fitSize([c,l],{type:"Sphere"})),u},aspectRatio:i}}var DR=pn({stream:e=>e}),qJ=pn(ll({point(e,t){this.stream.point(e,-t)}}));function bT(e,t,n,r){let i=n[e],o=n[t],s=i.length,a=n[e]=new Float64Array(s).fill(NaN),c=n[t]=new Float64Array(s).fill(NaN),l,u=r.stream({point(f,h){a[l]=f,c[l]=h}});for(l=0;l<s;++l)u.point(i[l],o[l])}function OR({projection:e}={}){return e==null?!1:typeof e.stream=="function"?!0:(mn(e)&&(e=e.type),e!=null)}function BR(e){if(typeof e?.stream=="function")return AR;if(mn(e)&&(e=e.type),e!=null){if(typeof e!="function"){let{aspectRatio:t}=NR(e);if(t)return t}return AR}}function nc(e,t,{projection:n}){let{x:r,y:i}=e,o={};return r&&(o.x=r),i&&(o.y=i),o=Lf(o,t),n&&r?.scale==="x"&&i?.scale==="y"&&bT("x","y",o,n),r&&(o.x=Ke(o.x)),i&&(o.y=Ke(o.y)),o}function LR(e){let t=[],n=[],r={scale:"x",value:t},i={scale:"y",value:n},o={point(s,a){t.push(s),n.push(a)},lineStart(){},lineEnd(){},polygonStart(){},polygonEnd(){},sphere(){}};for(let s of e.value)Pr(s,o);return[r,i]}var $R=new Map([["accent",iA],["category10",rA],["dark2",oA],["observable10",sA],["paired",aA],["pastel1",cA],["pastel2",lA],["set1",uA],["set2",fA],["set3",hA],["tableau10",dA]]);function PR(e){return e!=null&&$R.has(`${e}`.toLowerCase())}var CR=new Map([...$R,["brbg",ea($b,Pb)],["prgn",ea(Ub,zb)],["piyg",ea(qb,jb)],["puor",ea(Vb,Yb)],["rdbu",ea(_m,uf)],["rdgy",ea(Xb,Gb)],["rdylbu",ea(Sm,ff)],["rdylgn",ea(Wb,Hb)],["spectral",ea(Zb,Jb)],["burd",kR(_m,uf)],["buylrd",kR(Sm,ff)],["blues",xn(_1,S1)],["greens",xn(I1,M1)],["greys",xn(A1,T1)],["oranges",xn(B1,L1)],["purples",xn(E1,N1)],["reds",xn(D1,O1)],["turbo",na(q1)],["viridis",na(V1)],["magma",na(Y1)],["inferno",na(X1)],["plasma",na(G1)],["cividis",na(C1)],["cubehelix",na(k1)],["warm",na(R1)],["cool",na($1)],["bugn",xn(Qb,Kb)],["bupu",xn(t1,e1)],["gnbu",xn(n1,r1)],["orrd",xn(i1,o1)],["pubu",xn(c1,l1)],["pubugn",xn(s1,a1)],["purd",xn(u1,f1)],["rdpu",xn(h1,d1)],["ylgn",xn(y1,g1)],["ylgnbu",xn(p1,m1)],["ylorbr",xn(x1,b1)],["ylorrd",xn(w1,v1)],["rainbow",FR(P1)],["sinebow",FR(z1)]]);function xn(e,t){return({length:n})=>n===1?[e[3][1]]:n===2?[e[3][1],e[3][2]]:(n=Math.max(3,Math.floor(n)),n>9?Rn(t,n):e[n])}function ea(e,t){return({length:n})=>n===2?[e[3][0],e[3][2]]:(n=Math.max(3,Math.floor(n)),n>11?Rn(t,n):e[n])}function kR(e,t){return({length:n})=>n===2?[e[3][2],e[3][0]]:(n=Math.max(3,Math.floor(n)),n>11?Rn(r=>t(1-r),n):e[n].slice().reverse())}function na(e){return({length:t})=>Rn(e,Math.max(2,Math.floor(t)))}function FR(e){return({length:t})=>Rn(e,Math.floor(t)+1).slice(0,-1)}function wT(e){let t=`${e}`.toLowerCase();if(!CR.has(t))throw new Error(`unknown ordinal scheme: ${t}`);return CR.get(t)}function Km(e,t){let n=wT(e),r=typeof n=="function"?n({length:t}):n;return r.length!==t?r.slice(0,t):r}function UR(e,t="greys"){let n=new Set,[r,i]=Km(t,2);for(let o of e)if(o!=null)if(o===!0)n.add(i);else if(o===!1)n.add(r);else return;return[...n]}var RR=new Map([["brbg",Pb],["prgn",zb],["piyg",jb],["puor",Yb],["rdbu",uf],["rdgy",Gb],["rdylbu",ff],["rdylgn",Hb],["spectral",Jb],["burd",e=>uf(1-e)],["buylrd",e=>ff(1-e)],["blues",S1],["greens",M1],["greys",T1],["purples",N1],["reds",O1],["oranges",L1],["turbo",q1],["viridis",V1],["magma",Y1],["inferno",X1],["plasma",G1],["cividis",C1],["cubehelix",k1],["warm",R1],["cool",$1],["bugn",Kb],["bupu",e1],["gnbu",r1],["orrd",o1],["pubugn",a1],["pubu",l1],["purd",f1],["rdpu",d1],["ylgnbu",m1],["ylgn",g1],["ylorbr",b1],["ylorrd",v1],["rainbow",P1],["sinebow",z1]]);function Cf(e){let t=`${e}`.toLowerCase();if(!RR.has(t))throw new Error(`unknown quantitative scheme: ${t}`);return RR.get(t)}var jJ=new Set(["brbg","prgn","piyg","puor","rdbu","rdgy","rdylbu","rdylgn","spectral","burd","buylrd"]);function zR(e){return e!=null&&jJ.has(`${e}`.toLowerCase())}var _T=e=>t=>e(1-t),vT=[0,1],qR=new Map([["number",_e],["rgb",fi],["hsl",mI],["hcl",yI],["lab",vx]]);function ST(e){let t=`${e}`.toLowerCase();if(!qR.has(t))throw new Error(`unknown interpolator: ${t}`);return qR.get(t)}function Ff(e,t,n,{type:r,nice:i,clamp:o,zero:s,domain:a=ZR(e,n),unknown:c,round:l,scheme:u,interval:f,range:h=he.get(e)===Al?GJ(n,a):he.get(e)===Tl?WJ(n,a):he.get(e)===El?vT:void 0,interpolate:d=he.get(e)===Vr?u==null&&h!==void 0?fi:Cf(u!==void 0?u:r==="cyclical"?"rainbow":"turbo"):l?tl:_e,reverse:p}){if(f=Vo(f,r),(r==="cyclical"||r==="sequential")&&(r="linear"),typeof d!="function"&&(d=ST(d)),p=!!p,h!==void 0){let m=(a=je(a)).length,y=(h=je(h)).length;if(m!==y){if(d.length===1)throw new Error("invalid piecewise interpolator");d=Ao(d,h),h=void 0}}if(d.length===1?(p&&(d=_T(d),p=!1),h===void 0&&(h=Float64Array.from(a,(m,y)=>y/(a.length-1)),h.length===2&&(h=vT)),t.interpolate((h===vT?pn:ty)(d))):t.interpolate(d),s){let[m,y]=le(a);(m>0||y<0)&&(a=Ha(a),Ws(a)!==Math.sign(m)?a[a.length-1]=0:a[0]=0)}return p&&(a=Na(a)),t.domain(a).unknown(c),i&&(t.nice(VJ(i,r)),a=t.domain()),h!==void 0&&t.range(h),o&&t.clamp(o),{type:r,domain:a,range:h,scale:t,interpolate:d,interval:f}}function VJ(e,t){return e===!0?void 0:typeof e=="number"?e:JF(e,t)}function jR(e,t,n){return Ff(e,$s(),t,n)}function VR(e,t,n){return IT(e,t,{...n,exponent:.5})}function IT(e,t,{exponent:n=1,...r}){return Ff(e,fm().exponent(n),t,{...r,type:"pow"})}function YR(e,t,{base:n=10,domain:r=HJ(t),...i}){return Ff(e,lm().base(n),t,{...i,domain:r})}function XR(e,t,{constant:n=1,...r}){return Ff(e,um().constant(n),t,r)}function GR(e,t,{range:n,quantiles:r=n===void 0?5:(n=[...n]).length,n:i=r,scheme:o="rdylbu",domain:s=ZJ(t),unknown:a,interpolate:c,reverse:l}){return n===void 0&&(n=c!==void 0?Rn(c,i):he.get(e)===Vr?Km(o,i):void 0),s.length>0&&(s=hm(s,n===void 0?{length:i}:n).quantiles()),Sw(e,t,{domain:s,range:n,reverse:l,unknown:a})}function WR(e,t,{range:n,n:r=n===void 0?5:(n=[...n]).length,scheme:i="rdylbu",domain:o=ZR(e,t),unknown:s,interpolate:a,reverse:c}){let[l,u]=le(o),f;return n===void 0?(f=An(l,u,r),f[0]<=l&&f.splice(0,1),f[f.length-1]>=u&&f.pop(),r=f.length+1,n=a!==void 0?Rn(a,r):he.get(e)===Vr?Km(i,r):void 0):(f=Rn(_e(l,u),r+1).slice(1,-1),l instanceof Date&&(f=f.map(h=>new Date(h)))),Ws(je(o))<0&&f.reverse(),Sw(e,t,{domain:f,range:n,reverse:c,unknown:s})}function Sw(e,t,{domain:n=[0],unknown:r,scheme:i="rdylbu",interpolate:o,range:s=o!==void 0?Rn(o,n.length+1):he.get(e)===Vr?Km(i,n.length+1):void 0,reverse:a}){n=je(n);let c=Ws(n);if(!isNaN(c)&&!YJ(n,c))throw new Error(`the ${e} scale has a non-monotonic domain`);return a&&(s=Na(s)),{type:"threshold",scale:dm(c<0?Na(n):n,s===void 0?[]:s).unknown(r),domain:n,range:s}}function YJ(e,t){for(let n=1,r=e.length,i=e[0];n<r;++n){let o=Zn(i,i=e[n]);if(o!==0&&o!==t)return!1}return!0}function HR(e){return{type:"identity",scale:cR(he.get(e))?am():t=>t}}function kf(e,t=bf){return e.length?[ue(e,({value:n})=>n===void 0?n:ue(n,t)),Ht(e,({value:n})=>n===void 0?n:Ht(n,t))]:[0,1]}function ZR(e,t){let n=he.get(e);return(n===Al||n===El||n===Tl?XJ:kf)(t)}function XJ(e){return[0,e.length?Ht(e,({value:t})=>t===void 0?t:Ht(t,bf)):1]}function GJ(e,t){let n=e.find(({radius:s})=>s!==void 0);if(n!==void 0)return[0,n.radius];let r=Kn(e,.5,({value:s})=>s===void 0?NaN:Kn(s,.25,ar)),i=t.map(s=>3*Math.sqrt(s/r)),o=30/Ht(i);return o<1?i.map(s=>s*o):i}function WJ(e,t){let n=Ui(e,({value:o})=>o===void 0?NaN:Ui(o,Math.abs)),r=t.map(o=>12*o/n),i=60/Ht(r);return i<1?r.map(o=>o*i):r}function HJ(e){for(let{value:t}of e)if(t!==void 0)for(let n of t){if(n>0)return kf(e,ar);if(n<0)return kf(e,ja)}return[1,10]}function ZJ(e){let t=[];for(let{value:n}of e)if(n!==void 0)for(let r of n)t.push(r);return t}function ty(e){return(t,n)=>r=>e(t+r*(n-t))}function Iw(e,t,n,r,{type:i,nice:o,clamp:s,domain:a=kf(r),unknown:c,pivot:l=0,scheme:u,range:f,symmetric:h=!0,interpolate:d=he.get(e)===Vr?u==null&&f!==void 0?fi:Cf(u!==void 0?u:"rdbu"):_e,reverse:p}){l=+l,a=je(a);let[m,y]=a;if(a.length>2&&Vn(`Warning: the diverging ${e} scale domain contains extra elements.`),Zn(m,y)<0&&([m,y]=[y,m],p=!p),m=Math.min(m,l),y=Math.max(y,l),typeof d!="function"&&(d=ST(d)),f!==void 0&&(d=d.length===1?ty(d)(...f):Ao(d,f)),p&&(d=_T(d)),h){let g=n.apply(l),x=g-n.apply(m),b=n.apply(y)-g;x<b?m=n.invert(g-b):x>b&&(y=n.invert(g+x))}return t.domain([m,l,y]).unknown(c).interpolator(d),s&&t.clamp(s),o&&t.nice(o),{type:i,domain:[m,y],pivot:l,interpolate:d,scale:t}}function JR(e,t,n){return Iw(e,vm(),JJ,t,n)}function QR(e,t,n){return MT(e,t,{...n,exponent:.5})}function MT(e,t,{exponent:n=1,...r}){return Iw(e,Rb().exponent(n=+n),tQ(n),t,{...r,type:"diverging-pow"})}function KR(e,t,{base:n=10,pivot:r=1,domain:i=kf(t,r<0?ja:ar),...o}){return Iw(e,kb().base(n=+n),QJ,t,{domain:i,pivot:r,...o})}function t7(e,t,{constant:n=1,...r}){return Iw(e,Fb().constant(n=+n),eQ(n),t,r)}var JJ={apply(e){return e},invert(e){return e}},QJ={apply:Math.log,invert:Math.exp},KJ={apply(e){return Math.sign(e)*Math.sqrt(Math.abs(e))},invert(e){return Math.sign(e)*(e*e)}};function tQ(e){return e===.5?KJ:{apply(t){return Math.sign(t)*Math.pow(Math.abs(t),e)},invert(t){return Math.sign(t)*Math.pow(Math.abs(t),1/e)}}}function eQ(e){return{apply(t){return Math.sign(t)*Math.log1p(Math.abs(t/e))},invert(t){return Math.sign(t)*Math.expm1(Math.abs(t))*e}}}function e7(e,t,n,r){return Ff(e,t,n,r)}function n7(e,t,n){return e7(e,Bb(),t,n)}function r7(e,t,n){return e7(e,Lb(),t,n)}var Rf=Symbol("ordinal");function o7(e,t,n,{type:r,interval:i,domain:o,range:s,reverse:a,hint:c}){return i=Vo(i,r),o===void 0&&(o=u7(n,i,e)),(r==="categorical"||r===Rf)&&(r="ordinal"),a&&(o=Na(o)),o=t.domain(o).domain(),s!==void 0&&(typeof s=="function"&&(s=s(o)),t.range(s)),{type:r,domain:o,range:s,scale:t,hint:c,interval:i}}function s7(e,t,{type:n,interval:r,domain:i,range:o,scheme:s,unknown:a,...c}){r=Vo(r,n),i===void 0&&(i=u7(t,r,e));let l;if(he.get(e)===Nf)l=nQ(t),o=o===void 0?rQ(l):Gt(o,Df);else if(he.get(e)===Vr&&(o===void 0&&(n==="ordinal"||n===Rf)&&(o=UR(i,s),o!==void 0&&(s=void 0)),s===void 0&&o===void 0&&(s=n==="ordinal"?"turbo":"observable10"),s!==void 0))if(o!==void 0){let u=Cf(s),f=o[0],h=o[1]-o[0];o=({length:d})=>Rn(p=>u(f+h*p),d)}else o=wT(s);if(a===om)throw new Error(`implicit unknown on ${e} scale is not supported`);return o7(e,hl().unknown(a),t,{...c,type:n,domain:i,range:o,hint:l})}function a7(e,t,{align:n=.5,padding:r=.5,...i}){return l7(zM().align(n).padding(r),t,i,e)}function c7(e,t,{align:n=.5,padding:r=.1,paddingInner:i=r,paddingOuter:o=e==="fx"||e==="fy"?0:r,...s}){return l7(Ua().align(n).paddingInner(i).paddingOuter(o),t,s,e)}function l7(e,t,n,r){let{round:i}=n;return i!==void 0&&e.round(i=!!i),e=o7(r,e,t,n),e.round=i,e}function u7(e,t,n){let r=new Qn;for(let{value:i,domain:o}of e){if(o!==void 0)return o();if(i!==void 0)for(let s of i)r.add(s)}if(t!==void 0){let[i,o]=le(r).map(t.floor,t);return t.range(i,t.offset(o))}if(r.size>1e4&&he.get(n)===vi)throw new Error(`implicit ordinal domain of ${n} scale has more than 10,000 values`);return As(r,dn)}function i7(e,t){let n;for(let{hint:r}of e){let i=r?.[t];if(i!==void 0){if(n===void 0)n=i;else if(n!==i)return}}return n}function nQ(e){return{fill:i7(e,"fill"),stroke:i7(e,"stroke")}}function rQ(e){return re(e.fill)?wA:K1}function ey(e,{label:t,inset:n=0,insetTop:r=n,insetRight:i=n,insetBottom:o=n,insetLeft:s=n,round:a,nice:c,clamp:l,zero:u,align:f,padding:h,projection:d,facet:{label:p=t}={},...m}={}){let y={};for(let[g,x]of e){let b=m[g],w=x7(g,x,{round:he.get(g)===vi?a:void 0,nice:c,clamp:l,zero:u,align:f,padding:h,projection:d,...b});if(w){let{label:_=g==="fx"||g==="fy"?p:t,percent:v,transform:M,inset:E,insetTop:I=E!==void 0?E:g==="y"?r:0,insetRight:D=E!==void 0?E:g==="x"?i:0,insetBottom:A=E!==void 0?E:g==="y"?o:0,insetLeft:O=E!==void 0?E:g==="x"?s:0}=b||{};if(M==null)M=void 0;else if(typeof M!="function")throw new Error("invalid scale transform; not a function");w.percent=!!v,w.label=_===void 0?iQ(x,w):_,w.transform=M,g==="x"||g==="fx"?(w.insetLeft=+O,w.insetRight=+D):(g==="y"||g==="fy")&&(w.insetTop=+I,w.insetBottom=+A),y[g]=w}}return y}function TT(e){let t={},n={scales:t};for(let[r,i]of Object.entries(e)){let{scale:o,type:s,interval:a,label:c}=i;t[r]=w7(i),n[r]=o,o.type=s,a!=null&&(o.interval=a),c!=null&&(o.label=c)}return n}function m7(e,t){let{x:n,y:r,fx:i,fy:o}=e,s=i||o?Tw(t):t;i&&f7(i,s),o&&h7(o,s);let a=i||o?ET(e,t):t;n&&f7(n,a),r&&h7(r,a)}function iQ(e=[],t){let n;for(let{label:r}of e)if(r!==void 0){if(n===void 0)n=r;else if(n!==r)return}if(n!==void 0)return!Go(t)&&t.percent&&(n=`${n} (%)`),{inferred:!0,toString:()=>n}}function Aw(e){return Math.sign(Ws(e.domain()))*Math.sign(Ws(e.range()))}function Tw(e){let{marginTop:t,marginRight:n,marginBottom:r,marginLeft:i,width:o,height:s,facet:{marginTop:a,marginRight:c,marginBottom:l,marginLeft:u}}=e;return{marginTop:Math.max(t,a),marginRight:Math.max(n,c),marginBottom:Math.max(r,l),marginLeft:Math.max(i,u),width:o,height:s}}function ET({fx:e,fy:t},n){let{marginTop:r,marginRight:i,marginBottom:o,marginLeft:s,width:a,height:c}=Tw(n);return{marginTop:r,marginRight:i,marginBottom:o,marginLeft:s,width:e?e.scale.bandwidth()+s+i:a,height:t?t.scale.bandwidth()+r+o:c,facet:{width:a,height:c}}}function f7(e,t){if(e.range===void 0){let{insetLeft:n,insetRight:r}=e,{width:i,marginLeft:o=0,marginRight:s=0}=t,a=o+n,c=i-s-r;e.range=[a,Math.max(a,c)],Go(e)||(e.range=g7(e)),e.scale.range(e.range)}y7(e)}function h7(e,t){if(e.range===void 0){let{insetTop:n,insetBottom:r}=e,{height:i,marginTop:o=0,marginBottom:s=0}=t,a=o+n,c=i-s-r;e.range=[Math.max(a,c),a],Go(e)?e.range.reverse():e.range=g7(e),e.scale.range(e.range)}y7(e)}function y7(e){e.round===void 0&&aQ(e)&&oQ(e)<=30&&e.scale.round(!0)}function oQ({scale:e}){let t=e.domain().length,[n,r]=e.range(),i=e.paddingInner?e.paddingInner():1,o=e.paddingOuter?e.paddingOuter():e.padding(),s=t-i,a=Math.abs(r-n)/Math.max(1,s+o*2);return(a-Math.floor(a))*s}function g7(e){let t=e.scale.domain().length+NT(e);if(!(t>2))return e.range;let[n,r]=e.range;return Array.from({length:t},(i,o)=>n+o/(t-1)*(r-n))}function Ew(e,t,n){return x7(e,n===void 0?void 0:[{hint:n}],{...t})}function x7(e,t=[],n={}){let r=sQ(e,t,n);if(n.type===void 0&&n.domain===void 0&&n.range===void 0&&n.interval==null&&e!=="fx"&&e!=="fy"&&Go({type:r})){let i=t.map(({value:o})=>o).filter(o=>o!==void 0);i.some(Le)?Vn(`Warning: some data associated with the ${e} scale are dates. Dates are typically associated with a "utc" or "time" scale rather than a "${$f(r)}" scale. If you are using a bar mark, you probably want a rect mark with the interval option instead; if you are using a group transform, you probably want a bin transform instead. If you want to treat this data as ordinal, you can specify the interval of the ${e} scale (e.g., d3.utcDay), or you can suppress this warning by setting the type of the ${e} scale to "${$f(r)}".`):i.some(eR)?Vn(`Warning: some data associated with the ${e} scale are strings that appear to be dates (e.g., YYYY-MM-DD). If these strings represent dates, you should parse them to Date objects. Dates are typically associated with a "utc" or "time" scale rather than a "${$f(r)}" scale. If you are using a bar mark, you probably want a rect mark with the interval option instead; if you are using a group transform, you probably want a bin transform instead. If you want to treat this data as ordinal, you can suppress this warning by setting the type of the ${e} scale to "${$f(r)}".`):i.some(nR)&&Vn(`Warning: some data associated with the ${e} scale are strings that appear to be numbers. If these strings represent numbers, you should parse or coerce them to numbers. Numbers are typically associated with a "linear" scale rather than a "${$f(r)}" scale. If you want to treat this data as ordinal, you can specify the interval of the ${e} scale (e.g., 1 for integers), or you can suppress this warning by setting the type of the ${e} scale to "${$f(r)}".`)}switch(n.type=r,r){case"diverging":case"diverging-sqrt":case"diverging-pow":case"diverging-log":case"diverging-symlog":case"cyclical":case"sequential":case"linear":case"sqrt":case"threshold":case"quantile":case"pow":case"log":case"symlog":n=Mw(t,n,Ke);break;case"identity":switch(he.get(e)){case vi:n=Mw(t,n,Ke);break;case Nf:n=Mw(t,n,cQ);break}break;case"utc":case"time":n=Mw(t,n,ZF);break}switch(r){case"diverging":return JR(e,t,n);case"diverging-sqrt":return QR(e,t,n);case"diverging-pow":return MT(e,t,n);case"diverging-log":return KR(e,t,n);case"diverging-symlog":return t7(e,t,n);case"categorical":case"ordinal":case Rf:return s7(e,t,n);case"cyclical":case"sequential":case"linear":return jR(e,t,n);case"sqrt":return VR(e,t,n);case"threshold":return Sw(e,t,n);case"quantile":return GR(e,t,n);case"quantize":return WR(e,t,n);case"pow":return IT(e,t,n);case"log":return YR(e,t,n);case"symlog":return XR(e,t,n);case"utc":return r7(e,t,n);case"time":return n7(e,t,n);case"point":return a7(e,t,n);case"band":return c7(e,t,n);case"identity":return HR(e);case void 0:return;default:throw new Error(`unknown scale type: ${r}`)}}function $f(e){return typeof e=="symbol"?e.description:e}function d7(e){return typeof e=="string"?`${e}`.toLowerCase():e}var p7={toString:()=>"projection"};function sQ(e,t,{type:n,domain:r,range:i,scheme:o,pivot:s,projection:a}){if(n=d7(n),e==="fx"||e==="fy")return"band";(e==="x"||e==="y")&&a!=null&&(n=p7);for(let l of t){let u=d7(l.type);if(u!==void 0){if(n===void 0)n=u;else if(n!==u)throw new Error(`scale incompatible with channel: ${n} !== ${u}`)}}if(n===p7)return;if(n!==void 0)return n;if(r===void 0&&!t.some(({value:l})=>l!==void 0))return;let c=he.get(e);if(c===Al)return"sqrt";if(c===El||c===Tl)return"linear";if(c===Nf)return"ordinal";if((r||i||[]).length>2)return AT(c);if(r!==void 0){if(Ne(r))return AT(c);if(Le(r))return"utc"}else{let l=t.map(({value:u})=>u).filter(u=>u!==void 0);if(l.some(Ne))return AT(c);if(l.some(Le))return"utc"}if(c===Vr){if(s!=null||zR(o))return"diverging";if(PR(o))return"categorical"}return"linear"}function AT(e){switch(e){case vi:return"point";case Vr:return Rf;default:return"ordinal"}}function Go({type:e}){return e==="ordinal"||e==="point"||e==="band"||e===Rf}function NT({type:e}){return e==="threshold"}function aQ({type:e}){return e==="point"||e==="band"}function ur(e){if(e===void 0)return!0;let t=e.domain(),n=e(t[0]);for(let r=1,i=t.length;r<i;++r)if(e(t[r])-n)return!1;return!0}function Mw(e,{domain:t,...n},r){for(let i of e)i.value!==void 0&&(t===void 0&&(t=i.value?.domain),i.value=r(i.value));return{domain:t===void 0?t:r(t),...n}}function cQ(e){return Gt(e,Df)}function rc(e={}){let t;for(let n in e)if(he.has(n)&&qo(e[n])){if(t!==void 0)throw new Error("ambiguous scale definition; multiple scales found");t=w7(Ew(n,e[n]))}if(t===void 0)throw new Error("invalid scale definition; no scale found");return t}function b7(e){return t=>{if(!he.has(t=`${t}`))throw new Error(`unknown scale: ${t}`);return e[t]}}function w7({scale:e,type:t,domain:n,range:r,interpolate:i,interval:o,transform:s,percent:a,pivot:c}){if(t==="identity")return{type:"identity",apply:u=>u,invert:u=>u};let l=e.unknown?e.unknown():void 0;return{type:t,domain:Ha(n),...r!==void 0&&{range:Ha(r)},...s!==void 0&&{transform:s},...a&&{percent:a},...l!==void 0&&{unknown:l},...o!==void 0&&{interval:o},...i!==void 0&&{interpolate:i},...e.clamp&&{clamp:e.clamp()},...c!==void 0&&{pivot:c,symmetric:!1},...e.base&&{base:e.base()},...e.exponent&&{exponent:e.exponent()},...e.constant&&{constant:e.constant()},...e.align&&{align:e.align(),round:e.round()},...e.padding&&(e.paddingInner?{paddingInner:e.paddingInner(),paddingOuter:e.paddingOuter()}:{padding:e.padding()}),...e.bandwidth&&{bandwidth:e.bandwidth(),step:e.step()},apply:u=>e(u),...e.invert&&{invert:u=>e.invert(u)}}}function Nw(e){let t,n;return(...r)=>((n?.length!==r.length||n.some((i,o)=>i!==r[o]))&&(n=r,t=e(...r)),t)}var lQ=Nw(e=>new Intl.NumberFormat(e)),uQ=Nw((e,t)=>new Intl.DateTimeFormat(e,{timeZone:"UTC",...t&&{month:t}})),fQ=Nw((e,t)=>new Intl.DateTimeFormat(e,{timeZone:"UTC",...t&&{weekday:t}}));function hQ(e="en-US"){let t=lQ(e);return n=>n!=null&&!isNaN(n)?t.format(n):void 0}function v7(e="en-US",t="short"){let n=uQ(e,t);return r=>r!=null&&!isNaN(r=+new Date(Date.UTC(2e3,+r)))?n.format(r):void 0}function _7(e="en-US",t="short"){let n=fQ(e,t);return r=>r!=null&&!isNaN(r=+new Date(Date.UTC(2001,0,+r)))?n.format(r):void 0}function DT(e){return wf(e,"Invalid Date")}function dQ(e="en-US"){let t=hQ(e);return n=>(n instanceof Date?DT:typeof n=="number"?t:qe)(n)}var Yi=dQ();var Ce=(typeof window<"u"?window.devicePixelRatio>1:typeof it>"u")?0:.5,pQ=0;function Dw(){return`plot-clip-${++pQ}`}function Ow(e,{title:t,href:n,ariaLabel:r,ariaDescription:i,ariaHidden:o,target:s,fill:a,fillOpacity:c,stroke:l,strokeWidth:u,strokeOpacity:f,strokeLinejoin:h,strokeLinecap:d,strokeMiterlimit:p,strokeDasharray:m,strokeDashoffset:y,opacity:g,mixBlendMode:x,imageFilter:b,paintOrder:w,pointerEvents:_,shapeRendering:v,channels:M},{ariaLabel:E,fill:I="currentColor",fillOpacity:D,stroke:A="none",strokeOpacity:O,strokeWidth:C,strokeLinecap:S,strokeLinejoin:T,strokeMiterlimit:N,paintOrder:F}){I===null&&(a=null,c=null),A===null&&(l=null,f=null),re(I)?!re(A)&&(!re(a)||M?.fill)&&(A="none"):re(A)&&(!re(l)||M?.stroke)&&(I="none");let[R,k]=Be(a,I),[$,P]=se(c,D),[U,W]=Be(l,A),[nt,ot]=se(f,O),[at,Y]=se(g);Qs(W)||(u===void 0&&(u=C),d===void 0&&(d=S),h===void 0&&(h=T),p===void 0&&!iR(h)&&(p=N),!Qs(k)&&w===void 0&&(w=F));let[st,j]=se(u);return I!==null&&(e.fill=fe(k,"currentColor"),e.fillOpacity=ny(P,1)),A!==null&&(e.stroke=fe(W,"none"),e.strokeWidth=ny(j,1),e.strokeOpacity=ny(ot,1),e.strokeLinejoin=fe(h,"miter"),e.strokeLinecap=fe(d,"butt"),e.strokeMiterlimit=ny(p,4),e.strokeDasharray=fe(m,"none"),e.strokeDashoffset=fe(y,"0")),e.target=qe(s),e.ariaLabel=qe(E),e.ariaDescription=qe(i),e.ariaHidden=qe(o),e.opacity=ny(Y,1),e.mixBlendMode=fe(x,"normal"),e.imageFilter=fe(b,"none"),e.paintOrder=fe(w,"normal"),e.pointerEvents=fe(_,"auto"),e.shapeRendering=fe(v,"auto"),{title:{value:t,optional:!0,filter:null},href:{value:n,optional:!0,filter:null},ariaLabel:{value:r,optional:!0,filter:null},fill:{value:R,scale:"auto",optional:!0},fillOpacity:{value:$,scale:"auto",optional:!0},stroke:{value:U,scale:"auto",optional:!0},strokeOpacity:{value:nt,scale:"auto",optional:!0},strokeWidth:{value:st,optional:!0},opacity:{value:at,scale:"auto",optional:!0}}}function mQ(e,t){t&&e.filter(n=>zm(t[n])).append("title").call(gQ,t)}function yQ(e,t){t&&e.filter(([n])=>zm(t[n])).append("title").call(xQ,t)}function gQ(e,t){t&&e.text(n=>Yi(t[n]))}function xQ(e,t){t&&e.text(([n])=>Yi(t[n]))}function Qt(e,{target:t,tip:n},{ariaLabel:r,title:i,fill:o,fillOpacity:s,stroke:a,strokeOpacity:c,strokeWidth:l,opacity:u,href:f}){r&&ft(e,"aria-label",h=>r[h]),o&&ft(e,"fill",h=>o[h]),s&&ft(e,"fill-opacity",h=>s[h]),a&&ft(e,"stroke",h=>a[h]),c&&ft(e,"stroke-opacity",h=>c[h]),l&&ft(e,"stroke-width",h=>l[h]),u&&ft(e,"opacity",h=>u[h]),f&&S7(e,h=>f[h],t),n||mQ(e,i)}function Nl(e,{target:t,tip:n},{ariaLabel:r,title:i,fill:o,fillOpacity:s,stroke:a,strokeOpacity:c,strokeWidth:l,opacity:u,href:f}){r&&ft(e,"aria-label",([h])=>r[h]),o&&ft(e,"fill",([h])=>o[h]),s&&ft(e,"fill-opacity",([h])=>s[h]),a&&ft(e,"stroke",([h])=>a[h]),c&&ft(e,"stroke-opacity",([h])=>c[h]),l&&ft(e,"stroke-width",([h])=>l[h]),u&&ft(e,"opacity",([h])=>u[h]),f&&S7(e,([h])=>f[h],t),n||yQ(e,i)}function bQ({ariaLabel:e,title:t,fill:n,fillOpacity:r,stroke:i,strokeOpacity:o,strokeWidth:s,opacity:a,href:c},{tip:l}){return[e,l?void 0:t,n,r,i,o,s,a,c].filter(u=>u!==void 0)}function ry(e,t,n){let r=ln(e,i=>t[i]);return n===void 0&&r.size>1+e.length>>1&&Vn("Warning: the implicit z channel has high cardinality. This may occur when the fill or stroke channel is associated with quantitative data rather than ordinal or categorical data. You can suppress this warning by setting the z option explicitly; if this data represents a single series, set z to null."),r.values()}function*Bw(e,t,n,r){let{z:i}=n,{z:o}=r,s=bQ(r,n),a=[...t,...s];for(let c of o?ry(e,o,i):[e]){let l,u;t:for(let f of c){for(let h of a)if(!ze(h[f])){u&&u.push(-1);continue t}if(l===void 0){u&&(yield u),l=s.map(h=>Zs(h[f])),u=[f];continue}u.push(f);for(let h=0;h<s.length;++h)if(Zs(s[h][f])!==l[h]){yield u,l=s.map(p=>Zs(p[f])),u=[f];continue t}}u&&(yield u)}}function wQ(e,t,n,r){let i,{clip:o=r.clip}=t;switch(o){case"frame":{let{width:s,height:a,marginLeft:c,marginRight:l,marginTop:u,marginBottom:f}=n,h=Dw();i=`url(#${h})`,e=ut("svg:g",r).call(d=>d.append("svg:clipPath").attr("id",h).append("rect").attr("x",c).attr("y",u).attr("width",s-l-c).attr("height",a-u-f)).each(function(){this.appendChild(e.node()),e.node=()=>this});break}case"sphere":{let{projection:s}=r;if(!s)throw new Error('the "sphere" clip option requires a projection');let a=Dw();i=`url(#${a})`,e.append("clipPath").attr("id",a).append("path").attr("d",Nn(s)({type:"Sphere"}));break}}ft(e,"aria-label",t.ariaLabel),ft(e,"aria-description",t.ariaDescription),ft(e,"aria-hidden",t.ariaHidden),ft(e,"clip-path",i)}function Ct(e,t,n,r){wQ(e,t,n,r),ft(e,"fill",t.fill),ft(e,"fill-opacity",t.fillOpacity),ft(e,"stroke",t.stroke),ft(e,"stroke-width",t.strokeWidth),ft(e,"stroke-opacity",t.strokeOpacity),ft(e,"stroke-linejoin",t.strokeLinejoin),ft(e,"stroke-linecap",t.strokeLinecap),ft(e,"stroke-miterlimit",t.strokeMiterlimit),ft(e,"stroke-dasharray",t.strokeDasharray),ft(e,"stroke-dashoffset",t.strokeDashoffset),ft(e,"shape-rendering",t.shapeRendering),ft(e,"filter",t.imageFilter),ft(e,"paint-order",t.paintOrder);let{pointerEvents:i=r.pointerSticky===!1?"none":void 0}=t;ft(e,"pointer-events",i)}function Lt(e,t){vQ(e,"mix-blend-mode",t.mixBlendMode),ft(e,"opacity",t.opacity)}function S7(e,t,n){e.each(function(r){let i=t(r);if(i!=null){let o=this.ownerDocument.createElementNS(ui.svg,"a");o.setAttribute("fill","inherit"),o.setAttributeNS(ui.xlink,"href",i),n!=null&&o.setAttribute("target",n),this.parentNode.insertBefore(o,this).appendChild(this)}})}function ft(e,t,n){n!=null&&e.attr(t,n)}function vQ(e,t,n){n!=null&&e.style(t,n)}function Et(e,t,{x:n,y:r},i=Ce,o=Ce){i+=t.dx,o+=t.dy,n?.bandwidth&&(i+=n.bandwidth()/2),r?.bandwidth&&(o+=r.bandwidth()/2),(i||o)&&e.attr("transform",`translate(${i},${o})`)}function fe(e,t){if((e=qe(e))!==t)return e}function ny(e,t){if((e=Bt(e))!==t)return e}var _Q=/^-?([_a-z]|[\240-\377]|\\[0-9a-f]{1,6}(\r\n|[ \t\r\n\f])?|\\[^\r\n\f0-9a-f])([_a-z0-9-]|[\240-\377]|\\[0-9a-f]{1,6}(\r\n|[ \t\r\n\f])?|\\[^\r\n\f0-9a-f])*$/i;function Pf(e){if(e===void 0)return"plot-d6a7b5";if(e=`${e}`,!_Q.test(e))throw new Error(`invalid class name: ${e}`);return e}function Uf(e,t){if(typeof t=="string")e.property("style",t);else if(t!=null)for(let n of e)Object.assign(n.style,t)}function bn({frameAnchor:e},{width:t,height:n,marginTop:r,marginRight:i,marginBottom:o,marginLeft:s}){return[/left$/.test(e)?s:/right$/.test(e)?t-i:(s+t-i)/2,/^top/.test(e)?r:/^bottom/.test(e)?n-o:(r+n-o)/2]}function M7(e,t,n={}){let r=.5-Ce,i=.5+Ce,o=.5+Ce,s=.5-Ce;for(let{marginTop:m,marginRight:y,marginBottom:g,marginLeft:x}of t)m>r&&(r=m),y>i&&(i=y),g>o&&(o=g),x>s&&(s=x);let{margin:a,marginTop:c=a!==void 0?a:r,marginRight:l=a!==void 0?a:i,marginBottom:u=a!==void 0?a:o,marginLeft:f=a!==void 0?a:s}=n;c=+c,l=+l,u=+u,f=+f;let{width:h=640,height:d=SQ(e,n,{width:h,marginTopDefault:r,marginRightDefault:i,marginBottomDefault:o,marginLeftDefault:s})+Math.max(0,c-r+u-o)}=n;h=+h,d=+d;let p={width:h,height:d,marginTop:c,marginRight:l,marginBottom:u,marginLeft:f};if(e.fx||e.fy){let{margin:m,marginTop:y=m!==void 0?m:c,marginRight:g=m!==void 0?m:l,marginBottom:x=m!==void 0?m:u,marginLeft:b=m!==void 0?m:f}=n.facet??{};y=+y,g=+g,x=+x,b=+b,p.facet={marginTop:y,marginRight:g,marginBottom:x,marginLeft:b}}return p}function SQ({x:e,y:t,fy:n,fx:r},{projection:i,aspectRatio:o},{width:s,marginTopDefault:a,marginRightDefault:c,marginBottomDefault:l,marginLeftDefault:u}){let f=n?n.scale.domain().length:1,h=BR(i);if(h){let p=r?r.scale.domain().length:1,m=(1.1*f-.1)/(1.1*p-.1)*h,y=Math.max(.1,Math.min(10,m));return Math.round((s-u-c)*y+a+l)}let d=t?Go(t)?t.scale.domain().length:Math.max(7,17/f):1;if(o!=null){if(o=+o,!(isFinite(o)&&o>0))throw new Error(`invalid aspectRatio: ${o}`);let p=I7("y",t)/(I7("x",e)*o),m=r?r.scale.bandwidth():1,y=n?n.scale.bandwidth():1,g=m*(s-u-c)-e.insetLeft-e.insetRight;return(p*g+t.insetTop+t.insetBottom)/y+a+l}return!!(t||n)*Math.max(1,Math.min(60,d*f))*20+!!r*30+60}function I7(e,t){if(!t)throw new Error(`aspectRatio requires ${e} scale`);let{type:n,domain:r}=t,i;switch(n){case"linear":case"utc":case"time":i=Number;break;case"pow":{let a=t.scale.exponent();i=c=>Math.pow(c,a);break}case"log":i=Math.log;break;case"point":case"band":return r.length;default:throw new Error(`unsupported ${e} scale for aspectRatio: ${n}`)}let[o,s]=le(r);return Math.abs(i(s)-i(o))}function T7(e,t){let{fx:n,fy:r}=ey(e,t),i=n?.scale.domain(),o=r?.scale.domain();return i&&o?H0(i,o).map(([s,a],c)=>({x:s,y:a,i:c})):i?i.map((s,a)=>({x:s,i:a})):o?o.map((s,a)=>({y:s,i:a})):void 0}function E7(e,{x:t,y:n}){return t&&=kT(t),n&&=kT(n),e.filter(t&&n?r=>t.has(r.x)&&n.has(r.y):t?r=>t.has(r.x):r=>n.has(r.y)).sort(t&&n?(r,i)=>t.get(r.x)-t.get(i.x)||n.get(r.y)-n.get(i.y):t?(r,i)=>t.get(r.x)-t.get(i.x):(r,i)=>n.get(r.y)-n.get(i.y))}function Cw(e,{fx:t,fy:n}){let r=cr(e),i=t?.value,o=n?.value;return t&&n?Pi(r,s=>(s.fx=i[s[0]],s.fy=o[s[0]],s),s=>i[s],s=>o[s]):t?Pi(r,s=>(s.fx=i[s[0]],s),s=>i[s]):Pi(r,s=>(s.fy=o[s[0]],s),s=>o[s])}function N7(e,t,{marginTop:n,marginLeft:r}){return e&&t?({x:i,y:o})=>`translate(${e(i)-r},${t(o)-n})`:e?({x:i})=>`translate(${e(i)-r},0)`:({y:i})=>`translate(0,${t(i)-n})`}function D7(e){let t=[],n=new Uint32Array(Tn(e,r=>r.length));for(let r of e){let i=0;for(let o of e)r!==o&&(n.set(o,i),i+=o.length);t.push(n.slice(0,i))}return t}var IQ=new Map([["top",OT],["right",CT],["bottom",BT],["left",LT],["top-left",Lw(OT,LT)],["top-right",Lw(OT,CT)],["bottom-left",Lw(BT,LT)],["bottom-right",Lw(BT,CT)],["top-empty",AQ],["right-empty",NQ],["bottom-empty",TQ],["left-empty",EQ],["empty",DQ]]);function O7(e){if(e==null)return null;let t=IQ.get(`${e}`.toLowerCase());if(t)return t;throw new Error(`invalid facet anchor: ${e}`)}var A7=new WeakMap;function kT(e){let t=A7.get(e);return t||A7.set(e,t=new Jn(Gt(e,(n,r)=>[n,r]))),t}function ic(e,t){return kT(e).get(t)}function MQ(e,t,n){return t=Zs(t),n=Zs(n),e.find(r=>Object.is(Zs(r.x),t)&&Object.is(Zs(r.y),n))}function kw(e,t,n){return MQ(e,t,n)?.empty}function OT(e,{y:t},{y:n}){return t?ic(t,n)===0:!0}function BT(e,{y:t},{y:n}){return t?ic(t,n)===t.length-1:!0}function LT(e,{x:t},{x:n}){return t?ic(t,n)===0:!0}function CT(e,{x:t},{x:n}){return t?ic(t,n)===t.length-1:!0}function AQ(e,{y:t},{x:n,y:r,empty:i}){if(i)return!1;if(!t)return;let o=ic(t,r);if(o>0)return kw(e,n,t[o-1])}function TQ(e,{y:t},{x:n,y:r,empty:i}){if(i)return!1;if(!t)return;let o=ic(t,r);if(o<t.length-1)return kw(e,n,t[o+1])}function EQ(e,{x:t},{x:n,y:r,empty:i}){if(i)return!1;if(!t)return;let o=ic(t,n);if(o>0)return kw(e,t[o-1],r)}function NQ(e,{x:t},{x:n,y:r,empty:i}){if(i)return!1;if(!t)return;let o=ic(t,n);if(o<t.length-1)return kw(e,t[o+1],r)}function DQ(e,t,{empty:n}){return n}function Lw(e,t){return function(){return e.apply(null,arguments)&&t.apply(null,arguments)}}function Fw(e,{channels:{fx:t,fy:n},groups:r}){return t&&n?e.map(({x:i,y:o})=>r.get(i)?.get(o)??[]):t?e.map(({x:i})=>r.get(i)??[]):e.map(({y:i})=>r.get(i)??[])}var St=class{constructor(t,n={},r={},i){let{facet:o="auto",facetAnchor:s,fx:a,fy:c,sort:l,dx:u=0,dy:f=0,margin:h=0,marginTop:d=h,marginRight:p=h,marginBottom:m=h,marginLeft:y=h,clip:g=i?.clip,channels:x,tip:b,render:w}=r;if(this.data=t,this.sort=jo(l)?l:null,this.initializer=Ie(r).initializer,this.transform=this.initializer?r.transform:gn(r).transform,o===null||o===!1?this.facet=null:(this.facet=sn(o===!0?"include":o,"facet",["auto","include","exclude","super"]),this.fx=t===Ga&&typeof a=="string"?[a]:a,this.fy=t===Ga&&typeof c=="string"?[c]:c),this.facetAnchor=O7(s),n=Gm(n),x!==void 0&&(n={...OQ(x),...n}),i!==void 0&&(n={...Ow(this,r,i),...n}),this.channels=Object.fromEntries(Object.entries(n).map(([_,v])=>{if(jr(v.value)){let{value:M,label:E=v.label,scale:I=v.scale}=v.value;v={...v,label:E,scale:I,value:M}}if(t===Ga&&typeof v.value=="string"){let{value:M}=v;v={...v,value:[M]}}return[_,v]}).filter(([_,{value:v,optional:M}])=>{if(v!=null)return!0;if(M)return!1;throw new Error(`missing channel value: ${_}`)})),this.dx=+u,this.dy=+f,this.marginTop=+d,this.marginRight=+p,this.marginBottom=+m,this.marginLeft=+y,this.clip=dw(g),this.tip=BQ(b),this.facet==="super"){if(a||c)throw new Error("super-faceting cannot use fx or fy");for(let _ in this.channels){let{scale:v}=n[_];if(!(v!=="x"&&v!=="y"))throw new Error("super-faceting cannot use x or y")}}w!=null&&(this.render=zf(w,this.render))}initialize(t,n,r){let i=je(this.data);t===void 0&&i!=null&&(t=[cr(i)]);let o=t;this.transform!=null&&({facets:t,data:i}=this.transform(i,t,r),i=je(i)),t!==void 0&&(t.original=o);let s=vw(this.channels,i);return this.sort!=null&&_R(i,t,s,n,this.sort),{data:i,facets:t,channels:s}}filter(t,n,r){for(let i in n){let{filter:o=ze}=n[i];if(o!==null){let s=r[i];t=t.filter(a=>o(s[a]))}}return t}project(t,n,r){for(let i in t)if(t[i].scale==="x"&&/^x|x$/.test(i)){let o=i.replace(/^x|x$/,"y");o in t&&t[o].scale==="y"&&bT(i,o,n,r.projection)}}scale(t,n,r){let i=Lf(t,n);return r.projection&&this.project(t,i,r),i}};function tn(...e){return e.plot=St.prototype.plot,e}function zf(e,t){if(e==null)return t===null?void 0:t;if(t==null)return e===null?void 0:e;if(typeof e!="function")throw new TypeError(`invalid render transform: ${e}`);if(typeof t!="function")throw new TypeError(`invalid render transform: ${t}`);return function(n,r,i,o,s,a){return e.call(this,n,r,i,o,s,(c,l,u,f,h)=>t.call(this,c,l,u,f,h,a))}}function OQ(e){return Object.fromEntries(Object.entries(Gm(e)).map(([t,n])=>(n=typeof n=="string"?{value:n,label:t}:wi(n),n.filter===void 0&&n.scale==null&&(n={...n,filter:null}),[t,n])))}function BQ(e){return e===!0?"xy":e===!1||e==null?null:typeof e=="string"?sn(e,"tip",["x","y","xy"]):e}function Xi(e,t){return e?.tip===!0?{...e,tip:t}:mn(e?.tip)&&e.tip.pointer===void 0?{...e,tip:{...e.tip,pointer:t}}:e}var B7=new WeakMap;function FT(e,t,{x:n,y:r,px:i,py:o,maxRadius:s=40,channels:a,render:c,...l}={}){return s=+s,i!=null&&(n??=null,a={...a,px:{value:i,scale:"x"}}),o!=null&&(r??=null,a={...a,py:{value:o,scale:"y"}}),{x:n,y:r,channels:a,...l,render:zf(function(u,f,h,d,p,m){p={...p,pointerSticky:!1};let y=p.ownerSVGElement,{data:g}=p.getMarkState(this),x=B7.get(y);x||B7.set(y,x={sticky:!1,roots:[],renders:[]});let b=x.renders.push(W)-1,{x:w,y:_,fx:v,fy:M}=f,E=v?v(u.fx)-d.marginLeft:0,I=M?M(u.fy)-d.marginTop:0;w?.bandwidth&&(E+=w.bandwidth()/2),_?.bandwidth&&(I+=_.bandwidth()/2);let D=u.fi!=null,A;if(D){let Y=x.facetStates;Y||(x.facetStates=Y=new Map),A=Y.get(this),A||Y.set(this,A=new Map)}let[O,C]=bn(this,d),{px:S,py:T}=h,N=S?Y=>S[Y]:RT(h,O),F=T?Y=>T[Y]:$T(h,C),R,k,$,P;function U(Y,st){if(D)if(P&&(P=cancelAnimationFrame(P)),Y==null)A.delete(u.fi);else{A.set(u.fi,st),P=requestAnimationFrame(()=>{P=null;for(let[j,Z]of A)if(Z<st||Z===st&&j<u.fi){Y=null;break}W(Y)});return}W(Y)}function W(Y){if(R===Y&&$===x.sticky)return;R=Y,$=p.pointerSticky=x.sticky;let st=R==null?[]:[R];D&&(st.fx=u.fx,st.fy=u.fy,st.fi=u.fi);let j=m(st,f,h,d,p);if(k){if(D){let Z=k.parentNode,rt=k.getAttribute("transform"),z=j.getAttribute("transform");rt?j.setAttribute("transform",rt):j.removeAttribute("transform"),z?Z.setAttribute("transform",z):Z.removeAttribute("transform"),j.removeAttribute("aria-label"),j.removeAttribute("aria-description"),j.removeAttribute("aria-hidden")}k.replaceWith(j)}return x.roots[b]=k=j,R==null&&A?.size>1||p.dispatchValue(R==null?null:g[R]),j}function nt(Y){if(x.sticky||Y.pointerType==="mouse"&&Y.buttons===1)return;let[st,j]=Fn(Y);st-=E,j-=I;let Z=st<d.marginLeft||st>d.width-d.marginRight?1:e,rt=j<d.marginTop||j>d.height-d.marginBottom?1:t,z=null,kt=s*s;for(let ht of u){let Wt=Z*(N(ht)-st),Zt=rt*(F(ht)-j),tt=Wt*Wt+Zt*Zt;tt<=kt&&(z=ht,kt=tt)}if(z!=null&&(e!==1||t!==1)){let ht=N(z)-st,Wt=F(z)-j;kt=ht*ht+Wt*Wt}U(z,kt)}function ot(Y){Y.pointerType==="mouse"&&R!=null&&(x.sticky&&x.roots.some(st=>st?.contains(Y.target))||(x.sticky?(x.sticky=!1,x.renders.forEach(st=>st(null))):(x.sticky=!0,W(R)),Y.stopImmediatePropagation()))}function at(Y){Y.pointerType==="mouse"&&(x.sticky||U(null))}return y.addEventListener("pointerenter",nt),y.addEventListener("pointermove",nt),y.addEventListener("pointerdown",ot),y.addEventListener("pointerleave",at),W(null)},c)}}function qf(e){return FT(1,1,e)}function jf(e){return FT(1,.01,e)}function Dl(e){return FT(.01,1,e)}function RT({x1:e,x2:t,x:n=e},r){return e&&t?i=>(e[i]+t[i])/2:n?i=>n[i]:()=>r}function $T({y1:e,y2:t,y:n=e},r){return e&&t?i=>(e[i]+t[i])/2:n?i=>n[i]:()=>r}function Rw(e){return Go(e)&&e.interval===void 0?void 0:"tabular-nums"}function L7(e,t){let{label:n=e.label,tickSize:r=6,width:i=240,height:o=44+r,marginTop:s=18,marginRight:a=0,marginBottom:c=16+r,marginLeft:l=0,style:u,ticks:f=(i-l-a)/64,tickFormat:h,fontVariant:d=Rw(e),round:p=!0,opacity:m,className:y}=t,g=ec(t);y=Pf(y),m=se(m)[1],h===null&&(h=()=>null);let x=ut("svg",g).attr("class",`${y}-ramp`).attr("font-family","system-ui, sans-serif").attr("font-size",10).attr("width",i).attr("height",o).attr("viewBox",`0 0 ${i} ${o}`).call(O=>O.append("style").text(`:where(.${y}-ramp) {
|
|
17
17
|
display: block;
|
|
18
18
|
height: auto;
|
|
19
19
|
height: intrinsic;
|
|
20
20
|
max-width: 100%;
|
|
21
21
|
overflow: visible;
|
|
22
22
|
}
|
|
23
|
-
:where(.${
|
|
23
|
+
:where(.${y}-ramp text) {
|
|
24
24
|
white-space: pre;
|
|
25
|
-
}`)).call(Cf,u),b=O=>O.selectAll(".tick line").attr("y1",s+c-o),w,v=p?(O,C)=>O.rangeRound(C):(O,C)=>O.range(C),{type:_,domain:I,range:D,interpolate:A,scale:E,pivot:T}=e;if(A){let O=D===void 0?A:yo(A.length===1?Xm(A):A,D);w=v(E.copy(),Fn(_e(l,i-a),Math.min(I.length+(T!==void 0),D===void 0?1/0:D.length)));let C=256,S=y.document.createElement("canvas");S.width=C,S.height=1;let M=S.getContext("2d");for(let N=0,F=C-1;N<C;++N)M.fillStyle=O(N/F),M.fillRect(N,0,1,1);x.append("image").attr("opacity",m).attr("x",l).attr("y",s).attr("width",i-l-a).attr("height",o-s-c).attr("preserveAspectRatio","none").attr("xlink:href",S.toDataURL())}else if(_==="threshold"){let O=I,C=d===void 0?S=>S:typeof d=="string"?ci(d):d;w=v(Ps().domain([-1,D.length-1]),[l,i-a]),x.append("g").attr("fill-opacity",m).selectAll().data(D).enter().append("rect").attr("x",(S,M)=>w(M-1)).attr("y",s).attr("width",(S,M)=>w(M)-w(M-1)).attr("height",o-s-c).attr("fill",S=>S),f=Gt(O,(S,M)=>M),d=S=>C(O[S],S)}else w=v(za().domain(I),[l,i-a]),x.append("g").attr("fill-opacity",m).selectAll().data(I).enter().append("rect").attr("x",w).attr("y",s).attr("width",Math.max(0,w.bandwidth()-1)).attr("height",o-s-c).attr("fill",E),b=()=>{};return x.append("g").attr("transform",`translate(0,${o-c})`).call(GS(w).ticks(Array.isArray(f)?null:f,typeof d=="string"?d:void 0).tickFormat(typeof d=="function"?d:void 0).tickSize(r).tickValues(Array.isArray(f)?f:null)).attr("font-size",null).attr("font-family",null).attr("font-variant",fe(h,"normal")).call(b).call(O=>O.select(".domain").remove()),n!==void 0&&x.append("text").attr("x",l).attr("y",s-6).attr("fill","currentColor").attr("font-weight","bold").text(n),x.node()}var Vf=Math.PI/180;function Xi(e,{marker:t,markerStart:n=t,markerMid:r=t,markerEnd:i=t}={}){e.markerStart=CT(n),e.markerMid=CT(r),e.markerEnd=CT(i)}function CT(e){if(e==null||e===!1)return null;if(e===!0)return M7;if(typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"none":return null;case"arrow":return I7("auto");case"arrow-reverse":return I7("auto-start-reverse");case"dot":return sQ;case"circle":case"circle-fill":return M7;case"circle-stroke":return aQ;case"tick":return kT("auto");case"tick-x":return kT(90);case"tick-y":return kT(0)}throw new Error(`invalid marker: ${e}`)}function I7(e){return(t,n)=>ut("svg:marker",n).attr("viewBox","-5 -5 10 10").attr("markerWidth",6.67).attr("markerHeight",6.67).attr("orient",e).attr("fill","none").attr("stroke",t).attr("stroke-width",1.5).attr("stroke-linecap","round").attr("stroke-linejoin","round").call(r=>r.append("path").attr("d","M-1.5,-3l3,3l-3,3")).node()}function sQ(e,t){return ut("svg:marker",t).attr("viewBox","-5 -5 10 10").attr("markerWidth",6.67).attr("markerHeight",6.67).attr("fill",e).attr("stroke","none").call(n=>n.append("circle").attr("r",2.5)).node()}function M7(e,t){return ut("svg:marker",t).attr("viewBox","-5 -5 10 10").attr("markerWidth",6.67).attr("markerHeight",6.67).attr("fill",e).attr("stroke","var(--plot-background)").attr("stroke-width",1.5).call(n=>n.append("circle").attr("r",3)).node()}function aQ(e,t){return ut("svg:marker",t).attr("viewBox","-5 -5 10 10").attr("markerWidth",6.67).attr("markerHeight",6.67).attr("fill","var(--plot-background)").attr("stroke",e).attr("stroke-width",1.5).call(n=>n.append("circle").attr("r",3)).node()}function kT(e){return(t,n)=>ut("svg:marker",n).attr("viewBox","-3 -3 6 6").attr("markerWidth",6).attr("markerHeight",6).attr("orient",e).attr("stroke",t).call(r=>r.append("path").attr("d","M0,-3v6")).node()}var cQ=0;function oa(e,t,{stroke:n},r){return T7(e,t,n&&(i=>n[i]),r)}function A7(e,t,{stroke:n},r){return T7(e,t,n&&(([i])=>n[i]),r)}function T7(e,{markerStart:t,markerMid:n,markerEnd:r,stroke:i},o=()=>i,s){let a=new Map;function c(l){return function(u){let f=o(u),d=a.get(l);d||a.set(l,d=new Map);let h=d.get(f);if(!h){let p=this.parentNode.insertBefore(l(f,s),this),m=`plot-marker-${++cQ}`;p.setAttribute("id",m),d.set(f,h=`url(#${m})`)}return h}}t&&e.attr("marker-start",c(t)),n&&e.attr("marker-mid",c(n)),r&&e.attr("marker-end",c(r))}function Nl({inset:e,insetLeft:t,insetRight:n,...r}={}){return[t,n]=E7(e,t,n),{inset:e,insetLeft:t,insetRight:n,...r}}function Dl({inset:e,insetTop:t,insetBottom:n,...r}={}){return[t,n]=E7(e,t,n),{inset:e,insetTop:t,insetBottom:n,...r}}function E7(e,t,n){return e===void 0&&t===void 0&&n===void 0?Ce?[1,0]:[.5,.5]:[t,n]}function N7(e,{interval:t}){return e={...pi(e)},e.interval=Tf(e.interval===void 0?t:e.interval),e}function Fw(e,t,n,r){let{[e]:i,[`${e}1`]:o,[`${e}2`]:s}=n,{value:a,interval:c}=N7(i,n);if(a==null||c==null&&!r)return n;let l=On(i);if(c==null){let h,p={transform:m=>h||(h=wt(m,a)),label:l};return{...n,[e]:void 0,[`${e}1`]:o===void 0?p:o,[`${e}2`]:s===void 0&&!(o===s&&r)?p:s}}let u,f;function d(h){return f!==void 0&&h===u?f:f=Gt(wt(u=h,a),p=>c.floor(p))}return t({...n,[e]:void 0,[`${e}1`]:o===void 0?{transform:d,label:l}:o,[`${e}2`]:s===void 0?{transform:h=>d(h).map(p=>c.offset(p)),label:l}:s})}function D7(e,t,n){let{[e]:r}=n,{value:i,interval:o}=N7(r,n);return i==null||o==null?n:t({...n,[e]:{label:On(r),transform:s=>{let a=Gt(wt(s,i),l=>o.floor(l)),c=a.map(l=>o.offset(l));return a.map(Le(a)?(l,u)=>l==null||isNaN(l=+l)||(u=c[u],u==null)||isNaN(u=+u)?void 0:new Date((l+u)/2):(l,u)=>l==null||(u=c[u],u==null)?NaN:(+l+ +u)/2)}}})}function FT(e={}){return Fw("x",Nl,e,!0)}function RT(e={}){return Fw("y",Dl,e,!0)}function Rw(e={}){return Fw("x",Nl,e)}function $w(e={}){return Fw("y",Dl,e)}function Pw(e={}){return D7("x",Nl,e)}function Uw(e={}){return D7("y",Dl,e)}var O7={ariaLabel:"rule",fill:null,stroke:"currentColor"},Wm=class extends St{constructor(t,n={}){let{x:r,y1:i,y2:o,inset:s=0,insetTop:a=s,insetBottom:c=s}=n;super(t,{x:{value:r,scale:"x",optional:!0},y1:{value:i,scale:"y",optional:!0},y2:{value:o,scale:"y",optional:!0}},Yi(n,"x"),O7),this.insetTop=Bt(a),this.insetBottom=Bt(c),Xi(this,n)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y1:l,y2:u}=r,{width:f,height:d,marginTop:h,marginRight:p,marginLeft:m,marginBottom:g}=i,{insetTop:y,insetBottom:x}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s},Ce,0).call(b=>b.selectAll().data(t).enter().append("line").call(Lt,this).attr("x1",c?w=>c[w]:(m+f-p)/2).attr("x2",c?w=>c[w]:(m+f-p)/2).attr("y1",l&&!lr(a)?w=>l[w]+y:h+y).attr("y2",u&&!lr(a)?a.bandwidth?w=>u[w]+a.bandwidth()-x:w=>u[w]-x:d-g-x).call(Qt,this,r).call(oa,this,r,o)).node()}},Hm=class extends St{constructor(t,n={}){let{x1:r,x2:i,y:o,inset:s=0,insetRight:a=s,insetLeft:c=s}=n;super(t,{y:{value:o,scale:"y",optional:!0},x1:{value:r,scale:"x",optional:!0},x2:{value:i,scale:"x",optional:!0}},Yi(n,"y"),O7),this.insetRight=Bt(a),this.insetLeft=Bt(c),Xi(this,n)}render(t,n,r,i,o){let{x:s,y:a}=n,{y:c,x1:l,x2:u}=r,{width:f,height:d,marginTop:h,marginRight:p,marginLeft:m,marginBottom:g}=i,{insetLeft:y,insetRight:x}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{y:c&&a},0,Ce).call(b=>b.selectAll().data(t).enter().append("line").call(Lt,this).attr("x1",l&&!lr(s)?w=>l[w]+y:m+y).attr("x2",u&&!lr(s)?s.bandwidth?w=>u[w]+s.bandwidth()-x:w=>u[w]-x:f-p-x).attr("y1",c?w=>c[w]:(h+d-g)/2).attr("y2",c?w=>c[w]:(h+d-g)/2).call(Qt,this,r).call(oa,this,r,o)).node()}};function Yr(e,t){let{x:n=G,y:r,y1:i,y2:o,...s}=$w(t);return[i,o]=B7(r,i,o),new Wm(e,{...s,x:n,y1:i,y2:o})}function Xr(e,t){let{y:n=G,x:r,x1:i,x2:o,...s}=Rw(t);return[i,o]=B7(r,i,o),new Hm(e,{...s,y:n,x1:i,x2:o})}function B7(e,t,n){if(e==null){if(t===void 0){if(n!==void 0)return[0,n]}else if(n===void 0)return[0,t]}else{if(t===void 0)return n===void 0?[0,e]:[e,n];if(n===void 0)return[e,t]}return[t,n]}function oc(e,...t){let n=t.length;for(let r=0,i=!0;r<n;++r)typeof t[r]!="function"&&(i&&(e=e.slice(),i=!1),e.splice(r,2,e[r]+t[r]+e[r+1]),t.splice(r,1),--r,--n);return r=>{let i=e[0];for(let o=0;o<n;++o)i+=t[o](r)+e[o+1];return i}}var lQ={ariaLabel:"text",strokeLinejoin:"round",strokeWidth:3,paintOrder:"stroke"},R7="\xAD",Bl=class extends St{constructor(t,n={}){let{x:r,y:i,text:o=cr(t)&&cw(t)?G:Ee,frameAnchor:s,textAnchor:a=/right$/i.test(s)?"end":/left$/i.test(s)?"start":"middle",lineAnchor:c=/^top/i.test(s)?"top":/^bottom/i.test(s)?"bottom":"middle",lineHeight:l=1,lineWidth:u=1/0,textOverflow:f,monospace:d,fontFamily:h=d?"ui-monospace, monospace":void 0,fontSize:p,fontStyle:m,fontVariant:g,fontWeight:y,rotate:x}=n,[b,w]=se(x,0),[v,_]=hQ(p);if(super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},fontSize:{value:v,optional:!0},rotate:{value:jF(b),optional:!0},text:{value:o,filter:Bm,optional:!0}},n,lQ),this.rotate=w,this.textAnchor=fe(a,"middle"),this.lineAnchor=tn(c,"lineAnchor",["top","middle","bottom"]),this.lineHeight=+l,this.lineWidth=+u,this.textOverflow=PT(f),this.monospace=!!d,this.fontFamily=qe(h),this.fontSize=_,this.fontStyle=qe(m),this.fontVariant=qe(g),this.fontWeight=qe(y),this.frameAnchor=Fo(s),!(this.lineWidth>=0))throw new Error(`invalid lineWidth: ${u}`);this.splitLines=zT(this),this.clipLine=qT(this)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,rotate:u,text:f,title:d,fontSize:h}=r,{rotate:p}=this,[m,g]=gn(this,i);return ut("svg:g",o).call(Ct,this,i,o).call(UT,this,f,i).call(Et,this,{x:c&&s,y:l&&a}).call(y=>y.selectAll().data(t).enter().append("text").call(Lt,this).call(uQ,this,f,d).attr("transform",oc`translate(${c?x=>c[x]:m},${l?x=>l[x]:g})${u?x=>` rotate(${u[x]})`:p?` rotate(${p})`:""}`).call(ft,"font-size",h&&(x=>h[x])).call(Qt,this,r)).node()}};function PT(e){return e==null?null:tn(e,"textOverflow",["clip","ellipsis","clip-start","clip-end","ellipsis-start","ellipsis-middle","ellipsis-end"]).replace(/^(clip|ellipsis)$/,"$1-end")}function uQ(e,t,n,r){if(!n)return;let{lineAnchor:i,lineHeight:o,textOverflow:s,splitLines:a,clipLine:c}=t;e.each(function(l){let u=a(ji(n[l])??"").map(c),f=u.length,d=i==="top"?.71:i==="bottom"?1-f:(164-f*100)/200;if(f>1){let h=0;for(let p=0;p<f;++p){if(++h,!u[p])continue;let m=this.ownerDocument.createElementNS(oi.svg,"tspan");m.setAttribute("x",0),p===h-1?m.setAttribute("y",`${(d+p)*o}em`):m.setAttribute("dy",`${h*o}em`),m.textContent=u[p],this.appendChild(m),h=0}}else d&&this.setAttribute("y",`${d*o}em`),this.textContent=u[0];if(s&&!r&&u[0]!==n[l]){let h=this.ownerDocument.createElementNS(oi.svg,"title");h.textContent=n[l],this.appendChild(h)}})}function Po(e,{x:t,y:n,...r}={}){return r.frameAnchor===void 0&&([t,n]=$e(t,n)),new Bl(e,{...r,x:t,y:n})}function zw(e,{x:t=G,...n}={}){return new Bl(e,Uw({...n,x:t}))}function qw(e,{y:t=G,...n}={}){return new Bl(e,Pw({...n,y:t}))}function UT(e,t,n){ft(e,"text-anchor",t.textAnchor),ft(e,"font-family",t.fontFamily),ft(e,"font-size",t.fontSize),ft(e,"font-style",t.fontStyle),ft(e,"font-variant",t.fontVariant===void 0?fQ(n):t.fontVariant),ft(e,"font-weight",t.fontWeight)}function fQ(e){return e&&(Ks(e)||Le(e))?"tabular-nums":void 0}var dQ=new Set(["inherit","initial","revert","unset","xx-small","x-small","small","medium","large","x-large","xx-large","xxx-large","larger","smaller"]);function hQ(e){return e==null||typeof e=="number"?[void 0,e]:typeof e!="string"?[e,void 0]:(e=e.trim().toLowerCase(),dQ.has(e)||/^[+-]?\d*\.?\d+(e[+-]?\d+)?(\w*|%)$/.test(e)?[void 0,e]:[e,void 0])}function pQ(e,t,n){let r=[],i,o=0;for(let[s,a,c]of mQ(e)){if(i===void 0&&(i=s),o>i&&n(e,i,a)>t&&(r.push(e.slice(i,o)+(e[o-1]===R7?"-":"")),i=s),c){r.push(e.slice(i,a)),i=void 0;continue}o=a}return r}function*mQ(e){let t=0,n=0,r=e.length;for(;n<r;){let i=1;switch(e[n]){case R7:case"-":++n,yield[t,n,!1],t=n;break;case" ":for(yield[t,n,!1];e[++n]===" ";);t=n;break;case"\r":e[n+1]===`
|
|
25
|
+
}`)).call(Uf,u),b=O=>O.selectAll(".tick line").attr("y1",s+c-o),w,_=p?(O,C)=>O.rangeRound(C):(O,C)=>O.range(C),{type:v,domain:M,range:E,interpolate:I,scale:D,pivot:A}=e;if(I){let O=E===void 0?I:Ao(I.length===1?ty(I):I,E);w=_(D.copy(),Rn(_e(l,i-a),Math.min(M.length+(A!==void 0),E===void 0?1/0:E.length)));let C=256,S=g.document.createElement("canvas");S.width=C,S.height=1;let T=S.getContext("2d");for(let N=0,F=C-1;N<C;++N)T.fillStyle=O(N/F),T.fillRect(N,0,1,1);x.append("image").attr("opacity",m).attr("x",l).attr("y",s).attr("width",i-l-a).attr("height",o-s-c).attr("preserveAspectRatio","none").attr("xlink:href",S.toDataURL())}else if(v==="threshold"){let O=M,C=h===void 0?S=>S:typeof h=="string"?pi(h):h;w=_($s().domain([-1,E.length-1]),[l,i-a]),x.append("g").attr("fill-opacity",m).selectAll().data(E).enter().append("rect").attr("x",(S,T)=>w(T-1)).attr("y",s).attr("width",(S,T)=>w(T)-w(T-1)).attr("height",o-s-c).attr("fill",S=>S),f=Gt(O,(S,T)=>T),h=S=>C(O[S],S)}else w=_(Ua().domain(M),[l,i-a]),x.append("g").attr("fill-opacity",m).selectAll().data(M).enter().append("rect").attr("x",w).attr("y",s).attr("width",Math.max(0,w.bandwidth()-1)).attr("height",o-s-c).attr("fill",D),b=()=>{};return x.append("g").attr("transform",`translate(0,${o-c})`).call(ZS(w).ticks(Array.isArray(f)?null:f,typeof h=="string"?h:void 0).tickFormat(typeof h=="function"?h:void 0).tickSize(r).tickValues(Array.isArray(f)?f:null)).attr("font-size",null).attr("font-family",null).attr("font-variant",fe(d,"normal")).call(b).call(O=>O.select(".domain").remove()),n!==void 0&&x.append("text").attr("x",l).attr("y",s-6).attr("fill","currentColor").attr("font-weight","bold").text(n),x.node()}var Vf=Math.PI/180;function Gi(e,{marker:t,markerStart:n=t,markerMid:r=t,markerEnd:i=t}={}){e.markerStart=PT(n),e.markerMid=PT(r),e.markerEnd=PT(i)}function PT(e){if(e==null||e===!1)return null;if(e===!0)return k7;if(typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"none":return null;case"arrow":return C7("auto");case"arrow-reverse":return C7("auto-start-reverse");case"dot":return LQ;case"circle":case"circle-fill":return k7;case"circle-stroke":return CQ;case"tick":return UT("auto");case"tick-x":return UT(90);case"tick-y":return UT(0)}throw new Error(`invalid marker: ${e}`)}function C7(e){return(t,n)=>ut("svg:marker",n).attr("viewBox","-5 -5 10 10").attr("markerWidth",6.67).attr("markerHeight",6.67).attr("orient",e).attr("fill","none").attr("stroke",t).attr("stroke-width",1.5).attr("stroke-linecap","round").attr("stroke-linejoin","round").call(r=>r.append("path").attr("d","M-1.5,-3l3,3l-3,3")).node()}function LQ(e,t){return ut("svg:marker",t).attr("viewBox","-5 -5 10 10").attr("markerWidth",6.67).attr("markerHeight",6.67).attr("fill",e).attr("stroke","none").call(n=>n.append("circle").attr("r",2.5)).node()}function k7(e,t){return ut("svg:marker",t).attr("viewBox","-5 -5 10 10").attr("markerWidth",6.67).attr("markerHeight",6.67).attr("fill",e).attr("stroke","var(--plot-background)").attr("stroke-width",1.5).call(n=>n.append("circle").attr("r",3)).node()}function CQ(e,t){return ut("svg:marker",t).attr("viewBox","-5 -5 10 10").attr("markerWidth",6.67).attr("markerHeight",6.67).attr("fill","var(--plot-background)").attr("stroke",e).attr("stroke-width",1.5).call(n=>n.append("circle").attr("r",3)).node()}function UT(e){return(t,n)=>ut("svg:marker",n).attr("viewBox","-3 -3 6 6").attr("markerWidth",6).attr("markerHeight",6).attr("orient",e).attr("stroke",t).call(r=>r.append("path").attr("d","M0,-3v6")).node()}var kQ=0;function ra(e,t,{stroke:n},r){return R7(e,t,n&&(i=>n[i]),r)}function F7(e,t,{stroke:n},r){return R7(e,t,n&&(([i])=>n[i]),r)}function R7(e,{markerStart:t,markerMid:n,markerEnd:r,stroke:i},o=()=>i,s){let a=new Map;function c(l){return function(u){let f=o(u),h=a.get(l);h||a.set(l,h=new Map);let d=h.get(f);if(!d){let p=this.parentNode.insertBefore(l(f,s),this),m=`plot-marker-${++kQ}`;p.setAttribute("id",m),h.set(f,d=`url(#${m})`)}return d}}t&&e.attr("marker-start",c(t)),n&&e.attr("marker-mid",c(n)),r&&e.attr("marker-end",c(r))}function Ol({inset:e,insetLeft:t,insetRight:n,...r}={}){return[t,n]=$7(e,t,n),{inset:e,insetLeft:t,insetRight:n,...r}}function Bl({inset:e,insetTop:t,insetBottom:n,...r}={}){return[t,n]=$7(e,t,n),{inset:e,insetTop:t,insetBottom:n,...r}}function $7(e,t,n){return e===void 0&&t===void 0&&n===void 0?Ce?[1,0]:[.5,.5]:[t,n]}function P7(e,{interval:t}){return e={...wi(e)},e.interval=Ef(e.interval===void 0?t:e.interval),e}function $w(e,t,n,r){let{[e]:i,[`${e}1`]:o,[`${e}2`]:s}=n,{value:a,interval:c}=P7(i,n);if(a==null||c==null&&!r)return n;let l=Bn(i);if(c==null){let d,p={transform:m=>d||(d=wt(m,a)),label:l};return{...n,[e]:void 0,[`${e}1`]:o===void 0?p:o,[`${e}2`]:s===void 0&&!(o===s&&r)?p:s}}let u,f;function h(d){return f!==void 0&&d===u?f:f=Gt(wt(u=d,a),p=>c.floor(p))}return t({...n,[e]:void 0,[`${e}1`]:o===void 0?{transform:h,label:l}:o,[`${e}2`]:s===void 0?{transform:d=>h(d).map(p=>c.offset(p)),label:l}:s})}function U7(e,t,n){let{[e]:r}=n,{value:i,interval:o}=P7(r,n);return i==null||o==null?n:t({...n,[e]:{label:Bn(r),transform:s=>{let a=Gt(wt(s,i),l=>o.floor(l)),c=a.map(l=>o.offset(l));return a.map(Le(a)?(l,u)=>l==null||isNaN(l=+l)||(u=c[u],u==null)||isNaN(u=+u)?void 0:new Date((l+u)/2):(l,u)=>l==null||(u=c[u],u==null)?NaN:(+l+ +u)/2)}}})}function zT(e={}){return $w("x",Ol,e,!0)}function qT(e={}){return $w("y",Bl,e,!0)}function Pw(e={}){return $w("x",Ol,e)}function Uw(e={}){return $w("y",Bl,e)}function zw(e={}){return U7("x",Ol,e)}function qw(e={}){return U7("y",Bl,e)}var z7={ariaLabel:"rule",fill:null,stroke:"currentColor"},iy=class extends St{constructor(t,n={}){let{x:r,y1:i,y2:o,inset:s=0,insetTop:a=s,insetBottom:c=s}=n;super(t,{x:{value:r,scale:"x",optional:!0},y1:{value:i,scale:"y",optional:!0},y2:{value:o,scale:"y",optional:!0}},Xi(n,"x"),z7),this.insetTop=Bt(a),this.insetBottom=Bt(c),Gi(this,n)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y1:l,y2:u}=r,{width:f,height:h,marginTop:d,marginRight:p,marginLeft:m,marginBottom:y}=i,{insetTop:g,insetBottom:x}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s},Ce,0).call(b=>b.selectAll().data(t).enter().append("line").call(Lt,this).attr("x1",c?w=>c[w]:(m+f-p)/2).attr("x2",c?w=>c[w]:(m+f-p)/2).attr("y1",l&&!ur(a)?w=>l[w]+g:d+g).attr("y2",u&&!ur(a)?a.bandwidth?w=>u[w]+a.bandwidth()-x:w=>u[w]-x:h-y-x).call(Qt,this,r).call(ra,this,r,o)).node()}},oy=class extends St{constructor(t,n={}){let{x1:r,x2:i,y:o,inset:s=0,insetRight:a=s,insetLeft:c=s}=n;super(t,{y:{value:o,scale:"y",optional:!0},x1:{value:r,scale:"x",optional:!0},x2:{value:i,scale:"x",optional:!0}},Xi(n,"y"),z7),this.insetRight=Bt(a),this.insetLeft=Bt(c),Gi(this,n)}render(t,n,r,i,o){let{x:s,y:a}=n,{y:c,x1:l,x2:u}=r,{width:f,height:h,marginTop:d,marginRight:p,marginLeft:m,marginBottom:y}=i,{insetLeft:g,insetRight:x}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{y:c&&a},0,Ce).call(b=>b.selectAll().data(t).enter().append("line").call(Lt,this).attr("x1",l&&!ur(s)?w=>l[w]+g:m+g).attr("x2",u&&!ur(s)?s.bandwidth?w=>u[w]+s.bandwidth()-x:w=>u[w]-x:f-p-x).attr("y1",c?w=>c[w]:(d+h-y)/2).attr("y2",c?w=>c[w]:(d+h-y)/2).call(Qt,this,r).call(ra,this,r,o)).node()}};function Yr(e,t){let{x:n=G,y:r,y1:i,y2:o,...s}=Uw(t);return[i,o]=q7(r,i,o),new iy(e,{...s,x:n,y1:i,y2:o})}function Xr(e,t){let{y:n=G,x:r,x1:i,x2:o,...s}=Pw(t);return[i,o]=q7(r,i,o),new oy(e,{...s,y:n,x1:i,x2:o})}function q7(e,t,n){if(e==null){if(t===void 0){if(n!==void 0)return[0,n]}else if(n===void 0)return[0,t]}else{if(t===void 0)return n===void 0?[0,e]:[e,n];if(n===void 0)return[e,t]}return[t,n]}function oc(e,...t){let n=t.length;for(let r=0,i=!0;r<n;++r)typeof t[r]!="function"&&(i&&(e=e.slice(),i=!1),e.splice(r,2,e[r]+t[r]+e[r+1]),t.splice(r,1),--r,--n);return r=>{let i=e[0];for(let o=0;o<n;++o)i+=t[o](r)+e[o+1];return i}}var FQ={ariaLabel:"text",strokeLinejoin:"round",strokeWidth:3,paintOrder:"stroke"},G7="\xAD",Cl=class extends St{constructor(t,n={}){let{x:r,y:i,text:o=lr(t)&&uw(t)?G:Ee,frameAnchor:s,textAnchor:a=/right$/i.test(s)?"end":/left$/i.test(s)?"start":"middle",lineAnchor:c=/^top/i.test(s)?"top":/^bottom/i.test(s)?"bottom":"middle",lineHeight:l=1,lineWidth:u=1/0,textOverflow:f,monospace:h,fontFamily:d=h?"ui-monospace, monospace":void 0,fontSize:p,fontStyle:m,fontVariant:y,fontWeight:g,rotate:x}=n,[b,w]=se(x,0),[_,v]=UQ(p);if(super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},fontSize:{value:_,optional:!0},rotate:{value:KF(b),optional:!0},text:{value:o,filter:zm,optional:!0}},n,FQ),this.rotate=w,this.textAnchor=fe(a,"middle"),this.lineAnchor=sn(c,"lineAnchor",["top","middle","bottom"]),this.lineHeight=+l,this.lineWidth=+u,this.textOverflow=VT(f),this.monospace=!!h,this.fontFamily=qe(d),this.fontSize=v,this.fontStyle=qe(m),this.fontVariant=qe(y),this.fontWeight=qe(g),this.frameAnchor=Yo(s),!(this.lineWidth>=0))throw new Error(`invalid lineWidth: ${u}`);this.splitLines=XT(this),this.clipLine=GT(this)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,rotate:u,text:f,title:h,fontSize:d}=r,{rotate:p}=this,[m,y]=bn(this,i);return ut("svg:g",o).call(Ct,this,i,o).call(YT,this,f,i).call(Et,this,{x:c&&s,y:l&&a}).call(g=>g.selectAll().data(t).enter().append("text").call(Lt,this).call(RQ,this,f,h).attr("transform",oc`translate(${c?x=>c[x]:m},${l?x=>l[x]:y})${u?x=>` rotate(${u[x]})`:p?` rotate(${p})`:""}`).call(ft,"font-size",d&&(x=>d[x])).call(Qt,this,r)).node()}};function VT(e){return e==null?null:sn(e,"textOverflow",["clip","ellipsis","clip-start","clip-end","ellipsis-start","ellipsis-middle","ellipsis-end"]).replace(/^(clip|ellipsis)$/,"$1-end")}function RQ(e,t,n,r){if(!n)return;let{lineAnchor:i,lineHeight:o,textOverflow:s,splitLines:a,clipLine:c}=t;e.each(function(l){let u=a(Yi(n[l])??"").map(c),f=u.length,h=i==="top"?.71:i==="bottom"?1-f:(164-f*100)/200;if(f>1){let d=0;for(let p=0;p<f;++p){if(++d,!u[p])continue;let m=this.ownerDocument.createElementNS(ui.svg,"tspan");m.setAttribute("x",0),p===d-1?m.setAttribute("y",`${(h+p)*o}em`):m.setAttribute("dy",`${d*o}em`),m.textContent=u[p],this.appendChild(m),d=0}}else h&&this.setAttribute("y",`${h*o}em`),this.textContent=u[0];if(s&&!r&&u[0]!==n[l]){let d=this.ownerDocument.createElementNS(ui.svg,"title");d.textContent=n[l],this.appendChild(d)}})}function Wo(e,{x:t,y:n,...r}={}){return r.frameAnchor===void 0&&([t,n]=Pe(t,n)),new Cl(e,{...r,x:t,y:n})}function jw(e,{x:t=G,...n}={}){return new Cl(e,qw({...n,x:t}))}function Vw(e,{y:t=G,...n}={}){return new Cl(e,zw({...n,y:t}))}function YT(e,t,n){ft(e,"text-anchor",t.textAnchor),ft(e,"font-family",t.fontFamily),ft(e,"font-size",t.fontSize),ft(e,"font-style",t.fontStyle),ft(e,"font-variant",t.fontVariant===void 0?$Q(n):t.fontVariant),ft(e,"font-weight",t.fontWeight)}function $Q(e){return e&&(Js(e)||Le(e))?"tabular-nums":void 0}var PQ=new Set(["inherit","initial","revert","unset","xx-small","x-small","small","medium","large","x-large","xx-large","xxx-large","larger","smaller"]);function UQ(e){return e==null||typeof e=="number"?[void 0,e]:typeof e!="string"?[e,void 0]:(e=e.trim().toLowerCase(),PQ.has(e)||/^[+-]?\d*\.?\d+(e[+-]?\d+)?(\w*|%)$/.test(e)?[void 0,e]:[e,void 0])}function zQ(e,t,n){let r=[],i,o=0;for(let[s,a,c]of qQ(e)){if(i===void 0&&(i=s),o>i&&n(e,i,a)>t&&(r.push(e.slice(i,o)+(e[o-1]===G7?"-":"")),i=s),c){r.push(e.slice(i,a)),i=void 0;continue}o=a}return r}function*qQ(e){let t=0,n=0,r=e.length;for(;n<r;){let i=1;switch(e[n]){case G7:case"-":++n,yield[t,n,!1],t=n;break;case" ":for(yield[t,n,!1];e[++n]===" ";);t=n;break;case"\r":e[n+1]===`
|
|
26
26
|
`&&++i;case`
|
|
27
|
-
`:yield[t,n,!0],n+=i,t=n;break;default:++n;break}}yield[t,n,!0]}var L7={a:56,b:63,c:57,d:63,e:58,f:37,g:62,h:60,i:26,j:26,k:55,l:26,m:88,n:60,o:60,p:62,q:62,r:39,s:54,t:38,u:60,v:55,w:79,x:54,y:55,z:55,A:69,B:67,C:73,D:74,E:61,F:58,G:76,H:75,I:28,J:55,K:67,L:58,M:89,N:75,O:78,P:65,Q:78,R:67,S:65,T:65,U:75,V:69,W:98,X:69,Y:67,Z:67,0:64,1:48,2:62,3:64,4:66,5:63,6:65,7:58,8:65,9:65," ":29,"!":32,'"':49,"'":31,"(":39,")":39,",":31,"-":48,".":31,"/":32,":":31,";":31,"?":52,"\u2018":31,"\u2019":31,"\u201C":47,"\u201D":47,"\u2026":82};function jw(e,t=0,n=e.length){let r=0;for(let i=t;i<n;i=Yf(e,i))r+=L7[e[i]]??(P7(e,i)?120:L7.e);return r}function Vw(e,t=0,n=e.length){let r=0;for(let i=t;i<n;i=Yf(e,i))r+=P7(e,i)?126:63;return r}function zT({monospace:e,lineWidth:t,textOverflow:n}){if(n!=null||t==1/0)return o=>o.split(/\r\n?|\n/g);let r=e?Vw:jw,i=t*100;return o=>pQ(o,i,r)}function qT({monospace:e,lineWidth:t,textOverflow:n}){if(n==null||t==1/0)return o=>o;let r=e?Vw:jw,i=t*100;switch(n){case"clip-start":return o=>k7(o,i,r,"");case"clip-end":return o=>C7(o,i,r,"");case"ellipsis-start":return o=>k7(o,i,r,Ol);case"ellipsis-middle":return o=>yQ(o,i,r,Ol);case"ellipsis-end":return o=>C7(o,i,r,Ol)}}var Ol="\u2026";function Ll(e,t,n,r){let i=[],o=0;for(let s=0,a=0,c=e.length;s<c;s=a){a=Yf(e,s);let l=n(e,s,a);if(o+l>t){for(o+=r;o>t&&s>0;)a=s,s=i.pop(),o-=n(e,s,a);return[s,t-o]}o+=l,i.push(s)}return[-1,0]}function C7(e,t,n,r){e=e.trim();let i=n(r),[o]=Ll(e,t,n,i);return o<0?e:e.slice(0,o).trimEnd()+r}function yQ(e,t,n,r){e=e.trim();let i=n(e);if(i<=t)return e;let o=n(r)/2,[s,a]=Ll(e,t/2,n,o),[c]=Ll(e,i-t/2-a+o,n,-o);return c<0?r:e.slice(0,s).trimEnd()+r+e.slice(Yf(e,c)).trimStart()}function k7(e,t,n,r){e=e.trim();let i=n(e);if(i<=t)return e;let o=n(r),[s]=Ll(e,i-t+o,n,-o);return s<0?r:r+e.slice(Yf(e,s)).trimStart()}var $T=/[\p{Combining_Mark}\p{Emoji_Modifier}]+/uy,F7=/\p{Extended_Pictographic}/uy;function Yf(e,t){return t+=gQ(e,t)?2:1,bQ(e,t)&&(t=$T.lastIndex),xQ(e,t)?Yf(e,t+1):t}function $7(e,t){return e.charCodeAt(t)<128}function gQ(e,t){let n=e.charCodeAt(t);if(n>=55296&&n<56320){let r=e.charCodeAt(t+1);return r>=56320&&r<57344}return!1}function xQ(e,t){return e.charCodeAt(t)===8205}function bQ(e,t){return $7(e,t)?!1:($T.lastIndex=t,$T.test(e))}function P7(e,t){return $7(e,t)?!1:(F7.lastIndex=t,F7.test(e))}var U7={ariaLabel:"vector",fill:"none",stroke:"currentColor",strokeWidth:1.5,strokeLinejoin:"round",strokeLinecap:"round"},z7=3.5,wQ=z7*5,q7={draw(e,t,n){let r=t*n/wQ;e.moveTo(0,0),e.lineTo(0,-t),e.moveTo(-r,r-t),e.lineTo(0,-t),e.lineTo(r,r-t)}},j7={draw(e,t,n){e.moveTo(-n,0),e.lineTo(0,-t),e.lineTo(n,0)}},vQ=new Map([["arrow",q7],["spike",j7]]);function _Q(e){return e&&typeof e.draw=="function"}function SQ(e){if(_Q(e))return e;let t=vQ.get(`${e}`.toLowerCase());if(t)return t;throw new Error(`invalid shape: ${e}`)}var Cl=class extends St{constructor(t,n={}){let{x:r,y:i,r:o=z7,length:s,rotate:a,shape:c=q7,anchor:l="middle",frameAnchor:u}=n,[f,d]=se(s,12),[h,p]=se(a,0);super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},length:{value:f,scale:"length",optional:!0},rotate:{value:h,optional:!0}},n,U7),this.r=+o,this.length=d,this.rotate=p,this.shape=SQ(c),this.anchor=tn(l,"anchor",["start","middle","end"]),this.frameAnchor=Fo(u)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,length:u,rotate:f}=r,{length:d,rotate:h,anchor:p,shape:m,r:g}=this,[y,x]=gn(this,i);return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(b=>b.selectAll().data(t).enter().append("path").call(Lt,this).attr("transform",oc`translate(${c?w=>c[w]:y},${l?w=>l[w]:x})${f?w=>` rotate(${f[w]})`:h?` rotate(${h})`:""}${p==="start"?"":p==="end"?u?w=>` translate(0,${u[w]})`:` translate(0,${d})`:u?w=>` translate(0,${u[w]/2})`:` translate(0,${d/2})`}`).attr("d",u?w=>{let v=er();return m.draw(v,u[w],g),v}:(()=>{let w=er();return m.draw(w,d,g),w})()).call(Qt,this,r)).node()}};function jT(e,t={}){let{x:n,y:r,...i}=t;return t.frameAnchor===void 0&&([n,r]=$e(n,r)),new Cl(e,{...i,x:n,y:r})}function Yw(e,t={}){let{x:n=G,...r}=t;return new Cl(e,{...r,x:n})}function Xw(e,t={}){let{y:n=G,...r}=t;return new Cl(e,{...r,y:n})}function V7(e,t={}){let{shape:n=j7,stroke:r=U7.stroke,strokeWidth:i=1,fill:o=r,fillOpacity:s=.3,anchor:a="start",...c}=t;return jT(e,{...c,shape:n,stroke:r,strokeWidth:i,fill:o,fillOpacity:s,anchor:a})}function sc(e,t){return arguments.length<2&&!cr(e)&&(t=e,e=null),t===void 0&&(t={}),[e,t]}function Gw({anchor:e}={},t){return e===void 0?t[0]:tn(e,"anchor",t)}function Y7(e){return Gw(e,["left","right"])}function X7(e){return Gw(e,["right","left"])}function G7(e){return Gw(e,["bottom","top"])}function W7(e){return Gw(e,["top","bottom"])}function Zm(){let[e,t]=sc(...arguments);return H7("y",Y7(t),e,t)}function Ww(){let[e,t]=sc(...arguments);return H7("fy",X7(t),e,t)}function Jm(){let[e,t]=sc(...arguments);return Z7("x",G7(t),e,t)}function Hw(){let[e,t]=sc(...arguments);return Z7("fx",W7(t),e,t)}function H7(e,t,n,{color:r="currentColor",opacity:i=1,stroke:o=r,strokeOpacity:s=i,strokeWidth:a=1,fill:c=r,fillOpacity:l=i,textAnchor:u,textStroke:f,textStrokeOpacity:d,textStrokeWidth:h,tickSize:p=e==="y"?6:0,tickPadding:m,tickRotate:g,x:y,margin:x,marginTop:b=x===void 0?20:x,marginRight:w=x===void 0?t==="right"?40:0:x,marginBottom:v=x===void 0?20:x,marginLeft:_=x===void 0?t==="left"?40:0:x,label:I,labelAnchor:D,labelArrow:A,labelOffset:E,...T}){return p=Bt(p),m=Bt(m),g=Bt(g),D!==void 0&&(D=tn(D,"labelAnchor",["center","top","bottom"])),A=i$(A),en(p&&!re(o)?IQ(e,t,n,{stroke:o,strokeOpacity:s,strokeWidth:a,tickSize:p,tickPadding:m,tickRotate:g,x:y,...T}):null,re(c)?null:AQ(e,t,n,{fill:c,fillOpacity:l,stroke:f,strokeOpacity:d,strokeWidth:h,textAnchor:u,tickSize:p,tickPadding:m,tickRotate:g,x:y,marginTop:b,marginRight:w,marginBottom:v,marginLeft:_,...T}),!re(c)&&I!==null?Po([],t$({fill:c,fillOpacity:l,...T},function(O,C,S,M,N){let F=M[e],{marginTop:R,marginRight:k,marginBottom:$,marginLeft:P}=e==="y"&&N.inset||N,U=D??(F.bandwidth?"center":"top"),W=E??(t==="right"?k:P)-3;return U==="center"?(this.textAnchor=void 0,this.lineAnchor=t==="right"?"bottom":"top",this.frameAnchor=t,this.rotate=-90):(this.textAnchor=t==="right"?"end":"start",this.lineAnchor=U,this.frameAnchor=`${U}-${t}`,this.rotate=0),this.dy=U==="top"?3-R:U==="bottom"?$-3:0,this.dx=t==="right"?W:-W,this.ariaLabel=`${e}-axis label`,{facets:[[0]],channels:{text:{value:[r$(e,F,{anchor:t,label:I,labelAnchor:U,labelArrow:A})]}}}})):null)}function Z7(e,t,n,{color:r="currentColor",opacity:i=1,stroke:o=r,strokeOpacity:s=i,strokeWidth:a=1,fill:c=r,fillOpacity:l=i,textAnchor:u,textStroke:f,textStrokeOpacity:d,textStrokeWidth:h,tickSize:p=e==="x"?6:0,tickPadding:m,tickRotate:g,y,margin:x,marginTop:b=x===void 0?t==="top"?30:0:x,marginRight:w=x===void 0?20:x,marginBottom:v=x===void 0?t==="bottom"?30:0:x,marginLeft:_=x===void 0?20:x,label:I,labelAnchor:D,labelArrow:A,labelOffset:E,...T}){return p=Bt(p),m=Bt(m),g=Bt(g),D!==void 0&&(D=tn(D,"labelAnchor",["center","left","right"])),A=i$(A),en(p&&!re(o)?MQ(e,t,n,{stroke:o,strokeOpacity:s,strokeWidth:a,tickSize:p,tickPadding:m,tickRotate:g,y,...T}):null,re(c)?null:TQ(e,t,n,{fill:c,fillOpacity:l,stroke:f,strokeOpacity:d,strokeWidth:h,textAnchor:u,tickSize:p,tickPadding:m,tickRotate:g,y,marginTop:b,marginRight:w,marginBottom:v,marginLeft:_,...T}),!re(c)&&I!==null?Po([],t$({fill:c,fillOpacity:l,...T},function(O,C,S,M,N){let F=M[e],{marginTop:R,marginRight:k,marginBottom:$,marginLeft:P}=e==="x"&&N.inset||N,U=D??(F.bandwidth?"center":"right"),W=E??(t==="top"?R:$)-3;return U==="center"?(this.frameAnchor=t,this.textAnchor=void 0):(this.frameAnchor=`${t}-${U}`,this.textAnchor=U==="right"?"end":"start"),this.lineAnchor=t,this.dy=t==="top"?-W:W,this.dx=U==="right"?k-3:U==="left"?3-P:0,this.ariaLabel=`${e}-axis label`,{facets:[[0]],channels:{text:{value:[r$(e,F,{anchor:t,label:I,labelAnchor:U,labelArrow:A})]}}}})):null)}function IQ(e,t,n,{strokeWidth:r=1,strokeLinecap:i=null,strokeLinejoin:o=null,facetAnchor:s=t+(e==="y"?"-empty":""),frameAnchor:a=t,tickSize:c,inset:l=0,insetLeft:u=l,insetRight:f=l,dx:d=0,y:h=e==="y"?void 0:null,...p}){return Xf(Xw,e,t,`${e}-axis tick`,n,{strokeWidth:r,strokeLinecap:i,strokeLinejoin:o,facetAnchor:s,frameAnchor:a,y:h,...p,dx:t==="left"?+d-Ce+ +u:+d+Ce-f,anchor:"start",length:c,shape:t==="left"?OQ:BQ})}function MQ(e,t,n,{strokeWidth:r=1,strokeLinecap:i=null,strokeLinejoin:o=null,facetAnchor:s=t+(e==="x"?"-empty":""),frameAnchor:a=t,tickSize:c,inset:l=0,insetTop:u=l,insetBottom:f=l,dy:d=0,x:h=e==="x"?void 0:null,...p}){return Xf(Yw,e,t,`${e}-axis tick`,n,{strokeWidth:r,strokeLinejoin:o,strokeLinecap:i,facetAnchor:s,frameAnchor:a,x:h,...p,dy:t==="bottom"?+d-Ce-f:+d+Ce+ +u,anchor:"start",length:c,shape:t==="bottom"?NQ:DQ})}function AQ(e,t,n,{facetAnchor:r=t+(e==="y"?"-empty":""),frameAnchor:i=t,tickSize:o,tickRotate:s=0,tickPadding:a=Math.max(3,9-o)+(Math.abs(s)>60?4*Math.cos(s*Vf):0),text:c,textAnchor:l=Math.abs(s)>60?"middle":t==="left"?"end":"start",lineAnchor:u=s>60?"top":s<-60?"bottom":"middle",fontVariant:f,inset:d=0,insetLeft:h=d,insetRight:p=d,dx:m=0,y:g=e==="y"?void 0:null,...y}){return Xf(qw,e,t,`${e}-axis tick label`,n,{facetAnchor:r,frameAnchor:i,text:c,textAnchor:l,lineAnchor:u,fontVariant:f,rotate:s,y:g,...y,dx:t==="left"?+m-o-a+ +h:+m+ +o+ +a-p},function(x,b,w,v,_){f===void 0&&(this.fontVariant=n$(x)),c===void 0&&(_.text=e$(x,b,w,v,t))})}function TQ(e,t,n,{facetAnchor:r=t+(e==="x"?"-empty":""),frameAnchor:i=t,tickSize:o,tickRotate:s=0,tickPadding:a=Math.max(3,9-o)+(Math.abs(s)>=10?4*Math.cos(s*Vf):0),text:c,textAnchor:l=Math.abs(s)>=10?s<0^t==="bottom"?"start":"end":"middle",lineAnchor:u=Math.abs(s)>=10?"middle":t==="bottom"?"top":"bottom",fontVariant:f,inset:d=0,insetTop:h=d,insetBottom:p=d,dy:m=0,x:g=e==="x"?void 0:null,...y}){return Xf(zw,e,t,`${e}-axis tick label`,n,{facetAnchor:r,frameAnchor:i,text:c===void 0?null:c,textAnchor:l,lineAnchor:u,fontVariant:f,rotate:s,x:g,...y,dy:t==="bottom"?+m+ +o+ +a-p:+m-o-a+ +h},function(x,b,w,v,_){f===void 0&&(this.fontVariant=n$(x)),c===void 0&&(_.text=e$(x,b,w,v,t))})}function Zw(){let[e,t]=sc(...arguments);return J7("y",Y7(t),e,t)}function Jw(){let[e,t]=sc(...arguments);return J7("fy",X7(t),e,t)}function Qw(){let[e,t]=sc(...arguments);return Q7("x",G7(t),e,t)}function Kw(){let[e,t]=sc(...arguments);return Q7("fx",W7(t),e,t)}function J7(e,t,n,{y:r=e==="y"?void 0:null,x:i=null,x1:o=t==="left"?i:null,x2:s=t==="right"?i:null,...a}){return Xf(Xr,e,t,`${e}-grid`,n,{y:r,x1:o,x2:s,...K7(a)})}function Q7(e,t,n,{x:r=e==="x"?void 0:null,y:i=null,y1:o=t==="top"?i:null,y2:s=t==="bottom"?i:null,...a}){return Xf(Yr,e,t,`${e}-grid`,n,{x:r,y1:o,y2:s,...K7(a)})}function K7({color:e="currentColor",opacity:t=.1,stroke:n=e,strokeOpacity:r=t,strokeWidth:i=1,...o}){return{stroke:n,strokeOpacity:r,strokeWidth:i,...o}}function t$({fill:e,fillOpacity:t,fontFamily:n,fontSize:r,fontStyle:i,fontVariant:o,fontWeight:s,monospace:a,pointerEvents:c,shapeRendering:l,clip:u=!1},f){return[,e]=Be(e),[,t]=se(t),{facet:"super",x:null,y:null,fill:e,fillOpacity:t,fontFamily:n,fontSize:r,fontStyle:i,fontVariant:o,fontWeight:s,monospace:a,pointerEvents:c,shapeRendering:l,clip:u,initializer:f}}function Xf(e,t,n,r,i,o,s){let a;function c(f,d,h,p,m,g){let y=f==null&&(t==="fx"||t==="fy"),{[t]:x}=p;if(!x)throw new Error(`missing scale: ${t}`);let b=x.domain(),{interval:w,ticks:v,tickFormat:_,tickSpacing:I=t==="x"?80:35}=o;if(typeof v=="string"&&o$(x)&&(w=v,v=void 0),v===void 0&&(v=ko(w,x.type)??EQ(x,I)),f==null){if(cr(v))f=je(v);else if(Ja(v))f=VT(v,...le(b));else if(x.interval){let A=x.interval;if(x.ticks){let[E,T]=le(b),O=(T-E)/A[_f];A=qA(A,O/v)??A,f=VT(A,E,T)}else{f=b;let E=f.length;A=qA(A,E/v)??A,A!==x.interval&&(f=VT(A,...le(f)))}if(A===x.interval){let E=Math.round(f.length/v);E>1&&(f=f.filter((T,O)=>O%E===0))}}else x.ticks?f=x.ticks(v):f=b;if(!x.ticks&&f.length&&f!==b){let A=new Jn(b);f=f.filter(E=>A.has(E)),f.length||Vn(`Warning: the ${t}-axis ticks appear to not align with the scale domain, resulting in no ticks. Try different ticks?`)}t==="y"||t==="x"?d=[ar(f)]:a[t]={scale:t,value:G}}s?.call(this,x,f,v,_,a);let D=Object.fromEntries(Object.entries(a).map(([A,E])=>[A,{...E,value:wt(f,E.value)}]));return y&&(d=g.filterFacets(f,D)),{data:f,facets:d,channels:D}}let l=Ie(o).initializer,u=e(i,Ie({...o,initializer:c},l));return i==null?(a=u.channels,u.channels={}):a={},u.ariaLabel=r,u.clip===void 0&&(u.clip=!1),u}function EQ(e,t){let[n,r]=le(e.range());return(r-n)/t}function e$(e,t,n,r,i){return{value:Qm(e,t,n,r,i)}}function Qm(e,t,n,r,i){return typeof r=="function"?r:r===void 0&&t&&Le(t)?kF(e.type,t,i)??ji:e.tickFormat?e.tickFormat(typeof n=="number"?n:null,r):r===void 0?ji:typeof r=="string"?(Le(e.domain())?Do:ci)(r):hn(r)}function VT(e,t,n){return e.range(t,e.offset(e.floor(n)))}var NQ={draw(e,t){e.moveTo(0,0),e.lineTo(0,t)}},DQ={draw(e,t){e.moveTo(0,0),e.lineTo(0,-t)}},OQ={draw(e,t){e.moveTo(0,0),e.lineTo(-t,0)}},BQ={draw(e,t){e.moveTo(0,0),e.lineTo(t,0)}};function n$(e){return e.bandwidth&&!e.interval?void 0:"tabular-nums"}function r$(e,t,{anchor:n,label:r=t.label,labelAnchor:i,labelArrow:o}={}){if(!(r==null||r.inferred&&o$(t)&&/^(date|time|year)$/i.test(r))){if(r=String(r),o==="auto"&&(o=(!t.bandwidth||t.interval)&&!/[↑↓→←]/.test(r)),!o)return r;if(o===!0){let s=Ew(t);s&&(o=/x$/.test(e)||i==="center"?/x$/.test(e)===s<0?"left":"right":s<0?"up":"down")}switch(o){case"left":return`\u2190 ${r}`;case"right":return`${r} \u2192`;case"up":return n==="right"?`${r} \u2191`:`\u2191 ${r}`;case"down":return n==="right"?`${r} \u2193`:`\u2193 ${r}`}return r}}function i$(e="auto"){return re(e)?!1:typeof e=="boolean"?e:tn(e,"labelArrow",["auto","up","right","down","left"])}function o$(e){return Le(e.domain())}function s$(e,t){if(t==null)return t;let n=e(t);if(!n)throw new Error(`scale not found: ${t}`);return n}function a$(e,{opacity:t,...n}={}){if(!$o(e)&&!MT(e))throw new Error(`swatches legend requires ordinal or threshold color scale (not ${e.type})`);return l$(e,n,(r,i,o,s)=>r.append("svg").attr("width",o).attr("height",s).attr("fill",i.scale).attr("fill-opacity",se(t)[1]).append("rect").attr("width","100%").attr("height","100%"))}function c$(e,{fill:t=e.hint?.fill!==void 0?e.hint.fill:"none",fillOpacity:n=1,stroke:r=e.hint?.stroke!==void 0?e.hint.stroke:re(t)?"currentColor":"none",strokeOpacity:i=1,strokeWidth:o=1.5,r:s=4.5,...a}={},c){let[l,u]=Be(t),[f,d]=Be(r),h=s$(c,l),p=s$(c,f),m=s*s*Math.PI;return n=se(n)[1],i=se(i)[1],o=se(o)[1],l$(e,a,(g,y,x,b)=>g.append("svg").attr("viewBox","-8 -8 16 16").attr("width",x).attr("height",b).attr("fill",l==="color"?w=>h.scale(w):u).attr("fill-opacity",n).attr("stroke",f==="color"?w=>p.scale(w):d).attr("stroke-opacity",i).attr("stroke-width",o).append("path").attr("d",w=>{let v=er();return e.scale(w).draw(v,m),v}))}function l$(e,t={},n){let{columns:r,tickFormat:i,fontVariant:o=kw(e),swatchSize:s=15,swatchWidth:a=s,swatchHeight:c=s,marginLeft:l=0,className:u,style:f,width:d}=t,h=nc(t);u=Lf(u),i=Qm(e.scale,e.domain,void 0,i);let p=ut("div",h).attr("class",`${u}-swatches ${u}-swatches-${r!=null?"columns":"wrap"}`),m;return r!=null?(m=`:where(.${u}-swatches-columns .${u}-swatch) {
|
|
27
|
+
`:yield[t,n,!0],n+=i,t=n;break;default:++n;break}}yield[t,n,!0]}var j7={a:56,b:63,c:57,d:63,e:58,f:37,g:62,h:60,i:26,j:26,k:55,l:26,m:88,n:60,o:60,p:62,q:62,r:39,s:54,t:38,u:60,v:55,w:79,x:54,y:55,z:55,A:69,B:67,C:73,D:74,E:61,F:58,G:76,H:75,I:28,J:55,K:67,L:58,M:89,N:75,O:78,P:65,Q:78,R:67,S:65,T:65,U:75,V:69,W:98,X:69,Y:67,Z:67,0:64,1:48,2:62,3:64,4:66,5:63,6:65,7:58,8:65,9:65," ":29,"!":32,'"':49,"'":31,"(":39,")":39,",":31,"-":48,".":31,"/":32,":":31,";":31,"?":52,"\u2018":31,"\u2019":31,"\u201C":47,"\u201D":47,"\u2026":82};function Yw(e,t=0,n=e.length){let r=0;for(let i=t;i<n;i=Yf(e,i))r+=j7[e[i]]??(H7(e,i)?120:j7.e);return r}function Xw(e,t=0,n=e.length){let r=0;for(let i=t;i<n;i=Yf(e,i))r+=H7(e,i)?126:63;return r}function XT({monospace:e,lineWidth:t,textOverflow:n}){if(n!=null||t==1/0)return o=>o.split(/\r\n?|\n/g);let r=e?Xw:Yw,i=t*100;return o=>zQ(o,i,r)}function GT({monospace:e,lineWidth:t,textOverflow:n}){if(n==null||t==1/0)return o=>o;let r=e?Xw:Yw,i=t*100;switch(n){case"clip-start":return o=>Y7(o,i,r,"");case"clip-end":return o=>V7(o,i,r,"");case"ellipsis-start":return o=>Y7(o,i,r,Ll);case"ellipsis-middle":return o=>jQ(o,i,r,Ll);case"ellipsis-end":return o=>V7(o,i,r,Ll)}}var Ll="\u2026";function kl(e,t,n,r){let i=[],o=0;for(let s=0,a=0,c=e.length;s<c;s=a){a=Yf(e,s);let l=n(e,s,a);if(o+l>t){for(o+=r;o>t&&s>0;)a=s,s=i.pop(),o-=n(e,s,a);return[s,t-o]}o+=l,i.push(s)}return[-1,0]}function V7(e,t,n,r){e=e.trim();let i=n(r),[o]=kl(e,t,n,i);return o<0?e:e.slice(0,o).trimEnd()+r}function jQ(e,t,n,r){e=e.trim();let i=n(e);if(i<=t)return e;let o=n(r)/2,[s,a]=kl(e,t/2,n,o),[c]=kl(e,i-t/2-a+o,n,-o);return c<0?r:e.slice(0,s).trimEnd()+r+e.slice(Yf(e,c)).trimStart()}function Y7(e,t,n,r){e=e.trim();let i=n(e);if(i<=t)return e;let o=n(r),[s]=kl(e,i-t+o,n,-o);return s<0?r:r+e.slice(Yf(e,s)).trimStart()}var jT=/[\p{Combining_Mark}\p{Emoji_Modifier}]+/uy,X7=/\p{Extended_Pictographic}/uy;function Yf(e,t){return t+=VQ(e,t)?2:1,XQ(e,t)&&(t=jT.lastIndex),YQ(e,t)?Yf(e,t+1):t}function W7(e,t){return e.charCodeAt(t)<128}function VQ(e,t){let n=e.charCodeAt(t);if(n>=55296&&n<56320){let r=e.charCodeAt(t+1);return r>=56320&&r<57344}return!1}function YQ(e,t){return e.charCodeAt(t)===8205}function XQ(e,t){return W7(e,t)?!1:(jT.lastIndex=t,jT.test(e))}function H7(e,t){return W7(e,t)?!1:(X7.lastIndex=t,X7.test(e))}var Z7={ariaLabel:"vector",fill:"none",stroke:"currentColor",strokeWidth:1.5,strokeLinejoin:"round",strokeLinecap:"round"},J7=3.5,GQ=J7*5,Q7={draw(e,t,n){let r=t*n/GQ;e.moveTo(0,0),e.lineTo(0,-t),e.moveTo(-r,r-t),e.lineTo(0,-t),e.lineTo(r,r-t)}},K7={draw(e,t,n){e.moveTo(-n,0),e.lineTo(0,-t),e.lineTo(n,0)}},WQ=new Map([["arrow",Q7],["spike",K7]]);function HQ(e){return e&&typeof e.draw=="function"}function ZQ(e){if(HQ(e))return e;let t=WQ.get(`${e}`.toLowerCase());if(t)return t;throw new Error(`invalid shape: ${e}`)}var Fl=class extends St{constructor(t,n={}){let{x:r,y:i,r:o=J7,length:s,rotate:a,shape:c=Q7,anchor:l="middle",frameAnchor:u}=n,[f,h]=se(s,12),[d,p]=se(a,0);super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},length:{value:f,scale:"length",optional:!0},rotate:{value:d,optional:!0}},n,Z7),this.r=+o,this.length=h,this.rotate=p,this.shape=ZQ(c),this.anchor=sn(l,"anchor",["start","middle","end"]),this.frameAnchor=Yo(u)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,length:u,rotate:f}=r,{length:h,rotate:d,anchor:p,shape:m,r:y}=this,[g,x]=bn(this,i);return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(b=>b.selectAll().data(t).enter().append("path").call(Lt,this).attr("transform",oc`translate(${c?w=>c[w]:g},${l?w=>l[w]:x})${f?w=>` rotate(${f[w]})`:d?` rotate(${d})`:""}${p==="start"?"":p==="end"?u?w=>` translate(0,${u[w]})`:` translate(0,${h})`:u?w=>` translate(0,${u[w]/2})`:` translate(0,${h/2})`}`).attr("d",u?w=>{let _=nr();return m.draw(_,u[w],y),_}:(()=>{let w=nr();return m.draw(w,h,y),w})()).call(Qt,this,r)).node()}};function WT(e,t={}){let{x:n,y:r,...i}=t;return t.frameAnchor===void 0&&([n,r]=Pe(n,r)),new Fl(e,{...i,x:n,y:r})}function Gw(e,t={}){let{x:n=G,...r}=t;return new Fl(e,{...r,x:n})}function Ww(e,t={}){let{y:n=G,...r}=t;return new Fl(e,{...r,y:n})}function t$(e,t={}){let{shape:n=K7,stroke:r=Z7.stroke,strokeWidth:i=1,fill:o=r,fillOpacity:s=.3,anchor:a="start",...c}=t;return WT(e,{...c,shape:n,stroke:r,strokeWidth:i,fill:o,fillOpacity:s,anchor:a})}function sc(e,t){return arguments.length<2&&!lr(e)&&(t=e,e=null),t===void 0&&(t={}),[e,t]}function Hw({anchor:e}={},t){return e===void 0?t[0]:sn(e,"anchor",t)}function e$(e){return Hw(e,["left","right"])}function n$(e){return Hw(e,["right","left"])}function r$(e){return Hw(e,["bottom","top"])}function i$(e){return Hw(e,["top","bottom"])}function sy(){let[e,t]=sc(...arguments);return o$("y",e$(t),e,t)}function Zw(){let[e,t]=sc(...arguments);return o$("fy",n$(t),e,t)}function ay(){let[e,t]=sc(...arguments);return s$("x",r$(t),e,t)}function Jw(){let[e,t]=sc(...arguments);return s$("fx",i$(t),e,t)}function o$(e,t,n,{color:r="currentColor",opacity:i=1,stroke:o=r,strokeOpacity:s=i,strokeWidth:a=1,fill:c=r,fillOpacity:l=i,textAnchor:u,textStroke:f,textStrokeOpacity:h,textStrokeWidth:d,tickSize:p=e==="y"?6:0,tickPadding:m,tickRotate:y,x:g,margin:x,marginTop:b=x===void 0?20:x,marginRight:w=x===void 0?t==="right"?40:0:x,marginBottom:_=x===void 0?20:x,marginLeft:v=x===void 0?t==="left"?40:0:x,label:M,labelAnchor:E,labelArrow:I,labelOffset:D,...A}){return p=Bt(p),m=Bt(m),y=Bt(y),E!==void 0&&(E=sn(E,"labelAnchor",["center","top","bottom"])),I=p$(I),tn(p&&!re(o)?JQ(e,t,n,{stroke:o,strokeOpacity:s,strokeWidth:a,tickSize:p,tickPadding:m,tickRotate:y,x:g,...A}):null,re(c)?null:KQ(e,t,n,{fill:c,fillOpacity:l,stroke:f,strokeOpacity:h,strokeWidth:d,textAnchor:u,tickSize:p,tickPadding:m,tickRotate:y,x:g,marginTop:b,marginRight:w,marginBottom:_,marginLeft:v,...A}),!re(c)&&M!==null?Wo([],u$({fill:c,fillOpacity:l,...A},function(O,C,S,T,N){let F=T[e],{marginTop:R,marginRight:k,marginBottom:$,marginLeft:P}=e==="y"&&N.inset||N,U=E??(F.bandwidth?"center":"top"),W=D??(t==="right"?k:P)-3;return U==="center"?(this.textAnchor=void 0,this.lineAnchor=t==="right"?"bottom":"top",this.frameAnchor=t,this.rotate=-90):(this.textAnchor=t==="right"?"end":"start",this.lineAnchor=U,this.frameAnchor=`${U}-${t}`,this.rotate=0),this.dy=U==="top"?3-R:U==="bottom"?$-3:0,this.dx=t==="right"?W:-W,this.ariaLabel=`${e}-axis label`,{facets:[[0]],channels:{text:{value:[d$(e,F,{anchor:t,label:M,labelAnchor:U,labelArrow:I})]}}}})):null)}function s$(e,t,n,{color:r="currentColor",opacity:i=1,stroke:o=r,strokeOpacity:s=i,strokeWidth:a=1,fill:c=r,fillOpacity:l=i,textAnchor:u,textStroke:f,textStrokeOpacity:h,textStrokeWidth:d,tickSize:p=e==="x"?6:0,tickPadding:m,tickRotate:y,y:g,margin:x,marginTop:b=x===void 0?t==="top"?30:0:x,marginRight:w=x===void 0?20:x,marginBottom:_=x===void 0?t==="bottom"?30:0:x,marginLeft:v=x===void 0?20:x,label:M,labelAnchor:E,labelArrow:I,labelOffset:D,...A}){return p=Bt(p),m=Bt(m),y=Bt(y),E!==void 0&&(E=sn(E,"labelAnchor",["center","left","right"])),I=p$(I),tn(p&&!re(o)?QQ(e,t,n,{stroke:o,strokeOpacity:s,strokeWidth:a,tickSize:p,tickPadding:m,tickRotate:y,y:g,...A}):null,re(c)?null:tK(e,t,n,{fill:c,fillOpacity:l,stroke:f,strokeOpacity:h,strokeWidth:d,textAnchor:u,tickSize:p,tickPadding:m,tickRotate:y,y:g,marginTop:b,marginRight:w,marginBottom:_,marginLeft:v,...A}),!re(c)&&M!==null?Wo([],u$({fill:c,fillOpacity:l,...A},function(O,C,S,T,N){let F=T[e],{marginTop:R,marginRight:k,marginBottom:$,marginLeft:P}=e==="x"&&N.inset||N,U=E??(F.bandwidth?"center":"right"),W=D??(t==="top"?R:$)-3;return U==="center"?(this.frameAnchor=t,this.textAnchor=void 0):(this.frameAnchor=`${t}-${U}`,this.textAnchor=U==="right"?"end":"start"),this.lineAnchor=t,this.dy=t==="top"?-W:W,this.dx=U==="right"?k-3:U==="left"?3-P:0,this.ariaLabel=`${e}-axis label`,{facets:[[0]],channels:{text:{value:[d$(e,F,{anchor:t,label:M,labelAnchor:U,labelArrow:I})]}}}})):null)}function JQ(e,t,n,{strokeWidth:r=1,strokeLinecap:i=null,strokeLinejoin:o=null,facetAnchor:s=t+(e==="y"?"-empty":""),frameAnchor:a=t,tickSize:c,inset:l=0,insetLeft:u=l,insetRight:f=l,dx:h=0,y:d=e==="y"?void 0:null,...p}){return Xf(Ww,e,n,{ariaLabel:`${e}-axis tick`,ariaHidden:!0},{strokeWidth:r,strokeLinecap:i,strokeLinejoin:o,facetAnchor:s,frameAnchor:a,y:d,...p,dx:t==="left"?+h-Ce+ +u:+h+Ce-f,anchor:"start",length:c,shape:t==="left"?iK:oK})}function QQ(e,t,n,{strokeWidth:r=1,strokeLinecap:i=null,strokeLinejoin:o=null,facetAnchor:s=t+(e==="x"?"-empty":""),frameAnchor:a=t,tickSize:c,inset:l=0,insetTop:u=l,insetBottom:f=l,dy:h=0,x:d=e==="x"?void 0:null,...p}){return Xf(Gw,e,n,{ariaLabel:`${e}-axis tick`,ariaHidden:!0},{strokeWidth:r,strokeLinejoin:o,strokeLinecap:i,facetAnchor:s,frameAnchor:a,x:d,...p,dy:t==="bottom"?+h-Ce-f:+h+Ce+ +u,anchor:"start",length:c,shape:t==="bottom"?nK:rK})}function KQ(e,t,n,{facetAnchor:r=t+(e==="y"?"-empty":""),frameAnchor:i=t,tickSize:o,tickRotate:s=0,tickPadding:a=Math.max(3,9-o)+(Math.abs(s)>60?4*Math.cos(s*Vf):0),text:c,textAnchor:l=Math.abs(s)>60?"middle":t==="left"?"end":"start",lineAnchor:u=s>60?"top":s<-60?"bottom":"middle",fontVariant:f,inset:h=0,insetLeft:d=h,insetRight:p=h,dx:m=0,y=e==="y"?void 0:null,...g}){return Xf(Vw,e,n,{ariaLabel:`${e}-axis tick label`},{facetAnchor:r,frameAnchor:i,text:c,textAnchor:l,lineAnchor:u,fontVariant:f,rotate:s,y,...g,dx:t==="left"?+m-o-a+ +d:+m+ +o+ +a-p},function(x,b,w,_,v){f===void 0&&(this.fontVariant=h$(x)),c===void 0&&(v.text=f$(x,b,w,_,t))})}function tK(e,t,n,{facetAnchor:r=t+(e==="x"?"-empty":""),frameAnchor:i=t,tickSize:o,tickRotate:s=0,tickPadding:a=Math.max(3,9-o)+(Math.abs(s)>=10?4*Math.cos(s*Vf):0),text:c,textAnchor:l=Math.abs(s)>=10?s<0^t==="bottom"?"start":"end":"middle",lineAnchor:u=Math.abs(s)>=10?"middle":t==="bottom"?"top":"bottom",fontVariant:f,inset:h=0,insetTop:d=h,insetBottom:p=h,dy:m=0,x:y=e==="x"?void 0:null,...g}){return Xf(jw,e,n,{ariaLabel:`${e}-axis tick label`},{facetAnchor:r,frameAnchor:i,text:c===void 0?null:c,textAnchor:l,lineAnchor:u,fontVariant:f,rotate:s,x:y,...g,dy:t==="bottom"?+m+ +o+ +a-p:+m-o-a+ +d},function(x,b,w,_,v){f===void 0&&(this.fontVariant=h$(x)),c===void 0&&(v.text=f$(x,b,w,_,t))})}function Qw(){let[e,t]=sc(...arguments);return a$("y",e$(t),e,t)}function Kw(){let[e,t]=sc(...arguments);return a$("fy",n$(t),e,t)}function tv(){let[e,t]=sc(...arguments);return c$("x",r$(t),e,t)}function ev(){let[e,t]=sc(...arguments);return c$("fx",i$(t),e,t)}function a$(e,t,n,{y:r=e==="y"?void 0:null,x:i=null,x1:o=t==="left"?i:null,x2:s=t==="right"?i:null,...a}){return Xf(Xr,e,n,{ariaLabel:`${e}-grid`,ariaHidden:!0},{y:r,x1:o,x2:s,...l$(a)})}function c$(e,t,n,{x:r=e==="x"?void 0:null,y:i=null,y1:o=t==="top"?i:null,y2:s=t==="bottom"?i:null,...a}){return Xf(Yr,e,n,{ariaLabel:`${e}-grid`,ariaHidden:!0},{x:r,y1:o,y2:s,...l$(a)})}function l$({color:e="currentColor",opacity:t=.1,stroke:n=e,strokeOpacity:r=t,strokeWidth:i=1,...o}){return{stroke:n,strokeOpacity:r,strokeWidth:i,...o}}function u$({fill:e,fillOpacity:t,fontFamily:n,fontSize:r,fontStyle:i,fontVariant:o,fontWeight:s,monospace:a,pointerEvents:c,shapeRendering:l,clip:u=!1},f){return[,e]=Be(e),[,t]=se(t),{facet:"super",x:null,y:null,fill:e,fillOpacity:t,fontFamily:n,fontSize:r,fontStyle:i,fontVariant:o,fontWeight:s,monospace:a,pointerEvents:c,shapeRendering:l,clip:u,initializer:f}}function Xf(e,t,n,r,i,o){let s;function a(u,f,h,d,p,m){let y=u==null&&(t==="fx"||t==="fy"),{[t]:g}=d;if(!g)throw new Error(`missing scale: ${t}`);let x=g.domain(),{interval:b,ticks:w,tickFormat:_,tickSpacing:v=t==="x"?80:35}=i;if(typeof w=="string"&&m$(g)&&(b=w,w=void 0),w===void 0&&(w=Vo(b,g.type)??eK(g,v)),u==null){if(lr(w))u=je(w);else if(Za(w))u=HT(w,...le(x));else if(g.interval){let E=g.interval;if(g.ticks){let[I,D]=le(x),A=(D-I)/E[Sf];E=XA(E,A/w)??E,u=HT(E,I,D)}else{u=x;let I=u.length;E=XA(E,I/w)??E,E!==g.interval&&(u=HT(E,...le(u)))}if(E===g.interval){let I=Math.round(u.length/w);I>1&&(u=u.filter((D,A)=>A%I===0))}}else g.ticks?u=g.ticks(w):u=x;if(!g.ticks&&u.length&&u!==x){let E=new Qn(x);u=u.filter(I=>E.has(I)),u.length||Vn(`Warning: the ${t}-axis ticks appear to not align with the scale domain, resulting in no ticks. Try different ticks?`)}t==="y"||t==="x"?f=[cr(u)]:s[t]={scale:t,value:G}}o?.call(this,g,u,w,_,s);let M=Object.fromEntries(Object.entries(s).map(([E,I])=>[E,{...I,value:wt(u,I.value)}]));return y&&(f=m.filterFacets(u,M)),{data:u,facets:f,channels:M}}let c=Ie(i).initializer,l=e(n,Ie({...i,initializer:a},c));return n==null?(s=l.channels,l.channels={}):s={},r!==void 0&&Object.assign(l,r),l.clip===void 0&&(l.clip=!1),l}function eK(e,t){let[n,r]=le(e.range());return(r-n)/t}function f$(e,t,n,r,i){return{value:cy(e,t,n,r,i)}}function cy(e,t,n,r,i){return typeof r=="function"?r:r===void 0&&t&&Le(t)?YF(e.type,t,i)??Yi:e.tickFormat?e.tickFormat(typeof n=="number"?n:null,r):r===void 0?Yi:typeof r=="string"?(Le(e.domain())?Po:pi)(r):pn(r)}function HT(e,t,n){return e.range(t,e.offset(e.floor(n)))}var nK={draw(e,t){e.moveTo(0,0),e.lineTo(0,t)}},rK={draw(e,t){e.moveTo(0,0),e.lineTo(0,-t)}},iK={draw(e,t){e.moveTo(0,0),e.lineTo(-t,0)}},oK={draw(e,t){e.moveTo(0,0),e.lineTo(t,0)}};function h$(e){return e.bandwidth&&!e.interval?void 0:"tabular-nums"}function d$(e,t,{anchor:n,label:r=t.label,labelAnchor:i,labelArrow:o}={}){if(!(r==null||r.inferred&&m$(t)&&/^(date|time|year)$/i.test(r))){if(r=String(r),o==="auto"&&(o=(!t.bandwidth||t.interval)&&!/[↑↓→←]/.test(r)),!o)return r;if(o===!0){let s=Aw(t);s&&(o=/x$/.test(e)||i==="center"?/x$/.test(e)===s<0?"left":"right":s<0?"up":"down")}switch(o){case"left":return`\u2190 ${r}`;case"right":return`${r} \u2192`;case"up":return n==="right"?`${r} \u2191`:`\u2191 ${r}`;case"down":return n==="right"?`${r} \u2193`:`\u2193 ${r}`}return r}}function p$(e="auto"){return re(e)?!1:typeof e=="boolean"?e:sn(e,"labelArrow",["auto","up","right","down","left"])}function m$(e){return Le(e.domain())}function y$(e,t){if(t==null)return t;let n=e(t);if(!n)throw new Error(`scale not found: ${t}`);return n}function g$(e,{opacity:t,...n}={}){if(!Go(e)&&!NT(e))throw new Error(`swatches legend requires ordinal or threshold color scale (not ${e.type})`);return b$(e,n,(r,i,o,s)=>r.append("svg").attr("width",o).attr("height",s).attr("fill",i.scale).attr("fill-opacity",se(t)[1]).append("rect").attr("width","100%").attr("height","100%"))}function x$(e,{fill:t=e.hint?.fill!==void 0?e.hint.fill:"none",fillOpacity:n=1,stroke:r=e.hint?.stroke!==void 0?e.hint.stroke:re(t)?"currentColor":"none",strokeOpacity:i=1,strokeWidth:o=1.5,r:s=4.5,...a}={},c){let[l,u]=Be(t),[f,h]=Be(r),d=y$(c,l),p=y$(c,f),m=s*s*Math.PI;return n=se(n)[1],i=se(i)[1],o=se(o)[1],b$(e,a,(y,g,x,b)=>y.append("svg").attr("viewBox","-8 -8 16 16").attr("width",x).attr("height",b).attr("fill",l==="color"?w=>d.scale(w):u).attr("fill-opacity",n).attr("stroke",f==="color"?w=>p.scale(w):h).attr("stroke-opacity",i).attr("stroke-width",o).append("path").attr("d",w=>{let _=nr();return e.scale(w).draw(_,m),_}))}function b$(e,t={},n){let{columns:r,tickFormat:i,fontVariant:o=Rw(e),swatchSize:s=15,swatchWidth:a=s,swatchHeight:c=s,marginLeft:l=0,className:u,style:f,width:h}=t,d=ec(t);u=Pf(u),i=cy(e.scale,e.domain,void 0,i);let p=ut("div",d).attr("class",`${u}-swatches ${u}-swatches-${r!=null?"columns":"wrap"}`),m;return r!=null?(m=`:where(.${u}-swatches-columns .${u}-swatch) {
|
|
28
28
|
display: flex;
|
|
29
29
|
align-items: center;
|
|
30
30
|
break-inside: avoid;
|
|
@@ -37,7 +37,7 @@ ${n}`}function YZ(e){return e==="time"?iw:e==="utc"?Lm:jZ}function kF(e,t,n){let
|
|
|
37
37
|
white-space: nowrap;
|
|
38
38
|
overflow: hidden;
|
|
39
39
|
text-overflow: ellipsis;
|
|
40
|
-
}`,p.style("columns",r).selectAll().data(e.domain).enter().append("div").attr("class",`${u}-swatch`).call(n,e,a,c).call(
|
|
40
|
+
}`,p.style("columns",r).selectAll().data(e.domain).enter().append("div").attr("class",`${u}-swatch`).call(n,e,a,c).call(y=>y.append("div").attr("class",`${u}-swatch-label`).attr("title",i).text(i))):(m=`:where(.${u}-swatches-wrap) {
|
|
41
41
|
display: flex;
|
|
42
42
|
align-items: center;
|
|
43
43
|
min-height: 33px;
|
|
@@ -47,7 +47,7 @@ ${n}`}function YZ(e){return e==="time"?iw:e==="utc"?Lm:jZ}function kF(e,t,n){let
|
|
|
47
47
|
display: inline-flex;
|
|
48
48
|
align-items: center;
|
|
49
49
|
margin-right: 1em;
|
|
50
|
-
}`,p.selectAll().data(e.domain).enter().append("span").attr("class",`${u}-swatch`).call(n,e,a,c).append(function(){return this.ownerDocument.createTextNode(i.apply(this,arguments))})),p.call(
|
|
50
|
+
}`,p.selectAll().data(e.domain).enter().append("span").attr("class",`${u}-swatch`).call(n,e,a,c).append(function(){return this.ownerDocument.createTextNode(i.apply(this,arguments))})),p.call(y=>y.insert("style","*").text(`:where(.${u}-swatches) {
|
|
51
51
|
font-family: system-ui, sans-serif;
|
|
52
52
|
font-size: 10px;
|
|
53
53
|
margin-bottom: 0.5em;
|
|
@@ -56,7 +56,7 @@ ${n}`}function YZ(e){return e==="time"?iw:e==="utc"?Lm:jZ}function kF(e,t,n){let
|
|
|
56
56
|
margin-right: 0.5em;
|
|
57
57
|
overflow: visible;
|
|
58
58
|
}
|
|
59
|
-
${m}`)).style("margin-left",l?`${+l}px`:null).style("width",d===void 0?null:`${+d}px`).style("font-variant",fe(o,"normal")).call(Cf,f).node()}var tv=new Map([["symbol",c$],["color",d$],["opacity",LQ]]);function u$(e={}){for(let[t,n]of tv){let r=e[t];if(Lo(r)){let i=nc(e),o;if(t==="symbol"){let{fill:s,stroke:a=s===void 0&&Lo(e.color)?"color":void 0}=e;o={fill:s,stroke:a}}return n(Dw(t,r,o),YT(i,r,e),s=>Lo(e[s])?Dw(s,e[s]):null)}}throw new Error("unknown legend type; no scale found")}function f$(e,t,n={}){return(r,i)=>{if(!tv.has(r))throw new Error(`unknown legend type: ${r}`);if(r in e)return tv.get(r)(e[r],YT(t,n[r],i),o=>e[o])}}function YT({className:e,...t},{label:n,ticks:r,tickFormat:i}={},o){return HF(o,{className:e,...t},{label:n,ticks:r,tickFormat:i})}function d$(e,{legend:t=!0,...n}){if(t===!0&&(t=e.type==="ordinal"?"swatches":"ramp"),e.domain!==void 0)switch(`${t}`.toLowerCase()){case"swatches":return a$(e,n);case"ramp":return S7(e,n);default:throw new Error(`unknown legend type: ${t}`)}}function LQ({type:e,interpolate:t,...n},{legend:r=!0,color:i=on(0,0,0),...o}){if(!t)throw new Error(`${e} opacity scales are not supported`);if(r===!0&&(r="ramp"),`${r}`.toLowerCase()!=="ramp")throw new Error(`${r} opacity legends are not supported`);return d$({type:e,...n,interpolate:CQ(i)},{legend:r,...o})}function CQ(e){let{r:t,g:n,b:r}=on(e)||on(0,0,0);return i=>`rgba(${t},${n},${r},${i})`}function h$(e,t,n){let r=[];for(let[i,o]of tv){let s=n[i];if(s?.legend&&i in e){let a=o(e[i],YT(t,e[i],s),c=>e[c]);a!=null&&r.push(a)}}return r}var kQ={ariaLabel:"frame",fill:"none",stroke:"currentColor",clip:!1},FQ={ariaLabel:"frame",fill:null,stroke:"currentColor",strokeLinecap:"square",clip:!1},Km=class extends St{constructor(t={}){let{anchor:n=null,inset:r=0,insetTop:i=r,insetRight:o=r,insetBottom:s=r,insetLeft:a=r,rx:c,ry:l}=t;super(Wa,void 0,t,n==null?kQ:FQ),this.anchor=GA(n,"anchor",["top","right","bottom","left"]),this.insetTop=Bt(i),this.insetRight=Bt(o),this.insetBottom=Bt(s),this.insetLeft=Bt(a),this.rx=Bt(c),this.ry=Bt(l)}render(t,n,r,i,o){let{marginTop:s,marginRight:a,marginBottom:c,marginLeft:l,width:u,height:f}=i,{anchor:d,insetTop:h,insetRight:p,insetBottom:m,insetLeft:g,rx:y,ry:x}=this,b=l+g,w=u-a-p,v=s+h,_=f-c-m;return ut(d?"svg:line":"svg:rect",o).datum(0).call(Ct,this,i,o).call(Lt,this).call(Qt,this,r).call(Et,this,{}).call(d==="left"?I=>I.attr("x1",b).attr("x2",b).attr("y1",v).attr("y2",_):d==="right"?I=>I.attr("x1",w).attr("x2",w).attr("y1",v).attr("y2",_):d==="top"?I=>I.attr("x1",b).attr("x2",w).attr("y1",v).attr("y2",v):d==="bottom"?I=>I.attr("x1",b).attr("x2",w).attr("y1",_).attr("y2",_):I=>I.attr("x",b).attr("y",v).attr("width",w-b).attr("height",_-v).attr("rx",y).attr("ry",x)).node()}};function Gf(e){return new Km(e)}var XT={ariaLabel:"tip",fill:"var(--plot-background)",stroke:"currentColor"},RQ=new Set(["geometry","href","src","ariaLabel","scales"]),ty=class extends St{constructor(t,n={}){n.tip&&(n={...n,tip:!1}),n.title===void 0&&cr(t)&&cw(t)&&(n={...n,title:G});let{x:r,y:i,x1:o,x2:s,y1:a,y2:c,anchor:l,preferredAnchor:u="bottom",monospace:f,fontFamily:d=f?"ui-monospace, monospace":void 0,fontSize:h,fontStyle:p,fontVariant:m,fontWeight:g,lineHeight:y=1,lineWidth:x=20,frameAnchor:b,format:w,textAnchor:v="start",textOverflow:_,textPadding:I=8,title:D,pointerSize:A=12,pathFilter:E="drop-shadow(0 3px 4px rgba(0,0,0,0.2))"}=n;super(t,{x:{value:o!=null&&s!=null?null:r,scale:"x",optional:!0},y:{value:a!=null&&c!=null?null:i,scale:"y",optional:!0},x1:{value:o,scale:"x",optional:s==null},y1:{value:a,scale:"y",optional:c==null},x2:{value:s,scale:"x",optional:o==null},y2:{value:c,scale:"y",optional:a==null},title:{value:D,optional:!0}},n,XT),this.anchor=uw(l,"anchor"),this.preferredAnchor=uw(u,"preferredAnchor"),this.frameAnchor=Fo(b),this.textAnchor=fe(v,"middle"),this.textPadding=+I,this.pointerSize=+A,this.pathFilter=qe(E),this.lineHeight=+y,this.lineWidth=+x,this.textOverflow=PT(_),this.monospace=!!f,this.fontFamily=qe(d),this.fontSize=Bt(h),this.fontStyle=qe(p),this.fontVariant=qe(m),this.fontWeight=qe(g);for(let T in XT)T in this.channels&&(this[T]=XT[T]);this.splitLines=zT(this),this.clipLine=qT(this),this.format={...w}}render(t,n,r,i,o){let s=this,{x:a,y:c,fx:l,fy:u}=n,{ownerSVGElement:f,document:d}=o,{anchor:h,monospace:p,lineHeight:m,lineWidth:g}=this,{textPadding:y,pointerSize:x,pathFilter:b}=this,{marginTop:w,marginLeft:v}=i,{x1:_,y1:I,x2:D,y2:A,x:E=_??D,y:T=I??A}=r,O=l?l(t.fx)-v:0,C=u?u(t.fy)-w:0,[S,M]=gn(this,i),N=BT(r,S),F=LT(r,M),R=p?Vw:jw,k=R(Ol),$,P;"title"in r?($=r.channels,P=qQ):($=zQ.call(this,r,n),P=jQ);let U=ut("svg:g",o).call(Ct,this,i,o).call(UT,this).call(Et,this,{x:E&&a,y:T&&c}).call(nt=>nt.selectAll().data(t).enter().append("g").attr("transform",at=>`translate(${Math.round(N(at))},${Math.round(F(at))})`).call(Lt,this).call(at=>at.append("path").attr("filter",b)).call(at=>at.append("text").each(function(Y){let rt=Vt(this);this.setAttribute("fill","currentColor"),this.setAttribute("fill-opacity",1),this.setAttribute("stroke","none");let j=P.call(s,Y,t,$,n,r);if(typeof j=="string")for(let H of s.splitLines(j))W(rt,{value:s.clipLine(H)});else{let H=new Set;for(let ot of j){let{label:z=""}=ot;z&&H.has(z)||(H.add(z),W(rt,ot))}}})));function W(nt,{label:at,value:Y,color:rt,opacity:j}){at??="",Y??="";let H=rt!=null||j!=null,ot,z=g*100,[kt]=Ll(at,z,R,k);if(kt>=0)at=at.slice(0,kt).trimEnd()+Ol,ot=Y.trim(),Y="";else{(at||!Y&&!H)&&(Y=" "+Y);let[Ht]=Ll(Y,z-R(at),R,k);Ht>=0&&(ot=Y.trim(),Y=Y.slice(0,Ht).trimEnd()+Ol)}let dt=nt.append("tspan").attr("x",0).attr("dy",`${m}em`).text("\u200B");at&&dt.append("tspan").attr("font-weight","bold").text(at),Y&&dt.append(()=>d.createTextNode(Y)),H&&dt.append("tspan").text(" \u25A0").attr("fill",rt).attr("fill-opacity",j).style("user-select","none"),ot&&dt.append("title").text(ot)}function tt(){let{width:nt,height:at}=i.facet??i;U.selectChildren().each(function(Y){let{x:rt,width:j,height:H}=this.getBBox();j=Math.round(j),H=Math.round(H);let ot=h;if(ot===void 0){let dt=N(Y)+O,Ht=F(Y)+C,Zt=dt+j+x+y*2<nt,et=dt-j-x-y*2>0,ae=Ht+H+x+y*2<at,Sr=Ht-H-x-y*2>0;ot=Zt&&et?ae&&Sr?s.preferredAnchor:Sr?"bottom":"top":ae&&Sr?Zt?"left":"right":(Zt||et)&&(ae||Sr)?`${Sr?"bottom":"top"}-${Zt?"left":"right"}`:s.preferredAnchor}let z=this.firstChild,kt=this.lastChild;if(z.setAttribute("d",UQ(ot,x,y,j,H)),rt)for(let dt of kt.childNodes)dt.setAttribute("x",-rt);kt.setAttribute("y",`${+$Q(ot,kt.childNodes.length,m).toFixed(6)}em`),kt.setAttribute("transform",`translate(${PQ(ot,x,y,j,H)})`)}),U.attr("visibility",null)}return t.length&&(U.attr("visibility","hidden"),f.isConnected?Promise.resolve().then(tt):typeof requestAnimationFrame<"u"&&requestAnimationFrame(tt)),U.node()}};function nv(e,{x:t,y:n,...r}={}){return r.frameAnchor===void 0&&([t,n]=$e(t,n)),new ty(e,{...r,x:t,y:n})}function $Q(e,t,n){return/^top(?:-|$)/.test(e)?.94-n:-.29-t*n}function PQ(e,t,n,r,i){switch(e){case"middle":return[-r/2,i/2];case"top-left":return[n,t+n];case"top":return[-r/2,t/2+n];case"top-right":return[-r-n,t+n];case"right":return[-t/2-r-n,i/2];case"bottom-left":return[n,-t-n];case"bottom":return[-r/2,-t/2-n];case"bottom-right":return[-r-n,-t-n];case"left":return[n+t/2,i/2]}}function UQ(e,t,n,r,i){let o=r+n*2,s=i+n*2;switch(e){case"middle":return`M${-o/2},${-s/2}h${o}v${s}h${-o}z`;case"top-left":return`M0,0l${t},${t}h${o-t}v${s}h${-o}z`;case"top":return`M0,0l${t/2},${t/2}h${(o-t)/2}v${s}h${-o}v${-s}h${(o-t)/2}z`;case"top-right":return`M0,0l${-t},${t}h${t-o}v${s}h${o}z`;case"right":return`M0,0l${-t/2},${-t/2}v${t/2-s/2}h${-o}v${s}h${o}v${t/2-s/2}z`;case"bottom-left":return`M0,0l${t},${-t}h${o-t}v${-s}h${-o}z`;case"bottom":return`M0,0l${t/2},${-t/2}h${(o-t)/2}v${-s}h${-o}v${s}h${(o-t)/2}z`;case"bottom-right":return`M0,0l${-t},${-t}h${t-o}v${-s}h${o}z`;case"left":return`M0,0l${t/2},${-t/2}v${t/2-s/2}h${o}v${s}h${-o}v${t/2-s/2}z`}}function zQ({channels:e},t){let n={},r=this.format;r=p$(r,e,"x"),r=p$(r,e,"y"),this.format=r;for(let i in r){let o=r[i];if(!(o===null||o===!1))if(i==="fx"||i==="fy")n[i]=!0;else{let s=qm(e,i);s&&(n[i]=s)}}for(let i in e){if(i in n||i in r||RQ.has(i))continue;let o=qm(e,i);o&&(n[i]=o)}this.facet&&(t.fx&&!("fx"in r)&&(n.fx=!0),t.fy&&!("fy"in r)&&(n.fy=!0));for(let i in n){let o=this.format[i];if(typeof o=="string"){let s=n[i]?.value??t[i]?.domain()??[];this.format[i]=(Le(s)?Do:ci)(o)}else if(o===void 0||o===!0){let s=t[i];this.format[i]=s?.bandwidth?Qm(s,s.domain()):ji}}return n}function p$(e,t,n){if(!(n in e))return e;let r=`${n}1`,i=`${n}2`;if((r in e||!(r in t))&&(i in e||!(i in t)))return e;let o=Object.entries(e),s=e[n];return o.splice(o.findIndex(([a])=>a===n)+1,0,[r,s],[i,s]),Object.fromEntries(o)}function qQ(e,t,{title:n}){return ji(n.value[e],e)}function*jQ(e,t,n,r,i){for(let o in n){if(o==="fx"||o==="fy"){yield{label:ev(r,n,o),value:this.format[o](t[o],e)};continue}if(o==="x1"&&"x2"in n||o==="y1"&&"y2"in n)continue;let s=n[o];if(o==="x2"&&"x1"in n)yield{label:y$(r,n,"x"),value:m$(this.format.x2,n.x1,s,e)};else if(o==="y2"&&"y1"in n)yield{label:y$(r,n,"y"),value:m$(this.format.y2,n.y1,s,e)};else{let a=s.value[e],c=s.scale;if(!ze(a)&&c==null)continue;yield{label:ev(r,n,o),value:this.format[o](a,e),color:c==="color"?i[o][e]:null,opacity:c==="opacity"?i[o][e]:null}}}}function m$(e,t,n,r){return n.hint?.length?`${e(n.value[r]-t.value[r],r)}`:`${e(t.value[r],r)}\u2013${e(n.value[r],r)}`}function y$(e,t,n){let r=ev(e,t,`${n}1`,n),i=ev(e,t,`${n}2`,n);return r===i?r:`${r}\u2013${i}`}function ev(e,t,n,r=n){let i=t[n],o=e[i?.scale??n];return String(o?.label??i?.label??r)}function ny(e={}){let{facet:t,style:n,title:r,subtitle:i,caption:o,ariaLabel:s,ariaDescription:a}=e,c=Lf(e.className),l=e.marks===void 0?[]:x$(e.marks);l.push(...ZQ(l));let u=WQ(t,e),f=new Map;for(let k of l){let $=b$(k,u,e);$&&f.set(k,$)}let d=new Map;u&&ey(d,[u],e),ey(d,f,e);let h=x$(JQ(l,d,e));for(let k of h){let $=b$(k,u,e);$&&f.set(k,$)}l.unshift(...h);let p=g7(d,e);if(p!==void 0){let k=u?Cw(p,u):void 0;for(let P of l){if(P.facet===null||P.facet==="super")continue;let U=f.get(P);U!==void 0&&(U.facetsIndex=P.fx!=null||P.fy!=null?Cw(p,U):k)}let $=new Set;for(let{facetsIndex:P}of f.values())P?.forEach((U,W)=>{U?.length>0&&$.add(W)});p.forEach(0<$.size&&$.size<p.length?(P,U)=>P.empty=!$.has(U):P=>P.empty=!1);for(let P of l)if(P.facet==="exclude"){let U=f.get(P);U!==void 0&&(U.facetsIndex=w7(U.facetsIndex))}}for(let k of de.keys())Lo(e[k])&&k!=="fx"&&k!=="fy"&&d.set(k,[]);let m=new Map;for(let k of l){if(m.has(k))throw new Error("duplicate mark; each mark must be unique");let{facetsIndex:$,channels:P}=f.get(k)??{},{data:U,facets:W,channels:tt}=k.initialize($,P,e);HT(tt,e),m.set(k,{data:U,facets:W,channels:tt})}let g=Gm(ey(d,m,e),e),y=m7(g,l,e);c7(g,y);let x=ST(g),{fx:b,fy:w}=x,v=b||w?IT(g,y):y,_=b||w?iK(x,y):y,I=nc(e),D=I.document,A=Os("svg").call(D.documentElement),E=A;I.ownerSVGElement=A,I.className=c,I.projection=vR(e,v),I.filterFacets=(k,$)=>Cw(p,{channels:$,groups:Bw(k,$)}),I.getMarkState=k=>{let $=m.get(k),P=f.get(k);return{...$,channels:{...$.channels,...P?.channels}}},I.dispatchValue=k=>{E.value!==k&&(E.value=k,E.dispatchEvent(new Event("input",{bubbles:!0})))};let T=new Set;for(let[k,$]of m)if(k.initializer!=null){let P=k.facet==="super"?_:v,U=k.initializer($.data,$.facets,$.channels,x,P,I);if(U.data!==void 0&&($.data=U.data),U.facets!==void 0&&($.facets=U.facets),U.channels!==void 0){let{fx:W,fy:tt,...nt}=U.channels;GQ(nt),Object.assign($.channels,nt);for(let at of Object.values(nt)){let{scale:Y}=at;Y!=null&&!JF(de.get(Y))&&(_$(at,e),T.add(Y))}(W!=null||tt!=null)&&f.set(k,!0)}}if(T.size){let k=new Map;ey(k,m,e,W=>T.has(W)),ey(d,m,e,W=>T.has(W));let $=rK(Gm(k,e),g),{scales:P,...U}=ST($);Object.assign(g,$),Object.assign(x,U),Object.assign(x.scales,P)}let O,C;p!==void 0&&(O={x:b?.domain(),y:w?.domain()},p=x7(p,O),C=b7(b,w,y));for(let[k,$]of m)$.values=k.scale($.channels,x,I);let{width:S,height:M}=y;Vt(A).attr("class",c).attr("fill","currentColor").attr("font-family","system-ui, sans-serif").attr("font-size",10).attr("text-anchor","middle").attr("width",S).attr("height",M).attr("viewBox",`0 0 ${S} ${M}`).attr("aria-label",s).attr("aria-description",a).call(k=>k.append("style").text(`:where(.${c}) {
|
|
59
|
+
${m}`)).style("margin-left",l?`${+l}px`:null).style("width",h===void 0?null:`${+h}px`).style("font-variant",fe(o,"normal")).call(Uf,f).node()}var nv=new Map([["symbol",x$],["color",_$],["opacity",sK]]);function w$(e={}){for(let[t,n]of nv){let r=e[t];if(qo(r)){let i=ec(e),o;if(t==="symbol"){let{fill:s,stroke:a=s===void 0&&qo(e.color)?"color":void 0}=e;o={fill:s,stroke:a}}return n(Ew(t,r,o),ZT(i,r,e),s=>qo(e[s])?Ew(s,e[s]):null)}}throw new Error("unknown legend type; no scale found")}function v$(e,t,n={}){return(r,i)=>{if(!nv.has(r))throw new Error(`unknown legend type: ${r}`);if(r in e)return nv.get(r)(e[r],ZT(t,n[r],i),o=>e[o])}}function ZT({className:e,...t},{label:n,ticks:r,tickFormat:i}={},o){return oR(o,{className:e,...t},{label:n,ticks:r,tickFormat:i})}function _$(e,{legend:t=!0,...n}){if(t===!0&&(t=e.type==="ordinal"?"swatches":"ramp"),e.domain!==void 0)switch(`${t}`.toLowerCase()){case"swatches":return g$(e,n);case"ramp":return L7(e,n);default:throw new Error(`unknown legend type: ${t}`)}}function sK({type:e,interpolate:t,...n},{legend:r=!0,color:i=rn(0,0,0),...o}){if(!t)throw new Error(`${e} opacity scales are not supported`);if(r===!0&&(r="ramp"),`${r}`.toLowerCase()!=="ramp")throw new Error(`${r} opacity legends are not supported`);return _$({type:e,...n,interpolate:aK(i)},{legend:r,...o})}function aK(e){let{r:t,g:n,b:r}=rn(e)||rn(0,0,0);return i=>`rgba(${t},${n},${r},${i})`}function S$(e,t,n){let r=[];for(let[i,o]of nv){let s=n[i];if(s?.legend&&i in e){let a=o(e[i],ZT(t,e[i],s),c=>e[c]);a!=null&&r.push(a)}}return r}var cK={ariaLabel:"frame",fill:"none",stroke:"currentColor",clip:!1},lK={ariaLabel:"frame",fill:null,stroke:"currentColor",strokeLinecap:"square",clip:!1},ly=class extends St{constructor(t={}){let{anchor:n=null,inset:r=0,insetTop:i=r,insetRight:o=r,insetBottom:s=r,insetLeft:a=r,rx:c,ry:l}=t;super(Ga,void 0,t,n==null?cK:lK),this.anchor=JA(n,"anchor",["top","right","bottom","left"]),this.insetTop=Bt(i),this.insetRight=Bt(o),this.insetBottom=Bt(s),this.insetLeft=Bt(a),this.rx=Bt(c),this.ry=Bt(l)}render(t,n,r,i,o){let{marginTop:s,marginRight:a,marginBottom:c,marginLeft:l,width:u,height:f}=i,{anchor:h,insetTop:d,insetRight:p,insetBottom:m,insetLeft:y,rx:g,ry:x}=this,b=l+y,w=u-a-p,_=s+d,v=f-c-m;return ut(h?"svg:line":"svg:rect",o).datum(0).call(Ct,this,i,o).call(Lt,this).call(Qt,this,r).call(Et,this,{}).call(h==="left"?M=>M.attr("x1",b).attr("x2",b).attr("y1",_).attr("y2",v):h==="right"?M=>M.attr("x1",w).attr("x2",w).attr("y1",_).attr("y2",v):h==="top"?M=>M.attr("x1",b).attr("x2",w).attr("y1",_).attr("y2",_):h==="bottom"?M=>M.attr("x1",b).attr("x2",w).attr("y1",v).attr("y2",v):M=>M.attr("x",b).attr("y",_).attr("width",w-b).attr("height",v-_).attr("rx",g).attr("ry",x)).node()}};function Gf(e){return new ly(e)}var JT={ariaLabel:"tip",fill:"var(--plot-background)",stroke:"currentColor"},uK=new Set(["geometry","href","src","ariaLabel","scales"]),uy=class extends St{constructor(t,n={}){n.tip&&(n={...n,tip:!1}),n.title===void 0&&lr(t)&&uw(t)&&(n={...n,title:G});let{x:r,y:i,x1:o,x2:s,y1:a,y2:c,anchor:l,preferredAnchor:u="bottom",monospace:f,fontFamily:h=f?"ui-monospace, monospace":void 0,fontSize:d,fontStyle:p,fontVariant:m,fontWeight:y,lineHeight:g=1,lineWidth:x=20,frameAnchor:b,format:w,textAnchor:_="start",textOverflow:v,textPadding:M=8,title:E,pointerSize:I=12,pathFilter:D="drop-shadow(0 3px 4px rgba(0,0,0,0.2))"}=n;super(t,{x:{value:o!=null&&s!=null?null:r,scale:"x",optional:!0},y:{value:a!=null&&c!=null?null:i,scale:"y",optional:!0},x1:{value:o,scale:"x",optional:s==null},y1:{value:a,scale:"y",optional:c==null},x2:{value:s,scale:"x",optional:o==null},y2:{value:c,scale:"y",optional:a==null},title:{value:E,optional:!0}},n,JT),this.anchor=hw(l,"anchor"),this.preferredAnchor=hw(u,"preferredAnchor"),this.frameAnchor=Yo(b),this.textAnchor=fe(_,"middle"),this.textPadding=+M,this.pointerSize=+I,this.pathFilter=qe(D),this.lineHeight=+g,this.lineWidth=+x,this.textOverflow=VT(v),this.monospace=!!f,this.fontFamily=qe(h),this.fontSize=Bt(d),this.fontStyle=qe(p),this.fontVariant=qe(m),this.fontWeight=qe(y);for(let A in JT)A in this.channels&&(this[A]=JT[A]);this.splitLines=XT(this),this.clipLine=GT(this),this.format={...w}}render(t,n,r,i,o){let s=this,{x:a,y:c,fx:l,fy:u}=n,{ownerSVGElement:f,document:h}=o,{anchor:d,monospace:p,lineHeight:m,lineWidth:y}=this,{textPadding:g,pointerSize:x,pathFilter:b}=this,{marginTop:w,marginLeft:_}=i,{x1:v,y1:M,x2:E,y2:I,x:D=v??E,y:A=M??I}=r,O=l?l(t.fx)-_:0,C=u?u(t.fy)-w:0,[S,T]=bn(this,i),N=RT(r,S),F=$T(r,T),R=p?Xw:Yw,k=R(Ll),$,P;"title"in r?($=r.channels,P=mK):($=pK.call(this,r,n),P=yK);let U=ut("svg:g",o).call(Ct,this,i,o).call(YT,this).call(Et,this,{x:D&&a,y:A&&c}).call(ot=>ot.selectAll().data(t).enter().append("g").attr("transform",at=>`translate(${Math.round(N(at))},${Math.round(F(at))})`).call(Lt,this).call(at=>at.append("path").attr("filter",b)).call(at=>at.append("text").each(function(Y){let st=Vt(this);this.setAttribute("fill","currentColor"),this.setAttribute("fill-opacity",1),this.setAttribute("stroke","none");let j=P.call(s,Y,t,$,n,r);if(typeof j=="string")for(let Z of s.splitLines(j))W(st,{value:s.clipLine(Z)});else{let Z=new Set;for(let rt of j){let{label:z=""}=rt;z&&Z.has(z)||(Z.add(z),W(st,rt))}}})));function W(ot,{label:at,value:Y,color:st,opacity:j}){at??="",Y??="";let Z=st!=null||j!=null,rt,z=y*100,[kt]=kl(at,z,R,k);if(kt>=0)at=at.slice(0,kt).trimEnd()+Ll,rt=Y.trim(),Y="";else{(at||!Y&&!Z)&&(Y=" "+Y);let[Wt]=kl(Y,z-R(at),R,k);Wt>=0&&(rt=Y.trim(),Y=Y.slice(0,Wt).trimEnd()+Ll)}let ht=ot.append("tspan").attr("x",0).attr("dy",`${m}em`).text("\u200B");at&&ht.append("tspan").attr("font-weight","bold").text(at),Y&&ht.append(()=>h.createTextNode(Y)),Z&&ht.append("tspan").text(" \u25A0").attr("fill",st).attr("fill-opacity",j).style("user-select","none"),rt&&ht.append("title").text(rt)}function nt(){let{width:ot,height:at}=i.facet??i;U.selectChildren().each(function(Y){let{x:st,width:j,height:Z}=this.getBBox();j=Math.round(j),Z=Math.round(Z);let rt=d;if(rt===void 0){let ht=N(Y)+O,Wt=F(Y)+C,Zt=ht+j+x+g*2<ot,tt=ht-j-x-g*2>0,ae=Wt+Z+x+g*2<at,Ir=Wt-Z-x-g*2>0;rt=Zt&&tt?ae&&Ir?s.preferredAnchor:Ir?"bottom":"top":ae&&Ir?Zt?"left":"right":(Zt||tt)&&(ae||Ir)?`${Ir?"bottom":"top"}-${Zt?"left":"right"}`:s.preferredAnchor}let z=this.firstChild,kt=this.lastChild;if(z.setAttribute("d",dK(rt,x,g,j,Z)),st)for(let ht of kt.childNodes)ht.setAttribute("x",-st);kt.setAttribute("y",`${+fK(rt,kt.childNodes.length,m).toFixed(6)}em`),kt.setAttribute("transform",`translate(${hK(rt,x,g,j,Z)})`)}),U.attr("visibility",null)}return t.length&&(U.attr("visibility","hidden"),f.isConnected?Promise.resolve().then(nt):typeof requestAnimationFrame<"u"&&requestAnimationFrame(nt)),U.node()}};function iv(e,{x:t,y:n,...r}={}){return r.frameAnchor===void 0&&([t,n]=Pe(t,n)),new uy(e,{...r,x:t,y:n})}function fK(e,t,n){return/^top(?:-|$)/.test(e)?.94-n:-.29-t*n}function hK(e,t,n,r,i){switch(e){case"middle":return[-r/2,i/2];case"top-left":return[n,t+n];case"top":return[-r/2,t/2+n];case"top-right":return[-r-n,t+n];case"right":return[-t/2-r-n,i/2];case"bottom-left":return[n,-t-n];case"bottom":return[-r/2,-t/2-n];case"bottom-right":return[-r-n,-t-n];case"left":return[n+t/2,i/2]}}function dK(e,t,n,r,i){let o=r+n*2,s=i+n*2;switch(e){case"middle":return`M${-o/2},${-s/2}h${o}v${s}h${-o}z`;case"top-left":return`M0,0l${t},${t}h${o-t}v${s}h${-o}z`;case"top":return`M0,0l${t/2},${t/2}h${(o-t)/2}v${s}h${-o}v${-s}h${(o-t)/2}z`;case"top-right":return`M0,0l${-t},${t}h${t-o}v${s}h${o}z`;case"right":return`M0,0l${-t/2},${-t/2}v${t/2-s/2}h${-o}v${s}h${o}v${t/2-s/2}z`;case"bottom-left":return`M0,0l${t},${-t}h${o-t}v${-s}h${-o}z`;case"bottom":return`M0,0l${t/2},${-t/2}h${(o-t)/2}v${-s}h${-o}v${s}h${(o-t)/2}z`;case"bottom-right":return`M0,0l${-t},${-t}h${t-o}v${-s}h${o}z`;case"left":return`M0,0l${t/2},${-t/2}v${t/2-s/2}h${o}v${s}h${-o}v${t/2-s/2}z`}}function pK({channels:e},t){let n={},r=this.format;r=I$(r,e,"x"),r=I$(r,e,"y"),this.format=r;for(let i in r){let o=r[i];if(!(o===null||o===!1))if(i==="fx"||i==="fy")n[i]=!0;else{let s=Qm(e,i);s&&(n[i]=s)}}for(let i in e){if(i in n||i in r||uK.has(i))continue;let o=Qm(e,i);o&&(n[i]=o)}this.facet&&(t.fx&&!("fx"in r)&&(n.fx=!0),t.fy&&!("fy"in r)&&(n.fy=!0));for(let i in n){let o=this.format[i];if(typeof o=="string"){let s=n[i]?.value??t[i]?.domain()??[];this.format[i]=(Le(s)?Po:pi)(o)}else if(o===void 0||o===!0){let s=t[i];this.format[i]=s?.bandwidth?cy(s,s.domain()):Yi}}return n}function I$(e,t,n){if(!(n in e))return e;let r=`${n}1`,i=`${n}2`;if((r in e||!(r in t))&&(i in e||!(i in t)))return e;let o=Object.entries(e),s=e[n];return o.splice(o.findIndex(([a])=>a===n)+1,0,[r,s],[i,s]),Object.fromEntries(o)}function mK(e,t,{title:n}){return Yi(n.value[e],e)}function*yK(e,t,n,r,i){for(let o in n){if(o==="fx"||o==="fy"){yield{label:rv(r,n,o),value:this.format[o](t[o],e)};continue}if(o==="x1"&&"x2"in n||o==="y1"&&"y2"in n)continue;let s=n[o];if(o==="x2"&&"x1"in n)yield{label:A$(r,n,"x"),value:M$(this.format.x2,n.x1,s,e)};else if(o==="y2"&&"y1"in n)yield{label:A$(r,n,"y"),value:M$(this.format.y2,n.y1,s,e)};else{let a=s.value[e],c=s.scale;if(!ze(a)&&c==null)continue;yield{label:rv(r,n,o),value:this.format[o](a,e),color:c==="color"?i[o][e]:null,opacity:c==="opacity"?i[o][e]:null}}}}function M$(e,t,n,r){return n.hint?.length?`${e(n.value[r]-t.value[r],r)}`:`${e(t.value[r],r)}\u2013${e(n.value[r],r)}`}function A$(e,t,n){let r=rv(e,t,`${n}1`,n),i=rv(e,t,`${n}2`,n);return r===i?r:`${r}\u2013${i}`}function rv(e,t,n,r=n){let i=t[n],o=e[i?.scale??n];return String(o?.label??i?.label??r)}function hy(e={}){let{facet:t,style:n,title:r,subtitle:i,caption:o,ariaLabel:s,ariaDescription:a}=e,c=Pf(e.className),l=e.marks===void 0?[]:E$(e.marks);l.push(...SK(l));let u=vK(t,e),f=new Map;for(let k of l){let $=N$(k,u,e);$&&f.set(k,$)}let h=new Map;u&&fy(h,[u],e),fy(h,f,e);let d=E$(IK(l,h,e));for(let k of d){let $=N$(k,u,e);$&&f.set(k,$)}l.unshift(...d);let p=T7(h,e);if(p!==void 0){let k=u?Fw(p,u):void 0;for(let P of l){if(P.facet===null||P.facet==="super")continue;let U=f.get(P);U!==void 0&&(U.facetsIndex=P.fx!=null||P.fy!=null?Fw(p,U):k)}let $=new Set;for(let{facetsIndex:P}of f.values())P?.forEach((U,W)=>{U?.length>0&&$.add(W)});p.forEach(0<$.size&&$.size<p.length?(P,U)=>P.empty=!$.has(U):P=>P.empty=!1);for(let P of l)if(P.facet==="exclude"){let U=f.get(P);U!==void 0&&(U.facetsIndex=D7(U.facetsIndex))}}for(let k of he.keys())qo(e[k])&&k!=="fx"&&k!=="fy"&&h.set(k,[]);let m=new Map;for(let k of l){if(m.has(k))throw new Error("duplicate mark; each mark must be unique");let{facetsIndex:$,channels:P}=f.get(k)??{},{data:U,facets:W,channels:nt}=k.initialize($,P,e);t3(nt,e),m.set(k,{data:U,facets:W,channels:nt})}let y=ey(fy(h,m,e),e),g=M7(y,l,e);m7(y,g);let x=TT(y),{fx:b,fy:w}=x,_=b||w?ET(y,g):g,v=b||w?OK(x,g):g,M=ec(e),E=M.document,I=Ds("svg").call(E.documentElement),D=I;M.ownerSVGElement=I,M.className=c,M.projection=ER(e,_),M.filterFacets=(k,$)=>Fw(p,{channels:$,groups:Cw(k,$)}),M.getMarkState=k=>{let $=m.get(k),P=f.get(k);return{...$,channels:{...$.channels,...P?.channels}}},M.dispatchValue=k=>{D.value!==k&&(D.value=k,D.dispatchEvent(new Event("input",{bubbles:!0})))};let A=new Set;for(let[k,$]of m)if(k.initializer!=null){let P=k.facet==="super"?v:_,U=k.initializer($.data,$.facets,$.channels,x,P,M);if(U.data!==void 0&&($.data=U.data),U.facets!==void 0&&($.facets=U.facets),U.channels!==void 0){let{fx:W,fy:nt,...ot}=U.channels;wK(ot),Object.assign($.channels,ot);for(let at of Object.values(ot)){let{scale:Y}=at;Y!=null&&!aR(he.get(Y))&&(B$(at,e),A.add(Y))}(W!=null||nt!=null)&&f.set(k,!0)}}if(A.size){let k=new Map;fy(k,m,e,W=>A.has(W)),fy(h,m,e,W=>A.has(W));let $=DK(ey(k,e),y),{scales:P,...U}=TT($);Object.assign(y,$),Object.assign(x,U),Object.assign(x.scales,P)}let O,C;p!==void 0&&(O={x:b?.domain(),y:w?.domain()},p=E7(p,O),C=N7(b,w,g));for(let[k,$]of m)$.values=k.scale($.channels,x,M);let{width:S,height:T}=g;Vt(I).attr("class",c).attr("fill","currentColor").attr("font-family","system-ui, sans-serif").attr("font-size",10).attr("text-anchor","middle").attr("width",S).attr("height",T).attr("viewBox",`0 0 ${S} ${T}`).attr("aria-label",s).attr("aria-description",a).call(k=>k.append("style").text(`:where(.${c}) {
|
|
60
60
|
--plot-background: white;
|
|
61
61
|
display: block;
|
|
62
62
|
height: auto;
|
|
@@ -66,24 +66,24 @@ ${m}`)).style("margin-left",l?`${+l}px`:null).style("width",d===void 0?null:`${+
|
|
|
66
66
|
:where(.${c} text),
|
|
67
67
|
:where(.${c} tspan) {
|
|
68
68
|
white-space: pre;
|
|
69
|
-
}`)).call(Cf,n);for(let k of l){let{channels:$,values:P,facets:U}=m.get(k);if(p===void 0||k.facet==="super"){let W=null;if(U&&(W=U[0],W=k.filter(W,$,P),W.length===0))continue;let tt=k.render(W,x,P,_,I);if(tt==null)continue;A.appendChild(tt)}else{let W;for(let tt of p){if(!(k.facetAnchor?.(p,O,tt)??!tt.empty))continue;let nt=null;if(U){let Y=f.has(k);if(nt=U[Y?tt.i:0],nt=k.filter(nt,$,P),nt.length===0)continue;!Y&&nt===U[0]&&(nt=Js(nt)),nt.fx=tt.x,nt.fy=tt.y,nt.fi=tt.i}let at=k.render(nt,x,P,v,I);if(at!=null){(W??=Vt(A).append("g")).append(()=>at).datum(tt);for(let Y of["aria-label","aria-description","aria-hidden","transform"])at.hasAttribute(Y)&&(W.attr(Y,at.getAttribute(Y)),at.removeAttribute(Y))}}W?.selectChildren().attr("transform",C)}}let N=h$(g,I,e),{figure:F=r!=null||i!=null||o!=null||N.length>0}=e;F&&(E=D.createElement("figure"),E.className=`${c}-figure`,E.style.maxWidth="initial",r!=null&&E.append(g$(D,r,"h2")),i!=null&&E.append(g$(D,i,"h3")),E.append(...N,A),o!=null&&E.append(VQ(D,o))),E.scale=d7(x.scales),E.legend=f$(g,I,e),E.projection=I.projection;let R=gR();return R>0&&Vt(A).append("text").attr("x",S).attr("y",20).attr("dy","-1em").attr("text-anchor","end").attr("font-family","initial").text("\u26A0\uFE0F").append("title").text(`${R.toLocaleString("en-US")} warning${R===1?"":"s"}. Please check the console.`),E}function g$(e,t,n){if(t.ownerDocument)return t;let r=e.createElement(n);return r.append(t),r}function VQ(e,t){let n=e.createElement("figcaption");return n.append(t),n}function YQ({marks:e=[],...t}={}){return ny({...t,marks:[...e,this]})}St.prototype.plot=YQ;function x$(e){return e.flat(1/0).filter(t=>t!=null).map(XQ)}function XQ(e){return typeof e.render=="function"?e:new WT(e)}var WT=class extends St{constructor(t){if(typeof t!="function")throw new TypeError("invalid mark; missing render function");super(),this.render=t}render(){}};function HT(e,t){for(let n in e)_$(e[n],t);return e}function _$(e,t){let{scale:n,transform:r=!0}=e;if(n==null||!r)return;let{type:i,percent:o,interval:s,transform:a=o?c=>c*100:JA(s,i)}=t[n]??{};a!=null&&(e.value=Gt(e.value,a),e.transform=!1)}function GQ(e){for(let t in e)fT(t,e[t])}function ey(e,t,n,r=$F){for(let{channels:i}of t.values())for(let o in i){let s=i[o],{scale:a}=s;if(a!=null&&r(a))if(a==="projection"){if(!IR(n)){let c=n.x?.domain===void 0,l=n.y?.domain===void 0;if(c||l){let[u,f]=AR(s);c&>(e,"x",u),l&>(e,"y",f)}}}else GT(e,a,s)}return e}function GT(e,t,n){let r=e.get(t);r!==void 0?r.push(n):e.set(t,[n])}function WQ(e,t){if(e==null)return;let{x:n,y:r}=e;if(n==null&&r==null)return;let i=je(e.data);if(i==null)throw new Error("missing facet data");let o={};n!=null&&(o.fx=Of(i,{value:n,scale:"fx"})),r!=null&&(o.fy=Of(i,{value:r,scale:"fy"})),HT(o,t);let s=Bw(i,o);return{channels:o,groups:s,data:e.data}}function b$(e,t,n){if(e.facet===null||e.facet==="super")return;let{fx:r,fy:i}=e;if(r!=null||i!=null){let c=je(e.data??r??i);if(c===void 0)throw new Error(`missing facet data in ${e.ariaLabel}`);if(c===null)return;let l={};return r!=null&&(l.fx=Of(c,{value:r,scale:"fx"})),i!=null&&(l.fy=Of(c,{value:i,scale:"fy"})),HT(l,n),{channels:l,groups:Bw(c,l)}}if(t===void 0)return;let{channels:o,groups:s,data:a}=t;if(e.facet!=="auto"||e.data===a)return{channels:o,groups:s};a.length>0&&(s.size>1||s.size===1&&o.fx&&o.fy&&[...s][0][1].size>1)&&je(e.data)?.length===a.length&&Vn(`Warning: the ${e.ariaLabel} mark appears to use faceted data, but isn\u2019t faceted. The mark data has the same length as the facet data and the mark facet option is "auto", but the mark data and facet data are distinct. If this mark should be faceted, set the mark facet option to true; otherwise, suppress this warning by setting the mark facet option to false.`)}function HQ(e,t={}){return Ie({...t,x:null,y:null},(n,r,i,o,s,a)=>a.getMarkState(e))}function ZQ(e){let t=[];for(let n of e){let r=n.tip;if(r){r===!0?r={}:typeof r=="string"&&(r={pointer:r});let{pointer:i,preferredAnchor:o}=r;i=/^x$/i.test(i)?jf:/^y$/i.test(i)?El:qf,r=i(HQ(n,r)),r.title=null,o===void 0&&(r.preferredAnchor=i===El?"left":"bottom");let s=nv(n.data,r);s.facet=n.facet,s.facetAnchor=n.facetAnchor,t.push(s)}}return t}function JQ(e,t,n){let{projection:r,x:i={},y:o={},fx:s={},fy:a={},axis:c,grid:l,facet:u={},facet:{axis:f=c,grid:d}=u,x:{axis:h=c,grid:p=h===null?null:l}=i,y:{axis:m=c,grid:g=m===null?null:l}=o,fx:{axis:y=f,grid:x=y===null?null:d}=s,fy:{axis:b=f,grid:w=b===null?null:d}=a}=n;(r||!Lo(i)&&!w$("x",e))&&(h=p=null),(r||!Lo(o)&&!w$("y",e))&&(m=g=null),t.has("fx")||(y=x=null),t.has("fy")||(b=w=null),h===void 0&&(h=!ov(e,"x")),m===void 0&&(m=!ov(e,"y")),y===void 0&&(y=!ov(e,"fx")),b===void 0&&(b=!ov(e,"fy")),h===!0&&(h="bottom"),m===!0&&(m="left"),y===!0&&(y=h==="top"||h===null?"bottom":"top"),b===!0&&(b=m==="right"||m===null?"left":"right");let v=[];return iv(v,w,Jw,a),rv(v,b,Ww,"right","left",u,a),iv(v,x,Kw,s),rv(v,y,Hw,"top","bottom",u,s),iv(v,g,Zw,o),rv(v,m,Zm,"left","right",n,o),iv(v,p,Qw,i),rv(v,h,Jm,"bottom","top",n,i),v}function rv(e,t,n,r,i,o,s){if(!t)return;let a=QQ(t);s=KQ(a?r:t,o,s);let{line:c}=s;(n===Zm||n===Jm)&&c&&!ta(c)&&e.push(Gf(tK(s))),e.push(n(s)),a&&e.push(n({...s,anchor:i,label:null}))}function iv(e,t,n,r){!t||ta(t)||e.push(n(eK(t,r)))}function QQ(e){return/^\s*both\s*$/i.test(e)}function KQ(e,t,{line:n=t.line,ticks:r,tickSize:i,tickSpacing:o,tickPadding:s,tickFormat:a,tickRotate:c,fontVariant:l,ariaLabel:u,ariaDescription:f,label:d=t.label,labelAnchor:h,labelArrow:p=t.labelArrow,labelOffset:m}){return{anchor:e,line:n,ticks:r,tickSize:i,tickSpacing:o,tickPadding:s,tickFormat:a,tickRotate:c,fontVariant:l,ariaLabel:u,ariaDescription:f,label:d,labelAnchor:h,labelArrow:p,labelOffset:m}}function tK(e){let{anchor:t,line:n}=e;return{anchor:t,facetAnchor:t+"-empty",stroke:n===!0?void 0:n}}function eK(e,{stroke:t=Qa(e)?e:void 0,ticks:n=nK(e)?e:void 0,tickSpacing:r,ariaLabel:i,ariaDescription:o}){return{stroke:t,ticks:n,tickSpacing:r,ariaLabel:i,ariaDescription:o}}function nK(e){switch(typeof e){case"number":return!0;case"string":return!Qa(e)}return cr(e)||typeof e?.range=="function"}function ov(e,t){let n=`${t}-axis `;return e.some(r=>r.ariaLabel?.startsWith(n))}function w$(e,t){for(let n of t)for(let r in n.channels){let{scale:i}=n.channels[r];if(i===e||i==="projection")return!0}return!1}function rK(e,t){for(let n in e){let r=e[n],i=t[n];r.label===void 0&&i&&(r.label=i.label)}return e}function iK({fx:e,fy:t},n){let{marginTop:r,marginRight:i,marginBottom:o,marginLeft:s,width:a,height:c}=Nw(n),l=e&&v$(e),u=t&&v$(t);return{marginTop:t?u[0]:r,marginRight:e?a-l[1]:i,marginBottom:t?c-u[1]:o,marginLeft:e?l[0]:s,inset:{marginTop:n.marginTop,marginRight:n.marginRight,marginBottom:n.marginBottom,marginLeft:n.marginLeft},width:a,height:c}}function v$(e){let t=e.domain(),n=e(t[0]),r=e(t[t.length-1]);return r<n&&([n,r]=[r,n]),[n,r+e.bandwidth()]}var oK=new Map([["basis",gA],["basis-closed",xA],["basis-open",bA],["bundle",wA],["bump-x",dA],["bump-y",hA],["cardinal",vA],["cardinal-closed",_A],["cardinal-open",SA],["catmull-rom",IA],["catmull-rom-closed",MA],["catmull-rom-open",AA],["linear",Xs],["linear-closed",TA],["monotone-x",NA],["monotone-y",DA],["natural",OA],["step",BA],["step-after",CA],["step-before",LA]]);function ry(e=Xs,t){if(typeof e=="function")return e;let n=oK.get(`${e}`.toLowerCase());if(!n)throw new Error(`unknown curve: ${e}`);if(t!==void 0){if("beta"in n)return n.beta(t);if("tension"in n)return n.tension(t);if("alpha"in n)return n.alpha(t)}return n}function sv(e=ac,t){return typeof e!="function"&&`${e}`.toLowerCase()==="auto"?ac:ry(e,t)}function ac(e){return Xs(e)}function Uo(e={y:"count"},t={}){[e,t]=JT(e,t);let{x:n,y:r}=t;return ZT(av(n,t,G),null,null,r,e,Nl(t))}function zo(e={x:"count"},t={}){[e,t]=JT(e,t);let{x:n,y:r}=t;return ZT(null,av(r,t,G),n,null,e,Dl(t))}function sa(e={fill:"count"},t={}){[e,t]=JT(e,t);let{x:n,y:r}=sK(t);return ZT(n,r,null,null,e,Nl(Dl(t)))}function M$(e,t,n={}){if(n?.interval==null)return n;let{reduce:r=gw}=n,i={filter:null};return n[t]!=null&&(i[t]=r),n[`${t}1`]!=null&&(i[`${t}1`]=r),n[`${t}2`]!=null&&(i[`${t}2`]=r),e(i,n)}function Wf(e={}){return M$(Uo,"y",Yi(e,"x"))}function Hf(e={}){return M$(zo,"x",Yi(e,"y"))}function ZT(e,t,n,r,{data:i=yw,filter:o=$m,sort:s,reverse:a,...c}={},l={}){e=S$(e),t=S$(t),c=aK(c,l),i=E$(i,G),s=s==null?void 0:A$("sort",s,l),o=o==null?void 0:T$("filter",o,l),n!=null&&Ro(c,"x","x1","x2")&&(n=null),r!=null&&Ro(c,"y","y1","y2")&&(r=null);let[u,f]=Dn(e),[d,h]=Dn(e),[p,m]=Dn(t),[g,y]=Dn(t),[x,b]=n!=null?[n,"x"]:r!=null?[r,"y"]:[],[w,v]=Dn(x),{x:_,y:I,z:D,fill:A,stroke:E,x1:T,x2:O,y1:C,y2:S,domain:M,cumulative:N,thresholds:F,interval:R,...k}=l,[$,P]=Dn(D),[U]=Be(A),[W]=Be(E),[tt,nt]=Dn(U),[at,Y]=Dn(W);return{..."z"in l&&{z:$||D},..."fill"in l&&{fill:tt||A},..."stroke"in l&&{stroke:at||E},...yn(k,(rt,j,H)=>{let ot=Sl(wt(rt,x),H?.[b]),z=wt(rt,D),kt=wt(rt,U),dt=wt(rt,W),Ht=zm(c,{z,fill:kt,stroke:dt}),Zt=[],et=[],ae=ot&&v([]),Sr=z&&P([]),Wi=kt&&nt([]),nz=dt&&Y([]),ID=e&&f([]),rz=e&&h([]),MD=t&&m([]),iz=t&&y([]),oz=uK(e,t,rt),sz=0;for(let Wl of c)Wl.initialize(rt);s&&s.initialize(rt),o&&o.initialize(rt);for(let Wl of j){let AD=[];for(let Cd of c)Cd.scope("facet",Wl);s&&s.scope("facet",Wl),o&&o.scope("facet",Wl);for(let[Cd,az]of Ka(Wl,Ht))for(let[cz,og]of Ka(az,ot))for(let[Hi,bc]of oz(og))if(!(o&&!o.reduce(Hi,bc))){AD.push(sz++),et.push(i.reduceIndex(Hi,rt,bc)),ot&&ae.push(cz),z&&Sr.push(Ht===z?Cd:z[(Hi.length>0?Hi:og)[0]]),kt&&Wi.push(Ht===kt?Cd:kt[(Hi.length>0?Hi:og)[0]]),dt&&nz.push(Ht===dt?Cd:dt[(Hi.length>0?Hi:og)[0]]),ID&&(ID.push(bc.x1),rz.push(bc.x2)),MD&&(MD.push(bc.y1),iz.push(bc.y2));for(let lz of c)lz.reduce(Hi,bc);s&&s.reduce(Hi)}Zt.push(AD)}return lT(Zt,s,a),{data:et,facets:Zt}}),...!Ro(c,"x")&&(u?{x1:u,x2:d,x:Af(u,d)}:{x:_,x1:T,x2:O}),...!Ro(c,"y")&&(p?{y1:p,y2:g,y:Af(p,g)}:{y:I,y1:C,y2:S}),...w&&{[b]:w},...Object.fromEntries(c.map(({name:rt,output:j})=>[rt,j]))}}function JT({cumulative:e,domain:t,thresholds:n,interval:r,...i},o){return[i,{cumulative:e,domain:t,thresholds:n,interval:r,...o}]}function av(e,{cumulative:t,domain:n,thresholds:r,interval:i},o){return e={...pi(e)},e.domain===void 0&&(e.domain=n),e.cumulative===void 0&&(e.cumulative=t),e.thresholds===void 0&&(e.thresholds=r),e.interval===void 0&&(e.interval=i),e.value===void 0&&(e.value=o),e.thresholds=QT(e.thresholds,e.interval),e}function sK(e){let{x:t,y:n}=e;return t=av(t,e),n=av(n,e),[t.value,n.value]=$e(t.value,n.value),{x:t,y:n}}function S$(e){if(e==null)return;let{value:t,cumulative:n,domain:r=le,thresholds:i}=e,o=s=>{let a=wt(s,t),c;if(Le(a)||lK(i)){a=Gt(a,XA,Float64Array);let[u,f]=typeof r=="function"?r(a):r,d=typeof i=="function"&&!Ja(i)?i(a,u,f):i;typeof d=="number"&&(d=am(u,f,d)),Ja(d)&&(r===le&&(u=d.floor(u),f=d.offset(d.floor(f))),d=d.range(u,d.offset(f))),c=d}else{a=Ke(a);let[u,f]=typeof r=="function"?r(a):r,d=typeof i=="function"&&!Ja(i)?i(a,u,f):i;if(typeof d=="number")if(r===le){let h=Es(u,f,d);if(isFinite(h))if(h>0){let p=Math.round(u/h),m=Math.round(f/h);p*h<=u||--p,m*h>f||++m;let g=m-p+1;d=new Float64Array(g);for(let y=0;y<g;++y)d[y]=(p+y)*h}else if(h<0){h=-h;let p=Math.round(u*h),m=Math.round(f*h);p/h<=u||--p,m/h>f||++m;let g=m-p+1;d=new Float64Array(g);for(let y=0;y<g;++y)d[y]=(p+y)/h}else d=[u];else d=[u]}else d=Mn(u,f,d);else Ja(d)&&(r===le&&(u=d.floor(u),f=d.offset(d.floor(f))),d=d.range(u,d.offset(f)));c=d}let l=[];if(c.length===1)l.push([c[0],c[0]]);else for(let u=1;u<c.length;++u)l.push([c[u-1],c[u]]);return l.bin=(n<0?dK:n>0?fK:KT)(l,c,a),l};return o.label=On(t),o}function QT(e,t,n=I$){if(e===void 0)return t===void 0?n:ko(t);if(typeof e=="string"){switch(e.toLowerCase()){case"freedman-diaconis":return K0;case"scott":return np;case"sturges":return Na;case"auto":return I$}return Cm(e)}return e}function aK(e,t){return aT(e,t,A$)}function A$(e,t,n){return pw(e,t,n,T$)}function T$(e,t,n){return mw(e,t,n,E$)}function E$(e,t){return Df(e,t,cK)}function cK(e){switch(`${e}`.toLowerCase()){case"x":return hK;case"x1":return mK;case"x2":return yK;case"y":return pK;case"y1":return gK;case"y2":return xK}throw new Error(`invalid bin reduce: ${e}`)}function I$(e,t,n){return Math.min(200,np(e,t,n))}function lK(e){return qF(e)||cr(e)&&Le(e)}function uK(e,t,n){let r=e?.(n),i=t?.(n);return r&&i?function*(o){let s=r.bin(o);for(let[a,[c,l]]of r.entries()){let u=i.bin(s[a]);for(let[f,[d,h]]of i.entries())yield[u[f],{data:n,x1:c,y1:d,x2:l,y2:h}]}}:r?function*(o){let s=r.bin(o);for(let[a,[c,l]]of r.entries())yield[s[a],{data:n,x1:c,x2:l}]}:function*(o){let s=i.bin(o);for(let[a,[c,l]]of i.entries())yield[s[a],{data:n,y1:c,y2:l}]}}function KT(e,t,n){return t=Ke(t),r=>{let i=e.map(()=>[]);for(let o of r)i[Ts(t,n[o])-1]?.push(o);return i}}function fK(e,t,n){let r=KT(e,t,n);return i=>{let o=r(i);for(let s=1,a=o.length;s<a;++s){let c=o[s-1],l=o[s];for(let u of c)l.push(u)}return o}}function dK(e,t,n){let r=KT(e,t,n);return i=>{let o=r(i);for(let s=o.length-2;s>=0;--s){let a=o[s+1],c=o[s];for(let l of a)c.push(l)}return o}}function N$(e,t){let n=(+e+ +t)/2;return e instanceof Date?new Date(n):n}var hK={reduceIndex(e,t,{x1:n,x2:r}){return N$(n,r)}},pK={reduceIndex(e,t,{y1:n,y2:r}){return N$(n,r)}},mK={reduceIndex(e,t,{x1:n}){return n}},yK={reduceIndex(e,t,{x2:n}){return n}},gK={reduceIndex(e,t,{y1:n}){return n}},xK={reduceIndex(e,t,{y2:n}){return n}};function Zf(e={}){return WA(e)?e:{...e,x:G}}function Jf(e={}){return HA(e)?e:{...e,y:G}}function D$(e,t){if(t.length===1)return{data:e,facets:t};let n=e.length,r=new Uint8Array(n),i=0;for(let a of t)for(let c of a)r[c]&&++i,r[c]=1;if(i===0)return{data:e,facets:t};e=Za(e);let o=e[jA]=new Uint32Array(n+i);t=t.map(a=>Za(a,Uint32Array));let s=n;r.fill(0);for(let a of t)for(let c=0,l=a.length;c<l;++c){let u=a[c];r[u]?(a[c]=s,e[s]=e[u],o[s]=u,++s):o[u]=u,r[u]=1}return{data:e,facets:t}}function t3(e={},t={}){arguments.length===1&&([e,t]=td(e));let{y1:n,y:r=n,x:i,...o}=t,[s,a,c,l]=ed(r,i,"y","x",e,o);return{...s,y1:n,y:a,x1:c,x2:l,x:Af(c,l)}}function L$(e={},t={}){arguments.length===1&&([e,t]=td(e));let{y1:n,y:r=n,x:i}=t,[o,s,a]=ed(r,i,"y","x",e,t);return{...o,y1:n,y:s,x:a}}function C$(e={},t={}){arguments.length===1&&([e,t]=td(e));let{y1:n,y:r=n,x:i}=t,[o,s,,a]=ed(r,i,"y","x",e,t);return{...o,y1:n,y:s,x:a}}function e3(e={},t={}){arguments.length===1&&([e,t]=td(e));let{x1:n,x:r=n,y:i,...o}=t,[s,a,c,l]=ed(r,i,"x","y",e,o);return{...s,x1:n,x:a,y1:c,y2:l,y:Af(c,l)}}function k$(e={},t={}){arguments.length===1&&([e,t]=td(e));let{x1:n,x:r=n,y:i}=t,[o,s,a]=ed(r,i,"x","y",e,t);return{...o,x1:n,x:s,y:a}}function F$(e={},t={}){arguments.length===1&&([e,t]=td(e));let{x1:n,x:r=n,y:i}=t,[o,s,,a]=ed(r,i,"x","y",e,t);return{...o,x1:n,x:s,y:a}}function Qf({x:e,x1:t,x2:n,...r}={}){return r=Yi(r,"y"),t===void 0&&n===void 0?t3({x:e,...r}):([t,n]=ZA(e,t,n),{...r,x1:t,x2:n})}function Kf({y:e,y1:t,y2:n,...r}={}){return r=Yi(r,"x"),t===void 0&&n===void 0?e3({y:e,...r}):([t,n]=ZA(e,t,n),{...r,y1:t,y2:n})}function td(e){let{offset:t,order:n,reverse:r,...i}=e;return[{offset:t,order:n,reverse:r},i]}var bK={length:!0};function ed(e,t=km,n,r,{offset:i,order:o,reverse:s},a){if(t===null)throw new Error(`stack requires ${r}`);let c=jn(a),[l,u]=Dn(e),[f,d]=mn(t),[h,p]=mn(t);return f.hint=h.hint=bK,i=wK(i),o=SK(o,i,r),[yn(a,(m,g,y)=>{({data:m,facets:g}=D$(m,g));let x=e==null?void 0:u(Sl(wt(m,e),y?.[n])),b=wt(m,t,Float64Array),w=wt(m,c),v=o&&o(m,x,b,w),_=m.length,I=d(new Float64Array(_)),D=p(new Float64Array(_)),A=[];for(let E of g){let T=x?Array.from(cn(E,O=>x[O]).values()):[E];if(v)for(let O of T)O.sort(v);for(let O of T){let C=0,S=0;s&&O.reverse();for(let M of O){let N=b[M];N<0?C=D[M]=(I[M]=C)+N:N>0?S=D[M]=(I[M]=S)+N:D[M]=I[M]=S}}A.push(T)}return i&&i(A,I,D,w),{data:m,facets:g}}),l,f,h]}function wK(e){if(e!=null){if(typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"expand":case"normalize":return vK;case"center":case"silhouette":return _K;case"wiggle":return $$}throw new Error(`unknown offset: ${e}`)}}function R$(e,t){let n=0,r=0;for(let i of e){let o=t[i];o<n&&(n=o),o>r&&(r=o)}return[n,r]}function vK(e,t,n){for(let r of e)for(let i of r){let[o,s]=R$(i,n);for(let a of i){let c=1/(s-o||1);t[a]=c*(t[a]-o),n[a]=c*(n[a]-o)}}}function _K(e,t,n){for(let r of e){for(let i of r){let[o,s]=R$(i,n);for(let a of i){let c=(s+o)/2;t[a]-=c,n[a]-=c}}P$(r,t,n)}U$(e,t,n)}function $$(e,t,n,r){for(let i of e){let o=new Zn,s=0;for(let a of i){let c=-1,l=a.map(h=>Math.abs(n[h]-t[h])),u=a.map(h=>{c=r?r[h]:++c;let p=n[h]-t[h],m=o.has(c)?p-o.get(c):0;return o.set(c,p),m}),f=[0,...W0(u)];for(let h of a)t[h]+=s,n[h]+=s;let d=An(l);d&&(s-=An(l,(h,p)=>(u[p]/2+f[p])*h)/d)}P$(i,t,n)}U$(e,t,n)}function P$(e,t,n){let r=ue(e,i=>ue(i,o=>t[o]));for(let i of e)for(let o of i)t[o]-=r,n[o]-=r}function U$(e,t,n){let r=e.length;if(r===1)return;let i=e.map(a=>a.flat()),o=i.map(a=>(ue(a,c=>t[c])+Wt(a,c=>n[c]))/2),s=ue(o);for(let a=0;a<r;a++){let c=s-o[a];for(let l of i[a])t[l]+=c,n[l]+=c}}function SK(e,t,n){if(e===void 0&&t===$$)return O$(dn);if(e!=null){if(typeof e=="string"){let r=e.startsWith("-"),i=r?bl:dn;switch((r?e.slice(1):e).toLowerCase()){case"value":case n:return IK(i);case"z":return MK(i);case"sum":return AK(i);case"appearance":return TK(i);case"inside-out":return O$(i)}return B$(VA(e))}if(typeof e=="function")return(e.length===1?B$:EK)(e);if(Array.isArray(e))return NK(e);throw new Error(`invalid order: ${e}`)}}function IK(e){return(t,n,r)=>(i,o)=>e(r[i],r[o])}function MK(e){return(t,n,r,i)=>(o,s)=>e(i[o],i[s])}function AK(e){return cv(e,(t,n,r,i)=>Tu(ar(t),o=>An(o,s=>r[s]),o=>i[o]))}function TK(e){return cv(e,(t,n,r,i)=>Tu(ar(t),o=>n[Xc(o,s=>r[s])],o=>i[o]))}function O$(e){return cv(e,(t,n,r,i)=>{let o=ar(t),s=Tu(o,f=>n[Xc(f,d=>r[d])],f=>i[f]),a=$i(o,f=>An(f,d=>r[d]),f=>i[f]),c=[],l=[],u=0;for(let f of s)u<0?(u+=a.get(f),c.push(f)):(u-=a.get(f),l.push(f));return l.reverse().concat(c)})}function B$(e){return t=>{let n=wt(t,e);return(r,i)=>dn(n[r],n[i])}}function EK(e){return t=>(n,r)=>e(t[n],t[r])}function NK(e){return cv(dn,()=>e)}function cv(e,t){return(n,r,i,o)=>{if(!o)throw new Error("missing channel: z");let s=new Zn(t(n,r,i,o).map((a,c)=>[a,c]));return(a,c)=>e(s.get(o[a]),s.get(o[c]))}}var DK={ariaLabel:"area",strokeWidth:1,strokeLinecap:"round",strokeLinejoin:"round",strokeMiterlimit:1},kl=class extends St{constructor(t,n={}){let{x1:r,y1:i,x2:o,y2:s,z:a,curve:c,tension:l}=n;super(t,{x1:{value:r,scale:"x"},y1:{value:i,scale:"y"},x2:{value:o,scale:"x",optional:!0},y2:{value:s,scale:"y",optional:!0},z:{value:jn(n),optional:!0}},n,DK),this.z=a,this.curve=ry(c,l)}filter(t){return t}render(t,n,r,i,o){let{x1:s,y1:a,x2:c=s,y2:l=a}=r;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n,0,0).call(u=>u.selectAll().data(_w(t,[s,a,c,l],this,r)).enter().append("path").call(Lt,this).call(Tl,this,r).attr("d",hf().curve(this.curve).defined(f=>f>=0).x0(f=>s[f]).y0(f=>a[f]).x1(f=>c[f]).y1(f=>l[f]))).node()}};function iy(e,t){return t===void 0?aa(e,{x:Zs,y:Ha}):new kl(e,t)}function cc(e,t){let{y:n=Ee,...r}=Hf(t);return new kl(e,Qf(Zf({...r,y1:n,y2:void 0})))}function aa(e,t){let{x:n=Ee,...r}=Wf(t);return new kl(e,Kf(Jf({...r,x1:n,x2:void 0})))}var OK={ariaLabel:"link",fill:"none",stroke:"currentColor",strokeMiterlimit:1},oy=class extends St{constructor(t,n={}){let{x1:r,y1:i,x2:o,y2:s,curve:a,tension:c}=n;super(t,{x1:{value:r,scale:"x"},y1:{value:i,scale:"y"},x2:{value:o,scale:"x",optional:!0},y2:{value:s,scale:"y",optional:!0}},n,OK),this.curve=sv(a,c),Xi(this,n)}project(t,n,r){this.curve!==ac&&super.project(t,n,r)}render(t,n,r,i,o){let{x1:s,y1:a,x2:c=s,y2:l=a}=r,{curve:u}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(f=>f.selectAll().data(t).enter().append("path").call(Lt,this).attr("d",u===ac&&o.projection?BK(o.projection,s,a,c,l):d=>{let h=er(),p=u(h);return p.lineStart(),p.point(s[d],a[d]),p.point(c[d],l[d]),p.lineEnd(),h}).call(Qt,this,r).call(oa,this,r,o)).node()}};function BK(e,t,n,r,i){let o=En(e);return t=Ke(t),n=Ke(n),r=Ke(r),i=Ke(i),s=>o({type:"LineString",coordinates:[[t[s],n[s]],[r[s],i[s]]]})}function lv(e,{x:t,x1:n,x2:r,y:i,y1:o,y2:s,...a}={}){return[n,r]=sy(t,n,r),[o,s]=sy(i,o,s),new oy(e,{...a,x1:n,x2:r,y1:o,y2:s})}function sy(e,t,n){if(e===void 0){if(t===void 0){if(n!==void 0)return[n]}else if(n===void 0)return[t]}else{if(t===void 0)return n===void 0?[e]:[e,n];if(n===void 0)return[e,t]}return[t,n]}var LK={ariaLabel:"arrow",fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeMiterlimit:1,strokeWidth:1.5},ay=class extends St{constructor(t,n={}){let{x1:r,y1:i,x2:o,y2:s,bend:a=0,headAngle:c=60,headLength:l=8,inset:u=0,insetStart:f=u,insetEnd:d=u,sweep:h}=n;super(t,{x1:{value:r,scale:"x"},y1:{value:i,scale:"y"},x2:{value:o,scale:"x",optional:!0},y2:{value:s,scale:"y",optional:!0}},n,LK),this.bend=a===!0?22.5:Math.max(-90,Math.min(90,a)),this.headAngle=+c,this.headLength=+l,this.insetStart=+f,this.insetEnd=+d,this.sweep=CK(h)}render(t,n,r,i,o){let{x1:s,y1:a,x2:c=s,y2:l=a,SW:u}=r,{strokeWidth:f,bend:d,headAngle:h,headLength:p,insetStart:m,insetEnd:g}=this,y=u?w=>u[w]:hn(f===void 0?1:f),x=h*Vf/2,b=p/1.5;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(w=>w.selectAll().data(t).enter().append("path").call(Lt,this).attr("d",v=>{let _=s[v],I=a[v],D=c[v],A=l[v],E=Math.hypot(D-_,A-I);if(E<=m+g)return null;let T=Math.atan2(A-I,D-_),O=Math.min(b*y(v),E/3),C=this.sweep(_,I,D,A)*d*Vf,S=Math.hypot(E/Math.tan(C),E)/2;if(m||g)if(S<1e5){let tt=Math.sign(C),[nt,at]=kK([_,I],[D,A],S,tt);if(m&&([_,I]=z$([nt,at,S],[_,I,m],-tt*Math.sign(m))),g){let[Y,rt]=z$([nt,at,S],[D,A,g],tt*Math.sign(g));T+=Math.atan2(rt-at,Y-nt)-Math.atan2(A-at,D-nt),D=Y,A=rt}}else{let tt=D-_,nt=A-I,at=Math.hypot(tt,nt);m&&(_+=tt/at*m,I+=nt/at*m),g&&(D-=tt/at*g,A-=nt/at*g)}let M=T+C,N=M+x,F=M-x,R=D-O*Math.cos(N),k=A-O*Math.sin(N),$=D-O*Math.cos(F),P=A-O*Math.sin(F),U=S<1e5?`A${S},${S} 0,0,${C>0?1:0} `:"L",W=O?`M${R},${k}L${D},${A}L${$},${P}`:"";return`M${_},${I}${U}${D},${A}${W}`}).call(Qt,this,r)).node()}};function CK(e=1){if(typeof e=="number")return hn(Math.sign(e));if(typeof e=="function")return(t,n,r,i)=>Math.sign(e(t,n,r,i));switch(tn(e,"sweep",["+x","-x","+y","-y"])){case"+x":return(t,n,r)=>zt(t,r);case"-x":return(t,n,r)=>Hn(t,r);case"+y":return(t,n,r,i)=>zt(n,i);case"-y":return(t,n,r,i)=>Hn(n,i)}}function kK([e,t],[n,r],i,o){let s=n-e,a=r-t,c=Math.hypot(s,a),l=o*Math.sqrt(i*i-c*c/4)/c;return[(e+n)/2-a*l,(t+r)/2+s*l]}function z$([e,t,n],[r,i,o],s){let a=r-e,c=i-t,l=Math.hypot(a,c),u=(a*a+c*c-o*o+n*n)/(2*l),f=s*Math.sqrt(n*n-u*u);return[e+(a*u+c*f)/l,t+(c*u-a*f)/l]}function q$(e,{x:t,x1:n,x2:r,y:i,y1:o,y2:s,...a}={}){return[n,r]=sy(t,n,r),[o,s]=sy(i,o,s),new ay(e,{...a,x1:n,x2:r,y1:o,y2:s})}var nd=class extends St{constructor(t,n,r={},i){super(t,n,r,i);let{inset:o=0,insetTop:s=o,insetRight:a=o,insetBottom:c=o,insetLeft:l=o,rx:u,ry:f}=r;this.insetTop=Bt(s),this.insetRight=Bt(a),this.insetBottom=Bt(c),this.insetLeft=Bt(l),this.rx=fe(u,"auto"),this.ry=fe(f,"auto")}render(t,n,r,i,o){let{rx:s,ry:a}=this;return ut("svg:g",o).call(Ct,this,i,o).call(this._transform,this,n).call(c=>c.selectAll().data(t).enter().append("rect").call(Lt,this).attr("x",this._x(n,r,i)).attr("width",this._width(n,r,i)).attr("y",this._y(n,r,i)).attr("height",this._height(n,r,i)).call(ft,"rx",s).call(ft,"ry",a).call(Qt,this,r)).node()}_x(t,{x:n},{marginLeft:r}){let{insetLeft:i}=this;return n?o=>n[o]+i:r+i}_y(t,{y:n},{marginTop:r}){let{insetTop:i}=this;return n?o=>n[o]+i:r+i}_width({x:t},{x:n},{marginRight:r,marginLeft:i,width:o}){let{insetLeft:s,insetRight:a}=this,c=n&&t?t.bandwidth():o-r-i;return Math.max(0,c-s-a)}_height({y:t},{y:n},{marginTop:r,marginBottom:i,height:o}){let{insetTop:s,insetBottom:a}=this,c=n&&t?t.bandwidth():o-r-i;return Math.max(0,c-s-a)}},j$={ariaLabel:"bar"},cy=class extends nd{constructor(t,n={}){let{x1:r,x2:i,y:o}=n;super(t,{x1:{value:r,scale:"x"},x2:{value:i,scale:"x"},y:{value:o,scale:"y",type:"band",optional:!0}},n,j$)}_transform(t,n,{x:r}){t.call(Et,n,{x:r},0,0)}_x({x:t},{x1:n,x2:r},{marginLeft:i}){let{insetLeft:o}=this;return lr(t)?i+o:s=>Math.min(n[s],r[s])+o}_width({x:t},{x1:n,x2:r},{marginRight:i,marginLeft:o,width:s}){let{insetLeft:a,insetRight:c}=this;return lr(t)?s-i-o-a-c:l=>Math.max(0,Math.abs(r[l]-n[l])-a-c)}},ly=class extends nd{constructor(t,n={}){let{x:r,y1:i,y2:o}=n;super(t,{y1:{value:i,scale:"y"},y2:{value:o,scale:"y"},x:{value:r,scale:"x",type:"band",optional:!0}},n,j$)}_transform(t,n,{y:r}){t.call(Et,n,{y:r},0,0)}_y({y:t},{y1:n,y2:r},{marginTop:i}){let{insetTop:o}=this;return lr(t)?i+o:s=>Math.min(n[s],r[s])+o}_height({y:t},{y1:n,y2:r},{marginTop:i,marginBottom:o,height:s}){let{insetTop:a,insetBottom:c}=this;return lr(t)?s-i-o-a-c:l=>Math.max(0,Math.abs(r[l]-n[l])-a-c)}};function qo(e,t={}){return If(t)||(t={...t,y:Ee,x2:G}),new cy(e,Qf(Rw(Zf(t))))}function jo(e,t={}){return If(t)||(t={...t,x:Ee,y2:G}),new ly(e,Kf($w(Jf(t))))}var FK={ariaLabel:"cell"},Fl=class extends nd{constructor(t,{x:n,y:r,...i}={}){super(t,{x:{value:n,scale:"x",type:"band",optional:!0},y:{value:r,scale:"y",type:"band",optional:!0}},i,FK)}_transform(t,n){t.call(Et,n,{},0,0)}};function lc(e,{x:t,y:n,...r}={}){return[t,n]=$e(t,n),new Fl(e,{...r,x:t,y:n})}function V$(e,{x:t=Ee,fill:n,stroke:r,...i}={}){return n===void 0&&Be(r)[0]===void 0&&(n=G),new Fl(e,{...i,x:t,fill:n,stroke:r})}function Y$(e,{y:t=Ee,fill:n,stroke:r,...i}={}){return n===void 0&&Be(r)[0]===void 0&&(n=G),new Fl(e,{...i,y:t,fill:n,stroke:r})}var RK={ariaLabel:"dot",fill:"none",stroke:"currentColor",strokeWidth:1.5};function uy(e){return e.sort===void 0&&e.reverse===void 0?dw({channel:"-r"},e):e}var Rl=class extends St{constructor(t,n={}){let{x:r,y:i,r:o,rotate:s,symbol:a=Gs,frameAnchor:c}=n,[l,u]=se(s,0),[f,d]=tR(a),[h,p]=se(o,f==null?3:4.5);super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},r:{value:h,scale:"r",filter:sr,optional:!0},rotate:{value:l,optional:!0},symbol:{value:f,scale:"auto",optional:!0}},uy(n),RK),this.r=p,this.rotate=u,this.symbol=d,this.frameAnchor=Fo(c);let{channels:m}=this,{symbol:g}=m;if(g){let{fill:y,stroke:x}=m;g.hint={fill:y?y.value===g.value?"color":"currentColor":this.fill??"currentColor",stroke:x?x.value===g.value?"color":"currentColor":this.stroke??"none"}}}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,r:u,rotate:f,symbol:d}=r,{r:h,rotate:p,symbol:m}=this,[g,y]=gn(this,i),x=m===Gs,b=u?void 0:h*h*Math.PI;return Va(h)&&(t=[]),ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(w=>w.selectAll().data(t).enter().append(x?"circle":"path").call(Lt,this).call(x?v=>{v.attr("cx",c?_=>c[_]:g).attr("cy",l?_=>l[_]:y).attr("r",u?_=>u[_]:h)}:v=>{v.attr("transform",oc`translate(${c?_=>c[_]:g},${l?_=>l[_]:y})${f?_=>` rotate(${f[_]})`:p?` rotate(${p})`:""}`).attr("d",u&&d?_=>{let I=er();return d[_].draw(I,u[_]*u[_]*Math.PI),I}:u?_=>{let I=er();return m.draw(I,u[_]*u[_]*Math.PI),I}:d?_=>{let I=er();return d[_].draw(I,b),I}:(()=>{let _=er();return m.draw(_,b),_})())}).call(Qt,this,r)).node()}};function yi(e,{x:t,y:n,...r}={}){return r.frameAnchor===void 0&&([t,n]=$e(t,n)),new Rl(e,{...r,x:t,y:n})}function X$(e,{x:t=G,...n}={}){return new Rl(e,Uw({...n,x:t}))}function G$(e,{y:t=G,...n}={}){return new Rl(e,Pw({...n,y:t}))}function W$(e,t){return yi(e,{...t,symbol:"circle"})}function H$(e,t){return yi(e,{...t,symbol:"hexagon"})}var $K={ariaLabel:"line",fill:"none",stroke:"currentColor",strokeWidth:1.5,strokeLinecap:"round",strokeLinejoin:"round",strokeMiterlimit:1},$l=class extends St{constructor(t,n={}){let{x:r,y:i,z:o,curve:s,tension:a}=n;super(t,{x:{value:r,scale:"x"},y:{value:i,scale:"y"},z:{value:jn(n),optional:!0}},n,$K),this.z=o,this.curve=sv(s,a),Xi(this,n)}filter(t){return t}project(t,n,r){this.curve!==ac&&super.project(t,n,r)}render(t,n,r,i,o){let{x:s,y:a}=r,{curve:c}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(l=>l.selectAll().data(_w(t,[s,a],this,r)).enter().append("path").call(Lt,this).call(Tl,this,r).call(A7,this,r,o).attr("d",c===ac&&o.projection?PK(o.projection,s,a):ym().curve(c).defined(u=>u>=0).x(u=>s[u]).y(u=>a[u]))).node()}};function PK(e,t,n){let r=En(e);return t=Ke(t),n=Ke(n),i=>{let o=[],s=[o];for(let a of i)a===-1?(o=[],s.push(o)):o.push([t[a],n[a]]);return r({type:"MultiLineString",coordinates:s})}}function Pl(e,{x:t,y:n,...r}={}){return[t,n]=$e(t,n),new $l(e,{...r,x:t,y:n})}function uc(e,{x:t=G,y:n=Ee,...r}={}){return new $l(e,Hf({...r,x:t,y:n}))}function fc(e,{x:t=Ee,y:n=G,...r}={}){return new $l(e,Wf({...r,x:t,y:n}))}var UK={ariaLabel:"rect"},Ul=class extends St{constructor(t,n={}){let{x1:r,y1:i,x2:o,y2:s,inset:a=0,insetTop:c=a,insetRight:l=a,insetBottom:u=a,insetLeft:f=a,rx:d,ry:h}=n;super(t,{x1:{value:r,scale:"x",type:r!=null&&o==null?"band":void 0,optional:!0},y1:{value:i,scale:"y",type:i!=null&&s==null?"band":void 0,optional:!0},x2:{value:o,scale:"x",optional:!0},y2:{value:s,scale:"y",optional:!0}},n,UK),this.insetTop=Bt(c),this.insetRight=Bt(l),this.insetBottom=Bt(u),this.insetLeft=Bt(f),this.rx=fe(d,"auto"),this.ry=fe(h,"auto")}render(t,n,r,i,o){let{x:s,y:a}=n,{x1:c,y1:l,x2:u,y2:f}=r,{marginTop:d,marginRight:h,marginBottom:p,marginLeft:m,width:g,height:y}=i,{projection:x}=o,{insetTop:b,insetRight:w,insetBottom:v,insetLeft:_,rx:I,ry:D}=this,A=(s?.bandwidth?s.bandwidth():0)-_-w,E=(a?.bandwidth?a.bandwidth():0)-b-v;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{},0,0).call(T=>T.selectAll().data(t).enter().append("rect").call(Lt,this).attr("x",c&&(x||!lr(s))?u?O=>Math.min(c[O],u[O])+_:O=>c[O]+_:m+_).attr("y",l&&(x||!lr(a))?f?O=>Math.min(l[O],f[O])+b:O=>l[O]+b:d+b).attr("width",c&&(x||!lr(s))?u?O=>Math.max(0,Math.abs(u[O]-c[O])+A):A:g-h-m-w-_).attr("height",l&&(x||!lr(a))?f?O=>Math.max(0,Math.abs(l[O]-f[O])+E):E:y-d-p-b-v).call(ft,"rx",I).call(ft,"ry",D).call(Qt,this,r)).node()}};function fy(e,t){return new Ul(e,FT(RT(t)))}function rd(e,t={}){return If(t)||(t={...t,y:Ee,x2:G,interval:1}),new Ul(e,Qf(RT(Zf(t))))}function id(e,t={}){return If(t)||(t={...t,x:Ee,y2:G,interval:1}),new Ul(e,Kf(FT(Jf(t))))}function r3(e,t){t=zK(t);let{x:n,y:r,color:i,size:o}=t,s=uv(e,n),a=uv(e,r),c=uv(e,i),l=uv(e,o),{fx:u,fy:f,x:{value:d,reduce:h,zero:p,...m},y:{value:g,reduce:y,zero:x,...b},color:{value:w,color:v,reduce:_},size:{value:I,reduce:D},mark:A}=t;if(h===void 0&&(h=y==null&&d==null&&I==null&&g!=null?"count":null),y===void 0&&(y=h==null&&g==null&&I==null&&d!=null?"count":null),D===void 0&&I==null&&_==null&&h==null&&y==null&&(d==null||Ne(s))&&(g==null||Ne(a))&&(D="count"),p===void 0&&(p=fv(h)?!0:void 0),x===void 0&&(x=fv(y)?!0:void 0),d==null&&g==null)throw new Error("must specify x or y");if(h!=null&&g==null)throw new Error("reducing x requires y");if(y!=null&&d==null)throw new Error("reducing y requires x");A===void 0&&(A=I!=null||D!=null?"dot":fv(h)||fv(y)||_!=null?"bar":d!=null&&g!=null?Ne(s)||Ne(a)||h==null&&y==null&&!dy(s)&&!dy(a)?"dot":"line":d!=null||g!=null?"rule":null);let E,T,O;switch(A){case"dot":O=yi,T="stroke";break;case"line":O=s&&a||h!=null||y!=null?x||y!=null||s&&dy(s)?fc:p||h!=null||a&&dy(a)?uc:Pl:s?uc:fc,T="stroke",J$(c)&&(E=null);break;case"area":O=!(x||y!=null)&&(p||h!=null||a&&dy(a))?cc:aa,T="fill",J$(c)&&(E=null);break;case"rule":O=s?Yr:Xr,T="stroke";break;case"bar":O=h!=null?Ne(a)?Z$(h)&&s&&Ne(s)?lc:qo:rd:y!=null?Ne(s)?Z$(y)&&a&&Ne(a)?lc:jo:id:_!=null||D!=null?s&&Ne(s)&&a&&Ne(a)?lc:s&&Ne(s)?jo:a&&Ne(a)?qo:fy:s&&Ks(s)&&!(a&&Ks(a))?qo:a&&Ks(a)&&!(s&&Ks(s))?jo:lc,T="fill";break;default:throw new Error(`invalid mark: ${A}`)}let C={fx:u,fy:f,x:s??void 0,y:a??void 0,[T]:c??v,z:E,r:l??void 0,tip:!0},S,M={[T]:_??void 0,r:D??void 0};if(h!=null&&y!=null)throw new Error("cannot reduce both x and y");return y!=null?(M.y=y,S=Ne(s)?tc:Uo):h!=null?(M.x=h,S=Ne(a)?ec:zo):(_!=null||D!=null)&&(s&&a?S=Ne(s)&&Ne(a)?Um:Ne(s)?zo:Ne(a)?Uo:sa:s?S=Ne(s)?tc:Uo:a&&(S=Ne(a)?ec:zo)),(S===sa||S===Uo)&&(C.x={value:s,...m}),(S===sa||S===zo)&&(C.y={value:a,...b}),p===void 0&&(p=s&&!(S===sa||S===Uo)&&(O===qo||O===cc||O===rd||O===Xr)),x===void 0&&(x=a&&!(S===sa||S===zo)&&(O===jo||O===aa||O===id||O===Yr)),{fx:u??null,fy:f??null,x:{value:d??null,reduce:h??null,zero:!!p,...m},y:{value:g??null,reduce:y??null,zero:!!x,...b},color:{value:w??null,reduce:_??null,...v!==void 0&&{color:v}},size:{value:I??null,reduce:D??null},mark:A,markImpl:Q$[O],markOptions:C,transformImpl:Q$[S],transformOptions:M,colorMode:T}}function K$(e,t){let n=r3(e,t),{fx:r,fy:i,x:{zero:o},y:{zero:s},markOptions:a,transformOptions:c,colorMode:l}=n,u=n3[n.markImpl],f=n3[n.transformImpl],d=r!=null||i!=null?Gf({strokeOpacity:.1}):null,h=[o?Yr([0]):null,s?Xr([0]):null],p=u(e,f?f(c,a):a);return l==="stroke"?en(d,h,p):en(d,p,h)}function dy(e){let t,n;for(let r of e){if(r==null)continue;if(t===void 0){t=r;continue}let i=Math.sign(zt(t,r));if(i){if(n!==void 0&&i!==n)return!1;t=r,n=i}}return!0}function zK({x:e,y:t,color:n,size:r,fx:i,fy:o,mark:s}={}){return jr(e)||(e=od(e)),jr(t)||(t=od(t)),jr(n)||(n=Qa(n)?{color:n}:od(n)),jr(r)||(r=od(r)),jr(i)&&({value:i}=od(i)),jr(o)&&({value:o}=od(o)),s!=null&&(s=`${s}`.toLowerCase()),{x:e,y:t,color:n,size:r,fx:i,fy:o,mark:s}}function uv(e,t){let n=wt(e,t.value);return n&&(n.label=On(t.value)),n}function od(e){return qK(e)?{reduce:e}:{value:e}}function fv(e){return/^(?:distinct|count|sum|proportion)$/i.test(e)}function Z$(e){return/^(?:first|last|mode)$/i.test(e)}function qK(e){if(e==null)return!1;if(typeof e.reduceIndex=="function"||typeof e.reduce=="function"&&pn(e)||/^p\d{2}$/i.test(e))return!0;switch(`${e}`.toLowerCase()){case"first":case"last":case"count":case"distinct":case"sum":case"proportion":case"proportion-facet":case"deviation":case"min":case"min-index":case"max":case"max-index":case"mean":case"median":case"variance":case"mode":return!0}return!1}function J$(e){return e?new Jn(e).size>e.length>>1:!1}var n3={dot:yi,line:Pl,lineX:uc,lineY:fc,areaX:cc,areaY:aa,ruleX:Yr,ruleY:Xr,barX:qo,barY:jo,rect:fy,rectX:rd,rectY:id,cell:lc,bin:sa,binX:Uo,binY:zo,group:Um,groupX:tc,groupY:ec},Q$=Object.fromEntries(Object.entries(n3).map(([e,t])=>[t,e]));function sd(e,t={}){let{x:n,x1:r,x2:i}=t;n===void 0&&r===void 0&&i===void 0&&(t={...t,x:n=G});let o={};return n!=null&&(o.x=e),r!=null&&(o.x1=e),i!=null&&(o.x2=e),vr(o,t)}function ad(e,t={}){let{y:n,y1:r,y2:i}=t;n===void 0&&r===void 0&&i===void 0&&(t={...t,y:n=G});let o={};return n!=null&&(o.y=e),r!=null&&(o.y1=e),i!=null&&(o.y2=e),vr(o,t)}function vr(e={},t={}){let n=jn(t),r=Object.entries(e).map(([i,o])=>{let s=aw(i,t);if(s==null)throw new Error(`missing channel: ${i}`);let[a,c]=mn(s);return{key:i,input:s,output:a,setOutput:c,map:jK(o)}});return{...yn(t,(i,o)=>{let s=wt(i,n),a=r.map(({input:l})=>wt(i,l)),c=r.map(({setOutput:l})=>l(new Array(i.length)));for(let l of o)for(let u of s?cn(l,f=>s[f]).values():[l])r.forEach(({map:f},d)=>f.mapIndex(u,a[d],c[d]));return{data:i,facets:o}}),...Object.fromEntries(r.map(({key:i,output:o})=>[i,o]))}}function jK(e){if(e==null)throw new Error("missing map");if(typeof e.mapIndex=="function")return e;if(typeof e.map=="function"&&pn(e))return VK(e);if(typeof e=="function")return i3(Mf(e));switch(`${e}`.toLowerCase()){case"cumsum":return XK;case"rank":return i3((t,n)=>rp(t,r=>n[r]));case"quantile":return i3((t,n)=>YK(t,r=>n[r]))}throw new Error(`invalid map: ${e}`)}function VK(e){return console.warn("deprecated map interface; implement mapIndex instead."),{mapIndex:e.map.bind(e)}}function YK(e,t){let n=uo(e,t)-1;return rp(e,t).map(r=>r/n)}function i3(e){return{mapIndex(t,n,r){let i=e(t,n);if(i.length!==t.length)throw new Error("map function returned a mismatched length");for(let o=0,s=t.length;o<s;++o)r[t[o]]=i[o]}}}var XK={mapIndex(e,t,n){let r=0;for(let i of e)n[i]=r+=t[i]}};function t9(e={},t){return arguments.length===1&&(t=e),sd(cd(e),t)}function e9(e={},t){return arguments.length===1&&(t=e),ad(cd(e),t)}function cd(e={}){typeof e=="number"&&(e={k:e});let{k:t,reduce:n,shift:r,anchor:i,strict:o}=e;if(i===void 0&&r!==void 0&&(i=WK(r),Vn(`Warning: the shift option is deprecated; please use anchor "${i}" instead.`)),!((t=Math.floor(t))>0))throw new Error(`invalid k: ${t}`);return HK(n)(t,GK(i,t),o)}function GK(e="middle",t){switch(`${e}`.toLowerCase()){case"middle":return t-1>>1;case"start":return 0;case"end":return t-1}throw new Error(`invalid anchor: ${e}`)}function WK(e){switch(`${e}`.toLowerCase()){case"centered":return"middle";case"leading":return"start";case"trailing":return"end"}throw new Error(`invalid shift: ${e}`)}function HK(e="mean"){if(typeof e=="string"){if(/^p\d{2}$/i.test(e))return dv(Sf(e));switch(e.toLowerCase()){case"deviation":return dv(ii);case"max":return hv((t,n)=>Wt(t,r=>n[r]));case"mean":return ZK;case"median":return dv(Pi);case"min":return hv((t,n)=>ue(t,r=>n[r]));case"mode":return hv((t,n)=>Ou(t,r=>n[r]));case"sum":return n9;case"variance":return dv(Ea);case"difference":return KK;case"ratio":return ttt;case"first":return ett;case"last":return ntt}}if(typeof e!="function")throw new Error(`invalid reduce: ${e}`);return hv(Mf(e))}function dv(e){return(t,n,r)=>r?{mapIndex(i,o,s){let a=l=>o[l]==null?NaN:+o[l],c=0;for(let l=0;l<t-1;++l)isNaN(a(l))&&++c;for(let l=0,u=i.length-t+1;l<u;++l)isNaN(a(l+t-1))&&++c,s[i[l+n]]=c===0?e(Js(i,l,l+t),a):NaN,isNaN(a(l))&&--c}}:{mapIndex(i,o,s){let a=c=>o[c]==null?NaN:+o[c];for(let c=-n;c<0;++c)s[i[c+n]]=e(Js(i,0,c+t),a);for(let c=0,l=i.length-n;c<l;++c)s[i[c+n]]=e(Js(i,c,c+t),a)}}}function hv(e){return(t,n,r)=>r?{mapIndex(i,o,s){let a=0;for(let c=0;c<t-1;++c)a+=ze(o[i[c]]);for(let c=0,l=i.length-t+1;c<l;++c)a+=ze(o[i[c+t-1]]),a===t&&(s[i[c+n]]=e(Js(i,c,c+t),o)),a-=ze(o[i[c]])}}:{mapIndex(i,o,s){for(let a=-n;a<0;++a)s[i[a+n]]=e(Js(i,0,a+t),o);for(let a=0,c=i.length-n;a<c;++a)s[i[a+n]]=e(Js(i,a,a+t),o)}}}function n9(e,t,n){return n?{mapIndex(r,i,o){let s=0,a=0;for(let c=0;c<e-1;++c){let l=i[r[c]];l===null||isNaN(l)?++s:a+=+l}for(let c=0,l=r.length-e+1;c<l;++c){let u=i[r[c]],f=i[r[c+e-1]];f===null||isNaN(f)?++s:a+=+f,o[r[c+t]]=s===0?a:NaN,u===null||isNaN(u)?--s:a-=+u}}}:{mapIndex(r,i,o){let s=0,a=r.length;for(let c=0,l=Math.min(a,e-t-1);c<l;++c)s+=+i[r[c]]||0;for(let c=-t,l=a-t;c<l;++c)s+=+i[r[c+e-1]]||0,o[r[c+t]]=s,s-=+i[r[c]]||0}}}function ZK(e,t,n){if(n){let r=n9(e,t,n);return{mapIndex(i,o,s){r.mapIndex(i,o,s);for(let a=0,c=i.length-e+1;a<c;++a)s[i[a+t]]/=e}}}else return{mapIndex(r,i,o){let s=0,a=0,c=r.length;for(let l=0,u=Math.min(c,e-t-1);l<u;++l){let f=i[r[l]];f!==null&&!isNaN(f=+f)&&(s+=f,++a)}for(let l=-t,u=c-t;l<u;++l){let f=i[r[l+e-1]],d=i[r[l]];f!==null&&!isNaN(f=+f)&&(s+=f,++a),o[r[l+t]]=s/a,d!==null&&!isNaN(d=+d)&&(s-=d,--a)}}}}function JK(e,t,n,r){for(let i=n+r;n<i;++n){let o=e[t[n]];if(ze(o))return o}}function QK(e,t,n,r){for(let i=n+r-1;i>=n;--i){let o=e[t[i]];if(ze(o))return o}}function r9(e,t,n,r){for(let i=n+r;n<i;++n){let o=e[t[n]];if(o!==null&&!isNaN(o=+o))return o}}function i9(e,t,n,r){for(let i=n+r-1;i>=n;--i){let o=e[t[i]];if(o!==null&&!isNaN(o=+o))return o}}function KK(e,t,n){return n?{mapIndex(r,i,o){for(let s=0,a=r.length-e;s<a;++s){let c=i[r[s]],l=i[r[s+e-1]];o[r[s+t]]=c===null||l===null?NaN:l-c}}}:{mapIndex(r,i,o){for(let s=-t,a=r.length-e+t+1;s<a;++s)o[r[s+t]]=i9(i,r,s,e)-r9(i,r,s,e)}}}function ttt(e,t,n){return n?{mapIndex(r,i,o){for(let s=0,a=r.length-e;s<a;++s){let c=i[r[s]],l=i[r[s+e-1]];o[r[s+t]]=c===null||l===null?NaN:l/c}}}:{mapIndex(r,i,o){for(let s=-t,a=r.length-e+t+1;s<a;++s)o[r[s+t]]=i9(i,r,s,e)/r9(i,r,s,e)}}}function ett(e,t,n){return n?{mapIndex(r,i,o){for(let s=0,a=r.length-e;s<a;++s)o[r[s+t]]=i[r[s]]}}:{mapIndex(r,i,o){for(let s=-t,a=r.length-e+t+1;s<a;++s)o[r[s+t]]=JK(i,r,s,e)}}}function ntt(e,t,n){return n?{mapIndex(r,i,o){for(let s=0,a=r.length-e;s<a;++s)o[r[s+t]]=i[r[s+e-1]]}}:{mapIndex(r,i,o){for(let s=-t,a=r.length-e+t+1;s<a;++s)o[r[s+t]]=QK(i,r,s,e)}}}var ca={n:20,k:2,color:"currentColor",opacity:.2,strict:!0,anchor:"end"};function o9(e,{x:t=G,y:n,k:r=ca.k,color:i=ca.color,opacity:o=ca.opacity,fill:s=i,fillOpacity:a=o,stroke:c=i,strokeOpacity:l,strokeWidth:u,...f}={}){return en(re(s)?null:cc(e,vr({x1:dc({k:-r,...f}),x2:dc({k:r,...f})},{x1:t,x2:t,y:n,fill:s,fillOpacity:a,...f})),re(c)?null:uc(e,vr({x:dc(f)},{x:t,y:n,stroke:c,strokeOpacity:l,strokeWidth:u,...f})))}function s9(e,{x:t,y:n=G,k:r=ca.k,color:i=ca.color,opacity:o=ca.opacity,fill:s=i,fillOpacity:a=o,stroke:c=i,strokeOpacity:l,strokeWidth:u,...f}={}){return en(re(s)?null:aa(e,vr({y1:dc({k:-r,...f}),y2:dc({k:r,...f})},{x:t,y1:n,y2:n,fill:s,fillOpacity:a,...f})),re(c)?null:fc(e,vr({y:dc(f)},{x:t,y:n,stroke:c,strokeOpacity:l,strokeWidth:u,...f})))}function dc({n:e=ca.n,k:t=0,strict:n=ca.strict,anchor:r=ca.anchor}={}){return cd({k:e,reduce:i=>Ns(i)+t*(ii(i)||0),strict:n,anchor:r})}var rtt={ariaLabel:"tick",fill:null,stroke:"currentColor"},pv=class extends St{constructor(t,n,r){super(t,n,r,rtt),Xi(this,r)}render(t,n,r,i,o){return ut("svg:g",o).call(Ct,this,i,o).call(this._transform,this,n).call(s=>s.selectAll().data(t).enter().append("line").call(Lt,this).attr("x1",this._x1(n,r,i)).attr("x2",this._x2(n,r,i)).attr("y1",this._y1(n,r,i)).attr("y2",this._y2(n,r,i)).call(Qt,this,r).call(oa,this,r,o)).node()}},hy=class extends pv{constructor(t,n={}){let{x:r,y:i,inset:o=0,insetTop:s=o,insetBottom:a=o}=n;super(t,{x:{value:r,scale:"x"},y:{value:i,scale:"y",type:"band",optional:!0}},n),this.insetTop=Bt(s),this.insetBottom=Bt(a)}_transform(t,n,{x:r}){t.call(Et,n,{x:r},Ce,0)}_x1(t,{x:n}){return r=>n[r]}_x2(t,{x:n}){return r=>n[r]}_y1({y:t},{y:n},{marginTop:r}){let{insetTop:i}=this;return n&&t?o=>n[o]+i:r+i}_y2({y:t},{y:n},{height:r,marginBottom:i}){let{insetBottom:o}=this;return n&&t?s=>n[s]+t.bandwidth()-o:r-i-o}},py=class extends pv{constructor(t,n={}){let{x:r,y:i,inset:o=0,insetRight:s=o,insetLeft:a=o}=n;super(t,{y:{value:i,scale:"y"},x:{value:r,scale:"x",type:"band",optional:!0}},n),this.insetRight=Bt(s),this.insetLeft=Bt(a)}_transform(t,n,{y:r}){t.call(Et,n,{y:r},0,Ce)}_x1({x:t},{x:n},{marginLeft:r}){let{insetLeft:i}=this;return n&&t?o=>n[o]+i:r+i}_x2({x:t},{x:n},{width:r,marginRight:i}){let{insetRight:o}=this;return n&&t?s=>n[s]+t.bandwidth()-o:r-i-o}_y1(t,{y:n}){return r=>n[r]}_y2(t,{y:n}){return r=>n[r]}};function mv(e,{x:t=G,...n}={}){return new hy(e,{...n,x:t})}function yv(e,{y:t=G,...n}={}){return new py(e,{...n,y:t})}function a9(e,{x:t=G,y:n=null,fill:r="#ccc",fillOpacity:i,stroke:o="currentColor",strokeOpacity:s,strokeWidth:a=2,sort:c,...l}={}){let u=n!=null?ec:Pm;return en(Xr(e,u({x1:o3,x2:s3},{x:t,y:n,stroke:o,strokeOpacity:s,...l})),qo(e,u({x1:"p25",x2:"p75"},{x:t,y:n,fill:r,fillOpacity:i,...l})),mv(e,u({x:"p50"},{x:t,y:n,stroke:o,strokeOpacity:s,strokeWidth:a,sort:c,...l})),yi(e,vr({x:l9},{x:t,y:n,z:n,stroke:o,strokeOpacity:s,...l})))}function c9(e,{y:t=G,x:n=null,fill:r="#ccc",fillOpacity:i,stroke:o="currentColor",strokeOpacity:s,strokeWidth:a=2,sort:c,...l}={}){let u=n!=null?tc:Pm;return en(Yr(e,u({y1:o3,y2:s3},{x:n,y:t,stroke:o,strokeOpacity:s,...l})),jo(e,u({y1:"p25",y2:"p75"},{x:n,y:t,fill:r,fillOpacity:i,...l})),yv(e,u({y:"p50"},{x:n,y:t,stroke:o,strokeOpacity:s,strokeWidth:a,sort:c,...l})),yi(e,vr({y:l9},{x:n,y:t,z:n,stroke:o,strokeOpacity:s,...l})))}function l9(e){let t=o3(e),n=s3(e);return e.map(r=>r<t||r>n?r:NaN)}function o3(e){let t=u9(e)*2.5-f9(e)*1.5;return ue(e,n=>n>=t?n:NaN)}function s3(e){let t=f9(e)*2.5-u9(e)*1.5;return Wt(e,n=>n<=t?n:NaN)}function u9(e){return Qn(e,.25)}function f9(e){return Qn(e,.75)}var itt={ariaLabel:"raster",stroke:null,pixelSize:1};function ld(e,t){let n=+e;if(isNaN(n))throw new Error(`invalid ${t}: ${e}`);return n}function d9(e,t){let n=Math.floor(e);if(isNaN(n))throw new Error(`invalid ${t}: ${e}`);return n}var yy=class extends St{constructor(t,n,r={},i){let{width:o,height:s,x:a,y:c,x1:l=a==null?0:void 0,y1:u=c==null?0:void 0,x2:f=a==null?o:void 0,y2:d=c==null?s:void 0,pixelSize:h=i.pixelSize,blur:p=0,interpolate:m}=r;if(o!=null&&(o=d9(o,"width")),s!=null&&(s=d9(s,"height")),l!=null&&(l=ld(l,"x1")),u!=null&&(u=ld(u,"y1")),f!=null&&(f=ld(f,"x2")),d!=null&&(d=ld(d,"y2")),a==null&&(l==null||f==null))throw new Error("missing x");if(c==null&&(u==null||d==null))throw new Error("missing y");t!=null&&o!=null&&s!=null&&(a===void 0&&l!=null&&f!=null&&(a=dtt(l,f,o,s)),c===void 0&&u!=null&&d!=null&&(c=htt(u,d,o,s))),super(t,{x:{value:a,scale:"x",optional:!0},y:{value:c,scale:"y",optional:!0},x1:{value:l==null?null:[l],scale:"x",optional:!0,filter:null},y1:{value:u==null?null:[u],scale:"y",optional:!0,filter:null},x2:{value:f==null?null:[f],scale:"x",optional:!0,filter:null},y2:{value:d==null?null:[d],scale:"y",optional:!0,filter:null},...n},r,i),this.width=o,this.height=s,this.pixelSize=ld(h,"pixelSize"),this.blur=ld(p,"blur"),this.interpolate=a==null||c==null?null:ott(m)}},gy=class extends yy{constructor(t,n={}){let{imageRendering:r}=n;if(t==null){let{fill:i,fillOpacity:o}=n;se(o)[0]!==void 0&&(n=gv("fillOpacity",n)),Be(i)[0]!==void 0&&(n=gv("fill",n))}super(t,void 0,n,itt),this.imageRendering=fe(r,"auto")}scale(t,{color:n,...r},i){return super.scale(t,r,i)}render(t,n,r,i,o){let s=n[r.channels.fill?.scale]??(M=>M),{x:a,y:c}=r,{document:l}=o,[u,f,d,h]=p9(r,i,o),p=d-u,m=h-f,{pixelSize:g,width:y=Math.round(Math.abs(p)/g),height:x=Math.round(Math.abs(m)/g)}=this,b=y*x,{fill:w,fillOpacity:v}=r,_=0;if(this.interpolate){let M=y/p,N=x/m,F=Gt(a,k=>(k-u)*M,Float64Array),R=Gt(c,k=>(k-f)*N,Float64Array);w&&(w=this.interpolate(t,y,x,F,R,w)),v&&(v=this.interpolate(t,y,x,F,R,v))}else this.data==null&&t&&(_=t.fi*b);let I=l.createElement("canvas");I.width=y,I.height=x;let D=I.getContext("2d"),A=D.createImageData(y,x),E=A.data,{r:T,g:O,b:C}=on(this.fill)??{r:0,g:0,b:0},S=(this.fillOpacity??1)*255;for(let M=0;M<b;++M){let N=M<<2;if(w){let F=s(w[M+_]);if(F==null){E[N+3]=0;continue}({r:T,g:O,b:C}=on(F))}v&&(S=v[M+_]*255),E[N+0]=T,E[N+1]=O,E[N+2]=C,E[N+3]=S}return this.blur>0&&$S(A,this.blur),D.putImageData(A,0,0),ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(M=>M.append("image").attr("transform",`translate(${u},${f}) scale(${Math.sign(d-u)},${Math.sign(h-f)})`).attr("width",Math.abs(p)).attr("height",Math.abs(m)).attr("preserveAspectRatio","none").call(ft,"image-rendering",this.imageRendering).call(Lt,this).attr("xlink:href",I.toDataURL())).node()}};function a3(e,t,n){arguments.length<3&&(n=t,t=null);let{x:r,y:i,[e]:o,...s}=n;return r===void 0&&i===void 0&&VF(t)&&(r=Zs,i=Ha,o===void 0&&(o=PF)),[t,{...s,x:r,y:i,[e]:o}]}function h9(){let[e,t]=a3("fill",...arguments);return new gy(e,e==null||t.fill!==void 0||t.fillOpacity!==void 0?t:{...t,fill:G})}function p9({x1:e,y1:t,x2:n,y2:r},i,{projection:o}){let{width:s,height:a,marginTop:c,marginRight:l,marginBottom:u,marginLeft:f}=i;return[e&&o==null?e[0]:f,t&&o==null?t[0]:c,n&&o==null?n[0]:s-l,r&&o==null?r[0]:a-u]}function c3({x1:e,y1:t,x2:n,y2:r},i,o,s){let a={};return e&&(a.x1=e),t&&(a.y1=t),n&&(a.x2=n),r&&(a.y2=r),p9(Bf(a,i),o,s)}function gv(e,t={}){let{[e]:n}=t;if(typeof n!="function")throw new Error(`invalid ${e}: not a function`);return Ie({...t,[e]:void 0},function(r,i,o,s,a,c){let{x:l,y:u}=s;if(!l)throw new Error("missing scale: x");if(!u)throw new Error("missing scale: y");let[f,d,h,p]=c3(o,s,a,c),m=h-f,g=p-d,{pixelSize:y}=this,{width:x=Math.round(Math.abs(m)/y),height:b=Math.round(Math.abs(g)/y)}=t,w=new Array(x*b*(i?i.length:1)),v=m/x,_=g/b,I=0;for(let D of i??[void 0])for(let A=.5;A<b;++A)for(let E=.5;E<x;++E,++I)w[I]=n(l.invert(f+E*v),u.invert(d+A*_),D);return{data:w,facets:i,channels:{[e]:{value:w,scale:"auto"}}}})}function ott(e){if(typeof e=="function")return e;if(e==null)return xv;switch(`${e}`.toLowerCase()){case"none":return xv;case"nearest":return u3;case"barycentric":return l3();case"random-walk":return f3()}throw new Error(`invalid interpolate: ${e}`)}function xv(e,t,n,r,i,o){let s=new Array(t*n);for(let a of e)r[a]<0||r[a]>=t||i[a]<0||i[a]>=n||(s[Math.floor(i[a])*t+Math.floor(r[a])]=o[a]);return s}function l3({random:e=Mo(42)}={}){return(t,n,r,i,o,s)=>{let{points:a,triangles:c,hull:l}=Pn.from(t,h=>i[h],h=>o[h]),u=new s.constructor(n*r).fill(NaN),f=new Uint8Array(n*r),d=ftt(s,e);for(let h=0;h<c.length;h+=3){let p=c[h],m=c[h+1],g=c[h+2],y=a[2*p],x=a[2*m],b=a[2*g],w=a[2*p+1],v=a[2*m+1],_=a[2*g+1],I=Math.min(y,x,b),D=Math.max(y,x,b),A=Math.min(w,v,_),E=Math.max(w,v,_),T=(v-_)*(y-b)+(w-_)*(b-x);if(!T)continue;let O=s[t[p]],C=s[t[m]],S=s[t[g]];for(let M=Math.floor(I);M<D;++M)for(let N=Math.floor(A);N<E;++N){if(M<0||M>=n||N<0||N>=r)continue;let F=M+.5,R=N+.5,k=((v-_)*(F-b)+(R-_)*(b-x))/T;if(k<0)continue;let $=((_-w)*(F-b)+(R-_)*(y-b))/T;if($<0)continue;let P=1-k-$;if(P<0)continue;let U=M+n*N;u[U]=d(O,k,C,$,S,P,M,N),f[U]=1}}return stt(u,f,i,o,s,n,r,l,t,d),u}}function stt(e,t,n,r,i,o,s,a,c,l){n=Float64Array.from(a,h=>n[c[h]]),r=Float64Array.from(a,h=>r[c[h]]),i=Array.from(a,h=>i[c[h]]);let u=n.length,f=Array.from({length:u},(h,p)=>ctt(p,n,r)),d=0;for(let h=0;h<s;++h){let p=h+.5;for(let m=0;m<o;++m){let g=m+o*h;if(!t[g]){let y=m+.5;for(let x=0;x<u;++x){let b=(u+d+(x%2?(x+1)/2:-x/2))%u;if(f[b](y,p)){let w=att(n.at(b-1),r.at(b-1),n[b],r[b],y,p);e[g]=l(i.at(b-1),w,i[b],1-w,i[b],0,m,h),d=b;break}}}}}}function att(e,t,n,r,i,o){let s=n-e,a=r-t,c=s*(n-i)+a*(r-o),l=s*(i-e)+a*(o-t);return c>0&&l>0?c/(c+l):+(c>l)}function my(e,t,n,r){return e*r-n*t}function ctt(e,t,n){let r=t.length,i=t.at(e-2),o=n.at(e-2),s=t.at(e-1),a=n.at(e-1),c=t[e],l=n[e],u=t.at(e+1-r),f=n.at(e+1-r),d=s-c,h=a-l,p=i-s,m=o-a,g=c-u,y=l-f,x=Math.hypot(d,h),b=Math.hypot(p,m),w=Math.hypot(g,y);return(v,_)=>{let I=v-s,D=_-a,A=v-c,E=_-l;return my(I,D,A,E)>-1e-6&&my(I,D,d,h)*b-my(I,D,p,m)*x>-1e-6&&my(A,E,g,y)*x-my(A,E,d,h)*w<=0}}function u3(e,t,n,r,i,o){let s=new o.constructor(t*n),a=Pn.from(e,u=>r[u],u=>i[u]),c,l;for(let u=.5,f=0;u<n;++u){l=c;for(let d=.5;d<t;++d,++f)l=a.find(d,u,l),d===.5&&(c=l),s[f]=o[e[l]]}return s}function f3({random:e=Mo(42),minDistance:t=.5,maxSteps:n=2}={}){return(r,i,o,s,a,c)=>{let l=new c.constructor(i*o),u=Pn.from(r,p=>s[p],p=>a[p]),f,d,h;for(let p=.5,m=0;p<o;++p){d=f;for(let g=.5;g<i;++g,++m){let y=g,x=p;h=d=u.find(y,x,d),g===.5&&(f=d);let b,w=0;for(;(b=Math.hypot(s[r[h]]-y,a[r[h]]-x))>t&&w<n;){let v=e(g,p,w)*2*Math.PI;y+=Math.cos(v)*b,x+=Math.sin(v)*b,h=u.find(y,x,h),++w}l[m]=c[r[h]]}}return l}}function ltt(e,t,n,r,i,o){return t*e+r*n+o*i}function utt(e){return(t,n,r,i,o,s,a,c)=>{let l=e(a,c);return l<n?t:l<n+i?r:o}}function ftt(e,t){return Ks(e)||Le(e)?ltt:utt(t)}function dtt(e,t,n){return{transform(r){let i=r.length,o=new Float64Array(i),s=(t-e)/n,a=e+s/2;for(let c=0;c<i;++c)o[c]=c%n*s+a;return o}}}function htt(e,t,n,r){return{transform(i){let o=i.length,s=new Float64Array(o),a=(t-e)/r,c=e+a/2;for(let l=0;l<o;++l)s[l]=Math.floor(l/n)%r*a+c;return s}}}var m9={ariaLabel:"contour",fill:"none",stroke:"currentColor",strokeMiterlimit:1,pixelSize:2},xy=class extends yy{constructor(t,{smooth:n=!0,value:r,...i}={}){let o=vw({},i,m9);if(r===void 0){for(let a in o)if(o[a].value!=null){if(r!==void 0)throw new Error("ambiguous contour value");r=i[a],i[a]="value"}}if(r!=null){let a={transform:c=>c.map(l=>l.value),label:On(r)};for(let c in o)i[c]==="value"&&(i[c]=a)}if(t==null){if(r==null)throw new Error("missing contour value");i=gv("value",{value:r,...i}),r=null}else{let{interpolate:a}=i;r===void 0&&(r=G),a===void 0&&(i.interpolate="nearest")}super(t,{value:{value:r,optional:!0}},ptt(i),m9);let s={geometry:{value:G}};for(let a in this.channels){let c=this.channels[a],{scale:l}=c;l==="x"||l==="y"||a==="value"||(s[a]=c,delete this.channels[a])}this.contourChannels=s,this.smooth=!!n}filter(t,{x:n,y:r,value:i,...o},s){return super.filter(t,o,s)}render(t,n,r,i,o){let{geometry:s}=r,a=En();return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(c=>{c.selectAll().data(t).enter().append("path").call(Lt,this).attr("d",l=>a(s[l])).call(Qt,this,r)}).node()}};function ptt({thresholds:e,interval:t,...n}){return e=QT(e,t,Na),Ie(n,function(r,i,o,s,a,c){let[l,u,f,d]=c3(o,s,a,c),h=f-l,p=d-u,{pixelSize:m,width:g=Math.round(Math.abs(h)/m),height:y=Math.round(Math.abs(p)/m)}=this,x=g/h,b=y/p,w=o.value.value,v=[];if(this.interpolate){let{x:E,y:T}=rc(o,s,c),O=Gt(E,N=>(N-l)*x,Float64Array),C=Gt(T,N=>(N-u)*b,Float64Array),S=[o.x,o.y,o.value],M=[O,C,w];for(let N of i){let F=this.filter(N,S,M);v.push(this.interpolate(F,g,y,O,C,w))}}else if(i){let E=g*y,T=i.length;for(let O=0;O<T;++O)v.push(w.slice(O*E,O*E+E))}else v.push(w);if(this.blur>0)for(let E of v)Qh({data:E,width:g,height:y},this.blur);let _=mtt(e,w,...ytt(v));if(_===null)throw new Error(`unsupported thresholds: ${e}`);let{contour:I}=Fa().size([g,y]).smooth(this.smooth),D=[],A=[];for(let E of v)A.push(Ue(D.length,D.push(...Gt(_,T=>I(E,T)))));for(let{coordinates:E}of D)for(let T of E)for(let O of T)for(let C of O)C[0]=C[0]/x+l,C[1]=C[1]/b+u;return{data:D,facets:A,channels:xw(this.contourChannels,D)}})}function mtt(e,t,n,r){if(typeof e?.range=="function")return e.range(e.floor(n),r);if(typeof e=="function"&&(e=e(t,n,r)),typeof e!="number")return je(e);let i=Mn(...Nu(n,r,e),e);for(;i[i.length-1]>=r;)i.pop();for(;i[1]<n;)i.shift();return i}function g9(){return new xy(...a3("value",...arguments))}function ytt(e){return[ue(e,t=>ue(t,y9)),Wt(e,t=>Wt(t,y9))]}function y9(e){return isFinite(e)?e:NaN}function w9(e,t){return d3(qf,e,t)}function v9(e,t={}){return d3(jf,e,t)}function _9(e,t={}){return d3(El,e,t)}function d3(e,t,n={}){let{x:r,y:i,maxRadius:o}=n,s=e({px:r,py:i,maxRadius:o}),a=[];r!=null&&a.push(Yr(t,x9("x",{...s,inset:-6},n))),i!=null&&a.push(Xr(t,x9("y",{...s,inset:-6},n))),r!=null&&a.push(Po(t,b9("x",{...s,dy:9,frameAnchor:"bottom",lineAnchor:"top"},n))),i!=null&&a.push(Po(t,b9("y",{...s,dx:-9,frameAnchor:"left",textAnchor:"end"},n)));for(let c of a)c.ariaLabel=`crosshair ${c.ariaLabel}`;return en(...a)}function S9(e,{channels:t,...n},{facet:r,facetAnchor:i,fx:o,fy:s,[e]:a,channels:c,transform:l,initializer:u}){return{...n,facet:r,facetAnchor:i,fx:o,fy:s,[e]:a,channels:{...t,...c},transform:l,initializer:gtt(e,u)}}function gtt(e,t){return t==null?t:function(n,r,{x:i,y:o,px:s,py:a,...c},...l){let{channels:{x:u,y:f,...d}={},...h}=t.call(this,n,r,{...c,x:s,y:a},...l);return{channels:{...d,...u&&{px:u,...e==="x"&&{x:u}},...f&&{py:f,...e==="y"&&{y:f}}},...h}}}function x9(e,t,n){let{color:r="currentColor",opacity:i=.2,ruleStroke:o=r,ruleStrokeOpacity:s=i,ruleStrokeWidth:a}=n;return{...S9(e,t,n),stroke:o,strokeOpacity:s,strokeWidth:a}}function b9(e,t,n){let{color:r="currentColor",textFill:i=r,textFillOpacity:o,textStroke:s="var(--plot-background)",textStrokeOpacity:a,textStrokeWidth:c=5}=n;return{...S9(e,t,xtt(e,n)),fill:i,fillOpacity:o,stroke:s,strokeOpacity:a,strokeWidth:c}}function xtt(e,t){return Ie(t,(n,r,i)=>({channels:{text:{value:qm(i,e)?.value}}}))}var btt={ariaLabel:"delaunay link",fill:"none",stroke:"currentColor",strokeMiterlimit:1},wtt={ariaLabel:"delaunay mesh",fill:null,stroke:"currentColor",strokeOpacity:.2},vtt={ariaLabel:"hull",fill:"none",stroke:"currentColor",strokeWidth:1.5,strokeMiterlimit:1},_tt={ariaLabel:"voronoi",fill:"none",stroke:"currentColor",strokeMiterlimit:1},Stt={ariaLabel:"voronoi mesh",fill:null,stroke:"currentColor",strokeOpacity:.2},h3=class extends St{constructor(t,n={}){let{x:r,y:i,z:o,curve:s,tension:a}=n;super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},z:{value:o,optional:!0}},n,btt),this.curve=ry(s,a),Xi(this,n)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,z:u}=r,{curve:f}=this,[d,h]=gn(this,i),p=c?x=>c[x]:hn(d),m=l?x=>l[x]:hn(h),g=this;function y(x){let b=-1,w=[],v={};for(let S in r)v[S]=[];let _=[],I=[],D=[],A=[];function E(S,M){S=x[S],M=x[M],w.push(++b),_[b]=p(S),D[b]=m(S),I[b]=p(M),A[b]=m(M);for(let N in r)v[N].push(r[N][M])}let{halfedges:T,hull:O,triangles:C}=Pn.from(x,p,m);for(let S=0;S<T.length;++S){let M=T[S];M>S&&E(C[S],C[M])}for(let S=0;S<O.length;++S)E(O[S],O[(S+1)%O.length]);Vt(this).selectAll().data(w).enter().append("path").call(Lt,g).attr("d",S=>{let M=er(),N=f(M);return N.lineStart(),N.point(_[S],D[S]),N.point(I[S],A[S]),N.lineEnd(),M}).call(Qt,g,v).call(oa,g,v,o)}return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(u?x=>x.selectAll().data(cn(t,b=>u[b]).values()).enter().append("g").each(y):x=>x.datum(t).each(y)).node()}},by=class extends St{constructor(t,n={},r,i=({z:o})=>o){let{x:o,y:s}=n;super(t,{x:{value:o,scale:"x",optional:!0},y:{value:s,scale:"y",optional:!0},z:{value:i(n),optional:!0}},n,r)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,z:u}=r,[f,d]=gn(this,i),h=c?y=>c[y]:hn(f),p=l?y=>l[y]:hn(d),m=this;function g(y){let x=Pn.from(y,h,p);Vt(this).append("path").datum(y[0]).call(Lt,m).attr("d",m._render(x,i)).call(Qt,m,r)}return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(u?y=>y.selectAll().data(cn(t,x=>u[x]).values()).enter().append("g").each(g):y=>y.datum(t).each(g)).node()}},p3=class extends by{constructor(t,n={}){super(t,n,wtt),this.fill="none"}_render(t){return t.render()}},m3=class extends by{constructor(t,n={}){super(t,n,vtt,jn)}_render(t){return t.renderHull()}},y3=class extends St{constructor(t,n={}){let{x:r,y:i,z:o}=n;super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},z:{value:o,optional:!0}},n,_tt)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,z:u}=r,[f,d]=gn(this,i),h=c?y=>c[y]:hn(f),p=l?y=>l[y]:hn(d),m=this;function g(y){let x=Pn.from(y,h,p),b=I9(x,i);Vt(this).selectAll().data(y).enter().append("path").call(Lt,m).attr("d",(w,v)=>b.renderCell(v)).call(Qt,m,r)}return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(u?y=>y.selectAll().data(cn(t,x=>u[x]).values()).enter().append("g").each(g):y=>y.datum(t).each(g)).node()}},g3=class extends by{constructor(t,n){super(t,n,Stt),this.fill="none"}_render(t,n){return I9(t,n).render()}};function I9(e,t){let{width:n,height:r,marginTop:i,marginRight:o,marginBottom:s,marginLeft:a}=t;return e.voronoi([a,i,n-o,r-s])}function wy(e,t,{x:n,y:r,...i}={}){return[n,r]=$e(n,r),new e(t,{...i,x:n,y:r})}function M9(e,t){return wy(h3,e,t)}function A9(e,t){return wy(p3,e,t)}function T9(e,t){return wy(m3,e,t)}function E9(e,t){return wy(y3,e,t)}function N9(e,t){return wy(g3,e,t)}var Itt={ariaLabel:"density",fill:"none",stroke:"currentColor",strokeMiterlimit:1},vy=class extends St{constructor(t,{x:n,y:r,z:i,weight:o,fill:s,stroke:a,...c}={}){let l=D9(s)&&(s="currentColor",!0),u=D9(a)&&(a="currentColor",!0);super(t,{x:{value:n,scale:"x",optional:!0},y:{value:r,scale:"y",optional:!0},z:{value:jn({z:i,fill:s,stroke:a}),optional:!0},weight:{value:o,optional:!0}},Att({...c,fill:s,stroke:a},l,u),Itt),l&&(this.fill=void 0),u&&(this.stroke=void 0),this.z=i}filter(t){return t}render(t,n,r,i,o){let{contours:s}=r,a=En();return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{}).call(c=>c.selectAll().data(t).enter().append("path").call(Lt,this).call(Qt,this,r).attr("d",l=>a(s[l]))).node()}};function O9(e,{x:t,y:n,...r}={}){return[t,n]=$e(t,n),new vy(e,{...r,x:t,y:n})}var Mtt=new Set(["x","y","z","weight"]);function Att(e,t,n){let{bandwidth:i,thresholds:o}=e;return i=i===void 0?20:+i,o=o===void 0?20:typeof o?.[Symbol.iterator]=="function"?Ke(o):+o,Ie(e,function(s,a,c,l,u,f){let d=c.weight?Ke(c.weight.value):null,h=c.z?.value,{z:p}=this,[m,g]=gn(this,u),{width:y,height:x}=u,{x:b,y:w}=rc(c,l,f),v=Object.fromEntries(Object.entries(c).filter(([C])=>!Mtt.has(C)).map(([C,S])=>[C,{...S,value:[]}])),_=t&&[],I=n&&[],D=AI().x(b?C=>b[C]:m).y(w?C=>w[C]:g).weight(d?C=>d[C]:1).size([y,x]).bandwidth(i),A=[];for(let C of a){let S=[];A.push(S);for(let M of h?Vm(C,h,p):[C]){let N=D.contours(M);S.push([M,N])}}let E=o;if(!(E instanceof _l)){let C=0;for(let S of A)for(let[,M]of S){let N=M.max;N>C&&(C=N)}E=Float64Array.from({length:o-1},(S,M)=>C*100*(M+1)/o)}let T=[],O=[];for(let C of A){let S=[];T.push(S);for(let[M,N]of C)for(let F of E){S.push(O.length),O.push(N(F/100)),_&&_.push(F),I&&I.push(F);for(let R in v)v[R].value.push(c[R].value[M[0]])}}return _&&_.push(0),I&&I.push(0),{data:s,facets:T,channels:{...v,..._&&{fill:{value:_,scale:"color"}},...I&&{stroke:{value:I,scale:"color"}},contours:{value:O}}}})}function D9(e){return/^density$/i.test(e)}function C9(e,{x1:t,x2:n,y1:r,y2:i,x:o=t===void 0&&n===void 0?Ee:void 0,y:s=r===void 0&&i===void 0?G:void 0,fill:a,positiveFill:c="#3ca951",negativeFill:l="#4269d0",fillOpacity:u=1,positiveFillOpacity:f=u,negativeFillOpacity:d=u,stroke:h,strokeOpacity:p,z:m=Be(h)[0],clip:g,tip:y,render:x,...b}={}){return[t,n]=B9(o,t,n),[r,i]=B9(s,r,i),t===n&&r===i&&(r=hc(0)),{tip:y}=Yi({tip:y},"x"),en(re(c)?null:Object.assign(iy(e,{x1:t,x2:n,y1:r,y2:i,z:m,fill:c,fillOpacity:f,render:zf(x,L9(!0)),clip:g,...b}),{ariaLabel:"positive difference"}),re(l)?null:Object.assign(iy(e,{x1:t,x2:n,y1:r,y2:i,z:m,fill:l,fillOpacity:d,render:zf(x,L9(!1)),clip:g,...b}),{ariaLabel:"negative difference"}),Pl(e,{x:n,y:i,z:m,stroke:h,strokeOpacity:p,tip:y,clip:!0,...b}))}function B9(e,t,n){return t===void 0&&n===void 0?t=n=hc(e):t===void 0?(n=hc(n),t=e===void 0?n:hc(e)):n===void 0?(t=hc(t),n=e===void 0?t:hc(e)):(t=hc(t),n=hc(n)),[t,n]}function hc(e){let t,{value:n,label:r=On(n)}=pi(e);return{transform:i=>t||(t=wt(i,n)),label:r}}function L9(e){return(t,n,r,i,o,s)=>{let{x1:a,x2:c}=r,{height:l}=i,u=new Float32Array(a.length),f=new Float32Array(c.length);(e===Ew(n.y)<0?u:f).fill(l);let d=s(t,n,{...r,x2:a,y2:f},i,o),h=s(t,n,{...r,x1:c,y1:u},i,o),p=d.querySelector("g")??d,m=h.querySelector("g")??h;for(let g=0;p.firstChild;g+=2){let y=ww(),x=ut("svg:clipPath",o).attr("id",y).node();x.appendChild(p.firstChild),m.childNodes[g].setAttribute("clip-path",`url(#${y})`),m.insertBefore(x,m.childNodes[g])}return h}}var Ttt={ariaLabel:"geo",fill:"none",stroke:"currentColor",strokeWidth:1,strokeLinecap:"round",strokeLinejoin:"round",strokeMiterlimit:1},_y=class extends St{constructor(t,n={}){let[r,i]=se(n.r,3);super(t,{geometry:{value:n.geometry,scale:"projection"},r:{value:r,scale:"r",filter:sr,optional:!0}},uy(n),Ttt),this.r=i}render(t,n,r,i,o){let{geometry:s,r:a}=r,c=En(o.projection??Ett(n)),{r:l}=this;return Va(l)?t=[]:l!==void 0&&c.pointRadius(l),ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(u=>{u.selectAll().data(t).enter().append("path").call(Lt,this).attr("d",a?f=>c.pointRadius(a[f])(s[f]):f=>c(s[f])).call(Qt,this,r)}).node()}};function Ett({x:e,y:t}){if(e||t)return e??=n=>n,t??=n=>n,cl({point(n,r){this.stream.point(e(n),t(r))}})}function bv(e,{geometry:t=G,...n}={}){switch(e?.type){case"FeatureCollection":e=e.features;break;case"GeometryCollection":e=e.geometries;break;case"Feature":case"LineString":case"MultiLineString":case"MultiPoint":case"MultiPolygon":case"Point":case"Polygon":case"Sphere":e=[e];break}return new _y(e,{geometry:t,...n})}function k9({strokeWidth:e=1.5,...t}={}){return bv({type:"Sphere"},{strokeWidth:e,...t})}function F9({strokeOpacity:e=.1,...t}={}){return bv(WI(),{strokeOpacity:e,...t})}var ud=.5,fd=0;function R9(e={fill:"count"},{binWidth:t,...n}={}){let{z:r}=n;return t=t===void 0?20:Bt(t),e=cT(e,n),Ro(e,"fill")&&(n.channels={...n.channels,fill:{value:[]}}),n.symbol===void 0&&(n.symbol="hexagon"),n.r===void 0&&!Ro(e,"r")&&(n.r=t/2),Ie(n,(i,o,s,a,c,l)=>{let{x:u,y:f,z:d,fill:h,stroke:p,symbol:m}=s;if(u===void 0)throw new Error("missing channel: x");if(f===void 0)throw new Error("missing channel: y");({x:u,y:f}=rc(s,a,l)),d=d?d.value:wt(i,r),h=h?.value,p=p?.value,m=m?.value;let g=zm(e,{z:d,fill:h,stroke:p,symbol:m}),y=d&&[],x=h&&[],b=p&&[],w=m&&[],v=[],_=[],I=[],D=-1;for(let O of e)O.initialize(i);for(let O of o){let C=[];for(let S of e)S.scope("facet",O);for(let[S,M]of Ka(O,g))for(let{index:N,extent:F}of Ntt(i,M,u,f,t)){C.push(++D),_.push(F.x),I.push(F.y),d&&y.push(g===d?S:d[N[0]]),h&&x.push(g===h?S:h[N[0]]),p&&b.push(g===p?S:p[N[0]]),m&&w.push(g===m?S:m[N[0]]);for(let R of e)R.reduce(N,F)}v.push(C)}let A=s.x.scale,E=s.y.scale,T={x:{value:_,source:a[A]?{value:Gt(_,a[A].invert),scale:A}:null},y:{value:I,source:a[E]?{value:Gt(I,a[E].invert),scale:E}:null},...d&&{z:{value:y}},...h&&{fill:{value:x,scale:"auto"}},...p&&{stroke:{value:b,scale:"auto"}},...m&&{symbol:{value:w,scale:"auto"}},...Object.fromEntries(e.map(({name:O,output:C})=>[O,{scale:"auto",label:C.label,radius:O==="r"?t/2:void 0,value:C.transform()}]))};return{data:i,facets:v,channels:T}})}function Ntt(e,t,n,r,i){let o=i*(1.5/QA),s=new Map;for(let a of t){let c=n[a],l=r[a];if(isNaN(c)||isNaN(l))continue;let u=Math.round(l=(l-fd)/o),f=Math.round(c=(c-ud)/i-(u&1)/2),d=l-u;if(Math.abs(d)*3>1){let m=c-f,g=f+(c<f?-1:1)/2,y=u+(l<u?-1:1),x=c-g,b=l-y;m*m+d*d>x*x+b*b&&(f=g+(u&1?1:-1)/2,u=y)}let h=`${f},${u}`,p=s.get(h);p===void 0&&(p={index:[],extent:{data:e,x:(f+(u&1)/2)*i+ud,y:u*o+fd}},s.set(h,p)),p.index.push(a)}return s.values()}var Dtt={ariaLabel:"hexgrid",fill:"none",stroke:"currentColor",strokeOpacity:.1};function $9(e){return new Sy(e)}var Sy=class extends St{constructor({binWidth:t=20,clip:n=!0,...r}={}){super(Wa,void 0,{clip:n,...r},Dtt),this.binWidth=Bt(t)}render(t,n,r,i,o){let{binWidth:s}=this,{marginTop:a,marginRight:c,marginBottom:l,marginLeft:u,width:f,height:d}=i,h=u-ud,p=f-c-ud,m=a-fd,g=d-l-fd,y=s/2,x=y*KA,b=x/2,w=y*2,v=x*1.5,_=Math.floor(h/w),I=Math.ceil(p/w),D=Math.floor((m+b)/v),A=Math.ceil((g-b)/v)+1,E=`m0,${pc(-x)}l${pc(y)},${pc(b)}v${pc(x)}l${pc(-y)},${pc(b)}`,T=E;for(let O=D;O<A;++O)for(let C=_;C<I;++C)T+=`M${pc(C*w+(O&1)*y)},${pc(O*v)}${E}`;return ut("svg:g",o).datum(0).call(Ct,this,i,o).call(Et,this,{},Ce+ud,Ce+fd).call(O=>O.append("path").call(Lt,this).call(Qt,this,r).attr("d",T)).node()}};function pc(e){return Math.round(e*1e3)/1e3}var Ott={ariaLabel:"image",fill:null,stroke:null};function Btt(e){return/^\.*\//.test(e)}function Ltt(e){return/^(blob|data|file|http|https):/i.test(e)}function Ctt(e){return typeof e=="string"&&(Btt(e)||Ltt(e))?[void 0,e]:[e,void 0]}var Iy=class extends St{constructor(t,n={}){let{x:r,y:i,r:o,width:s,height:a,rotate:c,src:l,preserveAspectRatio:u,crossOrigin:f,frameAnchor:d,imageRendering:h}=n;o==null&&(o=void 0),o===void 0&&s===void 0&&a===void 0?s=a=16:s===void 0&&a!==void 0?s=a:a===void 0&&s!==void 0&&(a=s);let[p,m]=Ctt(l),[g,y]=se(o),[x,b]=se(s,y!==void 0?y*2:void 0),[w,v]=se(a,y!==void 0?y*2:void 0),[_,I]=se(c,0);super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},r:{value:g,scale:"r",filter:sr,optional:!0},width:{value:x,filter:sr,optional:!0},height:{value:w,filter:sr,optional:!0},rotate:{value:_,optional:!0},src:{value:p,optional:!0}},uy(n),Ott),this.src=m,this.width=b,this.rotate=I,this.height=v,this.r=y,this.preserveAspectRatio=fe(u,"xMidYMid"),this.crossOrigin=qe(f),this.frameAnchor=Fo(d),this.imageRendering=fe(h,"auto")}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,width:u,height:f,r:d,rotate:h,src:p}=r,{r:m,width:g,height:y,rotate:x}=this,[b,w]=gn(this,i);return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(v=>v.selectAll().data(t).enter().append("image").call(Lt,this).attr("x",P9(c,u,d,b,g,m)).attr("y",P9(l,f,d,w,y,m)).attr("width",u?_=>u[_]:g!==void 0?g:d?_=>d[_]*2:m*2).attr("height",f?_=>f[_]:y!==void 0?y:d?_=>d[_]*2:m*2).attr("transform",h?_=>`rotate(${h[_]})`:x?`rotate(${x})`:null).attr("transform-origin",h||x?oc`${c?_=>c[_]:b}px ${l?_=>l[_]:w}px`:null).call(ft,"href",p?_=>p[_]:this.src).call(ft,"preserveAspectRatio",this.preserveAspectRatio).call(ft,"crossorigin",this.crossOrigin).call(ft,"image-rendering",this.imageRendering).call(ft,"clip-path",d?_=>`circle(${d[_]}px)`:m!==void 0?`circle(${m}px)`:null).call(Qt,this,r)).node()}};function P9(e,t,n,r,i,o){return t&&e?s=>e[s]-t[s]/2:t?s=>r-t[s]/2:e&&i!==void 0?s=>e[s]-i/2:i!==void 0?r-i/2:n&&e?s=>e[s]-n[s]:n?s=>r-n[s]:e?s=>e[s]-o:r-o}function U9(e,{x:t,y:n,...r}={}){return r.frameAnchor===void 0&&([t,n]=$e(t,n)),new Iy(e,{...r,x:t,y:n})}function ktt(e,t,n){var r=1e-8,i=t-1,o=n-1,s=0,a,c,l,u,f,d,h,p,m,g,y;if(e<=0)return 0;if(e>=1)return 1;for(t>=1&&n>=1?(l=e<.5?e:1-e,u=Math.sqrt(-2*Math.log(l)),h=(2.30753+u*.27061)/(1+u*(.99229+u*.04481))-u,e<.5&&(h=-h),p=(h*h-3)/6,m=2/(1/(2*t-1)+1/(2*n-1)),g=h*Math.sqrt(p+m)/m-(1/(2*n-1)-1/(2*t-1))*(p+5/6-2/(3*m)),h=t/(t+n*Math.exp(2*g))):(a=Math.log(t/(t+n)),c=Math.log(n/(t+n)),u=Math.exp(t*a)/t,f=Math.exp(n*c)/n,g=u+f,e<u/g?h=Math.pow(t*g*e,1/t):h=1-Math.pow(n*g*(1-e),1/n)),y=-dd(t)-dd(n)+dd(t+n);s<10;s++){if(h===0||h===1)return h;if(d=Ftt(h,t,n)-e,u=Math.exp(i*Math.log(h)+o*Math.log(1-h)+y),f=d/u,h-=u=f/(1-.5*Math.min(1,f*(i/h-o/(1-h)))),h<=0&&(h=.5*(h+u)),h>=1&&(h=.5*(h+u+1)),Math.abs(u)<r*h&&s>0)break}return h}function Ftt(e,t,n){var r=e===0||e===1?0:Math.exp(dd(t+n)-dd(t)-dd(n)+t*Math.log(e)+n*Math.log(1-e));return e<0||e>1?!1:e<(t+1)/(t+n+2)?r*z9(e,t,n)/t:1-r*z9(1-e,n,t)/n}function z9(e,t,n){var r=1e-30,i=1,o=t+n,s=t+1,a=t-1,c=1,l=1-o*e/s,u,f,d,h;for(Math.abs(l)<r&&(l=r),l=1/l,h=l;i<=100&&(u=2*i,f=i*(n-i)*e/((a+u)*(t+u)),l=1+f*l,Math.abs(l)<r&&(l=r),c=1+f/c,Math.abs(c)<r&&(c=r),l=1/l,h*=l*c,f=-(t+i)*(o+i)*e/((t+u)*(s+u)),l=1+f*l,Math.abs(l)<r&&(l=r),c=1+f/c,Math.abs(c)<r&&(c=r),l=1/l,d=l*c,h*=d,!(Math.abs(d-1)<3e-7));i++);return h}function dd(e){var t=0,n=[76.18009172947146,-86.5053203294167,24.01409824083091,-1.231739572450155,.001208650973866179,-5395239384953e-18],r=1.000000000190015,i,o,s;for(s=(o=i=e)+5.5,s-=(i+.5)*Math.log(s);t<6;t++)r+=n[t]/++o;return Math.log(2.506628274631*r/i)-s}function q9(e,t){var n=ktt(2*Math.min(e,1-e),.5*t,.5);return n=Math.sqrt(t*(1-n)/n),e>.5?n:-n}var Rtt={ariaLabel:"linear-regression",fill:"currentColor",fillOpacity:.1,stroke:"currentColor",strokeWidth:1.5,strokeLinecap:"round",strokeLinejoin:"round",strokeMiterlimit:1},wv=class extends St{constructor(t,n={}){let{x:r,y:i,z:o,ci:s=.95,precision:a=4}=n;if(super(t,{x:{value:r,scale:"x"},y:{value:i,scale:"y"},z:{value:jn(n),optional:!0}},n,Rtt),this.z=o,this.ci=+s,this.precision=+a,!(0<=this.ci&&this.ci<1))throw new Error(`invalid ci; not in [0, 1): ${s}`);if(!(this.precision>0))throw new Error(`invalid precision: ${a}`)}render(t,n,r,i,o){let{x:s,y:a,z:c}=r,{ci:l}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(u=>u.selectAll().data(c?Vm(t,c,this.z):[t]).enter().call(f=>f.append("path").attr("fill","none").call(Lt,this).call(Tl,this,{...r,fill:null,fillOpacity:null}).attr("d",d=>this._renderLine(d,s,a)).call(l&&!ta(this.fill)?d=>d.select($tt).attr("stroke","none").call(Lt,this).call(Tl,this,{...r,stroke:null,strokeOpacity:null,strokeWidth:null}).attr("d",h=>this._renderBand(h,s,a)):()=>{}))).node()}};function $tt(){return this.parentNode.insertBefore(this.ownerDocument.createElementNS(oi.svg,"path"),this)}var x3=class extends wv{constructor(t,n){super(t,n)}_renderBand(t,n,r){let{ci:i,precision:o}=this,[s,a]=le(t,u=>r[u]),c=vv(t,r,n),l=Y9(t,r,n,(1-i)/2,c);return hf().y(u=>u).x0(u=>l(u,-1)).x1(u=>l(u,1))(Ue(s,a-o/2,o).concat(a))}_renderLine(t,n,r){let[i,o]=le(t,a=>r[a]),s=vv(t,r,n);return`M${s(i)},${i}L${s(o)},${o}`}},b3=class extends wv{constructor(t,n){super(t,n)}_renderBand(t,n,r){let{ci:i,precision:o}=this,[s,a]=le(t,u=>n[u]),c=vv(t,n,r),l=Y9(t,n,r,(1-i)/2,c);return hf().x(u=>u).y0(u=>l(u,-1)).y1(u=>l(u,1))(Ue(s,a-o/2,o).concat(a))}_renderLine(t,n,r){let[i,o]=le(t,a=>n[a]),s=vv(t,n,r);return`M${i},${s(i)}L${o},${s(o)}`}};function j9(e,{y:t=Ee,x:n=G,stroke:r,fill:i=re(r)?"currentColor":r,...o}={}){return new x3(e,Hf({...o,x:n,y:t,fill:i,stroke:r}))}function V9(e,{x:t=Ee,y:n=G,stroke:r,fill:i=re(r)?"currentColor":r,...o}={}){return new b3(e,Wf({...o,x:t,y:n,fill:i,stroke:r}))}function vv(e,t,n){let r=0,i=0,o=0,s=0;for(let u of e){let f=t[u],d=n[u];r+=f,i+=d,o+=f*d,s+=f*f}let a=e.length,c=(a*o-r*i)/(a*s-r*r),l=(i-c*r)/a;return u=>c*u+l}function Y9(e,t,n,r,i){let o=An(e,u=>t[u])/e.length,s=0,a=0;for(let u of e)s+=(t[u]-o)**2,a+=(n[u]-i(t[u]))**2;let c=Math.sqrt(a/(e.length-2)),l=q9(r,e.length-2);return(u,f)=>{let d=i(u),h=c*Math.sqrt(1/e.length+(u-o)**2/s);return d+f*l*h}}function My({path:e=G,delimiter:t,frameAnchor:n,treeLayout:r=ll,treeSort:i,treeSeparation:o,treeAnchor:s,treeFilter:a,...c}={}){s=Mv(s),i=W9(i),a!=null&&(a=v3(a)),n===void 0&&(n=s.frameAnchor);let l=H9(t),u=nP(c,v3),[f,d]=mn(),[h,p]=mn();return{x:f,y:h,frameAnchor:n,...yn(c,(m,g)=>{let y=l(wt(m,e)),x=d([]),b=p([]),w=-1,v=[],_=[],I=bb().path(A=>y[A]),D=r();D.nodeSize&&D.nodeSize([1,1]),D.separation&&o!==void 0&&D.separation(o??km);for(let A of u)A[Sv]=A[tP]([]);for(let A of g){let E=[],T=I(A.filter(O=>y[O]!=null)).each(O=>O.data=m[O.data]);i!=null&&T.sort(i),D(T);for(let O of T.descendants())if(!(a!=null&&!a(O))){E.push(++w),v[w]=O.data,s.position(O,w,x,b);for(let C of u)C[Sv][w]=C[eP](O)}_.push(E)}return{data:v,facets:_}}),...Object.fromEntries(u)}}function Iv({path:e=G,delimiter:t,curve:n="bump-x",stroke:r="#555",strokeWidth:i=1.5,strokeOpacity:o=.5,treeLayout:s=ll,treeSort:a,treeSeparation:c,treeAnchor:l,treeFilter:u,...f}={}){l=Mv(l),a=W9(a),u!=null&&(u=G9(u)),f={curve:n,stroke:r,strokeWidth:i,strokeOpacity:o,...f};let d=H9(t),h=nP(f,G9),[p,m]=mn(),[g,y]=mn(),[x,b]=mn(),[w,v]=mn();return{x1:p,x2:g,y1:x,y2:w,...yn(f,(_,I)=>{let D=d(wt(_,e)),A=m([]),E=y([]),T=b([]),O=v([]),C=-1,S=[],M=[],N=bb().path(R=>D[R]),F=s();F.nodeSize&&F.nodeSize([1,1]),F.separation&&c!==void 0&&F.separation(c??km);for(let R of h)R[Sv]=R[tP]([]);for(let R of I){let k=[],$=N(R.filter(P=>D[P]!=null)).each(P=>P.data=_[P.data]);a!=null&&$.sort(a),F($);for(let{source:P,target:U}of $.links())if(!(u!=null&&!u(U,P))){k.push(++C),S[C]=U.data,l.position(P,C,A,T),l.position(U,C,E,O);for(let W of h)W[Sv][C]=W[eP](U,P)}M.push(k)}return{data:S,facets:M}}),...Object.fromEntries(h)}}function Mv(e="left"){switch(`${e}`.trim().toLowerCase()){case"left":return Ptt;case"right":return Utt}throw new Error(`invalid tree anchor: ${e}`)}var Ptt={frameAnchor:"left",dx:6,position({x:e,y:t},n,r,i){r[n]=t,i[n]=-e}},Utt={frameAnchor:"right",dx:-6,position({x:e,y:t},n,r,i){r[n]=-t,i[n]=-e}};function W9(e){return e==null||typeof e=="function"?e:`${e}`.trim().toLowerCase().startsWith("node:")?X9(v3(e)):X9(ztt(e))}function X9(e){return(t,n)=>dn(e(t),e(n))}function ztt(e){return t=>t.data?.[e]}function H9(e="/"){if(e=`${e}`,e==="/")return n=>n;if(e.length!==1)throw new Error("delimiter must be exactly one character");let t=e.charCodeAt(0);return n=>n.map(r=>qtt(r,t))}var w3=92,Z9=47;function qtt(e,t){if(t===w3)throw new Error("delimiter cannot be backslash");let n=!1;for(let r=0,i=e.length;r<i;++r){switch(e.charCodeAt(r)){case w3:if(!n){n=!0;continue}break;case t:n?(e=e.slice(0,r-1)+e.slice(r),--r,--i):e=e.slice(0,r)+"/"+e.slice(r+1);break;case Z9:n?(e=e.slice(0,r)+"\\\\"+e.slice(r),r+=2,i+=2):(e=e.slice(0,r)+"\\"+e.slice(r),++r,++i);break}n=!1}return e}function jtt(e){let t=!1;for(let n=0,r=e.length;n<r;++n){switch(e.charCodeAt(n)){case w3:if(!t){t=!0;continue}case Z9:t&&(e=e.slice(0,n-1)+e.slice(n),--n,--r);break}t=!1}return e}function J9(e){return pn(e)&&typeof e.node=="function"}function Vtt(e){return pn(e)&&typeof e.link=="function"}function v3(e){if(J9(e))return e.node;if(e=`${e}`.trim().toLowerCase(),!!e.startsWith("node:")){switch(e){case"node:name":return S3;case"node:path":return _3;case"node:internal":return Q9;case"node:external":return K9;case"node:depth":return I3;case"node:height":return M3}throw new Error(`invalid node value: ${e}`)}}function G9(e){if(J9(e))return e.node;if(Vtt(e))return e.link;if(e=`${e}`.trim().toLowerCase(),!(!e.startsWith("node:")&&!e.startsWith("parent:"))){switch(e){case"parent:name":return _v(S3);case"parent:path":return _v(_3);case"parent:depth":return _v(I3);case"parent:height":return _v(M3);case"node:name":return S3;case"node:path":return _3;case"node:internal":return Q9;case"node:external":return K9;case"node:depth":return I3;case"node:height":return M3}throw new Error(`invalid link value: ${e}`)}}function _3(e){return e.id}function S3(e){return Ytt(e.id)}function I3(e){return e.depth}function M3(e){return e.height}function Q9(e){return!!e.children}function K9(e){return!e.children}function _v(e){return(t,n)=>n==null?void 0:e(n)}function Ytt(e){let t=e.length;for(;--t>0&&!Xtt(e,t););return jtt(e.slice(t+1))}function Xtt(e,t){if(e[t]==="/"){let n=0;for(;t>0&&e[--t]==="\\";)++n;if(!(n&1))return!0}return!1}var tP=2,eP=3,Sv=4;function nP(e,t){let n=[];for(let r in e){let i=e[r],o=t(i);o!==void 0&&n.push([r,...mn(i),o])}return n}function A3(e,{fill:t,stroke:n,strokeWidth:r,strokeOpacity:i,strokeLinejoin:o,strokeLinecap:s,strokeMiterlimit:a,strokeDasharray:c,strokeDashoffset:l,marker:u,markerStart:f=u,markerEnd:d=u,dot:h=re(f)&&re(d),text:p="node:name",textStroke:m="var(--plot-background)",title:g="node:path",dx:y,dy:x,textAnchor:b,treeLayout:w=ll,textLayout:v=w===ll||w===gb?"mirrored":"normal",tip:_,...I}={}){if(y===void 0&&(y=Mv(I.treeAnchor).dx),b!==void 0)throw new Error("textAnchor is not a configurable tree option");v=tn(v,"textLayout",["mirrored","normal"]);function D(A){return Po(e,My({treeLayout:w,text:p,fill:t===void 0?"currentColor":t,stroke:m,dx:y,dy:x,title:g,...A,...I}))}return en(lv(e,Iv({treeLayout:w,markerStart:f,markerEnd:d,stroke:n!==void 0?n:t===void 0?"node:internal":t,strokeWidth:r,strokeOpacity:i,strokeLinejoin:o,strokeLinecap:s,strokeMiterlimit:a,strokeDasharray:c,strokeDashoffset:l,...I})),h?yi(e,My({treeLayout:w,fill:t===void 0?"node:internal":t,title:g,tip:_,...I})):null,p!=null?v==="mirrored"?[D({textAnchor:"start",treeFilter:"node:external"}),D({textAnchor:"end",treeFilter:"node:internal",dx:-y})]:D():null)}function rP(e,t){return A3(e,{...t,treeLayout:gb})}function iP({geometry:e=G,...t}={}){return Ie({...t,x:null,y:null},(n,r,i,o,s,{projection:a})=>{let c=wt(n,e),l=c.length,u=new Float64Array(l),f=new Float64Array(l),d=En(a);for(let h=0;h<l;++h)[u[h],f[h]]=d.centroid(c[h]);return{data:n,facets:r,channels:{x:{value:u,scale:a==null?"x":null,source:null},y:{value:f,scale:a==null?"y":null,source:null}}}})}function oP({geometry:e=G,...t}={}){let n;return{...t,x:{transform:r=>Float64Array.from(n=wt(wt(r,e),qI),([i])=>i)},y:{transform:()=>Float64Array.from(n,([,r])=>r)}}}var yP=yz(mP(),1);var tet=({marginLeft:e})=>[1,e],eet=({width:e,marginRight:t})=>[-1,e-t],net=({width:e,marginLeft:t,marginRight:n})=>[0,(t+e-n)/2],ret=({marginTop:e})=>[1,e],iet=({height:e,marginBottom:t})=>[-1,e-t],oet=({height:e,marginTop:t,marginBottom:n})=>[0,(t+e-n)/2];function gP(e){return typeof e=="string"?{anchor:e}:e}function xP(e={},t={}){arguments.length===1&&([e,t]=wP(e));let{anchor:n="left",padding:r=1,r:i=t.r}=gP(e);switch(`${n}`.toLowerCase()){case"left":n=tet;break;case"right":n=eet;break;case"middle":n=net;break;default:throw new Error(`unknown dodge anchor: ${n}`)}return vP("x","y",n,Bt(r),i,t)}function bP(e={},t={}){arguments.length===1&&([e,t]=wP(e));let{anchor:n="bottom",padding:r=1,r:i=t.r}=gP(e);switch(`${n}`.toLowerCase()){case"top":n=ret;break;case"bottom":n=iet;break;case"middle":n=oet;break;default:throw new Error(`unknown dodge anchor: ${n}`)}return vP("y","x",n,Bt(r),i,t)}function wP(e){let{anchor:t,padding:n,...r}=e,{r:i}=r;return[{anchor:t,padding:n,r:i},r]}function vP(e,t,n,r,i,o){if(i!=null&&typeof i!="number"){let{channels:s,sort:a,reverse:c}=o;s=Rm(s),s?.r===void 0&&(o={...o,channels:{...s,r:{value:i,scale:"r"}}}),a===void 0&&c===void 0&&(o.sort={channel:"-r"})}return Ie(o,function(s,a,c,l,u,f){let{[t]:d,r:h}=c;if(!c[t])throw new Error(`missing channel: ${t}`);({[t]:d}=rc(c,l,f));let p=h?void 0:i!==void 0?Bt(i):this.r!==void 0?this.r:3;h&&(h=wt(h.value,l[h.scale]||G,Float64Array));let[m,g]=n(u),y=m?aet:set,x=new Float64Array(d.length),b=h?w=>h[w]:()=>p;for(let w of a){let v=(0,yP.default)();w=w.filter(h?I=>xf(d[I])&&sr(h[I]):I=>xf(d[I]));let _=new Float64Array(2*w.length+2);for(let I of w){let D=b(I),A=m?D+r:0,E=d[I]-D,T=d[I]+D,O=2;v.queryInterval(E-r,T+r,([,,S])=>{let M=x[S]-A,N=d[I]-d[S],F=r+(h?h[I]+h[S]:2*p),R=Math.sqrt(F*F-N*N);_[O++]=M-R,_[O++]=M+R});let C=_.slice(0,O);m&&(C=C.filter(S=>S>=0));t:for(let S of C.sort(y)){for(let M=0;M<O;M+=2)if(_[M]+1e-6<S&&S<_[M+1]-1e-6)continue t;x[I]=S+A;break}v.insert([E,T,I])}}m||(m=1);for(let w of a)for(let v of w)x[v]=x[v]*m+g;return{data:s,facets:a,channels:{[e]:{value:x,source:null},[t]:{value:d,source:c[t]},...h&&{r:{value:h,source:c.r}}}}})}function set(e,t){return Math.abs(e)-Math.abs(t)}function aet(e,t){return e-t}function SP(e,t){return arguments.length===1&&({basis:e,...t}=e),sd(Ev(e),t)}function IP(e,t){return arguments.length===1&&({basis:e,...t}=e),ad(Ev(e),t)}function Ev(e){if(e===void 0)return _P;if(typeof e=="function")return Nv(Mf(e));if(/^p\d{2}$/i.test(e))return yd(Sf(e));switch(`${e}`.toLowerCase()){case"deviation":return fet;case"first":return _P;case"last":return uet;case"max":return det;case"mean":return het;case"median":return pet;case"min":return met;case"sum":return yet;case"extent":return cet}throw new Error(`invalid basis: ${e}`)}function Nv(e){return{mapIndex(t,n,r){let i=+e(t,n);for(let o of t)r[o]=n[o]===null?NaN:n[o]/i}}}function yd(e){return Nv((t,n)=>e(t,r=>n[r]))}var cet={mapIndex(e,t,n){let[r,i]=le(e,s=>t[s]),o=i-r;for(let s of e)n[s]=t[s]===null?NaN:(t[s]-r)/o}},_P=Nv((e,t)=>{for(let n=0;n<e.length;++n){let r=t[e[n]];if(ze(r))return r}}),uet=Nv((e,t)=>{for(let n=e.length-1;n>=0;--n){let r=t[e[n]];if(ze(r))return r}}),fet={mapIndex(e,t,n){let r=Ns(e,o=>t[o]),i=ii(e,o=>t[o]);for(let o of e)n[o]=t[o]===null?NaN:i?(t[o]-r)/i:0}},det=yd(Wt),het=yd(Ns),pet=yd(Pi),met=yd(ue),yet=yd(An);function MP(e,t){return get("x",e,t)}function get(e,t,n={}){let r,i=1;if(typeof t=="number")i=t,r=(l,u)=>+l+u;else{if(typeof t=="string"){let l=t.startsWith("-")?-1:1;[t,i]=sw(t.replace(/^[+-]/,"")),i*=l}t=Tf(t),r=(l,u)=>t.offset(l,u)}let o=`${e}1`,s=`${e}2`,a=vr({[o]:l=>l.map(u=>r(u,i)),[s]:l=>l},n),c=a[s].transform;return a[s].transform=()=>{let l=c(),[u,f]=le(l);return l.domain=i<0?[u,r(f,i)]:[r(u,i),f],l},a}function AP(e,t={}){if(typeof e=="string")switch(e.toLowerCase()){case"first":return B3(t);case"last":return L3(t)}if(typeof e=="function")return mc(null,e,t);let n,r;for(n in e){if(r!==void 0)throw new Error("ambiguous selector; multiple inputs");r=xet(e[n])}if(r===void 0)throw new Error(`invalid selector: ${e}`);return mc(n,r,t)}function xet(e){if(typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"min":return C3;case"max":return k3}throw new Error(`unknown selector: ${e}`)}function B3(e){return mc(null,bet,e)}function L3(e){return mc(null,wet,e)}function TP(e){return mc("x",C3,e)}function EP(e){return mc("y",C3,e)}function NP(e){return mc("x",k3,e)}function DP(e){return mc("y",k3,e)}function*bet(e){yield e[0]}function*wet(e){yield e[e.length-1]}function*C3(e,t){yield ex(e,n=>t[n])}function*k3(e,t){yield Xc(e,n=>t[n])}function mc(e,t,n){if(e!=null){if(n[e]==null)throw new Error(`missing channel: ${e}`);e=n[e]}let r=jn(n);return yn(n,(i,o)=>{let s=wt(i,r),a=wt(i,e),c=[];for(let l of o){let u=[];for(let f of s?cn(l,d=>s[d]).values():[l])for(let d of t(f,a))u.push(d);c.push(u)}return{data:i,facets:c}})}var vet=new Map([["style","style"],["width","width"],["height","height"],["margin","margin"],["marginLeft","marginLeft"],["marginRight","marginRight"],["marginTop","marginTop"],["marginBottom","marginBottom"],["align","align"],["aspectRatio","aspectRatio"],["axis","axis"],["inset","inset"],["grid","grid"],["label","label"],["padding","padding"],["round","round"],["xScale","x.type"],["xDomain","x.domain"],["xRange","x.range"],["xNice","x.nice"],["xInset","x.inset"],["xInsetLeft","x.insetLeft"],["xInsetRight","x.insetRight"],["xClamp","x.clamp"],["xRound","x.round"],["xAlign","x.align"],["xPadding","x.padding"],["xPaddingInner","x.paddingInner"],["xPaddingOuter","x.paddingOuter"],["xAxis","x.axis"],["xTicks","x.ticks"],["xTickSize","x.tickSize"],["xTickSpacing","x.tickSpacing"],["xTickPadding","x.tickPadding"],["xTickFormat","x.tickFormat"],["xTickRotate","x.tickRotate"],["xGrid","x.grid"],["xLine","x.line"],["xLabel","x.label"],["xLabelAnchor","x.labelAnchor"],["xLabelOffset","x.labelOffset"],["xFontVariant","x.fontVariant"],["xAriaLabel","x.ariaLabel"],["xAriaDescription","x.ariaDescription"],["xReverse","x.reverse"],["xZero","x.zero"],["xBase","x.base"],["xExponent","x.exponent"],["xConstant","x.constant"],["yScale","y.type"],["yDomain","y.domain"],["yRange","y.range"],["yNice","y.nice"],["yInset","y.inset"],["yInsetTop","y.insetTop"],["yInsetBottom","y.insetBottom"],["yClamp","y.clamp"],["yRound","y.round"],["yAlign","y.align"],["yPadding","y.padding"],["yPaddingInner","y.paddingInner"],["yPaddingOuter","y.paddingOuter"],["yAxis","y.axis"],["yTicks","y.ticks"],["yTickSize","y.tickSize"],["yTickSpacing","y.tickSpacing"],["yTickPadding","y.tickPadding"],["yTickFormat","y.tickFormat"],["yTickRotate","y.tickRotate"],["yGrid","y.grid"],["yLine","y.line"],["yLabel","y.label"],["yLabelAnchor","y.labelAnchor"],["yLabelOffset","y.labelOffset"],["yFontVariant","y.fontVariant"],["yAriaLabel","y.ariaLabel"],["yAriaDescription","y.ariaDescription"],["yReverse","y.reverse"],["yZero","y.zero"],["yBase","y.base"],["yExponent","y.exponent"],["yConstant","y.constant"],["facetMargin","facet.margin"],["facetMarginTop","facet.marginTop"],["facetMarginBottom","facet.marginBottom"],["facetMarginLeft","facet.marginLeft"],["facetMarginRight","facet.marginRight"],["facetGrid","facet.grid"],["facetLabel","facet.label"],["fxDomain","fx.domain"],["fxRange","fx.range"],["fxNice","fx.nice"],["fxInset","fx.inset"],["fxInsetLeft","fx.insetLeft"],["fxInsetRight","fx.insetRight"],["fxRound","fx.round"],["fxAlign","fx.align"],["fxPadding","fx.padding"],["fxPaddingInner","fx.paddingInner"],["fxPaddingOuter","fx.paddingOuter"],["fxAxis","fx.axis"],["fxTicks","fx.ticks"],["fxTickSize","fx.tickSize"],["fxTickSpacing","fx.tickSpacing"],["fxTickPadding","fx.tickPadding"],["fxTickFormat","fx.tickFormat"],["fxTickRotate","fx.tickRotate"],["fxGrid","fx.grid"],["fxLine","fx.line"],["fxLabel","fx.label"],["fxLabelAnchor","fx.labelAnchor"],["fxLabelOffset","fx.labelOffset"],["fxFontVariant","fx.fontVariant"],["fxAriaLabel","fx.ariaLabel"],["fxAriaDescription","fx.ariaDescription"],["fxReverse","fx.reverse"],["fyDomain","fy.domain"],["fyRange","fy.range"],["fyNice","fy.mice"],["fyInset","fy,inset"],["fyInsetTop","fy.insetTop"],["fyInsetBottom","fy.insetBottom"],["fyRound","fy.round"],["fyAlign","fy.align"],["fyPadding","fy.padding"],["fyPaddingInner","fy.paddingInner"],["fyPaddingOuter","fy.paddingOuter"],["fyAxis","fy.axis"],["fyTicks","fy.ticks"],["fyTickSize","fy.tickSize"],["fyTickSpacing","fy.tickSpacing"],["fyTickPadding","fy.tickPadding"],["fyTickFormat","fy.tickFormat"],["fyTickRotate","fy.tickRotate"],["fyGrid","fy.grid"],["fyLine","fy.line"],["fyLabel","fy.label"],["fyLabelAnchor","fy.labelAnchor"],["fyLabelOffset","fy.labelOffset"],["fyFontVariant","fy.fontVariant"],["fyAriaLabel","fy.ariaLabel"],["fyAriaDescription","fy.ariaDescription"],["fyReverse","fy.reverse"],["colorScale","color.type"],["colorDomain","color.domain"],["colorRange","color.range"],["colorClamp","color.clamp"],["colorN","color.n"],["colorNice","color.nice"],["colorScheme","color.scheme"],["colorInterpolate","color.interpolate"],["colorPivot","color.pivot"],["colorSymmetric","color.symmetric"],["colorLabel","color.label"],["colorReverse","color.reverse"],["colorZero","color.zero"],["colorTickFormat","color.tickFormat"],["colorBase","color.base"],["colorExponent","color.exponent"],["colorConstant","color.constant"],["opacityScale","opacity.type"],["opacityDomain","opacity.domain"],["opacityRange","opacity.range"],["opacityClamp","opacity.clamp"],["opacityNice","opacity.nice"],["opacityLabel","opacity.label"],["opacityReverse","opacity.reverse"],["opacityZero","opacity.zero"],["opacityTickFormat","opacity.tickFormat"],["opacityBase","opacity.base"],["opacityExponent","opacity.exponent"],["opacityConstant","opacity.constant"],["rScale","r.type"],["rDomain","r.domain"],["rRange","r.range"],["rClamp","r.clamp"],["rNice","r.nice"],["rZero","r.zero"],["rBase","r.base"],["rExponent","r.exponent"],["rConstant","r.constant"],["lengthScale","length.type"],["lengthDomain","length.domain"],["lengthRange","length.range"],["lengthClamp","length.clamp"],["lengthNice","length.nice"],["lengthZero","length.zero"],["lengthBase","length.base"],["lengthExponent","length.exponent"],["lengthConstant","length.constant"],["projectionType","projection.type"],["projectionParallels","projection.parallels"],["projectionPrecision","projection.precision"],["projectionRotate","projection.rotate"],["projectionDomain","projection.domain"],["projectionInset","projection.inset"],["projectionInsetLeft","projection.insetLeft"],["projectionInsetRight","projection.insetRight"],["projectionInsetTop","projection.insetTop"],["projectionInsetBottom","projection.insetBottom"],["projectionClip","projection.clip"]]);function _et(e,t,n){for(let r=0;r<t.length;++r){let i=t[r];r===t.length-1?e[i]=n:e=e[i]||(e[i]={})}}function OP(e,t,n){for(let r in e){let i=vet.get(r);if(i==null)throw new Error(`Unrecognized plot attribute: ${r}`);let o=e[r];typeof o=="symbol"?n.push(r):o!==void 0&&_et(t,i.split("."),o)}}var Iet=new Set(["frame","hexgrid","sphere","graticule"]);async function LP(e){let t={marks:[]},n=[],{attributes:r,marks:i}=e;OP(r,t,n);let o=[];for(let a of i)for(let{type:c,data:l,options:u}of a.plotSpecs())Iet.has(c)?t.marks.push(Dv[c](u)):t.marks.push(Dv[c](l,u)),o.push(a.index);Aet(t,e);let s=ny(t);Tet(s,o),Met(e,s,r,n);for(let a of e.interactors)await a.init(s);return s}function Met(e,t,n,r){r.forEach(i=>{let o=n[i];if(o===lo){if(!i.endsWith("Domain"))throw new Error(`Unsupported fixed attribute: ${i}`);let s=i.slice(0,-6),a=t.scale(s);a?.domain&&e.setAttribute(i,n[`${s}Reverse`]?a.domain.slice().reverse():a.domain)}else throw new Error(`Unrecognized symbol: ${o}`)})}function Aet(e,t){let{marks:n}=t;Ov("x",e,n),Ov("y",e,n),Ov("fx",e,n),Ov("fy",e,n)}function Ov(e,t,n){let r=t[e]||{};if(r.axis===null||r.label!==void 0)return;let i=n.map(l=>l.channelField(e)?.field);if(i.every(l=>l==null))return;let o,s,a;for(let l=0;l<i.length;++l){let{column:u,label:f}=i[l]||{};u===void 0&&f===void 0||(o===void 0&&s===void 0?(o=u,s=f,a=Eet(n[l].data,e)||"number"):s!==f?s=void 0:o!==u&&(o=void 0))}let c=s||o;if(c!==void 0){if((a==="number"||a==="date")&&(e==="x"||e==="y")){r.percent&&(c=`${c} (%)`);let l=(e==="x"?1:-1)*(r.reverse?-1:1);e==="x"||r.labelAnchor==="center"?c=e==="x"==l<0?`\u2190 ${c}`:`${c} \u2192`:c=`${l<0?"\u2191 ":"\u2193 "}${c}`}t[e]={...r,label:c}}}function Tet(e,t){let n=e.querySelectorAll('g[aria-label="facet"]');if(n.length)for(let r of n)BP(r,t);else BP(e,t)}function BP(e,t){let n=-1;for(let r of e.children){let i=r.getAttribute("aria-label")||"";r.nodeName==="style"||i.includes("-axis")||i.includes("-grid")||r.setAttribute("data-index",t[++n])}}function Eet(e,t){for(let n of e){let r=n[t]??n[t+"1"]??n[t+"2"];if(r!=null)return r instanceof Date?"date":typeof r}}var Net={width:640,marginLeft:40,marginRight:20,marginTop:20,marginBottom:30},Ey=class{constructor(t){this.attributes={...Net},this.listeners=null,this.interactors=[],this.legends=[],this.marks=[],this.markset=null,this.element=t||document.createElement("div"),this.element.setAttribute("class","plot"),this.element.style.display="flex",this.element.value=this,this.params=new Map,this.synch=RS()}margins(){return{left:this.getAttribute("marginLeft"),top:this.getAttribute("marginTop"),bottom:this.getAttribute("marginBottom"),right:this.getAttribute("marginRight")}}innerWidth(){let{left:t,right:n}=this.margins();return this.getAttribute("width")-t-n}innerHeight(t=400){let{top:n,bottom:r}=this.margins(),i=this.getAttribute("height");return i==null&&t!=null&&(i=t,this.setAttribute("height",i,{silent:!0})),i-n-r}pending(t){this.synch.pending(t)}update(t){return this.synch.ready(t)&&!this.pendingRender&&(this.pendingRender=!0,requestAnimationFrame(()=>this.render())),this.synch.promise}async render(){this.pendingRender=!1;let t=await LP(this),n=this.legends.flatMap(({legend:r,include:i})=>{let o=r.init(t);return i?o:[]});this.element.replaceChildren(t,...n),this.synch.resolve()}getAttribute(t){return this.attributes[t]}setAttribute(t,n,r){return Hh(this.attributes[t],n)?(n===void 0?delete this.attributes[t]:this.attributes[t]=n,r?.silent||this.listeners?.get(t)?.forEach(i=>i(t,n)),!0):!1}addAttributeListener(t,n){let r=this.listeners||(this.listeners=new Map);return r.has(t)||r.set(t,new Set),r.get(t).add(n),this}removeAttributeListener(t,n){return this.listeners?.get(t)?.delete(n)}addParams(t,n){let{params:r}=this;for(let i of n)r.has(i)?r.get(i).push(t):(r.set(i,[t]),i.addEventListener("value",()=>Promise.allSettled(r.get(i).map(o=>o.requestQuery()))))}addMark(t){return t.setPlot(this,this.marks.length),this.marks.push(t),this.markset=null,this}get markSet(){return this.markset||(this.markset=new Set(this.marks))}addInteractor(t){return this.interactors.push(t),this}addLegend(t,n=!0){t.setPlot(this),this.legends.push({legend:t,include:n})}};function Bv(e){return typeof e!="string"?!1:(e=e.toLowerCase().trim(),e==="none"||e==="currentcolor"||e.startsWith("url(")&&e.endsWith(")")||e.startsWith("var(")&&e.endsWith(")")||Rr(e)!==null)}var Det=new Set(["order","sort","label","anchor","curve","tension","marker","markerStart","markerMid","markerEnd","textAnchor","lineAnchor","lineHeight","textOverflow","monospace","fontFamily","fontSize","fontStyle","fontVariant","fontWeight","frameAnchor","strokeLinejoin","strokeLinecap","strokeMiterlimit","strokeDasharray","strokeDashoffset","mixBlendMode","shapeRendering","imageRendering","preserveAspectRatio","interpolate","crossOrigin","paintOrder","pointerEvents","target"]);function CP(e){return Det.has(e)}var Oet=new Set(["asterisk","circle","cross","diamond","diamond2","hexagon","plus","square","square2","star","times","triangle","triangle2","wye"]);function kP(e){return Oet.has(`${e}`.toLowerCase())}function Lv(e){return Su(e)?Bet(e):e}function Bet(e){let{batches:t,numRows:n}=e;if(!n)return[];let r=Array.from({length:n},()=>({}));for(let i=0,o=0;o<t.length;++o){let s=t[o],{schema:a,numRows:c,numCols:l}=s;for(let u=0;u<l;++u){let f=s.getChildAt(u),{name:d,type:h}=a.fields[u],p=Gh(h);for(let m=i,g=0;g<c;++g,++m)r[m][d]=p(f.get(g))}i+=c}return r}var FP=e=>e==="stroke"||e==="fill",Let=e=>e==="symbol",Cet=(e,t)=>e!=="sort"&&e!=="tip"&&t!=null&&!Array.isArray(t),F3=(e,t)=>({channel:e,field:t,as:t instanceof xr?t.column:e}),R3=(e,t)=>({channel:e,value:t}),Cv=e=>Array.isArray(e),Bn=class extends ur{constructor(t,n,r,i={}){super(n?.options?.filterBy),this.type=t,this.reqs=i,this.source=n,Cv(this.source)&&(this.data=this.source);let o=this.channels=[],s=this.detail=new Set,a=this.params=new Set,c=(l,u)=>{let f=typeof u;if(l==="channels")for(let d in u)s.add(d),c(d,u[d]);else if(f==="function"&&u[Zh]){let d=u(this,l);for(let h in d)c(h,d[h])}else if(f==="string")CP(l)||FP(l)&&Bv(u)||Let(l)&&kP(u)?o.push(R3(l,u)):o.push(F3(l,Ia(u)));else if(ws(u))if(Array.isArray(u.columns))o.push(F3(l,u)),a.add(u);else{let d=R3(l,u.value);o.push(d),u.addEventListener("value",h=>(d.value=h,this.update()))}else f==="object"&&Cet(l,u)?o.push(F3(l,u)):u!==void 0&&o.push(R3(l,u))};for(let l in r)c(l,r[l])}setPlot(t,n){this.plot=t,this.index=n,t.addParams(this,this.params),this.source?.table&&this.queryPending()}hasOwnData(){return this.source==null||Cv(this.source)}hasFieldInfo(){return!!this._fieldInfo}channel(t){return this.channels.find(n=>n.channel===t)}channelField(t,{exact:n}={}){let r=n?this.channel(t):this.channels.find(i=>i.channel.startsWith(t));return r?.field?r:null}fields(){if(this.hasOwnData())return null;let{source:{table:t},channels:n,reqs:r}=this,i=new Map;for(let{channel:o,field:s}of n){if(!s)continue;let a=s.stats?.stats||[],c=s.stats?.column??s,l=i.get(c)??i.set(c,new Set).get(c);a.forEach(u=>l.add(u)),r[o]?.forEach(u=>l.add(u))}return Array.from(i,([o,s])=>({table:t,column:o,stats:s}))}fieldInfo(t){let n=Object.fromEntries(t.map(r=>[r.column,r]));for(let r of this.channels){let{field:i}=r;i&&Object.assign(r,n[i.stats?.column??i])}return this._fieldInfo=!0,this}query(t=[]){if(this.hasOwnData())return null;let{channels:n,source:{table:r}}=this;return $3(n,r).where(t)}queryPending(){return this.plot.pending(this),this}queryResult(t){return this.data=Lv(t),this}update(){return this.plot.update(this)}plotSpecs(){let{type:t,data:n,detail:r,channels:i}=this,o={},s={};for(let a of i){let c=r.has(a.channel)?s:o;c[a.channel]=gi(a)}return r.size&&(o.channels=s),[{type:t,data:n,options:o}]}};function gi(e){return Object.hasOwn(e,"value")?e.value:FP(e.channel)?{value:e.as,scale:"color"}:e.as}function $3(e,t,n=[]){let r=ht.from({source:t}),i=new Set,o=!1;for(let s of e){let{channel:a,field:c,as:l}=s;if(!n.includes(a)){if(a==="orderby")r.orderby(s.value);else if(c){if(c.aggregate)o=!0;else{if(i.has(l))continue;i.add(l)}r.select({[l]:c})}}}return o&&r.groupby(Array.from(i)),r}function ql(e,t){let{plot:n}=e,r=n.getAttribute(`${t}Scale`);if(!r){let{type:o}=e.channelField(t);r=o==="date"?"time":"linear"}let i={type:r};switch(r){case"log":i.base=n.getAttribute(`${t}Base`)??10;break;case"pow":i.exponent=n.getAttribute(`${t}Exponent`)??1;break;case"symlog":i.constant=n.getAttribute(`${t}Constant`)??1;break}return Yh(i)}function Gr(e,t,n,r,i=1,o){let{field:s}=e.channelField(t);o=o??s;let{type:a,apply:c,sqlApply:l}=ql(e,t),u=!!e.plot.getAttribute(`${t}Reverse`),[f,d]=r.map(x=>c(x)),h=l(o),p=a==="time"||a==="utc"?h:o,m=d===f?0:(n-i)/(d-f),g=m!==1?` * ${m}::DOUBLE`:"";return[u?q`(${d} - ${h}::DOUBLE)${g}`:q`(${h}::DOUBLE - ${f})${g}`,p]}var P3={x:["min","max"]},U3={y:["min","max"]},kv={...P3,...U3};function RP(e,t,n,r,i){let{plot:o}=e,s=o.getAttribute(r),a=o.getAttribute(i);if(Array.isArray(s)&&!s[Sn])return s;{let{column:c,min:l,max:u}=e.channelField(n),f=z3(t,c)||(a?Ps().domain([l,u]).nice().domain():[l,u]);return s!==lo&&(f[Sn]=!0),o.setAttribute(r,f,{silent:!0}),f}}function Vo(e,t){return RP(e,t,"x","xDomain","xNice")}function Yo(e,t){return RP(e,t,"y","yDomain","yNice")}function z3(e,t){if(!e)return;let n,r,i=(o,s)=>{if(o==="BETWEEN"&&`${s.field}`===t){let{range:a}=s;a&&(n==null||a[0]<n)&&(n=a[0]),a&&(r==null||a[1]>r)&&(r=a[1])}};return Array.isArray(e)?e.forEach(o=>o.visit?.(i)):e.visit&&e.visit(i),n!=null&&r!=null&&n!==r?[n,r]:void 0}var Ny=class extends Bn{constructor(t,n,r){let i=t.endsWith("X")?"y":t.endsWith("Y")?"x":null,o=i?{[i]:["min","max"]}:void 0;super(t,n,r,o),this.dim=i}query(t=[]){let{plot:n,dim:r,source:i}=this,{optimize:o=!0}=i.options||{},s=super.query(t);if(!r)return s;let a=r==="x"?"y":"x",c=this.channelField(a,{exact:!0})?.as,{field:l,as:u,type:f,min:d,max:h}=this.channelField(r);if(o&&(f==="date"||f==="number")&&c){let m=r==="x"?n.innerWidth():n.innerHeight(),[g,y]=z3(t,l)||[d,h],[x]=Gr(this,r,m,[g,y],1,u),b=s.select().map(w=>w.as).filter(w=>w!==u&&w!==c);return ket(s,x,u,c,b)}else return s.orderby(l)}};function ket(e,t,n,r,i=[]){let o=q`FLOOR(${t})::INTEGER`,s=a=>ht.from(e).select(a).groupby(o,i);return ht.union(s([{[n]:ei(n),[r]:wu(r,n)},...i]),s([{[n]:ti(n),[r]:vu(r,n)},...i]),s([{[n]:wu(n,r),[r]:ei(r)},...i]),s([{[n]:vu(n,r),[r]:ti(r)},...i])).orderby(i,n)}function $P(e,t="density"){return Su(e)?kS(e.getChild(t).type):typeof e[0]?.[t]=="number"?Float64Array:Array}function PP(e,t,n="density"){let r=new($P(t))(e);if(Su(t)){let i=t.numRows;if(i===0)return r;let o=Iu(t.getChild("index")),s=Iu(t.getChild(n));for(let a=0;a<i;++a)r[o[a]]=s[a]}else for(let i of t)r[i.index]=i[n];return r}function UP(e,t,n,r,i=[],o){let s=e*t,a=r.map(y=>$P(n,y)),c=r.length,l=y=>{let x={};return i.forEach((b,w)=>x[b]=y[w]),r.forEach((b,w)=>x[b]=new a[w](s)),x},u={},f=i.length?null:u[[]]=l([]),d=i.length?y=>u[y]??(u[y]=l(y)):()=>f,h=n.numRows;if(h===0)return Object.values(u);let p=Iu(n.getChild("index")),m=r.map(y=>Iu(n.getChild(y))),g=i.map(y=>n.getChild(y));if(o){let y=p.map(b=>b%e),x=p.map(b=>Math.floor(b/e));if(i.length)for(let b=0;b<h;++b){let w=g.map(_=>_.get(b)),v=d(w);v.index||(v.index=[]),v.index.push(b)}else f.index=p.map((b,w)=>w);Object.values(u).forEach(b=>{for(let w=0;w<c;++w)o(b.index,e,t,y,x,m[w],b[r[w]]);delete b.index})}else for(let y=0;y<h;++y){let x=g.map(w=>w.get(y)),b=d(x);for(let w=0;w<c;++w)b[r[w]][p[y]]=m[w][y]}return Object.values(u)}function Dy(e,t){let n=0,r=0;return e.forEach(i=>{let o=i[t],s=o.length;for(let a=0;a<s;++a){let c=o[a];c<n&&(n=c),c>r&&(r=c)}}),n===0&&r===0?[0,1]:[n,r]}function zP(e,t){let n=new Jn;return e.forEach(r=>{let i=r[t],o=i.length;for(let s=0;s<o;++s)n.add(i[s])}),Array.from(n).sort(zt)}function Ln(e,t,n,r){br(n)?(r=r||(()=>e.requestUpdate()),n.addEventListener("value",i=>(e[t]=i,r())),e[t]=n.value):e[t]=n}function Oy(e,t=!1){let n=new Float64Array(5),r=new Float64Array(4);Fet(n,r,e);let i=Float64Array.of(0,r[1]-n[1]*r[0],r[2]-n[2]*r[0],r[3]-n[3]*r[0],-n[4]*r[0]),o=1+n[1]+n[2]+n[3]+n[4],s=(r[0]+r[1]+r[2]+r[3])/o,a=(i[1]+i[2]+i[3]+i[4])/o;return{sigma:e,negative:t,a:n,b_causal:r,b_anticausal:i,sum_causal:s,sum_anticausal:a}}function Fet(e,t,n){let i=Float64Array.of(.84,1.8675,.84,-1.8675,-.34015,-.1299,-.34015,.1299),o=Math.exp(-1.783/n),s=Math.exp(-1.723/n),a=.6318/n,c=1.997/n,l=Float64Array.of(-o*Math.cos(a),o*Math.sin(a),-o*Math.cos(-a),o*Math.sin(-a),-s*Math.cos(c),s*Math.sin(c),-s*Math.cos(-c),s*Math.sin(-c)),u=n*2.5066282746310007,f=Float64Array.of(i[0],i[1],0,0,0,0,0,0),d=Float64Array.of(1,0,l[0],l[1],0,0,0,0,0,0),h,p;for(p=2;p<8;p+=2){for(f[p]=l[p]*f[p-2]-l[p+1]*f[p-1],f[p+1]=l[p]*f[p-1]+l[p+1]*f[p-2],h=p-2;h>0;h-=2)f[h]+=l[p]*f[h-2]-l[p+1]*f[h-1],f[h+1]+=l[p]*f[h-1]+l[p+1]*f[h-2];for(h=0;h<=p;h+=2)f[h]+=i[p]*d[h]-i[p+1]*d[h+1],f[h+1]+=i[p]*d[h+1]+i[p+1]*d[h];for(d[p+2]=l[p]*d[p]-l[p+1]*d[p+1],d[p+3]=l[p]*d[p+1]+l[p+1]*d[p],h=p;h>0;h-=2)d[h]+=l[p]*d[h-2]-l[p+1]*d[h-1],d[h+1]+=l[p]*d[h-1]+l[p+1]*d[h-2]}for(p=0;p<4;++p)h=p<<1,t[p]=f[h]/u,e[p+1]=d[h+2]}function qP(e,t,n,[r,i]){let o=new Float64Array(Math.max(r,i)),s=new Float64Array(Math.max(r,i)),a=new Float64Array(5),c=new Float64Array(n.length);for(let l=0,u=0;l<i;++l,u+=r){let f=c.subarray(u);Fv(e,n.subarray(u),r,1,o,s,a,f)}for(let l=0;l<r;++l){let u=c.subarray(l);Fv(t,u,i,r,o,s,a,u)}return c}function Fv(e,t,n,r=1,i=new Float64Array(n),o=new Float64Array(n),s=new Float64Array(5),a=i,c=Ret){let l=r*2,u=r*3,f=r*4,d=r*n,h,p;for(c(i,t,n,r,e.b_causal,3,e.a,4,e.sum_causal,s,e.sigma),p=4,h=f;p<n;++p,h+=r)i[p]=e.b_causal[0]*t[h]+e.b_causal[1]*t[h-r]+e.b_causal[2]*t[h-l]+e.b_causal[3]*t[h-u]-e.a[1]*i[p-1]-e.a[2]*i[p-2]-e.a[3]*i[p-3]-e.a[4]*i[p-4];for(c(o,t,n,-r,e.b_anticausal,4,e.a,4,e.sum_anticausal,s,e.sigma),p=4,h=d-r*5;p<n;++p,h-=r)o[p]=e.b_anticausal[1]*t[h+r]+e.b_anticausal[2]*t[h+l]+e.b_anticausal[3]*t[h+u]+e.b_anticausal[4]*t[h+f]-e.a[1]*o[p-1]-e.a[2]*o[p-2]-e.a[3]*o[p-3]-e.a[4]*o[p-4];if(e.negative)for(p=0,h=0;p<n;++p,h+=r)a[h]=i[p]+o[n-p-1];else for(p=0,h=0;p<n;++p,h+=r)a[h]=Math.max(0,i[p]+o[n-p-1]);return a}function Ret(e,t,n,r,i,o,s,a,c,l,u,f=.5){let d=Math.abs(r)*n,h=r<0?d+r:0,p,m,g;for(m=0;m<=a;++m)for(l[m]=m<=o?i[m]:0,g=1;g<=a&&g<=m;++g)l[m]-=s[g]*l[m-g];for(g=0;g<a;++g)for(e[g]=0,m=1;m<=g;++m)p=h+r*m,p>=0&&p<d&&(e[g]+=l[g-m]*t[p]);let y=t[h],x=Math.ceil(u*10);for(m=0;m<x;++m){for(g=0;g<a;++g)e[g]+=l[g]*y;if(c-=Math.abs(l[0]),c<=f)break;for(l[a]=m+a<=o?i[m+a]:0,g=1;g<=a;++g)l[a]-=s[g]*l[a-g];for(g=0;g<a;++g)l[g]=l[g+1]}}function jP({random:e=Mo(42)}={}){return(t,n,r,i,o,s,a)=>{let{points:c,triangles:l,hull:u}=Pn.from(t,h=>i[h],h=>o[h]),f=new Uint8Array(n*r),d=jet(s,e);for(let h=0;h<l.length;h+=3){let p=l[h],m=l[h+1],g=l[h+2],y=c[2*p],x=c[2*m],b=c[2*g],w=c[2*p+1],v=c[2*m+1],_=c[2*g+1],I=Math.min(y,x,b),D=Math.max(y,x,b),A=Math.min(w,v,_),E=Math.max(w,v,_),T=(v-_)*(y-b)+(w-_)*(b-x);if(!T)continue;let O=s[t[p]],C=s[t[m]],S=s[t[g]];for(let M=Math.floor(I);M<D;++M)for(let N=Math.floor(A);N<E;++N){if(M<0||M>=n||N<0||N>=r)continue;let F=M+.5,R=N+.5,k=((v-_)*(F-b)+(R-_)*(b-x))/T;if(k<0)continue;let $=((_-w)*(F-b)+(R-_)*(y-b))/T;if($<0)continue;let P=1-k-$;if(P<0)continue;let U=M+n*N;a[U]=d(O,k,C,$,S,P,M,N),f[U]=1}}return $et(a,f,i,o,s,n,r,u,t,d),a}}function $et(e,t,n,r,i,o,s,a,c,l){n=Float64Array.from(a,h=>n[c[h]]),r=Float64Array.from(a,h=>r[c[h]]),i=Array.from(a,h=>i[c[h]]);let u=n.length,f=Array.from({length:u},(h,p)=>Uet(p,n,r)),d=0;for(let h=0;h<s;++h){let p=h+.5;for(let m=0;m<o;++m){let g=m+o*h;if(!t[g]){let y=m+.5;for(let x=0;x<u;++x){let b=(u+d+(x%2?(x+1)/2:-x/2))%u;if(f[b](y,p)){let w=Pet(n.at(b-1),r.at(b-1),n[b],r[b],y,p);e[g]=l(i.at(b-1),w,i[b],1-w,i[b],0,m,h),d=b;break}}}}}}function Pet(e,t,n,r,i,o){let s=n-e,a=r-t,c=s*(n-i)+a*(r-o),l=s*(i-e)+a*(o-t);return c>0&&l>0?c/(c+l):+(c>l)}function By(e,t,n,r){return e*r-n*t}function Uet(e,t,n){let r=t.length,i=t.at(e-2),o=n.at(e-2),s=t.at(e-1),a=n.at(e-1),c=t[e],l=n[e],u=t.at(e+1-r),f=n.at(e+1-r),d=s-c,h=a-l,p=i-s,m=o-a,g=c-u,y=l-f,x=Math.hypot(d,h),b=Math.hypot(p,m),w=Math.hypot(g,y);return(v,_)=>{let I=v-s,D=_-a,A=v-c,E=_-l;return By(I,D,A,E)>-1e-6&&By(I,D,d,h)*b-By(I,D,p,m)*x>-1e-6&&By(A,E,g,y)*x-By(A,E,d,h)*w<=0}}function VP(e,t,n,r,i,o,s){let a=Pn.from(e,u=>r[u],u=>i[u]),c,l;for(let u=.5,f=0;u<n;++u){l=c;for(let d=.5;d<t;++d,++f)l=a.find(d,u,l),d===.5&&(c=l),s[f]=o[e[l]]}return s}function YP({random:e=Mo(42),minDistance:t=.5,maxSteps:n=2}={}){return(r,i,o,s,a,c,l)=>{let u=Pn.from(r,p=>s[p],p=>a[p]),f,d,h;for(let p=.5,m=0;p<o;++p){d=f;for(let g=.5;g<i;++g,++m){let y=g,x=p;h=d=u.find(y,x,d),g===.5&&(f=d);let b,w=0;for(;(b=Math.hypot(s[r[h]]-y,a[r[h]]-x))>t&&w<n;){let v=e(g,p,w)*2*Math.PI;y+=Math.cos(v)*b,x+=Math.sin(v)*b,h=u.find(y,x,h),++w}l[m]=c[r[h]]}}return l}}function zet(e,t,n,r,i,o){return t*e+r*n+o*i}function qet(e){return(t,n,r,i,o,s,a,c)=>{let l=e(a,c);return l<n?t:l<n+i?r:o}}function jet(e,t){return Vet(e)||Yet(e)?zet:qet(t)}function Vet(e){for(let t of e)if(t!=null)return typeof t=="number"}function Yet(e){for(let t of e)if(t!=null)return t instanceof Date}var la="density",Gi=class extends Bn{constructor(t,n,r){let{bandwidth:i=0,interpolate:o="none",pixelSize:s=1,pad:a=1,width:c,height:l,...u}=r,f=Xet(u);super(t,n,u,kv),this.densityMap=f,Ln(this,"bandwidth",i,()=>this.grids?this.convolve().update():null),Ln(this,"pixelSize",s),Ln(this,"interpolate",o),Ln(this,"pad",a),Ln(this,"width",c),Ln(this,"height",l)}setPlot(t,n){let r=()=>{this.hasFieldInfo()&&this.requestUpdate()};return t.addAttributeListener("domainX",r),t.addAttributeListener("domainY",r),super.setPlot(t,n)}get filterIndexable(){let t=this.plot.getAttribute("xDomain"),n=this.plot.getAttribute("yDomain");return t&&n&&!t[Sn]&&!n[Sn]}query(t=[]){let{interpolate:n,pad:r,channels:i,densityMap:o,source:s}=this,[a,c]=this.extentX=Vo(this,t),[l,u]=this.extentY=Yo(this,t),[f,d]=this.bins=this.binDimensions(this),[h,p]=Gr(this,"x",f,[a,c],r),[m,g]=Gr(this,"y",d,[l,u],r),y=r?[Ae(p,[+a,+c]),Ae(g,[+l,+u])]:[Is(+a,p),Ss(p,+c),Is(+l,g),Ss(g,+u)],x=ht.from(s.table).where(t.concat(y)),b=this.groupby=[],w={};for(let _ of i)if(Object.hasOwn(_,"field")){let{as:I,channel:D,field:A}=_;A.aggregate?(w[D]=A,o[D]=!0):D==="weight"?w[la]=Fr(A):D!=="x"&&D!=="y"&&(x.select({[I]:A}),b.push(I))}let v=this.aggr=Object.keys(w);if(w.density&&v.length>1)throw new Error("Weight option can not be used with custom aggregates.");if(v.length||(v.push(la),w.density=kr()),n==="linear"){if(v.length>1)throw new Error("Linear binning not applicable to multiple aggregates.");if(!w.density)throw new Error("Linear binning not applicable to custom aggregates.");return Het(x,h,m,w[la],f,b)}else return Wet(x,h,m,w,f,b)}binDimensions(){let{plot:t,pixelSize:n,width:r,height:i}=this;return[r??Math.round(t.innerWidth()/n),i??Math.round(t.innerHeight()/n)]}queryResult(t){let[n,r]=this.bins,i=Get(this.interpolate);return this.grids=UP(n,r,t,this.aggr,this.groupby,i),this.convolve()}convolve(){let{aggr:t,bandwidth:n,bins:r,grids:i,plot:o}=this;if(this.kde=this.grids,n>0){let s=t.length===1?t[0]:t.includes(la)?la:null;if(!s)return console.warn("No compatible grid found for smoothing."),this;let a=o.innerWidth(),c=o.innerHeight(),[l,u]=r,f=i.some(p=>p[s].some(m=>m<0)),d=Oy(n*(l-1)/a,f),h=Oy(n*(u-1)/c,f);this.kde=this.grids.map(p=>{let m=qP(d,h,p[s],r);return{...p,[s]:m}})}return this}plotSpecs(){throw new Error("Unimplemented. Use a Grid2D mark subclass.")}};function Xet(e){let t={};for(let n in e)e[n]==="density"&&(delete e[n],t[n]=!0);return t}function Get(e="none"){if(typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"none":case"linear":return;case"nearest":return VP;case"barycentric":return jP();case"random-walk":return YP()}throw new Error(`invalid interpolate: ${e}`)}function Wet(e,t,n,r,i,o){return e.select({index:q`FLOOR(${t})::INTEGER + FLOOR(${n})::INTEGER * ${i}`,...r}).groupby("index",o)}function Het(e,t,n,r,i,o){let s=r?.column?`* ${r.column}`:"",a=(d,h)=>e.clone().select({xp:t,yp:n,i:d,w:h}),c=a(q`FLOOR(xp)::INTEGER + FLOOR(yp)::INTEGER * ${i}`,q`(FLOOR(xp)::INTEGER + 1 - xp) * (FLOOR(yp)::INTEGER + 1 - yp)${s}`),l=a(q`FLOOR(xp)::INTEGER + (FLOOR(yp)::INTEGER + 1) * ${i}`,q`(FLOOR(xp)::INTEGER + 1 - xp) * (yp - FLOOR(yp)::INTEGER)${s}`),u=a(q`FLOOR(xp)::INTEGER + 1 + FLOOR(yp)::INTEGER * ${i}`,q`(xp - FLOOR(xp)::INTEGER) * (FLOOR(yp)::INTEGER + 1 - yp)${s}`),f=a(q`FLOOR(xp)::INTEGER + 1 + (FLOOR(yp)::INTEGER + 1) * ${i}`,q`(xp - FLOOR(xp)::INTEGER) * (yp - FLOOR(yp)::INTEGER)${s}`);return ht.from(ht.unionAll(c,l,u,f)).select({index:"i",density:Fr("w")},o).groupby("index",o).having(zc("density",0))}var Ly=class extends Gi{constructor(t,n){let{thresholds:r=10,...i}=n;super("geo",t,{bandwidth:20,interpolate:"linear",pixelSize:2,...i}),Ln(this,"thresholds",r,()=>this.grids?this.contours().update():null)}convolve(){return super.convolve().contours()}contours(){let{bins:t,densityMap:n,kde:r,thresholds:i,plot:o}=this,s=i;if(!Array.isArray(s)){let[,w]=Dy(r,"density");s=Array.from({length:s-1},(v,_)=>w*(_+1)/s)}(n.fill||n.stroke)&&this.plot.getAttribute("colorScale")!=="log"&&this.plot.setAttribute("colorZero",!0);let[a,c]=t,[l,u]=o.getAttribute("xDomain"),[f,d]=o.getAttribute("yDomain"),h=(u-l)/a,p=(d-f)/c,m=+l,g=+f,y=w=>m+w*h,x=w=>g+w*p,b=Fa().size(t);return this.data=r.flatMap(w=>s.map(v=>Object.assign(Zet(b.contour(w.density,v),y,x),{...w,density:v}))),this}plotSpecs(){let{type:t,channels:n,densityMap:r,data:i}=this,o={};for(let s of n){let{channel:a}=s;a!=="x"&&a!=="y"&&(o[a]=gi(s))}return r.fill&&(o.fill="density"),r.stroke&&(o.stroke="density"),[{type:t,data:i,options:o}]}};function Zet(e,t,n){function r(s){s.forEach(i)}function i(s){s.forEach(o)}function o(s){s[0]=t(s[0]),s[1]=n(s[1])}return e.coordinates.forEach(r),e}function Rv(e,t){if(typeof document<"u"){let n=document.createElement("canvas");return n.setAttribute("width",e),n.setAttribute("height",t),n}throw new Error("Can not create a canvas instance.")}function XP(e=1){let t=255*e|0;return(n,r,i)=>{for(let o=0,s=0;o<i;++o)for(let a=0;a<r;++a,s+=4)n[s+3]=t}}function GP(e){let{apply:t}=e;return(n,r,i,o)=>{for(let s=0,a=0;s<i;++s)for(let c=0,l=(i-s-1)*r;c<r;++c,a+=4)n[a+3]=255*t(o[c+l])|0}}function WP(e={}){let{r:t=0,g:n=0,b:r=0,opacity:i=1}=typeof e=="string"?on(e):e,o=new Uint8ClampedArray([t,n,r,255*i|0]);return(s,a,c)=>{for(let l=0,u=0;l<c;++l)for(let f=0;f<a;++f,u+=4)s[u+0]=o[0],s[u+1]=o[1],s[u+2]=o[2],s[u+3]=o[3]}}function HP(e){let{domain:t,range:n}=e,r=Object.create(null),i=new Uint8ClampedArray(4*t.length),o=t.length-1,s=n.length;for(let a=0;a<=o;++a){let c=n[a%s],{r:l,g:u,b:f,opacity:d=1}=typeof c=="string"?on(c):c,h=a<<2;i[h+0]=l,i[h+1]=u,i[h+2]=f,i[h+3]=255*d|0,r[t[a]]=h}return(a,c,l,u)=>{if(u.map)for(let f=0,d=0;f<l;++f)for(let h=0,p=(l-f-1)*c;h<c;++h,d+=4){let m=r[u[h+p]];a[d+0]=i[m+0],a[d+1]=i[m+1],a[d+2]=i[m+2],a[d+3]=i[m+3]}else{let f=r[u];for(let d=0,h=0;d<l;++d)for(let p=0;p<c;++p,h+=4)a[h+0]=i[f+0],a[h+1]=i[f+1],a[h+2]=i[f+2],a[h+3]=i[f+3]}}}function ZP(e,t,n){let{interpolate:r}=t,i=new Uint8ClampedArray(4*e),o=e-1;for(let s=0;s<=o;++s){let a=r(s/o),{r:c,g:l,b:u,opacity:f=1}=typeof a=="string"?on(a):a,d=s<<2;i[d+0]=c,i[d+1]=l,i[d+2]=u,i[d+3]=255*f|0}return(s,a,c,l)=>{for(let u=0,f=0;u<c;++u)for(let d=0,h=(c-u-1)*a;d<a;++d,f+=4){let p=o*n(l[d+h])<<2;s[f+0]=i[p+0],s[f+1]=i[p+1],s[f+2]=i[p+2],s[f+3]=i[p+3]}}}var yc=class extends Gi{constructor(t,n){super("image",t,n)}setPlot(t,n){let r=()=>{this.hasFieldInfo()&&this.rasterize()};t.addAttributeListener("schemeColor",r),super.setPlot(t,n)}convolve(){return super.convolve().rasterize()}rasterize(){let{bins:t,kde:n}=this,[r,i]=t,{canvas:o,ctx:s,img:a}=tnt(this,r,i),{alpha:c,alphaProp:l,color:u,colorProp:f}=q3(this);return this.data=n.map(d=>(u?.(a.data,r,i,d[f]),c?.(a.data,r,i,d[l]),s.putImageData(a,0,0),{src:o.toDataURL()})),this}plotSpecs(){let{type:t,plot:n,data:r}=this,i={src:"src",width:n.innerWidth(),height:n.innerHeight(),preserveAspectRatio:"none",imageRendering:this.channel("imageRendering")?.value,frameAnchor:"middle"};return[{type:t,data:r,options:i}]}},Cy=class extends yc{constructor(t,n){super(t,{bandwidth:20,interpolate:"linear",pixelSize:2,...n})}};function q3(e){let{aggr:t,densityMap:n,groupby:r,plot:i}=e,o=t.includes(la),s=t.includes("fillOpacity"),a=e.channel("fill"),c=e.channel("fillOpacity");if(t.length>2||o&&s)throw new Error("Invalid raster encodings. Try dropping an aggregate?");if(r.includes(c?.as))throw new Error("Raster fillOpacity must be an aggregate or constant.");let l=n.fill||t.includes("fill")?"grid":r.includes(a?.as)?"group":Bv(a?.value)?a.value:o&&i.getAttribute("colorScheme")?"grid":void 0,u=n.fillOpacity||t.includes("fillOpacity")?"grid":typeof c?.value=="number"?c.value:o&&l!=="grid"?"grid":void 0;if(l!=="grid"&&u!=="grid")throw new Error("Raster mark missing density values.");let f=a?.as??(l==="grid"?la:null),d=c?.as??(u==="grid"?la:null),h=l!=="grid"&&l!=="group"?WP(l):Qet(e,f),p=u!=="grid"?XP(u):Jet(e,d);return{alphaProp:d,colorProp:f,alpha:p,color:h}}function Jet(e,t){let{plot:n,kde:r}=e,i=n.getAttribute("opacityDomain"),o=i===lo,s=i?.[Sn],a=!o&&!s&&i||Dy(r,t);(o||s)&&(s&&(a[Sn]=!0),n.setAttribute("colorDomain",a));let c=Uf({opacity:{type:n.getAttribute("opacityScale"),domain:a,clamp:n.getAttribute("opacityClamp"),nice:n.getAttribute("opacityNice"),reverse:n.getAttribute("opacityReverse"),zero:n.getAttribute("opacityZero"),base:n.getAttribute("opacityBase"),exponent:n.getAttribute("opacityExponent"),constant:n.getAttribute("opacityConstant")}});return GP(c)}function Qet(e,t){let{plot:n,kde:r}=e,i=!r[0][t]?.map,o=i||Array.isArray(r[0][t]),s=n.getAttribute("colorDomain"),a=s===lo,c=s?.[Sn],l=!a&&!c&&s||(i?r.map(f=>f[t]).sort(zt):o?zP(r,t):Dy(r,t));(a||c)&&(c&&(l[Sn]=!0),n.setAttribute("colorDomain",l));let u=Uf({color:{type:n.getAttribute("colorScale"),domain:l,range:n.getAttribute("colorRange"),clamp:n.getAttribute("colorClamp"),n:n.getAttribute("colorN"),nice:n.getAttribute("colorNice"),reverse:n.getAttribute("colorReverse"),scheme:n.getAttribute("colorScheme"),interpolate:n.getAttribute("colorInterpolate"),pivot:n.getAttribute("colorPivot"),symmetric:n.getAttribute("colorSymmetric"),zero:n.getAttribute("colorZero"),base:n.getAttribute("colorBase"),exponent:n.getAttribute("colorExponent"),constant:n.getAttribute("colorConstant")}});if(o)return HP(u);{let f=Uf({x:{type:Ket(u.type),domain:u.domain,reverse:u.reverse,range:[0,1],clamp:u.clamp,base:u.base,exponent:u.exponent,constant:u.constant}});return ZP(1024,u,f.apply)}}function Ket(e){return e.endsWith("symlog")?"symlog":e.endsWith("log")?"log":e.endsWith("pow")?"pow":e.endsWith("sqrt")?"sqrt":e==="diverging"?"linear":e}function tnt(e,t,n){if(!e.image||e.image.w!==t||e.image.h!==n){let r=Rv(t,n),i=r.getContext("2d",{willReadFrequently:!0}),o=i.getImageData(0,0,t,n);e.image={canvas:r,ctx:i,img:o,w:t,h:n}}return e.image}var ky=class extends yc{constructor(t,n){let{normalize:r=!0,...i}=n;super(t,i),Ln(this,"normalize",r)}query(t=[]){let{channels:n,normalize:r,source:i,binPad:o}=this,[s,a]=this.bins=this.binDimensions(this),[c]=Gr(this,"x",s,Vo(this,t),o),[l]=Gr(this,"y",a,Yo(this,t),o),u=ht.from(i.table).where(ent(this,t));this.aggr=["density"];let f=this.groupby=[],d=[];for(let h of n)if(Object.hasOwn(h,"field")){let{channel:p,field:m}=h;p==="z"?(u.select({[p]:m}),d.push("z")):p!=="x"&&p!=="y"&&(u.select({[p]:m}),f.push(p))}return nnt(u,c,l,d,s,a,f,r)}};function ent(e,t){if(Array.isArray(t)&&!t.length)return t;let{column:n}=e.channelField("x"),{column:r}=e.channelField("y"),i=s=>{let a=`${s.field}`;return s.op!=="BETWEEN"||a!==n&&a!==r},o=s=>s.op==="AND"?Wn(s.children.filter(a=>i(a))):s;return Array.isArray(t)?t.filter(s=>i(s)).map(s=>o(s)):o(t)}function nnt(e,t,n,r,i,o,s=[],a=!0){e.select({x:q`FLOOR(${t})::INTEGER`,y:q`FLOOR(${n})::INTEGER`});let c=s.concat(r),l=c.length?`PARTITION BY ${c.join(", ")} `:"",u=ht.from(e).select(c,{x0:"x",y0:"y",dx:q`(lead(x) OVER sw - x)`,dy:q`(lead(y) OVER sw - y)`}).window({sw:q`${l}ORDER BY x ASC`}).qualify(Wn(q`(x0 < ${i} OR x0 + dx < ${i})`,q`(y0 < ${o} OR y0 + dy < ${o})`,q`(x0 > 0 OR x0 + dx > 0)`,q`(y0 > 0 OR y0 + dy > 0)`)),f=ht.select({x:q`GREATEST(MAX(ABS(dx)), MAX(ABS(dy)))`}).from("pairs"),d=ht.select({i:q`UNNEST(range((${f})))::INTEGER`}),h=ht.unionAll(ht.select(c,{x:q`x0 + i`,y:q`y0 + ROUND(i * dy / dx::FLOAT)::INTEGER`}).from("pairs","indices").where(q`ABS(dy) <= ABS(dx) AND i < ABS(dx)`),ht.select(c,{x:q`x0 + ROUND(SIGN(dy) * i * dx / dy::FLOAT)::INTEGER`,y:q`y0 + SIGN(dy) * i`}).from("pairs","indices").where(q`ABS(dy) > ABS(dx) AND i < ABS(dy)`),ht.select(c,{x:"x0",y:"y0"}).from("pairs").where(Uc("dx"))),p=["x"].concat(c).join(", "),m=ht.from("raster").select(c,"x","y",a?{w:q`1.0 / COUNT(*) OVER (PARTITION BY ${p})`}:null).where(Wn(Ae("x",[0,i],!0),Ae("y",[0,o],!0)));return ht.with({pairs:u,indices:d,raster:h,points:m}).from("points").select(s,{index:q`x + y * ${i}::INTEGER`,density:a?Fr("w"):kr()}).groupby("index",s)}var gd=class extends Bn{constructor(t,n,r){let{bins:i=1024,bandwidth:o=20,...s}=r,a=t.endsWith("X")?"y":"x";super(t,n,s,a==="x"?P3:U3),this.dim=a,Ln(this,"bins",i),Ln(this,"bandwidth",o,()=>this.grid?this.convolve().update():null)}get filterIndexable(){let t=this.dim==="x"?"xDomain":"yDomain",n=this.plot.getAttribute(t);return n&&!n[Sn]}query(t=[]){if(this.hasOwnData())throw new Error("Density1DMark requires a data source");let{bins:n,channels:r,dim:i,source:{table:o}}=this,s=this.extent=(i==="x"?Vo:Yo)(this,t),[a,c]=Gr(this,i,n,s),l=$3(r,o,[i]).where(t.concat(Ae(c,s))),u=this.channelField("weight")?"weight":null;return rnt(l,a,u)}queryResult(t){return this.grid=PP(this.bins,t),this.convolve()}convolve(){let{bins:t,bandwidth:n,dim:r,grid:i,plot:o,extent:[s,a]}=this,c=i.some(x=>x<0),l=r==="x"?o.innerWidth():o.innerHeight(),u=Oy(n*(t-1)/l,c),f=Fv(u,i,t),d=this.data=[],h=r==="x"?"y":"x",p=this.channelField(r).as,m=+s,g=(a-m)/(t-1),y=1/g;for(let x=0;x<t;++x)d.push({[p]:m+x*g,[h]:f[x]*y});return this}plotSpecs(){let{type:t,data:n,channels:r,dim:i}=this,o=i==="x"?{y:"y"}:{x:"x"};for(let s of r)o[s.channel]=gi(s);return[{type:t,data:n,options:o}]}};function rnt(e,t,n){let r=n?`* ${n}`:"",i=e.clone().select({p:t,i:q`FLOOR(p)::INTEGER`,w:q`(FLOOR(p) + 1 - p)${r}`}),o=e.clone().select({p:t,i:q`FLOOR(p)::INTEGER + 1`,w:q`(p - FLOOR(p))${r}`});return ht.from(ht.unionAll(i,o)).select({index:"i",density:Fr("w")}).groupby("index").having($h("density",0))}var Fy=class extends Gi{constructor(t,n){let{type:r="dot",...i}=n;super(r,t,{bandwidth:20,interpolate:"linear",pad:0,pixelSize:2,...i})}convolve(){super.convolve();let{bins:t,pad:n,extentX:r,extentY:i}=this,[o,s]=t,a=ql(this,"x"),c=ql(this,"y"),[l,u]=r.map(g=>a.apply(g)),[f,d]=i.map(g=>c.apply(g)),h=(u-l)/(o-n),p=(d-f)/(s-n),m=n?0:.5;return this.data=int(this.kde,t,l,f,h,p,a.invert,c.invert,m),this}plotSpecs(){let{type:t,channels:n,densityMap:r,data:i}=this,o={};for(let s of n){let{channel:a}=s;o[a]=a==="x"||a==="y"?a:gi(s)}for(let s in r)r[s]&&(o[s]="density");return[{type:t,data:i,options:o}]}};function int(e,t,n,r,i,o,s,a,c){let l=1/(i*o),[u,f]=t,d=[];for(let h of e){let p=h.density;for(let m=0,g=0;g<f;++g)for(let y=0;y<u;++y,++m)d.push({...h,x:s(n+(y+c)*i),y:a(r+(g+c)*o),density:p[m]*l})}return d}var ont="geom",Ry=class extends Bn{constructor(t,n={},r){!Cv(t)&&!n?.geometry&&(n.geometry=qh(ont)),super("geo",t,n,r)}queryResult(t){super.queryResult(t);let n=this.channelField("geometry")?.as;return n&&this.data&&this.data.forEach(r=>{typeof r[n]=="string"&&(r[n]=JSON.parse(r[n]))}),this}};var $y=class extends Bn{constructor(t,n){let{type:r="hexagon",binWidth:i=20,...o}=n;super(r,t,{r:i/2,clip:!0,...o},kv),this.binWidth=i}get filterIndexable(){let t=this.plot.getAttribute("xDomain"),n=this.plot.getAttribute("yDomain");return t&&n&&!t[Sn]&&!n[Sn]}query(t=[]){if(this.hasOwnData())return null;let{plot:n,binWidth:r,channels:i,source:o}=this,[s,a]=Vo(this,t),[c,l]=Yo(this,t),u=.5-n.getAttribute("marginLeft"),f=0-n.getAttribute("marginTop"),d=`${r}::DOUBLE`,h=`${r*(1.5/Math.sqrt(3))}::DOUBLE`,p=`${n.innerWidth()/(a-s)}::DOUBLE`,m=`${n.innerHeight()/(l-c)}::DOUBLE`,g,y,x=new Set,b={};for(let D of i)D.channel==="orderby"?w.orderby(D.value):D.channel==="x"?g=D:D.channel==="y"?y=D:Object.hasOwn(D,"field")&&(b[D.as]=D.field,D.field.aggregate&&D.field.columns.forEach(A=>x.add(A)));let w=ht.select({[g.as]:q`${s}::DOUBLE + ((x + 0.5 * (y & 1)) * ${d} + ${u})::DOUBLE / ${p}`,[y.as]:q`${l}::DOUBLE - (y * ${h} + ${f})::DOUBLE / ${m}`,...b}).groupby("x","y"),v=`${p} * (${g.field} - ${s}::DOUBLE)`,_=`${m} * (${l}::DOUBLE - ${y.field})`,I=ht.select({py:q`(${_} - ${f}) / ${h}`,pj:q`ROUND(py)::INTEGER`,px:q`(${v} - ${u}) / ${d} - 0.5 * (pj & 1)`,pi:q`ROUND(px)::INTEGER`,tt:q`ABS(py-pj) * 3 > 1 AND (px-pi)**2 + (py-pj)**2 > (px - pi - 0.5 * CASE WHEN px < pi THEN -1 ELSE 1 END)**2 + (py - pj - CASE WHEN py < pj THEN -1 ELSE 1 END)**2`,x:q`CASE WHEN tt THEN (pi + (CASE WHEN px < pi THEN -0.5 ELSE 0.5 END) + (CASE WHEN pj & 1 <> 0 THEN 0.5 ELSE -0.5 END))::INTEGER ELSE pi END`,y:q`CASE WHEN tt THEN (pj + CASE WHEN py < pj THEN -1 ELSE 1 END)::INTEGER ELSE pj END`}).select(Array.from(x)).from(o.table).where(vs(g.field),vs(y.field),t);return w.from(I)}};var Py=class extends Gi{constructor(t,n){let{origin:r=[0,0],dim:i="xy",...o}=n;super("image",t,o),this.origin=r,this.tileX=i.toLowerCase().includes("x"),this.tileY=i.toLowerCase().includes("y")}setPlot(t,n){let r=()=>{this.hasFieldInfo()&&this.rasterize()};t.addAttributeListener("schemeColor",r),super.setPlot(t,n)}requestQuery(){return this.requestTiles()}query(t=[]){return this._filter=t,null}tileQuery(t){let{binType:n,binPad:r,channels:i,densityMap:o,source:s}=this,[[a,c],[l,u]]=t,[f,d]=this.bins,[h,p]=Gr(this,"x",f,[a,c],r),[m,g]=Gr(this,"y",d,[l,u],r),y=r?[Ae(p,[+a,+c]),Ae(g,[+l,+u])]:[Is(+a,p),Ss(p,+c),Is(+l,g),Ss(g,+u)],x=ht.from(s.table).where(y),b=this.groupby=[],w={};for(let _ of i)if(Object.hasOwn(_,"field")){let{as:I,channel:D,field:A}=_;A.aggregate?(w[D]=A,o[D]=!0):D==="weight"?w.density=Fr(A):D!=="x"&&D!=="y"&&(x.select({[I]:A}),b.push(I))}let v=this.aggr=Object.keys(w);if(w.density&&v.length>1)throw new Error("Weight option can not be used with custom aggregates.");if(v.length||(v.push("density"),w.density=kr()),n==="linear"){if(v.length>1)throw new Error("Linear binning not applicable to multiple aggregates.");if(!w.density)throw new Error("Linear binning not applicable to custom aggregates.");return unt(x,h,m,w.density,f,b)}else return lnt(x,h,m,w,f,b)}async requestTiles(){let t=ni();this.prefetch&&t.cancel(this.prefetch);let{binPad:n,tileX:r,tileY:i,origin:[o,s]}=this,[a,c]=this.bins=this.binDimensions(this),[l,u]=Vo(this,this._filter),[f,d]=Yo(this,this._filter),h=u-l,p=d-f,m=Math.floor((l-o)*(a-n)/h),g=Math.floor((f-s)*(c-n)/p),y=(E,T)=>[[o+E*h,o+(E+1)*h],[s+T*p,s+(T+1)*p]],x=Math.floor((l-o)/h),b=r?JP((u-o)/h):x,w=Math.floor((f-s)/p),v=i?JP((d-s)/p):w,_=[];for(let E=x;E<=b;++E)for(let T=w;T<=v;++T)_.push([E,T]);let I=_.map(([E,T])=>t.query(this.tileQuery(y(E,T)))),D=[];if(r)for(let E=w;E<=v;++E)D.push([b+1,E]),D.push([x-1,E]);if(i){let E=r?x-1:x,T=r?b+1:b;for(let O=E;O<=T;++O)D.push([O,v+1]),D.push([O,w-1])}this.prefetch=D.map(([E,T])=>t.prefetch(this.tileQuery(y(E,T))));let A=await Promise.all(I);this.grids=[{density:snt(a,c,m,g,_,A)}],this.convolve().update()}convolve(){return super.convolve().rasterize()}rasterize(){let{bins:t,kde:n}=this,[r,i]=t,{canvas:o,ctx:s,img:a}=cnt(this,r,i),{alpha:c,alphaProp:l,color:u,colorProp:f}=q3(this);return this.data=n.map(d=>(u?.(a.data,r,i,d[f]),c?.(a.data,r,i,d[l]),s.putImageData(a,0,0),{src:o.toDataURL()})),this}plotSpecs(){let{type:t,data:n,plot:r}=this,i={src:"src",width:r.innerWidth(),height:r.innerHeight(),preserveAspectRatio:"none",imageRendering:this.channel("imageRendering")?.value,frameAnchor:"middle"};return[{type:t,data:n,options:i}]}};function snt(e,t,n,r,i,o){let s=new Float64Array(e*t);return o.forEach((a,c)=>{let[l,u]=i[c],f=l*e-n,d=u*t-r;ant(e,t,s,a,f,d)}),s}function ant(e,t,n,r,i,o){let s=r.numRows;if(s===0)return;let a=r.getChild("index").toArray(),c=r.getChild("density").toArray();for(let l=0;l<s;++l){let u=a[l],f=i+u%e,d=o+Math.floor(u/e);0<=f&&f<e&&0<=d&&d<t&&(n[f+d*e]=c[l])}}function cnt(e,t,n){if(!e.image||e.image.w!==t||e.image.h!==n){let r=Rv(t,n),i=r.getContext("2d",{willReadFrequently:!0}),o=i.getImageData(0,0,t,n);e.image={canvas:r,ctx:i,img:o,w:t,h:n}}return e.image}function lnt(e,t,n,r,i,o){return e.select({index:q`FLOOR(${t})::INTEGER + FLOOR(${n})::INTEGER * ${i}`,...r}).groupby("index",o)}function unt(e,t,n,r,i,o){let s=r.column?`* ${r.column}`:"",a=(d,h)=>e.clone().select({xp:t,yp:n,i:d,w:h}),c=a(q`FLOOR(xp)::INTEGER + FLOOR(yp)::INTEGER * ${i}`,q`(FLOOR(xp)::INTEGER + 1 - xp) * (FLOOR(yp)::INTEGER + 1 - yp)${s}`),l=a(q`FLOOR(xp)::INTEGER + (FLOOR(yp)::INTEGER + 1) * ${i}`,q`(FLOOR(xp)::INTEGER + 1 - xp) * (yp - FLOOR(yp)::INTEGER)${s}`),u=a(q`FLOOR(xp)::INTEGER + 1 + FLOOR(yp)::INTEGER * ${i}`,q`(xp - FLOOR(xp)::INTEGER) * (FLOOR(yp)::INTEGER + 1 - yp)${s}`),f=a(q`FLOOR(xp)::INTEGER + 1 + (FLOOR(yp)::INTEGER + 1) * ${i}`,q`(xp - FLOOR(xp)::INTEGER) * (yp - FLOOR(yp)::INTEGER)${s}`);return ht.from(ht.unionAll(c,l,u,f)).select({index:"i",density:Fr("w")},o).groupby("index",o).having(zc("density",0))}function JP(e){let t=Math.floor(e);return t===e?t-1:t}function fnt(e,t,n){var r=1e-8,i=t-1,o=n-1,s=0,a,c,l,u,f,d,h,p,m,g,y;if(e<=0)return 0;if(e>=1)return 1;for(t>=1&&n>=1?(l=e<.5?e:1-e,u=Math.sqrt(-2*Math.log(l)),h=(2.30753+u*.27061)/(1+u*(.99229+u*.04481))-u,e<.5&&(h=-h),p=(h*h-3)/6,m=2/(1/(2*t-1)+1/(2*n-1)),g=h*Math.sqrt(p+m)/m-(1/(2*n-1)-1/(2*t-1))*(p+5/6-2/(3*m)),h=t/(t+n*Math.exp(2*g))):(a=Math.log(t/(t+n)),c=Math.log(n/(t+n)),u=Math.exp(t*a)/t,f=Math.exp(n*c)/n,g=u+f,e<u/g?h=Math.pow(t*g*e,1/t):h=1-Math.pow(n*g*(1-e),1/n)),y=-xd(t)-xd(n)+xd(t+n);s<10;s++){if(h===0||h===1)return h;if(d=dnt(h,t,n)-e,u=Math.exp(i*Math.log(h)+o*Math.log(1-h)+y),f=d/u,h-=u=f/(1-.5*Math.min(1,f*(i/h-o/(1-h)))),h<=0&&(h=.5*(h+u)),h>=1&&(h=.5*(h+u+1)),Math.abs(u)<r*h&&s>0)break}return h}function dnt(e,t,n){var r=e===0||e===1?0:Math.exp(xd(t+n)-xd(t)-xd(n)+t*Math.log(e)+n*Math.log(1-e));return e<0||e>1?!1:e<(t+1)/(t+n+2)?r*QP(e,t,n)/t:1-r*QP(1-e,n,t)/n}function QP(e,t,n){var r=1e-30,i=1,o=t+n,s=t+1,a=t-1,c=1,l=1-o*e/s,u,f,d,h;for(Math.abs(l)<r&&(l=r),l=1/l,h=l;i<=100&&(u=2*i,f=i*(n-i)*e/((a+u)*(t+u)),l=1+f*l,Math.abs(l)<r&&(l=r),c=1+f/c,Math.abs(c)<r&&(c=r),l=1/l,h*=l*c,f=-(t+i)*(o+i)*e/((t+u)*(s+u)),l=1+f*l,Math.abs(l)<r&&(l=r),c=1+f/c,Math.abs(c)<r&&(c=r),l=1/l,d=l*c,h*=d,!(Math.abs(d-1)<3e-7));i++);return h}function xd(e){var t=0,n=[76.18009172947146,-86.5053203294167,24.01409824083091,-1.231739572450155,.001208650973866179,-5395239384953e-18],r=1.000000000190015,i,o,s;for(s=(o=i=e)+5.5,s-=(i+.5)*Math.log(s);t<6;t++)r+=n[t]/++o;return Math.log(2.506628274631*r/i)-s}function KP(e,t){var n=fnt(2*Math.min(e,1-e),.5*t,.5);return n=Math.sqrt(t*(1-n)/n),e>.5?n:-n}var Uy=class extends Bn{constructor(t,n){let{ci:r=.95,precision:i=4,...o}=n;super("line",t,o);let s=()=>this.modelFit?this.confidenceBand().update():null;Ln(this,"ci",r,s),Ln(this,"precision",i,s)}query(t=[]){let n=this.channelField("x").as,r=this.channelField("y").as,i=Array.from(new Set(["stroke","z","fx","fy"].flatMap(o=>this.channelField(o)?.as||[])));return ht.from(super.query(t)).select({intercept:lS(r,n),slope:uS(r,n),n:fS(r,n),ssy:dS(r,n),ssx:hS(r,n),xm:pS(r,n),x0:_u(ei(n).where(vs(r))),x1:_u(ti(n).where(vs(r)))}).select(i).groupby(i)}queryResult(t){return this.modelFit=Lv(t),this.lineData=this.modelFit.flatMap(n=>hnt(n)),this.confidenceBand()}confidenceBand(){let{ci:t,modelFit:n,precision:r,plot:i}=this,o=i.innerWidth();return this.areaData=t?n.flatMap(s=>pnt(t,r,s,o)):null,this}plotSpecs(){let{lineData:t,areaData:n,channels:r,ci:i}=this,o={x:"x",y:"y"},s={x:"x",y1:"y1",y2:"y2",fillOpacity:.1};for(let a of r)switch(a.channel){case"x":case"y":case"fill":break;case"stroke":o.stroke=s.fill=gi(a);break;case"strokeOpacity":o.strokeOpacity=gi(a);break;case"fillOpacity":s.fillOpacity=gi(a);break;default:o[a.channel]=s[a.channel]=gi(a);break}return[...i?[{type:"areaY",data:n,options:s}]:[],{type:"line",data:t,options:o}]}};function hnt(e){let{x0:t,x1:n,xm:r,intercept:i,slope:o,n:s,ssx:a,ssy:c,...l}=e;return[{x:t,y:i+t*o,...l},{x:n,y:i+n*o,...l}]}function pnt(e,t,n,r){let{x0:i,x1:o,xm:s,intercept:a,slope:c,n:l,ssx:u,ssy:f,...d}=n,h=t*(o-i)/r,p=KP((1-e)/2,l-2)*Math.sqrt(f/(l-2));return Ue(i,o-h/2,h).concat(o).map(m=>{let g=a+m*c,y=p*Math.sqrt(1/l+(m-s)**2/u);return{x:m,y1:g-y,y2:g+y,...d}})}function tU(e){let t=e.toLowerCase(),n=e.length,r="";for(let i=0;i<n;++i)r+=(e[i]!==t[i]?"-":"")+t[i];return r}function bd(e){let t={};for(let n in e)t[tU(n)]=e[n];return t}function mnt(e){let{channels:t}=e,n=new Set,r=!1,i=!1;for(let o of t){let{channel:s,field:a,as:c}=o;if(s==="orderby")r=!0;else if(a)if(a.aggregate)i=!0;else{if(n.has(c))continue;n.add(c)}}return!r&&i&&n.size&&e.channels.push({channel:"orderby",value:Array.from(n)}),e}var zy=class{constructor(t,{selection:n,channels:r={}}){this.mark=mnt(t),this.selection=n;let i=Object.entries(bd(r));this.channels=i.length?i:[["opacity",.2]],this.selection.addEventListener("value",kd(()=>this.update()))}init(t){this.svg=t;let n=this.values=[],r=this.mark.index,i=this.nodes=t.querySelectorAll(`[data-index="${r}"] > *`),{channels:o}=this;for(let s=0;s<i.length;++s){let a=i[s];n.push(o.map(c=>a.getAttribute(c[0])))}return this.update()}async update(){let{svg:t,nodes:n,channels:r,values:i,mark:o,selection:s}=this;if(!t)return;let a=await ynt(o,s);for(let c=0;c<n.length;++c){let l=n[c],u=i[c],f=a(l.__data__);for(let d=0;d<r.length;++d){let[h,p]=r[d];l.setAttribute(h,f?u[d]:p)}}}};async function ynt(e,t){let n=t?.predicate(e);if(!n||n.length===0)return()=>!0;let r=e.filterBy?.predicate(e,!0),i={__:Wn(n)},o=e.query(r),s=o.groupby().length?o.select(i):o.$select(i),a=await e.coordinator.query(s),c=a.getChild?.("__");return a.numRows||a.length?c?l=>c.get(l):l=>a[l].__:()=>!1}function j3(e){let t=e.on,n=!0;function r(i){n=!1,i(),n=!0}return e.reset=(...i)=>{r(()=>e.clear(...i))},e.moveSilent=(...i)=>{r(()=>e.move(...i))},e.on=(...i)=>{if(i.length>1&&i[1]){let o=i[1];i[1]=(...s)=>n&&o(...s)}return t(...i)},e}function eU(){return j3(vI())}function nU(){return j3(bI())}function rU(){return j3(wI())}function qy(e,t){return e===t||e&&t&&Math.abs(e[0]-t[0])<1e-12&&Math.abs(e[1]-t[1])<1e-12||!1}function Xo(e,t){let n=e.channelField(t)?.field;return n?.basis||n}function jy(e,t,n=1){return t.invert(n*Math.floor(e/n))}function $v(){let e=this,t=e.getScreenCTM,n;e.getScreenCTM=()=>e.isConnected?n=t.call(e):n}var wd=class{constructor(t,{channel:n,selection:r,field:i,pixelSize:o=1,peers:s=!0,brush:a}){this.mark=t,this.channel=n,this.pixelSize=o||1,this.selection=r,this.peers=s,this.field=i||Xo(t,n),this.style=a&&bd(a),this.brush=n==="y"?rU():nU(),this.brush.on("brush end",({selection:c})=>this.publish(c))}reset(){this.value=void 0,this.g&&this.brush.reset(this.g)}activate(){this.selection.activate(this.clause(this.value||[0,1]))}publish(t){let n;t&&(n=t.map(r=>jy(r,this.scale,this.pixelSize)).sort((r,i)=>r-i)),qy(n,this.value)||(this.value=n,this.g.call(this.brush.moveSilent,t),this.selection.update(this.clause(n)))}clause(t){let{mark:n,pixelSize:r,field:i,scale:o}=this;return{source:this,schema:{type:"interval",pixelSize:r,scales:[o]},clients:this.peers?n.plot.markSet:new Set().add(n),value:t,predicate:t?Ae(i,t):null}}init(t){let{brush:n,channel:r,style:i}=this;this.scale=t.scale(r);let o=t.scale("x").range,s=t.scale("y").range;n.extent([[ue(o),ue(s)],[Wt(o),Wt(s)]]);let a=Vt(t).selectAll('g[aria-label="facet"]'),c=a.size()?a:Vt(t);if(this.g=c.append("g").attr("class",`interval-${r}`).each($v).call(n).call(n.moveSilent,this.value?.map(this.scale.apply)),i){let l=this.g.selectAll("rect.selection");for(let u in i)l.attr(u,i[u])}t.addEventListener("pointerenter",()=>this.activate())}};var Pv=(e,t)=>e-t,Vy=class{constructor(t,{selection:n,xfield:r,yfield:i,pixelSize:o=1,peers:s=!0,brush:a}){this.mark=t,this.pixelSize=o||1,this.selection=n,this.peers=s,this.xfield=r||Xo(t,"x"),this.yfield=i||Xo(t,"y"),this.style=a&&bd(a),this.brush=eU(),this.brush.on("brush end",({selection:c})=>this.publish(c))}reset(){this.value=void 0,this.g&&this.brush.reset(this.g)}activate(){this.selection.activate(this.clause(this.value||[[0,1],[0,1]]))}publish(t){let{value:n,pixelSize:r,xscale:i,yscale:o}=this,s,a;if(t){let[c,l]=t;s=[c[0],l[0]].map(u=>jy(u,i,r)).sort(Pv),a=[c[1],l[1]].map(u=>jy(u,o,r)).sort(Pv)}(!qy(s,n?.[0])||!qy(a,n?.[1]))&&(this.value=t?[s,a]:void 0,this.g.call(this.brush.moveSilent,t),this.selection.update(this.clause(this.value)))}clause(t){let{mark:n,pixelSize:r,xfield:i,yfield:o,xscale:s,yscale:a}=this;return{source:this,schema:{type:"interval",pixelSize:r,scales:[s,a]},clients:this.peers?n.plot.markSet:new Set().add(n),value:t,predicate:t?Wn(Ae(i,t[0]),Ae(o,t[1])):null}}init(t){let{brush:n,style:r}=this,i=this.xscale=t.scale("x"),o=this.yscale=t.scale("y"),s=i.range,a=o.range;n.extent([[ue(s),ue(a)],[Wt(s),Wt(a)]]);let c=Vt(t).selectAll('g[aria-label="facet"]'),l=c.size()?c:Vt(t);if(this.g=l.append("g").attr("class","interval-xy").each($v).call(n),r){let u=this.g.selectAll("rect.selection");for(let f in r)u.attr(f,r[f])}if(this.value){let[u,f]=this.value[0].map(i.apply).sort(Pv),[d,h]=this.value[1].map(o.apply).sort(Pv);this.g.call(n.moveSilent,[[u,d],[f,h]])}t.addEventListener("pointerenter",()=>this.activate())}};var vd=class{constructor(t,{selection:n,channel:r,field:i}){this.mark=t,this.selection=n,this.clients=new Set().add(t),this.channel=r,this.field=i||Xo(t,[r])}clause(t){let{clients:n,field:r}=this,i=t?_s(r,Cr(t)):null;return{source:this,schema:{type:"point"},clients:n,value:t,predicate:i}}init(t){let n=this,{mark:r,channel:i,selection:o}=this,{data:s}=r,a=r.channelField(i).as,c=Vt(t).selectAll('g[aria-label="facet"]'),l=c.size()?c:Vt(t),u=t.scale(i),f=!ri(o);l.on("pointerdown pointermove",function(d){let[h,p]=kn(d,this),m=gnt(s,a,u.invert(i==="x"?h:p));o.update(f?m:n.clause(m))}),!f&&t.addEventListener("pointerenter",()=>{this.selection.activate(this.clause(0))})}};function gnt(e,t,n){let r=1/0,i;return e.forEach(o=>{let s=Math.abs(o[t]-n);s<r&&(r=s,i=o[t])}),i}var iU=(e,t)=>e-t,Yy=class{constructor(t,{x:n=new Ms,y:r=new Ms,xfield:i,yfield:o,zoom:s=!0,panx:a=!0,pany:c=!0}){this.mark=t,this.xsel=n,this.ysel=r,this.xfield=i||Xo(t,"x"),this.yfield=o||Xo(t,"y"),this.zoom=V3(s,[0,1/0],[1,1]),this.panx=this.xsel&&a,this.pany=this.ysel&&c;let{plot:l}=t;a&&this.xsel.addEventListener("value",u=>{l.setAttribute("xDomain",u)&&l.update()}),c&&this.ysel.addEventListener("value",u=>{l.setAttribute("yDomain",u)&&l.update()})}publish(t){if(this.panx){let n=xnt(t,this.xscale);this.xsel.update(this.clause(n,this.xfield,this.xscale))}if(this.pany){let n=bnt(t,this.yscale);this.ysel.update(this.clause(n,this.yfield,this.yscale))}}clause(t,n,r){return{source:this,schema:{type:"interval",scales:[r]},clients:this.mark.plot.markSet,value:t,predicate:t?Ae(n,t):null}}init(t){if(this.svg=t,this.initialized)return;this.initialized=!0;let{panx:n,pany:r,mark:{plot:{element:i}},xsel:o,ysel:s}=this;this.xscale=t.scale("x"),this.yscale=t.scale("y");let a=this.xscale.range.slice().sort(iU),c=this.yscale.range.slice().sort(iU),l=V3(n,[-1/0,1/0],a),u=V3(r,[-1/0,1/0],c),f=RA().extent([[a[0],c[0]],[a[1],c[1]]]).scaleExtent(this.zoom).translateExtent([[l[0],u[0]],[l[1],u[1]]]).on("start",()=>{this.xscale=this.svg.scale("x"),this.yscale=this.svg.scale("y")}).on("end",()=>i.__zoom=new qr(1,0,0)).on("zoom",({transform:d})=>this.publish(d));if(Vt(i).call(f),n||r){let d=!1;i.addEventListener("mouseenter",()=>{if(!d){if(d=!0,n){let{xscale:h,xfield:p}=this;o.activate(this.clause(h.domain,p,h))}if(r){let{yscale:h,yfield:p}=this;s.activate(this.clause(h.domain,p,h))}}}),i.addEventListener("mouseleave",()=>d=!1)}}};function V3(e,t,n){return e?Array.isArray(e)?e:t:n}function xnt(e,t){return t.range.map(e.invertX,e).map(t.invert,t)}function bnt(e,t){return t.range.map(e.invertY,e).map(t.invert,t)}var jl=class{constructor(t,{selection:n,channels:r,peers:i=!0}){this.value=null,this.mark=t,this.selection=n,this.peers=i,this.channels=r.map(o=>{let s=o==="color"?["fill","stroke"]:o==="x"?["x","x1","x2"]:o==="y"?["y","y1","y2"]:[o];for(let a=0;a<s.length;++a){let c=t.channelField(s[a]);if(c)return{field:c.field?.basis||c.field,as:c.as}}throw new Error(`Missing channel: ${o}`)})}clause(t){let{channels:n,mark:r}=this,i=null;if(t){let o=t.map(s=>{let a=s.map((c,l)=>Ph(n[l].field,Cr(c)));return a.length>1?Wn(a):a[0]});i=o.length>1?Pc(o):o[0]}return{source:this,schema:{type:"point"},clients:this.peers?r.plot.markSet:new Set().add(r),value:t,predicate:i}}init(t,n,r){let{mark:i,channels:o,selection:s}=this,{data:a}=i;r=r||(l=>{let u=a[l.__data__];return o.map(f=>u[f.as])}),n=n||`[data-index="${i.index}"]`;let c=new Set(t.querySelectorAll(n));t.addEventListener("pointerdown",l=>{let u=s.single?s.value:this.value,f=l.target,d=null;if(wnt(c,f)){let h=r(f);l.shiftKey&&u?.length?(d=u.filter(p=>Y3(p,h)),d.length===u.length&&d.push(h)):u?.length===1&&!Y3(u[0],h)?d=null:d=[h]}this.value=d,vnt(u,d)&&s.update(this.clause(d))}),t.addEventListener("pointerenter",()=>{this.selection.activate(this.clause([this.channels.map(()=>0)]))})}};function wnt(e,t){return e.has(t)||e.has(t.parentNode)||e.has(t.parentNode?.parentNode)}function vnt(e,t){return e==null||t==null?e!=null||t!=null:e.length!==t.length||e.some((n,r)=>Y3(n,t[r]))}function Y3(e,t){let n=e.length;if(t.length!==n)return!0;for(let r=0;r<n;++r)if(e[r]!==t[r])return!0;return!1}var _d=class{constructor(t,n){let{as:r,...i}=n;this.channel=t,this.options={label:null,...i},this.selection=r,this.element=document.createElement("div"),this.element.setAttribute("class","legend"),this.element.value=this}setPlot(t){let{channel:n,selection:r}=this,i=_nt(t,n);this.selection&&i&&(this.handler=new jl(i,{selection:r,channels:[n]}),this.selection.addEventListener("value",()=>this.update()))}init(t){let{channel:n,options:r,handler:i}=this,s=t.scale(n).type==="ordinal"?r:{marginTop:1,tickSize:2,height:28,...r};return this.legend=t.legend(n,s),i&&(i.init(this.legend,":scope > div",a=>[a.__data__]),this.update()),this.element.replaceChildren(this.legend),this.element}update(){if(!this.legend)return;let{value:t}=this.selection,n=t&&t.length?new Set(t.map(i=>i[0])):null,r=this.legend.querySelectorAll(":scope > div");for(let i of r){let o=n?n.has(i.__data__):!0;i.style.opacity=o?1:.2}}};function _nt({marks:e},t){let n=t==="color"?["fill","stroke"]:t==="opacity"?["opacity","fillOpacity","strokeOpacity"]:null;if(n==null)return null;for(let r=e.length-1;r>-1;--r)for(let i of n)if(e[r].channelField(i,{exact:!0}))return e[r];return null}var Snt=new Set(["rectY-x","rectX-y","rect-x","rect-y"]);function Uv(e,t={steps:25}){let n=(r,i)=>Snt.has(`${r.type}-${i}`)?{[`${i}1`]:X3(r,i,e,t),[`${i}2`]:X3(r,i,e,{...t,offset:1})}:{[i]:X3(r,i,e,t)};return n[Zh]=!0,n}function X3(e,t,n,r){return{column:n,label:n,get stats(){return{column:n,stats:["min","max"]}},get columns(){return[n]},get basis(){return n},toString(){let{apply:i,sqlApply:o,sqlInvert:s}=ql(e,t),{min:a,max:c}=e.channelField(t),l=Int(i(a),i(c),r),u=o(n),f=l.min===0?u:`(${u} - ${l.min})`,d=`${(l.max-l.min)/l.steps}::DOUBLE`,h=r.offset?`${r.offset} + `:"",p=`${l.min} + ${d} * (${h}FLOOR(${f} / ${d}))`;return`${s(p)}`}}}function Int(e,t,n){let{steps:r=25,minstep:i=0,nice:o=!0}=n;if(o!==!1){let s=t-e,a=r,c=Math.LN10,l=Math.ceil(Math.log(a)/c),u=Math.max(i,Math.pow(10,Math.round(Math.log(s)/c)-l));for(;Math.ceil(s/u)>a;)u*=10;let f=[5,2],d;for(let m=0,g=f.length;m<g;++m)d=u/f[m],d>=i&&s/d<=a&&(u=d);d=Math.log(u);let h=d>=0?0:~~(-d/c)+1,p=Math.pow(10,-h-1);d=Math.floor(e/u+p)*u,e=e<d?d-u:d,t=Math.ceil(t/u)*u,r=Math.round((t-e)/u)}return{min:e,max:t,steps:r}}var Mnt=e=>e&&typeof e=="object"&&!Array.isArray(e);var Xy=class extends ur{constructor({element:t,filterBy:n,from:r,column:i,label:o=i,format:s=u=>u,options:a,value:c,as:l}={}){super(n),this.from=r,this.column=i,this.selection=l,this.format=s,this.element=t??document.createElement("div"),this.element.setAttribute("class","input"),this.element.value=this;let u=document.createElement("label");u.innerText=o||i,this.element.appendChild(u),this.select=document.createElement("select"),a&&(this.data=a.map(f=>Mnt(f)?f:{value:f}),this.update()),c=c??this.selection?.value??this.data?.[0]?.value,this.selection?.value===void 0&&this.publish(c),this.element.appendChild(this.select),this.selection&&(this.select.addEventListener("input",()=>{this.publish(this.selectedValue()??null)}),ri(this.selection)||this.selection.addEventListener("value",f=>{f!==this.select.value&&this.selectedValue(f)}))}selectedValue(t){if(arguments.length===0){let n=this.select.selectedIndex;return this.data[n].value}else{let n=this.data?.findIndex(r=>r.value===t);n>=0?this.select.selectedIndex=n:this.select.value=String(t)}}reset(){this.select.selectedIndex=this.from?0:-1}publish(t){let{selection:n,column:r}=this;ri(n)?n.update({source:this,schema:{type:"point"},value:t,predicate:t!==""&&t!==void 0?_s(r,Cr(t)):null}):br(n)&&n.update(t)}query(t=[]){let{from:n,column:r}=this;return n?ht.from(n).select({value:r}).distinct().where(t).orderby(r):null}queryResult(t){return this.data=[{value:"",label:"All"},...t],this}update(){let{data:t,format:n,select:r}=this;r.replaceChildren();for(let{value:i,label:o}of t){let s=document.createElement("option");s.setAttribute("value",i),s.innerText=o??n(i),this.select.appendChild(s)}return this.selection&&this.selectedValue(this.selection?.value??""),this}};var Ant={contains:B2,prefix:L2,suffix:C2,regexp:O2},Tnt=0;var Gy=class extends ur{constructor({element:t,filterBy:n,from:r,column:i,label:o,type:s="contains",as:a}={}){if(super(n),this.id="search_"+ ++Tnt,this.type=s,this.from=r,this.column=i,this.selection=a,this.element=t??document.createElement("div"),this.element.setAttribute("class","input"),this.element.value=this,o){let c=document.createElement("label");c.setAttribute("for",this.id),c.innerText=o,this.element.appendChild(c)}this.searchbox=document.createElement("input"),this.searchbox.setAttribute("id",this.id),this.searchbox.setAttribute("type","text"),this.searchbox.setAttribute("placeholder","Query"),this.element.appendChild(this.searchbox),this.selection&&(this.searchbox.addEventListener("input",()=>{this.publish(this.searchbox.value||null)}),ri(this.selection)||this.selection.addEventListener("value",c=>{c!==this.searchbox.value&&(this.searchbox.value=c)}))}reset(){this.searchbox.value=""}publish(t){let{selection:n,column:r,type:i}=this;ri(n)?n.update({source:this,schema:{type:i},value:t,predicate:t?Ant[i](r,Cr(t)):null}):br(n)&&n.update(t)}query(t=[]){let{from:n,column:r}=this;return n?ht.from(n).select({list:r}).distinct().where(t):null}queryResult(t){return this.data=t,this}update(){let t=document.createElement("datalist"),n=`${this.id}_list`;t.setAttribute("id",n);for(let r of this.data){let i=document.createElement("option");i.setAttribute("value",r.list),t.append(i)}return this.datalist&&this.datalist.remove(),this.element.appendChild(this.datalist=t),this.searchbox.setAttribute("list",n),this}};var Ent=0;var Wy=class extends ur{constructor({element:t,filterBy:n,as:r,min:i,max:o,step:s,from:a,column:c,label:l=c,value:u=r?.value,width:f}={}){if(super(n),this.id="slider_"+ ++Ent,this.from=a,this.column=c||"value",this.selection=r,this.min=i,this.max=o,this.step=s,this.element=t||document.createElement("div"),this.element.setAttribute("class","input"),this.element.value=this,l){let d=document.createElement("label");d.setAttribute("for",this.id),d.innerText=l,this.element.appendChild(d)}this.slider=document.createElement("input"),this.slider.setAttribute("id",this.id),this.slider.setAttribute("type","range"),f!=null&&(this.slider.style.width=`${+f}px`),i!=null&&this.slider.setAttribute("min",i),o!=null&&this.slider.setAttribute("max",o),s!=null&&this.slider.setAttribute("step",s),u!=null&&(this.slider.setAttribute("value",u),this.selection?.value===void 0&&this.publish(u)),this.element.appendChild(this.slider),this.selection&&(this.slider.addEventListener("input",()=>{this.publish(+this.slider.value)}),ri(this.selection)||this.selection.addEventListener("value",d=>{d!==+this.slider.value&&(this.slider.value=d)}))}query(t=[]){let{from:n,column:r}=this;return!n||this.min!=null&&this.max!=null?null:ht.select({min:ei(r),max:ti(r)}).from(n).where(t)}queryResult(t){let{min:n,max:r}=Array.from(t)[0];return this.min==null&&this.slider.setAttribute("min",n),this.max==null&&this.slider.setAttribute("max",r),this.step==null&&this.slider.setAttribute("step",(r-n)/500),this}publish(t){let{selection:n,column:r}=this;ri(n)?n.update({source:this,schema:{type:"point"},value:t,predicate:_s(r,Cr(t))}):br(this.selection)&&n.update(t)}};var W3=Z3(e=>{let t=zv(e);return n=>n==null?"":typeof n=="number"?t(n):n instanceof Date?H3(n):`${n}`}),zv=Z3(e=>t=>t===0?"0":t.toLocaleString(e)),Ujt=W3(),zjt=zv();function H3(e){return bf(e,"Invalid Date")}function Z3(e){let t=Z3,n;return(r="en")=>r===t?n:n=e(t=r)}var Nnt=-1;var Hy=class extends ur{constructor({element:t,filterBy:n,from:r,columns:i=["*"],align:o={},format:s,width:a,maxWidth:c,height:l=500,rowBatch:u=100}={}){super(n),this.id=`table-${++Nnt}`,this.from=r,this.columns=i,this.format=s,this.align=o,this.widths=typeof a=="object"?a:{},this.offset=0,this.limit=+u,this.pending=!1,this.sortHeader=null,this.sortColumn=null,this.sortDesc=!1,this.element=t||document.createElement("div"),this.element.setAttribute("id",this.id),this.element.value=this,typeof a=="number"&&(this.element.style.width=`${a}px`),c&&(this.element.style.maxWidth=`${c}px`),this.element.style.maxHeight=`${l}px`,this.element.style.overflow="auto";let f=-1;this.element.addEventListener("scroll",d=>{let{pending:h,loaded:p}=this,{scrollHeight:m,scrollTop:g,clientHeight:y}=d.target,x=g<f;f=g,!(x||h||p)&&m-g<2*y&&(this.pending=!0,this.requestData(this.offset+this.limit))}),this.tbl=document.createElement("table"),this.element.appendChild(this.tbl),this.head=document.createElement("thead"),this.tbl.appendChild(this.head),this.body=document.createElement("tbody"),this.tbl.appendChild(this.body),this.style=document.createElement("style"),this.element.appendChild(this.style)}requestData(t=0){this.offset=t;let n=this.query(this.filterBy?.predicate(this));this.requestQuery(n),ni().prefetch(n.clone().offset(t+this.limit))}fields(){return this.columns.map(t=>Ia(this.from,t))}fieldInfo(t){this.schema=t;let n=this.head;n.innerHTML="";let r=document.createElement("tr");for(let{column:i}of t){let o=document.createElement("th");o.addEventListener("click",s=>this.sort(s,i)),o.appendChild(document.createElement("span")),o.appendChild(document.createTextNode(i)),r.appendChild(o)}return n.appendChild(r),this.formats=Dnt(this.format,t),this.style.innerText=Lnt(this.id,Ont(this.align,t),Bnt(this.widths,t)),this}query(t=[]){let{from:n,limit:r,offset:i,schema:o,sortColumn:s,sortDesc:a}=this;return ht.from(n).select(o.map(c=>c.column)).where(t).orderby(s?a?A2(s):s:[]).limit(r).offset(i)}queryResult(t){return this.pending||(this.loaded=!1,this.body.replaceChildren()),this.data=t,this}update(){let{body:t,formats:n,data:r,schema:i,limit:o}=this,s=i.length,a=0;for(let c of r){++a;let l=document.createElement("tr");for(let u=0;u<s;++u){let f=c[i[u].column],d=document.createElement("td");d.innerText=f==null?"":n[u](f),l.appendChild(d)}t.appendChild(l)}return a<o&&(this.loaded=!0),this.pending=!1,this}sort(t,n){n===this.sortColumn?this.sortDesc=!this.sortDesc:(this.sortColumn=n,this.sortDesc=!1);let r=t.currentTarget,i=this.sortHeader;i===r&&t.metaKey?(i.firstChild.textContent="",this.sortHeader=null,this.sortColumn=null):(i&&(i.firstChild.textContent=""),this.sortHeader=r,r.firstChild.textContent=this.sortDesc?"\u25BE":"\u25B4"),this.requestData()}};function Dnt(e={},t,n){return t.map(({column:r,type:i})=>{if(r in e)return e[r];switch(i){case"number":return zv(n);case"date":return H3;default:return W3(n)}})}function Ont(e={},t){return t.map(({column:n,type:r})=>n in e?e[n]:r==="number"?"right":"left")}function Bnt(e={},t){return t.map(({column:n})=>e[n])}function Lnt(e,t,n){let r=[];return t.forEach((i,o)=>{let s=+n[o];if(i!=="left"||s){let a=i!=="left"?`text-align:${i};`:"",c=s?`width:${s}px;max-width:${s}px;`:"";r.push(`#${e} tr>:nth-child(${o+1}) {${a}${c}}`)}}),r.join(" ")}function Zy(e,...t){let n=e?.context?.coordinator??ni();for(let r of t)n.connect(r)}function qv(e,t,n){let r=new t(n);return Zy(e,r),r.element}function oU(e){return qv(this,Xy,e)}function sU(e){return qv(this,Gy,e)}function aU(e){return qv(this,Wy,e)}function cU(e){return qv(this,Hy,e)}function lU({direction:e="vertical",wrap:t=!1},n){let r=document.createElement("div");return r.style.display="flex",r.style.flexDirection=e==="vertical"?"column":"row",r.style.flexWrap=t?t===!0?"wrap":t:"nowrap",r.style.justifyContent="flex-start",r.style.alignItems="flex-start",n.forEach(i=>r.appendChild(i)),r.value={element:r},r}function uU(...e){return lU({direction:"vertical"},e.flat())}function fU(...e){return lU({direction:"horizontal"},e.flat())}function dU({dim:e="width",size:t=10}){let n=document.createElement("span");n.style.display="inline-block",n.style[e]=Number.isNaN(+t)?t:`${t}px`;let r={element:n};return n.value=r,n}function hU(e){return dU({dim:"height",size:e})}function pU(e){return dU({dim:"width",size:e})}var jv={};Ir(jv,{align:()=>f6,aspectRatio:()=>d6,axis:()=>h6,colorBase:()=>QE,colorClamp:()=>zE,colorConstant:()=>t8,colorDomain:()=>PE,colorExponent:()=>KE,colorInterpolate:()=>YE,colorLabel:()=>WE,colorN:()=>qE,colorNice:()=>jE,colorPivot:()=>XE,colorRange:()=>UE,colorReverse:()=>HE,colorScale:()=>$E,colorScheme:()=>VE,colorSymmetric:()=>GE,colorTickFormat:()=>JE,colorZero:()=>ZE,facetGrid:()=>F4,facetLabel:()=>R4,facetMargin:()=>O4,facetMarginBottom:()=>L4,facetMarginLeft:()=>C4,facetMarginRight:()=>k4,facetMarginTop:()=>B4,fxAlign:()=>Y4,fxAriaDescription:()=>lE,fxAriaLabel:()=>cE,fxAxis:()=>H4,fxDomain:()=>$4,fxFontVariant:()=>aE,fxGrid:()=>nE,fxInset:()=>z4,fxInsetLeft:()=>q4,fxInsetRight:()=>j4,fxLabel:()=>iE,fxLabelAnchor:()=>oE,fxLabelOffset:()=>sE,fxLine:()=>rE,fxNice:()=>U4,fxPadding:()=>X4,fxPaddingInner:()=>G4,fxPaddingOuter:()=>W4,fxRange:()=>P4,fxReverse:()=>uE,fxRound:()=>V4,fxTickFormat:()=>tE,fxTickPadding:()=>K4,fxTickRotate:()=>eE,fxTickSize:()=>J4,fxTickSpacing:()=>Q4,fxTicks:()=>Z4,fyAlign:()=>xE,fyAriaDescription:()=>FE,fyAriaLabel:()=>kE,fyAxis:()=>_E,fyDomain:()=>fE,fyFontVariant:()=>CE,fyGrid:()=>NE,fyInset:()=>pE,fyInsetBottom:()=>yE,fyInsetTop:()=>mE,fyLabel:()=>OE,fyLabelAnchor:()=>BE,fyLabelOffset:()=>LE,fyLine:()=>DE,fyNice:()=>hE,fyPadding:()=>bE,fyPaddingInner:()=>wE,fyPaddingOuter:()=>vE,fyRange:()=>dE,fyReverse:()=>RE,fyRound:()=>gE,fyTickFormat:()=>TE,fyTickPadding:()=>AE,fyTickRotate:()=>EE,fyTickSize:()=>IE,fyTickSpacing:()=>ME,fyTicks:()=>SE,grid:()=>m6,height:()=>s6,inset:()=>p6,label:()=>y6,lengthBase:()=>E8,lengthClamp:()=>M8,lengthConstant:()=>D8,lengthDomain:()=>S8,lengthExponent:()=>N8,lengthNice:()=>A8,lengthRange:()=>I8,lengthScale:()=>_8,lengthZero:()=>T8,margin:()=>n6,marginBottom:()=>u6,marginLeft:()=>a6,marginRight:()=>c6,marginTop:()=>l6,margins:()=>e6,name:()=>K3,opacityBase:()=>u8,opacityClamp:()=>i8,opacityConstant:()=>d8,opacityDomain:()=>n8,opacityExponent:()=>f8,opacityLabel:()=>s8,opacityNice:()=>o8,opacityRange:()=>r8,opacityReverse:()=>a8,opacityScale:()=>e8,opacityTickFormat:()=>l8,opacityZero:()=>c8,padding:()=>g6,projectionClip:()=>z8,projectionDomain:()=>k8,projectionInset:()=>F8,projectionInsetBottom:()=>U8,projectionInsetLeft:()=>R8,projectionInsetRight:()=>$8,projectionInsetTop:()=>P8,projectionParallels:()=>B8,projectionPrecision:()=>L8,projectionRotate:()=>C8,projectionType:()=>O8,rBase:()=>b8,rClamp:()=>y8,rConstant:()=>v8,rDomain:()=>p8,rExponent:()=>w8,rNice:()=>g8,rRange:()=>m8,rScale:()=>h8,rZero:()=>x8,round:()=>x6,style:()=>i6,width:()=>o6,xAlign:()=>E6,xAriaDescription:()=>X6,xAriaLabel:()=>Y6,xAxis:()=>B6,xBase:()=>H6,xClamp:()=>A6,xConstant:()=>J6,xDomain:()=>w6,xExponent:()=>Z6,xFontVariant:()=>V6,xGrid:()=>P6,xInset:()=>S6,xInsetLeft:()=>I6,xInsetRight:()=>M6,xLabel:()=>z6,xLabelAnchor:()=>q6,xLabelOffset:()=>j6,xLine:()=>U6,xNice:()=>_6,xPadding:()=>N6,xPaddingInner:()=>D6,xPaddingOuter:()=>O6,xRange:()=>v6,xReverse:()=>G6,xRound:()=>T6,xScale:()=>b6,xTickFormat:()=>R6,xTickPadding:()=>F6,xTickRotate:()=>$6,xTickSize:()=>C6,xTickSpacing:()=>k6,xTicks:()=>L6,xZero:()=>W6,xyDomain:()=>r6,yAlign:()=>a4,yAriaDescription:()=>M4,yAriaLabel:()=>I4,yAxis:()=>f4,yBase:()=>E4,yClamp:()=>o4,yConstant:()=>D4,yDomain:()=>K6,yExponent:()=>N4,yFontVariant:()=>S4,yGrid:()=>x4,yInset:()=>n4,yInsetBottom:()=>i4,yInsetTop:()=>r4,yLabel:()=>w4,yLabelAnchor:()=>v4,yLabelOffset:()=>_4,yLine:()=>b4,yNice:()=>e4,yPadding:()=>c4,yPaddingInner:()=>l4,yPaddingOuter:()=>u4,yRange:()=>t4,yReverse:()=>A4,yRound:()=>s4,yScale:()=>Q6,yTickFormat:()=>y4,yTickPadding:()=>m4,yTickRotate:()=>g4,yTickSize:()=>h4,yTickSpacing:()=>p4,yTicks:()=>d4,yZero:()=>T4});var Jy=class extends Map{request(t,n){if(this.has(t))n(this.get(t));else{let r=this.waiting||(this.waiting=new Map),i=r.get(t)||[];r.set(t,i.concat(n))}}set(t,n){this.has(t)&&console.warn(`Overwriting named plot "${t}".`);let{waiting:r}=this;return r?.has(t)&&(r.get(t).forEach(i=>i(n)),r.delete(t)),super.set(t,n)}},J3=new Jy;function Q3(e,t,n){(e?.context?.namedPlots??J3).request(t,n)}function mU(e,t,n){(e?.context?.namedPlots??J3).set(t,n)}function K3(e){return t=>mU(this,e,t)}function yU(e,t,n){br(n)?(n.addEventListener("value",r=>{e.setAttribute(t,r),e.update()}),n.value!==void 0&&e.setAttribute(t,n.value)):e.setAttribute(t,n)}function Cnt(e,t){return n=>{yU(n,e,t)}}function t6(e){return t=>{for(let[n,r]of Object.entries(e))yU(t,n,r)}}function e6(e){let{top:t,bottom:n,left:r,right:i}=e,o={};return t!==void 0&&(o.marginTop=t),n!==void 0&&(o.marginBottom=n),r!==void 0&&(o.marginLeft=r),i!==void 0&&(o.marginRight=i),t6(o)}function n6(e){return t6({marginTop:e,marginBottom:e,marginLeft:e,marginRight:e})}function r6(e){return t6({xDomain:e,yDomain:e})}var L=e=>t=>Cnt(e,t),i6=L("style"),o6=L("width"),s6=L("height"),a6=L("marginLeft"),c6=L("marginRight"),l6=L("marginTop"),u6=L("marginBottom"),f6=L("align"),d6=L("aspectRatio"),h6=L("axis"),p6=L("inset"),m6=L("grid"),y6=L("label"),g6=L("padding"),x6=L("round"),b6=L("xScale"),w6=L("xDomain"),v6=L("xRange"),_6=L("xNice"),S6=L("xInset"),I6=L("xInsetLeft"),M6=L("xInsetRight"),A6=L("xClamp"),T6=L("xRound"),E6=L("xAlign"),N6=L("xPadding"),D6=L("xPaddingInner"),O6=L("xPaddingOuter"),B6=L("xAxis"),L6=L("xTicks"),C6=L("xTickSize"),k6=L("xTickSpacing"),F6=L("xTickPadding"),R6=L("xTickFormat"),$6=L("xTickRotate"),P6=L("xGrid"),U6=L("xLine"),z6=L("xLabel"),q6=L("xLabelAnchor"),j6=L("xLabelOffset"),V6=L("xFontVariant"),Y6=L("xAriaLabel"),X6=L("xAriaDescription"),G6=L("xReverse"),W6=L("xZero"),H6=L("xBase"),Z6=L("xExponent"),J6=L("xConstant"),Q6=L("yScale"),K6=L("yDomain"),t4=L("yRange"),e4=L("yNice"),n4=L("yInset"),r4=L("yInsetTop"),i4=L("yInsetBottom"),o4=L("yClamp"),s4=L("yRound"),a4=L("yAlign"),c4=L("yPadding"),l4=L("yPaddingInner"),u4=L("yPaddingOuter"),f4=L("yAxis"),d4=L("yTicks"),h4=L("yTickSize"),p4=L("yTickSpacing"),m4=L("yTickPadding"),y4=L("yTickFormat"),g4=L("yTickRotate"),x4=L("yGrid"),b4=L("yLine"),w4=L("yLabel"),v4=L("yLabelAnchor"),_4=L("yLabelOffset"),S4=L("yFontVariant"),I4=L("yAriaLabel"),M4=L("yAriaDescription"),A4=L("yReverse"),T4=L("yZero"),E4=L("yBase"),N4=L("yExponent"),D4=L("yConstant"),O4=L("facetMargin"),B4=L("facetMarginTop"),L4=L("facetMarginBottom"),C4=L("facetMarginLeft"),k4=L("facetMarginRight"),F4=L("facetGrid"),R4=L("facetLabel"),$4=L("fxDomain"),P4=L("fxRange"),U4=L("fxNice"),z4=L("fxInset"),q4=L("fxInsetLeft"),j4=L("fxInsetRight"),V4=L("fxRound"),Y4=L("fxAlign"),X4=L("fxPadding"),G4=L("fxPaddingInner"),W4=L("fxPaddingOuter"),H4=L("fxAxis"),Z4=L("fxTicks"),J4=L("fxTickSize"),Q4=L("fxTickSpacing"),K4=L("fxTickPadding"),tE=L("fxTickFormat"),eE=L("fxTickRotate"),nE=L("fxGrid"),rE=L("fxLine"),iE=L("fxLabel"),oE=L("fxLabelAnchor"),sE=L("fxLabelOffset"),aE=L("fxFontVariant"),cE=L("fxAriaLabel"),lE=L("fxAriaDescription"),uE=L("fxReverse"),fE=L("fyDomain"),dE=L("fyRange"),hE=L("fyNice"),pE=L("fyInset"),mE=L("fyInsetTop"),yE=L("fyInsetBottom"),gE=L("fyRound"),xE=L("fyAlign"),bE=L("fyPadding"),wE=L("fyPaddingInner"),vE=L("fyPaddingOuter"),_E=L("fyAxis"),SE=L("fyTicks"),IE=L("fyTickSize"),ME=L("fyTickSpacing"),AE=L("fyTickPadding"),TE=L("fyTickFormat"),EE=L("fyTickRotate"),NE=L("fyGrid"),DE=L("fyLine"),OE=L("fyLabel"),BE=L("fyLabelAnchor"),LE=L("fyLabelOffset"),CE=L("fyFontVariant"),kE=L("fyAriaLabel"),FE=L("fyAriaDescription"),RE=L("fyReverse"),$E=L("colorScale"),PE=L("colorDomain"),UE=L("colorRange"),zE=L("colorClamp"),qE=L("colorN"),jE=L("colorNice"),VE=L("colorScheme"),YE=L("colorInterpolate"),XE=L("colorPivot"),GE=L("colorSymmetric"),WE=L("colorLabel"),HE=L("colorReverse"),ZE=L("colorZero"),JE=L("colorTickFormat"),QE=L("colorBase"),KE=L("colorExponent"),t8=L("colorConstant"),e8=L("opacityScale"),n8=L("opacityDomain"),r8=L("opacityRange"),i8=L("opacityClamp"),o8=L("opacityNice"),s8=L("opacityLabel"),a8=L("opacityReverse"),c8=L("opacityZero"),l8=L("opacityTickFormat"),u8=L("opacityBase"),f8=L("opacityExponent"),d8=L("opacityConstant"),h8=L("rScale"),p8=L("rDomain"),m8=L("rRange"),y8=L("rClamp"),g8=L("rNice"),x8=L("rZero"),b8=L("rBase"),w8=L("rExponent"),v8=L("rConstant"),_8=L("lengthScale"),S8=L("lengthDomain"),I8=L("lengthRange"),M8=L("lengthClamp"),A8=L("lengthNice"),T8=L("lengthZero"),E8=L("lengthBase"),N8=L("lengthExponent"),D8=L("lengthConstant"),O8=L("projectionType"),B8=L("projectionParallels"),L8=L("projectionPrecision"),C8=L("projectionRotate"),k8=L("projectionDomain"),F8=L("projectionInset"),R8=L("projectionInsetLeft"),$8=L("projectionInsetRight"),P8=L("projectionInsetTop"),U8=L("projectionInsetBottom"),z8=L("projectionClip");function gU(e,t){return{table:e,options:t}}var Vv={};Ir(Vv,{area:()=>j8,areaX:()=>V8,areaY:()=>Y8,arrow:()=>FN,axisFx:()=>zN,axisFy:()=>qN,axisX:()=>PN,axisY:()=>UN,barX:()=>H8,barY:()=>Z8,cell:()=>J8,cellX:()=>Q8,cellY:()=>K8,circle:()=>sN,contour:()=>IN,delaunayLink:()=>LN,delaunayMesh:()=>CN,denseLine:()=>SN,density:()=>_N,densityX:()=>wN,densityY:()=>vN,dot:()=>rN,dotX:()=>iN,dotY:()=>oN,frame:()=>$N,geo:()=>GN,graticule:()=>HN,gridFx:()=>YN,gridFy:()=>XN,gridX:()=>jN,gridY:()=>VN,heatmap:()=>MN,hexagon:()=>aN,hexbin:()=>EN,hexgrid:()=>NN,hull:()=>kN,image:()=>bN,line:()=>X8,lineX:()=>G8,lineY:()=>W8,link:()=>RN,raster:()=>AN,rasterTile:()=>TN,rect:()=>tN,rectX:()=>eN,rectY:()=>nN,regressionY:()=>DN,ruleX:()=>fN,ruleY:()=>dN,sphere:()=>WN,spike:()=>xN,text:()=>cN,textX:()=>lN,textY:()=>uN,tickX:()=>hN,tickY:()=>pN,vector:()=>mN,vectorX:()=>yN,vectorY:()=>gN,voronoi:()=>ON,voronoiMesh:()=>BN});var knt=new Set(["frame","axisX","axisY","axisFx","axisFy","gridX","gridY","gridFx","gridFy","hexgrid","graticule","sphere"]);function At(e,t,n={}){arguments.length===2&&!Array.isArray(t)&&(n=t,t=knt.has(e)?null:[{}]);let r=e.startsWith("area")||e.startsWith("line")?Ny:Bn;return q8(r,e,t,n)}function q8(e,t,n,r){return i=>{i.addMark(new e(t,n,r))}}function ua(e,t,n){return r=>{r.addMark(new e(t,n))}}var j8=(...e)=>At("area",...e),V8=(...e)=>At("areaX",...e),Y8=(...e)=>At("areaY",...e),X8=(...e)=>At("line",...e),G8=(...e)=>At("lineX",...e),W8=(...e)=>At("lineY",...e),H8=(...e)=>At("barX",...e),Z8=(...e)=>At("barY",...e),J8=(...e)=>At("cell",...e),Q8=(...e)=>At("cellX",...e),K8=(...e)=>At("cellY",...e),tN=(...e)=>At("rect",...e),eN=(...e)=>At("rectX",...e),nN=(...e)=>At("rectY",...e),rN=(...e)=>At("dot",...e),iN=(...e)=>At("dotX",...e),oN=(...e)=>At("dotY",...e),sN=(...e)=>At("circle",...e),aN=(...e)=>At("hexagon",...e),cN=(...e)=>At("text",...e),lN=(...e)=>At("textX",...e),uN=(...e)=>At("textY",...e),fN=(...e)=>At("ruleX",...e),dN=(...e)=>At("ruleY",...e),hN=(...e)=>At("tickX",...e),pN=(...e)=>At("tickY",...e),mN=(...e)=>At("vector",...e),yN=(...e)=>At("vectoX",...e),gN=(...e)=>At("vectorY",...e),xN=(...e)=>At("spike",...e),bN=(...e)=>At("image",...e),wN=(...e)=>q8(gd,"areaX",...e),vN=(...e)=>q8(gd,"areaY",...e),_N=(...e)=>ua(Fy,...e),SN=(...e)=>ua(ky,...e),IN=(...e)=>ua(Ly,...e),MN=(...e)=>ua(Cy,...e),AN=(...e)=>ua(yc,...e),TN=(...e)=>ua(Py,...e),EN=(...e)=>ua($y,...e),NN=(...e)=>At("hexgrid",...e),DN=(...e)=>ua(Uy,...e),ON=(...e)=>At("voronoi",...e),BN=(...e)=>At("voronoiMesh",...e),LN=(...e)=>At("delaunayLink",...e),CN=(...e)=>At("delaunayMesh",...e),kN=(...e)=>At("hull",...e),FN=(...e)=>At("arrow",...e),RN=(...e)=>At("link",...e),$N=(...e)=>At("frame",...e),PN=(...e)=>At("axisX",...e),UN=(...e)=>At("axisY",...e),zN=(...e)=>At("axisFx",...e),qN=(...e)=>At("axisFy",...e),jN=(...e)=>At("gridX",...e),VN=(...e)=>At("gridY",...e),YN=(...e)=>At("gridFx",...e),XN=(...e)=>At("gridFy",...e),GN=(...e)=>ua(Ry,...e),WN=(...e)=>At("sphere",...e),HN=(...e)=>At("graticule",...e);var Yv={};Ir(Yv,{highlight:()=>ZN,intervalX:()=>nD,intervalXY:()=>iD,intervalY:()=>rD,nearestX:()=>tD,nearestY:()=>eD,pan:()=>oD,panX:()=>sD,panY:()=>aD,panZoom:()=>cD,panZoomX:()=>lD,panZoomY:()=>uD,toggle:()=>Sd,toggleColor:()=>KN,toggleX:()=>JN,toggleY:()=>QN});function gc(e,t){return n=>{let r=n.marks[n.marks.length-1];n.addInteractor(new e(r,t))}}function ZN({by:e,...t}){return gc(zy,{selection:e,channels:t})}function Sd({as:e,...t}){return gc(jl,{...t,selection:e})}function JN(e){return Sd({...e,channels:["x"]})}function QN(e){return Sd({...e,channels:["y"]})}function KN(e){return Sd({...e,channels:["color"]})}function tD({as:e,...t}){return gc(vd,{...t,selection:e,channel:"x"})}function eD({as:e,...t}){return gc(vd,{...t,selection:e,channel:"y"})}function nD({as:e,...t}){return gc(wd,{...t,selection:e,channel:"x"})}function rD({as:e,...t}){return gc(wd,{...t,selection:e,channel:"y"})}function iD({as:e,...t}){return gc(Vy,{...t,selection:e})}function Id(e){return gc(Yy,e)}function oD(e={}){return Id({...e,zoom:!1})}function sD(e={}){return Id({...e,zoom:!1,pany:!1})}function aD(e={}){return Id({...e,zoom:!1,panx:!1})}function cD(e={}){return Id(e)}function lD(e={}){return Id({...e,pany:!1})}function uD(e={}){return Id({...e,panx:!1})}var Xv={};Ir(Xv,{colorLegend:()=>dD,opacityLegend:()=>hD,symbolLegend:()=>pD});function fD(e,t={}){if(t.for){let{for:n,...r}=t,i=new _d(e,r),o=typeof n,s=a=>a.addLegend(i,!1);return o==="string"?Q3(this,n,s):n.value&&s(n.value),i.element}else return n=>n.addLegend(new _d(e,t))}function dD(e){return fD.call(this,"color",e)}function hD(e){return fD.call(this,"opacity",e)}function pD(e){return fD.call(this,"symbol",e)}function xU(...e){let t=new Ey;return e.flat().forEach(n=>n(t)),Zy(this,...t.marks),t.element}function yD({coordinator:e=ni(),namedPlots:t=new Jy,extensions:n=null,...r}={}){return{...mD,...n,context:{coordinator:e,namedPlots:t,...r}}}var bU="spec",Gv="literal",qVt="dataref",wU="options",vU="selection",_U="paramref",SU="param",gD="select",Wv="value",IU="crossfilter",Hv="intersect",MU="union",AU="single",TU="data",EU="expression",xc="sql",fa="agg",Qy="input",Md="hconcat",Ad="vconcat",Td="hspace",Ed="vspace",Zv="mark",xD="from",Nd="plot",Ky="legend",NU="attribute",DU="transform",OU="interactor",tg="Fixed";var $t=class{constructor(t,n=null){this.type=t,this.children=n}instantiate(){throw Error("instantiate not implemented")}codegen(){return Error("codegen not implemented")}toJSON(){return Error("toJSON not implemented")}};var eg=class extends $t{constructor(t,n,r,i,o,s){super(bU,[t]),this.root=t,this.meta=n,this.config=r,this.data=i,this.params=o,this.plotDefaults=s}toJSON(){let{root:t,meta:n,config:r,plotDefaults:i}=this,o=new Map(Object.entries(this.data)),s=new Map(Object.entries(this.params)),a={};if(n&&(a.meta={...n}),r&&(a.config={...r}),o?.size){let c=a.data={};for(let[l,u]of o)c[l]=u.toJSON()}if(s?.size){let c=a.params={};for(let[l,u]of s)c[l]=u.toJSON()}if(i?.length){let c=a.plotDefaults={};for(let l of i)Object.assign(c,l.toJSON())}return Object.assign(a,t.toJSON())}};function BU(e){let t=typeof e;return t==="object"?e?.param:t==="string"?Fnt(e):null}function Fnt(e){return e?.[0]==="$"?e.slice(1):null}function ng(e){return`$${e}`}function LU(e){return[e].flat()}function xi(e){return Array.isArray(e)}function Dd(e){return e!==null&&typeof e=="object"&&!xi(e)}function Go(e){return typeof e=="string"}function Od(e,t){throw Object.assign(Error(e),{data:t})}function _r(e,t){let n={};for(let r in e)n[r]=t.maybeSelection(e[r]);return new Bd(n)}var Bd=class e extends $t{constructor(t){super(wU),this.options=t}filter(t){let n=Object.fromEntries(Object.entries(this.options).filter(([r,i])=>t(r,i)));return new e(n)}instantiate(t){let{options:n}=this,r={};for(let i in n)r[i]=n[i].instantiate(t);return r}codegen(t){let{options:n}=this,r=[];for(let i in n)r.push(`${i}: ${n[i].codegen(t)}`);return r.length?`{${t.maybeLineWrap(r)}}`:""}toJSON(){let{options:t}=this,n={};for(let r in t)n[r]=t[r].toJSON();return n}};var FU="table",RU="parquet",$U="csv",bD="json",i_="spatial",CU=new Map([[FU,Rnt],[RU,$nt],[$U,Pnt],[bD,Unt],[i_,znt]]);function PU(e,t,n){if(t=qnt(t),CU.has(t.type))return CU.get(t.type)(e,t,n);n.error("Unrecognized data format type.",t)}function Rnt(e,t,n){let{query:r,type:i,...o}=t;return new Qv(e,r,_r(o,n))}function $nt(e,t,n){let{file:r,type:i,...o}=t;return new t_(e,r,_r(o,n))}function Pnt(e,t,n){let{file:r,type:i,...o}=t;return new e_(e,r,_r(o,n))}function Unt(e,t,n){let{data:r,file:i,type:o,...s}=t,a=_r(s,n);return r?new r_(e,r,a):new n_(e,i,a)}function znt(e,t,n){let{file:r,type:i,...o}=t;return new Kv(e,r,_r(o,n))}function qnt(e){return xi(e)&&(e={type:"json",data:e}),Go(e)&&(e={type:"table",query:e}),{...e,type:jnt(e)}}function jnt(e){return e.type||Vnt(e.file)||"table"}function Vnt(e){let t=e?.lastIndexOf(".");return t>0?e.slice(t+1):null}function kU(e,t){return t?new URL(e,t).toString():e}function Ynt(e,t){let n=e?.codegen(t);return n?`, ${n}`:""}var Jv=class extends $t{constructor(t,n){super(TU),this.name=t,this.format=n}},Ld=class extends Jv{constructor(t,n){super(t,n)}instantiateQuery(t){t.error("instantiateQuery not implemented")}codegenQuery(t){t.error("codegenQuery not implemented")}instantiate(t){let n=this.instantiateQuery(t);if(n)return n}codegen(t){let n=this.codegenQuery(t);if(n)return n}},Qv=class extends Ld{constructor(t,n,r){super(t,FU),this.query=n?.trim(),this.options=r}instantiateQuery(t){let{name:n,query:r,options:i}=this;if(r)return t.api.create(n,r,i.instantiate(t))}codegenQuery(t){let{name:n,query:r,options:i}=this;if(r)return`\`${ao(n,r,i.instantiate(t))}\``}toJSON(){let{format:t,query:n,options:r}=this;return{type:t,query:n,...r.toJSON()}}},Vl=class extends Ld{constructor(t,n,r,i,o){super(t,n),this.file=i,this.method=r,this.options=o}instantiateQuery(t){let{name:n,method:r,file:i,options:o}=this,s=kU(i,t.baseURL),a=o?.instantiate(t);return t.api[r](n,s,a)}codegenQuery(t){let{name:n,method:r,file:i,options:o}=this,s=kU(i,t.baseURL),a=Ynt(o,t);return`${t.ns()}${r}("${n}", "${s}"${a})`}toJSON(){let{format:t,file:n,options:r}=this;return{type:t,file:n,...r.toJSON()}}},Kv=class extends Vl{constructor(t,n,r){super(t,i_,"loadSpatial",n,r)}},t_=class extends Vl{constructor(t,n,r){super(t,RU,"loadParquet",n,r)}},e_=class extends Vl{constructor(t,n,r){super(t,$U,"loadCSV",n,r)}},n_=class extends Vl{constructor(t,n,r){super(t,bD,"loadJSON",n,r)}},r_=class extends Ld{constructor(t,n,r){super(t,bD),this.data=n,this.options=r}instantiateQuery(t){let{name:n,data:r,options:i}=this;return t.api.loadObjects(n,r,i.instantiate(t))}codegenQuery(t){let{name:n,data:r,options:i}=this,o=i?","+i.codegen(t):"",s=`[
|
|
69
|
+
}`)).call(Uf,n);for(let k of l){let{channels:$,values:P,facets:U}=m.get(k);if(p===void 0||k.facet==="super"){let W=null;if(U&&(W=U[0],W=k.filter(W,$,P),W.length===0))continue;let nt=k.render(W,x,P,v,M);if(nt==null)continue;I.appendChild(nt)}else{let W;for(let nt of p){if(!(k.facetAnchor?.(p,O,nt)??!nt.empty))continue;let ot=null;if(U){let Y=f.has(k);if(ot=U[Y?nt.i:0],ot=k.filter(ot,$,P),ot.length===0)continue;!Y&&ot===U[0]&&(ot=Hs(ot)),ot.fx=nt.x,ot.fy=nt.y,ot.fi=nt.i}let at=k.render(ot,x,P,_,M);if(at!=null){(W??=Vt(I).append("g")).append(()=>at).datum(nt);for(let Y of["aria-label","aria-description","aria-hidden","transform"])at.hasAttribute(Y)&&(W.attr(Y,at.getAttribute(Y)),at.removeAttribute(Y))}}W?.selectChildren().attr("transform",C)}}let N=S$(y,M,e),{figure:F=r!=null||i!=null||o!=null||N.length>0}=e;F&&(D=E.createElement("figure"),D.className=`${c}-figure`,D.style.maxWidth="initial",r!=null&&D.append(T$(E,r,"h2")),i!=null&&D.append(T$(E,i,"h3")),D.append(...N,I),o!=null&&D.append(gK(E,o))),D.scale=b7(x.scales),D.legend=v$(y,M,e);let R=MR();return R>0&&Vt(I).append("text").attr("x",S).attr("y",20).attr("dy","-1em").attr("text-anchor","end").attr("font-family","initial").text("\u26A0\uFE0F").append("title").text(`${R.toLocaleString("en-US")} warning${R===1?"":"s"}. Please check the console.`),D}function T$(e,t,n){if(t.ownerDocument)return t;let r=e.createElement(n);return r.append(t),r}function gK(e,t){let n=e.createElement("figcaption");return n.append(t),n}function xK({marks:e=[],...t}={}){return hy({...t,marks:[...e,this]})}St.prototype.plot=xK;function E$(e){return e.flat(1/0).filter(t=>t!=null).map(bK)}function bK(e){return typeof e.render=="function"?e:new KT(e)}var KT=class extends St{constructor(t){if(typeof t!="function")throw new TypeError("invalid mark; missing render function");super(),this.render=t}render(){}};function t3(e,t){for(let n in e)B$(e[n],t);return e}function B$(e,t){let{scale:n,transform:r=!0}=e;if(n==null||!r)return;let{type:i,percent:o,interval:s,transform:a=o?c=>c*100:eT(s,i)}=t[n]??{};a!=null&&(e.value=Gt(e.value,a),e.transform=!1)}function wK(e){for(let t in e)yT(t,e[t])}function fy(e,t,n,r=WF){for(let{channels:i}of t.values())for(let o in i){let s=i[o],{scale:a}=s;if(a!=null&&r(a))if(a==="projection"){if(!OR(n)){let c=n.x?.domain===void 0,l=n.y?.domain===void 0;if(c||l){let[u,f]=LR(s);c&&QT(e,"x",u),l&&QT(e,"y",f)}}}else QT(e,a,s)}return e}function QT(e,t,n){let r=e.get(t);r!==void 0?r.push(n):e.set(t,[n])}function vK(e,t){if(e==null)return;let{x:n,y:r}=e;if(n==null&&r==null)return;let i=je(e.data);if(i==null)throw new Error("missing facet data");let o={};n!=null&&(o.fx=Bf(i,{value:n,scale:"fx"})),r!=null&&(o.fy=Bf(i,{value:r,scale:"fy"})),t3(o,t);let s=Cw(i,o);return{channels:o,groups:s,data:e.data}}function N$(e,t,n){if(e.facet===null||e.facet==="super")return;let{fx:r,fy:i}=e;if(r!=null||i!=null){let c=je(e.data??r??i);if(c===void 0)throw new Error(`missing facet data in ${e.ariaLabel}`);if(c===null)return;let l={};return r!=null&&(l.fx=Bf(c,{value:r,scale:"fx"})),i!=null&&(l.fy=Bf(c,{value:i,scale:"fy"})),t3(l,n),{channels:l,groups:Cw(c,l)}}if(t===void 0)return;let{channels:o,groups:s,data:a}=t;if(e.facet!=="auto"||e.data===a)return{channels:o,groups:s};a.length>0&&(s.size>1||s.size===1&&o.fx&&o.fy&&[...s][0][1].size>1)&&je(e.data)?.length===a.length&&Vn(`Warning: the ${e.ariaLabel} mark appears to use faceted data, but isn\u2019t faceted. The mark data has the same length as the facet data and the mark facet option is "auto", but the mark data and facet data are distinct. If this mark should be faceted, set the mark facet option to true; otherwise, suppress this warning by setting the mark facet option to false.`)}function _K(e,t={}){return Ie({...t,x:null,y:null},(n,r,i,o,s,a)=>a.getMarkState(e))}function SK(e){let t=[];for(let n of e){let r=n.tip;if(r){r===!0?r={}:typeof r=="string"&&(r={pointer:r});let{pointer:i,preferredAnchor:o}=r;i=/^x$/i.test(i)?jf:/^y$/i.test(i)?Dl:qf,r=i(_K(n,r)),r.title=null,o===void 0&&(r.preferredAnchor=i===Dl?"left":"bottom");let s=iv(n.data,r);s.facet=n.facet,s.facetAnchor=n.facetAnchor,t.push(s)}}return t}function IK(e,t,n){let{projection:r,x:i={},y:o={},fx:s={},fy:a={},axis:c,grid:l,facet:u={},facet:{axis:f=c,grid:h}=u,x:{axis:d=c,grid:p=d===null?null:l}=i,y:{axis:m=c,grid:y=m===null?null:l}=o,fx:{axis:g=f,grid:x=g===null?null:h}=s,fy:{axis:b=f,grid:w=b===null?null:h}=a}=n;(r||!qo(i)&&!D$("x",e))&&(d=p=null),(r||!qo(o)&&!D$("y",e))&&(m=y=null),t.has("fx")||(g=x=null),t.has("fy")||(b=w=null),d===void 0&&(d=!av(e,"x")),m===void 0&&(m=!av(e,"y")),g===void 0&&(g=!av(e,"fx")),b===void 0&&(b=!av(e,"fy")),d===!0&&(d="bottom"),m===!0&&(m="left"),g===!0&&(g=d==="top"||d===null?"bottom":"top"),b===!0&&(b=m==="right"||m===null?"left":"right");let _=[];return sv(_,w,Kw,a),ov(_,b,Zw,"right","left",u,a),sv(_,x,ev,s),ov(_,g,Jw,"top","bottom",u,s),sv(_,y,Qw,o),ov(_,m,sy,"left","right",n,o),sv(_,p,tv,i),ov(_,d,ay,"bottom","top",n,i),_}function ov(e,t,n,r,i,o,s){if(!t)return;let a=MK(t);s=AK(a?r:t,o,s);let{line:c}=s;(n===sy||n===ay)&&c&&!Qs(c)&&e.push(Gf(TK(s))),e.push(n(s)),a&&e.push(n({...s,anchor:i,label:null}))}function sv(e,t,n,r){!t||Qs(t)||e.push(n(EK(t,r)))}function MK(e){return/^\s*both\s*$/i.test(e)}function AK(e,t,{line:n=t.line,ticks:r,tickSize:i,tickSpacing:o,tickPadding:s,tickFormat:a,tickRotate:c,fontVariant:l,ariaLabel:u,ariaDescription:f,label:h=t.label,labelAnchor:d,labelArrow:p=t.labelArrow,labelOffset:m}){return{anchor:e,line:n,ticks:r,tickSize:i,tickSpacing:o,tickPadding:s,tickFormat:a,tickRotate:c,fontVariant:l,ariaLabel:u,ariaDescription:f,label:h,labelAnchor:d,labelArrow:p,labelOffset:m}}function TK(e){let{anchor:t,line:n}=e;return{anchor:t,facetAnchor:t+"-empty",stroke:n===!0?void 0:n}}function EK(e,{stroke:t=Ja(e)?e:void 0,ticks:n=NK(e)?e:void 0,tickSpacing:r,ariaLabel:i,ariaDescription:o}){return{stroke:t,ticks:n,tickSpacing:r,ariaLabel:i,ariaDescription:o}}function NK(e){switch(typeof e){case"number":return!0;case"string":return!Ja(e)}return lr(e)||typeof e?.range=="function"}function av(e,t){let n=`${t}-axis `;return e.some(r=>r.ariaLabel?.startsWith(n))}function D$(e,t){for(let n of t)for(let r in n.channels){let{scale:i}=n.channels[r];if(i===e||i==="projection")return!0}return!1}function DK(e,t){for(let n in e){let r=e[n],i=t[n];r.label===void 0&&i&&(r.label=i.label)}return e}function OK({fx:e,fy:t},n){let{marginTop:r,marginRight:i,marginBottom:o,marginLeft:s,width:a,height:c}=Tw(n),l=e&&O$(e),u=t&&O$(t);return{marginTop:t?u[0]:r,marginRight:e?a-l[1]:i,marginBottom:t?c-u[1]:o,marginLeft:e?l[0]:s,inset:{marginTop:n.marginTop,marginRight:n.marginRight,marginBottom:n.marginBottom,marginLeft:n.marginLeft},width:a,height:c}}function O$(e){let t=e.domain(),n=e(t[0]),r=e(t[t.length-1]);return r<n&&([n,r]=[r,n]),[n,r+e.bandwidth()]}var BK=new Map([["basis",vA],["basis-closed",_A],["basis-open",SA],["bundle",IA],["bump-x",yA],["bump-y",gA],["cardinal",MA],["cardinal-closed",AA],["cardinal-open",TA],["catmull-rom",EA],["catmull-rom-closed",NA],["catmull-rom-open",DA],["linear",Ys],["linear-closed",OA],["monotone-x",LA],["monotone-y",CA],["natural",kA],["step",FA],["step-after",$A],["step-before",RA]]);function dy(e=Ys,t){if(typeof e=="function")return e;let n=BK.get(`${e}`.toLowerCase());if(!n)throw new Error(`unknown curve: ${e}`);if(t!==void 0){if("beta"in n)return n.beta(t);if("tension"in n)return n.tension(t);if("alpha"in n)return n.alpha(t)}return n}function cv(e=ac,t){return typeof e!="function"&&`${e}`.toLowerCase()==="auto"?ac:dy(e,t)}function ac(e){return Ys(e)}function Ho(e={y:"count"},t={}){[e,t]=n3(e,t);let{x:n,y:r}=t;return e3(lv(n,t,G),null,null,r,e,Ol(t))}function Zo(e={x:"count"},t={}){[e,t]=n3(e,t);let{x:n,y:r}=t;return e3(null,lv(r,t,G),n,null,e,Bl(t))}function ia(e={fill:"count"},t={}){[e,t]=n3(e,t);let{x:n,y:r}=LK(t);return e3(n,r,null,null,e,Ol(Bl(t)))}function k$(e,t,n={}){if(n?.interval==null)return n;let{reduce:r=ww}=n,i={filter:null};return n[t]!=null&&(i[t]=r),n[`${t}1`]!=null&&(i[`${t}1`]=r),n[`${t}2`]!=null&&(i[`${t}2`]=r),e(i,n)}function Wf(e={}){return k$(Ho,"y",Xi(e,"x"))}function Hf(e={}){return k$(Zo,"x",Xi(e,"y"))}function e3(e,t,n,r,{data:i=bw,filter:o=Wm,sort:s,reverse:a,...c}={},l={}){e=L$(e),t=L$(t),c=CK(c,l),i=$$(i,G),s=s==null?void 0:F$("sort",s,l),o=o==null?void 0:R$("filter",o,l),n!=null&&Xo(c,"x","x1","x2")&&(n=null),r!=null&&Xo(c,"y","y1","y2")&&(r=null);let[u,f]=On(e),[h,d]=On(e),[p,m]=On(t),[y,g]=On(t),[x,b]=n!=null?[n,"x"]:r!=null?[r,"y"]:[],[w,_]=On(x),{x:v,y:M,z:E,fill:I,stroke:D,x1:A,x2:O,y1:C,y2:S,domain:T,cumulative:N,thresholds:F,interval:R,...k}=l,[$,P]=On(E),[U]=Be(I),[W]=Be(D),[nt,ot]=On(U),[at,Y]=On(W);return{..."z"in l&&{z:$||E},..."fill"in l&&{fill:nt||I},..."stroke"in l&&{stroke:at||D},...gn(k,(st,j,Z)=>{let rt=Ml(wt(st,x),Z?.[b]),z=wt(st,E),kt=wt(st,U),ht=wt(st,W),Wt=Jm(c,{z,fill:kt,stroke:ht}),Zt=[],tt=[],ae=rt&&_([]),Ir=z&&P([]),Hi=kt&&ot([]),hz=ht&&Y([]),CD=e&&f([]),dz=e&&d([]),kD=t&&m([]),pz=t&&g([]),mz=RK(e,t,st),yz=0;for(let Zl of c)Zl.initialize(st);s&&s.initialize(st),o&&o.initialize(st);for(let Zl of j){let FD=[];for(let Jl of c)Jl.scope("facet",Zl);s&&s.scope("facet",Zl),o&&o.scope("facet",Zl);for(let[Jl,gz]of Qa(Zl,Wt))for(let[xz,gg]of Qa(gz,rt))for(let[Zi,ns]of mz(gg))if(Wt&&(ns.z=Jl),!(o&&!o.reduce(Zi,ns))){FD.push(yz++),tt.push(i.reduceIndex(Zi,st,ns)),rt&&ae.push(xz),z&&Ir.push(Wt===z?Jl:z[(Zi.length>0?Zi:gg)[0]]),kt&&Hi.push(Wt===kt?Jl:kt[(Zi.length>0?Zi:gg)[0]]),ht&&hz.push(Wt===ht?Jl:ht[(Zi.length>0?Zi:gg)[0]]),CD&&(CD.push(ns.x1),dz.push(ns.x2)),kD&&(kD.push(ns.y1),pz.push(ns.y2));for(let bz of c)bz.reduce(Zi,ns);s&&s.reduce(Zi,ns)}Zt.push(FD)}return dT(Zt,s,a),{data:tt,facets:Zt}}),...!Xo(c,"x")&&(u?{x1:u,x2:h,x:Tf(u,h)}:{x:v,x1:A,x2:O}),...!Xo(c,"y")&&(p?{y1:p,y2:y,y:Tf(p,y)}:{y:M,y1:C,y2:S}),...w&&{[b]:w},...Object.fromEntries(c.map(({name:st,output:j})=>[st,j]))}}function n3({cumulative:e,domain:t,thresholds:n,interval:r,...i},o){return[i,{cumulative:e,domain:t,thresholds:n,interval:r,...o}]}function lv(e,{cumulative:t,domain:n,thresholds:r,interval:i},o){return e={...wi(e)},e.domain===void 0&&(e.domain=n),e.cumulative===void 0&&(e.cumulative=t),e.thresholds===void 0&&(e.thresholds=r),e.interval===void 0&&(e.interval=i),e.value===void 0&&(e.value=o),e.thresholds=r3(e.thresholds,e.interval),e}function LK(e){let{x:t,y:n}=e;return t=lv(t,e),n=lv(n,e),[t.value,n.value]=Pe(t.value,n.value),{x:t,y:n}}function L$(e){if(e==null)return;let{value:t,cumulative:n,domain:r=le,thresholds:i}=e,o=s=>{let a=wt(s,t),c;if(Le(a)||FK(i)){a=Gt(a,ZA,Float64Array);let[u,f]=typeof r=="function"?r(a):r,h=typeof i=="function"&&!Za(i)?i(a,u,f):i;typeof h=="number"&&(h=ym(u,f,h)),Za(h)&&(r===le&&(u=h.floor(u),f=h.offset(h.floor(f))),h=h.range(u,h.offset(f))),c=h}else{a=Ke(a);let[u,f]=typeof r=="function"?r(a):r,h=typeof i=="function"&&!Za(i)?i(a,u,f):i;if(typeof h=="number")if(r===le){let d=Ts(u,f,h);if(isFinite(d))if(d>0){let p=Math.round(u/d),m=Math.round(f/d);p*d<=u||--p,m*d>f||++m;let y=m-p+1;h=new Float64Array(y);for(let g=0;g<y;++g)h[g]=(p+g)*d}else if(d<0){d=-d;let p=Math.round(u*d),m=Math.round(f*d);p/d<=u||--p,m/d>f||++m;let y=m-p+1;h=new Float64Array(y);for(let g=0;g<y;++g)h[g]=(p+g)/d}else h=[u];else h=[u]}else h=An(u,f,h);else Za(h)&&(r===le&&(u=h.floor(u),f=h.offset(h.floor(f))),h=h.range(u,h.offset(f)));c=h}let l=[];if(c.length===1)l.push([c[0],c[0]]);else for(let u=1;u<c.length;++u)l.push([c[u-1],c[u]]);return l.bin=(n<0?PK:n>0?$K:i3)(l,c,a),l};return o.label=Bn(t),o}function r3(e,t,n=C$){if(e===void 0)return t===void 0?n:Vo(t);if(typeof e=="string"){switch(e.toLowerCase()){case"freedman-diaconis":return ex;case"scott":return fp;case"sturges":return Ea;case"auto":return C$}return Vm(e)}return e}function CK(e,t){return fT(e,t,F$)}function F$(e,t,n){return gw(e,t,n,R$)}function R$(e,t,n){return xw(e,t,n,$$)}function $$(e,t){return Of(e,t,kK)}function kK(e){switch(`${e}`.toLowerCase()){case"x":return UK;case"x1":return qK;case"x2":return jK;case"y":return zK;case"y1":return VK;case"y2":return YK;case"z":return pT}throw new Error(`invalid bin reduce: ${e}`)}function C$(e,t,n){return Math.min(200,fp(e,t,n))}function FK(e){return QF(e)||lr(e)&&Le(e)}function RK(e,t,n){let r=e?.(n),i=t?.(n);return r&&i?function*(o){let s=r.bin(o);for(let[a,[c,l]]of r.entries()){let u=i.bin(s[a]);for(let[f,[h,d]]of i.entries())yield[u[f],{data:n,x1:c,y1:h,x2:l,y2:d}]}}:r?function*(o){let s=r.bin(o);for(let[a,[c,l]]of r.entries())yield[s[a],{data:n,x1:c,x2:l}]}:function*(o){let s=i.bin(o);for(let[a,[c,l]]of i.entries())yield[s[a],{data:n,y1:c,y2:l}]}}function i3(e,t,n){return t=Ke(t),r=>{let i=e.map(()=>[]);for(let o of r)i[Ms(t,n[o])-1]?.push(o);return i}}function $K(e,t,n){let r=i3(e,t,n);return i=>{let o=r(i);for(let s=1,a=o.length;s<a;++s){let c=o[s-1],l=o[s];for(let u of c)l.push(u)}return o}}function PK(e,t,n){let r=i3(e,t,n);return i=>{let o=r(i);for(let s=o.length-2;s>=0;--s){let a=o[s+1],c=o[s];for(let l of a)c.push(l)}return o}}function P$(e,t){let n=(+e+ +t)/2;return e instanceof Date?new Date(n):n}var UK={reduceIndex(e,t,{x1:n,x2:r}){return P$(n,r)}},zK={reduceIndex(e,t,{y1:n,y2:r}){return P$(n,r)}},qK={reduceIndex(e,t,{x1:n}){return n}},jK={reduceIndex(e,t,{x2:n}){return n}},VK={reduceIndex(e,t,{y1:n}){return n}},YK={reduceIndex(e,t,{y2:n}){return n}};function Zf(e={}){return QA(e)?e:{...e,x:G}}function Jf(e={}){return KA(e)?e:{...e,y:G}}function U$(e,t){if(t.length===1)return{data:e,facets:t};let n=e.length,r=new Uint8Array(n),i=0;for(let a of t)for(let c of a)r[c]&&++i,r[c]=1;if(i===0)return{data:e,facets:t};e=Ha(e);let o=e[GA]=new Uint32Array(n+i);t=t.map(a=>Ha(a,Uint32Array));let s=n;r.fill(0);for(let a of t)for(let c=0,l=a.length;c<l;++c){let u=a[c];r[u]?(a[c]=s,e[s]=e[u],o[s]=u,++s):o[u]=u,r[u]=1}return{data:e,facets:t}}function o3(e={},t={}){arguments.length===1&&([e,t]=th(e));let{y1:n,y:r=n,x:i,...o}=t,[s,a,c,l]=eh(r,i,"y","x",e,o);return{...s,y1:n,y:a,x1:c,x2:l,x:Tf(c,l)}}function j$(e={},t={}){arguments.length===1&&([e,t]=th(e));let{y1:n,y:r=n,x:i}=t,[o,s,a]=eh(r,i,"y","x",e,t);return{...o,y1:n,y:s,x:a}}function V$(e={},t={}){arguments.length===1&&([e,t]=th(e));let{y1:n,y:r=n,x:i}=t,[o,s,,a]=eh(r,i,"y","x",e,t);return{...o,y1:n,y:s,x:a}}function s3(e={},t={}){arguments.length===1&&([e,t]=th(e));let{x1:n,x:r=n,y:i,...o}=t,[s,a,c,l]=eh(r,i,"x","y",e,o);return{...s,x1:n,x:a,y1:c,y2:l,y:Tf(c,l)}}function Y$(e={},t={}){arguments.length===1&&([e,t]=th(e));let{x1:n,x:r=n,y:i}=t,[o,s,a]=eh(r,i,"x","y",e,t);return{...o,x1:n,x:s,y:a}}function X$(e={},t={}){arguments.length===1&&([e,t]=th(e));let{x1:n,x:r=n,y:i}=t,[o,s,,a]=eh(r,i,"x","y",e,t);return{...o,x1:n,x:s,y:a}}function Qf({x:e,x1:t,x2:n,...r}={}){return r=Xi(r,"y"),t===void 0&&n===void 0?o3({x:e,...r}):([t,n]=tT(e,t,n),{...r,x1:t,x2:n})}function Kf({y:e,y1:t,y2:n,...r}={}){return r=Xi(r,"x"),t===void 0&&n===void 0?s3({y:e,...r}):([t,n]=tT(e,t,n),{...r,y1:t,y2:n})}function th(e){let{offset:t,order:n,reverse:r,...i}=e;return[{offset:t,order:n,reverse:r},i]}var XK={length:!0};function eh(e,t=Ym,n,r,{offset:i,order:o,reverse:s},a){if(t===null)throw new Error(`stack requires ${r}`);let c=jn(a),[l,u]=On(e),[f,h]=yn(t),[d,p]=yn(t);return f.hint=d.hint=XK,i=GK(i),o=ZK(o,i,r),[gn(a,(m,y,g)=>{({data:m,facets:y}=U$(m,y));let x=e==null?void 0:u(Ml(wt(m,e),g?.[n])),b=wt(m,t,Float64Array),w=wt(m,c),_=o&&o(m,x,b,w),v=m.length,M=h(new Float64Array(v)),E=p(new Float64Array(v)),I=[];for(let D of y){let A=x?Array.from(ln(D,O=>x[O]).values()):[D];if(_)for(let O of A)O.sort(_);for(let O of A){let C=0,S=0;s&&O.reverse();for(let T of O){let N=b[T];N<0?C=E[T]=(M[T]=C)+N:N>0?S=E[T]=(M[T]=S)+N:E[T]=M[T]=S}}I.push(A)}return i&&i(I,M,E,w),{data:m,facets:y}}),l,f,d]}function GK(e){if(e!=null){if(typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"expand":case"normalize":return WK;case"center":case"silhouette":return HK;case"wiggle":return W$}throw new Error(`unknown offset: ${e}`)}}function G$(e,t){let n=0,r=0;for(let i of e){let o=t[i];o<n&&(n=o),o>r&&(r=o)}return[n,r]}function WK(e,t,n){for(let r of e)for(let i of r){let[o,s]=G$(i,n);for(let a of i){let c=1/(s-o||1);t[a]=c*(t[a]-o),n[a]=c*(n[a]-o)}}}function HK(e,t,n){for(let r of e){for(let i of r){let[o,s]=G$(i,n);for(let a of i){let c=(s+o)/2;t[a]-=c,n[a]-=c}}H$(r,t,n)}Z$(e,t,n)}function W$(e,t,n,r){for(let i of e){let o=new Jn,s=0;for(let a of i){let c=-1,l=a.map(d=>Math.abs(n[d]-t[d])),u=a.map(d=>{c=r?r[d]:++c;let p=n[d]-t[d],m=o.has(c)?p-o.get(c):0;return o.set(c,p),m}),f=[0,...Z0(u)];for(let d of a)t[d]+=s,n[d]+=s;let h=Tn(l);h&&(s-=Tn(l,(d,p)=>(u[p]/2+f[p])*d)/h)}H$(i,t,n)}Z$(e,t,n)}function H$(e,t,n){let r=ue(e,i=>ue(i,o=>t[o]));for(let i of e)for(let o of i)t[o]-=r,n[o]-=r}function Z$(e,t,n){let r=e.length;if(r===1)return;let i=e.map(a=>a.flat()),o=i.map(a=>(ue(a,c=>t[c])+Ht(a,c=>n[c]))/2),s=ue(o);for(let a=0;a<r;a++){let c=s-o[a];for(let l of i[a])t[l]+=c,n[l]+=c}}function ZK(e,t,n){if(e===void 0&&t===W$)return z$(dn);if(e!=null){if(typeof e=="string"){let r=e.startsWith("-"),i=r?vl:dn;switch((r?e.slice(1):e).toLowerCase()){case"value":case n:return JK(i);case"z":return QK(i);case"sum":return KK(i);case"appearance":return ttt(i);case"inside-out":return z$(i)}return q$(WA(e))}if(typeof e=="function")return(e.length===1?q$:ett)(e);if(Array.isArray(e))return ntt(e);throw new Error(`invalid order: ${e}`)}}function JK(e){return(t,n,r)=>(i,o)=>e(r[i],r[o])}function QK(e){return(t,n,r,i)=>(o,s)=>e(i[o],i[s])}function KK(e){return uv(e,(t,n,r,i)=>Eu(cr(t),o=>Tn(o,s=>r[s]),o=>i[o]))}function ttt(e){return uv(e,(t,n,r,i)=>Eu(cr(t),o=>n[Gc(o,s=>r[s])],o=>i[o]))}function z$(e){return uv(e,(t,n,r,i)=>{let o=cr(t),s=Eu(o,f=>n[Gc(f,h=>r[h])],f=>i[f]),a=Pi(o,f=>Tn(f,h=>r[h]),f=>i[f]),c=[],l=[],u=0;for(let f of s)u<0?(u+=a.get(f),c.push(f)):(u-=a.get(f),l.push(f));return l.reverse().concat(c)})}function q$(e){return t=>{let n=wt(t,e);return(r,i)=>dn(n[r],n[i])}}function ett(e){return t=>(n,r)=>e(t[n],t[r])}function ntt(e){return uv(dn,()=>e)}function uv(e,t){return(n,r,i,o)=>{if(!o)throw new Error("missing channel: z");let s=new Jn(t(n,r,i,o).map((a,c)=>[a,c]));return(a,c)=>e(s.get(o[a]),s.get(o[c]))}}var rtt={ariaLabel:"area",strokeWidth:1,strokeLinecap:"round",strokeLinejoin:"round",strokeMiterlimit:1},Rl=class extends St{constructor(t,n={}){let{x1:r,y1:i,x2:o,y2:s,z:a,curve:c,tension:l}=n;super(t,{x1:{value:r,scale:"x"},y1:{value:i,scale:"y"},x2:{value:o,scale:"x",optional:!0},y2:{value:s,scale:"y",optional:!0},z:{value:jn(n),optional:!0}},n,rtt),this.z=a,this.curve=dy(c,l)}filter(t){return t}render(t,n,r,i,o){let{x1:s,y1:a,x2:c=s,y2:l=a}=r;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n,0,0).call(u=>u.selectAll().data(Bw(t,[s,a,c,l],this,r)).enter().append("path").call(Lt,this).call(Nl,this,r).attr("d",pf().curve(this.curve).defined(f=>f>=0).x0(f=>s[f]).y0(f=>a[f]).x1(f=>c[f]).y1(f=>l[f]))).node()}};function py(e,t){return t===void 0?oa(e,{x:Il,y:Wa}):new Rl(e,t)}function cc(e,t){let{y:n=Ee,...r}=Hf(t);return new Rl(e,Qf(Zf({...r,y1:n,y2:void 0})))}function oa(e,t){let{x:n=Ee,...r}=Wf(t);return new Rl(e,Kf(Jf({...r,x1:n,x2:void 0})))}var itt={ariaLabel:"link",fill:"none",stroke:"currentColor",strokeMiterlimit:1},my=class extends St{constructor(t,n={}){let{x1:r,y1:i,x2:o,y2:s,curve:a,tension:c}=n;super(t,{x1:{value:r,scale:"x"},y1:{value:i,scale:"y"},x2:{value:o,scale:"x",optional:!0},y2:{value:s,scale:"y",optional:!0}},n,itt),this.curve=cv(a,c),Gi(this,n)}project(t,n,r){this.curve!==ac&&super.project(t,n,r)}render(t,n,r,i,o){let{x1:s,y1:a,x2:c=s,y2:l=a}=r,{curve:u}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(f=>f.selectAll().data(t).enter().append("path").call(Lt,this).attr("d",u===ac&&o.projection?ott(o.projection,s,a,c,l):h=>{let d=nr(),p=u(d);return p.lineStart(),p.point(s[h],a[h]),p.point(c[h],l[h]),p.lineEnd(),d}).call(Qt,this,r).call(ra,this,r,o)).node()}};function ott(e,t,n,r,i){let o=Nn(e);return t=Ke(t),n=Ke(n),r=Ke(r),i=Ke(i),s=>o({type:"LineString",coordinates:[[t[s],n[s]],[r[s],i[s]]]})}function fv(e,{x:t,x1:n,x2:r,y:i,y1:o,y2:s,...a}={}){return[n,r]=yy(t,n,r),[o,s]=yy(i,o,s),new my(e,{...a,x1:n,x2:r,y1:o,y2:s})}function yy(e,t,n){if(e===void 0){if(t===void 0){if(n!==void 0)return[n]}else if(n===void 0)return[t]}else{if(t===void 0)return n===void 0?[e]:[e,n];if(n===void 0)return[e,t]}return[t,n]}var stt={ariaLabel:"arrow",fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeMiterlimit:1,strokeWidth:1.5},gy=class extends St{constructor(t,n={}){let{x1:r,y1:i,x2:o,y2:s,bend:a=0,headAngle:c=60,headLength:l=8,inset:u=0,insetStart:f=u,insetEnd:h=u,sweep:d}=n;super(t,{x1:{value:r,scale:"x"},y1:{value:i,scale:"y"},x2:{value:o,scale:"x",optional:!0},y2:{value:s,scale:"y",optional:!0}},n,stt),this.bend=a===!0?22.5:Math.max(-90,Math.min(90,a)),this.headAngle=+c,this.headLength=+l,this.insetStart=+f,this.insetEnd=+h,this.sweep=att(d)}render(t,n,r,i,o){let{x1:s,y1:a,x2:c=s,y2:l=a,SW:u}=r,{strokeWidth:f,bend:h,headAngle:d,headLength:p,insetStart:m,insetEnd:y}=this,g=u?w=>u[w]:pn(f===void 0?1:f),x=d*Vf/2,b=p/1.5;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(w=>w.selectAll().data(t).enter().append("path").call(Lt,this).attr("d",_=>{let v=s[_],M=a[_],E=c[_],I=l[_],D=Math.hypot(E-v,I-M);if(D<=m+y)return null;let A=Math.atan2(I-M,E-v),O=Math.min(b*g(_),D/3),C=this.sweep(v,M,E,I)*h*Vf,S=Math.hypot(D/Math.tan(C),D)/2;if(m||y)if(S<1e5){let nt=Math.sign(C),[ot,at]=ctt([v,M],[E,I],S,nt);if(m&&([v,M]=J$([ot,at,S],[v,M,m],-nt*Math.sign(m))),y){let[Y,st]=J$([ot,at,S],[E,I,y],nt*Math.sign(y));A+=Math.atan2(st-at,Y-ot)-Math.atan2(I-at,E-ot),E=Y,I=st}}else{let nt=E-v,ot=I-M,at=Math.hypot(nt,ot);m&&(v+=nt/at*m,M+=ot/at*m),y&&(E-=nt/at*y,I-=ot/at*y)}let T=A+C,N=T+x,F=T-x,R=E-O*Math.cos(N),k=I-O*Math.sin(N),$=E-O*Math.cos(F),P=I-O*Math.sin(F),U=S<1e5?`A${S},${S} 0,0,${C>0?1:0} `:"L",W=O?`M${R},${k}L${E},${I}L${$},${P}`:"";return`M${v},${M}${U}${E},${I}${W}`}).call(Qt,this,r)).node()}};function att(e=1){if(typeof e=="number")return pn(Math.sign(e));if(typeof e=="function")return(t,n,r,i)=>Math.sign(e(t,n,r,i));switch(sn(e,"sweep",["+x","-x","+y","-y"])){case"+x":return(t,n,r)=>zt(t,r);case"-x":return(t,n,r)=>Zn(t,r);case"+y":return(t,n,r,i)=>zt(n,i);case"-y":return(t,n,r,i)=>Zn(n,i)}}function ctt([e,t],[n,r],i,o){let s=n-e,a=r-t,c=Math.hypot(s,a),l=o*Math.sqrt(i*i-c*c/4)/c;return[(e+n)/2-a*l,(t+r)/2+s*l]}function J$([e,t,n],[r,i,o],s){let a=r-e,c=i-t,l=Math.hypot(a,c),u=(a*a+c*c-o*o+n*n)/(2*l),f=s*Math.sqrt(n*n-u*u);return[e+(a*u+c*f)/l,t+(c*u-a*f)/l]}function Q$(e,{x:t,x1:n,x2:r,y:i,y1:o,y2:s,...a}={}){return[n,r]=yy(t,n,r),[o,s]=yy(i,o,s),new gy(e,{...a,x1:n,x2:r,y1:o,y2:s})}var nh=class extends St{constructor(t,n,r={},i){super(t,n,r,i);let{inset:o=0,insetTop:s=o,insetRight:a=o,insetBottom:c=o,insetLeft:l=o,rx:u,ry:f}=r;this.insetTop=Bt(s),this.insetRight=Bt(a),this.insetBottom=Bt(c),this.insetLeft=Bt(l),this.rx=fe(u,"auto"),this.ry=fe(f,"auto")}render(t,n,r,i,o){let{rx:s,ry:a}=this;return ut("svg:g",o).call(Ct,this,i,o).call(this._transform,this,n).call(c=>c.selectAll().data(t).enter().append("rect").call(Lt,this).attr("x",this._x(n,r,i)).attr("width",this._width(n,r,i)).attr("y",this._y(n,r,i)).attr("height",this._height(n,r,i)).call(ft,"rx",s).call(ft,"ry",a).call(Qt,this,r)).node()}_x(t,{x:n},{marginLeft:r}){let{insetLeft:i}=this;return n?o=>n[o]+i:r+i}_y(t,{y:n},{marginTop:r}){let{insetTop:i}=this;return n?o=>n[o]+i:r+i}_width({x:t},{x:n},{marginRight:r,marginLeft:i,width:o}){let{insetLeft:s,insetRight:a}=this,c=n&&t?t.bandwidth():o-r-i;return Math.max(0,c-s-a)}_height({y:t},{y:n},{marginTop:r,marginBottom:i,height:o}){let{insetTop:s,insetBottom:a}=this,c=n&&t?t.bandwidth():o-r-i;return Math.max(0,c-s-a)}},K$={ariaLabel:"bar"},xy=class extends nh{constructor(t,n={}){let{x1:r,x2:i,y:o}=n;super(t,{x1:{value:r,scale:"x"},x2:{value:i,scale:"x"},y:{value:o,scale:"y",type:"band",optional:!0}},n,K$)}_transform(t,n,{x:r}){t.call(Et,n,{x:r},0,0)}_x({x:t},{x1:n,x2:r},{marginLeft:i}){let{insetLeft:o}=this;return ur(t)?i+o:s=>Math.min(n[s],r[s])+o}_width({x:t},{x1:n,x2:r},{marginRight:i,marginLeft:o,width:s}){let{insetLeft:a,insetRight:c}=this;return ur(t)?s-i-o-a-c:l=>Math.max(0,Math.abs(r[l]-n[l])-a-c)}},by=class extends nh{constructor(t,n={}){let{x:r,y1:i,y2:o}=n;super(t,{y1:{value:i,scale:"y"},y2:{value:o,scale:"y"},x:{value:r,scale:"x",type:"band",optional:!0}},n,K$)}_transform(t,n,{y:r}){t.call(Et,n,{y:r},0,0)}_y({y:t},{y1:n,y2:r},{marginTop:i}){let{insetTop:o}=this;return ur(t)?i+o:s=>Math.min(n[s],r[s])+o}_height({y:t},{y1:n,y2:r},{marginTop:i,marginBottom:o,height:s}){let{insetTop:a,insetBottom:c}=this;return ur(t)?s-i-o-a-c:l=>Math.max(0,Math.abs(r[l]-n[l])-a-c)}};function Jo(e,t={}){return Mf(t)||(t={...t,y:Ee,x2:G}),new xy(e,Qf(Pw(Zf(t))))}function Qo(e,t={}){return Mf(t)||(t={...t,x:Ee,y2:G}),new by(e,Kf(Uw(Jf(t))))}var ltt={ariaLabel:"cell"},$l=class extends nh{constructor(t,{x:n,y:r,...i}={}){super(t,{x:{value:n,scale:"x",type:"band",optional:!0},y:{value:r,scale:"y",type:"band",optional:!0}},i,ltt)}_transform(t,n){t.call(Et,n,{},0,0)}};function lc(e,{x:t,y:n,...r}={}){return[t,n]=Pe(t,n),new $l(e,{...r,x:t,y:n})}function t9(e,{x:t=Ee,fill:n,stroke:r,...i}={}){return n===void 0&&Be(r)[0]===void 0&&(n=G),new $l(e,{...i,x:t,fill:n,stroke:r})}function e9(e,{y:t=Ee,fill:n,stroke:r,...i}={}){return n===void 0&&Be(r)[0]===void 0&&(n=G),new $l(e,{...i,y:t,fill:n,stroke:r})}var utt={ariaLabel:"dot",fill:"none",stroke:"currentColor",strokeWidth:1.5};function wy(e){return e.sort===void 0&&e.reverse===void 0?mw({channel:"-r"},e):e}var Pl=class extends St{constructor(t,n={}){let{x:r,y:i,r:o,rotate:s,symbol:a=Xs,frameAnchor:c}=n,[l,u]=se(s,0),[f,h]=uR(a),[d,p]=se(o,f==null?3:4.5);super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},r:{value:d,scale:"r",filter:ar,optional:!0},rotate:{value:l,optional:!0},symbol:{value:f,scale:"auto",optional:!0}},wy(n),utt),this.r=p,this.rotate=u,this.symbol=h,this.frameAnchor=Yo(c);let{channels:m}=this,{symbol:y}=m;if(y){let{fill:g,stroke:x}=m;y.hint={fill:g?g.value===y.value?"color":"currentColor":this.fill??"currentColor",stroke:x?x.value===y.value?"color":"currentColor":this.stroke??"none"}}}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,r:u,rotate:f,symbol:h}=r,{r:d,rotate:p,symbol:m}=this,[y,g]=bn(this,i),x=m===Xs,b=u?void 0:d*d*Math.PI;return ja(d)&&(t=[]),ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(w=>w.selectAll().data(t).enter().append(x?"circle":"path").call(Lt,this).call(x?_=>{_.attr("cx",c?v=>c[v]:y).attr("cy",l?v=>l[v]:g).attr("r",u?v=>u[v]:d)}:_=>{_.attr("transform",oc`translate(${c?v=>c[v]:y},${l?v=>l[v]:g})${f?v=>` rotate(${f[v]})`:p?` rotate(${p})`:""}`).attr("d",u&&h?v=>{let M=nr();return h[v].draw(M,u[v]*u[v]*Math.PI),M}:u?v=>{let M=nr();return m.draw(M,u[v]*u[v]*Math.PI),M}:h?v=>{let M=nr();return h[v].draw(M,b),M}:(()=>{let v=nr();return m.draw(v,b),v})())}).call(Qt,this,r)).node()}};function _i(e,{x:t,y:n,...r}={}){return r.frameAnchor===void 0&&([t,n]=Pe(t,n)),new Pl(e,{...r,x:t,y:n})}function n9(e,{x:t=G,...n}={}){return new Pl(e,qw({...n,x:t}))}function r9(e,{y:t=G,...n}={}){return new Pl(e,zw({...n,y:t}))}function i9(e,t){return _i(e,{...t,symbol:"circle"})}function o9(e,t){return _i(e,{...t,symbol:"hexagon"})}var ftt={ariaLabel:"line",fill:"none",stroke:"currentColor",strokeWidth:1.5,strokeLinecap:"round",strokeLinejoin:"round",strokeMiterlimit:1},Ul=class extends St{constructor(t,n={}){let{x:r,y:i,z:o,curve:s,tension:a}=n;super(t,{x:{value:r,scale:"x"},y:{value:i,scale:"y"},z:{value:jn(n),optional:!0}},n,ftt),this.z=o,this.curve=cv(s,a),Gi(this,n)}filter(t){return t}project(t,n,r){this.curve!==ac&&super.project(t,n,r)}render(t,n,r,i,o){let{x:s,y:a}=r,{curve:c}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(l=>l.selectAll().data(Bw(t,[s,a],this,r)).enter().append("path").call(Lt,this).call(Nl,this,r).call(F7,this,r,o).attr("d",c===ac&&o.projection?htt(o.projection,s,a):Mm().curve(c).defined(u=>u>=0).x(u=>s[u]).y(u=>a[u]))).node()}};function htt(e,t,n){let r=Nn(e);return t=Ke(t),n=Ke(n),i=>{let o=[],s=[o];for(let a of i)a===-1?(o=[],s.push(o)):o.push([t[a],n[a]]);return r({type:"MultiLineString",coordinates:s})}}function zl(e,{x:t,y:n,...r}={}){return[t,n]=Pe(t,n),new Ul(e,{...r,x:t,y:n})}function uc(e,{x:t=G,y:n=Ee,...r}={}){return new Ul(e,Hf({...r,x:t,y:n}))}function fc(e,{x:t=Ee,y:n=G,...r}={}){return new Ul(e,Wf({...r,x:t,y:n}))}var dtt={ariaLabel:"rect"},ql=class extends St{constructor(t,n={}){let{x1:r,y1:i,x2:o,y2:s,inset:a=0,insetTop:c=a,insetRight:l=a,insetBottom:u=a,insetLeft:f=a,rx:h,ry:d}=n;super(t,{x1:{value:r,scale:"x",type:r!=null&&o==null?"band":void 0,optional:!0},y1:{value:i,scale:"y",type:i!=null&&s==null?"band":void 0,optional:!0},x2:{value:o,scale:"x",optional:!0},y2:{value:s,scale:"y",optional:!0}},n,dtt),this.insetTop=Bt(c),this.insetRight=Bt(l),this.insetBottom=Bt(u),this.insetLeft=Bt(f),this.rx=fe(h,"auto"),this.ry=fe(d,"auto")}render(t,n,r,i,o){let{x:s,y:a}=n,{x1:c,y1:l,x2:u,y2:f}=r,{marginTop:h,marginRight:d,marginBottom:p,marginLeft:m,width:y,height:g}=i,{projection:x}=o,{insetTop:b,insetRight:w,insetBottom:_,insetLeft:v,rx:M,ry:E}=this,I=(s?.bandwidth?s.bandwidth():0)-v-w,D=(a?.bandwidth?a.bandwidth():0)-b-_;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{},0,0).call(A=>A.selectAll().data(t).enter().append("rect").call(Lt,this).attr("x",c&&(x||!ur(s))?u?O=>Math.min(c[O],u[O])+v:O=>c[O]+v:m+v).attr("y",l&&(x||!ur(a))?f?O=>Math.min(l[O],f[O])+b:O=>l[O]+b:h+b).attr("width",c&&(x||!ur(s))?u?O=>Math.max(0,Math.abs(u[O]-c[O])+I):I:y-d-m-w-v).attr("height",l&&(x||!ur(a))?f?O=>Math.max(0,Math.abs(l[O]-f[O])+D):D:g-h-p-b-_).call(ft,"rx",M).call(ft,"ry",E).call(Qt,this,r)).node()}};function vy(e,t){return new ql(e,zT(qT(t)))}function rh(e,t={}){return Mf(t)||(t={...t,y:Ee,x2:G,interval:1}),new ql(e,Qf(qT(Zf(t))))}function ih(e,t={}){return Mf(t)||(t={...t,x:Ee,y2:G,interval:1}),new ql(e,Kf(zT(Jf(t))))}function c3(e,t){t=ptt(t);let{x:n,y:r,color:i,size:o}=t,s=hv(e,n),a=hv(e,r),c=hv(e,i),l=hv(e,o),{fx:u,fy:f,x:{value:h,reduce:d,zero:p,...m},y:{value:y,reduce:g,zero:x,...b},color:{value:w,color:_,reduce:v},size:{value:M,reduce:E},mark:I}=t;if(d===void 0&&(d=g==null&&h==null&&M==null&&y!=null?"count":null),g===void 0&&(g=d==null&&y==null&&M==null&&h!=null?"count":null),E===void 0&&M==null&&v==null&&d==null&&g==null&&(h==null||Ne(s))&&(y==null||Ne(a))&&(E="count"),p===void 0&&(p=dv(d)?!0:void 0),x===void 0&&(x=dv(g)?!0:void 0),h==null&&y==null)throw new Error("must specify x or y");if(d!=null&&y==null)throw new Error("reducing x requires y");if(g!=null&&h==null)throw new Error("reducing y requires x");I===void 0&&(I=M!=null||E!=null?"dot":dv(d)||dv(g)||v!=null?"bar":h!=null&&y!=null?Ne(s)||Ne(a)||d==null&&g==null&&!_y(s)&&!_y(a)?"dot":"line":h!=null||y!=null?"rule":null);let D,A,O;switch(I){case"dot":O=_i,A="stroke";break;case"line":O=s&&a||d!=null||g!=null?x||g!=null||s&&_y(s)?fc:p||d!=null||a&&_y(a)?uc:zl:s?uc:fc,A="stroke",a9(c)&&(D=null);break;case"area":O=!(x||g!=null)&&(p||d!=null||a&&_y(a))?cc:oa,A="fill",a9(c)&&(D=null);break;case"rule":O=s?Yr:Xr,A="stroke";break;case"bar":O=d!=null?Ne(a)?s9(d)&&s&&Ne(s)?lc:Jo:rh:g!=null?Ne(s)?s9(g)&&a&&Ne(a)?lc:Qo:ih:v!=null||E!=null?s&&Ne(s)&&a&&Ne(a)?lc:s&&Ne(s)?Qo:a&&Ne(a)?Jo:vy:s&&Js(s)&&!(a&&Js(a))?Jo:a&&Js(a)&&!(s&&Js(s))?Qo:lc,A="fill";break;default:throw new Error(`invalid mark: ${I}`)}let C={fx:u,fy:f,x:s??void 0,y:a??void 0,[A]:c??_,z:D,r:l??void 0,tip:!0},S,T={[A]:v??void 0,r:E??void 0};if(d!=null&&g!=null)throw new Error("cannot reduce both x and y");return g!=null?(T.y=g,S=Ne(s)?Ka:Ho):d!=null?(T.x=d,S=Ne(a)?tc:Zo):(v!=null||E!=null)&&(s&&a?S=Ne(s)&&Ne(a)?Zm:Ne(s)?Zo:Ne(a)?Ho:ia:s?S=Ne(s)?Ka:Ho:a&&(S=Ne(a)?tc:Zo)),(S===ia||S===Ho)&&(C.x={value:s,...m}),(S===ia||S===Zo)&&(C.y={value:a,...b}),p===void 0&&(p=s&&!(S===ia||S===Ho)&&(O===Jo||O===cc||O===rh||O===Xr)),x===void 0&&(x=a&&!(S===ia||S===Zo)&&(O===Qo||O===oa||O===ih||O===Yr)),{fx:u??null,fy:f??null,x:{value:h??null,reduce:d??null,zero:!!p,...m},y:{value:y??null,reduce:g??null,zero:!!x,...b},color:{value:w??null,reduce:v??null,..._!==void 0&&{color:_}},size:{value:M??null,reduce:E??null},mark:I,markImpl:c9[O],markOptions:C,transformImpl:c9[S],transformOptions:T,colorMode:A}}function l9(e,t){let n=c3(e,t),{fx:r,fy:i,x:{zero:o},y:{zero:s},markOptions:a,transformOptions:c,colorMode:l}=n,u=a3[n.markImpl],f=a3[n.transformImpl],h=r!=null||i!=null?Gf({strokeOpacity:.1}):null,d=[o?Yr([0]):null,s?Xr([0]):null],p=u(e,f?f(c,a):a);return l==="stroke"?tn(h,d,p):tn(h,p,d)}function _y(e){let t,n;for(let r of e){if(r==null)continue;if(t===void 0){t=r;continue}let i=Math.sign(zt(t,r));if(i){if(n!==void 0&&i!==n)return!1;t=r,n=i}}return!0}function ptt({x:e,y:t,color:n,size:r,fx:i,fy:o,mark:s}={}){return jr(e)||(e=oh(e)),jr(t)||(t=oh(t)),jr(n)||(n=Ja(n)?{color:n}:oh(n)),jr(r)||(r=oh(r)),jr(i)&&({value:i}=oh(i)),jr(o)&&({value:o}=oh(o)),s!=null&&(s=`${s}`.toLowerCase()),{x:e,y:t,color:n,size:r,fx:i,fy:o,mark:s}}function hv(e,t){let n=wt(e,t.value);return n&&(n.label=Bn(t.value)),n}function oh(e){return mtt(e)?{reduce:e}:{value:e}}function dv(e){return/^(?:distinct|count|sum|proportion)$/i.test(e)}function s9(e){return/^(?:first|last|mode)$/i.test(e)}function mtt(e){if(e==null)return!1;if(typeof e.reduceIndex=="function"||typeof e.reduce=="function"&&mn(e)||/^p\d{2}$/i.test(e))return!0;switch(`${e}`.toLowerCase()){case"first":case"last":case"count":case"distinct":case"sum":case"proportion":case"proportion-facet":case"deviation":case"min":case"min-index":case"max":case"max-index":case"mean":case"median":case"variance":case"mode":return!0}return!1}function a9(e){return e?new Qn(e).size>e.length>>1:!1}var a3={dot:_i,line:zl,lineX:uc,lineY:fc,areaX:cc,areaY:oa,ruleX:Yr,ruleY:Xr,barX:Jo,barY:Qo,rect:vy,rectX:rh,rectY:ih,cell:lc,bin:ia,binX:Ho,binY:Zo,group:Zm,groupX:Ka,groupY:tc},c9=Object.fromEntries(Object.entries(a3).map(([e,t])=>[t,e]));function sh(e,t={}){let{x:n,x1:r,x2:i}=t;n===void 0&&r===void 0&&i===void 0&&(t={...t,x:n=G});let o={};return n!=null&&(o.x=e),r!=null&&(o.x1=e),i!=null&&(o.x2=e),_r(o,t)}function ah(e,t={}){let{y:n,y1:r,y2:i}=t;n===void 0&&r===void 0&&i===void 0&&(t={...t,y:n=G});let o={};return n!=null&&(o.y=e),r!=null&&(o.y1=e),i!=null&&(o.y2=e),_r(o,t)}function _r(e={},t={}){let n=jn(t),r=Object.entries(e).map(([i,o])=>{let s=lw(i,t);if(s==null)throw new Error(`missing channel: ${i}`);let[a,c]=yn(s);return{key:i,input:s,output:a,setOutput:c,map:ytt(o)}});return{...gn(t,(i,o)=>{let s=wt(i,n),a=r.map(({input:l})=>wt(i,l)),c=r.map(({setOutput:l})=>l(new Array(i.length)));for(let l of o)for(let u of s?ln(l,f=>s[f]).values():[l])r.forEach(({map:f},h)=>f.mapIndex(u,a[h],c[h]));return{data:i,facets:o}}),...Object.fromEntries(r.map(({key:i,output:o})=>[i,o]))}}function ytt(e){if(e==null)throw new Error("missing map");if(typeof e.mapIndex=="function")return e;if(typeof e.map=="function"&&mn(e))return gtt(e);if(typeof e=="function")return l3(Af(e));switch(`${e}`.toLowerCase()){case"cumsum":return btt;case"rank":return l3((t,n)=>hp(t,r=>n[r]));case"quantile":return l3((t,n)=>xtt(t,r=>n[r]))}throw new Error(`invalid map: ${e}`)}function gtt(e){return console.warn("deprecated map interface; implement mapIndex instead."),{mapIndex:e.map.bind(e)}}function xtt(e,t){let n=_o(e,t)-1;return hp(e,t).map(r=>r/n)}function l3(e){return{mapIndex(t,n,r){let i=e(t,n);if(i.length!==t.length)throw new Error("map function returned a mismatched length");for(let o=0,s=t.length;o<s;++o)r[t[o]]=i[o]}}}var btt={mapIndex(e,t,n){let r=0;for(let i of e)n[i]=r+=t[i]}};function u9(e={},t){return arguments.length===1&&(t=e),sh(ch(e),t)}function f9(e={},t){return arguments.length===1&&(t=e),ah(ch(e),t)}function ch(e={}){typeof e=="number"&&(e={k:e});let{k:t,reduce:n,shift:r,anchor:i,strict:o}=e;if(i===void 0&&r!==void 0&&(i=vtt(r),Vn(`Warning: the shift option is deprecated; please use anchor "${i}" instead.`)),!((t=Math.floor(t))>0))throw new Error(`invalid k: ${t}`);return _tt(n)(t,wtt(i,t),o)}function wtt(e="middle",t){switch(`${e}`.toLowerCase()){case"middle":return t-1>>1;case"start":return 0;case"end":return t-1}throw new Error(`invalid anchor: ${e}`)}function vtt(e){switch(`${e}`.toLowerCase()){case"centered":return"middle";case"leading":return"start";case"trailing":return"end"}throw new Error(`invalid shift: ${e}`)}function _tt(e="mean"){if(typeof e=="string"){if(/^p\d{2}$/i.test(e))return pv(If(e));switch(e.toLowerCase()){case"deviation":return pv(li);case"max":return mv((t,n)=>Ht(t,r=>n[r]));case"mean":return Stt;case"median":return pv(Ui);case"min":return mv((t,n)=>ue(t,r=>n[r]));case"mode":return mv((t,n)=>Bu(t,r=>n[r]));case"sum":return h9;case"variance":return pv(Ta);case"difference":return Att;case"ratio":return Ttt;case"first":return Ett;case"last":return Ntt}}if(typeof e!="function")throw new Error(`invalid reduce: ${e}`);return mv(Af(e))}function pv(e){return(t,n,r)=>r?{mapIndex(i,o,s){let a=l=>o[l]==null?NaN:+o[l],c=0;for(let l=0;l<t-1;++l)isNaN(a(l))&&++c;for(let l=0,u=i.length-t+1;l<u;++l)isNaN(a(l+t-1))&&++c,s[i[l+n]]=c===0?e(Hs(i,l,l+t),a):NaN,isNaN(a(l))&&--c}}:{mapIndex(i,o,s){let a=c=>o[c]==null?NaN:+o[c];for(let c=-n;c<0;++c)s[i[c+n]]=e(Hs(i,0,c+t),a);for(let c=0,l=i.length-n;c<l;++c)s[i[c+n]]=e(Hs(i,c,c+t),a)}}}function mv(e){return(t,n,r)=>r?{mapIndex(i,o,s){let a=0;for(let c=0;c<t-1;++c)a+=ze(o[i[c]]);for(let c=0,l=i.length-t+1;c<l;++c)a+=ze(o[i[c+t-1]]),a===t&&(s[i[c+n]]=e(Hs(i,c,c+t),o)),a-=ze(o[i[c]])}}:{mapIndex(i,o,s){for(let a=-n;a<0;++a)s[i[a+n]]=e(Hs(i,0,a+t),o);for(let a=0,c=i.length-n;a<c;++a)s[i[a+n]]=e(Hs(i,a,a+t),o)}}}function h9(e,t,n){return n?{mapIndex(r,i,o){let s=0,a=0;for(let c=0;c<e-1;++c){let l=i[r[c]];l===null||isNaN(l)?++s:a+=+l}for(let c=0,l=r.length-e+1;c<l;++c){let u=i[r[c]],f=i[r[c+e-1]];f===null||isNaN(f)?++s:a+=+f,o[r[c+t]]=s===0?a:NaN,u===null||isNaN(u)?--s:a-=+u}}}:{mapIndex(r,i,o){let s=0,a=r.length;for(let c=0,l=Math.min(a,e-t-1);c<l;++c)s+=+i[r[c]]||0;for(let c=-t,l=a-t;c<l;++c)s+=+i[r[c+e-1]]||0,o[r[c+t]]=s,s-=+i[r[c]]||0}}}function Stt(e,t,n){if(n){let r=h9(e,t,n);return{mapIndex(i,o,s){r.mapIndex(i,o,s);for(let a=0,c=i.length-e+1;a<c;++a)s[i[a+t]]/=e}}}else return{mapIndex(r,i,o){let s=0,a=0,c=r.length;for(let l=0,u=Math.min(c,e-t-1);l<u;++l){let f=i[r[l]];f!==null&&!isNaN(f=+f)&&(s+=f,++a)}for(let l=-t,u=c-t;l<u;++l){let f=i[r[l+e-1]],h=i[r[l]];f!==null&&!isNaN(f=+f)&&(s+=f,++a),o[r[l+t]]=s/a,h!==null&&!isNaN(h=+h)&&(s-=h,--a)}}}}function Itt(e,t,n,r){for(let i=n+r;n<i;++n){let o=e[t[n]];if(ze(o))return o}}function Mtt(e,t,n,r){for(let i=n+r-1;i>=n;--i){let o=e[t[i]];if(ze(o))return o}}function d9(e,t,n,r){for(let i=n+r;n<i;++n){let o=e[t[n]];if(o!==null&&!isNaN(o=+o))return o}}function p9(e,t,n,r){for(let i=n+r-1;i>=n;--i){let o=e[t[i]];if(o!==null&&!isNaN(o=+o))return o}}function Att(e,t,n){return n?{mapIndex(r,i,o){for(let s=0,a=r.length-e;s<a;++s){let c=i[r[s]],l=i[r[s+e-1]];o[r[s+t]]=c===null||l===null?NaN:l-c}}}:{mapIndex(r,i,o){for(let s=-t,a=r.length-e+t+1;s<a;++s)o[r[s+t]]=p9(i,r,s,e)-d9(i,r,s,e)}}}function Ttt(e,t,n){return n?{mapIndex(r,i,o){for(let s=0,a=r.length-e;s<a;++s){let c=i[r[s]],l=i[r[s+e-1]];o[r[s+t]]=c===null||l===null?NaN:l/c}}}:{mapIndex(r,i,o){for(let s=-t,a=r.length-e+t+1;s<a;++s)o[r[s+t]]=p9(i,r,s,e)/d9(i,r,s,e)}}}function Ett(e,t,n){return n?{mapIndex(r,i,o){for(let s=0,a=r.length-e;s<a;++s)o[r[s+t]]=i[r[s]]}}:{mapIndex(r,i,o){for(let s=-t,a=r.length-e+t+1;s<a;++s)o[r[s+t]]=Itt(i,r,s,e)}}}function Ntt(e,t,n){return n?{mapIndex(r,i,o){for(let s=0,a=r.length-e;s<a;++s)o[r[s+t]]=i[r[s+e-1]]}}:{mapIndex(r,i,o){for(let s=-t,a=r.length-e+t+1;s<a;++s)o[r[s+t]]=Mtt(i,r,s,e)}}}var sa={n:20,k:2,color:"currentColor",opacity:.2,strict:!0,anchor:"end"};function m9(e,{x:t=G,y:n,k:r=sa.k,color:i=sa.color,opacity:o=sa.opacity,fill:s=i,fillOpacity:a=o,stroke:c=i,strokeOpacity:l,strokeWidth:u,...f}={}){return tn(re(s)?null:cc(e,_r({x1:hc({k:-r,...f}),x2:hc({k:r,...f})},{x1:t,x2:t,y:n,fill:s,fillOpacity:a,...f})),re(c)?null:uc(e,_r({x:hc(f)},{x:t,y:n,stroke:c,strokeOpacity:l,strokeWidth:u,...f})))}function y9(e,{x:t,y:n=G,k:r=sa.k,color:i=sa.color,opacity:o=sa.opacity,fill:s=i,fillOpacity:a=o,stroke:c=i,strokeOpacity:l,strokeWidth:u,...f}={}){return tn(re(s)?null:oa(e,_r({y1:hc({k:-r,...f}),y2:hc({k:r,...f})},{x:t,y1:n,y2:n,fill:s,fillOpacity:a,...f})),re(c)?null:fc(e,_r({y:hc(f)},{x:t,y:n,stroke:c,strokeOpacity:l,strokeWidth:u,...f})))}function hc({n:e=sa.n,k:t=0,strict:n=sa.strict,anchor:r=sa.anchor}={}){return ch({k:e,reduce:i=>Es(i)+t*(li(i)||0),strict:n,anchor:r})}var Dtt={ariaLabel:"tick",fill:null,stroke:"currentColor"},yv=class extends St{constructor(t,n,r){super(t,n,r,Dtt),Gi(this,r)}render(t,n,r,i,o){return ut("svg:g",o).call(Ct,this,i,o).call(this._transform,this,n).call(s=>s.selectAll().data(t).enter().append("line").call(Lt,this).attr("x1",this._x1(n,r,i)).attr("x2",this._x2(n,r,i)).attr("y1",this._y1(n,r,i)).attr("y2",this._y2(n,r,i)).call(Qt,this,r).call(ra,this,r,o)).node()}},Sy=class extends yv{constructor(t,n={}){let{x:r,y:i,inset:o=0,insetTop:s=o,insetBottom:a=o}=n;super(t,{x:{value:r,scale:"x"},y:{value:i,scale:"y",type:"band",optional:!0}},n),this.insetTop=Bt(s),this.insetBottom=Bt(a)}_transform(t,n,{x:r}){t.call(Et,n,{x:r},Ce,0)}_x1(t,{x:n}){return r=>n[r]}_x2(t,{x:n}){return r=>n[r]}_y1({y:t},{y:n},{marginTop:r}){let{insetTop:i}=this;return n&&t?o=>n[o]+i:r+i}_y2({y:t},{y:n},{height:r,marginBottom:i}){let{insetBottom:o}=this;return n&&t?s=>n[s]+t.bandwidth()-o:r-i-o}},Iy=class extends yv{constructor(t,n={}){let{x:r,y:i,inset:o=0,insetRight:s=o,insetLeft:a=o}=n;super(t,{y:{value:i,scale:"y"},x:{value:r,scale:"x",type:"band",optional:!0}},n),this.insetRight=Bt(s),this.insetLeft=Bt(a)}_transform(t,n,{y:r}){t.call(Et,n,{y:r},0,Ce)}_x1({x:t},{x:n},{marginLeft:r}){let{insetLeft:i}=this;return n&&t?o=>n[o]+i:r+i}_x2({x:t},{x:n},{width:r,marginRight:i}){let{insetRight:o}=this;return n&&t?s=>n[s]+t.bandwidth()-o:r-i-o}_y1(t,{y:n}){return r=>n[r]}_y2(t,{y:n}){return r=>n[r]}};function gv(e,{x:t=G,...n}={}){return new Sy(e,{...n,x:t})}function xv(e,{y:t=G,...n}={}){return new Iy(e,{...n,y:t})}function g9(e,{x:t=G,y:n=null,fill:r="#ccc",fillOpacity:i,stroke:o="currentColor",strokeOpacity:s,strokeWidth:a=2,sort:c,...l}={}){let u=n!=null?tc:Hm;return tn(Xr(e,u({x1:u3,x2:f3},{x:t,y:n,stroke:o,strokeOpacity:s,...l})),Jo(e,u({x1:"p25",x2:"p75"},{x:t,y:n,fill:r,fillOpacity:i,...l})),gv(e,u({x:"p50"},{x:t,y:n,stroke:o,strokeOpacity:s,strokeWidth:a,sort:c,...l})),_i(e,_r({x:b9},{x:t,y:n,z:n,stroke:o,strokeOpacity:s,...l})))}function x9(e,{y:t=G,x:n=null,fill:r="#ccc",fillOpacity:i,stroke:o="currentColor",strokeOpacity:s,strokeWidth:a=2,sort:c,...l}={}){let u=n!=null?Ka:Hm;return tn(Yr(e,u({y1:u3,y2:f3},{x:n,y:t,stroke:o,strokeOpacity:s,...l})),Qo(e,u({y1:"p25",y2:"p75"},{x:n,y:t,fill:r,fillOpacity:i,...l})),xv(e,u({y:"p50"},{x:n,y:t,stroke:o,strokeOpacity:s,strokeWidth:a,sort:c,...l})),_i(e,_r({y:b9},{x:n,y:t,z:n,stroke:o,strokeOpacity:s,...l})))}function b9(e){let t=u3(e),n=f3(e);return e.map(r=>r<t||r>n?r:NaN)}function u3(e){let t=w9(e)*2.5-v9(e)*1.5;return ue(e,n=>n>=t?n:NaN)}function f3(e){let t=v9(e)*2.5-w9(e)*1.5;return Ht(e,n=>n<=t?n:NaN)}function w9(e){return Kn(e,.25)}function v9(e){return Kn(e,.75)}var Ott={ariaLabel:"raster",stroke:null,pixelSize:1};function lh(e,t){let n=+e;if(isNaN(n))throw new Error(`invalid ${t}: ${e}`);return n}function _9(e,t){let n=Math.floor(e);if(isNaN(n))throw new Error(`invalid ${t}: ${e}`);return n}var Ay=class extends St{constructor(t,n,r={},i){let{width:o,height:s,x:a,y:c,x1:l=a==null?0:void 0,y1:u=c==null?0:void 0,x2:f=a==null?o:void 0,y2:h=c==null?s:void 0,pixelSize:d=i.pixelSize,blur:p=0,interpolate:m}=r;if(o!=null&&(o=_9(o,"width")),s!=null&&(s=_9(s,"height")),l!=null&&(l=lh(l,"x1")),u!=null&&(u=lh(u,"y1")),f!=null&&(f=lh(f,"x2")),h!=null&&(h=lh(h,"y2")),a==null&&(l==null||f==null))throw new Error("missing x");if(c==null&&(u==null||h==null))throw new Error("missing y");t!=null&&o!=null&&s!=null&&(a===void 0&&l!=null&&f!=null&&(a=Ptt(l,f,o,s)),c===void 0&&u!=null&&h!=null&&(c=Utt(u,h,o,s))),super(t,{x:{value:a,scale:"x",optional:!0},y:{value:c,scale:"y",optional:!0},x1:{value:l==null?null:[l],scale:"x",optional:!0,filter:null},y1:{value:u==null?null:[u],scale:"y",optional:!0,filter:null},x2:{value:f==null?null:[f],scale:"x",optional:!0,filter:null},y2:{value:h==null?null:[h],scale:"y",optional:!0,filter:null},...n},r,i),this.width=o,this.height=s,this.pixelSize=lh(d,"pixelSize"),this.blur=lh(p,"blur"),this.interpolate=a==null||c==null?null:Btt(m)}},Ty=class extends Ay{constructor(t,n={}){let{imageRendering:r}=n;if(t==null){let{fill:i,fillOpacity:o}=n;se(o)[0]!==void 0&&(n=bv("fillOpacity",n)),Be(i)[0]!==void 0&&(n=bv("fill",n))}super(t,void 0,n,Ott),this.imageRendering=fe(r,"auto")}scale(t,{color:n,...r},i){return super.scale(t,r,i)}render(t,n,r,i,o){let s=n[r.channels.fill?.scale]??(T=>T),{x:a,y:c}=r,{document:l}=o,[u,f,h,d]=I9(r,i,o),p=h-u,m=d-f,{pixelSize:y,width:g=Math.round(Math.abs(p)/y),height:x=Math.round(Math.abs(m)/y)}=this,b=g*x,{fill:w,fillOpacity:_}=r,v=0;if(this.interpolate){let T=g/p,N=x/m,F=Gt(a,k=>(k-u)*T,Float64Array),R=Gt(c,k=>(k-f)*N,Float64Array);w&&(w=this.interpolate(t,g,x,F,R,w)),_&&(_=this.interpolate(t,g,x,F,R,_))}else this.data==null&&t&&(v=t.fi*b);let M=l.createElement("canvas");M.width=g,M.height=x;let E=M.getContext("2d"),I=E.createImageData(g,x),D=I.data,{r:A,g:O,b:C}=rn(this.fill)??{r:0,g:0,b:0},S=(this.fillOpacity??1)*255;for(let T=0;T<b;++T){let N=T<<2;if(w){let F=s(w[T+v]);if(F==null){D[N+3]=0;continue}({r:A,g:O,b:C}=rn(F))}_&&(S=_[T+v]*255),D[N+0]=A,D[N+1]=O,D[N+2]=C,D[N+3]=S}return this.blur>0&&zS(I,this.blur),E.putImageData(I,0,0),ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(T=>T.append("image").attr("transform",`translate(${u},${f}) scale(${Math.sign(h-u)},${Math.sign(d-f)})`).attr("width",Math.abs(p)).attr("height",Math.abs(m)).attr("preserveAspectRatio","none").call(ft,"image-rendering",this.imageRendering).call(Lt,this).attr("xlink:href",M.toDataURL())).node()}};function h3(e,t,n){arguments.length<3&&(n=t,t=null);let{x:r,y:i,[e]:o,...s}=n;return r===void 0&&i===void 0&&tR(t)&&(r=Il,i=Wa,o===void 0&&(o=HF)),[t,{...s,x:r,y:i,[e]:o}]}function S9(){let[e,t]=h3("fill",...arguments);return new Ty(e,e==null||t.fill!==void 0||t.fillOpacity!==void 0?t:{...t,fill:G})}function I9({x1:e,y1:t,x2:n,y2:r},i,{projection:o}){let{width:s,height:a,marginTop:c,marginRight:l,marginBottom:u,marginLeft:f}=i;return[e&&o==null?e[0]:f,t&&o==null?t[0]:c,n&&o==null?n[0]:s-l,r&&o==null?r[0]:a-u]}function d3({x1:e,y1:t,x2:n,y2:r},i,o,s){let a={};return e&&(a.x1=e),t&&(a.y1=t),n&&(a.x2=n),r&&(a.y2=r),I9(Lf(a,i),o,s)}function bv(e,t={}){let{[e]:n}=t;if(typeof n!="function")throw new Error(`invalid ${e}: not a function`);return Ie({...t,[e]:void 0},function(r,i,o,s,a,c){let{x:l,y:u}=s;if(!l)throw new Error("missing scale: x");if(!u)throw new Error("missing scale: y");let[f,h,d,p]=d3(o,s,a,c),m=d-f,y=p-h,{pixelSize:g}=this,{width:x=Math.round(Math.abs(m)/g),height:b=Math.round(Math.abs(y)/g)}=t,w=new Array(x*b*(i?i.length:1)),_=m/x,v=y/b,M=0;for(let E of i??[void 0])for(let I=.5;I<b;++I)for(let D=.5;D<x;++D,++M)w[M]=n(l.invert(f+D*_),u.invert(h+I*v),E);return{data:w,facets:i,channels:{[e]:{value:w,scale:"auto"}}}})}function Btt(e){if(typeof e=="function")return e;if(e==null)return wv;switch(`${e}`.toLowerCase()){case"none":return wv;case"nearest":return Ny;case"barycentric":return Ey();case"random-walk":return Dy()}throw new Error(`invalid interpolate: ${e}`)}function wv(e,t,n,r,i,o){let s=new Array(t*n);for(let a of e)r[a]<0||r[a]>=t||i[a]<0||i[a]>=n||(s[Math.floor(i[a])*t+Math.floor(r[a])]=o[a]);return s}function Ey({random:e=fl(42)}={}){return(t,n,r,i,o,s)=>{let{points:a,triangles:c,hull:l}=di.from(t,d=>i[d],d=>o[d]),u=new s.constructor(n*r).fill(NaN),f=new Uint8Array(n*r),h=$tt(s,e);for(let d=0;d<c.length;d+=3){let p=c[d],m=c[d+1],y=c[d+2],g=a[2*p],x=a[2*m],b=a[2*y],w=a[2*p+1],_=a[2*m+1],v=a[2*y+1],M=Math.min(g,x,b),E=Math.max(g,x,b),I=Math.min(w,_,v),D=Math.max(w,_,v),A=(_-v)*(g-b)+(w-v)*(b-x);if(!A)continue;let O=s[t[p]],C=s[t[m]],S=s[t[y]];for(let T=Math.floor(M);T<E;++T)for(let N=Math.floor(I);N<D;++N){if(T<0||T>=n||N<0||N>=r)continue;let F=T+.5,R=N+.5,k=((_-v)*(F-b)+(R-v)*(b-x))/A;if(k<0)continue;let $=((v-w)*(F-b)+(R-v)*(g-b))/A;if($<0)continue;let P=1-k-$;if(P<0)continue;let U=T+n*N;u[U]=h(O,k,C,$,S,P,T,N),f[U]=1}}return Ltt(u,f,i,o,s,n,r,l,t,h),u}}function Ltt(e,t,n,r,i,o,s,a,c,l){n=Float64Array.from(a,d=>n[c[d]]),r=Float64Array.from(a,d=>r[c[d]]),i=Array.from(a,d=>i[c[d]]);let u=n.length,f=Array.from({length:u},(d,p)=>ktt(p,n,r)),h=0;for(let d=0;d<s;++d){let p=d+.5;for(let m=0;m<o;++m){let y=m+o*d;if(!t[y]){let g=m+.5;for(let x=0;x<u;++x){let b=(u+h+(x%2?(x+1)/2:-x/2))%u;if(f[b](g,p)){let w=Ctt(n.at(b-1),r.at(b-1),n[b],r[b],g,p);e[y]=l(i.at(b-1),w,i[b],1-w,i[b],0,m,d),h=b;break}}}}}}function Ctt(e,t,n,r,i,o){let s=n-e,a=r-t,c=s*(n-i)+a*(r-o),l=s*(i-e)+a*(o-t);return c>0&&l>0?c/(c+l):+(c>l)}function My(e,t,n,r){return e*r-n*t}function ktt(e,t,n){let r=t.length,i=t.at(e-2),o=n.at(e-2),s=t.at(e-1),a=n.at(e-1),c=t[e],l=n[e],u=t.at(e+1-r),f=n.at(e+1-r),h=s-c,d=a-l,p=i-s,m=o-a,y=c-u,g=l-f,x=Math.hypot(h,d),b=Math.hypot(p,m),w=Math.hypot(y,g);return(_,v)=>{let M=_-s,E=v-a,I=_-c,D=v-l;return My(M,E,I,D)>-1e-6&&My(M,E,h,d)*b-My(M,E,p,m)*x>-1e-6&&My(I,D,y,g)*x-My(I,D,h,d)*w<=0}}function Ny(e,t,n,r,i,o){let s=new o.constructor(t*n),a=di.from(e,u=>r[u],u=>i[u]),c,l;for(let u=.5,f=0;u<n;++u){l=c;for(let h=.5;h<t;++h,++f)l=a.find(h,u,l),h===.5&&(c=l),s[f]=o[e[l]]}return s}function Dy({random:e=fl(42),minDistance:t=.5,maxSteps:n=2}={}){return(r,i,o,s,a,c)=>{let l=new c.constructor(i*o),u=di.from(r,p=>s[p],p=>a[p]),f,h,d;for(let p=.5,m=0;p<o;++p){h=f;for(let y=.5;y<i;++y,++m){let g=y,x=p;d=h=u.find(g,x,h),y===.5&&(f=h);let b,w=0;for(;(b=Math.hypot(s[r[d]]-g,a[r[d]]-x))>t&&w<n;){let _=e(y,p,w)*2*Math.PI;g+=Math.cos(_)*b,x+=Math.sin(_)*b,d=u.find(g,x,d),++w}l[m]=c[r[d]]}}return l}}function Ftt(e,t,n,r,i,o){return t*e+r*n+o*i}function Rtt(e){return(t,n,r,i,o,s,a,c)=>{let l=e(a,c);return l<n?t:l<n+i?r:o}}function $tt(e,t){return Js(e)||Le(e)?Ftt:Rtt(t)}function Ptt(e,t,n){return{transform(r){let i=r.length,o=new Float64Array(i),s=(t-e)/n,a=e+s/2;for(let c=0;c<i;++c)o[c]=c%n*s+a;return o}}}function Utt(e,t,n,r){return{transform(i){let o=i.length,s=new Float64Array(o),a=(t-e)/r,c=e+a/2;for(let l=0;l<o;++l)s[l]=Math.floor(l/n)%r*a+c;return s}}}var M9={ariaLabel:"contour",fill:"none",stroke:"currentColor",strokeMiterlimit:1,pixelSize:2},Oy=class extends Ay{constructor(t,{smooth:n=!0,value:r,...i}={}){let o=Ow({},i,M9);if(r===void 0){for(let a in o)if(o[a].value!=null){if(r!==void 0)throw new Error("ambiguous contour value");r=i[a],i[a]="value"}}if(r!=null){let a={transform:c=>c.map(l=>l.value),label:Bn(r)};for(let c in o)i[c]==="value"&&(i[c]=a)}if(t==null){if(r==null)throw new Error("missing contour value");i=bv("value",{value:r,...i}),r=null}else{let{interpolate:a}=i;r===void 0&&(r=G),a===void 0&&(i.interpolate="nearest")}super(t,{value:{value:r,optional:!0}},ztt(i),M9);let s={geometry:{value:G}};for(let a in this.channels){let c=this.channels[a],{scale:l}=c;l==="x"||l==="y"||a==="value"||(s[a]=c,delete this.channels[a])}this.contourChannels=s,this.smooth=!!n}filter(t,{x:n,y:r,value:i,...o},s){return super.filter(t,o,s)}render(t,n,r,i,o){let{geometry:s}=r,a=Nn();return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(c=>{c.selectAll().data(t).enter().append("path").call(Lt,this).attr("d",l=>a(s[l])).call(Qt,this,r)}).node()}};function ztt({thresholds:e,interval:t,...n}){return e=r3(e,t,Ea),Ie(n,function(r,i,o,s,a,c){let[l,u,f,h]=d3(o,s,a,c),d=f-l,p=h-u,{pixelSize:m,width:y=Math.round(Math.abs(d)/m),height:g=Math.round(Math.abs(p)/m)}=this,x=y/d,b=g/p,w=o.value.value,_=[];if(this.interpolate){let{x:D,y:A}=nc(o,s,c),O=Gt(D,N=>(N-l)*x,Float64Array),C=Gt(A,N=>(N-u)*b,Float64Array),S=[o.x,o.y,o.value],T=[O,C,w];for(let N of i){let F=this.filter(N,S,T);_.push(this.interpolate(F,y,g,O,C,w))}}else if(i){let D=y*g,A=i.length;for(let O=0;O<A;++O)_.push(w.slice(O*D,O*D+D))}else _.push(w);if(this.blur>0)for(let D of _)ap({data:D,width:y,height:g},this.blur);let v=qtt(e,w,...jtt(_));if(v===null)throw new Error(`unsupported thresholds: ${e}`);let{contour:M}=ka().size([y,g]).smooth(this.smooth),E=[],I=[];for(let D of _)I.push(Ue(E.length,E.push(...Gt(v,A=>M(D,A)))));for(let{coordinates:D}of E)for(let A of D)for(let O of A)for(let C of O)C[0]=C[0]/x+l,C[1]=C[1]/b+u;return{data:E,facets:I,channels:vw(this.contourChannels,E)}})}function qtt(e,t,n,r){if(typeof e?.range=="function")return e.range(e.floor(n),r);if(typeof e=="function"&&(e=e(t,n,r)),typeof e!="number")return je(e);let i=An(...Du(n,r,e),e);for(;i[i.length-1]>=r;)i.pop();for(;i[1]<n;)i.shift();return i}function T9(){return new Oy(...h3("value",...arguments))}function jtt(e){return[ue(e,t=>ue(t,A9)),Ht(e,t=>Ht(t,A9))]}function A9(e){return isFinite(e)?e:NaN}function D9(e,t){return p3(qf,e,t)}function O9(e,t={}){return p3(jf,e,t)}function B9(e,t={}){return p3(Dl,e,t)}function p3(e,t,n={}){let{x:r,y:i,maxRadius:o}=n,s=e({px:r,py:i,maxRadius:o}),a=[];r!=null&&a.push(Yr(t,E9("x",{...s,inset:-6},n))),i!=null&&a.push(Xr(t,E9("y",{...s,inset:-6},n))),r!=null&&a.push(Wo(t,N9("x",{...s,dy:9,frameAnchor:"bottom",lineAnchor:"top"},n))),i!=null&&a.push(Wo(t,N9("y",{...s,dx:-9,frameAnchor:"left",textAnchor:"end"},n)));for(let c of a)c.ariaLabel=`crosshair ${c.ariaLabel}`;return tn(...a)}function L9(e,{channels:t,...n},{facet:r,facetAnchor:i,fx:o,fy:s,[e]:a,channels:c,transform:l,initializer:u}){return{...n,facet:r,facetAnchor:i,fx:o,fy:s,[e]:a,channels:{...t,...c},transform:l,initializer:Vtt(e,u)}}function Vtt(e,t){return t==null?t:function(n,r,{x:i,y:o,px:s,py:a,...c},...l){let{channels:{x:u,y:f,...h}={},...d}=t.call(this,n,r,{...c,x:s,y:a},...l);return{channels:{...h,...u&&{px:u,...e==="x"&&{x:u}},...f&&{py:f,...e==="y"&&{y:f}}},...d}}}function E9(e,t,n){let{color:r="currentColor",opacity:i=.2,ruleStroke:o=r,ruleStrokeOpacity:s=i,ruleStrokeWidth:a}=n;return{...L9(e,t,n),stroke:o,strokeOpacity:s,strokeWidth:a}}function N9(e,t,n){let{color:r="currentColor",textFill:i=r,textFillOpacity:o,textStroke:s="var(--plot-background)",textStrokeOpacity:a,textStrokeWidth:c=5}=n;return{...L9(e,t,Ytt(e,n)),fill:i,fillOpacity:o,stroke:s,strokeOpacity:a,strokeWidth:c}}function Ytt(e,t){return Ie(t,(n,r,i)=>({channels:{text:{value:Qm(i,e)?.value}}}))}var Xtt={ariaLabel:"delaunay link",fill:"none",stroke:"currentColor",strokeMiterlimit:1},Gtt={ariaLabel:"delaunay mesh",fill:null,stroke:"currentColor",strokeOpacity:.2},Wtt={ariaLabel:"hull",fill:"none",stroke:"currentColor",strokeWidth:1.5,strokeMiterlimit:1},Htt={ariaLabel:"voronoi",fill:"none",stroke:"currentColor",strokeMiterlimit:1},Ztt={ariaLabel:"voronoi mesh",fill:null,stroke:"currentColor",strokeOpacity:.2},m3=class extends St{constructor(t,n={}){let{x:r,y:i,z:o,curve:s,tension:a}=n;super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},z:{value:o,optional:!0}},n,Xtt),this.curve=dy(s,a),Gi(this,n)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,z:u}=r,{curve:f}=this,[h,d]=bn(this,i),p=c?x=>c[x]:pn(h),m=l?x=>l[x]:pn(d),y=this;function g(x){let b=-1,w=[],_={};for(let S in r)_[S]=[];let v=[],M=[],E=[],I=[];function D(S,T){S=x[S],T=x[T],w.push(++b),v[b]=p(S),E[b]=m(S),M[b]=p(T),I[b]=m(T);for(let N in r)_[N].push(r[N][T])}let{halfedges:A,hull:O,triangles:C}=di.from(x,p,m);for(let S=0;S<A.length;++S){let T=A[S];T>S&&D(C[S],C[T])}for(let S=0;S<O.length;++S)D(O[S],O[(S+1)%O.length]);Vt(this).selectAll().data(w).enter().append("path").call(Lt,y).attr("d",S=>{let T=nr(),N=f(T);return N.lineStart(),N.point(v[S],E[S]),N.point(M[S],I[S]),N.lineEnd(),T}).call(Qt,y,_).call(ra,y,_,o)}return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(u?x=>x.selectAll().data(ln(t,b=>u[b]).values()).enter().append("g").each(g):x=>x.datum(t).each(g)).node()}},By=class extends St{constructor(t,n={},r,i=({z:o})=>o){let{x:o,y:s}=n;super(t,{x:{value:o,scale:"x",optional:!0},y:{value:s,scale:"y",optional:!0},z:{value:i(n),optional:!0}},n,r)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,z:u}=r,[f,h]=bn(this,i),d=c?g=>c[g]:pn(f),p=l?g=>l[g]:pn(h),m=this;function y(g){let x=di.from(g,d,p);Vt(this).append("path").datum(g[0]).call(Lt,m).attr("d",m._render(x,i)).call(Qt,m,r)}return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(u?g=>g.selectAll().data(ln(t,x=>u[x]).values()).enter().append("g").each(y):g=>g.datum(t).each(y)).node()}},y3=class extends By{constructor(t,n={}){super(t,n,Gtt),this.fill="none"}_render(t){return t.render()}},g3=class extends By{constructor(t,n={}){super(t,n,Wtt,jn)}_render(t){return t.renderHull()}},x3=class extends St{constructor(t,n={}){let{x:r,y:i,z:o}=n;super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},z:{value:o,optional:!0}},n,Htt)}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,z:u}=r,[f,h]=bn(this,i),d=c?g=>c[g]:pn(f),p=l?g=>l[g]:pn(h),m=this;function y(g){let x=di.from(g,d,p),b=C9(x,i);Vt(this).selectAll().data(g).enter().append("path").call(Lt,m).attr("d",(w,_)=>b.renderCell(_)).call(Qt,m,r)}return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(u?g=>g.selectAll().data(ln(t,x=>u[x]).values()).enter().append("g").each(y):g=>g.datum(t).each(y)).node()}},b3=class extends By{constructor(t,n){super(t,n,Ztt),this.fill="none"}_render(t,n){return C9(t,n).render()}};function C9(e,t){let{width:n,height:r,marginTop:i,marginRight:o,marginBottom:s,marginLeft:a}=t;return e.voronoi([a,i,n-o,r-s])}function Ly(e,t,{x:n,y:r,...i}={}){return[n,r]=Pe(n,r),new e(t,{...i,x:n,y:r})}function k9(e,t){return Ly(m3,e,t)}function F9(e,t){return Ly(y3,e,t)}function R9(e,t){return Ly(g3,e,t)}function $9(e,t){return Ly(x3,e,t)}function P9(e,t){return Ly(b3,e,t)}var Jtt={ariaLabel:"density",fill:"none",stroke:"currentColor",strokeMiterlimit:1},Cy=class extends St{constructor(t,{x:n,y:r,z:i,weight:o,fill:s,stroke:a,...c}={}){let l=U9(s)&&(s="currentColor",!0),u=U9(a)&&(a="currentColor",!0);super(t,{x:{value:n,scale:"x",optional:!0},y:{value:r,scale:"y",optional:!0},z:{value:jn({z:i,fill:s,stroke:a}),optional:!0},weight:{value:o,optional:!0}},Ktt({...c,fill:s,stroke:a},l,u),Jtt),l&&(this.fill=void 0),u&&(this.stroke=void 0),this.z=i}filter(t){return t}render(t,n,r,i,o){let{contours:s}=r,a=Nn();return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{}).call(c=>c.selectAll().data(t).enter().append("path").call(Lt,this).call(Qt,this,r).attr("d",l=>a(s[l]))).node()}};function z9(e,{x:t,y:n,...r}={}){return[t,n]=Pe(t,n),new Cy(e,{...r,x:t,y:n})}var Qtt=new Set(["x","y","z","weight"]);function Ktt(e,t,n){let{bandwidth:i,thresholds:o}=e;return i=i===void 0?20:+i,o=o===void 0?20:typeof o?.[Symbol.iterator]=="function"?Ke(o):+o,Ie(e,function(s,a,c,l,u,f){let h=c.weight?Ke(c.weight.value):null,d=c.z?.value,{z:p}=this,[m,y]=bn(this,u),{width:g,height:x}=u,{x:b,y:w}=nc(c,l,f),_=Object.fromEntries(Object.entries(c).filter(([C])=>!Qtt.has(C)).map(([C,S])=>[C,{...S,value:[]}])),v=t&&[],M=n&&[],E=NI().x(b?C=>b[C]:m).y(w?C=>w[C]:y).weight(h?C=>h[C]:1).size([g,x]).bandwidth(i),I=[];for(let C of a){let S=[];I.push(S);for(let T of d?ry(C,d,p):[C]){let N=E.contours(T);S.push([T,N])}}let D=o;if(!(D instanceof Sl)){let C=0;for(let S of I)for(let[,T]of S){let N=T.max;N>C&&(C=N)}D=Float64Array.from({length:o-1},(S,T)=>C*100*(T+1)/o)}let A=[],O=[];for(let C of I){let S=[];A.push(S);for(let[T,N]of C)for(let F of D){S.push(O.length),O.push(N(F/100)),v&&v.push(F),M&&M.push(F);for(let R in _)_[R].value.push(c[R].value[T[0]])}}return v&&v.push(0),M&&M.push(0),{data:s,facets:A,channels:{..._,...v&&{fill:{value:v,scale:"color"}},...M&&{stroke:{value:M,scale:"color"}},contours:{value:O}}}})}function U9(e){return/^density$/i.test(e)}function V9(e,{x1:t,x2:n,y1:r,y2:i,x:o=t===void 0&&n===void 0?Ee:void 0,y:s=r===void 0&&i===void 0?G:void 0,fill:a,positiveFill:c="#3ca951",negativeFill:l="#4269d0",fillOpacity:u=1,positiveFillOpacity:f=u,negativeFillOpacity:h=u,stroke:d,strokeOpacity:p,z:m=Be(d)[0],clip:y,tip:g,render:x,...b}={}){return[t,n]=q9(o,t,n),[r,i]=q9(s,r,i),t===n&&r===i&&(r=dc(0)),{tip:g}=Xi({tip:g},"x"),tn(re(c)?null:Object.assign(py(e,{x1:t,x2:n,y1:r,y2:i,z:m,fill:c,fillOpacity:f,render:zf(x,j9(!0)),clip:y,...b}),{ariaLabel:"positive difference"}),re(l)?null:Object.assign(py(e,{x1:t,x2:n,y1:r,y2:i,z:m,fill:l,fillOpacity:h,render:zf(x,j9(!1)),clip:y,...b}),{ariaLabel:"negative difference"}),zl(e,{x:n,y:i,z:m,stroke:d,strokeOpacity:p,tip:g,clip:!0,...b}))}function q9(e,t,n){return t===void 0&&n===void 0?t=n=dc(e):t===void 0?(n=dc(n),t=e===void 0?n:dc(e)):n===void 0?(t=dc(t),n=e===void 0?t:dc(e)):(t=dc(t),n=dc(n)),[t,n]}function dc(e){let t,{value:n,label:r=Bn(n)}=wi(e);return{transform:i=>t||(t=wt(i,n)),label:r}}function j9(e){return(t,n,r,i,o,s)=>{let{x1:a,x2:c}=r,{height:l}=i,u=new Float32Array(a.length),f=new Float32Array(c.length);(e===Aw(n.y)<0?u:f).fill(l);let h=s(t,n,{...r,x2:a,y2:f},i,o),d=s(t,n,{...r,x1:c,y1:u},i,o),p=h.querySelector("g")??h,m=d.querySelector("g")??d;for(let y=0;p.firstChild;y+=2){let g=Dw(),x=ut("svg:clipPath",o).attr("id",g).node();x.appendChild(p.firstChild),m.childNodes[y].setAttribute("clip-path",`url(#${g})`),m.insertBefore(x,m.childNodes[y])}return d}}var tet={ariaLabel:"geo",fill:"none",stroke:"currentColor",strokeWidth:1,strokeLinecap:"round",strokeLinejoin:"round",strokeMiterlimit:1},ky=class extends St{constructor(t,n={}){let[r,i]=se(n.r,3);super(t,{geometry:{value:n.geometry,scale:"projection"},r:{value:r,scale:"r",filter:ar,optional:!0}},wy(n),tet),this.r=i}render(t,n,r,i,o){let{geometry:s,r:a}=r,c=Nn(o.projection??eet(n)),{r:l}=this;return ja(l)?t=[]:l!==void 0&&c.pointRadius(l),ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(u=>{u.selectAll().data(t).enter().append("path").call(Lt,this).attr("d",a?f=>c.pointRadius(a[f])(s[f]):f=>c(s[f])).call(Qt,this,r)}).node()}};function eet({x:e,y:t}){if(e||t)return e??=n=>n,t??=n=>n,ll({point(n,r){this.stream.point(e(n),t(r))}})}function vv(e,{geometry:t=G,...n}={}){switch(e?.type){case"FeatureCollection":e=e.features;break;case"GeometryCollection":e=e.geometries;break;case"Feature":case"LineString":case"MultiLineString":case"MultiPoint":case"MultiPolygon":case"Point":case"Polygon":case"Sphere":e=[e];break}return new ky(e,{geometry:t,...n})}function Y9({strokeWidth:e=1.5,...t}={}){return vv({type:"Sphere"},{strokeWidth:e,...t})}function X9({strokeOpacity:e=.1,...t}={}){return vv(JI(),{strokeOpacity:e,...t})}var uh=.5,fh=0;function G9(e={fill:"count"},{binWidth:t,...n}={}){let{z:r}=n;return t=t===void 0?20:Bt(t),e=hT(e,n),Xo(e,"fill")&&(n.channels={...n.channels,fill:{value:[]}}),n.symbol===void 0&&(n.symbol="hexagon"),n.r===void 0&&!Xo(e,"r")&&(n.r=t/2),Ie(n,(i,o,s,a,c,l)=>{let{x:u,y:f,z:h,fill:d,stroke:p,symbol:m}=s;if(u===void 0)throw new Error("missing channel: x");if(f===void 0)throw new Error("missing channel: y");({x:u,y:f}=nc(s,a,l)),h=h?h.value:wt(i,r),d=d?.value,p=p?.value,m=m?.value;let y=Jm(e,{z:h,fill:d,stroke:p,symbol:m}),g=h&&[],x=d&&[],b=p&&[],w=m&&[],_=[],v=[],M=[],E=-1;for(let O of e)O.initialize(i);for(let O of o){let C=[];for(let S of e)S.scope("facet",O);for(let[S,T]of Qa(O,y))for(let{index:N,extent:F}of net(i,T,u,f,t)){C.push(++E),v.push(F.x),M.push(F.y),h&&g.push(y===h?S:h[N[0]]),d&&x.push(y===d?S:d[N[0]]),p&&b.push(y===p?S:p[N[0]]),m&&w.push(y===m?S:m[N[0]]);for(let R of e)R.reduce(N,F)}_.push(C)}let I=s.x.scale,D=s.y.scale,A={x:{value:v,source:a[I]?{value:Gt(v,a[I].invert),scale:I}:null},y:{value:M,source:a[D]?{value:Gt(M,a[D].invert),scale:D}:null},...h&&{z:{value:g}},...d&&{fill:{value:x,scale:"auto"}},...p&&{stroke:{value:b,scale:"auto"}},...m&&{symbol:{value:w,scale:"auto"}},...Object.fromEntries(e.map(({name:O,output:C})=>[O,{scale:"auto",label:C.label,radius:O==="r"?t/2:void 0,value:C.transform()}]))};return{data:i,facets:_,channels:A}})}function net(e,t,n,r,i){let o=i*(1.5/nT),s=new Map;for(let a of t){let c=n[a],l=r[a];if(isNaN(c)||isNaN(l))continue;let u=Math.round(l=(l-fh)/o),f=Math.round(c=(c-uh)/i-(u&1)/2),h=l-u;if(Math.abs(h)*3>1){let m=c-f,y=f+(c<f?-1:1)/2,g=u+(l<u?-1:1),x=c-y,b=l-g;m*m+h*h>x*x+b*b&&(f=y+(u&1?1:-1)/2,u=g)}let d=`${f},${u}`,p=s.get(d);p===void 0&&(p={index:[],extent:{data:e,x:(f+(u&1)/2)*i+uh,y:u*o+fh}},s.set(d,p)),p.index.push(a)}return s.values()}var ret={ariaLabel:"hexgrid",fill:"none",stroke:"currentColor",strokeOpacity:.1};function W9(e){return new Fy(e)}var Fy=class extends St{constructor({binWidth:t=20,clip:n=!0,...r}={}){super(Ga,void 0,{clip:n,...r},ret),this.binWidth=Bt(t)}render(t,n,r,i,o){let{binWidth:s}=this,{marginTop:a,marginRight:c,marginBottom:l,marginLeft:u,width:f,height:h}=i,d=u-uh,p=f-c-uh,m=a-fh,y=h-l-fh,g=s/2,x=g*rT,b=x/2,w=g*2,_=x*1.5,v=Math.floor(d/w),M=Math.ceil(p/w),E=Math.floor((m+b)/_),I=Math.ceil((y-b)/_)+1,D=`m0,${pc(-x)}l${pc(g)},${pc(b)}v${pc(x)}l${pc(-g)},${pc(b)}`,A=D;for(let O=E;O<I;++O)for(let C=v;C<M;++C)A+=`M${pc(C*w+(O&1)*g)},${pc(O*_)}${D}`;return ut("svg:g",o).datum(0).call(Ct,this,i,o).call(Et,this,{},Ce+uh,Ce+fh).call(O=>O.append("path").call(Lt,this).call(Qt,this,r).attr("d",A)).node()}};function pc(e){return Math.round(e*1e3)/1e3}var iet={ariaLabel:"image",fill:null,stroke:null};function oet(e){return/^\.*\//.test(e)}function set(e){return/^(blob|data|file|http|https):/i.test(e)}function aet(e){return typeof e=="string"&&(oet(e)||set(e))?[void 0,e]:[e,void 0]}var Ry=class extends St{constructor(t,n={}){let{x:r,y:i,r:o,width:s,height:a,rotate:c,src:l,preserveAspectRatio:u,crossOrigin:f,frameAnchor:h,imageRendering:d}=n;o==null&&(o=void 0),o===void 0&&s===void 0&&a===void 0?s=a=16:s===void 0&&a!==void 0?s=a:a===void 0&&s!==void 0&&(a=s);let[p,m]=aet(l),[y,g]=se(o),[x,b]=se(s,g!==void 0?g*2:void 0),[w,_]=se(a,g!==void 0?g*2:void 0),[v,M]=se(c,0);super(t,{x:{value:r,scale:"x",optional:!0},y:{value:i,scale:"y",optional:!0},r:{value:y,scale:"r",filter:ar,optional:!0},width:{value:x,filter:ar,optional:!0},height:{value:w,filter:ar,optional:!0},rotate:{value:v,optional:!0},src:{value:p,optional:!0}},wy(n),iet),this.src=m,this.width=b,this.rotate=M,this.height=_,this.r=g,this.preserveAspectRatio=fe(u,"xMidYMid"),this.crossOrigin=qe(f),this.frameAnchor=Yo(h),this.imageRendering=fe(d,"auto")}render(t,n,r,i,o){let{x:s,y:a}=n,{x:c,y:l,width:u,height:f,r:h,rotate:d,src:p}=r,{r:m,width:y,height:g,rotate:x}=this,[b,w]=bn(this,i);return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,{x:c&&s,y:l&&a}).call(_=>_.selectAll().data(t).enter().append("image").call(Lt,this).attr("x",H9(c,u,h,b,y,m)).attr("y",H9(l,f,h,w,g,m)).attr("width",u?v=>u[v]:y!==void 0?y:h?v=>h[v]*2:m*2).attr("height",f?v=>f[v]:g!==void 0?g:h?v=>h[v]*2:m*2).attr("transform",d?v=>`rotate(${d[v]})`:x?`rotate(${x})`:null).attr("transform-origin",d||x?oc`${c?v=>c[v]:b}px ${l?v=>l[v]:w}px`:null).call(ft,"href",p?v=>p[v]:this.src).call(ft,"preserveAspectRatio",this.preserveAspectRatio).call(ft,"crossorigin",this.crossOrigin).call(ft,"image-rendering",this.imageRendering).call(ft,"clip-path",h?v=>`circle(${h[v]}px)`:m!==void 0?`circle(${m}px)`:null).call(Qt,this,r)).node()}};function H9(e,t,n,r,i,o){return t&&e?s=>e[s]-t[s]/2:t?s=>r-t[s]/2:e&&i!==void 0?s=>e[s]-i/2:i!==void 0?r-i/2:n&&e?s=>e[s]-n[s]:n?s=>r-n[s]:e?s=>e[s]-o:r-o}function Z9(e,{x:t,y:n,...r}={}){return r.frameAnchor===void 0&&([t,n]=Pe(t,n)),new Ry(e,{...r,x:t,y:n})}function cet(e,t,n){var r=1e-8,i=t-1,o=n-1,s=0,a,c,l,u,f,h,d,p,m,y,g;if(e<=0)return 0;if(e>=1)return 1;for(t>=1&&n>=1?(l=e<.5?e:1-e,u=Math.sqrt(-2*Math.log(l)),d=(2.30753+u*.27061)/(1+u*(.99229+u*.04481))-u,e<.5&&(d=-d),p=(d*d-3)/6,m=2/(1/(2*t-1)+1/(2*n-1)),y=d*Math.sqrt(p+m)/m-(1/(2*n-1)-1/(2*t-1))*(p+5/6-2/(3*m)),d=t/(t+n*Math.exp(2*y))):(a=Math.log(t/(t+n)),c=Math.log(n/(t+n)),u=Math.exp(t*a)/t,f=Math.exp(n*c)/n,y=u+f,e<u/y?d=Math.pow(t*y*e,1/t):d=1-Math.pow(n*y*(1-e),1/n)),g=-hh(t)-hh(n)+hh(t+n);s<10;s++){if(d===0||d===1)return d;if(h=uet(d,t,n)-e,u=Math.exp(i*Math.log(d)+o*Math.log(1-d)+g),f=h/u,d-=u=f/(1-.5*Math.min(1,f*(i/d-o/(1-d)))),d<=0&&(d=.5*(d+u)),d>=1&&(d=.5*(d+u+1)),Math.abs(u)<r*d&&s>0)break}return d}function uet(e,t,n){var r=e===0||e===1?0:Math.exp(hh(t+n)-hh(t)-hh(n)+t*Math.log(e)+n*Math.log(1-e));return e<0||e>1?!1:e<(t+1)/(t+n+2)?r*J9(e,t,n)/t:1-r*J9(1-e,n,t)/n}function J9(e,t,n){var r=1e-30,i=1,o=t+n,s=t+1,a=t-1,c=1,l=1-o*e/s,u,f,h,d;for(Math.abs(l)<r&&(l=r),l=1/l,d=l;i<=100&&(u=2*i,f=i*(n-i)*e/((a+u)*(t+u)),l=1+f*l,Math.abs(l)<r&&(l=r),c=1+f/c,Math.abs(c)<r&&(c=r),l=1/l,d*=l*c,f=-(t+i)*(o+i)*e/((t+u)*(s+u)),l=1+f*l,Math.abs(l)<r&&(l=r),c=1+f/c,Math.abs(c)<r&&(c=r),l=1/l,h=l*c,d*=h,!(Math.abs(h-1)<3e-7));i++);return d}function hh(e){var t=0,n=[76.18009172947146,-86.5053203294167,24.01409824083091,-1.231739572450155,.001208650973866179,-5395239384953e-18],r=1.000000000190015,i,o,s;for(s=(o=i=e)+5.5,s-=(i+.5)*Math.log(s);t<6;t++)r+=n[t]/++o;return Math.log(2.506628274631*r/i)-s}function Q9(e,t){var n=cet(2*Math.min(e,1-e),.5*t,.5);return n=Math.sqrt(t*(1-n)/n),e>.5?n:-n}var fet={ariaLabel:"linear-regression",fill:"currentColor",fillOpacity:.1,stroke:"currentColor",strokeWidth:1.5,strokeLinecap:"round",strokeLinejoin:"round",strokeMiterlimit:1},_v=class extends St{constructor(t,n={}){let{x:r,y:i,z:o,ci:s=.95,precision:a=4}=n;if(super(t,{x:{value:r,scale:"x"},y:{value:i,scale:"y"},z:{value:jn(n),optional:!0}},n,fet),this.z=o,this.ci=+s,this.precision=+a,!(0<=this.ci&&this.ci<1))throw new Error(`invalid ci; not in [0, 1): ${s}`);if(!(this.precision>0))throw new Error(`invalid precision: ${a}`)}render(t,n,r,i,o){let{x:s,y:a,z:c}=r,{ci:l}=this;return ut("svg:g",o).call(Ct,this,i,o).call(Et,this,n).call(u=>u.selectAll().data(c?ry(t,c,this.z):[t]).enter().call(f=>f.append("path").attr("fill","none").call(Lt,this).call(Nl,this,{...r,fill:null,fillOpacity:null}).attr("d",h=>this._renderLine(h,s,a)).call(l&&!Qs(this.fill)?h=>h.select(het).attr("stroke","none").call(Lt,this).call(Nl,this,{...r,stroke:null,strokeOpacity:null,strokeWidth:null}).attr("d",d=>this._renderBand(d,s,a)):()=>{}))).node()}};function het(){return this.parentNode.insertBefore(this.ownerDocument.createElementNS(ui.svg,"path"),this)}var w3=class extends _v{constructor(t,n){super(t,n)}_renderBand(t,n,r){let{ci:i,precision:o}=this,[s,a]=le(t,u=>r[u]),c=Sv(t,r,n),l=eP(t,r,n,(1-i)/2,c);return pf().y(u=>u).x0(u=>l(u,-1)).x1(u=>l(u,1))(Ue(s,a-o/2,o).concat(a))}_renderLine(t,n,r){let[i,o]=le(t,a=>r[a]),s=Sv(t,r,n);return`M${s(i)},${i}L${s(o)},${o}`}},v3=class extends _v{constructor(t,n){super(t,n)}_renderBand(t,n,r){let{ci:i,precision:o}=this,[s,a]=le(t,u=>n[u]),c=Sv(t,n,r),l=eP(t,n,r,(1-i)/2,c);return pf().x(u=>u).y0(u=>l(u,-1)).y1(u=>l(u,1))(Ue(s,a-o/2,o).concat(a))}_renderLine(t,n,r){let[i,o]=le(t,a=>n[a]),s=Sv(t,n,r);return`M${i},${s(i)}L${o},${s(o)}`}};function K9(e,{y:t=Ee,x:n=G,stroke:r,fill:i=re(r)?"currentColor":r,...o}={}){return new w3(e,Hf({...o,x:n,y:t,fill:i,stroke:r}))}function tP(e,{x:t=Ee,y:n=G,stroke:r,fill:i=re(r)?"currentColor":r,...o}={}){return new v3(e,Wf({...o,x:t,y:n,fill:i,stroke:r}))}function Sv(e,t,n){let r=0,i=0,o=0,s=0;for(let u of e){let f=t[u],h=n[u];r+=f,i+=h,o+=f*h,s+=f*f}let a=e.length,c=(a*o-r*i)/(a*s-r*r),l=(i-c*r)/a;return u=>c*u+l}function eP(e,t,n,r,i){let o=Tn(e,u=>t[u])/e.length,s=0,a=0;for(let u of e)s+=(t[u]-o)**2,a+=(n[u]-i(t[u]))**2;let c=Math.sqrt(a/(e.length-2)),l=Q9(r,e.length-2);return(u,f)=>{let h=i(u),d=c*Math.sqrt(1/e.length+(u-o)**2/s);return h+f*l*d}}function $y({path:e=G,delimiter:t,frameAnchor:n,treeLayout:r=ul,treeSort:i,treeSeparation:o,treeAnchor:s,treeFilter:a,...c}={}){s=Tv(s),i=iP(i),a!=null&&(a=S3(a)),n===void 0&&(n=s.frameAnchor);let l=oP(t),u=hP(c,S3),[f,h]=yn(),[d,p]=yn();return{x:f,y:d,frameAnchor:n,...gn(c,(m,y)=>{let g=l(wt(m,e)),x=h([]),b=p([]),w=-1,_=[],v=[],M=vb().path(I=>g[I]),E=r();E.nodeSize&&E.nodeSize([1,1]),E.separation&&o!==void 0&&E.separation(o??Ym);for(let I of u)I[Mv]=I[uP]([]);for(let I of y){let D=[],A=M(I.filter(O=>g[O]!=null)).each(O=>O.data=m[O.data]);i!=null&&A.sort(i),E(A);for(let O of A.descendants())if(!(a!=null&&!a(O))){D.push(++w),_[w]=O.data,s.position(O,w,x,b);for(let C of u)C[Mv][w]=C[fP](O)}v.push(D)}return{data:_,facets:v}}),...Object.fromEntries(u)}}function Av({path:e=G,delimiter:t,curve:n="bump-x",stroke:r="#555",strokeWidth:i=1.5,strokeOpacity:o=.5,treeLayout:s=ul,treeSort:a,treeSeparation:c,treeAnchor:l,treeFilter:u,...f}={}){l=Tv(l),a=iP(a),u!=null&&(u=rP(u)),f={curve:n,stroke:r,strokeWidth:i,strokeOpacity:o,...f};let h=oP(t),d=hP(f,rP),[p,m]=yn(),[y,g]=yn(),[x,b]=yn(),[w,_]=yn();return{x1:p,x2:y,y1:x,y2:w,...gn(f,(v,M)=>{let E=h(wt(v,e)),I=m([]),D=g([]),A=b([]),O=_([]),C=-1,S=[],T=[],N=vb().path(R=>E[R]),F=s();F.nodeSize&&F.nodeSize([1,1]),F.separation&&c!==void 0&&F.separation(c??Ym);for(let R of d)R[Mv]=R[uP]([]);for(let R of M){let k=[],$=N(R.filter(P=>E[P]!=null)).each(P=>P.data=v[P.data]);a!=null&&$.sort(a),F($);for(let{source:P,target:U}of $.links())if(!(u!=null&&!u(U,P))){k.push(++C),S[C]=U.data,l.position(P,C,I,A),l.position(U,C,D,O);for(let W of d)W[Mv][C]=W[fP](U,P)}T.push(k)}return{data:S,facets:T}}),...Object.fromEntries(d)}}function Tv(e="left"){switch(`${e}`.trim().toLowerCase()){case"left":return det;case"right":return pet}throw new Error(`invalid tree anchor: ${e}`)}var det={frameAnchor:"left",dx:6,position({x:e,y:t},n,r,i){r[n]=t,i[n]=-e}},pet={frameAnchor:"right",dx:-6,position({x:e,y:t},n,r,i){r[n]=-t,i[n]=-e}};function iP(e){return e==null||typeof e=="function"?e:`${e}`.trim().toLowerCase().startsWith("node:")?nP(S3(e)):nP(met(e))}function nP(e){return(t,n)=>dn(e(t),e(n))}function met(e){return t=>t.data?.[e]}function oP(e="/"){if(e=`${e}`,e==="/")return n=>n;if(e.length!==1)throw new Error("delimiter must be exactly one character");let t=e.charCodeAt(0);return n=>n.map(r=>yet(r,t))}var _3=92,sP=47;function yet(e,t){if(t===_3)throw new Error("delimiter cannot be backslash");let n=!1;for(let r=0,i=e.length;r<i;++r){switch(e.charCodeAt(r)){case _3:if(!n){n=!0;continue}break;case t:n?(e=e.slice(0,r-1)+e.slice(r),--r,--i):e=e.slice(0,r)+"/"+e.slice(r+1);break;case sP:n?(e=e.slice(0,r)+"\\\\"+e.slice(r),r+=2,i+=2):(e=e.slice(0,r)+"\\"+e.slice(r),++r,++i);break}n=!1}return e}function get(e){let t=!1;for(let n=0,r=e.length;n<r;++n){switch(e.charCodeAt(n)){case _3:if(!t){t=!0;continue}case sP:t&&(e=e.slice(0,n-1)+e.slice(n),--n,--r);break}t=!1}return e}function aP(e){return mn(e)&&typeof e.node=="function"}function xet(e){return mn(e)&&typeof e.link=="function"}function S3(e){if(aP(e))return e.node;if(e=`${e}`.trim().toLowerCase(),!!e.startsWith("node:")){switch(e){case"node:name":return M3;case"node:path":return I3;case"node:internal":return cP;case"node:external":return lP;case"node:depth":return A3;case"node:height":return T3}throw new Error(`invalid node value: ${e}`)}}function rP(e){if(aP(e))return e.node;if(xet(e))return e.link;if(e=`${e}`.trim().toLowerCase(),!(!e.startsWith("node:")&&!e.startsWith("parent:"))){switch(e){case"parent:name":return Iv(M3);case"parent:path":return Iv(I3);case"parent:depth":return Iv(A3);case"parent:height":return Iv(T3);case"node:name":return M3;case"node:path":return I3;case"node:internal":return cP;case"node:external":return lP;case"node:depth":return A3;case"node:height":return T3}throw new Error(`invalid link value: ${e}`)}}function I3(e){return e.id}function M3(e){return bet(e.id)}function A3(e){return e.depth}function T3(e){return e.height}function cP(e){return!!e.children}function lP(e){return!e.children}function Iv(e){return(t,n)=>n==null?void 0:e(n)}function bet(e){let t=e.length;for(;--t>0&&!wet(e,t););return get(e.slice(t+1))}function wet(e,t){if(e[t]==="/"){let n=0;for(;t>0&&e[--t]==="\\";)++n;if(!(n&1))return!0}return!1}var uP=2,fP=3,Mv=4;function hP(e,t){let n=[];for(let r in e){let i=e[r],o=t(i);o!==void 0&&n.push([r,...yn(i),o])}return n}function E3(e,{fill:t,stroke:n,strokeWidth:r,strokeOpacity:i,strokeLinejoin:o,strokeLinecap:s,strokeMiterlimit:a,strokeDasharray:c,strokeDashoffset:l,marker:u,markerStart:f=u,markerEnd:h=u,dot:d=re(f)&&re(h),text:p="node:name",textStroke:m="var(--plot-background)",title:y="node:path",dx:g,dy:x,textAnchor:b,treeLayout:w=ul,textLayout:_=w===ul||w===bb?"mirrored":"normal",tip:v,...M}={}){if(g===void 0&&(g=Tv(M.treeAnchor).dx),b!==void 0)throw new Error("textAnchor is not a configurable tree option");_=sn(_,"textLayout",["mirrored","normal"]);function E(I){return Wo(e,$y({treeLayout:w,text:p,fill:t===void 0?"currentColor":t,stroke:m,dx:g,dy:x,title:y,...I,...M}))}return tn(fv(e,Av({treeLayout:w,markerStart:f,markerEnd:h,stroke:n!==void 0?n:t===void 0?"node:internal":t,strokeWidth:r,strokeOpacity:i,strokeLinejoin:o,strokeLinecap:s,strokeMiterlimit:a,strokeDasharray:c,strokeDashoffset:l,...M})),d?_i(e,$y({treeLayout:w,fill:t===void 0?"node:internal":t,title:y,tip:v,...M})):null,p!=null?_==="mirrored"?[E({textAnchor:"start",treeFilter:"node:external"}),E({textAnchor:"end",treeFilter:"node:internal",dx:-g})]:E():null)}function dP(e,t){return E3(e,{...t,treeLayout:bb})}function pP({geometry:e=G,...t}={}){return Ie({...t,x:null,y:null},(n,r,i,o,s,{projection:a})=>{let c=wt(n,e),l=c.length,u=new Float64Array(l),f=new Float64Array(l),h=Nn(a);for(let d=0;d<l;++d)[u[d],f[d]]=h.centroid(c[d]);return{data:n,facets:r,channels:{x:{value:u,scale:a==null?"x":null,source:null},y:{value:f,scale:a==null?"y":null,source:null}}}})}function mP({geometry:e=G,...t}={}){let n;return{...t,x:{transform:r=>Float64Array.from(n=wt(wt(r,e),YI),([i])=>i)},y:{transform:()=>Float64Array.from(n,([,r])=>r)}}}var AP=Az(MP(),1);var Net=({marginLeft:e})=>[1,e],Det=({width:e,marginRight:t})=>[-1,e-t],Oet=({width:e,marginLeft:t,marginRight:n})=>[0,(t+e-n)/2],Bet=({marginTop:e})=>[1,e],Let=({height:e,marginBottom:t})=>[-1,e-t],Cet=({height:e,marginTop:t,marginBottom:n})=>[0,(t+e-n)/2];function TP(e){return typeof e=="string"?{anchor:e}:e}function EP(e={},t={}){arguments.length===1&&([e,t]=DP(e));let{anchor:n="left",padding:r=1,r:i=t.r}=TP(e);switch(`${n}`.toLowerCase()){case"left":n=Net;break;case"right":n=Det;break;case"middle":n=Oet;break;default:throw new Error(`unknown dodge anchor: ${n}`)}return OP("x","y",n,Bt(r),i,t)}function NP(e={},t={}){arguments.length===1&&([e,t]=DP(e));let{anchor:n="bottom",padding:r=1,r:i=t.r}=TP(e);switch(`${n}`.toLowerCase()){case"top":n=Bet;break;case"bottom":n=Let;break;case"middle":n=Cet;break;default:throw new Error(`unknown dodge anchor: ${n}`)}return OP("y","x",n,Bt(r),i,t)}function DP(e){let{anchor:t,padding:n,...r}=e,{r:i}=r;return[{anchor:t,padding:n,r:i},r]}function OP(e,t,n,r,i,o){if(i!=null&&typeof i!="number"){let{channels:s,sort:a,reverse:c}=o;s=Gm(s),s?.r===void 0&&(o={...o,channels:{...s,r:{value:i,scale:"r"}}}),a===void 0&&c===void 0&&(o.sort={channel:"-r"})}return Ie(o,function(s,a,c,l,u,f){let{[t]:h,r:d}=c;if(!c[t])throw new Error(`missing channel: ${t}`);({[t]:h}=nc(c,l,f));let p=d?void 0:i!==void 0?Bt(i):this.r!==void 0?this.r:3;d&&(d=wt(d.value,l[d.scale]||G,Float64Array));let[m,y]=n(u),g=m?Fet:ket,x=new Float64Array(h.length),b=d?w=>d[w]:()=>p;for(let w of a){let _=(0,AP.default)();w=w.filter(d?M=>bf(h[M])&&ar(d[M]):M=>bf(h[M]));let v=new Float64Array(2*w.length+2);for(let M of w){let E=b(M),I=m?E+r:0,D=h[M]-E,A=h[M]+E,O=2;_.queryInterval(D-r,A+r,([,,S])=>{let T=x[S]-I,N=h[M]-h[S],F=r+(d?d[M]+d[S]:2*p),R=Math.sqrt(F*F-N*N);v[O++]=T-R,v[O++]=T+R});let C=v.slice(0,O);m&&(C=C.filter(S=>S>=0));t:for(let S of C.sort(g)){for(let T=0;T<O;T+=2)if(v[T]+1e-6<S&&S<v[T+1]-1e-6)continue t;x[M]=S+I;break}_.insert([D,A,M])}}m||(m=1);for(let w of a)for(let _ of w)x[_]=x[_]*m+y;return{data:s,facets:a,channels:{[e]:{value:x,source:null},[t]:{value:h,source:c[t]},...d&&{r:{value:d,source:c.r}}}}})}function ket(e,t){return Math.abs(e)-Math.abs(t)}function Fet(e,t){return e-t}function LP(e,t){return arguments.length===1&&({basis:e,...t}=e),sh(Dv(e),t)}function CP(e,t){return arguments.length===1&&({basis:e,...t}=e),ah(Dv(e),t)}function Dv(e){if(e===void 0)return BP;if(typeof e=="function")return Ov(Af(e));if(/^p\d{2}$/i.test(e))return yh(If(e));switch(`${e}`.toLowerCase()){case"deviation":return Pet;case"first":return BP;case"last":return $et;case"max":return Uet;case"mean":return zet;case"median":return qet;case"min":return jet;case"sum":return Vet;case"extent":return Ret}throw new Error(`invalid basis: ${e}`)}function Ov(e){return{mapIndex(t,n,r){let i=+e(t,n);for(let o of t)r[o]=n[o]===null?NaN:n[o]/i}}}function yh(e){return Ov((t,n)=>e(t,r=>n[r]))}var Ret={mapIndex(e,t,n){let[r,i]=le(e,s=>t[s]),o=i-r;for(let s of e)n[s]=t[s]===null?NaN:(t[s]-r)/o}},BP=Ov((e,t)=>{for(let n=0;n<e.length;++n){let r=t[e[n]];if(ze(r))return r}}),$et=Ov((e,t)=>{for(let n=e.length-1;n>=0;--n){let r=t[e[n]];if(ze(r))return r}}),Pet={mapIndex(e,t,n){let r=Es(e,o=>t[o]),i=li(e,o=>t[o]);for(let o of e)n[o]=t[o]===null?NaN:i?(t[o]-r)/i:0}},Uet=yh(Ht),zet=yh(Es),qet=yh(Ui),jet=yh(ue),Vet=yh(Tn);function kP(e,t){return Yet("x",e,t)}function Yet(e,t,n={}){let r,i=1;if(typeof t=="number")i=t,r=(l,u)=>+l+u;else{if(typeof t=="string"){let l=t.startsWith("-")?-1:1;[t,i]=cw(t.replace(/^[+-]/,"")),i*=l}t=Ef(t),r=(l,u)=>t.offset(l,u)}let o=`${e}1`,s=`${e}2`,a=_r({[o]:l=>l.map(u=>r(u,i)),[s]:l=>l},n),c=a[s].transform;return a[s].transform=()=>{let l=c(),[u,f]=le(l);return l.domain=i<0?[u,r(f,i)]:[r(u,i),f],l},a}function FP(e,t={}){if(typeof e=="string")switch(e.toLowerCase()){case"first":return C3(t);case"last":return k3(t)}if(typeof e=="function")return mc(null,e,t);let n,r;for(n in e){if(r!==void 0)throw new Error("ambiguous selector; multiple inputs");r=Xet(e[n])}if(r===void 0)throw new Error(`invalid selector: ${e}`);return mc(n,r,t)}function Xet(e){if(typeof e=="function")return e;switch(`${e}`.toLowerCase()){case"min":return F3;case"max":return R3}throw new Error(`unknown selector: ${e}`)}function C3(e){return mc(null,Get,e)}function k3(e){return mc(null,Wet,e)}function RP(e){return mc("x",F3,e)}function $P(e){return mc("y",F3,e)}function PP(e){return mc("x",R3,e)}function UP(e){return mc("y",R3,e)}function*Get(e){yield e[0]}function*Wet(e){yield e[e.length-1]}function*F3(e,t){yield rx(e,n=>t[n])}function*R3(e,t){yield Gc(e,n=>t[n])}function mc(e,t,n){if(e!=null){if(n[e]==null)throw new Error(`missing channel: ${e}`);e=n[e]}let r=jn(n);return gn(n,(i,o)=>{let s=wt(i,r),a=wt(i,e),c=[];for(let l of o){let u=[];for(let f of s?ln(l,h=>s[h]).values():[l])for(let h of t(f,a))u.push(h);c.push(u)}return{data:i,facets:c}})}var Het=new Map([["style","style"],["width","width"],["height","height"],["margin","margin"],["marginLeft","marginLeft"],["marginRight","marginRight"],["marginTop","marginTop"],["marginBottom","marginBottom"],["align","align"],["aspectRatio","aspectRatio"],["axis","axis"],["inset","inset"],["grid","grid"],["label","label"],["padding","padding"],["xScale","x.type"],["xDomain","x.domain"],["xRange","x.range"],["xNice","x.nice"],["xInset","x.inset"],["xInsetLeft","x.insetLeft"],["xInsetRight","x.insetRight"],["xClamp","x.clamp"],["xRound","x.round"],["xAlign","x.align"],["xPadding","x.padding"],["xPaddingInner","x.paddingInner"],["xPaddingOuter","x.paddingOuter"],["xAxis","x.axis"],["xTicks","x.ticks"],["xTickSize","x.tickSize"],["xTickSpacing","x.tickSpacing"],["xTickPadding","x.tickPadding"],["xTickFormat","x.tickFormat"],["xTickRotate","x.tickRotate"],["xGrid","x.grid"],["xLine","x.line"],["xLabel","x.label"],["xLabelAnchor","x.labelAnchor"],["xLabelArrow","x.labelArrow"],["xLabelOffset","x.labelOffset"],["xFontVariant","x.fontVariant"],["xAriaLabel","x.ariaLabel"],["xAriaDescription","x.ariaDescription"],["xPercent","x.percent"],["xReverse","x.reverse"],["xZero","x.zero"],["xBase","x.base"],["xExponent","x.exponent"],["xConstant","x.constant"],["yScale","y.type"],["yDomain","y.domain"],["yRange","y.range"],["yNice","y.nice"],["yInset","y.inset"],["yInsetTop","y.insetTop"],["yInsetBottom","y.insetBottom"],["yClamp","y.clamp"],["yRound","y.round"],["yAlign","y.align"],["yPadding","y.padding"],["yPaddingInner","y.paddingInner"],["yPaddingOuter","y.paddingOuter"],["yAxis","y.axis"],["yTicks","y.ticks"],["yTickSize","y.tickSize"],["yTickSpacing","y.tickSpacing"],["yTickPadding","y.tickPadding"],["yTickFormat","y.tickFormat"],["yTickRotate","y.tickRotate"],["yGrid","y.grid"],["yLine","y.line"],["yLabel","y.label"],["yLabelAnchor","y.labelAnchor"],["yLabelArrow","y.labelArrow"],["yLabelOffset","y.labelOffset"],["yFontVariant","y.fontVariant"],["yAriaLabel","y.ariaLabel"],["yAriaDescription","y.ariaDescription"],["yPercent","y.percent"],["yReverse","y.reverse"],["yZero","y.zero"],["yBase","y.base"],["yExponent","y.exponent"],["yConstant","y.constant"],["facetMargin","facet.margin"],["facetMarginTop","facet.marginTop"],["facetMarginBottom","facet.marginBottom"],["facetMarginLeft","facet.marginLeft"],["facetMarginRight","facet.marginRight"],["facetGrid","facet.grid"],["facetLabel","facet.label"],["fxDomain","fx.domain"],["fxRange","fx.range"],["fxInset","fx.inset"],["fxInsetLeft","fx.insetLeft"],["fxInsetRight","fx.insetRight"],["fxRound","fx.round"],["fxAlign","fx.align"],["fxPadding","fx.padding"],["fxPaddingInner","fx.paddingInner"],["fxPaddingOuter","fx.paddingOuter"],["fxAxis","fx.axis"],["fxTicks","fx.ticks"],["fxTickSize","fx.tickSize"],["fxTickSpacing","fx.tickSpacing"],["fxTickPadding","fx.tickPadding"],["fxTickFormat","fx.tickFormat"],["fxTickRotate","fx.tickRotate"],["fxGrid","fx.grid"],["fxLine","fx.line"],["fxLabel","fx.label"],["fxLabelAnchor","fx.labelAnchor"],["fxLabelOffset","fx.labelOffset"],["fxFontVariant","fx.fontVariant"],["fxAriaLabel","fx.ariaLabel"],["fxAriaDescription","fx.ariaDescription"],["fxReverse","fx.reverse"],["fyDomain","fy.domain"],["fyRange","fy.range"],["fyInset","fy,inset"],["fyInsetTop","fy.insetTop"],["fyInsetBottom","fy.insetBottom"],["fyRound","fy.round"],["fyAlign","fy.align"],["fyPadding","fy.padding"],["fyPaddingInner","fy.paddingInner"],["fyPaddingOuter","fy.paddingOuter"],["fyAxis","fy.axis"],["fyTicks","fy.ticks"],["fyTickSize","fy.tickSize"],["fyTickSpacing","fy.tickSpacing"],["fyTickPadding","fy.tickPadding"],["fyTickFormat","fy.tickFormat"],["fyTickRotate","fy.tickRotate"],["fyGrid","fy.grid"],["fyLine","fy.line"],["fyLabel","fy.label"],["fyLabelAnchor","fy.labelAnchor"],["fyLabelOffset","fy.labelOffset"],["fyFontVariant","fy.fontVariant"],["fyAriaLabel","fy.ariaLabel"],["fyAriaDescription","fy.ariaDescription"],["fyReverse","fy.reverse"],["colorScale","color.type"],["colorDomain","color.domain"],["colorRange","color.range"],["colorClamp","color.clamp"],["colorN","color.n"],["colorNice","color.nice"],["colorScheme","color.scheme"],["colorInterpolate","color.interpolate"],["colorPivot","color.pivot"],["colorSymmetric","color.symmetric"],["colorLabel","color.label"],["colorPercent","color.percent"],["colorReverse","color.reverse"],["colorZero","color.zero"],["colorTickFormat","color.tickFormat"],["colorBase","color.base"],["colorExponent","color.exponent"],["colorConstant","color.constant"],["opacityScale","opacity.type"],["opacityDomain","opacity.domain"],["opacityRange","opacity.range"],["opacityClamp","opacity.clamp"],["opacityNice","opacity.nice"],["opacityLabel","opacity.label"],["opacityPercent","opacity.percent"],["opacityReverse","opacity.reverse"],["opacityZero","opacity.zero"],["opacityTickFormat","opacity.tickFormat"],["opacityBase","opacity.base"],["opacityExponent","opacity.exponent"],["opacityConstant","opacity.constant"],["symbolScale","symbol.type"],["symbolDomain","symbol.domain"],["symbolRange","symbol.range"],["rScale","r.type"],["rDomain","r.domain"],["rRange","r.range"],["rClamp","r.clamp"],["rNice","r.nice"],["rPercent","r.percent"],["rZero","r.zero"],["rBase","r.base"],["rExponent","r.exponent"],["rConstant","r.constant"],["lengthScale","length.type"],["lengthDomain","length.domain"],["lengthRange","length.range"],["lengthClamp","length.clamp"],["lengthNice","length.nice"],["lengthPercent","length.percent"],["lengthZero","length.zero"],["lengthBase","length.base"],["lengthExponent","length.exponent"],["lengthConstant","length.constant"],["projectionType","projection.type"],["projectionParallels","projection.parallels"],["projectionPrecision","projection.precision"],["projectionRotate","projection.rotate"],["projectionDomain","projection.domain"],["projectionInset","projection.inset"],["projectionInsetLeft","projection.insetLeft"],["projectionInsetRight","projection.insetRight"],["projectionInsetTop","projection.insetTop"],["projectionInsetBottom","projection.insetBottom"],["projectionClip","projection.clip"]]);function Zet(e,t,n){for(let r=0;r<t.length;++r){let i=t[r];r===t.length-1?e[i]=n:e=e[i]||(e[i]={})}}function zP(e,t,n){for(let r in e){let i=Het.get(r);if(i==null)throw new Error(`Unrecognized plot attribute: ${r}`);let o=e[r];typeof o=="symbol"?n.push(r):o!==void 0&&Zet(t,i.split("."),o)}}var Jet=new Set(["frame","hexgrid","sphere","graticule"]);async function jP(e){let t={marks:[]},n=[],{attributes:r,marks:i}=e;zP(r,t,n);let o=[];for(let a of i)for(let{type:c,data:l,options:u}of a.plotSpecs()){if(Jet.has(c))t.marks.push(zy[c](u));else if(np(l)){let f=Object.fromEntries(Object.entries(u).map(([h,d])=>{let p=d;if(typeof d=="string")p=l.getChild(d)??d;else if(typeof d=="object"){let m=l.getChild(d.value);p=m?{value:m}:d}return[h,p]}));t.marks.push(zy[c]({length:l.numRows},f))}else t.marks.push(zy[c](l,u));o.push(a.index)}Ket(t,e);let s=hy(t);tnt(s,o),Qet(e,s,r,n);for(let a of e.interactors)await a.init(s);return s}function Qet(e,t,n,r){r.forEach(i=>{let o=n[i];if(o===vo){if(!i.endsWith("Domain"))throw new Error(`Unsupported fixed attribute: ${i}`);let s=i.slice(0,-6),a=t.scale(s);a?.domain&&e.setAttribute(i,n[`${s}Reverse`]?a.domain.slice().reverse():a.domain)}else throw new Error(`Unrecognized symbol: ${o}`)})}function Ket(e,t){let{marks:n}=t;Bv("x",e,n),Bv("y",e,n),Bv("fx",e,n),Bv("fy",e,n)}function Bv(e,t,n){let r=t[e]||{};if(r.axis===null||r.label!==void 0)return;let i=n.map(l=>l.channelField(e)?.field);if(i.every(l=>l==null))return;let o,s,a;for(let l=0;l<i.length;++l){let{column:u,label:f}=i[l]||{};u===void 0&&f===void 0||(o===void 0&&s===void 0?(o=u,s=f,a=ent(n[l].data,e)||"number"):s!==f?s=void 0:o!==u&&(o=void 0))}let c=s||o;if(c!==void 0){if((a==="number"||a==="date")&&(e==="x"||e==="y")){r.percent&&(c=`${c} (%)`);let l=(e==="x"?1:-1)*(r.reverse?-1:1);e==="x"||r.labelAnchor==="center"?c=e==="x"==l<0?`\u2190 ${c}`:`${c} \u2192`:c=`${l<0?"\u2191 ":"\u2193 "}${c}`}t[e]={...r,label:c}}}function tnt(e,t){let n=e.querySelectorAll('g[aria-label="facet"]');if(n.length)for(let r of n)qP(r,t);else qP(e,t)}function qP(e,t){let n=-1;for(let r of e.children){let i=r.getAttribute("aria-label")||"";r.nodeName==="style"||i.includes("-axis")||i.includes("-grid")||r.setAttribute("data-index",t[++n])}}function ent(e,t){let{columns:n}=e,r=n[t]??n[t+"1"]??n[t+"2"];if(r){for(let i of r)if(i!=null)return i instanceof Date?"date":typeof i}}var nnt={width:640,marginLeft:40,marginRight:20,marginTop:20,marginBottom:30},qy=class{constructor(t){this.attributes={...nnt},this.listeners=null,this.interactors=[],this.legends=[],this.marks=[],this.markset=null,this.element=t||document.createElement("div"),this.element.setAttribute("class","plot"),this.element.style.display="flex",this.element.value=this,this.params=new Map,this.synch=US()}margins(){return{left:this.getAttribute("marginLeft"),top:this.getAttribute("marginTop"),bottom:this.getAttribute("marginBottom"),right:this.getAttribute("marginRight")}}innerWidth(){let{left:t,right:n}=this.margins();return this.getAttribute("width")-t-n}innerHeight(t=400){let{top:n,bottom:r}=this.margins(),i=this.getAttribute("height");return i==null&&t!=null&&(i=t,this.setAttribute("height",i,{silent:!0})),i-n-r}pending(t){this.synch.pending(t)}update(t){return this.synch.ready(t)&&!this.pendingRender&&(this.pendingRender=!0,requestAnimationFrame(()=>this.render())),this.synch.promise}async render(){this.pendingRender=!1;let t=await jP(this),n=this.legends.flatMap(({legend:r,include:i})=>{let o=r.init(t);return i?o:[]});this.element.replaceChildren(t,...n),this.synch.resolve()}getAttribute(t){return this.attributes[t]}setAttribute(t,n,r){return ip(this.attributes[t],n)?(n===void 0?delete this.attributes[t]:this.attributes[t]=n,r?.silent||this.listeners?.get(t)?.forEach(i=>i(t,n)),!0):!1}addAttributeListener(t,n){let r=this.listeners||(this.listeners=new Map);return r.has(t)||r.set(t,new Set),r.get(t).add(n),this}removeAttributeListener(t,n){return this.listeners?.get(t)?.delete(n)}addParams(t,n){let{params:r}=this;for(let i of n)r.has(i)?r.get(i).push(t):(r.set(i,[t]),i.addEventListener("value",()=>Promise.allSettled(r.get(i).map(o=>o.requestQuery()))))}addMark(t){return t.setPlot(this,this.marks.length),this.marks.push(t),this.markset=null,this}get markSet(){return this.markset||(this.markset=new Set(this.marks))}addInteractor(t){return this.interactors.push(t),this}addLegend(t,n=!0){t.setPlot(this),this.legends.push({legend:t,include:n})}};function Lv(e){return typeof e!="string"?!1:(e=e.toLowerCase().trim(),e==="none"||e==="currentcolor"||e.startsWith("url(")&&e.endsWith(")")||e.startsWith("var(")&&e.endsWith(")")||Rr(e)!==null)}var rnt=new Set(["order","sort","label","anchor","curve","tension","marker","markerStart","markerMid","markerEnd","textAnchor","lineAnchor","lineHeight","textOverflow","monospace","fontFamily","fontSize","fontStyle","fontVariant","fontWeight","frameAnchor","strokeLinejoin","strokeLinecap","strokeMiterlimit","strokeDasharray","strokeDashoffset","mixBlendMode","shapeRendering","imageRendering","preserveAspectRatio","interpolate","crossOrigin","paintOrder","pointerEvents","target"]);function VP(e){return rnt.has(e)}var int=new Set(["asterisk","circle","cross","diamond","diamond2","hexagon","plus","square","square2","star","times","triangle","triangle2","wye"]);function YP(e){return int.has(`${e}`.toLowerCase())}function aa(e){return np(e)?ont(e):snt(e)}function ont(e){let{numRows:t,numCols:n,schema:{fields:r}}=e,i={};for(let o=0;o<n;++o){let s=r[o].name;i[s]?console.warn(`Redundant column name "${s}". Skipping...`):i[s]=$S(e.getChildAt(o))}return{numRows:t,columns:i}}function snt(e){let t=e.length;if(typeof e[0]=="object"){let n=t?Object.keys(e[0]):[],r={};return n.length>0&&n.forEach(i=>{r[i]=e.map(o=>o[i])}),{numRows:t,columns:r}}else return{numRows:t,values:e}}var XP=e=>e==="stroke"||e==="fill",ant=e=>/opacity$/i.test(e),cnt=e=>e==="symbol",lnt=(e,t)=>e!=="sort"&&e!=="tip"&&t!=null&&!Array.isArray(t),$3=(e,t)=>({channel:e,field:t,as:t instanceof br?t.column:e}),P3=(e,t)=>({channel:e,value:t}),Cv=e=>Array.isArray(e),Ln=class extends fr{constructor(t,n,r,i={}){super(n?.options?.filterBy),this.type=t,this.reqs=i,this.source=n,Cv(this.source)&&(this.data=aa(this.source));let o=this.channels=[],s=this.detail=new Set,a=this.params=new Set,c=(l,u)=>{let f=typeof u;if(l==="channels")for(let h in u)s.add(h),c(h,u[h]);else if(f==="function"&&u[op]){let h=u(this,l);for(let d in h)c(d,h[d])}else if(f==="string")VP(l)||XP(l)&&Lv(u)||cnt(l)&&YP(u)?o.push(P3(l,u)):o.push($3(l,Sa(u)));else if(xs(u))if(Array.isArray(u.columns))o.push($3(l,u)),a.add(u);else{let h=P3(l,u.value);o.push(h),u.addEventListener("value",d=>(h.value=d,this.update()))}else f==="object"&&lnt(l,u)?o.push($3(l,u)):u!==void 0&&o.push(P3(l,u))};for(let l in r)c(l,r[l])}setPlot(t,n){this.plot=t,this.index=n,t.addParams(this,this.params),this.source?.table&&this.queryPending()}hasOwnData(){return this.source==null||Cv(this.source)}hasFieldInfo(){return!!this._fieldInfo}channel(t){return this.channels.find(n=>n.channel===t)}channelField(t,{exact:n=!1}={}){let r=n?this.channel(t):this.channels.find(i=>i.channel.startsWith(t));return r?.field?r:null}fields(){if(this.hasOwnData())return null;let{source:{table:t},channels:n,reqs:r}=this,i=new Map;for(let{channel:o,field:s}of n){if(!s)continue;let a=s.stats?.stats||[],c=s.stats?.column??s,l=i.get(c)??i.set(c,new Set).get(c);a.forEach(u=>l.add(u)),r[o]?.forEach(u=>l.add(u))}return Array.from(i,([o,s])=>({table:t,column:o,stats:s}))}fieldInfo(t){let n=Object.fromEntries(t.map(r=>[r.column,r]));for(let r of this.channels){let{field:i}=r;i&&Object.assign(r,n[i.stats?.column??i])}return this._fieldInfo=!0,this}query(t=[]){if(this.hasOwnData())return null;let{channels:n,source:{table:r}}=this;return U3(n,r).where(t)}queryPending(){return this.plot.pending(this),this}queryResult(t){return this.data=aa(t),this}update(){return this.plot.update(this)}plotSpecs(){let{type:t,detail:n,channels:r}=this,{numRows:i,values:o,columns:s}=this.data||{},a={},c={};for(let f of r){let h=n.has(f.channel)?c:a;h[f.channel]=Yn(f,s)}n.size&&(a.channels=c);let l=o??(this.data?{length:i}:null);return[{type:t,data:l,options:a}]}};function Yn(e,t){let n=t?.[e.as]??e.as;return Object.hasOwn(e,"value")?e.value:XP(e.channel)?{value:n,scale:"color"}:ant(e.channel)?{value:n,scale:"opacity"}:n}function U3(e,t,n=[]){let r=dt.from({source:t}),i=new Set,o=!1;for(let s of e){let{channel:a,field:c,as:l}=s;if(!n.includes(a)){if(a==="orderby")r.orderby(s.value);else if(c){if(c.aggregate)o=!0;else{if(i.has(l))continue;i.add(l)}r.select({[l]:c})}}}return o&&r.groupby(Array.from(i)),r}function Vl(e,t){let{plot:n}=e,r=n.getAttribute(`${t}Scale`);if(!r){let{type:o}=e.channelField(t);r=o==="date"?"time":"linear"}let i={type:r};switch(r){case"log":i.base=n.getAttribute(`${t}Base`)??10;break;case"pow":i.exponent=n.getAttribute(`${t}Exponent`)??1;break;case"symlog":i.constant=n.getAttribute(`${t}Constant`)??1;break}return tp(i)}function Gr(e,t,n,r,i=1,o){let{field:s}=e.channelField(t);o=o??s;let{type:a,apply:c,sqlApply:l}=Vl(e,t),u=!!e.plot.getAttribute(`${t}Reverse`),[f,h]=r.map(x=>c(x)),d=l(o),p=a==="time"||a==="utc"?d:o,m=h===f?0:(n-i)/(h-f),y=m!==1?` * ${m}::DOUBLE`:"";return[u?q`(${h} - ${d}::DOUBLE)${y}`:q`(${d}::DOUBLE - ${f})${y}`,p]}var z3={x:["min","max"]},q3={y:["min","max"]},kv={...z3,...q3};function GP(e,t,n,r,i){let{plot:o}=e,s=o.getAttribute(r),a=o.getAttribute(i);if(Array.isArray(s)&&!s[In])return s;{let{column:c,min:l,max:u}=e.channelField(n),f=j3(t,c)||(a?$s().domain([l,u]).nice().domain():[l,u]);return s!==vo&&(f[In]=!0),o.setAttribute(r,f,{silent:!0}),f}}function Ko(e,t){return GP(e,t,"x","xDomain","xNice")}function ts(e,t){return GP(e,t,"y","yDomain","yNice")}function j3(e,t){if(!e)return;let n,r,i=(o,s)=>{if(o==="BETWEEN"&&`${s.field}`===t){let{range:a}=s;a&&(n==null||a[0]<n)&&(n=a[0]),a&&(r==null||a[1]>r)&&(r=a[1])}};return Array.isArray(e)?e.forEach(o=>o.visit?.(i)):e.visit&&e.visit(i),n!=null&&r!=null&&n!==r?[n,r]:void 0}var jy=class extends Ln{constructor(t,n,r){let i=t.endsWith("X")?"y":t.endsWith("Y")?"x":null,o=i?{[i]:["min","max"]}:void 0;super(t,n,r,o),this.dim=i}query(t=[]){let{plot:n,dim:r,source:i}=this,{optimize:o=!0}=i.options||{},s=super.query(t);if(!r)return s;let a=r==="x"?"y":"x",c=this.channelField(a,{exact:!0})?.as,{field:l,as:u,type:f,min:h,max:d}=this.channelField(r);if(o&&(f==="date"||f==="number")&&c){let m=r==="x"?n.innerWidth():n.innerHeight(),[y,g]=j3(t,l)||[h,d],[x]=Gr(this,r,m,[y,g],1,u),b=s.select().map(w=>w.as).filter(w=>w!==u&&w!==c);return unt(s,x,u,c,b)}else return s.orderby(l)}};function unt(e,t,n,r,i=[]){let o=q`FLOOR(${t})::INTEGER`,s=a=>dt.from(e).select(a).groupby(o,i);return dt.union(s([{[n]:si(n),[r]:Su(r,n)},...i]),s([{[n]:oi(n),[r]:Iu(r,n)},...i]),s([{[n]:Su(n,r),[r]:si(r)},...i]),s([{[n]:Iu(n,r),[r]:oi(r)},...i])).orderby(i,n)}function WP(e,t=[]){return new t.constructor(e)}function HP(e,t,n){let r=WP(e,n),i=n.length;for(let o=0;o<i;++o)r[t[o]]=n[o];return r}function ZP(e,t,n,r,i,o,s){let a=n.length,c=e*t,l=i.map(d=>r[d]),u={},f=[],h=new Int32Array(a);if(o?.length){let d=o.map(m=>r[m]),p={};for(let m=0;m<a;++m){let y=d.map(g=>g[m]);h[m]=p[y]??=f.push(y)-1}for(let m=0;m<o.length;++m)u[o[m]]=f.map(y=>y[m])}else f.push([]);if(s){let d=n.map(y=>y%e),p=n.map(y=>Math.floor(y/e)),m=f.map(()=>[]);for(let y=0;y<a;++y)m[h[y]].push(y);i.forEach((y,g)=>{let x=l[g];u[y]=f.map((b,w)=>s(m[w],e,t,d,p,x))})}else i.forEach((d,p)=>{let m=l[p],y=u[d]=f.map(()=>WP(c,m));for(let g=0;g<a;++g)y[h[g]][n[g]]=m[g]});return{numRows:f.length,columns:u}}function Vy(e){let t=1/0,n=-1/0;return e.forEach(r=>{let i=r.length;for(let o=0;o<i;++o){let s=r[o];s<t&&(t=s),s>n&&(n=s)}}),Number.isFinite(t)&&Number.isFinite(n)?[t,n]:[0,1]}function JP(e){let t=new Qn;return e.forEach(n=>{let r=n.length;for(let i=0;i<r;++i)t.add(n[i])}),Array.from(t).sort(zt)}function an(e,t){return wr(e)?(e.addEventListener("value",t),e.value):e}function Yy(e,t=!1){let n=new Float64Array(5),r=new Float64Array(4);fnt(n,r,e);let i=Float64Array.of(0,r[1]-n[1]*r[0],r[2]-n[2]*r[0],r[3]-n[3]*r[0],-n[4]*r[0]),o=1+n[1]+n[2]+n[3]+n[4],s=(r[0]+r[1]+r[2]+r[3])/o,a=(i[1]+i[2]+i[3]+i[4])/o;return{sigma:e,negative:t,a:n,b_causal:r,b_anticausal:i,sum_causal:s,sum_anticausal:a}}function fnt(e,t,n){let i=Float64Array.of(.84,1.8675,.84,-1.8675,-.34015,-.1299,-.34015,.1299),o=Math.exp(-1.783/n),s=Math.exp(-1.723/n),a=.6318/n,c=1.997/n,l=Float64Array.of(-o*Math.cos(a),o*Math.sin(a),-o*Math.cos(-a),o*Math.sin(-a),-s*Math.cos(c),s*Math.sin(c),-s*Math.cos(-c),s*Math.sin(-c)),u=n*2.5066282746310007,f=Float64Array.of(i[0],i[1],0,0,0,0,0,0),h=Float64Array.of(1,0,l[0],l[1],0,0,0,0,0,0),d,p;for(p=2;p<8;p+=2){for(f[p]=l[p]*f[p-2]-l[p+1]*f[p-1],f[p+1]=l[p]*f[p-1]+l[p+1]*f[p-2],d=p-2;d>0;d-=2)f[d]+=l[p]*f[d-2]-l[p+1]*f[d-1],f[d+1]+=l[p]*f[d-1]+l[p+1]*f[d-2];for(d=0;d<=p;d+=2)f[d]+=i[p]*h[d]-i[p+1]*h[d+1],f[d+1]+=i[p]*h[d+1]+i[p+1]*h[d];for(h[p+2]=l[p]*h[p]-l[p+1]*h[p+1],h[p+3]=l[p]*h[p+1]+l[p+1]*h[p],d=p;d>0;d-=2)h[d]+=l[p]*h[d-2]-l[p+1]*h[d-1],h[d+1]+=l[p]*h[d-1]+l[p+1]*h[d-2]}for(p=0;p<4;++p)d=p<<1,t[p]=f[d]/u,e[p+1]=h[d+2]}function QP(e,t,n,[r,i]){let o=new Float64Array(Math.max(r,i)),s=new Float64Array(Math.max(r,i)),a=new Float64Array(5),c=new Float64Array(n.length);for(let l=0,u=0;l<i;++l,u+=r){let f=c.subarray(u);Fv(e,n.subarray(u),r,1,o,s,a,f)}for(let l=0;l<r;++l){let u=c.subarray(l);Fv(t,u,i,r,o,s,a,u)}return c}function Fv(e,t,n,r=1,i=new Float64Array(n),o=new Float64Array(n),s=new Float64Array(5),a=i,c=hnt){let l=r*2,u=r*3,f=r*4,h=r*n,d,p;for(c(i,t,n,r,e.b_causal,3,e.a,4,e.sum_causal,s,e.sigma),p=4,d=f;p<n;++p,d+=r)i[p]=e.b_causal[0]*t[d]+e.b_causal[1]*t[d-r]+e.b_causal[2]*t[d-l]+e.b_causal[3]*t[d-u]-e.a[1]*i[p-1]-e.a[2]*i[p-2]-e.a[3]*i[p-3]-e.a[4]*i[p-4];for(c(o,t,n,-r,e.b_anticausal,4,e.a,4,e.sum_anticausal,s,e.sigma),p=4,d=h-r*5;p<n;++p,d-=r)o[p]=e.b_anticausal[1]*t[d+r]+e.b_anticausal[2]*t[d+l]+e.b_anticausal[3]*t[d+u]+e.b_anticausal[4]*t[d+f]-e.a[1]*o[p-1]-e.a[2]*o[p-2]-e.a[3]*o[p-3]-e.a[4]*o[p-4];if(e.negative)for(p=0,d=0;p<n;++p,d+=r)a[d]=i[p]+o[n-p-1];else for(p=0,d=0;p<n;++p,d+=r)a[d]=Math.max(0,i[p]+o[n-p-1]);return a}function hnt(e,t,n,r,i,o,s,a,c,l,u,f=.5){let h=Math.abs(r)*n,d=r<0?h+r:0,p,m,y;for(m=0;m<=a;++m)for(l[m]=m<=o?i[m]:0,y=1;y<=a&&y<=m;++y)l[m]-=s[y]*l[m-y];for(y=0;y<a;++y)for(e[y]=0,m=1;m<=y;++m)p=d+r*m,p>=0&&p<h&&(e[y]+=l[y-m]*t[p]);let g=t[d],x=Math.ceil(u*10);for(m=0;m<x;++m){for(y=0;y<a;++y)e[y]+=l[y]*g;if(c-=Math.abs(l[0]),c<=f)break;for(l[a]=m+a<=o?i[m+a]:0,y=1;y<=a;++y)l[a]-=s[y]*l[a-y];for(y=0;y<a;++y)l[y]=l[y+1]}}var ca="density",Wi=class extends Ln{constructor(t,n,r){let{bandwidth:i=0,interpolate:o="none",pixelSize:s=1,pad:a=1,width:c,height:l,...u}=r,f=dnt(u);super(t,n,u,kv),this.densityMap=f,this.bandwidth=an(i,h=>(this.bandwidth=h,this.grids?this.convolve().update():null)),this.interpolate=an(o,h=>(this.interpolate=h,this.requestUpdate())),this.pixelSize=an(s,h=>(this.pixelSize=h,this.requestUpdate())),this.pad=an(a,h=>(this.pad=h,this.requestUpdate())),this.width=an(c,h=>(this.width=h,this.requestUpdate())),this.height=an(l,h=>(this.height=h,this.requestUpdate()))}setPlot(t,n){let r=()=>{this.hasFieldInfo()&&this.requestUpdate()};t.addAttributeListener("xDomain",r),t.addAttributeListener("yDomain",r),super.setPlot(t,n)}get filterIndexable(){let t=this.plot.getAttribute("xDomain"),n=this.plot.getAttribute("yDomain");return t&&n&&!t[In]&&!n[In]}query(t=[]){let{interpolate:n,pad:r,channels:i,densityMap:o,source:s}=this,[a,c]=this.extentX=Ko(this,t),[l,u]=this.extentY=ts(this,t),[f,h]=this.bins=this.binDimensions(),[d,p]=Gr(this,"x",f,[a,c],r),[m,y]=Gr(this,"y",h,[l,u],r),g=r?[Ae(p,[+a,+c]),Ae(y,[+l,+u])]:[_s(+a,p),vs(p,+c),_s(+l,y),vs(y,+u)],x=dt.from(s.table).where(t.concat(g)),b=this.groupby=[],w={};for(let v of i)if(Object.hasOwn(v,"field")){let{as:M,channel:E,field:I}=v;I.aggregate?(w[E]=I,o[E]=!0):E==="weight"?w[ca]=Fr(I):E!=="x"&&E!=="y"&&(x.select({[M]:I}),b.push(M))}let _=this.aggr=Object.keys(w);if(w.density&&_.length>1)throw new Error("Weight option can not be used with custom aggregates.");if(_.length||(_.push(ca),w.density=kr()),n==="linear"){if(_.length>1)throw new Error("Linear binning not applicable to multiple aggregates.");if(!w.density)throw new Error("Linear binning not applicable to custom aggregates.");return ynt(x,d,m,w[ca],f,b)}else return mnt(x,d,m,w,f,b)}binDimensions(){let{plot:t,pixelSize:n,width:r,height:i}=this;return[r??Math.round(t.innerWidth()/n),i??Math.round(t.innerHeight()/n)]}queryResult(t){let[n,r]=this.bins,i=pnt(this.interpolate),{columns:o}=aa(t);return this.grids0=ZP(n,r,o.index,o,this.aggr,this.groupby,i),this.convolve()}convolve(){let{aggr:t,bandwidth:n,bins:r,grids0:i,plot:o}=this;if(this.grids=i,n>0){let s=t.length===1?t[0]:t.includes(ca)?ca:null;if(!s)return console.warn("No compatible grid found for smoothing."),this;let a=i.columns[s],c=o.innerWidth(),l=o.innerHeight(),[u,f]=r,h=a.some(m=>m.some(y=>y<0)),d=Yy(n*(u-1)/c,h),p=Yy(n*(f-1)/l,h);this.grids={numRows:i.numRows,columns:{...i.columns,[s]:a.map(m=>QP(d,p,m,r))}}}return this}};function dnt(e){let t={};for(let n in e)e[n]==="density"&&(delete e[n],t[n]=!0);return t}function pnt(e="none"){if(typeof e=="function")return e;switch(e.toLowerCase()){case"none":case"linear":return;case"nearest":return Ny;case"barycentric":return Ey();case"random-walk":return Dy()}throw new Error(`invalid interpolate: ${e}`)}function mnt(e,t,n,r,i,o){return e.select({index:q`FLOOR(${t})::INTEGER + FLOOR(${n})::INTEGER * ${i}`,...r}).groupby("index",o)}function ynt(e,t,n,r,i,o){let s=r?.column?`* ${r.column}`:"",a=(h,d)=>e.clone().select({xp:t,yp:n,i:h,w:d}),c=a(q`FLOOR(xp)::INTEGER + FLOOR(yp)::INTEGER * ${i}`,q`(FLOOR(xp)::INTEGER + 1 - xp) * (FLOOR(yp)::INTEGER + 1 - yp)${s}`),l=a(q`FLOOR(xp)::INTEGER + (FLOOR(yp)::INTEGER + 1) * ${i}`,q`(FLOOR(xp)::INTEGER + 1 - xp) * (yp - FLOOR(yp)::INTEGER)${s}`),u=a(q`FLOOR(xp)::INTEGER + 1 + FLOOR(yp)::INTEGER * ${i}`,q`(xp - FLOOR(xp)::INTEGER) * (FLOOR(yp)::INTEGER + 1 - yp)${s}`),f=a(q`FLOOR(xp)::INTEGER + 1 + (FLOOR(yp)::INTEGER + 1) * ${i}`,q`(xp - FLOOR(xp)::INTEGER) * (yp - FLOOR(yp)::INTEGER)${s}`);return dt.from(dt.unionAll(c,l,u,f)).select({index:"i",density:Fr("w")},o).groupby("index",o).having(qc("density",0))}var Xy=class extends Wi{constructor(t,n){let{thresholds:r=10,...i}=n;super("geo",t,{bandwidth:20,interpolate:"linear",pixelSize:2,...i}),this.thresholds=an(r,o=>(this.thresholds=o,this.grids?this.contours().update():null))}convolve(){return super.convolve().contours()}contours(){let{bins:t,densityMap:n,grids:r,thresholds:i,plot:o}=this,{numRows:s,columns:a}=r,c=i,l;if(Array.isArray(c))l=c;else{let[,A]=Vy(a.density);l=Array.from({length:c-1},(O,C)=>A*(C+1)/c)}(n.fill||n.stroke)&&this.plot.getAttribute("colorScale")!=="log"&&this.plot.setAttribute("colorZero",!0);let[u,f]=t,[h,d]=o.getAttribute("xDomain"),[p,m]=o.getAttribute("yDomain"),y=(d-h)/u,g=(m-p)/f,x=+h,b=+p,w=A=>x+A*y,_=A=>b+A*g,v=ka().size(t),M=this.contourData=Array(s*l.length),{density:E,...I}=a,D=Object.entries(I);for(let A=0,O=0;A<s;++A){let C=E[A],S=D.reduce((T,[N,F])=>(T[N]=F[A],T),{});for(let T=0;T<l.length;++T,++O)M[O]=Object.assign(gnt(v.contour(C,l[T]),w,_),S)}return this}plotSpecs(){let{type:t,channels:n,densityMap:r,contourData:i}=this,o={};for(let s of n){let{channel:a}=s;a!=="x"&&a!=="y"&&(o[a]=Yn(s))}for(let s in r)r[s]&&(o[s]=Yn({channel:s,as:"value"}));return[{type:t,data:i,options:o}]}};function gnt(e,t,n){function r(s){s.forEach(i)}function i(s){s.forEach(o)}function o(s){s[0]=t(s[0]),s[1]=n(s[1])}return e.coordinates.forEach(r),e}function Rv(e,t){if(typeof document<"u"){let n=document.createElement("canvas");return n.setAttribute("width",e),n.setAttribute("height",t),n}throw new Error("Can not create a canvas instance.")}function KP(e=1){let t=255*e|0;return(n,r,i)=>{for(let o=0,s=0;o<i;++o)for(let a=0;a<r;++a,s+=4)n[s+3]=t}}function tU(e){let{apply:t}=e;return(n,r,i,o)=>{for(let s=0,a=0;s<i;++s)for(let c=0,l=(i-s-1)*r;c<r;++c,a+=4)n[a+3]=255*t(o[c+l])|0}}function eU(e={}){let{r:t=0,g:n=0,b:r=0,opacity:i=1}=typeof e=="string"?rn(e):e,o=new Uint8ClampedArray([t,n,r,255*i|0]);return(s,a,c)=>{for(let l=0,u=0;l<c;++l)for(let f=0;f<a;++f,u+=4)s[u+0]=o[0],s[u+1]=o[1],s[u+2]=o[2],s[u+3]=o[3]}}function nU(e){let{domain:t,range:n}=e,r=Object.create(null),i=new Uint8ClampedArray(4*t.length),o=t.length-1,s=n.length;for(let a=0;a<=o;++a){let c=n[a%s],{r:l,g:u,b:f,opacity:h=1}=typeof c=="string"?rn(c):c,d=a<<2;i[d+0]=l,i[d+1]=u,i[d+2]=f,i[d+3]=255*h|0,r[t[a]]=d}return(a,c,l,u)=>{if(u.map)for(let f=0,h=0;f<l;++f)for(let d=0,p=(l-f-1)*c;d<c;++d,h+=4){let m=r[u[d+p]];a[h+0]=i[m+0],a[h+1]=i[m+1],a[h+2]=i[m+2],a[h+3]=i[m+3]}else{let f=r[u];for(let h=0,d=0;h<l;++h)for(let p=0;p<c;++p,d+=4)a[d+0]=i[f+0],a[d+1]=i[f+1],a[d+2]=i[f+2],a[d+3]=i[f+3]}}}function rU(e,t,n){let{interpolate:r}=t,i=new Uint8ClampedArray(4*e),o=e-1;for(let s=0;s<=o;++s){let a=r(s/o),{r:c,g:l,b:u,opacity:f=1}=typeof a=="string"?rn(a):a,h=s<<2;i[h+0]=c,i[h+1]=l,i[h+2]=u,i[h+3]=255*f|0}return(s,a,c,l)=>{for(let u=0,f=0;u<c;++u)for(let h=0,d=(c-u-1)*a;h<a;++h,f+=4){let p=o*n(l[h+d])<<2;s[f+0]=i[p+0],s[f+1]=i[p+1],s[f+2]=i[p+2],s[f+3]=i[p+3]}}}var yc=class extends Wi{constructor(t,n){super("image",t,n),this.image=null}setPlot(t,n){let r=()=>{this.hasFieldInfo()&&this.rasterize()};t.addAttributeListener("schemeColor",r),super.setPlot(t,n)}convolve(){return super.convolve().rasterize()}rasterize(){let{bins:t,grids:n}=this,[r,i]=t,{numRows:o,columns:s}=n,{canvas:a,ctx:c,img:l}=vnt(this,r,i),{alpha:u,alphaProp:f,color:h,colorProp:d}=V3(this),p=s[f]??[],m=s[d]??[];return this.data={numRows:o,columns:{src:Array.from({length:o},(y,g)=>(h?.(l.data,r,i,m[g]),u?.(l.data,r,i,p[g]),c.putImageData(l,0,0),a.toDataURL()))}},this}plotSpecs(){let{type:t,plot:n,data:{numRows:r,columns:i}}=this,o={src:i.src,width:n.innerWidth(),height:n.innerHeight(),preserveAspectRatio:"none",imageRendering:this.channel("imageRendering")?.value,frameAnchor:"middle"};return[{type:t,data:{length:r},options:o}]}},Gy=class extends yc{constructor(t,n){super(t,{bandwidth:20,interpolate:"linear",pixelSize:2,...n})}};function V3(e){let{aggr:t,densityMap:n,groupby:r,plot:i}=e,o=t.includes(ca),s=t.includes("fillOpacity"),a=e.channel("fill"),c=e.channel("fillOpacity");if(t.length>2||o&&s)throw new Error("Invalid raster encodings. Try dropping an aggregate?");if(r.includes(c?.as))throw new Error("Raster fillOpacity must be an aggregate or constant.");let l=n.fill||t.includes("fill")?"grid":r.includes(a?.as)?"group":Lv(a?.value)?a.value:o&&i.getAttribute("colorScheme")?"grid":void 0,u=n.fillOpacity||t.includes("fillOpacity")?"grid":typeof c?.value=="number"?c.value:o&&l!=="grid"?"grid":void 0;if(l!=="grid"&&u!=="grid")throw new Error("Raster mark missing density values.");let f=a?.as??(l==="grid"?ca:null),h=c?.as??(u==="grid"?ca:null),d=l!=="grid"&&l!=="group"?eU(l):bnt(e,f),p=u!=="grid"?KP(u):xnt(e,h);return{alphaProp:h,colorProp:f,alpha:p,color:d}}function xnt(e,t){let{plot:n,grids:r}=e,i=n.getAttribute("opacityDomain"),o=i===vo,s=i?.[In],a=!o&&!s&&i||Vy(r.columns[t]);(o||s||!i)&&(o||(a[In]=!0),n.setAttribute("opacityDomain",a));let c=rc({opacity:{type:n.getAttribute("opacityScale"),domain:a,clamp:n.getAttribute("opacityClamp"),nice:n.getAttribute("opacityNice"),reverse:n.getAttribute("opacityReverse"),zero:n.getAttribute("opacityZero"),base:n.getAttribute("opacityBase"),exponent:n.getAttribute("opacityExponent"),constant:n.getAttribute("opacityConstant")}});return tU(c)}function bnt(e,t){let{plot:n,grids:r}=e,i=r.columns[t],o=!i[0]?.map,s=o||Array.isArray(i[0]),a=n.getAttribute("colorDomain"),c=a===vo,l=a?.[In],u=!c&&!l&&a||(o?i.sort(zt):s?JP(i):Vy(i));(c||l||!a)&&(c||(u[In]=!0),n.setAttribute("colorDomain",u));let f=rc({color:{type:n.getAttribute("colorScale"),domain:u,range:n.getAttribute("colorRange"),clamp:n.getAttribute("colorClamp"),n:n.getAttribute("colorN"),nice:n.getAttribute("colorNice"),reverse:n.getAttribute("colorReverse"),scheme:n.getAttribute("colorScheme"),interpolate:n.getAttribute("colorInterpolate"),pivot:n.getAttribute("colorPivot"),symmetric:n.getAttribute("colorSymmetric"),zero:n.getAttribute("colorZero"),base:n.getAttribute("colorBase"),exponent:n.getAttribute("colorExponent"),constant:n.getAttribute("colorConstant")}});if(s)return nU(f);{let h=rc({x:{type:wnt(f.type),domain:f.domain,reverse:f.reverse,range:[0,1],clamp:f.clamp,base:f.base,exponent:f.exponent,constant:f.constant}});return rU(1024,f,h.apply)}}function wnt(e){return e.endsWith("symlog")?"symlog":e.endsWith("log")?"log":e.endsWith("pow")?"pow":e.endsWith("sqrt")?"sqrt":e==="diverging"?"linear":e}function vnt(e,t,n){if(!e.image||e.image.w!==t||e.image.h!==n){let r=Rv(t,n),i=r.getContext("2d",{willReadFrequently:!0}),o=i.getImageData(0,0,t,n);e.image={canvas:r,ctx:i,img:o,w:t,h:n}}return e.image}var Wy=class extends yc{constructor(t,n){let{normalize:r=!0,...i}=n;super(t,i),this.normalize=an(r,o=>(this.normalize=o,this.requestUpdate()))}query(t=[]){let{channels:n,normalize:r,source:i,pad:o}=this,[s,a]=this.bins=this.binDimensions(),[c]=Gr(this,"x",s,Ko(this,t),o),[l]=Gr(this,"y",a,ts(this,t),o),u=dt.from(i.table).where(_nt(this,t));this.aggr=["density"];let f=this.groupby=[],h=[];for(let d of n)if(Object.hasOwn(d,"field")){let{channel:p,field:m}=d;p==="z"?(u.select({[p]:m}),h.push("z")):p!=="x"&&p!=="y"&&(u.select({[p]:m}),f.push(p))}return Snt(u,c,l,h,s,a,f,r)}};function _nt(e,t){if(Array.isArray(t)&&!t.length)return t;let{column:n}=e.channelField("x"),{column:r}=e.channelField("y"),i=s=>{let a=`${s.field}`;return s.op!=="BETWEEN"||a!==n&&a!==r},o=s=>s.op==="AND"?Hn(s.children.filter(a=>i(a))):s;return Array.isArray(t)?t.filter(s=>i(s)).map(s=>o(s)):o(t)}function Snt(e,t,n,r,i,o,s=[],a=!0){e.select({x:q`FLOOR(${t})::INTEGER`,y:q`FLOOR(${n})::INTEGER`});let c=s.concat(r),l=c.length?`PARTITION BY ${c.join(", ")} `:"",u=dt.from(e).select(c,{x0:"x",y0:"y",dx:q`(lead(x) OVER sw - x)`,dy:q`(lead(y) OVER sw - y)`}).window({sw:q`${l}ORDER BY x ASC`}).qualify(Hn(q`(x0 < ${i} OR x0 + dx < ${i})`,q`(y0 < ${o} OR y0 + dy < ${o})`,q`(x0 > 0 OR x0 + dx > 0)`,q`(y0 > 0 OR y0 + dy > 0)`)),f=dt.select({x:q`GREATEST(MAX(ABS(dx)), MAX(ABS(dy)))`}).from("pairs"),h=dt.select({i:q`UNNEST(range((${f})))::INTEGER`}),d=dt.unionAll(dt.select(c,{x:q`x0 + i`,y:q`y0 + ROUND(i * dy / dx::FLOAT)::INTEGER`}).from("pairs","indices").where(q`ABS(dy) <= ABS(dx) AND i < ABS(dx)`),dt.select(c,{x:q`x0 + ROUND(SIGN(dy) * i * dx / dy::FLOAT)::INTEGER`,y:q`y0 + SIGN(dy) * i`}).from("pairs","indices").where(q`ABS(dy) > ABS(dx) AND i < ABS(dy)`),dt.select(c,{x:"x0",y:"y0"}).from("pairs").where(zc("dx"))),p=["x"].concat(c).join(", "),m=dt.from("raster").select(c,"x","y",a?{w:q`1.0 / COUNT(*) OVER (PARTITION BY ${p})`}:null).where(Hn(Ae("x",[0,i],!0),Ae("y",[0,o],!0)));return dt.with({pairs:u,indices:h,raster:d,points:m}).from("points").select(s,{index:q`x + y * ${i}::INTEGER`,density:a?Fr("w"):kr()}).groupby("index",s)}var gh=class extends Ln{constructor(t,n,r){let{bins:i=1024,bandwidth:o=20,...s}=r,a=t.endsWith("X")?"y":"x";super(t,n,s,a==="x"?z3:q3),this.dim=a,this.bins=an(i,c=>(this.bins=c,this.requestUpdate())),this.bandwidth=an(o,c=>(this.bandwidth=c,this.grid?this.convolve().update():null))}get filterIndexable(){let t=this.dim==="x"?"xDomain":"yDomain",n=this.plot.getAttribute(t);return n&&!n[In]}query(t=[]){if(this.hasOwnData())throw new Error("Density1DMark requires a data source");let{bins:n,channels:r,dim:i,source:{table:o}}=this,s=this.extent=(i==="x"?Ko:ts)(this,t),[a,c]=Gr(this,i,n,s),l=U3(r,o,[i]).where(t.concat(Ae(c,s))),u=this.channelField("weight")?"weight":null;return Int(l,a,u)}queryResult(t){let{columns:{index:n,density:r}}=aa(t);return this.grid=HP(this.bins,n,r),this.convolve()}convolve(){let{bins:t,bandwidth:n,dim:r,grid:i,plot:o,extent:[s,a]}=this,c=i.some(b=>b<0),l=r==="x"?o.innerWidth():o.innerHeight(),u=Yy(n*(t-1)/l,c),f=Fv(u,i,t),h=r==="x"?"y":"x",d=this.channelField(r).as,p=+s,m=(a-p)/(t-1),y=1/m,g=new Float64Array(t),x=new Float64Array(t);for(let b=0;b<t;++b)g[b]=p+b*m,x[b]=f[b]*y;return this.data={numRows:t,columns:{[d]:g,[h]:x}},this}plotSpecs(){let{type:t,data:{numRows:n,columns:r},channels:i,dim:o}=this,s=o==="x"?{y:r.y}:{x:r.x};for(let a of i)s[a.channel]=Yn(a,r);return[{type:t,data:{length:n},options:s}]}};function Int(e,t,n){let r=n?`* ${n}`:"",i=e.clone().select({p:t,i:q`FLOOR(p)::INTEGER`,w:q`(FLOOR(p) + 1 - p)${r}`}),o=e.clone().select({p:t,i:q`FLOOR(p)::INTEGER + 1`,w:q`(p - FLOOR(p))${r}`});return dt.from(dt.unionAll(i,o)).select({index:"i",density:Fr("w")}).groupby("index").having(Gd("density",0))}var Hy=class extends Wi{constructor(t,n){let{type:r="dot",...i}=n;super(r,t,{bandwidth:20,interpolate:"linear",pad:0,pixelSize:2,...i})}convolve(){super.convolve();let{bins:t,pad:n,extentX:r,extentY:i}=this,[o,s]=t,a=Vl(this,"x"),c=Vl(this,"y"),[l,u]=r.map(y=>a.apply(y)),[f,h]=i.map(y=>c.apply(y)),d=(u-l)/(o-n),p=(h-f)/(s-n),m=n?0:.5;return this.data=Mnt(this.grids,t,l,f,d,p,a.invert,c.invert,m),this}plotSpecs(){let{type:t,channels:n,densityMap:r,data:{numRows:i,columns:o}}=this,s={};for(let a of n){let{channel:c}=a;s[c]=c==="x"||c==="y"?o[c]:Yn(a,o)}for(let a in r)r[a]&&(s[a]=o.density);return[{type:t,data:{length:i},options:s}]}};function Mnt(e,t,n,r,i,o,s,a,c){let l=1/(i*o),[u,f]=t,h=u*f,d=h*e.numRows,p=new Float64Array(d),m=new Float64Array(d),y=new Float64Array(d),g={x:p,y:m,density:y},{density:x,...b}=e.columns;for(let _ in b)g[_]=new b[_].constructor(d);let w=0;for(let _=0;_<e.numRows;++_){for(let M in b)g[M].fill(b[M][_],w,w+h);let v=x[_];for(let M=0,E=0;E<f;++E)for(let I=0;I<u;++I,++w,++M)p[w]=s(n+(I+c)*i),m[w]=a(r+(E+c)*o),y[w]=v[M]*l}return{numRows:d,columns:g}}var Ant="geom",Zy=class extends Ln{constructor(t,n={},r){!Cv(t)&&!n?.geometry&&(n.geometry=Jd(Ant)),super("geo",t,n,r)}queryResult(t){super.queryResult(t);let n=this.channelField("geometry")?.as;if(n){let{columns:r}=this.data;typeof r[n][0]=="string"&&(r[n]=r[n].map(i=>JSON.parse(i)))}return this}};var Jy=class extends Ln{constructor(t,n){let{type:r="hexagon",binWidth:i=20,...o}=n;super(r,t,{r:i/2,clip:!0,...o},kv),this.binWidth=an(i,s=>(this.binWidth=s,this.requestUpdate()))}get filterIndexable(){let t=this.plot.getAttribute("xDomain"),n=this.plot.getAttribute("yDomain");return t&&n&&!t[In]&&!n[In]}query(t=[]){if(this.hasOwnData())return null;let{plot:n,binWidth:r,channels:i,source:o}=this,[s,a]=Ko(this,t),[c,l]=ts(this,t),u=.5-n.getAttribute("marginLeft"),f=0-n.getAttribute("marginTop"),h=`${r}::DOUBLE`,d=`${r*(1.5/Math.sqrt(3))}::DOUBLE`,p=`${n.innerWidth()/(a-s)}::DOUBLE`,m=`${n.innerHeight()/(l-c)}::DOUBLE`,y,g,x=new Set,b={},w;for(let I of i)I.channel==="orderby"?w=I.value:I.channel==="x"?y=I:I.channel==="y"?g=I:Object.hasOwn(I,"field")&&(b[I.as]=I.field,I.field.aggregate&&I.field.columns.forEach(D=>x.add(D)));let _=dt.select({[y.as]:q`${s}::DOUBLE + ((x + 0.5 * (y & 1)) * ${h} + ${u})::DOUBLE / ${p}`,[g.as]:q`${l}::DOUBLE - (y * ${d} + ${f})::DOUBLE / ${m}`,...b}).groupby("x","y");w&&_.orderby(w);let v=`${p} * (${y.field} - ${s}::DOUBLE)`,M=`${m} * (${l}::DOUBLE - ${g.field})`,E=dt.select({py:q`(${M} - ${f}) / ${d}`,pj:q`ROUND(py)::INTEGER`,px:q`(${v} - ${u}) / ${h} - 0.5 * (pj & 1)`,pi:q`ROUND(px)::INTEGER`,tt:q`ABS(py-pj) * 3 > 1 AND (px-pi)**2 + (py-pj)**2 > (px - pi - 0.5 * CASE WHEN px < pi THEN -1 ELSE 1 END)**2 + (py - pj - CASE WHEN py < pj THEN -1 ELSE 1 END)**2`,x:q`CASE WHEN tt THEN (pi + (CASE WHEN px < pi THEN -0.5 ELSE 0.5 END) + (CASE WHEN pj & 1 <> 0 THEN 0.5 ELSE -0.5 END))::INTEGER ELSE pi END`,y:q`CASE WHEN tt THEN (pj + CASE WHEN py < pj THEN -1 ELSE 1 END)::INTEGER ELSE pj END`}).select(Array.from(x)).from(o.table).where(bs(y.field),bs(g.field),t);return _.from(E)}};var Qy=class extends Wi{constructor(t,n){let{origin:r=[0,0],dim:i="xy",...o}=n;super("image",t,o),this.image=null,this.origin=r,this.tileX=i.toLowerCase().includes("x"),this.tileY=i.toLowerCase().includes("y")}setPlot(t,n){let r=()=>{this.hasFieldInfo()&&this.rasterize()};t.addAttributeListener("schemeColor",r),super.setPlot(t,n)}requestQuery(){return this.requestTiles()}query(t=[]){return this._filter=t,null}tileQuery(t){let{interpolate:n,pad:r,channels:i,densityMap:o,source:s}=this,[[a,c],[l,u]]=t,[f,h]=this.bins,[d,p]=Gr(this,"x",f,[a,c],r),[m,y]=Gr(this,"y",h,[l,u],r),g=r?[Ae(p,[+a,+c]),Ae(y,[+l,+u])]:[_s(+a,p),vs(p,+c),_s(+l,y),vs(y,+u)],x=dt.from(s.table).where(g),b=this.groupby=[],w={};for(let v of i)if(Object.hasOwn(v,"field")){let{as:M,channel:E,field:I}=v;I.aggregate?(w[E]=I,o[E]=!0):E==="weight"?w.density=Fr(I):E!=="x"&&E!=="y"&&(x.select({[M]:I}),b.push(M))}let _=this.aggr=Object.keys(w);if(w.density&&_.length>1)throw new Error("Weight option can not be used with custom aggregates.");if(_.length||(_.push("density"),w.density=kr()),n==="linear"){if(_.length>1)throw new Error("Linear binning not applicable to multiple aggregates.");if(!w.density)throw new Error("Linear binning not applicable to custom aggregates.");return Ont(x,d,m,w.density,f,b)}else return Dnt(x,d,m,w,f,b)}async requestTiles(){let t=ai();this.prefetch&&t.cancel(this.prefetch);let{pad:n,tileX:r,tileY:i,origin:[o,s]}=this,[a,c]=this.bins=this.binDimensions(),[l,u]=Ko(this,this._filter),[f,h]=ts(this,this._filter),d=u-l,p=h-f,m=Math.floor((l-o)*(a-n)/d),y=Math.floor((f-s)*(c-n)/p),g=(A,O)=>[[o+A*d,o+(A+1)*d],[s+O*p,s+(O+1)*p]],x=Math.floor((l-o)/d),b=r?iU((u-o)/d):x,w=Math.floor((f-s)/p),_=i?iU((h-s)/p):w,v=[];for(let A=x;A<=b;++A)for(let O=w;O<=_;++O)v.push([A,O]);let M=v.map(([A,O])=>t.query(this.tileQuery(g(A,O)))),E=[];if(r)for(let A=w;A<=_;++A)E.push([b+1,A]),E.push([x-1,A]);if(i){let A=r?x-1:x,O=r?b+1:b;for(let C=A;C<=O;++C)E.push([C,_+1]),E.push([C,w-1])}this.prefetch=E.map(([A,O])=>t.prefetch(this.tileQuery(g(A,O))));let I=await Promise.all(M),D=Tnt(a,c,m,y,v,I);this.grids0={numRows:D.length,columns:{density:[D]}},this.convolve().update()}convolve(){return super.convolve().rasterize()}rasterize(){let{bins:t,grids:n}=this,[r,i]=t,{numRows:o,columns:s}=n,{canvas:a,ctx:c,img:l}=Nnt(this,r,i),{alpha:u,alphaProp:f,color:h,colorProp:d}=V3(this),p=s[f]??[],m=s[d]??[];return this.data={numRows:o,columns:{src:Array.from({length:o},(y,g)=>(h?.(l.data,r,i,m[g]),u?.(l.data,r,i,p[g]),c.putImageData(l,0,0),a.toDataURL()))}},this}plotSpecs(){let{type:t,plot:n,data:{numRows:r,columns:i}}=this,o={src:i.src,width:n.innerWidth(),height:n.innerHeight(),preserveAspectRatio:"none",imageRendering:this.channel("imageRendering")?.value,frameAnchor:"middle"};return[{type:t,data:{length:r},options:o}]}};function Tnt(e,t,n,r,i,o){let s=new Float64Array(e*t);return o.forEach((a,c)=>{let[l,u]=i[c],f=l*e-n,h=u*t-r;Ent(e,t,s,a,f,h)}),s}function Ent(e,t,n,r,i,o){let s=r.numRows;if(s===0)return;let a=r.getChild("index").toArray(),c=r.getChild("density").toArray();for(let l=0;l<s;++l){let u=a[l],f=i+u%e,h=o+Math.floor(u/e);0<=f&&f<e&&0<=h&&h<t&&(n[f+h*e]=c[l])}}function Nnt(e,t,n){if(!e.image||e.image.w!==t||e.image.h!==n){let r=Rv(t,n),i=r.getContext("2d",{willReadFrequently:!0}),o=i.getImageData(0,0,t,n);e.image={canvas:r,ctx:i,img:o,w:t,h:n}}return e.image}function Dnt(e,t,n,r,i,o){return e.select({index:q`FLOOR(${t})::INTEGER + FLOOR(${n})::INTEGER * ${i}`,...r}).groupby("index",o)}function Ont(e,t,n,r,i,o){let s=r.column?`* ${r.column}`:"",a=(h,d)=>e.clone().select({xp:t,yp:n,i:h,w:d}),c=a(q`FLOOR(xp)::INTEGER + FLOOR(yp)::INTEGER * ${i}`,q`(FLOOR(xp)::INTEGER + 1 - xp) * (FLOOR(yp)::INTEGER + 1 - yp)${s}`),l=a(q`FLOOR(xp)::INTEGER + (FLOOR(yp)::INTEGER + 1) * ${i}`,q`(FLOOR(xp)::INTEGER + 1 - xp) * (yp - FLOOR(yp)::INTEGER)${s}`),u=a(q`FLOOR(xp)::INTEGER + 1 + FLOOR(yp)::INTEGER * ${i}`,q`(xp - FLOOR(xp)::INTEGER) * (FLOOR(yp)::INTEGER + 1 - yp)${s}`),f=a(q`FLOOR(xp)::INTEGER + 1 + (FLOOR(yp)::INTEGER + 1) * ${i}`,q`(xp - FLOOR(xp)::INTEGER) * (yp - FLOOR(yp)::INTEGER)${s}`);return dt.from(dt.unionAll(c,l,u,f)).select({index:"i",density:Fr("w")},o).groupby("index",o).having(qc("density",0))}function iU(e){let t=Math.floor(e);return t===e?t-1:t}function Bnt(e,t,n){var r=1e-8,i=t-1,o=n-1,s=0,a,c,l,u,f,h,d,p,m,y,g;if(e<=0)return 0;if(e>=1)return 1;for(t>=1&&n>=1?(l=e<.5?e:1-e,u=Math.sqrt(-2*Math.log(l)),d=(2.30753+u*.27061)/(1+u*(.99229+u*.04481))-u,e<.5&&(d=-d),p=(d*d-3)/6,m=2/(1/(2*t-1)+1/(2*n-1)),y=d*Math.sqrt(p+m)/m-(1/(2*n-1)-1/(2*t-1))*(p+5/6-2/(3*m)),d=t/(t+n*Math.exp(2*y))):(a=Math.log(t/(t+n)),c=Math.log(n/(t+n)),u=Math.exp(t*a)/t,f=Math.exp(n*c)/n,y=u+f,e<u/y?d=Math.pow(t*y*e,1/t):d=1-Math.pow(n*y*(1-e),1/n)),g=-xh(t)-xh(n)+xh(t+n);s<10;s++){if(d===0||d===1)return d;if(h=Lnt(d,t,n)-e,u=Math.exp(i*Math.log(d)+o*Math.log(1-d)+g),f=h/u,d-=u=f/(1-.5*Math.min(1,f*(i/d-o/(1-d)))),d<=0&&(d=.5*(d+u)),d>=1&&(d=.5*(d+u+1)),Math.abs(u)<r*d&&s>0)break}return d}function Lnt(e,t,n){var r=e===0||e===1?0:Math.exp(xh(t+n)-xh(t)-xh(n)+t*Math.log(e)+n*Math.log(1-e));return e<0||e>1?0:e<(t+1)/(t+n+2)?r*oU(e,t,n)/t:1-r*oU(1-e,n,t)/n}function oU(e,t,n){var r=1e-30,i=1,o=t+n,s=t+1,a=t-1,c=1,l=1-o*e/s,u,f,h,d;for(Math.abs(l)<r&&(l=r),l=1/l,d=l;i<=100&&(u=2*i,f=i*(n-i)*e/((a+u)*(t+u)),l=1+f*l,Math.abs(l)<r&&(l=r),c=1+f/c,Math.abs(c)<r&&(c=r),l=1/l,d*=l*c,f=-(t+i)*(o+i)*e/((t+u)*(s+u)),l=1+f*l,Math.abs(l)<r&&(l=r),c=1+f/c,Math.abs(c)<r&&(c=r),l=1/l,h=l*c,d*=h,!(Math.abs(h-1)<3e-7));i++);return d}function xh(e){var t=0,n=[76.18009172947146,-86.5053203294167,24.01409824083091,-1.231739572450155,.001208650973866179,-5395239384953e-18],r=1.000000000190015,i,o,s;for(s=(o=i=e)+5.5,s-=(i+.5)*Math.log(s);t<6;t++)r+=n[t]/++o;return Math.log(2.506628274631*r/i)-s}function sU(e,t){var n=Bnt(2*Math.min(e,1-e),.5*t,.5);return n=Math.sqrt(t*(1-n)/n),e>.5?n:-n}var Ky=class extends Ln{constructor(t,n){let{ci:r=.95,precision:i=4,...o}=n;super("line",t,o);let s=()=>this.modelFit?this.confidenceBand().update():null;this.ci=an(r,a=>(this.ci=a,s())),this.precision=an(i,a=>(this.precision=a,s()))}query(t=[]){let n=this.channelField("x").as,r=this.channelField("y").as,i=Array.from(new Set(["stroke","z","fx","fy"].flatMap(o=>this.channelField(o)?.as||[])));return dt.from(super.query(t)).select({intercept:fS(r,n),slope:hS(r,n),n:dS(r,n),ssy:pS(r,n),ssx:mS(r,n),xm:yS(r,n),x0:Mu(si(n).where(bs(r))),x1:Mu(oi(n).where(bs(r)))}).select(i).groupby(i)}queryResult(t){return this.modelFit=aa(t),this.lineData=Cnt(this.modelFit),this.confidenceBand()}confidenceBand(){let{ci:t,modelFit:n,precision:r,plot:i}=this,o=i.innerWidth();return this.areaData=t?knt(n,t,r,o):null,this}plotSpecs(){let{lineData:t,areaData:n,channels:r,ci:i}=this,o=t.columns,s=i?n.columns:{},a={x:o.x,y:o.y},c={x:s.x,y1:s.y1,y2:s.y2,fillOpacity:.1};for(let l of r)switch(l.channel){case"x":case"y":case"fill":break;case"tip":c.tip=Yn(l,s);break;case"stroke":a.stroke=Yn(l,o),c.fill=Yn(l,s);break;case"strokeOpacity":a.strokeOpacity=Yn(l,o);break;case"fillOpacity":c.fillOpacity=Yn(l,s);break;default:a[l.channel]=Yn(l,o),c[l.channel]=Yn(l,s);break}return[...i?[{type:"areaY",data:{length:n.numRows},options:c}]:[],{type:"line",data:{length:t.numRows},options:a}]}};function Y3(e,t){if(e.concat)return e.concat(t);let n=new e.constructor(e.length+t.length);return n.set(e,0),n.set(t,e.length),n}function Cnt(e){let{x0:t,x1:n,xm:r,intercept:i,slope:o,n:s,ssx:a,ssy:c,...l}=e.columns,u=(d,p)=>i[p]+d*o[p],f=Y3(t,n),h=Y3(t.map(u),n.map(u));for(let d in l)l[d]=Y3(l[d],l[d]);return{numRows:f.length,columns:{x:f,y:h,...l}}}function knt(e,t,n,r){let i=e.numRows,{x0:o,x1:s,xm:a,intercept:c,slope:l,n:u,ssx:f,ssy:h,...d}=e.columns,p=Object.keys(d),m={x:[],y1:[],y2:[]};p.forEach(y=>m[y]=[]);for(let y=0;y<i;++y){let g=n*(s[y]-o[y])/r,x=sU((1-t)/2,u[y]-2)*Math.sqrt(h[y]/(u[y]-2));Ue(o[y],s[y]-g/2,g).concat(s[y]).forEach(b=>{let w=c[y]+b*l[y],_=x*Math.sqrt(1/u[y]+(b-a[y])**2/f[y]);m.x.push(b),m.y1.push(w-_),m.y2.push(w+_),p.forEach(v=>m[v].push(d[v][y]))})}return{numRows:m.x.length,columns:m}}function aU(e){let t=e.toLowerCase(),n=e.length,r="";for(let i=0;i<n;++i)r+=(e[i]!==t[i]?"-":"")+t[i];return r}function bh(e){let t={};for(let n in e)t[aU(n)]=e[n];return t}function Fnt(e){let{channels:t}=e,n=new Set,r=!1,i=!1;for(let o of t){let{channel:s,field:a,as:c}=o;if(s==="orderby")r=!0;else if(a)if(a.aggregate)i=!0;else{if(n.has(c))continue;n.add(c)}}return!r&&i&&n.size&&e.channels.push({channel:"orderby",value:Array.from(n)}),e}var tg=class{constructor(t,{selection:n,channels:r={}}){this.mark=Fnt(t),this.selection=n;let i=Object.entries(bh(r));this.channels=i.length?i:[["opacity",.2]],this.selection.addEventListener("value",Ch(()=>this.update()))}init(t){this.svg=t;let n=this.values=[],r=this.mark.index,i=this.nodes=t.querySelectorAll(`[data-index="${r}"] > *`),{channels:o}=this;for(let s=0;s<i.length;++s){let a=i[s];n.push(o.map(c=>a.getAttribute(c[0])))}return this.update()}async update(){let{svg:t,nodes:n,channels:r,values:i,mark:o,selection:s}=this;if(!t)return;let a=await Rnt(o,s);for(let c=0;c<n.length;++c){let l=n[c],u=i[c],f=a(l.__data__);for(let h=0;h<r.length;++h){let[d,p]=r[h];l.setAttribute(d,f?u[h]:p)}}}};async function Rnt(e,t){let n=t?.predicate(e);if(!n||n.length===0)return()=>!0;let r=e.filterBy?.predicate(e,!0),i={__:Hn(n)},o=e.query(r),s=o.groupby().length?o.select(i):o.$select(i),a=await e.coordinator.query(s),c=a.getChild?.("__");return a.numRows||a.length?c?l=>c.get(l):l=>a[l].__:()=>!1}function X3(e){let t=e.on,n=!0;function r(i){n=!1,i(),n=!0}return e.reset=(...i)=>{r(()=>e.clear(...i))},e.moveSilent=(...i)=>{r(()=>e.move(...i))},e.on=(...i)=>{if(i.length>1&&i[1]){let o=i[1];i[1]=(...s)=>n&&o(...s)}return t(...i)},e}function cU(){return X3(II())}function lU(){return X3(_I())}function uU(){return X3(SI())}function eg(e,t){return e===t||e&&t&&Math.abs(e[0]-t[0])<1e-12&&Math.abs(e[1]-t[1])<1e-12||!1}function es(e,t){let n=e.channelField(t)?.field;return n?.basis||n}function ng(e,t,n=1){return t.invert(n*Math.floor(e/n))}function $v(){let e=this,t=e.getScreenCTM,n;e.getScreenCTM=()=>e.isConnected?n=t.call(e):n}var gc=class{constructor(t,{channel:n,selection:r,field:i=void 0,pixelSize:o=1,peers:s=!0,brush:a}){this.mark=t,this.channel=n,this.pixelSize=o||1,this.selection=r,this.peers=s,this.field=i||es(t,n),this.style=a&&bh(a),this.brush=n==="y"?uU():lU(),this.brush.on("brush end",({selection:c})=>this.publish(c))}reset(){this.value=void 0,this.g&&this.brush.reset(this.g)}activate(){this.selection.activate(this.clause(this.value||[0,1]))}publish(t){let n;t&&(n=t.map(r=>ng(r,this.scale,this.pixelSize)).sort((r,i)=>r-i)),eg(n,this.value)||(this.value=n,this.g.call(this.brush.moveSilent,t),this.selection.update(this.clause(n)))}clause(t){let{mark:n,pixelSize:r,field:i,scale:o}=this;return{source:this,schema:{type:"interval",pixelSize:r,scales:[o]},clients:this.peers?n.plot.markSet:new Set().add(n),value:t,predicate:t?Ae(i,t):null}}init(t,n){let{brush:r,channel:i,style:o}=this;this.scale=t.scale(i);let s=t.scale("x").range,a=t.scale("y").range;r.extent([[ue(s),ue(a)],[Ht(s),Ht(a)]]);let c=Vt(t).selectAll('g[aria-label="facet"]');if(n=c.size()?c:Vt(n??t),this.g=n.append("g").attr("class",`interval-${i}`).each($v).call(r).call(r.moveSilent,this.value?.map(this.scale.apply)),o){let l=this.g.selectAll("rect.selection");for(let u in o)l.attr(u,o[u])}t.addEventListener("pointerenter",l=>{l.buttons||this.activate()})}};var Pv=(e,t)=>e-t,rg=class{constructor(t,{selection:n,xfield:r,yfield:i,pixelSize:o=1,peers:s=!0,brush:a}){this.mark=t,this.pixelSize=o||1,this.selection=n,this.peers=s,this.xfield=r||es(t,"x"),this.yfield=i||es(t,"y"),this.style=a&&bh(a),this.brush=cU(),this.brush.on("brush end",({selection:c})=>this.publish(c))}reset(){this.value=void 0,this.g&&this.brush.reset(this.g)}activate(){this.selection.activate(this.clause(this.value||[[0,1],[0,1]]))}publish(t){let{value:n,pixelSize:r,xscale:i,yscale:o}=this,s,a;if(t){let[c,l]=t;s=[c[0],l[0]].map(u=>ng(u,i,r)).sort(Pv),a=[c[1],l[1]].map(u=>ng(u,o,r)).sort(Pv)}(!eg(s,n?.[0])||!eg(a,n?.[1]))&&(this.value=t?[s,a]:void 0,this.g.call(this.brush.moveSilent,t),this.selection.update(this.clause(this.value)))}clause(t){let{mark:n,pixelSize:r,xfield:i,yfield:o,xscale:s,yscale:a}=this;return{source:this,schema:{type:"interval",pixelSize:r,scales:[s,a]},clients:this.peers?n.plot.markSet:new Set().add(n),value:t,predicate:t?Hn(Ae(i,t[0]),Ae(o,t[1])):null}}init(t){let{brush:n,style:r}=this,i=this.xscale=t.scale("x"),o=this.yscale=t.scale("y"),s=i.range,a=o.range;n.extent([[ue(s),ue(a)],[Ht(s),Ht(a)]]);let c=Vt(t).selectAll('g[aria-label="facet"]'),l=c.size()?c:Vt(t);if(this.g=l.append("g").attr("class","interval-xy").each($v).call(n),r){let u=this.g.selectAll("rect.selection");for(let f in r)u.attr(f,r[f])}if(this.value){let[u,f]=this.value[0].map(i.apply).sort(Pv),[h,d]=this.value[1].map(o.apply).sort(Pv);this.g.call(n.moveSilent,[[u,h],[f,d]])}t.addEventListener("pointerenter",u=>{u.buttons||this.activate()})}};var wh=class{constructor(t,{selection:n,channel:r,field:i}){this.mark=t,this.selection=n,this.clients=new Set().add(t),this.channel=r,this.field=i||es(t,[r])}clause(t){let{clients:n,field:r}=this,i=t?ws(r,Cr(t)):null;return{source:this,schema:{type:"point"},clients:n,value:t,predicate:i}}init(t){let n=this,{mark:r,channel:i,selection:o}=this,{data:s}=r,a=r.channelField(i).as,c=Vt(t).selectAll('g[aria-label="facet"]'),l=c.size()?c:Vt(t),u=t.scale(i),f=!ci(o);l.on("pointerdown pointermove",function(h){let[d,p]=Fn(h,this),m=$nt(s.columns[a],u.invert(i==="x"?d:p));o.update(f?m:n.clause(m))}),!f&&t.addEventListener("pointerenter",h=>{h.buttons||this.selection.activate(this.clause(0))})}};function $nt(e,t){let n=1/0,r;for(let i=0;i<e.length;++i){let o=Math.abs(e[i]-t);o<n&&(n=o,r=e[i])}return r}var fU=(e,t)=>e-t,ig=class{constructor(t,{x:n=new Ss,y:r=new Ss,xfield:i,yfield:o,zoom:s=!0,panx:a=!0,pany:c=!0}){this.mark=t,this.xsel=n,this.ysel=r,this.xfield=i||es(t,"x"),this.yfield=o||es(t,"y"),this.zoom=G3(s,[0,1/0],[1,1]),this.panx=this.xsel&&a,this.pany=this.ysel&&c;let{plot:l}=t;a&&this.xsel.addEventListener("value",u=>{l.setAttribute("xDomain",u)&&l.update()}),c&&this.ysel.addEventListener("value",u=>{l.setAttribute("yDomain",u)&&l.update()})}publish(t){if(this.panx){let n=Pnt(t,this.xscale);this.xsel.update(this.clause(n,this.xfield,this.xscale))}if(this.pany){let n=Unt(t,this.yscale);this.ysel.update(this.clause(n,this.yfield,this.yscale))}}clause(t,n,r){return{source:this,schema:{type:"interval",scales:[r]},clients:this.mark.plot.markSet,value:t,predicate:t?Ae(n,t):null}}init(t){if(this.svg=t,this.initialized)return;this.initialized=!0;let{panx:n,pany:r,mark:{plot:{element:i}},xsel:o,ysel:s}=this;this.xscale=t.scale("x"),this.yscale=t.scale("y");let a=this.xscale.range.slice().sort(fU),c=this.yscale.range.slice().sort(fU),l=G3(n,[-1/0,1/0],a),u=G3(r,[-1/0,1/0],c),f=zA().extent([[a[0],c[0]],[a[1],c[1]]]).scaleExtent(this.zoom).translateExtent([[l[0],u[0]],[l[1],u[1]]]).on("start",()=>{this.xscale=this.svg.scale("x"),this.yscale=this.svg.scale("y")}).on("end",()=>i.__zoom=new qr(1,0,0)).on("zoom",({transform:h})=>this.publish(h));if(Vt(i).call(f),n||r){let h=!1;i.addEventListener("pointerenter",d=>{if(!h&&(h=!0,!d.buttons)){if(n){let{xscale:p,xfield:m}=this;o.activate(this.clause(p.domain,m,p))}if(r){let{yscale:p,yfield:m}=this;s.activate(this.clause(p.domain,m,p))}}}),i.addEventListener("pointerleave",()=>h=!1)}}};function G3(e,t,n){return e?Array.isArray(e)?e:t:n}function Pnt(e,t){return t.range.map(e.invertX,e).map(t.invert,t)}function Unt(e,t){return t.range.map(e.invertY,e).map(t.invert,t)}var Yl=class{constructor(t,{selection:n,channels:r,peers:i=!0}){this.value=null,this.mark=t,this.selection=n,this.peers=i,this.channels=r.map(o=>{let s=o==="color"?["color","fill","stroke"]:o==="x"?["x","x1","x2"]:o==="y"?["y","y1","y2"]:[o];for(let a=0;a<s.length;++a){let c=t.channelField(s[a],{exact:!0});if(c)return{field:c.field?.basis||c.field,as:c.as}}throw new Error(`Missing channel: ${o}`)})}clause(t){let{channels:n,mark:r}=this,i=null;if(t){let o=t.map(s=>{let a=s.map((c,l)=>Wd(n[l].field,Cr(c)));return a.length>1?Hn(a):a[0]});i=o.length>1?Uc(o):o[0]}return{source:this,schema:{type:"point"},clients:this.peers?r.plot.markSet:new Set().add(r),value:t,predicate:i}}init(t,n,r){let{mark:i,channels:o,selection:s}=this,{data:{columns:a={}}={}}=i;r??=l=>o.map(u=>a[u.as][l.__data__]),n??=`[data-index="${i.index}"]`;let c=new Set(t.querySelectorAll(n));t.addEventListener("pointerdown",l=>{let u=s.single?s.value:this.value,f=l.target,h=null;if(znt(c,f)){let d=r(f);(l.shiftKey||l.metaKey)&&u?.length?(h=u.filter(p=>W3(p,d)),h.length===u.length&&h.push(d)):u?.length===1&&!W3(u[0],d)?h=null:h=[d]}this.value=h,qnt(u,h)&&s.update(this.clause(h))}),t.addEventListener("pointerenter",l=>{l.buttons||this.selection.activate(this.clause([this.channels.map(()=>0)]))})}};function znt(e,t){return e.has(t)||e.has(t.parentNode)||e.has(t.parentNode?.parentNode)}function qnt(e,t){return e==null||t==null?e!=null||t!=null:e.length!==t.length||e.some((n,r)=>W3(n,t[r]))}function W3(e,t){let n=e.length;if(t.length!==n)return!0;for(let r=0;r<n;++r)if(e[r]!==t[r])return!0;return!1}var dU=":scope > div, :scope > span",Uv="swatch",hU="ramp",vh=class{constructor(t,n){let{as:r,field:i,...o}=n;this.channel=t,this.options={label:null,...o},this.type=null,this.handler=null,this.selection=r,this.field=i,this.legend=null,this.element=document.createElement("div"),this.element.setAttribute("class","legend"),Object.assign(this.element,{value:this})}setPlot(t){this.plot=t}init(t){let n=jnt(this,t);return this.element.replaceChildren(n),this.element}update(){if(!this.legend)return;let{value:t}=this.selection,n=t&&t.length?new Set(t.map(i=>i[0])):null,r=this.legend.querySelectorAll(dU);for(let i of r){let o=n?n.has(i.__data__):!0;i.style.opacity=o?1:.2}}};function jnt(e,t){let{channel:n,options:r,selection:i}=e,o=t.scale(n),s=o.type==="ordinal"?Uv:hU,a=s===Uv?r:r.label?{tickSize:2,...r}:{tickSize:2,marginTop:1,height:29,...r},c=t.legend(n,a);e.legend=c;let l=!!i;if(l&&s===hU){let u=a.width??240,f=Gnt(o,u);f?c.scale=function(h){return h==="x"?{range:[0,u]}:h==="y"?{range:[-10,0]}:h===n?f:void 0}:l=!1}if(l){let u=Vnt(e,s);s===Uv?(u.init(c,dU,f=>[f.__data__]),e.update()):u.init(c,c.querySelector("g:last-of-type"))}return c}function Vnt(e,t){let{channel:n,handler:r,selection:i}=e;if(r)return r;let o=Ynt(e);if(t===Uv)e.handler=new Yl(o,{selection:i,channels:[n]}),i.addEventListener("value",()=>e.update());else{let s={fill:"none",stroke:"currentColor"};e.handler=new gc(o,{selection:i,channel:n,brush:s})}return e.handler}function Ynt(e){let{channel:t,plot:n}=e,r=e.field??Xnt(n.marks,t)??"value";if(r){let i={field:r};return{plot:n,channelField:o=>t===o?i:void 0}}}function Xnt(e,t){let n=t==="color"?["fill","stroke"]:t==="opacity"?["opacity","fillOpacity","strokeOpacity"]:null;if(n==null)return null;for(let r=e.length-1;r>-1;--r)for(let i of n){let o=e[r].channelField(i,{exact:!0});if(o)return o.field}return null}function Gnt(e,t){let{apply:n,invert:r,interpolate:i,...o}=e,s=e.type;s.startsWith("diverging-")&&(s=s.slice(11));let a;switch(s){case"log":case"pow":case"sqrt":case"symlog":a=s;break;case"threshold":case"quantize":case"quantile":return console.warn(`Legends do not yet support ${s} scales.`),null;default:a="linear"}return rc({x:{...o,type:a,range:[0,t]}})}var Wnt=new Set(["rectY-x","rectX-y","rect-x","rect-y"]);function zv(e,t={steps:25}){let n=(r,i)=>Wnt.has(`${r.type}-${i}`)?{[`${i}1`]:H3(r,i,e,t),[`${i}2`]:H3(r,i,e,{...t,offset:1})}:{[i]:H3(r,i,e,t)};return n[op]=!0,n}function H3(e,t,n,r){return{column:n,label:n,get stats(){return{column:n,stats:["min","max"]}},get columns(){return[n]},get basis(){return n},toString(){let{apply:i,sqlApply:o,sqlInvert:s}=Vl(e,t),{min:a,max:c}=e.channelField(t),l=Hnt(i(a),i(c),r),u=o(n),f=l.min===0?u:`(${u} - ${l.min})`,h=`${(l.max-l.min)/l.steps}::DOUBLE`,d=r.offset?`${r.offset} + `:"",p=`${l.min} + ${h} * (${d}FLOOR(${f} / ${h}))`;return`${s(p)}`}}}function Hnt(e,t,n){let{steps:r=25,minstep:i=0,nice:o=!0}=n;if(o!==!1){let s=t-e,a=r,c=Math.LN10,l=Math.ceil(Math.log(a)/c),u=Math.max(i,Math.pow(10,Math.round(Math.log(s)/c)-l));for(;Math.ceil(s/u)>a;)u*=10;let f=[5,2],h;for(let m=0,y=f.length;m<y;++m)h=u/f[m],h>=i&&s/h<=a&&(u=h);h=Math.log(u);let d=h>=0?0:~~(-h/c)+1,p=Math.pow(10,-d-1);h=Math.floor(e/u+p)*u,e=e<h?h-u:h,t=Math.ceil(t/u)*u,r=Math.round((t-e)/u)}return{min:e,max:t,steps:r}}var Znt=e=>e&&typeof e=="object"&&!Array.isArray(e);var og=class extends fr{constructor({element:t,filterBy:n,from:r,column:i,label:o=i,format:s=u=>u,options:a,value:c,as:l}={}){super(n),this.from=r,this.column=i,this.selection=l,this.format=s,this.element=t??document.createElement("div"),this.element.setAttribute("class","input"),this.element.value=this;let u=document.createElement("label");u.innerText=o||i,this.element.appendChild(u),this.select=document.createElement("select"),a&&(this.data=a.map(f=>Znt(f)?f:{value:f}),this.update()),c=c??this.selection?.value??this.data?.[0]?.value,this.selection?.value===void 0&&this.publish(c),this.element.appendChild(this.select),this.selection&&(this.select.addEventListener("input",()=>{this.publish(this.selectedValue()??null)}),ci(this.selection)||this.selection.addEventListener("value",f=>{f!==this.select.value&&this.selectedValue(f)}))}selectedValue(t){if(arguments.length===0){let n=this.select.selectedIndex;return this.data[n].value}else{let n=this.data?.findIndex(r=>r.value===t);n>=0?this.select.selectedIndex=n:this.select.value=String(t)}}reset(){this.select.selectedIndex=this.from?0:-1}publish(t){let{selection:n,column:r}=this;ci(n)?n.update({source:this,schema:{type:"point"},value:t,predicate:t!==""&&t!==void 0?ws(r,Cr(t)):null}):wr(n)&&n.update(t)}query(t=[]){let{from:n,column:r}=this;return n?dt.from(n).select({value:r}).distinct().where(t).orderby(r):null}queryResult(t){return this.data=[{value:"",label:"All"},...t],this}update(){let{data:t,format:n,select:r}=this;r.replaceChildren();for(let{value:i,label:o}of t){let s=document.createElement("option");s.setAttribute("value",i),s.innerText=o??n(i),this.select.appendChild(s)}return this.selection&&this.selectedValue(this.selection?.value??""),this}};var Jnt={contains:C2,prefix:k2,suffix:F2,regexp:L2},Qnt=0;var sg=class extends fr{constructor({element:t,filterBy:n,from:r,column:i,label:o,type:s="contains",as:a}={}){if(super(n),this.id="search_"+ ++Qnt,this.type=s,this.from=r,this.column=i,this.selection=a,this.element=t??document.createElement("div"),this.element.setAttribute("class","input"),this.element.value=this,o){let c=document.createElement("label");c.setAttribute("for",this.id),c.innerText=o,this.element.appendChild(c)}this.searchbox=document.createElement("input"),this.searchbox.setAttribute("id",this.id),this.searchbox.setAttribute("type","text"),this.searchbox.setAttribute("placeholder","Query"),this.element.appendChild(this.searchbox),this.selection&&(this.searchbox.addEventListener("input",()=>{this.publish(this.searchbox.value||null)}),ci(this.selection)||this.selection.addEventListener("value",c=>{c!==this.searchbox.value&&(this.searchbox.value=c)}))}reset(){this.searchbox.value=""}publish(t){let{selection:n,column:r,type:i}=this;ci(n)?n.update({source:this,schema:{type:i},value:t,predicate:t?Jnt[i](r,Cr(t)):null}):wr(n)&&n.update(t)}query(t=[]){let{from:n,column:r}=this;return n?dt.from(n).select({list:r}).distinct().where(t):null}queryResult(t){return this.data=t,this}update(){let t=document.createElement("datalist"),n=`${this.id}_list`;t.setAttribute("id",n);for(let r of this.data){let i=document.createElement("option");i.setAttribute("value",r.list),t.append(i)}return this.datalist&&this.datalist.remove(),this.element.appendChild(this.datalist=t),this.searchbox.setAttribute("list",n),this}};var Knt=0;var ag=class extends fr{constructor({element:t,filterBy:n,as:r,min:i,max:o,step:s,from:a,column:c,label:l=c,value:u=r?.value,width:f}={}){if(super(n),this.id="slider_"+ ++Knt,this.from=a,this.column=c||"value",this.selection=r,this.min=i,this.max=o,this.step=s,this.element=t||document.createElement("div"),this.element.setAttribute("class","input"),this.element.value=this,l){let h=document.createElement("label");h.setAttribute("for",this.id),h.innerText=l,this.element.appendChild(h)}this.slider=document.createElement("input"),this.slider.setAttribute("id",this.id),this.slider.setAttribute("type","range"),f!=null&&(this.slider.style.width=`${+f}px`),i!=null&&this.slider.setAttribute("min",i),o!=null&&this.slider.setAttribute("max",o),s!=null&&this.slider.setAttribute("step",s),u!=null&&(this.slider.setAttribute("value",u),this.selection?.value===void 0&&this.publish(u)),this.element.appendChild(this.slider),this.selection&&(this.slider.addEventListener("input",()=>{this.publish(+this.slider.value)}),ci(this.selection)||this.selection.addEventListener("value",h=>{h!==+this.slider.value&&(this.slider.value=h)}))}query(t=[]){let{from:n,column:r}=this;return!n||this.min!=null&&this.max!=null?null:dt.select({min:si(r),max:oi(r)}).from(n).where(t)}queryResult(t){let{min:n,max:r}=Array.from(t)[0];return this.min==null&&this.slider.setAttribute("min",n),this.max==null&&this.slider.setAttribute("max",r),this.step==null&&this.slider.setAttribute("step",String((r-n)/500)),this}publish(t){let{selection:n,column:r}=this;ci(n)?n.update({source:this,schema:{type:"point"},value:t,predicate:ws(r,Cr(t))}):wr(this.selection)&&n.update(t)}};var J3=pU(e=>{let t=qv(e);return n=>n==null?"":typeof n=="number"?t(n):n instanceof Date?Q3(n):`${n}`}),qv=pU(e=>t=>t===0?"0":t.toLocaleString(e)),aVt=J3(),cVt=qv();function Q3(e){return wf(e,"Invalid Date")}function pU(e){let t=null,n;return(r="en")=>r===t?n:n=e(t=r)}var trt=-1;var cg=class extends fr{constructor({element:t,filterBy:n,from:r,columns:i=["*"],align:o={},format:s,width:a,maxWidth:c,height:l=500,rowBatch:u=100}={}){super(n),this.id=`table-${++trt}`,this.from=r,this.columns=i,this.format=s,this.align=o,this.widths=typeof a=="object"?a:{},this.offset=0,this.limit=+u,this.pending=!1,this.sortHeader=null,this.sortColumn=null,this.sortDesc=!1,this.element=t||document.createElement("div"),this.element.setAttribute("id",this.id),this.element.value=this,typeof a=="number"&&(this.element.style.width=`${a}px`),c&&(this.element.style.maxWidth=`${c}px`),this.element.style.maxHeight=`${l}px`,this.element.style.overflow="auto";let f=-1;this.element.addEventListener("scroll",h=>{let{pending:d,loaded:p}=this,{scrollHeight:m,scrollTop:y,clientHeight:g}=h.target,x=y<f;f=y,!(x||d||p)&&m-y<2*g&&(this.pending=!0,this.requestData(this.offset+this.limit))}),this.tbl=document.createElement("table"),this.element.appendChild(this.tbl),this.head=document.createElement("thead"),this.tbl.appendChild(this.head),this.body=document.createElement("tbody"),this.tbl.appendChild(this.body),this.style=document.createElement("style"),this.element.appendChild(this.style)}requestData(t=0){this.offset=t;let n=this.query(this.filterBy?.predicate(this));this.requestQuery(n),ai().prefetch(n.clone().offset(t+this.limit))}fields(){return this.columns.map(t=>Sa(this.from,t))}fieldInfo(t){this.schema=t;let n=this.head;n.innerHTML="";let r=document.createElement("tr");for(let{column:i}of t){let o=document.createElement("th");o.addEventListener("click",s=>this.sort(s,i)),o.appendChild(document.createElement("span")),o.appendChild(document.createTextNode(i)),r.appendChild(o)}return n.appendChild(r),this.formats=ert(this.format,t),this.style.innerText=irt(this.id,nrt(this.align,t),rrt(this.widths,t)),this}query(t=[]){let{from:n,limit:r,offset:i,schema:o,sortColumn:s,sortDesc:a}=this;return dt.from(n).select(o.map(c=>c.column)).where(t).orderby(s?a?E2(s):s:[]).limit(r).offset(i)}queryResult(t){return this.pending||(this.loaded=!1,this.body.replaceChildren()),this.data=t,this}update(){let{body:t,formats:n,data:r,schema:i,limit:o}=this,s=i.length,a=0;for(let c of r){++a;let l=document.createElement("tr");for(let u=0;u<s;++u){let f=c[i[u].column],h=document.createElement("td");h.innerText=f==null?"":n[u](f),l.appendChild(h)}t.appendChild(l)}return a<o&&(this.loaded=!0),this.pending=!1,this}sort(t,n){n===this.sortColumn?this.sortDesc=!this.sortDesc:(this.sortColumn=n,this.sortDesc=!1);let r=t.currentTarget,i=this.sortHeader;i===r&&t.metaKey?(i.firstChild.textContent="",this.sortHeader=null,this.sortColumn=null):(i&&(i.firstChild.textContent=""),this.sortHeader=r,r.firstChild.textContent=this.sortDesc?"\u25BE":"\u25B4"),this.requestData()}};function ert(e={},t,n){return t.map(({column:r,type:i})=>{if(r in e)return e[r];switch(i){case"number":return qv(n);case"date":return Q3;default:return J3(n)}})}function nrt(e={},t){return t.map(({column:n,type:r})=>n in e?e[n]:r==="number"?"right":"left")}function rrt(e={},t){return t.map(({column:n})=>e[n])}function irt(e,t,n){let r=[];return t.forEach((i,o)=>{let s=+n[o];if(i!=="left"||s){let a=i!=="left"?`text-align:${i};`:"",c=s?`width:${s}px;max-width:${s}px;`:"";r.push(`#${e} tr>:nth-child(${o+1}) {${a}${c}}`)}}),r.join(" ")}function lg(e,...t){let n=e?.context?.coordinator??ai();for(let r of t)n.connect(r)}function jv(e,t,n){let r=new t(n);return lg(e,r),r.element}function mU(e){return jv(this,og,e)}function yU(e){return jv(this,sg,e)}function gU(e){return jv(this,ag,e)}function xU(e){return jv(this,cg,e)}function bU({direction:e="vertical",wrap:t=!1},n){let r=document.createElement("div");return r.style.display="flex",r.style.flexDirection=e==="vertical"?"column":"row",r.style.flexWrap=t?t===!0?"wrap":t:"nowrap",r.style.justifyContent="flex-start",r.style.alignItems="flex-start",n.forEach(i=>r.appendChild(i)),Object.assign(r,{value:{element:r}}),r}function wU(...e){return bU({direction:"vertical"},e.flat())}function vU(...e){return bU({direction:"horizontal"},e.flat())}function _U({dim:e="width",size:t=10}){let n=document.createElement("span");return n.style.display="inline-block",n.style[e]=Number.isNaN(+t)?t:`${t}px`,Object.assign(n,{value:{element:n}})}function SU(e){return _U({dim:"height",size:e})}function IU(e){return _U({dim:"width",size:e})}var Vv={};Mr(Vv,{align:()=>d6,aspectRatio:()=>p6,axis:()=>m6,colorBase:()=>n8,colorClamp:()=>VE,colorConstant:()=>i8,colorDomain:()=>qE,colorExponent:()=>r8,colorInterpolate:()=>WE,colorLabel:()=>JE,colorN:()=>YE,colorNice:()=>XE,colorPercent:()=>QE,colorPivot:()=>HE,colorRange:()=>jE,colorReverse:()=>KE,colorScale:()=>zE,colorScheme:()=>GE,colorSymmetric:()=>ZE,colorTickFormat:()=>e8,colorZero:()=>t8,facetGrid:()=>z4,facetLabel:()=>q4,facetMargin:()=>F4,facetMarginBottom:()=>$4,facetMarginLeft:()=>P4,facetMarginRight:()=>U4,facetMarginTop:()=>R4,fxAlign:()=>H4,fxAriaDescription:()=>dE,fxAriaLabel:()=>hE,fxAxis:()=>K4,fxDomain:()=>j4,fxFontVariant:()=>fE,fxGrid:()=>sE,fxInset:()=>Y4,fxInsetLeft:()=>X4,fxInsetRight:()=>G4,fxLabel:()=>cE,fxLabelAnchor:()=>lE,fxLabelOffset:()=>uE,fxLine:()=>aE,fxPadding:()=>Z4,fxPaddingInner:()=>J4,fxPaddingOuter:()=>Q4,fxRange:()=>V4,fxReverse:()=>pE,fxRound:()=>W4,fxTickFormat:()=>iE,fxTickPadding:()=>rE,fxTickRotate:()=>oE,fxTickSize:()=>eE,fxTickSpacing:()=>nE,fxTicks:()=>tE,fyAlign:()=>vE,fyAriaDescription:()=>PE,fyAriaLabel:()=>$E,fyAxis:()=>ME,fyDomain:()=>mE,fyFontVariant:()=>RE,fyGrid:()=>BE,fyInset:()=>gE,fyInsetBottom:()=>bE,fyInsetTop:()=>xE,fyLabel:()=>CE,fyLabelAnchor:()=>kE,fyLabelOffset:()=>FE,fyLine:()=>LE,fyPadding:()=>_E,fyPaddingInner:()=>SE,fyPaddingOuter:()=>IE,fyRange:()=>yE,fyReverse:()=>UE,fyRound:()=>wE,fyTickFormat:()=>DE,fyTickPadding:()=>NE,fyTickRotate:()=>OE,fyTickSize:()=>TE,fyTickSpacing:()=>EE,fyTicks:()=>AE,grid:()=>g6,height:()=>c6,inset:()=>y6,label:()=>x6,lengthBase:()=>$8,lengthClamp:()=>C8,lengthConstant:()=>U8,lengthDomain:()=>B8,lengthExponent:()=>P8,lengthNice:()=>k8,lengthPercent:()=>F8,lengthRange:()=>L8,lengthScale:()=>O8,lengthZero:()=>R8,margin:()=>i6,marginBottom:()=>h6,marginLeft:()=>l6,marginRight:()=>u6,marginTop:()=>f6,margins:()=>r6,name:()=>e6,opacityBase:()=>m8,opacityClamp:()=>c8,opacityConstant:()=>g8,opacityDomain:()=>s8,opacityExponent:()=>y8,opacityLabel:()=>u8,opacityNice:()=>l8,opacityPercent:()=>f8,opacityRange:()=>a8,opacityReverse:()=>h8,opacityScale:()=>o8,opacityTickFormat:()=>p8,opacityZero:()=>d8,padding:()=>b6,projectionClip:()=>J8,projectionDomain:()=>Y8,projectionInset:()=>X8,projectionInsetBottom:()=>Z8,projectionInsetLeft:()=>G8,projectionInsetRight:()=>W8,projectionInsetTop:()=>H8,projectionParallels:()=>q8,projectionPrecision:()=>j8,projectionRotate:()=>V8,projectionType:()=>z8,rBase:()=>E8,rClamp:()=>I8,rConstant:()=>D8,rDomain:()=>_8,rExponent:()=>N8,rNice:()=>M8,rPercent:()=>A8,rRange:()=>S8,rScale:()=>v8,rZero:()=>T8,style:()=>s6,symbolDomain:()=>b8,symbolRange:()=>w8,symbolScale:()=>x8,width:()=>a6,xAlign:()=>N6,xAriaDescription:()=>W6,xAriaLabel:()=>G6,xAxis:()=>L6,xBase:()=>Q6,xClamp:()=>T6,xConstant:()=>t4,xDomain:()=>v6,xExponent:()=>K6,xFontVariant:()=>X6,xGrid:()=>U6,xInset:()=>I6,xInsetLeft:()=>M6,xInsetRight:()=>A6,xLabel:()=>q6,xLabelAnchor:()=>j6,xLabelArrow:()=>V6,xLabelOffset:()=>Y6,xLine:()=>z6,xNice:()=>S6,xPadding:()=>D6,xPaddingInner:()=>O6,xPaddingOuter:()=>B6,xPercent:()=>H6,xRange:()=>_6,xReverse:()=>Z6,xRound:()=>E6,xScale:()=>w6,xTickFormat:()=>$6,xTickPadding:()=>R6,xTickRotate:()=>P6,xTickSize:()=>k6,xTickSpacing:()=>F6,xTicks:()=>C6,xZero:()=>J6,xyDomain:()=>o6,yAlign:()=>u4,yAriaDescription:()=>N4,yAriaLabel:()=>E4,yAxis:()=>p4,yBase:()=>L4,yClamp:()=>c4,yConstant:()=>k4,yDomain:()=>n4,yExponent:()=>C4,yFontVariant:()=>T4,yGrid:()=>v4,yInset:()=>o4,yInsetBottom:()=>a4,yInsetTop:()=>s4,yLabel:()=>S4,yLabelAnchor:()=>I4,yLabelArrow:()=>M4,yLabelOffset:()=>A4,yLine:()=>_4,yNice:()=>i4,yPadding:()=>f4,yPaddingInner:()=>h4,yPaddingOuter:()=>d4,yPercent:()=>D4,yRange:()=>r4,yReverse:()=>O4,yRound:()=>l4,yScale:()=>e4,yTickFormat:()=>b4,yTickPadding:()=>x4,yTickRotate:()=>w4,yTickSize:()=>y4,yTickSpacing:()=>g4,yTicks:()=>m4,yZero:()=>B4});var ug=class extends Map{request(t,n){if(this.has(t))n(this.get(t));else{let r=this.waiting||(this.waiting=new Map),i=r.get(t)||[];r.set(t,i.concat(n))}}set(t,n){this.has(t)&&console.warn(`Overwriting named plot "${t}".`);let{waiting:r}=this;return r?.has(t)&&(r.get(t).forEach(i=>i(n)),r.delete(t)),super.set(t,n)}clear(){return this.waiting?.clear(),super.clear()}},K3=new ug;function t6(e,t,n){(e?.context?.namedPlots??K3).request(t,n)}function MU(e,t,n){(e?.context?.namedPlots??K3).set(t,n)}function e6(e){return t=>MU(this,e,t)}function AU(e,t,n){wr(n)?(n.addEventListener("value",r=>{e.setAttribute(t,r),e.update()}),n.value!==void 0&&e.setAttribute(t,n.value)):e.setAttribute(t,n)}function ort(e,t){return n=>{AU(n,e,t)}}function n6(e){return t=>{for(let[n,r]of Object.entries(e))AU(t,n,r)}}function r6(e){let{top:t,bottom:n,left:r,right:i}=e,o={};return t!==void 0&&(o.marginTop=t),n!==void 0&&(o.marginBottom=n),r!==void 0&&(o.marginLeft=r),i!==void 0&&(o.marginRight=i),n6(o)}function i6(e){return n6({marginTop:e,marginBottom:e,marginLeft:e,marginRight:e})}function o6(e){return n6({xDomain:e,yDomain:e})}var B=e=>t=>ort(e,t),s6=B("style"),a6=B("width"),c6=B("height"),l6=B("marginLeft"),u6=B("marginRight"),f6=B("marginTop"),h6=B("marginBottom"),d6=B("align"),p6=B("aspectRatio"),m6=B("axis"),y6=B("inset"),g6=B("grid"),x6=B("label"),b6=B("padding"),w6=B("xScale"),v6=B("xDomain"),_6=B("xRange"),S6=B("xNice"),I6=B("xInset"),M6=B("xInsetLeft"),A6=B("xInsetRight"),T6=B("xClamp"),E6=B("xRound"),N6=B("xAlign"),D6=B("xPadding"),O6=B("xPaddingInner"),B6=B("xPaddingOuter"),L6=B("xAxis"),C6=B("xTicks"),k6=B("xTickSize"),F6=B("xTickSpacing"),R6=B("xTickPadding"),$6=B("xTickFormat"),P6=B("xTickRotate"),U6=B("xGrid"),z6=B("xLine"),q6=B("xLabel"),j6=B("xLabelAnchor"),V6=B("xLabelArrow"),Y6=B("xLabelOffset"),X6=B("xFontVariant"),G6=B("xAriaLabel"),W6=B("xAriaDescription"),H6=B("xPercent"),Z6=B("xReverse"),J6=B("xZero"),Q6=B("xBase"),K6=B("xExponent"),t4=B("xConstant"),e4=B("yScale"),n4=B("yDomain"),r4=B("yRange"),i4=B("yNice"),o4=B("yInset"),s4=B("yInsetTop"),a4=B("yInsetBottom"),c4=B("yClamp"),l4=B("yRound"),u4=B("yAlign"),f4=B("yPadding"),h4=B("yPaddingInner"),d4=B("yPaddingOuter"),p4=B("yAxis"),m4=B("yTicks"),y4=B("yTickSize"),g4=B("yTickSpacing"),x4=B("yTickPadding"),b4=B("yTickFormat"),w4=B("yTickRotate"),v4=B("yGrid"),_4=B("yLine"),S4=B("yLabel"),I4=B("yLabelAnchor"),M4=B("yLabelArrow"),A4=B("yLabelOffset"),T4=B("yFontVariant"),E4=B("yAriaLabel"),N4=B("yAriaDescription"),D4=B("yPercent"),O4=B("yReverse"),B4=B("yZero"),L4=B("yBase"),C4=B("yExponent"),k4=B("yConstant"),F4=B("facetMargin"),R4=B("facetMarginTop"),$4=B("facetMarginBottom"),P4=B("facetMarginLeft"),U4=B("facetMarginRight"),z4=B("facetGrid"),q4=B("facetLabel"),j4=B("fxDomain"),V4=B("fxRange"),Y4=B("fxInset"),X4=B("fxInsetLeft"),G4=B("fxInsetRight"),W4=B("fxRound"),H4=B("fxAlign"),Z4=B("fxPadding"),J4=B("fxPaddingInner"),Q4=B("fxPaddingOuter"),K4=B("fxAxis"),tE=B("fxTicks"),eE=B("fxTickSize"),nE=B("fxTickSpacing"),rE=B("fxTickPadding"),iE=B("fxTickFormat"),oE=B("fxTickRotate"),sE=B("fxGrid"),aE=B("fxLine"),cE=B("fxLabel"),lE=B("fxLabelAnchor"),uE=B("fxLabelOffset"),fE=B("fxFontVariant"),hE=B("fxAriaLabel"),dE=B("fxAriaDescription"),pE=B("fxReverse"),mE=B("fyDomain"),yE=B("fyRange"),gE=B("fyInset"),xE=B("fyInsetTop"),bE=B("fyInsetBottom"),wE=B("fyRound"),vE=B("fyAlign"),_E=B("fyPadding"),SE=B("fyPaddingInner"),IE=B("fyPaddingOuter"),ME=B("fyAxis"),AE=B("fyTicks"),TE=B("fyTickSize"),EE=B("fyTickSpacing"),NE=B("fyTickPadding"),DE=B("fyTickFormat"),OE=B("fyTickRotate"),BE=B("fyGrid"),LE=B("fyLine"),CE=B("fyLabel"),kE=B("fyLabelAnchor"),FE=B("fyLabelOffset"),RE=B("fyFontVariant"),$E=B("fyAriaLabel"),PE=B("fyAriaDescription"),UE=B("fyReverse"),zE=B("colorScale"),qE=B("colorDomain"),jE=B("colorRange"),VE=B("colorClamp"),YE=B("colorN"),XE=B("colorNice"),GE=B("colorScheme"),WE=B("colorInterpolate"),HE=B("colorPivot"),ZE=B("colorSymmetric"),JE=B("colorLabel"),QE=B("colorPercent"),KE=B("colorReverse"),t8=B("colorZero"),e8=B("colorTickFormat"),n8=B("colorBase"),r8=B("colorExponent"),i8=B("colorConstant"),o8=B("opacityScale"),s8=B("opacityDomain"),a8=B("opacityRange"),c8=B("opacityClamp"),l8=B("opacityNice"),u8=B("opacityLabel"),f8=B("opacityPercent"),h8=B("opacityReverse"),d8=B("opacityZero"),p8=B("opacityTickFormat"),m8=B("opacityBase"),y8=B("opacityExponent"),g8=B("opacityConstant"),x8=B("symbolScale"),b8=B("symbolDomain"),w8=B("symbolRange"),v8=B("rScale"),_8=B("rDomain"),S8=B("rRange"),I8=B("rClamp"),M8=B("rNice"),A8=B("rPercent"),T8=B("rZero"),E8=B("rBase"),N8=B("rExponent"),D8=B("rConstant"),O8=B("lengthScale"),B8=B("lengthDomain"),L8=B("lengthRange"),C8=B("lengthClamp"),k8=B("lengthNice"),F8=B("lengthPercent"),R8=B("lengthZero"),$8=B("lengthBase"),P8=B("lengthExponent"),U8=B("lengthConstant"),z8=B("projectionType"),q8=B("projectionParallels"),j8=B("projectionPrecision"),V8=B("projectionRotate"),Y8=B("projectionDomain"),X8=B("projectionInset"),G8=B("projectionInsetLeft"),W8=B("projectionInsetRight"),H8=B("projectionInsetTop"),Z8=B("projectionInsetBottom"),J8=B("projectionClip");function TU(e,t){return{table:e,options:t}}var Yv={};Mr(Yv,{area:()=>K8,areaX:()=>tN,areaY:()=>eN,arrow:()=>XN,axisFx:()=>JN,axisFy:()=>QN,axisX:()=>HN,axisY:()=>ZN,barX:()=>oN,barY:()=>sN,cell:()=>aN,cellX:()=>cN,cellY:()=>lN,circle:()=>yN,contour:()=>CN,delaunayLink:()=>jN,delaunayMesh:()=>VN,denseLine:()=>LN,density:()=>BN,densityX:()=>DN,densityY:()=>ON,dot:()=>dN,dotX:()=>pN,dotY:()=>mN,frame:()=>WN,geo:()=>rD,graticule:()=>oD,gridFx:()=>eD,gridFy:()=>nD,gridX:()=>KN,gridY:()=>tD,heatmap:()=>kN,hexagon:()=>gN,hexbin:()=>$N,hexgrid:()=>PN,hull:()=>YN,image:()=>NN,line:()=>nN,lineX:()=>rN,lineY:()=>iN,link:()=>GN,raster:()=>FN,rasterTile:()=>RN,rect:()=>uN,rectX:()=>fN,rectY:()=>hN,regressionY:()=>UN,ruleX:()=>vN,ruleY:()=>_N,sphere:()=>iD,spike:()=>EN,text:()=>xN,textX:()=>bN,textY:()=>wN,tickX:()=>SN,tickY:()=>IN,vector:()=>MN,vectorX:()=>AN,vectorY:()=>TN,voronoi:()=>zN,voronoiMesh:()=>qN});var srt=new Set(["frame","axisX","axisY","axisFx","axisFy","gridX","gridY","gridFx","gridFy","hexgrid","graticule","sphere"]);function At(e,t,n={}){arguments.length===2&&!Array.isArray(t)&&(n=t,t=srt.has(e)?null:[{}]);let r=e.startsWith("area")||e.startsWith("line")?jy:Ln;return Q8(r,e,t,n)}function Q8(e,t,n,r){return i=>{i.addMark(new e(t,n,r))}}function la(e,t,n){return r=>{r.addMark(new e(t,n))}}var K8=(...e)=>At("area",...e),tN=(...e)=>At("areaX",...e),eN=(...e)=>At("areaY",...e),nN=(...e)=>At("line",...e),rN=(...e)=>At("lineX",...e),iN=(...e)=>At("lineY",...e),oN=(...e)=>At("barX",...e),sN=(...e)=>At("barY",...e),aN=(...e)=>At("cell",...e),cN=(...e)=>At("cellX",...e),lN=(...e)=>At("cellY",...e),uN=(...e)=>At("rect",...e),fN=(...e)=>At("rectX",...e),hN=(...e)=>At("rectY",...e),dN=(...e)=>At("dot",...e),pN=(...e)=>At("dotX",...e),mN=(...e)=>At("dotY",...e),yN=(...e)=>At("circle",...e),gN=(...e)=>At("hexagon",...e),xN=(...e)=>At("text",...e),bN=(...e)=>At("textX",...e),wN=(...e)=>At("textY",...e),vN=(...e)=>At("ruleX",...e),_N=(...e)=>At("ruleY",...e),SN=(...e)=>At("tickX",...e),IN=(...e)=>At("tickY",...e),MN=(...e)=>At("vector",...e),AN=(...e)=>At("vectoX",...e),TN=(...e)=>At("vectorY",...e),EN=(...e)=>At("spike",...e),NN=(...e)=>At("image",...e),DN=(...e)=>Q8(gh,"areaX",...e),ON=(...e)=>Q8(gh,"areaY",...e),BN=(...e)=>la(Hy,...e),LN=(...e)=>la(Wy,...e),CN=(...e)=>la(Xy,...e),kN=(...e)=>la(Gy,...e),FN=(...e)=>la(yc,...e),RN=(...e)=>la(Qy,...e),$N=(...e)=>la(Jy,...e),PN=(...e)=>At("hexgrid",...e),UN=(...e)=>la(Ky,...e),zN=(...e)=>At("voronoi",...e),qN=(...e)=>At("voronoiMesh",...e),jN=(...e)=>At("delaunayLink",...e),VN=(...e)=>At("delaunayMesh",...e),YN=(...e)=>At("hull",...e),XN=(...e)=>At("arrow",...e),GN=(...e)=>At("link",...e),WN=(...e)=>At("frame",...e),HN=(...e)=>At("axisX",...e),ZN=(...e)=>At("axisY",...e),JN=(...e)=>At("axisFx",...e),QN=(...e)=>At("axisFy",...e),KN=(...e)=>At("gridX",...e),tD=(...e)=>At("gridY",...e),eD=(...e)=>At("gridFx",...e),nD=(...e)=>At("gridFy",...e),rD=(...e)=>la(Zy,...e),iD=(...e)=>At("sphere",...e),oD=(...e)=>At("graticule",...e);var Xv={};Mr(Xv,{highlight:()=>sD,intervalX:()=>hD,intervalXY:()=>pD,intervalY:()=>dD,nearestX:()=>uD,nearestY:()=>fD,pan:()=>mD,panX:()=>yD,panY:()=>gD,panZoom:()=>xD,panZoomX:()=>bD,panZoomY:()=>wD,toggle:()=>_h,toggleColor:()=>lD,toggleX:()=>aD,toggleY:()=>cD});function xc(e,t){return n=>{let r=n.marks[n.marks.length-1];n.addInteractor(new e(r,t))}}function sD({by:e,...t}){return xc(tg,{selection:e,channels:t})}function _h({as:e,...t}){return xc(Yl,{...t,selection:e})}function aD(e){return _h({...e,channels:["x"]})}function cD(e){return _h({...e,channels:["y"]})}function lD(e){return _h({...e,channels:["color"]})}function uD({as:e,...t}){return xc(wh,{...t,selection:e,channel:"x"})}function fD({as:e,...t}){return xc(wh,{...t,selection:e,channel:"y"})}function hD({as:e,...t}){return xc(gc,{...t,selection:e,channel:"x"})}function dD({as:e,...t}){return xc(gc,{...t,selection:e,channel:"y"})}function pD({as:e,...t}){return xc(rg,{...t,selection:e})}function Sh(e){return xc(ig,e)}function mD(e={}){return Sh({...e,zoom:!1})}function yD(e={}){return Sh({...e,zoom:!1,pany:!1})}function gD(e={}){return Sh({...e,zoom:!1,panx:!1})}function xD(e={}){return Sh(e)}function bD(e={}){return Sh({...e,pany:!1})}function wD(e={}){return Sh({...e,panx:!1})}var Gv={};Mr(Gv,{colorLegend:()=>_D,opacityLegend:()=>SD,symbolLegend:()=>ID});function vD(e,t={}){if(t.for){let{for:n,...r}=t,i=new vh(e,r),o=typeof n,s=a=>a.addLegend(i,!1);return o==="string"?t6(this,n,s):n.value&&s(n.value),i.element}else return n=>n.addLegend(new vh(e,t))}function _D(e){return vD.call(this,"color",e)}function SD(e){return vD.call(this,"opacity",e)}function ID(e){return vD.call(this,"symbol",e)}function EU(...e){let t=new qy;return e.flat().forEach(n=>n(t)),lg(this,...t.marks),t.update(),t.element}function AD({coordinator:e=ai(),namedPlots:t=new ug,extensions:n=null,...r}={}){return{...MD,...n,context:{coordinator:e,namedPlots:t,...r}}}var NU="spec",Wv="literal",lYt="dataref",DU="options",OU="selection",BU="paramref",LU="param",TD="select",Hv="value",CU="crossfilter",Zv="intersect",kU="union",FU="single",RU="data",$U="expression",bc="sql",ua="agg",fg="input",Ih="hconcat",Mh="vconcat",Ah="hspace",Th="vspace",Jv="mark",ED="from",Eh="plot",hg="legend",PU="attribute",UU="transform",zU="interactor",dg="Fixed";var $t=class{constructor(t,n=null){this.type=t,this.children=n}instantiate(t){throw Error("instantiate not implemented")}codegen(t){return Error("codegen not implemented")}toJSON(){return Error("toJSON not implemented")}};var pg=class extends $t{constructor(t,n,r,i,o,s){super(NU,[t]),this.root=t,this.meta=n,this.config=r,this.data=i,this.params=o,this.plotDefaults=s}toJSON(){let{root:t,meta:n,config:r,plotDefaults:i}=this,o=new Map(Object.entries(this.data)),s=new Map(Object.entries(this.params)),a={};if(n&&(a.meta={...n}),r&&(a.config={...r}),o?.size){let c=a.data={};for(let[l,u]of o)c[l]=u.toJSON()}if(s?.size){let c=a.params={};for(let[l,u]of s)c[l]=u.toJSON()}if(i?.length){let c=a.plotDefaults={};for(let l of i)Object.assign(c,l.toJSON())}return Object.assign(a,t.toJSON())}};function qU(e){let t=typeof e;return t==="object"?e?.param:t==="string"?art(e):null}function art(e){return e?.[0]==="$"?e.slice(1):null}function mg(e){return`$${e}`}function Qv(e){return[e].flat()}function Si(e){return Array.isArray(e)}function Nh(e){return e!==null&&typeof e=="object"&&!Si(e)}function wc(e){return typeof e=="string"}function Dh(e,t){throw Object.assign(Error(e),{data:t})}var crt=/^(?:[-+]\d{2})?\d{4}(?:-\d{2}(?:-\d{2})?)?(?:T\d{2}:\d{2}(?::\d{2}(?:\.\d{3})?)?(?:Z|[-+]\d{2}:?\d{2})?)?$/;function jU(e,t){return crt.test(e+="")?new Date(e):t}function Sr(e,t){let n={};for(let r in e)n[r]=t.maybeSelection(e[r]);return new Oh(n)}var Oh=class e extends $t{constructor(t){super(DU),this.options=t}filter(t){let n=Object.fromEntries(Object.entries(this.options).filter(([r,i])=>t(r,i)));return new e(n)}instantiate(t){let{options:n}=this,r={};for(let i in n)r[i]=n[i].instantiate(t);return r}codegen(t){let{options:n}=this,r=[];for(let i in n)r.push(`${i}: ${n[i].codegen(t)}`);return r.length?`{${t.maybeLineWrap(r)}}`:""}toJSON(){let{options:t}=this,n={};for(let r in t)n[r]=t[r].toJSON();return n}};var XU="table",GU="parquet",WU="csv",ND="json",s_="spatial",VU=new Map([[XU,hrt],[GU,drt],[WU,prt],[ND,mrt],[s_,yrt]]);function HU(e,t,n){let r=lrt(t);if(VU.has(r.type))return VU.get(r.type)(e,r,n);n.error("Unrecognized data format type.",t)}function lrt(e){return Si(e)&&(e={type:"json",data:e}),wc(e)&&(e={type:"table",query:e}),{...e,type:urt(e)}}function urt(e){return e.type||frt(e.file)||"table"}function frt(e){let t=e?.lastIndexOf(".");return t>0?e.slice(t+1):null}function hrt(e,t,n){let{query:r,type:i,...o}=t;return new t_(e,r,Sr(o,n))}function drt(e,t,n){let{file:r,type:i,...o}=t;return new n_(e,r,Sr(o,n))}function prt(e,t,n){let{file:r,type:i,...o}=t;return new r_(e,r,Sr(o,n))}function mrt(e,t,n){let{data:r,file:i,type:o,...s}=t,a=Sr(s,n);return r?new o_(e,r,a):new i_(e,i,a)}function yrt(e,t,n){let{file:r,type:i,...o}=t;return new e_(e,r,Sr(o,n))}function YU(e,t){return t?new URL(e,t).toString():e}function grt(e,t){let n=e?.codegen(t);return n?`, ${n}`:""}var Kv=class extends $t{constructor(t,n){super(RU),this.name=t,this.format=n}},Bh=class extends Kv{constructor(t,n){super(t,n)}instantiateQuery(t){t.error("instantiateQuery not implemented")}codegenQuery(t){t.error("codegenQuery not implemented")}instantiate(t){let n=this.instantiateQuery(t);if(n)return n}codegen(t){let n=this.codegenQuery(t);if(n)return n}},t_=class extends Bh{constructor(t,n,r){super(t,XU),this.query=n?.trim(),this.options=r}instantiateQuery(t){let{name:n,query:r,options:i}=this;if(r)return t.api.create(n,r,i.instantiate(t))}codegenQuery(t){let{name:n,query:r,options:i}=this;if(r)return`\`${bo(n,r,i.instantiate(t))}\``}toJSON(){let{format:t,query:n,options:r}=this;return{type:t,query:n,...r.toJSON()}}},Xl=class extends Bh{constructor(t,n,r,i,o){super(t,n),this.file=i,this.method=r,this.options=o}instantiateQuery(t){let{name:n,method:r,file:i,options:o}=this,s=YU(i,t.baseURL),a=o?.instantiate(t);return t.api[r](n,s,a)}codegenQuery(t){let{name:n,method:r,file:i,options:o}=this,s=YU(i,t.baseURL),a=grt(o,t);return`${t.ns()}${r}("${n}", "${s}"${a})`}toJSON(){let{format:t,file:n,options:r}=this;return{type:t,file:n,...r.toJSON()}}},e_=class extends Xl{constructor(t,n,r){super(t,s_,"loadSpatial",n,r)}},n_=class extends Xl{constructor(t,n,r){super(t,GU,"loadParquet",n,r)}},r_=class extends Xl{constructor(t,n,r){super(t,WU,"loadCSV",n,r)}},i_=class extends Xl{constructor(t,n,r){super(t,ND,"loadJSON",n,r)}},o_=class extends Bh{constructor(t,n,r){super(t,ND),this.data=n,this.options=r}instantiateQuery(t){let{name:n,data:r,options:i}=this;return t.api.loadObjects(n,r,i.instantiate(t))}codegenQuery(t){let{name:n,data:r,options:i}=this,o=i?","+i.codegen(t):"",s=`[
|
|
70
70
|
`+r.map(a=>JSON.stringify(a)).join(`,
|
|
71
71
|
`)+`
|
|
72
|
-
]`;return`${t.ns()}loadObjects("${n}", ${s}${o})`}toJSON(){let{format:t,data:n,options:r}=this;return{type:t,data:n,...r.toJSON()}}};function
|
|
73
|
-
`)),
|
|
74
|
-
`),"];"]);let
|
|
75
|
-
`)}var
|
|
72
|
+
]`;return`${t.ns()}loadObjects("${n}", ${s}${o})`}toJSON(){let{format:t,data:n,options:r}=this;return{type:t,data:n,...r.toJSON()}}};function a_(e){let t=e.config?.extensions,n=new Set(t?Qv(t):[]);for(let r of Object.values(e.data))r.format===s_&&n.add("spatial");return n}async function xrt(e,t){let{data:n,params:r,plotDefaults:i}=e,o=new c_({plotDefaults:i,...t}),s=[],a=a_(e);s.push(...Array.from(a).map(c=>ep(c)));for(let c of Object.values(n)){let l=c.instantiate(o);l&&s.push(l)}s.length>0&&await o.coordinator.exec(s);for(let[c,l]of Object.entries(r))if(!o.activeParams.has(c)){let u=l.instantiate(o);o.activeParams.set(c,u)}return{element:e.root.instantiate(o),params:o.activeParams}}var c_=class{constructor({api:t=AD(),plotDefaults:n=[],params:r=new Map,baseURL:i=null}={}){this.api=t,this.plotDefaults=n,this.activeParams=r,this.baseURL=i,this.coordinator=t.context.coordinator}error(t,n){Dh(t,n)}};function brt(e,t={}){let{root:n,data:r,params:i,plotDefaults:o}=e,{preamble:s,...a}=t,c=new l_({plotDefaults:o,...a}),l=[];for(let[x,b]of c.imports)l.push(wc(b)?`import ${b} from "${x}";`:`import { ${b.join(", ")} } from "${x}";`);let u=s?Qv(s).map(x=>`${c.tab()}${x}`):[],f=[];if(c.connector){let x=`${c.ns()}${c.connector}Connector()`;f.push(`${c.tab()}${c.ns()}coordinator().databaseConnector(${x});`)}let h=[];for(let x of a_(e))h.push(`${c.ns()}loadExtension("${x}")`);for(let x of Object.values(r)){let b=x.codegen(c);b&&h.push(b)}let d=[];h.length&&(d.push(`${c.tab()}await ${c.ns()}coordinator().exec([`),c.indent(),d.push(h.map(x=>`${c.tab()}${x}`).join(`,
|
|
73
|
+
`)),c.undent(),d.push(`${c.tab()}]);`));let p=[];for(let[x,b]of Object.entries(i))p.push(`const ${mg(x)} = ${b.codegen(c)};`);let m=[],y=o;y.length&&(m=["const defaultAttributes = [",y.map(x=>" "+x.codegen(c)).join(`,
|
|
74
|
+
`),"];"]);let g=[`export default ${n.codegen(c)};`];return[...l,...Lh(l),...u,...Lh(u),...f,...Lh(f),...d,...Lh(d),...p,...Lh(p),...m,...Lh(m),...g].join(`
|
|
75
|
+
`)}var l_=class{constructor({plotDefaults:t=void 0,namespace:n="vg",connector:r=void 0,imports:i=new Map([["@uwdata/vgplot","* as vg"]]),baseURL:o=void 0,depth:s=0}={}){this.plotDefaults=t,this.namespace=`${n}.`,this.connector=r,this.imports=i,this.baseURL=o,this.depth=s}addImport(t,n){this.imports.has(t)?this.imports.get(t).push(n):this.imports.set(t,[n])}setImports(t,n){this.imports.set(t,n)}ns(){return this.namespace}indent(){this.depth+=1}undent(){this.depth-=1}tab(){return Array.from({length:this.depth},()=>" ").join("")}stringify(t){if(Si(t)){let n=t.map(r=>this.stringify(r));return`[${this.maybeLineWrap(n)}]`}else if(Nh(t)){let n=Object.entries(t).map(([r,i])=>`${wrt(r)}: ${this.stringify(i)}`);return`{${this.maybeLineWrap(n)}}`}else return JSON.stringify(t)}maybeLineWrap(t){let n=80-2*this.depth;if(2*t.length+t.reduce((i,o)=>i+o.length,0)>n){this.indent();let i=t.map(o=>`
|
|
76
76
|
${this.tab()}${o}`).join(",");return this.undent(),i+`
|
|
77
|
-
`+this.tab()}else return t.join(", ")}error(t,n){
|
|
77
|
+
`+this.tab()}else return t.join(", ")}error(t,n){Dh(t,n)}};function wrt(e){return/^[A-Za-z_$]\w*/.test(e)?e:JSON.stringify(e)}function Lh(e){return e?.length?[""]:[]}var Gl=class extends $t{constructor(t){super(Wv),this.value=t}instantiate(){return this.value}codegen(t){return t.stringify(this.value)}toJSON(){return this.value}};var Wl=class extends $t{constructor(t=Zv,n){super(OU),this.select=t,this.cross=n}instantiate(t){let{select:n,cross:r}=this;return t.api.Selection[n]({cross:r})}codegen(t){let{select:n,cross:r}=this,i=r!=null?`{ cross: ${r} }`:"";return`${t.ns()}Selection.${n}(${i})`}toJSON(){let{select:t,cross:n}=this;return{select:t,cross:n}}};var vrt=new Set([Hv,FU,CU,Zv,kU]);function ZU(e,t){let n=Nh(e)?e:{value:e},{select:r=Hv,cross:i,date:o,value:s}=n;return vrt.has(r)||t.error(`Unrecognized param type: ${r}`,n),r!==Hv?new Wl(r,i):Si(s)?new Hl(s.map(a=>t.maybeParam(a))):new Hl(s,o)}var Hl=class extends $t{constructor(t,n){super(LU),this.value=t,this.date=n}instantiate(t){let{date:n,value:r}=this,{Param:i}=t.api;return Si(r)?i.array(r.map(o=>o.instantiate(t))):i.value(jU(n,r))}codegen(t){let{value:n,date:r}=this,i=`${t.ns()}Param.`;return Si(n)?`${i}array([${n.map(o=>o.codegen(t)).join(", ")}])`:r?`${i}value(new Date(${JSON.stringify(r)}))`:`${i}value(${JSON.stringify(n)})`}toJSON(){let{date:t,value:n}=this;return Si(n)?n.map(r=>r.toJSON()):t?{date:t}:n}};var yg=class extends $t{constructor(t){super(BU),this.name=t}instantiate(t){return t.activeParams?.get(this.name)}codegen(){return mg(this.name)}toJSON(){return mg(this.name)}};function h_(e,t,n){return n.plot?.attributes?.has(e)||n.error(`Unrecognized attribute: ${e}`),new u_(e,t===dg?new f_:n.maybeParam(t))}var u_=class extends $t{constructor(t,n){super(PU),this.name=t,this.value=n}instantiate(t){let{name:n,value:r}=this;return t.api[n](r.instantiate(t))}codegen(t){let{name:n,value:r}=this;return`${t.tab()}${t.ns()}${n}(${r.codegen(t)})`}toJSON(){let{name:t,value:n}=this;return{[t]:n.toJSON()}}},f_=class extends $t{constructor(){super(Wv),this.value=dg}instantiate(t){return t.api[dg]}codegen(t){return`${t.ns()}${dg}`}toJSON(){return this.value}};function JU(e,t){let n=e[Ih].map(r=>t.parseComponent(r));return new d_(n)}var d_=class extends $t{constructor(t){super(Ih,t)}instantiate(t){return t.api[Ih](this.children.map(n=>n.instantiate(t)))}codegen(t){t.indent();let n=this.children.map(r=>r.codegen(t));return t.undent(),`${t.tab()}${t.ns()}${this.type}(
|
|
78
78
|
${n.join(`,
|
|
79
79
|
`)}
|
|
80
|
-
${t.tab()})`}toJSON(){return{[this.type]:this.children.map(t=>t.toJSON())}}};function
|
|
80
|
+
${t.tab()})`}toJSON(){return{[this.type]:this.children.map(t=>t.toJSON())}}};function QU(e){return new p_(e[Ah])}var p_=class extends $t{constructor(t){super(Ah),this.value=t}instantiate(t){return t.api[Ah](this.value)}codegen(t){return`${t.tab()}${t.ns()}${this.type}(${t.stringify(this.value)})`}toJSON(){return{[this.type]:this.value}}};function KU(e,t){let{[fg]:n,...r}=e;return t.inputs?.has(n)||t.error(`Unrecognized input type: ${n}`,e),new m_(n,Sr(r,t))}var m_=class extends $t{constructor(t,n){super(fg),this.name=t,this.options=n}instantiate(t){return t.api[this.name](this.options.instantiate(t))}codegen(t){let n=this.options.codegen(t);return`${t.tab()}${t.ns()}${this.name}(${n})`}toJSON(){let{type:t,name:n,options:r}=this;return{[t]:n,...r.toJSON()}}};function g_(e,t){let{[hg]:n,...r}=e,i=`${n}Legend`;return t.plot?.legends?.has(i)||t.error(`Unrecognized legend type: ${n}`,e),new y_(i,n,Sr(r,t))}var y_=class extends $t{constructor(t,n,r){super(hg),this.key=t,this.name=n,this.options=r}instantiate(t){return t.api[this.key](this.options.instantiate(t))}codegen(t){let n=this.options.codegen(t);return`${t.tab()}${t.ns()}${this.key}(${n})`}toJSON(){let{type:t,name:n,options:r}=this;return{[t]:n,...r.toJSON()}}};function tz(e,t){let{[TD]:n,...r}=e;return t.plot?.interactors?.has(n)||t.error(`Unrecognized interactor type: ${n}`,e),new x_(n,Sr(r,t))}var x_=class extends $t{constructor(t,n){super(zU),this.name=t,this.options=n}instantiate(t){return t.api[this.name](this.options.instantiate(t))}codegen(t){let n=this.options.codegen(t);return`${t.tab()}${t.ns()}${this.name}(${n})`}toJSON(){let{name:t,options:n}=this;return{[TD]:t,...n.toJSON()}}};function ez(e,t){let{label:n}=e,r=e[bc]?bc:e[ua]?ua:t.error("Unrecognized expression type",e),i=e[r],o=i.split(/(\\'|\\"|"(?:\\"|[^"])*"|'(?:\\'|[^'])*'|\$\w+)/g),s=[""],a=[];for(let c=0,l=0;c<o.length;++c){let u=o[c];u.startsWith("$")?(a[l]=t.maybeParam(u),s[++l]=""):s[l]+=u}return new b_(i,s,a,n,r===ua)}var b_=class extends $t{constructor(t,n,r,i,o){super($U),this.value=t,this.spans=n,this.params=r,this.label=i,this.aggregate=o}instantiate(t){let{spans:n,params:r,label:i,aggregate:o}=this,s=t.api[o?ua:bc],a=r.map(c=>c.instantiate(t));return s(n,...a).annotate({label:i})}codegen(t){let{spans:n,params:r,label:i,aggregate:o}=this,s=o?ua:bc,a="",c=r.length;for(let l=0;l<c;++l)a+=n[l]+"${"+r[l].codegen(t)+"}";return a+=n[c],`${t.ns()}${s}\`${a}\``+(i?`.annotate({ label: ${JSON.stringify(i)} })`:"")}toJSON(){return{[this.aggregate?ua:bc]:this.value}}};function nz(e,t){if(!e)return null;if(Si(e))return new Gl(e);let{from:n,...r}=e;return new w_(n,Sr(r,t))}var w_=class extends $t{constructor(t,n){super(ED),this.table=t,this.options=n}instantiate(t){let{table:n,options:r}=this;return t.api[ED](n,r.instantiate(t))}codegen(t){let{type:n,table:r,options:i}=this,o=i.codegen(t);return`${t.ns()}${n}("${r}"${o?", "+o:""})`}toJSON(){let{type:t,table:n,options:r}=this;return{[t]:n,...r.toJSON()}}};function DD(e){return e==null?[]:[e].flat()}function rz(e,t){let n;for(let o in e)t.transforms.has(o)&&(n=o);if(!n)return;let r=n==="count"||n==null?[]:DD(e[n]),i={distinct:e.distinct,orderby:DD(e.orderby).map(o=>t.maybeParam(o)),partitionby:DD(e.partitionby).map(o=>t.maybeParam(o)),rows:e.rows?t.maybeParam(e.rows):null,range:e.range?t.maybeParam(e.range):null};return new v_(n,r,i)}var v_=class extends $t{constructor(t,n,r){super(UU),this.name=t,this.args=n,this.options=r}instantiate(t){let{name:n,args:r,options:i}=this,{distinct:o,orderby:s,partitionby:a,rows:c,range:l}=i,u=t.api[n](...r);return o&&(u=u.distinct()),s.length&&(u=u.orderby(s.map(f=>f.instantiate(t)))),a.length&&(u=u.partitionby(a.map(f=>f.instantiate(t)))),c!=null?u=u.rows(c.instantiate(t)):l!=null&&(u=u.range(l.instantiate(t))),u}codegen(t){let{name:n,args:r,options:i}=this,{distinct:o,orderby:s,partitionby:a,rows:c,range:l}=i,u=`${t.ns()}${n}(`+r.map(f=>JSON.stringify(f)).join(", ")+")";if(o&&(u+=".distinct()"),s.length){let f=s.map(h=>h.codegen(t));u+=`.orderby(${f.join(", ")})`}if(a.length){let f=a.map(h=>h.codegen(t));u+=`.partitionby(${f.join(", ")})`}return c?u+=`.rows(${c.codegen(t)})`:l&&(u+=`.range(${l.codegen(t)})`),u}toJSON(){let{name:t,args:n,options:r}=this,{distinct:i,orderby:o,partitionby:s,rows:a,range:c}=r,l={[t]:OD(n)};return i&&(l.distinct=!0),o.length&&(l.orderby=OD(o.map(u=>u.toJSON()))),s.length&&(l.partitionby=OD(s.map(u=>u.toJSON()))),a?l.rows=a.toJSON():c&&(l.range=c.toJSON()),l}};function OD(e){return e.length===0?"":e.length===1?e[0]:e}function _rt(e,t){if(Nh(e))return e[bc]||e[ua]?ez(e,t):rz(e,t)}function iz(e,t){let{mark:n,data:r,...i}=e;t.plot?.marks?.has(n)||t.error(`Unrecognized mark type: ${n}`,e);let o=nz(r,t),s={};for(let a in i){let c=i[a];s[a]=_rt(c,t)||t.maybeParam(c)}return new __(n,o,new Oh(s))}var __=class extends $t{constructor(t,n,r){super(Jv),this.name=t,this.data=n,this.options=r}instantiate(t){let{name:n,data:r,options:i}=this,o=i.instantiate(t);return r?t.api[n](r.instantiate(t),o):t.api[n](o)}codegen(t){let{name:n,data:r,options:i}=this,o=r?r.codegen(t):"",s=i.codegen(t),a;if(o&&s){t.indent();let c=i.codegen(t);a=`
|
|
81
81
|
${t.tab()}${o},
|
|
82
82
|
${t.tab()}${c}
|
|
83
|
-
`,t.undent(),a+=t.tab()}else a=`${o}${s}`;return`${t.tab()}${t.ns()}${n}(${a})`}toJSON(){let{type:t,name:n,data:r,options:i}=this;return{[t]:n,...r?{data:r.toJSON()}:{},...i.toJSON()}}};function
|
|
83
|
+
`,t.undent(),a+=t.tab()}else a=`${o}${s}`;return`${t.tab()}${t.ns()}${n}(${a})`}toJSON(){let{type:t,name:n,data:r,options:i}=this;return{[t]:n,...r?{data:r.toJSON()}:{},...i.toJSON()}}};function oz(e,t){return BD({plot:[e]},t)}function BD(e,t){let{[Eh]:n,...r}=e,i=Object.entries(r).map(([s,a])=>h_(s,a,t)),o=n.map(s=>wc(s.mark)?iz(s,t):wc(s.legend)?g_(s,t):wc(s.select)?tz(s,t):t.error("Invalid plot entry.",s));return new S_(o,i)}var S_=class extends $t{constructor(t,n){super(Eh,t),this.attributes=n}instantiate(t){let n=[...t.plotDefaults||[],...this.attributes||[]];return t.api[Eh](this.children.map(r=>r.instantiate(t)),n.map(r=>r.instantiate(t)))}codegen(t){let{type:n,children:r,attributes:i}=this;t.indent();let o=[...r.map(s=>s.codegen(t)),...t.plotDefaults?.length?[`${t.tab()}...defaultAttributes`]:[],...i.map(s=>s.codegen(t))].join(`,
|
|
84
84
|
`);return t.undent(),`${t.tab()}${t.ns()}${n}(
|
|
85
85
|
${o}
|
|
86
|
-
${t.tab()})`}toJSON(){let{type:t,children:n,attributes:r}=this,i={[t]:n.map(o=>o.toJSON())};for(let o of r)Object.assign(i,o.toJSON());return i}};function
|
|
86
|
+
${t.tab()})`}toJSON(){let{type:t,children:n,attributes:r}=this,i={[t]:n.map(o=>o.toJSON())};for(let o of r)Object.assign(i,o.toJSON());return i}};function sz(e,t){let n=e[Mh].map(r=>t.parseComponent(r));return new I_(n)}var I_=class extends $t{constructor(t){super(Mh,t)}instantiate(t){return t.api[Mh](this.children.map(n=>n.instantiate(t)))}codegen(t){t.indent();let n=this.children.map(r=>r.codegen(t));return t.undent(),`${t.tab()}${t.ns()}${this.type}(
|
|
87
87
|
${n.join(`,
|
|
88
88
|
`)}
|
|
89
|
-
${t.tab()})`}toJSON(){return{[this.type]:this.children.map(t=>t.toJSON())}}};function
|
|
89
|
+
${t.tab()})`}toJSON(){return{[this.type]:this.children.map(t=>t.toJSON())}}};function az(e){return new M_(e[Th])}var M_=class extends $t{constructor(t){super(Th),this.value=t}instantiate(t){return t.api[Th](this.value)}codegen(t){return`${t.tab()}${t.ns()}${this.type}(${t.stringify(this.value)})`}toJSON(){return{[this.type]:this.value}}};function cz(e=[]){return new Map([[Eh,BD],[Jv,oz],[hg,g_],[fg,KU],[Ih,JU],[Mh,sz],[Ah,QU],[Th,az],...e])}function lz(e=[]){return new Set(["menu","search","slider","table",...e])}function uz({attributes:e=Srt(),interactors:t=Irt(),legends:n=Mrt(),marks:r=Art()}={}){return{attributes:e,interactors:t,legends:n,marks:r}}function Srt(e=[]){return new Set([...Object.keys(Vv),...e])}function Irt(e=[]){return new Set([...Object.keys(Xv),...e])}function Mrt(e=[]){return new Set([...Object.keys(Gv),...e])}function Art(e=[]){return new Set([...Object.keys(Yv),...e])}function fz(e=[]){return new Set(["argmin","argmax","avg","bin","centroid","centroidX","centroidY","count","dateMonth","dateMonthDay","dateDay","first","geojson","last","max","median","min","mode","product","quantile","sum","row_number","rank","dense_rank","percent_rank","cume_dist","ntile","lag","lead","first_value","last_value","nth_value",...e])}function Trt(e,t){return new LD(t).parse(e)}var LD=class{constructor({components:t=cz(),transforms:n=fz(),inputs:r=lz(),plot:i=uz(),params:o=[],datasets:s=[]}={}){this.components=t,this.transforms=n,this.inputs=r,this.plot=i,this.params=new Map(o),this.datasets=new Map(s)}parse(t){let{meta:n,config:r,data:i={},params:o,plotDefaults:s={},...a}=t;for(let c in i)this.datasets.set(c,HU(c,i[c],this));this.plotDefaults=Object.entries(s).map(([c,l])=>h_(c,l,this));for(let c in o)this.params.set(c,ZU(o[c],this));return new pg(this.parseComponent(a),n?{...n}:void 0,r?{...r}:void 0,Object.fromEntries(this.datasets),Object.fromEntries(this.params),this.plotDefaults)}parseComponent(t){for(let[n,r]of this.components)if(t[n]!=null)return r(t,this);this.error("Invalid specification.",t)}maybeParam(t,n=()=>new Hl){let{params:r}=this,i=qU(t);if(i){if(!r.has(i)){let o=n();r.set(i,o)}return new yg(i)}return new Gl(t)}maybeSelection(t){return this.maybeParam(t,()=>new Wl)}error(t,n){Dh(t,n)}};export{ua as AGG,$t as ASTNode,PU as ATTRIBUTE,CU as CROSSFILTER,r_ as CSVDataNode,l_ as CodegenContext,RU as DATA,lYt as DATAREF,Kv as DataNode,$U as EXPRESSION,b_ as ExpressionNode,dg as FIXED,ED as FROM,Xl as FileDataNode,Ih as HCONCAT,d_ as HConcatNode,Ah as HSPACE,p_ as HSpaceNode,fg as INPUT,zU as INTERACTOR,Zv as INTERSECT,m_ as InputNode,c_ as InstantiateContext,i_ as JSONDataNode,hg as LEGEND,Wv as LITERAL,o_ as LiteralJSONDataNode,Gl as LiteralNode,Jv as MARK,DU as OPTIONS,Oh as OptionsNode,LU as PARAM,BU as PARAMREF,Eh as PLOT,Hl as ParamNode,yg as ParamRefNode,n_ as ParquetDataNode,u_ as PlotAttributeNode,f_ as PlotFixedNode,w_ as PlotFromNode,x_ as PlotInteractorNode,y_ as PlotLegendNode,__ as PlotMarkNode,S_ as PlotNode,Bh as QueryDataNode,TD as SELECT,OU as SELECTION,FU as SINGLE,NU as SPEC,bc as SQL,Wl as SelectionNode,e_ as SpatialDataNode,pg as SpecNode,UU as TRANSFORM,t_ as TableDataNode,v_ as TransformNode,kU as UNION,Hv as VALUE,Mh as VCONCAT,I_ as VConcatNode,Th as VSPACE,M_ as VSpaceNode,xrt as astToDOM,brt as astToESM,Trt as parseSpec};
|