raain-model 0.3.1 → 1.10.25

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 (194) hide show
  1. package/README.md +7 -10
  2. package/RELEASE.md +10 -10
  3. package/cartesian/CartesianMeasureValue.d.ts +41 -0
  4. package/cartesian/CartesianMeasureValue.js +106 -0
  5. package/cartesian/CartesianMeasureValue.js.map +1 -0
  6. package/cartesian/CartesianValue.d.ts +9 -0
  7. package/cartesian/CartesianValue.js +12 -0
  8. package/cartesian/CartesianValue.js.map +1 -0
  9. package/cartesian/ICartesianMeasureValue.d.ts +29 -0
  10. package/cartesian/ICartesianMeasureValue.js +3 -0
  11. package/cartesian/ICartesianMeasureValue.js.map +1 -0
  12. package/cartesian/LatLng.d.ts +12 -0
  13. package/cartesian/LatLng.js +31 -0
  14. package/cartesian/LatLng.js.map +1 -0
  15. package/cartesian/RadarCartesianMeasureValue.d.ts +15 -0
  16. package/cartesian/RadarCartesianMeasureValue.js +22 -0
  17. package/cartesian/RadarCartesianMeasureValue.js.map +1 -0
  18. package/cartesian/RainCartesianMeasureValue.d.ts +17 -0
  19. package/cartesian/RainCartesianMeasureValue.js +25 -0
  20. package/cartesian/RainCartesianMeasureValue.js.map +1 -0
  21. package/gauge/GaugeMeasure.d.ts +20 -0
  22. package/gauge/GaugeMeasure.js +24 -0
  23. package/gauge/GaugeMeasure.js.map +1 -0
  24. package/gauge/GaugeNode.d.ts +24 -0
  25. package/gauge/GaugeNode.js +31 -0
  26. package/gauge/GaugeNode.js.map +1 -0
  27. package/gauge/GaugeNodeMap.d.ts +22 -0
  28. package/gauge/GaugeNodeMap.js +42 -0
  29. package/gauge/GaugeNodeMap.js.map +1 -0
  30. package/index.d.ts +39 -20
  31. package/index.js +53 -23
  32. package/index.js.map +1 -1
  33. package/organization/EventNode.d.ts +22 -0
  34. package/organization/EventNode.js +30 -0
  35. package/organization/EventNode.js.map +1 -0
  36. package/{IVersion.js.map → organization/IVersion.js.map} +1 -1
  37. package/{Link.d.ts → organization/Link.d.ts} +4 -5
  38. package/organization/Link.js +34 -0
  39. package/organization/Link.js.map +1 -0
  40. package/organization/Measure.d.ts +20 -0
  41. package/organization/Measure.js +35 -0
  42. package/organization/Measure.js.map +1 -0
  43. package/organization/PeopleNode.d.ts +18 -0
  44. package/organization/PeopleNode.js +26 -0
  45. package/organization/PeopleNode.js.map +1 -0
  46. package/{RaainNode.d.ts → organization/RaainNode.d.ts} +12 -7
  47. package/organization/RaainNode.js +95 -0
  48. package/organization/RaainNode.js.map +1 -0
  49. package/organization/TeamNode.d.ts +22 -0
  50. package/organization/TeamNode.js +32 -0
  51. package/organization/TeamNode.js.map +1 -0
  52. package/package.json +13 -10
  53. package/polar/AbstractPolarMeasureValue.d.ts +29 -0
  54. package/polar/AbstractPolarMeasureValue.js +92 -0
  55. package/polar/AbstractPolarMeasureValue.js.map +1 -0
  56. package/polar/GaugePolarMeasureValue.d.ts +11 -0
  57. package/polar/GaugePolarMeasureValue.js +14 -0
  58. package/polar/GaugePolarMeasureValue.js.map +1 -0
  59. package/polar/IPolarMeasureValue.d.ts +19 -0
  60. package/{IMeasureValue.js → polar/IPolarMeasureValue.js} +1 -1
  61. package/polar/IPolarMeasureValue.js.map +1 -0
  62. package/polar/MeasureValuePolarContainer.d.ts +11 -0
  63. package/polar/MeasureValuePolarContainer.js +22 -0
  64. package/polar/MeasureValuePolarContainer.js.map +1 -0
  65. package/polar/PolarMeasureValue.d.ts +26 -0
  66. package/polar/PolarMeasureValue.js +100 -0
  67. package/polar/PolarMeasureValue.js.map +1 -0
  68. package/polar/PolarValue.d.ts +10 -0
  69. package/polar/PolarValue.js +12 -0
  70. package/polar/PolarValue.js.map +1 -0
  71. package/polar/RadarPolarMeasureValue.d.ts +15 -0
  72. package/polar/RadarPolarMeasureValue.js +34 -0
  73. package/polar/RadarPolarMeasureValue.js.map +1 -0
  74. package/polar/RainPolarMeasureValue.d.ts +18 -0
  75. package/polar/RainPolarMeasureValue.js +42 -0
  76. package/polar/RainPolarMeasureValue.js.map +1 -0
  77. package/quality/QualityPoint.d.ts +35 -0
  78. package/quality/QualityPoint.js +63 -0
  79. package/quality/QualityPoint.js.map +1 -0
  80. package/quality/SpeedMatrix.d.ts +79 -0
  81. package/quality/SpeedMatrix.js +251 -0
  82. package/quality/SpeedMatrix.js.map +1 -0
  83. package/quality/SpeedMatrixContainer.d.ts +76 -0
  84. package/quality/SpeedMatrixContainer.js +310 -0
  85. package/quality/SpeedMatrixContainer.js.map +1 -0
  86. package/quality/history/CartesianGaugeHistory.d.ts +15 -0
  87. package/quality/history/CartesianGaugeHistory.js +14 -0
  88. package/quality/history/CartesianGaugeHistory.js.map +1 -0
  89. package/quality/history/CartesianRainHistory.d.ts +11 -0
  90. package/quality/history/CartesianRainHistory.js +12 -0
  91. package/quality/history/CartesianRainHistory.js.map +1 -0
  92. package/quality/history/PositionHistory.d.ts +20 -0
  93. package/quality/history/PositionHistory.js +17 -0
  94. package/quality/history/PositionHistory.js.map +1 -0
  95. package/quality/position/Position.d.ts +22 -0
  96. package/quality/position/Position.js +50 -0
  97. package/quality/position/Position.js.map +1 -0
  98. package/quality/position/PositionValue.d.ts +9 -0
  99. package/quality/position/PositionValue.js +12 -0
  100. package/quality/position/PositionValue.js.map +1 -0
  101. package/quality/tools/QualityTools.d.ts +24 -0
  102. package/quality/tools/QualityTools.js +182 -0
  103. package/quality/tools/QualityTools.js.map +1 -0
  104. package/radar/RadarMeasure.d.ts +17 -0
  105. package/radar/RadarMeasure.js +18 -0
  106. package/radar/RadarMeasure.js.map +1 -0
  107. package/radar/RadarNode.d.ts +24 -0
  108. package/radar/RadarNode.js +31 -0
  109. package/radar/RadarNode.js.map +1 -0
  110. package/radar/RadarNodeMap.d.ts +28 -0
  111. package/radar/RadarNodeMap.js +46 -0
  112. package/radar/RadarNodeMap.js.map +1 -0
  113. package/rain/RainComputation.d.ts +34 -0
  114. package/rain/RainComputation.js +55 -0
  115. package/rain/RainComputation.js.map +1 -0
  116. package/{RainComputationNode.d.ts → rain/RainComputationAbstract.d.ts} +19 -20
  117. package/rain/RainComputationAbstract.js +102 -0
  118. package/rain/RainComputationAbstract.js.map +1 -0
  119. package/rain/RainComputationMap.d.ts +32 -0
  120. package/rain/RainComputationMap.js +45 -0
  121. package/rain/RainComputationMap.js.map +1 -0
  122. package/rain/RainComputationQuality.d.ts +37 -0
  123. package/rain/RainComputationQuality.js +103 -0
  124. package/rain/RainComputationQuality.js.map +1 -0
  125. package/rain/RainMeasure.d.ts +18 -0
  126. package/rain/RainMeasure.js +19 -0
  127. package/rain/RainMeasure.js.map +1 -0
  128. package/rain/RainNode.d.ts +38 -0
  129. package/rain/RainNode.js +127 -0
  130. package/rain/RainNode.js.map +1 -0
  131. package/EventNode.d.ts +0 -10
  132. package/EventNode.js +0 -17
  133. package/EventNode.js.map +0 -1
  134. package/GaugeMeasure.d.ts +0 -7
  135. package/GaugeMeasure.js +0 -31
  136. package/GaugeMeasure.js.map +0 -1
  137. package/GaugeMeasureValue.d.ts +0 -16
  138. package/GaugeMeasureValue.js +0 -66
  139. package/GaugeMeasureValue.js.map +0 -1
  140. package/GaugeNode.d.ts +0 -19
  141. package/GaugeNode.js +0 -48
  142. package/GaugeNode.js.map +0 -1
  143. package/GaugeNodeMap.d.ts +0 -22
  144. package/GaugeNodeMap.js +0 -61
  145. package/GaugeNodeMap.js.map +0 -1
  146. package/IMeasureValue.d.ts +0 -12
  147. package/IMeasureValue.js.map +0 -1
  148. package/Link.js +0 -36
  149. package/Link.js.map +0 -1
  150. package/Measure.d.ts +0 -9
  151. package/Measure.js +0 -43
  152. package/Measure.js.map +0 -1
  153. package/MeasureValuePolarContainer.d.ts +0 -7
  154. package/MeasureValuePolarContainer.js +0 -28
  155. package/MeasureValuePolarContainer.js.map +0 -1
  156. package/PeopleNode.d.ts +0 -7
  157. package/PeopleNode.js +0 -14
  158. package/PeopleNode.js.map +0 -1
  159. package/PolarValue.d.ts +0 -6
  160. package/PolarValue.js +0 -12
  161. package/PolarValue.js.map +0 -1
  162. package/RaainNode.js +0 -103
  163. package/RaainNode.js.map +0 -1
  164. package/RadarMeasure.d.ts +0 -7
  165. package/RadarMeasure.js +0 -31
  166. package/RadarMeasure.js.map +0 -1
  167. package/RadarMeasureValue.d.ts +0 -19
  168. package/RadarMeasureValue.js +0 -75
  169. package/RadarMeasureValue.js.map +0 -1
  170. package/RadarNode.d.ts +0 -14
  171. package/RadarNode.js +0 -49
  172. package/RadarNode.js.map +0 -1
  173. package/RadarNodeMap.d.ts +0 -11
  174. package/RadarNodeMap.js +0 -56
  175. package/RadarNodeMap.js.map +0 -1
  176. package/RainComputationMap.d.ts +0 -11
  177. package/RainComputationMap.js +0 -59
  178. package/RainComputationMap.js.map +0 -1
  179. package/RainComputationNode.js +0 -148
  180. package/RainComputationNode.js.map +0 -1
  181. package/RainMeasure.d.ts +0 -5
  182. package/RainMeasure.js +0 -29
  183. package/RainMeasure.js.map +0 -1
  184. package/RainMeasureValue.d.ts +0 -21
  185. package/RainMeasureValue.js +0 -74
  186. package/RainMeasureValue.js.map +0 -1
  187. package/RainNode.d.ts +0 -21
  188. package/RainNode.js +0 -107
  189. package/RainNode.js.map +0 -1
  190. package/tools/PolarValues.d.ts +0 -16
  191. package/tools/PolarValues.js +0 -99
  192. package/tools/PolarValues.js.map +0 -1
  193. /package/{IVersion.d.ts → organization/IVersion.d.ts} +0 -0
  194. /package/{IVersion.js → organization/IVersion.js} +0 -0
