@datagrok-libraries/bio 5.30.2 → 5.31.0
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/package.json +2 -2
- package/src/trees/tree-helper.d.ts +1 -1
- package/src/trees/tree-helper.d.ts.map +1 -1
- package/src/types/index.d.ts +1 -0
- package/src/types/index.d.ts.map +1 -1
- package/src/trees/distance-matrix.d.ts +0 -25
- package/src/trees/distance-matrix.d.ts.map +0 -1
- package/src/trees/distance-matrix.js +0 -88
- package/src/trees/distance-matrix.js.map +0 -1
package/package.json
CHANGED
|
@@ -8,12 +8,12 @@
|
|
|
8
8
|
"access": "public"
|
|
9
9
|
},
|
|
10
10
|
"friendlyName": "Datagrok bio library",
|
|
11
|
-
"version": "5.
|
|
11
|
+
"version": "5.31.0",
|
|
12
12
|
"description": "",
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"@datagrok-libraries/gridext": "^1.3.22",
|
|
15
15
|
"@datagrok-libraries/utils": "^2.5.0",
|
|
16
|
-
"@datagrok-libraries/ml": "^6.3.
|
|
16
|
+
"@datagrok-libraries/ml": "^6.3.28",
|
|
17
17
|
"@deck.gl/core": "8.8.12",
|
|
18
18
|
"cash-dom": "latest",
|
|
19
19
|
"datagrok-api": "^1.10.2",
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as DG from 'datagrok-api/dg';
|
|
2
|
-
import { DistanceMatrix } from '
|
|
2
|
+
import { DistanceMatrix } from '@datagrok-libraries/ml/src/distance-matrix';
|
|
3
3
|
import { ClusterMatrix, NodeCuttedType, NodeType } from './types';
|
|
4
4
|
import { DistanceMetric } from './consts';
|
|
5
5
|
export interface ITreeHelper {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tree-helper.d.ts","sourceRoot":"","sources":["tree-helper.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAEtC,OAAO,EAAC,cAAc,EAAC,MAAM,
|
|
1
|
+
{"version":3,"file":"tree-helper.d.ts","sourceRoot":"","sources":["tree-helper.ts"],"names":[],"mappings":"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"}
|
package/src/types/index.d.ts
CHANGED
|
@@ -23,6 +23,7 @@ export type Monomer = {
|
|
|
23
23
|
};
|
|
24
24
|
};
|
|
25
25
|
export interface IMonomerLib {
|
|
26
|
+
get error(): string | undefined;
|
|
26
27
|
getMonomer(polymerType: string, monomerSymbol: string): Monomer | null;
|
|
27
28
|
getMonomerMolsByPolymerType(polymerType: string): {
|
|
28
29
|
[monomerSymbol: string]: string;
|
package/src/types/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAC,UAAU,EAAC,MAAM,MAAM,CAAC;AAChC,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAC,UAAU,EAAC,MAAM,MAAM,CAAC;AAChC,OAAO,EACL,oBAAoB,IAAI,GAAG,EAC3B,kBAAkB,IAAI,GAAG,EAAE,oBAAoB,IAAI,GAAG,EACvD,MAAM,gBAAgB,CAAC;AAExB,KAAK,MAAM,GAAG;IACZ,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC/B,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAC3B,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;IAC7B,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;CACrB,CAAA;AACD,MAAM,MAAM,OAAO,GAAG;IACpB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACrB,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IACnB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IACtB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACrB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC;IACjB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACrB,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAC3B,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAC3B,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,EAAE,MAAM,CAAC;IAC9B,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,EAAE;QAAE,CAAC,QAAQ,EAAE,MAAM,GAAG,GAAG,CAAA;KAAE,CAAA;CACzC,CAAC;AAEF,MAAM,WAAW,WAAW;IAC1B,IAAI,KAAK,IAAI,MAAM,GAAG,SAAS,CAAC;IAChC,UAAU,CAAC,WAAW,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,GAAG,IAAI,CAAC;IACvE,2BAA2B,CAAC,WAAW,EAAE,MAAM,GAAG;QAAE,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAC7F,uBAAuB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IACvD,eAAe,IAAI,MAAM,EAAE,CAAC;IAC5B,MAAM,CAAC,GAAG,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,IAAI,SAAS,IAAI,UAAU,CAAC,GAAG,CAAC,CAAC;CAClC"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
/** Distance matrix class compatible with data structure of scipy.spatial.distance.pdist */
|
|
2
|
-
export declare class DistanceMatrix {
|
|
3
|
-
_data: Float32Array;
|
|
4
|
-
_size: number;
|
|
5
|
-
get data(): Float32Array;
|
|
6
|
-
get size(): number;
|
|
7
|
-
/**
|
|
8
|
-
* @param {Float32Array} data Distance data
|
|
9
|
-
* @param {number} size Number of original observations
|
|
10
|
-
*/
|
|
11
|
-
constructor(data?: Float32Array, size?: number);
|
|
12
|
-
private _linearizeIJ;
|
|
13
|
-
get(i: number, j: number): number;
|
|
14
|
-
set(i: number, j: number, value: number): void;
|
|
15
|
-
static calc<TObj>(list: Indexable<TObj>, method: (a: TObj, b: TObj) => number): DistanceMatrix;
|
|
16
|
-
square(): void;
|
|
17
|
-
add(other: DistanceMatrix): void;
|
|
18
|
-
sqrt(): void;
|
|
19
|
-
normalize(): void;
|
|
20
|
-
}
|
|
21
|
-
export interface Indexable<TObj> {
|
|
22
|
-
[index: number]: TObj;
|
|
23
|
-
get length(): number;
|
|
24
|
-
}
|
|
25
|
-
//# sourceMappingURL=distance-matrix.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"distance-matrix.d.ts","sourceRoot":"","sources":["distance-matrix.ts"],"names":[],"mappings":"AAIA,2FAA2F;AAC3F,qBAAa,cAAc;IACzB,KAAK,EAAE,YAAY,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IAEd,IAAI,IAAI,IAAI,YAAY,CAAuB;IAE/C,IAAI,IAAI,IAAI,MAAM,CAAuB;IAEzC;;;OAGG;gBACS,IAAI,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,EAAE,MAAM;IAqB9C,OAAO,CAAC,YAAY;IAKpB,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IASxB,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;IAIvC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,KAAK,MAAM,GAAG,cAAc;IAWvF,MAAM;IAMN,GAAG,CAAC,KAAK,EAAE,cAAc;IAQzB,IAAI;IAMJ,SAAS;CAajB;AAED,MAAM,WAAW,SAAS,CAAC,IAAI;IAC7B,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,IAAI,MAAM,IAAI,MAAM,CAAC;CACtB"}
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
/** Distance matrix class compatible with data structure of scipy.spatial.distance.pdist */
|
|
2
|
-
export class DistanceMatrix {
|
|
3
|
-
get data() { return this._data; }
|
|
4
|
-
get size() { return this._size; }
|
|
5
|
-
/**
|
|
6
|
-
* @param {Float32Array} data Distance data
|
|
7
|
-
* @param {number} size Number of original observations
|
|
8
|
-
*/
|
|
9
|
-
constructor(data, size) {
|
|
10
|
-
if (size == undefined) {
|
|
11
|
-
if (data == undefined)
|
|
12
|
-
throw new Error('Arguments error: data or size is required.');
|
|
13
|
-
this._data = data;
|
|
14
|
-
this._size = (1 + Math.sqrt(1 + 4 * 2 * this._data.length)) / 2;
|
|
15
|
-
if (this._size != Math.floor(this._size))
|
|
16
|
-
throw new Error(`Invalid data length ${this._data.length} leads to non integer size ${this._size}`);
|
|
17
|
-
}
|
|
18
|
-
else {
|
|
19
|
-
this._size = size;
|
|
20
|
-
const dataLength = size * (size - 1) / 2;
|
|
21
|
-
if (data) {
|
|
22
|
-
if (data.length != dataLength)
|
|
23
|
-
throw new Error(`Invalid data length. Observations size ${size} requires data length ${dataLength}.`);
|
|
24
|
-
this._data = data;
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
this._data = new Float32Array(dataLength);
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
_linearizeIJ(i, j) {
|
|
32
|
-
if (!(i < j))
|
|
33
|
-
throw new Error('i must be less than j');
|
|
34
|
-
return this._size * i + j - Math.floor(((i + 2) * (i + 1)) / 2);
|
|
35
|
-
}
|
|
36
|
-
get(i, j) {
|
|
37
|
-
if (i == j)
|
|
38
|
-
return 0;
|
|
39
|
-
else if (i < j)
|
|
40
|
-
return this._data[this._linearizeIJ(i, j)];
|
|
41
|
-
else
|
|
42
|
-
return this._data[this._linearizeIJ(j, i)];
|
|
43
|
-
}
|
|
44
|
-
set(i, j, value) {
|
|
45
|
-
this._data[this._linearizeIJ(i, j)] = value;
|
|
46
|
-
}
|
|
47
|
-
static calc(list, method) {
|
|
48
|
-
const size = list.length;
|
|
49
|
-
const res = new DistanceMatrix(undefined, size);
|
|
50
|
-
for (let i = 0; i < size; i++) {
|
|
51
|
-
for (let j = i + 1; j < size; j++)
|
|
52
|
-
res.set(i, j, method(list[i], list[j]));
|
|
53
|
-
}
|
|
54
|
-
return res;
|
|
55
|
-
}
|
|
56
|
-
// squares each value in matrix in place
|
|
57
|
-
square() {
|
|
58
|
-
for (let i = 0; i < this._data.length; i++)
|
|
59
|
-
this._data[i] = Math.pow(this._data[i], 2);
|
|
60
|
-
}
|
|
61
|
-
// adds another matrix to this one in place
|
|
62
|
-
add(other) {
|
|
63
|
-
if (this._size !== other._size)
|
|
64
|
-
throw new Error(`Matrices must have the same size. This size: ${this._size}, other size: ${other._size}`);
|
|
65
|
-
for (let i = 0; i < this._data.length; i++)
|
|
66
|
-
this._data[i] += other._data[i];
|
|
67
|
-
}
|
|
68
|
-
// square root each value in matrix in place
|
|
69
|
-
sqrt() {
|
|
70
|
-
for (let i = 0; i < this._data.length; i++)
|
|
71
|
-
this._data[i] = Math.sqrt(this._data[i]);
|
|
72
|
-
}
|
|
73
|
-
//normilze distance matrix in place
|
|
74
|
-
normalize() {
|
|
75
|
-
let min = this._data[0];
|
|
76
|
-
let max = this._data[0];
|
|
77
|
-
for (let i = 0; i < this._data.length; i++) {
|
|
78
|
-
if (this._data[i] < min)
|
|
79
|
-
min = this._data[i];
|
|
80
|
-
if (this._data[i] > max)
|
|
81
|
-
max = this._data[i];
|
|
82
|
-
}
|
|
83
|
-
const range = max - min;
|
|
84
|
-
for (let i = 0; i < this._data.length; i++)
|
|
85
|
-
this._data[i] = range === 0 ? this._data[i] - min : (this._data[i] - min) / (max - min);
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
//# sourceMappingURL=distance-matrix.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"distance-matrix.js","sourceRoot":"","sources":["distance-matrix.ts"],"names":[],"mappings":"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"}
|