annotate artifacts/src/main/java/org/dive4elements/river/exports/MiddleBedHeightExporter.java @ 7999:3bdb9f99b4a0 facet-metadata

Add river elevation model to middle bed height csv export.
author Raimund Renkert <rrenkert@intevation.de>
date Thu, 03 Jul 2014 11:31:26 +0200
parents 3c1a16755e61
children 60cd665b1bd6
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: 4929
diff changeset
9 package org.dive4elements.river.exports;
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
10
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
11 import java.io.OutputStream;
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
12 import java.text.NumberFormat;
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
13 import java.util.ArrayList;
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
14 import java.util.List;
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
15 import java.util.Collections;
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
16 import java.util.SortedMap;
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
17 import java.util.TreeMap;
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
18
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
19 import org.apache.log4j.Logger;
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
20
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
21 import au.com.bytecode.opencsv.CSVWriter;
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
22
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
23 import org.dive4elements.river.artifacts.D4EArtifact;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4929
diff changeset
24 import org.dive4elements.river.artifacts.model.CalculationResult;
7983
62befca02480 Moved MiddleBedHeight classes to minfo package. Facet now returns double[][] data.
Raimund Renkert <rrenkert@intevation.de>
parents: 7693
diff changeset
25 import org.dive4elements.river.artifacts.model.minfo.MiddleBedHeightData;
7600
410fbd6a6d01 issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7088
diff changeset
26
410fbd6a6d01 issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7088
diff changeset
27 import org.dive4elements.river.model.River;
410fbd6a6d01 issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7088
diff changeset
28
410fbd6a6d01 issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7088
diff changeset
29 import org.dive4elements.river.utils.Formatter;
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
30 import org.dive4elements.river.utils.RiverUtils;
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
31
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
32
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
33 /**
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
34 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
35 */
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
36 public class MiddleBedHeightExporter extends AbstractExporter {
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
37
3042
2ff802d66b71 trivial doc.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 2714
diff changeset
38 /** Private logger. */
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
39 private static final Logger logger =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
40 Logger.getLogger(MiddleBedHeightExporter.class);
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
41
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
42 public static final String CSV_KM =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
43 "export.bedheight_middle.csv.header.km";
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
44
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
45 public static final String CSV_SOUNDING =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
46 "export.bedheight_middle.csv.header.sounding";
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
47
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
48 public static final String CSV_HEIGHT =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
49 "export.bedheight_middle.csv.header.height";
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
50
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
51 public static final String CSV_UNCERTAINTY =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
52 "export.bedheight_middle.csv.header.uncertainty";
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
53
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
54 public static final String CSV_DATA_GAP =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
55 "export.bedheight_middle.csv.header.datagap";
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
56
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
57 public static final String CSV_SOUNDING_WIDTH =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
58 "export.bedheight_middle.csv.header.soundingwidth";
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
59
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
60 public static final String CSV_WIDTH =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
61 "export.bedheight_middle.csv.header.width";
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
62
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
63 public static final String CSV_LOCATIONS =
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
64 "export.bedheight_middle.csv.header.locations";
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
65
7994
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
66 public static final String CSV_META_YEAR =
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
67 "export.bedheight_middle.csv.header.year";
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
68
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
69 public static final String CSV_META_TYPE =
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
70 "export.bedheight_middle.csv.header.type";
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
71
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
72 public static final String CSV_META_CUR_ELEV_MODEL =
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
73 "export.bedheight_middle.csv.header.cur.elevation";
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
74
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
75 public static final String CSV_META_OLD_ELEV_MODEL =
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
76 "export.bedheight_middle.csv.header.old.elevation";
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
77
7999
3bdb9f99b4a0 Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7994
diff changeset
78 public static final String CSV_META_RIVER_ELEV_MODEL =
3bdb9f99b4a0 Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7994
diff changeset
79 "export.bedheight_middle.csv.header.river.elevation";
3bdb9f99b4a0 Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7994
diff changeset
80
7994
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
81 public static final String CSV_META_SOUNDING_WIDTH =
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
82 "export.bedheight_middle.csv.header.sounding.width";
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
83
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
84 public static final String CSV_META_RANGE =
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
85 "export.bedheight_middle.csv.header.range";
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
86
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
87 public static final String CSV_META_LOC_SYSTEM =
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
88 "export.bedheight_middle.csv.header.location.system";
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
89
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
90 public static final String CSV_META_EVAL_BY =
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
91 "export.bedheight_middle.csv.header.evalby";
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
92
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
93 protected List<MiddleBedHeightData> data;
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
94
7077
0a337f0005c2 Extended init() of OutGenerator to take name of the out to serve.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6351
diff changeset
95 public MiddleBedHeightExporter() {
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
96 data = new ArrayList<MiddleBedHeightData>();
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
97 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
98
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
99 @Override
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
100 protected void addData(Object d) {
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
101 if (d instanceof CalculationResult) {
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
102 d = ((CalculationResult) d).getData();
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
103
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
104 if (d instanceof MiddleBedHeightData[]) {
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
105 logger.debug("Add new data of type MiddleBedHeightData");
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
106 for (MiddleBedHeightData mD :(MiddleBedHeightData[]) d) {
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
107 data.add(mD);
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
108 }
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
109 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
110 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
111 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
112
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
113
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
114 @Override
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
115 protected void writeCSVData(CSVWriter writer) {
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
116 logger.info("MiddleBedHeightExporter.writeCSVData");
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
117 logger.debug("CSV gets " + data.size() + " MiddleBedHeightData objects.");
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
118
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
119
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
120 Collections.sort(data);
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
121
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
122 for (MiddleBedHeightData d: data) {
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
123 data2CSV(writer, d);
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
124 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
125 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
126
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
127
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
128 protected void writeCSVHeader(CSVWriter writer) {
7600
410fbd6a6d01 issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7088
diff changeset
129 River river = RiverUtils.getRiver((D4EArtifact) master);
410fbd6a6d01 issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7088
diff changeset
130 String riverUnit = river.getWstUnit().getName();
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
131 writer.writeNext(new String[] {
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
132 msg(CSV_KM, CSV_KM),
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
133 msg(CSV_SOUNDING, CSV_SOUNDING),
7600
410fbd6a6d01 issue1596: include river wst unit in csv header for middle bed height.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 7088
diff changeset
134 msg(CSV_HEIGHT, CSV_HEIGHT, new Object[] {riverUnit}),
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
135 msg(CSV_UNCERTAINTY, CSV_UNCERTAINTY),
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
136 msg(CSV_DATA_GAP, CSV_DATA_GAP),
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
137 msg(CSV_SOUNDING_WIDTH, CSV_SOUNDING_WIDTH),
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
138 msg(CSV_WIDTH, CSV_WIDTH),
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
139 msg(CSV_LOCATIONS, CSV_LOCATIONS)
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
140 });
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
141 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
142
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
143
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
144 protected void data2CSV(CSVWriter writer, MiddleBedHeightData data) {
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
145 logger.debug("Add next MiddleBedHeightData to CSV");
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
146
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
147 D4EArtifact flys = (D4EArtifact) master;
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
148
7994
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
149 writeMetaData(writer, data);
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
150
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
151 writeCSVHeader(writer);
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
152
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
153 NumberFormat kmF = Formatter.getMiddleBedHeightKM(context);
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
154 NumberFormat heightF = Formatter.getMiddleBedHeightHeight(context);
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
155 NumberFormat uncertF = Formatter.getMiddleBedHeightUncert(context);
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
156 NumberFormat gapF = Formatter.getMiddleBedHeightDataGap(context);
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
157 NumberFormat soundF = Formatter.getMiddleBedHeightSounding(context);
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
158 NumberFormat widthF = Formatter.getMiddleBedHeightWidth(context);
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
159
4929
1366277655b9 Bedheights: Write sounding name and set max fraction digits in calculation output.
Raimund Renkert <rrenkert@intevation.de>
parents: 3042
diff changeset
160 heightF.setMaximumFractionDigits(1);
1366277655b9 Bedheights: Write sounding name and set max fraction digits in calculation output.
Raimund Renkert <rrenkert@intevation.de>
parents: 3042
diff changeset
161 soundF.setMaximumFractionDigits(1);
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
162
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
163 SortedMap <Double, Integer> kmIndexMap = new TreeMap<Double, Integer>();
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
164
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
165 for (int i = 0, n = data.size(); i < n; i++) {
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
166 kmIndexMap.put(data.getKM(i), i);
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
167 }
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
168
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
169 for (int i: kmIndexMap.values()) {
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
170 int start = data.getStartYear();
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
171 int end = data.getEndYear();
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
172
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
173 if (start == end) {
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
174 String uncert = !Double.isNaN(data.getUncertainty(i)) ?
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
175 uncertF.format(data.getUncertainty(i)) : "";
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
176 String gap = !Double.isNaN(data.getDataGap(i)) ?
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
177 gapF.format(data.getDataGap(i)) + "%" : "";
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
178 String sound = !Double.isNaN(data.getSoundingWidth(i)) ?
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
179 soundF.format(data.getSoundingWidth(i)) : "";
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
180 writer.writeNext(new String[] {
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
181 kmF.format(data.getKM(i)),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
182 data.getDescription(),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
183 heightF.format(data.getMiddleHeight(i)),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
184 uncert,
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
185 gap,
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
186 sound,
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
187 widthF.format(data.getWidth(i)),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
188 RiverUtils.getLocationDescription(flys, data.getKM(i)),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
189 });
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
190 }
7693
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
191 else {
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
192 writer.writeNext(new String[] {
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
193 kmF.format(data.getKM(i)),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
194 data.getDescription(),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
195 heightF.format(data.getMiddleHeight(i)),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
196 "",
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
197 "",
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
198 "",
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
199 "",
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
200 RiverUtils.getLocationDescription(flys, data.getKM(i)),
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
201 });
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
202 }
c130196389df (issue1596) Sort Export of Middle bedHeight
Andre Heinecke <aheinecke@intevation.de>
parents: 7600
diff changeset
203
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
204 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
205 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
206
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
207
7994
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
208 private void writeMetaData(CSVWriter writer, MiddleBedHeightData data) {
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
209 writer.writeNext(new String[]{"#"});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
210 writer.writeNext(new String[]{"# " + msg(CSV_META_YEAR) +
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
211 ": " + data.getStartYear()});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
212 writer.writeNext(new String[]{"# " + msg(CSV_META_TYPE) +
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
213 ": " + data.getType()});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
214 writer.writeNext(new String[]{"# " + msg(CSV_META_LOC_SYSTEM) +
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
215 ": " + data.getLocationSystem()});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
216 writer.writeNext(new String[]{"# " + msg(CSV_META_CUR_ELEV_MODEL) +
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
217 ": " + data.getCurElevationModel()});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
218 writer.writeNext(new String[]{"# " + msg(CSV_META_OLD_ELEV_MODEL) +
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
219 ": " + data.getOldElevationModel()});
7999
3bdb9f99b4a0 Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7994
diff changeset
220 writer.writeNext(new String[]{"# " + msg(CSV_META_RIVER_ELEV_MODEL) +
3bdb9f99b4a0 Add river elevation model to middle bed height csv export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7994
diff changeset
221 ": " + data.getRiverElevationModel()});
7994
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
222 writer.writeNext(new String[]{"# " + msg(CSV_META_SOUNDING_WIDTH) +
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
223 ": " + data.getSoundingWidth()});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
224 writer.writeNext(new String[]{"# " + msg(CSV_META_RANGE) +
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
225 ": " + data.getStations().min() + " - " + data.getStations().max()});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
226 writer.writeNext(new String[]{"# " + msg(CSV_META_EVAL_BY) +
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
227 ": " + data.getEvaluatedBy()});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
228 writer.writeNext(new String[]{"#"});
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
229 }
3c1a16755e61 Add meta data to middle bed height CSV export.
Raimund Renkert <rrenkert@intevation.de>
parents: 7983
diff changeset
230
2714
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
231 @Override
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
232 protected void writePDF(OutputStream out) {
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
233 logger.error("TODO: Implement FlowVelocityExporter.writePDF");
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
234 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
235 }
2952f6dee5cf Added an exporter for middle bed height values.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
236 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org