@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.
- package/CHANGELOG.md +4 -0
- package/dist/_d4c0.js +279 -0
- package/dist/_d4c0.js.map +1 -0
- package/dist/node_modules_datagrok-libraries_math_src_dbscan_wasm_clustering-worker_js.js +279 -0
- package/dist/node_modules_datagrok-libraries_math_src_dbscan_wasm_clustering-worker_js.js.map +1 -0
- package/dist/node_modules_datagrok-libraries_ml_src_MCL_mcl-sparse-matrix-mult-worker_js.js +59 -0
- package/dist/node_modules_datagrok-libraries_ml_src_MCL_mcl-sparse-matrix-mult-worker_js.js.map +1 -0
- package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js.js +284 -0
- package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_distance-matrix-worker_js.js.map +1 -0
- package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js.js +265 -0
- package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_single-value-knn-worker_js.js.map +1 -0
- package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-worker_js.js +287 -0
- package/dist/node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-worker_js.js.map +1 -0
- package/dist/package-test.js +26140 -1
- package/dist/package-test.js.map +1 -1
- package/dist/package.js +30337 -1
- package/dist/package.js.map +1 -1
- package/dist/src_workers_softmax-worker_ts.js +154 -0
- package/dist/src_workers_softmax-worker_ts.js.map +1 -0
- package/dist/src_workers_tsne-worker_ts.js +244 -0
- package/dist/src_workers_tsne-worker_ts.js.map +1 -0
- package/dist/src_workers_umap-worker_ts.js +252 -0
- package/dist/src_workers_umap-worker_ts.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_math_src_dbscan_wasm_dbscan_js.js +1253 -0
- package/dist/vendors-node_modules_datagrok-libraries_math_src_dbscan_wasm_dbscan_js.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_math_src_hierarchical-clustering_wasm_clustering-worker_js.js +942 -0
- package/dist/vendors-node_modules_datagrok-libraries_math_src_hierarchical-clustering_wasm_clustering-worker_js.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_math_src_webGPU_sparse-matrix_webGPU-sparse-matrix_js-07693f.js +1525 -0
- package/dist/vendors-node_modules_datagrok-libraries_math_src_webGPU_sparse-matrix_webGPU-sparse-matrix_js-07693f.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_MCL_mcl-worker_js-node_modules_datagrok-librar-e4203d.js +2244 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_MCL_mcl-worker_js-node_modules_datagrok-librar-e4203d.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-threshold-worker_js.js +286 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-threshold-worker_js.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-worker_js.js +280 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_knn-worker_js.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-threshold-worker_js.js +282 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_sparse-matrix-threshold-worker_js.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2.js +1821 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2.js.map +1 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_multi-column-dimensionality-reduction_mulit-co-3800a0.js +7776 -0
- package/dist/vendors-node_modules_datagrok-libraries_ml_src_multi-column-dimensionality-reduction_mulit-co-3800a0.js.map +1 -0
- package/dist/vendors-node_modules_keckelt_tsne_lib_index_js.js +379 -0
- package/dist/vendors-node_modules_keckelt_tsne_lib_index_js.js.map +1 -0
- package/dist/vendors-node_modules_ml-matrix_matrix_mjs.js +5946 -0
- package/dist/vendors-node_modules_ml-matrix_matrix_mjs.js.map +1 -0
- package/dist/vendors-node_modules_umap-js_dist_index_js.js +2284 -0
- package/dist/vendors-node_modules_umap-js_dist_index_js.js.map +1 -0
- package/dist/wasm_EDAForWebWorker_js-wasm_callWasmForWebWorker_js.js +779 -0
- package/dist/wasm_EDAForWebWorker_js-wasm_callWasmForWebWorker_js.js.map +1 -0
- package/dist/wasm_workers_errorWorker_js.js +267 -0
- package/dist/wasm_workers_errorWorker_js.js.map +1 -0
- package/dist/wasm_workers_fitLinearRegressionParamsWithDataNormalizingWorker_js.js +267 -0
- package/dist/wasm_workers_fitLinearRegressionParamsWithDataNormalizingWorker_js.js.map +1 -0
- package/dist/wasm_workers_fitLinearRegressionParamsWorker_js.js +267 -0
- package/dist/wasm_workers_fitLinearRegressionParamsWorker_js.js.map +1 -0
- package/dist/wasm_workers_fitSoftmaxWorker_js.js +267 -0
- package/dist/wasm_workers_fitSoftmaxWorker_js.js.map +1 -0
- package/dist/wasm_workers_generateDatasetWorker_js.js +267 -0
- package/dist/wasm_workers_generateDatasetWorker_js.js.map +1 -0
- package/dist/wasm_workers_normalizeDatasetWorker_js.js +267 -0
- package/dist/wasm_workers_normalizeDatasetWorker_js.js.map +1 -0
- package/dist/wasm_workers_partialLeastSquareRegressionWorker_js.js +267 -0
- package/dist/wasm_workers_partialLeastSquareRegressionWorker_js.js.map +1 -0
- package/dist/wasm_workers_predictByLSSVMWorker_js.js +267 -0
- package/dist/wasm_workers_predictByLSSVMWorker_js.js.map +1 -0
- package/dist/wasm_workers_principalComponentAnalysisNipalsWorker_js.js +267 -0
- package/dist/wasm_workers_principalComponentAnalysisNipalsWorker_js.js.map +1 -0
- package/dist/wasm_workers_principalComponentAnalysisWorkerUpd_js.js +271 -0
- package/dist/wasm_workers_principalComponentAnalysisWorkerUpd_js.js.map +1 -0
- package/dist/wasm_workers_trainAndAnalyzeLSSVMWorker_js.js +267 -0
- package/dist/wasm_workers_trainAndAnalyzeLSSVMWorker_js.js.map +1 -0
- package/dist/wasm_workers_trainLSSVMWorker_js.js +267 -0
- package/dist/wasm_workers_trainLSSVMWorker_js.js.map +1 -0
- package/dist/wasm_workers_xgboostWorker_js.js +279 -0
- package/dist/wasm_workers_xgboostWorker_js.js.map +1 -0
- package/package.json +5 -4
- package/src/package-api.ts +259 -0
- package/src/package.g.ts +522 -0
- package/src/package.ts +907 -678
- package/test-console-output-1.log +78 -93
- package/test-record-1.mp4 +0 -0
- package/tsconfig.json +2 -2
- package/webpack.config.js +5 -0
- package/dist/111.js +0 -2
- package/dist/111.js.map +0 -1
- package/dist/128.js +0 -2
- package/dist/128.js.map +0 -1
- package/dist/153.js +0 -2
- package/dist/153.js.map +0 -1
- package/dist/23.js +0 -2
- package/dist/23.js.map +0 -1
- package/dist/234.js +0 -2
- package/dist/234.js.map +0 -1
- package/dist/242.js +0 -2
- package/dist/242.js.map +0 -1
- package/dist/260.js +0 -2
- package/dist/260.js.map +0 -1
- package/dist/33.js +0 -2
- package/dist/33.js.map +0 -1
- package/dist/348.js +0 -2
- package/dist/348.js.map +0 -1
- package/dist/377.js +0 -2
- package/dist/377.js.map +0 -1
- package/dist/412.js +0 -2
- package/dist/412.js.map +0 -1
- package/dist/415.js +0 -2
- package/dist/415.js.map +0 -1
- package/dist/501.js +0 -2
- package/dist/501.js.map +0 -1
- package/dist/531.js +0 -2
- package/dist/531.js.map +0 -1
- package/dist/583.js +0 -2
- package/dist/583.js.map +0 -1
- package/dist/589.js +0 -2
- package/dist/589.js.map +0 -1
- package/dist/603.js +0 -2
- package/dist/603.js.map +0 -1
- package/dist/656.js +0 -2
- package/dist/656.js.map +0 -1
- package/dist/682.js +0 -2
- package/dist/682.js.map +0 -1
- package/dist/705.js +0 -2
- package/dist/705.js.map +0 -1
- package/dist/727.js +0 -2
- package/dist/727.js.map +0 -1
- package/dist/731.js +0 -2
- package/dist/731.js.map +0 -1
- package/dist/738.js +0 -3
- package/dist/738.js.LICENSE.txt +0 -51
- package/dist/738.js.map +0 -1
- package/dist/763.js +0 -2
- package/dist/763.js.map +0 -1
- package/dist/778.js +0 -2
- package/dist/778.js.map +0 -1
- package/dist/783.js +0 -2
- package/dist/783.js.map +0 -1
- package/dist/793.js +0 -2
- package/dist/793.js.map +0 -1
- package/dist/801.js +0 -2
- package/dist/801.js.map +0 -1
- package/dist/810.js +0 -2
- package/dist/810.js.map +0 -1
- package/dist/860.js +0 -2
- package/dist/860.js.map +0 -1
- package/dist/907.js +0 -2
- package/dist/907.js.map +0 -1
- package/dist/950.js +0 -2
- package/dist/950.js.map +0 -1
- package/dist/980.js +0 -2
- package/dist/980.js.map +0 -1
- package/dist/990.js +0 -2
- package/dist/990.js.map +0 -1
|
@@ -0,0 +1,1821 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
(self["webpackChunkeda"] = self["webpackChunkeda"] || []).push([["vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2"],{
|
|
3
|
+
|
|
4
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/distance-matrix/types.js":
|
|
5
|
+
/*!**************************************************************************!*\
|
|
6
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/distance-matrix/types.js ***!
|
|
7
|
+
\**************************************************************************/
|
|
8
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
9
|
+
|
|
10
|
+
__webpack_require__.r(__webpack_exports__);
|
|
11
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
12
|
+
/* harmony export */ DistanceAggregationMethods: () => (/* binding */ DistanceAggregationMethods)
|
|
13
|
+
/* harmony export */ });
|
|
14
|
+
var DistanceAggregationMethods;
|
|
15
|
+
(function (DistanceAggregationMethods) {
|
|
16
|
+
DistanceAggregationMethods["EUCLIDEAN"] = "EUCLIDEAN";
|
|
17
|
+
DistanceAggregationMethods["MANHATTAN"] = "MANHATTAN";
|
|
18
|
+
})(DistanceAggregationMethods || (DistanceAggregationMethods = {}));
|
|
19
|
+
;
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ0eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSwwQkFHVDtBQUhILFdBQVksMEJBQTBCO0lBQ2xDLHFEQUF1QixDQUFBO0lBQ3ZCLHFEQUF1QixDQUFBO0FBQ3pCLENBQUMsRUFIUywwQkFBMEIsS0FBMUIsMEJBQTBCLFFBR25DO0FBQUEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIERpc3RhbmNlQWdncmVnYXRpb25NZXRob2RzIHtcbiAgICBFVUNMSURFQU4gPSAnRVVDTElERUFOJyxcbiAgICBNQU5IQVRUQU4gPSAnTUFOSEFUVEFOJyxcbiAgfTtcblxuZXhwb3J0IHR5cGUgRGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZCA9IGtleW9mIHR5cGVvZiBEaXN0YW5jZUFnZ3JlZ2F0aW9uTWV0aG9kcztcbiJdfQ==
|
|
21
|
+
|
|
22
|
+
/***/ }),
|
|
23
|
+
|
|
24
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/distance-matrix/utils.js":
|
|
25
|
+
/*!**************************************************************************!*\
|
|
26
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/distance-matrix/utils.js ***!
|
|
27
|
+
\**************************************************************************/
|
|
28
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
29
|
+
|
|
30
|
+
__webpack_require__.r(__webpack_exports__);
|
|
31
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
32
|
+
/* harmony export */ getAggregationFunction: () => (/* binding */ getAggregationFunction),
|
|
33
|
+
/* harmony export */ insertLarger: () => (/* binding */ insertLarger),
|
|
34
|
+
/* harmony export */ insertSmaller: () => (/* binding */ insertSmaller),
|
|
35
|
+
/* harmony export */ isNil: () => (/* binding */ isNil)
|
|
36
|
+
/* harmony export */ });
|
|
37
|
+
/* harmony import */ var _types__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./types */ "./node_modules/@datagrok-libraries/ml/src/distance-matrix/types.js");
|
|
38
|
+
|
|
39
|
+
const isNil = (x) => x === null || x === undefined;
|
|
40
|
+
function insertSmaller(distancesAr, indexes, num, index) {
|
|
41
|
+
if (num > distancesAr[distancesAr.length - 1])
|
|
42
|
+
return;
|
|
43
|
+
const newPosition = distancesAr.findIndex((v) => num < v);
|
|
44
|
+
distancesAr.pop();
|
|
45
|
+
distancesAr.splice(newPosition, 0, num);
|
|
46
|
+
indexes.pop();
|
|
47
|
+
indexes.splice(newPosition, 0, index);
|
|
48
|
+
}
|
|
49
|
+
function insertLarger(distancesAr, indexes, num, index) {
|
|
50
|
+
if (num < distancesAr[distancesAr.length - 1])
|
|
51
|
+
return;
|
|
52
|
+
const newPosition = distancesAr.findIndex((v) => num > v);
|
|
53
|
+
distancesAr.pop();
|
|
54
|
+
distancesAr.splice(newPosition, 0, num);
|
|
55
|
+
indexes.pop();
|
|
56
|
+
indexes.splice(newPosition, 0, index);
|
|
57
|
+
}
|
|
58
|
+
function getAggregationFunction(aggregationMethod, weights) {
|
|
59
|
+
switch (aggregationMethod) {
|
|
60
|
+
case _types__WEBPACK_IMPORTED_MODULE_0__.DistanceAggregationMethods.MANHATTAN:
|
|
61
|
+
return (vs) => vs.reduce((acc, val, idx) => acc + val * weights[idx], 0);
|
|
62
|
+
default:
|
|
63
|
+
return (vs) => {
|
|
64
|
+
// euclidean
|
|
65
|
+
const sum = vs.reduce((acc, val, idx) => acc + (val * weights[idx]) ** 2, 0);
|
|
66
|
+
return Math.sqrt(sum);
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJ1dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTRCLDBCQUEwQixFQUFDLE1BQU0sU0FBUyxDQUFDO0FBRTlFLE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBRyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLEtBQUssU0FBUyxDQUFDO0FBRS9ELE1BQU0sVUFBVSxhQUFhLENBQUMsV0FBcUIsRUFBRSxPQUFpQixFQUFFLEdBQVcsRUFBRSxLQUFhO0lBQ2hHLElBQUksR0FBRyxHQUFHLFdBQVcsQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFDLENBQUMsQ0FBQztRQUN6QyxPQUFPO0lBRVQsTUFBTSxXQUFXLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzFELFdBQVcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNsQixXQUFXLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFBRSxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDeEMsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ2QsT0FBTyxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBQ3hDLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLFdBQXFCLEVBQUUsT0FBaUIsRUFBRSxHQUFXLEVBQUUsS0FBYTtJQUMvRixJQUFJLEdBQUcsR0FBRyxXQUFXLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBQyxDQUFDLENBQUM7UUFDekMsT0FBTztJQUVULE1BQU0sV0FBVyxHQUFHLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMxRCxXQUFXLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDbEIsV0FBVyxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNkLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztBQUN4QyxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUNwQyxpQkFBNEMsRUFBRSxPQUFpQjtJQUUvRCxRQUFRLGlCQUFpQixFQUFFLENBQUM7UUFDMUIsS0FBSywwQkFBMEIsQ0FBQyxTQUFTO1lBQ3ZDLE9BQU8sQ0FBQyxFQUFZLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDckY7WUFDRSxPQUFPLENBQUMsRUFBWSxFQUFFLEVBQUU7Z0JBQ3RCLFlBQVk7Z0JBQ1osTUFBTSxHQUFHLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO2dCQUM3RSxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDeEIsQ0FBQyxDQUFDO0lBQ04sQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0Rpc3RhbmNlQWdncmVnYXRpb25NZXRob2QsIERpc3RhbmNlQWdncmVnYXRpb25NZXRob2RzfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGlzTmlsID0gKHg6IGFueSkgPT4geCA9PT0gbnVsbCB8fCB4ID09PSB1bmRlZmluZWQ7XG5cbmV4cG9ydCBmdW5jdGlvbiBpbnNlcnRTbWFsbGVyKGRpc3RhbmNlc0FyOiBudW1iZXJbXSwgaW5kZXhlczogbnVtYmVyW10sIG51bTogbnVtYmVyLCBpbmRleDogbnVtYmVyKSB7XG4gIGlmIChudW0gPiBkaXN0YW5jZXNBcltkaXN0YW5jZXNBci5sZW5ndGgtMV0pXG4gICAgcmV0dXJuO1xuXG4gIGNvbnN0IG5ld1Bvc2l0aW9uID0gZGlzdGFuY2VzQXIuZmluZEluZGV4KCh2KSA9PiBudW0gPCB2KTtcbiAgZGlzdGFuY2VzQXIucG9wKCk7XG4gIGRpc3RhbmNlc0FyLnNwbGljZShuZXdQb3NpdGlvbiwgMCwgbnVtKTtcbiAgaW5kZXhlcy5wb3AoKTtcbiAgaW5kZXhlcy5zcGxpY2UobmV3UG9zaXRpb24sIDAsIGluZGV4KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluc2VydExhcmdlcihkaXN0YW5jZXNBcjogbnVtYmVyW10sIGluZGV4ZXM6IG51bWJlcltdLCBudW06IG51bWJlciwgaW5kZXg6IG51bWJlcikge1xuICBpZiAobnVtIDwgZGlzdGFuY2VzQXJbZGlzdGFuY2VzQXIubGVuZ3RoLTFdKVxuICAgIHJldHVybjtcblxuICBjb25zdCBuZXdQb3NpdGlvbiA9IGRpc3RhbmNlc0FyLmZpbmRJbmRleCgodikgPT4gbnVtID4gdik7XG4gIGRpc3RhbmNlc0FyLnBvcCgpO1xuICBkaXN0YW5jZXNBci5zcGxpY2UobmV3UG9zaXRpb24sIDAsIG51bSk7XG4gIGluZGV4ZXMucG9wKCk7XG4gIGluZGV4ZXMuc3BsaWNlKG5ld1Bvc2l0aW9uLCAwLCBpbmRleCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRBZ2dyZWdhdGlvbkZ1bmN0aW9uKFxuICBhZ2dyZWdhdGlvbk1ldGhvZDogRGlzdGFuY2VBZ2dyZWdhdGlvbk1ldGhvZCwgd2VpZ2h0czogbnVtYmVyW11cbik6ICh2YWx1ZXM6IG51bWJlcltdKSA9PiBudW1iZXIge1xuICBzd2l0Y2ggKGFnZ3JlZ2F0aW9uTWV0aG9kKSB7XG4gICAgY2FzZSBEaXN0YW5jZUFnZ3JlZ2F0aW9uTWV0aG9kcy5NQU5IQVRUQU46XG4gICAgICByZXR1cm4gKHZzOiBudW1iZXJbXSkgPT4gdnMucmVkdWNlKChhY2MsIHZhbCwgaWR4KSA9PiBhY2MgKyB2YWwgKiB3ZWlnaHRzW2lkeF0sIDApO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gKHZzOiBudW1iZXJbXSkgPT4ge1xuICAgICAgICAvLyBldWNsaWRlYW5cbiAgICAgICAgY29uc3Qgc3VtID0gdnMucmVkdWNlKChhY2MsIHZhbCwgaWR4KSA9PiBhY2MgKyAodmFsICogd2VpZ2h0c1tpZHhdKSAqKiAyLCAwKTtcbiAgICAgICAgcmV0dXJuIE1hdGguc3FydChzdW0pO1xuICAgICAgfTtcbiAgfVxufVxuIl19
|
|
71
|
+
|
|
72
|
+
/***/ }),
|
|
73
|
+
|
|
74
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/distance-metrics-methods.js":
|
|
75
|
+
/*!*****************************************************************************!*\
|
|
76
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/distance-metrics-methods.js ***!
|
|
77
|
+
\*****************************************************************************/
|
|
78
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
79
|
+
|
|
80
|
+
__webpack_require__.r(__webpack_exports__);
|
|
81
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
82
|
+
/* harmony export */ CHEM_SIMILARITY_METRICS: () => (/* binding */ CHEM_SIMILARITY_METRICS),
|
|
83
|
+
/* harmony export */ MACROMOLECULE_SIMILARITY_METRICS: () => (/* binding */ MACROMOLECULE_SIMILARITY_METRICS),
|
|
84
|
+
/* harmony export */ SEQ_SPACE_SIMILARITY_METRICS: () => (/* binding */ SEQ_SPACE_SIMILARITY_METRICS),
|
|
85
|
+
/* harmony export */ asymmetricDistance: () => (/* binding */ asymmetricDistance),
|
|
86
|
+
/* harmony export */ asymmetricSimilarity: () => (/* binding */ asymmetricSimilarity),
|
|
87
|
+
/* harmony export */ braunBlanquetDistance: () => (/* binding */ braunBlanquetDistance),
|
|
88
|
+
/* harmony export */ braunBlanquetSimilarity: () => (/* binding */ braunBlanquetSimilarity),
|
|
89
|
+
/* harmony export */ commonItemsCount: () => (/* binding */ commonItemsCount),
|
|
90
|
+
/* harmony export */ cosineDistance: () => (/* binding */ cosineDistance),
|
|
91
|
+
/* harmony export */ cosineSimilarity: () => (/* binding */ cosineSimilarity),
|
|
92
|
+
/* harmony export */ diceDistance: () => (/* binding */ diceDistance),
|
|
93
|
+
/* harmony export */ diceSimilarity: () => (/* binding */ diceSimilarity),
|
|
94
|
+
/* harmony export */ distanceMetrics: () => (/* binding */ distanceMetrics),
|
|
95
|
+
/* harmony export */ euclideanDistanceBitArray: () => (/* binding */ euclideanDistanceBitArray),
|
|
96
|
+
/* harmony export */ euclideanSimilarity: () => (/* binding */ euclideanSimilarity),
|
|
97
|
+
/* harmony export */ getDistanceFromSimilarity: () => (/* binding */ getDistanceFromSimilarity),
|
|
98
|
+
/* harmony export */ getSimilarityFromDistance: () => (/* binding */ getSimilarityFromDistance),
|
|
99
|
+
/* harmony export */ hammingDistance: () => (/* binding */ hammingDistance),
|
|
100
|
+
/* harmony export */ hammingSimilarity: () => (/* binding */ hammingSimilarity),
|
|
101
|
+
/* harmony export */ inverseCommonItemsCount: () => (/* binding */ inverseCommonItemsCount),
|
|
102
|
+
/* harmony export */ kulczynskiDistance: () => (/* binding */ kulczynskiDistance),
|
|
103
|
+
/* harmony export */ kulczynskiSimilarity: () => (/* binding */ kulczynskiSimilarity),
|
|
104
|
+
/* harmony export */ mcConnaugheyDistance: () => (/* binding */ mcConnaugheyDistance),
|
|
105
|
+
/* harmony export */ mcConnaugheySimilarity: () => (/* binding */ mcConnaugheySimilarity),
|
|
106
|
+
/* harmony export */ numericDistance: () => (/* binding */ numericDistance),
|
|
107
|
+
/* harmony export */ rogotGoldbergDistance: () => (/* binding */ rogotGoldbergDistance),
|
|
108
|
+
/* harmony export */ rogotGoldbergSimilarity: () => (/* binding */ rogotGoldbergSimilarity),
|
|
109
|
+
/* harmony export */ russelDistance: () => (/* binding */ russelDistance),
|
|
110
|
+
/* harmony export */ russelSimilarity: () => (/* binding */ russelSimilarity),
|
|
111
|
+
/* harmony export */ similarityMetric: () => (/* binding */ similarityMetric),
|
|
112
|
+
/* harmony export */ sokalDistance: () => (/* binding */ sokalDistance),
|
|
113
|
+
/* harmony export */ sokalSimilarity: () => (/* binding */ sokalSimilarity),
|
|
114
|
+
/* harmony export */ tanimotoDistance: () => (/* binding */ tanimotoDistance),
|
|
115
|
+
/* harmony export */ tanimotoDistanceIntArray: () => (/* binding */ tanimotoDistanceIntArray),
|
|
116
|
+
/* harmony export */ tanimotoSimilarity: () => (/* binding */ tanimotoSimilarity),
|
|
117
|
+
/* harmony export */ vectorCosineDistance: () => (/* binding */ vectorCosineDistance),
|
|
118
|
+
/* harmony export */ vectorEuclideanDistance: () => (/* binding */ vectorEuclideanDistance),
|
|
119
|
+
/* harmony export */ vectorManhattenDistance: () => (/* binding */ vectorManhattenDistance)
|
|
120
|
+
/* harmony export */ });
|
|
121
|
+
/* harmony import */ var _datagrok_libraries_utils_src_bit_array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @datagrok-libraries/utils/src/bit-array */ "./node_modules/@datagrok-libraries/utils/src/bit-array.js");
|
|
122
|
+
/* harmony import */ var _typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./typed-metrics/consts */ "./node_modules/@datagrok-libraries/ml/src/typed-metrics/consts.js");
|
|
123
|
+
/* harmony import */ var _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./macromolecule-distance-functions */ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/index.js");
|
|
124
|
+
|
|
125
|
+
|
|
126
|
+
|
|
127
|
+
const similarityMetric = {
|
|
128
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Tanimoto]: tanimotoSimilarity,
|
|
129
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Dice]: diceSimilarity,
|
|
130
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Asymmetric]: asymmetricSimilarity,
|
|
131
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.BraunBlanquet]: braunBlanquetSimilarity,
|
|
132
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Cosine]: cosineSimilarity,
|
|
133
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Kulczynski]: kulczynskiSimilarity,
|
|
134
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.McConnaughey]: mcConnaugheySimilarity,
|
|
135
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.RogotGoldberg]: rogotGoldbergSimilarity,
|
|
136
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Russel]: russelSimilarity,
|
|
137
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Sokal]: sokalSimilarity,
|
|
138
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Hamming]: hammingSimilarity,
|
|
139
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Euclidean]: euclideanSimilarity,
|
|
140
|
+
};
|
|
141
|
+
const distanceMetrics = {
|
|
142
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Tanimoto]: tanimotoDistance,
|
|
143
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Dice]: diceDistance,
|
|
144
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Asymmetric]: asymmetricDistance,
|
|
145
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.BraunBlanquet]: braunBlanquetDistance,
|
|
146
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Cosine]: cosineDistance,
|
|
147
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Kulczynski]: kulczynskiDistance,
|
|
148
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.McConnaughey]: mcConnaugheyDistance,
|
|
149
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.RogotGoldberg]: rogotGoldbergDistance,
|
|
150
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Russel]: russelDistance,
|
|
151
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Sokal]: sokalDistance,
|
|
152
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Hamming]: hammingDistance,
|
|
153
|
+
[_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Euclidean]: euclideanDistanceBitArray,
|
|
154
|
+
};
|
|
155
|
+
const CHEM_SIMILARITY_METRICS = [
|
|
156
|
+
_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Tanimoto,
|
|
157
|
+
_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Dice,
|
|
158
|
+
_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Cosine
|
|
159
|
+
];
|
|
160
|
+
const SEQ_SPACE_SIMILARITY_METRICS = [
|
|
161
|
+
_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Tanimoto,
|
|
162
|
+
_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Asymmetric,
|
|
163
|
+
_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Cosine,
|
|
164
|
+
_typed_metrics_consts__WEBPACK_IMPORTED_MODULE_1__.BitArrayMetricsNames.Sokal
|
|
165
|
+
];
|
|
166
|
+
const MACROMOLECULE_SIMILARITY_METRICS = [
|
|
167
|
+
_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_2__.MmDistanceFunctionsNames.HAMMING,
|
|
168
|
+
_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_2__.MmDistanceFunctionsNames.LEVENSHTEIN,
|
|
169
|
+
_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_2__.MmDistanceFunctionsNames.MONOMER_CHEMICAL_DISTANCE,
|
|
170
|
+
_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_2__.MmDistanceFunctionsNames.NEEDLEMANN_WUNSCH
|
|
171
|
+
];
|
|
172
|
+
function tanimotoSimilarity(x, y) {
|
|
173
|
+
const total = x.trueCount() + y.trueCount();
|
|
174
|
+
if (total == 0)
|
|
175
|
+
return 1.0;
|
|
176
|
+
const common = x.andWithCountBits(y, true);
|
|
177
|
+
return common / (total - common);
|
|
178
|
+
}
|
|
179
|
+
function tanimotoDistance(x, y) {
|
|
180
|
+
return 1 - tanimotoSimilarity(x, y);
|
|
181
|
+
}
|
|
182
|
+
function tanimotoDistanceIntArray(x, y) {
|
|
183
|
+
const xb = new _datagrok_libraries_utils_src_bit_array__WEBPACK_IMPORTED_MODULE_0__["default"](x, x.length * 32);
|
|
184
|
+
const yb = new _datagrok_libraries_utils_src_bit_array__WEBPACK_IMPORTED_MODULE_0__["default"](y, y.length * 32);
|
|
185
|
+
return getDistanceFromSimilarity(tanimotoSimilarity(xb, yb));
|
|
186
|
+
}
|
|
187
|
+
function vectorEuclideanDistance(x, y) {
|
|
188
|
+
let sum = 0;
|
|
189
|
+
for (let i = 0; i < x.length; i++)
|
|
190
|
+
sum += Math.pow(x[i] - y[i], 2);
|
|
191
|
+
return Math.sqrt(sum);
|
|
192
|
+
}
|
|
193
|
+
function vectorManhattenDistance(x, y) {
|
|
194
|
+
let sum = 0;
|
|
195
|
+
for (let i = 0; i < x.length; i++)
|
|
196
|
+
sum += Math.abs(x[i] - y[i]);
|
|
197
|
+
return sum;
|
|
198
|
+
}
|
|
199
|
+
function vectorCosineDistance(x, y) {
|
|
200
|
+
let multSum = 0;
|
|
201
|
+
let xSquareSum = 0;
|
|
202
|
+
let ySquareSum = 0;
|
|
203
|
+
for (let i = 0; i < x.length; i++) {
|
|
204
|
+
multSum += x[i] * y[i];
|
|
205
|
+
xSquareSum += x[i] * x[i];
|
|
206
|
+
ySquareSum += y[i] * y[i];
|
|
207
|
+
}
|
|
208
|
+
const sim = multSum / (Math.sqrt(xSquareSum) * Math.sqrt(ySquareSum));
|
|
209
|
+
// similarity is in range [-1, 1], but we need distance in range [0, 1]
|
|
210
|
+
return (1 - sim) / 2;
|
|
211
|
+
}
|
|
212
|
+
function diceSimilarity(x, y) {
|
|
213
|
+
const total = x.trueCount() + y.trueCount();
|
|
214
|
+
if (total == 0)
|
|
215
|
+
return 0.0;
|
|
216
|
+
const common = x.andWithCountBits(y, true);
|
|
217
|
+
return 2 * common / total;
|
|
218
|
+
}
|
|
219
|
+
function diceDistance(x, y) {
|
|
220
|
+
return 1 - diceSimilarity(x, y);
|
|
221
|
+
}
|
|
222
|
+
function cosineSimilarity(x, y) {
|
|
223
|
+
const total = x.trueCount() * y.trueCount();
|
|
224
|
+
if (total == 0)
|
|
225
|
+
return 0.0;
|
|
226
|
+
const common = x.andWithCountBits(y, true);
|
|
227
|
+
return common / Math.sqrt(total);
|
|
228
|
+
}
|
|
229
|
+
function cosineDistance(x, y) {
|
|
230
|
+
return 1 - cosineSimilarity(x, y);
|
|
231
|
+
}
|
|
232
|
+
function euclideanSimilarity(x, y) {
|
|
233
|
+
return getSimilarityFromDistance(euclideanDistanceBitArray(x, y));
|
|
234
|
+
}
|
|
235
|
+
function euclideanDistanceBitArray(x, y) {
|
|
236
|
+
return Math.sqrt(x.trueCount() + y.trueCount() - 2 * x.andWithCountBits(y, true));
|
|
237
|
+
}
|
|
238
|
+
function hammingSimilarity(x, y) {
|
|
239
|
+
return getSimilarityFromDistance(hammingDistance(x, y));
|
|
240
|
+
}
|
|
241
|
+
function hammingDistance(x, y) {
|
|
242
|
+
return x.trueCount() + y.trueCount() - 2 * x.andWithCountBits(y, true);
|
|
243
|
+
}
|
|
244
|
+
function sokalSimilarity(x, y) {
|
|
245
|
+
const total = x.trueCount() + y.trueCount();
|
|
246
|
+
const common = x.andWithCountBits(y, true);
|
|
247
|
+
return common / (2 * total - 3 * common);
|
|
248
|
+
}
|
|
249
|
+
function sokalDistance(x, y) {
|
|
250
|
+
return 1 - sokalSimilarity(x, y);
|
|
251
|
+
}
|
|
252
|
+
function kulczynskiSimilarity(x, y) {
|
|
253
|
+
const total = x.trueCount() + y.trueCount();
|
|
254
|
+
const totalProd = x.trueCount() * y.trueCount();
|
|
255
|
+
if (totalProd == 0)
|
|
256
|
+
return 0.0;
|
|
257
|
+
const common = x.andWithCountBits(y, true);
|
|
258
|
+
return (common * total) / (2 * totalProd);
|
|
259
|
+
}
|
|
260
|
+
function kulczynskiDistance(x, y) {
|
|
261
|
+
return getDistanceFromSimilarity(kulczynskiSimilarity(x, y));
|
|
262
|
+
}
|
|
263
|
+
function mcConnaugheySimilarity(x, y) {
|
|
264
|
+
const total = x.trueCount() + y.trueCount();
|
|
265
|
+
const totalProd = x.trueCount() * y.trueCount();
|
|
266
|
+
if (totalProd == 0)
|
|
267
|
+
return 0.0;
|
|
268
|
+
const common = x.andWithCountBits(y, true);
|
|
269
|
+
return (common * total - totalProd) / totalProd;
|
|
270
|
+
}
|
|
271
|
+
function mcConnaugheyDistance(x, y) {
|
|
272
|
+
return getDistanceFromSimilarity(mcConnaugheySimilarity(x, y));
|
|
273
|
+
}
|
|
274
|
+
function asymmetricSimilarity(x, y) {
|
|
275
|
+
const min = Math.min(x.trueCount(), y.trueCount());
|
|
276
|
+
if (min == 0)
|
|
277
|
+
return 0.0;
|
|
278
|
+
const common = x.andWithCountBits(y, true);
|
|
279
|
+
return common / min;
|
|
280
|
+
}
|
|
281
|
+
function asymmetricDistance(x, y) {
|
|
282
|
+
return 1 - asymmetricSimilarity(x, y);
|
|
283
|
+
}
|
|
284
|
+
function braunBlanquetSimilarity(x, y) {
|
|
285
|
+
const max = Math.max(x.trueCount(), y.trueCount());
|
|
286
|
+
if (max == 0)
|
|
287
|
+
return 0.0;
|
|
288
|
+
const common = x.andWithCountBits(y, true);
|
|
289
|
+
return common / max;
|
|
290
|
+
}
|
|
291
|
+
function braunBlanquetDistance(x, y) {
|
|
292
|
+
return getDistanceFromSimilarity(braunBlanquetSimilarity(x, y));
|
|
293
|
+
}
|
|
294
|
+
function russelSimilarity(x, y) {
|
|
295
|
+
if (x.length == 0)
|
|
296
|
+
return 0.0;
|
|
297
|
+
const common = x.andWithCountBits(y, true);
|
|
298
|
+
return common / x.length;
|
|
299
|
+
}
|
|
300
|
+
function russelDistance(x, y) {
|
|
301
|
+
return getDistanceFromSimilarity(russelSimilarity(x, y));
|
|
302
|
+
}
|
|
303
|
+
function rogotGoldbergSimilarity(x, y) {
|
|
304
|
+
const common = x.andWithCountBits(y, true);
|
|
305
|
+
const total = x.countBits(true) + y.countBits(true);
|
|
306
|
+
const len = x.length;
|
|
307
|
+
const diff = len - total + common;
|
|
308
|
+
if ((common == len) || (diff == len))
|
|
309
|
+
return 1.0;
|
|
310
|
+
else
|
|
311
|
+
return common / total + diff / (2 * len - total);
|
|
312
|
+
}
|
|
313
|
+
function rogotGoldbergDistance(x, y) {
|
|
314
|
+
return getDistanceFromSimilarity(rogotGoldbergSimilarity(x, y));
|
|
315
|
+
}
|
|
316
|
+
function getSimilarityFromDistance(distance) {
|
|
317
|
+
return 1 / (1 + distance);
|
|
318
|
+
}
|
|
319
|
+
function getDistanceFromSimilarity(similarity) {
|
|
320
|
+
return similarity <= 0 ? 3.402823E+38 : (1 / similarity) - 1;
|
|
321
|
+
}
|
|
322
|
+
function numericDistance(args) {
|
|
323
|
+
if (args && args.range != undefined && args.range > 0) {
|
|
324
|
+
const range = args.range;
|
|
325
|
+
return (a, b) => Math.abs(a - b) / range;
|
|
326
|
+
}
|
|
327
|
+
return (a, b) => Math.abs(a - b);
|
|
328
|
+
}
|
|
329
|
+
function commonItemsCount(args) {
|
|
330
|
+
const mostCommon = args?.mostCommon ?? new Set();
|
|
331
|
+
return (arr1, arr2) => {
|
|
332
|
+
const len1 = arr1.length;
|
|
333
|
+
const len2 = arr2.length;
|
|
334
|
+
let count = 0;
|
|
335
|
+
let i1 = 0;
|
|
336
|
+
let i2 = 0;
|
|
337
|
+
while ((i1 < len1) && (i2 < len2)) {
|
|
338
|
+
if (arr1[i1] === arr2[i2]) {
|
|
339
|
+
if (!mostCommon?.has(arr1[i1]))
|
|
340
|
+
++count;
|
|
341
|
+
++i1;
|
|
342
|
+
++i2;
|
|
343
|
+
}
|
|
344
|
+
else if (arr1[i1] < arr2[i2]) {
|
|
345
|
+
++i1;
|
|
346
|
+
}
|
|
347
|
+
else {
|
|
348
|
+
++i2;
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
return count;
|
|
352
|
+
};
|
|
353
|
+
}
|
|
354
|
+
function inverseCommonItemsCount(args) {
|
|
355
|
+
const f = commonItemsCount(args);
|
|
356
|
+
return (arr1, arr2) => {
|
|
357
|
+
if (arr2.length === 0 || arr1.length === 0)
|
|
358
|
+
return 10000;
|
|
359
|
+
return Math.min(arr1.length, arr2.length) / (f(arr1, arr2) + 0.0001);
|
|
360
|
+
};
|
|
361
|
+
}
|
|
362
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"distance-metrics-methods.js","sourceRoot":"","sources":["distance-metrics-methods.ts"],"names":[],"mappings":"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","sourcesContent":["import BitArray from '@datagrok-libraries/utils/src/bit-array';\nimport {BitArrayMetricsNames} from './typed-metrics/consts';\nimport {MmDistanceFunctionsNames} from './macromolecule-distance-functions';\n\nexport const similarityMetric: { [name: string]: (x: BitArray, y: BitArray) => number } = {\n  [BitArrayMetricsNames.Tanimoto]: tanimotoSimilarity,\n  [BitArrayMetricsNames.Dice]: diceSimilarity,\n  [BitArrayMetricsNames.Asymmetric]: asymmetricSimilarity,\n  [BitArrayMetricsNames.BraunBlanquet]: braunBlanquetSimilarity,\n  [BitArrayMetricsNames.Cosine]: cosineSimilarity,\n  [BitArrayMetricsNames.Kulczynski]: kulczynskiSimilarity,\n  [BitArrayMetricsNames.McConnaughey]: mcConnaugheySimilarity,\n  [BitArrayMetricsNames.RogotGoldberg]: rogotGoldbergSimilarity,\n  [BitArrayMetricsNames.Russel]: russelSimilarity,\n  [BitArrayMetricsNames.Sokal]: sokalSimilarity,\n  [BitArrayMetricsNames.Hamming]: hammingSimilarity,\n  [BitArrayMetricsNames.Euclidean]: euclideanSimilarity,\n};\n\nexport const distanceMetrics: { [name: string]: (x: BitArray, y: BitArray) => number } = {\n  [BitArrayMetricsNames.Tanimoto]: tanimotoDistance,\n  [BitArrayMetricsNames.Dice]: diceDistance,\n  [BitArrayMetricsNames.Asymmetric]: asymmetricDistance,\n  [BitArrayMetricsNames.BraunBlanquet]: braunBlanquetDistance,\n  [BitArrayMetricsNames.Cosine]: cosineDistance,\n  [BitArrayMetricsNames.Kulczynski]: kulczynskiDistance,\n  [BitArrayMetricsNames.McConnaughey]: mcConnaugheyDistance,\n  [BitArrayMetricsNames.RogotGoldberg]: rogotGoldbergDistance,\n  [BitArrayMetricsNames.Russel]: russelDistance,\n  [BitArrayMetricsNames.Sokal]: sokalDistance,\n  [BitArrayMetricsNames.Hamming]: hammingDistance,\n  [BitArrayMetricsNames.Euclidean]: euclideanDistanceBitArray,\n};\n\nexport const CHEM_SIMILARITY_METRICS = [\n  BitArrayMetricsNames.Tanimoto,\n  BitArrayMetricsNames.Dice,\n  BitArrayMetricsNames.Cosine];\nexport const SEQ_SPACE_SIMILARITY_METRICS = [\n  BitArrayMetricsNames.Tanimoto,\n  BitArrayMetricsNames.Asymmetric,\n  BitArrayMetricsNames.Cosine,\n  BitArrayMetricsNames.Sokal];\nexport const MACROMOLECULE_SIMILARITY_METRICS = [\n  MmDistanceFunctionsNames.HAMMING,\n  MmDistanceFunctionsNames.LEVENSHTEIN,\n  MmDistanceFunctionsNames.MONOMER_CHEMICAL_DISTANCE,\n  MmDistanceFunctionsNames.NEEDLEMANN_WUNSCH\n];\n\n\nexport function tanimotoSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  if (total == 0) return 1.0;\n  const common = x.andWithCountBits(y, true);\n  return common / (total - common);\n}\n\nexport function tanimotoDistance(x: BitArray, y: BitArray): number {\n  return 1 - tanimotoSimilarity(x, y);\n}\n\nexport function tanimotoDistanceIntArray(x: Uint32Array, y: Uint32Array): number {\n  const xb = new BitArray(x, x.length * 32);\n  const yb = new BitArray(y, y.length * 32);\n  return getDistanceFromSimilarity(tanimotoSimilarity(xb, yb));\n}\n\nexport function vectorEuclideanDistance(x: ArrayLike<number>, y: ArrayLike<number>): number {\n  let sum = 0;\n  for (let i = 0; i < x.length; i++)\n    sum += Math.pow(x[i] - y[i], 2);\n  return Math.sqrt(sum);\n}\n\nexport function vectorManhattenDistance(x: ArrayLike<number>, y: ArrayLike<number>): number {\n  let sum = 0;\n  for (let i = 0; i < x.length; i++)\n    sum += Math.abs(x[i] - y[i]);\n  return sum;\n}\n\nexport function vectorCosineDistance(x: ArrayLike<number>, y: ArrayLike<number>): number {\n  let multSum = 0; let xSquareSum = 0; let ySquareSum = 0;\n  for (let i = 0; i < x.length; i++) {\n    multSum += x[i] * y[i];\n    xSquareSum += x[i] * x[i];\n    ySquareSum += y[i] * y[i];\n  }\n  const sim = multSum / (Math.sqrt(xSquareSum) * Math.sqrt(ySquareSum));\n  // similarity is in range [-1, 1], but we need distance in range [0, 1]\n  return (1 - sim) / 2; \n\n}\n\nexport function diceSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  if (total == 0) return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return 2 * common / total;\n}\n\nexport function diceDistance(x: BitArray, y: BitArray): number {\n  return 1 - diceSimilarity(x, y);\n}\n\nexport function cosineSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() * y.trueCount();\n  if (total == 0) return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / Math.sqrt(total);\n}\n\nexport function cosineDistance(x: BitArray, y: BitArray): number {\n  return 1 - cosineSimilarity(x, y);\n}\n\nexport function euclideanSimilarity(x: BitArray, y: BitArray): number {\n  return getSimilarityFromDistance(euclideanDistanceBitArray(x, y));\n}\n\nexport function euclideanDistanceBitArray(x: BitArray, y: BitArray): number {\n  return Math.sqrt(x.trueCount() + y.trueCount() - 2 * x.andWithCountBits(y, true));\n}\n\nexport function hammingSimilarity(x: BitArray, y: BitArray): number {\n  return getSimilarityFromDistance(hammingDistance(x, y));\n}\n\nexport function hammingDistance(x: BitArray, y: BitArray): number {\n  return x.trueCount() + y.trueCount() - 2 * x.andWithCountBits(y, true);\n}\n\nexport function sokalSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const common = x.andWithCountBits(y, true);\n  return common / (2 * total - 3 * common);\n}\n\nexport function sokalDistance(x: BitArray, y: BitArray): number {\n  return 1 - sokalSimilarity(x, y);\n}\n\nexport function kulczynskiSimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const totalProd = x.trueCount() * y.trueCount();\n  if (totalProd == 0) return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return (common * total) / (2 * totalProd);\n}\n\nexport function kulczynskiDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(kulczynskiSimilarity(x, y));\n}\n\nexport function mcConnaugheySimilarity(x: BitArray, y: BitArray): number {\n  const total = x.trueCount() + y.trueCount();\n  const totalProd = x.trueCount() * y.trueCount();\n  if (totalProd == 0) return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return (common * total - totalProd) / totalProd;\n}\n\nexport function mcConnaugheyDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(mcConnaugheySimilarity(x, y));\n}\n\nexport function asymmetricSimilarity(x: BitArray, y: BitArray): number {\n  const min = Math.min(x.trueCount(), y.trueCount());\n  if (min == 0) return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / min;\n}\n\nexport function asymmetricDistance(x: BitArray, y: BitArray): number {\n  return 1 - asymmetricSimilarity(x, y);\n}\n\nexport function braunBlanquetSimilarity(x: BitArray, y: BitArray): number {\n  const max = Math.max(x.trueCount(), y.trueCount());\n  if (max == 0) return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / max;\n}\n\nexport function braunBlanquetDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(braunBlanquetSimilarity(x, y));\n}\n\nexport function russelSimilarity(x: BitArray, y: BitArray): number {\n  if (x.length == 0) return 0.0;\n  const common = x.andWithCountBits(y, true);\n  return common / x.length;\n}\n\nexport function russelDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(russelSimilarity(x, y));\n}\n\nexport function rogotGoldbergSimilarity(x: BitArray, y: BitArray): number {\n  const common = x.andWithCountBits(y, true);\n  const total = x.countBits(true) + y.countBits(true);\n  const len = x.length;\n  const diff = len - total + common;\n  if ((common == len) || (diff == len)) return 1.0;\n  else return common / total + diff / (2 * len - total);\n}\n\nexport function rogotGoldbergDistance(x: BitArray, y: BitArray): number {\n  return getDistanceFromSimilarity(rogotGoldbergSimilarity(x, y));\n}\n\nexport function getSimilarityFromDistance(distance: number) {\n  return 1 / (1 + distance);\n}\n\nexport function getDistanceFromSimilarity(similarity: number) { //in case similarity is 0, use max number for float32\n  return similarity <= 0 ? 3.402823E+38 : (1 / similarity) - 1;\n}\n\nexport function numericDistance(args?: {range?: number}) {\n  if (args && args.range != undefined && args.range > 0) {\n    const range = args.range;\n    return (a: number, b: number) => Math.abs(a - b) / range;\n  }\n\n  return (a: number, b: number) => Math.abs(a - b);\n}\n\nexport function commonItemsCount(args?: {mostCommon?: Set<number>}) {\n  const mostCommon = args?.mostCommon ?? new Set<number>();\n  return (arr1: ArrayLike<number>, arr2: ArrayLike<number>) => {\n    const len1 = arr1.length;\n    const len2 = arr2.length;\n    let count = 0;\n    let i1 = 0;\n    let i2 = 0;\n\n    while ((i1 < len1) && (i2 < len2)) {\n      if (arr1[i1] === arr2[i2]) {\n        if (!mostCommon?.has(arr1[i1]))\n          ++count;\n        ++i1;\n        ++i2;\n      } else if (arr1[i1] < arr2[i2]) { ++i1; } else { ++i2; }\n    }\n\n    return count;\n  };\n}\n\nexport function inverseCommonItemsCount(args?: {mostCommon?: Set<number>}) {\n  const f = commonItemsCount(args);\n  return (arr1: ArrayLike<number>, arr2: ArrayLike<number>) => {\n    if (arr2.length === 0 || arr1.length === 0)\n      return 10000;\n\n    return Math.min(arr1.length, arr2.length) / (f(arr1, arr2) + 0.0001);\n  };\n}\n"]}
|
|
363
|
+
|
|
364
|
+
/***/ }),
|
|
365
|
+
|
|
366
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/hamming.js":
|
|
367
|
+
/*!*********************************************************************************************!*\
|
|
368
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/hamming.js ***!
|
|
369
|
+
\*********************************************************************************************/
|
|
370
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
371
|
+
|
|
372
|
+
__webpack_require__.r(__webpack_exports__);
|
|
373
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
374
|
+
/* harmony export */ hamming: () => (/* binding */ hamming)
|
|
375
|
+
/* harmony export */ });
|
|
376
|
+
function hamming(args = {}) {
|
|
377
|
+
function getDistanceF() {
|
|
378
|
+
if (!args || !args.scoringMatrix || !args.alphabetIndexes)
|
|
379
|
+
return (a, b) => a === b ? 0 : 1;
|
|
380
|
+
if (args.scoringMatrix.length !== Object.keys(args.alphabetIndexes).length)
|
|
381
|
+
throw new Error('Scoring matrix and alphabet indexes should have the same length');
|
|
382
|
+
const indexes = args.alphabetIndexes;
|
|
383
|
+
const matrix = args.scoringMatrix;
|
|
384
|
+
//const matrixMap = new Map<string, Map<string, number>>();
|
|
385
|
+
//const map2: any = {};
|
|
386
|
+
const minCharCode = Math.min(...Object.keys(indexes).map((k) => k.charCodeAt(0))) + 1;
|
|
387
|
+
const scorringArray = new Float32Array((matrix.length + minCharCode) * (matrix.length + minCharCode));
|
|
388
|
+
Object.entries(indexes).forEach(([key, index]) => {
|
|
389
|
+
//matrixMap.set(key, new Map<string, number>());
|
|
390
|
+
//map2[key] = {};
|
|
391
|
+
const matrixRow = matrix[index];
|
|
392
|
+
Object.entries(indexes).forEach(([key2, index2]) => {
|
|
393
|
+
//matrixMap.get(key)!.set(key2, matrixRow[index2]);
|
|
394
|
+
scorringArray[key.charCodeAt(0) * matrix.length + key2.charCodeAt(0)] = matrixRow[index2];
|
|
395
|
+
//map2[key][key2] = matrixRow[index2];
|
|
396
|
+
});
|
|
397
|
+
});
|
|
398
|
+
return (a, b) => {
|
|
399
|
+
return 1 - scorringArray[a.charCodeAt(0) * matrix.length + b.charCodeAt(0)];
|
|
400
|
+
};
|
|
401
|
+
}
|
|
402
|
+
const distanceF = getDistanceF();
|
|
403
|
+
const threshold = args?.threshold ?? 0;
|
|
404
|
+
return (seq1, seq2) => {
|
|
405
|
+
// hamming distance should only be used with same size strings,
|
|
406
|
+
// but still, lets add a check and if they are not same length add the difference to the result
|
|
407
|
+
let diff = 0;
|
|
408
|
+
const s1l = seq1.length;
|
|
409
|
+
const s2l = seq2.length;
|
|
410
|
+
const thresholdLimit = Math.ceil(Math.max(s1l, s2l) * (1 - threshold));
|
|
411
|
+
if (s1l !== s2l)
|
|
412
|
+
diff = Math.abs(s1l - s2l);
|
|
413
|
+
let result = 0;
|
|
414
|
+
for (let i = 0; i < Math.min(s1l, s2l); i++) {
|
|
415
|
+
if (seq1[i] !== seq2[i]) {
|
|
416
|
+
result += distanceF(seq1[i], seq2[i]);
|
|
417
|
+
if (result > thresholdLimit)
|
|
418
|
+
return 1;
|
|
419
|
+
}
|
|
420
|
+
}
|
|
421
|
+
result += diff;
|
|
422
|
+
result /= Math.max(s1l, s2l);
|
|
423
|
+
return result;
|
|
424
|
+
};
|
|
425
|
+
}
|
|
426
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFtbWluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImhhbW1pbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLE9BQU8sQ0FBQyxPQUF3QyxFQUFFO0lBQ2hFLFNBQVMsWUFBWTtRQUNuQixJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlO1lBQ3ZELE9BQU8sQ0FBQyxDQUFTLEVBQUUsQ0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNuRCxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxLQUFLLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLE1BQU07WUFDeEUsTUFBTSxJQUFJLEtBQUssQ0FBQyxpRUFBaUUsQ0FBQyxDQUFDO1FBQ3JGLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUM7UUFDckMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQztRQUNsQywyREFBMkQ7UUFDM0QsdUJBQXVCO1FBQ3ZCLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRXRGLE1BQU0sYUFBYSxHQUFHLElBQUksWUFBWSxDQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sR0FBRyxXQUFXLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUN0RyxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLEVBQUU7WUFDL0MsZ0RBQWdEO1lBQ2hELGlCQUFpQjtZQUNqQixNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDaEMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsRUFBRSxFQUFFO2dCQUNqRCxtREFBbUQ7Z0JBQ25ELGFBQWEsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztnQkFDMUYsc0NBQXNDO1lBQ3hDLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLENBQUMsQ0FBUyxFQUFFLENBQVMsRUFBRSxFQUFFO1lBQzlCLE9BQU8sQ0FBQyxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzlFLENBQUMsQ0FBQztJQUNKLENBQUM7SUFDRCxNQUFNLFNBQVMsR0FBRyxZQUFZLEVBQUUsQ0FBQztJQUVqQyxNQUFNLFNBQVMsR0FBRyxJQUFJLEVBQUUsU0FBUyxJQUFJLENBQUMsQ0FBQztJQUV2QyxPQUFPLENBQUMsSUFBWSxFQUFFLElBQVksRUFBRSxFQUFFO1FBQ3BDLCtEQUErRDtRQUMvRCwrRkFBK0Y7UUFDL0YsSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ2IsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUN4QixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQ3hCLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsU0FBUyxDQUFDLENBQUMsQ0FBQztRQUN2RSxJQUFJLEdBQUcsS0FBSyxHQUFHO1lBQ2IsSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBRTdCLElBQUksTUFBTSxHQUFHLENBQUMsQ0FBQztRQUNmLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQzVDLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUN4QixNQUFNLElBQUksU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDdEMsSUFBSSxNQUFNLEdBQUcsY0FBYztvQkFDekIsT0FBTyxDQUFDLENBQUM7WUFDYixDQUFDO1FBQ0gsQ0FBQztRQUNELE1BQU0sSUFBSSxJQUFJLENBQUM7UUFDZixNQUFNLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDN0IsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7bW1EaXN0YW5jZUZ1bmN0aW9uQXJncywgbW1EaXN0YW5jZUZ1bmN0aW9uVHlwZX0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBoYW1taW5nKGFyZ3M6IFBhcnRpYWw8bW1EaXN0YW5jZUZ1bmN0aW9uQXJncz4gPSB7fSk6IG1tRGlzdGFuY2VGdW5jdGlvblR5cGUge1xuICBmdW5jdGlvbiBnZXREaXN0YW5jZUYoKTogKGE6IHN0cmluZywgYjogc3RyaW5nKSA9PiBudW1iZXIge1xuICAgIGlmICghYXJncyB8fCAhYXJncy5zY29yaW5nTWF0cml4IHx8ICFhcmdzLmFscGhhYmV0SW5kZXhlcylcbiAgICAgIHJldHVybiAoYTogc3RyaW5nLCBiOiBzdHJpbmcpID0+IGEgPT09IGIgPyAwIDogMTtcbiAgICBpZiAoYXJncy5zY29yaW5nTWF0cml4Lmxlbmd0aCAhPT0gT2JqZWN0LmtleXMoYXJncy5hbHBoYWJldEluZGV4ZXMpLmxlbmd0aClcbiAgICAgIHRocm93IG5ldyBFcnJvcignU2NvcmluZyBtYXRyaXggYW5kIGFscGhhYmV0IGluZGV4ZXMgc2hvdWxkIGhhdmUgdGhlIHNhbWUgbGVuZ3RoJyk7XG4gICAgY29uc3QgaW5kZXhlcyA9IGFyZ3MuYWxwaGFiZXRJbmRleGVzO1xuICAgIGNvbnN0IG1hdHJpeCA9IGFyZ3Muc2NvcmluZ01hdHJpeDtcbiAgICAvL2NvbnN0IG1hdHJpeE1hcCA9IG5ldyBNYXA8c3RyaW5nLCBNYXA8c3RyaW5nLCBudW1iZXI+PigpO1xuICAgIC8vY29uc3QgbWFwMjogYW55ID0ge307XG4gICAgY29uc3QgbWluQ2hhckNvZGUgPSBNYXRoLm1pbiguLi5PYmplY3Qua2V5cyhpbmRleGVzKS5tYXAoKGspID0+IGsuY2hhckNvZGVBdCgwKSkpICsgMTtcblxuICAgIGNvbnN0IHNjb3JyaW5nQXJyYXkgPSBuZXcgRmxvYXQzMkFycmF5KChtYXRyaXgubGVuZ3RoICsgbWluQ2hhckNvZGUpICogKG1hdHJpeC5sZW5ndGggKyBtaW5DaGFyQ29kZSkpO1xuICAgIE9iamVjdC5lbnRyaWVzKGluZGV4ZXMpLmZvckVhY2goKFtrZXksIGluZGV4XSkgPT4ge1xuICAgICAgLy9tYXRyaXhNYXAuc2V0KGtleSwgbmV3IE1hcDxzdHJpbmcsIG51bWJlcj4oKSk7XG4gICAgICAvL21hcDJba2V5XSA9IHt9O1xuICAgICAgY29uc3QgbWF0cml4Um93ID0gbWF0cml4W2luZGV4XTtcbiAgICAgIE9iamVjdC5lbnRyaWVzKGluZGV4ZXMpLmZvckVhY2goKFtrZXkyLCBpbmRleDJdKSA9PiB7XG4gICAgICAgIC8vbWF0cml4TWFwLmdldChrZXkpIS5zZXQoa2V5MiwgbWF0cml4Um93W2luZGV4Ml0pO1xuICAgICAgICBzY29ycmluZ0FycmF5W2tleS5jaGFyQ29kZUF0KDApICogbWF0cml4Lmxlbmd0aCArIGtleTIuY2hhckNvZGVBdCgwKV0gPSBtYXRyaXhSb3dbaW5kZXgyXTtcbiAgICAgICAgLy9tYXAyW2tleV1ba2V5Ml0gPSBtYXRyaXhSb3dbaW5kZXgyXTtcbiAgICAgIH0pO1xuICAgIH0pO1xuICAgIHJldHVybiAoYTogc3RyaW5nLCBiOiBzdHJpbmcpID0+IHtcbiAgICAgIHJldHVybiAxIC0gc2NvcnJpbmdBcnJheVthLmNoYXJDb2RlQXQoMCkgKiBtYXRyaXgubGVuZ3RoICsgYi5jaGFyQ29kZUF0KDApXTtcbiAgICB9O1xuICB9XG4gIGNvbnN0IGRpc3RhbmNlRiA9IGdldERpc3RhbmNlRigpO1xuXG4gIGNvbnN0IHRocmVzaG9sZCA9IGFyZ3M/LnRocmVzaG9sZCA/PyAwO1xuXG4gIHJldHVybiAoc2VxMTogc3RyaW5nLCBzZXEyOiBzdHJpbmcpID0+IHtcbiAgICAvLyBoYW1taW5nIGRpc3RhbmNlIHNob3VsZCBvbmx5IGJlIHVzZWQgd2l0aCBzYW1lIHNpemUgc3RyaW5ncyxcbiAgICAvLyBidXQgc3RpbGwsIGxldHMgYWRkIGEgY2hlY2sgYW5kIGlmIHRoZXkgYXJlIG5vdCBzYW1lIGxlbmd0aCBhZGQgdGhlIGRpZmZlcmVuY2UgdG8gdGhlIHJlc3VsdFxuICAgIGxldCBkaWZmID0gMDtcbiAgICBjb25zdCBzMWwgPSBzZXExLmxlbmd0aDtcbiAgICBjb25zdCBzMmwgPSBzZXEyLmxlbmd0aDtcbiAgICBjb25zdCB0aHJlc2hvbGRMaW1pdCA9IE1hdGguY2VpbChNYXRoLm1heChzMWwsIHMybCkgKiAoMSAtIHRocmVzaG9sZCkpO1xuICAgIGlmIChzMWwgIT09IHMybClcbiAgICAgIGRpZmYgPSBNYXRoLmFicyhzMWwgLSBzMmwpO1xuXG4gICAgbGV0IHJlc3VsdCA9IDA7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBNYXRoLm1pbihzMWwsIHMybCk7IGkrKykge1xuICAgICAgaWYgKHNlcTFbaV0gIT09IHNlcTJbaV0pIHtcbiAgICAgICAgcmVzdWx0ICs9IGRpc3RhbmNlRihzZXExW2ldLCBzZXEyW2ldKTtcbiAgICAgICAgaWYgKHJlc3VsdCA+IHRocmVzaG9sZExpbWl0KVxuICAgICAgICAgIHJldHVybiAxO1xuICAgICAgfVxuICAgIH1cbiAgICByZXN1bHQgKz0gZGlmZjtcbiAgICByZXN1bHQgLz0gTWF0aC5tYXgoczFsLCBzMmwpO1xuICAgIHJldHVybiByZXN1bHQ7XG4gIH07XG59XG4iXX0=
|
|
427
|
+
|
|
428
|
+
/***/ }),
|
|
429
|
+
|
|
430
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/index.js":
|
|
431
|
+
/*!*******************************************************************************************!*\
|
|
432
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/index.js ***!
|
|
433
|
+
\*******************************************************************************************/
|
|
434
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
435
|
+
|
|
436
|
+
__webpack_require__.r(__webpack_exports__);
|
|
437
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
438
|
+
/* harmony export */ MmDistanceFunctionsNames: () => (/* reexport safe */ _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_0__.MmDistanceFunctionsNames),
|
|
439
|
+
/* harmony export */ mmDistanceFunctions: () => (/* reexport safe */ _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_0__.mmDistanceFunctions)
|
|
440
|
+
/* harmony export */ });
|
|
441
|
+
/* harmony import */ var _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./macromolecule-distance-functions */ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/macromolecule-distance-functions.js");
|
|
442
|
+
|
|
443
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsd0JBQXdCLEVBQUUsbUJBQW1CLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7TW1EaXN0YW5jZUZ1bmN0aW9uc05hbWVzLCBtbURpc3RhbmNlRnVuY3Rpb25zfSBmcm9tICcuL21hY3JvbW9sZWN1bGUtZGlzdGFuY2UtZnVuY3Rpb25zJztcbiJdfQ==
|
|
444
|
+
|
|
445
|
+
/***/ }),
|
|
446
|
+
|
|
447
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/levenstein.js":
|
|
448
|
+
/*!************************************************************************************************!*\
|
|
449
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/levenstein.js ***!
|
|
450
|
+
\************************************************************************************************/
|
|
451
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
452
|
+
|
|
453
|
+
__webpack_require__.r(__webpack_exports__);
|
|
454
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
455
|
+
/* harmony export */ levenstein: () => (/* binding */ levenstein)
|
|
456
|
+
/* harmony export */ });
|
|
457
|
+
/* harmony import */ var fastest_levenshtein__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! fastest-levenshtein */ "./node_modules/fastest-levenshtein/esm/mod.js");
|
|
458
|
+
|
|
459
|
+
function levenstein() {
|
|
460
|
+
return (seq1, seq2) => {
|
|
461
|
+
return (0,fastest_levenshtein__WEBPACK_IMPORTED_MODULE_0__.distance)(seq1, seq2) / Math.max(seq1.length, seq2.length);
|
|
462
|
+
};
|
|
463
|
+
}
|
|
464
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGV2ZW5zdGVpbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxldmVuc3RlaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBRzdDLE1BQU0sVUFBVSxVQUFVO0lBQ3hCLE9BQU8sQ0FBQyxJQUFZLEVBQUUsSUFBWSxFQUFFLEVBQUU7UUFDcEMsT0FBTyxRQUFRLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDbkUsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7ZGlzdGFuY2V9IGZyb20gJ2Zhc3Rlc3QtbGV2ZW5zaHRlaW4nO1xuaW1wb3J0IHttbURpc3RhbmNlRnVuY3Rpb25UeXBlfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGxldmVuc3RlaW4oKTogbW1EaXN0YW5jZUZ1bmN0aW9uVHlwZSB7XG4gIHJldHVybiAoc2VxMTogc3RyaW5nLCBzZXEyOiBzdHJpbmcpID0+IHtcbiAgICByZXR1cm4gZGlzdGFuY2Uoc2VxMSwgc2VxMikgLyBNYXRoLm1heChzZXExLmxlbmd0aCwgc2VxMi5sZW5ndGgpO1xuICB9O1xufVxuIl19
|
|
465
|
+
|
|
466
|
+
/***/ }),
|
|
467
|
+
|
|
468
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/macromolecule-distance-functions.js":
|
|
469
|
+
/*!**********************************************************************************************************************!*\
|
|
470
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/macromolecule-distance-functions.js ***!
|
|
471
|
+
\**********************************************************************************************************************/
|
|
472
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
473
|
+
|
|
474
|
+
__webpack_require__.r(__webpack_exports__);
|
|
475
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
476
|
+
/* harmony export */ MmDistanceFunctionsNames: () => (/* binding */ MmDistanceFunctionsNames),
|
|
477
|
+
/* harmony export */ mmDistanceFunctions: () => (/* binding */ mmDistanceFunctions)
|
|
478
|
+
/* harmony export */ });
|
|
479
|
+
/* harmony import */ var _hamming__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./hamming */ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/hamming.js");
|
|
480
|
+
/* harmony import */ var _levenstein__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./levenstein */ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/levenstein.js");
|
|
481
|
+
/* harmony import */ var _needleman_wunsch__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./needleman-wunsch */ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/needleman-wunsch.js");
|
|
482
|
+
|
|
483
|
+
|
|
484
|
+
|
|
485
|
+
/** Enum containing currently supported macromolecule distance functions
|
|
486
|
+
* Hamming distance will be used if the sequences are already aligned
|
|
487
|
+
* Needleman distance will be used for protein sequences with known BLOSUM62 matrix
|
|
488
|
+
* Levenshtein distance will be used for nucleotide sequences as for them substitution matrix is same as identity matrix
|
|
489
|
+
*/
|
|
490
|
+
var MmDistanceFunctionsNames;
|
|
491
|
+
(function (MmDistanceFunctionsNames) {
|
|
492
|
+
MmDistanceFunctionsNames["HAMMING"] = "Hamming";
|
|
493
|
+
MmDistanceFunctionsNames["LEVENSHTEIN"] = "Levenshtein";
|
|
494
|
+
MmDistanceFunctionsNames["NEEDLEMANN_WUNSCH"] = "Needlemann-Wunsch";
|
|
495
|
+
MmDistanceFunctionsNames["MONOMER_CHEMICAL_DISTANCE"] = "Monomer chemical distance";
|
|
496
|
+
})(MmDistanceFunctionsNames || (MmDistanceFunctionsNames = {}));
|
|
497
|
+
;
|
|
498
|
+
const mmDistanceFunctions = {
|
|
499
|
+
[MmDistanceFunctionsNames.HAMMING]: _hamming__WEBPACK_IMPORTED_MODULE_0__.hamming,
|
|
500
|
+
[MmDistanceFunctionsNames.LEVENSHTEIN]: _levenstein__WEBPACK_IMPORTED_MODULE_1__.levenstein,
|
|
501
|
+
[MmDistanceFunctionsNames.NEEDLEMANN_WUNSCH]: _needleman_wunsch__WEBPACK_IMPORTED_MODULE_2__.needlemanWunsch,
|
|
502
|
+
[MmDistanceFunctionsNames.MONOMER_CHEMICAL_DISTANCE]: _hamming__WEBPACK_IMPORTED_MODULE_0__.hamming
|
|
503
|
+
};
|
|
504
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFjcm9tb2xlY3VsZS1kaXN0YW5jZS1mdW5jdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtYWNyb21vbGVjdWxlLWRpc3RhbmNlLWZ1bmN0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sV0FBVyxDQUFDO0FBQ2xDLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxjQUFjLENBQUM7QUFDeEMsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBR25EOzs7O0dBSUc7QUFDSCxNQUFNLENBQU4sSUFBWSx3QkFLWDtBQUxELFdBQVksd0JBQXdCO0lBQ2xDLCtDQUFtQixDQUFBO0lBQ25CLHVEQUEyQixDQUFBO0lBQzNCLG1FQUF1QyxDQUFBO0lBQ3ZDLG1GQUF1RCxDQUFBO0FBQ3pELENBQUMsRUFMVyx3QkFBd0IsS0FBeEIsd0JBQXdCLFFBS25DO0FBQUEsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUE4RTtJQUM1RyxDQUFDLHdCQUF3QixDQUFDLE9BQU8sQ0FBQyxFQUFFLE9BQU87SUFDM0MsQ0FBQyx3QkFBd0IsQ0FBQyxXQUFXLENBQUMsRUFBRSxVQUFVO0lBQ2xELENBQUMsd0JBQXdCLENBQUMsaUJBQWlCLENBQUMsRUFBRSxlQUFlO0lBQzdELENBQUMsd0JBQXdCLENBQUMseUJBQXlCLENBQUMsRUFBRSxPQUFPO0NBQzlELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge2hhbW1pbmd9IGZyb20gJy4vaGFtbWluZyc7XG5pbXBvcnQge2xldmVuc3RlaW59IGZyb20gJy4vbGV2ZW5zdGVpbic7XG5pbXBvcnQge25lZWRsZW1hbld1bnNjaH0gZnJvbSAnLi9uZWVkbGVtYW4td3Vuc2NoJztcbmltcG9ydCB7bW1EaXN0YW5jZUZ1bmN0aW9uVHlwZX0gZnJvbSAnLi90eXBlcyc7XG5cbi8qKiBFbnVtIGNvbnRhaW5pbmcgY3VycmVudGx5IHN1cHBvcnRlZCBtYWNyb21vbGVjdWxlIGRpc3RhbmNlIGZ1bmN0aW9uc1xuICogSGFtbWluZyBkaXN0YW5jZSB3aWxsIGJlIHVzZWQgaWYgdGhlIHNlcXVlbmNlcyBhcmUgYWxyZWFkeSBhbGlnbmVkXG4gKiBOZWVkbGVtYW4gZGlzdGFuY2Ugd2lsbCBiZSB1c2VkIGZvciBwcm90ZWluIHNlcXVlbmNlcyB3aXRoIGtub3duIEJMT1NVTTYyIG1hdHJpeFxuICogTGV2ZW5zaHRlaW4gZGlzdGFuY2Ugd2lsbCBiZSB1c2VkIGZvciBudWNsZW90aWRlIHNlcXVlbmNlcyBhcyBmb3IgdGhlbSBzdWJzdGl0dXRpb24gbWF0cml4IGlzIHNhbWUgYXMgaWRlbnRpdHkgbWF0cml4XG4gKi9cbmV4cG9ydCBlbnVtIE1tRGlzdGFuY2VGdW5jdGlvbnNOYW1lcyB7XG4gIEhBTU1JTkcgPSAnSGFtbWluZycsXG4gIExFVkVOU0hURUlOID0gJ0xldmVuc2h0ZWluJyxcbiAgTkVFRExFTUFOTl9XVU5TQ0ggPSAnTmVlZGxlbWFubi1XdW5zY2gnLFxuICBNT05PTUVSX0NIRU1JQ0FMX0RJU1RBTkNFID0gJ01vbm9tZXIgY2hlbWljYWwgZGlzdGFuY2UnXG59O1xuXG5leHBvcnQgY29uc3QgbW1EaXN0YW5jZUZ1bmN0aW9uczogUmVjb3JkPE1tRGlzdGFuY2VGdW5jdGlvbnNOYW1lcywgKHZhbHVlPzogYW55KSA9PiBtbURpc3RhbmNlRnVuY3Rpb25UeXBlPiA9IHtcbiAgW01tRGlzdGFuY2VGdW5jdGlvbnNOYW1lcy5IQU1NSU5HXTogaGFtbWluZyxcbiAgW01tRGlzdGFuY2VGdW5jdGlvbnNOYW1lcy5MRVZFTlNIVEVJTl06IGxldmVuc3RlaW4sXG4gIFtNbURpc3RhbmNlRnVuY3Rpb25zTmFtZXMuTkVFRExFTUFOTl9XVU5TQ0hdOiBuZWVkbGVtYW5XdW5zY2gsXG4gIFtNbURpc3RhbmNlRnVuY3Rpb25zTmFtZXMuTU9OT01FUl9DSEVNSUNBTF9ESVNUQU5DRV06IGhhbW1pbmdcbn07XG4iXX0=
|
|
505
|
+
|
|
506
|
+
/***/ }),
|
|
507
|
+
|
|
508
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/needleman-wunsch.js":
|
|
509
|
+
/*!******************************************************************************************************!*\
|
|
510
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/needleman-wunsch.js ***!
|
|
511
|
+
\******************************************************************************************************/
|
|
512
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
513
|
+
|
|
514
|
+
__webpack_require__.r(__webpack_exports__);
|
|
515
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
516
|
+
/* harmony export */ needlemanWunsch: () => (/* binding */ needlemanWunsch)
|
|
517
|
+
/* harmony export */ });
|
|
518
|
+
// Blosum 62 matrix for protein sequences
|
|
519
|
+
const BLOSUM62 = [[4, -1, -2, -2, 0, -1, -1, 0, -2, -1, -1, -1, -1, -2, -1, 1, 0, -3, -2, 0, -2, -1, 0, -4],
|
|
520
|
+
[-1, 5, 0, -2, -3, 1, 0, -2, 0, -3, -2, 2, -1, -3, -2, -1, -1, -3, -2, -3, -1, 0, -1, -4],
|
|
521
|
+
[-2, 0, 6, 1, -3, 0, 0, 0, 1, -3, -3, 0, -2, -3, -2, 1, 0, -4, -2, -3, 3, 0, -1, -4],
|
|
522
|
+
[-2, -2, 1, 6, -3, 0, 2, -1, -1, -3, -4, -1, -3, -3, -1, 0, -1, -4, -3, -3, 4, 1, -1, -4],
|
|
523
|
+
[0, -3, -3, -3, 9, -3, -4, -3, -3, -1, -1, -3, -1, -2, -3, -1, -1, -2, -2, -1, -3, -3, -2, -4],
|
|
524
|
+
[-1, 1, 0, 0, -3, 5, 2, -2, 0, -3, -2, 1, 0, -3, -1, 0, -1, -2, -1, -2, 0, 3, -1, -4],
|
|
525
|
+
[-1, 0, 0, 2, -4, 2, 5, -2, 0, -3, -3, 1, -2, -3, -1, 0, -1, -3, -2, -2, 1, 4, -1, -4],
|
|
526
|
+
[0, -2, 0, -1, -3, -2, -2, 6, -2, -4, -4, -2, -3, -3, -2, 0, -2, -2, -3, -3, -1, -2, -1, -4],
|
|
527
|
+
[-2, 0, 1, -1, -3, 0, 0, -2, 8, -3, -3, -1, -2, -1, -2, -1, -2, -2, 2, -3, 0, 0, -1, -4],
|
|
528
|
+
[-1, -3, -3, -3, -1, -3, -3, -4, -3, 4, 2, -3, 1, 0, -3, -2, -1, -3, -1, 3, -3, -3, -1, -4],
|
|
529
|
+
[-1, -2, -3, -4, -1, -2, -3, -4, -3, 2, 4, -2, 2, 0, -3, -2, -1, -2, -1, 1, -4, -3, -1, -4],
|
|
530
|
+
[-1, 2, 0, -1, -3, 1, 1, -2, -1, -3, -2, 5, -1, -3, -1, 0, -1, -3, -2, -2, 0, 1, -1, -4],
|
|
531
|
+
[-1, -1, -2, -3, -1, 0, -2, -3, -2, 1, 2, -1, 5, 0, -2, -1, -1, -1, -1, 1, -3, -1, -1, -4],
|
|
532
|
+
[-2, -3, -3, -3, -2, -3, -3, -3, -1, 0, 0, -3, 0, 6, -4, -2, -2, 1, 3, -1, -3, -3, -1, -4],
|
|
533
|
+
[-1, -2, -2, -1, -3, -1, -1, -2, -2, -3, -3, -1, -2, -4, 7, -1, -1, -4, -3, -2, -2, -1, -2, -4],
|
|
534
|
+
[1, -1, 1, 0, -1, 0, 0, 0, -1, -2, -2, 0, -1, -2, -1, 4, 1, -3, -2, -2, 0, 0, 0, -4],
|
|
535
|
+
[0, -1, 0, -1, -1, -1, -1, -2, -2, -1, -1, -1, -1, -2, -1, 1, 5, -2, -2, 0, -1, -1, 0, -4],
|
|
536
|
+
[-3, -3, -4, -4, -2, -2, -3, -2, -2, -3, -2, -3, -1, 1, -4, -3, -2, 11, 2, -3, -4, -3, -2, -4],
|
|
537
|
+
[-2, -2, -2, -3, -2, -1, -2, -3, 2, -1, -1, -2, -1, 3, -3, -2, -2, 2, 7, -1, -3, -2, -1, -4],
|
|
538
|
+
[0, -3, -3, -3, -1, -2, -2, -3, -3, 3, 1, -2, 1, -1, -2, -2, 0, -3, -1, 4, -3, -2, -1, -4],
|
|
539
|
+
[-2, -1, 3, 4, -3, 0, 1, -1, 0, -3, -4, 0, -3, -3, -2, 0, -1, -4, -3, -3, 4, 1, -1, -4],
|
|
540
|
+
[-1, 0, 0, 1, -3, 3, 4, -2, 0, -3, -3, 1, -1, -3, -1, 0, -1, -3, -2, -2, 1, 4, -1, -4],
|
|
541
|
+
[0, -1, -1, -1, -2, -1, -1, -1, -1, -1, -1, -1, -1, -1, -2, 0, 0, -2, -1, -1, -1, -1, -1, -4],
|
|
542
|
+
[-4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, 1]];
|
|
543
|
+
// Protein indexes for BLOSUM matrix
|
|
544
|
+
const ProtIndexes = {
|
|
545
|
+
'A': 0, 'R': 1, 'N': 2, 'D': 3, 'C': 4, 'Q': 5, 'E': 6, 'G': 7, 'H': 8,
|
|
546
|
+
'I': 9, 'L': 10, 'K': 11, 'M': 12, 'F': 13, 'P': 14, 'S': 15, 'T': 16,
|
|
547
|
+
'W': 17, 'Y': 18, 'V': 19, 'B': 20, 'Z': 21, 'X': 22, '*': 23
|
|
548
|
+
};
|
|
549
|
+
const defaultArgs = {
|
|
550
|
+
gapOpen: 1,
|
|
551
|
+
gapExtend: 0.6,
|
|
552
|
+
scoringMatrix: BLOSUM62,
|
|
553
|
+
alphabetIndexes: ProtIndexes
|
|
554
|
+
};
|
|
555
|
+
/** Returns a function that calculates the distance between two sequences based on gap penalty and matrix
|
|
556
|
+
* @param {Partial<NeedlemanWunschArgs>}args - arguments for Needleman-Wunsch algorithm like gap penalty, Scoring matrix..
|
|
557
|
+
* @return {mmDistanceFunctionType} - function that calculates the distance between two sequences
|
|
558
|
+
*/
|
|
559
|
+
function needlemanWunsch(args) {
|
|
560
|
+
const maxLen = 10000;
|
|
561
|
+
const charCodeArray = new Uint16Array(0x10000);
|
|
562
|
+
const { gapOpen, gapExtend, scoringMatrix, alphabetIndexes } = { ...defaultArgs, ...args };
|
|
563
|
+
Object.entries(alphabetIndexes).forEach(([k, v]) => charCodeArray[k.charCodeAt(0)] = v);
|
|
564
|
+
// As we don't need traceback, no need to store the whole matrix
|
|
565
|
+
// Instead, we will store only the last two rows
|
|
566
|
+
const matrix = [
|
|
567
|
+
new Float32Array(maxLen),
|
|
568
|
+
new Float32Array(maxLen)
|
|
569
|
+
];
|
|
570
|
+
return (seq1, seq2) => {
|
|
571
|
+
// similarly, we need to keep track of what operation led to the current cell
|
|
572
|
+
// i.e. whether we came from the left, top or diagonal to assign gap open/gap extend penalty
|
|
573
|
+
const verticalGaps = new Array(seq1.length + 1).fill(false);
|
|
574
|
+
const horizontalGaps = new Array(seq1.length + 1).fill(false);
|
|
575
|
+
//variables to keep track which row we are in
|
|
576
|
+
// they will swap places on each iteration
|
|
577
|
+
let prevRow = 0;
|
|
578
|
+
let currRow = 1;
|
|
579
|
+
// Initialize first row
|
|
580
|
+
for (let i = 1; i < seq1.length + 1; i++) {
|
|
581
|
+
matrix[0][i] = -gapExtend - (i - 1) * gapExtend;
|
|
582
|
+
matrix[1][i] = 0;
|
|
583
|
+
}
|
|
584
|
+
matrix[0][0] = 0;
|
|
585
|
+
// Calculate the rest of the matrix
|
|
586
|
+
for (let i = 1; i < seq2.length + 1; i++) {
|
|
587
|
+
matrix[currRow][0] = -gapExtend - (i - 1) * gapExtend;
|
|
588
|
+
for (let j = 1; j < seq1.length + 1; j++) {
|
|
589
|
+
const diagonal = matrix[prevRow][j - 1] +
|
|
590
|
+
scoringMatrix[charCodeArray[seq1.charCodeAt(j - 1)]][charCodeArray[seq2.charCodeAt(i - 1)]];
|
|
591
|
+
const top = matrix[prevRow][j] - (verticalGaps[j] || i === 1 || i === seq2.length ? gapExtend : gapOpen);
|
|
592
|
+
const left = matrix[currRow][j - 1] - (horizontalGaps[j - 1] || j === 1 || j === seq1.length ? gapExtend : gapOpen);
|
|
593
|
+
matrix[currRow][j] = Math.max(diagonal, left, top);
|
|
594
|
+
// update gap arrays
|
|
595
|
+
if (matrix[currRow][j] === diagonal) {
|
|
596
|
+
verticalGaps[j] = false;
|
|
597
|
+
horizontalGaps[j] = false;
|
|
598
|
+
}
|
|
599
|
+
else if (matrix[currRow][j] === left) {
|
|
600
|
+
verticalGaps[j] = false;
|
|
601
|
+
horizontalGaps[j] = true;
|
|
602
|
+
}
|
|
603
|
+
else {
|
|
604
|
+
verticalGaps[j] = true;
|
|
605
|
+
horizontalGaps[j] = false;
|
|
606
|
+
}
|
|
607
|
+
}
|
|
608
|
+
// Swap rows
|
|
609
|
+
prevRow = currRow;
|
|
610
|
+
currRow = (currRow + 1) % 2;
|
|
611
|
+
}
|
|
612
|
+
// as the matrix is the similarity matrix, but we are interested in distance,
|
|
613
|
+
// we need compare it to perfect match score to get reasonable distance
|
|
614
|
+
// const perfectMatchSeq1 = seq1.split('').map((c) => scoringMatrix[alphabetIndexes[c]][alphabetIndexes[c]])
|
|
615
|
+
// .reduce((a, b) => a + b, 0);
|
|
616
|
+
// const perfectMatchSeq2 = seq2.split('').map((c) => scoringMatrix[alphabetIndexes[c]][alphabetIndexes[c]])
|
|
617
|
+
// .reduce((a, b) => a + b, 0);
|
|
618
|
+
// const maxScore = Math.max(perfectMatchSeq1, perfectMatchSeq2);
|
|
619
|
+
const maxScore = Math.min(seq1.length, seq2.length);
|
|
620
|
+
return (maxScore - matrix[prevRow][seq1.length]) / maxScore;
|
|
621
|
+
};
|
|
622
|
+
}
|
|
623
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"needleman-wunsch.js","sourceRoot":"","sources":["needleman-wunsch.ts"],"names":[],"mappings":"AAGA,yCAAyC;AACzC,MAAM,QAAQ,GACd,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IACxF,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzF,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACpF,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzF,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC9F,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACrF,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACtF,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5F,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxF,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3F,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3F,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxF,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1F,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1F,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC/F,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IACpF,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1F,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC9F,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5F,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1F,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACvF,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,C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","sourcesContent":["/* eslint-disable max-len */\nimport {mmDistanceFunctionArgs, mmDistanceFunctionType} from './types';\n\n// Blosum 62 matrix for protein sequences\nconst BLOSUM62:Array<Array<number>> =\n[[4, -1, -2, -2, 0, -1, -1, 0, -2, -1, -1, -1, -1, -2, -1, 1, 0, -3, -2, 0, -2, -1, 0, -4],\n  [-1, 5, 0, -2, -3, 1, 0, -2, 0, -3, -2, 2, -1, -3, -2, -1, -1, -3, -2, -3, -1, 0, -1, -4],\n  [-2, 0, 6, 1, -3, 0, 0, 0, 1, -3, -3, 0, -2, -3, -2, 1, 0, -4, -2, -3, 3, 0, -1, -4],\n  [-2, -2, 1, 6, -3, 0, 2, -1, -1, -3, -4, -1, -3, -3, -1, 0, -1, -4, -3, -3, 4, 1, -1, -4],\n  [0, -3, -3, -3, 9, -3, -4, -3, -3, -1, -1, -3, -1, -2, -3, -1, -1, -2, -2, -1, -3, -3, -2, -4],\n  [-1, 1, 0, 0, -3, 5, 2, -2, 0, -3, -2, 1, 0, -3, -1, 0, -1, -2, -1, -2, 0, 3, -1, -4],\n  [-1, 0, 0, 2, -4, 2, 5, -2, 0, -3, -3, 1, -2, -3, -1, 0, -1, -3, -2, -2, 1, 4, -1, -4],\n  [0, -2, 0, -1, -3, -2, -2, 6, -2, -4, -4, -2, -3, -3, -2, 0, -2, -2, -3, -3, -1, -2, -1, -4],\n  [-2, 0, 1, -1, -3, 0, 0, -2, 8, -3, -3, -1, -2, -1, -2, -1, -2, -2, 2, -3, 0, 0, -1, -4],\n  [-1, -3, -3, -3, -1, -3, -3, -4, -3, 4, 2, -3, 1, 0, -3, -2, -1, -3, -1, 3, -3, -3, -1, -4],\n  [-1, -2, -3, -4, -1, -2, -3, -4, -3, 2, 4, -2, 2, 0, -3, -2, -1, -2, -1, 1, -4, -3, -1, -4],\n  [-1, 2, 0, -1, -3, 1, 1, -2, -1, -3, -2, 5, -1, -3, -1, 0, -1, -3, -2, -2, 0, 1, -1, -4],\n  [-1, -1, -2, -3, -1, 0, -2, -3, -2, 1, 2, -1, 5, 0, -2, -1, -1, -1, -1, 1, -3, -1, -1, -4],\n  [-2, -3, -3, -3, -2, -3, -3, -3, -1, 0, 0, -3, 0, 6, -4, -2, -2, 1, 3, -1, -3, -3, -1, -4],\n  [-1, -2, -2, -1, -3, -1, -1, -2, -2, -3, -3, -1, -2, -4, 7, -1, -1, -4, -3, -2, -2, -1, -2, -4],\n  [1, -1, 1, 0, -1, 0, 0, 0, -1, -2, -2, 0, -1, -2, -1, 4, 1, -3, -2, -2, 0, 0, 0, -4],\n  [0, -1, 0, -1, -1, -1, -1, -2, -2, -1, -1, -1, -1, -2, -1, 1, 5, -2, -2, 0, -1, -1, 0, -4],\n  [-3, -3, -4, -4, -2, -2, -3, -2, -2, -3, -2, -3, -1, 1, -4, -3, -2, 11, 2, -3, -4, -3, -2, -4],\n  [-2, -2, -2, -3, -2, -1, -2, -3, 2, -1, -1, -2, -1, 3, -3, -2, -2, 2, 7, -1, -3, -2, -1, -4],\n  [0, -3, -3, -3, -1, -2, -2, -3, -3, 3, 1, -2, 1, -1, -2, -2, 0, -3, -1, 4, -3, -2, -1, -4],\n  [-2, -1, 3, 4, -3, 0, 1, -1, 0, -3, -4, 0, -3, -3, -2, 0, -1, -4, -3, -3, 4, 1, -1, -4],\n  [-1, 0, 0, 1, -3, 3, 4, -2, 0, -3, -3, 1, -1, -3, -1, 0, -1, -3, -2, -2, 1, 4, -1, -4],\n  [0, -1, -1, -1, -2, -1, -1, -1, -1, -1, -1, -1, -1, -1, -2, 0, 0, -2, -1, -1, -1, -1, -1, -4],\n  [-4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, 1]];\n\n// Protein indexes for BLOSUM matrix\nconst ProtIndexes: {[id:string]:number} = {\n  'A': 0, 'R': 1, 'N': 2, 'D': 3, 'C': 4, 'Q': 5, 'E': 6, 'G': 7, 'H': 8,\n  'I': 9, 'L': 10, 'K': 11, 'M': 12, 'F': 13, 'P': 14, 'S': 15, 'T': 16,\n  'W': 17, 'Y': 18, 'V': 19, 'B': 20, 'Z': 21, 'X': 22, '*': 23\n};\n\ntype NeedlemanWunschArgs = mmDistanceFunctionArgs & {\n  gapOpen: number;\n  gapExtend: number;\n}\n\nconst defaultArgs: NeedlemanWunschArgs = {\n  gapOpen: 1,\n  gapExtend: 0.6,\n  scoringMatrix: BLOSUM62,\n  alphabetIndexes: ProtIndexes\n};\n\n/** Returns a function that calculates the distance between two sequences based on gap penalty and matrix\n * @param {Partial<NeedlemanWunschArgs>}args - arguments for Needleman-Wunsch algorithm like gap penalty, Scoring matrix..\n * @return {mmDistanceFunctionType} - function that calculates the distance between two sequences\n*/\nexport function needlemanWunsch(args: Partial<NeedlemanWunschArgs>): mmDistanceFunctionType {\n  const maxLen = 10000;\n  const charCodeArray = new Uint16Array(0x10000);\n\n  const {gapOpen, gapExtend, scoringMatrix, alphabetIndexes} = {...defaultArgs, ...args};\n  Object.entries(alphabetIndexes).forEach(([k, v]) => charCodeArray[k.charCodeAt(0)] = v);\n  // As we don't need traceback, no need to store the whole matrix\n  // Instead, we will store only the last two rows\n  const matrix: Array<Float32Array> = [\n    new Float32Array(maxLen),\n    new Float32Array(maxLen)\n  ];\n  return (seq1: string, seq2: string) : number => {\n    // similarly, we need to keep track of what operation led to the current cell\n    // i.e. whether we came from the left, top or diagonal to assign gap open/gap extend penalty\n\n    const verticalGaps: boolean[] = new Array<boolean>(seq1.length +1).fill(false);\n    const horizontalGaps: boolean[] = new Array<boolean>(seq1.length +1).fill(false);\n    //variables to keep track which row we are in\n    // they will swap places on each iteration\n    let prevRow = 0;\n    let currRow = 1;\n    // Initialize first row\n    for (let i = 1; i < seq1.length + 1; i++) {\n      matrix[0][i] = -gapExtend - (i - 1) * gapExtend;\n      matrix[1][i] = 0;\n    }\n    matrix[0][0] = 0;\n\n    // Calculate the rest of the matrix\n    for (let i = 1; i < seq2.length + 1; i++) {\n      matrix[currRow][0] = -gapExtend - (i - 1) * gapExtend;\n      for (let j = 1; j < seq1.length + 1; j++) {\n        const diagonal =\n          matrix[prevRow][j - 1] +\n            scoringMatrix[charCodeArray[seq1.charCodeAt(j - 1)]][charCodeArray[seq2.charCodeAt(i - 1)]];\n        const top = matrix[prevRow][j] - (verticalGaps[j] || i === 1 || i === seq2.length ? gapExtend : gapOpen );\n        const left = matrix[currRow][j - 1] - (horizontalGaps[j - 1] || j === 1 || j === seq1.length ? gapExtend : gapOpen);\n        matrix[currRow][j] = Math.max(\n          diagonal, left, top\n        );\n        // update gap arrays\n        if (matrix[currRow][j] === diagonal) {\n          verticalGaps[j] = false;\n          horizontalGaps[j] = false;\n        } else if (matrix[currRow][j] === left) {\n          verticalGaps[j] = false;\n          horizontalGaps[j] = true;\n        } else {\n          verticalGaps[j] = true;\n          horizontalGaps[j] = false;\n        }\n      }\n      // Swap rows\n      prevRow = currRow;\n      currRow = (currRow + 1) % 2;\n    }\n    // as the matrix is the similarity matrix, but we are interested in distance,\n    // we need compare it to perfect match score to get reasonable distance\n    // const perfectMatchSeq1 = seq1.split('').map((c) => scoringMatrix[alphabetIndexes[c]][alphabetIndexes[c]])\n    //   .reduce((a, b) => a + b, 0);\n    // const perfectMatchSeq2 = seq2.split('').map((c) => scoringMatrix[alphabetIndexes[c]][alphabetIndexes[c]])\n    //   .reduce((a, b) => a + b, 0);\n    // const maxScore = Math.max(perfectMatchSeq1, perfectMatchSeq2);\n    const maxScore = Math.min(seq1.length, seq2.length);\n    return (maxScore - matrix[prevRow][seq1.length]) / maxScore;\n  };\n}\n"]}
|
|
624
|
+
|
|
625
|
+
/***/ }),
|
|
626
|
+
|
|
627
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/typed-metrics/consts.js":
|
|
628
|
+
/*!*************************************************************************!*\
|
|
629
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/typed-metrics/consts.js ***!
|
|
630
|
+
\*************************************************************************/
|
|
631
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
632
|
+
|
|
633
|
+
__webpack_require__.r(__webpack_exports__);
|
|
634
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
635
|
+
/* harmony export */ BitArrayMetricsNames: () => (/* binding */ BitArrayMetricsNames),
|
|
636
|
+
/* harmony export */ DistanceMetricsSubjects: () => (/* binding */ DistanceMetricsSubjects),
|
|
637
|
+
/* harmony export */ IntArrayMetricsNames: () => (/* binding */ IntArrayMetricsNames),
|
|
638
|
+
/* harmony export */ NumberArrayMetricsNames: () => (/* binding */ NumberArrayMetricsNames),
|
|
639
|
+
/* harmony export */ NumberMetricsNames: () => (/* binding */ NumberMetricsNames),
|
|
640
|
+
/* harmony export */ StringMetricsNames: () => (/* binding */ StringMetricsNames),
|
|
641
|
+
/* harmony export */ VectorMetricsNames: () => (/* binding */ VectorMetricsNames)
|
|
642
|
+
/* harmony export */ });
|
|
643
|
+
var StringMetricsNames;
|
|
644
|
+
(function (StringMetricsNames) {
|
|
645
|
+
StringMetricsNames["Levenshtein"] = "Levenshtein";
|
|
646
|
+
StringMetricsNames["JaroWinkler"] = "Jaro-Winkler";
|
|
647
|
+
StringMetricsNames["Manhattan"] = "Manhattan String";
|
|
648
|
+
StringMetricsNames["Onehot"] = "One-Hot";
|
|
649
|
+
})(StringMetricsNames || (StringMetricsNames = {}));
|
|
650
|
+
var VectorMetricsNames;
|
|
651
|
+
(function (VectorMetricsNames) {
|
|
652
|
+
VectorMetricsNames["Euclidean"] = "Euclidean";
|
|
653
|
+
VectorMetricsNames["Manhattan"] = "Manhattan";
|
|
654
|
+
VectorMetricsNames["Cosine"] = "Vector Cosine";
|
|
655
|
+
})(VectorMetricsNames || (VectorMetricsNames = {}));
|
|
656
|
+
var BitArrayMetricsNames;
|
|
657
|
+
(function (BitArrayMetricsNames) {
|
|
658
|
+
BitArrayMetricsNames["Tanimoto"] = "Tanimoto";
|
|
659
|
+
BitArrayMetricsNames["Dice"] = "Dice";
|
|
660
|
+
BitArrayMetricsNames["Asymmetric"] = "Asymmetric";
|
|
661
|
+
BitArrayMetricsNames["BraunBlanquet"] = "Braun-Blanquet";
|
|
662
|
+
BitArrayMetricsNames["Cosine"] = "Cosine";
|
|
663
|
+
BitArrayMetricsNames["Kulczynski"] = "Kulczynski";
|
|
664
|
+
BitArrayMetricsNames["McConnaughey"] = "Mc-Connaughey";
|
|
665
|
+
BitArrayMetricsNames["RogotGoldberg"] = "Rogot-Goldberg";
|
|
666
|
+
BitArrayMetricsNames["Russel"] = "Russel";
|
|
667
|
+
BitArrayMetricsNames["Sokal"] = "Sokal";
|
|
668
|
+
BitArrayMetricsNames["Hamming"] = "Hamming";
|
|
669
|
+
BitArrayMetricsNames["Euclidean"] = "Euclidean BitArray";
|
|
670
|
+
})(BitArrayMetricsNames || (BitArrayMetricsNames = {}));
|
|
671
|
+
var IntArrayMetricsNames;
|
|
672
|
+
(function (IntArrayMetricsNames) {
|
|
673
|
+
IntArrayMetricsNames["TanimotoIntArray"] = "TanimotoIntArray";
|
|
674
|
+
})(IntArrayMetricsNames || (IntArrayMetricsNames = {}));
|
|
675
|
+
var DistanceMetricsSubjects;
|
|
676
|
+
(function (DistanceMetricsSubjects) {
|
|
677
|
+
DistanceMetricsSubjects["Vector"] = "Vector";
|
|
678
|
+
DistanceMetricsSubjects["String"] = "String";
|
|
679
|
+
DistanceMetricsSubjects["BitArray"] = "BitArray";
|
|
680
|
+
DistanceMetricsSubjects["MacroMolecule"] = "MacroMolecule";
|
|
681
|
+
DistanceMetricsSubjects["Number"] = "Number";
|
|
682
|
+
DistanceMetricsSubjects["IntArray"] = "IntArray";
|
|
683
|
+
DistanceMetricsSubjects["NumberArray"] = "NumberArray";
|
|
684
|
+
})(DistanceMetricsSubjects || (DistanceMetricsSubjects = {}));
|
|
685
|
+
var NumberMetricsNames;
|
|
686
|
+
(function (NumberMetricsNames) {
|
|
687
|
+
NumberMetricsNames["Difference"] = "Difference";
|
|
688
|
+
})(NumberMetricsNames || (NumberMetricsNames = {}));
|
|
689
|
+
var NumberArrayMetricsNames;
|
|
690
|
+
(function (NumberArrayMetricsNames) {
|
|
691
|
+
NumberArrayMetricsNames["CommonItems"] = "Common Items";
|
|
692
|
+
})(NumberArrayMetricsNames || (NumberArrayMetricsNames = {}));
|
|
693
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29uc3RzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGtCQUtUO0FBTEgsV0FBWSxrQkFBa0I7SUFDMUIsaURBQTJCLENBQUE7SUFDM0Isa0RBQTRCLENBQUE7SUFDNUIsb0RBQThCLENBQUE7SUFDOUIsd0NBQWtCLENBQUE7QUFDcEIsQ0FBQyxFQUxTLGtCQUFrQixLQUFsQixrQkFBa0IsUUFLM0I7QUFFSCxNQUFNLENBQU4sSUFBWSxrQkFJVDtBQUpILFdBQVksa0JBQWtCO0lBQzFCLDZDQUF1QixDQUFBO0lBQ3ZCLDZDQUF1QixDQUFBO0lBQ3ZCLDhDQUF3QixDQUFBO0FBQzFCLENBQUMsRUFKUyxrQkFBa0IsS0FBbEIsa0JBQWtCLFFBSTNCO0FBRUgsTUFBTSxDQUFOLElBQVksb0JBYVQ7QUFiSCxXQUFZLG9CQUFvQjtJQUM1Qiw2Q0FBcUIsQ0FBQTtJQUNyQixxQ0FBYSxDQUFBO0lBQ2IsaURBQXlCLENBQUE7SUFDekIsd0RBQWdDLENBQUE7SUFDaEMseUNBQWlCLENBQUE7SUFDakIsaURBQXlCLENBQUE7SUFDekIsc0RBQThCLENBQUE7SUFDOUIsd0RBQWdDLENBQUE7SUFDaEMseUNBQWlCLENBQUE7SUFDakIsdUNBQWUsQ0FBQTtJQUNmLDJDQUFtQixDQUFBO0lBQ25CLHdEQUFnQyxDQUFBO0FBQ2xDLENBQUMsRUFiUyxvQkFBb0IsS0FBcEIsb0JBQW9CLFFBYTdCO0FBRUgsTUFBTSxDQUFOLElBQVksb0JBRVg7QUFGRCxXQUFZLG9CQUFvQjtJQUM5Qiw2REFBcUMsQ0FBQTtBQUN2QyxDQUFDLEVBRlcsb0JBQW9CLEtBQXBCLG9CQUFvQixRQUUvQjtBQUVELE1BQU0sQ0FBTixJQUFZLHVCQVFUO0FBUkgsV0FBWSx1QkFBdUI7SUFDL0IsNENBQWlCLENBQUE7SUFDakIsNENBQWlCLENBQUE7SUFDakIsZ0RBQXFCLENBQUE7SUFDckIsMERBQStCLENBQUE7SUFDL0IsNENBQWlCLENBQUE7SUFDakIsZ0RBQXFCLENBQUE7SUFDckIsc0RBQTJCLENBQUE7QUFDN0IsQ0FBQyxFQVJTLHVCQUF1QixLQUF2Qix1QkFBdUIsUUFRaEM7QUFFSCxNQUFNLENBQU4sSUFBWSxrQkFFWDtBQUZELFdBQVksa0JBQWtCO0lBQzVCLCtDQUF5QixDQUFBO0FBQzNCLENBQUMsRUFGVyxrQkFBa0IsS0FBbEIsa0JBQWtCLFFBRTdCO0FBRUQsTUFBTSxDQUFOLElBQVksdUJBRVg7QUFGRCxXQUFZLHVCQUF1QjtJQUNqQyx1REFBNEIsQ0FBQTtBQUM5QixDQUFDLEVBRlcsdUJBQXVCLEtBQXZCLHVCQUF1QixRQUVsQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFN0cmluZ01ldHJpY3NOYW1lcyB7XG4gICAgTGV2ZW5zaHRlaW4gPSAnTGV2ZW5zaHRlaW4nLFxuICAgIEphcm9XaW5rbGVyID0gJ0phcm8tV2lua2xlcicsXG4gICAgTWFuaGF0dGFuID0gJ01hbmhhdHRhbiBTdHJpbmcnLFxuICAgIE9uZWhvdCA9ICdPbmUtSG90JyxcbiAgfVxuXG5leHBvcnQgZW51bSBWZWN0b3JNZXRyaWNzTmFtZXMge1xuICAgIEV1Y2xpZGVhbiA9ICdFdWNsaWRlYW4nLFxuICAgIE1hbmhhdHRhbiA9ICdNYW5oYXR0YW4nLFxuICAgIENvc2luZSA9ICdWZWN0b3IgQ29zaW5lJyxcbiAgfVxuXG5leHBvcnQgZW51bSBCaXRBcnJheU1ldHJpY3NOYW1lcyB7XG4gICAgVGFuaW1vdG8gPSAnVGFuaW1vdG8nLFxuICAgIERpY2UgPSAnRGljZScsXG4gICAgQXN5bW1ldHJpYyA9ICdBc3ltbWV0cmljJyxcbiAgICBCcmF1bkJsYW5xdWV0ID0gJ0JyYXVuLUJsYW5xdWV0JyxcbiAgICBDb3NpbmUgPSAnQ29zaW5lJyxcbiAgICBLdWxjenluc2tpID0gJ0t1bGN6eW5za2knLFxuICAgIE1jQ29ubmF1Z2hleSA9ICdNYy1Db25uYXVnaGV5JyxcbiAgICBSb2dvdEdvbGRiZXJnID0gJ1JvZ290LUdvbGRiZXJnJyxcbiAgICBSdXNzZWwgPSAnUnVzc2VsJyxcbiAgICBTb2thbCA9ICdTb2thbCcsXG4gICAgSGFtbWluZyA9ICdIYW1taW5nJyxcbiAgICBFdWNsaWRlYW4gPSAnRXVjbGlkZWFuIEJpdEFycmF5JyxcbiAgfVxuXG5leHBvcnQgZW51bSBJbnRBcnJheU1ldHJpY3NOYW1lcyB7XG4gIFRhbmltb3RvSW50QXJyYXkgPSAnVGFuaW1vdG9JbnRBcnJheScsXG59XG5cbmV4cG9ydCBlbnVtIERpc3RhbmNlTWV0cmljc1N1YmplY3RzIHtcbiAgICBWZWN0b3IgPSAnVmVjdG9yJyxcbiAgICBTdHJpbmcgPSAnU3RyaW5nJyxcbiAgICBCaXRBcnJheSA9ICdCaXRBcnJheScsXG4gICAgTWFjcm9Nb2xlY3VsZSA9ICdNYWNyb01vbGVjdWxlJyxcbiAgICBOdW1iZXIgPSAnTnVtYmVyJyxcbiAgICBJbnRBcnJheSA9ICdJbnRBcnJheScsXG4gICAgTnVtYmVyQXJyYXkgPSAnTnVtYmVyQXJyYXknLFxuICB9XG5cbmV4cG9ydCBlbnVtIE51bWJlck1ldHJpY3NOYW1lcyB7XG4gIERpZmZlcmVuY2UgPSAnRGlmZmVyZW5jZScsXG59XG5cbmV4cG9ydCBlbnVtIE51bWJlckFycmF5TWV0cmljc05hbWVzIHtcbiAgQ29tbW9uSXRlbXMgPSAnQ29tbW9uIEl0ZW1zJyxcbn1cbiJdfQ==
|
|
694
|
+
|
|
695
|
+
/***/ }),
|
|
696
|
+
|
|
697
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/typed-metrics/index.js":
|
|
698
|
+
/*!************************************************************************!*\
|
|
699
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/typed-metrics/index.js ***!
|
|
700
|
+
\************************************************************************/
|
|
701
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
702
|
+
|
|
703
|
+
__webpack_require__.r(__webpack_exports__);
|
|
704
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
705
|
+
/* harmony export */ AvailableMetrics: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.AvailableMetrics),
|
|
706
|
+
/* harmony export */ BitArrayMetricsNames: () => (/* reexport safe */ _consts__WEBPACK_IMPORTED_MODULE_0__.BitArrayMetricsNames),
|
|
707
|
+
/* harmony export */ DistanceMetricsSubjects: () => (/* reexport safe */ _consts__WEBPACK_IMPORTED_MODULE_0__.DistanceMetricsSubjects),
|
|
708
|
+
/* harmony export */ Measure: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.Measure),
|
|
709
|
+
/* harmony export */ MetricToDataType: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.MetricToDataType),
|
|
710
|
+
/* harmony export */ NumberArrayMetricsNames: () => (/* reexport safe */ _consts__WEBPACK_IMPORTED_MODULE_0__.NumberArrayMetricsNames),
|
|
711
|
+
/* harmony export */ NumberMetricsNames: () => (/* reexport safe */ _consts__WEBPACK_IMPORTED_MODULE_0__.NumberMetricsNames),
|
|
712
|
+
/* harmony export */ StringMetricsNames: () => (/* reexport safe */ _consts__WEBPACK_IMPORTED_MODULE_0__.StringMetricsNames),
|
|
713
|
+
/* harmony export */ VectorMetricsNames: () => (/* reexport safe */ _consts__WEBPACK_IMPORTED_MODULE_0__.VectorMetricsNames),
|
|
714
|
+
/* harmony export */ bitArrayDistanceMetricsMethods: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.bitArrayDistanceMetricsMethods),
|
|
715
|
+
/* harmony export */ isBitArrayMetric: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.isBitArrayMetric),
|
|
716
|
+
/* harmony export */ isMacroMoleculeMetric: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.isMacroMoleculeMetric),
|
|
717
|
+
/* harmony export */ isStringMetric: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.isStringMetric),
|
|
718
|
+
/* harmony export */ isVectorMetric: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.isVectorMetric),
|
|
719
|
+
/* harmony export */ manhattanDistance: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.manhattanDistance),
|
|
720
|
+
/* harmony export */ stringDistanceMetricsMethods: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.stringDistanceMetricsMethods),
|
|
721
|
+
/* harmony export */ vectorDistanceMetricsMethods: () => (/* reexport safe */ _typed_metrics__WEBPACK_IMPORTED_MODULE_1__.vectorDistanceMetricsMethods)
|
|
722
|
+
/* harmony export */ });
|
|
723
|
+
/* harmony import */ var _consts__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./consts */ "./node_modules/@datagrok-libraries/ml/src/typed-metrics/consts.js");
|
|
724
|
+
/* harmony import */ var _typed_metrics__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./typed-metrics */ "./node_modules/@datagrok-libraries/ml/src/typed-metrics/typed-metrics.js");
|
|
725
|
+
|
|
726
|
+
|
|
727
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsa0JBQWtCLEVBQ2xCLGtCQUFrQixFQUNsQixvQkFBb0IsRUFDcEIsdUJBQXVCLEVBQ3ZCLGtCQUFrQixFQUNsQix1QkFBdUIsRUFDeEIsTUFBTSxVQUFVLENBQUM7QUFFbEIsT0FBTyxFQU9MLGdCQUFnQixFQUNoQiw0QkFBNEIsRUFDNUIsNEJBQTRCLEVBQzVCLDhCQUE4QixFQUM5QixnQkFBZ0IsRUFDaEIsY0FBYyxFQUNkLGdCQUFnQixFQUNoQixjQUFjLEVBQ2QscUJBQXFCLEVBQ3JCLGlCQUFpQixFQUNqQixPQUFPLEVBQ1IsTUFBTSxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7XG4gIFN0cmluZ01ldHJpY3NOYW1lcyxcbiAgVmVjdG9yTWV0cmljc05hbWVzLFxuICBCaXRBcnJheU1ldHJpY3NOYW1lcyxcbiAgRGlzdGFuY2VNZXRyaWNzU3ViamVjdHMsXG4gIE51bWJlck1ldHJpY3NOYW1lcyxcbiAgTnVtYmVyQXJyYXlNZXRyaWNzTmFtZXNcbn0gZnJvbSAnLi9jb25zdHMnO1xuXG5leHBvcnQge1xuICBBdmFpbGFibGVEYXRhVHlwZXMsXG4gIEJpdEFycmF5TWV0cmljcyxcbiAgU3RyaW5nTWV0cmljcyxcbiAgVmVjdG9yTWV0cmljcyxcbiAgS25vd25NZXRyaWNzLFxuICBWYWxpZFR5cGVzLFxuICBBdmFpbGFibGVNZXRyaWNzLFxuICB2ZWN0b3JEaXN0YW5jZU1ldHJpY3NNZXRob2RzLFxuICBzdHJpbmdEaXN0YW5jZU1ldHJpY3NNZXRob2RzLFxuICBiaXRBcnJheURpc3RhbmNlTWV0cmljc01ldGhvZHMsXG4gIE1ldHJpY1RvRGF0YVR5cGUsXG4gIGlzU3RyaW5nTWV0cmljLFxuICBpc0JpdEFycmF5TWV0cmljLFxuICBpc1ZlY3Rvck1ldHJpYyxcbiAgaXNNYWNyb01vbGVjdWxlTWV0cmljLFxuICBtYW5oYXR0YW5EaXN0YW5jZSxcbiAgTWVhc3VyZVxufSBmcm9tICcuL3R5cGVkLW1ldHJpY3MnO1xuIl19
|
|
728
|
+
|
|
729
|
+
/***/ }),
|
|
730
|
+
|
|
731
|
+
/***/ "./node_modules/@datagrok-libraries/ml/src/typed-metrics/typed-metrics.js":
|
|
732
|
+
/*!********************************************************************************!*\
|
|
733
|
+
!*** ./node_modules/@datagrok-libraries/ml/src/typed-metrics/typed-metrics.js ***!
|
|
734
|
+
\********************************************************************************/
|
|
735
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
736
|
+
|
|
737
|
+
__webpack_require__.r(__webpack_exports__);
|
|
738
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
739
|
+
/* harmony export */ AvailableMetrics: () => (/* binding */ AvailableMetrics),
|
|
740
|
+
/* harmony export */ Measure: () => (/* binding */ Measure),
|
|
741
|
+
/* harmony export */ MetricToDataType: () => (/* binding */ MetricToDataType),
|
|
742
|
+
/* harmony export */ bitArrayDistanceMetricsMethods: () => (/* binding */ bitArrayDistanceMetricsMethods),
|
|
743
|
+
/* harmony export */ categoricalDistance: () => (/* binding */ categoricalDistance),
|
|
744
|
+
/* harmony export */ intArrayDistanceMetricsMethods: () => (/* binding */ intArrayDistanceMetricsMethods),
|
|
745
|
+
/* harmony export */ isBitArrayMetric: () => (/* binding */ isBitArrayMetric),
|
|
746
|
+
/* harmony export */ isMacroMoleculeMetric: () => (/* binding */ isMacroMoleculeMetric),
|
|
747
|
+
/* harmony export */ isNumberArrayMetric: () => (/* binding */ isNumberArrayMetric),
|
|
748
|
+
/* harmony export */ isNumericMetric: () => (/* binding */ isNumericMetric),
|
|
749
|
+
/* harmony export */ isStringMetric: () => (/* binding */ isStringMetric),
|
|
750
|
+
/* harmony export */ isVectorMetric: () => (/* binding */ isVectorMetric),
|
|
751
|
+
/* harmony export */ manhattanDistance: () => (/* binding */ manhattanDistance),
|
|
752
|
+
/* harmony export */ numberArrayDistanceMetrics: () => (/* binding */ numberArrayDistanceMetrics),
|
|
753
|
+
/* harmony export */ numberDistanceMetricsMethods: () => (/* binding */ numberDistanceMetricsMethods),
|
|
754
|
+
/* harmony export */ stringDistanceMetricsMethods: () => (/* binding */ stringDistanceMetricsMethods),
|
|
755
|
+
/* harmony export */ vectorDistanceMetricsMethods: () => (/* binding */ vectorDistanceMetricsMethods)
|
|
756
|
+
/* harmony export */ });
|
|
757
|
+
/* harmony import */ var fastest_levenshtein__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! fastest-levenshtein */ "./node_modules/fastest-levenshtein/esm/mod.js");
|
|
758
|
+
/* harmony import */ var jaro_winkler_typescript__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! jaro-winkler-typescript */ "./node_modules/jaro-winkler-typescript/lib/index.js");
|
|
759
|
+
/* harmony import */ var _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../distance-metrics-methods */ "./node_modules/@datagrok-libraries/ml/src/distance-metrics-methods.js");
|
|
760
|
+
/* harmony import */ var _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../macromolecule-distance-functions */ "./node_modules/@datagrok-libraries/ml/src/macromolecule-distance-functions/index.js");
|
|
761
|
+
/* harmony import */ var _consts__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./consts */ "./node_modules/@datagrok-libraries/ml/src/typed-metrics/consts.js");
|
|
762
|
+
|
|
763
|
+
|
|
764
|
+
|
|
765
|
+
|
|
766
|
+
|
|
767
|
+
const vectorDistanceMetricsMethods = {
|
|
768
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Euclidean]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.vectorEuclideanDistance,
|
|
769
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Manhattan]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.vectorManhattenDistance,
|
|
770
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Cosine]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.vectorCosineDistance,
|
|
771
|
+
};
|
|
772
|
+
const stringDistanceMetricsMethods = {
|
|
773
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Levenshtein]: fastest_levenshtein__WEBPACK_IMPORTED_MODULE_0__.distance,
|
|
774
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.JaroWinkler]: jaro_winkler_typescript__WEBPACK_IMPORTED_MODULE_1__.jaroWinkler,
|
|
775
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Manhattan]: manhattanDistance,
|
|
776
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Onehot]: categoricalDistance,
|
|
777
|
+
};
|
|
778
|
+
const bitArrayDistanceMetricsMethods = {
|
|
779
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Tanimoto]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.tanimotoDistance,
|
|
780
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Dice]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.diceDistance,
|
|
781
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Asymmetric]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.asymmetricDistance,
|
|
782
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.BraunBlanquet]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.braunBlanquetDistance,
|
|
783
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Cosine]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.cosineDistance,
|
|
784
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Kulczynski]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.kulczynskiDistance,
|
|
785
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.McConnaughey]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.mcConnaugheyDistance,
|
|
786
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.RogotGoldberg]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.rogotGoldbergDistance,
|
|
787
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Russel]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.russelDistance,
|
|
788
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Sokal]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.sokalDistance,
|
|
789
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Hamming]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.hammingDistance,
|
|
790
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Euclidean]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.euclideanDistanceBitArray,
|
|
791
|
+
};
|
|
792
|
+
const intArrayDistanceMetricsMethods = {
|
|
793
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.IntArrayMetricsNames.TanimotoIntArray]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.tanimotoDistanceIntArray,
|
|
794
|
+
};
|
|
795
|
+
const numberDistanceMetricsMethods = {
|
|
796
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.NumberMetricsNames.Difference]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.numericDistance,
|
|
797
|
+
};
|
|
798
|
+
const numberArrayDistanceMetrics = {
|
|
799
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.NumberArrayMetricsNames.CommonItems]: _distance_metrics_methods__WEBPACK_IMPORTED_MODULE_2__.inverseCommonItemsCount,
|
|
800
|
+
};
|
|
801
|
+
const AvailableMetrics = {
|
|
802
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.Vector]: {
|
|
803
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Euclidean]: vectorDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Euclidean],
|
|
804
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Manhattan]: vectorDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Manhattan],
|
|
805
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Cosine]: vectorDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.VectorMetricsNames.Cosine],
|
|
806
|
+
},
|
|
807
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.String]: {
|
|
808
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Levenshtein]: stringDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Levenshtein],
|
|
809
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.JaroWinkler]: stringDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.JaroWinkler],
|
|
810
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Manhattan]: stringDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Manhattan],
|
|
811
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Onehot]: stringDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.StringMetricsNames.Onehot],
|
|
812
|
+
},
|
|
813
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.BitArray]: {
|
|
814
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Tanimoto]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Tanimoto],
|
|
815
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Dice]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Dice],
|
|
816
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Asymmetric]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Asymmetric],
|
|
817
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.BraunBlanquet]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.BraunBlanquet],
|
|
818
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Cosine]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Cosine],
|
|
819
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Kulczynski]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Kulczynski],
|
|
820
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.McConnaughey]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.McConnaughey],
|
|
821
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.RogotGoldberg]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.RogotGoldberg],
|
|
822
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Russel]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Russel],
|
|
823
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Sokal]: bitArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.BitArrayMetricsNames.Sokal],
|
|
824
|
+
},
|
|
825
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.MacroMolecule]: {
|
|
826
|
+
[_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.MmDistanceFunctionsNames.HAMMING]: _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.mmDistanceFunctions[_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.MmDistanceFunctionsNames.HAMMING],
|
|
827
|
+
[_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.MmDistanceFunctionsNames.LEVENSHTEIN]: _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.mmDistanceFunctions[_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.MmDistanceFunctionsNames.LEVENSHTEIN],
|
|
828
|
+
[_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.MmDistanceFunctionsNames.NEEDLEMANN_WUNSCH]: _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.mmDistanceFunctions[_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.MmDistanceFunctionsNames.NEEDLEMANN_WUNSCH],
|
|
829
|
+
[_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.MmDistanceFunctionsNames.MONOMER_CHEMICAL_DISTANCE]: _macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.mmDistanceFunctions[_macromolecule_distance_functions__WEBPACK_IMPORTED_MODULE_3__.MmDistanceFunctionsNames.MONOMER_CHEMICAL_DISTANCE],
|
|
830
|
+
},
|
|
831
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.Number]: {
|
|
832
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.NumberMetricsNames.Difference]: numberDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.NumberMetricsNames.Difference],
|
|
833
|
+
},
|
|
834
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.IntArray]: {
|
|
835
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.IntArrayMetricsNames.TanimotoIntArray]: intArrayDistanceMetricsMethods[_consts__WEBPACK_IMPORTED_MODULE_4__.IntArrayMetricsNames.TanimotoIntArray],
|
|
836
|
+
},
|
|
837
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.NumberArray]: {
|
|
838
|
+
[_consts__WEBPACK_IMPORTED_MODULE_4__.NumberArrayMetricsNames.CommonItems]: numberArrayDistanceMetrics[_consts__WEBPACK_IMPORTED_MODULE_4__.NumberArrayMetricsNames.CommonItems],
|
|
839
|
+
},
|
|
840
|
+
};
|
|
841
|
+
const MetricToDataType = Object.keys(AvailableMetrics)
|
|
842
|
+
.reduce((ret, key) => {
|
|
843
|
+
for (const val of Object.keys(AvailableMetrics[key]))
|
|
844
|
+
ret[val] = key;
|
|
845
|
+
return ret;
|
|
846
|
+
}, {});
|
|
847
|
+
function isStringMetric(name) {
|
|
848
|
+
return MetricToDataType[name] == 'String';
|
|
849
|
+
}
|
|
850
|
+
function isBitArrayMetric(name) {
|
|
851
|
+
return MetricToDataType[name] == 'BitArray';
|
|
852
|
+
}
|
|
853
|
+
function isVectorMetric(name) {
|
|
854
|
+
return MetricToDataType[name] == 'Vector';
|
|
855
|
+
}
|
|
856
|
+
function isMacroMoleculeMetric(name) {
|
|
857
|
+
return MetricToDataType[name] == _consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.MacroMolecule.toString();
|
|
858
|
+
}
|
|
859
|
+
function isNumericMetric(name) {
|
|
860
|
+
return MetricToDataType[name] == _consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.Number.toString();
|
|
861
|
+
}
|
|
862
|
+
function isNumberArrayMetric(name) {
|
|
863
|
+
return MetricToDataType[name] == _consts__WEBPACK_IMPORTED_MODULE_4__.DistanceMetricsSubjects.NumberArray.toString();
|
|
864
|
+
}
|
|
865
|
+
/** Manhattan distance between two sequences (match - 0, mismatch - 1) normalized for length. */
|
|
866
|
+
function manhattanDistance(s1, s2) {
|
|
867
|
+
if (s1.length !== s2.length) {
|
|
868
|
+
return 1;
|
|
869
|
+
}
|
|
870
|
+
else {
|
|
871
|
+
let dist = 0;
|
|
872
|
+
for (let i = 1; i < s1.length; i++)
|
|
873
|
+
dist += s1[i] == s2[i] ? 0 : 1;
|
|
874
|
+
return dist / s1.length;
|
|
875
|
+
}
|
|
876
|
+
}
|
|
877
|
+
function categoricalDistance(s1, s2) {
|
|
878
|
+
return s1 === s2 ? 0 : 1;
|
|
879
|
+
}
|
|
880
|
+
/** Unified class implementing different string measures. */
|
|
881
|
+
class Measure {
|
|
882
|
+
/**
|
|
883
|
+
* Creates an instance of Measure with .
|
|
884
|
+
* @param {string} method Method to calculate distance between strings.
|
|
885
|
+
* @memberof Measurer
|
|
886
|
+
*/
|
|
887
|
+
constructor(method) {
|
|
888
|
+
this.method = method;
|
|
889
|
+
this.dataType = MetricToDataType[method];
|
|
890
|
+
}
|
|
891
|
+
/**
|
|
892
|
+
* Returns true if the metric needs arguments to be calculated.
|
|
893
|
+
* @param {KnownMetrics} method Metric to check if it needs arguments.
|
|
894
|
+
* @return {boolean} True if the metric needs arguments.
|
|
895
|
+
* @memberof Measure
|
|
896
|
+
*/
|
|
897
|
+
metricNeedsArgs(method) {
|
|
898
|
+
return isMacroMoleculeMetric(method) || isNumericMetric(method) || isNumberArrayMetric(method);
|
|
899
|
+
}
|
|
900
|
+
/**
|
|
901
|
+
* Returns custom string distance function specified.
|
|
902
|
+
* @param {opts} opts Options for the measure. used for macromolecule distances
|
|
903
|
+
* @return {DistanceMetric} Callback of the measure chosen.
|
|
904
|
+
* @memberof Measurer
|
|
905
|
+
*/
|
|
906
|
+
getMeasure(opts) {
|
|
907
|
+
const dict = AvailableMetrics;
|
|
908
|
+
if (!dict.hasOwnProperty(this.dataType) || !dict[this.dataType].hasOwnProperty(this.method))
|
|
909
|
+
throw new Error(`Unknown measure ${this.method} for data type ${this.dataType}`);
|
|
910
|
+
return this.metricNeedsArgs(this.method) ?
|
|
911
|
+
dict[this.dataType][this.method](opts) :
|
|
912
|
+
dict[this.dataType][this.method];
|
|
913
|
+
}
|
|
914
|
+
/**
|
|
915
|
+
* Returns custom string distance by the given data type.
|
|
916
|
+
* @param {AvailableDataTypes} dataType Metric's data type
|
|
917
|
+
* @return {string[]} Metric names which expects the given data type
|
|
918
|
+
* @memberof Measurer
|
|
919
|
+
*/
|
|
920
|
+
static getMetricByDataType(dataType) {
|
|
921
|
+
return Object.keys(AvailableMetrics[dataType]);
|
|
922
|
+
}
|
|
923
|
+
/** Returns metric names available.
|
|
924
|
+
* @memberof Measurer
|
|
925
|
+
*/
|
|
926
|
+
static get availableMeasures() {
|
|
927
|
+
return Object.keys(AvailableMetrics);
|
|
928
|
+
}
|
|
929
|
+
}
|
|
930
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typed-metrics.js","sourceRoot":"","sources":["typed-metrics.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fl from 'fastest-levenshtein';\nimport {jaroWinkler} from 'jaro-winkler-typescript';\nimport {DistanceMetric} from '@datagrok-libraries/utils/src/type-declarations';\nimport {\n  asymmetricDistance,\n  braunBlanquetDistance,\n  cosineDistance,\n  diceDistance,\n  euclideanDistanceBitArray,\n  hammingDistance,\n  kulczynskiDistance,\n  mcConnaugheyDistance,\n  rogotGoldbergDistance,\n  russelDistance,\n  sokalDistance,\n  tanimotoDistance,\n  numericDistance,\n  tanimotoDistanceIntArray,\n  inverseCommonItemsCount,\n  vectorEuclideanDistance,\n  vectorManhattenDistance,\n  vectorCosineDistance,\n} from '../distance-metrics-methods';\n\nimport BitArray from '@datagrok-libraries/utils/src/bit-array';\nimport {Vector, StringDictionary} from '@datagrok-libraries/utils/src/type-declarations';\nimport {mmDistanceFunctions, MmDistanceFunctionsNames} from '../macromolecule-distance-functions';\nimport {DistanceMetricsSubjects, BitArrayMetricsNames,\n  StringMetricsNames, VectorMetricsNames, NumberMetricsNames, IntArrayMetricsNames,\n  NumberArrayMetricsNames} from './consts';\n\n\nexport const vectorDistanceMetricsMethods: { [name: string]: (x: Vector, y: Vector) => number } = {\n  [VectorMetricsNames.Euclidean]: vectorEuclideanDistance,\n  [VectorMetricsNames.Manhattan]: vectorManhattenDistance,\n  [VectorMetricsNames.Cosine]: vectorCosineDistance,\n};\n\nexport const stringDistanceMetricsMethods: { [name: string]: (x: string, y: string) => number } = {\n  [StringMetricsNames.Levenshtein]: fl.distance,\n  [StringMetricsNames.JaroWinkler]: jaroWinkler,\n  [StringMetricsNames.Manhattan]: manhattanDistance,\n  [StringMetricsNames.Onehot]: categoricalDistance,\n};\n\nexport const bitArrayDistanceMetricsMethods: { [name: string]: (x: BitArray, y: BitArray) => number } = {\n  [BitArrayMetricsNames.Tanimoto]: tanimotoDistance,\n  [BitArrayMetricsNames.Dice]: diceDistance,\n  [BitArrayMetricsNames.Asymmetric]: asymmetricDistance,\n  [BitArrayMetricsNames.BraunBlanquet]: braunBlanquetDistance,\n  [BitArrayMetricsNames.Cosine]: cosineDistance,\n  [BitArrayMetricsNames.Kulczynski]: kulczynskiDistance,\n  [BitArrayMetricsNames.McConnaughey]: mcConnaugheyDistance,\n  [BitArrayMetricsNames.RogotGoldberg]: rogotGoldbergDistance,\n  [BitArrayMetricsNames.Russel]: russelDistance,\n  [BitArrayMetricsNames.Sokal]: sokalDistance,\n  [BitArrayMetricsNames.Hamming]: hammingDistance,\n  [BitArrayMetricsNames.Euclidean]: euclideanDistanceBitArray,\n};\n\nexport const intArrayDistanceMetricsMethods: { [name: string]: (x: Uint32Array, y: Uint32Array) => number } = {\n  [IntArrayMetricsNames.TanimotoIntArray]: tanimotoDistanceIntArray,\n};\n\nexport const numberDistanceMetricsMethods: { [name: string]: (args: any) => (x: number, y: number) => number } = {\n  [NumberMetricsNames.Difference]: numericDistance,\n};\n\nexport const numberArrayDistanceMetrics:\n{ [name: string]: (args: any) => (x: ArrayLike<number>, y: ArrayLike<number>) => number } = {\n  [NumberArrayMetricsNames.CommonItems]: inverseCommonItemsCount,\n};\n\nexport const AvailableMetrics = {\n  [DistanceMetricsSubjects.Vector]: {\n    [VectorMetricsNames.Euclidean]: vectorDistanceMetricsMethods[VectorMetricsNames.Euclidean],\n    [VectorMetricsNames.Manhattan]: vectorDistanceMetricsMethods[VectorMetricsNames.Manhattan],\n    [VectorMetricsNames.Cosine]: vectorDistanceMetricsMethods[VectorMetricsNames.Cosine],\n  },\n  [DistanceMetricsSubjects.String]: {\n    [StringMetricsNames.Levenshtein]: stringDistanceMetricsMethods[StringMetricsNames.Levenshtein],\n    [StringMetricsNames.JaroWinkler]: stringDistanceMetricsMethods[StringMetricsNames.JaroWinkler],\n    [StringMetricsNames.Manhattan]: stringDistanceMetricsMethods[StringMetricsNames.Manhattan],\n    [StringMetricsNames.Onehot]: stringDistanceMetricsMethods[StringMetricsNames.Onehot],\n  },\n  [DistanceMetricsSubjects.BitArray]: {\n    [BitArrayMetricsNames.Tanimoto]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.Tanimoto],\n    [BitArrayMetricsNames.Dice]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.Dice],\n    [BitArrayMetricsNames.Asymmetric]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.Asymmetric],\n    [BitArrayMetricsNames.BraunBlanquet]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.BraunBlanquet],\n    [BitArrayMetricsNames.Cosine]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.Cosine],\n    [BitArrayMetricsNames.Kulczynski]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.Kulczynski],\n    [BitArrayMetricsNames.McConnaughey]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.McConnaughey],\n    [BitArrayMetricsNames.RogotGoldberg]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.RogotGoldberg],\n    [BitArrayMetricsNames.Russel]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.Russel],\n    [BitArrayMetricsNames.Sokal]: bitArrayDistanceMetricsMethods[BitArrayMetricsNames.Sokal],\n  },\n  [DistanceMetricsSubjects.MacroMolecule]: { // optional args needed for macromolecule functions which initialize them\n    [MmDistanceFunctionsNames.HAMMING]: mmDistanceFunctions[MmDistanceFunctionsNames.HAMMING],\n    [MmDistanceFunctionsNames.LEVENSHTEIN]: mmDistanceFunctions[MmDistanceFunctionsNames.LEVENSHTEIN],\n    [MmDistanceFunctionsNames.NEEDLEMANN_WUNSCH]: mmDistanceFunctions[MmDistanceFunctionsNames.NEEDLEMANN_WUNSCH],\n    [MmDistanceFunctionsNames.MONOMER_CHEMICAL_DISTANCE]:\n      mmDistanceFunctions[MmDistanceFunctionsNames.MONOMER_CHEMICAL_DISTANCE],\n  },\n  [DistanceMetricsSubjects.Number]: {\n    [NumberMetricsNames.Difference]: numberDistanceMetricsMethods[NumberMetricsNames.Difference],\n  },\n  [DistanceMetricsSubjects.IntArray]: {\n    [IntArrayMetricsNames.TanimotoIntArray]: intArrayDistanceMetricsMethods[IntArrayMetricsNames.TanimotoIntArray],\n  },\n  [DistanceMetricsSubjects.NumberArray]: {\n    [NumberArrayMetricsNames.CommonItems]: numberArrayDistanceMetrics[NumberArrayMetricsNames.CommonItems],\n  },\n};\n\nexport const MetricToDataType: StringDictionary = Object.keys(AvailableMetrics)\n  .reduce((ret: StringDictionary, key) => {\n    for (const val of Object.keys(AvailableMetrics[key as AvailableDataTypes]))\n      ret[val as AvailableDataTypes] = key;\n\n    return ret;\n  }, {});\n\nexport type AvailableDataTypes = keyof typeof AvailableMetrics;\nexport type VectorMetrics = keyof typeof AvailableMetrics[DistanceMetricsSubjects.Vector];\nexport type StringMetrics = keyof typeof AvailableMetrics[DistanceMetricsSubjects.String];\nexport type BitArrayMetrics = keyof typeof AvailableMetrics[DistanceMetricsSubjects.BitArray];\nexport type NumberMetrics = keyof typeof AvailableMetrics[DistanceMetricsSubjects.Number];\nexport type IntArrayMetrics = keyof typeof AvailableMetrics[DistanceMetricsSubjects.IntArray];\nexport type NumberArrayMetrics = keyof typeof AvailableMetrics[DistanceMetricsSubjects.NumberArray];\nexport type KnownMetrics = StringMetrics | BitArrayMetrics | VectorMetrics |\n  MmDistanceFunctionsNames | NumberMetricsNames | IntArrayMetricsNames | NumberArrayMetricsNames;\n\nexport type ValidTypes =\n  { data: string[], metric: StringMetrics | MmDistanceFunctionsNames } |\n  { data: Vector[], metric: VectorMetrics } |\n  { data: BitArray[], metric: BitArrayMetrics } |\n  { data: number[], metric: NumberMetricsNames };\n\nexport function isStringMetric(name: KnownMetrics) {\n  return MetricToDataType[name] == 'String';\n}\n\nexport function isBitArrayMetric(name: KnownMetrics) {\n  return MetricToDataType[name] == 'BitArray';\n}\n\nexport function isVectorMetric(name: KnownMetrics) {\n  return MetricToDataType[name] == 'Vector';\n}\n\nexport function isMacroMoleculeMetric(name: KnownMetrics) {\n  return MetricToDataType[name] == DistanceMetricsSubjects.MacroMolecule.toString();\n}\n\nexport function isNumericMetric(name: KnownMetrics) {\n  return MetricToDataType[name] == DistanceMetricsSubjects.Number.toString();\n}\n\nexport function isNumberArrayMetric(name: KnownMetrics) {\n  return MetricToDataType[name] == DistanceMetricsSubjects.NumberArray.toString();\n}\n\n/** Manhattan distance between two sequences (match - 0, mismatch - 1) normalized for length. */\nexport function manhattanDistance(s1: string, s2: string): number {\n  if (s1.length !== s2.length) {\n    return 1;\n  } else {\n    let dist: number = 0;\n    for (let i = 1; i < s1.length; i++)\n      dist += s1[i] == s2[i] ? 0 : 1;\n    return dist / s1.length;\n  }\n}\n\nexport function categoricalDistance(s1: string, s2: string): number {\n  return s1 === s2 ? 0 : 1;\n}\n\n/** Unified class implementing different string measures. */\nexport class Measure {\n  protected method: KnownMetrics;\n  protected dataType: AvailableDataTypes;\n\n  /**\n   * Creates an instance of Measure with .\n   * @param {string} method Method to calculate distance between strings.\n   * @memberof Measurer\n   */\n  constructor(method: KnownMetrics) {\n    this.method = method;\n    this.dataType = MetricToDataType[method] as AvailableDataTypes;\n  }\n\n  /**\n   * Returns true if the metric needs arguments to be calculated.\n   * @param {KnownMetrics} method Metric to check if it needs arguments.\n   * @return {boolean} True if the metric needs arguments.\n   * @memberof Measure\n   */\n  public metricNeedsArgs(method: KnownMetrics): boolean {\n    return isMacroMoleculeMetric(method) || isNumericMetric(method) || isNumberArrayMetric(method);\n  }\n  /**\n   * Returns custom string distance function specified.\n   * @param {opts} opts Options for the measure. used for macromolecule distances\n   * @return {DistanceMetric} Callback of the measure chosen.\n   * @memberof Measurer\n   */\n  public getMeasure(opts?: any): DistanceMetric {\n    const dict: { [key: string]:\n      {[key2: string]: DistanceMetric | ((opts: any) => DistanceMetric)}\n    } = AvailableMetrics;\n    if (!dict.hasOwnProperty(this.dataType) || !dict[this.dataType].hasOwnProperty(this.method))\n      throw new Error(`Unknown measure ${this.method} for data type ${this.dataType}`);\n    return this.metricNeedsArgs(this.method) ?\n      (dict[this.dataType][this.method] as ((opts: any) => DistanceMetric))(opts) :\n      dict[this.dataType][this.method] as DistanceMetric;\n  }\n\n  /**\n   * Returns custom string distance by the given data type.\n   * @param {AvailableDataTypes} dataType Metric's data type\n   * @return {string[]} Metric names which expects the given data type\n   * @memberof Measurer\n   */\n  public static getMetricByDataType(dataType: AvailableDataTypes): string[] {\n    return Object.keys(AvailableMetrics[dataType]);\n  }\n\n  /** Returns metric names available.\n   * @memberof Measurer\n   */\n  static get availableMeasures(): string[] {\n    return Object.keys(AvailableMetrics);\n  }\n}\n"]}
|
|
931
|
+
|
|
932
|
+
/***/ }),
|
|
933
|
+
|
|
934
|
+
/***/ "./node_modules/@datagrok-libraries/utils/src/bit-array.js":
|
|
935
|
+
/*!*****************************************************************!*\
|
|
936
|
+
!*** ./node_modules/@datagrok-libraries/utils/src/bit-array.js ***!
|
|
937
|
+
\*****************************************************************/
|
|
938
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
939
|
+
|
|
940
|
+
__webpack_require__.r(__webpack_exports__);
|
|
941
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
942
|
+
/* harmony export */ "default": () => (/* binding */ BitArray)
|
|
943
|
+
/* harmony export */ });
|
|
944
|
+
class BitArray {
|
|
945
|
+
constructor(arg, defaultValue = false) {
|
|
946
|
+
this._length = 0;
|
|
947
|
+
this._version = 0;
|
|
948
|
+
this._updateLevel = 0;
|
|
949
|
+
this._selectedCount = 0;
|
|
950
|
+
this._selectedCountVersion = -1;
|
|
951
|
+
this._selectedIndexesVersion = -1;
|
|
952
|
+
this._versionedName = '';
|
|
953
|
+
this._versionedNameVersion = -1;
|
|
954
|
+
this.SHRINK_THRESHOLD = 0x100;
|
|
955
|
+
if (typeof arg === 'number') {
|
|
956
|
+
const length = arg;
|
|
957
|
+
const buff = BitArray._createBuffer(length);
|
|
958
|
+
if (defaultValue) {
|
|
959
|
+
for (let i = 0; i < buff.length; i++)
|
|
960
|
+
buff[i] = -1;
|
|
961
|
+
}
|
|
962
|
+
this._data = buff;
|
|
963
|
+
this._length = length;
|
|
964
|
+
}
|
|
965
|
+
else if (arg instanceof Uint32Array) {
|
|
966
|
+
this._data = arg;
|
|
967
|
+
this._length = defaultValue;
|
|
968
|
+
}
|
|
969
|
+
else {
|
|
970
|
+
throw new Error('Invalid constructor');
|
|
971
|
+
}
|
|
972
|
+
}
|
|
973
|
+
getRawData() { return this._data; }
|
|
974
|
+
assureGoez(num, argName) {
|
|
975
|
+
if (num < 0)
|
|
976
|
+
throw new Error(`${argName} should be greater than zero`);
|
|
977
|
+
}
|
|
978
|
+
assureInRange(value, min, max, argName) {
|
|
979
|
+
if ((value < min) || (value > max))
|
|
980
|
+
throw new Error(`Argument ${argName} (${value}) out of range (${min}, ${max})`);
|
|
981
|
+
}
|
|
982
|
+
copy(src, dst, count) {
|
|
983
|
+
for (let i = 0; i < count; i++)
|
|
984
|
+
dst[i] = src[i];
|
|
985
|
+
}
|
|
986
|
+
copyFrom(other) {
|
|
987
|
+
if (this._length != other._length)
|
|
988
|
+
throw new Error(`Lengths differ (${this._length} != ${other._length})`);
|
|
989
|
+
this.copy(other._data, this._data, this.lengthInInts);
|
|
990
|
+
this._version++;
|
|
991
|
+
}
|
|
992
|
+
get length() {
|
|
993
|
+
return this._length;
|
|
994
|
+
}
|
|
995
|
+
get buffer() {
|
|
996
|
+
return this._data;
|
|
997
|
+
}
|
|
998
|
+
set buffer(data) {
|
|
999
|
+
this._data = data;
|
|
1000
|
+
this._version++;
|
|
1001
|
+
}
|
|
1002
|
+
get version() {
|
|
1003
|
+
return this._version;
|
|
1004
|
+
}
|
|
1005
|
+
set version(value) {
|
|
1006
|
+
this._version = value;
|
|
1007
|
+
}
|
|
1008
|
+
incrementVersion(notify = true) {
|
|
1009
|
+
this._version++;
|
|
1010
|
+
}
|
|
1011
|
+
get lengthInInts() {
|
|
1012
|
+
return Math.floor((this._length + 0x1f) / 0x20);
|
|
1013
|
+
}
|
|
1014
|
+
get versionedName() {
|
|
1015
|
+
return this._version == this._versionedNameVersion ? this._versionedName : '';
|
|
1016
|
+
}
|
|
1017
|
+
set versionedName(name) {
|
|
1018
|
+
this._versionedName = name;
|
|
1019
|
+
this._versionedNameVersion = this._version;
|
|
1020
|
+
}
|
|
1021
|
+
get self() {
|
|
1022
|
+
return this;
|
|
1023
|
+
}
|
|
1024
|
+
setLength(value) {
|
|
1025
|
+
if (value < 0)
|
|
1026
|
+
throw new Error('should be >= 0');
|
|
1027
|
+
if (value == this._length)
|
|
1028
|
+
return;
|
|
1029
|
+
const nIntsNeeded = Math.floor((value + 0x1f) / 0x20);
|
|
1030
|
+
if ((nIntsNeeded > this._data.length) || ((nIntsNeeded + this.SHRINK_THRESHOLD) < this._data.length)) {
|
|
1031
|
+
const newData = new Uint32Array(nIntsNeeded);
|
|
1032
|
+
this.copy(this._data, newData, (nIntsNeeded > this._data.length) ? this._data.length : nIntsNeeded);
|
|
1033
|
+
this._data = newData;
|
|
1034
|
+
}
|
|
1035
|
+
if (value > this._length) {
|
|
1036
|
+
if (this._length % 0x20 > 0)
|
|
1037
|
+
this._data[this.lengthInInts - 1] &= (1 << ((this._length % 0x20) & 0x1f)) - 1;
|
|
1038
|
+
this._data.fill(0, this.lengthInInts, nIntsNeeded);
|
|
1039
|
+
}
|
|
1040
|
+
this._length = value;
|
|
1041
|
+
this._version++;
|
|
1042
|
+
}
|
|
1043
|
+
static fromAnd(set1, set2) {
|
|
1044
|
+
if (set1._length != set2._length)
|
|
1045
|
+
throw new Error(`Lengths differ (${set1._length} != ${set2._length})`);
|
|
1046
|
+
const temp = new BitArray(set1._length);
|
|
1047
|
+
temp._length = set1._length;
|
|
1048
|
+
temp._data = BitArray._createBuffer(temp._length);
|
|
1049
|
+
temp._version = 0;
|
|
1050
|
+
const len = set1.lengthInInts;
|
|
1051
|
+
for (let i = 0; i < len; i++)
|
|
1052
|
+
temp._data[i] = set1._data[i] & set2._data[i];
|
|
1053
|
+
return temp;
|
|
1054
|
+
}
|
|
1055
|
+
static _createBuffer(length) {
|
|
1056
|
+
return new Uint32Array(Math.floor((length + 0x1f) / 0x20));
|
|
1057
|
+
}
|
|
1058
|
+
static fromValues(values) {
|
|
1059
|
+
const temp = new BitArray(values.length);
|
|
1060
|
+
temp._version = 0;
|
|
1061
|
+
for (let i = 0; i < temp._length; i++) {
|
|
1062
|
+
if (values[i])
|
|
1063
|
+
temp._data[Math.floor(i / 0x20)] |= 1 << ((i % 0x20) & 0x1f);
|
|
1064
|
+
}
|
|
1065
|
+
return temp;
|
|
1066
|
+
}
|
|
1067
|
+
/// Constructs a [BitSet] of length [count], where idx-th bit is determined by a call to [flag] (idx).
|
|
1068
|
+
static fromSeq(count, flag) {
|
|
1069
|
+
const temp = new BitArray(count);
|
|
1070
|
+
for (let i = 0; i < count; ++i)
|
|
1071
|
+
temp.setBit(i, flag(i));
|
|
1072
|
+
temp._version = 0;
|
|
1073
|
+
return temp;
|
|
1074
|
+
}
|
|
1075
|
+
/// Constructs a [BitSet] from a string [s] containing '0' or '1'.
|
|
1076
|
+
static fromString(s) {
|
|
1077
|
+
return BitArray.fromSeq(s.length, (i) => s.charAt(i) == '1');
|
|
1078
|
+
}
|
|
1079
|
+
/// Constructs a [BitSet], based on length [_length] and byte array [_data].
|
|
1080
|
+
static fromUint32Array(_length, _data) {
|
|
1081
|
+
const temp = new BitArray(_length);
|
|
1082
|
+
temp._data = _data;
|
|
1083
|
+
return temp;
|
|
1084
|
+
}
|
|
1085
|
+
/// Deserializes a [BitSet] from [bytes].
|
|
1086
|
+
static fromBytes(bytes) {
|
|
1087
|
+
const len = bytes.length;
|
|
1088
|
+
const temp = new BitArray(len * 8);
|
|
1089
|
+
temp._data = new Uint32Array(Math.floor((len + 3) / 4));
|
|
1090
|
+
temp._length = len * 8;
|
|
1091
|
+
let num1 = 0;
|
|
1092
|
+
let num2 = 0;
|
|
1093
|
+
while ((len - num2) >= 4) {
|
|
1094
|
+
temp._data[num1++] = (((bytes[num2] & 0xff) | ((bytes[num2 + 1] & 0xff) << 8)) |
|
|
1095
|
+
((bytes[num2 + 2] & 0xff) << 0x10)) | ((bytes[num2 + 3] & 0xff) << 0x18);
|
|
1096
|
+
num2 += 4;
|
|
1097
|
+
}
|
|
1098
|
+
if (len - num2 == 3)
|
|
1099
|
+
temp._data[num1] = (bytes[num2 + 2] & 0xff) << 0x10;
|
|
1100
|
+
if (len - num2 == 2)
|
|
1101
|
+
temp._data[num1] |= (bytes[num2 + 1] & 0xff) << 8;
|
|
1102
|
+
if (len - num2 == 1)
|
|
1103
|
+
temp._data[num1] |= bytes[num2] & 0xff;
|
|
1104
|
+
temp._version = 0;
|
|
1105
|
+
return temp;
|
|
1106
|
+
}
|
|
1107
|
+
toString() {
|
|
1108
|
+
return `${this._length} bits, ${this.countBits(true)} set`;
|
|
1109
|
+
}
|
|
1110
|
+
/// Performs deep comparison of two bitsets.
|
|
1111
|
+
equals(other) {
|
|
1112
|
+
if (this == other)
|
|
1113
|
+
return true;
|
|
1114
|
+
if (other == null)
|
|
1115
|
+
return false;
|
|
1116
|
+
if (this._length != other._length)
|
|
1117
|
+
return false;
|
|
1118
|
+
if (this._length == 0)
|
|
1119
|
+
return true;
|
|
1120
|
+
for (let i = 0; i < this._data.length - 1; i++)
|
|
1121
|
+
if (this._data[i] != other._data[i])
|
|
1122
|
+
return false;
|
|
1123
|
+
for (let i = (this._data.length - 1) * 8; i < this._length; i++) {
|
|
1124
|
+
if (this.getBit(i) != other.getBit(i))
|
|
1125
|
+
return false;
|
|
1126
|
+
}
|
|
1127
|
+
return true;
|
|
1128
|
+
}
|
|
1129
|
+
/** Clones a bitset. */
|
|
1130
|
+
clone() {
|
|
1131
|
+
const bitArray = new BitArray(0, false);
|
|
1132
|
+
bitArray._data = Uint32Array.from(this._data); // effective length: (lengthInInts)
|
|
1133
|
+
bitArray._length = this._length;
|
|
1134
|
+
bitArray._version = this._version;
|
|
1135
|
+
return bitArray;
|
|
1136
|
+
}
|
|
1137
|
+
/** Initializes a bitset. */
|
|
1138
|
+
init(flag, notify) {
|
|
1139
|
+
this.setAll(false, false);
|
|
1140
|
+
for (let i = 0; i < this._length; i++) {
|
|
1141
|
+
if (flag(i))
|
|
1142
|
+
this._data[Math.floor(i / 0x20)] |= 1 << ((i % 0x20) & 0x1f);
|
|
1143
|
+
}
|
|
1144
|
+
this.incrementVersion(notify);
|
|
1145
|
+
return this;
|
|
1146
|
+
}
|
|
1147
|
+
/// Inverts a bitset.
|
|
1148
|
+
invert(notify = true) {
|
|
1149
|
+
for (let i = 0; i < this._data.length; i++)
|
|
1150
|
+
this._data[i] ^= -1;
|
|
1151
|
+
this.incrementVersion(notify);
|
|
1152
|
+
}
|
|
1153
|
+
/// Sets all bits to [value], optionally suppressing notifications.
|
|
1154
|
+
setAll(value, notify = false) {
|
|
1155
|
+
const flags = value ? -1 : 0;
|
|
1156
|
+
const len = this.lengthInInts;
|
|
1157
|
+
for (let i = 0; i < len; i++) //todo: optimize
|
|
1158
|
+
this._data[i] = flags;
|
|
1159
|
+
this.incrementVersion(notify);
|
|
1160
|
+
}
|
|
1161
|
+
/// Sets bits at [indexes] position to [value].
|
|
1162
|
+
/// Clears the bitset if [clear] flag is true.
|
|
1163
|
+
/// Change notification is raised when [notify] is true.
|
|
1164
|
+
setIndexes(indexes, value = true, clear = true, notify = true) {
|
|
1165
|
+
if (clear)
|
|
1166
|
+
this.setAll(!value, false);
|
|
1167
|
+
for (const i of indexes)
|
|
1168
|
+
this.setFast(i, value);
|
|
1169
|
+
this.incrementVersion(notify);
|
|
1170
|
+
}
|
|
1171
|
+
everyIndex(indexes, value = true) {
|
|
1172
|
+
for (const index of indexes) {
|
|
1173
|
+
if (this.getBit(index) != value)
|
|
1174
|
+
return false;
|
|
1175
|
+
}
|
|
1176
|
+
return true;
|
|
1177
|
+
}
|
|
1178
|
+
anyIndex(indexes, value = true) {
|
|
1179
|
+
for (const index of indexes) {
|
|
1180
|
+
if (this.getBit(index) == value)
|
|
1181
|
+
return true;
|
|
1182
|
+
}
|
|
1183
|
+
return false;
|
|
1184
|
+
}
|
|
1185
|
+
setWhere(check, value = true, clear = true, notify = true, allowClear = true) {
|
|
1186
|
+
if (clear && allowClear)
|
|
1187
|
+
this.setAll(!value, false);
|
|
1188
|
+
if (allowClear) {
|
|
1189
|
+
for (let i = 0; i < this._length; i++) {
|
|
1190
|
+
if (check(i))
|
|
1191
|
+
this.setFast(i, value);
|
|
1192
|
+
}
|
|
1193
|
+
}
|
|
1194
|
+
else {
|
|
1195
|
+
for (let i = 0; i < this._length; i++)
|
|
1196
|
+
this.setFast(i, check(i) ? value : !value);
|
|
1197
|
+
}
|
|
1198
|
+
this.incrementVersion(notify);
|
|
1199
|
+
}
|
|
1200
|
+
getRange(from, to) {
|
|
1201
|
+
this.assureInRange(from, 0, this._length - 1, 'from');
|
|
1202
|
+
this.assureInRange(to, 0, this._length, 'to');
|
|
1203
|
+
const arr = [];
|
|
1204
|
+
for (let i = from; i < to; ++i)
|
|
1205
|
+
arr.push(this.getBit(i));
|
|
1206
|
+
return BitArray.fromValues(arr);
|
|
1207
|
+
}
|
|
1208
|
+
getRangeAsList(from, to) {
|
|
1209
|
+
this.assureInRange(from, 0, this._length - 1, 'from');
|
|
1210
|
+
this.assureInRange(to, 0, this._length, 'to');
|
|
1211
|
+
const arr = [];
|
|
1212
|
+
for (let i = from; i < to; ++i)
|
|
1213
|
+
arr.push(this.getBit(i));
|
|
1214
|
+
return arr;
|
|
1215
|
+
}
|
|
1216
|
+
setRange(from, to, value, notify = true) {
|
|
1217
|
+
this.assureInRange(from, 0, this._length - 1, 'from');
|
|
1218
|
+
this.assureInRange(to, 0, this._length - 1, 'to');
|
|
1219
|
+
const start = Math.min(from, to);
|
|
1220
|
+
const end = Math.max(from, to);
|
|
1221
|
+
//todo: optimize
|
|
1222
|
+
if (value) {
|
|
1223
|
+
for (let i = start; i <= end; i++)
|
|
1224
|
+
this.setTrue(i);
|
|
1225
|
+
}
|
|
1226
|
+
else {
|
|
1227
|
+
for (let i = start; i <= end; i++)
|
|
1228
|
+
this.setFalse(i);
|
|
1229
|
+
}
|
|
1230
|
+
this.incrementVersion(notify);
|
|
1231
|
+
return this;
|
|
1232
|
+
}
|
|
1233
|
+
/// Sets n randomly chosen bits to value, remaining bits to !value.
|
|
1234
|
+
setRandom(n, value, notify = true) {
|
|
1235
|
+
if (n < 0 || n > this._length)
|
|
1236
|
+
throw new Error('n must be >= 0 && <= Count');
|
|
1237
|
+
if (n > this._length / 2)
|
|
1238
|
+
this.setRandom(this._length - n, !value);
|
|
1239
|
+
this.setAll(!value);
|
|
1240
|
+
for (let k = 0; k < n;) {
|
|
1241
|
+
const i = Math.floor(Math.random() * this._length);
|
|
1242
|
+
if (this.getBit(i) == value)
|
|
1243
|
+
continue;
|
|
1244
|
+
this.setFast(i, value);
|
|
1245
|
+
k++;
|
|
1246
|
+
}
|
|
1247
|
+
this.incrementVersion(notify);
|
|
1248
|
+
}
|
|
1249
|
+
/// Modifies current bitset by performing the bitwise AND operation against the
|
|
1250
|
+
/// corresponding elements in the specified bitset.
|
|
1251
|
+
and(value, notify = true) {
|
|
1252
|
+
if (this._length != value._length)
|
|
1253
|
+
throw new Error('Array lengths differ.');
|
|
1254
|
+
for (let i = 0, len = this.lengthInInts; i < len; i++)
|
|
1255
|
+
this._data[i] &= value._data[i];
|
|
1256
|
+
this.incrementVersion(notify);
|
|
1257
|
+
return this;
|
|
1258
|
+
}
|
|
1259
|
+
/// Performs the bitwise AND NOT operation on the elements in the current bitset
|
|
1260
|
+
/// against the corresponding elements in the specified bitset.
|
|
1261
|
+
andNot(value, notify = true) {
|
|
1262
|
+
if (this._length != value._length)
|
|
1263
|
+
throw new Error('Array lengths differ.');
|
|
1264
|
+
const len = this.lengthInInts;
|
|
1265
|
+
for (let num2 = 0; num2 < len; num2++)
|
|
1266
|
+
this._data[num2] &= ~value._data[num2];
|
|
1267
|
+
this.incrementVersion(notify);
|
|
1268
|
+
return this;
|
|
1269
|
+
}
|
|
1270
|
+
/// Performs the bitwise NOT AND operation on the elements in the current bitset
|
|
1271
|
+
/// against the corresponding elements in the specified bitset.
|
|
1272
|
+
notAnd(value, notify = true) {
|
|
1273
|
+
if (this._length != value._length)
|
|
1274
|
+
throw new Error('Array lengths differ.');
|
|
1275
|
+
for (let i = 0, len = this.lengthInInts; i < len; i++)
|
|
1276
|
+
this._data[i] = (~this._data[i]) & value._data[i];
|
|
1277
|
+
this.incrementVersion(notify);
|
|
1278
|
+
return this;
|
|
1279
|
+
}
|
|
1280
|
+
/// Inverts all bit values in the current bitset
|
|
1281
|
+
not(notify = true) {
|
|
1282
|
+
for (let i = 0, len = this.lengthInInts; i < len; i++)
|
|
1283
|
+
this._data[i] = ~this._data[i];
|
|
1284
|
+
this.incrementVersion(notify);
|
|
1285
|
+
return this;
|
|
1286
|
+
}
|
|
1287
|
+
/// Performs the bitwise OR operation on the elements in the current bitset
|
|
1288
|
+
/// against the corresponding elements in the specified bitset.
|
|
1289
|
+
or(value, notify = true) {
|
|
1290
|
+
if (this._length != value._length)
|
|
1291
|
+
throw new Error('Array lengths differ.');
|
|
1292
|
+
for (let i = 0, len = this.lengthInInts; i < len; i++)
|
|
1293
|
+
this._data[i] |= value._data[i];
|
|
1294
|
+
this.incrementVersion(notify);
|
|
1295
|
+
return this;
|
|
1296
|
+
}
|
|
1297
|
+
/// Performs the bitwise exclusive OR operation on the elements in the current bitset
|
|
1298
|
+
/// against the corresponding elements in the specified bitset.
|
|
1299
|
+
xor(value, notify = true) {
|
|
1300
|
+
if (this._length != value._length)
|
|
1301
|
+
throw new Error('Array lengths differ.');
|
|
1302
|
+
for (let i = 0, len = this.lengthInInts; i < len; i++)
|
|
1303
|
+
this._data[i] ^= value._data[i];
|
|
1304
|
+
this.incrementVersion(notify);
|
|
1305
|
+
return this;
|
|
1306
|
+
}
|
|
1307
|
+
/// Inserts n 0-bits at position pos, resizing self and shifting bits appropriately.
|
|
1308
|
+
insertAt(pos, n, flag = false) {
|
|
1309
|
+
this.assureInRange(pos, 0, this._length, 'pos');
|
|
1310
|
+
if (n == 0)
|
|
1311
|
+
return;
|
|
1312
|
+
//TODO: optimize
|
|
1313
|
+
//the most primitive implementation, optimize it later!
|
|
1314
|
+
// beginUpdate();
|
|
1315
|
+
const oldlength = this._length;
|
|
1316
|
+
this.setLength(this._length + n);
|
|
1317
|
+
//if (!contains(!flag)) return; // nothing to do
|
|
1318
|
+
for (let i = oldlength - 1; i >= pos; i--)
|
|
1319
|
+
this.setBit(i + n, this.getBit(i));
|
|
1320
|
+
for (let i = pos; i < pos + n; i++)
|
|
1321
|
+
this.setBit(i, flag);
|
|
1322
|
+
// endUpdate();
|
|
1323
|
+
}
|
|
1324
|
+
/// Deletes n bits beginning at position pos, resizing self and shifting remaining
|
|
1325
|
+
/// bits appropriately.
|
|
1326
|
+
removeAt(pos, n = 1) {
|
|
1327
|
+
// the most primitive implementation, optimize it later!
|
|
1328
|
+
if (n < 0)
|
|
1329
|
+
throw new Error('n cannot be negative');
|
|
1330
|
+
this.assureInRange(pos, 0, this._length - n, 'pos');
|
|
1331
|
+
if (this.contains(true)) {
|
|
1332
|
+
for (let i = pos; i < this._length - n; i++)
|
|
1333
|
+
this.setBit(i, this.getBit(i + n));
|
|
1334
|
+
}
|
|
1335
|
+
this.setLength(this._length - n);
|
|
1336
|
+
}
|
|
1337
|
+
removeByMask(mask, flag = true) {
|
|
1338
|
+
if (this._length != mask.length)
|
|
1339
|
+
throw new Error('length != mask.length');
|
|
1340
|
+
if (mask == this) { // no need to iterate
|
|
1341
|
+
this.setLength(mask.countBits(!flag));
|
|
1342
|
+
this.setAll(!flag);
|
|
1343
|
+
}
|
|
1344
|
+
else {
|
|
1345
|
+
let dstIdx = 0;
|
|
1346
|
+
for (let srcIdx = -1; (srcIdx = mask.findNext(srcIdx, !flag)) != -1;)
|
|
1347
|
+
this.setFast(dstIdx++, this.getBit(srcIdx));
|
|
1348
|
+
this._length = dstIdx;
|
|
1349
|
+
this._version++;
|
|
1350
|
+
}
|
|
1351
|
+
return this;
|
|
1352
|
+
}
|
|
1353
|
+
/// Similar to the [] operator.
|
|
1354
|
+
getBit(pos) {
|
|
1355
|
+
return (this._data[Math.floor(pos / 0x20)] & (1 << (pos & 0x1f))) != 0;
|
|
1356
|
+
}
|
|
1357
|
+
/// Similar to the [] operator.
|
|
1358
|
+
setBit(pos, bit, notify = true) {
|
|
1359
|
+
this.setFast(pos, bit);
|
|
1360
|
+
if (notify)
|
|
1361
|
+
this._version++;
|
|
1362
|
+
else
|
|
1363
|
+
this._version++;
|
|
1364
|
+
}
|
|
1365
|
+
/// Sets [i]-th bit to [value], does not check bounds, does not increment version
|
|
1366
|
+
setFast(i, value) {
|
|
1367
|
+
if (value)
|
|
1368
|
+
this._data[Math.floor(i / 0x20)] |= 1 << (i & 0x1f);
|
|
1369
|
+
else
|
|
1370
|
+
this._data[Math.floor(i / 0x20)] &= ~(1 << (i & 0x1f));
|
|
1371
|
+
}
|
|
1372
|
+
setTrue(pos) {
|
|
1373
|
+
this._data[Math.floor(pos / 0x20)] |= 1 << (pos & 0x1f);
|
|
1374
|
+
}
|
|
1375
|
+
setFalse(pos) {
|
|
1376
|
+
this._data[Math.floor(pos / 0x20)] &= ~(1 << (pos & 0x1f));
|
|
1377
|
+
}
|
|
1378
|
+
trueCount() {
|
|
1379
|
+
return this.countBits(true);
|
|
1380
|
+
}
|
|
1381
|
+
falseCount() {
|
|
1382
|
+
return this.countBits(false);
|
|
1383
|
+
}
|
|
1384
|
+
/// Counts bits of the specified value.
|
|
1385
|
+
countBits(value) {
|
|
1386
|
+
if (this._length == 0)
|
|
1387
|
+
return 0;
|
|
1388
|
+
if (this._selectedCountVersion != this._version) {
|
|
1389
|
+
this._selectedCount = 0;
|
|
1390
|
+
const len = this.lengthInInts;
|
|
1391
|
+
let i = 0;
|
|
1392
|
+
for (; i < len - 1; i++) {
|
|
1393
|
+
for (let k = this._data[i]; k != 0; k >>>= 8) { //todo: cast data[i] to uint
|
|
1394
|
+
this._selectedCount += BitArray._onBitCount[k & 0xff];
|
|
1395
|
+
}
|
|
1396
|
+
}
|
|
1397
|
+
// The last int.
|
|
1398
|
+
let k = this._data[i];
|
|
1399
|
+
const remainingBits = this._length & 0x1f;
|
|
1400
|
+
if (remainingBits != 0) /* if remainingBits == 0, the last int is fully used and ALL bits should be left as is */
|
|
1401
|
+
k &= ~((4294967295) << remainingBits);
|
|
1402
|
+
for (; k != 0; k >>>= 8)
|
|
1403
|
+
this._selectedCount += BitArray._onBitCount[k & 0xff];
|
|
1404
|
+
this._selectedCountVersion = this._version;
|
|
1405
|
+
}
|
|
1406
|
+
return (value ? this._selectedCount : this._length - this._selectedCount);
|
|
1407
|
+
}
|
|
1408
|
+
/// Returns a number of set bits where also [check] is true
|
|
1409
|
+
countWhere(check) {
|
|
1410
|
+
let result = 0;
|
|
1411
|
+
if (this.trueCount() == this._length) {
|
|
1412
|
+
for (let i = 0; i < this._length; i++)
|
|
1413
|
+
result += check(i) ? 1 : 0;
|
|
1414
|
+
}
|
|
1415
|
+
else {
|
|
1416
|
+
for (let i = -1; (i = this.findNext(i, true)) != -1;)
|
|
1417
|
+
result += check(i) ? 1 : 0;
|
|
1418
|
+
}
|
|
1419
|
+
return result;
|
|
1420
|
+
}
|
|
1421
|
+
/// Performs bit "and" and counts bits of the specified value, without bitset modification.
|
|
1422
|
+
andWithCountBits(second, value) {
|
|
1423
|
+
if (this._length == 0)
|
|
1424
|
+
return 0;
|
|
1425
|
+
let count = 0;
|
|
1426
|
+
const len = this.lengthInInts;
|
|
1427
|
+
let i = 0;
|
|
1428
|
+
for (; i < len - 1; i++) {
|
|
1429
|
+
for (let k = this._data[i] & second._data[i]; k != 0; k >>>= 8)
|
|
1430
|
+
count += BitArray._onBitCount[k & 0xff];
|
|
1431
|
+
}
|
|
1432
|
+
// The last int.
|
|
1433
|
+
let k = this._data[i] & second._data[i];
|
|
1434
|
+
const remainingBits = this._length & 0x1f;
|
|
1435
|
+
if (remainingBits != 0)
|
|
1436
|
+
k &= ~((4294967295) << remainingBits);
|
|
1437
|
+
for (; k != 0; k >>>= 8)
|
|
1438
|
+
count += BitArray._onBitCount[k & 0xff];
|
|
1439
|
+
return (value ? count : this._length - count);
|
|
1440
|
+
}
|
|
1441
|
+
clear() {
|
|
1442
|
+
this.setLength(0);
|
|
1443
|
+
}
|
|
1444
|
+
contains(value) {
|
|
1445
|
+
return this.findNext(-1, value) >= 0;
|
|
1446
|
+
}
|
|
1447
|
+
get allTrue() {
|
|
1448
|
+
return this.countBits(true) == this._length;
|
|
1449
|
+
}
|
|
1450
|
+
get allFalse() {
|
|
1451
|
+
return this.countBits(false) == this._length;
|
|
1452
|
+
}
|
|
1453
|
+
get anyTrue() {
|
|
1454
|
+
return this.countBits(true) > 0;
|
|
1455
|
+
}
|
|
1456
|
+
get anyFalse() {
|
|
1457
|
+
return this.countBits(false) > 0;
|
|
1458
|
+
}
|
|
1459
|
+
/// Returns the position of the next bit of the specified value, starting from the specified position.
|
|
1460
|
+
/// Returns -1, if there are no such bits.
|
|
1461
|
+
findNext(index, value = true) {
|
|
1462
|
+
this.assureInRange(index, -1, this._length, 'index');
|
|
1463
|
+
if (index >= this._length - 1)
|
|
1464
|
+
return -1;
|
|
1465
|
+
index = index < 0 ? 0 : index + 1; // skip start
|
|
1466
|
+
let unusedBits = index & 0x1f;
|
|
1467
|
+
const numInts = this.lengthInInts;
|
|
1468
|
+
for (let i = Math.floor(index / 32); i < numInts; i++) {
|
|
1469
|
+
let k = (value ? this._data[i] : ~this._data[i]); // uint cast
|
|
1470
|
+
if (unusedBits != 0) {
|
|
1471
|
+
k &= ((0xffffffff << unusedBits) & 0xffffffff);
|
|
1472
|
+
unusedBits = 0;
|
|
1473
|
+
}
|
|
1474
|
+
else if (!value && k == -4294967296) /* looking for false, all bits are set */ {
|
|
1475
|
+
continue;
|
|
1476
|
+
}
|
|
1477
|
+
for (let j = 0; k != 0; j += 8, k >>>= 8) {
|
|
1478
|
+
const p = BitArray._firstOnBit[k & 0xff];
|
|
1479
|
+
if (p >= 0) {
|
|
1480
|
+
index = p + (i * 32) + j;
|
|
1481
|
+
if (index >= this._length)
|
|
1482
|
+
return -1;
|
|
1483
|
+
return index;
|
|
1484
|
+
}
|
|
1485
|
+
}
|
|
1486
|
+
}
|
|
1487
|
+
return -1;
|
|
1488
|
+
}
|
|
1489
|
+
/// Finds previous bit of the specified value in the bitset.
|
|
1490
|
+
findPrev(index, value = true) {
|
|
1491
|
+
if (index == 0)
|
|
1492
|
+
return -1;
|
|
1493
|
+
this.assureInRange(index, -1, this._length, 'index');
|
|
1494
|
+
index = index < 0 ? this._length - 1 : index - 1; // skip start
|
|
1495
|
+
const lastIntIdx = Math.floor(index / 0x20);
|
|
1496
|
+
let remainingBits = (index + 1) & 0x1f;
|
|
1497
|
+
for (let i = lastIntIdx; i >= 0; i--) {
|
|
1498
|
+
let k = (value ? this._data[i] : ~this._data[i]); // cast
|
|
1499
|
+
if (remainingBits != 0) {
|
|
1500
|
+
k &= ~((4294967295) << remainingBits);
|
|
1501
|
+
remainingBits = 0;
|
|
1502
|
+
}
|
|
1503
|
+
for (let j = 24; k != 0; j -= 8, k <<= 8) {
|
|
1504
|
+
const p = BitArray._lastOnBit[k >>> 0x18];
|
|
1505
|
+
if (p >= 0)
|
|
1506
|
+
return p + (i * 32) + j;
|
|
1507
|
+
}
|
|
1508
|
+
}
|
|
1509
|
+
return -1;
|
|
1510
|
+
}
|
|
1511
|
+
}
|
|
1512
|
+
BitArray._onBitCount = Int8Array.from([
|
|
1513
|
+
0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4,
|
|
1514
|
+
1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,
|
|
1515
|
+
1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,
|
|
1516
|
+
2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
|
|
1517
|
+
1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,
|
|
1518
|
+
2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
|
|
1519
|
+
2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
|
|
1520
|
+
3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,
|
|
1521
|
+
1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,
|
|
1522
|
+
2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
|
|
1523
|
+
2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
|
|
1524
|
+
3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,
|
|
1525
|
+
2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,
|
|
1526
|
+
3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,
|
|
1527
|
+
3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,
|
|
1528
|
+
4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8
|
|
1529
|
+
]);
|
|
1530
|
+
BitArray._firstOnBit = Int8Array.from([
|
|
1531
|
+
-1, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1532
|
+
4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1533
|
+
5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1534
|
+
4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1535
|
+
6, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1536
|
+
4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1537
|
+
5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1538
|
+
4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1539
|
+
7, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1540
|
+
4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1541
|
+
5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1542
|
+
4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1543
|
+
6, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1544
|
+
4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1545
|
+
5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,
|
|
1546
|
+
4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0
|
|
1547
|
+
]);
|
|
1548
|
+
BitArray._lastOnBit = Int8Array.from([
|
|
1549
|
+
-1, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
1550
|
+
4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
|
|
1551
|
+
5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
|
|
1552
|
+
5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
|
|
1553
|
+
6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
|
|
1554
|
+
6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
|
|
1555
|
+
6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
|
|
1556
|
+
6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
|
|
1557
|
+
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
|
|
1558
|
+
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
|
|
1559
|
+
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
|
|
1560
|
+
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
|
|
1561
|
+
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
|
|
1562
|
+
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
|
|
1563
|
+
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
|
|
1564
|
+
7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7
|
|
1565
|
+
]);
|
|
1566
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-array.js","sourceRoot":"","sources":["bit-array.ts"],"names":[],"mappings":"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,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;CAAC,CAAC,CAAC;AAE5C,oBAAW,GAAG,SAAS,CAAC,IAAI,CAAC;IAClC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC/C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;CAAC,CAAC,CAAC;AAE5C,mBAAU,GAAG,SAAS,CAAC,IAAI,CAAC;IACjC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC/C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IAC9C,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;CAAC,CAAC,CAAC","sourcesContent":["export default class BitArray {\n  static _onBitCount = Int8Array.from([\n    0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4,\n    1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,\n    1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,\n    2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,\n    1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,\n    2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,\n    2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,\n    3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,\n    1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,\n    2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,\n    2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,\n    3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,\n    2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,\n    3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,\n    3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,\n    4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8]);\n\n  static _firstOnBit = Int8Array.from([\n    -1, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    6, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    7, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    6, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0,\n    4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0]);\n\n  static _lastOnBit = Int8Array.from([\n    -1, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3,\n    4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,\n    5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,\n    5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,\n    6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,\n    6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,\n    6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,\n    6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,\n    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,\n    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,\n    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,\n    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,\n    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,\n    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,\n    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,\n    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7]);\n\n  private _data: Uint32Array;\n  private _length = 0;\n  private _version = 0;\n  private _updateLevel = 0;\n  private _selectedCount = 0;\n  private _selectedCountVersion = -1;\n  private _selectedIndexesVersion = -1;\n  private _versionedName = '';\n  private _versionedNameVersion = -1;\n  SHRINK_THRESHOLD = 0x100;\n\n  constructor(data: Uint32Array, length: number)\n  constructor(length: number, defaultValue?: boolean)\n  constructor(arg: number | Uint32Array, defaultValue: boolean | number = false) {\n    if (typeof arg === 'number') {\n      const length = arg;\n      const buff = BitArray._createBuffer(length);\n      if (defaultValue) {\n        for (let i = 0; i < buff.length; i++)\n          buff[i] = -1;\n      }\n      this._data = buff;\n      this._length = length;\n    } else if (arg instanceof Uint32Array) {\n      this._data = arg as Uint32Array;\n      this._length = defaultValue as number;\n    } else {\n      throw new Error('Invalid constructor');\n    }\n  }\n\n\n  getRawData() { return this._data; }\n\n  assureGoez(num: number, argName: String): void {\n    if (num < 0) throw new Error(`${argName} should be greater than zero`);\n  }\n\n  assureInRange(value: number, min: number, max: number, argName: String): void {\n    if ((value < min) || (value > max))\n      throw new Error(`Argument ${argName} (${value}) out of range (${min}, ${max})`);\n  }\n\n  copy(src: Uint32Array, dst: Uint32Array, count: number): void {\n    for (let i = 0; i < count; i++)\n      dst[i] = src[i];\n  }\n\n  copyFrom(other: BitArray): void {\n    if (this._length != other._length)\n      throw new Error(`Lengths differ (${this._length} != ${other._length})`);\n    this.copy(other._data, this._data, this.lengthInInts);\n    this._version++;\n  }\n\n  get length() {\n    return this._length;\n  }\n\n  get buffer() {\n    return this._data;\n  }\n\n  set buffer(data: Uint32Array) {\n    this._data = data;\n    this._version++;\n  }\n\n  get version() {\n    return this._version;\n  }\n\n  set version(value: number) {\n    this._version = value;\n  }\n\n  incrementVersion(notify = true): void {\n    this._version++;\n  }\n\n  get lengthInInts() {\n    return Math.floor((this._length + 0x1f) / 0x20);\n  }\n\n  get versionedName() {\n    return this._version == this._versionedNameVersion ? this._versionedName : '';\n  }\n\n  set versionedName(name: string) {\n    this._versionedName = name;\n    this._versionedNameVersion = this._version;\n  }\n\n  get self() {\n    return this;\n  }\n\n  setLength(value: number): void {\n    if (value < 0)\n      throw new Error('should be >= 0');\n\n    if (value == this._length) return;\n    const nIntsNeeded = Math.floor((value + 0x1f) / 0x20);\n    if ((nIntsNeeded > this._data.length) || ((nIntsNeeded + this.SHRINK_THRESHOLD) < this._data.length)) {\n      const newData = new Uint32Array(nIntsNeeded);\n      this.copy(this._data, newData, (nIntsNeeded > this._data.length) ? this._data.length : nIntsNeeded);\n      this._data = newData;\n    }\n\n    if (value > this._length) {\n      if (this._length % 0x20 > 0)\n        this._data[this.lengthInInts - 1] &= (1 << ((this._length % 0x20) & 0x1f)) - 1;\n\n      this._data.fill(0, this.lengthInInts, nIntsNeeded);\n    }\n    this._length = value;\n    this._version++;\n  }\n\n  static fromAnd(set1: BitArray, set2: BitArray): BitArray {\n    if (set1._length != set2._length)\n      throw new Error(`Lengths differ (${set1._length} != ${set2._length})`);\n\n    const temp = new BitArray(set1._length);\n    temp._length = set1._length;\n    temp._data = BitArray._createBuffer(temp._length);\n    temp._version = 0;\n\n    const len = set1.lengthInInts;\n    for (let i = 0; i < len; i++)\n      temp._data[i] = set1._data[i] & set2._data[i];\n\n    return temp;\n  }\n\n  private static _createBuffer(length: number): Uint32Array {\n    return new Uint32Array(Math.floor((length + 0x1f) / 0x20));\n  }\n\n  static fromValues(values: Array<boolean>): BitArray {\n    const temp = new BitArray(values.length);\n    temp._version = 0;\n\n    for (let i = 0; i < temp._length; i++) {\n      if (values[i])\n        temp._data[Math.floor(i / 0x20)] |= 1 << ((i % 0x20) & 0x1f);\n    }\n    return temp;\n  }\n\n  /// Constructs a [BitSet] of length [count], where idx-th bit is determined by a call to [flag] (idx).\n  static fromSeq(count: number, flag: Function): BitArray {\n    const temp = new BitArray(count);\n    for (let i = 0; i < count; ++i)\n      temp.setBit(i, flag(i));\n\n    temp._version = 0;\n    return temp;\n  }\n\n  /// Constructs a [BitSet] from a string [s] containing '0' or '1'.\n  static fromString(s: string): BitArray {\n    return BitArray.fromSeq(s.length, (i: number) => s.charAt(i) == '1');\n  }\n\n  /// Constructs a [BitSet], based on length [_length] and byte array [_data].\n  static fromUint32Array(_length: number, _data: Uint32Array): BitArray {\n    const temp = new BitArray(_length);\n    temp._data = _data;\n    return temp;\n  }\n\n  /// Deserializes a [BitSet] from [bytes].\n  static fromBytes(bytes: Uint8Array): BitArray {\n    const len = bytes.length;\n    const temp = new BitArray(len * 8);\n    temp._data = new Uint32Array(Math.floor((len + 3) / 4));\n    temp._length = len * 8;\n    let num1 = 0;\n    let num2 = 0;\n\n    while ((len - num2) >= 4) {\n      temp._data[num1++] = (\n        ((bytes[num2] & 0xff) | ((bytes[num2 + 1] & 0xff) << 8)) |\n        ((bytes[num2 + 2] & 0xff) << 0x10)\n      ) | ((bytes[num2 + 3] & 0xff) << 0x18);\n\n      num2 += 4;\n    }\n\n    if (len - num2 == 3)\n      temp._data[num1] = (bytes[num2 + 2] & 0xff) << 0x10;\n\n    if (len - num2 == 2)\n      temp._data[num1] |= (bytes[num2 + 1] & 0xff) << 8;\n\n    if (len - num2 == 1)\n      temp._data[num1] |= bytes[num2] & 0xff;\n\n    temp._version = 0;\n    return temp;\n  }\n\n  toString(): string {\n    return `${this._length} bits, ${this.countBits(true)} set`;\n  }\n\n  /// Performs deep comparison of two bitsets.\n  equals(other: BitArray): boolean {\n    if (this == other) return true;\n    if (other == null) return false;\n    if (this._length != other._length) return false;\n    if (this._length == 0) return true;\n\n    for (let i = 0; i < this._data.length - 1; i++)\n      if (this._data[i] != other._data[i]) return false;\n\n    for (let i = (this._data.length - 1) * 8; i < this._length; i++) {\n      if (this.getBit(i) != other.getBit(i))\n        return false;\n    }\n    return true;\n  }\n\n  /** Clones a bitset. */\n  clone(): BitArray {\n    const bitArray = new BitArray(0, false);\n    bitArray._data = Uint32Array.from(this._data); // effective length: (lengthInInts)\n    bitArray._length = this._length;\n    bitArray._version = this._version;\n    return bitArray;\n  }\n\n  /** Initializes a bitset. */\n  init(flag: Function, notify: boolean): BitArray {\n    this.setAll(false, false);\n\n    for (let i = 0; i < this._length; i++) {\n      if (flag(i))\n        this._data[Math.floor(i / 0x20)] |= 1 << ((i % 0x20) & 0x1f);\n    }\n\n    this.incrementVersion(notify);\n    return this;\n  }\n\n  /// Inverts a bitset.\n  invert(notify = true): void {\n    for (let i = 0; i < this._data.length; i++)\n      this._data[i] ^= -1;\n\n    this.incrementVersion(notify);\n  }\n\n  /// Sets all bits to [value], optionally suppressing notifications.\n  setAll(value: boolean, notify = false): void {\n    const flags = value ? -1 : 0;\n    const len = this.lengthInInts;\n\n    for (let i = 0; i < len; i++) //todo: optimize\n      this._data[i] = flags;\n\n    this.incrementVersion(notify);\n  }\n\n  /// Sets bits at [indexes] position to [value].\n  /// Clears the bitset if [clear] flag is true.\n  /// Change notification is raised when [notify] is true.\n  setIndexes(indexes: Array<number>, value = true, clear = true, notify = true): void {\n    if (clear)\n      this.setAll(!value, false);\n\n    for (const i of indexes)\n      this.setFast(i, value);\n\n    this.incrementVersion(notify);\n  }\n\n  everyIndex(indexes: Array<number>, value = true): boolean {\n    for (const index of indexes) {\n      if (this.getBit(index) != value)\n        return false;\n    }\n    return true;\n  }\n\n  anyIndex(indexes: Array<number>, value = true): boolean {\n    for (const index of indexes) {\n      if (this.getBit(index) == value)\n        return true;\n    }\n    return false;\n  }\n\n  setWhere(check: Function, value = true, clear = true, notify = true, allowClear = true): void {\n    if (clear && allowClear)\n      this.setAll(!value, false);\n\n    if (allowClear) {\n      for (let i = 0; i < this._length; i++) {\n        if (check(i))\n          this.setFast(i, value);\n      }\n    } else {\n      for (let i = 0; i < this._length; i++)\n        this.setFast(i, check(i) ? value : !value);\n    }\n\n    this.incrementVersion(notify);\n  }\n\n  getRange(from: number, to: number): BitArray {\n    this.assureInRange(from, 0, this._length - 1, 'from');\n    this.assureInRange(to, 0, this._length, 'to');\n    const arr: Array<boolean> = [];\n    for (let i = from; i < to; ++i)\n      arr.push(this.getBit(i));\n    return BitArray.fromValues(arr);\n  }\n\n  getRangeAsList(from: number, to: number): boolean[] {\n    this.assureInRange(from, 0, this._length - 1, 'from');\n    this.assureInRange(to, 0, this._length, 'to');\n    const arr: boolean[] = [];\n    for (let i = from; i < to; ++i)\n      arr.push(this.getBit(i));\n    return arr;\n  }\n\n\n  setRange(from: number, to: number, value: boolean, notify = true): BitArray {\n    this.assureInRange(from, 0, this._length - 1, 'from');\n    this.assureInRange(to, 0, this._length - 1, 'to');\n\n    const start = Math.min(from, to);\n    const end = Math.max(from, to);\n\n    //todo: optimize\n    if (value) {\n      for (let i = start; i <= end; i++)\n        this.setTrue(i);\n    } else {\n      for (let i = start; i <= end; i++)\n        this.setFalse(i);\n    }\n\n    this.incrementVersion(notify);\n    return this;\n  }\n\n  /// Sets n randomly chosen bits to value, remaining bits to !value.\n  setRandom(n: number, value: boolean, notify = true): void {\n    if (n < 0 || n > this._length)\n      throw new Error('n must be >= 0 && <= Count');\n\n    if (n > this._length / 2)\n      this.setRandom(this._length - n, !value);\n\n    this.setAll(!value);\n\n    for (let k = 0; k < n;) {\n      const i = Math.floor(Math.random() * this._length);\n      if (this.getBit(i) == value) continue;\n      this.setFast(i, value);\n      k++;\n    }\n\n    this.incrementVersion(notify);\n  }\n\n  /// Modifies current bitset by performing the bitwise AND operation against the\n  /// corresponding elements in the specified bitset.\n  and(value: BitArray, notify = true): BitArray {\n    if (this._length != value._length)\n      throw new Error('Array lengths differ.');\n\n    for (let i = 0, len = this.lengthInInts; i < len; i++)\n      this._data[i] &= value._data[i];\n\n    this.incrementVersion(notify);\n    return this;\n  }\n\n  /// Performs the bitwise AND NOT operation on the elements in the current bitset\n  /// against the corresponding elements in the specified bitset.\n  andNot(value: BitArray, notify = true): BitArray {\n    if (this._length != value._length)\n      throw new Error('Array lengths differ.');\n\n    const len = this.lengthInInts;\n    for (let num2 = 0; num2 < len; num2++)\n      this._data[num2] &= ~value._data[num2];\n\n    this.incrementVersion(notify);\n    return this;\n  }\n\n  /// Performs the bitwise NOT AND operation on the elements in the current bitset\n  /// against the corresponding elements in the specified bitset.\n  notAnd(value: BitArray, notify = true): BitArray {\n    if (this._length != value._length)\n      throw new Error('Array lengths differ.');\n\n    for (let i = 0, len = this.lengthInInts; i < len; i++)\n      this._data[i] = (~this._data[i]) & value._data[i];\n\n    this.incrementVersion(notify);\n    return this;\n  }\n\n  /// Inverts all bit values in the current bitset\n  not(notify = true): BitArray {\n    for (let i = 0, len = this.lengthInInts; i < len; i++)\n      this._data[i] = ~this._data[i];\n\n    this.incrementVersion(notify);\n    return this;\n  }\n\n  /// Performs the bitwise OR operation on the elements in the current bitset\n  /// against the corresponding elements in the specified bitset.\n  or(value: BitArray, notify = true) {\n    if (this._length != value._length)\n      throw new Error('Array lengths differ.');\n\n    for (let i = 0, len = this.lengthInInts; i < len; i++)\n      this._data[i] |= value._data[i];\n\n    this.incrementVersion(notify);\n    return this;\n  }\n\n  /// Performs the bitwise exclusive OR operation on the elements in the current bitset\n  /// against the corresponding elements in the specified bitset.\n  xor(value: BitArray, notify = true) {\n    if (this._length != value._length)\n      throw new Error('Array lengths differ.');\n\n    for (let i = 0, len = this.lengthInInts; i < len; i++)\n      this._data[i] ^= value._data[i];\n\n    this.incrementVersion(notify);\n    return this;\n  }\n\n  /// Inserts n 0-bits at position pos, resizing self and shifting bits appropriately.\n  insertAt(pos: number, n: number, flag = false): void {\n    this.assureInRange(pos, 0, this._length, 'pos');\n\n    if (n == 0) return;\n\n    //TODO: optimize\n    //the most primitive implementation, optimize it later!\n\n    // beginUpdate();\n    const oldlength = this._length;\n    this.setLength(this._length + n);\n\n    //if (!contains(!flag)) return; // nothing to do\n\n    for (let i = oldlength - 1; i >= pos; i--)\n      this.setBit(i + n, this.getBit(i));\n\n    for (let i = pos; i < pos + n; i++)\n      this.setBit(i, flag);\n\n    // endUpdate();\n  }\n\n  /// Deletes n bits beginning at position pos, resizing self and shifting remaining\n  /// bits appropriately.\n  removeAt(pos: number, n = 1): void {\n    // the most primitive implementation, optimize it later!\n    if (n < 0)\n      throw new Error('n cannot be negative');\n\n    this.assureInRange(pos, 0, this._length - n, 'pos');\n\n    if (this.contains(true)) {\n      for (let i = pos; i < this._length - n; i++)\n        this.setBit(i, this.getBit(i + n));\n    }\n\n    this.setLength(this._length - n);\n  }\n\n  removeByMask(mask: BitArray, flag = true): BitArray {\n    if (this._length != mask.length)\n      throw new Error('length != mask.length');\n\n    if (mask == this) { // no need to iterate\n      this.setLength(mask.countBits(!flag));\n      this.setAll(!flag);\n    } else {\n      let dstIdx = 0;\n\n      for (let srcIdx = -1; (srcIdx = mask.findNext(srcIdx, !flag)) != -1;)\n        this.setFast(dstIdx++, this.getBit(srcIdx));\n\n      this._length = dstIdx;\n      this._version++;\n    }\n\n    return this;\n  }\n\n  /// Similar to the [] operator.\n  getBit(pos: number): boolean {\n    return (this._data[Math.floor(pos / 0x20)] & (1 << (pos & 0x1f))) != 0;\n  }\n\n  /// Similar to the [] operator.\n  setBit(pos: number, bit: boolean, notify = true) {\n    this.setFast(pos, bit);\n    if (notify)\n      this._version++;\n    else\n      this._version++;\n  }\n\n  /// Sets [i]-th bit to [value], does not check bounds, does not increment version\n  setFast(i: number, value: boolean): void {\n    if (value)\n      this._data[Math.floor(i / 0x20)] |= 1 << (i & 0x1f);\n    else\n      this._data[Math.floor(i / 0x20)] &= ~(1 << (i & 0x1f));\n  }\n\n  setTrue(pos: number): void {\n    this._data[Math.floor(pos / 0x20)] |= 1 << (pos & 0x1f);\n  }\n\n  setFalse(pos: number) {\n    this._data[Math.floor(pos / 0x20)] &= ~(1 << (pos & 0x1f));\n  }\n\n  trueCount(): number {\n    return this.countBits(true);\n  }\n\n  falseCount(): number {\n    return this.countBits(false);\n  }\n\n  /// Counts bits of the specified value.\n  countBits(value: boolean): number {\n    if (this._length == 0) return 0;\n\n    if (this._selectedCountVersion != this._version) {\n      this._selectedCount = 0;\n      const len = this.lengthInInts;\n      let i = 0;\n      for (; i < len - 1; i++) {\n        for (let k = this._data[i]; k != 0; k >>>= 8) { //todo: cast data[i] to uint\n          this._selectedCount += BitArray._onBitCount[k & 0xff];\n        }\n      }\n\n      // The last int.\n      let k = this._data[i];\n      const remainingBits = this._length & 0x1f;\n      if (remainingBits != 0) /* if remainingBits == 0, the last int is fully used and ALL bits should be left as is */\n        k &= ~((4294967295) << remainingBits);\n\n      for (; k != 0; k >>>= 8)\n        this._selectedCount += BitArray._onBitCount[k & 0xff];\n\n      this._selectedCountVersion = this._version;\n    }\n\n    return (value ? this._selectedCount : this._length - this._selectedCount);\n  }\n\n  /// Returns a number of set bits where also [check] is true\n  countWhere(check: Function): number {\n    let result = 0;\n    if (this.trueCount() == this._length) {\n      for (let i = 0; i < this._length; i++)\n        result += check(i) ? 1 : 0;\n    } else {\n      for (let i = -1; (i = this.findNext(i, true)) != -1;)\n        result += check(i) ? 1 : 0;\n    }\n    return result;\n  }\n\n  /// Performs bit \"and\" and counts bits of the specified value, without bitset modification.\n  andWithCountBits(second: BitArray, value: boolean): number {\n    if (this._length == 0) return 0;\n\n    let count = 0;\n    const len = this.lengthInInts;\n    let i = 0;\n    for (; i < len - 1; i++) {\n      for (let k = this._data[i] & second._data[i]; k != 0; k >>>= 8)\n        count += BitArray._onBitCount[k & 0xff];\n    }\n\n    // The last int.\n    let k = this._data[i] & second._data[i];\n    const remainingBits = this._length & 0x1f;\n    if (remainingBits != 0)\n      k &= ~((4294967295) << remainingBits);\n    for (; k != 0; k >>>= 8)\n      count += BitArray._onBitCount[k & 0xff];\n\n    return (value ? count : this._length - count);\n  }\n\n  clear(): void {\n    this.setLength(0);\n  }\n\n  contains(value: boolean): boolean {\n    return this.findNext(-1, value) >= 0;\n  }\n\n  get allTrue() {\n    return this.countBits(true) == this._length;\n  }\n\n  get allFalse() {\n    return this.countBits(false) == this._length;\n  }\n\n  get anyTrue() {\n    return this.countBits(true) > 0;\n  }\n\n  get anyFalse() {\n    return this.countBits(false) > 0;\n  }\n\n  /// Returns the position of the next bit of the specified value, starting from the specified position.\n  /// Returns -1, if there are no such bits.\n  findNext(index: number, value = true): number {\n    this.assureInRange(index, -1, this._length, 'index');\n\n    if (index >= this._length - 1) return -1;\n    index = index < 0 ? 0 : index + 1; // skip start\n    let unusedBits = index & 0x1f;\n    const numInts = this.lengthInInts;\n\n    for (let i = Math.floor(index / 32); i < numInts; i++) {\n      let k = (value ? this._data[i] : ~this._data[i]); // uint cast\n      if (unusedBits != 0) {\n        k &= ((0xffffffff << unusedBits) & 0xffffffff);\n        unusedBits = 0;\n      } else if (!value && k == -4294967296) /* looking for false, all bits are set */{\n        continue;\n      }\n\n      for (let j = 0; k != 0; j += 8, k >>>= 8) {\n        const p = BitArray._firstOnBit[k & 0xff];\n        if (p >= 0) {\n          index = p + (i * 32) + j;\n          if (index >= this._length) return -1;\n          return index;\n        }\n      }\n    }\n    return -1;\n  }\n\n  /// Finds previous bit of the specified value in the bitset.\n  findPrev(index: number, value = true): number {\n    if (index == 0) return -1;\n    this.assureInRange(index, -1, this._length, 'index');\n\n    index = index < 0 ? this._length - 1 : index - 1; // skip start\n\n    const lastIntIdx = Math.floor(index / 0x20);\n    let remainingBits = (index + 1) & 0x1f;\n\n    for (let i = lastIntIdx; i >= 0; i--) {\n      let k = (value ? this._data[i] : ~this._data[i]); // cast\n      if (remainingBits != 0) {\n        k &= ~((4294967295) << remainingBits);\n        remainingBits = 0;\n      }\n      for (let j = 24; k != 0; j -= 8, k <<= 8) {\n        const p = BitArray._lastOnBit[k >>> 0x18];\n        if (p >= 0)\n          return p + (i * 32) + j;\n      }\n    }\n    return -1;\n  }\n}\n"]}
|
|
1567
|
+
|
|
1568
|
+
/***/ }),
|
|
1569
|
+
|
|
1570
|
+
/***/ "./node_modules/fastest-levenshtein/esm/mod.js":
|
|
1571
|
+
/*!*****************************************************!*\
|
|
1572
|
+
!*** ./node_modules/fastest-levenshtein/esm/mod.js ***!
|
|
1573
|
+
\*****************************************************/
|
|
1574
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
1575
|
+
|
|
1576
|
+
__webpack_require__.r(__webpack_exports__);
|
|
1577
|
+
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
|
1578
|
+
/* harmony export */ closest: () => (/* binding */ closest),
|
|
1579
|
+
/* harmony export */ distance: () => (/* binding */ distance)
|
|
1580
|
+
/* harmony export */ });
|
|
1581
|
+
const peq = new Uint32Array(0x10000);
|
|
1582
|
+
const myers_32 = (a, b) => {
|
|
1583
|
+
const n = a.length;
|
|
1584
|
+
const m = b.length;
|
|
1585
|
+
const lst = 1 << (n - 1);
|
|
1586
|
+
let pv = -1;
|
|
1587
|
+
let mv = 0;
|
|
1588
|
+
let sc = n;
|
|
1589
|
+
let i = n;
|
|
1590
|
+
while (i--) {
|
|
1591
|
+
peq[a.charCodeAt(i)] |= 1 << i;
|
|
1592
|
+
}
|
|
1593
|
+
for (i = 0; i < m; i++) {
|
|
1594
|
+
let eq = peq[b.charCodeAt(i)];
|
|
1595
|
+
const xv = eq | mv;
|
|
1596
|
+
eq |= ((eq & pv) + pv) ^ pv;
|
|
1597
|
+
mv |= ~(eq | pv);
|
|
1598
|
+
pv &= eq;
|
|
1599
|
+
if (mv & lst) {
|
|
1600
|
+
sc++;
|
|
1601
|
+
}
|
|
1602
|
+
if (pv & lst) {
|
|
1603
|
+
sc--;
|
|
1604
|
+
}
|
|
1605
|
+
mv = (mv << 1) | 1;
|
|
1606
|
+
pv = (pv << 1) | ~(xv | mv);
|
|
1607
|
+
mv &= xv;
|
|
1608
|
+
}
|
|
1609
|
+
i = n;
|
|
1610
|
+
while (i--) {
|
|
1611
|
+
peq[a.charCodeAt(i)] = 0;
|
|
1612
|
+
}
|
|
1613
|
+
return sc;
|
|
1614
|
+
};
|
|
1615
|
+
const myers_x = (b, a) => {
|
|
1616
|
+
const n = a.length;
|
|
1617
|
+
const m = b.length;
|
|
1618
|
+
const mhc = [];
|
|
1619
|
+
const phc = [];
|
|
1620
|
+
const hsize = Math.ceil(n / 32);
|
|
1621
|
+
const vsize = Math.ceil(m / 32);
|
|
1622
|
+
for (let i = 0; i < hsize; i++) {
|
|
1623
|
+
phc[i] = -1;
|
|
1624
|
+
mhc[i] = 0;
|
|
1625
|
+
}
|
|
1626
|
+
let j = 0;
|
|
1627
|
+
for (; j < vsize - 1; j++) {
|
|
1628
|
+
let mv = 0;
|
|
1629
|
+
let pv = -1;
|
|
1630
|
+
const start = j * 32;
|
|
1631
|
+
const vlen = Math.min(32, m) + start;
|
|
1632
|
+
for (let k = start; k < vlen; k++) {
|
|
1633
|
+
peq[b.charCodeAt(k)] |= 1 << k;
|
|
1634
|
+
}
|
|
1635
|
+
for (let i = 0; i < n; i++) {
|
|
1636
|
+
const eq = peq[a.charCodeAt(i)];
|
|
1637
|
+
const pb = (phc[(i / 32) | 0] >>> i) & 1;
|
|
1638
|
+
const mb = (mhc[(i / 32) | 0] >>> i) & 1;
|
|
1639
|
+
const xv = eq | mv;
|
|
1640
|
+
const xh = ((((eq | mb) & pv) + pv) ^ pv) | eq | mb;
|
|
1641
|
+
let ph = mv | ~(xh | pv);
|
|
1642
|
+
let mh = pv & xh;
|
|
1643
|
+
if ((ph >>> 31) ^ pb) {
|
|
1644
|
+
phc[(i / 32) | 0] ^= 1 << i;
|
|
1645
|
+
}
|
|
1646
|
+
if ((mh >>> 31) ^ mb) {
|
|
1647
|
+
mhc[(i / 32) | 0] ^= 1 << i;
|
|
1648
|
+
}
|
|
1649
|
+
ph = (ph << 1) | pb;
|
|
1650
|
+
mh = (mh << 1) | mb;
|
|
1651
|
+
pv = mh | ~(xv | ph);
|
|
1652
|
+
mv = ph & xv;
|
|
1653
|
+
}
|
|
1654
|
+
for (let k = start; k < vlen; k++) {
|
|
1655
|
+
peq[b.charCodeAt(k)] = 0;
|
|
1656
|
+
}
|
|
1657
|
+
}
|
|
1658
|
+
let mv = 0;
|
|
1659
|
+
let pv = -1;
|
|
1660
|
+
const start = j * 32;
|
|
1661
|
+
const vlen = Math.min(32, m - start) + start;
|
|
1662
|
+
for (let k = start; k < vlen; k++) {
|
|
1663
|
+
peq[b.charCodeAt(k)] |= 1 << k;
|
|
1664
|
+
}
|
|
1665
|
+
let score = m;
|
|
1666
|
+
for (let i = 0; i < n; i++) {
|
|
1667
|
+
const eq = peq[a.charCodeAt(i)];
|
|
1668
|
+
const pb = (phc[(i / 32) | 0] >>> i) & 1;
|
|
1669
|
+
const mb = (mhc[(i / 32) | 0] >>> i) & 1;
|
|
1670
|
+
const xv = eq | mv;
|
|
1671
|
+
const xh = ((((eq | mb) & pv) + pv) ^ pv) | eq | mb;
|
|
1672
|
+
let ph = mv | ~(xh | pv);
|
|
1673
|
+
let mh = pv & xh;
|
|
1674
|
+
score += (ph >>> (m - 1)) & 1;
|
|
1675
|
+
score -= (mh >>> (m - 1)) & 1;
|
|
1676
|
+
if ((ph >>> 31) ^ pb) {
|
|
1677
|
+
phc[(i / 32) | 0] ^= 1 << i;
|
|
1678
|
+
}
|
|
1679
|
+
if ((mh >>> 31) ^ mb) {
|
|
1680
|
+
mhc[(i / 32) | 0] ^= 1 << i;
|
|
1681
|
+
}
|
|
1682
|
+
ph = (ph << 1) | pb;
|
|
1683
|
+
mh = (mh << 1) | mb;
|
|
1684
|
+
pv = mh | ~(xv | ph);
|
|
1685
|
+
mv = ph & xv;
|
|
1686
|
+
}
|
|
1687
|
+
for (let k = start; k < vlen; k++) {
|
|
1688
|
+
peq[b.charCodeAt(k)] = 0;
|
|
1689
|
+
}
|
|
1690
|
+
return score;
|
|
1691
|
+
};
|
|
1692
|
+
const distance = (a, b) => {
|
|
1693
|
+
if (a.length < b.length) {
|
|
1694
|
+
const tmp = b;
|
|
1695
|
+
b = a;
|
|
1696
|
+
a = tmp;
|
|
1697
|
+
}
|
|
1698
|
+
if (b.length === 0) {
|
|
1699
|
+
return a.length;
|
|
1700
|
+
}
|
|
1701
|
+
if (a.length <= 32) {
|
|
1702
|
+
return myers_32(a, b);
|
|
1703
|
+
}
|
|
1704
|
+
return myers_x(a, b);
|
|
1705
|
+
};
|
|
1706
|
+
const closest = (str, arr) => {
|
|
1707
|
+
let min_distance = Infinity;
|
|
1708
|
+
let min_index = 0;
|
|
1709
|
+
for (let i = 0; i < arr.length; i++) {
|
|
1710
|
+
const dist = distance(str, arr[i]);
|
|
1711
|
+
if (dist < min_distance) {
|
|
1712
|
+
min_distance = dist;
|
|
1713
|
+
min_index = i;
|
|
1714
|
+
}
|
|
1715
|
+
}
|
|
1716
|
+
return arr[min_index];
|
|
1717
|
+
};
|
|
1718
|
+
|
|
1719
|
+
|
|
1720
|
+
|
|
1721
|
+
/***/ }),
|
|
1722
|
+
|
|
1723
|
+
/***/ "./node_modules/jaro-winkler-typescript/lib/index.js":
|
|
1724
|
+
/*!***********************************************************!*\
|
|
1725
|
+
!*** ./node_modules/jaro-winkler-typescript/lib/index.js ***!
|
|
1726
|
+
\***********************************************************/
|
|
1727
|
+
/***/ ((__unused_webpack_module, exports) => {
|
|
1728
|
+
|
|
1729
|
+
|
|
1730
|
+
// Reference: https://www.geeksforgeeks.org/jaro-and-jaro-winkler-similarity/
|
|
1731
|
+
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
|
1732
|
+
exports.jaroWinkler = exports.jaro = void 0;
|
|
1733
|
+
/**
|
|
1734
|
+
*
|
|
1735
|
+
* @param str1 String 1 for compare
|
|
1736
|
+
* @param str2 String 2 for compare
|
|
1737
|
+
* @param options to control case sensitive or not
|
|
1738
|
+
*/
|
|
1739
|
+
function jaro(str1, str2, options) {
|
|
1740
|
+
// Exit early if either are empty.
|
|
1741
|
+
if (str1.length === 0 || str2.length === 0) {
|
|
1742
|
+
return 0;
|
|
1743
|
+
}
|
|
1744
|
+
// Convert to upper if case-sensitive is false.
|
|
1745
|
+
if (options && !options.caseSensitive) {
|
|
1746
|
+
str1 = str1.toUpperCase();
|
|
1747
|
+
str2 = str2.toUpperCase();
|
|
1748
|
+
}
|
|
1749
|
+
// Exact match
|
|
1750
|
+
if (str1 === str2) {
|
|
1751
|
+
return 1;
|
|
1752
|
+
}
|
|
1753
|
+
// Number of matches
|
|
1754
|
+
var m = 0;
|
|
1755
|
+
// Length of two Strings
|
|
1756
|
+
var len1 = str1.length;
|
|
1757
|
+
var len2 = str2.length;
|
|
1758
|
+
// Maximum distance
|
|
1759
|
+
var window = Math.floor(Math.max(len1, len2) / 2) - 1;
|
|
1760
|
+
// Hash for matches
|
|
1761
|
+
var str1Hash = new Array(len1);
|
|
1762
|
+
var str2Hash = new Array(len2);
|
|
1763
|
+
for (var i = 0; i < len1; i++) {
|
|
1764
|
+
for (var j = Math.max(0, i - window); j <= Math.min(len2, i + window + 1); j++) {
|
|
1765
|
+
if (!str1Hash[i] && !str2Hash[j] && str1[i] === str2[j]) {
|
|
1766
|
+
++m;
|
|
1767
|
+
str1Hash[i] = str2Hash[j] = true;
|
|
1768
|
+
break;
|
|
1769
|
+
}
|
|
1770
|
+
}
|
|
1771
|
+
}
|
|
1772
|
+
// Exit early if no matches were found.
|
|
1773
|
+
if (m === 0) {
|
|
1774
|
+
return 0;
|
|
1775
|
+
}
|
|
1776
|
+
// Count the transpositions.
|
|
1777
|
+
var t = 0;
|
|
1778
|
+
var point = 0;
|
|
1779
|
+
for (var i = 0; i < len1; i++) {
|
|
1780
|
+
if (str1Hash[i]) {
|
|
1781
|
+
while (!str2Hash[point]) {
|
|
1782
|
+
point++;
|
|
1783
|
+
}
|
|
1784
|
+
if (str1.charAt(i) !== str2.charAt(point++)) {
|
|
1785
|
+
t++;
|
|
1786
|
+
}
|
|
1787
|
+
}
|
|
1788
|
+
}
|
|
1789
|
+
t /= 2;
|
|
1790
|
+
return (m / len1 + m / len2 + (m - t) / m) / 3;
|
|
1791
|
+
}
|
|
1792
|
+
exports.jaro = jaro;
|
|
1793
|
+
/**
|
|
1794
|
+
*
|
|
1795
|
+
* @param str1 String 1 for compare
|
|
1796
|
+
* @param str2 String 2 for compare
|
|
1797
|
+
* @param options to control case sensitive or not
|
|
1798
|
+
*/
|
|
1799
|
+
function jaroWinkler(str1, str2, options) {
|
|
1800
|
+
// Jaro Distance
|
|
1801
|
+
var jaroDist = jaro(str1, str2, options);
|
|
1802
|
+
// Same prefix length, maxium is 4
|
|
1803
|
+
var prefix = 0;
|
|
1804
|
+
if (jaroDist > 0.7) {
|
|
1805
|
+
var minIndex = Math.min(str1.length, str2.length);
|
|
1806
|
+
var i = 0;
|
|
1807
|
+
while (str1[i] === str2[i] && i < 4 && i < minIndex) {
|
|
1808
|
+
++prefix;
|
|
1809
|
+
i++;
|
|
1810
|
+
}
|
|
1811
|
+
jaroDist += 0.1 * prefix * (1 - jaroDist);
|
|
1812
|
+
}
|
|
1813
|
+
return jaroDist;
|
|
1814
|
+
}
|
|
1815
|
+
exports.jaroWinkler = jaroWinkler;
|
|
1816
|
+
|
|
1817
|
+
|
|
1818
|
+
/***/ })
|
|
1819
|
+
|
|
1820
|
+
}]);
|
|
1821
|
+
//# sourceMappingURL=vendors-node_modules_datagrok-libraries_ml_src_distance-matrix_utils_js-node_modules_datagrok-72c7b2.js.map
|