@datagrok/eda 1.4.2 → 1.4.4

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.
Files changed (153) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/README.md +1 -0
  3. package/dist/_d4c0.js +279 -0
  4. package/dist/_d4c0.js.map +1 -0
  5. package/dist/node_modules_datagrok-libraries_math_src_dbscan_wasm_clustering-worker_js.js +279 -0
  6. package/dist/node_modules_datagrok-libraries_math_src_dbscan_wasm_clustering-worker_js.js.map +1 -0
  7. package/dist/node_modules_datagrok-libraries_ml_src_MCL_mcl-sparse-matrix-mult-worker_js.js +59 -0
  8. package/dist/node_modules_datagrok-libraries_ml_src_MCL_mcl-sparse-matrix-mult-worker_js.js.map +1 -0
  9. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js.js +284 -0
  10. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js.js.map +1 -0
  11. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js.js +265 -0
  12. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js.js.map +1 -0
  13. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-worker_js.js +287 -0
  14. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-worker_js.js.map +1 -0
  15. package/dist/package-test.js +26140 -1
  16. package/dist/package-test.js.map +1 -1
  17. package/dist/package.js +30337 -1
  18. package/dist/package.js.map +1 -1
  19. package/dist/src_workers_softmax-worker_ts.js +154 -0
  20. package/dist/src_workers_softmax-worker_ts.js.map +1 -0
  21. package/dist/src_workers_tsne-worker_ts.js +244 -0
  22. package/dist/src_workers_tsne-worker_ts.js.map +1 -0
  23. package/dist/src_workers_umap-worker_ts.js +252 -0
  24. package/dist/src_workers_umap-worker_ts.js.map +1 -0
  25. package/dist/vendors-node_modules_datagrok-libraries_math_src_dbscan_wasm_dbscan_js.js +1253 -0
  26. package/dist/vendors-node_modules_datagrok-libraries_math_src_dbscan_wasm_dbscan_js.js.map +1 -0
  27. package/dist/vendors-node_modules_datagrok-libraries_math_src_hierarchical-clustering_wasm_clustering-worker_js.js +942 -0
  28. package/dist/vendors-node_modules_datagrok-libraries_math_src_hierarchical-clustering_wasm_clustering-worker_js.js.map +1 -0
  29. package/dist/vendors-node_modules_datagrok-libraries_math_src_webGPU_sparse-matrix_webGPU-sparse-matrix_js-07693f.js +1525 -0
  30. package/dist/vendors-node_modules_datagrok-libraries_math_src_webGPU_sparse-matrix_webGPU-sparse-matrix_js-07693f.js.map +1 -0
  31. package/dist/vendors-node_modules_datagrok-libraries_ml_src_MCL_mcl-worker_js-node_modules_datagrok-librar-e4203d.js +2244 -0
  32. package/dist/vendors-node_modules_datagrok-libraries_ml_src_MCL_mcl-worker_js-node_modules_datagrok-librar-e4203d.js.map +1 -0
  33. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-threshold-worker_js.js +286 -0
  34. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-threshold-worker_js.js.map +1 -0
  35. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-worker_js.js +280 -0
  36. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-worker_js.js.map +1 -0
  37. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-threshold-worker_js.js +282 -0
  38. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-threshold-worker_js.js.map +1 -0
  39. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2.js +1821 -0
  40. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2.js.map +1 -0
  41. package/dist/vendors-node_modules_datagrok-libraries_ml_src_multi-column-dimensionality-reduction_mulit-co-3800a0.js +7776 -0
  42. package/dist/vendors-node_modules_datagrok-libraries_ml_src_multi-column-dimensionality-reduction_mulit-co-3800a0.js.map +1 -0
  43. package/dist/vendors-node_modules_keckelt_tsne_lib_index_js.js +379 -0
  44. package/dist/vendors-node_modules_keckelt_tsne_lib_index_js.js.map +1 -0
  45. package/dist/vendors-node_modules_ml-matrix_matrix_mjs.js +5946 -0
  46. package/dist/vendors-node_modules_ml-matrix_matrix_mjs.js.map +1 -0
  47. package/dist/vendors-node_modules_umap-js_dist_index_js.js +2284 -0
  48. package/dist/vendors-node_modules_umap-js_dist_index_js.js.map +1 -0
  49. package/dist/wasm_EDAForWebWorker_js-wasm_callWasmForWebWorker_js.js +779 -0
  50. package/dist/wasm_EDAForWebWorker_js-wasm_callWasmForWebWorker_js.js.map +1 -0
  51. package/dist/wasm_workers_errorWorker_js.js +267 -0
  52. package/dist/wasm_workers_errorWorker_js.js.map +1 -0
  53. package/dist/wasm_workers_fitLinearRegressionParamsWithDataNormalizingWorker_js.js +267 -0
  54. package/dist/wasm_workers_fitLinearRegressionParamsWithDataNormalizingWorker_js.js.map +1 -0
  55. package/dist/wasm_workers_fitLinearRegressionParamsWorker_js.js +267 -0
  56. package/dist/wasm_workers_fitLinearRegressionParamsWorker_js.js.map +1 -0
  57. package/dist/wasm_workers_fitSoftmaxWorker_js.js +267 -0
  58. package/dist/wasm_workers_fitSoftmaxWorker_js.js.map +1 -0
  59. package/dist/wasm_workers_generateDatasetWorker_js.js +267 -0
  60. package/dist/wasm_workers_generateDatasetWorker_js.js.map +1 -0
  61. package/dist/wasm_workers_normalizeDatasetWorker_js.js +267 -0
  62. package/dist/wasm_workers_normalizeDatasetWorker_js.js.map +1 -0
  63. package/dist/wasm_workers_partialLeastSquareRegressionWorker_js.js +267 -0
  64. package/dist/wasm_workers_partialLeastSquareRegressionWorker_js.js.map +1 -0
  65. package/dist/wasm_workers_predictByLSSVMWorker_js.js +267 -0
  66. package/dist/wasm_workers_predictByLSSVMWorker_js.js.map +1 -0
  67. package/dist/wasm_workers_principalComponentAnalysisNipalsWorker_js.js +267 -0
  68. package/dist/wasm_workers_principalComponentAnalysisNipalsWorker_js.js.map +1 -0
  69. package/dist/wasm_workers_principalComponentAnalysisWorkerUpd_js.js +271 -0
  70. package/dist/wasm_workers_principalComponentAnalysisWorkerUpd_js.js.map +1 -0
  71. package/dist/wasm_workers_trainAndAnalyzeLSSVMWorker_js.js +267 -0
  72. package/dist/wasm_workers_trainAndAnalyzeLSSVMWorker_js.js.map +1 -0
  73. package/dist/wasm_workers_trainLSSVMWorker_js.js +267 -0
  74. package/dist/wasm_workers_trainLSSVMWorker_js.js.map +1 -0
  75. package/dist/wasm_workers_xgboostWorker_js.js +279 -0
  76. package/dist/wasm_workers_xgboostWorker_js.js.map +1 -0
  77. package/package.json +5 -4
  78. package/src/package-api.ts +259 -0
  79. package/src/package.g.ts +522 -0
  80. package/src/package.ts +907 -678
  81. package/test-console-output-1.log +95 -80
  82. package/test-record-1.mp4 +0 -0
  83. package/tsconfig.json +2 -2
  84. package/webpack.config.js +5 -0
  85. package/dist/111.js +0 -2
  86. package/dist/111.js.map +0 -1
  87. package/dist/128.js +0 -2
  88. package/dist/128.js.map +0 -1
  89. package/dist/153.js +0 -2
  90. package/dist/153.js.map +0 -1
  91. package/dist/23.js +0 -2
  92. package/dist/23.js.map +0 -1
  93. package/dist/234.js +0 -2
  94. package/dist/234.js.map +0 -1
  95. package/dist/242.js +0 -2
  96. package/dist/242.js.map +0 -1
  97. package/dist/260.js +0 -2
  98. package/dist/260.js.map +0 -1
  99. package/dist/33.js +0 -2
  100. package/dist/33.js.map +0 -1
  101. package/dist/348.js +0 -2
  102. package/dist/348.js.map +0 -1
  103. package/dist/377.js +0 -2
  104. package/dist/377.js.map +0 -1
  105. package/dist/412.js +0 -2
  106. package/dist/412.js.map +0 -1
  107. package/dist/415.js +0 -2
  108. package/dist/415.js.map +0 -1
  109. package/dist/501.js +0 -2
  110. package/dist/501.js.map +0 -1
  111. package/dist/531.js +0 -2
  112. package/dist/531.js.map +0 -1
  113. package/dist/583.js +0 -2
  114. package/dist/583.js.map +0 -1
  115. package/dist/589.js +0 -2
  116. package/dist/589.js.map +0 -1
  117. package/dist/603.js +0 -2
  118. package/dist/603.js.map +0 -1
  119. package/dist/656.js +0 -2
  120. package/dist/656.js.map +0 -1
  121. package/dist/682.js +0 -2
  122. package/dist/682.js.map +0 -1
  123. package/dist/705.js +0 -2
  124. package/dist/705.js.map +0 -1
  125. package/dist/727.js +0 -2
  126. package/dist/727.js.map +0 -1
  127. package/dist/731.js +0 -2
  128. package/dist/731.js.map +0 -1
  129. package/dist/738.js +0 -3
  130. package/dist/738.js.LICENSE.txt +0 -51
  131. package/dist/738.js.map +0 -1
  132. package/dist/763.js +0 -2
  133. package/dist/763.js.map +0 -1
  134. package/dist/778.js +0 -2
  135. package/dist/778.js.map +0 -1
  136. package/dist/783.js +0 -2
  137. package/dist/783.js.map +0 -1
  138. package/dist/793.js +0 -2
  139. package/dist/793.js.map +0 -1
  140. package/dist/801.js +0 -2
  141. package/dist/801.js.map +0 -1
  142. package/dist/810.js +0 -2
  143. package/dist/810.js.map +0 -1
  144. package/dist/860.js +0 -2
  145. package/dist/860.js.map +0 -1
  146. package/dist/907.js +0 -2
  147. package/dist/907.js.map +0 -1
  148. package/dist/950.js +0 -2
  149. package/dist/950.js.map +0 -1
  150. package/dist/980.js +0 -2
  151. package/dist/980.js.map +0 -1
  152. package/dist/990.js +0 -2
  153. package/dist/990.js.map +0 -1
