annotate artifacts/src/main/java/org/dive4elements/river/exports/FlowVelocityExporter.java @ 9312:740d65e4aa14

Q [m³/s] one message
author gernotbelger
date Thu, 26 Jul 2018 15:54:20 +0200
parents 5e38e2924c07
children
rev   line source
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
2 * Software engineering by Intevation GmbH
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
3 *
5994
af13ceeba52a Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5867
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
5994
af13ceeba52a Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5867
diff changeset
6 * documentation coming with Dive4Elements River for details.
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
7 */
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
8
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 2703
diff changeset
9 package org.dive4elements.river.exports;
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
10
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
11 import java.io.OutputStream;
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
12 import java.text.NumberFormat;
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
13 import java.util.ArrayList;
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
14 import java.util.List;
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
15
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
16 import org.apache.log4j.Logger;
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
17 import org.dive4elements.river.artifacts.D4EArtifact;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 2703
diff changeset
18 import org.dive4elements.river.artifacts.model.CalculationResult;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 2703
diff changeset
19 import org.dive4elements.river.artifacts.model.FlowVelocityData;
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
20 import org.dive4elements.river.utils.Formatter;
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
21 import org.dive4elements.river.utils.RiverUtils;
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
22
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
23 import au.com.bytecode.opencsv.CSVWriter;
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
24
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
25 /**
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
26 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
27 */
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
28 public class FlowVelocityExporter extends AbstractExporter {
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
29
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
30 private static final Logger log = Logger.getLogger(FlowVelocityExporter.class);
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
31
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
32 public static final String CSV_KM = "export.flow_velocity.csv.header.km";
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
33
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
34 public static final String CSV_V_TOTAL = "export.flow_velocity.csv.header.v_total";
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
35
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
36 public static final String CSV_V_MAIN = "export.flow_velocity.csv.header.v_main";
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
37
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
38 public static final String CSV_TAU_MAIN = "export.flow_velocity.csv.header.tau_main";
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
39
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
40 public static final String CSV_Q = "common.export.csv.header.q";
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
41
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
42 public static final String CSV_LOCATIONS = "export.flow_velocity.csv.header.locations";
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
43
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
44 protected List<FlowVelocityData[]> data;
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
45
7077
0a337f0005c2 Extended init() of OutGenerator to take name of the out to serve.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5994
diff changeset
46 public FlowVelocityExporter() {
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
47 this.data = new ArrayList<>();
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
48 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
49
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
50 @Override
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
51 protected void addData(Object d) {
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
52 if (d instanceof CalculationResult) {
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
53 d = ((CalculationResult) d).getData();
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
54
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
55 if (d instanceof FlowVelocityData[]) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7535
diff changeset
56 log.debug("Add new data of type FlowVelocityData");
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
57 this.data.add((FlowVelocityData[]) d);
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
58 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
59 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
60 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
61
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
62 @Override
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
63 protected void writeCSVData(final CSVWriter writer) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7535
diff changeset
64 log.info("FlowVelocityExporter.writeCSVData");
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
65 log.debug("CSV gets " + this.data.size() + " FlowVelocityData objects.");
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
66
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
67 writeCSVHeader(writer);
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
68
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
69 for (final FlowVelocityData[] d : this.data) {
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
70 data2CSV(writer, d);
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
71 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
72 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
73
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
74 protected void writeCSVHeader(final CSVWriter writer) {
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
75 writer.writeNext(new String[] { msg(CSV_KM, CSV_KM), msg(CSV_V_MAIN, CSV_V_MAIN), msg(CSV_V_TOTAL, CSV_V_TOTAL), msg(CSV_TAU_MAIN, CSV_TAU_MAIN),
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
76 msg(CSV_Q, CSV_Q), msg(CSV_LOCATIONS, CSV_LOCATIONS) });
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
77 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
78
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
79 protected void data2CSV(final CSVWriter writer, final FlowVelocityData[] fData) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7535
diff changeset
80 log.debug("Add next FlowVelocityData to CSV");
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
81
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
82 final D4EArtifact flys = (D4EArtifact) this.master;
2703
aa4391648a05 Finalized the CSV export of MINFO flow velocity calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2702
diff changeset
83
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
84 for (final FlowVelocityData data : fData) {
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
85 for (int i = 0, n = data.size(); i < n; i++) {
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
86 final NumberFormat kmF = Formatter.getFlowVelocityKM(this.context);
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
87 final NumberFormat valF = Formatter.getFlowVelocityValues(this.context);
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
88 final NumberFormat qF = Formatter.getFlowVelocityQ(this.context);
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
89
8616
594b0bbc7011 Clean up bad code from 8614:e7a2234e7c3f
Andre Heinecke <andre.heinecke@intevation.de>
parents: 8614
diff changeset
90 String vMain = "";
594b0bbc7011 Clean up bad code from 8614:e7a2234e7c3f
Andre Heinecke <andre.heinecke@intevation.de>
parents: 8614
diff changeset
91 String vTotal = "";
594b0bbc7011 Clean up bad code from 8614:e7a2234e7c3f
Andre Heinecke <andre.heinecke@intevation.de>
parents: 8614
diff changeset
92
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
93 if (data.getType().equals("main") || data.getType().equals("main_total")) {
8616
594b0bbc7011 Clean up bad code from 8614:e7a2234e7c3f
Andre Heinecke <andre.heinecke@intevation.de>
parents: 8614
diff changeset
94 vMain = valF.format(data.getVMain(i));
8614
e7a2234e7c3f (issue1608) Export appropiate data for different result types
Andre Heinecke <andre.heinecke@intevation.de>
parents: 8202
diff changeset
95 }
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
96 if (data.getType().equals("total") || data.getType().equals("main_total")) {
8616
594b0bbc7011 Clean up bad code from 8614:e7a2234e7c3f
Andre Heinecke <andre.heinecke@intevation.de>
parents: 8614
diff changeset
97 vTotal = valF.format(data.getVTotal(i));
594b0bbc7011 Clean up bad code from 8614:e7a2234e7c3f
Andre Heinecke <andre.heinecke@intevation.de>
parents: 8614
diff changeset
98 }
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
99 writer.writeNext(new String[] { kmF.format(data.getKM(i)), vMain, vTotal, valF.format(data.getTauMain(i)),
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
100 qF.format(data.getQ(i)) + "=" + data.getZone(), RiverUtils.getLocationDescription(flys, data.getKM(i)), });
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
101 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
102 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
103 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
104
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
105 @Override
9312
740d65e4aa14 Q [m³/s] one message
gernotbelger
parents: 8856
diff changeset
106 protected void writePDF(final OutputStream out) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 7535
diff changeset
107 log.error("TODO: Implement FlowVelocityExporter.writePDF");
2702
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
108 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
109 }
4c00cf83fff1 Added state, calculation and csv exporter for MINFO flow velociy calculation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
110 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org