Nektar++
Public Member Functions | Protected Attributes | Private Member Functions | List of all members
Nektar::Collections::PhysDeriv_SumFac_Seg Class Reference

Phys deriv operator using sum-factorisation (Segment) More...

Inheritance diagram for Nektar::Collections::PhysDeriv_SumFac_Seg:
[legend]

Public Member Functions

virtual ~PhysDeriv_SumFac_Seg ()
 
virtual void operator() (const Array< OneD, const NekDouble > &input, Array< OneD, NekDouble > &output0, Array< OneD, NekDouble > &output1, Array< OneD, NekDouble > &output2, Array< OneD, NekDouble > &wsp)
 Perform operation. More...
 
virtual void operator() (int dir, const Array< OneD, const NekDouble > &input, Array< OneD, NekDouble > &output, Array< OneD, NekDouble > &wsp)
 
- Public Member Functions inherited from Nektar::Collections::Operator
 Operator (std::vector< StdRegions::StdExpansionSharedPtr > pCollExp, std::shared_ptr< CoalescedGeomData > GeomData)
 Constructor. More...
 
virtual COLLECTIONS_EXPORT ~Operator ()
 
int GetWspSize ()
 Get the size of the required workspace. More...
 

Protected Attributes

int m_coordim
 
const int m_nquad0
 
Array< TwoD, const NekDoublem_derivFac
 
NekDoublem_Deriv0
 
- Protected Attributes inherited from Nektar::Collections::Operator
StdRegions::StdExpansionSharedPtr m_stdExp
 
unsigned int m_numElmt
 
unsigned int m_wspSize
 

Private Member Functions

 PhysDeriv_SumFac_Seg (vector< StdRegions::StdExpansionSharedPtr > pCollExp, CoalescedGeomDataSharedPtr pGeomData)
 

Detailed Description

Phys deriv operator using sum-factorisation (Segment)

Definition at line 510 of file PhysDeriv.cpp.

Constructor & Destructor Documentation

◆ ~PhysDeriv_SumFac_Seg()

virtual Nektar::Collections::PhysDeriv_SumFac_Seg::~PhysDeriv_SumFac_Seg ( )
inlinevirtual

Definition at line 515 of file PhysDeriv.cpp.

516  {
517  }

◆ PhysDeriv_SumFac_Seg()

Nektar::Collections::PhysDeriv_SumFac_Seg::PhysDeriv_SumFac_Seg ( vector< StdRegions::StdExpansionSharedPtr pCollExp,
CoalescedGeomDataSharedPtr  pGeomData 
)
inlineprivate

Definition at line 583 of file PhysDeriv.cpp.

References Nektar::Collections::ePhysDeriv, Nektar::LibUtilities::eSegment, Nektar::Collections::eSumFac, and Nektar::Collections::GetOperatorFactory().

586  : Operator (pCollExp, pGeomData),
587  m_nquad0 (m_stdExp->GetNumPoints(0))
588  {
589  LibUtilities::PointsKeyVector PtsKey = m_stdExp->GetPointsKeys();
590  m_coordim = pCollExp[0]->GetCoordim();
591 
592  m_derivFac = pGeomData->GetDerivFactors(pCollExp);
593 
594  m_Deriv0 = &((m_stdExp->GetBasis(0)->GetD())->GetPtr())[0];
596  }
std::vector< PointsKey > PointsKeyVector
Definition: Points.h:246
Array< TwoD, const NekDouble > m_derivFac
Definition: PhysDeriv.cpp:579
Operator(std::vector< StdRegions::StdExpansionSharedPtr > pCollExp, std::shared_ptr< CoalescedGeomData > GeomData)
Constructor.
Definition: Operator.h:113
StdRegions::StdExpansionSharedPtr m_stdExp
Definition: Operator.h:148

Member Function Documentation

◆ operator()() [1/2]

virtual void Nektar::Collections::PhysDeriv_SumFac_Seg::operator() ( const Array< OneD, const NekDouble > &  input,
Array< OneD, NekDouble > &  output0,
Array< OneD, NekDouble > &  output1,
Array< OneD, NekDouble > &  output2,
Array< OneD, NekDouble > &  wsp 
)
inlinevirtual

Perform operation.

Implements Nektar::Collections::Operator.

Definition at line 519 of file PhysDeriv.cpp.

References ASSERTL1, Blas::Dgemm(), and Vmath::Vmul().

