ProverConstraintFolder

Struct ProverConstraintFolder 

Source
pub struct ProverConstraintFolder<'a, SC: StarkGenericConfig> {
Show 13 fields pub preprocessed: VerticalPair<RowMajorMatrixView<'a, PackedVal<SC>>, RowMajorMatrixView<'a, PackedVal<SC>>>, pub main: VerticalPair<RowMajorMatrixView<'a, PackedVal<SC>>, RowMajorMatrixView<'a, PackedVal<SC>>>, pub perm: VerticalPair<RowMajorMatrixView<'a, PackedChallenge<SC>>, RowMajorMatrixView<'a, PackedChallenge<SC>>>, pub perm_challenges: &'a [PackedChallenge<SC>], pub local_cumulative_sum: &'a PackedChallenge<SC>, pub global_cumulative_sum: &'a SepticDigest<Val<SC>>, pub is_first_row: PackedVal<SC>, pub is_last_row: PackedVal<SC>, pub is_transition: PackedVal<SC>, pub powers_of_alpha: &'a Vec<SC::Challenge>, pub accumulator: PackedChallenge<SC>, pub public_values: &'a [Val<SC>], pub constraint_index: usize,
}
Expand description

A folder for prover constraints.

Fields§

§preprocessed: VerticalPair<RowMajorMatrixView<'a, PackedVal<SC>>, RowMajorMatrixView<'a, PackedVal<SC>>>

The preprocessed trace.

§main: VerticalPair<RowMajorMatrixView<'a, PackedVal<SC>>, RowMajorMatrixView<'a, PackedVal<SC>>>

The main trace.

§perm: VerticalPair<RowMajorMatrixView<'a, PackedChallenge<SC>>, RowMajorMatrixView<'a, PackedChallenge<SC>>>

The permutation trace.

§perm_challenges: &'a [PackedChallenge<SC>]

The challenges for the permutation.

§local_cumulative_sum: &'a PackedChallenge<SC>

The local cumulative sum for the permutation.

§global_cumulative_sum: &'a SepticDigest<Val<SC>>

The global cumulative sum for the permutation.

§is_first_row: PackedVal<SC>

The selector for the first row.

§is_last_row: PackedVal<SC>

The selector for the last row.

§is_transition: PackedVal<SC>

The selector for the transition.

§powers_of_alpha: &'a Vec<SC::Challenge>

The powers of the constraint folding challenge.

§accumulator: PackedChallenge<SC>

The accumulator for the constraint folding.

§public_values: &'a [Val<SC>]

The public values.

§constraint_index: usize

The constraint index.

Trait Implementations§

Source§

impl<'a, SC: StarkGenericConfig> AirBuilder for ProverConstraintFolder<'a, SC>

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 main(&self) -> Self::M

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)

Source§

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

Source§

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

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

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>

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

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>

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

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

Source§

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

Source§

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§

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

Source§

impl<'a, SC: StarkGenericConfig> MultiTableAirBuilder<'a> for ProverConstraintFolder<'a, SC>

Source§

type LocalSum = <<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

The type of the local cumulative sum.
Source§

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

The type of the global cumulative sum;
Source§

fn local_cumulative_sum(&self) -> &'a Self::LocalSum

Returns the local cumulative sum of the permutation.
Source§

fn global_cumulative_sum(&self) -> &'a SepticDigest<Self::GlobalSum>

Returns the global cumulative sum of the permutation.
Source§

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

Source§

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

Source§

impl<'a, SC: StarkGenericConfig> PermutationAirBuilder for ProverConstraintFolder<'a, SC>

Source§

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

Auto Trait Implementations§

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<AB> BaseAirBuilder for AB

Source§

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

Returns a sub-builder whose constraints are enforced only when condition is not one.
Source§

fn assert_all_eq<I1: Into<Self::Expr>, I2: Into<Self::Expr>>( &mut self, left: impl IntoIterator<Item = I1>, right: impl IntoIterator<Item = I2>, )

Asserts that an iterator of expressions are all equal.
Source§

fn assert_all_zero<I: Into<Self::Expr>>( &mut self, iter: impl IntoIterator<Item = I>, )

Asserts that an iterator of expressions are all zero.
Source§

fn if_else( &mut self, condition: impl Into<Self::Expr> + Clone, a: impl Into<Self::Expr> + Clone, b: impl Into<Self::Expr> + Clone, ) -> Self::Expr

Will return a if condition is 1, else b. This assumes that condition is already checked to be a boolean.
Source§

fn index_array( &mut self, array: &[impl Into<Self::Expr> + Clone], index_bitmap: &[impl Into<Self::Expr> + Clone], ) -> Self::Expr

Index an array of expressions using an index bitmap. This function assumes that the EIndex type is a boolean and that index_bitmap’s entries sum to 1.
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<AB> ByteAirBuilder for AB
where AB: BaseAirBuilder,

Source§

fn send_byte( &mut self, opcode: impl Into<Self::Expr>, a: impl Into<Self::Expr>, b: impl Into<Self::Expr>, c: impl Into<Self::Expr>, multiplicity: impl Into<Self::Expr>, )

