Go to the documentation of this file.
17 #ifndef __DUDLEY_DOMAINFACTORY_H__
18 #define __DUDLEY_DOMAINFACTORY_H__
20 #include <dudley/DudleyDomain.h>
22 #include <boost/python/list.hpp>
43 int integrationOrder = -1,
44 int reducedIntegrationOrder = -1,
45 bool optimize =
false);
57 int integrationOrder = -1,
58 int reducedIntegrationOrder = -1,
59 bool optimize =
false);
76 double l0=1.0,
double l1=1.0,
double l2=1.0,
77 bool periodic0=
false,
bool periodic1=
false,
bool periodic2=
false,
78 int integrationOrder=-1,
int reducedIntegrationOrder=-1,
79 bool useElementsOnFace=
false,
bool useFullElementOrder=
false,
107 double l0 = 1.0,
double l1 = 1.0,
108 bool periodic0 =
false,
bool periodic1 =
false,
109 int integrationOrder = -1,
110 int reducedIntegrationOrder = -1,
111 bool useElementsOnFace =
false,
112 bool useFullElementOrder =
false,
113 bool optimize =
false);
124 #endif // __DUDLEY_DOMAINFACTORY_H__
void setContactElements(ElementFile *elements)
replaces the contact element file by elements
Definition: finley/src/FinleyDomain.cpp:132
Domain_ptr brick_driver(const bp::list &args)
Definition: finley/src/DomainFactory.cpp:1103
int * Tag
Tag[i] is the tag of element i.
Definition: dudley/src/ElementFile.h:131
index_t minColor
minimum color value
Definition: finley/src/ElementFile.h:163
void joinFaces(double safetyFactor, double tolerance, bool optimize)
Definition: Mesh_joinFaces.cpp:47
FinleyDomain implements the AbstractContinuousDomain interface for the Finley library.
Definition: finley/src/FinleyDomain.h:137
Definition: blocktools.h:67
Definition: DudleyException.h:35
Definition: dudley/src/NodeFile.h:37
void allocTable(dim_t NE)
allocates the element table within an element file to hold NE elements
Definition: finley/src/ElementFile.cpp:75
Domain_ptr rectangle(JMPI info, dim_t n0, dim_t n1, int order, double l0, double l1, bool periodic0, bool periodic1, int integrationOrder, int reducedIntegrationOrder, bool useElementsOnFace, bool useFullElementOrder, bool optimize)
Creates a 2-dimensional rectangular mesh with n0 x n1 x 2 Tri3 elements over the rectangle [0,...
Definition: dudley/src/DomainFactory.cpp:735
void glueFaces(double safetyFactor, double tolerance, bool optimize)
Definition: Mesh_glueFaces.cpp:47
#define INDEX2(_X1_, _X2_, _N1_)
Definition: index.h:21
boost::shared_ptr< const ReferenceElementSet > const_ReferenceElementSet_ptr
Definition: ReferenceElementSets.h:90
int * Tag
Tag[i] is the tag of element i.
Definition: finley/src/ElementFile.h:139
index_t * Nodes
Nodes[INDEX(k, i, numNodes)] is the k-th node in the i-th element.
Definition: dudley/src/ElementFile.h:143
void setElements(ElementFile *elements)
replaces the element file by elements
Definition: DudleyDomain.cpp:105
Definition: FinleyException.h:36
Domain_ptr getPtr()
Returns smart pointer which is managing this object. If one does not exist yet it creates one.
Definition: AbstractDomain.cpp:36
void allocTable(dim_t NE)
allocates the element table within an element file to hold NE elements
Definition: dudley/src/ElementFile.cpp:64
Domain_ptr readGmsh(const string &fileName, int numDim, int, int, bool optimize)
reads a gmsh mesh file
Definition: dudley/src/DomainFactory.cpp:679
int * Owner
Owner[i] contains the rank that owns element i.
Definition: dudley/src/ElementFile.h:134
boost::shared_ptr< AbstractDomain > Domain_ptr
Definition: AbstractDomain.h:47
void createMappings(const std::vector< index_t > &dofDistribution, const std::vector< index_t > &nodeDistribution)
Definition: DudleyDomain.cpp:123
index_t * Nodes
Definition: finley/src/ElementFile.h:154
JMPI makeInfo(MPI_Comm comm, bool owncom)
Definition: EsysMPI.cpp:39
index_t maxColor
maximum color value
Definition: finley/src/ElementFile.h:166
index_t maxColor
maximum color value
Definition: dudley/src/ElementFile.h:154
Domain_ptr rectangle_driver(const bp::list &args)
Definition: dudley/src/DomainFactory.cpp:752
index_t minColor
minimum color value
Definition: dudley/src/ElementFile.h:151
Domain_ptr rectangle(JMPI info, dim_t n0, dim_t n1, int order, double l0, double l1, bool periodic0, bool periodic1, int integrationOrder, int reducedIntegrationOrder, bool useElementsOnFace, bool useFullElementOrder, bool optimize, const vector< double > &points, const vector< int > &tags, const std::map< std::string, int > &tagNamesToNums)
Creates a 2-dimensional rectangular mesh with n0 x n1 elements over the rectangle [0,...
Definition: finley/src/DomainFactory.cpp:1168
A suite of factory methods for creating 2D and 3D dudley domains.
Definition: dudley/src/Assemble.h:31
#define MPI_COMM_WORLD
Definition: EsysMPI.h:46
int * Owner
Owner[i] contains the rank that owns element i.
Definition: finley/src/ElementFile.h:142
double l2(dim_t n, const double *x, escript::JMPI mpiinfo)
returns the global L2 norm of x
Definition: PasoUtil.cpp:524
An exception class for Input/Output errors.
Definition: EsysException.h:79
index_t dim_t
Definition: DataTypes.h:87
boost::shared_ptr< JMPI_ > JMPI
Definition: EsysMPI.h:70
Definition: dudley/src/ElementFile.h:62
index_t * Id
Definition: dudley/src/ElementFile.h:128
void addDiracPoints(const std::vector< double > &points, const std::vector< int > &tags)
adds Dirac delta points. Do NOT call this at any time other than construction! Using them later creat...
Definition: Mesh_addPoints.cpp:46
index_t * Color
Definition: finley/src/ElementFile.h:160
NodeFile * getNodes() const
returns a pointer to this domain's node file
Definition: finley/src/FinleyDomain.h:328
Domain_ptr readGmsh_driver(const bp::list &args)
Definition: finley/src/DomainFactory.cpp:983
index_t * Id
Definition: finley/src/ElementFile.h:136
NodeFile * getNodes() const
returns a pointer to this domain's node file
Definition: DudleyDomain.h:210
Domain_ptr joinFaces(const bp::list &meshList, double safetyFactor, double tolerance, bool optimize)
Definition: finley/src/DomainFactory.cpp:1298
void updateTagList()
Definition: dudley/src/ElementFile.h:185
const TagMap & getTagMap() const
returns a reference to the tag name->value map
Definition: finley/src/FinleyDomain.h:842
Domain_ptr brick_driver(const bp::list &args)
Definition: dudley/src/DomainFactory.cpp:710
void cleanupAndThrow(FinleyDomain *dom, string msg)
Definition: finley/src/DomainFactory.cpp:89
Domain_ptr brick(JMPI info, dim_t n0, dim_t n1, dim_t n2, int order, double l0, double l1, double l2, bool periodic0, bool periodic1, bool periodic2, int integrationOrder, int reducedIntegrationOrder, bool useElementsOnFace, bool useFullElementOrder, bool optimize, const std::vector< double > &points, const std::vector< int > &tags, const std::map< std::string, int > &tagNamesToNums)
Creates a rectangular mesh with n0 x n1 x n2 elements over the brick [0,l0] x [0,l1] x [0,...
Definition: finley/src/DomainFactory.cpp:1064
Data load(const std::string fileName, const AbstractDomain &domain)
reads Data on domain from file in netCDF format
Definition: DataFactory.cpp:494
void allocTable(dim_t numNodes)
allocates the node table within this node file to hold numNodes nodes.
Definition: dudley/src/NodeFile.cpp:73
ElementTypeId
Definition: ReferenceElements.h:36
int index_t
type for array/matrix indices used both globally and on each rank
Definition: DataTypes.h:82
Domain_ptr glueFaces(const bp::list &meshList, double safetyFactor, double tolerance, bool optimize)
Definition: finley/src/DomainFactory.cpp:1286
void setElements(ElementFile *elements)
replaces the element file by elements
Definition: finley/src/FinleyDomain.cpp:120
Definition: finley/src/NodeFile.h:39
Definition: AbstractContinuousDomain.cpp:22
ElementFile * getPoints() const
returns a pointer to this domain's point (nodal) element file
Definition: finley/src/FinleyDomain.h:376
virtual void setTagMap(const std::string &name, int tag)
sets a map from a clear tag name to a tag key
Definition: DudleyDomain.cpp:1910
Domain_ptr readMesh(const string &fileName, int, int, bool optimize)
reads a mesh from a fly file. For MPI parallel runs fans out the mesh to multiple processes.
Definition: dudley/src/DomainFactory.cpp:672
void setPoints(ElementFile *elements)
replaces the point element file by elements
Definition: DudleyDomain.cpp:117
void setPoints(ElementFile *elements)
replaces the point element file by elements
Definition: finley/src/FinleyDomain.cpp:138
DudleyDomain implements the AbstractContinuousDomain interface for the Dudley library.
Definition: DudleyDomain.h:119
Definition: finley/src/ElementFile.h:72
void createMappings(const IndexVector &dofDistribution, const IndexVector &nodeDistribution)
Definition: finley/src/FinleyDomain.cpp:183
index_t * Color
Definition: dudley/src/ElementFile.h:148
virtual void setTagMap(const std::string &name, int tag)
sets a map from a clear tag name to a tag key
Definition: finley/src/FinleyDomain.cpp:2504
void setFaceElements(ElementFile *elements)
replaces the face element file by elements
Definition: DudleyDomain.cpp:111
std::map< std::string, int > TagMap
Definition: finley/src/FinleyDomain.h:123
Definition: ReferenceElementSets.h:37
void setFaceElements(ElementFile *elements)
replaces the face element file by elements
Definition: finley/src/FinleyDomain.cpp:126
Domain_ptr rectangle_driver(const bp::list &args)
Definition: finley/src/DomainFactory.cpp:1205
void updateTagList()
Definition: finley/src/ElementFile.h:189
A suite of factory methods for creating various finley domains.
Definition: finley/src/Assemble.h:31
void cleanupAndThrow(DudleyDomain *dom, string msg)
Definition: dudley/src/DomainFactory.cpp:84
void allocTable(dim_t numNodes)
allocates the node table within this node file to hold numNodes nodes.
Definition: finley/src/NodeFile.cpp:137
An exception class that signals an invalid argument value.
Definition: EsysException.h:99
ElementTypeId
Definition: ElementType.h:35
AbstractContinuousDomain, base class for continuous domains.
Definition: AbstractContinuousDomain.h:56
Domain_ptr readMesh_driver(const bp::list &args)
Definition: finley/src/DomainFactory.cpp:902
Domain_ptr meshMerge(const bp::list &meshList)
Definition: finley/src/DomainFactory.cpp:1270
Domain_ptr brick(JMPI info, dim_t n0, dim_t n1, dim_t n2, int order, double l0, double l1, double l2, bool periodic0, bool periodic1, bool periodic2, int integrationOrder, int reducedIntegrationOrder, bool useElementsOnFace, bool useFullElementOrder, bool optimize)
Creates a rectangular mesh with n0 x n1 x n2 elements over the brick [0,l0] x [0,l1] x [0,...
Definition: dudley/src/DomainFactory.cpp:687
std::vector< index_t > IndexVector
Definition: DataTypes.h:85