pub struct ProverConstraintFolder<'a, SC: StarkGenericConfig> {Show 16 fields
pub preprocessed: ViewPair<'a, PackedVal<SC>>,
pub partitioned_main: Vec<ViewPair<'a, PackedVal<SC>>>,
pub after_challenge: Vec<ViewPair<'a, PackedChallenge<SC>>>,
pub challenges: &'a [Vec<PackedChallenge<SC>>],
pub is_first_row: PackedVal<SC>,
pub is_last_row: PackedVal<SC>,
pub is_transition: PackedVal<SC>,
pub alpha_powers: &'a [SC::Challenge],
pub accumulator: PackedChallenge<SC>,
pub constraint_index: usize,
pub public_values: &'a [Val<SC>],
pub exposed_values_after_challenge: &'a [&'a [PackedChallenge<SC>]],
pub interactions: Vec<Interaction<PackedVal<SC>>>,
pub interaction_chunk_size: usize,
pub rap_phase_seq_kind: RapPhaseSeqKind,
pub has_common_main: bool,
}
Expand description
A folder for prover constraints.
Fields§
§preprocessed: ViewPair<'a, PackedVal<SC>>
§partitioned_main: Vec<ViewPair<'a, PackedVal<SC>>>
§after_challenge: Vec<ViewPair<'a, PackedChallenge<SC>>>
§challenges: &'a [Vec<PackedChallenge<SC>>]
§is_first_row: PackedVal<SC>
§is_last_row: PackedVal<SC>
§is_transition: PackedVal<SC>
§alpha_powers: &'a [SC::Challenge]
§accumulator: PackedChallenge<SC>
§constraint_index: usize
§public_values: &'a [Val<SC>]
§exposed_values_after_challenge: &'a [&'a [PackedChallenge<SC>]]
§interactions: Vec<Interaction<PackedVal<SC>>>
§interaction_chunk_size: usize
Number of interactions to bundle in permutation trace, if applicable.
rap_phase_seq_kind: RapPhaseSeqKind
§has_common_main: bool
Trait Implementations§
Source§impl<'a, SC> AirBuilder for ProverConstraintFolder<'a, SC>where
SC: StarkGenericConfig,
impl<'a, SC> AirBuilder for ProverConstraintFolder<'a, SC>where
SC: StarkGenericConfig,
Source§fn main(&self) -> Self::M
fn main(&self) -> Self::M
It is difficult to horizontally concatenate matrices when the main trace is partitioned, so we disable this method in that case.
type F = <<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val
type Expr = <<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing
type Var = <<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing
type M = VerticalPair<DenseMatrix<<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing, &'a [<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing]>, DenseMatrix<<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing, &'a [<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing]>>
fn is_first_row(&self) -> Self::Expr
fn is_last_row(&self) -> Self::Expr
fn is_transition_window(&self, size: usize) -> Self::Expr
fn assert_zero<I: Into<Self::Expr>>(&mut self, x: I)
fn is_transition(&self) -> Self::Expr
Source§fn when<I>(&mut self, condition: I) -> FilteredAirBuilder<'_, Self>
fn when<I>(&mut self, condition: I) -> FilteredAirBuilder<'_, Self>
Returns a sub-builder whose constraints are enforced only when
condition
is nonzero.Source§fn when_ne<I1, I2>(&mut self, x: I1, y: I2) -> FilteredAirBuilder<'_, Self>
fn when_ne<I1, I2>(&mut self, x: I1, y: I2) -> FilteredAirBuilder<'_, Self>
Returns a sub-builder whose constraints are enforced only when
x != y
.Source§fn when_first_row(&mut self) -> FilteredAirBuilder<'_, Self>
fn when_first_row(&mut self) -> FilteredAirBuilder<'_, Self>
Returns a sub-builder whose constraints are enforced only on the first row.
Source§fn when_last_row(&mut self) -> FilteredAirBuilder<'_, Self>
fn when_last_row(&mut self) -> FilteredAirBuilder<'_, Self>
Returns a sub-builder whose constraints are enforced only on the last row.
Source§fn when_transition(&mut self) -> FilteredAirBuilder<'_, Self>
fn when_transition(&mut self) -> FilteredAirBuilder<'_, Self>
Returns a sub-builder whose constraints are enforced on all rows except the last.
Source§fn when_transition_window(
&mut self,
size: usize,
) -> FilteredAirBuilder<'_, Self>
fn when_transition_window( &mut self, size: usize, ) -> FilteredAirBuilder<'_, Self>
Returns a sub-builder whose constraints are enforced on all rows except the last
size - 1
.fn assert_one<I>(&mut self, x: I)
fn assert_eq<I1, I2>(&mut self, x: I1, y: I2)
Source§fn assert_bool<I>(&mut self, x: I)
fn assert_bool<I>(&mut self, x: I)
Assert that
x
is a boolean, i.e. either 0 or 1.Source§impl<SC: StarkGenericConfig> AirBuilderWithPublicValues for ProverConstraintFolder<'_, SC>
impl<SC: StarkGenericConfig> AirBuilderWithPublicValues for ProverConstraintFolder<'_, SC>
type PublicVar = <ProverConstraintFolder<'_, SC> as AirBuilder>::F
fn public_values(&self) -> &[Self::F]
Source§impl<SC> ExtensionBuilder for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
impl<SC> ExtensionBuilder for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
type EF = <SC as StarkGenericConfig>::Challenge
type ExprEF = <<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking
type VarEF = <<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking
fn assert_zero_ext<I>(&mut self, x: I)
fn assert_eq_ext<I1, I2>(&mut self, x: I1, y: I2)
fn assert_one_ext<I>(&mut self, x: I)
Source§impl<SC> InteractionBuilder for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
impl<SC> InteractionBuilder for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
Source§fn push_interaction<E: Into<Self::Expr>>(
&mut self,
bus_index: usize,
fields: impl IntoIterator<Item = E>,
count: impl Into<Self::Expr>,
interaction_type: InteractionType,
)
fn push_interaction<E: Into<Self::Expr>>( &mut self, bus_index: usize, fields: impl IntoIterator<Item = E>, count: impl Into<Self::Expr>, interaction_type: InteractionType, )
Stores a new interaction in the builder.
Source§fn num_interactions(&self) -> usize
fn num_interactions(&self) -> usize
Returns the current number of interactions.
Source§fn all_interactions(&self) -> &[Interaction<Self::Expr>]
fn all_interactions(&self) -> &[Interaction<Self::Expr>]
Returns all interactions stored.
Source§fn push_send<E: Into<Self::Expr>>(
&mut self,
bus_index: usize,
fields: impl IntoIterator<Item = E>,
count: impl Into<Self::Expr>,
)
fn push_send<E: Into<Self::Expr>>( &mut self, bus_index: usize, fields: impl IntoIterator<Item = E>, count: impl Into<Self::Expr>, )
Stores a new send interaction in the builder.
Source§fn push_receive<E: Into<Self::Expr>>(
&mut self,
bus_index: usize,
fields: impl IntoIterator<Item = E>,
count: impl Into<Self::Expr>,
)
fn push_receive<E: Into<Self::Expr>>( &mut self, bus_index: usize, fields: impl IntoIterator<Item = E>, count: impl Into<Self::Expr>, )
Stores a new receive interaction in the builder.
Source§impl<SC> PairBuilder for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
impl<SC> PairBuilder for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
fn preprocessed(&self) -> Self::M
Source§impl<SC> PartitionedAirBuilder for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
impl<SC> PartitionedAirBuilder for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
Source§fn cached_mains(&self) -> &[Self::M]
fn cached_mains(&self) -> &[Self::M]
Cached main trace matrix.
Source§fn common_main(&self) -> &Self::M
fn common_main(&self) -> &Self::M
Common main trace matrix. Panic if there is no common main trace.
Source§impl<'a, SC> PermutationAirBuilder for ProverConstraintFolder<'a, SC>where
SC: StarkGenericConfig,
impl<'a, SC> PermutationAirBuilder for ProverConstraintFolder<'a, SC>where
SC: StarkGenericConfig,
type MP = VerticalPair<DenseMatrix<<<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking, &'a [<<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking]>, DenseMatrix<<<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking, &'a [<<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking]>>
type RandomVar = <<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking
fn permutation(&self) -> Self::MP
fn permutation_randomness(&self) -> &[Self::RandomVar]
Source§impl<SC> PermutationAirBuilderWithExposedValues for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
impl<SC> PermutationAirBuilderWithExposedValues for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
fn permutation_exposed_values(&self) -> &[Self::VarEF]
Source§impl<SC> SymbolicEvaluator<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val, <<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing> for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
impl<SC> SymbolicEvaluator<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val, <<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing> for ProverConstraintFolder<'_, SC>where
SC: StarkGenericConfig,
fn eval_var(&self, symbolic_var: SymbolicVariable<Val<SC>>) -> PackedVal<SC>
fn eval_expr(&self, symbolic_expr: &SymbolicExpression<F>) -> E
Auto Trait Implementations§
impl<'a, SC> Freeze for ProverConstraintFolder<'a, SC>where
<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing: Freeze,
<<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking: Freeze,
impl<'a, SC> RefUnwindSafe for ProverConstraintFolder<'a, SC>where
<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing: RefUnwindSafe,
<<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking: RefUnwindSafe,
<SC as StarkGenericConfig>::Challenge: RefUnwindSafe,
<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val: RefUnwindSafe,
impl<'a, SC> Send for ProverConstraintFolder<'a, SC>
impl<'a, SC> Sync for ProverConstraintFolder<'a, SC>
impl<'a, SC> Unpin for ProverConstraintFolder<'a, SC>where
<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing: Unpin,
<<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking: Unpin,
impl<'a, SC> UnwindSafe for ProverConstraintFolder<'a, SC>where
<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing: UnwindSafe + RefUnwindSafe,
<<SC as StarkGenericConfig>::Challenge as ExtensionField<<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val>>::ExtensionPacking: UnwindSafe + RefUnwindSafe,
<SC as StarkGenericConfig>::Challenge: RefUnwindSafe,
<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val: RefUnwindSafe,
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