surfacetopology


Namesurfacetopology JSON
Version 0.1.2 PyPI version JSON
download
home_pagehttps://github.com/jacquemv/surfacetopology
SummaryCheck the validity and determine the topology of a triangulated surface
upload_time2023-10-07 20:27:24
maintainer
docs_urlNone
authorVincent Jacquemet
requires_python
licenseMIT
keywords triangular mesh surface manifold boundary orientability genus
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ### Triangulated compact manifolds

The connectivity of a triangulated surface composed of $n_v$ vertices and $n_t$ triangles can be specified by a 3-by-$n_t$ matrix of vertex indices ranging from 0 to $n_v-1$. Each row contains the index of the three vertices of a triangle. This representation is less general than a simplicial complex, but is more convenient and widespread for large meshes. Note that the vertex positions are not needed since only topological properties are considered.

This triangulation describes a compact manifold surface if and only if:
1. every triangle has 3 distinct vertices;
2. every edge is adjacent to 1 or 2 triangles;
3. the set of triangles adjacent to any vertex forms a closed or open fan.

A fan is a collection of triangles sharing a common vertex and chained 
together by a sequence of shared edges.

### Objective

The purpose of this package is to check if a triangulation satisfies the above conditions and to calculate the basic topological properties such as connectedness, orientability, genus and boundaries that are used for the classification of compact 2-manifolds.

### Examples

The function `surface_topology` separates the connected components and provides for each one some information about the mesh. The attribute ``manifold`` indicates if the conditions are satisfied. The attribute ``genus`` is calculated from the Euler characteristic (``euler``).

```python
>>> import surfacetopology as topo
>>> S1 = topo.small_mesh('tetrahedron')
>>> S1
[[0 1 2]
 [0 2 3]
 [1 0 3]
 [2 1 3]]
>>> topo.surface_topology(S1)
[SurfaceTopology(n_vertices=4, n_edges=6, n_triangles=4, n_boundaries=0,
euler=2, genus=0, manifold=True, oriented=True, closed=True)]
```

If a surface has multiple connected components (here artificially generated using ``disjoint_sum``), a list of ``SurfaceTopology`` objects are returned. When there are isolated vertices, a large number of connected components of size 1 may be generated. In that case, it is useful to call the function ``renumber_vertices`` first.

```python
>>> S2 = topo.small_mesh('torus')
>>> S = topo.disjoint_sum(S1, S2, 10+S1)
>>> len(topo.surface_topology(S))
13
>>> S = topo.renumber_vertices(S)
>>> len(topo.surface_topology(S))
3
```

If a surface is not oriented, the orientability will be checked by attempting to fix the orientation (stored in the attribute ``triangles`` if the surface turns out to be orientable). Here, the Moebius strip is not orientable and has genus 1.

```python
>>> S3 = topo.small_mesh('moebius')
>>> topo.surface_topology(S3)
[SurfaceTopology(n_vertices=6, n_edges=12, n_triangles=6, n_boundaries=1,
euler=0, genus=1, manifold=True, oriented=False, orientable=False, closed=False)]
```

Surfaces with higher genus can be generated using ``connected_sum``

```python
>>> S = topo.connected_sum(S2, S2, S2)
>>> topo.surface_topology(S)
[SurfaceTopology(n_vertices=15, n_edges=57, n_triangles=38, n_boundaries=0,
euler=-4, genus=3, manifold=True, oriented=True, closed=True)]
```

In case ``manifold`` is false, the ``SurfaceTopology`` object contains attributes for trouble-shooting (``nonmanifold_vertices``, ``nonmanifold_edges``, ``collapsed_triangles``).

### Implementation

The code is implemented in C++, interfaced and compiled using ``cython``, and with a wrapper for python (``surfacetopology/wrapper.py``). It was designed for meshes with 100k vertices, but should be appropriate for 1M vertices.

### Installation

Can be installed using the command ``pip install surfacetopology`` (on Windows, a compiler such as Microsoft Visual C++ is required).

