Added test case to ensure permuting arrays changes hash.
git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/branches/MATH_2_0@719995 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
9b8d0da71a
commit
54a42c0024
|
@ -19,6 +19,7 @@ import junit.framework.Test;
|
||||||
import junit.framework.TestCase;
|
import junit.framework.TestCase;
|
||||||
import junit.framework.TestSuite;
|
import junit.framework.TestSuite;
|
||||||
|
|
||||||
|
import org.apache.commons.math.random.RandomDataImpl;
|
||||||
import org.apache.commons.math.TestUtils;
|
import org.apache.commons.math.TestUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -332,6 +333,35 @@ public final class MathUtilsTest extends TestCase {
|
||||||
MathUtils.hash(new double[] { 1d, 1d }));
|
MathUtils.hash(new double[] { 1d, 1d }));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make sure that permuted arrays do not hash to the same value.
|
||||||
|
*/
|
||||||
|
public void testPermutedArrayHash() {
|
||||||
|
double[] original = new double[10];
|
||||||
|
double[] permuted = new double[10];
|
||||||
|
RandomDataImpl random = new RandomDataImpl();
|
||||||
|
|
||||||
|
// Generate 10 distinct random values
|
||||||
|
for (int i = 0; i < 10; i++) {
|
||||||
|
original[i] = random.nextUniform((double)i + 0.5, (double)i + 0.75);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Generate a random permutation, making sure it is not the identity
|
||||||
|
boolean isIdentity = true;
|
||||||
|
do {
|
||||||
|
int[] permutation = random.nextPermutation(10, 10);
|
||||||
|
for (int i = 0; i < 10; i++) {
|
||||||
|
if (i != permutation[i]) {
|
||||||
|
isIdentity = false;
|
||||||
|
}
|
||||||
|
permuted[i] = original[permutation[i]];
|
||||||
|
}
|
||||||
|
} while (isIdentity);
|
||||||
|
|
||||||
|
// Verify that permuted array has different hash
|
||||||
|
assertFalse(MathUtils.hash(original) == MathUtils.hash(permuted));
|
||||||
|
}
|
||||||
|
|
||||||
public void testIndicatorByte() {
|
public void testIndicatorByte() {
|
||||||
assertEquals((byte)1, MathUtils.indicator((byte)2));
|
assertEquals((byte)1, MathUtils.indicator((byte)2));
|
||||||
assertEquals((byte)1, MathUtils.indicator((byte)0));
|
assertEquals((byte)1, MathUtils.indicator((byte)0));
|
||||||
|
|
Loading…
Reference in New Issue