Class PackedInts
>= 0 and 
 <= a specified maximum value. The values are stored as packed ints, with each value consuming a
 fixed number of bits.- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic interfaceA decoder for packed integers.static interfaceAn encoder for packed integers.static enumA format to write packed ints.static final recordSimple class that holds a format and a number of bits per value.static classA packed integer array that can be modified.static final classAPackedInts.Readerwhich has all its values equal to 0 (bitsPerValue = 0).static classA read-only random access array of positive integers.static interfaceRun-once iterator interface, to decode previously saved PackedInts.static classA write-once Writer.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final Stringstatic final floatNo memory overhead at all, but the returned implementation may be slow.static final floatAt most 25% memory overhead.static final intDefault amount of memory to use for bulk operations.static final floatAt most 50% memory overhead, always select a reasonably fast implementation.static final floatAt most 700% memory overhead, always select a direct implementation.static final intstatic final intstatic final int
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic intbitsRequired(long maxValue) Returns how many bits are required to hold values up to and including maxValue NOTE: This method returns at least 1.static voidcheckVersion(int version) Check the validity of a version number.static voidcopy(PackedInts.Reader src, int srcPos, PackedInts.Mutable dest, int destPos, int len, int mem) Copysrc[srcPos:srcPos+len]intodest[destPos:destPos+len]using at mostmembytes.static PackedInts.FormatAndBitsfastestFormatAndBits(int valueCount, int bitsPerValue, float acceptableOverheadRatio) Try to find thePackedInts.Formatand number of bits per value that would restore from disk the fastest reader whose overhead is less thanacceptableOverheadRatio.static PackedInts.DecodergetDecoder(PackedInts.Format format, int version, int bitsPerValue) Get aPackedInts.Decoder.static PackedInts.EncodergetEncoder(PackedInts.Format format, int version, int bitsPerValue) Get anPackedInts.Encoder.static PackedInts.MutablegetMutable(int valueCount, int bitsPerValue, float acceptableOverheadRatio) Create a packed integer array with the given amount of values initialized to 0.static PackedInts.MutablegetMutable(int valueCount, int bitsPerValue, PackedInts.Format format) Same asgetMutable(int, int, float)with a pre-computed number of bits per value and format.static PackedInts.ReaderIteratorgetReaderIteratorNoHeader(DataInput in, PackedInts.Format format, int version, int valueCount, int bitsPerValue, int mem) Expert: Restore aPackedInts.ReaderIteratorfrom a stream without reading metadata at the beginning of the stream.static PackedInts.WritergetWriterNoHeader(DataOutput out, PackedInts.Format format, int valueCount, int bitsPerValue, int mem) Expert: Create a packed integer array writer for the given output, format, value count, and number of bits per value.static longmaxValue(int bitsPerValue) Calculates the maximum unsigned long that can be expressed with the given number of bits.static intunsignedBitsRequired(long bits) Returns how many bits are required to storebits, interpreted as an unsigned value.
- 
Field Details- 
FASTESTpublic static final float FASTESTAt most 700% memory overhead, always select a direct implementation.- See Also:
 
- 
FASTpublic static final float FASTAt most 50% memory overhead, always select a reasonably fast implementation.- See Also:
 
- 
DEFAULTpublic static final float DEFAULTAt most 25% memory overhead.- See Also:
 
- 
COMPACTpublic static final float COMPACTNo memory overhead at all, but the returned implementation may be slow.- See Also:
 
- 
DEFAULT_BUFFER_SIZEpublic static final int DEFAULT_BUFFER_SIZEDefault amount of memory to use for bulk operations.- See Also:
 
- 
CODEC_NAME- See Also:
 
- 
VERSION_MONOTONIC_WITHOUT_ZIGZAGpublic static final int VERSION_MONOTONIC_WITHOUT_ZIGZAG- See Also:
 
- 
VERSION_STARTpublic static final int VERSION_START- See Also:
 
- 
VERSION_CURRENTpublic static final int VERSION_CURRENT- See Also:
 
 
- 
- 
Constructor Details- 
PackedIntspublic PackedInts()
 
- 
- 
Method Details- 
checkVersionpublic static void checkVersion(int version) Check the validity of a version number.
- 
fastestFormatAndBitspublic static PackedInts.FormatAndBits fastestFormatAndBits(int valueCount, int bitsPerValue, float acceptableOverheadRatio) Try to find thePackedInts.Formatand number of bits per value that would restore from disk the fastest reader whose overhead is less thanacceptableOverheadRatio.The acceptableOverheadRatioparameter makes sense for random-accessPackedInts.Readers. In case you only plan to perform sequential access on this stream later on, you should probably useCOMPACT.If you don't know how many values you are going to write, use valueCount = -1.
- 
getDecoderpublic static PackedInts.Decoder getDecoder(PackedInts.Format format, int version, int bitsPerValue) Get aPackedInts.Decoder.- Parameters:
- format- the format used to store packed ints
- version- the compatibility version
- bitsPerValue- the number of bits per value
- Returns:
- a decoder
 
