Nektar++
Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Member Functions | Private Attributes | Static Private Attributes | List of all members
Nektar::LibUtilities::NodalPrismElec Class Reference

#include <NodalPrismElec.h>

Inheritance diagram for Nektar::LibUtilities::NodalPrismElec:
[legend]

Public Member Functions

virtual ~NodalPrismElec ()
 
 NodalPrismElec (const PointsKey &key)
 
- Public Member Functions inherited from Nektar::LibUtilities::Points< NekDouble >
virtual ~Points ()
 
void Initialize (void)
 
size_t GetPointsDim () const
 
size_t GetNumPoints () const
 
size_t GetTotNumPoints () const
 
PointsType GetPointsType () const
 
const Array< OneD, const DataType > & GetZ () const
 
const Array< OneD, const DataType > & GetW () const
 
void GetZW (Array< OneD, const DataType > &z, Array< OneD, const DataType > &w) const
 
const Array< OneD, const NekDouble > & GetBaryWeights () const
 
void GetPoints (Array< OneD, const DataType > &x) const
 
void GetPoints (Array< OneD, const DataType > &x, Array< OneD, const DataType > &y) const
 
void GetPoints (Array< OneD, const DataType > &x, Array< OneD, const DataType > &y, Array< OneD, const DataType > &z) const
 
const MatrixSharedPtrTypeGetD (Direction dir=xDir) const
 
const MatrixSharedPtrType GetI (const PointsKey &key)
 
const MatrixSharedPtrType GetI (const Array< OneD, const DataType > &x)
 
const MatrixSharedPtrType GetI (size_t uint, const Array< OneD, const DataType > &x)
 
const MatrixSharedPtrType GetI (const Array< OneD, const DataType > &x, const Array< OneD, const DataType > &y)
 
const MatrixSharedPtrType GetI (const Array< OneD, const DataType > &x, const Array< OneD, const DataType > &y, const Array< OneD, const DataType > &z)
 
const MatrixSharedPtrType GetGalerkinProjection (const PointsKey &pkey)
 

Static Public Member Functions

static std::shared_ptr< PointsBaseTypeCreate (const PointsKey &key)
 

Protected Member Functions

virtual const MatrixSharedPtrType v_GetI (const PointsKey &pkey) override
 
virtual const MatrixSharedPtrType v_GetI (const Array< OneD, const NekDouble > &x, const Array< OneD, const NekDouble > &y, const Array< OneD, const NekDouble > &z) override
 
- Protected Member Functions inherited from Nektar::LibUtilities::Points< NekDouble >
virtual void v_Initialize (void)
 
virtual void v_CalculatePoints ()
 
virtual void v_CalculateWeights ()
 

Private Member Functions

 NodalPrismElec ()=delete
 
 NodalPrismElec (const NodalPrismElec &points)=delete
 
void NodalPointReorder3d ()
 
virtual void v_CalculatePoints () override final
 
virtual void v_CalculateWeights () override final
 
virtual void v_CalculateDerivMatrix () override final
 
void CalculateInterpMatrix (const Array< OneD, const NekDouble > &xi, const Array< OneD, const NekDouble > &yi, const Array< OneD, const NekDouble > &zi, Array< OneD, NekDouble > &interp)
 

Private Attributes

std::shared_ptr< NodalUtilPrismm_util
 

Static Private Attributes

static bool initPointsManager []
 

Additional Inherited Members

- Public Types inherited from Nektar::LibUtilities::Points< NekDouble >
typedef NekDouble DataType
 
typedef std::shared_ptr< NekMatrix< DataType > > MatrixSharedPtrType
 
- Protected Attributes inherited from Nektar::LibUtilities::Points< NekDouble >
PointsKey m_pointsKey
 Points type for this points distributions. More...
 
Array< OneD, DataTypem_points [3]
 Storage for the point locations, allowing for up to a 3D points storage. More...
 
Array< OneD, DataTypem_weights
 Quadrature weights for the weights. More...
 
Array< OneD, DataTypem_bcweights
 Barycentric weights. More...
 
MatrixSharedPtrType m_derivmatrix [3]
 Derivative matrices. More...
 
NekManager< PointsKey, NekMatrix< DataType >, PointsKey::opLessm_InterpManager
 
NekManager< PointsKey, NekMatrix< DataType >, PointsKey::opLessm_GalerkinProjectionManager
 

Detailed Description

Definition at line 46 of file NodalPrismElec.h.

Constructor & Destructor Documentation

◆ ~NodalPrismElec()

virtual Nektar::LibUtilities::NodalPrismElec::~NodalPrismElec ( )
inlinevirtual

Definition at line 49 of file NodalPrismElec.h.

50 {
51 }

◆ NodalPrismElec() [1/3]

Nektar::LibUtilities::NodalPrismElec::NodalPrismElec ( const PointsKey key)
inline

Definition at line 53 of file NodalPrismElec.h.

53 : PointsBaseType(key)
54 {
55 }
Points< NekDouble > PointsBaseType

◆ NodalPrismElec() [2/3]

Nektar::LibUtilities::NodalPrismElec::NodalPrismElec ( )
privatedelete

◆ NodalPrismElec() [3/3]

Nektar::LibUtilities::NodalPrismElec::NodalPrismElec ( const NodalPrismElec points)
privatedelete

Member Function Documentation

◆ CalculateInterpMatrix()

void Nektar::LibUtilities::NodalPrismElec::CalculateInterpMatrix ( const Array< OneD, const NekDouble > &  xi,
const Array< OneD, const NekDouble > &  yi,
const Array< OneD, const NekDouble > &  zi,
Array< OneD, NekDouble > &  interp 
)
private

Definition at line 429 of file NodalPrismElec.cpp.

433{
434 Array<OneD, Array<OneD, NekDouble>> xi(3);
435 xi[0] = xia;
436 xi[1] = yia;
437 xi[1] = zia;
438
439 std::shared_ptr<NekMatrix<NekDouble>> mat =
440 m_util->GetInterpolationMatrix(xi);
441 Vmath::Vcopy(mat->GetRows() * mat->GetColumns(), mat->GetRawPtr(), 1,
442 &interp[0], 1);
443}
std::shared_ptr< NodalUtilPrism > m_util
void Vcopy(int n, const T *x, const int incx, T *y, const int incy)
Definition: Vmath.cpp:1191

References m_util, and Vmath::Vcopy().

Referenced by v_GetI().

◆ Create()

std::shared_ptr< PointsBaseType > Nektar::LibUtilities::NodalPrismElec::Create ( const PointsKey key)
static

Definition at line 457 of file NodalPrismElec.cpp.

