pub struct MultisetEqualityDigests;
Expand description
Determine whether two lists are equal up to permutation.
The lists are given as lists of digests. This function uses hashing to compute a challenge indeterminate, and then computes a running products for both lists. In the future, the implementation of function may be replaced by one that uses Triton VM’s native support for permutation checks instead of Fiat-Shamir and running products.
Trait Implementations§
Source§impl BasicSnippet for MultisetEqualityDigests
impl BasicSnippet for MultisetEqualityDigests
fn inputs(&self) -> Vec<(DataType, String)>
fn outputs(&self) -> Vec<(DataType, String)>
fn entrypoint(&self) -> String
fn code(&self, library: &mut Library) -> Vec<LabelledInstruction>
fn annotated_code(&self, library: &mut Library) -> Vec<LabelledInstruction>
fn link_for_isolated_run(&self) -> Vec<LabelledInstruction>
Source§fn init_stack_for_isolated_run(&self) -> Vec<BFieldElement>
fn init_stack_for_isolated_run(&self) -> Vec<BFieldElement>
Intial stack on program start, when the snippet runs in isolation.
fn stack_diff(&self) -> isize
Source§impl Clone for MultisetEqualityDigests
impl Clone for MultisetEqualityDigests
Source§fn clone(&self) -> MultisetEqualityDigests
fn clone(&self) -> MultisetEqualityDigests
Returns a copy 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 MultisetEqualityDigests
impl Debug for MultisetEqualityDigests
Source§impl Default for MultisetEqualityDigests
impl Default for MultisetEqualityDigests
Source§fn default() -> MultisetEqualityDigests
fn default() -> MultisetEqualityDigests
Returns the “default value” for a type. Read more
Source§impl Hash for MultisetEqualityDigests
impl Hash for MultisetEqualityDigests
Source§impl PartialEq for MultisetEqualityDigests
impl PartialEq for MultisetEqualityDigests
impl Copy for MultisetEqualityDigests
impl Eq for MultisetEqualityDigests
impl StructuralPartialEq for MultisetEqualityDigests
Auto Trait Implementations§
impl Freeze for MultisetEqualityDigests
impl RefUnwindSafe for MultisetEqualityDigests
impl Send for MultisetEqualityDigests
impl Sync for MultisetEqualityDigests
impl Unpin for MultisetEqualityDigests
impl UnwindSafe for MultisetEqualityDigests
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<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