/* This code can be loaded, or copied and paste using cpaste, into Sage. It will load the data associated to the HMF, including the field, level, and Hecke and Atkin-Lehner eigenvalue data. */ P. = PolynomialRing(QQ) g = P([-55, 0, 1]) F. = NumberField(g) ZF = F.ring_of_integers() NN = ZF.ideal([8, 4, 2*w + 2]) primes_array = [ [2, 2, w + 1],\ [3, 3, w + 1],\ [3, 3, w + 2],\ [5, 5, -2*w + 15],\ [11, 11, 3*w - 22],\ [13, 13, w + 4],\ [13, 13, w + 9],\ [17, 17, w + 2],\ [17, 17, w + 15],\ [19, 19, -w - 6],\ [19, 19, w - 6],\ [23, 23, w + 3],\ [23, 23, w + 20],\ [47, 47, w + 14],\ [47, 47, w + 33],\ [49, 7, -7],\ [67, 67, w + 16],\ [67, 67, w + 51],\ [73, 73, w + 36],\ [73, 73, w + 37],\ [79, 79, 5*w + 36],\ [79, 79, 5*w - 36],\ [89, 89, -w - 12],\ [89, 89, w - 12],\ [103, 103, w + 40],\ [103, 103, w + 63],\ [131, 131, -6*w - 43],\ [131, 131, -6*w + 43],\ [139, 139, 2*w - 9],\ [139, 139, -2*w - 9],\ [151, 151, 4*w - 27],\ [151, 151, 4*w + 27],\ [163, 163, w + 50],\ [163, 163, w + 113],\ [173, 173, w + 48],\ [173, 173, w + 125],\ [181, 181, -3*w - 26],\ [181, 181, 3*w - 26],\ [193, 193, w + 21],\ [193, 193, w + 172],\ [197, 197, w + 45],\ [197, 197, w + 152],\ [211, 211, 2*w - 3],\ [211, 211, -2*w - 3],\ [223, 223, w + 72],\ [223, 223, w + 151],\ [229, 229, 6*w + 47],\ [229, 229, 6*w - 47],\ [233, 233, w + 88],\ [233, 233, w + 145],\ [239, 239, -3*w - 16],\ [239, 239, 3*w - 16],\ [269, 269, -w - 18],\ [269, 269, w - 18],\ [271, 271, -8*w - 57],\ [271, 271, -8*w + 57],\ [277, 277, w + 71],\ [277, 277, w + 206],\ [293, 293, w + 73],\ [293, 293, w + 220],\ [337, 337, w + 27],\ [337, 337, w + 310],\ [359, 359, 9*w + 64],\ [359, 359, 9*w - 64],\ [367, 367, w + 34],\ [367, 367, w + 333],\ [373, 373, w + 146],\ [373, 373, w + 227],\ [383, 383, w + 173],\ [383, 383, w + 210],\ [389, 389, -5*w - 42],\ [389, 389, 5*w - 42],\ [401, 401, 29*w - 216],\ [401, 401, 11*w - 84],\ [421, 421, -6*w + 49],\ [421, 421, -6*w - 49],\ [431, 431, 3*w - 8],\ [431, 431, -3*w - 8],\ [439, 439, -4*w - 21],\ [439, 439, 4*w - 21],\ [443, 443, w + 99],\ [443, 443, w + 344],\ [449, 449, -8*w - 63],\ [449, 449, -8*w + 63],\ [457, 457, w + 91],\ [457, 457, w + 366],\ [463, 463, w + 38],\ [463, 463, w + 425],\ [467, 467, w + 191],\ [467, 467, w + 276],\ [479, 479, -3*w - 4],\ [479, 479, 3*w - 4],\ [487, 487, w + 223],\ [487, 487, w + 264],\ [491, 491, 3*w - 2],\ [491, 491, -3*w - 2],\ [509, 509, 2*w - 27],\ [509, 509, -2*w - 27],\ [521, 521, -w - 24],\ [521, 521, w - 24],\ [557, 557, w + 75],\ [557, 557, w + 482],\ [571, 571, 11*w + 78],\ [571, 571, 11*w - 78],\ [587, 587, w + 246],\ [587, 587, w + 341],\ [593, 593, w + 184],\ [593, 593, w + 409],\ [613, 613, w + 235],\ [613, 613, w + 378],\ [641, 641, -4*w - 39],\ [641, 641, 4*w - 39],\ [643, 643, w + 174],\ [643, 643, w + 469],\ [647, 647, w + 257],\ [647, 647, w + 390],\ [659, 659, -18*w + 131],\ [659, 659, 30*w - 221],\ [661, 661, 3*w - 34],\ [661, 661, -3*w - 34],\ [673, 673, w + 196],\ [673, 673, w + 477],\ [677, 677, w + 240],\ [677, 677, w + 437],\ [683, 683, w + 136],\ [683, 683, w + 547],\ [709, 709, 21*w - 158],\ [709, 709, 27*w - 202],\ [727, 727, w + 339],\ [727, 727, w + 388],\ [733, 733, w + 39],\ [733, 733, w + 694],\ [739, 739, 10*w - 69],\ [739, 739, 10*w + 69],\ [811, 811, 35*w - 258],\ [811, 811, -19*w + 138],\ [823, 823, w + 177],\ [823, 823, w + 646],\ [829, 829, -6*w - 53],\ [829, 829, 6*w - 53],\ [841, 29, -29],\ [853, 853, w + 316],\ [853, 853, w + 537],\ [857, 857, w + 270],\ [857, 857, w + 587],\ [863, 863, w + 405],\ [863, 863, w + 458],\ [877, 877, w + 377],\ [877, 877, w + 500],\ [881, 881, -19*w + 144],\ [881, 881, -37*w + 276],\ [883, 883, w + 52],\ [883, 883, w + 831],\ [907, 907, w + 350],\ [907, 907, w + 557],\ [919, 919, -8*w - 51],\ [919, 919, 8*w - 51],\ [929, 929, 5*w - 48],\ [929, 929, -5*w - 48],\ [937, 937, w + 176],\ [937, 937, w + 761],\ [947, 947, w + 252],\ [947, 947, w + 695],\ [953, 953, w + 334],\ [953, 953, w + 619],\ [961, 31, -31],\ [983, 983, w + 277],\ [983, 983, w + 706],\ [997, 997, w + 371],\ [997, 997, w + 626]] primes = [ZF.ideal(I) for I in primes_array] heckePol = x K = QQ e = 1 hecke_eigenvalues_array = [0, 3, 1, 0, 4, -2, 6, 5, -3, 1, 3, -6, -2, 0, 8, -5, 12, -4, -2, 14, -6, -2, 11, 3, -6, -10, 3, 1, -4, -4, 4, 20, 13, 23, 10, -14, 0, -8, -23, 17, -12, -12, -5, -23, -26, -14, 14, -10, -17, -25, 8, 0, -4, -12, -14, -2, -10, 22, -8, 24, 23, 23, -30, 6, -20, 28, 0, -16, -38, 6, -32, 16, -27, 29, -30, 10, -24, 16, -16, -8, -32, -8, -6, 10, -7, 25, -22, 38, -7, -21, 36, 12, -2, -22, -3, 31, 2, 10, -6, 42, 42, 42, 23, 37, -15, -5, 14, 30, 28, -44, -19, 5, 31, 37, -6, 22, -43, -17, 20, 12, 1, 9, 30, 14, 21, -41, -46, 26, -52, -28, 42, -6, -40, 16, -47, -5, 16, -32, -48, 8, 5, 30, -2, 21, -27, 16, -32, 10, -46, -50, -18, 25, -21, 31, 13, -58, -14, -15, 41, -26, 54, 55, 45, 37, -27, 3, -16, 24, 26, 42] hecke_eigenvalues = {} for i in range(len(hecke_eigenvalues_array)): hecke_eigenvalues[primes[i]] = hecke_eigenvalues_array[i] AL_eigenvalues = {} AL_eigenvalues[ZF.ideal([2, 2, w + 1])] = 1 # EXAMPLE: # pp = ZF.ideal(2).factor()[0][0] # hecke_eigenvalues[pp]