Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/states/WaterlevelFetcher.java @ 9708:93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
author | dnt_bjoernsen <d.tironi@bjoernsen.de> |
---|---|
date | Fri, 22 Jan 2021 18:45:39 +0100 |
parents | 3f49835a00c3 |
children |
rev | line source |
---|---|
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
2 * Software engineering by |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
3 * Björnsen Beratende Ingenieure GmbH |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
5 * |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
6 * This file is Free Software under the GNU AGPL (>=v3) |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
8 * documentation coming with Dive4Elements River for details. |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
9 */ |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
10 package org.dive4elements.river.artifacts.states; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
11 |
8962
708f210ff242
Fetching year informations for waterlevels used in sinfo
gernotbelger
parents:
8947
diff
changeset
|
12 import java.util.Calendar; |
708f210ff242
Fetching year informations for waterlevels used in sinfo
gernotbelger
parents:
8947
diff
changeset
|
13 import java.util.Date; |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
14 import java.util.List; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
15 |
8964
45f1ad66560e
Code cleanup concerning calculations: improved error handling; improved interpolation; bed heights are now always used for spatial discretisation
gernotbelger
parents:
8962
diff
changeset
|
16 import org.apache.commons.lang.math.DoubleRange; |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
17 import org.apache.log4j.Logger; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
18 import org.dive4elements.artifacts.CallContext; |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
19 import org.dive4elements.river.artifacts.AbstractFixBunduArtifact; |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
20 import org.dive4elements.river.artifacts.D4EArtifact; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
21 import org.dive4elements.river.artifacts.StaticWKmsArtifact; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
22 import org.dive4elements.river.artifacts.StaticWQKmsArtifact; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
23 import org.dive4elements.river.artifacts.WINFOArtifact; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
24 import org.dive4elements.river.artifacts.access.FixRealizingAccess; |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
25 import org.dive4elements.river.artifacts.bundu.bezugswst.BezugswstCalculationResults; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
26 import org.dive4elements.river.artifacts.bundu.bezugswst.BezugswstMainCalculationResult; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
27 import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult; |
8946
5d5d482da3e9
Implementing SINFO - FlowDepthMinMax calculation
gernotbelger
parents:
8883
diff
changeset
|
28 import org.dive4elements.river.artifacts.model.Calculation; |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
29 import org.dive4elements.river.artifacts.model.CalculationResult; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
30 import org.dive4elements.river.artifacts.model.Segment; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
31 import org.dive4elements.river.artifacts.model.WKms; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
32 import org.dive4elements.river.artifacts.model.WQKms; |
8962
708f210ff242
Fetching year informations for waterlevels used in sinfo
gernotbelger
parents:
8947
diff
changeset
|
33 import org.dive4elements.river.artifacts.model.WstColumnFactory; |
8883 | 34 import org.dive4elements.river.artifacts.model.fixings.FixRealizingCalculationExtended; |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
35 import org.dive4elements.river.artifacts.model.fixings.FixRealizingResult; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
36 import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; |
8962
708f210ff242
Fetching year informations for waterlevels used in sinfo
gernotbelger
parents:
8947
diff
changeset
|
37 import org.dive4elements.river.model.TimeInterval; |
708f210ff242
Fetching year informations for waterlevels used in sinfo
gernotbelger
parents:
8947
diff
changeset
|
38 import org.dive4elements.river.model.WstColumn; |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
39 import org.dive4elements.river.utils.RiverUtils; |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
40 |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
41 /** |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
42 * Helper class that accesses existing waterlevels (in most cases) from the |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
43 * data-cage. This is mainly a refaktoring of |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
44 * org.dive4elements.river.artifacts.states.WDifferencesState.getWKms(String, |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
45 * CallContext, double, double), adding more infos to the fetched water levels. |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
46 * |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
47 * @author Gernot Belger |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
48 */ |
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
49 public class WaterlevelFetcher { |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
50 private static Logger log = Logger.getLogger(WaterlevelFetcher.class); |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
51 |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
52 /** |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
53 * @param simulationRange |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
54 * This range is used to check if the found waterlevel covers it. It |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
55 * is NOT used to reduce the fetched data, because in case of |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
56 * waterlevels we always need to full set in order to determine the |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
57 * relevant gauge. |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
58 */ |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
59 public WaterlevelData findWaterlevel(final CallContext context, final String mingle, |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
60 final DoubleRange simulationRange, final Calculation problems) { |
8881
6b93a2498e06
Slightly better abstraction for extraction waterlevels via datacage
gernotbelger
parents:
diff
changeset
|
61 |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
62 final String[] def = mingle.split(";"); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
63 final String uuid = def[0]; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
64 // final String factory = def[1]; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
65 final int idx = Integer.parseInt(def[2]); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
66 final String name = def[3]; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
67 final D4EArtifact d4eArtifact = RiverUtils.getArtifact(uuid, context); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
68 if (d4eArtifact == null) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
69 return null; |
8962
708f210ff242
Fetching year informations for waterlevels used in sinfo
gernotbelger
parents:
8947
diff
changeset
|
70 |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
71 final WaterlevelData data = fetchWaterlevelFromArtifact(context, d4eArtifact, idx, Double.NaN, Double.NaN); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
72 if (data == null) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
73 problems.addProblem("waterlevelfetcher.missing", mingle); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
74 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
75 } |
8962
708f210ff242
Fetching year informations for waterlevels used in sinfo
gernotbelger
parents:
8947
diff
changeset
|
76 |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
77 if (!data.covers(simulationRange)) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
78 problems.addProblem("waterlevelfetcher.empty", data.getName()); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
79 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
80 } |
8962
708f210ff242
Fetching year informations for waterlevels used in sinfo
gernotbelger
parents:
8947
diff
changeset
|
81 |
9708
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
82 return data.withName(name); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
83 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
84 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
85 private WaterlevelData fetchWaterlevelFromArtifact(final CallContext context, final D4EArtifact d4eArtifact, |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
86 final int idx, final double from, final double to) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
87 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
88 if (d4eArtifact instanceof StaticWKmsArtifact) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
89 return fetchStaticWKmsArtifactWaterlevel((StaticWKmsArtifact) d4eArtifact, from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
90 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
91 if (d4eArtifact instanceof StaticWQKmsArtifact) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
92 return fetchStaticWQKmsArtifactWaterlevel((StaticWQKmsArtifact) d4eArtifact, from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
93 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
94 if (d4eArtifact instanceof WINFOArtifact) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
95 return fetchWINFOArtifactWaterlevel(context, (WINFOArtifact) d4eArtifact, idx, from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
96 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
97 if (d4eArtifact instanceof AbstractFixBunduArtifact) //including BUNDUArtifact |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
98 return fetchFixationArtifactWaterlevel(context, (AbstractFixBunduArtifact) d4eArtifact, idx, from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
99 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
100 log.warn(String.format("Get Waterlevel from %s not implemented!", d4eArtifact.getClass().getSimpleName())); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
101 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
102 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
103 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
104 // REMARK: instead of several helper methods here this would be a good place for |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
105 // abstraction, in order to push |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
106 // this logic back to the corresponding artifacts. However this will most |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
107 // certainly break existing |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
108 // artifact-serialization |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
109 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
110 private WaterlevelData fetchStaticWKmsArtifactWaterlevel(final StaticWKmsArtifact staticWKms, final double from, |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
111 final double to) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
112 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
113 log.debug("WDifferencesState obtain data from StaticWKms"); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
114 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
115 final WKms wkms = staticWKms.getWKms(from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
116 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
117 if (wkms != null) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
118 final int year = fetchStaticWKmsYear(staticWKms); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
119 return new WaterlevelData(wkms, year, false, false); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
120 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
121 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
122 log.error("No WKms from Static artifact for this range."); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
123 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
124 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
125 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
126 private WaterlevelData fetchStaticWQKmsArtifactWaterlevel(final StaticWQKmsArtifact staticWKms, final double from, |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
127 final double to) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
128 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
129 log.debug("WDifferencesState obtain data from StaticWQKms"); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
130 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
131 final WQKms wkms = staticWKms.getWQKms(from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
132 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
133 if (wkms != null) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
134 final int year = fetchStaticWKmsYear(staticWKms); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
135 return new WaterlevelData(wkms, year, false, false); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
136 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
137 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
138 log.error("No WKms from Static artifact for this range."); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
139 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
140 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
141 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
142 private WaterlevelData fetchWINFOArtifactWaterlevel(final CallContext context, final WINFOArtifact flys, |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
143 final int idx, final double from, final double to) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
144 log.debug("Get WKms from WINFOArtifact"); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
145 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
146 final WKms[] wkms = (WKms[]) flys.getWaterlevelData(context).getData(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
147 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
148 if (wkms == null || wkms.length == 0) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
149 log.warn("no waterlevels in artifact"); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
150 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
151 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
152 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
153 if (wkms.length < idx + 1) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
154 log.warn("Not enough waterlevels in artifact."); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
155 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
156 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
157 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
158 // REAMRK: W_INFO results does not know any 'year' |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
159 final int year = -1; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
160 return new WaterlevelData(wkms[idx], year, false, true).filterByRange(from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
161 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
162 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
163 // private WaterlevelData fetchBUNDUArtifactWaterlevel(final CallContext |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
164 // context, final BUNDUArtifact flys, |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
165 // final int idx, final double from, final double to) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
166 // log.debug("Get WKms from BUNDUArtifact"); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
167 // |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
168 // final WKms[] wkms = (WKms[]) flys.getWaterlevelData(context).getData(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
169 // |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
170 // if (wkms == null || wkms.length == 0) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
171 // log.warn("no waterlevels in artifact"); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
172 // return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
173 // } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
174 // |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
175 // if (wkms.length < idx + 1) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
176 // log.warn("Not enough waterlevels in artifact."); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
177 // return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
178 // } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
179 // |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
180 // // REAMRK: W_INFO results does not know any 'year' |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
181 // final int year = -1; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
182 // return new WaterlevelData(wkms[idx], year, false, true).filterByRange(from, |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
183 // to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
184 // } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
185 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
186 private WaterlevelData fetchFixationArtifactWaterlevel(final CallContext context, |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
187 final AbstractFixBunduArtifact artifact, final int idx, final double from, final double to) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
188 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
189 log.debug("Get WKms from FixationArtifact or BUNDUArtifact.bezugswst"); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
190 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
191 final Object r = artifact.compute(context, ComputeType.ADVANCE, false); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
192 if (r instanceof CalculationResult) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
193 final Object frR = ((CalculationResult) r).getData(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
194 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
195 ///For BezugsWST |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
196 if (frR instanceof BezugswstCalculationResults) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
197 List<AbstractCalculationExportableResult> results = ((BezugswstCalculationResults)frR).getResults(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
198 BezugswstMainCalculationResult mainResult = this.getBezugsWstMainResultFromList(results); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
199 if (mainResult!=null) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
200 //Taken FROM BezugswstCalculation |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
201 // We have no wst year as the wst is created by a calculation; we do not need it though |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
202 final int wspYear = -1; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
203 // Remark: showAllGauges true for Fixierungsanalyse, false for WInfo, so true here as well |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
204 final boolean showAllGauges = true; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
205 return new WaterlevelData( mainResult.getWQKms() , wspYear, showAllGauges, true) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
206 .filterByRange(from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
207 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
208 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
209 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
210 else if (frR instanceof FixRealizingResult) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
211 // Get W/Q input per gauge for this case. |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
212 final FixRealizingAccess fixAccess = new FixRealizingAccess(artifact); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
213 final List<Segment> segments = fixAccess.getSegments(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
214 final boolean isFixRealize = (segments != null && !segments.isEmpty()); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
215 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
216 /* |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
217 * ugly but necessary to keep this logic at least a bit inside the FixRealizing |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
218 * stuff |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
219 */ |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
220 final FixRealizingCalculationExtended calculation = new FixRealizingCalculationExtended(fixAccess); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
221 final int year = calculation.determineMeanYear(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
222 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
223 // REMARK: same logic as in WaterlevelExporter |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
224 final boolean showAllGauges = isFixRealize; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
225 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
226 return new WaterlevelData(((FixRealizingResult) frR).getWQKms()[idx], year, showAllGauges, true) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
227 .filterByRange(from, to); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
228 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
229 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
230 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
231 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
232 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
233 private BezugswstMainCalculationResult getBezugsWstMainResultFromList(List<AbstractCalculationExportableResult> results) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
234 for ( Object result : results) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
235 if (result instanceof BezugswstMainCalculationResult) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
236 return (BezugswstMainCalculationResult) result; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
237 return null; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
238 } |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
239 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
240 /** |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
241 * Fetches the 'year' for a staticXXX-artifact. REMARK: actually this should |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
242 * happen inside the staticWKms artifact and eventually in the WKmsFactory, but |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
243 * the code there is already awful and it will also break the old |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
244 * artifact-serialization... |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
245 */ |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
246 private int fetchStaticWKmsYear(final D4EArtifact staticWKms) { |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
247 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
248 final int colPos = Integer.parseInt(staticWKms.getDataAsString("col_pos")); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
249 final int wstId = Integer.parseInt(staticWKms.getDataAsString("wst_id")); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
250 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
251 final WstColumn wstColumn = WstColumnFactory.getWstColumn(wstId, colPos); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
252 final TimeInterval timeInterval = wstColumn.getTimeInterval(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
253 if (timeInterval == null) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
254 return -1; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
255 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
256 final Date startTime = timeInterval.getStartTime(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
257 if (startTime == null) |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
258 return -1; |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
259 |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
260 // REMARK: the times are stored without timezone in the DB, so it is unclear |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
261 // what hibernate makes of it. |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
262 // We simply use the default timezone here and hope we never get problems... |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
263 // Actually we always have 12:00 as time in the db data, so a smal timeshift due |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
264 // to winter/sommertime or UTC/GMT+1 will |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
265 // no change anything regarding the year. |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
266 final Calendar cal = Calendar.getInstance(); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
267 cal.setTime(startTime); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
268 return cal.get(Calendar.YEAR); |
93389a05119e
zu Nachtrag - BezugsWST in intell. Datenkorb
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents:
9425
diff
changeset
|
269 } |
8883 | 270 } |