mz_compute::typedefs::spines

Type Alias ColKeySpine

Source
pub type ColKeySpine<K, T, R> = Spine<Rc<OrdKeyBatch<MzStack<((K, ()), T, R)>>>>;
Expand description

A spine for generic keys

Aliased Type§

struct ColKeySpine<K, T, R> { /* private fields */ }

Implementations

Source§

impl<B> Spine<B>
where B: Batch,

Source

pub fn with_effort( effort: usize, operator: OperatorInfo, logger: Option<Logger<DifferentialEvent>>, activator: Option<Activator>, ) -> Spine<B>

Allocates a fueled Spine with a specified effort multiplier.

This trace will merge batches progressively, with each inserted batch applying a multiple of the batch’s length in effort to each merge. The effort parameter is that multiplier. This value should be at least one for the merging to happen; a value of zero is not helpful.

Source

pub fn introduce_batch(&mut self, batch: Option<B>, batch_index: usize)

Introduces a batch at an indicated level.

The level indication is often related to the size of the batch, but it can also be used to artificially fuel the computation by supplying empty batches at non-trivial indices, to move merges along.

Source

pub fn apply_fuel(&mut self, fuel: &mut isize)

Applies an amount of fuel to merges in progress.

The supplied fuel is for each in progress merge, and if we want to spend the fuel non-uniformly (e.g. prioritizing merges at low layers) we could do so in order to maintain fewer batches on average (at the risk of completing merges of large batches later, but tbh probably not much later).

Trait Implementations

Source§

impl<B> Drop for Spine<B>
where B: Batch,

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<B> Trace for Spine<B>
where B: Batch + Clone + 'static,

Source§

fn exert(&mut self)

Apply some amount of effort to trace maintenance.

Whether and how much effort to apply is determined by self.exert_logic, a closure the user can set.

Source§

fn close(&mut self)

Completes the trace with a final empty batch.

Source§

fn new( info: OperatorInfo, logging: Option<Logger<DifferentialEvent>>, activator: Option<Activator>, ) -> Spine<B>

Allocates a new empty trace.
Source§

fn set_exert_logic( &mut self, logic: Arc<dyn for<'a> Fn(&'a [(usize, usize, usize)]) -> Option<usize> + Send + Sync>, )

Sets the logic for exertion in the absence of updates. Read more
Source§

fn insert(&mut self, batch: <Spine<B> as TraceReader>::Batch)

Introduces a batch of updates to the trace. Read more
Source§

impl<B> TraceReader for Spine<B>
where B: Batch + Clone + 'static,

Source§

type Key<'a> = <B as BatchReader>::Key<'a>

Key by which updates are indexed.
Source§

type Val<'a> = <B as BatchReader>::Val<'a>

Values associated with keys.
Source§

type Time = <B as BatchReader>::Time

Timestamps associated with updates
Source§

type TimeGat<'a> = <B as BatchReader>::TimeGat<'a>

Borrowed form of timestamp.
Source§

type Diff = <B as BatchReader>::Diff

Owned form of update difference.
Source§

type DiffGat<'a> = <B as BatchReader>::DiffGat<'a>

Borrowed form of update difference.
Source§

type Batch = B

The type of an immutable collection of updates.
Source§

type Storage = Vec<B>

Storage type for Self::Cursor. Likely related to Self::Batch.
Source§

type Cursor = CursorList<<B as BatchReader>::Cursor>

The type used to enumerate the collections contents.
Source§

fn cursor_through( &mut self, upper: AntichainRef<'_, <Spine<B> as TraceReader>::Time>, ) -> Option<(<Spine<B> as TraceReader>::Cursor, <Spine<B> as TraceReader>::Storage)>

Acquires a cursor to the restriction of the collection’s contents to updates at times not greater or equal to an element of upper. Read more
Source§

fn set_logical_compaction( &mut self, frontier: AntichainRef<'_, <B as BatchReader>::Time>, )

Advances the frontier that constrains logical compaction. Read more
Source§

fn get_logical_compaction( &mut self, ) -> AntichainRef<'_, <B as BatchReader>::Time>

Reports the logical compaction frontier. Read more
Source§

fn set_physical_compaction( &mut self, frontier: AntichainRef<'_, <B as BatchReader>::Time>, )

Advances the frontier that constrains physical compaction. Read more
Source§

fn get_physical_compaction( &mut self, ) -> AntichainRef<'_, <B as BatchReader>::Time>

Reports the physical compaction frontier. Read more
Source§

fn map_batches<F>(&self, f: F)
where F: FnMut(&<Spine<B> as TraceReader>::Batch),

Maps logic across the non-empty sequence of batches in the trace. Read more
Source§

fn cursor(&mut self) -> (Self::Cursor, Self::Storage)

Provides a cursor over updates contained in the trace.
Source§

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

👎Deprecated since 0.11: please use set_logical_compaction
Deprecated form of set_logical_compaction.
Source§

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

👎Deprecated since 0.11: please use get_logical_compaction
Deprecated form of get_logical_compaction.
Source§

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

👎Deprecated since 0.11: please use set_physical_compaction
Deprecated form of set_physical_compaction.
Source§

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

👎Deprecated since 0.11: please use get_physical_compaction
Deprecated form of get_physical_compaction.
Source§

fn read_upper(&mut self, target: &mut Antichain<Self::Time>)

Reads the upper frontier of committed times.
Source§

fn advance_upper(&mut self, upper: &mut Antichain<Self::Time>)

Advances upper by any empty batches. Read more