com.clican.pluto.dataprocess.dpl.function.impl.StandardDeviation.java Source code

Java tutorial

Introduction

Here is the source code for com.clican.pluto.dataprocess.dpl.function.impl.StandardDeviation.java

Source

/**
 * The Clican-Pluto software suit is Copyright 2009, Clican Company and individual contributors, and is licensed under the GNU LGPL.
 *
 * @author clican
 *
 */
package com.clican.pluto.dataprocess.dpl.function.impl;

import java.util.List;
import java.util.Map;

import org.apache.commons.math.stat.descriptive.moment.Variance;

import com.clican.pluto.dataprocess.dpl.parser.bean.PrefixAndSuffix;
import com.clican.pluto.dataprocess.exception.CalculationException;
import com.clican.pluto.dataprocess.exception.DplParseException;
import com.clican.pluto.dataprocess.exception.PrefixAndSuffixException;

/**
 * 
 * 
 * standardDeviation(double[] values)
 * 
 * 
 * 
 * standardDeviation * 365^(1/2)
 * 
 * values - ??
 * 
 * @author clican
 * 
 */
public class StandardDeviation extends BaseMultiRowFunction {

    protected PrefixAndSuffix valuePas;

    public Object calculate(List<Map<String, Object>> rowSet)
            throws CalculationException, PrefixAndSuffixException {
        if (rowSet.size() == 0) {
            throw new CalculationException("SharpeRatio??");
        }
        double[] values = new double[rowSet.size()];
        double sum = 0;
        for (int i = 0; i < rowSet.size(); i++) {
            Map<String, Object> row = rowSet.get(i);
            Double value = valuePas.getValue(row);
            values[i] = value;
            sum += value;
        }
        double avg = sum / rowSet.size();
        Variance var = new Variance(false);
        return Math.sqrt(var.evaluate(values, avg));
    }

    public void setParams(List<Object> params) throws DplParseException {
        super.setParams(params);
        valuePas = this.pasList.get(0);
    }

}

// $Id: StandardDeviation.java 12447 2010-05-13 11:55:06Z wei.zhang $