Skip to main content

Builder

Struct Builder 

Source
pub struct Builder<C: Config> {
    pub poseidon2_constants: Vec<Ext<SP1Field, SP1ExtensionField>>,
    pub program_type: RecursionProgramType,
    /* private fields */
}
Expand description

A builder for the DSL.

Can compile to both assembly and a set of constraints.

Fields§

§poseidon2_constants: Vec<Ext<SP1Field, SP1ExtensionField>>§program_type: RecursionProgramType

Implementations§

Source§

impl<C: Config> Builder<C>

Source

pub fn num2bits_v_circuit( &mut self, num: Var<C::N>, bits: usize, ) -> Vec<Var<C::N>>

Converts a variable to bits inside a circuit.

Source

pub fn num2bits_f_circuit(&mut self, num: Felt<SP1Field>) -> Vec<Var<C::N>>

Converts a felt to bits inside a circuit.

Source

pub fn bits2num_v_circuit(&mut self, bits: &[Var<C::N>]) -> Var<C::N>

Convert bits to a variable inside a circuit.

Source§

impl<C: Config> Builder<C>

Source

pub fn new(program_type: RecursionProgramType) -> Self

Source

pub fn new_sub_builder( variable_count: u32, nb_public_values: Option<Var<C::N>>, p2_hash_num: Var<C::N>, debug: bool, program_type: RecursionProgramType, ) -> Self

Creates a new builder with a given number of counts for each type.

Source

pub fn sub_builder(&self) -> Self

Convenience function for creating a new sub builder.

Source

pub fn push_op(&mut self, op: DslIr<C>)

Pushes an operation to the builder.

Source

pub fn extend_ops(&mut self, ops: impl IntoIterator<Item = DslIr<C>>)

Source

pub fn push_backtrace(&mut self)

Source

pub fn push_traced_op(&mut self, op: DslIr<C>)

Pushes an operation to the builder and records a trace if the “debug” feature is enabled.

Source

pub fn variable_count(&self) -> u32

Source

pub fn into_operations(self) -> Vec<DslIr<C>>

Source

pub fn into_root_block(self) -> DslIrBlock<C>

Source

pub fn get_mut_operations(&mut self) -> &mut Vec<DslIr<C>>

Get a mutable reference to the list of operations. Can be used for adjusting evaluation order using the utility functions from std::mem.

One use case is to move “lazy” evaluation out of a parallel context.

Source

pub fn uninit<V: Variable<C>>(&mut self) -> V

Creates an uninitialized variable.

Source

pub fn eval<V: Variable<C>, E: Into<V::Expression>>(&mut self, expr: E) -> V

Evaluates an expression and returns a variable.

Source

pub fn constant<V: FromConstant<C>>(&mut self, value: V::Constant) -> V

Evaluates a constant expression and returns a variable.

Source

pub fn assign<V: Variable<C>, E: Into<V::Expression>>( &mut self, dst: V, expr: E, )

Assigns an expression to a variable.

Source

pub fn assert_eq<V: Variable<C>>( &mut self, lhs: impl Into<V::Expression>, rhs: impl Into<V::Expression>, )

Asserts that two expressions are equal.

Source

pub fn assert_ne<V: Variable<C>>( &mut self, lhs: impl Into<V::Expression>, rhs: impl Into<V::Expression>, )

Asserts that two expressions are not equal.

Source

pub fn assert_var_eq<LhsExpr: Into<SymbolicVar<C::N>>, RhsExpr: Into<SymbolicVar<C::N>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )

Assert that two vars are equal.

Source

pub fn assert_var_ne<LhsExpr: Into<SymbolicVar<C::N>>, RhsExpr: Into<SymbolicVar<C::N>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )

Assert that two vars are not equal.

Source

pub fn assert_felt_eq<LhsExpr: Into<SymbolicFelt<SP1Field>>, RhsExpr: Into<SymbolicFelt<SP1Field>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )

Assert that two felts are equal.

Source

pub fn assert_felt_ne<LhsExpr: Into<SymbolicFelt<SP1Field>>, RhsExpr: Into<SymbolicFelt<SP1Field>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )

Assert that two felts are not equal.

