You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

34 lines
843 B

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. use rand::SeedableRng;
  2. use rand_xorshift::XorShiftRng;
  3. use std::ops::{AddAssign, MulAssign, SubAssign};
  4. use ark_curve_benches::*;
  5. use ark_bn254::{
  6. fq::Fq, fq2::Fq2, fr::Fr, Bn254, Fq12, G1Affine, G1Projective as G1, G2Affine,
  7. G2Projective as G2,
  8. };
  9. use ark_ec::{
  10. PairingEngine, ProjectiveCurve,
  11. };
  12. use ark_ff::{
  13. biginteger::{BigInteger256 as FrRepr, BigInteger256 as FqRepr},
  14. BigInteger, Field, PrimeField, SquareRootField, UniformRand,
  15. };
  16. mod g1 {
  17. use super::*;
  18. ec_bench!(G1, G1Affine);
  19. }
  20. mod g2 {
  21. use super::*;
  22. ec_bench!(G2, G2Affine);
  23. }
  24. f_bench!(Fq, Fq, FqRepr, FqRepr, fq);
  25. f_bench!(Fr, Fr, FrRepr, FrRepr, fr);
  26. f_bench!(extension, Fq2, Fq2, fq2);
  27. f_bench!(target, Fq12, Fq12, fq12);
  28. pairing_bench!(Bn254, Fq12);
  29. bencher::benchmark_main!(fq, fr, fq2, fq12, g1::group_ops, g2::group_ops, pairing);