annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flood_duration/FloodDurationCurveFacet.java @ 9631:6ecd1a28017f

Nachtrag Pos. 20: Q theme for height chart added, calculator corrected (rows for km without any infrastructure)
author mschaefer
date Tue, 15 Oct 2019 12:26:13 +0200
parents 669ab639c56b
children
rev   line source
9269
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9268
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9268
diff changeset
2 * Software engineering by
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9268
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9268
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
9252
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
5 *
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
9 */
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
10
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
11 package org.dive4elements.river.artifacts.sinfo.flood_duration;
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
12
9548
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
13 import java.util.ArrayList;
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
14 import java.util.List;
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
15
9252
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
16 import org.apache.log4j.Logger;
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
17 import org.dive4elements.artifactdatabase.state.DefaultFacet;
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
18 import org.dive4elements.artifactdatabase.state.Facet;
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
19 import org.dive4elements.artifacts.Artifact;
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
20 import org.dive4elements.artifacts.CallContext;
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
21 import org.dive4elements.river.artifacts.D4EArtifact;
9548
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
22 import org.dive4elements.river.artifacts.model.DurationCurveFacet;
9266
465347d12990 Station specific calculation of flood duration curve and infrastructure annotations
mschaefer
parents: 9265
diff changeset
23 import org.dive4elements.river.artifacts.sinfo.SINFOArtifact;
9268
ae9dee74e43e Fixed: current station of duration chart was not changed
gernotbelger
parents: 9266
diff changeset
24 import org.dive4elements.river.exports.fixings.FixChartGenerator;
9252
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
25
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
26 /**
9269
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9268
diff changeset
27 * Data of a flood duration curve.
9252
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
28 */
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
29 public class FloodDurationCurveFacet extends DefaultFacet {
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
30
9268
ae9dee74e43e Fixed: current station of duration chart was not changed
gernotbelger
parents: 9266
diff changeset
31 private static final long serialVersionUID = 1L;
ae9dee74e43e Fixed: current station of duration chart was not changed
gernotbelger
parents: 9266
diff changeset
32
9252
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
33 private static Logger log = Logger.getLogger(FloodDurationCurveFacet.class);
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
34
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
35 public FloodDurationCurveFacet() {
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
36 }
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
37
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
38 public FloodDurationCurveFacet(final String name, final String description) {
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
39 super(0, name, description);
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
40 }
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
41
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
42 /**
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
43 * Expose state computation from SINFOArtifact.
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
44 */
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
45 @Override
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
46 public Object getData(final Artifact artifact, final CallContext context) {
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
47
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
48 log.debug("Get data for flood duration curve data");
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
49
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
50 final D4EArtifact flys = (D4EArtifact) artifact;
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
51
9268
ae9dee74e43e Fixed: current station of duration chart was not changed
gernotbelger
parents: 9266
diff changeset
52 final double currentKm = FixChartGenerator.getCurrentKm(context);
ae9dee74e43e Fixed: current station of duration chart was not changed
gernotbelger
parents: 9266
diff changeset
53 return new FloodDurationCalculation(context).calcStationCurve(currentKm, (SINFOArtifact) flys);
9252
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
54 }
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
55
9548
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
56 @Override
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
57 public List getStaticDataProviderKeys(final Artifact art) {
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
58 final List<String> list = new ArrayList<>();
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
59 list.add(DurationCurveFacet.BB_DURATIONCURVE);
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
60 return list;
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
61 }
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
62
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
63 /**
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
64 * Can provide whatever getData returns and additionally the location.
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
65 *
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
66 * @param key
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
67 * will respond on BB_DURATIONCURVE +KM
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
68 * @param param
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
69 * ignored
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
70 * @param context
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
71 * ignored
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
72 * @return whatever getData delivers or location.
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
73 */
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
74 @Override
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
75 public Object provideBlackboardData(final Artifact artifact, final Object key, final Object param, final CallContext context) {
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
76 if (key.equals(DurationCurveFacet.BB_DURATIONCURVE))
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
77 return getData(artifact, context);
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
78
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
79 return null;
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
80 }
9252
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
81
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
82 /** Create a deep copy. */
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
83 @Override
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
84 public Facet deepCopy() {
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
85 final FloodDurationCurveFacet copy = new FloodDurationCurveFacet();
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
86 copy.set(this);
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
87 return copy;
c2a0028bfa9f Work on S-Info flood duration curve chart
mschaefer
parents:
diff changeset
88 }
9548
669ab639c56b Implemented datacage for sinfo - ueberflutungsdauern
gernotbelger
parents: 9269
diff changeset
89 }

http://dive4elements.wald.intevation.org