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); |
|
40 if (difference > maxDifference) { |
|
41 problems.addProblem("sinfo_calc_flow_depth.warning.year_difference", label, wstYear, soundingYear); |
|
42 } |
|
43 } |
|
44 |
|
45 public static int getMaxDifferenceYears(final int year) { |
|
46 |
|
47 if (year < 1918) |
|
48 return 25; |
|
49 |
|
50 if (1918 <= year && year < 1958) |
|
51 return 12; |
|
52 |
|
53 if (1958 <= year && year < 1998) |
|
54 return 6; |
|
55 |
|
56 /* >= 1998 */ |
|
57 return 3; |
|
58 } |
|
59 } |