Package org.apache.lucene.util
Class BitUtil
- java.lang.Object
-
- org.apache.lucene.util.BitUtil
-
public final class BitUtil extends java.lang.ObjectA variety of high efficiency bit twiddling routines and encoders for primitives.
-
-
Field Summary
Fields Modifier and Type Field Description private static longMAGIC0private static longMAGIC1private static longMAGIC2private static longMAGIC3private static longMAGIC4private static longMAGIC5private static longMAGIC6private static longSHIFT0private static longSHIFT1private static longSHIFT2private static longSHIFT3private static longSHIFT4static java.lang.invoke.VarHandleVH_BE_DOUBLEDeprecated.Better use little endian unless it is needed for backwards compatibility.static java.lang.invoke.VarHandleVH_BE_FLOATDeprecated.Better use little endian unless it is needed for backwards compatibility.static java.lang.invoke.VarHandleVH_BE_INTDeprecated.Better use little endian unless it is needed for backwards compatibility.static java.lang.invoke.VarHandleVH_BE_LONGDeprecated.Better use little endian unless it is needed for backwards compatibility.static java.lang.invoke.VarHandleVH_BE_SHORTDeprecated.Better use little endian unless it is needed for backwards compatibility.static java.lang.invoke.VarHandleVH_LE_DOUBLEAVarHandleto read/write little endiandoublefrom a byte array.static java.lang.invoke.VarHandleVH_LE_FLOATAVarHandleto read/write little endianfloatfrom a byte array.static java.lang.invoke.VarHandleVH_LE_INTAVarHandleto read/write little endianintfrom a byte array.static java.lang.invoke.VarHandleVH_LE_LONGAVarHandleto read/write little endianlongfrom a byte array.static java.lang.invoke.VarHandleVH_LE_SHORTAVarHandleto read/write little endianshortfrom/to a byte array.
-
Constructor Summary
Constructors Modifier Constructor Description privateBitUtil()
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static 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 valuestatic 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 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 Detail
-
VH_LE_SHORT
public static final java.lang.invoke.VarHandle VH_LE_SHORT
AVarHandleto read/write little endianshortfrom/to a byte array. Shape:short vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, short val)
-
VH_LE_INT
public static final java.lang.invoke.VarHandle VH_LE_INT
AVarHandleto read/write little endianintfrom a byte array. Shape:int vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, int val)
-
VH_LE_LONG
public static final java.lang.invoke.VarHandle VH_LE_LONG
AVarHandleto read/write little endianlongfrom a byte array. Shape:long vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, long val)
-
VH_LE_FLOAT
public static final java.lang.invoke.VarHandle VH_LE_FLOAT
AVarHandleto read/write little endianfloatfrom a byte array. Shape:float vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, float val)
-
VH_LE_DOUBLE
public static final java.lang.invoke.VarHandle VH_LE_DOUBLE
AVarHandleto read/write little endiandoublefrom a byte array. Shape:double vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, double val)
-
VH_BE_SHORT
@Deprecated public static final java.lang.invoke.VarHandle VH_BE_SHORT
Deprecated.Better use little endian unless it is needed for backwards compatibility.AVarHandleto read/write big endianshortfrom a byte array. Shape:short vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, short val)
-
VH_BE_INT
@Deprecated public static final java.lang.invoke.VarHandle VH_BE_INT
Deprecated.Better use little endian unless it is needed for backwards compatibility.AVarHandleto read/write big endianintfrom a byte array. Shape:int vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, int val)
-
VH_BE_LONG
@Deprecated public static final java.lang.invoke.VarHandle VH_BE_LONG
Deprecated.Better use little endian unless it is needed for backwards compatibility.AVarHandleto read/write big endianlongfrom a byte array. Shape:long vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, long val)
-
VH_BE_FLOAT
@Deprecated public static final java.lang.invoke.VarHandle VH_BE_FLOAT
Deprecated.Better use little endian unless it is needed for backwards compatibility.AVarHandleto read/write big endianfloatfrom a byte array. Shape:float vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, float val)
-
VH_BE_DOUBLE
@Deprecated public static final java.lang.invoke.VarHandle VH_BE_DOUBLE
Deprecated.Better use little endian unless it is needed for backwards compatibility.AVarHandleto read/write big endiandoublefrom a byte array. Shape:double vh.get(byte[] arr, int ofs)andvoid vh.set(byte[] arr, int ofs, double val)
-
MAGIC0
private static final long MAGIC0
- See Also:
- Constant Field Values
-
MAGIC1
private static final long MAGIC1
- See Also:
- Constant Field Values
-
MAGIC2
private static final long MAGIC2
- See Also:
- Constant Field Values
-
MAGIC3
private static final long MAGIC3
- See Also:
- Constant Field Values
-
MAGIC4
private static final long MAGIC4
- See Also:
- Constant Field Values
-
MAGIC5
private static final long MAGIC5
- See Also:
- Constant Field Values
-
MAGIC6
private static final long MAGIC6
- See Also:
- Constant Field Values
-
SHIFT0
private static final long SHIFT0
- See Also:
- Constant Field Values
-
SHIFT1
private static final long SHIFT1
- See Also:
- Constant Field Values
-
SHIFT2
private static final long SHIFT2
- See Also:
- Constant Field Values
-
SHIFT3
private static final long SHIFT3
- See Also:
- Constant Field Values
-
SHIFT4
private static final long SHIFT4
- See Also:
- Constant Field Values
-
-
Method Detail
-
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 valueAdapted 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 onnbits, the returned value will be an unsigned long that can be stored onn+1bits.
-
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).
-
-