annotate artifacts/src/main/java/org/dive4elements/river/artifacts/model/minfo/BedloadDiameterDataFacet.java @ 8858:a805211690f7 3.2.x

Fix license headers.
author Tom Gottfried <tom@intevation.de>
date Thu, 18 Jan 2018 20:52:41 +0100
parents 5e38e2924c07
children 0a5239a1e46e
rev   line source
8858
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
2 * Software engineering by Intevation GmbH
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
3 *
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
6 * documentation coming with Dive4Elements River for details.
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
7 */
a805211690f7 Fix license headers.
Tom Gottfried <tom@intevation.de>
parents: 8856
diff changeset
8
6260
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
9 package org.dive4elements.river.artifacts.model.minfo;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
10
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
11 import gnu.trove.TDoubleArrayList;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
12
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
13 import org.apache.log4j.Logger;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
14 import org.dive4elements.artifactdatabase.state.Facet;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
15 import org.dive4elements.artifacts.Artifact;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
16 import org.dive4elements.artifacts.CallContext;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
17 import org.dive4elements.river.artifacts.D4EArtifact;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
18 import org.dive4elements.river.artifacts.access.BedQualityAccess;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
19 import org.dive4elements.river.artifacts.model.DataFacet;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
20 import org.dive4elements.river.artifacts.states.DefaultState.ComputeType;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
21
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
22
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
23 public class BedloadDiameterDataFacet
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
24 extends DataFacet
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
25 {
8856
5e38e2924c07 Fix code style.
Tom Gottfried <tom@intevation.de>
parents: 8260
diff changeset
26 private static final Logger log = Logger.getLogger(
5e38e2924c07 Fix code style.
Tom Gottfried <tom@intevation.de>
parents: 8260
diff changeset
27 BedloadDiameterDataFacet.class);
6260
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
28
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
29 public BedloadDiameterDataFacet() {
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
30 }
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
31
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
32 public BedloadDiameterDataFacet(
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
33 int ndx,
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
34 String name,
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
35 String description,
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
36 ComputeType type,
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
37 String stateId,
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
38 String hash
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
39 ) {
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
40 super(ndx, name, description, type, hash, stateId);
7894
42076d94977e Added metadata to facets.
Raimund Renkert <rrenkert@intevation.de>
parents: 7540
diff changeset
41 this.metaData.put("X", "chart.longitudinal.section.xaxis.label");
8260
48d4921665e3 Making i18n work was just easier using less wrappers in this case (issue1631).
Tom Gottfried <tom@intevation.de>
parents: 8202
diff changeset
42 this.metaData.put("Y", "chart.bedquality.yaxis.label.diameter");
6260
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
43 }
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
44
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
45 public Object getData(Artifact artifact, CallContext context) {
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
46 D4EArtifact d4e = (D4EArtifact) artifact;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
47 BedQualityAccess access = new BedQualityAccess(d4e, context);
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
48 int ndx = getIndex() & 7;
6357
673e146e7793 Fixed bed quality data facet index to get the correct diameter.
Raimund Renkert <rrenkert@intevation.de>
parents: 6260
diff changeset
49 int diam = (getIndex() >> 4);
6260
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
50 String diameter = "";
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
51 switch (diam) {
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
52 case 1: diameter = "d10"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
53 case 2: diameter = "d16"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
54 case 3: diameter = "d20"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
55 case 4: diameter = "d25"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
56 case 5: diameter = "d30"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
57 case 6: diameter = "d40"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
58 case 7: diameter = "d50"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
59 case 8: diameter = "d60"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
60 case 9: diameter = "d70"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
61 case 10: diameter = "d75"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
62 case 11: diameter = "d80"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
63 case 12: diameter = "d84"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
64 case 13: diameter = "d90"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
65 case 14: diameter = "dmin"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
66 case 15: diameter = "dmax"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
67 case 16: diameter = "dm"; break;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
68 default: return null;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
69 }
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
70
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
71 QualityMeasurements measurements =
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
72 QualityMeasurementFactory.getBedloadMeasurements(
7261
a56fe3bc6700 Refactoring: Let RiverAccess.getRiver return an River.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 6357
diff changeset
73 access.getRiverName(),
6260
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
74 access.getFrom(),
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
75 access.getTo(),
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
76 access.getDateRanges().get(ndx).getFrom(),
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
77 access.getDateRanges().get(ndx).getTo());
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
78 TDoubleArrayList kms = new TDoubleArrayList();
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
79 TDoubleArrayList data = new TDoubleArrayList();
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
80 for (QualityMeasurement m : measurements.getMeasurements()) {
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
81 kms.add(m.getKm());
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
82 data.add(m.getDiameter(diameter)*1000);
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
83 }
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
84 BedDiameterData bdd = new BedDiameterData(diameter, kms, data);
7987
98ca61cb58fb Split bed quality facets and updated processors and state.
Raimund Renkert <rrenkert@intevation.de>
parents: 7894
diff changeset
85 return bdd.getDiameterData();
6260
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
86 }
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
87
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
88 /** Copy deeply. */
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
89 @Override
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
90 public Facet deepCopy() {
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
91 BedloadDiameterDataFacet copy = new BedloadDiameterDataFacet();
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
92 copy.set(this);
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
93 copy.type = type;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
94 copy.hash = hash;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
95 copy.stateId = stateId;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
96 return copy;
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
97 }
947434874937 New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
98 }

http://dive4elements.wald.intevation.org