From b9d91f59d05e5f691e22087ed31be79abaa2b6c4 Mon Sep 17 00:00:00 2001 From: Shahar Papini Date: Tue, 9 Jul 2024 07:59:57 +0300 Subject: [PATCH] Eval framework info --- .../prover/src/constraint_framework/info.rs | 44 +++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 crates/prover/src/constraint_framework/info.rs diff --git a/crates/prover/src/constraint_framework/info.rs b/crates/prover/src/constraint_framework/info.rs new file mode 100644 index 000000000..499b0cc0f --- /dev/null +++ b/crates/prover/src/constraint_framework/info.rs @@ -0,0 +1,44 @@ +use std::ops::Mul; + +use num_traits::One; + +use super::EvalAtRow; +use crate::core::fields::m31::BaseField; +use crate::core::fields::qm31::SecureField; +use crate::core::pcs::TreeVec; + +#[derive(Default)] +pub struct InfoEvaluator { + pub mask_offsets: TreeVec>>, + pub n_constraints: usize, +} +impl InfoEvaluator { + pub fn new() -> Self { + Self::default() + } +} +impl EvalAtRow for InfoEvaluator { + type F = BaseField; + type EF = SecureField; + fn next_interaction_mask( + &mut self, + interaction: usize, + offsets: [isize; N], + ) -> [Self::F; N] { + if self.mask_offsets.len() <= interaction { + self.mask_offsets.resize(interaction + 1, vec![]); + } + self.mask_offsets[interaction].push(offsets.into_iter().collect()); + [BaseField::one(); N] + } + fn add_constraint(&mut self, _constraint: G) + where + Self::EF: Mul, + { + self.n_constraints += 1; + } + + fn combine_ef(_values: [Self::F; 4]) -> Self::EF { + SecureField::one() + } +}