21template <
typename T,
typename =
void>
22struct scalar_value_type
29struct scalar_value_type<
T,
std::
void_t<typename T::value_type>>
31 typedef typename T::value_type value_type;
35using scalar_value_type_t =
typename scalar_value_type<T>::value_type;
44 contravariantPiola = 3,
45 doubleCovariantPiola = 4,
46 doubleContravariantPiola = 5,
50template <
typename O,
typename P,
typename Q,
typename R>
55 for (std::size_t
i = 0;
i <
U.extent(0); ++
i)
56 for (std::size_t
j = 0;
j <
U.extent(1); ++
j)
61template <
typename O,
typename P,
typename Q,
typename R>
65 using T =
typename std::decay_t<O>::value_type;
66 using Z =
typename impl::scalar_value_type_t<T>;
67 for (std::size_t
p = 0;
p <
U.extent(0); ++
p)
70 for (std::size_t
i = 0;
i <
r.extent(1); ++
i)
73 for (std::size_t
k = 0;
k <
K.extent(0); ++
k)
81template <
typename O,
typename P,
typename Q,
typename R>
85 using T =
typename std::decay_t<O>::value_type;
86 using Z =
typename impl::scalar_value_type_t<T>;
87 for (std::size_t
p = 0;
p <
U.extent(0); ++
p)
89 for (std::size_t
i = 0;
i <
r.extent(1); ++
i)
92 for (std::size_t
k = 0;
k <
J.extent(1); ++
k)
98 std::transform(
r.data_handle(),
r.data_handle() +
r.size(),
r.data_handle(),
99 [
detJ](
auto ri) { return ri / static_cast<Z>(detJ); });
103template <
typename O,
typename P,
typename Q,
typename R>
107 using T =
typename std::decay_t<O>::value_type;
108 using Z =
typename impl::scalar_value_type_t<T>;
109 for (std::size_t
p = 0;
p <
U.extent(0); ++
p)
111 md::mdspan<const T, md::dextents<std::size_t, 2>>
_U(
112 U.data_handle() +
p *
U.extent(1),
K.extent(0),
K.extent(0));
113 md::mdspan<T, md::dextents<std::size_t, 2>>
_r(
114 r.data_handle() +
p *
r.extent(1),
K.extent(1),
K.extent(1));
116 for (std::size_t
i = 0;
i <
_r.extent(0); ++
i)
118 for (std::size_t
j = 0;
j <
_r.extent(1); ++
j)
121 for (std::size_t
k = 0;
k <
K.extent(0); ++
k)
122 for (std::size_t
l = 0;
l <
_U.extent(1); ++
l)
131template <
typename O,
typename P,
typename Q,
typename R>
135 using T =
typename std::decay_t<O>::value_type;
136 using Z =
typename impl::scalar_value_type_t<T>;
137 for (std::size_t
p = 0;
p <
U.extent(0); ++
p)
139 md::mdspan<const T, md::dextents<std::size_t, 2>>
_U(
140 U.data_handle() +
p *
U.extent(1),
J.extent(1),
J.extent(1));
141 md::mdspan<T, md::dextents<std::size_t, 2>>
_r(
142 r.data_handle() +
p *
r.extent(1),
J.extent(0),
J.extent(0));
145 for (std::size_t
i = 0;
i <
_r.extent(0); ++
i)
147 for (std::size_t
j = 0;
j <
_r.extent(1); ++
j)
150 for (std::size_t
k = 0;
k <
J.extent(1); ++
k)
151 for (std::size_t
l = 0;
l <
_U.extent(1); ++
l)
158 std::transform(
r.data_handle(),
r.data_handle() +
r.size(),
r.data_handle(),
159 [
detJ](
auto ri) { return ri / static_cast<Z>(detJ * detJ); });
A finite element.
Definition finite-element.h:137
Information about finite element maps.
Definition maps.h:15
void l2_piola(O &&r, const P &U, const Q &, double detJ, const R &)
L2 Piola map.
Definition maps.h:51
void covariant_piola(O &&r, const P &U, const Q &, double, const R &K)
Covariant Piola map.
Definition maps.h:62
void contravariant_piola(O &&r, const P &U, const Q &J, double detJ, const R &)
Contravariant Piola map.
Definition maps.h:82
void double_contravariant_piola(O &&r, const P &U, const Q &J, double detJ, const R &)
Double contravariant Piola map.
Definition maps.h:132
void double_covariant_piola(O &&r, const P &U, const Q &, double, const R &K)
Double covariant Piola map.
Definition maps.h:104
type
Map type.
Definition maps.h:40