annotate artifacts/src/main/java/org/dive4elements/river/artifacts/common/AbstractCalculationResult.java @ 8999:e3b3ce32c825

Work on uinfo
author gernotbelger
date Thu, 12 Apr 2018 19:15:42 +0200
parents
children 23945061daec
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 org.dive4elements.river.artifacts.common.IResultType;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
19 import gnu.trove.TDoubleArrayList;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
20
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
21 /**
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
22 * @author Gernot Belger
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
23 */
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
24 public abstract class AbstractCalculationResult implements Serializable {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
25
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
26 private static final long serialVersionUID = 1L;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
27
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
28 protected final Collection<ResultRow> rows;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
29
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
30 private final String label;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
31
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
32
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
33
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
34 public AbstractCalculationResult(final String label, final Collection<ResultRow> rows) {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
35 this.label = label;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
36 this.rows = new ArrayList<>(rows);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
37 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
38
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
39 public final String getLabel() {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
40 return this.label;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
41 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
42
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
43
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
44 public boolean isEmpty() {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
45 return this.rows.isEmpty();
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
46 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
47
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
48 public final void addRow(final ResultRow resultRow) {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
49 this.rows.add(resultRow);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
50 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
51
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
52 public final Collection<ResultRow> getRows() {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
53 return Collections.unmodifiableCollection(this.rows);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
54 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
55
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
56 public final double[][] getStationPoints(final IResultType type) { //gehört die Methode hier rein? oder in erbende Klassen?
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
57
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
58 final TDoubleArrayList xPoints = new TDoubleArrayList(this.rows.size());
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
59 final TDoubleArrayList yPoints = new TDoubleArrayList(this.rows.size());
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
60
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
61 for (final ResultRow row : this.rows) {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
62
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
63 final double station = row.getDoubleValue(GeneralResultType.station); //TODO: move "station" (and others) to common
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
64 final double value = row.getDoubleValue(type);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
65
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
66 xPoints.add(station);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
67 yPoints.add(value);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
68 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
69
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
70 return new double[][] { xPoints.toNativeArray(), yPoints.toNativeArray() };
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
71 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
72
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
73 protected final <TYPE> List<TYPE> getValues(final IResultType type) {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
74
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
75 final List<TYPE> values = new ArrayList<>();
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
76
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
77 for (final ResultRow row : this.rows) {
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
78 @SuppressWarnings("unchecked")
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
79 final TYPE value = (TYPE) row.getValue(type);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
80 values.add(value);
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
81 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
82
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
83 return values;
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
84 }
e3b3ce32c825 Work on uinfo
gernotbelger
parents:
diff changeset
85 }

http://dive4elements.wald.intevation.org