Package org.apache.lucene.util
Class BitUtil
java.lang.Object
org.apache.lucene.util.BitUtil
A variety of high efficiency bit twiddling routines.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final longprivate static final longprivate static final longprivate static final longprivate static final longprivate static final longprivate static final longprivate static final longprivate static final longprivate static final longprivate static final longprivate static final long -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic longdeinterleave(long b) Extract just the even-bits value as a long from the bit-interleaved valuestatic longflipFlop(long b) flip flops odd with even bitsstatic longinterleave(int even, int odd) Interleaves the first 32 bits of each long value Adapted from: http://graphics.stanford.edu/~seander/bithacks.html#InterleaveBMNstatic intnextHighestPowerOfTwo(int v) returns the next highest power of two, or the current value if it's already a power of two or zerostatic longnextHighestPowerOfTwo(long v) returns the next highest power of two, or the current value if it's already a power of two or zerostatic longpop_andnot(long[] arr1, long[] arr2, int wordOffset, int numWords) Returns the popcount or cardinality ofA & ~B.static longpop_array(long[] arr, int wordOffset, int numWords) Returns the number of set bits in an array of longs.static longpop_intersect(long[] arr1, long[] arr2, int wordOffset, int numWords) Returns the popcount or cardinality of the two sets after an intersection.static longpop_union(long[] arr1, long[] arr2, int wordOffset, int numWords) Returns the popcount or cardinality of the union of two sets.static longpop_xor(long[] arr1, long[] arr2, int wordOffset, int numWords) Returns the popcount or cardinality of A ^ B Neither array is modified.static intzigZagDecode(int i) Decode an int previously encoded withzigZagEncode(int).static longzigZagDecode(long l) Decode a long previously encoded withzigZagEncode(long).static intzigZagEncode(int i) Same aszigZagEncode(long)but on integers.static longzigZagEncode(long l) Zig-zag encode the provided long.
-
Field Details
-
MAGIC0
private static final long MAGIC0- See Also:
-
MAGIC1
private static final long MAGIC1- See Also:
-
MAGIC2
private static final long MAGIC2- See Also:
-
MAGIC3
private static final long MAGIC3- See Also:
-
MAGIC4
private static final long MAGIC4- See Also:
-
MAGIC5
private static final long MAGIC5- See Also:
-
MAGIC6
private static final long MAGIC6- See Also:
-
SHIFT0
private static final long SHIFT0- See Also:
-
SHIFT1
private static final long SHIFT1- See Also:
-
SHIFT2
private static final long SHIFT2- See Also:
-
SHIFT3
private static final long SHIFT3- See Also:
-
SHIFT4
private static final long SHIFT4- See Also:
-
-
Constructor Details
-
BitUtil
private BitUtil()
-
-
Method Details
-
pop_array
public static long pop_array(long[] arr, int wordOffset, int numWords) Returns the number of set bits in an array of longs. -
pop_intersect
public static long pop_intersect(long[] arr1, long[] arr2, int wordOffset, int numWords) Returns the popcount or cardinality of the two sets after an intersection. Neither array is modified. -
pop_union
public static long pop_union(long[] arr1, long[] arr2, int wordOffset, int numWords) Returns the popcount or cardinality of the union of two sets. Neither array is modified. -
pop_andnot
public static long pop_andnot(long[] arr1, long[] arr2, int wordOffset, int numWords) Returns the popcount or cardinality ofA & ~B. Neither array is modified. -
pop_xor
public static long pop_xor(long[] arr1, long[] arr2, int wordOffset, int numWords) Returns the popcount or cardinality of A ^ B Neither array is modified. -
nextHighestPowerOfTwo
public static int nextHighestPowerOfTwo(int v) returns the next highest power of two, or the current value if it's already a power of two or zero -
nextHighestPowerOfTwo
public static long nextHighestPowerOfTwo(long v) returns the next highest power of two, or the current value if it's already a power of two or zero -
interleave
public static long interleave(int even, int odd) Interleaves the first 32 bits of each long value Adapted from: http://graphics.stanford.edu/~seander/bithacks.html#InterleaveBMN -
deinterleave
public static long deinterleave(long b) Extract just the even-bits value as a long from the bit-interleaved value -
flipFlop
public static long flipFlop(long b) flip flops odd with even bits -
zigZagEncode
public static int zigZagEncode(int i) Same aszigZagEncode(long)but on integers. -
zigZagEncode
public static long zigZagEncode(long l) Zig-zag encode the provided long. Assuming the input is a signed long whose absolute value can be stored on n bits, the returned value will be an unsigned long that can be stored on n+1 bits. -
zigZagDecode
public static int zigZagDecode(int i) Decode an int previously encoded withzigZagEncode(int). -
zigZagDecode
public static long zigZagDecode(long l) Decode a long previously encoded withzigZagEncode(long).
-