escript  Revision_
Quadrature.h
Go to the documentation of this file.
1 
2 /*****************************************************************************
3 *
4 * Copyright (c) 2003-2018 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 {
40  HexQuad,
41  NoQuad // marks end of list
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 {
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);
106 
107 } // namespace finley
108 
109 #endif // __FINLEY_QUADRATURE_H__
110 
finley::QuadInfo
Definition: Quadrature.h:51
finley::RecQuad
Definition: Quadrature.h:36
finley::Quad_MacroPoint
Quad_getMacro Quad_MacroPoint
Definition: Quadrature.h:72
INDEX4
#define INDEX4(_X1_, _X2_, _X3_, _X4_, _N1_, _N2_, _N3_)
Definition: index.h:25
TWO
#define TWO
Definition: Quadrature.cpp:1351
Quadrature.h
finley::Quad_MacroTet
Quad_getMacro Quad_MacroTet
Definition: Quadrature.h:76
finley::Quad_getNodesRecOnFace
Quad_getNodes Quad_getNodesRecOnFace
Definition: Quadrature.h:86
INDEX2
#define INDEX2(_X1_, _X2_, _N1_)
Definition: index.h:21
finley::Quad_getNumNodesPoint
Quad_getNumNodes Quad_getNumNodesPoint
Definition: Quadrature.h:95
finley::Quad_getNumNodesTet
Quad_getNumNodes Quad_getNumNodesTet
Definition: Quadrature.h:99
finley::NoQuad
Definition: Quadrature.h:39
finley::FinleyException
Definition: FinleyException.h:36
finley::Quad_getNodesTriMacro
Quad_getNodes Quad_getNodesTriMacro
Definition: Quadrature.h:89
MAX_numQuadNodesLine
#define MAX_numQuadNodesLine
Definition: Quadrature.h:28
finley::QuadInfoList
const QuadInfo QuadInfoList[]
Definition: Quadrature.cpp:31
finley::Quad_getNodesTetMacro
Quad_getNodes Quad_getNodesTetMacro
Definition: Quadrature.h:90
finley::QuadInfo::numDim
int numDim
number of spatial dimensions
Definition: Quadrature.h:57
finley::Quad_getNodesHexMacro
Quad_getNodes Quad_getNodesHexMacro
Definition: Quadrature.h:92
finley::Quad_getNumNodesLine
Quad_getNumNodes Quad_getNumNodesLine
Definition: Quadrature.h:96
QUADNODES
#define QUADNODES(_K_, _I_)
Definition: Quadrature.cpp:26
finley::Quad_MacroTri
Quad_getMacro Quad_MacroTri
Definition: Quadrature.h:74
QUADWEIGHTS
#define QUADWEIGHTS(_I_)
Definition: Quadrature.cpp:27
INDEX3
#define INDEX3(_X1_, _X2_, _X3_, _N1_, _N2_)
Definition: index.h:23
finley::PointQuad
Definition: Quadrature.h:33
finley::QuadInfo::Name
const char * Name
the name in text form e.g. "Line", "Rec", ...
Definition: Quadrature.h:55
finley::Quad_getNodesPointOnFace
Quad_getNodes Quad_getNodesPointOnFace
Definition: Quadrature.h:88
finley::Quad_getNodesLineMacro
Quad_getNodes Quad_getNodesLineMacro
Definition: Quadrature.h:93
finley::Quad_getNodesRec
Quad_getNodes Quad_getNodesRec
Definition: Quadrature.h:81
finley::Quad_getNodesTriOnFace
Quad_getNodes Quad_getNodesTriOnFace
Definition: Quadrature.h:85
finley::Quad_getNodes
void() Quad_getNodes(int, std::vector< double > &, std::vector< double > &)
Definition: Quadrature.h:42
finley::LineQuad
Definition: Quadrature.h:34
finley::Quad_getNumNodesTri
Quad_getNumNodes Quad_getNumNodesTri
Definition: Quadrature.h:97
finley::Quad_getNumNodes
int() Quad_getNumNodes(int)
Definition: Quadrature.h:43
finley::Quad_MacroLine
Quad_getMacro Quad_MacroLine
Definition: Quadrature.h:73
finley::Quad_getNodesTri
Quad_getNodes Quad_getNodesTri
Definition: Quadrature.h:79
finley::QuadInfo::TypeId
QuadTypeId TypeId
quadrature type id
Definition: Quadrature.h:53
finley::HexQuad
Definition: Quadrature.h:38
finley::Quad_getNodesLine
Quad_getNodes Quad_getNodesLine
Definition: Quadrature.h:83
finley::Quad_getNodesHex
Quad_getNodes Quad_getNodesHex
Definition: Quadrature.h:82
finley::QuadInfo_getInfo
const QuadInfo * QuadInfo_getInfo(QuadTypeId id)
Definition: Quadrature.cpp:41
finley::Quad_makeNodesOnFace
void Quad_makeNodesOnFace(int, int, double *, double *, Quad_getNodes)
finley::QuadInfo::numVertices
int numVertices
number of vertices of the element
Definition: Quadrature.h:59
finley::Quad_getNumNodesHex
Quad_getNumNodes Quad_getNumNodesHex
Definition: Quadrature.h:100
finley::TriQuad
Definition: Quadrature.h:35
finley::QuadInfo::getNumQuadNodes
Quad_getNumNodes * getNumQuadNodes
Definition: Quadrature.h:64
finley::QuadInfo::getQuadNodes
Quad_getNodes * getQuadNodes
function that returns the quadrature points for a given order
Definition: Quadrature.h:61
Finley.h
DIM
#define DIM
finley::TetQuad
Definition: Quadrature.h:37
finley::QuadInfo::getMacro
Quad_getMacro * getMacro
transfers a given quadrature scheme to a macro element structure
Definition: Quadrature.h:66
HALF
#define HALF
Definition: Quadrature.cpp:1350
finley::Quad_getNumNodesRec
Quad_getNumNodes Quad_getNumNodesRec
Definition: Quadrature.h:98
finley::Quad_getNodesLineOnFace
Quad_getNodes Quad_getNodesLineOnFace
Definition: Quadrature.h:87
finley::Quad_MacroHex
Quad_getMacro Quad_MacroHex
Definition: Quadrature.h:77
finley::Quad_MacroRec
Quad_getMacro Quad_MacroRec
Definition: Quadrature.h:75
finley
A suite of factory methods for creating various finley domains.
Definition: finley/src/Assemble.h:31
finley::Quad_getNodesPoint
Quad_getNodes Quad_getNodesPoint
Definition: Quadrature.h:84
escript::ValueError
An exception class that signals an invalid argument value.
Definition: EsysException.h:99
finley::QuadTypeId
QuadTypeId
Definition: Quadrature.h:32
finley::Quad_getMacro
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:44
finley::Quad_getNodesTet
Quad_getNodes Quad_getNodesTet
Definition: Quadrature.h:80
finley::Quad_getNodesRecMacro
Quad_getNodes Quad_getNodesRecMacro
Definition: Quadrature.h:91