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
Source§fn parameters(&self) -> Vec<(DataType, String)>
fn parameters(&self) -> Vec<(DataType, String)>
The parameters expected by this snippet. Read more
Source§fn return_values(&self) -> Vec<(DataType, String)>
fn return_values(&self) -> Vec<(DataType, String)>
The (types of the) values this snippet computes. Read more
Source§fn entrypoint(&self) -> String
fn entrypoint(&self) -> String
The name of the snippet as a possible target for Triton VM’s
instruction
call.Source§fn code(&self, library: &mut Library) -> Vec<LabelledInstruction>
fn code(&self, library: &mut Library) -> Vec<LabelledInstruction>
The Triton Assembly that defines this snippet. Read more
Source§fn annotated_code(&self, library: &mut Library) -> Vec<LabelledInstruction>
fn annotated_code(&self, library: &mut Library) -> Vec<LabelledInstruction>
Source§fn stack_diff(&self) -> isize
fn stack_diff(&self) -> isize
The size difference of the stack as a result of executing this snippet.
Source§impl Clone for MultisetEqualityDigests
impl Clone for MultisetEqualityDigests
Source§fn clone(&self) -> MultisetEqualityDigests
fn clone(&self) -> MultisetEqualityDigests
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 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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> SignedOffSnippet for Twhere
T: BasicSnippet + ?Sized,
impl<T> SignedOffSnippet for Twhere
T: BasicSnippet + ?Sized,
Source§fn fingerprint(&self) -> SignOffFingerprint
fn fingerprint(&self) -> SignOffFingerprint
The unique fingerprint as used for signing off on
this snippet.
Source§fn assert_all_sign_offs_are_up_to_date(&self)
fn assert_all_sign_offs_are_up_to_date(&self)
Panics if any sign-offs disagree with the actual
fingerprint.