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

#include <src/ftensor/src/FTensor/Ddg/Ddg_times_Tensor4.hpp>

Collaboration diagram for FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >:
[legend]

Public Member Functions

 Ddg_times_Tensor4_2301_ijkl (const Ddg_Expr< A, T, Dim01, Dim23, i, j, m, n > &a, const Tensor4_Expr< B, U, Dim23, Dim23, Dim2, Dim3, m, n, k, l > &b)
 
promote< T, U >::V operator() (const int N1, const int N2, const int N3, const int N4) const
 

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 int N4, 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 int N4, const Number< 1 > &, const Number< Current_Dim1 > &) const
 
promote< T, U >::V eval (const int N1, const int N2, const int N3, const int N4, const Number< 1 > &, const Number< 1 > &) const
 

Private Attributes

Ddg_Expr< A, T, Dim01, Dim23, i, j, m, niterA
 
Tensor4_Expr< B, U, Dim23, Dim23, Dim2, Dim3, m, n, k, literB
 

Detailed Description

template<class A, class B, class T, class U, int Dim01, int Dim23, int Dim2, int Dim3, char i, char j, char k, char l, char m, char n>
class FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >

Definition at line 13 of file Ddg_times_Tensor4.hpp.

Constructor & Destructor Documentation

◆ Ddg_times_Tensor4_2301_ijkl()

template<class A , class B , class T , class U , int Dim01, int Dim23, int Dim2, int Dim3, char i, char j, char k, char l, char m, char n>
FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >::Ddg_times_Tensor4_2301_ijkl ( const Ddg_Expr< A, T, Dim01, Dim23, i, j, m, n > &  a,
const Tensor4_Expr< B, U, Dim23, Dim23, Dim2, Dim3, m, n, k, l > &  b 
)
inline

Definition at line 42 of file Ddg_times_Tensor4.hpp.

45  : iterA(a), iterB(b) {}

Member Function Documentation

◆ eval() [1/3]

template<class A , class B , class T , class U , int Dim01, int Dim23, int Dim2, int Dim3, char i, char j, char k, char l, char m, char n>
promote<T, U>::V FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >::eval ( const int  N1,
const int  N2,
const int  N3,
const int  N4,
const Number< 1 > &  ,
const Number< 1 > &   
) const
inlineprivate

Definition at line 34 of file Ddg_times_Tensor4.hpp.

37  {
38  return iterA(N1, N2, 0, 0) * iterB(0, 0, N3, N4);
39  }

◆ eval() [2/3]

template<class A , class B , class T , class U , int Dim01, int Dim23, int Dim2, int Dim3, char i, char j, char k, char l, char m, char n>
template<int Current_Dim1>
promote<T, U>::V FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >::eval ( const int  N1,
const int  N2,
const int  N3,
const int  N4,
const Number< 1 > &  ,
const Number< Current_Dim1 > &   
) const
inlineprivate

Definition at line 28 of file Ddg_times_Tensor4.hpp.

29  {
30  return iterA(N1, N2, 0, Current_Dim1 - 1) *
31  iterB(0, Current_Dim1 - 1, N3, N4) +
32  eval(N1, N2, N3, N4, Number<Dim23>(), Number<Current_Dim1 - 1>());
33  }

◆ eval() [3/3]

template<class A , class B , class T , class U , int Dim01, int Dim23, int Dim2, int Dim3, char i, char j, char k, char l, char m, char n>
template<int Current_Dim0, int Current_Dim1>
promote<T, U>::V FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >::eval ( const int  N1,
const int  N2,
const int  N3,
const int  N4,
const Number< Current_Dim0 > &  ,
const Number< Current_Dim1 > &   
) const
inlineprivate

Definition at line 19 of file Ddg_times_Tensor4.hpp.

20  {
21  return iterA(N1, N2, Current_Dim0 - 1, Current_Dim1 - 1) *
22  iterB(Current_Dim0 - 1, Current_Dim1 - 1, N3, N4) +
23  eval(N1, N2, N3, N4, Number<Current_Dim0 - 1>(),
24  Number<Current_Dim1>());
25  }

◆ operator()()

template<class A , class B , class T , class U , int Dim01, int Dim23, int Dim2, int Dim3, char i, char j, char k, char l, char m, char n>
promote<T, U>::V FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >::operator() ( const int  N1,
const int  N2,
const int  N3,
const int  N4 
) const
inline

Definition at line 46 of file Ddg_times_Tensor4.hpp.

47  {
48  return eval(N1, N2, N3, N4, Number<Dim23>(), Number<Dim23>());
49  }

Member Data Documentation

◆ iterA

template<class A , class B , class T , class U , int Dim01, int Dim23, int Dim2, int Dim3, char i, char j, char k, char l, char m, char n>
Ddg_Expr<A, T, Dim01, Dim23, i, j, m, n> FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >::iterA
private

Definition at line 14 of file Ddg_times_Tensor4.hpp.

◆ iterB

template<class A , class B , class T , class U , int Dim01, int Dim23, int Dim2, int Dim3, char i, char j, char k, char l, char m, char n>
Tensor4_Expr<B, U, Dim23, Dim23, Dim2, Dim3, m, n, k, l> FTensor::Ddg_times_Tensor4_2301_ijkl< A, B, T, U, Dim01, Dim23, Dim2, Dim3, i, j, k, l, m, n >::iterB
private

Definition at line 15 of file Ddg_times_Tensor4.hpp.


The documentation for this class was generated from the following file:
FTensor::Ddg_times_Tensor4_2301_ijkl::iterA
Ddg_Expr< A, T, Dim01, Dim23, i, j, m, n > iterA
Definition: Ddg_times_Tensor4.hpp:14
a
constexpr double a
Definition: approx_sphere.cpp:30
FTensor::Ddg_times_Tensor4_2301_ijkl::eval
promote< T, U >::V eval(const int N1, const int N2, const int N3, const int N4, const Number< Current_Dim0 > &, const Number< Current_Dim1 > &) const
Definition: Ddg_times_Tensor4.hpp:19
FTensor::Ddg_times_Tensor4_2301_ijkl::iterB
Tensor4_Expr< B, U, Dim23, Dim23, Dim2, Dim3, m, n, k, l > iterB
Definition: Ddg_times_Tensor4.hpp:15