[MATH-906] Use NaNStrategy.FAILED as default in NaturalRanking.
git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@1411880 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
4577812519
commit
0073facaf9
|
@ -52,6 +52,9 @@ If the output is not quite correct, check for invisible trailing spaces!
|
||||||
<body>
|
<body>
|
||||||
<release version="3.1" date="TBD" description="
|
<release version="3.1" date="TBD" description="
|
||||||
">
|
">
|
||||||
|
<action dev="tn" type="update" issue="MATH-906" due-to="Patrick Meyer">
|
||||||
|
Use "NaNStrategy#FAILED" as default strategy in "NaturalRanking".
|
||||||
|
</action>
|
||||||
<action dev="erans" type="add" issue="MATH-899">
|
<action dev="erans" type="add" issue="MATH-899">
|
||||||
Added a new "SynchronizedRandomGenerator" that wraps another
|
Added a new "SynchronizedRandomGenerator" that wraps another
|
||||||
"RandomGenerator" with all methods being synchronized, thus
|
"RandomGenerator" with all methods being synchronized, thus
|
||||||
|
|
|
@ -35,7 +35,7 @@ import org.apache.commons.math3.util.FastMath;
|
||||||
* <p>NaNs are treated according to the configured {@link NaNStrategy} and ties
|
* <p>NaNs are treated according to the configured {@link NaNStrategy} and ties
|
||||||
* are handled using the selected {@link TiesStrategy}.
|
* are handled using the selected {@link TiesStrategy}.
|
||||||
* Configuration settings are supplied in optional constructor arguments.
|
* Configuration settings are supplied in optional constructor arguments.
|
||||||
* Defaults are {@link NaNStrategy#MAXIMAL} and {@link TiesStrategy#AVERAGE},
|
* Defaults are {@link NaNStrategy#FAILED} and {@link TiesStrategy#AVERAGE},
|
||||||
* respectively. When using {@link TiesStrategy#RANDOM}, a
|
* respectively. When using {@link TiesStrategy#RANDOM}, a
|
||||||
* {@link RandomGenerator} may be supplied as a constructor argument.</p>
|
* {@link RandomGenerator} may be supplied as a constructor argument.</p>
|
||||||
* <p>Examples:
|
* <p>Examples:
|
||||||
|
@ -72,7 +72,7 @@ import org.apache.commons.math3.util.FastMath;
|
||||||
public class NaturalRanking implements RankingAlgorithm {
|
public class NaturalRanking implements RankingAlgorithm {
|
||||||
|
|
||||||
/** default NaN strategy */
|
/** default NaN strategy */
|
||||||
public static final NaNStrategy DEFAULT_NAN_STRATEGY = NaNStrategy.MAXIMAL;
|
public static final NaNStrategy DEFAULT_NAN_STRATEGY = NaNStrategy.FAILED;
|
||||||
|
|
||||||
/** default ties strategy */
|
/** default ties strategy */
|
||||||
public static final TiesStrategy DEFAULT_TIES_STRATEGY = TiesStrategy.AVERAGE;
|
public static final TiesStrategy DEFAULT_TIES_STRATEGY = TiesStrategy.AVERAGE;
|
||||||
|
|
|
@ -16,6 +16,8 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.commons.math3.stat.ranking;
|
package org.apache.commons.math3.stat.ranking;
|
||||||
|
|
||||||
|
import junit.framework.Assert;
|
||||||
|
|
||||||
import org.apache.commons.math3.TestUtils;
|
import org.apache.commons.math3.TestUtils;
|
||||||
import org.apache.commons.math3.exception.NotANumberException;
|
import org.apache.commons.math3.exception.NotANumberException;
|
||||||
import org.apache.commons.math3.random.JDKRandomGenerator;
|
import org.apache.commons.math3.random.JDKRandomGenerator;
|
||||||
|
@ -40,20 +42,31 @@ public class NaturalRankingTest {
|
||||||
private final double[] allSame = { 0, 0, 0, 0 };
|
private final double[] allSame = { 0, 0, 0, 0 };
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testDefault() { // Ties averaged, NaNs maximal
|
public void testDefault() { // Ties averaged, NaNs failed
|
||||||
NaturalRanking ranking = new NaturalRanking();
|
NaturalRanking ranking = new NaturalRanking();
|
||||||
double[] ranks = ranking.rank(exampleData);
|
double[] ranks;
|
||||||
double[] correctRanks = { 5, 3, 6, 7, 3, 8, 9, 1, 3 };
|
|
||||||
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
try {
|
||||||
|
ranks = ranking.rank(exampleData);
|
||||||
|
Assert.fail("expected NotANumberException due to NaNStrategy.FAILED");
|
||||||
|
} catch (NotANumberException e) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
|
||||||
ranks = ranking.rank(tiesFirst);
|
ranks = ranking.rank(tiesFirst);
|
||||||
correctRanks = new double[] { 1.5, 1.5, 4, 3, 5 };
|
double[] correctRanks = new double[] { 1.5, 1.5, 4, 3, 5 };
|
||||||
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
||||||
ranks = ranking.rank(tiesLast);
|
ranks = ranking.rank(tiesLast);
|
||||||
correctRanks = new double[] { 3.5, 3.5, 2, 1 };
|
correctRanks = new double[] { 3.5, 3.5, 2, 1 };
|
||||||
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
||||||
|
|
||||||
|
try {
|
||||||
ranks = ranking.rank(multipleNaNs);
|
ranks = ranking.rank(multipleNaNs);
|
||||||
correctRanks = new double[] { 1, 2, 3.5, 3.5 };
|
Assert.fail("expected NotANumberException due to NaNStrategy.FAILED");
|
||||||
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
} catch (NotANumberException e) {
|
||||||
|
// expected
|
||||||
|
}
|
||||||
|
|
||||||
ranks = ranking.rank(multipleTies);
|
ranks = ranking.rank(multipleTies);
|
||||||
correctRanks = new double[] { 3, 2, 4.5, 4.5, 6.5, 6.5, 1 };
|
correctRanks = new double[] { 3, 2, 4.5, 4.5, 6.5, 6.5, 1 };
|
||||||
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
||||||
|
@ -64,7 +77,7 @@ public class NaturalRankingTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNaNsMaximalTiesMinimum() {
|
public void testNaNsMaximalTiesMinimum() {
|
||||||
NaturalRanking ranking = new NaturalRanking(TiesStrategy.MINIMUM);
|
NaturalRanking ranking = new NaturalRanking(NaNStrategy.MAXIMAL, TiesStrategy.MINIMUM);
|
||||||
double[] ranks = ranking.rank(exampleData);
|
double[] ranks = ranking.rank(exampleData);
|
||||||
double[] correctRanks = { 5, 2, 6, 7, 2, 8, 9, 1, 2 };
|
double[] correctRanks = { 5, 2, 6, 7, 2, 8, 9, 1, 2 };
|
||||||
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
TestUtils.assertEquals(correctRanks, ranks, 0d);
|
||||||
|
|
Loading…
Reference in New Issue