@datagrok/bio 2.12.0 → 2.12.2

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/709.js CHANGED
@@ -1,2 +1,2 @@
1
- var bio;(()=>{"use strict";var t,e,r={2357:(t,e,r)=>{var o=r(2590);async function n(t,e,r){const o=t.length,n=[],s=[];for(let a=0;a<o;a++)for(let l=a+1;l<o;l++){const o=t[a],i=t[l];e[o]?.[i]>=r&&(n.push(a),s.push(l))}return function(t,e,r){const o=new Float32Array(r.length).fill(0).map((()=>10*Math.random())),n=new Float32Array(r.length).fill(0).map((()=>10*Math.random())),s=new Float32Array(r.length).fill(0),a=new Float32Array(r.length).fill(0);for(let l=0;l<100;l++){const i=1-l/100;s.fill(0),a.fill(0);for(let r=0;r<t.length;r++){const l=t[r],c=e[r],f=o[l]-o[c],h=n[l]-n[c];Math.abs(f)>=1&&(s[l]-=i*f,s[c]+=i*f),Math.abs(h)>=1&&(a[l]-=i*h,a[c]+=i*h)}for(let t=0;t<r.length;t++){const e=Math.sqrt(s[t]*s[t]+a[t]*a[t]);e>0&&(o[t]+=s[t]/e*i,n[t]+=a[t]/e*i)}}let l=o[0],i=n[0],c=o[0],f=n[0];for(let t=1;t<r.length;t++)l=Math.min(l,o[t]),i=Math.min(i,n[t]),c=Math.max(c,o[t]),f=Math.max(f,n[t]);let h=c-l,u=f-i;0===h&&(h=c);for(let t=0;t<r.length;t++)o[t]=(o[t]-l)/h/2+.5;0===u&&(u=f);for(let t=0;t<r.length;t++)n[t]=(n[t]-i)/u/2+.5;return{embedX:o,embedY:n}}(n,s,t)}const s={expandFactor:2,maxIterations:5,inflateFactor:2,multFactor:1};class a{constructor(t={}){this._options={...s,...t}}async transform(t,e){let r=this.toObjectForm(t);if(this._options.maxIterations>0){this.addLoops(r,e),this.normalize(r);for(let t=0;t<this._options.maxIterations;t++)r=this.expand(r,e),this.inflate(r),this.normalize(r)}const{clusters:o,is:n,js:s}=this.assignClusters(r,e);this.correctClusters(o);const a=await this.layout(o,r,e);return{clusters:o,embedX:a.embedX,embedY:a.embedY,is:n,js:s}}correctClusters(t){const e={};for(const r of t)e[r]||(e[r]=0),e[r]++;const r=Object.keys(e).map(Number).sort(((t,r)=>e[t]-e[r])),o={};r.forEach(((t,e)=>o[t]=e+1));for(let e=0;e<t.length;e++)t[e]=o[t[e]]}async layout(t,e,r){const o=new Float32Array(r).fill(0),s=new Float32Array(r).fill(0),a={};t.forEach(((t,e)=>{a[t]||(a[t]=[]),a[t].push(e)}));let l=0;const i=Object.keys(a);i.sort(((t,e)=>a[e].length-a[t].length));let c=6,f=0;for(const t of i){const r=a[t],i=await n(r,e,.001);l===Math.ceil(c/1.5)&&(l=0,f+=5/c,c=Math.ceil(1.5*c));const h=l%c*5/c*1.5;for(let t=0;t<i.embedX.length;t++)o[r[t]]=5*i.embedX[t]/c+h,s[r[t]]=5*i.embedY[t]/c+f;l++}return{embedX:o,embedY:s}}mergeClusters(t,e,r){const o=t[e],n=t[r];for(let e=0;e<t.length;e++)t[e]===n&&(t[e]=o)}assignClusters(t,e){let r=0;const o=[],n=[],s=Math.floor(Math.max(Math.log10(e),2))+1,a=Math.pow(10,s),l=new Array(e).fill(-1);for(const e of Object.keys(t))for(const s of Object.keys(t[e]))Math.round(t[e][s]*a)/a>0&&t[e][s]!==Number(e)&&Number(s)>Number(e)&&(o.push(Number(e)),n.push(Number(s)),-1!==l[Number(e)]&&-1!==l[Number(s)]?l[Number(e)]!==l[Number(s)]&&this.mergeClusters(l,Number(e),Number(s)):-1!==l[Number(e)]?l[Number(s)]=l[Number(e)]:-1!==l[Number(s)]?l[Number(e)]=l[Number(s)]:(r++,l[Number(e)]=r,l[Number(s)]=r));for(let t=0;t<l.length;t++)-1===l[t]&&(r++,l[t]=r);return{clusters:l,is:o,js:n}}toObjectForm(t){const e={};for(let r=0;r<t.i.length;r++)e[t.i[r]]||(e[t.i[r]]={}),e[t.i[r]][t.j[r]]=1-t.distance[r],e[t.j[r]]||(e[t.j[r]]={}),e[t.j[r]][t.i[r]]=1-t.distance[r];return e}addLoops(t,e){for(let r=0;r<e;r++)t[r]||(t[r]={}),t[r][r]=this._options.multFactor}normalize(t){for(const e of Object.keys(t)){const r=t[e];let o=0;for(const t of Object.keys(r))o+=r[t];if(0!==o)for(const n of Object.keys(r))t[e][n]/=o}}expand(t,e){const r={},o=Math.floor(Math.max(Math.log10(e),2))+1,n=Math.pow(10,o);for(let o=0;o<e;o++)if(t[o]){r[o]={};for(let s=o;s<e;s++){if(!t[o]?.[s])continue;const e=this.getExpandValue(t,o,s);Math.round(e*n)/n>0&&(r[o][s]=e,r[s]||(r[s]={}),r[s][o]=e)}}return r}inflate(t){for(const e of Object.keys(t)){const r=t[e];for(const o of Object.keys(r))t[e][o]=Math.pow(t[e][o],this._options.inflateFactor)}}getExpandValue(t,e,r){let o=0;const n=Object.keys(t[e]??{}),s=Object.keys(t[r]??{});for(const a of n)s.includes(a)&&(o+=t[e][a]*t[r][a]);return o}}onmessage=async t=>{const{data:e,threshold:r,weights:n,aggregationMethod:s,distanceFnArgs:l,distanceFns:i,maxIterations:c}=t.data,f=await(new o._).calcMultiColumn(e,i,r/100,l,n,s),h=await new a({maxIterations:c??5}).transform(f,e[0].length);postMessage({res:h})}},6814:(t,e,r)=>{r.d(e,{cZ:()=>n,kK:()=>o}),r(7862);const o=t=>null==t;function n(t,e,r,o){if(r>t[t.length-1])return;const n=t.findIndex((t=>r<t));t.pop(),t.splice(n,0,r),e.pop(),e.splice(n,0,o)}}},o={};function n(t){var e=o[t];if(void 0!==e)return e.exports;var s=o[t]={exports:{}};return r[t](s,s.exports,n),s.exports}n.m=r,n.x=()=>{var t=n.O(void 0,[590],(()=>n(2357)));return n.O(t)},t=[],n.O=(e,r,o,s)=>{if(!r){var a=1/0;for(f=0;f<t.length;f++){for(var[r,o,s]=t[f],l=!0,i=0;i<r.length;i++)(!1&s||a>=s)&&Object.keys(n.O).every((t=>n.O[t](r[i])))?r.splice(i--,1):(l=!1,s<a&&(a=s));if(l){t.splice(f--,1);var c=o();void 0!==c&&(e=c)}}return e}s=s||0;for(var f=t.length;f>0&&t[f-1][2]>s;f--)t[f]=t[f-1];t[f]=[r,o,s]},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.f={},n.e=t=>Promise.all(Object.keys(n.f).reduce(((e,r)=>(n.f[r](t,e),e)),[])),n.u=t=>t+".js",n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}(),n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{var t;n.g.importScripts&&(t=n.g.location+"");var e=n.g.document;if(!t&&e&&(e.currentScript&&(t=e.currentScript.src),!t)){var r=e.getElementsByTagName("script");if(r.length)for(var o=r.length-1;o>-1&&!t;)t=r[o--].src}if(!t)throw new Error("Automatic publicPath is not supported in this browser");t=t.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),n.p=t})(),(()=>{n.b=self.location+"";var t={709:1};n.f.i=(e,r)=>{t[e]||importScripts(n.p+n.u(e))};var e=self.webpackChunkbio=self.webpackChunkbio||[],r=e.push.bind(e);e.push=e=>{var[o,s,a]=e;for(var l in s)n.o(s,l)&&(n.m[l]=s[l]);for(a&&a(n);o.length;)t[o.pop()]=1;r(e)}})(),e=n.x,n.x=()=>n.e(590).then(e);var s=n.x();bio=s})();
1
+ var bio;(()=>{"use strict";var t,e,r={2357:(t,e,r)=>{var o=r(2590);async function n(t,e,r){const o=t.length,n=[],s=[];for(let a=0;a<o;a++)for(let l=a+1;l<o;l++){const o=t[a],i=t[l];e[o]?.[i]>=r&&(n.push(a),s.push(l))}return function(t,e,r){const o=new Float32Array(r.length).fill(0).map((()=>10*Math.random())),n=new Float32Array(r.length).fill(0).map((()=>10*Math.random())),s=new Float32Array(r.length).fill(0),a=new Float32Array(r.length).fill(0);for(let l=0;l<100;l++){const i=1-l/100;s.fill(0),a.fill(0);for(let r=0;r<t.length;r++){const l=t[r],c=e[r],f=o[l]-o[c],h=n[l]-n[c];Math.abs(f)>=1&&(s[l]-=i*f,s[c]+=i*f),Math.abs(h)>=1&&(a[l]-=i*h,a[c]+=i*h)}for(let t=0;t<r.length;t++){const e=Math.sqrt(s[t]*s[t]+a[t]*a[t]);e>0&&(o[t]+=s[t]/e*i,n[t]+=a[t]/e*i)}}let l=o[0],i=n[0],c=o[0],f=n[0];for(let t=1;t<r.length;t++)l=Math.min(l,o[t]),i=Math.min(i,n[t]),c=Math.max(c,o[t]),f=Math.max(f,n[t]);let h=c-l,u=f-i;0===h&&(h=c);for(let t=0;t<r.length;t++)o[t]=(o[t]-l)/h/2+.5;0===u&&(u=f);for(let t=0;t<r.length;t++)n[t]=(n[t]-i)/u/2+.5;return{embedX:o,embedY:n}}(n,s,t)}const s={expandFactor:2,maxIterations:5,inflateFactor:2,multFactor:1};class a{constructor(t={}){this._options={...s,...t}}async transform(t,e){let r=this.toObjectForm(t);if(this._options.maxIterations>0){this.addLoops(r,e),this.normalize(r);for(let t=0;t<this._options.maxIterations;t++)r=this.expand(r,e),this.inflate(r),this.normalize(r)}const{clusters:o,is:n,js:s}=this.assignClusters(r,e);this.correctClusters(o);const a=await this.layout(o,r,e);return{clusters:o,embedX:a.embedX,embedY:a.embedY,is:n,js:s}}correctClusters(t){const e={};for(const r of t)e[r]||(e[r]=0),e[r]++;const r=Object.keys(e).map(Number).sort(((t,r)=>e[t]-e[r])),o={};r.forEach(((t,e)=>o[t]=e+1));for(let e=0;e<t.length;e++)t[e]=o[t[e]]}async layout(t,e,r){const o=new Float32Array(r).fill(0),s=new Float32Array(r).fill(0),a={};t.forEach(((t,e)=>{a[t]||(a[t]=[]),a[t].push(e)}));let l=0;const i=Object.keys(a);i.sort(((t,e)=>a[e].length-a[t].length));let c=6,f=0;for(const t of i){const r=a[t],i=await n(r,e,.001);l===Math.ceil(c/1.5)&&(l=0,f+=5/c,c=Math.ceil(1.5*c));const h=l%c*5/c*1.5;for(let t=0;t<i.embedX.length;t++)o[r[t]]=5*i.embedX[t]/c+h,s[r[t]]=5*i.embedY[t]/c+f;l++}return{embedX:o,embedY:s}}mergeClusters(t,e,r){const o=t[e],n=t[r];for(let e=0;e<t.length;e++)t[e]===n&&(t[e]=o)}assignClusters(t,e){let r=0;const o=[],n=[],s=Math.floor(Math.max(Math.log10(e),2))+1,a=Math.pow(10,s),l=new Array(e).fill(-1);for(const e of Object.keys(t))for(const s of Object.keys(t[e]))Math.round(t[e][s]*a)/a>0&&t[e][s]!==Number(e)&&Number(s)>Number(e)&&(o.push(Number(e)),n.push(Number(s)),-1!==l[Number(e)]&&-1!==l[Number(s)]?l[Number(e)]!==l[Number(s)]&&this.mergeClusters(l,Number(e),Number(s)):-1!==l[Number(e)]?l[Number(s)]=l[Number(e)]:-1!==l[Number(s)]?l[Number(e)]=l[Number(s)]:(r++,l[Number(e)]=r,l[Number(s)]=r));for(let t=0;t<l.length;t++)-1===l[t]&&(r++,l[t]=r);return{clusters:l,is:new Uint32Array(o),js:new Uint32Array(n)}}toObjectForm(t){const e={};for(let r=0;r<t.i.length;r++)e[t.i[r]]||(e[t.i[r]]={}),e[t.i[r]][t.j[r]]=1-t.distance[r],e[t.j[r]]||(e[t.j[r]]={}),e[t.j[r]][t.i[r]]=1-t.distance[r];return e}addLoops(t,e){for(let r=0;r<e;r++)t[r]||(t[r]={}),t[r][r]=this._options.multFactor}normalize(t){for(const e of Object.keys(t)){const r=t[e];let o=0;for(const t of Object.keys(r))o+=r[t];if(0!==o)for(const n of Object.keys(r))t[e][n]/=o}}expand(t,e){const r={},o=Math.floor(Math.max(Math.log10(e),2))+1,n=Math.pow(10,o);for(let o=0;o<e;o++)if(t[o]){r[o]={};for(let s=o;s<e;s++){if(!t[o]?.[s])continue;const e=this.getExpandValue(t,o,s);Math.round(e*n)/n>0&&(r[o][s]=e,r[s]||(r[s]={}),r[s][o]=e)}}return r}inflate(t){for(const e of Object.keys(t)){const r=t[e];for(const o of Object.keys(r))t[e][o]=Math.pow(t[e][o],this._options.inflateFactor)}}getExpandValue(t,e,r){let o=0;const n=Object.keys(t[e]??{}),s=Object.keys(t[r]??{});for(const a of n)s.includes(a)&&(o+=t[e][a]*t[r][a]);return o}}onmessage=async t=>{const{data:e,threshold:r,weights:n,aggregationMethod:s,distanceFnArgs:l,distanceFns:i,maxIterations:c}=t.data,f=await(new o._).calcMultiColumn(e,i,r/100,l,n,s),h=await new a({maxIterations:c??5}).transform(f,e[0].length);postMessage({res:h})}},6814:(t,e,r)=>{r.d(e,{cZ:()=>n,kK:()=>o}),r(7862);const o=t=>null==t;function n(t,e,r,o){if(r>t[t.length-1])return;const n=t.findIndex((t=>r<t));t.pop(),t.splice(n,0,r),e.pop(),e.splice(n,0,o)}}},o={};function n(t){var e=o[t];if(void 0!==e)return e.exports;var s=o[t]={exports:{}};return r[t](s,s.exports,n),s.exports}n.m=r,n.x=()=>{var t=n.O(void 0,[590],(()=>n(2357)));return n.O(t)},t=[],n.O=(e,r,o,s)=>{if(!r){var a=1/0;for(f=0;f<t.length;f++){for(var[r,o,s]=t[f],l=!0,i=0;i<r.length;i++)(!1&s||a>=s)&&Object.keys(n.O).every((t=>n.O[t](r[i])))?r.splice(i--,1):(l=!1,s<a&&(a=s));if(l){t.splice(f--,1);var c=o();void 0!==c&&(e=c)}}return e}s=s||0;for(var f=t.length;f>0&&t[f-1][2]>s;f--)t[f]=t[f-1];t[f]=[r,o,s]},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.f={},n.e=t=>Promise.all(Object.keys(n.f).reduce(((e,r)=>(n.f[r](t,e),e)),[])),n.u=t=>t+".js",n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}(),n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{var t;n.g.importScripts&&(t=n.g.location+"");var e=n.g.document;if(!t&&e&&(e.currentScript&&(t=e.currentScript.src),!t)){var r=e.getElementsByTagName("script");if(r.length)for(var o=r.length-1;o>-1&&!t;)t=r[o--].src}if(!t)throw new Error("Automatic publicPath is not supported in this browser");t=t.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),n.p=t})(),(()=>{n.b=self.location+"";var t={709:1};n.f.i=(e,r)=>{t[e]||importScripts(n.p+n.u(e))};var e=self.webpackChunkbio=self.webpackChunkbio||[],r=e.push.bind(e);e.push=e=>{var[o,s,a]=e;for(var l in s)n.o(s,l)&&(n.m[l]=s[l]);for(a&&a(n);o.length;)t[o.pop()]=1;r(e)}})(),e=n.x,n.x=()=>n.e(590).then(e);var s=n.x();bio=s})();
2
2
  //# sourceMappingURL=709.js.map
