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

#include <src/ftensor/src/FTensor/Tensor2/Tensor2_times_Tensor2.hpp>

Collaboration diagram for FTensor::Tensor2_times_Tensor2_00< A, B, T, U, Dim0, Dim1, Dim2, i, j, k >:
[legend]

Public Member Functions

 Tensor2_times_Tensor2_00 (const Tensor2_Expr< A, T, Dim1, Dim0, j, i > &a, const Tensor2_Expr< B, U, Dim1, Dim2, j, k > &b)
 
promote< T, U >::V operator() (const int N1, const int N2) const
 

Private Member Functions

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

Private Attributes

Tensor2_Expr< A, T, Dim1, Dim0, j, iiterA
 
Tensor2_Expr< B, U, Dim1, Dim2, j, kiterB
 

Detailed Description

template<class A, class B, class T, class U, int Dim0, int Dim1, int Dim2, char i, char j, char k>
class FTensor::Tensor2_times_Tensor2_00< A, B, T, U, Dim0, Dim1, Dim2, i, j, k >

Definition at line 206 of file Tensor2_times_Tensor2.hpp.

Constructor & Destructor Documentation

◆ Tensor2_times_Tensor2_00()

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, char i, char j, char k>
FTensor::Tensor2_times_Tensor2_00< A, B, T, U, Dim0, Dim1, Dim2, i, j, k >::Tensor2_times_Tensor2_00 ( const Tensor2_Expr< A, T, Dim1, Dim0, j, i > &  a,
const Tensor2_Expr< B, U, Dim1, Dim2, j, k > &  b 
)
inline

Definition at line 225 of file Tensor2_times_Tensor2.hpp.

227  : iterA(a), iterB(b)
228  {}

Member Function Documentation

◆ eval() [1/2]

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

Definition at line 219 of file Tensor2_times_Tensor2.hpp.

220  {
221  return iterA(0, N1) * iterB(0, N2);
222  }

◆ eval() [2/2]

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, char i, char j, char k>
template<int Current_Dim>
promote<T, U>::V FTensor::Tensor2_times_Tensor2_00< A, B, T, U, Dim0, Dim1, Dim2, i, j, k >::eval ( const int  N1,
const int  N2,
const Number< Current_Dim > &   
) const
inlineprivate

Definition at line 213 of file Tensor2_times_Tensor2.hpp.

214  {
215  return iterA(Current_Dim - 1, N1) * iterB(Current_Dim - 1, N2)
216  + eval(N1, N2, Number<Current_Dim - 1>());
217  }

◆ operator()()

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

Definition at line 229 of file Tensor2_times_Tensor2.hpp.

230  {
231  return eval(N1, N2, Number<Dim1>());
232  }

Member Data Documentation

◆ iterA

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, char i, char j, char k>
Tensor2_Expr<A, T, Dim1, Dim0, j, i> FTensor::Tensor2_times_Tensor2_00< A, B, T, U, Dim0, Dim1, Dim2, i, j, k >::iterA
private

Definition at line 208 of file Tensor2_times_Tensor2.hpp.

◆ iterB

template<class A , class B , class T , class U , int Dim0, int Dim1, int Dim2, char i, char j, char k>
Tensor2_Expr<B, U, Dim1, Dim2, j, k> FTensor::Tensor2_times_Tensor2_00< A, B, T, U, Dim0, Dim1, Dim2, i, j, k >::iterB
private

Definition at line 209 of file Tensor2_times_Tensor2.hpp.


The documentation for this class was generated from the following file:
FTensor::Tensor2_times_Tensor2_00::iterB
Tensor2_Expr< B, U, Dim1, Dim2, j, k > iterB
Definition: Tensor2_times_Tensor2.hpp:209
a
constexpr double a
Definition: approx_sphere.cpp:30
FTensor::Tensor2_times_Tensor2_00::iterA
Tensor2_Expr< A, T, Dim1, Dim0, j, i > iterA
Definition: Tensor2_times_Tensor2.hpp:208
FTensor::Tensor2_times_Tensor2_00::eval
promote< T, U >::V eval(const int N1, const int N2, const Number< Current_Dim > &) const
Definition: Tensor2_times_Tensor2.hpp:213