annotate artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/bezugswst/BezugswstMissVolCalculationResult2.java @ 9535:3fa8551c3d1b

Fixed error in bundu bzws missing volume calculation for mean bed height; added various additional output columns (field bed height, field flow depth etc.)
author mschaefer
date Fri, 12 Oct 2018 18:49:38 +0200
parents 5f81d3f7b82b
children 4deb6b24f072
rev   line source
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
2 * Software engineering by
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
5 *
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
9 */
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.bundu.bezugswst;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
11
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
12 import java.util.ArrayList;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
13 import java.util.Collection;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
14 import java.util.List;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
15
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.artifacts.bundu.BunduResultType;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
17 import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
18 import org.dive4elements.river.artifacts.common.AbstractExportContext;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
19 import org.dive4elements.river.artifacts.common.ExportContextCSV;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
20 import org.dive4elements.river.artifacts.common.ExportContextPDF;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
21 import org.dive4elements.river.artifacts.common.GeneralResultType;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
22 import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
23 import org.dive4elements.river.artifacts.common.ResultRow;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
24 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
9446
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
25 import org.dive4elements.river.model.BedHeightValueType;
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
26
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
27 /**
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
28 * Contains the results of a //TODO LINK{@link BezugswstCalculation}.
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
29 *
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
30 * @author Gernot Belger
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
31 */
9332
c64de8cc4e97 bundu.bezugswst missing volume calcResult3
gernotbelger
parents: 9331
diff changeset
32 final class BezugswstMissVolCalculationResult2 extends AbstractCalculationExportableResult implements BunduWstExporter.MissResultType {
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
33
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
34 private static final long serialVersionUID = 1L;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
35
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
36 private static final String JASPER_FILE = "/jasper/templates/bundu.bezugswst.result2.jrxml";
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
37 private static final String fieldBedheightMsgKey = "bundu.export.bezugswst.csv.meta.miss.bedheight.field";
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
38 private static final String fieldFlowdepthMsgKey = "bundu.export.bezugswst.csv.meta.miss.flowdepth.field";
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
39 private static final String fieldVolumeMsgKey = "bundu.export.bezugswst.csv.meta.miss.volume.field";
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
40 private static final String fieldMassMsgKey = "bundu.export.bezugswst.csv.meta.miss.mass.field";
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
41
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
42 public BezugswstMissVolCalculationResult2(final String label, final Collection<ResultRow> rows) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
43 super(label, rows);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
44
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
45 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
46
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
47 @Override
9455
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
48 protected boolean pdfExportEnabled() {
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
49 return false;
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
50 }
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
51
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
52 @Override
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
53 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
54 // no metadata
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
55 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
56
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
57 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
58 protected String getJasperFile() {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
59 return JASPER_FILE;
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
60 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
61
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
62 protected String[] formatRow(final AbstractExportContext exportContext, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
63
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
64 final Collection<String> lines = new ArrayList<>(44);
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
65
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
66 lines.add(exportContext.formatRowValue(row, GeneralResultType.station));
9446
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
67 @SuppressWarnings("unchecked")
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
68 final List<Double> vFields = (List<Double>) row.getValue(BunduResultType.missVolumeFields);
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
69 assert (vFields.size() == fieldSize()); // immer abgleichen mit der Calculation!
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
70 @SuppressWarnings("unchecked")
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
71 final List<Double> mFields = (List<Double>) row.getValue(BunduResultType.missMassFields);
9448
d32b11d585cd CSV-Export bundu.wst fehlvolumen
gernotbelger
parents: 9446
diff changeset
72 assert (vFields.size() == mFields.size());
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
73 @SuppressWarnings("unchecked")
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
74 final List<Double> hFields = (List<Double>) row.getValue(BunduResultType.bedHeightFields);
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
75 @SuppressWarnings("unchecked")
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
76 final List<Double> dFields = (List<Double>) row.getValue(BunduResultType.depthFields);
9448
d32b11d585cd CSV-Export bundu.wst fehlvolumen
gernotbelger
parents: 9446
diff changeset
77 for (int i = 0; i < vFields.size(); i++) {
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
78 lines.add(BunduResultType.bedHeightFields.exportValue(exportContext.getContext(), hFields.get(i)));
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
79 lines.add(BunduResultType.depthFields.exportValue(exportContext.getContext(), dFields.get(i)));
9446
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
80 lines.add(BunduResultType.missVolumeFields.exportValue(exportContext.getContext(), vFields.get(i)));
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
81 lines.add(BunduResultType.missMassFields.exportValue(exportContext.getContext(), mFields.get(i)));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
82 }
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
83 lines.add(exportContext.formatRowValue(row, BunduResultType.heightMeanBed));
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
84 lines.add(exportContext.formatRowValue(row, BunduResultType.flowdepthMeanBed));
9432
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
85 lines.add(exportContext.formatRowValue(row, BunduResultType.missVolumeMeanBed));
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
86 lines.add(exportContext.formatRowValue(row, BunduResultType.missMassMeanBed));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
87
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
88 return lines.toArray(new String[lines.size()]);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
89 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
90
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
91 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
92 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
93
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
94 final int colSize = 4 * fieldSize() + 3;
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
95 exportContextCSV.writeTitleForTabs("bundu.export.csv.title.bezugswst.result2", colSize); // Voraussetzung für Tabs ist, dass der Titel vor den Headern
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
96 final Collection<String> header = new ArrayList<>(colSize);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
97
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
98 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
99
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
100 for (int i = 1, j = 1; i <= fieldSize() * 4; i += 4, j++) {
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
101 header.add(exportContextCSV.msg(fieldBedheightMsgKey, j) + " [" + river.getWstUnit() + "]");
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
102 header.add(exportContextCSV.msg(fieldFlowdepthMsgKey, j));
9450
7e1fb8d0cb0d Bundu bzws calculation nearly completed, some corrections with csv output, started with linking the minfo density calculation
mschaefer
parents: 9448
diff changeset
103 header.add(exportContextCSV.msg(fieldVolumeMsgKey, j));
7e1fb8d0cb0d Bundu bzws calculation nearly completed, some corrections with csv output, started with linking the minfo density calculation
mschaefer
parents: 9448
diff changeset
104 header.add(exportContextCSV.msg(fieldMassMsgKey, j));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
105 }
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
106 header.add(exportContextCSV.formatCsvHeader(BunduResultType.heightMeanBed) + " [" + river.getWstUnit() + "]");
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
107 header.add(exportContextCSV.formatCsvHeader(BunduResultType.flowdepthMeanBed));
9432
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
108 header.add(exportContextCSV.formatCsvHeader(BunduResultType.missVolumeMeanBed));
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
109 header.add(exportContextCSV.formatCsvHeader(BunduResultType.missMassMeanBed));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
110
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
111 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
112
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
113 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
114
9446
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
115 /**
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
116 * Number of elements of the various field lists
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
117 */
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
118 private int fieldSize() {
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
119 return BedHeightValueType.FIELD_LAST_INDEX - BedHeightValueType.FIELD_FIRST_INDEX + 1;
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
120 }
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
121
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
122 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
123 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
124
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
125 return this.formatRow(exportContextCSV, row);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
126 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
127
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
128 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
129 protected String[] formatPDFRow(final ExportContextPDF exportContextPDF, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
130
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
131 return this.formatRow(exportContextPDF, row);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
132 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
133
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
134 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
135 protected void addJRTableHeader(final ExportContextPDF exportContextPDF, final MetaAndTableJRDataSource source) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
136 /* column headings */
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
137
9446
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
138 // TODO Auftrennung jeder Volumen+Masse-Spalte in zwei getrennte Volumen- und Masse-Spalten
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
139 exportContextPDF.addJRMetadata(source, "station_header", GeneralResultType.station);
9446
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
140 for (int i = 1; i <= fieldSize(); i++) {
9444
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
141 exportContextPDF.addJRMetadata(source, "field_header" + String.valueOf(i), exportContextPDF.msg(fieldVolumeMsgKey, i));
ecadc9ed0ba0 Added heights and depths of cross section fields in the bundu bzws calculation and longitudinal section charts
mschaefer
parents: 9432
diff changeset
142 exportContextPDF.addJRMetadata(source, "field_header" + String.valueOf(i), exportContextPDF.msg(fieldMassMsgKey, i));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
143 }
9432
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
144 exportContextPDF.addJRMetadata(source, "mean_bedheight_header", BunduResultType.missVolumeMeanBed);
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
145 exportContextPDF.addJRMetadata(source, "mean_bedheight_header", BunduResultType.missMassMeanBed);
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
146
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
147 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
148 }

http://dive4elements.wald.intevation.org