escript  Revision_4925
AbstractAssembler.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_ABSTRACTASSEMBLER_H__
17 #define __RIPLEY_ABSTRACTASSEMBLER_H__
18 
19 #include <map>
20 #include <escript/Data.h>
21 #include <ripley/Ripley.h>
22 #include <ripley/RipleyException.h>
23 #include <paso/SystemMatrix.h>
24 
25 namespace ripley {
26 
27 escript::Data unpackData(std::string target,
28  std::map<std::string, escript::Data> mapping);
29 
30 class RipleyDomain;
31 /* returns the data associated with the string key or an empty data object
32  if the map does not contain the given key */
33 escript::Data unpackData(std::string, std::map<std::string, escript::Data>);
34 
36 public:
37  virtual ~AbstractAssembler() {};
38  /* The default RipleyDomain assemblers, with original signatures */
39 
43  const escript::Data& A, const escript::Data& B,
44  const escript::Data& C, const escript::Data& D,
45  const escript::Data& X, const escript::Data& Y) const {
46  throw RipleyException("This assembler does not support "
47  "old style signatures");
48  }
49 
53  escript::Data& rhs, const escript::Data& d,
54  const escript::Data& y) const {
55  throw RipleyException("This assembler does not support "
56  "old style signatures");
57  }
58 
62  escript::Data& rhs, const escript::Data& A, const escript::Data& B,
63  const escript::Data& C, const escript::Data& D,
64  const escript::Data& X, const escript::Data& Y) const {
65  throw RipleyException("This assembler does not support "
66  "old style signatures");
67  }
68 
72  escript::Data& rhs, const escript::Data& d,
73  const escript::Data& y) const {
74  throw RipleyException("This assembler does not support "
75  "old style signatures");
76  }
77 
81  const escript::Data& A, const escript::Data& B,
82  const escript::Data& C, const escript::Data& D,
83  const escript::Data& X, const escript::Data& Y) {
84  throw RipleyException("This assembler does not support "
85  "old style signatures");
86  }
87 
91  escript::Data& rhs, const escript::Data& d,
92  const escript::Data& y) const {
93  throw RipleyException("This assembler does not support "
94  "old style signatures");
95  }
96 
100  escript::Data& rhs, const escript::Data& A, const escript::Data& B,
101  const escript::Data& C, const escript::Data& D,
102  const escript::Data& X, const escript::Data& Y) {
103  throw RipleyException("This assembler does not support "
104  "old style signatures");
105  }
106 
110  escript::Data& rhs, const escript::Data& d,
111  const escript::Data& y) const {
112  throw RipleyException("This assembler does not support "
113  "old style signatures");
114  }
115 
116  /* The new interface for assemblers */
117  virtual void assemblePDESingle(paso::SystemMatrix_ptr mat,
118  escript::Data& rhs,
119  std::map<std::string, escript::Data> coefs) const = 0;
121  escript::Data& rhs,
122  std::map<std::string, escript::Data> coefs) const = 0;
124  escript::Data& rhs,
125  std::map<std::string, escript::Data> coefs) const = 0;
127  escript::Data& rhs,
128  std::map<std::string, escript::Data> coefs) const = 0;
129  virtual void assemblePDESystem(paso::SystemMatrix_ptr mat,
130  escript::Data& rhs,
131  std::map<std::string, escript::Data> coefs) const = 0;
133  escript::Data& rhs,
134  std::map<std::string, escript::Data> coefs) const = 0;
136  escript::Data& rhs,
137  std::map<std::string, escript::Data> coefs) const = 0;
139  escript::Data& rhs,
140  std::map<std::string, escript::Data> coefs) const = 0;
141 
142  virtual void collateFunctionSpaceTypes(std::vector<int>& fsTypes,
143  std::map<std::string, escript::Data> coefs) const = 0;
144 };
145 
146 } // namespace ripley
147 
148 
149 #endif // __RIPLEY_ABSTRACTASSEMBLER_H__
150 
escript::Data unpackData(std::string target, std::map< std::string, escript::Data > mapping)
Definition: AbstractAssembler.cpp:19
Definition: AbstractAssembler.h:35
virtual ~AbstractAssembler()
Definition: AbstractAssembler.h:37
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: AbstractAssembler.h:61
void assemblePDEBoundarySystemReduced(paso::SystemMatrix_ptr mat, escript::Data &rhs, const escript::Data &d, const escript::Data &y) const
Definition: AbstractAssembler.h:109
void assemblePDEBoundarySingleReduced(paso::SystemMatrix_ptr mat, escript::Data &rhs, const escript::Data &d, const escript::Data &y) const
Definition: AbstractAssembler.h:71
RipleyException exception class.
Definition: RipleyException.h:29
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)
Definition: AbstractAssembler.h:99
boost::shared_ptr< SystemMatrix > SystemMatrix_ptr
Definition: SystemMatrix.h:38
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: AbstractAssembler.h:42
void assemblePDEBoundarySingle(paso::SystemMatrix_ptr mat, escript::Data &rhs, const escript::Data &d, const escript::Data &y) const
Definition: AbstractAssembler.h:52
Data represents a collection of datapoints.
Definition: Data.h:71
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)
Definition: AbstractAssembler.h:80
virtual void collateFunctionSpaceTypes(std::vector< int > &fsTypes, std::map< std::string, escript::Data > coefs) const =0
void assemblePDEBoundarySystem(paso::SystemMatrix_ptr mat, escript::Data &rhs, const escript::Data &d, const escript::Data &y) const
Definition: AbstractAssembler.h:90