All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.davidmoten.hilbert.Util Maven / Gradle / Ivy

The newest version!
package org.davidmoten.hilbert;

import java.util.Arrays;

final class Util {

    private Util() {
        // prevent instantiation
    }

    // visible for testing
    static void reverse(byte[] array) {
        if (array == null) {
            return;
        }
        int i = 0;
        int j = array.length - 1;
        byte tmp;
        while (j > i) {
            tmp = array[j];
            array[j] = array[i];
            array[i] = tmp;
            j--;
            i++;
        }
    }

    /**
     * Returns the least value x where min(a,b) <= x < max(a,b) and x has the
     * maximum number of trailing zeroes in its binary representation.
     * 
     * @param a
     *            first value
     * @param b
     *            second value
     * @return most significant (in terms of divisors of powers of 2) between a and
     *         b
     */
    static long mostSignificantBetween(long a, long b) {
        if (a > b) {
            return mostSignificantBetween(b, a);
        } else if (a == b) {
            return a;
        } else {
            long x = a == 0 ? 1 : a;
            int bit = 0;
            while (x < b) {
                if ((x & (1 << bit)) == 0) {
                    bit++;
                } else {
                    long y = x + (1 << bit);
                    if (y < b) {
                        bit++;
                        x = y;
                    } else {
                        break;
                    }
                }
            }
            return x;
        }
    }

    public static void zero(long[] x) {
        Arrays.fill(x, 0);
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy