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

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

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

Public Member Functions

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

Private Member Functions

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

Private Attributes

Ddg_Expr< A, T, Dim01, Dim23, i, j, k, literA
 
Tensor1_Expr< B, U, Dim01, iiterB
 

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_Tensor1_0< A, B, T, U, Dim01, Dim23, i, j, k, l >

Definition at line 118 of file Ddg_times_Tensor1.hpp.

Constructor & Destructor Documentation

◆ Ddg_times_Tensor1_0()

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

Definition at line 134 of file Ddg_times_Tensor1.hpp.

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

Member Function Documentation

◆ eval() [1/2]

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_Tensor1_0< A, B, T, U, Dim01, Dim23, i, j, k, l >::eval ( const int  N1,
const int  N2,
const int  N3,
const Number< 1 > &   
) const
inlineprivate

Definition at line 128 of file Ddg_times_Tensor1.hpp.

129  {
130  return iterA(0, N3, N1, N2) * iterB(0);
131  }

◆ eval() [2/2]

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

Definition at line 123 of file Ddg_times_Tensor1.hpp.

124  {
125  return iterA(Current_Dim - 1, N3, N1, N2) * iterB(Current_Dim - 1) +
126  eval(N1, N2, N3, Number<Current_Dim - 1>());
127  }

◆ 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_Tensor1_0< A, B, T, U, Dim01, Dim23, i, j, k, l >::operator() ( const int  N1,
const int  N2,
const int  N3 
) const
inline

Definition at line 137 of file Ddg_times_Tensor1.hpp.

138  {
139  return eval(N1, N2, N3, Number<Dim01>());
140  }

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_Tensor1_0< A, B, T, U, Dim01, Dim23, i, j, k, l >::iterA
private

Definition at line 119 of file Ddg_times_Tensor1.hpp.

◆ iterB

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

Definition at line 120 of file Ddg_times_Tensor1.hpp.


The documentation for this class was generated from the following file:
FTensor::Ddg_times_Tensor1_0::eval
promote< T, U >::V eval(const int N1, const int N2, const int N3, const Number< Current_Dim > &) const
Definition: Ddg_times_Tensor1.hpp:123
a
constexpr double a
Definition: approx_sphere.cpp:30
FTensor::Ddg_times_Tensor1_0::iterA
Ddg_Expr< A, T, Dim01, Dim23, i, j, k, l > iterA
Definition: Ddg_times_Tensor1.hpp:119
FTensor::Ddg_times_Tensor1_0::iterB
Tensor1_Expr< B, U, Dim01, i > iterB
Definition: Ddg_times_Tensor1.hpp:120