 |
| v0.14.0
|
Go to the documentation of this file.
28 template <
typename T>
inline static auto getVee(T &&w1, T &&w2, T &&w3) {
31 std::forward<T>(w1), std::forward<T>(w2), std::forward<T>(w3)
36 template <
typename T>
inline static auto getHat(T &&w1, T &&w2, T &&w3) {
40 template <
typename A>
inline static auto getVee(
A &&t_w_hat) {
44 template <
typename A>
inline static auto getHat(
A &&t_w_vee) {
48 template <
typename A,
typename B>
49 inline static auto exp(
A &&t_w_vee, B &&theta) {
50 return expImpl(std::forward<A>(t_w_vee), std::forward<B>(theta));
53 template <
typename A,
typename B>
54 inline static auto Jl(
A &&t_w_vee, B &&theta) {
55 return JlImpl(std::forward<A>(t_w_vee), std::forward<B>(theta));
58 template <
typename A,
typename B>
59 inline static auto Jr(
A &&t_w_vee, B &&theta) {
60 return JrImpl(std::forward<A>(t_w_vee), std::forward<B>(theta));
63 template <
typename A,
typename B,
typename C>
64 inline static auto action(
A &&t_w_vee, B &&theta, C &&t_A) {
65 return actionImpl(std::forward<A>(t_w_vee), std::forward<B>(theta),
66 std::forward<C>(t_A));
69 template <
typename A,
typename B>
71 return dActionJlImpl(std::forward<A>(t_w_vee), std::forward<B>(t_A));
74 template <
typename A,
typename B>
76 return dActionJrImpl(std::forward<A>(t_w_vee), std::forward<B>(t_A));
79 template <
typename A,
typename B>
80 inline static auto diffExp(
A &&t_w_vee, B &&theta) {
81 return diffExpImpl(std::forward<A>(t_w_vee), std::forward<B>(theta));
85 inline static constexpr
int dim = 3;
101 template <
typename T>
109 template <
typename T1,
typename T2,
typename T3>
111 const T2 alpha,
const T3 beta) {
114 auto t_hat =
getHat(t_w_vee);
116 beta * (t_hat(
i,
k) * t_hat(
k,
j));
120 template <
typename T1,
typename T2>
123 if (std::fabs(theta) < std::numeric_limits<T2>::epsilon()) {
126 const auto s = sin(theta);
127 const auto s_half = sin(theta / 2);
128 const auto a = s / theta;
129 const auto b = 2 * (s_half / theta) * (s_half / theta);
133 template <
typename T1,
typename T2>
137 auto get_tensor = [&t_w_vee](
auto a,
auto diff_a,
auto b,
auto diff_b) {
145 auto t_hat =
getHat(t_w_vee);
146 t_diff_exp(
i,
j,
k) =
148 a * FTensor::levi_civita<int>(
i,
j,
k)
152 diff_a * t_hat(
i,
j) * t_w_vee(
k)
156 b * (t_hat(
i,
l) * FTensor::levi_civita<int>(
l,
j,
k) +
157 FTensor::levi_civita<int>(
i,
l,
k) * t_hat(
l,
j))
161 diff_b * t_hat(
i,
l) * t_hat(
l,
j) * t_w_vee(
k);
166 if(std::fabs(theta) < std::numeric_limits<T2>::epsilon()){
167 return get_tensor(1., -1. / 3., 0., 1. / 1.2);
170 const auto ss = sin(theta);
171 const auto a = ss / theta;
173 const auto theta2 = theta * theta;
174 const auto cc = cos(theta);
175 const auto diff_a = (theta * cc - ss) / (theta2 * theta);
177 const auto ss_2 = sin(theta / 2.);
178 const auto cc_2 = cos(theta / 2.);
179 const auto b = 2. * ss_2 * ss_2 / theta2;
181 (2. * theta * ss_2 * cc_2 - 4. * ss_2 * ss_2) / (theta2 * theta2);
183 return get_tensor(
a, diff_a, b, diff_b);
186 template <
typename T1,
typename T2>
189 if (std::fabs(theta) < std::numeric_limits<T2>::epsilon()) {
192 const auto s = sin(theta);
193 const auto s_half = sin(theta / 2);
194 const auto a = 2 * (s_half / theta) * (s_half / theta);
195 const auto b = ((theta - s) / theta) / theta / theta;
199 template <
typename T1,
typename T2>
202 if (std::fabs(theta) < std::numeric_limits<T2>::epsilon()) {
205 const auto s = sin(theta);
206 const auto s_half = sin(theta / 2);
207 const auto a = 2 * (s_half / theta) * (s_half / theta);
208 const auto b = ((theta - s) / theta) / theta / theta;
212 template <
typename T1,
typename T2,
typename T3>
218 t_B(
i,
j) =
exp(t_w_vee, theta)(
i,
k) * t_A(
k,
j);
static auto action(A &&t_w_vee, B &&theta, C &&t_A)
static auto actionImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 theta, FTensor::Tensor2_symmetric< T3, dim > &t_A)
static auto getVeeImpl(FTensor::Tensor2< T, dim, dim > &t_w_hat)
static auto getVee(A &&t_w_hat)
static auto getHat(T &&w1, T &&w2, T &&w3)
static auto getHat(A &&t_w_vee)
constexpr std::enable_if<(Dim0<=2 &&Dim1<=2), Tensor2_Expr< Levi_Civita< T >, T, Dim0, Dim1, i, j > >::type levi_civita(const Index< i, Dim0 > &, const Index< j, Dim1 > &)
levi_civita functions to make for easy adhoc use
static auto exp(A &&t_w_vee, B &&theta)
static auto diffExp(A &&t_w_vee, B &&theta)
static auto diffExpImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 theta)
static auto Jl(A &&t_w_vee, B &&theta)
static auto expImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 theta)
static auto getVee(T &&w1, T &&w2, T &&w3)
FTensor::Index< 'i', SPACE_DIM > i
static auto dActionJl(A &&t_w_vee, B &&t_A)
static auto genericFormImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 alpha, const T3 beta)
static auto dActionJr(A &&t_w_vee, B &&t_A)
static auto Jr(A &&t_w_vee, B &&theta)
static auto JrImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 theta)
FTensor::Index< 'j', 3 > j
static auto getHatImpl(FTensor::Tensor1< T, dim > &t_w_vee)
static FTENSOR_INDEX(dim, i)
const double D
diffusivity
FTensor::Index< 'm', 3 > m
static auto JlImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 &theta)
FTensor::Index< 'k', 3 > k
FTensor::Index< 'l', 3 > l