v0.13.2
Loading...
Searching...
No Matches
Public Member Functions | Private Member Functions | Private Attributes | List of all members
FTensor::Ddg_times_Tensor2_symmetric_23< A, B, T, U, Dim01, Dim23, i, j, k, l > Class Template Reference

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

Collaboration diagram for FTensor::Ddg_times_Tensor2_symmetric_23< A, B, T, U, Dim01, Dim23, i, j, k, l >:
[legend]

Public Member Functions

 Ddg_times_Tensor2_symmetric_23 (const Ddg_Expr< A, T, Dim01, Dim23, i, j, k, l > &a, const Tensor2_symmetric_Expr< B, U, Dim23, k, l > &b)
 
promote< T, U >::V operator() (const int N1, const int N2) const
 

Private Member Functions

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

Private Attributes

Ddg_Expr< A, T, Dim01, Dim23, i, j, k, literA
 
Tensor2_symmetric_Expr< B, U, Dim23, k, literB
 

Detailed Description

template<class A, class B, class T, class U, int Dim01, int Dim23, char i, char j, char k, char l>
class FTensor::Ddg_times_Tensor2_symmetric_23< A, B, T, U, Dim01, Dim23, i, j, k, l >

Definition at line 161 of file Ddg_times_Tensor2_symmetric.hpp.

Constructor & Destructor Documentation

◆ Ddg_times_Tensor2_symmetric_23()

template<class A , class B , class T , class U , int Dim01, int Dim23, char i, char j, char k, char l>
FTensor::Ddg_times_Tensor2_symmetric_23< A, B, T, U, Dim01, Dim23, i, j, k, l >::Ddg_times_Tensor2_symmetric_23 ( const Ddg_Expr< A, T, Dim01, Dim23, i, j, k, l > &  a,
const Tensor2_symmetric_Expr< B, U, Dim23, k, l > &  b 
)
inline

Definition at line 191 of file Ddg_times_Tensor2_symmetric.hpp.

194 : iterA(a), iterB(b)
195 {}
constexpr double a
Ddg_Expr< A, T, Dim01, Dim23, i, j, k, l > iterA
Tensor2_symmetric_Expr< B, U, Dim23, k, l > iterB

Member Function Documentation

◆ eval() [1/3]

template<class A , class B , class T , class U , int Dim01, int Dim23, char i, char j, char k, char l>
promote< T, U >::V FTensor::Ddg_times_Tensor2_symmetric_23< A, B, T, U, Dim01, Dim23, i, j, k, l >::eval ( const int  N1,
const int  N2,
const Number< 1 > &  ,
const Number< 1 > &   
) const
inlineprivate

Definition at line 184 of file Ddg_times_Tensor2_symmetric.hpp.

186 {
187 return iterA(N1, N2, 0, 0) * iterB(0, 0);
188 }
static Number< 2 > N2
static Number< 1 > N1

◆ eval() [2/3]

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

Definition at line 178 of file Ddg_times_Tensor2_symmetric.hpp.

180 {
181 return iterA(N1, N2, 0, Current_Dim1 - 1) * iterB(0, Current_Dim1 - 1)
182 + eval(N1, N2, Number<Dim23>(), Number<Current_Dim1 - 1>());
183 }
promote< T, U >::V eval(const int N1, const int N2, const Number< Current_Dim0 > &, const Number< Current_Dim1 > &) const

◆ eval() [3/3]

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

Definition at line 168 of file Ddg_times_Tensor2_symmetric.hpp.

170 {
171 return iterA(N1, N2, Current_Dim0 - 1, Current_Dim1 - 1)
172 * iterB(Current_Dim0 - 1, Current_Dim1 - 1)
173 + eval(N1, N2, Number<Current_Dim0 - 1>(),
174 Number<Current_Dim1>());
175 }

◆ operator()()

template<class A , class B , class T , class U , int Dim01, int Dim23, char i, char j, char k, char l>
promote< T, U >::V FTensor::Ddg_times_Tensor2_symmetric_23< A, B, T, U, Dim01, Dim23, i, j, k, l >::operator() ( const int  N1,
const int  N2 
) const
inline

Definition at line 196 of file Ddg_times_Tensor2_symmetric.hpp.

197 {
198 return eval(N1, N2, Number<Dim23>(), Number<Dim23>());
199 }

Member Data Documentation

◆ iterA

template<class A , class B , class T , class U , int Dim01, int Dim23, char i, char j, char k, char l>
Ddg_Expr<A, T, Dim01, Dim23, i, j, k, l> FTensor::Ddg_times_Tensor2_symmetric_23< A, B, T, U, Dim01, Dim23, i, j, k, l >::iterA
private

Definition at line 163 of file Ddg_times_Tensor2_symmetric.hpp.

◆ iterB

template<class A , class B , class T , class U , int Dim01, int Dim23, char i, char j, char k, char l>
Tensor2_symmetric_Expr<B, U, Dim23, k, l> FTensor::Ddg_times_Tensor2_symmetric_23< A, B, T, U, Dim01, Dim23, i, j, k, l >::iterB
private

Definition at line 164 of file Ddg_times_Tensor2_symmetric.hpp.


The documentation for this class was generated from the following file: