pub struct LabradorProver<'a> { /* private fields */ }
Expand description
Implements the steps executed by the prover (\mathcal{P}) in the paper.
Implementations§
Source§impl<'a> LabradorProver<'a>
impl<'a> LabradorProver<'a>
Sourcepub fn new(
params: &'a EnvironmentParameters,
crs: &'a AjtaiInstances,
witness: &'a Witness,
st: &'a Statement,
) -> Self
pub fn new( params: &'a EnvironmentParameters, crs: &'a AjtaiInstances, witness: &'a Witness, st: &'a Statement, ) -> Self
Constructs a new prover instance.
Sourcepub fn prove<S: Sponge>(&mut self) -> Result<LabradorTranscript<S>, ProverError>
pub fn prove<S: Sponge>(&mut self) -> Result<LabradorTranscript<S>, ProverError>
Executes all prover steps (Fig. 2, page 17).
On success the returned LabradorTranscript
contains every message that
needs to be sent to the verifier.
Auto Trait Implementations§
impl<'a> Freeze for LabradorProver<'a>
impl<'a> RefUnwindSafe for LabradorProver<'a>
impl<'a> Send for LabradorProver<'a>
impl<'a> Sync for LabradorProver<'a>
impl<'a> Unpin for LabradorProver<'a>
impl<'a> UnwindSafe for LabradorProver<'a>
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