11#include <basix/mdspan.hpp>
14#include <dolfinx/common/IndexMap.h>
15#include <dolfinx/common/MPI.h>
16#include <dolfinx/common/sort.h>
17#include <dolfinx/fem/CoordinateElement.h>
18#include <dolfinx/fem/ElementDofLayout.h>
19#include <dolfinx/fem/dofmapbuilder.h>
20#include <dolfinx/graph/AdjacencyList.h>
21#include <dolfinx/graph/partition.h>
32template <std::
floating_po
int T>
62 template <
typename U,
typename V,
typename W>
63 requires std::is_convertible_v<std::remove_cvref_t<U>,
64 std::vector<std::vector<std::int32_t>>>
65 and std::is_convertible_v<std::remove_cvref_t<V>,
67 and std::is_convertible_v<std::remove_cvref_t<W>,
68 std::vector<std::int64_t>>
70 std::shared_ptr<const common::IndexMap>
index_map, U&& dofmaps,
72 typename std::remove_reference_t<typename V::value_type>>>& elements,
74 : _dim(
dim), _dofmaps(std::forward<U>(dofmaps)), _index_map(
index_map),
75 _cmaps(elements), _x(std::forward<V>(
x)),
78 assert(_x.size() % 3 == 0);
79 if (_x.size() / 3 != _input_global_indices.size())
80 throw std::runtime_error(
"Geometry size mismatch.");
82 if (_dofmaps.size() != _cmaps.size())
84 throw std::runtime_error(
"Geometry number of dofmaps not equal to the "
85 "number of coordinate elements.");
107 int dim()
const {
return _dim; }
111 MDSPAN_IMPL_STANDARD_NAMESPACE::mdspan<
113 MDSPAN_IMPL_STANDARD_NAMESPACE::dextents<std::size_t, 2>>
116 if (_dofmaps.size() != 1)
117 throw std::runtime_error(
"Multiple dofmaps");
127 MDSPAN_IMPL_STANDARD_NAMESPACE::mdspan<
129 MDSPAN_IMPL_STANDARD_NAMESPACE::dextents<std::size_t, 2>>
132 std::size_t ndofs = _cmaps.at(i).dim();
133 return MDSPAN_IMPL_STANDARD_NAMESPACE::mdspan<
135 MDSPAN_IMPL_STANDARD_NAMESPACE::dextents<std::size_t, 2>>(
136 _dofmaps.at(i).data(), _dofmaps.at(i).size() / ndofs, ndofs);
141 std::shared_ptr<const common::IndexMap>
index_map()
const
150 std::span<const value_type>
x()
const {
return _x; }
157 std::span<value_type>
x() {
return _x; }
165 const std::vector<fem::CoordinateElement<value_type>>&
cmaps()
const
175 if (_cmaps.size() > 1)
176 throw std::runtime_error(
"Multiple cmaps.");
177 return _cmaps.front();
183 return _input_global_indices;
191 std::vector<std::vector<std::int32_t>> _dofmaps;
194 std::shared_ptr<const common::IndexMap> _index_map;
197 std::vector<fem::CoordinateElement<value_type>> _cmaps;
201 std::vector<value_type> _x;
204 std::vector<std::int64_t> _input_global_indices;
209template <
typename U,
typename V,
typename W>
210Geometry(std::shared_ptr<const common::IndexMap>, U&&,
212 typename std::remove_reference_t<typename V::value_type>>>&,
214 -> Geometry<typename std::remove_cvref_t<typename V::value_type>>;
242Geometry<typename std::remove_reference_t<typename U::value_type>>
246 std::remove_reference_t<typename U::value_type>>>& elements,
247 std::span<const std::int64_t> nodes, std::span<const std::int64_t> xdofs,
253 spdlog::info(
"Create Geometry (multiple)");
255 assert(std::ranges::is_sorted(nodes));
256 using T =
typename std::remove_reference_t<typename U::value_type>;
259 const int tdim = topology.
dim();
260 const std::size_t num_cell_types = topology.
entity_types(tdim).size();
261 if (elements.size() != num_cell_types)
262 throw std::runtime_error(
"Mismatch between topology and geometry.");
264 std::vector<fem::ElementDofLayout> dof_layouts;
265 for (
const auto& el : elements)
266 dof_layouts.push_back(el.create_dof_layout());
268 spdlog::info(
"Got {} dof layouts", dof_layouts.size());
271 auto [_dof_index_map, bs, dofmaps]
273 topology, dof_layouts, reorder_fn);
275 = std::make_shared<common::IndexMap>(std::move(_dof_index_map));
278 if (elements.front().needs_dof_permutations())
280 const std::int32_t num_cells
282 const std::vector<std::uint32_t>& cell_info
284 int d = elements.front().dim();
285 for (std::int32_t cell = 0; cell < num_cells; ++cell)
287 std::span dofs(dofmaps.front().data() + cell * d, d);
288 elements.front().permute_inv(dofs, cell_info[cell]);
292 spdlog::info(
"Calling compute_local_to_global");
299 spdlog::info(
"xdofs.size = {}", xdofs.size());
300 std::vector<std::int32_t> all_dofmaps;
302 for (
auto q : dofmaps)
304 s << q.size() <<
" ";
305 all_dofmaps.insert(all_dofmaps.end(), q.begin(), q.end());
307 spdlog::info(
"dofmap sizes = {}", s.str());
308 spdlog::info(
"all_dofmaps.size = {}", all_dofmaps.size());
309 spdlog::info(
"nodes.size = {}", nodes.size());
315 std::vector<std::int64_t> igi(nodes.size());
316 std::ranges::transform(l2l, igi.begin(),
317 [&nodes](
auto index) { return nodes[index]; });
320 assert(x.size() % dim == 0);
321 const std::size_t shape0 = x.size() / dim;
322 const std::size_t shape1 = dim;
323 std::vector<T> xg(3 * shape0, 0);
324 for (std::size_t i = 0; i < shape0; ++i)
326 std::copy_n(std::next(x.begin(), shape1 * l2l[i]), shape1,
327 std::next(xg.begin(), 3 * i));
330 spdlog::info(
"Creating geometry with {} dofmaps", dof_layouts.size());
332 return Geometry(dof_index_map, std::move(dofmaps), elements, std::move(xg),
333 dim, std::move(igi));
Definition topologycomputation.h:24
Geometry stores the geometry imposed on a mesh.
Definition Geometry.h:34
~Geometry()=default
Destructor.
std::span< value_type > x()
Access geometry degrees-of-freedom data (non-const version).
Definition Geometry.h:157
MDSPAN_IMPL_STANDARD_NAMESPACE::mdspan< const std::int32_t, MDSPAN_IMPL_STANDARD_NAMESPACE::dextents< std::size_t, 2 > > dofmap(std::size_t i) const
Degree-of-freedom map associated with the ith coordinate map element in the geometry.
Definition Geometry.h:130
Geometry(std::shared_ptr< const common::IndexMap > index_map, U &&dofmaps, const std::vector< fem::CoordinateElement< typename std::remove_reference_t< typename V::value_type > > > &elements, V &&x, int dim, W &&input_global_indices)
Constructor of object that holds mesh geometry data.
Definition Geometry.h:69
std::shared_ptr< const common::IndexMap > index_map() const
Index map for the geometry 'degrees-of-freedom'.
Definition Geometry.h:141
Geometry(Geometry &&)=default
Move constructor.
Geometry(const Geometry &)=default
Copy constructor.
const fem::CoordinateElement< value_type > & cmap() const
The element that describes the geometry map.
Definition Geometry.h:173
int dim() const
Return dimension of the Euclidean coordinate system.
Definition Geometry.h:107
Geometry & operator=(Geometry &&)=default
Move assignment.
MDSPAN_IMPL_STANDARD_NAMESPACE::mdspan< const std::int32_t, MDSPAN_IMPL_STANDARD_NAMESPACE::dextents< std::size_t, 2 > > dofmap() const
DofMap for the geometry.
Definition Geometry.h:114
const std::vector< std::int64_t > & input_global_indices() const
Global user indices.
Definition Geometry.h:181
std::span< const value_type > x() const
Access geometry degrees-of-freedom data (const version).
Definition Geometry.h:150
Geometry & operator=(const Geometry &)=delete
Copy assignment.
const std::vector< fem::CoordinateElement< value_type > > & cmaps() const
The elements that describes the geometry map.
Definition Geometry.h:165
T value_type
Value type.
Definition Geometry.h:37
Topology stores the topology of a mesh, consisting of mesh entities and connectivity (incidence relat...
Definition Topology.h:46
std::shared_ptr< const common::IndexMap > index_map(int dim) const
Get the IndexMap that described the parallel distribution of the mesh entities.
Definition Topology.cpp:787
const std::vector< std::uint32_t > & get_cell_permutation_info() const
Returns the permutation information.
Definition Topology.cpp:807
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.
Definition Topology.cpp:793
const std::vector< CellType > & entity_types(int dim) const
Entity types in the topology for a given dimension.
Definition Topology.cpp:764
int dim() const noexcept
Topological dimension of the mesh.
Definition Topology.cpp:759
std::tuple< common::IndexMap, int, std::vector< std::vector< std::int32_t > > > build_dofmap_data(MPI_Comm comm, const mesh::Topology &topology, const std::vector< ElementDofLayout > &element_dof_layouts, const std::function< std::vector< int >(const graph::AdjacencyList< std::int32_t > &)> &reorder_fn)
Definition dofmapbuilder.cpp:627
std::vector< std::int64_t > compute_local_to_global(std::span< const std::int64_t > global, std::span< const std::int32_t > local)
Definition partition.cpp:534
std::vector< std::int32_t > compute_local_to_local(std::span< const std::int64_t > local0_to_global, std::span< const std::int64_t > local1_to_global)
Compute a local0-to-local1 map from two local-to-global maps with common global indices.
Definition partition.cpp:556
Mesh data structures and algorithms on meshes.
Definition DofMap.h:32
Geometry< typename std::remove_reference_t< typename U::value_type > > create_geometry(const Topology &topology, const std::vector< fem::CoordinateElement< std::remove_reference_t< typename U::value_type > > > &elements, std::span< const std::int64_t > nodes, std::span< const std::int64_t > xdofs, const U &x, int dim, std::function< std::vector< int >(const graph::AdjacencyList< std::int32_t > &)> reorder_fn=nullptr)
Build Geometry from input data.
Definition Geometry.h:243