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 
40 #include <SpatialDomains/TriGeom.h>
42 
45 #include <LocalRegions/MatrixKey.h>
46 
47 namespace Nektar
48 {
49 namespace LocalRegions
50 {
51 
52 class NodalTriExp final : virtual public StdRegions::StdNodalTriExp,
53  virtual public Expansion2D
54 {
55 public:
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,
74  Array<OneD, NekDouble> &coords);
75 
76  //----------------------------
77  // Integration Methods
78  //----------------------------
79 
80  /// \brief Integrate the physical point list \a inarray over region
82  Integral(const Array<OneD, const NekDouble> &inarray);
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 
168 protected:
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 
196 private:
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 */
225  virtual void v_IProductWRTBase(const Array<OneD, const NekDouble> &inarray,
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,
241  Array<OneD, NekDouble> &out_d2 = NullNekDouble1DArray) override
242  {
243  StdTriExp::v_PhysDeriv(inarray, out_d0, out_d1, out_d2);
244  }
245 
247  const Array<OneD, const NekDouble> &inarray,
249  Array<OneD, NekDouble> &out_d2 = NullNekDouble1DArray) override
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 
317  virtual void v_BwdTrans_SumFac(const Array<OneD, const NekDouble> &inarray,
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 
350  virtual void v_LaplacianMatrixOp(
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 
358  virtual void v_LaplacianMatrixOp(
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 
366  virtual void v_WeakDerivMatrixOp(
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 
374  virtual void v_HelmholtzMatrixOp(
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 
385 typedef std::shared_ptr<NodalTriExp> NodalTriExpSharedPtr;
386 typedef 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:50
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 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 v_AlignVectorToCollapsedDir(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, Array< OneD, NekDouble >> &outarray) override
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