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
a536e1aacf0f Further work on SINFO-FlowDepth
gernotbelger
parents: 8881
diff changeset
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
a536e1aacf0f Further work on SINFO-FlowDepth
gernotbelger
parents: 8881
diff changeset
270 }

http://dive4elements.wald.intevation.org