annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/inundationduration/InundationDurationCalculation.java @ 9558:709a73badd48

VegetationZone removed from Uinfo-Ü'Dauern Workflow
author gernotbelger
date Wed, 24 Oct 2018 12:00:49 +0200
parents bf6b63208f34
children ba0561906f81
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;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
13
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
14 import org.dive4elements.artifacts.CallContext;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
15 import org.dive4elements.river.artifacts.model.Calculation;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.artifacts.model.CalculationResult;
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
17 import org.dive4elements.river.artifacts.sinfo.tkhstate.TsvHelper.TsvReaderException;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
18 import org.dive4elements.river.artifacts.uinfo.UINFOArtifact;
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
19 import org.dive4elements.river.artifacts.uinfo.inundationduration.InundationDurationAccess.WmsClassification;
9481
787fc085459b TSV introduced; uinfo.inundationWMS-Config
gernotbelger
parents: 9404
diff changeset
20 import org.dive4elements.river.artifacts.uinfo.inundationduration.InundationDurationCalculationResult.WmsLayer;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
21
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
22 /**
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
23 * @author Domenico Nardi Tironi
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
24 *
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
25 */
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
26 final class InundationDurationCalculation {
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
27
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
28 private final CallContext context;
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
29
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
30 public InundationDurationCalculation(final CallContext context) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
31 this.context = context;
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
32 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
33
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
34 public CalculationResult calculate(final UINFOArtifact uinfo) {
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
35 final Calculation problems = new Calculation();
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
36
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
37 try {
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
38 final InundationDurationAccess indurax = new InundationDurationAccess(uinfo);
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
39
9558
709a73badd48 VegetationZone removed from Uinfo-Ü'Dauern Workflow
gernotbelger
parents: 9537
diff changeset
40 // VegetationZones have been removed - these two lines should be deleted
709a73badd48 VegetationZone removed from Uinfo-Ü'Dauern Workflow
gernotbelger
parents: 9537
diff changeset
41 // final String zonesRaw = indurax.getVegZones();
709a73badd48 VegetationZone removed from Uinfo-Ü'Dauern Workflow
gernotbelger
parents: 9537
diff changeset
42 // final List<VegetationZoneServerClientXChange> zones = VegetationZoneServerClientXChange.parse(zonesRaw);
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
43 // FIXME: instead find out a-uuid of referenced vegetations
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
44 // FIXME:
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
45 final String vegZoneId = "unknown";
9069
1ffd38826175 access uinfo.vegetationzones+inundation_duration
gernotbelger
parents: 8996
diff changeset
46
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
47 final boolean isUseScenario = indurax.getIsUseScenario();
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
48
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
49 final InundationDurationCalculationResult result = new InundationDurationCalculationResult();
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
50
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
51 final WmsLayer inundationDurationLayer = indurax.createWMSLayer(this.context, "uinfo.export.url.inundationduration.inundationduration",
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
52 WmsClassification.asIs, vegZoneId);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
53 result.addLayer(inundationDurationLayer);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
54
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
55 final WmsLayer vegetationLayer = indurax.createWMSLayer(this.context, "uinfo.export.url.inundationduration.vegetation",
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
56 WmsClassification.vegetationZone, vegZoneId);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
57 result.addLayer(vegetationLayer);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
58
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
59 if (isUseScenario) {
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
60 // 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
61 // und "jahre" funktioniert)
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
62 // final WmsLayer scenarioInundationDurationLayer = indurax.createScenarioWMSLayer(this.context.getMeta(),
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
63 // "uinfo.export.url.inundationduration.scenario");
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
64 // result.addLayer(scenarioInundationDurationLayer);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
65 //
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
66 // // TODO: add vegetationzone-values as styles to layer
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
67 // final WmsLayer scenarioVegetationLayer = indurax.createScenarioWMSLayer(this.context.getMeta(),
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
68 // "uinfo.export.url.inundationduration.vegetation_scenario");
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
69 // result.addLayer(scenarioVegetationLayer);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
70 }
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 return new CalculationResult(result, problems);
9190
0633f963c5be uinfo.inundationduration workflow
gernotbelger
parents: 9178
diff changeset
73 }
9537
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
74 catch (IOException | TsvReaderException e) {
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
75 e.printStackTrace();
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
76 problems.addProblem("Invalid server configuration: " + e.getLocalizedMessage());
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
77 return new CalculationResult(null, problems);
bf6b63208f34 Work on uinfo inundation duration calculation.
gernotbelger
parents: 9481
diff changeset
78 }
8996
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
79 }
fb9430250899 Work on uinfo
gernotbelger
parents:
diff changeset
80 }

http://dive4elements.wald.intevation.org