Struct datafusion_physical_expr_common::aggregate::groups_accumulator::bool_op::BooleanGroupsAccumulator
source · 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: &[Arc<dyn Array>],
_opt_filter: Option<&BooleanArray>,
) -> Result<Vec<Arc<dyn Array>>, DataFusionError>
fn convert_to_state( &self, _values: &[Arc<dyn Array>], _opt_filter: Option<&BooleanArray>, ) -> Result<Vec<Arc<dyn Array>>, DataFusionError>
Converts an input batch directly 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