458{
459 std::shared_ptr<PointsBaseType> returnval(
461
462 returnval->Initialize();
463
464 return returnval;
465}
static std::shared_ptr< DataType > AllocateSharedPtr(const Args &...args)
Allocate a shared pointer from the memory pool.

◆ NodalPointReorder3d()

void Nektar::LibUtilities::NodalPrismElec::NodalPointReorder3d ( )
private

Definition at line 183 of file NodalPrismElec.cpp.

184{
185 size_t npts = GetNumPoints();
186 using std::vector;
187 vector<int> vertex;
188 vector<int> iEdge_01; // interior edge 0
189 vector<int> iEdge_12; // interior edge 1
190 vector<int> iEdge_23; // interior edge 2
191 vector<int> iEdge_30; // interior edge 3
192 vector<int> iEdge_04; // interior edge 4
193 vector<int> iEdge_14; // interior edge 5
194 vector<int> iEdge_25; // interior edge 6
195 vector<int> iEdge_35; // interior edge 7
196 vector<int> iEdge_45; // interior edge 8
197 vector<int> iFace_0123; // interior face 0
198 vector<int> iFace_014; // interior face 1
199 vector<int> iFace_1254; // interior face 2
200 vector<int> iFace_325; // interior face 3
201 vector<int> iFace_0354; // interior face 4
202 vector<int> interiorVolumePoints; // interior volume points
203 vector<int> map;
204
205 // Build the lattice prism left to right - bottom to top
206 for (size_t y = 0, index = 0; y < npts; y++)
207 {
208 for (size_t t = 0; t < npts * (npts + 1) / 2; t++, index++)
209 {
210 if (isVertex(t, y, npts))
211 {
212 vertex.push_back(index);
213 }
214 else if (isEdge(t, y, npts))
215 {
216 if (isEdge_01(t, y, npts))
217 {
218 iEdge_01.push_back(index);
219 }
220 else if (isEdge_12(t, y, npts))
221 {
222 iEdge_12.push_back(index);
223 }
224 else if (isEdge_23(t, y, npts))
225 {
226 iEdge_23.push_back(index);
227 }
228 else if (isEdge_30(t, y, npts))
229 {
230 iEdge_30.push_back(index);
231 }
232 else if (isEdge_04(t, y, npts))
233 {
234 iEdge_04.push_back(index);
235 }
236 else if (isEdge_14(t, y, npts))
237 {
238 iEdge_14.push_back(index);
239 }
240 else if (isEdge_25(t, y, npts))
241 {
242 iEdge_25.push_back(index);
243 }
244 else if (isEdge_35(t, y, npts))
245 {
246 iEdge_35.push_back(index);
247 }
248 else if (isEdge_45(t, y, npts))
249 {
250 iEdge_45.push_back(index);
251 }
252 }
253 else if (isFace(t, y, npts))
254 {
255 if (isFace_0123(t, y, npts))
256 {
257 iFace_0123.push_back(index);
258 }
259 else if (isFace_014(t, y, npts))
260 {
261 iFace_014.push_back(index);
262 }
263 else if (isFace_1254(t, y, npts))
264 {
265 iFace_1254.push_back(index);
266 }
267 else if (isFace_325(t, y, npts))
268 {
269 iFace_325.push_back(index);
270 }
271 else if (isFace_0354(t, y, npts))
272 {
273 iFace_0354.push_back(index);
274 }
275 }
276 else
277 {
278 interiorVolumePoints.push_back(index);
279 }
280 }
281 }
282
283 // sort vertices
284 std::swap(vertex[2], vertex[4]);
285 // sort edges
286 std::reverse(iEdge_23.begin(), iEdge_23.end());
287 std::reverse(iEdge_30.begin(), iEdge_30.end());
288 std::reverse(iEdge_04.begin(), iEdge_04.end());
289 std::reverse(iEdge_35.begin(), iEdge_35.end());
290
291 // faces
292 for (size_t i = 0; i < npts - 2; i++)
293 {
294 for (size_t j = i + 1; j < npts - 2; j++)
295 {
296 std::swap(iFace_1254[i * (npts - 2) + j],
297 iFace_1254[j * (npts - 2) + i]);
298 }
299 }
300 for (size_t i = 0; i < npts - 2; i++)
301 {
302 std::reverse(iFace_0354.begin() + (i * (npts - 2)),
303 iFace_0354.begin() + (i * (npts - 2) + npts - 2));
304 }
305 for (size_t i = 0; i < npts - 2; i++)
306 {
307 for (size_t j = i + 1; j < npts - 2; j++)
308 {
309 std::swap(iFace_0354[i * (npts - 2) + j],
310 iFace_0354[j * (npts - 2) + i]);
311 }
312 }
313
314 for (size_t n = 0; n < vertex.size(); ++n)
315 {
316 map.push_back(vertex[n]);
317 }
318
319 for (size_t n = 0; n < iEdge_01.size(); ++n)
320 {
321 map.push_back(iEdge_01[n]);
322 }
323
324 for (size_t n = 0; n < iEdge_12.size(); ++n)
325 {
326 map.push_back(iEdge_12[n]);
327 }
328
329 for (size_t n = 0; n < iEdge_23.size(); ++n)
330 {
331 map.push_back(iEdge_23[n]);
332 }
333
334 for (size_t n = 0; n < iEdge_30.size(); ++n)
335 {
336 map.push_back(iEdge_30[n]);
337 }
338
339 for (size_t n = 0; n < iEdge_04.size(); ++n)
340 {
341 map.push_back(iEdge_04[n]);
342 }
343
344 for (size_t n = 0; n < iEdge_14.size(); ++n)
345 {
346 map.push_back(iEdge_14[n]);
347 }
348
349 for (size_t n = 0; n < iEdge_25.size(); ++n)
350 {
351 map.push_back(iEdge_25[n]);
352 }
353
354 for (size_t n = 0; n < iEdge_35.size(); ++n)
355 {
356 map.push_back(iEdge_35[n]);
357 }
358
359 for (size_t n = 0; n < iEdge_45.size(); ++n)
360 {
361 map.push_back(iEdge_45[n]);
362 }
363
364 for (size_t n = 0; n < iFace_0123.size(); ++n)
365 {
366 map.push_back(iFace_0123[n]);
367 }
368
369 for (size_t n = 0; n < iFace_014.size(); ++n)
370 {
371 map.push_back(iFace_014[n]);
372 }
373
374 for (size_t n = 0; n < iFace_1254.size(); ++n)
375 {
376 map.push_back(iFace_1254[n]);
377 }
378
379 for (size_t n = 0; n < iFace_325.size(); ++n)
380 {
381 map.push_back(iFace_325[n]);
382 }
383
384 for (size_t n = 0; n < iFace_0354.size(); ++n)
385 {
386 map.push_back(iFace_0354[n]);
387 }
388
389 for (size_t n = 0; n < interiorVolumePoints.size(); ++n)
390 {
391 map.push_back(interiorVolumePoints[n]);
392 }
393
394 Array<OneD, NekDouble> points[3];
395 points[0] = Array<OneD, NekDouble>(GetTotNumPoints());
396 points[1] = Array<OneD, NekDouble>(GetTotNumPoints());
397 points[2] = Array<OneD, NekDouble>(GetTotNumPoints());
398
399 for (size_t index = 0; index < map.size(); ++index)
400 {
401 points[0][index] = m_points[0][index];
402 points[1][index] = m_points[1][index];
403 points[2][index] = m_points[2][index];
404 }
405
406 for (size_t index = 0; index < map.size(); ++index)
407 {
408 m_points[0][index] = points[0][map[index]];
409 m_points[1][index] = points[1][map[index]];
410 m_points[2][index] = points[2][map[index]];
411 }
412}
Array< OneD, DataType > m_points[3]
Storage for the point locations, allowing for up to a 3D points storage.
Definition: Points.h:361

References Nektar::LibUtilities::Points< NekDouble >::GetNumPoints(), Nektar::LibUtilities::Points< NekDouble >::GetTotNumPoints(), and Nektar::LibUtilities::Points< NekDouble >::m_points.

Referenced by v_CalculatePoints().

◆ v_CalculateDerivMatrix()

void Nektar::LibUtilities::NodalPrismElec::v_CalculateDerivMatrix ( )
finaloverrideprivatevirtual

Definition at line 447 of file NodalPrismElec.cpp.

448{
449 // Allocate the derivative matrix.
450 PointsBaseType::v_CalculateDerivMatrix();
451
452 m_derivmatrix[0] = m_util->GetDerivMatrix(0);
453 m_derivmatrix[1] = m_util->GetDerivMatrix(1);
454 m_derivmatrix[2] = m_util->GetDerivMatrix(2);
455}
MatrixSharedPtrType m_derivmatrix[3]
Derivative matrices.
Definition: Points.h:367

References Nektar::LibUtilities::Points< NekDouble >::m_derivmatrix, and m_util.

◆ v_CalculatePoints()

void Nektar::LibUtilities::NodalPrismElec::v_CalculatePoints ( )
finaloverrideprivatevirtual

Reimplemented from Nektar::LibUtilities::Points< NekDouble >.

Definition at line 153 of file NodalPrismElec.cpp.

154{
155 // Allocate the storage for points
157
158 // Populate m_points
159 size_t npts = GetNumPoints();
160
161 LibUtilities::PointsKey pkey1(npts, LibUtilities::eNodalTriElec);
162 Array<OneD, NekDouble> u1, v1;
163 LibUtilities::PointsManager()[pkey1]->GetPoints(u1, v1);
164 LibUtilities::PointsKey pkey2(npts, LibUtilities::eGaussLobattoLegendre);
165 Array<OneD, NekDouble> u;
166 LibUtilities::PointsManager()[pkey2]->GetPoints(u);
167
168 for (size_t y = 0, index = 0; y < npts; y++)
169 {
170 for (size_t t = 0; t < u1.size(); t++, index++)
171 {
172 m_points[0][index] = u1[t];
173 m_points[1][index] = u[y];
174 m_points[2][index] = v1[t];
175 }
176 }
177
180 npts - 1, m_points[0], m_points[1], m_points[2]);
181}
PointsManagerT & PointsManager(void)
@ eNodalTriElec
2D Nodal Electrostatic Points on a Triangle
Definition: PointsType.h:83
@ eGaussLobattoLegendre
1D Gauss-Lobatto-Legendre quadrature points
Definition: PointsType.h:53

References Nektar::MemoryManager< DataType >::AllocateSharedPtr(), Nektar::LibUtilities::eGaussLobattoLegendre, Nektar::LibUtilities::eNodalTriElec, Nektar::LibUtilities::Points< NekDouble >::GetNumPoints(), Nektar::LibUtilities::Points< NekDouble >::m_points, m_util, NodalPointReorder3d(), Nektar::LibUtilities::PointsManager(), and Nektar::LibUtilities::Points< NekDouble >::v_CalculatePoints().

◆ v_CalculateWeights()

void Nektar::LibUtilities::NodalPrismElec::v_CalculateWeights ( )
finaloverrideprivatevirtual

Reimplemented from Nektar::LibUtilities::Points< NekDouble >.

Definition at line 414 of file NodalPrismElec.cpp.

415{
416 // Allocate the storage for points
418
419 typedef DataType T;
420
421 // Solve the Vandermonde system of integrals for the weight vector
422 NekVector<T> w = m_util->GetWeights();
423
424 m_weights = Array<OneD, T>(w.GetRows(), w.GetPtr());
425}
Array< OneD, DataType > m_weights
Quadrature weights for the weights.
Definition: Points.h:363
std::vector< double > w(NPUPPER)

References m_util, Nektar::LibUtilities::Points< NekDouble >::m_weights, Nektar::LibUtilities::Points< NekDouble >::v_CalculateWeights(), and Nektar::UnitTests::w().

