@grnsft/if 0.1.3-beta → 0.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (62) hide show
  1. package/README.md +2 -21
  2. package/package.json +1 -3
  3. package/src/config/units.yaml +24 -11
  4. package/tsconfig.build.tsbuildinfo +1 -1
  5. package/yarn-error.log +5431 -0
  6. package/build/config/config.d.ts +0 -12
  7. package/build/config/config.js +0 -54
  8. package/build/config/index.d.ts +0 -2
  9. package/build/config/index.js +0 -8
  10. package/build/config/strings.d.ts +0 -19
  11. package/build/config/strings.js +0 -34
  12. package/build/index.d.ts +0 -2
  13. package/build/index.js +0 -53
  14. package/build/lib/models-universe.d.ts +0 -36
  15. package/build/lib/models-universe.js +0 -113
  16. package/build/lib/observatory.d.ts +0 -20
  17. package/build/lib/observatory.js +0 -31
  18. package/build/lib/planet-aggregator.d.ts +0 -6
  19. package/build/lib/planet-aggregator.js +0 -35
  20. package/build/lib/supercomputer.d.ts +0 -37
  21. package/build/lib/supercomputer.js +0 -148
  22. package/build/models/index.d.ts +0 -1
  23. package/build/models/index.js +0 -6
  24. package/build/models/time-sync.d.ts +0 -55
  25. package/build/models/time-sync.js +0 -235
  26. package/build/types/helpers.d.ts +0 -1
  27. package/build/types/helpers.js +0 -3
  28. package/build/types/impl.d.ts +0 -45
  29. package/build/types/impl.js +0 -5
  30. package/build/types/model-interface.d.ts +0 -14
  31. package/build/types/model-interface.js +0 -3
  32. package/build/types/models-universe.d.ts +0 -23
  33. package/build/types/models-universe.js +0 -3
  34. package/build/types/planet-aggregator.d.ts +0 -6
  35. package/build/types/planet-aggregator.js +0 -3
  36. package/build/types/process-args.d.ts +0 -7
  37. package/build/types/process-args.js +0 -3
  38. package/build/types/supercomputer.d.ts +0 -4
  39. package/build/types/supercomputer.js +0 -3
  40. package/build/types/time-sync.d.ts +0 -9
  41. package/build/types/time-sync.js +0 -3
  42. package/build/types/units-dealer.d.ts +0 -3
  43. package/build/types/units-dealer.js +0 -3
  44. package/build/types/units.d.ts +0 -11
  45. package/build/types/units.js +0 -37
  46. package/build/util/args.d.ts +0 -8
  47. package/build/util/args.js +0 -58
  48. package/build/util/errors.d.ts +0 -6
  49. package/build/util/errors.js +0 -25
  50. package/build/util/helpers.d.ts +0 -4
  51. package/build/util/helpers.js +0 -18
  52. package/build/util/units-dealer.d.ts +0 -10
  53. package/build/util/units-dealer.js +0 -32
  54. package/build/util/validations.d.ts +0 -29
  55. package/build/util/validations.js +0 -80
  56. package/build/util/yaml.d.ts +0 -12
  57. package/build/util/yaml.js +0 -36
  58. package/examples/impls/test/time-sync.yml +0 -75
  59. package/examples/ompls/test/time-sync.yml +0 -255
  60. package/examples/ompls/time-sync.yml +0 -212
  61. package/hack-banner.png +0 -0
  62. package/src/models/README.md +0 -266
