@datagrok/eda 1.4.3 → 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 (152) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/dist/_d4c0.js +279 -0
  3. package/dist/_d4c0.js.map +1 -0
  4. package/dist/node_modules_datagrok-libraries_math_src_dbscan_wasm_clustering-worker_js.js +279 -0
  5. package/dist/node_modules_datagrok-libraries_math_src_dbscan_wasm_clustering-worker_js.js.map +1 -0
  6. package/dist/node_modules_datagrok-libraries_ml_src_MCL_mcl-sparse-matrix-mult-worker_js.js +59 -0
  7. package/dist/node_modules_datagrok-libraries_ml_src_MCL_mcl-sparse-matrix-mult-worker_js.js.map +1 -0
  8. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js.js +284 -0
  9. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js.js.map +1 -0
  10. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js.js +265 -0
  11. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js.js.map +1 -0
  12. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-worker_js.js +287 -0
  13. package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-worker_js.js.map +1 -0
  14. package/dist/package-test.js +26140 -1
  15. package/dist/package-test.js.map +1 -1
  16. package/dist/package.js +30337 -1
  17. package/dist/package.js.map +1 -1
  18. package/dist/src_workers_softmax-worker_ts.js +154 -0
  19. package/dist/src_workers_softmax-worker_ts.js.map +1 -0
  20. package/dist/src_workers_tsne-worker_ts.js +244 -0
  21. package/dist/src_workers_tsne-worker_ts.js.map +1 -0
  22. package/dist/src_workers_umap-worker_ts.js +252 -0
  23. package/dist/src_workers_umap-worker_ts.js.map +1 -0
  24. package/dist/vendors-node_modules_datagrok-libraries_math_src_dbscan_wasm_dbscan_js.js +1253 -0
  25. package/dist/vendors-node_modules_datagrok-libraries_math_src_dbscan_wasm_dbscan_js.js.map +1 -0
  26. package/dist/vendors-node_modules_datagrok-libraries_math_src_hierarchical-clustering_wasm_clustering-worker_js.js +942 -0
  27. package/dist/vendors-node_modules_datagrok-libraries_math_src_hierarchical-clustering_wasm_clustering-worker_js.js.map +1 -0
  28. package/dist/vendors-node_modules_datagrok-libraries_math_src_webGPU_sparse-matrix_webGPU-sparse-matrix_js-07693f.js +1525 -0
  29. package/dist/vendors-node_modules_datagrok-libraries_math_src_webGPU_sparse-matrix_webGPU-sparse-matrix_js-07693f.js.map +1 -0
  30. package/dist/vendors-node_modules_datagrok-libraries_ml_src_MCL_mcl-worker_js-node_modules_datagrok-librar-e4203d.js +2244 -0
  31. package/dist/vendors-node_modules_datagrok-libraries_ml_src_MCL_mcl-worker_js-node_modules_datagrok-librar-e4203d.js.map +1 -0
  32. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-threshold-worker_js.js +286 -0
  33. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-threshold-worker_js.js.map +1 -0
  34. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-worker_js.js +280 -0
  35. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-worker_js.js.map +1 -0
  36. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-threshold-worker_js.js +282 -0
  37. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-threshold-worker_js.js.map +1 -0
  38. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2.js +1821 -0
  39. package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2.js.map +1 -0
  40. package/dist/vendors-node_modules_datagrok-libraries_ml_src_multi-column-dimensionality-reduction_mulit-co-3800a0.js +7776 -0
  41. package/dist/vendors-node_modules_datagrok-libraries_ml_src_multi-column-dimensionality-reduction_mulit-co-3800a0.js.map +1 -0
  42. package/dist/vendors-node_modules_keckelt_tsne_lib_index_js.js +379 -0
  43. package/dist/vendors-node_modules_keckelt_tsne_lib_index_js.js.map +1 -0
  44. package/dist/vendors-node_modules_ml-matrix_matrix_mjs.js +5946 -0
  45. package/dist/vendors-node_modules_ml-matrix_matrix_mjs.js.map +1 -0
  46. package/dist/vendors-node_modules_umap-js_dist_index_js.js +2284 -0
  47. package/dist/vendors-node_modules_umap-js_dist_index_js.js.map +1 -0
  48. package/dist/wasm_EDAForWebWorker_js-wasm_callWasmForWebWorker_js.js +779 -0
  49. package/dist/wasm_EDAForWebWorker_js-wasm_callWasmForWebWorker_js.js.map +1 -0
  50. package/dist/wasm_workers_errorWorker_js.js +267 -0
  51. package/dist/wasm_workers_errorWorker_js.js.map +1 -0
  52. package/dist/wasm_workers_fitLinearRegressionParamsWithDataNormalizingWorker_js.js +267 -0
  53. package/dist/wasm_workers_fitLinearRegressionParamsWithDataNormalizingWorker_js.js.map +1 -0
  54. package/dist/wasm_workers_fitLinearRegressionParamsWorker_js.js +267 -0
  55. package/dist/wasm_workers_fitLinearRegressionParamsWorker_js.js.map +1 -0
  56. package/dist/wasm_workers_fitSoftmaxWorker_js.js +267 -0
  57. package/dist/wasm_workers_fitSoftmaxWorker_js.js.map +1 -0
  58. package/dist/wasm_workers_generateDatasetWorker_js.js +267 -0
  59. package/dist/wasm_workers_generateDatasetWorker_js.js.map +1 -0
  60. package/dist/wasm_workers_normalizeDatasetWorker_js.js +267 -0
  61. package/dist/wasm_workers_normalizeDatasetWorker_js.js.map +1 -0
  62. package/dist/wasm_workers_partialLeastSquareRegressionWorker_js.js +267 -0
  63. package/dist/wasm_workers_partialLeastSquareRegressionWorker_js.js.map +1 -0
  64. package/dist/wasm_workers_predictByLSSVMWorker_js.js +267 -0
  65. package/dist/wasm_workers_predictByLSSVMWorker_js.js.map +1 -0
  66. package/dist/wasm_workers_principalComponentAnalysisNipalsWorker_js.js +267 -0
  67. package/dist/wasm_workers_principalComponentAnalysisNipalsWorker_js.js.map +1 -0
  68. package/dist/wasm_workers_principalComponentAnalysisWorkerUpd_js.js +271 -0
  69. package/dist/wasm_workers_principalComponentAnalysisWorkerUpd_js.js.map +1 -0
  70. package/dist/wasm_workers_trainAndAnalyzeLSSVMWorker_js.js +267 -0
  71. package/dist/wasm_workers_trainAndAnalyzeLSSVMWorker_js.js.map +1 -0
  72. package/dist/wasm_workers_trainLSSVMWorker_js.js +267 -0
  73. package/dist/wasm_workers_trainLSSVMWorker_js.js.map +1 -0
  74. package/dist/wasm_workers_xgboostWorker_js.js +279 -0
  75. package/dist/wasm_workers_xgboostWorker_js.js.map +1 -0
  76. package/package.json +5 -4
  77. package/src/package-api.ts +259 -0
  78. package/src/package.g.ts +522 -0
  79. package/src/package.ts +907 -678
  80. package/test-console-output-1.log +78 -93
  81. package/test-record-1.mp4 +0 -0
  82. package/tsconfig.json +2 -2
  83. package/webpack.config.js +5 -0
  84. package/dist/111.js +0 -2
  85. package/dist/111.js.map +0 -1
  86. package/dist/128.js +0 -2
  87. package/dist/128.js.map +0 -1
  88. package/dist/153.js +0 -2
  89. package/dist/153.js.map +0 -1
  90. package/dist/23.js +0 -2
  91. package/dist/23.js.map +0 -1
  92. package/dist/234.js +0 -2
  93. package/dist/234.js.map +0 -1
  94. package/dist/242.js +0 -2
  95. package/dist/242.js.map +0 -1
  96. package/dist/260.js +0 -2
  97. package/dist/260.js.map +0 -1
  98. package/dist/33.js +0 -2
  99. package/dist/33.js.map +0 -1
  100. package/dist/348.js +0 -2
  101. package/dist/348.js.map +0 -1
  102. package/dist/377.js +0 -2
  103. package/dist/377.js.map +0 -1
  104. package/dist/412.js +0 -2
  105. package/dist/412.js.map +0 -1
  106. package/dist/415.js +0 -2
  107. package/dist/415.js.map +0 -1
  108. package/dist/501.js +0 -2
  109. package/dist/501.js.map +0 -1
  110. package/dist/531.js +0 -2
  111. package/dist/531.js.map +0 -1
  112. package/dist/583.js +0 -2
  113. package/dist/583.js.map +0 -1
  114. package/dist/589.js +0 -2
  115. package/dist/589.js.map +0 -1
  116. package/dist/603.js +0 -2
  117. package/dist/603.js.map +0 -1
  118. package/dist/656.js +0 -2
  119. package/dist/656.js.map +0 -1
  120. package/dist/682.js +0 -2
  121. package/dist/682.js.map +0 -1
  122. package/dist/705.js +0 -2
  123. package/dist/705.js.map +0 -1
  124. package/dist/727.js +0 -2
  125. package/dist/727.js.map +0 -1
  126. package/dist/731.js +0 -2
  127. package/dist/731.js.map +0 -1
  128. package/dist/738.js +0 -3
  129. package/dist/738.js.LICENSE.txt +0 -51
  130. package/dist/738.js.map +0 -1
  131. package/dist/763.js +0 -2
  132. package/dist/763.js.map +0 -1
  133. package/dist/778.js +0 -2
  134. package/dist/778.js.map +0 -1
  135. package/dist/783.js +0 -2
  136. package/dist/783.js.map +0 -1
  137. package/dist/793.js +0 -2
  138. package/dist/793.js.map +0 -1
  139. package/dist/801.js +0 -2
  140. package/dist/801.js.map +0 -1
  141. package/dist/810.js +0 -2
  142. package/dist/810.js.map +0 -1
  143. package/dist/860.js +0 -2
  144. package/dist/860.js.map +0 -1
  145. package/dist/907.js +0 -2
  146. package/dist/907.js.map +0 -1
  147. package/dist/950.js +0 -2
  148. package/dist/950.js.map +0 -1
  149. package/dist/980.js +0 -2
  150. package/dist/980.js.map +0 -1
  151. package/dist/990.js +0 -2
  152. package/dist/990.js.map +0 -1