525  {
526  const int nqcol = m_nquad0*m_numElmt;
527 
528  ASSERTL1(wsp.num_elements() == m_wspSize,
529  "Incorrect workspace size");
530  ASSERTL1(input.num_elements() >= nqcol,
531  "Incorrect input size");
532 
533  Array<OneD, NekDouble> diff0(nqcol, wsp);
534 
535  Blas::Dgemm('N', 'N', m_nquad0, m_numElmt,
536  m_nquad0, 1.0, m_Deriv0, m_nquad0,
537  input.get(), m_nquad0, 0.0,
538  diff0.get(), m_nquad0);
539 
540  Vmath::Vmul (nqcol, m_derivFac[0], 1, diff0, 1, output0, 1);
541 
542  if (m_coordim == 2)
543  {
544  Vmath::Vmul (nqcol, m_derivFac[1], 1, diff0, 1, output1, 1);
545  }
546  else if (m_coordim == 3)
547  {
548  Vmath::Vmul (nqcol, m_derivFac[1], 1, diff0, 1, output1, 1);
549  Vmath::Vmul (nqcol, m_derivFac[2], 1, diff0, 1, output2, 1);
550  }
551  }
static void Dgemm(const char &transa, const char &transb, const int &m, const int &n, const int &k, const double &alpha, const double *a, const int &lda, const double *b, const int &ldb, const double &beta, double *c, const int &ldc)
BLAS level 3: Matrix-matrix multiply C = A x B where A[m x n], B[n x k], C[m x k].
Definition: Blas.hpp:213
Array< TwoD, const NekDouble > m_derivFac
Definition: PhysDeriv.cpp:579
#define ASSERTL1(condition, msg)
Assert Level 1 – Debugging which is used whether in FULLDEBUG or DEBUG compilation mode...
Definition: ErrorUtil.hpp:250
void Vmul(int n, const T *x, const int incx, const T *y, const int incy, T *z, const int incz)
Multiply vector z = x*y.
Definition: Vmath.cpp:186

◆ operator()() [2/2]

virtual void Nektar::Collections::PhysDeriv_SumFac_Seg::operator() ( int  dir,
const Array< OneD, const NekDouble > &  input,
Array< OneD, NekDouble > &  output,
Array< OneD, NekDouble > &  wsp 
)
inlinevirtual

Implements Nektar::Collections::Operator.

Definition at line 553 of file PhysDeriv.cpp.

References ASSERTL1, Blas::Dgemm(), and Vmath::Vmul().

558  {
559  const int nqcol = m_nquad0*m_numElmt;
560 
561  ASSERTL1(wsp.num_elements() == m_wspSize,
562  "Incorrect workspace size");
563  ASSERTL1(input.num_elements() >= nqcol,
564  "Incorrect input size");
565 
566  Array<OneD, NekDouble> diff0(nqcol, wsp);
567 
568  Blas::Dgemm('N', 'N', m_nquad0, m_numElmt,
569  m_nquad0, 1.0, m_Deriv0, m_nquad0,
570  input.get(), m_nquad0, 0.0,
571  diff0.get(), m_nquad0);
572 
573  Vmath::Vmul(nqcol, m_derivFac[dir], 1, diff0, 1, output, 1);
574  }
static void Dgemm(const char &transa, const char &transb, const int &m, const int &n, const int &k, const double &alpha, const double *a, const int &lda, const double *b, const int &ldb, const double &beta, double *c, const int &ldc)
BLAS level 3: Matrix-matrix multiply C = A x B where A[m x n], B[n x k], C[m x k].
Definition: Blas.hpp:213
Array< TwoD, const NekDouble > m_derivFac
Definition: PhysDeriv.cpp:579
#define ASSERTL1(condition, msg)
Assert Level 1 – Debugging which is used whether in FULLDEBUG or DEBUG compilation mode...
Definition: ErrorUtil.hpp:250
void Vmul(int n, const T *x, const int incx, const T *y, const int incy, T *z, const int incz)
Multiply vector z = x*y.
Definition: Vmath.cpp:186

Member Data Documentation

◆ m_coordim

int Nektar::Collections::PhysDeriv_SumFac_Seg::m_coordim
protected

Definition at line 577 of file PhysDeriv.cpp.

◆ m_Deriv0

NekDouble* Nektar::Collections::PhysDeriv_SumFac_Seg::m_Deriv0
protected

Definition at line 580 of file PhysDeriv.cpp.

◆ m_derivFac

Array<TwoD, const NekDouble> Nektar::Collections::PhysDeriv_SumFac_Seg::m_derivFac
protected

Definition at line 579 of file PhysDeriv.cpp.

◆ m_nquad0

const int Nektar::Collections::PhysDeriv_SumFac_Seg::m_nquad0
protected

Definition at line 578 of file PhysDeriv.cpp.