changeset 8705:682a26e4158b

(issue1787) Globally sorting WST-columns over avg(Q)+max(Q) might give unexpected results at some kms. We thus sort locally since Rev 93a31cfb18c0.
author Tom Gottfried <tom@intevation.de>
date Thu, 23 Apr 2015 19:20:40 +0200 (2015-04-23)
parents 93a31cfb18c0
children 94cddb00f934
files artifacts/src/main/java/org/dive4elements/river/artifacts/model/QRangeTree.java artifacts/src/main/java/org/dive4elements/river/artifacts/model/WstValueTableFactory.java
diffstat 2 files changed, 8 insertions(+), 70 deletions(-) [+]
line wrap: on
line diff
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/model/QRangeTree.java	Thu Apr 23 19:13:33 2015 +0200
+++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/model/QRangeTree.java	Thu Apr 23 19:20:40 2015 +0200
@@ -278,16 +278,6 @@
         return parent;
     }
 
-    public double averageQ() {
-        double sum = 0d;
-        int n = 0;
-        for (Node node = head(); node != null; node = node.next) {
-            sum += node.q;
-            ++n;
-        }
-        return sum/n;
-    }
-
     public double maxQ() {
         double max = -Double.MAX_VALUE;
         for (Node node = head(); node != null; node = node.next) {
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/model/WstValueTableFactory.java	Thu Apr 23 19:13:33 2015 +0200
+++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/model/WstValueTableFactory.java	Thu Apr 23 19:20:40 2015 +0200
@@ -106,8 +106,8 @@
         // Fetch data for one column only.
 
         WstValueTable.Column [] columns = loadColumns(session, wst_id);
-        int [] map = loadQRangesMap(session, columns, wst_id);
-        List<WstValueTable.Row> rows = loadRows(session, wst_id, columns.length, map);
+        loadQRanges(session, columns, wst_id);
+        List<WstValueTable.Row> rows = loadRows(session, wst_id, columns.length);
 
         WstValueTable valueTable = new WstValueTable(columns, rows);
 
@@ -212,10 +212,9 @@
 
         WstValueTable.Column [] columns = loadColumns(session, wst);
 
-        int map [] = loadQRangesMap(session, columns, wst);
+        loadQRanges(session, columns, wst);
 
-        List<WstValueTable.Row> rows =
-            loadRows(session, wst.getId(), columns.length, map);
+        List<WstValueTable.Row> rows = loadRows(session, wst, columns.length);
 
         return new WstValueTable(columns, rows);
     }
@@ -283,15 +282,6 @@
         int     wst_id,
         int     numColumns
     ) {
-        return loadRows(session, wst_id, numColumns, null);
-    }
-
-    protected static List<WstValueTable.Row> loadRows(
-        Session session,
-        int     wst_id,
-        int     numColumns,
-        int []  map
-    ) {
         SQLQuery sqlQuery = session.createSQLQuery(SQL_SELECT_WS)
             .addScalar("km",         StandardBasicTypes.DOUBLE)
             .addScalar("w",          StandardBasicTypes.DOUBLE)
@@ -316,8 +306,7 @@
                 rows.add(row);
             }
             Double w = (Double)result[1];
-            int index = map != null ? map[column] : column;
-            ws[index] = w != null ? w : Double.NaN;
+            ws[column] = w != null ? w : Double.NaN;
             lastColumn = column;
         }
 
@@ -406,7 +395,7 @@
         columns[0].setQRangeTree(qRangeTree);
     }
 
-    protected static int [] loadQRangesMap(
+    protected static void loadQRanges(
         Session                 session,
         WstValueTable.Column [] columns,
         int                     wst_id
@@ -445,8 +434,6 @@
             columns[lastColumn].setQRangeTree(qRangeTree);
         }
 
-        return sortColumnsByAverageQ(columns);
-
         /* This is debug code to visualize the q ranges trees
 
         java.io.PrintWriter out = null;
@@ -477,51 +464,12 @@
         */
     }
 
-    private static final class QIndex implements Comparable<QIndex> {
-        double q;
-        int    index;
-
-        QIndex(double q, int index) {
-            this.q     = q;
-            this.index = index;
-        }
-
-        @Override
-        public int compareTo(QIndex other) {
-            double diff = q - other.q;
-            if (diff < 0d) return -1;
-            if (diff > 0d) return +1;
-            return 0;
-        }
-    } // class QIndex
-
-    /** Ensure that the q colums are sorted in ascending order. */
-    protected static int [] sortColumnsByAverageQ(WstValueTable.Column [] columns) {
-        QIndex [] order = new QIndex[columns.length];
-        for (int i = 0; i < order.length; ++i) {
-            QRangeTree tree = columns[i].getQRangeTree();
-            double avg = tree.averageQ();
-            double max = tree.maxQ();
-            double q   = (avg+max)*0.5d;
-            order[i] = new QIndex(q, i);
-        }
-        Arrays.sort(order);
-        WstValueTable.Column [] copy = new WstValueTable.Column[order.length];
-        int [] map = new int[order.length];
-        for (int i = 0; i < copy.length; ++i) {
-            copy[i] = columns[order[i].index];
-            map[order[i].index] = i;
-        }
-        System.arraycopy(copy, 0, columns, 0, order.length);
-        return map;
-    }
-
-    protected static int [] loadQRangesMap(
+    protected static void loadQRanges(
         Session                 session,
         WstValueTable.Column [] columns,
         Wst                     wst
     ) {
-        return loadQRangesMap(session, columns, wst.getId());
+        loadQRanges(session, columns, wst.getId());
     }
 
 }

http://dive4elements.wald.intevation.org