@@ -0,0 +1,59 @@
1
+ var eda;
2
+ /******/ (() => { // webpackBootstrap
3
+ /******/ "use strict";
4
+ var __webpack_exports__ = {};
5
+ /*!**************************************************************************************!*\
6
+ !*** ./node_modules/@datagrok-libraries/ml/src/MCL/mcl-sparse-matrix-mult-worker.js ***!
7
+ \**************************************************************************************/
8
+
9
+ const indexesMapRows = new Map();
10
+ onmessage = (e) => {
11
+ // init step for the worker
12
+ if (e.data.is) {
13
+ const { is, js, ds } = e.data;
14
+ for (let i = 0; i < is.length; i++) {
15
+ if (!indexesMapRows.has(is[i]))
16
+ indexesMapRows.set(is[i], new Map());
17
+ indexesMapRows.get(is[i]).set(js[i], ds[i]);
18
+ }
19
+ postMessage('ready');
20
+ return;
21
+ }
22
+ // main step for the worker
23
+ const { blockStart, blockEnd } = e.data;
24
+ const resI = [];
25
+ const resJ = [];
26
+ const resD = [];
27
+ // we do operations row by row
28
+ // therefore, iterating over all columns is necessary
29
+ // graphically speaking, one worker is working on a horizontal stripe in a matrix
30
+ // blockstart and blockend are the indexes of the rows that the worker is responsible for
31
+ for (let i = blockStart; i < blockEnd; i++) {
32
+ const iMap = indexesMapRows.get(i);
33
+ if (!iMap)
34
+ continue;
35
+ // this worker is responsible for every nonzero value in the row (or iMap)
36
+ // since we are using iMap a lot, we can materialize it
37
+ const iMapEntries = Array.from(iMap.entries());
38
+ for (const [k, _v] of iMapEntries) {
39
+ let sum = 0;
40
+ // here we know that the value is not zero
41
+ // therefore, we can iterate over the columns
42
+ for (const [k1, v1] of iMapEntries) {
43
+ // here we check the column
44
+ const jVal = indexesMapRows.get(k1)?.get(k);
45
+ if (jVal)
46
+ sum += v1 * jVal;
47
+ }
48
+ resI.push(i);
49
+ resJ.push(k);
50
+ resD.push(sum);
51
+ }
52
+ }
53
+ postMessage({ i: new Uint32Array(resI), j: new Uint32Array(resJ), distance: new Float32Array(resD) });
54
+ };
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWNsLXNwYXJzZS1tYXRyaXgtbXVsdC13b3JrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtY2wtc3BhcnNlLW1hdHJpeC1tdWx0LXdvcmtlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBRUEsTUFBTSxjQUFjLEdBQUcsSUFBSSxHQUFHLEVBQStCLENBQUM7QUFFOUQsU0FBUyxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUU7SUFDaEIsMkJBQTJCO0lBQzNCLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUNkLE1BQU0sRUFBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFDNUIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNuQyxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzVCLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksR0FBRyxFQUFrQixDQUFDLENBQUM7WUFFdkQsY0FBYyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQy9DLENBQUM7UUFDRCxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDckIsT0FBTztJQUNULENBQUM7SUFFRCwyQkFBMkI7SUFDM0IsTUFBTSxFQUFDLFVBQVUsRUFBRSxRQUFRLEVBQUMsR0FBMEIsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUU3RCxNQUFNLElBQUksR0FBYSxFQUFFLENBQUM7SUFDMUIsTUFBTSxJQUFJLEdBQWEsRUFBRSxDQUFDO0lBQzFCLE1BQU0sSUFBSSxHQUFhLEVBQUUsQ0FBQztJQUUxQiw4QkFBOEI7SUFDOUIscURBQXFEO0lBQ3JELGlGQUFpRjtJQUdqRix5RkFBeUY7SUFDekYsS0FBSyxJQUFJLENBQUMsR0FBRyxVQUFVLEVBQUUsQ0FBQyxHQUFHLFFBQVEsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1FBQzNDLE1BQU0sSUFBSSxHQUFHLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkMsSUFBSSxDQUFDLElBQUk7WUFDUCxTQUFTO1FBRVgsMEVBQTBFO1FBQzFFLHVEQUF1RDtRQUN2RCxNQUFNLFdBQVcsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQy9DLEtBQUssTUFBTSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxXQUFXLEVBQUUsQ0FBQztZQUNsQyxJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUM7WUFDWiwwQ0FBMEM7WUFDMUMsNkNBQTZDO1lBQzdDLEtBQUssTUFBTSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsSUFBSSxXQUFXLEVBQUUsQ0FBQztnQkFDbkMsMkJBQTJCO2dCQUMzQixNQUFNLElBQUksR0FBRyxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDNUMsSUFBSSxJQUFJO29CQUNOLEdBQUcsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLENBQUM7WUFFRCxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDakIsQ0FBQztJQUNILENBQUM7SUFHRCxXQUFXLENBQUMsRUFBQyxDQUFDLEVBQUUsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxFQUFFLElBQUksV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsRUFBQyxDQUFDLENBQUM7QUFDdEcsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5cbmNvbnN0IGluZGV4ZXNNYXBSb3dzID0gbmV3IE1hcDxudW1iZXIsIE1hcDxudW1iZXIsIG51bWJlcj4+KCk7XG5cbm9ubWVzc2FnZSA9IChlKSA9PiB7XG4gIC8vIGluaXQgc3RlcCBmb3IgdGhlIHdvcmtlclxuICBpZiAoZS5kYXRhLmlzKSB7XG4gICAgY29uc3Qge2lzLCBqcywgZHN9ID0gZS5kYXRhO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgaXMubGVuZ3RoOyBpKyspIHtcbiAgICAgIGlmICghaW5kZXhlc01hcFJvd3MuaGFzKGlzW2ldKSlcbiAgICAgICAgaW5kZXhlc01hcFJvd3Muc2V0KGlzW2ldLCBuZXcgTWFwPG51bWJlciwgbnVtYmVyPigpKTtcblxuICAgICAgaW5kZXhlc01hcFJvd3MuZ2V0KGlzW2ldKSEuc2V0KGpzW2ldLCBkc1tpXSk7XG4gICAgfVxuICAgIHBvc3RNZXNzYWdlKCdyZWFkeScpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIG1haW4gc3RlcCBmb3IgdGhlIHdvcmtlclxuICBjb25zdCB7YmxvY2tTdGFydCwgYmxvY2tFbmR9OiB7W186IHN0cmluZ106IG51bWJlcn0gPSBlLmRhdGE7XG5cbiAgY29uc3QgcmVzSTogbnVtYmVyW10gPSBbXTtcbiAgY29uc3QgcmVzSjogbnVtYmVyW10gPSBbXTtcbiAgY29uc3QgcmVzRDogbnVtYmVyW10gPSBbXTtcblxuICAvLyB3ZSBkbyBvcGVyYXRpb25zIHJvdyBieSByb3dcbiAgLy8gdGhlcmVmb3JlLCBpdGVyYXRpbmcgb3ZlciBhbGwgY29sdW1ucyBpcyBuZWNlc3NhcnlcbiAgLy8gZ3JhcGhpY2FsbHkgc3BlYWtpbmcsIG9uZSB3b3JrZXIgaXMgd29ya2luZyBvbiBhIGhvcml6b250YWwgc3RyaXBlIGluIGEgbWF0cml4XG5cblxuICAvLyBibG9ja3N0YXJ0IGFuZCBibG9ja2VuZCBhcmUgdGhlIGluZGV4ZXMgb2YgdGhlIHJvd3MgdGhhdCB0aGUgd29ya2VyIGlzIHJlc3BvbnNpYmxlIGZvclxuICBmb3IgKGxldCBpID0gYmxvY2tTdGFydDsgaSA8IGJsb2NrRW5kOyBpKyspIHtcbiAgICBjb25zdCBpTWFwID0gaW5kZXhlc01hcFJvd3MuZ2V0KGkpO1xuICAgIGlmICghaU1hcClcbiAgICAgIGNvbnRpbnVlO1xuXG4gICAgLy8gdGhpcyB3b3JrZXIgaXMgcmVzcG9uc2libGUgZm9yIGV2ZXJ5IG5vbnplcm8gdmFsdWUgaW4gdGhlIHJvdyAob3IgaU1hcClcbiAgICAvLyBzaW5jZSB3ZSBhcmUgdXNpbmcgaU1hcCBhIGxvdCwgd2UgY2FuIG1hdGVyaWFsaXplIGl0XG4gICAgY29uc3QgaU1hcEVudHJpZXMgPSBBcnJheS5mcm9tKGlNYXAuZW50cmllcygpKTtcbiAgICBmb3IgKGNvbnN0IFtrLCBfdl0gb2YgaU1hcEVudHJpZXMpIHtcbiAgICAgIGxldCBzdW0gPSAwO1xuICAgICAgLy8gaGVyZSB3ZSBrbm93IHRoYXQgdGhlIHZhbHVlIGlzIG5vdCB6ZXJvXG4gICAgICAvLyB0aGVyZWZvcmUsIHdlIGNhbiBpdGVyYXRlIG92ZXIgdGhlIGNvbHVtbnNcbiAgICAgIGZvciAoY29uc3QgW2sxLCB2MV0gb2YgaU1hcEVudHJpZXMpIHtcbiAgICAgICAgLy8gaGVyZSB3ZSBjaGVjayB0aGUgY29sdW1uXG4gICAgICAgIGNvbnN0IGpWYWwgPSBpbmRleGVzTWFwUm93cy5nZXQoazEpPy5nZXQoayk7XG4gICAgICAgIGlmIChqVmFsKVxuICAgICAgICAgIHN1bSArPSB2MSAqIGpWYWw7XG4gICAgICB9XG5cbiAgICAgIHJlc0kucHVzaChpKTtcbiAgICAgIHJlc0oucHVzaChrKTtcbiAgICAgIHJlc0QucHVzaChzdW0pO1xuICAgIH1cbiAgfVxuXG5cbiAgcG9zdE1lc3NhZ2Uoe2k6IG5ldyBVaW50MzJBcnJheShyZXNJKSwgajogbmV3IFVpbnQzMkFycmF5KHJlc0opLCBkaXN0YW5jZTogbmV3IEZsb2F0MzJBcnJheShyZXNEKX0pO1xufTtcbiJdfQ==
56
+ eda = __webpack_exports__;
57
+ /******/ })()
58
+ ;
59
+ //# sourceMappingURL=node_modules_datagrok-libraries_ml_src_MCL_mcl-sparse-matrix-mult-worker_js.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node_modules_datagrok-libraries_ml_src_MCL_mcl-sparse-matrix-mult-worker_js.js","mappings":";;;;;;;AAAa;AACb;AACA;AACA;AACA;AACA,gBAAgB,aAAa;AAC7B,wBAAwB,eAAe;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,uBAAuB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,cAAc;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,sFAAsF;AACxG;AACA,2CAA2C,+xJ","sources":["webpack://eda/./node_modules/@datagrok-libraries/ml/src/MCL/mcl-sparse-matrix-mult-worker.js"],"sourcesContent":["\"use strict\";\nconst indexesMapRows = new Map();\nonmessage = (e) => {\n // init step for the worker\n if (e.data.is) {\n const { is, js, ds } = e.data;\n for (let i = 0; i < is.length; i++) {\n if (!indexesMapRows.has(is[i]))\n indexesMapRows.set(is[i], new Map());\n indexesMapRows.get(is[i]).set(js[i], ds[i]);\n }\n postMessage('ready');\n return;\n }\n // main step for the worker\n const { blockStart, blockEnd } = e.data;\n const resI = [];\n const resJ = [];\n const resD = [];\n // we do operations row by row\n // therefore, iterating over all columns is necessary\n // graphically speaking, one worker is working on a horizontal stripe in a matrix\n // blockstart and blockend are the indexes of the rows that the worker is responsible for\n for (let i = blockStart; i < blockEnd; i++) {\n const iMap = indexesMapRows.get(i);\n if (!iMap)\n continue;\n // this worker is responsible for every nonzero value in the row (or iMap)\n // since we are using iMap a lot, we can materialize it\n const iMapEntries = Array.from(iMap.entries());\n for (const [k, _v] of iMapEntries) {\n let sum = 0;\n // here we know that the value is not zero\n // therefore, we can iterate over the columns\n for (const [k1, v1] of iMapEntries) {\n // here we check the column\n const jVal = indexesMapRows.get(k1)?.get(k);\n if (jVal)\n sum += v1 * jVal;\n }\n resI.push(i);\n resJ.push(k);\n resD.push(sum);\n }\n }\n postMessage({ i: new Uint32Array(resI), j: new Uint32Array(resJ), distance: new Float32Array(resD) });\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWNsLXNwYXJzZS1tYXRyaXgtbXVsdC13b3JrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtY2wtc3BhcnNlLW1hdHJpeC1tdWx0LXdvcmtlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBRUEsTUFBTSxjQUFjLEdBQUcsSUFBSSxHQUFHLEVBQStCLENBQUM7QUFFOUQsU0FBUyxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUU7SUFDaEIsMkJBQTJCO0lBQzNCLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUNkLE1BQU0sRUFBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFDNUIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNuQyxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzVCLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksR0FBRyxFQUFrQixDQUFDLENBQUM7WUFFdkQsY0FBYyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQy9DLENBQUM7UUFDRCxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDckIsT0FBTztJQUNULENBQUM7SUFFRCwyQkFBMkI7SUFDM0IsTUFBTSxFQUFDLFVBQVUsRUFBRSxRQUFRLEVBQUMsR0FBMEIsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUU3RCxNQUFNLElBQUksR0FBYSxFQUFFLENBQUM7SUFDMUIsTUFBTSxJQUFJLEdBQWEsRUFBRSxDQUFDO0lBQzFCLE1BQU0sSUFBSSxHQUFhLEVBQUUsQ0FBQztJQUUxQiw4QkFBOEI7SUFDOUIscURBQXFEO0lBQ3JELGlGQUFpRjtJQUdqRix5RkFBeUY7SUFDekYsS0FBSyxJQUFJLENBQUMsR0FBRyxVQUFVLEVBQUUsQ0FBQyxHQUFHLFFBQVEsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1FBQzNDLE1BQU0sSUFBSSxHQUFHLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkMsSUFBSSxDQUFDLElBQUk7WUFDUCxTQUFTO1FBRVgsMEVBQTBFO1FBQzFFLHVEQUF1RDtRQUN2RCxNQUFNLFdBQVcsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQy9DLEtBQUssTUFBTSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxXQUFXLEVBQUUsQ0FBQztZQUNsQyxJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUM7WUFDWiwwQ0FBMEM7WUFDMUMsNkNBQTZDO1lBQzdDLEtBQUssTUFBTSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsSUFBSSxXQUFXLEVBQUUsQ0FBQztnQkFDbkMsMkJBQTJCO2dCQUMzQixNQUFNLElBQUksR0FBRyxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDNUMsSUFBSSxJQUFJO29CQUNOLEdBQUcsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLENBQUM7WUFFRCxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDakIsQ0FBQztJQUNILENBQUM7SUFHRCxXQUFXLENBQUMsRUFBQyxDQUFDLEVBQUUsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxFQUFFLElBQUksV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsRUFBQyxDQUFDLENBQUM7QUFDdEcsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5cbmNvbnN0IGluZGV4ZXNNYXBSb3dzID0gbmV3IE1hcDxudW1iZXIsIE1hcDxudW1iZXIsIG51bWJlcj4+KCk7XG5cbm9ubWVzc2FnZSA9IChlKSA9PiB7XG4gIC8vIGluaXQgc3RlcCBmb3IgdGhlIHdvcmtlclxuICBpZiAoZS5kYXRhLmlzKSB7XG4gICAgY29uc3Qge2lzLCBqcywgZHN9ID0gZS5kYXRhO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgaXMubGVuZ3RoOyBpKyspIHtcbiAgICAgIGlmICghaW5kZXhlc01hcFJvd3MuaGFzKGlzW2ldKSlcbiAgICAgICAgaW5kZXhlc01hcFJvd3Muc2V0KGlzW2ldLCBuZXcgTWFwPG51bWJlciwgbnVtYmVyPigpKTtcblxuICAgICAgaW5kZXhlc01hcFJvd3MuZ2V0KGlzW2ldKSEuc2V0KGpzW2ldLCBkc1tpXSk7XG4gICAgfVxuICAgIHBvc3RNZXNzYWdlKCdyZWFkeScpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIG1haW4gc3RlcCBmb3IgdGhlIHdvcmtlclxuICBjb25zdCB7YmxvY2tTdGFydCwgYmxvY2tFbmR9OiB7W186IHN0cmluZ106IG51bWJlcn0gPSBlLmRhdGE7XG5cbiAgY29uc3QgcmVzSTogbnVtYmVyW10gPSBbXTtcbiAgY29uc3QgcmVzSjogbnVtYmVyW10gPSBbXTtcbiAgY29uc3QgcmVzRDogbnVtYmVyW10gPSBbXTtcblxuICAvLyB3ZSBkbyBvcGVyYXRpb25zIHJvdyBieSByb3dcbiAgLy8gdGhlcmVmb3JlLCBpdGVyYXRpbmcgb3ZlciBhbGwgY29sdW1ucyBpcyBuZWNlc3NhcnlcbiAgLy8gZ3JhcGhpY2FsbHkgc3BlYWtpbmcsIG9uZSB3b3JrZXIgaXMgd29ya2luZyBvbiBhIGhvcml6b250YWwgc3RyaXBlIGluIGEgbWF0cml4XG5cblxuICAvLyBibG9ja3N0YXJ0IGFuZCBibG9ja2VuZCBhcmUgdGhlIGluZGV4ZXMgb2YgdGhlIHJvd3MgdGhhdCB0aGUgd29ya2VyIGlzIHJlc3BvbnNpYmxlIGZvclxuICBmb3IgKGxldCBpID0gYmxvY2tTdGFydDsgaSA8IGJsb2NrRW5kOyBpKyspIHtcbiAgICBjb25zdCBpTWFwID0gaW5kZXhlc01hcFJvd3MuZ2V0KGkpO1xuICAgIGlmICghaU1hcClcbiAgICAgIGNvbnRpbnVlO1xuXG4gICAgLy8gdGhpcyB3b3JrZXIgaXMgcmVzcG9uc2libGUgZm9yIGV2ZXJ5IG5vbnplcm8gdmFsdWUgaW4gdGhlIHJvdyAob3IgaU1hcClcbiAgICAvLyBzaW5jZSB3ZSBhcmUgdXNpbmcgaU1hcCBhIGxvdCwgd2UgY2FuIG1hdGVyaWFsaXplIGl0XG4gICAgY29uc3QgaU1hcEVudHJpZXMgPSBBcnJheS5mcm9tKGlNYXAuZW50cmllcygpKTtcbiAgICBmb3IgKGNvbnN0IFtrLCBfdl0gb2YgaU1hcEVudHJpZXMpIHtcbiAgICAgIGxldCBzdW0gPSAwO1xuICAgICAgLy8gaGVyZSB3ZSBrbm93IHRoYXQgdGhlIHZhbHVlIGlzIG5vdCB6ZXJvXG4gICAgICAvLyB0aGVyZWZvcmUsIHdlIGNhbiBpdGVyYXRlIG92ZXIgdGhlIGNvbHVtbnNcbiAgICAgIGZvciAoY29uc3QgW2sxLCB2MV0gb2YgaU1hcEVudHJpZXMpIHtcbiAgICAgICAgLy8gaGVyZSB3ZSBjaGVjayB0aGUgY29sdW1uXG4gICAgICAgIGNvbnN0IGpWYWwgPSBpbmRleGVzTWFwUm93cy5nZXQoazEpPy5nZXQoayk7XG4gICAgICAgIGlmIChqVmFsKVxuICAgICAgICAgIHN1bSArPSB2MSAqIGpWYWw7XG4gICAgICB9XG5cbiAgICAgIHJlc0kucHVzaChpKTtcbiAgICAgIHJlc0oucHVzaChrKTtcbiAgICAgIHJlc0QucHVzaChzdW0pO1xuICAgIH1cbiAgfVxuXG5cbiAgcG9zdE1lc3NhZ2Uoe2k6IG5ldyBVaW50MzJBcnJheShyZXNJKSwgajogbmV3IFVpbnQzMkFycmF5KHJlc0opLCBkaXN0YW5jZTogbmV3IEZsb2F0MzJBcnJheShyZXNEKX0pO1xufTtcbiJdfQ=="],"names":[],"sourceRoot":""}
@@ -0,0 +1,284 @@
1
+ var eda;
2
+ /******/ (() => { // webpackBootstrap
3
+ /******/ "use strict";
4
+ /******/ var __webpack_modules__ = ({
5
+
6
+ /***/ "./node_modules/@datagrok-libraries/ml/src/distance-matrix/distance-matrix-worker.js":
7
+ /*!*******************************************************************************************!*\
8
+ !*** ./node_modules/@datagrok-libraries/ml/src/distance-matrix/distance-matrix-worker.js ***!
9
+ \*******************************************************************************************/
10
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
11
+
12
+ __webpack_require__.r(__webpack_exports__);
13
+ /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./utils */ "./node_modules/@datagrok-libraries/ml/src/distance-matrix/utils.js");
14
+ /* harmony import */ var _typed_metrics__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../typed-metrics */ "./node_modules/@datagrok-libraries/ml/src/typed-metrics/index.js");
15
+ /* harmony import */ var _datagrok_libraries_utils_src_bit_array__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @datagrok-libraries/utils/src/bit-array */ "./node_modules/@datagrok-libraries/utils/src/bit-array.js");
16
+
17
+
18
+
19
+ onmessage = (event) => {
20
+ const { values, fnNames, startRow, startCol, chunckSize, opts, weights, aggregationMethod } = event.data;
21
+ const data = {};
22
+ try {
23
+ let i = startRow;
24
+ let j = startCol;
25
+ let cnt = 0;
26
+ let lmin = 0;
27
+ let lmax = Number.MIN_VALUE;
28
+ const aggregate = (0,_utils__WEBPACK_IMPORTED_MODULE_0__.getAggregationFunction)(aggregationMethod, weights);
29
+ values.forEach((v, colIdx) => {
30
+ if ((0,_typed_metrics__WEBPACK_IMPORTED_MODULE_1__.isBitArrayMetric)(fnNames[colIdx])) {
31
+ for (let mi = 0; mi < v.length; ++mi) {
32
+ if ((0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(v[mi]))
33
+ continue;
34
+ values[colIdx][mi] = new _datagrok_libraries_utils_src_bit_array__WEBPACK_IMPORTED_MODULE_2__["default"](values[colIdx][mi]._data, values[colIdx][mi]._length);
35
+ }
36
+ }
37
+ });
38
+ const distanceFns = new Array(fnNames.length)
39
+ .fill(null)
40
+ .map((_, di) => new _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.Measure(fnNames[di]).getMeasure(opts[di]));
41
+ const retVal = new Float32Array(chunckSize);
42
+ while (cnt < chunckSize) {
43
+ const distanceValues = distanceFns.map((fn, idx) => !(0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(values[idx][i]) && !(0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(values[idx][j]) ?
44
+ fn(values[idx][i], values[idx][j]) : 1);
45
+ const value = distanceValues.length === 1 ? distanceValues[0] : aggregate(distanceValues);
46
+ retVal[cnt] = value;
47
+ if (value < lmin)
48
+ lmin = value;
49
+ if (value > lmax)
50
+ lmax = value;
51
+ cnt++;
52
+ j++;
53
+ if (j === values[0].length) {
54
+ i++;
55
+ j = i + 1;
56
+ }
57
+ }
58
+ data.distanceMatrixData = retVal;
59
+ data.min = lmin;
60
+ data.max = lmax;
61
+ }
62
+ catch (e) {
63
+ data.error = e;
64
+ }
65
+ postMessage(data);
66
+ };
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzdGFuY2UtbWF0cml4LXdvcmtlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImRpc3RhbmNlLW1hdHJpeC13b3JrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHNCQUFzQixFQUFFLEtBQUssRUFBQyxNQUFNLFNBQVMsQ0FBQztBQUN0RCxPQUFPLEVBQWUsT0FBTyxFQUFFLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDekUsT0FBTyxRQUFRLE1BQU0seUNBQXlDLENBQUM7QUFHL0QsU0FBUyxHQUFHLENBQUMsS0FBSyxFQUFFLEVBQUU7SUFDcEIsTUFBTSxFQUFDLE1BQU0sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBQyxHQUdyRixLQUFLLENBQUMsSUFBSSxDQUFDO0lBQ2YsTUFBTSxJQUFJLEdBQWtGLEVBQUUsQ0FBQztJQUMvRixJQUFJLENBQUM7UUFDSCxJQUFJLENBQUMsR0FBRyxRQUFRLENBQUM7UUFDakIsSUFBSSxDQUFDLEdBQUcsUUFBUSxDQUFDO1FBQ2pCLElBQUksR0FBRyxHQUFHLENBQUMsQ0FBQztRQUNaLElBQUksSUFBSSxHQUFHLENBQUMsQ0FBQztRQUNiLElBQUksSUFBSSxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUM7UUFDNUIsTUFBTSxTQUFTLEdBQUcsc0JBQXNCLENBQUMsaUJBQWlCLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDckUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUMzQixJQUFJLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQ3RDLEtBQUssSUFBSSxFQUFFLEdBQUcsQ0FBQyxFQUFFLEVBQUUsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUM7b0JBQ3JDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQzt3QkFBRSxTQUFTO29CQUMzQixNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQzFGLENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDSCxNQUFNLFdBQVcsR0FBRyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDO2FBQzFDLElBQUksQ0FBQyxJQUFJLENBQUM7YUFDVixHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNqRSxNQUFNLE1BQU0sR0FBRyxJQUFJLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUM1QyxPQUFPLEdBQUcsR0FBRyxVQUFVLEVBQUUsQ0FBQztZQUN4QixNQUFNLGNBQWMsR0FBRyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDcEcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDMUMsTUFBTSxLQUFLLEdBQUcsY0FBYyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1lBQzFGLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUM7WUFDcEIsSUFBSSxLQUFLLEdBQUcsSUFBSTtnQkFDZCxJQUFJLEdBQUcsS0FBSyxDQUFDO1lBQ2YsSUFBSSxLQUFLLEdBQUcsSUFBSTtnQkFDZCxJQUFJLEdBQUcsS0FBSyxDQUFDO1lBQ2YsR0FBRyxFQUFFLENBQUM7WUFDTixDQUFDLEVBQUUsQ0FBQztZQUNKLElBQUksQ0FBQyxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDM0IsQ0FBQyxFQUFFLENBQUM7Z0JBQ0osQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDWixDQUFDO1FBQ0gsQ0FBQztRQUNELElBQUksQ0FBQyxrQkFBa0IsR0FBRyxNQUFNLENBQUM7UUFDakMsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUM7UUFDaEIsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUM7SUFDbEIsQ0FBQztJQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDWCxJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQztJQUNqQixDQUFDO0lBQ0QsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ3BCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Z2V0QWdncmVnYXRpb25GdW5jdGlvbiwgaXNOaWx9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHtLbm93bk1ldHJpY3MsIE1lYXN1cmUsIGlzQml0QXJyYXlNZXRyaWN9IGZyb20gJy4uL3R5cGVkLW1ldHJpY3MnO1xuaW1wb3J0IEJpdEFycmF5IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL2JpdC1hcnJheSc7XG5pbXBvcnQge0Rpc3RhbmNlQWdncmVnYXRpb25NZXRob2R9IGZyb20gJy4vdHlwZXMnO1xuXG5vbm1lc3NhZ2UgPSAoZXZlbnQpID0+IHtcbiAgY29uc3Qge3ZhbHVlcywgZm5OYW1lcywgc3RhcnRSb3csIHN0YXJ0Q29sLCBjaHVuY2tTaXplLCBvcHRzLCB3ZWlnaHRzLCBhZ2dyZWdhdGlvbk1ldGhvZH06IHtcbiAgICB2YWx1ZXM6IGFueVtdW10sIGZuTmFtZXM6IEtub3duTWV0cmljc1tdLCBzdGFydFJvdzogbnVtYmVyLCBzdGFydENvbDogbnVtYmVyLCBjaHVuY2tTaXplOiBudW1iZXIsXG4gICAgb3B0czoge1tfOiBzdHJpbmddOiBhbnl9W10sIHdlaWdodHM6IG51bWJlcltdLCBhZ2dyZWdhdGlvbk1ldGhvZDogRGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZCxcbiAgfSA9IGV2ZW50LmRhdGE7XG4gIGNvbnN0IGRhdGE6IHsgZXJyb3I/OiBhbnksIGRpc3RhbmNlTWF0cml4RGF0YT86IEZsb2F0MzJBcnJheSwgbWluPzogbnVtYmVyLCBtYXg/OiBudW1iZXJ9ID0ge307XG4gIHRyeSB7XG4gICAgbGV0IGkgPSBzdGFydFJvdztcbiAgICBsZXQgaiA9IHN0YXJ0Q29sO1xuICAgIGxldCBjbnQgPSAwO1xuICAgIGxldCBsbWluID0gMDtcbiAgICBsZXQgbG1heCA9IE51bWJlci5NSU5fVkFMVUU7XG4gICAgY29uc3QgYWdncmVnYXRlID0gZ2V0QWdncmVnYXRpb25GdW5jdGlvbihhZ2dyZWdhdGlvbk1ldGhvZCwgd2VpZ2h0cyk7XG4gICAgdmFsdWVzLmZvckVhY2goKHYsIGNvbElkeCkgPT4ge1xuICAgICAgaWYgKGlzQml0QXJyYXlNZXRyaWMoZm5OYW1lc1tjb2xJZHhdKSkge1xuICAgICAgICBmb3IgKGxldCBtaSA9IDA7IG1pIDwgdi5sZW5ndGg7ICsrbWkpIHtcbiAgICAgICAgICBpZiAoaXNOaWwodlttaV0pKSBjb250aW51ZTtcbiAgICAgICAgICB2YWx1ZXNbY29sSWR4XVttaV0gPSBuZXcgQml0QXJyYXkodmFsdWVzW2NvbElkeF1bbWldLl9kYXRhLCB2YWx1ZXNbY29sSWR4XVttaV0uX2xlbmd0aCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbiAgICBjb25zdCBkaXN0YW5jZUZucyA9IG5ldyBBcnJheShmbk5hbWVzLmxlbmd0aClcbiAgICAgIC5maWxsKG51bGwpXG4gICAgICAubWFwKChfLCBkaSkgPT4gbmV3IE1lYXN1cmUoZm5OYW1lc1tkaV0pLmdldE1lYXN1cmUob3B0c1tkaV0pKTtcbiAgICBjb25zdCByZXRWYWwgPSBuZXcgRmxvYXQzMkFycmF5KGNodW5ja1NpemUpO1xuICAgIHdoaWxlIChjbnQgPCBjaHVuY2tTaXplKSB7XG4gICAgICBjb25zdCBkaXN0YW5jZVZhbHVlcyA9IGRpc3RhbmNlRm5zLm1hcCgoZm4sIGlkeCkgPT4gIWlzTmlsKHZhbHVlc1tpZHhdW2ldKSAmJiAhaXNOaWwodmFsdWVzW2lkeF1bal0pID9cbiAgICAgICAgZm4odmFsdWVzW2lkeF1baV0sIHZhbHVlc1tpZHhdW2pdKSA6IDEpO1xuICAgICAgY29uc3QgdmFsdWUgPSBkaXN0YW5jZVZhbHVlcy5sZW5ndGggPT09IDEgPyBkaXN0YW5jZVZhbHVlc1swXSA6IGFnZ3JlZ2F0ZShkaXN0YW5jZVZhbHVlcyk7XG4gICAgICByZXRWYWxbY250XSA9IHZhbHVlO1xuICAgICAgaWYgKHZhbHVlIDwgbG1pbilcbiAgICAgICAgbG1pbiA9IHZhbHVlO1xuICAgICAgaWYgKHZhbHVlID4gbG1heClcbiAgICAgICAgbG1heCA9IHZhbHVlO1xuICAgICAgY250Kys7XG4gICAgICBqKys7XG4gICAgICBpZiAoaiA9PT0gdmFsdWVzWzBdLmxlbmd0aCkge1xuICAgICAgICBpKys7XG4gICAgICAgIGogPSBpICsgMTtcbiAgICAgIH1cbiAgICB9XG4gICAgZGF0YS5kaXN0YW5jZU1hdHJpeERhdGEgPSByZXRWYWw7XG4gICAgZGF0YS5taW4gPSBsbWluO1xuICAgIGRhdGEubWF4ID0gbG1heDtcbiAgfSBjYXRjaCAoZSkge1xuICAgIGRhdGEuZXJyb3IgPSBlO1xuICB9XG4gIHBvc3RNZXNzYWdlKGRhdGEpO1xufTtcbiJdfQ==
68
+
69
+ /***/ })
70
+
71
+ /******/ });
72
+ /************************************************************************/
73
+ /******/ // The module cache
74
+ /******/ var __webpack_module_cache__ = {};
75
+ /******/
76
+ /******/ // The require function
77
+ /******/ function __webpack_require__(moduleId) {
78
+ /******/ // Check if module is in cache
79
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
80
+ /******/ if (cachedModule !== undefined) {
81
+ /******/ return cachedModule.exports;
82
+ /******/ }
83
+ /******/ // Create a new module (and put it into the cache)
84
+ /******/ var module = __webpack_module_cache__[moduleId] = {
85
+ /******/ // no module.id needed
86
+ /******/ // no module.loaded needed
87
+ /******/ exports: {}
88
+ /******/ };
89
+ /******/
90
+ /******/ // Execute the module function
91
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
92
+ /******/
93
+ /******/ // Return the exports of the module
94
+ /******/ return module.exports;
95
+ /******/ }
96
+ /******/
97
+ /******/ // expose the modules object (__webpack_modules__)
98
+ /******/ __webpack_require__.m = __webpack_modules__;
99
+ /******/
100
+ /******/ // the startup function
101
+ /******/ __webpack_require__.x = () => {
102
+ /******/ // Load entry module and return exports
103
+ /******/ // This entry module depends on other loaded chunks and execution need to be delayed
104
+ /******/ var __webpack_exports__ = __webpack_require__.O(undefined, ["vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2"], () => (__webpack_require__("./node_modules/@datagrok-libraries/ml/src/distance-matrix/distance-matrix-worker.js")))
105
+ /******/ __webpack_exports__ = __webpack_require__.O(__webpack_exports__);
106
+ /******/ return __webpack_exports__;
107
+ /******/ };
108
+ /******/
109
+ /************************************************************************/
110
+ /******/ /* webpack/runtime/chunk loaded */
111
+ /******/ (() => {
112
+ /******/ var deferred = [];
113
+ /******/ __webpack_require__.O = (result, chunkIds, fn, priority) => {
114
+ /******/ if(chunkIds) {
115
+ /******/ priority = priority || 0;
116
+ /******/ for(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];
117
+ /******/ deferred[i] = [chunkIds, fn, priority];
118
+ /******/ return;
119
+ /******/ }
120
+ /******/ var notFulfilled = Infinity;
121
+ /******/ for (var i = 0; i < deferred.length; i++) {
122
+ /******/ var [chunkIds, fn, priority] = deferred[i];
123
+ /******/ var fulfilled = true;
124
+ /******/ for (var j = 0; j < chunkIds.length; j++) {
125
+ /******/ if ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {
126
+ /******/ chunkIds.splice(j--, 1);
127
+ /******/ } else {
128
+ /******/ fulfilled = false;
129
+ /******/ if(priority < notFulfilled) notFulfilled = priority;
130
+ /******/ }
131
+ /******/ }
132
+ /******/ if(fulfilled) {
133
+ /******/ deferred.splice(i--, 1)
134
+ /******/ var r = fn();
135
+ /******/ if (r !== undefined) result = r;
136
+ /******/ }
137
+ /******/ }
138
+ /******/ return result;
139
+ /******/ };
140
+ /******/ })();
141
+ /******/
142
+ /******/ /* webpack/runtime/define property getters */
143
+ /******/ (() => {
144
+ /******/ // define getter functions for harmony exports
145
+ /******/ __webpack_require__.d = (exports, definition) => {
146
+ /******/ for(var key in definition) {
147
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
148
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
149
+ /******/ }
150
+ /******/ }
151
+ /******/ };
152
+ /******/ })();
153
+ /******/
154
+ /******/ /* webpack/runtime/ensure chunk */
155
+ /******/ (() => {
156
+ /******/ __webpack_require__.f = {};
157
+ /******/ // This file contains only the entry chunk.
158
+ /******/ // The chunk loading function for additional chunks
159
+ /******/ __webpack_require__.e = (chunkId) => {
160
+ /******/ return Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {
161
+ /******/ __webpack_require__.f[key](chunkId, promises);
162
+ /******/ return promises;
163
+ /******/ }, []));
164
+ /******/ };
165
+ /******/ })();
166
+ /******/
167
+ /******/ /* webpack/runtime/get javascript chunk filename */
168
+ /******/ (() => {
169
+ /******/ // This function allow to reference async chunks and sibling chunks for the entrypoint
170
+ /******/ __webpack_require__.u = (chunkId) => {
171
+ /******/ // return url for filenames based on template
172
+ /******/ return "" + chunkId + ".js";
173
+ /******/ };
174
+ /******/ })();
175
+ /******/
176
+ /******/ /* webpack/runtime/global */
177
+ /******/ (() => {
178
+ /******/ __webpack_require__.g = (function() {
179
+ /******/ if (typeof globalThis === 'object') return globalThis;
180
+ /******/ try {
181
+ /******/ return this || new Function('return this')();
182
+ /******/ } catch (e) {
183
+ /******/ if (typeof window === 'object') return window;
184
+ /******/ }
185
+ /******/ })();
186
+ /******/ })();
187
+ /******/
188
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
189
+ /******/ (() => {
190
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
191
+ /******/ })();
192
+ /******/
193
+ /******/ /* webpack/runtime/make namespace object */
194
+ /******/ (() => {
195
+ /******/ // define __esModule on exports
196
+ /******/ __webpack_require__.r = (exports) => {
197
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
198
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
199
+ /******/ }
200
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
201
+ /******/ };
202
+ /******/ })();
203
+ /******/
204
+ /******/ /* webpack/runtime/publicPath */
205
+ /******/ (() => {
206
+ /******/ var scriptUrl;
207
+ /******/ if (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + "";
208
+ /******/ var document = __webpack_require__.g.document;
209
+ /******/ if (!scriptUrl && document) {
210
+ /******/ if (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT')
211
+ /******/ scriptUrl = document.currentScript.src;
212
+ /******/ if (!scriptUrl) {
213
+ /******/ var scripts = document.getElementsByTagName("script");
214
+ /******/ if(scripts.length) {
215
+ /******/ var i = scripts.length - 1;
216
+ /******/ while (i > -1 && (!scriptUrl || !/^http(s?):/.test(scriptUrl))) scriptUrl = scripts[i--].src;
217
+ /******/ }
218
+ /******/ }
219
+ /******/ }
220
+ /******/ // When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration
221
+ /******/ // or pass an empty string ("") and set the __webpack_public_path__ variable from your code to use your own logic.
222
+ /******/ if (!scriptUrl) throw new Error("Automatic publicPath is not supported in this browser");
223
+ /******/ scriptUrl = scriptUrl.replace(/^blob:/, "").replace(/#.*$/, "").replace(/\?.*$/, "").replace(/\/[^\/]+$/, "/");
224
+ /******/ __webpack_require__.p = scriptUrl;
225
+ /******/ })();
226
+ /******/
227
+ /******/ /* webpack/runtime/importScripts chunk loading */
228
+ /******/ (() => {
229
+ /******/ // no baseURI
230
+ /******/
231
+ /******/ // object to store loaded chunks
232
+ /******/ // "1" means "already loaded"
233
+ /******/ var installedChunks = {
234
+ /******/ "node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js": 1
235
+ /******/ };
236
+ /******/
237
+ /******/ // importScripts chunk loading
238
+ /******/ var installChunk = (data) => {
239
+ /******/ var [chunkIds, moreModules, runtime] = data;
240
+ /******/ for(var moduleId in moreModules) {
241
+ /******/ if(__webpack_require__.o(moreModules, moduleId)) {
242
+ /******/ __webpack_require__.m[moduleId] = moreModules[moduleId];
243
+ /******/ }
244
+ /******/ }
245
+ /******/ if(runtime) runtime(__webpack_require__);
246
+ /******/ while(chunkIds.length)
247
+ /******/ installedChunks[chunkIds.pop()] = 1;
248
+ /******/ parentChunkLoadingFunction(data);
249
+ /******/ };
250
+ /******/ __webpack_require__.f.i = (chunkId, promises) => {
251
+ /******/ // "1" is the signal for "already loaded"
252
+ /******/ if(!installedChunks[chunkId]) {
253
+ /******/ if(true) { // all chunks have JS
254
+ /******/ importScripts(__webpack_require__.p + __webpack_require__.u(chunkId));
255
+ /******/ }
256
+ /******/ }
257
+ /******/ };
258
+ /******/
259
+ /******/ var chunkLoadingGlobal = self["webpackChunkeda"] = self["webpackChunkeda"] || [];
260
+ /******/ var parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);
261
+ /******/ chunkLoadingGlobal.push = installChunk;
262
+ /******/
263
+ /******/ // no HMR
264
+ /******/
265
+ /******/ // no HMR manifest
266
+ /******/ })();
267
+ /******/
268
+ /******/ /* webpack/runtime/startup chunk dependencies */
269
+ /******/ (() => {
270
+ /******/ var next = __webpack_require__.x;
271
+ /******/ __webpack_require__.x = () => {
272
+ /******/ return __webpack_require__.e("vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2").then(next);
273
+ /******/ };
274
+ /******/ })();
275
+ /******/
276
+ /************************************************************************/
277
+ /******/
278
+ /******/ // run startup
279
+ /******/ var __webpack_exports__ = __webpack_require__.x();
280
+ /******/ eda = __webpack_exports__;
281
+ /******/
282
+ /******/ })()
283
+ ;
284
+ //# sourceMappingURL=node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js.js","mappings":";;;;;;;;;;;;;;;AAAwD;AACK;AACE;AAC/D;AACA,YAAY,oFAAoF;AAChG;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,8DAAsB;AAChD;AACA,gBAAgB,gEAAgB;AAChC,iCAAiC,eAAe;AAChD,wBAAwB,6CAAK;AAC7B;AACA,6CAA6C,+EAAQ;AACrD;AACA;AACA,SAAS;AACT;AACA;AACA,gCAAgC,mDAAO;AACvC;AACA;AACA,iEAAiE,6CAAK,qBAAqB,6CAAK;AAChG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C,m9L;;;;;;UCnD3C;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;;;;WClCA;WACA;WACA;WACA;WACA,+BAA+B,wCAAwC;WACvE;WACA;WACA;WACA;WACA,iBAAiB,qBAAqB;WACtC;WACA;WACA,kBAAkB,qBAAqB;WACvC;WACA;WACA,KAAK;WACL;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,E;;;;;WC3BA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA,E;;;;;WCPA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,EAAE;WACF,E;;;;;WCRA;WACA;WACA;WACA;WACA,E;;;;;WCJA;WACA;WACA;WACA;WACA,GAAG;WACH;WACA;WACA,CAAC,I;;;;;WCPD,wF;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D,E;;;;;WCNA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,kC;;;;;WClBA;;WAEA;WACA;WACA;WACA;WACA;;WAEA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,aAAa;WACb;WACA;WACA;WACA;;WAEA;WACA;WACA;;WAEA;;WAEA,kB;;;;;WCpCA;WACA;WACA;WACA,E;;;;;UEHA;UACA","sources":["webpack://eda/./node_modules/@datagrok-libraries/ml/src/distance-matrix/distance-matrix-worker.js","webpack://eda/webpack/bootstrap","webpack://eda/webpack/runtime/chunk loaded","webpack://eda/webpack/runtime/define property getters","webpack://eda/webpack/runtime/ensure chunk","webpack://eda/webpack/runtime/get javascript chunk filename","webpack://eda/webpack/runtime/global","webpack://eda/webpack/runtime/hasOwnProperty shorthand","webpack://eda/webpack/runtime/make namespace object","webpack://eda/webpack/runtime/publicPath","webpack://eda/webpack/runtime/importScripts chunk loading","webpack://eda/webpack/runtime/startup chunk dependencies","webpack://eda/webpack/before-startup","webpack://eda/webpack/startup","webpack://eda/webpack/after-startup"],"sourcesContent":["import { getAggregationFunction, isNil } from './utils';\nimport { Measure, isBitArrayMetric } from '../typed-metrics';\nimport BitArray from '@datagrok-libraries/utils/src/bit-array';\nonmessage = (event) => {\n const { values, fnNames, startRow, startCol, chunckSize, opts, weights, aggregationMethod } = event.data;\n const data = {};\n try {\n let i = startRow;\n let j = startCol;\n let cnt = 0;\n let lmin = 0;\n let lmax = Number.MIN_VALUE;\n const aggregate = getAggregationFunction(aggregationMethod, weights);\n values.forEach((v, colIdx) => {\n if (isBitArrayMetric(fnNames[colIdx])) {\n for (let mi = 0; mi < v.length; ++mi) {\n if (isNil(v[mi]))\n continue;\n values[colIdx][mi] = new BitArray(values[colIdx][mi]._data, values[colIdx][mi]._length);\n }\n }\n });\n const distanceFns = new Array(fnNames.length)\n .fill(null)\n .map((_, di) => new Measure(fnNames[di]).getMeasure(opts[di]));\n const retVal = new Float32Array(chunckSize);\n while (cnt < chunckSize) {\n const distanceValues = distanceFns.map((fn, idx) => !isNil(values[idx][i]) && !isNil(values[idx][j]) ?\n fn(values[idx][i], values[idx][j]) : 1);\n const value = distanceValues.length === 1 ? distanceValues[0] : aggregate(distanceValues);\n retVal[cnt] = value;\n if (value < lmin)\n lmin = value;\n if (value > lmax)\n lmax = value;\n cnt++;\n j++;\n if (j === values[0].length) {\n i++;\n j = i + 1;\n }\n }\n data.distanceMatrixData = retVal;\n data.min = lmin;\n data.max = lmax;\n }\n catch (e) {\n data.error = e;\n }\n postMessage(data);\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzdGFuY2UtbWF0cml4LXdvcmtlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImRpc3RhbmNlLW1hdHJpeC13b3JrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHNCQUFzQixFQUFFLEtBQUssRUFBQyxNQUFNLFNBQVMsQ0FBQztBQUN0RCxPQUFPLEVBQWUsT0FBTyxFQUFFLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDekUsT0FBTyxRQUFRLE1BQU0seUNBQXlDLENBQUM7QUFHL0QsU0FBUyxHQUFHLENBQUMsS0FBSyxFQUFFLEVBQUU7SUFDcEIsTUFBTSxFQUFDLE1BQU0sRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBQyxHQUdyRixLQUFLLENBQUMsSUFBSSxDQUFDO0lBQ2YsTUFBTSxJQUFJLEdBQWtGLEVBQUUsQ0FBQztJQUMvRixJQUFJLENBQUM7UUFDSCxJQUFJLENBQUMsR0FBRyxRQUFRLENBQUM7UUFDakIsSUFBSSxDQUFDLEdBQUcsUUFBUSxDQUFDO1FBQ2pCLElBQUksR0FBRyxHQUFHLENBQUMsQ0FBQztRQUNaLElBQUksSUFBSSxHQUFHLENBQUMsQ0FBQztRQUNiLElBQUksSUFBSSxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUM7UUFDNUIsTUFBTSxTQUFTLEdBQUcsc0JBQXNCLENBQUMsaUJBQWlCLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDckUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUMzQixJQUFJLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQ3RDLEtBQUssSUFBSSxFQUFFLEdBQUcsQ0FBQyxFQUFFLEVBQUUsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUM7b0JBQ3JDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQzt3QkFBRSxTQUFTO29CQUMzQixNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQzFGLENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDSCxNQUFNLFdBQVcsR0FBRyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDO2FBQzFDLElBQUksQ0FBQyxJQUFJLENBQUM7YUFDVixHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNqRSxNQUFNLE1BQU0sR0FBRyxJQUFJLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUM1QyxPQUFPLEdBQUcsR0FBRyxVQUFVLEVBQUUsQ0FBQztZQUN4QixNQUFNLGNBQWMsR0FBRyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDcEcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDMUMsTUFBTSxLQUFLLEdBQUcsY0FBYyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1lBQzFGLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLENBQUM7WUFDcEIsSUFBSSxLQUFLLEdBQUcsSUFBSTtnQkFDZCxJQUFJLEdBQUcsS0FBSyxDQUFDO1lBQ2YsSUFBSSxLQUFLLEdBQUcsSUFBSTtnQkFDZCxJQUFJLEdBQUcsS0FBSyxDQUFDO1lBQ2YsR0FBRyxFQUFFLENBQUM7WUFDTixDQUFDLEVBQUUsQ0FBQztZQUNKLElBQUksQ0FBQyxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDM0IsQ0FBQyxFQUFFLENBQUM7Z0JBQ0osQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDWixDQUFDO1FBQ0gsQ0FBQztRQUNELElBQUksQ0FBQyxrQkFBa0IsR0FBRyxNQUFNLENBQUM7UUFDakMsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUM7UUFDaEIsSUFBSSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUM7SUFDbEIsQ0FBQztJQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDWCxJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQztJQUNqQixDQUFDO0lBQ0QsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ3BCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Z2V0QWdncmVnYXRpb25GdW5jdGlvbiwgaXNOaWx9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHtLbm93bk1ldHJpY3MsIE1lYXN1cmUsIGlzQml0QXJyYXlNZXRyaWN9IGZyb20gJy4uL3R5cGVkLW1ldHJpY3MnO1xuaW1wb3J0IEJpdEFycmF5IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL2JpdC1hcnJheSc7XG5pbXBvcnQge0Rpc3RhbmNlQWdncmVnYXRpb25NZXRob2R9IGZyb20gJy4vdHlwZXMnO1xuXG5vbm1lc3NhZ2UgPSAoZXZlbnQpID0+IHtcbiAgY29uc3Qge3ZhbHVlcywgZm5OYW1lcywgc3RhcnRSb3csIHN0YXJ0Q29sLCBjaHVuY2tTaXplLCBvcHRzLCB3ZWlnaHRzLCBhZ2dyZWdhdGlvbk1ldGhvZH06IHtcbiAgICB2YWx1ZXM6IGFueVtdW10sIGZuTmFtZXM6IEtub3duTWV0cmljc1tdLCBzdGFydFJvdzogbnVtYmVyLCBzdGFydENvbDogbnVtYmVyLCBjaHVuY2tTaXplOiBudW1iZXIsXG4gICAgb3B0czoge1tfOiBzdHJpbmddOiBhbnl9W10sIHdlaWdodHM6IG51bWJlcltdLCBhZ2dyZWdhdGlvbk1ldGhvZDogRGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZCxcbiAgfSA9IGV2ZW50LmRhdGE7XG4gIGNvbnN0IGRhdGE6IHsgZXJyb3I/OiBhbnksIGRpc3RhbmNlTWF0cml4RGF0YT86IEZsb2F0MzJBcnJheSwgbWluPzogbnVtYmVyLCBtYXg/OiBudW1iZXJ9ID0ge307XG4gIHRyeSB7XG4gICAgbGV0IGkgPSBzdGFydFJvdztcbiAgICBsZXQgaiA9IHN0YXJ0Q29sO1xuICAgIGxldCBjbnQgPSAwO1xuICAgIGxldCBsbWluID0gMDtcbiAgICBsZXQgbG1heCA9IE51bWJlci5NSU5fVkFMVUU7XG4gICAgY29uc3QgYWdncmVnYXRlID0gZ2V0QWdncmVnYXRpb25GdW5jdGlvbihhZ2dyZWdhdGlvbk1ldGhvZCwgd2VpZ2h0cyk7XG4gICAgdmFsdWVzLmZvckVhY2goKHYsIGNvbElkeCkgPT4ge1xuICAgICAgaWYgKGlzQml0QXJyYXlNZXRyaWMoZm5OYW1lc1tjb2xJZHhdKSkge1xuICAgICAgICBmb3IgKGxldCBtaSA9IDA7IG1pIDwgdi5sZW5ndGg7ICsrbWkpIHtcbiAgICAgICAgICBpZiAoaXNOaWwodlttaV0pKSBjb250aW51ZTtcbiAgICAgICAgICB2YWx1ZXNbY29sSWR4XVttaV0gPSBuZXcgQml0QXJyYXkodmFsdWVzW2NvbElkeF1bbWldLl9kYXRhLCB2YWx1ZXNbY29sSWR4XVttaV0uX2xlbmd0aCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbiAgICBjb25zdCBkaXN0YW5jZUZucyA9IG5ldyBBcnJheShmbk5hbWVzLmxlbmd0aClcbiAgICAgIC5maWxsKG51bGwpXG4gICAgICAubWFwKChfLCBkaSkgPT4gbmV3IE1lYXN1cmUoZm5OYW1lc1tkaV0pLmdldE1lYXN1cmUob3B0c1tkaV0pKTtcbiAgICBjb25zdCByZXRWYWwgPSBuZXcgRmxvYXQzMkFycmF5KGNodW5ja1NpemUpO1xuICAgIHdoaWxlIChjbnQgPCBjaHVuY2tTaXplKSB7XG4gICAgICBjb25zdCBkaXN0YW5jZVZhbHVlcyA9IGRpc3RhbmNlRm5zLm1hcCgoZm4sIGlkeCkgPT4gIWlzTmlsKHZhbHVlc1tpZHhdW2ldKSAmJiAhaXNOaWwodmFsdWVzW2lkeF1bal0pID9cbiAgICAgICAgZm4odmFsdWVzW2lkeF1baV0sIHZhbHVlc1tpZHhdW2pdKSA6IDEpO1xuICAgICAgY29uc3QgdmFsdWUgPSBkaXN0YW5jZVZhbHVlcy5sZW5ndGggPT09IDEgPyBkaXN0YW5jZVZhbHVlc1swXSA6IGFnZ3JlZ2F0ZShkaXN0YW5jZVZhbHVlcyk7XG4gICAgICByZXRWYWxbY250XSA9IHZhbHVlO1xuICAgICAgaWYgKHZhbHVlIDwgbG1pbilcbiAgICAgICAgbG1pbiA9IHZhbHVlO1xuICAgICAgaWYgKHZhbHVlID4gbG1heClcbiAgICAgICAgbG1heCA9IHZhbHVlO1xuICAgICAgY250Kys7XG4gICAgICBqKys7XG4gICAgICBpZiAoaiA9PT0gdmFsdWVzWzBdLmxlbmd0aCkge1xuICAgICAgICBpKys7XG4gICAgICAgIGogPSBpICsgMTtcbiAgICAgIH1cbiAgICB9XG4gICAgZGF0YS5kaXN0YW5jZU1hdHJpeERhdGEgPSByZXRWYWw7XG4gICAgZGF0YS5taW4gPSBsbWluO1xuICAgIGRhdGEubWF4ID0gbG1heDtcbiAgfSBjYXRjaCAoZSkge1xuICAgIGRhdGEuZXJyb3IgPSBlO1xuICB9XG4gIHBvc3RNZXNzYWdlKGRhdGEpO1xufTtcbiJdfQ==","// 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, [\"vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2\"], () => (__webpack_require__(\"./node_modules/@datagrok-libraries/ml/src/distance-matrix/distance-matrix-worker.js\")))\n\t__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n\treturn __webpack_exports__;\n};\n\n","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};","// 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))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","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 && document.currentScript.tagName.toUpperCase() === 'SCRIPT')\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 || !/^http(s?):/.test(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(/^blob:/, \"\").replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","// no baseURI\n\n// object to store loaded chunks\n// \"1\" means \"already loaded\"\nvar installedChunks = {\n\t\"node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js\": 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[\"webpackChunkeda\"] = self[\"webpackChunkeda\"] || [];\nvar parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);\nchunkLoadingGlobal.push = installChunk;\n\n// no HMR\n\n// no HMR manifest","var next = __webpack_require__.x;\n__webpack_require__.x = () => {\n\treturn __webpack_require__.e(\"vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2\").then(next);\n};","","// run startup\nvar __webpack_exports__ = __webpack_require__.x();\n",""],"names":[],"sourceRoot":""}