ntrulp 0.2.5

Pure implementation of high-security prime-degree large-Galois-group inert-modulus ideal-lattice-based cryptography.
Documentation
use criterion::{criterion_group, criterion_main, Criterion};
use ntrulp::poly::rq::Rq;

use ntrulp::encode::rq;
use ntrulp::rng::short_random;

fn encoder_benchmark(cb: &mut Criterion) {
    let mut rng = rand::rng();
    let coeffs = short_random(&mut rng).unwrap();
    let rq = Rq::from(coeffs).recip::<1>().unwrap();
    let bytes0 = rq::encode(&rq.coeffs);

    cb.bench_function("fast_encode", |b| {
        b.iter(|| {
            rq::encode(&rq.coeffs);
        });
    });
    cb.bench_function("fast_decode", |b| {
        b.iter(|| {
            rq::decode(&bytes0);
        });
    });
}

criterion_group!(benches, encoder_benchmark);
criterion_main!(benches);