Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/model/minfo/SedimentLoadDataFacet.java @ 8094:bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
author | Andre Heinecke <andre.heinecke@intevation.de> |
---|---|
date | Fri, 15 Aug 2014 18:10:16 +0200 |
parents | 01f778f84330 |
children | f01c65261963 |
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 |
8094
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
9 // TODO Aheinecke 15.8.2014 |
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
10 // This class was formerly known as SedimentLoadFacet. |
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
11 // This class could be a base for the calculated sediment loads. |
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
12 // If there is another facet for them remove this |
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
13 // class altogether. |
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
14 // |
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
15 // The new SedimentLoadFacet is a new StaticFacet which only wraps |
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
16 // static data from the database. |
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
17 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
18 package org.dive4elements.river.artifacts.model.minfo; |
5778
4a1bd43e7aa6
Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5744
diff
changeset
|
19 |
6382
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
20 import gnu.trove.TDoubleArrayList; |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
21 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
22 import org.dive4elements.artifactdatabase.state.Facet; |
5778
4a1bd43e7aa6
Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5744
diff
changeset
|
23 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
24 import org.dive4elements.artifacts.Artifact; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
25 import org.dive4elements.artifacts.CallContext; |
5778
4a1bd43e7aa6
Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5744
diff
changeset
|
26 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
27 import org.dive4elements.river.artifacts.D4EArtifact; |
5778
4a1bd43e7aa6
Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5744
diff
changeset
|
28 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
29 import org.dive4elements.river.artifacts.model.CalculationResult; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
30 import org.dive4elements.river.artifacts.model.DataFacet; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
31 import org.dive4elements.river.artifacts.model.FacetTypes; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
32 |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
33 import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
34 |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
35 import org.dive4elements.river.model.MeasurementStation; |
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5778
diff
changeset
|
36 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
37 import org.dive4elements.river.utils.RiverUtils; |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
38 |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
39 import java.util.ArrayList; |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
40 import java.util.Collections; |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
41 import java.util.List; |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
42 import java.util.Map; |
6940
274948f91dd6
issue1466: Fix, sort stations before gap detection.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6679
diff
changeset
|
43 import java.util.TreeSet; |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
44 import java.util.TreeMap; |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
45 |
5778
4a1bd43e7aa6
Removed obsolete imports.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5744
diff
changeset
|
46 import org.apache.log4j.Logger; |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
47 |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
48 |
5647
ddb2a4e982b8
Doc and cosmetics.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5645
diff
changeset
|
49 /** Facet to access various sediment loads. */ |
8094
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
50 public class SedimentLoadDataFacet |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
51 extends DataFacet |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
52 { |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
53 /** Very own logger. */ |
8094
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
54 private static Logger logger = Logger.getLogger(SedimentLoadDataFacet.class); |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
55 |
5647
ddb2a4e982b8
Doc and cosmetics.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5645
diff
changeset
|
56 /** Used as tolerance value when fetching measurement stations. */ |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
57 private static double EPSILON = 1e-5; |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
58 |
5647
ddb2a4e982b8
Doc and cosmetics.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5645
diff
changeset
|
59 |
8094
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
60 public SedimentLoadDataFacet() { |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
61 } |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
62 |
8094
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
63 public SedimentLoadDataFacet(int idx, String name, String description, |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
64 ComputeType type, String stateId, String hash) { |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
65 super(idx, name, description, type, hash, stateId); |
7894
42076d94977e
Added metadata to facets.
Raimund Renkert <rrenkert@intevation.de>
parents:
7501
diff
changeset
|
66 this.metaData.put("X", "chart.longitudinal.section.xaxis.label"); |
42076d94977e
Added metadata to facets.
Raimund Renkert <rrenkert@intevation.de>
parents:
7501
diff
changeset
|
67 this.metaData.put("Y", ""); |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
68 } |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
69 |
6679
0c593745bcd6
Added @Override annotation.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6412
diff
changeset
|
70 @Override |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
71 public Object getData(Artifact artifact, CallContext context) { |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
72 logger.debug("Get data for sediment load at index: " + index); |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
73 |
5867
59ff03ff48f1
River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5865
diff
changeset
|
74 D4EArtifact flys = (D4EArtifact) artifact; |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
75 |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
76 CalculationResult res = (CalculationResult) flys.compute(context, hash, |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
77 stateId, type, false); |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
78 |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
79 Object[] data = |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
80 (SedimentLoadResult[]) res.getData(); // TODO CAST TO SPECIFIC CLASS |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
81 |
5865
73da40528cf2
River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
82 List<MeasurementStation> allStations = RiverUtils.getRiver(flys).getMeasurementStations(); |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
83 SedimentLoadResult result = data != null && data.length > index ? (SedimentLoadResult)data[index] : null; |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
84 if (result == null) { |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
85 return null; |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
86 } |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
87 |
6382
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
88 // These complicated calculations were necessary because |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
89 // SedimentLoad/Fraction did not contain the ranges of the given |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
90 // values. Since this changed, the code is somewhat obsolete, but stable. |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
91 // For an example of easier calculation, see the "total" part below. |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
92 |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
93 List<Double> sortedStarts = new ArrayList<Double>(); |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
94 // Filter stations according to type. |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
95 List<MeasurementStation> stations = new ArrayList<MeasurementStation>(); |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
96 for (MeasurementStation station: allStations) { |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
97 if (station.getRange() == null || station.getMeasurementType() == null) { |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
98 continue; |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
99 } |
6412
c74261e05a62
issue1235: revert some changes, use correct Schwebstoff/Geschiebe-measurement-stations.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6382
diff
changeset
|
100 if (this.getName().contains("susp_sediment") |
c74261e05a62
issue1235: revert some changes, use correct Schwebstoff/Geschiebe-measurement-stations.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6382
diff
changeset
|
101 && station.getMeasurementType().equals("Schwebstoff")) { |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
102 stations.add(station); |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
103 sortedStarts.add(station.getStation()); |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
104 } |
6412
c74261e05a62
issue1235: revert some changes, use correct Schwebstoff/Geschiebe-measurement-stations.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6382
diff
changeset
|
105 else if (!this.getName().contains("susp_sediment") |
c74261e05a62
issue1235: revert some changes, use correct Schwebstoff/Geschiebe-measurement-stations.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6382
diff
changeset
|
106 && station.getMeasurementType().equals("Geschiebe")) { |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
107 stations.add(station); |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
108 sortedStarts.add(station.getStation()); |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
109 } |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
110 } |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
111 Collections.sort(sortedStarts); |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
112 |
6382
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
113 // Handle sediment load differently, as it respects already |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
114 // the ranges that were added to SedimentLoad/Fraction. |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
115 if (getName().equals(FacetTypes.SEDIMENT_LOAD_TA_TOTAL) |
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
116 ||getName().equals(FacetTypes.SEDIMENT_LOAD_M3A_TOTAL)) { |
8024
963ede7b32bb
Renamed SedimentLoad to SedimentLoadLSData to make place for SedimentLoad in backend.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
7894
diff
changeset
|
117 SedimentLoadLSData load = result.getLoad(); |
6382
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
118 TDoubleArrayList xPos = new TDoubleArrayList(); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
119 TDoubleArrayList yPos = new TDoubleArrayList(); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
120 double lastX = -1d; |
6940
274948f91dd6
issue1466: Fix, sort stations before gap detection.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6679
diff
changeset
|
121 for (double km: new TreeSet<Double>(load.getKms())) { |
6382
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
122 SedimentLoadFraction fraction = load.getFraction(km); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
123 if (fraction.getTotal() != 0) { |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
124 if (Math.abs(lastX-km) >= EPSILON) { |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
125 xPos.add(Double.NaN); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
126 yPos.add(Double.NaN); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
127 } |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
128 xPos.add(km); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
129 yPos.add(fraction.getTotal()); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
130 xPos.add(fraction.getTotalRange().getEnd()); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
131 yPos.add(fraction.getTotal()); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
132 lastX = fraction.getTotalRange().getEnd(); |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
133 } |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
134 } |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
135 return new double[][] {xPos.toNativeArray(), yPos.toNativeArray()}; |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
136 } |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
137 |
43ef4943e0c2
SedimentLoadFacet: Now that we have total load values with correct ranges in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6343
diff
changeset
|
138 // Access data according to type (except total - see above). |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
139 double[][] sd = getLoadData(result); |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
140 |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
141 // Sort by km. |
6340
fbe2d4c2b2dd
In prep for 1235: Renamed variables for improved readability.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5994
diff
changeset
|
142 TreeMap<Double, Double> sortedKmLoad = new TreeMap<Double,Double>(); |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
143 |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
144 double[] km = sd[0]; |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
145 double[] load = sd[1]; |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
146 |
6342
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
147 // Build map of km->load, but directly exclude the ones which do |
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
148 // not match against a measurements station ranges start. |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
149 for (int i = 0 ; i < km.length; i++) { |
6342
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
150 for (MeasurementStation station: stations) { |
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
151 if (Math.abs(station.getStation() - km[i]) <= EPSILON) { |
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
152 sortedKmLoad.put(km[i], load[i]); |
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
153 continue; |
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
154 } |
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
155 } |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
156 } |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
157 |
6341
3ec08ff0f497
Comment.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6340
diff
changeset
|
158 // [0] -> x, [1] -> y |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
159 double[][] values = new double[2][]; |
6342
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
160 values[0] = new double[sortedKmLoad.size()*3]; |
b8cd8e2d0c35
SedimentLoadFacet, issue1235: Ignore values not measured at measurement stations
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6341
diff
changeset
|
161 values[1] = new double[sortedKmLoad.size()*3]; |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
162 |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
163 // Find station via its station (km). |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
164 // TODO use a binarySearch instead of linear absdiff approach |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
165 int i = 0; |
6340
fbe2d4c2b2dd
In prep for 1235: Renamed variables for improved readability.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5994
diff
changeset
|
166 for (Map.Entry<Double, Double> kmLoad: sortedKmLoad.entrySet()) { |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
167 boolean matchFound = false; |
7254
fe32a7f9655e
Reduce usage of careless 'for (int i = 0; i < x.size(); i++)' pattern.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
6940
diff
changeset
|
168 for (int k = 0, S = stations.size(); k < S; k++) { |
6343
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
169 MeasurementStation station = stations.get(k); |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
170 if (Math.abs(station.getStation() - kmLoad.getKey()) < EPSILON) { |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
171 // Value has been taken at measurement station. |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
172 values[0][i*3] = station.getRange().getA().doubleValue() + EPSILON; |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
173 values[1][i*3] = kmLoad.getValue(); |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
174 double endValue = 0d; |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
175 // Valid until next measurements stations begin of range, |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
176 // or end of current range if last value. |
7254
fe32a7f9655e
Reduce usage of careless 'for (int i = 0; i < x.size(); i++)' pattern.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
6940
diff
changeset
|
177 if (k+2 <= S) { |
6343
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
178 endValue = stations.get(k+1).getRange().getA().doubleValue(); |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
179 } |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
180 else { |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
181 endValue = station.getRange().getB().doubleValue(); |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
182 } |
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
183 values[0][i*3+1] = endValue; |
6340
fbe2d4c2b2dd
In prep for 1235: Renamed variables for improved readability.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5994
diff
changeset
|
184 values[1][i*3+1] = kmLoad.getValue(); |
6343
588e99129883
issue1235: Values are valid until next measurements station range start.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6342
diff
changeset
|
185 values[0][i*3+2] = endValue; |
6340
fbe2d4c2b2dd
In prep for 1235: Renamed variables for improved readability.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5994
diff
changeset
|
186 values[1][i*3+2] = kmLoad.getValue(); |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
187 matchFound = true; |
8033
5e3f4b4fcb28
New way to loaded sediment loads from database and cache it. The data structure a way more straight forward. TODO: Implement calculation on this basis.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
8024
diff
changeset
|
188 break; |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
189 } |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
190 } |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
191 // Store points without match for later assessment. |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
192 if (!matchFound) { |
6340
fbe2d4c2b2dd
In prep for 1235: Renamed variables for improved readability.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5994
diff
changeset
|
193 logger.warn("measurement without station ("+kmLoad.getKey()+")!"); |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
194 } |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
195 i++; |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
196 } |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
197 |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
198 for (int x = 0; x < values[0].length-1; x++) { |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
199 // Introduce gaps where no data in measurement station. |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
200 if (Math.abs(values[0][x+1] - values[0][x]) > 3*EPSILON |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
201 && values[1][x+1] != values[1][x]) { |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
202 values[0][x] = Double.NaN; |
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
203 values[1][x] = Double.NaN; |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
204 } |
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
205 } |
5653
5231e6b849ce
issue1077: Handle overlapping measurement station ranges, refactored Generator,
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5648
diff
changeset
|
206 |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
207 return values; |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
208 } |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
209 |
5645
696d710470f5
flys/issue1077: Show loads as step line, therefore transform data in
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
4372
diff
changeset
|
210 |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
211 /** Get data according to type of facet. */ |
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
212 private double[][] getLoadData(SedimentLoadResult result) { |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
213 String name = getName(); |
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
214 if (FacetTypes.IS.SEDIMENT_LOAD_SAND(name)) |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
215 return result.getSandData(); |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
216 else if (FacetTypes.IS.SEDIMENT_LOAD_COARSE(name)) |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
217 return result.getCoarseData(); |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
218 else if (FacetTypes.IS.SEDIMENT_LOAD_FINEMIDDLE(name)) |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
219 return result.getFineMiddleData(); |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
220 else if (FacetTypes.IS.SEDIMENT_LOAD_SUSP_SAND(name)) |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
221 return result.getSuspSandData(); |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
222 else if (FacetTypes.IS.SEDIMENT_LOAD_SUSP_SAND_BED(name)) |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
223 return result.getSuspSandBedData(); |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
224 else if (FacetTypes.IS.SEDIMENT_LOAD_SUSP_SEDIMENT(name)) |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
225 return result.getSuspSedimentData(); |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
226 else if (FacetTypes.IS.SEDIMENT_LOAD_TOTAL_LOAD(name)) |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
227 return result.getTotalLoadData(); |
7501
aab63784a80f
issue1658: Adjust Facet to new facet-types (t/a and m^3/a).
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
7254
diff
changeset
|
228 else if (FacetTypes.IS.SEDIMENT_LOAD_TOTAL(name)) |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
229 return result.getTotalData(); |
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
230 else { |
8094
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
231 logger.error("SedimentLoadDataFacet " + name + " cannot determine data type."); |
5648
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
232 return null; |
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
233 } |
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
234 } |
4feda81c38bc
SedimentLoadFacet: Minor refactor.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
5647
diff
changeset
|
235 |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
236 /** Copy deeply. */ |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
237 @Override |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
238 public Facet deepCopy() { |
8094
bb0d35d32b01
Rename the SedimentLoadDataFacet and add deprection comment
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8090
diff
changeset
|
239 SedimentLoadDataFacet copy = new SedimentLoadDataFacet(); |
4372
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
240 copy.set(this); |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
241 copy.type = type; |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
242 copy.hash = hash; |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
243 copy.stateId = stateId; |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
244 return copy; |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
245 } |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
246 } |
19772b414d46
New facet and result set for sediment load.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
247 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 : |