◆ v_GetI() [1/2]

virtual const MatrixSharedPtrType Nektar::LibUtilities::NodalPrismElec::v_GetI ( const Array< OneD, const NekDouble > &  x,
const Array< OneD, const NekDouble > &  y,
const Array< OneD, const NekDouble > &  z 
)
inlineoverrideprotectedvirtual

Definition at line 71 of file NodalPrismElec.h.

75 {
76 size_t numpoints = x.size();
77 size_t np = GetTotNumPoints();
78
79 Array<OneD, NekDouble> interp(GetTotNumPoints() * numpoints);
80 CalculateInterpMatrix(x, y, z, interp);
81
82 NekDouble *d = interp.data();
83 return MemoryManager<NekMatrix<NekDouble>>::AllocateSharedPtr(numpoints,
84 np, d);
85 }
void CalculateInterpMatrix(const Array< OneD, const NekDouble > &xi, const Array< OneD, const NekDouble > &yi, const Array< OneD, const NekDouble > &zi, Array< OneD, NekDouble > &interp)
std::vector< double > z(NPUPPER)
std::vector< double > d(NPUPPER *NPUPPER)
double NekDouble

References CalculateInterpMatrix(), Nektar::UnitTests::d(), Nektar::LibUtilities::Points< NekDouble >::GetTotNumPoints(), and Nektar::UnitTests::z().

◆ v_GetI() [2/2]

virtual const MatrixSharedPtrType Nektar::LibUtilities::NodalPrismElec::v_GetI ( const PointsKey pkey)
inlineoverrideprotectedvirtual

Definition at line 61 of file NodalPrismElec.h.

62 {
63 ASSERTL0(pkey.GetPointsDim() == 3,
64 "NodalPrismElec Points can only interp to "
65 "other 3d point distributions");
66 Array<OneD, const NekDouble> x, y, z;
67 PointsManager()[pkey]->GetPoints(x, y, z);
68 return GetI(x, y, z);
69 }
#define ASSERTL0(condition, msg)
Definition: ErrorUtil.hpp:215
const MatrixSharedPtrType GetI(const PointsKey &key)
Definition: Points.h:322

References ASSERTL0, Nektar::LibUtilities::Points< NekDouble >::GetI(), Nektar::LibUtilities::PointsKey::GetPointsDim(), Nektar::LibUtilities::PointsManager(), and Nektar::UnitTests::z().

Member Data Documentation

◆ initPointsManager

bool Nektar::LibUtilities::NodalPrismElec::initPointsManager
staticprivate
Initial value:
bool RegisterCreator(const KeyType &key, const CreateFuncType &createFunc)
Register the given function and associate it with the key. The return value is just to facilitate cal...
Definition: NekManager.hpp:169
static std::shared_ptr< PointsBaseType > Create(const PointsKey &key)
@ eNodalPrismElec
3D electrostatically spaced points on a Prism
Definition: PointsType.h:89

Definition at line 88 of file NodalPrismElec.h.

◆ m_util

std::shared_ptr<NodalUtilPrism> Nektar::LibUtilities::NodalPrismElec::m_util
private