pub struct Builder<C: Config> {
pub program_type: RecursionProgramType,
/* private fields */
}
Expand description
A builder for the DSL.
Can compile to both assembly and a set of constraints.
Fields§
§program_type: RecursionProgramType
Implementations§
Source§impl<C: Config> Builder<C>
impl<C: Config> Builder<C>
Sourcepub fn num2bits_v(&mut self, num: Var<C::N>) -> Array<C, Var<C::N>>
pub fn num2bits_v(&mut self, num: Var<C::N>) -> Array<C, Var<C::N>>
Converts a variable to LE bits.
Sourcepub fn range_check_v(&mut self, num: Var<C::N>, num_bits: usize)
pub fn range_check_v(&mut self, num: Var<C::N>, num_bits: usize)
Range checks a variable to a certain number of bits.
Sourcepub fn num2bits_v_circuit(
&mut self,
num: Var<C::N>,
bits: usize,
) -> Vec<Var<C::N>>
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.
Sourcepub fn range_check_f(&mut self, num: Felt<C::F>, num_bits: usize)
pub fn range_check_f(&mut self, num: Felt<C::F>, num_bits: usize)
Range checks a felt to a certain number of bits.
Sourcepub fn num2bits_f_circuit(&mut self, num: Felt<C::F>) -> Vec<Var<C::N>>
pub fn num2bits_f_circuit(&mut self, num: Felt<C::F>) -> Vec<Var<C::N>>
Converts a felt to bits inside a circuit.
Sourcepub fn bits2num_v(&mut self, bits: &Array<C, Var<C::N>>) -> Var<C::N>
pub fn bits2num_v(&mut self, bits: &Array<C, Var<C::N>>) -> Var<C::N>
Convert bits to a variable.
Sourcepub fn bits2num_v_circuit(&mut self, bits: &[Var<C::N>]) -> Var<C::N>
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>
impl<C: Config> Builder<C>
pub fn new(program_type: RecursionProgramType) -> Self
Sourcepub 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
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.
Sourcepub fn sub_builder(&self) -> Self
pub fn sub_builder(&self) -> Self
Convenience function for creating a new sub builder.
pub fn extend_ops(&mut self, ops: impl IntoIterator<Item = DslIr<C>>)
pub fn push_backtrace(&mut self)
Sourcepub fn push_traced_op(&mut self, op: DslIr<C>)
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.
pub fn variable_count(&self) -> u32
pub fn set_variable_count(&mut self, variable_count: u32)
pub fn into_operations(self) -> Vec<DslIr<C>>
pub fn into_root_block(self) -> DslIrBlock<C>
Sourcepub fn get_mut_operations(&mut self) -> &mut Vec<DslIr<C>>
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.
Sourcepub fn eval<V: Variable<C>, E: Into<V::Expression>>(&mut self, expr: E) -> V
pub fn eval<V: Variable<C>, E: Into<V::Expression>>(&mut self, expr: E) -> V
Evaluates an expression and returns a variable.
Sourcepub fn constant<V: FromConstant<C>>(&mut self, value: V::Constant) -> V
pub fn constant<V: FromConstant<C>>(&mut self, value: V::Constant) -> V
Evaluates a constant expression and returns a variable.
Sourcepub fn assign<V: Variable<C>, E: Into<V::Expression>>(
&mut self,
dst: V,
expr: E,
)
pub fn assign<V: Variable<C>, E: Into<V::Expression>>( &mut self, dst: V, expr: E, )
Assigns an expression to a variable.
Sourcepub fn assert_eq<V: Variable<C>>(
&mut self,
lhs: impl Into<V::Expression>,
rhs: impl Into<V::Expression>,
)
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.
Sourcepub fn assert_ne<V: Variable<C>>(
&mut self,
lhs: impl Into<V::Expression>,
rhs: impl Into<V::Expression>,
)
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.
Sourcepub fn assert_var_eq<LhsExpr: Into<SymbolicVar<C::N>>, RhsExpr: Into<SymbolicVar<C::N>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
)
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.
Sourcepub fn assert_var_ne<LhsExpr: Into<SymbolicVar<C::N>>, RhsExpr: Into<SymbolicVar<C::N>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
)
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.
Sourcepub fn assert_felt_eq<LhsExpr: Into<SymbolicFelt<C::F>>, RhsExpr: Into<SymbolicFelt<C::F>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
)
pub fn assert_felt_eq<LhsExpr: Into<SymbolicFelt<C::F>>, RhsExpr: Into<SymbolicFelt<C::F>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )
Assert that two felts are equal.
Sourcepub fn assert_felt_ne<LhsExpr: Into<SymbolicFelt<C::F>>, RhsExpr: Into<SymbolicFelt<C::F>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
)
pub fn assert_felt_ne<LhsExpr: Into<SymbolicFelt<C::F>>, RhsExpr: Into<SymbolicFelt<C::F>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )
Assert that two felts are not equal.
Sourcepub fn assert_usize_eq<LhsExpr: Into<SymbolicUsize<C::N>>, RhsExpr: Into<SymbolicUsize<C::N>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
)
pub fn assert_usize_eq<LhsExpr: Into<SymbolicUsize<C::N>>, RhsExpr: Into<SymbolicUsize<C::N>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )
Assert that two usizes are equal.
Sourcepub fn assert_usize_ne(
&mut self,
lhs: impl Into<SymbolicUsize<C::N>>,
rhs: impl Into<SymbolicUsize<C::N>>,
)
pub fn assert_usize_ne( &mut self, lhs: impl Into<SymbolicUsize<C::N>>, rhs: impl Into<SymbolicUsize<C::N>>, )
Assert that two usizes are not equal.
Sourcepub fn assert_ext_eq<LhsExpr: Into<SymbolicExt<C::F, C::EF>>, RhsExpr: Into<SymbolicExt<C::F, C::EF>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
)
pub fn assert_ext_eq<LhsExpr: Into<SymbolicExt<C::F, C::EF>>, RhsExpr: Into<SymbolicExt<C::F, C::EF>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )
Assert that two exts are equal.
Sourcepub fn assert_ext_ne<LhsExpr: Into<SymbolicExt<C::F, C::EF>>, RhsExpr: Into<SymbolicExt<C::F, C::EF>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
)
pub fn assert_ext_ne<LhsExpr: Into<SymbolicExt<C::F, C::EF>>, RhsExpr: Into<SymbolicExt<C::F, C::EF>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, )
Assert that two exts are not equal.
pub fn lt(&mut self, lhs: Var<C::N>, rhs: Var<C::N>) -> Var<C::N>
Sourcepub fn if_eq<LhsExpr: Into<SymbolicVar<C::N>>, RhsExpr: Into<SymbolicVar<C::N>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
) -> IfBuilder<'_, C>
pub fn if_eq<LhsExpr: Into<SymbolicVar<C::N>>, RhsExpr: Into<SymbolicVar<C::N>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, ) -> IfBuilder<'_, C>
Evaluate a block of operations if two expressions are equal.
Sourcepub fn if_ne<LhsExpr: Into<SymbolicVar<C::N>>, RhsExpr: Into<SymbolicVar<C::N>>>(
&mut self,
lhs: LhsExpr,
rhs: RhsExpr,
) -> IfBuilder<'_, C>
pub fn if_ne<LhsExpr: Into<SymbolicVar<C::N>>, RhsExpr: Into<SymbolicVar<C::N>>>( &mut self, lhs: LhsExpr, rhs: RhsExpr, ) -> IfBuilder<'_, C>
Evaluate a block of operations if two expressions are not equal.
Sourcepub fn range(
&mut self,
start: impl Into<Usize<C::N>>,
end: impl Into<Usize<C::N>>,
) -> RangeBuilder<'_, C>
pub fn range( &mut self, start: impl Into<Usize<C::N>>, end: impl Into<Usize<C::N>>, ) -> RangeBuilder<'_, C>
Evaluate a block of operations over a range from start to end.
Sourcepub fn break_loop(&mut self)
pub fn break_loop(&mut self)
Break out of a loop.
pub fn print_debug(&mut self, val: usize)
Sourcepub fn hint_felts(&mut self) -> Array<C, Felt<C::F>>
pub fn hint_felts(&mut self) -> Array<C, Felt<C::F>>
Hint a vector of felts.
pub fn witness_var(&mut self) -> Var<C::N>
pub fn witness_felt(&mut self) -> Felt<C::F>
pub fn witness_ext(&mut self) -> Ext<C::F, C::EF>
Sourcepub fn materialize(&mut self, num: Usize<C::N>) -> Var<C::N>
pub fn materialize(&mut self, num: Usize<C::N>) -> Var<C::N>
Materializes a usize into a variable.
Sourcepub fn register_public_value(&mut self, val: Felt<C::F>)
pub fn register_public_value(&mut self, val: Felt<C::F>)
Register a felt as public value. This is append to the proof’s public values buffer.
Sourcepub fn commit_public_value(&mut self, val: Felt<C::F>)
pub fn commit_public_value(&mut self, val: Felt<C::F>)
Register and commits a felt as public value. This value will be constrained when verified.
Sourcepub fn commit_public_values(&mut self, vals: &Array<C, Felt<C::F>>)
pub fn commit_public_values(&mut self, vals: &Array<C, Felt<C::F>>)
Commits an array of felts in public values.
pub fn commit_vkey_hash_circuit(&mut self, var: Var<C::N>)
pub fn commit_committed_values_digest_circuit(&mut self, var: Var<C::N>)
pub fn reduce_e(&mut self, ext: Ext<C::F, C::EF>)
pub fn felt2var_circuit(&mut self, felt: Felt<C::F>) -> Var<C::N>
pub fn cycle_tracker(&mut self, name: &str)
pub fn halt(&mut self)
Source§impl<C: Config> Builder<C>
impl<C: Config> Builder<C>
Sourcepub fn array<V: MemVariable<C>>(
&mut self,
len: impl Into<Usize<C::N>>,
) -> Array<C, V>
pub fn array<V: MemVariable<C>>( &mut self, len: impl Into<Usize<C::N>>, ) -> Array<C, V>
Initialize an array of fixed length len
. The entries will be uninitialized.
Sourcepub fn vec<V: MemVariable<C>>(&mut self, v: Vec<V>) -> Array<C, V>
pub fn vec<V: MemVariable<C>>(&mut self, v: Vec<V>) -> Array<C, V>
Creates an array from a vector.
Sourcepub fn dyn_array<V: MemVariable<C>>(
&mut self,
len: impl Into<Usize<C::N>>,
) -> Array<C, V>
pub fn dyn_array<V: MemVariable<C>>( &mut self, len: impl Into<Usize<C::N>>, ) -> Array<C, V>
Creates a dynamic array for a length.
pub fn get<V: MemVariable<C>, I: Into<Usize<C::N>>>( &mut self, slice: &Array<C, V>, index: I, ) -> V
pub fn get_ptr<V: MemVariable<C>, I: Into<Usize<C::N>>>( &mut self, slice: &Array<C, V>, index: I, ) -> Ptr<C::N>
pub fn set<V: MemVariable<C>, I: Into<Usize<C::N>>, Expr: Into<V::Expression>>( &mut self, slice: &mut Array<C, V>, index: I, value: Expr, )
pub fn set_value<V: MemVariable<C>, I: Into<Usize<C::N>>>( &mut self, slice: &mut Array<C, V>, index: I, value: V, )
Source§impl<C: Config> Builder<C>
impl<C: Config> Builder<C>
Sourcepub fn poseidon2_permute(
&mut self,
array: &Array<C, Felt<C::F>>,
) -> Array<C, Felt<C::F>>
pub fn poseidon2_permute( &mut self, array: &Array<C, Felt<C::F>>, ) -> Array<C, Felt<C::F>>
Applies the Poseidon2 permutation to the given array.
Reference: [p3_poseidon2::Poseidon2]
Sourcepub fn poseidon2_permute_mut(&mut self, array: &Array<C, Felt<C::F>>)
pub fn poseidon2_permute_mut(&mut self, array: &Array<C, Felt<C::F>>)
Applies the Poseidon2 permutation to the given array.
Reference: [p3_poseidon2::Poseidon2]
Sourcepub fn poseidon2_absorb(
&mut self,
p2_hash_and_absorb_num: Var<C::N>,
input: &Array<C, Felt<C::F>>,
)
pub fn poseidon2_absorb( &mut self, p2_hash_and_absorb_num: Var<C::N>, input: &Array<C, Felt<C::F>>, )
Applies the Poseidon2 absorb function to the given array.
Reference: p3_symmetric::PaddingFreeSponge
Sourcepub fn poseidon2_finalize_mut(
&mut self,
p2_hash_num: Var<C::N>,
output: &Array<C, Felt<C::F>>,
)
pub fn poseidon2_finalize_mut( &mut self, p2_hash_num: Var<C::N>, output: &Array<C, Felt<C::F>>, )
Applies the Poseidon2 finalize to the given hash number.
Reference: p3_symmetric::PaddingFreeSponge
Sourcepub fn poseidon2_compress(
&mut self,
left: &Array<C, Felt<C::F>>,
right: &Array<C, Felt<C::F>>,
) -> Array<C, Felt<C::F>>
pub fn poseidon2_compress( &mut self, left: &Array<C, Felt<C::F>>, right: &Array<C, Felt<C::F>>, ) -> Array<C, Felt<C::F>>
Applies the Poseidon2 compression function to the given array.
Reference: p3_symmetric::TruncatedPermutation
Sourcepub fn poseidon2_compress_x(
&mut self,
result: &mut Array<C, Felt<C::F>>,
left: &Array<C, Felt<C::F>>,
right: &Array<C, Felt<C::F>>,
)
pub fn poseidon2_compress_x( &mut self, result: &mut Array<C, Felt<C::F>>, left: &Array<C, Felt<C::F>>, right: &Array<C, Felt<C::F>>, )
Applies the Poseidon2 compression to the given array.
Reference: p3_symmetric::TruncatedPermutation
Sourcepub fn poseidon2_hash(
&mut self,
array: &Array<C, Felt<C::F>>,
) -> Array<C, Felt<C::F>>
pub fn poseidon2_hash( &mut self, array: &Array<C, Felt<C::F>>, ) -> Array<C, Felt<C::F>>
Applies the Poseidon2 permutation to the given array.
Reference: p3_symmetric::PaddingFreeSponge
pub fn poseidon2_hash_x( &mut self, array: &Array<C, Array<C, Felt<C::F>>>, ) -> Array<C, Felt<C::F>>
pub fn poseidon2_hash_ext( &mut self, array: &Array<C, Array<C, Ext<C::F, C::EF>>>, ) -> Array<C, Felt<C::F>>
Source§impl<C: Config> Builder<C>
impl<C: Config> Builder<C>
Sourcepub fn generator(&mut self) -> Felt<C::F>
pub fn generator(&mut self) -> Felt<C::F>
The generator for the field.
Reference: p3_baby_bear::BabyBear
Sourcepub fn select_v(
&mut self,
cond: Var<C::N>,
a: Var<C::N>,
b: Var<C::N>,
) -> Var<C::N>
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.
Sourcepub fn select_f(
&mut self,
cond: Var<C::N>,
a: Felt<C::F>,
b: Felt<C::F>,
) -> Felt<C::F>
pub fn select_f( &mut self, cond: Var<C::N>, a: Felt<C::F>, b: Felt<C::F>, ) -> Felt<C::F>
Select a felt based on a condition.
Sourcepub fn select_ef(
&mut self,
cond: Var<C::N>,
a: Ext<C::F, C::EF>,
b: Ext<C::F, C::EF>,
) -> Ext<C::F, C::EF>
pub fn select_ef( &mut self, cond: Var<C::N>, a: Ext<C::F, C::EF>, b: Ext<C::F, C::EF>, ) -> Ext<C::F, C::EF>
Select an extension based on a condition.
Sourcepub fn exp_power_of_2<V: Variable<C>, E: Into<V::Expression>>(
&mut self,
e: E,
power_log: usize,
) -> V
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.
Sourcepub fn exp_bits<V>(&mut self, x: V, power_bits: &Array<C, Var<C::N>>) -> V
pub fn exp_bits<V>(&mut self, x: V, power_bits: &Array<C, Var<C::N>>) -> V
Exponentializes a variable to an array of bits in little endian.
Sourcepub fn exp_f_bits(
&mut self,
x: Felt<C::F>,
power_bits: Vec<Var<C::N>>,
) -> Felt<C::F>
pub fn exp_f_bits( &mut self, x: Felt<C::F>, power_bits: Vec<Var<C::N>>, ) -> Felt<C::F>
Exponentiates a felt to a list of bits in little endian.
Sourcepub fn exp_e_bits(
&mut self,
x: Ext<C::F, C::EF>,
power_bits: Vec<Var<C::N>>,
) -> Ext<C::F, C::EF>
pub fn exp_e_bits( &mut self, x: Ext<C::F, C::EF>, power_bits: Vec<Var<C::N>>, ) -> Ext<C::F, C::EF>
Exponentiates a extension to a list of bits in little endian.
Sourcepub fn exp_reverse_bits_len<V>(
&mut self,
x: V,
power_bits: &Array<C, Var<C::N>>,
bit_len: impl Into<Usize<C::N>>,
) -> V
pub fn exp_reverse_bits_len<V>( &mut self, x: V, power_bits: &Array<C, Var<C::N>>, bit_len: impl Into<Usize<C::N>>, ) -> V
Exponetiates a variable to a list of reversed bits with a given length.
Reference: [p3_util::reverse_bits_len]
Sourcepub fn exp_reverse_bits_len_fast(
&mut self,
x: Felt<C::F>,
power_bits: &Array<C, Var<C::N>>,
bit_len: impl Into<Usize<C::N>>,
) -> Felt<C::F>
pub fn exp_reverse_bits_len_fast( &mut self, x: Felt<C::F>, power_bits: &Array<C, Var<C::N>>, bit_len: impl Into<Usize<C::N>>, ) -> Felt<C::F>
A version of exp_reverse_bits_len
that uses the ExpReverseBitsLen precompile.
Sourcepub fn exp_power_of_2_v<V>(
&mut self,
base: impl Into<V::Expression>,
power_log: impl Into<Usize<C::N>>,
) -> V
pub fn exp_power_of_2_v<V>( &mut self, base: impl Into<V::Expression>, power_log: impl Into<Usize<C::N>>, ) -> V
Exponentiates a variable to a list of bits in little endian.
Sourcepub fn exp_power_of_2_v_circuit<V>(
&mut self,
base: impl Into<V::Expression>,
power_log: usize,
) -> V
pub fn exp_power_of_2_v_circuit<V>( &mut self, base: impl Into<V::Expression>, power_log: usize, ) -> V
Exponentiates a variable to a list of bits in little endian inside a circuit.
Sourcepub fn sll<V>(
&mut self,
base: impl Into<V::Expression>,
shift: Usize<C::N>,
) -> V
pub fn sll<V>( &mut self, base: impl Into<V::Expression>, shift: Usize<C::N>, ) -> V
Multiplies base
by 2^{log_power}
.
Sourcepub fn ext_from_base_slice(&mut self, arr: &[Felt<C::F>]) -> Ext<C::F, C::EF>
pub fn ext_from_base_slice(&mut self, arr: &[Felt<C::F>]) -> Ext<C::F, C::EF>
Creates an ext from a slice of felts.
pub fn felts2ext(&mut self, felts: &[Felt<C::F>]) -> Ext<C::F, C::EF>
Trait Implementations§
Source§impl<C: Config<F = BabyBear>> CircuitV2Builder<C> for Builder<C>
impl<C: Config<F = BabyBear>> CircuitV2Builder<C> for Builder<C>
Source§fn num2bits_v2_f(&mut self, num: Felt<C::F>, num_bits: usize) -> Vec<Felt<C::F>>
fn num2bits_v2_f(&mut self, num: Felt<C::F>, num_bits: usize) -> Vec<Felt<C::F>>
Converts a felt to bits inside a circuit.
Source§fn exp_reverse_bits_v2(
&mut self,
input: Felt<C::F>,
power_bits: Vec<Felt<C::F>>,
) -> Felt<C::F>
fn exp_reverse_bits_v2( &mut self, input: Felt<C::F>, power_bits: Vec<Felt<C::F>>, ) -> Felt<C::F>
A version of exp_reverse_bits_len
that uses the ExpReverseBitsLen precompile.
Source§fn batch_fri_v2(
&mut self,
alpha_pows: Vec<Ext<C::F, C::EF>>,
p_at_zs: Vec<Ext<C::F, C::EF>>,
p_at_xs: Vec<Felt<C::F>>,
) -> Ext<C::F, C::EF>
fn batch_fri_v2( &mut self, alpha_pows: Vec<Ext<C::F, C::EF>>, p_at_zs: Vec<Ext<C::F, C::EF>>, p_at_xs: Vec<Felt<C::F>>, ) -> Ext<C::F, C::EF>
A version of the batch_fri
that uses the BatchFRI precompile.
Source§fn poseidon2_permute_v2(&mut self, array: [Felt<C::F>; 16]) -> [Felt<C::F>; 16]
fn poseidon2_permute_v2(&mut self, array: [Felt<C::F>; 16]) -> [Felt<C::F>; 16]
Applies the Poseidon2 permutation to the given array.
Source§fn poseidon2_hash_v2(&mut self, input: &[Felt<C::F>]) -> [Felt<C::F>; 8]
fn poseidon2_hash_v2(&mut self, input: &[Felt<C::F>]) -> [Felt<C::F>; 8]
Applies the Poseidon2 hash function to the given array.
Reference: p3_symmetric::PaddingFreeSponge
Source§fn poseidon2_compress_v2(
&mut self,
input: impl IntoIterator<Item = Felt<C::F>>,
) -> [Felt<C::F>; 8]
fn poseidon2_compress_v2( &mut self, input: impl IntoIterator<Item = Felt<C::F>>, ) -> [Felt<C::F>; 8]
Applies the Poseidon2 compression function to the given array.
Reference: p3_symmetric::TruncatedPermutation
Source§fn fri_fold_v2(
&mut self,
input: CircuitV2FriFoldInput<C>,
) -> CircuitV2FriFoldOutput<C>
fn fri_fold_v2( &mut self, input: CircuitV2FriFoldInput<C>, ) -> CircuitV2FriFoldOutput<C>
Runs FRI fold.
Source§fn ext2felt_v2(&mut self, ext: Ext<C::F, C::EF>) -> [Felt<C::F>; 4]
fn ext2felt_v2(&mut self, ext: Ext<C::F, C::EF>) -> [Felt<C::F>; 4]
Decomposes an ext into its felt coordinates.
Source§fn add_curve_v2(
&mut self,
point1: SepticCurve<Felt<C::F>>,
point2: SepticCurve<Felt<C::F>>,
) -> SepticCurve<Felt<C::F>>
fn add_curve_v2( &mut self, point1: SepticCurve<Felt<C::F>>, point2: SepticCurve<Felt<C::F>>, ) -> SepticCurve<Felt<C::F>>
Adds two septic elliptic curve points.
Source§fn assert_digest_zero_v2(
&mut self,
is_real: Felt<C::F>,
digest: SepticDigest<Felt<C::F>>,
)
fn assert_digest_zero_v2( &mut self, is_real: Felt<C::F>, digest: SepticDigest<Felt<C::F>>, )
Asserts that the digest
is the zero digest when is_real
is non-zero.
Source§fn select_global_cumulative_sum(
&mut self,
is_first_shard: Felt<C::F>,
vk_digest: SepticDigest<Felt<C::F>>,
) -> SepticDigest<Felt<C::F>>
fn select_global_cumulative_sum( &mut self, is_first_shard: Felt<C::F>, vk_digest: SepticDigest<Felt<C::F>>, ) -> SepticDigest<Felt<C::F>>
Returns the zero digest when is_first_shard
is zero, and returns the vk_digest
when
is_first_shard
is one. It is assumed that is_first_shard
is already checked to be a
boolean.
Source§fn hint_felt_v2(&mut self) -> Felt<C::F>
fn hint_felt_v2(&mut self) -> Felt<C::F>
Hint a single felt.
fn bits2num_v2_f( &mut self, bits: impl IntoIterator<Item = Felt<<C as Config>::F>>, ) -> Felt<<C as Config>::F>
fn sum_digest_v2( &mut self, digests: Vec<SepticDigest<Felt<C::F>>>, ) -> SepticDigest<Felt<C::F>>
fn commit_public_values_v2( &mut self, public_values: RecursionPublicValues<Felt<C::F>>, )
fn cycle_tracker_v2_enter(&mut self, name: impl Into<Cow<'static, str>>)
fn cycle_tracker_v2_exit(&mut self)
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> UnwindSafe for Builder<C>
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
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<F, EF, E> ExtensionOperand<F, EF> for E
impl<F, EF, E> ExtensionOperand<F, EF> for E
fn to_operand(self) -> ExtOperand<F, EF>
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.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>
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>
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 moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
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
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
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
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.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
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.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
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.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
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.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
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.