Source

pub fn assert_ext_eq<LhsExpr: Into<SymbolicExt<SP1Field, SP1ExtensionField>>, RhsExpr: Into<SymbolicExt<SP1Field, SP1ExtensionField>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )

Assert that two exts are equal.

Source

pub fn assert_ext_ne<LhsExpr: Into<SymbolicExt<SP1Field, SP1ExtensionField>>, RhsExpr: Into<SymbolicExt<SP1Field, SP1ExtensionField>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )

Assert that two exts are not equal.

Source

pub fn print_debug(&mut self, val: usize)

Source

pub fn print_v(&mut self, dst: Var<C::N>)

Print a variable.

Source

pub fn print_f(&mut self, dst: Felt<SP1Field>)

Print a felt.

Source

pub fn print_e(&mut self, dst: Ext<SP1Field, SP1ExtensionField>)

Print an ext.

Source

pub fn witness_var(&mut self) -> Var<C::N>

Source

pub fn witness_felt(&mut self) -> Felt<SP1Field>

Source

pub fn witness_ext(&mut self) -> Ext<SP1Field, SP1ExtensionField>

Source

pub fn error(&mut self)

Throws an error.

Source

pub fn commit_public_value(&mut self, val: Felt<SP1Field>)

Register and commits a felt as public value. This value will be constrained when verified.

Source

pub fn commit_vkey_hash_circuit(&mut self, var: Var<C::N>)

Source

pub fn commit_committed_values_digest_circuit(&mut self, var: Var<C::N>)

Source

pub fn commit_exit_code_circuit(&mut self, var: Var<C::N>)

Source

pub fn commit_proof_nonce_circuit(&mut self, var: Var<C::N>)

Source

pub fn commit_vk_root_circuit(&mut self, var: Var<C::N>)

Source

pub fn reduce_e(&mut self, ext: Ext<SP1Field, SP1ExtensionField>)

Source

pub fn felt2var_circuit(&mut self, felt: Felt<SP1Field>) -> Var<C::N>

Source§

impl<C: Config> Builder<C>

Source

pub fn generator(&mut self) -> Felt<SP1Field>

The generator for the field.

Reference: [p3_koala_bear::KoalaBear]

Source

pub fn select_v( &mut self, cond: Var<C::N>, a: Var<C::N>, b: Var<C::N>, ) -> Var<C::N>

Select a variable based on a condition.

Source

pub fn select_f( &mut self, cond: Var<C::N>, a: Felt<SP1Field>, b: Felt<SP1Field>, ) -> Felt<SP1Field>

Select a felt based on a condition.

Source

pub fn select_ef( &mut self, cond: Var<C::N>, a: Ext<SP1Field, SP1ExtensionField>, b: Ext<SP1Field, SP1ExtensionField>, ) -> Ext<SP1Field, SP1ExtensionField>

Select an extension based on a condition.

Source

pub fn exp_power_of_2<V: Variable<C>, E: Into<V::Expression>>( &mut self, e: E, power_log: usize, ) -> V

Exponentiates a variable to a power of two.

Source

pub fn exp_f_bits( &mut self, x: Felt<SP1Field>, power_bits: Vec<Var<C::N>>, ) -> Felt<SP1Field>

Exponentiates a felt to a list of bits in little endian.

Source

pub fn exp_e_bits( &mut self, x: Ext<SP1Field, SP1ExtensionField>, power_bits: Vec<Var<C::N>>, ) -> Ext<SP1Field, SP1ExtensionField>

Exponentiates a extension to a list of bits in little endian.

Source

pub fn exp_power_of_2_v_circuit<V>( &mut self, base: impl Into<V::Expression>, power_log: usize, ) -> V
where V: Copy + Mul<Output = V::Expression> + Variable<C>,

Exponentiates a variable to a list of bits in little endian inside a circuit.

Source

pub fn ext_from_base_slice( &mut self, arr: &[Felt<SP1Field>], ) -> Ext<SP1Field, SP1ExtensionField>

Creates an ext from a slice of felts.

Source

pub fn felts2ext( &mut self, felts: &[Felt<SP1Field>], ) -> Ext<SP1Field, SP1ExtensionField>

