diff --git a/crates/prover/src/constraint_framework/preprocessed_columns.rs b/crates/prover/src/constraint_framework/preprocessed_columns.rs index a6df63bf6d..d3dea87634 100644 --- a/crates/prover/src/constraint_framework/preprocessed_columns.rs +++ b/crates/prover/src/constraint_framework/preprocessed_columns.rs @@ -7,7 +7,7 @@ use num_traits::{One, Zero}; use crate::core::backend::simd::m31::{PackedM31, N_LANES}; use crate::core::backend::simd::SimdBackend; -use crate::core::backend::{Backend, Col, Column}; +use crate::core::backend::{Col, Column}; use crate::core::fields::m31::{BaseField, M31}; use crate::core::poly::circle::{CanonicCoset, CircleEvaluation}; use crate::core::poly::BitReversedOrder; @@ -29,12 +29,15 @@ pub trait PreprocessedColumn: Debug { /// Generates a column according to the preprocessed column chosen. fn gen_column_simd(&self) -> CircleEvaluation; } + impl PartialEq for dyn PreprocessedColumn { fn eq(&self, other: &Self) -> bool { self.id() == other.id() } } + impl Eq for dyn PreprocessedColumn {} + impl Hash for dyn PreprocessedColumn { fn hash(&self, state: &mut H) { self.id().hash(state); @@ -251,114 +254,6 @@ impl PreprocessedColumn for IsStepWithOffset { } } -// TODO(Gali): Remove Enum. -#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] -pub enum PreprocessedColumnEnum { - /// A column with `1` at the first position, and `0` elsewhere. - IsFirst(u32), - Plonk(usize), - /// A column with the numbers [0..2^log_size-1]. - Seq(u32), - XorTable(u32, u32, usize), -} - -impl PreprocessedColumnEnum { - pub const fn name(&self) -> &'static str { - match self { - PreprocessedColumnEnum::IsFirst(_) => "preprocessed_is_first", - PreprocessedColumnEnum::Plonk(_) => "preprocessed_plonk", - PreprocessedColumnEnum::Seq(_) => "preprocessed_seq", - PreprocessedColumnEnum::XorTable(..) => "preprocessed_xor_table", - } - } - - pub fn log_size(&self) -> u32 { - match self { - PreprocessedColumnEnum::IsFirst(log_size) => *log_size, - PreprocessedColumnEnum::Seq(log_size) => *log_size, - PreprocessedColumnEnum::XorTable(log_size, ..) => *log_size, - PreprocessedColumnEnum::Plonk(_) => unimplemented!(), - } - } - - /// Returns the values of the column at the given row. - pub fn packed_at(&self, vec_row: usize) -> PackedM31 { - match self { - PreprocessedColumnEnum::IsFirst(log_size) => { - assert!(vec_row < (1 << log_size) / N_LANES); - if vec_row == 0 { - unsafe { - PackedM31::from_simd_unchecked(Simd::from_array(std::array::from_fn(|i| { - if i == 0 { - 1 - } else { - 0 - } - }))) - } - } else { - PackedM31::zero() - } - } - PreprocessedColumnEnum::Seq(log_size) => { - assert!(vec_row < (1 << log_size) / N_LANES); - PackedM31::broadcast(M31::from(vec_row * N_LANES)) + SIMD_ENUMERATION_0 - } - - _ => unimplemented!(), - } - } - - /// Generates a column according to the preprocessed column chosen. - pub fn gen_preprocessed_column( - preprocessed_column: &PreprocessedColumnEnum, - ) -> CircleEvaluation { - match preprocessed_column { - PreprocessedColumnEnum::IsFirst(log_size) => gen_is_first(*log_size), - PreprocessedColumnEnum::Plonk(_) | PreprocessedColumnEnum::XorTable(..) => { - unimplemented!("eval_preprocessed_column: Plonk and XorTable are not supported.") - } - PreprocessedColumnEnum::Seq(log_size) => gen_seq(*log_size), - } - } -} - -/// Generates a column with a single one at the first position, and zeros elsewhere. -pub fn gen_is_first(log_size: u32) -> CircleEvaluation { - let mut col = Col::::zeros(1 << log_size); - col.set(0, BaseField::one()); - CircleEvaluation::new(CanonicCoset::new(log_size).circle_domain(), col) -} - -/// Generates a column with `1` at every `2^log_step` positions, `0` elsewhere, shifted by offset. -// TODO(andrew): Consider optimizing. Is a quotients of two coset_vanishing (use succinct rep for -// verifier). -pub fn gen_is_step_with_offset( - log_size: u32, - log_step: u32, - offset: usize, -) -> CircleEvaluation { - let mut col = Col::::zeros(1 << log_size); - - let size = 1 << log_size; - let step = 1 << log_step; - let step_offset = offset % step; - - for i in (step_offset..size).step_by(step) { - let circle_domain_index = coset_index_to_circle_domain_index(i, log_size); - let circle_domain_index_bit_rev = bit_reverse_index(circle_domain_index, log_size); - col.set(circle_domain_index_bit_rev, BaseField::one()); - } - - CircleEvaluation::new(CanonicCoset::new(log_size).circle_domain(), col) -} - -/// Generates a column with sequence of numbers from 0 to 2^log_size - 1. -pub fn gen_seq(log_size: u32) -> CircleEvaluation { - let col = Col::::from_iter((0..(1 << log_size)).map(BaseField::from)); - CircleEvaluation::new(CanonicCoset::new(log_size).circle_domain(), col) -} - pub fn gen_preprocessed_columns<'a>( columns: impl Iterator>, ) -> Vec> {