@@ -0,0 +1,265 @@
1
+ var eda;
2
+ /******/ (() => { // webpackBootstrap
3
+ /******/ "use strict";
4
+ /******/ var __webpack_modules__ = ({
5
+
6
+ /***/ "./node_modules/@datagrok-libraries/ml/src/distance-matrix/single-value-knn-worker.js":
7
+ /*!********************************************************************************************!*\
8
+ !*** ./node_modules/@datagrok-libraries/ml/src/distance-matrix/single-value-knn-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 = async (event) => {
20
+ const { values, fnNames, opts, nNeighbours, weights, aggregationMethod, target, startIdx } = event.data;
21
+ try {
22
+ const knnIndexes = new Array(nNeighbours).fill(-1);
23
+ const knnDistances = new Array(nNeighbours).fill(999999);
24
+ const aggregate = (0,_utils__WEBPACK_IMPORTED_MODULE_0__.getAggregationFunction)(aggregationMethod, weights);
25
+ values.forEach((v, colIdx) => {
26
+ if ((0,_typed_metrics__WEBPACK_IMPORTED_MODULE_1__.isBitArrayMetric)(fnNames[colIdx])) {
27
+ for (let i = 0; i < v.length; ++i) {
28
+ if ((0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(v[i]))
29
+ continue;
30
+ values[colIdx][i] = new _datagrok_libraries_utils_src_bit_array__WEBPACK_IMPORTED_MODULE_2__["default"](values[colIdx][i]._data, values[colIdx][i]._length);
31
+ }
32
+ }
33
+ });
34
+ let cnt = 0;
35
+ const distanceFns = new Array(fnNames.length).fill(null).map((_, i) => new _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.Measure(fnNames[i]).getMeasure(opts[i]));
36
+ for (let i = 0; i < values[0].length; i++) {
37
+ const distanceValues = distanceFns.map((fn, idx) => !(0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(target[idx]) && !(0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(values[idx][i]) ?
38
+ fn(target[idx], values[idx][i]) : 1);
39
+ const value = distanceValues.length === 1 ? distanceValues[0] : aggregate(distanceValues);
40
+ (0,_utils__WEBPACK_IMPORTED_MODULE_0__.insertSmaller)(knnDistances, knnIndexes, value, i + startIdx);
41
+ }
42
+ postMessage({ knnDistances, knnIndexes });
43
+ }
44
+ catch (e) {
45
+ postMessage({ error: e });
46
+ }
47
+ };
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xlLXZhbHVlLWtubi13b3JrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzaW5nbGUtdmFsdWUta25uLXdvcmtlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsYUFBYSxFQUFFLEtBQUssRUFBQyxNQUFNLFNBQVMsQ0FBQztBQUNyRSxPQUFPLEVBQWUsT0FBTyxFQUFFLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDekUsT0FBTyxRQUFRLE1BQU0seUNBQXlDLENBQUM7QUFHL0QsU0FBUyxHQUFHLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRTtJQUMxQixNQUFNLEVBQUMsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFDLEdBRWdDLEtBQUssQ0FBQyxJQUFJLENBQUM7SUFDbkksSUFBSSxDQUFDO1FBQ0gsTUFBTSxVQUFVLEdBQUcsSUFBSSxLQUFLLENBQVMsV0FBVyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0QsTUFBTSxZQUFZLEdBQUcsSUFBSSxLQUFLLENBQVMsV0FBVyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2pFLE1BQU0sU0FBUyxHQUFHLHNCQUFzQixDQUFDLGlCQUFpQixFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ3JFLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDM0IsSUFBSSxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUN0QyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDO29CQUNsQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7d0JBQUUsU0FBUztvQkFDMUIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksUUFBUSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUN2RixDQUFDO1lBQ0gsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ1osTUFBTSxXQUFXLEdBQUcsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUVwSCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQzFDLE1BQU0sY0FBYyxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNqRyxFQUFFLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN2QyxNQUFNLEtBQUssR0FBRyxjQUFjLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDLENBQUM7WUFDMUYsYUFBYSxDQUFDLFlBQVksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQztRQUMvRCxDQUFDO1FBQ0QsV0FBVyxDQUFDLEVBQUMsWUFBWSxFQUFFLFVBQVUsRUFBQyxDQUFDLENBQUM7SUFDMUMsQ0FBQztJQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDWCxXQUFXLENBQUMsRUFBQyxLQUFLLEVBQUUsQ0FBQyxFQUFDLENBQUMsQ0FBQztJQUMxQixDQUFDO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtnZXRBZ2dyZWdhdGlvbkZ1bmN0aW9uLCBpbnNlcnRTbWFsbGVyLCBpc05pbH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQge0tub3duTWV0cmljcywgTWVhc3VyZSwgaXNCaXRBcnJheU1ldHJpY30gZnJvbSAnLi4vdHlwZWQtbWV0cmljcyc7XG5pbXBvcnQgQml0QXJyYXkgZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvYml0LWFycmF5JztcbmltcG9ydCB7RGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZH0gZnJvbSAnLi90eXBlcyc7XG5cbm9ubWVzc2FnZSA9IGFzeW5jIChldmVudCkgPT4ge1xuICBjb25zdCB7dmFsdWVzLCBmbk5hbWVzLCBvcHRzLCBuTmVpZ2hib3Vycywgd2VpZ2h0cywgYWdncmVnYXRpb25NZXRob2QsIHRhcmdldCwgc3RhcnRJZHh9OlxuICAgIHt2YWx1ZXM6IEFycmF5PGFueVtdPiwgZm5OYW1lczogS25vd25NZXRyaWNzW10sIHN0YXJ0SWR4OiBudW1iZXIsXG4gICAgICBvcHRzOiBhbnlbXSwgbk5laWdoYm91cnM6IG51bWJlciwgd2VpZ2h0czogbnVtYmVyW10sIGFnZ3JlZ2F0aW9uTWV0aG9kOiBEaXN0YW5jZUFnZ3JlZ2F0aW9uTWV0aG9kLCB0YXJnZXQ6IGFueVtdfSA9IGV2ZW50LmRhdGE7XG4gIHRyeSB7XG4gICAgY29uc3Qga25uSW5kZXhlcyA9IG5ldyBBcnJheTxudW1iZXI+KG5OZWlnaGJvdXJzKS5maWxsKC0xKTtcbiAgICBjb25zdCBrbm5EaXN0YW5jZXMgPSBuZXcgQXJyYXk8bnVtYmVyPihuTmVpZ2hib3VycykuZmlsbCg5OTk5OTkpO1xuICAgIGNvbnN0IGFnZ3JlZ2F0ZSA9IGdldEFnZ3JlZ2F0aW9uRnVuY3Rpb24oYWdncmVnYXRpb25NZXRob2QsIHdlaWdodHMpO1xuICAgIHZhbHVlcy5mb3JFYWNoKCh2LCBjb2xJZHgpID0+IHtcbiAgICAgIGlmIChpc0JpdEFycmF5TWV0cmljKGZuTmFtZXNbY29sSWR4XSkpIHtcbiAgICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCB2Lmxlbmd0aDsgKytpKSB7XG4gICAgICAgICAgaWYgKGlzTmlsKHZbaV0pKSBjb250aW51ZTtcbiAgICAgICAgICB2YWx1ZXNbY29sSWR4XVtpXSA9IG5ldyBCaXRBcnJheSh2YWx1ZXNbY29sSWR4XVtpXS5fZGF0YSwgdmFsdWVzW2NvbElkeF1baV0uX2xlbmd0aCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbiAgICBsZXQgY250ID0gMDtcbiAgICBjb25zdCBkaXN0YW5jZUZucyA9IG5ldyBBcnJheShmbk5hbWVzLmxlbmd0aCkuZmlsbChudWxsKS5tYXAoKF8sIGkpID0+IG5ldyBNZWFzdXJlKGZuTmFtZXNbaV0pLmdldE1lYXN1cmUob3B0c1tpXSkpO1xuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB2YWx1ZXNbMF0ubGVuZ3RoOyBpKyspIHtcbiAgICAgIGNvbnN0IGRpc3RhbmNlVmFsdWVzID0gZGlzdGFuY2VGbnMubWFwKChmbiwgaWR4KSA9PiAhaXNOaWwodGFyZ2V0W2lkeF0pICYmICFpc05pbCh2YWx1ZXNbaWR4XVtpXSkgP1xuICAgICAgICBmbih0YXJnZXRbaWR4XSwgdmFsdWVzW2lkeF1baV0pIDogMSk7XG4gICAgICBjb25zdCB2YWx1ZSA9IGRpc3RhbmNlVmFsdWVzLmxlbmd0aCA9PT0gMSA/IGRpc3RhbmNlVmFsdWVzWzBdIDogYWdncmVnYXRlKGRpc3RhbmNlVmFsdWVzKTtcbiAgICAgIGluc2VydFNtYWxsZXIoa25uRGlzdGFuY2VzLCBrbm5JbmRleGVzLCB2YWx1ZSwgaSArIHN0YXJ0SWR4KTtcbiAgICB9XG4gICAgcG9zdE1lc3NhZ2Uoe2tubkRpc3RhbmNlcywga25uSW5kZXhlc30pO1xuICB9IGNhdGNoIChlKSB7XG4gICAgcG9zdE1lc3NhZ2Uoe2Vycm9yOiBlfSk7XG4gIH1cbn07XG4iXX0=
49
+
50
+ /***/ })
51
+
52
+ /******/ });
53
+ /************************************************************************/
54
+ /******/ // The module cache
55
+ /******/ var __webpack_module_cache__ = {};
56
+ /******/
57
+ /******/ // The require function
58
+ /******/ function __webpack_require__(moduleId) {
59
+ /******/ // Check if module is in cache
60
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
61
+ /******/ if (cachedModule !== undefined) {
62
+ /******/ return cachedModule.exports;
63
+ /******/ }
64
+ /******/ // Create a new module (and put it into the cache)
65
+ /******/ var module = __webpack_module_cache__[moduleId] = {
66
+ /******/ // no module.id needed
67
+ /******/ // no module.loaded needed
68
+ /******/ exports: {}
69
+ /******/ };
70
+ /******/
71
+ /******/ // Execute the module function
72
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
73
+ /******/
74
+ /******/ // Return the exports of the module
75
+ /******/ return module.exports;
76
+ /******/ }
77
+ /******/
78
+ /******/ // expose the modules object (__webpack_modules__)
79
+ /******/ __webpack_require__.m = __webpack_modules__;
80
+ /******/
81
+ /******/ // the startup function
82
+ /******/ __webpack_require__.x = () => {
83
+ /******/ // Load entry module and return exports
84
+ /******/ // This entry module depends on other loaded chunks and execution need to be delayed
85
+ /******/ 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/single-value-knn-worker.js")))
86
+ /******/ __webpack_exports__ = __webpack_require__.O(__webpack_exports__);
87
+ /******/ return __webpack_exports__;
88
+ /******/ };
89
+ /******/
90
+ /************************************************************************/
91
+ /******/ /* webpack/runtime/chunk loaded */
92
+ /******/ (() => {
93
+ /******/ var deferred = [];
94
+ /******/ __webpack_require__.O = (result, chunkIds, fn, priority) => {
95
+ /******/ if(chunkIds) {
96
+ /******/ priority = priority || 0;
97
+ /******/ for(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];
98
+ /******/ deferred[i] = [chunkIds, fn, priority];
99
+ /******/ return;
100
+ /******/ }
101
+ /******/ var notFulfilled = Infinity;
102
+ /******/ for (var i = 0; i < deferred.length; i++) {
103
+ /******/ var [chunkIds, fn, priority] = deferred[i];
104
+ /******/ var fulfilled = true;
105
+ /******/ for (var j = 0; j < chunkIds.length; j++) {
106
+ /******/ if ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {
107
+ /******/ chunkIds.splice(j--, 1);
108
+ /******/ } else {
109
+ /******/ fulfilled = false;
110
+ /******/ if(priority < notFulfilled) notFulfilled = priority;
111
+ /******/ }
112
+ /******/ }
113
+ /******/ if(fulfilled) {
114
+ /******/ deferred.splice(i--, 1)
115
+ /******/ var r = fn();
116
+ /******/ if (r !== undefined) result = r;
117
+ /******/ }
118
+ /******/ }
119
+ /******/ return result;
120
+ /******/ };
121
+ /******/ })();
122
+ /******/
123
+ /******/ /* webpack/runtime/define property getters */
124
+ /******/ (() => {
125
+ /******/ // define getter functions for harmony exports
126
+ /******/ __webpack_require__.d = (exports, definition) => {
127
+ /******/ for(var key in definition) {
128
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
129
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
130
+ /******/ }
131
+ /******/ }
132
+ /******/ };
133
+ /******/ })();
134
+ /******/
135
+ /******/ /* webpack/runtime/ensure chunk */
136
+ /******/ (() => {
137
+ /******/ __webpack_require__.f = {};
138
+ /******/ // This file contains only the entry chunk.
139
+ /******/ // The chunk loading function for additional chunks
140
+ /******/ __webpack_require__.e = (chunkId) => {
141
+ /******/ return Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {
142
+ /******/ __webpack_require__.f[key](chunkId, promises);
143
+ /******/ return promises;
144
+ /******/ }, []));
145
+ /******/ };
146
+ /******/ })();
147
+ /******/
148
+ /******/ /* webpack/runtime/get javascript chunk filename */
149
+ /******/ (() => {
150
+ /******/ // This function allow to reference async chunks and sibling chunks for the entrypoint
151
+ /******/ __webpack_require__.u = (chunkId) => {
152
+ /******/ // return url for filenames based on template
153
+ /******/ return "" + chunkId + ".js";
154
+ /******/ };
155
+ /******/ })();
156
+ /******/
157
+ /******/ /* webpack/runtime/global */
158
+ /******/ (() => {
159
+ /******/ __webpack_require__.g = (function() {
160
+ /******/ if (typeof globalThis === 'object') return globalThis;
161
+ /******/ try {
162
+ /******/ return this || new Function('return this')();
163
+ /******/ } catch (e) {
164
+ /******/ if (typeof window === 'object') return window;
165
+ /******/ }
166
+ /******/ })();
167
+ /******/ })();
168
+ /******/
169
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
170
+ /******/ (() => {
171
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
172
+ /******/ })();
173
+ /******/
174
+ /******/ /* webpack/runtime/make namespace object */
175
+ /******/ (() => {
176
+ /******/ // define __esModule on exports
177
+ /******/ __webpack_require__.r = (exports) => {
178
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
179
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
180
+ /******/ }
181
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
182
+ /******/ };
183
+ /******/ })();
184
+ /******/
185
+ /******/ /* webpack/runtime/publicPath */
186
+ /******/ (() => {
187
+ /******/ var scriptUrl;
188
+ /******/ if (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + "";
189
+ /******/ var document = __webpack_require__.g.document;
190
+ /******/ if (!scriptUrl && document) {
191
+ /******/ if (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT')
192
+ /******/ scriptUrl = document.currentScript.src;
193
+ /******/ if (!scriptUrl) {
194
+ /******/ var scripts = document.getElementsByTagName("script");
195
+ /******/ if(scripts.length) {
196
+ /******/ var i = scripts.length - 1;
197
+ /******/ while (i > -1 && (!scriptUrl || !/^http(s?):/.test(scriptUrl))) scriptUrl = scripts[i--].src;
198
+ /******/ }
199
+ /******/ }
200
+ /******/ }
201
+ /******/ // When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration
202
+ /******/ // or pass an empty string ("") and set the __webpack_public_path__ variable from your code to use your own logic.
203
+ /******/ if (!scriptUrl) throw new Error("Automatic publicPath is not supported in this browser");
204
+ /******/ scriptUrl = scriptUrl.replace(/^blob:/, "").replace(/#.*$/, "").replace(/\?.*$/, "").replace(/\/[^\/]+$/, "/");
205
+ /******/ __webpack_require__.p = scriptUrl;
206
+ /******/ })();
207
+ /******/
208
+ /******/ /* webpack/runtime/importScripts chunk loading */
209
+ /******/ (() => {
210
+ /******/ // no baseURI
211
+ /******/
212
+ /******/ // object to store loaded chunks
213
+ /******/ // "1" means "already loaded"
214
+ /******/ var installedChunks = {
215
+ /******/ "node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js": 1
216
+ /******/ };
217
+ /******/
218
+ /******/ // importScripts chunk loading
219
+ /******/ var installChunk = (data) => {
220
+ /******/ var [chunkIds, moreModules, runtime] = data;
221
+ /******/ for(var moduleId in moreModules) {
222
+ /******/ if(__webpack_require__.o(moreModules, moduleId)) {
223
+ /******/ __webpack_require__.m[moduleId] = moreModules[moduleId];
224
+ /******/ }
225
+ /******/ }
226
+ /******/ if(runtime) runtime(__webpack_require__);
227
+ /******/ while(chunkIds.length)
228
+ /******/ installedChunks[chunkIds.pop()] = 1;
229
+ /******/ parentChunkLoadingFunction(data);
230
+ /******/ };
231
+ /******/ __webpack_require__.f.i = (chunkId, promises) => {
232
+ /******/ // "1" is the signal for "already loaded"
233
+ /******/ if(!installedChunks[chunkId]) {
234
+ /******/ if(true) { // all chunks have JS
235
+ /******/ importScripts(__webpack_require__.p + __webpack_require__.u(chunkId));
236
+ /******/ }
237
+ /******/ }
238
+ /******/ };
239
+ /******/
240
+ /******/ var chunkLoadingGlobal = self["webpackChunkeda"] = self["webpackChunkeda"] || [];
241
+ /******/ var parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);
242
+ /******/ chunkLoadingGlobal.push = installChunk;
243
+ /******/
244
+ /******/ // no HMR
245
+ /******/
246
+ /******/ // no HMR manifest
247
+ /******/ })();
248
+ /******/
249
+ /******/ /* webpack/runtime/startup chunk dependencies */
250
+ /******/ (() => {
251
+ /******/ var next = __webpack_require__.x;
252
+ /******/ __webpack_require__.x = () => {
253
+ /******/ return __webpack_require__.e("vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2").then(next);
254
+ /******/ };
255
+ /******/ })();
256
+ /******/
257
+ /************************************************************************/
258
+ /******/
259
+ /******/ // run startup
260
+ /******/ var __webpack_exports__ = __webpack_require__.x();
261
+ /******/ eda = __webpack_exports__;
262
+ /******/
263
+ /******/ })()
264
+ ;
265
+ //# sourceMappingURL=node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js.js","mappings":";;;;;;;;;;;;;;;AAAuE;AACV;AACE;AAC/D;AACA,YAAY,mFAAmF;AAC/F;AACA;AACA;AACA,0BAA0B,8DAAsB;AAChD;AACA,gBAAgB,gEAAgB;AAChC,gCAAgC,cAAc;AAC9C,wBAAwB,6CAAK;AAC7B;AACA,4CAA4C,+EAAQ;AACpD;AACA;AACA,SAAS;AACT;AACA,mFAAmF,mDAAO;AAC1F,wBAAwB,sBAAsB;AAC9C,iEAAiE,6CAAK,kBAAkB,6CAAK;AAC7F;AACA;AACA,YAAY,qDAAa;AACzB;AACA,sBAAsB,0BAA0B;AAChD;AACA;AACA,sBAAsB,UAAU;AAChC;AACA;AACA,2CAA2C,2mK;;;;;;UChC3C;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/single-value-knn-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, insertSmaller, isNil } from './utils';\nimport { Measure, isBitArrayMetric } from '../typed-metrics';\nimport BitArray from '@datagrok-libraries/utils/src/bit-array';\nonmessage = async (event) => {\n const { values, fnNames, opts, nNeighbours, weights, aggregationMethod, target, startIdx } = event.data;\n try {\n const knnIndexes = new Array(nNeighbours).fill(-1);\n const knnDistances = new Array(nNeighbours).fill(999999);\n const aggregate = getAggregationFunction(aggregationMethod, weights);\n values.forEach((v, colIdx) => {\n if (isBitArrayMetric(fnNames[colIdx])) {\n for (let i = 0; i < v.length; ++i) {\n if (isNil(v[i]))\n continue;\n values[colIdx][i] = new BitArray(values[colIdx][i]._data, values[colIdx][i]._length);\n }\n }\n });\n let cnt = 0;\n const distanceFns = new Array(fnNames.length).fill(null).map((_, i) => new Measure(fnNames[i]).getMeasure(opts[i]));\n for (let i = 0; i < values[0].length; i++) {\n const distanceValues = distanceFns.map((fn, idx) => !isNil(target[idx]) && !isNil(values[idx][i]) ?\n fn(target[idx], values[idx][i]) : 1);\n const value = distanceValues.length === 1 ? distanceValues[0] : aggregate(distanceValues);\n insertSmaller(knnDistances, knnIndexes, value, i + startIdx);\n }\n postMessage({ knnDistances, knnIndexes });\n }\n catch (e) {\n postMessage({ error: e });\n }\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xlLXZhbHVlLWtubi13b3JrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzaW5nbGUtdmFsdWUta25uLXdvcmtlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsYUFBYSxFQUFFLEtBQUssRUFBQyxNQUFNLFNBQVMsQ0FBQztBQUNyRSxPQUFPLEVBQWUsT0FBTyxFQUFFLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDekUsT0FBTyxRQUFRLE1BQU0seUNBQXlDLENBQUM7QUFHL0QsU0FBUyxHQUFHLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRTtJQUMxQixNQUFNLEVBQUMsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFDLEdBRWdDLEtBQUssQ0FBQyxJQUFJLENBQUM7SUFDbkksSUFBSSxDQUFDO1FBQ0gsTUFBTSxVQUFVLEdBQUcsSUFBSSxLQUFLLENBQVMsV0FBVyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0QsTUFBTSxZQUFZLEdBQUcsSUFBSSxLQUFLLENBQVMsV0FBVyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2pFLE1BQU0sU0FBUyxHQUFHLHNCQUFzQixDQUFDLGlCQUFpQixFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ3JFLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDM0IsSUFBSSxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUN0QyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDO29CQUNsQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7d0JBQUUsU0FBUztvQkFDMUIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksUUFBUSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUN2RixDQUFDO1lBQ0gsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ1osTUFBTSxXQUFXLEdBQUcsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUVwSCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQzFDLE1BQU0sY0FBYyxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNqRyxFQUFFLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN2QyxNQUFNLEtBQUssR0FBRyxjQUFjLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDLENBQUM7WUFDMUYsYUFBYSxDQUFDLFlBQVksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQztRQUMvRCxDQUFDO1FBQ0QsV0FBVyxDQUFDLEVBQUMsWUFBWSxFQUFFLFVBQVUsRUFBQyxDQUFDLENBQUM7SUFDMUMsQ0FBQztJQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDWCxXQUFXLENBQUMsRUFBQyxLQUFLLEVBQUUsQ0FBQyxFQUFDLENBQUMsQ0FBQztJQUMxQixDQUFDO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtnZXRBZ2dyZWdhdGlvbkZ1bmN0aW9uLCBpbnNlcnRTbWFsbGVyLCBpc05pbH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQge0tub3duTWV0cmljcywgTWVhc3VyZSwgaXNCaXRBcnJheU1ldHJpY30gZnJvbSAnLi4vdHlwZWQtbWV0cmljcyc7XG5pbXBvcnQgQml0QXJyYXkgZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvYml0LWFycmF5JztcbmltcG9ydCB7RGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZH0gZnJvbSAnLi90eXBlcyc7XG5cbm9ubWVzc2FnZSA9IGFzeW5jIChldmVudCkgPT4ge1xuICBjb25zdCB7dmFsdWVzLCBmbk5hbWVzLCBvcHRzLCBuTmVpZ2hib3Vycywgd2VpZ2h0cywgYWdncmVnYXRpb25NZXRob2QsIHRhcmdldCwgc3RhcnRJZHh9OlxuICAgIHt2YWx1ZXM6IEFycmF5PGFueVtdPiwgZm5OYW1lczogS25vd25NZXRyaWNzW10sIHN0YXJ0SWR4OiBudW1iZXIsXG4gICAgICBvcHRzOiBhbnlbXSwgbk5laWdoYm91cnM6IG51bWJlciwgd2VpZ2h0czogbnVtYmVyW10sIGFnZ3JlZ2F0aW9uTWV0aG9kOiBEaXN0YW5jZUFnZ3JlZ2F0aW9uTWV0aG9kLCB0YXJnZXQ6IGFueVtdfSA9IGV2ZW50LmRhdGE7XG4gIHRyeSB7XG4gICAgY29uc3Qga25uSW5kZXhlcyA9IG5ldyBBcnJheTxudW1iZXI+KG5OZWlnaGJvdXJzKS5maWxsKC0xKTtcbiAgICBjb25zdCBrbm5EaXN0YW5jZXMgPSBuZXcgQXJyYXk8bnVtYmVyPihuTmVpZ2hib3VycykuZmlsbCg5OTk5OTkpO1xuICAgIGNvbnN0IGFnZ3JlZ2F0ZSA9IGdldEFnZ3JlZ2F0aW9uRnVuY3Rpb24oYWdncmVnYXRpb25NZXRob2QsIHdlaWdodHMpO1xuICAgIHZhbHVlcy5mb3JFYWNoKCh2LCBjb2xJZHgpID0+IHtcbiAgICAgIGlmIChpc0JpdEFycmF5TWV0cmljKGZuTmFtZXNbY29sSWR4XSkpIHtcbiAgICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCB2Lmxlbmd0aDsgKytpKSB7XG4gICAgICAgICAgaWYgKGlzTmlsKHZbaV0pKSBjb250aW51ZTtcbiAgICAgICAgICB2YWx1ZXNbY29sSWR4XVtpXSA9IG5ldyBCaXRBcnJheSh2YWx1ZXNbY29sSWR4XVtpXS5fZGF0YSwgdmFsdWVzW2NvbElkeF1baV0uX2xlbmd0aCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbiAgICBsZXQgY250ID0gMDtcbiAgICBjb25zdCBkaXN0YW5jZUZucyA9IG5ldyBBcnJheShmbk5hbWVzLmxlbmd0aCkuZmlsbChudWxsKS5tYXAoKF8sIGkpID0+IG5ldyBNZWFzdXJlKGZuTmFtZXNbaV0pLmdldE1lYXN1cmUob3B0c1tpXSkpO1xuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB2YWx1ZXNbMF0ubGVuZ3RoOyBpKyspIHtcbiAgICAgIGNvbnN0IGRpc3RhbmNlVmFsdWVzID0gZGlzdGFuY2VGbnMubWFwKChmbiwgaWR4KSA9PiAhaXNOaWwodGFyZ2V0W2lkeF0pICYmICFpc05pbCh2YWx1ZXNbaWR4XVtpXSkgP1xuICAgICAgICBmbih0YXJnZXRbaWR4XSwgdmFsdWVzW2lkeF1baV0pIDogMSk7XG4gICAgICBjb25zdCB2YWx1ZSA9IGRpc3RhbmNlVmFsdWVzLmxlbmd0aCA9PT0gMSA/IGRpc3RhbmNlVmFsdWVzWzBdIDogYWdncmVnYXRlKGRpc3RhbmNlVmFsdWVzKTtcbiAgICAgIGluc2VydFNtYWxsZXIoa25uRGlzdGFuY2VzLCBrbm5JbmRleGVzLCB2YWx1ZSwgaSArIHN0YXJ0SWR4KTtcbiAgICB9XG4gICAgcG9zdE1lc3NhZ2Uoe2tubkRpc3RhbmNlcywga25uSW5kZXhlc30pO1xuICB9IGNhdGNoIChlKSB7XG4gICAgcG9zdE1lc3NhZ2Uoe2Vycm9yOiBlfSk7XG4gIH1cbn07XG4iXX0=","// 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/single-value-knn-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_single-value-knn-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":""}
@@ -0,0 +1,287 @@
1
+ var eda;
2
+ /******/ (() => { // webpackBootstrap
3
+ /******/ "use strict";
4
+ /******/ var __webpack_modules__ = ({
5
+
6
+ /***/ "./node_modules/@datagrok-libraries/ml/src/distance-matrix/sparse-matrix-worker.js":
7
+ /*!*****************************************************************************************!*\
8
+ !*** ./node_modules/@datagrok-libraries/ml/src/distance-matrix/sparse-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 = async (event) => {
20
+ const { values, startIdx, endIdx, threshold, fnNames, opts, aggregationMethod, weights } = event.data;
21
+ try {
22
+ const i = [];
23
+ const j = [];
24
+ const distances = [];
25
+ const chunkSize = endIdx - startIdx;
26
+ //const mi = startRow;
27
+ //const mj = startCol;
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 i = 0; i < v.length; ++i) {
32
+ if ((0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(v[i]))
33
+ continue;
34
+ values[colIdx][i] = new _datagrok_libraries_utils_src_bit_array__WEBPACK_IMPORTED_MODULE_2__["default"](values[colIdx][i]._data, values[colIdx][i]._length);
35
+ }
36
+ }
37
+ });
38
+ let cnt = 0;
39
+ const distanceFns = new Array(fnNames.length).fill(null).map((_, i) => new _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.Measure(fnNames[i]).getMeasure(opts[i]));
40
+ const startRow = values[0].length - 2 - Math.floor(Math.sqrt(-8 * startIdx + 4 * values[0].length * (values[0].length - 1) - 7) / 2 - 0.5);
41
+ const startCol = startIdx - values[0].length * startRow + Math.floor((startRow + 1) * (startRow + 2) / 2);
42
+ let mi = startRow;
43
+ let mj = startCol;
44
+ while (cnt < chunkSize) {
45
+ //const value = seq1List[mi] && seq1List[mj] ? hamming(seq1List[mi], seq1List[mj]) : 0;
46
+ const distanceValues = distanceFns.map((fn, idx) => !(0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(values[idx][mi]) && !(0,_utils__WEBPACK_IMPORTED_MODULE_0__.isNil)(values[idx][mj]) ?
47
+ fn(values[idx][mi], values[idx][mj]) : 1);
48
+ const value = distanceValues.length === 1 ? distanceValues[0] : aggregate(distanceValues);
49
+ if (1 - value >= threshold) {
50
+ i.push(mi);
51
+ j.push(mj);
52
+ distances.push(value);
53
+ }
54
+ cnt++;
55
+ mj++;
56
+ if (mj === values[0].length) {
57
+ mi++;
58
+ mj = mi + 1;
59
+ }
60
+ }
61
+ const iArray = new Int32Array(i);
62
+ const jArray = new Int32Array(j);
63
+ const distanceArray = new Float32Array(distances);
64
+ postMessage({ i: iArray, j: jArray, distance: distanceArray });
65
+ }
66
+ catch (e) {
67
+ postMessage({ error: e });
68
+ }
69
+ };
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BhcnNlLW1hdHJpeC13b3JrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzcGFyc2UtbWF0cml4LXdvcmtlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsS0FBSyxFQUFDLE1BQU0sU0FBUyxDQUFDO0FBQ3RELE9BQU8sRUFBZSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQztBQUN6RSxPQUFPLFFBQVEsTUFBTSx5Q0FBeUMsQ0FBQztBQUUvRCxTQUFTLEdBQUcsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFO0lBQzFCLE1BQU0sRUFBQyxNQUFNLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxpQkFBaUIsRUFBRSxPQUFPLEVBQUMsR0FHbEMsS0FBSyxDQUFDLElBQUksQ0FBQztJQUMvRCxJQUFJLENBQUM7UUFDSCxNQUFNLENBQUMsR0FBYSxFQUFFLENBQUM7UUFDdkIsTUFBTSxDQUFDLEdBQWEsRUFBRSxDQUFDO1FBQ3ZCLE1BQU0sU0FBUyxHQUFhLEVBQUUsQ0FBQztRQUMvQixNQUFNLFNBQVMsR0FBRyxNQUFNLEdBQUcsUUFBUSxDQUFDO1FBQ3BDLHNCQUFzQjtRQUN0QixzQkFBc0I7UUFFdEIsTUFBTSxTQUFTLEdBQUcsc0JBQXNCLENBQUMsaUJBQWlCLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFckUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUMzQixJQUFJLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQ3RDLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7b0JBQ2xDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzt3QkFBRSxTQUFTO29CQUMxQixNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQ3ZGLENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUM7UUFDWixNQUFNLFdBQVcsR0FBRyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3BILE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQ2hELElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsUUFBUSxHQUFHLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUM7UUFDMUYsTUFBTSxRQUFRLEdBQUcsUUFBUSxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDMUcsSUFBSSxFQUFFLEdBQUcsUUFBUSxDQUFDO1FBQ2xCLElBQUksRUFBRSxHQUFHLFFBQVEsQ0FBQztRQUNsQixPQUFPLEdBQUcsR0FBRyxTQUFTLEVBQUUsQ0FBQztZQUN2Qix1RkFBdUY7WUFDdkYsTUFBTSxjQUFjLEdBQUcsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3RHLEVBQUUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzVDLE1BQU0sS0FBSyxHQUFHLGNBQWMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQztZQUMxRixJQUFJLENBQUMsR0FBRyxLQUFLLElBQUksU0FBUyxFQUFFLENBQUM7Z0JBQzNCLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7Z0JBQ1gsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztnQkFDWCxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3hCLENBQUM7WUFDRCxHQUFHLEVBQUUsQ0FBQztZQUNOLEVBQUUsRUFBRSxDQUFDO1lBQ0wsSUFBSSxFQUFFLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO2dCQUM1QixFQUFFLEVBQUUsQ0FBQztnQkFDTCxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztZQUNkLENBQUM7UUFDSCxDQUFDO1FBRUQsTUFBTSxNQUFNLEdBQUcsSUFBSSxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDakMsTUFBTSxNQUFNLEdBQUcsSUFBSSxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDakMsTUFBTSxhQUFhLEdBQUcsSUFBSSxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDbEQsV0FBVyxDQUFDLEVBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUMsQ0FBQyxDQUFDO0lBQy9ELENBQUM7SUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1FBQ1gsV0FBVyxDQUFDLEVBQUMsS0FBSyxFQUFFLENBQUMsRUFBQyxDQUFDLENBQUM7SUFDMUIsQ0FBQztBQUNILENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Z2V0QWdncmVnYXRpb25GdW5jdGlvbiwgaXNOaWx9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IHtLbm93bk1ldHJpY3MsIE1lYXN1cmUsIGlzQml0QXJyYXlNZXRyaWN9IGZyb20gJy4uL3R5cGVkLW1ldHJpY3MnO1xuaW1wb3J0IEJpdEFycmF5IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL2JpdC1hcnJheSc7XG5pbXBvcnQge0Rpc3RhbmNlQWdncmVnYXRpb25NZXRob2R9IGZyb20gJy4vdHlwZXMnO1xub25tZXNzYWdlID0gYXN5bmMgKGV2ZW50KSA9PiB7XG4gIGNvbnN0IHt2YWx1ZXMsIHN0YXJ0SWR4LCBlbmRJZHgsIHRocmVzaG9sZCwgZm5OYW1lcywgb3B0cywgYWdncmVnYXRpb25NZXRob2QsIHdlaWdodHN9OlxuICAgIHt2YWx1ZXM6IEFycmF5PGFueVtdPiwgc3RhcnRJZHg6IG51bWJlciwgZW5kSWR4OiBudW1iZXIsXG4gICAgICB0aHJlc2hvbGQ6IG51bWJlciwgZm5OYW1lczogS25vd25NZXRyaWNzW10sIG9wdHM6IGFueVtdLCB3ZWlnaHRzOiBudW1iZXJbXSxcbiAgICAgIGFnZ3JlZ2F0aW9uTWV0aG9kOiBEaXN0YW5jZUFnZ3JlZ2F0aW9uTWV0aG9kfSA9IGV2ZW50LmRhdGE7XG4gIHRyeSB7XG4gICAgY29uc3QgaTogbnVtYmVyW10gPSBbXTtcbiAgICBjb25zdCBqOiBudW1iZXJbXSA9IFtdO1xuICAgIGNvbnN0IGRpc3RhbmNlczogbnVtYmVyW10gPSBbXTtcbiAgICBjb25zdCBjaHVua1NpemUgPSBlbmRJZHggLSBzdGFydElkeDtcbiAgICAvL2NvbnN0IG1pID0gc3RhcnRSb3c7XG4gICAgLy9jb25zdCBtaiA9IHN0YXJ0Q29sO1xuXG4gICAgY29uc3QgYWdncmVnYXRlID0gZ2V0QWdncmVnYXRpb25GdW5jdGlvbihhZ2dyZWdhdGlvbk1ldGhvZCwgd2VpZ2h0cyk7XG5cbiAgICB2YWx1ZXMuZm9yRWFjaCgodiwgY29sSWR4KSA9PiB7XG4gICAgICBpZiAoaXNCaXRBcnJheU1ldHJpYyhmbk5hbWVzW2NvbElkeF0pKSB7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdi5sZW5ndGg7ICsraSkge1xuICAgICAgICAgIGlmIChpc05pbCh2W2ldKSkgY29udGludWU7XG4gICAgICAgICAgdmFsdWVzW2NvbElkeF1baV0gPSBuZXcgQml0QXJyYXkodmFsdWVzW2NvbElkeF1baV0uX2RhdGEsIHZhbHVlc1tjb2xJZHhdW2ldLl9sZW5ndGgpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSk7XG4gICAgbGV0IGNudCA9IDA7XG4gICAgY29uc3QgZGlzdGFuY2VGbnMgPSBuZXcgQXJyYXkoZm5OYW1lcy5sZW5ndGgpLmZpbGwobnVsbCkubWFwKChfLCBpKSA9PiBuZXcgTWVhc3VyZShmbk5hbWVzW2ldKS5nZXRNZWFzdXJlKG9wdHNbaV0pKTtcbiAgICBjb25zdCBzdGFydFJvdyA9IHZhbHVlc1swXS5sZW5ndGggLSAyIC0gTWF0aC5mbG9vcihcbiAgICAgIE1hdGguc3FydCgtOCAqIHN0YXJ0SWR4ICsgNCAqIHZhbHVlc1swXS5sZW5ndGggKiAodmFsdWVzWzBdLmxlbmd0aCAtIDEpIC0gNykgLyAyIC0gMC41KTtcbiAgICBjb25zdCBzdGFydENvbCA9IHN0YXJ0SWR4IC0gdmFsdWVzWzBdLmxlbmd0aCAqIHN0YXJ0Um93ICsgTWF0aC5mbG9vcigoc3RhcnRSb3cgKyAxKSAqIChzdGFydFJvdyArIDIpIC8gMik7XG4gICAgbGV0IG1pID0gc3RhcnRSb3c7XG4gICAgbGV0IG1qID0gc3RhcnRDb2w7XG4gICAgd2hpbGUgKGNudCA8IGNodW5rU2l6ZSkge1xuICAgICAgLy9jb25zdCB2YWx1ZSA9IHNlcTFMaXN0W21pXSAmJiBzZXExTGlzdFttal0gPyBoYW1taW5nKHNlcTFMaXN0W21pXSwgc2VxMUxpc3RbbWpdKSA6IDA7XG4gICAgICBjb25zdCBkaXN0YW5jZVZhbHVlcyA9IGRpc3RhbmNlRm5zLm1hcCgoZm4sIGlkeCkgPT4gIWlzTmlsKHZhbHVlc1tpZHhdW21pXSkgJiYgIWlzTmlsKHZhbHVlc1tpZHhdW21qXSkgP1xuICAgICAgICBmbih2YWx1ZXNbaWR4XVttaV0sIHZhbHVlc1tpZHhdW21qXSkgOiAxKTtcbiAgICAgIGNvbnN0IHZhbHVlID0gZGlzdGFuY2VWYWx1ZXMubGVuZ3RoID09PSAxID8gZGlzdGFuY2VWYWx1ZXNbMF0gOiBhZ2dyZWdhdGUoZGlzdGFuY2VWYWx1ZXMpO1xuICAgICAgaWYgKDEgLSB2YWx1ZSA+PSB0aHJlc2hvbGQpIHtcbiAgICAgICAgaS5wdXNoKG1pKTtcbiAgICAgICAgai5wdXNoKG1qKTtcbiAgICAgICAgZGlzdGFuY2VzLnB1c2godmFsdWUpO1xuICAgICAgfVxuICAgICAgY250Kys7XG4gICAgICBtaisrO1xuICAgICAgaWYgKG1qID09PSB2YWx1ZXNbMF0ubGVuZ3RoKSB7XG4gICAgICAgIG1pKys7XG4gICAgICAgIG1qID0gbWkgKyAxO1xuICAgICAgfVxuICAgIH1cblxuICAgIGNvbnN0IGlBcnJheSA9IG5ldyBJbnQzMkFycmF5KGkpO1xuICAgIGNvbnN0IGpBcnJheSA9IG5ldyBJbnQzMkFycmF5KGopO1xuICAgIGNvbnN0IGRpc3RhbmNlQXJyYXkgPSBuZXcgRmxvYXQzMkFycmF5KGRpc3RhbmNlcyk7XG4gICAgcG9zdE1lc3NhZ2Uoe2k6IGlBcnJheSwgajogakFycmF5LCBkaXN0YW5jZTogZGlzdGFuY2VBcnJheX0pO1xuICB9IGNhdGNoIChlKSB7XG4gICAgcG9zdE1lc3NhZ2Uoe2Vycm9yOiBlfSk7XG4gIH1cbn07XG4iXX0=
71
+
72
+ /***/ })
73
+
74
+ /******/ });
75
+ /************************************************************************/
76
+ /******/ // The module cache
77
+ /******/ var __webpack_module_cache__ = {};
78
+ /******/
79
+ /******/ // The require function
80
+ /******/ function __webpack_require__(moduleId) {
81
+ /******/ // Check if module is in cache
82
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
83
+ /******/ if (cachedModule !== undefined) {
84
+ /******/ return cachedModule.exports;
85
+ /******/ }
86
+ /******/ // Create a new module (and put it into the cache)
87
+ /******/ var module = __webpack_module_cache__[moduleId] = {
88
+ /******/ // no module.id needed
89
+ /******/ // no module.loaded needed
90
+ /******/ exports: {}
91
+ /******/ };
92
+ /******/
93
+ /******/ // Execute the module function
94
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
95
+ /******/
96
+ /******/ // Return the exports of the module
97
+ /******/ return module.exports;
98
+ /******/ }
99
+ /******/
100
+ /******/ // expose the modules object (__webpack_modules__)
101
+ /******/ __webpack_require__.m = __webpack_modules__;
102
+ /******/
103
+ /******/ // the startup function
104
+ /******/ __webpack_require__.x = () => {
105
+ /******/ // Load entry module and return exports
106
+ /******/ // This entry module depends on other loaded chunks and execution need to be delayed
107
+ /******/ 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/sparse-matrix-worker.js")))
108
+ /******/ __webpack_exports__ = __webpack_require__.O(__webpack_exports__);
109
+ /******/ return __webpack_exports__;
110
+ /******/ };
111
+ /******/
112
+ /************************************************************************/
113
+ /******/ /* webpack/runtime/chunk loaded */
114
+ /******/ (() => {
115
+ /******/ var deferred = [];
116
+ /******/ __webpack_require__.O = (result, chunkIds, fn, priority) => {
117
+ /******/ if(chunkIds) {
118
+ /******/ priority = priority || 0;
119
+ /******/ for(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];
120
+ /******/ deferred[i] = [chunkIds, fn, priority];
121
+ /******/ return;
122
+ /******/ }
123
+ /******/ var notFulfilled = Infinity;
124
+ /******/ for (var i = 0; i < deferred.length; i++) {
125
+ /******/ var [chunkIds, fn, priority] = deferred[i];
126
+ /******/ var fulfilled = true;
127
+ /******/ for (var j = 0; j < chunkIds.length; j++) {
128
+ /******/ if ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {
129
+ /******/ chunkIds.splice(j--, 1);
130
+ /******/ } else {
131
+ /******/ fulfilled = false;
132
+ /******/ if(priority < notFulfilled) notFulfilled = priority;
133
+ /******/ }
134
+ /******/ }
135
+ /******/ if(fulfilled) {
136
+ /******/ deferred.splice(i--, 1)
137
+ /******/ var r = fn();
138
+ /******/ if (r !== undefined) result = r;
139
+ /******/ }
140
+ /******/ }
141
+ /******/ return result;
142
+ /******/ };
143
+ /******/ })();
144
+ /******/
145
+ /******/ /* webpack/runtime/define property getters */
146
+ /******/ (() => {
147
+ /******/ // define getter functions for harmony exports
148
+ /******/ __webpack_require__.d = (exports, definition) => {
149
+ /******/ for(var key in definition) {
150
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
151
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
152
+ /******/ }
153
+ /******/ }
154
+ /******/ };
155
+ /******/ })();
156
+ /******/
157
+ /******/ /* webpack/runtime/ensure chunk */
158
+ /******/ (() => {
159
+ /******/ __webpack_require__.f = {};
160
+ /******/ // This file contains only the entry chunk.
161
+ /******/ // The chunk loading function for additional chunks
162
+ /******/ __webpack_require__.e = (chunkId) => {
163
+ /******/ return Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {
164
+ /******/ __webpack_require__.f[key](chunkId, promises);
165
+ /******/ return promises;
166
+ /******/ }, []));
167
+ /******/ };
168
+ /******/ })();
169
+ /******/
170
+ /******/ /* webpack/runtime/get javascript chunk filename */
171
+ /******/ (() => {
172
+ /******/ // This function allow to reference async chunks and sibling chunks for the entrypoint
173
+ /******/ __webpack_require__.u = (chunkId) => {
174
+ /******/ // return url for filenames based on template
175
+ /******/ return "" + chunkId + ".js";
176
+ /******/ };
177
+ /******/ })();
178
+ /******/
179
+ /******/ /* webpack/runtime/global */
180
+ /******/ (() => {
181
+ /******/ __webpack_require__.g = (function() {
182
+ /******/ if (typeof globalThis === 'object') return globalThis;
183
+ /******/ try {
184
+ /******/ return this || new Function('return this')();
185
+ /******/ } catch (e) {
186
+ /******/ if (typeof window === 'object') return window;
187
+ /******/ }
188
+ /******/ })();
189
+ /******/ })();
190
+ /******/
191
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
192
+ /******/ (() => {
193
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
194
+ /******/ })();
195
+ /******/
196
+ /******/ /* webpack/runtime/make namespace object */
197
+ /******/ (() => {
198
+ /******/ // define __esModule on exports
199
+ /******/ __webpack_require__.r = (exports) => {
200
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
201
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
202
+ /******/ }
203
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
204
+ /******/ };
205
+ /******/ })();
206
+ /******/
207
+ /******/ /* webpack/runtime/publicPath */
208
+ /******/ (() => {
209
+ /******/ var scriptUrl;
210
+ /******/ if (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + "";
211
+ /******/ var document = __webpack_require__.g.document;
212
+ /******/ if (!scriptUrl && document) {
213
+ /******/ if (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT')
214
+ /******/ scriptUrl = document.currentScript.src;
215
+ /******/ if (!scriptUrl) {
216
+ /******/ var scripts = document.getElementsByTagName("script");
217
+ /******/ if(scripts.length) {
218
+ /******/ var i = scripts.length - 1;
219
+ /******/ while (i > -1 && (!scriptUrl || !/^http(s?):/.test(scriptUrl))) scriptUrl = scripts[i--].src;
220
+ /******/ }
221
+ /******/ }
222
+ /******/ }
223
+ /******/ // When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration
224
+ /******/ // or pass an empty string ("") and set the __webpack_public_path__ variable from your code to use your own logic.
225
+ /******/ if (!scriptUrl) throw new Error("Automatic publicPath is not supported in this browser");
226
+ /******/ scriptUrl = scriptUrl.replace(/^blob:/, "").replace(/#.*$/, "").replace(/\?.*$/, "").replace(/\/[^\/]+$/, "/");
227
+ /******/ __webpack_require__.p = scriptUrl;
228
+ /******/ })();
229
+ /******/
230
+ /******/ /* webpack/runtime/importScripts chunk loading */
231
+ /******/ (() => {
232
+ /******/ // no baseURI
233
+ /******/
234
+ /******/ // object to store loaded chunks
235
+ /******/ // "1" means "already loaded"
236
+ /******/ var installedChunks = {
237
+ /******/ "node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-worker_js": 1
238
+ /******/ };
239
+ /******/
240
+ /******/ // importScripts chunk loading
241
+ /******/ var installChunk = (data) => {
242
+ /******/ var [chunkIds, moreModules, runtime] = data;
243
+ /******/ for(var moduleId in moreModules) {
244
+ /******/ if(__webpack_require__.o(moreModules, moduleId)) {
245
+ /******/ __webpack_require__.m[moduleId] = moreModules[moduleId];
246
+ /******/ }
247
+ /******/ }
248
+ /******/ if(runtime) runtime(__webpack_require__);
249
+ /******/ while(chunkIds.length)
250
+ /******/ installedChunks[chunkIds.pop()] = 1;
251
+ /******/ parentChunkLoadingFunction(data);
252
+ /******/ };
253
+ /******/ __webpack_require__.f.i = (chunkId, promises) => {
254
+ /******/ // "1" is the signal for "already loaded"
255
+ /******/ if(!installedChunks[chunkId]) {
256
+ /******/ if(true) { // all chunks have JS
257
+ /******/ importScripts(__webpack_require__.p + __webpack_require__.u(chunkId));
258
+ /******/ }
259
+ /******/ }
260
+ /******/ };
261
+ /******/
262
+ /******/ var chunkLoadingGlobal = self["webpackChunkeda"] = self["webpackChunkeda"] || [];
263
+ /******/ var parentChunkLoadingFunction = chunkLoadingGlobal.push.bind(chunkLoadingGlobal);
264
+ /******/ chunkLoadingGlobal.push = installChunk;
265
+ /******/
266
+ /******/ // no HMR
267
+ /******/
268
+ /******/ // no HMR manifest
269
+ /******/ })();
270
+ /******/
271
+ /******/ /* webpack/runtime/startup chunk dependencies */
272
+ /******/ (() => {
273
+ /******/ var next = __webpack_require__.x;
274
+ /******/ __webpack_require__.x = () => {
275
+ /******/ return __webpack_require__.e("vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2").then(next);
276
+ /******/ };
277
+ /******/ })();
278
+ /******/
279
+ /************************************************************************/
280
+ /******/
281
+ /******/ // run startup
282
+ /******/ var __webpack_exports__ = __webpack_require__.x();
283
+ /******/ eda = __webpack_exports__;
284
+ /******/
285
+ /******/ })()
286
+ ;
287
+ //# sourceMappingURL=node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-worker_js.js.map