Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/WWQQ.java @ 5622:b28a6d05e969
Add a new mechanism in mapfish print call to add arbitary data maps
Data properties are identified by starting with mapfish-data
and they are then split in info value pairs where info
can be the description of the information and value the value
of the information to be transported in the data map.
author | Andre Heinecke <aheinecke@intevation.de> |
---|---|
date | Tue, 09 Apr 2013 19:04:32 +0200 |
parents | bcf25d8c183e |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.model; import de.intevation.flys.artifacts.math.Identity; import de.intevation.flys.utils.DoubleUtil; import gnu.trove.TDoubleArrayList; public class WWQQ extends WW { public static class ApplyFunctionIterator extends WW.ApplyFunctionIterator { public ApplyFunctionIterator(WWQQ ww) { super(ww, Identity.IDENTITY, Identity.IDENTITY); } @Override public void get(int idx, double [] wwqqPair) { WWQQ wwqq = (WWQQ)ww; wwqqPair[0] = function1.value(wwqq.getW(idx)); wwqqPair[1] = function2.value(wwqq.getW2(idx)); wwqqPair[2] = wwqq.getQ1(idx); wwqqPair[3] = wwqq.getQ2(idx); } } // class ApplyFunctionIterator protected TDoubleArrayList qs1; protected TDoubleArrayList qs2; public WWQQ() { this(""); } public WWQQ(String name) { super(name); } public WWQQ(int capacity) { this(capacity, ""); } public WWQQ(int capacity, String name) { super(capacity, name); } public WWQQ( String name, double startKm, Double startDatum, double [] ws1, double [] qs1, double endKm, Double endDatum, double [] ws2, double [] qs2 ) { super(name, startKm, startDatum, ws1, endKm, endDatum, ws2); this.qs1 = new TDoubleArrayList(qs1); this.qs2 = new TDoubleArrayList(qs2); } public double getQ1(int idx) { return qs1.getQuick(idx); } public double getQ2(int idx) { return qs2.getQuick(idx); } public double [] getQs1() { return qs1.toNativeArray(); } public double [] getQs2() { return qs2.toNativeArray(); } @Override public double [] get(int idx) { return get(idx, new double[4]); } @Override public double [] get(int idx, double [] dst) { dst[0] = ws .getQuick(idx); dst[1] = ws2.getQuick(idx); dst[2] = qs1.getQuick(idx); dst[3] = qs2.getQuick(idx); return dst; } @Override public void removeNaNs() { DoubleUtil.removeNaNs(new TDoubleArrayList [] { ws, ws2, qs1, qs2 }); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :