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 : 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
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 
131  Array<OneD, NekDouble> &outarray,
132  const StdRegions::StdMatrixKey &mkey)
133  {
134  StdExpansion::LaplacianMatrixOp_MatFree_GenericImpl(inarray, outarray,
135  mkey);
136  }
137 
138  void LaplacianMatrixOp(const int k1, const int k2,
139  const Array<OneD, const NekDouble> &inarray,
140  Array<OneD, NekDouble> &outarray,
141  const StdRegions::StdMatrixKey &mkey)
142  {
143  StdExpansion::LaplacianMatrixOp_MatFree(k1, k2, inarray, outarray,
144  mkey);
145  }
146 
147  void WeakDerivMatrixOp(const int i,
148  const Array<OneD, const NekDouble> &inarray,
149  Array<OneD, NekDouble> &outarray,
150  const StdRegions::StdMatrixKey &mkey)
151  {
152  StdExpansion::WeakDerivMatrixOp_MatFree(i, inarray, outarray, mkey);
153  }
154 
156  Array<OneD, NekDouble> &outarray,
157  const StdRegions::StdMatrixKey &mkey)
158  {
159  StdExpansion::HelmholtzMatrixOp_MatFree_GenericImpl(inarray, outarray,
160  mkey);
161  }
162 
163 protected:
165 
167  Array<OneD, NekDouble> &outarray,
168  bool multiplybyweights = true);
170  Array<OneD, NekDouble> &outarray);
171 
173  const int dir, const Array<OneD, const NekDouble> &inarray,
174  Array<OneD, NekDouble> &outarray);
175  void IProductWRTDerivBase_MatOp(const int dir,
176  const Array<OneD, const NekDouble> &inarray,
177  Array<OneD, NekDouble> &outarray);
178 
180  Array<OneD, NekDouble> &outarray,
181  const StdRegions::StdMatrixKey &mkey);
182 
184 
186 
188 
189 private:
194 
195  // virtual StdRegions::ExpansionType v_DetExpansionType() const
196  //{
197  // return DetExpansionType();
198  //}
199 
201  {
202  return StdNodalTriExp::GenNBasisTransMatrix();
203  }
204 
205  virtual void v_GetCoords(
206  Array<OneD, NekDouble> &coords_0,
209  {
210  GetCoords(coords_0, coords_1, coords_2);
211  }
212 
213  virtual void v_GetCoord(const Array<OneD, const NekDouble> &lcoord,
214  Array<OneD, NekDouble> &coord)
215  {
216  GetCoord(lcoord, coord);
217  }
218 
221  {
222  return StdNodalTriExp::GetNodalPoints(x, y);
223  }
224 
225  /** \brief Virtual call to integrate the physical point list \a inarray
226  over region (see SegExp::Integral) */
228  {
229  return Integral(inarray);
230  }
231 
232  /** \brief Virtual call to TriExp::IProduct_WRT_B */
233  virtual void v_IProductWRTBase(const Array<OneD, const NekDouble> &inarray,
234  Array<OneD, NekDouble> &outarray)
235  {
236  IProductWRTBase(inarray, outarray);
237  }
238 
240  const int dir, const Array<OneD, const NekDouble> &inarray,
241  Array<OneD, NekDouble> &outarray)
242  {
243  IProductWRTDerivBase(dir, inarray, outarray);
244  }
245 
246  virtual void v_StdPhysDeriv(
247  const Array<OneD, const NekDouble> &inarray,
250  {
251  StdTriExp::v_PhysDeriv(inarray, out_d0, out_d1, out_d2);
252  }
253 
254  virtual void v_PhysDeriv(
255  const Array<OneD, const NekDouble> &inarray,
258  {
259  boost::ignore_unused(out_d2);
260  PhysDeriv(inarray, out_d0, out_d1);
261  }
262 
263  virtual void v_PhysDeriv(const int dir,
264  const Array<OneD, const NekDouble> &inarray,
265  Array<OneD, NekDouble> &outarray)
266  {
268  switch (dir)
269  {
270  case 0:
271  {
272  PhysDeriv(inarray, outarray, tmp);
273  }
274  break;
275  case 1:
276  {
277  PhysDeriv(inarray, tmp, outarray);
278  }
279  break;
280  default:
281  {
282  ASSERTL1(dir >= 0 && dir < 2, "input dir is out of range");
283  }
284  break;
285  }
286  }
287 
288  /// Virtual call to SegExp::FwdTrans
289  virtual void v_FwdTrans(const Array<OneD, const NekDouble> &inarray,
290  Array<OneD, NekDouble> &outarray)
291  {
292  FwdTrans(inarray, outarray);
293  }
294 
295  /// Virtual call to TriExp::Evaluate
297  const Array<OneD, const NekDouble> &coord,
298  const Array<OneD, const NekDouble> &physvals)
299 
300  {
301  return PhysEvaluate(coord, physvals);
302  }
303 
305  const StdRegions::StdMatrixKey &mkey)
306  {
307  return CreateStdMatrix(mkey);
308  }
309 
311  {
312  return m_matrixManager[mkey];
313  }
314 
315  // virtual DNekScalMatSharedPtr v_GetLocMatrix(const
316  // StdRegions::MatrixType mtype, NekDouble lambdaval, NekDouble
317  // tau)
318  // {
319  // MatrixKey
320  // mkey(mtype,DetExpansionType(),*this,lambdaval,tau); return
321  // m_matrixManager[mkey];
322  // }
323 
325  const MatrixKey &mkey)
326  {
327  return m_staticCondMatrixManager[mkey];
328  }
329 
330  virtual void v_BwdTrans_SumFac(const Array<OneD, const NekDouble> &inarray,
331  Array<OneD, NekDouble> &outarray)
332  {
333  StdNodalTriExp::v_BwdTrans_SumFac(inarray, outarray);
334  }
335 
337  const Array<OneD, const NekDouble> &inarray,
338  Array<OneD, NekDouble> &outarray, bool multiplybyweights = true)
339  {
340  boost::ignore_unused(multiplybyweights);
341  IProductWRTBase_SumFac(inarray, outarray);
342  }
343 
345  const int dir, const Array<OneD, const NekDouble> &inarray,
346  Array<OneD, NekDouble> &outarray)
347  {
348  IProductWRTDerivBase_SumFac(dir, inarray, outarray);
349  }
350 
351  virtual void v_AlignVectorToCollapsedDir(
352  const int dir, const Array<OneD, const NekDouble> &inarray,
353  Array<OneD, Array<OneD, NekDouble>> &outarray);
354 
355  virtual void v_MassMatrixOp(const Array<OneD, const NekDouble> &inarray,
356  Array<OneD, NekDouble> &outarray,
357  const StdRegions::StdMatrixKey &mkey)
358  {
359  MassMatrixOp(inarray, outarray, mkey);
360  }
361 
362  virtual void v_LaplacianMatrixOp(
363  const Array<OneD, const NekDouble> &inarray,
364  Array<OneD, NekDouble> &outarray, const StdRegions::StdMatrixKey &mkey)
365  {
366  LaplacianMatrixOp(inarray, outarray, mkey);
367  }
368 
369  virtual void v_LaplacianMatrixOp(
370  const int k1, const int k2, const Array<OneD, const NekDouble> &inarray,
371  Array<OneD, NekDouble> &outarray, const StdRegions::StdMatrixKey &mkey)
372  {
373  LaplacianMatrixOp(k1, k2, inarray, outarray, mkey);
374  }
375 
376  virtual void v_WeakDerivMatrixOp(
377  const int i, const Array<OneD, const NekDouble> &inarray,
378  Array<OneD, NekDouble> &outarray, const StdRegions::StdMatrixKey &mkey)
379  {
380  WeakDerivMatrixOp(i, inarray, outarray, mkey);
381  }
382 
383  virtual void v_HelmholtzMatrixOp(
384  const Array<OneD, const NekDouble> &inarray,
385  Array<OneD, NekDouble> &outarray, const StdRegions::StdMatrixKey &mkey)
386  {
387  HelmholtzMatrixOp(inarray, outarray, mkey);
388  }
389 
390  void v_ComputeTraceNormal(const int edge);
391 };
392 
393 typedef std::shared_ptr<NodalTriExp> NodalTriExpSharedPtr;
394 typedef std::vector<NodalTriExpSharedPtr> NodalTriExpVector;
395 
396 } // namespace LocalRegions
397 } // namespace Nektar
398 
399 #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:191
virtual void v_GetCoord(const Array< OneD, const NekDouble > &lcoord, Array< OneD, NekDouble > &coord)
Definition: NodalTriExp.h:213
virtual void v_BwdTrans_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Definition: NodalTriExp.h:330
virtual void v_PhysDeriv(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Calculate the derivative of the physical points in a given direction.
Definition: NodalTriExp.h:263
virtual void v_FwdTrans(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Virtual call to SegExp::FwdTrans.
Definition: NodalTriExp.h:289
virtual void v_HelmholtzMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:383
void GetCoord(const Array< OneD, const NekDouble > &Lcoords, Array< OneD, NekDouble > &coords)
virtual void v_LaplacianMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:362
virtual DNekScalMatSharedPtr v_GetLocMatrix(const MatrixKey &mkey)
Definition: NodalTriExp.h:310
virtual void v_AlignVectorToCollapsedDir(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, Array< OneD, NekDouble >> &outarray)
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.
virtual void v_IProductWRTBase(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Virtual call to TriExp::IProduct_WRT_B.
Definition: NodalTriExp.h:233
DNekMatSharedPtr CreateStdMatrix(const StdRegions::StdMatrixKey &mkey)
virtual void v_IProductWRTBase_SumFac(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, bool multiplybyweights=true)
Definition: NodalTriExp.h:336
virtual void v_IProductWRTDerivBase_SumFac(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Definition: NodalTriExp.h:344
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:138
void WeakDerivMatrixOp(const int i, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:147
virtual 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)
Calculate the derivative of the physical points.
Definition: NodalTriExp.h:254
void GetCoords(Array< OneD, NekDouble > &coords_1, Array< OneD, NekDouble > &coords_2, Array< OneD, NekDouble > &coords_3=NullNekDouble1DArray)
virtual void v_IProductWRTDerivBase(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
Definition: NodalTriExp.h:239
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
virtual NekDouble v_PhysEvaluate(const Array< OneD, const NekDouble > &coord, const Array< OneD, const NekDouble > &physvals)
Virtual call to TriExp::Evaluate.
Definition: NodalTriExp.h:296
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:193
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...
virtual DNekMatSharedPtr v_GenNBasisTransMatrix()
Definition: NodalTriExp.h:200
void LaplacianMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:130
void IProductWRTDerivBase_SumFac(const int dir, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual NekDouble v_Integral(const Array< OneD, const NekDouble > &inarray)
Virtual call to integrate the physical point list inarray over region (see SegExp::Integral)
Definition: NodalTriExp.h:227
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 void v_MassMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:355
NekDouble Integral(const Array< OneD, const NekDouble > &inarray)
Integrate the physical point list inarray over region.
Definition: NodalTriExp.cpp:95
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_GetNodalPoints(Array< OneD, const NekDouble > &x, Array< OneD, const NekDouble > &y)
Definition: NodalTriExp.h:219
virtual DNekMatSharedPtr v_CreateStdMatrix(const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:304
virtual DNekScalBlkMatSharedPtr v_GetLocStaticCondMatrix(const MatrixKey &mkey)
Definition: NodalTriExp.h:324
virtual void v_GetCoords(Array< OneD, NekDouble > &coords_0, Array< OneD, NekDouble > &coords_1=NullNekDouble1DArray, Array< OneD, NekDouble > &coords_2=NullNekDouble1DArray)
Definition: NodalTriExp.h:205
virtual void v_LaplacianMatrixOp(const int k1, const int k2, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:369
virtual 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)
Definition: NodalTriExp.h:246
void v_ComputeTraceNormal(const int edge)
void IProductWRTBase_MatOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray)
virtual StdRegions::StdExpansionSharedPtr v_GetStdExp(void) const
virtual DNekMatSharedPtr v_GenMatrix(const StdRegions::StdMatrixKey &mkey)
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
void HelmholtzMatrixOp(const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:155
virtual StdRegions::StdExpansionSharedPtr v_GetLinStdExp(void) const
virtual void v_WeakDerivMatrixOp(const int i, const Array< OneD, const NekDouble > &inarray, Array< OneD, NekDouble > &outarray, const StdRegions::StdMatrixKey &mkey)
Definition: NodalTriExp.h:376
std::shared_ptr< NodalTriExp > NodalTriExpSharedPtr
Definition: NodalTriExp.h:393
std::vector< NodalTriExpSharedPtr > NodalTriExpVector
Definition: NodalTriExp.h:394
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:1
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