Available versions of this document: latest release, release 4.12, release 4.11, release 4.10, release 4.9, release 4.8, release 4.7, release 4.6, release 4.5, release 4.4, release 4.3, release 4.2, release 4.1, release 4.0, release 3.6, release 3.5, nightly master
Reference documentation for older polymake versions: release 3.4, release 3.3, release 3.2
BigObject Action
from application group
parametrized object used for encoding group actions (representations).
- GeneratorType is
Array<Int>
for permutation groups, orMatrix<Scalar>
for matrix groups.
- DomainType is
Int
for permutation groups,Vector<Scalar>
for matrix groups acting on facets or vertices,Set<Int>
orBitset
for groups acting on simplices,IncidenceMatrix
for groups acting on (maximal) cones of a fan
- OrbitGeneratorScalarType is the type of the entries of vectors that generate a geometric orbit; default
Rational
Properties
Symmetry
These properties capture information of the object that is concerned with the action of permutation groups.
-
ALL_GROUP_ELEMENTS
All elements of the group, as expressed in the present action Notice that this is a temporary property; it will not be stored in any file.
-
CHARACTER
The character of the action. The ordering corresponds to the columns of the CHARACTER_TABLE.
- Type:
- Example:
The following computes the character of the 3D-cube symmetry group acting on its vertices.
> $p = cube(3, group=>true); > print $p->GROUP->VERTICES_ACTION->CHARACTER; 8 4 2 0 0 0 0 0 0 0
-
CONJUGACY_CLASSES
The conjugacy classes themselves.
- Type:
- Example:
Every conjugacy class of the alternating group on 3 elements is a singleton, since it is abelian.
> print alternating_group(3)->PERMUTATION_ACTION->CONJUGACY_CLASSES; {<0 1 2>} {<1 2 0>} {<2 0 1>}
-
CONJUGACY_CLASS_REPRESENTATIVES
A set of representatives for each conjugacy class. The order of these representatives must agree with the implicit order of the columns of the CHARACTER_TABLE.
- Type:
Array<GeneratorType>
- Example:
The following lists representatives of the 3D-cube symmetry group acting on its facets.
> $p = cube(3, group=>true); > print $p->GROUP->FACETS_ACTION->CONJUGACY_CLASS_REPRESENTATIVES; 0 1 2 3 4 5 0 1 4 5 2 3 4 5 0 1 2 3 1 0 2 3 4 5 1 0 4 5 2 3 3 2 0 1 4 5 5 4 0 1 2 3 1 0 3 2 4 5 1 0 5 4 2 3 1 0 3 2 5 4
-
DEGREE
The degree of the representation. For permutation groups, this is the number of permuted indices, for matrix groups it is the dimension of the vector space the group acts on
- Type:
- Example:
The combinatorial/linear automoprhisms of a 3D-cube can be represented by its vertices or facets. The former has degree 8 (8 vertices), and the latter has degree 6 (6 facets).
> $p = cube(3, group=>true); > print $p->GROUP->VERTICES_ACTION->DEGREE; 8
print $p→GROUP→FACETS_ACTION→DEGREE;
-
DOMAIN_NAME
the name of the property that we act on, for example MAX_INTERIOR_SIMPLICES or INTERIOR_RIDGES
- Type:
- Example:
The following induces the action of the cube symmetry group on the MAX_INTERIOR_SIMPLICES
> $p = cube(3, group=>true); > $a = group::induce_set_action($p, $p->GROUP->VERTICES_ACTION, "MAX_INTERIOR_SIMPLICES"); > print $a->DOMAIN_NAME; MAX_INTERIOR_SIMPLICES
-
EQUATIONS_GENERATORS
A set of generators for equations, stored as the rows of a matrix. The list of generators may be redundant and non-canonical.
- Type:
Matrix<OrbitGeneratorScalarType,NonSymmetric>
-
EXPLICIT_ORBIT_REPRESENTATIVES
The representatives of orbits explicitly, not via their indices.
- Type:
Array<DomainType>
- Example:
Consider the symmetries of a cube. These symmetres act on the cube's maximal interior simplices. Note that there are four orbits, which correspond to the four possible configurations of four vertices in general position up to symmetry. This property then returns four sets of vertices by their indices, each of which represent a single orbit.
> $c = polytope::cube(3, group=>1); > induce_implicit_action($c, $c->GROUP->VERTICES_ACTION, $c->GROUP->REPRESENTATIVE_MAX_INTERIOR_SIMPLICES, "MAX_INTERIOR_SIMPLICES"); > print $c->GROUP->IMPLICIT_SET_ACTION->EXPLICIT_ORBIT_REPRESENTATIVES; {0 1 2 4} {0 1 2 5} {0 1 2 7} {0 3 5 6}
-
EXPLICIT_ORBIT_REPRESENTATIVE_MATRIX
The representatives of orbits explicitly, not via their indices
- Type:
Matrix<OrbitGeneratorScalarType,NonSymmetric>
- Example:
We begin with a polyhedral fan. Consider the orbit fan of the original fan, which is the fan defined to be the minimal fan invariant under (in this case) the linear symmetries of the square (in homogenous coordinates), which also contains the rays and maximal cones of the original fan. It is reasonable to ask for the action of the cube on the rays. This property allows us to extract explicit rays which represent the orbits of this action.
> $f = new PolyhedralFan(RAYS=>[[1,1,1],[1,1,0],[1,1/2,1/4]],MAXIMAL_CONES=>[[0,2],[1,2]]); > $of = orbit_fan($f,polytope::cube(2,group=>1)->GROUP->MATRIX_ACTION); > print $of->GROUP->RAYS_ACTION->EXPLICIT_ORBIT_REPRESENTATIVE_MATRIX; 1 -1 -1 1 -1 0 1 -1/2 -1/4
-
FACETS_GENERATORS
A set of generators for facets, stored as the rows of a matrix. This set of generators together with an action on the facets results in a set of facets, which induce a polyhedron. The list of generators may be redundant and non-canonical.
- Type:
Matrix<OrbitGeneratorScalarType,NonSymmetric>
- Example:
Consider the generating facets (stored as row vectors) (1,0,3), (-4,5,6), where we allow ourselves to permute the first and second coordinate to create the new facets (5,-4,6) and (0,1,3). This results in an unbounded polyhedron. The creation of the new facets may be done automatically in polymake via
> $a = new group::PermutationAction(GENERATORS=>[[1,0,2]], FACETS_GENERATORS=>[[1,1,0,3], [1,-4,5,6]]); > $g = new group::Group(HOMOGENEOUS_COORDINATE_ACTION=>$a); > $p = new polytope::Polytope<Rational>(GROUP=>$g); > print $p->FACETS; 1 0 1 3 1 1 0 3 1 -4 5 6 1 5 -4 6
> print $p->BOUNDED; false
-
GENERATORS
The generators of the group action.
-
IMAGES
The images of all domain elements under each group element: [ [ g(x) for x in D ] for g in G ]
- Type:
-
INDEX_OF
This is populated, when the action was induced by
induce_set_action
. In this case, the action corresponds to permuations of sets. However, internally (i.e. in the output of other properties) these sets are referred to by their indices in some array. This property stores the map which takes a set which is being permuted, and outputs the corresponding index in the array. This is a temporary property; it will not be stored in any file.- Type:
- Example:
Consider the induced action on the four interior triangles of a square. The following shows an assigment from each triangle (represented as the set of its vertices) to a number between 0 and 3.
> $p = cube(2, group=>true); > $a = group::induce_set_action($p, $p->GROUP->VERTICES_ACTION, "MAX_INTERIOR_SIMPLICES"); > print $p->GROUP->SET_ACTION->INDEX_OF; {({1 2 3} 3) ({0 1 2} 0) ({0 2 3} 2) ({0 1 3} 1)}
-
INEQUALITIES_GENERATORS
A set of generators for inequalities, stored as the rows of a matrix. The list of generators may be redundant and non-canonical.
- Type:
Matrix<OrbitGeneratorScalarType,NonSymmetric>
- Example:
The following constructs a truncated orbit polytope. The inequalites used to generate the polytope can then be recovered by this property.
> $p = orbit_polytope(new Matrix([ [1,6,0,5,-5,0,-5], [1,1,2,3,4,5,6] ]), group::cyclic_group(6)); > $p->GROUP->FACETS_ACTION; > $tp = truncated_orbit_polytope($p, 1/2); > print $tp->GROUP->COORDINATE_ACTION->INEQUALITIES_GENERATORS; 1 -3/23 -1/23 -1/23 -1/23 -1/23 1/23 1 -1/21 -1/21 -1/21 -1/21 -1/21 -1/21 1 -63/313 -29/939 -29/939 -29/939 47/313 -13/313 1 -101/1651 1919/1651 -1701/1651 109/1651 2029/1651 -1601/1651 1 1/19 21/19 -1 1/19 21/19 -1 1 -17/167 -7/167 -7/167 3/167 -17/167 3/167 1 -103/718 -17/718 -17/718 48/359 16/359 -93/718 1 43/2157 2363/2157 -2057/2157 683/2157 2143/2157 -2257/2157 1 109/1651 1769/1651 -1551/1651 529/1651 1549/1651 -1751/1651 1 -19/219 1/219 -19/219 1/219 -19/219 1/219 1 16769/5331 -6431/5331 -6331/5331 19189/5331 -4231/5331 -4331/5331 1 23219/23181 -26681/23181 2339/23181 30919/23181 -19681/23181 3919/23181 1 3 -1 -1 3 -1 -1 -1 1 1 1 1 1 1 111/2 -6 -1 -1 -1 -1 4 661/2 -31 9 -11 -11 -11 -11
-
INPUT_LINEALITY_GENERATORS
A set of generators for input lineality, stored as the rows of a matrix. The list of generators may be redundant and non-canonical.
- Type:
Matrix<OrbitGeneratorScalarType,NonSymmetric>
-
INPUT_RAYS_GENERATORS
A set of generators for input rays, stored as the rows of a matrix. The list of generators may be redundant and non-canonical. This may also refer to points, when this stores an action corresponding to a polytope.
- Type:
Matrix<OrbitGeneratorScalarType,NonSymmetric>
- Example:
Consider the point (2,1), and consider the symmetry group of linear symmetries on the square, where each symmetry is represented as a matrix. The following computes the polytope whose vertices are the image of (2,1) under the matrices corresponding to linear symmetries. You can recover (2,1) (in homogenous coordinates) by asking the underlying symmetry group for its INPUT_RAYS_GENERATORS.
> $g = orbit_polytope(new Vector([1,1,2]), polytope::cube(2,group=>1)->GROUP->MATRIX_ACTION); > print $g->GROUP->MATRIX_ACTION->INPUT_RAYS_GENERATORS; 1 1 2
-
IRREDUCIBLE_DECOMPOSITION
The multiplicities of each irreducible representation in this action. The ordering corresponds to the rows of the CHARACTER_TABLE
- Type:
- Example:
The following computes the irreducible decomposistion of the 3D-cube symmetry group acting on its vertices.
> $p = cube(3, group=>true); > print $p->GROUP->VERTICES_ACTION->IRREDUCIBLE_DECOMPOSITION; 1 0 0 1 0 0 0 0 1 1
-
LINEALITY_SPACE_GENERATORS
A set of generators for input lineality, stored as the rows of a matrix. The list of generators may be redundant and non-canonical.
- Type:
Matrix<OrbitGeneratorScalarType,NonSymmetric>
-
MAXIMAL_CONES_GENERATORS
A set of generators for the maximal cones of a fan, stored in terms of indices of vertex generators. The list of generators may be redundant and non-canonical.
- Type:
- Example:
Consider a PolyhedralFan where we know what the rays are, and we know the symmetries of this polyhedral fan with respect to its rays and its maximal cones. We can fully describe the action on the rays, but we only know a few of the maximal cones. By applying the symmetries on the rays, we may deduce the PolyhedralFan with the least amount of maximal cones which respect the action of the symmetry group on its maximal cones.
> $ra = new group::PermutationAction(GENERATORS=>[[0,3,2,1]]); > $a = new group::PermutationAction(MAXIMAL_CONES_GENERATORS=>[[0,1],[1,2]]); > $g = new group::Group(MAXIMAL_CONES_ACTION=>$a, RAYS_ACTION=>$ra); > $f = new PolyhedralFan(GROUP=>$g, RAYS=>[[1,1],[1,0],[-1,-1],[0,1]]); > print $f->MAXIMAL_CONES; {2 3} {1 2} {0 1} {0 3}
-
N_EQUATIONS_GENERATORS
The number of generators for orbits.
- Type:
-
N_FACETS_GENERATORS
The number of generators for orbits.
- Type:
-
N_INEQUALITIES_GENERATORS
The number of generators for orbits. See
INEQUALITIES_GENERATORS
- Type:
- Example:
As in the example for
INEQUALITIES_GENERATORS
, constructs a truncated orbit polytope. The number of inequalities used to generate the polytope may be recovered by this property.> $p = orbit_polytope(new Matrix([ [1,6,0,5,-5,0,-5], [1,1,2,3,4,5,6] ]), group::cyclic_group(6)); > $p->GROUP->FACETS_ACTION; > $tp = truncated_orbit_polytope($p, 1/2); > print $tp->GROUP->COORDINATE_ACTION->N_INEQUALITIES_GENERATORS; 16
-
N_INPUT_LINEALITY_GENERATORS
The number of generators for orbits.
- Type:
-
N_INPUT_RAYS_GENERATORS
The number of input ray generators, see
INPUT_RAYS_GENERATORS
.- Type:
- Example:
Consider the point (1,2,3), where we may permute the coordinates as we wish. Taking the convex hull, we arrive at a polytope. Since we permuted (1,2,3) to get the vertices, we naturally have a group associated with the polytope. This has one input ray generator (in this case a point), namely (1,2,3).
> $g = polytope::orbit_polytope(new Vector([1,1,2,3]), group::symmetric_group(3)); > print $g->GROUP->COORDINATE_ACTION->N_INPUT_RAYS_GENERATORS; 1
-
N_LINEALITY_SPACE_GENERATORS
The number of generators for orbits.
- Type:
-
N_MAXIMAL_CONES_GENERATORS
The number of generators for orbits.
- Type:
-
N_ORBITS
The number of orbits in the domain under the group action.
- Type:
- Example:
Under the action of the symmetric group any element may be moved to any other element.
> print symmetric_group(20)->PERMUTATION_ACTION->N_ORBITS; 1
-
N_ORBIT_REPRESENTATIVES
the number of representatives of orbits
- Type:
-
N_RAYS_GENERATORS
The number of generators for orbits. See
RAYS_GENERATORS
.- Type:
- Example:
Consider a polyhedral fan. We may the coordinates of the rays to obtain new rays. We define a new polyhedral by the rays we obtain in this way. This property lets us recover the number of generators we gave in this construction.
> $f = new PolyhedralFan(RAYS=>[[1,1],[1,0],[-1,-1]], MAXIMAL_CONES=>[[0,1],[1,2]]); > $of = orbit_fan($f,[[1,0]]); > print $of->GROUP->HOMOGENEOUS_COORDINATE_ACTION->N_RAYS_GENERATORS; 3
-
ORBITS
The orbits of the domain, represented via their indices.
- Type:
- Example:
Consider the linear symmetries over an Egyptian pyramid (pyramid with a square base) acting on the vertices. All four of the vertices of the base may be exchanged by 90/180-degree rotations. However, the apex vertex is a fixed point under any symmetry. This means that there should be two orbits - one of size 4, one of size 1.
> $c = cube(2); > $p = pyramid($c); > linear_symmetries($p); > print $p->GROUP->VERTICES_ACTION->ORBITS; {0 1 2 3} {4}
-
ORBIT_REPRESENTATIVES
A collection of representatives for each orbit, represented via their indices
- Type:
- Example:
Consider the linear symmetries over an Egyptian pyramid (pyramid with a square base). There are two orbits - one orbit consisting of the four vertices of the base square, and one consisting of the apex vertex. This returns a vertex of the square, and the apex vertex (by their indices).
> $s = cube(2); > $p = pyramid($s); > linear_symmetries($p); > print $p->GROUP->VERTICES_ACTION->ORBIT_REPRESENTATIVES; 0 4
-
ORBIT_REPRESENTATIVE_LABELS
Labels for the orbit representatives
- Type:
-
ORBIT_SIZES
The cardinality of each orbit
- Type:
-
PERMUTATION_TO_ORBIT_ORDER
A permutation that orders the domain elements by orbits. After permutation, the first elements will be the ones in the first orbit (as ordered in
ORBITS
), and the ones after will be in the second orbit, and so on.- Type:
- Example:
Begin with a polyhedral fan, and consider its orbit fan with respect to the linear symmetries of a square in homogenous coordinates. Then the following returns a permutation on the orbit fan's maximal cones, which encodes the sequence 0 3 4 5 1 6 7 8 2 9 10 11 12 13 14 15, which is a sequence respecting the orbit order.
> $f = new PolyhedralFan(RAYS=>[[1,1,1],[1,1,0],[1,1/2,1/4]],MAXIMAL_CONES=>[[0,2],[1,2]]); > $of = orbit_fan($f,polytope::cube(2,group=>1)->GROUP->MATRIX_ACTION); > $of->GROUP->RAYS_ACTION; > print $of->GROUP->MAXIMAL_CONES_ACTION->ORBITS; {0 3 4 5} {1 6 7 8} {2 9 10 11 12 13 14 15}
> print $of->GROUP->MAXIMAL_CONES_ACTION->PERMUTATION_TO_ORBIT_ORDER; 0 4 8 1 2 3 5 6 7 9 10 11 12 13 14 15
-
RAYS_GENERATORS
A set of generators for rays, stored as the rows of a matrix. The list of generators may be redundant and non-canonical.
- Type:
Matrix<OrbitGeneratorScalarType,NonSymmetric>
- Example:
Consider a polyhedral fan. We consider the orbit fan of this fan - i.e. we consider the rays, upon which we may apply elements of a finite matrix group. This will result in new rays, and this collection of rays defines a new a new polyhedral fan. The original rays we had may be recovered using this property.
> $f = new PolyhedralFan(RAYS=>[[1,1],[1,0],[-1,-1]], MAXIMAL_CONES=>[[0,1],[1,2]]); > $of = orbit_fan($f,polytope::cube(2,group=>1)->GROUP->MATRIX_ACTION); > print $of->GROUP->MATRIX_ACTION->RAYS_GENERATORS; 1 1 1 0 -1 -1