Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
sagemath
GitHub Repository: sagemath/sagelib
Path: blob/master/sage/groups/pari_group.py
4057 views
1
r"""
2
PARI Groups
3
"""
4
5
import group
6
from sage.libs.all import pari_gen
7
from sage.rings.all import Integer
8
from sage.structure.parent import Parent
9
10
class PariGroup(group.Group):
11
def __init__(self, x, degree=None):
12
"""
13
EXAMPLES::
14
15
sage: R.<x> = PolynomialRing(QQ)
16
sage: f = x^4 - 17*x^3 - 2*x + 1
17
sage: G = f.galois_group(pari_group=True); G
18
PARI group [24, -1, 5, "S4"] of degree 4
19
sage: G.category()
20
Category of finite groups
21
22
Caveat: fix those tests and/or document precisely that this is
23
an abstract group without explicit elements::
24
25
sage: TestSuite(G).run()
26
Failure in
27
...
28
The following tests failed: _test_an_element, _test_associativity, _test_elements, _test_elements_eq, _test_enumerated_set_contains, _test_enumerated_set_iter_cardinality, _test_enumerated_set_iter_list, _test_inverse, _test_one, _test_prod, _test_some_elements
29
"""
30
if not isinstance(x, pari_gen):
31
raise TypeError, "x (=%s) must be a PARI gen"%x
32
self.__x = x
33
self.__degree = degree
34
from sage.categories.finite_groups import FiniteGroups
35
Parent.__init__(self, category = FiniteGroups())
36
37
def __repr__(self):
38
return "PARI group %s of degree %s"%(self.__x, self.__degree)
39
40
def __cmp__(self, other):
41
if not isinstance(other, PariGroup):
42
return cmp(type(self), type(other))
43
return cmp((self.__x, self.__degree), (other.__x, other.__degree))
44
45
def _pari_(self):
46
return self.__x
47
48
def degree(self):
49
return self.__degree
50
51
def order(self):
52
return Integer(self.__x[0])
53
54
def permutation_group(self):
55
if self.__degree is None:
56
raise NotImplementedError
57
import perm_gps.permgroup_named
58
return perm_gps.permgroup_named.TransitiveGroup(self.__degree, self.__x[2])
59
60
_permgroup_ = permutation_group
61
62