From 591046b620417f6de51248e131875904c1f211a1 Mon Sep 17 00:00:00 2001 From: Lev Sizov Date: Thu, 17 Nov 2022 09:37:17 +0100 Subject: [PATCH] Fix Ethereum compatibility for infinite G1Affine and G2Affine --- src/ethereum.rs | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/src/ethereum.rs b/src/ethereum.rs index de644cc..d061ed2 100644 --- a/src/ethereum.rs +++ b/src/ethereum.rs @@ -26,7 +26,7 @@ impl From for G1Affine { fn from(src: G1) -> G1Affine { let x: Fq = u256_to_point(src.x); let y: Fq = u256_to_point(src.y); - let inf = x.is_zero() && y.is_zero(); + let inf = x.is_zero() || y.is_zero(); G1Affine::new(x, y, inf) } } @@ -64,7 +64,7 @@ impl From for G2Affine { let c1 = u256_to_point(src.y[1]); let y = Fq2::new(c0, c1); - let inf = x.is_zero() && y.is_zero(); + let inf = x.is_zero() || y.is_zero(); G2Affine::new(x, y, inf) } } @@ -236,6 +236,14 @@ mod tests { assert_eq!(el2, el4); } + #[test] + fn convert_infinity_g1() { + let g1 = G1Affine::default(); + let g1_eth = G1::from(&g1); + let g1_2 = G1Affine::from(g1_eth); + assert_eq!(g1, g1_2); + } + #[test] fn convert_g2() { let el = g2(); @@ -246,6 +254,14 @@ mod tests { assert_eq!(el2, el4); } + #[test] + fn convert_infinity_g2() { + let g2 = G2Affine::default(); + let g2_eth = G2::from(&g2); + let g2_2 = G2Affine::from(g2_eth); + assert_eq!(g2, g2_2); + } + #[test] fn convert_vk() { let vk = ark_groth16::VerifyingKey:: {