pub struct CirclePcs<Val: Field, InputMmcs, FriMmcs> {
pub mmcs: InputMmcs,
pub fri_config: FriConfig<FriMmcs>,
pub _phantom: PhantomData<Val>,
}Fields§
§mmcs: InputMmcs§fri_config: FriConfig<FriMmcs>§_phantom: PhantomData<Val>Trait Implementations§
Source§impl<Val: Debug + Field, InputMmcs: Debug, FriMmcs: Debug> Debug for CirclePcs<Val, InputMmcs, FriMmcs>
impl<Val: Debug + Field, InputMmcs: Debug, FriMmcs: Debug> Debug for CirclePcs<Val, InputMmcs, FriMmcs>
Source§impl<Val, InputMmcs, FriMmcs, Challenge, Challenger> Pcs<Challenge, Challenger> for CirclePcs<Val, InputMmcs, FriMmcs>where
Val: ComplexExtendable,
Challenge: ExtensionField<Val>,
InputMmcs: Mmcs<Val>,
FriMmcs: Mmcs<Challenge>,
Challenger: FieldChallenger<Val> + GrindingChallenger + CanObserve<FriMmcs::Commitment>,
impl<Val, InputMmcs, FriMmcs, Challenge, Challenger> Pcs<Challenge, Challenger> for CirclePcs<Val, InputMmcs, FriMmcs>where
Val: ComplexExtendable,
Challenge: ExtensionField<Val>,
InputMmcs: Mmcs<Val>,
FriMmcs: Mmcs<Challenge>,
Challenger: FieldChallenger<Val> + GrindingChallenger + CanObserve<FriMmcs::Commitment>,
type Domain = CircleDomain<Val>
Source§type Commitment = <InputMmcs as Mmcs<Val>>::Commitment
type Commitment = <InputMmcs as Mmcs<Val>>::Commitment
The commitment that’s sent to the verifier.
Source§type ProverData = <InputMmcs as Mmcs<Val>>::ProverData<DenseMatrix<Val>>
type ProverData = <InputMmcs as Mmcs<Val>>::ProverData<DenseMatrix<Val>>
Data that the prover stores for committed polynomials, to help the prover with opening.
Source§type Proof = CirclePcsProof<Val, Challenge, InputMmcs, FriMmcs, <Challenger as GrindingChallenger>::Witness>
type Proof = CirclePcsProof<Val, Challenge, InputMmcs, FriMmcs, <Challenger as GrindingChallenger>::Witness>
The opening argument.
type Error = FriError<<FriMmcs as Mmcs<Challenge>>::Error, InputError<<InputMmcs as Mmcs<Val>>::Error, <FriMmcs as Mmcs<Challenge>>::Error>>
Source§fn natural_domain_for_degree(&self, degree: usize) -> Self::Domain
fn natural_domain_for_degree(&self, degree: usize) -> Self::Domain
This should return a coset domain (s.t. Domain::next_point returns Some)
fn commit( &self, evaluations: Vec<(Self::Domain, RowMajorMatrix<Val>)>, ) -> (Self::Commitment, Self::ProverData)
fn get_evaluations_on_domain<'a>( &self, data: &'a Self::ProverData, idx: usize, domain: Self::Domain, ) -> impl Matrix<Val> + 'a
fn open( &self, rounds: Vec<(&Self::ProverData, Vec<Vec<Challenge>>)>, challenger: &mut Challenger, ) -> (OpenedValues<Challenge>, Self::Proof)
fn verify( &self, rounds: Vec<(Self::Commitment, Vec<(Self::Domain, Vec<(Challenge, Vec<Challenge>)>)>)>, proof: &Self::Proof, challenger: &mut Challenger, ) -> Result<(), Self::Error>
Auto Trait Implementations§
impl<Val, InputMmcs, FriMmcs> Freeze for CirclePcs<Val, InputMmcs, FriMmcs>
impl<Val, InputMmcs, FriMmcs> RefUnwindSafe for CirclePcs<Val, InputMmcs, FriMmcs>
impl<Val, InputMmcs, FriMmcs> Send for CirclePcs<Val, InputMmcs, FriMmcs>
impl<Val, InputMmcs, FriMmcs> Sync for CirclePcs<Val, InputMmcs, FriMmcs>
impl<Val, InputMmcs, FriMmcs> Unpin for CirclePcs<Val, InputMmcs, FriMmcs>
impl<Val, InputMmcs, FriMmcs> UnwindSafe for CirclePcs<Val, InputMmcs, FriMmcs>
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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