36#include <boost/core/ignore_unused.hpp>
54 : m_base(numbases), m_elmt_id(0), m_ncoeffs(numcoeffs),
55 m_stdMatrixManager(std::bind(&
StdExpansion::CreateStdMatrix, this,
56 std::placeholders::_1),
57 std::string(
"StdExpansionStdMatrix")),
58 m_stdStaticCondMatrixManager(
59 std::bind(&
StdExpansion::CreateStdStaticCondMatrix, this,
60 std::placeholders::_1),
61 std::string(
"StdExpansionStdStaticCondMatrix"))
67 "NULL Basis attempting to be used.");
72 "NULL Basis attempting to be used.");
77 "NULL Basis attempting to be used.");
88 : std::enable_shared_from_this<
StdExpansion>(T), m_base(T.m_base),
89 m_elmt_id(T.m_elmt_id), m_ncoeffs(T.m_ncoeffs),
90 m_stdMatrixManager(T.m_stdMatrixManager),
91 m_stdStaticCondMatrixManager(T.m_stdStaticCondMatrixManager)
140 return (val < 0.0) ? 0.0 :
sqrt(val);
165 for (i = 0; i < coordim; ++i)
168 Vmath::Vvtvp(ntot, wsp_deriv, 1, wsp_deriv, 1, sum, 1, sum, 1);
198 for (i = 0; i < nbdry; ++i)
200 for (j = 0; j < nbdry; ++j)
202 (*A)(i, j) = (*mat)(bmap[i], bmap[j]);
205 for (j = 0; j < nint; ++j)
207 (*B)(i, j) = (*mat)(bmap[i], imap[j]);
211 for (i = 0; i < nint; ++i)
213 for (j = 0; j < nbdry; ++j)
215 (*C)(i, j) = (*mat)(imap[i], bmap[j]);
218 for (j = 0; j < nint; ++j)
220 (*D)(i, j) = (*mat)(imap[i], imap[j]);
229 (*A) = (*A) - (*B) * (*C);
239 returnval->SetBlock(0, 0,
A);
240 returnval->SetBlock(0, 1, B);
241 returnval->SetBlock(1, 0, C);
242 returnval->SetBlock(1, 1, D);
318 returnval->GetRawPtr() + i * nq, 1);
331 for (i = 0; i < nq; ++i)
339 returnval->GetRawPtr() + i *
m_ncoeffs, 1);
352 for (i = 0; i < nq; ++i)
360 returnval->GetRawPtr() + i *
m_ncoeffs, 1);
373 for (i = 0; i < nq; ++i)
381 returnval->GetRawPtr() + i *
m_ncoeffs, 1);
394 for (i = 0; i < nq; ++i)
402 returnval->GetRawPtr() + i *
m_ncoeffs, 1);
433 int nummodes =
m_base[0]->GetNumModes();
434 bool equispaced =
true;
435 for (
int i = 1; i <
m_base.size(); ++i)
437 if (
m_base[i]->GetNumModes() != nummodes)
444 "Currently need to have same num modes in all "
445 "directionmodes to use EquiSpacedToCoeff method");
463 returnval->GetRawPtr() + i *
m_ncoeffs, 1);
510 "This type of matrix, " +
511 static_cast<std::string
>(
513 ", can not be created using a general approach");
590 "This matrix does not have an operator");
665 "This matrix does not have an operator");
731 varcoefftypes[k2][k1]))
800 for (i = 0; i < dim; ++i)
814 for (i = 0; i < dim; i++)
816 for (j = 0; j < dim; j++)
877 boost::ignore_unused(inarray, outarray, mkey);
889 for (
auto &x : varcoefftypes)
897 ASSERTL0(ndir,
"Must define at least one advection velocity");
899 "Number of constants is larger than coordinate dimensions");
910 for (i = 0; i < ndir; ++i)
914 1, tmp_adv, 1, tmp_adv, 1);
923 bool addDiffusionTerm)
930 for (
auto &x : varcoefftypes)
938 ASSERTL0(ndir,
"Must define at least one advection velocity");
940 "Number of constants is larger than coordinate dimensions");
952 for (i = 0; i < ndir; ++i)
956 1, tmp_adv, 1, tmp_adv, 1);
962 Vmath::Svtvp(totpts, -lambda, tmp, 1, tmp_adv, 1, tmp_adv, 1);
970 if (addDiffusionTerm)
1009 const std::vector<unsigned int> &nummodes,
int &modes_offset)
1011 boost::ignore_unused(nummodes, modes_offset);
1019 boost::ignore_unused(Fx, outarray);
1027 boost::ignore_unused(Fx, Fy, outarray);
1036 boost::ignore_unused(Fx, Fy, Fz, outarray);
1044 boost::ignore_unused(Fvec, outarray);
1051 boost::ignore_unused(mkey);
1059 boost::ignore_unused(mkey);
1067 boost::ignore_unused(dir, inarray, outarray);
1074 boost::ignore_unused(coeffs, dir);
1083 boost::ignore_unused(Lcoord, physvals);
1091 boost::ignore_unused(xi, eta);
1098 boost::ignore_unused(eta, xi);
1105 boost::ignore_unused(i, k);
1106 ASSERTL0(
false,
"This function is not valid or not defined");
1113 boost::ignore_unused(i, j);
1114 ASSERTL0(
false,
"This function is not valid or not defined");
1120 ASSERTL0(
false,
"This function is not valid or not defined");
1127 ASSERTL0(
false,
"This method is not defined for this expansion");
1134 ASSERTL0(
false,
"This method is not defined for this expansion");
1141 ASSERTL0(
false,
"This function has not been defined for this expansion");
1154 boost::ignore_unused(dir, inarray, outarray);
1166 boost::ignore_unused(direction, inarray, outarray);
1177 boost::ignore_unused(inarray, outarray);
1187 boost::ignore_unused(inarray);
1189 "local expansions");
1202 boost::ignore_unused(inarray, out_d1, out_d2, out_d3);
1204 "local expansions");
1210 boost::ignore_unused(inarray, out_ds);
1212 "local expansions");
1217 boost::ignore_unused(inarray, out_dn);
1219 "local expansions");
1232 boost::ignore_unused(dir, inarray, out_d0);
1234 "specific element types");
1246 boost::ignore_unused(inarray, direction, outarray);
1248 "specific element types");
1256 boost::ignore_unused(inarray, out_d1, out_d2, out_d3);
1264 boost::ignore_unused(dir, inarray, outarray);
1272 boost::ignore_unused(coords, physvals);
1281 boost::ignore_unused(I, physvals);
1289 boost::ignore_unused(coords, mode);
1297 std::array<NekDouble, 3> &firstOrderDerivs)
1299 boost::ignore_unused(coord, inarray, firstOrderDerivs);
1301 "PhysEvaluate first order derivative method does not exist"
1302 " for this shape type: " +
1303 static_cast<std::string
>(
1311 std::array<NekDouble, 3> &firstOrderDerivs,
1312 std::array<NekDouble, 6> &secondOrderDerivs)
1314 boost::ignore_unused(coord, inarray, firstOrderDerivs, secondOrderDerivs);
1316 "PhysEvaluate second order derivative method does not exist"
1317 " for this shape type: " +
1318 static_cast<std::string
>(
1325 boost::ignore_unused(mode, outarray);
1327 "been defined for this shape");
1332 boost::ignore_unused(mkey);
1334 "been defined for this element");
1341 boost::ignore_unused(mkey);
1343 "been defined for this element");
1352 boost::ignore_unused(coords_0, coords_1, coords_2);
1359 boost::ignore_unused(Lcoord, coord);
1370 boost::ignore_unused(outarray);
1376 boost::ignore_unused(outarray);
1382 boost::ignore_unused(localVertexId, useCoeffPacking);
1392 boost::ignore_unused(tid, maparray, signarray, traceOrient,
P, Q);
1399 boost::ignore_unused(traceid, maparray);
1409 boost::ignore_unused(tid, maparray, signarray, traceOrient,
P, Q);
1417 boost::ignore_unused(tid, maparray, signarray, traceOrient);
1424 boost::ignore_unused(tid, traceOrient, numModes0, numModes1);
1432 boost::ignore_unused(vertex, inarray, outarray);
1434 "this shape or library");
1448 boost::ignore_unused(inarray, outarray);
1450 "Method does not exist for this shape or library");
1457 boost::ignore_unused(inarray, outarray);
1465 boost::ignore_unused(inarray, outarray, multiplybyweights);
1477 boost::ignore_unused(direction, inarray, outarray);
1485 boost::ignore_unused(dir, inarray, outarray);
1510 boost::ignore_unused(array, mkey);
1511 ASSERTL0(
false,
"This function is not defined in StdExpansion.");
1519 boost::ignore_unused(array, alpha, exponent, cutoff);
1520 ASSERTL0(
false,
"This function is not defined in StdExpansion.");
1527 boost::ignore_unused(numMin, inarray, outarray);
1528 ASSERTL0(
false,
"This function is not defined in StdExpansion.");
1579 bool addDiffusionTerm)
1609 boost::ignore_unused(inarray, outarray, wsp);
1610 ASSERTL0(
false,
"Not implemented.");
1625 boost::ignore_unused(m_transformationmatrix);
1642 for (
int i = 0; i <
m_base.size(); ++i)
1644 nqbase =
m_base[i]->GetNumPoints();
1645 np = std::max(np, nqbase);
1665 out = (*intmat) * in;
1671 boost::ignore_unused(conn, standard);
1673 "GetSimplexEquiSpacedConnectivity not"
1674 " implemented for " +
1675 static_cast<std::string
>(
1696 out = (*intmat) * in;
#define ASSERTL0(condition, msg)
#define NEKERROR(type, msg)
Assert Level 0 – Fundamental assert which is used whether in FULLDEBUG, DEBUG or OPT compilation mode...
#define ASSERTL1(condition, msg)
Assert Level 1 – Debugging which is used whether in FULLDEBUG or DEBUG compilation mode....
#define ASSERTL2(condition, msg)
Assert Level 2 – Debugging which is used FULLDEBUG compilation mode. This level assert is designed to...
Describes the specification for a Basis.
Defines a specification for a set of points.
static std::shared_ptr< DataType > AllocateSharedPtr(const Args &...args)
Allocate a shared pointer from the memory pool.
The base class for all shapes.
void GetBoundaryMap(Array< OneD, unsigned int > &outarray)
virtual void v_LaplacianMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual int v_GetVertexMap(int localVertexId, bool useCoeffPacking=false)
virtual void v_LocCollapsedToLocCoord(const Array< OneD, const NekDouble > &eta, Array< OneD, NekDouble > &xi)
virtual ~StdExpansion()
Destructor.
virtual void v_PhysDeriv_n(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &out_dn)
virtual void v_PhysDirectionalDeriv(const Array< OneD, const NekDouble > &inarray, const Array< OneD, const NekDouble > &direction, Array< OneD, NekDouble > &outarray)
Physical derivative along a direction vector.
StdExpansion()
Default Constructor.
int GetNcoeffs(void) const
This function returns the total number of coefficients used in the expansion.
virtual void v_GetTraceToElementMap(const int tid, Array< OneD, unsigned int > &maparray, Array< OneD, int > &signarray, Orientation traceOrient=eForwards, int P=-1, int Q=-1)
int GetTotPoints() const
This function returns the total number of quadrature points used in the element.
virtual void v_GetCoord(const Array< OneD, const NekDouble > &Lcoord, Array< OneD, NekDouble > &coord)
void GeneralMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
void FillMode(const int mode, Array< OneD, NekDouble > &outarray)
This function fills the array outarray with the mode-th mode of the expansion.
virtual NekDouble v_StdPhysEvaluate(const Array< OneD, const NekDouble > &Lcoord, const Array< OneD, const NekDouble > &physvals)
void PhysInterpToSimplexEquiSpaced(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, int npset=-1)
This function performs an interpolation from the physical space points provided at input into an arra...
void WeakDirectionalDerivMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
void WeakDerivMatrixOp_MatFree(const int i, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
DNekBlkMatSharedPtr CreateStdStaticCondMatrix(const StdMatrixKey &mkey)
Create the static condensation of a matrix when using a boundary interior decomposition.
void LaplacianMatrixOp_MatFree_GenericImpl(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_IProductWRTDirectionalDerivBase_SumFac(const Array< OneD, const NekDouble > &direction, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
void HelmholtzMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
int NumBndryCoeffs(void) const
void MassLevelCurvatureMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_GetCoords(Array< OneD, NekDouble > &coords_0, Array< OneD, NekDouble > &coords_1, Array< OneD, NekDouble > &coords_2)
void LinearAdvectionDiffusionReactionMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey, bool addDiffusionTerm=true)
DNekMatSharedPtr GetStdMatrix(const StdMatrixKey &mkey)
virtual void v_GetElmtTraceToTraceMap(const unsigned int tid, Array< OneD, unsigned int > &maparray, Array< OneD, int > &signarray, Orientation traceOrient=eForwards, int P=-1, int Q=-1)
virtual void v_NormVectorIProductWRTBase(const Array< OneD, const NekDouble > &Fx, Array< OneD, NekDouble > &outarray)
virtual void v_GetSimplexEquiSpacedConnectivity(Array< OneD, int > &conn, bool standard=true)
virtual void v_SVVLaplacianFilter(Array< OneD, NekDouble > &array, const StdMatrixKey &mkey)
virtual std::shared_ptr< StdExpansion > v_GetLinStdExp(void) const
void WeakDerivMatrixOp(const int i, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_GetInteriorMap(Array< OneD, unsigned int > &outarray)
virtual void v_SetCoeffsToOrientation(StdRegions::Orientation dir, Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
NekDouble Linf(const Array< OneD, const NekDouble > &phys, const Array< OneD, const NekDouble > &sol=NullNekDouble1DArray)
Function to evaluate the discrete error where is given by the array sol.
void EquiSpacedToCoeffs(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
This function performs a projection/interpolation from the equispaced points sometimes used in post-p...
void MassMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_IProductWRTDerivBase(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual void v_HelmholtzMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_HelmholtzMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_WeakDirectionalDerivMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
void BwdTrans_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual NekDouble v_PhysEvaluate(const Array< OneD, const NekDouble > &coords, const Array< OneD, const NekDouble > &physvals)
virtual DNekMatSharedPtr v_BuildInverseTransformationMatrix(const DNekScalMatSharedPtr &m_transformationmatrix)
NekDouble L2(const Array< OneD, const NekDouble > &phys, const Array< OneD, const NekDouble > &sol=NullNekDouble1DArray)
Function to evaluate the discrete error, where is given by the array sol.
virtual void v_GetVertexPhysVals(const int vertex, const Array< OneD, const NekDouble > &inarray, NekDouble &outarray)
void IProductWRTDerivBase_SumFac(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
void LinearAdvectionMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
DNekMatSharedPtr CreateGeneralMatrix(const StdMatrixKey &mkey)
this function generates the mass matrix
virtual void v_MassLevelCurvatureMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_GetTraceCoeffMap(const unsigned int traceid, Array< OneD, unsigned int > &maparray)
virtual bool v_IsBoundaryInteriorExpansion() const
virtual void v_MultiplyByQuadratureMetric(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
void LaplacianMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_FillMode(const int mode, Array< OneD, NekDouble > &outarray)
void LaplacianMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_MultiplyByStdQuadratureMetric(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual void v_ExponentialFilter(Array< OneD, NekDouble > &array, const NekDouble alpha, const NekDouble exponent, const NekDouble cutoff)
void MassLevelCurvatureMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
LibUtilities::ShapeType DetShapeType() const
This function returns the shape of the expansion domain.
virtual void v_LaplacianMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_IProductWRTDerivBase_SumFac(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual DNekMatSharedPtr v_GenMatrix(const StdMatrixKey &mkey)
void GetInteriorMap(Array< OneD, unsigned int > &outarray)
virtual DNekMatSharedPtr v_CreateStdMatrix(const StdMatrixKey &mkey)
virtual void v_BwdTrans_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual void v_GetTraceNumModes(const int fid, int &numModes0, int &numModes1, Orientation traceOrient=eDir1FwdDir1_Dir2FwdDir2)
virtual void v_PhysDeriv_s(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &out_ds)
virtual void v_FwdTransBndConstrained(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual void v_GetBoundaryMap(Array< OneD, unsigned int > &outarray)
void GenStdMatBwdDeriv(const int dir, DNekMatSharedPtr &mat)
virtual void v_MassMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual const LibUtilities::PointsKey v_GetNodalPointsKey() const
virtual void v_WeakDerivMatrixOp(const int i, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
void LinearAdvectionDiffusionReactionMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey, bool addDiffusionTerm=true)
void IProductWRTBase_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, bool multiplybyweights=true)
virtual void v_LocCoordToLocCollapsed(const Array< OneD, const NekDouble > &xi, Array< OneD, NekDouble > &eta)
virtual NekDouble v_PhysEvaluateBasis(const Array< OneD, const NekDouble > &coords, int mode)
virtual void v_GetTraceInteriorToElementMap(const int eid, Array< OneD, unsigned int > &maparray, Array< OneD, int > &signarray, const Orientation traceOrient=eForwards)
virtual void v_IProductWRTBase(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)=0
Calculates the inner product of a given function f with the different modes of the expansion.
virtual int v_GetCoordim() const
virtual bool v_IsNodalNonTensorialExp()
virtual void v_LinearAdvectionDiffusionReactionMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey, bool addDiffusionTerm=true)
void HelmholtzMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_ReduceOrderCoeffs(int numMin, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual void v_DropLocStaticCondMatrix(const LocalRegions::MatrixKey &mkey)
void WeakDirectionalDerivMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_LaplacianMatrixOp_MatFree_Kernel(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, Array< OneD, NekDouble > &wsp)
NekDouble H1(const Array< OneD, const NekDouble > &phys, const Array< OneD, const NekDouble > &sol=NullNekDouble1DArray)
Function to evaluate the discrete error, where is given by the array sol.
virtual int v_CalcNumberOfCoefficients(const std::vector< unsigned int > &nummodes, int &modes_offset)
virtual NekDouble v_Integral(const Array< OneD, const NekDouble > &inarray)
Integrates the specified function over the domain.
void SVVLaplacianFilter(Array< OneD, NekDouble > &array, const StdMatrixKey &mkey)
virtual std::shared_ptr< StdExpansion > v_GetStdExp() const
void HelmholtzMatrixOp_MatFree_GenericImpl(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_BwdTrans(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)=0
int GetShapeDimension() const
virtual LibUtilities::PointsKey v_GetTracePointsKey(const int i, const int j) const
Array< OneD, LibUtilities::BasisSharedPtr > m_base
virtual void v_LinearAdvectionMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_IProductWRTBase_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, bool multiplybyweights=true)
virtual void v_IProductWRTDirectionalDerivBase(const Array< OneD, const NekDouble > &direction, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
void LinearAdvectionMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual void v_PhysDeriv(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &out_d1, Array< OneD, NekDouble > &out_d2, Array< OneD, NekDouble > &out_d3)
Calculate the derivative of the physical points.
virtual const LibUtilities::BasisKey v_GetTraceBasisKey(const int i, const int k) const
virtual void v_StdPhysDeriv(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &out_d1, Array< OneD, NekDouble > &out_d2, Array< OneD, NekDouble > &out_d3)
NekDouble StdPhysEvaluate(const Array< OneD, const NekDouble > &Lcoord, const Array< OneD, const NekDouble > &physvals)
void MassMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
void GeneralMatrixOp_MatFree(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdMatrixKey &mkey)
virtual DNekScalBlkMatSharedPtr v_GetLocStaticCondMatrix(const LocalRegions::MatrixKey &mkey)
LibUtilities::ShapeType GetShapeType() const
const VarCoeffMap & GetVarCoeffs() const
MatrixType GetMatrixType() const
bool HasVarCoeff(const StdRegions::VarCoeffType &coeff) const
LibUtilities::PointsType GetNodalPointsType() const
const ConstFactorMap & GetConstFactors() const
const Array< OneD, const NekDouble > & GetVarCoeff(const StdRegions::VarCoeffType &coeff) const
NekDouble GetConstFactor(const ConstFactorType &factor) const
bool ConstFactorExists(const ConstFactorType &factor) const
static void Daxpy(const int &n, const double &alpha, const double *x, const int &incx, const double *y, const int &incy)
BLAS level 1: y = alpha x plus y.
const char *const ShapeTypeMap[SIZE_ShapeType]
BasisManagerT & BasisManager(void)
static const BasisKey NullBasisKey(eNoBasisType, 0, NullPointsKey)
Defines a null basis with no type or points.
int GetNumberOfCoefficients(ShapeType shape, std::vector< unsigned int > &modes, int offset=0)
@ P
Monomial polynomials .
static const PointsKey NullPointsKey(0, eNoPointsType)
std::shared_ptr< StdExpansion > StdExpansionSharedPtr
@ eLinearAdvectionReaction
@ eLinearAdvectionDiffusionReaction
@ ePhysInterpToEquiSpaced
const char *const MatrixTypeMap[]
std::map< ConstFactorType, NekDouble > ConstFactorMap
static ConstFactorMap NullConstFactorMap
static VarCoeffMap NullVarCoeffMap
std::shared_ptr< StdMatrixKey > StdMatrixKeySharedPtr
The above copyright notice and this permission notice shall be included.
std::shared_ptr< DNekScalMat > DNekScalMatSharedPtr
std::shared_ptr< DNekBlkMat > DNekBlkMatSharedPtr
static DNekScalBlkMatSharedPtr NullDNekScalBlkMatSharedPtr
std::shared_ptr< DNekScalBlkMat > DNekScalBlkMatSharedPtr
static DNekMatSharedPtr NullDNekMatSharedPtr
static Array< OneD, NekDouble > NullNekDouble1DArray
std::shared_ptr< DNekMat > DNekMatSharedPtr
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.
void Svtvp(int n, const T alpha, const T *x, const int incx, const T *y, const int incy, T *z, const int incz)
svtvp (scalar times vector plus vector): z = alpha*x + y
void Vabs(int n, const T *x, const int incx, T *y, const int incy)
vabs: y = |x|
void Vvtvp(int n, const T *w, const int incw, const T *x, const int incx, const T *y, const int incy, T *z, const int incz)
vvtvp (vector times vector plus vector): z = w*x + y
void Vadd(int n, const T *x, const int incx, const T *y, const int incy, T *z, const int incz)
Add vector z = x+y.
void Smul(int n, const T alpha, const T *x, const int incx, T *y, const int incy)
Scalar multiply y = alpha*x.
void Zero(int n, T *x, const int incx)
Zero vector.
T Vamax(int n, const T *x, const int incx)
Return the maximum absolute element in x called vamax to avoid conflict with max.
void Vcopy(int n, const T *x, const int incx, T *y, const int incy)
void Vsub(int n, const T *x, const int incx, const T *y, const int incy, T *z, const int incz)
Subtract vector z = x-y.
scalarT< T > sqrt(scalarT< T > in)