openvm_stark_backend::air_builders::prover

Struct ProverConstraintFolder

Source
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>

Source§

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.

Source§

type F = <<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val

Source§

type Expr = <<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing

Source§

type Var = <<<<SC as StarkGenericConfig>::Pcs as Pcs<<SC as StarkGenericConfig>::Challenge, <SC as StarkGenericConfig>::Challenger>>::Domain as PolynomialSpace>::Val as Field>::Packing

Source§

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]>>

Source§

fn is_first_row(&self) -> Self::Expr

Source§

fn is_last_row(&self) -> Self::Expr

Source§

fn is_transition_window(&self, size: usize) -> Self::Expr

Source§

fn assert_zero<I: Into<Self::Expr>>(&mut self, x: I)

§

fn is_transition(&self) -> Self::Expr

§

fn when<I>(&mut self, condition: I) -> FilteredAirBuilder<'_, Self>
where I: Into<Self::Expr>,

Returns a sub-builder whose constraints are enforced only when condition is nonzero.
§

fn when_ne<I1, I2>(&mut self, x: I1, y: I2) -> FilteredAirBuilder<'_, Self>
where I1: Into<Self::Expr>, I2: Into<Self::Expr>,

Returns a sub-builder whose constraints are enforced only when x != y.
§

fn when_first_row(&mut self) -> FilteredAirBuilder<'_, Self>

Returns a sub-builder whose constraints are enforced only on the first row.
§

fn when_last_row(&mut self) -> FilteredAirBuilder<'_, Self>

Returns a sub-builder whose constraints are enforced only on the last row.
§

fn when_transition(&mut self) -> FilteredAirBuilder<'_, Self>

Returns a sub-builder whose constraints are enforced on all rows except the last.
§

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)
where I: Into<Self::Expr>,

§

fn assert_eq<I1, I2>(&mut self, x: I1, y: I2)
where I1: Into<Self::Expr>, I2: Into<Self::Expr>,

§

fn assert_bool<I>(&mut self, x: I)
where I: Into<Self::Expr>,

Assert that x is a boolean, i.e. either 0 or 1.
Source§

impl<SC: StarkGenericConfig> AirBuilderWithPublicValues for ProverConstraintFolder<'_, SC>

Source§

type PublicVar = <ProverConstraintFolder<'_, SC> as AirBuilder>::F

Source§

fn public_values(&self) -> &[Self::F]

Source§

impl<SC> ExtensionBuilder for ProverConstraintFolder<'_, SC>

Source§

type EF = <SC as StarkGenericConfig>::Challenge

Source§

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

Source§

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

Source§

fn assert_zero_ext<I>(&mut self, x: I)
where I: Into<Self::ExprEF>,

§

fn assert_eq_ext<I1, I2>(&mut self, x: I1, y: I2)
where I1: Into<Self::ExprEF>, I2: Into<Self::ExprEF>,

§

fn assert_one_ext<I>(&mut self, x: I)
where I: Into<Self::ExprEF>,

Source§

impl<SC> InteractionBuilder for ProverConstraintFolder<'_, SC>

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, )

Stores a new interaction in the builder.
Source§

fn num_interactions(&self) -> usize

Returns the current number of interactions.
Source§

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>, )

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>, )

Stores a new receive interaction in the builder.
Source§

impl<SC> PairBuilder for ProverConstraintFolder<'_, SC>

Source§

fn preprocessed(&self) -> Self::M

Source§

impl<SC> PartitionedAirBuilder for ProverConstraintFolder<'_, SC>

Source§

fn cached_mains(&self) -> &[Self::M]

Cached main trace matrix.
Source§

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>

Source§

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]>>

Source§

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

Source§

fn permutation(&self) -> Self::MP

Source§

fn permutation_randomness(&self) -> &[Self::RandomVar]

Source§

impl<SC> PermutationAirBuilderWithExposedValues for ProverConstraintFolder<'_, SC>

Source§

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>

Source§

fn eval_var(&self, symbolic_var: SymbolicVariable<Val<SC>>) -> PackedVal<SC>

Source§

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> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more