escript  Revision_
Quadrature.h
Go to the documentation of this file.
1 
2 /*****************************************************************************
3 *
4 * Copyright (c) 2003-2016 by The University of Queensland
5 * http://www.uq.edu.au
6 *
7 * Primary Business: Queensland, Australia
8 * Licensed under the Apache License, version 2.0
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Development until 2012 by Earth Systems Science Computational Center (ESSCC)
12 * Development 2012-2013 by School of Earth Sciences
13 * Development from 2014 by Centre for Geoscience Computing (GeoComp)
14 *
15 *****************************************************************************/
16 
17 
18 /****************************************************************************
19 
20  Finley: integration schemes for element shapes Tri, Quad, Hex, Tet, Line,
21  Point
22 
23 *****************************************************************************/
24 
25 #ifndef __FINLEY_QUADRATURE_H__
26 #define __FINLEY_QUADRATURE_H__
27 
28 #include "Finley.h"
29 
30 #define MAX_numQuadNodesLine 10
31 
32 namespace finley {
33 
34 typedef enum {
41  NoQuad // marks end of list
42 } QuadTypeId;
43 
44 typedef void (Quad_getNodes) (int, std::vector<double>&, std::vector<double>&);
45 typedef int (Quad_getNumNodes) (int);
46 typedef int (Quad_getMacro) (int numSubElements, int numQuadNodes,
47  const double* quadNodes,
48  const double* quadWeights,
49  int numF, const double* dFdv,
50  int new_len, double* new_quadNodes,
51  double* new_quadWeights, double* new_dFfv);
52 
53 struct QuadInfo {
55  QuadTypeId TypeId;
57  const char* Name;
59  int numDim;
69 };
70 
71 
72 /****** Interfaces ******/
73 
80 
96 
103 
104 void Quad_makeNodesOnFace(int, int, double*, double*, Quad_getNodes);
105 const QuadInfo* QuadInfo_getInfo(QuadTypeId id);
106 
107 } // namespace finley
108 
109 #endif // __FINLEY_QUADRATURE_H__
110 
Quad_getNumNodes Quad_getNumNodesTet
Definition: Quadrature.h:101
Definition: Quadrature.h:35
Quad_getNodes Quad_getNodesTetMacro
Definition: Quadrature.h:92
Quad_getNumNodes Quad_getNumNodesTri
Definition: Quadrature.h:99
void Quad_makeNodesOnFace(int, int, double *, double *, Quad_getNodes)
Quad_getNodes * getQuadNodes
function that returns the quadrature points for a given order
Definition: Quadrature.h:63
Quad_getMacro Quad_MacroHex
Definition: Quadrature.h:79
Quad_getNodes Quad_getNodesPointOnFace
Definition: Quadrature.h:90
int numVertices
number of vertices of the element
Definition: Quadrature.h:61
Quad_getNodes Quad_getNodesRecMacro
Definition: Quadrature.h:93
Quad_getMacro Quad_MacroTri
Definition: Quadrature.h:76
Quad_getNodes Quad_getNodesHexMacro
Definition: Quadrature.h:94
Quad_getNodes Quad_getNodesTri
Definition: Quadrature.h:81
Quad_getNodes Quad_getNodesTriMacro
Definition: Quadrature.h:91
Quad_getMacro Quad_MacroRec
Definition: Quadrature.h:77
Definition: Quadrature.h:37
Definition: Quadrature.h:40
Quad_getNodes Quad_getNodesRec
Definition: Quadrature.h:83
int() Quad_getMacro(int numSubElements, int numQuadNodes, const double *quadNodes, const double *quadWeights, int numF, const double *dFdv, int new_len, double *new_quadNodes, double *new_quadWeights, double *new_dFfv)
Definition: Quadrature.h:46
Definition: Quadrature.h:41
Quad_getMacro Quad_MacroPoint
Definition: Quadrature.h:74
Quad_getNumNodes Quad_getNumNodesRec
Definition: Quadrature.h:100
A suite of factory methods for creating various finley domains.
Definition: finley/src/Assemble.h:31
Quad_getNumNodes Quad_getNumNodesHex
Definition: Quadrature.h:102
void() Quad_getNodes(int, std::vector< double > &, std::vector< double > &)
Definition: Quadrature.h:44
const char * Name
the name in text form e.g. "Line", "Rec", ...
Definition: Quadrature.h:57
Quad_getNodes Quad_getNodesHex
Definition: Quadrature.h:84
Quad_getMacro * getMacro
transfers a given quadrature scheme to a macro element structure
Definition: Quadrature.h:68
Quad_getNumNodes * getNumQuadNodes
Definition: Quadrature.h:66
const QuadInfo * QuadInfo_getInfo(QuadTypeId id)
Definition: Quadrature.cpp:43
Quad_getNodes Quad_getNodesLine
Definition: Quadrature.h:85
Quad_getMacro Quad_MacroLine
Definition: Quadrature.h:75
QuadTypeId
Definition: Quadrature.h:34
Definition: Quadrature.h:39
Quad_getNodes Quad_getNodesRecOnFace
Definition: Quadrature.h:88
int() Quad_getNumNodes(int)
Definition: Quadrature.h:45
Definition: Quadrature.h:38
Definition: Quadrature.h:36
Quad_getNodes Quad_getNodesTet
Definition: Quadrature.h:82
Quad_getNodes Quad_getNodesPoint
Definition: Quadrature.h:86
Quad_getNodes Quad_getNodesLineMacro
Definition: Quadrature.h:95
QuadTypeId TypeId
quadrature type id
Definition: Quadrature.h:55
Quad_getNodes Quad_getNodesTriOnFace
Definition: Quadrature.h:87
Quad_getNodes Quad_getNodesLineOnFace
Definition: Quadrature.h:89
Quad_getNumNodes Quad_getNumNodesLine
Definition: Quadrature.h:98
Quad_getMacro Quad_MacroTet
Definition: Quadrature.h:78
Definition: Quadrature.h:53
Quad_getNumNodes Quad_getNumNodesPoint
Definition: Quadrature.h:97
int numDim
number of spatial dimensions
Definition: Quadrature.h:59