From b3904d32d29f26101178df560d21a0b5287580dd Mon Sep 17 00:00:00 2001 From: bing Date: Tue, 3 Oct 2023 13:17:57 +0800 Subject: [PATCH 1/8] first --- starky/src/evaluation_frame.rs | 133 +++++++++++++++++++++++++++++++ starky/src/fibonacci_stark.rs | 55 ++++++++----- starky/src/lib.rs | 1 + starky/src/permutation.rs | 14 ++-- starky/src/prover.rs | 14 ++-- starky/src/recursive_verifier.rs | 23 +++--- starky/src/stark.rs | 29 ++++--- starky/src/stark_testing.rs | 52 ++++++------ starky/src/vanishing_poly.rs | 5 +- starky/src/verifier.rs | 20 +++-- 10 files changed, 248 insertions(+), 98 deletions(-) create mode 100644 starky/src/evaluation_frame.rs diff --git a/starky/src/evaluation_frame.rs b/starky/src/evaluation_frame.rs new file mode 100644 index 0000000000..74324cb88c --- /dev/null +++ b/starky/src/evaluation_frame.rs @@ -0,0 +1,133 @@ +use plonky2::field::packed::PackedField; +use plonky2::field::types::Field; + +/// A trait for viewing an evaluation frame of a STARK table. +/// +/// It allows to access the current and next rows at a given step +/// and can be used to implement constraint evaluation both natively +/// and recursively. +pub trait StarkEvaluationFrame: Sized +where + F: Field, + P: PackedField, +{ + /// The number of columns for the STARK table this evaluation frame views. + const COLUMNS: usize; + const PUBLIC_INPUTS: usize; + + /// Returns the local values (i.e. current row) for this evaluation frame. + fn get_local_values(&self) -> &[P]; + /// Returns the next values (i.e. next row) for this evaluation frame. + fn get_next_values(&self) -> &[P]; + + fn get_public_inputs(&self) -> &[P::Scalar]; + + /// Outputs a new evaluation frame from the provided local and next values. + /// + /// **NOTE**: Concrete implementations of this method SHOULD ensure that + /// the provided slices lengths match the `Self::COLUMNS` value. + fn from_values(lv: &[P], nv: &[P], public_inputs: &[P::Scalar]) -> Self; +} +pub struct StarkFrame +where + F: Field, + P: PackedField, +{ + local_values: [P; N], + next_values: [P; N], + public_inputs: [P::Scalar; N2], +} + +impl StarkEvaluationFrame for StarkFrame +where + F: Field, + P: PackedField, +{ + const COLUMNS: usize = N; + const PUBLIC_INPUTS: usize = N2; + + fn get_local_values(&self) -> &[P] { + &self.local_values + } + + fn get_next_values(&self) -> &[P] { + &self.next_values + } + + fn get_public_inputs(&self) -> &[P::Scalar] { + &self.public_inputs + } + + fn from_values(lv: &[P], nv: &[P], public_inputs: &[P::Scalar]) -> Self { + assert_eq!(lv.len(), Self::COLUMNS); + assert_eq!(nv.len(), Self::COLUMNS); + assert_eq!(public_inputs.len(), Self::PUBLIC_INPUTS); + + Self { + local_values: lv.try_into().unwrap(), + next_values: nv.try_into().unwrap(), + public_inputs: public_inputs.try_into().unwrap(), + } + } +} + +/// A trait for viewing an evaluation frame of a STARK table. +/// +/// It allows to access the current and next rows at a given step +/// and can be used to implement constraint evaluation both natively +/// and recursively. +pub trait StarkEvaluationFrameTarget: Sized { + /// The number of columns for the STARK table this evaluation frame views. + const COLUMNS: usize; + const PUBLIC_INPUTS: usize; + + /// Returns the local values (i.e. current row) for this evaluation frame. + fn get_local_values(&self) -> &[T]; + /// Returns the next values (i.e. next row) for this evaluation frame. + fn get_next_values(&self) -> &[T]; + + fn get_public_inputs(&self) -> &[T]; + + /// Outputs a new evaluation frame from the provided local and next values. + /// + /// **NOTE**: Concrete implementations of this method SHOULD ensure that + /// the provided slices lengths match the `Self::COLUMNS` value. + fn from_values(lv: &[T], nv: &[T], public_inputs: &[T]) -> Self; +} + +pub struct StarkFrameTarget { + local_values: [T; N], + next_values: [T; N], + public_inputs: [T; N2], +} + +impl StarkEvaluationFrameTarget + for StarkFrameTarget +{ + const COLUMNS: usize = N; + const PUBLIC_INPUTS: usize = N2; + + fn get_local_values(&self) -> &[T] { + &self.local_values + } + + fn get_next_values(&self) -> &[T] { + &self.next_values + } + + fn get_public_inputs(&self) -> &[T] { + &self.public_inputs + } + + fn from_values(lv: &[T], nv: &[T], public_inputs: &[T]) -> Self { + assert_eq!(lv.len(), Self::COLUMNS); + assert_eq!(nv.len(), Self::COLUMNS); + assert_eq!(public_inputs.len(), Self::PUBLIC_INPUTS); + + Self { + local_values: lv.try_into().unwrap(), + next_values: nv.try_into().unwrap(), + public_inputs: public_inputs.try_into().unwrap(), + } + } +} diff --git a/starky/src/fibonacci_stark.rs b/starky/src/fibonacci_stark.rs index 24108f008e..2deee1af36 100644 --- a/starky/src/fibonacci_stark.rs +++ b/starky/src/fibonacci_stark.rs @@ -6,13 +6,16 @@ use plonky2::field::extension::{Extendable, FieldExtension}; use plonky2::field::packed::PackedField; use plonky2::field::polynomial::PolynomialValues; use plonky2::hash::hash_types::RichField; +use plonky2::iop::ext_target::ExtensionTarget; use plonky2::plonk::circuit_builder::CircuitBuilder; use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer}; +use crate::evaluation_frame::{ + StarkEvaluationFrame, StarkEvaluationFrameTarget, StarkFrame, StarkFrameTarget, +}; use crate::permutation::PermutationPair; use crate::stark::Stark; use crate::util::trace_rows_to_poly_values; -use crate::vars::{StarkEvaluationTargets, StarkEvaluationVars}; /// Toy STARK system used for testing. /// Computes a Fibonacci sequence with state `[x0, x1, i, j]` using the state transition @@ -58,56 +61,65 @@ impl, const D: usize> FibonacciStark { } impl, const D: usize> Stark for FibonacciStark { - const COLUMNS: usize = 4; + type EvaluationFrame = StarkFrame + where + FE: FieldExtension, + P: PackedField; + + type EvaluationFrameTarget = StarkFrameTarget, 3, 3>; + + const COLUMNS: usize = 3; const PUBLIC_INPUTS: usize = 3; fn eval_packed_generic( &self, - vars: StarkEvaluationVars, + vars: &Self::EvaluationFrame, yield_constr: &mut ConstraintConsumer

