Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/Parameters.java @ 3045:0905d1e7b37e
Fix certain GaugeDischargeArtifact issues.
flys-artifacts/trunk@4614 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Felix Wolfsteller <felix.wolfsteller@intevation.de> |
---|---|
date | Wed, 06 Jun 2012 15:46:49 +0000 |
parents | 52aac4941d2a |
children | 0b5a7a2c3724 |
line wrap: on
line source
package de.intevation.flys.artifacts.model; import gnu.trove.TDoubleArrayList; import java.io.Serializable; import org.apache.log4j.Logger; public class Parameters implements Serializable { private static Logger log = Logger.getLogger(Parameters.class); protected String [] columnNames; protected TDoubleArrayList [] columns; public Parameters() { } public Parameters(String [] columnNames) { if (columnNames == null || columnNames.length < 1) { throw new IllegalArgumentException("columnNames too short."); } this.columnNames = columnNames; columns = new TDoubleArrayList[columnNames.length]; for (int i = 0; i < columns.length; ++i) { columns[i] = new TDoubleArrayList(); } } public int columnIndex(String name) { for (int i = 0; i < columnNames.length; ++i) { if (columnNames[i].equals(name)) { return i; } } return -1; } public int newRow() { int N = columns[0].size(); for (int i = 0; i < columns.length; ++i) { columns[i].add(Double.NaN); } return N; } public double get(int row, int index) { return columns[index].getQuick(row); } public double get(int i, String columnName) { int index = columnIndex(columnName); return index >= 0 ? columns[index].getQuick(i) : Double.NaN; } public void set(int row, int index, double value) { columns[index].setQuick(row, value); } public void set(int i, String columnName, double value) { int idx = columnIndex(columnName); if (idx >= 0) { columns[idx].setQuick(i, value); } } public boolean set(int row, int [] indices, double [] values) { boolean invalid = false; for (int i = 0; i < indices.length; ++i) { double v = values[i]; if (Double.isNaN(v)) { invalid = true; } else { columns[indices[i]].setQuick(row, v); } } return invalid; } public int size() { return columns[0].size(); } public int getNumberColumns() { return columnNames.length; } public String [] getColumnNames() { return columnNames; } public void removeNaNs() { W.removeNaNs(columns); } public int [] columnIndices(String [] columns) { int [] indices = new int[columns.length]; for (int i = 0; i < columns.length; ++i) { indices[i] = columnIndex(columns[i]); } return indices; } public void get(int row, int [] columnIndices, double [] values) { for (int i = 0; i < columnIndices.length; ++i) { int index = columnIndices[i]; values[i] = index >= 0 && index < columns.length ? columns[index].getQuick(row) : Double.NaN; } } public int binarySearch(String columnName, double value) { return binarySearch(columnIndex(columnName), value); } public int binarySearch(int columnIndex, double value) { TDoubleArrayList column = columns[columnIndex]; return column.binarySearch(value); } public int binarySearch(String columnName, double value, double epsilon) { return binarySearch(columnIndex(columnName), value, epsilon); } public int binarySearch(int columnIndex, double value, double epsilon) { if (epsilon < 0d) epsilon = -epsilon; double vl = value - epsilon; double vh = value + epsilon; TDoubleArrayList column = columns[columnIndex]; int lo = 0, hi = column.size()-1; while (hi >= lo) { int mid = (lo+hi) >> 1; double v = column.getQuick(mid); if (v < vl) hi = mid - 1; else if (v > vh) lo = mid + 1; else return mid; } return -1; } public boolean isSorted(String columnName) { return isSorted(columnIndex(columnName)); } public boolean isSorted(int columnIndex) { TDoubleArrayList column = columns[columnIndex]; for (int i = 1, N = column.size(); i < N; ++i) { if (column.getQuick(i-1) > column.getQuick(i)) { return false; } } return true; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :