16 typedef typename std::remove_pointer<T>::type
Type;
19 typedef typename std::remove_pointer<T>::type
Type;
27 template <
typename T>
inline static auto getVee(T &&w1, T &&w2, T &&w3) {
30 std::forward<T>(w1), std::forward<T>(w2), std::forward<T>(w3)
35 template <
typename T>
inline static auto getHat(T &&w1, T &&w2, T &&w3) {
39 template <
typename A>
inline static auto getVee(
A &&t_w_hat) {
43 template <
typename A>
inline static auto getHat(
A &&t_w_vee) {
47 template <
typename A,
typename B>
48 inline static auto exp(
A &&t_w_vee,
B &&theta) {
49 return expImpl(std::forward<A>(t_w_vee), std::forward<B>(theta));
52 template <
typename A,
typename B>
53 inline static auto Jl(
A &&t_w_vee,
B &&theta) {
54 return JlImpl(std::forward<A>(t_w_vee), std::forward<B>(theta));
57 template <
typename A,
typename B>
58 inline static auto Jr(
A &&t_w_vee,
B &&theta) {
59 return JrImpl(std::forward<A>(t_w_vee), std::forward<B>(theta));
62 template <
typename A,
typename B,
typename C>
63 inline static auto action(
A &&t_w_vee,
B &&theta, C &&t_A) {
64 return actionImpl(std::forward<A>(t_w_vee), std::forward<B>(theta),
65 std::forward<C>(t_A));
68 template <
typename A,
typename B>
70 return dActionJlImpl(std::forward<A>(t_w_vee), std::forward<B>(t_A));
73 template <
typename A,
typename B>
75 return dActionJrImpl(std::forward<A>(t_w_vee), std::forward<B>(t_A));
78 template <
typename A,
typename B>
79 inline static auto diffExp(
A &&t_w_vee,
B &&theta) {
80 return diffExpImpl(std::forward<A>(t_w_vee), std::forward<B>(theta));
84 inline static constexpr int dim = 3;
96 t_w_vee(
k) = (levi_civita(
i,
j,
k) * t_w_hat(
i,
j)) / 2;
100 template <
typename T>
104 t_w_hat(
i,
j) = levi_civita(
i,
j,
k) * t_w_vee(
k);
108 template <
typename T1,
typename T2,
typename T3>
110 const T2 alpha,
const T3 beta) {
113 auto t_hat =
getHat(t_w_vee);
115 beta * (t_hat(
i,
k) * t_hat(
k,
j));
119 template <
typename T1,
typename T2>
122 if (std::fabs(theta) < std::numeric_limits<T2>::epsilon()) {
125 const auto s = sin(theta);
126 const auto s_half = sin(theta / 2);
127 const auto a = s / theta;
128 const auto b = 2 * (s_half / theta) * (s_half / theta);
132 template <
typename T1,
typename T2>
136 auto get_tensor = [&t_w_vee](
auto a,
auto diff_a,
auto b,
auto diff_b) {
144 auto t_hat =
getHat(t_w_vee);
145 t_diff_exp(
i,
j,
k) =
147 a * FTensor::levi_civita<int>(
i,
j,
k)
151 diff_a * t_hat(
i,
j) * t_w_vee(
k)
155 b * (t_hat(
i,
l) * FTensor::levi_civita<int>(
l,
j,
k) +
156 FTensor::levi_civita<int>(
i,
l,
k) * t_hat(
l,
j))
160 diff_b * t_hat(
i,
l) * t_hat(
l,
j) * t_w_vee(
k);
165 if(std::fabs(theta) < std::numeric_limits<T2>::epsilon()){
166 return get_tensor(1., -1. / 3., 0., 1. / 1.2);
169 const auto ss = sin(theta);
170 const auto a = ss / theta;
172 const auto theta2 = theta * theta;
173 const auto cc = cos(theta);
174 const auto diff_a = (theta * cc - ss) / (theta2 * theta);
176 const auto ss_2 = sin(theta / 2.);
177 const auto cc_2 = cos(theta / 2.);
178 const auto b = 2. * ss_2 * ss_2 / theta2;
180 (2. * theta * ss_2 * cc_2 - 4. * ss_2 * ss_2) / (theta2 * theta2);
182 return get_tensor(
a, diff_a, b, diff_b);
185 template <
typename T1,
typename T2>
188 if (std::fabs(theta) < std::numeric_limits<T2>::epsilon()) {
191 const auto s = sin(theta);
192 const auto s_half = sin(theta / 2);
193 const auto a = 2 * (s_half / theta) * (s_half / theta);
194 const auto b = ((theta - s) / theta) / theta / theta;
198 template <
typename T1,
typename T2>
201 if (std::fabs(theta) < std::numeric_limits<T2>::epsilon()) {
204 const auto s = sin(theta);
205 const auto s_half = sin(theta / 2);
206 const auto a = 2 * (s_half / theta) * (s_half / theta);
207 const auto b = ((theta - s) / theta) / theta / theta;
211 template <
typename T1,
typename T2,
typename T3>
217 t_B(
i,
j) =
exp(t_w_vee, theta)(
i,
k) * t_A(
k,
j);
#define FTENSOR_INDEX(DIM, I)
FTensor::Index< 'i', SPACE_DIM > i
const double n
refractive index of diffusive medium
FTensor::Index< 'l', 3 > l
FTensor::Index< 'j', 3 > j
FTensor::Index< 'k', 3 > k
Tensors class implemented by Walter Landry.
FTensor::Index< 'm', 3 > m
static auto diffExpImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 theta)
static auto dActionJr(A &&t_w_vee, B &&t_A)
static auto Jr(A &&t_w_vee, B &&theta)
static auto Jl(A &&t_w_vee, B &&theta)
static auto action(A &&t_w_vee, B &&theta, C &&t_A)
static auto JrImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 theta)
static FTENSOR_INDEX(dim, l)
static FTENSOR_INDEX(dim, k)
static auto JlImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 &theta)
static auto getVee(A &&t_w_hat)
static auto getHatImpl(FTensor::Tensor1< T, dim > &t_w_vee)
static auto getHat(T &&w1, T &&w2, T &&w3)
static FTENSOR_INDEX(dim, j)
static auto genericFormImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 alpha, const T3 beta)
static auto diffExp(A &&t_w_vee, B &&theta)
static auto dActionJl(A &&t_w_vee, B &&t_A)
static auto actionImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 theta, FTensor::Tensor2_symmetric< T3, dim > &t_A)
static auto expImpl(FTensor::Tensor1< T1, dim > &t_w_vee, const T2 theta)
static auto getHat(A &&t_w_vee)
static FTENSOR_INDEX(dim, n)
static FTENSOR_INDEX(dim, m)
static auto getVeeImpl(FTensor::Tensor2< T, dim, dim > &t_w_hat)
static FTENSOR_INDEX(dim, i)
static auto getVee(T &&w1, T &&w2, T &&w3)
static auto exp(A &&t_w_vee, B &&theta)