Skip to content

Commit 490b166

Browse files
committed
adding alias in polytope, plus doc formatting
1 parent b8f98e7 commit 490b166

File tree

2 files changed

+68
-52
lines changed

2 files changed

+68
-52
lines changed

src/sage/geometry/lattice_polytope.py

+48-45
Original file line numberDiff line numberDiff line change
@@ -43,14 +43,14 @@
4343
4444
.. NOTE::
4545
46-
IMPORTANT: PALP requires some parameters to be determined during
47-
compilation time, i.e., the maximum dimension of polytopes, the
48-
maximum number of points, etc. These limitations may lead to errors
49-
during calls to different functions of these module. Currently, a
50-
:exc:`ValueError` exception will be raised if the output of ``poly.x``
51-
or ``nef.x`` is empty or contains the exclamation mark. The error
52-
message will contain the exact command that caused an error, the
53-
description and vertices of the polytope, and the obtained output.
46+
IMPORTANT: PALP requires some parameters to be determined during
47+
compilation time, i.e., the maximum dimension of polytopes, the
48+
maximum number of points, etc. These limitations may lead to errors
49+
during calls to different functions of these module. Currently, a
50+
:exc:`ValueError` exception will be raised if the output of ``poly.x``
51+
or ``nef.x`` is empty or contains the exclamation mark. The error
52+
message will contain the exact command that caused an error, the
53+
description and vertices of the polytope, and the obtained output.
5454
5555
Data obtained from PALP and some other data is cached and most
5656
returned values are immutable. In particular, you cannot change the
@@ -360,16 +360,16 @@ def ReflexivePolytope(dim, n):
360360
361361
.. NOTE::
362362
363-
#. Numeration starts with zero: `0 \leq n \leq 15` for `{\rm dim} = 2`
364-
and `0 \leq n \leq 4318` for `{\rm dim} = 3`.
363+
#. Numeration starts with zero: `0 \leq n \leq 15` for `{\rm dim} = 2`
364+
and `0 \leq n \leq 4318` for `{\rm dim} = 3`.
365365
366-
#. During the first call, all reflexive polytopes of requested
367-
dimension are loaded and cached for future use, so the first
368-
call for 3-dimensional polytopes can take several seconds,
369-
but all consecutive calls are fast.
366+
#. During the first call, all reflexive polytopes of requested
367+
dimension are loaded and cached for future use, so the first
368+
call for 3-dimensional polytopes can take several seconds,
369+
but all consecutive calls are fast.
370370
371-
#. Equivalent to ``ReflexivePolytopes(dim)[n]`` but checks bounds
372-
first.
371+
#. Equivalent to ``ReflexivePolytopes(dim)[n]`` but checks bounds
372+
first.
373373
374374
EXAMPLES:
375375
@@ -420,9 +420,9 @@ def ReflexivePolytopes(dim):
420420
421421
.. NOTE::
422422
423-
During the first call the database is loaded and cached for
424-
future use, so repetitive calls will return the same object in
425-
memory.
423+
During the first call the database is loaded and cached for
424+
future use, so repetitive calls will return the same object in
425+
memory.
426426
427427
INPUT:
428428
@@ -970,14 +970,14 @@ def _palp(self, command, reduce_dimension=False):
970970
r"""
971971
Run ``command`` on vertices of this polytope.
972972
973-
Returns the output of ``command`` as a string.
973+
This returns the output of ``command`` as a string.
974974
975975
.. NOTE::
976976
977-
PALP cannot be called for polytopes that do not span the ambient space.
978-
If you specify ``reduce_dimension=True`` argument, PALP will be
979-
called for vertices of this polytope in some basis of the affine space
980-
it spans.
977+
PALP cannot be called for polytopes that do not span the
978+
ambient space. If you specify ``reduce_dimension=True``
979+
argument, PALP will be called for vertices of this
980+
polytope in some basis of the affine space it spans.
981981
982982
TESTS::
983983
@@ -1409,13 +1409,14 @@ def affine_transform(self, a=1, b=0):
14091409
14101410
.. NOTE::
14111411
1412-
#. While ``a`` and ``b`` may be rational, the final result must be a
1413-
lattice polytope, i.e. all vertices must be integral.
1412+
#. While ``a`` and ``b`` may be rational, the final result
1413+
must be a lattice polytope, i.e. all vertices must be integral.
14141414
1415-
#. If the transform (restricted to this polytope) is bijective, facial
1416-
structure will be preserved, e.g. the first facet of the image will
1417-
be spanned by the images of vertices which span the first facet of
1418-
the original polytope.
1415+
#. If the transform (restricted to this polytope) is
1416+
bijective, facial structure will be preserved, e.g. the
1417+
first facet of the image will be spanned by the images
1418+
of vertices which span the first facet of the original
1419+
polytope.
14191420
14201421
INPUT:
14211422
@@ -1496,6 +1497,8 @@ def affine_transform(self, a=1, b=0):
14961497
r._original = self
14971498
return r
14981499

1500+
linear_transformation = affine_transform
1501+
14991502
def ambient(self):
15001503
r"""
15011504
Return the ambient structure of ``self``.
@@ -2396,10 +2399,10 @@ def incidence_matrix(self):
23962399
23972400
.. NOTE::
23982401
2399-
The columns correspond to facets/facet normals
2400-
in the order of :meth:`facet_normals`, the rows
2401-
correspond to the vertices in the order of
2402-
:meth:`vertices`.
2402+
The columns correspond to facets/facet normals
2403+
in the order of :meth:`facet_normals`, the rows
2404+
correspond to the vertices in the order of
2405+
:meth:`vertices`.
24032406
24042407
EXAMPLES::
24052408
@@ -2450,9 +2453,9 @@ def index(self):
24502453
24512454
.. NOTE::
24522455
2453-
The first call to this function for each dimension can take
2454-
a few seconds while the dictionary of all polytopes is
2455-
constructed, but after that it is cached and fast.
2456+
The first call to this function for each dimension can take
2457+
a few seconds while the dictionary of all polytopes is
2458+
constructed, but after that it is cached and fast.
24562459
24572460
:rtype: integer
24582461
@@ -4972,15 +4975,15 @@ def _palp(command, polytopes, reduce_dimension=False):
49724975
Run ``command`` on vertices of given
49734976
``polytopes``.
49744977
4975-
Returns the name of the file containing the output of
4978+
This returns the name of the file containing the output of
49764979
``command``. You should delete it after using.
49774980
49784981
.. NOTE::
49794982
4980-
PALP cannot be called for polytopes that do not span the ambient space.
4981-
If you specify ``reduce_dimension=True`` argument, PALP will be
4982-
called for vertices of this polytope in some basis of the affine space
4983-
it spans.
4983+
PALP cannot be called for polytopes that do not span the
4984+
ambient space. If you specify ``reduce_dimension=True``
4985+
argument, PALP will be called for vertices of this polytope in
4986+
some basis of the affine space it spans.
49844987
49854988
TESTS::
49864989
@@ -5436,8 +5439,8 @@ def convex_hull(points):
54365439
54375440
.. NOTE::
54385441
5439-
``points`` might not span the space. Also, it fails for large
5440-
numbers of vertices in dimensions 4 or greater
5442+
``points`` might not span the space. Also, it fails for large
5443+
numbers of vertices in dimensions 4 or greater
54415444
54425445
INPUT:
54435446
@@ -5511,7 +5514,7 @@ def minkowski_sum(points1, points2):
55115514
55125515
.. NOTE::
55135516
5514-
Polytopes might not be of maximal dimension.
5517+
Polytopes might not be of maximal dimension.
55155518
55165519
INPUT:
55175520