Tested using Anaconda 2023.09 (python 3.11) on Linux and Windows.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/jacquemv/surfacetopology",
    "name": "surfacetopology",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "triangular,mesh,surface,manifold,boundary,orientability,genus",
    "author": "Vincent Jacquemet",
    "author_email": "vincent.jacquemet@umontreal.ca",
    "download_url": "https://files.pythonhosted.org/packages/89/18/1706ca7f7e83dee1b104d760d44a8037899426795f5358fd8ca368afd751/surfacetopology-0.1.2.tar.gz",
    "platform": null,
    "description": "### Triangulated compact manifolds\n\nThe connectivity of a triangulated surface composed of $n_v$ vertices and $n_t$ triangles can be specified by a 3-by-$n_t$ matrix of vertex indices ranging from 0 to $n_v-1$. Each row contains the index of the three vertices of a triangle. This representation is less general than a simplicial complex, but is more convenient and widespread for large meshes. Note that the vertex positions are not needed since only topological properties are considered.\n\nThis triangulation describes a compact manifold surface if and only if:\n1. every triangle has 3 distinct vertices;\n2. every edge is adjacent to 1 or 2 triangles;\n3. the set of triangles adjacent to any vertex forms a closed or open fan.\n\nA fan is a collection of triangles sharing a common vertex and chained \ntogether by a sequence of shared edges.\n\n### Objective\n\nThe purpose of this package is to check if a triangulation satisfies the above conditions and to calculate the basic topological properties such as connectedness, orientability, genus and boundaries that are used for the classification of compact 2-manifolds.\n\n### Examples\n\nThe function `surface_topology` separates the connected components and provides for each one some information about the mesh. The attribute ``manifold`` indicates if the conditions are satisfied. The attribute ``genus`` is calculated from the Euler characteristic (``euler``).\n\n```python\n>>> import surfacetopology as topo\n>>> S1 = topo.small_mesh('tetrahedron')\n>>> S1\n[[0 1 2]\n [0 2 3]\n [1 0 3]\n [2 1 3]]\n>>> topo.surface_topology(S1)\n[SurfaceTopology(n_vertices=4, n_edges=6, n_triangles=4, n_boundaries=0,\neuler=2, genus=0, manifold=True, oriented=True, closed=True)]\n```\n\nIf a surface has multiple connected components (here artificially generated using ``disjoint_sum``), a list of ``SurfaceTopology`` objects are returned. When there are isolated vertices, a large number of connected components of size 1 may be generated. In that case, it is useful to call the function ``renumber_vertices`` first.\n\n```python\n>>> S2 = topo.small_mesh('torus')\n>>> S = topo.disjoint_sum(S1, S2, 10+S1)\n>>> len(topo.surface_topology(S))\n13\n>>> S = topo.renumber_vertices(S)\n>>> len(topo.surface_topology(S))\n3\n```\n\nIf a surface is not oriented, the orientability will be checked by attempting to fix the orientation (stored in the attribute ``triangles`` if the surface turns out to be orientable). Here, the Moebius strip is not orientable and has genus 1.\n\n```python\n>>> S3 = topo.small_mesh('moebius')\n>>> topo.surface_topology(S3)\n[SurfaceTopology(n_vertices=6, n_edges=12, n_triangles=6, n_boundaries=1,\neuler=0, genus=1, manifold=True, oriented=False, orientable=False, closed=False)]\n```\n\nSurfaces with higher genus can be generated using ``connected_sum``\n\n```python\n>>> S = topo.connected_sum(S2, S2, S2)\n>>> topo.surface_topology(S)\n[SurfaceTopology(n_vertices=15, n_edges=57, n_triangles=38, n_boundaries=0,\neuler=-4, genus=3, manifold=True, oriented=True, closed=True)]\n```\n\nIn case ``manifold`` is false, the ``SurfaceTopology`` object contains attributes for trouble-shooting (``nonmanifold_vertices``, ``nonmanifold_edges``, ``collapsed_triangles``).\n\n### Implementation\n\nThe code is implemented in C++, interfaced and compiled using ``cython``, and with a wrapper for python (``surfacetopology/wrapper.py``). It was designed for meshes with 100k vertices, but should be appropriate for 1M vertices.\n\n### Installation\n\nCan be installed using the command ``pip install surfacetopology`` (on Windows, a compiler such as Microsoft Visual C++ is required).\n\nTested using Anaconda 2023.09 (python 3.11) on Linux and Windows.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Check the validity and determine the topology of a triangulated surface",
    "version": "0.1.2",
    "project_urls": {
        "Homepage": "https://github.com/jacquemv/surfacetopology"
    },
    "split_keywords": [
        "triangular",
        "mesh",
        "surface",
        "manifold",
        "boundary",
        "orientability",
        "genus"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "89181706ca7f7e83dee1b104d760d44a8037899426795f5358fd8ca368afd751",
                "md5": "3a4381c783910778f5b0f12ec1428ef4",
                "sha256": "83b82252ae508c25f0f6a6df369b89f321a0f8ddf4475016d1a3b400f74a6c0e"
            },
            "downloads": -1,
            "filename": "surfacetopology-0.1.2.tar.gz",
            "has_sig": false,
            "md5_digest": "3a4381c783910778f5b0f12ec1428ef4",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 150236,
            "upload_time": "2023-10-07T20:27:24",
            "upload_time_iso_8601": "2023-10-07T20:27:24.724493Z",
            "url": "https://files.pythonhosted.org/packages/89/18/1706ca7f7e83dee1b104d760d44a8037899426795f5358fd8ca368afd751/surfacetopology-0.1.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-10-07 20:27:24",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "jacquemv",
    "github_project": "surfacetopology",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "surfacetopology"
}
        
Elapsed time: 0.14095s