Пример #1
0
 public void testLog2Ceiling() {
   for (BigInteger x : POSITIVE_BIGINTEGER_CANDIDATES) {
     for (RoundingMode mode : asList(CEILING, UP)) {
       int result = BigIntegerMath.log2(x, mode);
       assertTrue(ZERO.setBit(result).compareTo(x) >= 0);
       assertTrue(result == 0 || ZERO.setBit(result - 1).compareTo(x) < 0);
     }
   }
 }
Пример #2
0
 public void testLog2Floor() {
   for (BigInteger x : POSITIVE_BIGINTEGER_CANDIDATES) {
     for (RoundingMode mode : asList(FLOOR, DOWN)) {
       int result = BigIntegerMath.log2(x, mode);
       assertTrue(ZERO.setBit(result).compareTo(x) <= 0);
       assertTrue(ZERO.setBit(result + 1).compareTo(x) > 0);
     }
   }
 }
Пример #3
0
 public void testLog2HalfDown() {
   for (BigInteger x : POSITIVE_BIGINTEGER_CANDIDATES) {
     int result = BigIntegerMath.log2(x, HALF_DOWN);
     BigInteger x2 = x.pow(2);
     // x^2 <= 2^(2 * result + 1), or else we would have rounded up
     assertTrue(ZERO.setBit(2 * result + 1).compareTo(x2) >= 0);
     // x^2 > 2^(2 * result - 1), or else we would have rounded down
     assertTrue(result == 0 || ZERO.setBit(2 * result - 1).compareTo(x2) < 0);
   }
 }
Пример #4
0
 // Relies on the correctness of isPowerOfTwo(BigInteger).
 public void testLog2Exact() {
   for (BigInteger x : POSITIVE_BIGINTEGER_CANDIDATES) {
     // We only expect an exception if x was not a power of 2.
     boolean isPowerOf2 = BigIntegerMath.isPowerOfTwo(x);
     try {
       assertEquals(x, ZERO.setBit(BigIntegerMath.log2(x, UNNECESSARY)));
       assertTrue(isPowerOf2);
     } catch (ArithmeticException e) {
       assertFalse(isPowerOf2);
     }
   }
 }
Пример #5
0
 public static CellEnum fromNumber(int i) {
   return get(ZERO.getIndex() + i);
 }