class Orc::RunLengthIntegerReaderV2
- Orc::RunLengthIntegerReaderV2
- Reference
- Object
Overview
The first byte of each group of values is a header that determines whether it is a run (value between 0 to 127) or literal list (value between -128 to -1). For runs, the control byte is the length of the run minus the length of the minimal run (3) and the control byte for literal lists is the negative length of the list. For example, a hundred 0’s is encoded as [0x61, 0x00] and the sequence 0x44, 0x45 would be encoded as [0xfe, 0x44, 0x45]. The next group can choose either of the encodings.
Included Modules
- Iterator(Int64)
Defined in:
orc/run_length_integer_reader_v2.crConstant Summary
-
MIN_REPEAT_SIZE =
3
Constructors
Instance Method Summary
- #bytes_to_big_endian(bytes : Bytes, size : Int32) : Int64
- #decode_width(encoded_width : UInt64)
- #has_next?
-
#next
Returns the next element in this iterator, or
Iterator::Stop::INSTANCE
if there are no more elements. - #read
- #read_direct(first_byte : UInt8)
- #read_ints(offset, length, width)
- #read_long_be(start, num_hops, num_bytes)
- #read_long_be2(read_buffer : Bytes, offset)
- #read_long_be8(read_buffer : Bytes, offset)
- #read_remaining_longs(offset, remainder, num_bytes)
- #read_short_repeat(first_byte : UInt8)
- #unpack_rolled_bytes(offset, length, num_bytes)
- #zigzag_decode(value : Int64)
Constructor Detail
Instance Method Detail
def next
#
Description copied from module Iterator(Int64)
Returns the next element in this iterator, or Iterator::Stop::INSTANCE
if there
are no more elements.