17 #ifndef __FINLEY_DOMAIN_H__ 18 #define __FINLEY_DOMAIN_H__ 57 #include <finley/Finley.h> 58 #include <finley/ElementFile.h> 59 #include <finley/NodeFile.h> 60 #include <finley/Util.h> 62 #include <escript/AbstractContinuousDomain.h> 63 #include <escript/FunctionSpace.h> 64 #include <escript/FunctionSpaceFactory.h> 67 #include <paso/SystemMatrixPattern.h> 69 #ifdef ESYS_HAVE_TRILINOS 70 #include <trilinoswrap/types.h> 79 typedef std::map<std::string, int>
TagMap;
116 const std::string& fileName,
119 bool optimize =
false);
135 const std::string& filename,
138 bool optimize =
false,
139 bool useMacroElements =
false);
159 double L0,
double L1,
160 bool periodic0,
bool periodic1,
int order,
161 int reducedOrder,
bool useElementsOnFace,
185 double l0,
double l1,
186 bool periodic0,
bool periodic1,
int order,
187 int reducedOrder,
bool useElementsOnFace,
188 bool useFullElementOrder,
189 bool useMacroElements,
bool optimize,
213 double l0,
double l1,
double l2,
214 bool periodic0,
bool periodic1,
bool periodic2,
215 int order,
int reducedOrder,
216 bool useElementsOnFace,
242 double l0,
double l1,
double l2,
243 bool periodic0,
bool periodic1,
bool periodic2,
244 int order,
int reducedOrder,
245 bool useElementsOnFace,
246 bool useFullElementOrder,
247 bool useMacroElements,
bool optimize,
278 const std::vector<int>& tags);
372 void write(
const std::string& fileName)
const;
385 void dump(
const std::string& fileName)
const;
534 virtual std::pair<int,dim_t>
getDataShape(
int functionSpaceCode)
const;
549 virtual void setTagMap(
const std::string& name,
int tag);
556 virtual int getTag(
const std::string& name)
const;
585 int functionSpaceType_target)
const;
606 int functionSpaceType_target)
const;
634 virtual void setToIntegrals(std::vector<escript::DataTypes::real_t>& integrals,
636 virtual void setToIntegrals(std::vector<escript::DataTypes::cplx_t>& integrals,
659 bool symmetry)
const;
727 int column_blocksize,
765 virtual void setTags(
int functionSpaceType,
int newTag,
781 virtual bool canTag(
int functionSpaceCode)
const;
792 const boost::python::tuple& filter)
const;
803 #ifdef ESYS_HAVE_PASO 806 bool reducedColOrder)
const;
809 #ifdef ESYS_HAVE_TRILINOS 810 esys_trilinos::const_TrilinosGraph_ptr getTrilinosGraph(
bool reducedOrder)
const;
814 void glueFaces(
double safetyFactor,
double tolerance,
bool optimize);
816 void joinFaces(
double safetyFactor,
double tolerance,
bool optimize);
840 template<
typename Scalar>
844 #ifdef ESYS_HAVE_PASO 846 bool reducedColOrder)
const;
848 #ifdef ESYS_HAVE_TRILINOS 849 esys_trilinos::GraphType* createTrilinosGraph(
bool reducedOrder)
const;
853 void markNodes(std::vector<short>& mask,
index_t offset,
bool useLinear)
const;
858 int* elem0,
int* elem1,
int* matchingNodes)
const;
861 const std::string& defaultType,
bool full)
const;
864 const std::string& defaultType)
const;
886 #ifdef ESYS_HAVE_PASO 893 #ifdef ESYS_HAVE_TRILINOS 894 mutable esys_trilinos::TrilinosGraph_ptr m_fullGraph;
895 mutable esys_trilinos::TrilinosGraph_ptr m_reducedGraph;
903 #endif // __FINLEY_DOMAIN_H__ virtual void setToSize(escript::Data &out) const
copies the size of samples into out. The actual function space to be considered is defined by out...
Definition: finley/src/FinleyDomain.cpp:1819
ElementFile * getPoints() const
returns a pointer to this domain's point (nodal) element file
Definition: finley/src/FinleyDomain.h:332
AbstractContinuousDomain, base class for continuous domains.
Definition: AbstractContinuousDomain.h:45
Definition: FunctionSpace.h:34
void writeElementInfo(std::ostream &stream, const ElementFile *e, const std::string &defaultType) const
Definition: finley/src/Mesh_write.cpp:33
void relabelElementNodes(const IndexVector &newNode, index_t offset)
Definition: finley/src/FinleyDomain.cpp:201
Definition: finley/src/FinleyDomain.h:85
escript::ATP_ptr newTransportProblem(int blocksize, const escript::FunctionSpace &functionspace, int type) const
creates a TransportProblem
Definition: finley/src/FinleyDomain.cpp:1963
virtual int getSystemMatrixTypeId(const boost::python::object &options) const
return the identifier of the matrix type to be used for the global stiffness matrix when a particular...
Definition: finley/src/FinleyDomain.cpp:2303
double l2(dim_t n, const double *x, escript::JMPI mpiinfo)
returns the global L2 norm of x
Definition: PasoUtil.cpp:501
virtual void setNewX(const escript::Data &arg)
assigns new location to the domain
Definition: finley/src/FinleyDomain.cpp:1857
virtual escript::Data getX() const
returns locations in the FEM nodes
Definition: finley/src/FinleyDomain.cpp:2375
void Print_Mesh_Info(bool full=false) const
Definition: finley/src/Mesh_write.cpp:147
Definition: finley/src/FinleyDomain.h:82
std::map< std::string, int > TagMap
Definition: finley/src/FinleyDomain.h:79
int getTagFromSampleNo(int functionSpaceType, index_t sampleNo) const
Return the tag key for the given sample number.
Definition: finley/src/FinleyDomain.cpp:2431
ElementFile * getFaceElements() const
returns a pointer to this domain's face element file
Definition: finley/src/FinleyDomain.h:308
void optimizeDOFDistribution(IndexVector &distribution)
Definition: finley/src/Mesh_optimizeDOFDistribution.cpp:65
ElementFile * m_points
the table of points (treated as elements of dimension 0)
Definition: finley/src/FinleyDomain.h:883
void glueFaces(double safetyFactor, double tolerance, bool optimize)
Definition: Mesh_glueFaces.cpp:32
ElementFile * m_faceElements
the table of face elements
Definition: finley/src/FinleyDomain.h:879
virtual void setTags(int functionSpaceType, int newTag, const escript::Data &mask) const
assigns new tag newTag to all samples of functionspace with a positive value of mask for any its samp...
Definition: finley/src/FinleyDomain.cpp:2471
void setToIntegralsWorker(std::vector< Scalar > &integrals, const escript::Data &arg) const
Definition: finley/src/FinleyDomain.cpp:1710
int numDim
number of spatial dimensions
Definition: finley/src/NodeFile.h:161
boost::shared_ptr< AbstractDomain > Domain_ptr
Definition: AbstractDomain.h:36
virtual void interpolateOnDomain(escript::Data &target, const escript::Data &source) const
interpolates data given on source onto target where source and target have to be given on the same do...
Definition: finley/src/FinleyDomain.cpp:1249
FinleyDomain implements the AbstractContinuousDomain interface for the Finley library.
Definition: finley/src/FinleyDomain.h:93
NodeFile * getNodes() const
returns a pointer to this domain's node file
Definition: finley/src/FinleyDomain.h:284
void joinFaces(double safetyFactor, double tolerance, bool optimize)
Definition: Mesh_joinFaces.cpp:32
virtual void setToIntegrals(std::vector< escript::DataTypes::real_t > &integrals, const escript::Data &arg) const
copies the integrals of the function defined by arg into integrals. arg has to be defined on this...
escript::JMPI m_mpiInfo
MPI information.
Definition: finley/src/FinleyDomain.h:867
void prepare(bool optimize)
prepares the mesh for further use
Definition: finley/src/FinleyDomain.cpp:2684
int integrationOrder
Definition: finley/src/FinleyDomain.h:872
virtual std::string functionSpaceTypeAsString(int functionSpaceType) const
Return a description for the given function space type code.
Definition: finley/src/FinleyDomain.cpp:930
ElementFile * getElements() const
returns a pointer to this domain's element file
Definition: finley/src/FinleyDomain.h:296
virtual bool isValidFunctionSpaceType(int functionSpaceType) const
Returns true if the given integer is a valid function space type for this domain. ...
Definition: finley/src/FinleyDomain.cpp:941
virtual int getDiracDeltaFunctionsCode() const
Return a DiracDeltaFunctions code.
Definition: finley/src/FinleyDomain.cpp:1038
std::vector< index_t > IndexVector
Definition: DataTypes.h:62
virtual void addPDEToSystem(escript::AbstractSystemMatrix &mat, escript::Data &rhs, const escript::Data &A, const escript::Data &B, const escript::Data &C, const escript::Data &D, const escript::Data &X, const escript::Data &Y, const escript::Data &d, const escript::Data &y, const escript::Data &d_contact, const escript::Data &y_contact, const escript::Data &d_dirac, const escript::Data &y_dirac) const
adds a PDE onto the stiffness matrix mat and a rhs
Definition: finley/src/FinleyDomain.cpp:1137
boost::shared_ptr< JMPI_ > JMPI
Definition: EsysMPI.h:71
virtual int getFunctionCode() const
Return a function FunctionSpace code.
Definition: finley/src/FinleyDomain.cpp:988
virtual void setToNormal(escript::Data &out) const
copies the surface normals at data points into out. The actual function space to be considered is def...
Definition: finley/src/FinleyDomain.cpp:1663
static escript::Domain_ptr createHex20(dim_t NE0, dim_t NE1, dim_t NE2, double l0, double l1, double l2, bool periodic0, bool periodic1, bool periodic2, int order, int reducedOrder, bool useElementsOnFace, bool useFullElementOrder, bool useMacroElements, bool optimize, escript::JMPI jmpi)
Creates a 3-dimensional rectangular domain with second order (Hex20 or Hex27) elements.
Definition: Mesh_hex20.cpp:38
virtual std::string showTagNames() const
Returns all tag names in a single string sperated by commas.
Definition: finley/src/FinleyDomain.cpp:2529
void resolveNodeIds()
Definition: finley/src/FinleyDomain.cpp:2872
void markNodes(std::vector< short > &mask, index_t offset, bool useLinear) const
Definition: finley/src/FinleyDomain.cpp:192
std::vector< int > ShapeType
The shape of a single datapoint.
Definition: DataTypes.h:42
virtual void interpolateAcross(escript::Data &target, const escript::Data &source) const
interpolates data given on source onto target where source and target are given on different domains...
Definition: finley/src/FinleyDomain.cpp:1687
static dim_t M
Definition: SparseMatrix_saveHB.cpp:37
virtual int getSolutionCode() const
Return a Solution code.
Definition: finley/src/FinleyDomain.cpp:1028
static FunctionSpaceNamesMapType m_functionSpaceTypeNames
Definition: finley/src/FinleyDomain.h:898
virtual bool probeInterpolationAcross(int functionSpaceType_source, const escript::AbstractDomain &targetDomain, int functionSpaceType_target) const
determines whether interpolation from source to target is possible.
Definition: finley/src/FinleyDomain.cpp:2279
virtual std::string getDescription() const
Return a description for this domain.
Definition: finley/src/FinleyDomain.cpp:925
A suite of factory methods for creating various finley domains.
Definition: finley/src/Assemble.h:31
virtual int getMPISize() const
returns the number of processors used for this domain
Definition: finley/src/FinleyDomain.h:344
virtual void addPDEToTransportProblem(escript::AbstractTransportProblem &tp, escript::Data &source, const escript::Data &M, const escript::Data &A, const escript::Data &B, const escript::Data &C, const escript::Data &D, const escript::Data &X, const escript::Data &Y, const escript::Data &d, const escript::Data &y, const escript::Data &d_contact, const escript::Data &y_contact, const escript::Data &d_dirac, const escript::Data &y_dirac) const
adds a PDE onto a transport problem
Definition: finley/src/FinleyDomain.cpp:1208
boost::shared_ptr< SystemMatrixPattern > SystemMatrixPattern_ptr
Definition: SystemMatrixPattern.h:39
boost::shared_ptr< AbstractTransportProblem > ATP_ptr
Definition: AbstractTransportProblem.h:160
virtual int getReducedFunctionCode() const
Return a function with reduced integration order FunctionSpace code.
Definition: finley/src/FinleyDomain.cpp:993
static escript::Domain_ptr readGmsh(escript::JMPI mpiInfo, const std::string &filename, int numDim, int integrationOrder=-1, int reducedIntegrationOrder=-1, bool optimize=false, bool useMacroElements=false)
reads a gmsh mesh file.
Definition: finley/src/Mesh_readGmsh.cpp:1149
void optimizeElementOrdering()
redistributes elements to minimize communication during assemblage
Definition: finley/src/FinleyDomain.cpp:2963
bool commonFunctionSpace(const std::vector< int > &fs, int &resultcode) const
given a vector of FunctionSpace typecodes, pass back a code which then can all be interpolated to...
Definition: finley/src/FinleyDomain.cpp:2020
virtual escript::Data getSize() const
returns the element size
Definition: finley/src/FinleyDomain.cpp:2385
virtual int getFunctionOnBoundaryCode() const
Return a function on boundary FunctionSpace code.
Definition: finley/src/FinleyDomain.cpp:998
virtual bool onMasterProcessor() const
returns true if on MPI processor 0, else false
Definition: finley/src/FinleyDomain.h:362
virtual const int * borrowListOfTagsInUse(int functionSpaceCode) const
Definition: finley/src/FinleyDomain.cpp:2573
int index_t
type for array/matrix indices used both globally and on each rank
Definition: DataTypes.h:59
void distributeByRankOfDOF(const IndexVector &distribution)
Definition: finley/src/FinleyDomain.cpp:2741
void findMatchingFaces(double safetyFactor, double tolerance, int *numPairs, int *elem0, int *elem1, int *matchingNodes) const
Definition: Mesh_findMatchingFaces.cpp:68
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:2508
std::string m_name
domain description
Definition: finley/src/FinleyDomain.h:869
static FinleyDomain * merge(const std::vector< const FinleyDomain *> &meshes)
Definition: Mesh_merge.cpp:24
virtual bool isValidTagName(const std::string &name) const
Returns true if name is a defined tag name.
Definition: finley/src/FinleyDomain.cpp:2524
virtual bool operator==(const escript::AbstractDomain &other) const
comparison operators
Definition: finley/src/FinleyDomain.cpp:2285
virtual bool canTag(int functionSpaceCode) const
Checks if this domain allows tags for the specified functionSpace code.
Definition: finley/src/FinleyDomain.cpp:2619
virtual bool probeInterpolationOnDomain(int functionSpaceType_source, int functionSpaceType_target) const
True if interpolation is possible from source to target.
Definition: finley/src/FinleyDomain.cpp:2141
void setFaceElements(ElementFile *elements)
replaces the face element file by elements
Definition: finley/src/FinleyDomain.cpp:126
virtual int getReducedFunctionOnBoundaryCode() const
Return a function on boundary with reduced integration order FunctionSpace code.
Definition: finley/src/FinleyDomain.cpp:1003
virtual int getDim() const
returns the dimensionality of this domain
Definition: finley/src/FinleyDomain.h:513
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:48
std::map< int, std::string > FunctionSpaceNamesMapType
Definition: finley/src/FinleyDomain.h:508
virtual escript::JMPI getMPI() const
returns a reference to the MPI information wrapper for this domain
Definition: finley/src/FinleyDomain.h:338
int StatusType
Definition: AbstractDomain.h:48
virtual int getApproximationOrder(int functionSpaceCode) const
returns the approximation order used for a function space functionSpaceCode
Definition: finley/src/FinleyDomain.cpp:2643
ElementFile * getContactElements() const
returns a pointer to this domain's contact element file
Definition: finley/src/FinleyDomain.h:320
virtual bool isCellOriented(int functionSpaceCode) const
returns true if data on this domain and a function space of type functionSpaceCode has to considered ...
Definition: finley/src/FinleyDomain.cpp:1995
int reducedApproximationOrder
Definition: finley/src/FinleyDomain.h:871
Data represents a collection of datapoints.
Definition: Data.h:63
void createMappings(const IndexVector &dofDistribution, const IndexVector &nodeDistribution)
Definition: finley/src/FinleyDomain.cpp:183
virtual std::pair< int, dim_t > getDataShape(int functionSpaceCode) const
Return the number of data points per sample, and the number of samples as a pair. ...
Definition: finley/src/FinleyDomain.cpp:1055
virtual int getContinuousFunctionCode() const
Return a continuous FunctionSpace code.
Definition: finley/src/FinleyDomain.cpp:978
Definition: finley/src/NodeFile.h:40
virtual int getTag(const std::string &name) const
Return the tag key for tag name.
Definition: finley/src/FinleyDomain.cpp:2513
int reducedIntegrationOrder
Definition: finley/src/FinleyDomain.h:873
void printElementInfo(const ElementFile *e, const std::string &title, const std::string &defaultType, bool full) const
Definition: finley/src/Mesh_write.cpp:52
virtual int getReducedSolutionCode() const
Return a ReducedSolution code.
Definition: finley/src/FinleyDomain.cpp:1033
const TagMap & getTagMap() const
returns a reference to the tag name->value map
Definition: finley/src/FinleyDomain.h:798
void setElements(ElementFile *elements)
replaces the element file by elements
Definition: finley/src/FinleyDomain.cpp:120
virtual int getMPIRank() const
returns the number MPI rank of this processor
Definition: finley/src/FinleyDomain.h:350
static escript::Domain_ptr createRec4(dim_t NE0, dim_t NE1, double L0, double L1, bool periodic0, bool periodic1, int order, int reducedOrder, bool useElementsOnFace, bool optimize, escript::JMPI jmpi)
Creates a 2-dimensional rectangular domain with first order (Rec4) elements in the rectangle [0...
Definition: Mesh_rec4.cpp:25
void optimizeDOFLabeling(const IndexVector &distribution)
optimizes the labeling of the DOFs on each processor
Definition: finley/src/FinleyDomain.cpp:2791
Definition: finley/src/FinleyDomain.h:84
void setFunctionSpaceTypeNames()
Build the table of function space type names.
Definition: finley/src/FinleyDomain.cpp:948
void setOrders()
Definition: finley/src/FinleyDomain.cpp:144
virtual void MPIBarrier() const
If compiled for MPI then execute an MPI_Barrier, else do nothing.
Definition: finley/src/FinleyDomain.cpp:113
virtual void addPDEToLumpedSystem(escript::Data &mat, const escript::Data &D, const escript::Data &d, const escript::Data &d_dirac, bool useHRZ) const
adds a PDE onto the lumped stiffness matrix matrix
Definition: finley/src/FinleyDomain.cpp:1170
int MPI_Comm
Definition: EsysMPI.h:41
static escript::Domain_ptr load(const std::string &filename)
recovers domain from a dump file
Definition: finley/src/DomainFactory.cpp:490
MPI_Comm getMPIComm() const
get the communicator for this domain. Returns an integer on non-MPI builds Routine must be implemente...
Definition: finley/src/FinleyDomain.h:364
static escript::Domain_ptr read(escript::JMPI mpiInfo, const std::string &fileName, int integrationOrder=-1, int reducedIntegrationOrder=-1, bool optimize=false)
reads a mesh from a fly file. For MPI parallel runs fans out the mesh to multiple processes...
Definition: finley/src/Mesh_read.cpp:152
virtual bool ownSample(int fsCode, index_t id) const
Definition: finley/src/FinleyDomain.cpp:1870
virtual int getReducedFunctionOnContactZeroCode() const
Return a FunctionOnContactZero code with reduced integration order.
Definition: finley/src/FinleyDomain.cpp:1013
void setContactElements(ElementFile *elements)
replaces the contact element file by elements
Definition: finley/src/FinleyDomain.cpp:132
Give a short description of what AbstractTransportProblem does.
Definition: AbstractTransportProblem.h:43
void setPoints(ElementFile *elements)
replaces the point element file by elements
Definition: finley/src/FinleyDomain.cpp:138
virtual int getTransportTypeId(int solver, int preconditioner, int package, bool symmetry) const
return the identifier of the transport problem type to be used when a particular solver, perconditioner, package and symmetric matrix is used.
Definition: finley/src/FinleyDomain.cpp:2363
virtual void setToX(escript::Data &arg) const
copies the location of data points into arg. The domain of arg has to match this. has to be implement...
Definition: finley/src/FinleyDomain.cpp:1644
virtual int getFunctionOnContactZeroCode() const
Return a FunctionOnContactZero code.
Definition: finley/src/FinleyDomain.cpp:1008
virtual StatusType getStatus() const
Returns a status indicator of the domain. The status identifier should be unique over the live time i...
Definition: finley/src/FinleyDomain.cpp:2638
virtual void setToGradient(escript::Data &grad, const escript::Data &arg) const
copies the gradient of arg into grad. The actual function space to be considered for the gradient is ...
Definition: finley/src/FinleyDomain.cpp:1753
escript::ASM_ptr newSystemMatrix(int row_blocksize, const escript::FunctionSpace &row_functionspace, int column_blocksize, const escript::FunctionSpace &column_functionspace, int type) const
creates a stiffness matrix and initializes it with zeros
Definition: finley/src/FinleyDomain.cpp:1900
ElementFile * m_contactElements
the table of contact elements
Definition: finley/src/FinleyDomain.h:881
Base class for escript system matrices.
Definition: AbstractSystemMatrix.h:42
ElementFile * m_elements
the table of the elements
Definition: finley/src/FinleyDomain.h:877
static escript::Domain_ptr createRec8(dim_t NE0, dim_t NE1, double l0, double l1, bool periodic0, bool periodic1, int order, int reducedOrder, bool useElementsOnFace, bool useFullElementOrder, bool useMacroElements, bool optimize, escript::JMPI jmpi)
Creates a 2-dimensional rectangular domain with second order (Rec8 or Rec9) elements in the rectangle...
Definition: Mesh_rec8.cpp:25
TagMap m_tagMap
the tag map mapping names to tag keys
Definition: finley/src/FinleyDomain.h:885
void createColoring(const IndexVector &dofMap)
tries to reduce the number of colours for all element files
Definition: finley/src/FinleyDomain.cpp:2954
void updateTagList()
regenerates list of tags in use for node file and element files
Definition: finley/src/FinleyDomain.cpp:2972
virtual escript::Data getNormal() const
returns boundary normals at the quadrature point on the face elements
Definition: finley/src/FinleyDomain.cpp:2380
void dump(const std::string &fileName) const
dumps the mesh to a file with the given name.
Definition: finley/src/FinleyDomain.cpp:562
boost::shared_ptr< AbstractSystemMatrix > ASM_ptr
Definition: AbstractSystemMatrix.h:32
static escript::Domain_ptr createHex8(dim_t NE0, dim_t NE1, dim_t NE2, double l0, double l1, double l2, bool periodic0, bool periodic1, bool periodic2, int order, int reducedOrder, bool useElementsOnFace, bool optimize, escript::JMPI jmpi)
Creates a 3-dimensional rectangular domain with first order (Hex8) elements.
Definition: Mesh_hex8.cpp:39
FinleyDomain(const std::string &name, int numDim, escript::JMPI jmpi)
Constructor for FinleyDomain.
Definition: finley/src/FinleyDomain.cpp:71
Definition: finley/src/FinleyDomain.h:83
const index_t * borrowSampleReferenceIDs(int functionSpaceType) const
Return the reference number of the given sample number.
Definition: finley/src/FinleyDomain.cpp:2390
SystemMatrixType
Definition: finley/src/FinleyDomain.h:81
Base class for all escript domains.
Definition: AbstractDomain.h:45
virtual dim_t getNumDataPointsGlobal() const
Return the number of data points summed across all MPI processes.
Definition: finley/src/FinleyDomain.cpp:1046
virtual int getReducedFunctionOnContactOneCode() const
Return a FunctionOnContactOne code with reduced integration order.
Definition: finley/src/FinleyDomain.cpp:1023
void write(const std::string &fileName) const
writes the current mesh to a file with the given name in the fly file format.
Definition: finley/src/Mesh_write.cpp:87
virtual bool supportsContactElements() const
Definition: finley/src/FinleyDomain.h:788
virtual int getNumberOfTagsInUse(int functionSpaceCode) const
returns the number of tags in use and a pointer to an array with the number of tags in use ...
Definition: finley/src/FinleyDomain.cpp:2542
virtual int getFunctionOnContactOneCode() const
Return a FunctionOnContactOne code.
Definition: finley/src/FinleyDomain.cpp:1018
virtual void addPDEToRHS(escript::Data &rhs, const escript::Data &X, const escript::Data &Y, const escript::Data &y, const escript::Data &y_contact, const escript::Data &y_dirac) const
adds a PDE onto the stiffness matrix mat and a rhs
Definition: finley/src/FinleyDomain.cpp:1184
int approximationOrder
Definition: finley/src/FinleyDomain.h:870
virtual int getReducedContinuousFunctionCode() const
Return a continuous on reduced order nodes FunctionSpace code.
Definition: finley/src/FinleyDomain.cpp:983
virtual signed char preferredInterpolationOnDomain(int functionSpaceType_source, int functionSpaceType_target) const
Preferred direction of interpolation. If you really need to test for a particular direction...
Definition: finley/src/FinleyDomain.cpp:2268
NodeFile * m_nodes
the table of the nodes
Definition: finley/src/FinleyDomain.h:875
~FinleyDomain()
Destructor for FinleyDomain.
Definition: finley/src/FinleyDomain.cpp:104
index_t dim_t
Definition: DataTypes.h:64
Definition: finley/src/ElementFile.h:61
virtual bool operator!=(const escript::AbstractDomain &other) const
Return true if given domains are not equal.
Definition: finley/src/FinleyDomain.cpp:2298
virtual escript::Data randomFill(const escript::DataTypes::ShapeType &shape, const escript::FunctionSpace &what, long seed, const boost::python::tuple &filter) const
Fills the data object with filtered random values.
Definition: finley/src/FinleyDomain.cpp:2670