annotate artifacts/src/main/java/org/dive4elements/river/artifacts/states/WQSelect.java @ 9372:e014eca211a3

distance_only_part_validation bugfix
author gernotbelger
date Thu, 02 Aug 2018 19:20:38 +0200
parents 2323d005f9a5
children
rev   line source
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
2 * Software engineering by Intevation GmbH
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
3 *
5994
af13ceeba52a Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5867
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
5994
af13ceeba52a Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5867
diff changeset
6 * documentation coming with Dive4Elements River for details.
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
7 */
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
8
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
9 package org.dive4elements.river.artifacts.states;
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
10
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
11 import java.text.NumberFormat;
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
12
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
13 import org.apache.log4j.Logger;
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
14 import org.dive4elements.artifactdatabase.ProtocolUtils;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
15 import org.dive4elements.artifactdatabase.data.StateData;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
16 import org.dive4elements.artifacts.Artifact;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
17 import org.dive4elements.artifacts.CallContext;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
18 import org.dive4elements.artifacts.common.utils.XMLUtils;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
19 import org.dive4elements.artifacts.common.utils.XMLUtils.ElementCreator;
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
20 import org.dive4elements.river.artifacts.D4EArtifact;
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
21 import org.dive4elements.river.artifacts.access.ComputationRangeAccess;
8757
bd17bd07db69 Remove further indirection in WINFOArtifact.
Tom Gottfried <tom@intevation.de>
parents: 8756
diff changeset
22 import org.dive4elements.river.artifacts.access.RangeAccess;
9130
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
23 import org.dive4elements.river.artifacts.access.RangeAccess.KM_MODE;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
24 import org.dive4elements.river.artifacts.model.WstFactory;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
25 import org.dive4elements.river.artifacts.model.WstValueTable;
6326
5c880567a020 Artifacts: Moved code from WINFO artifact into state where it belongs.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5994
diff changeset
26 import org.dive4elements.river.artifacts.model.WstValueTableFactory;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
27 import org.dive4elements.river.artifacts.resources.Resources;
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
28 import org.dive4elements.river.model.Gauge;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
29 import org.dive4elements.river.model.River;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
30 import org.dive4elements.river.model.Wst;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
31 import org.dive4elements.river.utils.RiverUtils;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
32 import org.w3c.dom.Element;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 4049
diff changeset
33
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
34 import gnu.trove.TDoubleArrayList;
1103
e0243627ba62 Use FLYSUtils.getRiver instead of WINFOArtifact.getRiver.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 1055
diff changeset
35
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
36 /**
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
37 * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
38 */
921
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
39 public class WQSelect extends DefaultState {
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
40
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
41 /** The log used in this class. */
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
42 private static Logger log = Logger.getLogger(WQSelect.class);
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
43
1691
17648043429f Cosmetics, docs, annotations.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 1103
diff changeset
44 /** The default step width for Qs. */
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
45 public static final String DEFAULT_STEP_Q = "50";
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
46
1691
17648043429f Cosmetics, docs, annotations.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 1103
diff changeset
47 /** The default step width for Qs. */
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
48 public static final String DEFAULT_STEP_W = "30";
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
49
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
50 /** The max number of steps for Qs and Ws. */
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
51 public static final int MAX_STEPS = 30;
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
52
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
53 /** The name of the 'mode' field. */
2423
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2422
diff changeset
54 public static final String WQ_MODE = "wq_isq";
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
55
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
56 /** Them name fo the 'free' field. */
2423
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2422
diff changeset
57 public static final String WQ_FREE = "wq_isfree";
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
58
1691
17648043429f Cosmetics, docs, annotations.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 1103
diff changeset
59 /** The name of the 'selection' field. */
2423
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2422
diff changeset
60 public static final String WQ_SELECTION = "wq_isrange";
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
61
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
62 /** The name of the 'from' field. */
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
63 public static final String WQ_FROM = "wq_from";
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
64
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
65 /** The name of the 'to' field. */
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
66 public static final String WQ_TO = "wq_to";
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
67
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
68 /** The name of the 'step' field. */
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
69 public static final String WQ_STEP = "wq_step";
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
70
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
71 /** The name of the 'single' field. */
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
72 public static final String WQ_SINGLE = "wq_single";
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
73
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
74 /**
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
75 * The default constructor that initializes an empty State object.
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
76 */
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
77 public WQSelect() {
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
78 }
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
79
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
80 @Override
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
81 protected Element createStaticData(final D4EArtifact flys, final ElementCreator creator, final CallContext cc, final String name, final String value,
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
82 final String type) {
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
83 if (!name.equals(WQ_SINGLE)) {
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
84 return super.createStaticData(flys, creator, cc, name, value, type);
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
85 }
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
86
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
87 final Boolean isQ = flys.getDataAsBoolean(WQ_MODE);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
88 final Boolean isFree = flys.getDataAsBoolean(WQ_FREE);
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
89
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
90 final Element dataElement = creator.create("data");
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
91 creator.addAttr(dataElement, "name", name, true);
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
92 creator.addAttr(dataElement, "type", type, true);
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
93
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
94 final Element itemElement = creator.create("item");
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
95 creator.addAttr(itemElement, "value", value, true);
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
96
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
97 String label;
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
98
2422
44dc117aa2b7 Picked rev 4058,4063,4065,4068,4069 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2260
diff changeset
99 if (!isQ || isFree) {
8914
e3519c3e7a0a Workflow for SINFO-Transport bodies heights inclduing winfo calculation
gernotbelger
parents: 8760
diff changeset
100 label = getLabel(flys, cc, value);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
101 } else {
8914
e3519c3e7a0a Workflow for SINFO-Transport bodies heights inclduing winfo calculation
gernotbelger
parents: 8760
diff changeset
102 label = getSpecialLabel(flys, cc, value);
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
103 }
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
104
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
105 creator.addAttr(itemElement, "label", label, true);
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
106
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
107 dataElement.appendChild(itemElement);
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
108
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
109 return dataElement;
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
110 }
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
111
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
112 protected static String getLabel(final D4EArtifact winfo, final CallContext cc, final String raw) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
113 final String[] values = raw.split(" ");
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
114
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
115 if (values.length < 1) {
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
116 return null;
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
117 }
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
118
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
119 final StringBuilder label = new StringBuilder();
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
120
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
121 final NumberFormat nf = NumberFormat.getInstance(Resources.getLocale(cc.getMeta()));
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
122
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
123 for (final String value : values) {
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
124 try {
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
125 final double v = Double.parseDouble(value.trim());
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
126
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
127 final String formatted = nf.format(v);
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
128
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
129 if (label.length() > 0) {
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
130 label.append(';');
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
131 }
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
132 label.append(formatted);
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
133 }
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
134 catch (final NumberFormatException nfe) {
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
135 // do nothing here
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
136 }
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
137 }
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
138
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
139 return label.toString();
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
140 }
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
141
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
142 protected static String getSpecialLabel(final D4EArtifact winfo, final CallContext cc, final String raw) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
143 final String[] values = raw.split(" ");
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
144
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
145 if (values.length < 1) {
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
146 return null;
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
147 }
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
148
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
149 final NumberFormat nf = NumberFormat.getInstance(Resources.getLocale(cc.getMeta()));
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
150
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
151 final RangeAccess rangeAccess = new RangeAccess(winfo);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
152 final Gauge gauge = rangeAccess.getRiver().determineRefGauge(rangeAccess.getKmRange(), rangeAccess.isRange());
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
153
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
154 final StringBuilder label = new StringBuilder();
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
155
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
156 for (final String value : values) {
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
157 try {
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
158 final double v = Double.parseDouble(value.trim());
2025
6762f54b23b1 Bugfix: format all Ws and Qs in WQSelect State.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1743
diff changeset
159
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
160 String tmp = nf.format(v);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
161 final String mv = RiverUtils.getNamedMainValue(gauge, v);
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
162
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
163 if (mv != null && mv.length() > 0) {
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
164 tmp = mv + ": " + tmp;
8760
9483a5bf4219 Remove indirection via RiverUtils to obtain reference gauge and reduce casts.
Tom Gottfried <tom@intevation.de>
parents: 8757
diff changeset
165 log.debug("Add main value: '" + mv + "'");
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
166 }
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
167 if (label.length() > 0) {
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
168 label.append(';');
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
169 }
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
170 label.append(tmp);
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
171 }
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
172 catch (final NumberFormatException nfe) {
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
173 // do nothing here
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
174 }
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
175 }
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
176
2164
d548e2e13524 Added code for the simple case of "Bezugslinienverfahren" ("W auf freier Strecke").
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 2070
diff changeset
177 return label.toString();
1743
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
178 }
8a2cbf947395 Prepared the DESCRIBE document of a WINFO Artifact so that named main values for Qs are displayed.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 1691
diff changeset
179
1691
17648043429f Cosmetics, docs, annotations.
Felix Wolfsteller <felix.wolfsteller@intevation.de>
parents: 1103
diff changeset
180 @Override
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
181 protected Element createData(final XMLUtils.ElementCreator cr, final Artifact artifact, final StateData data, final CallContext context) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
182 final Element select = ProtocolUtils.createArtNode(cr, "select", null, null);
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
183
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
184 cr.addAttr(select, "name", data.getName(), true);
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
185
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
186 final Element label = ProtocolUtils.createArtNode(cr, "label", null, null);
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
187
4049
8e66293c5369 Removed dead code
Sascha L. Teichmann <teichmann@intevation.de>
parents: 2623
diff changeset
188 // XXX: DEAD CODE
8e66293c5369 Removed dead code
Sascha L. Teichmann <teichmann@intevation.de>
parents: 2623
diff changeset
189 /*
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
190 * Element choices = ProtocolUtils.createArtNode(
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
191 * cr, "choices", null, null);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
192 */
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
193
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
194 label.setTextContent(Resources.getMsg(context.getMeta(), data.getName(), data.getName()));
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
195
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
196 select.appendChild(label);
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
197
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
198 return select;
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
199 }
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
200
660
627be3ca1ab6 code clean up in states
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 631
diff changeset
201 @Override
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
202 protected Element[] createItems(final XMLUtils.ElementCreator cr, final Artifact artifact, final String name, final CallContext context) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
203 final D4EArtifact flys = (D4EArtifact) artifact;
8760
9483a5bf4219 Remove indirection via RiverUtils to obtain reference gauge and reduce casts.
Tom Gottfried <tom@intevation.de>
parents: 8757
diff changeset
204
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
205 final double[] minmaxW = determineMinMaxW(flys);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
206 final double[] minmaxWFree = determineMinMaxWFree(flys);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
207 final double[] minmaxQ = determineMinMaxQAtGauge(flys);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
208 final double[] minmaxQFree = determineMinMaxQ(flys);
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
209
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
210 if (name.equals("wq_from")) {
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
211 final Element minW = createItem(cr, new String[] { "minW", String.valueOf(minmaxW[0]) });
2062
ed6c6d437875 Added min/max values for free Qs to the Artifact's DESCRIBE document.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2061
diff changeset
212
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
213 final Element minQ = createItem(cr, new String[] { "minQ", String.valueOf(minmaxQ[0]) });
2062
ed6c6d437875 Added min/max values for free Qs to the Artifact's DESCRIBE document.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2061
diff changeset
214
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
215 final Element minQFree = createItem(cr, new String[] { "minQFree", String.valueOf(minmaxQFree[0]) });
2062
ed6c6d437875 Added min/max values for free Qs to the Artifact's DESCRIBE document.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2061
diff changeset
216
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
217 final Element minWFree = createItem(cr, new String[] { "minWFree", String.valueOf(minmaxWFree[0]) });
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
218
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
219 return new Element[] { minW, minQ, minQFree, minWFree };
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
220 } else if (name.equals("wq_to")) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
221 final Element maxW = createItem(cr, new String[] { "maxW", String.valueOf(minmaxW[1]) });
2062
ed6c6d437875 Added min/max values for free Qs to the Artifact's DESCRIBE document.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2061
diff changeset
222
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
223 final Element maxQ = createItem(cr, new String[] { "maxQ", String.valueOf(minmaxQ[1]) });
2062
ed6c6d437875 Added min/max values for free Qs to the Artifact's DESCRIBE document.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2061
diff changeset
224
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
225 final Element maxQFree = createItem(cr, new String[] { "maxQFree", String.valueOf(minmaxQFree[1]) });
2062
ed6c6d437875 Added min/max values for free Qs to the Artifact's DESCRIBE document.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2061
diff changeset
226
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
227 final Element maxWFree = createItem(cr, new String[] { "maxWFree", String.valueOf(minmaxWFree[1]) });
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
228
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
229 return new Element[] { maxW, maxQ, maxQFree, maxWFree };
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
230 } else {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
231 final Element stepW = createItem(cr, new String[] { "stepW", String.valueOf(getStepsW(minmaxW[0], minmaxW[1])) });
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
232 final Element stepQ = createItem(cr, new String[] { "stepQ", String.valueOf(getStepsQ(minmaxQ[0], minmaxQ[1])) });
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
233 final Element stepQFree = createItem(cr, new String[] { "stepQFree", String.valueOf(getStepsQ(minmaxQFree[0], minmaxQFree[1])) });
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
234 final Element stepWFree = createItem(cr, new String[] { "stepWFree", String.valueOf(getStepsW(minmaxWFree[0], minmaxWFree[1])) });
2062
ed6c6d437875 Added min/max values for free Qs to the Artifact's DESCRIBE document.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2061
diff changeset
235
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
236 return new Element[] { stepW, stepQ, stepQFree, stepWFree };
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
237 }
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
238 }
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
239
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
240 protected static double getStepsW(final double min, final double max) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
241 final double diff = min < max ? max - min : min - max;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
242 final double step = diff / MAX_STEPS;
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
243
2061
87f9153bb7ca Fixed order to determine correct step width of Qs and Ws.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2060
diff changeset
244 if (step < 10) {
87f9153bb7ca Fixed order to determine correct step width of Qs and Ws.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2060
diff changeset
245 return getSteps(step, 1);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
246 } else if (step < 100) {
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
247 return getSteps(step, 10);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
248 } else if (step < 1000) {
2061
87f9153bb7ca Fixed order to determine correct step width of Qs and Ws.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2060
diff changeset
249 return getSteps(step, 100);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
250 } else {
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
251 return step;
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
252 }
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
253 }
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
254
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
255 protected static double getStepsQ(final double min, final double max) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
256 final double diff = min < max ? max - min : min - max;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
257 final double step = diff / MAX_STEPS;
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
258
2061
87f9153bb7ca Fixed order to determine correct step width of Qs and Ws.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2060
diff changeset
259 if (step < 10) {
87f9153bb7ca Fixed order to determine correct step width of Qs and Ws.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2060
diff changeset
260 return getSteps(step, 1);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
261 } else if (step < 100) {
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
262 return getSteps(step, 10);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
263 } else if (step < 1000) {
2061
87f9153bb7ca Fixed order to determine correct step width of Qs and Ws.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2060
diff changeset
264 return getSteps(step, 100);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
265 } else {
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
266 return step;
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
267 }
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
268 }
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
269
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
270 protected static double getSteps(final double steps, final double factor) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
271 final int fac = (int) (steps / factor);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
272 final double diff = steps - fac * factor;
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
273
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
274 if (diff == 0) {
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
275 return steps;
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
276 }
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
277
2623
c4591312f3d3 Fixed step calculation in W/Q range input mode.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2618
diff changeset
278 return factor * (fac + 1);
2059
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
279 }
522826b41ffa Compute better step width for W/Q input.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2030
diff changeset
280
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
281 // ist mit super identisch
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
282 // protected Element createItem(XMLUtils.ElementCreator cr, Object obj) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
283 // Element item = ProtocolUtils.createArtNode(cr, "item", null, null);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
284 // Element label = ProtocolUtils.createArtNode(cr, "label", null, null);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
285 // Element value = ProtocolUtils.createArtNode(cr, "value", null, null);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
286 //
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
287 // String[] arr = (String[]) obj;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
288 //
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
289 // label.setTextContent(arr[0]);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
290 // value.setTextContent(arr[1]);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
291 //
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
292 // item.appendChild(label);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
293 // item.appendChild(value);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
294 //
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
295 // return item;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
296 // }
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
297
660
627be3ca1ab6 code clean up in states
Sascha L. Teichmann <sascha.teichmann@intevation.de>
parents: 631
diff changeset
298 @Override
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
299 protected String getUIProvider() {
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
300 return "wq_panel";
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
301 }
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
302
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
303 /**
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
304 * Determines the min and max W value for the current gauge. If no min and
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
305 * max values could be determined, this method will return
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
306 * [Double.MIN_VALUE, Double.MAX_VALUE].
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
307 *
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
308 * @param artifact
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
309 * The D4EArtifact.
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
310 *
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
311 * @return the min and max W values for the current gauge.
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
312 */
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
313 protected double[] determineMinMaxW(final D4EArtifact winfo) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
314 log.debug("WQSelect.determineCurrentGauge");
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
315
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
316 final RangeAccess rangeAccess = new RangeAccess(winfo);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
317 final Gauge gauge = rangeAccess.getRiver().determineRefGauge(rangeAccess.getKmRange(), rangeAccess.isRange());
8760
9483a5bf4219 Remove indirection via RiverUtils to obtain reference gauge and reduce casts.
Tom Gottfried <tom@intevation.de>
parents: 8757
diff changeset
318
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
319 final double[] minmaxW = gauge != null ? gauge.determineMinMaxW() : null;
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
320
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
321 final double minW = minmaxW != null ? minmaxW[0] : Double.MIN_VALUE;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
322 final double maxW = minmaxW != null ? minmaxW[1] : Double.MAX_VALUE;
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
323
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
324 return new double[] { minW, maxW };
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
325 }
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
326
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
327 /**
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
328 * Determines the min and max W value. If no min and
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
329 * max values could be determined, this method will return
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
330 * [Double.MIN_VALUE, Double.MAX_VALUE].
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
331 *
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
332 * @param artifact
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
333 * The D4EArtifact.
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
334 *
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
335 * @return the min and max W values.
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
336 */
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
337 protected double[] determineMinMaxWFree(final D4EArtifact winfo) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
338 log.debug("WQSelect.determineMinMaxWFree");
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
339
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
340 final WstValueTable valueTable = WstValueTableFactory.getTable(RiverUtils.getRiver(winfo));
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
341
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
342 final ComputationRangeAccess access = new ComputationRangeAccess(winfo);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
343
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
344 double[] minmaxW = null;
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
345 if (valueTable != null) {
9130
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
346
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
347 final double startKm = access.getStartKm();
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
348 // Use the start km to determine the min max values.
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
349 minmaxW = valueTable.getMinMaxW(startKm);
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
350 }
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
351 return minmaxW != null ? minmaxW : new double[] { Double.MIN_VALUE, Double.MAX_VALUE };
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
352 }
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
353
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
354 /**
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
355 * Determines the min and max Q value for the current gauge. If no min and
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
356 * max values could be determined, this method will return
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
357 * [Double.MIN_VALUE, Double.MAX_VALUE].
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
358 *
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
359 * @param artifact
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
360 * The D4EArtifact.
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
361 *
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
362 * @return the min and max Q values for the current gauge.
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
363 */
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
364 protected double[] determineMinMaxQAtGauge(final D4EArtifact winfo) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
365 log.debug("WQSelect.determineMinMaxQAtGauge");
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
366
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
367 final RangeAccess rangeAccess = new RangeAccess(winfo);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
368 final River river = rangeAccess.getRiver();
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
369 final Gauge gauge = river.determineRefGauge(rangeAccess.getKmRange(), rangeAccess.isRange());
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
370
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
371 final Wst wst = WstFactory.getWst(river);
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
372
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
373 final double[] minmaxQ = gauge != null ? wst.determineMinMaxQ(gauge.getRange()) : null;
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
374
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
375 final double minQ = minmaxQ != null ? minmaxQ[0] : Double.MIN_VALUE;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
376 final double maxQ = minmaxQ != null ? minmaxQ[1] : Double.MAX_VALUE;
319
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
377
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
378 return new double[] { minQ, maxQ };
d8558dd64152 The WQ state fills the DESCRIBE with default values for W and Q.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 313
diff changeset
379 }
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
380
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
381 /**
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
382 * Determines the min and max Q value for the current kilometer range. If no
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
383 * min and max values could be determined, this method will return
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
384 *
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
385 * @param artifact
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
386 * The D4EArtifact.
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
387 *
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
388 * @return the min and max Q values for the current kilometer range.
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
389 */
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
390 protected double[] determineMinMaxQ(final D4EArtifact winfo) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
391 log.debug("WQSelect.determineMinMaxQ");
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
392
9130
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
393 final WstValueTable valueTable = WstValueTableFactory.getTable(RiverUtils.getRiver(winfo));
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
394
9130
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
395 final ComputationRangeAccess access = new ComputationRangeAccess(winfo);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
396
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
397 double[] minmaxQ = null;
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
398 if (valueTable != null) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
399
9130
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
400 final KM_MODE mode = access.getKmRangeMode();
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
401 switch (mode) {
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
402 case RANGE: {
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
403 final double[] km = access.getFromToStep();
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
404 minmaxQ = valueTable.getMinMaxQ(km[0], km[1], km[2]);
9130
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
405 break;
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
406 }
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
407
9130
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
408 case DISTANCE_ONLY: {
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
409 minmaxQ = valueTable.getMinMaxQ(access.getFrom(), access.getTo(), 0.1);
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
410 break;
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
411 }
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
412
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
413 default: {
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
414 final double[] km = access.getKms();
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
415 minmaxQ = valueTable.getMinMaxQ(km[0]);
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
416 for (int i = 1; i < km.length; i++) {
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
417 final double[] tmp = valueTable.getMinMaxQ(km[i]);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
418 if (tmp[0] < minmaxQ[0]) {
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
419 minmaxQ[0] = tmp[0];
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
420 }
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
421 if (tmp[1] > minmaxQ[1]) {
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
422 minmaxQ[1] = tmp[1];
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
423 }
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
424 }
9130
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
425 break;
f61bc0c63188 WQSelect can now handle distance-only data
gernotbelger
parents: 8914
diff changeset
426 }
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
427 }
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
428 }
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
429 return minmaxQ != null ? minmaxQ : new double[] { Double.MIN_VALUE, Double.MAX_VALUE };
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
430 }
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
431
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
432 @Override
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
433 public boolean validate(final Artifact artifact) throws IllegalArgumentException {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
434 log.debug("WQSelect.validate");
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
435
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
436 final D4EArtifact flys = (D4EArtifact) artifact;
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
437
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
438 final StateData data = getData(flys, WQ_SELECTION);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
439 final boolean isRange = data != null ? Boolean.valueOf((String) data.getValue()) : false;
2423
ac528b883b47 Picked rev 4070,4074,4076,4080 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2422
diff changeset
440
2422
44dc117aa2b7 Picked rev 4058,4063,4065,4068,4069 from trunk.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2260
diff changeset
441 if (!isRange) {
8760
9483a5bf4219 Remove indirection via RiverUtils to obtain reference gauge and reduce casts.
Tom Gottfried <tom@intevation.de>
parents: 8757
diff changeset
442 return validateSingle(flys);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
443 } else {
8760
9483a5bf4219 Remove indirection via RiverUtils to obtain reference gauge and reduce casts.
Tom Gottfried <tom@intevation.de>
parents: 8757
diff changeset
444 return validateRange(flys);
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
445 }
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
446 }
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
447
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
448 protected boolean validateBounds(final double fromValid, final double toValid, final double from, final double to, final double step)
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
449 throws IllegalArgumentException {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
450 log.debug("RangeState.validateRange");
921
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
451
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
452 if (from < fromValid) {
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
453 log.error("Invalid 'from'. " + from + " is smaller than " + fromValid);
921
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
454 throw new IllegalArgumentException("error_feed_from_out_of_range");
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
455 } else if (to > toValid) {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
456 log.error("Invalid 'to'. " + to + " is bigger than " + toValid);
921
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
457 throw new IllegalArgumentException("error_feed_to_out_of_range");
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
458 }
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
459
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
460 return true;
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
461 }
610d0e0f4f85 #159 Modifications in the transition model to support a state with a kilometer range input only.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 660
diff changeset
462
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
463 protected boolean validateSingle(final D4EArtifact artifact) throws IllegalArgumentException {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
464 log.debug("WQSelect.validateSingle");
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
465
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
466 final StateData data = getData(artifact, WQ_SINGLE);
624
929137ee8154 ISSUE-62 (part I/II) States are no longer filled with data - if a state needs user input, it needs to query the owner artifact.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 379
diff changeset
467
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
468 final String tmp = data != null ? (String) data.getValue() : null;
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
469
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
470 if (tmp == null || tmp.length() == 0) {
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
471 throw new IllegalArgumentException("error_empty_state");
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
472 }
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
473
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
474 final String[] strValues = tmp.split(" ");
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
475 final TDoubleArrayList all = new TDoubleArrayList();
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
476
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
477 for (final String strValue : strValues) {
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
478 try {
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
479 all.add(Double.parseDouble(strValue));
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
480 }
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
481 catch (final NumberFormatException nfe) {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
482 log.warn(nfe, nfe);
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
483 }
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
484 }
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
485
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
486 all.sort();
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
487
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
488 final RiverUtils.WQ_MODE mode = RiverUtils.getWQMode(artifact);
624
929137ee8154 ISSUE-62 (part I/II) States are no longer filled with data - if a state needs user input, it needs to query the owner artifact.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 379
diff changeset
489
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
490 log.debug("WQ Mode: " + mode);
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
491
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
492 double[] minmax = null;
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
493
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
494 if (mode == RiverUtils.WQ_MODE.WGAUGE) {
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
495 minmax = determineMinMaxW(artifact);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
496 } else if (mode == RiverUtils.WQ_MODE.QGAUGE) {
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
497 minmax = determineMinMaxQAtGauge(artifact);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
498 } else if (mode == RiverUtils.WQ_MODE.QFREE) {
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
499 minmax = determineMinMaxQ(artifact);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
500 } else {
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
501 minmax = determineMinMaxWFree(artifact);
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
502 }
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
503
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
504 final double min = all.get(0);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
505 final double max = all.get(all.size() - 1);
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
506
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
507 log.debug("Inserted min value = " + min);
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
508 log.debug("Inserted max value = " + max);
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
509
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
510 return validateBounds(minmax[0], minmax[1], min, max, 0d);
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
511 }
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
512
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
513 protected boolean validateRange(final D4EArtifact artifact) throws IllegalArgumentException {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
514 log.debug("WQSelect.validateRange");
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
515
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
516 final RiverUtils.WQ_MODE mode = RiverUtils.getWQMode(artifact);
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
517
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
518 if (mode == null) {
631
a9af60c84dca Small bugfixes in the WQ selection state.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 624
diff changeset
519 throw new IllegalArgumentException("error_feed_invalid_wq_mode");
a9af60c84dca Small bugfixes in the WQ selection state.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 624
diff changeset
520 }
a9af60c84dca Small bugfixes in the WQ selection state.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 624
diff changeset
521
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
522 final StateData dFrom = artifact.getData(WQ_FROM);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
523 final StateData dTo = artifact.getData(WQ_TO);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
524 final StateData dStep = artifact.getData(WQ_STEP);
631
a9af60c84dca Small bugfixes in the WQ selection state.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 624
diff changeset
525
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
526 final String fromStr = dFrom != null ? (String) dFrom.getValue() : null;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
527 final String toStr = dTo != null ? (String) dTo.getValue() : null;
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
528 final String stepStr = dStep != null ? (String) dStep.getValue() : null;
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
529
352
ed3325a0232a Throw an illegal argument exception in LocationDistanceSelect.validate() and WQSelect.validate() if no data has been inserted so far.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 322
diff changeset
530 if (fromStr == null || toStr == null || stepStr == null) {
ed3325a0232a Throw an illegal argument exception in LocationDistanceSelect.validate() and WQSelect.validate() if no data has been inserted so far.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 322
diff changeset
531 throw new IllegalArgumentException("error_empty_state");
ed3325a0232a Throw an illegal argument exception in LocationDistanceSelect.validate() and WQSelect.validate() if no data has been inserted so far.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 322
diff changeset
532 }
ed3325a0232a Throw an illegal argument exception in LocationDistanceSelect.validate() and WQSelect.validate() if no data has been inserted so far.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 322
diff changeset
533
631
a9af60c84dca Small bugfixes in the WQ selection state.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 624
diff changeset
534 try {
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
535 final double from = Double.parseDouble(fromStr);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
536 final double to = Double.parseDouble(toStr);
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
537 final double step = Double.parseDouble(stepStr);
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
538
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
539 if (mode == RiverUtils.WQ_MODE.WGAUGE) {
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
540 return validateGaugeW(artifact, from, to, step);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
541 } else if (mode == RiverUtils.WQ_MODE.QGAUGE) {
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
542 return validateGaugeQ(artifact, from, to, step);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
543 } else if (mode == RiverUtils.WQ_MODE.QFREE) {
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
544 return validateFreeQ(artifact, from, to, step);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
545 } else if (mode == RiverUtils.WQ_MODE.WFREE) {
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
546 return validateFreeW(artifact, from, to, step);
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
547 } else {
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
548 throw new IllegalArgumentException("error_feed_invalid_wq_mode");
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
549 }
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
550 }
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
551 catch (final NumberFormatException nfe) {
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
552 throw new IllegalArgumentException("error_feed_number_format");
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
553 }
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
554 }
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
555
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
556 /**
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
557 * Validates the inserted W values.
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
558 *
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
559 * @param artifact
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
560 * The owner artifact.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
561 * @param from
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
562 * The lower value of the W range.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
563 * @param to
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
564 * The upper value of the W range.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
565 * @param step
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
566 * The step width.
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
567 *
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
568 * @return true, if everything was fine, otherwise an exception is thrown.
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
569 */
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
570 protected boolean validateGaugeW(final D4EArtifact artifact, final double from, final double to, final double step) throws IllegalArgumentException {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
571 log.debug("WQSelect.validateGaugeW");
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
572
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
573 final double[] minmaxW = determineMinMaxW(artifact);
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
574
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
575 return validateBounds(minmaxW[0], minmaxW[1], from, to, step);
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
576 }
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
577
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
578 /**
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
579 * Validates the inserted Q values based on the Q range for the current
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
580 * gauge.
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
581 *
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
582 * @param artifact
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
583 * The owner artifact.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
584 * @param from
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
585 * The lower value of the Q range.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
586 * @param to
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
587 * The upper value of the Q range.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
588 * @param step
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
589 * The step width.
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
590 *
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
591 * @return true, if everything was fine, otherwise an exception is thrown.
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
592 */
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
593 protected boolean validateGaugeQ(final D4EArtifact artifact, final double from, final double to, final double step) throws IllegalArgumentException {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
594 log.debug("WQSelect.validateGaugeQ");
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
595
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
596 final double[] minmaxQ = determineMinMaxQAtGauge(artifact);
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
597
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
598 return validateBounds(minmaxQ[0], minmaxQ[1], from, to, step);
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
599 }
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
600
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
601 /**
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
602 * Validates the inserted Q values based on the Q range for the current
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
603 * kilometer range.
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
604 *
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
605 * @param artifact
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
606 * The owner artifact.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
607 * @param from
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
608 * The lower value of the Q range.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
609 * @param to
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
610 * The upper value of the Q range.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
611 * @param step
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
612 * The step width.
2060
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
613 *
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
614 * @return true, if everything was fine, otherwise an exception is thrown.
3ffb7195173f Validate user defined Qs based on the start kilometer ('Q free').
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 2059
diff changeset
615 */
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
616 protected boolean validateFreeQ(final D4EArtifact artifact, final double from, final double to, final double step) throws IllegalArgumentException {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
617 log.debug("WQSelect.validateFreeQ");
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
618
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
619 final double[] minmaxQ = determineMinMaxQ(artifact);
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
620
379
c21fb8de54f8 Enabled the FLYSArtifact to handle an array of inserted WQ values (without given ranges).
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 352
diff changeset
621 return validateBounds(minmaxQ[0], minmaxQ[1], from, to, step);
322
448d0dc64357 The inserted ranges (distance and WQ ranges) are validated in the feed() operation.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents: 320
diff changeset
622 }
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
623
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
624 /**
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
625 * Validates the inserted W values based on the W range for the current
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
626 * kilometer range.
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
627 *
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
628 * @param artifact
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
629 * The owner artifact.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
630 * @param from
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
631 * The lower value of the W range.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
632 * @param to
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
633 * The upper value of the W range.
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
634 * @param step
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
635 * The step width.
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
636 *
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
637 * @return true, if everything was fine, otherwise an exception is thrown.
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
638 */
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
639 protected boolean validateFreeW(final D4EArtifact artifact, final double from, final double to, final double step) throws IllegalArgumentException {
8202
e4606eae8ea5 sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6326
diff changeset
640 log.debug("WQSelect.validateFreeW");
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
641
9277
2323d005f9a5 compile error fix
gernotbelger
parents: 9130
diff changeset
642 final double[] minmaxW = determineMinMaxWFree(artifact);
2617
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
643
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
644 return validateBounds(minmaxW[0], minmaxW[1], from, to, step);
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
645 }
71086a3a1c5f Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents: 2423
diff changeset
646
137
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
647 }
7f839b81cdde Added a new state for the W/Q input in the WINFO parameterization.
Ingo Weinzierl <ingo.weinzierl@intevation.de>
parents:
diff changeset
648 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :

http://dive4elements.wald.intevation.org