lance_encoding::data

Enum DataBlock

Source
pub enum DataBlock {
    Empty(),
    Constant(ConstantDataBlock),
    AllNull(AllNullDataBlock),
    Nullable(NullableDataBlock),
    FixedWidth(FixedWidthDataBlock),
    FixedSizeList(FixedSizeListBlock),
    VariableWidth(VariableWidthBlock),
    Opaque(OpaqueBlock),
    Struct(StructDataBlock),
    Dictionary(DictionaryDataBlock),
}
Expand description

A DataBlock is a collection of buffers that represents an “array” of data in very generic terms

The output of each decoder is a DataBlock. Decoders can be chained together to transform one DataBlock into a different kind of DataBlock.

The DataBlock is somewhere in between Arrow’s ArrayData and Array and represents a physical layout of the data.

A DataBlock can be converted into an Arrow ArrayData (and then Array) for a given array type. For example, a FixedWidthDataBlock can be converted into any primitive type or a fixed size list of a primitive type. This is a zero-copy operation.

In addition, a DataBlock can be created from an Arrow array or arrays. This is not a zero-copy operation as some normalization may be required.

Variants§

Implementations§

Source§

impl DataBlock

Source

pub fn into_arrow( self, data_type: DataType, validate: bool, ) -> Result<ArrayData>

Convert self into an Arrow ArrayData

Source

pub fn into_buffers(self) -> Vec<LanceBuffer>

Convert the data block into a collection of buffers for serialization

The order matters and will be used to reconstruct the data block at read time.

Source

pub fn borrow_and_clone(&mut self) -> Self

Converts the data buffers into borrowed mode and clones the block

This is a zero-copy operation but requires a mutable reference to self and, afterwards, all buffers will be in Borrowed mode.

Source

pub fn try_clone(&self) -> Result<Self>

Try and clone the block

This will fail if any buffers are in owned mode. You can call borrow_and_clone() to ensure that all buffers are in borrowed mode before calling this method.

Source

pub fn name(&self) -> &'static str

Source

pub fn num_values(&self) -> u64

Source

pub fn data_size(&self) -> u64

Source

pub fn remove_validity(self) -> Self

Removes any validity information from the block

This does not filter the block (e.g. remove rows). It only removes the validity bitmaps (if present). Any garbage masked by null bits will now appear as proper values.

Source

pub fn make_builder( &self, estimated_size_bytes: u64, ) -> Box<dyn DataBlockBuilderImpl>

Source§

impl DataBlock

Source§

impl DataBlock

Source

pub fn from_arrays(arrays: &[ArrayRef], num_values: u64) -> Self

Source

pub fn from_array<T: Array + 'static>(array: T) -> Self

Trait Implementations§

Source§

impl ComputeStat for DataBlock

Source§

fn compute_stat(&mut self)

Source§

impl Debug for DataBlock

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl From<Arc<dyn Array>> for DataBlock

Source§

fn from(array: ArrayRef) -> Self

Converts to this type from the input type.
Source§

impl GetStat for DataBlock

Source§

fn get_stat(&self, stat: Stat) -> Option<Arc<dyn Array>>

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize = _

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,

Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSendSync for T