annotate artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/bezugswst/BezugswstMissVolCalculationResult2.java @ 9636:ac41551a8e4d

Bundu/Bzws: Error message for missing channel/year, Nachtrag Pos. 20: import of two levels of infrastructure types
author mschaefer
date Mon, 11 Nov 2019 16:29:36 +0100
parents 4deb6b24f072
children
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
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
36 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
37 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
38 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
39 private static final String fieldMassMsgKey = "bundu.export.bezugswst.csv.meta.miss.mass.field";
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
40
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
41 public BezugswstMissVolCalculationResult2(final String label, final Collection<ResultRow> rows) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
42 super(label, rows);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
43
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 @Override
9455
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
47 protected boolean pdfExportEnabled() {
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
48 return false;
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
49 }
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
50
5f81d3f7b82b pdf export disabled flag
gernotbelger
parents: 9450
diff changeset
51 @Override
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
52 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
53 // no metadata
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
54 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
55
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
56 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
57 protected String getJasperFile() {
9539
4deb6b24f072 PDF-Export zu 2.8 Nachtrag
gernotbelger
parents: 9535
diff changeset
58 throw new UnsupportedOperationException();
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
59 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
60
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
61 protected String[] formatRow(final AbstractExportContext exportContext, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
62
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
63 final Collection<String> lines = new ArrayList<>(44);
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
64
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
65 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
66 @SuppressWarnings("unchecked")
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
67 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
68 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
69 @SuppressWarnings("unchecked")
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
70 final List<Double> mFields = (List<Double>) row.getValue(BunduResultType.missMassFields);
9448
d32b11d585cd CSV-Export bundu.wst fehlvolumen
gernotbelger
parents: 9446
diff changeset
71 assert (vFields.size() == mFields.size());
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
72 @SuppressWarnings("unchecked")
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
73 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
74 @SuppressWarnings("unchecked")
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
75 final List<Double> dFields = (List<Double>) row.getValue(BunduResultType.depthFields);
9448
d32b11d585cd CSV-Export bundu.wst fehlvolumen
gernotbelger
parents: 9446
diff changeset
76 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
77 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
78 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
79 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
80 lines.add(BunduResultType.missMassFields.exportValue(exportContext.getContext(), mFields.get(i)));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
81 }
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
82 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
83 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
84 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
85 lines.add(exportContext.formatRowValue(row, BunduResultType.missMassMeanBed));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
86
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
87 return lines.toArray(new String[lines.size()]);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
88 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
89
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
90 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
91 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
92
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
93 final int colSize = 4 * fieldSize() + 3;
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
94 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
95 final Collection<String> header = new ArrayList<>(colSize);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
96
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
97 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
98
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
99 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
100 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
101 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
102 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
103 header.add(exportContextCSV.msg(fieldMassMsgKey, j));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
104 }
9535
3fa8551c3d1b Fixed error in bundu bzws missing volume calculation for mean bed height;
mschaefer
parents: 9455
diff changeset
105 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
106 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
107 header.add(exportContextCSV.formatCsvHeader(BunduResultType.missVolumeMeanBed));
d194c5b24bf8 Added bundu bzws w calculation and longitudinal sections of wspl and depth
mschaefer
parents: 9332
diff changeset
108 header.add(exportContextCSV.formatCsvHeader(BunduResultType.missMassMeanBed));
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
109
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
110 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
111
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
112 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
113
9446
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
114 /**
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
115 * 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
116 */
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
117 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
118 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
119 }
e60584f2a531 Added bundu bzws calculation for missing volumes (masses still not yet ready) and results1/2/3
mschaefer
parents: 9444
diff changeset
120
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
121 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
122 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final ResultRow row) {
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
123
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
124 return this.formatRow(exportContextCSV, row);
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
125 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
126
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
127 @Override
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
128 protected String[] formatPDFRow(final ExportContextPDF exportContextPDF, final ResultRow row) {
9539
4deb6b24f072 PDF-Export zu 2.8 Nachtrag
gernotbelger
parents: 9535
diff changeset
129 throw new UnsupportedOperationException();
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
130 }
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
131
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
132 @Override
9539
4deb6b24f072 PDF-Export zu 2.8 Nachtrag
gernotbelger
parents: 9535
diff changeset
133 protected void addJRTableHeader(final ExportContextPDF exportContext, final MetaAndTableJRDataSource source) {
4deb6b24f072 PDF-Export zu 2.8 Nachtrag
gernotbelger
parents: 9535
diff changeset
134 throw new UnsupportedOperationException();
4deb6b24f072 PDF-Export zu 2.8 Nachtrag
gernotbelger
parents: 9535
diff changeset
135 }
9331
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
136
127638669052 bundu bezugswst result 2
gernotbelger
parents:
diff changeset
137 }

http://dive4elements.wald.intevation.org