File: EntityMap.h

package info (click to toggle)
fenics-dolfinx 1%3A0.10.0.post4-1exp1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 6,028 kB
  • sloc: cpp: 36,535; python: 25,391; makefile: 226; sh: 171; xml: 55
file content (122 lines) | stat: -rw-r--r-- 4,234 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
// Copyright (C) 2025 Jørgen S. Dokken and Joseph P. Dean
//
// This file is part of DOLFINx (https://www.fenicsproject.org)
//
// SPDX-License-Identifier:    LGPL-3.0-or-later

#pragma once

#include "Topology.h"
#include <concepts>
#include <dolfinx/common/IndexMap.h>
#include <span>
#include <vector>

namespace dolfinx::mesh
{
/// @brief A bidirectional map relating entities in one topology to
/// another.
class EntityMap
{
public:
  /// @brief Constructor of a bidirectional map relating entities of
  /// dimension `dim` in `topology` and `sub_topology`.
  ///
  /// @tparam U
  /// @param topology A mesh topology.
  /// @param sub_topology Topology of another mesh. This must be a
  /// "sub-topology" of `topology`, i.e. every entity in `sub_topology`
  /// must also exist in `topology`.
  /// @param dim Topological dimension of the entities.
  /// @param sub_topology_to_topology List of entities in `topology`
  /// where `sub_topology_to_topology[i]` is the index in `topology`
  /// corresponding to entity `i` in `sub_topology`.
  template <typename U>
    requires std::is_convertible_v<std::remove_cvref_t<U>,
                                   std::vector<std::int32_t>>
  EntityMap(std::shared_ptr<const Topology> topology,
            std::shared_ptr<const Topology> sub_topology, int dim,
            U&& sub_topology_to_topology)
      : _dim(dim), _topology(topology),
        _sub_topology_to_topology(std::forward<U>(sub_topology_to_topology)),
        _sub_topology(sub_topology)
  {
    auto e_imap = sub_topology->index_map(_dim);
    if (!e_imap)
    {
      throw std::runtime_error(
          "No index map for entities, call `Topology::create_entities("
          + std::to_string(_dim) + ")");
    }

    std::size_t num_ents = e_imap->size_local() + e_imap->num_ghosts();
    if (num_ents != _sub_topology_to_topology.size())
    {
      throw std::runtime_error(
          "Size mismatch between `sub_topology_to_topology` and index map.");
    }
  }

  /// Copy constructor
  EntityMap(const EntityMap& map) = default;

  /// Move constructor
  EntityMap(EntityMap&& map) = default;

  // Destructor
  ~EntityMap() = default;

  /// @brief Get the topological dimension of the entities related by
  /// this `EntityMap`.
  /// @return The topological dimension.
  std::size_t dim() const;

  /// @brief Get the (parent) topology.
  /// @return The parent topology.
  std::shared_ptr<const Topology> topology() const;

  /// @brief Get the sub-topology.
  /// @return The sub-topology.
  std::shared_ptr<const Topology> sub_topology() const;

  /// @brief Map entities between the sub-topology and the parent
  /// topology.
  ///
  /// If `inverse` is false, this function maps a list of
  /// `this->dim()`-dimensional entities from `this->sub_topology()` to
  /// the corresponding entities in `this->topology()`. If `inverse` is
  /// true, it performs the inverse mapping: from `this->topology()` to
  /// `this->sub_topology()`. Entities that do not exist in the
  /// sub-topology are marked as -1.
  ///
  /// @note If `inverse` is `true`, this function recomputes the inverse
  /// map on every call (it is not cached), which may be expensive if
  /// called repeatedly.
  ///
  /// @param entities List of entity indices in the source topology.
  /// @param inverse If false, maps from `this->sub_topology()` to
  /// `this->topology()`. If true, maps from `this->topology()` to
  /// `this->sub_topology()`.
  /// @return A list of mapped entity indices. Entities that do not
  /// exist in the target topology are marked as -1.
  std::vector<std::int32_t>
  sub_topology_to_topology(std::span<const std::int32_t> entities,
                           bool inverse) const;

private:
  // Dimension of the entities
  std::size_t _dim;

  // A topology
  std::shared_ptr<const Topology> _topology;

  // A list of `_dim`-dimensional entities in _topology, where
  // `_sub_topology_to_topology[i]` is the index in `_topology` of the
  // `i`th entity in `_sub_topology`
  std::vector<std::int32_t> _sub_topology_to_topology;

  // A second topology, consisting of a subset of entities in
  // `_topology`
  std::shared_ptr<const Topology> _sub_topology;
};
} // namespace dolfinx::mesh