Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/bezugswst/BezugswstCalculation.java @ 9331:127638669052
bundu bezugswst result 2
author | gernotbelger |
---|---|
date | Fri, 27 Jul 2018 18:49:55 +0200 |
parents | 0a0937f33bb5 |
children | c64de8cc4e97 |
rev | line source |
---|---|
9313 | 1 /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde |
2 * Software engineering by | |
3 * Björnsen Beratende Ingenieure GmbH | |
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt | |
5 * | |
6 * This file is Free Software under the GNU AGPL (>=v3) | |
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the | |
8 * documentation coming with Dive4Elements River for details. | |
9 */ | |
10 package org.dive4elements.river.artifacts.bundu.bezugswst; | |
11 | |
12 import java.util.ArrayList; | |
13 import java.util.List; | |
14 | |
15 import org.dive4elements.artifacts.CallContext; | |
9330
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
16 import org.dive4elements.artifacts.CallMeta; |
9313 | 17 import org.dive4elements.river.artifacts.bundu.BUNDUArtifact; |
9318
7b2b086e45f0
collision pdf details, ResultType refactoring, bezugswst result
gernotbelger
parents:
9313
diff
changeset
|
18 import org.dive4elements.river.artifacts.bundu.BunduResultType; |
9313 | 19 import org.dive4elements.river.artifacts.common.GeneralResultType; |
20 import org.dive4elements.river.artifacts.common.ResultRow; | |
21 import org.dive4elements.river.artifacts.model.CalculationResult; | |
22 import org.dive4elements.river.artifacts.resources.Resources; | |
9323 | 23 import org.dive4elements.river.artifacts.sinfo.util.BedHeightInfo; |
9313 | 24 import org.dive4elements.river.artifacts.sinfo.util.CalculationUtils; |
25 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; | |
9323 | 26 import org.dive4elements.river.artifacts.sinfo.util.WstInfo; |
9313 | 27 import org.dive4elements.river.model.River; |
28 | |
29 class BezugswstCalculation { | |
30 | |
31 // private static Logger log = Logger.getLogger(FloodDurationCalculation.class); | |
32 | |
33 private final CallContext context; | |
34 | |
35 public BezugswstCalculation(final CallContext context) { | |
36 this.context = context; | |
37 } | |
38 | |
39 public CalculationResult calculate(final BUNDUArtifact bunduartifact) { | |
40 | |
41 final String user = CalculationUtils.findArtifactUser(this.context, bunduartifact); | |
9330
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
42 final CallMeta m = this.context.getMeta(); |
9313 | 43 /* access input data */ |
44 final BunduAccess access = new BunduAccess(bunduartifact); | |
45 | |
46 final River river = access.getRiver(); | |
47 final RiverInfo riverInfo = new RiverInfo(river); | |
9330
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
48 final String calcModeLabel = Resources.getMsg(m, "bundu_bezugswst"); |
9313 | 49 final BezugswstCalculationResults results = new BezugswstCalculationResults(calcModeLabel, user, riverInfo, access.getRange()); |
50 | |
9323 | 51 // TODO: get wst, sounding for river |
52 final WstInfo wstInfo = null; | |
53 final BedHeightInfo sounding = null; | |
54 // final int wspYear = waterlevel.getYear(); | |
55 // final WstInfo wstInfo = new WstInfo(wspLabel, wspYear, riverInfo.getReferenceGauge()); | |
56 final String function = access.getFunction(); | |
57 final boolean preprocessing = access.getPreprocessing();// nullpointer dürfen nicht entstehen; Fehler läge woanders | |
58 final int startYear = access.getStartYear(); | |
59 final int endYear = access.getBezugsJahr(); | |
60 final Integer ud = access.getUd(); | |
61 final double[] qs = access.getQs(); | |
62 final Double missingVolFrom = access.getMissingVolFrom(); | |
63 final Double missingVolTo = access.getMissingVolTo(); | |
9330
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
64 |
9313 | 65 final List<ResultRow> list = new ArrayList<>(); |
66 final ResultRow row = ResultRow.create(); | |
67 row.putValue(GeneralResultType.station, 666.666); | |
9318
7b2b086e45f0
collision pdf details, ResultType refactoring, bezugswst result
gernotbelger
parents:
9313
diff
changeset
|
68 row.putValue(BunduResultType.bezugswst, 22.15); |
9313 | 69 row.putValue(GeneralResultType.dischargeQwithUnit, 77.666); |
9318
7b2b086e45f0
collision pdf details, ResultType refactoring, bezugswst result
gernotbelger
parents:
9313
diff
changeset
|
70 row.putValue(GeneralResultType.waterlevelLabel, "GLQ"); |
7b2b086e45f0
collision pdf details, ResultType refactoring, bezugswst result
gernotbelger
parents:
9313
diff
changeset
|
71 row.putValue(GeneralResultType.gaugeLabel, "Bonn"); |
7b2b086e45f0
collision pdf details, ResultType refactoring, bezugswst result
gernotbelger
parents:
9313
diff
changeset
|
72 row.putValue(GeneralResultType.location, "keine Lage"); |
9313 | 73 list.add(row); |
74 | |
9330
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
75 final BezugswstMainCalculationResult result = new BezugswstMainCalculationResult("label? was fürn label?", list, sounding, wstInfo, function, |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
76 preprocessing, startYear, endYear, ud, qs, missingVolFrom, missingVolTo); |
9313 | 77 results.addResult(result, null); |
9330
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
78 |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
79 // missing volume calculation |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
80 if (access.getMissingVolFrom() != null) { |
9331 | 81 /// FIRST RESULT |
9330
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
82 final List<ResultRow> listResult1 = new ArrayList<>(); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
83 final ResultRow rowResult1 = ResultRow.create(); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
84 rowResult1.putValue(BunduResultType.bezugswst, 45.15); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
85 rowResult1.putValue(GeneralResultType.dischargeQwithUnit, 890); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
86 rowResult1.putValue(GeneralResultType.waterlevelLabel, "GLQ"); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
87 rowResult1.putValue(GeneralResultType.gaugeLabel, "Bonn"); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
88 |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
89 rowResult1.putValue(BunduResultType.sounding, "NIEDERRHEIN_QP-2002"); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
90 rowResult1.putValue(BunduResultType.channelLowerEdge, 42.65); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
91 rowResult1.putValue(BunduResultType.channelMinDepth, 2.5); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
92 rowResult1.putValue(BunduResultType.hasMissingDepth, Resources.getMsg(m, "true")); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
93 rowResult1.putValue(BunduResultType.missVolume, 2250); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
94 rowResult1.putValue(BunduResultType.missMass, 3897); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
95 rowResult1.putValue(BunduResultType.excavationVolume, 2475); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
96 rowResult1.putValue(BunduResultType.excavationCosts, 999.99); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
97 rowResult1.putValue(BunduResultType.channelWidth, 150); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
98 rowResult1.putValue(BunduResultType.density, 1732); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
99 |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
100 rowResult1.putValue(GeneralResultType.location, "Spitzenlage"); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
101 listResult1.add(rowResult1); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
102 |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
103 final BezugswstMissVolCalculationResult1 r1 = new BezugswstMissVolCalculationResult1( |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
104 Resources.getMsg(m, "bundu.export.csv.title.bezugswst.result1"), listResult1); |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
105 results.addResult(r1, null); |
9331 | 106 |
107 // SECOND RESULT | |
108 final List<ResultRow> listResult2 = new ArrayList<>(); | |
109 final ResultRow rowResult2 = ResultRow.create(); | |
110 | |
111 rowResult2.putValue(GeneralResultType.station, 890); | |
112 final List<String> fieldValues = new ArrayList<>(); | |
113 fieldValues.add("444 [m³] / 765 [t]"); | |
114 fieldValues.add("4.444 [m³] / 1.765 [t]"); | |
115 fieldValues.add("444 [m³] / 765 [t]"); | |
116 fieldValues.add(""); | |
117 fieldValues.add(""); | |
118 fieldValues.add(""); | |
119 fieldValues.add(""); | |
120 fieldValues.add(""); | |
121 fieldValues.add(""); | |
122 fieldValues.add("444 [m³] / 765 [t]"); | |
123 rowResult2.putValue(BunduResultType.fields, fieldValues); | |
124 rowResult2.putValue(BunduResultType.meanBedheight, "9.444 [m³] / 8.765 [t]"); | |
125 | |
126 listResult2.add(rowResult2); | |
127 | |
128 final BezugswstMissVolCalculationResult2 r2 = new BezugswstMissVolCalculationResult2( | |
129 Resources.getMsg(m, "bundu.export.csv.title.bezugswst.result2"), listResult2); | |
130 results.addResult(r2, null); | |
131 | |
9330
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
132 } |
0a0937f33bb5
bundu.bezugswst first result for missing volume added
gernotbelger
parents:
9323
diff
changeset
|
133 |
9313 | 134 return new CalculationResult(results, null);// problems); |
135 } | |
136 | |
137 /** | |
138 * Calculates one W-MSH differences pair. | |
139 * | |
140 * @param infoProvider | |
141 */ | |
142 | |
143 } |