use ark_ec::{ models::CurveConfig, short_weierstrass::{self as sw, SWCurveConfig}, }; use ark_ff::{Field, MontFp, Zero}; use crate::{fq::Fq, fr::Fr}; #[cfg(test)] mod tests; pub type Affine = sw::Affine; pub type Projective = sw::Projective; #[derive(Copy, Clone, Default, PartialEq, Eq)] pub struct Config; impl CurveConfig for Config { type BaseField = Fq; type ScalarField = Fr; /// COFACTOR = 1 const COFACTOR: &'static [u64] = &[0x1]; /// COFACTOR_INV = COFACTOR^{-1} mod r = 1 #[rustfmt::skip] const COFACTOR_INV: Fr = Fr::ONE; } impl SWCurveConfig for Config { /// COEFF_A = 0 const COEFF_A: Fq = Fq::ZERO; /// COEFF_B = 7 const COEFF_B: Fq = MontFp!("7"); /// GENERATOR = (G_GENERATOR_X, G_GENERATOR_Y) const GENERATOR: Affine = Affine::new_unchecked(G_GENERATOR_X, G_GENERATOR_Y); #[inline(always)] fn mul_by_a(_: Self::BaseField) -> Self::BaseField { Self::BaseField::zero() } } /// G_GENERATOR_X = /// 53718550993811904772965658690407829053653678808745171666022356150019200052646 pub const G_GENERATOR_X: Fq = MontFp!("53718550993811904772965658690407829053653678808745171666022356150019200052646"); /// G_GENERATOR_Y = /// 28941648020349172432234515805717979317553499307621291159490218670604692907903 pub const G_GENERATOR_Y: Fq = MontFp!("28941648020349172432234515805717979317553499307621291159490218670604692907903");