001: /*
002: * Copyright 2003-2004 The Apache Software Foundation.
003: *
004: * Licensed under the Apache License, Version 2.0 (the "License");
005: * you may not use this file except in compliance with the License.
006: * You may obtain a copy of the License at
007: *
008: * http://www.apache.org/licenses/LICENSE-2.0
009: *
010: * Unless required by applicable law or agreed to in writing, software
011: * distributed under the License is distributed on an "AS IS" BASIS,
012: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013: * See the License for the specific language governing permissions and
014: * limitations under the License.
015: */
016: package org.apache.commons.math.stat.descriptive.moment;
017:
018: import junit.framework.Test;
019: import junit.framework.TestSuite;
020:
021: import org.apache.commons.math.stat.descriptive.StorelessUnivariateStatisticAbstractTest;
022: import org.apache.commons.math.stat.descriptive.UnivariateStatistic;
023:
024: /**
025: * Test cases for the {@link UnivariateStatistic} class.
026: *
027: * @version $Revision: 155427 $ $Date: 2005-02-26 06:11:52 -0700 (Sat, 26 Feb 2005) $
028: */
029: public class StandardDeviationTest extends
030: StorelessUnivariateStatisticAbstractTest {
031:
032: protected StandardDeviation stat;
033:
034: /**
035: * @param name
036: */
037: public StandardDeviationTest(String name) {
038: super (name);
039: }
040:
041: /* (non-Javadoc)
042: * @see org.apache.commons.math.stat.descriptive.UnivariateStatisticAbstractTest#getUnivariateStatistic()
043: */
044: public UnivariateStatistic getUnivariateStatistic() {
045: return new StandardDeviation();
046: }
047:
048: public static Test suite() {
049: TestSuite suite = new TestSuite(StandardDeviationTest.class);
050: suite.setName("StandardDeviation Tests");
051: return suite;
052: }
053:
054: /* (non-Javadoc)
055: * @see org.apache.commons.math.stat.descriptive.UnivariateStatisticAbstractTest#expectedValue()
056: */
057: public double expectedValue() {
058: return this .std;
059: }
060:
061: /**
062: * Make sure Double.NaN is returned iff n = 0
063: *
064: */
065: public void testNaN() {
066: StandardDeviation std = new StandardDeviation();
067: assertTrue(Double.isNaN(std.getResult()));
068: std.increment(1d);
069: assertEquals(0d, std.getResult(), 0);
070: }
071:
072: /**
073: * Test population version of variance
074: */
075: public void testPopulation() {
076: double[] values = { -1.0d, 3.1d, 4.0d, -2.1d, 22d, 11.7d, 3d,
077: 14d };
078: double sigma = populationStandardDeviation(values);
079: SecondMoment m = new SecondMoment();
080: m.evaluate(values); // side effect is to add values
081: StandardDeviation s1 = new StandardDeviation();
082: s1.setBiasCorrected(false);
083: assertEquals(sigma, s1.evaluate(values), 1E-14);
084: s1.incrementAll(values);
085: assertEquals(sigma, s1.getResult(), 1E-14);
086: s1 = new StandardDeviation(false, m);
087: assertEquals(sigma, s1.getResult(), 1E-14);
088: s1 = new StandardDeviation(false);
089: assertEquals(sigma, s1.evaluate(values), 1E-14);
090: s1.incrementAll(values);
091: assertEquals(sigma, s1.getResult(), 1E-14);
092: }
093:
094: /**
095: * Definitional formula for population standard deviation
096: */
097: protected double populationStandardDeviation(double[] v) {
098: double mean = new Mean().evaluate(v);
099: double sum = 0;
100: for (int i = 0; i < v.length; i++) {
101: sum += (v[i] - mean) * (v[i] - mean);
102: }
103: return Math.sqrt(sum / (double) v.length);
104: }
105:
106: }
|