, ) where FE: FieldExtension, P: PackedField, { + let local_values = vars.get_local_values(); + let next_values = vars.get_next_values(); + let public_inputs = vars.get_public_inputs(); + // Check public inputs. - yield_constr - .constraint_first_row(vars.local_values[0] - vars.public_inputs[Self::PI_INDEX_X0]); - yield_constr - .constraint_first_row(vars.local_values[1] - vars.public_inputs[Self::PI_INDEX_X1]); - yield_constr - .constraint_last_row(vars.local_values[1] - vars.public_inputs[Self::PI_INDEX_RES]); + yield_constr.constraint_first_row(local_values[0] - public_inputs[Self::PI_INDEX_X0]); + yield_constr.constraint_first_row(local_values[1] - public_inputs[Self::PI_INDEX_X1]); + yield_constr.constraint_last_row(local_values[1] - public_inputs[Self::PI_INDEX_RES]); // x0' <- x1 - yield_constr.constraint_transition(vars.next_values[0] - vars.local_values[1]); + yield_constr.constraint_transition(next_values[0] - local_values[1]); // x1' <- x0 + x1 - yield_constr.constraint_transition( - vars.next_values[1] - vars.local_values[0] - vars.local_values[1], - ); + yield_constr.constraint_transition(next_values[1] - local_values[0] - local_values[1]); } fn eval_ext_circuit( &self, builder: &mut CircuitBuilder, - vars: StarkEvaluationTargets, + vars: &Self::EvaluationFrameTarget, yield_constr: &mut RecursiveConstraintConsumer, ) { + let local_values = vars.get_local_values(); + let next_values = vars.get_next_values(); + let public_inputs = vars.get_public_inputs(); // Check public inputs. let pis_constraints = [ - builder.sub_extension(vars.local_values[0], vars.public_inputs[Self::PI_INDEX_X0]), - builder.sub_extension(vars.local_values[1], vars.public_inputs[Self::PI_INDEX_X1]), - builder.sub_extension(vars.local_values[1], vars.public_inputs[Self::PI_INDEX_RES]), + builder.sub_extension(local_values[0], public_inputs[Self::PI_INDEX_X0]), + builder.sub_extension(local_values[1], public_inputs[Self::PI_INDEX_X1]), + builder.sub_extension(local_values[1], public_inputs[Self::PI_INDEX_RES]), ]; yield_constr.constraint_first_row(builder, pis_constraints[0]); yield_constr.constraint_first_row(builder, pis_constraints[1]); yield_constr.constraint_last_row(builder, pis_constraints[2]); // x0' <- x1 - let first_col_constraint = builder.sub_extension(vars.next_values[0], vars.local_values[1]); + let first_col_constraint = builder.sub_extension(next_values[0], local_values[1]); yield_constr.constraint_transition(builder, first_col_constraint); // x1' <- x0 + x1 let second_col_constraint = { - let tmp = builder.sub_extension(vars.next_values[1], vars.local_values[0]); - builder.sub_extension(tmp, vars.local_values[1]) + let tmp = builder.sub_extension(next_values[1], local_values[0]); + builder.sub_extension(tmp, local_values[1]) }; yield_constr.constraint_transition(builder, second_col_constraint); } @@ -193,7 +205,8 @@ mod tests { let num_rows = 1 << 5; let stark = S::new(num_rows); - test_stark_circuit_constraints::(stark) + let pis = [F::ZERO, F::ONE, fibonacci(num_rows - 1, F::ZERO, F::ONE)]; + test_stark_circuit_constraints::(stark, pis) } #[test] diff --git a/starky/src/lib.rs b/starky/src/lib.rs index fcf1a7092f..33498e9ab9 100644 --- a/starky/src/lib.rs +++ b/starky/src/lib.rs @@ -10,6 +10,7 @@ mod get_challenges; pub mod config; pub mod constraint_consumer; +pub mod evaluation_frame; pub mod permutation; pub mod proof; pub mod prover; diff --git a/starky/src/permutation.rs b/starky/src/permutation.rs index 4f5d29213f..25622a7ebe 100644 --- a/starky/src/permutation.rs +++ b/starky/src/permutation.rs @@ -20,8 +20,8 @@ use plonky2_maybe_rayon::*; use crate::config::StarkConfig; use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer}; +use crate::evaluation_frame::{StarkEvaluationFrame, StarkEvaluationFrameTarget}; use crate::stark::Stark; -use crate::vars::{StarkEvaluationTargets, StarkEvaluationVars}; /// A pair of lists of columns, `lhs` and `rhs`, that should be permutations of one another. /// In particular, there should exist some permutation `pi` such that for any `i`, @@ -262,7 +262,7 @@ where pub(crate) fn eval_permutation_checks( stark: &S, config: &StarkConfig, - vars: StarkEvaluationVars, + vars: &S::EvaluationFrame, permutation_data: PermutationCheckVars, consumer: &mut ConstraintConsumer

, ) where @@ -273,6 +273,8 @@ pub(crate) fn eval_permutation_checks, Vec<_>) = column_pairs .iter() - .map(|&(i, j)| (vars.local_values[i], vars.local_values[j])) + .map(|&(i, j)| (local_values[i], local_values[j])) .unzip(); ( factor.reduce_ext(lhs.into_iter()) + FE::from_basefield(*gamma), @@ -330,7 +332,7 @@ pub(crate) fn eval_permutation_checks_circuit( builder: &mut CircuitBuilder, stark: &S, config: &StarkConfig, - vars: StarkEvaluationTargets, + vars: &S::EvaluationFrameTarget, permutation_data: PermutationCheckDataTarget, consumer: &mut RecursiveConstraintConsumer, ) where @@ -339,6 +341,8 @@ pub(crate) fn eval_permutation_checks_circuit( [(); S::COLUMNS]:, [(); S::PUBLIC_INPUTS]:, { + let local_values = vars.get_local_values(); + let PermutationCheckDataTarget { local_zs, next_zs, @@ -376,7 +380,7 @@ pub(crate) fn eval_permutation_checks_circuit( let mut factor = ReducingFactorTarget::new(beta_ext); let (lhs, rhs): (Vec<_>, Vec<_>) = column_pairs .iter() - .map(|&(i, j)| (vars.local_values[i], vars.local_values[j])) + .map(|&(i, j)| (local_values[i], local_values[j])) .unzip(); let reduced_lhs = factor.reduce(&lhs, builder); let reduced_rhs = factor.reduce(&rhs, builder); diff --git a/starky/src/prover.rs b/starky/src/prover.rs index 12e0cda963..4018fb54f2 100644 --- a/starky/src/prover.rs +++ b/starky/src/prover.rs @@ -20,6 +20,7 @@ use plonky2_maybe_rayon::*; use crate::config::StarkConfig; use crate::constraint_consumer::ConstraintConsumer; +use crate::evaluation_frame::StarkEvaluationFrame; use crate::permutation::{ compute_permutation_z_polys, get_n_permutation_challenge_sets, PermutationChallengeSet, PermutationCheckVars, @@ -27,7 +28,6 @@ use crate::permutation::{ use crate::proof::{StarkOpeningSet, StarkProof, StarkProofWithPublicInputs}; use crate::stark::Stark; use crate::vanishing_poly::eval_vanishing_poly; -use crate::vars::StarkEvaluationVars; pub fn prove( stark: S, @@ -272,11 +272,11 @@ where lagrange_basis_first, lagrange_basis_last, ); - let vars = StarkEvaluationVars { - local_values: &get_trace_values_packed(i_start), - next_values: &get_trace_values_packed(i_next_start), - public_inputs: &public_inputs, - }; + let vars = S::EvaluationFrame::from_values( + &get_trace_values_packed(i_start), + &get_trace_values_packed(i_next_start), + &public_inputs, + ); let permutation_check_data = permutation_zs_commitment_challenges.as_ref().map( |(permutation_zs_commitment, permutation_challenge_sets)| PermutationCheckVars { local_zs: permutation_zs_commitment.get_lde_values_packed(i_start, step), @@ -287,7 +287,7 @@ where eval_vanishing_poly::( stark, config, - vars, + &vars, permutation_check_data, &mut consumer, ); diff --git a/starky/src/recursive_verifier.rs b/starky/src/recursive_verifier.rs index 11d834791b..5a65b321fb 100644 --- a/starky/src/recursive_verifier.rs +++ b/starky/src/recursive_verifier.rs @@ -1,4 +1,3 @@ -use alloc::vec::Vec; use core::iter::once; use anyhow::{ensure, Result}; @@ -8,6 +7,7 @@ use plonky2::field::types::Field; use plonky2::fri::witness_util::set_fri_proof_target; use plonky2::hash::hash_types::RichField; use plonky2::iop::ext_target::ExtensionTarget; +use plonky2::iop::target::Target; use plonky2::iop::witness::Witness; use plonky2::plonk::circuit_builder::CircuitBuilder; use plonky2::plonk::config::{AlgebraicHasher, GenericConfig}; @@ -16,6 +16,7 @@ use plonky2::with_context; use crate::config::StarkConfig; use crate::constraint_consumer::RecursiveConstraintConsumer; +use crate::evaluation_frame::StarkEvaluationFrameTarget; use crate::permutation::PermutationCheckDataTarget; use crate::proof::{ StarkOpeningSetTarget, StarkProof, StarkProofChallengesTarget, StarkProofTarget, @@ -23,7 +24,6 @@ use crate::proof::{ }; use crate::stark::Stark; use crate::vanishing_poly::eval_vanishing_poly_circuit; -use crate::vars::StarkEvaluationTargets; pub fn verify_stark_proof_circuit< F: RichField + Extendable, @@ -90,16 +90,15 @@ fn verify_stark_proof_with_challenges_circuit< permutation_zs_next, quotient_polys, } = &proof.openings; - let vars = StarkEvaluationTargets { - local_values: &local_values.to_vec().try_into().unwrap(), - next_values: &next_values.to_vec().try_into().unwrap(), - public_inputs: &public_inputs + + let vars = S::EvaluationFrameTarget::from_values( + local_values, + next_values, + &public_inputs .into_iter() - .map(|t| builder.convert_to_ext(t)) - .collect::>() - .try_into() - .unwrap(), - }; + .map(|pi| pi.to_ext_target(Target::default())) + .collect::>(), + ); let zeta_pow_deg = builder.exp_power_of_2_extension(challenges.stark_zeta, degree_bits); let z_h_zeta = builder.sub_extension(zeta_pow_deg, one); @@ -132,7 +131,7 @@ fn verify_stark_proof_with_challenges_circuit< builder, &stark, inner_config, - vars, + &vars, permutation_data, &mut consumer, ) diff --git a/starky/src/stark.rs b/starky/src/stark.rs index 1ea172f3bd..a7e3f40481 100644 --- a/starky/src/stark.rs +++ b/starky/src/stark.rs @@ -15,8 +15,8 @@ use plonky2::util::ceil_div_usize; use crate::config::StarkConfig; use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer}; +use crate::evaluation_frame::{StarkEvaluationFrame, StarkEvaluationFrameTarget}; use crate::permutation::PermutationPair; -use crate::vars::{StarkEvaluationTargets, StarkEvaluationVars}; pub struct LookupConfig { pub degree_bits: usize, @@ -26,9 +26,17 @@ pub struct LookupConfig { /// Represents a STARK system. pub trait Stark, const D: usize>: Sync { /// The total number of columns in the trace. - const COLUMNS: usize; - /// The number of public inputs. - const PUBLIC_INPUTS: usize; + const COLUMNS: usize = Self::EvaluationFrameTarget::COLUMNS; + const PUBLIC_INPUTS: usize = 0; + + /// This is used to evaluate constraints natively. + type EvaluationFrame: StarkEvaluationFrame + where + FE: FieldExtension, + P: PackedField; + + /// The `Target` version of `Self::EvaluationFrame`, used to evaluate constraints recursively. + type EvaluationFrameTarget: StarkEvaluationFrameTarget>; /// Evaluate constraints at a vector of points. /// @@ -38,7 +46,7 @@ pub trait Stark, const D: usize>: Sync { /// constraints over `F`. fn eval_packed_generic( &self, - vars: StarkEvaluationVars, + vars: &Self::EvaluationFrame, yield_constr: &mut ConstraintConsumer

, ) where FE: FieldExtension, @@ -47,7 +55,7 @@ pub trait Stark, const D: usize>: Sync { /// Evaluate constraints at a vector of points from the base field `F`. fn eval_packed_base>( &self, - vars: StarkEvaluationVars, + vars: &Self::EvaluationFrame, yield_constr: &mut ConstraintConsumer

, ) { self.eval_packed_generic(vars, yield_constr) @@ -56,12 +64,7 @@ pub trait Stark, const D: usize>: Sync { /// Evaluate constraints at a single point from the degree `D` extension field. fn eval_ext( &self, - vars: StarkEvaluationVars< - F::Extension, - F::Extension, - { Self::COLUMNS }, - { Self::PUBLIC_INPUTS }, - >, + vars: &Self::EvaluationFrame, yield_constr: &mut ConstraintConsumer, ) { self.eval_packed_generic(vars, yield_constr) @@ -74,7 +77,7 @@ pub trait Stark, const D: usize>: Sync { fn eval_ext_circuit( &self, builder: &mut CircuitBuilder, - vars: StarkEvaluationTargets, + vars: &Self::EvaluationFrameTarget, yield_constr: &mut RecursiveConstraintConsumer, ); diff --git a/starky/src/stark_testing.rs b/starky/src/stark_testing.rs index 8572547ce8..b8658cd619 100644 --- a/starky/src/stark_testing.rs +++ b/starky/src/stark_testing.rs @@ -13,8 +13,8 @@ use plonky2::plonk::config::GenericConfig; use plonky2::util::{log2_ceil, log2_strict, transpose}; use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer}; +use crate::evaluation_frame::{StarkEvaluationFrame, StarkEvaluationFrameTarget}; use crate::stark::Stark; -use crate::vars::{StarkEvaluationTargets, StarkEvaluationVars}; const WITNESS_SIZE: usize = 1 << 5; @@ -42,14 +42,11 @@ where let alpha = F::rand(); let constraint_evals = (0..size) .map(|i| { - let vars = StarkEvaluationVars { - local_values: &trace_ldes[i].clone().try_into().unwrap(), - next_values: &trace_ldes[(i + (1 << rate_bits)) % size] - .clone() - .try_into() - .unwrap(), - public_inputs: &public_inputs, - }; + let vars = S::EvaluationFrame::from_values( + &trace_ldes[i], + &trace_ldes[(i + (1 << rate_bits)) % size], + &public_inputs, + ); let mut consumer = ConstraintConsumer::::new( vec![alpha], @@ -57,7 +54,7 @@ where lagrange_first.values[i], lagrange_last.values[i], ); - stark.eval_packed_base(vars, &mut consumer); + stark.eval_packed_base(&vars, &mut consumer); consumer.accumulators()[0] }) .collect::>(); @@ -85,17 +82,18 @@ pub fn test_stark_circuit_constraints< const D: usize, >( stark: S, + public_inputs: [F; S::PUBLIC_INPUTS], ) -> Result<()> where [(); S::COLUMNS]:, [(); S::PUBLIC_INPUTS]:, { // Compute native constraint evaluation on random values. - let vars = StarkEvaluationVars { - local_values: &F::Extension::rand_array::<{ S::COLUMNS }>(), - next_values: &F::Extension::rand_array::<{ S::COLUMNS }>(), - public_inputs: &F::Extension::rand_array::<{ S::PUBLIC_INPUTS }>(), - }; + let vars = S::EvaluationFrame::from_values( + &F::Extension::rand_array::<{ S::COLUMNS }>(), + &F::Extension::rand_array::<{ S::COLUMNS }>(), + &F::Extension::rand_array::<{ S::PUBLIC_INPUTS }>(), + ); let alphas = F::rand_vec(1); let z_last = F::Extension::rand(); let lagrange_first = F::Extension::rand(); @@ -110,20 +108,26 @@ where lagrange_first, lagrange_last, ); - stark.eval_ext(vars, &mut consumer); + stark.eval_ext(&vars, &mut consumer); let native_eval = consumer.accumulators()[0]; - // Compute circuit constraint evaluation on same random values. let circuit_config = CircuitConfig::standard_recursion_config(); let mut builder = CircuitBuilder::::new(circuit_config); let mut pw = PartialWitness::::new(); let locals_t = builder.add_virtual_extension_targets(S::COLUMNS); - pw.set_extension_targets(&locals_t, vars.local_values); + pw.set_extension_targets(&locals_t, vars.get_local_values()); let nexts_t = builder.add_virtual_extension_targets(S::COLUMNS); - pw.set_extension_targets(&nexts_t, vars.next_values); + pw.set_extension_targets(&nexts_t, vars.get_next_values()); let pis_t = builder.add_virtual_extension_targets(S::PUBLIC_INPUTS); - pw.set_extension_targets(&pis_t, vars.public_inputs); + pw.set_extension_targets( + &pis_t, + &public_inputs + .iter() + .copied() + .map(F::Extension::from_basefield) + .collect::>(), + ); let alphas_t = builder.add_virtual_targets(1); pw.set_target(alphas_t[0], alphas[0]); let z_last_t = builder.add_virtual_extension_target(); @@ -133,11 +137,7 @@ where let lagrange_last_t = builder.add_virtual_extension_target(); pw.set_extension_target(lagrange_last_t, lagrange_last); - let vars = StarkEvaluationTargets:: { - local_values: &locals_t.try_into().unwrap(), - next_values: &nexts_t.try_into().unwrap(), - public_inputs: &pis_t.try_into().unwrap(), - }; + let vars = S::EvaluationFrameTarget::from_values(&locals_t, &nexts_t, &pis_t); let mut consumer = RecursiveConstraintConsumer::::new( builder.zero_extension(), alphas_t, @@ -145,7 +145,7 @@ where lagrange_first_t, lagrange_last_t, ); - stark.eval_ext_circuit(&mut builder, vars, &mut consumer); + stark.eval_ext_circuit(&mut builder, &vars, &mut consumer); let circuit_eval = consumer.accumulators()[0]; let native_eval_t = builder.constant_extension(native_eval); builder.connect_extension(circuit_eval, native_eval_t); diff --git a/starky/src/vanishing_poly.rs b/starky/src/vanishing_poly.rs index a3fe753e9b..58a4732a65 100644 --- a/starky/src/vanishing_poly.rs +++ b/starky/src/vanishing_poly.rs @@ -10,12 +10,11 @@ use crate::permutation::{ PermutationCheckVars, }; use crate::stark::Stark; -use crate::vars::{StarkEvaluationTargets, StarkEvaluationVars}; pub(crate) fn eval_vanishing_poly( stark: &S, config: &StarkConfig, - vars: StarkEvaluationVars, + vars: &S::EvaluationFrame, permutation_data: Option>, consumer: &mut ConstraintConsumer

, ) where @@ -42,7 +41,7 @@ pub(crate) fn eval_vanishing_poly_circuit( builder: &mut CircuitBuilder, stark: &S, config: &StarkConfig, - vars: StarkEvaluationTargets, + vars: &S::EvaluationFrameTarget, permutation_data: Option>, consumer: &mut RecursiveConstraintConsumer, ) where diff --git a/starky/src/verifier.rs b/starky/src/verifier.rs index 4180aaf5ce..bc4e3c0e66 100644 --- a/starky/src/verifier.rs +++ b/starky/src/verifier.rs @@ -12,11 +12,11 @@ use plonky2::plonk::plonk_common::reduce_with_powers; use crate::config::StarkConfig; use crate::constraint_consumer::ConstraintConsumer; +use crate::evaluation_frame::StarkEvaluationFrame; use crate::permutation::PermutationCheckVars; use crate::proof::{StarkOpeningSet, StarkProof, StarkProofChallenges, StarkProofWithPublicInputs}; use crate::stark::Stark; use crate::vanishing_poly::eval_vanishing_poly; -use crate::vars::StarkEvaluationVars; pub fn verify_stark_proof< F: RichField + Extendable, @@ -67,17 +67,14 @@ where permutation_zs_next, quotient_polys, } = &proof.openings; - let vars = StarkEvaluationVars { - local_values: &local_values.to_vec().try_into().unwrap(), - next_values: &next_values.to_vec().try_into().unwrap(), - public_inputs: &public_inputs + let vars = S::EvaluationFrame::from_values( + local_values, + next_values, + &public_inputs .into_iter() .map(F::Extension::from_basefield) - .collect::>() - .try_into() - .unwrap(), - }; - + .collect::>(), + ); let (l_0, l_last) = eval_l_0_and_l_last(degree_bits, challenges.stark_zeta); let last = F::primitive_root_of_unity(degree_bits).inverse(); let z_last = challenges.stark_zeta - last.into(); @@ -99,7 +96,7 @@ where eval_vanishing_poly::( &stark, config, - vars, + &vars, permutation_data, &mut consumer, ); @@ -155,6 +152,7 @@ where C: GenericConfig, S: Stark, [(); S::COLUMNS]:, + [(); S::PUBLIC_INPUTS]:, { let StarkProofWithPublicInputs { proof, From b4d30df7927c5b30ccbd147715b75c99297568a2 Mon Sep 17 00:00:00 2001 From: bing Date: Tue, 3 Oct 2023 15:45:49 +0800 Subject: [PATCH 2/8] fixes' --- starky/src/evaluation_frame.rs | 2 ++ starky/src/fibonacci_stark.rs | 13 ++++++------- starky/src/prover.rs | 8 ++------ starky/src/stark.rs | 2 +- starky/src/stark_testing.rs | 10 +--------- starky/src/verifier.rs | 3 ++- 6 files changed, 14 insertions(+), 24 deletions(-) diff --git a/starky/src/evaluation_frame.rs b/starky/src/evaluation_frame.rs index 74324cb88c..e74b84a5f7 100644 --- a/starky/src/evaluation_frame.rs +++ b/starky/src/evaluation_frame.rs @@ -32,6 +32,8 @@ pub struct StarkFrame where F: Field, P: PackedField, + [(); N]:, + [(); N2]:, { local_values: [P; N], next_values: [P; N], diff --git a/starky/src/fibonacci_stark.rs b/starky/src/fibonacci_stark.rs index 2deee1af36..add928db53 100644 --- a/starky/src/fibonacci_stark.rs +++ b/starky/src/fibonacci_stark.rs @@ -60,16 +60,16 @@ impl, const D: usize> FibonacciStark { } } +const COLUMNS: usize = 4; +const PUBLIC_INPUTS: usize = 3; + impl, const D: usize> Stark for FibonacciStark { - type EvaluationFrame = StarkFrame + type EvaluationFrame = StarkFrame where FE: FieldExtension, P: PackedField; - type EvaluationFrameTarget = StarkFrameTarget, 3, 3>; - - const COLUMNS: usize = 3; - const PUBLIC_INPUTS: usize = 3; + type EvaluationFrameTarget = StarkFrameTarget, COLUMNS, PUBLIC_INPUTS>; fn eval_packed_generic( &self, @@ -205,8 +205,7 @@ mod tests { let num_rows = 1 << 5; let stark = S::new(num_rows); - let pis = [F::ZERO, F::ONE, fibonacci(num_rows - 1, F::ZERO, F::ONE)]; - test_stark_circuit_constraints::(stark, pis) + test_stark_circuit_constraints::(stark) } #[test] diff --git a/starky/src/prover.rs b/starky/src/prover.rs index 4018fb54f2..c7b65c0bb3 100644 --- a/starky/src/prover.rs +++ b/starky/src/prover.rs @@ -236,12 +236,8 @@ where let z_h_on_coset = ZeroPolyOnCoset::::new(degree_bits, quotient_degree_bits); // Retrieve the LDE values at index `i`. - let get_trace_values_packed = |i_start| -> [P; S::COLUMNS] { - trace_commitment - .get_lde_values_packed(i_start, step) - .try_into() - .unwrap() - }; + let get_trace_values_packed = + |i_start| -> Vec

{ trace_commitment.get_lde_values_packed(i_start, step) }; // Last element of the subgroup. let last = F::primitive_root_of_unity(degree_bits).inverse(); diff --git a/starky/src/stark.rs b/starky/src/stark.rs index a7e3f40481..534943846a 100644 --- a/starky/src/stark.rs +++ b/starky/src/stark.rs @@ -27,7 +27,7 @@ pub struct LookupConfig { pub trait Stark, const D: usize>: Sync { /// The total number of columns in the trace. const COLUMNS: usize = Self::EvaluationFrameTarget::COLUMNS; - const PUBLIC_INPUTS: usize = 0; + const PUBLIC_INPUTS: usize = Self::EvaluationFrameTarget::PUBLIC_INPUTS; /// This is used to evaluate constraints natively. type EvaluationFrame: StarkEvaluationFrame diff --git a/starky/src/stark_testing.rs b/starky/src/stark_testing.rs index b8658cd619..13b7ba22b8 100644 --- a/starky/src/stark_testing.rs +++ b/starky/src/stark_testing.rs @@ -82,7 +82,6 @@ pub fn test_stark_circuit_constraints< const D: usize, >( stark: S, - public_inputs: [F; S::PUBLIC_INPUTS], ) -> Result<()> where [(); S::COLUMNS]:, @@ -120,14 +119,7 @@ where let nexts_t = builder.add_virtual_extension_targets(S::COLUMNS); pw.set_extension_targets(&nexts_t, vars.get_next_values()); let pis_t = builder.add_virtual_extension_targets(S::PUBLIC_INPUTS); - pw.set_extension_targets( - &pis_t, - &public_inputs - .iter() - .copied() - .map(F::Extension::from_basefield) - .collect::>(), - ); + pw.set_extension_targets(&pis_t, vars.get_public_inputs()); let alphas_t = builder.add_virtual_targets(1); pw.set_target(alphas_t[0], alphas[0]); let z_last_t = builder.add_virtual_extension_target(); diff --git a/starky/src/verifier.rs b/starky/src/verifier.rs index bc4e3c0e66..1a197cb312 100644 --- a/starky/src/verifier.rs +++ b/starky/src/verifier.rs @@ -71,7 +71,8 @@ where local_values, next_values, &public_inputs - .into_iter() + .iter() + .copied() .map(F::Extension::from_basefield) .collect::>(), ); From 40d0b25add1230773bf5e04ee302f61ab688e04e Mon Sep 17 00:00:00 2001 From: bing Date: Tue, 3 Oct 2023 15:53:49 +0800 Subject: [PATCH 3/8] fix recursive verifier --- starky/src/recursive_verifier.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/starky/src/recursive_verifier.rs b/starky/src/recursive_verifier.rs index 5a65b321fb..7378839b66 100644 --- a/starky/src/recursive_verifier.rs +++ b/starky/src/recursive_verifier.rs @@ -96,7 +96,7 @@ fn verify_stark_proof_with_challenges_circuit< next_values, &public_inputs .into_iter() - .map(|pi| pi.to_ext_target(Target::default())) + .map(|t| builder.convert_to_ext(t)) .collect::>(), ); From 8b834fc5f18a3d5a19b6a4b88f5a54b6560abbfc Mon Sep 17 00:00:00 2001 From: bing Date: Tue, 3 Oct 2023 16:35:11 +0800 Subject: [PATCH 4/8] remove where bounds --- starky/src/fibonacci_stark.rs | 6 ++---- starky/src/lib.rs | 1 - starky/src/permutation.rs | 4 ---- starky/src/prover.rs | 8 ++------ starky/src/recursive_verifier.rs | 5 ----- starky/src/stark_testing.rs | 20 ++++++-------------- starky/src/vanishing_poly.rs | 4 ---- starky/src/verifier.rs | 14 ++------------ 8 files changed, 12 insertions(+), 50 deletions(-) diff --git a/starky/src/fibonacci_stark.rs b/starky/src/fibonacci_stark.rs index add928db53..7bd935fd4e 100644 --- a/starky/src/fibonacci_stark.rs +++ b/starky/src/fibonacci_stark.rs @@ -177,7 +177,7 @@ mod tests { stark, &config, trace, - public_inputs, + &public_inputs, &mut TimingTree::default(), )?; @@ -225,7 +225,7 @@ mod tests { stark, &config, trace, - public_inputs, + &public_inputs, &mut TimingTree::default(), )?; verify_stark_proof(stark, proof.clone(), &config)?; @@ -247,8 +247,6 @@ mod tests { ) -> Result<()> where InnerC::Hasher: AlgebraicHasher, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { let circuit_config = CircuitConfig::standard_recursion_config(); let mut builder = CircuitBuilder::::new(circuit_config); diff --git a/starky/src/lib.rs b/starky/src/lib.rs index 33498e9ab9..4e5bd190a0 100644 --- a/starky/src/lib.rs +++ b/starky/src/lib.rs @@ -1,7 +1,6 @@ #![allow(incomplete_features)] #![allow(clippy::too_many_arguments)] #![allow(clippy::type_complexity)] -#![feature(generic_const_exprs)] #![cfg_attr(not(feature = "std"), no_std)] #![feature(core_intrinsics)] extern crate alloc; diff --git a/starky/src/permutation.rs b/starky/src/permutation.rs index 25622a7ebe..278d91ad5b 100644 --- a/starky/src/permutation.rs +++ b/starky/src/permutation.rs @@ -270,8 +270,6 @@ pub(crate) fn eval_permutation_checks, P: PackedField, S: Stark, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { let local_values = vars.get_local_values(); @@ -338,8 +336,6 @@ pub(crate) fn eval_permutation_checks_circuit( ) where F: RichField + Extendable, S: Stark, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { let local_values = vars.get_local_values(); diff --git a/starky/src/prover.rs b/starky/src/prover.rs index c7b65c0bb3..57cdd2999a 100644 --- a/starky/src/prover.rs +++ b/starky/src/prover.rs @@ -33,15 +33,13 @@ pub fn prove( stark: S, config: &StarkConfig, trace_poly_values: Vec>, - public_inputs: [F; S::PUBLIC_INPUTS], + public_inputs: &[F], timing: &mut TimingTree, ) -> Result> where F: RichField + Extendable, C: GenericConfig, S: Stark, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { let degree = trace_poly_values[0].len(); let degree_bits = log2_strict(degree); @@ -202,7 +200,7 @@ fn compute_quotient_polys<'a, F, P, C, S, const D: usize>( PolynomialBatch, Vec>, )>, - public_inputs: [F; S::PUBLIC_INPUTS], + public_inputs: &[F], alphas: Vec, degree_bits: usize, config: &StarkConfig, @@ -212,8 +210,6 @@ where P: PackedField, C: GenericConfig, S: Stark, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { let degree = 1 << degree_bits; let rate_bits = config.fri_config.rate_bits; diff --git a/starky/src/recursive_verifier.rs b/starky/src/recursive_verifier.rs index 7378839b66..1b6028d0ce 100644 --- a/starky/src/recursive_verifier.rs +++ b/starky/src/recursive_verifier.rs @@ -7,7 +7,6 @@ use plonky2::field::types::Field; use plonky2::fri::witness_util::set_fri_proof_target; use plonky2::hash::hash_types::RichField; use plonky2::iop::ext_target::ExtensionTarget; -use plonky2::iop::target::Target; use plonky2::iop::witness::Witness; use plonky2::plonk::circuit_builder::CircuitBuilder; use plonky2::plonk::config::{AlgebraicHasher, GenericConfig}; @@ -37,8 +36,6 @@ pub fn verify_stark_proof_circuit< inner_config: &StarkConfig, ) where C::Hasher: AlgebraicHasher, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { assert_eq!(proof_with_pis.public_inputs.len(), S::PUBLIC_INPUTS); let degree_bits = proof_with_pis.proof.recover_degree_bits(inner_config); @@ -73,8 +70,6 @@ fn verify_stark_proof_with_challenges_circuit< degree_bits: usize, ) where C::Hasher: AlgebraicHasher, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { check_permutation_options(&stark, &proof_with_pis, &challenges).unwrap(); let one = builder.one_extension(); diff --git a/starky/src/stark_testing.rs b/starky/src/stark_testing.rs index 13b7ba22b8..36f116ee61 100644 --- a/starky/src/stark_testing.rs +++ b/starky/src/stark_testing.rs @@ -22,16 +22,12 @@ const WITNESS_SIZE: usize = 1 << 5; /// low-degree witness polynomials. pub fn test_stark_low_degree, S: Stark, const D: usize>( stark: S, -) -> Result<()> -where - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, -{ +) -> Result<()> { let rate_bits = log2_ceil(stark.constraint_degree() + 1); let trace_ldes = random_low_degree_matrix::(S::COLUMNS, rate_bits); let size = trace_ldes.len(); - let public_inputs = F::rand_array::<{ S::PUBLIC_INPUTS }>(); + let public_inputs = F::rand_vec(S::PUBLIC_INPUTS); let lagrange_first = PolynomialValues::selector(WITNESS_SIZE, 0).lde(rate_bits); let lagrange_last = PolynomialValues::selector(WITNESS_SIZE, WITNESS_SIZE - 1).lde(rate_bits); @@ -82,16 +78,12 @@ pub fn test_stark_circuit_constraints< const D: usize, >( stark: S, -) -> Result<()> -where - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, -{ +) -> Result<()> { // Compute native constraint evaluation on random values. let vars = S::EvaluationFrame::from_values( - &F::Extension::rand_array::<{ S::COLUMNS }>(), - &F::Extension::rand_array::<{ S::COLUMNS }>(), - &F::Extension::rand_array::<{ S::PUBLIC_INPUTS }>(), + &F::Extension::rand_vec(S::COLUMNS), + &F::Extension::rand_vec(S::COLUMNS), + &F::Extension::rand_vec(S::PUBLIC_INPUTS), ); let alphas = F::rand_vec(1); let z_last = F::Extension::rand(); diff --git a/starky/src/vanishing_poly.rs b/starky/src/vanishing_poly.rs index 58a4732a65..0a399dce53 100644 --- a/starky/src/vanishing_poly.rs +++ b/starky/src/vanishing_poly.rs @@ -22,8 +22,6 @@ pub(crate) fn eval_vanishing_poly( FE: FieldExtension, P: PackedField, S: Stark, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { stark.eval_packed_generic(vars, consumer); if let Some(permutation_data) = permutation_data { @@ -47,8 +45,6 @@ pub(crate) fn eval_vanishing_poly_circuit( ) where F: RichField + Extendable, S: Stark, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { stark.eval_ext_circuit(builder, vars, consumer); if let Some(permutation_data) = permutation_data { diff --git a/starky/src/verifier.rs b/starky/src/verifier.rs index 1a197cb312..bb9e773de4 100644 --- a/starky/src/verifier.rs +++ b/starky/src/verifier.rs @@ -27,11 +27,7 @@ pub fn verify_stark_proof< stark: S, proof_with_pis: StarkProofWithPublicInputs, config: &StarkConfig, -) -> Result<()> -where - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, -{ +) -> Result<()> { ensure!(proof_with_pis.public_inputs.len() == S::PUBLIC_INPUTS); let degree_bits = proof_with_pis.proof.recover_degree_bits(config); let challenges = proof_with_pis.get_challenges(&stark, config, degree_bits); @@ -49,11 +45,7 @@ pub(crate) fn verify_stark_proof_with_challenges< challenges: StarkProofChallenges, degree_bits: usize, config: &StarkConfig, -) -> Result<()> -where - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, -{ +) -> Result<()> { validate_proof_shape(&stark, &proof_with_pis, config)?; check_permutation_options(&stark, &proof_with_pis, &challenges)?; let StarkProofWithPublicInputs { @@ -152,8 +144,6 @@ where F: RichField + Extendable, C: GenericConfig, S: Stark, - [(); S::COLUMNS]:, - [(); S::PUBLIC_INPUTS]:, { let StarkProofWithPublicInputs { proof, From 2759234d304a8ab1cca0b01f3a0fcb923cfc021c Mon Sep 17 00:00:00 2001 From: bing Date: Tue, 3 Oct 2023 16:35:36 +0800 Subject: [PATCH 5/8] clippy --- starky/src/prover.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/starky/src/prover.rs b/starky/src/prover.rs index 57cdd2999a..871897c4f5 100644 --- a/starky/src/prover.rs +++ b/starky/src/prover.rs @@ -267,7 +267,7 @@ where let vars = S::EvaluationFrame::from_values( &get_trace_values_packed(i_start), &get_trace_values_packed(i_next_start), - &public_inputs, + public_inputs, ); let permutation_check_data = permutation_zs_commitment_challenges.as_ref().map( |(permutation_zs_commitment, permutation_challenge_sets)| PermutationCheckVars { From 83fc8ee62a801c89d4986ad3d618a3b8386add79 Mon Sep 17 00:00:00 2001 From: bing Date: Tue, 3 Oct 2023 16:38:47 +0800 Subject: [PATCH 6/8] unnecessary where bound --- starky/src/evaluation_frame.rs | 2 -- 1 file changed, 2 deletions(-) diff --git a/starky/src/evaluation_frame.rs b/starky/src/evaluation_frame.rs index e74b84a5f7..74324cb88c 100644 --- a/starky/src/evaluation_frame.rs +++ b/starky/src/evaluation_frame.rs @@ -32,8 +32,6 @@ pub struct StarkFrame where F: Field, P: PackedField, - [(); N]:, - [(); N2]:, { local_values: [P; N], next_values: [P; N], From c69229e4ff4bc76be11fb61d4a1c768b5ad99111 Mon Sep 17 00:00:00 2001 From: bing Date: Fri, 6 Oct 2023 14:04:02 +0800 Subject: [PATCH 7/8] update --- starky/src/evaluation_frame.rs | 102 ++++++------------------------- starky/src/fibonacci_stark.rs | 9 ++- starky/src/lib.rs | 1 - starky/src/permutation.rs | 2 +- starky/src/recursive_verifier.rs | 2 +- starky/src/stark.rs | 6 +- starky/src/stark_testing.rs | 2 +- starky/src/vars.rs | 26 -------- 8 files changed, 28 insertions(+), 122 deletions(-) delete mode 100644 starky/src/vars.rs diff --git a/starky/src/evaluation_frame.rs b/starky/src/evaluation_frame.rs index 74324cb88c..3da7b88b71 100644 --- a/starky/src/evaluation_frame.rs +++ b/starky/src/evaluation_frame.rs @@ -1,108 +1,41 @@ -use plonky2::field::packed::PackedField; -use plonky2::field::types::Field; - /// A trait for viewing an evaluation frame of a STARK table. /// /// It allows to access the current and next rows at a given step /// and can be used to implement constraint evaluation both natively /// and recursively. -pub trait StarkEvaluationFrame: Sized -where - F: Field, - P: PackedField, +pub trait StarkEvaluationFrame: + Sized { /// The number of columns for the STARK table this evaluation frame views. const COLUMNS: usize; const PUBLIC_INPUTS: usize; - /// Returns the local values (i.e. current row) for this evaluation frame. - fn get_local_values(&self) -> &[P]; - /// Returns the next values (i.e. next row) for this evaluation frame. - fn get_next_values(&self) -> &[P]; - - fn get_public_inputs(&self) -> &[P::Scalar]; - - /// Outputs a new evaluation frame from the provided local and next values. - /// - /// **NOTE**: Concrete implementations of this method SHOULD ensure that - /// the provided slices lengths match the `Self::COLUMNS` value. - fn from_values(lv: &[P], nv: &[P], public_inputs: &[P::Scalar]) -> Self; -} -pub struct StarkFrame -where - F: Field, - P: PackedField, -{ - local_values: [P; N], - next_values: [P; N], - public_inputs: [P::Scalar; N2], -} - -impl StarkEvaluationFrame for StarkFrame -where - F: Field, - P: PackedField, -{ - const COLUMNS: usize = N; - const PUBLIC_INPUTS: usize = N2; - - fn get_local_values(&self) -> &[P] { - &self.local_values - } - - fn get_next_values(&self) -> &[P] { - &self.next_values - } - - fn get_public_inputs(&self) -> &[P::Scalar] { - &self.public_inputs - } - - fn from_values(lv: &[P], nv: &[P], public_inputs: &[P::Scalar]) -> Self { - assert_eq!(lv.len(), Self::COLUMNS); - assert_eq!(nv.len(), Self::COLUMNS); - assert_eq!(public_inputs.len(), Self::PUBLIC_INPUTS); - - Self { - local_values: lv.try_into().unwrap(), - next_values: nv.try_into().unwrap(), - public_inputs: public_inputs.try_into().unwrap(), - } - } -} - -/// A trait for viewing an evaluation frame of a STARK table. -/// -/// It allows to access the current and next rows at a given step -/// and can be used to implement constraint evaluation both natively -/// and recursively. -pub trait StarkEvaluationFrameTarget: Sized { - /// The number of columns for the STARK table this evaluation frame views. - const COLUMNS: usize; - const PUBLIC_INPUTS: usize; - /// Returns the local values (i.e. current row) for this evaluation frame. fn get_local_values(&self) -> &[T]; /// Returns the next values (i.e. next row) for this evaluation frame. fn get_next_values(&self) -> &[T]; - fn get_public_inputs(&self) -> &[T]; - + fn get_public_inputs(&self) -> &[U]; /// Outputs a new evaluation frame from the provided local and next values. /// /// **NOTE**: Concrete implementations of this method SHOULD ensure that /// the provided slices lengths match the `Self::COLUMNS` value. - fn from_values(lv: &[T], nv: &[T], public_inputs: &[T]) -> Self; + fn from_values(lv: &[T], nv: &[T], pis: &[U]) -> Self; } -pub struct StarkFrameTarget { +pub struct StarkFrame< + T: Copy + Clone + Default, + U: Copy + Clone + Default, + const N: usize, + const N2: usize, +> { local_values: [T; N], next_values: [T; N], - public_inputs: [T; N2], + public_inputs: [U; N2], } -impl StarkEvaluationFrameTarget - for StarkFrameTarget +impl + StarkEvaluationFrame for StarkFrame { const COLUMNS: usize = N; const PUBLIC_INPUTS: usize = N2; @@ -115,19 +48,20 @@ impl StarkEvaluation &self.next_values } - fn get_public_inputs(&self) -> &[T] { + fn get_public_inputs(&self) -> &[U] { &self.public_inputs } - fn from_values(lv: &[T], nv: &[T], public_inputs: &[T]) -> Self { + fn from_values(lv: &[T], nv: &[T], pis: &[U]) -> Self { assert_eq!(lv.len(), Self::COLUMNS); assert_eq!(nv.len(), Self::COLUMNS); - assert_eq!(public_inputs.len(), Self::PUBLIC_INPUTS); + assert_eq!(pis.len(), Self::PUBLIC_INPUTS); Self { local_values: lv.try_into().unwrap(), next_values: nv.try_into().unwrap(), - public_inputs: public_inputs.try_into().unwrap(), + public_inputs: pis.try_into().unwrap(), } } } + diff --git a/starky/src/fibonacci_stark.rs b/starky/src/fibonacci_stark.rs index 7bd935fd4e..28cd59f884 100644 --- a/starky/src/fibonacci_stark.rs +++ b/starky/src/fibonacci_stark.rs @@ -10,9 +10,7 @@ use plonky2::iop::ext_target::ExtensionTarget; use plonky2::plonk::circuit_builder::CircuitBuilder; use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer}; -use crate::evaluation_frame::{ - StarkEvaluationFrame, StarkEvaluationFrameTarget, StarkFrame, StarkFrameTarget, -}; +use crate::evaluation_frame::{StarkEvaluationFrame, StarkFrame}; use crate::permutation::PermutationPair; use crate::stark::Stark; use crate::util::trace_rows_to_poly_values; @@ -64,12 +62,13 @@ const COLUMNS: usize = 4; const PUBLIC_INPUTS: usize = 3; impl, const D: usize> Stark for FibonacciStark { - type EvaluationFrame = StarkFrame + type EvaluationFrame = StarkFrame where FE: FieldExtension, P: PackedField; - type EvaluationFrameTarget = StarkFrameTarget, COLUMNS, PUBLIC_INPUTS>; + type EvaluationFrameTarget = + StarkFrame, ExtensionTarget, COLUMNS, PUBLIC_INPUTS>; fn eval_packed_generic( &self, diff --git a/starky/src/lib.rs b/starky/src/lib.rs index 4e5bd190a0..336bd3a178 100644 --- a/starky/src/lib.rs +++ b/starky/src/lib.rs @@ -18,7 +18,6 @@ pub mod stark; pub mod stark_testing; pub mod util; pub mod vanishing_poly; -pub mod vars; pub mod verifier; #[cfg(test)] diff --git a/starky/src/permutation.rs b/starky/src/permutation.rs index 278d91ad5b..1059a79b7f 100644 --- a/starky/src/permutation.rs +++ b/starky/src/permutation.rs @@ -20,7 +20,7 @@ use plonky2_maybe_rayon::*; use crate::config::StarkConfig; use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer}; -use crate::evaluation_frame::{StarkEvaluationFrame, StarkEvaluationFrameTarget}; +use crate::evaluation_frame::StarkEvaluationFrame; use crate::stark::Stark; /// A pair of lists of columns, `lhs` and `rhs`, that should be permutations of one another. diff --git a/starky/src/recursive_verifier.rs b/starky/src/recursive_verifier.rs index 1b6028d0ce..bd5d2f1916 100644 --- a/starky/src/recursive_verifier.rs +++ b/starky/src/recursive_verifier.rs @@ -15,7 +15,7 @@ use plonky2::with_context; use crate::config::StarkConfig; use crate::constraint_consumer::RecursiveConstraintConsumer; -use crate::evaluation_frame::StarkEvaluationFrameTarget; +use crate::evaluation_frame::StarkEvaluationFrame; use crate::permutation::PermutationCheckDataTarget; use crate::proof::{ StarkOpeningSetTarget, StarkProof, StarkProofChallengesTarget, StarkProofTarget, diff --git a/starky/src/stark.rs b/starky/src/stark.rs index 534943846a..afa22f3c07 100644 --- a/starky/src/stark.rs +++ b/starky/src/stark.rs @@ -15,7 +15,7 @@ use plonky2::util::ceil_div_usize; use crate::config::StarkConfig; use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer}; -use crate::evaluation_frame::{StarkEvaluationFrame, StarkEvaluationFrameTarget}; +use crate::evaluation_frame::StarkEvaluationFrame; use crate::permutation::PermutationPair; pub struct LookupConfig { @@ -30,13 +30,13 @@ pub trait Stark, const D: usize>: Sync { const PUBLIC_INPUTS: usize = Self::EvaluationFrameTarget::PUBLIC_INPUTS; /// This is used to evaluate constraints natively. - type EvaluationFrame: StarkEvaluationFrame + type EvaluationFrame: StarkEvaluationFrame where FE: FieldExtension, P: PackedField; /// The `Target` version of `Self::EvaluationFrame`, used to evaluate constraints recursively. - type EvaluationFrameTarget: StarkEvaluationFrameTarget>; + type EvaluationFrameTarget: StarkEvaluationFrame, ExtensionTarget>; /// Evaluate constraints at a vector of points. /// diff --git a/starky/src/stark_testing.rs b/starky/src/stark_testing.rs index 36f116ee61..a454a29c34 100644 --- a/starky/src/stark_testing.rs +++ b/starky/src/stark_testing.rs @@ -13,7 +13,7 @@ use plonky2::plonk::config::GenericConfig; use plonky2::util::{log2_ceil, log2_strict, transpose}; use crate::constraint_consumer::{ConstraintConsumer, RecursiveConstraintConsumer}; -use crate::evaluation_frame::{StarkEvaluationFrame, StarkEvaluationFrameTarget}; +use crate::evaluation_frame::StarkEvaluationFrame; use crate::stark::Stark; const WITNESS_SIZE: usize = 1 << 5; diff --git a/starky/src/vars.rs b/starky/src/vars.rs deleted file mode 100644 index 682ac83711..0000000000 --- a/starky/src/vars.rs +++ /dev/null @@ -1,26 +0,0 @@ -use plonky2::field::packed::PackedField; -use plonky2::field::types::Field; -use plonky2::iop::ext_target::ExtensionTarget; - -#[derive(Debug, Copy, Clone)] -pub struct StarkEvaluationVars<'a, F, P, const COLUMNS: usize, const PUBLIC_INPUTS: usize> -where - F: Field, - P: PackedField, -{ - pub local_values: &'a [P; COLUMNS], - pub next_values: &'a [P; COLUMNS], - pub public_inputs: &'a [P::Scalar; PUBLIC_INPUTS], -} - -#[derive(Debug, Copy, Clone)] -pub struct StarkEvaluationTargets< - 'a, - const D: usize, - const COLUMNS: usize, - const PUBLIC_INPUTS: usize, -> { - pub local_values: &'a [ExtensionTarget; COLUMNS], - pub next_values: &'a [ExtensionTarget; COLUMNS], - pub public_inputs: &'a [ExtensionTarget; PUBLIC_INPUTS], -} From 0af518feda5a668dd4b497c46613a04c134f94be Mon Sep 17 00:00:00 2001 From: bing Date: Fri, 6 Oct 2023 15:43:29 +0800 Subject: [PATCH 8/8] fmt --- starky/src/evaluation_frame.rs | 1 - 1 file changed, 1 deletion(-) diff --git a/starky/src/evaluation_frame.rs b/starky/src/evaluation_frame.rs index 3da7b88b71..a4eb02f5ba 100644 --- a/starky/src/evaluation_frame.rs +++ b/starky/src/evaluation_frame.rs @@ -64,4 +64,3 @@ impl