#[non_exhaustive]pub enum StreamingPartitionAlgorithm {
Fennel,
Hashing,
LinearDeterministic,
}Expand description
Algorithm variant for the stateful streaming partitioner.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Fennel
FENNEL: minimize edge cut + imbalance penalty, vertex streaming.
Score for partition p: |N(v) ∩ Vp| - γ · |Vp|^α.
Hashing
Consistent hashing baseline: v % k.
LinearDeterministic
Linear Deterministic Greedy: |N(v) ∩ Vp| · (1 - |Vp| / cap).
Trait Implementations§
Source§impl Clone for StreamingPartitionAlgorithm
impl Clone for StreamingPartitionAlgorithm
Source§fn clone(&self) -> StreamingPartitionAlgorithm
fn clone(&self) -> StreamingPartitionAlgorithm
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for StreamingPartitionAlgorithm
impl Debug for StreamingPartitionAlgorithm
impl Copy for StreamingPartitionAlgorithm
impl Eq for StreamingPartitionAlgorithm
impl StructuralPartialEq for StreamingPartitionAlgorithm
Auto Trait Implementations§
impl Freeze for StreamingPartitionAlgorithm
impl RefUnwindSafe for StreamingPartitionAlgorithm
impl Send for StreamingPartitionAlgorithm
impl Sync for StreamingPartitionAlgorithm
impl Unpin for StreamingPartitionAlgorithm
impl UnsafeUnpin for StreamingPartitionAlgorithm
impl UnwindSafe for StreamingPartitionAlgorithm
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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