Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/salix/SalixLineCalculationRegionalResult.java @ 9316:72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
author | mschaefer |
---|---|
date | Thu, 26 Jul 2018 17:28:32 +0200 |
parents | 9a9f076d5716 |
children | c36befc9011c |
rev | line source |
---|---|
9243 | 1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde |
2 * Software engineering by | |
3 * Björnsen Beratende Ingenieure GmbH | |
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt | |
5 * | |
6 * This file is Free Software under the GNU AGPL (>=v3) | |
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the | |
8 * documentation coming with Dive4Elements River for details. | |
9 */ | |
10 package org.dive4elements.river.artifacts.uinfo.salix; | |
11 | |
12 import java.text.NumberFormat; | |
13 import java.util.Collection; | |
14 import java.util.List; | |
15 | |
16 import org.dive4elements.river.artifacts.common.ExportContextCSV; | |
9316
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
17 import org.dive4elements.river.artifacts.common.GeneralResultType; |
9243 | 18 import org.dive4elements.river.artifacts.common.IExportContext; |
19 import org.dive4elements.river.artifacts.common.ResultRow; | |
20 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; | |
21 import org.dive4elements.river.artifacts.uinfo.commons.UInfoResultType; | |
22 | |
9316
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
23 import gnu.trove.TDoubleArrayList; |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
24 |
9243 | 25 /** |
26 * @author Domenico Nardi Tironi | |
27 */ | |
28 final class SalixLineCalculationRegionalResult extends SalixLineCalculationNoScenarioResult { | |
29 | |
30 private static final long serialVersionUID = 1L; | |
31 | |
9316
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
32 private final String[] scenarioLabels; |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
33 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
34 public SalixLineCalculationRegionalResult(final String label, final String[] scenarioLabels, final Collection<ResultRow> rows) { |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
35 super(label, rows); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
36 this.scenarioLabels = scenarioLabels; |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
37 } |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
38 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
39 public final int getScenarioCount() { |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
40 return (this.scenarioLabels != null) ? this.scenarioLabels.length : 0; |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
41 } |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
42 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
43 public String getScenarioLabel(final int i) { |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
44 if ((this.scenarioLabels != null) && (i < this.scenarioLabels.length)) |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
45 return this.scenarioLabels[i]; |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
46 else |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
47 return ""; |
9243 | 48 } |
49 | |
50 @Override | |
51 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) { | |
52 | |
53 final Collection<String> header = super.writeNoScenarioHeader(exportContextCSV); | |
54 | |
9316
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
55 for (int i = 1; i <= getScenarioCount(); i++) { |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
56 header.add(exportContextCSV.msg(SalixScenario.getScenarioValueHeader())); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
57 header.add(exportContextCSV.msg(SalixScenario.getDwsplHeader())); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
58 } |
9243 | 59 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()])); |
60 } | |
61 | |
62 @Override | |
63 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) { | |
64 writeRegionalEffectsCSVMetadata(exportContextCSV); | |
65 exportContextCSV.writeBlankLine(); | |
66 | |
67 } | |
68 | |
69 @Override | |
9316
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
70 protected String[] formatRow(final IExportContext context, final ResultRow row) { |
9243 | 71 |
72 final Collection<String> lines = super.getNoScenarioFormat(row, context); | |
73 | |
74 if (context instanceof ExportContextCSV) { // enum gespart - pdf-export hat ja nur die drei spalten | |
75 final NumberFormat formatter = ((ExportContextCSV) context).getSalixScenFormatter(); | |
76 final List<SalixScenario> scenList = (List<SalixScenario>) row.getValue(UInfoResultType.customMultiRowColSalixRegionalValue_Dwspl); | |
77 | |
78 for (final SalixScenario scenario : scenList) { | |
79 // scenario unused; index wurde ja verworfen, stattdessen 2 spalten | |
80 lines.add(scenario.getSalixValueFormatted(formatter)); | |
81 lines.add(scenario.getDwsplFormatted()); | |
82 } | |
83 } | |
84 return lines.toArray(new String[lines.size()]); | |
85 } | |
86 | |
87 private void writeRegionalEffectsCSVMetadata(final ExportContextCSV exportContextCSV) { | |
88 final String main = "uinfo.export.csv.meta.header.salix.regional"; | |
89 // "##Regional wirkende Eingriffe" | |
90 exportContextCSV.writeCSVMetaEntry(main); | |
91 writeRegionalCommonCSVMeta(exportContextCSV); | |
92 } | |
93 | |
9316
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
94 /** |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
95 * Gets a longitudinal section of W, Q, or flood duration of one of the waterlevels |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
96 */ |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
97 public final double[][] getScenarioPoints(final int dataIndex) { |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
98 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
99 final Collection<ResultRow> rows = getRows(); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
100 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
101 final TDoubleArrayList xPoints = new TDoubleArrayList(rows.size()); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
102 final TDoubleArrayList yPoints = new TDoubleArrayList(rows.size()); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
103 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
104 for (final ResultRow row : rows) { |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
105 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
106 final double station = row.getDoubleValue(GeneralResultType.station); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
107 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
108 final List<SalixScenario> scenarios = (List<SalixScenario>) row.getValue(UInfoResultType.customMultiRowColSalixRegionalValue_Dwspl); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
109 if (dataIndex <= scenarios.size() - 1) { |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
110 final double value = scenarios.get(dataIndex).getSalixValue(); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
111 xPoints.add(station); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
112 yPoints.add(value); |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
113 } |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
114 } |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
115 |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
116 return new double[][] { xPoints.toNativeArray(), yPoints.toNativeArray() }; |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
117 } |
72b3270e1568
U-Info salix line with regional and supraregional scenario calculation and chart display
mschaefer
parents:
9309
diff
changeset
|
118 |
9243 | 119 // TODO: move to SupraRegionalEffectsResult-Class; remove here |
120 // private void writeExtendedRegionalEffectsCSVMetadata(final ExportContextCSV exportContextCSV) { | |
121 // final String main = "uinfo.export.csv.meta.header.salix.regionalextended"; | |
122 // // "##Überregional wirkende Eingriffe" | |
123 // exportContextCSV.writeCSVMetaEntry(main); | |
124 // | |
125 // writeRegionalCommonCSVMeta(exportContextCSV); | |
126 // } | |
127 | |
128 // TODO: move to historical class and delete here | |
129 // private void writeHistoricalViewCSVMetadata(final ExportContextCSV exportContextCSV) { | |
130 // final String main = "uinfo.export.csv.meta.header.salix.historical"; | |
131 // // "##Historische Betrachtung" | |
132 // exportContextCSV.writeCSVMetaEntry(main); | |
133 // | |
134 // final String mainSub = "uinfo.export.csv.meta.header.salix"; | |
135 // // "# Szenariotyp: " | |
136 // exportContextCSV.writeCSVMetaEntry(mainSub + ".szenariotyp"); | |
137 // // "# Teilabschnitt: " | |
138 // exportContextCSV.writeCSVMetaEntry(mainSub + ".teilabschnitt"); | |
139 // | |
140 // // "# Art des Zeitraums: " | |
141 // exportContextCSV.writeCSVMetaEntry(main + ".zeitart"); | |
142 // // "# Historischer Zeitpunkt: " | |
143 // exportContextCSV.writeCSVMetaEntry(main + ".zeitpunkt"); | |
144 // } | |
145 } |