annotate artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flood_duration/FloodDurationCalculationResult.java @ 9612:f8308db94634

#20 UI, Diagramme
author dnt_bjoernsen <d.tironi@bjoernsen.de>
date Wed, 09 Oct 2019 16:17:16 +0200
parents aa6ee96071b7
children d889ffe2fb05
rev   line source
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
1 /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
2 * Software engineering by
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
5 *
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
9 */
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.sinfo.flood_duration;
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
11
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
12 import java.io.Serializable;
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
13 import java.text.NumberFormat;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
14 import java.util.ArrayList;
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
15 import java.util.Collection;
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
16 import java.util.Collections;
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
17 import java.util.List;
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
18 import java.util.Map.Entry;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
19 import java.util.Set;
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
20
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
21 import org.apache.commons.collections.Predicate;
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
22 import org.apache.commons.lang.builder.EqualsBuilder;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
23 import org.apache.commons.lang.builder.HashCodeBuilder;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
24 import org.dive4elements.artifacts.CallContext;
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
25 import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult;
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
26 import org.dive4elements.river.artifacts.common.AbstractExportContext;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
27 import org.dive4elements.river.artifacts.common.ExportContextCSV;
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9176
diff changeset
28 import org.dive4elements.river.artifacts.common.ExportContextPDF;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
29 import org.dive4elements.river.artifacts.common.GeneralResultType;
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
30 import org.dive4elements.river.artifacts.common.IResultType;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
31 import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource;
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
32 import org.dive4elements.river.artifacts.common.ResultRow;
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
33 import org.dive4elements.river.artifacts.resources.Resources;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
34 import org.dive4elements.river.artifacts.sinfo.common.SInfoResultType;
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
35 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
36 import org.dive4elements.river.model.Attribute.AttributeKey;
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
37
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
38 import gnu.trove.TDoubleArrayList;
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
39
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
40 /**
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
41 * Contains the result of a {@link FloodDurationCalculation}.
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
42 *
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
43 * @author Gernot Belger
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
44 */
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
45 public final class FloodDurationCalculationResult extends AbstractCalculationExportableResult {
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
46
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
47 private final static class InfrastructurePredicate implements Predicate {
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
48
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
49 private final Infrastructure m_infrastructure;
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
50
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
51 public InfrastructurePredicate(final Infrastructure infrastructure) {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
52 this.m_infrastructure = infrastructure;
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
53 }
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
54
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
55 @Override
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
56 public boolean evaluate(final Object object) {
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
57 final ResultRow row = (ResultRow) object;
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
58 final Infrastructure test = new Infrastructure(row);
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
59 return this.m_infrastructure.equals(test);
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
60 }
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
61 }
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
62
9585
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
63 private final static class HasInfrastructurePredicate implements Predicate {
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
64
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
65 @Override
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
66 public boolean evaluate(final Object object) {
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
67 final ResultRow row = (ResultRow) object;
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
68
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
69 return row.getValue(SInfoResultType.riverside) != null;
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
70 }
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
71 }
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
72
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
73 public static final class Infrastructure implements Serializable {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
74
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
75 private static final long serialVersionUID = 1L;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
76
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
77 private final String m_type;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
78
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
79 private final String m_part;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
80
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
81 private final AttributeKey m_riverside;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
82
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
83 private static final String FACET_FLOOD_DURATION_DESCRIPTION = "sinfo_facet_flood_duration";
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
84
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
85 private static final String FACET_ABSOLUTE_HEIGHT = "sinfo.flood_duration.absolute.height";
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
86
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
87 public Infrastructure(final ResultRow row) {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
88 this.m_type = String.valueOf(row.getValue(SInfoResultType.infrastructuretype));
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
89 this.m_part = String.valueOf(row.getValue(SInfoResultType.infrastructurepart));
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
90 final String riversideStr = String.valueOf(row.getValue(SInfoResultType.riverside));
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
91 this.m_riverside = riversideStr.equals("null") ? AttributeKey.NONE : AttributeKey.valueOf(riversideStr);
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
92 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
93
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
94 public AttributeKey getRiverside() {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
95 return this.m_riverside;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
96 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
97
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
98 @Override
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
99 public int hashCode() {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
100 return new HashCodeBuilder() //
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
101 .append(this.m_type)//
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
102 .append(this.m_part)//
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
103 .append(this.m_riverside)//
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
104 .toHashCode();
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
105 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
106
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
107 @Override
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
108 public boolean equals(final Object obj) {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
109
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
110 if (obj == null)
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
111 return false;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
112 if (obj == this)
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
113 return true;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
114 if (obj.getClass() != getClass())
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
115 return false;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
116
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
117 final Infrastructure other = (Infrastructure) obj;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
118 return new EqualsBuilder() //
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
119 .append(this.m_type, other.m_type) //
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
120 .append(this.m_part, other.m_part) //
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
121 .append(this.m_riverside, other.m_riverside) //
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
122 .isEquals();
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
123 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
124
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
125 public String getFloodHeightLabel(final CallContext context) {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
126 return Resources.getMsg(context.getMeta(), FACET_ABSOLUTE_HEIGHT, FACET_ABSOLUTE_HEIGHT) + " " + this.m_type + " - " + this.m_part + " ("
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
127 + getLocalizedRiverside(context) + ")";
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
128 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
129
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
130 public String getFloodDurationLabel(final CallContext context) {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
131 return Resources.getMsg(context.getMeta(), FACET_FLOOD_DURATION_DESCRIPTION, FACET_FLOOD_DURATION_DESCRIPTION) + " " + this.m_type + " - "
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
132 + this.m_part + " (" + getLocalizedRiverside(context) + ")";
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
133 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
134
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
135 private String getLocalizedRiverside(final CallContext callContext) {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
136 return SInfoResultType.localizeRiverside(callContext, this.m_riverside);
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
137 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
138 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
139
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
140 private static final long serialVersionUID = 1L;
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
141
9492
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
142 private final boolean isUseWspl;
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
143
9285
9b16f58c62a7 Small cleanup/renames
mschaefer
parents: 9265
diff changeset
144 private final String[] waterlevelLabels;
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
145
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
146 private final int maxWaterlevelPdf = 3;
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
147
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
148 private final Set<Infrastructure> m_infastructures;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
149
9208
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
150 public interface ValueGetter {
9215
0fc9c82e744e work on collison, flood_duration
gernotbelger
parents: 9208
diff changeset
151 double getValue(DurationWaterlevel waterlevel);
9208
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
152 }
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
153
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
154 private enum ExportMode {
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
155 pdf, csv
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
156 }
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
157
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
158 public FloodDurationCalculationResult(final String label, final String[] mainvalueLabels, final Collection<ResultRow> rows, final boolean isUseWspl,
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
159 final Set<Infrastructure> infrastructures) {
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
160 super(label, rows);
9285
9b16f58c62a7 Small cleanup/renames
mschaefer
parents: 9265
diff changeset
161 this.waterlevelLabels = mainvalueLabels;
9492
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
162 this.isUseWspl = isUseWspl;
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
163 this.m_infastructures = infrastructures;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
164 }
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
165
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
166 public Set<Infrastructure> getInfastructureMap() {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
167 return this.m_infastructures;
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
168 }
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
169
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
170 /**
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
171 * Collection of the result rows containing only the rows describing an infrastructure
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
172 */
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
173 // FIXME: bad to override, instead make new method 'getInfrastructureRows' or similar?
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
174 @Override
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
175 public Collection<ResultRow> getRows() {
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
176
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
177 final Collection<ResultRow> rows = super.getRows();
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
178
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
179 final List<ResultRow> infrasOnlyRows = new ArrayList<>();
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
180 for (final ResultRow row : rows) {
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
181 if (row.getValue(SInfoResultType.infrastructuretype) != null && row.getValue(SInfoResultType.infrastructurepart) != null)
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
182 infrasOnlyRows.add(row);
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
183 }
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
184 return Collections.unmodifiableCollection(infrasOnlyRows);
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
185 }
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
186
9298
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
187 /**
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
188 * Collection of all result rows
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
189 */
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
190 public Collection<ResultRow> getAllRows() {
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
191
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
192 return super.getRows();
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
193 }
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
194
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
195 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9176
diff changeset
196 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) {
9294
7a8b9331a946 Moved waterlevel metadata block to global metadata, because its only written once
gernotbelger
parents: 9285
diff changeset
197 /* nothing to do, as we never have several results, everything is written into the general header */
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
198 }
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
199
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
200 @Override
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
201 protected String getJasperFile() {
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
202 if (this.getWaterlevelCount() <= 1)
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
203 return "/jasper/templates/sinfo.floodduration.jrxml";
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
204
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
205 return "/jasper/templates/sinfo.floodduration2.jrxml";
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
206 }
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
207
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
208 protected String[] formatRow(final AbstractExportContext exportContextCSV, final ResultRow row, final ExportMode mode) {
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
209
9492
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
210 final Collection<String> lines = new ArrayList<>(20);
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
211
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
212 lines.add(exportContextCSV.formatRowValue(row, GeneralResultType.station));
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
213 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.riverside));
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
214 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.floodDuration));
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
215
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
216 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.floodDischarge));
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
217
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
218 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.infrastructureHeight));
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
219 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.infrastructuretype));
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
220 lines.add(exportContextCSV.formatRowValue(row, SInfoResultType.infrastructurepart));
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
221
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
222 final List<DurationWaterlevel> waterlevelList = (List<DurationWaterlevel>) row.getValue(SInfoResultType.customMultiRowColWaterlevel);
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
223
9492
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
224 final int expectedSizetoGaugelabel = lines.size() + (waterlevelList.size() < 2 ? 4 : 12); // removing columns only works for fixed
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
225 // indices
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
226
9492
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
227 final NumberFormat wFormatter = exportContextCSV.getFlowDepthFormatter();
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
228 final NumberFormat qFormatter = exportContextCSV.getQFormatter();
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
229 final NumberFormat durFormatter = exportContextCSV.getFloodDurationFormatter();
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
230
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
231 for (int i = 0; i < waterlevelList.size(); i++) {
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
232
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
233 if (i == this.maxWaterlevelPdf && mode == ExportMode.pdf)
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
234 break;
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
235
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
236 final DurationWaterlevel item = waterlevelList.get(i);
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
237 lines.add(item.getWFormatted(wFormatter));
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
238 lines.add(item.getFloodDurDaysPerYearFormatted(durFormatter));
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
239 lines.add(item.getQFormatted(qFormatter));
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
240 lines.add(item.getBezeichnung());
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
241 }
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
242
9492
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
243 final int lineSize = lines.size();
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
244 while (mode == ExportMode.pdf && lines.size() < expectedSizetoGaugelabel)
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
245 lines.add("");
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
246
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
247 if (isUseWspl() || mode == ExportMode.pdf)
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
248 lines.add(exportContextCSV.formatRowValue(row, GeneralResultType.gaugeLabel)); // PDF: necessary, because if removed, location would not be shown!
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
249
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 9298
diff changeset
250 lines.add(exportContextCSV.formatRowValue(row, GeneralResultType.location));
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
251
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
252 return lines.toArray(new String[lines.size()]);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
253 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
254
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
255 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9176
diff changeset
256 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
257
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
258 final Collection<String> header = new ArrayList<>(20);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
259
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
260 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station));
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
261 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.riverside));
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
262 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.floodDuration));
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
263 header.add(exportContextCSV.msgUnitCSV(SInfoResultType.floodDischarge, SInfoResultType.floodDischarge.getUnit()));
9297
7100a555607c Small fixes of the S-Info flood duration outputs
mschaefer
parents: 9294
diff changeset
264 header.add(exportContextCSV.msgUnitCSV(SInfoResultType.infrastructureHeight, river.getWstUnit()));
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
265 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.infrastructuretype));
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
266 header.add(exportContextCSV.formatCsvHeader(SInfoResultType.infrastructurepart));
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
267
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
268 // add dynamic headers
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
269 final int waterlevelCount = // results.
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
270 getWaterlevelCount();
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
271 for (int i = 0; i < waterlevelCount; i++) {
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
272 final String appendIndex = "_" + Integer.toString(i + 1);
9297
7100a555607c Small fixes of the S-Info flood duration outputs
mschaefer
parents: 9294
diff changeset
273 header.add(exportContextCSV.msg(DurationWaterlevel.getHeaderWCsv(), appendIndex, river.getWstUnit()));
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
274 header.add(exportContextCSV.msg(DurationWaterlevel.getHeaderFloodDurPerYearCsv(), appendIndex));
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
275 header.add(exportContextCSV.msg(DurationWaterlevel.getHeaderQ(), appendIndex));
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
276 header.add(exportContextCSV.msg(DurationWaterlevel.getHeaderBezeichnCsv(), appendIndex));
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
277 }
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
278
9492
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
279 if (isUseWspl())
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
280 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.gaugeLabel));
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
281
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 9298
diff changeset
282 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.location));
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
283
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
284 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
285 }
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
286
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
287 public List<Double> getValidDurationChartKilometers() {
9585
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
288
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
289 // Wunsch BfG (Testung MS3): nur stationen mit infrastruktur
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
290 final Predicate filter = new HasInfrastructurePredicate();
aa6ee96071b7 Punkt 6.2.1 Sprünge auf vollen HM
gernotbelger
parents: 9492
diff changeset
291 return getValues(GeneralResultType.station, filter);
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
292 }
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
293
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
294 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9176
diff changeset
295 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final ResultRow row) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
296
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
297 return this.formatRow(exportContextCSV, row, ExportMode.csv);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
298 }
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
299
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
300 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9176
diff changeset
301 protected String[] formatPDFRow(final ExportContextPDF exportContextPDF, final ResultRow row) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
302
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
303 return this.formatRow(exportContextPDF, row, ExportMode.pdf);
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
304 }
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
305
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
306 @Override
9195
a4121ec450d6 'ca.'-issue
gernotbelger
parents: 9176
diff changeset
307 protected void addJRTableHeader(final ExportContextPDF exportContextPDF, final MetaAndTableJRDataSource source) {
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
308
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
309 /* column headings */
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
310 exportContextPDF.addJRMetadata(source, "station_header", GeneralResultType.station);
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
311 exportContextPDF.addJRMetadata(source, "riverside_header", SInfoResultType.riverside);
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
312 exportContextPDF.addJRMetadata(source, "inundationduration_header", SInfoResultType.floodDuration);
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
313 exportContextPDF.addJRMetadata(source, "inundationduration_q_header", SInfoResultType.floodDischarge);
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9195
diff changeset
314 exportContextPDF.addJRMetadata(source, "infrastructure_height_header", SInfoResultType.infrastructureHeight);
9176
1614cb14308f Work on calculations for S-Info flood duration workflow
mschaefer
parents: 9170
diff changeset
315 exportContextPDF.addJRMetadata(source, "infrastructure_type_header", SInfoResultType.infrastructuretype);
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
316 exportContextPDF.addJRMetadata(source, "infrastructure_part_header", SInfoResultType.infrastructurepart);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
317
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
318 for (int i = 1; i <= this.getWaterlevelCount(); i++) {
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
319
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
320 final String appendIndex = "_" + Integer.toString(i);
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
321 exportContextPDF.addJRMetadata(source, getPdfHeader("w", i), exportContextPDF.msg(DurationWaterlevel.getHeaderWPdf(), appendIndex));
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
322 exportContextPDF.addJRMetadata(source, getPdfHeader("duration", i),
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
323 exportContextPDF.msg(DurationWaterlevel.getHeaderFloodDurPerYearPdf(), appendIndex));
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
324 exportContextPDF.addJRMetadata(source, getPdfHeader("q", i), exportContextPDF.msg(DurationWaterlevel.getHeaderQ(), appendIndex));
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
325 exportContextPDF.addJRMetadata(source, getPdfHeader("bezeichnung", i),
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
326 exportContextPDF.msg(DurationWaterlevel.getHeaderBezeichnPdf(), appendIndex));
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
327 }
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
328
9318
7b2b086e45f0 collision pdf details, ResultType refactoring, bezugswst result
gernotbelger
parents: 9312
diff changeset
329 exportContextPDF.addJRMetadata(source, "gauge_header", GeneralResultType.gaugeLabel);
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 9298
diff changeset
330 exportContextPDF.addJRMetadata(source, "location_header", GeneralResultType.location);
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 9145
diff changeset
331 }
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
332
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
333 private final String getPdfHeader(final String rootStr, final int index) {
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
334 final String hd = "_header";
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
335 final StringBuilder builder = new StringBuilder();
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
336 return builder.append(rootStr).append("_").append(index).append(hd).toString();
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
337 }
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
338
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
339 public final int getWaterlevelCount() {
9285
9b16f58c62a7 Small cleanup/renames
mschaefer
parents: 9265
diff changeset
340 return (this.waterlevelLabels != null) ? this.waterlevelLabels.length : 0;
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
341 }
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
342
9285
9b16f58c62a7 Small cleanup/renames
mschaefer
parents: 9265
diff changeset
343 public String getWaterlevelLabel(final int j) {
9b16f58c62a7 Small cleanup/renames
mschaefer
parents: 9265
diff changeset
344 if (this.waterlevelLabels != null && j < this.waterlevelLabels.length)
9b16f58c62a7 Small cleanup/renames
mschaefer
parents: 9265
diff changeset
345 return this.waterlevelLabels[j];
9205
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
346 return "";
3dae6b78e1da inundationDuration/floodDuration multiple columns+chartLines refactoring
gernotbelger
parents: 9202
diff changeset
347 }
9208
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
348
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
349 /**
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
350 * Gets the longitudinal section of a result value type for one river side
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
351 */
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
352 public final double[][] getInfrastructurePoints(final IResultType type, final Infrastructure infrastructure) {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
353
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
354 return getPoints(GeneralResultType.station, type, new InfrastructurePredicate(infrastructure));
9229
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
355 }
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
356
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
357 /**
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
358 * Gets a longitudinal section of W, Q, or flood duration of one of the waterlevels
0dcd1cd41915 Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
mschaefer
parents: 9217
diff changeset
359 */
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
360 public final double[][] getMainValueDurationPoints(final ValueGetter valuegetter, final int dataIndex) {
9208
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
361
9298
0b1a51b0c42e Included the infrastructure-less stations in the S-Info flood duration long. sections, and the selected wspls in their w/q duration curves
mschaefer
parents: 9297
diff changeset
362 final Collection<ResultRow> rows = getAllRows();
9208
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
363
9265
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
364 final TDoubleArrayList xPoints = new TDoubleArrayList(rows.size());
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
365 final TDoubleArrayList yPoints = new TDoubleArrayList(rows.size());
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
366
e5367900dd6d Small cleanup concerning getPoints
gernotbelger
parents: 9236
diff changeset
367 for (final ResultRow row : rows) {
9208
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
368
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
369 final double station = row.getDoubleValue(GeneralResultType.station);
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
370
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
371 final List<DurationWaterlevel> waterlevels = (List<DurationWaterlevel>) row.getValue(SInfoResultType.customMultiRowColWaterlevel);
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
372 final DurationWaterlevel waterlevel = waterlevels.get(dataIndex);
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
373
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
374 final Double value = valuegetter.getValue(waterlevel);
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
375
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
376 xPoints.add(station);
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
377 yPoints.add(value);
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
378 }
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
379
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
380 return new double[][] { xPoints.toNativeArray(), yPoints.toNativeArray() };
53cc5b496692 funcion replaced by interface
gernotbelger
parents: 9205
diff changeset
381 }
9492
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
382
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
383 public boolean isUseWspl() {
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
384 return this.isUseWspl;
10530f1d7dd5 Meilenstein-2-Rücklauf Punkt 2.2.4 Angabe des Bezugspegels
gernotbelger
parents: 9357
diff changeset
385 }
9612
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
386
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
387 public Collection<Entry<String, String>> getUniqueInfrastruktureTypes() {
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
388 // TODO Auto-generated method stub
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
389 return null;
f8308db94634 #20 UI, Diagramme
dnt_bjoernsen <d.tironi@bjoernsen.de>
parents: 9585
diff changeset
390 }
9145
e6b63b2b41b9 sinfo.flood_duration pdf, csv, ui
gernotbelger
parents:
diff changeset
391 }

http://dive4elements.wald.intevation.org