-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathtest_conrey.py
47 lines (45 loc) · 1.69 KB
/
test_conrey.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
from sage.all import randint, Mod, prod, gcd, N
import pyximport; pyximport.install()
from dirichlet_conrey import DirichletGroup_conrey
def test_conrey(nranges=[(20,100),(200,1000),(500,500000)]):
for n,r in nranges:
for i in range(n):
q = randint(1,r)
print("n, r, i, q = {}, {}, {}, {}".format(n,r,i,q))
G = DirichletGroup_conrey(q)
inv = G.invariants()
cinv = tuple([ Mod(g,q).multiplicative_order() for g in G.gens() ])
try:
assert prod(inv) == G.order()
assert q <= 2 or G.zeta_order() == inv[0]
assert cinv == inv
except:
print( 'group error')
return q, inv, G
if q > 2:
m = 0
while gcd(m,q) != 1:
m = randint(1,q)
chi = G[m]
n = randint(1,q)
try:
assert chi.multiplicative_order() == Mod(m,q).multiplicative_order()
if gcd(n,q) != 1:
try:
assert chi.logvalue(n) == -1
except:
print( 'non unit value error')
return chi, n, r
elif q < 10^6:
try:
ref = chi.sage_character()(n).n().real()
new = N(chi(n).real)
assert abs(ref - new) < 1e-5
except:
print( 'unit value error')
return chi, n
except:
print( 'char error')
return chi, n, r
if __name__ == "__main__":
test_conrey()