annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/vegetationzones/VegetationZonesCalculation.java @ 9107:41f4bc83aa7a

vegzones improved
author gernotbelger
date Tue, 29 May 2018 15:19:03 +0200
parents 611a523fc42f
children 431f1c269be5
rev   line source
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
2 * Software engineering by
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
3 * Björnsen Beratende Ingenieure GmbH
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
5 *
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
6 * This file is Free Software under the GNU AGPL (>=v3)
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
8 * documentation coming with Dive4Elements River for details.
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
9 */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
10 package org.dive4elements.river.artifacts.uinfo.vegetationzones;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
11
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
12 import java.util.ArrayList;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
13 import java.util.Collection;
9070
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
14 import java.util.List;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
15
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
16 import org.apache.commons.lang.math.DoubleRange;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
17 import org.dive4elements.artifacts.CallContext;
9107
41f4bc83aa7a vegzones improved
gernotbelger
parents: 9070
diff changeset
18 import org.dive4elements.river.artifacts.access.RangeAccess;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
19 import org.dive4elements.river.artifacts.common.ResultRow;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
20 import org.dive4elements.river.artifacts.model.Calculation;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
21 import org.dive4elements.river.artifacts.model.CalculationResult;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
22 import org.dive4elements.river.artifacts.resources.Resources;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
23 import org.dive4elements.river.artifacts.sinfo.util.CalculationUtils;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
24 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
25 import org.dive4elements.river.artifacts.uinfo.UINFOArtifact;
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
26 import org.dive4elements.river.artifacts.uinfo.commons.UInfoResultType;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
27 import org.dive4elements.river.model.River;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
28
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
29 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
30 * @author Domenico Nardi Tironi
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
31 *
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
32 */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
33 final class VegetationZonesCalculation {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
34
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
35 private final CallContext context;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
36
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
37 public VegetationZonesCalculation(final CallContext context) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
38 this.context = context;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
39 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
40
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
41 public CalculationResult calculate(final UINFOArtifact uinfo) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
42 final Calculation problems = new Calculation();
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
43
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
44 final String calcModeLabel = Resources.getMsg(this.context.getMeta(), uinfo.getCalculationMode().name());
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
45 final String user = CalculationUtils.findArtifactUser(this.context, uinfo);
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
46
9070
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
47 // FIXME: remove, check other states as well
9107
41f4bc83aa7a vegzones improved
gernotbelger
parents: 9070
diff changeset
48 final RangeAccess access = new RangeAccess(uinfo);
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
49 final River river = access.getRiver();
9107
41f4bc83aa7a vegzones improved
gernotbelger
parents: 9070
diff changeset
50 final DoubleRange calcRange = access.getRange();
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
51 final RiverInfo riverInfo = new RiverInfo(river);
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
52
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 9068
diff changeset
53 final VegetationzonesAccess vAccess = new VegetationzonesAccess(uinfo);
9070
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
54 final String zonesRaw = vAccess.getVegZones();
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
55 final List<VegetationZoneAccessHelper> helpers = VegetationZoneAccessHelper.parse(zonesRaw);
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
56 final VegetationZonesCalculationResults results = new VegetationZonesCalculationResults(calcModeLabel, user, riverInfo, calcRange);
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
57
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
58 final Collection<ResultRow> rows = new ArrayList<>();
9070
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
59 for (final VegetationZoneAccessHelper zone : helpers) {
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 9068
diff changeset
60 final ResultRow row2 = ResultRow.create().//
9070
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
61 putValue(UInfoResultType.vegname, zone.getZoneName()).//
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
62 putValue(UInfoResultType.vegdauervon, zone.getMin_day_overflow()).//
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
63 putValue(UInfoResultType.vegdauerbis, zone.getMax_day_overflow());
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 9068
diff changeset
64 rows.add(row2);
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 9068
diff changeset
65 }
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
66
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 9068
diff changeset
67 final VegetationZonesCalculationResult result = new VegetationZonesCalculationResult("Ergebnis 1", rows);
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
68
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
69 results.addResult(result, problems);
9006
7134a4c7d1b6 U-Info S-Info general work
gernotbelger
parents: 8996
diff changeset
70
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
71 return new CalculationResult(results, problems);
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
72 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
73 }

http://dive4elements.wald.intevation.org