|
//! This module defines structs that are shared by all sub protocols.
|
|
|
|
use crate::VirtualPolynomial;
|
|
use ark_ff::PrimeField;
|
|
|
|
/// A Subclaim is a claim generated by the verifier at the end of verification
|
|
/// when it is convinced.
|
|
pub struct SubClaim<F: PrimeField> {
|
|
/// the multi-dimensional point that this multilinear extension is evaluated
|
|
/// to
|
|
pub point: Vec<F>,
|
|
/// the expected evaluation
|
|
pub expected_evaluation: F,
|
|
}
|
|
|
|
/// An IOP proof is a collections of messages from prover to verifier at each
|
|
/// round through the interactive protocol.
|
|
#[derive(Clone, Debug, Default, PartialEq)]
|
|
pub struct IOPProof<F: PrimeField> {
|
|
pub proofs: Vec<IOPProverMessage<F>>,
|
|
}
|
|
|
|
/// A message from the prover to the verifier at a given round
|
|
/// is a list of evaluations.
|
|
#[derive(Clone, Debug, Default, PartialEq)]
|
|
pub struct IOPProverMessage<F: PrimeField> {
|
|
pub(crate) evaluations: Vec<F>,
|
|
}
|
|
|
|
/// Prover State of a PolyIOP.
|
|
pub struct IOPProverState<F: PrimeField> {
|
|
/// sampled randomness given by the verifier
|
|
pub challenges: Vec<F>,
|
|
/// the current round number
|
|
pub(crate) round: usize,
|
|
/// pointer to the virtual polynomial
|
|
pub(crate) poly: VirtualPolynomial<F>,
|
|
}
|
|
|
|
/// Prover State of a PolyIOP
|
|
pub struct IOPVerifierState<F: PrimeField> {
|
|
pub(crate) round: usize,
|
|
pub(crate) num_vars: usize,
|
|
pub(crate) max_degree: usize,
|
|
pub(crate) finished: bool,
|
|
/// a list storing the univariate polynomial in evaluation form sent by the
|
|
/// prover at each round
|
|
pub(crate) polynomials_received: Vec<Vec<F>>,
|
|
/// a list storing the randomness sampled by the verifier at each round
|
|
pub(crate) challenges: Vec<F>,
|
|
}
|