pub struct BooleanGroupsAccumulator<F>{ /* private fields */ }
Expand description
An accumulator that implements a single operation over a
BooleanArray
where the accumulated state is also boolean (such
as BitAndAssign
)
F: The function to apply to two elements. The first argument is
the existing value and should be updated with the second value
(e.g. BitAndAssign
style).
Implementations§
Trait Implementations§
Source§impl<F> Debug for BooleanGroupsAccumulator<F>
impl<F> Debug for BooleanGroupsAccumulator<F>
Source§impl<F> GroupsAccumulator for BooleanGroupsAccumulator<F>
impl<F> GroupsAccumulator for BooleanGroupsAccumulator<F>
Source§fn update_batch(
&mut self,
values: &[ArrayRef],
group_indices: &[usize],
opt_filter: Option<&BooleanArray>,
total_num_groups: usize,
) -> Result<()>
fn update_batch( &mut self, values: &[ArrayRef], group_indices: &[usize], opt_filter: Option<&BooleanArray>, total_num_groups: usize, ) -> Result<()>
Source§fn evaluate(&mut self, emit_to: EmitTo) -> Result<ArrayRef>
fn evaluate(&mut self, emit_to: EmitTo) -> Result<ArrayRef>
Returns the final aggregate value for each group as a single
RecordBatch
, resetting the internal state. Read moreSource§fn state(&mut self, emit_to: EmitTo) -> Result<Vec<ArrayRef>>
fn state(&mut self, emit_to: EmitTo) -> Result<Vec<ArrayRef>>
Returns the intermediate aggregate state for this accumulator,
used for multi-phase grouping, resetting its internal state. Read more
Source§fn merge_batch(
&mut self,
values: &[ArrayRef],
group_indices: &[usize],
opt_filter: Option<&BooleanArray>,
total_num_groups: usize,
) -> Result<()>
fn merge_batch( &mut self, values: &[ArrayRef], group_indices: &[usize], opt_filter: Option<&BooleanArray>, total_num_groups: usize, ) -> Result<()>
Merges intermediate state (the output from
Self::state
)
into this accumulator’s current state. Read moreSource§fn size(&self) -> usize
fn size(&self) -> usize
Amount of memory used to store the state of this accumulator,
in bytes. Read more
Source§fn convert_to_state(
&self,
values: &[ArrayRef],
opt_filter: Option<&BooleanArray>,
) -> Result<Vec<ArrayRef>>
fn convert_to_state( &self, values: &[ArrayRef], opt_filter: Option<&BooleanArray>, ) -> Result<Vec<ArrayRef>>
Converts an input batch directly to the intermediate aggregate state. Read more
Source§fn supports_convert_to_state(&self) -> bool
fn supports_convert_to_state(&self) -> bool
Returns
true
if Self::convert_to_state
is implemented to support
intermediate aggregate state conversion.Auto Trait Implementations§
impl<F> Freeze for BooleanGroupsAccumulator<F>where
F: Freeze,
impl<F> RefUnwindSafe for BooleanGroupsAccumulator<F>where
F: RefUnwindSafe,
impl<F> Send for BooleanGroupsAccumulator<F>
impl<F> Sync for BooleanGroupsAccumulator<F>
impl<F> Unpin for BooleanGroupsAccumulator<F>where
F: Unpin,
impl<F> UnwindSafe for BooleanGroupsAccumulator<F>where
F: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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