Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
79 changes: 61 additions & 18 deletions crates/prover/src/core/pcs/prover.rs
Original file line number Diff line number Diff line change
Expand Up @@ -37,9 +37,28 @@ impl<'a, B: BackendForChannel<MC>, MC: MerkleChannel> CommitmentSchemeProver<'a,
}
}

fn commit(&mut self, polynomials: ColumnVec<CirclePoly<B>>, channel: &mut MC::C) {
fn commit(
&mut self,
evals: ColumnVec<CircleEvaluation<B, BaseField, BitReversedOrder>>,
channel: &mut MC::C,
) {
let _span = span!(Level::INFO, "Commitment").entered();
let tree = CommitmentTreeProver::new(
evals,
self.config.fri_config.log_blowup_factor,
channel,
self.twiddles,
);
self.trees.push(tree);
}

fn commit_on_composition_poly(
&mut self,
polynomials: ColumnVec<CirclePoly<B>>,
channel: &mut MC::C,
) {
let _span = span!(Level::INFO, "Commitment").entered();
let tree = CommitmentTreeProver::new_from_composition_poly(
polynomials,
self.config.fri_config.log_blowup_factor,
channel,
Expand All @@ -52,7 +71,7 @@ impl<'a, B: BackendForChannel<MC>, MC: MerkleChannel> CommitmentSchemeProver<'a,
TreeBuilder {
tree_index: self.trees.len(),
commitment_scheme: self,
polys: Vec::default(),
evals: Vec::default(),
}
}

Expand Down Expand Up @@ -189,27 +208,16 @@ pub struct CommitmentSchemeProof<H: MerkleHasher> {
pub struct TreeBuilder<'a, 'b, B: BackendForChannel<MC>, MC: MerkleChannel> {
tree_index: usize,
commitment_scheme: &'a mut CommitmentSchemeProver<'b, B, MC>,
polys: ColumnVec<CirclePoly<B>>,
evals: ColumnVec<CircleEvaluation<B, BaseField, BitReversedOrder>>,
}
impl<B: BackendForChannel<MC>, MC: MerkleChannel> TreeBuilder<'_, '_, B, MC> {
pub fn extend_evals(
&mut self,
columns: impl IntoIterator<Item = CircleEvaluation<B, BaseField, BitReversedOrder>>,
) -> TreeSubspan {
let span = span!(Level::INFO, "Interpolation for commitment").entered();
let polys = B::interpolate_columns(columns, self.commitment_scheme.twiddles);
span.exit();

self.extend_polys(polys)
}

pub fn extend_polys(
&mut self,
columns: impl IntoIterator<Item = CirclePoly<B>>,
) -> TreeSubspan {
let col_start = self.polys.len();
self.polys.extend(columns);
let col_end = self.polys.len();
let col_start = self.evals.len();
self.evals.extend(columns);
let col_end = self.evals.len();
TreeSubspan {
tree_index: self.tree_index,
col_start,
Expand All @@ -219,7 +227,17 @@ impl<B: BackendForChannel<MC>, MC: MerkleChannel> TreeBuilder<'_, '_, B, MC> {

pub fn commit(self, channel: &mut MC::C) {
let _span = span!(Level::INFO, "Commitment").entered();
self.commitment_scheme.commit(self.polys, channel);
self.commitment_scheme.commit(self.evals, channel);
}

pub fn commit_on_composition_poly(
self,
channel: &mut MC::C,
composition_poly: Vec<CirclePoly<B>>,
) {
let _span = span!(Level::INFO, "Commitment").entered();
self.commitment_scheme
.commit_on_composition_poly(composition_poly, channel);
}
}

Expand All @@ -233,6 +251,31 @@ pub struct CommitmentTreeProver<B: BackendForChannel<MC>, MC: MerkleChannel> {

impl<B: BackendForChannel<MC>, MC: MerkleChannel> CommitmentTreeProver<B, MC> {
pub fn new(
evals: ColumnVec<CircleEvaluation<B, BaseField, BitReversedOrder>>,
log_blowup_factor: u32,
channel: &mut MC::C,
twiddles: &TwiddleTree<B>,
) -> Self {
let span = span!(Level::INFO, "Interpolation").entered();
let polynomials = B::interpolate_columns(evals, twiddles);
span.exit();

let span = span!(Level::INFO, "Extension").entered();
let evaluations = B::evaluate_polynomials(&polynomials, log_blowup_factor, twiddles);
span.exit();

let _span = span!(Level::INFO, "Merkle").entered();
let tree = MerkleProver::commit(evaluations.iter().map(|eval| &eval.values).collect());
MC::mix_root(channel, tree.root());

CommitmentTreeProver {
polynomials,
evaluations,
commitment: tree,
}
}

pub fn new_from_composition_poly(
polynomials: ColumnVec<CirclePoly<B>>,
log_blowup_factor: u32,
channel: &mut MC::C,
Expand Down
6 changes: 3 additions & 3 deletions crates/prover/src/core/prover/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,9 @@ pub fn prove<B: BackendForChannel<MC>, MC: MerkleChannel>(
let composition_poly = component_provers.compute_composition_polynomial(random_coeff, &trace);
span1.exit();

let mut tree_builder = commitment_scheme.tree_builder();
tree_builder.extend_polys(composition_poly.into_coordinate_polys());
tree_builder.commit(channel);
let tree_builder = commitment_scheme.tree_builder();
tree_builder
.commit_on_composition_poly(channel, composition_poly.into_coordinate_polys().to_vec());
span.exit();

// Draw OODS point.
Expand Down
Loading