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.
- package/README.md +7 -10
- package/RELEASE.md +10 -10
- package/cartesian/CartesianMeasureValue.d.ts +41 -0
- package/cartesian/CartesianMeasureValue.js +106 -0
- package/cartesian/CartesianMeasureValue.js.map +1 -0
- package/cartesian/CartesianValue.d.ts +9 -0
- package/cartesian/CartesianValue.js +12 -0
- package/cartesian/CartesianValue.js.map +1 -0
- package/cartesian/ICartesianMeasureValue.d.ts +29 -0
- package/cartesian/ICartesianMeasureValue.js +3 -0
- package/cartesian/ICartesianMeasureValue.js.map +1 -0
- package/cartesian/LatLng.d.ts +12 -0
- package/cartesian/LatLng.js +31 -0
- package/cartesian/LatLng.js.map +1 -0
- package/cartesian/RadarCartesianMeasureValue.d.ts +15 -0
- package/cartesian/RadarCartesianMeasureValue.js +22 -0
- package/cartesian/RadarCartesianMeasureValue.js.map +1 -0
- package/cartesian/RainCartesianMeasureValue.d.ts +17 -0
- package/cartesian/RainCartesianMeasureValue.js +25 -0
- package/cartesian/RainCartesianMeasureValue.js.map +1 -0
- package/gauge/GaugeMeasure.d.ts +20 -0
- package/gauge/GaugeMeasure.js +24 -0
- package/gauge/GaugeMeasure.js.map +1 -0
- package/gauge/GaugeNode.d.ts +24 -0
- package/gauge/GaugeNode.js +31 -0
- package/gauge/GaugeNode.js.map +1 -0
- package/gauge/GaugeNodeMap.d.ts +22 -0
- package/gauge/GaugeNodeMap.js +42 -0
- package/gauge/GaugeNodeMap.js.map +1 -0
- package/index.d.ts +39 -20
- package/index.js +53 -23
- package/index.js.map +1 -1
- package/organization/EventNode.d.ts +22 -0
- package/organization/EventNode.js +30 -0
- package/organization/EventNode.js.map +1 -0
- package/{IVersion.js.map → organization/IVersion.js.map} +1 -1
- package/{Link.d.ts → organization/Link.d.ts} +4 -5
- package/organization/Link.js +34 -0
- package/organization/Link.js.map +1 -0
- package/organization/Measure.d.ts +20 -0
- package/organization/Measure.js +35 -0
- package/organization/Measure.js.map +1 -0
- package/organization/PeopleNode.d.ts +18 -0
- package/organization/PeopleNode.js +26 -0
- package/organization/PeopleNode.js.map +1 -0
- package/{RaainNode.d.ts → organization/RaainNode.d.ts} +12 -7
- package/organization/RaainNode.js +95 -0
- package/organization/RaainNode.js.map +1 -0
- package/organization/TeamNode.d.ts +22 -0
- package/organization/TeamNode.js +32 -0
- package/organization/TeamNode.js.map +1 -0
- package/package.json +13 -10
- package/polar/AbstractPolarMeasureValue.d.ts +29 -0
- package/polar/AbstractPolarMeasureValue.js +92 -0
- package/polar/AbstractPolarMeasureValue.js.map +1 -0
- package/polar/GaugePolarMeasureValue.d.ts +11 -0
- package/polar/GaugePolarMeasureValue.js +14 -0
- package/polar/GaugePolarMeasureValue.js.map +1 -0
- package/polar/IPolarMeasureValue.d.ts +19 -0
- package/{IMeasureValue.js → polar/IPolarMeasureValue.js} +1 -1
- package/polar/IPolarMeasureValue.js.map +1 -0
- package/polar/MeasureValuePolarContainer.d.ts +11 -0
- package/polar/MeasureValuePolarContainer.js +22 -0
- package/polar/MeasureValuePolarContainer.js.map +1 -0
- package/polar/PolarMeasureValue.d.ts +26 -0
- package/polar/PolarMeasureValue.js +100 -0
- package/polar/PolarMeasureValue.js.map +1 -0
- package/polar/PolarValue.d.ts +10 -0
- package/polar/PolarValue.js +12 -0
- package/polar/PolarValue.js.map +1 -0
- package/polar/RadarPolarMeasureValue.d.ts +15 -0
- package/polar/RadarPolarMeasureValue.js +34 -0
- package/polar/RadarPolarMeasureValue.js.map +1 -0
- package/polar/RainPolarMeasureValue.d.ts +18 -0
- package/polar/RainPolarMeasureValue.js +42 -0
- package/polar/RainPolarMeasureValue.js.map +1 -0
- package/quality/QualityPoint.d.ts +35 -0
- package/quality/QualityPoint.js +63 -0
- package/quality/QualityPoint.js.map +1 -0
- package/quality/SpeedMatrix.d.ts +79 -0
- package/quality/SpeedMatrix.js +251 -0
- package/quality/SpeedMatrix.js.map +1 -0
- package/quality/SpeedMatrixContainer.d.ts +76 -0
- package/quality/SpeedMatrixContainer.js +310 -0
- package/quality/SpeedMatrixContainer.js.map +1 -0
- package/quality/history/CartesianGaugeHistory.d.ts +15 -0
- package/quality/history/CartesianGaugeHistory.js +14 -0
- package/quality/history/CartesianGaugeHistory.js.map +1 -0
- package/quality/history/CartesianRainHistory.d.ts +11 -0
- package/quality/history/CartesianRainHistory.js +12 -0
- package/quality/history/CartesianRainHistory.js.map +1 -0
- package/quality/history/PositionHistory.d.ts +20 -0
- package/quality/history/PositionHistory.js +17 -0
- package/quality/history/PositionHistory.js.map +1 -0
- package/quality/position/Position.d.ts +22 -0
- package/quality/position/Position.js +50 -0
- package/quality/position/Position.js.map +1 -0
- package/quality/position/PositionValue.d.ts +9 -0
- package/quality/position/PositionValue.js +12 -0
- package/quality/position/PositionValue.js.map +1 -0
- package/quality/tools/QualityTools.d.ts +24 -0
- package/quality/tools/QualityTools.js +182 -0
- package/quality/tools/QualityTools.js.map +1 -0
- package/radar/RadarMeasure.d.ts +17 -0
- package/radar/RadarMeasure.js +18 -0
- package/radar/RadarMeasure.js.map +1 -0
- package/radar/RadarNode.d.ts +24 -0
- package/radar/RadarNode.js +31 -0
- package/radar/RadarNode.js.map +1 -0
- package/radar/RadarNodeMap.d.ts +28 -0
- package/radar/RadarNodeMap.js +46 -0
- package/radar/RadarNodeMap.js.map +1 -0
- package/rain/RainComputation.d.ts +34 -0
- package/rain/RainComputation.js +55 -0
- package/rain/RainComputation.js.map +1 -0
- package/{RainComputationNode.d.ts → rain/RainComputationAbstract.d.ts} +19 -20
- package/rain/RainComputationAbstract.js +102 -0
- package/rain/RainComputationAbstract.js.map +1 -0
- package/rain/RainComputationMap.d.ts +32 -0
- package/rain/RainComputationMap.js +45 -0
- package/rain/RainComputationMap.js.map +1 -0
- package/rain/RainComputationQuality.d.ts +37 -0
- package/rain/RainComputationQuality.js +103 -0
- package/rain/RainComputationQuality.js.map +1 -0
- package/rain/RainMeasure.d.ts +18 -0
- package/rain/RainMeasure.js +19 -0
- package/rain/RainMeasure.js.map +1 -0
- package/rain/RainNode.d.ts +38 -0
- package/rain/RainNode.js +127 -0
- package/rain/RainNode.js.map +1 -0
- package/EventNode.d.ts +0 -10
- package/EventNode.js +0 -17
- package/EventNode.js.map +0 -1
- package/GaugeMeasure.d.ts +0 -7
- package/GaugeMeasure.js +0 -31
- package/GaugeMeasure.js.map +0 -1
- package/GaugeMeasureValue.d.ts +0 -16
- package/GaugeMeasureValue.js +0 -66
- package/GaugeMeasureValue.js.map +0 -1
- package/GaugeNode.d.ts +0 -19
- package/GaugeNode.js +0 -48
- package/GaugeNode.js.map +0 -1
- package/GaugeNodeMap.d.ts +0 -22
- package/GaugeNodeMap.js +0 -61
- package/GaugeNodeMap.js.map +0 -1
- package/IMeasureValue.d.ts +0 -12
- package/IMeasureValue.js.map +0 -1
- package/Link.js +0 -36
- package/Link.js.map +0 -1
- package/Measure.d.ts +0 -9
- package/Measure.js +0 -43
- package/Measure.js.map +0 -1
- package/MeasureValuePolarContainer.d.ts +0 -7
- package/MeasureValuePolarContainer.js +0 -28
- package/MeasureValuePolarContainer.js.map +0 -1
- package/PeopleNode.d.ts +0 -7
- package/PeopleNode.js +0 -14
- package/PeopleNode.js.map +0 -1
- package/PolarValue.d.ts +0 -6
- package/PolarValue.js +0 -12
- package/PolarValue.js.map +0 -1
- package/RaainNode.js +0 -103
- package/RaainNode.js.map +0 -1
- package/RadarMeasure.d.ts +0 -7
- package/RadarMeasure.js +0 -31
- package/RadarMeasure.js.map +0 -1
- package/RadarMeasureValue.d.ts +0 -19
- package/RadarMeasureValue.js +0 -75
- package/RadarMeasureValue.js.map +0 -1
- package/RadarNode.d.ts +0 -14
- package/RadarNode.js +0 -49
- package/RadarNode.js.map +0 -1
- package/RadarNodeMap.d.ts +0 -11
- package/RadarNodeMap.js +0 -56
- package/RadarNodeMap.js.map +0 -1
- package/RainComputationMap.d.ts +0 -11
- package/RainComputationMap.js +0 -59
- package/RainComputationMap.js.map +0 -1
- package/RainComputationNode.js +0 -148
- package/RainComputationNode.js.map +0 -1
- package/RainMeasure.d.ts +0 -5
- package/RainMeasure.js +0 -29
- package/RainMeasure.js.map +0 -1
- package/RainMeasureValue.d.ts +0 -21
- package/RainMeasureValue.js +0 -74
- package/RainMeasureValue.js.map +0 -1
- package/RainNode.d.ts +0 -21
- package/RainNode.js +0 -107
- package/RainNode.js.map +0 -1
- package/tools/PolarValues.d.ts +0 -16
- package/tools/PolarValues.js +0 -99
- package/tools/PolarValues.js.map +0 -1
- /package/{IVersion.d.ts → organization/IVersion.d.ts} +0 -0
- /package/{IVersion.js → organization/IVersion.js} +0 -0
|
@@ -0,0 +1,310 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SpeedMatrixContainer = void 0;
|
|
4
|
+
const SpeedMatrix_1 = require("./SpeedMatrix");
|
|
5
|
+
const PositionValue_1 = require("./position/PositionValue");
|
|
6
|
+
const PositionHistory_1 = require("./history/PositionHistory");
|
|
7
|
+
const QualityPoint_1 = require("./QualityPoint");
|
|
8
|
+
const CartesianValue_1 = require("../cartesian/CartesianValue");
|
|
9
|
+
class SpeedMatrixContainer {
|
|
10
|
+
constructor(json) {
|
|
11
|
+
this.qualityPoints = undefined;
|
|
12
|
+
this.trustedIndicators = [];
|
|
13
|
+
this.flattenMatrices = [];
|
|
14
|
+
this.matrices = json.matrices;
|
|
15
|
+
}
|
|
16
|
+
static CreateFromJson(json) {
|
|
17
|
+
const created = new SpeedMatrixContainer({ matrices: [] });
|
|
18
|
+
if (json === null || json === void 0 ? void 0 : json.qualityPoints) {
|
|
19
|
+
created.qualityPoints = json.qualityPoints;
|
|
20
|
+
}
|
|
21
|
+
if (json === null || json === void 0 ? void 0 : json.matrices) {
|
|
22
|
+
created.matrices = json.matrices.map((m) => SpeedMatrix_1.SpeedMatrix.CreateFromJson(m));
|
|
23
|
+
}
|
|
24
|
+
if (json === null || json === void 0 ? void 0 : json.trustedIndicators) {
|
|
25
|
+
created.trustedIndicators = json.trustedIndicators;
|
|
26
|
+
}
|
|
27
|
+
if (json === null || json === void 0 ? void 0 : json.flattenMatrices) {
|
|
28
|
+
created.flattenMatrices = json.flattenMatrices;
|
|
29
|
+
}
|
|
30
|
+
return created;
|
|
31
|
+
}
|
|
32
|
+
static mergeStillComputed(v1, v2) {
|
|
33
|
+
if (!v1 && !v2) {
|
|
34
|
+
return undefined;
|
|
35
|
+
}
|
|
36
|
+
if (!v1) {
|
|
37
|
+
return v2;
|
|
38
|
+
}
|
|
39
|
+
if (!v2) {
|
|
40
|
+
return v1;
|
|
41
|
+
}
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
static mergeDateMin(d1, d2) {
|
|
45
|
+
const stillComputed = this.mergeStillComputed(d1, d2);
|
|
46
|
+
if (stillComputed === null) {
|
|
47
|
+
return new Date(Math.min(new Date(d1).getTime(), new Date(d2).getTime()));
|
|
48
|
+
}
|
|
49
|
+
if (stillComputed !== undefined) {
|
|
50
|
+
return new Date(stillComputed);
|
|
51
|
+
}
|
|
52
|
+
return stillComputed;
|
|
53
|
+
}
|
|
54
|
+
static mergeDateMax(d1, d2) {
|
|
55
|
+
const stillComputed = this.mergeStillComputed(d1, d2);
|
|
56
|
+
if (stillComputed === null) {
|
|
57
|
+
return new Date(Math.max(new Date(d1).getTime(), new Date(d2).getTime()));
|
|
58
|
+
}
|
|
59
|
+
if (stillComputed !== undefined) {
|
|
60
|
+
return new Date(stillComputed);
|
|
61
|
+
}
|
|
62
|
+
return stillComputed;
|
|
63
|
+
}
|
|
64
|
+
static mergeAvg(v1, v2) {
|
|
65
|
+
if (v1 === 0 && v2 === 0) {
|
|
66
|
+
return 0;
|
|
67
|
+
}
|
|
68
|
+
const stillComputed = this.mergeStillComputed(v1, v2);
|
|
69
|
+
if (stillComputed === null) {
|
|
70
|
+
return (v1 + v2) / 2;
|
|
71
|
+
}
|
|
72
|
+
return stillComputed;
|
|
73
|
+
}
|
|
74
|
+
static mergeMin(v1, v2) {
|
|
75
|
+
const stillComputed = this.mergeStillComputed(v1, v2);
|
|
76
|
+
if (stillComputed === null) {
|
|
77
|
+
return Math.min(v1, v2);
|
|
78
|
+
}
|
|
79
|
+
return stillComputed;
|
|
80
|
+
}
|
|
81
|
+
static mergeConcat(a1, a2) {
|
|
82
|
+
const stillComputed = this.mergeStillComputed(a1, a2);
|
|
83
|
+
if (stillComputed === null) {
|
|
84
|
+
return a1.concat(a2);
|
|
85
|
+
}
|
|
86
|
+
return stillComputed;
|
|
87
|
+
}
|
|
88
|
+
static mergeReduce(a1, a2) {
|
|
89
|
+
const stillComputed = this.mergeStillComputed(a1, a2);
|
|
90
|
+
if (stillComputed === null) {
|
|
91
|
+
const ids = new Map();
|
|
92
|
+
const concatted = a1.concat(a2);
|
|
93
|
+
for (const qualityPoint of concatted) {
|
|
94
|
+
const oldValue = {
|
|
95
|
+
gaugeValue: 0,
|
|
96
|
+
rainValue: 0
|
|
97
|
+
};
|
|
98
|
+
// if (ids.has(qualityPoint.gaugeId)) {
|
|
99
|
+
// oldValue = ids.get(qualityPoint.gaugeId);
|
|
100
|
+
// }
|
|
101
|
+
ids.set(qualityPoint.gaugeId, {
|
|
102
|
+
gaugeLabel: qualityPoint.gaugeLabel,
|
|
103
|
+
gaugeValue: qualityPoint.getGaugeValue() + oldValue.gaugeValue,
|
|
104
|
+
gaugeLat: qualityPoint.gaugeCartesianValue.lat,
|
|
105
|
+
gaugeLng: qualityPoint.gaugeCartesianValue.lng,
|
|
106
|
+
rainValue: qualityPoint.getRainValue() + oldValue.rainValue,
|
|
107
|
+
rainLat: qualityPoint.getRainLat(),
|
|
108
|
+
rainLng: qualityPoint.getRainLng(),
|
|
109
|
+
gaugeDate: qualityPoint.gaugeDate,
|
|
110
|
+
rainDate: qualityPoint.rainDate,
|
|
111
|
+
rainCartesianValues: qualityPoint.rainCartesianValues,
|
|
112
|
+
remark: qualityPoint.remark,
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
return [...ids].map(([id, value]) => {
|
|
116
|
+
return new QualityPoint_1.QualityPoint({
|
|
117
|
+
gaugeId: id,
|
|
118
|
+
gaugeLabel: value.gaugeLabel,
|
|
119
|
+
gaugeDate: value.gaugeDate,
|
|
120
|
+
rainDate: value.rainDate,
|
|
121
|
+
gaugeCartesianValue: new CartesianValue_1.CartesianValue({ value: value.gaugeValue, lat: value.gaugeLat, lng: value.gaugeLng }),
|
|
122
|
+
rainCartesianValues: value.rainCartesianValues,
|
|
123
|
+
speed: null,
|
|
124
|
+
remark: value.remark,
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
return stillComputed;
|
|
129
|
+
}
|
|
130
|
+
getMatrix(index = 0) {
|
|
131
|
+
return this.getMatrices()[index];
|
|
132
|
+
}
|
|
133
|
+
getMatrices() {
|
|
134
|
+
return this.matrices;
|
|
135
|
+
}
|
|
136
|
+
getQualityPoints() {
|
|
137
|
+
if (this.qualityPoints) {
|
|
138
|
+
if (this.qualityPoints.length > 0 && this.flattenMatrices.length > 0) {
|
|
139
|
+
return this.qualityPoints.map(p => new QualityPoint_1.QualityPoint(p));
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
this.qualityPoints = [];
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
const flattenMatrices = [];
|
|
146
|
+
let qualityPoints = [];
|
|
147
|
+
for (const matrix of this.matrices) {
|
|
148
|
+
if (matrix.isConsistent()) {
|
|
149
|
+
flattenMatrices.push(matrix.renderFlatten({ normalize: true }));
|
|
150
|
+
qualityPoints = SpeedMatrixContainer.mergeReduce(qualityPoints, matrix.getQualityPoints());
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
// store
|
|
154
|
+
this.flattenMatrices = flattenMatrices;
|
|
155
|
+
this.qualityPoints = qualityPoints.map(p => new QualityPoint_1.QualityPoint(p));
|
|
156
|
+
return this.qualityPoints;
|
|
157
|
+
}
|
|
158
|
+
getMaxGauge() {
|
|
159
|
+
const qualityPoints = this.getQualityPoints();
|
|
160
|
+
let max = -1;
|
|
161
|
+
for (const p of qualityPoints) {
|
|
162
|
+
max = Math.max(max, p.getGaugeValue());
|
|
163
|
+
}
|
|
164
|
+
return max;
|
|
165
|
+
}
|
|
166
|
+
getMaxRain() {
|
|
167
|
+
const qualityPoints = this.getQualityPoints();
|
|
168
|
+
let max = -1;
|
|
169
|
+
for (const p of qualityPoints) {
|
|
170
|
+
max = Math.max(max, p.getRainValue());
|
|
171
|
+
}
|
|
172
|
+
return max;
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Get summed quality indicator (0 ideally)
|
|
176
|
+
* @link SpeedMatrix.ComputeQualityIndicator
|
|
177
|
+
*/
|
|
178
|
+
getQuality() {
|
|
179
|
+
const qualityPoints = this.getQualityPoints();
|
|
180
|
+
return SpeedMatrix_1.SpeedMatrix.ComputeQualityIndicator(qualityPoints);
|
|
181
|
+
}
|
|
182
|
+
getTrustedIndicators() {
|
|
183
|
+
if (this.trustedIndicators.length > 0) {
|
|
184
|
+
return this.trustedIndicators;
|
|
185
|
+
}
|
|
186
|
+
this.trustedIndicators = [];
|
|
187
|
+
for (const matrix of this.matrices) {
|
|
188
|
+
this.trustedIndicators.push(matrix.getTrustedTechnicalIndicator());
|
|
189
|
+
}
|
|
190
|
+
return this.trustedIndicators;
|
|
191
|
+
}
|
|
192
|
+
getSpeed() {
|
|
193
|
+
let mergedSpeed;
|
|
194
|
+
for (const matrix of this.matrices) {
|
|
195
|
+
if (!mergedSpeed) {
|
|
196
|
+
mergedSpeed = matrix.getSpeed();
|
|
197
|
+
}
|
|
198
|
+
else {
|
|
199
|
+
mergedSpeed = {
|
|
200
|
+
angleInDegrees: SpeedMatrixContainer.mergeAvg(mergedSpeed.angleInDegrees, matrix.getSpeed().angleInDegrees),
|
|
201
|
+
pixelsPerPeriod: SpeedMatrixContainer.mergeAvg(mergedSpeed.pixelsPerPeriod, matrix.getSpeed().pixelsPerPeriod),
|
|
202
|
+
};
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
if (!mergedSpeed) {
|
|
206
|
+
mergedSpeed = { angleInDegrees: 0, pixelsPerPeriod: 0 };
|
|
207
|
+
}
|
|
208
|
+
return mergedSpeed;
|
|
209
|
+
}
|
|
210
|
+
isConsistent() {
|
|
211
|
+
const indics = this.getTrustedIndicators();
|
|
212
|
+
let indicAverage = 0;
|
|
213
|
+
for (const indic of indics) {
|
|
214
|
+
indicAverage += indic;
|
|
215
|
+
}
|
|
216
|
+
indicAverage = indicAverage / (indics.length ? indics.length : 1);
|
|
217
|
+
return indicAverage > (SpeedMatrix_1.SpeedMatrix.DEFAULT_TRUSTED_INDICATOR / 2);
|
|
218
|
+
}
|
|
219
|
+
getFlattenMatrixCount() {
|
|
220
|
+
return this.flattenMatrices.length;
|
|
221
|
+
}
|
|
222
|
+
renderFlattenMatrix(index = 0, options = { normalize: true }) {
|
|
223
|
+
let rendered;
|
|
224
|
+
if (this.flattenMatrices && this.flattenMatrices[index]) {
|
|
225
|
+
rendered = this.flattenMatrices[index];
|
|
226
|
+
}
|
|
227
|
+
else {
|
|
228
|
+
this.getQualityPoints();
|
|
229
|
+
rendered = this.flattenMatrices[index];
|
|
230
|
+
}
|
|
231
|
+
if (options.normalize) {
|
|
232
|
+
rendered = SpeedMatrix_1.SpeedMatrix.Normalize(rendered);
|
|
233
|
+
}
|
|
234
|
+
return rendered;
|
|
235
|
+
}
|
|
236
|
+
renderMergedMatrix(options = { normalize: true }) {
|
|
237
|
+
var _a;
|
|
238
|
+
const count = this.flattenMatrices.length;
|
|
239
|
+
const size = Math.sqrt((_a = this.flattenMatrices[0]) === null || _a === void 0 ? void 0 : _a.length);
|
|
240
|
+
const range = (size - 1) / 2;
|
|
241
|
+
let maxValue = 0;
|
|
242
|
+
let matrix = [];
|
|
243
|
+
for (let x = -range; x <= range; x++) {
|
|
244
|
+
for (let y = -range; y <= range; y++) {
|
|
245
|
+
let value = 0;
|
|
246
|
+
for (const flattenMatrix of this.flattenMatrices) {
|
|
247
|
+
const pos = flattenMatrix.filter(v => v.x === x && v.y === y)[0];
|
|
248
|
+
value += pos.value;
|
|
249
|
+
maxValue = Math.max(maxValue, value);
|
|
250
|
+
}
|
|
251
|
+
value = value / count;
|
|
252
|
+
matrix.push(new PositionValue_1.PositionValue({ x, y, value }));
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
if (options.normalize) {
|
|
256
|
+
matrix = SpeedMatrix_1.SpeedMatrix.Normalize(matrix);
|
|
257
|
+
}
|
|
258
|
+
return matrix;
|
|
259
|
+
}
|
|
260
|
+
toJSON(options) {
|
|
261
|
+
const json = {
|
|
262
|
+
qualityPoints: this.getQualityPoints(),
|
|
263
|
+
trustedIndicators: this.getTrustedIndicators(),
|
|
264
|
+
flattenMatrices: this.flattenMatrices,
|
|
265
|
+
speed: this.getSpeed(),
|
|
266
|
+
matrices: this.matrices
|
|
267
|
+
.filter(m => !!m)
|
|
268
|
+
.map(m => m.toJSON()),
|
|
269
|
+
};
|
|
270
|
+
if (options === null || options === void 0 ? void 0 : options.removeMatrices) {
|
|
271
|
+
delete json.matrices;
|
|
272
|
+
}
|
|
273
|
+
if (options === null || options === void 0 ? void 0 : options.removeFlatten) {
|
|
274
|
+
delete json.flattenMatrices;
|
|
275
|
+
}
|
|
276
|
+
if (options === null || options === void 0 ? void 0 : options.removeIndicators) {
|
|
277
|
+
delete json.trustedIndicators;
|
|
278
|
+
}
|
|
279
|
+
return json;
|
|
280
|
+
}
|
|
281
|
+
merge(speedMatrixContainerToMergeIn) {
|
|
282
|
+
this.qualityPoints = SpeedMatrixContainer.mergeReduce(this.getQualityPoints(), speedMatrixContainerToMergeIn.getQualityPoints());
|
|
283
|
+
this.trustedIndicators = SpeedMatrixContainer.mergeConcat(this.getTrustedIndicators(), speedMatrixContainerToMergeIn.getTrustedIndicators());
|
|
284
|
+
this.matrices = SpeedMatrixContainer.mergeConcat(this.matrices, speedMatrixContainerToMergeIn.matrices);
|
|
285
|
+
this.flattenMatrices = SpeedMatrixContainer.mergeConcat(this.flattenMatrices, speedMatrixContainerToMergeIn.flattenMatrices);
|
|
286
|
+
return this;
|
|
287
|
+
}
|
|
288
|
+
logMergedMatrix(options = { normalize: true }) {
|
|
289
|
+
const mergedMatrix = this.renderMergedMatrix(options);
|
|
290
|
+
const positionHistories = mergedMatrix.map(pv => new PositionHistory_1.PositionHistory({
|
|
291
|
+
id: '-',
|
|
292
|
+
label: '-',
|
|
293
|
+
date: null,
|
|
294
|
+
x: pv.x,
|
|
295
|
+
y: pv.y,
|
|
296
|
+
value: pv.value,
|
|
297
|
+
valueFromGauge: -1,
|
|
298
|
+
valueFromRain: -1
|
|
299
|
+
}));
|
|
300
|
+
const valueDisplay = (pv) => {
|
|
301
|
+
if (!pv) {
|
|
302
|
+
return '';
|
|
303
|
+
}
|
|
304
|
+
return '' + Math.round(pv.value * 1000) / 1000;
|
|
305
|
+
};
|
|
306
|
+
SpeedMatrix_1.SpeedMatrix.LogPositionValues(positionHistories, valueDisplay);
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
exports.SpeedMatrixContainer = SpeedMatrixContainer;
|
|
310
|
+
//# sourceMappingURL=SpeedMatrixContainer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SpeedMatrixContainer.js","sourceRoot":"","sources":["../../src/quality/SpeedMatrixContainer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { CartesianValue } from '../../cartesian/CartesianValue';
|
|
2
|
+
export declare class CartesianGaugeHistory {
|
|
3
|
+
gaugeId: string;
|
|
4
|
+
gaugeLabel: string;
|
|
5
|
+
date: Date;
|
|
6
|
+
value: CartesianValue;
|
|
7
|
+
configurationAsJSON: string;
|
|
8
|
+
constructor(json: {
|
|
9
|
+
gaugeId: string;
|
|
10
|
+
gaugeLabel: string;
|
|
11
|
+
date: Date;
|
|
12
|
+
value: CartesianValue;
|
|
13
|
+
configurationAsJSON: string;
|
|
14
|
+
});
|
|
15
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CartesianGaugeHistory = void 0;
|
|
4
|
+
class CartesianGaugeHistory {
|
|
5
|
+
constructor(json) {
|
|
6
|
+
this.gaugeId = json.gaugeId;
|
|
7
|
+
this.gaugeLabel = json.gaugeLabel;
|
|
8
|
+
this.date = json.date;
|
|
9
|
+
this.value = json.value;
|
|
10
|
+
this.configurationAsJSON = json.configurationAsJSON;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.CartesianGaugeHistory = CartesianGaugeHistory;
|
|
14
|
+
//# sourceMappingURL=CartesianGaugeHistory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CartesianGaugeHistory.js","sourceRoot":"","sources":["../../../src/quality/history/CartesianGaugeHistory.ts"],"names":[],"mappings":";;;AAEA,MAAa,qBAAqB;IAO9B,YAAY,IAMX;QACG,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACtB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACxB,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;IACxD,CAAC;CACJ;AApBD,sDAoBC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { CartesianValue } from '../../cartesian/CartesianValue';
|
|
2
|
+
export declare class CartesianRainHistory {
|
|
3
|
+
periodBegin: Date;
|
|
4
|
+
periodEnd: Date;
|
|
5
|
+
computedValue: CartesianValue;
|
|
6
|
+
constructor(json: {
|
|
7
|
+
periodBegin: Date;
|
|
8
|
+
periodEnd: Date;
|
|
9
|
+
computedValue: CartesianValue;
|
|
10
|
+
});
|
|
11
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CartesianRainHistory = void 0;
|
|
4
|
+
class CartesianRainHistory {
|
|
5
|
+
constructor(json) {
|
|
6
|
+
this.periodBegin = json.periodBegin;
|
|
7
|
+
this.periodEnd = json.periodEnd;
|
|
8
|
+
this.computedValue = json.computedValue;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.CartesianRainHistory = CartesianRainHistory;
|
|
12
|
+
//# sourceMappingURL=CartesianRainHistory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CartesianRainHistory.js","sourceRoot":"","sources":["../../../src/quality/history/CartesianRainHistory.ts"],"names":[],"mappings":";;;AAEA,MAAa,oBAAoB;IAM7B,YAAY,IAIX;QACG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;IAC5C,CAAC;CACJ;AAfD,oDAeC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { PositionValue } from '../position/PositionValue';
|
|
2
|
+
export declare class PositionHistory extends PositionValue {
|
|
3
|
+
id: string;
|
|
4
|
+
label: string;
|
|
5
|
+
date: Date;
|
|
6
|
+
valueFromGauge: number;
|
|
7
|
+
valueFromRain: number;
|
|
8
|
+
configurationAsJSON: string;
|
|
9
|
+
constructor(json: {
|
|
10
|
+
id: string;
|
|
11
|
+
label: string;
|
|
12
|
+
date: Date;
|
|
13
|
+
x: number;
|
|
14
|
+
y: number;
|
|
15
|
+
value: number;
|
|
16
|
+
valueFromGauge?: number;
|
|
17
|
+
valueFromRain?: number;
|
|
18
|
+
configurationAsJSON?: string;
|
|
19
|
+
});
|
|
20
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PositionHistory = void 0;
|
|
4
|
+
const PositionValue_1 = require("../position/PositionValue");
|
|
5
|
+
class PositionHistory extends PositionValue_1.PositionValue {
|
|
6
|
+
constructor(json) {
|
|
7
|
+
super(json);
|
|
8
|
+
this.id = json.id;
|
|
9
|
+
this.label = json.label;
|
|
10
|
+
this.date = json.date;
|
|
11
|
+
this.valueFromGauge = json.valueFromGauge;
|
|
12
|
+
this.valueFromRain = json.valueFromRain;
|
|
13
|
+
this.configurationAsJSON = json.configurationAsJSON;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.PositionHistory = PositionHistory;
|
|
17
|
+
//# sourceMappingURL=PositionHistory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PositionHistory.js","sourceRoot":"","sources":["../../../src/quality/history/PositionHistory.ts"],"names":[],"mappings":";;;AAAA,6DAAwD;AAExD,MAAa,eAAgB,SAAQ,6BAAa;IAQ9C,YAAY,IAUX;QACG,KAAK,CAAC,IAAI,CAAC,CAAC;QAEZ,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAClB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACtB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAC1C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACxC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;IACxD,CAAC;CACJ;AA5BD,0CA4BC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export declare class Position {
|
|
2
|
+
static DEFAULT_PRECISION: number;
|
|
3
|
+
x: number;
|
|
4
|
+
y: number;
|
|
5
|
+
private readonly precision;
|
|
6
|
+
constructor(json: {
|
|
7
|
+
x: number;
|
|
8
|
+
y: number;
|
|
9
|
+
});
|
|
10
|
+
static uniq: (a: Position[]) => Position[];
|
|
11
|
+
setPrecision(precision?: number): void;
|
|
12
|
+
getXY(precision?: number): {
|
|
13
|
+
x: number;
|
|
14
|
+
y: number;
|
|
15
|
+
};
|
|
16
|
+
samePosition(p: Position, precision?: number): boolean;
|
|
17
|
+
getPrecision(): number;
|
|
18
|
+
getXYScaled(scale: number): {
|
|
19
|
+
x: number;
|
|
20
|
+
y: number;
|
|
21
|
+
};
|
|
22
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Position = void 0;
|
|
4
|
+
class Position {
|
|
5
|
+
constructor(json) {
|
|
6
|
+
this.x = json.x;
|
|
7
|
+
this.y = json.y;
|
|
8
|
+
this.precision = Position.DEFAULT_PRECISION;
|
|
9
|
+
}
|
|
10
|
+
setPrecision(precision = Position.DEFAULT_PRECISION) {
|
|
11
|
+
const tenPower = Math.pow(10, precision);
|
|
12
|
+
const xy = this.getXY(precision);
|
|
13
|
+
this.x = xy.x;
|
|
14
|
+
this.y = xy.y;
|
|
15
|
+
}
|
|
16
|
+
getXY(precision) {
|
|
17
|
+
if (typeof precision === 'undefined') {
|
|
18
|
+
return { x: this.x, y: this.y };
|
|
19
|
+
}
|
|
20
|
+
const tenPower = Math.pow(10, precision);
|
|
21
|
+
return {
|
|
22
|
+
x: Math.round(this.x * tenPower) / tenPower,
|
|
23
|
+
y: Math.round(this.y * tenPower) / tenPower,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
samePosition(p, precision) {
|
|
27
|
+
const xy = this.getXY(precision);
|
|
28
|
+
return xy.x === p.x && xy.y === p.y;
|
|
29
|
+
}
|
|
30
|
+
getPrecision() {
|
|
31
|
+
return this.precision;
|
|
32
|
+
}
|
|
33
|
+
getXYScaled(scale) {
|
|
34
|
+
const precision = Math.round(Math.log10(1 / scale));
|
|
35
|
+
return this.getXY(precision);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
Position.DEFAULT_PRECISION = 6;
|
|
39
|
+
Position.uniq = (a) => {
|
|
40
|
+
const set = [];
|
|
41
|
+
for (const p of a) {
|
|
42
|
+
const same = set.filter(s => s.x === p.x && s.y === p.y);
|
|
43
|
+
if (same.length <= 0) {
|
|
44
|
+
set.push(p);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return set;
|
|
48
|
+
};
|
|
49
|
+
exports.Position = Position;
|
|
50
|
+
//# sourceMappingURL=Position.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Position.js","sourceRoot":"","sources":["../../../src/quality/position/Position.ts"],"names":[],"mappings":";;;AAAA,MAAa,QAAQ;IAMjB,YAAY,IAGX;QACG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;QAChB,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;QAChB,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,iBAAiB,CAAC;IAChD,CAAC;IAaD,YAAY,CAAC,YAAoB,QAAQ,CAAC,iBAAiB;QACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACzC,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QACjC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACd,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;IAClB,CAAC;IAGD,KAAK,CAAC,SAAkB;QACpB,IAAI,OAAO,SAAS,KAAK,WAAW,EAAE;YAClC,OAAO,EAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,EAAC,CAAC;SACjC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;QACzC,OAAO;YACH,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,QAAQ,CAAC,GAAG,QAAQ;YAC3C,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,QAAQ,CAAC,GAAG,QAAQ;SAC9C,CAAC;IACN,CAAC;IAED,YAAY,CAAC,CAAW,EAAE,SAAkB;QACxC,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QACjC,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACxC,CAAC;IAED,YAAY;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,WAAW,CAAC,KAAa;QACrB,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QACpD,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IACjC,CAAC;;AAzDM,0BAAiB,GAAG,CAAC,CAAC;AActB,aAAI,GAAG,CAAC,CAAa,EAAc,EAAE;IACxC,MAAM,GAAG,GAAG,EAAE,CAAC;IACf,KAAK,MAAM,CAAC,IAAI,CAAC,EAAE;QACf,MAAM,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE;YAClB,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SACf;KACJ;IACD,OAAO,GAAG,CAAC;AACf,CAAC,CAAA;AAxBQ,4BAAQ"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PositionValue = void 0;
|
|
4
|
+
const Position_1 = require("../position/Position");
|
|
5
|
+
class PositionValue extends Position_1.Position {
|
|
6
|
+
constructor(json) {
|
|
7
|
+
super(json);
|
|
8
|
+
this.value = json.value;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.PositionValue = PositionValue;
|
|
12
|
+
//# sourceMappingURL=PositionValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PositionValue.js","sourceRoot":"","sources":["../../../src/quality/position/PositionValue.ts"],"names":[],"mappings":";;;AAAA,mDAA8C;AAG9C,MAAa,aAAc,SAAQ,mBAAQ;IAGvC,YAAY,IAIX;QACG,KAAK,CAAC,IAAI,CAAC,CAAC;QACZ,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;IAC5B,CAAC;CACJ;AAXD,sCAWC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { LatLng } from '../../cartesian/LatLng';
|
|
2
|
+
import { Position } from '../position/Position';
|
|
3
|
+
import { CartesianValue } from '../../cartesian/CartesianValue';
|
|
4
|
+
export declare class QualityTools {
|
|
5
|
+
static DEFAULT_SCALE: number;
|
|
6
|
+
static IndexOfDualArray(array: any, itemToFind: any): any;
|
|
7
|
+
static Precision(a: any): number;
|
|
8
|
+
static RoundLatLng(latOrLng: number, scale?: number, needPrecision?: boolean): number;
|
|
9
|
+
static LimitWithPrecision(latOrLng: number, precision?: number): number;
|
|
10
|
+
static IsEqualsLatLng(latOrLng1: number, latOrLng2: number, cartesianStep?: number): boolean;
|
|
11
|
+
static IsAroundLatLng(latLngCenter: LatLng, latLngAround: LatLng, stepRange: number, cartesianStep?: number): boolean;
|
|
12
|
+
static IsNotAroundLatLng(latLngCenter: LatLng, latLngAround: LatLng, stepRange: number, cartesianStep?: number): boolean;
|
|
13
|
+
static MapLatLngToPosition(latLng: LatLng, rounded?: boolean, cartesianPixelWidth?: LatLng): Position;
|
|
14
|
+
static MapPositionToLatLng(position: Position): LatLng;
|
|
15
|
+
static DegToRad(azimuthInDegrees: number): number;
|
|
16
|
+
static GetAzimuthRad(angleInDegrees: number): number;
|
|
17
|
+
static ComputeLatSteps(cartesianValues: CartesianValue[]): number[];
|
|
18
|
+
static ComputeLngSteps(cartesianValues: CartesianValue[]): number[];
|
|
19
|
+
static LogCartesianValues(cartesianValues: CartesianValue[]): void;
|
|
20
|
+
static UniqNum(a: number[]): number[];
|
|
21
|
+
static UniqStr(a: number[]): number[];
|
|
22
|
+
static CreateNDimArray(dimensions: any[], defaultValue?: any): any[];
|
|
23
|
+
protected static LabelWithSign(val: number): string;
|
|
24
|
+
}
|