Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flowdepth/FlowDepthUtils.java @ 8980:b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
Some improvements to error handling and handling of empty results.
author | gernotbelger |
---|---|
date | Thu, 05 Apr 2018 18:30:34 +0200 |
parents | 322b0e6298ea |
children | 8ae7137b67d7 |
rev | line source |
---|---|
8946 | 1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde |
2 * Software engineering by | |
3 * Björnsen Beratende Ingenieure GmbH | |
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.flowdepth; | |
11 | |
12 import org.dive4elements.river.artifacts.model.Calculation; | |
13 | |
14 /** | |
15 * @author Gernot Belger | |
16 */ | |
17 public final class FlowDepthUtils { | |
18 | |
19 private FlowDepthUtils() { | |
20 throw new UnsupportedOperationException(); | |
21 } | |
22 | |
23 /** | |
24 * Checks the year difference between waterlevels and sounding, and issues a warning if too big. | |
25 * | |
26 * Zeitraum Zeitliche Differenz [a] | |
27 * X ≥ 1998 ± 3 | |
28 * 1958 ≤ X < 1998 ± 6 | |
29 * 1918 ≤ X < 1958 ± 12 | |
30 * X < 1918 ± 25 | |
31 */ | |
8951 | 32 public static void checkYearDifference(final String label, final int wstYear, final int soundingYear, final Calculation problems) { |
8946 | 33 |
34 if (wstYear < 0) | |
35 return; | |
36 | |
37 final int maxDifference = getMaxDifferenceYears(soundingYear); | |
38 | |
39 final int difference = Math.abs(soundingYear - wstYear); | |
8980
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8951
diff
changeset
|
40 if (difference > maxDifference) |
b194fa64506a
SINFO - show results themes according to spec, either raw data or floating mean values.
gernotbelger
parents:
8951
diff
changeset
|
41 problems.addProblem("sinfo_calc_flow_depth.warning.year_difference", label, Integer.toString(wstYear), Integer.toString(soundingYear)); |
8946 | 42 } |
43 | |
44 public static int getMaxDifferenceYears(final int year) { | |
45 | |
46 if (year < 1918) | |
47 return 25; | |
48 | |
49 if (1918 <= year && year < 1958) | |
50 return 12; | |
51 | |
52 if (1958 <= year && year < 1998) | |
53 return 6; | |
54 | |
55 /* >= 1998 */ | |
56 return 3; | |
57 } | |
58 } |