Struct ark_marlin::Proof[][src]

pub struct Proof<F: PrimeField, PC: PolynomialCommitment<F, DensePolynomial<F>>> {
    pub commitments: Vec<Vec<PC::Commitment>>,
    pub evaluations: Vec<F>,
    pub prover_messages: Vec<ProverMsg<F>>,
    pub pc_proof: BatchLCProof<F, DensePolynomial<F>, PC>,
}

A zkSNARK proof.

Fields

commitments: Vec<Vec<PC::Commitment>>

Commitments to the polynomials produced by the AHP prover.

evaluations: Vec<F>

Evaluations of these polynomials.

prover_messages: Vec<ProverMsg<F>>

The field elements sent by the prover.

pc_proof: BatchLCProof<F, DensePolynomial<F>, PC>

An evaluation proof from the polynomial commitment.

Implementations

impl<F: PrimeField, PC: PolynomialCommitment<F, DensePolynomial<F>>> Proof<F, PC>[src]

pub fn new(
    commitments: Vec<Vec<PC::Commitment>>,
    evaluations: Vec<F>,
    prover_messages: Vec<ProverMsg<F>>,
    pc_proof: BatchLCProof<F, DensePolynomial<F>, PC>
) -> Self
[src]

Construct a new proof.

pub fn print_size_info(&self)[src]

Prints information about the size of the proof.

Trait Implementations

impl<F: PrimeField, PC: PolynomialCommitment<F, DensePolynomial<F>>> CanonicalDeserialize for Proof<F, PC>[src]

impl<F: PrimeField, PC: PolynomialCommitment<F, DensePolynomial<F>>> CanonicalSerialize for Proof<F, PC>[src]

Auto Trait Implementations

impl<F, PC> RefUnwindSafe for Proof<F, PC> where
    F: RefUnwindSafe,
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::BatchProof: RefUnwindSafe,
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::Commitment: RefUnwindSafe

impl<F, PC> Send for Proof<F, PC> where
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::BatchProof: Send,
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::Commitment: Send

impl<F, PC> Sync for Proof<F, PC> where
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::BatchProof: Sync,
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::Commitment: Sync

impl<F, PC> Unpin for Proof<F, PC> where
    F: Unpin,
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::BatchProof: Unpin,
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::Commitment: Unpin

impl<F, PC> UnwindSafe for Proof<F, PC> where
    F: UnwindSafe,
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::BatchProof: UnwindSafe,
    <PC as PolynomialCommitment<F, DensePolynomial<F>>>::Commitment: UnwindSafe

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T> Instrument for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> Pointable for T

type Init = T

The type for initializers.

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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