@@ -1,148 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Supercomputer = void 0;
4
- const observatory_1 = require("./observatory");
5
- const planet_aggregator_1 = require("./planet-aggregator");
6
- const errors_1 = require("../util/errors");
7
- const config_1 = require("../config");
8
- const { ImplValidationError } = errors_1.ERRORS;
9
- const { STRUCTURE_MALFORMED } = config_1.STRINGS;
10
- /**
11
- * Computer for `impl` documents.
12
- */
13
- class Supercomputer {
14
- constructor(impl, modelsHandbook) {
15
- this.olderChild = { name: '', info: {} };
16
- this.aggregatedImpacts = [];
17
- this.childAmount = 0;
18
- this.impl = impl;
19
- this.modelsHandbook = modelsHandbook;
20
- }
21
- /**
22
- * Goes through all aggregations collected from child components, then calculates the average.
23
- */
24
- calculateAggregation() {
25
- if (!this.impl.aggregation) {
26
- throw new ImplValidationError('Aggregation params are not provided.');
27
- }
28
- const method = this.impl.aggregation['aggregation-method'];
29
- return this.aggregatedImpacts.reduce((acc, impact, index) => {
30
- const keys = Object.keys(impact);
31
- keys.forEach(key => {
32
- acc[key] = acc[key] ?? 0;
33
- acc[key] += impact[key];
34
- if (index === this.childAmount - 1) {
35
- if (method === 'avg') {
36
- acc[key] /= this.childAmount;
37
- }
38
- }
39
- });
40
- return acc;
41
- }, {});
42
- }
43
- /**
44
- * Flattens config entries.
45
- */
46
- flattenConfigValues(config) {
47
- if (!config) {
48
- return {};
49
- }
50
- const configModelNames = Object.keys(config);
51
- const values = configModelNames.reduce((acc, name) => {
52
- acc = {
53
- ...acc,
54
- ...config[name],
55
- };
56
- return acc;
57
- }, {});
58
- return values;
59
- }
60
- /**
61
- * Adds config entries to each obsercation object passed.
62
- */
63
- enrichInputs(inputs, config, nestedConfig) {
64
- const configValues = this.flattenConfigValues(config);
65
- const nestedConfigValues = this.flattenConfigValues(nestedConfig);
66
- return inputs.map((input) => ({
67
- ...input,
68
- ...configValues,
69
- ...nestedConfigValues,
70
- }));
71
- }
72
- /**
73
- * If child is top level, then initializes `this.olderChild`.
74
- * If `children` object contains `children` property, it means inputs are nested (calls compute again).
75
- * Otherwise enriches inputs, passes them to Observatory.
76
- * For each model from pipeline Observatory gathers inputs. Then results are stored.
77
- */
78
- async calculateOutputsForChild(childrenObject, params) {
79
- const { childName, areChildrenNested } = params;
80
- if (!areChildrenNested) {
81
- this.olderChild = {
82
- name: childName,
83
- info: this.impl.graph.children[childName],
84
- };
85
- }
86
- const { pipeline, inputs, config } = this.olderChild.info;
87
- if ('children' in childrenObject[childName]) {
88
- return this.compute(childrenObject[childName].children);
89
- }
90
- if (!('inputs' in childrenObject[childName])) {
91
- throw new ImplValidationError(STRUCTURE_MALFORMED(childName));
92
- }
93
- this.childAmount++;
94
- const specificInputs = areChildrenNested
95
- ? childrenObject[childName].inputs
96
- : inputs;
97
- const childrenConfig = childrenObject[childName].config || {};
98
- const enrichedInputs = this.enrichInputs(specificInputs, config, childrenConfig);
99
- const observatory = new observatory_1.Observatory(enrichedInputs);
100
- for (const modelName of pipeline) {
101
- const params = config && config[modelName];
102
- const modelInstance = await this.modelsHandbook.getInitializedModel(modelName, params);
103
- await observatory.doInvestigationsWith(modelInstance);
104
- }
105
- const outputs = observatory.getOutputs();
106
- /**
107
- * If aggregation is required, then init `aggregated-outputs`.
108
- */
109
- if (this.impl.aggregation) {
110
- const aggregatedImpactsPerChild = (0, planet_aggregator_1.planetAggregator)(outputs, this.impl.aggregation);
111
- this.aggregatedImpacts.push(aggregatedImpactsPerChild);
112
- if (areChildrenNested) {
113
- this.impl.graph.children[this.olderChild.name].children[childName]['aggregated-outputs'] = aggregatedImpactsPerChild;
114
- }
115
- else {
116
- this.impl.graph.children[this.olderChild.name]['aggregated-outputs'] =
117
- aggregatedImpactsPerChild;
118
- }
119
- }
120
- if (areChildrenNested) {
121
- this.impl.graph.children[this.olderChild.name].children[childName].outputs = outputs;
122
- }
123
- else {
124
- this.impl.graph.children[this.olderChild.name].outputs = outputs;
125
- }
126
- return;
127
- }
128
- /**
129
- * Checks if object is top level children or nested, then runs through all children and calculates outputs.
130
- */
131
- async compute(childrenObject) {
132
- const implOrChildren = childrenObject || this.impl;
133
- const areChildrenNested = !!childrenObject;
134
- const children = areChildrenNested
135
- ? implOrChildren
136
- : implOrChildren.graph.children;
137
- const childrenNames = Object.keys(children);
138
- for (const childName of childrenNames) {
139
- await this.calculateOutputsForChild(children, {
140
- childName,
141
- areChildrenNested,
142
- });
143
- }
144
- return this.impl;
145
- }
146
- }
147
- exports.Supercomputer = Supercomputer;
148
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwZXJjb21wdXRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvc3VwZXJjb21wdXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSwrQ0FBMEM7QUFDMUMsMkRBQXFEO0FBRXJELDJDQUFzQztBQUV0QyxzQ0FBa0M7QUFPbEMsTUFBTSxFQUFDLG1CQUFtQixFQUFDLEdBQUcsZUFBTSxDQUFDO0FBRXJDLE1BQU0sRUFBQyxtQkFBbUIsRUFBQyxHQUFHLGdCQUFPLENBQUM7QUFFdEM7O0dBRUc7QUFDSCxNQUFhLGFBQWE7SUFPeEIsWUFBWSxJQUFVLEVBQUUsY0FBOEI7UUFOOUMsZUFBVSxHQUFxQixFQUFDLElBQUksRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBQyxDQUFDO1FBR3BELHNCQUFpQixHQUF3QixFQUFFLENBQUM7UUFDNUMsZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFHdEIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7SUFDdkMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksb0JBQW9CO1FBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQzNCLE1BQU0sSUFBSSxtQkFBbUIsQ0FBQyxzQ0FBc0MsQ0FBQyxDQUFDO1FBQ3hFLENBQUM7UUFFRCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBRTNELE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEVBQUU7WUFDMUQsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUVqQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO2dCQUNqQixHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDekIsR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFFeEIsSUFBSSxLQUFLLEtBQUssSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLEVBQUUsQ0FBQztvQkFDbkMsSUFBSSxNQUFNLEtBQUssS0FBSyxFQUFFLENBQUM7d0JBQ3JCLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDO29CQUMvQixDQUFDO2dCQUNILENBQUM7WUFDSCxDQUFDLENBQUMsQ0FBQztZQUVILE9BQU8sR0FBRyxDQUFDO1FBQ2IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztJQUVEOztPQUVHO0lBQ0ssbUJBQW1CLENBQUMsTUFBYztRQUN4QyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDWixPQUFPLEVBQUUsQ0FBQztRQUNaLENBQUM7UUFFRCxNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDN0MsTUFBTSxNQUFNLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBUSxFQUFFLElBQVksRUFBRSxFQUFFO1lBQ2hFLEdBQUcsR0FBRztnQkFDSixHQUFHLEdBQUc7Z0JBQ04sR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDO2FBQ2hCLENBQUM7WUFFRixPQUFPLEdBQUcsQ0FBQztRQUNiLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVQLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFFRDs7T0FFRztJQUNLLFlBQVksQ0FDbEIsTUFBcUIsRUFDckIsTUFBYyxFQUNkLFlBQW9CO1FBRXBCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN0RCxNQUFNLGtCQUFrQixHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUVsRSxPQUFPLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFVLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDakMsR0FBRyxLQUFLO1lBQ1IsR0FBRyxZQUFZO1lBQ2YsR0FBRyxrQkFBa0I7U0FDdEIsQ0FBQyxDQUFDLENBQUM7SUFDTixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSyxLQUFLLENBQUMsd0JBQXdCLENBQ3BDLGNBQXdCLEVBQ3hCLE1BQVc7UUFFWCxNQUFNLEVBQUMsU0FBUyxFQUFFLGlCQUFpQixFQUFDLEdBQUcsTUFBTSxDQUFDO1FBRTlDLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxVQUFVLEdBQUc7Z0JBQ2hCLElBQUksRUFBRSxTQUFTO2dCQUNmLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDO2FBQzFDLENBQUM7UUFDSixDQUFDO1FBRUQsTUFBTSxFQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFDLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUM7UUFFeEQsSUFBSSxVQUFVLElBQUksY0FBYyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUM7WUFDNUMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMxRCxDQUFDO1FBRUQsSUFBSSxDQUFDLENBQUMsUUFBUSxJQUFJLGNBQWMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDN0MsTUFBTSxJQUFJLG1CQUFtQixDQUFDLG1CQUFtQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDaEUsQ0FBQztRQUVELElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUVuQixNQUFNLGNBQWMsR0FBRyxpQkFBaUI7WUFDdEMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNO1lBQ2xDLENBQUMsQ0FBQyxNQUFNLENBQUM7UUFFWCxNQUFNLGNBQWMsR0FBRyxjQUFjLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQztRQUU5RCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUN0QyxjQUFjLEVBQ2QsTUFBTSxFQUNOLGNBQWMsQ0FDZixDQUFDO1FBRUYsTUFBTSxXQUFXLEdBQUcsSUFBSSx5QkFBVyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBRXBELEtBQUssTUFBTSxTQUFTLElBQUksUUFBUSxFQUFFLENBQUM7WUFDakMsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUMzQyxNQUFNLGFBQWEsR0FBRyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsbUJBQW1CLENBQ2pFLFNBQVMsRUFDVCxNQUFNLENBQ1AsQ0FBQztZQUVGLE1BQU0sV0FBVyxDQUFDLG9CQUFvQixDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3hELENBQUM7UUFFRCxNQUFNLE9BQU8sR0FBRyxXQUFXLENBQUMsVUFBVSxFQUFFLENBQUM7UUFFekM7O1dBRUc7UUFDSCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDMUIsTUFBTSx5QkFBeUIsR0FBRyxJQUFBLG9DQUFnQixFQUNoRCxPQUFPLEVBQ1AsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQ3RCLENBQUM7WUFFRixJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLHlCQUF5QixDQUFDLENBQUM7WUFFdkQsSUFBSSxpQkFBaUIsRUFBRSxDQUFDO2dCQUN0QixJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQ2hFLG9CQUFvQixDQUNyQixHQUFHLHlCQUF5QixDQUFDO1lBQ2hDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQztvQkFDbEUseUJBQXlCLENBQUM7WUFDOUIsQ0FBQztRQUNILENBQUM7UUFFRCxJQUFJLGlCQUFpQixFQUFFLENBQUM7WUFDdEIsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUNyRCxTQUFTLENBQ1YsQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3RCLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUNuRSxDQUFDO1FBRUQsT0FBTztJQUNULENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxPQUFPLENBQUMsY0FBb0I7UUFDdkMsTUFBTSxjQUFjLEdBQUcsY0FBYyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUM7UUFDbkQsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLENBQUMsY0FBYyxDQUFDO1FBQzNDLE1BQU0sUUFBUSxHQUFhLGlCQUFpQjtZQUMxQyxDQUFDLENBQUMsY0FBYztZQUNoQixDQUFDLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUM7UUFDbEMsTUFBTSxhQUFhLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUU1QyxLQUFLLE1BQU0sU0FBUyxJQUFJLGFBQWEsRUFBRSxDQUFDO1lBQ3RDLE1BQU0sSUFBSSxDQUFDLHdCQUF3QixDQUFDLFFBQVEsRUFBRTtnQkFDNUMsU0FBUztnQkFDVCxpQkFBaUI7YUFDbEIsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDO0NBQ0Y7QUE1TEQsc0NBNExDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtNb2RlbHNVbml2ZXJzZX0gZnJvbSAnLi9tb2RlbHMtdW5pdmVyc2UnO1xuaW1wb3J0IHtPYnNlcnZhdG9yeX0gZnJvbSAnLi9vYnNlcnZhdG9yeSc7XG5pbXBvcnQge3BsYW5ldEFnZ3JlZ2F0b3J9IGZyb20gJy4vcGxhbmV0LWFnZ3JlZ2F0b3InO1xuXG5pbXBvcnQge0VSUk9SU30gZnJvbSAnLi4vdXRpbC9lcnJvcnMnO1xuXG5pbXBvcnQge1NUUklOR1N9IGZyb20gJy4uL2NvbmZpZyc7XG5cbmltcG9ydCB7Q2hpbGRyZW4sIENvbmZpZywgSW1wbH0gZnJvbSAnLi4vdHlwZXMvaW1wbCc7XG5pbXBvcnQge01vZGVsUGFyYW1zfSBmcm9tICcuLi90eXBlcy9tb2RlbC1pbnRlcmZhY2UnO1xuaW1wb3J0IHtBZ2dyZWdhdGlvblJlc3VsdH0gZnJvbSAnLi4vdHlwZXMvcGxhbmV0LWFnZ3JlZ2F0b3InO1xuaW1wb3J0IHtDaGlsZEluZm9ybWF0aW9ufSBmcm9tICcuLi90eXBlcy9zdXBlcmNvbXB1dGVyJztcblxuY29uc3Qge0ltcGxWYWxpZGF0aW9uRXJyb3J9ID0gRVJST1JTO1xuXG5jb25zdCB7U1RSVUNUVVJFX01BTEZPUk1FRH0gPSBTVFJJTkdTO1xuXG4vKipcbiAqIENvbXB1dGVyIGZvciBgaW1wbGAgZG9jdW1lbnRzLlxuICovXG5leHBvcnQgY2xhc3MgU3VwZXJjb21wdXRlciB7XG4gIHByaXZhdGUgb2xkZXJDaGlsZDogQ2hpbGRJbmZvcm1hdGlvbiA9IHtuYW1lOiAnJywgaW5mbzoge319O1xuICBwcml2YXRlIGltcGw6IEltcGw7XG4gIHByaXZhdGUgbW9kZWxzSGFuZGJvb2s6IE1vZGVsc1VuaXZlcnNlO1xuICBwcml2YXRlIGFnZ3JlZ2F0ZWRJbXBhY3RzOiBBZ2dyZWdhdGlvblJlc3VsdFtdID0gW107XG4gIHByaXZhdGUgY2hpbGRBbW91bnQgPSAwO1xuXG4gIGNvbnN0cnVjdG9yKGltcGw6IEltcGwsIG1vZGVsc0hhbmRib29rOiBNb2RlbHNVbml2ZXJzZSkge1xuICAgIHRoaXMuaW1wbCA9IGltcGw7XG4gICAgdGhpcy5tb2RlbHNIYW5kYm9vayA9IG1vZGVsc0hhbmRib29rO1xuICB9XG5cbiAgLyoqXG4gICAqIEdvZXMgdGhyb3VnaCBhbGwgYWdncmVnYXRpb25zIGNvbGxlY3RlZCBmcm9tIGNoaWxkIGNvbXBvbmVudHMsIHRoZW4gY2FsY3VsYXRlcyB0aGUgYXZlcmFnZS5cbiAgICovXG4gIHB1YmxpYyBjYWxjdWxhdGVBZ2dyZWdhdGlvbigpIHtcbiAgICBpZiAoIXRoaXMuaW1wbC5hZ2dyZWdhdGlvbikge1xuICAgICAgdGhyb3cgbmV3IEltcGxWYWxpZGF0aW9uRXJyb3IoJ0FnZ3JlZ2F0aW9uIHBhcmFtcyBhcmUgbm90IHByb3ZpZGVkLicpO1xuICAgIH1cblxuICAgIGNvbnN0IG1ldGhvZCA9IHRoaXMuaW1wbC5hZ2dyZWdhdGlvblsnYWdncmVnYXRpb24tbWV0aG9kJ107XG5cbiAgICByZXR1cm4gdGhpcy5hZ2dyZWdhdGVkSW1wYWN0cy5yZWR1Y2UoKGFjYywgaW1wYWN0LCBpbmRleCkgPT4ge1xuICAgICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKGltcGFjdCk7XG5cbiAgICAgIGtleXMuZm9yRWFjaChrZXkgPT4ge1xuICAgICAgICBhY2Nba2V5XSA9IGFjY1trZXldID8/IDA7XG4gICAgICAgIGFjY1trZXldICs9IGltcGFjdFtrZXldO1xuXG4gICAgICAgIGlmIChpbmRleCA9PT0gdGhpcy5jaGlsZEFtb3VudCAtIDEpIHtcbiAgICAgICAgICBpZiAobWV0aG9kID09PSAnYXZnJykge1xuICAgICAgICAgICAgYWNjW2tleV0gLz0gdGhpcy5jaGlsZEFtb3VudDtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH0pO1xuXG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGbGF0dGVucyBjb25maWcgZW50cmllcy5cbiAgICovXG4gIHByaXZhdGUgZmxhdHRlbkNvbmZpZ1ZhbHVlcyhjb25maWc6IENvbmZpZykge1xuICAgIGlmICghY29uZmlnKSB7XG4gICAgICByZXR1cm4ge307XG4gICAgfVxuXG4gICAgY29uc3QgY29uZmlnTW9kZWxOYW1lcyA9IE9iamVjdC5rZXlzKGNvbmZpZyk7XG4gICAgY29uc3QgdmFsdWVzID0gY29uZmlnTW9kZWxOYW1lcy5yZWR1Y2UoKGFjYzogYW55LCBuYW1lOiBzdHJpbmcpID0+IHtcbiAgICAgIGFjYyA9IHtcbiAgICAgICAgLi4uYWNjLFxuICAgICAgICAuLi5jb25maWdbbmFtZV0sXG4gICAgICB9O1xuXG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9KTtcblxuICAgIHJldHVybiB2YWx1ZXM7XG4gIH1cblxuICAvKipcbiAgICogQWRkcyBjb25maWcgZW50cmllcyB0byBlYWNoIG9ic2VyY2F0aW9uIG9iamVjdCBwYXNzZWQuXG4gICAqL1xuICBwcml2YXRlIGVucmljaElucHV0cyhcbiAgICBpbnB1dHM6IE1vZGVsUGFyYW1zW10sXG4gICAgY29uZmlnOiBDb25maWcsXG4gICAgbmVzdGVkQ29uZmlnOiBDb25maWdcbiAgKSB7XG4gICAgY29uc3QgY29uZmlnVmFsdWVzID0gdGhpcy5mbGF0dGVuQ29uZmlnVmFsdWVzKGNvbmZpZyk7XG4gICAgY29uc3QgbmVzdGVkQ29uZmlnVmFsdWVzID0gdGhpcy5mbGF0dGVuQ29uZmlnVmFsdWVzKG5lc3RlZENvbmZpZyk7XG5cbiAgICByZXR1cm4gaW5wdXRzLm1hcCgoaW5wdXQ6IGFueSkgPT4gKHtcbiAgICAgIC4uLmlucHV0LFxuICAgICAgLi4uY29uZmlnVmFsdWVzLFxuICAgICAgLi4ubmVzdGVkQ29uZmlnVmFsdWVzLFxuICAgIH0pKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBJZiBjaGlsZCBpcyB0b3AgbGV2ZWwsIHRoZW4gaW5pdGlhbGl6ZXMgYHRoaXMub2xkZXJDaGlsZGAuXG4gICAqIElmIGBjaGlsZHJlbmAgb2JqZWN0IGNvbnRhaW5zIGBjaGlsZHJlbmAgcHJvcGVydHksIGl0IG1lYW5zIGlucHV0cyBhcmUgbmVzdGVkIChjYWxscyBjb21wdXRlIGFnYWluKS5cbiAgICogT3RoZXJ3aXNlIGVucmljaGVzIGlucHV0cywgcGFzc2VzIHRoZW0gdG8gT2JzZXJ2YXRvcnkuXG4gICAqIEZvciBlYWNoIG1vZGVsIGZyb20gcGlwZWxpbmUgT2JzZXJ2YXRvcnkgZ2F0aGVycyBpbnB1dHMuIFRoZW4gcmVzdWx0cyBhcmUgc3RvcmVkLlxuICAgKi9cbiAgcHJpdmF0ZSBhc3luYyBjYWxjdWxhdGVPdXRwdXRzRm9yQ2hpbGQoXG4gICAgY2hpbGRyZW5PYmplY3Q6IENoaWxkcmVuLFxuICAgIHBhcmFtczogYW55XG4gICkge1xuICAgIGNvbnN0IHtjaGlsZE5hbWUsIGFyZUNoaWxkcmVuTmVzdGVkfSA9IHBhcmFtcztcblxuICAgIGlmICghYXJlQ2hpbGRyZW5OZXN0ZWQpIHtcbiAgICAgIHRoaXMub2xkZXJDaGlsZCA9IHtcbiAgICAgICAgbmFtZTogY2hpbGROYW1lLFxuICAgICAgICBpbmZvOiB0aGlzLmltcGwuZ3JhcGguY2hpbGRyZW5bY2hpbGROYW1lXSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgY29uc3Qge3BpcGVsaW5lLCBpbnB1dHMsIGNvbmZpZ30gPSB0aGlzLm9sZGVyQ2hpbGQuaW5mbztcblxuICAgIGlmICgnY2hpbGRyZW4nIGluIGNoaWxkcmVuT2JqZWN0W2NoaWxkTmFtZV0pIHtcbiAgICAgIHJldHVybiB0aGlzLmNvbXB1dGUoY2hpbGRyZW5PYmplY3RbY2hpbGROYW1lXS5jaGlsZHJlbik7XG4gICAgfVxuXG4gICAgaWYgKCEoJ2lucHV0cycgaW4gY2hpbGRyZW5PYmplY3RbY2hpbGROYW1lXSkpIHtcbiAgICAgIHRocm93IG5ldyBJbXBsVmFsaWRhdGlvbkVycm9yKFNUUlVDVFVSRV9NQUxGT1JNRUQoY2hpbGROYW1lKSk7XG4gICAgfVxuXG4gICAgdGhpcy5jaGlsZEFtb3VudCsrO1xuXG4gICAgY29uc3Qgc3BlY2lmaWNJbnB1dHMgPSBhcmVDaGlsZHJlbk5lc3RlZFxuICAgICAgPyBjaGlsZHJlbk9iamVjdFtjaGlsZE5hbWVdLmlucHV0c1xuICAgICAgOiBpbnB1dHM7XG5cbiAgICBjb25zdCBjaGlsZHJlbkNvbmZpZyA9IGNoaWxkcmVuT2JqZWN0W2NoaWxkTmFtZV0uY29uZmlnIHx8IHt9O1xuXG4gICAgY29uc3QgZW5yaWNoZWRJbnB1dHMgPSB0aGlzLmVucmljaElucHV0cyhcbiAgICAgIHNwZWNpZmljSW5wdXRzLFxuICAgICAgY29uZmlnLFxuICAgICAgY2hpbGRyZW5Db25maWdcbiAgICApO1xuXG4gICAgY29uc3Qgb2JzZXJ2YXRvcnkgPSBuZXcgT2JzZXJ2YXRvcnkoZW5yaWNoZWRJbnB1dHMpO1xuXG4gICAgZm9yIChjb25zdCBtb2RlbE5hbWUgb2YgcGlwZWxpbmUpIHtcbiAgICAgIGNvbnN0IHBhcmFtcyA9IGNvbmZpZyAmJiBjb25maWdbbW9kZWxOYW1lXTtcbiAgICAgIGNvbnN0IG1vZGVsSW5zdGFuY2UgPSBhd2FpdCB0aGlzLm1vZGVsc0hhbmRib29rLmdldEluaXRpYWxpemVkTW9kZWwoXG4gICAgICAgIG1vZGVsTmFtZSxcbiAgICAgICAgcGFyYW1zXG4gICAgICApO1xuXG4gICAgICBhd2FpdCBvYnNlcnZhdG9yeS5kb0ludmVzdGlnYXRpb25zV2l0aChtb2RlbEluc3RhbmNlKTtcbiAgICB9XG5cbiAgICBjb25zdCBvdXRwdXRzID0gb2JzZXJ2YXRvcnkuZ2V0T3V0cHV0cygpO1xuXG4gICAgLyoqXG4gICAgICogSWYgYWdncmVnYXRpb24gaXMgcmVxdWlyZWQsIHRoZW4gaW5pdCBgYWdncmVnYXRlZC1vdXRwdXRzYC5cbiAgICAgKi9cbiAgICBpZiAodGhpcy5pbXBsLmFnZ3JlZ2F0aW9uKSB7XG4gICAgICBjb25zdCBhZ2dyZWdhdGVkSW1wYWN0c1BlckNoaWxkID0gcGxhbmV0QWdncmVnYXRvcihcbiAgICAgICAgb3V0cHV0cyxcbiAgICAgICAgdGhpcy5pbXBsLmFnZ3JlZ2F0aW9uXG4gICAgICApO1xuXG4gICAgICB0aGlzLmFnZ3JlZ2F0ZWRJbXBhY3RzLnB1c2goYWdncmVnYXRlZEltcGFjdHNQZXJDaGlsZCk7XG5cbiAgICAgIGlmIChhcmVDaGlsZHJlbk5lc3RlZCkge1xuICAgICAgICB0aGlzLmltcGwuZ3JhcGguY2hpbGRyZW5bdGhpcy5vbGRlckNoaWxkLm5hbWVdLmNoaWxkcmVuW2NoaWxkTmFtZV1bXG4gICAgICAgICAgJ2FnZ3JlZ2F0ZWQtb3V0cHV0cydcbiAgICAgICAgXSA9IGFnZ3JlZ2F0ZWRJbXBhY3RzUGVyQ2hpbGQ7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aGlzLmltcGwuZ3JhcGguY2hpbGRyZW5bdGhpcy5vbGRlckNoaWxkLm5hbWVdWydhZ2dyZWdhdGVkLW91dHB1dHMnXSA9XG4gICAgICAgICAgYWdncmVnYXRlZEltcGFjdHNQZXJDaGlsZDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoYXJlQ2hpbGRyZW5OZXN0ZWQpIHtcbiAgICAgIHRoaXMuaW1wbC5ncmFwaC5jaGlsZHJlblt0aGlzLm9sZGVyQ2hpbGQubmFtZV0uY2hpbGRyZW5bXG4gICAgICAgIGNoaWxkTmFtZVxuICAgICAgXS5vdXRwdXRzID0gb3V0cHV0cztcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5pbXBsLmdyYXBoLmNoaWxkcmVuW3RoaXMub2xkZXJDaGlsZC5uYW1lXS5vdXRwdXRzID0gb3V0cHV0cztcbiAgICB9XG5cbiAgICByZXR1cm47XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2tzIGlmIG9iamVjdCBpcyB0b3AgbGV2ZWwgY2hpbGRyZW4gb3IgbmVzdGVkLCB0aGVuIHJ1bnMgdGhyb3VnaCBhbGwgY2hpbGRyZW4gYW5kIGNhbGN1bGF0ZXMgb3V0cHV0cy5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBjb21wdXRlKGNoaWxkcmVuT2JqZWN0PzogYW55KSB7XG4gICAgY29uc3QgaW1wbE9yQ2hpbGRyZW4gPSBjaGlsZHJlbk9iamVjdCB8fCB0aGlzLmltcGw7XG4gICAgY29uc3QgYXJlQ2hpbGRyZW5OZXN0ZWQgPSAhIWNoaWxkcmVuT2JqZWN0O1xuICAgIGNvbnN0IGNoaWxkcmVuOiBDaGlsZHJlbiA9IGFyZUNoaWxkcmVuTmVzdGVkXG4gICAgICA/IGltcGxPckNoaWxkcmVuXG4gICAgICA6IGltcGxPckNoaWxkcmVuLmdyYXBoLmNoaWxkcmVuO1xuICAgIGNvbnN0IGNoaWxkcmVuTmFtZXMgPSBPYmplY3Qua2V5cyhjaGlsZHJlbik7XG5cbiAgICBmb3IgKGNvbnN0IGNoaWxkTmFtZSBvZiBjaGlsZHJlbk5hbWVzKSB7XG4gICAgICBhd2FpdCB0aGlzLmNhbGN1bGF0ZU91dHB1dHNGb3JDaGlsZChjaGlsZHJlbiwge1xuICAgICAgICBjaGlsZE5hbWUsXG4gICAgICAgIGFyZUNoaWxkcmVuTmVzdGVkLFxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuaW1wbDtcbiAgfVxufVxuIl19
@@ -1 +0,0 @@
1
- export { TimeSyncModel } from './time-sync';
@@ -1,6 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.TimeSyncModel = void 0;
4
- var time_sync_1 = require("./time-sync");
5
- Object.defineProperty(exports, "TimeSyncModel", { enumerable: true, get: function () { return time_sync_1.TimeSyncModel; } });
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kZWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlDQUEwQztBQUFsQywwR0FBQSxhQUFhLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQge1RpbWVTeW5jTW9kZWx9IGZyb20gJy4vdGltZS1zeW5jJztcbiJdfQ==
@@ -1,55 +0,0 @@
1
- import { ModelParams, ModelPluginInterface } from '../types/model-interface';
2
- import { TimeNormalizerConfig } from '../types/time-sync';
3
- import { UnitsDealerUsage } from '../types/units-dealer';
4
- export declare class TimeSyncModel implements ModelPluginInterface {
5
- startTime: string | undefined;
6
- endTime: string | undefined;
7
- dealer: UnitsDealerUsage;
8
- interval: number;
9
- /**
10
- * Setups basic configuration.
11
- */
12
- configure(params: TimeNormalizerConfig): Promise<ModelPluginInterface>;
13
- /**
14
- * Validates `startTime`, `endTime` and `interval` params.
15
- */
16
- private validateParams;
17
- /**
18
- * Calculates minimal factor.
19
- */
20
- private convertPerInterval;
21
- /**
22
- * Normalize time per given second.
23
- */
24
- private normalizeTimePerSecond;
25
- /**
26
- * Barkes down input per minimal time unit.
27
- */
28
- private breakDownInput;
29
- /**
30
- * Populates object to fill the gaps in observational timeline using zeroish values.
31
- */
32
- private fillWithZeroishInput;
33
- /**
34
- * Checks if padding is needed either at start of the timeline or the end and returns status.
35
- */
36
- private checkForPadding;
37
- /**
38
- * Iterates over given inputs frame, meanwhile checking if aggregation method is `sum`, then calculates it.
39
- * For methods is `avg` and `none` calculating average of the frame.
40
- */
41
- private resampleInputFrame;
42
- /**
43
- * Takes each array frame with interval length, then aggregating them together as from units.yaml file.
44
- */
45
- private resampleInputs;
46
- /**
47
- * Pads zeroish inputs from the beginning or at the end of the inputs if needed.
48
- */
49
- private padInputs;
50
- private trimInputsByGlobalTimeline;
51
- /**
52
- * Normalizes provided time window according to time configuration.
53
- */
54
- execute(inputs: ModelParams[]): Promise<ModelParams[]>;
55
- }
@@ -1,235 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.TimeSyncModel = void 0;
4
- const moment = require("moment");
5
- const moment_range_1 = require("moment-range");
6
- const config_1 = require("../config");
7
- const errors_1 = require("../util/errors");
8
- const units_dealer_1 = require("../util/units-dealer");
9
- const momentRange = (0, moment_range_1.extendMoment)(moment);
10
- const { InputValidationError } = errors_1.ERRORS;
11
- const { INVALID_TIME_NORMALIZATION, INVALID_TIME_INTERVAL, INVALID_OBSERVATION_OVERLAP, } = config_1.STRINGS;
12
- class TimeSyncModel {
13
- constructor() {
14
- this.interval = 1;
15
- /**
16
- * Calculates minimal factor.
17
- */
18
- this.convertPerInterval = (value, duration) => value / duration;
19
- /**
20
- * Normalize time per given second.
21
- */
22
- this.normalizeTimePerSecond = (currentRoundMoment, i) => {
23
- const thisMoment = moment(currentRoundMoment).milliseconds(0);
24
- return thisMoment.add(i, 'second');
25
- };
26
- /**
27
- * Iterates over given inputs frame, meanwhile checking if aggregation method is `sum`, then calculates it.
28
- * For methods is `avg` and `none` calculating average of the frame.
29
- */
30
- this.resampleInputFrame = (inputsInTimeslot) => {
31
- return inputsInTimeslot.reduce((acc, input, index, inputs) => {
32
- const metrics = Object.keys(input);
33
- metrics.forEach(metric => {
34
- const method = this.dealer.askToGiveMethodFor(metric);
35
- acc[metric] = acc[metric] ?? 0;
36
- if (metric === 'timestamp') {
37
- acc[metric] = inputs[0][metric];
38
- return;
39
- }
40
- if (method === 'sum') {
41
- acc[metric] += input[metric];
42
- return;
43
- }
44
- /** divide each metric by the timeslot length, so that their sum yields the timeslot average.*/
45
- if (index === inputsInTimeslot.length - 1) {
46
- acc[metric] /= inputsInTimeslot.length;
47
- return;
48
- }
49
- acc[metric] += input[metric];
50
- });
51
- return acc;
52
- }, {});
53
- };
54
- }
55
- /**
56
- * Setups basic configuration.
57
- */
58
- async configure(params) {
59
- this.startTime = params['start-time'];
60
- this.endTime = params['end-time'];
61
- this.interval = params.interval;
62
- this.dealer = await (0, units_dealer_1.UnitsDealer)();
63
- return this;
64
- }
65
- /**
66
- * Validates `startTime`, `endTime` and `interval` params.
67
- */
68
- validateParams() {
69
- if (!this.startTime || !this.endTime) {
70
- throw new InputValidationError(INVALID_TIME_NORMALIZATION);
71
- }
72
- if (this.startTime > this.endTime) {
73
- throw new InputValidationError(INVALID_TIME_NORMALIZATION);
74
- }
75
- if (!this.interval) {
76
- throw new InputValidationError(INVALID_TIME_INTERVAL);
77
- }
78
- }
79
- /**
80
- * Barkes down input per minimal time unit.
81
- */
82
- breakDownInput(input, i) {
83
- const inputKeys = Object.keys(input);
84
- return inputKeys.reduce((acc, key) => {
85
- const method = this.dealer.askToGiveMethodFor(key);
86
- if (key === 'timestamp') {
87
- const perSecond = this.normalizeTimePerSecond(input.timestamp, i);
88
- acc[key] = moment(perSecond).milliseconds(0).toISOString();
89
- return acc;
90
- }
91
- /** @todo use user defined resolution later */
92
- if (key === 'duration') {
93
- acc[key] = 1;
94
- return acc;
95
- }
96
- acc[key] =
97
- method === 'sum'
98
- ? this.convertPerInterval(input[key], input['duration'])
99
- : input[key];
100
- return acc;
101
- }, {});
102
- }
103
- /**
104
- * Populates object to fill the gaps in observational timeline using zeroish values.
105
- */
106
- fillWithZeroishInput(input, missingTimestamp) {
107
- const metrics = Object.keys(input);
108
- return metrics.reduce((acc, metric) => {
109
- if (metric === 'timestamp') {
110
- acc[metric] = moment(missingTimestamp).milliseconds(0).toISOString();
111
- return acc;
112
- }
113
- /** @todo later will be changed to user defined interval */
114
- if (metric === 'duration') {
115
- acc[metric] = 1;
116
- return acc;
117
- }
118
- if (metric === 'time-reserved') {
119
- acc[metric] = acc['duration'];
120
- return acc;
121
- }
122
- const method = this.dealer.askToGiveMethodFor(metric);
123
- acc[metric] = method === 'avg' || method === 'sum' ? 0 : input[metric];
124
- return acc;
125
- }, {});
126
- }
127
- /**
128
- * Checks if padding is needed either at start of the timeline or the end and returns status.
129
- */
130
- checkForPadding(inputs) {
131
- const startDiffInSeconds = moment(inputs[0].timestamp).diff(moment(this.startTime)) / 1000;
132
- const lastInput = inputs[inputs.length - 1];
133
- const endDiffInSeconds = moment(lastInput.timestamp)
134
- .add(lastInput.duration, 'seconds')
135
- .diff(moment(this.endTime)) / 1000;
136
- return {
137
- start: startDiffInSeconds > 0,
138
- end: endDiffInSeconds < 0,
139
- };
140
- }
141
- /**
142
- * Takes each array frame with interval length, then aggregating them together as from units.yaml file.
143
- */
144
- resampleInputs(inputs) {
145
- return inputs.reduce((acc, _input, index, inputs) => {
146
- const frameStart = index * this.interval;
147
- const frameEnd = (index + 1) * this.interval;
148
- const inputsFrame = inputs.slice(frameStart, frameEnd);
149
- const resampledInput = this.resampleInputFrame(inputsFrame);
150
- /** Checks if resampled input is not empty, then includes in result. */
151
- if (Object.keys(resampledInput).length > 0) {
152
- acc.push(resampledInput);
153
- }
154
- return acc;
155
- }, []);
156
- }
157
- /**
158
- * Pads zeroish inputs from the beginning or at the end of the inputs if needed.
159
- */
160
- padInputs(inputs, pad) {
161
- const { start, end } = pad;
162
- const paddedFromBeginning = [];
163
- if (start) {
164
- const dateRange = momentRange.range(moment(this.startTime), moment(inputs[0].timestamp).subtract(1, 'second'));
165
- /** Checks if converting to value of is needed. */
166
- for (const second of dateRange.by('second')) {
167
- paddedFromBeginning.push(this.fillWithZeroishInput(inputs[0], second.valueOf()));
168
- }
169
- }
170
- const paddedArray = paddedFromBeginning.concat(inputs);
171
- if (end) {
172
- const lastInput = inputs[inputs.length - 1];
173
- const dateRange = momentRange.range(moment(lastInput.timestamp).add(lastInput.duration, 'seconds'), moment(this.endTime));
174
- for (const second of dateRange.by('second')) {
175
- paddedArray.push(this.fillWithZeroishInput(lastInput, second.valueOf()));
176
- }
177
- }
178
- return paddedArray;
179
- }
180
- /*
181
- * Checks if input's timestamp is included in global specified period then leaves it, otherwise.
182
- */
183
- trimInputsByGlobalTimeline(inputs) {
184
- return inputs.reduce((acc, item) => {
185
- const { timestamp } = item;
186
- if (moment(timestamp).isSameOrAfter(moment(this.startTime)) &&
187
- moment(timestamp).isSameOrBefore(moment(this.endTime))) {
188
- acc.push(item);
189
- }
190
- return acc;
191
- }, []);
192
- }
193
- /**
194
- * Normalizes provided time window according to time configuration.
195
- */
196
- async execute(inputs) {
197
- this.validateParams();
198
- const pad = this.checkForPadding(inputs);
199
- const paddedInputs = this.padInputs(inputs, pad);
200
- const flattenInputs = paddedInputs.reduce((acc, input, index) => {
201
- const currentMoment = moment(input.timestamp);
202
- /** Checks if not the first input, then check consistency with previous ones. */
203
- if (index > 0) {
204
- const previousInput = paddedInputs[index - 1];
205
- const previousInputTimestamp = moment(previousInput.timestamp);
206
- /** Checks for timestamps overlap. */
207
- if (moment(previousInput.timestamp)
208
- .add(previousInput.duration, 'seconds')
209
- .isAfter(currentMoment)) {
210
- throw new InputValidationError(INVALID_OBSERVATION_OVERLAP);
211
- }
212
- const compareableTime = previousInputTimestamp.add(previousInput.duration, 'second');
213
- const timelineGapSize = currentMoment.diff(compareableTime, 'second');
214
- //console.log(currentMoment, timelineGapSize)
215
- /** Checks if there is gap in timeline. */
216
- if (timelineGapSize > 1) {
217
- for (let missingTimestamp = compareableTime.valueOf(); missingTimestamp <= currentMoment.valueOf() - 1000; missingTimestamp += 1000) {
218
- const filledGap = this.fillWithZeroishInput(input, missingTimestamp);
219
- acc.push(filledGap);
220
- }
221
- }
222
- }
223
- /** Break down current observation. */
224
- for (let i = 0; i < input.duration; i++) {
225
- const normalizedInput = this.breakDownInput(input, i);
226
- acc.push(normalizedInput);
227
- }
228
- return this.trimInputsByGlobalTimeline(acc);
229
- }, []);
230
- const sortedInputs = flattenInputs.sort((a, b) => moment(a.timestamp).diff(moment(b.timestamp)));
231
- return this.resampleInputs(sortedInputs);
232
- }
233
- }
234
- exports.TimeSyncModel = TimeSyncModel;
235
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1zeW5jLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vZGVscy90aW1lLXN5bmMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaUNBQWtDO0FBQ2xDLCtDQUEwQztBQUUxQyxzQ0FBa0M7QUFFbEMsMkNBQXNDO0FBQ3RDLHVEQUFpRDtBQU9qRCxNQUFNLFdBQVcsR0FBRyxJQUFBLDJCQUFZLEVBQUMsTUFBTSxDQUFDLENBQUM7QUFFekMsTUFBTSxFQUFDLG9CQUFvQixFQUFDLEdBQUcsZUFBTSxDQUFDO0FBRXRDLE1BQU0sRUFDSiwwQkFBMEIsRUFDMUIscUJBQXFCLEVBQ3JCLDJCQUEyQixHQUM1QixHQUFHLGdCQUFPLENBQUM7QUFFWixNQUFhLGFBQWE7SUFBMUI7UUFJRSxhQUFRLEdBQUcsQ0FBQyxDQUFDO1FBK0JiOztXQUVHO1FBQ0ssdUJBQWtCLEdBQUcsQ0FBQyxLQUFhLEVBQUUsUUFBZ0IsRUFBRSxFQUFFLENBQy9ELEtBQUssR0FBRyxRQUFRLENBQUM7UUFFbkI7O1dBRUc7UUFDSywyQkFBc0IsR0FBRyxDQUFDLGtCQUEwQixFQUFFLENBQVMsRUFBRSxFQUFFO1lBQ3pFLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUU5RCxPQUFPLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQ3JDLENBQUMsQ0FBQztRQXNGRjs7O1dBR0c7UUFDSyx1QkFBa0IsR0FBRyxDQUFDLGdCQUErQixFQUFFLEVBQUU7WUFDL0QsT0FBTyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsRUFBRTtnQkFDM0QsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQWtCLENBQUM7Z0JBRXBELE9BQU8sQ0FBQyxP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QUFJLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQzNDLENBQUM7Q0FDRjtBQTVURCxzQ0E0VEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbW9tZW50ID0gcmVxdWlyZSgnbW9tZW50Jyk7XG5pbXBvcnQge2V4dGVuZE1vbWVudH0gZnJvbSAnbW9tZW50LXJhbmdlJztcblxuaW1wb3J0IHtTVFJJTkdTfSBmcm9tICcuLi9jb25maWcnO1xuXG5pbXBvcnQge0VSUk9SU30gZnJvbSAnLi4vdXRpbC9lcnJvcnMnO1xuaW1wb3J0IHtVbml0c0RlYWxlcn0gZnJvbSAnLi4vdXRpbC91bml0cy1kZWFsZXInO1xuXG5pbXBvcnQge01vZGVsUGFyYW1zLCBNb2RlbFBsdWdpbkludGVyZmFjZX0gZnJvbSAnLi4vdHlwZXMvbW9kZWwtaW50ZXJmYWNlJztcbmltcG9ydCB7UGFkZGluZ1JlY2VpcHQsIFRpbWVOb3JtYWxpemVyQ29uZmlnfSBmcm9tICcuLi90eXBlcy90aW1lLXN5bmMnO1xuaW1wb3J0IHtVbml0c0RlYWxlclVzYWdlfSBmcm9tICcuLi90eXBlcy91bml0cy1kZWFsZXInO1xuaW1wb3J0IHtVbml0S2V5TmFtZX0gZnJvbSAnLi4vdHlwZXMvdW5pdHMnO1xuXG5jb25zdCBtb21lbnRSYW5nZSA9IGV4dGVuZE1vbWVudChtb21lbnQpO1xuXG5jb25zdCB7SW5wdXRWYWxpZGF0aW9uRXJyb3J9ID0gRVJST1JTO1xuXG5jb25zdCB7XG4gIElOVkFMSURfVElNRV9OT1JNQUxJWkFUSU9OLFxuICBJTlZBTElEX1RJTUVfSU5URVJWQUwsXG4gIElOVkFMSURfT0JTRVJWQVRJT05fT1ZFUkxBUCxcbn0gPSBTVFJJTkdTO1xuXG5leHBvcnQgY2xhc3MgVGltZVN5bmNNb2RlbCBpbXBsZW1lbnRzIE1vZGVsUGx1Z2luSW50ZXJmYWNlIHtcbiAgc3RhcnRUaW1lOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIGVuZFRpbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgZGVhbGVyITogVW5pdHNEZWFsZXJVc2FnZTtcbiAgaW50ZXJ2YWwgPSAxO1xuXG4gIC8qKlxuICAgKiBTZXR1cHMgYmFzaWMgY29uZmlndXJhdGlvbi5cbiAgICovXG4gIGFzeW5jIGNvbmZpZ3VyZShwYXJhbXM6IFRpbWVOb3JtYWxpemVyQ29uZmlnKTogUHJvbWlzZTxNb2RlbFBsdWdpbkludGVyZmFjZT4ge1xuICAgIHRoaXMuc3RhcnRUaW1lID0gcGFyYW1zWydzdGFydC10aW1lJ107XG4gICAgdGhpcy5lbmRUaW1lID0gcGFyYW1zWydlbmQtdGltZSddO1xuICAgIHRoaXMuaW50ZXJ2YWwgPSBwYXJhbXMuaW50ZXJ2YWw7XG4gICAgdGhpcy5kZWFsZXIgPSBhd2FpdCBVbml0c0RlYWxlcigpO1xuXG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGVzIGBzdGFydFRpbWVgLCBgZW5kVGltZWAgYW5kIGBpbnRlcnZhbGAgcGFyYW1zLlxuICAgKi9cbiAgcHJpdmF0ZSB2YWxpZGF0ZVBhcmFtcygpIHtcbiAgICBpZiAoIXRoaXMuc3RhcnRUaW1lIHx8ICF0aGlzLmVuZFRpbWUpIHtcbiAgICAgIHRocm93IG5ldyBJbnB1dFZhbGlkYXRpb25FcnJvcihJTlZBTElEX1RJTUVfTk9STUFMSVpBVElPTik7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuc3RhcnRUaW1lID4gdGhpcy5lbmRUaW1lKSB7XG4gICAgICB0aHJvdyBuZXcgSW5wdXRWYWxpZGF0aW9uRXJyb3IoSU5WQUxJRF9USU1FX05PUk1BTElaQVRJT04pO1xuICAgIH1cblxuICAgIGlmICghdGhpcy5pbnRlcnZhbCkge1xuICAgICAgdGhyb3cgbmV3IElucHV0VmFsaWRhdGlvbkVycm9yKElOVkFMSURfVElNRV9JTlRFUlZBTCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIENhbGN1bGF0ZXMgbWluaW1hbCBmYWN0b3IuXG4gICAqL1xuICBwcml2YXRlIGNvbnZlcnRQZXJJbnRlcnZhbCA9ICh2YWx1ZTogbnVtYmVyLCBkdXJhdGlvbjogbnVtYmVyKSA9PlxuICAgIHZhbHVlIC8gZHVyYXRpb247XG5cbiAgLyoqXG4gICAqIE5vcm1hbGl6ZSB0aW1lIHBlciBnaXZlbiBzZWNvbmQuXG4gICAqL1xuICBwcml2YXRlIG5vcm1hbGl6ZVRpbWVQZXJTZWNvbmQgPSAoY3VycmVudFJvdW5kTW9tZW50OiBzdHJpbmcsIGk6IG51bWJlcikgPT4ge1xuICAgIGNvbnN0IHRoaXNNb21lbnQgPSBtb21lbnQoY3VycmVudFJvdW5kTW9tZW50KS5taWxsaXNlY29uZHMoMCk7XG5cbiAgICByZXR1cm4gdGhpc01vbWVudC5hZGQoaSwgJ3NlY29uZCcpO1xuICB9O1xuXG4gIC8qKlxuICAgKiBCYXJrZXMgZG93biBpbnB1dCBwZXIgbWluaW1hbCB0aW1lIHVuaXQuXG4gICAqL1xuICBwcml2YXRlIGJyZWFrRG93bklucHV0KGlucHV0OiBNb2RlbFBhcmFtcywgaTogbnVtYmVyKSB7XG4gICAgY29uc3QgaW5wdXRLZXlzID0gT2JqZWN0LmtleXMoaW5wdXQpIGFzIFVuaXRLZXlOYW1lW107XG5cbiAgICByZXR1cm4gaW5wdXRLZXlzLnJlZHVjZSgoYWNjLCBrZXkpID0+IHtcbiAgICAgIGNvbnN0IG1ldGhvZCA9IHRoaXMuZGVhbGVyLmFza1RvR2l2ZU1ldGhvZEZvcihrZXkpO1xuXG4gICAgICBpZiAoa2V5ID09PSAndGltZXN0YW1wJykge1xuICAgICAgICBjb25zdCBwZXJTZWNvbmQgPSB0aGlzLm5vcm1hbGl6ZVRpbWVQZXJTZWNvbmQoaW5wdXQudGltZXN0YW1wLCBpKTtcbiAgICAgICAgYWNjW2tleV0gPSBtb21lbnQocGVyU2Vjb25kKS5taWxsaXNlY29uZHMoMCkudG9JU09TdHJpbmcoKTtcblxuICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgfVxuXG4gICAgICAvKiogQHRvZG8gdXNlIHVzZXIgZGVmaW5lZCByZXNvbHV0aW9uIGxhdGVyICovXG4gICAgICBpZiAoa2V5ID09PSAnZHVyYXRpb24nKSB7XG4gICAgICAgIGFjY1trZXldID0gMTtcblxuICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgfVxuXG4gICAgICBhY2Nba2V5XSA9XG4gICAgICAgIG1ldGhvZCA9PT0gJ3N1bSdcbiAgICAgICAgICA/IHRoaXMuY29udmVydFBlckludGVydmFsKGlucHV0W2tleV0sIGlucHV0WydkdXJhdGlvbiddKVxuICAgICAgICAgIDogaW5wdXRba2V5XTtcblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSBhcyBNb2RlbFBhcmFtcyk7XG4gIH1cblxuICAvKipcbiAgICogUG9wdWxhdGVzIG9iamVjdCB0byBmaWxsIHRoZSBnYXBzIGluIG9ic2VydmF0aW9uYWwgdGltZWxpbmUgdXNpbmcgemVyb2lzaCB2YWx1ZXMuXG4gICAqL1xuICBwcml2YXRlIGZpbGxXaXRoWmVyb2lzaElucHV0KGlucHV0OiBNb2RlbFBhcmFtcywgbWlzc2luZ1RpbWVzdGFtcDogbnVtYmVyKSB7XG4gICAgY29uc3QgbWV0cmljcyA9IE9iamVjdC5rZXlzKGlucHV0KSBhcyBVbml0S2V5TmFtZVtdO1xuXG4gICAgcmV0dXJuIG1ldHJpY3MucmVkdWNlKChhY2MsIG1ldHJpYykgPT4ge1xuICAgICAgaWYgKG1ldHJpYyA9PT0gJ3RpbWVzdGFtcCcpIHtcbiAgICAgICAgYWNjW21ldHJpY10gPSBtb21lbnQobWlzc2luZ1RpbWVzdGFtcCkubWlsbGlzZWNvbmRzKDApLnRvSVNPU3RyaW5nKCk7XG5cbiAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgIH1cblxuICAgICAgLyoqIEB0b2RvIGxhdGVyIHdpbGwgYmUgY2hhbmdlZCB0byB1c2VyIGRlZmluZWQgaW50ZXJ2YWwgKi9cbiAgICAgIGlmIChtZXRyaWMgPT09ICdkdXJhdGlvbicpIHtcbiAgICAgICAgYWNjW21ldHJpY10gPSAxO1xuXG4gICAgICAgIHJldHVybiBhY2M7XG4gICAgICB9XG5cbiAgICAgIGlmIChtZXRyaWMgPT09ICd0aW1lLXJlc2VydmVkJykge1xuICAgICAgICBhY2NbbWV0cmljXSA9IGFjY1snZHVyYXRpb24nXTtcblxuICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBtZXRob2QgPSB0aGlzLmRlYWxlci5hc2tUb0dpdmVNZXRob2RGb3IobWV0cmljKTtcbiAgICAgIGFjY1ttZXRyaWNdID0gbWV0aG9kID09PSAnYXZnJyB8fCBtZXRob2QgPT09ICdzdW0nID8gMCA6IGlucHV0W21ldHJpY107XG5cbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSwge30gYXMgTW9kZWxQYXJhbXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyBpZiBwYWRkaW5nIGlzIG5lZWRlZCBlaXRoZXIgYXQgc3RhcnQgb2YgdGhlIHRpbWVsaW5lIG9yIHRoZSBlbmQgYW5kIHJldHVybnMgc3RhdHVzLlxuICAgKi9cbiAgcHJpdmF0ZSBjaGVja0ZvclBhZGRpbmcoaW5wdXRzOiBNb2RlbFBhcmFtc1tdKTogUGFkZGluZ1JlY2VpcHQge1xuICAgIGNvbnN0IHN0YXJ0RGlmZkluU2Vjb25kcyA9XG4gICAgICBtb21lbnQoaW5wdXRzWzBdLnRpbWVzdGFtcCkuZGlmZihtb21lbnQodGhpcy5zdGFydFRpbWUpKSAvIDEwMDA7XG5cbiAgICBjb25zdCBsYXN0SW5wdXQgPSBpbnB1dHNbaW5wdXRzLmxlbmd0aCAtIDFdO1xuICAgIGNvbnN0IGVuZERpZmZJblNlY29uZHMgPVxuICAgICAgbW9tZW50KGxhc3RJbnB1dC50aW1lc3RhbXApXG4gICAgICAgIC5hZGQobGFzdElucHV0LmR1cmF0aW9uLCAnc2Vjb25kcycpXG4gICAgICAgIC5kaWZmKG1vbWVudCh0aGlzLmVuZFRpbWUpKSAvIDEwMDA7XG5cbiAgICByZXR1cm4ge1xuICAgICAgc3RhcnQ6IHN0YXJ0RGlmZkluU2Vjb25kcyA+IDAsXG4gICAgICBlbmQ6IGVuZERpZmZJblNlY29uZHMgPCAwLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogSXRlcmF0ZXMgb3ZlciBnaXZlbiBpbnB1dHMgZnJhbWUsIG1lYW53aGlsZSBjaGVja2luZyBpZiBhZ2dyZWdhdGlvbiBtZXRob2QgaXMgYHN1bWAsIHRoZW4gY2FsY3VsYXRlcyBpdC5cbiAgICogRm9yIG1ldGhvZHMgaXMgYGF2Z2AgYW5kIGBub25lYCBjYWxjdWxhdGluZyBhdmVyYWdlIG9mIHRoZSBmcmFtZS5cbiAgICovXG4gIHByaXZhdGUgcmVzYW1wbGVJbnB1dEZyYW1lID0gKGlucHV0c0luVGltZXNsb3Q6IE1vZGVsUGFyYW1zW10pID0+IHtcbiAgICByZXR1cm4gaW5wdXRzSW5UaW1lc2xvdC5yZWR1Y2UoKGFjYywgaW5wdXQsIGluZGV4LCBpbnB1dHMpID0+IHtcbiAgICAgIGNvbnN0IG1ldHJpY3MgPSBPYmplY3Qua2V5cyhpbnB1dCkgYXMgVW5pdEtleU5hbWVbXTtcblxuICAgICAgbWV0cmljcy5mb3JFYWNoKG1ldHJpYyA9PiB7XG4gICAgICAgIGNvbnN0IG1ldGhvZCA9IHRoaXMuZGVhbGVyLmFza1RvR2l2ZU1ldGhvZEZvcihtZXRyaWMpO1xuICAgICAgICBhY2NbbWV0cmljXSA9IGFjY1ttZXRyaWNdID8/IDA7XG5cbiAgICAgICAgaWYgKG1ldHJpYyA9PT0gJ3RpbWVzdGFtcCcpIHtcbiAgICAgICAgICBhY2NbbWV0cmljXSA9IGlucHV0c1swXVttZXRyaWNdO1xuXG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKG1ldGhvZCA9PT0gJ3N1bScpIHtcbiAgICAgICAgICBhY2NbbWV0cmljXSArPSBpbnB1dFttZXRyaWNdO1xuXG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgLyoqIGRpdmlkZSBlYWNoIG1ldHJpYyBieSB0aGUgdGltZXNsb3QgbGVuZ3RoLCBzbyB0aGF0IHRoZWlyIHN1bSB5aWVsZHMgdGhlIHRpbWVzbG90IGF2ZXJhZ2UuKi9cbiAgICAgICAgaWYgKGluZGV4ID09PSBpbnB1dHNJblRpbWVzbG90Lmxlbmd0aCAtIDEpIHtcbiAgICAgICAgICBhY2NbbWV0cmljXSAvPSBpbnB1dHNJblRpbWVzbG90Lmxlbmd0aDtcblxuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGFjY1ttZXRyaWNdICs9IGlucHV0W21ldHJpY107XG4gICAgICB9KTtcblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSBhcyBNb2RlbFBhcmFtcyk7XG4gIH07XG5cbiAgLyoqXG4gICAqIFRha2VzIGVhY2ggYXJyYXkgZnJhbWUgd2l0aCBpbnRlcnZhbCBsZW5ndGgsIHRoZW4gYWdncmVnYXRpbmcgdGhlbSB0b2dldGhlciBhcyBmcm9tIHVuaXRzLnlhbWwgZmlsZS5cbiAgICovXG4gIHByaXZhdGUgcmVzYW1wbGVJbnB1dHMoaW5wdXRzOiBNb2RlbFBhcmFtc1tdKSB7XG4gICAgcmV0dXJuIGlucHV0cy5yZWR1Y2UoKGFjYywgX2lucHV0LCBpbmRleCwgaW5wdXRzKSA9PiB7XG4gICAgICBjb25zdCBmcmFtZVN0YXJ0ID0gaW5kZXggKiB0aGlzLmludGVydmFsO1xuICAgICAgY29uc3QgZnJhbWVFbmQgPSAoaW5kZXggKyAxKSAqIHRoaXMuaW50ZXJ2YWw7XG4gICAgICBjb25zdCBpbnB1dHNGcmFtZSA9IGlucHV0cy5zbGljZShmcmFtZVN0YXJ0LCBmcmFtZUVuZCk7XG5cbiAgICAgIGNvbnN0IHJlc2FtcGxlZElucHV0ID0gdGhpcy5yZXNhbXBsZUlucHV0RnJhbWUoaW5wdXRzRnJhbWUpO1xuXG4gICAgICAvKiogQ2hlY2tzIGlmIHJlc2FtcGxlZCBpbnB1dCBpcyBub3QgZW1wdHksIHRoZW4gaW5jbHVkZXMgaW4gcmVzdWx0LiAqL1xuICAgICAgaWYgKE9iamVjdC5rZXlzKHJlc2FtcGxlZElucHV0KS5sZW5ndGggPiAwKSB7XG4gICAgICAgIGFjYy5wdXNoKHJlc2FtcGxlZElucHV0KTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCBbXSBhcyBNb2RlbFBhcmFtc1tdKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQYWRzIHplcm9pc2ggaW5wdXRzIGZyb20gdGhlIGJlZ2lubmluZyBvciBhdCB0aGUgZW5kIG9mIHRoZSBpbnB1dHMgaWYgbmVlZGVkLlxuICAgKi9cbiAgcHJpdmF0ZSBwYWRJbnB1dHMoaW5wdXRzOiBNb2RlbFBhcmFtc1tdLCBwYWQ6IFBhZGRpbmdSZWNlaXB0KTogTW9kZWxQYXJhbXNbXSB7XG4gICAgY29uc3Qge3N0YXJ0LCBlbmR9ID0gcGFkO1xuICAgIGNvbnN0IHBhZGRlZEZyb21CZWdpbm5pbmcgPSBbXTtcblxuICAgIGlmIChzdGFydCkge1xuICAgICAgY29uc3QgZGF0ZVJhbmdlID0gbW9tZW50UmFuZ2UucmFuZ2UoXG4gICAgICAgIG1vbWVudCh0aGlzLnN0YXJ0VGltZSksXG4gICAgICAgIG1vbWVudChpbnB1dHNbMF0udGltZXN0YW1wKS5zdWJ0cmFjdCgxLCAnc2Vjb25kJylcbiAgICAgICk7XG5cbiAgICAgIC8qKiBDaGVja3MgaWYgY29udmVydGluZyB0byB2YWx1ZSBvZiBpcyBuZWVkZWQuICovXG4gICAgICBmb3IgKGNvbnN0IHNlY29uZCBvZiBkYXRlUmFuZ2UuYnkoJ3NlY29uZCcpKSB7XG4gICAgICAgIHBhZGRlZEZyb21CZWdpbm5pbmcucHVzaChcbiAgICAgICAgICB0aGlzLmZpbGxXaXRoWmVyb2lzaElucHV0KGlucHV0c1swXSwgc2Vjb25kLnZhbHVlT2YoKSlcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdCBwYWRkZWRBcnJheSA9IHBhZGRlZEZyb21CZWdpbm5pbmcuY29uY2F0KGlucHV0cyk7XG5cbiAgICBpZiAoZW5kKSB7XG4gICAgICBjb25zdCBsYXN0SW5wdXQgPSBpbnB1dHNbaW5wdXRzLmxlbmd0aCAtIDFdO1xuICAgICAgY29uc3QgZGF0ZVJhbmdlID0gbW9tZW50UmFuZ2UucmFuZ2UoXG4gICAgICAgIG1vbWVudChsYXN0SW5wdXQudGltZXN0YW1wKS5hZGQobGFzdElucHV0LmR1cmF0aW9uLCAnc2Vjb25kcycpLFxuICAgICAgICBtb21lbnQodGhpcy5lbmRUaW1lKVxuICAgICAgKTtcblxuICAgICAgZm9yIChjb25zdCBzZWNvbmQgb2YgZGF0ZVJhbmdlLmJ5KCdzZWNvbmQnKSkge1xuICAgICAgICBwYWRkZWRBcnJheS5wdXNoKFxuICAgICAgICAgIHRoaXMuZmlsbFdpdGhaZXJvaXNoSW5wdXQobGFzdElucHV0LCBzZWNvbmQudmFsdWVPZigpKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBwYWRkZWRBcnJheTtcbiAgfVxuXG4gIC8qXG4gICAqIENoZWNrcyBpZiBpbnB1dCdzIHRpbWVzdGFtcCBpcyBpbmNsdWRlZCBpbiBnbG9iYWwgc3BlY2lmaWVkIHBlcmlvZCB0aGVuIGxlYXZlcyBpdCwgb3RoZXJ3aXNlLlxuICAgKi9cbiAgcHJpdmF0ZSB0cmltSW5wdXRzQnlHbG9iYWxUaW1lbGluZShpbnB1dHM6IE1vZGVsUGFyYW1zW10pOiBNb2RlbFBhcmFtc1tdIHtcbiAgICByZXR1cm4gaW5wdXRzLnJlZHVjZSgoYWNjLCBpdGVtKSA9PiB7XG4gICAgICBjb25zdCB7dGltZXN0YW1wfSA9IGl0ZW07XG5cbiAgICAgIGlmIChcbiAgICAgICAgbW9tZW50KHRpbWVzdGFtcCkuaXNTYW1lT3JBZnRlcihtb21lbnQodGhpcy5zdGFydFRpbWUpKSAmJlxuICAgICAgICBtb21lbnQodGltZXN0YW1wKS5pc1NhbWVPckJlZm9yZShtb21lbnQodGhpcy5lbmRUaW1lKSlcbiAgICAgICkge1xuICAgICAgICBhY2MucHVzaChpdGVtKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCBbXSBhcyBNb2RlbFBhcmFtc1tdKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBOb3JtYWxpemVzIHByb3ZpZGVkIHRpbWUgd2luZG93IGFjY29yZGluZyB0byB0aW1lIGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICBhc3luYyBleGVjdXRlKGlucHV0czogTW9kZWxQYXJhbXNbXSk6IFByb21pc2U8TW9kZWxQYXJhbXNbXT4ge1xuICAgIHRoaXMudmFsaWRhdGVQYXJhbXMoKTtcblxuICAgIGNvbnN0IHBhZCA9IHRoaXMuY2hlY2tGb3JQYWRkaW5nKGlucHV0cyk7XG4gICAgY29uc3QgcGFkZGVkSW5wdXRzID0gdGhpcy5wYWRJbnB1dHMoaW5wdXRzLCBwYWQpO1xuXG4gICAgY29uc3QgZmxhdHRlbklucHV0cyA9IHBhZGRlZElucHV0cy5yZWR1Y2UoKGFjYywgaW5wdXQsIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBjdXJyZW50TW9tZW50ID0gbW9tZW50KGlucHV0LnRpbWVzdGFtcCk7XG5cbiAgICAgIC8qKiBDaGVja3MgaWYgbm90IHRoZSBmaXJzdCBpbnB1dCwgdGhlbiBjaGVjayBjb25zaXN0ZW5jeSB3aXRoIHByZXZpb3VzIG9uZXMuICovXG4gICAgICBpZiAoaW5kZXggPiAwKSB7XG4gICAgICAgIGNvbnN0IHByZXZpb3VzSW5wdXQgPSBwYWRkZWRJbnB1dHNbaW5kZXggLSAxXTtcbiAgICAgICAgY29uc3QgcHJldmlvdXNJbnB1dFRpbWVzdGFtcCA9IG1vbWVudChwcmV2aW91c0lucHV0LnRpbWVzdGFtcCk7XG5cbiAgICAgICAgLyoqIENoZWNrcyBmb3IgdGltZXN0YW1wcyBvdmVybGFwLiAqL1xuICAgICAgICBpZiAoXG4gICAgICAgICAgbW9tZW50KHByZXZpb3VzSW5wdXQudGltZXN0YW1wKVxuICAgICAgICAgICAgLmFkZChwcmV2aW91c0lucHV0LmR1cmF0aW9uLCAnc2Vjb25kcycpXG4gICAgICAgICAgICAuaXNBZnRlcihjdXJyZW50TW9tZW50KVxuICAgICAgICApIHtcbiAgICAgICAgICB0aHJvdyBuZXcgSW5wdXRWYWxpZGF0aW9uRXJyb3IoSU5WQUxJRF9PQlNFUlZBVElPTl9PVkVSTEFQKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGNvbXBhcmVhYmxlVGltZSA9IHByZXZpb3VzSW5wdXRUaW1lc3RhbXAuYWRkKFxuICAgICAgICAgIHByZXZpb3VzSW5wdXQuZHVyYXRpb24sXG4gICAgICAgICAgJ3NlY29uZCdcbiAgICAgICAgKTtcblxuICAgICAgICBjb25zdCB0aW1lbGluZUdhcFNpemUgPSBjdXJyZW50TW9tZW50LmRpZmYoY29tcGFyZWFibGVUaW1lLCAnc2Vjb25kJyk7XG4gICAgICAgIC8vY29uc29sZS5sb2coY3VycmVudE1vbWVudCwgdGltZWxpbmVHYXBTaXplKVxuICAgICAgICAvKiogQ2hlY2tzIGlmIHRoZXJlIGlzIGdhcCBpbiB0aW1lbGluZS4gKi9cbiAgICAgICAgaWYgKHRpbWVsaW5lR2FwU2l6ZSA+IDEpIHtcbiAgICAgICAgICBmb3IgKFxuICAgICAgICAgICAgbGV0IG1pc3NpbmdUaW1lc3RhbXAgPSBjb21wYXJlYWJsZVRpbWUudmFsdWVPZigpO1xuICAgICAgICAgICAgbWlzc2luZ1RpbWVzdGFtcCA8PSBjdXJyZW50TW9tZW50LnZhbHVlT2YoKSAtIDEwMDA7XG4gICAgICAgICAgICBtaXNzaW5nVGltZXN0YW1wICs9IDEwMDBcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIGNvbnN0IGZpbGxlZEdhcCA9IHRoaXMuZmlsbFdpdGhaZXJvaXNoSW5wdXQoXG4gICAgICAgICAgICAgIGlucHV0LFxuICAgICAgICAgICAgICBtaXNzaW5nVGltZXN0YW1wXG4gICAgICAgICAgICApO1xuXG4gICAgICAgICAgICBhY2MucHVzaChmaWxsZWRHYXApO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICAvKiogQnJlYWsgZG93biBjdXJyZW50IG9ic2VydmF0aW9uLiAqL1xuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBpbnB1dC5kdXJhdGlvbjsgaSsrKSB7XG4gICAgICAgIGNvbnN0IG5vcm1hbGl6ZWRJbnB1dCA9IHRoaXMuYnJlYWtEb3duSW5wdXQoaW5wdXQsIGkpO1xuXG4gICAgICAgIGFjYy5wdXNoKG5vcm1hbGl6ZWRJbnB1dCk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzLnRyaW1JbnB1dHNCeUdsb2JhbFRpbWVsaW5lKGFjYyk7XG4gICAgfSwgW10gYXMgTW9kZWxQYXJhbXNbXSk7XG5cbiAgICBjb25zdCBzb3J0ZWRJbnB1dHMgPSBmbGF0dGVuSW5wdXRzLnNvcnQoKGEsIGIpID0+XG4gICAgICBtb21lbnQoYS50aW1lc3RhbXApLmRpZmYobW9tZW50KGIudGltZXN0YW1wKSlcbiAgICApO1xuXG4gICAgcmV0dXJuIHRoaXMucmVzYW1wbGVJbnB1dHMoc29ydGVkSW5wdXRzKTtcbiAgfVxufVxuIl19
@@ -1 +0,0 @@
1
- export type AsyncReturnType<T extends (...args: any) => Promise<any>> = T extends (...args: any) => Promise<infer R> ? R : any;
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9oZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBBc3luY1JldHVyblR5cGU8VCBleHRlbmRzICguLi5hcmdzOiBhbnkpID0+IFByb21pc2U8YW55Pj4gPVxuICBUIGV4dGVuZHMgKC4uLmFyZ3M6IGFueSkgPT4gUHJvbWlzZTxpbmZlciBSPiA/IFIgOiBhbnk7XG4iXX0=
@@ -1,45 +0,0 @@
1
- import { ModelParams } from './model-interface';
2
- import { AggregationResult } from './planet-aggregator';
3
- declare const AGGREGATION_METHODS: string[], AGGREGATION_METRICS: string[];
4
- type Tag = {
5
- kind?: string;
6
- complexity?: string;
7
- category?: string;
8
- };
9
- type Model = {
10
- name: string;
11
- kind?: string;
12
- verbose?: boolean;
13
- path?: string;
14
- config?: Config;
15
- };
16
- export type Config = Record<string, any>;
17
- export type Children = {
18
- [key: string]: {
19
- pipeline: string[];
20
- config: Config;
21
- inputs: ModelParams[];
22
- children: Children;
23
- outputs?: ModelParams[];
24
- 'aggregated-outputs'?: AggregationResult;
25
- };
26
- };
27
- export type AggregationMetrics = (typeof AGGREGATION_METRICS)[number];
28
- export type AggregationMethod = (typeof AGGREGATION_METHODS)[number];
29
- export type Impl = {
30
- name: string;
31
- description: string | null | undefined;
32
- tags: Tag | null | undefined;
33
- initialize: {
34
- models: Model[];
35
- };
36
- graph: {
37
- children: Children;
38
- };
39
- aggregation?: {
40
- 'aggregation-metrics': AggregationMetrics[];
41
- 'aggregation-method': AggregationMethod;
42
- };
43
- 'aggregated-outputs'?: AggregationResult;
44
- };
45
- export {};
@@ -1,5 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const config_1 = require("../config");
4
- const { AGGREGATION_METHODS, AGGREGATION_METRICS } = config_1.CONFIG;
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1wbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9pbXBsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsc0NBQWlDO0FBSWpDLE1BQU0sRUFBQyxtQkFBbUIsRUFBRSxtQkFBbUIsRUFBQyxHQUFHLGVBQU0sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q09ORklHfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHtNb2RlbFBhcmFtc30gZnJvbSAnLi9tb2RlbC1pbnRlcmZhY2UnO1xuaW1wb3J0IHtBZ2dyZWdhdGlvblJlc3VsdH0gZnJvbSAnLi9wbGFuZXQtYWdncmVnYXRvcic7XG5cbmNvbnN0IHtBR0dSRUdBVElPTl9NRVRIT0RTLCBBR0dSRUdBVElPTl9NRVRSSUNTfSA9IENPTkZJRztcblxudHlwZSBUYWcgPSB7XG4gIGtpbmQ/OiBzdHJpbmc7XG4gIGNvbXBsZXhpdHk/OiBzdHJpbmc7XG4gIGNhdGVnb3J5Pzogc3RyaW5nO1xufTtcblxudHlwZSBNb2RlbCA9IHtcbiAgbmFtZTogc3RyaW5nO1xuICBraW5kPzogc3RyaW5nO1xuICB2ZXJib3NlPzogYm9vbGVhbjtcbiAgcGF0aD86IHN0cmluZztcbiAgY29uZmlnPzogQ29uZmlnO1xufTtcblxuZXhwb3J0IHR5cGUgQ29uZmlnID0gUmVjb3JkPHN0cmluZywgYW55PjtcblxuZXhwb3J0IHR5cGUgQ2hpbGRyZW4gPSB7XG4gIFtrZXk6IHN0cmluZ106IHtcbiAgICBwaXBlbGluZTogc3RyaW5nW107XG4gICAgY29uZmlnOiBDb25maWc7XG4gICAgaW5wdXRzOiBNb2RlbFBhcmFtc1tdO1xuICAgIGNoaWxkcmVuOiBDaGlsZHJlbjtcbiAgICBvdXRwdXRzPzogTW9kZWxQYXJhbXNbXTtcbiAgICAnYWdncmVnYXRlZC1vdXRwdXRzJz86IEFnZ3JlZ2F0aW9uUmVzdWx0O1xuICB9O1xufTtcblxuZXhwb3J0IHR5cGUgQWdncmVnYXRpb25NZXRyaWNzID0gKHR5cGVvZiBBR0dSRUdBVElPTl9NRVRSSUNTKVtudW1iZXJdO1xuZXhwb3J0IHR5cGUgQWdncmVnYXRpb25NZXRob2QgPSAodHlwZW9mIEFHR1JFR0FUSU9OX01FVEhPRFMpW251bWJlcl07XG5cbmV4cG9ydCB0eXBlIEltcGwgPSB7XG4gIG5hbWU6IHN0cmluZztcbiAgZGVzY3JpcHRpb246IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQ7XG4gIHRhZ3M6IFRhZyB8IG51bGwgfCB1bmRlZmluZWQ7XG4gIGluaXRpYWxpemU6IHtcbiAgICBtb2RlbHM6IE1vZGVsW107XG4gIH07XG4gIGdyYXBoOiB7XG4gICAgY2hpbGRyZW46IENoaWxkcmVuO1xuICB9O1xuICBhZ2dyZWdhdGlvbj86IHtcbiAgICAnYWdncmVnYXRpb24tbWV0cmljcyc6IEFnZ3JlZ2F0aW9uTWV0cmljc1tdO1xuICAgICdhZ2dyZWdhdGlvbi1tZXRob2QnOiBBZ2dyZWdhdGlvbk1ldGhvZDtcbiAgfTtcbiAgJ2FnZ3JlZ2F0ZWQtb3V0cHV0cyc/OiBBZ2dyZWdhdGlvblJlc3VsdDtcbn07XG4iXX0=
@@ -1,14 +0,0 @@
1
- import { UnitKeyName } from './units';
2
- export type ModelParams = {
3
- [K in UnitKeyName]?: any;
4
- };
5
- export interface ModelPluginInterface {
6
- /**
7
- * Configures instance with given params.
8
- */
9
- configure(params: object | undefined): Promise<ModelPluginInterface>;
10
- /**
11
- * Calculates `output` based on given model's `input`.
12
- */
13
- execute(inputs: ModelParams[]): Promise<ModelParams[]>;
14
- }
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwtaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGVzL21vZGVsLWludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtVbml0S2V5TmFtZX0gZnJvbSAnLi91bml0cyc7XG5cbmV4cG9ydCB0eXBlIE1vZGVsUGFyYW1zID0ge1xuICBbSyBpbiBVbml0S2V5TmFtZV0/OiBhbnk7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIE1vZGVsUGx1Z2luSW50ZXJmYWNlIHtcbiAgLyoqXG4gICAqIENvbmZpZ3VyZXMgaW5zdGFuY2Ugd2l0aCBnaXZlbiBwYXJhbXMuXG4gICAqL1xuICBjb25maWd1cmUocGFyYW1zOiBvYmplY3QgfCB1bmRlZmluZWQpOiBQcm9taXNlPE1vZGVsUGx1Z2luSW50ZXJmYWNlPjtcblxuICAvKipcbiAgICogQ2FsY3VsYXRlcyBgb3V0cHV0YCBiYXNlZCBvbiBnaXZlbiBtb2RlbCdzIGBpbnB1dGAuXG4gICAqL1xuICBleGVjdXRlKGlucHV0czogTW9kZWxQYXJhbXNbXSk6IFByb21pc2U8TW9kZWxQYXJhbXNbXT47XG59XG4iXX0=
@@ -1,23 +0,0 @@
1
- import { ModelPluginInterface } from '../types/model-interface';
2
- export type GraphOptions = {
3
- 'core-units': number;
4
- 'physical-processor': string;
5
- };
6
- export type ImplInitializeModel = {
7
- config?: Record<string, any>;
8
- name: string;
9
- model?: string;
10
- path?: string;
11
- };
12
- export type InitalizedModels = {
13
- [key: string]: (graphOptions: GraphOptions) => Promise<ModelPluginInterface>;
14
- };
15
- export type HandModelParams = {
16
- name: string;
17
- model?: string;
18
- path?: string;
19
- };
20
- export type ClassContainerParams = {
21
- model: string;
22
- path: string;
23
- };
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWxzLXVuaXZlcnNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGVzL21vZGVscy11bml2ZXJzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtNb2RlbFBsdWdpbkludGVyZmFjZX0gZnJvbSAnLi4vdHlwZXMvbW9kZWwtaW50ZXJmYWNlJztcblxuZXhwb3J0IHR5cGUgR3JhcGhPcHRpb25zID0ge1xuICAnY29yZS11bml0cyc6IG51bWJlcjtcbiAgJ3BoeXNpY2FsLXByb2Nlc3Nvcic6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEltcGxJbml0aWFsaXplTW9kZWwgPSB7XG4gIGNvbmZpZz86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIG5hbWU6IHN0cmluZztcbiAgbW9kZWw/OiBzdHJpbmc7XG4gIHBhdGg/OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBJbml0YWxpemVkTW9kZWxzID0ge1xuICBba2V5OiBzdHJpbmddOiAoZ3JhcGhPcHRpb25zOiBHcmFwaE9wdGlvbnMpID0+IFByb21pc2U8TW9kZWxQbHVnaW5JbnRlcmZhY2U+O1xufTtcblxuZXhwb3J0IHR5cGUgSGFuZE1vZGVsUGFyYW1zID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIG1vZGVsPzogc3RyaW5nO1xuICBwYXRoPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgQ2xhc3NDb250YWluZXJQYXJhbXMgPSB7XG4gIG1vZGVsOiBzdHJpbmc7XG4gIHBhdGg6IHN0cmluZztcbn07XG4iXX0=
@@ -1,6 +0,0 @@
1
- import { AggregationMethod, AggregationMetrics } from './impl';
2
- export type PlanetAggregatorParams = {
3
- 'aggregation-metrics': AggregationMetrics[];
4
- 'aggregation-method': AggregationMethod;
5
- };
6
- export type AggregationResult = Record<string, number>;