annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flood_duration/FloodDurationMainValuesQFacet.java @ 9620:26e113e8224f

Nachtrag Pos. 20: flood duration calculation for multiple infrastructure groups/types, local class FloodDurationCalculationResult.Infrastructure renamed and extracted into own class
author mschaefer
date Thu, 10 Oct 2019 17:11:54 +0200
parents f8308db94634
children
rev   line source
9269
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9259
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: 9259
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: 9259
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: 9259
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
5 *
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
9 */
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
10
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
11 package org.dive4elements.river.artifacts.sinfo.flood_duration;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
12
9269
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9259
diff changeset
13 import java.util.List;
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9259
diff changeset
14
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
15 import org.apache.log4j.Logger;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
16 import org.dive4elements.artifactdatabase.state.DefaultFacet;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
17 import org.dive4elements.artifacts.Artifact;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
18 import org.dive4elements.artifacts.CallContext;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
19 import org.dive4elements.river.artifacts.D4EArtifact;
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
20 import org.dive4elements.river.artifacts.model.Calculation;
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
21 import org.dive4elements.river.artifacts.model.CalculationResult;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
22 import org.dive4elements.river.artifacts.states.DefaultState.ComputeType;
9269
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9259
diff changeset
23 import org.dive4elements.river.exports.fixings.FixChartGenerator;
9259
66b003701546 Added infrastructure height and Q annotation to S-Info flood duration curve chart
mschaefer
parents: 9257
diff changeset
24 import org.dive4elements.river.jfree.RiverAnnotation;
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
25 import org.dive4elements.river.jfree.StickyAxisAnnotation;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
26
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
27 /**
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
28 * Facet to show Main Q Values.
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
29 */
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
30 public class FloodDurationMainValuesQFacet extends DefaultFacet {
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
31
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
32 private static final long serialVersionUID = 1L;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
33
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
34 /** Own log. */
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
35 private static Logger log = Logger.getLogger(FloodDurationMainValuesQFacet.class);
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
36
9620
26e113e8224f Nachtrag Pos. 20: flood duration calculation for multiple infrastructure groups/types,
mschaefer
parents: 9612
diff changeset
37 private final FloodDurationInfrastructureChoice m_infrastructure;
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
38
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
39 /** Trivial Constructor. */
9620
26e113e8224f Nachtrag Pos. 20: flood duration calculation for multiple infrastructure groups/types,
mschaefer
parents: 9612
diff changeset
40 public FloodDurationMainValuesQFacet(final String name, final String description, final int facetIndex,
26e113e8224f Nachtrag Pos. 20: flood duration calculation for multiple infrastructure groups/types,
mschaefer
parents: 9612
diff changeset
41 final FloodDurationInfrastructureChoice infrastructure) {
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
42 this.description = description;
9259
66b003701546 Added infrastructure height and Q annotation to S-Info flood duration curve chart
mschaefer
parents: 9257
diff changeset
43 this.name = name;
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
44 this.index = facetIndex;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
45 this.m_infrastructure = infrastructure;
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
46 }
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
47
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
48 /**
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
49 * Returns the data this facet requires.
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
50 */
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
51 @Override
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
52 public Object getData(final Artifact artifact, final CallContext context) {
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
53
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
54 log.debug("Get data for flood duration main value Q data");
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
55
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
56 final D4EArtifact flys = (D4EArtifact) artifact;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
57
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
58 final CalculationResult res = (CalculationResult) flys.compute(context, ComputeType.ADVANCE, false);
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
59
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
60 final FloodDurationCalculationResults data = (FloodDurationCalculationResults) res.getData();
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
61
9269
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9259
diff changeset
62 final double currentKm = FixChartGenerator.getCurrentKm(context);
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9259
diff changeset
63
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
64 final FloodDurationCalculationResult result = data.getResults().get(0);
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
65
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
66 final Calculation problems = new Calculation();
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
67
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
68 final FacetCalculator calculator = new FacetCalculator(context);
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
69 final List<StickyAxisAnnotation> annotations = calculator.calcMainValueQAnnotations(problems, currentKm, result);
9269
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9259
diff changeset
70
83ebeb620b5a Station specific main value annotations in S-Info flood duration curve, corrected infrastructure flood duration calculation
mschaefer
parents: 9259
diff changeset
71 return new RiverAnnotation(this.description, annotations);
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
72 }
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
73
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
74 /**
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
75 * Create a deep copy of this Facet.
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
76 *
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
77 * @return a deep copy.
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
78 */
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
79 @Override
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
80 public FloodDurationMainValuesQFacet deepCopy() {
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
81 final FloodDurationMainValuesQFacet copy = new FloodDurationMainValuesQFacet(this.name, this.description, this.index, this.m_infrastructure);
9257
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
82 copy.set(this);
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
83 return copy;
ef7b65576d4b Added W and Q main values to S-Info flood duration curve chart
mschaefer
parents:
diff changeset
84 }
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9269
diff changeset
85 }

http://dive4elements.wald.intevation.org