Mercurial > dive4elements > river
changeset 6395:d2803cc7a338
Artifacts: Official lines: Only apply in Q-Calculations and filter against the ranges of the gauges.
author | Sascha L. Teichmann <teichmann@intevation.de> |
---|---|
date | Fri, 21 Jun 2013 16:28:47 +0200 (2013-06-21) |
parents | cf4889a257cb |
children | f1018fd85183 |
files | artifacts/src/main/java/org/dive4elements/river/artifacts/model/OfficialLineFinder.java |
diffstat | 1 files changed, 65 insertions(+), 3 deletions(-) [+] |
line wrap: on
line diff
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/model/OfficialLineFinder.java Fri Jun 21 15:37:32 2013 +0200 +++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/model/OfficialLineFinder.java Fri Jun 21 16:28:47 2013 +0200 @@ -136,22 +136,84 @@ return rivers2officialLines; } + public static final Range MAX_RANGE = new Range(-Double.MAX_VALUE, +Double.MAX_VALUE); + + private static final String nn(String s) { + return s != null ? s : ""; + } + + public static Range extractRange(D4EArtifact artifact) { + String mode = nn(artifact.getDataAsString("ld_mode")); + String locations = nn(artifact.getDataAsString("ld_locations")); + String from = nn(artifact.getDataAsString("ld_from")); + String to = nn(artifact.getDataAsString("ld_to")); + + if (mode.equals("location")) { + try { + String loc = locations.replace(" ", ""); + String[] split = loc.split(","); + if (split.length < 1) { + return MAX_RANGE; + } + double min = Double.parseDouble(split[0]); + double max = min; + for (int i = 1; i < split.length; ++i) { + double v = Double.parseDouble(split[i]); + if (v > max) max = v; + if (v < min) min = v; + } + return new Range(min, max); + } + catch (NumberFormatException nfe) { + return MAX_RANGE; + } + } + try { + return new Range(Double.parseDouble(from), Double.parseDouble(to)); + } + catch (NumberFormatException nfe) { + return MAX_RANGE; + } + } + + private static List<ValueRange> filterByRange(Range range, List<ValueRange> ranges) { + List<ValueRange> list = new ArrayList<ValueRange>(ranges.size()); + for (ValueRange r: ranges) { + if (r.intersects(range)) { + list.add(r); + } + } + return list; + } + + private static boolean isQ(D4EArtifact artifact) { + Boolean b = artifact.getDataAsBoolean("wq_isq"); + return b != null && b; + } + public static List<OfficialLine> findOfficialLines(D4EArtifact artifact) { + if (!isQ(artifact)) { // Only handle Q calculations + return Collections.<OfficialLine>emptyList(); + } + Map<String, List<ValueRange>> rivers2officialLines = getAll(); - String riverName = artifact.getDataAsString("river"); + String riverName = nn(artifact.getDataAsString("river")); - if (riverName == null) { + List<ValueRange> ranges = rivers2officialLines.get(riverName); + + if (ranges == null) { return Collections.<OfficialLine>emptyList(); } - List<ValueRange> ranges = rivers2officialLines.get(riverName); + ranges = filterByRange(extractRange(artifact), ranges); if (ranges.isEmpty()) { return Collections.<OfficialLine>emptyList(); } + // TODO: Figure out all the cases here. return Collections.<OfficialLine>emptyList();