numpy-ts 0.8.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.
- package/README.md +12 -12
- package/dist/numpy-ts.browser.js +2 -2
- package/dist/numpy-ts.esm.js +2 -2
- package/dist/numpy-ts.node-io.cjs +3 -3
- package/dist/numpy-ts.node-io.cjs.map +4 -4
- package/dist/numpy-ts.node-io.mjs +3 -3
- package/dist/numpy-ts.node-io.mjs.map +4 -4
- package/dist/numpy-ts.node.cjs +2 -2
- package/dist/numpy-ts.node.cjs.map +4 -4
- package/dist/types/core/ndarray.d.ts +402 -0
- package/dist/types/index.d.ts +1 -1
- package/dist/types/ops/exponential.d.ts +79 -1
- package/dist/types/ops/gradient.d.ts +57 -0
- package/dist/types/ops/linalg.d.ts +220 -0
- package/dist/types/ops/rounding.d.ts +36 -0
- package/dist/types/ops/sets.d.ts +38 -0
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";var ut=Object.defineProperty;var Gi=Object.getOwnPropertyDescriptor;var Hi=Object.getOwnPropertyNames;var Yi=Object.prototype.hasOwnProperty;var C=(r,t)=>()=>(r&&(t=r(r=0)),t);var ct=(r,t)=>{for(var e in t)ut(r,e,{get:t[e],enumerable:!0})},Ji=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Hi(t))!Yi.call(r,o)&&o!==e&&ut(r,o,{get:()=>t[o],enumerable:!(n=Gi(t,o))||n.enumerable});return r};var ft=r=>Ji(ut({},"__esModule",{value:!0}),r);function se(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 ie(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 s=e<0?t+e:e;if(s<0||s>=t)throw new Error(`Index ${e} is out of bounds for size ${t}`);return{start:s,stop:s+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 ue=C(()=>{"use strict"});function O(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 fe(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 le(r){return r==="int64"||r==="int32"||r==="int16"||r==="int8"||r==="uint64"||r==="uint32"||r==="uint16"||r==="uint8"}function ce(r){return r==="float64"||r==="float32"}function x(r){return r==="int64"||r==="uint64"}function k(r,t){if(r===t)return r;if(r==="bool")return t;if(t==="bool")return r;if(ce(r)||ce(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"),s=c=>c.includes("64")?64:c.includes("32")?32:c.includes("16")?16:c.includes("8")?8:0,i=s(r),u=s(t);if(r==="int64"&&t==="uint64"||r==="uint64"&&t==="int64")return"float64";if(e&&a&&i===u){if(i===8)return"int16";if(i===16)return"int32";if(i===32)return"int64"}if(o&&n&&i===u){if(u===8)return"int16";if(u===16)return"int32";if(u===32)return"int64"}if(e&&n||o&&a){let c=Math.max(i,u);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?i>u?r:u===8?"int16":u===16?"int32":u===32?"int64":"float64":o&&n?u>i?t:i===8?"int16":i===16?"int32":i===32?"int64":"float64":"float64"}var V,q=C(()=>{"use strict";V="float64"});function j(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,W=C(()=>{"use strict";q();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,s=this._offset;for(let i=0;i<o;i++){let u=1;for(let f=i+1;f<o;f++)u*=e[f];let c=Math.floor(a/u);a=a%u,s+=c*n[i]}return this._data[s]}iset(t,e){let n=this._shape,o=this._strides,a=n.length;if(a===0){this._data[this._offset]=e;return}let s=t,i=this._offset;for(let u=0;u<a;u++){let c=1;for(let p=u+1;p<a;p++)c*=n[p];let f=Math.floor(s/c);s=s%c,i+=f*o[u]}this._data[i]=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=O(e);if(!o)throw new Error(`Cannot copy array with dtype ${e}`);let a=new o(n);if(this.isCContiguous&&this._offset===0)if(x(e)){let s=this._data,i=a;for(let u=0;u<n;u++)i[u]=s[u]}else a.set(this._data);else if(x(e)){let s=a;for(let i=0;i<n;i++)s[i]=this.iget(i)}else for(let s=0;s<n;s++)a[s]=this.iget(s);return new r(a,t,r._computeStrides(t),0,e)}static fromData(t,e,n,o,a){let s=o??r._computeStrides(e),i=a??0;return new r(t,e,s,i,n)}static zeros(t,e=V){let n=t.reduce((s,i)=>s*i,1),o=O(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=V){let n=t.reduce((s,i)=>s*i,1),o=O(e);if(!o)throw new Error(`Cannot create array with dtype ${e}`);let a=new o(n);return x(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 pe(r,t){let e=r.length,n=t.length,o=Math.max(e,n),a=new Array(o);for(let s=0;s<o;s++){let i=s<o-e?1:r[s-(o-e)],u=s<o-n?1:t[s-(o-n)];if(i===u)a[s]=i;else if(i===1)a[s]=u;else if(u===1)a[s]=i;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 Xi(r,t,e){let n=r.length,o=e.length,a=new Array(o).fill(0);for(let s=0;s<n;s++){let i=o-n+s,u=r[s],c=e[i];if(u===c)a[i]=t[s];else if(u===1)a[i]=0;else throw new Error("Invalid broadcast")}return a}function Ur(r,t){let e=Xi(r.shape,r.strides,t);return D.fromData(r.data,Array.from(t),r.dtype,e,r.offset)}function L(r,t,e,n){let o=pe(r.shape,t.shape),a=Ur(r,o),s=Ur(t,o),i=k(r.dtype,t.dtype),u=D.zeros(o,i),c=u.data,f=u.size;if(x(i)){let p=c;for(let l=0;l<f;l++){let y=a.iget(l),m=s.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=x(r.dtype)||x(t.dtype);for(let l=0;l<f;l++){let y=a.iget(l),m=s.iget(l),d=Number(y),g=Number(m);c[l]=e(d,g)}}return u}function er(r,t,e){let n=pe(r.shape,t.shape),o=Ur(r,n),a=Ur(t,n),s=n.reduce((c,f)=>c*f,1),i=new Uint8Array(s),u=x(r.dtype)||x(t.dtype);for(let c=0;c<s;c++){let f=o.iget(c),p=a.iget(c),l=Number(f),y=Number(p);i[c]=e(l,y)?1:0}return D.fromData(i,n,"bool")}function F(r,t,e=!0){let n=r.dtype,o=Array.from(r.shape),a=r.size,i=e?n:n!=="float32"&&n!=="float64"?"float64":n,u=D.zeros(o,i),c=u.data,f=r.data;if(x(n))if(x(i)){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 u}var ar=C(()=>{"use strict";W();q()});function lt(r,t){return r.isCContiguous&&t.isCContiguous&&r.shape.length===t.shape.length&&r.shape.every((e,n)=>e===t.shape[n])}function ye(r,t){return typeof t=="number"?tu(r,t):lt(r,t)?Qi(r,t):L(r,t,(e,n)=>e+n,"add")}function Qi(r,t){let e=k(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,s=t.data,i=n.data;if(x(e)){let u=i;if(!x(r.dtype)||!x(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 s[f]=="bigint"?s[f]:BigInt(Math.round(Number(s[f])));u[f]=p+l}else{let f=a,p=s;for(let l=0;l<o;l++)u[l]=f[l]+p[l]}}else if(x(r.dtype)||x(t.dtype))for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?Number(a[c]):a[c],p=typeof s[c]=="bigint"?Number(s[c]):s[c];i[c]=f+p}else for(let c=0;c<o;c++)i[c]=a[c]+s[c];return n}function me(r,t){return typeof t=="number"?eu(r,t):lt(r,t)?Ki(r,t):L(r,t,(e,n)=>e-n,"subtract")}function Ki(r,t){let e=k(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,s=t.data,i=n.data;if(x(e)){let u=i;if(!x(r.dtype)||!x(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 s[f]=="bigint"?s[f]:BigInt(Math.round(Number(s[f])));u[f]=p-l}else{let f=a,p=s;for(let l=0;l<o;l++)u[l]=f[l]-p[l]}}else if(x(r.dtype)||x(t.dtype))for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?Number(a[c]):a[c],p=typeof s[c]=="bigint"?Number(s[c]):s[c];i[c]=f-p}else for(let c=0;c<o;c++)i[c]=a[c]-s[c];return n}function de(r,t){return typeof t=="number"?nu(r,t):lt(r,t)?ru(r,t):L(r,t,(e,n)=>e*n,"multiply")}function ru(r,t){let e=k(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,s=t.data,i=n.data;if(x(e)){let u=i;if(!x(r.dtype)||!x(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 s[f]=="bigint"?s[f]:BigInt(Math.round(Number(s[f])));u[f]=p*l}else{let f=a,p=s;for(let l=0;l<o;l++)u[l]=f[l]*p[l]}}else if(x(r.dtype)||x(t.dtype))for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?Number(a[c]):a[c],p=typeof s[c]=="bigint"?Number(s[c]):s[c];i[c]=f*p}else for(let c=0;c<o;c++)i[c]=a[c]*s[c];return n}function ge(r,t){if(typeof t=="number")return ou(r,t);let e=r.dtype==="float64",n=t.dtype==="float64",o=r.dtype==="float32",a=t.dtype==="float32";if(e||n){let u=e?r:lr(r,"float64"),c=n?t:lr(t,"float64");return L(u,c,(f,p)=>f/p,"divide")}if(o||a){let u=o?r:lr(r,"float32"),c=a?t:lr(t,"float32");return L(u,c,(f,p)=>f/p,"divide")}let s=lr(r,"float64"),i=lr(t,"float64");return L(s,i,(u,c)=>u/c,"divide")}function lr(r,t){let e=D.zeros(Array.from(r.shape),t),n=r.size,o=r.data,a=e.data;for(let s=0;s<n;s++)a[s]=Number(o[s]);return e}function tu(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]+f}else for(let u=0;u<a;u++)i[u]=Number(o[u])+t;return s}function eu(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]-f}else for(let u=0;u<a;u++)i[u]=Number(o[u])-t;return s}function nu(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]*f}else for(let u=0;u<a;u++)i[u]=Number(o[u])*t;return s}function ou(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,i=e!=="float32"&&e!=="float64"?"float64":e,u=D.zeros(n,i),c=u.data;if(x(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 u}function Ae(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),s=a.data;if(x(t)){let i=n,u=s;for(let c=0;c<o;c++){let f=i[c];u[c]=f<0n?-f:f}}else for(let i=0;i<o;i++)s[i]=Math.abs(Number(n[i]));return a}function he(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),s=a.data;if(x(t)){let i=n,u=s;for(let c=0;c<o;c++)u[c]=-i[c]}else for(let i=0;i<o;i++)s[i]=-Number(n[i]);return a}function be(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),s=a.data;if(x(t)){let i=n,u=s;for(let c=0;c<o;c++){let f=i[c];u[c]=f>0n?1n:f<0n?-1n:0n}}else for(let i=0;i<o;i++){let u=Number(n[i]);s[i]=u>0?1:u<0?-1:0}return a}function vr(r,t){return typeof t=="number"?au(r,t):L(r,t,(e,n)=>(e%n+n)%n,"mod")}function au(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++){let l=u[p];c[p]=(l%f+f)%f}}else for(let u=0;u<a;u++){let c=Number(o[u]);i[u]=(c%t+t)%t}return s}function pt(r,t){return typeof t=="number"?su(r,t):L(r,t,(e,n)=>Math.floor(e/n),"floor_divide")}function su(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]/f}else for(let u=0;u<a;u++)i[u]=Math.floor(Number(o[u])/t);return s}function Se(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),s=a.data;for(let i=0;i<o;i++)s[i]=n[i];return a}function De(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,s=t!=="float32"&&t!=="float64"?"float64":t,i=D.zeros(e,s),u=i.data;if(x(t))for(let c=0;c<o;c++)u[c]=1/Number(n[c]);else for(let c=0;c<o;c++)u[c]=1/Number(n[c]);return i}function xe(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,s=t!=="float32"&&t!=="float64"?"float64":t,i=D.zeros(e,s),u=i.data;for(let c=0;c<o;c++)u[c]=Math.cbrt(Number(n[c]));return i}function Ne(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=t==="float32"?"float32":"float64",s=D.zeros(e,a),i=s.data;for(let u=0;u<o;u++)i[u]=Math.abs(Number(n[u]));return s}function we(r,t){let e=pt(r,t),n=vr(r,t);return[e,n]}function Ie(r){let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),s=a.data;if(x(t)){let i=n,u=s;for(let c=0;c<o;c++)u[c]=i[c]*i[c]}else for(let i=0;i<o;i++){let u=Number(n[i]);s[i]=u*u}return a}function ze(r,t){return vr(r,t)}function _e(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.size,a=e==="float32"?"float32":"float64",s=D.zeros(n,a),i=s.data;if(typeof t=="number")for(let u=0;u<o;u++){let c=Number(r.data[u]);c<0?i[u]=0:c===0?i[u]=t:i[u]=1}else{let u=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?i[f]=0:p===0?i[f]=Number(u[f]):i[f]=1}else for(let f=0;f<o;f++){let p=Number(r.data[f]),l=f%t.size;p<0?i[f]=0:p===0?i[f]=Number(u[l]):i[f]=1}}return s}var Be=C(()=>{"use strict";W();q();ar()});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 s=a.length-t+n,i=s<0?1:a[s];if(i!==1){if(o===1)o=i;else if(o!==i)return null}}e[n]=o}return e}function uu(r,t,e){let n=r.length,o=e.length,a=new Array(o).fill(0);for(let s=0;s<n;s++){let i=o-n+s,u=r[s],c=e[i];if(u===c)a[i]=t[s];else if(u===1)a[i]=0;else throw new Error("Invalid broadcast")}return a}function J(r,t){let e=uu(r.shape,r.strides,t);return D.fromData(r.data,Array.from(t),r.dtype,e,r.offset)}function yt(...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=C(()=>{"use strict";W()});function Ee(r,t){return typeof t=="number"?cu(r,t):er(r,t,(e,n)=>e>n)}function Te(r,t){return typeof t=="number"?fu(r,t):er(r,t,(e,n)=>e>=n)}function Ue(r,t){return typeof t=="number"?lu(r,t):er(r,t,(e,n)=>e<n)}function ve(r,t){return typeof t=="number"?pu(r,t):er(r,t,(e,n)=>e<=n)}function Oe(r,t){return typeof t=="number"?yu(r,t):er(r,t,(e,n)=>e===n)}function $e(r,t){return typeof t=="number"?mu(r,t):er(r,t,(e,n)=>e!==n)}function dt(r,t,e=1e-5,n=1e-8){return typeof t=="number"?du(r,t,e,n):er(r,t,(o,a)=>{let s=Math.abs(o-a),i=n+e*Math.abs(a);return s<=i})}function Me(r,t,e=1e-5,n=1e-8){let o=dt(r,t,e,n),a=o.data;for(let s=0;s<o.size;s++)if(a[s]===0)return!1;return!0}function Ce(r,t){let e=[Array.from(r.shape),Array.from(t.shape)],n=nr(e);if(n===null)return!1;let o=J(r,n),a=J(t,n),s=n.length,i=n.reduce((f,p)=>f*p,1),u=x(o.dtype),c=x(a.dtype);for(let f=0;f<i;f++){let p=f,l=new Array(s);for(let d=s-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(u||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 cu(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 fu(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 lu(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 pu(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 yu(r,t){let e=new Uint8Array(r.size),n=r.data,o=r.dtype;if(x(o)){let a=BigInt(Math.round(t)),s=n;for(let i=0;i<r.size;i++)e[i]=s[i]===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 mu(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 du(r,t,e,n){let o=new Uint8Array(r.size),a=r.data,s=r.dtype;if(x(s)){let i=a;for(let u=0;u<r.size;u++){let c=Number(i[u]),f=Math.abs(c-t),p=n+e*Math.abs(t);o[u]=f<=p?1:0}}else for(let i=0;i<r.size;i++){let u=Number(a[i]),c=Math.abs(u-t),f=n+e*Math.abs(t);o[i]=c<=f?1:0}return D.fromData(o,Array.from(r.shape),"bool")}var ke=C(()=>{"use strict";W();q();ar();mt()});function U(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 v(r,t,e,n){let o=n.length,a=new Array(o),s=Array.from(n).filter((u,c)=>c!==t),i=r;for(let u=s.length-1;u>=0;u--)a[u>=t?u+1:u]=i%s[u],i=Math.floor(i/s[u]);return a[t]=e,a}var gt=C(()=>{"use strict"});function gr(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,s=r.size,i=r.data;if(t===void 0)if(x(n)){let m=i,d=BigInt(0);for(let g=0;g<s;g++)d+=m[g];return Number(d)}else{let m=0;for(let d=0;d<s;d++)m+=Number(i[d]);return m}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 c=Array.from(o).filter((m,d)=>d!==u);if(c.length===0)return gr(r);let f=D.zeros(c,n),p=f.data,l=o[u],y=c.reduce((m,d)=>m*d,1);if(x(n)){let m=i,d=p;for(let g=0;g<y;g++){let h=BigInt(0);for(let A=0;A<l;A++){let b=v(g,u,A,o),S=U(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=v(m,u,g,o),A=U(h,o);d+=Number(i[A])}p[m]=d}if(e){let m=[...o];return m[u]=1,D.fromData(p,m,n)}return f}function Or(r,t,e=!1){let n=r.dtype,o=r.shape;if(t===void 0)return gr(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 s=gr(r,t,e);if(typeof s=="number")return s/o[a];let i=o[a],u=n;(x(n)||n.startsWith("int")||n.startsWith("uint"))&&(u="float64");let c=D.zeros(Array.from(s.shape),u),f=c.data,p=s.data;if(x(n)){let l=p;for(let y=0;y<f.length;y++)f[y]=Number(l[y])/i}else for(let l=0;l<f.length;l++)f[l]=Number(p[l])/i;return c}function $r(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,s=r.size,i=r.data;if(t===void 0){if(s===0)throw new Error("max of empty array");let m=i[0];for(let d=1;d<s;d++)i[d]>m&&(m=i[d]);return Number(m)}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 c=Array.from(o).filter((m,d)=>d!==u);if(c.length===0)return $r(r);let f=D.zeros(c,n),p=f.data,l=o[u],y=c.reduce((m,d)=>m*d,1);if(x(n)){let m=i,d=p;for(let g=0;g<y;g++){let h=v(g,u,0,o),A=U(h,o),b=m[A];for(let S=1;S<l;S++){let N=v(g,u,S,o),w=U(N,o),I=m[w];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=v(m,u,g,o),A=U(h,o),b=Number(i[A]);b>d&&(d=b)}p[m]=d}if(e){let m=[...o];return m[u]=1,D.fromData(p,m,n)}return f}function At(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,s=r.size,i=r.data;if(t===void 0)if(x(n)){let m=i,d=BigInt(1);for(let g=0;g<s;g++)d*=m[g];return Number(d)}else{let m=1;for(let d=0;d<s;d++)m*=Number(i[d]);return m}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 c=Array.from(o).filter((m,d)=>d!==u);if(c.length===0)return At(r);let f=D.zeros(c,n),p=f.data,l=o[u],y=c.reduce((m,d)=>m*d,1);if(x(n)){let m=i,d=p;for(let g=0;g<y;g++){let h=BigInt(1);for(let A=0;A<l;A++){let b=v(g,u,A,o),S=U(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=v(m,u,g,o),A=U(h,o);d*=Number(i[A])}p[m]=d}if(e){let m=[...o];return m[u]=1,D.fromData(p,m,n)}return f}function Mr(r,t,e=!1){let n=r.dtype,o=r.shape,a=o.length,s=r.size,i=r.data;if(t===void 0){if(s===0)throw new Error("min of empty array");let m=i[0];for(let d=1;d<s;d++)i[d]<m&&(m=i[d]);return Number(m)}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 c=Array.from(o).filter((m,d)=>d!==u);if(c.length===0)return Mr(r);let f=D.zeros(c,n),p=f.data,l=o[u],y=c.reduce((m,d)=>m*d,1);if(x(n)){let m=i,d=p;for(let g=0;g<y;g++){let h=v(g,u,0,o),A=U(h,o),b=m[A];for(let S=1;S<l;S++){let N=v(g,u,S,o),w=U(N,o),I=m[w];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=v(m,u,g,o),A=U(h,o),b=Number(i[A]);b<d&&(d=b)}p[m]=d}if(e){let m=[...o];return m[u]=1,D.fromData(p,m,n)}return f}function ht(r,t){let e=r.dtype,n=r.shape,o=n.length,a=r.size,s=r.data;if(t===void 0){if(a===0)throw new Error("argmin of empty array");let y=s[0],m=0;for(let d=1;d<a;d++)s[d]<y&&(y=s[d],m=d);return m}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((y,m)=>m!==i);if(u.length===0)return ht(r);let c=D.zeros(u,"int32"),f=c.data,p=n[i],l=u.reduce((y,m)=>y*m,1);if(x(e)){let y=s;for(let m=0;m<l;m++){let d=v(m,i,0,n),g=U(d,n),h=y[g],A=0;for(let b=1;b<p;b++){let S=v(m,i,b,n),N=U(S,n),w=y[N];w<h&&(h=w,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=v(y,i,g,n),A=U(h,n),b=Number(s[A]);b<m&&(m=b,d=g)}f[y]=d}return c}function bt(r,t){let e=r.dtype,n=r.shape,o=n.length,a=r.size,s=r.data;if(t===void 0){if(a===0)throw new Error("argmax of empty array");let y=s[0],m=0;for(let d=1;d<a;d++)s[d]>y&&(y=s[d],m=d);return m}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((y,m)=>m!==i);if(u.length===0)return bt(r);let c=D.zeros(u,"int32"),f=c.data,p=n[i],l=u.reduce((y,m)=>y*m,1);if(x(e)){let y=s;for(let m=0;m<l;m++){let d=v(m,i,0,n),g=U(d,n),h=y[g],A=0;for(let b=1;b<p;b++){let S=v(m,i,b,n),N=U(S,n),w=y[N];w>h&&(h=w,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=v(y,i,g,n),A=U(h,n),b=Number(s[A]);b>m&&(m=b,d=g)}f[y]=d}return c}function St(r,t,e=0,n=!1){let o=r.shape,a=o.length,s=r.size,i=r.data,u=Or(r,t,n);if(t===void 0){let h=u,A=0;for(let b=0;b<s;b++){let S=Number(i[b])-h;A+=S*S}return A/(s-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=u,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=v(h,c,S,o),w=U(N,o),I=Number(i[w])-b;A+=I*I}d[h]=A/(f-e)}return m}function Pe(r,t,e=0,n=!1){let o=St(r,t,e,n);if(typeof o=="number")return Math.sqrt(o);let a=D.zeros(Array.from(o.shape),"float64"),s=o.data,i=a.data;for(let u=0;u<s.length;u++)i[u]=Math.sqrt(Number(s[u]));return a}function Dt(r,t,e=!1){let n=r.shape,o=n.length,a=r.size,s=r.data;if(t===void 0){for(let y=0;y<a;y++)if(!s[y])return!1;return!0}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((y,m)=>m!==i);if(u.length===0)return Dt(r);let c=D.zeros(u,"bool"),f=c.data,p=n[i],l=u.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=v(y,i,d,n),h=U(g,n);if(!s[h]){m=!1;break}}f[y]=m?1:0}if(e){let y=[...n];return y[i]=1,D.fromData(f,y,"bool")}return c}function xt(r,t,e=!1){let n=r.shape,o=n.length,a=r.size,s=r.data;if(t===void 0){for(let y=0;y<a;y++)if(s[y])return!0;return!1}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((y,m)=>m!==i);if(u.length===0)return xt(r);let c=D.zeros(u,"bool"),f=c.data,p=n[i],l=u.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=v(y,i,d,n),h=U(g,n);if(s[h]){m=!0;break}}f[y]=m?1:0}if(e){let y=[...n];return y[i]=1,D.fromData(f,y,"bool")}return c}function Nt(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 s=new Float64Array(r.size),i=e[a],u=[],c=1;for(let l=n-1;l>=0;l--)u.unshift(c),c*=e[l];let f=r.size,p=u[a];for(let l=0;l<f;l++)Math.floor(l/p)%i===0?s[l]=Number(o[l]):s[l]=s[l-p]+Number(o[l]);return D.fromData(s,[...e],"float64")}function wt(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 s=new Float64Array(r.size),i=e[a],u=[],c=1;for(let l=n-1;l>=0;l--)u.unshift(c),c*=e[l];let f=r.size,p=u[a];for(let l=0;l<f;l++)Math.floor(l/p)%i===0?s[l]=Number(o[l]):s[l]=s[l-p]*Number(o[l]);return D.fromData(s,[...e],"float64")}function It(r,t,e=!1){let n=$r(r,t,e),o=Mr(r,t,e);if(typeof n=="number"&&typeof o=="number")return n-o;let a=n,s=o,i=a.data,u=s.data,c=new Float64Array(a.size);for(let f=0;f<a.size;f++)c[f]=Number(i[f])-Number(u[f]);return D.fromData(c,[...a.shape],"float64")}function zt(r,t,e=!1){return pr(r,.5,t,e)}function _t(r,t,e,n=!1){return pr(r,t/100,e,n)}function pr(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,s=r.data;if(e===void 0){let y=[];for(let b=0;b<r.size;b++)y.push(Number(s[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 i=e;if(i<0&&(i=a+i),i<0||i>=a)throw new Error(`axis ${e} is out of bounds for array of dimension ${a}`);let u=Array.from(o).filter((y,m)=>m!==i);if(u.length===0)return pr(r,t);let c=u.reduce((y,m)=>y*m,1),f=o[i],p=new Float64Array(c);for(let y=0;y<c;y++){let m=[];for(let b=0;b<f;b++){let S=v(y,i,b,o),N=U(S,o);m.push(Number(s[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,u,"float64");if(n){let y=[...o];return y[i]=1,D.fromData(p,y,"float64")}return l}function Cr(r,t,e,n=!1){let o=r.shape,a=o.length,s=r.data;if(e===void 0)return Or(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(s[h])*A,d+=A}return d===0?NaN:m/d}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 u=Array.from(o).filter((m,d)=>d!==i);if(u.length===0)return Cr(r,void 0,e);let c=u.reduce((m,d)=>m*d,1),f=o[i],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=v(m,i,h,o),b=U(A,o),S=Number(p[h%e.size]);d+=Number(s[b])*S,g+=S}l[m]=g===0?NaN:d/g}let y=D.fromData(l,u,"float64");if(n){let m=[...o];return m[i]=1,D.fromData(l,m,"float64")}return y}function kr(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 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((l,y)=>y!==s);if(i.length===0)return kr(r);let u=i.reduce((l,y)=>l*y,1),c=n[s],f=new Float64Array(u);for(let l=0;l<u;l++){let y=0;for(let m=0;m<c;m++){let d=v(l,s,m,n),g=U(d,n),h=Number(a[g]);isNaN(h)||(y+=h)}f[l]=y}let p=D.fromData(f,i,"float64");if(e){let l=[...n];return l[s]=1,D.fromData(f,l,"float64")}return p}function Pr(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 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((l,y)=>y!==s);if(i.length===0)return Pr(r);let u=i.reduce((l,y)=>l*y,1),c=n[s],f=new Float64Array(u);for(let l=0;l<u;l++){let y=1;for(let m=0;m<c;m++){let d=v(l,s,m,n),g=U(d,n),h=Number(a[g]);isNaN(h)||(y*=h)}f[l]=y}let p=D.fromData(f,i,"float64");if(e){let l=[...n];return l[s]=1,D.fromData(f,l,"float64")}return p}function Vr(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 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((l,y)=>y!==s);if(i.length===0)return Vr(r);let u=i.reduce((l,y)=>l*y,1),c=n[s],f=new Float64Array(u);for(let l=0;l<u;l++){let y=0,m=0;for(let d=0;d<c;d++){let g=v(l,s,d,n),h=U(g,n),A=Number(a[h]);isNaN(A)||(y+=A,m++)}f[l]=m===0?NaN:y/m}let p=D.fromData(f,i,"float64");if(e){let l=[...n];return l[s]=1,D.fromData(f,l,"float64")}return p}function Ar(r,t,e=0,n=!1){let o=r.shape,a=o.length,s=r.data;if(t===void 0){let y=0,m=0;for(let h=0;h<r.size;h++){let A=Number(s[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(s[h]);isNaN(A)||(g+=(A-d)**2)}return g/(m-e)}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 u=Array.from(o).filter((y,m)=>m!==i);if(u.length===0)return Ar(r,void 0,e);let c=u.reduce((y,m)=>y*m,1),f=o[i],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=v(y,i,A,o),S=U(b,o),N=Number(s[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=v(y,i,A,o),S=U(b,o),N=Number(s[S]);isNaN(N)||(h+=(N-g)**2)}p[y]=h/(d-e)}let l=D.fromData(p,u,"float64");if(n){let y=[...o];return y[i]=1,D.fromData(p,y,"float64")}return l}function Bt(r,t,e=0,n=!1){let o=Ar(r,t,e,n);if(typeof o=="number")return Math.sqrt(o);let a=o,s=new Float64Array(a.size);for(let i=0;i<a.size;i++)s[i]=Math.sqrt(Number(a.data[i]));return D.fromData(s,[...a.shape],"float64")}function Fr(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 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((l,y)=>y!==s);if(i.length===0)return Fr(r);let u=i.reduce((l,y)=>l*y,1),c=n[s],f=new Float64Array(u);for(let l=0;l<u;l++){let y=1/0;for(let m=0;m<c;m++){let d=v(l,s,m,n),g=U(d,n),h=Number(a[g]);!isNaN(h)&&h<y&&(y=h)}f[l]=y===1/0?NaN:y}let p=D.fromData(f,i,"float64");if(e){let l=[...n];return l[s]=1,D.fromData(f,l,"float64")}return p}function Rr(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 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((l,y)=>y!==s);if(i.length===0)return Rr(r);let u=i.reduce((l,y)=>l*y,1),c=n[s],f=new Float64Array(u);for(let l=0;l<u;l++){let y=-1/0;for(let m=0;m<c;m++){let d=v(l,s,m,n),g=U(d,n),h=Number(a[g]);!isNaN(h)&&h>y&&(y=h)}f[l]=y===-1/0?NaN:y}let p=D.fromData(f,i,"float64");if(e){let l=[...n];return l[s]=1,D.fromData(f,l,"float64")}return p}function Lr(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 s=Array.from(e).filter((f,p)=>p!==a);if(s.length===0)return Lr(r);let i=s.reduce((f,p)=>f*p,1),u=e[a],c=new Int32Array(i);for(let f=0;f<i;f++){let p=1/0,l=0;for(let y=0;y<u;y++){let m=v(f,a,y,e),d=U(m,e),g=Number(o[d]);!isNaN(g)&&g<p&&(p=g,l=y)}c[f]=l}return D.fromData(c,s,"int32")}function qr(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 s=Array.from(e).filter((f,p)=>p!==a);if(s.length===0)return qr(r);let i=s.reduce((f,p)=>f*p,1),u=e[a],c=new Int32Array(i);for(let f=0;f<i;f++){let p=-1/0,l=0;for(let y=0;y<u;y++){let m=v(f,a,y,e),d=U(m,e),g=Number(o[d]);!isNaN(g)&&g>p&&(p=g,l=y)}c[f]=l}return D.fromData(c,s,"int32")}function Et(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 s=new Float64Array(r.size),i=e[a],u=[],c=1;for(let l=n-1;l>=0;l--)u.unshift(c),c*=e[l];let f=r.size,p=u[a];for(let l=0;l<f;l++){let y=Number(o[l]);Math.floor(l/p)%i===0?s[l]=isNaN(y)?0:y:s[l]=s[l-p]+(isNaN(y)?0:y)}return D.fromData(s,[...e],"float64")}function Tt(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 s=new Float64Array(r.size),i=e[a],u=[],c=1;for(let l=n-1;l>=0;l--)u.unshift(c),c*=e[l];let f=r.size,p=u[a];for(let l=0;l<f;l++){let y=Number(o[l]);Math.floor(l/p)%i===0?s[l]=isNaN(y)?1:y:s[l]=s[l-p]*(isNaN(y)?1:y)}return D.fromData(s,[...e],"float64")}function jr(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 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((l,y)=>y!==s);if(i.length===0)return jr(r);let u=i.reduce((l,y)=>l*y,1),c=n[s],f=new Float64Array(u);for(let l=0;l<u;l++){let y=[];for(let g=0;g<c;g++){let h=v(l,s,g,n),A=U(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,i,"float64");if(e){let l=[...n];return l[s]=1,D.fromData(f,l,"float64")}return p}var Ve=C(()=>{"use strict";W();q();gt()});function G(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,j(a),0)}let u=r.copy().data;return D.fromData(u,a,n,j(a),0)}function Wr(r){let t=r.size,e=r.dtype,n=O(e);if(!n)throw new Error(`Cannot flatten array with dtype ${e}`);if(r.isCContiguous){let i=r.data.slice(r.offset,r.offset+t);return D.fromData(i,[t],e,[1],0)}let o=new n(t),a=x(e);for(let s=0;s<t;s++){let i=r.iget(s);o[s]=i}return D.fromData(o,[t],e,[1],0)}function br(r){let t=r.size,e=r.dtype;if(r.isCContiguous){let n=r.data;return D.fromData(n,[t],e,[1],0)}return Wr(r)}function Sr(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,s=r.dtype,i;if(t===void 0)i=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)}i=t.map(l=>l<0?n+l:l)}let u=i.map(p=>e[p]),c=Array.from(o),f=i.map(p=>c[p]);return D.fromData(a,u,s,f,r.offset)}function Fe(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,s=r.dtype;if(t===void 0){let i=[],u=[];for(let c=0;c<n;c++)e[c]!==1&&(i.push(e[c]),u.push(o[c]));return i.length===0&&(i.push(1),u.push(1)),D.fromData(a,i,s,u,r.offset)}else{let i=t<0?n+t:t;if(i<0||i>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);if(e[i]!==1)throw new Error(`cannot select an axis which has size not equal to one (axis ${t} has size ${e[i]})`);let u=[],c=[];for(let f=0;f<n;f++)f!==i&&(u.push(e[f]),c.push(o[f]));return D.fromData(a,u,s,c,r.offset)}}function hr(r,t){let e=r.shape,n=e.length,o=r.strides,a=r.data,s=r.dtype,i=t;if(i<0&&(i=n+t+1),i<0||i>n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n+1}`);let u=[...Array.from(e)];u.splice(i,0,1);let c=[...Array.from(o)],f=i<n?o[i]*(e[i]||1):1;return c.splice(i,0,f),D.fromData(a,u,s,c,r.offset)}function Re(r,t,e){let n=r.shape,o=n.length,a=r.strides,s=r.data,i=r.dtype,u=t<0?o+t:t,c=e<0?o+e:e;if(u<0||u>=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(u===c)return D.fromData(s,Array.from(n),i,Array.from(a),r.offset);let f=Array.from(n),p=Array.from(a);return[f[u],f[c]]=[f[c],f[u]],[p[u],p[c]]=[p[c],p[u]],D.fromData(s,f,i,p,r.offset)}function Ut(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 s=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}),i=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(s).size!==s.length)throw new Error("repeated axis in source");if(new Set(i).size!==i.length)throw new Error("repeated axis in destination");let u=[];for(let c=0;c<n;c++)s.includes(c)||u.push(c);for(let c=0;c<s.length;c++){let f=i[c];u.splice(f,0,s[c])}return Sr(r,u)}function sr(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 s=Array.from(e.shape),i=e.shape[a];for(let y=1;y<r.length;y++)i+=r[y].shape[a];s[a]=i;let u=s.reduce((y,m)=>y*m,1),c=O(o);if(!c)throw new Error(`Cannot concatenate arrays with dtype ${o}`);let f=new c(u),p=j(s),l=0;for(let y of r){let m=y.shape[a];hu(y,f,s,p,a,l,o),l+=m}return D.fromData(f,s,o)}function hu(r,t,e,n,o,a,s){let i=r.shape,u=i.length,c=r.size,f=s==="int64"||s==="uint64";if(o===0&&r.isCContiguous&&u>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&&u===2&&r.isCContiguous){let y=i[0],m=i[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(u).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<u;g++)d+=p[g]*n[g];t[d]=m;for(let g=u-1;g>=0&&(p[g]++,!(p[g]<i[g]));g--)p[g]=0}}function Le(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 i=1;i<r.length;i++){let u=r[i];if(u.ndim!==o)throw new Error("all input arrays must have the same shape");for(let c=0;c<o;c++)if(u.shape[c]!==n[c])throw new Error("all input arrays must have the same shape")}let s=r.map(i=>hr(i,a));return sr(s,a)}function qe(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?G(e,[1,e.shape[0]]):e);return sr(t,0)}function vt(r){if(r.length===0)throw new Error("need at least one array to stack");return r.every(e=>e.ndim===1)?sr(r,0):sr(r,1)}function je(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?G(hr(G(e,[1,e.shape[0]]),2),[1,e.shape[0],1]):e.ndim===2?hr(e,2):e);return sr(t,2)}function We(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 s=n[a],i;if(typeof t=="number"){if(s%t!==0)throw new Error("array split does not result in an equal division");let u=s/t;i=[];for(let c=1;c<t;c++)i.push(c*u)}else i=t;return Ze(r,i,a)}function Dr(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 s=n[a],i;if(typeof t=="number"){let u=t,c=Math.floor(s/u),f=s%u;i=[];let p=0;for(let l=0;l<u-1;l++)p+=c+(l<f?1:0),i.push(p)}else i=t;return Ze(r,i,a)}function Ze(r,t,e){let n=r.shape,o=n[e],a=[0,...t,o],s=[];for(let i=0;i<a.length-1;i++){let u=a[i],c=a[i+1];if(u>c)throw new Error("split indices must be in ascending order");let f=Array.from(n);f[e]=c-u;let p=r.offset+u*r.strides[e];s.push(D.fromData(r.data,f,r.dtype,Array.from(r.strides),p))}return s}function Ge(r,t){if(r.ndim<2)throw new Error("vsplit only works on arrays of 2 or more dimensions");return Dr(r,t,0)}function He(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 Dr(r,t,e)}function Ye(r,t){let e=r.shape,n=e.length,o=r.dtype,a=Array.isArray(t)?t:[t],s=Math.max(n,a.length),i=new Array(s).fill(1),u=new Array(s).fill(1);for(let A=0;A<n;A++)i[s-n+A]=e[A];for(let A=0;A<a.length;A++)u[s-a.length+A]=a[A];let c=i.map((A,b)=>A*u[b]),f=c.reduce((A,b)=>A*b,1),p=O(o);if(!p)throw new Error(`Cannot tile array with dtype ${o}`);let l=new p(f),y=j(c),m=r;n<s&&(m=G(r,i));let d=o==="int64"||o==="uint64",g=m.strides,h=new Array(s).fill(0);for(let A=0;A<f;A++){let b=m.offset;for(let w=0;w<s;w++){let I=h[w]%i[w];b+=I*g[w]}let S=m.data[b],N=0;for(let w=0;w<s;w++)N+=h[w]*y[w];l[N]=S;for(let w=s-1;w>=0&&(h[w]++,!(h[w]<c[w]));w--)h[w]=0}return D.fromData(l,c,o)}function Je(r,t,e){let n=r.shape,o=n.length,a=r.dtype,s=r.size;if(e===void 0){let A=s,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=O(a);if(!N)throw new Error(`Cannot repeat array with dtype ${a}`);let w=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++)w[I++]=B}return D.fromData(w,[S],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],c=Array.isArray(t)?t:new Array(u).fill(t);if(c.length!==u)throw new Error(`operands could not be broadcast together with shape (${u},) (${c.length},)`);let f=Array.from(n);f[i]=c.reduce((A,b)=>A+b,0);let p=f.reduce((A,b)=>A*b,1),l=O(a);if(!l)throw new Error(`Cannot repeat array with dtype ${a}`);let y=new l(p),m=j(f),d=new Array(o).fill(0),g=a==="int64"||a==="uint64",h=[0];for(let A=0;A<u;A++)h.push(h[A]+c[A]);for(let A=0;A<s;A++){let b=r.iget(A),S=d[i],N=c[S],w=0;for(let B=0;B<o;B++)B!==i&&(w+=d[B]*m[B]);let I=m[i],z=h[S];for(let B=0;B<N;B++){let E=w+(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 Xe(r,t){let e=r.shape,n=e.length,o=r.dtype,a=r.size,s;if(t===void 0)s=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}`);s=new Set([l])}else s=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 i=O(o);if(!i)throw new Error(`Cannot flip array with dtype ${o}`);let u=new i(a),c=x(o);if(n===1&&r.isCContiguous){let l=r.data,y=r.offset;for(let m=0;m<a;m++)u[m]=l[y+a-1-m];return D.fromData(u,[...e],o)}if(n===2&&r.isCContiguous){let l=e[0],y=e[1],m=r.data,d=r.offset;if(s.size===2){for(let g=0;g<a;g++)u[g]=m[d+a-1-g];return D.fromData(u,[...e],o)}if(s.size===1){if(s.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++)u[A+b]=m[h+b]}return D.fromData(u,[...e],o)}else if(s.has(1)){for(let g=0;g<l;g++){let h=d+g*y,A=g*y;for(let b=0;b<y;b++)u[A+b]=m[h+y-1-b]}return D.fromData(u,[...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]=s.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];u[l]=m;for(let d=n-1;d>=0&&(p[d]++,!(p[d]<e[d]));d--)p[d]=0}return D.fromData(u,[...e],o)}function Qe(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 s=e[0]<0?o+e[0]:e[0],i=e[1]<0?o+e[1]:e[1];if(s<0||s>=o||i<0||i>=o)throw new Error(`Axes are out of bounds for array of dimension ${o}`);if(s===i)throw new Error("Axes must be different");if(t=(t%4+4)%4,t===0)return r.copy();let u=O(a);if(!u)throw new Error(`Cannot rotate array with dtype ${a}`);let c=[...n];(t===1||t===3)&&([c[s],c[i]]=[c[i],c[s]]);let f=c.reduce((g,h)=>g*h,1),p=new u(f),l=j(c),y=x(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[i]-1-m[i],A=m[s]):t===2?(h=n[s]-1-m[s],A=n[i]-1-m[i],d[s]=h,d[i]=A):(h=m[i],A=n[s]-1-m[s]),t!==2&&(d[s]=h,d[i]=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 Ke(r,t,e){let n=r.shape,o=n.length,a=r.dtype,s=r.size;if(e===void 0){let m=Array.isArray(t)?t.reduce((b,S)=>b+S,0):t,d=Wr(r),g=O(a);if(!g)throw new Error(`Cannot roll array with dtype ${a}`);let h=new g(s),A=x(a);for(let b=0;b<s;b++){let S=((b-m)%s+s)%s,N=d.iget(S);h[b]=N}return D.fromData(h,[...n],a)}let i=Array.isArray(t)?t:[t],u=Array.isArray(e)?e:[e];if(i.length!==u.length)throw new Error("shift and axis must have the same length");let c=u.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=O(a);if(!f)throw new Error(`Cannot roll array with dtype ${a}`);let p=new f(s),l=x(a),y=new Array(o).fill(0);for(let m=0;m<s;m++){let d=[...y];for(let A=0;A<c.length;A++){let b=c[A],S=n[b],N=i[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 rn(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):Ut(r,o,a)}function tn(r,t){if(r.ndim<3)throw new Error("dsplit only works on arrays of 3 or more dimensions");return Dr(r,t,2)}function en(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?G(e,[e.shape[0],1]):e);return vt(t)}function nn(r,t){let e=r.dtype,n=t.reduce((u,c)=>u*c,1),o=r.size,a=O(e);if(!a)throw new Error(`Cannot resize array with dtype ${e}`);let s=new a(n),i=x(e);for(let u=0;u<n;u++){let c=u%o,f=r.iget(c);s[u]=f}return D.fromData(s,t,e)}function on(r){return r.map(t=>t.ndim===0?G(t,[1]):t)}function an(r){return r.map(t=>t.ndim===0?G(t,[1,1]):t.ndim===1?G(t,[1,t.shape[0]]):t)}function sn(r){return r.map(t=>t.ndim===0?G(t,[1,1,1]):t.ndim===1?G(t,[1,t.shape[0],1]):t.ndim===2?G(t,[t.shape[0],t.shape[1],1]):t)}var Ot=C(()=>{"use strict";W();q()});function bu(r,t,e,n,o,a,s,i,u,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+=(i[h*u+S]??0)*(c[S*f+A]??0);l[h*y+A]=(l[h*y+A]??0)+s*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+=(i[S*u+h]??0)*(c[S*f+A]??0);l[h*y+A]=(l[h*y+A]??0)+s*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+=(i[h*u+S]??0)*(c[A*f+S]??0);l[h*y+A]=(l[h*y+A]??0)+s*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+=(i[S*u+h]??0)*(c[A*f+S]??0);l[h*y+A]=(l[h*y+A]??0)+s*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+=(i[S*u+h]??0)*(c[A*f+S]??0);l[A*y+h]=(l[A*y+h]??0)+s*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+=(i[h*u+S]??0)*(c[A*f+S]??0);l[A*y+h]=(l[A*y+h]??0)+s*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+=(i[S*u+h]??0)*(c[S*f+A]??0);l[A*y+h]=(l[A*y+h]??0)+s*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+=(i[h*u+S]??0)*(c[S*f+A]??0);l[A*y+h]=(l[A*y+h]??0)+s*b}}function Mt(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 s=k(r.dtype,t.dtype),i=D.zeros([...t.shape],s);for(let u=0;u<t.size;u++){let c=t.data[u+t.offset];typeof o=="bigint"&&typeof c=="bigint"?i.data[u]=o*c:i.data[u]=Number(o)*Number(c)}return i}else{let s=k(r.dtype,t.dtype),i=D.zeros([...r.shape],s);for(let u=0;u<r.size;u++){let c=r.data[u+r.offset];typeof c=="bigint"&&typeof a=="bigint"?i.data[u]=c*a:i.data[u]=Number(c)*Number(a)}return i}}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 s=0;s<o;s++){let i=r.get(s),u=t.get(s);typeof i=="bigint"&&typeof u=="bigint"?a=Number(a)+Number(i*u):a+=Number(i)*Number(u)}return a}if(e===2&&n===2)return ir(r,t);if(e===2&&n===1){let[o,a]=r.shape,s=t.shape[0];if(a!==s)throw new Error(`dot: incompatible shapes (${o},${a}) and (${s},)`);let i=k(r.dtype,t.dtype),u=D.zeros([o],i);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)}u.set([c],f)}return u}if(e===1&&n===2){let o=r.shape[0],[a,s]=t.shape;if(o!==a)throw new Error(`dot: incompatible shapes (${o},) and (${a},${s})`);let i=k(r.dtype,t.dtype),u=D.zeros([s],i);for(let c=0;c<s;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)}u.set([c],f)}return u}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 s=[...r.shape.slice(0,-1)],i=k(r.dtype,t.dtype),u=D.zeros(s,i),c=s.reduce((f,p)=>f*p,1);for(let f=0;f<c;f++){let p=0,l=f,y=[];for(let m=s.length-1;m>=0;m--)y[m]=l%s[m],l=Math.floor(l/s[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)}u.set(y,p)}return u}if(e===1&&n>2){let o=r.shape[0],a=1,s=t.shape[a];if(o!==s)throw new Error(`dot: incompatible shapes (${o},) and ${JSON.stringify(t.shape)}`);let i=[...t.shape.slice(0,a),...t.shape.slice(a+1)],u=k(r.dtype,t.dtype),c=D.zeros(i,u),f=i.reduce((p,l)=>p*l,1);for(let p=0;p<f;p++){let l=p,y=[];for(let h=i.length-1;h>=0;h--)y[h]=l%i[h],l=Math.floor(l/i[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 s=[...r.shape.slice(0,-1),...t.shape.slice(0,-2),t.shape[n-1]],i=k(r.dtype,t.dtype),u=D.zeros(s,i),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,w=t.data[N+t.offset];typeof S=="bigint"&&typeof w=="bigint"?g=Number(g)+Number(S*w):g+=Number(S)*Number(w)}let h=y*f*p+m*p+d;u.data[h]=g}return u}throw new Error(`dot: unexpected combination of dimensions ${e}D \xB7 ${n}D`)}function ir(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 s=k(r.dtype,t.dtype),i=s.startsWith("int")||s.startsWith("uint")||s==="bool"?"float64":s;if(i!=="float64")throw new Error(`matmul currently only supports float64, got ${i}`);let u=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&&(u=u.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 bu("row-major",g,h,e,a,n,1,u,A,c,b,0,S.data,a),S}function fn(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 s=r.get(a,a);typeof s=="bigint"?o=(typeof o=="bigint"?o:BigInt(o))+s:o=(typeof o=="bigint"?Number(o):o)+s}return o}function cn(r,t){return Sr(r,t)}function ln(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 Mt(r,t);let s=[...r.shape.slice(0,-1),...t.shape.slice(0,-1)],i=k(r.dtype,t.dtype),u=D.zeros(s,i),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(s.length===0)return m;let d=c===1?y:l*f+y;u.data[d]=m}return u}function Ct(r,t){let e=r.ndim===1?r:br(r),n=t.ndim===1?t:br(t),o=e.size,a=n.size,s=k(r.dtype,t.dtype),i=D.zeros([o,a],s);for(let u=0;u<o;u++)for(let c=0;c<a;c++){let f=e.get(u),p=n.get(c),l;typeof f=="bigint"&&typeof p=="bigint"?l=f*p:l=Number(f)*Number(p),i.set([u,c],l)}return i}function pn(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=[],s=[];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)||s.push(l);let i=[...a.map(l=>r.shape[l]),...s.map(l=>t.shape[l])];if(i.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 w=n[N];g[N]=d%r.shape[w],d=Math.floor(d/r.shape[w])}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 u=k(r.dtype,t.dtype),c=D.zeros(i,u),f=i.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=i.length-1;A>=0;A--)m[A]=y%i[A],y=Math.floor(y/i[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<s.length;z++)N[s[z]]=g[z];for(let z=0;z<n.length;z++)S[n[z]]=b[z],N[o[z]]=b[z];let w=r.get(...S),I=t.get(...N);typeof w=="bigint"&&typeof I=="bigint"?h=Number(h)+Number(w*I):h+=Number(w)*Number(I)}c.set(m,h)}return c}function yn(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 s=e<0?a+e:e,i=n<0?a+n:n;if(s<0||s>=a||i<0||i>=a)throw new Error("axis out of bounds");if(s===i)throw new Error("axis1 and axis2 cannot be the same");let u=o[s],c=o[i],f;t>=0?f=Math.max(0,Math.min(u,c-t)):f=Math.max(0,Math.min(u+t,c));let p=[];for(let d=0;d<a;d++)d!==s&&d!==i&&p.push(o[d]);p.push(f);let l=D.zeros(p,r.dtype),y=o.filter((d,g)=>g!==s&&g!==i),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===s?b[I]=t>=0?A:A-t:I===i?b[I]=t>=0?A+t:A:b[I]=h[S++];let N=[...h,A],w=r.get(...b);l.set(N,w)}}return l}function mn(r,...t){let e=r.indexOf("->"),n,o;e===-1?(n=r,o=Su(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 s=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(s.has(b)){if(s.get(b)!==S)throw new Error(`einsum: size mismatch for index '${b}': ${s.get(b)} vs ${S}`)}else s.set(b,S)}}for(let d of o)if(!s.has(d))throw new Error(`einsum: output subscript contains unknown index '${d}'`);let i=new Set(o),u=new Set;for(let d of a)for(let g of d)u.add(g);let c=[];for(let d of u)i.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,w]=[g[0],g[1]],[I,z]=[o[0],o[1]];if(b===I&&w===z&&S===N&&c.length===1&&c[0]===S||b===I&&w===z&&S===N&&c.length===1&&c[0]===S)return ir(h,A);if(S===I&&w===z&&b===N&&c.length===1&&c[0]===b){let B=cn(h);return ir(B,A)}if(b===I&&N===z&&S===w&&c.length===1&&c[0]===S){let B=cn(A);return ir(h,B)}}if(d.length===1&&g.length===1&&d===g&&o.length===0&&h.ndim===1&&A.ndim===1)return $t(t,a,c,s);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 Ct(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 $t(t,a,c,s)}let f=Array.from(o).map(d=>s.get(d));if(f.length===0)return $t(t,a,c,s);let p=t[0].dtype;for(let d=1;d<t.length;d++)p=k(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*=s.get(d);for(let d=0;d<y;d++){let g=Du(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 w=c.length-1;w>=0;w--){let I=c[w],z=s.get(I);h.set(I,S%z),S=Math.floor(S/z)}let N=1;for(let w=0;w<t.length;w++){let I=t[w],z=a[w],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 Su(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 $t(r,t,e,n){let o=1;for(let s of e)o*=n.get(s);let a=0;for(let s=0;s<o;s++){let i=new Map,u=s;for(let f=e.length-1;f>=0;f--){let p=e[f],l=n.get(p);i.set(p,u%l),u=Math.floor(u/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(i.get(d));let m=p.get(...y);c*=Number(m)}a+=c}return a}function Du(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 dn(r,t){let e=r.shape,n=t.shape,o=e.length,a=n.length,s=k(r.dtype,t.dtype),i=Math.max(o,a),u=new Array(i),c=new Array(i).fill(1),f=new Array(i).fill(1);for(let m=0;m<o;m++)c[i-o+m]=e[m];for(let m=0;m<a;m++)f[i-a+m]=n[m];for(let m=0;m<i;m++)u[m]=c[m]*f[m];let p=D.zeros(u,s),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(i).fill(0);for(let b=0;b<o;b++)h[i-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 w=new Array(i).fill(0);for(let E=0;E<a;E++)w[i-a+E]=N[E];let I=t.get(...N),z=new Array(i);for(let E=0;E<i;E++)z[E]=h[E]*f[E]+w[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 gn=C(()=>{"use strict";W();q();Ot()});function An(r){return F(r,Math.sqrt,!1)}function hn(r,t){return typeof t=="number"?Nu(r,t):L(r,t,Math.pow,"power")}function Nu(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,u=e!=="float32"&&e!=="float64"&&(t<0||!Number.isInteger(t))?"float64":e,c=D.zeros(n,u),f=c.data;if(x(e))if(x(u)&&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 bn=C(()=>{"use strict";W();ar();q()});function Sn(r){return F(r,Math.sin,!1)}function Dn(r){return F(r,Math.cos,!1)}function xn(r){return F(r,Math.tan,!1)}function Nn(r){return F(r,Math.asin,!1)}function wn(r){return F(r,Math.acos,!1)}function In(r){return F(r,Math.atan,!1)}function zn(r,t){return typeof t=="number"?zu(r,t):Iu(r,t)}function Iu(r,t){let e=Array.from(r.shape),n=r.size,o=r.dtype,a=t.dtype,s=o==="float32"&&a==="float32"?"float32":"float64",i=D.zeros(e,s),u=i.data;for(let c=0;c<n;c++){let f=(x(o),Number(r.data[c])),p=(x(a),Number(t.data[c]));u[c]=Math.atan2(f,p)}return i}function zu(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=e==="float32"?"float32":"float64",i=D.zeros(n,s),u=i.data;if(x(e))for(let c=0;c<a;c++)u[c]=Math.atan2(Number(o[c]),t);else for(let c=0;c<a;c++)u[c]=Math.atan2(Number(o[c]),t);return i}function _n(r,t){return typeof t=="number"?Bu(r,t):_u(r,t)}function _u(r,t){let e=Array.from(r.shape),n=r.size,o=r.dtype,a=t.dtype,s=o==="float32"&&a==="float32"?"float32":"float64",i=D.zeros(e,s),u=i.data;for(let c=0;c<n;c++){let f=(x(o),Number(r.data[c])),p=(x(a),Number(t.data[c]));u[c]=Math.hypot(f,p)}return i}function Bu(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=e==="float32"?"float32":"float64",i=D.zeros(n,s),u=i.data;if(x(e))for(let c=0;c<a;c++)u[c]=Math.hypot(Number(o[c]),t);else for(let c=0;c<a;c++)u[c]=Math.hypot(Number(o[c]),t);return i}function Bn(r){let t=180/Math.PI;return F(r,e=>e*t,!1)}function En(r){let t=Math.PI/180;return F(r,e=>e*t,!1)}var Tn=C(()=>{"use strict";W();ar();q()});function Un(r){return F(r,Math.sinh,!1)}function vn(r){return F(r,Math.cosh,!1)}function On(r){return F(r,Math.tanh,!1)}function $n(r){return F(r,Math.asinh,!1)}function Mn(r){return F(r,Math.acosh,!1)}function Cn(r){return F(r,Math.atanh,!1)}var kn=C(()=>{"use strict";ar()});function kt(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 s=0;s<o;s++)if(a[s]!==t[s])throw new Error(`operands could not be broadcast together with shape (${e.join(",")}) (${t.join(",")})`);return J(r,t)}function Pn(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=>J(n,e))}function Vn(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=O(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);x(a),h[A]=S}return D.fromData(h,[d],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];for(let m of t){let d=m<0?i+m:m;if(d<0||d>=i)throw new Error(`index ${m} is out of bounds for axis ${s} with size ${i}`)}let u=Array.from(n);u[s]=t.length;let c=u.reduce((m,d)=>m*d,1),f=O(a);if(!f)throw new Error(`Cannot take from array with dtype ${a}`);let p=new f(c),l=j(u),y=new Array(o).fill(0);for(let m=0;m<c;m++){let d=[...y],g=y[s],h=t[g];h<0&&(h=i+h),d[s]=h;let A=r.get(...d),b=0;for(let S=0;S<o;S++)b+=y[S]*l[S];x(a),p[b]=A;for(let S=o-1;S>=0&&(y[S]++,!(y[S]<u[S]));S--)y[S]=0}return D.fromData(p,u,a)}function Fn(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 s=0;s<e.size;s++)a.push(e.iget(s));if(a.length===1)a=new Array(t.length).fill(a[0]);else if(a.length!==t.length){let s=[...a];a=[];for(let i=0;i<t.length;i++)a.push(s[i%s.length])}}for(let s=0;s<t.length;s++){let i=t[s];if(i<0&&(i=n+i),i<0||i>=n)throw new Error(`index ${t[s]} is out of bounds for axis 0 with size ${n}`);let u=a[s];x(o)?typeof u!="bigint"&&(u=BigInt(Math.round(Number(u)))):typeof u=="bigint"&&(u=Number(u)),r.iset(i,u)}}function Rn(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 s=nr(a);if(s===null)throw new Error("operands could not be broadcast together");let i=J(r,s),u=t.map(l=>J(l,s)),c=s.reduce((l,y)=>l*y,1),f=O(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(i.iget(l));if(y<0||y>=n)throw new Error(`index ${y} is out of bounds for axis 0 with size ${n}`);let m=u[y].iget(l);x(o),p[l]=m}return D.fromData(p,s,o)}function Ln(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),s=t.iget(o);if(e){let i=typeof a=="number"&&Number.isNaN(a),u=typeof s=="number"&&Number.isNaN(s);if(i&&u)continue}if(a!==s)return!1}return!0}function qn(r,t,e){let n=r.shape,o=n.length,a=r.dtype,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=t.shape;if(i.length!==o)throw new Error(`indices and arr must have the same number of dimensions, got ${i.length} vs ${o}`);for(let d=0;d<o;d++)if(d!==s&&i[d]!==n[d]&&i[d]!==1&&n[d]!==1)throw new Error(`index ${i[d]} is out of bounds for size ${n[d]} in dimension ${d}`);let u=Array.from(i),c=u.reduce((d,g)=>d*g,1),f=O(a);if(!f)throw new Error(`Cannot take_along_axis with dtype ${a}`);let p=new f(c),l=j(n),y=j(i),m=n[s];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%u[I],h=Math.floor(h/u[I]);let A=0;for(let I=0;I<o;I++){let z=i[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 ${s} with size ${m}`);let S=[...g];S[s]=b;let N=0;for(let I=0;I<o;I++){let z=n[I]===1?0:S[I];N+=z*l[I]}let w=r.iget(N);x(a),p[d]=w}return D.fromData(p,u,a)}function jn(r,t,e,n){let o=r.shape,a=o.length,s=r.dtype,i=n<0?a+n:n;if(i<0||i>=a)throw new Error(`axis ${n} is out of bounds for array of dimension ${a}`);let u=t.shape,c=e.shape;if(u.length!==a||c.length!==a)throw new Error("indices, arr, and values must have same ndim");let f=o[i],p=j(o),l=j(u),y=j(c),m=u.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%u[z],h=Math.floor(h/u[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 ${i} 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),w=[...g];w[i]=b;let I=0;for(let z=0;z<a;z++)I+=w[z]*p[z];x(s)?typeof N!="bigint"&&(N=BigInt(Math.round(Number(N)))):typeof N=="bigint"&&(N=Number(N)),r.iset(I,N)}}function Wn(r,t,e){let n=r.size,o=r.dtype,a;if(typeof e=="number"||typeof e=="bigint")a=[e];else{a=[];for(let i=0;i<e.size;i++)a.push(e.iget(i))}let s=0;for(let i=0;i<n;i++)if(t.iget(i)){let c=a[s%a.length];x(o)?typeof c!="bigint"&&(c=BigInt(Math.round(Number(c)))):typeof c=="bigint"&&(c=Number(c)),r.iset(i,c),s++}}function Zn(r,t,e){let n=t.shape,o=n.length,a=t.dtype,s=t.data,i=x(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=O(a);if(!S)throw new Error(`Cannot compress with dtype ${a}`);let N=new S(A),w=0;for(let I=0;I<b;I++)r.iget(I)&&(N[w]=s[I],w++);return D.fromData(N,[A],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 c=n[u],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[u]=l;let m=y.reduce((A,b)=>A*b,1),d=O(a);if(!d)throw new Error(`Cannot compress with dtype ${a}`);let g=new d(m),h=j(n);if(u===0){let A=h[0],b=n.slice(1).reduce((N,w)=>N*w,1),S=0;for(let N=0;N<l;N++){let I=p[N]*A;if(i){let z=s,B=g;for(let E=0;E<b;E++)B[S++]=z[I+E]}else{let z=s,B=g;for(let E=0;E<b;E++)B[S++]=z[I+E]}}}else{let A=n.slice(0,u).reduce((N,w)=>N*w,1),b=n.slice(u+1).reduce((N,w)=>N*w,1),S=0;for(let N=0;N<A;N++)for(let w=0;w<l;w++){let I=p[w],z=0,B=N;for(let E=u-1;E>=0;E--){let T=B%n[E];B=Math.floor(B/n[E]),z+=T*h[E]}if(z+=I*h[u],i){let E=s,T=g;for(let $=0;$<b;$++)T[S++]=E[z+$]}else{let E=s,T=g;for(let $=0;$<b;$++)T[S++]=E[z+$]}}}return D.fromData(g,y,a)}function Gn(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=nr(n);if(o===null)throw new Error("condlist and choicelist arrays could not be broadcast together");let a=t[0].dtype,s=o.reduce((l,y)=>l*y,1),i=O(a);if(!i)throw new Error(`Cannot select with dtype ${a}`);let u=e;x(a)?u=typeof e=="bigint"?e:BigInt(e):u=typeof e=="bigint"?Number(e):e;let c=new i(s);for(let l=0;l<s;l++)x(a),c[l]=u;let f=r.map(l=>J(l,o)),p=t.map(l=>J(l,o));for(let l=0;l<s;l++)for(let y=0;y<r.length;y++)if(f[y].iget(l)){let m=p[y].iget(l);x(a),c[l]=m;break}return D.fromData(c,o,a)}function Hn(r,t,e){let n=r.size,o=r.dtype,a=[];for(let i=0;i<e.size;i++)a.push(e.iget(i));if(a.length===0)return;let s=0;for(let i=0;i<n;i++)if(t.iget(i)){let c=a[s%a.length];x(o)?typeof c!="bigint"&&(c=BigInt(Math.round(Number(c)))):typeof c=="bigint"&&(c=Number(c)),r.iset(i,c),s++}}function Pt(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 Yn(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 Pt(n,e)}function Vt(r,t=0,e){let n=e??r,o=[],a=[];for(let s=0;s<r;s++)for(let i=0;i<=Math.min(s+t,n-1);i++)i>=0&&(o.push(s),a.push(i));return[D.fromData(new Int32Array(o),[o.length],"int32"),D.fromData(new Int32Array(a),[a.length],"int32")]}function Jn(r,t=0){let e=r.shape;if(e.length!==2)throw new Error("array must be 2-D");return Vt(e[0],t,e[1])}function Ft(r,t=0,e){let n=e??r,o=[],a=[];for(let s=0;s<r;s++)for(let i=Math.max(s+t,0);i<n;i++)o.push(s),a.push(i);return[D.fromData(new Int32Array(o),[o.length],"int32"),D.fromData(new Int32Array(a),[a.length],"int32")]}function Xn(r,t=0){let e=r.shape;if(e.length!==2)throw new Error("array must be 2-D");return Ft(e[0],t,e[1])}function Qn(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=[],s=[];for(let i=0;i<r;i++)for(let u=0;u<r;u++)n.get(i,u)&&(a.push(i),s.push(u));return[D.fromData(new Int32Array(a),[a.length],"int32"),D.fromData(new Int32Array(s),[s.length],"int32")]}function Kn(r,t="int32"){let e=r.length,n=[e,...r],o=n.reduce((u,c)=>u*c,1),a=O(t);if(!a)throw new Error(`Cannot create indices with dtype ${t}`);let s=new a(o),i=r.reduce((u,c)=>u*c,1);for(let u=0;u<e;u++){let c=u*i;for(let f=0;f<i;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[u];t==="int64"?s[c+f]=BigInt(y):s[c+f]=y}}return D.fromData(s,n,t)}function ro(...r){let t=r.length,e=[];for(let n=0;n<t;n++){let o=r[n],a=o.size,s=o.dtype,i=new Array(t).fill(1);i[n]=a;let u=O(s);if(!u)throw new Error(`Cannot create ix_ with dtype ${s}`);let c=new u(a);for(let f=0;f<a;f++){let p=o.iget(f);x(s),c[f]=p}e.push(D.fromData(c,i,s))}return e}function to(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),s=new Array(o),i=1;for(let u=o-1;u>=0;u--)s[u]=i,i*=t[u];for(let u=0;u<n;u++){let c=0;for(let f=0;f<o;f++){let p=Number(r[f].iget(u)),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*s[f]}a[u]=c}return D.fromData(a,[n],"int32")}function eo(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 s=o.length,i=t.reduce((f,p)=>f*p,1),u=new Array(n);if(e==="C"){let f=1;for(let p=n-1;p>=0;p--)u[p]=f,f*=t[p]}else{let f=1;for(let p=0;p<n;p++)u[p]=f,f*=t[p]}let c=[];for(let f=0;f<n;f++){let p=new Int32Array(s);c.push(D.fromData(p,a.length?a:[1],"int32"))}for(let f=0;f<s;f++){let p=o[f];if(p<0||p>=i)throw new Error(`index ${p} is out of bounds for array with size ${i}`);if(e==="C")for(let l=0;l<n;l++){let y=Math.floor(p/u[l]);p=p%u[l],c[l].data[f]=y%t[l]}else for(let l=n-1;l>=0;l--){let y=Math.floor(p/u[l]);p=p%u[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 no=C(()=>{"use strict";W();q();mt()});function Y(r,t){if(!le(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 xr(r,t){return r.isCContiguous&&t.isCContiguous&&r.shape.length===t.shape.length&&r.shape.every((e,n)=>e===t.shape[n])}function so(r,t){return Y(r.dtype,"bitwise_and"),typeof t=="number"?Ou(r,t):(Y(t.dtype,"bitwise_and"),xr(r,t)?vu(r,t):L(r,t,(e,n)=>e&n,"bitwise_and"))}function vu(r,t){let e=k(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,s=t.data,i=n.data;if(x(e)){let u=i;if(!x(r.dtype)||!x(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 s[f]=="bigint"?s[f]:BigInt(Math.round(Number(s[f])));u[f]=p&l}else{let f=a,p=s;for(let l=0;l<o;l++)u[l]=f[l]&p[l]}}else for(let u=0;u<o;u++)i[u]=a[u]&s[u];return n}function Ou(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]&f}else for(let u=0;u<a;u++)i[u]=o[u]&t;return s}function io(r,t){return Y(r.dtype,"bitwise_or"),typeof t=="number"?Mu(r,t):(Y(t.dtype,"bitwise_or"),xr(r,t)?$u(r,t):L(r,t,(e,n)=>e|n,"bitwise_or"))}function $u(r,t){let e=k(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,s=t.data,i=n.data;if(x(e)){let u=i;if(!x(r.dtype)||!x(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 s[f]=="bigint"?s[f]:BigInt(Math.round(Number(s[f])));u[f]=p|l}else{let f=a,p=s;for(let l=0;l<o;l++)u[l]=f[l]|p[l]}}else for(let u=0;u<o;u++)i[u]=a[u]|s[u];return n}function Mu(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]|f}else for(let u=0;u<a;u++)i[u]=o[u]|t;return s}function uo(r,t){return Y(r.dtype,"bitwise_xor"),typeof t=="number"?ku(r,t):(Y(t.dtype,"bitwise_xor"),xr(r,t)?Cu(r,t):L(r,t,(e,n)=>e^n,"bitwise_xor"))}function Cu(r,t){let e=k(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,s=t.data,i=n.data;if(x(e)){let u=i;if(!x(r.dtype)||!x(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 s[f]=="bigint"?s[f]:BigInt(Math.round(Number(s[f])));u[f]=p^l}else{let f=a,p=s;for(let l=0;l<o;l++)u[l]=f[l]^p[l]}}else for(let u=0;u<o;u++)i[u]=a[u]^s[u];return n}function ku(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]^f}else for(let u=0;u<a;u++)i[u]=o[u]^t;return s}function Rt(r){Y(r.dtype,"bitwise_not");let t=r.dtype,e=Array.from(r.shape),n=r.data,o=r.size,a=D.zeros(e,t),s=a.data;if(x(t)){let i=n,u=s;for(let c=0;c<o;c++)u[c]=~i[c]}else for(let i=0;i<o;i++)s[i]=~n[i];return a}function co(r){return Rt(r)}function fo(r,t){if(Y(r.dtype,"left_shift"),typeof t=="number")return oo(r,t);if(Y(t.dtype,"left_shift"),t.size===1||t.ndim===1&&t.shape[0]===1){let e=x(t.dtype)?Number(t.data[0]):t.data[0];return oo(r,e)}return xr(r,t)?Pu(r,t):L(r,t,(e,n)=>e<<n,"left_shift")}function Pu(r,t){let e=k(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,s=t.data,i=n.data;if(x(e)){let u=i;for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?a[c]:BigInt(Math.round(Number(a[c]))),p=typeof s[c]=="bigint"?s[c]:BigInt(Math.round(Number(s[c])));u[c]=f<<p}}else for(let u=0;u<o;u++)i[u]=a[u]<<s[u];return n}function oo(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]<<f}else for(let u=0;u<a;u++)i[u]=o[u]<<t;return s}function lo(r,t){if(Y(r.dtype,"right_shift"),typeof t=="number")return ao(r,t);if(Y(t.dtype,"right_shift"),t.size===1||t.ndim===1&&t.shape[0]===1){let e=x(t.dtype)?Number(t.data[0]):t.data[0];return ao(r,e)}return xr(r,t)?Vu(r,t):L(r,t,(e,n)=>e>>n,"right_shift")}function Vu(r,t){let e=k(r.dtype,t.dtype),n=D.zeros(Array.from(r.shape),e),o=r.size,a=r.data,s=t.data,i=n.data;if(x(e)){let u=i;for(let c=0;c<o;c++){let f=typeof a[c]=="bigint"?a[c]:BigInt(Math.round(Number(a[c]))),p=typeof s[c]=="bigint"?s[c]:BigInt(Math.round(Number(s[c])));u[c]=f>>p}}else for(let u=0;u<o;u++)i[u]=a[u]>>s[u];return n}function ao(r,t){let e=r.dtype,n=Array.from(r.shape),o=r.data,a=r.size,s=D.zeros(n,e),i=s.data;if(x(e)){let u=o,c=i,f=BigInt(Math.round(t));for(let p=0;p<a;p++)c[p]=u[p]>>f}else for(let u=0;u<a;u++)i[u]=o[u]>>t;return s}function po(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],s=Math.ceil(a/8),i=[...n];i[t]=s;let u=D.zeros(i,"uint8"),c=u.data;if(o===1){for(let g=0;g<s;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 u}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=Zr(n),d=Zr(i);for(let g=0;g<l;g++)for(let h=0;h<y;h++)for(let A=0;A<s;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 M=0;M<t;M++){let R=M<t-1?f.slice(M+1).reduce((st,it)=>st*it,1):1,H=Math.floor(E/R);E%=R,B+=H*m[M]}B+=z*m[t];let T=h;for(let M=t+1;M<o;M++){let R=M<o-1?p.slice(M-t).reduce((st,it)=>st*it,1):1,H=Math.floor(T/R);T%=R,B+=H*m[M]}let $=Number(r.data[B])!==0?1:0;e==="big"?b|=$<<7-I:b|=$<<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 w=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(w/z);w%=z,S+=B*d[I]}c[S]=b}return u}function yo(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 s=o[t],i=s*8;e>=0&&(i=e);let u=[...o];u[t]=i;let c=D.zeros(u,"uint8"),f=c.data;if(a===1){for(let h=0;h<s;h++){let A=Number(r.data[h]);for(let b=0;b<8;b++){let S=h*8+b;if(S>=i)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=Zr(o),g=Zr(u);for(let h=0;h<y;h++)for(let A=0;A<m;A++)for(let b=0;b<s;b++){let S=0,N=h;for(let z=0;z<t;z++){let B=z<t-1?p.slice(z+1).reduce((T,$)=>T*$,1):1,E=Math.floor(N/B);N%=B,S+=E*d[z]}S+=b*d[t];let w=A;for(let z=t+1;z<a;z++){let B=z<a-1?l.slice(z-t).reduce((T,$)=>T*$,1):1,E=Math.floor(w/B);w%=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>=i)break;let E=0;N=h;for(let T=0;T<t;T++){let $=T<t-1?p.slice(T+1).reduce((R,H)=>R*H,1):1,M=Math.floor(N/$);N%=$,E+=M*g[T]}E+=B*g[t],w=A;for(let T=t+1;T<a;T++){let $=T<a-1?l.slice(T-t).reduce((R,H)=>R*H,1):1,M=Math.floor(w/$);w%=$,E+=M*g[T]}n==="big"?f[E]=I>>7-z&1:f[E]=I>>z&1}}return c}function Zr(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 mo=C(()=>{"use strict";W();q();ar()});function Lt(r,t=-1){let e=r.shape,n=e.length,o=r.dtype,a=r.data;if(n===0)return r.copy();let s=t;if(s<0&&(s=n+s),s<0||s>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=r.copy(),u=i.data,c=e[s],f=Array.from(e).filter((l,y)=>y!==s),p=f.length===0?1:f.reduce((l,y)=>l*y,1);if(x(o)){let l=a,y=u;for(let m=0;m<p;m++){let d=[];for(let g=0;g<c;g++){let h=v(m,s,g,e),A=U(h,e);d.push({value:l[A],idx:g})}d.sort((g,h)=>g.value<h.value?-1:g.value>h.value?1:0);for(let g=0;g<c;g++){let h=v(m,s,g,e),A=U(h,e);y[A]=d[g].value}}}else for(let l=0;l<p;l++){let y=[];for(let m=0;m<c;m++){let d=v(l,s,m,e),g=U(d,e);y.push(Number(a[g]))}y.sort((m,d)=>isNaN(m)&&isNaN(d)?0:isNaN(m)?1:isNaN(d)?-1:m-d);for(let m=0;m<c;m++){let d=v(l,s,m,e),g=U(d,e);u[g]=y[m]}}return i}function qt(r,t=-1){let e=r.shape,n=e.length,o=r.dtype,a=r.data;if(n===0)return D.zeros([0],"int32");let s=t;if(s<0&&(s=n+s),s<0||s>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=D.zeros(Array.from(e),"int32"),u=i.data,c=e[s],f=Array.from(e).filter((l,y)=>y!==s),p=f.length===0?1:f.reduce((l,y)=>l*y,1);if(x(o)){let l=a;for(let y=0;y<p;y++){let m=[];for(let d=0;d<c;d++){let g=v(y,s,d,e),h=U(g,e);m.push({value:l[h],idx:d})}m.sort((d,g)=>d.value<g.value?-1:d.value>g.value?1:0);for(let d=0;d<c;d++){let g=v(y,s,d,e),h=U(g,e);u[h]=m[d].idx}}}else for(let l=0;l<p;l++){let y=[];for(let m=0;m<c;m++){let d=v(l,s,m,e),g=U(d,e);y.push({value:Number(a[g]),idx:m})}y.sort((m,d)=>isNaN(m.value)&&isNaN(d.value)?0:isNaN(m.value)?1:isNaN(d.value)?-1:m.value-d.value);for(let m=0;m<c;m++){let d=v(l,s,m,e),g=U(d,e);u[g]=y[m].idx}}return i}function go(r){if(r.length===0)return D.zeros([0],"int32");let e=r[0].size;for(let s of r){if(s.ndim!==1)throw new Error("keys must be 1D arrays");if(s.size!==e)throw new Error("all keys must have the same length")}let n=[];for(let s=0;s<e;s++)n.push(s);n.sort((s,i)=>{for(let u=r.length-1;u>=0;u--){let f=r[u].data,p=Number(f[s]),l=Number(f[i]);if(!(isNaN(p)&&isNaN(l))){if(isNaN(p))return 1;if(isNaN(l)||p<l)return-1;if(p>l)return 1}}return 0});let o=D.zeros([e],"int32"),a=o.data;for(let s=0;s<e;s++)a[s]=n[s];return o}function Ru(r,t){let e=0,n=r.length-1;for(;e<n;){let o=Math.floor((e+n)/2),a=r[e],s=r[o],i=r[n],u;a<=s&&s<=i||i<=s&&s<=a?u=o:s<=a&&a<=i||i<=a&&a<=s?u=e:u=n;let c=r[u];[r[u],r[n]]=[r[n],r[u]];let f=e;for(let p=e;p<n;p++){let l=r[p],y=isNaN(l),m=isNaN(c);!y&&(m||l<=c)&&([r[f],r[p]]=[r[p],r[f]],f++)}if([r[f],r[n]]=[r[n],r[f]],f===t)return;f<t?e=f+1:n=f-1}}function Lu(r,t){let e=0,n=r.length-1;for(;e<n;){let o=Math.floor((e+n)/2),a=r[e],s=r[o],i=r[n],u;a<=s&&s<=i||i<=s&&s<=a?u=o:s<=a&&a<=i||i<=a&&a<=s?u=e:u=n;let c=r[u];[r[u],r[n]]=[r[n],r[u]];let f=e;for(let p=e;p<n;p++)r[p]<=c&&([r[f],r[p]]=[r[p],r[f]],f++);if([r[f],r[n]]=[r[n],r[f]],f===t)return;f<t?e=f+1:n=f-1}}function qu(r,t){let e=0,n=r.length-1;for(;e<n;){let o=Math.floor((e+n)/2),a=r[e].value,s=r[o].value,i=r[n].value,u;a<=s&&s<=i||i<=s&&s<=a?u=o:s<=a&&a<=i||i<=a&&a<=s?u=e:u=n;let c=r[u].value;[r[u],r[n]]=[r[n],r[u]];let f=e;for(let p=e;p<n;p++){let l=r[p].value,y=isNaN(l),m=isNaN(c);!y&&(m||l<=c)&&([r[f],r[p]]=[r[p],r[f]],f++)}if([r[f],r[n]]=[r[n],r[f]],f===t)return;f<t?e=f+1:n=f-1}}function ju(r,t){let e=0,n=r.length-1;for(;e<n;){let o=Math.floor((e+n)/2),a=r[e].value,s=r[o].value,i=r[n].value,u;a<=s&&s<=i||i<=s&&s<=a?u=o:s<=a&&a<=i||i<=a&&a<=s?u=e:u=n;let c=r[u].value;[r[u],r[n]]=[r[n],r[u]];let f=e;for(let p=e;p<n;p++)r[p].value<=c&&([r[f],r[p]]=[r[p],r[f]],f++);if([r[f],r[n]]=[r[n],r[f]],f===t)return;f<t?e=f+1:n=f-1}}function jt(r,t,e=-1){let n=r.shape,o=n.length,a=r.dtype;if(o===0)return r.copy();let s=e;if(s<0&&(s=o+s),s<0||s>=o)throw new Error(`axis ${e} is out of bounds for array of dimension ${o}`);let i=n[s],u=t;if(u<0&&(u=i+u),u<0||u>=i)throw new Error(`kth(=${t}) out of bounds (${i})`);let c=r.copy(),f=c.data,p=Array.from(n).filter((y,m)=>m!==s),l=p.length===0?1:p.reduce((y,m)=>y*m,1);if(x(a)){let y=f;for(let m=0;m<l;m++){let d=[];for(let g=0;g<i;g++){let h=v(m,s,g,n),A=U(h,n);d.push(y[A])}Lu(d,u);for(let g=0;g<i;g++){let h=v(m,s,g,n),A=U(h,n);y[A]=d[g]}}}else for(let y=0;y<l;y++){let m=[];for(let d=0;d<i;d++){let g=v(y,s,d,n),h=U(g,n);m.push(Number(f[h]))}Ru(m,u);for(let d=0;d<i;d++){let g=v(y,s,d,n),h=U(g,n);f[h]=m[d]}}return c}function Wt(r,t,e=-1){let n=r.shape,o=n.length,a=r.dtype,s=r.data;if(o===0)return D.zeros([0],"int32");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],c=t;if(c<0&&(c=u+c),c<0||c>=u)throw new Error(`kth(=${t}) out of bounds (${u})`);let f=D.zeros(Array.from(n),"int32"),p=f.data,l=Array.from(n).filter((m,d)=>d!==i),y=l.length===0?1:l.reduce((m,d)=>m*d,1);if(x(a)){let m=s;for(let d=0;d<y;d++){let g=[];for(let h=0;h<u;h++){let A=v(d,i,h,n),b=U(A,n);g.push({value:m[b],idx:h})}ju(g,c);for(let h=0;h<u;h++){let A=v(d,i,h,n),b=U(A,n);p[b]=g[h].idx}}}else for(let m=0;m<y;m++){let d=[];for(let g=0;g<u;g++){let h=v(m,i,g,n),A=U(h,n);d.push({value:Number(s[A]),idx:g})}qu(d,c);for(let g=0;g<u;g++){let h=v(m,i,g,n),A=U(h,n);p[A]=d[g].idx}}return f}function Ao(r){let t=r.dtype,e=r.size,n=r.data,o=[];for(let i=0;i<e;i++)o.push(Number(n[i]));o.sort((i,u)=>isNaN(i)&&isNaN(u)?0:isNaN(i)?1:isNaN(u)?-1:i-u);let a=D.zeros([e],t),s=a.data;for(let i=0;i<e;i++)s[i]=o[i];return a}function Gr(r){let t=r.shape,e=t.length,n=r.data,o=r.size,a=[];for(let f=0;f<e;f++)a.push([]);let s=[],i=1;for(let f=e-1;f>=0;f--)s.unshift(i),i*=t[f];for(let f=0;f<o;f++)if(n[f]){let p=f;for(let l=0;l<e;l++){let y=Math.floor(p/s[l]);p=p%s[l],a[l].push(y)}}let u=a[0]?.length??0,c=[];for(let f=0;f<e;f++){let p=D.zeros([u],"int32"),l=p.data;for(let y=0;y<u;y++)l[y]=a[f][y];c.push(p)}return c}function ho(r){let t=r.data,e=r.size,n=[];for(let s=0;s<e;s++)t[s]&&n.push(s);let o=D.zeros([n.length],"int32"),a=o.data;for(let s=0;s<n.length;s++)a[s]=n[s];return o}function bo(r,t,e){if(t===void 0&&e===void 0)return Gr(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,s=Math.max(n.length,o.length,a.length),i=B=>{let E=Array(s).fill(1);for(let T=0;T<B.length;T++)E[s-B.length+T]=B[T];return E},u=i(n),c=i(o),f=i(a),p=[];for(let B=0;B<s;B++){let E=[u[B],c[B],f[B]],T=Math.max(...E);for(let $ of E)if($!==1&&$!==T)throw new Error("operands could not be broadcast together");p.push(T)}let l=t.dtype,y=D.zeros(p,l),m=y.data,d=r.data,g=t.data,h=e.data,A=(B,E)=>{let T=[],$=1;for(let M=B.length-1;M>=0;M--)T.unshift($),$*=B[M];for(;T.length<E.length;)T.unshift(0);for(let M=0;M<E.length;M++)E[M]===1&&p[M]!==1&&(T[M]=0);return T},b=A(n,u),S=A(o,c),N=A(a,f),w=[],I=1;for(let B=p.length-1;B>=0;B--)w.unshift(I),I*=p[B];let z=p.reduce((B,E)=>B*E,1);for(let B=0;B<z;B++){let E=B,T=0,$=0,M=0;for(let R=0;R<s;R++){let H=Math.floor(E/w[R]);E=E%w[R],T+=H*b[R],$+=H*S[R],M+=H*N[R]}d[T]?m[B]=g[$]:m[B]=h[M]}return y}function Zt(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,s=t.size,i=D.zeros([s],"int32"),u=i.data;for(let c=0;c<s;c++){let f=Number(a[c]),p=0,l=o;if(e==="left")for(;p<l;){let y=Math.floor((p+l)/2);Number(n[y])<f?p=y+1:l=y}else for(;p<l;){let y=Math.floor((p+l)/2);Number(n[y])<=f?p=y+1:l=y}u[c]=p}return i}function So(r,t){let e=r.data,n=t.data,o=t.dtype,a=Math.min(r.size,t.size),s=0;for(let f=0;f<a;f++)e[f]&&s++;let i=D.zeros([s],o),u=i.data,c=0;if(x(o)){let f=n,p=u;for(let l=0;l<a;l++)e[l]&&(p[c++]=f[l])}else for(let f=0;f<a;f++)e[f]&&(u[c++]=n[f]);return i}function Gt(r,t){let e=r.shape,n=e.length,o=r.data,a=r.size;if(t===void 0){let l=0;for(let y=0;y<a;y++)o[y]&&l++;return l}let s=t;if(s<0&&(s=n+s),s<0||s>=n)throw new Error(`axis ${t} is out of bounds for array of dimension ${n}`);let i=Array.from(e).filter((l,y)=>y!==s);if(i.length===0)return Gt(r);let u=D.zeros(i,"int32"),c=u.data,f=e[s],p=i.reduce((l,y)=>l*y,1);for(let l=0;l<p;l++){let y=0;for(let m=0;m<f;m++){let d=v(l,s,m,e),g=U(d,e);o[g]&&y++}c[l]=y}return u}var Do=C(()=>{"use strict";W();q();gt()});function X(r,t=V){let e=D.zeros(r,t);return new _(e)}function Ht(r,t=V){let e=D.ones(r,t);return new _(e)}function Zu(r){let t=[],e=r;for(;Array.isArray(e);)t.push(e.length),e=e[0];return t}function xo(r){return typeof r=="bigint"?!0:Array.isArray(r)?r.some(t=>xo(t)):!1}function Gu(r){let t=[];function e(n){Array.isArray(n)?n.forEach(o=>e(o)):t.push(n)}return e(r),t}function P(r,t){if(r instanceof _)return!t||r.dtype===t?r.copy():r.astype(t);let e=xo(r),n=Zu(r),o=n.reduce((f,p)=>f*p,1),a=t;a||(e?a="int64":a=V);let s=O(a);if(!s)throw new Error(`Cannot create array with dtype ${a}`);let i=new s(o),u=Gu(r);if(x(a)){let f=i;for(let p=0;p<o;p++){let l=u[p];f[p]=typeof l=="bigint"?l:BigInt(Math.round(Number(l)))}}else if(a==="bool"){let f=i;for(let p=0;p<o;p++)f[p]=u[p]?1:0}else{let f=i;for(let p=0;p<o;p++){let l=u[p];f[p]=Number(l)}}let c=D.fromData(i,n,a);return new _(c)}function No(r,t,e=1,n=V){let o=r,a=t;if(t===void 0&&(o=0,a=r),a===void 0)throw new Error("stop is required");let s=Math.max(0,Math.ceil((a-o)/e)),i=O(n);if(!i)throw new Error(`Cannot create arange array with dtype ${n}`);let u=new i(s);if(x(n))for(let f=0;f<s;f++)u[f]=BigInt(Math.round(o+f*e));else if(n==="bool")for(let f=0;f<s;f++)u[f]=o+f*e!==0?1:0;else for(let f=0;f<s;f++)u[f]=o+f*e;let c=D.fromData(u,[s],n);return new _(c)}function wo(r,t,e=50,n=V){if(e<0)throw new Error("num must be non-negative");if(e===0)return P([],n);if(e===1)return P([r],n);let o=O(n);if(!o)throw new Error(`Cannot create linspace array with dtype ${n}`);let a=new o(e),s=(t-r)/(e-1);if(x(n))for(let u=0;u<e;u++)a[u]=BigInt(Math.round(r+u*s));else if(n==="bool")for(let u=0;u<e;u++)a[u]=r+u*s!==0?1:0;else for(let u=0;u<e;u++)a[u]=r+u*s;let i=D.fromData(a,[e],n);return new _(i)}function Io(r,t,e=50,n=10,o=V){if(e<0)throw new Error("num must be non-negative");if(e===0)return P([],o);if(e===1)return P([Math.pow(n,r)],o);let a=O(o);if(!a)throw new Error(`Cannot create logspace array with dtype ${o}`);let s=new a(e),i=(t-r)/(e-1);if(x(o))for(let c=0;c<e;c++){let f=r+c*i;s[c]=BigInt(Math.round(Math.pow(n,f)))}else if(o==="bool")for(let c=0;c<e;c++){let f=r+c*i;s[c]=Math.pow(n,f)!==0?1:0}else for(let c=0;c<e;c++){let f=r+c*i;s[c]=Math.pow(n,f)}let u=D.fromData(s,[e],o);return new _(u)}function zo(r,t,e=50,n=V){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 P([],n);if(e===1)return P([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 s=O(n);if(!s)throw new Error(`Cannot create geomspace array with dtype ${n}`);let i=new s(e),u=Math.log(Math.abs(r)),f=(Math.log(Math.abs(t))-u)/(e-1);if(x(n))for(let l=0;l<e;l++){let y=o*Math.exp(u+l*f);i[l]=BigInt(Math.round(y))}else if(n==="bool")for(let l=0;l<e;l++){let y=o*Math.exp(u+l*f);i[l]=y!==0?1:0}else for(let l=0;l<e;l++){let y=o*Math.exp(u+l*f);i[l]=y}let p=D.fromData(i,[e],n);return new _(p)}function Yt(r,t,e=0,n=V){let o=t??r,a=X([r,o],n),s=a.data;if(x(n)){let i=s;for(let u=0;u<r;u++){let c=u+e;c>=0&&c<o&&(i[u*o+c]=BigInt(1))}}else{let i=s;for(let u=0;u<r;u++){let c=u+e;c>=0&&c<o&&(i[u*o+c]=1)}}return a}function Jt(r,t=V){return X(r,t)}function Xt(r,t,e){let n=e;n||(typeof t=="bigint"?n="int64":typeof t=="boolean"?n="bool":Number.isInteger(t)?n="int32":n=V);let o=O(n);if(!o)throw new Error(`Cannot create full array with dtype ${n}`);let a=r.reduce((u,c)=>u*c,1),s=new o(a);if(x(n)){let u=typeof t=="bigint"?t:BigInt(Math.round(Number(t)));s.fill(u)}else n==="bool"?s.fill(t?1:0):s.fill(Number(t));let i=D.fromData(s,r,n);return new _(i)}function _o(r,t=V){return Yt(r,r,0,t)}function Nr(r,t){return r instanceof _?!t||r.dtype===t?r:r.astype(t):P(r,t)}function Bo(r){return r.copy()}function Eo(r,t){return X(Array.from(r.shape),t??r.dtype)}function To(r,t){return Ht(Array.from(r.shape),t??r.dtype)}function Uo(r,t){return Jt(Array.from(r.shape),t??r.dtype)}function vo(r,t,e){return Xt(Array.from(r.shape),t,e??r.dtype)}function Oo(r,t){return Nr(r,t)}function $o(r,t){let e=Nr(r,t);return e.flags.C_CONTIGUOUS?e:e.copy()}function Mo(r,t){return Nr(r,t).copy()}function Qt(r,t=0){if(r.ndim===1){let e=r.size,n=e+Math.abs(t),o=X([n,n],r.dtype);for(let a=0;a<e;a++){let s=t>=0?a:a-t,i=t>=0?a+t:a;o.set([s,i],r.get([a]))}return o}else if(r.ndim===2){let[e,n]=r.shape,o,a,s;if(t>=0?(o=0,a=t,s=Math.min(e,n-t)):(o=-t,a=0,s=Math.min(e+t,n)),s<=0)return X([0],r.dtype);let i=O(r.dtype),u=new i(s);for(let f=0;f<s;f++){let p=r.get([o+f,a+f]);x(r.dtype)?u[f]=typeof p=="bigint"?p:BigInt(p):u[f]=p}let c=D.fromData(u,[s],r.dtype);return new _(c)}else throw new Error("Input must be 1-D or 2-D")}function Co(r,t=0){let e=r.flatten();return Qt(e,t)}function ko(r,t,e=V){let n=t.reduce((c,f)=>c*f,1),o=O(e);if(!o)throw new Error(`Cannot create array with dtype ${e}`);let a=new o(n),s=t.length,i=new Array(s).fill(0);for(let c=0;c<n;c++){let f=r(...i);x(e)?a[c]=typeof f=="bigint"?f:BigInt(Number(f)):e==="bool"?a[c]=f?1:0:a[c]=Number(f);for(let p=s-1;p>=0&&(i[p]++,!(i[p]<t[p]));p--)i[p]=0}let u=D.fromData(a,t,e);return new _(u)}function Po(...r){let t=[],e="xy";for(let i of r)i instanceof _?t.push(i):typeof i=="object"&&"indexing"in i&&(e=i.indexing||"xy");if(t.length===0)return[];if(t.length===1)return[t[0].copy()];let n=t.map(i=>i.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,s=[];for(let i=0;i<t.length;i++){let u=t[i],c=u.size,f=new Array(a).fill(1);f[i]=c;let p=u.reshape(...f),l=kt(p.storage,o),y=_._fromStorage(l.copy());s.push(y)}return e==="xy"&&s.length>=2&&([s[0],s[1]]=[s[1],s[0]]),s}function Vo(r,t,e=0,n=V){let o=t??r,a=X([r,o],n);for(let s=0;s<r;s++)for(let i=0;i<=s+e&&i<o;i++)i>=0&&a.set([s,i],1);return a}function Fo(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],s=n.slice(0,-2).reduce((i,u)=>i*u,1);for(let i=0;i<s;i++)for(let u=0;u<o;u++)for(let c=0;c<a;c++)if(c>u+t){let f=[],p=i;for(let l=n.length-3;l>=0;l--)f.unshift(p%n[l]),p=Math.floor(p/n[l]);f.push(u,c),e.set(f,0)}return e}function Ro(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],s=n.slice(0,-2).reduce((i,u)=>i*u,1);for(let i=0;i<s;i++)for(let u=0;u<o;u++)for(let c=0;c<a;c++)if(c<u+t){let f=[],p=i;for(let l=n.length-3;l>=0;l--)f.unshift(p%n[l]),p=Math.floor(p/n[l]);f.push(u,c),e.set(f,0)}return e}function Lo(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=X([n,o],r.dtype);for(let s=0;s<n;s++){let i=r.get([s]);for(let u=0;u<o;u++){let c=e?u:o-1-u;a.set([s,u],Math.pow(i,c))}}return a}function qo(r,t=V,e=-1,n=0){let o,a=n;r instanceof ArrayBuffer?o=r:(o=r.buffer,a+=r.byteOffset);let s=Hu(t),i=o.byteLength-a,u=Math.floor(i/s),c=e<0?u:Math.min(e,u);if(c<=0)return P([],t);let f=O(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 jo(r,t=V,e=-1){let n=[],o=0;for(let a of r){if(e>=0&&o>=e)break;n.push(a),o++}return P(n,t)}function Wo(r,t=V,e=-1){let n=[],o=0;for(let a of r){if(e>=0&&o>=e)break;n.push(a),o++}return P(n,t)}function Zo(r,t=V,e=-1,n=""){let o;n===""?o=r.trim().split(/\s+/):o=r.split(n);let a=[],s=0;for(let i of o){if(e>=0&&s>=e)break;let u=i.trim();u!==""&&(x(t)?a.push(BigInt(u)):a.push(parseFloat(u)),s++)}return P(a,t)}function Hu(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 Go(r){return r.sqrt()}function Ho(r,t){return r.power(t)}function Yo(r){return r.absolute()}function Jo(r){return r.negative()}function Xo(r){return r.sign()}function Qo(r,t){return r.mod(t)}function Ko(r,t){return r.floor_divide(t)}function ra(r){return r.positive()}function ta(r){return r.reciprocal()}function ea(r,t){return r.dot(t)}function na(r){return r.trace()}function oa(r,t=0,e=0,n=1){let o=yn(r.storage,t,e,n);return _._fromStorage(o)}function aa(r,t){let e=dn(r.storage,t.storage);return _._fromStorage(e)}function sa(r,t){return r.transpose(t)}function ia(r,t){return r.inner(t)}function ua(r,t){return r.outer(t)}function ca(r,t,e=2){return r.tensordot(t,e)}function fa(r){return r.sin()}function la(r){return r.cos()}function pa(r){return r.tan()}function ya(r){return r.arcsin()}function ma(r){return r.arccos()}function da(r){return r.arctan()}function ga(r,t){return r.arctan2(t)}function Aa(r,t){return r.hypot(t)}function ha(r){return r.degrees()}function ba(r){return r.radians()}function Sa(r){return r.radians()}function Da(r){return r.degrees()}function xa(r){return r.sinh()}function Na(r){return r.cosh()}function wa(r){return r.tanh()}function Ia(r){return r.arcsinh()}function za(r){return r.arccosh()}function _a(r){return r.arctanh()}function Ba(r,t,e){return r.swapaxes(t,e)}function Ea(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=sr(e,t);return _._fromStorage(n)}function Ta(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=Le(e,t);return _._fromStorage(n)}function Kt(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=qe(t);return _._fromStorage(e)}function Ua(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=vt(t);return _._fromStorage(e)}function va(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=je(t);return _._fromStorage(e)}function Oa(r,t,e=0){return We(r.storage,t,e).map(o=>_._fromStorage(o,r.base??r))}function $a(r,t,e=0){return Dr(r.storage,t,e).map(o=>_._fromStorage(o,r.base??r))}function Ma(r,t){return Ge(r.storage,t).map(n=>_._fromStorage(n,r.base??r))}function Ca(r,t){return He(r.storage,t).map(n=>_._fromStorage(n,r.base??r))}function ka(r,t){let e=Ye(r.storage,t);return _._fromStorage(e)}function Pa(r,t,e){return r.repeat(t,e)}function Va(r){return r.ravel()}function Fa(r,t){return r.reshape(...t)}function Ra(r,t){return r.squeeze(t)}function La(r,t){return r.expand_dims(t)}function Hr(r,t){let e=Xe(r.storage,t);return _._fromStorage(e)}function qa(r){if(r.ndim<2)throw new Error("Input must be at least 2-D");return Hr(r,1)}function ja(r){if(r.ndim<2)throw new Error("Input must be at least 2-D");return Hr(r,0)}function Wa(r,t=1,e=[0,1]){let n=Qe(r.storage,t,e);return _._fromStorage(n)}function Za(r,t,e){let n=Ke(r.storage,t,e);return _._fromStorage(n)}function Ga(r,t,e=0){let n=rn(r.storage,t,e);return _._fromStorage(n,r.base??r)}function Ha(...r){let t=r.map(o=>o.storage),n=on(t).map((o,a)=>o===t[a]?r[a]:_._fromStorage(o));return n.length===1?n[0]:n}function Ya(...r){let t=r.map(o=>o.storage),n=an(t).map((o,a)=>o===t[a]?r[a]:_._fromStorage(o));return n.length===1?n[0]:n}function Ja(...r){let t=r.map(o=>o.storage),n=sn(t).map((o,a)=>o===t[a]?r[a]:_._fromStorage(o));return n.length===1?n[0]:n}function Xa(r,t){return tn(r.storage,t).map(n=>_._fromStorage(n,r.base??r))}function Qa(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=en(t);return _._fromStorage(e)}function Ka(r){return Kt(r)}function rs(r,t){let e=nn(r.storage,t);return _._fromStorage(e)}function ts(r,t,e){let n=t instanceof _?t:P(t,r.dtype);if(e===void 0){let o=r.flatten(),a=n.flatten();return ur([o,a])}return ur([r,n],e)}function es(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=O(n),A=new h(g.length);for(let S=0;S<g.length;S++){let N=y.get([g[S]]);x(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,s=e<0?a+e:e;if(s<0||s>=a)throw new Error(`axis ${e} is out of bounds for array of dimension ${a}`);let i=o[s],u=Array.isArray(t)?t:[t],c=new Set(u.map(y=>y<0?i+y:y)),f=[],p=0;for(let y=0;y<=i;y++)(c.has(y)||y===i)&&(y>p&&f.push([p,y]),p=y+1);if(f.length===0){let y=[...o];return y[s]=0,X(y,n)}let l=[];for(let[y,m]of f){let d=o.map(()=>":");d[s]=`${y}:${m}`,l.push(r.slice(...d))}return ur(l,s)}function ns(r,t,e,n){let o=e instanceof _?e:P(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,s=a.length,i=n<0?s+n:n;if(i<0||i>=s)throw new Error(`axis ${n} is out of bounds for array of dimension ${s}`);let u=a[i],c=t<0?u+t:t;if(c<0||c>u)throw new Error(`index ${t} is out of bounds for axis ${n} with size ${u}`);let f=[];if(c>0){let p=a.map(()=>":");p[i]=`0:${c}`,f.push(r.slice(...p))}if(f.push(o),c<u){let p=a.map(()=>":");p[i]=`${c}:`,f.push(r.slice(...p))}return ur(f,i)}function os(r,t,e="constant",n=0){let o=r.shape,a=o.length,s=r.dtype,i;if(typeof t=="number"?i=o.map(()=>[t,t]):Array.isArray(t)&&typeof t[0]=="number"?i=o.map(()=>t):i=t,i.length!==a)throw new Error(`pad_width must have ${a} elements`);let u=o.map((d,g)=>d+i[g][0]+i[g][1]),c=u.reduce((d,g)=>d*g,1),f=O(s),p=new f(c),l=x(s);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]=i[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]<u[b]));b--)y[b]=0;continue}else{let b=[];for(let S=0;S<a;S++){let[N]=i[S],w=y[S]-N,I=o[S];w<0?e==="edge"?w=0:e==="reflect"?(w=-w,w>=I&&(w=I-1)):e==="symmetric"?(w=-w-1,w>=I&&(w=I-1),w<0&&(w=0)):e==="wrap"&&(w=(w%I+I)%I):w>=I&&(e==="edge"?w=I-1:e==="reflect"?(w=2*I-w-2,w<0&&(w=0)):e==="symmetric"?(w=2*I-w-1,w<0&&(w=0)):e==="wrap"&&(w=w%I)),b.push(Math.max(0,Math.min(I-1,w)))}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]<u[b]));b--)y[b]=0}let m=D.fromData(p,u,s);return new _(m)}function as(r,t){let e=kt(r.storage,t);return _._fromStorage(e,r.base??r)}function ss(...r){let t=r.map(n=>n.storage);return Pn(t).map((n,o)=>_._fromStorage(n,r[o].base??r[o]))}function is(...r){return yt(...r)}function us(r,t,e){return r.take(t,e)}function cs(r,t,e){r.put(t,e)}function fs(r,t){let e=t.map(o=>o.storage),n=Rn(r.storage,e);return _._fromStorage(n)}function ls(r,t,e=!1){return Ln(r.storage,t.storage,e)}function ps(r,t){return Ce(r.storage,t.storage)}function ys(r,t){return _._fromStorage(Nt(r.storage,t))}function ms(r,t){return _._fromStorage(wt(r.storage,t))}function ds(r,t,e=!1){let n=It(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function gs(r,t,e=!1){let n=zt(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function As(r,t,e,n=!1){let o=_t(r.storage,t,e,n);return typeof o=="number"?o:_._fromStorage(o)}function hs(r,t,e,n=!1){let o=pr(r.storage,t,e,n);return typeof o=="number"?o:_._fromStorage(o)}function bs(r,t,e,n=!1){let o=e?e.storage:void 0,a=Cr(r.storage,t,o,n);return typeof a=="number"?a:_._fromStorage(a)}function Ss(r,t,e=!1){let n=kr(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function Ds(r,t,e=!1){let n=Pr(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function xs(r,t,e=!1){let n=Vr(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function Ns(r,t,e=0,n=!1){let o=Ar(r.storage,t,e,n);return typeof o=="number"?o:_._fromStorage(o)}function ws(r,t,e=0,n=!1){let o=Bt(r.storage,t,e,n);return typeof o=="number"?o:_._fromStorage(o)}function Is(r,t,e=!1){let n=Fr(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function zs(r,t,e=!1){let n=Rr(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function _s(r,t){let e=Lr(r.storage,t);return typeof e=="number"?e:_._fromStorage(e)}function Bs(r,t){let e=qr(r.storage,t);return typeof e=="number"?e:_._fromStorage(e)}function Es(r,t){return _._fromStorage(Et(r.storage,t))}function Ts(r,t){return _._fromStorage(Tt(r.storage,t))}function Us(r,t,e=!1){let n=jr(r.storage,t,e);return typeof n=="number"?n:_._fromStorage(n)}function vs(r){return r.cbrt()}function Os(r){return r.fabs()}function $s(r,t){return r.divmod(t)}function Ms(r){return r.square()}function Cs(r,t){return r.remainder(t)}function ks(r,t){return r.heaviside(t)}function Ps(r,t){return r.bitwise_and(t)}function Vs(r,t){return r.bitwise_or(t)}function Fs(r,t){return r.bitwise_xor(t)}function Rs(r){return r.bitwise_not()}function Ls(r){return r.invert()}function qs(r,t){return r.left_shift(t)}function js(r,t){return r.right_shift(t)}function Ws(r,t=-1,e="big"){let n=po(r.storage,t,e);return _._fromStorage(n)}function Zs(r,t=-1,e=-1,n="big"){let o=yo(r.storage,t,e,n);return _._fromStorage(o)}function Gs(r,...t){let e=t.map(o=>o.storage),n=mn(r,...e);return typeof n=="number"||typeof n=="bigint"?n:_._fromStorage(n)}function Hs(r,t,e){return _._fromStorage(qn(r.storage,t.storage,e))}function Ys(r,t,e,n){jn(r.storage,t.storage,e.storage,n)}function Js(r,t,e){let n=e instanceof _?e.storage:e;Wn(r.storage,t.storage,n)}function Xs(r,t,e){return _._fromStorage(Zn(r.storage,t.storage,e))}function Qs(r,t,e=0){let n=r.map(a=>a.storage),o=t.map(a=>a.storage);return _._fromStorage(Gn(n,o,e))}function Ks(r,t,e){Hn(r.storage,t.storage,e.storage)}function ri(r,t=2){return Pt(r,t).map(n=>_._fromStorage(n))}function ti(r){return Yn(r.storage).map(e=>_._fromStorage(e))}function ei(r,t=0,e){return Vt(r,t,e).map(o=>_._fromStorage(o))}function ni(r,t=0){return Jn(r.storage,t).map(n=>_._fromStorage(n))}function oi(r,t=0,e){return Ft(r,t,e).map(o=>_._fromStorage(o))}function ai(r,t=0){return Xn(r.storage,t).map(n=>_._fromStorage(n))}function si(r,t,e=0){return Qn(r,(a,s)=>t(a,s).storage,e).map(a=>_._fromStorage(a))}function ii(r,t="int32"){return _._fromStorage(Kn(r,t))}function ui(...r){return ro(...r.map(e=>e.storage)).map(e=>_._fromStorage(e))}function ci(r,t,e="raise"){let n=r.map(o=>o.storage);return _._fromStorage(to(n,t,e))}function fi(r,t,e="C"){let n=r instanceof _?r.storage:r;return eo(n,t,e).map(a=>_._fromStorage(a))}function li(r,t=-1){return _._fromStorage(Lt(r.storage,t))}function pi(r,t=-1){return _._fromStorage(qt(r.storage,t))}function yi(r){let t=r.map(e=>e.storage);return _._fromStorage(go(t))}function mi(r,t,e=-1){return _._fromStorage(jt(r.storage,t,e))}function di(r,t,e=-1){return _._fromStorage(Wt(r.storage,t,e))}function gi(r){return _._fromStorage(Ao(r.storage))}function Ai(r){return Gr(r.storage).map(e=>_._fromStorage(e))}function hi(r){return _._fromStorage(ho(r.storage))}function bi(r,t,e){let n=bo(r.storage,t?.storage,e?.storage);return Array.isArray(n)?n.map(o=>_._fromStorage(o)):_._fromStorage(n)}function Si(r,t,e="left"){return _._fromStorage(Zt(r.storage,t.storage,e))}function Di(r,t){return _._fromStorage(So(r.storage,t.storage))}function xi(r,t){let e=Gt(r.storage,t);return typeof e=="number"?e:_._fromStorage(e)}var _,Yr=C(()=>{"use strict";ue();q();W();Be();ke();Ve();Ot();gn();bn();Tn();kn();no();mo();Do();_=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((s,i)=>{let u=s;if(u<0&&(u=this.shape[i]+u),u<0||u>=this.shape[i])throw new Error(`Index ${s} is out of bounds for axis ${i} with size ${this.shape[i]}`);return u}),o=this.dtype,a;x(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,s=O(t);if(!s)throw new Error(`Cannot convert to dtype ${t}`);let i=new s(a),u=this.data;if(x(n)&&!x(t)){let f=u;if(t==="bool")for(let p=0;p<a;p++)i[p]=f[p]!==BigInt(0)?1:0;else for(let p=0;p<a;p++)i[p]=Number(f[p])}else if(!x(n)&&x(t)){let f=u;for(let p=0;p<a;p++)i[p]=BigInt(Math.round(Number(f[p])))}else if(t==="bool"){let f=u;for(let p=0;p<a;p++)i[p]=f[p]!==0?1:0}else if(n==="bool"&&!x(t)){let f=u;for(let p=0;p<a;p++)i[p]=f[p]}else if(!x(n)&&!x(t)){let f=u;for(let p=0;p<a;p++)i[p]=f[p]}else{let f=u;for(let p=0;p<a;p++)i[p]=f[p]}let c=D.fromData(i,o,t);return new r(c)}add(t){let e=typeof t=="number"?t:t._storage,n=ye(this._storage,e);return r._fromStorage(n)}subtract(t){let e=typeof t=="number"?t:t._storage,n=me(this._storage,e);return r._fromStorage(n)}multiply(t){let e=typeof t=="number"?t:t._storage,n=de(this._storage,e);return r._fromStorage(n)}divide(t){let e=typeof t=="number"?t:t._storage,n=ge(this._storage,e);return r._fromStorage(n)}mod(t){let e=typeof t=="number"?t:t._storage,n=vr(this._storage,e);return r._fromStorage(n)}floor_divide(t){let e=typeof t=="number"?t:t._storage,n=pt(this._storage,e);return r._fromStorage(n)}positive(){let t=Se(this._storage);return r._fromStorage(t)}reciprocal(){let t=De(this._storage);return r._fromStorage(t)}sqrt(){let t=An(this._storage);return r._fromStorage(t)}power(t){let e=typeof t=="number"?t:t._storage,n=hn(this._storage,e);return r._fromStorage(n)}absolute(){let t=Ae(this._storage);return r._fromStorage(t)}negative(){let t=he(this._storage);return r._fromStorage(t)}sign(){let t=be(this._storage);return r._fromStorage(t)}sin(){let t=Sn(this._storage);return r._fromStorage(t)}cos(){let t=Dn(this._storage);return r._fromStorage(t)}tan(){let t=xn(this._storage);return r._fromStorage(t)}arcsin(){let t=Nn(this._storage);return r._fromStorage(t)}arccos(){let t=wn(this._storage);return r._fromStorage(t)}arctan(){let t=In(this._storage);return r._fromStorage(t)}arctan2(t){let e=typeof t=="number"?t:t._storage,n=zn(this._storage,e);return r._fromStorage(n)}hypot(t){let e=typeof t=="number"?t:t._storage,n=_n(this._storage,e);return r._fromStorage(n)}degrees(){let t=Bn(this._storage);return r._fromStorage(t)}radians(){let t=En(this._storage);return r._fromStorage(t)}sinh(){let t=Un(this._storage);return r._fromStorage(t)}cosh(){let t=vn(this._storage);return r._fromStorage(t)}tanh(){let t=On(this._storage);return r._fromStorage(t)}arcsinh(){let t=$n(this._storage);return r._fromStorage(t)}arccosh(){let t=Mn(this._storage);return r._fromStorage(t)}arctanh(){let t=Cn(this._storage);return r._fromStorage(t)}greater(t){let e=typeof t=="number"?t:t._storage,n=Ee(this._storage,e);return r._fromStorage(n)}greater_equal(t){let e=typeof t=="number"?t:t._storage,n=Te(this._storage,e);return r._fromStorage(n)}less(t){let e=typeof t=="number"?t:t._storage,n=Ue(this._storage,e);return r._fromStorage(n)}less_equal(t){let e=typeof t=="number"?t:t._storage,n=ve(this._storage,e);return r._fromStorage(n)}equal(t){let e=typeof t=="number"?t:t._storage,n=Oe(this._storage,e);return r._fromStorage(n)}not_equal(t){let e=typeof t=="number"?t:t._storage,n=$e(this._storage,e);return r._fromStorage(n)}isclose(t,e=1e-5,n=1e-8){let o=typeof t=="number"?t:t._storage,a=dt(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=so(this._storage,e);return r._fromStorage(n)}bitwise_or(t){let e=typeof t=="number"?t:t._storage,n=io(this._storage,e);return r._fromStorage(n)}bitwise_xor(t){let e=typeof t=="number"?t:t._storage,n=uo(this._storage,e);return r._fromStorage(n)}bitwise_not(){let t=Rt(this._storage);return r._fromStorage(t)}invert(){let t=co(this._storage);return r._fromStorage(t)}left_shift(t){let e=typeof t=="number"?t:t._storage,n=fo(this._storage,e);return r._fromStorage(n)}right_shift(t){let e=typeof t=="number"?t:t._storage,n=lo(this._storage,e);return r._fromStorage(n)}sum(t,e=!1){let n=gr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}mean(t,e=!1){let n=Or(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}max(t,e=!1){let n=$r(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}min(t,e=!1){let n=Mr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}prod(t,e=!1){let n=At(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}argmin(t){let e=ht(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}argmax(t){let e=bt(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}var(t,e=0,n=!1){let o=St(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}std(t,e=0,n=!1){let o=Pe(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}all(t,e=!1){let n=Dt(this._storage,t,e);return typeof n=="boolean"?n:r._fromStorage(n)}any(t,e=!1){let n=xt(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(wt(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=zt(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}percentile(t,e,n=!1){let o=_t(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}quantile(t,e,n=!1){let o=pr(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}average(t,e){let n=Cr(this._storage,e,t?.storage);return typeof n=="number"?n:r._fromStorage(n)}nansum(t,e=!1){let n=kr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanprod(t,e=!1){let n=Pr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanmean(t,e=!1){let n=Vr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanvar(t,e=0,n=!1){let o=Ar(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}nanstd(t,e=0,n=!1){let o=Bt(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}nanmin(t,e=!1){let n=Fr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanmax(t,e=!1){let n=Rr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanargmin(t){let e=Lr(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}nanargmax(t){let e=qr(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}nancumsum(t){return r._fromStorage(Et(this._storage,t))}nancumprod(t){return r._fromStorage(Tt(this._storage,t))}nanmedian(t,e=!1){let n=jr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}sort(t=-1){return r._fromStorage(Lt(this._storage,t))}argsort(t=-1){return r._fromStorage(qt(this._storage,t))}partition(t,e=-1){return r._fromStorage(jt(this._storage,t,e))}argpartition(t,e=-1){return r._fromStorage(Wt(this._storage,t,e))}nonzero(){return Gr(this._storage).map(e=>r._fromStorage(e))}searchsorted(t,e="left"){return r._fromStorage(Zt(this._storage,t._storage,e))}reshape(...t){let e=t.length===1&&Array.isArray(t[0])?t[0]:t,n=G(this._storage,e),a=n.data===this.data?this._base??this:void 0;return r._fromStorage(n,a)}flatten(){let t=Wr(this._storage);return r._fromStorage(t)}ravel(){let t=br(this._storage),n=t.data===this.data?this._base??this:void 0;return r._fromStorage(t,n)}transpose(t){let e=Sr(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}squeeze(t){let e=Fe(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}expand_dims(t){let e=hr(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}swapaxes(t,e){let n=Re(this._storage,t,e),o=this._base??this;return r._fromStorage(n,o)}moveaxis(t,e){let n=Ut(this._storage,t,e),o=this._base??this;return r._fromStorage(n,o)}repeat(t,e){let n=Je(this._storage,t,e);return r._fromStorage(n)}take(t,e){let n=Vn(this._storage,t,e);return r._fromStorage(n)}put(t,e){let n=e instanceof r?e._storage:e;Fn(this._storage,t,n)}matmul(t){let e=ir(this._storage,t._storage);return r._fromStorage(e)}dot(t){let e=Mt(this._storage,t._storage);return typeof e=="number"||typeof e=="bigint"?e:r._fromStorage(e)}trace(){return fn(this._storage)}inner(t){let e=ln(this._storage,t._storage);return typeof e=="number"||typeof e=="bigint"?e:r._fromStorage(e)}outer(t){let e=Ct(this._storage,t._storage);return r._fromStorage(e)}tensordot(t,e=2){let n=pn(this._storage,t._storage,e);return typeof n=="number"||typeof n=="bigint"?n:r._fromStorage(n)}cbrt(){let t=xe(this._storage);return r._fromStorage(t)}fabs(){let t=Ne(this._storage);return r._fromStorage(t)}divmod(t){let e=typeof t=="number"?t:t._storage,[n,o]=we(this._storage,e);return[r._fromStorage(n),r._fromStorage(o)]}square(){let t=Ie(this._storage);return r._fromStorage(t)}remainder(t){let e=typeof t=="number"?t:t._storage,n=ze(this._storage,e);return r._fromStorage(n)}heaviside(t){let e=typeof t=="number"?t:t._storage,n=_e(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((u,c)=>{let f=se(u);return ie(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 u=0;u<e.length;u++){let c=e[u],f=this._storage.strides[u];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 s=D.fromData(this._storage.data,n,this._storage.dtype,o,a),i=this._base??this;return new r(s,i)}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 s=[];for(let i=0;i<t[a];i++)o[a]=i,s.push(n(o,a+1));return s};return n(new Array(e),0)}}});function re(){let r=new ArrayBuffer(2);return new DataView(r).setInt16(0,256,!0),new Int16Array(r)[0]===256}function wi(r){if(r.startsWith("[")||r.startsWith("("))throw new Q(`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 Ni)throw new Q(`Unsupported dtype: ${Ni[n]} (${r}). Use the 'force' parameter to skip arrays with unsupported dtypes.`);let o=Yu[e];if(!o)throw new Q(`Unknown or unsupported dtype descriptor: ${r}. Supported types: ${Jr.join(", ")}. Use the 'force' parameter to skip arrays with unsupported dtypes.`);let a=re(),s=t==="<"||t==="|"||t==="="&&a,i=t===">"||t==="="&&!a,u=parseInt(e.slice(1),10),c=u>1&&(i&&a||s&&!a);return{dtype:o,needsByteSwap:c,itemsize:u}}var wr,Jr,Yu,Ir,Ni,Q,Z,zr=C(()=>{"use strict";wr=new Uint8Array([147,78,85,77,80,89]),Jr=["float64","float32","int64","int32","int16","int8","uint64","uint32","uint16","uint8","bool"];Yu={f8:"float64",f4:"float32",i8:"int64",i4:"int32",i2:"int16",i1:"int8",u8:"uint64",u4:"uint32",u2:"uint16",u1:"uint8",b1:"bool"},Ir={float64:"<f8",float32:"<f4",int64:"<i8",int32:"<i4",int16:"<i2",int8:"|i1",uint64:"<u8",uint32:"<u4",uint16:"<u2",uint8:"|u1",bool:"|b1"},Ni={c:"complex numbers",S:"byte strings",U:"Unicode strings",O:"Python objects",V:"structured arrays (void)",M:"datetime64",m:"timedelta64"};Q=class extends Error{constructor(t){super(t),this.name="UnsupportedDTypeError"}},Z=class extends Error{constructor(t){super(t),this.name="InvalidNpyError"}}});function or(r){let t=r instanceof ArrayBuffer?new Uint8Array(r):r,e=Xr(t);return Qr(t,e)}function Xr(r){if(r.length<10)throw new Z("File too small to be a valid NPY file");for(let c=0;c<wr.length;c++)if(r[c]!==wr[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 s=r.slice(o,a),i=new TextDecoder("utf-8").decode(s).trim(),u=Ju(i);return{version:{major:t,minor:e},header:u,dataOffset:a}}function Qr(r,t){let{header:e,dataOffset:n}=t,{dtype:o,needsByteSwap:a,itemsize:s}=wi(e.descr),i=e.shape.reduce((d,g)=>d*g,1),u=i*s,c=r.length-n;if(c<u)throw new Z(`File truncated: expected ${u} bytes of data, got ${c}`);let f=new ArrayBuffer(u);new Uint8Array(f).set(r.subarray(n,n+u));let l=Xu(f,o,i,a,s),y=e.shape,m;if(e.fortran_order&&y.length>1){let d=[...y].reverse(),g=D.fromData(l,d,o);m=Qu(g,d),y=e.shape}else m=D.fromData(l,[...y],o);return new _(m)}function Ju(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",s=n[1].trim(),i;return s===""?i=[]:i=s.split(",").map(u=>u.trim()).filter(u=>u!=="").map(u=>{let c=parseInt(u,10);if(isNaN(c))throw new Z(`Invalid shape value: ${u}`);return c}),{descr:o,fortran_order:a,shape:i}}function Xu(r,t,e,n,o){let a=O(t);if(!a)throw new Z(`Cannot create array for dtype: ${t}`);if(!n)return new a(r,0,e);let s=new Uint8Array(r),i=new Uint8Array(r.byteLength);for(let u=0;u<e;u++){let c=u*o;for(let f=0;f<o;f++)i[c+f]=s[c+o-1-f]}return new a(i.buffer,0,e)}function Qu(r,t){let e=t.length,n=r.size,o=r.dtype,a=O(o);if(!a)throw new Z(`Cannot create array for dtype: ${o}`);let s=new a(n),i=[...t].reverse(),u=Ii(t),c=Ii(i),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=u[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];x(o),s[y]=r.iget(p)}return D.fromData(s,i,o)}function Ii(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 Kr=C(()=>{"use strict";Yr();W();q();zr()});function tr(r){let t=r.shape,e=r.dtype,n=Ir[e],o=t.length===0?"()":t.length===1?`(${t[0]},)`:`(${t.join(", ")})`,a=`{'descr': '${n}', 'fortran_order': False, 'shape': ${o}, }`,s=12,u=(64-(s+a.length+1)%64)%64;a=a+" ".repeat(u)+`
|
|
2
|
-
`;let c=new TextEncoder().encode(a),f=c.length,p=r.size,l=fe(e),y=p*l,m=s+f+y,d=new Uint8Array(m);d.set(wr,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,s);let g=s+f;return Ku(r,d.subarray(g),l),d}function Ku(r,t,e){let n=r.dtype,o=r.size,a=re(),s=x(n),i=r._storage;if(i.isCContiguous&&i.offset===0&&a){let c=i.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=i.iget(f),l=f*e;s?rc(c,l,p,n==="uint64"):tc(c,l,p,n)}}}function rc(r,t,e,n){n?r.setBigUint64(t,e,!0):r.setBigInt64(t,e,!0)}function tc(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 rt=C(()=>{"use strict";q();zr()});function te(r){let t=4294967295;for(let e=0;e<r.length;e++)t=ec[(t^r[e])&255]^t>>>8;return(t^4294967295)>>>0}var ec,ee=C(()=>{"use strict";ec=(()=>{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 zi(r){let t=Bi(r),e=new Map;for(let n of t){let o=await nc(n);e.set(n.name,o)}return e}function _i(r){let t=Bi(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 Bi(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),s=e.getUint16(o+10,!0),i=[],u=a;for(let c=0;c<s&&e.getUint32(u,!0)===33639248;c++){let p=e.getUint16(u+10,!0),l=e.getUint32(u+16,!0),y=e.getUint32(u+20,!0),m=e.getUint32(u+24,!0),d=e.getUint16(u+28,!0),g=e.getUint16(u+30,!0),h=e.getUint16(u+32,!0),A=e.getUint32(u+42,!0),b=t.slice(u+46,u+46+d),S=new TextDecoder("utf-8").decode(b);i.push({name:S,compressionMethod:p,crc32:l,compressedSize:y,uncompressedSize:m,localHeaderOffset:A}),u=u+46+d+g+h}for(let c of i){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 nc(r){if(r.compressionMethod===0)return r.compressedData;if(r.compressionMethod===8)return await oc(r.compressedData);throw new Error(`Unsupported compression method: ${r.compressionMethod}`)}async function oc(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 s=a.reduce((c,f)=>c+f.length,0),i=new Uint8Array(s),u=0;for(let c of a)i.set(c,u),u+=c.length;return i}var Ei=C(()=>{"use strict";ee()});var Ui={};ct(Ui,{loadNpz:()=>tt,loadNpzSync:()=>et,parseNpz:()=>cr,parseNpzSync:()=>Br});async function cr(r,t={}){let e=t.force??!1,n=await zi(r);return Ti(n,e)}function Br(r,t={}){let e=t.force??!1,n=_i(r);return Ti(n,e)}function Ti(r,t){let e=new Map,n=[],o=new Map;for(let[a,s]of r){if(!a.endsWith(".npy"))continue;let i=a.slice(0,-4);try{let u=or(s);e.set(i,u)}catch(u){if(u instanceof Q&&t)n.push(i),o.set(i,u.message);else throw u}}return{arrays:e,skipped:n,errors:o}}async function tt(r,t={}){let e=await cr(r,t);return Object.fromEntries(e.arrays)}function et(r,t={}){let e=Br(r,t);return Object.fromEntries(e.arrays)}var nt=C(()=>{"use strict";Kr();zr();Ei()});async function vi(r,t={}){let e=t.compress??!1,n=[];for(let[l,y]of r){let m=te(y),d,g;e?(d=await sc(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 i=o+a+22,u=new Uint8Array(i),c=new DataView(u.buffer),f=0;for(let l of n)l.offset=f,f=$i(u,c,f,l);let p=f;for(let l of n)f=Mi(u,c,f,l);return Ci(c,f,n.length,a,p),u}function Oi(r){let t=[];for(let[f,p]of r){let l=te(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,s=new Uint8Array(a),i=new DataView(s.buffer),u=0;for(let f of t)f.offset=u,u=$i(s,i,u,f);let c=u;for(let f of t)u=Mi(s,i,u,f);return Ci(i,u,t.length,n,c),s}function $i(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 Mi(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 Ci(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 sc(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 s=a.reduce((c,f)=>c+f.length,0),i=new Uint8Array(s),u=0;for(let c of a)i.set(c,u),u+=c.length;return i}var ki=C(()=>{"use strict";ee()});var Vi={};ct(Vi,{serializeNpz:()=>mr,serializeNpzSync:()=>ot});async function mr(r,t={}){let e=Pi(r);return vi(e,{compress:t.compress??!1})}function ot(r){let t=Pi(r);return Oi(t)}function Pi(r){let t=new Map;if(Array.isArray(r)){for(let n=0;n<r.length;n++){let o=r[n],a=tr(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=tr(o),s=n.endsWith(".npy")?n:`${n}.npy`;t.set(s,a)}return t}var at=C(()=>{"use strict";rt();ki()});var Nc={};ct(Nc,{DTYPE_TO_DESCR:()=>Ir,InvalidNpyError:()=>Z,NDArray:()=>_,SUPPORTED_DTYPES:()=>Jr,UnsupportedDTypeError:()=>Q,__version__:()=>ic,absolute:()=>Yo,append:()=>ts,arange:()=>No,arccos:()=>ma,arccosh:()=>za,arcsin:()=>ya,arcsinh:()=>Ia,arctan:()=>da,arctan2:()=>ga,arctanh:()=>_a,argpartition:()=>di,argsort:()=>pi,array:()=>P,array_equal:()=>ls,array_equiv:()=>ps,array_split:()=>$a,asanyarray:()=>Oo,asarray:()=>Nr,ascontiguousarray:()=>$o,asfortranarray:()=>Mo,atleast_1d:()=>Ha,atleast_2d:()=>Ya,atleast_3d:()=>Ja,average:()=>bs,bitwise_and:()=>Ps,bitwise_not:()=>Rs,bitwise_or:()=>Vs,bitwise_xor:()=>Fs,broadcast_arrays:()=>ss,broadcast_shapes:()=>is,broadcast_to:()=>as,cbrt:()=>vs,choose:()=>fs,column_stack:()=>Qa,compress:()=>Xs,concatenate:()=>ur,copy:()=>Bo,cos:()=>la,cosh:()=>Na,count_nonzero:()=>xi,cumprod:()=>ms,cumsum:()=>ys,deg2rad:()=>Sa,degrees:()=>ha,delete:()=>es,diag:()=>Qt,diag_indices:()=>ri,diag_indices_from:()=>ti,diagflat:()=>Co,diagonal:()=>oa,divmod:()=>$s,dot:()=>ea,dsplit:()=>Xa,dstack:()=>va,einsum:()=>Gs,empty:()=>Jt,empty_like:()=>Uo,expand_dims:()=>La,extract:()=>Di,eye:()=>Yt,fabs:()=>Os,flatnonzero:()=>hi,flip:()=>Hr,fliplr:()=>qa,flipud:()=>ja,floor_divide:()=>Ko,frombuffer:()=>qo,fromfile:()=>jo,fromfunction:()=>ko,fromiter:()=>Wo,fromregex:()=>Dc,fromregexSync:()=>xc,fromstring:()=>Zo,full:()=>Xt,full_like:()=>vo,genfromtxt:()=>bc,genfromtxtSync:()=>Sc,geomspace:()=>zo,heaviside:()=>ks,hsplit:()=>Ca,hstack:()=>Ua,hypot:()=>Aa,identity:()=>_o,indices:()=>ii,inner:()=>ia,insert:()=>ns,invert:()=>Ls,ix_:()=>ui,kron:()=>aa,left_shift:()=>qs,lexsort:()=>yi,linspace:()=>wo,load:()=>cc,loadNpy:()=>Ri,loadNpySync:()=>Li,loadNpz:()=>tt,loadNpzFile:()=>Wi,loadNpzFileSync:()=>Zi,loadNpzSync:()=>et,loadSync:()=>fc,loadtxt:()=>dc,loadtxtSync:()=>gc,logspace:()=>Io,mask_indices:()=>si,median:()=>gs,meshgrid:()=>Po,mod:()=>Qo,moveaxis:()=>Ea,nanargmax:()=>Bs,nanargmin:()=>_s,nancumprod:()=>Ts,nancumsum:()=>Es,nanmax:()=>zs,nanmean:()=>xs,nanmedian:()=>Us,nanmin:()=>Is,nanprod:()=>Ds,nanstd:()=>ws,nansum:()=>Ss,nanvar:()=>Ns,negative:()=>Jo,nonzero:()=>Ai,ones:()=>Ht,ones_like:()=>To,outer:()=>ua,packbits:()=>Ws,pad:()=>os,parseNpy:()=>or,parseNpyData:()=>Qr,parseNpyHeader:()=>Xr,parseNpz:()=>cr,parseNpzSync:()=>Br,parseTxt:()=>fr,partition:()=>mi,percentile:()=>As,place:()=>Ks,positive:()=>ra,power:()=>Ho,ptp:()=>ds,put:()=>cs,put_along_axis:()=>Ys,putmask:()=>Js,quantile:()=>hs,rad2deg:()=>Da,radians:()=>ba,ravel:()=>Va,ravel_multi_index:()=>ci,reciprocal:()=>ta,remainder:()=>Cs,repeat:()=>Pa,reshape:()=>Fa,resize:()=>rs,right_shift:()=>js,roll:()=>Za,rollaxis:()=>Ga,rot90:()=>Wa,row_stack:()=>Ka,save:()=>lc,saveNpy:()=>qi,saveNpySync:()=>ji,saveNpz:()=>ae,saveNpzSync:()=>uc,saveSync:()=>pc,savetxt:()=>Ac,savetxtSync:()=>hc,savez:()=>yc,savez_compressed:()=>mc,searchsorted:()=>Si,select:()=>Qs,serializeNpy:()=>tr,serializeNpz:()=>mr,serializeNpzSync:()=>ot,serializeTxt:()=>dr,sign:()=>Xo,sin:()=>fa,sinh:()=>xa,sort:()=>li,sort_complex:()=>gi,split:()=>Oa,sqrt:()=>Go,square:()=>Ms,squeeze:()=>Ra,stack:()=>Ta,swapaxes:()=>Ba,take:()=>us,take_along_axis:()=>Hs,tan:()=>pa,tanh:()=>wa,tensordot:()=>ca,tile:()=>ka,trace:()=>na,transpose:()=>sa,tri:()=>Vo,tril:()=>Fo,tril_indices:()=>ei,tril_indices_from:()=>ni,triu:()=>Ro,triu_indices:()=>oi,triu_indices_from:()=>ai,unpackbits:()=>Zs,unravel_index:()=>fi,vander:()=>Lo,vsplit:()=>Ma,vstack:()=>Kt,where:()=>bi,zeros:()=>X,zeros_like:()=>Eo});module.exports=ft(Nc);var K=require("node:fs"),rr=require("node:fs/promises");Kr();rt();nt();at();Yr();function fr(r,t={}){let{delimiter:e,comments:n="#",skiprows:o=0,usecols:a,max_rows:s,dtype:i="float64",missing_values:u,filling_values:c}=t,f=r.split(/\r?\n/);if(o>0&&(f=f.slice(o)),f=f.filter(d=>{let g=d.trim();return!(g===""||n&&g.startsWith(n))}),s!==void 0&&s>0&&(f=f.slice(0,s)),f.length===0)return P([],i);let p=[],l=new Set(u?Array.isArray(u)?u:[u]:[]),y=c!==void 0?c:i.includes("int")||i==="bool"?0:NaN;for(let d of f){let g;e===void 0?g=d.trim().split(/\s+/):g=d.split(e),a!==void 0&&(g=(Array.isArray(a)?a:[a]).map(b=>(b<0&&(b=g.length+b),g[b]??"")));let h=g.map(A=>{let b=A.trim();if(l.has(b)||b==="")return y;let S=parseFloat(b);return isNaN(S)?y:S});p.push(h)}let m=p[0]?.length??0;for(let d=1;d<p.length;d++)if(p[d].length!==m)throw new Error(`Inconsistent number of columns: row 0 has ${m} columns, row ${d} has ${p[d].length} columns`);return m===1?P(p.map(d=>d[0]),i):P(p,i)}function Er(r,t={}){let e={...t,missing_values:t.missing_values??["","nan","NaN","NA","N/A","-"],filling_values:t.filling_values??NaN};return fr(r,e)}function Tr(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 s=a.slice(1).map(i=>{let u=parseFloat(i);return isNaN(u)?0:u});o.push(s)}return o.length===0?P([],e):o[0].length===1?P(o.map(s=>s[0]),e):P(o,e)}function Fi(r,t){let e=typeof r=="bigint"?Number(r):r,n=t.match(/^%([+-]?)(\d*)(?:\.(\d+))?([dfeEgGs])$/);if(!n)return String(e);let[,o,a,s,i]=n,u=s!==void 0?parseInt(s,10):void 0,c;switch(i){case"d":c=Math.round(e).toString();break;case"f":c=e.toFixed(u??6);break;case"e":c=e.toExponential(u??6).replace(/e([+-])(\d)$/,"e$10$2");break;case"E":c=e.toExponential(u??6).toUpperCase().replace(/E([+-])(\d)$/,"E$10$2");break;case"g":case"G":{let f=u??6,p=Math.floor(Math.log10(Math.abs(e)));p>=-4&&p<f?(c=e.toPrecision(f),c.includes(".")&&(c=c.replace(/\.?0+$/,""))):c=e.toExponential(f-1),i==="G"&&(c=c.toUpperCase());break}case"s":c=String(e);break;default:c=String(e)}if(a){let f=parseInt(a,10);if(c.length<f){let p=" ".repeat(f-c.length);o==="-"?c=c+p:c=p+c}}return o==="+"&&e>=0&&!c.startsWith("-")&&(c="+"+c),c}function dr(r,t={}){let{fmt:e="%.18e",delimiter:n=" ",newline:o=`
|
|
3
|
-
`,header:a,footer:
|
|
1
|
+
"use strict";var dt=Object.defineProperty;var wc=Object.getOwnPropertyDescriptor;var zc=Object.getOwnPropertyNames;var Ic=Object.prototype.hasOwnProperty;var k=(r,t)=>()=>(r&&(t=r(r=0)),t);var gt=(r,t)=>{for(var e in t)dt(r,e,{get:t[e],enumerable:!0})},_c=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of zc(t))!Ic.call(r,o)&&o!==e&&dt(r,o,{get:()=>t[o],enumerable:!(n=wc(t,o))||n.enumerable});return r};var At=r=>_c(dt({},"__esModule",{value:!0}),r);function _e(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 Be(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 ve=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 Oe(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 Te(r){return r==="int64"||r==="int32"||r==="int16"||r==="int8"||r==="uint64"||r==="uint32"||r==="uint16"||r==="uint8"}function Ee(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(Ee(r)||Ee(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 F,j=k(()=>{"use strict";F="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=F){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=F){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 xr(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 Bc(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 Vr(r,t){let e=Bc(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=xr(r.shape,t.shape),a=Vr(r,o),i=Vr(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 ar(r,t,e){let n=xr(r.shape,t.shape),o=Vr(r,n),a=Vr(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 cr=k(()=>{"use strict";R();j()});function ht(r,t){return r.isCContiguous&&t.isCContiguous&&r.shape.length===t.shape.length&&r.shape.every((e,n)=>e===t.shape[n])}function Ue(r,t){return typeof t=="number"?Tc(r,t):ht(r,t)?vc(r,t):L(r,t,(e,n)=>e+n,"add")}function vc(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 $e(r,t){return typeof t=="number"?Uc(r,t):ht(r,t)?Ec(r,t):L(r,t,(e,n)=>e-n,"subtract")}function Ec(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 Me(r,t){return typeof t=="number"?$c(r,t):ht(r,t)?Oc(r,t):L(r,t,(e,n)=>e*n,"multiply")}function Oc(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 ke(r,t){if(typeof t=="number")return Mc(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:dr(r,"float64"),c=n?t:dr(t,"float64");return L(s,c,(l,m)=>l/m,"divide")}if(o||a){let s=o?r:dr(r,"float32"),c=a?t:dr(t,"float32");return L(s,c,(l,m)=>l/m,"divide")}let i=dr(r,"float64"),u=dr(t,"float64");return L(i,u,(s,c)=>s/c,"divide")}function dr(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 Tc(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 Uc(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 $c(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 Mc(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 Ce(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 Ve(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 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++){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 Pr(r,t){return typeof t=="number"?kc(r,t):L(r,t,(e,n)=>(e%n+n)%n,"mod")}function kc(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 bt(r,t){return typeof t=="number"?Cc(r,t):L(r,t,(e,n)=>Math.floor(e/n),"floor_divide")}function Cc(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 qe(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 Fe(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 Re(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 je(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 Le(r,t){let e=bt(r,t),n=Pr(r,t);return[e,n]}function We(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 Ze(r,t){return Pr(r,t)}function Ge(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 He=k(()=>{"use strict";R();j();cr()});function sr(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 Pc(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=Pc(r.shape,r.strides,t);return N.fromData(r.data,Array.from(t),r.dtype,e,r.offset)}function St(...r){let t=sr(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 Nt=k(()=>{"use strict";R()});function Ye(r,t){return typeof t=="number"?qc(r,t):ar(r,t,(e,n)=>e>n)}function Je(r,t){return typeof t=="number"?Fc(r,t):ar(r,t,(e,n)=>e>=n)}function Qe(r,t){return typeof t=="number"?Rc(r,t):ar(r,t,(e,n)=>e<n)}function Xe(r,t){return typeof t=="number"?jc(r,t):ar(r,t,(e,n)=>e<=n)}function Ke(r,t){return typeof t=="number"?Lc(r,t):ar(r,t,(e,n)=>e===n)}function rn(r,t){return typeof t=="number"?Wc(r,t):ar(r,t,(e,n)=>e!==n)}function Dt(r,t,e=1e-5,n=1e-8){return typeof t=="number"?Zc(r,t,e,n):ar(r,t,(o,a)=>{let i=Math.abs(o-a),u=n+e*Math.abs(a);return i<=u})}function tn(r,t,e=1e-5,n=1e-8){let o=Dt(r,t,e,n),a=o.data;for(let i=0;i<o.size;i++)if(a[i]===0)return!1;return!0}function en(r,t){let e=[Array.from(r.shape),Array.from(t.shape)],n=sr(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 qc(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 Fc(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 Rc(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 jc(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 Lc(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 Wc(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 Zc(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 nn=k(()=>{"use strict";R();j();cr();Nt()});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 xt=k(()=>{"use strict"});function wr(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 wr(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 qr(r,t,e=!1){let n=r.dtype,o=r.shape;if(t===void 0)return wr(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=wr(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 Fr(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 Fr(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 wt(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 wt(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 Rr(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 Rr(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 zt(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 zt(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 It(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 It(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 _t(r,t,e=0,n=!1){let o=r.shape,a=o.length,i=r.size,u=r.data,s=qr(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 on(r,t,e=0,n=!1){let o=_t(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 vt(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 vt(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 Et(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 Ot(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 Tt(r,t,e=!1){let n=Fr(r,t,e),o=Rr(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 Ut(r,t,e=!1){return gr(r,.5,t,e)}function $t(r,t,e,n=!1){return gr(r,t/100,e,n)}function gr(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 gr(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 jr(r,t,e,n=!1){let o=r.shape,a=o.length,i=r.data;if(e===void 0)return qr(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 jr(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 Lr(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 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=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 Wr(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 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;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 Zr(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 Zr(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 zr(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 zr(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 Mt(r,t,e=0,n=!1){let o=zr(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 Gr(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 Gr(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 Hr(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 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=-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 Yr(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 Yr(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 Jr(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 Jr(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 kt(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 Ct(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 Qr(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 Qr(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 an=k(()=>{"use strict";R();j();xt()});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 Xr(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 Ar(r){let t=r.size,e=r.dtype;if(r.isCContiguous){let n=r.data;return N.fromData(n,[t],e,[1],0)}return Xr(r)}function _r(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 sn(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 Ir(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 un(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 _r(r,s)}function lr(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];Yc(p,l,i,m,a,f,o),f+=y}return N.fromData(l,i,o)}function Yc(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 cn(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=>Ir(u,a));return lr(i,a)}function ln(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 lr(t,0)}function Pt(r){if(r.length===0)throw new Error("need at least one array to stack");return r.every(e=>e.ndim===1)?lr(r,0):lr(r,1)}function fn(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(e=>e.ndim===1?W(Ir(W(e,[1,e.shape[0]]),2),[1,e.shape[0],1]):e.ndim===2?Ir(e,2):e);return lr(t,2)}function mn(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 pn(r,u,a)}function Br(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 pn(r,u,a)}function pn(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 yn(r,t){if(r.ndim<2)throw new Error("vsplit only works on arrays of 2 or more dimensions");return Br(r,t,0)}function dn(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 Br(r,t,e)}function gn(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 An(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 hn(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 bn(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 Sn(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=Xr(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 Nn(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 Dn(r,t){if(r.ndim<3)throw new Error("dsplit only works on arrays of 3 or more dimensions");return Br(r,t,2)}function xn(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 Pt(t)}function wn(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 zn(r){return r.map(t=>t.ndim===0?W(t,[1]):t)}function In(r){return r.map(t=>t.ndim===0?W(t,[1,1]):t.ndim===1?W(t,[1,t.shape[0]]):t)}function _n(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 qt=k(()=>{"use strict";R();j()});function Jc(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 Rt(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 Jc("row-major",g,b,e,a,n,1,s,h,c,A,0,S.data,a),S}function On(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 vn(r,t){return _r(r,t)}function Tn(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 Rt(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 jt(r,t){let e=r.ndim===1?r:Ar(r),n=t.ndim===1?t:Ar(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 Un(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 $n(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 Mn(r,...t){let e=r.indexOf("->"),n,o;e===-1?(n=r,o=Qc(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=vn(b);return J(B,h)}if(A===w&&D===_&&S===x&&c.length===1&&c[0]===S){let B=vn(h);return J(b,B)}}if(d.length===1&&g.length===1&&d===g&&o.length===0&&b.ndim===1&&h.ndim===1)return Ft(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 jt(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 Ft(t,a,c,i)}let l=Array.from(o).map(d=>i.get(d));if(l.length===0)return Ft(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=Xc(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 Qc(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 Ft(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 Xc(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 kn(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 Cn(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),q=B(1),Y=l===3?B(2):0;if(m===0)b.set(D,v*q-E*M);else{let Z=E*Y-$*q,Dr=$*M-v*Y,Sc=v*q-E*M,yt=(Nc,Dc)=>{let xc=[...D.slice(0,d),Nc,...D.slice(d)];b.set(xc,Dc)};yt(0,Z),yt(1,Dr),yt(2,Sc)}}return b}function hr(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:Ar(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 hr(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 fr(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}=ir(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}=ir(r);a=Number(i.get(0))}else if(t===-2){let{s:i}=ir(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 Vn(r,t=null,e=null,n=!1){if(t===null)return e===null?hr(r,2,null,n):typeof e=="number"?hr(r,2,e,n):fr(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 fr(r,t,n)}if(r.ndim===2&&e===null&&(t==="fro"||t==="nuc"))return fr(r,t,n);if(typeof t!="number"&&t!==null)throw new Error(`norm: ord '${t}' not valid for vector norm`);return hr(r,t??2,e,n)}function Lt(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 Pn(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 ir(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}=Wt(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 Wt(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 qn(r,t=!0,e=!0){let n=ir(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 Fn(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}=Zt(r),u=a.data,s=i;for(let c=0;c<n;c++)s*=u[c*n+c];return s}function Zt(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 Kr(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}=Zt(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 En(r,t){let[e]=r.shape,n=e,{lu:o,piv:a}=Zt(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 Rn(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 En(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=En(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 jn(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}=ir(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 Ln(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}=ir(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=fr(r,t),a=Kr(r),i=fr(a,t);return o*i}function Wn(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}=ir(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 Zn(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=Kr(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 Gn(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}=ir(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 Gt(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}=Wt(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}=Kc(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 Kc(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=Lt(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 Ht(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}=Wt(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 Hn(r){let{w:t}=Gt(r);return t}function Yn(r,t="L"){let{w:e}=Ht(r,t);return e}var Jn=k(()=>{"use strict";R();j();qt()});function Qn(r){return V(r,Math.sqrt,!1)}function Xn(r,t){return typeof t=="number"?tl(r,t):L(r,t,Math.pow,"power")}function tl(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 Kn(r){return V(r,Math.exp,!1)}function ro(r){return V(r,t=>Math.pow(2,t),!1)}function to(r){return V(r,Math.expm1,!1)}function eo(r){return V(r,Math.log,!1)}function no(r){return V(r,Math.log2,!1)}function oo(r){return V(r,Math.log10,!1)}function ao(r){return V(r,Math.log1p,!1)}function so(r,t){return typeof t=="number"?nl(r,t):el(r,t)}function el(r,t){let e=xr(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 nl(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 io(r,t){return typeof t=="number"?al(r,t):ol(r,t)}function ol(r,t){let e=xr(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 al(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 uo=k(()=>{"use strict";R();cr();j()});function co(r){return V(r,Math.sin,!1)}function lo(r){return V(r,Math.cos,!1)}function fo(r){return V(r,Math.tan,!1)}function mo(r){return V(r,Math.asin,!1)}function po(r){return V(r,Math.acos,!1)}function yo(r){return V(r,Math.atan,!1)}function go(r,t){return typeof t=="number"?ul(r,t):il(r,t)}function il(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 ul(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 Ao(r,t){return typeof t=="number"?ll(r,t):cl(r,t)}function cl(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 ll(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 ho(r){let t=180/Math.PI;return V(r,e=>e*t,!1)}function bo(r){let t=Math.PI/180;return V(r,e=>e*t,!1)}var So=k(()=>{"use strict";R();cr();j()});function No(r){return V(r,Math.sinh,!1)}function Do(r){return V(r,Math.cosh,!1)}function xo(r){return V(r,Math.tanh,!1)}function wo(r){return V(r,Math.asinh,!1)}function zo(r){return V(r,Math.acosh,!1)}function Io(r){return V(r,Math.atanh,!1)}var _o=k(()=>{"use strict";cr()});function Yt(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=sr([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 Bo(r){if(r.length===0)return[];if(r.length===1)return[r[0]];let t=r.map(n=>Array.from(n.shape)),e=sr(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 vo(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 Eo(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 Oo(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=sr(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 To(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 Uo(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 $o(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 Mo(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 ko(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 Co(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=sr(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 Vo(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 Jt(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 Po(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 Jt(n,e)}function Qt(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 qo(r,t=0){let e=r.shape;if(e.length!==2)throw new Error("array must be 2-D");return Qt(e[0],t,e[1])}function Xt(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 Fo(r,t=0){let e=r.shape;if(e.length!==2)throw new Error("array must be 2-D");return Xt(e[0],t,e[1])}function Ro(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 jo(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 Lo(...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 Wo(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 Zo(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 Go=k(()=>{"use strict";R();j();Nt()});function Q(r,t){if(!Te(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 vr(r,t){return r.isCContiguous&&t.isCContiguous&&r.shape.length===t.shape.length&&r.shape.every((e,n)=>e===t.shape[n])}function Jo(r,t){return Q(r.dtype,"bitwise_and"),typeof t=="number"?dl(r,t):(Q(t.dtype,"bitwise_and"),vr(r,t)?yl(r,t):L(r,t,(e,n)=>e&n,"bitwise_and"))}function yl(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 dl(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 Qo(r,t){return Q(r.dtype,"bitwise_or"),typeof t=="number"?Al(r,t):(Q(t.dtype,"bitwise_or"),vr(r,t)?gl(r,t):L(r,t,(e,n)=>e|n,"bitwise_or"))}function gl(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 Al(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 Xo(r,t){return Q(r.dtype,"bitwise_xor"),typeof t=="number"?bl(r,t):(Q(t.dtype,"bitwise_xor"),vr(r,t)?hl(r,t):L(r,t,(e,n)=>e^n,"bitwise_xor"))}function hl(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 bl(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 Kt(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 Ko(r){return Kt(r)}function ra(r,t){if(Q(r.dtype,"left_shift"),typeof t=="number")return Ho(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 Ho(r,e)}return vr(r,t)?Sl(r,t):L(r,t,(e,n)=>e<<n,"left_shift")}function Sl(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 Ho(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 ta(r,t){if(Q(r.dtype,"right_shift"),typeof t=="number")return Yo(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 Yo(r,e)}return vr(r,t)?Nl(r,t):L(r,t,(e,n)=>e>>n,"right_shift")}function Nl(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 Yo(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 ea(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=rt(n),d=rt(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 q=M<t-1?l.slice(M+1).reduce((Z,Dr)=>Z*Dr,1):1,Y=Math.floor(v/q);v%=q,B+=Y*y[M]}B+=_*y[t];let E=b;for(let M=t+1;M<o;M++){let q=M<o-1?m.slice(M-t).reduce((Z,Dr)=>Z*Dr,1):1,Y=Math.floor(E/q);E%=q,B+=Y*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 na(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=rt(o),g=rt(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((q,Y)=>q*Y,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((q,Y)=>q*Y,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 rt(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 oa=k(()=>{"use strict";R();j();cr()});function re(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 te(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 aa(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 xl(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 wl(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 zl(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 Il(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 ee(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])}wl(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]))}xl(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 ne(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})}Il(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})}zl(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 sa(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 tt(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 ia(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 ua(r,t,e){if(t===void 0&&e===void 0)return tt(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 q=0;q<i;q++){let Y=Math.floor(v/x[q]);v=v%x[q],E+=Y*A[q],$+=Y*S[q],M+=Y*D[q]}d[E]?y[B]=g[$]:y[B]=b[M]}return p}function oe(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 ca(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 ae(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 ae(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 la=k(()=>{"use strict";R();j();xt()});function fa(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 se(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]=fa(m*c)/c}return u}function ie(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 ue(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 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.floor(Number(n[s]));return i}function le(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]=fa(Number(n[s]));return i}function fe(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 ma=k(()=>{"use strict";R()});function nr(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 pa(r,t){return me(r,t)}function ya(r,t){let e=r.dtype,n=nr(r),o=nr(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 me(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 da(r,t){let e=r.dtype,n=nr(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 ga(r,t){let e=r.dtype,n=nr(r),o=nr(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 Aa(r,t){let e=r.dtype,n=nr(r),o=nr(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 ha=k(()=>{"use strict";R()});function pe(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=El(i,a);return i}function El(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 ba(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 Sa(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(Ol(r,a[s],i[s]));return u.length===1?u[0]:u}function Ol(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 Na(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 Da=k(()=>{"use strict";R();j()});function K(r,t=F){let e=N.zeros(r,t);return new I(e)}function ye(r,t=F){let e=N.ones(r,t);return new I(e)}function Ul(r){let t=[],e=r;for(;Array.isArray(e);)t.push(e.length),e=e[0];return t}function xa(r){return typeof r=="bigint"?!0:Array.isArray(r)?r.some(t=>xa(t)):!1}function $l(r){let t=[];function e(n){Array.isArray(n)?n.forEach(o=>e(o)):t.push(n)}return e(r),t}function P(r,t){if(r instanceof I)return!t||r.dtype===t?r.copy():r.astype(t);let e=xa(r),n=Ul(r),o=n.reduce((l,m)=>l*m,1),a=t;a||(e?a="int64":a=F);let i=U(a);if(!i)throw new Error(`Cannot create array with dtype ${a}`);let u=new i(o),s=$l(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 wa(r,t,e=1,n=F){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 za(r,t,e=50,n=F){if(e<0)throw new Error("num must be non-negative");if(e===0)return P([],n);if(e===1)return P([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 Ia(r,t,e=50,n=10,o=F){if(e<0)throw new Error("num must be non-negative");if(e===0)return P([],o);if(e===1)return P([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 _a(r,t,e=50,n=F){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 P([],n);if(e===1)return P([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 de(r,t,e=0,n=F){let o=t??r,a=K([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 ge(r,t=F){return K(r,t)}function Ae(r,t,e){let n=e;n||(typeof t=="bigint"?n="int64":typeof t=="boolean"?n="bool":Number.isInteger(t)?n="int32":n=F);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 Ba(r,t=F){return de(r,r,0,t)}function Er(r,t){return r instanceof I?!t||r.dtype===t?r:r.astype(t):P(r,t)}function va(r){return r.copy()}function Ea(r,t){return K(Array.from(r.shape),t??r.dtype)}function Oa(r,t){return ye(Array.from(r.shape),t??r.dtype)}function Ta(r,t){return ge(Array.from(r.shape),t??r.dtype)}function Ua(r,t,e){return Ae(Array.from(r.shape),t,e??r.dtype)}function $a(r,t){return Er(r,t)}function Ma(r,t){let e=Er(r,t);return e.flags.C_CONTIGUOUS?e:e.copy()}function ka(r,t){return Er(r,t).copy()}function he(r,t=0){if(r.ndim===1){let e=r.size,n=e+Math.abs(t),o=K([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 K([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 Ca(r,t=0){let e=r.flatten();return he(e,t)}function Va(r,t,e=F){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 Pa(...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=Yt(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 qa(r,t,e=0,n=F){let o=t??r,a=K([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 Fa(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 Ra(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 ja(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=K([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 La(r,t=F,e=-1,n=0){let o,a=n;r instanceof ArrayBuffer?o=r:(o=r.buffer,a+=r.byteOffset);let i=Ml(t),u=o.byteLength-a,s=Math.floor(u/i),c=e<0?s:Math.min(e,s);if(c<=0)return P([],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 Wa(r,t=F,e=-1){let n=[],o=0;for(let a of r){if(e>=0&&o>=e)break;n.push(a),o++}return P(n,t)}function Za(r,t=F,e=-1){let n=[],o=0;for(let a of r){if(e>=0&&o>=e)break;n.push(a),o++}return P(n,t)}function Ga(r,t=F,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 P(a,t)}function Ml(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 Ha(r){return r.sqrt()}function Ya(r,t){return r.power(t)}function Ja(r){return r.exp()}function Qa(r){return r.exp2()}function Xa(r){return r.expm1()}function Ka(r){return r.log()}function rs(r){return r.log2()}function ts(r){return r.log10()}function es(r){return r.log1p()}function ns(r,t){return r.logaddexp(t)}function os(r,t){return r.logaddexp2(t)}function as(r){return r.absolute()}function ss(r){return r.negative()}function is(r){return r.sign()}function us(r,t){return r.mod(t)}function cs(r,t){return r.floor_divide(t)}function ls(r){return r.positive()}function fs(r){return r.reciprocal()}function ms(r,t){return r.dot(t)}function ps(r){return r.trace()}function ys(r,t=0,e=0,n=1){let o=$n(r.storage,t,e,n);return I._fromStorage(o)}function ds(r,t){let e=kn(r.storage,t.storage);return I._fromStorage(e)}function gs(r,t){return r.transpose(t)}function As(r,t){return r.inner(t)}function hs(r,t){return r.outer(t)}function bs(r,t,e=2){return r.tensordot(t,e)}function Ss(r){return r.sin()}function Ns(r){return r.cos()}function Ds(r){return r.tan()}function xs(r){return r.arcsin()}function ws(r){return r.arccos()}function zs(r){return r.arctan()}function Is(r,t){return r.arctan2(t)}function _s(r,t){return r.hypot(t)}function Bs(r){return r.degrees()}function vs(r){return r.radians()}function Es(r){return r.radians()}function Os(r){return r.degrees()}function Ts(r){return r.sinh()}function Us(r){return r.cosh()}function $s(r){return r.tanh()}function Ms(r){return r.arcsinh()}function ks(r){return r.arccosh()}function Cs(r){return r.arctanh()}function Vs(r,t,e){return r.swapaxes(t,e)}function Ps(r,t,e){return r.moveaxis(t,e)}function mr(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=lr(e,t);return I._fromStorage(n)}function qs(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=cn(e,t);return I._fromStorage(n)}function be(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=ln(t);return I._fromStorage(e)}function Fs(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=Pt(t);return I._fromStorage(e)}function Rs(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=fn(t);return I._fromStorage(e)}function js(r,t,e=0){return mn(r.storage,t,e).map(o=>I._fromStorage(o,r.base??r))}function Ls(r,t,e=0){return Br(r.storage,t,e).map(o=>I._fromStorage(o,r.base??r))}function Ws(r,t){return yn(r.storage,t).map(n=>I._fromStorage(n,r.base??r))}function Zs(r,t){return dn(r.storage,t).map(n=>I._fromStorage(n,r.base??r))}function Gs(r,t){let e=gn(r.storage,t);return I._fromStorage(e)}function Hs(r,t,e){return r.repeat(t,e)}function Ys(r){return r.ravel()}function Js(r,t){return r.reshape(...t)}function Qs(r,t){return r.squeeze(t)}function Xs(r,t){return r.expand_dims(t)}function et(r,t){let e=hn(r.storage,t);return I._fromStorage(e)}function Ks(r){if(r.ndim<2)throw new Error("Input must be at least 2-D");return et(r,1)}function ri(r){if(r.ndim<2)throw new Error("Input must be at least 2-D");return et(r,0)}function ti(r,t=1,e=[0,1]){let n=bn(r.storage,t,e);return I._fromStorage(n)}function ei(r,t,e){let n=Sn(r.storage,t,e);return I._fromStorage(n)}function ni(r,t,e=0){let n=Nn(r.storage,t,e);return I._fromStorage(n,r.base??r)}function oi(...r){let t=r.map(o=>o.storage),n=zn(t).map((o,a)=>o===t[a]?r[a]:I._fromStorage(o));return n.length===1?n[0]:n}function ai(...r){let t=r.map(o=>o.storage),n=In(t).map((o,a)=>o===t[a]?r[a]:I._fromStorage(o));return n.length===1?n[0]:n}function si(...r){let t=r.map(o=>o.storage),n=_n(t).map((o,a)=>o===t[a]?r[a]:I._fromStorage(o));return n.length===1?n[0]:n}function ii(r,t){return Dn(r.storage,t).map(n=>I._fromStorage(n,r.base??r))}function ui(r){if(r.length===0)throw new Error("need at least one array to stack");let t=r.map(n=>n.storage),e=xn(t);return I._fromStorage(e)}function ci(r){return be(r)}function li(r,t){let e=wn(r.storage,t);return I._fromStorage(e)}function fi(r,t,e){let n=t instanceof I?t:P(t,r.dtype);if(e===void 0){let o=r.flatten(),a=n.flatten();return mr([o,a])}return mr([r,n],e)}function mi(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,K(p,n)}let f=[];for(let[p,y]of l){let d=o.map(()=>":");d[i]=`${p}:${y}`,f.push(r.slice(...d))}return mr(f,i)}function pi(r,t,e,n){let o=e instanceof I?e:P(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),mr(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 mr(l,u)}function yi(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 di(r,t){let e=Yt(r.storage,t);return I._fromStorage(e,r.base??r)}function gi(...r){let t=r.map(n=>n.storage);return Bo(t).map((n,o)=>I._fromStorage(n,r[o].base??r[o]))}function Ai(...r){return St(...r)}function hi(r,t,e){return r.take(t,e)}function bi(r,t,e){r.put(t,e)}function Si(r,t){let e=t.map(o=>o.storage),n=Oo(r.storage,e);return I._fromStorage(n)}function Ni(r,t,e=!1){return To(r.storage,t.storage,e)}function Di(r,t){return en(r.storage,t.storage)}function xi(r,t){return I._fromStorage(Et(r.storage,t))}function wi(r,t){return I._fromStorage(Ot(r.storage,t))}function zi(r,t,e=!1){let n=Tt(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function Ii(r,t,e=!1){let n=Ut(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function _i(r,t,e,n=!1){let o=$t(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)}function Bi(r,t,e,n=!1){let o=gr(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)}function vi(r,t,e,n=!1){let o=e?e.storage:void 0,a=jr(r.storage,t,o,n);return typeof a=="number"?a:I._fromStorage(a)}function Ei(r,t,e=!1){let n=Lr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function Oi(r,t,e=!1){let n=Wr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function Ti(r,t,e=!1){let n=Zr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function Ui(r,t,e=0,n=!1){let o=zr(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)}function $i(r,t,e=0,n=!1){let o=Mt(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)}function Mi(r,t,e=!1){let n=Gr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function ki(r,t,e=!1){let n=Hr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function Ci(r,t){let e=Yr(r.storage,t);return typeof e=="number"?e:I._fromStorage(e)}function Vi(r,t){let e=Jr(r.storage,t);return typeof e=="number"?e:I._fromStorage(e)}function Pi(r,t){return I._fromStorage(kt(r.storage,t))}function qi(r,t){return I._fromStorage(Ct(r.storage,t))}function Fi(r,t,e=!1){let n=Qr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)}function Ri(r){return r.cbrt()}function ji(r){return r.fabs()}function Li(r,t){return r.divmod(t)}function Wi(r){return r.square()}function Zi(r,t){return r.remainder(t)}function Gi(r,t){return r.heaviside(t)}function Hi(r,t){return r.bitwise_and(t)}function Yi(r,t){return r.bitwise_or(t)}function Ji(r,t){return r.bitwise_xor(t)}function Qi(r){return r.bitwise_not()}function Xi(r){return r.invert()}function Ki(r,t){return r.left_shift(t)}function ru(r,t){return r.right_shift(t)}function tu(r,t=-1,e="big"){let n=ea(r.storage,t,e);return I._fromStorage(n)}function eu(r,t=-1,e=-1,n="big"){let o=na(r.storage,t,e,n);return I._fromStorage(o)}function nu(r,...t){let e=t.map(o=>o.storage),n=Mn(r,...e);return typeof n=="number"||typeof n=="bigint"?n:I._fromStorage(n)}function au(r,t,e){return I._fromStorage(Uo(r.storage,t.storage,e))}function su(r,t,e,n){$o(r.storage,t.storage,e.storage,n)}function iu(r,t,e){let n=e instanceof I?e.storage:e;Mo(r.storage,t.storage,n)}function uu(r,t,e){return I._fromStorage(ko(r.storage,t.storage,e))}function cu(r,t,e=0){let n=r.map(a=>a.storage),o=t.map(a=>a.storage);return I._fromStorage(Co(n,o,e))}function lu(r,t,e){Vo(r.storage,t.storage,e.storage)}function fu(r,t=2){return Jt(r,t).map(n=>I._fromStorage(n))}function mu(r){return Po(r.storage).map(e=>I._fromStorage(e))}function pu(r,t=0,e){return Qt(r,t,e).map(o=>I._fromStorage(o))}function yu(r,t=0){return qo(r.storage,t).map(n=>I._fromStorage(n))}function du(r,t=0,e){return Xt(r,t,e).map(o=>I._fromStorage(o))}function gu(r,t=0){return Fo(r.storage,t).map(n=>I._fromStorage(n))}function Au(r,t,e=0){return Ro(r,(a,i)=>t(a,i).storage,e).map(a=>I._fromStorage(a))}function hu(r,t="int32"){return I._fromStorage(jo(r,t))}function bu(...r){return Lo(...r.map(e=>e.storage)).map(e=>I._fromStorage(e))}function Su(r,t,e="raise"){let n=r.map(o=>o.storage);return I._fromStorage(Wo(n,t,e))}function Nu(r,t,e="C"){let n=r instanceof I?r.storage:r;return Zo(n,t,e).map(a=>I._fromStorage(a))}function Du(r,t=-1){return I._fromStorage(re(r.storage,t))}function xu(r,t=-1){return I._fromStorage(te(r.storage,t))}function wu(r){let t=r.map(e=>e.storage);return I._fromStorage(aa(t))}function zu(r,t,e=-1){return I._fromStorage(ee(r.storage,t,e))}function Iu(r,t,e=-1){return I._fromStorage(ne(r.storage,t,e))}function _u(r){return I._fromStorage(sa(r.storage))}function Bu(r){return tt(r.storage).map(e=>I._fromStorage(e))}function vu(r){return I._fromStorage(ia(r.storage))}function Eu(r,t,e){let n=ua(r.storage,t?.storage,e?.storage);return Array.isArray(n)?n.map(o=>I._fromStorage(o)):I._fromStorage(n)}function Ou(r,t,e="left"){return I._fromStorage(oe(r.storage,t.storage,e))}function Tu(r,t){return I._fromStorage(ca(r.storage,t.storage))}function Uu(r,t){let e=ae(r.storage,t);return typeof e=="number"?e:I._fromStorage(e)}function Se(r,t=0){return I._fromStorage(se(r.storage,t))}function $u(r){return I._fromStorage(ie(r.storage))}function Mu(r){return I._fromStorage(ue(r.storage))}function ku(r){return I._fromStorage(ce(r.storage))}function Cu(r){return I._fromStorage(le(r.storage))}function Vu(r){return I._fromStorage(fe(r.storage))}function Pu(r,t=!1,e=!1,n=!1){let o=nr(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 qu(r,t){return I._fromStorage(pa(r.storage,t.storage))}function Fu(r,t){return I._fromStorage(ya(r.storage,t.storage))}function Ru(r,t){return I._fromStorage(me(r.storage,t.storage))}function ju(r,t){return I._fromStorage(da(r.storage,t.storage))}function Lu(r,t){return I._fromStorage(ga(r.storage,t.storage))}function Wu(r,t){return I._fromStorage(Aa(r.storage,t.storage))}function Zu(r,t=1,e=-1){return I._fromStorage(pe(r.storage,t,e))}function Gu(r,t=null,e=null){return I._fromStorage(ba(r.storage,t,e))}function Hu(r,t=1,e=null){let n=Sa(r.storage,t,e);return Array.isArray(n)?n.map(o=>I._fromStorage(o)):I._fromStorage(n)}function Yu(r,t,e=-1,n=-1,o=-1){return I._fromStorage(Na(r.storage,t.storage,e,n,o))}var I,ou,nt=k(()=>{"use strict";ve();j();R();He();nn();an();qt();Jn();uo();So();_o();Go();oa();la();ma();ha();Da();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=Ue(this._storage,e);return r._fromStorage(n)}subtract(t){let e=typeof t=="number"?t:t._storage,n=$e(this._storage,e);return r._fromStorage(n)}multiply(t){let e=typeof t=="number"?t:t._storage,n=Me(this._storage,e);return r._fromStorage(n)}divide(t){let e=typeof t=="number"?t:t._storage,n=ke(this._storage,e);return r._fromStorage(n)}mod(t){let e=typeof t=="number"?t:t._storage,n=Pr(this._storage,e);return r._fromStorage(n)}floor_divide(t){let e=typeof t=="number"?t:t._storage,n=bt(this._storage,e);return r._fromStorage(n)}positive(){let t=qe(this._storage);return r._fromStorage(t)}reciprocal(){let t=Fe(this._storage);return r._fromStorage(t)}sqrt(){let t=Qn(this._storage);return r._fromStorage(t)}power(t){let e=typeof t=="number"?t:t._storage,n=Xn(this._storage,e);return r._fromStorage(n)}exp(){let t=Kn(this._storage);return r._fromStorage(t)}exp2(){let t=ro(this._storage);return r._fromStorage(t)}expm1(){let t=to(this._storage);return r._fromStorage(t)}log(){let t=eo(this._storage);return r._fromStorage(t)}log2(){let t=no(this._storage);return r._fromStorage(t)}log10(){let t=oo(this._storage);return r._fromStorage(t)}log1p(){let t=ao(this._storage);return r._fromStorage(t)}logaddexp(t){let e=typeof t=="number"?t:t._storage,n=so(this._storage,e);return r._fromStorage(n)}logaddexp2(t){let e=typeof t=="number"?t:t._storage,n=io(this._storage,e);return r._fromStorage(n)}absolute(){let t=Ce(this._storage);return r._fromStorage(t)}negative(){let t=Ve(this._storage);return r._fromStorage(t)}sign(){let t=Pe(this._storage);return r._fromStorage(t)}around(t=0){let e=se(this._storage,t);return r._fromStorage(e)}round(t=0){return this.around(t)}ceil(){let t=ie(this._storage);return r._fromStorage(t)}fix(){let t=ue(this._storage);return r._fromStorage(t)}floor(){let t=ce(this._storage);return r._fromStorage(t)}rint(){let t=le(this._storage);return r._fromStorage(t)}trunc(){let t=fe(this._storage);return r._fromStorage(t)}sin(){let t=co(this._storage);return r._fromStorage(t)}cos(){let t=lo(this._storage);return r._fromStorage(t)}tan(){let t=fo(this._storage);return r._fromStorage(t)}arcsin(){let t=mo(this._storage);return r._fromStorage(t)}arccos(){let t=po(this._storage);return r._fromStorage(t)}arctan(){let t=yo(this._storage);return r._fromStorage(t)}arctan2(t){let e=typeof t=="number"?t:t._storage,n=go(this._storage,e);return r._fromStorage(n)}hypot(t){let e=typeof t=="number"?t:t._storage,n=Ao(this._storage,e);return r._fromStorage(n)}degrees(){let t=ho(this._storage);return r._fromStorage(t)}radians(){let t=bo(this._storage);return r._fromStorage(t)}sinh(){let t=No(this._storage);return r._fromStorage(t)}cosh(){let t=Do(this._storage);return r._fromStorage(t)}tanh(){let t=xo(this._storage);return r._fromStorage(t)}arcsinh(){let t=wo(this._storage);return r._fromStorage(t)}arccosh(){let t=zo(this._storage);return r._fromStorage(t)}arctanh(){let t=Io(this._storage);return r._fromStorage(t)}greater(t){let e=typeof t=="number"?t:t._storage,n=Ye(this._storage,e);return r._fromStorage(n)}greater_equal(t){let e=typeof t=="number"?t:t._storage,n=Je(this._storage,e);return r._fromStorage(n)}less(t){let e=typeof t=="number"?t:t._storage,n=Qe(this._storage,e);return r._fromStorage(n)}less_equal(t){let e=typeof t=="number"?t:t._storage,n=Xe(this._storage,e);return r._fromStorage(n)}equal(t){let e=typeof t=="number"?t:t._storage,n=Ke(this._storage,e);return r._fromStorage(n)}not_equal(t){let e=typeof t=="number"?t:t._storage,n=rn(this._storage,e);return r._fromStorage(n)}isclose(t,e=1e-5,n=1e-8){let o=typeof t=="number"?t:t._storage,a=Dt(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 tn(this._storage,o,e,n)}bitwise_and(t){let e=typeof t=="number"?t:t._storage,n=Jo(this._storage,e);return r._fromStorage(n)}bitwise_or(t){let e=typeof t=="number"?t:t._storage,n=Qo(this._storage,e);return r._fromStorage(n)}bitwise_xor(t){let e=typeof t=="number"?t:t._storage,n=Xo(this._storage,e);return r._fromStorage(n)}bitwise_not(){let t=Kt(this._storage);return r._fromStorage(t)}invert(){let t=Ko(this._storage);return r._fromStorage(t)}left_shift(t){let e=typeof t=="number"?t:t._storage,n=ra(this._storage,e);return r._fromStorage(n)}right_shift(t){let e=typeof t=="number"?t:t._storage,n=ta(this._storage,e);return r._fromStorage(n)}sum(t,e=!1){let n=wr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}mean(t,e=!1){let n=qr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}max(t,e=!1){let n=Fr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}min(t,e=!1){let n=Rr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}prod(t,e=!1){let n=wt(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}argmin(t){let e=zt(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}argmax(t){let e=It(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}var(t,e=0,n=!1){let o=_t(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}std(t,e=0,n=!1){let o=on(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=vt(this._storage,t,e);return typeof n=="boolean"?n:r._fromStorage(n)}cumsum(t){return r._fromStorage(Et(this._storage,t))}cumprod(t){return r._fromStorage(Ot(this._storage,t))}ptp(t,e=!1){let n=Tt(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=$t(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}quantile(t,e,n=!1){let o=gr(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}average(t,e){let n=jr(this._storage,e,t?.storage);return typeof n=="number"?n:r._fromStorage(n)}nansum(t,e=!1){let n=Lr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanprod(t,e=!1){let n=Wr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanmean(t,e=!1){let n=Zr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanvar(t,e=0,n=!1){let o=zr(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}nanstd(t,e=0,n=!1){let o=Mt(this._storage,t,e,n);return typeof o=="number"?o:r._fromStorage(o)}nanmin(t,e=!1){let n=Gr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanmax(t,e=!1){let n=Hr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}nanargmin(t){let e=Yr(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}nanargmax(t){let e=Jr(this._storage,t);return typeof e=="number"?e:r._fromStorage(e)}nancumsum(t){return r._fromStorage(kt(this._storage,t))}nancumprod(t){return r._fromStorage(Ct(this._storage,t))}nanmedian(t,e=!1){let n=Qr(this._storage,t,e);return typeof n=="number"?n:r._fromStorage(n)}sort(t=-1){return r._fromStorage(re(this._storage,t))}argsort(t=-1){return r._fromStorage(te(this._storage,t))}partition(t,e=-1){return r._fromStorage(ee(this._storage,t,e))}argpartition(t,e=-1){return r._fromStorage(ne(this._storage,t,e))}nonzero(){return tt(this._storage).map(e=>r._fromStorage(e))}searchsorted(t,e="left"){return r._fromStorage(oe(this._storage,t._storage,e))}diff(t=1,e=-1){return r._fromStorage(pe(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=Xr(this._storage);return r._fromStorage(t)}ravel(){let t=Ar(this._storage),n=t.data===this.data?this._base??this:void 0;return r._fromStorage(t,n)}transpose(t){let e=_r(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}squeeze(t){let e=sn(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}expand_dims(t){let e=Ir(this._storage,t),n=this._base??this;return r._fromStorage(e,n)}swapaxes(t,e){let n=un(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=An(this._storage,t,e);return r._fromStorage(n)}take(t,e){let n=vo(this._storage,t,e);return r._fromStorage(n)}put(t,e){let n=e instanceof r?e._storage:e;Eo(this._storage,t,n)}matmul(t){let e=J(this._storage,t._storage);return r._fromStorage(e)}dot(t){let e=Rt(this._storage,t._storage);return typeof e=="number"||typeof e=="bigint"?e:r._fromStorage(e)}trace(){return On(this._storage)}inner(t){let e=Tn(this._storage,t._storage);return typeof e=="number"||typeof e=="bigint"?e:r._fromStorage(e)}outer(t){let e=jt(this._storage,t._storage);return r._fromStorage(e)}tensordot(t,e=2){let n=Un(this._storage,t._storage,e);return typeof n=="number"||typeof n=="bigint"?n:r._fromStorage(n)}cbrt(){let t=Re(this._storage);return r._fromStorage(t)}fabs(){let t=je(this._storage);return r._fromStorage(t)}divmod(t){let e=typeof t=="number"?t:t._storage,[n,o]=Le(this._storage,e);return[r._fromStorage(n),r._fromStorage(o)]}square(){let t=We(this._storage);return r._fromStorage(t)}remainder(t){let e=typeof t=="number"?t:t._storage,n=Ze(this._storage,e);return r._fromStorage(n)}heaviside(t){let e=typeof t=="number"?t:t._storage,n=Ge(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=_e(s);return Be(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)}};ou={cross:(r,t,e=-1,n=-1,o=-1,a)=>{let i=Cn(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=Vn(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)},vector_norm:(r,t=2,e,n=!1)=>{let o=hr(r.storage,t,e,n);return typeof o=="number"?o:I._fromStorage(o)},matrix_norm:(r,t="fro",e=!1)=>{let n=fr(r.storage,t,e);return typeof n=="number"?n:I._fromStorage(n)},qr:(r,t="reduced")=>{let e=Lt(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(Pn(r.storage,t)),svd:(r,t=!0,e=!0)=>{let n=qn(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=>Fn(r.storage),inv:r=>I._fromStorage(Kr(r.storage)),solve:(r,t)=>I._fromStorage(Rn(r.storage,t.storage)),lstsq:(r,t,e=null)=>{let n=jn(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)=>Ln(r.storage,t),matrix_rank:(r,t)=>Wn(r.storage,t),matrix_power:(r,t)=>I._fromStorage(Zn(r.storage,t)),pinv:(r,t=1e-15)=>I._fromStorage(Gn(r.storage,t)),eig:r=>{let t=Gt(r.storage);return{w:I._fromStorage(t.w),v:I._fromStorage(t.v)}},eigh:(r,t="L")=>{let e=Ht(r.storage,t);return{w:I._fromStorage(e.w),v:I._fromStorage(e.v)}},eigvals:r=>I._fromStorage(Hn(r.storage)),eigvalsh:(r,t="L")=>I._fromStorage(Yn(r.storage,t))}});function Ne(){let r=new ArrayBuffer(2);return new DataView(r).setInt16(0,256,!0),new Int16Array(r)[0]===256}function Qu(r){if(r.startsWith("[")||r.startsWith("("))throw new rr(`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 Ju)throw new rr(`Unsupported dtype: ${Ju[n]} (${r}). Use the 'force' parameter to skip arrays with unsupported dtypes.`);let o=kl[e];if(!o)throw new rr(`Unknown or unsupported dtype descriptor: ${r}. Supported types: ${ot.join(", ")}. Use the 'force' parameter to skip arrays with unsupported dtypes.`);let a=Ne(),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 Or,ot,kl,Tr,Ju,rr,H,Ur=k(()=>{"use strict";Or=new Uint8Array([147,78,85,77,80,89]),ot=["float64","float32","int64","int32","int16","int8","uint64","uint32","uint16","uint8","bool"];kl={f8:"float64",f4:"float32",i8:"int64",i4:"int32",i2:"int16",i1:"int8",u8:"uint64",u4:"uint32",u2:"uint16",u1:"uint8",b1:"bool"},Tr={float64:"<f8",float32:"<f4",int64:"<i8",int32:"<i4",int16:"<i2",int8:"|i1",uint64:"<u8",uint32:"<u4",uint16:"<u2",uint8:"|u1",bool:"|b1"},Ju={c:"complex numbers",S:"byte strings",U:"Unicode strings",O:"Python objects",V:"structured arrays (void)",M:"datetime64",m:"timedelta64"};rr=class extends Error{constructor(t){super(t),this.name="UnsupportedDTypeError"}},H=class extends Error{constructor(t){super(t),this.name="InvalidNpyError"}}});function ur(r){let t=r instanceof ArrayBuffer?new Uint8Array(r):r,e=at(t);return st(t,e)}function at(r){if(r.length<10)throw new H("File too small to be a valid NPY file");for(let c=0;c<Or.length;c++)if(r[c]!==Or[c])throw new H("Invalid NPY magic number");let t=r[6],e=r[7];if(t!==1&&t!==2&&t!==3)throw new H(`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 H("File truncated: header extends beyond file");let i=r.slice(o,a),u=new TextDecoder("utf-8").decode(i).trim(),s=Cl(u);return{version:{major:t,minor:e},header:s,dataOffset:a}}function st(r,t){let{header:e,dataOffset:n}=t,{dtype:o,needsByteSwap:a,itemsize:i}=Qu(e.descr),u=e.shape.reduce((d,g)=>d*g,1),s=u*i,c=r.length-n;if(c<s)throw new H(`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=Vl(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=Pl(g,d),p=e.shape}else y=N.fromData(f,[...p],o);return new I(y)}function Cl(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 H(`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 H(`Invalid shape value: ${s}`);return c}),{descr:o,fortran_order:a,shape:u}}function Vl(r,t,e,n,o){let a=U(t);if(!a)throw new H(`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 Pl(r,t){let e=t.length,n=r.size,o=r.dtype,a=U(o);if(!a)throw new H(`Cannot create array for dtype: ${o}`);let i=new a(n),u=[...t].reverse(),s=Xu(t),c=Xu(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 Xu(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 it=k(()=>{"use strict";nt();R();j();Ur()});function or(r){let t=r.shape,e=r.dtype,n=Tr[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=Oe(e),p=m*f,y=i+l+p,d=new Uint8Array(y);d.set(Or,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 ql(r,d.subarray(g),f),d}function ql(r,t,e){let n=r.dtype,o=r.size,a=Ne(),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?Fl(c,f,m,n==="uint64"):Rl(c,f,m,n)}}}function Fl(r,t,e,n){n?r.setBigUint64(t,e,!0):r.setBigInt64(t,e,!0)}function Rl(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 ut=k(()=>{"use strict";j();Ur()});function De(r){let t=4294967295;for(let e=0;e<r.length;e++)t=jl[(t^r[e])&255]^t>>>8;return(t^4294967295)>>>0}var jl,xe=k(()=>{"use strict";jl=(()=>{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 Ku(r){let t=tc(r),e=new Map;for(let n of t){let o=await Ll(n);e.set(n.name,o)}return e}function rc(r){let t=tc(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 tc(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 Ll(r){if(r.compressionMethod===0)return r.compressedData;if(r.compressionMethod===8)return await Wl(r.compressedData);throw new Error(`Unsupported compression method: ${r.compressionMethod}`)}async function Wl(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 ec=k(()=>{"use strict";xe()});var oc={};gt(oc,{loadNpz:()=>ct,loadNpzSync:()=>lt,parseNpz:()=>pr,parseNpzSync:()=>Mr});async function pr(r,t={}){let e=t.force??!1,n=await Ku(r);return nc(n,e)}function Mr(r,t={}){let e=t.force??!1,n=rc(r);return nc(n,e)}function nc(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=ur(i);e.set(u,s)}catch(s){if(s instanceof rr&&t)n.push(u),o.set(u,s.message);else throw s}}return{arrays:e,skipped:n,errors:o}}async function ct(r,t={}){let e=await pr(r,t);return Object.fromEntries(e.arrays)}function lt(r,t={}){let e=Mr(r,t);return Object.fromEntries(e.arrays)}var ft=k(()=>{"use strict";it();Ur();ec()});async function ac(r,t={}){let e=t.compress??!1,n=[];for(let[f,p]of r){let y=De(p),d,g;e?(d=await Gl(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=ic(s,c,l,f);let m=l;for(let f of n)l=uc(s,c,l,f);return cc(c,l,n.length,a,m),s}function sc(r){let t=[];for(let[l,m]of r){let f=De(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=ic(i,u,s,l);let c=s;for(let l of t)s=uc(i,u,s,l);return cc(u,s,t.length,n,c),i}function ic(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 uc(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 cc(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 Gl(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 lc=k(()=>{"use strict";xe()});var mc={};gt(mc,{serializeNpz:()=>Sr,serializeNpzSync:()=>mt});async function Sr(r,t={}){let e=fc(r);return ac(e,{compress:t.compress??!1})}function mt(r){let t=fc(r);return sc(t)}function fc(r){let t=new Map;if(Array.isArray(r)){for(let n=0;n<r.length;n++){let o=r[n],a=or(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=or(o),i=n.endsWith(".npy")?n:`${n}.npy`;t.set(i,a)}return t}var pt=k(()=>{"use strict";ut();lc()});var ff={};gt(ff,{DTYPE_TO_DESCR:()=>Tr,InvalidNpyError:()=>H,NDArray:()=>I,SUPPORTED_DTYPES:()=>ot,UnsupportedDTypeError:()=>rr,__version__:()=>Hl,absolute:()=>as,append:()=>fi,arange:()=>wa,arccos:()=>ws,arccosh:()=>ks,arcsin:()=>xs,arcsinh:()=>Ms,arctan:()=>zs,arctan2:()=>Is,arctanh:()=>Cs,argpartition:()=>Iu,argsort:()=>xu,around:()=>Se,array:()=>P,array_equal:()=>Ni,array_equiv:()=>Di,array_split:()=>Ls,asanyarray:()=>$a,asarray:()=>Er,ascontiguousarray:()=>Ma,asfortranarray:()=>ka,atleast_1d:()=>oi,atleast_2d:()=>ai,atleast_3d:()=>si,average:()=>vi,bitwise_and:()=>Hi,bitwise_not:()=>Qi,bitwise_or:()=>Yi,bitwise_xor:()=>Ji,broadcast_arrays:()=>gi,broadcast_shapes:()=>Ai,broadcast_to:()=>di,cbrt:()=>Ri,ceil:()=>$u,choose:()=>Si,column_stack:()=>ui,compress:()=>uu,concatenate:()=>mr,copy:()=>va,cos:()=>Ns,cosh:()=>Us,count_nonzero:()=>Uu,cross:()=>Yu,cumprod:()=>wi,cumsum:()=>xi,deg2rad:()=>Es,degrees:()=>Bs,delete:()=>mi,diag:()=>he,diag_indices:()=>fu,diag_indices_from:()=>mu,diagflat:()=>Ca,diagonal:()=>ys,diff:()=>Zu,divmod:()=>Li,dot:()=>ms,dsplit:()=>ii,dstack:()=>Rs,ediff1d:()=>Gu,einsum:()=>nu,empty:()=>ge,empty_like:()=>Ta,exp:()=>Ja,exp2:()=>Qa,expand_dims:()=>Xs,expm1:()=>Xa,extract:()=>Tu,eye:()=>de,fabs:()=>ji,fix:()=>Mu,flatnonzero:()=>vu,flip:()=>et,fliplr:()=>Ks,flipud:()=>ri,floor:()=>ku,floor_divide:()=>cs,frombuffer:()=>La,fromfile:()=>Wa,fromfunction:()=>Va,fromiter:()=>Za,fromregex:()=>cf,fromregexSync:()=>lf,fromstring:()=>Ga,full:()=>Ae,full_like:()=>Ua,genfromtxt:()=>sf,genfromtxtSync:()=>uf,geomspace:()=>_a,gradient:()=>Hu,heaviside:()=>Gi,hsplit:()=>Zs,hstack:()=>Fs,hypot:()=>_s,identity:()=>Ba,in1d:()=>qu,indices:()=>hu,inner:()=>As,insert:()=>pi,intersect1d:()=>Fu,invert:()=>Xi,isin:()=>Ru,ix_:()=>bu,kron:()=>ds,left_shift:()=>Ki,lexsort:()=>wu,linalg:()=>ou,linspace:()=>za,load:()=>Jl,loadNpy:()=>yc,loadNpySync:()=>dc,loadNpz:()=>ct,loadNpzFile:()=>hc,loadNpzFileSync:()=>bc,loadNpzSync:()=>lt,loadSync:()=>Ql,loadtxt:()=>ef,loadtxtSync:()=>nf,log:()=>Ka,log10:()=>ts,log1p:()=>es,log2:()=>rs,logaddexp:()=>ns,logaddexp2:()=>os,logspace:()=>Ia,mask_indices:()=>Au,median:()=>Ii,meshgrid:()=>Pa,mod:()=>us,moveaxis:()=>Ps,nanargmax:()=>Vi,nanargmin:()=>Ci,nancumprod:()=>qi,nancumsum:()=>Pi,nanmax:()=>ki,nanmean:()=>Ti,nanmedian:()=>Fi,nanmin:()=>Mi,nanprod:()=>Oi,nanstd:()=>$i,nansum:()=>Ei,nanvar:()=>Ui,negative:()=>ss,nonzero:()=>Bu,ones:()=>ye,ones_like:()=>Oa,outer:()=>hs,packbits:()=>tu,pad:()=>yi,parseNpy:()=>ur,parseNpyData:()=>st,parseNpyHeader:()=>at,parseNpz:()=>pr,parseNpzSync:()=>Mr,parseTxt:()=>yr,partition:()=>zu,percentile:()=>_i,place:()=>lu,positive:()=>ls,power:()=>Ya,ptp:()=>zi,put:()=>bi,put_along_axis:()=>su,putmask:()=>iu,quantile:()=>Bi,rad2deg:()=>Os,radians:()=>vs,ravel:()=>Ys,ravel_multi_index:()=>Su,reciprocal:()=>fs,remainder:()=>Zi,repeat:()=>Hs,reshape:()=>Js,resize:()=>li,right_shift:()=>ru,rint:()=>Cu,roll:()=>ei,rollaxis:()=>ni,rot90:()=>ti,round:()=>Se,row_stack:()=>ci,save:()=>Xl,saveNpy:()=>gc,saveNpySync:()=>Ac,saveNpz:()=>Ie,saveNpzSync:()=>Yl,saveSync:()=>Kl,savetxt:()=>of,savetxtSync:()=>af,savez:()=>rf,savez_compressed:()=>tf,searchsorted:()=>Ou,select:()=>cu,serializeNpy:()=>or,serializeNpz:()=>Sr,serializeNpzSync:()=>mt,serializeTxt:()=>Nr,setdiff1d:()=>ju,setxor1d:()=>Lu,sign:()=>is,sin:()=>Ss,sinh:()=>Ts,sort:()=>Du,sort_complex:()=>_u,split:()=>js,sqrt:()=>Ha,square:()=>Wi,squeeze:()=>Qs,stack:()=>qs,swapaxes:()=>Vs,take:()=>hi,take_along_axis:()=>au,tan:()=>Ds,tanh:()=>$s,tensordot:()=>bs,tile:()=>Gs,trace:()=>ps,transpose:()=>gs,tri:()=>qa,tril:()=>Fa,tril_indices:()=>pu,tril_indices_from:()=>yu,triu:()=>Ra,triu_indices:()=>du,triu_indices_from:()=>gu,trunc:()=>Vu,union1d:()=>Wu,unique:()=>Pu,unpackbits:()=>eu,unravel_index:()=>Nu,vander:()=>ja,vsplit:()=>Ws,vstack:()=>be,where:()=>Eu,zeros:()=>K,zeros_like:()=>Ea});module.exports=At(ff);var tr=require("node:fs"),er=require("node:fs/promises");it();ut();ft();pt();nt();function yr(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 P([],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?P(m.map(d=>d[0]),u):P(m,u)}function kr(r,t={}){let e={...t,missing_values:t.missing_values??["","nan","NaN","NA","N/A","-"],filling_values:t.filling_values??NaN};return yr(r,e)}function Cr(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?P([],e):o[0].length===1?P(o.map(i=>i[0]),e):P(o,e)}function pc(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 Nr(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(pc(l,e));else for(let l of c){let m=l.map(f=>pc(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}nt();it();ut();Ur();ft();pt();var Hl="0.9.0";async function yc(r){let t=await(0,er.readFile)(r);return ur(t)}function dc(r){let t=(0,tr.readFileSync)(r);return ur(t)}async function gc(r,t){let e=or(t);await(0,er.writeFile)(r,e)}function Ac(r,t){let e=or(t);(0,tr.writeFileSync)(r,e)}async function hc(r,t={}){let e=await(0,er.readFile)(r);return pr(e,t)}function bc(r,t={}){let e=(0,tr.readFileSync)(r),{parseNpzSync:n}=(ft(),At(oc));return n(e,t)}async function Ie(r,t,e={}){let n=await Sr(t,e);await(0,er.writeFile)(r,n)}function Yl(r,t){let{serializeNpzSync:e}=(pt(),At(mc)),n=e(t);(0,tr.writeFileSync)(r,n)}async function Jl(r,t={}){if(r.endsWith(".npy")){if(t.allowNpy===!1)throw new Error("Loading .npy files is disabled (allowNpy: false)");return yc(r)}else{if(r.endsWith(".npz"))return hc(r,t);throw new Error(`Unknown file extension. Expected .npy or .npz, got: ${r}`)}}function Ql(r,t={}){if(r.endsWith(".npy")){if(t.allowNpy===!1)throw new Error("Loading .npy files is disabled (allowNpy: false)");return dc(r)}else{if(r.endsWith(".npz"))return bc(r,t);throw new Error(`Unknown file extension. Expected .npy or .npz, got: ${r}`)}}async function Xl(r,t){if(!r.endsWith(".npy"))throw new Error(`save() is for .npy files. Use saveNpz() for .npz files. Got: ${r}`);return gc(r,t)}function Kl(r,t){if(!r.endsWith(".npy"))throw new Error(`saveSync() is for .npy files. Use saveNpzSync() for .npz files. Got: ${r}`);return Ac(r,t)}async function rf(r,t){return r.endsWith(".npz")||(r=r+".npz"),Ie(r,t,{compress:!1})}async function tf(r,t){return r.endsWith(".npz")||(r=r+".npz"),Ie(r,t,{compress:!0})}async function ef(r,t={}){let e=await(0,er.readFile)(r,{encoding:t.encoding??"utf-8"});return yr(e,t)}function nf(r,t={}){let e=(0,tr.readFileSync)(r,{encoding:t.encoding??"utf-8"});return yr(e,t)}async function of(r,t,e={}){let n=Nr(t,e);await(0,er.writeFile)(r,n,"utf-8")}function af(r,t,e={}){let n=Nr(t,e);(0,tr.writeFileSync)(r,n,"utf-8")}async function sf(r,t={}){let e=await(0,er.readFile)(r,{encoding:t.encoding??"utf-8"});return kr(e,t)}function uf(r,t={}){let e=(0,tr.readFileSync)(r,{encoding:t.encoding??"utf-8"});return kr(e,t)}async function cf(r,t,e="float64"){let n=await(0,er.readFile)(r,{encoding:"utf-8"});return Cr(n,t,e)}function lf(r,t,e="float64"){let n=(0,tr.readFileSync)(r,{encoding:"utf-8"});return Cr(n,t,e)}0&&(module.exports={DTYPE_TO_DESCR,InvalidNpyError,NDArray,SUPPORTED_DTYPES,UnsupportedDTypeError,__version__,absolute,append,arange,arccos,arccosh,arcsin,arcsinh,arctan,arctan2,arctanh,argpartition,argsort,around,array,array_equal,array_equiv,array_split,asanyarray,asarray,ascontiguousarray,asfortranarray,atleast_1d,atleast_2d,atleast_3d,average,bitwise_and,bitwise_not,bitwise_or,bitwise_xor,broadcast_arrays,broadcast_shapes,broadcast_to,cbrt,ceil,choose,column_stack,compress,concatenate,copy,cos,cosh,count_nonzero,cross,cumprod,cumsum,deg2rad,degrees,delete:null,diag,diag_indices,diag_indices_from,diagflat,diagonal,diff,divmod,dot,dsplit,dstack,ediff1d,einsum,empty,empty_like,exp,exp2,expand_dims,expm1,extract,eye,fabs,fix,flatnonzero,flip,fliplr,flipud,floor,floor_divide,frombuffer,fromfile,fromfunction,fromiter,fromregex,fromregexSync,fromstring,full,full_like,genfromtxt,genfromtxtSync,geomspace,gradient,heaviside,hsplit,hstack,hypot,identity,in1d,indices,inner,insert,intersect1d,invert,isin,ix_,kron,left_shift,lexsort,linalg,linspace,load,loadNpy,loadNpySync,loadNpz,loadNpzFile,loadNpzFileSync,loadNpzSync,loadSync,loadtxt,loadtxtSync,log,log10,log1p,log2,logaddexp,logaddexp2,logspace,mask_indices,median,meshgrid,mod,moveaxis,nanargmax,nanargmin,nancumprod,nancumsum,nanmax,nanmean,nanmedian,nanmin,nanprod,nanstd,nansum,nanvar,negative,nonzero,ones,ones_like,outer,packbits,pad,parseNpy,parseNpyData,parseNpyHeader,parseNpz,parseNpzSync,parseTxt,partition,percentile,place,positive,power,ptp,put,put_along_axis,putmask,quantile,rad2deg,radians,ravel,ravel_multi_index,reciprocal,remainder,repeat,reshape,resize,right_shift,rint,roll,rollaxis,rot90,round,row_stack,save,saveNpy,saveNpySync,saveNpz,saveNpzSync,saveSync,savetxt,savetxtSync,savez,savez_compressed,searchsorted,select,serializeNpy,serializeNpz,serializeNpzSync,serializeTxt,setdiff1d,setxor1d,sign,sin,sinh,sort,sort_complex,split,sqrt,square,squeeze,stack,swapaxes,take,take_along_axis,tan,tanh,tensordot,tile,trace,transpose,tri,tril,tril_indices,tril_indices_from,triu,triu_indices,triu_indices_from,trunc,union1d,unique,unpackbits,unravel_index,vander,vsplit,vstack,where,zeros,zeros_like});
|
|
4
4
|
//# sourceMappingURL=numpy-ts.node-io.cjs.map
|