pub struct BooleanBuffer {
buffer: Buffer,
bit_offset: usize,
bit_len: usize,
}Expand description
A slice-able Buffer containing bit-packed booleans
This structure represents a sequence of boolean values packed into a
byte-aligned Buffer. Both the offset and length are represented in bits.
§Layout
The values are represented as little endian bit-packed values, where the least significant bit of each byte represents the first boolean value and then proceeding to the most significant bit.
For example, the 10 bit bitmask 0b0111001101 has length 10, and is
represented using 2 bytes with offset 0 like this:
┌─────────────────────────────────┐ ┌─────────────────────────────────┐
│┌───┬───┬───┬───┬───┬───┬───┬───┐│ │┌───┬───┬───┬───┬───┬───┬───┬───┐│
││ 1 │ 0 │ 1 │ 1 │ 0 │ 0 │ 1 │ 1 ││ ││ 1 │ 0 │ ? │ ? │ ? │ ? │ ? │ ? ││
│└───┴───┴───┴───┴───┴───┴───┴───┘│ │└───┴───┴───┴───┴───┴───┴───┴───┘│
bit └─────────────────────────────────┘ └─────────────────────────────────┘
offset 0 Byte 0 7 0 Byte 1 7
length = 10 bits, offset = 0The same bitmask with length 10 and offset 3 would be represented using 2 bytes like this:
┌─────────────────────────────────┐ ┌─────────────────────────────────┐
│┌───┬───┬───┬───┬───┬───┬───┬───┐│ │┌───┬───┬───┬───┬───┬───┬───┬───┐│
││ ? │ ? │ ? │ 1 │ 0 │ 1 │ 1 │ 0 ││ ││ 0 │ 1 │ 1 │ 1 │ 0 │ ? │ ? │ ? ││
│└───┴───┴───┴───┴───┴───┴───┴───┘│ │└───┴───┴───┴───┴───┴───┴───┴───┘│
bit └─────────────────────────────────┘ └─────────────────────────────────┘
offset 0 Byte 0 7 0 Byte 1 7
length = 10 bits, offset = 3Note that the bits marked ? are not logically part of the mask and may
contain either 0 or 1
§See Also
BooleanBufferBuilderfor buildingBooleanBufferinstancesNullBufferfor representing null values in Arrow arrays
Fields§
§buffer: BufferUnderlying buffer (byte aligned)
bit_offset: usizeOffset in bits (not bytes)
bit_len: usizeLength in bits (not bytes)
Implementations§
Source§impl BooleanBuffer
impl BooleanBuffer
Sourcepub fn new(buffer: Buffer, bit_offset: usize, bit_len: usize) -> Self
pub fn new(buffer: Buffer, bit_offset: usize, bit_len: usize) -> Self
Create a new BooleanBuffer from a Buffer, bit_offset offset and bit_len length
§Panics
This method will panic if buffer is not large enough
Sourcepub fn new_set(length: usize) -> Self
pub fn new_set(length: usize) -> Self
Create a new BooleanBuffer of length bits (not bytes) where all values are true
Sourcepub fn new_unset(length: usize) -> Self
pub fn new_unset(length: usize) -> Self
Create a new BooleanBuffer of length bits (not bytes) where all values are false
Sourcepub fn collect_bool<F: FnMut(usize) -> bool>(len: usize, f: F) -> Self
pub fn collect_bool<F: FnMut(usize) -> bool>(len: usize, f: F) -> Self
Invokes f with indexes 0..len collecting the boolean results into a new BooleanBuffer
Sourcepub fn from_bits(
src: impl AsRef<[u8]>,
offset_in_bits: usize,
len_in_bits: usize,
) -> Self
pub fn from_bits( src: impl AsRef<[u8]>, offset_in_bits: usize, len_in_bits: usize, ) -> Self
Create a new BooleanBuffer by copying the relevant bits from an
input buffer.
§Notes:
- The new
BooleanBufferhas zero offset, even ifoffset_in_bitsis non-zero
§Example: Create a new BooleanBuffer copying a bit slice from in input slice
let input = [0b11001100u8, 0b10111010u8];
// // Copy bits 4..16 from input
let result = BooleanBuffer::from_bits(&input, 4, 12);
assert_eq!(result.values(), &[0b10101100u8, 0b00001011u8]);Sourcepub fn from_bitwise_unary_op<F>(
src: impl AsRef<[u8]>,
offset_in_bits: usize,
len_in_bits: usize,
op: F,
) -> Self
pub fn from_bitwise_unary_op<F>( src: impl AsRef<[u8]>, offset_in_bits: usize, len_in_bits: usize, op: F, ) -> Self
Create a new BooleanBuffer by applying the bitwise operation to op
to an input buffer.
This function is faster than applying the operation bit by bit as it processes input buffers in chunks of 64 bits (8 bytes) at a time
§Notes:
optakes a singleu64inputs and produces oneu64output.opmust only apply bitwise operations on the relevant bits; the inputu64may contain irrelevant bits and may be processed differently on different endian architectures.opmay be called with input bits outside the requested range- The output always has zero offset
§See Also
apply_bitwise_unary_opfor in-place unary bitwise operations
§Example: Create new BooleanBuffer from bitwise NOT of an input Buffer
let input = [0b11001100u8, 0b10111010u8]; // 2 bytes = 16 bits
// NOT of the first 12 bits
let result = BooleanBuffer::from_bitwise_unary_op(
&input, 0, 12, |a| !a
);
assert_eq!(result.values(), &[0b00110011u8, 0b11110101u8]);Sourcefn try_from_aligned_bitwise_unary_op<F>(
src: &[u8],
len_in_bits: usize,
op: &mut F,
) -> Option<Self>
fn try_from_aligned_bitwise_unary_op<F>( src: &[u8], len_in_bits: usize, op: &mut F, ) -> Option<Self>
Fast path for Self::from_bitwise_unary_op when input is aligned to
8-byte (64-bit) boundaries
Returns None if the fast path cannot be taken
Sourcepub fn count_set_bits(&self) -> usize
pub fn count_set_bits(&self) -> usize
Returns the number of set bits in this buffer
Sourcepub fn bit_chunks(&self) -> BitChunks<'_>
pub fn bit_chunks(&self) -> BitChunks<'_>
Returns a BitChunks instance which can be used to iterate over
this buffer’s bits in u64 chunks
Sourcepub fn offset(&self) -> usize
pub fn offset(&self) -> usize
Returns the offset of this BooleanBuffer in bits (not bytes)
Sourcepub fn len(&self) -> usize
pub fn len(&self) -> usize
Returns the length of this BooleanBuffer in bits (not bytes)
Sourcepub fn is_empty(&self) -> bool
pub fn is_empty(&self) -> bool
Returns true if this BooleanBuffer is empty
Sourcepub fn shrink_to_fit(&mut self)
pub fn shrink_to_fit(&mut self)
Free up unused memory.
Sourcepub unsafe fn value_unchecked(&self, i: usize) -> bool
pub unsafe fn value_unchecked(&self, i: usize) -> bool
Returns the boolean value at index i.
§Safety
This doesn’t check bounds, the caller must ensure that index < self.len()
Sourcepub fn values(&self) -> &[u8] ⓘ
pub fn values(&self) -> &[u8] ⓘ
Returns the packed values of this BooleanBuffer not including any offset
Sourcepub fn slice(&self, offset: usize, len: usize) -> Self
pub fn slice(&self, offset: usize, len: usize) -> Self
Slices this BooleanBuffer by the provided offset and length
Sourcepub fn sliced(&self) -> Buffer
pub fn sliced(&self) -> Buffer
Returns a Buffer containing the sliced contents of this BooleanBuffer
Equivalent to self.buffer.bit_slice(self.offset, self.len)
Sourcepub fn ptr_eq(&self, other: &Self) -> bool
pub fn ptr_eq(&self, other: &Self) -> bool
Returns true if this BooleanBuffer is equal to other, using pointer comparisons
to determine buffer equality. This is cheaper than PartialEq::eq but may
return false when the arrays are logically equal
Sourcepub fn inner(&self) -> &Buffer
pub fn inner(&self) -> &Buffer
Returns the inner Buffer
Note: this does not account for offset and length of this BooleanBuffer
Sourcepub fn into_inner(self) -> Buffer
pub fn into_inner(self) -> Buffer
Returns the inner Buffer, consuming self
Note: this does not account for offset and length of this BooleanBuffer
Sourcepub fn iter(&self) -> BitIterator<'_> ⓘ
pub fn iter(&self) -> BitIterator<'_> ⓘ
Returns an iterator over the bits in this BooleanBuffer
Sourcepub fn set_indices(&self) -> BitIndexIterator<'_> ⓘ
pub fn set_indices(&self) -> BitIndexIterator<'_> ⓘ
Returns an iterator over the set bit positions in this BooleanBuffer
Sourcepub fn set_indices_u32(&self) -> BitIndexU32Iterator<'_> ⓘ
pub fn set_indices_u32(&self) -> BitIndexU32Iterator<'_> ⓘ
Returns a u32 iterator over set bit positions without any usize->u32 conversion
Sourcepub fn set_slices(&self) -> BitSliceIterator<'_> ⓘ
pub fn set_slices(&self) -> BitSliceIterator<'_> ⓘ
Returns a BitSliceIterator yielding contiguous ranges of set bits
Trait Implementations§
Source§impl BitAnd<&BooleanBuffer> for &BooleanBuffer
impl BitAnd<&BooleanBuffer> for &BooleanBuffer
Source§type Output = BooleanBuffer
type Output = BooleanBuffer
& operator.Source§impl BitOr<&BooleanBuffer> for &BooleanBuffer
impl BitOr<&BooleanBuffer> for &BooleanBuffer
Source§type Output = BooleanBuffer
type Output = BooleanBuffer
| operator.Source§impl BitXor<&BooleanBuffer> for &BooleanBuffer
impl BitXor<&BooleanBuffer> for &BooleanBuffer
Source§type Output = BooleanBuffer
type Output = BooleanBuffer
^ operator.Source§impl Clone for BooleanBuffer
impl Clone for BooleanBuffer
Source§fn clone(&self) -> BooleanBuffer
fn clone(&self) -> BooleanBuffer
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more