escript  Revision_4925
DefaultAssembler3D.h
Go to the documentation of this file.
1 
2 /*****************************************************************************
3 *
4 * Copyright (c) 2003-2014 by University of Queensland
5 * http://www.uq.edu.au
6 *
7 * Primary Business: Queensland, Australia
8 * Licensed under the Open Software License version 3.0
9 * http://www.opensource.org/licenses/osl-3.0.php
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 #ifndef __RIPLEY_DEFAULTASSEMBLER3D_H__
17 #define __RIPLEY_DEFAULTASSEMBLER3D_H__
18 
19 #include <map>
20 #include <escript/Data.h>
21 #include <ripley/Ripley.h>
22 #include <ripley/RipleyException.h>
23 #include <ripley/AbstractAssembler.h>
24 #include <ripley/Brick.h>
25 
26 namespace ripley {
27 
28 
30 public:
33  domain = dom;
34  this->m_dx = m_dx;
35  this->m_NX = m_NX;
36  this->m_NE = m_NE;
37  this->m_NN = m_NN;
38  }
40  /* The default RipleyDomain assemblers, with original signatures */
41 
45  escript::Data& rhs,
46  const escript::Data& A, const escript::Data& B,
47  const escript::Data& C, const escript::Data& D,
48  const escript::Data& X, const escript::Data& Y) const;
49 
53  escript::Data& rhs, const escript::Data& d,
54  const escript::Data& y) const;
55 
59  escript::Data& rhs, const escript::Data& A, const escript::Data& B,
60  const escript::Data& C, const escript::Data& D,
61  const escript::Data& X, const escript::Data& Y) const;
62 
66  escript::Data& rhs, const escript::Data& d,
67  const escript::Data& y) const;
68 
72  const escript::Data& A, const escript::Data& B,
73  const escript::Data& C, const escript::Data& D,
74  const escript::Data& X, const escript::Data& Y) const;
75 
79  escript::Data& rhs, const escript::Data& d,
80  const escript::Data& y) const;
81 
85  escript::Data& rhs, const escript::Data& A, const escript::Data& B,
86  const escript::Data& C, const escript::Data& D,
87  const escript::Data& X, const escript::Data& Y) const;
88 
92  escript::Data& rhs, const escript::Data& d,
93  const escript::Data& y) const;
94 
95  /* The new interface for assemblers */
97  std::map<std::string, escript::Data> coefs) const;
99  escript::Data& rhs,
100  std::map<std::string, escript::Data> coefs) const;
102  escript::Data& rhs,
103  std::map<std::string, escript::Data> coefs) const;
105  escript::Data& rhs,
106  std::map<std::string, escript::Data> coefs) const;
108  std::map<std::string, escript::Data> coefs) const;
110  escript::Data& rhs,
111  std::map<std::string, escript::Data> coefs) const;
113  escript::Data& rhs,
114  std::map<std::string, escript::Data> coefs) const;
116  escript::Data& rhs,
117  std::map<std::string, escript::Data> coefs) const;
118 
119  void collateFunctionSpaceTypes(std::vector<int>& fsTypes,
120  std::map<std::string, escript::Data> coefs) const;
121 protected:
122  const Brick *domain;
123  const double *m_dx;
124  const dim_t *m_NX;
125  const dim_t *m_NE;
126  const dim_t *m_NN;
127 };
128 
129 } // namespace ripley
130 
131 #endif // __RIPLEY_DEFAULTASSEMBLER3D_H__
132 
virtual void assemblePDEBoundarySingleReduced(paso::SystemMatrix_ptr mat, escript::Data &rhs, const escript::Data &d, const escript::Data &y) const
Definition: DefaultAssembler3D.cpp:5671
virtual void assemblePDEBoundarySystemReduced(paso::SystemMatrix_ptr mat, escript::Data &rhs, const escript::Data &d, const escript::Data &y) const
Definition: DefaultAssembler3D.cpp:6655
Definition: AbstractAssembler.h:35
virtual void assemblePDEBoundarySystem(paso::SystemMatrix_ptr mat, escript::Data &rhs, const escript::Data &d, const escript::Data &y) const
Definition: DefaultAssembler3D.cpp:5973
const dim_t * m_NN
Definition: DefaultAssembler3D.h:126
virtual void assemblePDESingleReduced(paso::SystemMatrix_ptr 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
Definition: DefaultAssembler3D.cpp:2177
boost::shared_ptr< SystemMatrix > SystemMatrix_ptr
Definition: SystemMatrix.h:38
const dim_t * m_NX
Definition: DefaultAssembler3D.h:124
const Brick * domain
Definition: DefaultAssembler3D.h:122
virtual void assemblePDESystemReduced(paso::SystemMatrix_ptr 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
Definition: DefaultAssembler3D.cpp:4665
Data represents a collection of datapoints.
Definition: Data.h:71
DefaultAssembler3D(Brick *dom, double *m_dx, dim_t *m_NX, dim_t *m_NE, dim_t *m_NN)
Definition: DefaultAssembler3D.h:31
virtual void assemblePDESystem(paso::SystemMatrix_ptr 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
Definition: DefaultAssembler3D.cpp:2551
void collateFunctionSpaceTypes(std::vector< int > &fsTypes, std::map< std::string, escript::Data > coefs) const
Definition: DefaultAssembler3D.cpp:23
Brick is the 3-dimensional implementation of a RipleyDomain.
Definition: Brick.h:29
virtual void assemblePDESingle(paso::SystemMatrix_ptr 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
Definition: DefaultAssembler3D.cpp:105
Definition: DefaultAssembler3D.h:29
const double * m_dx
Definition: DefaultAssembler3D.h:123
~DefaultAssembler3D()
Definition: DefaultAssembler3D.h:39
virtual void assemblePDEBoundarySingle(paso::SystemMatrix_ptr mat, escript::Data &rhs, const escript::Data &d, const escript::Data &y) const
Definition: DefaultAssembler3D.cpp:5068
int dim_t
Definition: types.h:24
const dim_t * m_NE
Definition: DefaultAssembler3D.h:125