src/sage/geometry/polyhedron/base5.py

+20-7
Original file line numberDiff line numberDiff line change
@@ -1747,7 +1747,8 @@ def _test_dilation(self, tester=None, **options):
17471747
p = self.change_ring(new_ring)
17481748
tester.assertIsInstance(scalar*p, Polyhedron_base)
17491749

1750-
def linear_transformation(self, linear_transf, new_base_ring=None):
1750+
def linear_transformation(self, linear_transf,
1751+
new_base_ring=None):
17511752
"""
17521753
Return the linear transformation of ``self``.
17531754
@@ -1807,6 +1808,12 @@ def linear_transformation(self, linear_transf, new_base_ring=None):
18071808
18081809
TESTS:
18091810
1811+
One can scale by a scalar as follows::
1812+
1813+
sage: P = polytopes.simplex()
1814+
sage: P.linear_transformation(2)
1815+
A 3-dimensional polyhedron in QQ^4 defined as the convex hull of 4 vertices
1816+
18101817
Linear transformation respects backend::
18111818
18121819
sage: P = polytopes.simplex(backend='field')
@@ -1862,6 +1869,11 @@ def linear_transformation(self, linear_transf, new_base_ring=None):
18621869
True
18631870
"""
18641871
is_injective = False
1872+
1873+
if linear_transf in self.base_ring():
1874+
# allow for scalar input
1875+
linear_transf = linear_transf * self.ambient_vector_space().matrix()
1876+
18651877
if linear_transf.nrows() != 0:
18661878
if new_base_ring:
18671879
R = new_base_ring
@@ -1870,17 +1882,18 @@ def linear_transformation(self, linear_transf, new_base_ring=None):
18701882

18711883
# Multiplying a matrix with a vector is slow.
18721884
# So we multiply the entire vertex matrix etc.
1873-
# Still we create generators, as possibly the Vrepresentation will be discarded later on.
1885+
# Still we create generators, as possibly the Vrepresentation
1886+
# will be discarded later on.
18741887
if self.n_vertices():
1875-
new_vertices = ( v for v in ((linear_transf*self.vertices_matrix(R)).transpose()) )
1888+
new_vertices = iter((linear_transf*self.vertices_matrix(R)).transpose())
18761889
else:
18771890
new_vertices = ()
18781891
if self.n_rays():
1879-
new_rays = ( r for r in matrix(R, self.rays())*linear_transf.transpose() )
1892+
new_rays = iter(matrix(R, self.rays())*linear_transf.transpose())
18801893
else:
18811894
new_rays = ()
18821895
if self.n_lines():
1883-
new_lines = ( l for l in matrix(R, self.lines())*linear_transf.transpose() )
1896+
new_lines = iter(matrix(R, self.lines())*linear_transf.transpose())
18841897
else:
18851898
new_lines = ()
18861899

@@ -1906,14 +1919,14 @@ def linear_transformation(self, linear_transf, new_base_ring=None):
19061919
# Note that such N must exist, as our map is injective on the polytope.
19071920
# It is uniquely defined by considering a basis of the homogeneous vertices.
19081921
N = new_homogeneous_basis.solve_left(homogeneous_basis)
1909-
new_inequalities = ( h for h in matrix(R, self.inequalities())*N )
1922+
new_inequalities = iter(matrix(R, self.inequalities())*N)
19101923

19111924
# The equations are the left kernel matrix of the homogeneous vertices
19121925
# or equivalently a basis thereof.
19131926
new_equations = (new_homogeneous_basis.transpose()).right_kernel_matrix()
19141927

19151928
else:
1916-
new_vertices = [[] for v in self.vertex_generator() ]
1929+
new_vertices = [[] for v in self.vertex_generator()]
19171930
new_rays = []
19181931
new_lines = []
19191932

0 commit comments

Comments
 (0)