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,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
|
+
}
|