Trait differential_dataflow::trace::Batcher

source ·
pub trait Batcher {
    type Input;
    type Output;
    type Time: Timestamp;

    // Required methods
    fn new(
        logger: Option<Logger<DifferentialEvent, WorkerIdentifier>>,
        operator_id: usize,
    ) -> Self;
    fn push_container(&mut self, batch: &mut Self::Input);
    fn seal<B: Builder<Input = Self::Output, Time = Self::Time>>(
        &mut self,
        upper: Antichain<Self::Time>,
    ) -> B::Output;
    fn frontier(&mut self) -> AntichainRef<'_, Self::Time>;
}
Expand description

Functionality for collecting and batching updates.

Required Associated Types§

source

type Input

Type pushed into the batcher.

source

type Output

Type produced by the batcher.

source

type Time: Timestamp

Times at which batches are formed.

Required Methods§

source

fn new( logger: Option<Logger<DifferentialEvent, WorkerIdentifier>>, operator_id: usize, ) -> Self

Allocates a new empty batcher.

source

fn push_container(&mut self, batch: &mut Self::Input)

Adds an unordered container of elements to the batcher.

source

fn seal<B: Builder<Input = Self::Output, Time = Self::Time>>( &mut self, upper: Antichain<Self::Time>, ) -> B::Output

Returns all updates not greater or equal to an element of upper.

source

fn frontier(&mut self) -> AntichainRef<'_, Self::Time>

Returns the lower envelope of contained update times.

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<Input, C, M, T> Batcher for MergeBatcher<Input, C, M, T>
where C: ContainerBuilder<Container = M::Chunk> + Default + for<'a> PushInto<&'a mut Input>, M: Merger<Time = T>, T: Timestamp,

§

type Input = Input

§

type Output = <M as Merger>::Output

§

type Time = T