use crate::{fq::Fq, fr::Fr}; use ark_ec::{ models::CurveConfig, short_weierstrass::{self as sw, SWCurveConfig}, }; use ark_ff::{Field, MontFp, Zero}; #[cfg(test)] mod tests; #[derive(Copy, Clone, Default, PartialEq, Eq)] pub struct VestaConfig; impl CurveConfig for VestaConfig { type BaseField = Fq; type ScalarField = Fr; /// COFACTOR = 1 const COFACTOR: &'static [u64] = &[0x1]; /// COFACTOR_INV = 1 const COFACTOR_INV: Fr = Fr::ONE; } pub type Affine = sw::Affine; pub type Projective = sw::Projective; impl SWCurveConfig for VestaConfig { /// COEFF_A = 0 const COEFF_A: Fq = Fq::ZERO; /// COEFF_B = 5 const COEFF_B: Fq = MontFp!("5"); /// AFFINE_GENERATOR_COEFFS = (G1_GENERATOR_X, G1_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 = -1 /// Encoded in Montgomery form, so the value here is -R mod p. pub const G_GENERATOR_X: Fq = MontFp!("-1"); /// G_GENERATOR_Y = 2 /// Encoded in Montgomery form, so the value here is 2R mod p. pub const G_GENERATOR_Y: Fq = MontFp!("2");