From 708e6916e906abf011b118092b10877ca6bf6577 Mon Sep 17 00:00:00 2001 From: x Date: Thu, 9 Mar 2023 12:58:22 +0100 Subject: [PATCH] weil reciprocity --- script/research/ec/weil-reciprocity.sage | 48 ++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 script/research/ec/weil-reciprocity.sage diff --git a/script/research/ec/weil-reciprocity.sage b/script/research/ec/weil-reciprocity.sage new file mode 100644 index 000000000..23c6eb6c7 --- /dev/null +++ b/script/research/ec/weil-reciprocity.sage @@ -0,0 +1,48 @@ +p = 115792089237316195423570985008687907853269984665640564039457584007908834671663 +Fp = GF(p) +E = EllipticCurve(Fp, [0, 7]) + +K. = PolynomialRing(Fp, implementation="generic") +L. = PolynomialRing(K, implementation="generic") + +def call(f, P): + Px, Py = P.xy() + return f(x=Px, y=Py) + +def slope_intercept(P0, P1): + P0x, P0y = P0.xy() + P1x, P1y = P1.xy() + m = (P1y - P0y) / (P1x - P0x) + c = P1y - m*P1x + return m, c + +inf = E(0, 1, 0) + +P0 = E(2638891549212558194816434702774699814912586136468438548683319413291233982670, 10140456388517236016202114238224306675726576846632714430386916682749918607464) +P1 = E(17532914127565625088989484000002092349237591241902561765149751398626236254705, 88418181982451178952779569856811854926376929222674054022068577993668451054968) +P2 = -(P0 + P1) +assert P0 + P1 + P2 == inf + +m, c = slope_intercept(P0, P1) +f = y - m*x - c +assert call(f, P0) == 0 +assert call(f, P1) == 0 +assert call(f, P2) == 0 + +A0 = E(71667150045698532747085079020221438975232032539323499361837608460679887058944, 112531462156938649599975140073878402074313288452223046891973447679626205036672) +A1 = E(24400044380857008437858416414134907169391225728426050882076550827717815954208, 31119844425475844378953714282286295361574062544261840901985213408230446258932) +A2 = -(A0 + A1) +assert A0 + A1 + A2 == inf + +λ, μ = slope_intercept(A0, A1) +g = y - λ*x - μ +assert call(g, A0) == 0 +assert call(g, A1) == 0 +assert call(g, A2) == 0 + +s = call(f, A0) * call(f, A1) * call(f, A2) +t = call(g, P0) * call(g, P1) * call(g, P2) +assert s == -t +print(s) +print(-t) +