Source

pub fn ext2felt_circuit( &mut self, value: Ext<SP1Field, SP1ExtensionField>, ) -> [Felt<SP1Field>; 4]

Converts an ext to a slice of felts inside a circuit.

Trait Implementations§

Source§

impl<C: Config> CircuitV2Builder<C> for Builder<C>

Source§

fn num2bits_v2_f( &mut self, num: Felt<SP1Field>, num_bits: usize, ) -> Vec<Felt<SP1Field>>

Converts a felt to bits inside a circuit.

Source§

fn prefix_sum_checks_v2( &mut self, point_1: Vec<Felt<SP1Field>>, point_2: Vec<Ext<SP1Field, SP1ExtensionField>>, ) -> (Ext<SP1Field, SP1ExtensionField>, Felt<SP1Field>)

A version of the prefix_sum_checks that uses the LagrangeEval precompile.

Source§

fn poseidon2_permute_v2( &mut self, array: [Felt<SP1Field>; 16], ) -> [Felt<SP1Field>; 16]

Applies the Poseidon2 permutation to the given array.

Source§

fn ext2felt_v2( &mut self, ext: Ext<SP1Field, SP1ExtensionField>, ) -> [Felt<SP1Field>; 4]

Decomposes an ext into its felt coordinates.

Source§

fn add_curve_v2( &mut self, point1: SepticCurve<Felt<SP1Field>>, point2: SepticCurve<Felt<SP1Field>>, ) -> SepticCurve<Felt<SP1Field>>

Adds two septic elliptic curve points.

Source§

fn assert_digest_zero_v2( &mut self, is_real: Felt<SP1Field>, digest: SepticDigest<Felt<SP1Field>>, )

Asserts that the digest is the zero digest when is_real is non-zero.

Source§

fn select_global_cumulative_sum( &mut self, is_first_execution_shard: Felt<SP1Field>, vk_digest: SepticDigest<Felt<SP1Field>>, ) -> SepticDigest<Felt<SP1Field>>

Returns the zero digest when is_first_execution_shard is zero, and returns the vk_digest when is_first_execution_shard is one. It is assumed that is_first_execution_shard is already checked to be a boolean.

Source§

fn hint_felt_v2(&mut self) -> Felt<SP1Field>

Hint a single felt.

Source§

fn hint_ext_v2(&mut self) -> Ext<SP1Field, SP1ExtensionField>

Hint a single ext.

Source§

fn hint_felts_v2(&mut self, len: usize) -> Vec<Felt<SP1Field>>

Hint a vector of felts.

Source§

fn hint_exts_v2(&mut self, len: usize) -> Vec<Ext<SP1Field, SP1ExtensionField>>

Hint a vector of exts.

Source§

fn bits2num_v2_f( &mut self, bits: impl IntoIterator<Item = Felt<SP1Field>>, ) -> Felt<SP1Field>

Source§

fn sum_digest_v2( &mut self, digests: Vec<SepticDigest<Felt<SP1Field>>>, ) -> SepticDigest<Felt<SP1Field>>

Source§

fn commit_public_values_v2( &mut self, public_values: RecursionPublicValues<Felt<SP1Field>>, )

Source§

fn cycle_tracker_v2_enter(&mut self, name: impl Into<Cow<'static, str>>)

Source§

fn cycle_tracker_v2_exit(&mut self)

Source§

impl<C: Debug + Config> Debug for Builder<C>
where C::N: Debug,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<C: Config> Default for Builder<C>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<C> Freeze for Builder<C>

§

impl<C> !RefUnwindSafe for Builder<C>

§

impl<C> !Send for Builder<C>

§

impl<C> !Sync for Builder<C>

§

impl<C> Unpin for Builder<C>

§

impl<C> UnsafeUnpin for Builder<C>

§

impl<C> UnwindSafe for Builder<C>
where <C as Config>::N: UnwindSafe,

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> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<F, EF, E> ExtensionOperand<F, EF> for E
where F: Field, EF: ExtensionField<F>, E: Any,

Source§

fn to_operand(self) -> ExtOperand<F, EF>

Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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<T> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
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<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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.
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