Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/SINFOArtifact.java @ 9631:6ecd1a28017f
Nachtrag Pos. 20: Q theme for height chart added, calculator corrected (rows for km without any infrastructure)
author | mschaefer |
---|---|
date | Tue, 15 Oct 2019 12:26:13 +0200 |
parents | 1d4262a68f1f |
children | 870d4585cab7 |
rev | line source |
---|---|
8854 | 1 /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
2 * Software engineering by |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
3 * Björnsen Beratende Ingenieure GmbH |
8854 | 4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt |
5 * | |
6 * This file is Free Software under the GNU AGPL (>=v3) | |
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the | |
8 * documentation coming with Dive4Elements River for details. | |
9 */ | |
10 package org.dive4elements.river.artifacts.sinfo; | |
11 | |
12 import org.apache.commons.lang.StringUtils; | |
8956 | 13 import org.dive4elements.artifactdatabase.state.Facet; |
14 import org.dive4elements.artifactdatabase.state.FacetActivity; | |
15 import org.dive4elements.artifacts.Artifact; | |
8854 | 16 import org.dive4elements.river.artifacts.D4EArtifact; |
8956 | 17 import org.dive4elements.river.artifacts.sinfo.common.D50Processor; |
8980
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
18 import org.dive4elements.river.artifacts.sinfo.common.FlowDepthDevelopmentPerYearProcessor; |
8956 | 19 import org.dive4elements.river.artifacts.sinfo.common.FlowDepthDevelopmentProcessor; |
9617
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
20 import org.dive4elements.river.artifacts.sinfo.common.FlowDepthDischargeProcessor; |
8956 | 21 import org.dive4elements.river.artifacts.sinfo.common.FlowDepthProcessor; |
9617
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
22 import org.dive4elements.river.artifacts.sinfo.common.FlowDepthWaterlevelProcessor; |
8956 | 23 import org.dive4elements.river.artifacts.sinfo.common.TauProcessor; |
24 import org.dive4elements.river.artifacts.sinfo.common.VelocityProcessor; | |
9631
6ecd1a28017f
Nachtrag Pos. 20: Q theme for height chart added, calculator corrected (rows for km without any infrastructure)
mschaefer
parents:
9617
diff
changeset
|
25 import org.dive4elements.river.artifacts.sinfo.flood_duration.FloodQProcessor; |
8854 | 26 |
27 /** | |
8869 | 28 * The default SINFO artifact. |
8854 | 29 * |
30 * @author Gernot Belger | |
31 */ | |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
32 public class SINFOArtifact extends D4EArtifact { |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
33 |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
34 private static final long serialVersionUID = 1L; |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
35 |
8854 | 36 /** Error message that is thrown if no mode has been chosen. */ |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
37 private static final String ERROR_NO_CALCULATION_MODE = "error_feed_no_calculation_mode"; |
8854 | 38 |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
39 /** |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
40 * Error message that is thrown if an invalid calculation mode has been |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
41 * chosen. |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
42 */ |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
43 private static final String ERROR_INVALID_CALCULATION_MODE = "error_feed_invalid_calculation_mode"; |
8854 | 44 |
45 /** The name of the artifact. */ | |
46 private static final String ARTIFACT_NAME = "sinfo"; | |
47 | |
8869 | 48 private static final String FIELD_RIVER = "river"; |
8854 | 49 |
50 private static final String FIELD_MODE = "calculation_mode"; | |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
51 |
8956 | 52 static { |
53 // Active/deactivate facets. | |
54 // BEWARE: we can only define one activity for "sinfo", so we use the artifact as place for this | |
55 FacetActivity.Registry.getInstance().register("sinfo", new FacetActivity() { | |
56 @Override | |
57 public Boolean isInitialActive(final Artifact artifact, final Facet facet, final String output) { | |
58 | |
8980
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
59 final String name = facet.getName(); |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
60 |
8956 | 61 if ("sinfo_tkk".equals(output)) { |
62 if (FlowDepthProcessor.FACET_FLOW_DEPTH_FILTERED.equals(name)) | |
63 return Boolean.FALSE; | |
64 if (VelocityProcessor.FACET_TKH_VELOCITY_FILTERED.equals(name)) | |
65 return Boolean.FALSE; | |
66 if (TauProcessor.FACET_TKH_TAU_FILTERED.equals(name)) | |
67 return Boolean.FALSE; | |
68 if (D50Processor.FACET_TKH_D50_FILTERED.equals(name)) | |
69 return Boolean.FALSE; | |
70 } | |
71 | |
72 if ("sinfo_flow_depth_development".equals(output)) { | |
73 if (FlowDepthProcessor.FACET_FLOW_DEPTH_CURRENT_FILTERED.equals(name)) | |
74 return Boolean.FALSE; | |
75 if (FlowDepthProcessor.FACET_FLOW_DEPTH_HISTORICAL_FILTERED.equals(name)) | |
76 return Boolean.FALSE; | |
77 if (FlowDepthDevelopmentProcessor.FACET_WATERLEVEL_DIFFERENCE_FILTERED.equals(name)) | |
78 return Boolean.FALSE; | |
9617
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
79 if (FlowDepthDevelopmentProcessor.FACET_WATERLEVEL_DIFFERENCE_RAW.equals(name)) |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
80 return Boolean.FALSE; |
8956 | 81 if (FlowDepthDevelopmentProcessor.FACET_BEDHEIGHT_DIFFERENCE_FILTERED.equals(name)) |
82 return Boolean.FALSE; | |
9617
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
83 if (FlowDepthDevelopmentProcessor.FACET_BEDHEIGHT_DIFFERENCE_RAW.equals(name)) |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
84 return Boolean.FALSE; |
8956 | 85 } |
86 | |
9617
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
87 if (FlowDepthDischargeProcessor.FACET_FLOW_DEPTH_DISCHARGE.equals(name)) |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
88 return Boolean.FALSE; |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
89 if (FlowDepthWaterlevelProcessor.FACET_FLOW_DEPTH_WATER_LEVEL.equals(name)) |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
90 return Boolean.FALSE; |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
91 if (FlowDepthWaterlevelProcessor.FACET_FLOW_DEPTH_BEDHEIGHT.equals(name)) |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
92 return Boolean.FALSE; |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
93 if (FlowDepthWaterlevelProcessor.FACET_FLOW_DEPTH_BEDHEIGHT_MIN.equals(name)) |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
94 return Boolean.FALSE; |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
95 if (FlowDepthWaterlevelProcessor.FACET_FLOW_DEPTH_BEDHEIGHT_MAX.equals(name)) |
1d4262a68f1f
#12 Minuend/Subtrahend + MergeConflict #19 CollisionCalculation
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9596
diff
changeset
|
96 return Boolean.FALSE; |
8980
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
97 if (FlowDepthProcessor.FACET_FLOW_DEPTH_RAW.equals(name)) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
98 return Boolean.FALSE; |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
99 if (FlowDepthProcessor.FACET_FLOW_DEPTH_TKH_RAW.equals(name)) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
100 return Boolean.FALSE; |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
101 if (FlowDepthProcessor.FACET_FLOW_DEPTH_CURRENT_RAW.equals(name)) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
102 return Boolean.FALSE; |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
103 if (FlowDepthProcessor.FACET_FLOW_DEPTH_HISTORICAL_RAW.equals(name)) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
104 return Boolean.FALSE; |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
105 if (FlowDepthProcessor.FACET_FLOW_DEPTH_MIN_RAW.equals(name)) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
106 return Boolean.FALSE; |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
107 if (FlowDepthProcessor.FACET_FLOW_DEPTH_MAX_RAW.equals(name)) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
108 return Boolean.FALSE; |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
109 |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
110 if (FlowDepthDevelopmentProcessor.FACET_FLOW_DEPTH_DEVELOPMENT_RAW.equals(name)) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
111 return Boolean.FALSE; |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
112 if (FlowDepthDevelopmentPerYearProcessor.FACET_FLOW_DEPTH_DEVELOPMENT_PER_YEAR_RAW.equals(name)) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
113 return Boolean.FALSE; |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8956
diff
changeset
|
114 |
9596
fbfd66e8fb81
Softwaretests...20181219 6.2.2: Sinfo/Ued Haupt-/Extremwerte update for current km, W/Q of selected WSPL initially visible
mschaefer
parents:
9307
diff
changeset
|
115 // if (FloodDurationCurveProcessor.FACET_FLOOD_DURATION_MAINVALUES_W.equals(name)) |
fbfd66e8fb81
Softwaretests...20181219 6.2.2: Sinfo/Ued Haupt-/Extremwerte update for current km, W/Q of selected WSPL initially visible
mschaefer
parents:
9307
diff
changeset
|
116 // return Boolean.FALSE; |
fbfd66e8fb81
Softwaretests...20181219 6.2.2: Sinfo/Ued Haupt-/Extremwerte update for current km, W/Q of selected WSPL initially visible
mschaefer
parents:
9307
diff
changeset
|
117 // if (FloodDurationCurveProcessor.FACET_FLOOD_DURATION_MAINVALUES_Q.equals(name)) |
fbfd66e8fb81
Softwaretests...20181219 6.2.2: Sinfo/Ued Haupt-/Extremwerte update for current km, W/Q of selected WSPL initially visible
mschaefer
parents:
9307
diff
changeset
|
118 // return Boolean.FALSE; |
9631
6ecd1a28017f
Nachtrag Pos. 20: Q theme for height chart added, calculator corrected (rows for km without any infrastructure)
mschaefer
parents:
9617
diff
changeset
|
119 if (FloodQProcessor.FACET_MAIN_VALUE_Q.equals(name)) |
6ecd1a28017f
Nachtrag Pos. 20: Q theme for height chart added, calculator corrected (rows for km without any infrastructure)
mschaefer
parents:
9617
diff
changeset
|
120 return Boolean.FALSE; |
9307
45bbd2c232f8
S-Info main value themes in flood duration w/q set to initially invisible
mschaefer
parents:
8980
diff
changeset
|
121 |
8956 | 122 return null; |
123 } | |
124 }); | |
125 } | |
126 | |
8854 | 127 /** |
128 * Default constructor, because it's serializable. | |
129 */ | |
130 public SINFOArtifact() { | |
131 } | |
132 | |
133 /** | |
134 * Returns the name of the concrete artifact. | |
135 * | |
136 * @return the name of the concrete artifact. | |
137 */ | |
138 @Override | |
139 public String getName() { | |
140 return ARTIFACT_NAME; | |
141 } | |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
142 |
8854 | 143 public SinfoCalcMode getCalculationMode() { |
144 | |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
145 final String calc = getDataAsString(FIELD_MODE); |
8854 | 146 if (calc == null) { |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
147 throw new IllegalArgumentException(ERROR_NO_CALCULATION_MODE); |
8854 | 148 } |
149 | |
150 try { | |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
151 return SinfoCalcMode.valueOf(StringUtils.trimToEmpty(calc).toLowerCase()); |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
152 } |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
153 catch (final Exception e) { |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
154 throw new IllegalArgumentException(ERROR_INVALID_CALCULATION_MODE, e); |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
155 } |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
156 } |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
157 |
8854 | 158 public String getRiver() { |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
159 return getDataAsString(FIELD_RIVER); |
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8869
diff
changeset
|
160 } |
8854 | 161 } |