v0.14.0
Public Member Functions | Private Member Functions | Private Attributes | List of all members
FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m > Class Template Reference

#include <src/ftensor/src/FTensor/Tensor4/Tensor4_times_Dg_double.hpp>

Collaboration diagram for FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >:
[legend]

Public Member Functions

promote< T, U >::V operator() (const int N1, const int N2, const int N3) const
 
 Tensor4_times_Dg_01 (const Tensor4_Expr< A, T, Dim0, Dim1, Dim2, Dim3, i, j, k, l > &a, const Dg_Expr< B, U, Dim0, Dim4, i, j, m > &b)
 

Private Member Functions

template<int Current_Dim0, int Current_Dim1>
promote< T, U >::V eval (const int N1, const int N2, const int N3, const Number< Current_Dim0 > &, const Number< Current_Dim1 > &) const
 
template<int Current_Dim1>
promote< T, U >::V eval (const int N1, const int N2, const int N3, const Number< 1 > &, const Number< Current_Dim1 > &) const
 
promote< T, U >::V eval (const int N1, const int N2, const int N3, const Number< 1 > &, const Number< 1 > &) const
 

Private Attributes

const Tensor4_Expr< A, T, Dim0, Dim1, Dim2, Dim3, i, j, k, literA
 
const Dg_Expr< B, U, Dim0, Dim4, i, j, miterB
 

Detailed Description

template<class A, class B, class T, class U, int Dim0, int Dim1, int Dim2, int Dim3, int Dim4, char i, char j, char k, char l, char m>
class FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >

Definition at line 84 of file Tensor4_times_Dg_double.hpp.

Constructor & Destructor Documentation

◆ Tensor4_times_Dg_01()

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, int Dim3, int Dim4, char i, char j, char k, char l, char m>
FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >::Tensor4_times_Dg_01 ( const Tensor4_Expr< A, T, Dim0, Dim1, Dim2, Dim3, i, j, k, l > &  a,
const Dg_Expr< B, U, Dim0, Dim4, i, j, m > &  b 
)
inline

Definition at line 114 of file Tensor4_times_Dg_double.hpp.

117  : iterA(a), iterB(b) {
118  static_assert(Dim0 == Dim1, "Dim0 and Dim1 should be equal");
119  }

Member Function Documentation

◆ eval() [1/3]

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, int Dim3, int Dim4, char i, char j, char k, char l, char m>
promote<T, U>::V FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >::eval ( const int  N1,
const int  N2,
const int  N3,
const Number< 1 > &  ,
const Number< 1 > &   
) const
inlineprivate

Definition at line 103 of file Tensor4_times_Dg_double.hpp.

104  {
105  return iterA(0, 0, N1, N2) * iterB(0, 0, N3);
106  }

◆ eval() [2/3]

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, int Dim3, int Dim4, char i, char j, char k, char l, char m>
template<int Current_Dim1>
promote<T, U>::V FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >::eval ( const int  N1,
const int  N2,
const int  N3,
const Number< 1 > &  ,
const Number< Current_Dim1 > &   
) const
inlineprivate

Definition at line 97 of file Tensor4_times_Dg_double.hpp.

99  {
100  return iterA(0, Current_Dim1 - 1, N1, N2) * iterB(0, Current_Dim1 - 1, N3) +
101  eval(N1, N2, N3, Number<Dim0>(), Number<Current_Dim1 - 1>());
102  }

◆ eval() [3/3]

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, int Dim3, int Dim4, char i, char j, char k, char l, char m>
template<int Current_Dim0, int Current_Dim1>
promote<T, U>::V FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >::eval ( const int  N1,
const int  N2,
const int  N3,
const Number< Current_Dim0 > &  ,
const Number< Current_Dim1 > &   
) const
inlineprivate

Definition at line 89 of file Tensor4_times_Dg_double.hpp.

91  {
92  return iterA(Current_Dim0 - 1, Current_Dim1 - 1, N1, N2) *
93  iterB(Current_Dim0 - 1, Current_Dim1 - 1, N3) +
94  eval(N1, N2, N3, Number<Current_Dim0 - 1>(), Number<Current_Dim1>());
95  }

◆ operator()()

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, int Dim3, int Dim4, char i, char j, char k, char l, char m>
promote<T, U>::V FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >::operator() ( const int  N1,
const int  N2,
const int  N3 
) const
inline

Definition at line 109 of file Tensor4_times_Dg_double.hpp.

110  {
111  return eval(N1, N2, N3, Number<Dim0>(), Number<Dim1>());
112  }

Member Data Documentation

◆ iterA

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, int Dim3, int Dim4, char i, char j, char k, char l, char m>
const Tensor4_Expr<A, T, Dim0, Dim1, Dim2, Dim3, i, j, k, l> FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >::iterA
private

Definition at line 85 of file Tensor4_times_Dg_double.hpp.

◆ iterB

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, int Dim3, int Dim4, char i, char j, char k, char l, char m>
const Dg_Expr<B, U, Dim0, Dim4, i, j, m> FTensor::Tensor4_times_Dg_01< A, B, T, U, Dim0, Dim1, Dim2, Dim3, Dim4, i, j, k, l, m >::iterB
private

Definition at line 86 of file Tensor4_times_Dg_double.hpp.


The documentation for this class was generated from the following file:
a
constexpr double a
Definition: approx_sphere.cpp:30
FTensor::Tensor4_times_Dg_01::eval
promote< T, U >::V eval(const int N1, const int N2, const int N3, const Number< Current_Dim0 > &, const Number< Current_Dim1 > &) const
Definition: Tensor4_times_Dg_double.hpp:89
FTensor::Tensor4_times_Dg_01::iterB
const Dg_Expr< B, U, Dim0, Dim4, i, j, m > iterB
Definition: Tensor4_times_Dg_double.hpp:86
FTensor::Tensor4_times_Dg_01::iterA
const Tensor4_Expr< A, T, Dim0, Dim1, Dim2, Dim3, i, j, k, l > iterA
Definition: Tensor4_times_Dg_double.hpp:85