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
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 StarkVerify
impl Clone for StarkVerify
Source§fn clone(&self) -> StarkVerify
fn clone(&self) -> StarkVerify
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 moreAuto 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 more