Mercurial > dive4elements > river
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 | 14 import org.dive4elements.artifactdatabase.ProtocolUtils; |
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 | 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 | 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 | 28 import org.dive4elements.river.model.Gauge; |
29 import org.dive4elements.river.model.River; | |
30 import org.dive4elements.river.model.Wst; | |
31 import org.dive4elements.river.utils.RiverUtils; | |
32 import org.w3c.dom.Element; | |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
4049
diff
changeset
|
33 |
9277 | 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 | 81 protected Element createStaticData(final D4EArtifact flys, final ElementCreator creator, final CallContext cc, final String name, final String value, |
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 | 87 final Boolean isQ = flys.getDataAsBoolean(WQ_MODE); |
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 | 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 | 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 | 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 | 112 protected static String getLabel(final D4EArtifact winfo, final CallContext cc, final String raw) { |
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 | 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 | 121 final NumberFormat nf = NumberFormat.getInstance(Resources.getLocale(cc.getMeta())); |
122 | |
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 | 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 | 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 | 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 | 142 protected static String getSpecialLabel(final D4EArtifact winfo, final CallContext cc, final String raw) { |
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 | 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 | 151 final RangeAccess rangeAccess = new RangeAccess(winfo); |
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 | 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 | 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 | 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 | 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 | 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 | 181 protected Element createData(final XMLUtils.ElementCreator cr, final Artifact artifact, final StateData data, final CallContext context) { |
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 | 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 | 190 * Element choices = ProtocolUtils.createArtNode( |
191 * cr, "choices", null, null); | |
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 | 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 | 202 protected Element[] createItems(final XMLUtils.ElementCreator cr, final Artifact artifact, final String name, final CallContext context) { |
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 | 205 final double[] minmaxW = determineMinMaxW(flys); |
206 final double[] minmaxWFree = determineMinMaxWFree(flys); | |
207 final double[] minmaxQ = determineMinMaxQAtGauge(flys); | |
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 | 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 | 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 | 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 | 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 | 220 } else if (name.equals("wq_to")) { |
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 | 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 | 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 | 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 | 230 } else { |
231 final Element stepW = createItem(cr, new String[] { "stepW", String.valueOf(getStepsW(minmaxW[0], minmaxW[1])) }); | |
232 final Element stepQ = createItem(cr, new String[] { "stepQ", String.valueOf(getStepsQ(minmaxQ[0], minmaxQ[1])) }); | |
233 final Element stepQFree = createItem(cr, new String[] { "stepQFree", String.valueOf(getStepsQ(minmaxQFree[0], minmaxQFree[1])) }); | |
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 | 240 protected static double getStepsW(final double min, final double max) { |
241 final double diff = min < max ? max - min : min - max; | |
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 | 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 | 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 | 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 | 255 protected static double getStepsQ(final double min, final double max) { |
256 final double diff = min < max ? max - min : min - max; | |
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 | 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 | 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 | 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 | 270 protected static double getSteps(final double steps, final double factor) { |
271 final int fac = (int) (steps / factor); | |
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 | 281 // ist mit super identisch |
282 // protected Element createItem(XMLUtils.ElementCreator cr, Object obj) { | |
283 // Element item = ProtocolUtils.createArtNode(cr, "item", null, null); | |
284 // Element label = ProtocolUtils.createArtNode(cr, "label", null, null); | |
285 // Element value = ProtocolUtils.createArtNode(cr, "value", null, null); | |
286 // | |
287 // String[] arr = (String[]) obj; | |
288 // | |
289 // label.setTextContent(arr[0]); | |
290 // value.setTextContent(arr[1]); | |
291 // | |
292 // item.appendChild(label); | |
293 // item.appendChild(value); | |
294 // | |
295 // return item; | |
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 | 308 * @param artifact |
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 | 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 | 316 final RangeAccess rangeAccess = new RangeAccess(winfo); |
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 | 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 | 321 final double minW = minmaxW != null ? minmaxW[0] : Double.MIN_VALUE; |
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 | 332 * @param artifact |
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 | 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 | 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 | 342 final ComputationRangeAccess access = new ComputationRangeAccess(winfo); |
343 | |
2617
71086a3a1c5f
Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2423
diff
changeset
|
344 double[] minmaxW = null; |
9277 | 345 if (valueTable != null) { |
9130 | 346 |
347 final double startKm = access.getStartKm(); | |
348 // Use the start km to determine the min max values. | |
349 minmaxW = valueTable.getMinMaxW(startKm); | |
2617
71086a3a1c5f
Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2423
diff
changeset
|
350 } |
9277 | 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 | 359 * @param artifact |
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 | 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 | 367 final RangeAccess rangeAccess = new RangeAccess(winfo); |
368 final River river = rangeAccess.getRiver(); | |
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 | 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 | 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 | 375 final double minQ = minmaxQ != null ? minmaxQ[0] : Double.MIN_VALUE; |
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 | 385 * @param artifact |
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 | 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 | 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 | 395 final ComputationRangeAccess access = new ComputationRangeAccess(winfo); |
9277 | 396 |
2617
71086a3a1c5f
Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2423
diff
changeset
|
397 double[] minmaxQ = null; |
9277 | 398 if (valueTable != null) { |
399 | |
9130 | 400 final KM_MODE mode = access.getKmRangeMode(); |
401 switch (mode) { | |
402 case RANGE: { | |
9277 | 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 | 405 break; |
2617
71086a3a1c5f
Issue 499.
Raimund Renkert <raimund.renkert@intevation.de>
parents:
2423
diff
changeset
|
406 } |
9277 | 407 |
9130 | 408 case DISTANCE_ONLY: { |
409 minmaxQ = valueTable.getMinMaxQ(access.getFrom(), access.getTo(), 0.1); | |
410 break; | |
411 } | |
412 | |
413 default: { | |
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 | 417 final double[] tmp = valueTable.getMinMaxQ(km[i]); |
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 | 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 | 425 break; |
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 | 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 | 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 | 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 | 438 final StateData data = getData(flys, WQ_SELECTION); |
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 | 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 | 448 protected boolean validateBounds(final double fromValid, final double toValid, final double from, final double to, final double step) |
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 | 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 | 455 } else if (to > toValid) { |
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 | 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 | 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 | 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 | 474 final String[] strValues = tmp.split(" "); |
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 | 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 | 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 | 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 | 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 | 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 | 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 | 504 final double min = all.get(0); |
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 | 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 | 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 | 522 final StateData dFrom = artifact.getData(WQ_FROM); |
523 final StateData dTo = artifact.getData(WQ_TO); | |
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 | 526 final String fromStr = dFrom != null ? (String) dFrom.getValue() : null; |
527 final String toStr = dTo != null ? (String) dTo.getValue() : null; | |
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 | 535 final double from = Double.parseDouble(fromStr); |
536 final double to = Double.parseDouble(toStr); | |
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 | 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 | 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 | 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 | 547 } else { |
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 | 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 | 559 * @param artifact |
560 * The owner artifact. | |
561 * @param from | |
562 * The lower value of the W range. | |
563 * @param to | |
564 * The upper value of the W range. | |
565 * @param step | |
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 | 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 | 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 | 582 * @param artifact |
583 * The owner artifact. | |
584 * @param from | |
585 * The lower value of the Q range. | |
586 * @param to | |
587 * The upper value of the Q range. | |
588 * @param step | |
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 | 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 | 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 | 605 * @param artifact |
606 * The owner artifact. | |
607 * @param from | |
608 * The lower value of the Q range. | |
609 * @param to | |
610 * The upper value of the Q range. | |
611 * @param step | |
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 | 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 | 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 | 628 * @param artifact |
629 * The owner artifact. | |
630 * @param from | |
631 * The lower value of the W range. | |
632 * @param to | |
633 * The upper value of the W range. | |
634 * @param step | |
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 | 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 | 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 : |