@datagrok-libraries/ml
Advanced tools
Comparing version 0.0.10 to 0.0.12
@@ -0,0 +0,0 @@ { |
@@ -7,7 +7,7 @@ { | ||
"friendlyName": "Datagrok ML library", | ||
"version": "0.0.10", | ||
"version": "0.0.12", | ||
"description": "Machine learning supporting utilities", | ||
"dependencies": { | ||
"datagrok-api": ">=0.95.8", | ||
"@datagrok-libraries/utils": ">=0.0.13", | ||
"@datagrok-libraries/utils": ">=0.0.19", | ||
"cash-dom": "latest", | ||
@@ -14,0 +14,0 @@ "dayjs": "latest", |
import * as umj from 'umap-js'; | ||
import { TSNE } from '@keckelt/tsne'; | ||
import { Options, DistanceMetric, Coordinates, Vectors } from '@datagrok-libraries/utils/src/type-declarations'; | ||
import { SPEBase, PSPEBase } from './spe'; | ||
import { SPEBase, PSPEBase, OriginalSPE } from './spe'; | ||
import { KnownMetrics } from './string-measure'; | ||
@@ -130,2 +130,22 @@ /** | ||
} | ||
/** | ||
* Implements original SPE dimensionality reduction. | ||
* | ||
* @class OriginalSPEReducer | ||
* @extends {Reducer} | ||
*/ | ||
declare class OriginalSPEReducer extends Reducer { | ||
protected reducer: OriginalSPE; | ||
/** | ||
* Creates an instance of OriginalSPEReducer. | ||
* @param {Options} options Options to pass to the constructor. | ||
* @memberof OriginalSPEReducer | ||
*/ | ||
constructor(options: Options); | ||
/** | ||
* Embeds the data given into the two-dimensional space using the original SPE method. | ||
* @return {Coordinates} Cartesian coordinate of this embedding. | ||
*/ | ||
transform(): Coordinates; | ||
} | ||
declare const AvailableReducers: { | ||
@@ -136,2 +156,3 @@ UMAP: typeof UMAPReducer; | ||
pSPE: typeof PSPEReducer; | ||
OriginalSPE: typeof OriginalSPEReducer; | ||
}; | ||
@@ -179,4 +200,13 @@ export declare type KnownMethods = keyof typeof AvailableReducers; | ||
static get availableMetrics(): string[]; | ||
/** | ||
* Returns metrics by their data type. | ||
* | ||
* @readonly | ||
* @memberof DimensionalityReducer | ||
*/ | ||
static get metricDataTypes(): { | ||
[name: string]: string[]; | ||
}; | ||
} | ||
export {}; | ||
//# sourceMappingURL=reduce-dimensionality.d.ts.map |
import * as umj from 'umap-js'; | ||
import { TSNE } from '@keckelt/tsne'; | ||
import { Vector } from '@datagrok-libraries/utils/src/type-declarations'; | ||
import { calcDistanceMatrix, transposeMatrix, calculateEuclideanDistance, assert, } from '@datagrok-libraries/utils/src/operations'; | ||
import { SPEBase, PSPEBase } from './spe'; | ||
import { StringMeasure, AvailableMetrics } from './string-measure'; | ||
import { calcDistanceMatrix, transposeMatrix, assert, } from '@datagrok-libraries/utils/src/operations'; | ||
import { SPEBase, PSPEBase, OriginalSPE } from './spe'; | ||
import { StringMeasure, MetricDataTypes, AvailableMetrics } from './string-measure'; | ||
import BitArray from '@datagrok-libraries/utils/src/bit-array'; | ||
import { similarityMetric } from '@datagrok-libraries/utils/src/similarity-metrics'; | ||
/** | ||
@@ -158,2 +160,26 @@ * Abstract dimensionality reducer. | ||
} | ||
/** | ||
* Implements original SPE dimensionality reduction. | ||
* | ||
* @class OriginalSPEReducer | ||
* @extends {Reducer} | ||
*/ | ||
class OriginalSPEReducer extends Reducer { | ||
/** | ||
* Creates an instance of OriginalSPEReducer. | ||
* @param {Options} options Options to pass to the constructor. | ||
* @memberof OriginalSPEReducer | ||
*/ | ||
constructor(options) { | ||
super(options); | ||
this.reducer = new OriginalSPE(options); | ||
} | ||
/** | ||
* Embeds the data given into the two-dimensional space using the original SPE method. | ||
* @return {Coordinates} Cartesian coordinate of this embedding. | ||
*/ | ||
transform() { | ||
return this.reducer.embed(this.data); | ||
} | ||
} | ||
const AvailableReducers = { | ||
@@ -164,2 +190,3 @@ 'UMAP': UMAPReducer, | ||
'pSPE': PSPEReducer, | ||
'OriginalSPE': OriginalSPEReducer, | ||
}; | ||
@@ -181,6 +208,12 @@ /** | ||
*/ | ||
constructor(data, method, metric, options) { | ||
constructor(data, method, metric = 'EuclideanDistance', options) { | ||
var _a; | ||
const measure = metric ? new StringMeasure(metric).getMeasure() : calculateEuclideanDistance; | ||
const measure = new StringMeasure(metric).getMeasure(); | ||
let specOptions = {}; | ||
if (Object.keys(similarityMetric).includes(metric.toString())) { | ||
for (let i = 0; i < data.length; ++i) { | ||
data[i] = new BitArray(data[i]._data, data[i]._length); | ||
} | ||
} | ||
assert(MetricDataTypes[data[0].constructor.name].includes(metric.toString()), 'Data type of the data is incompatible with the metric given.'); | ||
if (method == 'UMAP') { | ||
@@ -236,3 +269,12 @@ specOptions = Object.assign(Object.assign(Object.assign({ data: data }, { distanceFn: measure }), { nEpochs: options === null || options === void 0 ? void 0 : options.cycles }), options); | ||
} | ||
/** | ||
* Returns metrics by their data type. | ||
* | ||
* @readonly | ||
* @memberof DimensionalityReducer | ||
*/ | ||
static get metricDataTypes() { | ||
return MetricDataTypes; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reduce-dimensionality.js","sourceRoot":"","sources":["reduce-dimensionality.ts"],"names":[],"mappings":"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","sourcesContent":["import * as umj from 'umap-js';\nimport {TSNE} from '@keckelt/tsne';\n\nimport {Options, DistanceMetric, Coordinates, Vector, Vectors} from '@datagrok-libraries/utils/src/type-declarations';\nimport {\n  calcDistanceMatrix,\n  transposeMatrix,\n  calculateEuclideanDistance,\n  assert,\n} from '@datagrok-libraries/utils/src/operations';\nimport {SPEBase, PSPEBase} from './spe';\nimport {StringMeasure, AvailableMetrics, KnownMetrics} from './string-measure';\n\n/**\n * Abstract dimensionality reducer.\n *\n * @abstract\n * @class Reducer\n */\nabstract class Reducer {\n  protected data: Vectors;\n\n  /**\n   * Creates an instance of Reducer.\n   * @param {Options} options Options to pass to the constructor.\n   * @memberof Reducer\n   */\n  constructor(options: Options) {\n    this.data = options.data;\n  }\n\n  /**\n   * Is to embed the data given into the two-dimensional space.\n   *\n   * @abstract\n   * @return {Coordinates} Cartesian coordinate of this embedding.\n   * @memberof Reducer\n   */\n  abstract transform(): Coordinates;\n}\n\n/**\n * Implements t-SNE dimensionality reduction.\n *\n * @class TSNEReducer\n * @extends {Reducer}\n */\nclass TSNEReducer extends Reducer {\n  protected reducer: TSNE;\n  protected iterations: number;\n  protected distance: DistanceMetric;\n\n  /**\n   * Creates an instance of TSNEReducer.\n   * @param {Options} options Options to pass to the constructor.\n   * @memberof TSNEReducer\n   */\n  constructor(options: Options) {\n    super(options);\n    this.reducer = new TSNE(options);\n    this.iterations = options?.iterations ?? 100;\n    this.distance = options.distance;\n  }\n\n  /**\n   * Embeds the data given into the two-dimensional space using t-SNE method.\n   * @return {Coordinates} Cartesian coordinate of this embedding.\n   */\n  public transform(): Coordinates {\n    this.reducer.initDataDist(calcDistanceMatrix(this.data, this.distance));\n\n    for (let i = 0; i < this.iterations; ++i) {\n      this.reducer.step(); // every time you call this, solution gets better\n    }\n    return this.reducer.getSolution();\n  }\n}\n\n/**\n * Implements UMAP dimensionality reduction.\n *\n * @class UMAPReducer\n * @extends {Reducer}\n */\nclass UMAPReducer extends Reducer {\n  protected reducer: umj.UMAP;\n  protected distanceFn: Function;\n  protected vectors: number[][];\n\n  /**\n   * Creates an instance of UMAPReducer.\n   * @param {Options} options Options to pass to the constructor.\n   * @memberof UMAPReducer\n   */\n  constructor(options: Options) {\n    super(options);\n\n    assert('distanceFn' in options);\n\n    this.distanceFn = options.distanceFn;\n    this.vectors = [];\n    options.distanceFn = this._encodedDistance.bind(this);\n    this.reducer = new umj.UMAP(options);\n  }\n\n  /**\n   * Custom distance wrapper to have numeric inputs instead of string ones.\n   *\n   * @protected\n   * @param {number[]} a The first item.\n   * @param {number[]} b The first item.\n   * @return {number} Distance metric.\n   * @memberof UMAPReducer\n   */\n  protected _encodedDistance(a: number[], b: number[]): number {\n    return this.distanceFn(this.data[a[0]], this.data[b[0]]);\n  }\n\n  /**\n   * Encodes the input data as a vector of indices.\n   *\n   * @protected\n   * @memberof UMAPReducer\n   */\n  protected _encode() {\n    for (let i = 0; i < this.data.length; ++i) {\n      this.vectors.push([i]);\n    }\n  }\n\n  /**\n   * Embeds the data given into the two-dimensional space using UMAP method.\n   * @return {Coordinates} Cartesian coordinate of this embedding.\n   */\n  public transform(): Coordinates {\n    this._encode();\n\n    const embedding = this.reducer.fit(this.vectors);\n\n    function arrayCast2Coordinates(data: number[][]): Coordinates {\n      return new Array(data.length).fill(0).map((_, i) => (Vector.from(data[i])));\n    }\n\n    return arrayCast2Coordinates(embedding);\n  }\n}\n\n/**\n * Implements original SPE dimensionality reduction.\n *\n * @class SPEReducer\n * @extends {Reducer}\n */\nclass SPEReducer extends Reducer {\n  protected reducer: SPEBase;\n\n  /**\n   * Creates an instance of SPEReducer.\n   * @param {Options} options Options to pass to the constructor.\n   * @memberof SPEReducer\n   */\n  constructor(options: Options) {\n    super(options);\n    this.reducer = new SPEBase(options);\n  }\n\n  /**\n   * Embeds the data given into the two-dimensional space using the original SPE method.\n   * @return {Coordinates} Cartesian coordinate of this embedding.\n   */\n  public transform(): Coordinates {\n    return this.reducer.embed(this.data);\n  }\n}\n\n/**\n * Implements modified SPE dimensionality reduction.\n *\n * @class PSPEReducer\n * @extends {Reducer}\n */\nclass PSPEReducer extends Reducer {\n  protected reducer: PSPEBase;\n\n  /**\n   * Creates an instance of PSPEReducer.\n   * @param {Options} options Options to pass to the constructor.\n   * @memberof PSPEReducer\n   */\n  constructor(options: Options) {\n    super(options);\n    this.reducer = new PSPEBase(options);\n  }\n\n  /**\n   * Embeds the data given into the two-dimensional space using the modified SPE method.\n   * @return {Coordinates} Cartesian coordinate of this embedding.\n   */\n  public transform(): Coordinates {\n    return this.reducer.embed(this.data);\n  }\n}\n\nconst AvailableReducers = {\n  'UMAP': UMAPReducer,\n  't-SNE': TSNEReducer,\n  'SPE': SPEReducer,\n  'pSPE': PSPEReducer,\n};\n\nexport type KnownMethods = keyof typeof AvailableReducers;\n\n/**\n * Unified class implementing different dimensionality reduction methods.\n *\n * @export\n * @class DimensionalityReducer\n */\nexport class DimensionalityReducer {\n  private reducer: Reducer | undefined;\n\n  /**\n   * Creates an instance of DimensionalityReducer.\n   * @param {any[]} data Vectors to embed.\n   * @param {KnownMethods} method Embedding method to be applied\n   * @param {KnownMetrics?} metric Distance metric to be computed between each of the vectors.\n   * @param {Options} [options] Options to pass to the implementing embedders.\n   * @memberof DimensionalityReducer\n   */\n  constructor(data: any[], method: KnownMethods, metric?: KnownMetrics, options?: Options) {\n    const measure = metric ? new StringMeasure(metric).getMeasure() : calculateEuclideanDistance;\n    let specOptions = {};\n\n    if (method == 'UMAP') {\n      specOptions = {\n        ...{data: data},\n        ...{distanceFn: measure},\n        ...{nEpochs: options?.cycles},\n        ...options,\n      };\n    } else if (method == 't-SNE') {\n      specOptions = {\n        ...{data: data},\n        ...{distance: measure},\n        ...{iterations: options?.cycles ?? undefined},\n        ...options,\n      };\n    } else if (method == 'SPE') {\n      specOptions = {...{data: data}, ...{distance: measure}, ...options};\n    } else {\n      specOptions = {...{data: data}, ...{distance: measure}, ...options};\n    }\n    this.reducer = new AvailableReducers[method](specOptions);\n  }\n\n  /**\n   * Embeds the data given into the two-dimensional space using the chosen method.\n   *\n   * @param {boolean} transpose Whether to transform coordinates to have columns-first orientation.\n   * @throws {Error} If the embedding method was not found.\n   * @return {Coordinates} Cartesian coordinate of this embedding.\n   * @memberof DimensionalityReducer\n   */\n  public transform(transpose: boolean = false): Coordinates {\n    if (this.reducer == undefined) {\n      throw new Error('Reducer was not defined.');\n    }\n    let embedding = this.reducer.transform();\n\n    if (transpose) {\n      embedding = transposeMatrix(embedding);\n    }\n    return embedding;\n  }\n\n  /**\n   * Returns dimensionality reduction methods available.\n   *\n   * @readonly\n   * @memberof DimensionalityReducer\n   */\n  static get availableMethods() {\n    return Object.keys(AvailableReducers);\n  }\n\n  /**\n   * Returns metrics available.\n   *\n   * @readonly\n   * @memberof DimensionalityReducer\n   */\n  static get availableMetrics() {\n    return Object.keys(AvailableMetrics);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reduce-dimensionality.js","sourceRoot":"","sources":["reduce-dimensionality.ts"],"names":[],"mappings":"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","sourcesContent":["import * as umj from 'umap-js';\r\nimport {TSNE} from '@keckelt/tsne';\r\n\r\nimport {Options, DistanceMetric, Coordinates, Vector, Vectors} from '@datagrok-libraries/utils/src/type-declarations';\r\nimport {\r\n  calcDistanceMatrix,\r\n  transposeMatrix,\r\n  assert,\r\n} from '@datagrok-libraries/utils/src/operations';\r\nimport {SPEBase, PSPEBase, OriginalSPE} from './spe';\r\nimport {StringMeasure, KnownMetrics, MetricDataTypes, AvailableMetrics} from './string-measure';\r\nimport BitArray from '@datagrok-libraries/utils/src/bit-array';\r\nimport {similarityMetric} from '@datagrok-libraries/utils/src/similarity-metrics';\r\n\r\n/**\r\n * Abstract dimensionality reducer.\r\n *\r\n * @abstract\r\n * @class Reducer\r\n */\r\nabstract class Reducer {\r\n  protected data: Vectors;\r\n\r\n  /**\r\n   * Creates an instance of Reducer.\r\n   * @param {Options} options Options to pass to the constructor.\r\n   * @memberof Reducer\r\n   */\r\n  constructor(options: Options) {\r\n    this.data = options.data;\r\n  }\r\n\r\n  /**\r\n   * Is to embed the data given into the two-dimensional space.\r\n   *\r\n   * @abstract\r\n   * @return {Coordinates} Cartesian coordinate of this embedding.\r\n   * @memberof Reducer\r\n   */\r\n  abstract transform(): Coordinates;\r\n}\r\n\r\n/**\r\n * Implements t-SNE dimensionality reduction.\r\n *\r\n * @class TSNEReducer\r\n * @extends {Reducer}\r\n */\r\nclass TSNEReducer extends Reducer {\r\n  protected reducer: TSNE;\r\n  protected iterations: number;\r\n  protected distance: DistanceMetric;\r\n\r\n  /**\r\n   * Creates an instance of TSNEReducer.\r\n   * @param {Options} options Options to pass to the constructor.\r\n   * @memberof TSNEReducer\r\n   */\r\n  constructor(options: Options) {\r\n    super(options);\r\n    this.reducer = new TSNE(options);\r\n    this.iterations = options?.iterations ?? 100;\r\n    this.distance = options.distance;\r\n  }\r\n\r\n  /**\r\n   * Embeds the data given into the two-dimensional space using t-SNE method.\r\n   * @return {Coordinates} Cartesian coordinate of this embedding.\r\n   */\r\n  public transform(): Coordinates {\r\n    this.reducer.initDataDist(calcDistanceMatrix(this.data, this.distance));\r\n\r\n    for (let i = 0; i < this.iterations; ++i) {\r\n      this.reducer.step(); // every time you call this, solution gets better\r\n    }\r\n    return this.reducer.getSolution();\r\n  }\r\n}\r\n\r\n/**\r\n * Implements UMAP dimensionality reduction.\r\n *\r\n * @class UMAPReducer\r\n * @extends {Reducer}\r\n */\r\nclass UMAPReducer extends Reducer {\r\n  protected reducer: umj.UMAP;\r\n  protected distanceFn: Function;\r\n  protected vectors: number[][];\r\n\r\n  /**\r\n   * Creates an instance of UMAPReducer.\r\n   * @param {Options} options Options to pass to the constructor.\r\n   * @memberof UMAPReducer\r\n   */\r\n  constructor(options: Options) {\r\n    super(options);\r\n\r\n    assert('distanceFn' in options);\r\n\r\n    this.distanceFn = options.distanceFn;\r\n    this.vectors = [];\r\n    options.distanceFn = this._encodedDistance.bind(this);\r\n    this.reducer = new umj.UMAP(options);\r\n  }\r\n\r\n  /**\r\n   * Custom distance wrapper to have numeric inputs instead of string ones.\r\n   *\r\n   * @protected\r\n   * @param {number[]} a The first item.\r\n   * @param {number[]} b The first item.\r\n   * @return {number} Distance metric.\r\n   * @memberof UMAPReducer\r\n   */\r\n  protected _encodedDistance(a: number[], b: number[]): number {\r\n    return this.distanceFn(this.data[a[0]], this.data[b[0]]);\r\n  }\r\n\r\n  /**\r\n   * Encodes the input data as a vector of indices.\r\n   *\r\n   * @protected\r\n   * @memberof UMAPReducer\r\n   */\r\n  protected _encode() {\r\n    for (let i = 0; i < this.data.length; ++i) {\r\n      this.vectors.push([i]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Embeds the data given into the two-dimensional space using UMAP method.\r\n   * @return {Coordinates} Cartesian coordinate of this embedding.\r\n   */\r\n  public transform(): Coordinates {\r\n    this._encode();\r\n\r\n    const embedding = this.reducer.fit(this.vectors);\r\n\r\n    function arrayCast2Coordinates(data: number[][]): Coordinates {\r\n      return new Array(data.length).fill(0).map((_, i) => (Vector.from(data[i])));\r\n    }\r\n\r\n    return arrayCast2Coordinates(embedding);\r\n  }\r\n}\r\n\r\n/**\r\n * Implements original SPE dimensionality reduction.\r\n *\r\n * @class SPEReducer\r\n * @extends {Reducer}\r\n */\r\nclass SPEReducer extends Reducer {\r\n  protected reducer: SPEBase;\r\n\r\n  /**\r\n   * Creates an instance of SPEReducer.\r\n   * @param {Options} options Options to pass to the constructor.\r\n   * @memberof SPEReducer\r\n   */\r\n  constructor(options: Options) {\r\n    super(options);\r\n    this.reducer = new SPEBase(options);\r\n  }\r\n\r\n  /**\r\n   * Embeds the data given into the two-dimensional space using the original SPE method.\r\n   * @return {Coordinates} Cartesian coordinate of this embedding.\r\n   */\r\n  public transform(): Coordinates {\r\n    return this.reducer.embed(this.data);\r\n  }\r\n}\r\n\r\n/**\r\n * Implements modified SPE dimensionality reduction.\r\n *\r\n * @class PSPEReducer\r\n * @extends {Reducer}\r\n */\r\nclass PSPEReducer extends Reducer {\r\n  protected reducer: PSPEBase;\r\n\r\n  /**\r\n   * Creates an instance of PSPEReducer.\r\n   * @param {Options} options Options to pass to the constructor.\r\n   * @memberof PSPEReducer\r\n   */\r\n  constructor(options: Options) {\r\n    super(options);\r\n    this.reducer = new PSPEBase(options);\r\n  }\r\n\r\n  /**\r\n   * Embeds the data given into the two-dimensional space using the modified SPE method.\r\n   * @return {Coordinates} Cartesian coordinate of this embedding.\r\n   */\r\n  public transform(): Coordinates {\r\n    return this.reducer.embed(this.data);\r\n  }\r\n}\r\n\r\n/**\r\n * Implements original SPE dimensionality reduction.\r\n *\r\n * @class OriginalSPEReducer\r\n * @extends {Reducer}\r\n */\r\nclass OriginalSPEReducer extends Reducer {\r\n  protected reducer: OriginalSPE;\r\n\r\n  /**\r\n   * Creates an instance of OriginalSPEReducer.\r\n   * @param {Options} options Options to pass to the constructor.\r\n   * @memberof OriginalSPEReducer\r\n   */\r\n  constructor(options: Options) {\r\n    super(options);\r\n    this.reducer = new OriginalSPE(options);\r\n  }\r\n\r\n  /**\r\n   * Embeds the data given into the two-dimensional space using the original SPE method.\r\n   * @return {Coordinates} Cartesian coordinate of this embedding.\r\n   */\r\n  public transform(): Coordinates {\r\n    return this.reducer.embed(this.data);\r\n  }\r\n}\r\n\r\nconst AvailableReducers = {\r\n  'UMAP': UMAPReducer,\r\n  't-SNE': TSNEReducer,\r\n  'SPE': SPEReducer,\r\n  'pSPE': PSPEReducer,\r\n  'OriginalSPE': OriginalSPEReducer,\r\n};\r\n\r\nexport type KnownMethods = keyof typeof AvailableReducers;\r\n\r\n/**\r\n * Unified class implementing different dimensionality reduction methods.\r\n *\r\n * @export\r\n * @class DimensionalityReducer\r\n */\r\nexport class DimensionalityReducer {\r\n  private reducer: Reducer | undefined;\r\n\r\n  /**\r\n   * Creates an instance of DimensionalityReducer.\r\n   * @param {any[]} data Vectors to embed.\r\n   * @param {KnownMethods} method Embedding method to be applied\r\n   * @param {KnownMetrics?} metric Distance metric to be computed between each of the vectors.\r\n   * @param {Options} [options] Options to pass to the implementing embedders.\r\n   * @memberof DimensionalityReducer\r\n   */\r\n  constructor(data: any[], method: KnownMethods, metric: KnownMetrics = 'EuclideanDistance', options?: Options) {\r\n    const measure = new StringMeasure(metric).getMeasure();\r\n    let specOptions = {};\r\n\r\n    if (Object.keys(similarityMetric).includes(metric.toString())) {\r\n      for (let i = 0; i < data.length; ++i) {\r\n        data[i] = new BitArray(data[i]._data, data[i]._length);\r\n      }\r\n    }\r\n\r\n    assert(MetricDataTypes[data[0].constructor.name].includes(metric.toString()),\r\n      'Data type of the data is incompatible with the metric given.');\r\n\r\n    if (method == 'UMAP') {\r\n      specOptions = {\r\n        ...{data: data},\r\n        ...{distanceFn: measure},\r\n        ...{nEpochs: options?.cycles},\r\n        ...options,\r\n      };\r\n    } else if (method == 't-SNE') {\r\n      specOptions = {\r\n        ...{data: data},\r\n        ...{distance: measure},\r\n        ...{iterations: options?.cycles ?? undefined},\r\n        ...options,\r\n      };\r\n    } else if (method == 'SPE') {\r\n      specOptions = {...{data: data}, ...{distance: measure}, ...options};\r\n    } else {\r\n      specOptions = {...{data: data}, ...{distance: measure}, ...options};\r\n    }\r\n    this.reducer = new AvailableReducers[method](specOptions);\r\n  }\r\n\r\n  /**\r\n   * Embeds the data given into the two-dimensional space using the chosen method.\r\n   *\r\n   * @param {boolean} transpose Whether to transform coordinates to have columns-first orientation.\r\n   * @throws {Error} If the embedding method was not found.\r\n   * @return {Coordinates} Cartesian coordinate of this embedding.\r\n   * @memberof DimensionalityReducer\r\n   */\r\n  public transform(transpose: boolean = false): Coordinates {\r\n    if (this.reducer == undefined) {\r\n      throw new Error('Reducer was not defined.');\r\n    }\r\n    let embedding = this.reducer.transform();\r\n\r\n    if (transpose) {\r\n      embedding = transposeMatrix(embedding);\r\n    }\r\n    return embedding;\r\n  }\r\n\r\n  /**\r\n   * Returns dimensionality reduction methods available.\r\n   *\r\n   * @readonly\r\n   * @memberof DimensionalityReducer\r\n   */\r\n  static get availableMethods() {\r\n    return Object.keys(AvailableReducers);\r\n  }\r\n\r\n  /**\r\n   * Returns metrics available.\r\n   *\r\n   * @readonly\r\n   * @memberof DimensionalityReducer\r\n   */\r\n  static get availableMetrics() {\r\n    return Object.keys(AvailableMetrics);\r\n  }\r\n\r\n  /**\r\n   * Returns metrics by their data type.\r\n   *\r\n   * @readonly\r\n   * @memberof DimensionalityReducer\r\n   */\r\n   static get metricDataTypes() {\r\n    return MetricDataTypes;\r\n  }\r\n}\r\n"]} |
@@ -68,2 +68,22 @@ import { Options, Coordinates, Vectors, DistanceMetric } from '@datagrok-libraries/utils/src/type-declarations'; | ||
} | ||
/** | ||
* Implements modified stochastic proximity embedding. | ||
* | ||
* @export | ||
* @class OriginalSPE | ||
* @link doi:10.1002/jcc.10234 | ||
*/ | ||
export declare class OriginalSPE extends SPEBase { | ||
/** | ||
* Embeds the vectors given into a two-dimensional space using a modified update rule. | ||
* | ||
* @param {Vectors} vectors D-dimensional coordinates. | ||
* @return {Coordinates} SPE coordinates in D space. | ||
*/ | ||
protected radiusPercent: number; | ||
protected maxDistance: number; | ||
protected maxDistanceSteps: number; | ||
constructor(options?: Options); | ||
embed(vectors: Vectors): Coordinates; | ||
} | ||
//# sourceMappingURL=spe.d.ts.map |
@@ -151,2 +151,73 @@ import { calculateEuclideanDistance, calcDistanceMatrix, fillRandomMatrix, vectorAdd, randomInt, } from '@datagrok-libraries/utils/src/operations'; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spe.js","sourceRoot":"","sources":["spe.ts"],"names":[],"mappings":"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","sourcesContent":["import {Options, Coordinates, Vectors, DistanceMetric} from '@datagrok-libraries/utils/src/type-declarations';\nimport {\n  calculateEuclideanDistance,\n  calcDistanceMatrix,\n  fillRandomMatrix,\n  vectorAdd,\n  randomInt,\n} from '@datagrok-libraries/utils/src/operations';\n\n/**\n * Implements stochastic proximity embedding.\n *\n * @export\n * @class SPEBase\n * @link doi:10.1016/S1093-3263(03)00155-4\n */\nexport class SPEBase {\n  protected static dimension = 2;\n  protected steps: number;\n  protected cycles: number;\n  protected cutoff: number;\n  protected lambda: number;\n  protected dlambda: number;\n  protected lambda2: number;\n  protected dlambda2: number;\n  protected epsilon: number;\n  protected distanceFunction: DistanceMetric;\n  protected distance: Coordinates;\n\n  /**\n   * Creates an instance of SPEBase.\n   * @param {Options} [options] Options to pass to the constructor.\n   * @memberof SPEBase\n   */\n  constructor(options?: Options) {\n    this.steps = options?.steps ?? 0;\n    this.cycles = options?.cycles ?? 1e6;\n    // Select a cutoff distance {cutoff} and ...\n    this.cutoff = options?.cutoff ?? 0;\n    // ... an initial learning rate {lambda} > 0\n    this.lambda = options?.lambda ?? 2.0;\n    this.dlambda = options?.dlambda ?? 0.01;\n    this.lambda2 = this.lambda/2.;\n    this.dlambda2 = this.dlambda/2.;\n    this.epsilon = options?.epsilon ?? 1e-10;\n    // eslint-disable-next-line brace-style\n    this.distanceFunction = options?.distance ?? calculateEuclideanDistance;\n    this.distance = [];\n  }\n\n  /**\n   * Initializes distance matrix.\n   *\n   * @protected\n   * @param {Vectors} vectors Input vectors to calculate distance between.\n   * @memberof SPEBase\n   */\n  protected initDistance(vectors: Vectors) {\n    this.distance = calcDistanceMatrix(vectors, this.distanceFunction);\n  }\n\n  /**\n   * Calculates distance between the two vectors given.\n   *\n   * @param {Vectors} vectors Set of vectors to calculate distances between.\n   * @param {number} index1 Index of the first vector of the pair.\n   * @param {number} index2 Index of the second vector of the pair.\n   * @return {number} Distance between these two vectors.\n   */\n  protected calcDistance(vectors: Vectors, index1: number, index2: number): number {\n    return this.distance[index1][index2];\n  }\n\n  /**\n   * Embeds the vectors given into a two-dimensional space.\n   *\n   * @param {Vectors} vectors D-dimensional coordinates.\n   * @return {Coordinates} SPE coordinates in D space.\n   */\n  public embed(vectors: Vectors): Coordinates {\n    const nItems = vectors.length;\n    const areaWidth = 40;\n    // Initialize the D-dimensional coordinates of the N points.\n    const coordinates = fillRandomMatrix(nItems, SPEBase.dimension, areaWidth);\n\n    let lambda2 = this.lambda2;\n\n    if (this.steps == 0) {\n      this.steps = vectors.length-1;\n    }\n\n    this.initDistance(vectors);\n\n    for (let cycle = 0; cycle < this.cycles; ++cycle) {\n      for (let step = 0; step < this.steps; ++step) {\n        // Select two points, i and j, at random, ...\n        const i = randomInt(nItems); let j = randomInt(nItems);\n        while (i == j) j = randomInt(nItems);\n\n        const rowi = coordinates[i]; const rowj = coordinates[j];\n\n        // ... retrieve (or evaluate) their proximity in the input space, rij and ...\n        const r = this.calcDistance(vectors, i, j);\n        // ... compute their Euclidean distance on the D-dimensional map, dij.\n        const d = calculateEuclideanDistance(rowi, rowj);\n\n        // If rij <= rc, or if rij > rc and dij < rij ...\n        if ((this.cutoff == 0) || (r <= this.cutoff) || (d < r)) {\n          const multiplier = lambda2*(r-d)/(d+this.epsilon);\n          // ... update the coordinates xi and xj.\n          const diffIJ = vectorAdd(rowi, rowj, -1);\n          coordinates[i] = vectorAdd(rowi, diffIJ, multiplier);\n          coordinates[j] = vectorAdd(rowj, diffIJ, -multiplier);\n        }\n      }\n      // Decrease the learning rate {lambda} by a prescribed {dlambda}.\n      lambda2 -= this.dlambda2;\n      if (lambda2 <= 0.) {\n        break;\n      }\n    }\n    return coordinates;\n  }\n}\n\n/**\n * Implements modified stochastic proximity embedding.\n *\n * @export\n * @class PSPEBase\n * @link doi:10.1016/S1093-3263(03)00155-4\n */\nexport class PSPEBase extends SPEBase {\n  /**\n   * Embeds the vectors given into a two-dimensional space using a modified update rule.\n   *\n   * @param {Vectors} vectors D-dimensional coordinates.\n   * @return {Coordinates} SPE coordinates in D space.\n   */\n  public embed(vectors: Vectors): Coordinates {\n    const nItems = vectors.length;\n    const areaWidth = 40;\n    //  Initialize the D-dimensional coordinates of the N points.\n    const coordinates = fillRandomMatrix(nItems, PSPEBase.dimension, areaWidth);\n    let lambda = this.lambda;\n\n    this.initDistance(vectors);\n\n    for (let cycle = 0; cycle < this.cycles; ++cycle) {\n      // Select a point, i, at random (pivot).\n      const i: number = randomInt(nItems);\n      const rowi = coordinates[i];\n\n      // For every point j != i ...\n      for (let j = 0; j < nItems; ++j) {\n        if (i == j) continue;\n        const rowj = coordinates[j];\n        // ... retrieve (or evaluate) its proximity to i in the input space, rij ...\n        const r = this.calcDistance(vectors, i, j);\n        // ... and compute their Euclidean distance on the D-dimensional map, dij.\n        const d = calculateEuclideanDistance(rowi, rowj);\n        // If rij <= rc, or if rij > rc and dij < rij ...\n        if ((this.cutoff == 0) || (r <= this.cutoff) || (d < r)) {\n          const multiplier = lambda*(r-d)/(d+this.epsilon);\n          const diffIJ = vectorAdd(rowi, rowj, -1);\n          // ... update the coordinates xj.\n          coordinates[j] = vectorAdd(rowj, diffIJ, -multiplier);\n        }\n      }\n      // Decrease the learning rate {lambda} by a prescribed {dlambda}.\n      lambda -= this.dlambda;\n      if (lambda <= 0.) {\n        break;\n      }\n    }\n    return coordinates;\n  }\n}\n"]} | ||
/** | ||
* Implements modified stochastic proximity embedding. | ||
* | ||
* @export | ||
* @class OriginalSPE | ||
* @link doi:10.1002/jcc.10234 | ||
*/ | ||
export class OriginalSPE extends SPEBase { | ||
constructor(options) { | ||
var _a, _b, _c, _d, _e; | ||
super(options); | ||
this.cycles = (_a = options === null || options === void 0 ? void 0 : options.cycles) !== null && _a !== void 0 ? _a : 1e3; | ||
this.steps = (_b = options === null || options === void 0 ? void 0 : options.steps) !== null && _b !== void 0 ? _b : 100000; | ||
this.radiusPercent = (_c = options === null || options === void 0 ? void 0 : options.radiusPercent) !== null && _c !== void 0 ? _c : 1.0; | ||
this.maxDistance = (_d = options === null || options === void 0 ? void 0 : options.maxDistance) !== null && _d !== void 0 ? _d : null; | ||
this.maxDistanceSteps = (_e = options === null || options === void 0 ? void 0 : options.maxDistanceSteps) !== null && _e !== void 0 ? _e : null; | ||
} | ||
embed(vectors) { | ||
const nItems = vectors.length; | ||
const areaWidth = 40; | ||
// Initialize the D-dimensional coordinates of the N points. | ||
const coordinates = fillRandomMatrix(nItems, OriginalSPE.dimension, areaWidth); | ||
this.initDistance(vectors); | ||
if (this.maxDistanceSteps == null) { | ||
this.maxDistanceSteps = nItems * Math.floor((nItems - 1) / 2); | ||
} | ||
if (this.maxDistance == null) { | ||
this.maxDistance = -1e37; | ||
for (let n = 0; n < this.maxDistanceSteps; n++) { | ||
const i = randomInt(nItems); | ||
let j = randomInt(nItems); | ||
while (i == j) | ||
j = randomInt(nItems); | ||
const d = this.calcDistance(vectors, i, j); | ||
if (d > this.maxDistance) { | ||
this.maxDistance = d; | ||
} | ||
} | ||
} | ||
let lambda = this.lambda; | ||
const radius = (this.radiusPercent == 0.0) ? this.maxDistance : this.maxDistance * this.radiusPercent; | ||
for (let cycle = 0; cycle < this.cycles; ++cycle) { | ||
for (let step = 0; step < this.steps; ++step) { | ||
// Select two points, i and j, at random, ... | ||
const i = randomInt(nItems); | ||
let j = randomInt(nItems); | ||
while (i == j) | ||
j = randomInt(nItems); | ||
const rowi = coordinates[i]; | ||
const rowj = coordinates[j]; | ||
// ... retrieve (or evaluate) their proximity in the input space, rij and ... | ||
const r = this.calcDistance(vectors, i, j); | ||
// ... compute their Euclidean distance on the D-dimensional map, dij. | ||
const d = calculateEuclideanDistance(rowi, rowj); | ||
if ((r <= radius) || (d < r)) { | ||
const multiplier = lambda * 0.5 * (r - d) / (d + this.epsilon); | ||
// ... update the coordinates xi and xj. | ||
const diffIJ = vectorAdd(rowi, rowj, -1); | ||
coordinates[i] = vectorAdd(rowi, diffIJ, multiplier); | ||
coordinates[j] = vectorAdd(rowj, diffIJ, -multiplier); | ||
} | ||
} | ||
lambda -= ((this.lambda - this.dlambda) / (this.cycles - 1.0)); | ||
; | ||
if (lambda < this.dlambda) { | ||
break; | ||
} | ||
} | ||
return coordinates; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spe.js","sourceRoot":"","sources":["spe.ts"],"names":[],"mappings":"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","sourcesContent":["import {Options, Coordinates, Vectors, DistanceMetric} from '@datagrok-libraries/utils/src/type-declarations';\r\nimport {\r\n  calculateEuclideanDistance,\r\n  calcDistanceMatrix,\r\n  fillRandomMatrix,\r\n  vectorAdd,\r\n  randomInt,\r\n} from '@datagrok-libraries/utils/src/operations';\r\n\r\n/**\r\n * Implements stochastic proximity embedding.\r\n *\r\n * @export\r\n * @class SPEBase\r\n * @link doi:10.1016/S1093-3263(03)00155-4\r\n */\r\nexport class SPEBase {\r\n  protected static dimension = 2;\r\n  protected steps: number;\r\n  protected cycles: number;\r\n  protected cutoff: number;\r\n  protected lambda: number;\r\n  protected dlambda: number;\r\n  protected lambda2: number;\r\n  protected dlambda2: number;\r\n  protected epsilon: number;\r\n  protected distanceFunction: DistanceMetric;\r\n  protected distance: Coordinates;\r\n\r\n  /**\r\n   * Creates an instance of SPEBase.\r\n   * @param {Options} [options] Options to pass to the constructor.\r\n   * @memberof SPEBase\r\n   */\r\n  constructor(options?: Options) {\r\n    this.steps = options?.steps ?? 0;\r\n    this.cycles = options?.cycles ?? 1e6;\r\n    // Select a cutoff distance {cutoff} and ...\r\n    this.cutoff = options?.cutoff ?? 0;\r\n    // ... an initial learning rate {lambda} > 0\r\n    this.lambda = options?.lambda ?? 2.0;\r\n    this.dlambda = options?.dlambda ?? 0.01;\r\n    this.lambda2 = this.lambda/2.;\r\n    this.dlambda2 = this.dlambda/2.;\r\n    this.epsilon = options?.epsilon ?? 1e-10;\r\n    // eslint-disable-next-line brace-style\r\n    this.distanceFunction = options?.distance ?? calculateEuclideanDistance;\r\n    this.distance = [];\r\n  }\r\n\r\n  /**\r\n   * Initializes distance matrix.\r\n   *\r\n   * @protected\r\n   * @param {Vectors} vectors Input vectors to calculate distance between.\r\n   * @memberof SPEBase\r\n   */\r\n  protected initDistance(vectors: Vectors) {\r\n    this.distance = calcDistanceMatrix(vectors, this.distanceFunction);\r\n  }\r\n\r\n  /**\r\n   * Calculates distance between the two vectors given.\r\n   *\r\n   * @param {Vectors} vectors Set of vectors to calculate distances between.\r\n   * @param {number} index1 Index of the first vector of the pair.\r\n   * @param {number} index2 Index of the second vector of the pair.\r\n   * @return {number} Distance between these two vectors.\r\n   */\r\n  protected calcDistance(vectors: Vectors, index1: number, index2: number): number {\r\n    return this.distance[index1][index2];\r\n  }\r\n\r\n  /**\r\n   * Embeds the vectors given into a two-dimensional space.\r\n   *\r\n   * @param {Vectors} vectors D-dimensional coordinates.\r\n   * @return {Coordinates} SPE coordinates in D space.\r\n   */\r\n  public embed(vectors: Vectors): Coordinates {\r\n    const nItems = vectors.length;\r\n    const areaWidth = 40;\r\n    // Initialize the D-dimensional coordinates of the N points.\r\n    const coordinates = fillRandomMatrix(nItems, SPEBase.dimension, areaWidth);\r\n\r\n    let lambda2 = this.lambda2;\r\n\r\n    if (this.steps == 0) {\r\n      this.steps = vectors.length-1;\r\n    }\r\n\r\n    this.initDistance(vectors);\r\n\r\n    for (let cycle = 0; cycle < this.cycles; ++cycle) {\r\n      for (let step = 0; step < this.steps; ++step) {\r\n        // Select two points, i and j, at random, ...\r\n        const i = randomInt(nItems); let j = randomInt(nItems);\r\n        while (i == j) j = randomInt(nItems);\r\n\r\n        const rowi = coordinates[i]; const rowj = coordinates[j];\r\n\r\n        // ... retrieve (or evaluate) their proximity in the input space, rij and ...\r\n        const r = this.calcDistance(vectors, i, j);\r\n        // ... compute their Euclidean distance on the D-dimensional map, dij.\r\n        const d = calculateEuclideanDistance(rowi, rowj);\r\n\r\n        // If rij <= rc, or if rij > rc and dij < rij ...\r\n        if ((this.cutoff == 0) || (r <= this.cutoff) || (d < r)) {\r\n          const multiplier = lambda2*(r-d)/(d+this.epsilon);\r\n          // ... update the coordinates xi and xj.\r\n          const diffIJ = vectorAdd(rowi, rowj, -1);\r\n          coordinates[i] = vectorAdd(rowi, diffIJ, multiplier);\r\n          coordinates[j] = vectorAdd(rowj, diffIJ, -multiplier);\r\n        }\r\n      }\r\n      // Decrease the learning rate {lambda} by a prescribed {dlambda}.\r\n      lambda2 -= this.dlambda2;\r\n      if (lambda2 <= 0.) {\r\n        break;\r\n      }\r\n    }\r\n    return coordinates;\r\n  }\r\n}\r\n\r\n/**\r\n * Implements modified stochastic proximity embedding.\r\n *\r\n * @export\r\n * @class PSPEBase\r\n * @link doi:10.1016/S1093-3263(03)00155-4\r\n */\r\nexport class PSPEBase extends SPEBase {\r\n  /**\r\n   * Embeds the vectors given into a two-dimensional space using a modified update rule.\r\n   *\r\n   * @param {Vectors} vectors D-dimensional coordinates.\r\n   * @return {Coordinates} SPE coordinates in D space.\r\n   */\r\n  public embed(vectors: Vectors): Coordinates {\r\n    const nItems = vectors.length;\r\n    const areaWidth = 40;\r\n    //  Initialize the D-dimensional coordinates of the N points.\r\n    const coordinates = fillRandomMatrix(nItems, PSPEBase.dimension, areaWidth);\r\n    let lambda = this.lambda;\r\n\r\n    this.initDistance(vectors);\r\n\r\n    for (let cycle = 0; cycle < this.cycles; ++cycle) {\r\n      // Select a point, i, at random (pivot).\r\n      const i: number = randomInt(nItems);\r\n      const rowi = coordinates[i];\r\n\r\n      // For every point j != i ...\r\n      for (let j = 0; j < nItems; ++j) {\r\n        if (i == j) continue;\r\n        const rowj = coordinates[j];\r\n        // ... retrieve (or evaluate) its proximity to i in the input space, rij ...\r\n        const r = this.calcDistance(vectors, i, j);\r\n        // ... and compute their Euclidean distance on the D-dimensional map, dij.\r\n        const d = calculateEuclideanDistance(rowi, rowj);\r\n        // If rij <= rc, or if rij > rc and dij < rij ...\r\n        if ((this.cutoff == 0) || (r <= this.cutoff) || (d < r)) {\r\n          const multiplier = lambda*(r-d)/(d+this.epsilon);\r\n          const diffIJ = vectorAdd(rowi, rowj, -1);\r\n          // ... update the coordinates xj.\r\n          coordinates[j] = vectorAdd(rowj, diffIJ, -multiplier);\r\n        }\r\n      }\r\n      // Decrease the learning rate {lambda} by a prescribed {dlambda}.\r\n      lambda -= this.dlambda;\r\n      if (lambda <= 0.) {\r\n        break;\r\n      }\r\n    }\r\n    return coordinates;\r\n  }\r\n}\r\n\r\n/**\r\n * Implements modified stochastic proximity embedding.\r\n *\r\n * @export\r\n * @class OriginalSPE\r\n * @link doi:10.1002/jcc.10234\r\n */\r\nexport class OriginalSPE extends SPEBase {\r\n  /**\r\n   * Embeds the vectors given into a two-dimensional space using a modified update rule.\r\n   *\r\n   * @param {Vectors} vectors D-dimensional coordinates.\r\n   * @return {Coordinates} SPE coordinates in D space.\r\n   */\r\n  protected radiusPercent: number;\r\n  protected maxDistance: number;\r\n  protected maxDistanceSteps: number;\r\n\r\n  constructor(options?: Options) {\r\n    super(options);\r\n    this.cycles = options?.cycles ?? 1e3;\r\n    this.steps = options?.steps ?? 100000;\r\n    this.radiusPercent = options?.radiusPercent ?? 1.0;\r\n    this.maxDistance = options?.maxDistance ?? null;\r\n    this.maxDistanceSteps = options?.maxDistanceSteps ?? null;\r\n  }\r\n\r\n  public embed(vectors: Vectors): Coordinates {\r\n    const nItems = vectors.length;\r\n    const areaWidth = 40;\r\n    // Initialize the D-dimensional coordinates of the N points.\r\n    const coordinates = fillRandomMatrix(nItems, OriginalSPE.dimension, areaWidth);\r\n\r\n    this.initDistance(vectors);\r\n\r\n    if (this.maxDistanceSteps == null) {\r\n      this.maxDistanceSteps = nItems * Math.floor((nItems - 1) / 2);\r\n    }\r\n    if (this.maxDistance == null) {\r\n      this.maxDistance = -1e37;\r\n      for (let n = 0; n < this.maxDistanceSteps; n++) {\r\n        const i = randomInt(nItems); let j = randomInt(nItems);\r\n        while (i == j) j = randomInt(nItems);\r\n\r\n        const d = this.calcDistance(vectors, i, j);\r\n        if (d > this.maxDistance) {\r\n          this.maxDistance = d;\r\n        }\r\n      }\r\n    }\r\n\r\n    let lambda = this.lambda;\r\n    const radius = (this.radiusPercent == 0.0) ? this.maxDistance : this.maxDistance * this.radiusPercent;\r\n\r\n    for (let cycle = 0; cycle < this.cycles; ++cycle) {\r\n      for (let step = 0; step < this.steps; ++step) {\r\n        // Select two points, i and j, at random, ...\r\n        const i = randomInt(nItems); let j = randomInt(nItems);\r\n        while (i == j) j = randomInt(nItems);\r\n\r\n        const rowi = coordinates[i]; const rowj = coordinates[j];\r\n\r\n        // ... retrieve (or evaluate) their proximity in the input space, rij and ...\r\n        const r = this.calcDistance(vectors, i, j);\r\n        // ... compute their Euclidean distance on the D-dimensional map, dij.\r\n        const d = calculateEuclideanDistance(rowi, rowj);\r\n\r\n        if ((r <= radius) || (d < r)) {\r\n          const multiplier = lambda * 0.5 * (r - d) / (d + this.epsilon);\r\n          // ... update the coordinates xi and xj.\r\n          const diffIJ = vectorAdd(rowi, rowj, -1);\r\n          coordinates[i] = vectorAdd(rowi, diffIJ, multiplier);\r\n          coordinates[j] = vectorAdd(rowj, diffIJ, -multiplier);\r\n        }\r\n      }\r\n      lambda -= ((this.lambda - this.dlambda) / (this.cycles - 1.0)); ;\r\n      if (lambda < this.dlambda) {\r\n        break;\r\n      }\r\n    }\r\n    return coordinates;\r\n  }\r\n}\r\n"]} |
@@ -5,2 +5,5 @@ import { DistanceMetric } from '@datagrok-libraries/utils/src/type-declarations'; | ||
}; | ||
export declare const MetricDataTypes: { | ||
[name: string]: string[]; | ||
}; | ||
export declare type KnownMetrics = keyof typeof AvailableMetrics; | ||
@@ -21,2 +24,7 @@ /** Unified class implementing different string measures. */ | ||
getMeasure(): DistanceMetric; | ||
/** | ||
* Returns custom string distance function specified. | ||
* @return {string[]} Callback of the measure chosen. | ||
*/ | ||
static getMetricByDataType(dataType: string): string[]; | ||
/** Returns metric names available. */ | ||
@@ -23,0 +31,0 @@ static get availableMeasures(): string[]; |
import * as fl from 'fastest-levenshtein'; | ||
import { jaroWinkler } from 'jaro-winkler-typescript'; | ||
import { similarityMetric } from '@datagrok-libraries/utils/src/similarity-metrics'; | ||
import { calculateEuclideanDistance } from '@datagrok-libraries/utils/src/operations'; | ||
export const AvailableMetrics = { | ||
'EuclideanDistance': calculateEuclideanDistance, | ||
'Levenshtein': fl.distance, | ||
'Jaro-Winkler': jaroWinkler, | ||
'Tanimoto': similarityMetric['Tanimoto'], | ||
'Dice': similarityMetric['Dice'], | ||
'Asymmetric': similarityMetric['Asymmetric'], | ||
'Braun-Blanquet': similarityMetric['Braun-Blanquet'], | ||
'Cosine': similarityMetric['Cosine'], | ||
'Kulczynski': similarityMetric['Kulczynski'], | ||
'Mc-Connaughey': similarityMetric['Mc-Connaughey'], | ||
'Rogot-Goldberg': similarityMetric['Rogot-Goldberg'], | ||
'Russel': similarityMetric['Russel'], | ||
'Sokal': similarityMetric['Sokal'], | ||
}; | ||
export const MetricDataTypes = { | ||
'String': ['Levenshtein', 'Jaro-Winkler'], | ||
'BitArray': Object.keys(similarityMetric), | ||
'Vector': ['EuclideanDistance'], | ||
'Number': [], | ||
'Object': [], | ||
}; | ||
/** Unified class implementing different string measures. */ | ||
@@ -24,2 +44,9 @@ export class StringMeasure { | ||
} | ||
/** | ||
* Returns custom string distance function specified. | ||
* @return {string[]} Callback of the measure chosen. | ||
*/ | ||
static getMetricByDataType(dataType) { | ||
return MetricDataTypes[dataType]; | ||
} | ||
/** Returns metric names available. */ | ||
@@ -30,2 +57,2 @@ static get availableMeasures() { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaW5nLW1lYXN1cmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzdHJpbmctbWVhc3VyZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFDLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUlwRCxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBcUM7SUFDaEUsYUFBYSxFQUFFLEVBQUUsQ0FBQyxRQUFRO0lBQzFCLGNBQWMsRUFBRSxXQUFXO0NBQzVCLENBQUM7QUFJRiw0REFBNEQ7QUFDNUQsTUFBTSxPQUFPLGFBQWE7SUFHeEI7Ozs7T0FJRztJQUNILFlBQVksTUFBb0I7UUFDOUIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFnQixDQUFDO0lBQ2pDLENBQUM7SUFFRDs7O09BR0c7SUFDSSxVQUFVO1FBQ2YsT0FBTyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVELHNDQUFzQztJQUN0QyxNQUFNLEtBQUssaUJBQWlCO1FBQzFCLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZsIGZyb20gJ2Zhc3Rlc3QtbGV2ZW5zaHRlaW4nO1xuaW1wb3J0IHtqYXJvV2lua2xlcn0gZnJvbSAnamFyby13aW5rbGVyLXR5cGVzY3JpcHQnO1xuXG5pbXBvcnQge0Rpc3RhbmNlTWV0cmljfSBmcm9tICdAZGF0YWdyb2stbGlicmFyaWVzL3V0aWxzL3NyYy90eXBlLWRlY2xhcmF0aW9ucyc7XG5cbmV4cG9ydCBjb25zdCBBdmFpbGFibGVNZXRyaWNzOiB7W25hbWU6IHN0cmluZ106IERpc3RhbmNlTWV0cmljfSA9IHtcbiAgJ0xldmVuc2h0ZWluJzogZmwuZGlzdGFuY2UsXG4gICdKYXJvLVdpbmtsZXInOiBqYXJvV2lua2xlcixcbn07XG5cbmV4cG9ydCB0eXBlIEtub3duTWV0cmljcyA9IGtleW9mIHR5cGVvZiBBdmFpbGFibGVNZXRyaWNzO1xuXG4vKiogVW5pZmllZCBjbGFzcyBpbXBsZW1lbnRpbmcgZGlmZmVyZW50IHN0cmluZyBtZWFzdXJlcy4gKi9cbmV4cG9ydCBjbGFzcyBTdHJpbmdNZWFzdXJlIHtcbiAgcHJvdGVjdGVkIG1ldGhvZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGFuIGluc3RhbmNlIG9mIFN0cmluZ01lYXN1cmUgd2l0aCAuXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBtZXRob2QgTWV0aG9kIHRvIGNhbGN1bGF0ZSBkaXN0YW5jZSBiZXR3ZWVuIHN0cmluZ3MuXG4gICAqIEBtZW1iZXJvZiBNZWFzdXJlclxuICAgKi9cbiAgY29uc3RydWN0b3IobWV0aG9kOiBLbm93bk1ldHJpY3MpIHtcbiAgICB0aGlzLm1ldGhvZCA9IG1ldGhvZCBhcyBzdHJpbmc7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBjdXN0b20gc3RyaW5nIGRpc3RhbmNlIGZ1bmN0aW9uIHNwZWNpZmllZC5cbiAgICogQHJldHVybiB7RGlzdGFuY2VNZXRyaWN9IENhbGxiYWNrIG9mIHRoZSBtZWFzdXJlIGNob3Nlbi5cbiAgICovXG4gIHB1YmxpYyBnZXRNZWFzdXJlKCk6IERpc3RhbmNlTWV0cmljIHtcbiAgICByZXR1cm4gQXZhaWxhYmxlTWV0cmljc1t0aGlzLm1ldGhvZF07XG4gIH1cblxuICAvKiogUmV0dXJucyBtZXRyaWMgbmFtZXMgYXZhaWxhYmxlLiAqL1xuICBzdGF0aWMgZ2V0IGF2YWlsYWJsZU1lYXN1cmVzKCk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gT2JqZWN0LmtleXMoQXZhaWxhYmxlTWV0cmljcyk7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaW5nLW1lYXN1cmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzdHJpbmctbWVhc3VyZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFDLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUdwRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxrREFBa0QsQ0FBQztBQUNsRixPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUVwRixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBcUM7SUFDaEUsbUJBQW1CLEVBQUUsMEJBQTBCO0lBQy9DLGFBQWEsRUFBRSxFQUFFLENBQUMsUUFBUTtJQUMxQixjQUFjLEVBQUUsV0FBVztJQUMzQixVQUFVLEVBQUUsZ0JBQWdCLENBQUMsVUFBVSxDQUFDO0lBQ3hDLE1BQU0sRUFBRSxnQkFBZ0IsQ0FBQyxNQUFNLENBQUM7SUFDaEMsWUFBWSxFQUFFLGdCQUFnQixDQUFDLFlBQVksQ0FBQztJQUM1QyxnQkFBZ0IsRUFBRSxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQztJQUNwRCxRQUFRLEVBQUUsZ0JBQWdCLENBQUMsUUFBUSxDQUFDO0lBQ3BDLFlBQVksRUFBRSxnQkFBZ0IsQ0FBQyxZQUFZLENBQUM7SUFDNUMsZUFBZSxFQUFFLGdCQUFnQixDQUFDLGVBQWUsQ0FBQztJQUNsRCxnQkFBZ0IsRUFBRSxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQztJQUNwRCxRQUFRLEVBQUUsZ0JBQWdCLENBQUMsUUFBUSxDQUFDO0lBQ3BDLE9BQU8sRUFBRSxnQkFBZ0IsQ0FBQyxPQUFPLENBQUM7Q0FDbkMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBK0I7SUFDekQsUUFBUSxFQUFFLENBQUMsYUFBYSxFQUFFLGNBQWMsQ0FBQztJQUN6QyxVQUFVLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUN6QyxRQUFRLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztJQUMvQixRQUFRLEVBQUUsRUFBRTtJQUNaLFFBQVEsRUFBRSxFQUFFO0NBQ2IsQ0FBQztBQUlGLDREQUE0RDtBQUM1RCxNQUFNLE9BQU8sYUFBYTtJQUd4Qjs7OztPQUlHO0lBQ0gsWUFBWSxNQUFvQjtRQUM5QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQWdCLENBQUM7SUFDakMsQ0FBQztJQUVEOzs7T0FHRztJQUNJLFVBQVU7UUFDZixPQUFPLGdCQUFnQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksTUFBTSxDQUFDLG1CQUFtQixDQUFDLFFBQWdCO1FBQ2hELE9BQU8sZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ25DLENBQUM7SUFFRCxzQ0FBc0M7SUFDdEMsTUFBTSxLQUFLLGlCQUFpQjtRQUMxQixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUN2QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBmbCBmcm9tICdmYXN0ZXN0LWxldmVuc2h0ZWluJztcclxuaW1wb3J0IHtqYXJvV2lua2xlcn0gZnJvbSAnamFyby13aW5rbGVyLXR5cGVzY3JpcHQnO1xyXG5cclxuaW1wb3J0IHtEaXN0YW5jZU1ldHJpY30gZnJvbSAnQGRhdGFncm9rLWxpYnJhcmllcy91dGlscy9zcmMvdHlwZS1kZWNsYXJhdGlvbnMnO1xyXG5pbXBvcnQge3NpbWlsYXJpdHlNZXRyaWN9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL3NpbWlsYXJpdHktbWV0cmljcyc7XHJcbmltcG9ydCB7Y2FsY3VsYXRlRXVjbGlkZWFuRGlzdGFuY2V9IGZyb20gJ0BkYXRhZ3Jvay1saWJyYXJpZXMvdXRpbHMvc3JjL29wZXJhdGlvbnMnO1xyXG5cclxuZXhwb3J0IGNvbnN0IEF2YWlsYWJsZU1ldHJpY3M6IHtbbmFtZTogc3RyaW5nXTogRGlzdGFuY2VNZXRyaWN9ID0ge1xyXG4gICdFdWNsaWRlYW5EaXN0YW5jZSc6IGNhbGN1bGF0ZUV1Y2xpZGVhbkRpc3RhbmNlLFxyXG4gICdMZXZlbnNodGVpbic6IGZsLmRpc3RhbmNlLFxyXG4gICdKYXJvLVdpbmtsZXInOiBqYXJvV2lua2xlcixcclxuICAnVGFuaW1vdG8nOiBzaW1pbGFyaXR5TWV0cmljWydUYW5pbW90byddLFxyXG4gICdEaWNlJzogc2ltaWxhcml0eU1ldHJpY1snRGljZSddLFxyXG4gICdBc3ltbWV0cmljJzogc2ltaWxhcml0eU1ldHJpY1snQXN5bW1ldHJpYyddLFxyXG4gICdCcmF1bi1CbGFucXVldCc6IHNpbWlsYXJpdHlNZXRyaWNbJ0JyYXVuLUJsYW5xdWV0J10sXHJcbiAgJ0Nvc2luZSc6IHNpbWlsYXJpdHlNZXRyaWNbJ0Nvc2luZSddLFxyXG4gICdLdWxjenluc2tpJzogc2ltaWxhcml0eU1ldHJpY1snS3VsY3p5bnNraSddLFxyXG4gICdNYy1Db25uYXVnaGV5Jzogc2ltaWxhcml0eU1ldHJpY1snTWMtQ29ubmF1Z2hleSddLFxyXG4gICdSb2dvdC1Hb2xkYmVyZyc6IHNpbWlsYXJpdHlNZXRyaWNbJ1JvZ290LUdvbGRiZXJnJ10sXHJcbiAgJ1J1c3NlbCc6IHNpbWlsYXJpdHlNZXRyaWNbJ1J1c3NlbCddLFxyXG4gICdTb2thbCc6IHNpbWlsYXJpdHlNZXRyaWNbJ1Nva2FsJ10sXHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgTWV0cmljRGF0YVR5cGVzOiB7W25hbWU6IHN0cmluZ106IHN0cmluZ1tdfSA9IHtcclxuICAnU3RyaW5nJzogWydMZXZlbnNodGVpbicsICdKYXJvLVdpbmtsZXInXSxcclxuICAnQml0QXJyYXknOiBPYmplY3Qua2V5cyhzaW1pbGFyaXR5TWV0cmljKSxcclxuICAnVmVjdG9yJzogWydFdWNsaWRlYW5EaXN0YW5jZSddLFxyXG4gICdOdW1iZXInOiBbXSxcclxuICAnT2JqZWN0JzogW10sXHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBLbm93bk1ldHJpY3MgPSBrZXlvZiB0eXBlb2YgQXZhaWxhYmxlTWV0cmljcztcclxuXHJcbi8qKiBVbmlmaWVkIGNsYXNzIGltcGxlbWVudGluZyBkaWZmZXJlbnQgc3RyaW5nIG1lYXN1cmVzLiAqL1xyXG5leHBvcnQgY2xhc3MgU3RyaW5nTWVhc3VyZSB7XHJcbiAgcHJvdGVjdGVkIG1ldGhvZDogc3RyaW5nO1xyXG5cclxuICAvKipcclxuICAgKiBDcmVhdGVzIGFuIGluc3RhbmNlIG9mIFN0cmluZ01lYXN1cmUgd2l0aCAuXHJcbiAgICogQHBhcmFtIHtzdHJpbmd9IG1ldGhvZCBNZXRob2QgdG8gY2FsY3VsYXRlIGRpc3RhbmNlIGJldHdlZW4gc3RyaW5ncy5cclxuICAgKiBAbWVtYmVyb2YgTWVhc3VyZXJcclxuICAgKi9cclxuICBjb25zdHJ1Y3RvcihtZXRob2Q6IEtub3duTWV0cmljcykge1xyXG4gICAgdGhpcy5tZXRob2QgPSBtZXRob2QgYXMgc3RyaW5nO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyBjdXN0b20gc3RyaW5nIGRpc3RhbmNlIGZ1bmN0aW9uIHNwZWNpZmllZC5cclxuICAgKiBAcmV0dXJuIHtEaXN0YW5jZU1ldHJpY30gQ2FsbGJhY2sgb2YgdGhlIG1lYXN1cmUgY2hvc2VuLlxyXG4gICAqL1xyXG4gIHB1YmxpYyBnZXRNZWFzdXJlKCk6IERpc3RhbmNlTWV0cmljIHtcclxuICAgIHJldHVybiBBdmFpbGFibGVNZXRyaWNzW3RoaXMubWV0aG9kXTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgY3VzdG9tIHN0cmluZyBkaXN0YW5jZSBmdW5jdGlvbiBzcGVjaWZpZWQuXHJcbiAgICogQHJldHVybiB7c3RyaW5nW119IENhbGxiYWNrIG9mIHRoZSBtZWFzdXJlIGNob3Nlbi5cclxuICAgKi9cclxuICBwdWJsaWMgc3RhdGljIGdldE1ldHJpY0J5RGF0YVR5cGUoZGF0YVR5cGU6IHN0cmluZyk6IHN0cmluZ1tdIHtcclxuICAgIHJldHVybiBNZXRyaWNEYXRhVHlwZXNbZGF0YVR5cGVdO1xyXG4gIH1cclxuXHJcbiAgLyoqIFJldHVybnMgbWV0cmljIG5hbWVzIGF2YWlsYWJsZS4gKi9cclxuICBzdGF0aWMgZ2V0IGF2YWlsYWJsZU1lYXN1cmVzKCk6IHN0cmluZ1tdIHtcclxuICAgIHJldHVybiBPYmplY3Qua2V5cyhBdmFpbGFibGVNZXRyaWNzKTtcclxuICB9XHJcbn1cclxuIl19 |
export {}; | ||
//# sourceMappingURL=dimensionality-reducer.d.ts.map |
@@ -21,2 +21,2 @@ import { DimensionalityReducer } from '../reduce-dimensionality'; | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltZW5zaW9uYWxpdHktcmVkdWNlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImRpbWVuc2lvbmFsaXR5LXJlZHVjZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHFCQUFxQixFQUFlLE1BQU0sMEJBQTBCLENBQUM7QUFFN0U7Ozs7Ozs7O0dBUUc7QUFDSCxTQUFTLFNBQVMsQ0FBQyxVQUFjLEVBQUUsTUFBb0IsRUFBRSxPQUFnQixFQUFFLFdBQW9CO0lBQzdGLE1BQU0sT0FBTyxHQUFHLElBQUkscUJBQXFCLENBQ3ZDLFVBQVUsRUFDVixNQUFNLEVBQ04sT0FBTyxFQUNQLFdBQVcsQ0FBQyxDQUFDLENBQUMsRUFBQyxNQUFNLEVBQUUsV0FBVyxFQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FDaEQsQ0FBQztJQUNGLE9BQU8sT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUNqQyxDQUFDO0FBRUQsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLEVBQUMsSUFBSSxFQUFFLEVBQUMsVUFBVSxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFDLEVBQUMsRUFBRSxFQUFFO0lBQ3RFLE1BQU0sU0FBUyxHQUFHLFNBQVMsQ0FBQyxVQUFVLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxXQUFXLENBQUMsQ0FBQztJQUN0RSxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQ2YsU0FBUyxFQUFFLFNBQVM7S0FDckIsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaW1lbnNpb25hbGl0eVJlZHVjZXIsIEtub3duTWV0aG9kc30gZnJvbSAnLi4vcmVkdWNlLWRpbWVuc2lvbmFsaXR5JztcblxuLyoqXG4gKiBXb3JrZXIgdGhyZWFkIHJlY2VpdmluZyBkYXRhIGZ1bmN0aW9uLlxuICpcbiAqIEBwYXJhbSB7YW55W119IGNvbHVtbkRhdGEgU2FtcGxlcyB0byBwcm9jZXNzLlxuICogQHBhcmFtIHtzdHJpbmd9IG1ldGhvZCBFbWJlZGRpbmcgbWV0aG9kLlxuICogQHBhcmFtIHtzdHJpbmd9IG1lYXN1cmUgRGlzdGFuY2UgbWV0cmljLlxuICogQHBhcmFtIHtudW1iZXJ9IGN5Y2xlc0NvdW50IE51bWJlciBvZiBjeWNsZXMgdG8gcmVwZWF0LlxuICogQHJldHVybiB7Q29vcmRpbmF0ZXN9IEVtYmVkZGluZy5cbiAqL1xuZnVuY3Rpb24gb25NZXNzYWdlKGNvbHVtbkRhdGE6IFtdLCBtZXRob2Q6IEtub3duTWV0aG9kcywgbWVhc3VyZT86IHN0cmluZywgY3ljbGVzQ291bnQ/OiBudW1iZXIpIHtcbiAgY29uc3QgcmVkdWNlciA9IG5ldyBEaW1lbnNpb25hbGl0eVJlZHVjZXIoXG4gICAgY29sdW1uRGF0YSxcbiAgICBtZXRob2QsXG4gICAgbWVhc3VyZSxcbiAgICBjeWNsZXNDb3VudCA/IHtjeWNsZXM6IGN5Y2xlc0NvdW50fSA6IHVuZGVmaW5lZCxcbiAgKTtcbiAgcmV0dXJuIHJlZHVjZXIudHJhbnNmb3JtKHRydWUpO1xufVxuXG5zZWxmLm9ubWVzc2FnZSA9ICh7ZGF0YToge2NvbHVtbkRhdGEsIG1ldGhvZCwgbWVhc3VyZSwgY3ljbGVzQ291bnR9fSkgPT4ge1xuICBjb25zdCBlbWJlZGRpbmcgPSBvbk1lc3NhZ2UoY29sdW1uRGF0YSwgbWV0aG9kLCBtZWFzdXJlLCBjeWNsZXNDb3VudCk7XG4gIHNlbGYucG9zdE1lc3NhZ2Uoe1xuICAgIGVtYmVkZGluZzogZW1iZWRkaW5nLFxuICB9KTtcbn07XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltZW5zaW9uYWxpdHktcmVkdWNlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImRpbWVuc2lvbmFsaXR5LXJlZHVjZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHFCQUFxQixFQUFlLE1BQU0sMEJBQTBCLENBQUM7QUFFN0U7Ozs7Ozs7O0dBUUc7QUFDSCxTQUFTLFNBQVMsQ0FBQyxVQUFpQixFQUFFLE1BQW9CLEVBQUUsT0FBZ0IsRUFBRSxXQUFvQjtJQUNoRyxNQUFNLE9BQU8sR0FBRyxJQUFJLHFCQUFxQixDQUN2QyxVQUFVLEVBQ1YsTUFBTSxFQUNOLE9BQU8sRUFDUCxXQUFXLENBQUMsQ0FBQyxDQUFDLEVBQUMsTUFBTSxFQUFFLFdBQVcsRUFBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQ2hELENBQUM7SUFDRixPQUFPLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7QUFDakMsQ0FBQztBQUVELElBQUksQ0FBQyxTQUFTLEdBQUcsQ0FBQyxFQUFDLElBQUksRUFBRSxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBQyxFQUFDLEVBQUUsRUFBRTtJQUN0RSxNQUFNLFNBQVMsR0FBRyxTQUFTLENBQUMsVUFBVSxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDdEUsSUFBSSxDQUFDLFdBQVcsQ0FBQztRQUNmLFNBQVMsRUFBRSxTQUFTO0tBQ3JCLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGltZW5zaW9uYWxpdHlSZWR1Y2VyLCBLbm93bk1ldGhvZHN9IGZyb20gJy4uL3JlZHVjZS1kaW1lbnNpb25hbGl0eSc7XHJcblxyXG4vKipcclxuICogV29ya2VyIHRocmVhZCByZWNlaXZpbmcgZGF0YSBmdW5jdGlvbi5cclxuICpcclxuICogQHBhcmFtIHthbnlbXX0gY29sdW1uRGF0YSBTYW1wbGVzIHRvIHByb2Nlc3MuXHJcbiAqIEBwYXJhbSB7c3RyaW5nfSBtZXRob2QgRW1iZWRkaW5nIG1ldGhvZC5cclxuICogQHBhcmFtIHtzdHJpbmd9IG1lYXN1cmUgRGlzdGFuY2UgbWV0cmljLlxyXG4gKiBAcGFyYW0ge251bWJlcn0gY3ljbGVzQ291bnQgTnVtYmVyIG9mIGN5Y2xlcyB0byByZXBlYXQuXHJcbiAqIEByZXR1cm4ge0Nvb3JkaW5hdGVzfSBFbWJlZGRpbmcuXHJcbiAqL1xyXG5mdW5jdGlvbiBvbk1lc3NhZ2UoY29sdW1uRGF0YTogYW55W10sIG1ldGhvZDogS25vd25NZXRob2RzLCBtZWFzdXJlPzogc3RyaW5nLCBjeWNsZXNDb3VudD86IG51bWJlcikge1xyXG4gIGNvbnN0IHJlZHVjZXIgPSBuZXcgRGltZW5zaW9uYWxpdHlSZWR1Y2VyKFxyXG4gICAgY29sdW1uRGF0YSxcclxuICAgIG1ldGhvZCxcclxuICAgIG1lYXN1cmUsXHJcbiAgICBjeWNsZXNDb3VudCA/IHtjeWNsZXM6IGN5Y2xlc0NvdW50fSA6IHVuZGVmaW5lZCxcclxuICApO1xyXG4gIHJldHVybiByZWR1Y2VyLnRyYW5zZm9ybSh0cnVlKTtcclxufVxyXG5cclxuc2VsZi5vbm1lc3NhZ2UgPSAoe2RhdGE6IHtjb2x1bW5EYXRhLCBtZXRob2QsIG1lYXN1cmUsIGN5Y2xlc0NvdW50fX0pID0+IHtcclxuICBjb25zdCBlbWJlZGRpbmcgPSBvbk1lc3NhZ2UoY29sdW1uRGF0YSwgbWV0aG9kLCBtZWFzdXJlLCBjeWNsZXNDb3VudCk7XHJcbiAgc2VsZi5wb3N0TWVzc2FnZSh7XHJcbiAgICBlbWJlZGRpbmc6IGVtYmVkZGluZyxcclxuICB9KTtcclxufTtcclxuIl19 |
@@ -0,0 +0,0 @@ /** |
@@ -24,2 +24,2 @@ /** | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltZW5zaW9uYWxpdHktcmVkdWNpbmctd29ya2VyLWNyZWF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJkaW1lbnNpb25hbGl0eS1yZWR1Y2luZy13b3JrZXItY3JlYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7R0FRRztBQUNILE1BQU0sVUFBVSxpQ0FBaUMsQ0FDL0MsVUFBaUIsRUFDakIsTUFBYyxFQUNkLE9BQWdCLEVBQ2hCLFdBQW9CO0lBRXBCLE9BQU8sSUFBSSxPQUFPLENBQUMsVUFBUyxPQUFPO1FBQ2pDLE1BQU0sTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksR0FBRyxDQUFDLDBCQUEwQixFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNoRixNQUFNLENBQUMsV0FBVyxDQUFDO1lBQ2pCLFVBQVUsRUFBRSxVQUFVO1lBQ3RCLE1BQU0sRUFBRSxNQUFNO1lBQ2QsT0FBTyxFQUFFLE9BQU87WUFDaEIsV0FBVyxFQUFFLFdBQVc7U0FDekIsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxDQUFDLFNBQVMsR0FBRyxDQUFDLEVBQUMsSUFBSSxFQUFFLEVBQUMsU0FBUyxFQUFDLEVBQUMsRUFBRSxFQUFFO1lBQ3pDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNyQixDQUFDLENBQUM7SUFDSixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEEgd29ya2VyIHRvIHBlcmZvcm0gZGltZW5zaW9uYWxpdHkgcmVkdWN0aW9uLlxuICpcbiAqIEBwYXJhbSB7YW55W119IGNvbHVtbkRhdGEgVGhlIGRhdGEgdG8gcHJvY2Vzcy5cbiAqIEBwYXJhbSB7c3RyaW5nfSBtZXRob2QgQSBtZXRob2Qgb2YgZGltZW5zaW9uYWxpdHkgcmVkdWN0aW9uLlxuICogQHBhcmFtIHtzdHJpbmd9IG1lYXN1cmUgQSBkaXN0YW5jZSBtZXRyaWNzLlxuICogQHBhcmFtIHtudW1iZXJ9IGN5Y2xlc0NvdW50IE51bWJlciBvZiBpdGVyYXRpb25zIHRvIHJ1bi5cbiAqIEByZXR1cm4ge1Byb21pc2U8dW5rbm93bj59IFJlc3VsdGluZyBlbWJlZGRpbmcuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVEaW1lbnNpbmFsaXR5UmVkdWNpbmdXb3JrZXIoXG4gIGNvbHVtbkRhdGE6IGFueVtdLFxuICBtZXRob2Q6IHN0cmluZyxcbiAgbWVhc3VyZT86IHN0cmluZyxcbiAgY3ljbGVzQ291bnQ/OiBudW1iZXIsXG4pOiBQcm9taXNlPHVua25vd24+IHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKGZ1bmN0aW9uKHJlc29sdmUpIHtcbiAgICBjb25zdCB3b3JrZXIgPSBuZXcgV29ya2VyKG5ldyBVUkwoJy4vZGltZW5zaW9uYWxpdHktcmVkdWNlcicsIGltcG9ydC5tZXRhLnVybCkpO1xuICAgIHdvcmtlci5wb3N0TWVzc2FnZSh7XG4gICAgICBjb2x1bW5EYXRhOiBjb2x1bW5EYXRhLFxuICAgICAgbWV0aG9kOiBtZXRob2QsXG4gICAgICBtZWFzdXJlOiBtZWFzdXJlLFxuICAgICAgY3ljbGVzQ291bnQ6IGN5Y2xlc0NvdW50LFxuICAgIH0pO1xuICAgIHdvcmtlci5vbm1lc3NhZ2UgPSAoe2RhdGE6IHtlbWJlZGRpbmd9fSkgPT4ge1xuICAgICAgcmVzb2x2ZShlbWJlZGRpbmcpO1xuICAgIH07XG4gIH0pO1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltZW5zaW9uYWxpdHktcmVkdWNpbmctd29ya2VyLWNyZWF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJkaW1lbnNpb25hbGl0eS1yZWR1Y2luZy13b3JrZXItY3JlYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7R0FRRztBQUNILE1BQU0sVUFBVSxpQ0FBaUMsQ0FDL0MsVUFBaUIsRUFDakIsTUFBYyxFQUNkLE9BQWdCLEVBQ2hCLFdBQW9CO0lBRXBCLE9BQU8sSUFBSSxPQUFPLENBQUMsVUFBUyxPQUFPO1FBQ2pDLE1BQU0sTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksR0FBRyxDQUFDLDBCQUEwQixFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNoRixNQUFNLENBQUMsV0FBVyxDQUFDO1lBQ2pCLFVBQVUsRUFBRSxVQUFVO1lBQ3RCLE1BQU0sRUFBRSxNQUFNO1lBQ2QsT0FBTyxFQUFFLE9BQU87WUFDaEIsV0FBVyxFQUFFLFdBQVc7U0FDekIsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxDQUFDLFNBQVMsR0FBRyxDQUFDLEVBQUMsSUFBSSxFQUFFLEVBQUMsU0FBUyxFQUFDLEVBQUMsRUFBRSxFQUFFO1lBQ3pDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNyQixDQUFDLENBQUM7SUFDSixDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogQSB3b3JrZXIgdG8gcGVyZm9ybSBkaW1lbnNpb25hbGl0eSByZWR1Y3Rpb24uXHJcbiAqXHJcbiAqIEBwYXJhbSB7YW55W119IGNvbHVtbkRhdGEgVGhlIGRhdGEgdG8gcHJvY2Vzcy5cclxuICogQHBhcmFtIHtzdHJpbmd9IG1ldGhvZCBBIG1ldGhvZCBvZiBkaW1lbnNpb25hbGl0eSByZWR1Y3Rpb24uXHJcbiAqIEBwYXJhbSB7c3RyaW5nfSBtZWFzdXJlIEEgZGlzdGFuY2UgbWV0cmljcy5cclxuICogQHBhcmFtIHtudW1iZXJ9IGN5Y2xlc0NvdW50IE51bWJlciBvZiBpdGVyYXRpb25zIHRvIHJ1bi5cclxuICogQHJldHVybiB7UHJvbWlzZTx1bmtub3duPn0gUmVzdWx0aW5nIGVtYmVkZGluZy5cclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVEaW1lbnNpbmFsaXR5UmVkdWNpbmdXb3JrZXIoXHJcbiAgY29sdW1uRGF0YTogYW55W10sXHJcbiAgbWV0aG9kOiBzdHJpbmcsXHJcbiAgbWVhc3VyZT86IHN0cmluZyxcclxuICBjeWNsZXNDb3VudD86IG51bWJlcixcclxuKTogUHJvbWlzZTx1bmtub3duPiB7XHJcbiAgcmV0dXJuIG5ldyBQcm9taXNlKGZ1bmN0aW9uKHJlc29sdmUpIHtcclxuICAgIGNvbnN0IHdvcmtlciA9IG5ldyBXb3JrZXIobmV3IFVSTCgnLi9kaW1lbnNpb25hbGl0eS1yZWR1Y2VyJywgaW1wb3J0Lm1ldGEudXJsKSk7XHJcbiAgICB3b3JrZXIucG9zdE1lc3NhZ2Uoe1xyXG4gICAgICBjb2x1bW5EYXRhOiBjb2x1bW5EYXRhLFxyXG4gICAgICBtZXRob2Q6IG1ldGhvZCxcclxuICAgICAgbWVhc3VyZTogbWVhc3VyZSxcclxuICAgICAgY3ljbGVzQ291bnQ6IGN5Y2xlc0NvdW50LFxyXG4gICAgfSk7XHJcbiAgICB3b3JrZXIub25tZXNzYWdlID0gKHtkYXRhOiB7ZW1iZWRkaW5nfX0pID0+IHtcclxuICAgICAgcmVzb2x2ZShlbWJlZGRpbmcpO1xyXG4gICAgfTtcclxuICB9KTtcclxufVxyXG4iXX0= |
@@ -0,0 +0,0 @@ { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
125837
1031
1
50