Package org.apache.lucene.util.packed
Class MonotonicBlockPackedWriter
java.lang.Object
org.apache.lucene.util.packed.MonotonicBlockPackedWriter
A writer for large monotonically increasing sequences of positive longs.
 
The sequence is divided into fixed-size blocks and for each block, values are modeled after a linear function f: x → A × x + B. The block encodes deltas from the expected values computed from this function using as few bits as possible.
Format:
- <BLock>BlockCount
- BlockCount: ⌈ ValueCount / BlockSize ⌉
- Block: <Header, (Ints)>
- Header: <B, A, BitsPerValue>
- B: the B from f: x → A × x + B using a zig-zag encodedvLong
- A: the A from f: x → A × x + B encoded using Float.floatToIntBits(float)on4 bytes
- BitsPerValue: a variable-length int
- Ints: if BitsPerValue is 0, then there is nothing to read and all values perfectly match the result of the function. Otherwise, these are thepackeddeltas from the expected value (computed from the function) using exactly BitsPerValue bits per value.
- See Also:
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidadd(long l) Append a new long.voidfinish()Flush all buffered data to disk.protected voidflush()longord()Return the number of values which have been added.voidreset(DataOutput out) Reset this writer to wrapout.protected final voidwriteValues(int bitsRequired) 
- 
Field Details- 
out
- 
valuesprotected final long[] values
- 
blocksprotected byte[] blocks
- 
offprotected int off
- 
ordprotected long ord
- 
finishedprotected boolean finished
 
- 
- 
Constructor Details- 
MonotonicBlockPackedWriterSole constructor.- Parameters:
- blockSize- the number of values of a single block, must be a power of 2
 
 
- 
- 
Method Details- 
addAppend a new long.- Throws:
- IOException
 
- 
flush- Throws:
- IOException
 
- 
resetReset this writer to wrapout. The block size remains unchanged.
- 
finishFlush all buffered data to disk. This instance is not usable anymore after this method has been called untilreset(DataOutput)has been called.- Throws:
- IOException
 
- 
ordpublic long ord()Return the number of values which have been added.
- 
writeValues- Throws:
- IOException
 
 
-