- 
getEncoderpublic static PackedInts.Encoder getEncoder(PackedInts.Format format, int version, int bitsPerValue) Get anPackedInts.Encoder.- Parameters:
- format- the format used to store packed ints
- version- the compatibility version
- bitsPerValue- the number of bits per value
- Returns:
- an encoder
 
- 
getReaderIteratorNoHeaderpublic static PackedInts.ReaderIterator getReaderIteratorNoHeader(DataInput in, PackedInts.Format format, int version, int valueCount, int bitsPerValue, int mem) Expert: Restore aPackedInts.ReaderIteratorfrom a stream without reading metadata at the beginning of the stream. This method is useful to restore data from streams which have been created usinggetWriterNoHeader(DataOutput, Format, int, int, int).- Parameters:
- in- the stream to read data from, positioned at the beginning of the packed values
- format- the format used to serialize
- version- the version used to serialize the data
- valueCount- how many values the stream holds
- bitsPerValue- the number of bits per value
- mem- how much memory the iterator is allowed to use to read-ahead (likely to speed up iteration)
- Returns:
- a ReaderIterator
- See Also:
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
getMutablepublic static PackedInts.Mutable getMutable(int valueCount, int bitsPerValue, float acceptableOverheadRatio) Create a packed integer array with the given amount of values initialized to 0. the valueCount and the bitsPerValue cannot be changed after creation. All Mutables known by this factory are kept fully in RAM.Positive values of acceptableOverheadRatiowill trade space for speed by selecting a faster but potentially less memory-efficient implementation. AnacceptableOverheadRatioofCOMPACTwill make sure that the most memory-efficient implementation is selected whereasFASTESTwill make sure that the fastest implementation is selected.- Parameters:
- valueCount- the number of elements
- bitsPerValue- the number of bits available for any given value
- acceptableOverheadRatio- an acceptable overhead ratio per value
- Returns:
- a mutable packed integer array
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
getMutablepublic static PackedInts.Mutable getMutable(int valueCount, int bitsPerValue, PackedInts.Format format) Same asgetMutable(int, int, float)with a pre-computed number of bits per value and format.- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
getWriterNoHeaderpublic static PackedInts.Writer getWriterNoHeader(DataOutput out, PackedInts.Format format, int valueCount, int bitsPerValue, int mem) Expert: Create a packed integer array writer for the given output, format, value count, and number of bits per value.The resulting stream will be long-aligned. This means that depending on the format which is used, up to 63 bits will be wasted. An easy way to make sure that no space is lost is to always use a valueCountthat is a multiple of 64.This method does not write any metadata to the stream, meaning that it is your responsibility to store it somewhere else in order to be able to recover data from the stream later on: - format(using- PackedInts.Format.getId()),
- valueCount,
- bitsPerValue,
- VERSION_CURRENT.
 It is possible to start writing values without knowing how many of them you are actually going to write. To do this, just pass -1asvalueCount. On the other hand, for any positive value ofvalueCount, the returned writer will make sure that you don't write more values than expected and pad the end of stream with zeros in case you have written less thanvalueCountwhen callingPackedInts.Writer.finish().The memparameter lets you control how much memory can be used to buffer changes in memory before flushing to disk. High values ofmemare likely to improve throughput. On the other hand, if speed is not that important to you, a value of0will use as little memory as possible and should already offer reasonable throughput.- Parameters:
- out- the data output
- format- the format to use to serialize the values
- valueCount- the number of values
- bitsPerValue- the number of bits per value
- mem- how much memory (in bytes) can be used to speed up serialization
- Returns:
- a Writer
- See Also:
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
bitsRequiredpublic static int bitsRequired(long maxValue) Returns how many bits are required to hold values up to and including maxValue NOTE: This method returns at least 1.- Parameters:
- maxValue- the maximum value that should be representable.
- Returns:
- the amount of bits needed to represent values from 0 to maxValue.
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
unsignedBitsRequiredpublic static int unsignedBitsRequired(long bits) Returns how many bits are required to storebits, interpreted as an unsigned value. NOTE: This method returns at least 1.- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
maxValuepublic static long maxValue(int bitsPerValue) Calculates the maximum unsigned long that can be expressed with the given number of bits.- Parameters:
- bitsPerValue- the number of bits available for any given value.
- Returns:
- the maximum value for the given bits.
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
copypublic static void copy(PackedInts.Reader src, int srcPos, PackedInts.Mutable dest, int destPos, int len, int mem) Copysrc[srcPos:srcPos+len]intodest[destPos:destPos+len]using at mostmembytes.
 
-