Sends a byte operation to be processed.
Source§

fn send_byte_pair( &mut self, opcode: impl Into<Self::Expr>, a1: impl Into<Self::Expr>, a2: impl Into<Self::Expr>, b: impl Into<Self::Expr>, c: impl Into<Self::Expr>, multiplicity: impl Into<Self::Expr>, )

Sends a byte operation with two outputs to be processed.
Source§

fn receive_byte( &mut self, opcode: impl Into<Self::Expr>, a: impl Into<Self::Expr>, b: impl Into<Self::Expr>, c: impl Into<Self::Expr>, multiplicity: impl Into<Self::Expr>, )

Receives a byte operation to be processed.
Source§

fn receive_byte_pair( &mut self, opcode: impl Into<Self::Expr>, a1: impl Into<Self::Expr>, a2: impl Into<Self::Expr>, b: impl Into<Self::Expr>, c: impl Into<Self::Expr>, multiplicity: impl Into<Self::Expr>, )

Receives a byte operation with two outputs to be processed.
Source§

impl<AB> ExtensionAirBuilder for AB
where AB: BaseAirBuilder,

Source§

fn assert_ext_eq<I: Into<Self::Expr>>( &mut self, left: BinomialExtension<I>, right: BinomialExtension<I>, )

Asserts that the two field extensions are equal.
Source§

fn assert_is_base_element<I: Into<Self::Expr> + Clone>( &mut self, element: BinomialExtension<I>, )

Checks if an extension element is a base element.
Source§

fn if_else_ext( &mut self, condition: impl Into<Self::Expr> + Clone, a: BinomialExtension<impl Into<Self::Expr> + Clone>, b: BinomialExtension<impl Into<Self::Expr> + Clone>, ) -> BinomialExtension<Self::Expr>

Performs an if else on extension elements.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<AB> InstructionAirBuilder for AB
where AB: BaseAirBuilder,

Source§

fn send_instruction( &mut self, shard: impl Into<Self::Expr> + Clone, clk: impl Into<Self::Expr> + Clone, pc: impl Into<Self::Expr>, next_pc: impl Into<Self::Expr>, num_extra_cycles: impl Into<Self::Expr>, opcode: impl Into<Self::Expr>, a: Word<impl Into<Self::Expr>>, b: Word<impl Into<Self::Expr>>, c: Word<impl Into<Self::Expr>>, op_a_0: impl Into<Self::Expr>, op_a_immutable: impl Into<Self::Expr>, is_memory: impl Into<Self::Expr>, is_syscall: impl Into<Self::Expr>, is_halt: impl Into<Self::Expr>, multiplicity: impl Into<Self::Expr>, )

Sends a RISC-V instruction to be processed.
Source§

fn receive_instruction( &mut self, shard: impl Into<Self::Expr> + Clone, clk: impl Into<Self::Expr> + Clone, pc: impl Into<Self::Expr>, next_pc: impl Into<Self::Expr>, num_extra_cycles: impl Into<Self::Expr>, opcode: impl Into<Self::Expr>, a: Word<impl Into<Self::Expr>>, b: Word<impl Into<Self::Expr>>, c: Word<impl Into<Self::Expr>>, op_a_0: impl Into<Self::Expr>, op_a_immutable: impl Into<Self::Expr>, is_memory: impl Into<Self::Expr>, is_syscall: impl Into<Self::Expr>, is_halt: impl Into<Self::Expr>, multiplicity: impl Into<Self::Expr>, )

Receives an ALU operation to be processed.
Source§

fn send_syscall( &mut self, shard: impl Into<Self::Expr> + Clone, clk: impl Into<Self::Expr> + Clone, syscall_id: impl Into<Self::Expr> + Clone, arg1: impl Into<Self::Expr> + Clone, arg2: impl Into<Self::Expr> + Clone, multiplicity: impl Into<Self::Expr>, scope: InteractionScope, )

Sends an syscall operation to be processed (with “ECALL” opcode).
Source§

fn receive_syscall( &mut self, shard: impl Into<Self::Expr> + Clone, clk: impl Into<Self::Expr> + Clone, syscall_id: impl Into<Self::Expr> + Clone, arg1: impl Into<Self::Expr> + Clone, arg2: impl Into<Self::Expr> + Clone, multiplicity: impl Into<Self::Expr>, scope: InteractionScope, )

Receives a syscall operation to be processed.
Source§

impl<T> Instrument for T

Source§

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

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

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

impl<AB, M> MessageBuilder<M> for AB

Source§

fn send(&mut self, _message: M, _scope: InteractionScope)

Sends a message.
Source§

fn receive(&mut self, _message: M, _scope: InteractionScope)

Receives a message.
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

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

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<AB> SepticExtensionAirBuilder for AB
where AB: BaseAirBuilder,

Source§

fn assert_septic_ext_eq<I: Into<Self::Expr>>( &mut self, left: SepticExtension<I>, right: SepticExtension<I>, )

Asserts that the two field extensions are equal.
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.
Source§

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

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

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

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<AB> MachineAirBuilder for AB

Source§

impl<AB> SP1AirBuilder for AB