Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/math/StdDevOutlier.java @ 5200:42bb6ff78d1b 2.9.11
Directly set the connectionInitSqls on the datasource
Somehow the factory fails to set the connectionInitSqls if
we add it to the dbcpProperties. So we now set it directly
author | Andre Heinecke <aheinecke@intevation.de> |
---|---|
date | Fri, 08 Mar 2013 11:48:33 +0100 |
parents | 846b0441f905 |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.math; import java.util.List; import org.apache.commons.math.stat.descriptive.moment.StandardDeviation; import org.apache.log4j.Logger; public class StdDevOutlier { public static final double DEFAULT_FACTOR = 3; private static Logger log = Logger.getLogger(StdDevOutlier.class); protected StdDevOutlier() { } public static Integer findOutlier(List<Double> values) { return findOutlier(values, DEFAULT_FACTOR, null); } public static Integer findOutlier( List<Double> values, double factor, double [] stdDevResult ) { boolean debug = log.isDebugEnabled(); if (debug) { log.debug("factor for std dev: " + factor); } int N = values.size(); if (debug) { log.debug("Values to check: " + N); } if (N < 3) { return null; } StandardDeviation stdDev = new StandardDeviation(); double maxValue = -Double.MAX_VALUE; int maxIndex = -1; for (int i = N-1; i >= 0; --i) { double value = Math.abs(values.get(i)); stdDev.increment(value); if (value > maxValue) { maxValue = value; maxIndex = i; } } double sd = stdDev.getResult(); double accepted = factor * sd; if (debug) { log.debug("std dev: " + stdDev); log.debug("accepted: " + accepted); log.debug("max value: " + maxValue); } if (stdDevResult != null) { stdDevResult[0] = sd; } return maxValue > accepted ? maxIndex : null; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :