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

#include <src/ftensor/src/FTensor/Dg/Dg_times_Tensor2_symmetric.hpp>

Collaboration diagram for FTensor::Dg_times_Tensor2_symmetric_10< A, B, T, U, Dim01, Dim2, i, j, k >:
[legend]

Public Member Functions

 Dg_times_Tensor2_symmetric_10 (const Dg_Expr< A, T, Dim01, Dim2, j, k, i > &a, const Tensor2_symmetric_Expr< B, U, Dim01, k, j > &b)
 
promote< T, U >::V operator() (const int N1) const
 

Private Member Functions

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

Private Attributes

Dg_Expr< A, T, Dim01, Dim2, j, k, iiterA
 
Tensor2_symmetric_Expr< B, U, Dim01, k, jiterB
 

Detailed Description

template<class A, class B, class T, class U, int Dim01, int Dim2, char i, char j, char k>
class FTensor::Dg_times_Tensor2_symmetric_10< A, B, T, U, Dim01, Dim2, i, j, k >

Definition at line 599 of file Dg_times_Tensor2_symmetric.hpp.

Constructor & Destructor Documentation

◆ Dg_times_Tensor2_symmetric_10()

template<class A , class B , class T , class U , int Dim01, int Dim2, char i, char j, char k>
FTensor::Dg_times_Tensor2_symmetric_10< A, B, T, U, Dim01, Dim2, i, j, k >::Dg_times_Tensor2_symmetric_10 ( const Dg_Expr< A, T, Dim01, Dim2, j, k, i > &  a,
const Tensor2_symmetric_Expr< B, U, Dim01, k, j > &  b 
)
inline

Definition at line 626 of file Dg_times_Tensor2_symmetric.hpp.

629  : iterA(a), iterB(b)
630  {}

Member Function Documentation

◆ eval() [1/3]

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

Definition at line 620 of file Dg_times_Tensor2_symmetric.hpp.

621  {
622  return iterA(0, 0, N1) * iterB(0, 0);
623  }

◆ eval() [2/3]

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

Definition at line 614 of file Dg_times_Tensor2_symmetric.hpp.

615  {
616  return iterA(0, Current_Dim1 - 1, N1) * iterB(Current_Dim1 - 1, 0)
617  + eval(N1, Number<Dim01>(), Number<Current_Dim1 - 1>());
618  }

◆ eval() [3/3]

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

Definition at line 605 of file Dg_times_Tensor2_symmetric.hpp.

607  {
608  return iterA(Current_Dim0 - 1, Current_Dim1 - 1, N1)
609  * iterB(Current_Dim1 - 1, Current_Dim0 - 1)
610  + eval(N1, Number<Current_Dim0 - 1>(), Number<Current_Dim1>());
611  }

◆ operator()()

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

Definition at line 631 of file Dg_times_Tensor2_symmetric.hpp.

632  {
633  return eval(N1, Number<Dim01>(), Number<Dim01>());
634  }

Member Data Documentation

◆ iterA

template<class A , class B , class T , class U , int Dim01, int Dim2, char i, char j, char k>
Dg_Expr<A, T, Dim01, Dim2, j, k, i> FTensor::Dg_times_Tensor2_symmetric_10< A, B, T, U, Dim01, Dim2, i, j, k >::iterA
private

Definition at line 601 of file Dg_times_Tensor2_symmetric.hpp.

◆ iterB

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

Definition at line 602 of file Dg_times_Tensor2_symmetric.hpp.


The documentation for this class was generated from the following file:
a
constexpr double a
Definition: approx_sphere.cpp:30
FTensor::Dg_times_Tensor2_symmetric_10::iterB
Tensor2_symmetric_Expr< B, U, Dim01, k, j > iterB
Definition: Dg_times_Tensor2_symmetric.hpp:602
FTensor::Dg_times_Tensor2_symmetric_10::iterA
Dg_Expr< A, T, Dim01, Dim2, j, k, i > iterA
Definition: Dg_times_Tensor2_symmetric.hpp:601
FTensor::Dg_times_Tensor2_symmetric_10::eval
promote< T, U >::V eval(const int N1, const Number< Current_Dim0 > &, const Number< Current_Dim1 > &) const
Definition: Dg_times_Tensor2_symmetric.hpp:605