@@ -0,0 +1,79 @@
1
+ import { PositionHistory } from './history/PositionHistory';
2
+ import { PositionValue } from './position/PositionValue';
3
+ import { Position } from './position/Position';
4
+ import { QualityPoint } from './QualityPoint';
5
+ export declare class SpeedMatrix {
6
+ protected qualityPoints: QualityPoint[];
7
+ protected speed: {
8
+ angleInDegrees: number;
9
+ pixelsPerPeriod: number;
10
+ };
11
+ protected trustedTechnicalIndicator: number;
12
+ protected flattenPositionRange: {
13
+ xMin: number;
14
+ xMax: number;
15
+ yMin: number;
16
+ yMax: number;
17
+ };
18
+ protected roundScale: Position;
19
+ static DEFAULT_MATRIX_RANGE: number;
20
+ static DEFAULT_TRUSTED_INDICATOR: number;
21
+ protected flattenPositionHistory: number[][];
22
+ constructor(qualityPoints: QualityPoint[], speed?: {
23
+ angleInDegrees: number;
24
+ pixelsPerPeriod: number;
25
+ }, trustedTechnicalIndicator?: number, flattenPositionRange?: {
26
+ xMin: number;
27
+ xMax: number;
28
+ yMin: number;
29
+ yMax: number;
30
+ }, roundScale?: Position);
31
+ static CreateFromJson(json: any | SpeedMatrix): SpeedMatrix;
32
+ /**
33
+ * Get quality indicator based on delta from computed vs reality
34
+ * 0 is ideal
35
+ * 2.56 (for example) is not ideal => can be improved :)
36
+ */
37
+ static ComputeQualityIndicator(points: QualityPoint[]): number;
38
+ static LogPositionValues(positionValues: PositionHistory[], valueDisplayFn: (v: PositionHistory) => string, flattenPositionRange?: {
39
+ xMin: number;
40
+ xMax: number;
41
+ yMin: number;
42
+ yMax: number;
43
+ }, logger?: Console): void;
44
+ static Normalize(values: PositionValue[]): PositionValue[];
45
+ renderFlatten(options: {
46
+ normalize: boolean;
47
+ }): PositionValue[];
48
+ getGaugeIdRelatedValues(id: string): QualityPoint;
49
+ getQualityPoints(): QualityPoint[];
50
+ getMaxRain(): number;
51
+ getMaxGauge(): number;
52
+ getTrustedTechnicalIndicator(): number;
53
+ isConsistent(): boolean;
54
+ toJSON(): {
55
+ flattenPositionHistory: number[][];
56
+ flattenPositionRange: {
57
+ xMin: number;
58
+ xMax: number;
59
+ yMin: number;
60
+ yMax: number;
61
+ };
62
+ speed: {
63
+ angleInDegrees: number;
64
+ pixelsPerPeriod: number;
65
+ };
66
+ qualityPoints: QualityPoint[];
67
+ trustedTechnicalIndicator: number;
68
+ roundScale: Position;
69
+ };
70
+ logFlatten(options?: {
71
+ overridingLogger?: any;
72
+ simplify?: boolean;
73
+ }): void;
74
+ getSpeed(): {
75
+ angleInDegrees: number;
76
+ pixelsPerPeriod: number;
77
+ };
78
+ protected getFlatten(): number[][];
79
+ }
@@ -0,0 +1,251 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SpeedMatrix = void 0;
4
+ const PositionHistory_1 = require("./history/PositionHistory");
5
+ const PositionValue_1 = require("./position/PositionValue");
6
+ const QualityTools_1 = require("./tools/QualityTools");
7
+ const Position_1 = require("./position/Position");
8
+ const QualityPoint_1 = require("./QualityPoint");
9
+ const CartesianValue_1 = require("../cartesian/CartesianValue");
10
+ const LatLng_1 = require("../cartesian/LatLng");
11
+ class SpeedMatrix {
12
+ constructor(qualityPoints, speed = { angleInDegrees: 0, pixelsPerPeriod: 0 }, trustedTechnicalIndicator = SpeedMatrix.DEFAULT_TRUSTED_INDICATOR, flattenPositionRange = {
13
+ xMin: -SpeedMatrix.DEFAULT_MATRIX_RANGE,
14
+ xMax: SpeedMatrix.DEFAULT_MATRIX_RANGE,
15
+ yMin: -SpeedMatrix.DEFAULT_MATRIX_RANGE,
16
+ yMax: SpeedMatrix.DEFAULT_MATRIX_RANGE
17
+ }, roundScale = new Position_1.Position({ x: QualityTools_1.QualityTools.DEFAULT_SCALE, y: QualityTools_1.QualityTools.DEFAULT_SCALE })) {
18
+ this.qualityPoints = qualityPoints;
19
+ this.speed = speed;
20
+ this.trustedTechnicalIndicator = trustedTechnicalIndicator;
21
+ this.flattenPositionRange = flattenPositionRange;
22
+ this.roundScale = roundScale;
23
+ }
24
+ static CreateFromJson(json) {
25
+ const created = new SpeedMatrix(json.qualityPoints, json.speed, json.trustedTechnicalIndicator, json.flattenPositionRange, json.roundScale);
26
+ if (json.flattenPositionHistory) {
27
+ created.flattenPositionHistory = json.flattenPositionHistory;
28
+ }
29
+ return created;
30
+ }
31
+ /**
32
+ * Get quality indicator based on delta from computed vs reality
33
+ * 0 is ideal
34
+ * 2.56 (for example) is not ideal => can be improved :)
35
+ */
36
+ static ComputeQualityIndicator(points) {
37
+ let indicator = 0;
38
+ for (const point of points) {
39
+ indicator += point.getDelta();
40
+ }
41
+ if (points.length > 0) {
42
+ indicator = indicator / points.length;
43
+ }
44
+ return indicator;
45
+ }
46
+ static LogPositionValues(positionValues, valueDisplayFn, flattenPositionRange = {
47
+ xMin: -SpeedMatrix.DEFAULT_MATRIX_RANGE,
48
+ xMax: SpeedMatrix.DEFAULT_MATRIX_RANGE,
49
+ yMin: -SpeedMatrix.DEFAULT_MATRIX_RANGE,
50
+ yMax: SpeedMatrix.DEFAULT_MATRIX_RANGE
51
+ }, logger = console) {
52
+ const labelWithSign = (val) => {
53
+ if (val < 0) {
54
+ return '' + val;
55
+ }
56
+ else if (val === 0) {
57
+ return ' ' + 0;
58
+ }
59
+ return '+' + val;
60
+ };
61
+ const labelX = (x) => {
62
+ return 'x' + labelWithSign(x - flattenPositionRange.xMax);
63
+ };
64
+ const labelY = (y) => {
65
+ return 'y' + labelWithSign(y - flattenPositionRange.yMax);
66
+ };
67
+ const matrixToRender = {};
68
+ for (let y = flattenPositionRange.yMax - flattenPositionRange.yMin; y >= 0; y--) {
69
+ const xObject = {};
70
+ for (let x = 0; x <= flattenPositionRange.xMax - flattenPositionRange.xMin; x++) {
71
+ xObject[labelX(x)] = valueDisplayFn(new PositionHistory_1.PositionHistory({
72
+ id: 'id',
73
+ label: 'label',
74
+ date: new Date(),
75
+ x,
76
+ y,
77
+ value: 0,
78
+ valueFromGauge: 0,
79
+ valueFromRain: 0
80
+ }));
81
+ }
82
+ matrixToRender[labelY(y)] = xObject;
83
+ }
84
+ for (let x = flattenPositionRange.xMin; x <= flattenPositionRange.xMax; x++) {
85
+ for (let y = flattenPositionRange.yMin; y <= flattenPositionRange.yMax; y++) {
86
+ const value = positionValues.filter(p => p.x === x && p.y === y)[0];
87
+ const yOfMatrix = y - flattenPositionRange.yMin;
88
+ const xOfMatrix = x - flattenPositionRange.xMin;
89
+ matrixToRender[labelY(yOfMatrix)][labelX(xOfMatrix)] = valueDisplayFn(value);
90
+ }
91
+ }
92
+ logger.table(matrixToRender);
93
+ }
94
+ static Normalize(values) {
95
+ const built = [];
96
+ let maxValue = Number.EPSILON;
97
+ for (const pos of values) {
98
+ maxValue = Math.max(maxValue, pos.value);
99
+ }
100
+ for (const pos of values) {
101
+ const normalizedValue = pos.value / maxValue;
102
+ built.push(new PositionValue_1.PositionValue({ x: pos.x, y: pos.y, value: normalizedValue }));
103
+ }
104
+ return built;
105
+ }
106
+ renderFlatten(options) {
107
+ const positionMatrix = this.getFlatten();
108
+ if (positionMatrix.length === 0) {
109
+ return [];
110
+ }
111
+ const positionHistories = [];
112
+ let maxValue = 0;
113
+ for (const [iX, posX] of positionMatrix.entries()) {
114
+ for (const [iY, value] of posX.entries()) {
115
+ const x = iX + this.flattenPositionRange.xMin;
116
+ const y = iY + this.flattenPositionRange.yMin;
117
+ maxValue = Math.max(maxValue, value);
118
+ positionHistories.push(new PositionValue_1.PositionValue({ x, y, value }));
119
+ }
120
+ }
121
+ // Normalize
122
+ if (maxValue && options.normalize) {
123
+ positionHistories.forEach(p => {
124
+ p.value = p.value / maxValue;
125
+ });
126
+ }
127
+ return positionHistories;
128
+ }
129
+ getGaugeIdRelatedValues(id) {
130
+ const points = this.qualityPoints.filter(p => p.gaugeId === id);
131
+ if (points.length === 1) {
132
+ return points[0];
133
+ }
134
+ return null;
135
+ }
136
+ getQualityPoints() {
137
+ return this.qualityPoints.map(p => new QualityPoint_1.QualityPoint(p));
138
+ }
139
+ getMaxRain() {
140
+ const qualityPoints = this.getQualityPoints();
141
+ let max = -1;
142
+ for (const p of qualityPoints) {
143
+ max = Math.max(max, p.getRainValue());
144
+ }
145
+ return max;
146
+ }
147
+ getMaxGauge() {
148
+ const qualityPoints = this.getQualityPoints();
149
+ let max = -1;
150
+ for (const p of qualityPoints) {
151
+ max = Math.max(max, p.getGaugeValue());
152
+ }
153
+ return max;
154
+ }
155
+ getTrustedTechnicalIndicator() {
156
+ return this.trustedTechnicalIndicator;
157
+ }
158
+ isConsistent() {
159
+ return this.trustedTechnicalIndicator > SpeedMatrix.DEFAULT_TRUSTED_INDICATOR / 2;
160
+ }
161
+ toJSON() {
162
+ return {
163
+ flattenPositionHistory: this.flattenPositionHistory,
164
+ flattenPositionRange: this.flattenPositionRange,
165
+ speed: this.speed,
166
+ qualityPoints: this.qualityPoints,
167
+ trustedTechnicalIndicator: this.trustedTechnicalIndicator,
168
+ roundScale: this.roundScale,
169
+ };
170
+ }
171
+ logFlatten(options = { overridingLogger: null, simplify: false }) {
172
+ let logger = options.overridingLogger;
173
+ if (!logger) {
174
+ logger = console;
175
+ }
176
+ const flatten = this.renderFlatten({ normalize: false });
177
+ const positionHistories = flatten.map(pv => new PositionHistory_1.PositionHistory({
178
+ id: '-',
179
+ label: '-',
180
+ date: null,
181
+ x: pv.x,
182
+ y: pv.y,
183
+ value: pv.value,
184
+ valueFromGauge: -1,
185
+ valueFromRain: -1
186
+ }));
187
+ const valueDisplay = (pv) => {
188
+ const v = pv.value;
189
+ if (options.simplify) {
190
+ if (v === 1) {
191
+ return '##';
192
+ }
193
+ else if (v >= 0.8) {
194
+ return '#';
195
+ }
196
+ else if (v >= 0.5) {
197
+ return '=';
198
+ }
199
+ else if (v >= 0.2) {
200
+ return '_';
201
+ }
202
+ return ' ';
203
+ }
204
+ return '' + Math.round(v * 1000) / 1000;
205
+ };
206
+ SpeedMatrix.LogPositionValues(positionHistories, valueDisplay, this.flattenPositionRange, logger);
207
+ }
208
+ getSpeed() {
209
+ if (!this.speed) {
210
+ return { angleInDegrees: 0, pixelsPerPeriod: 0 };
211
+ }
212
+ return this.speed;
213
+ }
214
+ getFlatten() {
215
+ if (this.flattenPositionHistory) {
216
+ return this.flattenPositionHistory;
217
+ }
218
+ this.flattenPositionHistory = [];
219
+ const yWidth = this.flattenPositionRange.yMax - this.flattenPositionRange.yMin + 1;
220
+ const xWidth = this.flattenPositionRange.xMax - this.flattenPositionRange.xMin + 1;
221
+ for (let y = 0; y < yWidth; y++) {
222
+ this.flattenPositionHistory.push(new Array(xWidth).fill(0));
223
+ }
224
+ // same position => add value
225
+ for (const qualityPoint of this.qualityPoints) {
226
+ const ratio = qualityPoint.getRatio();
227
+ const cartesianValue = new CartesianValue_1.CartesianValue({
228
+ value: ratio,
229
+ lat: qualityPoint.getRainLat() - qualityPoint.gaugeCartesianValue.lat,
230
+ lng: qualityPoint.getRainLng() - qualityPoint.gaugeCartesianValue.lng,
231
+ });
232
+ const position = QualityTools_1.QualityTools.MapLatLngToPosition(cartesianValue, false, new LatLng_1.LatLng({
233
+ lat: QualityTools_1.QualityTools.DEFAULT_SCALE,
234
+ lng: QualityTools_1.QualityTools.DEFAULT_SCALE
235
+ }));
236
+ const positionX = Math.round((position.x / this.roundScale.x) - this.flattenPositionRange.xMin);
237
+ const positionY = Math.round((position.y / this.roundScale.y) - this.flattenPositionRange.yMin);
238
+ if (0 <= positionX && positionX < xWidth && 0 <= positionY && positionY < yWidth) {
239
+ this.flattenPositionHistory[positionX][positionY] += cartesianValue.value;
240
+ }
241
+ else {
242
+ throw new Error('Matrix ranges and positions are not consistent.');
243
+ }
244
+ }
245
+ return this.flattenPositionHistory;
246
+ }
247
+ }
248
+ SpeedMatrix.DEFAULT_MATRIX_RANGE = 8;
249
+ SpeedMatrix.DEFAULT_TRUSTED_INDICATOR = 1;
250
+ exports.SpeedMatrix = SpeedMatrix;
251
+ //# sourceMappingURL=SpeedMatrix.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SpeedMatrix.js","sourceRoot":"","sources":["../../src/quality/SpeedMatrix.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,76 @@
1
+ import { SpeedMatrix } from './SpeedMatrix';
2
+ import { PositionValue } from './position/PositionValue';
3
+ import { QualityPoint } from './QualityPoint';
4
+ export declare class SpeedMatrixContainer {
5
+ protected qualityPoints: QualityPoint[];
6
+ protected trustedIndicators: number[];
7
+ protected flattenMatrices: PositionValue[][];
8
+ protected matrices: SpeedMatrix[];
9
+ constructor(json: {
10
+ matrices: SpeedMatrix[];
11
+ });
12
+ static CreateFromJson(json: any): SpeedMatrixContainer;
13
+ protected static mergeStillComputed(v1: any, v2: any): any;
14
+ protected static mergeDateMin(d1: Date, d2: Date): Date;
15
+ protected static mergeDateMax(d1: Date, d2: Date): Date;
16
+ protected static mergeAvg(v1: number, v2: number): number;
17
+ protected static mergeMin(v1: number, v2: number): number;
18
+ protected static mergeConcat(a1: Array<any>, a2: Array<any>): Array<any>;
19
+ protected static mergeReduce(a1: Array<QualityPoint>, a2: Array<QualityPoint>): Array<QualityPoint>;
20
+ getMatrix(index?: number): SpeedMatrix;
21
+ getMatrices(): SpeedMatrix[];
22
+ getQualityPoints(): QualityPoint[];
23
+ getMaxGauge(): number;
24
+ getMaxRain(): number;
25
+ /**
26
+ * Get summed quality indicator (0 ideally)
27
+ * @link SpeedMatrix.ComputeQualityIndicator
28
+ */
29
+ getQuality(): number;
30
+ getTrustedIndicators(): number[];
31
+ getSpeed(): {
32
+ angleInDegrees: number;
33
+ pixelsPerPeriod: number;
34
+ };
35
+ isConsistent(): boolean;
36
+ getFlattenMatrixCount(): number;
37
+ renderFlattenMatrix(index?: number, options?: {
38
+ normalize?: boolean;
39
+ }): PositionValue[];
40
+ renderMergedMatrix(options?: {
41
+ normalize?: boolean;
42
+ }): PositionValue[];
43
+ toJSON(options?: {
44
+ removeFlatten?: boolean;
45
+ removeMatrices?: boolean;
46
+ removeIndicators?: boolean;
47
+ }): {
48
+ qualityPoints: QualityPoint[];
49
+ trustedIndicators: number[];
50
+ flattenMatrices: PositionValue[][];
51
+ speed: {
52
+ angleInDegrees: number;
53
+ pixelsPerPeriod: number;
54
+ };
55
+ matrices: {
56
+ flattenPositionHistory: number[][];
57
+ flattenPositionRange: {
58
+ xMin: number;
59
+ xMax: number;
60
+ yMin: number;
61
+ yMax: number;
62
+ };
63
+ speed: {
64
+ angleInDegrees: number;
65
+ pixelsPerPeriod: number;
66
+ };
67
+ qualityPoints: QualityPoint[];
68
+ trustedTechnicalIndicator: number;
69
+ roundScale: import("..").Position;
70
+ }[];
71
+ };
72
+ merge(speedMatrixContainerToMergeIn: SpeedMatrixContainer): this;
73
+ logMergedMatrix(options?: {
74
+ normalize?: boolean;
75
+ }): void;
76
+ }