\\ Pari/GP code for working with number field 40.0.40126953504928778716867347648517224229883090465646395672541598175985664.2 \\ Some of these functions may take a long time to execute (this depends on the field). \\ Define the number field: K = bnfinit(y^40 + 4*y^38 + 14*y^36 + 48*y^34 + 164*y^32 + 560*y^30 + 1912*y^28 + 6528*y^26 + 22288*y^24 + 76096*y^22 + 259808*y^20 + 152192*y^18 + 89152*y^16 + 52224*y^14 + 30592*y^12 + 17920*y^10 + 10496*y^8 + 6144*y^6 + 3584*y^4 + 2048*y^2 + 1024, 1) \\ Defining polynomial: K.pol \\ Degree over Q: poldegree(K.pol) \\ Signature: K.sign \\ Discriminant: K.disc \\ Ramified primes: factor(abs(K.disc))[,1]~ \\ Integral basis: K.zk \\ Class group: K.clgp \\ Unit rank: K.fu \\ Generator for roots of unity: K.tu[2] \\ Fundamental units: K.fu \\ Regulator: K.reg \\ Analytic class number formula: # self-contained Pari/GP code snippet to compute the analytic class number formula K = bnfinit(x^40 + 4*x^38 + 14*x^36 + 48*x^34 + 164*x^32 + 560*x^30 + 1912*x^28 + 6528*x^26 + 22288*x^24 + 76096*x^22 + 259808*x^20 + 152192*x^18 + 89152*x^16 + 52224*x^14 + 30592*x^12 + 17920*x^10 + 10496*x^8 + 6144*x^6 + 3584*x^4 + 2048*x^2 + 1024, 1); [polcoeff (lfunrootres (lfuncreate (K))[1][1][2], -1), 2^K.r1 * (2*Pi)^K.r2 * K.reg * K.no / (K.tu[1] * sqrt (abs (K.disc)))] \\ Intermediate fields: L = nfsubfields(K); L[2..length(b)] \\ Galois group: polgalois(K.pol) \\ Frobenius cycle types: \\ to obtain a list of $[e_i,f_i]$ for the factorization of the ideal $p\mathcal{O}_K$ for $p=7$ in Pari: p = 7; pfac = idealprimedec(K, p); vector(length(pfac), j, [pfac[j][3], pfac[j][4]])