Skip to content

Commit

Permalink
generate enabler column
Browse files Browse the repository at this point in the history
  • Loading branch information
shaharsamocha7 committed Jan 8, 2025
1 parent ef25282 commit 748e324
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 1 deletion.
32 changes: 31 additions & 1 deletion stwo_cairo_prover/crates/prover/src/components/utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -81,12 +81,21 @@ impl AtomicMultiplicityColumn {
}
}

/// Generates a padding column for the given log size and padding offset.
/// The padding column is a MultiplicityColumn with the first `padding_offset` elements set to 1 and
/// the rest set to 0.
pub fn gen_padding_column(log_size: usize, padding_offset: usize) -> MultiplicityColumn {
let mut padding_column = MultiplicityColumn::new(1 << log_size);
(0..padding_offset).for_each(|i| padding_column.increase_at(i as u32));
padding_column
}

#[cfg(test)]
mod tests {
use num_traits::{One, Zero};
use rand::rngs::SmallRng;
use rand::{Rng, SeedableRng};
use stwo_prover::core::backend::simd::m31::N_LANES;
use stwo_prover::core::backend::simd::m31::{PackedM31, N_LANES};
use stwo_prover::core::fields::m31::M31;

#[test]
Expand All @@ -107,4 +116,25 @@ mod tests {
assert!(res_chunk.to_array() == expected_chunk);
}
}

#[test]
fn test_gen_padding_column() {
let log_size = 5;
let n_calls = 7;

let enabler_column = super::gen_padding_column(log_size, n_calls);

for (i, val) in enabler_column
.into_simd_vec()
.into_iter()
.flat_map(PackedM31::to_array)
.enumerate()
{
if i < n_calls {
assert_eq!(val, M31::one());
} else {
assert_eq!(val, M31::zero());
}
}
}
}
1 change: 1 addition & 0 deletions stwo_cairo_prover/crates/prover/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
#![feature(
exact_size_is_empty,
trait_upcasting,
portable_simd,
iter_array_chunks,
Expand Down

0 comments on commit 748e324

Please sign in to comment.