Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/model/minfo/BedloadDiameterDataFacet.java @ 9726:0a5239a1e46e 3.2.x
Upgrade to Log4j 2
author | Tom Gottfried <tom@intevation.de> |
---|---|
date | Wed, 02 Mar 2022 10:26:50 +0100 |
parents | a805211690f7 |
children |
rev | line source |
---|---|
8858 | 1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde |
2 * Software engineering by Intevation GmbH | |
3 * | |
4 * This file is Free Software under the GNU AGPL (>=v3) | |
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the | |
6 * documentation coming with Dive4Elements River for details. | |
7 */ | |
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 |
9726 | 13 import org.apache.logging.log4j.Logger; |
14 import org.apache.logging.log4j.LogManager; | |
6260
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
15 import org.dive4elements.artifactdatabase.state.Facet; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
16 import org.dive4elements.artifacts.Artifact; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
17 import org.dive4elements.artifacts.CallContext; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
18 import org.dive4elements.river.artifacts.D4EArtifact; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
19 import org.dive4elements.river.artifacts.access.BedQualityAccess; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
20 import org.dive4elements.river.artifacts.model.DataFacet; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
21 import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; |
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 |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
24 public class BedloadDiameterDataFacet |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
25 extends DataFacet |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
26 { |
9726 | 27 private static final Logger log = LogManager.getLogger( |
8856 | 28 BedloadDiameterDataFacet.class); |
6260
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
29 |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
30 public BedloadDiameterDataFacet() { |
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 |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
33 public BedloadDiameterDataFacet( |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
34 int ndx, |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
35 String name, |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
36 String description, |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
37 ComputeType type, |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
38 String stateId, |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
39 String hash |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
40 ) { |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
41 super(ndx, name, description, type, hash, stateId); |
7894
42076d94977e
Added metadata to facets.
Raimund Renkert <rrenkert@intevation.de>
parents:
7540
diff
changeset
|
42 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
|
43 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
|
44 } |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
45 |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
46 public Object getData(Artifact artifact, CallContext context) { |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
47 D4EArtifact d4e = (D4EArtifact) artifact; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
48 BedQualityAccess access = new BedQualityAccess(d4e, context); |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
49 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
|
50 int diam = (getIndex() >> 4); |
6260
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
51 String diameter = ""; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
52 switch (diam) { |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
53 case 1: diameter = "d10"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
54 case 2: diameter = "d16"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
55 case 3: diameter = "d20"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
56 case 4: diameter = "d25"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
57 case 5: diameter = "d30"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
58 case 6: diameter = "d40"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
59 case 7: diameter = "d50"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
60 case 8: diameter = "d60"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
61 case 9: diameter = "d70"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
62 case 10: diameter = "d75"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
63 case 11: diameter = "d80"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
64 case 12: diameter = "d84"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
65 case 13: diameter = "d90"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
66 case 14: diameter = "dmin"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
67 case 15: diameter = "dmax"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
68 case 16: diameter = "dm"; break; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
69 default: return null; |
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 |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
72 QualityMeasurements measurements = |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
73 QualityMeasurementFactory.getBedloadMeasurements( |
7261
a56fe3bc6700
Refactoring: Let RiverAccess.getRiver return an River.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents:
6357
diff
changeset
|
74 access.getRiverName(), |
6260
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
75 access.getFrom(), |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
76 access.getTo(), |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
77 access.getDateRanges().get(ndx).getFrom(), |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
78 access.getDateRanges().get(ndx).getTo()); |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
79 TDoubleArrayList kms = new TDoubleArrayList(); |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
80 TDoubleArrayList data = new TDoubleArrayList(); |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
81 for (QualityMeasurement m : measurements.getMeasurements()) { |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
82 kms.add(m.getKm()); |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
83 data.add(m.getDiameter(diameter)*1000); |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
84 } |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
85 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
|
86 return bdd.getDiameterData(); |
6260
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 |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
89 /** Copy deeply. */ |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
90 @Override |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
91 public Facet deepCopy() { |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
92 BedloadDiameterDataFacet copy = new BedloadDiameterDataFacet(); |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
93 copy.set(this); |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
94 copy.type = type; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
95 copy.hash = hash; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
96 copy.stateId = stateId; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
97 return copy; |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
98 } |
947434874937
New facet for bedload diameter measurements.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff
changeset
|
99 } |