Struct LabradorVerifier

Source
pub struct LabradorVerifier<'a> { /* private fields */ }
Expand description

Implements the algorithm executed by the verifier (\mathcal{V}) in the paper.

Implementations§

Source§

impl<'a> LabradorVerifier<'a>

Source

pub fn new( params: &'a EnvironmentParameters, crs: &'a AjtaiInstances, st: &'a Statement, ) -> Self

Constructs a new verifier instance.

Source

pub fn verify<S: Sponge>( &mut self, proof: &LabradorTranscript<S>, ) -> Result<bool, VerifierError>

Verifies a prover transcript. Executes all verifier steps (Fig. 2 page 17, Fig. 3 page 18).

Returns Ok(true) if all checks succeed, otherwise an explanatory VerifierError. The sponge seeded inside this routine must be identical to the prover’s so that the generated randomizers match.

Auto Trait Implementations§

§

impl<'a> Freeze for LabradorVerifier<'a>

§

impl<'a> RefUnwindSafe for LabradorVerifier<'a>

§

impl<'a> Send for LabradorVerifier<'a>

§

impl<'a> Sync for LabradorVerifier<'a>

§

impl<'a> Unpin for LabradorVerifier<'a>

§

impl<'a> UnwindSafe for LabradorVerifier<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V