Simplicial homology
Template:Short description In algebraic topology, simplicial homology is the sequence of homology groups of a simplicial complex. It formalizes the idea of the number of holes of a given dimension in the complex. This generalizes the number of connected components (the case of dimension 0).
Simplicial homology arose as a way to study topological spaces whose building blocks are n-simplices, the n-dimensional analogs of triangles. This includes a point (0-simplex), a line segment (1-simplex), a triangle (2-simplex) and a tetrahedron (3-simplex). By definition, such a space is homeomorphic to a simplicial complex (more precisely, the geometric realization of an abstract simplicial complex). Such a homeomorphism is referred to as a triangulation of the given space. Many topological spaces of interest can be triangulated, including every smooth manifold (Cairns and Whitehead).<ref>Template:Citation</ref>Template:Rp
Simplicial homology is defined by a simple recipe for any abstract simplicial complex. It is a remarkable fact that simplicial homology only depends on the associated topological space.<ref>Template:Citation</ref>Template:Rp As a result, it gives a computable way to distinguish one space from another.
DefinitionsEdit
OrientationsEdit
A key concept in defining simplicial homology is the notion of an orientation of a simplex. By definition, an orientation of a Template:Math-simplex is given by an ordering of the vertices, written as (Template:Math), with the rule that two orderings define the same orientation if and only if they differ by an even permutation. Thus every simplex has exactly two orientations, and switching the order of two vertices changes an orientation to the opposite orientation. For example, choosing an orientation of a 1-simplex amounts to choosing one of the two possible directions, and choosing an orientation of a 2-simplex amounts to choosing what "counterclockwise" should mean.
ChainsEdit
Let Template:Math be a simplicial complex. A [[Chain (algebraic topology)|simplicial Template:Math-chain]] is a finite formal sum
- <math>\sum_{i=1}^N c_i \sigma_i, \,</math>
where each Template:Math is an integer and Template:Math is an oriented Template:Math-simplex. In this definition, we declare that each oriented simplex is equal to the negative of the simplex with the opposite orientation. For example,
- <math> (v_0,v_1) = -(v_1,v_0).</math>
The group of Template:Math-chains on Template:Math is written Template:Math. This is a free abelian group which has a basis in one-to-one correspondence with the set of Template:Math-simplices in Template:Math. To define a basis explicitly, one has to choose an orientation of each simplex. One standard way to do this is to choose an ordering of all the vertices and give each simplex the orientation corresponding to the induced ordering of its vertices.
Boundaries and cyclesEdit
Let Template:Math be an oriented Template:Math-simplex, viewed as a basis element of Template:Math. The boundary operator
- <math>\partial_k: C_k \rightarrow C_{k-1}</math>
is the homomorphism defined by:
- <math>\partial_k(\sigma)=\sum_{i=0}^k (-1)^i (v_0 , \dots , \widehat{v_i} , \dots ,v_k),</math>
where the oriented simplex
- <math>(v_0 , \dots , \widehat{v_i} , \dots ,v_k)</math>
is the Template:Mathth face of Template:Math, obtained by deleting its Template:Mathth vertex.
In Template:Math, elements of the subgroup
- <math>Z_k := \ker \partial_k</math>
are referred to as cycles, and the subgroup
- <math>B_k := \operatorname{im} \partial_{k+1}</math>
is said to consist of boundaries.
Boundaries of boundariesEdit
Because <math>(-1)^{i+j-1}(v_0 , \dots , \widehat{v_i} , \dots , \widehat\widehat{v_j} ,\dots , v_k) = - (-1)^{i+j}(v_0 , \dots , \widehat\widehat{v_i} , \dots , \widehat{v_j} ,\dots , v_k)</math>, where <math>\widehat\widehat{v_x}</math> is the second face removed, <math>\partial^2 = 0</math>. In geometric terms, this says that the boundary of a boundary of anything has no boundary. Equivalently, the abelian groups
- <math>(C_k, \partial_k)</math>
form a chain complex. Another equivalent statement is that Template:Math is contained in Template:Math.
As an example, consider a tetrahedron with vertices oriented as <math>w,x,y,z</math>. By definition, its boundary is given by
- <math>xyz - wyz + wxz - wxy</math>.
The boundary of the boundary is given by
- <math>(yz-xz+xy)-(yz-wz+wy)+(xz-wz+wx)-(xy-wy+wx) = 0 </math>
Homology groupsEdit
The Template:Mathth homology group Template:Mvar of Template:Math is defined to be the quotient abelian group
- <math>H_k(S) = Z_k/B_k\, .</math>
It follows that the homology group Template:Math is nonzero exactly when there are Template:Math-cycles on Template:Math which are not boundaries. In a sense, this means that there are Template:Math-dimensional holes in the complex. For example, consider the complex Template:Math obtained by gluing two triangles (with no interior) along one edge, shown in the image. The edges of each triangle can be oriented so as to form a cycle. These two cycles are by construction not boundaries (since every 2-chain is zero). One can compute that the homology group Template:Math is isomorphic to Template:Math, with a basis given by the two cycles mentioned. This makes precise the informal idea that Template:Math has two "1-dimensional holes".
Holes can be of different dimensions. The rank of the Template:Mathth homology group, the number
- <math>\beta_k = \operatorname{rank} (H_k(S))\,</math>
is called the Template:Mathth Betti number of Template:Math. It gives a measure of the number of Template:Math-dimensional holes in Template:Math.
ExampleEdit
Homology groups of a triangleEdit
Let Template:Math be a triangle (without its interior), viewed as a simplicial complex. Thus Template:Math has three vertices, which we call Template:Math, and three edges, which are 1-dimensional simplices. To compute the homology groups of Template:Math, we start by describing the chain groups Template:Math:
- Template:Math is isomorphic to Template:Math with basis Template:Math
- Template:Math is isomorphic to Template:Math with a basis given by the oriented 1-simplices Template:Math, Template:Math, and Template:Math.
- Template:Math is the trivial group, since there is no simplex like <math>(v_0, v_1, v_2)</math> because the triangle has been supposed without its interior. So are the chain groups in other dimensions.
The boundary homomorphism Template:Math: Template:Math is given by:
- <math> \partial(v_0,v_1) = (v_1)-(v_0)</math>
- <math> \partial(v_0,v_2) = (v_2)-(v_0)</math>
- <math> \partial(v_1,v_2) = (v_2)-(v_1)</math>
Since Template:Math, every 0-chain is a cycle (i.e. Template:Math); moreover, the group Template:Math of the 0-boundaries is generated by the three elements on the right of these equations, creating a two-dimensional subgroup of Template:Math. So the 0th homology group Template:Math is isomorphic to Template:Math, with a basis given (for example) by the image of the 0-cycle (Template:Math). Indeed, all three vertices become equal in the quotient group; this expresses the fact that Template:Math is connected.
Next, the group of 1-cycles is the kernel of the homomorphism ∂ above, which is isomorphic to Template:Math, with a basis given (for example) by Template:Math. (A picture reveals that this 1-cycle goes around the triangle in one of the two possible directions.) Since Template:Math, the group of 1-boundaries is zero, and so the 1st homology group Template:Math is isomorphic to Template:Math. This makes precise the idea that the triangle has one 1-dimensional hole.
Next, since by definition there are no 2-cycles, Template:Math (the trivial group). Therefore the 2nd homology group Template:Math is zero. The same is true for Template:Math for all Template:Math not equal to 0 or 1. Therefore, the homological connectivity of the triangle is 0 (it is the largest Template:Math for which the reduced homology groups up to Template:Math are trivial).
Homology groups of higher-dimensional simplicesEdit
Let Template:Math be a tetrahedron (without its interior), viewed as a simplicial complex. Thus Template:Math has four 0-dimensional vertices, six 1-dimensional edges, and four 2-dimensional faces. It turns out that Template:Math is isomorphic to Template:Math, Template:Math is isomorphic to Template:Math too, and all other groups are trivial. Therefore, the homological connectivity of the tetrahedron is 0.
If the tetrahedron contains its interior, then Template:Math is trivial too.
In general, if Template:Math is a Template:Math-dimensional simplex, the following holds:
- If Template:Math is considered without its interior, then Template:Math and Template:Math and all other homologies are trivial;
- If Template:Math is considered with its interior, then Template:Math and all other homologies are trivial.
Simplicial mapsEdit
{{#invoke:Labelled list hatnote|labelledList|Main article|Main articles|Main page|Main pages}} Let S and T be simplicial complexes. A simplicial map f from S to T is a function from the vertex set of S to the vertex set of T such that the image of each simplex in S (viewed as a set of vertices) is a simplex in T. A simplicial map Template:Math determines a homomorphism of homology groups Template:Math for each integer k. This is the homomorphism associated to a chain map from the chain complex of S to the chain complex of T. Explicitly, this chain map is given on k-chains by
- <math>f((v_0, \ldots, v_k)) = (f(v_0),\ldots,f(v_k))</math>
if Template:Math are all distinct, and otherwise Template:Math.
This construction makes simplicial homology a functor from simplicial complexes to abelian groups. This is essential to applications of the theory, including the Brouwer fixed point theorem and the topological invariance of simplicial homology.
Related homologiesEdit
Singular homology is a related theory that is better adapted to theory rather than computation. Singular homology is defined for all topological spaces and depends only on the topology, not any triangulation; and it agrees with simplicial homology for spaces which can be triangulated.<ref>Template:Citation</ref>Template:Rp Nonetheless, because it is possible to compute the simplicial homology of a simplicial complex automatically and efficiently, simplicial homology has become important for application to real-life situations, such as image analysis, medical imaging, and data analysis in general.
Another related theory is Cellular homology.
ApplicationsEdit
A standard scenario in many computer applications is a collection of points (measurements, dark pixels in a bit map, etc.) in which one wishes to find a topological feature. Homology can serve as a qualitative tool to search for such a feature, since it is readily computable from combinatorial data such as a simplicial complex. However, the data points have to first be triangulated, meaning one replaces the data with a simplicial complex approximation. Computation of persistent homology<ref>Template:Cite journal
Template:Cite journal</ref> involves analysis of homology at different resolutions, registering homology classes (holes) that persist as the resolution is changed. Such features can be used to detect structures of molecules, tumors in X-rays, and cluster structures in complex data.
More generally, simplicial homology plays a central role in topological data analysis, a technique in the field of data mining.
ImplementationsEdit
- Exact, efficient, computation of simplicial homology of large simplical complexes can be computed using the GAP Simplicial Homology.
- A MATLAB toolbox for computing persistent homology, Plex (Vin de Silva, Gunnar Carlsson), is available at this site.
- Stand-alone implementations in C++ are available as part of the Perseus, Dionysus and PHAT software projects.
- For Python, there are libraries such as scikit-tda, Persim, giotto-tda and GUDHI, the latter aimed at generating topological features for machine learning. These can be found at the PyPI repository.