Nektar++
NodalTriExp.h
Go to the documentation of this file.
1///////////////////////////////////////////////////////////////////////////////
2//
3// File: NodalTriExp.h
4//
5// For more information, please see: http://www.nektar.info
6//
7// The MIT License
8//
9// Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
10// Department of Aeronautics, Imperial College London (UK), and Scientific
11// Computing and Imaging Institute, University of Utah (USA).
12//
13// Permission is hereby granted, free of charge, to any person obtaining a
14// copy of this software and associated documentation files (the "Software"),
15// to deal in the Software without restriction, including without limitation
16// the rights to use, copy, modify, merge, publish, distribute, sublicense,
17// and/or sell copies of the Software, and to permit persons to whom the
18// Software is furnished to do so, subject to the following conditions:
19//
20// The above copyright notice and this permission notice shall be included
21// in all copies or substantial portions of the Software.
22//
23// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
24// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
26// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
28// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
29// DEALINGS IN THE SOFTWARE.
30//
31// Description: Header for NodalTriExp routines
32//
33///////////////////////////////////////////////////////////////////////////////
34
35#ifndef NODALTRIEXP_H
36#define NODALTRIEXP_H
37
38#include <boost/core/ignore_unused.hpp>
39
42
46
47namespace Nektar
48{
49namespace LocalRegions
50{
51
52class NodalTriExp final : virtual public StdRegions::StdNodalTriExp,
53 virtual public Expansion2D
54{
55public:
56 /** \brief Constructor using BasisKey class for quadrature
57 points and order definition */
60 const LibUtilities::PointsType Ntype,
62
63 /// Copy Constructor
65
66 /// Destructor
67 LOCAL_REGIONS_EXPORT virtual ~NodalTriExp() override = default;
68
73 const Array<OneD, const NekDouble> &Lcoords,
75
76 //----------------------------
77 // Integration Methods
78 //----------------------------
79
80 /// \brief Integrate the physical point list \a inarray over region
83
84 /** \brief Inner product of \a inarray over region with respect to the
85 expansion basis (this)->_Base[0] and return in \a outarray */
87 Array<OneD, NekDouble> &outarray)
88 {
89 NodalTriExp::IProductWRTBase_SumFac(inarray, outarray);
90 }
91
92 void IProductWRTDerivBase(const int dir,
93 const Array<OneD, const NekDouble> &inarray,
94 Array<OneD, NekDouble> &outarray)
95 {
96 NodalTriExp::IProductWRTDerivBase_SumFac(dir, inarray, outarray);
97 }
98
99 //-----------------------------
100 // Differentiation Methods
101 //-----------------------------
102
104 const Array<OneD, const NekDouble> &inarray,
107
108 //----------------------------
109 // Evaluations Methods
110 //---------------------------
111
112 /** \brief Forward transform from physical quadrature space
113 stored in \a inarray and evaluate the expansion coefficients and
114 store in \a (this)->_coeffs */
116 const Array<OneD, const NekDouble> &inarray,
117 Array<OneD, NekDouble> &outarray);
118
121 const Array<OneD, const NekDouble> &physvals);
122
124 Array<OneD, NekDouble> &outarray,
125 const StdRegions::StdMatrixKey &mkey)
126 {
127 StdExpansion::MassMatrixOp_MatFree(inarray, outarray, mkey);
128 }
129
132 const Array<OneD, const NekDouble> &inarray,
133 std::array<NekDouble, 3> &firstOrderDerivs) final;
134
136 Array<OneD, NekDouble> &outarray,
137 const StdRegions::StdMatrixKey &mkey)
138 {
139 StdExpansion::LaplacianMatrixOp_MatFree_GenericImpl(inarray, outarray,
140 mkey);
141 }
142
143 void LaplacianMatrixOp(const int k1, const int k2,
144 const Array<OneD, const NekDouble> &inarray,
145 Array<OneD, NekDouble> &outarray,
146 const StdRegions::StdMatrixKey &mkey)
147 {
148 StdExpansion::LaplacianMatrixOp_MatFree(k1, k2, inarray, outarray,
149 mkey);
150 }
151
152 void WeakDerivMatrixOp(const int i,
153 const Array<OneD, const NekDouble> &inarray,
154 Array<OneD, NekDouble> &outarray,
155 const StdRegions::StdMatrixKey &mkey)
156 {
157 StdExpansion::WeakDerivMatrixOp_MatFree(i, inarray, outarray, mkey);
158 }
159
161 Array<OneD, NekDouble> &outarray,
162 const StdRegions::StdMatrixKey &mkey)
163 {
164 StdExpansion::HelmholtzMatrixOp_MatFree_GenericImpl(inarray, outarray,
165 mkey);
166 }
167
168protected:
170
172 Array<OneD, NekDouble> &outarray,
173 bool multiplybyweights = true);
175 Array<OneD, NekDouble> &outarray);
176
178 const int dir, const Array<OneD, const NekDouble> &inarray,
179 Array<OneD, NekDouble> &outarray);
180 void IProductWRTDerivBase_MatOp(const int dir,
181 const Array<OneD, const NekDouble> &inarray,
182 Array<OneD, NekDouble> &outarray);
183
185 Array<OneD, NekDouble> &outarray,
186 const StdRegions::StdMatrixKey &mkey);
187
188 virtual StdRegions::StdExpansionSharedPtr v_GetStdExp(void) const override;
189
191 void) const override;
192
194 const StdRegions::StdMatrixKey &mkey) override;
195
196private:
201
202 virtual void v_GetCoords(
203 Array<OneD, NekDouble> &coords_0,
205 Array<OneD, NekDouble> &coords_2 = NullNekDouble1DArray) override
206 {
207 GetCoords(coords_0, coords_1, coords_2);
208 }
209
210 virtual void v_GetCoord(const Array<OneD, const NekDouble> &lcoord,
211 Array<OneD, NekDouble> &coord) override
212 {
213 GetCoord(lcoord, coord);
214 }
215
216 /** \brief Virtual call to integrate the physical point list \a inarray
217 over region (see SegExp::Integral) */
219 const Array<OneD, const NekDouble> &inarray) override
220 {
221 return Integral(inarray);
222 }
223
224 /** \brief Virtual call to TriExp::IProduct_WRT_B */
226 Array<OneD, NekDouble> &outarray) override
227 {
228 IProductWRTBase(inarray, outarray);
229 }
230
232 const int dir, const Array<OneD, const NekDouble> &inarray,
233 Array<OneD, NekDouble> &outarray) override
234 {
235 IProductWRTDerivBase(dir, inarray, outarray);
236 }
237
239 const Array<OneD, const NekDouble> &inarray,
242 {
243 StdTriExp::v_PhysDeriv(inarray, out_d0, out_d1, out_d2);
244 }
245
247 const Array<OneD, const NekDouble> &inarray,
250 {
251 boost::ignore_unused(out_d2);
252 PhysDeriv(inarray, out_d0, out_d1);
253 }
254
255 virtual void v_PhysDeriv(const int dir,
256 const Array<OneD, const NekDouble> &inarray,
257 Array<OneD, NekDouble> &outarray) override
258 {
260 switch (dir)
261 {
262 case 0:
263 {
264 PhysDeriv(inarray, outarray, tmp);
265 }
266 break;
267 case 1:
268 {
269 PhysDeriv(inarray, tmp, outarray);
270 }
271 break;
272 default:
273 {
274 ASSERTL1(dir >= 0 && dir < 2, "input dir is out of range");
275 }
276 break;
277 }
278 }
279
280 /// Virtual call to SegExp::FwdTrans
281 virtual void v_FwdTrans(const Array<OneD, const NekDouble> &inarray,
282 Array<OneD, NekDouble> &outarray) override
283 {
284 FwdTrans(inarray, outarray);
285 }
286
287 /// Virtual call to TriExp::Evaluate
289 const Array<OneD, const NekDouble> &coord,
290 const Array<OneD, const NekDouble> &physvals) override
291 {
292 return PhysEvaluate(coord, physvals);
293 }
294
296 const StdRegions::StdMatrixKey &mkey) override
297 {
298 return CreateStdMatrix(mkey);
299 }
300
301 virtual DNekScalMatSharedPtr v_GetLocMatrix(const MatrixKey &mkey) override
302 {
303 return m_matrixManager[mkey];
304 }
305
306 virtual void v_DropLocMatrix(const MatrixKey &mkey) override
307 {
308 m_matrixManager.DeleteObject(mkey);
309 }
310
312 const MatrixKey &mkey) override
313 {
314 return m_staticCondMatrixManager[mkey];
315 }
316
318 Array<OneD, NekDouble> &outarray) override
319 {
320 StdNodalTriExp::v_BwdTrans_SumFac(inarray, outarray);
321 }
322
324 const Array<OneD, const NekDouble> &inarray,
325 Array<OneD, NekDouble> &outarray,
326 bool multiplybyweights = true) override
327 {
328 boost::ignore_unused(multiplybyweights);
329 IProductWRTBase_SumFac(inarray, outarray);
330 }
331
333 const int dir, const Array<OneD, const NekDouble> &inarray,
334 Array<OneD, NekDouble> &outarray) override
335 {
336 IProductWRTDerivBase_SumFac(dir, inarray, outarray);
337 }
338
340 const int dir, const Array<OneD, const NekDouble> &inarray,
341 Array<OneD, Array<OneD, NekDouble>> &outarray) override;
342
343 virtual void v_MassMatrixOp(const Array<OneD, const NekDouble> &inarray,
344 Array<OneD, NekDouble> &outarray,
345 const StdRegions::StdMatrixKey &mkey) override
346 {
347 MassMatrixOp(inarray, outarray, mkey);
348 }
349
351 const Array<OneD, const NekDouble> &inarray,
352 Array<OneD, NekDouble> &outarray,
353 const StdRegions::StdMatrixKey &mkey) override
354 {
355 LaplacianMatrixOp(inarray, outarray, mkey);
356 }
357
359 const int k1, const int k2, const Array<OneD, const NekDouble> &inarray,
360 Array<OneD, NekDouble> &outarray,
361 const StdRegions::StdMatrixKey &mkey) override
362 {
363 LaplacianMatrixOp(k1, k2, inarray, outarray, mkey);
364 }
365
367 const int i, const Array<OneD, const NekDouble> &inarray,
368 Array<OneD, NekDouble> &outarray,
369 const StdRegions::StdMatrixKey &mkey) override
370 {
371 WeakDerivMatrixOp(i, inarray, outarray, mkey);
372 }
373
375 const Array<OneD, const NekDouble> &inarray,
376 Array<OneD, NekDouble> &outarray,
377 const StdRegions::StdMatrixKey &mkey) override
378 {
379 HelmholtzMatrixOp(inarray, outarray, mkey);
380 }
381
382 void v_ComputeTraceNormal(const int edge) override;
383};
384
385typedef std::shared_ptr<NodalTriExp> NodalTriExpSharedPtr;
386typedef std::vector<NodalTriExpSharedPtr> NodalTriExpVector;
387
388} // namespace LocalRegions
389} // namespace Nektar
390
391#endif // NODALTRIEXP_H
#define ASSERTL1(condition, msg)
Assert Level 1 – Debugging which is used whether in FULLDEBUG or DEBUG compilation mode....
Definition: ErrorUtil.hpp:249
#define LOCAL_REGIONS_EXPORT
Describes the specification for a Basis.
Definition: Basis.h:47
LibUtilities::NekManager< MatrixKey, DNekScalMat, MatrixKey::opLess > m_matrixManager
Definition: NodalTriExp.h:198
void v_IProductWRTDerivBase_SumFac(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray) override
Definition: NodalTriExp.h:332
virtual void v_IProductWRTBase(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray) override
Virtual call to TriExp::IProduct_WRT_B.
Definition: NodalTriExp.h:225
virtual void v_PhysDeriv(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray) override
Calculate the derivative of the physical points in a given direction.
Definition: NodalTriExp.h:255
void v_PhysDeriv(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &out_d0, Array< OneD, NekDouble > &out_d1, Array< OneD, NekDouble > &out_d2=NullNekDouble1DArray) override
Calculate the derivative of the physical points.
Definition: NodalTriExp.h:246
void GetCoord(const Array< OneD, const NekDouble > &Lcoords, Array< OneD, NekDouble > &coords)
virtual NekDouble v_PhysEvaluate(const Array< OneD, const NekDouble > &coord, const Array< OneD, const NekDouble > &physvals) override
Virtual call to TriExp::Evaluate.
Definition: NodalTriExp.h:288
void PhysDeriv(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &out_d0, Array< OneD, NekDouble > &out_d1, Array< OneD, NekDouble > &out_d2=NullNekDouble1DArray)
Differentiation Methods.
void v_StdPhysDeriv(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &out_d0, Array< OneD, NekDouble > &out_d1, Array< OneD, NekDouble > &out_d2=NullNekDouble1DArray) override
Definition: NodalTriExp.h:238
DNekMatSharedPtr CreateStdMatrix(const StdRegions::StdMatrixKey &mkey)
virtual DNekMatSharedPtr v_GenMatrix(const StdRegions::StdMatrixKey &mkey) override
NekDouble v_PhysEvaluate(const Array< OneD, NekDouble > &coord, const Array< OneD, const NekDouble > &inarray, std::array< NekDouble, 3 > &firstOrderDerivs) final
void LaplacianMatrixOp(const int k1, const int k2, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:143
virtual void v_LaplacianMatrixOp(const int k1, const int k2, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey) override
Definition: NodalTriExp.h:358
void v_AlignVectorToCollapsedDir(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, Array< OneD, NekDouble > > &outarray) override
void WeakDerivMatrixOp(const int i, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:152
void GetCoords(Array< OneD, NekDouble > &coords_1, Array< OneD, NekDouble > &coords_2, Array< OneD, NekDouble > &coords_3=NullNekDouble1DArray)
void GeneralMatrixOp_MatOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
void IProductWRTBase(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Inner product of inarray over region with respect to the expansion basis (this)->_Base[0] and return ...
Definition: NodalTriExp.h:86
void IProductWRTDerivBase_MatOp(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
LibUtilities::NekManager< MatrixKey, DNekScalBlkMat, MatrixKey::opLess > m_staticCondMatrixManager
Definition: NodalTriExp.h:200
virtual void v_LaplacianMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey) override
Definition: NodalTriExp.h:350
virtual void v_GetCoords(Array< OneD, NekDouble > &coords_0, Array< OneD, NekDouble > &coords_1=NullNekDouble1DArray, Array< OneD, NekDouble > &coords_2=NullNekDouble1DArray) override
Definition: NodalTriExp.h:202
void FwdTrans(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Forward transform from physical quadrature space stored in inarray and evaluate the expansion coeffic...
void LaplacianMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:135
virtual DNekScalMatSharedPtr v_GetLocMatrix(const MatrixKey &mkey) override
Definition: NodalTriExp.h:301
virtual void v_GetCoord(const Array< OneD, const NekDouble > &lcoord, Array< OneD, NekDouble > &coord) override
Definition: NodalTriExp.h:210
virtual void v_FwdTrans(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray) override
Virtual call to SegExp::FwdTrans.
Definition: NodalTriExp.h:281
virtual DNekMatSharedPtr v_CreateStdMatrix(const StdRegions::StdMatrixKey &mkey) override
Definition: NodalTriExp.h:295
void IProductWRTDerivBase_SumFac(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
void IProductWRTDerivBase(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Definition: NodalTriExp.h:92
NekDouble PhysEvaluate(const Array< OneD, const NekDouble > &coord, const Array< OneD, const NekDouble > &physvals)
virtual DNekScalBlkMatSharedPtr v_GetLocStaticCondMatrix(const MatrixKey &mkey) override
Definition: NodalTriExp.h:311
virtual StdRegions::StdExpansionSharedPtr v_GetStdExp(void) const override
NekDouble Integral(const Array< OneD, const NekDouble > &inarray)
Integrate the physical point list inarray over region.
Definition: NodalTriExp.cpp:93
void IProductWRTBase_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, bool multiplybyweights=true)
void MassMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:123
virtual void v_BwdTrans_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray) override
Definition: NodalTriExp.h:317
virtual NekDouble v_Integral(const Array< OneD, const NekDouble > &inarray) override
Virtual call to integrate the physical point list inarray over region (see SegExp::Integral)
Definition: NodalTriExp.h:218
virtual void v_IProductWRTBase_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, bool multiplybyweights=true) override
Definition: NodalTriExp.h:323
void IProductWRTBase_MatOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual StdRegions::StdExpansionSharedPtr v_GetLinStdExp(void) const override
virtual void v_IProductWRTDerivBase(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray) override
Definition: NodalTriExp.h:231
virtual void v_DropLocMatrix(const MatrixKey &mkey) override
Definition: NodalTriExp.h:306
virtual void v_MassMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey) override
Definition: NodalTriExp.h:343
NodalTriExp(const LibUtilities::BasisKey &Ba, const LibUtilities::BasisKey &Bb, const LibUtilities::PointsType Ntype, const SpatialDomains::TriGeomSharedPtr &geom)
Constructor using BasisKey class for quadrature points and order definition.
Definition: NodalTriExp.cpp:44
virtual ~NodalTriExp() override=default
Destructor.
virtual void v_WeakDerivMatrixOp(const int i, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey) override
Definition: NodalTriExp.h:366
void HelmholtzMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:160
void v_ComputeTraceNormal(const int edge) override
virtual void v_HelmholtzMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey) override
Definition: NodalTriExp.h:374
std::shared_ptr< NodalTriExp > NodalTriExpSharedPtr
Definition: NodalTriExp.h:385
std::vector< NodalTriExpSharedPtr > NodalTriExpVector
Definition: NodalTriExp.h:386
std::shared_ptr< TriGeom > TriGeomSharedPtr
Definition: TriGeom.h:58
std::shared_ptr< StdExpansion > StdExpansionSharedPtr
The above copyright notice and this permission notice shall be included.
Definition: CoupledSolver.h:2
std::shared_ptr< DNekScalMat > DNekScalMatSharedPtr
std::shared_ptr< DNekScalBlkMat > DNekScalBlkMatSharedPtr
Definition: NekTypeDefs.hpp:79
static Array< OneD, NekDouble > NullNekDouble1DArray
std::shared_ptr< DNekMat > DNekMatSharedPtr
Definition: NekTypeDefs.hpp:75
double NekDouble