|
|
// Copyright (c) 2023 Espresso Systems (espressosys.com)
// This file is part of the HyperPlonk library.
// You should have received a copy of the MIT License
// along with the HyperPlonk library. If not, see <https://mit-license.org/>.
#[macro_use]
extern crate criterion;
use arithmetic::fix_variables;
use ark_bls12_381::Fr;
use ark_ff::Field;
use ark_poly::{DenseMultilinearExtension, MultilinearExtension};
use ark_std::{ops::Range, test_rng};
use criterion::{black_box, BenchmarkId, Criterion};
const NUM_VARIABLES_RANGE: Range<usize> = 10..21;
fn evaluation_op_bench<F: Field>(c: &mut Criterion) {
let mut rng = test_rng();
let mut group = c.benchmark_group("Evaluate");
for nv in NUM_VARIABLES_RANGE {
group.bench_with_input(BenchmarkId::new("evaluate native", nv), &nv, |b, &nv| {
let poly = DenseMultilinearExtension::<F>::rand(nv, &mut rng);
let point: Vec<_> = (0..nv).map(|_| F::rand(&mut rng)).collect();
b.iter(|| black_box(poly.evaluate(&point).unwrap()))
});
group.bench_with_input(BenchmarkId::new("evaluate optimized", nv), &nv, |b, &nv| {
let poly = DenseMultilinearExtension::<F>::rand(nv, &mut rng);
let point: Vec<_> = (0..nv).map(|_| F::rand(&mut rng)).collect();
b.iter(|| black_box(fix_variables(&poly, &point)))
});
}
group.finish();
}
fn bench_bls_381(c: &mut Criterion) {
evaluation_op_bench::<Fr>(c);
}
criterion_group!(benches, bench_bls_381);
criterion_main!(benches);
|