annotate artifacts/src/main/java/org/dive4elements/river/artifacts/common/AbstractCalculationResult.java @ 9205:3dae6b78e1da

inundationDuration/floodDuration multiple columns+chartLines refactoring
author gernotbelger
date Mon, 02 Jul 2018 19:01:09 +0200
parents 4f411c6ee3ae
children e5367900dd6d
rev   line source
8999
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
2 * Software engineering by
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
5 *
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
9 */
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.common;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
11
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
12 import java.io.Serializable;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
13 import java.util.ArrayList;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
14 import java.util.Collection;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
15 import java.util.Collections;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
16 import java.util.List;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
17
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
18 import gnu.trove.TDoubleArrayList;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
19
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
20 /**
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
21 * @author Gernot Belger
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
22 */
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
23 public abstract class AbstractCalculationResult implements Serializable {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
24
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
25 private static final long serialVersionUID = 1L;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
26
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
27 protected final Collection<ResultRow> rows;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
28
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
29 private final String label;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
30
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 8999
diff changeset
31 public AbstractCalculationResult(final String label, final Collection<ResultRow> rows) {
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 8999
diff changeset
32 this.label = label;
8999
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
33 this.rows = new ArrayList<>(rows);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
34 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
35
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
36 public final String getLabel() {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
37 return this.label;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
38 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
39
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
40 public boolean isEmpty() {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
41 return this.rows.isEmpty();
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
42 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
43
9202
b4402594213b More work on calculations and output for S-Info flood duration workflow (chart types 1 and 2)
mschaefer
parents: 9150
diff changeset
44 public Collection<ResultRow> getRows() {
8999
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
45 return Collections.unmodifiableCollection(this.rows);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
46 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
47
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 8999
diff changeset
48 public final double[][] getStationPoints(final IResultType type) { // gehört die Methode hier rein? oder in erbende Klassen?
8999
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
49
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
50 final TDoubleArrayList xPoints = new TDoubleArrayList(this.rows.size());
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
51 final TDoubleArrayList yPoints = new TDoubleArrayList(this.rows.size());
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
52
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
53 for (final ResultRow row : this.rows) {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
54
9150
23945061daec gigantic refactoring: exporter, result, results
gernotbelger
parents: 8999
diff changeset
55 final double station = row.getDoubleValue(GeneralResultType.station); // TODO: move "station" (and others) to common
8999
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
56 final double value = row.getDoubleValue(type);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
57
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
58 xPoints.add(station);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
59 yPoints.add(value);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
60 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
61
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
62 return new double[][] { xPoints.toNativeArray(), yPoints.toNativeArray() };
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
63 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
64
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
65 protected final <TYPE> List<TYPE> getValues(final IResultType type) {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
66
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
67 final List<TYPE> values = new ArrayList<>();
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
68
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
69 for (final ResultRow row : this.rows) {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
70 @SuppressWarnings("unchecked")
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
71 final TYPE value = (TYPE) row.getValue(type);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
72 values.add(value);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
73 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
74
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
75 return values;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
76 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
77 }

http://dive4elements.wald.intevation.org