DOLFINx 0.10.0.0
DOLFINx C++ interface
|
Topology stores the topology of a mesh, consisting of mesh entities and connectivity (incidence relations for the mesh entities). More...
#include <Topology.h>
Public Member Functions | |
Topology (std::vector< CellType > cell_types, std::shared_ptr< const common::IndexMap > vertex_map, std::vector< std::shared_ptr< const common::IndexMap > > cell_maps, std::vector< std::shared_ptr< graph::AdjacencyList< std::int32_t > > > cells, const std::optional< std::vector< std::vector< std::int64_t > > > &original_cell_index=std::nullopt) | |
Create a mesh topology. | |
Topology (const Topology &topology)=default | |
Copy constructor. | |
Topology (Topology &&topology)=default | |
Move constructor. | |
~Topology ()=default | |
Destructor. | |
Topology & | operator= (const Topology &topology)=delete |
Assignment. | |
Topology & | operator= (Topology &&topology)=default |
Assignment. | |
int | dim () const noexcept |
Topological dimension of the mesh. | |
const std::vector< CellType > & | entity_types (int dim) const |
Entity types in the topology for a given dimension. | |
CellType | cell_type () const |
Cell type. | |
std::vector< std::shared_ptr< const common::IndexMap > > | index_maps (int dim) const |
Get the index maps that described the parallel distribution of the mesh entities of a given topological dimension. | |
std::shared_ptr< const common::IndexMap > | index_map (int dim) const |
Get the IndexMap that described the parallel distribution of the mesh entities. | |
std::shared_ptr< const graph::AdjacencyList< std::int32_t > > | connectivity (std::array< int, 2 > d0, std::array< int, 2 > d1) const |
Get the connectivity from entities of topological dimension d0 to dimension d1 . | |
std::shared_ptr< const graph::AdjacencyList< std::int32_t > > | connectivity (int d0, int d1) const |
Return connectivity from entities of dimension d0 to entities of dimension d1 . Assumes only one entity type per dimension. | |
const std::vector< std::uint32_t > & | get_cell_permutation_info () const |
Returns the permutation information. | |
const std::vector< std::uint8_t > & | get_facet_permutations () const |
Get the numbers that encode the number of permutations to apply to facets. | |
const std::vector< std::int32_t > & | interprocess_facets (int index) const |
List of inter-process facets of a given type. | |
const std::vector< std::int32_t > & | interprocess_facets () const |
List of inter-process facets. | |
bool | create_entities (int dim) |
Create entities of given topological dimension. | |
void | create_connectivity (int d0, int d1) |
Create connectivity between given pair of dimensions, d0 / -> d1 . | |
void | create_entity_permutations () |
Compute entity permutations and reflections. | |
MPI_Comm | comm () const |
Mesh MPI communicator. | |
Public Attributes | |
std::vector< std::vector< std::int64_t > > | original_cell_index |
Original cell index for each cell type. | |
Topology stores the topology of a mesh, consisting of mesh entities and connectivity (incidence relations for the mesh entities).
A mesh entity e may be identified globally as a pair e = (dim, i)
, where dim is the topological dimension and i is the index of the entity within that topological dimension.
Topology | ( | std::vector< CellType > | cell_types, |
std::shared_ptr< const common::IndexMap > | vertex_map, | ||
std::vector< std::shared_ptr< const common::IndexMap > > | cell_maps, | ||
std::vector< std::shared_ptr< graph::AdjacencyList< std::int32_t > > > | cells, | ||
const std::optional< std::vector< std::vector< std::int64_t > > > & | original_cell_index = std::nullopt ) |
Create a mesh topology.
A Topology represents the connectivity of a mesh. Mesh entities, i.e. vertices, edges, faces and cells, are defined in terms of their vertices. Connectivity represents the relationships between entities, e.g. the cells that are connected to a given edge in the mesh.
[in] | cell_types | Types of cells. |
[in] | vertex_map | Index map describing the distribution of mesh vertices. |
[in] | cell_maps | Index maps describing the distribution of mesh cells for each cell type in cell_types . |
[in] | cells | Cell-to-vertex connectivities for each cell type in cell_types . |
[in] | original_cell_index | Original indices for each cell in cells . |
mesh::CellType cell_type | ( | ) | const |
Cell type.
This function is is for topologies with one cell type only.
MPI_Comm comm | ( | ) | const |
std::shared_ptr< const graph::AdjacencyList< std::int32_t > > connectivity | ( | int | d0, |
int | d1 ) const |
Return connectivity from entities of dimension d0
to entities of dimension d1
. Assumes only one entity type per dimension.
[in] | d0 | Topological dimension. |
[in] | d1 | Topological dimension. |
d0
gives the list of incident entities of dimension d1
. Returns nullptr
if connectivity has not been computed. std::shared_ptr< const graph::AdjacencyList< std::int32_t > > connectivity | ( | std::array< int, 2 > | d0, |
std::array< int, 2 > | d1 ) const |
Get the connectivity from entities of topological dimension d0
to dimension d1
.
The entity type and incident entity type are each described by a pair (dim, index)
. The index within a topological dimension dim
, is that of the cell type given in entity_types(dim)
.
[in] | d0 | Pair of (topological dimension of entities, index of "entity type" within topological dimension). |
[in] | d1 | Pair of (topological dimension of entities, index of incident "entity type" within topological dimension). |
d0
to entity types in d1
, or nullptr
if not yet computed. void create_connectivity | ( | int | d0, |
int | d1 ) |
Create connectivity between given pair of dimensions, d0 / -> d1
.
[in] | d0 | Topological dimension. |
[in] | d1 | Topological dimension. |
bool create_entities | ( | int | dim | ) |
Create entities of given topological dimension.
[in] | dim | Topological dimension of entities to compute. |
const std::vector< CellType > & entity_types | ( | int | dim | ) | const |
Entity types in the topology for a given dimension.
[in] | dim | Topological dimension. |
const std::vector< std::uint8_t > & get_facet_permutations | ( | ) | const |
Get the numbers that encode the number of permutations to apply to facets.
The permutations are encoded so that:
n % 2
gives the number of reflections to applyn // 2
gives the number of rotations to applyThe data is stored in a flattened 2D array, so that data[cell_index * / facets_per_cell + facet_index]
contains the facet with index facet_index
of the cell with index cell_index
.
std::shared_ptr< const common::IndexMap > index_map | ( | int | dim | ) | const |
Get the IndexMap that described the parallel distribution of the mesh entities.
[in] | dim | Topological dimension |
dim
. Returns nullptr
if index map has not been set. std::vector< std::shared_ptr< const common::IndexMap > > index_maps | ( | int | dim | ) | const |
Get the index maps that described the parallel distribution of the mesh entities of a given topological dimension.
[in] | dim | Topological dimension. |
const std::vector< std::int32_t > & interprocess_facets | ( | ) | const |
List of inter-process facets.
"Inter-process" facets are facets that are connected (1) to a cell that is owned by the calling process (rank) and (2) to a cell that is owned by another process.
const std::vector< std::int32_t > & interprocess_facets | ( | int | index | ) | const |
List of inter-process facets of a given type.
"Inter-process" facets are facets that are connected (1) to a cell that is owned by the calling process (rank) and (2) to a cell that is owned by another process.
Facets must have been computed for inter-process facet data to be available.
[in] | index | Index of facet type, following the order given by entity_types. |