@grnsft/if 0.1.3 → 0.1.5

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 (134) hide show
  1. package/README.md +21 -2
  2. package/build/config/config.d.ts +12 -0
  3. package/build/config/config.js +54 -0
  4. package/build/config/index.d.ts +2 -0
  5. package/build/config/index.js +8 -0
  6. package/build/config/strings.d.ts +19 -0
  7. package/build/config/strings.js +34 -0
  8. package/build/index.d.ts +2 -0
  9. package/build/index.js +53 -0
  10. package/build/lib/models-universe.d.ts +36 -0
  11. package/build/lib/models-universe.js +113 -0
  12. package/build/lib/observatory.d.ts +20 -0
  13. package/build/lib/observatory.js +31 -0
  14. package/build/lib/planet-aggregator.d.ts +6 -0
  15. package/build/lib/planet-aggregator.js +35 -0
  16. package/build/lib/supercomputer.d.ts +37 -0
  17. package/build/lib/supercomputer.js +148 -0
  18. package/build/models/index.d.ts +1 -0
  19. package/build/models/index.js +6 -0
  20. package/build/models/time-sync.d.ts +55 -0
  21. package/build/models/time-sync.js +235 -0
  22. package/build/types/helpers.d.ts +1 -0
  23. package/build/types/helpers.js +3 -0
  24. package/build/types/impl.d.ts +45 -0
  25. package/build/types/impl.js +5 -0
  26. package/build/types/model-interface.d.ts +14 -0
  27. package/build/types/model-interface.js +3 -0
  28. package/build/types/models-universe.d.ts +23 -0
  29. package/build/types/models-universe.js +3 -0
  30. package/build/types/planet-aggregator.d.ts +6 -0
  31. package/build/types/planet-aggregator.js +3 -0
  32. package/build/types/process-args.d.ts +7 -0
  33. package/build/types/process-args.js +3 -0
  34. package/build/types/supercomputer.d.ts +4 -0
  35. package/build/types/supercomputer.js +3 -0
  36. package/build/types/time-sync.d.ts +9 -0
  37. package/build/types/time-sync.js +3 -0
  38. package/build/types/units-dealer.d.ts +3 -0
  39. package/build/types/units-dealer.js +3 -0
  40. package/build/types/units.d.ts +11 -0
  41. package/build/types/units.js +37 -0
  42. package/build/util/args.d.ts +8 -0
  43. package/build/util/args.js +58 -0
  44. package/build/util/errors.d.ts +6 -0
  45. package/build/util/errors.js +25 -0
  46. package/build/util/helpers.d.ts +4 -0
  47. package/build/util/helpers.js +18 -0
  48. package/build/util/units-dealer.d.ts +10 -0
  49. package/build/util/units-dealer.js +32 -0
  50. package/build/util/validations.d.ts +29 -0
  51. package/build/util/validations.js +80 -0
  52. package/build/util/yaml.d.ts +12 -0
  53. package/build/util/yaml.js +36 -0
  54. package/examples/impls/test/time-sync.yml +75 -0
  55. package/examples/ompls/test/time-sync.yml +255 -0
  56. package/examples/ompls/time-sync.yml +212 -0
  57. package/hack-banner.png +0 -0
  58. package/package.json +3 -1
  59. package/src/config/units.yaml +11 -24
  60. package/src/models/README.md +266 -0
  61. package/tsconfig.build.tsbuildinfo +1 -1
  62. package/.devcontainer/devcontainer.json +0 -38
  63. package/.examples/ompls/azure.yml +0 -205
  64. package/.github/ISSUE_TEMPLATE/agenda.md +0 -37
  65. package/.github/ISSUE_TEMPLATE/blank-issue.md +0 -10
  66. package/.github/ISSUE_TEMPLATE/bug-report.md +0 -32
  67. package/.github/ISSUE_TEMPLATE/dev-ticket.md +0 -44
  68. package/.github/ISSUE_TEMPLATE/feedback.md +0 -42
  69. package/.github/ISSUE_TEMPLATE/model-plugin.md +0 -63
  70. package/.github/ISSUE_TEMPLATE/sprint-planning.md +0 -39
  71. package/.github/ISSUE_TEMPLATE/sprint-retro.md +0 -41
  72. package/.github/ISSUE_TEMPLATE/user-story.md +0 -10
  73. package/.github/PULL_REQUEST_TEMPLATE.md +0 -21
  74. package/.github/workflows/nodejs-ci.yml +0 -26
  75. package/coverage/clover.xml +0 -237
  76. package/coverage/coverage-final.json +0 -11
  77. package/coverage/lcov-report/base.css +0 -224
  78. package/coverage/lcov-report/block-navigation.js +0 -87
  79. package/coverage/lcov-report/config/config.ts.html +0 -256
  80. package/coverage/lcov-report/config/index.html +0 -146
  81. package/coverage/lcov-report/config/index.ts.html +0 -91
  82. package/coverage/lcov-report/config/strings.ts.html +0 -187
  83. package/coverage/lcov-report/favicon.png +0 -0
  84. package/coverage/lcov-report/index.html +0 -146
  85. package/coverage/lcov-report/lib/boavizta/index.html +0 -116
  86. package/coverage/lcov-report/lib/boavizta/index.ts.html +0 -1171
  87. package/coverage/lcov-report/lib/case-studies/aveva-model.ts.html +0 -277
  88. package/coverage/lcov-report/lib/case-studies/emem-model.ts.html +0 -439
  89. package/coverage/lcov-report/lib/case-studies/eshoppen-model.ts.html +0 -550
  90. package/coverage/lcov-report/lib/case-studies/index.html +0 -176
  91. package/coverage/lcov-report/lib/case-studies/index.ts.html +0 -97
  92. package/coverage/lcov-report/lib/case-studies/sci-accenture-model.ts.html +0 -232
  93. package/coverage/lcov-report/lib/ccf/index.html +0 -116
  94. package/coverage/lcov-report/lib/ccf/index.ts.html +0 -1339
  95. package/coverage/lcov-report/lib/cloud-instance-metadata/index.html +0 -116
  96. package/coverage/lcov-report/lib/cloud-instance-metadata/index.ts.html +0 -370
  97. package/coverage/lcov-report/lib/index.html +0 -161
  98. package/coverage/lcov-report/lib/index.ts.html +0 -121
  99. package/coverage/lcov-report/lib/models-universe.ts.html +0 -475
  100. package/coverage/lcov-report/lib/observatory.ts.html +0 -187
  101. package/coverage/lcov-report/lib/planet-aggregator.ts.html +0 -253
  102. package/coverage/lcov-report/lib/sci/index.html +0 -116
  103. package/coverage/lcov-report/lib/sci/index.ts.html +0 -571
  104. package/coverage/lcov-report/lib/sci-e/index.html +0 -116
  105. package/coverage/lcov-report/lib/sci-e/index.ts.html +0 -403
  106. package/coverage/lcov-report/lib/sci-m/index.html +0 -116
  107. package/coverage/lcov-report/lib/sci-m/index.ts.html +0 -487
  108. package/coverage/lcov-report/lib/sci-o/index.html +0 -116
  109. package/coverage/lcov-report/lib/sci-o/index.ts.html +0 -265
  110. package/coverage/lcov-report/lib/shell-imp/index.html +0 -116
  111. package/coverage/lcov-report/lib/shell-imp/index.ts.html +0 -376
  112. package/coverage/lcov-report/lib/supercomputer.ts.html +0 -712
  113. package/coverage/lcov-report/lib/teads-aws/index.html +0 -116
  114. package/coverage/lcov-report/lib/teads-aws/index.ts.html +0 -823
  115. package/coverage/lcov-report/lib/teads-curve/index.html +0 -116
  116. package/coverage/lcov-report/lib/teads-curve/index.ts.html +0 -625
  117. package/coverage/lcov-report/lib/watt-time/index.html +0 -116
  118. package/coverage/lcov-report/lib/watt-time/index.ts.html +0 -829
  119. package/coverage/lcov-report/prettify.css +0 -1
  120. package/coverage/lcov-report/prettify.js +0 -2
  121. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  122. package/coverage/lcov-report/sorter.js +0 -196
  123. package/coverage/lcov-report/types/common.ts.html +0 -109
  124. package/coverage/lcov-report/types/index.html +0 -116
  125. package/coverage/lcov-report/util/args.ts.html +0 -259
  126. package/coverage/lcov-report/util/errors.ts.html +0 -160
  127. package/coverage/lcov-report/util/index.html +0 -146
  128. package/coverage/lcov-report/util/models-universe.ts.html +0 -679
  129. package/coverage/lcov-report/util/observatory.ts.html +0 -229
  130. package/coverage/lcov-report/util/supercomputer.ts.html +0 -466
  131. package/coverage/lcov-report/util/yaml.ts.html +0 -199
  132. package/coverage/lcov.info +0 -403
  133. package/scripts/impact-test.sh +0 -12
  134. package/yarn-error.log +0 -5431
