12#ifndef ARCANE_MESHMDVARIABLEREF_H
13#define ARCANE_MESHMDVARIABLEREF_H
17#include "arcane/utils/ArrayLayout.h"
18#include "arcane/utils/ArrayShape.h"
19#include "arcane/utils/MDSpan.h"
21#include "arcane/DataView.h"
23#include "arcane/MeshVariableArrayRef.h"
44template <
typename ItemType,
typename DataType>
48 template <
typename _ItemType,
typename _DataType,
typename _Extents>
55 using ValueDataType =
typename VariableType::ValueDataType;
66 ValueDataType* trueData() {
return this->m_private_part->trueData(); }
67 const ValueDataType* trueData()
const {
return this->m_private_part->trueData(); }
93template <
typename ItemType,
typename DataType,
typename Extents>
101 using ItemLocalIdType =
typename ItemType::LocalIdType;
102 using FullExtentsType = Extents;
108 , m_underlying_var(
b)
110 _internalInit(m_underlying_var.variable());
123 const Int32 nb_rank = Extents::rank();
145template <
typename ItemType,
typename DataType,
typename Extents>
147:
public MeshMDVariableRefBaseT<ItemType, DataType, typename Extents::template AddedFirstExtentsType<DynExtent>>
151 static_assert(Extents::rank() >= 0 && Extents::rank() <= 3,
"Only Extents of rank 0, 1, 2 or 3 are implemented");
152 static_assert(std::is_same_v<DataType,BasicType>,
"DataType should be a basic type (Real, Int32, Int64, ... )");
157 using ItemLocalIdType =
typename ItemType::LocalIdType;
158 static constexpr int nb_dynamic = Extents::nb_dynamic;
168 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 0,
void>>
169 DataType& operator()(ItemLocalIdType
id)
171 return this->m_mdspan(
id.localId());
174 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 0,
void>>
175 const DataType& operator()(ItemLocalIdType
id)
const
177 return this->m_mdspan(
id.localId());
181 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 1,
void>>
182 DataType& operator()(ItemLocalIdType
id, Int32
i1)
184 return this->m_mdspan(
id.localId(),
i1);
187 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 1,
void>>
188 const DataType& operator()(ItemLocalIdType
id, Int32
i1)
const
190 return this->m_mdspan(
id.localId(),
i1);
193 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 2,
void>>
194 DataType& operator()(ItemLocalIdType
id, Int32
i1, Int32
i2)
196 return this->m_mdspan(
id.localId(),
i1,
i2);
199 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 2,
void>>
200 const DataType& operator()(ItemLocalIdType
id, Int32
i1, Int32
i2)
const
202 return this->m_mdspan(
id.localId(),
i1,
i2);
205 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 3,
void>>
206 DataType& operator()(ItemLocalIdType
id, Int32 i, Int32
j, Int32
k)
208 return this->m_mdspan(
id.localId(), i,
j,
k);
211 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 3,
void>>
212 const DataType& operator()(ItemLocalIdType
id, Int32 i, Int32
j, Int32
k)
const
214 return this->m_mdspan(
id.localId(), i,
j,
k);
226 this->m_underlying_var.resizeAndReshape(shape);
237template <
typename ItemType,
typename DataType,
int Size,
typename Extents>
239:
public MeshMDVariableRefBaseT<ItemType, DataType, typename Extents::template AddedFirstLastExtentsType<DynExtent, Size>>
251 static_assert(Extents::rank() >= 0 && Extents::rank() <= 2,
"Only Extents of rank 0, 1 or 2 are implemented");
252 static_assert(std::is_same_v<DataType, BasicType>,
"DataType should be a basic type (Real, Int32, Int64, ... )");
256 using ItemLocalIdType =
typename ItemType::LocalIdType;
260 static constexpr int nb_dynamic = Extents::nb_dynamic;
271 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 0,
void>>
278 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 0,
void>>
285 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 1,
void>>
292 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 1,
void>>
299 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 2,
void>>
306 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 2,
void>>
320 std::array<Int32, nb_dynamic + 1>
full_dims;
322 for (
int i = 0; i < nb_dynamic; ++i)
326 this->m_underlying_var.resizeAndReshape(shape);
333 BaseClass::updateFromInternal();
338 DataType* v = this->m_mdspan.to1DSpan().data();
340 m_vector_mdspan =
MDSpanType(
nv, this->m_mdspan.extents().dynamicExtents());
345 MDSpanType m_vector_mdspan;
355template <
typename ItemType,
typename DataType,
int Row,
int Column,
typename Extents>
357:
public MeshMDVariableRefBaseT<ItemType, DataType, typename Extents::template AddedFirstLastLastExtentsType<DynExtent, Row, Column>>
369 static_assert(Extents::rank() >= 0 && Extents::rank() <= 1,
"Only Extents of rank 0 or 1 are implemented");
370 static_assert(std::is_same_v<DataType, BasicType>,
"DataType should be a basic type (Real, Int32, Int64, ... )");
374 using ItemLocalIdType =
typename ItemType::LocalIdType;
378 static constexpr int nb_dynamic = Extents::nb_dynamic;
388 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 0,
void>>
394 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 0,
void>>
400 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 1,
void>>
406 template <
typename X = Extents,
typename = std::enable_if_t<X::rank() == 1,
void>>
420 std::array<Int32, nb_dynamic + 2>
full_dims;
422 for (
int i = 0; i < nb_dynamic; ++i)
427 this->m_underlying_var.resizeAndReshape(shape);
434 BaseClass::updateFromInternal();
439 DataType* v = this->m_mdspan.to1DSpan().data();
441 m_matrix_mdspan =
MDSpanType(
nv, this->m_mdspan.extents().dynamicExtents());
446 MDSpanType m_matrix_mdspan;
static ARCCORE_HOST_DEVICE ArrayExtentsBase< Extents > fromSpan(SmallSpan< const Int32 > extents)
Construit une instance à partir des valeurs données dans extents.
Lecteur des fichiers de maillage via la bibliothèque LIMA.
constexpr ARCCORE_HOST_DEVICE DataType * ptrAt(Int32 i, Int32 j, Int32 k, Int32 l) const
Pointeur sur la valeur pour l'élément i,j,k.
Classe de base gérant une variable multi-dimension sur une entité du maillage.
UnderlyingVariableType & underlyingVariable()
Variable sous-jacente associée.
void updateFromInternal() override
Mise à jour à partir de la partie interne.
ArrayShape fullShape() const
Forme complète (statique + dynamique) de la variable.
Classe gérant une variable multi-dimension sur une entité du maillage.
void reshape(std::array< Int32, Extents::nb_dynamic > dims)
Change la forme de la donnée.
Classe gérant une variable multi-dimension de type 'NumMatrix' sur une entité du maillage.
void reshape(std::array< Int32, Extents::nb_dynamic > dims)
Change la forme de la donnée.
void updateFromInternal() override
Mise à jour à partir de la partie interne.
Variable tableau sur un type d'entité du maillage.
Classe de base d'une variable sur des entités du maillage.
Classe gérant une variable multi-dimension de type 'NumVector' sur une entité du maillage.
void reshape(std::array< Int32, Extents::nb_dynamic > dims)
Change la forme de la donnée.
ConstReferenceType operator()(ItemLocalIdType id, Int32 i1) const
Accède à la donnée en lecture.
ReferenceType operator()(ItemLocalIdType id, Int32 i1)
Accède à la donnée en lecture/écriture.
ConstReferenceType operator()(ItemLocalIdType id, Int32 i1, Int32 i2) const
Accède à la donnée en lecture.
ReferenceType operator()(ItemLocalIdType id)
Accède à la donnée en lecture/écriture.
void updateFromInternal() override
Mise à jour à partir de la partie interne.
ConstReferenceType operator()(ItemLocalIdType id) const
Accède à la donnée en lecture.
ReferenceType operator()(ItemLocalIdType id, Int32 i1, Int32 i2)
Accède à la donnée en lecture/écriture.
Paramètres nécessaires à la construction d'une variable.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-