Jump to content

Convex polytope: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
m Reverted edits by 136.54.47.130 (talk) (HG) (3.4.12)
 
(22 intermediate revisions by 16 users not shown)
Line 1: Line 1:
{{Short description|Convex hull of a finite set of points in a Euclidean space}}
[[File:3dpoly.svg|thumb|right|A 3-dimensional convex polytope]]
[[File:3dpoly.svg|thumb|right|A 3-dimensional convex polytope]]
A '''convex polytope''' is a special case of a [[polytope]], having the additional property that it is also a [[convex set]] contained in the <math>n</math>-dimensional Euclidean space <math>\mathbb{R}^n</math>. Most texts<ref name=grun/><ref name=zieg>{{Citation
A '''convex polytope''' is a special case of a [[polytope]], having the additional property that it is also a [[convex set]] contained in the <math>n</math>-dimensional Euclidean space <math>\mathbb{R}^n</math>. Most texts<ref name=grun/><ref name=zieg>{{Citation
Line 20: Line 21:
*Many examples of bounded convex polytopes can be found in the article "[[polyhedron]]".
*Many examples of bounded convex polytopes can be found in the article "[[polyhedron]]".
*In the 2-dimensional case the full-dimensional examples are a [[half-plane]], a strip between two parallel lines, an [[angle]] shape (the intersection of two non-parallel half-planes), a shape defined by a convex [[polygonal chain]] with two [[ray (geometry)|ray]]s attached to its ends, and a [[convex polygon]].
*In the 2-dimensional case the full-dimensional examples are a [[half-plane]], a strip between two parallel lines, an [[angle]] shape (the intersection of two non-parallel half-planes), a shape defined by a convex [[polygonal chain]] with two [[ray (geometry)|ray]]s attached to its ends, and a [[convex polygon]].
*Special cases of an unbounded convex polytope are a slab between two parallel hyperplanes, a wedge defined by two non-parallel [[Half-space (geometry)|half-space]]s, a [[polyhedral cylinder]] (infinite [[prism (geometry)|prism]]), and a [[polyhedral cone]] (infinite [[cone]]) defined by three or more half-spaces passing through a common point.
*Special cases of an unbounded convex polytope are a [[Slab (geometry)|slab]] between two parallel hyperplanes, a wedge defined by two non-parallel [[Half-space (geometry)|half-space]]s, a [[polyhedral cylinder]] (infinite [[prism (geometry)|prism]]), and a [[polyhedral cone]] (infinite [[cone]]) defined by three or more half-spaces passing through a common point.


==Definitions==
==Definitions==
Line 37: Line 38:
A convex polytope may be defined as an intersection of a finite number of half-spaces. Such definition is called a '''half-space representation''' ('''H-representation''' or '''H-description''').<ref name=grun/> There exist infinitely many H-descriptions of a convex polytope. However, for a full-dimensional convex polytope, the minimal H-description is in fact unique and is given by the set of the [[facet (geometry)|facet]]-defining halfspaces.<ref name=grun/>
A convex polytope may be defined as an intersection of a finite number of half-spaces. Such definition is called a '''half-space representation''' ('''H-representation''' or '''H-description''').<ref name=grun/> There exist infinitely many H-descriptions of a convex polytope. However, for a full-dimensional convex polytope, the minimal H-description is in fact unique and is given by the set of the [[facet (geometry)|facet]]-defining halfspaces.<ref name=grun/>


A [[closed half-space]] can be written as a [[linear inequality]]:<ref name=grun>[[Branko Grünbaum]], ''[[Convex Polytopes]]'', 2nd edition, prepared by [[Volker Kaibel]], [[Victor Klee]], and [[Günter M. Ziegler]], 2003, {{ISBN|0-387-40409-0}}, {{ISBN|978-0-387-40409-7}}, 466pp.</ref>
A [[closed half-space]] can be written as a [[linear inequality]]:<ref name="grun">[[Branko Grünbaum]], ''[[Convex Polytopes]]'', 2nd edition, prepared by [[Volker Kaibel]], [[Victor Klee]], and [[Günter M. Ziegler]], 2003, {{ISBN|0-387-40409-0}}, {{ISBN|978-0-387-40409-7}}, 466pp.</ref>


:<math>a_1 x_1 + a_2 x_2 + \cdots + a_n x_n \leq b</math>
:<math>a_1 x_1 + a_2 x_2 + \cdots + a_n x_n \leq b</math>
Line 66: Line 67:
In general the intersection of arbitrary half-spaces need not be bounded. However if one wishes to have a definition equivalent to that as a convex hull, then bounding must be explicitly required.
In general the intersection of arbitrary half-spaces need not be bounded. However if one wishes to have a definition equivalent to that as a convex hull, then bounding must be explicitly required.


==== Equivalence to the vertex representation ====
By requiring that the intersection of half-spaces results in a bounded set, the definition becomes equivalent to the vertex-representation.<ref>{{Cite book |last=Hug |first=Daniel |title=Lectures on convex geometry |last2=Weil |first2=Wolfgang |date=2020 |publisher=Springer |isbn=978-3-030-50180-8 |series=Graduate texts in mathematics |location=Cham, Switzerland |pages=30-35}}</ref> An outline of the proof, that the bounded intersection of half-spaces results in a polytope in vertex-representation, follows:

The ''bounded'' intersection of [[Closed half-space|closed half-spaces]] of <math>\mathbb{R}^n</math> is clearly compact and convex. A compact and convex set with a finite number of extreme points must be a polytope, where those [[Extreme point|extreme points]] form the set of vertices. It remains to show that the set of extreme points (of the bounded intersection of a finite set of half-spaces) is also finite:

Let <math>x \in \textrm{ext}(P)</math> be an extreme point of <math>P := \bigcap_{i=1}^{k} H_i</math>, the bounded intersection of closed half-spaces <math>H_i</math>. We consider the intersection of all the corresponding hyperplanes (which divide the space into the half-spaces) that contain <math>x</math>. This yields an affine subspace <math>U</math>. For each half-space where the hyperplane does not contain <math>x</math>, we consider the intersection of the ''interior'' of those half-spaces. This yields an open set <math>O</math>. Clearly, <math>x \in (U \cap O) \subseteq P</math>. Since <math>x</math> is an extreme point of <math>P</math> and <math>D := U \cap O</math> is [[Open set|relatively open]], it follows that <math>D</math> must be 0-dimensional and <math>D = \left\{ x \right\}</math>. If <math>D</math> was not 0-dimensional, <math>x</math> would be the inner point of (at least) a line, which contradicts <math>x</math> being an extreme point. Since every construction of <math>D</math> chooses either the interior or the boundary of one of the <math>k</math> closed half-spaces, there are only finitely many different sets <math>D</math>. Every extreme point lies in one of these sets, which means that the amount of extreme points is finite.
=== Using the different representations ===
=== Using the different representations ===
The two representations together provide an efficient way to decide whether a given vector is included in a given convex polytope: to show that it is in the polytope, it is sufficient to present it is a convex combination of the polytope vertices (the V-description is used); to show that it is not in the polytope, it is sufficient to present a single defining inequality that it violates.<ref name="lp">{{Cite Lovasz Plummer}}</ref>{{Rp|256}}
The two representations together provide an efficient way to decide whether a given vector is included in a given convex polytope: to show that it is in the polytope, it is sufficient to present it as a convex combination of the polytope vertices (the V-description is used); to show that it is not in the polytope, it is sufficient to present a single defining inequality that it violates.<ref name="lp">{{Cite Lovasz Plummer}}</ref>{{Rp|256}}


A subtle point in the representation by vectors is that the number of vectors may be exponential in the dimension, so the proof that a vector is in the polytope might be exponentially long. Fortunately, [[Carathéodory's theorem (convex hull)|Carathéodory's theorem]] guarantees that every vector in the polytope can be represented by at most ''d''+1 defining vectors, where ''d'' is the dimension of the space.
A subtle point in the representation by vectors is that the number of vectors may be exponential in the dimension, so the proof that a vector is in the polytope might be exponentially long. Fortunately, [[Carathéodory's theorem (convex hull)|Carathéodory's theorem]] guarantees that every vector in the polytope can be represented by at most ''d''+1 defining vectors, where ''d'' is the dimension of the space.
Line 73: Line 80:
===Representation of unbounded polytopes===
===Representation of unbounded polytopes===


For an unbounded polytope (sometimes called: polyhedron), the H-desciption is still valid, but the V-description should be extended. [[Theodore Motzkin]] (1936) proved that any unbounded polytope can be represented as a sum of a ''bounded polytope'' and a [[Convex cone|''convex polyhedral cone'']].<ref>{{Cite book|last=Motzkin|first=Theodore|title=Beitrage zur Theorie der linearen Ungleichungen (Ph.D. dissertation)|publisher=|year=1936|isbn=|location=Jerusalem|pages=}}</ref> In other words, every vector in an unbounded polytope is a [[convex sum]] of its vertices (its "defining points"), plus a [[conical sum]] of the [[Euclidean vector]]s of its infinite edges (its "defining rays"). This is called the '''finite basis theorem'''.<ref name="Jeter" />
For an unbounded polytope (sometimes called: polyhedron), the H-description is still valid, but the V-description should be extended. [[Theodore Motzkin]] (1936) proved that any unbounded polytope can be represented as a sum of a ''bounded polytope'' and a [[Convex cone|''convex polyhedral cone'']].<ref>{{Cite book|last=Motzkin|first=Theodore|title=Beitrage zur Theorie der linearen Ungleichungen (Ph.D. dissertation)|year=1936|location=Jerusalem}}</ref> In other words, every vector in an unbounded polytope is a [[convex sum]] of its vertices (its "defining points"), plus a [[conical sum]] of the [[Euclidean vector]]s of its infinite edges (its "defining rays"). This is called the '''finite basis theorem'''.<ref name="Jeter" />


==Properties==
==Properties==
Line 84: Line 91:
If a polytope is ''d''-dimensional, its [[Facet (mathematics)|facets]] are its (''d''&nbsp;&minus;&nbsp;1)-dimensional faces, its [[vertex (geometry)|vertices]] are its 0-dimensional faces, its [[edge (geometry)|edges]] are its 1-dimensional faces, and its [[ridge (geometry)|ridges]] are its (''d''&nbsp;&minus;&nbsp;2)-dimensional faces.
If a polytope is ''d''-dimensional, its [[Facet (mathematics)|facets]] are its (''d''&nbsp;&minus;&nbsp;1)-dimensional faces, its [[vertex (geometry)|vertices]] are its 0-dimensional faces, its [[edge (geometry)|edges]] are its 1-dimensional faces, and its [[ridge (geometry)|ridges]] are its (''d''&nbsp;&minus;&nbsp;2)-dimensional faces.


Given a convex polytope ''P'' defined by the matrix inequality <math>Ax \leq b</math>, if each row in ''A'' corresponds with a bounding hyperplane and is [[linearly independent]] of the other rows, then each facet of ''P'' corresponds with exactly one row of ''A'', and vice versa. Each point on a given facet will satisfy the linear equality of the corresponding row in the matrix. (It may or may not also satisfy equality in other rows). Similarly, each point on a ridge will satisfy equality in two of the rows of ''A''.
Given a convex polytope ''P'' defined by the matrix inequality <math>Ax \leq b</math>, if each row in ''A'' corresponds with a bounding hyperplane and is [[linearly independent]] of the other rows, then each facet of ''P'' corresponds with exactly one row of ''A'', and vice versa, as long as equality holds. Each point on a given facet will satisfy the linear equality of the corresponding row in the matrix. (It may or may not also satisfy equality in other rows). Similarly, each point on a ridge will satisfy equality in two of the rows of ''A''.


[[File:Pyramid face lattice.svg|thumb|360px|The face lattice of a [[square pyramid]], drawn as a [[Hasse diagram]]; each face in the lattice is labeled by its vertex set.]]
[[File:Pyramid face lattice.svg|thumb|360px|The face lattice of a [[square pyramid]], drawn as a [[Hasse diagram]]; each face in the lattice is labeled by its vertex set.]]
Line 93: Line 100:
Two polytopes are called '''combinatorially isomorphic''' if their face lattices are [[isomorphism|isomorphic]].
Two polytopes are called '''combinatorially isomorphic''' if their face lattices are [[isomorphism|isomorphic]].


The '''polytope graph''' ('''polytopal graph''', '''graph of the polytope''', '''1-skeleton''') is the set of vertices and edges of the polytope only, ignoring higher-dimensional faces. For instance, a [[polyhedral graph]] is the polytope graph of a three-dimensional polytope. By a result of [[Hassler Whitney|Whitney]]<ref>{{cite journal |authorlink=Hassler Whitney |first=Hassler |last=Whitney |title=Congruent graphs and the connectivity of graphs |journal=Amer. J. Math. |volume=54 |issue=1 |pages=150–168 |year=1932 |jstor=2371086 |doi=10.2307/2371086|hdl=10338.dmlcz/101067 |hdl-access=free }}</ref> the face lattice of a three-dimensional polytope is determined by its graph. The same is true for [[simple polytope]]s of arbitrary dimension (Blind & Mani-Levitska 1987, proving a conjecture of [[Micha Perles]]).<ref>{{citation
The '''polytope graph''' ('''polytopal graph''', '''graph of the polytope''', '''1-skeleton''') is the set of vertices and edges of the polytope only, ignoring higher-dimensional faces. For instance, a [[polyhedral graph]] is the polytope graph of a three-dimensional polytope. By a result of [[Hassler Whitney|Whitney]]<ref>{{cite journal |author-link=Hassler Whitney |first=Hassler |last=Whitney |title=Congruent graphs and the connectivity of graphs |journal=Amer. J. Math. |volume=54 |issue=1 |pages=150–168 |year=1932 |jstor=2371086 |doi=10.2307/2371086|hdl=10338.dmlcz/101067 |hdl-access=free }}</ref> the face lattice of a three-dimensional polytope is determined by its graph. The same is true for [[simple polytope]]s of arbitrary dimension (Blind & Mani-Levitska 1987, proving a conjecture of [[Micha Perles]]).<ref>{{citation
| last1 = Blind | first1 = Roswitha
| last1 = Blind | first1 = Roswitha | author1-link = Roswitha Blind
| last2 = Mani-Levitska | first2 = Peter
| last2 = Mani-Levitska | first2 = Peter
| doi = 10.1007/BF01830678
| doi = 10.1007/BF01830678
Line 103: Line 110:
| title = Puzzles and polytope isomorphisms
| title = Puzzles and polytope isomorphisms
| volume = 34
| volume = 34
| year = 1987}}.</ref> Kalai (1988)<ref>{{citation
| year = 1987| s2cid = 120222616 }}.</ref> Kalai (1988)<ref>{{citation
| last = Kalai | first = Gil | authorlink = Gil Kalai
| last = Kalai | first = Gil | author-link = Gil Kalai
| doi = 10.1016/0097-3165(88)90064-7
| doi = 10.1016/0097-3165(88)90064-7
| issue = 2
| issue = 2
Line 113: Line 120:
| volume = 49
| volume = 49
| year = 1988| doi-access = free
| year = 1988| doi-access = free
}}.</ref> gives a simple proof based on [[unique sink orientation]]s. Because these polytopes' face lattices are determined by their graphs, the problem of deciding whether two three-dimensional or simple convex polytopes are combinatorially isomorphic can be formulated equivalently as a special case of the [[graph isomorphism problem]]. However, it is also possible to translate these problems in the opposite direction, showing that polytope isomorphism testing is graph-isomorphism complete.<ref>{{cite journal |first=Volker |last=Kaibel |first2=Alexander |last2=Schwartz |url=http://eprintweb.org/S/authors/All/ka/Kaibel/16 |title=On the Complexity of Polytope Isomorphism Problems |journal=[[Graphs and Combinatorics]] |volume=19 |issue=2 |pages=215–230 |year=2003 |arxiv=math/0106093 |doi=10.1007/s00373-002-0503-y |url-status=dead |archiveurl=https://web.archive.org/web/20150721175904/http://eprintweb.org/S/authors/All/ka/Kaibel/16 |archivedate=2015-07-21 }}</ref>
}}.</ref> gives a simple proof based on [[unique sink orientation]]s. Because these polytopes' face lattices are determined by their graphs, the problem of deciding whether two three-dimensional or simple convex polytopes are combinatorially isomorphic can be formulated equivalently as a special case of the [[graph isomorphism problem]]. However, it is also possible to translate these problems in the opposite direction, showing that polytope isomorphism testing is graph-isomorphism complete.<ref>{{cite journal |first1=Volker |last1=Kaibel |first2=Alexander |last2=Schwartz |url=http://eprintweb.org/S/authors/All/ka/Kaibel/16 |title=On the Complexity of Polytope Isomorphism Problems |journal=[[Graphs and Combinatorics]] |volume=19 |issue=2 |pages=215–230 |year=2003 |arxiv=math/0106093 |doi=10.1007/s00373-002-0503-y |s2cid=179936 |url-status=dead |archive-url=https://web.archive.org/web/20150721175904/http://eprintweb.org/S/authors/All/ka/Kaibel/16 |archive-date=2015-07-21 }}</ref>


=== Topological properties ===
=== Topological properties ===
Line 123: Line 130:
A convex polytope can be decomposed into a [[simplicial complex]], or union of [[simplex|simplices]], satisfying certain properties.
A convex polytope can be decomposed into a [[simplicial complex]], or union of [[simplex|simplices]], satisfying certain properties.


Given a convex ''r''-dimensional polytope ''P'', <!--(but not in any (r-1)-plane, say)--> a subset of its vertices containing (''r''+1) [[affinely independent]] points defines an [[simplex|''r''-simplex]]. It is possible to form a collection of subsets such that the union of the corresponding simplices is equal to ''P'', and the intersection of any two simplices is either empty or a lower-dimensional simplex. This simplicial decomposition is the basis of many methods for computing the volume of a convex polytope, since the volume of a simplex is easily given by a formula.<ref>{{Cite book | last1 = Büeler | first1 = B. | last2 = Enge | first2 = A. | last3 = Fukuda | first3 = K. | doi = 10.1007/978-3-0348-8438-9_6 | chapter = Exact Volume Computation for Polytopes: A Practical Study | title = Polytopes — Combinatorics and Computation | pages = 131 | year = 2000 | isbn = 978-3-7643-6351-2 | pmid = | pmc = }}</ref>
Given a convex ''r''-dimensional polytope ''P'', <!--(but not in any (r-1)-plane, say)--> a subset of its vertices containing (''r''+1) [[affinely independent]] points defines an [[simplex|''r''-simplex]]. It is possible to form a collection of subsets such that the union of the corresponding simplices is equal to ''P'', and the intersection of any two simplices is either empty or a lower-dimensional simplex. This simplicial decomposition is the basis of many methods for computing the volume of a convex polytope, since the volume of a simplex is easily given by a formula.<ref>{{Cite book | last1 = Büeler | first1 = B. | last2 = Enge | first2 = A. | last3 = Fukuda | first3 = K. |author3-link=Komei Fukuda| doi = 10.1007/978-3-0348-8438-9_6 | chapter = Exact Volume Computation for Polytopes: A Practical Study | title = Polytopes — Combinatorics and Computation | pages = 131–154 | year = 2000 | isbn = 978-3-7643-6351-2 | chapter-url = https://hal.inria.fr/hal-03029034 }}</ref>

===Scissors-congruency===
Every convex polyhedron is [[scissors-congruent]] to an orthoscheme. Every regular convex polyhedron ([[Platonic solid]]) can be dissected into some even number of instances of its [[characteristic orthoscheme]].


==Algorithmic problems for a convex polytope==
==Algorithmic problems for a convex polytope==
Line 131: Line 141:
Different representations of a convex polytope have different utility, therefore the construction of one representation given another one is an important problem. The problem of the construction of a V-representation is known as the [[vertex enumeration problem]] and the problem of the construction of a H-representation is known as the '''facet enumeration problem'''. While the vertex set of a bounded convex polytope uniquely defines it, in various applications it is important to know more about the combinatorial structure of the polytope, i.e., about its face lattice. Various [[convex hull algorithms]] deal both with the facet enumeration and face lattice construction.
Different representations of a convex polytope have different utility, therefore the construction of one representation given another one is an important problem. The problem of the construction of a V-representation is known as the [[vertex enumeration problem]] and the problem of the construction of a H-representation is known as the '''facet enumeration problem'''. While the vertex set of a bounded convex polytope uniquely defines it, in various applications it is important to know more about the combinatorial structure of the polytope, i.e., about its face lattice. Various [[convex hull algorithms]] deal both with the facet enumeration and face lattice construction.


In the planar case, i.e., for a [[convex polygon]], both facet and vertex enumeration problems amount to the ordering vertices (resp. edges) around the convex hull. It is a trivial task when the convex polygon is specified in a traditional for [[polygon]]s way, i.e., by the ordered sequence of its vertices <math>v_1,\dots, v_m</math>. When the input list of vertices (or edges) is unordered, the [[time complexity]] of the problems becomes [[Big Oh notation|O]](''m''&nbsp;log&nbsp;''m'').<ref>{{Introduction to Algorithms|edition=2|chapter=33.3 Finding the convex hull|pages=947–957}}</ref> A matching [[lower bound]] is known in the [[algebraic decision tree]] model of computation.<ref>{{citation
In the planar case, i.e., for a [[convex polygon]], both facet and vertex enumeration problems amount to the ordering vertices (resp. edges) around the convex hull. It is a trivial task when the convex polygon is specified in a traditional way for [[polygon]]s, i.e., by the ordered sequence of its vertices <math>v_1,\dots, v_m</math>. When the input list of vertices (or edges) is unordered, the [[time complexity]] of the problems becomes [[Big Oh notation|O]](''m''&nbsp;log&nbsp;''m'').<ref>{{Introduction to Algorithms|edition=2|chapter=33.3 Finding the convex hull|pages=947–957}}</ref> A matching [[lower bound]] is known in the [[algebraic decision tree]] model of computation.<ref>{{citation
| last = Yao | first = Andrew Chi Chih | authorlink = Andrew Yao
| last = Yao | first = Andrew Chi Chih | author-link = Andrew Yao
| doi = 10.1145/322276.322289
| doi = 10.1145/322276.322289
| issue = 4
| issue = 4
Line 140: Line 150:
| title = A lower bound to finding convex hulls
| title = A lower bound to finding convex hulls
| volume = 28
| volume = 28
| year = 1981}}; {{citation
| year = 1981| s2cid = 13846330 | doi-access = free
}}; {{citation
| last = Ben-Or | first = Michael
| last = Ben-Or | first = Michael
| contribution = Lower Bounds for Algebraic Computation Trees
| contribution = Lower Bounds for Algebraic Computation Trees
Line 146: Line 157:
| pages = 80–86
| pages = 80–86
| title = Proceedings of the Fifteenth Annual ACM Symposium on Theory of Computing (STOC '83)
| title = Proceedings of the Fifteenth Annual ACM Symposium on Theory of Computing (STOC '83)
| year = 1983}}.</ref>
| year = 1983| doi-access = free
}}.</ref>


=== Volume computation ===
=== Volume computation ===


The task of computing the [[volume]] of a convex polytope has been studied in the field of [[computational geometry]]. The volume can be computed [[approximation algorithm|approximately]], for instance, using the [[convex volume approximation]] technique, when having access to a membership [[oracle machine|oracle]]. As for [[exact algorithm|exact computation]], one obstacle is that, when given a representation of the convex polytope as an [[equation system]] of [[linear inequality|linear inequalities]], the volume of the polytope may have a [[bit-length]] which is not polynomial in this representation.<ref>{{Cite journal|last=Lawrence|first=Jim|date=1991|title=Polytope volume computation|url=https://www.ams.org/mcom/1991-57-195/S0025-5718-1991-1079024-2/|journal=Mathematics of Computation|language=en|volume=57|issue=195|pages=259–271|doi=10.1090/S0025-5718-1991-1079024-2|issn=0025-5718}}</ref>
The task of computing the [[volume]] of a convex polytope has been studied in the field of [[computational geometry]]. The volume can be computed [[approximation algorithm|approximately]], for instance, using the [[convex volume approximation]] technique, when having access to a membership [[oracle machine|oracle]]. As for [[exact algorithm|exact computation]], one obstacle is that, when given a representation of the convex polytope as an [[equation system]] of [[linear inequality|linear inequalities]], the volume of the polytope may have a [[bit-length]] which is not polynomial in this representation.<ref>{{Cite journal|last=Lawrence|first=Jim|date=1991|title=Polytope volume computation|url=https://www.ams.org/mcom/1991-57-195/S0025-5718-1991-1079024-2/|journal=Mathematics of Computation|language=en|volume=57|issue=195|pages=259–271|doi=10.1090/S0025-5718-1991-1079024-2|bibcode=1991MaCom..57..259L |issn=0025-5718|doi-access=free}}</ref>


==See also==
==See also==
Line 162: Line 174:
==External links==
==External links==
{{Commonscat|Convex polytopes}}
{{Commonscat|Convex polytopes}}
*{{mathworld | urlname = ConvexPolygon | title = Convex polygon}}
*{{mathworld | urlname = ConvexPolygon | title = Convex polygon|ref=none}}
*{{mathworld | urlname = ConvexPolyhedron | title = Convex polyhedron}}
*{{mathworld | urlname = ConvexPolyhedron | title = Convex polyhedron|ref=none}}
*[[Komei Fukuda]], [https://www.cs.mcgill.ca/~fukuda/soft/polyfaq/polyfaq.html Polyhedral computation FAQ].
*[[Komei Fukuda]], [https://www.cs.mcgill.ca/~fukuda/soft/polyfaq/polyfaq.html Polyhedral computation FAQ].



Latest revision as of 21:14, 30 November 2024

A 3-dimensional convex polytope

A convex polytope is a special case of a polytope, having the additional property that it is also a convex set contained in the -dimensional Euclidean space . Most texts[1][2] use the term "polytope" for a bounded convex polytope, and the word "polyhedron" for the more general, possibly unbounded object. Others[3] (including this article) allow polytopes to be unbounded. The terms "bounded/unbounded convex polytope" will be used below whenever the boundedness is critical to the discussed issue. Yet other texts identify a convex polytope with its boundary.

Convex polytopes play an important role both in various branches of mathematics and in applied areas, most notably in linear programming.

In the influential textbooks of Grünbaum[1] and Ziegler[2] on the subject, as well as in many other texts in discrete geometry, convex polytopes are often simply called "polytopes". Grünbaum points out that this is solely to avoid the endless repetition of the word "convex", and that the discussion should throughout be understood as applying only to the convex variety (p. 51).

A polytope is called full-dimensional if it is an -dimensional object in .

Examples

[edit]
  • Many examples of bounded convex polytopes can be found in the article "polyhedron".
  • In the 2-dimensional case the full-dimensional examples are a half-plane, a strip between two parallel lines, an angle shape (the intersection of two non-parallel half-planes), a shape defined by a convex polygonal chain with two rays attached to its ends, and a convex polygon.
  • Special cases of an unbounded convex polytope are a slab between two parallel hyperplanes, a wedge defined by two non-parallel half-spaces, a polyhedral cylinder (infinite prism), and a polyhedral cone (infinite cone) defined by three or more half-spaces passing through a common point.

Definitions

[edit]

A convex polytope may be defined in a number of ways, depending on what is more suitable for the problem at hand. Grünbaum's definition is in terms of a convex set of points in space. Other important definitions are: as the intersection of half-spaces (half-space representation) and as the convex hull of a set of points (vertex representation).

Vertex representation (convex hull)

[edit]

In his book Convex Polytopes, Grünbaum defines a convex polytope as a compact convex set with a finite number of extreme points:

A set of is convex if, for each pair of distinct points , in , the closed segment with endpoints and is contained within .

This is equivalent to defining a bounded convex polytope as the convex hull of a finite set of points, where the finite set must contain the set of extreme points of the polytope. Such a definition is called a vertex representation (V-representation or V-description).[1] For a compact convex polytope, the minimal V-description is unique and it is given by the set of the vertices of the polytope.[1] A convex polytope is called an integral polytope if all of its vertices have integer coordinates.

Intersection of half-spaces

[edit]

A convex polytope may be defined as an intersection of a finite number of half-spaces. Such definition is called a half-space representation (H-representation or H-description).[1] There exist infinitely many H-descriptions of a convex polytope. However, for a full-dimensional convex polytope, the minimal H-description is in fact unique and is given by the set of the facet-defining halfspaces.[1]

A closed half-space can be written as a linear inequality:[1]

where is the dimension of the space containing the polytope under consideration. Hence, a closed convex polytope may be regarded as the set of solutions to the system of linear inequalities:

where is the number of half-spaces defining the polytope. This can be concisely written as the matrix inequality:

where is an matrix, is an column vector whose coordinates are the variables to , and is an column vector whose coordinates are the right-hand sides to of the scalar inequalities.

An open convex polytope is defined in the same way, with strict inequalities used in the formulas instead of the non-strict ones.

The coefficients of each row of and correspond with the coefficients of the linear inequality defining the respective half-space. Hence, each row in the matrix corresponds with a supporting hyperplane of the polytope, a hyperplane bounding a half-space that contains the polytope. If a supporting hyperplane also intersects the polytope, it is called a bounding hyperplane (since it is a supporting hyperplane, it can only intersect the polytope at the polytope's boundary).

The foregoing definition assumes that the polytope is full-dimensional. In this case, there is a unique minimal set of defining inequalities (up to multiplication by a positive number). Inequalities belonging to this unique minimal system are called essential. The set of points of a polytope which satisfy an essential inequality with equality is called a facet.

If the polytope is not full-dimensional, then the solutions of lie in a proper affine subspace of and the polytope can be studied as an object in this subspace. In this case, there exist linear equations which are satisfied by all points of the polytope. Adding one of these equations to any of the defining inequalities does not change the polytope. Therefore, in general there is no unique minimal set of inequalities defining the polytope.

In general the intersection of arbitrary half-spaces need not be bounded. However if one wishes to have a definition equivalent to that as a convex hull, then bounding must be explicitly required.

Equivalence to the vertex representation

[edit]

By requiring that the intersection of half-spaces results in a bounded set, the definition becomes equivalent to the vertex-representation.[4] An outline of the proof, that the bounded intersection of half-spaces results in a polytope in vertex-representation, follows:

The bounded intersection of closed half-spaces of is clearly compact and convex. A compact and convex set with a finite number of extreme points must be a polytope, where those extreme points form the set of vertices. It remains to show that the set of extreme points (of the bounded intersection of a finite set of half-spaces) is also finite:

Let be an extreme point of , the bounded intersection of closed half-spaces . We consider the intersection of all the corresponding hyperplanes (which divide the space into the half-spaces) that contain . This yields an affine subspace . For each half-space where the hyperplane does not contain , we consider the intersection of the interior of those half-spaces. This yields an open set . Clearly, . Since is an extreme point of and is relatively open, it follows that must be 0-dimensional and . If was not 0-dimensional, would be the inner point of (at least) a line, which contradicts being an extreme point. Since every construction of chooses either the interior or the boundary of one of the closed half-spaces, there are only finitely many different sets . Every extreme point lies in one of these sets, which means that the amount of extreme points is finite.

Using the different representations

[edit]

The two representations together provide an efficient way to decide whether a given vector is included in a given convex polytope: to show that it is in the polytope, it is sufficient to present it as a convex combination of the polytope vertices (the V-description is used); to show that it is not in the polytope, it is sufficient to present a single defining inequality that it violates.[5]: 256 

A subtle point in the representation by vectors is that the number of vectors may be exponential in the dimension, so the proof that a vector is in the polytope might be exponentially long. Fortunately, Carathéodory's theorem guarantees that every vector in the polytope can be represented by at most d+1 defining vectors, where d is the dimension of the space.

Representation of unbounded polytopes

[edit]

For an unbounded polytope (sometimes called: polyhedron), the H-description is still valid, but the V-description should be extended. Theodore Motzkin (1936) proved that any unbounded polytope can be represented as a sum of a bounded polytope and a convex polyhedral cone.[6] In other words, every vector in an unbounded polytope is a convex sum of its vertices (its "defining points"), plus a conical sum of the Euclidean vectors of its infinite edges (its "defining rays"). This is called the finite basis theorem.[3]

Properties

[edit]

Every (bounded) convex polytope is the image of a simplex, as every point is a convex combination of the (finitely many) vertices. However, polytopes are not in general isomorphic to simplices. This is in contrast to the case of vector spaces and linear combinations, every finite-dimensional vector space being not only an image of, but in fact isomorphic to, Euclidean space of some dimension (or analog over other fields).

The face lattice

[edit]

A face of a convex polytope is any intersection of the polytope with a halfspace such that none of the interior points of the polytope lie on the boundary of the halfspace. Equivalently, a face is the set of points giving equality in some valid inequality of the polytope.[5]: 258 

If a polytope is d-dimensional, its facets are its (d − 1)-dimensional faces, its vertices are its 0-dimensional faces, its edges are its 1-dimensional faces, and its ridges are its (d − 2)-dimensional faces.

Given a convex polytope P defined by the matrix inequality , if each row in A corresponds with a bounding hyperplane and is linearly independent of the other rows, then each facet of P corresponds with exactly one row of A, and vice versa, as long as equality holds. Each point on a given facet will satisfy the linear equality of the corresponding row in the matrix. (It may or may not also satisfy equality in other rows). Similarly, each point on a ridge will satisfy equality in two of the rows of A.

The face lattice of a square pyramid, drawn as a Hasse diagram; each face in the lattice is labeled by its vertex set.

In general, an (n − j)-dimensional face satisfies equality in j specific rows of A. These rows form a basis of the face. Geometrically speaking, this means that the face is the set of points on the polytope that lie in the intersection of j of the polytope's bounding hyperplanes.

The faces of a convex polytope thus form an Eulerian lattice called its face lattice, where the partial ordering is by set containment of faces. The definition of a face given above allows both the polytope itself and the empty set to be considered as faces, ensuring that every pair of faces has a join and a meet in the face lattice. The whole polytope is the unique maximum element of the lattice, and the empty set, considered to be a (−1)-dimensional face (a null polytope) of every polytope, is the unique minimum element of the lattice.

Two polytopes are called combinatorially isomorphic if their face lattices are isomorphic.

The polytope graph (polytopal graph, graph of the polytope, 1-skeleton) is the set of vertices and edges of the polytope only, ignoring higher-dimensional faces. For instance, a polyhedral graph is the polytope graph of a three-dimensional polytope. By a result of Whitney[7] the face lattice of a three-dimensional polytope is determined by its graph. The same is true for simple polytopes of arbitrary dimension (Blind & Mani-Levitska 1987, proving a conjecture of Micha Perles).[8] Kalai (1988)[9] gives a simple proof based on unique sink orientations. Because these polytopes' face lattices are determined by their graphs, the problem of deciding whether two three-dimensional or simple convex polytopes are combinatorially isomorphic can be formulated equivalently as a special case of the graph isomorphism problem. However, it is also possible to translate these problems in the opposite direction, showing that polytope isomorphism testing is graph-isomorphism complete.[10]

Topological properties

[edit]

A convex polytope, like any compact convex subset of Rn, is homeomorphic to a closed ball.[11] Let m denote the dimension of the polytope. If the polytope is full-dimensional, then m = n. The convex polytope therefore is an m-dimensional manifold with boundary, its Euler characteristic is 1, and its fundamental group is trivial. The boundary of the convex polytope is homeomorphic to an (m − 1)-sphere. The boundary's Euler characteristic is 0 for even m and 2 for odd m. The boundary may also be regarded as a tessellation of (m − 1)-dimensional spherical space — i.e. as a spherical tiling.

Simplicial decomposition

[edit]

A convex polytope can be decomposed into a simplicial complex, or union of simplices, satisfying certain properties.

Given a convex r-dimensional polytope P, a subset of its vertices containing (r+1) affinely independent points defines an r-simplex. It is possible to form a collection of subsets such that the union of the corresponding simplices is equal to P, and the intersection of any two simplices is either empty or a lower-dimensional simplex. This simplicial decomposition is the basis of many methods for computing the volume of a convex polytope, since the volume of a simplex is easily given by a formula.[12]

Scissors-congruency

[edit]

Every convex polyhedron is scissors-congruent to an orthoscheme. Every regular convex polyhedron (Platonic solid) can be dissected into some even number of instances of its characteristic orthoscheme.

Algorithmic problems for a convex polytope

[edit]

Construction of representations

[edit]

Different representations of a convex polytope have different utility, therefore the construction of one representation given another one is an important problem. The problem of the construction of a V-representation is known as the vertex enumeration problem and the problem of the construction of a H-representation is known as the facet enumeration problem. While the vertex set of a bounded convex polytope uniquely defines it, in various applications it is important to know more about the combinatorial structure of the polytope, i.e., about its face lattice. Various convex hull algorithms deal both with the facet enumeration and face lattice construction.

In the planar case, i.e., for a convex polygon, both facet and vertex enumeration problems amount to the ordering vertices (resp. edges) around the convex hull. It is a trivial task when the convex polygon is specified in a traditional way for polygons, i.e., by the ordered sequence of its vertices . When the input list of vertices (or edges) is unordered, the time complexity of the problems becomes O(m log m).[13] A matching lower bound is known in the algebraic decision tree model of computation.[14]

Volume computation

[edit]

The task of computing the volume of a convex polytope has been studied in the field of computational geometry. The volume can be computed approximately, for instance, using the convex volume approximation technique, when having access to a membership oracle. As for exact computation, one obstacle is that, when given a representation of the convex polytope as an equation system of linear inequalities, the volume of the polytope may have a bit-length which is not polynomial in this representation.[15]

See also

[edit]

References

[edit]
  1. ^ a b c d e f g Branko Grünbaum, Convex Polytopes, 2nd edition, prepared by Volker Kaibel, Victor Klee, and Günter M. Ziegler, 2003, ISBN 0-387-40409-0, ISBN 978-0-387-40409-7, 466pp.
  2. ^ a b Ziegler, Günter M. (1995), Lectures on Polytopes, Graduate Texts in Mathematics, vol. 152, Berlin, New York: Springer-Verlag.
  3. ^ a b Mathematical Programming, by Melvyn W. Jeter (1986) ISBN 0-8247-7478-7, p. 68
  4. ^ Hug, Daniel; Weil, Wolfgang (2020). Lectures on convex geometry. Graduate texts in mathematics. Cham, Switzerland: Springer. pp. 30–35. ISBN 978-3-030-50180-8.
  5. ^ a b Lovász, László; Plummer, M. D. (1986), Matching Theory, Annals of Discrete Mathematics, vol. 29, North-Holland, ISBN 0-444-87916-1, MR 0859549
  6. ^ Motzkin, Theodore (1936). Beitrage zur Theorie der linearen Ungleichungen (Ph.D. dissertation). Jerusalem.{{cite book}}: CS1 maint: location missing publisher (link)
  7. ^ Whitney, Hassler (1932). "Congruent graphs and the connectivity of graphs". Amer. J. Math. 54 (1): 150–168. doi:10.2307/2371086. hdl:10338.dmlcz/101067. JSTOR 2371086.
  8. ^ Blind, Roswitha; Mani-Levitska, Peter (1987), "Puzzles and polytope isomorphisms", Aequationes Mathematicae, 34 (2–3): 287–297, doi:10.1007/BF01830678, MR 0921106, S2CID 120222616.
  9. ^ Kalai, Gil (1988), "A simple way to tell a simple polytope from its graph", Journal of Combinatorial Theory, Ser. A, 49 (2): 381–383, doi:10.1016/0097-3165(88)90064-7, MR 0964396.
  10. ^ Kaibel, Volker; Schwartz, Alexander (2003). "On the Complexity of Polytope Isomorphism Problems". Graphs and Combinatorics. 19 (2): 215–230. arXiv:math/0106093. doi:10.1007/s00373-002-0503-y. S2CID 179936. Archived from the original on 2015-07-21.
  11. ^ Glen E. Bredon, Topology and Geometry, 1993, ISBN 0-387-97926-3, p. 56.
  12. ^ Büeler, B.; Enge, A.; Fukuda, K. (2000). "Exact Volume Computation for Polytopes: A Practical Study". Polytopes — Combinatorics and Computation. pp. 131–154. doi:10.1007/978-3-0348-8438-9_6. ISBN 978-3-7643-6351-2.
  13. ^ Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Ronald L.; Stein, Clifford (2001) [1990]. "33.3 Finding the convex hull". Introduction to Algorithms (2nd ed.). MIT Press and McGraw-Hill. pp. 947–957. ISBN 0-262-03293-7.
  14. ^ Yao, Andrew Chi Chih (1981), "A lower bound to finding convex hulls", Journal of the ACM, 28 (4): 780–787, doi:10.1145/322276.322289, MR 0677089, S2CID 13846330; Ben-Or, Michael (1983), "Lower Bounds for Algebraic Computation Trees", Proceedings of the Fifteenth Annual ACM Symposium on Theory of Computing (STOC '83), pp. 80–86, doi:10.1145/800061.808735.
  15. ^ Lawrence, Jim (1991). "Polytope volume computation". Mathematics of Computation. 57 (195): 259–271. Bibcode:1991MaCom..57..259L. doi:10.1090/S0025-5718-1991-1079024-2. ISSN 0025-5718.
[edit]