@@ -0,0 +1,148 @@
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwZXJjb21wdXRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvc3VwZXJjb21wdXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSwrQ0FBMEM7QUFDMUMsMkRBQXFEO0FBRXJELDJDQUFzQztBQUV0QyxzQ0FBa0M7QUFPbEMsTUFBTSxFQUFDLG1CQUFtQixFQUFDLEdBQUcsZUFBTSxDQUFDO0FBRXJDLE1BQU0sRUFBQyxtQkFBbUIsRUFBQyxHQUFHLGdCQUFPLENBQUM7QUFFdEM7O0dBRUc7QUFDSCxNQUFhLGFBQWE7SUFPeEIsWUFBWSxJQUFVLEVBQUUsY0FBOEI7UUFOOUMsZUFBVSxHQUFxQixFQUFDLElBQUksRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBQyxDQUFDO1FBR3BELHNCQUFpQixHQUF3QixFQUFFLENBQUM7UUFDNUMsZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFHdEIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7SUFDdkMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksb0JBQW9CO1FBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUMxQixNQUFNLElBQUksbUJBQW1CLENBQUMsc0NBQXNDLENBQUMsQ0FBQztTQUN2RTtRQUVELE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFFM0QsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsRUFBRTtZQUMxRCxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBRWpDLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ2pCLEdB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QUM3QjtTQUNGO1FBRUQsSUFBSSxpQkFBaUIsRUFBRTtZQUNyQixJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQ3JELFNBQVMsQ0FDVixDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7U0FDckI7YUFBTTtZQUNMLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7U0FDbEU7UUFFRCxPQUFPO0lBQ1QsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLE9BQU8sQ0FBQyxjQUFvQjtRQUN2QyxNQUFNLGNBQWMsR0FBRyxjQUFjLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQztRQUNuRCxNQUFNLGlCQUFpQixHQUFHLENBQUMsQ0FBQyxjQUFjLENBQUM7UUFDM0MsTUFBTSxRQUFRLEdBQWEsaUJBQWlCO1lBQzFDLENBQUMsQ0FBQyxjQUFjO1lBQ2hCLENBQUMsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUNsQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRTVDLEtBQUssTUFBTSxTQUFTLElBQUksYUFBYSxFQUFFO1lBQ3JDLE1BQU0sSUFBSSxDQUFDLHdCQUF3QixDQUFDLFFBQVEsRUFBRTtnQkFDNUMsU0FBUztnQkFDVCxpQkFBaUI7YUFDbEIsQ0FBQyxDQUFDO1NBQ0o7UUFFRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztDQUNGO0FBNUxELHNDQTRMQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TW9kZWxzVW5pdmVyc2V9IGZyb20gJy4vbW9kZWxzLXVuaXZlcnNlJztcbmltcG9ydCB7T2JzZXJ2YXRvcnl9IGZyb20gJy4vb2JzZXJ2YXRvcnknO1xuaW1wb3J0IHtwbGFuZXRBZ2dyZWdhdG9yfSBmcm9tICcuL3BsYW5ldC1hZ2dyZWdhdG9yJztcblxuaW1wb3J0IHtFUlJPUlN9IGZyb20gJy4uL3V0aWwvZXJyb3JzJztcblxuaW1wb3J0IHtTVFJJTkdTfSBmcm9tICcuLi9jb25maWcnO1xuXG5pbXBvcnQge0NoaWxkcmVuLCBDb25maWcsIEltcGx9IGZyb20gJy4uL3R5cGVzL2ltcGwnO1xuaW1wb3J0IHtNb2RlbFBhcmFtc30gZnJvbSAnLi4vdHlwZXMvbW9kZWwtaW50ZXJmYWNlJztcbmltcG9ydCB7QWdncmVnYXRpb25SZXN1bHR9IGZyb20gJy4uL3R5cGVzL3BsYW5ldC1hZ2dyZWdhdG9yJztcbmltcG9ydCB7Q2hpbGRJbmZvcm1hdGlvbn0gZnJvbSAnLi4vdHlwZXMvc3VwZXJjb21wdXRlcic7XG5cbmNvbnN0IHtJbXBsVmFsaWRhdGlvbkVycm9yfSA9IEVSUk9SUztcblxuY29uc3Qge1NUUlVDVFVSRV9NQUxGT1JNRUR9ID0gU1RSSU5HUztcblxuLyoqXG4gKiBDb21wdXRlciBmb3IgYGltcGxgIGRvY3VtZW50cy5cbiAqL1xuZXhwb3J0IGNsYXNzIFN1cGVyY29tcHV0ZXIge1xuICBwcml2YXRlIG9sZGVyQ2hpbGQ6IENoaWxkSW5mb3JtYXRpb24gPSB7bmFtZTogJycsIGluZm86IHt9fTtcbiAgcHJpdmF0ZSBpbXBsOiBJbXBsO1xuICBwcml2YXRlIG1vZGVsc0hhbmRib29rOiBNb2RlbHNVbml2ZXJzZTtcbiAgcHJpdmF0ZSBhZ2dyZWdhdGVkSW1wYWN0czogQWdncmVnYXRpb25SZXN1bHRbXSA9IFtdO1xuICBwcml2YXRlIGNoaWxkQW1vdW50ID0gMDtcblxuICBjb25zdHJ1Y3RvcihpbXBsOiBJbXBsLCBtb2RlbHNIYW5kYm9vazogTW9kZWxzVW5pdmVyc2UpIHtcbiAgICB0aGlzLmltcGwgPSBpbXBsO1xuICAgIHRoaXMubW9kZWxzSGFuZGJvb2sgPSBtb2RlbHNIYW5kYm9vaztcbiAgfVxuXG4gIC8qKlxuICAgKiBHb2VzIHRocm91Z2ggYWxsIGFnZ3JlZ2F0aW9ucyBjb2xsZWN0ZWQgZnJvbSBjaGlsZCBjb21wb25lbnRzLCB0aGVuIGNhbGN1bGF0ZXMgdGhlIGF2ZXJhZ2UuXG4gICAqL1xuICBwdWJsaWMgY2FsY3VsYXRlQWdncmVnYXRpb24oKSB7XG4gICAgaWYgKCF0aGlzLmltcGwuYWdncmVnYXRpb24pIHtcbiAgICAgIHRocm93IG5ldyBJbXBsVmFsaWRhdGlvbkVycm9yKCdBZ2dyZWdhdGlvbiBwYXJhbXMgYXJlIG5vdCBwcm92aWRlZC4nKTtcbiAgICB9XG5cbiAgICBjb25zdCBtZXRob2QgPSB0aGlzLmltcGwuYWdncmVnYXRpb25bJ2FnZ3JlZ2F0aW9uLW1ldGhvZCddO1xuXG4gICAgcmV0dXJuIHRoaXMuYWdncmVnYXRlZEltcGFjdHMucmVkdWNlKChhY2MsIGltcGFjdCwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGtleXMgPSBPYmplY3Qua2V5cyhpbXBhY3QpO1xuXG4gICAgICBrZXlzLmZvckVhY2goa2V5ID0+IHtcbiAgICAgICAgYWNjW2tleV0gPSBhY2Nba2V5XSA/PyAwO1xuICAgICAgICBhY2Nba2V5XSArPSBpbXBhY3Rba2V5XTtcblxuICAgICAgICBpZiAoaW5kZXggPT09IHRoaXMuY2hpbGRBbW91bnQgLSAxKSB7XG4gICAgICAgICAgaWYgKG1ldGhvZCA9PT0gJ2F2ZycpIHtcbiAgICAgICAgICAgIGFjY1trZXldIC89IHRoaXMuY2hpbGRBbW91bnQ7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9KTtcblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSk7XG4gIH1cblxuICAvKipcbiAgICogRmxhdHRlbnMgY29uZmlnIGVudHJpZXMuXG4gICAqL1xuICBwcml2YXRlIGZsYXR0ZW5Db25maWdWYWx1ZXMoY29uZmlnOiBDb25maWcpIHtcbiAgICBpZiAoIWNvbmZpZykge1xuICAgICAgcmV0dXJuIHt9O1xuICAgIH1cblxuICAgIGNvbnN0IGNvbmZpZ01vZGVsTmFtZXMgPSBPYmplY3Qua2V5cyhjb25maWcpO1xuICAgIGNvbnN0IHZhbHVlcyA9IGNvbmZpZ01vZGVsTmFtZXMucmVkdWNlKChhY2M6IGFueSwgbmFtZTogc3RyaW5nKSA9PiB7XG4gICAgICBhY2MgPSB7XG4gICAgICAgIC4uLmFjYyxcbiAgICAgICAgLi4uY29uZmlnW25hbWVdLFxuICAgICAgfTtcblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSk7XG5cbiAgICByZXR1cm4gdmFsdWVzO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgY29uZmlnIGVudHJpZXMgdG8gZWFjaCBvYnNlcmNhdGlvbiBvYmplY3QgcGFzc2VkLlxuICAgKi9cbiAgcHJpdmF0ZSBlbnJpY2hJbnB1dHMoXG4gICAgaW5wdXRzOiBNb2RlbFBhcmFtc1tdLFxuICAgIGNvbmZpZzogQ29uZmlnLFxuICAgIG5lc3RlZENvbmZpZzogQ29uZmlnXG4gICkge1xuICAgIGNvbnN0IGNvbmZpZ1ZhbHVlcyA9IHRoaXMuZmxhdHRlbkNvbmZpZ1ZhbHVlcyhjb25maWcpO1xuICAgIGNvbnN0IG5lc3RlZENvbmZpZ1ZhbHVlcyA9IHRoaXMuZmxhdHRlbkNvbmZpZ1ZhbHVlcyhuZXN0ZWRDb25maWcpO1xuXG4gICAgcmV0dXJuIGlucHV0cy5tYXAoKGlucHV0OiBhbnkpID0+ICh7XG4gICAgICAuLi5pbnB1dCxcbiAgICAgIC4uLmNvbmZpZ1ZhbHVlcyxcbiAgICAgIC4uLm5lc3RlZENvbmZpZ1ZhbHVlcyxcbiAgICB9KSk7XG4gIH1cblxuICAvKipcbiAgICogSWYgY2hpbGQgaXMgdG9wIGxldmVsLCB0aGVuIGluaXRpYWxpemVzIGB0aGlzLm9sZGVyQ2hpbGRgLlxuICAgKiBJZiBgY2hpbGRyZW5gIG9iamVjdCBjb250YWlucyBgY2hpbGRyZW5gIHByb3BlcnR5LCBpdCBtZWFucyBpbnB1dHMgYXJlIG5lc3RlZCAoY2FsbHMgY29tcHV0ZSBhZ2FpbikuXG4gICAqIE90aGVyd2lzZSBlbnJpY2hlcyBpbnB1dHMsIHBhc3NlcyB0aGVtIHRvIE9ic2VydmF0b3J5LlxuICAgKiBGb3IgZWFjaCBtb2RlbCBmcm9tIHBpcGVsaW5lIE9ic2VydmF0b3J5IGdhdGhlcnMgaW5wdXRzLiBUaGVuIHJlc3VsdHMgYXJlIHN0b3JlZC5cbiAgICovXG4gIHByaXZhdGUgYXN5bmMgY2FsY3VsYXRlT3V0cHV0c0ZvckNoaWxkKFxuICAgIGNoaWxkcmVuT2JqZWN0OiBDaGlsZHJlbixcbiAgICBwYXJhbXM6IGFueVxuICApIHtcbiAgICBjb25zdCB7Y2hpbGROYW1lLCBhcmVDaGlsZHJlbk5lc3RlZH0gPSBwYXJhbXM7XG5cbiAgICBpZiAoIWFyZUNoaWxkcmVuTmVzdGVkKSB7XG4gICAgICB0aGlzLm9sZGVyQ2hpbGQgPSB7XG4gICAgICAgIG5hbWU6IGNoaWxkTmFtZSxcbiAgICAgICAgaW5mbzogdGhpcy5pbXBsLmdyYXBoLmNoaWxkcmVuW2NoaWxkTmFtZV0sXG4gICAgICB9O1xuICAgIH1cblxuICAgIGNvbnN0IHtwaXBlbGluZSwgaW5wdXRzLCBjb25maWd9ID0gdGhpcy5vbGRlckNoaWxkLmluZm87XG5cbiAgICBpZiAoJ2NoaWxkcmVuJyBpbiBjaGlsZHJlbk9iamVjdFtjaGlsZE5hbWVdKSB7XG4gICAgICByZXR1cm4gdGhpcy5jb21wdXRlKGNoaWxkcmVuT2JqZWN0W2NoaWxkTmFtZV0uY2hpbGRyZW4pO1xuICAgIH1cblxuICAgIGlmICghKCdpbnB1dHMnIGluIGNoaWxkcmVuT2JqZWN0W2NoaWxkTmFtZV0pKSB7XG4gICAgICB0aHJvdyBuZXcgSW1wbFZhbGlkYXRpb25FcnJvcihTVFJVQ1RVUkVfTUFMRk9STUVEKGNoaWxkTmFtZSkpO1xuICAgIH1cblxuICAgIHRoaXMuY2hpbGRBbW91bnQrKztcblxuICAgIGNvbnN0IHNwZWNpZmljSW5wdXRzID0gYXJlQ2hpbGRyZW5OZXN0ZWRcbiAgICAgID8gY2hpbGRyZW5PYmplY3RbY2hpbGROYW1lXS5pbnB1dHNcbiAgICAgIDogaW5wdXRzO1xuXG4gICAgY29uc3QgY2hpbGRyZW5Db25maWcgPSBjaGlsZHJlbk9iamVjdFtjaGlsZE5hbWVdLmNvbmZpZyB8fCB7fTtcblxuICAgIGNvbnN0IGVucmljaGVkSW5wdXRzID0gdGhpcy5lbnJpY2hJbnB1dHMoXG4gICAgICBzcGVjaWZpY0lucHV0cyxcbiAgICAgIGNvbmZpZyxcbiAgICAgIGNoaWxkcmVuQ29uZmlnXG4gICAgKTtcblxuICAgIGNvbnN0IG9ic2VydmF0b3J5ID0gbmV3IE9ic2VydmF0b3J5KGVucmljaGVkSW5wdXRzKTtcblxuICAgIGZvciAoY29uc3QgbW9kZWxOYW1lIG9mIHBpcGVsaW5lKSB7XG4gICAgICBjb25zdCBwYXJhbXMgPSBjb25maWcgJiYgY29uZmlnW21vZGVsTmFtZV07XG4gICAgICBjb25zdCBtb2RlbEluc3RhbmNlID0gYXdhaXQgdGhpcy5tb2RlbHNIYW5kYm9vay5nZXRJbml0aWFsaXplZE1vZGVsKFxuICAgICAgICBtb2RlbE5hbWUsXG4gICAgICAgIHBhcmFtc1xuICAgICAgKTtcblxuICAgICAgYXdhaXQgb2JzZXJ2YXRvcnkuZG9JbnZlc3RpZ2F0aW9uc1dpdGgobW9kZWxJbnN0YW5jZSk7XG4gICAgfVxuXG4gICAgY29uc3Qgb3V0cHV0cyA9IG9ic2VydmF0b3J5LmdldE91dHB1dHMoKTtcblxuICAgIC8qKlxuICAgICAqIElmIGFnZ3JlZ2F0aW9uIGlzIHJlcXVpcmVkLCB0aGVuIGluaXQgYGFnZ3JlZ2F0ZWQtb3V0cHV0c2AuXG4gICAgICovXG4gICAgaWYgKHRoaXMuaW1wbC5hZ2dyZWdhdGlvbikge1xuICAgICAgY29uc3QgYWdncmVnYXRlZEltcGFjdHNQZXJDaGlsZCA9IHBsYW5ldEFnZ3JlZ2F0b3IoXG4gICAgICAgIG91dHB1dHMsXG4gICAgICAgIHRoaXMuaW1wbC5hZ2dyZWdhdGlvblxuICAgICAgKTtcblxuICAgICAgdGhpcy5hZ2dyZWdhdGVkSW1wYWN0cy5wdXNoKGFnZ3JlZ2F0ZWRJbXBhY3RzUGVyQ2hpbGQpO1xuXG4gICAgICBpZiAoYXJlQ2hpbGRyZW5OZXN0ZWQpIHtcbiAgICAgICAgdGhpcy5pbXBsLmdyYXBoLmNoaWxkcmVuW3RoaXMub2xkZXJDaGlsZC5uYW1lXS5jaGlsZHJlbltjaGlsZE5hbWVdW1xuICAgICAgICAgICdhZ2dyZWdhdGVkLW91dHB1dHMnXG4gICAgICAgIF0gPSBhZ2dyZWdhdGVkSW1wYWN0c1BlckNoaWxkO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5pbXBsLmdyYXBoLmNoaWxkcmVuW3RoaXMub2xkZXJDaGlsZC5uYW1lXVsnYWdncmVnYXRlZC1vdXRwdXRzJ10gPVxuICAgICAgICAgIGFnZ3JlZ2F0ZWRJbXBhY3RzUGVyQ2hpbGQ7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGFyZUNoaWxkcmVuTmVzdGVkKSB7XG4gICAgICB0aGlzLmltcGwuZ3JhcGguY2hpbGRyZW5bdGhpcy5vbGRlckNoaWxkLm5hbWVdLmNoaWxkcmVuW1xuICAgICAgICBjaGlsZE5hbWVcbiAgICAgIF0ub3V0cHV0cyA9IG91dHB1dHM7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuaW1wbC5ncmFwaC5jaGlsZHJlblt0aGlzLm9sZGVyQ2hpbGQubmFtZV0ub3V0cHV0cyA9IG91dHB1dHM7XG4gICAgfVxuXG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyBpZiBvYmplY3QgaXMgdG9wIGxldmVsIGNoaWxkcmVuIG9yIG5lc3RlZCwgdGhlbiBydW5zIHRocm91Z2ggYWxsIGNoaWxkcmVuIGFuZCBjYWxjdWxhdGVzIG91dHB1dHMuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgY29tcHV0ZShjaGlsZHJlbk9iamVjdD86IGFueSkge1xuICAgIGNvbnN0IGltcGxPckNoaWxkcmVuID0gY2hpbGRyZW5PYmplY3QgfHwgdGhpcy5pbXBsO1xuICAgIGNvbnN0IGFyZUNoaWxkcmVuTmVzdGVkID0gISFjaGlsZHJlbk9iamVjdDtcbiAgICBjb25zdCBjaGlsZHJlbjogQ2hpbGRyZW4gPSBhcmVDaGlsZHJlbk5lc3RlZFxuICAgICAgPyBpbXBsT3JDaGlsZHJlblxuICAgICAgOiBpbXBsT3JDaGlsZHJlbi5ncmFwaC5jaGlsZHJlbjtcbiAgICBjb25zdCBjaGlsZHJlbk5hbWVzID0gT2JqZWN0LmtleXMoY2hpbGRyZW4pO1xuXG4gICAgZm9yIChjb25zdCBjaGlsZE5hbWUgb2YgY2hpbGRyZW5OYW1lcykge1xuICAgICAgYXdhaXQgdGhpcy5jYWxjdWxhdGVPdXRwdXRzRm9yQ2hpbGQoY2hpbGRyZW4sIHtcbiAgICAgICAgY2hpbGROYW1lLFxuICAgICAgICBhcmVDaGlsZHJlbk5lc3RlZCxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmltcGw7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1 @@
1
+ export { TimeSyncModel } from './time-sync';
@@ -0,0 +1,6 @@
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==
@@ -0,0 +1,55 @@
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
+ }
@@ -0,0 +1,235 @@
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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LEVBQUUsRUFDaEQsZ0JBQWdCLElBQUksYUFBYSxDQUFDLE9BQU8sRUFBRSxHQUFHLElBQUksRUFDbEQsZ0JBQWdCLElBQUksSUFBSSxFQUN4Qjt3QkFDQSxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQ3pDLEtBQUssRUFDTCxnQkFBZ0IsQ0FDakIsQ0FBQzt3QkFFRixHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO3FCQUNyQjtpQkFDRjthQUNGO1lBRUQsc0NBQXNDO1lBQ3RDLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFO2dCQUN2QyxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztnQkFFdEQsR0FBRyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQzthQUMzQjtZQUVELE9BQU8sSUFBSSxDQUFDLDBCQUEwQixDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzlDLENBQUMsRUFBRSxFQUFtQixDQUFDLENBQUM7UUFFeEIsTUFBTSxZQUFZLEdBQUcsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUMvQyxNQUFNLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQzlDLENBQUM7UUFFRixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDM0MsQ0FBQztDQUNGO0FBNVRELHNDQTRUQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBtb21lbnQgPSByZXF1aXJlKCdtb21lbnQnKTtcbmltcG9ydCB7ZXh0ZW5kTW9tZW50fSBmcm9tICdtb21lbnQtcmFuZ2UnO1xuXG5pbXBvcnQge1NUUklOR1N9IGZyb20gJy4uL2NvbmZpZyc7XG5cbmltcG9ydCB7RVJST1JTfSBmcm9tICcuLi91dGlsL2Vycm9ycyc7XG5pbXBvcnQge1VuaXRzRGVhbGVyfSBmcm9tICcuLi91dGlsL3VuaXRzLWRlYWxlcic7XG5cbmltcG9ydCB7TW9kZWxQYXJhbXMsIE1vZGVsUGx1Z2luSW50ZXJmYWNlfSBmcm9tICcuLi90eXBlcy9tb2RlbC1pbnRlcmZhY2UnO1xuaW1wb3J0IHtQYWRkaW5nUmVjZWlwdCwgVGltZU5vcm1hbGl6ZXJDb25maWd9IGZyb20gJy4uL3R5cGVzL3RpbWUtc3luYyc7XG5pbXBvcnQge1VuaXRzRGVhbGVyVXNhZ2V9IGZyb20gJy4uL3R5cGVzL3VuaXRzLWRlYWxlcic7XG5pbXBvcnQge1VuaXRLZXlOYW1lfSBmcm9tICcuLi90eXBlcy91bml0cyc7XG5cbmNvbnN0IG1vbWVudFJhbmdlID0gZXh0ZW5kTW9tZW50KG1vbWVudCk7XG5cbmNvbnN0IHtJbnB1dFZhbGlkYXRpb25FcnJvcn0gPSBFUlJPUlM7XG5cbmNvbnN0IHtcbiAgSU5WQUxJRF9USU1FX05PUk1BTElaQVRJT04sXG4gIElOVkFMSURfVElNRV9JTlRFUlZBTCxcbiAgSU5WQUxJRF9PQlNFUlZBVElPTl9PVkVSTEFQLFxufSA9IFNUUklOR1M7XG5cbmV4cG9ydCBjbGFzcyBUaW1lU3luY01vZGVsIGltcGxlbWVudHMgTW9kZWxQbHVnaW5JbnRlcmZhY2Uge1xuICBzdGFydFRpbWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgZW5kVGltZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBkZWFsZXIhOiBVbml0c0RlYWxlclVzYWdlO1xuICBpbnRlcnZhbCA9IDE7XG5cbiAgLyoqXG4gICAqIFNldHVwcyBiYXNpYyBjb25maWd1cmF0aW9uLlxuICAgKi9cbiAgYXN5bmMgY29uZmlndXJlKHBhcmFtczogVGltZU5vcm1hbGl6ZXJDb25maWcpOiBQcm9taXNlPE1vZGVsUGx1Z2luSW50ZXJmYWNlPiB7XG4gICAgdGhpcy5zdGFydFRpbWUgPSBwYXJhbXNbJ3N0YXJ0LXRpbWUnXTtcbiAgICB0aGlzLmVuZFRpbWUgPSBwYXJhbXNbJ2VuZC10aW1lJ107XG4gICAgdGhpcy5pbnRlcnZhbCA9IHBhcmFtcy5pbnRlcnZhbDtcbiAgICB0aGlzLmRlYWxlciA9IGF3YWl0IFVuaXRzRGVhbGVyKCk7XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBWYWxpZGF0ZXMgYHN0YXJ0VGltZWAsIGBlbmRUaW1lYCBhbmQgYGludGVydmFsYCBwYXJhbXMuXG4gICAqL1xuICBwcml2YXRlIHZhbGlkYXRlUGFyYW1zKCkge1xuICAgIGlmICghdGhpcy5zdGFydFRpbWUgfHwgIXRoaXMuZW5kVGltZSkge1xuICAgICAgdGhyb3cgbmV3IElucHV0VmFsaWRhdGlvbkVycm9yKElOVkFMSURfVElNRV9OT1JNQUxJWkFUSU9OKTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5zdGFydFRpbWUgPiB0aGlzLmVuZFRpbWUpIHtcbiAgICAgIHRocm93IG5ldyBJbnB1dFZhbGlkYXRpb25FcnJvcihJTlZBTElEX1RJTUVfTk9STUFMSVpBVElPTik7XG4gICAgfVxuXG4gICAgaWYgKCF0aGlzLmludGVydmFsKSB7XG4gICAgICB0aHJvdyBuZXcgSW5wdXRWYWxpZGF0aW9uRXJyb3IoSU5WQUxJRF9USU1FX0lOVEVSVkFMKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQ2FsY3VsYXRlcyBtaW5pbWFsIGZhY3Rvci5cbiAgICovXG4gIHByaXZhdGUgY29udmVydFBlckludGVydmFsID0gKHZhbHVlOiBudW1iZXIsIGR1cmF0aW9uOiBudW1iZXIpID0+XG4gICAgdmFsdWUgLyBkdXJhdGlvbjtcblxuICAvKipcbiAgICogTm9ybWFsaXplIHRpbWUgcGVyIGdpdmVuIHNlY29uZC5cbiAgICovXG4gIHByaXZhdGUgbm9ybWFsaXplVGltZVBlclNlY29uZCA9IChjdXJyZW50Um91bmRNb21lbnQ6IHN0cmluZywgaTogbnVtYmVyKSA9PiB7XG4gICAgY29uc3QgdGhpc01vbWVudCA9IG1vbWVudChjdXJyZW50Um91bmRNb21lbnQpLm1pbGxpc2Vjb25kcygwKTtcblxuICAgIHJldHVybiB0aGlzTW9tZW50LmFkZChpLCAnc2Vjb25kJyk7XG4gIH07XG5cbiAgLyoqXG4gICAqIEJhcmtlcyBkb3duIGlucHV0IHBlciBtaW5pbWFsIHRpbWUgdW5pdC5cbiAgICovXG4gIHByaXZhdGUgYnJlYWtEb3duSW5wdXQoaW5wdXQ6IE1vZGVsUGFyYW1zLCBpOiBudW1iZXIpIHtcbiAgICBjb25zdCBpbnB1dEtleXMgPSBPYmplY3Qua2V5cyhpbnB1dCkgYXMgVW5pdEtleU5hbWVbXTtcblxuICAgIHJldHVybiBpbnB1dEtleXMucmVkdWNlKChhY2MsIGtleSkgPT4ge1xuICAgICAgY29uc3QgbWV0aG9kID0gdGhpcy5kZWFsZXIuYXNrVG9HaXZlTWV0aG9kRm9yKGtleSk7XG5cbiAgICAgIGlmIChrZXkgPT09ICd0aW1lc3RhbXAnKSB7XG4gICAgICAgIGNvbnN0IHBlclNlY29uZCA9IHRoaXMubm9ybWFsaXplVGltZVBlclNlY29uZChpbnB1dC50aW1lc3RhbXAsIGkpO1xuICAgICAgICBhY2Nba2V5XSA9IG1vbWVudChwZXJTZWNvbmQpLm1pbGxpc2Vjb25kcygwKS50b0lTT1N0cmluZygpO1xuXG4gICAgICAgIHJldHVybiBhY2M7XG4gICAgICB9XG5cbiAgICAgIC8qKiBAdG9kbyB1c2UgdXNlciBkZWZpbmVkIHJlc29sdXRpb24gbGF0ZXIgKi9cbiAgICAgIGlmIChrZXkgPT09ICdkdXJhdGlvbicpIHtcbiAgICAgICAgYWNjW2tleV0gPSAxO1xuXG4gICAgICAgIHJldHVybiBhY2M7XG4gICAgICB9XG5cbiAgICAgIGFjY1trZXldID1cbiAgICAgICAgbWV0aG9kID09PSAnc3VtJ1xuICAgICAgICAgID8gdGhpcy5jb252ZXJ0UGVySW50ZXJ2YWwoaW5wdXRba2V5XSwgaW5wdXRbJ2R1cmF0aW9uJ10pXG4gICAgICAgICAgOiBpbnB1dFtrZXldO1xuXG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9IGFzIE1vZGVsUGFyYW1zKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQb3B1bGF0ZXMgb2JqZWN0IHRvIGZpbGwgdGhlIGdhcHMgaW4gb2JzZXJ2YXRpb25hbCB0aW1lbGluZSB1c2luZyB6ZXJvaXNoIHZhbHVlcy5cbiAgICovXG4gIHByaXZhdGUgZmlsbFdpdGhaZXJvaXNoSW5wdXQoaW5wdXQ6IE1vZGVsUGFyYW1zLCBtaXNzaW5nVGltZXN0YW1wOiBudW1iZXIpIHtcbiAgICBjb25zdCBtZXRyaWNzID0gT2JqZWN0LmtleXMoaW5wdXQpIGFzIFVuaXRLZXlOYW1lW107XG5cbiAgICByZXR1cm4gbWV0cmljcy5yZWR1Y2UoKGFjYywgbWV0cmljKSA9PiB7XG4gICAgICBpZiAobWV0cmljID09PSAndGltZXN0YW1wJykge1xuICAgICAgICBhY2NbbWV0cmljXSA9IG1vbWVudChtaXNzaW5nVGltZXN0YW1wKS5taWxsaXNlY29uZHMoMCkudG9JU09TdHJpbmcoKTtcblxuICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgfVxuXG4gICAgICAvKiogQHRvZG8gbGF0ZXIgd2lsbCBiZSBjaGFuZ2VkIHRvIHVzZXIgZGVmaW5lZCBpbnRlcnZhbCAqL1xuICAgICAgaWYgKG1ldHJpYyA9PT0gJ2R1cmF0aW9uJykge1xuICAgICAgICBhY2NbbWV0cmljXSA9IDE7XG5cbiAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgIH1cblxuICAgICAgaWYgKG1ldHJpYyA9PT0gJ3RpbWUtcmVzZXJ2ZWQnKSB7XG4gICAgICAgIGFjY1ttZXRyaWNdID0gYWNjWydkdXJhdGlvbiddO1xuXG4gICAgICAgIHJldHVybiBhY2M7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IG1ldGhvZCA9IHRoaXMuZGVhbGVyLmFza1RvR2l2ZU1ldGhvZEZvcihtZXRyaWMpO1xuICAgICAgYWNjW21ldHJpY10gPSBtZXRob2QgPT09ICdhdmcnIHx8IG1ldGhvZCA9PT0gJ3N1bScgPyAwIDogaW5wdXRbbWV0cmljXTtcblxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSBhcyBNb2RlbFBhcmFtcyk7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2tzIGlmIHBhZGRpbmcgaXMgbmVlZGVkIGVpdGhlciBhdCBzdGFydCBvZiB0aGUgdGltZWxpbmUgb3IgdGhlIGVuZCBhbmQgcmV0dXJucyBzdGF0dXMuXG4gICAqL1xuICBwcml2YXRlIGNoZWNrRm9yUGFkZGluZyhpbnB1dHM6IE1vZGVsUGFyYW1zW10pOiBQYWRkaW5nUmVjZWlwdCB7XG4gICAgY29uc3Qgc3RhcnREaWZmSW5TZWNvbmRzID1cbiAgICAgIG1vbWVudChpbnB1dHNbMF0udGltZXN0YW1wKS5kaWZmKG1vbWVudCh0aGlzLnN0YXJ0VGltZSkpIC8gMTAwMDtcblxuICAgIGNvbnN0IGxhc3RJbnB1dCA9IGlucHV0c1tpbnB1dHMubGVuZ3RoIC0gMV07XG4gICAgY29uc3QgZW5kRGlmZkluU2Vjb25kcyA9XG4gICAgICBtb21lbnQobGFzdElucHV0LnRpbWVzdGFtcClcbiAgICAgICAgLmFkZChsYXN0SW5wdXQuZHVyYXRpb24sICdzZWNvbmRzJylcbiAgICAgICAgLmRpZmYobW9tZW50KHRoaXMuZW5kVGltZSkpIC8gMTAwMDtcblxuICAgIHJldHVybiB7XG4gICAgICBzdGFydDogc3RhcnREaWZmSW5TZWNvbmRzID4gMCxcbiAgICAgIGVuZDogZW5kRGlmZkluU2Vjb25kcyA8IDAsXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBJdGVyYXRlcyBvdmVyIGdpdmVuIGlucHV0cyBmcmFtZSwgbWVhbndoaWxlIGNoZWNraW5nIGlmIGFnZ3JlZ2F0aW9uIG1ldGhvZCBpcyBgc3VtYCwgdGhlbiBjYWxjdWxhdGVzIGl0LlxuICAgKiBGb3IgbWV0aG9kcyBpcyBgYXZnYCBhbmQgYG5vbmVgIGNhbGN1bGF0aW5nIGF2ZXJhZ2Ugb2YgdGhlIGZyYW1lLlxuICAgKi9cbiAgcHJpdmF0ZSByZXNhbXBsZUlucHV0RnJhbWUgPSAoaW5wdXRzSW5UaW1lc2xvdDogTW9kZWxQYXJhbXNbXSkgPT4ge1xuICAgIHJldHVybiBpbnB1dHNJblRpbWVzbG90LnJlZHVjZSgoYWNjLCBpbnB1dCwgaW5kZXgsIGlucHV0cykgPT4ge1xuICAgICAgY29uc3QgbWV0cmljcyA9IE9iamVjdC5rZXlzKGlucHV0KSBhcyBVbml0S2V5TmFtZVtdO1xuXG4gICAgICBtZXRyaWNzLmZvckVhY2gobWV0cmljID0+IHtcbiAgICAgICAgY29uc3QgbWV0aG9kID0gdGhpcy5kZWFsZXIuYXNrVG9HaXZlTWV0aG9kRm9yKG1ldHJpYyk7XG4gICAgICAgIGFjY1ttZXRyaWNdID0gYWNjW21ldHJpY10gPz8gMDtcblxuICAgICAgICBpZiAobWV0cmljID09PSAndGltZXN0YW1wJykge1xuICAgICAgICAgIGFjY1ttZXRyaWNdID0gaW5wdXRzWzBdW21ldHJpY107XG5cbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBpZiAobWV0aG9kID09PSAnc3VtJykge1xuICAgICAgICAgIGFjY1ttZXRyaWNdICs9IGlucHV0W21ldHJpY107XG5cbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICAvKiogZGl2aWRlIGVhY2ggbWV0cmljIGJ5IHRoZSB0aW1lc2xvdCBsZW5ndGgsIHNvIHRoYXQgdGhlaXIgc3VtIHlpZWxkcyB0aGUgdGltZXNsb3QgYXZlcmFnZS4qL1xuICAgICAgICBpZiAoaW5kZXggPT09IGlucHV0c0luVGltZXNsb3QubGVuZ3RoIC0gMSkge1xuICAgICAgICAgIGFjY1ttZXRyaWNdIC89IGlucHV0c0luVGltZXNsb3QubGVuZ3RoO1xuXG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgYWNjW21ldHJpY10gKz0gaW5wdXRbbWV0cmljXTtcbiAgICAgIH0pO1xuXG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9IGFzIE1vZGVsUGFyYW1zKTtcbiAgfTtcblxuICAvKipcbiAgICogVGFrZXMgZWFjaCBhcnJheSBmcmFtZSB3aXRoIGludGVydmFsIGxlbmd0aCwgdGhlbiBhZ2dyZWdhdGluZyB0aGVtIHRvZ2V0aGVyIGFzIGZyb20gdW5pdHMueWFtbCBmaWxlLlxuICAgKi9cbiAgcHJpdmF0ZSByZXNhbXBsZUlucHV0cyhpbnB1dHM6IE1vZGVsUGFyYW1zW10pIHtcbiAgICByZXR1cm4gaW5wdXRzLnJlZHVjZSgoYWNjLCBfaW5wdXQsIGluZGV4LCBpbnB1dHMpID0+IHtcbiAgICAgIGNvbnN0IGZyYW1lU3RhcnQgPSBpbmRleCAqIHRoaXMuaW50ZXJ2YWw7XG4gICAgICBjb25zdCBmcmFtZUVuZCA9IChpbmRleCArIDEpICogdGhpcy5pbnRlcnZhbDtcbiAgICAgIGNvbnN0IGlucHV0c0ZyYW1lID0gaW5wdXRzLnNsaWNlKGZyYW1lU3RhcnQsIGZyYW1lRW5kKTtcblxuICAgICAgY29uc3QgcmVzYW1wbGVkSW5wdXQgPSB0aGlzLnJlc2FtcGxlSW5wdXRGcmFtZShpbnB1dHNGcmFtZSk7XG5cbiAgICAgIC8qKiBDaGVja3MgaWYgcmVzYW1wbGVkIGlucHV0IGlzIG5vdCBlbXB0eSwgdGhlbiBpbmNsdWRlcyBpbiByZXN1bHQuICovXG4gICAgICBpZiAoT2JqZWN0LmtleXMocmVzYW1wbGVkSW5wdXQpLmxlbmd0aCA+IDApIHtcbiAgICAgICAgYWNjLnB1c2gocmVzYW1wbGVkSW5wdXQpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIFtdIGFzIE1vZGVsUGFyYW1zW10pO1xuICB9XG5cbiAgLyoqXG4gICAqIFBhZHMgemVyb2lzaCBpbnB1dHMgZnJvbSB0aGUgYmVnaW5uaW5nIG9yIGF0IHRoZSBlbmQgb2YgdGhlIGlucHV0cyBpZiBuZWVkZWQuXG4gICAqL1xuICBwcml2YXRlIHBhZElucHV0cyhpbnB1dHM6IE1vZGVsUGFyYW1zW10sIHBhZDogUGFkZGluZ1JlY2VpcHQpOiBNb2RlbFBhcmFtc1tdIHtcbiAgICBjb25zdCB7c3RhcnQsIGVuZH0gPSBwYWQ7XG4gICAgY29uc3QgcGFkZGVkRnJvbUJlZ2lubmluZyA9IFtdO1xuXG4gICAgaWYgKHN0YXJ0KSB7XG4gICAgICBjb25zdCBkYXRlUmFuZ2UgPSBtb21lbnRSYW5nZS5yYW5nZShcbiAgICAgICAgbW9tZW50KHRoaXMuc3RhcnRUaW1lKSxcbiAgICAgICAgbW9tZW50KGlucHV0c1swXS50aW1lc3RhbXApLnN1YnRyYWN0KDEsICdzZWNvbmQnKVxuICAgICAgKTtcblxuICAgICAgLyoqIENoZWNrcyBpZiBjb252ZXJ0aW5nIHRvIHZhbHVlIG9mIGlzIG5lZWRlZC4gKi9cbiAgICAgIGZvciAoY29uc3Qgc2Vjb25kIG9mIGRhdGVSYW5nZS5ieSgnc2Vjb25kJykpIHtcbiAgICAgICAgcGFkZGVkRnJvbUJlZ2lubmluZy5wdXNoKFxuICAgICAgICAgIHRoaXMuZmlsbFdpdGhaZXJvaXNoSW5wdXQoaW5wdXRzWzBdLCBzZWNvbmQudmFsdWVPZigpKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH1cblxuICAgIGNvbnN0IHBhZGRlZEFycmF5ID0gcGFkZGVkRnJvbUJlZ2lubmluZy5jb25jYXQoaW5wdXRzKTtcblxuICAgIGlmIChlbmQpIHtcbiAgICAgIGNvbnN0IGxhc3RJbnB1dCA9IGlucHV0c1tpbnB1dHMubGVuZ3RoIC0gMV07XG4gICAgICBjb25zdCBkYXRlUmFuZ2UgPSBtb21lbnRSYW5nZS5yYW5nZShcbiAgICAgICAgbW9tZW50KGxhc3RJbnB1dC50aW1lc3RhbXApLmFkZChsYXN0SW5wdXQuZHVyYXRpb24sICdzZWNvbmRzJyksXG4gICAgICAgIG1vbWVudCh0aGlzLmVuZFRpbWUpXG4gICAgICApO1xuXG4gICAgICBmb3IgKGNvbnN0IHNlY29uZCBvZiBkYXRlUmFuZ2UuYnkoJ3NlY29uZCcpKSB7XG4gICAgICAgIHBhZGRlZEFycmF5LnB1c2goXG4gICAgICAgICAgdGhpcy5maWxsV2l0aFplcm9pc2hJbnB1dChsYXN0SW5wdXQsIHNlY29uZC52YWx1ZU9mKCkpXG4gICAgICAgICk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHBhZGRlZEFycmF5O1xuICB9XG5cbiAgLypcbiAgICogQ2hlY2tzIGlmIGlucHV0J3MgdGltZXN0YW1wIGlzIGluY2x1ZGVkIGluIGdsb2JhbCBzcGVjaWZpZWQgcGVyaW9kIHRoZW4gbGVhdmVzIGl0LCBvdGhlcndpc2UuXG4gICAqL1xuICBwcml2YXRlIHRyaW1JbnB1dHNCeUdsb2JhbFRpbWVsaW5lKGlucHV0czogTW9kZWxQYXJhbXNbXSk6IE1vZGVsUGFyYW1zW10ge1xuICAgIHJldHVybiBpbnB1dHMucmVkdWNlKChhY2MsIGl0ZW0pID0+IHtcbiAgICAgIGNvbnN0IHt0aW1lc3RhbXB9ID0gaXRlbTtcblxuICAgICAgaWYgKFxuICAgICAgICBtb21lbnQodGltZXN0YW1wKS5pc1NhbWVPckFmdGVyKG1vbWVudCh0aGlzLnN0YXJ0VGltZSkpICYmXG4gICAgICAgIG1vbWVudCh0aW1lc3RhbXApLmlzU2FtZU9yQmVmb3JlKG1vbWVudCh0aGlzLmVuZFRpbWUpKVxuICAgICAgKSB7XG4gICAgICAgIGFjYy5wdXNoKGl0ZW0pO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIFtdIGFzIE1vZGVsUGFyYW1zW10pO1xuICB9XG5cbiAgLyoqXG4gICAqIE5vcm1hbGl6ZXMgcHJvdmlkZWQgdGltZSB3aW5kb3cgYWNjb3JkaW5nIHRvIHRpbWUgY29uZmlndXJhdGlvbi5cbiAgICovXG4gIGFzeW5jIGV4ZWN1dGUoaW5wdXRzOiBNb2RlbFBhcmFtc1tdKTogUHJvbWlzZTxNb2RlbFBhcmFtc1tdPiB7XG4gICAgdGhpcy52YWxpZGF0ZVBhcmFtcygpO1xuXG4gICAgY29uc3QgcGFkID0gdGhpcy5jaGVja0ZvclBhZGRpbmcoaW5wdXRzKTtcbiAgICBjb25zdCBwYWRkZWRJbnB1dHMgPSB0aGlzLnBhZElucHV0cyhpbnB1dHMsIHBhZCk7XG5cbiAgICBjb25zdCBmbGF0dGVuSW5wdXRzID0gcGFkZGVkSW5wdXRzLnJlZHVjZSgoYWNjLCBpbnB1dCwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGN1cnJlbnRNb21lbnQgPSBtb21lbnQoaW5wdXQudGltZXN0YW1wKTtcblxuICAgICAgLyoqIENoZWNrcyBpZiBub3QgdGhlIGZpcnN0IGlucHV0LCB0aGVuIGNoZWNrIGNvbnNpc3RlbmN5IHdpdGggcHJldmlvdXMgb25lcy4gKi9cbiAgICAgIGlmIChpbmRleCA+IDApIHtcbiAgICAgICAgY29uc3QgcHJldmlvdXNJbnB1dCA9IHBhZGRlZElucHV0c1tpbmRleCAtIDFdO1xuICAgICAgICBjb25zdCBwcmV2aW91c0lucHV0VGltZXN0YW1wID0gbW9tZW50KHByZXZpb3VzSW5wdXQudGltZXN0YW1wKTtcblxuICAgICAgICAvKiogQ2hlY2tzIGZvciB0aW1lc3RhbXBzIG92ZXJsYXAuICovXG4gICAgICAgIGlmIChcbiAgICAgICAgICBtb21lbnQocHJldmlvdXNJbnB1dC50aW1lc3RhbXApXG4gICAgICAgICAgICAuYWRkKHByZXZpb3VzSW5wdXQuZHVyYXRpb24sICdzZWNvbmRzJylcbiAgICAgICAgICAgIC5pc0FmdGVyKGN1cnJlbnRNb21lbnQpXG4gICAgICAgICkge1xuICAgICAgICAgIHRocm93IG5ldyBJbnB1dFZhbGlkYXRpb25FcnJvcihJTlZBTElEX09CU0VSVkFUSU9OX09WRVJMQVApO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgY29tcGFyZWFibGVUaW1lID0gcHJldmlvdXNJbnB1dFRpbWVzdGFtcC5hZGQoXG4gICAgICAgICAgcHJldmlvdXNJbnB1dC5kdXJhdGlvbixcbiAgICAgICAgICAnc2Vjb25kJ1xuICAgICAgICApO1xuXG4gICAgICAgIGNvbnN0IHRpbWVsaW5lR2FwU2l6ZSA9IGN1cnJlbnRNb21lbnQuZGlmZihjb21wYXJlYWJsZVRpbWUsICdzZWNvbmQnKTtcbiAgICAgICAgLy9jb25zb2xlLmxvZyhjdXJyZW50TW9tZW50LCB0aW1lbGluZUdhcFNpemUpXG4gICAgICAgIC8qKiBDaGVja3MgaWYgdGhlcmUgaXMgZ2FwIGluIHRpbWVsaW5lLiAqL1xuICAgICAgICBpZiAodGltZWxpbmVHYXBTaXplID4gMSkge1xuICAgICAgICAgIGZvciAoXG4gICAgICAgICAgICBsZXQgbWlzc2luZ1RpbWVzdGFtcCA9IGNvbXBhcmVhYmxlVGltZS52YWx1ZU9mKCk7XG4gICAgICAgICAgICBtaXNzaW5nVGltZXN0YW1wIDw9IGN1cnJlbnRNb21lbnQudmFsdWVPZigpIC0gMTAwMDtcbiAgICAgICAgICAgIG1pc3NpbmdUaW1lc3RhbXAgKz0gMTAwMFxuICAgICAgICAgICkge1xuICAgICAgICAgICAgY29uc3QgZmlsbGVkR2FwID0gdGhpcy5maWxsV2l0aFplcm9pc2hJbnB1dChcbiAgICAgICAgICAgICAgaW5wdXQsXG4gICAgICAgICAgICAgIG1pc3NpbmdUaW1lc3RhbXBcbiAgICAgICAgICAgICk7XG5cbiAgICAgICAgICAgIGFjYy5wdXNoKGZpbGxlZEdhcCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC8qKiBCcmVhayBkb3duIGN1cnJlbnQgb2JzZXJ2YXRpb24uICovXG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IGlucHV0LmR1cmF0aW9uOyBpKyspIHtcbiAgICAgICAgY29uc3Qgbm9ybWFsaXplZElucHV0ID0gdGhpcy5icmVha0Rvd25JbnB1dChpbnB1dCwgaSk7XG5cbiAgICAgICAgYWNjLnB1c2gobm9ybWFsaXplZElucHV0KTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHRoaXMudHJpbUlucHV0c0J5R2xvYmFsVGltZWxpbmUoYWNjKTtcbiAgICB9LCBbXSBhcyBNb2RlbFBhcmFtc1tdKTtcblxuICAgIGNvbnN0IHNvcnRlZElucHV0cyA9IGZsYXR0ZW5JbnB1dHMuc29ydCgoYSwgYikgPT5cbiAgICAgIG1vbWVudChhLnRpbWVzdGFtcCkuZGlmZihtb21lbnQoYi50aW1lc3RhbXApKVxuICAgICk7XG5cbiAgICByZXR1cm4gdGhpcy5yZXNhbXBsZUlucHV0cyhzb3J0ZWRJbnB1dHMpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1 @@
1
+ export type AsyncReturnType<T extends (...args: any) => Promise<any>> = T extends (...args: any) => Promise<infer R> ? R : any;
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9oZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBBc3luY1JldHVyblR5cGU8VCBleHRlbmRzICguLi5hcmdzOiBhbnkpID0+IFByb21pc2U8YW55Pj4gPVxuICBUIGV4dGVuZHMgKC4uLmFyZ3M6IGFueSkgPT4gUHJvbWlzZTxpbmZlciBSPiA/IFIgOiBhbnk7XG4iXX0=
@@ -0,0 +1,45 @@
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 {};
@@ -0,0 +1,5 @@
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=
@@ -0,0 +1,14 @@
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
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwtaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGVzL21vZGVsLWludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtVbml0S2V5TmFtZX0gZnJvbSAnLi91bml0cyc7XG5cbmV4cG9ydCB0eXBlIE1vZGVsUGFyYW1zID0ge1xuICBbSyBpbiBVbml0S2V5TmFtZV0/OiBhbnk7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIE1vZGVsUGx1Z2luSW50ZXJmYWNlIHtcbiAgLyoqXG4gICAqIENvbmZpZ3VyZXMgaW5zdGFuY2Ugd2l0aCBnaXZlbiBwYXJhbXMuXG4gICAqL1xuICBjb25maWd1cmUocGFyYW1zOiBvYmplY3QgfCB1bmRlZmluZWQpOiBQcm9taXNlPE1vZGVsUGx1Z2luSW50ZXJmYWNlPjtcblxuICAvKipcbiAgICogQ2FsY3VsYXRlcyBgb3V0cHV0YCBiYXNlZCBvbiBnaXZlbiBtb2RlbCdzIGBpbnB1dGAuXG4gICAqL1xuICBleGVjdXRlKGlucHV0czogTW9kZWxQYXJhbXNbXSk6IFByb21pc2U8TW9kZWxQYXJhbXNbXT47XG59XG4iXX0=
@@ -0,0 +1,23 @@
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
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWxzLXVuaXZlcnNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R5cGVzL21vZGVscy11bml2ZXJzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtNb2RlbFBsdWdpbkludGVyZmFjZX0gZnJvbSAnLi4vdHlwZXMvbW9kZWwtaW50ZXJmYWNlJztcblxuZXhwb3J0IHR5cGUgR3JhcGhPcHRpb25zID0ge1xuICAnY29yZS11bml0cyc6IG51bWJlcjtcbiAgJ3BoeXNpY2FsLXByb2Nlc3Nvcic6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEltcGxJbml0aWFsaXplTW9kZWwgPSB7XG4gIGNvbmZpZz86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIG5hbWU6IHN0cmluZztcbiAgbW9kZWw/OiBzdHJpbmc7XG4gIHBhdGg/OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBJbml0YWxpemVkTW9kZWxzID0ge1xuICBba2V5OiBzdHJpbmddOiAoZ3JhcGhPcHRpb25zOiBHcmFwaE9wdGlvbnMpID0+IFByb21pc2U8TW9kZWxQbHVnaW5JbnRlcmZhY2U+O1xufTtcblxuZXhwb3J0IHR5cGUgSGFuZE1vZGVsUGFyYW1zID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIG1vZGVsPzogc3RyaW5nO1xuICBwYXRoPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgQ2xhc3NDb250YWluZXJQYXJhbXMgPSB7XG4gIG1vZGVsOiBzdHJpbmc7XG4gIHBhdGg6IHN0cmluZztcbn07XG4iXX0=
@@ -0,0 +1,6 @@
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>;