pub struct StarkVerify { /* private fields */ }Expand description
Verify a STARK proof.
Verify a STARK proof located in memory. Assumes the nondeterministic digests
stream has been updated with the digests extracted from the proof using
update_nondeterminism. Crashes the VM if the
proof is invalid.
Stack signature:
- BEFORE: _ *claim *proof
- AFTER: _
Implementations§
Source§impl StarkVerify
impl StarkVerify
pub fn new_with_static_layout(stark: Stark) -> Self
pub fn new_with_dynamic_layout(stark: Stark) -> Self
Sourcepub fn number_of_nondeterministic_digests_consumed(
&self,
proof: &Proof,
) -> usize
pub fn number_of_nondeterministic_digests_consumed( &self, proof: &Proof, ) -> usize
The number of nondeterministic digests that will be consumed when this snippet verifies the given proof.
Sourcepub fn number_of_nondeterministic_tokens_consumed(
&self,
_proof: &Proof,
_claim: &Claim,
) -> usize
pub fn number_of_nondeterministic_tokens_consumed( &self, _proof: &Proof, _claim: &Claim, ) -> usize
The number of nondeterministic individual tokens that will be consumed when this snippet verifies the given (claim, proof) pair.
Sourcepub fn update_nondeterminism(
&self,
nondeterminism: &mut NonDeterminism,
proof: &Proof,
claim: &Claim,
)
pub fn update_nondeterminism( &self, nondeterminism: &mut NonDeterminism, proof: &Proof, claim: &Claim, )
Prepares the non-determinism for verifying a STARK proof. Specifically, extracts the digests for traversing authentication paths and appends them to nondeterministic digests. Leaves memory and individual tokens intact.
Trait Implementations§
Source§impl BasicSnippet for StarkVerify
impl BasicSnippet for StarkVerify
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 StarkVerify
impl Clone for StarkVerify
Source§fn clone(&self) -> StarkVerify
fn clone(&self) -> StarkVerify
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 StarkVerify
impl Debug for StarkVerify
impl Copy for StarkVerify
Auto Trait Implementations§
impl Freeze for StarkVerify
impl RefUnwindSafe for StarkVerify
impl Send for StarkVerify
impl Sync for StarkVerify
impl Unpin for StarkVerify
impl UnwindSafe for StarkVerify
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<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.