numpy-ts 0.7.0 → 0.9.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.
@@ -1,3 +1,4 @@
1
- var Gr=Object.defineProperty;var Io=Object.getOwnPropertyDescriptor;var zo=Object.getOwnPropertyNames;var _o=Object.prototype.hasOwnProperty;var M=(r,t)=>()=>(r&&(t=r(r=0)),t);var kt=(r,t)=>{for(var e in t)Gr(r,e,{get:t[e],enumerable:!0})},Bo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of zo(t))!_o.call(r,o)&&o!==e&&Gr(r,o,{get:()=>t[o],enumerable:!(n=Io(t,o))||n.enumerable});return r};var Vt=r=>Bo(Gr({},"__esModule",{value:!0}),r);function Pt(r){if(!r.includes(":")){if(r.includes("."))throw new Error(`Invalid slice index: "${r}" (must be integer)`);let a=parseInt(r,10);if(isNaN(a))throw new Error(`Invalid slice index: "${r}"`);return{start:a,stop:null,step:1,isIndex:!0}}let t=r.split(":");if(t.length>3)throw new Error(`Invalid slice notation: "${r}" (too many colons)`);let e=t[0]===""?null:parseInt(t[0],10),n=t[1]===""||t[1]===void 0?null:parseInt(t[1],10),o=t[2]===""||t[2]===void 0?1:parseInt(t[2],10);if(e!==null&&isNaN(e))throw new Error(`Invalid start index in slice: "${r}"`);if(n!==null&&isNaN(n))throw new Error(`Invalid stop index in slice: "${r}"`);if(isNaN(o))throw new Error(`Invalid step in slice: "${r}"`);if(o===0)throw new Error("Slice step cannot be zero");return{start:e,stop:n,step:o,isIndex:!1}}function Ft(r,t){let{start:e,stop:n}=r,{step:o,isIndex:a}=r;if(a){if(e===null)throw new Error("Index cannot be null");let u=e<0?t+e:e;if(u<0||u>=t)throw new Error(`Index ${e} is out of bounds for size ${t}`);return{start:u,stop:u+1,step:1,isIndex:!0}}return o>0?(e===null&&(e=0),n===null&&(n=t)):(e===null&&(e=t-1),n===null&&(n=-t-1)),e<0&&(e=t+e),n<0&&(n=t+n),e=Math.max(0,Math.min(e,t)),n=Math.max(-1,Math.min(n,t)),{start:e,stop:n,step:o,isIndex:!1}}var Rt=M(()=>{"use strict"});function U(r){switch(r){case"float64":return Float64Array;case"float32":return Float32Array;case"int64":return BigInt64Array;case"int32":return Int32Array;case"int16":return Int16Array;case"int8":return Int8Array;case"uint64":return BigUint64Array;case"uint32":return Uint32Array;case"uint16":return Uint16Array;case"uint8":return Uint8Array;case"bool":return Uint8Array;default:throw new Error(`Unknown dtype: ${r}`)}}function qt(r){switch(r){case"float64":case"int64":case"uint64":return 8;case"float32":case"int32":case"uint32":return 4;case"int16":case"uint16":return 2;case"int8":case"uint8":case"bool":return 1;default:throw new Error(`Unknown dtype: ${r}`)}}function jt(r){return r==="int64"||r==="int32"||r==="int16"||r==="int8"||r==="uint64"||r==="uint32"||r==="uint16"||r==="uint8"}function Lt(r){return r==="float64"||r==="float32"}function w(r){return r==="int64"||r==="uint64"}function v(r,t){if(r===t)return r;if(r==="bool")return t;if(t==="bool")return r;if(Lt(r)||Lt(t)){if(r==="float64"||t==="float64")return"float64";if(r==="float32"){let c=t;return c==="int32"||c==="int64"||c==="uint32"||c==="uint64"?"float64":"float32"}if(t==="float32"){let c=r;return c==="int32"||c==="int64"||c==="uint32"||c==="uint64"?"float64":"float32"}return"float32"}let e=r.startsWith("int"),n=t.startsWith("int"),o=r.startsWith("uint"),a=t.startsWith("uint"),u=c=>c.includes("64")?64:c.includes("32")?32:c.includes("16")?16:c.includes("8")?8:0,s=u(r),i=u(t);if(r==="int64"&&t==="uint64"||r==="uint64"&&t==="int64")return"float64";if(e&&a&&s===i){if(s===8)return"int16";if(s===16)return"int32";if(s===32)return"int64"}if(o&&n&&s===i){if(i===8)return"int16";if(i===16)return"int32";if(i===32)return"int64"}if(e&&n||o&&a){let c=Math.max(s,i);return e?c===64?"int64":c===32?"int32":c===16?"int16":"int8":c===64?"uint64":c===32?"uint32":c===16?"uint16":"uint8"}return e&&a?s>i?r:i===8?"int16":i===16?"int32":i===32?"int64":"float64":o&&n?i>s?t:s===8?"int16":s===16?"int32":s===32?"int64":"float64":"float64"}var C,R=M(()=>{"use strict";C="float64"});function L(r){let t=new Array(r.length),e=1;for(let n=r.length-1;n>=0;n--)t[n]=e,e*=r[n];return t}var D,q=M(()=>{"use strict";R();D=class r{constructor(t,e,n,o,a){this._data=t,this._shape=e,this._strides=n,this._offset=o,this._dtype=a}get shape(){return this._shape}get ndim(){return this._shape.length}get size(){return this._shape.reduce((t,e)=>t*e,1)}get dtype(){return this._dtype}get data(){return this._data}get strides(){return this._strides}get offset(){return this._offset}get isCContiguous(){let t=this._shape,e=this._strides,n=t.length;if(n===0)return!0;if(n===1)return e[0]===1;let o=1;for(let a=n-1;a>=0;a--){if(e[a]!==o)return!1;o*=t[a]}return!0}get isFContiguous(){let t=this._shape,e=this._strides,n=t.length;if(n===0)return!0;if(n===1)return e[0]===1;let o=1;for(let a=0;a<n;a++){if(e[a]!==o)return!1;o*=t[a]}return!0}iget(t){let e=this._shape,n=this._strides,o=e.length;if(o===0)return this._data[this._offset];let a=t,u=this._offset;for(let s=0;s<o;s++){let i=1;for(let f=s+1;f<o;f++)i*=e[f];let c=Math.floor(a/i);a=a%i,u+=c*n[s]}return this._data[u]}iset(t,e){let n=this._shape,o=this._strides,a=n.length;if(a===0){this._data[this._offset]=e;return}let u=t,s=this._offset;for(let i=0;i<a;i++){let c=1;for(let p=i+1;p<a;p++)c*=n[p];let f=Math.floor(u/c);u=u%c,s+=f*o[i]}this._data[s]=e}get(...t){let e=this._strides,n=this._offset;for(let o=0;o<t.length;o++)n+=t[o]*e[o];return this._data[n]}set(t,e){let n=this._strides,o=this._offset;for(let a=0;a<t.length;a++)o+=t[a]*n[a];this._data[o]=e}copy(){let t=Array.from(this._shape),e=this._dtype,n=this.size,o=U(e);if(!o)throw new Error(`Cannot copy array with dtype ${e}`);let a=new o(n);if(this.isCContiguous&&this._offset===0)if(w(e)){let u=this._data,s=a;for(let i=0;i<n;i++)s[i]=u[i]}else a.set(this._data);else if(w(e)){let u=a;for(let s=0;s<n;s++)u[s]=this.iget(s)}else for(let u=0;u<n;u++)a[u]=this.iget(u);return new r(a,t,r._computeStrides(t),0,e)}static fromData(t,e,n,o,a){let u=o??r._computeStrides(e),s=a??0;return new r(t,e,u,s,n)}static zeros(t,e=C){let n=t.reduce((u,s)=>u*s,1),o=U(e);if(!o)throw new Error(`Cannot create array with dtype ${e}`);let a=new o(n);return new r(a,t,r._computeStrides(t),0,e)}static ones(t,e=C){let n=t.reduce((u,s)=>u*s,1),o=U(e);if(!o)throw new Error(`Cannot create array with dtype ${e}`);let a=new o(n);return w(e)?a.fill(BigInt(1)):a.fill(1),new r(a,t,r._computeStrides(t),0,e)}static _computeStrides(t){let e=new Array(t.length),n=1;for(let o=t.length-1;o>=0;o--)e[o]=n,n*=t[o];return e}}});function Zt(r,t){let e=r.length,n=t.length,o=Math.max(e,n),a=new Array(o);for(let u=0;u<o;u++){let s=u<o-e?1:r[u-(o-e)],i=u<o-n?1:t[u-(o-n)];if(s===i)a[u]=s;else if(s===1)a[u]=i;else if(i===1)a[u]=s;else throw new Error(`operands could not be broadcast together with shapes ${JSON.stringify(Array.from(r))} ${JSON.stringify(Array.from(t))}`)}return a}function Eo(r,t,e){let n=r.length,o=e.length,a=new Array(o).fill(0);for(let u=0;u<n;u++){let s=o-n+u,i=r[u],c=e[s];if(i===c)a[s]=t[u];else if(i===1)a[s]=0;else throw new Error("Invalid broadcast")}return a}function Nr(r,t){let e=Eo(r.shape,r.strides,t);return D.fromData(r.data,Array.from(t),r.dtype,e,r.offset)}function P(r,t,e,n){let o=Zt(r.shape,t.shape),a=Nr(r,o),u=Nr(t,o),s=v(r.dtype,t.dtype),i=D.zeros(o,s),c=i.data,f=i.size;if(w(s)){let p=c;for(let l=0;l<f;l++){let y=a.iget(l),m=u.iget(l),d=typeof y=="bigint"?y:BigInt(Math.round(y)),g=typeof m=="bigint"?m:BigInt(Math.round(m));n==="add"?p[l]=d+g:n==="subtract"?p[l]=d-g:n==="multiply"?p[l]=d*g:n==="divide"?p[l]=d/g:p[l]=BigInt(Math.round(e(Number(d),Number(g))))}}else{let p=w(r.dtype)||w(t.dtype);for(let l=0;l<f;l++){let y=a.iget(l),m=u.iget(l),d=Number(y),g=Number(m);c[l]=e(d,g)}}return i}function Q(r,t,e){let n=Zt(r.shape,t.shape),o=Nr(r,n),a=Nr(t,n),u=n.reduce((c,f)=>c*f,1),s=new Uint8Array(u),i=w(r.dtype)||w(t.dtype);for(let c=0;c<u;c++){let f=o.iget(c),p=a.iget(c),l=Number(f),y=Number(p);s[c]=e(l,y)?1:0}return D.fromData(s,n,"bool")}function V(r,t,e=!0){let n=r.dtype,o=Array.from(r.shape),a=r.size,s=e?n:n!=="float32"&&n!=="float64"?"float64":n,i=D.zeros(o,s),c=i.data,f=r.data;if(w(n))if(w(s)){let p=c;for(let l=0;l<a;l++){let y=Number(f[l]);p[l]=BigInt(Math.round(t(y)))}}else for(let p=0;p<a;p++)c[p]=t(Number(f[p]));else for(let p=0;p<a;p++)c[p]=t(Number(f[p]));return i}var er=M(()=>{"use strict";q();R()});function Hr(r,t){return r.isCContiguous&&t.isCContiguous&&r.shape.length===t.shape.length&&r.shape.every((e,n)=>e===t.shape[n])}function Wt(r,t){return typeof t=="number"?$o(r,t):Hr(r,t)?Uo(r,t):P(r,t,(e,n)=>e+n,"add")}function Uo(r,t){let e=v(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,u=t.data,s=n.data;if(w(e)){let i=s;if(!w(r.dtype)||!w(t.dtype))for(let f=0;f<o;f++){let p=typeof a[f]=="bigint"?a[f]:BigInt(Math.round(Number(a[f]))),l=typeof u[f]=="bigint"?u[f]:BigInt(Math.round(Number(u[f])));i[f]=p+l}else{let f=a,p=u;for(let l=0;l<o;l++)i[l]=f[l]+p[l]}}else if(w(r.dtype)||w(t.dtype))for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?Number(a[c]):a[c],p=typeof u[c]=="bigint"?Number(u[c]):u[c];s[c]=f+p}else for(let c=0;c<o;c++)s[c]=a[c]+u[c];return n}function Gt(r,t){return typeof t=="number"?vo(r,t):Hr(r,t)?To(r,t):P(r,t,(e,n)=>e-n,"subtract")}function To(r,t){let e=v(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,u=t.data,s=n.data;if(w(e)){let i=s;if(!w(r.dtype)||!w(t.dtype))for(let f=0;f<o;f++){let p=typeof a[f]=="bigint"?a[f]:BigInt(Math.round(Number(a[f]))),l=typeof u[f]=="bigint"?u[f]:BigInt(Math.round(Number(u[f])));i[f]=p-l}else{let f=a,p=u;for(let l=0;l<o;l++)i[l]=f[l]-p[l]}}else if(w(r.dtype)||w(t.dtype))for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?Number(a[c]):a[c],p=typeof u[c]=="bigint"?Number(u[c]):u[c];s[c]=f-p}else for(let c=0;c<o;c++)s[c]=a[c]-u[c];return n}function Ht(r,t){return typeof t=="number"?Mo(r,t):Hr(r,t)?Oo(r,t):P(r,t,(e,n)=>e*n,"multiply")}function Oo(r,t){let e=v(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,u=t.data,s=n.data;if(w(e)){let i=s;if(!w(r.dtype)||!w(t.dtype))for(let f=0;f<o;f++){let p=typeof a[f]=="bigint"?a[f]:BigInt(Math.round(Number(a[f]))),l=typeof u[f]=="bigint"?u[f]:BigInt(Math.round(Number(u[f])));i[f]=p*l}else{let f=a,p=u;for(let l=0;l<o;l++)i[l]=f[l]*p[l]}}else if(w(r.dtype)||w(t.dtype))for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?Number(a[c]):a[c],p=typeof u[c]=="bigint"?Number(u[c]):u[c];s[c]=f*p}else for(let c=0;c<o;c++)s[c]=a[c]*u[c];return n}function Yt(r,t){if(typeof t=="number")return Co(r,t);let e=r.dtype==="float64",n=t.dtype==="float64",o=r.dtype==="float32",a=t.dtype==="float32";if(e||n){let i=e?r:sr(r,"float64"),c=n?t:sr(t,"float64");return P(i,c,(f,p)=>f/p,"divide")}if(o||a){let i=o?r:sr(r,"float32"),c=a?t:sr(t,"float32");return P(i,c,(f,p)=>f/p,"divide")}let u=sr(r,"float64"),s=sr(t,"float64");return P(u,s,(i,c)=>i/c,"divide")}function sr(r,t){let e=D.zeros(Array.from(r.shape),t),n=r.size,o=r.data,a=e.data;for(let u=0;u<n;u++)a[u]=Number(o[u]);return e}function $o(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]+f}else for(let i=0;i<a;i++)s[i]=Number(o[i])+t;return u}function vo(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]-f}else for(let i=0;i<a;i++)s[i]=Number(o[i])-t;return u}function Mo(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]*f}else for(let i=0;i<a;i++)s[i]=Number(o[i])*t;return u}function Co(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=e!=="float32"&&e!=="float64"?"float64":e,i=D.zeros(n,s),c=i.data;if(w(e))for(let f=0;f<a;f++)c[f]=Number(o[f])/t;else for(let f=0;f<a;f++)c[f]=Number(o[f])/t;return i}function Jt(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),u=a.data;if(w(t)){let s=n,i=u;for(let c=0;c<o;c++){let f=s[c];i[c]=f<0n?-f:f}}else for(let s=0;s<o;s++)u[s]=Math.abs(Number(n[s]));return a}function Xt(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),u=a.data;if(w(t)){let s=n,i=u;for(let c=0;c<o;c++)i[c]=-s[c]}else for(let s=0;s<o;s++)u[s]=-Number(n[s]);return a}function Qt(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),u=a.data;if(w(t)){let s=n,i=u;for(let c=0;c<o;c++){let f=s[c];i[c]=f>0n?1n:f<0n?-1n:0n}}else for(let s=0;s<o;s++){let i=Number(n[s]);u[s]=i>0?1:i<0?-1:0}return a}function wr(r,t){return typeof t=="number"?ko(r,t):P(r,t,(e,n)=>(e%n+n)%n,"mod")}function ko(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++){let l=i[p];c[p]=(l%f+f)%f}}else for(let i=0;i<a;i++){let c=Number(o[i]);s[i]=(c%t+t)%t}return u}function Yr(r,t){return typeof t=="number"?Vo(r,t):P(r,t,(e,n)=>Math.floor(e/n),"floor_divide")}function Vo(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]/f}else for(let i=0;i<a;i++)s[i]=Math.floor(Number(o[i])/t);return u}function Kt(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),u=a.data;for(let s=0;s<o;s++)u[s]=n[s];return a}function re(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,u=t!=="float32"&&t!=="float64"?"float64":t,s=D.zeros(e,u),i=s.data;if(w(t))for(let c=0;c<o;c++)i[c]=1/Number(n[c]);else for(let c=0;c<o;c++)i[c]=1/Number(n[c]);return s}function te(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,u=t!=="float32"&&t!=="float64"?"float64":t,s=D.zeros(e,u),i=s.data;for(let c=0;c<o;c++)i[c]=Math.cbrt(Number(n[c]));return s}function ee(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=t==="float32"?"float32":"float64",u=D.zeros(e,a),s=u.data;for(let i=0;i<o;i++)s[i]=Math.abs(Number(n[i]));return u}function ne(r,t){let e=Yr(r,t),n=wr(r,t);return[e,n]}function oe(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),u=a.data;if(w(t)){let s=n,i=u;for(let c=0;c<o;c++)i[c]=s[c]*s[c]}else for(let s=0;s<o;s++){let i=Number(n[s]);u[s]=i*i}return a}function ae(r,t){return wr(r,t)}function se(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.size,a=e==="float32"?"float32":"float64",u=D.zeros(n,a),s=u.data;if(typeof t=="number")for(let i=0;i<o;i++){let c=Number(r.data[i]);c<0?s[i]=0:c===0?s[i]=t:s[i]=1}else{let i=t.data,c=t.shape;if(n.every((f,p)=>f===c[p]))for(let f=0;f<o;f++){let p=Number(r.data[f]);p<0?s[f]=0:p===0?s[f]=Number(i[f]):s[f]=1}else for(let f=0;f<o;f++){let p=Number(r.data[f]),l=f%t.size;p<0?s[f]=0:p===0?s[f]=Number(i[l]):s[f]=1}}return u}var ie=M(()=>{"use strict";q();R();er()});function K(r){if(r.length===0)return[];if(r.length===1)return Array.from(r[0]);let t=Math.max(...r.map(n=>n.length)),e=new Array(t);for(let n=0;n<t;n++){let o=1;for(let a of r){let u=a.length-t+n,s=u<0?1:a[u];if(s!==1){if(o===1)o=s;else if(o!==s)return null}}e[n]=o}return e}function Fo(r,t,e){let n=r.length,o=e.length,a=new Array(o).fill(0);for(let u=0;u<n;u++){let s=o-n+u,i=r[u],c=e[s];if(i===c)a[s]=t[u];else if(i===1)a[s]=0;else throw new Error("Invalid broadcast")}return a}function H(r,t){let e=Fo(r.shape,r.strides,t);return D.fromData(r.data,Array.from(t),r.dtype,e,r.offset)}function Jr(...r){let t=K(r);if(t===null){let e=r.map(n=>`(${n.join(",")})`).join(" ");throw new Error(`shape mismatch: objects cannot be broadcast to a single shape. Mismatch is between ${e}`)}return t}var Xr=M(()=>{"use strict";q()});function ue(r,t){return typeof t=="number"?Ro(r,t):Q(r,t,(e,n)=>e>n)}function ce(r,t){return typeof t=="number"?Lo(r,t):Q(r,t,(e,n)=>e>=n)}function fe(r,t){return typeof t=="number"?qo(r,t):Q(r,t,(e,n)=>e<n)}function le(r,t){return typeof t=="number"?jo(r,t):Q(r,t,(e,n)=>e<=n)}function pe(r,t){return typeof t=="number"?Zo(r,t):Q(r,t,(e,n)=>e===n)}function ye(r,t){return typeof t=="number"?Wo(r,t):Q(r,t,(e,n)=>e!==n)}function Qr(r,t,e=1e-5,n=1e-8){return typeof t=="number"?Go(r,t,e,n):Q(r,t,(o,a)=>{let u=Math.abs(o-a),s=n+e*Math.abs(a);return u<=s})}function me(r,t,e=1e-5,n=1e-8){let o=Qr(r,t,e,n),a=o.data;for(let u=0;u<o.size;u++)if(a[u]===0)return!1;return!0}function de(r,t){let e=[Array.from(r.shape),Array.from(t.shape)],n=K(e);if(n===null)return!1;let o=H(r,n),a=H(t,n),u=n.length,s=n.reduce((f,p)=>f*p,1),i=w(o.dtype),c=w(a.dtype);for(let f=0;f<s;f++){let p=f,l=new Array(u);for(let d=u-1;d>=0;d--)l[d]=p%n[d],p=Math.floor(p/n[d]);let y=o.get(...l),m=a.get(...l);if(i||c){let d=typeof y=="bigint"?y:BigInt(Number(y)),g=typeof m=="bigint"?m:BigInt(Number(m));if(d!==g)return!1}else if(y!==m)return!1}return!0}function Ro(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]>t?1:0;return D.fromData(e,Array.from(r.shape),"bool")}function Lo(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]>=t?1:0;return D.fromData(e,Array.from(r.shape),"bool")}function qo(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]<t?1:0;return D.fromData(e,Array.from(r.shape),"bool")}function jo(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]<=t?1:0;return D.fromData(e,Array.from(r.shape),"bool")}function Zo(r,t){let e=new Uint8Array(r.size),n=r.data,o=r.dtype;if(w(o)){let a=BigInt(Math.round(t)),u=n;for(let s=0;s<r.size;s++)e[s]=u[s]===a?1:0}else for(let a=0;a<r.size;a++)e[a]=n[a]===t?1:0;return D.fromData(e,Array.from(r.shape),"bool")}function Wo(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]!==t?1:0;return D.fromData(e,Array.from(r.shape),"bool")}function Go(r,t,e,n){let o=new Uint8Array(r.size),a=r.data,u=r.dtype;if(w(u)){let s=a;for(let i=0;i<r.size;i++){let c=Number(s[i]),f=Math.abs(c-t),p=n+e*Math.abs(t);o[i]=f<=p?1:0}}else for(let s=0;s<r.size;s++){let i=Number(a[s]),c=Math.abs(i-t),f=n+e*Math.abs(t);o[s]=c<=f?1:0}return D.fromData(o,Array.from(r.shape),"bool")}var ge=M(()=>{"use strict";q();R();er();Xr()});function O(r,t){let e=0,n=1;for(let o=r.length-1;o>=0;o--)e+=r[o]*n,n*=t[o];return e}function $(r,t,e,n){let o=n.length,a=new Array(o),u=Array.from(n).filter((i,c)=>c!==t),s=r;for(let i=u.length-1;i>=0;i--)a[i>=t?i+1:i]=s%u[i],s=Math.floor(s/u[i]);return a[t]=e,a}var Ae=M(()=>{"use strict"});function lr(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,u=r.size,s=r.data;if(t===void 0)if(w(n)){let m=s,d=BigInt(0);for(let g=0;g<u;g++)d+=m[g];return Number(d)}else{let m=0;for(let d=0;d<u;d++)m+=Number(s[d]);return m}let i=t;if(i<0&&(i=a+i),i<0||i>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let c=Array.from(o).filter((m,d)=>d!==i);if(c.length===0)return lr(r);let f=D.zeros(c,n),p=f.data,l=o[i],y=c.reduce((m,d)=>m*d,1);if(w(n)){let m=s,d=p;for(let g=0;g<y;g++){let h=BigInt(0);for(let A=0;A<l;A++){let b=$(g,i,A,o),S=O(b,o);h+=m[S]}d[g]=h}}else for(let m=0;m<y;m++){let d=0;for(let g=0;g<l;g++){let h=$(m,i,g,o),A=O(h,o);d+=Number(s[A])}p[m]=d}if(e){let m=[...o];return m[i]=1,D.fromData(p,m,n)}return f}function xr(r,t,e=!1){let n=r.dtype,o=r.shape;if(t===void 0)return lr(r)/r.size;let a=t;if(a<0&&(a=o.length+a),a<0||a>=o.length)throw new Error(`axis ${t} is out of bounds for array of dimension ${o.length}`);let u=lr(r,t,e);if(typeof u=="number")return u/o[a];let s=o[a],i=n;(w(n)||n.startsWith("int")||n.startsWith("uint"))&&(i="float64");let c=D.zeros(Array.from(u.shape),i),f=c.data,p=u.data;if(w(n)){let l=p;for(let y=0;y<f.length;y++)f[y]=Number(l[y])/s}else for(let l=0;l<f.length;l++)f[l]=Number(p[l])/s;return c}function Ir(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,u=r.size,s=r.data;if(t===void 0){if(u===0)throw new Error("max of empty array");let m=s[0];for(let d=1;d<u;d++)s[d]>m&&(m=s[d]);return Number(m)}let i=t;if(i<0&&(i=a+i),i<0||i>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let c=Array.from(o).filter((m,d)=>d!==i);if(c.length===0)return Ir(r);let f=D.zeros(c,n),p=f.data,l=o[i],y=c.reduce((m,d)=>m*d,1);if(w(n)){let m=s,d=p;for(let g=0;g<y;g++){let h=$(g,i,0,o),A=O(h,o),b=m[A];for(let S=1;S<l;S++){let N=$(g,i,S,o),x=O(N,o),I=m[x];I>b&&(b=I)}d[g]=b}}else for(let m=0;m<y;m++){let d=-1/0;for(let g=0;g<l;g++){let h=$(m,i,g,o),A=O(h,o),b=Number(s[A]);b>d&&(d=b)}p[m]=d}if(e){let m=[...o];return m[i]=1,D.fromData(p,m,n)}return f}function Kr(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,u=r.size,s=r.data;if(t===void 0)if(w(n)){let m=s,d=BigInt(1);for(let g=0;g<u;g++)d*=m[g];return Number(d)}else{let m=1;for(let d=0;d<u;d++)m*=Number(s[d]);return m}let i=t;if(i<0&&(i=a+i),i<0||i>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let c=Array.from(o).filter((m,d)=>d!==i);if(c.length===0)return Kr(r);let f=D.zeros(c,n),p=f.data,l=o[i],y=c.reduce((m,d)=>m*d,1);if(w(n)){let m=s,d=p;for(let g=0;g<y;g++){let h=BigInt(1);for(let A=0;A<l;A++){let b=$(g,i,A,o),S=O(b,o);h*=m[S]}d[g]=h}}else for(let m=0;m<y;m++){let d=1;for(let g=0;g<l;g++){let h=$(m,i,g,o),A=O(h,o);d*=Number(s[A])}p[m]=d}if(e){let m=[...o];return m[i]=1,D.fromData(p,m,n)}return f}function zr(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,u=r.size,s=r.data;if(t===void 0){if(u===0)throw new Error("min of empty array");let m=s[0];for(let d=1;d<u;d++)s[d]<m&&(m=s[d]);return Number(m)}let i=t;if(i<0&&(i=a+i),i<0||i>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let c=Array.from(o).filter((m,d)=>d!==i);if(c.length===0)return zr(r);let f=D.zeros(c,n),p=f.data,l=o[i],y=c.reduce((m,d)=>m*d,1);if(w(n)){let m=s,d=p;for(let g=0;g<y;g++){let h=$(g,i,0,o),A=O(h,o),b=m[A];for(let S=1;S<l;S++){let N=$(g,i,S,o),x=O(N,o),I=m[x];I<b&&(b=I)}d[g]=b}}else for(let m=0;m<y;m++){let d=1/0;for(let g=0;g<l;g++){let h=$(m,i,g,o),A=O(h,o),b=Number(s[A]);b<d&&(d=b)}p[m]=d}if(e){let m=[...o];return m[i]=1,D.fromData(p,m,n)}return f}function rt(r,t){let e=r.dtype,n=r.shape,o=n.length,a=r.size,u=r.data;if(t===void 0){if(a===0)throw new Error("argmin of empty array");let y=u[0],m=0;for(let d=1;d<a;d++)u[d]<y&&(y=u[d],m=d);return m}let s=t;if(s<0&&(s=o+s),s<0||s>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let i=Array.from(n).filter((y,m)=>m!==s);if(i.length===0)return rt(r);let c=D.zeros(i,"int32"),f=c.data,p=n[s],l=i.reduce((y,m)=>y*m,1);if(w(e)){let y=u;for(let m=0;m<l;m++){let d=$(m,s,0,n),g=O(d,n),h=y[g],A=0;for(let b=1;b<p;b++){let S=$(m,s,b,n),N=O(S,n),x=y[N];x<h&&(h=x,A=b)}f[m]=A}}else for(let y=0;y<l;y++){let m=1/0,d=0;for(let g=0;g<p;g++){let h=$(y,s,g,n),A=O(h,n),b=Number(u[A]);b<m&&(m=b,d=g)}f[y]=d}return c}function tt(r,t){let e=r.dtype,n=r.shape,o=n.length,a=r.size,u=r.data;if(t===void 0){if(a===0)throw new Error("argmax of empty array");let y=u[0],m=0;for(let d=1;d<a;d++)u[d]>y&&(y=u[d],m=d);return m}let s=t;if(s<0&&(s=o+s),s<0||s>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let i=Array.from(n).filter((y,m)=>m!==s);if(i.length===0)return tt(r);let c=D.zeros(i,"int32"),f=c.data,p=n[s],l=i.reduce((y,m)=>y*m,1);if(w(e)){let y=u;for(let m=0;m<l;m++){let d=$(m,s,0,n),g=O(d,n),h=y[g],A=0;for(let b=1;b<p;b++){let S=$(m,s,b,n),N=O(S,n),x=y[N];x>h&&(h=x,A=b)}f[m]=A}}else for(let y=0;y<l;y++){let m=-1/0,d=0;for(let g=0;g<p;g++){let h=$(y,s,g,n),A=O(h,n),b=Number(u[A]);b>m&&(m=b,d=g)}f[y]=d}return c}function et(r,t,e=0,n=!1){let o=r.shape,a=o.length,u=r.size,s=r.data,i=xr(r,t,n);if(t===void 0){let h=i,A=0;for(let b=0;b<u;b++){let S=Number(s[b])-h;A+=S*S}return A/(u-e)}let c=t;if(c<0&&(c=a+c),c<0||c>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let f=o[c],p=i,l=p.data,y=n?p.shape:Array.from(o).filter((h,A)=>A!==c),m=D.zeros(Array.from(y),"float64"),d=m.data,g=y.reduce((h,A)=>h*A,1);for(let h=0;h<g;h++){let A=0,b=Number(l[h]);for(let S=0;S<f;S++){let N=$(h,c,S,o),x=O(N,o),I=Number(s[x])-b;A+=I*I}d[h]=A/(f-e)}return m}function he(r,t,e=0,n=!1){let o=et(r,t,e,n);if(typeof o=="number")return Math.sqrt(o);let a=D.zeros(Array.from(o.shape),"float64"),u=o.data,s=a.data;for(let i=0;i<u.length;i++)s[i]=Math.sqrt(Number(u[i]));return a}function nt(r,t,e=!1){let n=r.shape,o=n.length,a=r.size,u=r.data;if(t===void 0){for(let y=0;y<a;y++)if(!u[y])return!1;return!0}let s=t;if(s<0&&(s=o+s),s<0||s>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let i=Array.from(n).filter((y,m)=>m!==s);if(i.length===0)return nt(r);let c=D.zeros(i,"bool"),f=c.data,p=n[s],l=i.reduce((y,m)=>y*m,1);for(let y=0;y<l;y++){let m=!0;for(let d=0;d<p;d++){let g=$(y,s,d,n),h=O(g,n);if(!u[h]){m=!1;break}}f[y]=m?1:0}if(e){let y=[...n];return y[s]=1,D.fromData(f,y,"bool")}return c}function ot(r,t,e=!1){let n=r.shape,o=n.length,a=r.size,u=r.data;if(t===void 0){for(let y=0;y<a;y++)if(u[y])return!0;return!1}let s=t;if(s<0&&(s=o+s),s<0||s>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let i=Array.from(n).filter((y,m)=>m!==s);if(i.length===0)return ot(r);let c=D.zeros(i,"bool"),f=c.data,p=n[s],l=i.reduce((y,m)=>y*m,1);for(let y=0;y<l;y++){let m=!1;for(let d=0;d<p;d++){let g=$(y,s,d,n),h=O(g,n);if(u[h]){m=!0;break}}f[y]=m?1:0}if(e){let y=[...n];return y[s]=1,D.fromData(f,y,"bool")}return c}function at(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let l=r.size,y=new Float64Array(l),m=0;for(let d=0;d<l;d++)m+=Number(o[d]),y[d]=m;return D.fromData(y,[l],"float64")}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=new Float64Array(r.size),s=e[a],i=[],c=1;for(let l=n-1;l>=0;l--)i.unshift(c),c*=e[l];let f=r.size,p=i[a];for(let l=0;l<f;l++)Math.floor(l/p)%s===0?u[l]=Number(o[l]):u[l]=u[l-p]+Number(o[l]);return D.fromData(u,[...e],"float64")}function st(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let l=r.size,y=new Float64Array(l),m=1;for(let d=0;d<l;d++)m*=Number(o[d]),y[d]=m;return D.fromData(y,[l],"float64")}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=new Float64Array(r.size),s=e[a],i=[],c=1;for(let l=n-1;l>=0;l--)i.unshift(c),c*=e[l];let f=r.size,p=i[a];for(let l=0;l<f;l++)Math.floor(l/p)%s===0?u[l]=Number(o[l]):u[l]=u[l-p]*Number(o[l]);return D.fromData(u,[...e],"float64")}function it(r,t,e=!1){let n=Ir(r,t,e),o=zr(r,t,e);if(typeof n=="number"&&typeof o=="number")return n-o;let a=n,u=o,s=a.data,i=u.data,c=new Float64Array(a.size);for(let f=0;f<a.size;f++)c[f]=Number(s[f])-Number(i[f]);return D.fromData(c,[...a.shape],"float64")}function ut(r,t,e=!1){return ir(r,.5,t,e)}function ct(r,t,e,n=!1){return ir(r,t/100,e,n)}function ir(r,t,e,n=!1){if(t<0||t>1)throw new Error("Quantile must be between 0 and 1");let o=r.shape,a=o.length,u=r.data;if(e===void 0){let y=[];for(let b=0;b<r.size;b++)y.push(Number(u[b]));y.sort((b,S)=>b-S);let m=y.length,d=t*(m-1),g=Math.floor(d),h=Math.ceil(d);if(g===h)return y[g];let A=d-g;return y[g]*(1-A)+y[h]*A}let s=e;if(s<0&&(s=a+s),s<0||s>=a)throw new Error(`axis ${e} is out of bounds for array of dimension ${a}`);let i=Array.from(o).filter((y,m)=>m!==s);if(i.length===0)return ir(r,t);let c=i.reduce((y,m)=>y*m,1),f=o[s],p=new Float64Array(c);for(let y=0;y<c;y++){let m=[];for(let b=0;b<f;b++){let S=$(y,s,b,o),N=O(S,o);m.push(Number(u[N]))}m.sort((b,S)=>b-S);let d=m.length,g=t*(d-1),h=Math.floor(g),A=Math.ceil(g);if(h===A)p[y]=m[h];else{let b=g-h;p[y]=m[h]*(1-b)+m[A]*b}}let l=D.fromData(p,i,"float64");if(n){let y=[...o];return y[s]=1,D.fromData(p,y,"float64")}return l}function _r(r,t,e,n=!1){let o=r.shape,a=o.length,u=r.data;if(e===void 0)return xr(r,t,n);if(t===void 0){let m=0,d=0,g=e.data;for(let h=0;h<r.size;h++){let A=Number(g[h%e.size]);m+=Number(u[h])*A,d+=A}return d===0?NaN:m/d}let s=t;if(s<0&&(s=a+s),s<0||s>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let i=Array.from(o).filter((m,d)=>d!==s);if(i.length===0)return _r(r,void 0,e);let c=i.reduce((m,d)=>m*d,1),f=o[s],p=e.data,l=new Float64Array(c);for(let m=0;m<c;m++){let d=0,g=0;for(let h=0;h<f;h++){let A=$(m,s,h,o),b=O(A,o),S=Number(p[h%e.size]);d+=Number(u[b])*S,g+=S}l[m]=g===0?NaN:d/g}let y=D.fromData(l,i,"float64");if(n){let m=[...o];return m[s]=1,D.fromData(l,m,"float64")}return y}function Br(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let l=0;for(let y=0;y<r.size;y++){let m=Number(a[y]);isNaN(m)||(l+=m)}return l}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((l,y)=>y!==u);if(s.length===0)return Br(r);let i=s.reduce((l,y)=>l*y,1),c=n[u],f=new Float64Array(i);for(let l=0;l<i;l++){let y=0;for(let m=0;m<c;m++){let d=$(l,u,m,n),g=O(d,n),h=Number(a[g]);isNaN(h)||(y+=h)}f[l]=y}let p=D.fromData(f,s,"float64");if(e){let l=[...n];return l[u]=1,D.fromData(f,l,"float64")}return p}function Er(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let l=1;for(let y=0;y<r.size;y++){let m=Number(a[y]);isNaN(m)||(l*=m)}return l}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((l,y)=>y!==u);if(s.length===0)return Er(r);let i=s.reduce((l,y)=>l*y,1),c=n[u],f=new Float64Array(i);for(let l=0;l<i;l++){let y=1;for(let m=0;m<c;m++){let d=$(l,u,m,n),g=O(d,n),h=Number(a[g]);isNaN(h)||(y*=h)}f[l]=y}let p=D.fromData(f,s,"float64");if(e){let l=[...n];return l[u]=1,D.fromData(f,l,"float64")}return p}function Ur(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let l=0,y=0;for(let m=0;m<r.size;m++){let d=Number(a[m]);isNaN(d)||(l+=d,y++)}return y===0?NaN:l/y}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((l,y)=>y!==u);if(s.length===0)return Ur(r);let i=s.reduce((l,y)=>l*y,1),c=n[u],f=new Float64Array(i);for(let l=0;l<i;l++){let y=0,m=0;for(let d=0;d<c;d++){let g=$(l,u,d,n),h=O(g,n),A=Number(a[h]);isNaN(A)||(y+=A,m++)}f[l]=m===0?NaN:y/m}let p=D.fromData(f,s,"float64");if(e){let l=[...n];return l[u]=1,D.fromData(f,l,"float64")}return p}function pr(r,t,e=0,n=!1){let o=r.shape,a=o.length,u=r.data;if(t===void 0){let y=0,m=0;for(let h=0;h<r.size;h++){let A=Number(u[h]);isNaN(A)||(y+=A,m++)}if(m-e<=0)return NaN;let d=y/m,g=0;for(let h=0;h<r.size;h++){let A=Number(u[h]);isNaN(A)||(g+=(A-d)**2)}return g/(m-e)}let s=t;if(s<0&&(s=a+s),s<0||s>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let i=Array.from(o).filter((y,m)=>m!==s);if(i.length===0)return pr(r,void 0,e);let c=i.reduce((y,m)=>y*m,1),f=o[s],p=new Float64Array(c);for(let y=0;y<c;y++){let m=0,d=0;for(let A=0;A<f;A++){let b=$(y,s,A,o),S=O(b,o),N=Number(u[S]);isNaN(N)||(m+=N,d++)}if(d-e<=0){p[y]=NaN;continue}let g=m/d,h=0;for(let A=0;A<f;A++){let b=$(y,s,A,o),S=O(b,o),N=Number(u[S]);isNaN(N)||(h+=(N-g)**2)}p[y]=h/(d-e)}let l=D.fromData(p,i,"float64");if(n){let y=[...o];return y[s]=1,D.fromData(p,y,"float64")}return l}function ft(r,t,e=0,n=!1){let o=pr(r,t,e,n);if(typeof o=="number")return Math.sqrt(o);let a=o,u=new Float64Array(a.size);for(let s=0;s<a.size;s++)u[s]=Math.sqrt(Number(a.data[s]));return D.fromData(u,[...a.shape],"float64")}function Tr(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let l=1/0;for(let y=0;y<r.size;y++){let m=Number(a[y]);!isNaN(m)&&m<l&&(l=m)}return l===1/0?NaN:l}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((l,y)=>y!==u);if(s.length===0)return Tr(r);let i=s.reduce((l,y)=>l*y,1),c=n[u],f=new Float64Array(i);for(let l=0;l<i;l++){let y=1/0;for(let m=0;m<c;m++){let d=$(l,u,m,n),g=O(d,n),h=Number(a[g]);!isNaN(h)&&h<y&&(y=h)}f[l]=y===1/0?NaN:y}let p=D.fromData(f,s,"float64");if(e){let l=[...n];return l[u]=1,D.fromData(f,l,"float64")}return p}function Or(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let l=-1/0;for(let y=0;y<r.size;y++){let m=Number(a[y]);!isNaN(m)&&m>l&&(l=m)}return l===-1/0?NaN:l}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((l,y)=>y!==u);if(s.length===0)return Or(r);let i=s.reduce((l,y)=>l*y,1),c=n[u],f=new Float64Array(i);for(let l=0;l<i;l++){let y=-1/0;for(let m=0;m<c;m++){let d=$(l,u,m,n),g=O(d,n),h=Number(a[g]);!isNaN(h)&&h>y&&(y=h)}f[l]=y===-1/0?NaN:y}let p=D.fromData(f,s,"float64");if(e){let l=[...n];return l[u]=1,D.fromData(f,l,"float64")}return p}function $r(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let f=1/0,p=-1;for(let l=0;l<r.size;l++){let y=Number(o[l]);!isNaN(y)&&y<f&&(f=y,p=l)}return p}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=Array.from(e).filter((f,p)=>p!==a);if(u.length===0)return $r(r);let s=u.reduce((f,p)=>f*p,1),i=e[a],c=new Int32Array(s);for(let f=0;f<s;f++){let p=1/0,l=0;for(let y=0;y<i;y++){let m=$(f,a,y,e),d=O(m,e),g=Number(o[d]);!isNaN(g)&&g<p&&(p=g,l=y)}c[f]=l}return D.fromData(c,u,"int32")}function vr(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let f=-1/0,p=-1;for(let l=0;l<r.size;l++){let y=Number(o[l]);!isNaN(y)&&y>f&&(f=y,p=l)}return p}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=Array.from(e).filter((f,p)=>p!==a);if(u.length===0)return vr(r);let s=u.reduce((f,p)=>f*p,1),i=e[a],c=new Int32Array(s);for(let f=0;f<s;f++){let p=-1/0,l=0;for(let y=0;y<i;y++){let m=$(f,a,y,e),d=O(m,e),g=Number(o[d]);!isNaN(g)&&g>p&&(p=g,l=y)}c[f]=l}return D.fromData(c,u,"int32")}function lt(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let l=r.size,y=new Float64Array(l),m=0;for(let d=0;d<l;d++){let g=Number(o[d]);isNaN(g)||(m+=g),y[d]=m}return D.fromData(y,[l],"float64")}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=new Float64Array(r.size),s=e[a],i=[],c=1;for(let l=n-1;l>=0;l--)i.unshift(c),c*=e[l];let f=r.size,p=i[a];for(let l=0;l<f;l++){let y=Number(o[l]);Math.floor(l/p)%s===0?u[l]=isNaN(y)?0:y:u[l]=u[l-p]+(isNaN(y)?0:y)}return D.fromData(u,[...e],"float64")}function pt(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let l=r.size,y=new Float64Array(l),m=1;for(let d=0;d<l;d++){let g=Number(o[d]);isNaN(g)||(m*=g),y[d]=m}return D.fromData(y,[l],"float64")}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=new Float64Array(r.size),s=e[a],i=[],c=1;for(let l=n-1;l>=0;l--)i.unshift(c),c*=e[l];let f=r.size,p=i[a];for(let l=0;l<f;l++){let y=Number(o[l]);Math.floor(l/p)%s===0?u[l]=isNaN(y)?1:y:u[l]=u[l-p]*(isNaN(y)?1:y)}return D.fromData(u,[...e],"float64")}function Mr(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let l=[];for(let d=0;d<r.size;d++){let g=Number(a[d]);isNaN(g)||l.push(g)}if(l.length===0)return NaN;l.sort((d,g)=>d-g);let y=l.length,m=Math.floor(y/2);return y%2===0?(l[m-1]+l[m])/2:l[m]}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((l,y)=>y!==u);if(s.length===0)return Mr(r);let i=s.reduce((l,y)=>l*y,1),c=n[u],f=new Float64Array(i);for(let l=0;l<i;l++){let y=[];for(let g=0;g<c;g++){let h=$(l,u,g,n),A=O(h,n),b=Number(a[A]);isNaN(b)||y.push(b)}if(y.length===0){f[l]=NaN;continue}y.sort((g,h)=>g-h);let m=y.length,d=Math.floor(m/2);m%2===0?f[l]=(y[d-1]+y[d])/2:f[l]=y[d]}let p=D.fromData(f,s,"float64");if(e){let l=[...n];return l[u]=1,D.fromData(f,l,"float64")}return p}var be=M(()=>{"use strict";q();R();Ae()});function W(r,t){let e=r.size,n=r.dtype,o=t.indexOf(-1),a;if(o!==-1){let c=t.reduce((p,l,y)=>y===o?p:p*l,1),f=e/c;if(!Number.isInteger(f))throw new Error(`cannot reshape array of size ${e} into shape ${JSON.stringify(t)}`);a=t.map((p,l)=>l===o?f:p)}else a=t;if(a.reduce((c,f)=>c*f,1)!==e)throw new Error(`cannot reshape array of size ${e} into shape ${JSON.stringify(a)}`);if(r.isCContiguous){let c=r.data;return D.fromData(c,a,n,L(a),0)}let i=r.copy().data;return D.fromData(i,a,n,L(a),0)}function Cr(r){let t=r.size,e=r.dtype,n=U(e);if(!n)throw new Error(`Cannot flatten array with dtype ${e}`);if(r.isCContiguous){let s=r.data.slice(r.offset,r.offset+t);return D.fromData(s,[t],e,[1],0)}let o=new n(t),a=w(e);for(let u=0;u<t;u++){let s=r.iget(u);o[u]=s}return D.fromData(o,[t],e,[1],0)}function mr(r){let t=r.size,e=r.dtype;if(r.isCContiguous){let n=r.data;return D.fromData(n,[t],e,[1],0)}return Cr(r)}function dr(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,u=r.dtype,s;if(t===void 0)s=Array.from({length:n},(p,l)=>n-1-l);else{if(t.length!==n)throw new Error(`axes must have length ${n}, got ${t.length}`);let p=new Set;for(let l of t){let y=l<0?n+l:l;if(y<0||y>=n)throw new Error(`axis ${l} is out of bounds for array of dimension ${n}`);if(p.has(y))throw new Error("repeated axis in transpose");p.add(y)}s=t.map(l=>l<0?n+l:l)}let i=s.map(p=>e[p]),c=Array.from(o),f=s.map(p=>c[p]);return D.fromData(a,i,u,f,r.offset)}function Se(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,u=r.dtype;if(t===void 0){let s=[],i=[];for(let c=0;c<n;c++)e[c]!==1&&(s.push(e[c]),i.push(o[c]));return s.length===0&&(s.push(1),i.push(1)),D.fromData(a,s,u,i,r.offset)}else{let s=t<0?n+t:t;if(s<0||s>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);if(e[s]!==1)throw new Error(`cannot select an axis which has size not equal to one (axis ${t} has size ${e[s]})`);let i=[],c=[];for(let f=0;f<n;f++)f!==s&&(i.push(e[f]),c.push(o[f]));return D.fromData(a,i,u,c,r.offset)}}function yr(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,u=r.dtype,s=t;if(s<0&&(s=n+t+1),s<0||s>n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n+1}`);let i=[...Array.from(e)];i.splice(s,0,1);let c=[...Array.from(o)],f=s<n?o[s]*(e[s]||1):1;return c.splice(s,0,f),D.fromData(a,i,u,c,r.offset)}function De(r,t,e){let n=r.shape,o=n.length,a=r.strides,u=r.data,s=r.dtype,i=t<0?o+t:t,c=e<0?o+e:e;if(i<0||i>=o)throw new Error(`axis1 ${t} is out of bounds for array of dimension ${o}`);if(c<0||c>=o)throw new Error(`axis2 ${e} is out of bounds for array of dimension ${o}`);if(i===c)return D.fromData(u,Array.from(n),s,Array.from(a),r.offset);let f=Array.from(n),p=Array.from(a);return[f[i],f[c]]=[f[c],f[i]],[p[i],p[c]]=[p[c],p[i]],D.fromData(u,f,s,p,r.offset)}function yt(r,t,e){let n=r.ndim,o=Array.isArray(t)?t:[t],a=Array.isArray(e)?e:[e];if(o.length!==a.length)throw new Error("source and destination must have the same number of elements");let u=o.map(c=>{let f=c<0?n+c:c;if(f<0||f>=n)throw new Error(`source axis ${c} is out of bounds for array of dimension ${n}`);return f}),s=a.map(c=>{let f=c<0?n+c:c;if(f<0||f>=n)throw new Error(`destination axis ${c} is out of bounds for array of dimension ${n}`);return f});if(new Set(u).size!==u.length)throw new Error("repeated axis in source");if(new Set(s).size!==s.length)throw new Error("repeated axis in destination");let i=[];for(let c=0;c<n;c++)u.includes(c)||i.push(c);for(let c=0;c<u.length;c++){let f=s[c];i.splice(f,0,u[c])}return dr(r,i)}function nr(r,t=0){if(r.length===0)throw new Error("need at least one array to concatenate");if(r.length===1)return r[0].copy();let e=r[0],n=e.ndim,o=e.dtype,a=t<0?n+t:t;if(a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);for(let y=1;y<r.length;y++){let m=r[y];if(m.ndim!==n)throw new Error("all the input arrays must have same number of dimensions");for(let d=0;d<n;d++)if(d!==a&&m.shape[d]!==e.shape[d])throw new Error("all the input array dimensions except for the concatenation axis must match exactly")}let u=Array.from(e.shape),s=e.shape[a];for(let y=1;y<r.length;y++)s+=r[y].shape[a];u[a]=s;let i=u.reduce((y,m)=>y*m,1),c=U(o);if(!c)throw new Error(`Cannot concatenate arrays with dtype ${o}`);let f=new c(i),p=L(u),l=0;for(let y of r){let m=y.shape[a];Jo(y,f,u,p,a,l,o),l+=m}return D.fromData(f,u,o)}function Jo(r,t,e,n,o,a,u){let s=r.shape,i=s.length,c=r.size,f=u==="int64"||u==="uint64";if(o===0&&r.isCContiguous&&i>0){let y=a*n[0],m=r.data,d=r.offset,g=d+c;t.set(m.subarray(d,g),y);return}if(o===1&&i===2&&r.isCContiguous){let y=s[0],m=s[1],d=e[1],g=r.data,h=r.offset;for(let A=0;A<y;A++){let b=h+A*m,S=A*d+a;t.set(g.subarray(b,b+m),S)}return}let p=new Array(i).fill(0),l=a*n[o];for(let y=0;y<c;y++){let m=r.iget(y),d=l;for(let g=0;g<i;g++)d+=p[g]*n[g];t[d]=m;for(let g=i-1;g>=0&&(p[g]++,!(p[g]<s[g]));g--)p[g]=0}}function Ne(r,t=0){if(r.length===0)throw new Error("need at least one array to stack");let e=r[0],n=e.shape,o=e.ndim,a=t<0?o+1+t:t;if(a<0||a>o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o+1}`);for(let s=1;s<r.length;s++){let i=r[s];if(i.ndim!==o)throw new Error("all input arrays must have the same shape");for(let c=0;c<o;c++)if(i.shape[c]!==n[c])throw new Error("all input arrays must have the same shape")}let u=r.map(s=>yr(s,a));return nr(u,a)}function we(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?W(e,[1,e.shape[0]]):e);return nr(t,0)}function mt(r){if(r.length===0)throw new Error("need at least one array to stack");return r.every(e=>e.ndim===1)?nr(r,0):nr(r,1)}function xe(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?W(yr(W(e,[1,e.shape[0]]),2),[1,e.shape[0],1]):e.ndim===2?yr(e,2):e);return nr(t,2)}function Ie(r,t,e=0){let n=r.shape,o=n.length,a=e<0?o+e:e;if(a<0||a>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let u=n[a],s;if(typeof t=="number"){if(u%t!==0)throw new Error("array split does not result in an equal division");let i=u/t;s=[];for(let c=1;c<t;c++)s.push(c*i)}else s=t;return ze(r,s,a)}function gr(r,t,e=0){let n=r.shape,o=n.length,a=e<0?o+e:e;if(a<0||a>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let u=n[a],s;if(typeof t=="number"){let i=t,c=Math.floor(u/i),f=u%i;s=[];let p=0;for(let l=0;l<i-1;l++)p+=c+(l<f?1:0),s.push(p)}else s=t;return ze(r,s,a)}function ze(r,t,e){let n=r.shape,o=n[e],a=[0,...t,o],u=[];for(let s=0;s<a.length-1;s++){let i=a[s],c=a[s+1];if(i>c)throw new Error("split indices must be in ascending order");let f=Array.from(n);f[e]=c-i;let p=r.offset+i*r.strides[e];u.push(D.fromData(r.data,f,r.dtype,Array.from(r.strides),p))}return u}function _e(r,t){if(r.ndim<2)throw new Error("vsplit only works on arrays of 2 or more dimensions");return gr(r,t,0)}function Be(r,t){if(r.ndim<1)throw new Error("hsplit only works on arrays of 1 or more dimensions");let e=r.ndim===1?0:1;return gr(r,t,e)}function Ee(r,t){let e=r.shape,n=e.length,o=r.dtype,a=Array.isArray(t)?t:[t],u=Math.max(n,a.length),s=new Array(u).fill(1),i=new Array(u).fill(1);for(let A=0;A<n;A++)s[u-n+A]=e[A];for(let A=0;A<a.length;A++)i[u-a.length+A]=a[A];let c=s.map((A,b)=>A*i[b]),f=c.reduce((A,b)=>A*b,1),p=U(o);if(!p)throw new Error(`Cannot tile array with dtype ${o}`);let l=new p(f),y=L(c),m=r;n<u&&(m=W(r,s));let d=o==="int64"||o==="uint64",g=m.strides,h=new Array(u).fill(0);for(let A=0;A<f;A++){let b=m.offset;for(let x=0;x<u;x++){let I=h[x]%s[x];b+=I*g[x]}let S=m.data[b],N=0;for(let x=0;x<u;x++)N+=h[x]*y[x];l[N]=S;for(let x=u-1;x>=0&&(h[x]++,!(h[x]<c[x]));x--)h[x]=0}return D.fromData(l,c,o)}function Ue(r,t,e){let n=r.shape,o=n.length,a=r.dtype,u=r.size;if(e===void 0){let A=u,b=Array.isArray(t)?t:new Array(A).fill(t);if(b.length!==A)throw new Error(`operands could not be broadcast together with shape (${A},) (${b.length},)`);let S=b.reduce((z,B)=>z+B,0),N=U(a);if(!N)throw new Error(`Cannot repeat array with dtype ${a}`);let x=new N(S),I=0;for(let z=0;z<A;z++){let B=r.iget(z),E=b[z];for(let T=0;T<E;T++)x[I++]=B}return D.fromData(x,[S],a)}let s=e<0?o+e:e;if(s<0||s>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let i=n[s],c=Array.isArray(t)?t:new Array(i).fill(t);if(c.length!==i)throw new Error(`operands could not be broadcast together with shape (${i},) (${c.length},)`);let f=Array.from(n);f[s]=c.reduce((A,b)=>A+b,0);let p=f.reduce((A,b)=>A*b,1),l=U(a);if(!l)throw new Error(`Cannot repeat array with dtype ${a}`);let y=new l(p),m=L(f),d=new Array(o).fill(0),g=a==="int64"||a==="uint64",h=[0];for(let A=0;A<i;A++)h.push(h[A]+c[A]);for(let A=0;A<u;A++){let b=r.iget(A),S=d[s],N=c[S],x=0;for(let B=0;B<o;B++)B!==s&&(x+=d[B]*m[B]);let I=m[s],z=h[S];for(let B=0;B<N;B++){let E=x+(z+B)*I;y[E]=b}for(let B=o-1;B>=0&&(d[B]++,!(d[B]<n[B]));B--)d[B]=0}return D.fromData(y,f,a)}function Te(r,t){let e=r.shape,n=e.length,o=r.dtype,a=r.size,u;if(t===void 0)u=new Set(Array.from({length:n},(l,y)=>y));else if(typeof t=="number"){let l=t<0?n+t:t;if(l<0||l>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);u=new Set([l])}else u=new Set(t.map(l=>{let y=l<0?n+l:l;if(y<0||y>=n)throw new Error(`axis ${l} is out of bounds for array of dimension ${n}`);return y}));let s=U(o);if(!s)throw new Error(`Cannot flip array with dtype ${o}`);let i=new s(a),c=w(o);if(n===1&&r.isCContiguous){let l=r.data,y=r.offset;for(let m=0;m<a;m++)i[m]=l[y+a-1-m];return D.fromData(i,[...e],o)}if(n===2&&r.isCContiguous){let l=e[0],y=e[1],m=r.data,d=r.offset;if(u.size===2){for(let g=0;g<a;g++)i[g]=m[d+a-1-g];return D.fromData(i,[...e],o)}if(u.size===1){if(u.has(0)){for(let g=0;g<l;g++){let h=d+(l-1-g)*y,A=g*y;for(let b=0;b<y;b++)i[A+b]=m[h+b]}return D.fromData(i,[...e],o)}else if(u.has(1)){for(let g=0;g<l;g++){let h=d+g*y,A=g*y;for(let b=0;b<y;b++)i[A+b]=m[h+y-1-b]}return D.fromData(i,[...e],o)}}}let f=new Array(n),p=new Array(n).fill(0);for(let l=0;l<a;l++){for(let d=0;d<n;d++)f[d]=u.has(d)?e[d]-1-p[d]:p[d];let y=r.offset;for(let d=0;d<n;d++)y+=f[d]*r.strides[d];let m=r.data[y];i[l]=m;for(let d=n-1;d>=0&&(p[d]++,!(p[d]<e[d]));d--)p[d]=0}return D.fromData(i,[...e],o)}function Oe(r,t=1,e=[0,1]){let n=r.shape,o=n.length,a=r.dtype;if(o<2)throw new Error("Input must be at least 2-D");let u=e[0]<0?o+e[0]:e[0],s=e[1]<0?o+e[1]:e[1];if(u<0||u>=o||s<0||s>=o)throw new Error(`Axes are out of bounds for array of dimension ${o}`);if(u===s)throw new Error("Axes must be different");if(t=(t%4+4)%4,t===0)return r.copy();let i=U(a);if(!i)throw new Error(`Cannot rotate array with dtype ${a}`);let c=[...n];(t===1||t===3)&&([c[u],c[s]]=[c[s],c[u]]);let f=c.reduce((g,h)=>g*h,1),p=new i(f),l=L(c),y=w(a),m=new Array(o).fill(0),d=new Array(o);for(let g=0;g<r.size;g++){for(let N=0;N<o;N++)d[N]=m[N];let h,A;t===1?(h=n[s]-1-m[s],A=m[u]):t===2?(h=n[u]-1-m[u],A=n[s]-1-m[s],d[u]=h,d[s]=A):(h=m[s],A=n[u]-1-m[u]),t!==2&&(d[u]=h,d[s]=A);let b=0;for(let N=0;N<o;N++)b+=d[N]*l[N];let S=r.iget(g);p[b]=S;for(let N=o-1;N>=0&&(m[N]++,!(m[N]<n[N]));N--)m[N]=0}return D.fromData(p,c,a)}function $e(r,t,e){let n=r.shape,o=n.length,a=r.dtype,u=r.size;if(e===void 0){let m=Array.isArray(t)?t.reduce((b,S)=>b+S,0):t,d=Cr(r),g=U(a);if(!g)throw new Error(`Cannot roll array with dtype ${a}`);let h=new g(u),A=w(a);for(let b=0;b<u;b++){let S=((b-m)%u+u)%u,N=d.iget(S);h[b]=N}return D.fromData(h,[...n],a)}let s=Array.isArray(t)?t:[t],i=Array.isArray(e)?e:[e];if(s.length!==i.length)throw new Error("shift and axis must have the same length");let c=i.map(m=>{let d=m<0?o+m:m;if(d<0||d>=o)throw new Error(`axis ${m} is out of bounds for array of dimension ${o}`);return d}),f=U(a);if(!f)throw new Error(`Cannot roll array with dtype ${a}`);let p=new f(u),l=w(a),y=new Array(o).fill(0);for(let m=0;m<u;m++){let d=[...y];for(let A=0;A<c.length;A++){let b=c[A],S=n[b],N=s[A];d[b]=((d[b]-N)%S+S)%S}let g=r.offset;for(let A=0;A<o;A++)g+=d[A]*r.strides[A];let h=r.data[g];p[m]=h;for(let A=o-1;A>=0&&(y[A]++,!(y[A]<n[A]));A--)y[A]=0}return D.fromData(p,[...n],a)}function ve(r,t,e=0){let n=r.ndim,o=t<0?n+t:t;if(o<0||o>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let a=e<0?n+e:e;if(a<0||a>n)throw new Error(`start ${e} is out of bounds`);return o<a&&a--,o===a?D.fromData(r.data,Array.from(r.shape),r.dtype,Array.from(r.strides),r.offset):yt(r,o,a)}function Me(r,t){if(r.ndim<3)throw new Error("dsplit only works on arrays of 3 or more dimensions");return gr(r,t,2)}function Ce(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?W(e,[e.shape[0],1]):e);return mt(t)}function ke(r,t){let e=r.dtype,n=t.reduce((i,c)=>i*c,1),o=r.size,a=U(e);if(!a)throw new Error(`Cannot resize array with dtype ${e}`);let u=new a(n),s=w(e);for(let i=0;i<n;i++){let c=i%o,f=r.iget(c);u[i]=f}return D.fromData(u,t,e)}function Ve(r){return r.map(t=>t.ndim===0?W(t,[1]):t)}function Pe(r){return r.map(t=>t.ndim===0?W(t,[1,1]):t.ndim===1?W(t,[1,t.shape[0]]):t)}function Fe(r){return r.map(t=>t.ndim===0?W(t,[1,1,1]):t.ndim===1?W(t,[1,t.shape[0],1]):t.ndim===2?W(t,[t.shape[0],t.shape[1],1]):t)}var dt=M(()=>{"use strict";q();R()});function Xo(r,t,e,n,o,a,u,s,i,c,f,p,l,y){if(p===0)for(let h=0;h<n*o;h++)l[h]=0;else if(p!==1)for(let h=0;h<n*o;h++)l[h]=(l[h]??0)*p;let m=r==="row-major",d=t==="transpose",g=e==="transpose";if(m&&!d&&!g)for(let h=0;h<n;h++)for(let A=0;A<o;A++){let b=0;for(let S=0;S<a;S++)b+=(s[h*i+S]??0)*(c[S*f+A]??0);l[h*y+A]=(l[h*y+A]??0)+u*b}else if(m&&d&&!g)for(let h=0;h<n;h++)for(let A=0;A<o;A++){let b=0;for(let S=0;S<a;S++)b+=(s[S*i+h]??0)*(c[S*f+A]??0);l[h*y+A]=(l[h*y+A]??0)+u*b}else if(m&&!d&&g)for(let h=0;h<n;h++)for(let A=0;A<o;A++){let b=0;for(let S=0;S<a;S++)b+=(s[h*i+S]??0)*(c[A*f+S]??0);l[h*y+A]=(l[h*y+A]??0)+u*b}else if(m&&d&&g)for(let h=0;h<n;h++)for(let A=0;A<o;A++){let b=0;for(let S=0;S<a;S++)b+=(s[S*i+h]??0)*(c[A*f+S]??0);l[h*y+A]=(l[h*y+A]??0)+u*b}else if(!m&&!d&&!g)for(let h=0;h<n;h++)for(let A=0;A<o;A++){let b=0;for(let S=0;S<a;S++)b+=(s[S*i+h]??0)*(c[A*f+S]??0);l[A*y+h]=(l[A*y+h]??0)+u*b}else if(!m&&d&&!g)for(let h=0;h<n;h++)for(let A=0;A<o;A++){let b=0;for(let S=0;S<a;S++)b+=(s[h*i+S]??0)*(c[A*f+S]??0);l[A*y+h]=(l[A*y+h]??0)+u*b}else if(!m&&!d&&g)for(let h=0;h<n;h++)for(let A=0;A<o;A++){let b=0;for(let S=0;S<a;S++)b+=(s[S*i+h]??0)*(c[S*f+A]??0);l[A*y+h]=(l[A*y+h]??0)+u*b}else for(let h=0;h<n;h++)for(let A=0;A<o;A++){let b=0;for(let S=0;S<a;S++)b+=(s[h*i+S]??0)*(c[S*f+A]??0);l[A*y+h]=(l[A*y+h]??0)+u*b}}function At(r,t){let e=r.ndim,n=t.ndim;if(e===0||n===0){let o=e===0?r.get():null,a=n===0?t.get():null;if(e===0&&n===0)return typeof o=="bigint"&&typeof a=="bigint"?o*a:Number(o)*Number(a);if(e===0){let u=v(r.dtype,t.dtype),s=D.zeros([...t.shape],u);for(let i=0;i<t.size;i++){let c=t.data[i+t.offset];typeof o=="bigint"&&typeof c=="bigint"?s.data[i]=o*c:s.data[i]=Number(o)*Number(c)}return s}else{let u=v(r.dtype,t.dtype),s=D.zeros([...r.shape],u);for(let i=0;i<r.size;i++){let c=r.data[i+r.offset];typeof c=="bigint"&&typeof a=="bigint"?s.data[i]=c*a:s.data[i]=Number(c)*Number(a)}return s}}if(e===1&&n===1){if(r.shape[0]!==t.shape[0])throw new Error(`dot: incompatible shapes (${r.shape[0]},) and (${t.shape[0]},)`);let o=r.shape[0],a=0;for(let u=0;u<o;u++){let s=r.get(u),i=t.get(u);typeof s=="bigint"&&typeof i=="bigint"?a=Number(a)+Number(s*i):a+=Number(s)*Number(i)}return a}if(e===2&&n===2)return or(r,t);if(e===2&&n===1){let[o,a]=r.shape,u=t.shape[0];if(a!==u)throw new Error(`dot: incompatible shapes (${o},${a}) and (${u},)`);let s=v(r.dtype,t.dtype),i=D.zeros([o],s);for(let c=0;c<o;c++){let f=0;for(let p=0;p<a;p++){let l=r.get(c,p),y=t.get(p);typeof l=="bigint"&&typeof y=="bigint"?f=Number(f)+Number(l*y):f+=Number(l)*Number(y)}i.set([c],f)}return i}if(e===1&&n===2){let o=r.shape[0],[a,u]=t.shape;if(o!==a)throw new Error(`dot: incompatible shapes (${o},) and (${a},${u})`);let s=v(r.dtype,t.dtype),i=D.zeros([u],s);for(let c=0;c<u;c++){let f=0;for(let p=0;p<o;p++){let l=r.get(p),y=t.get(p,c);typeof l=="bigint"&&typeof y=="bigint"?f=Number(f)+Number(l*y):f+=Number(l)*Number(y)}i.set([c],f)}return i}if(e>2&&n===1){let o=r.shape[e-1],a=t.shape[0];if(o!==a)throw new Error(`dot: incompatible shapes ${JSON.stringify(r.shape)} and (${a},)`);let u=[...r.shape.slice(0,-1)],s=v(r.dtype,t.dtype),i=D.zeros(u,s),c=u.reduce((f,p)=>f*p,1);for(let f=0;f<c;f++){let p=0,l=f,y=[];for(let m=u.length-1;m>=0;m--)y[m]=l%u[m],l=Math.floor(l/u[m]);for(let m=0;m<o;m++){let d=[...y,m],g=r.get(...d),h=t.get(m);typeof g=="bigint"&&typeof h=="bigint"?p=Number(p)+Number(g*h):p+=Number(g)*Number(h)}i.set(y,p)}return i}if(e===1&&n>2){let o=r.shape[0],a=1,u=t.shape[a];if(o!==u)throw new Error(`dot: incompatible shapes (${o},) and ${JSON.stringify(t.shape)}`);let s=[...t.shape.slice(0,a),...t.shape.slice(a+1)],i=v(r.dtype,t.dtype),c=D.zeros(s,i),f=s.reduce((p,l)=>p*l,1);for(let p=0;p<f;p++){let l=p,y=[];for(let h=s.length-1;h>=0;h--)y[h]=l%s[h],l=Math.floor(l/s[h]);let m=y.slice(0,a),d=y.slice(a),g=0;for(let h=0;h<o;h++){let A=r.get(h),b=[...m,h,...d],S=t.get(...b);typeof A=="bigint"&&typeof S=="bigint"?g=Number(g)+Number(A*S):g+=Number(A)*Number(S)}c.set(y,g)}return c}if(e>=2&&n>=2&&!(e===2&&n===2)){let o=r.shape[e-1],a=t.shape[n-2];if(o!==a)throw new Error(`dot: incompatible shapes ${JSON.stringify(r.shape)} and ${JSON.stringify(t.shape)}`);let u=[...r.shape.slice(0,-1),...t.shape.slice(0,-2),t.shape[n-1]],s=v(r.dtype,t.dtype),i=D.zeros(u,s),c=r.shape.slice(0,-1).reduce((y,m)=>y*m,1),f=t.shape.slice(0,-2).reduce((y,m)=>y*m,1),p=t.shape[n-1],l=o;for(let y=0;y<c;y++)for(let m=0;m<f;m++)for(let d=0;d<p;d++){let g=0;for(let A=0;A<l;A++){let b=y*l+A,S=r.data[b+r.offset],N=m*l*p+A*p+d,x=t.data[N+t.offset];typeof S=="bigint"&&typeof x=="bigint"?g=Number(g)+Number(S*x):g+=Number(S)*Number(x)}let h=y*f*p+m*p+d;i.data[h]=g}return i}throw new Error(`dot: unexpected combination of dimensions ${e}D \xB7 ${n}D`)}function or(r,t){if(r.ndim!==2||t.ndim!==2)throw new Error("matmul requires 2D arrays");let[e=0,n=0]=r.shape,[o=0,a=0]=t.shape;if(n!==o)throw new Error(`matmul shape mismatch: (${e},${n}) @ (${o},${a})`);let u=v(r.dtype,t.dtype),s=u.startsWith("int")||u.startsWith("uint")||u==="bool"?"float64":u;if(s!=="float64")throw new Error(`matmul currently only supports float64, got ${s}`);let i=r.dtype==="float64"?r.data:Float64Array.from(Array.from(r.data).map(Number)),c=t.dtype==="float64"?t.data:Float64Array.from(Array.from(t.data).map(Number));r.offset>0&&(i=i.subarray(r.offset)),t.offset>0&&(c=c.subarray(t.offset));let[f=0,p=0]=r.strides,[l=0,y=0]=t.strides,m=p>f,d=y>l,g=m?"transpose":"no-transpose",h=d?"transpose":"no-transpose",A,b;m?A=p:A=f,d?b=y:b=l;let S=D.zeros([e,a],"float64");return Xo("row-major",g,h,e,a,n,1,i,A,c,b,0,S.data,a),S}function qe(r){if(r.ndim!==2)throw new Error(`trace requires 2D array, got ${r.ndim}D`);let[t=0,e=0]=r.shape,n=Math.min(t,e),o=0;for(let a=0;a<n;a++){let u=r.get(a,a);typeof u=="bigint"?o=(typeof o=="bigint"?o:BigInt(o))+u:o=(typeof o=="bigint"?Number(o):o)+u}return o}function Le(r,t){return dr(r,t)}function je(r,t){let e=r.ndim,n=t.ndim,o=r.shape[e-1],a=t.shape[n-1];if(o!==a)throw new Error(`inner: incompatible shapes - last dimensions ${o} and ${a} don't match`);if(e===1&&n===1)return At(r,t);let u=[...r.shape.slice(0,-1),...t.shape.slice(0,-1)],s=v(r.dtype,t.dtype),i=D.zeros(u,s),c=e===1?1:r.shape.slice(0,-1).reduce((l,y)=>l*y,1),f=n===1?1:t.shape.slice(0,-1).reduce((l,y)=>l*y,1),p=o;for(let l=0;l<c;l++)for(let y=0;y<f;y++){let m=0;for(let g=0;g<p;g++){let h=e===1?g:l*p+g,A=n===1?g:y*p+g,b=r.data[h+r.offset],S=t.data[A+t.offset];typeof b=="bigint"&&typeof S=="bigint"?m=Number(m)+Number(b*S):m+=Number(b)*Number(S)}if(u.length===0)return m;let d=c===1?y:l*f+y;i.data[d]=m}return i}function ht(r,t){let e=r.ndim===1?r:mr(r),n=t.ndim===1?t:mr(t),o=e.size,a=n.size,u=v(r.dtype,t.dtype),s=D.zeros([o,a],u);for(let i=0;i<o;i++)for(let c=0;c<a;c++){let f=e.get(i),p=n.get(c),l;typeof f=="bigint"&&typeof p=="bigint"?l=f*p:l=Number(f)*Number(p),s.set([i,c],l)}return s}function Ze(r,t,e){let n,o;if(typeof e=="number"){let l=e;if(l<0)throw new Error("tensordot: axes must be non-negative");if(l>r.ndim||l>t.ndim)throw new Error("tensordot: axes exceeds array dimensions");n=Array.from({length:l},(y,m)=>r.ndim-l+m),o=Array.from({length:l},(y,m)=>m)}else if([n,o]=e,n.length!==o.length)throw new Error("tensordot: axes lists must have same length");for(let l=0;l<n.length;l++){let y=n[l],m=o[l];if(y<0||y>=r.ndim||m<0||m>=t.ndim)throw new Error("tensordot: axis out of bounds");if(r.shape[y]!==t.shape[m])throw new Error(`tensordot: shape mismatch on axes ${y} and ${m}: ${r.shape[y]} != ${t.shape[m]}`)}let a=[],u=[];for(let l=0;l<r.ndim;l++)n.includes(l)||a.push(l);for(let l=0;l<t.ndim;l++)o.includes(l)||u.push(l);let s=[...a.map(l=>r.shape[l]),...u.map(l=>t.shape[l])];if(s.length===0){let l=0,y=n.map(m=>r.shape[m]).reduce((m,d)=>m*d,1);for(let m=0;m<y;m++){let d=m,g=new Array(n.length);for(let N=n.length-1;N>=0;N--){let x=n[N];g[N]=d%r.shape[x],d=Math.floor(d/r.shape[x])}let h=new Array(r.ndim),A=new Array(t.ndim);for(let N=0;N<n.length;N++)h[n[N]]=g[N];for(let N=0;N<o.length;N++)A[o[N]]=g[N];let b=r.get(...h),S=t.get(...A);typeof b=="bigint"&&typeof S=="bigint"?l=Number(l)+Number(b*S):l+=Number(b)*Number(S)}return l}let i=v(r.dtype,t.dtype),c=D.zeros(s,i),f=s.reduce((l,y)=>l*y,1),p=n.map(l=>r.shape[l]).reduce((l,y)=>l*y,1);for(let l=0;l<f;l++){let y=l,m=[];for(let A=s.length-1;A>=0;A--)m[A]=y%s[A],y=Math.floor(y/s[A]);let d=m.slice(0,a.length),g=m.slice(a.length),h=0;for(let A=0;A<p;A++){y=A;let b=[];for(let z=n.length-1;z>=0;z--){let B=n[z];b[z]=y%r.shape[B],y=Math.floor(y/r.shape[B])}let S=new Array(r.ndim),N=new Array(t.ndim);for(let z=0;z<a.length;z++)S[a[z]]=d[z];for(let z=0;z<u.length;z++)N[u[z]]=g[z];for(let z=0;z<n.length;z++)S[n[z]]=b[z],N[o[z]]=b[z];let x=r.get(...S),I=t.get(...N);typeof x=="bigint"&&typeof I=="bigint"?h=Number(h)+Number(x*I):h+=Number(x)*Number(I)}c.set(m,h)}return c}function We(r,t=0,e=0,n=1){let o=r.shape,a=o.length;if(a<2)throw new Error("diagonal requires an array of at least two dimensions");let u=e<0?a+e:e,s=n<0?a+n:n;if(u<0||u>=a||s<0||s>=a)throw new Error("axis out of bounds");if(u===s)throw new Error("axis1 and axis2 cannot be the same");let i=o[u],c=o[s],f;t>=0?f=Math.max(0,Math.min(i,c-t)):f=Math.max(0,Math.min(i+t,c));let p=[];for(let d=0;d<a;d++)d!==u&&d!==s&&p.push(o[d]);p.push(f);let l=D.zeros(p,r.dtype),y=o.filter((d,g)=>g!==u&&g!==s),m=y.reduce((d,g)=>d*g,1);for(let d=0;d<m;d++){let g=d,h=[];for(let A=y.length-1;A>=0;A--)h.unshift(g%y[A]),g=Math.floor(g/y[A]);for(let A=0;A<f;A++){let b=new Array(a),S=0;for(let I=0;I<a;I++)I===u?b[I]=t>=0?A:A-t:I===s?b[I]=t>=0?A+t:A:b[I]=h[S++];let N=[...h,A],x=r.get(...b);l.set(N,x)}}return l}function Ge(r,...t){let e=r.indexOf("->"),n,o;e===-1?(n=r,o=Qo(n)):(n=r.slice(0,e),o=r.slice(e+2));let a=n.split(",").map(d=>d.trim());if(a.length!==t.length)throw new Error(`einsum: expected ${a.length} operands, got ${t.length}`);let u=new Map;for(let d=0;d<t.length;d++){let g=a[d],h=t[d];if(g.length!==h.ndim)throw new Error(`einsum: operand ${d} has ${h.ndim} dimensions but subscript '${g}' has ${g.length} indices`);for(let A=0;A<g.length;A++){let b=g[A],S=h.shape[A];if(u.has(b)){if(u.get(b)!==S)throw new Error(`einsum: size mismatch for index '${b}': ${u.get(b)} vs ${S}`)}else u.set(b,S)}}for(let d of o)if(!u.has(d))throw new Error(`einsum: output subscript contains unknown index '${d}'`);let s=new Set(o),i=new Set;for(let d of a)for(let g of d)i.add(g);let c=[];for(let d of i)s.has(d)||c.push(d);if(t.length===2&&a.length===2){let[d,g]=a,[h,A]=t;if(d.length===2&&g.length===2&&o.length===2&&h.ndim===2&&A.ndim===2){let[b,S]=[d[0],d[1]],[N,x]=[g[0],g[1]],[I,z]=[o[0],o[1]];if(b===I&&x===z&&S===N&&c.length===1&&c[0]===S||b===I&&x===z&&S===N&&c.length===1&&c[0]===S)return or(h,A);if(S===I&&x===z&&b===N&&c.length===1&&c[0]===b){let B=Le(h);return or(B,A)}if(b===I&&N===z&&S===x&&c.length===1&&c[0]===S){let B=Le(A);return or(h,B)}}if(d.length===1&&g.length===1&&d===g&&o.length===0&&h.ndim===1&&A.ndim===1)return gt(t,a,c,u);if(d&&g&&d.length===1&&g.length===1&&o.length===2&&o===d+g&&c.length===0&&h.ndim===1&&A.ndim===1)return ht(h,A)}if(t.length===1&&a[0].length===2&&o.length===0){let d=a[0];if(d[0]===d[1]&&t[0].ndim===2)return gt(t,a,c,u)}let f=Array.from(o).map(d=>u.get(d));if(f.length===0)return gt(t,a,c,u);let p=t[0].dtype;for(let d=1;d<t.length;d++)p=v(p,t[d].dtype);let l=D.zeros(f,p),y=f.reduce((d,g)=>d*g,1),m=1;for(let d of c)m*=u.get(d);for(let d=0;d<y;d++){let g=Ko(d,f),h=new Map;for(let b=0;b<o.length;b++)h.set(o[b],g[b]);let A=0;for(let b=0;b<m;b++){let S=b;for(let x=c.length-1;x>=0;x--){let I=c[x],z=u.get(I);h.set(I,S%z),S=Math.floor(S/z)}let N=1;for(let x=0;x<t.length;x++){let I=t[x],z=a[x],B=[];for(let T of z)B.push(h.get(T));let E=I.get(...B);N*=Number(E)}A+=N}l.set(g,A)}return l}function Qo(r){let t=new Map,e=r.split(",");for(let o of e)for(let a of o.trim())t.set(a,(t.get(a)||0)+1);let n=[];for(let[o,a]of t)a===1&&n.push(o);return n.sort().join("")}function gt(r,t,e,n){let o=1;for(let u of e)o*=n.get(u);let a=0;for(let u=0;u<o;u++){let s=new Map,i=u;for(let f=e.length-1;f>=0;f--){let p=e[f],l=n.get(p);s.set(p,i%l),i=Math.floor(i/l)}let c=1;for(let f=0;f<r.length;f++){let p=r[f],l=t[f],y=[];for(let d of l)y.push(s.get(d));let m=p.get(...y);c*=Number(m)}a+=c}return a}function Ko(r,t){let e=new Array(t.length),n=r;for(let o=t.length-1;o>=0;o--)e[o]=n%t[o],n=Math.floor(n/t[o]);return e}function He(r,t){let e=r.shape,n=t.shape,o=e.length,a=n.length,u=v(r.dtype,t.dtype),s=Math.max(o,a),i=new Array(s),c=new Array(s).fill(1),f=new Array(s).fill(1);for(let m=0;m<o;m++)c[s-o+m]=e[m];for(let m=0;m<a;m++)f[s-a+m]=n[m];for(let m=0;m<s;m++)i[m]=c[m]*f[m];let p=D.zeros(i,u),l=e.reduce((m,d)=>m*d,1),y=n.reduce((m,d)=>m*d,1);for(let m=0;m<l;m++){let d=m,g=new Array(o);for(let b=o-1;b>=0;b--)g[b]=d%e[b],d=Math.floor(d/e[b]);let h=new Array(s).fill(0);for(let b=0;b<o;b++)h[s-o+b]=g[b];let A=r.get(...g);for(let b=0;b<y;b++){let S=b,N=new Array(a);for(let E=a-1;E>=0;E--)N[E]=S%n[E],S=Math.floor(S/n[E]);let x=new Array(s).fill(0);for(let E=0;E<a;E++)x[s-a+E]=N[E];let I=t.get(...N),z=new Array(s);for(let E=0;E<s;E++)z[E]=h[E]*f[E]+x[E];let B=typeof A=="bigint"||typeof I=="bigint"?BigInt(Number(A))*BigInt(Number(I)):Number(A)*Number(I);p.set(z,B)}}return p}var Ye=M(()=>{"use strict";q();R();dt()});function Je(r){return V(r,Math.sqrt,!1)}function Xe(r,t){return typeof t=="number"?ta(r,t):P(r,t,Math.pow,"power")}function ta(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=e!=="float32"&&e!=="float64"&&(t<0||!Number.isInteger(t))?"float64":e,c=D.zeros(n,i),f=c.data;if(w(e))if(w(i)&&Number.isInteger(t)&&t>=0){let p=o,l=f;for(let y=0;y<a;y++)l[y]=p[y]**BigInt(t)}else for(let p=0;p<a;p++)f[p]=Math.pow(Number(o[p]),t);else for(let p=0;p<a;p++)f[p]=Math.pow(Number(o[p]),t);return c}var Qe=M(()=>{"use strict";q();er();R()});function Ke(r){return V(r,Math.sin,!1)}function rn(r){return V(r,Math.cos,!1)}function tn(r){return V(r,Math.tan,!1)}function en(r){return V(r,Math.asin,!1)}function nn(r){return V(r,Math.acos,!1)}function on(r){return V(r,Math.atan,!1)}function an(r,t){return typeof t=="number"?oa(r,t):na(r,t)}function na(r,t){let e=Array.from(r.shape),n=r.size,o=r.dtype,a=t.dtype,u=o==="float32"&&a==="float32"?"float32":"float64",s=D.zeros(e,u),i=s.data;for(let c=0;c<n;c++){let f=(w(o),Number(r.data[c])),p=(w(a),Number(t.data[c]));i[c]=Math.atan2(f,p)}return s}function oa(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=e==="float32"?"float32":"float64",s=D.zeros(n,u),i=s.data;if(w(e))for(let c=0;c<a;c++)i[c]=Math.atan2(Number(o[c]),t);else for(let c=0;c<a;c++)i[c]=Math.atan2(Number(o[c]),t);return s}function sn(r,t){return typeof t=="number"?sa(r,t):aa(r,t)}function aa(r,t){let e=Array.from(r.shape),n=r.size,o=r.dtype,a=t.dtype,u=o==="float32"&&a==="float32"?"float32":"float64",s=D.zeros(e,u),i=s.data;for(let c=0;c<n;c++){let f=(w(o),Number(r.data[c])),p=(w(a),Number(t.data[c]));i[c]=Math.hypot(f,p)}return s}function sa(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=e==="float32"?"float32":"float64",s=D.zeros(n,u),i=s.data;if(w(e))for(let c=0;c<a;c++)i[c]=Math.hypot(Number(o[c]),t);else for(let c=0;c<a;c++)i[c]=Math.hypot(Number(o[c]),t);return s}function un(r){let t=180/Math.PI;return V(r,e=>e*t,!1)}function cn(r){let t=Math.PI/180;return V(r,e=>e*t,!1)}var fn=M(()=>{"use strict";q();er();R()});function ln(r){return V(r,Math.sinh,!1)}function pn(r){return V(r,Math.cosh,!1)}function yn(r){return V(r,Math.tanh,!1)}function mn(r){return V(r,Math.asinh,!1)}function dn(r){return V(r,Math.acosh,!1)}function gn(r){return V(r,Math.atanh,!1)}var An=M(()=>{"use strict";er()});function bt(r,t){let e=r.shape,n=e.length,o=t.length;if(o<n)throw new Error("input operand has more dimensions than allowed by the axis remapping");let a=K([Array.from(e),t]);if(a===null)throw new Error(`operands could not be broadcast together with shape (${e.join(",")}) (${t.join(",")})`);for(let u=0;u<o;u++)if(a[u]!==t[u])throw new Error(`operands could not be broadcast together with shape (${e.join(",")}) (${t.join(",")})`);return H(r,t)}function hn(r){if(r.length===0)return[];if(r.length===1)return[r[0]];let t=r.map(n=>Array.from(n.shape)),e=K(t);if(e===null)throw new Error(`operands could not be broadcast together with shapes ${t.map(n=>`(${n.join(",")})`).join(" ")}`);return r.map(n=>H(n,e))}function bn(r,t,e){let n=r.shape,o=n.length,a=r.dtype;if(e===void 0){let m=r.size;for(let A of t){let b=A<0?m+A:A;if(b<0||b>=m)throw new Error(`index ${A} is out of bounds for axis 0 with size ${m}`)}let d=t.length,g=U(a);if(!g)throw new Error(`Cannot take from array with dtype ${a}`);let h=new g(d);for(let A=0;A<d;A++){let b=t[A];b<0&&(b=m+b);let S=r.iget(b);w(a),h[A]=S}return D.fromData(h,[d],a)}let u=e<0?o+e:e;if(u<0||u>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let s=n[u];for(let m of t){let d=m<0?s+m:m;if(d<0||d>=s)throw new Error(`index ${m} is out of bounds for axis ${u} with size ${s}`)}let i=Array.from(n);i[u]=t.length;let c=i.reduce((m,d)=>m*d,1),f=U(a);if(!f)throw new Error(`Cannot take from array with dtype ${a}`);let p=new f(c),l=L(i),y=new Array(o).fill(0);for(let m=0;m<c;m++){let d=[...y],g=y[u],h=t[g];h<0&&(h=s+h),d[u]=h;let A=r.get(...d),b=0;for(let S=0;S<o;S++)b+=y[S]*l[S];w(a),p[b]=A;for(let S=o-1;S>=0&&(y[S]++,!(y[S]<i[S]));S--)y[S]=0}return D.fromData(p,i,a)}function Sn(r,t,e){let n=r.size,o=r.dtype,a;if(typeof e=="number"||typeof e=="bigint")a=new Array(t.length).fill(e);else{a=[];for(let u=0;u<e.size;u++)a.push(e.iget(u));if(a.length===1)a=new Array(t.length).fill(a[0]);else if(a.length!==t.length){let u=[...a];a=[];for(let s=0;s<t.length;s++)a.push(u[s%u.length])}}for(let u=0;u<t.length;u++){let s=t[u];if(s<0&&(s=n+s),s<0||s>=n)throw new Error(`index ${t[u]} is out of bounds for axis 0 with size ${n}`);let i=a[u];w(o)?typeof i!="bigint"&&(i=BigInt(Math.round(Number(i)))):typeof i=="bigint"&&(i=Number(i)),r.iset(s,i)}}function Dn(r,t){if(t.length===0)throw new Error("choices cannot be empty");let e=r.shape,n=t.length,o=t[0].dtype,a=t.map(l=>Array.from(l.shape));a.unshift(Array.from(e));let u=K(a);if(u===null)throw new Error("operands could not be broadcast together");let s=H(r,u),i=t.map(l=>H(l,u)),c=u.reduce((l,y)=>l*y,1),f=U(o);if(!f)throw new Error(`Cannot choose with dtype ${o}`);let p=new f(c);for(let l=0;l<c;l++){let y=Number(s.iget(l));if(y<0||y>=n)throw new Error(`index ${y} is out of bounds for axis 0 with size ${n}`);let m=i[y].iget(l);w(o),p[l]=m}return D.fromData(p,u,o)}function Nn(r,t,e=!1){if(r.ndim!==t.ndim)return!1;for(let o=0;o<r.ndim;o++)if(r.shape[o]!==t.shape[o])return!1;let n=r.size;for(let o=0;o<n;o++){let a=r.iget(o),u=t.iget(o);if(e){let s=typeof a=="number"&&Number.isNaN(a),i=typeof u=="number"&&Number.isNaN(u);if(s&&i)continue}if(a!==u)return!1}return!0}function wn(r,t,e){let n=r.shape,o=n.length,a=r.dtype,u=e<0?o+e:e;if(u<0||u>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let s=t.shape;if(s.length!==o)throw new Error(`indices and arr must have the same number of dimensions, got ${s.length} vs ${o}`);for(let d=0;d<o;d++)if(d!==u&&s[d]!==n[d]&&s[d]!==1&&n[d]!==1)throw new Error(`index ${s[d]} is out of bounds for size ${n[d]} in dimension ${d}`);let i=Array.from(s),c=i.reduce((d,g)=>d*g,1),f=U(a);if(!f)throw new Error(`Cannot take_along_axis with dtype ${a}`);let p=new f(c),l=L(n),y=L(s),m=n[u];for(let d=0;d<c;d++){let g=new Array(o),h=d;for(let I=o-1;I>=0;I--)g[I]=h%i[I],h=Math.floor(h/i[I]);let A=0;for(let I=0;I<o;I++){let z=s[I]===1?0:g[I];A+=z*y[I]}let b=Number(t.iget(A));if(b<0&&(b=m+b),b<0||b>=m)throw new Error(`index ${b} is out of bounds for axis ${u} with size ${m}`);let S=[...g];S[u]=b;let N=0;for(let I=0;I<o;I++){let z=n[I]===1?0:S[I];N+=z*l[I]}let x=r.iget(N);w(a),p[d]=x}return D.fromData(p,i,a)}function xn(r,t,e,n){let o=r.shape,a=o.length,u=r.dtype,s=n<0?a+n:n;if(s<0||s>=a)throw new Error(`axis ${n} is out of bounds for array of dimension ${a}`);let i=t.shape,c=e.shape;if(i.length!==a||c.length!==a)throw new Error("indices, arr, and values must have same ndim");let f=o[s],p=L(o),l=L(i),y=L(c),m=i.reduce((d,g)=>d*g,1);for(let d=0;d<m;d++){let g=new Array(a),h=d;for(let z=a-1;z>=0;z--)g[z]=h%i[z],h=Math.floor(h/i[z]);let A=0;for(let z=0;z<a;z++)A+=g[z]*l[z];let b=Number(t.iget(A));if(b<0&&(b=f+b),b<0||b>=f)throw new Error(`index ${b} is out of bounds for axis ${s} with size ${f}`);let S=0;for(let z=0;z<a;z++){let B=c[z]===1?0:g[z];S+=B*y[z]}let N=e.iget(S),x=[...g];x[s]=b;let I=0;for(let z=0;z<a;z++)I+=x[z]*p[z];w(u)?typeof N!="bigint"&&(N=BigInt(Math.round(Number(N)))):typeof N=="bigint"&&(N=Number(N)),r.iset(I,N)}}function In(r,t,e){let n=r.size,o=r.dtype,a;if(typeof e=="number"||typeof e=="bigint")a=[e];else{a=[];for(let s=0;s<e.size;s++)a.push(e.iget(s))}let u=0;for(let s=0;s<n;s++)if(t.iget(s)){let c=a[u%a.length];w(o)?typeof c!="bigint"&&(c=BigInt(Math.round(Number(c)))):typeof c=="bigint"&&(c=Number(c)),r.iset(s,c),u++}}function zn(r,t,e){let n=t.shape,o=n.length,a=t.dtype,u=t.data,s=w(a);if(e===void 0){let A=0,b=Math.min(r.size,t.size);for(let I=0;I<b;I++)r.iget(I)&&A++;let S=U(a);if(!S)throw new Error(`Cannot compress with dtype ${a}`);let N=new S(A),x=0;for(let I=0;I<b;I++)r.iget(I)&&(N[x]=u[I],x++);return D.fromData(N,[A],a)}let i=e<0?o+e:e;if(i<0||i>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let c=n[i],f=Math.min(r.size,c),p=[];for(let A=0;A<f;A++)r.iget(A)&&p.push(A);let l=p.length,y=[...n];y[i]=l;let m=y.reduce((A,b)=>A*b,1),d=U(a);if(!d)throw new Error(`Cannot compress with dtype ${a}`);let g=new d(m),h=L(n);if(i===0){let A=h[0],b=n.slice(1).reduce((N,x)=>N*x,1),S=0;for(let N=0;N<l;N++){let I=p[N]*A;if(s){let z=u,B=g;for(let E=0;E<b;E++)B[S++]=z[I+E]}else{let z=u,B=g;for(let E=0;E<b;E++)B[S++]=z[I+E]}}}else{let A=n.slice(0,i).reduce((N,x)=>N*x,1),b=n.slice(i+1).reduce((N,x)=>N*x,1),S=0;for(let N=0;N<A;N++)for(let x=0;x<l;x++){let I=p[x],z=0,B=N;for(let E=i-1;E>=0;E--){let T=B%n[E];B=Math.floor(B/n[E]),z+=T*h[E]}if(z+=I*h[i],s){let E=u,T=g;for(let k=0;k<b;k++)T[S++]=E[z+k]}else{let E=u,T=g;for(let k=0;k<b;k++)T[S++]=E[z+k]}}}return D.fromData(g,y,a)}function _n(r,t,e=0){if(r.length!==t.length)throw new Error("condlist and choicelist must have same length");if(r.length===0)throw new Error("condlist and choicelist cannot be empty");let n=[...r.map(l=>Array.from(l.shape)),...t.map(l=>Array.from(l.shape))],o=K(n);if(o===null)throw new Error("condlist and choicelist arrays could not be broadcast together");let a=t[0].dtype,u=o.reduce((l,y)=>l*y,1),s=U(a);if(!s)throw new Error(`Cannot select with dtype ${a}`);let i=e;w(a)?i=typeof e=="bigint"?e:BigInt(e):i=typeof e=="bigint"?Number(e):e;let c=new s(u);for(let l=0;l<u;l++)w(a),c[l]=i;let f=r.map(l=>H(l,o)),p=t.map(l=>H(l,o));for(let l=0;l<u;l++)for(let y=0;y<r.length;y++)if(f[y].iget(l)){let m=p[y].iget(l);w(a),c[l]=m;break}return D.fromData(c,o,a)}function Bn(r,t,e){let n=r.size,o=r.dtype,a=[];for(let s=0;s<e.size;s++)a.push(e.iget(s));if(a.length===0)return;let u=0;for(let s=0;s<n;s++)if(t.iget(s)){let c=a[u%a.length];w(o)?typeof c!="bigint"&&(c=BigInt(Math.round(Number(c)))):typeof c=="bigint"&&(c=Number(c)),r.iset(s,c),u++}}function St(r,t=2){if(t<1)throw new Error("ndim must be at least 1");let e=new Int32Array(r);for(let o=0;o<r;o++)e[o]=o;let n=[];for(let o=0;o<t;o++)n.push(D.fromData(new Int32Array(e),[r],"int32"));return n}function En(r){let t=r.shape,e=t.length;if(e<2)throw new Error("array must be at least 2-D");let n=t[0];for(let o=1;o<e;o++)if(t[o]!==n)throw new Error("All dimensions of input must be equal");return St(n,e)}function Dt(r,t=0,e){let n=e??r,o=[],a=[];for(let u=0;u<r;u++)for(let s=0;s<=Math.min(u+t,n-1);s++)s>=0&&(o.push(u),a.push(s));return[D.fromData(new Int32Array(o),[o.length],"int32"),D.fromData(new Int32Array(a),[a.length],"int32")]}function Un(r,t=0){let e=r.shape;if(e.length!==2)throw new Error("array must be 2-D");return Dt(e[0],t,e[1])}function Nt(r,t=0,e){let n=e??r,o=[],a=[];for(let u=0;u<r;u++)for(let s=Math.max(u+t,0);s<n;s++)o.push(u),a.push(s);return[D.fromData(new Int32Array(o),[o.length],"int32"),D.fromData(new Int32Array(a),[a.length],"int32")]}function Tn(r,t=0){let e=r.shape;if(e.length!==2)throw new Error("array must be 2-D");return Nt(e[0],t,e[1])}function On(r,t,e=0){let n=t(r,e),o=n.shape;if(o.length!==2||o[0]!==r||o[1]!==r)throw new Error("mask_func must return n x n array");let a=[],u=[];for(let s=0;s<r;s++)for(let i=0;i<r;i++)n.get(s,i)&&(a.push(s),u.push(i));return[D.fromData(new Int32Array(a),[a.length],"int32"),D.fromData(new Int32Array(u),[u.length],"int32")]}function $n(r,t="int32"){let e=r.length,n=[e,...r],o=n.reduce((i,c)=>i*c,1),a=U(t);if(!a)throw new Error(`Cannot create indices with dtype ${t}`);let u=new a(o),s=r.reduce((i,c)=>i*c,1);for(let i=0;i<e;i++){let c=i*s;for(let f=0;f<s;f++){let p=new Array(e),l=f;for(let m=e-1;m>=0;m--)p[m]=l%r[m],l=Math.floor(l/r[m]);let y=p[i];t==="int64"?u[c+f]=BigInt(y):u[c+f]=y}}return D.fromData(u,n,t)}function vn(...r){let t=r.length,e=[];for(let n=0;n<t;n++){let o=r[n],a=o.size,u=o.dtype,s=new Array(t).fill(1);s[n]=a;let i=U(u);if(!i)throw new Error(`Cannot create ix_ with dtype ${u}`);let c=new i(a);for(let f=0;f<a;f++){let p=o.iget(f);w(u),c[f]=p}e.push(D.fromData(c,s,u))}return e}function Mn(r,t,e="raise"){if(r.length!==t.length)throw new Error("multi_index length must equal dims length");if(r.length===0)throw new Error("multi_index cannot be empty");let n=r[0].size,o=t.length,a=new Int32Array(n),u=new Array(o),s=1;for(let i=o-1;i>=0;i--)u[i]=s,s*=t[i];for(let i=0;i<n;i++){let c=0;for(let f=0;f<o;f++){let p=Number(r[f].iget(i)),l=t[f];if(e==="wrap")p=(p%l+l)%l;else if(e==="clip")p=Math.max(0,Math.min(p,l-1));else if(p<0||p>=l)throw new Error(`index ${p} is out of bounds for axis ${f} with size ${l}`);c+=p*u[f]}a[i]=c}return D.fromData(a,[n],"int32")}function Cn(r,t,e="C"){let n=t.length,o,a;if(typeof r=="number")o=[r],a=[];else{o=[];for(let f=0;f<r.size;f++)o.push(Number(r.iget(f)));a=Array.from(r.shape)}let u=o.length,s=t.reduce((f,p)=>f*p,1),i=new Array(n);if(e==="C"){let f=1;for(let p=n-1;p>=0;p--)i[p]=f,f*=t[p]}else{let f=1;for(let p=0;p<n;p++)i[p]=f,f*=t[p]}let c=[];for(let f=0;f<n;f++){let p=new Int32Array(u);c.push(D.fromData(p,a.length?a:[1],"int32"))}for(let f=0;f<u;f++){let p=o[f];if(p<0||p>=s)throw new Error(`index ${p} is out of bounds for array with size ${s}`);if(e==="C")for(let l=0;l<n;l++){let y=Math.floor(p/i[l]);p=p%i[l],c[l].data[f]=y%t[l]}else for(let l=n-1;l>=0;l--){let y=Math.floor(p/i[l]);p=p%i[l],c[l].data[f]=y%t[l]}}return typeof r=="number"?c.map(f=>{let p=f.iget(0);return D.fromData(new Int32Array([Number(p)]),[],"int32")}):c}var kn=M(()=>{"use strict";q();R();Xr()});function G(r,t){if(!jt(r)&&r!=="bool")throw new TypeError(`ufunc '${t}' not supported for the input types, and the inputs could not be safely coerced to any supported types`)}function Ar(r,t){return r.isCContiguous&&t.isCContiguous&&r.shape.length===t.shape.length&&r.shape.every((e,n)=>e===t.shape[n])}function Fn(r,t){return G(r.dtype,"bitwise_and"),typeof t=="number"?la(r,t):(G(t.dtype,"bitwise_and"),Ar(r,t)?fa(r,t):P(r,t,(e,n)=>e&n,"bitwise_and"))}function fa(r,t){let e=v(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,u=t.data,s=n.data;if(w(e)){let i=s;if(!w(r.dtype)||!w(t.dtype))for(let f=0;f<o;f++){let p=typeof a[f]=="bigint"?a[f]:BigInt(Math.round(Number(a[f]))),l=typeof u[f]=="bigint"?u[f]:BigInt(Math.round(Number(u[f])));i[f]=p&l}else{let f=a,p=u;for(let l=0;l<o;l++)i[l]=f[l]&p[l]}}else for(let i=0;i<o;i++)s[i]=a[i]&u[i];return n}function la(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]&f}else for(let i=0;i<a;i++)s[i]=o[i]&t;return u}function Rn(r,t){return G(r.dtype,"bitwise_or"),typeof t=="number"?ya(r,t):(G(t.dtype,"bitwise_or"),Ar(r,t)?pa(r,t):P(r,t,(e,n)=>e|n,"bitwise_or"))}function pa(r,t){let e=v(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,u=t.data,s=n.data;if(w(e)){let i=s;if(!w(r.dtype)||!w(t.dtype))for(let f=0;f<o;f++){let p=typeof a[f]=="bigint"?a[f]:BigInt(Math.round(Number(a[f]))),l=typeof u[f]=="bigint"?u[f]:BigInt(Math.round(Number(u[f])));i[f]=p|l}else{let f=a,p=u;for(let l=0;l<o;l++)i[l]=f[l]|p[l]}}else for(let i=0;i<o;i++)s[i]=a[i]|u[i];return n}function ya(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]|f}else for(let i=0;i<a;i++)s[i]=o[i]|t;return u}function Ln(r,t){return G(r.dtype,"bitwise_xor"),typeof t=="number"?da(r,t):(G(t.dtype,"bitwise_xor"),Ar(r,t)?ma(r,t):P(r,t,(e,n)=>e^n,"bitwise_xor"))}function ma(r,t){let e=v(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,u=t.data,s=n.data;if(w(e)){let i=s;if(!w(r.dtype)||!w(t.dtype))for(let f=0;f<o;f++){let p=typeof a[f]=="bigint"?a[f]:BigInt(Math.round(Number(a[f]))),l=typeof u[f]=="bigint"?u[f]:BigInt(Math.round(Number(u[f])));i[f]=p^l}else{let f=a,p=u;for(let l=0;l<o;l++)i[l]=f[l]^p[l]}}else for(let i=0;i<o;i++)s[i]=a[i]^u[i];return n}function da(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]^f}else for(let i=0;i<a;i++)s[i]=o[i]^t;return u}function wt(r){G(r.dtype,"bitwise_not");let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),u=a.data;if(w(t)){let s=n,i=u;for(let c=0;c<o;c++)i[c]=~s[c]}else for(let s=0;s<o;s++)u[s]=~n[s];return a}function qn(r){return wt(r)}function jn(r,t){if(G(r.dtype,"left_shift"),typeof t=="number")return Vn(r,t);if(G(t.dtype,"left_shift"),t.size===1||t.ndim===1&&t.shape[0]===1){let e=w(t.dtype)?Number(t.data[0]):t.data[0];return Vn(r,e)}return Ar(r,t)?ga(r,t):P(r,t,(e,n)=>e<<n,"left_shift")}function ga(r,t){let e=v(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,u=t.data,s=n.data;if(w(e)){let i=s;for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?a[c]:BigInt(Math.round(Number(a[c]))),p=typeof u[c]=="bigint"?u[c]:BigInt(Math.round(Number(u[c])));i[c]=f<<p}}else for(let i=0;i<o;i++)s[i]=a[i]<<u[i];return n}function Vn(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]<<f}else for(let i=0;i<a;i++)s[i]=o[i]<<t;return u}function Zn(r,t){if(G(r.dtype,"right_shift"),typeof t=="number")return Pn(r,t);if(G(t.dtype,"right_shift"),t.size===1||t.ndim===1&&t.shape[0]===1){let e=w(t.dtype)?Number(t.data[0]):t.data[0];return Pn(r,e)}return Ar(r,t)?Aa(r,t):P(r,t,(e,n)=>e>>n,"right_shift")}function Aa(r,t){let e=v(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,u=t.data,s=n.data;if(w(e)){let i=s;for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?a[c]:BigInt(Math.round(Number(a[c]))),p=typeof u[c]=="bigint"?u[c]:BigInt(Math.round(Number(u[c])));i[c]=f>>p}}else for(let i=0;i<o;i++)s[i]=a[i]>>u[i];return n}function Pn(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=D.zeros(n,e),s=u.data;if(w(e)){let i=o,c=s,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=i[p]>>f}else for(let i=0;i<a;i++)s[i]=o[i]>>t;return u}function Wn(r,t=-1,e="big"){let n=Array.from(r.shape),o=n.length;if(t<0&&(t=o+t),t<0||t>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let a=n[t],u=Math.ceil(a/8),s=[...n];s[t]=u;let i=D.zeros(s,"uint8"),c=i.data;if(o===1){for(let g=0;g<u;g++){let h=0;for(let A=0;A<8;A++){let b=g*8+A;if(b<a){let S=Number(r.data[b])!==0?1:0;e==="big"?h|=S<<7-A:h|=S<<A}}c[g]=h}return i}let f=n.slice(0,t),p=n.slice(t+1),l=f.reduce((g,h)=>g*h,1),y=p.reduce((g,h)=>g*h,1),m=kr(n),d=kr(s);for(let g=0;g<l;g++)for(let h=0;h<y;h++)for(let A=0;A<u;A++){let b=0;for(let I=0;I<8;I++){let z=A*8+I;if(z<a){let B=0,E=g;for(let F=0;F<t;F++){let Y=F<t-1?f.slice(F+1).reduce((Zr,Wr)=>Zr*Wr,1):1,tr=Math.floor(E/Y);E%=Y,B+=tr*m[F]}B+=z*m[t];let T=h;for(let F=t+1;F<o;F++){let Y=F<o-1?p.slice(F-t).reduce((Zr,Wr)=>Zr*Wr,1):1,tr=Math.floor(T/Y);T%=Y,B+=tr*m[F]}let k=Number(r.data[B])!==0?1:0;e==="big"?b|=k<<7-I:b|=k<<I}}let S=0,N=g;for(let I=0;I<t;I++){let z=I<t-1?f.slice(I+1).reduce((E,T)=>E*T,1):1,B=Math.floor(N/z);N%=z,S+=B*d[I]}S+=A*d[t];let x=h;for(let I=t+1;I<o;I++){let z=I<o-1?p.slice(I-t).reduce((E,T)=>E*T,1):1,B=Math.floor(x/z);x%=z,S+=B*d[I]}c[S]=b}return i}function Gn(r,t=-1,e=-1,n="big"){if(r.dtype!=="uint8")throw new TypeError("Expected an input array of unsigned byte data type");let o=Array.from(r.shape),a=o.length;if(t<0&&(t=a+t),t<0||t>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let u=o[t],s=u*8;e>=0&&(s=e);let i=[...o];i[t]=s;let c=D.zeros(i,"uint8"),f=c.data;if(a===1){for(let h=0;h<u;h++){let A=Number(r.data[h]);for(let b=0;b<8;b++){let S=h*8+b;if(S>=s)break;n==="big"?f[S]=A>>7-b&1:f[S]=A>>b&1}}return c}let p=o.slice(0,t),l=o.slice(t+1),y=p.reduce((h,A)=>h*A,1),m=l.reduce((h,A)=>h*A,1),d=kr(o),g=kr(i);for(let h=0;h<y;h++)for(let A=0;A<m;A++)for(let b=0;b<u;b++){let S=0,N=h;for(let z=0;z<t;z++){let B=z<t-1?p.slice(z+1).reduce((T,k)=>T*k,1):1,E=Math.floor(N/B);N%=B,S+=E*d[z]}S+=b*d[t];let x=A;for(let z=t+1;z<a;z++){let B=z<a-1?l.slice(z-t).reduce((T,k)=>T*k,1):1,E=Math.floor(x/B);x%=B,S+=E*d[z]}let I=Number(r.data[S]);for(let z=0;z<8;z++){let B=b*8+z;if(B>=s)break;let E=0;N=h;for(let T=0;T<t;T++){let k=T<t-1?p.slice(T+1).reduce((Y,tr)=>Y*tr,1):1,F=Math.floor(N/k);N%=k,E+=F*g[T]}E+=B*g[t],x=A;for(let T=t+1;T<a;T++){let k=T<a-1?l.slice(T-t).reduce((Y,tr)=>Y*tr,1):1,F=Math.floor(x/k);x%=k,E+=F*g[T]}n==="big"?f[E]=I>>7-z&1:f[E]=I>>z&1}}return c}function kr(r){let t=r.length,e=new Array(t),n=1;for(let o=t-1;o>=0;o--)e[o]=n,n*=r[o];return e}var Hn=M(()=>{"use strict";q();R();er()});function J(r,t=C){let e=D.zeros(r,t);return new _(e)}function Yn(r,t=C){let e=D.ones(r,t);return new _(e)}function ba(r){let t=[],e=r;for(;Array.isArray(e);)t.push(e.length),e=e[0];return t}function Jn(r){return typeof r=="bigint"?!0:Array.isArray(r)?r.some(t=>Jn(t)):!1}function Sa(r){let t=[];function e(n){Array.isArray(n)?n.forEach(o=>e(o)):t.push(n)}return e(r),t}function j(r,t){if(r instanceof _)return!t||r.dtype===t?r.copy():r.astype(t);let e=Jn(r),n=ba(r),o=n.reduce((f,p)=>f*p,1),a=t;a||(e?a="int64":a=C);let u=U(a);if(!u)throw new Error(`Cannot create array with dtype ${a}`);let s=new u(o),i=Sa(r);if(w(a)){let f=s;for(let p=0;p<o;p++){let l=i[p];f[p]=typeof l=="bigint"?l:BigInt(Math.round(Number(l)))}}else if(a==="bool"){let f=s;for(let p=0;p<o;p++)f[p]=i[p]?1:0}else{let f=s;for(let p=0;p<o;p++){let l=i[p];f[p]=Number(l)}}let c=D.fromData(s,n,a);return new _(c)}function Da(r,t,e=1,n=C){let o=r,a=t;if(t===void 0&&(o=0,a=r),a===void 0)throw new Error("stop is required");let u=Math.max(0,Math.ceil((a-o)/e)),s=U(n);if(!s)throw new Error(`Cannot create arange array with dtype ${n}`);let i=new s(u);if(w(n))for(let f=0;f<u;f++)i[f]=BigInt(Math.round(o+f*e));else if(n==="bool")for(let f=0;f<u;f++)i[f]=o+f*e!==0?1:0;else for(let f=0;f<u;f++)i[f]=o+f*e;let c=D.fromData(i,[u],n);return new _(c)}function Na(r,t,e=50,n=C){if(e<0)throw new Error("num must be non-negative");if(e===0)return j([],n);if(e===1)return j([r],n);let o=U(n);if(!o)throw new Error(`Cannot create linspace array with dtype ${n}`);let a=new o(e),u=(t-r)/(e-1);if(w(n))for(let i=0;i<e;i++)a[i]=BigInt(Math.round(r+i*u));else if(n==="bool")for(let i=0;i<e;i++)a[i]=r+i*u!==0?1:0;else for(let i=0;i<e;i++)a[i]=r+i*u;let s=D.fromData(a,[e],n);return new _(s)}function wa(r,t,e=50,n=10,o=C){if(e<0)throw new Error("num must be non-negative");if(e===0)return j([],o);if(e===1)return j([Math.pow(n,r)],o);let a=U(o);if(!a)throw new Error(`Cannot create logspace array with dtype ${o}`);let u=new a(e),s=(t-r)/(e-1);if(w(o))for(let c=0;c<e;c++){let f=r+c*s;u[c]=BigInt(Math.round(Math.pow(n,f)))}else if(o==="bool")for(let c=0;c<e;c++){let f=r+c*s;u[c]=Math.pow(n,f)!==0?1:0}else for(let c=0;c<e;c++){let f=r+c*s;u[c]=Math.pow(n,f)}let i=D.fromData(u,[e],o);return new _(i)}function xa(r,t,e=50,n=C){if(e<0)throw new Error("num must be non-negative");if(r===0||t===0)throw new Error("Geometric sequence cannot include zero");if(e===0)return j([],n);if(e===1)return j([r],n);let o=Math.sign(r),a=Math.sign(t);if(o!==a)throw new Error("Geometric sequence cannot contain both positive and negative values");let u=U(n);if(!u)throw new Error(`Cannot create geomspace array with dtype ${n}`);let s=new u(e),i=Math.log(Math.abs(r)),f=(Math.log(Math.abs(t))-i)/(e-1);if(w(n))for(let l=0;l<e;l++){let y=o*Math.exp(i+l*f);s[l]=BigInt(Math.round(y))}else if(n==="bool")for(let l=0;l<e;l++){let y=o*Math.exp(i+l*f);s[l]=y!==0?1:0}else for(let l=0;l<e;l++){let y=o*Math.exp(i+l*f);s[l]=y}let p=D.fromData(s,[e],n);return new _(p)}function Xn(r,t,e=0,n=C){let o=t??r,a=J([r,o],n),u=a.data;if(w(n)){let s=u;for(let i=0;i<r;i++){let c=i+e;c>=0&&c<o&&(s[i*o+c]=BigInt(1))}}else{let s=u;for(let i=0;i<r;i++){let c=i+e;c>=0&&c<o&&(s[i*o+c]=1)}}return a}function Qn(r,t=C){return J(r,t)}function Kn(r,t,e){let n=e;n||(typeof t=="bigint"?n="int64":typeof t=="boolean"?n="bool":Number.isInteger(t)?n="int32":n=C);let o=U(n);if(!o)throw new Error(`Cannot create full array with dtype ${n}`);let a=r.reduce((i,c)=>i*c,1),u=new o(a);if(w(n)){let i=typeof t=="bigint"?t:BigInt(Math.round(Number(t)));u.fill(i)}else n==="bool"?u.fill(t?1:0):u.fill(Number(t));let s=D.fromData(u,r,n);return new _(s)}function Ia(r,t=C){return Xn(r,r,0,t)}function Vr(r,t){return r instanceof _?!t||r.dtype===t?r:r.astype(t):j(r,t)}function za(r){return r.copy()}function _a(r,t){return J(Array.from(r.shape),t??r.dtype)}function Ba(r,t){return Yn(Array.from(r.shape),t??r.dtype)}function Ea(r,t){return Qn(Array.from(r.shape),t??r.dtype)}function Ua(r,t,e){return Kn(Array.from(r.shape),t,e??r.dtype)}function Ta(r,t){return Vr(r,t)}function Oa(r,t){let e=Vr(r,t);return e.flags.C_CONTIGUOUS?e:e.copy()}function $a(r,t){return Vr(r,t).copy()}function ro(r,t=0){if(r.ndim===1){let e=r.size,n=e+Math.abs(t),o=J([n,n],r.dtype);for(let a=0;a<e;a++){let u=t>=0?a:a-t,s=t>=0?a+t:a;o.set([u,s],r.get([a]))}return o}else if(r.ndim===2){let[e,n]=r.shape,o,a,u;if(t>=0?(o=0,a=t,u=Math.min(e,n-t)):(o=-t,a=0,u=Math.min(e+t,n)),u<=0)return J([0],r.dtype);let s=U(r.dtype),i=new s(u);for(let f=0;f<u;f++){let p=r.get([o+f,a+f]);w(r.dtype)?i[f]=typeof p=="bigint"?p:BigInt(p):i[f]=p}let c=D.fromData(i,[u],r.dtype);return new _(c)}else throw new Error("Input must be 1-D or 2-D")}function va(r,t=0){let e=r.flatten();return ro(e,t)}function Ma(r,t,e=C){let n=t.reduce((c,f)=>c*f,1),o=U(e);if(!o)throw new Error(`Cannot create array with dtype ${e}`);let a=new o(n),u=t.length,s=new Array(u).fill(0);for(let c=0;c<n;c++){let f=r(...s);w(e)?a[c]=typeof f=="bigint"?f:BigInt(Number(f)):e==="bool"?a[c]=f?1:0:a[c]=Number(f);for(let p=u-1;p>=0&&(s[p]++,!(s[p]<t[p]));p--)s[p]=0}let i=D.fromData(a,t,e);return new _(i)}function Ca(...r){let t=[],e="xy";for(let s of r)s instanceof _?t.push(s):typeof s=="object"&&"indexing"in s&&(e=s.indexing||"xy");if(t.length===0)return[];if(t.length===1)return[t[0].copy()];let n=t.map(s=>s.size);e==="xy"&&t.length>=2&&(t=[t[1],t[0],...t.slice(2)],[n[0],n[1]]=[n[1],n[0]]);let o=n,a=o.length,u=[];for(let s=0;s<t.length;s++){let i=t[s],c=i.size,f=new Array(a).fill(1);f[s]=c;let p=i.reshape(...f),l=bt(p.storage,o),y=_._fromStorage(l.copy());u.push(y)}return e==="xy"&&u.length>=2&&([u[0],u[1]]=[u[1],u[0]]),u}function ka(r,t,e=0,n=C){let o=t??r,a=J([r,o],n);for(let u=0;u<r;u++)for(let s=0;s<=u+e&&s<o;s++)s>=0&&a.set([u,s],1);return a}function Va(r,t=0){if(r.ndim<2)throw new Error("Input must have at least 2 dimensions");let e=r.copy(),n=e.shape,o=n[n.length-2],a=n[n.length-1],u=n.slice(0,-2).reduce((s,i)=>s*i,1);for(let s=0;s<u;s++)for(let i=0;i<o;i++)for(let c=0;c<a;c++)if(c>i+t){let f=[],p=s;for(let l=n.length-3;l>=0;l--)f.unshift(p%n[l]),p=Math.floor(p/n[l]);f.push(i,c),e.set(f,0)}return e}function Pa(r,t=0){if(r.ndim<2)throw new Error("Input must have at least 2 dimensions");let e=r.copy(),n=e.shape,o=n[n.length-2],a=n[n.length-1],u=n.slice(0,-2).reduce((s,i)=>s*i,1);for(let s=0;s<u;s++)for(let i=0;i<o;i++)for(let c=0;c<a;c++)if(c<i+t){let f=[],p=s;for(let l=n.length-3;l>=0;l--)f.unshift(p%n[l]),p=Math.floor(p/n[l]);f.push(i,c),e.set(f,0)}return e}function Fa(r,t,e=!1){if(r.ndim!==1)throw new Error("Input must be 1-D");let n=r.size,o=t??n;if(o<0)throw new Error("N must be non-negative");let a=J([n,o],r.dtype);for(let u=0;u<n;u++){let s=r.get([u]);for(let i=0;i<o;i++){let c=e?i:o-1-i;a.set([u,i],Math.pow(s,c))}}return a}function Ra(r,t=C,e=-1,n=0){let o,a=n;r instanceof ArrayBuffer?o=r:(o=r.buffer,a+=r.byteOffset);let u=Za(t),s=o.byteLength-a,i=Math.floor(s/u),c=e<0?i:Math.min(e,i);if(c<=0)return j([],t);let f=U(t);if(!f)throw new Error(`Unsupported dtype: ${t}`);let p=new f(o,a,c),l=D.fromData(p,[c],t);return new _(l)}function La(r,t=C,e=-1){let n=[],o=0;for(let a of r){if(e>=0&&o>=e)break;n.push(a),o++}return j(n,t)}function qa(r,t=C,e=-1){let n=[],o=0;for(let a of r){if(e>=0&&o>=e)break;n.push(a),o++}return j(n,t)}function ja(r,t=C,e=-1,n=""){let o;n===""?o=r.trim().split(/\s+/):o=r.split(n);let a=[],u=0;for(let s of o){if(e>=0&&u>=e)break;let i=s.trim();i!==""&&(w(t)?a.push(BigInt(i)):a.push(parseFloat(i)),u++)}return j(a,t)}function Za(r){switch(r){case"int8":case"uint8":case"bool":return 1;case"int16":case"uint16":return 2;case"int32":case"uint32":case"float32":return 4;case"int64":case"uint64":case"float64":return 8;default:return 8}}function Wa(r){return r.sqrt()}function Ga(r,t){return r.power(t)}function Ha(r){return r.absolute()}function Ya(r){return r.negative()}function Ja(r){return r.sign()}function Xa(r,t){return r.mod(t)}function Qa(r,t){return r.floor_divide(t)}function Ka(r){return r.positive()}function rs(r){return r.reciprocal()}function ts(r,t){return r.dot(t)}function es(r){return r.trace()}function ns(r,t=0,e=0,n=1){let o=We(r.storage,t,e,n);return _._fromStorage(o)}function os(r,t){let e=He(r.storage,t.storage);return _._fromStorage(e)}function as(r,t){return r.transpose(t)}function ss(r,t){return r.inner(t)}function is(r,t){return r.outer(t)}function us(r,t,e=2){return r.tensordot(t,e)}function cs(r){return r.sin()}function fs(r){return r.cos()}function ls(r){return r.tan()}function ps(r){return r.arcsin()}function ys(r){return r.arccos()}function ms(r){return r.arctan()}function ds(r,t){return r.arctan2(t)}function gs(r,t){return r.hypot(t)}function As(r){return r.degrees()}function hs(r){return r.radians()}function bs(r){return r.radians()}function Ss(r){return r.degrees()}function Ds(r){return r.sinh()}function Ns(r){return r.cosh()}function ws(r){return r.tanh()}function xs(r){return r.arcsinh()}function Is(r){return r.arccosh()}function zs(r){return r.arctanh()}function _s(r,t,e){return r.swapaxes(t,e)}function Bs(r,t,e){return r.moveaxis(t,e)}function ur(r,t=0){if(r.length===0)throw new Error("need at least one array to concatenate");let e=r.map(o=>o.storage),n=nr(e,t);return _._fromStorage(n)}function Es(r,t=0){if(r.length===0)throw new Error("need at least one array to stack");let e=r.map(o=>o.storage),n=Ne(e,t);return _._fromStorage(n)}function to(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=we(t);return _._fromStorage(e)}function Us(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=mt(t);return _._fromStorage(e)}function Ts(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=xe(t);return _._fromStorage(e)}function Os(r,t,e=0){return Ie(r.storage,t,e).map(o=>_._fromStorage(o,r.base??r))}function $s(r,t,e=0){return gr(r.storage,t,e).map(o=>_._fromStorage(o,r.base??r))}function vs(r,t){return _e(r.storage,t).map(n=>_._fromStorage(n,r.base??r))}function Ms(r,t){return Be(r.storage,t).map(n=>_._fromStorage(n,r.base??r))}function Cs(r,t){let e=Ee(r.storage,t);return _._fromStorage(e)}function ks(r,t,e){return r.repeat(t,e)}function Vs(r){return r.ravel()}function Ps(r,t){return r.reshape(...t)}function Fs(r,t){return r.squeeze(t)}function Rs(r,t){return r.expand_dims(t)}function xt(r,t){let e=Te(r.storage,t);return _._fromStorage(e)}function Ls(r){if(r.ndim<2)throw new Error("Input must be at least 2-D");return xt(r,1)}function qs(r){if(r.ndim<2)throw new Error("Input must be at least 2-D");return xt(r,0)}function js(r,t=1,e=[0,1]){let n=Oe(r.storage,t,e);return _._fromStorage(n)}function Zs(r,t,e){let n=$e(r.storage,t,e);return _._fromStorage(n)}function Ws(r,t,e=0){let n=ve(r.storage,t,e);return _._fromStorage(n,r.base??r)}function Gs(...r){let t=r.map(o=>o.storage),n=Ve(t).map((o,a)=>o===t[a]?r[a]:_._fromStorage(o));return n.length===1?n[0]:n}function Hs(...r){let t=r.map(o=>o.storage),n=Pe(t).map((o,a)=>o===t[a]?r[a]:_._fromStorage(o));return n.length===1?n[0]:n}function Ys(...r){let t=r.map(o=>o.storage),n=Fe(t).map((o,a)=>o===t[a]?r[a]:_._fromStorage(o));return n.length===1?n[0]:n}function Js(r,t){return Me(r.storage,t).map(n=>_._fromStorage(n,r.base??r))}function Xs(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=Ce(t);return _._fromStorage(e)}function Qs(r){return to(r)}function Ks(r,t){let e=ke(r.storage,t);return _._fromStorage(e)}function ri(r,t,e){let n=t instanceof _?t:j(t,r.dtype);if(e===void 0){let o=r.flatten(),a=n.flatten();return ur([o,a])}return ur([r,n],e)}function ti(r,t,e){let n=r.dtype;if(e===void 0){let y=r.flatten(),d=(Array.isArray(t)?t:[t]).map(S=>S<0?y.size+S:S),g=[];for(let S=0;S<y.size;S++)d.includes(S)||g.push(S);let h=U(n),A=new h(g.length);for(let S=0;S<g.length;S++){let N=y.get([g[S]]);w(n)?A[S]=typeof N=="bigint"?N:BigInt(N):A[S]=N}let b=D.fromData(A,[g.length],n);return new _(b)}let o=r.shape,a=o.length,u=e<0?a+e:e;if(u<0||u>=a)throw new Error(`axis ${e} is out of bounds for array of dimension ${a}`);let s=o[u],i=Array.isArray(t)?t:[t],c=new Set(i.map(y=>y<0?s+y:y)),f=[],p=0;for(let y=0;y<=s;y++)(c.has(y)||y===s)&&(y>p&&f.push([p,y]),p=y+1);if(f.length===0){let y=[...o];return y[u]=0,J(y,n)}let l=[];for(let[y,m]of f){let d=o.map(()=>":");d[u]=`${y}:${m}`,l.push(r.slice(...d))}return ur(l,u)}function ei(r,t,e,n){let o=e instanceof _?e:j(e,r.dtype);if(n===void 0){let p=r.flatten(),l=o.flatten(),y=t<0?p.size+t:t;if(y<0||y>p.size)throw new Error(`index ${t} is out of bounds for array of size ${p.size}`);let m=y>0?p.slice(`0:${y}`):null,d=y<p.size?p.slice(`${y}:`):null,g=[];return m&&g.push(m),g.push(l),d&&g.push(d),ur(g)}let a=r.shape,u=a.length,s=n<0?u+n:n;if(s<0||s>=u)throw new Error(`axis ${n} is out of bounds for array of dimension ${u}`);let i=a[s],c=t<0?i+t:t;if(c<0||c>i)throw new Error(`index ${t} is out of bounds for axis ${n} with size ${i}`);let f=[];if(c>0){let p=a.map(()=>":");p[s]=`0:${c}`,f.push(r.slice(...p))}if(f.push(o),c<i){let p=a.map(()=>":");p[s]=`${c}:`,f.push(r.slice(...p))}return ur(f,s)}function ni(r,t,e="constant",n=0){let o=r.shape,a=o.length,u=r.dtype,s;if(typeof t=="number"?s=o.map(()=>[t,t]):Array.isArray(t)&&typeof t[0]=="number"?s=o.map(()=>t):s=t,s.length!==a)throw new Error(`pad_width must have ${a} elements`);let i=o.map((d,g)=>d+s[g][0]+s[g][1]),c=i.reduce((d,g)=>d*g,1),f=U(u),p=new f(c),l=w(u);e==="constant"&&(l?p.fill(BigInt(n)):p.fill(n));let y=new Array(a).fill(0);for(let d=0;d<c;d++){let g=!0,h=[];for(let b=0;b<a;b++){let[S]=s[b],N=y[b]-S;if(N<0||N>=o[b]){g=!1;break}h.push(N)}let A;if(g)A=r.get(h);else if(e==="constant"){for(let b=a-1;b>=0&&(y[b]++,!(y[b]<i[b]));b--)y[b]=0;continue}else{let b=[];for(let S=0;S<a;S++){let[N]=s[S],x=y[S]-N,I=o[S];x<0?e==="edge"?x=0:e==="reflect"?(x=-x,x>=I&&(x=I-1)):e==="symmetric"?(x=-x-1,x>=I&&(x=I-1),x<0&&(x=0)):e==="wrap"&&(x=(x%I+I)%I):x>=I&&(e==="edge"?x=I-1:e==="reflect"?(x=2*I-x-2,x<0&&(x=0)):e==="symmetric"?(x=2*I-x-1,x<0&&(x=0)):e==="wrap"&&(x=x%I)),b.push(Math.max(0,Math.min(I-1,x)))}A=r.get(b)}l?p[d]=typeof A=="bigint"?A:BigInt(Number(A)):p[d]=Number(A);for(let b=a-1;b>=0&&(y[b]++,!(y[b]<i[b]));b--)y[b]=0}let m=D.fromData(p,i,u);return new _(m)}function oi(r,t){let e=bt(r.storage,t);return _._fromStorage(e,r.base??r)}function ai(...r){let t=r.map(n=>n.storage);return hn(t).map((n,o)=>_._fromStorage(n,r[o].base??r[o]))}function si(...r){return Jr(...r)}function ii(r,t,e){return r.take(t,e)}function ui(r,t,e){r.put(t,e)}function ci(r,t){let e=t.map(o=>o.storage),n=Dn(r.storage,e);return _._fromStorage(n)}function fi(r,t,e=!1){return Nn(r.storage,t.storage,e)}function li(r,t){return de(r.storage,t.storage)}function pi(r,t){return _._fromStorage(at(r.storage,t))}function yi(r,t){return _._fromStorage(st(r.storage,t))}function mi(r,t,e=!1){let n=it(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function di(r,t,e=!1){let n=ut(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function gi(r,t,e,n=!1){let o=ct(r.storage,t,e,n);return typeof o=="number"?o:_._fromStorage(o)}function Ai(r,t,e,n=!1){let o=ir(r.storage,t,e,n);return typeof o=="number"?o:_._fromStorage(o)}function hi(r,t,e,n=!1){let o=e?e.storage:void 0,a=_r(r.storage,t,o,n);return typeof a=="number"?a:_._fromStorage(a)}function bi(r,t,e=!1){let n=Br(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function Si(r,t,e=!1){let n=Er(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function Di(r,t,e=!1){let n=Ur(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function Ni(r,t,e=0,n=!1){let o=pr(r.storage,t,e,n);return typeof o=="number"?o:_._fromStorage(o)}function wi(r,t,e=0,n=!1){let o=ft(r.storage,t,e,n);return typeof o=="number"?o:_._fromStorage(o)}function xi(r,t,e=!1){let n=Tr(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function Ii(r,t,e=!1){let n=Or(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function zi(r,t){let e=$r(r.storage,t);return typeof e=="number"?e:_._fromStorage(e)}function _i(r,t){let e=vr(r.storage,t);return typeof e=="number"?e:_._fromStorage(e)}function Bi(r,t){return _._fromStorage(lt(r.storage,t))}function Ei(r,t){return _._fromStorage(pt(r.storage,t))}function Ui(r,t,e=!1){let n=Mr(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function Ti(r){return r.cbrt()}function Oi(r){return r.fabs()}function $i(r,t){return r.divmod(t)}function vi(r){return r.square()}function Mi(r,t){return r.remainder(t)}function Ci(r,t){return r.heaviside(t)}function ki(r,t){return r.bitwise_and(t)}function Vi(r,t){return r.bitwise_or(t)}function Pi(r,t){return r.bitwise_xor(t)}function Fi(r){return r.bitwise_not()}function Ri(r){return r.invert()}function Li(r,t){return r.left_shift(t)}function qi(r,t){return r.right_shift(t)}function ji(r,t=-1,e="big"){let n=Wn(r.storage,t,e);return _._fromStorage(n)}function Zi(r,t=-1,e=-1,n="big"){let o=Gn(r.storage,t,e,n);return _._fromStorage(o)}function Wi(r,...t){let e=t.map(o=>o.storage),n=Ge(r,...e);return typeof n=="number"||typeof n=="bigint"?n:_._fromStorage(n)}function Gi(r,t,e){return _._fromStorage(wn(r.storage,t.storage,e))}function Hi(r,t,e,n){xn(r.storage,t.storage,e.storage,n)}function Yi(r,t,e){let n=e instanceof _?e.storage:e;In(r.storage,t.storage,n)}function Ji(r,t,e){return _._fromStorage(zn(r.storage,t.storage,e))}function Xi(r,t,e=0){let n=r.map(a=>a.storage),o=t.map(a=>a.storage);return _._fromStorage(_n(n,o,e))}function Qi(r,t,e){Bn(r.storage,t.storage,e.storage)}function Ki(r,t=2){return St(r,t).map(n=>_._fromStorage(n))}function ru(r){return En(r.storage).map(e=>_._fromStorage(e))}function tu(r,t=0,e){return Dt(r,t,e).map(o=>_._fromStorage(o))}function eu(r,t=0){return Un(r.storage,t).map(n=>_._fromStorage(n))}function nu(r,t=0,e){return Nt(r,t,e).map(o=>_._fromStorage(o))}function ou(r,t=0){return Tn(r.storage,t).map(n=>_._fromStorage(n))}function au(r,t,e=0){return On(r,(a,u)=>t(a,u).storage,e).map(a=>_._fromStorage(a))}function su(r,t="int32"){return _._fromStorage($n(r,t))}function iu(...r){return vn(...r.map(e=>e.storage)).map(e=>_._fromStorage(e))}function uu(r,t,e="raise"){let n=r.map(o=>o.storage);return _._fromStorage(Mn(n,t,e))}function cu(r,t,e="C"){let n=r instanceof _?r.storage:r;return Cn(n,t,e).map(a=>_._fromStorage(a))}var _,It=M(()=>{"use strict";Rt();R();q();ie();ge();be();dt();Ye();Qe();fn();An();kn();Hn();_=class r{constructor(t,e){this._storage=t,this._base=e}get storage(){return this._storage}static _fromStorage(t,e){return new r(t,e)}get shape(){return this._storage.shape}get ndim(){return this._storage.ndim}get size(){return this._storage.size}get dtype(){return this._storage.dtype}get data(){return this._storage.data}get strides(){return this._storage.strides}get flags(){return{C_CONTIGUOUS:this._storage.isCContiguous,F_CONTIGUOUS:this._storage.isFContiguous,OWNDATA:this._base===void 0}}get base(){return this._base??null}get(t){if(t.length!==this.ndim)throw new Error(`Index has ${t.length} dimensions, but array has ${this.ndim} dimensions`);let e=t.map((n,o)=>{let a=n;if(a<0&&(a=this.shape[o]+a),a<0||a>=this.shape[o])throw new Error(`Index ${n} is out of bounds for axis ${o} with size ${this.shape[o]}`);return a});return this._storage.get(...e)}set(t,e){if(t.length!==this.ndim)throw new Error(`Index has ${t.length} dimensions, but array has ${this.ndim} dimensions`);let n=t.map((u,s)=>{let i=u;if(i<0&&(i=this.shape[s]+i),i<0||i>=this.shape[s])throw new Error(`Index ${u} is out of bounds for axis ${s} with size ${this.shape[s]}`);return i}),o=this.dtype,a;w(o)?a=typeof e=="bigint"?e:BigInt(Math.round(e)):o==="bool"?a=e?1:0:a=Number(e),this._storage.set(n,a)}copy(){return new r(this._storage.copy())}astype(t,e=!0){let n=this.dtype;if(n===t&&!e)return this;if(n===t&&e)return this.copy();let o=Array.from(this.shape),a=this.size,u=U(t);if(!u)throw new Error(`Cannot convert to dtype ${t}`);let s=new u(a),i=this.data;if(w(n)&&!w(t)){let f=i;if(t==="bool")for(let p=0;p<a;p++)s[p]=f[p]!==BigInt(0)?1:0;else for(let p=0;p<a;p++)s[p]=Number(f[p])}else if(!w(n)&&w(t)){let f=i;for(let p=0;p<a;p++)s[p]=BigInt(Math.round(Number(f[p])))}else if(t==="bool"){let f=i;for(let p=0;p<a;p++)s[p]=f[p]!==0?1:0}else if(n==="bool"&&!w(t)){let f=i;for(let p=0;p<a;p++)s[p]=f[p]}else if(!w(n)&&!w(t)){let f=i;for(let p=0;p<a;p++)s[p]=f[p]}else{let f=i;for(let p=0;p<a;p++)s[p]=f[p]}let c=D.fromData(s,o,t);return new r(c)}add(t){let e=typeof t=="number"?t:t._storage,n=Wt(this._storage,e);return r._fromStorage(n)}subtract(t){let e=typeof t=="number"?t:t._storage,n=Gt(this._storage,e);return r._fromStorage(n)}multiply(t){let e=typeof t=="number"?t:t._storage,n=Ht(this._storage,e);return r._fromStorage(n)}divide(t){let e=typeof t=="number"?t:t._storage,n=Yt(this._storage,e);return r._fromStorage(n)}mod(t){let e=typeof t=="number"?t:t._storage,n=wr(this._storage,e);return r._fromStorage(n)}floor_divide(t){let e=typeof t=="number"?t:t._storage,n=Yr(this._storage,e);return r._fromStorage(n)}positive(){let t=Kt(this._storage);return r._fromStorage(t)}reciprocal(){let t=re(this._storage);return r._fromStorage(t)}sqrt(){let t=Je(this._storage);return r._fromStorage(t)}power(t){let e=typeof t=="number"?t:t._storage,n=Xe(this._storage,e);return r._fromStorage(n)}absolute(){let t=Jt(this._storage);return r._fromStorage(t)}negative(){let t=Xt(this._storage);return r._fromStorage(t)}sign(){let t=Qt(this._storage);return r._fromStorage(t)}sin(){let t=Ke(this._storage);return r._fromStorage(t)}cos(){let t=rn(this._storage);return r._fromStorage(t)}tan(){let t=tn(this._storage);return r._fromStorage(t)}arcsin(){let t=en(this._storage);return r._fromStorage(t)}arccos(){let t=nn(this._storage);return r._fromStorage(t)}arctan(){let t=on(this._storage);return r._fromStorage(t)}arctan2(t){let e=typeof t=="number"?t:t._storage,n=an(this._storage,e);return r._fromStorage(n)}hypot(t){let e=typeof t=="number"?t:t._storage,n=sn(this._storage,e);return r._fromStorage(n)}degrees(){let t=un(this._storage);return r._fromStorage(t)}radians(){let t=cn(this._storage);return r._fromStorage(t)}sinh(){let t=ln(this._storage);return r._fromStorage(t)}cosh(){let t=pn(this._storage);return r._fromStorage(t)}tanh(){let t=yn(this._storage);return r._fromStorage(t)}arcsinh(){let t=mn(this._storage);return r._fromStorage(t)}arccosh(){let t=dn(this._storage);return r._fromStorage(t)}arctanh(){let t=gn(this._storage);return r._fromStorage(t)}greater(t){let e=typeof t=="number"?t:t._storage,n=ue(this._storage,e);return r._fromStorage(n)}greater_equal(t){let e=typeof t=="number"?t:t._storage,n=ce(this._storage,e);return r._fromStorage(n)}less(t){let e=typeof t=="number"?t:t._storage,n=fe(this._storage,e);return r._fromStorage(n)}less_equal(t){let e=typeof t=="number"?t:t._storage,n=le(this._storage,e);return r._fromStorage(n)}equal(t){let e=typeof t=="number"?t:t._storage,n=pe(this._storage,e);return r._fromStorage(n)}not_equal(t){let e=typeof t=="number"?t:t._storage,n=ye(this._storage,e);return r._fromStorage(n)}isclose(t,e=1e-5,n=1e-8){let o=typeof t=="number"?t:t._storage,a=Qr(this._storage,o,e,n);return r._fromStorage(a)}allclose(t,e=1e-5,n=1e-8){let o=typeof t=="number"?t:t._storage;return me(this._storage,o,e,n)}bitwise_and(t){let e=typeof t=="number"?t:t._storage,n=Fn(this._storage,e);return r._fromStorage(n)}bitwise_or(t){let e=typeof t=="number"?t:t._storage,n=Rn(this._storage,e);return r._fromStorage(n)}bitwise_xor(t){let e=typeof t=="number"?t:t._storage,n=Ln(this._storage,e);return r._fromStorage(n)}bitwise_not(){let t=wt(this._storage);return r._fromStorage(t)}invert(){let t=qn(this._storage);return r._fromStorage(t)}left_shift(t){let e=typeof t=="number"?t:t._storage,n=jn(this._storage,e);return r._fromStorage(n)}right_shift(t){let e=typeof t=="number"?t:t._storage,n=Zn(this._storage,e);return r._fromStorage(n)}sum(t,e=!1){let n=lr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}mean(t,e=!1){let n=xr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}max(t,e=!1){let n=Ir(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}min(t,e=!1){let n=zr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}prod(t,e=!1){let n=Kr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}argmin(t){let e=rt(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}argmax(t){let e=tt(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}var(t,e=0,n=!1){let o=et(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}std(t,e=0,n=!1){let o=he(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}all(t,e=!1){let n=nt(this._storage,t,e);return typeof n=="boolean"?n:r._fromStorage(n)}any(t,e=!1){let n=ot(this._storage,t,e);return typeof n=="boolean"?n:r._fromStorage(n)}cumsum(t){return r._fromStorage(at(this._storage,t))}cumprod(t){return r._fromStorage(st(this._storage,t))}ptp(t,e=!1){let n=it(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}median(t,e=!1){let n=ut(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}percentile(t,e,n=!1){let o=ct(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}quantile(t,e,n=!1){let o=ir(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}average(t,e){let n=_r(this._storage,e,t?.storage);return typeof n=="number"?n:r._fromStorage(n)}nansum(t,e=!1){let n=Br(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanprod(t,e=!1){let n=Er(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanmean(t,e=!1){let n=Ur(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanvar(t,e=0,n=!1){let o=pr(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}nanstd(t,e=0,n=!1){let o=ft(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}nanmin(t,e=!1){let n=Tr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanmax(t,e=!1){let n=Or(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanargmin(t){let e=$r(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}nanargmax(t){let e=vr(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}nancumsum(t){return r._fromStorage(lt(this._storage,t))}nancumprod(t){return r._fromStorage(pt(this._storage,t))}nanmedian(t,e=!1){let n=Mr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}reshape(...t){let e=t.length===1&&Array.isArray(t[0])?t[0]:t,n=W(this._storage,e),a=n.data===this.data?this._base??this:void 0;return r._fromStorage(n,a)}flatten(){let t=Cr(this._storage);return r._fromStorage(t)}ravel(){let t=mr(this._storage),n=t.data===this.data?this._base??this:void 0;return r._fromStorage(t,n)}transpose(t){let e=dr(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}squeeze(t){let e=Se(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}expand_dims(t){let e=yr(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}swapaxes(t,e){let n=De(this._storage,t,e),o=this._base??this;return r._fromStorage(n,o)}moveaxis(t,e){let n=yt(this._storage,t,e),o=this._base??this;return r._fromStorage(n,o)}repeat(t,e){let n=Ue(this._storage,t,e);return r._fromStorage(n)}take(t,e){let n=bn(this._storage,t,e);return r._fromStorage(n)}put(t,e){let n=e instanceof r?e._storage:e;Sn(this._storage,t,n)}matmul(t){let e=or(this._storage,t._storage);return r._fromStorage(e)}dot(t){let e=At(this._storage,t._storage);return typeof e=="number"||typeof e=="bigint"?e:r._fromStorage(e)}trace(){return qe(this._storage)}inner(t){let e=je(this._storage,t._storage);return typeof e=="number"||typeof e=="bigint"?e:r._fromStorage(e)}outer(t){let e=ht(this._storage,t._storage);return r._fromStorage(e)}tensordot(t,e=2){let n=Ze(this._storage,t._storage,e);return typeof n=="number"||typeof n=="bigint"?n:r._fromStorage(n)}cbrt(){let t=te(this._storage);return r._fromStorage(t)}fabs(){let t=ee(this._storage);return r._fromStorage(t)}divmod(t){let e=typeof t=="number"?t:t._storage,[n,o]=ne(this._storage,e);return[r._fromStorage(n),r._fromStorage(o)]}square(){let t=oe(this._storage);return r._fromStorage(t)}remainder(t){let e=typeof t=="number"?t:t._storage,n=ae(this._storage,e);return r._fromStorage(n)}heaviside(t){let e=typeof t=="number"?t:t._storage,n=se(this._storage,e);return r._fromStorage(n)}slice(...t){if(t.length===0)return this;if(t.length>this.ndim)throw new Error(`Too many indices for array: array is ${this.ndim}-dimensional, but ${t.length} were indexed`);let e=t.map((i,c)=>{let f=Pt(i);return Ft(f,this.shape[c])});for(;e.length<this.ndim;)e.push({start:0,stop:this.shape[e.length],step:1,isIndex:!1});let n=[],o=[],a=this._storage.offset;for(let i=0;i<e.length;i++){let c=e[i],f=this._storage.strides[i];if(a+=c.start*f,!c.isIndex){let p;c.step>0?p=Math.max(0,Math.ceil((c.stop-c.start)/c.step)):p=Math.max(0,Math.ceil((c.start-c.stop)/Math.abs(c.step))),n.push(p),o.push(f*c.step)}}let u=D.fromData(this._storage.data,n,this._storage.dtype,o,a),s=this._base??this;return new r(u,s)}row(t){if(this.ndim<2)throw new Error("row() requires at least 2 dimensions");return this.slice(String(t),":")}col(t){if(this.ndim<2)throw new Error("col() requires at least 2 dimensions");return this.slice(":",String(t))}rows(t,e){if(this.ndim<2)throw new Error("rows() requires at least 2 dimensions");return this.slice(`${t}:${e}`,":")}cols(t,e){if(this.ndim<2)throw new Error("cols() requires at least 2 dimensions");return this.slice(":",`${t}:${e}`)}toString(){return`NDArray(shape=${JSON.stringify(this.shape)}, dtype=${this.dtype})`}toArray(){if(this.ndim===0)return this._storage.iget(0);let t=this.shape,e=t.length,n=(o,a)=>{if(a===e)return this._storage.get(...o);let u=[];for(let s=0;s<t[a];s++)o[a]=s,u.push(n(o,a+1));return u};return n(new Array(e),0)}}});function _t(){let r=new ArrayBuffer(2);return new DataView(r).setInt16(0,256,!0),new Int16Array(r)[0]===256}function no(r){if(r.startsWith("[")||r.startsWith("("))throw new X(`Structured/compound dtypes are not supported: ${r}`);let t="",e=r;(r[0]==="<"||r[0]===">"||r[0]==="="||r[0]==="|")&&(t=r[0],e=r.slice(1));let n=e[0];if(n&&n in eo)throw new X(`Unsupported dtype: ${eo[n]} (${r}). Use the 'force' parameter to skip arrays with unsupported dtypes.`);let o=fu[e];if(!o)throw new X(`Unknown or unsupported dtype descriptor: ${r}. Supported types: ${zt.join(", ")}. Use the 'force' parameter to skip arrays with unsupported dtypes.`);let a=_t(),u=t==="<"||t==="|"||t==="="&&a,s=t===">"||t==="="&&!a,i=parseInt(e.slice(1),10),c=i>1&&(s&&a||u&&!a);return{dtype:o,needsByteSwap:c,itemsize:i}}var hr,zt,fu,Pr,eo,X,Z,br=M(()=>{"use strict";hr=new Uint8Array([147,78,85,77,80,89]),zt=["float64","float32","int64","int32","int16","int8","uint64","uint32","uint16","uint8","bool"];fu={f8:"float64",f4:"float32",i8:"int64",i4:"int32",i2:"int16",i1:"int8",u8:"uint64",u4:"uint32",u2:"uint16",u1:"uint8",b1:"bool"},Pr={float64:"<f8",float32:"<f4",int64:"<i8",int32:"<i4",int16:"<i2",int8:"|i1",uint64:"<u8",uint32:"<u4",uint16:"<u2",uint8:"|u1",bool:"|b1"},eo={c:"complex numbers",S:"byte strings",U:"Unicode strings",O:"Python objects",V:"structured arrays (void)",M:"datetime64",m:"timedelta64"};X=class extends Error{constructor(t){super(t),this.name="UnsupportedDTypeError"}},Z=class extends Error{constructor(t){super(t),this.name="InvalidNpyError"}}});function ar(r){let t=r instanceof ArrayBuffer?new Uint8Array(r):r,e=Bt(t);return Et(t,e)}function Bt(r){if(r.length<10)throw new Z("File too small to be a valid NPY file");for(let c=0;c<hr.length;c++)if(r[c]!==hr[c])throw new Z("Invalid NPY magic number");let t=r[6],e=r[7];if(t!==1&&t!==2&&t!==3)throw new Z(`Unsupported NPY version: ${t}.${e}`);let n,o;t===1?(n=r[8]|r[9]<<8,o=10):(n=r[8]|r[9]<<8|r[10]<<16|r[11]<<24,o=12);let a=o+n;if(r.length<a)throw new Z("File truncated: header extends beyond file");let u=r.slice(o,a),s=new TextDecoder("utf-8").decode(u).trim(),i=lu(s);return{version:{major:t,minor:e},header:i,dataOffset:a}}function Et(r,t){let{header:e,dataOffset:n}=t,{dtype:o,needsByteSwap:a,itemsize:u}=no(e.descr),s=e.shape.reduce((d,g)=>d*g,1),i=s*u,c=r.length-n;if(c<i)throw new Z(`File truncated: expected ${i} bytes of data, got ${c}`);let f=new ArrayBuffer(i);new Uint8Array(f).set(r.subarray(n,n+i));let l=pu(f,o,s,a,u),y=e.shape,m;if(e.fortran_order&&y.length>1){let d=[...y].reverse(),g=D.fromData(l,d,o);m=yu(g,d),y=e.shape}else m=D.fromData(l,[...y],o);return new _(m)}function lu(r){let t=r.match(/'descr'\s*:\s*'([^']+)'/),e=r.match(/'fortran_order'\s*:\s*(True|False)/),n=r.match(/'shape'\s*:\s*\(([^)]*)\)/);if(!t||!e||!n)throw new Z(`Failed to parse NPY header: ${r}`);let o=t[1],a=e[1]==="True",u=n[1].trim(),s;return u===""?s=[]:s=u.split(",").map(i=>i.trim()).filter(i=>i!=="").map(i=>{let c=parseInt(i,10);if(isNaN(c))throw new Z(`Invalid shape value: ${i}`);return c}),{descr:o,fortran_order:a,shape:s}}function pu(r,t,e,n,o){let a=U(t);if(!a)throw new Z(`Cannot create array for dtype: ${t}`);if(!n)return new a(r,0,e);let u=new Uint8Array(r),s=new Uint8Array(r.byteLength);for(let i=0;i<e;i++){let c=i*o;for(let f=0;f<o;f++)s[c+f]=u[c+o-1-f]}return new a(s.buffer,0,e)}function yu(r,t){let e=t.length,n=r.size,o=r.dtype,a=U(o);if(!a)throw new Z(`Cannot create array for dtype: ${o}`);let u=new a(n),s=[...t].reverse(),i=oo(t),c=oo(s),f=new Array(e).fill(0);for(let p=0;p<n;p++){let l=p;for(let m=0;m<e;m++){let d=i[m];f[m]=Math.floor(l/d),l=l%d}let y=0;for(let m=0;m<e;m++)y+=f[e-1-m]*c[m];w(o),u[y]=r.iget(p)}return D.fromData(u,s,o)}function oo(r){let t=new Array(r.length),e=1;for(let n=r.length-1;n>=0;n--)t[n]=e,e*=r[n];return t}var Fr=M(()=>{"use strict";It();q();R();br()});function rr(r){let t=r.shape,e=r.dtype,n=Pr[e],o=t.length===0?"()":t.length===1?`(${t[0]},)`:`(${t.join(", ")})`,a=`{'descr': '${n}', 'fortran_order': False, 'shape': ${o}, }`,u=12,i=(64-(u+a.length+1)%64)%64;a=a+" ".repeat(i)+`
2
- `;let c=new TextEncoder().encode(a),f=c.length,p=r.size,l=qt(e),y=p*l,m=u+f+y,d=new Uint8Array(m);d.set(hr,0),d[6]=3,d[7]=0,d[8]=f&255,d[9]=f>>8&255,d[10]=f>>16&255,d[11]=f>>24&255,d.set(c,u);let g=u+f;return mu(r,d.subarray(g),l),d}function mu(r,t,e){let n=r.dtype,o=r.size,a=_t(),u=w(n),s=r._storage;if(s.isCContiguous&&s.offset===0&&a){let c=s.data,f=new Uint8Array(c.buffer,c.byteOffset,o*e);t.set(f)}else{let c=new DataView(t.buffer,t.byteOffset,t.byteLength);for(let f=0;f<o;f++){let p=s.iget(f),l=f*e;u?du(c,l,p,n==="uint64"):gu(c,l,p,n)}}}function du(r,t,e,n){n?r.setBigUint64(t,e,!0):r.setBigInt64(t,e,!0)}function gu(r,t,e,n){switch(n){case"float64":r.setFloat64(t,e,!0);break;case"float32":r.setFloat32(t,e,!0);break;case"int32":r.setInt32(t,e,!0);break;case"int16":r.setInt16(t,e,!0);break;case"int8":r.setInt8(t,e);break;case"uint32":r.setUint32(t,e,!0);break;case"uint16":r.setUint16(t,e,!0);break;case"uint8":case"bool":r.setUint8(t,e);break;default:throw new Error(`Unsupported dtype for serialization: ${n}`)}}var Rr=M(()=>{"use strict";R();br()});function Ut(r){let t=4294967295;for(let e=0;e<r.length;e++)t=Au[(t^r[e])&255]^t>>>8;return(t^4294967295)>>>0}var Au,Tt=M(()=>{"use strict";Au=(()=>{let r=new Uint32Array(256);for(let t=0;t<256;t++){let e=t;for(let n=0;n<8;n++)e=e&1?3988292384^e>>>1:e>>>1;r[t]=e}return r})()});async function ao(r){let t=io(r),e=new Map;for(let n of t){let o=await hu(n);e.set(n.name,o)}return e}function so(r){let t=io(r),e=new Map;for(let n of t){if(n.compressionMethod!==0)throw new Error(`Cannot read compressed entry synchronously: ${n.name}. Use readZip() (async) for DEFLATE-compressed files.`);e.set(n.name,n.compressedData)}return e}function io(r){let t=r instanceof ArrayBuffer?new Uint8Array(r):r,e=new DataView(t.buffer,t.byteOffset,t.byteLength),n=[],o=-1;for(let c=t.length-22;c>=0;c--)if(e.getUint32(c,!0)===101010256){o=c;break}if(o===-1)throw new Error("Invalid ZIP file: end of central directory not found");let a=e.getUint32(o+16,!0),u=e.getUint16(o+10,!0),s=[],i=a;for(let c=0;c<u&&e.getUint32(i,!0)===33639248;c++){let p=e.getUint16(i+10,!0),l=e.getUint32(i+16,!0),y=e.getUint32(i+20,!0),m=e.getUint32(i+24,!0),d=e.getUint16(i+28,!0),g=e.getUint16(i+30,!0),h=e.getUint16(i+32,!0),A=e.getUint32(i+42,!0),b=t.slice(i+46,i+46+d),S=new TextDecoder("utf-8").decode(b);s.push({name:S,compressionMethod:p,crc32:l,compressedSize:y,uncompressedSize:m,localHeaderOffset:A}),i=i+46+d+g+h}for(let c of s){let f=c.localHeaderOffset;if(e.getUint32(f,!0)!==67324752)throw new Error(`Invalid local file header at offset ${f}`);let l=e.getUint16(f+26,!0),y=e.getUint16(f+28,!0),m=f+30+l+y,d=t.slice(m,m+c.compressedSize);n.push({name:c.name,compressedData:d,compressionMethod:c.compressionMethod,crc32:c.crc32,compressedSize:c.compressedSize,uncompressedSize:c.uncompressedSize})}return n}async function hu(r){if(r.compressionMethod===0)return r.compressedData;if(r.compressionMethod===8)return await bu(r.compressedData);throw new Error(`Unsupported compression method: ${r.compressionMethod}`)}async function bu(r){if(typeof DecompressionStream>"u")throw new Error("DecompressionStream is not available. This environment does not support the Compression Streams API. Please use a modern browser or Node.js 18+.");let t=new DecompressionStream("deflate-raw"),e=new Uint8Array(r.length);e.set(r);let n=t.writable.getWriter();n.write(e),n.close();let o=t.readable.getReader(),a=[];for(;;){let{done:c,value:f}=await o.read();if(c)break;a.push(f)}let u=a.reduce((c,f)=>c+f.length,0),s=new Uint8Array(u),i=0;for(let c of a)s.set(c,i),i+=c.length;return s}var uo=M(()=>{"use strict";Tt()});var fo={};kt(fo,{loadNpz:()=>vt,loadNpzSync:()=>Mt,parseNpz:()=>fr,parseNpzSync:()=>Lr});async function fr(r,t={}){let e=t.force??!1,n=await ao(r);return co(n,e)}function Lr(r,t={}){let e=t.force??!1,n=so(r);return co(n,e)}function co(r,t){let e=new Map,n=[],o=new Map;for(let[a,u]of r){if(!a.endsWith(".npy"))continue;let s=a.slice(0,-4);try{let i=ar(u);e.set(s,i)}catch(i){if(i instanceof X&&t)n.push(s),o.set(s,i.message);else throw i}}return{arrays:e,skipped:n,errors:o}}async function vt(r,t={}){let e=await fr(r,t);return Object.fromEntries(e.arrays)}function Mt(r,t={}){let e=Lr(r,t);return Object.fromEntries(e.arrays)}var qr=M(()=>{"use strict";Fr();br();uo()});async function lo(r,t={}){let e=t.compress??!1,n=[];for(let[l,y]of r){let m=Ut(y),d,g;e?(d=await Du(y),d.length<y.length?g=8:(d=y,g=0)):(d=y,g=0),n.push({name:l,data:y,compressedData:d,crc:m,compressionMethod:g,offset:0})}let o=0;for(let l of n){let y=new TextEncoder().encode(l.name);o+=30+y.length+l.compressedData.length}let a=0;for(let l of n){let y=new TextEncoder().encode(l.name);a+=46+y.length}let s=o+a+22,i=new Uint8Array(s),c=new DataView(i.buffer),f=0;for(let l of n)l.offset=f,f=yo(i,c,f,l);let p=f;for(let l of n)f=mo(i,c,f,l);return go(c,f,n.length,a,p),i}function po(r){let t=[];for(let[f,p]of r){let l=Ut(p);t.push({name:f,data:p,compressedData:p,crc:l,compressionMethod:0,offset:0})}let e=0;for(let f of t){let p=new TextEncoder().encode(f.name);e+=30+p.length+f.compressedData.length}let n=0;for(let f of t){let p=new TextEncoder().encode(f.name);n+=46+p.length}let a=e+n+22,u=new Uint8Array(a),s=new DataView(u.buffer),i=0;for(let f of t)f.offset=i,i=yo(u,s,i,f);let c=i;for(let f of t)i=mo(u,s,i,f);return go(s,i,t.length,n,c),u}function yo(r,t,e,n){let o=new TextEncoder().encode(n.name);return t.setUint32(e,67324752,!0),e+=4,t.setUint16(e,n.compressionMethod===8?20:10,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,n.compressionMethod,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,33,!0),e+=2,t.setUint32(e,n.crc,!0),e+=4,t.setUint32(e,n.compressedData.length,!0),e+=4,t.setUint32(e,n.data.length,!0),e+=4,t.setUint16(e,o.length,!0),e+=2,t.setUint16(e,0,!0),e+=2,r.set(o,e),e+=o.length,r.set(n.compressedData,e),e+=n.compressedData.length,e}function mo(r,t,e,n){let o=new TextEncoder().encode(n.name);return t.setUint32(e,33639248,!0),e+=4,t.setUint16(e,20,!0),e+=2,t.setUint16(e,n.compressionMethod===8?20:10,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,n.compressionMethod,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,33,!0),e+=2,t.setUint32(e,n.crc,!0),e+=4,t.setUint32(e,n.compressedData.length,!0),e+=4,t.setUint32(e,n.data.length,!0),e+=4,t.setUint16(e,o.length,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint32(e,0,!0),e+=4,t.setUint32(e,n.offset,!0),e+=4,r.set(o,e),e+=o.length,e}function go(r,t,e,n,o){r.setUint32(t,101010256,!0),t+=4,r.setUint16(t,0,!0),t+=2,r.setUint16(t,0,!0),t+=2,r.setUint16(t,e,!0),t+=2,r.setUint16(t,e,!0),t+=2,r.setUint32(t,n,!0),t+=4,r.setUint32(t,o,!0),t+=4,r.setUint16(t,0,!0)}async function Du(r){if(typeof CompressionStream>"u")throw new Error("CompressionStream is not available. This environment does not support the Compression Streams API. Please use a modern browser or Node.js 18+.");let t=new CompressionStream("deflate-raw"),e=new Uint8Array(r.length);e.set(r);let n=t.writable.getWriter();n.write(e),n.close();let o=t.readable.getReader(),a=[];for(;;){let{done:c,value:f}=await o.read();if(c)break;a.push(f)}let u=a.reduce((c,f)=>c+f.length,0),s=new Uint8Array(u),i=0;for(let c of a)s.set(c,i),i+=c.length;return s}var Ao=M(()=>{"use strict";Tt()});var bo={};kt(bo,{serializeNpz:()=>Dr,serializeNpzSync:()=>Ct});async function Dr(r,t={}){let e=ho(r);return lo(e,{compress:t.compress??!1})}function Ct(r){let t=ho(r);return po(t)}function ho(r){let t=new Map;if(Array.isArray(r)){for(let n=0;n<r.length;n++){let o=r[n],a=rr(o);t.set(`arr_${n}.npy`,a)}return t}let e=r instanceof Map?r.entries():Object.entries(r);for(let[n,o]of e){if(typeof n!="string"||n.length===0)throw new Error("Array names must be non-empty strings");let a=rr(o),u=n.endsWith(".npy")?n:`${n}.npy`;t.set(u,a)}return t}var jr=M(()=>{"use strict";Rr();Ao()});Fr();Rr();qr();jr();import{readFileSync as So,writeFileSync as Do}from"node:fs";import{readFile as No,writeFile as wo}from"node:fs/promises";It();Fr();Rr();br();qr();jr();var Lc="0.7.0";async function Nu(r){let t=await No(r);return ar(t)}function wu(r){let t=So(r);return ar(t)}async function xu(r,t){let e=rr(t);await wo(r,e)}function Iu(r,t){let e=rr(t);Do(r,e)}async function zu(r,t={}){let e=await No(r);return fr(e,t)}function _u(r,t={}){let e=So(r),{parseNpzSync:n}=(qr(),Vt(fo));return n(e,t)}async function xo(r,t,e={}){let n=await Dr(t,e);await wo(r,n)}function Qc(r,t){let{serializeNpzSync:e}=(jr(),Vt(bo)),n=e(t);Do(r,n)}async function Kc(r,t={}){if(r.endsWith(".npy")){if(t.allowNpy===!1)throw new Error("Loading .npy files is disabled (allowNpy: false)");return Nu(r)}else{if(r.endsWith(".npz"))return zu(r,t);throw new Error(`Unknown file extension. Expected .npy or .npz, got: ${r}`)}}function rf(r,t={}){if(r.endsWith(".npy")){if(t.allowNpy===!1)throw new Error("Loading .npy files is disabled (allowNpy: false)");return wu(r)}else{if(r.endsWith(".npz"))return _u(r,t);throw new Error(`Unknown file extension. Expected .npy or .npz, got: ${r}`)}}async function tf(r,t){if(!r.endsWith(".npy"))throw new Error(`save() is for .npy files. Use saveNpz() for .npz files. Got: ${r}`);return xu(r,t)}function ef(r,t){if(!r.endsWith(".npy"))throw new Error(`saveSync() is for .npy files. Use saveNpzSync() for .npz files. Got: ${r}`);return Iu(r,t)}async function nf(r,t){return r.endsWith(".npz")||(r=r+".npz"),xo(r,t,{compress:!1})}async function of(r,t){return r.endsWith(".npz")||(r=r+".npz"),xo(r,t,{compress:!0})}export{Pr as DTYPE_TO_DESCR,Z as InvalidNpyError,_ as NDArray,zt as SUPPORTED_DTYPES,X as UnsupportedDTypeError,Lc as __version__,Ha as absolute,ri as append,Da as arange,ys as arccos,Is as arccosh,ps as arcsin,xs as arcsinh,ms as arctan,ds as arctan2,zs as arctanh,j as array,fi as array_equal,li as array_equiv,$s as array_split,Ta as asanyarray,Vr as asarray,Oa as ascontiguousarray,$a as asfortranarray,Gs as atleast_1d,Hs as atleast_2d,Ys as atleast_3d,hi as average,ki as bitwise_and,Fi as bitwise_not,Vi as bitwise_or,Pi as bitwise_xor,ai as broadcast_arrays,si as broadcast_shapes,oi as broadcast_to,Ti as cbrt,ci as choose,Xs as column_stack,Ji as compress,ur as concatenate,za as copy,fs as cos,Ns as cosh,yi as cumprod,pi as cumsum,bs as deg2rad,As as degrees,ti as delete,ro as diag,Ki as diag_indices,ru as diag_indices_from,va as diagflat,ns as diagonal,$i as divmod,ts as dot,Js as dsplit,Ts as dstack,Wi as einsum,Qn as empty,Ea as empty_like,Rs as expand_dims,Xn as eye,Oi as fabs,xt as flip,Ls as fliplr,qs as flipud,Qa as floor_divide,Ra as frombuffer,La as fromfile,Ma as fromfunction,qa as fromiter,ja as fromstring,Kn as full,Ua as full_like,xa as geomspace,Ci as heaviside,Ms as hsplit,Us as hstack,gs as hypot,Ia as identity,su as indices,ss as inner,ei as insert,Ri as invert,iu as ix_,os as kron,Li as left_shift,Na as linspace,Kc as load,Nu as loadNpy,wu as loadNpySync,vt as loadNpz,zu as loadNpzFile,_u as loadNpzFileSync,Mt as loadNpzSync,rf as loadSync,wa as logspace,au as mask_indices,di as median,Ca as meshgrid,Xa as mod,Bs as moveaxis,_i as nanargmax,zi as nanargmin,Ei as nancumprod,Bi as nancumsum,Ii as nanmax,Di as nanmean,Ui as nanmedian,xi as nanmin,Si as nanprod,wi as nanstd,bi as nansum,Ni as nanvar,Ya as negative,Yn as ones,Ba as ones_like,is as outer,ji as packbits,ni as pad,ar as parseNpy,Et as parseNpyData,Bt as parseNpyHeader,fr as parseNpz,Lr as parseNpzSync,gi as percentile,Qi as place,Ka as positive,Ga as power,mi as ptp,ui as put,Hi as put_along_axis,Yi as putmask,Ai as quantile,Ss as rad2deg,hs as radians,Vs as ravel,uu as ravel_multi_index,rs as reciprocal,Mi as remainder,ks as repeat,Ps as reshape,Ks as resize,qi as right_shift,Zs as roll,Ws as rollaxis,js as rot90,Qs as row_stack,tf as save,xu as saveNpy,Iu as saveNpySync,xo as saveNpz,Qc as saveNpzSync,ef as saveSync,nf as savez,of as savez_compressed,Xi as select,rr as serializeNpy,Dr as serializeNpz,Ct as serializeNpzSync,Ja as sign,cs as sin,Ds as sinh,Os as split,Wa as sqrt,vi as square,Fs as squeeze,Es as stack,_s as swapaxes,ii as take,Gi as take_along_axis,ls as tan,ws as tanh,us as tensordot,Cs as tile,es as trace,as as transpose,ka as tri,Va as tril,tu as tril_indices,eu as tril_indices_from,Pa as triu,nu as triu_indices,ou as triu_indices_from,Zi as unpackbits,cu as unravel_index,Fa as vander,vs as vsplit,to as vstack,J as zeros,_a as zeros_like};
1
+ var ut=Object.defineProperty;var Ha=Object.getOwnPropertyDescriptor;var Ya=Object.getOwnPropertyNames;var Ja=Object.prototype.hasOwnProperty;var k=(r,t)=>()=>(r&&(t=r(r=0)),t);var be=(r,t)=>{for(var e in t)ut(r,e,{get:t[e],enumerable:!0})},Qa=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ya(t))!Ja.call(r,o)&&o!==e&&ut(r,o,{get:()=>t[o],enumerable:!(n=Ha(t,o))||n.enumerable});return r};var Se=r=>Qa(ut({},"__esModule",{value:!0}),r);function Ne(r){if(!r.includes(":")){if(r.includes("."))throw new Error(`Invalid slice index: "${r}" (must be integer)`);let a=parseInt(r,10);if(isNaN(a))throw new Error(`Invalid slice index: "${r}"`);return{start:a,stop:null,step:1,isIndex:!0}}let t=r.split(":");if(t.length>3)throw new Error(`Invalid slice notation: "${r}" (too many colons)`);let e=t[0]===""?null:parseInt(t[0],10),n=t[1]===""||t[1]===void 0?null:parseInt(t[1],10),o=t[2]===""||t[2]===void 0?1:parseInt(t[2],10);if(e!==null&&isNaN(e))throw new Error(`Invalid start index in slice: "${r}"`);if(n!==null&&isNaN(n))throw new Error(`Invalid stop index in slice: "${r}"`);if(isNaN(o))throw new Error(`Invalid step in slice: "${r}"`);if(o===0)throw new Error("Slice step cannot be zero");return{start:e,stop:n,step:o,isIndex:!1}}function De(r,t){let{start:e,stop:n}=r,{step:o,isIndex:a}=r;if(a){if(e===null)throw new Error("Index cannot be null");let i=e<0?t+e:e;if(i<0||i>=t)throw new Error(`Index ${e} is out of bounds for size ${t}`);return{start:i,stop:i+1,step:1,isIndex:!0}}return o>0?(e===null&&(e=0),n===null&&(n=t)):(e===null&&(e=t-1),n===null&&(n=-t-1)),e<0&&(e=t+e),n<0&&(n=t+n),e=Math.max(0,Math.min(e,t)),n=Math.max(-1,Math.min(n,t)),{start:e,stop:n,step:o,isIndex:!1}}var xe=k(()=>{"use strict"});function U(r){switch(r){case"float64":return Float64Array;case"float32":return Float32Array;case"int64":return BigInt64Array;case"int32":return Int32Array;case"int16":return Int16Array;case"int8":return Int8Array;case"uint64":return BigUint64Array;case"uint32":return Uint32Array;case"uint16":return Uint16Array;case"uint8":return Uint8Array;case"bool":return Uint8Array;default:throw new Error(`Unknown dtype: ${r}`)}}function ze(r){switch(r){case"float64":case"int64":case"uint64":return 8;case"float32":case"int32":case"uint32":return 4;case"int16":case"uint16":return 2;case"int8":case"uint8":case"bool":return 1;default:throw new Error(`Unknown dtype: ${r}`)}}function Ie(r){return r==="int64"||r==="int32"||r==="int16"||r==="int8"||r==="uint64"||r==="uint32"||r==="uint16"||r==="uint8"}function we(r){return r==="float64"||r==="float32"}function z(r){return r==="int64"||r==="uint64"}function C(r,t){if(r===t)return r;if(r==="bool")return t;if(t==="bool")return r;if(we(r)||we(t)){if(r==="float64"||t==="float64")return"float64";if(r==="float32"){let c=t;return c==="int32"||c==="int64"||c==="uint32"||c==="uint64"?"float64":"float32"}if(t==="float32"){let c=r;return c==="int32"||c==="int64"||c==="uint32"||c==="uint64"?"float64":"float32"}return"float32"}let e=r.startsWith("int"),n=t.startsWith("int"),o=r.startsWith("uint"),a=t.startsWith("uint"),i=c=>c.includes("64")?64:c.includes("32")?32:c.includes("16")?16:c.includes("8")?8:0,u=i(r),s=i(t);if(r==="int64"&&t==="uint64"||r==="uint64"&&t==="int64")return"float64";if(e&&a&&u===s){if(u===8)return"int16";if(u===16)return"int32";if(u===32)return"int64"}if(o&&n&&u===s){if(s===8)return"int16";if(s===16)return"int32";if(s===32)return"int64"}if(e&&n||o&&a){let c=Math.max(u,s);return e?c===64?"int64":c===32?"int32":c===16?"int16":"int8":c===64?"uint64":c===32?"uint32":c===16?"uint16":"uint8"}return e&&a?u>s?r:s===8?"int16":s===16?"int32":s===32?"int64":"float64":o&&n?s>u?t:u===8?"int16":u===16?"int32":u===32?"int64":"float64":"float64"}var q,j=k(()=>{"use strict";q="float64"});function G(r){let t=new Array(r.length),e=1;for(let n=r.length-1;n>=0;n--)t[n]=e,e*=r[n];return t}var N,R=k(()=>{"use strict";j();N=class r{constructor(t,e,n,o,a){this._data=t,this._shape=e,this._strides=n,this._offset=o,this._dtype=a}get shape(){return this._shape}get ndim(){return this._shape.length}get size(){return this._shape.reduce((t,e)=>t*e,1)}get dtype(){return this._dtype}get data(){return this._data}get strides(){return this._strides}get offset(){return this._offset}get isCContiguous(){let t=this._shape,e=this._strides,n=t.length;if(n===0)return!0;if(n===1)return e[0]===1;let o=1;for(let a=n-1;a>=0;a--){if(e[a]!==o)return!1;o*=t[a]}return!0}get isFContiguous(){let t=this._shape,e=this._strides,n=t.length;if(n===0)return!0;if(n===1)return e[0]===1;let o=1;for(let a=0;a<n;a++){if(e[a]!==o)return!1;o*=t[a]}return!0}iget(t){let e=this._shape,n=this._strides,o=e.length;if(o===0)return this._data[this._offset];let a=t,i=this._offset;for(let u=0;u<o;u++){let s=1;for(let l=u+1;l<o;l++)s*=e[l];let c=Math.floor(a/s);a=a%s,i+=c*n[u]}return this._data[i]}iset(t,e){let n=this._shape,o=this._strides,a=n.length;if(a===0){this._data[this._offset]=e;return}let i=t,u=this._offset;for(let s=0;s<a;s++){let c=1;for(let m=s+1;m<a;m++)c*=n[m];let l=Math.floor(i/c);i=i%c,u+=l*o[s]}this._data[u]=e}get(...t){let e=this._strides,n=this._offset;for(let o=0;o<t.length;o++)n+=t[o]*e[o];return this._data[n]}set(t,e){let n=this._strides,o=this._offset;for(let a=0;a<t.length;a++)o+=t[a]*n[a];this._data[o]=e}copy(){let t=Array.from(this._shape),e=this._dtype,n=this.size,o=U(e);if(!o)throw new Error(`Cannot copy array with dtype ${e}`);let a=new o(n);if(this.isCContiguous&&this._offset===0)if(z(e)){let i=this._data,u=a;for(let s=0;s<n;s++)u[s]=i[s]}else a.set(this._data);else if(z(e)){let i=a;for(let u=0;u<n;u++)i[u]=this.iget(u)}else for(let i=0;i<n;i++)a[i]=this.iget(i);return new r(a,t,r._computeStrides(t),0,e)}static fromData(t,e,n,o,a){let i=o??r._computeStrides(e),u=a??0;return new r(t,e,i,u,n)}static zeros(t,e=q){let n=t.reduce((i,u)=>i*u,1),o=U(e);if(!o)throw new Error(`Cannot create array with dtype ${e}`);let a=new o(n);return new r(a,t,r._computeStrides(t),0,e)}static ones(t,e=q){let n=t.reduce((i,u)=>i*u,1),o=U(e);if(!o)throw new Error(`Cannot create array with dtype ${e}`);let a=new o(n);return z(e)?a.fill(BigInt(1)):a.fill(1),new r(a,t,r._computeStrides(t),0,e)}static _computeStrides(t){let e=new Array(t.length),n=1;for(let o=t.length-1;o>=0;o--)e[o]=n,n*=t[o];return e}}});function br(r,t){let e=r.length,n=t.length,o=Math.max(e,n),a=new Array(o);for(let i=0;i<o;i++){let u=i<o-e?1:r[i-(o-e)],s=i<o-n?1:t[i-(o-n)];if(u===s)a[i]=u;else if(u===1)a[i]=s;else if(s===1)a[i]=u;else throw new Error(`operands could not be broadcast together with shapes ${JSON.stringify(Array.from(r))} ${JSON.stringify(Array.from(t))}`)}return a}function Xa(r,t,e){let n=r.length,o=e.length,a=new Array(o).fill(0);for(let i=0;i<n;i++){let u=o-n+i,s=r[i],c=e[u];if(s===c)a[u]=t[i];else if(s===1)a[u]=0;else throw new Error("Invalid broadcast")}return a}function Mr(r,t){let e=Xa(r.shape,r.strides,t);return N.fromData(r.data,Array.from(t),r.dtype,e,r.offset)}function L(r,t,e,n){let o=br(r.shape,t.shape),a=Mr(r,o),i=Mr(t,o),u=C(r.dtype,t.dtype),s=N.zeros(o,u),c=s.data,l=s.size;if(z(u)){let m=c;for(let f=0;f<l;f++){let p=a.iget(f),y=i.iget(f),d=typeof p=="bigint"?p:BigInt(Math.round(p)),g=typeof y=="bigint"?y:BigInt(Math.round(y));n==="add"?m[f]=d+g:n==="subtract"?m[f]=d-g:n==="multiply"?m[f]=d*g:n==="divide"?m[f]=d/g:m[f]=BigInt(Math.round(e(Number(d),Number(g))))}}else{let m=z(r.dtype)||z(t.dtype);for(let f=0;f<l;f++){let p=a.iget(f),y=i.iget(f),d=Number(p),g=Number(y);c[f]=e(d,g)}}return s}function er(r,t,e){let n=br(r.shape,t.shape),o=Mr(r,n),a=Mr(t,n),i=n.reduce((c,l)=>c*l,1),u=new Uint8Array(i),s=z(r.dtype)||z(t.dtype);for(let c=0;c<i;c++){let l=o.iget(c),m=a.iget(c),f=Number(l),p=Number(m);u[c]=e(f,p)?1:0}return N.fromData(u,n,"bool")}function V(r,t,e=!0){let n=r.dtype,o=Array.from(r.shape),a=r.size,u=e?n:n!=="float32"&&n!=="float64"?"float64":n,s=N.zeros(o,u),c=s.data,l=r.data;if(z(n))if(z(u)){let m=c;for(let f=0;f<a;f++){let p=Number(l[f]);m[f]=BigInt(Math.round(t(p)))}}else for(let m=0;m<a;m++)c[m]=t(Number(l[m]));else for(let m=0;m<a;m++)c[m]=t(Number(l[m]));return s}var sr=k(()=>{"use strict";R();j()});function ct(r,t){return r.isCContiguous&&t.isCContiguous&&r.shape.length===t.shape.length&&r.shape.every((e,n)=>e===t.shape[n])}function _e(r,t){return typeof t=="number"?es(r,t):ct(r,t)?Ka(r,t):L(r,t,(e,n)=>e+n,"add")}function Ka(r,t){let e=C(r.dtype,t.dtype),n=N.zeros(Array.from(r.shape),e),o=r.size,a=r.data,i=t.data,u=n.data;if(z(e)){let s=u;if(!z(r.dtype)||!z(t.dtype))for(let l=0;l<o;l++){let m=typeof a[l]=="bigint"?a[l]:BigInt(Math.round(Number(a[l]))),f=typeof i[l]=="bigint"?i[l]:BigInt(Math.round(Number(i[l])));s[l]=m+f}else{let l=a,m=i;for(let f=0;f<o;f++)s[f]=l[f]+m[f]}}else if(z(r.dtype)||z(t.dtype))for(let c=0;c<o;c++){let l=typeof a[c]=="bigint"?Number(a[c]):a[c],m=typeof i[c]=="bigint"?Number(i[c]):i[c];u[c]=l+m}else for(let c=0;c<o;c++)u[c]=a[c]+i[c];return n}function Be(r,t){return typeof t=="number"?ns(r,t):ct(r,t)?rs(r,t):L(r,t,(e,n)=>e-n,"subtract")}function rs(r,t){let e=C(r.dtype,t.dtype),n=N.zeros(Array.from(r.shape),e),o=r.size,a=r.data,i=t.data,u=n.data;if(z(e)){let s=u;if(!z(r.dtype)||!z(t.dtype))for(let l=0;l<o;l++){let m=typeof a[l]=="bigint"?a[l]:BigInt(Math.round(Number(a[l]))),f=typeof i[l]=="bigint"?i[l]:BigInt(Math.round(Number(i[l])));s[l]=m-f}else{let l=a,m=i;for(let f=0;f<o;f++)s[f]=l[f]-m[f]}}else if(z(r.dtype)||z(t.dtype))for(let c=0;c<o;c++){let l=typeof a[c]=="bigint"?Number(a[c]):a[c],m=typeof i[c]=="bigint"?Number(i[c]):i[c];u[c]=l-m}else for(let c=0;c<o;c++)u[c]=a[c]-i[c];return n}function ve(r,t){return typeof t=="number"?os(r,t):ct(r,t)?ts(r,t):L(r,t,(e,n)=>e*n,"multiply")}function ts(r,t){let e=C(r.dtype,t.dtype),n=N.zeros(Array.from(r.shape),e),o=r.size,a=r.data,i=t.data,u=n.data;if(z(e)){let s=u;if(!z(r.dtype)||!z(t.dtype))for(let l=0;l<o;l++){let m=typeof a[l]=="bigint"?a[l]:BigInt(Math.round(Number(a[l]))),f=typeof i[l]=="bigint"?i[l]:BigInt(Math.round(Number(i[l])));s[l]=m*f}else{let l=a,m=i;for(let f=0;f<o;f++)s[f]=l[f]*m[f]}}else if(z(r.dtype)||z(t.dtype))for(let c=0;c<o;c++){let l=typeof a[c]=="bigint"?Number(a[c]):a[c],m=typeof i[c]=="bigint"?Number(i[c]):i[c];u[c]=l*m}else for(let c=0;c<o;c++)u[c]=a[c]*i[c];return n}function Ee(r,t){if(typeof t=="number")return as(r,t);let e=r.dtype==="float64",n=t.dtype==="float64",o=r.dtype==="float32",a=t.dtype==="float32";if(e||n){let s=e?r:lr(r,"float64"),c=n?t:lr(t,"float64");return L(s,c,(l,m)=>l/m,"divide")}if(o||a){let s=o?r:lr(r,"float32"),c=a?t:lr(t,"float32");return L(s,c,(l,m)=>l/m,"divide")}let i=lr(r,"float64"),u=lr(t,"float64");return L(i,u,(s,c)=>s/c,"divide")}function lr(r,t){let e=N.zeros(Array.from(r.shape),t),n=r.size,o=r.data,a=e.data;for(let i=0;i<n;i++)a[i]=Number(o[i]);return e}function es(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]+l}else for(let s=0;s<a;s++)u[s]=Number(o[s])+t;return i}function ns(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]-l}else for(let s=0;s<a;s++)u[s]=Number(o[s])-t;return i}function os(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]*l}else for(let s=0;s<a;s++)u[s]=Number(o[s])*t;return i}function as(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=e!=="float32"&&e!=="float64"?"float64":e,s=N.zeros(n,u),c=s.data;if(z(e))for(let l=0;l<a;l++)c[l]=Number(o[l])/t;else for(let l=0;l<a;l++)c[l]=Number(o[l])/t;return s}function Oe(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=N.zeros(e,t),i=a.data;if(z(t)){let u=n,s=i;for(let c=0;c<o;c++){let l=u[c];s[c]=l<0n?-l:l}}else for(let u=0;u<o;u++)i[u]=Math.abs(Number(n[u]));return a}function Te(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=N.zeros(e,t),i=a.data;if(z(t)){let u=n,s=i;for(let c=0;c<o;c++)s[c]=-u[c]}else for(let u=0;u<o;u++)i[u]=-Number(n[u]);return a}function Ue(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=N.zeros(e,t),i=a.data;if(z(t)){let u=n,s=i;for(let c=0;c<o;c++){let l=u[c];s[c]=l>0n?1n:l<0n?-1n:0n}}else for(let u=0;u<o;u++){let s=Number(n[u]);i[u]=s>0?1:s<0?-1:0}return a}function kr(r,t){return typeof t=="number"?ss(r,t):L(r,t,(e,n)=>(e%n+n)%n,"mod")}function ss(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++){let f=s[m];c[m]=(f%l+l)%l}}else for(let s=0;s<a;s++){let c=Number(o[s]);u[s]=(c%t+t)%t}return i}function lt(r,t){return typeof t=="number"?is(r,t):L(r,t,(e,n)=>Math.floor(e/n),"floor_divide")}function is(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]/l}else for(let s=0;s<a;s++)u[s]=Math.floor(Number(o[s])/t);return i}function $e(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=N.zeros(e,t),i=a.data;for(let u=0;u<o;u++)i[u]=n[u];return a}function Me(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,i=t!=="float32"&&t!=="float64"?"float64":t,u=N.zeros(e,i),s=u.data;if(z(t))for(let c=0;c<o;c++)s[c]=1/Number(n[c]);else for(let c=0;c<o;c++)s[c]=1/Number(n[c]);return u}function ke(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,i=t!=="float32"&&t!=="float64"?"float64":t,u=N.zeros(e,i),s=u.data;for(let c=0;c<o;c++)s[c]=Math.cbrt(Number(n[c]));return u}function Ce(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=t==="float32"?"float32":"float64",i=N.zeros(e,a),u=i.data;for(let s=0;s<o;s++)u[s]=Math.abs(Number(n[s]));return i}function Ve(r,t){let e=lt(r,t),n=kr(r,t);return[e,n]}function Pe(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=N.zeros(e,t),i=a.data;if(z(t)){let u=n,s=i;for(let c=0;c<o;c++)s[c]=u[c]*u[c]}else for(let u=0;u<o;u++){let s=Number(n[u]);i[u]=s*s}return a}function qe(r,t){return kr(r,t)}function Fe(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.size,a=e==="float32"?"float32":"float64",i=N.zeros(n,a),u=i.data;if(typeof t=="number")for(let s=0;s<o;s++){let c=Number(r.data[s]);c<0?u[s]=0:c===0?u[s]=t:u[s]=1}else{let s=t.data,c=t.shape;if(n.every((l,m)=>l===c[m]))for(let l=0;l<o;l++){let m=Number(r.data[l]);m<0?u[l]=0:m===0?u[l]=Number(s[l]):u[l]=1}else for(let l=0;l<o;l++){let m=Number(r.data[l]),f=l%t.size;m<0?u[l]=0:m===0?u[l]=Number(s[f]):u[l]=1}}return i}var Re=k(()=>{"use strict";R();j();sr()});function nr(r){if(r.length===0)return[];if(r.length===1)return Array.from(r[0]);let t=Math.max(...r.map(n=>n.length)),e=new Array(t);for(let n=0;n<t;n++){let o=1;for(let a of r){let i=a.length-t+n,u=i<0?1:a[i];if(u!==1){if(o===1)o=u;else if(o!==u)return null}}e[n]=o}return e}function cs(r,t,e){let n=r.length,o=e.length,a=new Array(o).fill(0);for(let i=0;i<n;i++){let u=o-n+i,s=r[i],c=e[u];if(s===c)a[u]=t[i];else if(s===1)a[u]=0;else throw new Error("Invalid broadcast")}return a}function X(r,t){let e=cs(r.shape,r.strides,t);return N.fromData(r.data,Array.from(t),r.dtype,e,r.offset)}function ft(...r){let t=nr(r);if(t===null){let e=r.map(n=>`(${n.join(",")})`).join(" ");throw new Error(`shape mismatch: objects cannot be broadcast to a single shape. Mismatch is between ${e}`)}return t}var mt=k(()=>{"use strict";R()});function je(r,t){return typeof t=="number"?ls(r,t):er(r,t,(e,n)=>e>n)}function Le(r,t){return typeof t=="number"?fs(r,t):er(r,t,(e,n)=>e>=n)}function We(r,t){return typeof t=="number"?ms(r,t):er(r,t,(e,n)=>e<n)}function Ze(r,t){return typeof t=="number"?ps(r,t):er(r,t,(e,n)=>e<=n)}function Ge(r,t){return typeof t=="number"?ys(r,t):er(r,t,(e,n)=>e===n)}function He(r,t){return typeof t=="number"?ds(r,t):er(r,t,(e,n)=>e!==n)}function pt(r,t,e=1e-5,n=1e-8){return typeof t=="number"?gs(r,t,e,n):er(r,t,(o,a)=>{let i=Math.abs(o-a),u=n+e*Math.abs(a);return i<=u})}function Ye(r,t,e=1e-5,n=1e-8){let o=pt(r,t,e,n),a=o.data;for(let i=0;i<o.size;i++)if(a[i]===0)return!1;return!0}function Je(r,t){let e=[Array.from(r.shape),Array.from(t.shape)],n=nr(e);if(n===null)return!1;let o=X(r,n),a=X(t,n),i=n.length,u=n.reduce((l,m)=>l*m,1),s=z(o.dtype),c=z(a.dtype);for(let l=0;l<u;l++){let m=l,f=new Array(i);for(let d=i-1;d>=0;d--)f[d]=m%n[d],m=Math.floor(m/n[d]);let p=o.get(...f),y=a.get(...f);if(s||c){let d=typeof p=="bigint"?p:BigInt(Number(p)),g=typeof y=="bigint"?y:BigInt(Number(y));if(d!==g)return!1}else if(p!==y)return!1}return!0}function ls(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]>t?1:0;return N.fromData(e,Array.from(r.shape),"bool")}function fs(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]>=t?1:0;return N.fromData(e,Array.from(r.shape),"bool")}function ms(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]<t?1:0;return N.fromData(e,Array.from(r.shape),"bool")}function ps(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]<=t?1:0;return N.fromData(e,Array.from(r.shape),"bool")}function ys(r,t){let e=new Uint8Array(r.size),n=r.data,o=r.dtype;if(z(o)){let a=BigInt(Math.round(t)),i=n;for(let u=0;u<r.size;u++)e[u]=i[u]===a?1:0}else for(let a=0;a<r.size;a++)e[a]=n[a]===t?1:0;return N.fromData(e,Array.from(r.shape),"bool")}function ds(r,t){let e=new Uint8Array(r.size),n=r.data;for(let o=0;o<r.size;o++)e[o]=n[o]!==t?1:0;return N.fromData(e,Array.from(r.shape),"bool")}function gs(r,t,e,n){let o=new Uint8Array(r.size),a=r.data,i=r.dtype;if(z(i)){let u=a;for(let s=0;s<r.size;s++){let c=Number(u[s]),l=Math.abs(c-t),m=n+e*Math.abs(t);o[s]=l<=m?1:0}}else for(let u=0;u<r.size;u++){let s=Number(a[u]),c=Math.abs(s-t),l=n+e*Math.abs(t);o[u]=c<=l?1:0}return N.fromData(o,Array.from(r.shape),"bool")}var Qe=k(()=>{"use strict";R();j();sr();mt()});function O(r,t){let e=0,n=1;for(let o=r.length-1;o>=0;o--)e+=r[o]*n,n*=t[o];return e}function T(r,t,e,n){let o=n.length,a=new Array(o),i=Array.from(n).filter((s,c)=>c!==t),u=r;for(let s=i.length-1;s>=0;s--)a[s>=t?s+1:s]=u%i[s],u=Math.floor(u/i[s]);return a[t]=e,a}var yt=k(()=>{"use strict"});function Sr(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,i=r.size,u=r.data;if(t===void 0)if(z(n)){let y=u,d=BigInt(0);for(let g=0;g<i;g++)d+=y[g];return Number(d)}else{let y=0;for(let d=0;d<i;d++)y+=Number(u[d]);return y}let s=t;if(s<0&&(s=a+s),s<0||s>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let c=Array.from(o).filter((y,d)=>d!==s);if(c.length===0)return Sr(r);let l=N.zeros(c,n),m=l.data,f=o[s],p=c.reduce((y,d)=>y*d,1);if(z(n)){let y=u,d=m;for(let g=0;g<p;g++){let b=BigInt(0);for(let h=0;h<f;h++){let A=T(g,s,h,o),S=O(A,o);b+=y[S]}d[g]=b}}else for(let y=0;y<p;y++){let d=0;for(let g=0;g<f;g++){let b=T(y,s,g,o),h=O(b,o);d+=Number(u[h])}m[y]=d}if(e){let y=[...o];return y[s]=1,N.fromData(m,y,n)}return l}function Cr(r,t,e=!1){let n=r.dtype,o=r.shape;if(t===void 0)return Sr(r)/r.size;let a=t;if(a<0&&(a=o.length+a),a<0||a>=o.length)throw new Error(`axis ${t} is out of bounds for array of dimension ${o.length}`);let i=Sr(r,t,e);if(typeof i=="number")return i/o[a];let u=o[a],s=n;(z(n)||n.startsWith("int")||n.startsWith("uint"))&&(s="float64");let c=N.zeros(Array.from(i.shape),s),l=c.data,m=i.data;if(z(n)){let f=m;for(let p=0;p<l.length;p++)l[p]=Number(f[p])/u}else for(let f=0;f<l.length;f++)l[f]=Number(m[f])/u;return c}function Vr(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,i=r.size,u=r.data;if(t===void 0){if(i===0)throw new Error("max of empty array");let y=u[0];for(let d=1;d<i;d++)u[d]>y&&(y=u[d]);return Number(y)}let s=t;if(s<0&&(s=a+s),s<0||s>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let c=Array.from(o).filter((y,d)=>d!==s);if(c.length===0)return Vr(r);let l=N.zeros(c,n),m=l.data,f=o[s],p=c.reduce((y,d)=>y*d,1);if(z(n)){let y=u,d=m;for(let g=0;g<p;g++){let b=T(g,s,0,o),h=O(b,o),A=y[h];for(let S=1;S<f;S++){let D=T(g,s,S,o),x=O(D,o),w=y[x];w>A&&(A=w)}d[g]=A}}else for(let y=0;y<p;y++){let d=-1/0;for(let g=0;g<f;g++){let b=T(y,s,g,o),h=O(b,o),A=Number(u[h]);A>d&&(d=A)}m[y]=d}if(e){let y=[...o];return y[s]=1,N.fromData(m,y,n)}return l}function dt(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,i=r.size,u=r.data;if(t===void 0)if(z(n)){let y=u,d=BigInt(1);for(let g=0;g<i;g++)d*=y[g];return Number(d)}else{let y=1;for(let d=0;d<i;d++)y*=Number(u[d]);return y}let s=t;if(s<0&&(s=a+s),s<0||s>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let c=Array.from(o).filter((y,d)=>d!==s);if(c.length===0)return dt(r);let l=N.zeros(c,n),m=l.data,f=o[s],p=c.reduce((y,d)=>y*d,1);if(z(n)){let y=u,d=m;for(let g=0;g<p;g++){let b=BigInt(1);for(let h=0;h<f;h++){let A=T(g,s,h,o),S=O(A,o);b*=y[S]}d[g]=b}}else for(let y=0;y<p;y++){let d=1;for(let g=0;g<f;g++){let b=T(y,s,g,o),h=O(b,o);d*=Number(u[h])}m[y]=d}if(e){let y=[...o];return y[s]=1,N.fromData(m,y,n)}return l}function Pr(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,i=r.size,u=r.data;if(t===void 0){if(i===0)throw new Error("min of empty array");let y=u[0];for(let d=1;d<i;d++)u[d]<y&&(y=u[d]);return Number(y)}let s=t;if(s<0&&(s=a+s),s<0||s>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let c=Array.from(o).filter((y,d)=>d!==s);if(c.length===0)return Pr(r);let l=N.zeros(c,n),m=l.data,f=o[s],p=c.reduce((y,d)=>y*d,1);if(z(n)){let y=u,d=m;for(let g=0;g<p;g++){let b=T(g,s,0,o),h=O(b,o),A=y[h];for(let S=1;S<f;S++){let D=T(g,s,S,o),x=O(D,o),w=y[x];w<A&&(A=w)}d[g]=A}}else for(let y=0;y<p;y++){let d=1/0;for(let g=0;g<f;g++){let b=T(y,s,g,o),h=O(b,o),A=Number(u[h]);A<d&&(d=A)}m[y]=d}if(e){let y=[...o];return y[s]=1,N.fromData(m,y,n)}return l}function gt(r,t){let e=r.dtype,n=r.shape,o=n.length,a=r.size,i=r.data;if(t===void 0){if(a===0)throw new Error("argmin of empty array");let p=i[0],y=0;for(let d=1;d<a;d++)i[d]<p&&(p=i[d],y=d);return y}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((p,y)=>y!==u);if(s.length===0)return gt(r);let c=N.zeros(s,"int32"),l=c.data,m=n[u],f=s.reduce((p,y)=>p*y,1);if(z(e)){let p=i;for(let y=0;y<f;y++){let d=T(y,u,0,n),g=O(d,n),b=p[g],h=0;for(let A=1;A<m;A++){let S=T(y,u,A,n),D=O(S,n),x=p[D];x<b&&(b=x,h=A)}l[y]=h}}else for(let p=0;p<f;p++){let y=1/0,d=0;for(let g=0;g<m;g++){let b=T(p,u,g,n),h=O(b,n),A=Number(i[h]);A<y&&(y=A,d=g)}l[p]=d}return c}function At(r,t){let e=r.dtype,n=r.shape,o=n.length,a=r.size,i=r.data;if(t===void 0){if(a===0)throw new Error("argmax of empty array");let p=i[0],y=0;for(let d=1;d<a;d++)i[d]>p&&(p=i[d],y=d);return y}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((p,y)=>y!==u);if(s.length===0)return At(r);let c=N.zeros(s,"int32"),l=c.data,m=n[u],f=s.reduce((p,y)=>p*y,1);if(z(e)){let p=i;for(let y=0;y<f;y++){let d=T(y,u,0,n),g=O(d,n),b=p[g],h=0;for(let A=1;A<m;A++){let S=T(y,u,A,n),D=O(S,n),x=p[D];x>b&&(b=x,h=A)}l[y]=h}}else for(let p=0;p<f;p++){let y=-1/0,d=0;for(let g=0;g<m;g++){let b=T(p,u,g,n),h=O(b,n),A=Number(i[h]);A>y&&(y=A,d=g)}l[p]=d}return c}function ht(r,t,e=0,n=!1){let o=r.shape,a=o.length,i=r.size,u=r.data,s=Cr(r,t,n);if(t===void 0){let b=s,h=0;for(let A=0;A<i;A++){let S=Number(u[A])-b;h+=S*S}return h/(i-e)}let c=t;if(c<0&&(c=a+c),c<0||c>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let l=o[c],m=s,f=m.data,p=n?m.shape:Array.from(o).filter((b,h)=>h!==c),y=N.zeros(Array.from(p),"float64"),d=y.data,g=p.reduce((b,h)=>b*h,1);for(let b=0;b<g;b++){let h=0,A=Number(f[b]);for(let S=0;S<l;S++){let D=T(b,c,S,o),x=O(D,o),w=Number(u[x])-A;h+=w*w}d[b]=h/(l-e)}return y}function Xe(r,t,e=0,n=!1){let o=ht(r,t,e,n);if(typeof o=="number")return Math.sqrt(o);let a=N.zeros(Array.from(o.shape),"float64"),i=o.data,u=a.data;for(let s=0;s<i.length;s++)u[s]=Math.sqrt(Number(i[s]));return a}function bt(r,t,e=!1){let n=r.shape,o=n.length,a=r.size,i=r.data;if(t===void 0){for(let p=0;p<a;p++)if(!i[p])return!1;return!0}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((p,y)=>y!==u);if(s.length===0)return bt(r);let c=N.zeros(s,"bool"),l=c.data,m=n[u],f=s.reduce((p,y)=>p*y,1);for(let p=0;p<f;p++){let y=!0;for(let d=0;d<m;d++){let g=T(p,u,d,n),b=O(g,n);if(!i[b]){y=!1;break}}l[p]=y?1:0}if(e){let p=[...n];return p[u]=1,N.fromData(l,p,"bool")}return c}function St(r,t,e=!1){let n=r.shape,o=n.length,a=r.size,i=r.data;if(t===void 0){for(let p=0;p<a;p++)if(i[p])return!0;return!1}let u=t;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let s=Array.from(n).filter((p,y)=>y!==u);if(s.length===0)return St(r);let c=N.zeros(s,"bool"),l=c.data,m=n[u],f=s.reduce((p,y)=>p*y,1);for(let p=0;p<f;p++){let y=!1;for(let d=0;d<m;d++){let g=T(p,u,d,n),b=O(g,n);if(i[b]){y=!0;break}}l[p]=y?1:0}if(e){let p=[...n];return p[u]=1,N.fromData(l,p,"bool")}return c}function Nt(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let f=r.size,p=new Float64Array(f),y=0;for(let d=0;d<f;d++)y+=Number(o[d]),p[d]=y;return N.fromData(p,[f],"float64")}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=new Float64Array(r.size),u=e[a],s=[],c=1;for(let f=n-1;f>=0;f--)s.unshift(c),c*=e[f];let l=r.size,m=s[a];for(let f=0;f<l;f++)Math.floor(f/m)%u===0?i[f]=Number(o[f]):i[f]=i[f-m]+Number(o[f]);return N.fromData(i,[...e],"float64")}function Dt(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let f=r.size,p=new Float64Array(f),y=1;for(let d=0;d<f;d++)y*=Number(o[d]),p[d]=y;return N.fromData(p,[f],"float64")}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=new Float64Array(r.size),u=e[a],s=[],c=1;for(let f=n-1;f>=0;f--)s.unshift(c),c*=e[f];let l=r.size,m=s[a];for(let f=0;f<l;f++)Math.floor(f/m)%u===0?i[f]=Number(o[f]):i[f]=i[f-m]*Number(o[f]);return N.fromData(i,[...e],"float64")}function xt(r,t,e=!1){let n=Vr(r,t,e),o=Pr(r,t,e);if(typeof n=="number"&&typeof o=="number")return n-o;let a=n,i=o,u=a.data,s=i.data,c=new Float64Array(a.size);for(let l=0;l<a.size;l++)c[l]=Number(u[l])-Number(s[l]);return N.fromData(c,[...a.shape],"float64")}function wt(r,t,e=!1){return fr(r,.5,t,e)}function zt(r,t,e,n=!1){return fr(r,t/100,e,n)}function fr(r,t,e,n=!1){if(t<0||t>1)throw new Error("Quantile must be between 0 and 1");let o=r.shape,a=o.length,i=r.data;if(e===void 0){let p=[];for(let A=0;A<r.size;A++)p.push(Number(i[A]));p.sort((A,S)=>A-S);let y=p.length,d=t*(y-1),g=Math.floor(d),b=Math.ceil(d);if(g===b)return p[g];let h=d-g;return p[g]*(1-h)+p[b]*h}let u=e;if(u<0&&(u=a+u),u<0||u>=a)throw new Error(`axis ${e} is out of bounds for array of dimension ${a}`);let s=Array.from(o).filter((p,y)=>y!==u);if(s.length===0)return fr(r,t);let c=s.reduce((p,y)=>p*y,1),l=o[u],m=new Float64Array(c);for(let p=0;p<c;p++){let y=[];for(let A=0;A<l;A++){let S=T(p,u,A,o),D=O(S,o);y.push(Number(i[D]))}y.sort((A,S)=>A-S);let d=y.length,g=t*(d-1),b=Math.floor(g),h=Math.ceil(g);if(b===h)m[p]=y[b];else{let A=g-b;m[p]=y[b]*(1-A)+y[h]*A}}let f=N.fromData(m,s,"float64");if(n){let p=[...o];return p[u]=1,N.fromData(m,p,"float64")}return f}function qr(r,t,e,n=!1){let o=r.shape,a=o.length,i=r.data;if(e===void 0)return Cr(r,t,n);if(t===void 0){let y=0,d=0,g=e.data;for(let b=0;b<r.size;b++){let h=Number(g[b%e.size]);y+=Number(i[b])*h,d+=h}return d===0?NaN:y/d}let u=t;if(u<0&&(u=a+u),u<0||u>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let s=Array.from(o).filter((y,d)=>d!==u);if(s.length===0)return qr(r,void 0,e);let c=s.reduce((y,d)=>y*d,1),l=o[u],m=e.data,f=new Float64Array(c);for(let y=0;y<c;y++){let d=0,g=0;for(let b=0;b<l;b++){let h=T(y,u,b,o),A=O(h,o),S=Number(m[b%e.size]);d+=Number(i[A])*S,g+=S}f[y]=g===0?NaN:d/g}let p=N.fromData(f,s,"float64");if(n){let y=[...o];return y[u]=1,N.fromData(f,y,"float64")}return p}function Fr(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let f=0;for(let p=0;p<r.size;p++){let y=Number(a[p]);isNaN(y)||(f+=y)}return f}let i=t;if(i<0&&(i=o+i),i<0||i>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let u=Array.from(n).filter((f,p)=>p!==i);if(u.length===0)return Fr(r);let s=u.reduce((f,p)=>f*p,1),c=n[i],l=new Float64Array(s);for(let f=0;f<s;f++){let p=0;for(let y=0;y<c;y++){let d=T(f,i,y,n),g=O(d,n),b=Number(a[g]);isNaN(b)||(p+=b)}l[f]=p}let m=N.fromData(l,u,"float64");if(e){let f=[...n];return f[i]=1,N.fromData(l,f,"float64")}return m}function Rr(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let f=1;for(let p=0;p<r.size;p++){let y=Number(a[p]);isNaN(y)||(f*=y)}return f}let i=t;if(i<0&&(i=o+i),i<0||i>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let u=Array.from(n).filter((f,p)=>p!==i);if(u.length===0)return Rr(r);let s=u.reduce((f,p)=>f*p,1),c=n[i],l=new Float64Array(s);for(let f=0;f<s;f++){let p=1;for(let y=0;y<c;y++){let d=T(f,i,y,n),g=O(d,n),b=Number(a[g]);isNaN(b)||(p*=b)}l[f]=p}let m=N.fromData(l,u,"float64");if(e){let f=[...n];return f[i]=1,N.fromData(l,f,"float64")}return m}function jr(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let f=0,p=0;for(let y=0;y<r.size;y++){let d=Number(a[y]);isNaN(d)||(f+=d,p++)}return p===0?NaN:f/p}let i=t;if(i<0&&(i=o+i),i<0||i>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let u=Array.from(n).filter((f,p)=>p!==i);if(u.length===0)return jr(r);let s=u.reduce((f,p)=>f*p,1),c=n[i],l=new Float64Array(s);for(let f=0;f<s;f++){let p=0,y=0;for(let d=0;d<c;d++){let g=T(f,i,d,n),b=O(g,n),h=Number(a[b]);isNaN(h)||(p+=h,y++)}l[f]=y===0?NaN:p/y}let m=N.fromData(l,u,"float64");if(e){let f=[...n];return f[i]=1,N.fromData(l,f,"float64")}return m}function Nr(r,t,e=0,n=!1){let o=r.shape,a=o.length,i=r.data;if(t===void 0){let p=0,y=0;for(let b=0;b<r.size;b++){let h=Number(i[b]);isNaN(h)||(p+=h,y++)}if(y-e<=0)return NaN;let d=p/y,g=0;for(let b=0;b<r.size;b++){let h=Number(i[b]);isNaN(h)||(g+=(h-d)**2)}return g/(y-e)}let u=t;if(u<0&&(u=a+u),u<0||u>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let s=Array.from(o).filter((p,y)=>y!==u);if(s.length===0)return Nr(r,void 0,e);let c=s.reduce((p,y)=>p*y,1),l=o[u],m=new Float64Array(c);for(let p=0;p<c;p++){let y=0,d=0;for(let h=0;h<l;h++){let A=T(p,u,h,o),S=O(A,o),D=Number(i[S]);isNaN(D)||(y+=D,d++)}if(d-e<=0){m[p]=NaN;continue}let g=y/d,b=0;for(let h=0;h<l;h++){let A=T(p,u,h,o),S=O(A,o),D=Number(i[S]);isNaN(D)||(b+=(D-g)**2)}m[p]=b/(d-e)}let f=N.fromData(m,s,"float64");if(n){let p=[...o];return p[u]=1,N.fromData(m,p,"float64")}return f}function It(r,t,e=0,n=!1){let o=Nr(r,t,e,n);if(typeof o=="number")return Math.sqrt(o);let a=o,i=new Float64Array(a.size);for(let u=0;u<a.size;u++)i[u]=Math.sqrt(Number(a.data[u]));return N.fromData(i,[...a.shape],"float64")}function Lr(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let f=1/0;for(let p=0;p<r.size;p++){let y=Number(a[p]);!isNaN(y)&&y<f&&(f=y)}return f===1/0?NaN:f}let i=t;if(i<0&&(i=o+i),i<0||i>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let u=Array.from(n).filter((f,p)=>p!==i);if(u.length===0)return Lr(r);let s=u.reduce((f,p)=>f*p,1),c=n[i],l=new Float64Array(s);for(let f=0;f<s;f++){let p=1/0;for(let y=0;y<c;y++){let d=T(f,i,y,n),g=O(d,n),b=Number(a[g]);!isNaN(b)&&b<p&&(p=b)}l[f]=p===1/0?NaN:p}let m=N.fromData(l,u,"float64");if(e){let f=[...n];return f[i]=1,N.fromData(l,f,"float64")}return m}function Wr(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let f=-1/0;for(let p=0;p<r.size;p++){let y=Number(a[p]);!isNaN(y)&&y>f&&(f=y)}return f===-1/0?NaN:f}let i=t;if(i<0&&(i=o+i),i<0||i>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let u=Array.from(n).filter((f,p)=>p!==i);if(u.length===0)return Wr(r);let s=u.reduce((f,p)=>f*p,1),c=n[i],l=new Float64Array(s);for(let f=0;f<s;f++){let p=-1/0;for(let y=0;y<c;y++){let d=T(f,i,y,n),g=O(d,n),b=Number(a[g]);!isNaN(b)&&b>p&&(p=b)}l[f]=p===-1/0?NaN:p}let m=N.fromData(l,u,"float64");if(e){let f=[...n];return f[i]=1,N.fromData(l,f,"float64")}return m}function Zr(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let l=1/0,m=-1;for(let f=0;f<r.size;f++){let p=Number(o[f]);!isNaN(p)&&p<l&&(l=p,m=f)}return m}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=Array.from(e).filter((l,m)=>m!==a);if(i.length===0)return Zr(r);let u=i.reduce((l,m)=>l*m,1),s=e[a],c=new Int32Array(u);for(let l=0;l<u;l++){let m=1/0,f=0;for(let p=0;p<s;p++){let y=T(l,a,p,e),d=O(y,e),g=Number(o[d]);!isNaN(g)&&g<m&&(m=g,f=p)}c[l]=f}return N.fromData(c,i,"int32")}function Gr(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let l=-1/0,m=-1;for(let f=0;f<r.size;f++){let p=Number(o[f]);!isNaN(p)&&p>l&&(l=p,m=f)}return m}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=Array.from(e).filter((l,m)=>m!==a);if(i.length===0)return Gr(r);let u=i.reduce((l,m)=>l*m,1),s=e[a],c=new Int32Array(u);for(let l=0;l<u;l++){let m=-1/0,f=0;for(let p=0;p<s;p++){let y=T(l,a,p,e),d=O(y,e),g=Number(o[d]);!isNaN(g)&&g>m&&(m=g,f=p)}c[l]=f}return N.fromData(c,i,"int32")}function _t(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let f=r.size,p=new Float64Array(f),y=0;for(let d=0;d<f;d++){let g=Number(o[d]);isNaN(g)||(y+=g),p[d]=y}return N.fromData(p,[f],"float64")}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=new Float64Array(r.size),u=e[a],s=[],c=1;for(let f=n-1;f>=0;f--)s.unshift(c),c*=e[f];let l=r.size,m=s[a];for(let f=0;f<l;f++){let p=Number(o[f]);Math.floor(f/m)%u===0?i[f]=isNaN(p)?0:p:i[f]=i[f-m]+(isNaN(p)?0:p)}return N.fromData(i,[...e],"float64")}function Bt(r,t){let e=r.shape,n=e.length,o=r.data;if(t===void 0){let f=r.size,p=new Float64Array(f),y=1;for(let d=0;d<f;d++){let g=Number(o[d]);isNaN(g)||(y*=g),p[d]=y}return N.fromData(p,[f],"float64")}let a=t;if(a<0&&(a=n+a),a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=new Float64Array(r.size),u=e[a],s=[],c=1;for(let f=n-1;f>=0;f--)s.unshift(c),c*=e[f];let l=r.size,m=s[a];for(let f=0;f<l;f++){let p=Number(o[f]);Math.floor(f/m)%u===0?i[f]=isNaN(p)?1:p:i[f]=i[f-m]*(isNaN(p)?1:p)}return N.fromData(i,[...e],"float64")}function Hr(r,t,e=!1){let n=r.shape,o=n.length,a=r.data;if(t===void 0){let f=[];for(let d=0;d<r.size;d++){let g=Number(a[d]);isNaN(g)||f.push(g)}if(f.length===0)return NaN;f.sort((d,g)=>d-g);let p=f.length,y=Math.floor(p/2);return p%2===0?(f[y-1]+f[y])/2:f[y]}let i=t;if(i<0&&(i=o+i),i<0||i>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let u=Array.from(n).filter((f,p)=>p!==i);if(u.length===0)return Hr(r);let s=u.reduce((f,p)=>f*p,1),c=n[i],l=new Float64Array(s);for(let f=0;f<s;f++){let p=[];for(let g=0;g<c;g++){let b=T(f,i,g,n),h=O(b,n),A=Number(a[h]);isNaN(A)||p.push(A)}if(p.length===0){l[f]=NaN;continue}p.sort((g,b)=>g-b);let y=p.length,d=Math.floor(y/2);y%2===0?l[f]=(p[d-1]+p[d])/2:l[f]=p[d]}let m=N.fromData(l,u,"float64");if(e){let f=[...n];return f[i]=1,N.fromData(l,f,"float64")}return m}var Ke=k(()=>{"use strict";R();j();yt()});function W(r,t){let e=r.size,n=r.dtype,o=t.indexOf(-1),a;if(o!==-1){let c=t.reduce((m,f,p)=>p===o?m:m*f,1),l=e/c;if(!Number.isInteger(l))throw new Error(`cannot reshape array of size ${e} into shape ${JSON.stringify(t)}`);a=t.map((m,f)=>f===o?l:m)}else a=t;if(a.reduce((c,l)=>c*l,1)!==e)throw new Error(`cannot reshape array of size ${e} into shape ${JSON.stringify(a)}`);if(r.isCContiguous){let c=r.data;return N.fromData(c,a,n,G(a),0)}let s=r.copy().data;return N.fromData(s,a,n,G(a),0)}function Yr(r){let t=r.size,e=r.dtype,n=U(e);if(!n)throw new Error(`Cannot flatten array with dtype ${e}`);if(r.isCContiguous){let u=r.data.slice(r.offset,r.offset+t);return N.fromData(u,[t],e,[1],0)}let o=new n(t),a=z(e);for(let i=0;i<t;i++){let u=r.iget(i);o[i]=u}return N.fromData(o,[t],e,[1],0)}function mr(r){let t=r.size,e=r.dtype;if(r.isCContiguous){let n=r.data;return N.fromData(n,[t],e,[1],0)}return Yr(r)}function xr(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,i=r.dtype,u;if(t===void 0)u=Array.from({length:n},(m,f)=>n-1-f);else{if(t.length!==n)throw new Error(`axes must have length ${n}, got ${t.length}`);let m=new Set;for(let f of t){let p=f<0?n+f:f;if(p<0||p>=n)throw new Error(`axis ${f} is out of bounds for array of dimension ${n}`);if(m.has(p))throw new Error("repeated axis in transpose");m.add(p)}u=t.map(f=>f<0?n+f:f)}let s=u.map(m=>e[m]),c=Array.from(o),l=u.map(m=>c[m]);return N.fromData(a,s,i,l,r.offset)}function rn(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,i=r.dtype;if(t===void 0){let u=[],s=[];for(let c=0;c<n;c++)e[c]!==1&&(u.push(e[c]),s.push(o[c]));return u.length===0&&(u.push(1),s.push(1)),N.fromData(a,u,i,s,r.offset)}else{let u=t<0?n+t:t;if(u<0||u>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);if(e[u]!==1)throw new Error(`cannot select an axis which has size not equal to one (axis ${t} has size ${e[u]})`);let s=[],c=[];for(let l=0;l<n;l++)l!==u&&(s.push(e[l]),c.push(o[l]));return N.fromData(a,s,i,c,r.offset)}}function Dr(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,i=r.dtype,u=t;if(u<0&&(u=n+t+1),u<0||u>n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n+1}`);let s=[...Array.from(e)];s.splice(u,0,1);let c=[...Array.from(o)],l=u<n?o[u]*(e[u]||1):1;return c.splice(u,0,l),N.fromData(a,s,i,c,r.offset)}function tn(r,t,e){let n=r.shape,o=n.length,a=r.strides,i=r.data,u=r.dtype,s=t<0?o+t:t,c=e<0?o+e:e;if(s<0||s>=o)throw new Error(`axis1 ${t} is out of bounds for array of dimension ${o}`);if(c<0||c>=o)throw new Error(`axis2 ${e} is out of bounds for array of dimension ${o}`);if(s===c)return N.fromData(i,Array.from(n),u,Array.from(a),r.offset);let l=Array.from(n),m=Array.from(a);return[l[s],l[c]]=[l[c],l[s]],[m[s],m[c]]=[m[c],m[s]],N.fromData(i,l,u,m,r.offset)}function vt(r,t,e){let n=r.ndim,o=Array.isArray(t)?t:[t],a=Array.isArray(e)?e:[e];if(o.length!==a.length)throw new Error("source and destination must have the same number of elements");let i=o.map(c=>{let l=c<0?n+c:c;if(l<0||l>=n)throw new Error(`source axis ${c} is out of bounds for array of dimension ${n}`);return l}),u=a.map(c=>{let l=c<0?n+c:c;if(l<0||l>=n)throw new Error(`destination axis ${c} is out of bounds for array of dimension ${n}`);return l});if(new Set(i).size!==i.length)throw new Error("repeated axis in source");if(new Set(u).size!==u.length)throw new Error("repeated axis in destination");let s=[];for(let c=0;c<n;c++)i.includes(c)||s.push(c);for(let c=0;c<i.length;c++){let l=u[c];s.splice(l,0,i[c])}return xr(r,s)}function ir(r,t=0){if(r.length===0)throw new Error("need at least one array to concatenate");if(r.length===1)return r[0].copy();let e=r[0],n=e.ndim,o=e.dtype,a=t<0?n+t:t;if(a<0||a>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);for(let p=1;p<r.length;p++){let y=r[p];if(y.ndim!==n)throw new Error("all the input arrays must have same number of dimensions");for(let d=0;d<n;d++)if(d!==a&&y.shape[d]!==e.shape[d])throw new Error("all the input array dimensions except for the concatenation axis must match exactly")}let i=Array.from(e.shape),u=e.shape[a];for(let p=1;p<r.length;p++)u+=r[p].shape[a];i[a]=u;let s=i.reduce((p,y)=>p*y,1),c=U(o);if(!c)throw new Error(`Cannot concatenate arrays with dtype ${o}`);let l=new c(s),m=G(i),f=0;for(let p of r){let y=p.shape[a];bs(p,l,i,m,a,f,o),f+=y}return N.fromData(l,i,o)}function bs(r,t,e,n,o,a,i){let u=r.shape,s=u.length,c=r.size,l=i==="int64"||i==="uint64";if(o===0&&r.isCContiguous&&s>0){let p=a*n[0],y=r.data,d=r.offset,g=d+c;t.set(y.subarray(d,g),p);return}if(o===1&&s===2&&r.isCContiguous){let p=u[0],y=u[1],d=e[1],g=r.data,b=r.offset;for(let h=0;h<p;h++){let A=b+h*y,S=h*d+a;t.set(g.subarray(A,A+y),S)}return}let m=new Array(s).fill(0),f=a*n[o];for(let p=0;p<c;p++){let y=r.iget(p),d=f;for(let g=0;g<s;g++)d+=m[g]*n[g];t[d]=y;for(let g=s-1;g>=0&&(m[g]++,!(m[g]<u[g]));g--)m[g]=0}}function en(r,t=0){if(r.length===0)throw new Error("need at least one array to stack");let e=r[0],n=e.shape,o=e.ndim,a=t<0?o+1+t:t;if(a<0||a>o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o+1}`);for(let u=1;u<r.length;u++){let s=r[u];if(s.ndim!==o)throw new Error("all input arrays must have the same shape");for(let c=0;c<o;c++)if(s.shape[c]!==n[c])throw new Error("all input arrays must have the same shape")}let i=r.map(u=>Dr(u,a));return ir(i,a)}function nn(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?W(e,[1,e.shape[0]]):e);return ir(t,0)}function Et(r){if(r.length===0)throw new Error("need at least one array to stack");return r.every(e=>e.ndim===1)?ir(r,0):ir(r,1)}function on(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?W(Dr(W(e,[1,e.shape[0]]),2),[1,e.shape[0],1]):e.ndim===2?Dr(e,2):e);return ir(t,2)}function an(r,t,e=0){let n=r.shape,o=n.length,a=e<0?o+e:e;if(a<0||a>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let i=n[a],u;if(typeof t=="number"){if(i%t!==0)throw new Error("array split does not result in an equal division");let s=i/t;u=[];for(let c=1;c<t;c++)u.push(c*s)}else u=t;return sn(r,u,a)}function wr(r,t,e=0){let n=r.shape,o=n.length,a=e<0?o+e:e;if(a<0||a>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let i=n[a],u;if(typeof t=="number"){let s=t,c=Math.floor(i/s),l=i%s;u=[];let m=0;for(let f=0;f<s-1;f++)m+=c+(f<l?1:0),u.push(m)}else u=t;return sn(r,u,a)}function sn(r,t,e){let n=r.shape,o=n[e],a=[0,...t,o],i=[];for(let u=0;u<a.length-1;u++){let s=a[u],c=a[u+1];if(s>c)throw new Error("split indices must be in ascending order");let l=Array.from(n);l[e]=c-s;let m=r.offset+s*r.strides[e];i.push(N.fromData(r.data,l,r.dtype,Array.from(r.strides),m))}return i}function un(r,t){if(r.ndim<2)throw new Error("vsplit only works on arrays of 2 or more dimensions");return wr(r,t,0)}function cn(r,t){if(r.ndim<1)throw new Error("hsplit only works on arrays of 1 or more dimensions");let e=r.ndim===1?0:1;return wr(r,t,e)}function ln(r,t){let e=r.shape,n=e.length,o=r.dtype,a=Array.isArray(t)?t:[t],i=Math.max(n,a.length),u=new Array(i).fill(1),s=new Array(i).fill(1);for(let h=0;h<n;h++)u[i-n+h]=e[h];for(let h=0;h<a.length;h++)s[i-a.length+h]=a[h];let c=u.map((h,A)=>h*s[A]),l=c.reduce((h,A)=>h*A,1),m=U(o);if(!m)throw new Error(`Cannot tile array with dtype ${o}`);let f=new m(l),p=G(c),y=r;n<i&&(y=W(r,u));let d=o==="int64"||o==="uint64",g=y.strides,b=new Array(i).fill(0);for(let h=0;h<l;h++){let A=y.offset;for(let x=0;x<i;x++){let w=b[x]%u[x];A+=w*g[x]}let S=y.data[A],D=0;for(let x=0;x<i;x++)D+=b[x]*p[x];f[D]=S;for(let x=i-1;x>=0&&(b[x]++,!(b[x]<c[x]));x--)b[x]=0}return N.fromData(f,c,o)}function fn(r,t,e){let n=r.shape,o=n.length,a=r.dtype,i=r.size;if(e===void 0){let h=i,A=Array.isArray(t)?t:new Array(h).fill(t);if(A.length!==h)throw new Error(`operands could not be broadcast together with shape (${h},) (${A.length},)`);let S=A.reduce((_,B)=>_+B,0),D=U(a);if(!D)throw new Error(`Cannot repeat array with dtype ${a}`);let x=new D(S),w=0;for(let _=0;_<h;_++){let B=r.iget(_),v=A[_];for(let E=0;E<v;E++)x[w++]=B}return N.fromData(x,[S],a)}let u=e<0?o+e:e;if(u<0||u>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let s=n[u],c=Array.isArray(t)?t:new Array(s).fill(t);if(c.length!==s)throw new Error(`operands could not be broadcast together with shape (${s},) (${c.length},)`);let l=Array.from(n);l[u]=c.reduce((h,A)=>h+A,0);let m=l.reduce((h,A)=>h*A,1),f=U(a);if(!f)throw new Error(`Cannot repeat array with dtype ${a}`);let p=new f(m),y=G(l),d=new Array(o).fill(0),g=a==="int64"||a==="uint64",b=[0];for(let h=0;h<s;h++)b.push(b[h]+c[h]);for(let h=0;h<i;h++){let A=r.iget(h),S=d[u],D=c[S],x=0;for(let B=0;B<o;B++)B!==u&&(x+=d[B]*y[B]);let w=y[u],_=b[S];for(let B=0;B<D;B++){let v=x+(_+B)*w;p[v]=A}for(let B=o-1;B>=0&&(d[B]++,!(d[B]<n[B]));B--)d[B]=0}return N.fromData(p,l,a)}function mn(r,t){let e=r.shape,n=e.length,o=r.dtype,a=r.size,i;if(t===void 0)i=new Set(Array.from({length:n},(f,p)=>p));else if(typeof t=="number"){let f=t<0?n+t:t;if(f<0||f>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);i=new Set([f])}else i=new Set(t.map(f=>{let p=f<0?n+f:f;if(p<0||p>=n)throw new Error(`axis ${f} is out of bounds for array of dimension ${n}`);return p}));let u=U(o);if(!u)throw new Error(`Cannot flip array with dtype ${o}`);let s=new u(a),c=z(o);if(n===1&&r.isCContiguous){let f=r.data,p=r.offset;for(let y=0;y<a;y++)s[y]=f[p+a-1-y];return N.fromData(s,[...e],o)}if(n===2&&r.isCContiguous){let f=e[0],p=e[1],y=r.data,d=r.offset;if(i.size===2){for(let g=0;g<a;g++)s[g]=y[d+a-1-g];return N.fromData(s,[...e],o)}if(i.size===1){if(i.has(0)){for(let g=0;g<f;g++){let b=d+(f-1-g)*p,h=g*p;for(let A=0;A<p;A++)s[h+A]=y[b+A]}return N.fromData(s,[...e],o)}else if(i.has(1)){for(let g=0;g<f;g++){let b=d+g*p,h=g*p;for(let A=0;A<p;A++)s[h+A]=y[b+p-1-A]}return N.fromData(s,[...e],o)}}}let l=new Array(n),m=new Array(n).fill(0);for(let f=0;f<a;f++){for(let d=0;d<n;d++)l[d]=i.has(d)?e[d]-1-m[d]:m[d];let p=r.offset;for(let d=0;d<n;d++)p+=l[d]*r.strides[d];let y=r.data[p];s[f]=y;for(let d=n-1;d>=0&&(m[d]++,!(m[d]<e[d]));d--)m[d]=0}return N.fromData(s,[...e],o)}function pn(r,t=1,e=[0,1]){let n=r.shape,o=n.length,a=r.dtype;if(o<2)throw new Error("Input must be at least 2-D");let i=e[0]<0?o+e[0]:e[0],u=e[1]<0?o+e[1]:e[1];if(i<0||i>=o||u<0||u>=o)throw new Error(`Axes are out of bounds for array of dimension ${o}`);if(i===u)throw new Error("Axes must be different");if(t=(t%4+4)%4,t===0)return r.copy();let s=U(a);if(!s)throw new Error(`Cannot rotate array with dtype ${a}`);let c=[...n];(t===1||t===3)&&([c[i],c[u]]=[c[u],c[i]]);let l=c.reduce((g,b)=>g*b,1),m=new s(l),f=G(c),p=z(a),y=new Array(o).fill(0),d=new Array(o);for(let g=0;g<r.size;g++){for(let D=0;D<o;D++)d[D]=y[D];let b,h;t===1?(b=n[u]-1-y[u],h=y[i]):t===2?(b=n[i]-1-y[i],h=n[u]-1-y[u],d[i]=b,d[u]=h):(b=y[u],h=n[i]-1-y[i]),t!==2&&(d[i]=b,d[u]=h);let A=0;for(let D=0;D<o;D++)A+=d[D]*f[D];let S=r.iget(g);m[A]=S;for(let D=o-1;D>=0&&(y[D]++,!(y[D]<n[D]));D--)y[D]=0}return N.fromData(m,c,a)}function yn(r,t,e){let n=r.shape,o=n.length,a=r.dtype,i=r.size;if(e===void 0){let y=Array.isArray(t)?t.reduce((A,S)=>A+S,0):t,d=Yr(r),g=U(a);if(!g)throw new Error(`Cannot roll array with dtype ${a}`);let b=new g(i),h=z(a);for(let A=0;A<i;A++){let S=((A-y)%i+i)%i,D=d.iget(S);b[A]=D}return N.fromData(b,[...n],a)}let u=Array.isArray(t)?t:[t],s=Array.isArray(e)?e:[e];if(u.length!==s.length)throw new Error("shift and axis must have the same length");let c=s.map(y=>{let d=y<0?o+y:y;if(d<0||d>=o)throw new Error(`axis ${y} is out of bounds for array of dimension ${o}`);return d}),l=U(a);if(!l)throw new Error(`Cannot roll array with dtype ${a}`);let m=new l(i),f=z(a),p=new Array(o).fill(0);for(let y=0;y<i;y++){let d=[...p];for(let h=0;h<c.length;h++){let A=c[h],S=n[A],D=u[h];d[A]=((d[A]-D)%S+S)%S}let g=r.offset;for(let h=0;h<o;h++)g+=d[h]*r.strides[h];let b=r.data[g];m[y]=b;for(let h=o-1;h>=0&&(p[h]++,!(p[h]<n[h]));h--)p[h]=0}return N.fromData(m,[...n],a)}function dn(r,t,e=0){let n=r.ndim,o=t<0?n+t:t;if(o<0||o>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let a=e<0?n+e:e;if(a<0||a>n)throw new Error(`start ${e} is out of bounds`);return o<a&&a--,o===a?N.fromData(r.data,Array.from(r.shape),r.dtype,Array.from(r.strides),r.offset):vt(r,o,a)}function gn(r,t){if(r.ndim<3)throw new Error("dsplit only works on arrays of 3 or more dimensions");return wr(r,t,2)}function An(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?W(e,[e.shape[0],1]):e);return Et(t)}function hn(r,t){let e=r.dtype,n=t.reduce((s,c)=>s*c,1),o=r.size,a=U(e);if(!a)throw new Error(`Cannot resize array with dtype ${e}`);let i=new a(n),u=z(e);for(let s=0;s<n;s++){let c=s%o,l=r.iget(c);i[s]=l}return N.fromData(i,t,e)}function bn(r){return r.map(t=>t.ndim===0?W(t,[1]):t)}function Sn(r){return r.map(t=>t.ndim===0?W(t,[1,1]):t.ndim===1?W(t,[1,t.shape[0]]):t)}function Nn(r){return r.map(t=>t.ndim===0?W(t,[1,1,1]):t.ndim===1?W(t,[1,t.shape[0],1]):t.ndim===2?W(t,[t.shape[0],t.shape[1],1]):t)}var Ot=k(()=>{"use strict";R();j()});function Ss(r,t,e,n,o,a,i,u,s,c,l,m,f,p){if(m===0)for(let b=0;b<n*o;b++)f[b]=0;else if(m!==1)for(let b=0;b<n*o;b++)f[b]=(f[b]??0)*m;let y=r==="row-major",d=t==="transpose",g=e==="transpose";if(y&&!d&&!g)for(let b=0;b<n;b++)for(let h=0;h<o;h++){let A=0;for(let S=0;S<a;S++)A+=(u[b*s+S]??0)*(c[S*l+h]??0);f[b*p+h]=(f[b*p+h]??0)+i*A}else if(y&&d&&!g)for(let b=0;b<n;b++)for(let h=0;h<o;h++){let A=0;for(let S=0;S<a;S++)A+=(u[S*s+b]??0)*(c[S*l+h]??0);f[b*p+h]=(f[b*p+h]??0)+i*A}else if(y&&!d&&g)for(let b=0;b<n;b++)for(let h=0;h<o;h++){let A=0;for(let S=0;S<a;S++)A+=(u[b*s+S]??0)*(c[h*l+S]??0);f[b*p+h]=(f[b*p+h]??0)+i*A}else if(y&&d&&g)for(let b=0;b<n;b++)for(let h=0;h<o;h++){let A=0;for(let S=0;S<a;S++)A+=(u[S*s+b]??0)*(c[h*l+S]??0);f[b*p+h]=(f[b*p+h]??0)+i*A}else if(!y&&!d&&!g)for(let b=0;b<n;b++)for(let h=0;h<o;h++){let A=0;for(let S=0;S<a;S++)A+=(u[S*s+b]??0)*(c[h*l+S]??0);f[h*p+b]=(f[h*p+b]??0)+i*A}else if(!y&&d&&!g)for(let b=0;b<n;b++)for(let h=0;h<o;h++){let A=0;for(let S=0;S<a;S++)A+=(u[b*s+S]??0)*(c[h*l+S]??0);f[h*p+b]=(f[h*p+b]??0)+i*A}else if(!y&&!d&&g)for(let b=0;b<n;b++)for(let h=0;h<o;h++){let A=0;for(let S=0;S<a;S++)A+=(u[S*s+b]??0)*(c[S*l+h]??0);f[h*p+b]=(f[h*p+b]??0)+i*A}else for(let b=0;b<n;b++)for(let h=0;h<o;h++){let A=0;for(let S=0;S<a;S++)A+=(u[b*s+S]??0)*(c[S*l+h]??0);f[h*p+b]=(f[h*p+b]??0)+i*A}}function Ut(r,t){let e=r.ndim,n=t.ndim;if(e===0||n===0){let o=e===0?r.get():null,a=n===0?t.get():null;if(e===0&&n===0)return typeof o=="bigint"&&typeof a=="bigint"?o*a:Number(o)*Number(a);if(e===0){let i=C(r.dtype,t.dtype),u=N.zeros([...t.shape],i);for(let s=0;s<t.size;s++){let c=t.data[s+t.offset];typeof o=="bigint"&&typeof c=="bigint"?u.data[s]=o*c:u.data[s]=Number(o)*Number(c)}return u}else{let i=C(r.dtype,t.dtype),u=N.zeros([...r.shape],i);for(let s=0;s<r.size;s++){let c=r.data[s+r.offset];typeof c=="bigint"&&typeof a=="bigint"?u.data[s]=c*a:u.data[s]=Number(c)*Number(a)}return u}}if(e===1&&n===1){if(r.shape[0]!==t.shape[0])throw new Error(`dot: incompatible shapes (${r.shape[0]},) and (${t.shape[0]},)`);let o=r.shape[0],a=0;for(let i=0;i<o;i++){let u=r.get(i),s=t.get(i);typeof u=="bigint"&&typeof s=="bigint"?a=Number(a)+Number(u*s):a+=Number(u)*Number(s)}return a}if(e===2&&n===2)return J(r,t);if(e===2&&n===1){let[o,a]=r.shape,i=t.shape[0];if(a!==i)throw new Error(`dot: incompatible shapes (${o},${a}) and (${i},)`);let u=C(r.dtype,t.dtype),s=N.zeros([o],u);for(let c=0;c<o;c++){let l=0;for(let m=0;m<a;m++){let f=r.get(c,m),p=t.get(m);typeof f=="bigint"&&typeof p=="bigint"?l=Number(l)+Number(f*p):l+=Number(f)*Number(p)}s.set([c],l)}return s}if(e===1&&n===2){let o=r.shape[0],[a,i]=t.shape;if(o!==a)throw new Error(`dot: incompatible shapes (${o},) and (${a},${i})`);let u=C(r.dtype,t.dtype),s=N.zeros([i],u);for(let c=0;c<i;c++){let l=0;for(let m=0;m<o;m++){let f=r.get(m),p=t.get(m,c);typeof f=="bigint"&&typeof p=="bigint"?l=Number(l)+Number(f*p):l+=Number(f)*Number(p)}s.set([c],l)}return s}if(e>2&&n===1){let o=r.shape[e-1],a=t.shape[0];if(o!==a)throw new Error(`dot: incompatible shapes ${JSON.stringify(r.shape)} and (${a},)`);let i=[...r.shape.slice(0,-1)],u=C(r.dtype,t.dtype),s=N.zeros(i,u),c=i.reduce((l,m)=>l*m,1);for(let l=0;l<c;l++){let m=0,f=l,p=[];for(let y=i.length-1;y>=0;y--)p[y]=f%i[y],f=Math.floor(f/i[y]);for(let y=0;y<o;y++){let d=[...p,y],g=r.get(...d),b=t.get(y);typeof g=="bigint"&&typeof b=="bigint"?m=Number(m)+Number(g*b):m+=Number(g)*Number(b)}s.set(p,m)}return s}if(e===1&&n>2){let o=r.shape[0],a=1,i=t.shape[a];if(o!==i)throw new Error(`dot: incompatible shapes (${o},) and ${JSON.stringify(t.shape)}`);let u=[...t.shape.slice(0,a),...t.shape.slice(a+1)],s=C(r.dtype,t.dtype),c=N.zeros(u,s),l=u.reduce((m,f)=>m*f,1);for(let m=0;m<l;m++){let f=m,p=[];for(let b=u.length-1;b>=0;b--)p[b]=f%u[b],f=Math.floor(f/u[b]);let y=p.slice(0,a),d=p.slice(a),g=0;for(let b=0;b<o;b++){let h=r.get(b),A=[...y,b,...d],S=t.get(...A);typeof h=="bigint"&&typeof S=="bigint"?g=Number(g)+Number(h*S):g+=Number(h)*Number(S)}c.set(p,g)}return c}if(e>=2&&n>=2&&!(e===2&&n===2)){let o=r.shape[e-1],a=t.shape[n-2];if(o!==a)throw new Error(`dot: incompatible shapes ${JSON.stringify(r.shape)} and ${JSON.stringify(t.shape)}`);let i=[...r.shape.slice(0,-1),...t.shape.slice(0,-2),t.shape[n-1]],u=C(r.dtype,t.dtype),s=N.zeros(i,u),c=r.shape.slice(0,-1).reduce((p,y)=>p*y,1),l=t.shape.slice(0,-2).reduce((p,y)=>p*y,1),m=t.shape[n-1],f=o;for(let p=0;p<c;p++)for(let y=0;y<l;y++)for(let d=0;d<m;d++){let g=0;for(let h=0;h<f;h++){let A=p*f+h,S=r.data[A+r.offset],D=y*f*m+h*m+d,x=t.data[D+t.offset];typeof S=="bigint"&&typeof x=="bigint"?g=Number(g)+Number(S*x):g+=Number(S)*Number(x)}let b=p*l*m+y*m+d;s.data[b]=g}return s}throw new Error(`dot: unexpected combination of dimensions ${e}D \xB7 ${n}D`)}function J(r,t){if(r.ndim!==2||t.ndim!==2)throw new Error("matmul requires 2D arrays");let[e=0,n=0]=r.shape,[o=0,a=0]=t.shape;if(n!==o)throw new Error(`matmul shape mismatch: (${e},${n}) @ (${o},${a})`);let i=C(r.dtype,t.dtype),u=i.startsWith("int")||i.startsWith("uint")||i==="bool"?"float64":i;if(u!=="float64")throw new Error(`matmul currently only supports float64, got ${u}`);let s=r.dtype==="float64"?r.data:Float64Array.from(Array.from(r.data).map(Number)),c=t.dtype==="float64"?t.data:Float64Array.from(Array.from(t.data).map(Number));r.offset>0&&(s=s.subarray(r.offset)),t.offset>0&&(c=c.subarray(t.offset));let[l=0,m=0]=r.strides,[f=0,p=0]=t.strides,y=m>l,d=p>f,g=y?"transpose":"no-transpose",b=d?"transpose":"no-transpose",h,A;y?h=m:h=l,d?A=p:A=f;let S=N.zeros([e,a],"float64");return Ss("row-major",g,b,e,a,n,1,s,h,c,A,0,S.data,a),S}function zn(r){if(r.ndim!==2)throw new Error(`trace requires 2D array, got ${r.ndim}D`);let[t=0,e=0]=r.shape,n=Math.min(t,e),o=0;for(let a=0;a<n;a++){let i=r.get(a,a);typeof i=="bigint"?o=(typeof o=="bigint"?o:BigInt(o))+i:o=(typeof o=="bigint"?Number(o):o)+i}return o}function xn(r,t){return xr(r,t)}function In(r,t){let e=r.ndim,n=t.ndim,o=r.shape[e-1],a=t.shape[n-1];if(o!==a)throw new Error(`inner: incompatible shapes - last dimensions ${o} and ${a} don't match`);if(e===1&&n===1)return Ut(r,t);let i=[...r.shape.slice(0,-1),...t.shape.slice(0,-1)],u=C(r.dtype,t.dtype),s=N.zeros(i,u),c=e===1?1:r.shape.slice(0,-1).reduce((f,p)=>f*p,1),l=n===1?1:t.shape.slice(0,-1).reduce((f,p)=>f*p,1),m=o;for(let f=0;f<c;f++)for(let p=0;p<l;p++){let y=0;for(let g=0;g<m;g++){let b=e===1?g:f*m+g,h=n===1?g:p*m+g,A=r.data[b+r.offset],S=t.data[h+t.offset];typeof A=="bigint"&&typeof S=="bigint"?y=Number(y)+Number(A*S):y+=Number(A)*Number(S)}if(i.length===0)return y;let d=c===1?p:f*l+p;s.data[d]=y}return s}function $t(r,t){let e=r.ndim===1?r:mr(r),n=t.ndim===1?t:mr(t),o=e.size,a=n.size,i=C(r.dtype,t.dtype),u=N.zeros([o,a],i);for(let s=0;s<o;s++)for(let c=0;c<a;c++){let l=e.get(s),m=n.get(c),f;typeof l=="bigint"&&typeof m=="bigint"?f=l*m:f=Number(l)*Number(m),u.set([s,c],f)}return u}function _n(r,t,e){let n,o;if(typeof e=="number"){let f=e;if(f<0)throw new Error("tensordot: axes must be non-negative");if(f>r.ndim||f>t.ndim)throw new Error("tensordot: axes exceeds array dimensions");n=Array.from({length:f},(p,y)=>r.ndim-f+y),o=Array.from({length:f},(p,y)=>y)}else if([n,o]=e,n.length!==o.length)throw new Error("tensordot: axes lists must have same length");for(let f=0;f<n.length;f++){let p=n[f],y=o[f];if(p<0||p>=r.ndim||y<0||y>=t.ndim)throw new Error("tensordot: axis out of bounds");if(r.shape[p]!==t.shape[y])throw new Error(`tensordot: shape mismatch on axes ${p} and ${y}: ${r.shape[p]} != ${t.shape[y]}`)}let a=[],i=[];for(let f=0;f<r.ndim;f++)n.includes(f)||a.push(f);for(let f=0;f<t.ndim;f++)o.includes(f)||i.push(f);let u=[...a.map(f=>r.shape[f]),...i.map(f=>t.shape[f])];if(u.length===0){let f=0,p=n.map(y=>r.shape[y]).reduce((y,d)=>y*d,1);for(let y=0;y<p;y++){let d=y,g=new Array(n.length);for(let D=n.length-1;D>=0;D--){let x=n[D];g[D]=d%r.shape[x],d=Math.floor(d/r.shape[x])}let b=new Array(r.ndim),h=new Array(t.ndim);for(let D=0;D<n.length;D++)b[n[D]]=g[D];for(let D=0;D<o.length;D++)h[o[D]]=g[D];let A=r.get(...b),S=t.get(...h);typeof A=="bigint"&&typeof S=="bigint"?f=Number(f)+Number(A*S):f+=Number(A)*Number(S)}return f}let s=C(r.dtype,t.dtype),c=N.zeros(u,s),l=u.reduce((f,p)=>f*p,1),m=n.map(f=>r.shape[f]).reduce((f,p)=>f*p,1);for(let f=0;f<l;f++){let p=f,y=[];for(let h=u.length-1;h>=0;h--)y[h]=p%u[h],p=Math.floor(p/u[h]);let d=y.slice(0,a.length),g=y.slice(a.length),b=0;for(let h=0;h<m;h++){p=h;let A=[];for(let _=n.length-1;_>=0;_--){let B=n[_];A[_]=p%r.shape[B],p=Math.floor(p/r.shape[B])}let S=new Array(r.ndim),D=new Array(t.ndim);for(let _=0;_<a.length;_++)S[a[_]]=d[_];for(let _=0;_<i.length;_++)D[i[_]]=g[_];for(let _=0;_<n.length;_++)S[n[_]]=A[_],D[o[_]]=A[_];let x=r.get(...S),w=t.get(...D);typeof x=="bigint"&&typeof w=="bigint"?b=Number(b)+Number(x*w):b+=Number(x)*Number(w)}c.set(y,b)}return c}function Bn(r,t=0,e=0,n=1){let o=r.shape,a=o.length;if(a<2)throw new Error("diagonal requires an array of at least two dimensions");let i=e<0?a+e:e,u=n<0?a+n:n;if(i<0||i>=a||u<0||u>=a)throw new Error("axis out of bounds");if(i===u)throw new Error("axis1 and axis2 cannot be the same");let s=o[i],c=o[u],l;t>=0?l=Math.max(0,Math.min(s,c-t)):l=Math.max(0,Math.min(s+t,c));let m=[];for(let d=0;d<a;d++)d!==i&&d!==u&&m.push(o[d]);m.push(l);let f=N.zeros(m,r.dtype),p=o.filter((d,g)=>g!==i&&g!==u),y=p.reduce((d,g)=>d*g,1);for(let d=0;d<y;d++){let g=d,b=[];for(let h=p.length-1;h>=0;h--)b.unshift(g%p[h]),g=Math.floor(g/p[h]);for(let h=0;h<l;h++){let A=new Array(a),S=0;for(let w=0;w<a;w++)w===i?A[w]=t>=0?h:h-t:w===u?A[w]=t>=0?h+t:h:A[w]=b[S++];let D=[...b,h],x=r.get(...A);f.set(D,x)}}return f}function vn(r,...t){let e=r.indexOf("->"),n,o;e===-1?(n=r,o=Ns(n)):(n=r.slice(0,e),o=r.slice(e+2));let a=n.split(",").map(d=>d.trim());if(a.length!==t.length)throw new Error(`einsum: expected ${a.length} operands, got ${t.length}`);let i=new Map;for(let d=0;d<t.length;d++){let g=a[d],b=t[d];if(g.length!==b.ndim)throw new Error(`einsum: operand ${d} has ${b.ndim} dimensions but subscript '${g}' has ${g.length} indices`);for(let h=0;h<g.length;h++){let A=g[h],S=b.shape[h];if(i.has(A)){if(i.get(A)!==S)throw new Error(`einsum: size mismatch for index '${A}': ${i.get(A)} vs ${S}`)}else i.set(A,S)}}for(let d of o)if(!i.has(d))throw new Error(`einsum: output subscript contains unknown index '${d}'`);let u=new Set(o),s=new Set;for(let d of a)for(let g of d)s.add(g);let c=[];for(let d of s)u.has(d)||c.push(d);if(t.length===2&&a.length===2){let[d,g]=a,[b,h]=t;if(d.length===2&&g.length===2&&o.length===2&&b.ndim===2&&h.ndim===2){let[A,S]=[d[0],d[1]],[D,x]=[g[0],g[1]],[w,_]=[o[0],o[1]];if(A===w&&x===_&&S===D&&c.length===1&&c[0]===S||A===w&&x===_&&S===D&&c.length===1&&c[0]===S)return J(b,h);if(S===w&&x===_&&A===D&&c.length===1&&c[0]===A){let B=xn(b);return J(B,h)}if(A===w&&D===_&&S===x&&c.length===1&&c[0]===S){let B=xn(h);return J(b,B)}}if(d.length===1&&g.length===1&&d===g&&o.length===0&&b.ndim===1&&h.ndim===1)return Tt(t,a,c,i);if(d&&g&&d.length===1&&g.length===1&&o.length===2&&o===d+g&&c.length===0&&b.ndim===1&&h.ndim===1)return $t(b,h)}if(t.length===1&&a[0].length===2&&o.length===0){let d=a[0];if(d[0]===d[1]&&t[0].ndim===2)return Tt(t,a,c,i)}let l=Array.from(o).map(d=>i.get(d));if(l.length===0)return Tt(t,a,c,i);let m=t[0].dtype;for(let d=1;d<t.length;d++)m=C(m,t[d].dtype);let f=N.zeros(l,m),p=l.reduce((d,g)=>d*g,1),y=1;for(let d of c)y*=i.get(d);for(let d=0;d<p;d++){let g=Ds(d,l),b=new Map;for(let A=0;A<o.length;A++)b.set(o[A],g[A]);let h=0;for(let A=0;A<y;A++){let S=A;for(let x=c.length-1;x>=0;x--){let w=c[x],_=i.get(w);b.set(w,S%_),S=Math.floor(S/_)}let D=1;for(let x=0;x<t.length;x++){let w=t[x],_=a[x],B=[];for(let E of _)B.push(b.get(E));let v=w.get(...B);D*=Number(v)}h+=D}f.set(g,h)}return f}function Ns(r){let t=new Map,e=r.split(",");for(let o of e)for(let a of o.trim())t.set(a,(t.get(a)||0)+1);let n=[];for(let[o,a]of t)a===1&&n.push(o);return n.sort().join("")}function Tt(r,t,e,n){let o=1;for(let i of e)o*=n.get(i);let a=0;for(let i=0;i<o;i++){let u=new Map,s=i;for(let l=e.length-1;l>=0;l--){let m=e[l],f=n.get(m);u.set(m,s%f),s=Math.floor(s/f)}let c=1;for(let l=0;l<r.length;l++){let m=r[l],f=t[l],p=[];for(let d of f)p.push(u.get(d));let y=m.get(...p);c*=Number(y)}a+=c}return a}function Ds(r,t){let e=new Array(t.length),n=r;for(let o=t.length-1;o>=0;o--)e[o]=n%t[o],n=Math.floor(n/t[o]);return e}function En(r,t){let e=r.shape,n=t.shape,o=e.length,a=n.length,i=C(r.dtype,t.dtype),u=Math.max(o,a),s=new Array(u),c=new Array(u).fill(1),l=new Array(u).fill(1);for(let y=0;y<o;y++)c[u-o+y]=e[y];for(let y=0;y<a;y++)l[u-a+y]=n[y];for(let y=0;y<u;y++)s[y]=c[y]*l[y];let m=N.zeros(s,i),f=e.reduce((y,d)=>y*d,1),p=n.reduce((y,d)=>y*d,1);for(let y=0;y<f;y++){let d=y,g=new Array(o);for(let A=o-1;A>=0;A--)g[A]=d%e[A],d=Math.floor(d/e[A]);let b=new Array(u).fill(0);for(let A=0;A<o;A++)b[u-o+A]=g[A];let h=r.get(...g);for(let A=0;A<p;A++){let S=A,D=new Array(a);for(let v=a-1;v>=0;v--)D[v]=S%n[v],S=Math.floor(S/n[v]);let x=new Array(u).fill(0);for(let v=0;v<a;v++)x[u-a+v]=D[v];let w=t.get(...D),_=new Array(u);for(let v=0;v<u;v++)_[v]=b[v]*l[v]+x[v];let B=typeof h=="bigint"||typeof w=="bigint"?BigInt(Number(h))*BigInt(Number(w)):Number(h)*Number(w);m.set(_,B)}}return m}function On(r,t,e=-1,n=-1,o=-1,a){a!==void 0&&(e=a,n=a,o=a);let i=(A,S)=>A<0?S+A:A,u=i(e,r.ndim),s=i(n,t.ndim);if(r.ndim===1&&t.ndim===1){let A=r.shape[0],S=t.shape[0];if(A===3&&S===3){let D=Number(r.get(0)),x=Number(r.get(1)),w=Number(r.get(2)),_=Number(t.get(0)),B=Number(t.get(1)),v=Number(t.get(2)),E=N.zeros([3],"float64");return E.set([0],x*v-w*B),E.set([1],w*_-D*v),E.set([2],D*B-x*_),E}else if(A===2&&S===2){let D=Number(r.get(0)),x=Number(r.get(1)),w=Number(t.get(0)),_=Number(t.get(1));return D*_-x*w}else if(A===2&&S===3||A===3&&S===2){let D=Number(r.get(0)),x=Number(r.get(1)),w=A===3?Number(r.get(2)):0,_=Number(t.get(0)),B=Number(t.get(1)),v=S===3?Number(t.get(2)):0,E=N.zeros([3],"float64");return E.set([0],x*v-w*B),E.set([1],w*_-D*v),E.set([2],D*B-x*_),E}else throw new Error(`cross: incompatible dimensions for cross product: ${A} and ${S}`)}let c=r.shape[u],l=t.shape[s];if(c!==2&&c!==3||l!==2&&l!==3)throw new Error(`cross: incompatible dimensions for cross product: ${c} and ${l}`);let m=c===2&&l===2?0:3,f=[...r.shape.slice(0,u),...r.shape.slice(u+1)],p=[...t.shape.slice(0,s),...t.shape.slice(s+1)];if(f.length!==p.length)throw new Error("cross: incompatible shapes for cross product");for(let A=0;A<f.length;A++)if(f[A]!==p[A])throw new Error("cross: incompatible shapes for cross product");let y=f,d=o<0?y.length+1+o:o,g;if(m===0?g=y:g=[...y.slice(0,d),m,...y.slice(d)],g.length===0)throw new Error("cross: unexpected scalar result from higher-dimensional input");let b=N.zeros(g,"float64"),h=y.reduce((A,S)=>A*S,1);for(let A=0;A<h;A++){let S=A,D=[];for(let Z=y.length-1;Z>=0;Z--)D[Z]=S%y[Z],S=Math.floor(S/y[Z]);let x=[...D.slice(0,u),0,...D.slice(u)],w=[...D.slice(0,s),0,...D.slice(s)],_=Z=>(x[u]=Z,Number(r.get(...x))),B=Z=>(w[s]=Z,Number(t.get(...w))),v=_(0),E=_(1),$=c===3?_(2):0,M=B(0),P=B(1),H=l===3?B(2):0;if(m===0)b.set(D,v*P-E*M);else{let Z=E*H-$*P,hr=$*M-v*H,La=v*P-E*M,it=(Wa,Za)=>{let Ga=[...D.slice(0,d),Wa,...D.slice(d)];b.set(Ga,Za)};it(0,Z),it(1,hr),it(2,La)}}return b}function pr(r,t=2,e,n=!1){if(typeof t!="number")throw new Error("vector_norm: ord must be a number");if(e==null){let c=r.ndim===1?r:mr(r),l=c.size,m;if(t===1/0){m=0;for(let f=0;f<l;f++)m=Math.max(m,Math.abs(Number(c.get(f))))}else if(t===-1/0){m=1/0;for(let f=0;f<l;f++)m=Math.min(m,Math.abs(Number(c.get(f))))}else if(t===0){m=0;for(let f=0;f<l;f++)Number(c.get(f))!==0&&m++}else if(t===1){m=0;for(let f=0;f<l;f++)m+=Math.abs(Number(c.get(f)))}else if(t===2){m=0;for(let f=0;f<l;f++){let p=Number(c.get(f));m+=p*p}m=Math.sqrt(m)}else{m=0;for(let f=0;f<l;f++)m+=Math.pow(Math.abs(Number(c.get(f))),t);m=Math.pow(m,1/t)}if(n){let f=new Array(r.ndim).fill(1),p=N.zeros(f,"float64");return p.set(new Array(r.ndim).fill(0),m),p}return m}let o=e<0?r.ndim+e:e;if(o<0||o>=r.ndim)throw new Error(`vector_norm: axis ${e} out of bounds for array with ${r.ndim} dimensions`);let a=n?[...r.shape.slice(0,o),1,...r.shape.slice(o+1)]:[...r.shape.slice(0,o),...r.shape.slice(o+1)];if(a.length===0)return pr(r,t,null,!1);let i=N.zeros(a,"float64"),u=r.shape[o],s=a.reduce((c,l)=>c*l,1);for(let c=0;c<s;c++){let l=c,m=[];for(let y=a.length-1;y>=0;y--)m[y]=l%a[y],l=Math.floor(l/a[y]);let f=n?[...m.slice(0,o),0,...m.slice(o+1)]:[...m.slice(0,o),0,...m.slice(o)],p;if(t===1/0){p=0;for(let y=0;y<u;y++)f[o]=y,p=Math.max(p,Math.abs(Number(r.get(...f))))}else if(t===-1/0){p=1/0;for(let y=0;y<u;y++)f[o]=y,p=Math.min(p,Math.abs(Number(r.get(...f))))}else if(t===0){p=0;for(let y=0;y<u;y++)f[o]=y,Number(r.get(...f))!==0&&p++}else if(t===1){p=0;for(let y=0;y<u;y++)f[o]=y,p+=Math.abs(Number(r.get(...f)))}else if(t===2){p=0;for(let y=0;y<u;y++){f[o]=y;let d=Number(r.get(...f));p+=d*d}p=Math.sqrt(p)}else{p=0;for(let y=0;y<u;y++)f[o]=y,p+=Math.pow(Math.abs(Number(r.get(...f))),t);p=Math.pow(p,1/t)}i.set(m,p)}return i}function ur(r,t="fro",e=!1){if(r.ndim!==2)throw new Error(`matrix_norm: input must be 2D, got ${r.ndim}D`);let[n,o]=r.shape,a;if(t==="fro"){a=0;for(let i=0;i<n;i++)for(let u=0;u<o;u++){let s=Number(r.get(i,u));a+=s*s}a=Math.sqrt(a)}else if(t==="nuc"){let{s:i}=or(r);a=0;for(let u=0;u<i.size;u++)a+=Number(i.get(u))}else if(t===1){a=0;for(let i=0;i<o;i++){let u=0;for(let s=0;s<n;s++)u+=Math.abs(Number(r.get(s,i)));a=Math.max(a,u)}}else if(t===-1){a=1/0;for(let i=0;i<o;i++){let u=0;for(let s=0;s<n;s++)u+=Math.abs(Number(r.get(s,i)));a=Math.min(a,u)}}else if(t===1/0){a=0;for(let i=0;i<n;i++){let u=0;for(let s=0;s<o;s++)u+=Math.abs(Number(r.get(i,s)));a=Math.max(a,u)}}else if(t===-1/0){a=1/0;for(let i=0;i<n;i++){let u=0;for(let s=0;s<o;s++)u+=Math.abs(Number(r.get(i,s)));a=Math.min(a,u)}}else if(t===2){let{s:i}=or(r);a=Number(i.get(0))}else if(t===-2){let{s:i}=or(r);a=Number(i.get(i.size-1))}else throw new Error(`matrix_norm: invalid ord value: ${t}`);if(e){let i=N.zeros([1,1],"float64");return i.set([0,0],a),i}return a}function Tn(r,t=null,e=null,n=!1){if(t===null)return e===null?pr(r,2,null,n):typeof e=="number"?pr(r,2,e,n):ur(r,"fro",n);if(Array.isArray(e)){if(e.length!==2)throw new Error("norm: axis must be a 2-tuple for matrix norms");let o=e[0]<0?r.ndim+e[0]:e[0],a=e[1]<0?r.ndim+e[1]:e[1];if(r.ndim!==2||o!==0&&o!==1||a!==0&&a!==1||o===a)throw new Error("norm: complex axis specification not yet supported");return ur(r,t,n)}if(r.ndim===2&&e===null&&(t==="fro"||t==="nuc"))return ur(r,t,n);if(typeof t!="number"&&t!==null)throw new Error(`norm: ord '${t}' not valid for vector norm`);return pr(r,t??2,e,n)}function Mt(r,t="reduced"){if(r.ndim!==2)throw new Error(`qr: input must be 2D, got ${r.ndim}D`);let[e,n]=r.shape,o=Math.min(e,n),a=N.zeros([e,n],"float64");for(let p=0;p<e;p++)for(let y=0;y<n;y++)a.set([p,y],Number(r.get(p,y)));let i=[],u=[];for(let p=0;p<o;p++){let y=e-p,d=[];for(let D=p;D<e;D++)d.push(Number(a.get(D,p)));let g=0;for(let D=0;D<y;D++)g+=d[D]*d[D];if(g=Math.sqrt(g),g<1e-15){i.push(d),u.push(0);continue}let b=d[0]>=0?1:-1,h=d[0]+b*g,A=[1];for(let D=1;D<y;D++)A.push(d[D]/h);let S=b*h/g;u.push(S),i.push(A);for(let D=p;D<n;D++){let x=0;for(let w=0;w<y;w++)x+=A[w]*Number(a.get(p+w,D));for(let w=0;w<y;w++)a.set([p+w,D],Number(a.get(p+w,D))-S*A[w]*x)}}if(t==="raw"){let p=N.zeros([e,n],"float64");for(let d=0;d<e;d++)for(let g=0;g<n;g++)p.set([d,g],Number(a.get(d,g)));let y=N.zeros([o],"float64");for(let d=0;d<o;d++)y.set([d],u[d]);return{h:p,tau:y}}if(t==="r"){let p=N.zeros([o,n],"float64");for(let y=0;y<o;y++)for(let d=y;d<n;d++)p.set([y,d],Number(a.get(y,d)));return p}let s=t==="complete"?e:o,c=N.zeros([e,s],"float64");for(let p=0;p<Math.min(e,s);p++)c.set([p,p],1);for(let p=o-1;p>=0;p--){let y=i[p],d=u[p],g=e-p;for(let b=p;b<s;b++){let h=0;for(let A=0;A<g;A++)h+=y[A]*Number(c.get(p+A,b));for(let A=0;A<g;A++)c.set([p+A,b],Number(c.get(p+A,b))-d*y[A]*h)}}let l=N.zeros([e,s],"float64");for(let p=0;p<e;p++)for(let y=0;y<s;y++)l.set([p,y],Number(c.get(p,y)));let m=t==="complete"?e:o,f=N.zeros([m,n],"float64");for(let p=0;p<m;p++)for(let y=0;y<n;y++)y>=p&&f.set([p,y],Number(a.get(p,y)));return{q:l,r:f}}function Un(r,t=!1){if(r.ndim!==2)throw new Error(`cholesky: input must be 2D, got ${r.ndim}D`);let[e,n]=r.shape;if(e!==n)throw new Error(`cholesky: matrix must be square, got ${e}x${n}`);let o=e,a=N.zeros([o,o],"float64");for(let i=0;i<o;i++)for(let u=0;u<=i;u++){let s=0;if(i===u){for(let l=0;l<u;l++)s+=Number(a.get(u,l))**2;let c=Number(r.get(u,u))-s;if(c<0)throw new Error("cholesky: matrix is not positive definite");a.set([u,u],Math.sqrt(c))}else{for(let l=0;l<u;l++)s+=Number(a.get(i,l))*Number(a.get(u,l));let c=Number(a.get(u,u));if(Math.abs(c)<1e-15)throw new Error("cholesky: matrix is not positive definite");a.set([i,u],(Number(r.get(i,u))-s)/c)}}if(t){let i=N.zeros([o,o],"float64");for(let u=0;u<o;u++)for(let s=u;s<o;s++)i.set([u,s],Number(a.get(s,u)));return i}return a}function or(r){if(r.ndim!==2)throw new Error(`svd: input must be 2D, got ${r.ndim}D`);let[t,e]=r.shape,n=Math.min(t,e),o=N.zeros([e,e],"float64");for(let m=0;m<e;m++)for(let f=0;f<e;f++){let p=0;for(let y=0;y<t;y++)p+=Number(r.get(y,m))*Number(r.get(y,f));o.set([m,f],p)}let{values:a,vectors:i}=kt(o),u=Array.from({length:e},(m,f)=>f);u.sort((m,f)=>a[f]-a[m]);let s=N.zeros([n],"float64");for(let m=0;m<n;m++){let f=a[u[m]];s.set([m],Math.sqrt(Math.max(0,f)))}let c=N.zeros([e,e],"float64");for(let m=0;m<e;m++)for(let f=0;f<e;f++)c.set([m,f],i[f][u[m]]);let l=N.zeros([t,t],"float64");for(let m=0;m<t;m++)for(let f=0;f<n;f++){let p=Number(s.get(f));if(p>1e-10){let y=0;for(let d=0;d<e;d++)y+=Number(r.get(m,d))*Number(c.get(f,d));l.set([m,f],y/p)}}if(t>n)for(let m=n;m<t;m++){let f=new Array(t).fill(0);f[m]=1;for(let y=0;y<m;y++){let d=0;for(let g=0;g<t;g++)d+=f[g]*Number(l.get(g,y));for(let g=0;g<t;g++)f[g]=f[g]-d*Number(l.get(g,y))}let p=0;for(let y=0;y<t;y++)p+=f[y]*f[y];if(p=Math.sqrt(p),p>1e-10)for(let y=0;y<t;y++)l.set([y,m],f[y]/p)}return{u:l,s,vt:c}}function kt(r){let t=r.shape[0],e=100*t*t,n=1e-10,o=[];for(let u=0;u<t;u++){o.push([]);for(let s=0;s<t;s++)o[u].push(Number(r.get(u,s)))}let a=[];for(let u=0;u<t;u++){a.push([]);for(let s=0;s<t;s++)a[u].push(u===s?1:0)}for(let u=0;u<e;u++){let s=0,c=0,l=1;for(let A=0;A<t;A++)for(let S=A+1;S<t;S++)Math.abs(o[A][S])>s&&(s=Math.abs(o[A][S]),c=A,l=S);if(s<n)break;let m=o[c][c],f=o[l][l],p=o[c][l],y;Math.abs(m-f)<1e-15?y=Math.PI/4:y=.5*Math.atan2(2*p,f-m);let d=Math.cos(y),g=Math.sin(y),b=d*d*m+g*g*f-2*g*d*p,h=g*g*m+d*d*f+2*g*d*p;o[c][c]=b,o[l][l]=h,o[c][l]=0,o[l][c]=0;for(let A=0;A<t;A++)if(A!==c&&A!==l){let S=o[A][c],D=o[A][l];o[A][c]=d*S-g*D,o[c][A]=o[A][c],o[A][l]=g*S+d*D,o[l][A]=o[A][l]}for(let A=0;A<t;A++){let S=a[A][c],D=a[A][l];a[A][c]=d*S-g*D,a[A][l]=g*S+d*D}}let i=[];for(let u=0;u<t;u++)i.push(o[u][u]);return{values:i,vectors:a}}function $n(r,t=!0,e=!0){let n=or(r);if(!e)return n.s;if(!t){let[o,a]=r.shape,i=Math.min(o,a),u=N.zeros([o,i],"float64");for(let c=0;c<o;c++)for(let l=0;l<i;l++)u.set([c,l],Number(n.u.get(c,l)));let s=N.zeros([i,a],"float64");for(let c=0;c<i;c++)for(let l=0;l<a;l++)s.set([c,l],Number(n.vt.get(c,l)));return{u,s:n.s,vt:s}}return n}function Mn(r){if(r.ndim!==2)throw new Error(`det: input must be 2D, got ${r.ndim}D`);let[t,e]=r.shape;if(t!==e)throw new Error(`det: matrix must be square, got ${t}x${e}`);let n=t;if(n===0)return 1;let o=r.data;if(n===1)return Number(o[0]);if(n===2)return Number(o[0])*Number(o[3])-Number(o[1])*Number(o[2]);let{lu:a,sign:i}=Ct(r),u=a.data,s=i;for(let c=0;c<n;c++)s*=u[c*n+c];return s}function Ct(r){let[t,e]=r.shape,n=t,o=e,a=N.zeros([n,o],"float64"),i=a.data,u=r.data;for(let l=0;l<n*o;l++)i[l]=Number(u[l]);let s=Array.from({length:n},(l,m)=>m),c=1;for(let l=0;l<Math.min(n,o);l++){let m=Math.abs(i[l*o+l]),f=l;for(let y=l+1;y<n;y++){let d=Math.abs(i[y*o+l]);d>m&&(m=d,f=y)}if(f!==l){for(let d=0;d<o;d++){let g=i[l*o+d];i[l*o+d]=i[f*o+d],i[f*o+d]=g}let y=s[l];s[l]=s[f],s[f]=y,c=-c}let p=i[l*o+l];if(Math.abs(p)>1e-15)for(let y=l+1;y<n;y++){let d=i[y*o+l]/p;i[y*o+l]=d;for(let g=l+1;g<o;g++)i[y*o+g]=i[y*o+g]-d*i[l*o+g]}}return{lu:a,piv:s,sign:c}}function Jr(r){if(r.ndim!==2)throw new Error(`inv: input must be 2D, got ${r.ndim}D`);let[t,e]=r.shape;if(t!==e)throw new Error(`inv: matrix must be square, got ${t}x${e}`);let n=t,{lu:o,piv:a}=Ct(r),i=o.data,u=N.zeros([n,n],"float64"),s=u.data;for(let c=0;c<n;c++){let l=new Float64Array(n);for(let m=0;m<n;m++){let f=a[m]===c?1:0;for(let p=0;p<m;p++)f-=i[m*n+p]*l[p];l[m]=f}for(let m=n-1;m>=0;m--){let f=l[m];for(let y=m+1;y<n;y++)f-=i[m*n+y]*s[y*n+c];let p=i[m*n+m];if(Math.abs(p)<1e-15)throw new Error("inv: singular matrix");s[m*n+c]=f/p}}return u}function wn(r,t){let[e]=r.shape,n=e,{lu:o,piv:a}=Ct(r),i=o.data,u=t.data,s=new Float64Array(n);for(let f=0;f<n;f++)s[f]=Number(u[a[f]]);let c=new Float64Array(n);for(let f=0;f<n;f++){let p=s[f];for(let y=0;y<f;y++)p-=i[f*n+y]*c[y];c[f]=p}let l=N.zeros([n],"float64"),m=l.data;for(let f=n-1;f>=0;f--){let p=c[f];for(let d=f+1;d<n;d++)p-=i[f*n+d]*m[d];let y=i[f*n+f];if(Math.abs(y)<1e-15)throw new Error("solve: singular matrix");m[f]=p/y}return l}function kn(r,t){if(r.ndim!==2)throw new Error(`solve: coefficient matrix must be 2D, got ${r.ndim}D`);let[e,n]=r.shape;if(e!==n)throw new Error(`solve: coefficient matrix must be square, got ${e}x${n}`);let o=e;if(t.ndim===1){if(t.shape[0]!==o)throw new Error(`solve: incompatible shapes (${e},${n}) and (${t.shape[0]},)`);return wn(r,t)}if(t.ndim===2){if(t.shape[0]!==o)throw new Error(`solve: incompatible shapes (${e},${n}) and (${t.shape[0]},${t.shape[1]})`);let a=t.shape[1],i=N.zeros([o,a],"float64");for(let u=0;u<a;u++){let s=N.zeros([o],"float64");for(let l=0;l<o;l++)s.set([l],Number(t.get(l,u)));let c=wn(r,s);for(let l=0;l<o;l++)i.set([l,u],Number(c.get(l)))}return i}throw new Error(`solve: b must be 1D or 2D, got ${t.ndim}D`)}function Cn(r,t,e=null){if(r.ndim!==2)throw new Error(`lstsq: coefficient matrix must be 2D, got ${r.ndim}D`);let[n,o]=r.shape,{u:a,s:i,vt:u}=or(r),s=Math.min(n,o),c=e??Math.max(n,o)*Number.EPSILON,m=Number(i.get(0))*c,f=0;for(let h=0;h<s;h++)Number(i.get(h))>m&&f++;let p=t.ndim===1?W(t,[t.size,1]):t,y=p.shape[1];if(p.shape[0]!==n)throw new Error(`lstsq: incompatible shapes (${n},${o}) and (${t.shape.join(",")})`);let d=N.zeros([o,y],"float64");for(let h=0;h<y;h++){let A=new Array(n).fill(0);for(let S=0;S<n;S++)for(let D=0;D<n;D++)A[S]+=Number(a.get(D,S))*Number(p.get(D,h));for(let S=0;S<o;S++){let D=0;for(let x=0;x<s;x++){let w=Number(i.get(x));w>m&&(D+=Number(u.get(x,S))*A[x]/w)}d.set([S,h],D)}}let g;if(n>o){g=N.zeros([y],"float64");for(let h=0;h<y;h++){let A=0;for(let S=0;S<n;S++){let D=0;for(let w=0;w<o;w++)D+=Number(r.get(S,w))*Number(d.get(w,h));let x=D-Number(p.get(S,h));A+=x*x}g.set([h],A)}}else g=N.zeros([0],"float64");return{x:t.ndim===1?W(d,[o]):d,residuals:g,rank:f,s:i}}function Vn(r,t=2){if(r.ndim!==2)throw new Error(`cond: input must be 2D, got ${r.ndim}D`);let[e,n]=r.shape;if(t===2||t===-2){let{s:u}=or(r),s=Math.min(e,n),c=Number(u.get(0)),l=Number(u.get(s-1));return t===2?l>0?c/l:1/0:c>0?l/c:0}if(e!==n)throw new Error(`cond: matrix must be square for p=${t}`);let o=ur(r,t),a=Jr(r),i=ur(a,t);return o*i}function Pn(r,t){if(r.ndim===0)return Number(r.get())!==0?1:0;if(r.ndim===1){for(let i=0;i<r.size;i++)if(Number(r.get(i))!==0)return 1;return 0}if(r.ndim!==2)throw new Error(`matrix_rank: input must be at most 2D, got ${r.ndim}D`);let{s:e}=or(r),n=Number(e.get(0)),o=t??n*Math.max(r.shape[0],r.shape[1])*Number.EPSILON,a=0;for(let i=0;i<e.size;i++)Number(e.get(i))>o&&a++;return a}function qn(r,t){if(r.ndim!==2)throw new Error(`matrix_power: input must be 2D, got ${r.ndim}D`);let[e,n]=r.shape;if(e!==n)throw new Error(`matrix_power: matrix must be square, got ${e}x${n}`);let o=e;if(!Number.isInteger(t))throw new Error("matrix_power: exponent must be an integer");if(t===0){let c=N.zeros([o,o],"float64");for(let l=0;l<o;l++)c.set([l,l],1);return c}let a=r,i=t;t<0&&(a=Jr(r),i=-t);let u=N.zeros([o,o],"float64");for(let c=0;c<o;c++)u.set([c,c],1);let s=N.zeros([o,o],"float64");for(let c=0;c<o;c++)for(let l=0;l<o;l++)s.set([c,l],Number(a.get(c,l)));for(;i>0;)i&1&&(u=J(u,s)),s=J(s,s),i>>=1;return u}function Fn(r,t=1e-15){if(r.ndim!==2)throw new Error(`pinv: input must be 2D, got ${r.ndim}D`);let[e,n]=r.shape,{u:o,s:a,vt:i}=or(r),u=Math.min(e,n),c=Number(a.get(0))*t,l=N.zeros([n,e],"float64");for(let m=0;m<n;m++)for(let f=0;f<e;f++){let p=0;for(let y=0;y<u;y++){let d=Number(a.get(y));d>c&&(p+=Number(i.get(y,m))*Number(o.get(f,y))/d)}l.set([m,f],p)}return l}function Vt(r){if(r.ndim!==2)throw new Error(`eig: input must be 2D, got ${r.ndim}D`);let[t,e]=r.shape;if(t!==e)throw new Error(`eig: matrix must be square, got ${t}x${e}`);let n=t,o=!0;r:for(let c=0;c<n;c++)for(let l=c+1;l<n;l++)if(Math.abs(Number(r.get(c,l))-Number(r.get(l,c)))>1e-10){o=!1;break r}if(o){let{values:c,vectors:l}=kt(r),m=N.zeros([n],"float64"),f=N.zeros([n,n],"float64");for(let p=0;p<n;p++){m.set([p],c[p]);for(let y=0;y<n;y++)f.set([y,p],l[y][p])}return{w:m,v:f}}console.warn("numpy-ts: eig() called on non-symmetric matrix. Complex eigenvalues are not supported; results may be inaccurate. For symmetric matrices, use eigh() instead.");let{values:a,vectors:i}=xs(r),u=N.zeros([n],"float64"),s=N.zeros([n,n],"float64");for(let c=0;c<n;c++){u.set([c],a[c]);for(let l=0;l<n;l++)s.set([l,c],i[l][c])}return{w:u,v:s}}function xs(r){let t=r.shape[0],e=1e3,n=1e-10,o=N.zeros([t,t],"float64");for(let s=0;s<t;s++)for(let c=0;c<t;c++)o.set([s,c],Number(r.get(s,c)));let a=N.zeros([t,t],"float64");for(let s=0;s<t;s++)a.set([s,s],1);for(let s=0;s<e;s++){let c=0;for(let p=0;p<t;p++)for(let y=0;y<t;y++)p!==y&&(c+=Number(o.get(p,y))**2);if(Math.sqrt(c)<n*t)break;let l=Mt(o,"reduced"),m=l.q,f=l.r;o=J(f,m),a=J(a,m)}let i=[];for(let s=0;s<t;s++)i.push(Number(o.get(s,s)));let u=[];for(let s=0;s<t;s++){u.push([]);for(let c=0;c<t;c++)u[s].push(Number(a.get(s,c)))}return{values:i,vectors:u}}function Pt(r,t="L"){if(r.ndim!==2)throw new Error(`eigh: input must be 2D, got ${r.ndim}D`);let[e,n]=r.shape;if(e!==n)throw new Error(`eigh: matrix must be square, got ${e}x${n}`);let o=e,a=N.zeros([o,o],"float64");for(let m=0;m<o;m++)for(let f=0;f<o;f++)t==="L"?m>=f&&(a.set([m,f],Number(r.get(m,f))),a.set([f,m],Number(r.get(m,f)))):f>=m&&(a.set([m,f],Number(r.get(m,f))),a.set([f,m],Number(r.get(m,f))));let{values:i,vectors:u}=kt(a),s=Array.from({length:o},(m,f)=>f);s.sort((m,f)=>i[m]-i[f]);let c=N.zeros([o],"float64"),l=N.zeros([o,o],"float64");for(let m=0;m<o;m++){c.set([m],i[s[m]]);for(let f=0;f<o;f++)l.set([f,m],u[f][s[m]])}return{w:c,v:l}}function Rn(r){let{w:t}=Vt(r);return t}function jn(r,t="L"){let{w:e}=Pt(r,t);return e}var Ln=k(()=>{"use strict";R();j();Ot()});function Wn(r){return V(r,Math.sqrt,!1)}function Zn(r,t){return typeof t=="number"?zs(r,t):L(r,t,Math.pow,"power")}function zs(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=e!=="float32"&&e!=="float64"&&(t<0||!Number.isInteger(t))?"float64":e,c=N.zeros(n,s),l=c.data;if(z(e))if(z(s)&&Number.isInteger(t)&&t>=0){let m=o,f=l;for(let p=0;p<a;p++)f[p]=m[p]**BigInt(t)}else for(let m=0;m<a;m++)l[m]=Math.pow(Number(o[m]),t);else for(let m=0;m<a;m++)l[m]=Math.pow(Number(o[m]),t);return c}function Gn(r){return V(r,Math.exp,!1)}function Hn(r){return V(r,t=>Math.pow(2,t),!1)}function Yn(r){return V(r,Math.expm1,!1)}function Jn(r){return V(r,Math.log,!1)}function Qn(r){return V(r,Math.log2,!1)}function Xn(r){return V(r,Math.log10,!1)}function Kn(r){return V(r,Math.log1p,!1)}function ro(r,t){return typeof t=="number"?_s(r,t):Is(r,t)}function Is(r,t){let e=br(r.shape,t.shape),n=e.reduce((c,l)=>c*l,1),o=r.dtype,a=t.dtype,i=o==="float32"&&a==="float32"?"float32":"float64",u=N.zeros(e,i),s=u.data;for(let c=0;c<n;c++){let l=(z(o),Number(r.iget(c))),m=(z(a),Number(t.iget(c))),f=Math.max(l,m),p=Math.min(l,m);s[c]=f+Math.log1p(Math.exp(p-f))}return u}function _s(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.size,a=e==="float32"?"float32":"float64",i=N.zeros(n,a),u=i.data;for(let s=0;s<o;s++){let c=(z(e),Number(r.data[s])),l=Math.max(c,t),m=Math.min(c,t);u[s]=l+Math.log1p(Math.exp(m-l))}return i}function to(r,t){return typeof t=="number"?vs(r,t):Bs(r,t)}function Bs(r,t){let e=br(r.shape,t.shape),n=e.reduce((l,m)=>l*m,1),o=r.dtype,a=t.dtype,i=o==="float32"&&a==="float32"?"float32":"float64",u=N.zeros(e,i),s=u.data,c=Math.LOG2E;for(let l=0;l<n;l++){let m=(z(o),Number(r.iget(l))),f=(z(a),Number(t.iget(l))),p=Math.max(m,f),y=Math.min(m,f);s[l]=p+Math.log1p(Math.pow(2,y-p))*c}return u}function vs(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.size,a=e==="float32"?"float32":"float64",i=N.zeros(n,a),u=i.data,s=Math.LOG2E;for(let c=0;c<o;c++){let l=(z(e),Number(r.data[c])),m=Math.max(l,t),f=Math.min(l,t);u[c]=m+Math.log1p(Math.pow(2,f-m))*s}return i}var eo=k(()=>{"use strict";R();sr();j()});function no(r){return V(r,Math.sin,!1)}function oo(r){return V(r,Math.cos,!1)}function ao(r){return V(r,Math.tan,!1)}function so(r){return V(r,Math.asin,!1)}function io(r){return V(r,Math.acos,!1)}function uo(r){return V(r,Math.atan,!1)}function co(r,t){return typeof t=="number"?Ts(r,t):Os(r,t)}function Os(r,t){let e=Array.from(r.shape),n=r.size,o=r.dtype,a=t.dtype,i=o==="float32"&&a==="float32"?"float32":"float64",u=N.zeros(e,i),s=u.data;for(let c=0;c<n;c++){let l=(z(o),Number(r.data[c])),m=(z(a),Number(t.data[c]));s[c]=Math.atan2(l,m)}return u}function Ts(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=e==="float32"?"float32":"float64",u=N.zeros(n,i),s=u.data;if(z(e))for(let c=0;c<a;c++)s[c]=Math.atan2(Number(o[c]),t);else for(let c=0;c<a;c++)s[c]=Math.atan2(Number(o[c]),t);return u}function lo(r,t){return typeof t=="number"?$s(r,t):Us(r,t)}function Us(r,t){let e=Array.from(r.shape),n=r.size,o=r.dtype,a=t.dtype,i=o==="float32"&&a==="float32"?"float32":"float64",u=N.zeros(e,i),s=u.data;for(let c=0;c<n;c++){let l=(z(o),Number(r.data[c])),m=(z(a),Number(t.data[c]));s[c]=Math.hypot(l,m)}return u}function $s(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=e==="float32"?"float32":"float64",u=N.zeros(n,i),s=u.data;if(z(e))for(let c=0;c<a;c++)s[c]=Math.hypot(Number(o[c]),t);else for(let c=0;c<a;c++)s[c]=Math.hypot(Number(o[c]),t);return u}function fo(r){let t=180/Math.PI;return V(r,e=>e*t,!1)}function mo(r){let t=Math.PI/180;return V(r,e=>e*t,!1)}var po=k(()=>{"use strict";R();sr();j()});function yo(r){return V(r,Math.sinh,!1)}function go(r){return V(r,Math.cosh,!1)}function Ao(r){return V(r,Math.tanh,!1)}function ho(r){return V(r,Math.asinh,!1)}function bo(r){return V(r,Math.acosh,!1)}function So(r){return V(r,Math.atanh,!1)}var No=k(()=>{"use strict";sr()});function qt(r,t){let e=r.shape,n=e.length,o=t.length;if(o<n)throw new Error("input operand has more dimensions than allowed by the axis remapping");let a=nr([Array.from(e),t]);if(a===null)throw new Error(`operands could not be broadcast together with shape (${e.join(",")}) (${t.join(",")})`);for(let i=0;i<o;i++)if(a[i]!==t[i])throw new Error(`operands could not be broadcast together with shape (${e.join(",")}) (${t.join(",")})`);return X(r,t)}function Do(r){if(r.length===0)return[];if(r.length===1)return[r[0]];let t=r.map(n=>Array.from(n.shape)),e=nr(t);if(e===null)throw new Error(`operands could not be broadcast together with shapes ${t.map(n=>`(${n.join(",")})`).join(" ")}`);return r.map(n=>X(n,e))}function xo(r,t,e){let n=r.shape,o=n.length,a=r.dtype;if(e===void 0){let y=r.size;for(let h of t){let A=h<0?y+h:h;if(A<0||A>=y)throw new Error(`index ${h} is out of bounds for axis 0 with size ${y}`)}let d=t.length,g=U(a);if(!g)throw new Error(`Cannot take from array with dtype ${a}`);let b=new g(d);for(let h=0;h<d;h++){let A=t[h];A<0&&(A=y+A);let S=r.iget(A);z(a),b[h]=S}return N.fromData(b,[d],a)}let i=e<0?o+e:e;if(i<0||i>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let u=n[i];for(let y of t){let d=y<0?u+y:y;if(d<0||d>=u)throw new Error(`index ${y} is out of bounds for axis ${i} with size ${u}`)}let s=Array.from(n);s[i]=t.length;let c=s.reduce((y,d)=>y*d,1),l=U(a);if(!l)throw new Error(`Cannot take from array with dtype ${a}`);let m=new l(c),f=G(s),p=new Array(o).fill(0);for(let y=0;y<c;y++){let d=[...p],g=p[i],b=t[g];b<0&&(b=u+b),d[i]=b;let h=r.get(...d),A=0;for(let S=0;S<o;S++)A+=p[S]*f[S];z(a),m[A]=h;for(let S=o-1;S>=0&&(p[S]++,!(p[S]<s[S]));S--)p[S]=0}return N.fromData(m,s,a)}function wo(r,t,e){let n=r.size,o=r.dtype,a;if(typeof e=="number"||typeof e=="bigint")a=new Array(t.length).fill(e);else{a=[];for(let i=0;i<e.size;i++)a.push(e.iget(i));if(a.length===1)a=new Array(t.length).fill(a[0]);else if(a.length!==t.length){let i=[...a];a=[];for(let u=0;u<t.length;u++)a.push(i[u%i.length])}}for(let i=0;i<t.length;i++){let u=t[i];if(u<0&&(u=n+u),u<0||u>=n)throw new Error(`index ${t[i]} is out of bounds for axis 0 with size ${n}`);let s=a[i];z(o)?typeof s!="bigint"&&(s=BigInt(Math.round(Number(s)))):typeof s=="bigint"&&(s=Number(s)),r.iset(u,s)}}function zo(r,t){if(t.length===0)throw new Error("choices cannot be empty");let e=r.shape,n=t.length,o=t[0].dtype,a=t.map(f=>Array.from(f.shape));a.unshift(Array.from(e));let i=nr(a);if(i===null)throw new Error("operands could not be broadcast together");let u=X(r,i),s=t.map(f=>X(f,i)),c=i.reduce((f,p)=>f*p,1),l=U(o);if(!l)throw new Error(`Cannot choose with dtype ${o}`);let m=new l(c);for(let f=0;f<c;f++){let p=Number(u.iget(f));if(p<0||p>=n)throw new Error(`index ${p} is out of bounds for axis 0 with size ${n}`);let y=s[p].iget(f);z(o),m[f]=y}return N.fromData(m,i,o)}function Io(r,t,e=!1){if(r.ndim!==t.ndim)return!1;for(let o=0;o<r.ndim;o++)if(r.shape[o]!==t.shape[o])return!1;let n=r.size;for(let o=0;o<n;o++){let a=r.iget(o),i=t.iget(o);if(e){let u=typeof a=="number"&&Number.isNaN(a),s=typeof i=="number"&&Number.isNaN(i);if(u&&s)continue}if(a!==i)return!1}return!0}function _o(r,t,e){let n=r.shape,o=n.length,a=r.dtype,i=e<0?o+e:e;if(i<0||i>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let u=t.shape;if(u.length!==o)throw new Error(`indices and arr must have the same number of dimensions, got ${u.length} vs ${o}`);for(let d=0;d<o;d++)if(d!==i&&u[d]!==n[d]&&u[d]!==1&&n[d]!==1)throw new Error(`index ${u[d]} is out of bounds for size ${n[d]} in dimension ${d}`);let s=Array.from(u),c=s.reduce((d,g)=>d*g,1),l=U(a);if(!l)throw new Error(`Cannot take_along_axis with dtype ${a}`);let m=new l(c),f=G(n),p=G(u),y=n[i];for(let d=0;d<c;d++){let g=new Array(o),b=d;for(let w=o-1;w>=0;w--)g[w]=b%s[w],b=Math.floor(b/s[w]);let h=0;for(let w=0;w<o;w++){let _=u[w]===1?0:g[w];h+=_*p[w]}let A=Number(t.iget(h));if(A<0&&(A=y+A),A<0||A>=y)throw new Error(`index ${A} is out of bounds for axis ${i} with size ${y}`);let S=[...g];S[i]=A;let D=0;for(let w=0;w<o;w++){let _=n[w]===1?0:S[w];D+=_*f[w]}let x=r.iget(D);z(a),m[d]=x}return N.fromData(m,s,a)}function Bo(r,t,e,n){let o=r.shape,a=o.length,i=r.dtype,u=n<0?a+n:n;if(u<0||u>=a)throw new Error(`axis ${n} is out of bounds for array of dimension ${a}`);let s=t.shape,c=e.shape;if(s.length!==a||c.length!==a)throw new Error("indices, arr, and values must have same ndim");let l=o[u],m=G(o),f=G(s),p=G(c),y=s.reduce((d,g)=>d*g,1);for(let d=0;d<y;d++){let g=new Array(a),b=d;for(let _=a-1;_>=0;_--)g[_]=b%s[_],b=Math.floor(b/s[_]);let h=0;for(let _=0;_<a;_++)h+=g[_]*f[_];let A=Number(t.iget(h));if(A<0&&(A=l+A),A<0||A>=l)throw new Error(`index ${A} is out of bounds for axis ${u} with size ${l}`);let S=0;for(let _=0;_<a;_++){let B=c[_]===1?0:g[_];S+=B*p[_]}let D=e.iget(S),x=[...g];x[u]=A;let w=0;for(let _=0;_<a;_++)w+=x[_]*m[_];z(i)?typeof D!="bigint"&&(D=BigInt(Math.round(Number(D)))):typeof D=="bigint"&&(D=Number(D)),r.iset(w,D)}}function vo(r,t,e){let n=r.size,o=r.dtype,a;if(typeof e=="number"||typeof e=="bigint")a=[e];else{a=[];for(let u=0;u<e.size;u++)a.push(e.iget(u))}let i=0;for(let u=0;u<n;u++)if(t.iget(u)){let c=a[i%a.length];z(o)?typeof c!="bigint"&&(c=BigInt(Math.round(Number(c)))):typeof c=="bigint"&&(c=Number(c)),r.iset(u,c),i++}}function Eo(r,t,e){let n=t.shape,o=n.length,a=t.dtype,i=t.data,u=z(a);if(e===void 0){let h=0,A=Math.min(r.size,t.size);for(let w=0;w<A;w++)r.iget(w)&&h++;let S=U(a);if(!S)throw new Error(`Cannot compress with dtype ${a}`);let D=new S(h),x=0;for(let w=0;w<A;w++)r.iget(w)&&(D[x]=i[w],x++);return N.fromData(D,[h],a)}let s=e<0?o+e:e;if(s<0||s>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let c=n[s],l=Math.min(r.size,c),m=[];for(let h=0;h<l;h++)r.iget(h)&&m.push(h);let f=m.length,p=[...n];p[s]=f;let y=p.reduce((h,A)=>h*A,1),d=U(a);if(!d)throw new Error(`Cannot compress with dtype ${a}`);let g=new d(y),b=G(n);if(s===0){let h=b[0],A=n.slice(1).reduce((D,x)=>D*x,1),S=0;for(let D=0;D<f;D++){let w=m[D]*h;if(u){let _=i,B=g;for(let v=0;v<A;v++)B[S++]=_[w+v]}else{let _=i,B=g;for(let v=0;v<A;v++)B[S++]=_[w+v]}}}else{let h=n.slice(0,s).reduce((D,x)=>D*x,1),A=n.slice(s+1).reduce((D,x)=>D*x,1),S=0;for(let D=0;D<h;D++)for(let x=0;x<f;x++){let w=m[x],_=0,B=D;for(let v=s-1;v>=0;v--){let E=B%n[v];B=Math.floor(B/n[v]),_+=E*b[v]}if(_+=w*b[s],u){let v=i,E=g;for(let $=0;$<A;$++)E[S++]=v[_+$]}else{let v=i,E=g;for(let $=0;$<A;$++)E[S++]=v[_+$]}}}return N.fromData(g,p,a)}function Oo(r,t,e=0){if(r.length!==t.length)throw new Error("condlist and choicelist must have same length");if(r.length===0)throw new Error("condlist and choicelist cannot be empty");let n=[...r.map(f=>Array.from(f.shape)),...t.map(f=>Array.from(f.shape))],o=nr(n);if(o===null)throw new Error("condlist and choicelist arrays could not be broadcast together");let a=t[0].dtype,i=o.reduce((f,p)=>f*p,1),u=U(a);if(!u)throw new Error(`Cannot select with dtype ${a}`);let s=e;z(a)?s=typeof e=="bigint"?e:BigInt(e):s=typeof e=="bigint"?Number(e):e;let c=new u(i);for(let f=0;f<i;f++)z(a),c[f]=s;let l=r.map(f=>X(f,o)),m=t.map(f=>X(f,o));for(let f=0;f<i;f++)for(let p=0;p<r.length;p++)if(l[p].iget(f)){let y=m[p].iget(f);z(a),c[f]=y;break}return N.fromData(c,o,a)}function To(r,t,e){let n=r.size,o=r.dtype,a=[];for(let u=0;u<e.size;u++)a.push(e.iget(u));if(a.length===0)return;let i=0;for(let u=0;u<n;u++)if(t.iget(u)){let c=a[i%a.length];z(o)?typeof c!="bigint"&&(c=BigInt(Math.round(Number(c)))):typeof c=="bigint"&&(c=Number(c)),r.iset(u,c),i++}}function Ft(r,t=2){if(t<1)throw new Error("ndim must be at least 1");let e=new Int32Array(r);for(let o=0;o<r;o++)e[o]=o;let n=[];for(let o=0;o<t;o++)n.push(N.fromData(new Int32Array(e),[r],"int32"));return n}function Uo(r){let t=r.shape,e=t.length;if(e<2)throw new Error("array must be at least 2-D");let n=t[0];for(let o=1;o<e;o++)if(t[o]!==n)throw new Error("All dimensions of input must be equal");return Ft(n,e)}function Rt(r,t=0,e){let n=e??r,o=[],a=[];for(let i=0;i<r;i++)for(let u=0;u<=Math.min(i+t,n-1);u++)u>=0&&(o.push(i),a.push(u));return[N.fromData(new Int32Array(o),[o.length],"int32"),N.fromData(new Int32Array(a),[a.length],"int32")]}function $o(r,t=0){let e=r.shape;if(e.length!==2)throw new Error("array must be 2-D");return Rt(e[0],t,e[1])}function jt(r,t=0,e){let n=e??r,o=[],a=[];for(let i=0;i<r;i++)for(let u=Math.max(i+t,0);u<n;u++)o.push(i),a.push(u);return[N.fromData(new Int32Array(o),[o.length],"int32"),N.fromData(new Int32Array(a),[a.length],"int32")]}function Mo(r,t=0){let e=r.shape;if(e.length!==2)throw new Error("array must be 2-D");return jt(e[0],t,e[1])}function ko(r,t,e=0){let n=t(r,e),o=n.shape;if(o.length!==2||o[0]!==r||o[1]!==r)throw new Error("mask_func must return n x n array");let a=[],i=[];for(let u=0;u<r;u++)for(let s=0;s<r;s++)n.get(u,s)&&(a.push(u),i.push(s));return[N.fromData(new Int32Array(a),[a.length],"int32"),N.fromData(new Int32Array(i),[i.length],"int32")]}function Co(r,t="int32"){let e=r.length,n=[e,...r],o=n.reduce((s,c)=>s*c,1),a=U(t);if(!a)throw new Error(`Cannot create indices with dtype ${t}`);let i=new a(o),u=r.reduce((s,c)=>s*c,1);for(let s=0;s<e;s++){let c=s*u;for(let l=0;l<u;l++){let m=new Array(e),f=l;for(let y=e-1;y>=0;y--)m[y]=f%r[y],f=Math.floor(f/r[y]);let p=m[s];t==="int64"?i[c+l]=BigInt(p):i[c+l]=p}}return N.fromData(i,n,t)}function Vo(...r){let t=r.length,e=[];for(let n=0;n<t;n++){let o=r[n],a=o.size,i=o.dtype,u=new Array(t).fill(1);u[n]=a;let s=U(i);if(!s)throw new Error(`Cannot create ix_ with dtype ${i}`);let c=new s(a);for(let l=0;l<a;l++){let m=o.iget(l);z(i),c[l]=m}e.push(N.fromData(c,u,i))}return e}function Po(r,t,e="raise"){if(r.length!==t.length)throw new Error("multi_index length must equal dims length");if(r.length===0)throw new Error("multi_index cannot be empty");let n=r[0].size,o=t.length,a=new Int32Array(n),i=new Array(o),u=1;for(let s=o-1;s>=0;s--)i[s]=u,u*=t[s];for(let s=0;s<n;s++){let c=0;for(let l=0;l<o;l++){let m=Number(r[l].iget(s)),f=t[l];if(e==="wrap")m=(m%f+f)%f;else if(e==="clip")m=Math.max(0,Math.min(m,f-1));else if(m<0||m>=f)throw new Error(`index ${m} is out of bounds for axis ${l} with size ${f}`);c+=m*i[l]}a[s]=c}return N.fromData(a,[n],"int32")}function qo(r,t,e="C"){let n=t.length,o,a;if(typeof r=="number")o=[r],a=[];else{o=[];for(let l=0;l<r.size;l++)o.push(Number(r.iget(l)));a=Array.from(r.shape)}let i=o.length,u=t.reduce((l,m)=>l*m,1),s=new Array(n);if(e==="C"){let l=1;for(let m=n-1;m>=0;m--)s[m]=l,l*=t[m]}else{let l=1;for(let m=0;m<n;m++)s[m]=l,l*=t[m]}let c=[];for(let l=0;l<n;l++){let m=new Int32Array(i);c.push(N.fromData(m,a.length?a:[1],"int32"))}for(let l=0;l<i;l++){let m=o[l];if(m<0||m>=u)throw new Error(`index ${m} is out of bounds for array with size ${u}`);if(e==="C")for(let f=0;f<n;f++){let p=Math.floor(m/s[f]);m=m%s[f],c[f].data[l]=p%t[f]}else for(let f=n-1;f>=0;f--){let p=Math.floor(m/s[f]);m=m%s[f],c[f].data[l]=p%t[f]}}return typeof r=="number"?c.map(l=>{let m=l.iget(0);return N.fromData(new Int32Array([Number(m)]),[],"int32")}):c}var Fo=k(()=>{"use strict";R();j();mt()});function Q(r,t){if(!Ie(r)&&r!=="bool")throw new TypeError(`ufunc '${t}' not supported for the input types, and the inputs could not be safely coerced to any supported types`)}function zr(r,t){return r.isCContiguous&&t.isCContiguous&&r.shape.length===t.shape.length&&r.shape.every((e,n)=>e===t.shape[n])}function Lo(r,t){return Q(r.dtype,"bitwise_and"),typeof t=="number"?Ps(r,t):(Q(t.dtype,"bitwise_and"),zr(r,t)?Vs(r,t):L(r,t,(e,n)=>e&n,"bitwise_and"))}function Vs(r,t){let e=C(r.dtype,t.dtype),n=N.zeros(Array.from(r.shape),e),o=r.size,a=r.data,i=t.data,u=n.data;if(z(e)){let s=u;if(!z(r.dtype)||!z(t.dtype))for(let l=0;l<o;l++){let m=typeof a[l]=="bigint"?a[l]:BigInt(Math.round(Number(a[l]))),f=typeof i[l]=="bigint"?i[l]:BigInt(Math.round(Number(i[l])));s[l]=m&f}else{let l=a,m=i;for(let f=0;f<o;f++)s[f]=l[f]&m[f]}}else for(let s=0;s<o;s++)u[s]=a[s]&i[s];return n}function Ps(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]&l}else for(let s=0;s<a;s++)u[s]=o[s]&t;return i}function Wo(r,t){return Q(r.dtype,"bitwise_or"),typeof t=="number"?Fs(r,t):(Q(t.dtype,"bitwise_or"),zr(r,t)?qs(r,t):L(r,t,(e,n)=>e|n,"bitwise_or"))}function qs(r,t){let e=C(r.dtype,t.dtype),n=N.zeros(Array.from(r.shape),e),o=r.size,a=r.data,i=t.data,u=n.data;if(z(e)){let s=u;if(!z(r.dtype)||!z(t.dtype))for(let l=0;l<o;l++){let m=typeof a[l]=="bigint"?a[l]:BigInt(Math.round(Number(a[l]))),f=typeof i[l]=="bigint"?i[l]:BigInt(Math.round(Number(i[l])));s[l]=m|f}else{let l=a,m=i;for(let f=0;f<o;f++)s[f]=l[f]|m[f]}}else for(let s=0;s<o;s++)u[s]=a[s]|i[s];return n}function Fs(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]|l}else for(let s=0;s<a;s++)u[s]=o[s]|t;return i}function Zo(r,t){return Q(r.dtype,"bitwise_xor"),typeof t=="number"?js(r,t):(Q(t.dtype,"bitwise_xor"),zr(r,t)?Rs(r,t):L(r,t,(e,n)=>e^n,"bitwise_xor"))}function Rs(r,t){let e=C(r.dtype,t.dtype),n=N.zeros(Array.from(r.shape),e),o=r.size,a=r.data,i=t.data,u=n.data;if(z(e)){let s=u;if(!z(r.dtype)||!z(t.dtype))for(let l=0;l<o;l++){let m=typeof a[l]=="bigint"?a[l]:BigInt(Math.round(Number(a[l]))),f=typeof i[l]=="bigint"?i[l]:BigInt(Math.round(Number(i[l])));s[l]=m^f}else{let l=a,m=i;for(let f=0;f<o;f++)s[f]=l[f]^m[f]}}else for(let s=0;s<o;s++)u[s]=a[s]^i[s];return n}function js(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]^l}else for(let s=0;s<a;s++)u[s]=o[s]^t;return i}function Lt(r){Q(r.dtype,"bitwise_not");let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=N.zeros(e,t),i=a.data;if(z(t)){let u=n,s=i;for(let c=0;c<o;c++)s[c]=~u[c]}else for(let u=0;u<o;u++)i[u]=~n[u];return a}function Go(r){return Lt(r)}function Ho(r,t){if(Q(r.dtype,"left_shift"),typeof t=="number")return Ro(r,t);if(Q(t.dtype,"left_shift"),t.size===1||t.ndim===1&&t.shape[0]===1){let e=z(t.dtype)?Number(t.data[0]):t.data[0];return Ro(r,e)}return zr(r,t)?Ls(r,t):L(r,t,(e,n)=>e<<n,"left_shift")}function Ls(r,t){let e=C(r.dtype,t.dtype),n=N.zeros(Array.from(r.shape),e),o=r.size,a=r.data,i=t.data,u=n.data;if(z(e)){let s=u;for(let c=0;c<o;c++){let l=typeof a[c]=="bigint"?a[c]:BigInt(Math.round(Number(a[c]))),m=typeof i[c]=="bigint"?i[c]:BigInt(Math.round(Number(i[c])));s[c]=l<<m}}else for(let s=0;s<o;s++)u[s]=a[s]<<i[s];return n}function Ro(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]<<l}else for(let s=0;s<a;s++)u[s]=o[s]<<t;return i}function Yo(r,t){if(Q(r.dtype,"right_shift"),typeof t=="number")return jo(r,t);if(Q(t.dtype,"right_shift"),t.size===1||t.ndim===1&&t.shape[0]===1){let e=z(t.dtype)?Number(t.data[0]):t.data[0];return jo(r,e)}return zr(r,t)?Ws(r,t):L(r,t,(e,n)=>e>>n,"right_shift")}function Ws(r,t){let e=C(r.dtype,t.dtype),n=N.zeros(Array.from(r.shape),e),o=r.size,a=r.data,i=t.data,u=n.data;if(z(e)){let s=u;for(let c=0;c<o;c++){let l=typeof a[c]=="bigint"?a[c]:BigInt(Math.round(Number(a[c]))),m=typeof i[c]=="bigint"?i[c]:BigInt(Math.round(Number(i[c])));s[c]=l>>m}}else for(let s=0;s<o;s++)u[s]=a[s]>>i[s];return n}function jo(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=N.zeros(n,e),u=i.data;if(z(e)){let s=o,c=u,l=BigInt(Math.round(t));for(let m=0;m<a;m++)c[m]=s[m]>>l}else for(let s=0;s<a;s++)u[s]=o[s]>>t;return i}function Jo(r,t=-1,e="big"){let n=Array.from(r.shape),o=n.length;if(t<0&&(t=o+t),t<0||t>=o)throw new Error(`axis ${t} is out of bounds for array of dimension ${o}`);let a=n[t],i=Math.ceil(a/8),u=[...n];u[t]=i;let s=N.zeros(u,"uint8"),c=s.data;if(o===1){for(let g=0;g<i;g++){let b=0;for(let h=0;h<8;h++){let A=g*8+h;if(A<a){let S=Number(r.data[A])!==0?1:0;e==="big"?b|=S<<7-h:b|=S<<h}}c[g]=b}return s}let l=n.slice(0,t),m=n.slice(t+1),f=l.reduce((g,b)=>g*b,1),p=m.reduce((g,b)=>g*b,1),y=Qr(n),d=Qr(u);for(let g=0;g<f;g++)for(let b=0;b<p;b++)for(let h=0;h<i;h++){let A=0;for(let w=0;w<8;w++){let _=h*8+w;if(_<a){let B=0,v=g;for(let M=0;M<t;M++){let P=M<t-1?l.slice(M+1).reduce((Z,hr)=>Z*hr,1):1,H=Math.floor(v/P);v%=P,B+=H*y[M]}B+=_*y[t];let E=b;for(let M=t+1;M<o;M++){let P=M<o-1?m.slice(M-t).reduce((Z,hr)=>Z*hr,1):1,H=Math.floor(E/P);E%=P,B+=H*y[M]}let $=Number(r.data[B])!==0?1:0;e==="big"?A|=$<<7-w:A|=$<<w}}let S=0,D=g;for(let w=0;w<t;w++){let _=w<t-1?l.slice(w+1).reduce((v,E)=>v*E,1):1,B=Math.floor(D/_);D%=_,S+=B*d[w]}S+=h*d[t];let x=b;for(let w=t+1;w<o;w++){let _=w<o-1?m.slice(w-t).reduce((v,E)=>v*E,1):1,B=Math.floor(x/_);x%=_,S+=B*d[w]}c[S]=A}return s}function Qo(r,t=-1,e=-1,n="big"){if(r.dtype!=="uint8")throw new TypeError("Expected an input array of unsigned byte data type");let o=Array.from(r.shape),a=o.length;if(t<0&&(t=a+t),t<0||t>=a)throw new Error(`axis ${t} is out of bounds for array of dimension ${a}`);let i=o[t],u=i*8;e>=0&&(u=e);let s=[...o];s[t]=u;let c=N.zeros(s,"uint8"),l=c.data;if(a===1){for(let b=0;b<i;b++){let h=Number(r.data[b]);for(let A=0;A<8;A++){let S=b*8+A;if(S>=u)break;n==="big"?l[S]=h>>7-A&1:l[S]=h>>A&1}}return c}let m=o.slice(0,t),f=o.slice(t+1),p=m.reduce((b,h)=>b*h,1),y=f.reduce((b,h)=>b*h,1),d=Qr(o),g=Qr(s);for(let b=0;b<p;b++)for(let h=0;h<y;h++)for(let A=0;A<i;A++){let S=0,D=b;for(let _=0;_<t;_++){let B=_<t-1?m.slice(_+1).reduce((E,$)=>E*$,1):1,v=Math.floor(D/B);D%=B,S+=v*d[_]}S+=A*d[t];let x=h;for(let _=t+1;_<a;_++){let B=_<a-1?f.slice(_-t).reduce((E,$)=>E*$,1):1,v=Math.floor(x/B);x%=B,S+=v*d[_]}let w=Number(r.data[S]);for(let _=0;_<8;_++){let B=A*8+_;if(B>=u)break;let v=0;D=b;for(let E=0;E<t;E++){let $=E<t-1?m.slice(E+1).reduce((P,H)=>P*H,1):1,M=Math.floor(D/$);D%=$,v+=M*g[E]}v+=B*g[t],x=h;for(let E=t+1;E<a;E++){let $=E<a-1?f.slice(E-t).reduce((P,H)=>P*H,1):1,M=Math.floor(x/$);x%=$,v+=M*g[E]}n==="big"?l[v]=w>>7-_&1:l[v]=w>>_&1}}return c}function Qr(r){let t=r.length,e=new Array(t),n=1;for(let o=t-1;o>=0;o--)e[o]=n,n*=r[o];return e}var Xo=k(()=>{"use strict";R();j();sr()});function Wt(r,t=-1){let e=r.shape,n=e.length,o=r.dtype,a=r.data;if(n===0)return r.copy();let i=t;if(i<0&&(i=n+i),i<0||i>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=r.copy(),s=u.data,c=e[i],l=Array.from(e).filter((f,p)=>p!==i),m=l.length===0?1:l.reduce((f,p)=>f*p,1);if(z(o)){let f=a,p=s;for(let y=0;y<m;y++){let d=[];for(let g=0;g<c;g++){let b=T(y,i,g,e),h=O(b,e);d.push({value:f[h],idx:g})}d.sort((g,b)=>g.value<b.value?-1:g.value>b.value?1:0);for(let g=0;g<c;g++){let b=T(y,i,g,e),h=O(b,e);p[h]=d[g].value}}}else for(let f=0;f<m;f++){let p=[];for(let y=0;y<c;y++){let d=T(f,i,y,e),g=O(d,e);p.push(Number(a[g]))}p.sort((y,d)=>isNaN(y)&&isNaN(d)?0:isNaN(y)?1:isNaN(d)?-1:y-d);for(let y=0;y<c;y++){let d=T(f,i,y,e),g=O(d,e);s[g]=p[y]}}return u}function Zt(r,t=-1){let e=r.shape,n=e.length,o=r.dtype,a=r.data;if(n===0)return N.zeros([0],"int32");let i=t;if(i<0&&(i=n+i),i<0||i>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=N.zeros(Array.from(e),"int32"),s=u.data,c=e[i],l=Array.from(e).filter((f,p)=>p!==i),m=l.length===0?1:l.reduce((f,p)=>f*p,1);if(z(o)){let f=a;for(let p=0;p<m;p++){let y=[];for(let d=0;d<c;d++){let g=T(p,i,d,e),b=O(g,e);y.push({value:f[b],idx:d})}y.sort((d,g)=>d.value<g.value?-1:d.value>g.value?1:0);for(let d=0;d<c;d++){let g=T(p,i,d,e),b=O(g,e);s[b]=y[d].idx}}}else for(let f=0;f<m;f++){let p=[];for(let y=0;y<c;y++){let d=T(f,i,y,e),g=O(d,e);p.push({value:Number(a[g]),idx:y})}p.sort((y,d)=>isNaN(y.value)&&isNaN(d.value)?0:isNaN(y.value)?1:isNaN(d.value)?-1:y.value-d.value);for(let y=0;y<c;y++){let d=T(f,i,y,e),g=O(d,e);s[g]=p[y].idx}}return u}function Ko(r){if(r.length===0)return N.zeros([0],"int32");let e=r[0].size;for(let i of r){if(i.ndim!==1)throw new Error("keys must be 1D arrays");if(i.size!==e)throw new Error("all keys must have the same length")}let n=[];for(let i=0;i<e;i++)n.push(i);n.sort((i,u)=>{for(let s=r.length-1;s>=0;s--){let l=r[s].data,m=Number(l[i]),f=Number(l[u]);if(!(isNaN(m)&&isNaN(f))){if(isNaN(m))return 1;if(isNaN(f)||m<f)return-1;if(m>f)return 1}}return 0});let o=N.zeros([e],"int32"),a=o.data;for(let i=0;i<e;i++)a[i]=n[i];return o}function Gs(r,t){let e=0,n=r.length-1;for(;e<n;){let o=Math.floor((e+n)/2),a=r[e],i=r[o],u=r[n],s;a<=i&&i<=u||u<=i&&i<=a?s=o:i<=a&&a<=u||u<=a&&a<=i?s=e:s=n;let c=r[s];[r[s],r[n]]=[r[n],r[s]];let l=e;for(let m=e;m<n;m++){let f=r[m],p=isNaN(f),y=isNaN(c);!p&&(y||f<=c)&&([r[l],r[m]]=[r[m],r[l]],l++)}if([r[l],r[n]]=[r[n],r[l]],l===t)return;l<t?e=l+1:n=l-1}}function Hs(r,t){let e=0,n=r.length-1;for(;e<n;){let o=Math.floor((e+n)/2),a=r[e],i=r[o],u=r[n],s;a<=i&&i<=u||u<=i&&i<=a?s=o:i<=a&&a<=u||u<=a&&a<=i?s=e:s=n;let c=r[s];[r[s],r[n]]=[r[n],r[s]];let l=e;for(let m=e;m<n;m++)r[m]<=c&&([r[l],r[m]]=[r[m],r[l]],l++);if([r[l],r[n]]=[r[n],r[l]],l===t)return;l<t?e=l+1:n=l-1}}function Ys(r,t){let e=0,n=r.length-1;for(;e<n;){let o=Math.floor((e+n)/2),a=r[e].value,i=r[o].value,u=r[n].value,s;a<=i&&i<=u||u<=i&&i<=a?s=o:i<=a&&a<=u||u<=a&&a<=i?s=e:s=n;let c=r[s].value;[r[s],r[n]]=[r[n],r[s]];let l=e;for(let m=e;m<n;m++){let f=r[m].value,p=isNaN(f),y=isNaN(c);!p&&(y||f<=c)&&([r[l],r[m]]=[r[m],r[l]],l++)}if([r[l],r[n]]=[r[n],r[l]],l===t)return;l<t?e=l+1:n=l-1}}function Js(r,t){let e=0,n=r.length-1;for(;e<n;){let o=Math.floor((e+n)/2),a=r[e].value,i=r[o].value,u=r[n].value,s;a<=i&&i<=u||u<=i&&i<=a?s=o:i<=a&&a<=u||u<=a&&a<=i?s=e:s=n;let c=r[s].value;[r[s],r[n]]=[r[n],r[s]];let l=e;for(let m=e;m<n;m++)r[m].value<=c&&([r[l],r[m]]=[r[m],r[l]],l++);if([r[l],r[n]]=[r[n],r[l]],l===t)return;l<t?e=l+1:n=l-1}}function Gt(r,t,e=-1){let n=r.shape,o=n.length,a=r.dtype;if(o===0)return r.copy();let i=e;if(i<0&&(i=o+i),i<0||i>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let u=n[i],s=t;if(s<0&&(s=u+s),s<0||s>=u)throw new Error(`kth(=${t}) out of bounds (${u})`);let c=r.copy(),l=c.data,m=Array.from(n).filter((p,y)=>y!==i),f=m.length===0?1:m.reduce((p,y)=>p*y,1);if(z(a)){let p=l;for(let y=0;y<f;y++){let d=[];for(let g=0;g<u;g++){let b=T(y,i,g,n),h=O(b,n);d.push(p[h])}Hs(d,s);for(let g=0;g<u;g++){let b=T(y,i,g,n),h=O(b,n);p[h]=d[g]}}}else for(let p=0;p<f;p++){let y=[];for(let d=0;d<u;d++){let g=T(p,i,d,n),b=O(g,n);y.push(Number(l[b]))}Gs(y,s);for(let d=0;d<u;d++){let g=T(p,i,d,n),b=O(g,n);l[b]=y[d]}}return c}function Ht(r,t,e=-1){let n=r.shape,o=n.length,a=r.dtype,i=r.data;if(o===0)return N.zeros([0],"int32");let u=e;if(u<0&&(u=o+u),u<0||u>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let s=n[u],c=t;if(c<0&&(c=s+c),c<0||c>=s)throw new Error(`kth(=${t}) out of bounds (${s})`);let l=N.zeros(Array.from(n),"int32"),m=l.data,f=Array.from(n).filter((y,d)=>d!==u),p=f.length===0?1:f.reduce((y,d)=>y*d,1);if(z(a)){let y=i;for(let d=0;d<p;d++){let g=[];for(let b=0;b<s;b++){let h=T(d,u,b,n),A=O(h,n);g.push({value:y[A],idx:b})}Js(g,c);for(let b=0;b<s;b++){let h=T(d,u,b,n),A=O(h,n);m[A]=g[b].idx}}}else for(let y=0;y<p;y++){let d=[];for(let g=0;g<s;g++){let b=T(y,u,g,n),h=O(b,n);d.push({value:Number(i[h]),idx:g})}Ys(d,c);for(let g=0;g<s;g++){let b=T(y,u,g,n),h=O(b,n);m[h]=d[g].idx}}return l}function ra(r){let t=r.dtype,e=r.size,n=r.data,o=[];for(let u=0;u<e;u++)o.push(Number(n[u]));o.sort((u,s)=>isNaN(u)&&isNaN(s)?0:isNaN(u)?1:isNaN(s)?-1:u-s);let a=N.zeros([e],t),i=a.data;for(let u=0;u<e;u++)i[u]=o[u];return a}function Xr(r){let t=r.shape,e=t.length,n=r.data,o=r.size,a=[];for(let l=0;l<e;l++)a.push([]);let i=[],u=1;for(let l=e-1;l>=0;l--)i.unshift(u),u*=t[l];for(let l=0;l<o;l++)if(n[l]){let m=l;for(let f=0;f<e;f++){let p=Math.floor(m/i[f]);m=m%i[f],a[f].push(p)}}let s=a[0]?.length??0,c=[];for(let l=0;l<e;l++){let m=N.zeros([s],"int32"),f=m.data;for(let p=0;p<s;p++)f[p]=a[l][p];c.push(m)}return c}function ta(r){let t=r.data,e=r.size,n=[];for(let i=0;i<e;i++)t[i]&&n.push(i);let o=N.zeros([n.length],"int32"),a=o.data;for(let i=0;i<n.length;i++)a[i]=n[i];return o}function ea(r,t,e){if(t===void 0&&e===void 0)return Xr(r);if(t===void 0||e===void 0)throw new Error("either both or neither of x and y should be given");let n=r.shape,o=t.shape,a=e.shape,i=Math.max(n.length,o.length,a.length),u=B=>{let v=Array(i).fill(1);for(let E=0;E<B.length;E++)v[i-B.length+E]=B[E];return v},s=u(n),c=u(o),l=u(a),m=[];for(let B=0;B<i;B++){let v=[s[B],c[B],l[B]],E=Math.max(...v);for(let $ of v)if($!==1&&$!==E)throw new Error("operands could not be broadcast together");m.push(E)}let f=t.dtype,p=N.zeros(m,f),y=p.data,d=r.data,g=t.data,b=e.data,h=(B,v)=>{let E=[],$=1;for(let M=B.length-1;M>=0;M--)E.unshift($),$*=B[M];for(;E.length<v.length;)E.unshift(0);for(let M=0;M<v.length;M++)v[M]===1&&m[M]!==1&&(E[M]=0);return E},A=h(n,s),S=h(o,c),D=h(a,l),x=[],w=1;for(let B=m.length-1;B>=0;B--)x.unshift(w),w*=m[B];let _=m.reduce((B,v)=>B*v,1);for(let B=0;B<_;B++){let v=B,E=0,$=0,M=0;for(let P=0;P<i;P++){let H=Math.floor(v/x[P]);v=v%x[P],E+=H*A[P],$+=H*S[P],M+=H*D[P]}d[E]?y[B]=g[$]:y[B]=b[M]}return p}function Yt(r,t,e="left"){if(r.ndim!==1)throw new Error("storage must be 1D");let n=r.data,o=r.size,a=t.data,i=t.size,u=N.zeros([i],"int32"),s=u.data;for(let c=0;c<i;c++){let l=Number(a[c]),m=0,f=o;if(e==="left")for(;m<f;){let p=Math.floor((m+f)/2);Number(n[p])<l?m=p+1:f=p}else for(;m<f;){let p=Math.floor((m+f)/2);Number(n[p])<=l?m=p+1:f=p}s[c]=m}return u}function na(r,t){let e=r.data,n=t.data,o=t.dtype,a=Math.min(r.size,t.size),i=0;for(let l=0;l<a;l++)e[l]&&i++;let u=N.zeros([i],o),s=u.data,c=0;if(z(o)){let l=n,m=s;for(let f=0;f<a;f++)e[f]&&(m[c++]=l[f])}else for(let l=0;l<a;l++)e[l]&&(s[c++]=n[l]);return u}function Jt(r,t){let e=r.shape,n=e.length,o=r.data,a=r.size;if(t===void 0){let f=0;for(let p=0;p<a;p++)o[p]&&f++;return f}let i=t;if(i<0&&(i=n+i),i<0||i>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let u=Array.from(e).filter((f,p)=>p!==i);if(u.length===0)return Jt(r);let s=N.zeros(u,"int32"),c=s.data,l=e[i],m=u.reduce((f,p)=>f*p,1);for(let f=0;f<m;f++){let p=0;for(let y=0;y<l;y++){let d=T(f,i,y,e),g=O(d,e);o[g]&&p++}c[f]=p}return s}var oa=k(()=>{"use strict";R();j();yt()});function aa(r){if(!isFinite(r))return r;let t=Math.floor(r),e=r-t;return Math.abs(e-.5)<1e-10?t%2===0?t:t+1:Math.round(r)}function Qt(r,t=0){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=e==="float32"?"float32":"float64",u=N.zeros(n,i),s=u.data,c=Math.pow(10,t);for(let l=0;l<a;l++){let m=Number(o[l]);s[l]=aa(m*c)/c}return u}function Xt(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=t==="float32"?"float32":"float64",i=N.zeros(e,a),u=i.data;for(let s=0;s<o;s++)u[s]=Math.ceil(Number(n[s]));return i}function Kt(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=t==="float32"?"float32":"float64",i=N.zeros(e,a),u=i.data;for(let s=0;s<o;s++)u[s]=Math.trunc(Number(n[s]));return i}function re(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=t==="float32"?"float32":"float64",i=N.zeros(e,a),u=i.data;for(let s=0;s<o;s++)u[s]=Math.floor(Number(n[s]));return i}function te(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=t==="float32"?"float32":"float64",i=N.zeros(e,a),u=i.data;for(let s=0;s<o;s++)u[s]=aa(Number(n[s]));return i}function ee(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=t==="float32"?"float32":"float64",i=N.zeros(e,a),u=i.data;for(let s=0;s<o;s++)u[s]=Math.trunc(Number(n[s]));return i}var sa=k(()=>{"use strict";R()});function K(r,t=!1,e=!1,n=!1){let o=r.dtype,a=r.size,i=r.data,u=[];for(let A=0;A<a;A++)u.push({value:Number(i[A]),index:A});u.sort((A,S)=>isNaN(A.value)&&isNaN(S.value)?0:isNaN(A.value)?1:isNaN(S.value)?-1:A.value-S.value);let s=[],c=[],l=new Array(a),m=[],f,p=0;for(let A=0;A<u.length;A++){let{value:S,index:D}=u[A];f===void 0||isNaN(S)&&!isNaN(f)||!isNaN(S)&&isNaN(f)||!isNaN(S)&&!isNaN(f)&&S!==f?(f!==void 0&&m.push(p),s.push(S),c.push(D),p=1,f=S):p++}p>0&&m.push(p);let y=new Map,d=-1;for(let A=0;A<s.length;A++){let S=s[A];isNaN(S)?d=A:y.set(S,A)}for(let A=0;A<a;A++){let S=Number(i[A]);isNaN(S)?l[A]=d:l[A]=y.get(S)}let g=N.zeros([s.length],o),b=g.data;for(let A=0;A<s.length;A++)b[A]=s[A];if(!t&&!e&&!n)return g;let h={values:g};if(t){let A=N.zeros([c.length],"int32"),S=A.data;for(let D=0;D<c.length;D++)S[D]=c[D];h.indices=A}if(e){let A=N.zeros([l.length],"int32"),S=A.data;for(let D=0;D<l.length;D++)S[D]=l[D];h.inverse=A}if(n){let A=N.zeros([m.length],"int32"),S=A.data;for(let D=0;D<m.length;D++)S[D]=m[D];h.counts=A}return h}function ia(r,t){return ne(r,t)}function ua(r,t){let e=r.dtype,n=K(r),o=K(t),a=new Set;for(let c=0;c<o.size;c++)a.add(Number(o.data[c]));let i=[];for(let c=0;c<n.size;c++){let l=Number(n.data[c]);a.has(l)&&i.push(l)}i.sort((c,l)=>c-l);let u=N.zeros([i.length],e),s=u.data;for(let c=0;c<i.length;c++)s[c]=i[c];return u}function ne(r,t){let e=Array.from(r.shape),n=r.size,o=new Set;for(let s=0;s<t.size;s++)o.add(Number(t.data[s]));let a=N.zeros(e,"bool"),i=a.data,u=r.data;for(let s=0;s<n;s++){let c=Number(u[s]);i[s]=o.has(c)?1:0}return a}function ca(r,t){let e=r.dtype,n=K(r),o=new Set;for(let s=0;s<t.size;s++)o.add(Number(t.data[s]));let a=[];for(let s=0;s<n.size;s++){let c=Number(n.data[s]);o.has(c)||a.push(c)}let i=N.zeros([a.length],e),u=i.data;for(let s=0;s<a.length;s++)u[s]=a[s];return i}function la(r,t){let e=r.dtype,n=K(r),o=K(t),a=new Set,i=new Set;for(let l=0;l<n.size;l++)a.add(Number(n.data[l]));for(let l=0;l<o.size;l++)i.add(Number(o.data[l]));let u=[];for(let l of a)i.has(l)||u.push(l);for(let l of i)a.has(l)||u.push(l);u.sort((l,m)=>l-m);let s=N.zeros([u.length],e),c=s.data;for(let l=0;l<u.length;l++)c[l]=u[l];return s}function fa(r,t){let e=r.dtype,n=K(r),o=K(t),a=new Set;for(let c=0;c<n.size;c++)a.add(Number(n.data[c]));for(let c=0;c<o.size;c++)a.add(Number(o.data[c]));let i=Array.from(a);i.sort((c,l)=>c-l);let u=N.zeros([i.length],e),s=u.data;for(let c=0;c<i.length;c++)s[c]=i[c];return u}var ma=k(()=>{"use strict";R()});function oe(r,t=1,e=-1){if(t<0)throw new Error(`order must be non-negative but got ${t}`);if(t===0)return r.copy();let n=Array.from(r.shape),o=n.length,a=e<0?o+e:e;if(a<0||a>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);if(n[a]<t+1)throw new Error(`diff requires at least ${t+1} elements along axis ${e}, but got ${n[a]}`);let i=r;for(let u=0;u<t;u++)i=ri(i,a);return i}function ri(r,t){let e=Array.from(r.shape),n=e.length,o=e[t],a=[...e];a[t]=o-1;let i=r.dtype,u=z(i)?"float64":i,s=N.zeros(a,u),c=s.data,l=r.strides,m=s.size;for(let f=0;f<m;f++){let p=f,y=new Array(n);for(let D=n-1;D>=0;D--)y[D]=p%a[D],p=Math.floor(p/a[D]);let d=[...y],g=[...y];g[t]=d[t]+1;let b=0,h=0;for(let D=0;D<n;D++)b+=d[D]*l[D],h+=g[D]*l[D];let A=(z(i),Number(r.data[b])),S=(z(i),Number(r.data[h]));c[f]=S-A}return s}function pa(r,t=null,e=null){let n=r.size,o=r.dtype,a=z(o)?"float64":o,i=Math.max(0,n-1),u=e?e.length:0,s=t?t.length:0,c=u+i+s,l=N.zeros([c],a),m=l.data,f=0;if(e)for(let p of e)m[f++]=p;for(let p=0;p<i;p++){let y=(z(o),Number(r.iget(p))),d=(z(o),Number(r.iget(p+1)));m[f++]=d-y}if(t)for(let p of t)m[f++]=p;return l}function ya(r,t=1,e=null){let o=Array.from(r.shape).length,a;if(e===null)a=Array.from({length:o},(s,c)=>c);else if(typeof e=="number"){let s=e<0?o+e:e;if(s<0||s>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);a=[s]}else a=e.map(s=>{let c=s<0?o+s:s;if(c<0||c>=o)throw new Error(`axis ${s} is out of bounds for array of dimension ${o}`);return c});let i;if(typeof t=="number")i=a.map(()=>t);else{if(t.length!==a.length)throw new Error("Number of spacings must match number of axes");i=t}let u=[];for(let s=0;s<a.length;s++)u.push(ti(r,a[s],i[s]));return u.length===1?u[0]:u}function ti(r,t,e){let n=Array.from(r.shape),o=n.length,a=n[t];if(a<2)throw new Error(`Shape of array along axis ${t} must be at least 2, but got ${a}`);let i=r.dtype,u=z(i)?"float64":i==="float32"?"float32":"float64",s=N.zeros(n,u),c=s.data,l=r.strides,m=e,f=2*m,p=r.size;for(let y=0;y<p;y++){let d=y,g=new Array(o);for(let A=o-1;A>=0;A--)g[A]=d%n[A],d=Math.floor(d/n[A]);let b=g[t],h;if(b===0){let A=[...g];A[t]=1;let S=0;for(let w=0;w<o;w++)S+=A[w]*l[w];let D=(z(i),Number(r.data[y]));h=((z(i),Number(r.data[S]))-D)/m}else if(b===a-1){let A=[...g];A[t]=a-2;let S=0;for(let w=0;w<o;w++)S+=A[w]*l[w];let D=(z(i),Number(r.data[y])),x=(z(i),Number(r.data[S]));h=(D-x)/m}else{let A=[...g],S=[...g];A[t]=b+1,S[t]=b-1;let D=0,x=0;for(let B=0;B<o;B++)D+=A[B]*l[B],x+=S[B]*l[B];let w=(z(i),Number(r.data[D])),_=(z(i),Number(r.data[x]));h=(w-_)/f}c[y]=h}return s}function da(r,t,e=-1,n=-1,o=-1){let a=Array.from(r.shape),i=Array.from(t.shape),u=a.length,s=i.length,c=e<0?u+e:e,l=n<0?s+n:n;if(c<0||c>=u)throw new Error(`axisa ${e} is out of bounds for array of dimension ${u}`);if(l<0||l>=s)throw new Error(`axisb ${n} is out of bounds for array of dimension ${s}`);let m=a[c],f=i[l];if(m!==2&&m!==3)throw new Error(`incompatible dimensions for cross product (dimension must be 2 or 3, got ${m})`);if(f!==2&&f!==3)throw new Error(`incompatible dimensions for cross product (dimension must be 2 or 3, got ${f})`);let p=C(r.dtype,t.dtype);if(u===1&&s===1&&m===3&&f===3){let y=N.zeros([3],p),d=y.data,g=Number(r.iget(0)),b=Number(r.iget(1)),h=Number(r.iget(2)),A=Number(t.iget(0)),S=Number(t.iget(1)),D=Number(t.iget(2));return d[0]=b*D-h*S,d[1]=h*A-g*D,d[2]=g*S-b*A,y}if(u===1&&s===1&&m===2&&f===2){let y=N.zeros([],p),d=Number(r.iget(0)),g=Number(r.iget(1)),b=Number(t.iget(0)),h=Number(t.iget(1));return y.data[0]=d*h-g*b,y}if(u===1&&s===1){if(m===2&&f===3){let y=N.zeros([3],p),d=y.data,g=Number(r.iget(0)),b=Number(r.iget(1)),h=Number(t.iget(0)),A=Number(t.iget(1)),S=Number(t.iget(2));return d[0]=b*S,d[1]=-g*S,d[2]=g*A-b*h,y}else if(m===3&&f===2){let y=N.zeros([3],p),d=y.data,g=Number(r.iget(0)),b=Number(r.iget(1)),h=Number(r.iget(2)),A=Number(t.iget(0)),S=Number(t.iget(1));return d[0]=-h*S,d[1]=h*A,d[2]=g*S-b*A,y}}if(u===2&&s===2&&c===1&&l===1){let y=a[0];if(i[0]!==y)throw new Error(`Shape mismatch: a has ${y} vectors, b has ${i[0]} vectors`);if(m===3&&f===3){let d=N.zeros([y,3],p),g=d.data;for(let b=0;b<y;b++){let h=Number(r.iget(b*3)),A=Number(r.iget(b*3+1)),S=Number(r.iget(b*3+2)),D=Number(t.iget(b*3)),x=Number(t.iget(b*3+1)),w=Number(t.iget(b*3+2));g[b*3]=A*w-S*x,g[b*3+1]=S*D-h*w,g[b*3+2]=h*x-A*D}return d}if(m===2&&f===2){let d=N.zeros([y],p),g=d.data;for(let b=0;b<y;b++){let h=Number(r.iget(b*2)),A=Number(r.iget(b*2+1)),S=Number(t.iget(b*2)),D=Number(t.iget(b*2+1));g[b]=h*D-A*S}return d}}throw new Error(`cross product not implemented for arrays with shapes ${JSON.stringify(a)} and ${JSON.stringify(i)}`)}var ga=k(()=>{"use strict";R();j()});function rr(r,t=q){let e=N.zeros(r,t);return new I(e)}function Aa(r,t=q){let e=N.ones(r,t);return new I(e)}function ni(r){let t=[],e=r;for(;Array.isArray(e);)t.push(e.length),e=e[0];return t}function ha(r){return typeof r=="bigint"?!0:Array.isArray(r)?r.some(t=>ha(t)):!1}function oi(r){let t=[];function e(n){Array.isArray(n)?n.forEach(o=>e(o)):t.push(n)}return e(r),t}function F(r,t){if(r instanceof I)return!t||r.dtype===t?r.copy():r.astype(t);let e=ha(r),n=ni(r),o=n.reduce((l,m)=>l*m,1),a=t;a||(e?a="int64":a=q);let i=U(a);if(!i)throw new Error(`Cannot create array with dtype ${a}`);let u=new i(o),s=oi(r);if(z(a)){let l=u;for(let m=0;m<o;m++){let f=s[m];l[m]=typeof f=="bigint"?f:BigInt(Math.round(Number(f)))}}else if(a==="bool"){let l=u;for(let m=0;m<o;m++)l[m]=s[m]?1:0}else{let l=u;for(let m=0;m<o;m++){let f=s[m];l[m]=Number(f)}}let c=N.fromData(u,n,a);return new I(c)}function ai(r,t,e=1,n=q){let o=r,a=t;if(t===void 0&&(o=0,a=r),a===void 0)throw new Error("stop is required");let i=Math.max(0,Math.ceil((a-o)/e)),u=U(n);if(!u)throw new Error(`Cannot create arange array with dtype ${n}`);let s=new u(i);if(z(n))for(let l=0;l<i;l++)s[l]=BigInt(Math.round(o+l*e));else if(n==="bool")for(let l=0;l<i;l++)s[l]=o+l*e!==0?1:0;else for(let l=0;l<i;l++)s[l]=o+l*e;let c=N.fromData(s,[i],n);return new I(c)}function si(r,t,e=50,n=q){if(e<0)throw new Error("num must be non-negative");if(e===0)return F([],n);if(e===1)return F([r],n);let o=U(n);if(!o)throw new Error(`Cannot create linspace array with dtype ${n}`);let a=new o(e),i=(t-r)/(e-1);if(z(n))for(let s=0;s<e;s++)a[s]=BigInt(Math.round(r+s*i));else if(n==="bool")for(let s=0;s<e;s++)a[s]=r+s*i!==0?1:0;else for(let s=0;s<e;s++)a[s]=r+s*i;let u=N.fromData(a,[e],n);return new I(u)}function ii(r,t,e=50,n=10,o=q){if(e<0)throw new Error("num must be non-negative");if(e===0)return F([],o);if(e===1)return F([Math.pow(n,r)],o);let a=U(o);if(!a)throw new Error(`Cannot create logspace array with dtype ${o}`);let i=new a(e),u=(t-r)/(e-1);if(z(o))for(let c=0;c<e;c++){let l=r+c*u;i[c]=BigInt(Math.round(Math.pow(n,l)))}else if(o==="bool")for(let c=0;c<e;c++){let l=r+c*u;i[c]=Math.pow(n,l)!==0?1:0}else for(let c=0;c<e;c++){let l=r+c*u;i[c]=Math.pow(n,l)}let s=N.fromData(i,[e],o);return new I(s)}function ui(r,t,e=50,n=q){if(e<0)throw new Error("num must be non-negative");if(r===0||t===0)throw new Error("Geometric sequence cannot include zero");if(e===0)return F([],n);if(e===1)return F([r],n);let o=Math.sign(r),a=Math.sign(t);if(o!==a)throw new Error("Geometric sequence cannot contain both positive and negative values");let i=U(n);if(!i)throw new Error(`Cannot create geomspace array with dtype ${n}`);let u=new i(e),s=Math.log(Math.abs(r)),l=(Math.log(Math.abs(t))-s)/(e-1);if(z(n))for(let f=0;f<e;f++){let p=o*Math.exp(s+f*l);u[f]=BigInt(Math.round(p))}else if(n==="bool")for(let f=0;f<e;f++){let p=o*Math.exp(s+f*l);u[f]=p!==0?1:0}else for(let f=0;f<e;f++){let p=o*Math.exp(s+f*l);u[f]=p}let m=N.fromData(u,[e],n);return new I(m)}function ba(r,t,e=0,n=q){let o=t??r,a=rr([r,o],n),i=a.data;if(z(n)){let u=i;for(let s=0;s<r;s++){let c=s+e;c>=0&&c<o&&(u[s*o+c]=BigInt(1))}}else{let u=i;for(let s=0;s<r;s++){let c=s+e;c>=0&&c<o&&(u[s*o+c]=1)}}return a}function Sa(r,t=q){return rr(r,t)}function Na(r,t,e){let n=e;n||(typeof t=="bigint"?n="int64":typeof t=="boolean"?n="bool":Number.isInteger(t)?n="int32":n=q);let o=U(n);if(!o)throw new Error(`Cannot create full array with dtype ${n}`);let a=r.reduce((s,c)=>s*c,1),i=new o(a);if(z(n)){let s=typeof t=="bigint"?t:BigInt(Math.round(Number(t)));i.fill(s)}else n==="bool"?i.fill(t?1:0):i.fill(Number(t));let u=N.fromData(i,r,n);return new I(u)}function ci(r,t=q){return ba(r,r,0,t)}function Kr(r,t){return r instanceof I?!t||r.dtype===t?r:r.astype(t):F(r,t)}function li(r){return r.copy()}function fi(r,t){return rr(Array.from(r.shape),t??r.dtype)}function mi(r,t){return Aa(Array.from(r.shape),t??r.dtype)}function pi(r,t){return Sa(Array.from(r.shape),t??r.dtype)}function yi(r,t,e){return Na(Array.from(r.shape),t,e??r.dtype)}function di(r,t){return Kr(r,t)}function gi(r,t){let e=Kr(r,t);return e.flags.C_CONTIGUOUS?e:e.copy()}function Ai(r,t){return Kr(r,t).copy()}function Da(r,t=0){if(r.ndim===1){let e=r.size,n=e+Math.abs(t),o=rr([n,n],r.dtype);for(let a=0;a<e;a++){let i=t>=0?a:a-t,u=t>=0?a+t:a;o.set([i,u],r.get([a]))}return o}else if(r.ndim===2){let[e,n]=r.shape,o,a,i;if(t>=0?(o=0,a=t,i=Math.min(e,n-t)):(o=-t,a=0,i=Math.min(e+t,n)),i<=0)return rr([0],r.dtype);let u=U(r.dtype),s=new u(i);for(let l=0;l<i;l++){let m=r.get([o+l,a+l]);z(r.dtype)?s[l]=typeof m=="bigint"?m:BigInt(m):s[l]=m}let c=N.fromData(s,[i],r.dtype);return new I(c)}else throw new Error("Input must be 1-D or 2-D")}function hi(r,t=0){let e=r.flatten();return Da(e,t)}function bi(r,t,e=q){let n=t.reduce((c,l)=>c*l,1),o=U(e);if(!o)throw new Error(`Cannot create array with dtype ${e}`);let a=new o(n),i=t.length,u=new Array(i).fill(0);for(let c=0;c<n;c++){let l=r(...u);z(e)?a[c]=typeof l=="bigint"?l:BigInt(Number(l)):e==="bool"?a[c]=l?1:0:a[c]=Number(l);for(let m=i-1;m>=0&&(u[m]++,!(u[m]<t[m]));m--)u[m]=0}let s=N.fromData(a,t,e);return new I(s)}function Si(...r){let t=[],e="xy";for(let u of r)u instanceof I?t.push(u):typeof u=="object"&&"indexing"in u&&(e=u.indexing||"xy");if(t.length===0)return[];if(t.length===1)return[t[0].copy()];let n=t.map(u=>u.size);e==="xy"&&t.length>=2&&(t=[t[1],t[0],...t.slice(2)],[n[0],n[1]]=[n[1],n[0]]);let o=n,a=o.length,i=[];for(let u=0;u<t.length;u++){let s=t[u],c=s.size,l=new Array(a).fill(1);l[u]=c;let m=s.reshape(...l),f=qt(m.storage,o),p=I._fromStorage(f.copy());i.push(p)}return e==="xy"&&i.length>=2&&([i[0],i[1]]=[i[1],i[0]]),i}function Ni(r,t,e=0,n=q){let o=t??r,a=rr([r,o],n);for(let i=0;i<r;i++)for(let u=0;u<=i+e&&u<o;u++)u>=0&&a.set([i,u],1);return a}function Di(r,t=0){if(r.ndim<2)throw new Error("Input must have at least 2 dimensions");let e=r.copy(),n=e.shape,o=n[n.length-2],a=n[n.length-1],i=n.slice(0,-2).reduce((u,s)=>u*s,1);for(let u=0;u<i;u++)for(let s=0;s<o;s++)for(let c=0;c<a;c++)if(c>s+t){let l=[],m=u;for(let f=n.length-3;f>=0;f--)l.unshift(m%n[f]),m=Math.floor(m/n[f]);l.push(s,c),e.set(l,0)}return e}function xi(r,t=0){if(r.ndim<2)throw new Error("Input must have at least 2 dimensions");let e=r.copy(),n=e.shape,o=n[n.length-2],a=n[n.length-1],i=n.slice(0,-2).reduce((u,s)=>u*s,1);for(let u=0;u<i;u++)for(let s=0;s<o;s++)for(let c=0;c<a;c++)if(c<s+t){let l=[],m=u;for(let f=n.length-3;f>=0;f--)l.unshift(m%n[f]),m=Math.floor(m/n[f]);l.push(s,c),e.set(l,0)}return e}function wi(r,t,e=!1){if(r.ndim!==1)throw new Error("Input must be 1-D");let n=r.size,o=t??n;if(o<0)throw new Error("N must be non-negative");let a=rr([n,o],r.dtype);for(let i=0;i<n;i++){let u=r.get([i]);for(let s=0;s<o;s++){let c=e?s:o-1-s;a.set([i,s],Math.pow(u,c))}}return a}function zi(r,t=q,e=-1,n=0){let o,a=n;r instanceof ArrayBuffer?o=r:(o=r.buffer,a+=r.byteOffset);let i=vi(t),u=o.byteLength-a,s=Math.floor(u/i),c=e<0?s:Math.min(e,s);if(c<=0)return F([],t);let l=U(t);if(!l)throw new Error(`Unsupported dtype: ${t}`);let m=new l(o,a,c),f=N.fromData(m,[c],t);return new I(f)}function Ii(r,t=q,e=-1){let n=[],o=0;for(let a of r){if(e>=0&&o>=e)break;n.push(a),o++}return F(n,t)}function _i(r,t=q,e=-1){let n=[],o=0;for(let a of r){if(e>=0&&o>=e)break;n.push(a),o++}return F(n,t)}function Bi(r,t=q,e=-1,n=""){let o;n===""?o=r.trim().split(/\s+/):o=r.split(n);let a=[],i=0;for(let u of o){if(e>=0&&i>=e)break;let s=u.trim();s!==""&&(z(t)?a.push(BigInt(s)):a.push(parseFloat(s)),i++)}return F(a,t)}function vi(r){switch(r){case"int8":case"uint8":case"bool":return 1;case"int16":case"uint16":return 2;case"int32":case"uint32":case"float32":return 4;case"int64":case"uint64":case"float64":return 8;default:return 8}}function Ei(r){return r.sqrt()}function Oi(r,t){return r.power(t)}function Ti(r){return r.exp()}function Ui(r){return r.exp2()}function $i(r){return r.expm1()}function Mi(r){return r.log()}function ki(r){return r.log2()}function Ci(r){return r.log10()}function Vi(r){return r.log1p()}function Pi(r,t){return r.logaddexp(t)}function qi(r,t){return r.logaddexp2(t)}function Fi(r){return r.absolute()}function Ri(r){return r.negative()}function ji(r){return r.sign()}function Li(r,t){return r.mod(t)}function Wi(r,t){return r.floor_divide(t)}function Zi(r){return r.positive()}function Gi(r){return r.reciprocal()}function Hi(r,t){return r.dot(t)}function Yi(r){return r.trace()}function Ji(r,t=0,e=0,n=1){let o=Bn(r.storage,t,e,n);return I._fromStorage(o)}function Qi(r,t){let e=En(r.storage,t.storage);return I._fromStorage(e)}function Xi(r,t){return r.transpose(t)}function Ki(r,t){return r.inner(t)}function ru(r,t){return r.outer(t)}function tu(r,t,e=2){return r.tensordot(t,e)}function eu(r){return r.sin()}function nu(r){return r.cos()}function ou(r){return r.tan()}function au(r){return r.arcsin()}function su(r){return r.arccos()}function iu(r){return r.arctan()}function uu(r,t){return r.arctan2(t)}function cu(r,t){return r.hypot(t)}function lu(r){return r.degrees()}function fu(r){return r.radians()}function mu(r){return r.radians()}function pu(r){return r.degrees()}function yu(r){return r.sinh()}function du(r){return r.cosh()}function gu(r){return r.tanh()}function Au(r){return r.arcsinh()}function hu(r){return r.arccosh()}function bu(r){return r.arctanh()}function Su(r,t,e){return r.swapaxes(t,e)}function Nu(r,t,e){return r.moveaxis(t,e)}function yr(r,t=0){if(r.length===0)throw new Error("need at least one array to concatenate");let e=r.map(o=>o.storage),n=ir(e,t);return I._fromStorage(n)}function Du(r,t=0){if(r.length===0)throw new Error("need at least one array to stack");let e=r.map(o=>o.storage),n=en(e,t);return I._fromStorage(n)}function xa(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=nn(t);return I._fromStorage(e)}function xu(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=Et(t);return I._fromStorage(e)}function wu(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=on(t);return I._fromStorage(e)}function zu(r,t,e=0){return an(r.storage,t,e).map(o=>I._fromStorage(o,r.base??r))}function Iu(r,t,e=0){return wr(r.storage,t,e).map(o=>I._fromStorage(o,r.base??r))}function _u(r,t){return un(r.storage,t).map(n=>I._fromStorage(n,r.base??r))}function Bu(r,t){return cn(r.storage,t).map(n=>I._fromStorage(n,r.base??r))}function vu(r,t){let e=ln(r.storage,t);return I._fromStorage(e)}function Eu(r,t,e){return r.repeat(t,e)}function Ou(r){return r.ravel()}function Tu(r,t){return r.reshape(...t)}function Uu(r,t){return r.squeeze(t)}function $u(r,t){return r.expand_dims(t)}function ae(r,t){let e=mn(r.storage,t);return I._fromStorage(e)}function Mu(r){if(r.ndim<2)throw new Error("Input must be at least 2-D");return ae(r,1)}function ku(r){if(r.ndim<2)throw new Error("Input must be at least 2-D");return ae(r,0)}function Cu(r,t=1,e=[0,1]){let n=pn(r.storage,t,e);return I._fromStorage(n)}function Vu(r,t,e){let n=yn(r.storage,t,e);return I._fromStorage(n)}function Pu(r,t,e=0){let n=dn(r.storage,t,e);return I._fromStorage(n,r.base??r)}function qu(...r){let t=r.map(o=>o.storage),n=bn(t).map((o,a)=>o===t[a]?r[a]:I._fromStorage(o));return n.length===1?n[0]:n}function Fu(...r){let t=r.map(o=>o.storage),n=Sn(t).map((o,a)=>o===t[a]?r[a]:I._fromStorage(o));return n.length===1?n[0]:n}function Ru(...r){let t=r.map(o=>o.storage),n=Nn(t).map((o,a)=>o===t[a]?r[a]:I._fromStorage(o));return n.length===1?n[0]:n}function ju(r,t){return gn(r.storage,t).map(n=>I._fromStorage(n,r.base??r))}function Lu(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=An(t);return I._fromStorage(e)}function Wu(r){return xa(r)}function Zu(r,t){let e=hn(r.storage,t);return I._fromStorage(e)}function Gu(r,t,e){let n=t instanceof I?t:F(t,r.dtype);if(e===void 0){let o=r.flatten(),a=n.flatten();return yr([o,a])}return yr([r,n],e)}function Hu(r,t,e){let n=r.dtype;if(e===void 0){let p=r.flatten(),d=(Array.isArray(t)?t:[t]).map(S=>S<0?p.size+S:S),g=[];for(let S=0;S<p.size;S++)d.includes(S)||g.push(S);let b=U(n),h=new b(g.length);for(let S=0;S<g.length;S++){let D=p.get([g[S]]);z(n)?h[S]=typeof D=="bigint"?D:BigInt(D):h[S]=D}let A=N.fromData(h,[g.length],n);return new I(A)}let o=r.shape,a=o.length,i=e<0?a+e:e;if(i<0||i>=a)throw new Error(`axis ${e} is out of bounds for array of dimension ${a}`);let u=o[i],s=Array.isArray(t)?t:[t],c=new Set(s.map(p=>p<0?u+p:p)),l=[],m=0;for(let p=0;p<=u;p++)(c.has(p)||p===u)&&(p>m&&l.push([m,p]),m=p+1);if(l.length===0){let p=[...o];return p[i]=0,rr(p,n)}let f=[];for(let[p,y]of l){let d=o.map(()=>":");d[i]=`${p}:${y}`,f.push(r.slice(...d))}return yr(f,i)}function Yu(r,t,e,n){let o=e instanceof I?e:F(e,r.dtype);if(n===void 0){let m=r.flatten(),f=o.flatten(),p=t<0?m.size+t:t;if(p<0||p>m.size)throw new Error(`index ${t} is out of bounds for array of size ${m.size}`);let y=p>0?m.slice(`0:${p}`):null,d=p<m.size?m.slice(`${p}:`):null,g=[];return y&&g.push(y),g.push(f),d&&g.push(d),yr(g)}let a=r.shape,i=a.length,u=n<0?i+n:n;if(u<0||u>=i)throw new Error(`axis ${n} is out of bounds for array of dimension ${i}`);let s=a[u],c=t<0?s+t:t;if(c<0||c>s)throw new Error(`index ${t} is out of bounds for axis ${n} with size ${s}`);let l=[];if(c>0){let m=a.map(()=>":");m[u]=`0:${c}`,l.push(r.slice(...m))}if(l.push(o),c<s){let m=a.map(()=>":");m[u]=`${c}:`,l.push(r.slice(...m))}return yr(l,u)}function Ju(r,t,e="constant",n=0){let o=r.shape,a=o.length,i=r.dtype,u;if(typeof t=="number"?u=o.map(()=>[t,t]):Array.isArray(t)&&typeof t[0]=="number"?u=o.map(()=>t):u=t,u.length!==a)throw new Error(`pad_width must have ${a} elements`);let s=o.map((d,g)=>d+u[g][0]+u[g][1]),c=s.reduce((d,g)=>d*g,1),l=U(i),m=new l(c),f=z(i);e==="constant"&&(f?m.fill(BigInt(n)):m.fill(n));let p=new Array(a).fill(0);for(let d=0;d<c;d++){let g=!0,b=[];for(let A=0;A<a;A++){let[S]=u[A],D=p[A]-S;if(D<0||D>=o[A]){g=!1;break}b.push(D)}let h;if(g)h=r.get(b);else if(e==="constant"){for(let A=a-1;A>=0&&(p[A]++,!(p[A]<s[A]));A--)p[A]=0;continue}else{let A=[];for(let S=0;S<a;S++){let[D]=u[S],x=p[S]-D,w=o[S];x<0?e==="edge"?x=0:e==="reflect"?(x=-x,x>=w&&(x=w-1)):e==="symmetric"?(x=-x-1,x>=w&&(x=w-1),x<0&&(x=0)):e==="wrap"&&(x=(x%w+w)%w):x>=w&&(e==="edge"?x=w-1:e==="reflect"?(x=2*w-x-2,x<0&&(x=0)):e==="symmetric"?(x=2*w-x-1,x<0&&(x=0)):e==="wrap"&&(x=x%w)),A.push(Math.max(0,Math.min(w-1,x)))}h=r.get(A)}f?m[d]=typeof h=="bigint"?h:BigInt(Number(h)):m[d]=Number(h);for(let A=a-1;A>=0&&(p[A]++,!(p[A]<s[A]));A--)p[A]=0}let y=N.fromData(m,s,i);return new I(y)}function Qu(r,t){let e=qt(r.storage,t);return I._fromStorage(e,r.base??r)}function Xu(...r){let t=r.map(n=>n.storage);return Do(t).map((n,o)=>I._fromStorage(n,r[o].base??r[o]))}function Ku(...r){return ft(...r)}function rc(r,t,e){return r.take(t,e)}function tc(r,t,e){r.put(t,e)}function ec(r,t){let e=t.map(o=>o.storage),n=zo(r.storage,e);return I._fromStorage(n)}function nc(r,t,e=!1){return Io(r.storage,t.storage,e)}function oc(r,t){return Je(r.storage,t.storage)}function ac(r,t){return I._fromStorage(Nt(r.storage,t))}function sc(r,t){return I._fromStorage(Dt(r.storage,t))}function ic(r,t,e=!1){let n=xt(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function uc(r,t,e=!1){let n=wt(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function cc(r,t,e,n=!1){let o=zt(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)}function lc(r,t,e,n=!1){let o=fr(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)}function fc(r,t,e,n=!1){let o=e?e.storage:void 0,a=qr(r.storage,t,o,n);return typeof a=="number"?a:I._fromStorage(a)}function mc(r,t,e=!1){let n=Fr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function pc(r,t,e=!1){let n=Rr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function yc(r,t,e=!1){let n=jr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function dc(r,t,e=0,n=!1){let o=Nr(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)}function gc(r,t,e=0,n=!1){let o=It(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)}function Ac(r,t,e=!1){let n=Lr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function hc(r,t,e=!1){let n=Wr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function bc(r,t){let e=Zr(r.storage,t);return typeof e=="number"?e:I._fromStorage(e)}function Sc(r,t){let e=Gr(r.storage,t);return typeof e=="number"?e:I._fromStorage(e)}function Nc(r,t){return I._fromStorage(_t(r.storage,t))}function Dc(r,t){return I._fromStorage(Bt(r.storage,t))}function xc(r,t,e=!1){let n=Hr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function wc(r){return r.cbrt()}function zc(r){return r.fabs()}function Ic(r,t){return r.divmod(t)}function _c(r){return r.square()}function Bc(r,t){return r.remainder(t)}function vc(r,t){return r.heaviside(t)}function Ec(r,t){return r.bitwise_and(t)}function Oc(r,t){return r.bitwise_or(t)}function Tc(r,t){return r.bitwise_xor(t)}function Uc(r){return r.bitwise_not()}function $c(r){return r.invert()}function Mc(r,t){return r.left_shift(t)}function kc(r,t){return r.right_shift(t)}function Cc(r,t=-1,e="big"){let n=Jo(r.storage,t,e);return I._fromStorage(n)}function Vc(r,t=-1,e=-1,n="big"){let o=Qo(r.storage,t,e,n);return I._fromStorage(o)}function Pc(r,...t){let e=t.map(o=>o.storage),n=vn(r,...e);return typeof n=="number"||typeof n=="bigint"?n:I._fromStorage(n)}function Fc(r,t,e){return I._fromStorage(_o(r.storage,t.storage,e))}function Rc(r,t,e,n){Bo(r.storage,t.storage,e.storage,n)}function jc(r,t,e){let n=e instanceof I?e.storage:e;vo(r.storage,t.storage,n)}function Lc(r,t,e){return I._fromStorage(Eo(r.storage,t.storage,e))}function Wc(r,t,e=0){let n=r.map(a=>a.storage),o=t.map(a=>a.storage);return I._fromStorage(Oo(n,o,e))}function Zc(r,t,e){To(r.storage,t.storage,e.storage)}function Gc(r,t=2){return Ft(r,t).map(n=>I._fromStorage(n))}function Hc(r){return Uo(r.storage).map(e=>I._fromStorage(e))}function Yc(r,t=0,e){return Rt(r,t,e).map(o=>I._fromStorage(o))}function Jc(r,t=0){return $o(r.storage,t).map(n=>I._fromStorage(n))}function Qc(r,t=0,e){return jt(r,t,e).map(o=>I._fromStorage(o))}function Xc(r,t=0){return Mo(r.storage,t).map(n=>I._fromStorage(n))}function Kc(r,t,e=0){return ko(r,(a,i)=>t(a,i).storage,e).map(a=>I._fromStorage(a))}function rl(r,t="int32"){return I._fromStorage(Co(r,t))}function tl(...r){return Vo(...r.map(e=>e.storage)).map(e=>I._fromStorage(e))}function el(r,t,e="raise"){let n=r.map(o=>o.storage);return I._fromStorage(Po(n,t,e))}function nl(r,t,e="C"){let n=r instanceof I?r.storage:r;return qo(n,t,e).map(a=>I._fromStorage(a))}function ol(r,t=-1){return I._fromStorage(Wt(r.storage,t))}function al(r,t=-1){return I._fromStorage(Zt(r.storage,t))}function sl(r){let t=r.map(e=>e.storage);return I._fromStorage(Ko(t))}function il(r,t,e=-1){return I._fromStorage(Gt(r.storage,t,e))}function ul(r,t,e=-1){return I._fromStorage(Ht(r.storage,t,e))}function cl(r){return I._fromStorage(ra(r.storage))}function ll(r){return Xr(r.storage).map(e=>I._fromStorage(e))}function fl(r){return I._fromStorage(ta(r.storage))}function ml(r,t,e){let n=ea(r.storage,t?.storage,e?.storage);return Array.isArray(n)?n.map(o=>I._fromStorage(o)):I._fromStorage(n)}function pl(r,t,e="left"){return I._fromStorage(Yt(r.storage,t.storage,e))}function yl(r,t){return I._fromStorage(na(r.storage,t.storage))}function dl(r,t){let e=Jt(r.storage,t);return typeof e=="number"?e:I._fromStorage(e)}function wa(r,t=0){return I._fromStorage(Qt(r.storage,t))}function gl(r){return I._fromStorage(Xt(r.storage))}function Al(r){return I._fromStorage(Kt(r.storage))}function hl(r){return I._fromStorage(re(r.storage))}function bl(r){return I._fromStorage(te(r.storage))}function Sl(r){return I._fromStorage(ee(r.storage))}function Nl(r,t=!1,e=!1,n=!1){let o=K(r.storage,t,e,n);if(o instanceof N)return I._fromStorage(o);let a={values:I._fromStorage(o.values)};return o.indices&&(a.indices=I._fromStorage(o.indices)),o.inverse&&(a.inverse=I._fromStorage(o.inverse)),o.counts&&(a.counts=I._fromStorage(o.counts)),a}function Dl(r,t){return I._fromStorage(ia(r.storage,t.storage))}function xl(r,t){return I._fromStorage(ua(r.storage,t.storage))}function wl(r,t){return I._fromStorage(ne(r.storage,t.storage))}function zl(r,t){return I._fromStorage(ca(r.storage,t.storage))}function Il(r,t){return I._fromStorage(la(r.storage,t.storage))}function _l(r,t){return I._fromStorage(fa(r.storage,t.storage))}function Bl(r,t=1,e=-1){return I._fromStorage(oe(r.storage,t,e))}function vl(r,t=null,e=null){return I._fromStorage(pa(r.storage,t,e))}function El(r,t=1,e=null){let n=ya(r.storage,t,e);return Array.isArray(n)?n.map(o=>I._fromStorage(o)):I._fromStorage(n)}function Ol(r,t,e=-1,n=-1,o=-1){return I._fromStorage(da(r.storage,t.storage,e,n,o))}var I,qc,rt=k(()=>{"use strict";xe();j();R();Re();Qe();Ke();Ot();Ln();eo();po();No();Fo();Xo();oa();sa();ma();ga();I=class r{constructor(t,e){this._storage=t,this._base=e}get storage(){return this._storage}static _fromStorage(t,e){return new r(t,e)}get shape(){return this._storage.shape}get ndim(){return this._storage.ndim}get size(){return this._storage.size}get dtype(){return this._storage.dtype}get data(){return this._storage.data}get strides(){return this._storage.strides}get flags(){return{C_CONTIGUOUS:this._storage.isCContiguous,F_CONTIGUOUS:this._storage.isFContiguous,OWNDATA:this._base===void 0}}get base(){return this._base??null}get(t){if(t.length!==this.ndim)throw new Error(`Index has ${t.length} dimensions, but array has ${this.ndim} dimensions`);let e=t.map((n,o)=>{let a=n;if(a<0&&(a=this.shape[o]+a),a<0||a>=this.shape[o])throw new Error(`Index ${n} is out of bounds for axis ${o} with size ${this.shape[o]}`);return a});return this._storage.get(...e)}set(t,e){if(t.length!==this.ndim)throw new Error(`Index has ${t.length} dimensions, but array has ${this.ndim} dimensions`);let n=t.map((i,u)=>{let s=i;if(s<0&&(s=this.shape[u]+s),s<0||s>=this.shape[u])throw new Error(`Index ${i} is out of bounds for axis ${u} with size ${this.shape[u]}`);return s}),o=this.dtype,a;z(o)?a=typeof e=="bigint"?e:BigInt(Math.round(e)):o==="bool"?a=e?1:0:a=Number(e),this._storage.set(n,a)}copy(){return new r(this._storage.copy())}astype(t,e=!0){let n=this.dtype;if(n===t&&!e)return this;if(n===t&&e)return this.copy();let o=Array.from(this.shape),a=this.size,i=U(t);if(!i)throw new Error(`Cannot convert to dtype ${t}`);let u=new i(a),s=this.data;if(z(n)&&!z(t)){let l=s;if(t==="bool")for(let m=0;m<a;m++)u[m]=l[m]!==BigInt(0)?1:0;else for(let m=0;m<a;m++)u[m]=Number(l[m])}else if(!z(n)&&z(t)){let l=s;for(let m=0;m<a;m++)u[m]=BigInt(Math.round(Number(l[m])))}else if(t==="bool"){let l=s;for(let m=0;m<a;m++)u[m]=l[m]!==0?1:0}else if(n==="bool"&&!z(t)){let l=s;for(let m=0;m<a;m++)u[m]=l[m]}else if(!z(n)&&!z(t)){let l=s;for(let m=0;m<a;m++)u[m]=l[m]}else{let l=s;for(let m=0;m<a;m++)u[m]=l[m]}let c=N.fromData(u,o,t);return new r(c)}add(t){let e=typeof t=="number"?t:t._storage,n=_e(this._storage,e);return r._fromStorage(n)}subtract(t){let e=typeof t=="number"?t:t._storage,n=Be(this._storage,e);return r._fromStorage(n)}multiply(t){let e=typeof t=="number"?t:t._storage,n=ve(this._storage,e);return r._fromStorage(n)}divide(t){let e=typeof t=="number"?t:t._storage,n=Ee(this._storage,e);return r._fromStorage(n)}mod(t){let e=typeof t=="number"?t:t._storage,n=kr(this._storage,e);return r._fromStorage(n)}floor_divide(t){let e=typeof t=="number"?t:t._storage,n=lt(this._storage,e);return r._fromStorage(n)}positive(){let t=$e(this._storage);return r._fromStorage(t)}reciprocal(){let t=Me(this._storage);return r._fromStorage(t)}sqrt(){let t=Wn(this._storage);return r._fromStorage(t)}power(t){let e=typeof t=="number"?t:t._storage,n=Zn(this._storage,e);return r._fromStorage(n)}exp(){let t=Gn(this._storage);return r._fromStorage(t)}exp2(){let t=Hn(this._storage);return r._fromStorage(t)}expm1(){let t=Yn(this._storage);return r._fromStorage(t)}log(){let t=Jn(this._storage);return r._fromStorage(t)}log2(){let t=Qn(this._storage);return r._fromStorage(t)}log10(){let t=Xn(this._storage);return r._fromStorage(t)}log1p(){let t=Kn(this._storage);return r._fromStorage(t)}logaddexp(t){let e=typeof t=="number"?t:t._storage,n=ro(this._storage,e);return r._fromStorage(n)}logaddexp2(t){let e=typeof t=="number"?t:t._storage,n=to(this._storage,e);return r._fromStorage(n)}absolute(){let t=Oe(this._storage);return r._fromStorage(t)}negative(){let t=Te(this._storage);return r._fromStorage(t)}sign(){let t=Ue(this._storage);return r._fromStorage(t)}around(t=0){let e=Qt(this._storage,t);return r._fromStorage(e)}round(t=0){return this.around(t)}ceil(){let t=Xt(this._storage);return r._fromStorage(t)}fix(){let t=Kt(this._storage);return r._fromStorage(t)}floor(){let t=re(this._storage);return r._fromStorage(t)}rint(){let t=te(this._storage);return r._fromStorage(t)}trunc(){let t=ee(this._storage);return r._fromStorage(t)}sin(){let t=no(this._storage);return r._fromStorage(t)}cos(){let t=oo(this._storage);return r._fromStorage(t)}tan(){let t=ao(this._storage);return r._fromStorage(t)}arcsin(){let t=so(this._storage);return r._fromStorage(t)}arccos(){let t=io(this._storage);return r._fromStorage(t)}arctan(){let t=uo(this._storage);return r._fromStorage(t)}arctan2(t){let e=typeof t=="number"?t:t._storage,n=co(this._storage,e);return r._fromStorage(n)}hypot(t){let e=typeof t=="number"?t:t._storage,n=lo(this._storage,e);return r._fromStorage(n)}degrees(){let t=fo(this._storage);return r._fromStorage(t)}radians(){let t=mo(this._storage);return r._fromStorage(t)}sinh(){let t=yo(this._storage);return r._fromStorage(t)}cosh(){let t=go(this._storage);return r._fromStorage(t)}tanh(){let t=Ao(this._storage);return r._fromStorage(t)}arcsinh(){let t=ho(this._storage);return r._fromStorage(t)}arccosh(){let t=bo(this._storage);return r._fromStorage(t)}arctanh(){let t=So(this._storage);return r._fromStorage(t)}greater(t){let e=typeof t=="number"?t:t._storage,n=je(this._storage,e);return r._fromStorage(n)}greater_equal(t){let e=typeof t=="number"?t:t._storage,n=Le(this._storage,e);return r._fromStorage(n)}less(t){let e=typeof t=="number"?t:t._storage,n=We(this._storage,e);return r._fromStorage(n)}less_equal(t){let e=typeof t=="number"?t:t._storage,n=Ze(this._storage,e);return r._fromStorage(n)}equal(t){let e=typeof t=="number"?t:t._storage,n=Ge(this._storage,e);return r._fromStorage(n)}not_equal(t){let e=typeof t=="number"?t:t._storage,n=He(this._storage,e);return r._fromStorage(n)}isclose(t,e=1e-5,n=1e-8){let o=typeof t=="number"?t:t._storage,a=pt(this._storage,o,e,n);return r._fromStorage(a)}allclose(t,e=1e-5,n=1e-8){let o=typeof t=="number"?t:t._storage;return Ye(this._storage,o,e,n)}bitwise_and(t){let e=typeof t=="number"?t:t._storage,n=Lo(this._storage,e);return r._fromStorage(n)}bitwise_or(t){let e=typeof t=="number"?t:t._storage,n=Wo(this._storage,e);return r._fromStorage(n)}bitwise_xor(t){let e=typeof t=="number"?t:t._storage,n=Zo(this._storage,e);return r._fromStorage(n)}bitwise_not(){let t=Lt(this._storage);return r._fromStorage(t)}invert(){let t=Go(this._storage);return r._fromStorage(t)}left_shift(t){let e=typeof t=="number"?t:t._storage,n=Ho(this._storage,e);return r._fromStorage(n)}right_shift(t){let e=typeof t=="number"?t:t._storage,n=Yo(this._storage,e);return r._fromStorage(n)}sum(t,e=!1){let n=Sr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}mean(t,e=!1){let n=Cr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}max(t,e=!1){let n=Vr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}min(t,e=!1){let n=Pr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}prod(t,e=!1){let n=dt(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}argmin(t){let e=gt(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}argmax(t){let e=At(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}var(t,e=0,n=!1){let o=ht(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}std(t,e=0,n=!1){let o=Xe(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}all(t,e=!1){let n=bt(this._storage,t,e);return typeof n=="boolean"?n:r._fromStorage(n)}any(t,e=!1){let n=St(this._storage,t,e);return typeof n=="boolean"?n:r._fromStorage(n)}cumsum(t){return r._fromStorage(Nt(this._storage,t))}cumprod(t){return r._fromStorage(Dt(this._storage,t))}ptp(t,e=!1){let n=xt(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}median(t,e=!1){let n=wt(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}percentile(t,e,n=!1){let o=zt(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}quantile(t,e,n=!1){let o=fr(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}average(t,e){let n=qr(this._storage,e,t?.storage);return typeof n=="number"?n:r._fromStorage(n)}nansum(t,e=!1){let n=Fr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanprod(t,e=!1){let n=Rr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanmean(t,e=!1){let n=jr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanvar(t,e=0,n=!1){let o=Nr(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}nanstd(t,e=0,n=!1){let o=It(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}nanmin(t,e=!1){let n=Lr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanmax(t,e=!1){let n=Wr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanargmin(t){let e=Zr(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}nanargmax(t){let e=Gr(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}nancumsum(t){return r._fromStorage(_t(this._storage,t))}nancumprod(t){return r._fromStorage(Bt(this._storage,t))}nanmedian(t,e=!1){let n=Hr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}sort(t=-1){return r._fromStorage(Wt(this._storage,t))}argsort(t=-1){return r._fromStorage(Zt(this._storage,t))}partition(t,e=-1){return r._fromStorage(Gt(this._storage,t,e))}argpartition(t,e=-1){return r._fromStorage(Ht(this._storage,t,e))}nonzero(){return Xr(this._storage).map(e=>r._fromStorage(e))}searchsorted(t,e="left"){return r._fromStorage(Yt(this._storage,t._storage,e))}diff(t=1,e=-1){return r._fromStorage(oe(this._storage,t,e))}reshape(...t){let e=t.length===1&&Array.isArray(t[0])?t[0]:t,n=W(this._storage,e),a=n.data===this.data?this._base??this:void 0;return r._fromStorage(n,a)}flatten(){let t=Yr(this._storage);return r._fromStorage(t)}ravel(){let t=mr(this._storage),n=t.data===this.data?this._base??this:void 0;return r._fromStorage(t,n)}transpose(t){let e=xr(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}squeeze(t){let e=rn(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}expand_dims(t){let e=Dr(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}swapaxes(t,e){let n=tn(this._storage,t,e),o=this._base??this;return r._fromStorage(n,o)}moveaxis(t,e){let n=vt(this._storage,t,e),o=this._base??this;return r._fromStorage(n,o)}repeat(t,e){let n=fn(this._storage,t,e);return r._fromStorage(n)}take(t,e){let n=xo(this._storage,t,e);return r._fromStorage(n)}put(t,e){let n=e instanceof r?e._storage:e;wo(this._storage,t,n)}matmul(t){let e=J(this._storage,t._storage);return r._fromStorage(e)}dot(t){let e=Ut(this._storage,t._storage);return typeof e=="number"||typeof e=="bigint"?e:r._fromStorage(e)}trace(){return zn(this._storage)}inner(t){let e=In(this._storage,t._storage);return typeof e=="number"||typeof e=="bigint"?e:r._fromStorage(e)}outer(t){let e=$t(this._storage,t._storage);return r._fromStorage(e)}tensordot(t,e=2){let n=_n(this._storage,t._storage,e);return typeof n=="number"||typeof n=="bigint"?n:r._fromStorage(n)}cbrt(){let t=ke(this._storage);return r._fromStorage(t)}fabs(){let t=Ce(this._storage);return r._fromStorage(t)}divmod(t){let e=typeof t=="number"?t:t._storage,[n,o]=Ve(this._storage,e);return[r._fromStorage(n),r._fromStorage(o)]}square(){let t=Pe(this._storage);return r._fromStorage(t)}remainder(t){let e=typeof t=="number"?t:t._storage,n=qe(this._storage,e);return r._fromStorage(n)}heaviside(t){let e=typeof t=="number"?t:t._storage,n=Fe(this._storage,e);return r._fromStorage(n)}slice(...t){if(t.length===0)return this;if(t.length>this.ndim)throw new Error(`Too many indices for array: array is ${this.ndim}-dimensional, but ${t.length} were indexed`);let e=t.map((s,c)=>{let l=Ne(s);return De(l,this.shape[c])});for(;e.length<this.ndim;)e.push({start:0,stop:this.shape[e.length],step:1,isIndex:!1});let n=[],o=[],a=this._storage.offset;for(let s=0;s<e.length;s++){let c=e[s],l=this._storage.strides[s];if(a+=c.start*l,!c.isIndex){let m;c.step>0?m=Math.max(0,Math.ceil((c.stop-c.start)/c.step)):m=Math.max(0,Math.ceil((c.start-c.stop)/Math.abs(c.step))),n.push(m),o.push(l*c.step)}}let i=N.fromData(this._storage.data,n,this._storage.dtype,o,a),u=this._base??this;return new r(i,u)}row(t){if(this.ndim<2)throw new Error("row() requires at least 2 dimensions");return this.slice(String(t),":")}col(t){if(this.ndim<2)throw new Error("col() requires at least 2 dimensions");return this.slice(":",String(t))}rows(t,e){if(this.ndim<2)throw new Error("rows() requires at least 2 dimensions");return this.slice(`${t}:${e}`,":")}cols(t,e){if(this.ndim<2)throw new Error("cols() requires at least 2 dimensions");return this.slice(":",`${t}:${e}`)}toString(){return`NDArray(shape=${JSON.stringify(this.shape)}, dtype=${this.dtype})`}toArray(){if(this.ndim===0)return this._storage.iget(0);let t=this.shape,e=t.length,n=(o,a)=>{if(a===e)return this._storage.get(...o);let i=[];for(let u=0;u<t[a];u++)o[a]=u,i.push(n(o,a+1));return i};return n(new Array(e),0)}};qc={cross:(r,t,e=-1,n=-1,o=-1,a)=>{let i=On(r.storage,t.storage,e,n,o,a);return typeof i=="number"?i:I._fromStorage(i)},norm:(r,t=null,e=null,n=!1)=>{let o=Tn(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)},vector_norm:(r,t=2,e,n=!1)=>{let o=pr(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)},matrix_norm:(r,t="fro",e=!1)=>{let n=ur(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)},qr:(r,t="reduced")=>{let e=Mt(r.storage,t);return e instanceof N?I._fromStorage(e):"q"in e&&"r"in e?{q:I._fromStorage(e.q),r:I._fromStorage(e.r)}:{h:I._fromStorage(e.h),tau:I._fromStorage(e.tau)}},cholesky:(r,t=!1)=>I._fromStorage(Un(r.storage,t)),svd:(r,t=!0,e=!0)=>{let n=$n(r.storage,t,e);return"u"in n?{u:I._fromStorage(n.u),s:I._fromStorage(n.s),vt:I._fromStorage(n.vt)}:I._fromStorage(n)},det:r=>Mn(r.storage),inv:r=>I._fromStorage(Jr(r.storage)),solve:(r,t)=>I._fromStorage(kn(r.storage,t.storage)),lstsq:(r,t,e=null)=>{let n=Cn(r.storage,t.storage,e);return{x:I._fromStorage(n.x),residuals:I._fromStorage(n.residuals),rank:n.rank,s:I._fromStorage(n.s)}},cond:(r,t=2)=>Vn(r.storage,t),matrix_rank:(r,t)=>Pn(r.storage,t),matrix_power:(r,t)=>I._fromStorage(qn(r.storage,t)),pinv:(r,t=1e-15)=>I._fromStorage(Fn(r.storage,t)),eig:r=>{let t=Vt(r.storage);return{w:I._fromStorage(t.w),v:I._fromStorage(t.v)}},eigh:(r,t="L")=>{let e=Pt(r.storage,t);return{w:I._fromStorage(e.w),v:I._fromStorage(e.v)}},eigvals:r=>I._fromStorage(Rn(r.storage)),eigvalsh:(r,t="L")=>I._fromStorage(jn(r.storage,t))}});function ie(){let r=new ArrayBuffer(2);return new DataView(r).setInt16(0,256,!0),new Int16Array(r)[0]===256}function Ia(r){if(r.startsWith("[")||r.startsWith("("))throw new tr(`Structured/compound dtypes are not supported: ${r}`);let t="",e=r;(r[0]==="<"||r[0]===">"||r[0]==="="||r[0]==="|")&&(t=r[0],e=r.slice(1));let n=e[0];if(n&&n in za)throw new tr(`Unsupported dtype: ${za[n]} (${r}). Use the 'force' parameter to skip arrays with unsupported dtypes.`);let o=Tl[e];if(!o)throw new tr(`Unknown or unsupported dtype descriptor: ${r}. Supported types: ${se.join(", ")}. Use the 'force' parameter to skip arrays with unsupported dtypes.`);let a=ie(),i=t==="<"||t==="|"||t==="="&&a,u=t===">"||t==="="&&!a,s=parseInt(e.slice(1),10),c=s>1&&(u&&a||i&&!a);return{dtype:o,needsByteSwap:c,itemsize:s}}var Ir,se,Tl,tt,za,tr,Y,_r=k(()=>{"use strict";Ir=new Uint8Array([147,78,85,77,80,89]),se=["float64","float32","int64","int32","int16","int8","uint64","uint32","uint16","uint8","bool"];Tl={f8:"float64",f4:"float32",i8:"int64",i4:"int32",i2:"int16",i1:"int8",u8:"uint64",u4:"uint32",u2:"uint16",u1:"uint8",b1:"bool"},tt={float64:"<f8",float32:"<f4",int64:"<i8",int32:"<i4",int16:"<i2",int8:"|i1",uint64:"<u8",uint32:"<u4",uint16:"<u2",uint8:"|u1",bool:"|b1"},za={c:"complex numbers",S:"byte strings",U:"Unicode strings",O:"Python objects",V:"structured arrays (void)",M:"datetime64",m:"timedelta64"};tr=class extends Error{constructor(t){super(t),this.name="UnsupportedDTypeError"}},Y=class extends Error{constructor(t){super(t),this.name="InvalidNpyError"}}});function cr(r){let t=r instanceof ArrayBuffer?new Uint8Array(r):r,e=ue(t);return ce(t,e)}function ue(r){if(r.length<10)throw new Y("File too small to be a valid NPY file");for(let c=0;c<Ir.length;c++)if(r[c]!==Ir[c])throw new Y("Invalid NPY magic number");let t=r[6],e=r[7];if(t!==1&&t!==2&&t!==3)throw new Y(`Unsupported NPY version: ${t}.${e}`);let n,o;t===1?(n=r[8]|r[9]<<8,o=10):(n=r[8]|r[9]<<8|r[10]<<16|r[11]<<24,o=12);let a=o+n;if(r.length<a)throw new Y("File truncated: header extends beyond file");let i=r.slice(o,a),u=new TextDecoder("utf-8").decode(i).trim(),s=Ul(u);return{version:{major:t,minor:e},header:s,dataOffset:a}}function ce(r,t){let{header:e,dataOffset:n}=t,{dtype:o,needsByteSwap:a,itemsize:i}=Ia(e.descr),u=e.shape.reduce((d,g)=>d*g,1),s=u*i,c=r.length-n;if(c<s)throw new Y(`File truncated: expected ${s} bytes of data, got ${c}`);let l=new ArrayBuffer(s);new Uint8Array(l).set(r.subarray(n,n+s));let f=$l(l,o,u,a,i),p=e.shape,y;if(e.fortran_order&&p.length>1){let d=[...p].reverse(),g=N.fromData(f,d,o);y=Ml(g,d),p=e.shape}else y=N.fromData(f,[...p],o);return new I(y)}function Ul(r){let t=r.match(/'descr'\s*:\s*'([^']+)'/),e=r.match(/'fortran_order'\s*:\s*(True|False)/),n=r.match(/'shape'\s*:\s*\(([^)]*)\)/);if(!t||!e||!n)throw new Y(`Failed to parse NPY header: ${r}`);let o=t[1],a=e[1]==="True",i=n[1].trim(),u;return i===""?u=[]:u=i.split(",").map(s=>s.trim()).filter(s=>s!=="").map(s=>{let c=parseInt(s,10);if(isNaN(c))throw new Y(`Invalid shape value: ${s}`);return c}),{descr:o,fortran_order:a,shape:u}}function $l(r,t,e,n,o){let a=U(t);if(!a)throw new Y(`Cannot create array for dtype: ${t}`);if(!n)return new a(r,0,e);let i=new Uint8Array(r),u=new Uint8Array(r.byteLength);for(let s=0;s<e;s++){let c=s*o;for(let l=0;l<o;l++)u[c+l]=i[c+o-1-l]}return new a(u.buffer,0,e)}function Ml(r,t){let e=t.length,n=r.size,o=r.dtype,a=U(o);if(!a)throw new Y(`Cannot create array for dtype: ${o}`);let i=new a(n),u=[...t].reverse(),s=_a(t),c=_a(u),l=new Array(e).fill(0);for(let m=0;m<n;m++){let f=m;for(let y=0;y<e;y++){let d=s[y];l[y]=Math.floor(f/d),f=f%d}let p=0;for(let y=0;y<e;y++)p+=l[e-1-y]*c[y];z(o),i[p]=r.iget(m)}return N.fromData(i,u,o)}function _a(r){let t=new Array(r.length),e=1;for(let n=r.length-1;n>=0;n--)t[n]=e,e*=r[n];return t}var et=k(()=>{"use strict";rt();R();j();_r()});function ar(r){let t=r.shape,e=r.dtype,n=tt[e],o=t.length===0?"()":t.length===1?`(${t[0]},)`:`(${t.join(", ")})`,a=`{'descr': '${n}', 'fortran_order': False, 'shape': ${o}, }`,i=12,s=(64-(i+a.length+1)%64)%64;a=a+" ".repeat(s)+`
2
+ `;let c=new TextEncoder().encode(a),l=c.length,m=r.size,f=ze(e),p=m*f,y=i+l+p,d=new Uint8Array(y);d.set(Ir,0),d[6]=3,d[7]=0,d[8]=l&255,d[9]=l>>8&255,d[10]=l>>16&255,d[11]=l>>24&255,d.set(c,i);let g=i+l;return kl(r,d.subarray(g),f),d}function kl(r,t,e){let n=r.dtype,o=r.size,a=ie(),i=z(n),u=r._storage;if(u.isCContiguous&&u.offset===0&&a){let c=u.data,l=new Uint8Array(c.buffer,c.byteOffset,o*e);t.set(l)}else{let c=new DataView(t.buffer,t.byteOffset,t.byteLength);for(let l=0;l<o;l++){let m=u.iget(l),f=l*e;i?Cl(c,f,m,n==="uint64"):Vl(c,f,m,n)}}}function Cl(r,t,e,n){n?r.setBigUint64(t,e,!0):r.setBigInt64(t,e,!0)}function Vl(r,t,e,n){switch(n){case"float64":r.setFloat64(t,e,!0);break;case"float32":r.setFloat32(t,e,!0);break;case"int32":r.setInt32(t,e,!0);break;case"int16":r.setInt16(t,e,!0);break;case"int8":r.setInt8(t,e);break;case"uint32":r.setUint32(t,e,!0);break;case"uint16":r.setUint16(t,e,!0);break;case"uint8":case"bool":r.setUint8(t,e);break;default:throw new Error(`Unsupported dtype for serialization: ${n}`)}}var nt=k(()=>{"use strict";j();_r()});function le(r){let t=4294967295;for(let e=0;e<r.length;e++)t=Pl[(t^r[e])&255]^t>>>8;return(t^4294967295)>>>0}var Pl,fe=k(()=>{"use strict";Pl=(()=>{let r=new Uint32Array(256);for(let t=0;t<256;t++){let e=t;for(let n=0;n<8;n++)e=e&1?3988292384^e>>>1:e>>>1;r[t]=e}return r})()});async function Ba(r){let t=Ea(r),e=new Map;for(let n of t){let o=await ql(n);e.set(n.name,o)}return e}function va(r){let t=Ea(r),e=new Map;for(let n of t){if(n.compressionMethod!==0)throw new Error(`Cannot read compressed entry synchronously: ${n.name}. Use readZip() (async) for DEFLATE-compressed files.`);e.set(n.name,n.compressedData)}return e}function Ea(r){let t=r instanceof ArrayBuffer?new Uint8Array(r):r,e=new DataView(t.buffer,t.byteOffset,t.byteLength),n=[],o=-1;for(let c=t.length-22;c>=0;c--)if(e.getUint32(c,!0)===101010256){o=c;break}if(o===-1)throw new Error("Invalid ZIP file: end of central directory not found");let a=e.getUint32(o+16,!0),i=e.getUint16(o+10,!0),u=[],s=a;for(let c=0;c<i&&e.getUint32(s,!0)===33639248;c++){let m=e.getUint16(s+10,!0),f=e.getUint32(s+16,!0),p=e.getUint32(s+20,!0),y=e.getUint32(s+24,!0),d=e.getUint16(s+28,!0),g=e.getUint16(s+30,!0),b=e.getUint16(s+32,!0),h=e.getUint32(s+42,!0),A=t.slice(s+46,s+46+d),S=new TextDecoder("utf-8").decode(A);u.push({name:S,compressionMethod:m,crc32:f,compressedSize:p,uncompressedSize:y,localHeaderOffset:h}),s=s+46+d+g+b}for(let c of u){let l=c.localHeaderOffset;if(e.getUint32(l,!0)!==67324752)throw new Error(`Invalid local file header at offset ${l}`);let f=e.getUint16(l+26,!0),p=e.getUint16(l+28,!0),y=l+30+f+p,d=t.slice(y,y+c.compressedSize);n.push({name:c.name,compressedData:d,compressionMethod:c.compressionMethod,crc32:c.crc32,compressedSize:c.compressedSize,uncompressedSize:c.uncompressedSize})}return n}async function ql(r){if(r.compressionMethod===0)return r.compressedData;if(r.compressionMethod===8)return await Fl(r.compressedData);throw new Error(`Unsupported compression method: ${r.compressionMethod}`)}async function Fl(r){if(typeof DecompressionStream>"u")throw new Error("DecompressionStream is not available. This environment does not support the Compression Streams API. Please use a modern browser or Node.js 18+.");let t=new DecompressionStream("deflate-raw"),e=new Uint8Array(r.length);e.set(r);let n=t.writable.getWriter();n.write(e),n.close();let o=t.readable.getReader(),a=[];for(;;){let{done:c,value:l}=await o.read();if(c)break;a.push(l)}let i=a.reduce((c,l)=>c+l.length,0),u=new Uint8Array(i),s=0;for(let c of a)u.set(c,s),s+=c.length;return u}var Oa=k(()=>{"use strict";fe()});var Ua={};be(Ua,{loadNpz:()=>ye,loadNpzSync:()=>de,parseNpz:()=>gr,parseNpzSync:()=>ot});async function gr(r,t={}){let e=t.force??!1,n=await Ba(r);return Ta(n,e)}function ot(r,t={}){let e=t.force??!1,n=va(r);return Ta(n,e)}function Ta(r,t){let e=new Map,n=[],o=new Map;for(let[a,i]of r){if(!a.endsWith(".npy"))continue;let u=a.slice(0,-4);try{let s=cr(i);e.set(u,s)}catch(s){if(s instanceof tr&&t)n.push(u),o.set(u,s.message);else throw s}}return{arrays:e,skipped:n,errors:o}}async function ye(r,t={}){let e=await gr(r,t);return Object.fromEntries(e.arrays)}function de(r,t={}){let e=ot(r,t);return Object.fromEntries(e.arrays)}var at=k(()=>{"use strict";et();_r();Oa()});async function $a(r,t={}){let e=t.compress??!1,n=[];for(let[f,p]of r){let y=le(p),d,g;e?(d=await jl(p),d.length<p.length?g=8:(d=p,g=0)):(d=p,g=0),n.push({name:f,data:p,compressedData:d,crc:y,compressionMethod:g,offset:0})}let o=0;for(let f of n){let p=new TextEncoder().encode(f.name);o+=30+p.length+f.compressedData.length}let a=0;for(let f of n){let p=new TextEncoder().encode(f.name);a+=46+p.length}let u=o+a+22,s=new Uint8Array(u),c=new DataView(s.buffer),l=0;for(let f of n)f.offset=l,l=ka(s,c,l,f);let m=l;for(let f of n)l=Ca(s,c,l,f);return Va(c,l,n.length,a,m),s}function Ma(r){let t=[];for(let[l,m]of r){let f=le(m);t.push({name:l,data:m,compressedData:m,crc:f,compressionMethod:0,offset:0})}let e=0;for(let l of t){let m=new TextEncoder().encode(l.name);e+=30+m.length+l.compressedData.length}let n=0;for(let l of t){let m=new TextEncoder().encode(l.name);n+=46+m.length}let a=e+n+22,i=new Uint8Array(a),u=new DataView(i.buffer),s=0;for(let l of t)l.offset=s,s=ka(i,u,s,l);let c=s;for(let l of t)s=Ca(i,u,s,l);return Va(u,s,t.length,n,c),i}function ka(r,t,e,n){let o=new TextEncoder().encode(n.name);return t.setUint32(e,67324752,!0),e+=4,t.setUint16(e,n.compressionMethod===8?20:10,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,n.compressionMethod,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,33,!0),e+=2,t.setUint32(e,n.crc,!0),e+=4,t.setUint32(e,n.compressedData.length,!0),e+=4,t.setUint32(e,n.data.length,!0),e+=4,t.setUint16(e,o.length,!0),e+=2,t.setUint16(e,0,!0),e+=2,r.set(o,e),e+=o.length,r.set(n.compressedData,e),e+=n.compressedData.length,e}function Ca(r,t,e,n){let o=new TextEncoder().encode(n.name);return t.setUint32(e,33639248,!0),e+=4,t.setUint16(e,20,!0),e+=2,t.setUint16(e,n.compressionMethod===8?20:10,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,n.compressionMethod,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,33,!0),e+=2,t.setUint32(e,n.crc,!0),e+=4,t.setUint32(e,n.compressedData.length,!0),e+=4,t.setUint32(e,n.data.length,!0),e+=4,t.setUint16(e,o.length,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint16(e,0,!0),e+=2,t.setUint32(e,0,!0),e+=4,t.setUint32(e,n.offset,!0),e+=4,r.set(o,e),e+=o.length,e}function Va(r,t,e,n,o){r.setUint32(t,101010256,!0),t+=4,r.setUint16(t,0,!0),t+=2,r.setUint16(t,0,!0),t+=2,r.setUint16(t,e,!0),t+=2,r.setUint16(t,e,!0),t+=2,r.setUint32(t,n,!0),t+=4,r.setUint32(t,o,!0),t+=4,r.setUint16(t,0,!0)}async function jl(r){if(typeof CompressionStream>"u")throw new Error("CompressionStream is not available. This environment does not support the Compression Streams API. Please use a modern browser or Node.js 18+.");let t=new CompressionStream("deflate-raw"),e=new Uint8Array(r.length);e.set(r);let n=t.writable.getWriter();n.write(e),n.close();let o=t.readable.getReader(),a=[];for(;;){let{done:c,value:l}=await o.read();if(c)break;a.push(l)}let i=a.reduce((c,l)=>c+l.length,0),u=new Uint8Array(i),s=0;for(let c of a)u.set(c,s),s+=c.length;return u}var Pa=k(()=>{"use strict";fe()});var Fa={};be(Fa,{serializeNpz:()=>vr,serializeNpzSync:()=>ge});async function vr(r,t={}){let e=qa(r);return $a(e,{compress:t.compress??!1})}function ge(r){let t=qa(r);return Ma(t)}function qa(r){let t=new Map;if(Array.isArray(r)){for(let n=0;n<r.length;n++){let o=r[n],a=ar(o);t.set(`arr_${n}.npy`,a)}return t}let e=r instanceof Map?r.entries():Object.entries(r);for(let[n,o]of e){if(typeof n!="string"||n.length===0)throw new Error("Array names must be non-empty strings");let a=ar(o),i=n.endsWith(".npy")?n:`${n}.npy`;t.set(i,a)}return t}var st=k(()=>{"use strict";nt();Pa()});et();nt();at();st();import{readFileSync as Ur,writeFileSync as Ae}from"node:fs";import{readFile as $r,writeFile as he}from"node:fs/promises";rt();function Ar(r,t={}){let{delimiter:e,comments:n="#",skiprows:o=0,usecols:a,max_rows:i,dtype:u="float64",missing_values:s,filling_values:c}=t,l=r.split(/\r?\n/);if(o>0&&(l=l.slice(o)),l=l.filter(d=>{let g=d.trim();return!(g===""||n&&g.startsWith(n))}),i!==void 0&&i>0&&(l=l.slice(0,i)),l.length===0)return F([],u);let m=[],f=new Set(s?Array.isArray(s)?s:[s]:[]),p=c!==void 0?c:u.includes("int")||u==="bool"?0:NaN;for(let d of l){let g;e===void 0?g=d.trim().split(/\s+/):g=d.split(e),a!==void 0&&(g=(Array.isArray(a)?a:[a]).map(A=>(A<0&&(A=g.length+A),g[A]??"")));let b=g.map(h=>{let A=h.trim();if(f.has(A)||A==="")return p;let S=parseFloat(A);return isNaN(S)?p:S});m.push(b)}let y=m[0]?.length??0;for(let d=1;d<m.length;d++)if(m[d].length!==y)throw new Error(`Inconsistent number of columns: row 0 has ${y} columns, row ${d} has ${m[d].length} columns`);return y===1?F(m.map(d=>d[0]),u):F(m,u)}function Er(r,t={}){let e={...t,missing_values:t.missing_values??["","nan","NaN","NA","N/A","-"],filling_values:t.filling_values??NaN};return Ar(r,e)}function Or(r,t,e="float64"){let n=typeof t=="string"?new RegExp(t,"gm"):new RegExp(t.source,"gm"),o=[],a;for(;(a=n.exec(r))!==null;)if(a.length>1){let i=a.slice(1).map(u=>{let s=parseFloat(u);return isNaN(s)?0:s});o.push(i)}return o.length===0?F([],e):o[0].length===1?F(o.map(i=>i[0]),e):F(o,e)}function Ra(r,t){let e=typeof r=="bigint"?Number(r):r,n=t.match(/^%([+-]?)(\d*)(?:\.(\d+))?([dfeEgGs])$/);if(!n)return String(e);let[,o,a,i,u]=n,s=i!==void 0?parseInt(i,10):void 0,c;switch(u){case"d":c=Math.round(e).toString();break;case"f":c=e.toFixed(s??6);break;case"e":c=e.toExponential(s??6).replace(/e([+-])(\d)$/,"e$10$2");break;case"E":c=e.toExponential(s??6).toUpperCase().replace(/E([+-])(\d)$/,"E$10$2");break;case"g":case"G":{let l=s??6,m=Math.floor(Math.log10(Math.abs(e)));m>=-4&&m<l?(c=e.toPrecision(l),c.includes(".")&&(c=c.replace(/\.?0+$/,""))):c=e.toExponential(l-1),u==="G"&&(c=c.toUpperCase());break}case"s":c=String(e);break;default:c=String(e)}if(a){let l=parseInt(a,10);if(c.length<l){let m=" ".repeat(l-c.length);o==="-"?c=c+m:c=m+c}}return o==="+"&&e>=0&&!c.startsWith("-")&&(c="+"+c),c}function Tr(r,t={}){let{fmt:e="%.18e",delimiter:n=" ",newline:o=`
3
+ `,header:a,footer:i,comments:u="# "}=t;if(r.ndim>2)throw new Error("savetxt: array must be 1D or 2D");let s=[];if(a!==void 0){let l=a.split(/\r?\n/);for(let m of l)m.startsWith(u.trimEnd())?s.push(m):s.push(u+m)}let c=r.toArray();if(r.ndim===1)for(let l of c)s.push(Ra(l,e));else for(let l of c){let m=l.map(f=>Ra(f,e));s.push(m.join(n))}if(i!==void 0){let l=i.split(/\r?\n/);for(let m of l)m.startsWith(u.trimEnd())?s.push(m):s.push(u+m)}return s.join(o)+o}rt();et();nt();_r();at();st();var Im="0.9.0";async function Ll(r){let t=await $r(r);return cr(t)}function Wl(r){let t=Ur(r);return cr(t)}async function Zl(r,t){let e=ar(t);await he(r,e)}function Gl(r,t){let e=ar(t);Ae(r,e)}async function Hl(r,t={}){let e=await $r(r);return gr(e,t)}function Yl(r,t={}){let e=Ur(r),{parseNpzSync:n}=(at(),Se(Ua));return n(e,t)}async function ja(r,t,e={}){let n=await vr(t,e);await he(r,n)}function Cm(r,t){let{serializeNpzSync:e}=(st(),Se(Fa)),n=e(t);Ae(r,n)}async function Vm(r,t={}){if(r.endsWith(".npy")){if(t.allowNpy===!1)throw new Error("Loading .npy files is disabled (allowNpy: false)");return Ll(r)}else{if(r.endsWith(".npz"))return Hl(r,t);throw new Error(`Unknown file extension. Expected .npy or .npz, got: ${r}`)}}function Pm(r,t={}){if(r.endsWith(".npy")){if(t.allowNpy===!1)throw new Error("Loading .npy files is disabled (allowNpy: false)");return Wl(r)}else{if(r.endsWith(".npz"))return Yl(r,t);throw new Error(`Unknown file extension. Expected .npy or .npz, got: ${r}`)}}async function qm(r,t){if(!r.endsWith(".npy"))throw new Error(`save() is for .npy files. Use saveNpz() for .npz files. Got: ${r}`);return Zl(r,t)}function Fm(r,t){if(!r.endsWith(".npy"))throw new Error(`saveSync() is for .npy files. Use saveNpzSync() for .npz files. Got: ${r}`);return Gl(r,t)}async function Rm(r,t){return r.endsWith(".npz")||(r=r+".npz"),ja(r,t,{compress:!1})}async function jm(r,t){return r.endsWith(".npz")||(r=r+".npz"),ja(r,t,{compress:!0})}async function Lm(r,t={}){let e=await $r(r,{encoding:t.encoding??"utf-8"});return Ar(e,t)}function Wm(r,t={}){let e=Ur(r,{encoding:t.encoding??"utf-8"});return Ar(e,t)}async function Zm(r,t,e={}){let n=Tr(t,e);await he(r,n,"utf-8")}function Gm(r,t,e={}){let n=Tr(t,e);Ae(r,n,"utf-8")}async function Hm(r,t={}){let e=await $r(r,{encoding:t.encoding??"utf-8"});return Er(e,t)}function Ym(r,t={}){let e=Ur(r,{encoding:t.encoding??"utf-8"});return Er(e,t)}async function Jm(r,t,e="float64"){let n=await $r(r,{encoding:"utf-8"});return Or(n,t,e)}function Qm(r,t,e="float64"){let n=Ur(r,{encoding:"utf-8"});return Or(n,t,e)}export{tt as DTYPE_TO_DESCR,Y as InvalidNpyError,I as NDArray,se as SUPPORTED_DTYPES,tr as UnsupportedDTypeError,Im as __version__,Fi as absolute,Gu as append,ai as arange,su as arccos,hu as arccosh,au as arcsin,Au as arcsinh,iu as arctan,uu as arctan2,bu as arctanh,ul as argpartition,al as argsort,wa as around,F as array,nc as array_equal,oc as array_equiv,Iu as array_split,di as asanyarray,Kr as asarray,gi as ascontiguousarray,Ai as asfortranarray,qu as atleast_1d,Fu as atleast_2d,Ru as atleast_3d,fc as average,Ec as bitwise_and,Uc as bitwise_not,Oc as bitwise_or,Tc as bitwise_xor,Xu as broadcast_arrays,Ku as broadcast_shapes,Qu as broadcast_to,wc as cbrt,gl as ceil,ec as choose,Lu as column_stack,Lc as compress,yr as concatenate,li as copy,nu as cos,du as cosh,dl as count_nonzero,Ol as cross,sc as cumprod,ac as cumsum,mu as deg2rad,lu as degrees,Hu as delete,Da as diag,Gc as diag_indices,Hc as diag_indices_from,hi as diagflat,Ji as diagonal,Bl as diff,Ic as divmod,Hi as dot,ju as dsplit,wu as dstack,vl as ediff1d,Pc as einsum,Sa as empty,pi as empty_like,Ti as exp,Ui as exp2,$u as expand_dims,$i as expm1,yl as extract,ba as eye,zc as fabs,Al as fix,fl as flatnonzero,ae as flip,Mu as fliplr,ku as flipud,hl as floor,Wi as floor_divide,zi as frombuffer,Ii as fromfile,bi as fromfunction,_i as fromiter,Jm as fromregex,Qm as fromregexSync,Bi as fromstring,Na as full,yi as full_like,Hm as genfromtxt,Ym as genfromtxtSync,ui as geomspace,El as gradient,vc as heaviside,Bu as hsplit,xu as hstack,cu as hypot,ci as identity,Dl as in1d,rl as indices,Ki as inner,Yu as insert,xl as intersect1d,$c as invert,wl as isin,tl as ix_,Qi as kron,Mc as left_shift,sl as lexsort,qc as linalg,si as linspace,Vm as load,Ll as loadNpy,Wl as loadNpySync,ye as loadNpz,Hl as loadNpzFile,Yl as loadNpzFileSync,de as loadNpzSync,Pm as loadSync,Lm as loadtxt,Wm as loadtxtSync,Mi as log,Ci as log10,Vi as log1p,ki as log2,Pi as logaddexp,qi as logaddexp2,ii as logspace,Kc as mask_indices,uc as median,Si as meshgrid,Li as mod,Nu as moveaxis,Sc as nanargmax,bc as nanargmin,Dc as nancumprod,Nc as nancumsum,hc as nanmax,yc as nanmean,xc as nanmedian,Ac as nanmin,pc as nanprod,gc as nanstd,mc as nansum,dc as nanvar,Ri as negative,ll as nonzero,Aa as ones,mi as ones_like,ru as outer,Cc as packbits,Ju as pad,cr as parseNpy,ce as parseNpyData,ue as parseNpyHeader,gr as parseNpz,ot as parseNpzSync,Ar as parseTxt,il as partition,cc as percentile,Zc as place,Zi as positive,Oi as power,ic as ptp,tc as put,Rc as put_along_axis,jc as putmask,lc as quantile,pu as rad2deg,fu as radians,Ou as ravel,el as ravel_multi_index,Gi as reciprocal,Bc as remainder,Eu as repeat,Tu as reshape,Zu as resize,kc as right_shift,bl as rint,Vu as roll,Pu as rollaxis,Cu as rot90,wa as round,Wu as row_stack,qm as save,Zl as saveNpy,Gl as saveNpySync,ja as saveNpz,Cm as saveNpzSync,Fm as saveSync,Zm as savetxt,Gm as savetxtSync,Rm as savez,jm as savez_compressed,pl as searchsorted,Wc as select,ar as serializeNpy,vr as serializeNpz,ge as serializeNpzSync,Tr as serializeTxt,zl as setdiff1d,Il as setxor1d,ji as sign,eu as sin,yu as sinh,ol as sort,cl as sort_complex,zu as split,Ei as sqrt,_c as square,Uu as squeeze,Du as stack,Su as swapaxes,rc as take,Fc as take_along_axis,ou as tan,gu as tanh,tu as tensordot,vu as tile,Yi as trace,Xi as transpose,Ni as tri,Di as tril,Yc as tril_indices,Jc as tril_indices_from,xi as triu,Qc as triu_indices,Xc as triu_indices_from,Sl as trunc,_l as union1d,Nl as unique,Vc as unpackbits,nl as unravel_index,wi as vander,_u as vsplit,xa as vstack,ml as where,rr as zeros,fi as zeros_like};
3
4
  //# sourceMappingURL=numpy-ts.node-io.mjs.map