@datagrok/eda 1.1.2 → 1.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/221.js ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunkeda=self.webpackChunkeda||[]).push([[221],{251:(t,e,r)=>{r.r(e),r.d(e,{default:()=>P});const o=Object.prototype.toString;function n(t){return o.call(t).endsWith("Array]")}function i(t,e,r){let o=0;const n=r(e);for(let e=0;e<t.x.length;e++)o+=Math.abs(t.y[e]-n(t.x[e]));return o}const s=Object.prototype.toString;function h(t){const e=s.call(t);return e.endsWith("Array]")&&!e.includes("Big")}const a=Object.prototype.toString;function u(t){const e=a.call(t);return e.endsWith("Array]")&&!e.includes("Big")}const l=Object.prototype.toString;const f=Object.prototype.toString;function c(t){var e,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!u(t))throw new TypeError("input must be an array");if(0===t.length)throw new TypeError("input must not be empty");if(void 0!==r.output){if(!u(r.output))throw new TypeError("output option must be an array if specified");e=r.output}else e=new Array(t.length);var o=function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!function(t){const e=f.call(t);return e.endsWith("Array]")&&!e.includes("Big")}(t))throw new TypeError("input must be an array");if(0===t.length)throw new TypeError("input must not be empty");var r=e.fromIndex,o=void 0===r?0:r,n=e.toIndex,i=void 0===n?t.length:n;if(o<0||o>=t.length||!Number.isInteger(o))throw new Error("fromIndex must be a positive integer smaller than length");if(i<=o||i>t.length||!Number.isInteger(i))throw new Error("toIndex must be an integer greater than fromIndex and at most equal to length");for(var s=t[o],h=o+1;h<i;h++)t[h]<s&&(s=t[h]);return s}(t),n=function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!function(t){const e=l.call(t);return e.endsWith("Array]")&&!e.includes("Big")}(t))throw new TypeError("input must be an array");if(0===t.length)throw new TypeError("input must not be empty");var r=e.fromIndex,o=void 0===r?0:r,n=e.toIndex,i=void 0===n?t.length:n;if(o<0||o>=t.length||!Number.isInteger(o))throw new Error("fromIndex must be a positive integer smaller than length");if(i<=o||i>t.length||!Number.isInteger(i))throw new Error("toIndex must be an integer greater than fromIndex and at most equal to length");for(var s=t[o],h=o+1;h<i;h++)t[h]>s&&(s=t[h]);return s}(t);if(o===n)throw new RangeError("minimum and maximum input values are equal. Cannot rescale a constant array");var i=r.min,s=void 0===i?r.autoMinMax?o:0:i,h=r.max,a=void 0===h?r.autoMinMax?n:1:h;if(s>=a)throw new RangeError("min option must be smaller than max option");for(var c=(a-s)/(n-o),m=0;m<t.length;m++)e[m]=(t[m]-o)*c+s;return e}const m=" ".repeat(2),p=" ".repeat(4);function g(t,e={}){const{maxRows:r=15,maxColumns:o=10,maxNumSize:n=8,padMinus:i="auto"}=e;return`${t.constructor.name} {\n${m}[\n${p}${function(t,e,r,o,n){const{rows:i,columns:s}=t,h=Math.min(i,e),a=Math.min(s,r),u=[];if("auto"===n){n=!1;t:for(let e=0;e<h;e++)for(let r=0;r<a;r++)if(t.get(e,r)<0){n=!0;break t}}for(let e=0;e<h;e++){let r=[];for(let i=0;i<a;i++)r.push(w(t.get(e,i),o,n));u.push(`${r.join(" ")}`)}return a!==s&&(u[u.length-1]+=` ... ${s-r} more columns`),h!==i&&u.push(`... ${i-e} more rows`),u.join(`\n${p}`)}(t,r,o,n,i)}\n${m}]\n${m}rows: ${t.rows}\n${m}columns: ${t.columns}\n}`}function w(t,e,r){return(t>=0&&r?` ${d(t,e-1)}`:d(t,e)).padEnd(e)}function d(t,e){let r=t.toString();if(r.length<=e)return r;let o=t.toFixed(e);if(o.length>e&&(o=t.toFixed(Math.max(0,e-(o.length-e)))),o.length<=e&&!o.startsWith("0.000")&&!o.startsWith("-0.000"))return o;let n=t.toExponential(e);return n.length>e&&(n=t.toExponential(Math.max(0,e-(n.length-e)))),n.slice(0)}function y(t,e,r){let o=r?t.rows:t.rows-1;if(e<0||e>o)throw new RangeError("Row index out of range")}function v(t,e,r){let o=r?t.columns:t.columns-1;if(e<0||e>o)throw new RangeError("Column index out of range")}function b(t,e){if(e.to1DArray&&(e=e.to1DArray()),e.length!==t.columns)throw new RangeError("vector size must be the same as the number of columns");return e}function M(t,e){if(e.to1DArray&&(e=e.to1DArray()),e.length!==t.rows)throw new RangeError("vector size must be the same as the number of rows");return e}function x(t,e,r,o,n){if(5!==arguments.length)throw new RangeError("expected 4 arguments");if(E("startRow",e),E("endRow",r),E("startColumn",o),E("endColumn",n),e>r||o>n||e<0||e>=t.rows||r<0||r>=t.rows||o<0||o>=t.columns||n<0||n>=t.columns)throw new RangeError("Submatrix indices are out of range")}function S(t,e=0){let r=[];for(let o=0;o<t;o++)r.push(e);return r}function E(t,e){if("number"!=typeof e)throw new TypeError(`${t} must be a number`)}function R(t){if(t.isEmpty())throw new Error("Empty matrix has no elements to index")}class N{static from1DArray(t,e,r){if(t*e!==r.length)throw new RangeError("data length does not match given dimensions");let o=new z(t,e);for(let n=0;n<t;n++)for(let t=0;t<e;t++)o.set(n,t,r[n*e+t]);return o}static rowVector(t){let e=new z(1,t.length);for(let r=0;r<t.length;r++)e.set(0,r,t[r]);return e}static columnVector(t){let e=new z(t.length,1);for(let r=0;r<t.length;r++)e.set(r,0,t[r]);return e}static zeros(t,e){return new z(t,e)}static ones(t,e){return new z(t,e).fill(1)}static rand(t,e,r={}){if("object"!=typeof r)throw new TypeError("options must be an object");const{random:o=Math.random}=r;let n=new z(t,e);for(let r=0;r<t;r++)for(let t=0;t<e;t++)n.set(r,t,o());return n}static randInt(t,e,r={}){if("object"!=typeof r)throw new TypeError("options must be an object");const{min:o=0,max:n=1e3,random:i=Math.random}=r;if(!Number.isInteger(o))throw new TypeError("min must be an integer");if(!Number.isInteger(n))throw new TypeError("max must be an integer");if(o>=n)throw new RangeError("min must be smaller than max");let s=n-o,h=new z(t,e);for(let r=0;r<t;r++)for(let t=0;t<e;t++){let e=o+Math.round(i()*s);h.set(r,t,e)}return h}static eye(t,e,r){void 0===e&&(e=t),void 0===r&&(r=1);let o=Math.min(t,e),n=this.zeros(t,e);for(let t=0;t<o;t++)n.set(t,t,r);return n}static diag(t,e,r){let o=t.length;void 0===e&&(e=o),void 0===r&&(r=e);let n=Math.min(o,e,r),i=this.zeros(e,r);for(let e=0;e<n;e++)i.set(e,e,t[e]);return i}static min(t,e){t=this.checkMatrix(t),e=this.checkMatrix(e);let r=t.rows,o=t.columns,n=new z(r,o);for(let i=0;i<r;i++)for(let r=0;r<o;r++)n.set(i,r,Math.min(t.get(i,r),e.get(i,r)));return n}static max(t,e){t=this.checkMatrix(t),e=this.checkMatrix(e);let r=t.rows,o=t.columns,n=new this(r,o);for(let i=0;i<r;i++)for(let r=0;r<o;r++)n.set(i,r,Math.max(t.get(i,r),e.get(i,r)));return n}static checkMatrix(t){return N.isMatrix(t)?t:new z(t)}static isMatrix(t){return null!=t&&"Matrix"===t.klass}get size(){return this.rows*this.columns}apply(t){if("function"!=typeof t)throw new TypeError("callback must be a function");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)t.call(this,e,r);return this}to1DArray(){let t=[];for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)t.push(this.get(e,r));return t}to2DArray(){let t=[];for(let e=0;e<this.rows;e++){t.push([]);for(let r=0;r<this.columns;r++)t[e].push(this.get(e,r))}return t}toJSON(){return this.to2DArray()}isRowVector(){return 1===this.rows}isColumnVector(){return 1===this.columns}isVector(){return 1===this.rows||1===this.columns}isSquare(){return this.rows===this.columns}isEmpty(){return 0===this.rows||0===this.columns}isSymmetric(){if(this.isSquare()){for(let t=0;t<this.rows;t++)for(let e=0;e<=t;e++)if(this.get(t,e)!==this.get(e,t))return!1;return!0}return!1}isEchelonForm(){let t=0,e=0,r=-1,o=!0,n=!1;for(;t<this.rows&&o;){for(e=0,n=!1;e<this.columns&&!1===n;)0===this.get(t,e)?e++:1===this.get(t,e)&&e>r?(n=!0,r=e):(o=!1,n=!0);t++}return o}isReducedEchelonForm(){let t=0,e=0,r=-1,o=!0,n=!1;for(;t<this.rows&&o;){for(e=0,n=!1;e<this.columns&&!1===n;)0===this.get(t,e)?e++:1===this.get(t,e)&&e>r?(n=!0,r=e):(o=!1,n=!0);for(let r=e+1;r<this.rows;r++)0!==this.get(t,r)&&(o=!1);t++}return o}echelonForm(){let t=this.clone(),e=0,r=0;for(;e<t.rows&&r<t.columns;){let o=e;for(let n=e;n<t.rows;n++)t.get(n,r)>t.get(o,r)&&(o=n);if(0===t.get(o,r))r++;else{t.swapRows(e,o);let n=t.get(e,r);for(let o=r;o<t.columns;o++)t.set(e,o,t.get(e,o)/n);for(let o=e+1;o<t.rows;o++){let n=t.get(o,r)/t.get(e,r);t.set(o,r,0);for(let i=r+1;i<t.columns;i++)t.set(o,i,t.get(o,i)-t.get(e,i)*n)}e++,r++}}return t}reducedEchelonForm(){let t=this.echelonForm(),e=t.columns,r=t.rows,o=r-1;for(;o>=0;)if(0===t.maxRow(o))o--;else{let n=0,i=!1;for(;n<r&&!1===i;)1===t.get(o,n)?i=!0:n++;for(let r=0;r<o;r++){let i=t.get(r,n);for(let s=n;s<e;s++){let e=t.get(r,s)-i*t.get(o,s);t.set(r,s,e)}}o--}return t}set(){throw new Error("set method is unimplemented")}get(){throw new Error("get method is unimplemented")}repeat(t={}){if("object"!=typeof t)throw new TypeError("options must be an object");const{rows:e=1,columns:r=1}=t;if(!Number.isInteger(e)||e<=0)throw new TypeError("rows must be a positive integer");if(!Number.isInteger(r)||r<=0)throw new TypeError("columns must be a positive integer");let o=new z(this.rows*e,this.columns*r);for(let t=0;t<e;t++)for(let e=0;e<r;e++)o.setSubMatrix(this,this.rows*t,this.columns*e);return o}fill(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,t);return this}neg(){return this.mulS(-1)}getRow(t){y(this,t);let e=[];for(let r=0;r<this.columns;r++)e.push(this.get(t,r));return e}getRowVector(t){return z.rowVector(this.getRow(t))}setRow(t,e){y(this,t),e=b(this,e);for(let r=0;r<this.columns;r++)this.set(t,r,e[r]);return this}swapRows(t,e){y(this,t),y(this,e);for(let r=0;r<this.columns;r++){let o=this.get(t,r);this.set(t,r,this.get(e,r)),this.set(e,r,o)}return this}getColumn(t){v(this,t);let e=[];for(let r=0;r<this.rows;r++)e.push(this.get(r,t));return e}getColumnVector(t){return z.columnVector(this.getColumn(t))}setColumn(t,e){v(this,t),e=M(this,e);for(let r=0;r<this.rows;r++)this.set(r,t,e[r]);return this}swapColumns(t,e){v(this,t),v(this,e);for(let r=0;r<this.rows;r++){let o=this.get(r,t);this.set(r,t,this.get(r,e)),this.set(r,e,o)}return this}addRowVector(t){t=b(this,t);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)+t[r]);return this}subRowVector(t){t=b(this,t);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)-t[r]);return this}mulRowVector(t){t=b(this,t);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)*t[r]);return this}divRowVector(t){t=b(this,t);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)/t[r]);return this}addColumnVector(t){t=M(this,t);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)+t[e]);return this}subColumnVector(t){t=M(this,t);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)-t[e]);return this}mulColumnVector(t){t=M(this,t);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)*t[e]);return this}divColumnVector(t){t=M(this,t);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)/t[e]);return this}mulRow(t,e){y(this,t);for(let r=0;r<this.columns;r++)this.set(t,r,this.get(t,r)*e);return this}mulColumn(t,e){v(this,t);for(let r=0;r<this.rows;r++)this.set(r,t,this.get(r,t)*e);return this}max(t){if(this.isEmpty())return NaN;switch(t){case"row":{const t=new Array(this.rows).fill(Number.NEGATIVE_INFINITY);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.get(e,r)>t[e]&&(t[e]=this.get(e,r));return t}case"column":{const t=new Array(this.columns).fill(Number.NEGATIVE_INFINITY);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.get(e,r)>t[r]&&(t[r]=this.get(e,r));return t}case void 0:{let t=this.get(0,0);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.get(e,r)>t&&(t=this.get(e,r));return t}default:throw new Error(`invalid option: ${t}`)}}maxIndex(){R(this);let t=this.get(0,0),e=[0,0];for(let r=0;r<this.rows;r++)for(let o=0;o<this.columns;o++)this.get(r,o)>t&&(t=this.get(r,o),e[0]=r,e[1]=o);return e}min(t){if(this.isEmpty())return NaN;switch(t){case"row":{const t=new Array(this.rows).fill(Number.POSITIVE_INFINITY);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.get(e,r)<t[e]&&(t[e]=this.get(e,r));return t}case"column":{const t=new Array(this.columns).fill(Number.POSITIVE_INFINITY);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.get(e,r)<t[r]&&(t[r]=this.get(e,r));return t}case void 0:{let t=this.get(0,0);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.get(e,r)<t&&(t=this.get(e,r));return t}default:throw new Error(`invalid option: ${t}`)}}minIndex(){R(this);let t=this.get(0,0),e=[0,0];for(let r=0;r<this.rows;r++)for(let o=0;o<this.columns;o++)this.get(r,o)<t&&(t=this.get(r,o),e[0]=r,e[1]=o);return e}maxRow(t){if(y(this,t),this.isEmpty())return NaN;let e=this.get(t,0);for(let r=1;r<this.columns;r++)this.get(t,r)>e&&(e=this.get(t,r));return e}maxRowIndex(t){y(this,t),R(this);let e=this.get(t,0),r=[t,0];for(let o=1;o<this.columns;o++)this.get(t,o)>e&&(e=this.get(t,o),r[1]=o);return r}minRow(t){if(y(this,t),this.isEmpty())return NaN;let e=this.get(t,0);for(let r=1;r<this.columns;r++)this.get(t,r)<e&&(e=this.get(t,r));return e}minRowIndex(t){y(this,t),R(this);let e=this.get(t,0),r=[t,0];for(let o=1;o<this.columns;o++)this.get(t,o)<e&&(e=this.get(t,o),r[1]=o);return r}maxColumn(t){if(v(this,t),this.isEmpty())return NaN;let e=this.get(0,t);for(let r=1;r<this.rows;r++)this.get(r,t)>e&&(e=this.get(r,t));return e}maxColumnIndex(t){v(this,t),R(this);let e=this.get(0,t),r=[0,t];for(let o=1;o<this.rows;o++)this.get(o,t)>e&&(e=this.get(o,t),r[0]=o);return r}minColumn(t){if(v(this,t),this.isEmpty())return NaN;let e=this.get(0,t);for(let r=1;r<this.rows;r++)this.get(r,t)<e&&(e=this.get(r,t));return e}minColumnIndex(t){v(this,t),R(this);let e=this.get(0,t),r=[0,t];for(let o=1;o<this.rows;o++)this.get(o,t)<e&&(e=this.get(o,t),r[0]=o);return r}diag(){let t=Math.min(this.rows,this.columns),e=[];for(let r=0;r<t;r++)e.push(this.get(r,r));return e}norm(t="frobenius"){let e=0;if("max"===t)return this.max();if("frobenius"===t){for(let t=0;t<this.rows;t++)for(let r=0;r<this.columns;r++)e+=this.get(t,r)*this.get(t,r);return Math.sqrt(e)}throw new RangeError(`unknown norm type: ${t}`)}cumulativeSum(){let t=0;for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)t+=this.get(e,r),this.set(e,r,t);return this}dot(t){N.isMatrix(t)&&(t=t.to1DArray());let e=this.to1DArray();if(e.length!==t.length)throw new RangeError("vectors do not have the same size");let r=0;for(let o=0;o<e.length;o++)r+=e[o]*t[o];return r}mmul(t){t=z.checkMatrix(t);let e=this.rows,r=this.columns,o=t.columns,n=new z(e,o),i=new Float64Array(r);for(let s=0;s<o;s++){for(let e=0;e<r;e++)i[e]=t.get(e,s);for(let t=0;t<e;t++){let e=0;for(let o=0;o<r;o++)e+=this.get(t,o)*i[o];n.set(t,s,e)}}return n}strassen2x2(t){t=z.checkMatrix(t);let e=new z(2,2);const r=this.get(0,0),o=t.get(0,0),n=this.get(0,1),i=t.get(0,1),s=this.get(1,0),h=t.get(1,0),a=this.get(1,1),u=t.get(1,1),l=(r+a)*(o+u),f=(s+a)*o,c=r*(i-u),m=a*(h-o),p=(r+n)*u,g=l+m-p+(n-a)*(h+u),w=c+p,d=f+m,y=l-f+c+(s-r)*(o+i);return e.set(0,0,g),e.set(0,1,w),e.set(1,0,d),e.set(1,1,y),e}strassen3x3(t){t=z.checkMatrix(t);let e=new z(3,3);const r=this.get(0,0),o=this.get(0,1),n=this.get(0,2),i=this.get(1,0),s=this.get(1,1),h=this.get(1,2),a=this.get(2,0),u=this.get(2,1),l=this.get(2,2),f=t.get(0,0),c=t.get(0,1),m=t.get(0,2),p=t.get(1,0),g=t.get(1,1),w=t.get(1,2),d=t.get(2,0),y=t.get(2,1),v=t.get(2,2),b=(r-i)*(-c+g),M=(-r+i+s)*(f-c+g),x=(i+s)*(-f+c),S=r*f,E=(-r+a+u)*(f-m+w),R=(-r+a)*(m-w),N=(a+u)*(-f+m),k=(-n+u+l)*(g+d-y),I=(n-l)*(g-y),F=n*d,T=(u+l)*(-d+y),A=(-n+s+h)*(w+d-v),C=(n-h)*(w-v),_=(s+h)*(-d+v),P=S+F+o*p,V=(r+o+n-i-s-u-l)*g+M+x+S+k+F+T,O=S+E+N+(r+o+n-s-h-a-u)*w+F+A+_,j=b+s*(-f+c+p-g-w-d+v)+M+S+F+A+C,q=b+M+x+S+h*y,D=F+A+C+_+i*m,L=S+E+R+u*(-f+m+p-g-w-d+y)+k+I+F,$=k+I+F+T+a*c,U=S+E+R+N+l*v;return e.set(0,0,P),e.set(0,1,V),e.set(0,2,O),e.set(1,0,j),e.set(1,1,q),e.set(1,2,D),e.set(2,0,L),e.set(2,1,$),e.set(2,2,U),e}mmulStrassen(t){t=z.checkMatrix(t);let e=this.clone(),r=e.rows,o=e.columns,n=t.rows,i=t.columns;function s(t,e,r){let o=t.rows,n=t.columns;if(o===e&&n===r)return t;{let o=N.zeros(e,r);return o=o.setSubMatrix(t,0,0),o}}o!==n&&console.warn(`Multiplying ${r} x ${o} and ${n} x ${i} matrix: dimensions do not match.`);let h=Math.max(r,n),a=Math.max(o,i);return e=s(e,h,a),function t(e,r,o,n){if(o<=512||n<=512)return e.mmul(r);o%2==1&&n%2==1?(e=s(e,o+1,n+1),r=s(r,o+1,n+1)):o%2==1?(e=s(e,o+1,n),r=s(r,o+1,n)):n%2==1&&(e=s(e,o,n+1),r=s(r,o,n+1));let i=parseInt(e.rows/2,10),h=parseInt(e.columns/2,10),a=e.subMatrix(0,i-1,0,h-1),u=r.subMatrix(0,i-1,0,h-1),l=e.subMatrix(0,i-1,h,e.columns-1),f=r.subMatrix(0,i-1,h,r.columns-1),c=e.subMatrix(i,e.rows-1,0,h-1),m=r.subMatrix(i,r.rows-1,0,h-1),p=e.subMatrix(i,e.rows-1,h,e.columns-1),g=r.subMatrix(i,r.rows-1,h,r.columns-1),w=t(N.add(a,p),N.add(u,g),i,h),d=t(N.add(c,p),u,i,h),y=t(a,N.sub(f,g),i,h),v=t(p,N.sub(m,u),i,h),b=t(N.add(a,l),g,i,h),M=t(N.sub(c,a),N.add(u,f),i,h),x=t(N.sub(l,p),N.add(m,g),i,h),S=N.add(w,v);S.sub(b),S.add(x);let E=N.add(y,b),R=N.add(d,v),k=N.sub(w,d);k.add(y),k.add(M);let z=N.zeros(2*S.rows,2*S.columns);return z=z.setSubMatrix(S,0,0),z=z.setSubMatrix(E,S.rows,0),z=z.setSubMatrix(R,0,S.columns),z=z.setSubMatrix(k,S.rows,S.columns),z.subMatrix(0,o-1,0,n-1)}(e,t=s(t,h,a),h,a)}scaleRows(t={}){if("object"!=typeof t)throw new TypeError("options must be an object");const{min:e=0,max:r=1}=t;if(!Number.isFinite(e))throw new TypeError("min must be a number");if(!Number.isFinite(r))throw new TypeError("max must be a number");if(e>=r)throw new RangeError("min must be smaller than max");let o=new z(this.rows,this.columns);for(let t=0;t<this.rows;t++){const n=this.getRow(t);n.length>0&&c(n,{min:e,max:r,output:n}),o.setRow(t,n)}return o}scaleColumns(t={}){if("object"!=typeof t)throw new TypeError("options must be an object");const{min:e=0,max:r=1}=t;if(!Number.isFinite(e))throw new TypeError("min must be a number");if(!Number.isFinite(r))throw new TypeError("max must be a number");if(e>=r)throw new RangeError("min must be smaller than max");let o=new z(this.rows,this.columns);for(let t=0;t<this.columns;t++){const n=this.getColumn(t);n.length&&c(n,{min:e,max:r,output:n}),o.setColumn(t,n)}return o}flipRows(){const t=Math.ceil(this.columns/2);for(let e=0;e<this.rows;e++)for(let r=0;r<t;r++){let t=this.get(e,r),o=this.get(e,this.columns-1-r);this.set(e,r,o),this.set(e,this.columns-1-r,t)}return this}flipColumns(){const t=Math.ceil(this.rows/2);for(let e=0;e<this.columns;e++)for(let r=0;r<t;r++){let t=this.get(r,e),o=this.get(this.rows-1-r,e);this.set(r,e,o),this.set(this.rows-1-r,e,t)}return this}kroneckerProduct(t){t=z.checkMatrix(t);let e=this.rows,r=this.columns,o=t.rows,n=t.columns,i=new z(e*o,r*n);for(let s=0;s<e;s++)for(let e=0;e<r;e++)for(let r=0;r<o;r++)for(let h=0;h<n;h++)i.set(o*s+r,n*e+h,this.get(s,e)*t.get(r,h));return i}kroneckerSum(t){if(t=z.checkMatrix(t),!this.isSquare()||!t.isSquare())throw new Error("Kronecker Sum needs two Square Matrices");let e=this.rows,r=t.rows,o=this.kroneckerProduct(z.eye(r,r)),n=z.eye(e,e).kroneckerProduct(t);return o.add(n)}transpose(){let t=new z(this.columns,this.rows);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)t.set(r,e,this.get(e,r));return t}sortRows(t=k){for(let e=0;e<this.rows;e++)this.setRow(e,this.getRow(e).sort(t));return this}sortColumns(t=k){for(let e=0;e<this.columns;e++)this.setColumn(e,this.getColumn(e).sort(t));return this}subMatrix(t,e,r,o){x(this,t,e,r,o);let n=new z(e-t+1,o-r+1);for(let i=t;i<=e;i++)for(let e=r;e<=o;e++)n.set(i-t,e-r,this.get(i,e));return n}subMatrixRow(t,e,r){if(void 0===e&&(e=0),void 0===r&&(r=this.columns-1),e>r||e<0||e>=this.columns||r<0||r>=this.columns)throw new RangeError("Argument out of range");let o=new z(t.length,r-e+1);for(let n=0;n<t.length;n++)for(let i=e;i<=r;i++){if(t[n]<0||t[n]>=this.rows)throw new RangeError(`Row index out of range: ${t[n]}`);o.set(n,i-e,this.get(t[n],i))}return o}subMatrixColumn(t,e,r){if(void 0===e&&(e=0),void 0===r&&(r=this.rows-1),e>r||e<0||e>=this.rows||r<0||r>=this.rows)throw new RangeError("Argument out of range");let o=new z(r-e+1,t.length);for(let n=0;n<t.length;n++)for(let i=e;i<=r;i++){if(t[n]<0||t[n]>=this.columns)throw new RangeError(`Column index out of range: ${t[n]}`);o.set(i-e,n,this.get(i,t[n]))}return o}setSubMatrix(t,e,r){if((t=z.checkMatrix(t)).isEmpty())return this;x(this,e,e+t.rows-1,r,r+t.columns-1);for(let o=0;o<t.rows;o++)for(let n=0;n<t.columns;n++)this.set(e+o,r+n,t.get(o,n));return this}selection(t,e){!function(t,e){if(!h(e))throw new TypeError("row indices must be an array");for(let r=0;r<e.length;r++)if(e[r]<0||e[r]>=t.rows)throw new RangeError("row indices are out of range")}(this,t),function(t,e){if(!h(e))throw new TypeError("column indices must be an array");for(let r=0;r<e.length;r++)if(e[r]<0||e[r]>=t.columns)throw new RangeError("column indices are out of range")}(this,e);let r=new z(t.length,e.length);for(let o=0;o<t.length;o++){let n=t[o];for(let t=0;t<e.length;t++){let i=e[t];r.set(o,t,this.get(n,i))}}return r}trace(){let t=Math.min(this.rows,this.columns),e=0;for(let r=0;r<t;r++)e+=this.get(r,r);return e}clone(){let t=new z(this.rows,this.columns);for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)t.set(e,r,this.get(e,r));return t}sum(t){switch(t){case"row":return function(t){let e=S(t.rows);for(let r=0;r<t.rows;++r)for(let o=0;o<t.columns;++o)e[r]+=t.get(r,o);return e}(this);case"column":return function(t){let e=S(t.columns);for(let r=0;r<t.rows;++r)for(let o=0;o<t.columns;++o)e[o]+=t.get(r,o);return e}(this);case void 0:return function(t){let e=0;for(let r=0;r<t.rows;r++)for(let o=0;o<t.columns;o++)e+=t.get(r,o);return e}(this);default:throw new Error(`invalid option: ${t}`)}}product(t){switch(t){case"row":return function(t){let e=S(t.rows,1);for(let r=0;r<t.rows;++r)for(let o=0;o<t.columns;++o)e[r]*=t.get(r,o);return e}(this);case"column":return function(t){let e=S(t.columns,1);for(let r=0;r<t.rows;++r)for(let o=0;o<t.columns;++o)e[o]*=t.get(r,o);return e}(this);case void 0:return function(t){let e=1;for(let r=0;r<t.rows;r++)for(let o=0;o<t.columns;o++)e*=t.get(r,o);return e}(this);default:throw new Error(`invalid option: ${t}`)}}mean(t){const e=this.sum(t);switch(t){case"row":for(let t=0;t<this.rows;t++)e[t]/=this.columns;return e;case"column":for(let t=0;t<this.columns;t++)e[t]/=this.rows;return e;case void 0:return e/this.size;default:throw new Error(`invalid option: ${t}`)}}variance(t,e={}){if("object"==typeof t&&(e=t,t=void 0),"object"!=typeof e)throw new TypeError("options must be an object");const{unbiased:r=!0,mean:o=this.mean(t)}=e;if("boolean"!=typeof r)throw new TypeError("unbiased must be a boolean");switch(t){case"row":if(!h(o))throw new TypeError("mean must be an array");return function(t,e,r){const o=t.rows,n=t.columns,i=[];for(let s=0;s<o;s++){let o=0,h=0,a=0;for(let e=0;e<n;e++)a=t.get(s,e)-r[s],o+=a,h+=a*a;e?i.push((h-o*o/n)/(n-1)):i.push((h-o*o/n)/n)}return i}(this,r,o);case"column":if(!h(o))throw new TypeError("mean must be an array");return function(t,e,r){const o=t.rows,n=t.columns,i=[];for(let s=0;s<n;s++){let n=0,h=0,a=0;for(let e=0;e<o;e++)a=t.get(e,s)-r[s],n+=a,h+=a*a;e?i.push((h-n*n/o)/(o-1)):i.push((h-n*n/o)/o)}return i}(this,r,o);case void 0:if("number"!=typeof o)throw new TypeError("mean must be a number");return function(t,e,r){const o=t.rows,n=t.columns,i=o*n;let s=0,h=0,a=0;for(let e=0;e<o;e++)for(let o=0;o<n;o++)a=t.get(e,o)-r,s+=a,h+=a*a;return e?(h-s*s/i)/(i-1):(h-s*s/i)/i}(this,r,o);default:throw new Error(`invalid option: ${t}`)}}standardDeviation(t,e){"object"==typeof t&&(e=t,t=void 0);const r=this.variance(t,e);if(void 0===t)return Math.sqrt(r);for(let t=0;t<r.length;t++)r[t]=Math.sqrt(r[t]);return r}center(t,e={}){if("object"==typeof t&&(e=t,t=void 0),"object"!=typeof e)throw new TypeError("options must be an object");const{center:r=this.mean(t)}=e;switch(t){case"row":if(!h(r))throw new TypeError("center must be an array");return function(t,e){for(let r=0;r<t.rows;r++)for(let o=0;o<t.columns;o++)t.set(r,o,t.get(r,o)-e[r])}(this,r),this;case"column":if(!h(r))throw new TypeError("center must be an array");return function(t,e){for(let r=0;r<t.rows;r++)for(let o=0;o<t.columns;o++)t.set(r,o,t.get(r,o)-e[o])}(this,r),this;case void 0:if("number"!=typeof r)throw new TypeError("center must be a number");return function(t,e){for(let r=0;r<t.rows;r++)for(let o=0;o<t.columns;o++)t.set(r,o,t.get(r,o)-e)}(this,r),this;default:throw new Error(`invalid option: ${t}`)}}scale(t,e={}){if("object"==typeof t&&(e=t,t=void 0),"object"!=typeof e)throw new TypeError("options must be an object");let r=e.scale;switch(t){case"row":if(void 0===r)r=function(t){const e=[];for(let r=0;r<t.rows;r++){let o=0;for(let e=0;e<t.columns;e++)o+=Math.pow(t.get(r,e),2)/(t.columns-1);e.push(Math.sqrt(o))}return e}(this);else if(!h(r))throw new TypeError("scale must be an array");return function(t,e){for(let r=0;r<t.rows;r++)for(let o=0;o<t.columns;o++)t.set(r,o,t.get(r,o)/e[r])}(this,r),this;case"column":if(void 0===r)r=function(t){const e=[];for(let r=0;r<t.columns;r++){let o=0;for(let e=0;e<t.rows;e++)o+=Math.pow(t.get(e,r),2)/(t.rows-1);e.push(Math.sqrt(o))}return e}(this);else if(!h(r))throw new TypeError("scale must be an array");return function(t,e){for(let r=0;r<t.rows;r++)for(let o=0;o<t.columns;o++)t.set(r,o,t.get(r,o)/e[o])}(this,r),this;case void 0:if(void 0===r)r=function(t){const e=t.size-1;let r=0;for(let o=0;o<t.columns;o++)for(let n=0;n<t.rows;n++)r+=Math.pow(t.get(n,o),2)/e;return Math.sqrt(r)}(this);else if("number"!=typeof r)throw new TypeError("scale must be a number");return function(t,e){for(let r=0;r<t.rows;r++)for(let o=0;o<t.columns;o++)t.set(r,o,t.get(r,o)/e)}(this,r),this;default:throw new Error(`invalid option: ${t}`)}}toString(t){return g(this,t)}}function k(t,e){return t-e}N.prototype.klass="Matrix","undefined"!=typeof Symbol&&(N.prototype[Symbol.for("nodejs.util.inspect.custom")]=function(){return g(this)}),N.random=N.rand,N.randomInt=N.randInt,N.diagonal=N.diag,N.prototype.diagonal=N.prototype.diag,N.identity=N.eye,N.prototype.negate=N.prototype.neg,N.prototype.tensorProduct=N.prototype.kroneckerProduct;class z extends N{constructor(t,e){if(super(),z.isMatrix(t))return t.clone();if(Number.isInteger(t)&&t>=0){if(this.data=[],!(Number.isInteger(e)&&e>=0))throw new TypeError("nColumns must be a positive integer");for(let r=0;r<t;r++)this.data.push(new Float64Array(e))}else{if(!h(t))throw new TypeError("First argument must be a positive number or an array");{const r=t;if("number"!=typeof(e=(t=r.length)?r[0].length:0))throw new TypeError("Data must be a 2D array with at least one element");this.data=[];for(let o=0;o<t;o++){if(r[o].length!==e)throw new RangeError("Inconsistent array dimensions");if(!r[o].every((t=>"number"==typeof t)))throw new TypeError("Input data contains non-numeric values");this.data.push(Float64Array.from(r[o]))}}}this.rows=t,this.columns=e}set(t,e,r){return this.data[t][e]=r,this}get(t,e){return this.data[t][e]}removeRow(t){return y(this,t),this.data.splice(t,1),this.rows-=1,this}addRow(t,e){return void 0===e&&(e=t,t=this.rows),y(this,t,!0),e=Float64Array.from(b(this,e)),this.data.splice(t,0,e),this.rows+=1,this}removeColumn(t){v(this,t);for(let e=0;e<this.rows;e++){const r=new Float64Array(this.columns-1);for(let o=0;o<t;o++)r[o]=this.data[e][o];for(let o=t+1;o<this.columns;o++)r[o-1]=this.data[e][o];this.data[e]=r}return this.columns-=1,this}addColumn(t,e){void 0===e&&(e=t,t=this.columns),v(this,t,!0),e=M(this,e);for(let r=0;r<this.rows;r++){const o=new Float64Array(this.columns+1);let n=0;for(;n<t;n++)o[n]=this.data[r][n];for(o[n++]=e[r];n<this.columns+1;n++)o[n]=this.data[r][n-1];this.data[r]=o}return this.columns+=1,this}}!function(t,e){t.prototype.add=function(t){return"number"==typeof t?this.addS(t):this.addM(t)},t.prototype.addS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)+t);return this},t.prototype.addM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)+t.get(e,r));return this},t.add=function(t,r){return new e(t).add(r)},t.prototype.sub=function(t){return"number"==typeof t?this.subS(t):this.subM(t)},t.prototype.subS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)-t);return this},t.prototype.subM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)-t.get(e,r));return this},t.sub=function(t,r){return new e(t).sub(r)},t.prototype.subtract=t.prototype.sub,t.prototype.subtractS=t.prototype.subS,t.prototype.subtractM=t.prototype.subM,t.subtract=t.sub,t.prototype.mul=function(t){return"number"==typeof t?this.mulS(t):this.mulM(t)},t.prototype.mulS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)*t);return this},t.prototype.mulM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)*t.get(e,r));return this},t.mul=function(t,r){return new e(t).mul(r)},t.prototype.multiply=t.prototype.mul,t.prototype.multiplyS=t.prototype.mulS,t.prototype.multiplyM=t.prototype.mulM,t.multiply=t.mul,t.prototype.div=function(t){return"number"==typeof t?this.divS(t):this.divM(t)},t.prototype.divS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)/t);return this},t.prototype.divM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)/t.get(e,r));return this},t.div=function(t,r){return new e(t).div(r)},t.prototype.divide=t.prototype.div,t.prototype.divideS=t.prototype.divS,t.prototype.divideM=t.prototype.divM,t.divide=t.div,t.prototype.mod=function(t){return"number"==typeof t?this.modS(t):this.modM(t)},t.prototype.modS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)%t);return this},t.prototype.modM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)%t.get(e,r));return this},t.mod=function(t,r){return new e(t).mod(r)},t.prototype.modulus=t.prototype.mod,t.prototype.modulusS=t.prototype.modS,t.prototype.modulusM=t.prototype.modM,t.modulus=t.mod,t.prototype.and=function(t){return"number"==typeof t?this.andS(t):this.andM(t)},t.prototype.andS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)&t);return this},t.prototype.andM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)&t.get(e,r));return this},t.and=function(t,r){return new e(t).and(r)},t.prototype.or=function(t){return"number"==typeof t?this.orS(t):this.orM(t)},t.prototype.orS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)|t);return this},t.prototype.orM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)|t.get(e,r));return this},t.or=function(t,r){return new e(t).or(r)},t.prototype.xor=function(t){return"number"==typeof t?this.xorS(t):this.xorM(t)},t.prototype.xorS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)^t);return this},t.prototype.xorM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)^t.get(e,r));return this},t.xor=function(t,r){return new e(t).xor(r)},t.prototype.leftShift=function(t){return"number"==typeof t?this.leftShiftS(t):this.leftShiftM(t)},t.prototype.leftShiftS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)<<t);return this},t.prototype.leftShiftM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)<<t.get(e,r));return this},t.leftShift=function(t,r){return new e(t).leftShift(r)},t.prototype.signPropagatingRightShift=function(t){return"number"==typeof t?this.signPropagatingRightShiftS(t):this.signPropagatingRightShiftM(t)},t.prototype.signPropagatingRightShiftS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)>>t);return this},t.prototype.signPropagatingRightShiftM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)>>t.get(e,r));return this},t.signPropagatingRightShift=function(t,r){return new e(t).signPropagatingRightShift(r)},t.prototype.rightShift=function(t){return"number"==typeof t?this.rightShiftS(t):this.rightShiftM(t)},t.prototype.rightShiftS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)>>>t);return this},t.prototype.rightShiftM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,this.get(e,r)>>>t.get(e,r));return this},t.rightShift=function(t,r){return new e(t).rightShift(r)},t.prototype.zeroFillRightShift=t.prototype.rightShift,t.prototype.zeroFillRightShiftS=t.prototype.rightShiftS,t.prototype.zeroFillRightShiftM=t.prototype.rightShiftM,t.zeroFillRightShift=t.rightShift,t.prototype.not=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,~this.get(t,e));return this},t.not=function(t){return new e(t).not()},t.prototype.abs=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.abs(this.get(t,e)));return this},t.abs=function(t){return new e(t).abs()},t.prototype.acos=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.acos(this.get(t,e)));return this},t.acos=function(t){return new e(t).acos()},t.prototype.acosh=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.acosh(this.get(t,e)));return this},t.acosh=function(t){return new e(t).acosh()},t.prototype.asin=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.asin(this.get(t,e)));return this},t.asin=function(t){return new e(t).asin()},t.prototype.asinh=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.asinh(this.get(t,e)));return this},t.asinh=function(t){return new e(t).asinh()},t.prototype.atan=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.atan(this.get(t,e)));return this},t.atan=function(t){return new e(t).atan()},t.prototype.atanh=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.atanh(this.get(t,e)));return this},t.atanh=function(t){return new e(t).atanh()},t.prototype.cbrt=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.cbrt(this.get(t,e)));return this},t.cbrt=function(t){return new e(t).cbrt()},t.prototype.ceil=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.ceil(this.get(t,e)));return this},t.ceil=function(t){return new e(t).ceil()},t.prototype.clz32=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.clz32(this.get(t,e)));return this},t.clz32=function(t){return new e(t).clz32()},t.prototype.cos=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.cos(this.get(t,e)));return this},t.cos=function(t){return new e(t).cos()},t.prototype.cosh=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.cosh(this.get(t,e)));return this},t.cosh=function(t){return new e(t).cosh()},t.prototype.exp=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.exp(this.get(t,e)));return this},t.exp=function(t){return new e(t).exp()},t.prototype.expm1=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.expm1(this.get(t,e)));return this},t.expm1=function(t){return new e(t).expm1()},t.prototype.floor=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.floor(this.get(t,e)));return this},t.floor=function(t){return new e(t).floor()},t.prototype.fround=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.fround(this.get(t,e)));return this},t.fround=function(t){return new e(t).fround()},t.prototype.log=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.log(this.get(t,e)));return this},t.log=function(t){return new e(t).log()},t.prototype.log1p=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.log1p(this.get(t,e)));return this},t.log1p=function(t){return new e(t).log1p()},t.prototype.log10=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.log10(this.get(t,e)));return this},t.log10=function(t){return new e(t).log10()},t.prototype.log2=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.log2(this.get(t,e)));return this},t.log2=function(t){return new e(t).log2()},t.prototype.round=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.round(this.get(t,e)));return this},t.round=function(t){return new e(t).round()},t.prototype.sign=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.sign(this.get(t,e)));return this},t.sign=function(t){return new e(t).sign()},t.prototype.sin=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.sin(this.get(t,e)));return this},t.sin=function(t){return new e(t).sin()},t.prototype.sinh=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.sinh(this.get(t,e)));return this},t.sinh=function(t){return new e(t).sinh()},t.prototype.sqrt=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.sqrt(this.get(t,e)));return this},t.sqrt=function(t){return new e(t).sqrt()},t.prototype.tan=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.tan(this.get(t,e)));return this},t.tan=function(t){return new e(t).tan()},t.prototype.tanh=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.tanh(this.get(t,e)));return this},t.tanh=function(t){return new e(t).tanh()},t.prototype.trunc=function(){for(let t=0;t<this.rows;t++)for(let e=0;e<this.columns;e++)this.set(t,e,Math.trunc(this.get(t,e)));return this},t.trunc=function(t){return new e(t).trunc()},t.pow=function(t,r){return new e(t).pow(r)},t.prototype.pow=function(t){return"number"==typeof t?this.powS(t):this.powM(t)},t.prototype.powS=function(t){for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,Math.pow(this.get(e,r),t));return this},t.prototype.powM=function(t){if(t=e.checkMatrix(t),this.rows!==t.rows||this.columns!==t.columns)throw new RangeError("Matrices dimensions must be equal");for(let e=0;e<this.rows;e++)for(let r=0;r<this.columns;r++)this.set(e,r,Math.pow(this.get(e,r),t.get(e,r)));return this}}(N,z);class I extends N{constructor(t){super(),this.data=t,this.rows=t.length,this.columns=t[0].length}set(t,e,r){return this.data[t][e]=r,this}get(t,e){return this.data[t][e]}}class F{constructor(t){let e,r,o,n,i,s,h,a,u,l=(t=I.checkMatrix(t)).clone(),f=l.rows,c=l.columns,m=new Float64Array(f),p=1;for(e=0;e<f;e++)m[e]=e;for(a=new Float64Array(f),r=0;r<c;r++){for(e=0;e<f;e++)a[e]=l.get(e,r);for(e=0;e<f;e++){for(u=Math.min(e,r),i=0,o=0;o<u;o++)i+=l.get(e,o)*a[o];a[e]-=i,l.set(e,r,a[e])}for(n=r,e=r+1;e<f;e++)Math.abs(a[e])>Math.abs(a[n])&&(n=e);if(n!==r){for(o=0;o<c;o++)s=l.get(n,o),l.set(n,o,l.get(r,o)),l.set(r,o,s);h=m[n],m[n]=m[r],m[r]=h,p=-p}if(r<f&&0!==l.get(r,r))for(e=r+1;e<f;e++)l.set(e,r,l.get(e,r)/l.get(r,r))}this.LU=l,this.pivotVector=m,this.pivotSign=p}isSingular(){let t=this.LU,e=t.columns;for(let r=0;r<e;r++)if(0===t.get(r,r))return!0;return!1}solve(t){t=z.checkMatrix(t);let e=this.LU;if(e.rows!==t.rows)throw new Error("Invalid matrix dimensions");if(this.isSingular())throw new Error("LU matrix is singular");let r,o,n,i=t.columns,s=t.subMatrixRow(this.pivotVector,0,i-1),h=e.columns;for(n=0;n<h;n++)for(r=n+1;r<h;r++)for(o=0;o<i;o++)s.set(r,o,s.get(r,o)-s.get(n,o)*e.get(r,n));for(n=h-1;n>=0;n--){for(o=0;o<i;o++)s.set(n,o,s.get(n,o)/e.get(n,n));for(r=0;r<n;r++)for(o=0;o<i;o++)s.set(r,o,s.get(r,o)-s.get(n,o)*e.get(r,n))}return s}get determinant(){let t=this.LU;if(!t.isSquare())throw new Error("Matrix must be square");let e=this.pivotSign,r=t.columns;for(let o=0;o<r;o++)e*=t.get(o,o);return e}get lowerTriangularMatrix(){let t=this.LU,e=t.rows,r=t.columns,o=new z(e,r);for(let n=0;n<e;n++)for(let e=0;e<r;e++)n>e?o.set(n,e,t.get(n,e)):n===e?o.set(n,e,1):o.set(n,e,0);return o}get upperTriangularMatrix(){let t=this.LU,e=t.rows,r=t.columns,o=new z(e,r);for(let n=0;n<e;n++)for(let e=0;e<r;e++)n<=e?o.set(n,e,t.get(n,e)):o.set(n,e,0);return o}get pivotPermutationVector(){return Array.from(this.pivotVector)}}function T(t,e){let r=0;return Math.abs(t)>Math.abs(e)?(r=e/t,Math.abs(t)*Math.sqrt(1+r*r)):0!==e?(r=t/e,Math.abs(e)*Math.sqrt(1+r*r)):0}class A{constructor(t){let e,r,o,n,i=(t=I.checkMatrix(t)).clone(),s=t.rows,h=t.columns,a=new Float64Array(h);for(o=0;o<h;o++){let t=0;for(e=o;e<s;e++)t=T(t,i.get(e,o));if(0!==t){for(i.get(o,o)<0&&(t=-t),e=o;e<s;e++)i.set(e,o,i.get(e,o)/t);for(i.set(o,o,i.get(o,o)+1),r=o+1;r<h;r++){for(n=0,e=o;e<s;e++)n+=i.get(e,o)*i.get(e,r);for(n=-n/i.get(o,o),e=o;e<s;e++)i.set(e,r,i.get(e,r)+n*i.get(e,o))}}a[o]=-t}this.QR=i,this.Rdiag=a}solve(t){t=z.checkMatrix(t);let e=this.QR,r=e.rows;if(t.rows!==r)throw new Error("Matrix row dimensions must agree");if(!this.isFullRank())throw new Error("Matrix is rank deficient");let o,n,i,s,h=t.columns,a=t.clone(),u=e.columns;for(i=0;i<u;i++)for(n=0;n<h;n++){for(s=0,o=i;o<r;o++)s+=e.get(o,i)*a.get(o,n);for(s=-s/e.get(i,i),o=i;o<r;o++)a.set(o,n,a.get(o,n)+s*e.get(o,i))}for(i=u-1;i>=0;i--){for(n=0;n<h;n++)a.set(i,n,a.get(i,n)/this.Rdiag[i]);for(o=0;o<i;o++)for(n=0;n<h;n++)a.set(o,n,a.get(o,n)-a.get(i,n)*e.get(o,i))}return a.subMatrix(0,u-1,0,h-1)}isFullRank(){let t=this.QR.columns;for(let e=0;e<t;e++)if(0===this.Rdiag[e])return!1;return!0}get upperTriangularMatrix(){let t,e,r=this.QR,o=r.columns,n=new z(o,o);for(t=0;t<o;t++)for(e=0;e<o;e++)t<e?n.set(t,e,r.get(t,e)):t===e?n.set(t,e,this.Rdiag[t]):n.set(t,e,0);return n}get orthogonalMatrix(){let t,e,r,o,n=this.QR,i=n.rows,s=n.columns,h=new z(i,s);for(r=s-1;r>=0;r--){for(t=0;t<i;t++)h.set(t,r,0);for(h.set(r,r,1),e=r;e<s;e++)if(0!==n.get(r,r)){for(o=0,t=r;t<i;t++)o+=n.get(t,r)*h.get(t,e);for(o=-o/n.get(r,r),t=r;t<i;t++)h.set(t,e,h.get(t,e)+o*n.get(t,r))}}return h}}class C{constructor(t,e={}){if((t=I.checkMatrix(t)).isEmpty())throw new Error("Matrix must be non-empty");let r=t.rows,o=t.columns;const{computeLeftSingularVectors:n=!0,computeRightSingularVectors:i=!0,autoTranspose:s=!1}=e;let h,a=Boolean(n),u=Boolean(i),l=!1;if(r<o)if(s){h=t.transpose(),r=h.rows,o=h.columns,l=!0;let e=a;a=u,u=e}else h=t.clone(),console.warn("Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose");else h=t.clone();let f=Math.min(r,o),c=Math.min(r+1,o),m=new Float64Array(c),p=new z(r,f),g=new z(o,o),w=new Float64Array(o),d=new Float64Array(r),y=new Float64Array(c);for(let t=0;t<c;t++)y[t]=t;let v=Math.min(r-1,o),b=Math.max(0,Math.min(o-2,r)),M=Math.max(v,b);for(let t=0;t<M;t++){if(t<v){m[t]=0;for(let e=t;e<r;e++)m[t]=T(m[t],h.get(e,t));if(0!==m[t]){h.get(t,t)<0&&(m[t]=-m[t]);for(let e=t;e<r;e++)h.set(e,t,h.get(e,t)/m[t]);h.set(t,t,h.get(t,t)+1)}m[t]=-m[t]}for(let e=t+1;e<o;e++){if(t<v&&0!==m[t]){let o=0;for(let n=t;n<r;n++)o+=h.get(n,t)*h.get(n,e);o=-o/h.get(t,t);for(let n=t;n<r;n++)h.set(n,e,h.get(n,e)+o*h.get(n,t))}w[e]=h.get(t,e)}if(a&&t<v)for(let e=t;e<r;e++)p.set(e,t,h.get(e,t));if(t<b){w[t]=0;for(let e=t+1;e<o;e++)w[t]=T(w[t],w[e]);if(0!==w[t]){w[t+1]<0&&(w[t]=0-w[t]);for(let e=t+1;e<o;e++)w[e]/=w[t];w[t+1]+=1}if(w[t]=-w[t],t+1<r&&0!==w[t]){for(let e=t+1;e<r;e++)d[e]=0;for(let e=t+1;e<r;e++)for(let r=t+1;r<o;r++)d[e]+=w[r]*h.get(e,r);for(let e=t+1;e<o;e++){let o=-w[e]/w[t+1];for(let n=t+1;n<r;n++)h.set(n,e,h.get(n,e)+o*d[n])}}if(u)for(let e=t+1;e<o;e++)g.set(e,t,w[e])}}let x=Math.min(o,r+1);if(v<o&&(m[v]=h.get(v,v)),r<x&&(m[x-1]=0),b+1<x&&(w[b]=h.get(b,x-1)),w[x-1]=0,a){for(let t=v;t<f;t++){for(let e=0;e<r;e++)p.set(e,t,0);p.set(t,t,1)}for(let t=v-1;t>=0;t--)if(0!==m[t]){for(let e=t+1;e<f;e++){let o=0;for(let n=t;n<r;n++)o+=p.get(n,t)*p.get(n,e);o=-o/p.get(t,t);for(let n=t;n<r;n++)p.set(n,e,p.get(n,e)+o*p.get(n,t))}for(let e=t;e<r;e++)p.set(e,t,-p.get(e,t));p.set(t,t,1+p.get(t,t));for(let e=0;e<t-1;e++)p.set(e,t,0)}else{for(let e=0;e<r;e++)p.set(e,t,0);p.set(t,t,1)}}if(u)for(let t=o-1;t>=0;t--){if(t<b&&0!==w[t])for(let e=t+1;e<o;e++){let r=0;for(let n=t+1;n<o;n++)r+=g.get(n,t)*g.get(n,e);r=-r/g.get(t+1,t);for(let n=t+1;n<o;n++)g.set(n,e,g.get(n,e)+r*g.get(n,t))}for(let e=0;e<o;e++)g.set(e,t,0);g.set(t,t,1)}let S=x-1,E=0,R=Number.EPSILON;for(;x>0;){let t,e;for(t=x-2;t>=-1&&-1!==t;t--){const e=Number.MIN_VALUE+R*Math.abs(m[t]+Math.abs(m[t+1]));if(Math.abs(w[t])<=e||Number.isNaN(w[t])){w[t]=0;break}}if(t===x-2)e=4;else{let r;for(r=x-1;r>=t&&r!==t;r--){let e=(r!==x?Math.abs(w[r]):0)+(r!==t+1?Math.abs(w[r-1]):0);if(Math.abs(m[r])<=R*e){m[r]=0;break}}r===t?e=3:r===x-1?e=1:(e=2,t=r)}switch(t++,e){case 1:{let e=w[x-2];w[x-2]=0;for(let r=x-2;r>=t;r--){let n=T(m[r],e),i=m[r]/n,s=e/n;if(m[r]=n,r!==t&&(e=-s*w[r-1],w[r-1]=i*w[r-1]),u)for(let t=0;t<o;t++)n=i*g.get(t,r)+s*g.get(t,x-1),g.set(t,x-1,-s*g.get(t,r)+i*g.get(t,x-1)),g.set(t,r,n)}break}case 2:{let e=w[t-1];w[t-1]=0;for(let o=t;o<x;o++){let n=T(m[o],e),i=m[o]/n,s=e/n;if(m[o]=n,e=-s*w[o],w[o]=i*w[o],a)for(let e=0;e<r;e++)n=i*p.get(e,o)+s*p.get(e,t-1),p.set(e,t-1,-s*p.get(e,o)+i*p.get(e,t-1)),p.set(e,o,n)}break}case 3:{const e=Math.max(Math.abs(m[x-1]),Math.abs(m[x-2]),Math.abs(w[x-2]),Math.abs(m[t]),Math.abs(w[t])),n=m[x-1]/e,i=m[x-2]/e,s=w[x-2]/e,h=m[t]/e,l=w[t]/e,f=((i+n)*(i-n)+s*s)/2,c=n*s*(n*s);let d=0;0===f&&0===c||(d=f<0?0-Math.sqrt(f*f+c):Math.sqrt(f*f+c),d=c/(f+d));let y=(h+n)*(h-n)+d,v=h*l;for(let e=t;e<x-1;e++){let n=T(y,v);0===n&&(n=Number.MIN_VALUE);let i=y/n,s=v/n;if(e!==t&&(w[e-1]=n),y=i*m[e]+s*w[e],w[e]=i*w[e]-s*m[e],v=s*m[e+1],m[e+1]=i*m[e+1],u)for(let t=0;t<o;t++)n=i*g.get(t,e)+s*g.get(t,e+1),g.set(t,e+1,-s*g.get(t,e)+i*g.get(t,e+1)),g.set(t,e,n);if(n=T(y,v),0===n&&(n=Number.MIN_VALUE),i=y/n,s=v/n,m[e]=n,y=i*w[e]+s*m[e+1],m[e+1]=-s*w[e]+i*m[e+1],v=s*w[e+1],w[e+1]=i*w[e+1],a&&e<r-1)for(let t=0;t<r;t++)n=i*p.get(t,e)+s*p.get(t,e+1),p.set(t,e+1,-s*p.get(t,e)+i*p.get(t,e+1)),p.set(t,e,n)}w[x-2]=y,E+=1;break}case 4:if(m[t]<=0&&(m[t]=m[t]<0?-m[t]:0,u))for(let e=0;e<=S;e++)g.set(e,t,-g.get(e,t));for(;t<S&&!(m[t]>=m[t+1]);){let e=m[t];if(m[t]=m[t+1],m[t+1]=e,u&&t<o-1)for(let r=0;r<o;r++)e=g.get(r,t+1),g.set(r,t+1,g.get(r,t)),g.set(r,t,e);if(a&&t<r-1)for(let o=0;o<r;o++)e=p.get(o,t+1),p.set(o,t+1,p.get(o,t)),p.set(o,t,e);t++}E=0,x--}}if(l){let t=g;g=p,p=t}this.m=r,this.n=o,this.s=m,this.U=p,this.V=g}solve(t){let e=t,r=this.threshold,o=this.s.length,n=z.zeros(o,o);for(let t=0;t<o;t++)Math.abs(this.s[t])<=r?n.set(t,t,0):n.set(t,t,1/this.s[t]);let i=this.U,s=this.rightSingularVectors,h=s.mmul(n),a=s.rows,u=i.rows,l=z.zeros(a,u);for(let t=0;t<a;t++)for(let e=0;e<u;e++){let r=0;for(let n=0;n<o;n++)r+=h.get(t,n)*i.get(e,n);l.set(t,e,r)}return l.mmul(e)}solveForDiagonal(t){return this.solve(z.diag(t))}inverse(){let t=this.V,e=this.threshold,r=t.rows,o=t.columns,n=new z(r,this.s.length);for(let i=0;i<r;i++)for(let r=0;r<o;r++)Math.abs(this.s[r])>e&&n.set(i,r,t.get(i,r)/this.s[r]);let i=this.U,s=i.rows,h=i.columns,a=new z(r,s);for(let t=0;t<r;t++)for(let e=0;e<s;e++){let r=0;for(let o=0;o<h;o++)r+=n.get(t,o)*i.get(e,o);a.set(t,e,r)}return a}get condition(){return this.s[0]/this.s[Math.min(this.m,this.n)-1]}get norm2(){return this.s[0]}get rank(){let t=Math.max(this.m,this.n)*this.s[0]*Number.EPSILON,e=0,r=this.s;for(let o=0,n=r.length;o<n;o++)r[o]>t&&e++;return e}get diagonal(){return Array.from(this.s)}get threshold(){return Number.EPSILON/2*Math.max(this.m,this.n)*this.s[0]}get leftSingularVectors(){return this.U}get rightSingularVectors(){return this.V}get diagonalMatrix(){return z.diag(this.s)}}function _(t,e,r,o,n){let i=r*o*o,s=z.eye(e.length,e.length,i);const h=n(e);let a=new Float64Array(t.x.length);for(let e=0;e<t.x.length;e++)a[e]=h(t.x[e]);let u=function(t,e,r,o,n){const i=r.length,s=t.x.length;let h=new Array(i);for(let a=0;a<i;a++){h[a]=new Array(s);let i=r.slice();i[a]+=o;let u=n(i);for(let r=0;r<s;r++)h[a][r]=e[r]-u(t.x[r])}return new z(h)}(t,a,e,o,n),l=function(t,e){const r=t.x.length;let o=new Array(r);for(let n=0;n<r;n++)o[n]=[t.y[n]-e[n]];return new z(o)}(t,a),f=function(t,e=!1){return t=I.checkMatrix(t),e?new C(t).inverse():function(t,e,r=!1){return t=I.checkMatrix(t),e=I.checkMatrix(e),r?new C(t).solve(e):t.isSquare()?new F(t).solve(e):new A(t).solve(e)}(t,z.eye(t.rows))}(s.add(u.mmul(u.transpose())));return(e=(e=new z([e])).sub(f.mmul(u).mmul(l).mul(o).transpose())).to1DArray()}function P(t,e,r={}){let{maxIterations:o=100,gradientDifference:s=.1,damping:h=0,errorTolerance:a=.01,minValues:u,maxValues:l,initialValues:f}=r;if(h<=0)throw new Error("The damping option must be a positive number");if(!t.x||!t.y)throw new Error("The data parameter must have x and y elements");if(!n(t.x)||t.x.length<2||!n(t.y)||t.y.length<2)throw new Error("The data parameter elements must be an array with more than 2 points");if(t.x.length!==t.y.length)throw new Error("The data parameter elements must have the same size");let c=f||new Array(e.length).fill(1),m=c.length;if(l=l||new Array(m).fill(Number.MAX_SAFE_INTEGER),u=u||new Array(m).fill(Number.MIN_SAFE_INTEGER),l.length!==u.length)throw new Error("minValues and maxValues must be the same size");if(!n(c))throw new Error("initialValues must be an array");let p,g=i(t,c,e),w=g<=a;for(p=0;p<o&&!w;p++){c=_(t,c,h,s,e);for(let t=0;t<m;t++)c[t]=Math.min(Math.max(u[t],c[t]),l[t]);if(g=i(t,c,e),isNaN(g))break;w=g<=a}return{parameterValues:c,parameterError:g,iterations:p}}},378:function(t,e,r){var o=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var r in t)Object.hasOwnProperty.call(t,r)&&(e[r]=t[r]);return e.default=t,e};Object.defineProperty(e,"__esModule",{value:!0});var n=o(r(517));function i(t,e){var r=function(r){return n.empty(t).map((function(){return n.filled(e,r)}))},o=[];return o.push(r(-1)),o.push(r(1/0)),o.push(r(0)),o}function s(t,e,r,o,n){e=Math.floor(e);var i=t[0][e],s=t[1][e];if(t[2][e],r>=s[0])return 0;for(var a=0;a<i.length;a++)if(o===i[a])return 0;return h(t,e,r,o,n)}function h(t,e,r,o,n){var i=t[0][e],s=t[1][e],h=t[2][e];if(r>=s[0])return 0;s[0]=r,i[0]=o,h[0]=n;for(var a=0,u=0;;){var l=2*a+1,f=l+1,c=t[0][0].length;if(l>=c)break;if(f>=c){if(!(s[l]>r))break;u=l}else if(s[l]>=s[f]){if(!(r<s[l]))break;u=l}else{if(!(r<s[f]))break;u=f}s[a]=s[u],i[a]=i[u],h[a]=h[u],a=u}return s[a]=r,i[a]=o,h[a]=n,1}function a(t,e,r,o){for(;2*o+1<r;){var n=2*o+1,i=n+1,s=o;if(t[s]<t[n]&&(s=n),i<r&&t[s]<t[i]&&(s=i),s===o)break;var h=t[o];t[o]=t[s],t[s]=h;var a=e[o];e[o]=e[s],e[s]=a,o=s}}e.makeHeap=i,e.rejectionSample=function(t,e,r){for(var o=n.zeros(t),i=0;i<t;i++){for(var s=!0,h=0;s;){h=n.tauRandInt(e,r);for(var a=!1,u=0;u<i;u++)if(h===o[u]){a=!0;break}a||(s=!1)}o[i]=h}return o},e.heapPush=s,e.uncheckedHeapPush=h,e.buildCandidates=function(t,e,r,o,h){for(var a=i(e,o),u=0;u<e;u++)for(var l=0;l<r;l++)if(!(t[0][u][l]<0)){var f=t[0][u][l],c=t[2][u][l],m=n.tauRand(h);s(a,u,m,f,c),s(a,f,m,u,c),t[2][u][l]=0}return a},e.deheapSort=function(t){for(var e=t[0],r=t[1],o=0;o<e.length;o++)for(var n=e[o],i=r[o],s=0;s<n.length-1;s++){var h=n.length-s-1,u=i.length-s-1,l=n[0];n[0]=n[h],n[h]=l;var f=i[0];i[0]=i[u],i[u]=f,a(i,n,u,0)}return{indices:e,weights:r}},e.smallestFlagged=function(t,e){for(var r=t[0][e],o=t[1][e],n=t[2][e],i=1/0,s=-1,h=0;h>r.length;h++)1===n[h]&&o[h]<i&&(i=o[h],s=h);return s>=0?(n[s]=0,Math.floor(r[s])):-1}},221:(t,e,r)=>{var o=r(364);e.u=o.UMAP},686:function(t,e,r){var o,n=this&&this.__read||function(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var o,n,i=r.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(o=i.next()).done;)s.push(o.value)}catch(t){n={error:t}}finally{try{o&&!o.done&&(r=i.return)&&r.call(i)}finally{if(n)throw n.error}}return s},i=this&&this.__values||function(t){var e="function"==typeof Symbol&&t[Symbol.iterator],r=0;return e?e.call(t):{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}}},s=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var r in t)Object.hasOwnProperty.call(t,r)&&(e[r]=t[r]);return e.default=t,e};Object.defineProperty(e,"__esModule",{value:!0});var h=s(r(517)),a=function(){function t(t,e,r,o){if(this.entries=new Map,this.nRows=0,this.nCols=0,t.length!==e.length||t.length!==r.length)throw new Error("rows, cols and values arrays must all have the same length");this.nRows=o[0],this.nCols=o[1];for(var n=0;n<r.length;n++){var i=t[n],s=e[n];this.checkDims(i,s);var h=this.makeKey(i,s);this.entries.set(h,{value:r[n],row:i,col:s})}}return t.prototype.makeKey=function(t,e){return t+":"+e},t.prototype.checkDims=function(t,e){if(!(t<this.nRows&&e<this.nCols))throw new Error("row and/or col specified outside of matrix dimensions")},t.prototype.set=function(t,e,r){this.checkDims(t,e);var o=this.makeKey(t,e);this.entries.has(o)?this.entries.get(o).value=r:this.entries.set(o,{value:r,row:t,col:e})},t.prototype.get=function(t,e,r){void 0===r&&(r=0),this.checkDims(t,e);var o=this.makeKey(t,e);return this.entries.has(o)?this.entries.get(o).value:r},t.prototype.getAll=function(t){void 0===t&&(t=!0);var e=[];return this.entries.forEach((function(t){e.push(t)})),t&&e.sort((function(t,e){return t.row===e.row?t.col-e.col:t.row-e.row})),e},t.prototype.getDims=function(){return[this.nRows,this.nCols]},t.prototype.getRows=function(){return Array.from(this.entries,(function(t){var e=n(t,2);return e[0],e[1].row}))},t.prototype.getCols=function(){return Array.from(this.entries,(function(t){var e=n(t,2);return e[0],e[1].col}))},t.prototype.getValues=function(){return Array.from(this.entries,(function(t){var e=n(t,2);return e[0],e[1].value}))},t.prototype.forEach=function(t){this.entries.forEach((function(e){return t(e.value,e.row,e.col)}))},t.prototype.map=function(e){var r=[];this.entries.forEach((function(t){r.push(e(t.value,t.row,t.col))}));var o=[this.nRows,this.nCols];return new t(this.getRows(),this.getCols(),r,o)},t.prototype.toArray=function(){var t=this,e=h.empty(this.nRows).map((function(){return h.zeros(t.nCols)}));return this.entries.forEach((function(t){e[t.row][t.col]=t.value})),e},t}();e.SparseMatrix=a,e.transpose=function(t){var e=[],r=[],o=[];t.forEach((function(t,n,i){e.push(n),r.push(i),o.push(t)}));var n=[t.nCols,t.nRows];return new a(r,e,o,n)},e.identity=function(t){for(var e=n(t,1)[0],r=new a([],[],[],t),o=0;o<e;o++)r.set(o,o,1);return r},e.pairwiseMultiply=function(t,e){return l(t,e,(function(t,e){return t*e}))},e.add=function(t,e){return l(t,e,(function(t,e){return t+e}))},e.subtract=function(t,e){return l(t,e,(function(t,e){return t-e}))},e.maximum=function(t,e){return l(t,e,(function(t,e){return t>e?t:e}))},e.multiplyScalar=function(t,e){return t.map((function(t){return t*e}))},e.eliminateZeros=function(t){for(var e=new Set,r=t.getValues(),o=t.getRows(),n=t.getCols(),i=0;i<r.length;i++)0===r[i]&&e.add(i);var s=function(t,r){return!e.has(r)},h=r.filter(s),u=o.filter(s),l=n.filter(s);return new a(u,l,h,t.getDims())},e.normalize=function(t,e){var r,o;void 0===e&&(e="l2");var n=u[e],s=new Map;t.forEach((function(t,e,r){var o=s.get(e)||[];o.push(r),s.set(e,o)}));var h=new a([],[],[],t.getDims()),l=function(e){for(var r=s.get(e).sort(),o=r.map((function(r){return t.get(e,r)})),i=n(o),a=0;a<i.length;a++)h.set(e,r[a],i[a])};try{for(var f=i(s.keys()),c=f.next();!c.done;c=f.next())l(c.value)}catch(t){r={error:t}}finally{try{c&&!c.done&&(o=f.return)&&o.call(f)}finally{if(r)throw r.error}}return h};var u=((o={}).max=function(t){for(var e=-1/0,r=0;r<t.length;r++)e=t[r]>e?t[r]:e;return t.map((function(t){return t/e}))},o.l1=function(t){for(var e=0,r=0;r<t.length;r++)e+=t[r];return t.map((function(t){return t/e}))},o.l2=function(t){for(var e=0,r=0;r<t.length;r++)e+=Math.pow(t[r],2);return t.map((function(t){return Math.sqrt(Math.pow(t,2)/e)}))},o);function l(t,e,r){for(var o=new Set,n=[],i=[],s=[],h=function(o,h){n.push(o),i.push(h);var a=r(t.get(o,h),e.get(o,h));s.push(a)},u=t.getValues(),l=t.getRows(),f=t.getCols(),c=0;c<u.length;c++){var m=(d=l[c])+":"+(y=f[c]);o.add(m),h(d,y)}var p=e.getValues(),g=e.getRows(),w=e.getCols();for(c=0;c<p.length;c++){var d,y;m=(d=g[c])+":"+(y=w[c]),o.has(m)||h(d,y)}var v=[t.nRows,t.nCols];return new a(n,i,s,v)}e.getCSR=function(t){var e=[];t.forEach((function(t,r,o){e.push({value:t,row:r,col:o})})),e.sort((function(t,e){return t.row===e.row?t.col-e.col:t.row-e.row}));for(var r=[],o=[],n=[],i=-1,s=0;s<e.length;s++){var h=e[s],a=h.row,u=h.col,l=h.value;a!==i&&(i=a,n.push(s)),r.push(u),o.push(l)}return{indices:r,values:o,indptr:n}}},760:function(t,e,r){var o=this&&this.__values||function(t){var e="function"==typeof Symbol&&t[Symbol.iterator],r=0;return e?e.call(t):{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}}},n=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var r in t)Object.hasOwnProperty.call(t,r)&&(e[r]=t[r]);return e.default=t,e};Object.defineProperty(e,"__esModule",{value:!0});var i=n(r(378)),s=n(r(686)),h=n(r(320)),a=n(r(517));e.makeNNDescent=function(t,e){return function(r,o,n,s,h,u,l,f){void 0===s&&(s=10),void 0===h&&(h=50),void 0===u&&(u=.001),void 0===l&&(l=.5),void 0===f&&(f=!0);for(var c=r.length,m=i.makeHeap(r.length,n),p=0;p<r.length;p++)for(var g=i.rejectionSample(n,r.length,e),w=0;w<g.length;w++){var d=t(r[p],r[g[w]]);i.heapPush(m,p,d,g[w],1),i.heapPush(m,g[w],d,p,1)}if(f)for(var y=0;y<o.length;y++)for(p=0;p<o[y].length&&!(o[y][p]<0);p++)for(w=p+1;w<o[y].length&&!(o[y][w]<0);w++)d=t(r[o[y][p]],r[o[y][w]]),i.heapPush(m,o[y][p],d,o[y][w],1),i.heapPush(m,o[y][w],d,o[y][p],1);for(y=0;y<s;y++){var v=i.buildCandidates(m,c,n,h,e),b=0;for(p=0;p<c;p++)for(w=0;w<h;w++){var M=Math.floor(v[0][p][w]);if(!(M<0||a.tauRand(e)<l))for(var x=0;x<h;x++){var S=Math.floor(v[0][p][x]),E=v[2][p][w],R=v[2][p][x];S<0||!E&&!R||(d=t(r[M],r[S]),b+=i.heapPush(m,M,d,S,1),b+=i.heapPush(m,S,d,M,1))}}if(b<=u*n*r.length)break}return i.deheapSort(m)}},e.makeInitializations=function(t){return{initFromRandom:function(e,r,o,n,s){for(var h=0;h<o.length;h++)for(var u=a.rejectionSample(e,r.length,s),l=0;l<u.length;l++)if(!(u[l]<0)){var f=t(r[u[l]],o[h]);i.heapPush(n,h,f,u[l],1)}},initFromTree:function(e,r,o,n,s){for(var a=0;a<o.length;a++)for(var u=h.searchFlatTree(o[a],e,s),l=0;l<u.length;l++){if(u[l]<0)return;var f=t(r[u[l]],o[a]);i.heapPush(n,a,f,u[l],1)}}}},e.makeInitializedNNSearch=function(t){return function(e,r,n,h){for(var a,u,l=s.getCSR(r),f=l.indices,c=l.indptr,m=0;m<h.length;m++)for(var p=new Set(n[0][m]);;){var g=i.smallestFlagged(n,m);if(-1===g)break;var w=f.slice(c[g],c[g+1]);try{for(var d=o(w),y=d.next();!y.done;y=d.next()){var v=y.value;if(v!==g&&-1!==v&&!p.has(v)){var b=t(e[v],h[m]);i.uncheckedHeapPush(n,m,b,v,1),p.add(v)}}}catch(t){a={error:t}}finally{try{y&&!y.done&&(u=d.return)&&u.call(d)}finally{if(a)throw a.error}}}return n}},e.initializeSearch=function(t,e,r,n,s,h,a){var u,l,f=i.makeHeap(r.length,n);if(s(n,e,r,f,a),t)try{for(var c=o(t),m=c.next();!m.done;m=c.next())h(m.value,e,r,f,a)}catch(t){u={error:t}}finally{try{m&&!m.done&&(l=c.return)&&l.call(c)}finally{if(u)throw u.error}}return f}},320:function(t,e,r){var o=this&&this.__read||function(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var o,n,i=r.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(o=i.next()).done;)s.push(o.value)}catch(t){n={error:t}}finally{try{o&&!o.done&&(r=i.return)&&r.call(i)}finally{if(n)throw n.error}}return s},n=this&&this.__spread||function(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(o(arguments[e]));return t},i=this&&this.__values||function(t){var e="function"==typeof Symbol&&t[Symbol.iterator],r=0;return e?e.call(t):{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}}},s=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var r in t)Object.hasOwnProperty.call(t,r)&&(e[r]=t[r]);return e.default=t,e};Object.defineProperty(e,"__esModule",{value:!0});var h=s(r(517)),a=function(t,e,r,o){this.hyperplanes=t,this.offsets=e,this.children=r,this.indices=o};function u(t,e,r,o,n){if(void 0===r&&(r=30),e.length>r){var i=function(t,e,r){var o=t[0].length,n=h.tauRandInt(e.length,r),i=h.tauRandInt(e.length,r);i=(i+=n===i?1:0)%e.length;for(var s=e[n],a=e[i],u=0,l=h.zeros(o),f=0;f<l.length;f++)l[f]=t[s][f]-t[a][f],u-=l[f]*(t[s][f]+t[a][f])/2;var c=0,m=0,p=h.zeros(e.length);for(f=0;f<e.length;f++){for(var g=u,w=0;w<o;w++)g+=l[w]*t[e[f]][w];0===g?(p[f]=h.tauRandInt(2,r),0===p[f]?c+=1:m+=1):g>0?(p[f]=0,c+=1):(p[f]=1,m+=1)}var d=h.zeros(c),y=h.zeros(m);for(c=0,m=0,f=0;f<p.length;f++)0===p[f]?(d[c]=e[f],c+=1):(y[m]=e[f],m+=1);return{indicesLeft:d,indicesRight:y,hyperplane:l,offset:u}}(t,e,n),s=i.indicesLeft,a=i.indicesRight,l=i.hyperplane,f=i.offset;return{leftChild:u(t,s,r,o+1,n),rightChild:u(t,a,r,o+1,n),isLeaf:!1,hyperplane:l,offset:f}}return{indices:e,isLeaf:!0}}function l(t,e,r,o,i,s,h){var a;if(t.isLeaf)return o[s][0]=-h,(a=i[h]).splice.apply(a,n([0,t.indices.length],t.indices)),{nodeNum:s,leafNum:h+=1};e[s]=t.hyperplane,r[s]=t.offset,o[s][0]=s+1;var u=s,f=l(t.leftChild,e,r,o,i,s+1,h);return s=f.nodeNum,h=f.leafNum,o[u][1]=s+1,{nodeNum:(f=l(t.rightChild,e,r,o,i,s+1,h)).nodeNum,leafNum:f.leafNum}}function f(t){return t.isLeaf?1:1+f(t.leftChild)+f(t.rightChild)}function c(t){return t.isLeaf?1:c(t.leftChild)+c(t.rightChild)}function m(t,e,r,o){for(var n=e,i=0;i<r.length;i++)n+=t[i]*r[i];return 0===n?h.tauRandInt(2,o):n>0?0:1}e.FlatTree=a,e.makeForest=function(t,e,r,o){var n=Math.max(10,e);return h.range(r).map((function(e,r){return function(t,e,r,o){return void 0===e&&(e=30),u(t,h.range(t.length),e,r,o)}(t,n,r,o)})).map((function(t){return function(t,e){var r=f(t),o=c(t),n=h.range(r).map((function(){return h.zeros(t.hyperplane?t.hyperplane.length:0)})),i=h.zeros(r),s=h.range(r).map((function(){return[-1,-1]})),u=h.range(o).map((function(){return h.range(e).map((function(){return-1}))}));return l(t,n,i,s,u,0,0),new a(n,i,s,u)}(t,n)}))},e.makeLeafArray=function(t){var e,r;if(t.length>0){var o=[];try{for(var s=i(t),h=s.next();!h.done;h=s.next()){var a=h.value;o.push.apply(o,n(a.indices))}}catch(t){e={error:t}}finally{try{h&&!h.done&&(r=s.return)&&r.call(s)}finally{if(e)throw e.error}}return o}return[[-1]]},e.searchFlatTree=function(t,e,r){for(var o=0;e.children[o][0]>0;)o=0===m(e.hyperplanes[o],e.offsets[o],t,r)?e.children[o][0]:e.children[o][1];var n=-1*e.children[o][0];return e.indices[n]}},364:function(t,e,r){var o=this&&this.__awaiter||function(t,e,r,o){return new(r||(r=Promise))((function(n,i){function s(t){try{a(o.next(t))}catch(t){i(t)}}function h(t){try{a(o.throw(t))}catch(t){i(t)}}function a(t){t.done?n(t.value):new r((function(e){e(t.value)})).then(s,h)}a((o=o.apply(t,e||[])).next())}))},n=this&&this.__generator||function(t,e){var r,o,n,i,s={label:0,sent:function(){if(1&n[0])throw n[1];return n[1]},trys:[],ops:[]};return i={next:h(0),throw:h(1),return:h(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function h(i){return function(h){return function(i){if(r)throw new TypeError("Generator is already executing.");for(;s;)try{if(r=1,o&&(n=2&i[0]?o.return:i[0]?o.throw||((n=o.return)&&n.call(o),0):o.next)&&!(n=n.call(o,i[1])).done)return n;switch(o=0,n&&(i=[2&i[0],n.value]),i[0]){case 0:case 1:n=i;break;case 4:return s.label++,{value:i[1],done:!1};case 5:s.label++,o=i[1],i=[0];continue;case 7:i=s.ops.pop(),s.trys.pop();continue;default:if(!((n=(n=s.trys).length>0&&n[n.length-1])||6!==i[0]&&2!==i[0])){s=0;continue}if(3===i[0]&&(!n||i[1]>n[0]&&i[1]<n[3])){s.label=i[1];break}if(6===i[0]&&s.label<n[1]){s.label=n[1],n=i;break}if(n&&s.label<n[2]){s.label=n[2],s.ops.push(i);break}n[2]&&s.ops.pop(),s.trys.pop();continue}i=e.call(t,s)}catch(t){i=[6,t],o=0}finally{r=n=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,h])}}},i=this&&this.__read||function(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var o,n,i=r.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(o=i.next()).done;)s.push(o.value)}catch(t){n={error:t}}finally{try{o&&!o.done&&(r=i.return)&&r.call(i)}finally{if(n)throw n.error}}return s},s=this&&this.__spread||function(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(i(arguments[e]));return t},h=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var r in t)Object.hasOwnProperty.call(t,r)&&(e[r]=t[r]);return e.default=t,e},a=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(e,"__esModule",{value:!0});var u=h(r(378)),l=h(r(686)),f=h(r(760)),c=h(r(320)),m=h(r(517)),p=a(r(251)),g=1e-5,w=.001,d=function(){function t(t){void 0===t&&(t={});var e=this;this.learningRate=1,this.localConnectivity=1,this.minDist=.1,this.nComponents=2,this.nEpochs=0,this.nNeighbors=15,this.negativeSampleRate=5,this.random=Math.random,this.repulsionStrength=1,this.setOpMixRatio=1,this.spread=1,this.transformQueueSize=4,this.targetMetric="categorical",this.targetWeight=.5,this.targetNNeighbors=this.nNeighbors,this.distanceFn=y,this.isInitialized=!1,this.rpForest=[],this.embedding=[],this.optimizationState=new v;var r=function(r){void 0!==t[r]&&(e[r]=t[r])};r("distanceFn"),r("learningRate"),r("localConnectivity"),r("minDist"),r("nComponents"),r("nEpochs"),r("nNeighbors"),r("negativeSampleRate"),r("random"),r("repulsionStrength"),r("setOpMixRatio"),r("spread"),r("transformQueueSize")}return t.prototype.fit=function(t){return this.initializeFit(t),this.optimizeLayout(),this.embedding},t.prototype.fitAsync=function(t,e){return void 0===e&&(e=function(){return!0}),o(this,void 0,void 0,(function(){return n(this,(function(r){switch(r.label){case 0:return this.initializeFit(t),[4,this.optimizeLayoutAsync(e)];case 1:return r.sent(),[2,this.embedding]}}))}))},t.prototype.setSupervisedProjection=function(t,e){void 0===e&&(e={}),this.Y=t,this.targetMetric=e.targetMetric||this.targetMetric,this.targetWeight=e.targetWeight||this.targetWeight,this.targetNNeighbors=e.targetNNeighbors||this.targetNNeighbors},t.prototype.setPrecomputedKNN=function(t,e){this.knnIndices=t,this.knnDistances=e},t.prototype.initializeFit=function(t){if(t.length<=this.nNeighbors)throw new Error("Not enough data points ("+t.length+") to create nNeighbors: "+this.nNeighbors+". Add more data points or adjust the configuration.");if(this.X===t&&this.isInitialized)return this.getNEpochs();if(this.X=t,!this.knnIndices&&!this.knnDistances){var e=this.nearestNeighbors(t);this.knnIndices=e.knnIndices,this.knnDistances=e.knnDistances}this.graph=this.fuzzySimplicialSet(t,this.nNeighbors,this.setOpMixRatio),this.makeSearchFns(),this.searchGraph=this.makeSearchGraph(t),this.processGraphForSupervisedProjection();var r=this.initializeSimplicialSetEmbedding(),o=r.head,n=r.tail,i=r.epochsPerSample;return this.optimizationState.head=o,this.optimizationState.tail=n,this.optimizationState.epochsPerSample=i,this.initializeOptimization(),this.prepareForOptimizationLoop(),this.isInitialized=!0,this.getNEpochs()},t.prototype.makeSearchFns=function(){var t=f.makeInitializations(this.distanceFn),e=t.initFromTree,r=t.initFromRandom;this.initFromTree=e,this.initFromRandom=r,this.search=f.makeInitializedNNSearch(this.distanceFn)},t.prototype.makeSearchGraph=function(t){for(var e=this.knnIndices,r=this.knnDistances,o=[t.length,t.length],n=new l.SparseMatrix([],[],[],o),i=0;i<e.length;i++)for(var s=e[i],h=r[i],a=0;a<s.length;a++){var u=s[a],f=h[a];f>0&&n.set(i,u,f)}var c=l.transpose(n);return l.maximum(n,c)},t.prototype.transform=function(t){var e=this,r=this.X;if(void 0===r||0===r.length)throw new Error("No data has been fit.");var o=Math.floor(this.nNeighbors*this.transformQueueSize);o=Math.min(r.length,o);var n=f.initializeSearch(this.rpForest,r,t,o,this.initFromRandom,this.initFromTree,this.random),i=this.search(r,this.searchGraph,n,t),s=u.deheapSort(i),h=s.indices,a=s.weights;h=h.map((function(t){return t.slice(0,e.nNeighbors)})),a=a.map((function(t){return t.slice(0,e.nNeighbors)}));var c=Math.max(0,this.localConnectivity-1),p=this.smoothKNNDistance(a,this.nNeighbors,c),g=p.sigmas,w=p.rhos,d=this.computeMembershipStrengths(h,a,g,w),y=d.rows,v=d.cols,b=d.vals,M=[t.length,r.length],x=new l.SparseMatrix(y,v,b,M),S=l.normalize(x,"l1"),E=l.getCSR(S),N=t.length,k=R(m.reshape2d(E.indices,N,this.nNeighbors),m.reshape2d(E.values,N,this.nNeighbors),this.embedding),z=this.nEpochs?this.nEpochs/3:x.nRows<=1e4?100:30,I=x.getValues().reduce((function(t,e){return e>t?e:t}),0);x=x.map((function(t){return t<I/z?0:t})),x=l.eliminateZeros(x);var F=this.makeEpochsPerSample(x.getValues(),z),T=x.getRows(),A=x.getCols();return this.assignOptimizationStateParameters({headEmbedding:k,tailEmbedding:this.embedding,head:T,tail:A,currentEpoch:0,nEpochs:z,nVertices:x.getDims()[1],epochsPerSample:F}),this.prepareForOptimizationLoop(),this.optimizeLayout()},t.prototype.processGraphForSupervisedProjection=function(){var t=this.Y,e=this.X;if(t){if(t.length!==e.length)throw new Error("Length of X and y must be equal");if("categorical"===this.targetMetric){var r=this.targetWeight<1?1/(1-this.targetWeight)*2.5:1e12;this.graph=this.categoricalSimplicialSetIntersection(this.graph,t,r)}}},t.prototype.step=function(){var t=this.optimizationState.currentEpoch;return t<this.getNEpochs()&&this.optimizeLayoutStep(t),this.optimizationState.currentEpoch},t.prototype.getEmbedding=function(){return this.embedding},t.prototype.nearestNeighbors=function(t){var e,r=this.distanceFn,o=this.nNeighbors,n=f.makeNNDescent(r,this.random),i=5+Math.floor(.5==(e=Math.pow(t.length,.5)/20)?0:Math.round(e)),s=Math.max(5,Math.floor(Math.round(function(t){return Math.log(t)/Math.log(2)}(t.length))));this.rpForest=c.makeForest(t,o,i,this.random);var h=n(t,c.makeLeafArray(this.rpForest),o,s);return{knnIndices:h.indices,knnDistances:h.weights}},t.prototype.fuzzySimplicialSet=function(t,e,r){void 0===r&&(r=1);var o=this,n=o.knnIndices,i=void 0===n?[]:n,s=o.knnDistances,h=void 0===s?[]:s,a=o.localConnectivity,u=this.smoothKNNDistance(h,e,a),f=u.sigmas,c=u.rhos,m=this.computeMembershipStrengths(i,h,f,c),p=m.rows,g=m.cols,w=m.vals,d=[t.length,t.length],y=new l.SparseMatrix(p,g,w,d),v=l.transpose(y),b=l.pairwiseMultiply(y,v),M=l.subtract(l.add(y,v),b),x=l.multiplyScalar(M,r),S=l.multiplyScalar(b,1-r);return l.add(x,S)},t.prototype.categoricalSimplicialSetIntersection=function(t,e,r,o){void 0===o&&(o=1);var n=S(t,e,o,r);return E(n=l.eliminateZeros(n))},t.prototype.smoothKNNDistance=function(t,e,r,o,n){void 0===r&&(r=1),void 0===o&&(o=64),void 0===n&&(n=1);for(var i=Math.log(e)/Math.log(2)*n,s=m.zeros(t.length),h=m.zeros(t.length),a=0;a<t.length;a++){var u=0,l=1/0,f=1,c=t[a],p=c.filter((function(t){return t>0}));if(p.length>=r){var d=Math.floor(r),y=r-d;d>0?(s[a]=p[d-1],y>g&&(s[a]+=y*(p[d]-p[d-1]))):s[a]=y*p[0]}else p.length>0&&(s[a]=m.max(p));for(var v=0;v<o;v++){for(var b=0,M=1;M<t[a].length;M++){var x=t[a][M]-s[a];b+=x>0?Math.exp(-x/f):1}if(Math.abs(b-i)<g)break;b>i?f=(u+(l=f))/2:(u=f,l===1/0?f*=2:f=(u+l)/2)}if(h[a]=f,s[a]>0){var S=m.mean(c);h[a]<w*S&&(h[a]=w*S)}else{var E=m.mean(t.map(m.mean));h[a]<w*E&&(h[a]=w*E)}}return{sigmas:h,rhos:s}},t.prototype.computeMembershipStrengths=function(t,e,r,o){for(var n=t.length,i=t[0].length,s=m.zeros(n*i),h=m.zeros(n*i),a=m.zeros(n*i),u=0;u<n;u++)for(var l=0;l<i;l++){var f=0;-1!==t[u][l]&&(f=t[u][l]===u?0:e[u][l]-o[u]<=0?1:Math.exp(-(e[u][l]-o[u])/r[u]),s[u*i+l]=u,h[u*i+l]=t[u][l],a[u*i+l]=f)}return{rows:s,cols:h,vals:a}},t.prototype.initializeSimplicialSetEmbedding=function(){for(var t=this,e=this.getNEpochs(),r=this.nComponents,o=this.graph.getValues(),n=0,i=0;i<o.length;i++){var s=o[i];n<o[i]&&(n=s)}var h=this.graph.map((function(t){return t<n/e?0:t}));this.embedding=m.zeros(h.nRows).map((function(){return m.zeros(r).map((function(){return 20*m.tauRand(t.random)-10}))}));var a=[],u=[],l=[],f=h.getAll();for(i=0;i<f.length;i++){var c=f[i];c.value&&(a.push(c.value),l.push(c.row),u.push(c.col))}return{head:u,tail:l,epochsPerSample:this.makeEpochsPerSample(a,e)}},t.prototype.makeEpochsPerSample=function(t,e){var r=m.filled(t.length,-1),o=m.max(t),n=t.map((function(t){return t/o*e}));return n.forEach((function(t,o){t>0&&(r[o]=e/n[o])})),r},t.prototype.assignOptimizationStateParameters=function(t){Object.assign(this.optimizationState,t)},t.prototype.prepareForOptimizationLoop=function(){var t=this,e=t.repulsionStrength,r=t.learningRate,o=t.negativeSampleRate,n=this.optimizationState,i=n.epochsPerSample,h=n.headEmbedding,a=n.tailEmbedding,u=h[0].length,l=h.length===a.length,f=i.map((function(t){return t/o})),c=s(f),m=s(i);this.assignOptimizationStateParameters({epochOfNextSample:m,epochOfNextNegativeSample:c,epochsPerNegativeSample:f,moveOther:l,initialAlpha:r,alpha:r,gamma:e,dim:u})},t.prototype.initializeOptimization=function(){var t=this.embedding,e=this.embedding,r=this.optimizationState,o=r.head,n=r.tail,i=r.epochsPerSample,s=this.getNEpochs(),h=this.graph.nCols,a=x(this.spread,this.minDist),u=a.a,l=a.b;this.assignOptimizationStateParameters({headEmbedding:t,tailEmbedding:e,head:o,tail:n,epochsPerSample:i,a:u,b:l,nEpochs:s,nVertices:h})},t.prototype.optimizeLayoutStep=function(t){for(var e=this.optimizationState,r=e.head,o=e.tail,n=e.headEmbedding,i=e.tailEmbedding,s=e.epochsPerSample,h=e.epochOfNextSample,a=e.epochOfNextNegativeSample,u=e.epochsPerNegativeSample,l=e.moveOther,f=e.initialAlpha,c=e.alpha,p=e.gamma,g=e.a,w=e.b,d=e.dim,y=e.nEpochs,v=e.nVertices,x=0;x<s.length;x++)if(!(h[x]>t)){var S=r[x],E=o[x],R=n[S],N=i[E],k=M(R,N),z=0;k>0&&(z=-2*g*w*Math.pow(k,w-1),z/=g*Math.pow(k,w)+1);for(var I=0;I<d;I++){var F=b(z*(R[I]-N[I]),4);R[I]+=F*c,l&&(N[I]+=-F*c)}h[x]+=s[x];for(var T=Math.floor((t-a[x])/u[x]),A=0;A<T;A++){var C=m.tauRandInt(v,this.random),_=i[C],P=M(R,_),V=0;if(P>0)V=2*p*w,V/=(.001+P)*(g*Math.pow(P,w)+1);else if(S===C)continue;for(I=0;I<d;I++)F=4,V>0&&(F=b(V*(R[I]-_[I]),4)),R[I]+=F*c}a[x]+=T*u[x]}return e.alpha=f*(1-t/y),e.currentEpoch+=1,n},t.prototype.optimizeLayoutAsync=function(t){var e=this;return void 0===t&&(t=function(){return!0}),new Promise((function(r,i){var s=function(){return o(e,void 0,void 0,(function(){var e,o,h,a,u,l;return n(this,(function(n){try{if(e=this.optimizationState,o=e.nEpochs,h=e.currentEpoch,this.embedding=this.optimizeLayoutStep(h),a=this.optimizationState.currentEpoch,u=!1===t(a),l=a===o,u||l)return[2,r(l)];setTimeout((function(){return s()}),0)}catch(t){i(t)}return[2]}))}))};setTimeout((function(){return s()}),0)}))},t.prototype.optimizeLayout=function(t){void 0===t&&(t=function(){return!0});for(var e=!1,r=[];!e;){var o=this.optimizationState,n=o.nEpochs,i=o.currentEpoch;r=this.optimizeLayoutStep(i);var s=this.optimizationState.currentEpoch,h=!1===t(s);e=s===n||h}return r},t.prototype.getNEpochs=function(){var t=this.graph;if(this.nEpochs>0)return this.nEpochs;var e=t.nRows;return e<=2500?500:e<=5e3?400:e<=7500?300:200},t}();function y(t,e){for(var r=0,o=0;o<t.length;o++)r+=Math.pow(t[o]-e[o],2);return Math.sqrt(r)}e.UMAP=d,e.euclidean=y,e.cosine=function(t,e){for(var r=0,o=0,n=0,i=0;i<t.length;i++)r+=t[i]*e[i],o+=Math.pow(t[i],2),n+=Math.pow(e[i],2);return 0===o&&0===n?0:0===o||0===n?1:1-r/Math.sqrt(o*n)};var v=function(){this.currentEpoch=0,this.headEmbedding=[],this.tailEmbedding=[],this.head=[],this.tail=[],this.epochsPerSample=[],this.epochOfNextSample=[],this.epochOfNextNegativeSample=[],this.epochsPerNegativeSample=[],this.moveOther=!0,this.initialAlpha=1,this.alpha=1,this.gamma=1,this.a=1.5769434603113077,this.b=.8950608779109733,this.dim=2,this.nEpochs=500,this.nVertices=0};function b(t,e){return t>e?e:t<-e?-e:t}function M(t,e){for(var r=0,o=0;o<t.length;o++)r+=Math.pow(t[o]-e[o],2);return r}function x(t,e){var r=m.linear(0,3*t,300).map((function(t){return t<e?1:t})),o=m.zeros(r.length).map((function(o,n){return r[n]>=e?Math.exp(-(r[n]-e)/t):o})),n={x:r,y:o},s=p.default(n,(function(t){var e=i(t,2),r=e[0],o=e[1];return function(t){return 1/(1+r*Math.pow(t,2*o))}}),{damping:1.5,initialValues:[.5,.5],gradientDifference:.1,maxIterations:100,errorTolerance:.01}).parameterValues,h=i(s,2);return{a:h[0],b:h[1]}}function S(t,e,r,o){return void 0===r&&(r=1),void 0===o&&(o=5),t.map((function(t,n,i){return-1===e[n]||-1===e[i]?t*Math.exp(-r):e[n]!==e[i]?t*Math.exp(-o):t}))}function E(t){t=l.normalize(t,"max");var e=l.transpose(t),r=l.pairwiseMultiply(e,t);return t=l.add(t,l.subtract(e,r)),l.eliminateZeros(t)}function R(t,e,r){for(var o=m.zeros(t.length).map((function(t){return m.zeros(r[0].length)})),n=0;n<t.length;n++)for(var i=0;i<t[0].length;i++)for(var s=0;s<r[0].length;s++){var h=t[n][i];o[n][s]+=e[n][i]*r[h][s]}return o}e.findABParams=x,e.fastIntersection=S,e.resetLocalConnectivity=E,e.initTransform=R},517:function(t,e){var r=this&&this.__values||function(t){var e="function"==typeof Symbol&&t[Symbol.iterator],r=0;return e?e.call(t):{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}}};function o(t,e){return Math.floor(e()*t)}function n(t){for(var e=[],r=0;r<t;r++)e.push(void 0);return e}function i(t,e){return n(t).map((function(){return e}))}function s(t){return i(t,0)}function h(t){return t.reduce((function(t,e){return t+e}))}Object.defineProperty(e,"__esModule",{value:!0}),e.tauRandInt=o,e.tauRand=function(t){return t()},e.norm=function(t){var e,o,n=0;try{for(var i=r(t),s=i.next();!s.done;s=i.next()){var h=s.value;n+=Math.pow(h,2)}}catch(t){e={error:t}}finally{try{s&&!s.done&&(o=i.return)&&o.call(i)}finally{if(e)throw e.error}}return Math.sqrt(n)},e.empty=n,e.range=function(t){return n(t).map((function(t,e){return e}))},e.filled=i,e.zeros=s,e.ones=function(t){return i(t,1)},e.linear=function(t,e,r){return n(r).map((function(o,n){return t+n*((e-t)/(r-1))}))},e.sum=h,e.mean=function(t){return h(t)/t.length},e.max=function(t){for(var e=0,r=0;r<t.length;r++)e=t[r]>e?t[r]:e;return e},e.max2d=function(t){for(var e=0,r=0;r<t.length;r++)for(var o=0;o<t[r].length;o++)e=t[r][o]>e?t[r][o]:e;return e},e.rejectionSample=function(t,e,r){for(var n=s(t),i=0;i<t;i++)for(var h=!0;h;){for(var a=o(e,r),u=!1,l=0;l<i;l++)if(a===n[l]){u=!0;break}u||(h=!1),n[i]=a}return n},e.reshape2d=function(t,e,r){var o=[],n=0;if(t.length!==e*r)throw new Error("Array dimensions must match input length.");for(var i=0;i<e;i++){for(var s=[],h=0;h<r;h++)s.push(t[n]),n+=1;o.push(s)}return o}}}]);
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"221.js","mappings":"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","sources":["webpack://eda/./node_modules/is-any-array/src/index.js","webpack://eda/./node_modules/ml-levenberg-marquardt/src/errorCalculation.js","webpack://eda/./node_modules/ml-matrix/node_modules/is-any-array/lib-esm/index.js","webpack://eda/./node_modules/ml-array-rescale/node_modules/is-any-array/lib-esm/index.js","webpack://eda/./node_modules/ml-array-max/node_modules/is-any-array/lib-esm/index.js","webpack://eda/./node_modules/ml-array-min/node_modules/is-any-array/lib-esm/index.js","webpack://eda/./node_modules/ml-array-rescale/lib-es6/index.js","webpack://eda/./node_modules/ml-array-min/lib-es6/index.js","webpack://eda/./node_modules/ml-array-max/lib-es6/index.js","webpack://eda/./node_modules/ml-matrix/src/inspect.js","webpack://eda/./node_modules/ml-matrix/src/util.js","webpack://eda/./node_modules/ml-matrix/src/matrix.js","webpack://eda/./node_modules/ml-matrix/src/stat.js","webpack://eda/./node_modules/ml-matrix/src/mathOperations.js","webpack://eda/./node_modules/ml-matrix/src/wrap/WrapperMatrix2D.js","webpack://eda/./node_modules/ml-matrix/src/dc/lu.js","webpack://eda/./node_modules/ml-matrix/src/dc/util.js","webpack://eda/./node_modules/ml-matrix/src/dc/qr.js","webpack://eda/./node_modules/ml-matrix/src/dc/svd.js","webpack://eda/./node_modules/ml-levenberg-marquardt/src/step.js","webpack://eda/./node_modules/ml-matrix/src/decompositions.js","webpack://eda/./node_modules/ml-levenberg-marquardt/src/index.js","webpack://eda/./node_modules/umap-js/dist/heap.js","webpack://eda/./node_modules/umap-js/dist/index.js","webpack://eda/./node_modules/umap-js/dist/matrix.js","webpack://eda/./node_modules/umap-js/dist/nn_descent.js","webpack://eda/./node_modules/umap-js/dist/tree.js","webpack://eda/./node_modules/umap-js/dist/umap.js","webpack://eda/./node_modules/umap-js/dist/utils.js"],"sourcesContent":["const toString = Object.prototype.toString;\n\nexport default function isAnyArray(object) {\n  return toString.call(object).endsWith('Array]');\n}\n","/**\n * Calculate current error\n * @ignore\n * @param {{x:Array<number>, y:Array<number>}} data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param {Array<number>} parameters - Array of current parameter values\n * @param {function} parameterizedFunction - The parameters and returns a function with the independent variable as a parameter\n * @return {number}\n */\nexport default function errorCalculation(\n  data,\n  parameters,\n  parameterizedFunction,\n) {\n  let error = 0;\n  const func = parameterizedFunction(parameters);\n\n  for (let i = 0; i < data.x.length; i++) {\n    error += Math.abs(data.y[i] - func(data.x[i]));\n  }\n\n  return error;\n}\n","// eslint-disable-next-line @typescript-eslint/unbound-method\nconst toString = Object.prototype.toString;\n/**\n * Checks if an object is an instance of an Array (array or typed array, except those that contain bigint values).\n *\n * @param value - Object to check.\n * @returns True if the object is an array or a typed array.\n */\nexport function isAnyArray(value) {\n    const tag = toString.call(value);\n    return tag.endsWith('Array]') && !tag.includes('Big');\n}\n//# sourceMappingURL=index.js.map","// eslint-disable-next-line @typescript-eslint/unbound-method\nconst toString = Object.prototype.toString;\n/**\n * Checks if an object is an instance of an Array (array or typed array, except those that contain bigint values).\n *\n * @param value - Object to check.\n * @returns True if the object is an array or a typed array.\n */\nexport function isAnyArray(value) {\n    const tag = toString.call(value);\n    return tag.endsWith('Array]') && !tag.includes('Big');\n}\n//# sourceMappingURL=index.js.map","// eslint-disable-next-line @typescript-eslint/unbound-method\nconst toString = Object.prototype.toString;\n/**\n * Checks if an object is an instance of an Array (array or typed array, except those that contain bigint values).\n *\n * @param value - Object to check.\n * @returns True if the object is an array or a typed array.\n */\nexport function isAnyArray(value) {\n    const tag = toString.call(value);\n    return tag.endsWith('Array]') && !tag.includes('Big');\n}\n//# sourceMappingURL=index.js.map","// eslint-disable-next-line @typescript-eslint/unbound-method\nconst toString = Object.prototype.toString;\n/**\n * Checks if an object is an instance of an Array (array or typed array, except those that contain bigint values).\n *\n * @param value - Object to check.\n * @returns True if the object is an array or a typed array.\n */\nexport function isAnyArray(value) {\n    const tag = toString.call(value);\n    return tag.endsWith('Array]') && !tag.includes('Big');\n}\n//# sourceMappingURL=index.js.map","import { isAnyArray } from 'is-any-array';\nimport max from 'ml-array-max';\nimport min from 'ml-array-min';\n\nfunction rescale(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  } else if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var output;\n\n  if (options.output !== undefined) {\n    if (!isAnyArray(options.output)) {\n      throw new TypeError('output option must be an array if specified');\n    }\n\n    output = options.output;\n  } else {\n    output = new Array(input.length);\n  }\n\n  var currentMin = min(input);\n  var currentMax = max(input);\n\n  if (currentMin === currentMax) {\n    throw new RangeError('minimum and maximum input values are equal. Cannot rescale a constant array');\n  }\n\n  var _options$min = options.min,\n      minValue = _options$min === void 0 ? options.autoMinMax ? currentMin : 0 : _options$min,\n      _options$max = options.max,\n      maxValue = _options$max === void 0 ? options.autoMinMax ? currentMax : 1 : _options$max;\n\n  if (minValue >= maxValue) {\n    throw new RangeError('min option must be smaller than max option');\n  }\n\n  var factor = (maxValue - minValue) / (currentMax - currentMin);\n\n  for (var i = 0; i < input.length; i++) {\n    output[i] = (input[i] - currentMin) * factor + minValue;\n  }\n\n  return output;\n}\n\nexport { rescale as default };\n","import { isAnyArray } from 'is-any-array';\n\nfunction min(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var _options$fromIndex = options.fromIndex,\n      fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n      _options$toIndex = options.toIndex,\n      toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n  if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n    throw new Error('fromIndex must be a positive integer smaller than length');\n  }\n\n  if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n    throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n  }\n\n  var minValue = input[fromIndex];\n\n  for (var i = fromIndex + 1; i < toIndex; i++) {\n    if (input[i] < minValue) minValue = input[i];\n  }\n\n  return minValue;\n}\n\nexport { min as default };\n","import { isAnyArray } from 'is-any-array';\n\nfunction max(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var _options$fromIndex = options.fromIndex,\n      fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n      _options$toIndex = options.toIndex,\n      toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n  if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n    throw new Error('fromIndex must be a positive integer smaller than length');\n  }\n\n  if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n    throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n  }\n\n  var maxValue = input[fromIndex];\n\n  for (var i = fromIndex + 1; i < toIndex; i++) {\n    if (input[i] > maxValue) maxValue = input[i];\n  }\n\n  return maxValue;\n}\n\nexport { max as default };\n","const indent = ' '.repeat(2);\nconst indentData = ' '.repeat(4);\n\nexport function inspectMatrix() {\n  return inspectMatrixWithOptions(this);\n}\n\nexport function inspectMatrixWithOptions(matrix, options = {}) {\n  const {\n    maxRows = 15,\n    maxColumns = 10,\n    maxNumSize = 8,\n    padMinus = 'auto',\n  } = options;\n  return `${matrix.constructor.name} {\n${indent}[\n${indentData}${inspectData(matrix, maxRows, maxColumns, maxNumSize, padMinus)}\n${indent}]\n${indent}rows: ${matrix.rows}\n${indent}columns: ${matrix.columns}\n}`;\n}\n\nfunction inspectData(matrix, maxRows, maxColumns, maxNumSize, padMinus) {\n  const { rows, columns } = matrix;\n  const maxI = Math.min(rows, maxRows);\n  const maxJ = Math.min(columns, maxColumns);\n  const result = [];\n\n  if (padMinus === 'auto') {\n    padMinus = false;\n    loop: for (let i = 0; i < maxI; i++) {\n      for (let j = 0; j < maxJ; j++) {\n        if (matrix.get(i, j) < 0) {\n          padMinus = true;\n          break loop;\n        }\n      }\n    }\n  }\n\n  for (let i = 0; i < maxI; i++) {\n    let line = [];\n    for (let j = 0; j < maxJ; j++) {\n      line.push(formatNumber(matrix.get(i, j), maxNumSize, padMinus));\n    }\n    result.push(`${line.join(' ')}`);\n  }\n  if (maxJ !== columns) {\n    result[result.length - 1] += ` ... ${columns - maxColumns} more columns`;\n  }\n  if (maxI !== rows) {\n    result.push(`... ${rows - maxRows} more rows`);\n  }\n  return result.join(`\\n${indentData}`);\n}\n\nfunction formatNumber(num, maxNumSize, padMinus) {\n  return (\n    num >= 0 && padMinus\n      ? ` ${formatNumber2(num, maxNumSize - 1)}`\n      : formatNumber2(num, maxNumSize)\n  ).padEnd(maxNumSize);\n}\n\nfunction formatNumber2(num, len) {\n  // small.length numbers should be as is\n  let str = num.toString();\n  if (str.length <= len) return str;\n\n  // (7)'0.00123' is better then (7)'1.23e-2'\n  // (8)'0.000123' is worse then (7)'1.23e-3',\n  let fix = num.toFixed(len);\n  if (fix.length > len) {\n    fix = num.toFixed(Math.max(0, len - (fix.length - len)));\n  }\n  if (\n    fix.length <= len &&\n    !fix.startsWith('0.000') &&\n    !fix.startsWith('-0.000')\n  ) {\n    return fix;\n  }\n\n  // well, if it's still too long the user should've used longer numbers\n  let exp = num.toExponential(len);\n  if (exp.length > len) {\n    exp = num.toExponential(Math.max(0, len - (exp.length - len)));\n  }\n  return exp.slice(0);\n}\n","import { isAnyArray } from 'is-any-array';\n\n/**\n * @private\n * Check that a row index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nexport function checkRowIndex(matrix, index, outer) {\n  let max = outer ? matrix.rows : matrix.rows - 1;\n  if (index < 0 || index > max) {\n    throw new RangeError('Row index out of range');\n  }\n}\n\n/**\n * @private\n * Check that a column index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nexport function checkColumnIndex(matrix, index, outer) {\n  let max = outer ? matrix.columns : matrix.columns - 1;\n  if (index < 0 || index > max) {\n    throw new RangeError('Column index out of range');\n  }\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nexport function checkRowVector(matrix, vector) {\n  if (vector.to1DArray) {\n    vector = vector.to1DArray();\n  }\n  if (vector.length !== matrix.columns) {\n    throw new RangeError(\n      'vector size must be the same as the number of columns',\n    );\n  }\n  return vector;\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nexport function checkColumnVector(matrix, vector) {\n  if (vector.to1DArray) {\n    vector = vector.to1DArray();\n  }\n  if (vector.length !== matrix.rows) {\n    throw new RangeError('vector size must be the same as the number of rows');\n  }\n  return vector;\n}\n\nexport function checkRowIndices(matrix, rowIndices) {\n  if (!isAnyArray(rowIndices)) {\n    throw new TypeError('row indices must be an array');\n  }\n\n  for (let i = 0; i < rowIndices.length; i++) {\n    if (rowIndices[i] < 0 || rowIndices[i] >= matrix.rows) {\n      throw new RangeError('row indices are out of range');\n    }\n  }\n}\n\nexport function checkColumnIndices(matrix, columnIndices) {\n  if (!isAnyArray(columnIndices)) {\n    throw new TypeError('column indices must be an array');\n  }\n\n  for (let i = 0; i < columnIndices.length; i++) {\n    if (columnIndices[i] < 0 || columnIndices[i] >= matrix.columns) {\n      throw new RangeError('column indices are out of range');\n    }\n  }\n}\n\nexport function checkRange(matrix, startRow, endRow, startColumn, endColumn) {\n  if (arguments.length !== 5) {\n    throw new RangeError('expected 4 arguments');\n  }\n  checkNumber('startRow', startRow);\n  checkNumber('endRow', endRow);\n  checkNumber('startColumn', startColumn);\n  checkNumber('endColumn', endColumn);\n  if (\n    startRow > endRow ||\n    startColumn > endColumn ||\n    startRow < 0 ||\n    startRow >= matrix.rows ||\n    endRow < 0 ||\n    endRow >= matrix.rows ||\n    startColumn < 0 ||\n    startColumn >= matrix.columns ||\n    endColumn < 0 ||\n    endColumn >= matrix.columns\n  ) {\n    throw new RangeError('Submatrix indices are out of range');\n  }\n}\n\nexport function newArray(length, value = 0) {\n  let array = [];\n  for (let i = 0; i < length; i++) {\n    array.push(value);\n  }\n  return array;\n}\n\nfunction checkNumber(name, value) {\n  if (typeof value !== 'number') {\n    throw new TypeError(`${name} must be a number`);\n  }\n}\n\nexport function checkNonEmpty(matrix) {\n  if (matrix.isEmpty()) {\n    throw new Error('Empty matrix has no elements to index');\n  }\n}\n","import { isAnyArray } from 'is-any-array';\nimport rescale from 'ml-array-rescale';\n\nimport { inspectMatrix, inspectMatrixWithOptions } from './inspect';\nimport { installMathOperations } from './mathOperations';\nimport {\n  sumByRow,\n  sumByColumn,\n  sumAll,\n  productByRow,\n  productByColumn,\n  productAll,\n  varianceByRow,\n  varianceByColumn,\n  varianceAll,\n  centerByRow,\n  centerByColumn,\n  centerAll,\n  scaleByRow,\n  scaleByColumn,\n  scaleAll,\n  getScaleByRow,\n  getScaleByColumn,\n  getScaleAll,\n} from './stat';\nimport {\n  checkRowVector,\n  checkRowIndex,\n  checkColumnIndex,\n  checkColumnVector,\n  checkRange,\n  checkNonEmpty,\n  checkRowIndices,\n  checkColumnIndices,\n} from './util';\n\nexport class AbstractMatrix {\n  static from1DArray(newRows, newColumns, newData) {\n    let length = newRows * newColumns;\n    if (length !== newData.length) {\n      throw new RangeError('data length does not match given dimensions');\n    }\n    let newMatrix = new Matrix(newRows, newColumns);\n    for (let row = 0; row < newRows; row++) {\n      for (let column = 0; column < newColumns; column++) {\n        newMatrix.set(row, column, newData[row * newColumns + column]);\n      }\n    }\n    return newMatrix;\n  }\n\n  static rowVector(newData) {\n    let vector = new Matrix(1, newData.length);\n    for (let i = 0; i < newData.length; i++) {\n      vector.set(0, i, newData[i]);\n    }\n    return vector;\n  }\n\n  static columnVector(newData) {\n    let vector = new Matrix(newData.length, 1);\n    for (let i = 0; i < newData.length; i++) {\n      vector.set(i, 0, newData[i]);\n    }\n    return vector;\n  }\n\n  static zeros(rows, columns) {\n    return new Matrix(rows, columns);\n  }\n\n  static ones(rows, columns) {\n    return new Matrix(rows, columns).fill(1);\n  }\n\n  static rand(rows, columns, options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { random = Math.random } = options;\n    let matrix = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        matrix.set(i, j, random());\n      }\n    }\n    return matrix;\n  }\n\n  static randInt(rows, columns, options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1000, random = Math.random } = options;\n    if (!Number.isInteger(min)) throw new TypeError('min must be an integer');\n    if (!Number.isInteger(max)) throw new TypeError('max must be an integer');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let interval = max - min;\n    let matrix = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        let value = min + Math.round(random() * interval);\n        matrix.set(i, j, value);\n      }\n    }\n    return matrix;\n  }\n\n  static eye(rows, columns, value) {\n    if (columns === undefined) columns = rows;\n    if (value === undefined) value = 1;\n    let min = Math.min(rows, columns);\n    let matrix = this.zeros(rows, columns);\n    for (let i = 0; i < min; i++) {\n      matrix.set(i, i, value);\n    }\n    return matrix;\n  }\n\n  static diag(data, rows, columns) {\n    let l = data.length;\n    if (rows === undefined) rows = l;\n    if (columns === undefined) columns = rows;\n    let min = Math.min(l, rows, columns);\n    let matrix = this.zeros(rows, columns);\n    for (let i = 0; i < min; i++) {\n      matrix.set(i, i, data[i]);\n    }\n    return matrix;\n  }\n\n  static min(matrix1, matrix2) {\n    matrix1 = this.checkMatrix(matrix1);\n    matrix2 = this.checkMatrix(matrix2);\n    let rows = matrix1.rows;\n    let columns = matrix1.columns;\n    let result = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        result.set(i, j, Math.min(matrix1.get(i, j), matrix2.get(i, j)));\n      }\n    }\n    return result;\n  }\n\n  static max(matrix1, matrix2) {\n    matrix1 = this.checkMatrix(matrix1);\n    matrix2 = this.checkMatrix(matrix2);\n    let rows = matrix1.rows;\n    let columns = matrix1.columns;\n    let result = new this(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        result.set(i, j, Math.max(matrix1.get(i, j), matrix2.get(i, j)));\n      }\n    }\n    return result;\n  }\n\n  static checkMatrix(value) {\n    return AbstractMatrix.isMatrix(value) ? value : new Matrix(value);\n  }\n\n  static isMatrix(value) {\n    return value != null && value.klass === 'Matrix';\n  }\n\n  get size() {\n    return this.rows * this.columns;\n  }\n\n  apply(callback) {\n    if (typeof callback !== 'function') {\n      throw new TypeError('callback must be a function');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        callback.call(this, i, j);\n      }\n    }\n    return this;\n  }\n\n  to1DArray() {\n    let array = [];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        array.push(this.get(i, j));\n      }\n    }\n    return array;\n  }\n\n  to2DArray() {\n    let copy = [];\n    for (let i = 0; i < this.rows; i++) {\n      copy.push([]);\n      for (let j = 0; j < this.columns; j++) {\n        copy[i].push(this.get(i, j));\n      }\n    }\n    return copy;\n  }\n\n  toJSON() {\n    return this.to2DArray();\n  }\n\n  isRowVector() {\n    return this.rows === 1;\n  }\n\n  isColumnVector() {\n    return this.columns === 1;\n  }\n\n  isVector() {\n    return this.rows === 1 || this.columns === 1;\n  }\n\n  isSquare() {\n    return this.rows === this.columns;\n  }\n\n  isEmpty() {\n    return this.rows === 0 || this.columns === 0;\n  }\n\n  isSymmetric() {\n    if (this.isSquare()) {\n      for (let i = 0; i < this.rows; i++) {\n        for (let j = 0; j <= i; j++) {\n          if (this.get(i, j) !== this.get(j, i)) {\n            return false;\n          }\n        }\n      }\n      return true;\n    }\n    return false;\n  }\n\n  isEchelonForm() {\n    let i = 0;\n    let j = 0;\n    let previousColumn = -1;\n    let isEchelonForm = true;\n    let checked = false;\n    while (i < this.rows && isEchelonForm) {\n      j = 0;\n      checked = false;\n      while (j < this.columns && checked === false) {\n        if (this.get(i, j) === 0) {\n          j++;\n        } else if (this.get(i, j) === 1 && j > previousColumn) {\n          checked = true;\n          previousColumn = j;\n        } else {\n          isEchelonForm = false;\n          checked = true;\n        }\n      }\n      i++;\n    }\n    return isEchelonForm;\n  }\n\n  isReducedEchelonForm() {\n    let i = 0;\n    let j = 0;\n    let previousColumn = -1;\n    let isReducedEchelonForm = true;\n    let checked = false;\n    while (i < this.rows && isReducedEchelonForm) {\n      j = 0;\n      checked = false;\n      while (j < this.columns && checked === false) {\n        if (this.get(i, j) === 0) {\n          j++;\n        } else if (this.get(i, j) === 1 && j > previousColumn) {\n          checked = true;\n          previousColumn = j;\n        } else {\n          isReducedEchelonForm = false;\n          checked = true;\n        }\n      }\n      for (let k = j + 1; k < this.rows; k++) {\n        if (this.get(i, k) !== 0) {\n          isReducedEchelonForm = false;\n        }\n      }\n      i++;\n    }\n    return isReducedEchelonForm;\n  }\n\n  echelonForm() {\n    let result = this.clone();\n    let h = 0;\n    let k = 0;\n    while (h < result.rows && k < result.columns) {\n      let iMax = h;\n      for (let i = h; i < result.rows; i++) {\n        if (result.get(i, k) > result.get(iMax, k)) {\n          iMax = i;\n        }\n      }\n      if (result.get(iMax, k) === 0) {\n        k++;\n      } else {\n        result.swapRows(h, iMax);\n        let tmp = result.get(h, k);\n        for (let j = k; j < result.columns; j++) {\n          result.set(h, j, result.get(h, j) / tmp);\n        }\n        for (let i = h + 1; i < result.rows; i++) {\n          let factor = result.get(i, k) / result.get(h, k);\n          result.set(i, k, 0);\n          for (let j = k + 1; j < result.columns; j++) {\n            result.set(i, j, result.get(i, j) - result.get(h, j) * factor);\n          }\n        }\n        h++;\n        k++;\n      }\n    }\n    return result;\n  }\n\n  reducedEchelonForm() {\n    let result = this.echelonForm();\n    let m = result.columns;\n    let n = result.rows;\n    let h = n - 1;\n    while (h >= 0) {\n      if (result.maxRow(h) === 0) {\n        h--;\n      } else {\n        let p = 0;\n        let pivot = false;\n        while (p < n && pivot === false) {\n          if (result.get(h, p) === 1) {\n            pivot = true;\n          } else {\n            p++;\n          }\n        }\n        for (let i = 0; i < h; i++) {\n          let factor = result.get(i, p);\n          for (let j = p; j < m; j++) {\n            let tmp = result.get(i, j) - factor * result.get(h, j);\n            result.set(i, j, tmp);\n          }\n        }\n        h--;\n      }\n    }\n    return result;\n  }\n\n  set() {\n    throw new Error('set method is unimplemented');\n  }\n\n  get() {\n    throw new Error('get method is unimplemented');\n  }\n\n  repeat(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { rows = 1, columns = 1 } = options;\n    if (!Number.isInteger(rows) || rows <= 0) {\n      throw new TypeError('rows must be a positive integer');\n    }\n    if (!Number.isInteger(columns) || columns <= 0) {\n      throw new TypeError('columns must be a positive integer');\n    }\n    let matrix = new Matrix(this.rows * rows, this.columns * columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        matrix.setSubMatrix(this, this.rows * i, this.columns * j);\n      }\n    }\n    return matrix;\n  }\n\n  fill(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, value);\n      }\n    }\n    return this;\n  }\n\n  neg() {\n    return this.mulS(-1);\n  }\n\n  getRow(index) {\n    checkRowIndex(this, index);\n    let row = [];\n    for (let i = 0; i < this.columns; i++) {\n      row.push(this.get(index, i));\n    }\n    return row;\n  }\n\n  getRowVector(index) {\n    return Matrix.rowVector(this.getRow(index));\n  }\n\n  setRow(index, array) {\n    checkRowIndex(this, index);\n    array = checkRowVector(this, array);\n    for (let i = 0; i < this.columns; i++) {\n      this.set(index, i, array[i]);\n    }\n    return this;\n  }\n\n  swapRows(row1, row2) {\n    checkRowIndex(this, row1);\n    checkRowIndex(this, row2);\n    for (let i = 0; i < this.columns; i++) {\n      let temp = this.get(row1, i);\n      this.set(row1, i, this.get(row2, i));\n      this.set(row2, i, temp);\n    }\n    return this;\n  }\n\n  getColumn(index) {\n    checkColumnIndex(this, index);\n    let column = [];\n    for (let i = 0; i < this.rows; i++) {\n      column.push(this.get(i, index));\n    }\n    return column;\n  }\n\n  getColumnVector(index) {\n    return Matrix.columnVector(this.getColumn(index));\n  }\n\n  setColumn(index, array) {\n    checkColumnIndex(this, index);\n    array = checkColumnVector(this, array);\n    for (let i = 0; i < this.rows; i++) {\n      this.set(i, index, array[i]);\n    }\n    return this;\n  }\n\n  swapColumns(column1, column2) {\n    checkColumnIndex(this, column1);\n    checkColumnIndex(this, column2);\n    for (let i = 0; i < this.rows; i++) {\n      let temp = this.get(i, column1);\n      this.set(i, column1, this.get(i, column2));\n      this.set(i, column2, temp);\n    }\n    return this;\n  }\n\n  addRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + vector[j]);\n      }\n    }\n    return this;\n  }\n\n  subRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - vector[j]);\n      }\n    }\n    return this;\n  }\n\n  mulRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * vector[j]);\n      }\n    }\n    return this;\n  }\n\n  divRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / vector[j]);\n      }\n    }\n    return this;\n  }\n\n  addColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + vector[i]);\n      }\n    }\n    return this;\n  }\n\n  subColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - vector[i]);\n      }\n    }\n    return this;\n  }\n\n  mulColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * vector[i]);\n      }\n    }\n    return this;\n  }\n\n  divColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / vector[i]);\n      }\n    }\n    return this;\n  }\n\n  mulRow(index, value) {\n    checkRowIndex(this, index);\n    for (let i = 0; i < this.columns; i++) {\n      this.set(index, i, this.get(index, i) * value);\n    }\n    return this;\n  }\n\n  mulColumn(index, value) {\n    checkColumnIndex(this, index);\n    for (let i = 0; i < this.rows; i++) {\n      this.set(i, index, this.get(i, index) * value);\n    }\n    return this;\n  }\n\n  max(by) {\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    switch (by) {\n      case 'row': {\n        const max = new Array(this.rows).fill(Number.NEGATIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max[row]) {\n              max[row] = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      case 'column': {\n        const max = new Array(this.columns).fill(Number.NEGATIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max[column]) {\n              max[column] = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      case undefined: {\n        let max = this.get(0, 0);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max) {\n              max = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  maxIndex() {\n    checkNonEmpty(this);\n    let v = this.get(0, 0);\n    let idx = [0, 0];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        if (this.get(i, j) > v) {\n          v = this.get(i, j);\n          idx[0] = i;\n          idx[1] = j;\n        }\n      }\n    }\n    return idx;\n  }\n\n  min(by) {\n    if (this.isEmpty()) {\n      return NaN;\n    }\n\n    switch (by) {\n      case 'row': {\n        const min = new Array(this.rows).fill(Number.POSITIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min[row]) {\n              min[row] = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      case 'column': {\n        const min = new Array(this.columns).fill(Number.POSITIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min[column]) {\n              min[column] = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      case undefined: {\n        let min = this.get(0, 0);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min) {\n              min = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  minIndex() {\n    checkNonEmpty(this);\n    let v = this.get(0, 0);\n    let idx = [0, 0];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        if (this.get(i, j) < v) {\n          v = this.get(i, j);\n          idx[0] = i;\n          idx[1] = j;\n        }\n      }\n    }\n    return idx;\n  }\n\n  maxRow(row) {\n    checkRowIndex(this, row);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(row, 0);\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) > v) {\n        v = this.get(row, i);\n      }\n    }\n    return v;\n  }\n\n  maxRowIndex(row) {\n    checkRowIndex(this, row);\n    checkNonEmpty(this);\n    let v = this.get(row, 0);\n    let idx = [row, 0];\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) > v) {\n        v = this.get(row, i);\n        idx[1] = i;\n      }\n    }\n    return idx;\n  }\n\n  minRow(row) {\n    checkRowIndex(this, row);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(row, 0);\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) < v) {\n        v = this.get(row, i);\n      }\n    }\n    return v;\n  }\n\n  minRowIndex(row) {\n    checkRowIndex(this, row);\n    checkNonEmpty(this);\n    let v = this.get(row, 0);\n    let idx = [row, 0];\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) < v) {\n        v = this.get(row, i);\n        idx[1] = i;\n      }\n    }\n    return idx;\n  }\n\n  maxColumn(column) {\n    checkColumnIndex(this, column);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(0, column);\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) > v) {\n        v = this.get(i, column);\n      }\n    }\n    return v;\n  }\n\n  maxColumnIndex(column) {\n    checkColumnIndex(this, column);\n    checkNonEmpty(this);\n    let v = this.get(0, column);\n    let idx = [0, column];\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) > v) {\n        v = this.get(i, column);\n        idx[0] = i;\n      }\n    }\n    return idx;\n  }\n\n  minColumn(column) {\n    checkColumnIndex(this, column);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(0, column);\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) < v) {\n        v = this.get(i, column);\n      }\n    }\n    return v;\n  }\n\n  minColumnIndex(column) {\n    checkColumnIndex(this, column);\n    checkNonEmpty(this);\n    let v = this.get(0, column);\n    let idx = [0, column];\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) < v) {\n        v = this.get(i, column);\n        idx[0] = i;\n      }\n    }\n    return idx;\n  }\n\n  diag() {\n    let min = Math.min(this.rows, this.columns);\n    let diag = [];\n    for (let i = 0; i < min; i++) {\n      diag.push(this.get(i, i));\n    }\n    return diag;\n  }\n\n  norm(type = 'frobenius') {\n    let result = 0;\n    if (type === 'max') {\n      return this.max();\n    } else if (type === 'frobenius') {\n      for (let i = 0; i < this.rows; i++) {\n        for (let j = 0; j < this.columns; j++) {\n          result = result + this.get(i, j) * this.get(i, j);\n        }\n      }\n      return Math.sqrt(result);\n    } else {\n      throw new RangeError(`unknown norm type: ${type}`);\n    }\n  }\n\n  cumulativeSum() {\n    let sum = 0;\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        sum += this.get(i, j);\n        this.set(i, j, sum);\n      }\n    }\n    return this;\n  }\n\n  dot(vector2) {\n    if (AbstractMatrix.isMatrix(vector2)) vector2 = vector2.to1DArray();\n    let vector1 = this.to1DArray();\n    if (vector1.length !== vector2.length) {\n      throw new RangeError('vectors do not have the same size');\n    }\n    let dot = 0;\n    for (let i = 0; i < vector1.length; i++) {\n      dot += vector1[i] * vector2[i];\n    }\n    return dot;\n  }\n\n  mmul(other) {\n    other = Matrix.checkMatrix(other);\n\n    let m = this.rows;\n    let n = this.columns;\n    let p = other.columns;\n\n    let result = new Matrix(m, p);\n\n    let Bcolj = new Float64Array(n);\n    for (let j = 0; j < p; j++) {\n      for (let k = 0; k < n; k++) {\n        Bcolj[k] = other.get(k, j);\n      }\n\n      for (let i = 0; i < m; i++) {\n        let s = 0;\n        for (let k = 0; k < n; k++) {\n          s += this.get(i, k) * Bcolj[k];\n        }\n\n        result.set(i, j, s);\n      }\n    }\n    return result;\n  }\n\n  strassen2x2(other) {\n    other = Matrix.checkMatrix(other);\n    let result = new Matrix(2, 2);\n    const a11 = this.get(0, 0);\n    const b11 = other.get(0, 0);\n    const a12 = this.get(0, 1);\n    const b12 = other.get(0, 1);\n    const a21 = this.get(1, 0);\n    const b21 = other.get(1, 0);\n    const a22 = this.get(1, 1);\n    const b22 = other.get(1, 1);\n\n    // Compute intermediate values.\n    const m1 = (a11 + a22) * (b11 + b22);\n    const m2 = (a21 + a22) * b11;\n    const m3 = a11 * (b12 - b22);\n    const m4 = a22 * (b21 - b11);\n    const m5 = (a11 + a12) * b22;\n    const m6 = (a21 - a11) * (b11 + b12);\n    const m7 = (a12 - a22) * (b21 + b22);\n\n    // Combine intermediate values into the output.\n    const c00 = m1 + m4 - m5 + m7;\n    const c01 = m3 + m5;\n    const c10 = m2 + m4;\n    const c11 = m1 - m2 + m3 + m6;\n\n    result.set(0, 0, c00);\n    result.set(0, 1, c01);\n    result.set(1, 0, c10);\n    result.set(1, 1, c11);\n    return result;\n  }\n\n  strassen3x3(other) {\n    other = Matrix.checkMatrix(other);\n    let result = new Matrix(3, 3);\n\n    const a00 = this.get(0, 0);\n    const a01 = this.get(0, 1);\n    const a02 = this.get(0, 2);\n    const a10 = this.get(1, 0);\n    const a11 = this.get(1, 1);\n    const a12 = this.get(1, 2);\n    const a20 = this.get(2, 0);\n    const a21 = this.get(2, 1);\n    const a22 = this.get(2, 2);\n\n    const b00 = other.get(0, 0);\n    const b01 = other.get(0, 1);\n    const b02 = other.get(0, 2);\n    const b10 = other.get(1, 0);\n    const b11 = other.get(1, 1);\n    const b12 = other.get(1, 2);\n    const b20 = other.get(2, 0);\n    const b21 = other.get(2, 1);\n    const b22 = other.get(2, 2);\n\n    const m1 = (a00 + a01 + a02 - a10 - a11 - a21 - a22) * b11;\n    const m2 = (a00 - a10) * (-b01 + b11);\n    const m3 = a11 * (-b00 + b01 + b10 - b11 - b12 - b20 + b22);\n    const m4 = (-a00 + a10 + a11) * (b00 - b01 + b11);\n    const m5 = (a10 + a11) * (-b00 + b01);\n    const m6 = a00 * b00;\n    const m7 = (-a00 + a20 + a21) * (b00 - b02 + b12);\n    const m8 = (-a00 + a20) * (b02 - b12);\n    const m9 = (a20 + a21) * (-b00 + b02);\n    const m10 = (a00 + a01 + a02 - a11 - a12 - a20 - a21) * b12;\n    const m11 = a21 * (-b00 + b02 + b10 - b11 - b12 - b20 + b21);\n    const m12 = (-a02 + a21 + a22) * (b11 + b20 - b21);\n    const m13 = (a02 - a22) * (b11 - b21);\n    const m14 = a02 * b20;\n    const m15 = (a21 + a22) * (-b20 + b21);\n    const m16 = (-a02 + a11 + a12) * (b12 + b20 - b22);\n    const m17 = (a02 - a12) * (b12 - b22);\n    const m18 = (a11 + a12) * (-b20 + b22);\n    const m19 = a01 * b10;\n    const m20 = a12 * b21;\n    const m21 = a10 * b02;\n    const m22 = a20 * b01;\n    const m23 = a22 * b22;\n\n    const c00 = m6 + m14 + m19;\n    const c01 = m1 + m4 + m5 + m6 + m12 + m14 + m15;\n    const c02 = m6 + m7 + m9 + m10 + m14 + m16 + m18;\n    const c10 = m2 + m3 + m4 + m6 + m14 + m16 + m17;\n    const c11 = m2 + m4 + m5 + m6 + m20;\n    const c12 = m14 + m16 + m17 + m18 + m21;\n    const c20 = m6 + m7 + m8 + m11 + m12 + m13 + m14;\n    const c21 = m12 + m13 + m14 + m15 + m22;\n    const c22 = m6 + m7 + m8 + m9 + m23;\n\n    result.set(0, 0, c00);\n    result.set(0, 1, c01);\n    result.set(0, 2, c02);\n    result.set(1, 0, c10);\n    result.set(1, 1, c11);\n    result.set(1, 2, c12);\n    result.set(2, 0, c20);\n    result.set(2, 1, c21);\n    result.set(2, 2, c22);\n    return result;\n  }\n\n  mmulStrassen(y) {\n    y = Matrix.checkMatrix(y);\n    let x = this.clone();\n    let r1 = x.rows;\n    let c1 = x.columns;\n    let r2 = y.rows;\n    let c2 = y.columns;\n    if (c1 !== r2) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        `Multiplying ${r1} x ${c1} and ${r2} x ${c2} matrix: dimensions do not match.`,\n      );\n    }\n\n    // Put a matrix into the top left of a matrix of zeros.\n    // `rows` and `cols` are the dimensions of the output matrix.\n    function embed(mat, rows, cols) {\n      let r = mat.rows;\n      let c = mat.columns;\n      if (r === rows && c === cols) {\n        return mat;\n      } else {\n        let resultat = AbstractMatrix.zeros(rows, cols);\n        resultat = resultat.setSubMatrix(mat, 0, 0);\n        return resultat;\n      }\n    }\n\n    // Make sure both matrices are the same size.\n    // This is exclusively for simplicity:\n    // this algorithm can be implemented with matrices of different sizes.\n\n    let r = Math.max(r1, r2);\n    let c = Math.max(c1, c2);\n    x = embed(x, r, c);\n    y = embed(y, r, c);\n\n    // Our recursive multiplication function.\n    function blockMult(a, b, rows, cols) {\n      // For small matrices, resort to naive multiplication.\n      if (rows <= 512 || cols <= 512) {\n        return a.mmul(b); // a is equivalent to this\n      }\n\n      // Apply dynamic padding.\n      if (rows % 2 === 1 && cols % 2 === 1) {\n        a = embed(a, rows + 1, cols + 1);\n        b = embed(b, rows + 1, cols + 1);\n      } else if (rows % 2 === 1) {\n        a = embed(a, rows + 1, cols);\n        b = embed(b, rows + 1, cols);\n      } else if (cols % 2 === 1) {\n        a = embed(a, rows, cols + 1);\n        b = embed(b, rows, cols + 1);\n      }\n\n      let halfRows = parseInt(a.rows / 2, 10);\n      let halfCols = parseInt(a.columns / 2, 10);\n      // Subdivide input matrices.\n      let a11 = a.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n      let b11 = b.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n\n      let a12 = a.subMatrix(0, halfRows - 1, halfCols, a.columns - 1);\n      let b12 = b.subMatrix(0, halfRows - 1, halfCols, b.columns - 1);\n\n      let a21 = a.subMatrix(halfRows, a.rows - 1, 0, halfCols - 1);\n      let b21 = b.subMatrix(halfRows, b.rows - 1, 0, halfCols - 1);\n\n      let a22 = a.subMatrix(halfRows, a.rows - 1, halfCols, a.columns - 1);\n      let b22 = b.subMatrix(halfRows, b.rows - 1, halfCols, b.columns - 1);\n\n      // Compute intermediate values.\n      let m1 = blockMult(\n        AbstractMatrix.add(a11, a22),\n        AbstractMatrix.add(b11, b22),\n        halfRows,\n        halfCols,\n      );\n      let m2 = blockMult(AbstractMatrix.add(a21, a22), b11, halfRows, halfCols);\n      let m3 = blockMult(a11, AbstractMatrix.sub(b12, b22), halfRows, halfCols);\n      let m4 = blockMult(a22, AbstractMatrix.sub(b21, b11), halfRows, halfCols);\n      let m5 = blockMult(AbstractMatrix.add(a11, a12), b22, halfRows, halfCols);\n      let m6 = blockMult(\n        AbstractMatrix.sub(a21, a11),\n        AbstractMatrix.add(b11, b12),\n        halfRows,\n        halfCols,\n      );\n      let m7 = blockMult(\n        AbstractMatrix.sub(a12, a22),\n        AbstractMatrix.add(b21, b22),\n        halfRows,\n        halfCols,\n      );\n\n      // Combine intermediate values into the output.\n      let c11 = AbstractMatrix.add(m1, m4);\n      c11.sub(m5);\n      c11.add(m7);\n      let c12 = AbstractMatrix.add(m3, m5);\n      let c21 = AbstractMatrix.add(m2, m4);\n      let c22 = AbstractMatrix.sub(m1, m2);\n      c22.add(m3);\n      c22.add(m6);\n\n      // Crop output to the desired size (undo dynamic padding).\n      let resultat = AbstractMatrix.zeros(2 * c11.rows, 2 * c11.columns);\n      resultat = resultat.setSubMatrix(c11, 0, 0);\n      resultat = resultat.setSubMatrix(c12, c11.rows, 0);\n      resultat = resultat.setSubMatrix(c21, 0, c11.columns);\n      resultat = resultat.setSubMatrix(c22, c11.rows, c11.columns);\n      return resultat.subMatrix(0, rows - 1, 0, cols - 1);\n    }\n\n    return blockMult(x, y, r, c);\n  }\n\n  scaleRows(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1 } = options;\n    if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n    if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let newMatrix = new Matrix(this.rows, this.columns);\n    for (let i = 0; i < this.rows; i++) {\n      const row = this.getRow(i);\n      if (row.length > 0) {\n        rescale(row, { min, max, output: row });\n      }\n      newMatrix.setRow(i, row);\n    }\n    return newMatrix;\n  }\n\n  scaleColumns(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1 } = options;\n    if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n    if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let newMatrix = new Matrix(this.rows, this.columns);\n    for (let i = 0; i < this.columns; i++) {\n      const column = this.getColumn(i);\n      if (column.length) {\n        rescale(column, {\n          min: min,\n          max: max,\n          output: column,\n        });\n      }\n      newMatrix.setColumn(i, column);\n    }\n    return newMatrix;\n  }\n\n  flipRows() {\n    const middle = Math.ceil(this.columns / 2);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < middle; j++) {\n        let first = this.get(i, j);\n        let last = this.get(i, this.columns - 1 - j);\n        this.set(i, j, last);\n        this.set(i, this.columns - 1 - j, first);\n      }\n    }\n    return this;\n  }\n\n  flipColumns() {\n    const middle = Math.ceil(this.rows / 2);\n    for (let j = 0; j < this.columns; j++) {\n      for (let i = 0; i < middle; i++) {\n        let first = this.get(i, j);\n        let last = this.get(this.rows - 1 - i, j);\n        this.set(i, j, last);\n        this.set(this.rows - 1 - i, j, first);\n      }\n    }\n    return this;\n  }\n\n  kroneckerProduct(other) {\n    other = Matrix.checkMatrix(other);\n\n    let m = this.rows;\n    let n = this.columns;\n    let p = other.rows;\n    let q = other.columns;\n\n    let result = new Matrix(m * p, n * q);\n    for (let i = 0; i < m; i++) {\n      for (let j = 0; j < n; j++) {\n        for (let k = 0; k < p; k++) {\n          for (let l = 0; l < q; l++) {\n            result.set(p * i + k, q * j + l, this.get(i, j) * other.get(k, l));\n          }\n        }\n      }\n    }\n    return result;\n  }\n\n  kroneckerSum(other) {\n    other = Matrix.checkMatrix(other);\n    if (!this.isSquare() || !other.isSquare()) {\n      throw new Error('Kronecker Sum needs two Square Matrices');\n    }\n    let m = this.rows;\n    let n = other.rows;\n    let AxI = this.kroneckerProduct(Matrix.eye(n, n));\n    let IxB = Matrix.eye(m, m).kroneckerProduct(other);\n    return AxI.add(IxB);\n  }\n\n  transpose() {\n    let result = new Matrix(this.columns, this.rows);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        result.set(j, i, this.get(i, j));\n      }\n    }\n    return result;\n  }\n\n  sortRows(compareFunction = compareNumbers) {\n    for (let i = 0; i < this.rows; i++) {\n      this.setRow(i, this.getRow(i).sort(compareFunction));\n    }\n    return this;\n  }\n\n  sortColumns(compareFunction = compareNumbers) {\n    for (let i = 0; i < this.columns; i++) {\n      this.setColumn(i, this.getColumn(i).sort(compareFunction));\n    }\n    return this;\n  }\n\n  subMatrix(startRow, endRow, startColumn, endColumn) {\n    checkRange(this, startRow, endRow, startColumn, endColumn);\n    let newMatrix = new Matrix(\n      endRow - startRow + 1,\n      endColumn - startColumn + 1,\n    );\n    for (let i = startRow; i <= endRow; i++) {\n      for (let j = startColumn; j <= endColumn; j++) {\n        newMatrix.set(i - startRow, j - startColumn, this.get(i, j));\n      }\n    }\n    return newMatrix;\n  }\n\n  subMatrixRow(indices, startColumn, endColumn) {\n    if (startColumn === undefined) startColumn = 0;\n    if (endColumn === undefined) endColumn = this.columns - 1;\n    if (\n      startColumn > endColumn ||\n      startColumn < 0 ||\n      startColumn >= this.columns ||\n      endColumn < 0 ||\n      endColumn >= this.columns\n    ) {\n      throw new RangeError('Argument out of range');\n    }\n\n    let newMatrix = new Matrix(indices.length, endColumn - startColumn + 1);\n    for (let i = 0; i < indices.length; i++) {\n      for (let j = startColumn; j <= endColumn; j++) {\n        if (indices[i] < 0 || indices[i] >= this.rows) {\n          throw new RangeError(`Row index out of range: ${indices[i]}`);\n        }\n        newMatrix.set(i, j - startColumn, this.get(indices[i], j));\n      }\n    }\n    return newMatrix;\n  }\n\n  subMatrixColumn(indices, startRow, endRow) {\n    if (startRow === undefined) startRow = 0;\n    if (endRow === undefined) endRow = this.rows - 1;\n    if (\n      startRow > endRow ||\n      startRow < 0 ||\n      startRow >= this.rows ||\n      endRow < 0 ||\n      endRow >= this.rows\n    ) {\n      throw new RangeError('Argument out of range');\n    }\n\n    let newMatrix = new Matrix(endRow - startRow + 1, indices.length);\n    for (let i = 0; i < indices.length; i++) {\n      for (let j = startRow; j <= endRow; j++) {\n        if (indices[i] < 0 || indices[i] >= this.columns) {\n          throw new RangeError(`Column index out of range: ${indices[i]}`);\n        }\n        newMatrix.set(j - startRow, i, this.get(j, indices[i]));\n      }\n    }\n    return newMatrix;\n  }\n\n  setSubMatrix(matrix, startRow, startColumn) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (matrix.isEmpty()) {\n      return this;\n    }\n    let endRow = startRow + matrix.rows - 1;\n    let endColumn = startColumn + matrix.columns - 1;\n    checkRange(this, startRow, endRow, startColumn, endColumn);\n    for (let i = 0; i < matrix.rows; i++) {\n      for (let j = 0; j < matrix.columns; j++) {\n        this.set(startRow + i, startColumn + j, matrix.get(i, j));\n      }\n    }\n    return this;\n  }\n\n  selection(rowIndices, columnIndices) {\n    checkRowIndices(this, rowIndices);\n    checkColumnIndices(this, columnIndices);\n    let newMatrix = new Matrix(rowIndices.length, columnIndices.length);\n    for (let i = 0; i < rowIndices.length; i++) {\n      let rowIndex = rowIndices[i];\n      for (let j = 0; j < columnIndices.length; j++) {\n        let columnIndex = columnIndices[j];\n        newMatrix.set(i, j, this.get(rowIndex, columnIndex));\n      }\n    }\n    return newMatrix;\n  }\n\n  trace() {\n    let min = Math.min(this.rows, this.columns);\n    let trace = 0;\n    for (let i = 0; i < min; i++) {\n      trace += this.get(i, i);\n    }\n    return trace;\n  }\n\n  clone() {\n    let newMatrix = new Matrix(this.rows, this.columns);\n    for (let row = 0; row < this.rows; row++) {\n      for (let column = 0; column < this.columns; column++) {\n        newMatrix.set(row, column, this.get(row, column));\n      }\n    }\n    return newMatrix;\n  }\n\n  sum(by) {\n    switch (by) {\n      case 'row':\n        return sumByRow(this);\n      case 'column':\n        return sumByColumn(this);\n      case undefined:\n        return sumAll(this);\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  product(by) {\n    switch (by) {\n      case 'row':\n        return productByRow(this);\n      case 'column':\n        return productByColumn(this);\n      case undefined:\n        return productAll(this);\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  mean(by) {\n    const sum = this.sum(by);\n    switch (by) {\n      case 'row': {\n        for (let i = 0; i < this.rows; i++) {\n          sum[i] /= this.columns;\n        }\n        return sum;\n      }\n      case 'column': {\n        for (let i = 0; i < this.columns; i++) {\n          sum[i] /= this.rows;\n        }\n        return sum;\n      }\n      case undefined:\n        return sum / this.size;\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  variance(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { unbiased = true, mean = this.mean(by) } = options;\n    if (typeof unbiased !== 'boolean') {\n      throw new TypeError('unbiased must be a boolean');\n    }\n    switch (by) {\n      case 'row': {\n        if (!isAnyArray(mean)) {\n          throw new TypeError('mean must be an array');\n        }\n        return varianceByRow(this, unbiased, mean);\n      }\n      case 'column': {\n        if (!isAnyArray(mean)) {\n          throw new TypeError('mean must be an array');\n        }\n        return varianceByColumn(this, unbiased, mean);\n      }\n      case undefined: {\n        if (typeof mean !== 'number') {\n          throw new TypeError('mean must be a number');\n        }\n        return varianceAll(this, unbiased, mean);\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  standardDeviation(by, options) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    const variance = this.variance(by, options);\n    if (by === undefined) {\n      return Math.sqrt(variance);\n    } else {\n      for (let i = 0; i < variance.length; i++) {\n        variance[i] = Math.sqrt(variance[i]);\n      }\n      return variance;\n    }\n  }\n\n  center(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { center = this.mean(by) } = options;\n    switch (by) {\n      case 'row': {\n        if (!isAnyArray(center)) {\n          throw new TypeError('center must be an array');\n        }\n        centerByRow(this, center);\n        return this;\n      }\n      case 'column': {\n        if (!isAnyArray(center)) {\n          throw new TypeError('center must be an array');\n        }\n        centerByColumn(this, center);\n        return this;\n      }\n      case undefined: {\n        if (typeof center !== 'number') {\n          throw new TypeError('center must be a number');\n        }\n        centerAll(this, center);\n        return this;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  scale(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    let scale = options.scale;\n    switch (by) {\n      case 'row': {\n        if (scale === undefined) {\n          scale = getScaleByRow(this);\n        } else if (!isAnyArray(scale)) {\n          throw new TypeError('scale must be an array');\n        }\n        scaleByRow(this, scale);\n        return this;\n      }\n      case 'column': {\n        if (scale === undefined) {\n          scale = getScaleByColumn(this);\n        } else if (!isAnyArray(scale)) {\n          throw new TypeError('scale must be an array');\n        }\n        scaleByColumn(this, scale);\n        return this;\n      }\n      case undefined: {\n        if (scale === undefined) {\n          scale = getScaleAll(this);\n        } else if (typeof scale !== 'number') {\n          throw new TypeError('scale must be a number');\n        }\n        scaleAll(this, scale);\n        return this;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  toString(options) {\n    return inspectMatrixWithOptions(this, options);\n  }\n}\n\nAbstractMatrix.prototype.klass = 'Matrix';\nif (typeof Symbol !== 'undefined') {\n  AbstractMatrix.prototype[Symbol.for('nodejs.util.inspect.custom')] =\n    inspectMatrix;\n}\n\nfunction compareNumbers(a, b) {\n  return a - b;\n}\n\nfunction isArrayOfNumbers(array) {\n  return array.every((element) => {\n    return typeof element === 'number';\n  });\n}\n\n// Synonyms\nAbstractMatrix.random = AbstractMatrix.rand;\nAbstractMatrix.randomInt = AbstractMatrix.randInt;\nAbstractMatrix.diagonal = AbstractMatrix.diag;\nAbstractMatrix.prototype.diagonal = AbstractMatrix.prototype.diag;\nAbstractMatrix.identity = AbstractMatrix.eye;\nAbstractMatrix.prototype.negate = AbstractMatrix.prototype.neg;\nAbstractMatrix.prototype.tensorProduct =\n  AbstractMatrix.prototype.kroneckerProduct;\n\nexport default class Matrix extends AbstractMatrix {\n  constructor(nRows, nColumns) {\n    super();\n    if (Matrix.isMatrix(nRows)) {\n      // eslint-disable-next-line no-constructor-return\n      return nRows.clone();\n    } else if (Number.isInteger(nRows) && nRows >= 0) {\n      // Create an empty matrix\n      this.data = [];\n      if (Number.isInteger(nColumns) && nColumns >= 0) {\n        for (let i = 0; i < nRows; i++) {\n          this.data.push(new Float64Array(nColumns));\n        }\n      } else {\n        throw new TypeError('nColumns must be a positive integer');\n      }\n    } else if (isAnyArray(nRows)) {\n      // Copy the values from the 2D array\n      const arrayData = nRows;\n      nRows = arrayData.length;\n      nColumns = nRows ? arrayData[0].length : 0;\n      if (typeof nColumns !== 'number') {\n        throw new TypeError(\n          'Data must be a 2D array with at least one element',\n        );\n      }\n      this.data = [];\n      for (let i = 0; i < nRows; i++) {\n        if (arrayData[i].length !== nColumns) {\n          throw new RangeError('Inconsistent array dimensions');\n        }\n        if (!isArrayOfNumbers(arrayData[i])) {\n          throw new TypeError('Input data contains non-numeric values');\n        }\n        this.data.push(Float64Array.from(arrayData[i]));\n      }\n    } else {\n      throw new TypeError(\n        'First argument must be a positive number or an array',\n      );\n    }\n    this.rows = nRows;\n    this.columns = nColumns;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.data[rowIndex][columnIndex] = value;\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.data[rowIndex][columnIndex];\n  }\n\n  removeRow(index) {\n    checkRowIndex(this, index);\n    this.data.splice(index, 1);\n    this.rows -= 1;\n    return this;\n  }\n\n  addRow(index, array) {\n    if (array === undefined) {\n      array = index;\n      index = this.rows;\n    }\n    checkRowIndex(this, index, true);\n    array = Float64Array.from(checkRowVector(this, array));\n    this.data.splice(index, 0, array);\n    this.rows += 1;\n    return this;\n  }\n\n  removeColumn(index) {\n    checkColumnIndex(this, index);\n    for (let i = 0; i < this.rows; i++) {\n      const newRow = new Float64Array(this.columns - 1);\n      for (let j = 0; j < index; j++) {\n        newRow[j] = this.data[i][j];\n      }\n      for (let j = index + 1; j < this.columns; j++) {\n        newRow[j - 1] = this.data[i][j];\n      }\n      this.data[i] = newRow;\n    }\n    this.columns -= 1;\n    return this;\n  }\n\n  addColumn(index, array) {\n    if (typeof array === 'undefined') {\n      array = index;\n      index = this.columns;\n    }\n    checkColumnIndex(this, index, true);\n    array = checkColumnVector(this, array);\n    for (let i = 0; i < this.rows; i++) {\n      const newRow = new Float64Array(this.columns + 1);\n      let j = 0;\n      for (; j < index; j++) {\n        newRow[j] = this.data[i][j];\n      }\n      newRow[j++] = array[i];\n      for (; j < this.columns + 1; j++) {\n        newRow[j] = this.data[i][j - 1];\n      }\n      this.data[i] = newRow;\n    }\n    this.columns += 1;\n    return this;\n  }\n}\n\ninstallMathOperations(AbstractMatrix, Matrix);\n","import { newArray } from './util';\n\nexport function sumByRow(matrix) {\n  let sum = newArray(matrix.rows);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[i] += matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nexport function sumByColumn(matrix) {\n  let sum = newArray(matrix.columns);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[j] += matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nexport function sumAll(matrix) {\n  let v = 0;\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      v += matrix.get(i, j);\n    }\n  }\n  return v;\n}\n\nexport function productByRow(matrix) {\n  let sum = newArray(matrix.rows, 1);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[i] *= matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nexport function productByColumn(matrix) {\n  let sum = newArray(matrix.columns, 1);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[j] *= matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nexport function productAll(matrix) {\n  let v = 1;\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      v *= matrix.get(i, j);\n    }\n  }\n  return v;\n}\n\nexport function varianceByRow(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const variance = [];\n\n  for (let i = 0; i < rows; i++) {\n    let sum1 = 0;\n    let sum2 = 0;\n    let x = 0;\n    for (let j = 0; j < cols; j++) {\n      x = matrix.get(i, j) - mean[i];\n      sum1 += x;\n      sum2 += x * x;\n    }\n    if (unbiased) {\n      variance.push((sum2 - (sum1 * sum1) / cols) / (cols - 1));\n    } else {\n      variance.push((sum2 - (sum1 * sum1) / cols) / cols);\n    }\n  }\n  return variance;\n}\n\nexport function varianceByColumn(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const variance = [];\n\n  for (let j = 0; j < cols; j++) {\n    let sum1 = 0;\n    let sum2 = 0;\n    let x = 0;\n    for (let i = 0; i < rows; i++) {\n      x = matrix.get(i, j) - mean[j];\n      sum1 += x;\n      sum2 += x * x;\n    }\n    if (unbiased) {\n      variance.push((sum2 - (sum1 * sum1) / rows) / (rows - 1));\n    } else {\n      variance.push((sum2 - (sum1 * sum1) / rows) / rows);\n    }\n  }\n  return variance;\n}\n\nexport function varianceAll(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const size = rows * cols;\n\n  let sum1 = 0;\n  let sum2 = 0;\n  let x = 0;\n  for (let i = 0; i < rows; i++) {\n    for (let j = 0; j < cols; j++) {\n      x = matrix.get(i, j) - mean;\n      sum1 += x;\n      sum2 += x * x;\n    }\n  }\n  if (unbiased) {\n    return (sum2 - (sum1 * sum1) / size) / (size - 1);\n  } else {\n    return (sum2 - (sum1 * sum1) / size) / size;\n  }\n}\n\nexport function centerByRow(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean[i]);\n    }\n  }\n}\n\nexport function centerByColumn(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean[j]);\n    }\n  }\n}\n\nexport function centerAll(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean);\n    }\n  }\n}\n\nexport function getScaleByRow(matrix) {\n  const scale = [];\n  for (let i = 0; i < matrix.rows; i++) {\n    let sum = 0;\n    for (let j = 0; j < matrix.columns; j++) {\n      sum += Math.pow(matrix.get(i, j), 2) / (matrix.columns - 1);\n    }\n    scale.push(Math.sqrt(sum));\n  }\n  return scale;\n}\n\nexport function scaleByRow(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale[i]);\n    }\n  }\n}\n\nexport function getScaleByColumn(matrix) {\n  const scale = [];\n  for (let j = 0; j < matrix.columns; j++) {\n    let sum = 0;\n    for (let i = 0; i < matrix.rows; i++) {\n      sum += Math.pow(matrix.get(i, j), 2) / (matrix.rows - 1);\n    }\n    scale.push(Math.sqrt(sum));\n  }\n  return scale;\n}\n\nexport function scaleByColumn(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale[j]);\n    }\n  }\n}\n\nexport function getScaleAll(matrix) {\n  const divider = matrix.size - 1;\n  let sum = 0;\n  for (let j = 0; j < matrix.columns; j++) {\n    for (let i = 0; i < matrix.rows; i++) {\n      sum += Math.pow(matrix.get(i, j), 2) / divider;\n    }\n  }\n  return Math.sqrt(sum);\n}\n\nexport function scaleAll(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale);\n    }\n  }\n}\n","export function installMathOperations(AbstractMatrix, Matrix) {\n  AbstractMatrix.prototype.add = function add(value) {\n    if (typeof value === 'number') return this.addS(value);\n    return this.addM(value);\n  };\n\n  AbstractMatrix.prototype.addS = function addS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.addM = function addM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.add = function add(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.add(value);\n  };\n\n  AbstractMatrix.prototype.sub = function sub(value) {\n    if (typeof value === 'number') return this.subS(value);\n    return this.subM(value);\n  };\n\n  AbstractMatrix.prototype.subS = function subS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.subM = function subM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sub = function sub(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sub(value);\n  };\n  AbstractMatrix.prototype.subtract = AbstractMatrix.prototype.sub;\n  AbstractMatrix.prototype.subtractS = AbstractMatrix.prototype.subS;\n  AbstractMatrix.prototype.subtractM = AbstractMatrix.prototype.subM;\n  AbstractMatrix.subtract = AbstractMatrix.sub;\n\n  AbstractMatrix.prototype.mul = function mul(value) {\n    if (typeof value === 'number') return this.mulS(value);\n    return this.mulM(value);\n  };\n\n  AbstractMatrix.prototype.mulS = function mulS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.mulM = function mulM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.mul = function mul(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.mul(value);\n  };\n  AbstractMatrix.prototype.multiply = AbstractMatrix.prototype.mul;\n  AbstractMatrix.prototype.multiplyS = AbstractMatrix.prototype.mulS;\n  AbstractMatrix.prototype.multiplyM = AbstractMatrix.prototype.mulM;\n  AbstractMatrix.multiply = AbstractMatrix.mul;\n\n  AbstractMatrix.prototype.div = function div(value) {\n    if (typeof value === 'number') return this.divS(value);\n    return this.divM(value);\n  };\n\n  AbstractMatrix.prototype.divS = function divS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.divM = function divM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.div = function div(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.div(value);\n  };\n  AbstractMatrix.prototype.divide = AbstractMatrix.prototype.div;\n  AbstractMatrix.prototype.divideS = AbstractMatrix.prototype.divS;\n  AbstractMatrix.prototype.divideM = AbstractMatrix.prototype.divM;\n  AbstractMatrix.divide = AbstractMatrix.div;\n\n  AbstractMatrix.prototype.mod = function mod(value) {\n    if (typeof value === 'number') return this.modS(value);\n    return this.modM(value);\n  };\n\n  AbstractMatrix.prototype.modS = function modS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) % value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.modM = function modM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) % matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.mod = function mod(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.mod(value);\n  };\n  AbstractMatrix.prototype.modulus = AbstractMatrix.prototype.mod;\n  AbstractMatrix.prototype.modulusS = AbstractMatrix.prototype.modS;\n  AbstractMatrix.prototype.modulusM = AbstractMatrix.prototype.modM;\n  AbstractMatrix.modulus = AbstractMatrix.mod;\n\n  AbstractMatrix.prototype.and = function and(value) {\n    if (typeof value === 'number') return this.andS(value);\n    return this.andM(value);\n  };\n\n  AbstractMatrix.prototype.andS = function andS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) & value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.andM = function andM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) & matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.and = function and(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.and(value);\n  };\n\n  AbstractMatrix.prototype.or = function or(value) {\n    if (typeof value === 'number') return this.orS(value);\n    return this.orM(value);\n  };\n\n  AbstractMatrix.prototype.orS = function orS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) | value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.orM = function orM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) | matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.or = function or(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.or(value);\n  };\n\n  AbstractMatrix.prototype.xor = function xor(value) {\n    if (typeof value === 'number') return this.xorS(value);\n    return this.xorM(value);\n  };\n\n  AbstractMatrix.prototype.xorS = function xorS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ^ value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.xorM = function xorM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ^ matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.xor = function xor(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.xor(value);\n  };\n\n  AbstractMatrix.prototype.leftShift = function leftShift(value) {\n    if (typeof value === 'number') return this.leftShiftS(value);\n    return this.leftShiftM(value);\n  };\n\n  AbstractMatrix.prototype.leftShiftS = function leftShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) << value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.leftShiftM = function leftShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) << matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.leftShift = function leftShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.leftShift(value);\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShift = function signPropagatingRightShift(value) {\n    if (typeof value === 'number') return this.signPropagatingRightShiftS(value);\n    return this.signPropagatingRightShiftM(value);\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShiftS = function signPropagatingRightShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >> value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShiftM = function signPropagatingRightShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >> matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.signPropagatingRightShift = function signPropagatingRightShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.signPropagatingRightShift(value);\n  };\n\n  AbstractMatrix.prototype.rightShift = function rightShift(value) {\n    if (typeof value === 'number') return this.rightShiftS(value);\n    return this.rightShiftM(value);\n  };\n\n  AbstractMatrix.prototype.rightShiftS = function rightShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >>> value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.rightShiftM = function rightShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >>> matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.rightShift = function rightShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.rightShift(value);\n  };\n  AbstractMatrix.prototype.zeroFillRightShift = AbstractMatrix.prototype.rightShift;\n  AbstractMatrix.prototype.zeroFillRightShiftS = AbstractMatrix.prototype.rightShiftS;\n  AbstractMatrix.prototype.zeroFillRightShiftM = AbstractMatrix.prototype.rightShiftM;\n  AbstractMatrix.zeroFillRightShift = AbstractMatrix.rightShift;\n\n  AbstractMatrix.prototype.not = function not() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, ~(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.not = function not(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.not();\n  };\n\n  AbstractMatrix.prototype.abs = function abs() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.abs(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.abs = function abs(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.abs();\n  };\n\n  AbstractMatrix.prototype.acos = function acos() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.acos(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.acos = function acos(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.acos();\n  };\n\n  AbstractMatrix.prototype.acosh = function acosh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.acosh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.acosh = function acosh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.acosh();\n  };\n\n  AbstractMatrix.prototype.asin = function asin() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.asin(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.asin = function asin(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.asin();\n  };\n\n  AbstractMatrix.prototype.asinh = function asinh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.asinh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.asinh = function asinh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.asinh();\n  };\n\n  AbstractMatrix.prototype.atan = function atan() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.atan(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.atan = function atan(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.atan();\n  };\n\n  AbstractMatrix.prototype.atanh = function atanh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.atanh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.atanh = function atanh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.atanh();\n  };\n\n  AbstractMatrix.prototype.cbrt = function cbrt() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cbrt(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cbrt = function cbrt(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cbrt();\n  };\n\n  AbstractMatrix.prototype.ceil = function ceil() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.ceil(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.ceil = function ceil(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.ceil();\n  };\n\n  AbstractMatrix.prototype.clz32 = function clz32() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.clz32(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.clz32 = function clz32(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.clz32();\n  };\n\n  AbstractMatrix.prototype.cos = function cos() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cos(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cos = function cos(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cos();\n  };\n\n  AbstractMatrix.prototype.cosh = function cosh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cosh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cosh = function cosh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cosh();\n  };\n\n  AbstractMatrix.prototype.exp = function exp() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.exp(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.exp = function exp(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.exp();\n  };\n\n  AbstractMatrix.prototype.expm1 = function expm1() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.expm1(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.expm1 = function expm1(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.expm1();\n  };\n\n  AbstractMatrix.prototype.floor = function floor() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.floor(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.floor = function floor(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.floor();\n  };\n\n  AbstractMatrix.prototype.fround = function fround() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.fround(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.fround = function fround(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.fround();\n  };\n\n  AbstractMatrix.prototype.log = function log() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log = function log(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log();\n  };\n\n  AbstractMatrix.prototype.log1p = function log1p() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log1p(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log1p = function log1p(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log1p();\n  };\n\n  AbstractMatrix.prototype.log10 = function log10() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log10(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log10 = function log10(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log10();\n  };\n\n  AbstractMatrix.prototype.log2 = function log2() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log2(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log2 = function log2(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log2();\n  };\n\n  AbstractMatrix.prototype.round = function round() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.round(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.round = function round(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.round();\n  };\n\n  AbstractMatrix.prototype.sign = function sign() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sign(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sign = function sign(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sign();\n  };\n\n  AbstractMatrix.prototype.sin = function sin() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sin(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sin = function sin(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sin();\n  };\n\n  AbstractMatrix.prototype.sinh = function sinh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sinh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sinh = function sinh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sinh();\n  };\n\n  AbstractMatrix.prototype.sqrt = function sqrt() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sqrt(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sqrt = function sqrt(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sqrt();\n  };\n\n  AbstractMatrix.prototype.tan = function tan() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.tan(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.tan = function tan(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.tan();\n  };\n\n  AbstractMatrix.prototype.tanh = function tanh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.tanh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.tanh = function tanh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.tanh();\n  };\n\n  AbstractMatrix.prototype.trunc = function trunc() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.trunc(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.trunc = function trunc(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.trunc();\n  };\n\n  AbstractMatrix.pow = function pow(matrix, arg0) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.pow(arg0);\n  };\n\n  AbstractMatrix.prototype.pow = function pow(value) {\n    if (typeof value === 'number') return this.powS(value);\n    return this.powM(value);\n  };\n\n  AbstractMatrix.prototype.powS = function powS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.pow(this.get(i, j), value));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.powM = function powM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.pow(this.get(i, j), matrix.get(i, j)));\n      }\n    }\n    return this;\n  };\n}\n","import { AbstractMatrix } from '../matrix';\n\nexport default class WrapperMatrix2D extends AbstractMatrix {\n  constructor(data) {\n    super();\n    this.data = data;\n    this.rows = data.length;\n    this.columns = data[0].length;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.data[rowIndex][columnIndex] = value;\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.data[rowIndex][columnIndex];\n  }\n}\n","import Matrix from '../matrix';\nimport WrapperMatrix2D from '../wrap/WrapperMatrix2D';\n\nexport default class LuDecomposition {\n  constructor(matrix) {\n    matrix = WrapperMatrix2D.checkMatrix(matrix);\n\n    let lu = matrix.clone();\n    let rows = lu.rows;\n    let columns = lu.columns;\n    let pivotVector = new Float64Array(rows);\n    let pivotSign = 1;\n    let i, j, k, p, s, t, v;\n    let LUcolj, kmax;\n\n    for (i = 0; i < rows; i++) {\n      pivotVector[i] = i;\n    }\n\n    LUcolj = new Float64Array(rows);\n\n    for (j = 0; j < columns; j++) {\n      for (i = 0; i < rows; i++) {\n        LUcolj[i] = lu.get(i, j);\n      }\n\n      for (i = 0; i < rows; i++) {\n        kmax = Math.min(i, j);\n        s = 0;\n        for (k = 0; k < kmax; k++) {\n          s += lu.get(i, k) * LUcolj[k];\n        }\n        LUcolj[i] -= s;\n        lu.set(i, j, LUcolj[i]);\n      }\n\n      p = j;\n      for (i = j + 1; i < rows; i++) {\n        if (Math.abs(LUcolj[i]) > Math.abs(LUcolj[p])) {\n          p = i;\n        }\n      }\n\n      if (p !== j) {\n        for (k = 0; k < columns; k++) {\n          t = lu.get(p, k);\n          lu.set(p, k, lu.get(j, k));\n          lu.set(j, k, t);\n        }\n\n        v = pivotVector[p];\n        pivotVector[p] = pivotVector[j];\n        pivotVector[j] = v;\n\n        pivotSign = -pivotSign;\n      }\n\n      if (j < rows && lu.get(j, j) !== 0) {\n        for (i = j + 1; i < rows; i++) {\n          lu.set(i, j, lu.get(i, j) / lu.get(j, j));\n        }\n      }\n    }\n\n    this.LU = lu;\n    this.pivotVector = pivotVector;\n    this.pivotSign = pivotSign;\n  }\n\n  isSingular() {\n    let data = this.LU;\n    let col = data.columns;\n    for (let j = 0; j < col; j++) {\n      if (data.get(j, j) === 0) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  solve(value) {\n    value = Matrix.checkMatrix(value);\n\n    let lu = this.LU;\n    let rows = lu.rows;\n\n    if (rows !== value.rows) {\n      throw new Error('Invalid matrix dimensions');\n    }\n    if (this.isSingular()) {\n      throw new Error('LU matrix is singular');\n    }\n\n    let count = value.columns;\n    let X = value.subMatrixRow(this.pivotVector, 0, count - 1);\n    let columns = lu.columns;\n    let i, j, k;\n\n    for (k = 0; k < columns; k++) {\n      for (i = k + 1; i < columns; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * lu.get(i, k));\n        }\n      }\n    }\n    for (k = columns - 1; k >= 0; k--) {\n      for (j = 0; j < count; j++) {\n        X.set(k, j, X.get(k, j) / lu.get(k, k));\n      }\n      for (i = 0; i < k; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * lu.get(i, k));\n        }\n      }\n    }\n    return X;\n  }\n\n  get determinant() {\n    let data = this.LU;\n    if (!data.isSquare()) {\n      throw new Error('Matrix must be square');\n    }\n    let determinant = this.pivotSign;\n    let col = data.columns;\n    for (let j = 0; j < col; j++) {\n      determinant *= data.get(j, j);\n    }\n    return determinant;\n  }\n\n  get lowerTriangularMatrix() {\n    let data = this.LU;\n    let rows = data.rows;\n    let columns = data.columns;\n    let X = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        if (i > j) {\n          X.set(i, j, data.get(i, j));\n        } else if (i === j) {\n          X.set(i, j, 1);\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get upperTriangularMatrix() {\n    let data = this.LU;\n    let rows = data.rows;\n    let columns = data.columns;\n    let X = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        if (i <= j) {\n          X.set(i, j, data.get(i, j));\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get pivotPermutationVector() {\n    return Array.from(this.pivotVector);\n  }\n}\n","export function hypotenuse(a, b) {\n  let r = 0;\n  if (Math.abs(a) > Math.abs(b)) {\n    r = b / a;\n    return Math.abs(a) * Math.sqrt(1 + r * r);\n  }\n  if (b !== 0) {\n    r = a / b;\n    return Math.abs(b) * Math.sqrt(1 + r * r);\n  }\n  return 0;\n}\n","import Matrix from '../matrix';\nimport WrapperMatrix2D from '../wrap/WrapperMatrix2D';\n\nimport { hypotenuse } from './util';\n\nexport default class QrDecomposition {\n  constructor(value) {\n    value = WrapperMatrix2D.checkMatrix(value);\n\n    let qr = value.clone();\n    let m = value.rows;\n    let n = value.columns;\n    let rdiag = new Float64Array(n);\n    let i, j, k, s;\n\n    for (k = 0; k < n; k++) {\n      let nrm = 0;\n      for (i = k; i < m; i++) {\n        nrm = hypotenuse(nrm, qr.get(i, k));\n      }\n      if (nrm !== 0) {\n        if (qr.get(k, k) < 0) {\n          nrm = -nrm;\n        }\n        for (i = k; i < m; i++) {\n          qr.set(i, k, qr.get(i, k) / nrm);\n        }\n        qr.set(k, k, qr.get(k, k) + 1);\n        for (j = k + 1; j < n; j++) {\n          s = 0;\n          for (i = k; i < m; i++) {\n            s += qr.get(i, k) * qr.get(i, j);\n          }\n          s = -s / qr.get(k, k);\n          for (i = k; i < m; i++) {\n            qr.set(i, j, qr.get(i, j) + s * qr.get(i, k));\n          }\n        }\n      }\n      rdiag[k] = -nrm;\n    }\n\n    this.QR = qr;\n    this.Rdiag = rdiag;\n  }\n\n  solve(value) {\n    value = Matrix.checkMatrix(value);\n\n    let qr = this.QR;\n    let m = qr.rows;\n\n    if (value.rows !== m) {\n      throw new Error('Matrix row dimensions must agree');\n    }\n    if (!this.isFullRank()) {\n      throw new Error('Matrix is rank deficient');\n    }\n\n    let count = value.columns;\n    let X = value.clone();\n    let n = qr.columns;\n    let i, j, k, s;\n\n    for (k = 0; k < n; k++) {\n      for (j = 0; j < count; j++) {\n        s = 0;\n        for (i = k; i < m; i++) {\n          s += qr.get(i, k) * X.get(i, j);\n        }\n        s = -s / qr.get(k, k);\n        for (i = k; i < m; i++) {\n          X.set(i, j, X.get(i, j) + s * qr.get(i, k));\n        }\n      }\n    }\n    for (k = n - 1; k >= 0; k--) {\n      for (j = 0; j < count; j++) {\n        X.set(k, j, X.get(k, j) / this.Rdiag[k]);\n      }\n      for (i = 0; i < k; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * qr.get(i, k));\n        }\n      }\n    }\n\n    return X.subMatrix(0, n - 1, 0, count - 1);\n  }\n\n  isFullRank() {\n    let columns = this.QR.columns;\n    for (let i = 0; i < columns; i++) {\n      if (this.Rdiag[i] === 0) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  get upperTriangularMatrix() {\n    let qr = this.QR;\n    let n = qr.columns;\n    let X = new Matrix(n, n);\n    let i, j;\n    for (i = 0; i < n; i++) {\n      for (j = 0; j < n; j++) {\n        if (i < j) {\n          X.set(i, j, qr.get(i, j));\n        } else if (i === j) {\n          X.set(i, j, this.Rdiag[i]);\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get orthogonalMatrix() {\n    let qr = this.QR;\n    let rows = qr.rows;\n    let columns = qr.columns;\n    let X = new Matrix(rows, columns);\n    let i, j, k, s;\n\n    for (k = columns - 1; k >= 0; k--) {\n      for (i = 0; i < rows; i++) {\n        X.set(i, k, 0);\n      }\n      X.set(k, k, 1);\n      for (j = k; j < columns; j++) {\n        if (qr.get(k, k) !== 0) {\n          s = 0;\n          for (i = k; i < rows; i++) {\n            s += qr.get(i, k) * X.get(i, j);\n          }\n\n          s = -s / qr.get(k, k);\n\n          for (i = k; i < rows; i++) {\n            X.set(i, j, X.get(i, j) + s * qr.get(i, k));\n          }\n        }\n      }\n    }\n    return X;\n  }\n}\n","import Matrix from '../matrix';\nimport WrapperMatrix2D from '../wrap/WrapperMatrix2D';\n\nimport { hypotenuse } from './util';\n\nexport default class SingularValueDecomposition {\n  constructor(value, options = {}) {\n    value = WrapperMatrix2D.checkMatrix(value);\n\n    if (value.isEmpty()) {\n      throw new Error('Matrix must be non-empty');\n    }\n\n    let m = value.rows;\n    let n = value.columns;\n\n    const {\n      computeLeftSingularVectors = true,\n      computeRightSingularVectors = true,\n      autoTranspose = false,\n    } = options;\n\n    let wantu = Boolean(computeLeftSingularVectors);\n    let wantv = Boolean(computeRightSingularVectors);\n\n    let swapped = false;\n    let a;\n    if (m < n) {\n      if (!autoTranspose) {\n        a = value.clone();\n        // eslint-disable-next-line no-console\n        console.warn(\n          'Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose',\n        );\n      } else {\n        a = value.transpose();\n        m = a.rows;\n        n = a.columns;\n        swapped = true;\n        let aux = wantu;\n        wantu = wantv;\n        wantv = aux;\n      }\n    } else {\n      a = value.clone();\n    }\n\n    let nu = Math.min(m, n);\n    let ni = Math.min(m + 1, n);\n    let s = new Float64Array(ni);\n    let U = new Matrix(m, nu);\n    let V = new Matrix(n, n);\n\n    let e = new Float64Array(n);\n    let work = new Float64Array(m);\n\n    let si = new Float64Array(ni);\n    for (let i = 0; i < ni; i++) si[i] = i;\n\n    let nct = Math.min(m - 1, n);\n    let nrt = Math.max(0, Math.min(n - 2, m));\n    let mrc = Math.max(nct, nrt);\n\n    for (let k = 0; k < mrc; k++) {\n      if (k < nct) {\n        s[k] = 0;\n        for (let i = k; i < m; i++) {\n          s[k] = hypotenuse(s[k], a.get(i, k));\n        }\n        if (s[k] !== 0) {\n          if (a.get(k, k) < 0) {\n            s[k] = -s[k];\n          }\n          for (let i = k; i < m; i++) {\n            a.set(i, k, a.get(i, k) / s[k]);\n          }\n          a.set(k, k, a.get(k, k) + 1);\n        }\n        s[k] = -s[k];\n      }\n\n      for (let j = k + 1; j < n; j++) {\n        if (k < nct && s[k] !== 0) {\n          let t = 0;\n          for (let i = k; i < m; i++) {\n            t += a.get(i, k) * a.get(i, j);\n          }\n          t = -t / a.get(k, k);\n          for (let i = k; i < m; i++) {\n            a.set(i, j, a.get(i, j) + t * a.get(i, k));\n          }\n        }\n        e[j] = a.get(k, j);\n      }\n\n      if (wantu && k < nct) {\n        for (let i = k; i < m; i++) {\n          U.set(i, k, a.get(i, k));\n        }\n      }\n\n      if (k < nrt) {\n        e[k] = 0;\n        for (let i = k + 1; i < n; i++) {\n          e[k] = hypotenuse(e[k], e[i]);\n        }\n        if (e[k] !== 0) {\n          if (e[k + 1] < 0) {\n            e[k] = 0 - e[k];\n          }\n          for (let i = k + 1; i < n; i++) {\n            e[i] /= e[k];\n          }\n          e[k + 1] += 1;\n        }\n        e[k] = -e[k];\n        if (k + 1 < m && e[k] !== 0) {\n          for (let i = k + 1; i < m; i++) {\n            work[i] = 0;\n          }\n          for (let i = k + 1; i < m; i++) {\n            for (let j = k + 1; j < n; j++) {\n              work[i] += e[j] * a.get(i, j);\n            }\n          }\n          for (let j = k + 1; j < n; j++) {\n            let t = -e[j] / e[k + 1];\n            for (let i = k + 1; i < m; i++) {\n              a.set(i, j, a.get(i, j) + t * work[i]);\n            }\n          }\n        }\n        if (wantv) {\n          for (let i = k + 1; i < n; i++) {\n            V.set(i, k, e[i]);\n          }\n        }\n      }\n    }\n\n    let p = Math.min(n, m + 1);\n    if (nct < n) {\n      s[nct] = a.get(nct, nct);\n    }\n    if (m < p) {\n      s[p - 1] = 0;\n    }\n    if (nrt + 1 < p) {\n      e[nrt] = a.get(nrt, p - 1);\n    }\n    e[p - 1] = 0;\n\n    if (wantu) {\n      for (let j = nct; j < nu; j++) {\n        for (let i = 0; i < m; i++) {\n          U.set(i, j, 0);\n        }\n        U.set(j, j, 1);\n      }\n      for (let k = nct - 1; k >= 0; k--) {\n        if (s[k] !== 0) {\n          for (let j = k + 1; j < nu; j++) {\n            let t = 0;\n            for (let i = k; i < m; i++) {\n              t += U.get(i, k) * U.get(i, j);\n            }\n            t = -t / U.get(k, k);\n            for (let i = k; i < m; i++) {\n              U.set(i, j, U.get(i, j) + t * U.get(i, k));\n            }\n          }\n          for (let i = k; i < m; i++) {\n            U.set(i, k, -U.get(i, k));\n          }\n          U.set(k, k, 1 + U.get(k, k));\n          for (let i = 0; i < k - 1; i++) {\n            U.set(i, k, 0);\n          }\n        } else {\n          for (let i = 0; i < m; i++) {\n            U.set(i, k, 0);\n          }\n          U.set(k, k, 1);\n        }\n      }\n    }\n\n    if (wantv) {\n      for (let k = n - 1; k >= 0; k--) {\n        if (k < nrt && e[k] !== 0) {\n          for (let j = k + 1; j < n; j++) {\n            let t = 0;\n            for (let i = k + 1; i < n; i++) {\n              t += V.get(i, k) * V.get(i, j);\n            }\n            t = -t / V.get(k + 1, k);\n            for (let i = k + 1; i < n; i++) {\n              V.set(i, j, V.get(i, j) + t * V.get(i, k));\n            }\n          }\n        }\n        for (let i = 0; i < n; i++) {\n          V.set(i, k, 0);\n        }\n        V.set(k, k, 1);\n      }\n    }\n\n    let pp = p - 1;\n    let iter = 0;\n    let eps = Number.EPSILON;\n    while (p > 0) {\n      let k, kase;\n      for (k = p - 2; k >= -1; k--) {\n        if (k === -1) {\n          break;\n        }\n        const alpha =\n          Number.MIN_VALUE + eps * Math.abs(s[k] + Math.abs(s[k + 1]));\n        if (Math.abs(e[k]) <= alpha || Number.isNaN(e[k])) {\n          e[k] = 0;\n          break;\n        }\n      }\n      if (k === p - 2) {\n        kase = 4;\n      } else {\n        let ks;\n        for (ks = p - 1; ks >= k; ks--) {\n          if (ks === k) {\n            break;\n          }\n          let t =\n            (ks !== p ? Math.abs(e[ks]) : 0) +\n            (ks !== k + 1 ? Math.abs(e[ks - 1]) : 0);\n          if (Math.abs(s[ks]) <= eps * t) {\n            s[ks] = 0;\n            break;\n          }\n        }\n        if (ks === k) {\n          kase = 3;\n        } else if (ks === p - 1) {\n          kase = 1;\n        } else {\n          kase = 2;\n          k = ks;\n        }\n      }\n\n      k++;\n\n      switch (kase) {\n        case 1: {\n          let f = e[p - 2];\n          e[p - 2] = 0;\n          for (let j = p - 2; j >= k; j--) {\n            let t = hypotenuse(s[j], f);\n            let cs = s[j] / t;\n            let sn = f / t;\n            s[j] = t;\n            if (j !== k) {\n              f = -sn * e[j - 1];\n              e[j - 1] = cs * e[j - 1];\n            }\n            if (wantv) {\n              for (let i = 0; i < n; i++) {\n                t = cs * V.get(i, j) + sn * V.get(i, p - 1);\n                V.set(i, p - 1, -sn * V.get(i, j) + cs * V.get(i, p - 1));\n                V.set(i, j, t);\n              }\n            }\n          }\n          break;\n        }\n        case 2: {\n          let f = e[k - 1];\n          e[k - 1] = 0;\n          for (let j = k; j < p; j++) {\n            let t = hypotenuse(s[j], f);\n            let cs = s[j] / t;\n            let sn = f / t;\n            s[j] = t;\n            f = -sn * e[j];\n            e[j] = cs * e[j];\n            if (wantu) {\n              for (let i = 0; i < m; i++) {\n                t = cs * U.get(i, j) + sn * U.get(i, k - 1);\n                U.set(i, k - 1, -sn * U.get(i, j) + cs * U.get(i, k - 1));\n                U.set(i, j, t);\n              }\n            }\n          }\n          break;\n        }\n        case 3: {\n          const scale = Math.max(\n            Math.abs(s[p - 1]),\n            Math.abs(s[p - 2]),\n            Math.abs(e[p - 2]),\n            Math.abs(s[k]),\n            Math.abs(e[k]),\n          );\n          const sp = s[p - 1] / scale;\n          const spm1 = s[p - 2] / scale;\n          const epm1 = e[p - 2] / scale;\n          const sk = s[k] / scale;\n          const ek = e[k] / scale;\n          const b = ((spm1 + sp) * (spm1 - sp) + epm1 * epm1) / 2;\n          const c = sp * epm1 * (sp * epm1);\n          let shift = 0;\n          if (b !== 0 || c !== 0) {\n            if (b < 0) {\n              shift = 0 - Math.sqrt(b * b + c);\n            } else {\n              shift = Math.sqrt(b * b + c);\n            }\n            shift = c / (b + shift);\n          }\n          let f = (sk + sp) * (sk - sp) + shift;\n          let g = sk * ek;\n          for (let j = k; j < p - 1; j++) {\n            let t = hypotenuse(f, g);\n            if (t === 0) t = Number.MIN_VALUE;\n            let cs = f / t;\n            let sn = g / t;\n            if (j !== k) {\n              e[j - 1] = t;\n            }\n            f = cs * s[j] + sn * e[j];\n            e[j] = cs * e[j] - sn * s[j];\n            g = sn * s[j + 1];\n            s[j + 1] = cs * s[j + 1];\n            if (wantv) {\n              for (let i = 0; i < n; i++) {\n                t = cs * V.get(i, j) + sn * V.get(i, j + 1);\n                V.set(i, j + 1, -sn * V.get(i, j) + cs * V.get(i, j + 1));\n                V.set(i, j, t);\n              }\n            }\n            t = hypotenuse(f, g);\n            if (t === 0) t = Number.MIN_VALUE;\n            cs = f / t;\n            sn = g / t;\n            s[j] = t;\n            f = cs * e[j] + sn * s[j + 1];\n            s[j + 1] = -sn * e[j] + cs * s[j + 1];\n            g = sn * e[j + 1];\n            e[j + 1] = cs * e[j + 1];\n            if (wantu && j < m - 1) {\n              for (let i = 0; i < m; i++) {\n                t = cs * U.get(i, j) + sn * U.get(i, j + 1);\n                U.set(i, j + 1, -sn * U.get(i, j) + cs * U.get(i, j + 1));\n                U.set(i, j, t);\n              }\n            }\n          }\n          e[p - 2] = f;\n          iter = iter + 1;\n          break;\n        }\n        case 4: {\n          if (s[k] <= 0) {\n            s[k] = s[k] < 0 ? -s[k] : 0;\n            if (wantv) {\n              for (let i = 0; i <= pp; i++) {\n                V.set(i, k, -V.get(i, k));\n              }\n            }\n          }\n          while (k < pp) {\n            if (s[k] >= s[k + 1]) {\n              break;\n            }\n            let t = s[k];\n            s[k] = s[k + 1];\n            s[k + 1] = t;\n            if (wantv && k < n - 1) {\n              for (let i = 0; i < n; i++) {\n                t = V.get(i, k + 1);\n                V.set(i, k + 1, V.get(i, k));\n                V.set(i, k, t);\n              }\n            }\n            if (wantu && k < m - 1) {\n              for (let i = 0; i < m; i++) {\n                t = U.get(i, k + 1);\n                U.set(i, k + 1, U.get(i, k));\n                U.set(i, k, t);\n              }\n            }\n            k++;\n          }\n          iter = 0;\n          p--;\n          break;\n        }\n        // no default\n      }\n    }\n\n    if (swapped) {\n      let tmp = V;\n      V = U;\n      U = tmp;\n    }\n\n    this.m = m;\n    this.n = n;\n    this.s = s;\n    this.U = U;\n    this.V = V;\n  }\n\n  solve(value) {\n    let Y = value;\n    let e = this.threshold;\n    let scols = this.s.length;\n    let Ls = Matrix.zeros(scols, scols);\n\n    for (let i = 0; i < scols; i++) {\n      if (Math.abs(this.s[i]) <= e) {\n        Ls.set(i, i, 0);\n      } else {\n        Ls.set(i, i, 1 / this.s[i]);\n      }\n    }\n\n    let U = this.U;\n    let V = this.rightSingularVectors;\n\n    let VL = V.mmul(Ls);\n    let vrows = V.rows;\n    let urows = U.rows;\n    let VLU = Matrix.zeros(vrows, urows);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < urows; j++) {\n        let sum = 0;\n        for (let k = 0; k < scols; k++) {\n          sum += VL.get(i, k) * U.get(j, k);\n        }\n        VLU.set(i, j, sum);\n      }\n    }\n\n    return VLU.mmul(Y);\n  }\n\n  solveForDiagonal(value) {\n    return this.solve(Matrix.diag(value));\n  }\n\n  inverse() {\n    let V = this.V;\n    let e = this.threshold;\n    let vrows = V.rows;\n    let vcols = V.columns;\n    let X = new Matrix(vrows, this.s.length);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < vcols; j++) {\n        if (Math.abs(this.s[j]) > e) {\n          X.set(i, j, V.get(i, j) / this.s[j]);\n        }\n      }\n    }\n\n    let U = this.U;\n\n    let urows = U.rows;\n    let ucols = U.columns;\n    let Y = new Matrix(vrows, urows);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < urows; j++) {\n        let sum = 0;\n        for (let k = 0; k < ucols; k++) {\n          sum += X.get(i, k) * U.get(j, k);\n        }\n        Y.set(i, j, sum);\n      }\n    }\n\n    return Y;\n  }\n\n  get condition() {\n    return this.s[0] / this.s[Math.min(this.m, this.n) - 1];\n  }\n\n  get norm2() {\n    return this.s[0];\n  }\n\n  get rank() {\n    let tol = Math.max(this.m, this.n) * this.s[0] * Number.EPSILON;\n    let r = 0;\n    let s = this.s;\n    for (let i = 0, ii = s.length; i < ii; i++) {\n      if (s[i] > tol) {\n        r++;\n      }\n    }\n    return r;\n  }\n\n  get diagonal() {\n    return Array.from(this.s);\n  }\n\n  get threshold() {\n    return (Number.EPSILON / 2) * Math.max(this.m, this.n) * this.s[0];\n  }\n\n  get leftSingularVectors() {\n    return this.U;\n  }\n\n  get rightSingularVectors() {\n    return this.V;\n  }\n\n  get diagonalMatrix() {\n    return Matrix.diag(this.s);\n  }\n}\n","import { inverse, Matrix } from 'ml-matrix';\n\n/**\n * Difference of the matrix function over the parameters\n * @ignore\n * @param {{x:Array<number>, y:Array<number>}} data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param {Array<number>} evaluatedData - Array of previous evaluated function values\n * @param {Array<number>} params - Array of previous parameter values\n * @param {number} gradientDifference - Adjustment for decrease the damping parameter\n * @param {function} paramFunction - The parameters and returns a function with the independent variable as a parameter\n * @return {Matrix}\n */\nfunction gradientFunction(\n  data,\n  evaluatedData,\n  params,\n  gradientDifference,\n  paramFunction,\n) {\n  const n = params.length;\n  const m = data.x.length;\n\n  let ans = new Array(n);\n\n  for (let param = 0; param < n; param++) {\n    ans[param] = new Array(m);\n    let auxParams = params.slice();\n    auxParams[param] += gradientDifference;\n    let funcParam = paramFunction(auxParams);\n\n    for (let point = 0; point < m; point++) {\n      ans[param][point] = evaluatedData[point] - funcParam(data.x[point]);\n    }\n  }\n  return new Matrix(ans);\n}\n\n/**\n * Matrix function over the samples\n * @ignore\n * @param {{x:Array<number>, y:Array<number>}} data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param {Array<number>} evaluatedData - Array of previous evaluated function values\n * @return {Matrix}\n */\nfunction matrixFunction(data, evaluatedData) {\n  const m = data.x.length;\n\n  let ans = new Array(m);\n\n  for (let point = 0; point < m; point++) {\n    ans[point] = [data.y[point] - evaluatedData[point]];\n  }\n\n  return new Matrix(ans);\n}\n\n/**\n * Iteration for Levenberg-Marquardt\n * @ignore\n * @param {{x:Array<number>, y:Array<number>}} data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param {Array<number>} params - Array of previous parameter values\n * @param {number} damping - Levenberg-Marquardt parameter\n * @param {number} gradientDifference - Adjustment for decrease the damping parameter\n * @param {function} parameterizedFunction - The parameters and returns a function with the independent variable as a parameter\n * @return {Array<number>}\n */\nexport default function step(\n  data,\n  params,\n  damping,\n  gradientDifference,\n  parameterizedFunction,\n) {\n  let value = damping * gradientDifference * gradientDifference;\n  let identity = Matrix.eye(params.length, params.length, value);\n\n  const func = parameterizedFunction(params);\n\n  let evaluatedData = new Float64Array(data.x.length);\n  for (let i = 0; i < data.x.length; i++) {\n    evaluatedData[i] = func(data.x[i]);\n  }\n\n  let gradientFunc = gradientFunction(\n    data,\n    evaluatedData,\n    params,\n    gradientDifference,\n    parameterizedFunction,\n  );\n  let matrixFunc = matrixFunction(data, evaluatedData);\n  let inverseMatrix = inverse(\n    identity.add(gradientFunc.mmul(gradientFunc.transpose())),\n  );\n\n  params = new Matrix([params]);\n  params = params.sub(\n    inverseMatrix\n      .mmul(gradientFunc)\n      .mmul(matrixFunc)\n      .mul(gradientDifference)\n      .transpose(),\n  );\n\n  return params.to1DArray();\n}\n","import LuDecomposition from './dc/lu';\nimport QrDecomposition from './dc/qr';\nimport SingularValueDecomposition from './dc/svd';\nimport Matrix from './matrix';\nimport WrapperMatrix2D from './wrap/WrapperMatrix2D';\n\nexport function inverse(matrix, useSVD = false) {\n  matrix = WrapperMatrix2D.checkMatrix(matrix);\n  if (useSVD) {\n    return new SingularValueDecomposition(matrix).inverse();\n  } else {\n    return solve(matrix, Matrix.eye(matrix.rows));\n  }\n}\n\nexport function solve(leftHandSide, rightHandSide, useSVD = false) {\n  leftHandSide = WrapperMatrix2D.checkMatrix(leftHandSide);\n  rightHandSide = WrapperMatrix2D.checkMatrix(rightHandSide);\n  if (useSVD) {\n    return new SingularValueDecomposition(leftHandSide).solve(rightHandSide);\n  } else {\n    return leftHandSide.isSquare()\n      ? new LuDecomposition(leftHandSide).solve(rightHandSide)\n      : new QrDecomposition(leftHandSide).solve(rightHandSide);\n  }\n}\n","import isArray from 'is-any-array';\n\nimport errorCalculation from './errorCalculation';\nimport step from './step';\n\n/**\n * Curve fitting algorithm\n * @param {{x:Array<number>, y:Array<number>}} data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param {function} parameterizedFunction - The parameters and returns a function with the independent variable as a parameter\n * @param {object} [options] - Options object\n * @param {number} [options.damping] - Levenberg-Marquardt parameter\n * @param {number} [options.gradientDifference = 10e-2] - Adjustment for decrease the damping parameter\n * @param {Array<number>} [options.minValues] - Minimum allowed values for parameters\n * @param {Array<number>} [options.maxValues] - Maximum allowed values for parameters\n * @param {Array<number>} [options.initialValues] - Array of initial parameter values\n * @param {number} [options.maxIterations = 100] - Maximum of allowed iterations\n * @param {number} [options.errorTolerance = 10e-3] - Minimum uncertainty allowed for each point\n * @return {{parameterValues: Array<number>, parameterError: number, iterations: number}}\n */\nexport default function levenbergMarquardt(\n  data,\n  parameterizedFunction,\n  options = {},\n) {\n  let {\n    maxIterations = 100,\n    gradientDifference = 10e-2,\n    damping = 0,\n    errorTolerance = 10e-3,\n    minValues,\n    maxValues,\n    initialValues,\n  } = options;\n\n  if (damping <= 0) {\n    throw new Error('The damping option must be a positive number');\n  } else if (!data.x || !data.y) {\n    throw new Error('The data parameter must have x and y elements');\n  } else if (\n    !isArray(data.x) ||\n    data.x.length < 2 ||\n    !isArray(data.y) ||\n    data.y.length < 2\n  ) {\n    throw new Error(\n      'The data parameter elements must be an array with more than 2 points',\n    );\n  } else if (data.x.length !== data.y.length) {\n    throw new Error('The data parameter elements must have the same size');\n  }\n\n  let parameters =\n    initialValues || new Array(parameterizedFunction.length).fill(1);\n  let parLen = parameters.length;\n  maxValues = maxValues || new Array(parLen).fill(Number.MAX_SAFE_INTEGER);\n  minValues = minValues || new Array(parLen).fill(Number.MIN_SAFE_INTEGER);\n\n  if (maxValues.length !== minValues.length) {\n    throw new Error('minValues and maxValues must be the same size');\n  }\n\n  if (!isArray(parameters)) {\n    throw new Error('initialValues must be an array');\n  }\n\n  let error = errorCalculation(data, parameters, parameterizedFunction);\n\n  let converged = error <= errorTolerance;\n\n  let iteration;\n  for (iteration = 0; iteration < maxIterations && !converged; iteration++) {\n    parameters = step(\n      data,\n      parameters,\n      damping,\n      gradientDifference,\n      parameterizedFunction,\n    );\n\n    for (let k = 0; k < parLen; k++) {\n      parameters[k] = Math.min(\n        Math.max(minValues[k], parameters[k]),\n        maxValues[k],\n      );\n    }\n\n    error = errorCalculation(data, parameters, parameterizedFunction);\n    if (isNaN(error)) break;\n    converged = error <= errorTolerance;\n  }\n\n  return {\n    parameterValues: parameters,\n    parameterError: error,\n    iterations: iteration,\n  };\n}\n","\"use strict\";\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\n    result[\"default\"] = mod;\n    return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar utils = __importStar(require(\"./utils\"));\nfunction makeHeap(nPoints, size) {\n    var makeArrays = function (fillValue) {\n        return utils.empty(nPoints).map(function () {\n            return utils.filled(size, fillValue);\n        });\n    };\n    var heap = [];\n    heap.push(makeArrays(-1));\n    heap.push(makeArrays(Infinity));\n    heap.push(makeArrays(0));\n    return heap;\n}\nexports.makeHeap = makeHeap;\nfunction rejectionSample(nSamples, poolSize, random) {\n    var result = utils.zeros(nSamples);\n    for (var i = 0; i < nSamples; i++) {\n        var rejectSample = true;\n        var j = 0;\n        while (rejectSample) {\n            j = utils.tauRandInt(poolSize, random);\n            var broken = false;\n            for (var k = 0; k < i; k++) {\n                if (j === result[k]) {\n                    broken = true;\n                    break;\n                }\n            }\n            if (!broken)\n                rejectSample = false;\n        }\n        result[i] = j;\n    }\n    return result;\n}\nexports.rejectionSample = rejectionSample;\nfunction heapPush(heap, row, weight, index, flag) {\n    row = Math.floor(row);\n    var indices = heap[0][row];\n    var weights = heap[1][row];\n    var isNew = heap[2][row];\n    if (weight >= weights[0]) {\n        return 0;\n    }\n    for (var i = 0; i < indices.length; i++) {\n        if (index === indices[i]) {\n            return 0;\n        }\n    }\n    return uncheckedHeapPush(heap, row, weight, index, flag);\n}\nexports.heapPush = heapPush;\nfunction uncheckedHeapPush(heap, row, weight, index, flag) {\n    var indices = heap[0][row];\n    var weights = heap[1][row];\n    var isNew = heap[2][row];\n    if (weight >= weights[0]) {\n        return 0;\n    }\n    weights[0] = weight;\n    indices[0] = index;\n    isNew[0] = flag;\n    var i = 0;\n    var iSwap = 0;\n    while (true) {\n        var ic1 = 2 * i + 1;\n        var ic2 = ic1 + 1;\n        var heapShape2 = heap[0][0].length;\n        if (ic1 >= heapShape2) {\n            break;\n        }\n        else if (ic2 >= heapShape2) {\n            if (weights[ic1] > weight) {\n                iSwap = ic1;\n            }\n            else {\n                break;\n            }\n        }\n        else if (weights[ic1] >= weights[ic2]) {\n            if (weight < weights[ic1]) {\n                iSwap = ic1;\n            }\n            else {\n                break;\n            }\n        }\n        else {\n            if (weight < weights[ic2]) {\n                iSwap = ic2;\n            }\n            else {\n                break;\n            }\n        }\n        weights[i] = weights[iSwap];\n        indices[i] = indices[iSwap];\n        isNew[i] = isNew[iSwap];\n        i = iSwap;\n    }\n    weights[i] = weight;\n    indices[i] = index;\n    isNew[i] = flag;\n    return 1;\n}\nexports.uncheckedHeapPush = uncheckedHeapPush;\nfunction buildCandidates(currentGraph, nVertices, nNeighbors, maxCandidates, random) {\n    var candidateNeighbors = makeHeap(nVertices, maxCandidates);\n    for (var i = 0; i < nVertices; i++) {\n        for (var j = 0; j < nNeighbors; j++) {\n            if (currentGraph[0][i][j] < 0) {\n                continue;\n            }\n            var idx = currentGraph[0][i][j];\n            var isn = currentGraph[2][i][j];\n            var d = utils.tauRand(random);\n            heapPush(candidateNeighbors, i, d, idx, isn);\n            heapPush(candidateNeighbors, idx, d, i, isn);\n            currentGraph[2][i][j] = 0;\n        }\n    }\n    return candidateNeighbors;\n}\nexports.buildCandidates = buildCandidates;\nfunction deheapSort(heap) {\n    var indices = heap[0];\n    var weights = heap[1];\n    for (var i = 0; i < indices.length; i++) {\n        var indHeap = indices[i];\n        var distHeap = weights[i];\n        for (var j = 0; j < indHeap.length - 1; j++) {\n            var indHeapIndex = indHeap.length - j - 1;\n            var distHeapIndex = distHeap.length - j - 1;\n            var temp1 = indHeap[0];\n            indHeap[0] = indHeap[indHeapIndex];\n            indHeap[indHeapIndex] = temp1;\n            var temp2 = distHeap[0];\n            distHeap[0] = distHeap[distHeapIndex];\n            distHeap[distHeapIndex] = temp2;\n            siftDown(distHeap, indHeap, distHeapIndex, 0);\n        }\n    }\n    return { indices: indices, weights: weights };\n}\nexports.deheapSort = deheapSort;\nfunction siftDown(heap1, heap2, ceiling, elt) {\n    while (elt * 2 + 1 < ceiling) {\n        var leftChild = elt * 2 + 1;\n        var rightChild = leftChild + 1;\n        var swap = elt;\n        if (heap1[swap] < heap1[leftChild]) {\n            swap = leftChild;\n        }\n        if (rightChild < ceiling && heap1[swap] < heap1[rightChild]) {\n            swap = rightChild;\n        }\n        if (swap === elt) {\n            break;\n        }\n        else {\n            var temp1 = heap1[elt];\n            heap1[elt] = heap1[swap];\n            heap1[swap] = temp1;\n            var temp2 = heap2[elt];\n            heap2[elt] = heap2[swap];\n            heap2[swap] = temp2;\n            elt = swap;\n        }\n    }\n}\nfunction smallestFlagged(heap, row) {\n    var ind = heap[0][row];\n    var dist = heap[1][row];\n    var flag = heap[2][row];\n    var minDist = Infinity;\n    var resultIndex = -1;\n    for (var i = 0; i > ind.length; i++) {\n        if (flag[i] === 1 && dist[i] < minDist) {\n            minDist = dist[i];\n            resultIndex = i;\n        }\n    }\n    if (resultIndex >= 0) {\n        flag[resultIndex] = 0;\n        return Math.floor(ind[resultIndex]);\n    }\n    else {\n        return -1;\n    }\n}\nexports.smallestFlagged = smallestFlagged;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar umap_1 = require(\"./umap\");\nexports.UMAP = umap_1.UMAP;\n","\"use strict\";\nvar __read = (this && this.__read) || function (o, n) {\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n    if (!m) return o;\n    var i = m.call(o), r, ar = [], e;\n    try {\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n    }\n    catch (error) { e = { error: error }; }\n    finally {\n        try {\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\n        }\n        finally { if (e) throw e.error; }\n    }\n    return ar;\n};\nvar __values = (this && this.__values) || function (o) {\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\n    if (m) return m.call(o);\n    return {\n        next: function () {\n            if (o && i >= o.length) o = void 0;\n            return { value: o && o[i++], done: !o };\n        }\n    };\n};\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\n    result[\"default\"] = mod;\n    return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar _a;\nvar utils = __importStar(require(\"./utils\"));\nvar SparseMatrix = (function () {\n    function SparseMatrix(rows, cols, values, dims) {\n        this.entries = new Map();\n        this.nRows = 0;\n        this.nCols = 0;\n        if (rows.length !== cols.length || rows.length !== values.length) {\n            throw new Error('rows, cols and values arrays must all have the same length');\n        }\n        this.nRows = dims[0];\n        this.nCols = dims[1];\n        for (var i = 0; i < values.length; i++) {\n            var row = rows[i];\n            var col = cols[i];\n            this.checkDims(row, col);\n            var key = this.makeKey(row, col);\n            this.entries.set(key, { value: values[i], row: row, col: col });\n        }\n    }\n    SparseMatrix.prototype.makeKey = function (row, col) {\n        return row + \":\" + col;\n    };\n    SparseMatrix.prototype.checkDims = function (row, col) {\n        var withinBounds = row < this.nRows && col < this.nCols;\n        if (!withinBounds) {\n            throw new Error('row and/or col specified outside of matrix dimensions');\n        }\n    };\n    SparseMatrix.prototype.set = function (row, col, value) {\n        this.checkDims(row, col);\n        var key = this.makeKey(row, col);\n        if (!this.entries.has(key)) {\n            this.entries.set(key, { value: value, row: row, col: col });\n        }\n        else {\n            this.entries.get(key).value = value;\n        }\n    };\n    SparseMatrix.prototype.get = function (row, col, defaultValue) {\n        if (defaultValue === void 0) { defaultValue = 0; }\n        this.checkDims(row, col);\n        var key = this.makeKey(row, col);\n        if (this.entries.has(key)) {\n            return this.entries.get(key).value;\n        }\n        else {\n            return defaultValue;\n        }\n    };\n    SparseMatrix.prototype.getAll = function (ordered) {\n        if (ordered === void 0) { ordered = true; }\n        var rowColValues = [];\n        this.entries.forEach(function (value) {\n            rowColValues.push(value);\n        });\n        if (ordered) {\n            rowColValues.sort(function (a, b) {\n                if (a.row === b.row) {\n                    return a.col - b.col;\n                }\n                else {\n                    return a.row - b.row;\n                }\n            });\n        }\n        return rowColValues;\n    };\n    SparseMatrix.prototype.getDims = function () {\n        return [this.nRows, this.nCols];\n    };\n    SparseMatrix.prototype.getRows = function () {\n        return Array.from(this.entries, function (_a) {\n            var _b = __read(_a, 2), key = _b[0], value = _b[1];\n            return value.row;\n        });\n    };\n    SparseMatrix.prototype.getCols = function () {\n        return Array.from(this.entries, function (_a) {\n            var _b = __read(_a, 2), key = _b[0], value = _b[1];\n            return value.col;\n        });\n    };\n    SparseMatrix.prototype.getValues = function () {\n        return Array.from(this.entries, function (_a) {\n            var _b = __read(_a, 2), key = _b[0], value = _b[1];\n            return value.value;\n        });\n    };\n    SparseMatrix.prototype.forEach = function (fn) {\n        this.entries.forEach(function (value) { return fn(value.value, value.row, value.col); });\n    };\n    SparseMatrix.prototype.map = function (fn) {\n        var vals = [];\n        this.entries.forEach(function (value) {\n            vals.push(fn(value.value, value.row, value.col));\n        });\n        var dims = [this.nRows, this.nCols];\n        return new SparseMatrix(this.getRows(), this.getCols(), vals, dims);\n    };\n    SparseMatrix.prototype.toArray = function () {\n        var _this = this;\n        var rows = utils.empty(this.nRows);\n        var output = rows.map(function () {\n            return utils.zeros(_this.nCols);\n        });\n        this.entries.forEach(function (value) {\n            output[value.row][value.col] = value.value;\n        });\n        return output;\n    };\n    return SparseMatrix;\n}());\nexports.SparseMatrix = SparseMatrix;\nfunction transpose(matrix) {\n    var cols = [];\n    var rows = [];\n    var vals = [];\n    matrix.forEach(function (value, row, col) {\n        cols.push(row);\n        rows.push(col);\n        vals.push(value);\n    });\n    var dims = [matrix.nCols, matrix.nRows];\n    return new SparseMatrix(rows, cols, vals, dims);\n}\nexports.transpose = transpose;\nfunction identity(size) {\n    var _a = __read(size, 1), rows = _a[0];\n    var matrix = new SparseMatrix([], [], [], size);\n    for (var i = 0; i < rows; i++) {\n        matrix.set(i, i, 1);\n    }\n    return matrix;\n}\nexports.identity = identity;\nfunction pairwiseMultiply(a, b) {\n    return elementWise(a, b, function (x, y) { return x * y; });\n}\nexports.pairwiseMultiply = pairwiseMultiply;\nfunction add(a, b) {\n    return elementWise(a, b, function (x, y) { return x + y; });\n}\nexports.add = add;\nfunction subtract(a, b) {\n    return elementWise(a, b, function (x, y) { return x - y; });\n}\nexports.subtract = subtract;\nfunction maximum(a, b) {\n    return elementWise(a, b, function (x, y) { return (x > y ? x : y); });\n}\nexports.maximum = maximum;\nfunction multiplyScalar(a, scalar) {\n    return a.map(function (value) {\n        return value * scalar;\n    });\n}\nexports.multiplyScalar = multiplyScalar;\nfunction eliminateZeros(m) {\n    var zeroIndices = new Set();\n    var values = m.getValues();\n    var rows = m.getRows();\n    var cols = m.getCols();\n    for (var i = 0; i < values.length; i++) {\n        if (values[i] === 0) {\n            zeroIndices.add(i);\n        }\n    }\n    var removeByZeroIndex = function (_, index) { return !zeroIndices.has(index); };\n    var nextValues = values.filter(removeByZeroIndex);\n    var nextRows = rows.filter(removeByZeroIndex);\n    var nextCols = cols.filter(removeByZeroIndex);\n    return new SparseMatrix(nextRows, nextCols, nextValues, m.getDims());\n}\nexports.eliminateZeros = eliminateZeros;\nfunction normalize(m, normType) {\n    if (normType === void 0) { normType = \"l2\"; }\n    var e_1, _a;\n    var normFn = normFns[normType];\n    var colsByRow = new Map();\n    m.forEach(function (_, row, col) {\n        var cols = colsByRow.get(row) || [];\n        cols.push(col);\n        colsByRow.set(row, cols);\n    });\n    var nextMatrix = new SparseMatrix([], [], [], m.getDims());\n    var _loop_1 = function (row) {\n        var cols = colsByRow.get(row).sort();\n        var vals = cols.map(function (col) { return m.get(row, col); });\n        var norm = normFn(vals);\n        for (var i = 0; i < norm.length; i++) {\n            nextMatrix.set(row, cols[i], norm[i]);\n        }\n    };\n    try {\n        for (var _b = __values(colsByRow.keys()), _c = _b.next(); !_c.done; _c = _b.next()) {\n            var row = _c.value;\n            _loop_1(row);\n        }\n    }\n    catch (e_1_1) { e_1 = { error: e_1_1 }; }\n    finally {\n        try {\n            if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n        }\n        finally { if (e_1) throw e_1.error; }\n    }\n    return nextMatrix;\n}\nexports.normalize = normalize;\nvar normFns = (_a = {},\n    _a[\"max\"] = function (xs) {\n        var max = -Infinity;\n        for (var i = 0; i < xs.length; i++) {\n            max = xs[i] > max ? xs[i] : max;\n        }\n        return xs.map(function (x) { return x / max; });\n    },\n    _a[\"l1\"] = function (xs) {\n        var sum = 0;\n        for (var i = 0; i < xs.length; i++) {\n            sum += xs[i];\n        }\n        return xs.map(function (x) { return x / sum; });\n    },\n    _a[\"l2\"] = function (xs) {\n        var sum = 0;\n        for (var i = 0; i < xs.length; i++) {\n            sum += Math.pow(xs[i], 2);\n        }\n        return xs.map(function (x) { return Math.sqrt(Math.pow(x, 2) / sum); });\n    },\n    _a);\nfunction elementWise(a, b, op) {\n    var visited = new Set();\n    var rows = [];\n    var cols = [];\n    var vals = [];\n    var operate = function (row, col) {\n        rows.push(row);\n        cols.push(col);\n        var nextValue = op(a.get(row, col), b.get(row, col));\n        vals.push(nextValue);\n    };\n    var valuesA = a.getValues();\n    var rowsA = a.getRows();\n    var colsA = a.getCols();\n    for (var i = 0; i < valuesA.length; i++) {\n        var row = rowsA[i];\n        var col = colsA[i];\n        var key = row + \":\" + col;\n        visited.add(key);\n        operate(row, col);\n    }\n    var valuesB = b.getValues();\n    var rowsB = b.getRows();\n    var colsB = b.getCols();\n    for (var i = 0; i < valuesB.length; i++) {\n        var row = rowsB[i];\n        var col = colsB[i];\n        var key = row + \":\" + col;\n        if (visited.has(key))\n            continue;\n        operate(row, col);\n    }\n    var dims = [a.nRows, a.nCols];\n    return new SparseMatrix(rows, cols, vals, dims);\n}\nfunction getCSR(x) {\n    var entries = [];\n    x.forEach(function (value, row, col) {\n        entries.push({ value: value, row: row, col: col });\n    });\n    entries.sort(function (a, b) {\n        if (a.row === b.row) {\n            return a.col - b.col;\n        }\n        else {\n            return a.row - b.row;\n        }\n    });\n    var indices = [];\n    var values = [];\n    var indptr = [];\n    var currentRow = -1;\n    for (var i = 0; i < entries.length; i++) {\n        var _a = entries[i], row = _a.row, col = _a.col, value = _a.value;\n        if (row !== currentRow) {\n            currentRow = row;\n            indptr.push(i);\n        }\n        indices.push(col);\n        values.push(value);\n    }\n    return { indices: indices, values: values, indptr: indptr };\n}\nexports.getCSR = getCSR;\n","\"use strict\";\nvar __values = (this && this.__values) || function (o) {\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\n    if (m) return m.call(o);\n    return {\n        next: function () {\n            if (o && i >= o.length) o = void 0;\n            return { value: o && o[i++], done: !o };\n        }\n    };\n};\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\n    result[\"default\"] = mod;\n    return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar heap = __importStar(require(\"./heap\"));\nvar matrix = __importStar(require(\"./matrix\"));\nvar tree = __importStar(require(\"./tree\"));\nvar utils = __importStar(require(\"./utils\"));\nfunction makeNNDescent(distanceFn, random) {\n    return function nNDescent(data, leafArray, nNeighbors, nIters, maxCandidates, delta, rho, rpTreeInit) {\n        if (nIters === void 0) { nIters = 10; }\n        if (maxCandidates === void 0) { maxCandidates = 50; }\n        if (delta === void 0) { delta = 0.001; }\n        if (rho === void 0) { rho = 0.5; }\n        if (rpTreeInit === void 0) { rpTreeInit = true; }\n        var nVertices = data.length;\n        var currentGraph = heap.makeHeap(data.length, nNeighbors);\n        for (var i = 0; i < data.length; i++) {\n            var indices = heap.rejectionSample(nNeighbors, data.length, random);\n            for (var j = 0; j < indices.length; j++) {\n                var d = distanceFn(data[i], data[indices[j]]);\n                heap.heapPush(currentGraph, i, d, indices[j], 1);\n                heap.heapPush(currentGraph, indices[j], d, i, 1);\n            }\n        }\n        if (rpTreeInit) {\n            for (var n = 0; n < leafArray.length; n++) {\n                for (var i = 0; i < leafArray[n].length; i++) {\n                    if (leafArray[n][i] < 0) {\n                        break;\n                    }\n                    for (var j = i + 1; j < leafArray[n].length; j++) {\n                        if (leafArray[n][j] < 0) {\n                            break;\n                        }\n                        var d = distanceFn(data[leafArray[n][i]], data[leafArray[n][j]]);\n                        heap.heapPush(currentGraph, leafArray[n][i], d, leafArray[n][j], 1);\n                        heap.heapPush(currentGraph, leafArray[n][j], d, leafArray[n][i], 1);\n                    }\n                }\n            }\n        }\n        for (var n = 0; n < nIters; n++) {\n            var candidateNeighbors = heap.buildCandidates(currentGraph, nVertices, nNeighbors, maxCandidates, random);\n            var c = 0;\n            for (var i = 0; i < nVertices; i++) {\n                for (var j = 0; j < maxCandidates; j++) {\n                    var p = Math.floor(candidateNeighbors[0][i][j]);\n                    if (p < 0 || utils.tauRand(random) < rho) {\n                        continue;\n                    }\n                    for (var k = 0; k < maxCandidates; k++) {\n                        var q = Math.floor(candidateNeighbors[0][i][k]);\n                        var cj = candidateNeighbors[2][i][j];\n                        var ck = candidateNeighbors[2][i][k];\n                        if (q < 0 || (!cj && !ck)) {\n                            continue;\n                        }\n                        var d = distanceFn(data[p], data[q]);\n                        c += heap.heapPush(currentGraph, p, d, q, 1);\n                        c += heap.heapPush(currentGraph, q, d, p, 1);\n                    }\n                }\n            }\n            if (c <= delta * nNeighbors * data.length) {\n                break;\n            }\n        }\n        var sorted = heap.deheapSort(currentGraph);\n        return sorted;\n    };\n}\nexports.makeNNDescent = makeNNDescent;\nfunction makeInitializations(distanceFn) {\n    function initFromRandom(nNeighbors, data, queryPoints, _heap, random) {\n        for (var i = 0; i < queryPoints.length; i++) {\n            var indices = utils.rejectionSample(nNeighbors, data.length, random);\n            for (var j = 0; j < indices.length; j++) {\n                if (indices[j] < 0) {\n                    continue;\n                }\n                var d = distanceFn(data[indices[j]], queryPoints[i]);\n                heap.heapPush(_heap, i, d, indices[j], 1);\n            }\n        }\n    }\n    function initFromTree(_tree, data, queryPoints, _heap, random) {\n        for (var i = 0; i < queryPoints.length; i++) {\n            var indices = tree.searchFlatTree(queryPoints[i], _tree, random);\n            for (var j = 0; j < indices.length; j++) {\n                if (indices[j] < 0) {\n                    return;\n                }\n                var d = distanceFn(data[indices[j]], queryPoints[i]);\n                heap.heapPush(_heap, i, d, indices[j], 1);\n            }\n        }\n        return;\n    }\n    return { initFromRandom: initFromRandom, initFromTree: initFromTree };\n}\nexports.makeInitializations = makeInitializations;\nfunction makeInitializedNNSearch(distanceFn) {\n    return function nnSearchFn(data, graph, initialization, queryPoints) {\n        var e_1, _a;\n        var _b = matrix.getCSR(graph), indices = _b.indices, indptr = _b.indptr;\n        for (var i = 0; i < queryPoints.length; i++) {\n            var tried = new Set(initialization[0][i]);\n            while (true) {\n                var vertex = heap.smallestFlagged(initialization, i);\n                if (vertex === -1) {\n                    break;\n                }\n                var candidates = indices.slice(indptr[vertex], indptr[vertex + 1]);\n                try {\n                    for (var candidates_1 = __values(candidates), candidates_1_1 = candidates_1.next(); !candidates_1_1.done; candidates_1_1 = candidates_1.next()) {\n                        var candidate = candidates_1_1.value;\n                        if (candidate === vertex ||\n                            candidate === -1 ||\n                            tried.has(candidate)) {\n                            continue;\n                        }\n                        var d = distanceFn(data[candidate], queryPoints[i]);\n                        heap.uncheckedHeapPush(initialization, i, d, candidate, 1);\n                        tried.add(candidate);\n                    }\n                }\n                catch (e_1_1) { e_1 = { error: e_1_1 }; }\n                finally {\n                    try {\n                        if (candidates_1_1 && !candidates_1_1.done && (_a = candidates_1.return)) _a.call(candidates_1);\n                    }\n                    finally { if (e_1) throw e_1.error; }\n                }\n            }\n        }\n        return initialization;\n    };\n}\nexports.makeInitializedNNSearch = makeInitializedNNSearch;\nfunction initializeSearch(forest, data, queryPoints, nNeighbors, initFromRandom, initFromTree, random) {\n    var e_2, _a;\n    var results = heap.makeHeap(queryPoints.length, nNeighbors);\n    initFromRandom(nNeighbors, data, queryPoints, results, random);\n    if (forest) {\n        try {\n            for (var forest_1 = __values(forest), forest_1_1 = forest_1.next(); !forest_1_1.done; forest_1_1 = forest_1.next()) {\n                var tree_1 = forest_1_1.value;\n                initFromTree(tree_1, data, queryPoints, results, random);\n            }\n        }\n        catch (e_2_1) { e_2 = { error: e_2_1 }; }\n        finally {\n            try {\n                if (forest_1_1 && !forest_1_1.done && (_a = forest_1.return)) _a.call(forest_1);\n            }\n            finally { if (e_2) throw e_2.error; }\n        }\n    }\n    return results;\n}\nexports.initializeSearch = initializeSearch;\n","\"use strict\";\nvar __read = (this && this.__read) || function (o, n) {\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n    if (!m) return o;\n    var i = m.call(o), r, ar = [], e;\n    try {\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n    }\n    catch (error) { e = { error: error }; }\n    finally {\n        try {\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\n        }\n        finally { if (e) throw e.error; }\n    }\n    return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n    for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n    return ar;\n};\nvar __values = (this && this.__values) || function (o) {\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\n    if (m) return m.call(o);\n    return {\n        next: function () {\n            if (o && i >= o.length) o = void 0;\n            return { value: o && o[i++], done: !o };\n        }\n    };\n};\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\n    result[\"default\"] = mod;\n    return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar utils = __importStar(require(\"./utils\"));\nvar FlatTree = (function () {\n    function FlatTree(hyperplanes, offsets, children, indices) {\n        this.hyperplanes = hyperplanes;\n        this.offsets = offsets;\n        this.children = children;\n        this.indices = indices;\n    }\n    return FlatTree;\n}());\nexports.FlatTree = FlatTree;\nfunction makeForest(data, nNeighbors, nTrees, random) {\n    var leafSize = Math.max(10, nNeighbors);\n    var trees = utils\n        .range(nTrees)\n        .map(function (_, i) { return makeTree(data, leafSize, i, random); });\n    var forest = trees.map(function (tree) { return flattenTree(tree, leafSize); });\n    return forest;\n}\nexports.makeForest = makeForest;\nfunction makeTree(data, leafSize, n, random) {\n    if (leafSize === void 0) { leafSize = 30; }\n    var indices = utils.range(data.length);\n    var tree = makeEuclideanTree(data, indices, leafSize, n, random);\n    return tree;\n}\nfunction makeEuclideanTree(data, indices, leafSize, q, random) {\n    if (leafSize === void 0) { leafSize = 30; }\n    if (indices.length > leafSize) {\n        var splitResults = euclideanRandomProjectionSplit(data, indices, random);\n        var indicesLeft = splitResults.indicesLeft, indicesRight = splitResults.indicesRight, hyperplane = splitResults.hyperplane, offset = splitResults.offset;\n        var leftChild = makeEuclideanTree(data, indicesLeft, leafSize, q + 1, random);\n        var rightChild = makeEuclideanTree(data, indicesRight, leafSize, q + 1, random);\n        var node = { leftChild: leftChild, rightChild: rightChild, isLeaf: false, hyperplane: hyperplane, offset: offset };\n        return node;\n    }\n    else {\n        var node = { indices: indices, isLeaf: true };\n        return node;\n    }\n}\nfunction euclideanRandomProjectionSplit(data, indices, random) {\n    var dim = data[0].length;\n    var leftIndex = utils.tauRandInt(indices.length, random);\n    var rightIndex = utils.tauRandInt(indices.length, random);\n    rightIndex += leftIndex === rightIndex ? 1 : 0;\n    rightIndex = rightIndex % indices.length;\n    var left = indices[leftIndex];\n    var right = indices[rightIndex];\n    var hyperplaneOffset = 0;\n    var hyperplaneVector = utils.zeros(dim);\n    for (var i = 0; i < hyperplaneVector.length; i++) {\n        hyperplaneVector[i] = data[left][i] - data[right][i];\n        hyperplaneOffset -=\n            (hyperplaneVector[i] * (data[left][i] + data[right][i])) / 2.0;\n    }\n    var nLeft = 0;\n    var nRight = 0;\n    var side = utils.zeros(indices.length);\n    for (var i = 0; i < indices.length; i++) {\n        var margin = hyperplaneOffset;\n        for (var d = 0; d < dim; d++) {\n            margin += hyperplaneVector[d] * data[indices[i]][d];\n        }\n        if (margin === 0) {\n            side[i] = utils.tauRandInt(2, random);\n            if (side[i] === 0) {\n                nLeft += 1;\n            }\n            else {\n                nRight += 1;\n            }\n        }\n        else if (margin > 0) {\n            side[i] = 0;\n            nLeft += 1;\n        }\n        else {\n            side[i] = 1;\n            nRight += 1;\n        }\n    }\n    var indicesLeft = utils.zeros(nLeft);\n    var indicesRight = utils.zeros(nRight);\n    nLeft = 0;\n    nRight = 0;\n    for (var i = 0; i < side.length; i++) {\n        if (side[i] === 0) {\n            indicesLeft[nLeft] = indices[i];\n            nLeft += 1;\n        }\n        else {\n            indicesRight[nRight] = indices[i];\n            nRight += 1;\n        }\n    }\n    return {\n        indicesLeft: indicesLeft,\n        indicesRight: indicesRight,\n        hyperplane: hyperplaneVector,\n        offset: hyperplaneOffset,\n    };\n}\nfunction flattenTree(tree, leafSize) {\n    var nNodes = numNodes(tree);\n    var nLeaves = numLeaves(tree);\n    var hyperplanes = utils\n        .range(nNodes)\n        .map(function () { return utils.zeros(tree.hyperplane ? tree.hyperplane.length : 0); });\n    var offsets = utils.zeros(nNodes);\n    var children = utils.range(nNodes).map(function () { return [-1, -1]; });\n    var indices = utils\n        .range(nLeaves)\n        .map(function () { return utils.range(leafSize).map(function () { return -1; }); });\n    recursiveFlatten(tree, hyperplanes, offsets, children, indices, 0, 0);\n    return new FlatTree(hyperplanes, offsets, children, indices);\n}\nfunction recursiveFlatten(tree, hyperplanes, offsets, children, indices, nodeNum, leafNum) {\n    var _a;\n    if (tree.isLeaf) {\n        children[nodeNum][0] = -leafNum;\n        (_a = indices[leafNum]).splice.apply(_a, __spread([0, tree.indices.length], tree.indices));\n        leafNum += 1;\n        return { nodeNum: nodeNum, leafNum: leafNum };\n    }\n    else {\n        hyperplanes[nodeNum] = tree.hyperplane;\n        offsets[nodeNum] = tree.offset;\n        children[nodeNum][0] = nodeNum + 1;\n        var oldNodeNum = nodeNum;\n        var res = recursiveFlatten(tree.leftChild, hyperplanes, offsets, children, indices, nodeNum + 1, leafNum);\n        nodeNum = res.nodeNum;\n        leafNum = res.leafNum;\n        children[oldNodeNum][1] = nodeNum + 1;\n        res = recursiveFlatten(tree.rightChild, hyperplanes, offsets, children, indices, nodeNum + 1, leafNum);\n        return { nodeNum: res.nodeNum, leafNum: res.leafNum };\n    }\n}\nfunction numNodes(tree) {\n    if (tree.isLeaf) {\n        return 1;\n    }\n    else {\n        return 1 + numNodes(tree.leftChild) + numNodes(tree.rightChild);\n    }\n}\nfunction numLeaves(tree) {\n    if (tree.isLeaf) {\n        return 1;\n    }\n    else {\n        return numLeaves(tree.leftChild) + numLeaves(tree.rightChild);\n    }\n}\nfunction makeLeafArray(rpForest) {\n    var e_1, _a;\n    if (rpForest.length > 0) {\n        var output = [];\n        try {\n            for (var rpForest_1 = __values(rpForest), rpForest_1_1 = rpForest_1.next(); !rpForest_1_1.done; rpForest_1_1 = rpForest_1.next()) {\n                var tree = rpForest_1_1.value;\n                output.push.apply(output, __spread(tree.indices));\n            }\n        }\n        catch (e_1_1) { e_1 = { error: e_1_1 }; }\n        finally {\n            try {\n                if (rpForest_1_1 && !rpForest_1_1.done && (_a = rpForest_1.return)) _a.call(rpForest_1);\n            }\n            finally { if (e_1) throw e_1.error; }\n        }\n        return output;\n    }\n    else {\n        return [[-1]];\n    }\n}\nexports.makeLeafArray = makeLeafArray;\nfunction selectSide(hyperplane, offset, point, random) {\n    var margin = offset;\n    for (var d = 0; d < point.length; d++) {\n        margin += hyperplane[d] * point[d];\n    }\n    if (margin === 0) {\n        var side = utils.tauRandInt(2, random);\n        return side;\n    }\n    else if (margin > 0) {\n        return 0;\n    }\n    else {\n        return 1;\n    }\n}\nfunction searchFlatTree(point, tree, random) {\n    var node = 0;\n    while (tree.children[node][0] > 0) {\n        var side = selectSide(tree.hyperplanes[node], tree.offsets[node], point, random);\n        if (side === 0) {\n            node = tree.children[node][0];\n        }\n        else {\n            node = tree.children[node][1];\n        }\n    }\n    var index = -1 * tree.children[node][0];\n    return tree.indices[index];\n}\nexports.searchFlatTree = searchFlatTree;\n","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n    function verb(n) { return function (v) { return step([n, v]); }; }\n    function step(op) {\n        if (f) throw new TypeError(\"Generator is already executing.\");\n        while (_) try {\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n            if (y = 0, t) op = [op[0] & 2, t.value];\n            switch (op[0]) {\n                case 0: case 1: t = op; break;\n                case 4: _.label++; return { value: op[1], done: false };\n                case 5: _.label++; y = op[1]; op = [0]; continue;\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\n                default:\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n                    if (t[2]) _.ops.pop();\n                    _.trys.pop(); continue;\n            }\n            op = body.call(thisArg, _);\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n    }\n};\nvar __read = (this && this.__read) || function (o, n) {\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n    if (!m) return o;\n    var i = m.call(o), r, ar = [], e;\n    try {\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n    }\n    catch (error) { e = { error: error }; }\n    finally {\n        try {\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\n        }\n        finally { if (e) throw e.error; }\n    }\n    return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n    for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n    return ar;\n};\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\n    result[\"default\"] = mod;\n    return result;\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n    return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar heap = __importStar(require(\"./heap\"));\nvar matrix = __importStar(require(\"./matrix\"));\nvar nnDescent = __importStar(require(\"./nn_descent\"));\nvar tree = __importStar(require(\"./tree\"));\nvar utils = __importStar(require(\"./utils\"));\nvar ml_levenberg_marquardt_1 = __importDefault(require(\"ml-levenberg-marquardt\"));\nvar SMOOTH_K_TOLERANCE = 1e-5;\nvar MIN_K_DIST_SCALE = 1e-3;\nvar UMAP = (function () {\n    function UMAP(params) {\n        if (params === void 0) { params = {}; }\n        var _this = this;\n        this.learningRate = 1.0;\n        this.localConnectivity = 1.0;\n        this.minDist = 0.1;\n        this.nComponents = 2;\n        this.nEpochs = 0;\n        this.nNeighbors = 15;\n        this.negativeSampleRate = 5;\n        this.random = Math.random;\n        this.repulsionStrength = 1.0;\n        this.setOpMixRatio = 1.0;\n        this.spread = 1.0;\n        this.transformQueueSize = 4.0;\n        this.targetMetric = \"categorical\";\n        this.targetWeight = 0.5;\n        this.targetNNeighbors = this.nNeighbors;\n        this.distanceFn = euclidean;\n        this.isInitialized = false;\n        this.rpForest = [];\n        this.embedding = [];\n        this.optimizationState = new OptimizationState();\n        var setParam = function (key) {\n            if (params[key] !== undefined)\n                _this[key] = params[key];\n        };\n        setParam('distanceFn');\n        setParam('learningRate');\n        setParam('localConnectivity');\n        setParam('minDist');\n        setParam('nComponents');\n        setParam('nEpochs');\n        setParam('nNeighbors');\n        setParam('negativeSampleRate');\n        setParam('random');\n        setParam('repulsionStrength');\n        setParam('setOpMixRatio');\n        setParam('spread');\n        setParam('transformQueueSize');\n    }\n    UMAP.prototype.fit = function (X) {\n        this.initializeFit(X);\n        this.optimizeLayout();\n        return this.embedding;\n    };\n    UMAP.prototype.fitAsync = function (X, callback) {\n        if (callback === void 0) { callback = function () { return true; }; }\n        return __awaiter(this, void 0, void 0, function () {\n            return __generator(this, function (_a) {\n                switch (_a.label) {\n                    case 0:\n                        this.initializeFit(X);\n                        return [4, this.optimizeLayoutAsync(callback)];\n                    case 1:\n                        _a.sent();\n                        return [2, this.embedding];\n                }\n            });\n        });\n    };\n    UMAP.prototype.setSupervisedProjection = function (Y, params) {\n        if (params === void 0) { params = {}; }\n        this.Y = Y;\n        this.targetMetric = params.targetMetric || this.targetMetric;\n        this.targetWeight = params.targetWeight || this.targetWeight;\n        this.targetNNeighbors = params.targetNNeighbors || this.targetNNeighbors;\n    };\n    UMAP.prototype.setPrecomputedKNN = function (knnIndices, knnDistances) {\n        this.knnIndices = knnIndices;\n        this.knnDistances = knnDistances;\n    };\n    UMAP.prototype.initializeFit = function (X) {\n        if (X.length <= this.nNeighbors) {\n            throw new Error(\"Not enough data points (\" + X.length + \") to create nNeighbors: \" + this.nNeighbors + \".  Add more data points or adjust the configuration.\");\n        }\n        if (this.X === X && this.isInitialized) {\n            return this.getNEpochs();\n        }\n        this.X = X;\n        if (!this.knnIndices && !this.knnDistances) {\n            var knnResults = this.nearestNeighbors(X);\n            this.knnIndices = knnResults.knnIndices;\n            this.knnDistances = knnResults.knnDistances;\n        }\n        this.graph = this.fuzzySimplicialSet(X, this.nNeighbors, this.setOpMixRatio);\n        this.makeSearchFns();\n        this.searchGraph = this.makeSearchGraph(X);\n        this.processGraphForSupervisedProjection();\n        var _a = this.initializeSimplicialSetEmbedding(), head = _a.head, tail = _a.tail, epochsPerSample = _a.epochsPerSample;\n        this.optimizationState.head = head;\n        this.optimizationState.tail = tail;\n        this.optimizationState.epochsPerSample = epochsPerSample;\n        this.initializeOptimization();\n        this.prepareForOptimizationLoop();\n        this.isInitialized = true;\n        return this.getNEpochs();\n    };\n    UMAP.prototype.makeSearchFns = function () {\n        var _a = nnDescent.makeInitializations(this.distanceFn), initFromTree = _a.initFromTree, initFromRandom = _a.initFromRandom;\n        this.initFromTree = initFromTree;\n        this.initFromRandom = initFromRandom;\n        this.search = nnDescent.makeInitializedNNSearch(this.distanceFn);\n    };\n    UMAP.prototype.makeSearchGraph = function (X) {\n        var knnIndices = this.knnIndices;\n        var knnDistances = this.knnDistances;\n        var dims = [X.length, X.length];\n        var searchGraph = new matrix.SparseMatrix([], [], [], dims);\n        for (var i = 0; i < knnIndices.length; i++) {\n            var knn = knnIndices[i];\n            var distances = knnDistances[i];\n            for (var j = 0; j < knn.length; j++) {\n                var neighbor = knn[j];\n                var distance = distances[j];\n                if (distance > 0) {\n                    searchGraph.set(i, neighbor, distance);\n                }\n            }\n        }\n        var transpose = matrix.transpose(searchGraph);\n        return matrix.maximum(searchGraph, transpose);\n    };\n    UMAP.prototype.transform = function (toTransform) {\n        var _this = this;\n        var rawData = this.X;\n        if (rawData === undefined || rawData.length === 0) {\n            throw new Error('No data has been fit.');\n        }\n        var nNeighbors = Math.floor(this.nNeighbors * this.transformQueueSize);\n        nNeighbors = Math.min(rawData.length, nNeighbors);\n        var init = nnDescent.initializeSearch(this.rpForest, rawData, toTransform, nNeighbors, this.initFromRandom, this.initFromTree, this.random);\n        var result = this.search(rawData, this.searchGraph, init, toTransform);\n        var _a = heap.deheapSort(result), indices = _a.indices, distances = _a.weights;\n        indices = indices.map(function (x) { return x.slice(0, _this.nNeighbors); });\n        distances = distances.map(function (x) { return x.slice(0, _this.nNeighbors); });\n        var adjustedLocalConnectivity = Math.max(0, this.localConnectivity - 1);\n        var _b = this.smoothKNNDistance(distances, this.nNeighbors, adjustedLocalConnectivity), sigmas = _b.sigmas, rhos = _b.rhos;\n        var _c = this.computeMembershipStrengths(indices, distances, sigmas, rhos), rows = _c.rows, cols = _c.cols, vals = _c.vals;\n        var size = [toTransform.length, rawData.length];\n        var graph = new matrix.SparseMatrix(rows, cols, vals, size);\n        var normed = matrix.normalize(graph, \"l1\");\n        var csrMatrix = matrix.getCSR(normed);\n        var nPoints = toTransform.length;\n        var eIndices = utils.reshape2d(csrMatrix.indices, nPoints, this.nNeighbors);\n        var eWeights = utils.reshape2d(csrMatrix.values, nPoints, this.nNeighbors);\n        var embedding = initTransform(eIndices, eWeights, this.embedding);\n        var nEpochs = this.nEpochs\n            ? this.nEpochs / 3\n            : graph.nRows <= 10000\n                ? 100\n                : 30;\n        var graphMax = graph\n            .getValues()\n            .reduce(function (max, val) { return (val > max ? val : max); }, 0);\n        graph = graph.map(function (value) { return (value < graphMax / nEpochs ? 0 : value); });\n        graph = matrix.eliminateZeros(graph);\n        var epochsPerSample = this.makeEpochsPerSample(graph.getValues(), nEpochs);\n        var head = graph.getRows();\n        var tail = graph.getCols();\n        this.assignOptimizationStateParameters({\n            headEmbedding: embedding,\n            tailEmbedding: this.embedding,\n            head: head,\n            tail: tail,\n            currentEpoch: 0,\n            nEpochs: nEpochs,\n            nVertices: graph.getDims()[1],\n            epochsPerSample: epochsPerSample,\n        });\n        this.prepareForOptimizationLoop();\n        return this.optimizeLayout();\n    };\n    UMAP.prototype.processGraphForSupervisedProjection = function () {\n        var _a = this, Y = _a.Y, X = _a.X;\n        if (Y) {\n            if (Y.length !== X.length) {\n                throw new Error('Length of X and y must be equal');\n            }\n            if (this.targetMetric === \"categorical\") {\n                var lt = this.targetWeight < 1.0;\n                var farDist = lt ? 2.5 * (1.0 / (1.0 - this.targetWeight)) : 1.0e12;\n                this.graph = this.categoricalSimplicialSetIntersection(this.graph, Y, farDist);\n            }\n        }\n    };\n    UMAP.prototype.step = function () {\n        var currentEpoch = this.optimizationState.currentEpoch;\n        if (currentEpoch < this.getNEpochs()) {\n            this.optimizeLayoutStep(currentEpoch);\n        }\n        return this.optimizationState.currentEpoch;\n    };\n    UMAP.prototype.getEmbedding = function () {\n        return this.embedding;\n    };\n    UMAP.prototype.nearestNeighbors = function (X) {\n        var _a = this, distanceFn = _a.distanceFn, nNeighbors = _a.nNeighbors;\n        var log2 = function (n) { return Math.log(n) / Math.log(2); };\n        var metricNNDescent = nnDescent.makeNNDescent(distanceFn, this.random);\n        var round = function (n) {\n            return n === 0.5 ? 0 : Math.round(n);\n        };\n        var nTrees = 5 + Math.floor(round(Math.pow(X.length, 0.5) / 20.0));\n        var nIters = Math.max(5, Math.floor(Math.round(log2(X.length))));\n        this.rpForest = tree.makeForest(X, nNeighbors, nTrees, this.random);\n        var leafArray = tree.makeLeafArray(this.rpForest);\n        var _b = metricNNDescent(X, leafArray, nNeighbors, nIters), indices = _b.indices, weights = _b.weights;\n        return { knnIndices: indices, knnDistances: weights };\n    };\n    UMAP.prototype.fuzzySimplicialSet = function (X, nNeighbors, setOpMixRatio) {\n        if (setOpMixRatio === void 0) { setOpMixRatio = 1.0; }\n        var _a = this, _b = _a.knnIndices, knnIndices = _b === void 0 ? [] : _b, _c = _a.knnDistances, knnDistances = _c === void 0 ? [] : _c, localConnectivity = _a.localConnectivity;\n        var _d = this.smoothKNNDistance(knnDistances, nNeighbors, localConnectivity), sigmas = _d.sigmas, rhos = _d.rhos;\n        var _e = this.computeMembershipStrengths(knnIndices, knnDistances, sigmas, rhos), rows = _e.rows, cols = _e.cols, vals = _e.vals;\n        var size = [X.length, X.length];\n        var sparseMatrix = new matrix.SparseMatrix(rows, cols, vals, size);\n        var transpose = matrix.transpose(sparseMatrix);\n        var prodMatrix = matrix.pairwiseMultiply(sparseMatrix, transpose);\n        var a = matrix.subtract(matrix.add(sparseMatrix, transpose), prodMatrix);\n        var b = matrix.multiplyScalar(a, setOpMixRatio);\n        var c = matrix.multiplyScalar(prodMatrix, 1.0 - setOpMixRatio);\n        var result = matrix.add(b, c);\n        return result;\n    };\n    UMAP.prototype.categoricalSimplicialSetIntersection = function (simplicialSet, target, farDist, unknownDist) {\n        if (unknownDist === void 0) { unknownDist = 1.0; }\n        var intersection = fastIntersection(simplicialSet, target, unknownDist, farDist);\n        intersection = matrix.eliminateZeros(intersection);\n        return resetLocalConnectivity(intersection);\n    };\n    UMAP.prototype.smoothKNNDistance = function (distances, k, localConnectivity, nIter, bandwidth) {\n        if (localConnectivity === void 0) { localConnectivity = 1.0; }\n        if (nIter === void 0) { nIter = 64; }\n        if (bandwidth === void 0) { bandwidth = 1.0; }\n        var target = (Math.log(k) / Math.log(2)) * bandwidth;\n        var rho = utils.zeros(distances.length);\n        var result = utils.zeros(distances.length);\n        for (var i = 0; i < distances.length; i++) {\n            var lo = 0.0;\n            var hi = Infinity;\n            var mid = 1.0;\n            var ithDistances = distances[i];\n            var nonZeroDists = ithDistances.filter(function (d) { return d > 0.0; });\n            if (nonZeroDists.length >= localConnectivity) {\n                var index = Math.floor(localConnectivity);\n                var interpolation = localConnectivity - index;\n                if (index > 0) {\n                    rho[i] = nonZeroDists[index - 1];\n                    if (interpolation > SMOOTH_K_TOLERANCE) {\n                        rho[i] +=\n                            interpolation * (nonZeroDists[index] - nonZeroDists[index - 1]);\n                    }\n                }\n                else {\n                    rho[i] = interpolation * nonZeroDists[0];\n                }\n            }\n            else if (nonZeroDists.length > 0) {\n                rho[i] = utils.max(nonZeroDists);\n            }\n            for (var n = 0; n < nIter; n++) {\n                var psum = 0.0;\n                for (var j = 1; j < distances[i].length; j++) {\n                    var d = distances[i][j] - rho[i];\n                    if (d > 0) {\n                        psum += Math.exp(-(d / mid));\n                    }\n                    else {\n                        psum += 1.0;\n                    }\n                }\n                if (Math.abs(psum - target) < SMOOTH_K_TOLERANCE) {\n                    break;\n                }\n                if (psum > target) {\n                    hi = mid;\n                    mid = (lo + hi) / 2.0;\n                }\n                else {\n                    lo = mid;\n                    if (hi === Infinity) {\n                        mid *= 2;\n                    }\n                    else {\n                        mid = (lo + hi) / 2.0;\n                    }\n                }\n            }\n            result[i] = mid;\n            if (rho[i] > 0.0) {\n                var meanIthDistances = utils.mean(ithDistances);\n                if (result[i] < MIN_K_DIST_SCALE * meanIthDistances) {\n                    result[i] = MIN_K_DIST_SCALE * meanIthDistances;\n                }\n            }\n            else {\n                var meanDistances = utils.mean(distances.map(utils.mean));\n                if (result[i] < MIN_K_DIST_SCALE * meanDistances) {\n                    result[i] = MIN_K_DIST_SCALE * meanDistances;\n                }\n            }\n        }\n        return { sigmas: result, rhos: rho };\n    };\n    UMAP.prototype.computeMembershipStrengths = function (knnIndices, knnDistances, sigmas, rhos) {\n        var nSamples = knnIndices.length;\n        var nNeighbors = knnIndices[0].length;\n        var rows = utils.zeros(nSamples * nNeighbors);\n        var cols = utils.zeros(nSamples * nNeighbors);\n        var vals = utils.zeros(nSamples * nNeighbors);\n        for (var i = 0; i < nSamples; i++) {\n            for (var j = 0; j < nNeighbors; j++) {\n                var val = 0;\n                if (knnIndices[i][j] === -1) {\n                    continue;\n                }\n                if (knnIndices[i][j] === i) {\n                    val = 0.0;\n                }\n                else if (knnDistances[i][j] - rhos[i] <= 0.0) {\n                    val = 1.0;\n                }\n                else {\n                    val = Math.exp(-((knnDistances[i][j] - rhos[i]) / sigmas[i]));\n                }\n                rows[i * nNeighbors + j] = i;\n                cols[i * nNeighbors + j] = knnIndices[i][j];\n                vals[i * nNeighbors + j] = val;\n            }\n        }\n        return { rows: rows, cols: cols, vals: vals };\n    };\n    UMAP.prototype.initializeSimplicialSetEmbedding = function () {\n        var _this = this;\n        var nEpochs = this.getNEpochs();\n        var nComponents = this.nComponents;\n        var graphValues = this.graph.getValues();\n        var graphMax = 0;\n        for (var i = 0; i < graphValues.length; i++) {\n            var value = graphValues[i];\n            if (graphMax < graphValues[i]) {\n                graphMax = value;\n            }\n        }\n        var graph = this.graph.map(function (value) {\n            if (value < graphMax / nEpochs) {\n                return 0;\n            }\n            else {\n                return value;\n            }\n        });\n        this.embedding = utils.zeros(graph.nRows).map(function () {\n            return utils.zeros(nComponents).map(function () {\n                return utils.tauRand(_this.random) * 20 + -10;\n            });\n        });\n        var weights = [];\n        var head = [];\n        var tail = [];\n        var rowColValues = graph.getAll();\n        for (var i = 0; i < rowColValues.length; i++) {\n            var entry = rowColValues[i];\n            if (entry.value) {\n                weights.push(entry.value);\n                tail.push(entry.row);\n                head.push(entry.col);\n            }\n        }\n        var epochsPerSample = this.makeEpochsPerSample(weights, nEpochs);\n        return { head: head, tail: tail, epochsPerSample: epochsPerSample };\n    };\n    UMAP.prototype.makeEpochsPerSample = function (weights, nEpochs) {\n        var result = utils.filled(weights.length, -1.0);\n        var max = utils.max(weights);\n        var nSamples = weights.map(function (w) { return (w / max) * nEpochs; });\n        nSamples.forEach(function (n, i) {\n            if (n > 0)\n                result[i] = nEpochs / nSamples[i];\n        });\n        return result;\n    };\n    UMAP.prototype.assignOptimizationStateParameters = function (state) {\n        Object.assign(this.optimizationState, state);\n    };\n    UMAP.prototype.prepareForOptimizationLoop = function () {\n        var _a = this, repulsionStrength = _a.repulsionStrength, learningRate = _a.learningRate, negativeSampleRate = _a.negativeSampleRate;\n        var _b = this.optimizationState, epochsPerSample = _b.epochsPerSample, headEmbedding = _b.headEmbedding, tailEmbedding = _b.tailEmbedding;\n        var dim = headEmbedding[0].length;\n        var moveOther = headEmbedding.length === tailEmbedding.length;\n        var epochsPerNegativeSample = epochsPerSample.map(function (e) { return e / negativeSampleRate; });\n        var epochOfNextNegativeSample = __spread(epochsPerNegativeSample);\n        var epochOfNextSample = __spread(epochsPerSample);\n        this.assignOptimizationStateParameters({\n            epochOfNextSample: epochOfNextSample,\n            epochOfNextNegativeSample: epochOfNextNegativeSample,\n            epochsPerNegativeSample: epochsPerNegativeSample,\n            moveOther: moveOther,\n            initialAlpha: learningRate,\n            alpha: learningRate,\n            gamma: repulsionStrength,\n            dim: dim,\n        });\n    };\n    UMAP.prototype.initializeOptimization = function () {\n        var headEmbedding = this.embedding;\n        var tailEmbedding = this.embedding;\n        var _a = this.optimizationState, head = _a.head, tail = _a.tail, epochsPerSample = _a.epochsPerSample;\n        var nEpochs = this.getNEpochs();\n        var nVertices = this.graph.nCols;\n        var _b = findABParams(this.spread, this.minDist), a = _b.a, b = _b.b;\n        this.assignOptimizationStateParameters({\n            headEmbedding: headEmbedding,\n            tailEmbedding: tailEmbedding,\n            head: head,\n            tail: tail,\n            epochsPerSample: epochsPerSample,\n            a: a,\n            b: b,\n            nEpochs: nEpochs,\n            nVertices: nVertices,\n        });\n    };\n    UMAP.prototype.optimizeLayoutStep = function (n) {\n        var optimizationState = this.optimizationState;\n        var head = optimizationState.head, tail = optimizationState.tail, headEmbedding = optimizationState.headEmbedding, tailEmbedding = optimizationState.tailEmbedding, epochsPerSample = optimizationState.epochsPerSample, epochOfNextSample = optimizationState.epochOfNextSample, epochOfNextNegativeSample = optimizationState.epochOfNextNegativeSample, epochsPerNegativeSample = optimizationState.epochsPerNegativeSample, moveOther = optimizationState.moveOther, initialAlpha = optimizationState.initialAlpha, alpha = optimizationState.alpha, gamma = optimizationState.gamma, a = optimizationState.a, b = optimizationState.b, dim = optimizationState.dim, nEpochs = optimizationState.nEpochs, nVertices = optimizationState.nVertices;\n        var clipValue = 4.0;\n        for (var i = 0; i < epochsPerSample.length; i++) {\n            if (epochOfNextSample[i] > n) {\n                continue;\n            }\n            var j = head[i];\n            var k = tail[i];\n            var current = headEmbedding[j];\n            var other = tailEmbedding[k];\n            var distSquared = rDist(current, other);\n            var gradCoeff = 0;\n            if (distSquared > 0) {\n                gradCoeff = -2.0 * a * b * Math.pow(distSquared, b - 1.0);\n                gradCoeff /= a * Math.pow(distSquared, b) + 1.0;\n            }\n            for (var d = 0; d < dim; d++) {\n                var gradD = clip(gradCoeff * (current[d] - other[d]), clipValue);\n                current[d] += gradD * alpha;\n                if (moveOther) {\n                    other[d] += -gradD * alpha;\n                }\n            }\n            epochOfNextSample[i] += epochsPerSample[i];\n            var nNegSamples = Math.floor((n - epochOfNextNegativeSample[i]) / epochsPerNegativeSample[i]);\n            for (var p = 0; p < nNegSamples; p++) {\n                var k_1 = utils.tauRandInt(nVertices, this.random);\n                var other_1 = tailEmbedding[k_1];\n                var distSquared_1 = rDist(current, other_1);\n                var gradCoeff_1 = 0.0;\n                if (distSquared_1 > 0.0) {\n                    gradCoeff_1 = 2.0 * gamma * b;\n                    gradCoeff_1 /=\n                        (0.001 + distSquared_1) * (a * Math.pow(distSquared_1, b) + 1);\n                }\n                else if (j === k_1) {\n                    continue;\n                }\n                for (var d = 0; d < dim; d++) {\n                    var gradD = 4.0;\n                    if (gradCoeff_1 > 0.0) {\n                        gradD = clip(gradCoeff_1 * (current[d] - other_1[d]), clipValue);\n                    }\n                    current[d] += gradD * alpha;\n                }\n            }\n            epochOfNextNegativeSample[i] += nNegSamples * epochsPerNegativeSample[i];\n        }\n        optimizationState.alpha = initialAlpha * (1.0 - n / nEpochs);\n        optimizationState.currentEpoch += 1;\n        return headEmbedding;\n    };\n    UMAP.prototype.optimizeLayoutAsync = function (epochCallback) {\n        var _this = this;\n        if (epochCallback === void 0) { epochCallback = function () { return true; }; }\n        return new Promise(function (resolve, reject) {\n            var step = function () { return __awaiter(_this, void 0, void 0, function () {\n                var _a, nEpochs, currentEpoch, epochCompleted, shouldStop, isFinished;\n                return __generator(this, function (_b) {\n                    try {\n                        _a = this.optimizationState, nEpochs = _a.nEpochs, currentEpoch = _a.currentEpoch;\n                        this.embedding = this.optimizeLayoutStep(currentEpoch);\n                        epochCompleted = this.optimizationState.currentEpoch;\n                        shouldStop = epochCallback(epochCompleted) === false;\n                        isFinished = epochCompleted === nEpochs;\n                        if (!shouldStop && !isFinished) {\n                            setTimeout(function () { return step(); }, 0);\n                        }\n                        else {\n                            return [2, resolve(isFinished)];\n                        }\n                    }\n                    catch (err) {\n                        reject(err);\n                    }\n                    return [2];\n                });\n            }); };\n            setTimeout(function () { return step(); }, 0);\n        });\n    };\n    UMAP.prototype.optimizeLayout = function (epochCallback) {\n        if (epochCallback === void 0) { epochCallback = function () { return true; }; }\n        var isFinished = false;\n        var embedding = [];\n        while (!isFinished) {\n            var _a = this.optimizationState, nEpochs = _a.nEpochs, currentEpoch = _a.currentEpoch;\n            embedding = this.optimizeLayoutStep(currentEpoch);\n            var epochCompleted = this.optimizationState.currentEpoch;\n            var shouldStop = epochCallback(epochCompleted) === false;\n            isFinished = epochCompleted === nEpochs || shouldStop;\n        }\n        return embedding;\n    };\n    UMAP.prototype.getNEpochs = function () {\n        var graph = this.graph;\n        if (this.nEpochs > 0) {\n            return this.nEpochs;\n        }\n        var length = graph.nRows;\n        if (length <= 2500) {\n            return 500;\n        }\n        else if (length <= 5000) {\n            return 400;\n        }\n        else if (length <= 7500) {\n            return 300;\n        }\n        else {\n            return 200;\n        }\n    };\n    return UMAP;\n}());\nexports.UMAP = UMAP;\nfunction euclidean(x, y) {\n    var result = 0;\n    for (var i = 0; i < x.length; i++) {\n        result += Math.pow((x[i] - y[i]), 2);\n    }\n    return Math.sqrt(result);\n}\nexports.euclidean = euclidean;\nfunction cosine(x, y) {\n    var result = 0.0;\n    var normX = 0.0;\n    var normY = 0.0;\n    for (var i = 0; i < x.length; i++) {\n        result += x[i] * y[i];\n        normX += Math.pow(x[i], 2);\n        normY += Math.pow(y[i], 2);\n    }\n    if (normX === 0 && normY === 0) {\n        return 0;\n    }\n    else if (normX === 0 || normY === 0) {\n        return 1.0;\n    }\n    else {\n        return 1.0 - result / Math.sqrt(normX * normY);\n    }\n}\nexports.cosine = cosine;\nvar OptimizationState = (function () {\n    function OptimizationState() {\n        this.currentEpoch = 0;\n        this.headEmbedding = [];\n        this.tailEmbedding = [];\n        this.head = [];\n        this.tail = [];\n        this.epochsPerSample = [];\n        this.epochOfNextSample = [];\n        this.epochOfNextNegativeSample = [];\n        this.epochsPerNegativeSample = [];\n        this.moveOther = true;\n        this.initialAlpha = 1.0;\n        this.alpha = 1.0;\n        this.gamma = 1.0;\n        this.a = 1.5769434603113077;\n        this.b = 0.8950608779109733;\n        this.dim = 2;\n        this.nEpochs = 500;\n        this.nVertices = 0;\n    }\n    return OptimizationState;\n}());\nfunction clip(x, clipValue) {\n    if (x > clipValue)\n        return clipValue;\n    else if (x < -clipValue)\n        return -clipValue;\n    else\n        return x;\n}\nfunction rDist(x, y) {\n    var result = 0.0;\n    for (var i = 0; i < x.length; i++) {\n        result += Math.pow(x[i] - y[i], 2);\n    }\n    return result;\n}\nfunction findABParams(spread, minDist) {\n    var curve = function (_a) {\n        var _b = __read(_a, 2), a = _b[0], b = _b[1];\n        return function (x) {\n            return 1.0 / (1.0 + a * Math.pow(x, (2 * b)));\n        };\n    };\n    var xv = utils\n        .linear(0, spread * 3, 300)\n        .map(function (val) { return (val < minDist ? 1.0 : val); });\n    var yv = utils.zeros(xv.length).map(function (val, index) {\n        var gte = xv[index] >= minDist;\n        return gte ? Math.exp(-(xv[index] - minDist) / spread) : val;\n    });\n    var initialValues = [0.5, 0.5];\n    var data = { x: xv, y: yv };\n    var options = {\n        damping: 1.5,\n        initialValues: initialValues,\n        gradientDifference: 10e-2,\n        maxIterations: 100,\n        errorTolerance: 10e-3,\n    };\n    var parameterValues = ml_levenberg_marquardt_1.default(data, curve, options).parameterValues;\n    var _a = __read(parameterValues, 2), a = _a[0], b = _a[1];\n    return { a: a, b: b };\n}\nexports.findABParams = findABParams;\nfunction fastIntersection(graph, target, unknownDist, farDist) {\n    if (unknownDist === void 0) { unknownDist = 1.0; }\n    if (farDist === void 0) { farDist = 5.0; }\n    return graph.map(function (value, row, col) {\n        if (target[row] === -1 || target[col] === -1) {\n            return value * Math.exp(-unknownDist);\n        }\n        else if (target[row] !== target[col]) {\n            return value * Math.exp(-farDist);\n        }\n        else {\n            return value;\n        }\n    });\n}\nexports.fastIntersection = fastIntersection;\nfunction resetLocalConnectivity(simplicialSet) {\n    simplicialSet = matrix.normalize(simplicialSet, \"max\");\n    var transpose = matrix.transpose(simplicialSet);\n    var prodMatrix = matrix.pairwiseMultiply(transpose, simplicialSet);\n    simplicialSet = matrix.add(simplicialSet, matrix.subtract(transpose, prodMatrix));\n    return matrix.eliminateZeros(simplicialSet);\n}\nexports.resetLocalConnectivity = resetLocalConnectivity;\nfunction initTransform(indices, weights, embedding) {\n    var result = utils\n        .zeros(indices.length)\n        .map(function (z) { return utils.zeros(embedding[0].length); });\n    for (var i = 0; i < indices.length; i++) {\n        for (var j = 0; j < indices[0].length; j++) {\n            for (var d = 0; d < embedding[0].length; d++) {\n                var a = indices[i][j];\n                result[i][d] += weights[i][j] * embedding[a][d];\n            }\n        }\n    }\n    return result;\n}\nexports.initTransform = initTransform;\n","\"use strict\";\nvar __values = (this && this.__values) || function (o) {\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\n    if (m) return m.call(o);\n    return {\n        next: function () {\n            if (o && i >= o.length) o = void 0;\n            return { value: o && o[i++], done: !o };\n        }\n    };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nfunction tauRandInt(n, random) {\n    return Math.floor(random() * n);\n}\nexports.tauRandInt = tauRandInt;\nfunction tauRand(random) {\n    return random();\n}\nexports.tauRand = tauRand;\nfunction norm(vec) {\n    var e_1, _a;\n    var result = 0;\n    try {\n        for (var vec_1 = __values(vec), vec_1_1 = vec_1.next(); !vec_1_1.done; vec_1_1 = vec_1.next()) {\n            var item = vec_1_1.value;\n            result += Math.pow(item, 2);\n        }\n    }\n    catch (e_1_1) { e_1 = { error: e_1_1 }; }\n    finally {\n        try {\n            if (vec_1_1 && !vec_1_1.done && (_a = vec_1.return)) _a.call(vec_1);\n        }\n        finally { if (e_1) throw e_1.error; }\n    }\n    return Math.sqrt(result);\n}\nexports.norm = norm;\nfunction empty(n) {\n    var output = [];\n    for (var i = 0; i < n; i++) {\n        output.push(undefined);\n    }\n    return output;\n}\nexports.empty = empty;\nfunction range(n) {\n    return empty(n).map(function (_, i) { return i; });\n}\nexports.range = range;\nfunction filled(n, v) {\n    return empty(n).map(function () { return v; });\n}\nexports.filled = filled;\nfunction zeros(n) {\n    return filled(n, 0);\n}\nexports.zeros = zeros;\nfunction ones(n) {\n    return filled(n, 1);\n}\nexports.ones = ones;\nfunction linear(a, b, len) {\n    return empty(len).map(function (_, i) {\n        return a + i * ((b - a) / (len - 1));\n    });\n}\nexports.linear = linear;\nfunction sum(input) {\n    return input.reduce(function (sum, val) { return sum + val; });\n}\nexports.sum = sum;\nfunction mean(input) {\n    return sum(input) / input.length;\n}\nexports.mean = mean;\nfunction max(input) {\n    var max = 0;\n    for (var i = 0; i < input.length; i++) {\n        max = input[i] > max ? input[i] : max;\n    }\n    return max;\n}\nexports.max = max;\nfunction max2d(input) {\n    var max = 0;\n    for (var i = 0; i < input.length; i++) {\n        for (var j = 0; j < input[i].length; j++) {\n            max = input[i][j] > max ? input[i][j] : max;\n        }\n    }\n    return max;\n}\nexports.max2d = max2d;\nfunction rejectionSample(nSamples, poolSize, random) {\n    var result = zeros(nSamples);\n    for (var i = 0; i < nSamples; i++) {\n        var rejectSample = true;\n        while (rejectSample) {\n            var j = tauRandInt(poolSize, random);\n            var broken = false;\n            for (var k = 0; k < i; k++) {\n                if (j === result[k]) {\n                    broken = true;\n                    break;\n                }\n            }\n            if (!broken) {\n                rejectSample = false;\n            }\n            result[i] = j;\n        }\n    }\n    return result;\n}\nexports.rejectionSample = rejectionSample;\nfunction reshape2d(x, a, b) {\n    var rows = [];\n    var count = 0;\n    var index = 0;\n    if (x.length !== a * b) {\n        throw new Error('Array dimensions must match input length.');\n    }\n    for (var i = 0; i < a; i++) {\n        var col = [];\n        for (var j = 0; j < b; j++) {\n            col.push(x[index]);\n            index += 1;\n        }\n        rows.push(col);\n        count += 1;\n    }\n    return rows;\n}\nexports.reshape2d = reshape2d;\n"],"names":["Object","prototype","toString","isAnyArray","object","call","endsWith","errorCalculation","data","parameters","parameterizedFunction","error","func","i","x","length","Math","abs","y","value","tag","includes","rescale","input","output","options","arguments","undefined","TypeError","Array","currentMin","_options$fromIndex","fromIndex","_options$toIndex","toIndex","Number","isInteger","Error","minValue","min","currentMax","maxValue","max","RangeError","_options$min","autoMinMax","_options$max","factor","indent","repeat","indentData","inspectMatrixWithOptions","matrix","maxRows","maxColumns","maxNumSize","padMinus","constructor","name","rows","columns","maxI","maxJ","result","loop","j","get","line","push","formatNumber","join","inspectData","num","formatNumber2","padEnd","len","str","fix","toFixed","startsWith","exp","toExponential","slice","checkRowIndex","index","outer","checkColumnIndex","checkRowVector","vector","to1DArray","checkColumnVector","checkRange","startRow","endRow","startColumn","endColumn","checkNumber","newArray","array","checkNonEmpty","isEmpty","AbstractMatrix","static","newRows","newColumns","newData","newMatrix","Matrix","row","column","set","fill","random","interval","round","this","zeros","l","matrix1","matrix2","checkMatrix","isMatrix","klass","size","apply","callback","to2DArray","copy","toJSON","isRowVector","isColumnVector","isVector","isSquare","isSymmetric","isEchelonForm","previousColumn","checked","isReducedEchelonForm","k","echelonForm","clone","h","iMax","swapRows","tmp","reducedEchelonForm","m","n","maxRow","p","pivot","setSubMatrix","neg","mulS","getRow","getRowVector","rowVector","setRow","row1","row2","temp","getColumn","getColumnVector","columnVector","setColumn","swapColumns","column1","column2","addRowVector","subRowVector","mulRowVector","divRowVector","addColumnVector","subColumnVector","mulColumnVector","divColumnVector","mulRow","mulColumn","by","NaN","NEGATIVE_INFINITY","maxIndex","v","idx","POSITIVE_INFINITY","minIndex","maxRowIndex","minRow","minRowIndex","maxColumn","maxColumnIndex","minColumn","minColumnIndex","diag","norm","type","sqrt","cumulativeSum","sum","dot","vector2","vector1","mmul","other","Bcolj","Float64Array","s","strassen2x2","a11","b11","a12","b12","a21","b21","a22","b22","m1","m2","m3","m4","m5","c00","c01","c10","c11","strassen3x3","a00","a01","a02","a10","a20","b00","b01","b02","b10","b20","m6","m7","m8","m9","m12","m13","m14","m15","m16","m17","m18","c02","c12","c20","c21","c22","mmulStrassen","r1","c1","r2","c2","embed","mat","cols","r","c","resultat","console","warn","blockMult","a","b","halfRows","parseInt","halfCols","subMatrix","add","sub","scaleRows","isFinite","scaleColumns","flipRows","middle","ceil","first","last","flipColumns","kroneckerProduct","q","kroneckerSum","AxI","eye","IxB","transpose","sortRows","compareFunction","compareNumbers","sort","sortColumns","subMatrixRow","indices","subMatrixColumn","selection","rowIndices","columnIndices","checkRowIndices","checkColumnIndices","rowIndex","columnIndex","trace","sumByRow","sumByColumn","sumAll","product","productByRow","productByColumn","productAll","mean","variance","unbiased","sum1","sum2","varianceByRow","varianceByColumn","varianceAll","standardDeviation","center","centerByRow","centerByColumn","centerAll","scale","pow","getScaleByRow","scaleByRow","getScaleByColumn","scaleByColumn","divider","getScaleAll","scaleAll","Symbol","for","rand","randomInt","randInt","diagonal","identity","negate","tensorProduct","nRows","nColumns","super","arrayData","every","element","from","removeRow","splice","addRow","removeColumn","newRow","addColumn","addS","addM","subS","subM","subtract","subtractS","subtractM","mul","mulM","multiply","multiplyS","multiplyM","div","divS","divM","divide","divideS","divideM","mod","modS","modM","modulus","modulusS","modulusM","and","andS","andM","or","orS","orM","xor","xorS","xorM","leftShift","leftShiftS","leftShiftM","signPropagatingRightShift","signPropagatingRightShiftS","signPropagatingRightShiftM","rightShift","rightShiftS","rightShiftM","zeroFillRightShift","zeroFillRightShiftS","zeroFillRightShiftM","not","acos","acosh","asin","asinh","atan","atanh","cbrt","clz32","cos","cosh","expm1","floor","fround","log","log1p","log10","log2","sign","sin","sinh","tan","tanh","trunc","arg0","powS","powM","installMathOperations","WrapperMatrix2D","LuDecomposition","t","LUcolj","kmax","lu","pivotVector","pivotSign","LU","isSingular","col","solve","count","X","determinant","lowerTriangularMatrix","upperTriangularMatrix","pivotPermutationVector","hypotenuse","QrDecomposition","qr","rdiag","nrm","QR","Rdiag","isFullRank","orthogonalMatrix","SingularValueDecomposition","computeLeftSingularVectors","computeRightSingularVectors","autoTranspose","wantu","Boolean","wantv","swapped","aux","nu","ni","U","V","e","work","si","nct","nrt","mrc","pp","iter","eps","EPSILON","kase","alpha","MIN_VALUE","isNaN","ks","f","cs","sn","sp","spm1","epm1","sk","ek","shift","g","Y","threshold","scols","Ls","rightSingularVectors","VL","vrows","urows","VLU","solveForDiagonal","inverse","vcols","ucols","condition","norm2","rank","tol","ii","leftSingularVectors","diagonalMatrix","step","params","damping","gradientDifference","evaluatedData","gradientFunc","paramFunction","ans","param","auxParams","funcParam","point","gradientFunction","matrixFunc","matrixFunction","inverseMatrix","useSVD","leftHandSide","rightHandSide","levenbergMarquardt","maxIterations","errorTolerance","minValues","maxValues","initialValues","parLen","MAX_SAFE_INTEGER","MIN_SAFE_INTEGER","iteration","converged","parameterValues","parameterError","iterations","__importStar","__esModule","hasOwnProperty","defineProperty","exports","utils","makeHeap","nPoints","makeArrays","fillValue","empty","map","filled","heap","Infinity","heapPush","weight","flag","weights","uncheckedHeapPush","isNew","iSwap","ic1","ic2","heapShape2","siftDown","heap1","heap2","ceiling","elt","leftChild","rightChild","swap","temp1","temp2","rejectionSample","nSamples","poolSize","rejectSample","tauRandInt","broken","buildCandidates","currentGraph","nVertices","nNeighbors","maxCandidates","candidateNeighbors","isn","d","tauRand","deheapSort","indHeap","distHeap","indHeapIndex","distHeapIndex","smallestFlagged","ind","dist","minDist","resultIndex","umap_1","UMAP","_a","__read","o","iterator","ar","next","done","__values","SparseMatrix","values","dims","entries","Map","nCols","checkDims","key","makeKey","has","defaultValue","getAll","ordered","rowColValues","forEach","getDims","getRows","_b","getCols","getValues","fn","vals","toArray","_this","pairwiseMultiply","elementWise","maximum","multiplyScalar","scalar","eliminateZeros","zeroIndices","Set","removeByZeroIndex","_","nextValues","filter","nextRows","nextCols","normalize","normType","e_1","normFn","normFns","colsByRow","nextMatrix","_loop_1","keys","_c","e_1_1","return","xs","op","visited","operate","nextValue","valuesA","rowsA","colsA","valuesB","rowsB","colsB","getCSR","indptr","currentRow","tree","makeNNDescent","distanceFn","leafArray","nIters","delta","rho","rpTreeInit","cj","ck","makeInitializations","initFromRandom","queryPoints","_heap","initFromTree","_tree","searchFlatTree","makeInitializedNNSearch","graph","initialization","tried","vertex","candidates","candidates_1","candidates_1_1","candidate","initializeSearch","forest","e_2","results","forest_1","forest_1_1","e_2_1","__spread","concat","FlatTree","hyperplanes","offsets","children","makeEuclideanTree","leafSize","splitResults","dim","leftIndex","rightIndex","left","right","hyperplaneOffset","hyperplaneVector","nLeft","nRight","side","margin","indicesLeft","indicesRight","hyperplane","offset","euclideanRandomProjectionSplit","isLeaf","recursiveFlatten","nodeNum","leafNum","oldNodeNum","res","numNodes","numLeaves","selectSide","makeForest","nTrees","range","makeTree","nNodes","nLeaves","flattenTree","makeLeafArray","rpForest","rpForest_1","rpForest_1_1","node","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","rejected","then","__generator","body","label","sent","trys","ops","verb","pop","__importDefault","nnDescent","ml_levenberg_marquardt_1","SMOOTH_K_TOLERANCE","MIN_K_DIST_SCALE","learningRate","localConnectivity","nComponents","nEpochs","negativeSampleRate","repulsionStrength","setOpMixRatio","spread","transformQueueSize","targetMetric","targetWeight","targetNNeighbors","euclidean","isInitialized","embedding","optimizationState","OptimizationState","setParam","fit","initializeFit","optimizeLayout","fitAsync","optimizeLayoutAsync","setSupervisedProjection","setPrecomputedKNN","knnIndices","knnDistances","getNEpochs","knnResults","nearestNeighbors","fuzzySimplicialSet","makeSearchFns","searchGraph","makeSearchGraph","processGraphForSupervisedProjection","initializeSimplicialSetEmbedding","head","tail","epochsPerSample","initializeOptimization","prepareForOptimizationLoop","search","knn","distances","neighbor","distance","transform","toTransform","rawData","init","adjustedLocalConnectivity","smoothKNNDistance","sigmas","rhos","computeMembershipStrengths","normed","csrMatrix","initTransform","reshape2d","graphMax","reduce","val","makeEpochsPerSample","assignOptimizationStateParameters","headEmbedding","tailEmbedding","currentEpoch","farDist","categoricalSimplicialSetIntersection","optimizeLayoutStep","getEmbedding","metricNNDescent","_d","_e","sparseMatrix","prodMatrix","simplicialSet","target","unknownDist","intersection","fastIntersection","resetLocalConnectivity","nIter","bandwidth","lo","hi","mid","ithDistances","nonZeroDists","interpolation","psum","meanIthDistances","meanDistances","graphValues","entry","w","state","assign","moveOther","epochsPerNegativeSample","epochOfNextNegativeSample","epochOfNextSample","initialAlpha","gamma","findABParams","current","distSquared","rDist","gradCoeff","gradD","clip","nNegSamples","k_1","other_1","distSquared_1","gradCoeff_1","epochCallback","epochCompleted","shouldStop","isFinished","setTimeout","err","cosine","normX","normY","clipValue","xv","linear","yv","default","z","vec","vec_1","vec_1_1","item","ones","max2d"],"sourceRoot":""}