1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.apache.commons.math.stat.descriptive.rank;
18
19 import junit.framework.Test;
20 import junit.framework.TestSuite;
21
22 import org.apache.commons.math.stat.descriptive.StorelessUnivariateStatisticAbstractTest;
23 import org.apache.commons.math.stat.descriptive.UnivariateStatistic;
24
25
26
27
28
29 public class MinTest extends StorelessUnivariateStatisticAbstractTest{
30
31 protected Min stat;
32
33
34
35
36 public MinTest(String name) {
37 super(name);
38 }
39
40 public static Test suite() {
41 TestSuite suite = new TestSuite(MinTest.class);
42 suite.setName("Min Tests");
43 return suite;
44 }
45
46
47
48
49 @Override
50 public UnivariateStatistic getUnivariateStatistic() {
51 return new Min();
52 }
53
54
55
56
57 @Override
58 public double expectedValue() {
59 return this.min;
60 }
61
62 public void testSpecialValues() {
63 double[] testArray = {0d, Double.NaN, Double.POSITIVE_INFINITY,
64 Double.NEGATIVE_INFINITY};
65 Min min = new Min();
66 assertTrue(Double.isNaN(min.getResult()));
67 min.increment(testArray[0]);
68 assertEquals(0d, min.getResult(), 0);
69 min.increment(testArray[1]);
70 assertEquals(0d, min.getResult(), 0);
71 min.increment(testArray[2]);
72 assertEquals(0d, min.getResult(), 0);
73 min.increment(testArray[3]);
74 assertEquals(Double.NEGATIVE_INFINITY, min.getResult(), 0);
75 assertEquals(Double.NEGATIVE_INFINITY, min.evaluate(testArray), 0);
76 }
77
78 public void testNaNs() {
79 Min min = new Min();
80 double nan = Double.NaN;
81 assertEquals(2d, min.evaluate(new double[]{nan, 2d, 3d}), 0);
82 assertEquals(1d, min.evaluate(new double[]{1d, nan, 3d}), 0);
83 assertEquals(1d, min.evaluate(new double[]{1d, 2d, nan}), 0);
84 assertTrue(Double.isNaN(min.evaluate(new double[]{nan, nan, nan})));
85 }
86
87 }