package/dist/709.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"709.js","mappings":"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","sources":["webpack://bio/webpack/runtime/chunk loaded","webpack://bio/webpack/runtime/startup chunk dependencies","webpack://bio/./node_modules/@datagrok-libraries/ml/src/MCL/bio-layout.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/MCL/marcov-cluster.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/MCL/mcl-worker.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/distance-matrix/utils.js","webpack://bio/webpack/bootstrap","webpack://bio/webpack/runtime/define property getters","webpack://bio/webpack/runtime/ensure chunk","webpack://bio/webpack/runtime/get javascript chunk filename","webpack://bio/webpack/runtime/global","webpack://bio/webpack/runtime/hasOwnProperty shorthand","webpack://bio/webpack/runtime/publicPath","webpack://bio/webpack/runtime/importScripts chunk loading","webpack://bio/webpack/startup"],"sourcesContent":["var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","var next = __webpack_require__.x;\n__webpack_require__.x = () => {\n\treturn __webpack_require__.e(590).then(next);\n};","export async function bioLayout(cluster, sparseObject, threshold) {\n const n = cluster.length;\n const is = [];\n const js = [];\n for (let i = 0; i < n; i++) {\n for (let j = i + 1; j < n; j++) {\n const a = cluster[i];\n const b = cluster[j];\n if (sparseObject[a]?.[b] >= threshold) {\n is.push(i);\n js.push(j);\n }\n }\n }\n return getLayoutEmbeddings(is, js, cluster);\n}\nfunction getLayoutEmbeddings(is, js, cluster) {\n const embedX = new Float32Array(cluster.length).fill(0).map(() => Math.random() * 10);\n const embedY = new Float32Array(cluster.length).fill(0).map(() => Math.random() * 10);\n const iterations = 100;\n const xVelocities = new Float32Array(cluster.length).fill(0);\n const yVelocities = new Float32Array(cluster.length).fill(0);\n for (let i = 0; i < iterations; i++) {\n const temperature = (1 - i / iterations);\n xVelocities.fill(0);\n yVelocities.fill(0);\n for (let idx = 0; idx < is.length; idx++) {\n const a = is[idx];\n const b = js[idx];\n const dx = embedX[a] - embedX[b];\n const dy = embedY[a] - embedY[b];\n // const distance = Math.sqrt(dx * dx + dy * dy);\n // const factor = (distance - 1) / distance;\n // const offsetX = dx * factor;\n // const offsetY = dy * factor;\n if (Math.abs(dx) >= 1) {\n xVelocities[a] -= temperature * dx;\n xVelocities[b] += temperature * dx;\n }\n if (Math.abs(dy) >= 1) {\n yVelocities[a] -= temperature * dy;\n yVelocities[b] += temperature * dy;\n }\n // embedY[a] += offsetY * temperature;\n // embedY[b] -= offsetY * temperature;\n }\n for (let idx = 0; idx < cluster.length; idx++) {\n const vecSize = Math.sqrt(xVelocities[idx] * xVelocities[idx] + yVelocities[idx] * yVelocities[idx]);\n if (vecSize > 0) {\n embedX[idx] += xVelocities[idx] / vecSize * temperature;\n embedY[idx] += yVelocities[idx] / vecSize * temperature;\n }\n }\n }\n // normalize\n let minX = embedX[0];\n let minY = embedY[0];\n let maxX = embedX[0];\n let maxY = embedY[0];\n for (let idx = 1; idx < cluster.length; idx++) {\n minX = Math.min(minX, embedX[idx]);\n minY = Math.min(minY, embedY[idx]);\n maxX = Math.max(maxX, embedX[idx]);\n maxY = Math.max(maxY, embedY[idx]);\n }\n let rangeX = maxX - minX;\n let rangeY = maxY - minY;\n if (rangeX === 0)\n rangeX = maxX;\n for (let idx = 0; idx < cluster.length; idx++)\n embedX[idx] = (embedX[idx] - minX) / rangeX / 2 + 0.5;\n if (rangeY === 0)\n rangeY = maxY;\n for (let idx = 0; idx < cluster.length; idx++)\n embedY[idx] = (embedY[idx] - minY) / rangeY / 2 + 0.5;\n return { embedX, embedY };\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bio-layout.js","sourceRoot":"","sources":["bio-layout.ts"],"names":[],"mappings":"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","sourcesContent":["import {SparseMatrixObject} from './types';\n\nexport async function bioLayout(cluster: number[], sparseObject: SparseMatrixObject, threshold: number) {\n  const n = cluster.length;\n  const is: number[] = [];\n  const js: number[] = [];\n  for (let i = 0; i < n; i++) {\n    for (let j = i + 1; j < n; j++) {\n      const a = cluster[i];\n      const b = cluster[j];\n      if (sparseObject[a]?.[b] >= threshold) {\n        is.push(i);\n        js.push(j);\n      }\n    }\n  }\n  return getLayoutEmbeddings(is, js, cluster);\n}\n\nfunction getLayoutEmbeddings(is: number[], js: number[], cluster: number[]) {\n  const embedX = new Float32Array(cluster.length).fill(0).map(() => Math.random() * 10);\n  const embedY = new Float32Array(cluster.length).fill(0).map(() => Math.random() * 10);\n  const iterations = 100;\n  const xVelocities = new Float32Array(cluster.length).fill(0);\n  const yVelocities = new Float32Array(cluster.length).fill(0);\n  for (let i = 0; i < iterations; i++) {\n    const temperature = (1 - i / iterations);\n    xVelocities.fill(0);\n    yVelocities.fill(0);\n    for (let idx = 0; idx < is.length; idx++) {\n      const a = is[idx];\n      const b = js[idx];\n      const dx = embedX[a] - embedX[b];\n      const dy = embedY[a] - embedY[b];\n      //   const distance = Math.sqrt(dx * dx + dy * dy);\n      //   const factor = (distance - 1) / distance;\n      //   const offsetX = dx * factor;\n      //   const offsetY = dy * factor;\n      if (Math.abs(dx) >= 1) {\n        xVelocities[a] -= temperature * dx;\n        xVelocities[b] += temperature * dx;\n      }\n      if (Math.abs(dy) >= 1) {\n        yVelocities[a] -= temperature * dy;\n        yVelocities[b] += temperature * dy;\n      }\n    //   embedY[a] += offsetY * temperature;\n    //   embedY[b] -= offsetY * temperature;\n    }\n    for (let idx = 0; idx < cluster.length; idx++) {\n      const vecSize = Math.sqrt(xVelocities[idx] * xVelocities[idx] + yVelocities[idx] * yVelocities[idx]);\n      if (vecSize > 0) {\n        embedX[idx] += xVelocities[idx] / vecSize * temperature;\n        embedY[idx] += yVelocities[idx] / vecSize * temperature;\n      }\n    }\n  }\n\n  // normalize\n  let minX = embedX[0];\n  let minY = embedY[0];\n  let maxX = embedX[0];\n  let maxY = embedY[0];\n  for (let idx = 1; idx < cluster.length; idx++) {\n    minX = Math.min(minX, embedX[idx]);\n    minY = Math.min(minY, embedY[idx]);\n    maxX = Math.max(maxX, embedX[idx]);\n    maxY = Math.max(maxY, embedY[idx]);\n  }\n  let rangeX = maxX - minX;\n  let rangeY = maxY - minY;\n  if (rangeX === 0)\n    rangeX = maxX;\n  for (let idx = 0; idx < cluster.length; idx++)\n    embedX[idx] = (embedX[idx] - minX) / rangeX / 2 + 0.5;\n  if (rangeY === 0)\n    rangeY = maxY;\n  for (let idx = 0; idx < cluster.length; idx++)\n    embedY[idx] = (embedY[idx] - minY) / rangeY / 2 + 0.5;\n\n  return {embedX, embedY};\n}\n"]}","import { bioLayout } from './bio-layout';\nexport const defaultMCLOptions = {\n expandFactor: 2,\n maxIterations: 5,\n inflateFactor: 2,\n multFactor: 1,\n};\nexport class MCLSparseReducer {\n constructor(opts = {}) {\n this._options = { ...defaultMCLOptions, ...opts };\n }\n async transform(sparseMatrix, nRows) {\n // testWorkerMultiply();\n // return new Int32Array(nRows);\n let sparseObject = this.toObjectForm(sparseMatrix);\n if (this._options.maxIterations > 0) {\n this.addLoops(sparseObject, nRows);\n this.normalize(sparseObject);\n for (let i = 0; i < this._options.maxIterations; i++) {\n sparseObject = this.expand(sparseObject, nRows);\n this.inflate(sparseObject);\n this.normalize(sparseObject);\n }\n }\n const { clusters, is, js } = this.assignClusters(sparseObject, nRows);\n this.correctClusters(clusters);\n const embeddings = await this.layout(clusters, sparseObject, nRows);\n return { clusters, embedX: embeddings.embedX, embedY: embeddings.embedY, is, js };\n }\n correctClusters(clusters) {\n const clusterSizeMap = {};\n for (const cluster of clusters) {\n if (!clusterSizeMap[cluster])\n clusterSizeMap[cluster] = 0;\n clusterSizeMap[cluster]++;\n }\n const sortedIndexes = Object.keys(clusterSizeMap).map(Number).sort((a, b) => clusterSizeMap[a] - clusterSizeMap[b]);\n const clusterMap = {};\n sortedIndexes.forEach((clusterIdx, i) => clusterMap[clusterIdx] = i + 1);\n for (let i = 0; i < clusters.length; i++)\n clusters[i] = clusterMap[clusters[i]];\n // let curCluster = 1;\n // for (let i = 0; i < clusters.length; i++) {\n // if (!clusterMap[clusters[i]]) {\n // clusterMap[clusters[i]] = curCluster;\n // clusters[i] = curCluster;\n // curCluster++;\n // } else {\n // clusters[i] = clusterMap[clusters[i]];\n // }\n // }\n }\n async layout(clusters, sparseMatrix, nRows) {\n const embedX = new Float32Array(nRows).fill(0);\n const embedY = new Float32Array(nRows).fill(0);\n const clusterMap = {};\n clusters.forEach((cluster, i) => {\n if (!clusterMap[cluster])\n clusterMap[cluster] = [];\n clusterMap[cluster].push(i);\n });\n // const nClusters = Object.keys(clusterMap).length;\n // const perRow = Math.floor(Math.sqrt(nClusters));\n let clusterNum = 0;\n const sortedClusterNames = Object.keys(clusterMap);\n sortedClusterNames.sort((a, b) => clusterMap[b].length - clusterMap[a].length);\n let perRow = 6;\n let yOffset = 0;\n const layoutSize = 5;\n for (const clusterName of sortedClusterNames) {\n const cluster = clusterMap[clusterName];\n const embeddings = await bioLayout(cluster, sparseMatrix, 0.001);\n if (clusterNum === Math.ceil(perRow / 1.5)) {\n clusterNum = 0;\n yOffset += layoutSize / perRow;\n perRow = Math.ceil(perRow * 1.5);\n }\n const offsetX = ((clusterNum % perRow) * layoutSize / perRow) * 1.5;\n // const offsetY = Math.floor(clusterNum / perRow) * 2;\n for (let i = 0; i < embeddings.embedX.length; i++) {\n embedX[cluster[i]] = embeddings.embedX[i] * layoutSize / perRow + offsetX;\n embedY[cluster[i]] = embeddings.embedY[i] * layoutSize / perRow + yOffset;\n }\n clusterNum++;\n }\n return { embedX, embedY };\n }\n mergeClusters(clusters, i, j) {\n const iCluster = clusters[i];\n const jCluster = clusters[j];\n for (let k = 0; k < clusters.length; k++) {\n if (clusters[k] === jCluster)\n clusters[k] = iCluster;\n }\n }\n assignClusters(sparseMatrix, nRows) {\n let clusterNum = 0;\n const is = [];\n const js = [];\n const order = Math.floor(Math.max(Math.log10(nRows), 2)) + 1;\n const minOrder = Math.pow(10, order);\n const clusters = new Array(nRows).fill(-1);\n for (const i of Object.keys(sparseMatrix)) {\n for (const j of Object.keys(sparseMatrix[i])) {\n if (Math.round(sparseMatrix[i][j] * minOrder) / minOrder > 0 &&\n sparseMatrix[i][j] !== Number(i) && Number(j) > Number(i)) {\n is.push(Number(i));\n js.push(Number(j));\n if (clusters[Number(i)] !== -1 && clusters[Number(j)] !== -1) {\n if (clusters[Number(i)] !== clusters[Number(j)])\n this.mergeClusters(clusters, Number(i), Number(j));\n }\n else if (clusters[Number(i)] !== -1) {\n clusters[Number(j)] = clusters[Number(i)];\n }\n else if (clusters[Number(j)] !== -1) {\n clusters[Number(i)] = clusters[Number(j)];\n }\n else {\n clusterNum++;\n clusters[Number(i)] = clusterNum;\n clusters[Number(j)] = clusterNum;\n }\n }\n }\n }\n for (let i = 0; i < clusters.length; i++) {\n if (clusters[i] === -1) {\n clusterNum++;\n clusters[i] = clusterNum;\n }\n }\n return { clusters, is, js };\n }\n toObjectForm(sparseMatrix) {\n const sparseObject = {};\n for (let i = 0; i < sparseMatrix.i.length; i++) {\n if (!sparseObject[sparseMatrix.i[i]])\n sparseObject[sparseMatrix.i[i]] = {};\n sparseObject[sparseMatrix.i[i]][sparseMatrix.j[i]] = 1 - sparseMatrix.distance[i];\n if (!sparseObject[sparseMatrix.j[i]])\n sparseObject[sparseMatrix.j[i]] = {};\n sparseObject[sparseMatrix.j[i]][sparseMatrix.i[i]] = 1 - sparseMatrix.distance[i];\n }\n return sparseObject;\n }\n addLoops(sparseObject, nRows) {\n for (let i = 0; i < nRows; i++) {\n if (!sparseObject[i])\n sparseObject[i] = {};\n sparseObject[i][i] = this._options.multFactor;\n }\n }\n normalize(sparseObject) {\n for (const i of Object.keys(sparseObject)) {\n const row = sparseObject[i];\n let sum = 0;\n for (const j of Object.keys(row))\n sum += row[j];\n if (sum === 0)\n continue;\n for (const j of Object.keys(row))\n sparseObject[i][j] /= sum;\n }\n }\n expand(sparseObject, nRows) {\n const expandedObject = {};\n const order = Math.floor(Math.max(Math.log10(nRows), 2)) + 1;\n const minOrder = Math.pow(10, order);\n for (let i = 0; i < nRows; i++) {\n if (!sparseObject[i])\n continue;\n // const row = sparseObject[i];\n expandedObject[i] = {};\n for (let j = i; j < nRows; j++) {\n if (!sparseObject[i]?.[j])\n continue;\n const val = this.getExpandValue(sparseObject, i, j); //pruning step\n if (Math.round(val * minOrder) / minOrder > 0) {\n expandedObject[i][j] = val;\n if (!expandedObject[j])\n expandedObject[j] = {};\n expandedObject[j][i] = val;\n }\n }\n }\n return expandedObject;\n }\n // private prune(row: SparseMatrixObject[number]) {\n // }\n inflate(sparseObject) {\n for (const i of Object.keys(sparseObject)) {\n const row = sparseObject[i];\n for (const j of Object.keys(row))\n sparseObject[i][j] = Math.pow(sparseObject[i][j], this._options.inflateFactor);\n }\n }\n getExpandValue(sparseObject, i, j) {\n let val = 0;\n const currentIndexes = Object.keys(sparseObject[i] ?? {});\n const otherIndexes = Object.keys(sparseObject[j] ?? {});\n for (const k of currentIndexes) {\n if (otherIndexes.includes(k))\n val += sparseObject[i][k] * sparseObject[j][k];\n }\n return val;\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"marcov-cluster.js","sourceRoot":"","sources":["marcov-cluster.ts"],"names":[],"mappings":"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","sourcesContent":["import {SparseMatrixResult} from '../distance-matrix/sparse-matrix-service';\nimport {bioLayout} from './bio-layout';\nimport {MCLOptions, SparseMatrixObject} from './types';\n\nexport const defaultMCLOptions: MCLOptions = {\n  expandFactor: 2,\n  maxIterations: 5,\n  inflateFactor: 2,\n  multFactor: 1,\n};\n\nexport class MCLSparseReducer {\n  private _options: MCLOptions;\n\n  constructor(opts: Partial<MCLOptions> = {}) {\n    this._options = {...defaultMCLOptions, ...opts};\n  }\n\n  public async transform(sparseMatrix: SparseMatrixResult, nRows: number) {\n    // testWorkerMultiply();\n    // return new Int32Array(nRows);\n    let sparseObject = this.toObjectForm(sparseMatrix);\n    if (this._options.maxIterations > 0) {\n      this.addLoops(sparseObject, nRows);\n      this.normalize(sparseObject);\n      for (let i = 0; i < this._options.maxIterations; i++) {\n        sparseObject = this.expand(sparseObject, nRows);\n        this.inflate(sparseObject);\n        this.normalize(sparseObject);\n      }\n    }\n    const {clusters, is, js} = this.assignClusters(sparseObject, nRows);\n    this.correctClusters(clusters);\n    const embeddings = await this.layout(clusters, sparseObject, nRows);\n    return {clusters, embedX: embeddings.embedX, embedY: embeddings.embedY, is, js};\n  }\n\n  private correctClusters(clusters: number[]) {\n    const clusterSizeMap: {[_: number]: number} = {};\n    for (const cluster of clusters) {\n      if (!clusterSizeMap[cluster])\n        clusterSizeMap[cluster] = 0;\n      clusterSizeMap[cluster]++;\n    }\n    const sortedIndexes = Object.keys(clusterSizeMap).map(Number).sort((a, b) => clusterSizeMap[a] - clusterSizeMap[b]);\n    const clusterMap: {[_: number]: number} = {};\n    sortedIndexes.forEach((clusterIdx, i) => clusterMap[clusterIdx] = i + 1);\n    for (let i = 0; i < clusters.length; i++)\n      clusters[i] = clusterMap[clusters[i]];\n    // let curCluster = 1;\n    // for (let i = 0; i < clusters.length; i++) {\n    //   if (!clusterMap[clusters[i]]) {\n    //     clusterMap[clusters[i]] = curCluster;\n    //     clusters[i] = curCluster;\n    //     curCluster++;\n    //   } else {\n    //     clusters[i] = clusterMap[clusters[i]];\n    //   }\n    // }\n  }\n\n  private async layout(clusters: number[], sparseMatrix: SparseMatrixObject, nRows: number) {\n    const embedX = new Float32Array(nRows).fill(0);\n    const embedY = new Float32Array(nRows).fill(0);\n    const clusterMap: {[_: number]: number[]} = {};\n    clusters.forEach((cluster, i) => {\n      if (!clusterMap[cluster])\n        clusterMap[cluster] = [];\n      clusterMap[cluster].push(i);\n    });\n    // const nClusters = Object.keys(clusterMap).length;\n    // const perRow = Math.floor(Math.sqrt(nClusters));\n    let clusterNum = 0;\n    const sortedClusterNames = Object.keys(clusterMap);\n    sortedClusterNames.sort((a, b) => clusterMap[b as any].length - clusterMap[a as any].length);\n    let perRow = 6;\n\n    let yOffset = 0;\n    const layoutSize = 5;\n    for (const clusterName of sortedClusterNames) {\n      const cluster = clusterMap[clusterName as any]!;\n      const embeddings = await bioLayout(cluster, sparseMatrix, 0.001);\n      if (clusterNum === Math.ceil(perRow / 1.5)) {\n        clusterNum = 0;\n        yOffset += layoutSize / perRow;\n        perRow = Math.ceil(perRow * 1.5);\n      }\n      const offsetX = ((clusterNum % perRow) * layoutSize / perRow) * 1.5;\n      // const offsetY = Math.floor(clusterNum / perRow) * 2;\n\n      for (let i = 0; i < embeddings.embedX.length; i++) {\n        embedX[cluster[i]] = embeddings.embedX[i] * layoutSize / perRow + offsetX;\n        embedY[cluster[i]] = embeddings.embedY[i] * layoutSize / perRow + yOffset;\n      }\n      clusterNum++;\n    }\n    return {embedX, embedY};\n  }\n\n  private mergeClusters(clusters: number[], i: number, j: number) {\n    const iCluster = clusters[i];\n    const jCluster = clusters[j];\n    for (let k = 0; k < clusters.length; k++) {\n      if (clusters[k] === jCluster)\n        clusters[k] = iCluster;\n    }\n  }\n  public assignClusters(sparseMatrix: SparseMatrixObject, nRows: number) {\n    let clusterNum = 0;\n    const is: number[] = [];\n    const js: number[] = [];\n    const order = Math.floor(Math.max(Math.log10(nRows), 2)) + 1;\n    const minOrder = Math.pow(10, order);\n    const clusters: number[] = new Array(nRows).fill(-1);\n    for (const i of Object.keys(sparseMatrix)) {\n      for (const j of Object.keys(sparseMatrix[i as any])) {\n        if (Math.round(sparseMatrix[i as any][j as any] * minOrder) / minOrder > 0 &&\n          sparseMatrix[i as any][j as any] !== Number(i) && Number(j) > Number(i)) {\n          is.push(Number(i));\n          js.push(Number(j));\n          if (clusters[Number(i)] !== -1 && clusters[Number(j)] !== -1) {\n            if (clusters[Number(i)] !== clusters[Number(j)])\n              this.mergeClusters(clusters, Number(i), Number(j));\n          } else if (clusters[Number(i)] !== -1) {\n            clusters[Number(j)] = clusters[Number(i)];\n          } else if (clusters[Number(j)] !== -1) {\n            clusters[Number(i)] = clusters[Number(j)];\n          } else {\n            clusterNum++;\n            clusters[Number(i)] = clusterNum;\n            clusters[Number(j)] = clusterNum;\n          }\n        }\n      }\n    }\n    for (let i=0; i < clusters.length; i++) {\n      if (clusters[i] === -1) {\n        clusterNum ++;\n        clusters[i] = clusterNum;\n      }\n    }\n    return {clusters, is, js};\n  }\n\n  public toObjectForm(sparseMatrix: SparseMatrixResult): SparseMatrixObject {\n    const sparseObject: {[_: number]: {[_: number]: number}} = {};\n    for (let i = 0; i < sparseMatrix.i.length; i++) {\n      if (!sparseObject[sparseMatrix.i[i]])\n        sparseObject[sparseMatrix.i[i]] = {};\n      sparseObject[sparseMatrix.i[i]][sparseMatrix.j[i]] = 1 - sparseMatrix.distance[i];\n      if (!sparseObject[sparseMatrix.j[i]])\n        sparseObject[sparseMatrix.j[i]] = {};\n      sparseObject[sparseMatrix.j[i]][sparseMatrix.i[i]] = 1 - sparseMatrix.distance[i];\n    }\n    return sparseObject;\n  }\n\n  private addLoops(sparseObject: SparseMatrixObject, nRows: number) {\n    for (let i = 0; i < nRows; i++) {\n      if (!sparseObject[i])\n        sparseObject[i] = {};\n      sparseObject[i][i] = this._options.multFactor;\n    }\n  }\n\n  private normalize(sparseObject: SparseMatrixObject) {\n    for (const i of Object.keys(sparseObject)) {\n      const row = sparseObject[i as any];\n      let sum = 0;\n      for (const j of Object.keys(row))\n        sum += row[j as any];\n      if (sum === 0) continue;\n      for (const j of Object.keys(row))\n        sparseObject[i as any][j as any] /= sum;\n    }\n  }\n\n  private expand(sparseObject: SparseMatrixObject, nRows: number) {\n    const expandedObject: SparseMatrixObject = {};\n    const order = Math.floor(Math.max(Math.log10(nRows), 2)) + 1;\n    const minOrder = Math.pow(10, order);\n    for (let i = 0; i < nRows; i++) {\n      if (!sparseObject[i])\n        continue;\n      // const row = sparseObject[i];\n      expandedObject[i] = {};\n      for (let j = i; j < nRows; j++) {\n        if (!sparseObject[i]?.[j])\n          continue;\n        const val = this.getExpandValue(sparseObject, i, j); //pruning step\n        if (Math.round(val * minOrder) / minOrder > 0) {\n          expandedObject[i][j] = val;\n          if (!expandedObject[j])\n            expandedObject[j] = {};\n          expandedObject[j][i] = val;\n        }\n      }\n    }\n    return expandedObject;\n  }\n\n  // private prune(row: SparseMatrixObject[number]) {\n\n  // }\n\n  private inflate(sparseObject: SparseMatrixObject) {\n    for (const i of Object.keys(sparseObject)) {\n      const row = sparseObject[i as any];\n      for (const j of Object.keys(row))\n        sparseObject[i as any][j as any] = Math.pow(sparseObject[i as any][j as any], this._options.inflateFactor);\n    }\n  }\n\n  private getExpandValue(sparseObject: SparseMatrixObject, i: any, j: any) {\n    let val = 0;\n    const currentIndexes = Object.keys(sparseObject[i] ?? {});\n    const otherIndexes = Object.keys(sparseObject[j] ?? {});\n    for (const k of currentIndexes) {\n      if (otherIndexes.includes(k))\n        val += sparseObject[i][k as any] * sparseObject[j][k as any];\n    }\n    return val;\n  }\n}\n\n"]}","import { SparseMatrixService } from '../distance-matrix/sparse-matrix-service';\nimport { MCLSparseReducer } from './marcov-cluster';\nonmessage = async (event) => {\n const { data, threshold, weights, aggregationMethod, distanceFnArgs, distanceFns, maxIterations } = event.data;\n const sparse = await new SparseMatrixService()\n .calcMultiColumn(data, distanceFns, threshold / 100, distanceFnArgs, weights, aggregationMethod);\n const res = await new MCLSparseReducer({ maxIterations: maxIterations ?? 5 }).transform(sparse, data[0].length);\n postMessage({ res });\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWNsLXdvcmtlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm1jbC13b3JrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFHN0UsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFFbEQsU0FBUyxHQUFHLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRTtJQUMxQixNQUFNLEVBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsY0FBYyxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUMsR0FHaEIsS0FBSyxDQUFDLElBQUksQ0FBQztJQUMxRixNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksbUJBQW1CLEVBQUU7U0FDM0MsZUFBZSxDQUFDLElBQUksRUFBRSxXQUFXLEVBQUUsU0FBUyxHQUFHLEdBQUcsRUFBRSxjQUFjLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixDQUFDLENBQUM7SUFDbkcsTUFBTSxHQUFHLEdBQUcsTUFBTSxJQUFJLGdCQUFnQixDQUFDLEVBQUMsYUFBYSxFQUFFLGFBQWEsSUFBSSxDQUFDLEVBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzlHLFdBQVcsQ0FBQyxFQUFDLEdBQUcsRUFBQyxDQUFDLENBQUM7QUFDckIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtTcGFyc2VNYXRyaXhTZXJ2aWNlfSBmcm9tICcuLi9kaXN0YW5jZS1tYXRyaXgvc3BhcnNlLW1hdHJpeC1zZXJ2aWNlJztcbmltcG9ydCB7RGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZH0gZnJvbSAnLi4vZGlzdGFuY2UtbWF0cml4L3R5cGVzJztcbmltcG9ydCB7S25vd25NZXRyaWNzfSBmcm9tICcuLi90eXBlZC1tZXRyaWNzJztcbmltcG9ydCB7TUNMU3BhcnNlUmVkdWNlcn0gZnJvbSAnLi9tYXJjb3YtY2x1c3Rlcic7XG5cbm9ubWVzc2FnZSA9IGFzeW5jIChldmVudCkgPT4ge1xuICBjb25zdCB7ZGF0YSwgdGhyZXNob2xkLCB3ZWlnaHRzLCBhZ2dyZWdhdGlvbk1ldGhvZCwgZGlzdGFuY2VGbkFyZ3MsIGRpc3RhbmNlRm5zLCBtYXhJdGVyYXRpb25zfTpcbiAgIHtkYXRhOiBhbnlbXVtdLCB0aHJlc2hvbGQ6IG51bWJlcixcbiAgICB3ZWlnaHRzOiBudW1iZXJbXSwgYWdncmVnYXRpb25NZXRob2Q6IERpc3RhbmNlQWdncmVnYXRpb25NZXRob2QsXG4gICAgZGlzdGFuY2VGbnM6IEtub3duTWV0cmljc1tdLCBkaXN0YW5jZUZuQXJnczogYW55W10sIG1heEl0ZXJhdGlvbnM6IG51bWJlcn0gPSBldmVudC5kYXRhO1xuICBjb25zdCBzcGFyc2UgPSBhd2FpdCBuZXcgU3BhcnNlTWF0cml4U2VydmljZSgpXG4gICAgLmNhbGNNdWx0aUNvbHVtbihkYXRhLCBkaXN0YW5jZUZucywgdGhyZXNob2xkIC8gMTAwLCBkaXN0YW5jZUZuQXJncywgd2VpZ2h0cywgYWdncmVnYXRpb25NZXRob2QpO1xuICBjb25zdCByZXMgPSBhd2FpdCBuZXcgTUNMU3BhcnNlUmVkdWNlcih7bWF4SXRlcmF0aW9uczogbWF4SXRlcmF0aW9ucyA/PyA1fSkudHJhbnNmb3JtKHNwYXJzZSwgZGF0YVswXS5sZW5ndGgpO1xuICBwb3N0TWVzc2FnZSh7cmVzfSk7XG59O1xuIl19","import { DistanceAggregationMethods } from './types';\nexport const isNil = (x) => x === null || x === undefined;\nexport function insertSmaller(distancesAr, indexes, num, index) {\n if (num > distancesAr[distancesAr.length - 1])\n return;\n const newPosition = distancesAr.findIndex((v) => num < v);\n distancesAr.pop();\n distancesAr.splice(newPosition, 0, num);\n indexes.pop();\n indexes.splice(newPosition, 0, index);\n}\nexport function insertLarger(distancesAr, indexes, num, index) {\n if (num < distancesAr[distancesAr.length - 1])\n return;\n const newPosition = distancesAr.findIndex((v) => num > v);\n distancesAr.pop();\n distancesAr.splice(newPosition, 0, num);\n indexes.pop();\n indexes.splice(newPosition, 0, index);\n}\nexport function getAggregationFunction(aggregationMethod, weights) {\n switch (aggregationMethod) {\n case DistanceAggregationMethods.MANHATTAN:\n return (vs) => vs.reduce((acc, val, idx) => acc + val * weights[idx], 0);\n default:\n return (vs) => {\n // euclidean\n const sum = vs.reduce((acc, val, idx) => acc + (val * weights[idx]) ** 2, 0);\n return Math.sqrt(sum);\n };\n }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTRCLDBCQUEwQixFQUFDLE1BQU0sU0FBUyxDQUFDO0FBRTlFLE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBRyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLEtBQUssU0FBUyxDQUFDO0FBRS9ELE1BQU0sVUFBVSxhQUFhLENBQUMsV0FBcUIsRUFBRSxPQUFpQixFQUFFLEdBQVcsRUFBRSxLQUFhO0lBQ2hHLElBQUksR0FBRyxHQUFHLFdBQVcsQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFDLENBQUMsQ0FBQztRQUN6QyxPQUFPO0lBRVQsTUFBTSxXQUFXLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzFELFdBQVcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNsQixXQUFXLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFBRSxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDeEMsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ2QsT0FBTyxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBQ3hDLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLFdBQXFCLEVBQUUsT0FBaUIsRUFBRSxHQUFXLEVBQUUsS0FBYTtJQUMvRixJQUFJLEdBQUcsR0FBRyxXQUFXLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBQyxDQUFDLENBQUM7UUFDekMsT0FBTztJQUVULE1BQU0sV0FBVyxHQUFHLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMxRCxXQUFXLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDbEIsV0FBVyxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNkLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztBQUN4QyxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUNwQyxpQkFBNEMsRUFBRSxPQUFpQjtJQUUvRCxRQUFRLGlCQUFpQixFQUFFO1FBQ3pCLEtBQUssMEJBQTBCLENBQUMsU0FBUztZQUN2QyxPQUFPLENBQUMsRUFBWSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3JGO1lBQ0UsT0FBTyxDQUFDLEVBQVksRUFBRSxFQUFFO2dCQUN0QixZQUFZO2dCQUNaLE1BQU0sR0FBRyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztnQkFDN0UsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3hCLENBQUMsQ0FBQztLQUNMO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZCwgRGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZHN9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgaXNOaWwgPSAoeDogYW55KSA9PiB4ID09PSBudWxsIHx8IHggPT09IHVuZGVmaW5lZDtcblxuZXhwb3J0IGZ1bmN0aW9uIGluc2VydFNtYWxsZXIoZGlzdGFuY2VzQXI6IG51bWJlcltdLCBpbmRleGVzOiBudW1iZXJbXSwgbnVtOiBudW1iZXIsIGluZGV4OiBudW1iZXIpIHtcbiAgaWYgKG51bSA+IGRpc3RhbmNlc0FyW2Rpc3RhbmNlc0FyLmxlbmd0aC0xXSlcbiAgICByZXR1cm47XG5cbiAgY29uc3QgbmV3UG9zaXRpb24gPSBkaXN0YW5jZXNBci5maW5kSW5kZXgoKHYpID0+IG51bSA8IHYpO1xuICBkaXN0YW5jZXNBci5wb3AoKTtcbiAgZGlzdGFuY2VzQXIuc3BsaWNlKG5ld1Bvc2l0aW9uLCAwLCBudW0pO1xuICBpbmRleGVzLnBvcCgpO1xuICBpbmRleGVzLnNwbGljZShuZXdQb3NpdGlvbiwgMCwgaW5kZXgpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW5zZXJ0TGFyZ2VyKGRpc3RhbmNlc0FyOiBudW1iZXJbXSwgaW5kZXhlczogbnVtYmVyW10sIG51bTogbnVtYmVyLCBpbmRleDogbnVtYmVyKSB7XG4gIGlmIChudW0gPCBkaXN0YW5jZXNBcltkaXN0YW5jZXNBci5sZW5ndGgtMV0pXG4gICAgcmV0dXJuO1xuXG4gIGNvbnN0IG5ld1Bvc2l0aW9uID0gZGlzdGFuY2VzQXIuZmluZEluZGV4KCh2KSA9PiBudW0gPiB2KTtcbiAgZGlzdGFuY2VzQXIucG9wKCk7XG4gIGRpc3RhbmNlc0FyLnNwbGljZShuZXdQb3NpdGlvbiwgMCwgbnVtKTtcbiAgaW5kZXhlcy5wb3AoKTtcbiAgaW5kZXhlcy5zcGxpY2UobmV3UG9zaXRpb24sIDAsIGluZGV4KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFnZ3JlZ2F0aW9uRnVuY3Rpb24oXG4gIGFnZ3JlZ2F0aW9uTWV0aG9kOiBEaXN0YW5jZUFnZ3JlZ2F0aW9uTWV0aG9kLCB3ZWlnaHRzOiBudW1iZXJbXVxuKTogKHZhbHVlczogbnVtYmVyW10pID0+IG51bWJlciB7XG4gIHN3aXRjaCAoYWdncmVnYXRpb25NZXRob2QpIHtcbiAgICBjYXNlIERpc3RhbmNlQWdncmVnYXRpb25NZXRob2RzLk1BTkhBVFRBTjpcbiAgICAgIHJldHVybiAodnM6IG51bWJlcltdKSA9PiB2cy5yZWR1Y2UoKGFjYywgdmFsLCBpZHgpID0+IGFjYyArIHZhbCAqIHdlaWdodHNbaWR4XSwgMCk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiAodnM6IG51bWJlcltdKSA9PiB7XG4gICAgICAgIC8vIGV1Y2xpZGVhblxuICAgICAgICBjb25zdCBzdW0gPSB2cy5yZWR1Y2UoKGFjYywgdmFsLCBpZHgpID0+IGFjYyArICh2YWwgKiB3ZWlnaHRzW2lkeF0pICoqIDIsIDApO1xuICAgICAgICByZXR1cm4gTWF0aC5zcXJ0KHN1bSk7XG4gICAgICB9O1xuICB9XG59XG4iXX0=","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n// the startup function\n__webpack_require__.x = () => {\n\t// Load entry module and return exports\n\t// This entry module depends on other loaded chunks and execution need to be delayed\n\tvar __webpack_exports__ = __webpack_require__.O(undefined, [590], () => (__webpack_require__(2357)))\n\t__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n\treturn __webpack_exports__;\n};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks and sibling chunks for the entrypoint\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + chunkId + \".js\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = self.location + \"\";\n\n// object to store loaded chunks\n// \"1\" means \"already loaded\"\nvar installedChunks = {\n\t709: 1\n};\n\n// importScripts chunk loading\nvar installChunk = (data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\tfor(var moduleId in moreModules) {\n\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t}\n\t}\n\tif(runtime) runtime(__webpack_require__);\n\twhile(chunkIds.length)\n\t\tinstalledChunks[chunkIds.pop()] = 1;\n\tparentChunkLoadingFunction(data);\n};\n__webpack_require__.f.i = (chunkId, promises) => {\n\t// \"1\" is the signal for \"already loaded\"\n\tif(!installedChunks[chunkId]) {\n\t\tif(true) { // all chunks have JS\n\t\t\timportScripts(__webpack_require__.p + __webpack_require__.u(chunkId));\n\t\t}\n\t}\n};\n\nvar chunkLoadingGlobal = self[\"webpackChunkbio\"] = self[\"webpackChunkbio\"] || [];\nvar parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);\nchunkLoadingGlobal.push = installChunk;\n\n// no HMR\n\n// no HMR manifest","// run startup\nvar __webpack_exports__ = __webpack_require__.x();\n"],"names":["deferred","next","async","bioLayout","cluster","sparseObject","threshold","n","length","is","js","i","j","a","b","push","embedX","Float32Array","fill","map","Math","random","embedY","xVelocities","yVelocities","temperature","idx","dx","dy","abs","vecSize","sqrt","minX","minY","maxX","maxY","min","max","rangeX","rangeY","getLayoutEmbeddings","defaultMCLOptions","expandFactor","maxIterations","inflateFactor","multFactor","MCLSparseReducer","constructor","opts","this","_options","sparseMatrix","nRows","toObjectForm","addLoops","normalize","expand","inflate","clusters","assignClusters","correctClusters","embeddings","layout","clusterSizeMap","sortedIndexes","Object","keys","Number","sort","clusterMap","forEach","clusterIdx","clusterNum","sortedClusterNames","perRow","yOffset","clusterName","ceil","offsetX","mergeClusters","iCluster","jCluster","k","order","floor","log10","minOrder","pow","Array","round","distance","row","sum","expandedObject","val","getExpandValue","currentIndexes","otherIndexes","includes","onmessage","event","data","weights","aggregationMethod","distanceFnArgs","distanceFns","sparse","calcMultiColumn","res","transform","postMessage","isNil","x","insertSmaller","distancesAr","indexes","num","index","newPosition","findIndex","v","pop","splice","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","exports","module","__webpack_modules__","m","__webpack_exports__","O","result","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","every","key","r","d","definition","o","defineProperty","enumerable","get","f","e","chunkId","Promise","all","reduce","promises","u","g","globalThis","Function","window","obj","prop","prototype","hasOwnProperty","call","scriptUrl","importScripts","location","document","currentScript","src","scripts","getElementsByTagName","Error","replace","p","self","installedChunks","chunkLoadingGlobal","parentChunkLoadingFunction","bind","moreModules","runtime","then"],"sourceRoot":""}
1
+ {"version":3,"file":"709.js","mappings":"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","sources":["webpack://bio/webpack/runtime/chunk loaded","webpack://bio/webpack/runtime/startup chunk dependencies","webpack://bio/./node_modules/@datagrok-libraries/ml/src/MCL/bio-layout.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/MCL/marcov-cluster.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/MCL/mcl-worker.js","webpack://bio/./node_modules/@datagrok-libraries/ml/src/distance-matrix/utils.js","webpack://bio/webpack/bootstrap","webpack://bio/webpack/runtime/define property getters","webpack://bio/webpack/runtime/ensure chunk","webpack://bio/webpack/runtime/get javascript chunk filename","webpack://bio/webpack/runtime/global","webpack://bio/webpack/runtime/hasOwnProperty shorthand","webpack://bio/webpack/runtime/publicPath","webpack://bio/webpack/runtime/importScripts chunk loading","webpack://bio/webpack/startup"],"sourcesContent":["var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","var next = __webpack_require__.x;\n__webpack_require__.x = () => {\n\treturn __webpack_require__.e(590).then(next);\n};","export async function bioLayout(cluster, sparseObject, threshold) {\n const n = cluster.length;\n const is = [];\n const js = [];\n for (let i = 0; i < n; i++) {\n for (let j = i + 1; j < n; j++) {\n const a = cluster[i];\n const b = cluster[j];\n if (sparseObject[a]?.[b] >= threshold) {\n is.push(i);\n js.push(j);\n }\n }\n }\n return getLayoutEmbeddings(is, js, cluster);\n}\nfunction getLayoutEmbeddings(is, js, cluster) {\n const embedX = new Float32Array(cluster.length).fill(0).map(() => Math.random() * 10);\n const embedY = new Float32Array(cluster.length).fill(0).map(() => Math.random() * 10);\n const iterations = 100;\n const xVelocities = new Float32Array(cluster.length).fill(0);\n const yVelocities = new Float32Array(cluster.length).fill(0);\n for (let i = 0; i < iterations; i++) {\n const temperature = (1 - i / iterations);\n xVelocities.fill(0);\n yVelocities.fill(0);\n for (let idx = 0; idx < is.length; idx++) {\n const a = is[idx];\n const b = js[idx];\n const dx = embedX[a] - embedX[b];\n const dy = embedY[a] - embedY[b];\n // const distance = Math.sqrt(dx * dx + dy * dy);\n // const factor = (distance - 1) / distance;\n // const offsetX = dx * factor;\n // const offsetY = dy * factor;\n if (Math.abs(dx) >= 1) {\n xVelocities[a] -= temperature * dx;\n xVelocities[b] += temperature * dx;\n }\n if (Math.abs(dy) >= 1) {\n yVelocities[a] -= temperature * dy;\n yVelocities[b] += temperature * dy;\n }\n // embedY[a] += offsetY * temperature;\n // embedY[b] -= offsetY * temperature;\n }\n for (let idx = 0; idx < cluster.length; idx++) {\n const vecSize = Math.sqrt(xVelocities[idx] * xVelocities[idx] + yVelocities[idx] * yVelocities[idx]);\n if (vecSize > 0) {\n embedX[idx] += xVelocities[idx] / vecSize * temperature;\n embedY[idx] += yVelocities[idx] / vecSize * temperature;\n }\n }\n }\n // normalize\n let minX = embedX[0];\n let minY = embedY[0];\n let maxX = embedX[0];\n let maxY = embedY[0];\n for (let idx = 1; idx < cluster.length; idx++) {\n minX = Math.min(minX, embedX[idx]);\n minY = Math.min(minY, embedY[idx]);\n maxX = Math.max(maxX, embedX[idx]);\n maxY = Math.max(maxY, embedY[idx]);\n }\n let rangeX = maxX - minX;\n let rangeY = maxY - minY;\n if (rangeX === 0)\n rangeX = maxX;\n for (let idx = 0; idx < cluster.length; idx++)\n embedX[idx] = (embedX[idx] - minX) / rangeX / 2 + 0.5;\n if (rangeY === 0)\n rangeY = maxY;\n for (let idx = 0; idx < cluster.length; idx++)\n embedY[idx] = (embedY[idx] - minY) / rangeY / 2 + 0.5;\n return { embedX, embedY };\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bio-layout.js","sourceRoot":"","sources":["bio-layout.ts"],"names":[],"mappings":"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","sourcesContent":["import {SparseMatrixObject} from './types';\n\nexport async function bioLayout(cluster: number[], sparseObject: SparseMatrixObject, threshold: number) {\n  const n = cluster.length;\n  const is: number[] = [];\n  const js: number[] = [];\n  for (let i = 0; i < n; i++) {\n    for (let j = i + 1; j < n; j++) {\n      const a = cluster[i];\n      const b = cluster[j];\n      if (sparseObject[a]?.[b] >= threshold) {\n        is.push(i);\n        js.push(j);\n      }\n    }\n  }\n  return getLayoutEmbeddings(is, js, cluster);\n}\n\nfunction getLayoutEmbeddings(is: number[], js: number[], cluster: number[]) {\n  const embedX = new Float32Array(cluster.length).fill(0).map(() => Math.random() * 10);\n  const embedY = new Float32Array(cluster.length).fill(0).map(() => Math.random() * 10);\n  const iterations = 100;\n  const xVelocities = new Float32Array(cluster.length).fill(0);\n  const yVelocities = new Float32Array(cluster.length).fill(0);\n  for (let i = 0; i < iterations; i++) {\n    const temperature = (1 - i / iterations);\n    xVelocities.fill(0);\n    yVelocities.fill(0);\n    for (let idx = 0; idx < is.length; idx++) {\n      const a = is[idx];\n      const b = js[idx];\n      const dx = embedX[a] - embedX[b];\n      const dy = embedY[a] - embedY[b];\n      //   const distance = Math.sqrt(dx * dx + dy * dy);\n      //   const factor = (distance - 1) / distance;\n      //   const offsetX = dx * factor;\n      //   const offsetY = dy * factor;\n      if (Math.abs(dx) >= 1) {\n        xVelocities[a] -= temperature * dx;\n        xVelocities[b] += temperature * dx;\n      }\n      if (Math.abs(dy) >= 1) {\n        yVelocities[a] -= temperature * dy;\n        yVelocities[b] += temperature * dy;\n      }\n    //   embedY[a] += offsetY * temperature;\n    //   embedY[b] -= offsetY * temperature;\n    }\n    for (let idx = 0; idx < cluster.length; idx++) {\n      const vecSize = Math.sqrt(xVelocities[idx] * xVelocities[idx] + yVelocities[idx] * yVelocities[idx]);\n      if (vecSize > 0) {\n        embedX[idx] += xVelocities[idx] / vecSize * temperature;\n        embedY[idx] += yVelocities[idx] / vecSize * temperature;\n      }\n    }\n  }\n\n  // normalize\n  let minX = embedX[0];\n  let minY = embedY[0];\n  let maxX = embedX[0];\n  let maxY = embedY[0];\n  for (let idx = 1; idx < cluster.length; idx++) {\n    minX = Math.min(minX, embedX[idx]);\n    minY = Math.min(minY, embedY[idx]);\n    maxX = Math.max(maxX, embedX[idx]);\n    maxY = Math.max(maxY, embedY[idx]);\n  }\n  let rangeX = maxX - minX;\n  let rangeY = maxY - minY;\n  if (rangeX === 0)\n    rangeX = maxX;\n  for (let idx = 0; idx < cluster.length; idx++)\n    embedX[idx] = (embedX[idx] - minX) / rangeX / 2 + 0.5;\n  if (rangeY === 0)\n    rangeY = maxY;\n  for (let idx = 0; idx < cluster.length; idx++)\n    embedY[idx] = (embedY[idx] - minY) / rangeY / 2 + 0.5;\n\n  return {embedX, embedY};\n}\n"]}","import { bioLayout } from './bio-layout';\nexport const defaultMCLOptions = {\n expandFactor: 2,\n maxIterations: 5,\n inflateFactor: 2,\n multFactor: 1,\n};\nexport class MCLSparseReducer {\n constructor(opts = {}) {\n this._options = { ...defaultMCLOptions, ...opts };\n }\n async transform(sparseMatrix, nRows) {\n // testWorkerMultiply();\n // return new Int32Array(nRows);\n let sparseObject = this.toObjectForm(sparseMatrix);\n if (this._options.maxIterations > 0) {\n this.addLoops(sparseObject, nRows);\n this.normalize(sparseObject);\n for (let i = 0; i < this._options.maxIterations; i++) {\n sparseObject = this.expand(sparseObject, nRows);\n this.inflate(sparseObject);\n this.normalize(sparseObject);\n }\n }\n const { clusters, is, js } = this.assignClusters(sparseObject, nRows);\n this.correctClusters(clusters);\n const embeddings = await this.layout(clusters, sparseObject, nRows);\n return { clusters, embedX: embeddings.embedX, embedY: embeddings.embedY, is, js };\n }\n correctClusters(clusters) {\n const clusterSizeMap = {};\n for (const cluster of clusters) {\n if (!clusterSizeMap[cluster])\n clusterSizeMap[cluster] = 0;\n clusterSizeMap[cluster]++;\n }\n const sortedIndexes = Object.keys(clusterSizeMap).map(Number).sort((a, b) => clusterSizeMap[a] - clusterSizeMap[b]);\n const clusterMap = {};\n sortedIndexes.forEach((clusterIdx, i) => clusterMap[clusterIdx] = i + 1);\n for (let i = 0; i < clusters.length; i++)\n clusters[i] = clusterMap[clusters[i]];\n // let curCluster = 1;\n // for (let i = 0; i < clusters.length; i++) {\n // if (!clusterMap[clusters[i]]) {\n // clusterMap[clusters[i]] = curCluster;\n // clusters[i] = curCluster;\n // curCluster++;\n // } else {\n // clusters[i] = clusterMap[clusters[i]];\n // }\n // }\n }\n async layout(clusters, sparseMatrix, nRows) {\n const embedX = new Float32Array(nRows).fill(0);\n const embedY = new Float32Array(nRows).fill(0);\n const clusterMap = {};\n clusters.forEach((cluster, i) => {\n if (!clusterMap[cluster])\n clusterMap[cluster] = [];\n clusterMap[cluster].push(i);\n });\n // const nClusters = Object.keys(clusterMap).length;\n // const perRow = Math.floor(Math.sqrt(nClusters));\n let clusterNum = 0;\n const sortedClusterNames = Object.keys(clusterMap);\n sortedClusterNames.sort((a, b) => clusterMap[b].length - clusterMap[a].length);\n let perRow = 6;\n let yOffset = 0;\n const layoutSize = 5;\n for (const clusterName of sortedClusterNames) {\n const cluster = clusterMap[clusterName];\n const embeddings = await bioLayout(cluster, sparseMatrix, 0.001);\n if (clusterNum === Math.ceil(perRow / 1.5)) {\n clusterNum = 0;\n yOffset += layoutSize / perRow;\n perRow = Math.ceil(perRow * 1.5);\n }\n const offsetX = ((clusterNum % perRow) * layoutSize / perRow) * 1.5;\n // const offsetY = Math.floor(clusterNum / perRow) * 2;\n for (let i = 0; i < embeddings.embedX.length; i++) {\n embedX[cluster[i]] = embeddings.embedX[i] * layoutSize / perRow + offsetX;\n embedY[cluster[i]] = embeddings.embedY[i] * layoutSize / perRow + yOffset;\n }\n clusterNum++;\n }\n return { embedX, embedY };\n }\n mergeClusters(clusters, i, j) {\n const iCluster = clusters[i];\n const jCluster = clusters[j];\n for (let k = 0; k < clusters.length; k++) {\n if (clusters[k] === jCluster)\n clusters[k] = iCluster;\n }\n }\n assignClusters(sparseMatrix, nRows) {\n let clusterNum = 0;\n const is = [];\n const js = [];\n const order = Math.floor(Math.max(Math.log10(nRows), 2)) + 1;\n const minOrder = Math.pow(10, order);\n const clusters = new Array(nRows).fill(-1);\n for (const i of Object.keys(sparseMatrix)) {\n for (const j of Object.keys(sparseMatrix[i])) {\n if (Math.round(sparseMatrix[i][j] * minOrder) / minOrder > 0 &&\n sparseMatrix[i][j] !== Number(i) && Number(j) > Number(i)) {\n is.push(Number(i));\n js.push(Number(j));\n if (clusters[Number(i)] !== -1 && clusters[Number(j)] !== -1) {\n if (clusters[Number(i)] !== clusters[Number(j)])\n this.mergeClusters(clusters, Number(i), Number(j));\n }\n else if (clusters[Number(i)] !== -1) {\n clusters[Number(j)] = clusters[Number(i)];\n }\n else if (clusters[Number(j)] !== -1) {\n clusters[Number(i)] = clusters[Number(j)];\n }\n else {\n clusterNum++;\n clusters[Number(i)] = clusterNum;\n clusters[Number(j)] = clusterNum;\n }\n }\n }\n }\n for (let i = 0; i < clusters.length; i++) {\n if (clusters[i] === -1) {\n clusterNum++;\n clusters[i] = clusterNum;\n }\n }\n return { clusters, is: new Uint32Array(is), js: new Uint32Array(js) };\n }\n toObjectForm(sparseMatrix) {\n const sparseObject = {};\n for (let i = 0; i < sparseMatrix.i.length; i++) {\n if (!sparseObject[sparseMatrix.i[i]])\n sparseObject[sparseMatrix.i[i]] = {};\n sparseObject[sparseMatrix.i[i]][sparseMatrix.j[i]] = 1 - sparseMatrix.distance[i];\n if (!sparseObject[sparseMatrix.j[i]])\n sparseObject[sparseMatrix.j[i]] = {};\n sparseObject[sparseMatrix.j[i]][sparseMatrix.i[i]] = 1 - sparseMatrix.distance[i];\n }\n return sparseObject;\n }\n addLoops(sparseObject, nRows) {\n for (let i = 0; i < nRows; i++) {\n if (!sparseObject[i])\n sparseObject[i] = {};\n sparseObject[i][i] = this._options.multFactor;\n }\n }\n normalize(sparseObject) {\n for (const i of Object.keys(sparseObject)) {\n const row = sparseObject[i];\n let sum = 0;\n for (const j of Object.keys(row))\n sum += row[j];\n if (sum === 0)\n continue;\n for (const j of Object.keys(row))\n sparseObject[i][j] /= sum;\n }\n }\n expand(sparseObject, nRows) {\n const expandedObject = {};\n const order = Math.floor(Math.max(Math.log10(nRows), 2)) + 1;\n const minOrder = Math.pow(10, order);\n for (let i = 0; i < nRows; i++) {\n if (!sparseObject[i])\n continue;\n // const row = sparseObject[i];\n expandedObject[i] = {};\n for (let j = i; j < nRows; j++) {\n if (!sparseObject[i]?.[j])\n continue;\n const val = this.getExpandValue(sparseObject, i, j); //pruning step\n if (Math.round(val * minOrder) / minOrder > 0) {\n expandedObject[i][j] = val;\n if (!expandedObject[j])\n expandedObject[j] = {};\n expandedObject[j][i] = val;\n }\n }\n }\n return expandedObject;\n }\n // private prune(row: SparseMatrixObject[number]) {\n // }\n inflate(sparseObject) {\n for (const i of Object.keys(sparseObject)) {\n const row = sparseObject[i];\n for (const j of Object.keys(row))\n sparseObject[i][j] = Math.pow(sparseObject[i][j], this._options.inflateFactor);\n }\n }\n getExpandValue(sparseObject, i, j) {\n let val = 0;\n const currentIndexes = Object.keys(sparseObject[i] ?? {});\n const otherIndexes = Object.keys(sparseObject[j] ?? {});\n for (const k of currentIndexes) {\n if (otherIndexes.includes(k))\n val += sparseObject[i][k] * sparseObject[j][k];\n }\n return val;\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"marcov-cluster.js","sourceRoot":"","sources":["marcov-cluster.ts"],"names":[],"mappings":"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","sourcesContent":["import {SparseMatrixResult} from '../distance-matrix/sparse-matrix-service';\nimport {bioLayout} from './bio-layout';\nimport {MCLOptions, SparseMatrixObject} from './types';\n\nexport const defaultMCLOptions: MCLOptions = {\n  expandFactor: 2,\n  maxIterations: 5,\n  inflateFactor: 2,\n  multFactor: 1,\n};\n\nexport class MCLSparseReducer {\n  private _options: MCLOptions;\n\n  constructor(opts: Partial<MCLOptions> = {}) {\n    this._options = {...defaultMCLOptions, ...opts};\n  }\n\n  public async transform(sparseMatrix: SparseMatrixResult, nRows: number) {\n    // testWorkerMultiply();\n    // return new Int32Array(nRows);\n    let sparseObject = this.toObjectForm(sparseMatrix);\n    if (this._options.maxIterations > 0) {\n      this.addLoops(sparseObject, nRows);\n      this.normalize(sparseObject);\n      for (let i = 0; i < this._options.maxIterations; i++) {\n        sparseObject = this.expand(sparseObject, nRows);\n        this.inflate(sparseObject);\n        this.normalize(sparseObject);\n      }\n    }\n    const {clusters, is, js} = this.assignClusters(sparseObject, nRows);\n    this.correctClusters(clusters);\n    const embeddings = await this.layout(clusters, sparseObject, nRows);\n    return {clusters, embedX: embeddings.embedX, embedY: embeddings.embedY, is, js};\n  }\n\n  private correctClusters(clusters: number[]) {\n    const clusterSizeMap: {[_: number]: number} = {};\n    for (const cluster of clusters) {\n      if (!clusterSizeMap[cluster])\n        clusterSizeMap[cluster] = 0;\n      clusterSizeMap[cluster]++;\n    }\n    const sortedIndexes = Object.keys(clusterSizeMap).map(Number).sort((a, b) => clusterSizeMap[a] - clusterSizeMap[b]);\n    const clusterMap: {[_: number]: number} = {};\n    sortedIndexes.forEach((clusterIdx, i) => clusterMap[clusterIdx] = i + 1);\n    for (let i = 0; i < clusters.length; i++)\n      clusters[i] = clusterMap[clusters[i]];\n    // let curCluster = 1;\n    // for (let i = 0; i < clusters.length; i++) {\n    //   if (!clusterMap[clusters[i]]) {\n    //     clusterMap[clusters[i]] = curCluster;\n    //     clusters[i] = curCluster;\n    //     curCluster++;\n    //   } else {\n    //     clusters[i] = clusterMap[clusters[i]];\n    //   }\n    // }\n  }\n\n  private async layout(clusters: number[], sparseMatrix: SparseMatrixObject, nRows: number) {\n    const embedX = new Float32Array(nRows).fill(0);\n    const embedY = new Float32Array(nRows).fill(0);\n    const clusterMap: {[_: number]: number[]} = {};\n    clusters.forEach((cluster, i) => {\n      if (!clusterMap[cluster])\n        clusterMap[cluster] = [];\n      clusterMap[cluster].push(i);\n    });\n    // const nClusters = Object.keys(clusterMap).length;\n    // const perRow = Math.floor(Math.sqrt(nClusters));\n    let clusterNum = 0;\n    const sortedClusterNames = Object.keys(clusterMap);\n    sortedClusterNames.sort((a, b) => clusterMap[b as any].length - clusterMap[a as any].length);\n    let perRow = 6;\n\n    let yOffset = 0;\n    const layoutSize = 5;\n    for (const clusterName of sortedClusterNames) {\n      const cluster = clusterMap[clusterName as any]!;\n      const embeddings = await bioLayout(cluster, sparseMatrix, 0.001);\n      if (clusterNum === Math.ceil(perRow / 1.5)) {\n        clusterNum = 0;\n        yOffset += layoutSize / perRow;\n        perRow = Math.ceil(perRow * 1.5);\n      }\n      const offsetX = ((clusterNum % perRow) * layoutSize / perRow) * 1.5;\n      // const offsetY = Math.floor(clusterNum / perRow) * 2;\n\n      for (let i = 0; i < embeddings.embedX.length; i++) {\n        embedX[cluster[i]] = embeddings.embedX[i] * layoutSize / perRow + offsetX;\n        embedY[cluster[i]] = embeddings.embedY[i] * layoutSize / perRow + yOffset;\n      }\n      clusterNum++;\n    }\n    return {embedX, embedY};\n  }\n\n  private mergeClusters(clusters: number[], i: number, j: number) {\n    const iCluster = clusters[i];\n    const jCluster = clusters[j];\n    for (let k = 0; k < clusters.length; k++) {\n      if (clusters[k] === jCluster)\n        clusters[k] = iCluster;\n    }\n  }\n  public assignClusters(sparseMatrix: SparseMatrixObject, nRows: number) {\n    let clusterNum = 0;\n    const is: number[] = [];\n    const js: number[] = [];\n    const order = Math.floor(Math.max(Math.log10(nRows), 2)) + 1;\n    const minOrder = Math.pow(10, order);\n    const clusters: number[] = new Array(nRows).fill(-1);\n    for (const i of Object.keys(sparseMatrix)) {\n      for (const j of Object.keys(sparseMatrix[i as any])) {\n        if (Math.round(sparseMatrix[i as any][j as any] * minOrder) / minOrder > 0 &&\n          sparseMatrix[i as any][j as any] !== Number(i) && Number(j) > Number(i)) {\n          is.push(Number(i));\n          js.push(Number(j));\n          if (clusters[Number(i)] !== -1 && clusters[Number(j)] !== -1) {\n            if (clusters[Number(i)] !== clusters[Number(j)])\n              this.mergeClusters(clusters, Number(i), Number(j));\n          } else if (clusters[Number(i)] !== -1) {\n            clusters[Number(j)] = clusters[Number(i)];\n          } else if (clusters[Number(j)] !== -1) {\n            clusters[Number(i)] = clusters[Number(j)];\n          } else {\n            clusterNum++;\n            clusters[Number(i)] = clusterNum;\n            clusters[Number(j)] = clusterNum;\n          }\n        }\n      }\n    }\n    for (let i=0; i < clusters.length; i++) {\n      if (clusters[i] === -1) {\n        clusterNum ++;\n        clusters[i] = clusterNum;\n      }\n    }\n    return {clusters, is: new Uint32Array(is), js: new Uint32Array(js)};\n  }\n\n  public toObjectForm(sparseMatrix: SparseMatrixResult): SparseMatrixObject {\n    const sparseObject: {[_: number]: {[_: number]: number}} = {};\n    for (let i = 0; i < sparseMatrix.i.length; i++) {\n      if (!sparseObject[sparseMatrix.i[i]])\n        sparseObject[sparseMatrix.i[i]] = {};\n      sparseObject[sparseMatrix.i[i]][sparseMatrix.j[i]] = 1 - sparseMatrix.distance[i];\n      if (!sparseObject[sparseMatrix.j[i]])\n        sparseObject[sparseMatrix.j[i]] = {};\n      sparseObject[sparseMatrix.j[i]][sparseMatrix.i[i]] = 1 - sparseMatrix.distance[i];\n    }\n    return sparseObject;\n  }\n\n  private addLoops(sparseObject: SparseMatrixObject, nRows: number) {\n    for (let i = 0; i < nRows; i++) {\n      if (!sparseObject[i])\n        sparseObject[i] = {};\n      sparseObject[i][i] = this._options.multFactor;\n    }\n  }\n\n  private normalize(sparseObject: SparseMatrixObject) {\n    for (const i of Object.keys(sparseObject)) {\n      const row = sparseObject[i as any];\n      let sum = 0;\n      for (const j of Object.keys(row))\n        sum += row[j as any];\n      if (sum === 0) continue;\n      for (const j of Object.keys(row))\n        sparseObject[i as any][j as any] /= sum;\n    }\n  }\n\n  private expand(sparseObject: SparseMatrixObject, nRows: number) {\n    const expandedObject: SparseMatrixObject = {};\n    const order = Math.floor(Math.max(Math.log10(nRows), 2)) + 1;\n    const minOrder = Math.pow(10, order);\n    for (let i = 0; i < nRows; i++) {\n      if (!sparseObject[i])\n        continue;\n      // const row = sparseObject[i];\n      expandedObject[i] = {};\n      for (let j = i; j < nRows; j++) {\n        if (!sparseObject[i]?.[j])\n          continue;\n        const val = this.getExpandValue(sparseObject, i, j); //pruning step\n        if (Math.round(val * minOrder) / minOrder > 0) {\n          expandedObject[i][j] = val;\n          if (!expandedObject[j])\n            expandedObject[j] = {};\n          expandedObject[j][i] = val;\n        }\n      }\n    }\n    return expandedObject;\n  }\n\n  // private prune(row: SparseMatrixObject[number]) {\n\n  // }\n\n  private inflate(sparseObject: SparseMatrixObject) {\n    for (const i of Object.keys(sparseObject)) {\n      const row = sparseObject[i as any];\n      for (const j of Object.keys(row))\n        sparseObject[i as any][j as any] = Math.pow(sparseObject[i as any][j as any], this._options.inflateFactor);\n    }\n  }\n\n  private getExpandValue(sparseObject: SparseMatrixObject, i: any, j: any) {\n    let val = 0;\n    const currentIndexes = Object.keys(sparseObject[i] ?? {});\n    const otherIndexes = Object.keys(sparseObject[j] ?? {});\n    for (const k of currentIndexes) {\n      if (otherIndexes.includes(k))\n        val += sparseObject[i][k as any] * sparseObject[j][k as any];\n    }\n    return val;\n  }\n}\n\n"]}","import { SparseMatrixService } from '../distance-matrix/sparse-matrix-service';\nimport { MCLSparseReducer } from './marcov-cluster';\nonmessage = async (event) => {\n const { data, threshold, weights, aggregationMethod, distanceFnArgs, distanceFns, maxIterations } = event.data;\n const sparse = await new SparseMatrixService()\n .calcMultiColumn(data, distanceFns, threshold / 100, distanceFnArgs, weights, aggregationMethod);\n const res = await new MCLSparseReducer({ maxIterations: maxIterations ?? 5 }).transform(sparse, data[0].length);\n postMessage({ res });\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWNsLXdvcmtlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm1jbC13b3JrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFHN0UsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFFbEQsU0FBUyxHQUFHLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRTtJQUMxQixNQUFNLEVBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsY0FBYyxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUMsR0FHaEIsS0FBSyxDQUFDLElBQUksQ0FBQztJQUMxRixNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksbUJBQW1CLEVBQUU7U0FDM0MsZUFBZSxDQUFDLElBQUksRUFBRSxXQUFXLEVBQUUsU0FBUyxHQUFHLEdBQUcsRUFBRSxjQUFjLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixDQUFDLENBQUM7SUFDbkcsTUFBTSxHQUFHLEdBQUcsTUFBTSxJQUFJLGdCQUFnQixDQUFDLEVBQUMsYUFBYSxFQUFFLGFBQWEsSUFBSSxDQUFDLEVBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzlHLFdBQVcsQ0FBQyxFQUFDLEdBQUcsRUFBQyxDQUFDLENBQUM7QUFDckIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtTcGFyc2VNYXRyaXhTZXJ2aWNlfSBmcm9tICcuLi9kaXN0YW5jZS1tYXRyaXgvc3BhcnNlLW1hdHJpeC1zZXJ2aWNlJztcbmltcG9ydCB7RGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZH0gZnJvbSAnLi4vZGlzdGFuY2UtbWF0cml4L3R5cGVzJztcbmltcG9ydCB7S25vd25NZXRyaWNzfSBmcm9tICcuLi90eXBlZC1tZXRyaWNzJztcbmltcG9ydCB7TUNMU3BhcnNlUmVkdWNlcn0gZnJvbSAnLi9tYXJjb3YtY2x1c3Rlcic7XG5cbm9ubWVzc2FnZSA9IGFzeW5jIChldmVudCkgPT4ge1xuICBjb25zdCB7ZGF0YSwgdGhyZXNob2xkLCB3ZWlnaHRzLCBhZ2dyZWdhdGlvbk1ldGhvZCwgZGlzdGFuY2VGbkFyZ3MsIGRpc3RhbmNlRm5zLCBtYXhJdGVyYXRpb25zfTpcbiAgIHtkYXRhOiBhbnlbXVtdLCB0aHJlc2hvbGQ6IG51bWJlcixcbiAgICB3ZWlnaHRzOiBudW1iZXJbXSwgYWdncmVnYXRpb25NZXRob2Q6IERpc3RhbmNlQWdncmVnYXRpb25NZXRob2QsXG4gICAgZGlzdGFuY2VGbnM6IEtub3duTWV0cmljc1tdLCBkaXN0YW5jZUZuQXJnczogYW55W10sIG1heEl0ZXJhdGlvbnM6IG51bWJlcn0gPSBldmVudC5kYXRhO1xuICBjb25zdCBzcGFyc2UgPSBhd2FpdCBuZXcgU3BhcnNlTWF0cml4U2VydmljZSgpXG4gICAgLmNhbGNNdWx0aUNvbHVtbihkYXRhLCBkaXN0YW5jZUZucywgdGhyZXNob2xkIC8gMTAwLCBkaXN0YW5jZUZuQXJncywgd2VpZ2h0cywgYWdncmVnYXRpb25NZXRob2QpO1xuICBjb25zdCByZXMgPSBhd2FpdCBuZXcgTUNMU3BhcnNlUmVkdWNlcih7bWF4SXRlcmF0aW9uczogbWF4SXRlcmF0aW9ucyA/PyA1fSkudHJhbnNmb3JtKHNwYXJzZSwgZGF0YVswXS5sZW5ndGgpO1xuICBwb3N0TWVzc2FnZSh7cmVzfSk7XG59O1xuIl19","import { DistanceAggregationMethods } from './types';\nexport const isNil = (x) => x === null || x === undefined;\nexport function insertSmaller(distancesAr, indexes, num, index) {\n if (num > distancesAr[distancesAr.length - 1])\n return;\n const newPosition = distancesAr.findIndex((v) => num < v);\n distancesAr.pop();\n distancesAr.splice(newPosition, 0, num);\n indexes.pop();\n indexes.splice(newPosition, 0, index);\n}\nexport function insertLarger(distancesAr, indexes, num, index) {\n if (num < distancesAr[distancesAr.length - 1])\n return;\n const newPosition = distancesAr.findIndex((v) => num > v);\n distancesAr.pop();\n distancesAr.splice(newPosition, 0, num);\n indexes.pop();\n indexes.splice(newPosition, 0, index);\n}\nexport function getAggregationFunction(aggregationMethod, weights) {\n switch (aggregationMethod) {\n case DistanceAggregationMethods.MANHATTAN:\n return (vs) => vs.reduce((acc, val, idx) => acc + val * weights[idx], 0);\n default:\n return (vs) => {\n // euclidean\n const sum = vs.reduce((acc, val, idx) => acc + (val * weights[idx]) ** 2, 0);\n return Math.sqrt(sum);\n };\n }\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTRCLDBCQUEwQixFQUFDLE1BQU0sU0FBUyxDQUFDO0FBRTlFLE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBRyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLEtBQUssU0FBUyxDQUFDO0FBRS9ELE1BQU0sVUFBVSxhQUFhLENBQUMsV0FBcUIsRUFBRSxPQUFpQixFQUFFLEdBQVcsRUFBRSxLQUFhO0lBQ2hHLElBQUksR0FBRyxHQUFHLFdBQVcsQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFDLENBQUMsQ0FBQztRQUN6QyxPQUFPO0lBRVQsTUFBTSxXQUFXLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzFELFdBQVcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNsQixXQUFXLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFBRSxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDeEMsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ2QsT0FBTyxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBQ3hDLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLFdBQXFCLEVBQUUsT0FBaUIsRUFBRSxHQUFXLEVBQUUsS0FBYTtJQUMvRixJQUFJLEdBQUcsR0FBRyxXQUFXLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBQyxDQUFDLENBQUM7UUFDekMsT0FBTztJQUVULE1BQU0sV0FBVyxHQUFHLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMxRCxXQUFXLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDbEIsV0FBVyxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNkLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztBQUN4QyxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUNwQyxpQkFBNEMsRUFBRSxPQUFpQjtJQUUvRCxRQUFRLGlCQUFpQixFQUFFO1FBQ3pCLEtBQUssMEJBQTBCLENBQUMsU0FBUztZQUN2QyxPQUFPLENBQUMsRUFBWSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3JGO1lBQ0UsT0FBTyxDQUFDLEVBQVksRUFBRSxFQUFFO2dCQUN0QixZQUFZO2dCQUNaLE1BQU0sR0FBRyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztnQkFDN0UsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3hCLENBQUMsQ0FBQztLQUNMO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZCwgRGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZHN9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgaXNOaWwgPSAoeDogYW55KSA9PiB4ID09PSBudWxsIHx8IHggPT09IHVuZGVmaW5lZDtcblxuZXhwb3J0IGZ1bmN0aW9uIGluc2VydFNtYWxsZXIoZGlzdGFuY2VzQXI6IG51bWJlcltdLCBpbmRleGVzOiBudW1iZXJbXSwgbnVtOiBudW1iZXIsIGluZGV4OiBudW1iZXIpIHtcbiAgaWYgKG51bSA+IGRpc3RhbmNlc0FyW2Rpc3RhbmNlc0FyLmxlbmd0aC0xXSlcbiAgICByZXR1cm47XG5cbiAgY29uc3QgbmV3UG9zaXRpb24gPSBkaXN0YW5jZXNBci5maW5kSW5kZXgoKHYpID0+IG51bSA8IHYpO1xuICBkaXN0YW5jZXNBci5wb3AoKTtcbiAgZGlzdGFuY2VzQXIuc3BsaWNlKG5ld1Bvc2l0aW9uLCAwLCBudW0pO1xuICBpbmRleGVzLnBvcCgpO1xuICBpbmRleGVzLnNwbGljZShuZXdQb3NpdGlvbiwgMCwgaW5kZXgpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW5zZXJ0TGFyZ2VyKGRpc3RhbmNlc0FyOiBudW1iZXJbXSwgaW5kZXhlczogbnVtYmVyW10sIG51bTogbnVtYmVyLCBpbmRleDogbnVtYmVyKSB7XG4gIGlmIChudW0gPCBkaXN0YW5jZXNBcltkaXN0YW5jZXNBci5sZW5ndGgtMV0pXG4gICAgcmV0dXJuO1xuXG4gIGNvbnN0IG5ld1Bvc2l0aW9uID0gZGlzdGFuY2VzQXIuZmluZEluZGV4KCh2KSA9PiBudW0gPiB2KTtcbiAgZGlzdGFuY2VzQXIucG9wKCk7XG4gIGRpc3RhbmNlc0FyLnNwbGljZShuZXdQb3NpdGlvbiwgMCwgbnVtKTtcbiAgaW5kZXhlcy5wb3AoKTtcbiAgaW5kZXhlcy5zcGxpY2UobmV3UG9zaXRpb24sIDAsIGluZGV4KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFnZ3JlZ2F0aW9uRnVuY3Rpb24oXG4gIGFnZ3JlZ2F0aW9uTWV0aG9kOiBEaXN0YW5jZUFnZ3JlZ2F0aW9uTWV0aG9kLCB3ZWlnaHRzOiBudW1iZXJbXVxuKTogKHZhbHVlczogbnVtYmVyW10pID0+IG51bWJlciB7XG4gIHN3aXRjaCAoYWdncmVnYXRpb25NZXRob2QpIHtcbiAgICBjYXNlIERpc3RhbmNlQWdncmVnYXRpb25NZXRob2RzLk1BTkhBVFRBTjpcbiAgICAgIHJldHVybiAodnM6IG51bWJlcltdKSA9PiB2cy5yZWR1Y2UoKGFjYywgdmFsLCBpZHgpID0+IGFjYyArIHZhbCAqIHdlaWdodHNbaWR4XSwgMCk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiAodnM6IG51bWJlcltdKSA9PiB7XG4gICAgICAgIC8vIGV1Y2xpZGVhblxuICAgICAgICBjb25zdCBzdW0gPSB2cy5yZWR1Y2UoKGFjYywgdmFsLCBpZHgpID0+IGFjYyArICh2YWwgKiB3ZWlnaHRzW2lkeF0pICoqIDIsIDApO1xuICAgICAgICByZXR1cm4gTWF0aC5zcXJ0KHN1bSk7XG4gICAgICB9O1xuICB9XG59XG4iXX0=","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n// the startup function\n__webpack_require__.x = () => {\n\t// Load entry module and return exports\n\t// This entry module depends on other loaded chunks and execution need to be delayed\n\tvar __webpack_exports__ = __webpack_require__.O(undefined, [590], () => (__webpack_require__(2357)))\n\t__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n\treturn __webpack_exports__;\n};\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks and sibling chunks for the entrypoint\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"\" + chunkId + \".js\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","__webpack_require__.b = self.location + \"\";\n\n// object to store loaded chunks\n// \"1\" means \"already loaded\"\nvar installedChunks = {\n\t709: 1\n};\n\n// importScripts chunk loading\nvar installChunk = (data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\tfor(var moduleId in moreModules) {\n\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t}\n\t}\n\tif(runtime) runtime(__webpack_require__);\n\twhile(chunkIds.length)\n\t\tinstalledChunks[chunkIds.pop()] = 1;\n\tparentChunkLoadingFunction(data);\n};\n__webpack_require__.f.i = (chunkId, promises) => {\n\t// \"1\" is the signal for \"already loaded\"\n\tif(!installedChunks[chunkId]) {\n\t\tif(true) { // all chunks have JS\n\t\t\timportScripts(__webpack_require__.p + __webpack_require__.u(chunkId));\n\t\t}\n\t}\n};\n\nvar chunkLoadingGlobal = self[\"webpackChunkbio\"] = self[\"webpackChunkbio\"] || [];\nvar parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);\nchunkLoadingGlobal.push = installChunk;\n\n// no HMR\n\n// no HMR manifest","// run startup\nvar __webpack_exports__ = __webpack_require__.x();\n"],"names":["deferred","next","async","bioLayout","cluster","sparseObject","threshold","n","length","is","js","i","j","a","b","push","embedX","Float32Array","fill","map","Math","random","embedY","xVelocities","yVelocities","temperature","idx","dx","dy","abs","vecSize","sqrt","minX","minY","maxX","maxY","min","max","rangeX","rangeY","getLayoutEmbeddings","defaultMCLOptions","expandFactor","maxIterations","inflateFactor","multFactor","MCLSparseReducer","constructor","opts","this","_options","sparseMatrix","nRows","toObjectForm","addLoops","normalize","expand","inflate","clusters","assignClusters","correctClusters","embeddings","layout","clusterSizeMap","sortedIndexes","Object","keys","Number","sort","clusterMap","forEach","clusterIdx","clusterNum","sortedClusterNames","perRow","yOffset","clusterName","ceil","offsetX","mergeClusters","iCluster","jCluster","k","order","floor","log10","minOrder","pow","Array","round","Uint32Array","distance","row","sum","expandedObject","val","getExpandValue","currentIndexes","otherIndexes","includes","onmessage","event","data","weights","aggregationMethod","distanceFnArgs","distanceFns","sparse","calcMultiColumn","res","transform","postMessage","isNil","x","insertSmaller","distancesAr","indexes","num","index","newPosition","findIndex","v","pop","splice","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","exports","module","__webpack_modules__","m","__webpack_exports__","O","result","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","every","key","r","d","definition","o","defineProperty","enumerable","get","f","e","chunkId","Promise","all","reduce","promises","u","g","globalThis","Function","window","obj","prop","prototype","hasOwnProperty","call","scriptUrl","importScripts","location","document","currentScript","src","scripts","getElementsByTagName","Error","replace","p","self","installedChunks","chunkLoadingGlobal","parentChunkLoadingFunction","bind","moreModules","runtime","then"],"sourceRoot":""}