annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/inundationduration/InundationDurationCalculation.java @ 9537:bf6b63208f34

Work on uinfo inundation duration calculation. Using proxy-wms to induce additional style information (work in progress).
author gernotbelger
date Wed, 17 Oct 2018 11:23:17 +0200
parents 787fc085459b
children 709a73badd48
rev   line source
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
2 * Software engineering by
1ffd38826175 access uinfo.vegetationzones+inundation_duration
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.inundationduration;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
11
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
12 import java.io.IOException;
9070
611a523fc42f VegetationZoneAccessHelper, VegetationTablePanels verbessert
gernotbelger
parents: 9069
diff changeset
13 import java.util.List;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
14
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
15 import org.dive4elements.artifacts.CallContext;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.artifacts.model.Calculation;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
17 import org.dive4elements.river.artifacts.model.CalculationResult;
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
18 import org.dive4elements.river.artifacts.sinfo.tkhstate.TsvHelper.TsvReaderException;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
19 import org.dive4elements.river.artifacts.uinfo.UINFOArtifact;
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
20 import org.dive4elements.river.artifacts.uinfo.inundationduration.InundationDurationAccess.WmsClassification;
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9404
diff changeset
21 import org.dive4elements.river.artifacts.uinfo.inundationduration.InundationDurationCalculationResult.WmsLayer;
9404
bc9a45d2b1fa common time range for gauges incl. error messages
gernotbelger
parents: 9190
diff changeset
22 import org.dive4elements.river.artifacts.uinfo.vegetationzones.VegetationZoneServerClientXChange;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
23
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
24 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
25 * @author Domenico Nardi Tironi
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
26 *
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
27 */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
28 final class InundationDurationCalculation {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
29
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
30 private final CallContext context;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
31
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
32 public InundationDurationCalculation(final CallContext context) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
33 this.context = context;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
34 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
35
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
36 public CalculationResult calculate(final UINFOArtifact uinfo) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
37 final Calculation problems = new Calculation();
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
38
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
39 try {
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
40 final InundationDurationAccess indurax = new InundationDurationAccess(uinfo);
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
41
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
42 final String zonesRaw = indurax.getVegZones();
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
43 final List<VegetationZoneServerClientXChange> zones = VegetationZoneServerClientXChange.parse(zonesRaw);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
44 // FIXME: instead find out a-uuid of referenced vegetations
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
45 // FIXME:
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
46 final String vegZoneId = "unknown";
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
47
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
48 final boolean isUseScenario = indurax.getIsUseScenario();
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
49
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
50 final InundationDurationCalculationResult result = new InundationDurationCalculationResult();
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
51
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
52 final WmsLayer inundationDurationLayer = indurax.createWMSLayer(this.context, "uinfo.export.url.inundationduration.inundationduration",
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
53 WmsClassification.asIs, vegZoneId);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
54 result.addLayer(inundationDurationLayer);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
55
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
56 final WmsLayer vegetationLayer = indurax.createWMSLayer(this.context, "uinfo.export.url.inundationduration.vegetation",
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
57 WmsClassification.vegetationZone, vegZoneId);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
58 result.addLayer(vegetationLayer);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
59
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
60 if (isUseScenario) {
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
61 // TODO: wieder einkommentieren, sobald die URL-Definition für Szenarien geklärt ist (und hoffentlich analog zu "mittel"
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
62 // und "jahre" funktioniert)
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
63 // final WmsLayer scenarioInundationDurationLayer = indurax.createScenarioWMSLayer(this.context.getMeta(),
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
64 // "uinfo.export.url.inundationduration.scenario");
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
65 // result.addLayer(scenarioInundationDurationLayer);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
66 //
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
67 // // TODO: add vegetationzone-values as styles to layer
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
68 // final WmsLayer scenarioVegetationLayer = indurax.createScenarioWMSLayer(this.context.getMeta(),
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
69 // "uinfo.export.url.inundationduration.vegetation_scenario");
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
70 // result.addLayer(scenarioVegetationLayer);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
71 }
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
72
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
73 return new CalculationResult(result, problems);
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
74 }
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
75 catch (IOException | TsvReaderException e) {
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
76 e.printStackTrace();
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
77 problems.addProblem("Invalid server configuration: " + e.getLocalizedMessage());
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
78 return new CalculationResult(null, problems);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
79 }
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
80 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
81 }

http://dive4elements.wald.intevation.org