BEM++  2.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Groups Pages
default_iterative_solver.hpp
1 // Copyright (C) 2011-2012 by the BEM++ Authors
2 //
3 // Permission is hereby granted, free of charge, to any person obtaining a copy
4 // of this software and associated documentation files (the "Software"), to deal
5 // in the Software without restriction, including without limitation the rights
6 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7 // copies of the Software, and to permit persons to whom the Software is
8 // furnished to do so, subject to the following conditions:
9 //
10 // The above copyright notice and this permission notice shall be included in
11 // all copies or substantial portions of the Software.
12 //
13 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
19 // THE SOFTWARE.
20 
21 #ifndef bempp_default_iterative_solver_hpp
22 #define bempp_default_iterative_solver_hpp
23 
24 #include "../common/common.hpp"
25 #include "bempp/common/config_trilinos.hpp"
26 
27 #ifdef WITH_TRILINOS
28 
29 #include "solver.hpp"
30 
31 #include "belos_solver_wrapper_fwd.hpp" // for default parameter lists
32 #include "preconditioner.hpp"
33 
34 #include "../common/deprecated.hpp"
35 
36 #include <boost/scoped_ptr.hpp>
37 
38 namespace Thyra
39 {
41 template <typename ValueType> class PreconditionerBase;
43 } // namespace Thyra
44 
45 namespace Bempp
46 {
47 
48 
63 template <typename BasisFunctionType, typename ResultType>
64 class DefaultIterativeSolver : public Solver<BasisFunctionType, ResultType>
65 {
66 public:
68 
79  ConvergenceTestMode::Mode mode =
80  ConvergenceTestMode::TEST_CONVERGENCE_IN_DUAL_TO_RANGE);
81 
92  ConvergenceTestMode::Mode mode =
93  ConvergenceTestMode::TEST_CONVERGENCE_IN_DUAL_TO_RANGE);
94 
95  virtual ~DefaultIterativeSolver();
96 
109  const Preconditioner<ResultType>& preconditioner);
110 
118  void initializeSolver(const Teuchos::RCP<Teuchos::ParameterList>& paramList);
119 
129  void initializeSolver(const Teuchos::RCP<Teuchos::ParameterList>& paramList,
130  const Preconditioner<ResultType>& preconditioner);
131 
132 private:
133  virtual Solution<BasisFunctionType, ResultType> solveImplNonblocked(
135  virtual BlockedSolution<BasisFunctionType, ResultType> solveImplBlocked(
137  rhs) const;
138 
139 private:
140  struct Impl;
141  boost::scoped_ptr<Impl> m_impl;
142 };
143 
144 } // namespace Bempp
145 
146 #endif // WITH_TRILINOS
147 
148 #endif
#define BEMPP_DEPRECATED
Macro used to mark deprecated functions or classes.
Definition: deprecated.hpp:41
The abstract interface of solvers of boundary integral equations.
Definition: solver.hpp:50
DefaultIterativeSolver(const BoundaryOperator< BasisFunctionType, ResultType > &boundaryOp, ConvergenceTestMode::Mode mode=ConvergenceTestMode::TEST_CONVERGENCE_IN_DUAL_TO_RANGE)
Constructor of the DefaultIterativeSolver class.
Definition: default_iterative_solver.cpp:200
Boundary operator consisting of multiple blocks arranged in a matrix.
Definition: blocked_boundary_operator.hpp:46
Default iterative solver for boundary integral equations.
Definition: default_iterative_solver.hpp:64
Operator acting on functions defined on a surface.
Definition: boundary_operator.hpp:63
This class holds the solution of a BEM computation together with various associated information...
Definition: solution.hpp:38
A simple container class to hold pointers to preconditioners.
Definition: preconditioner.hpp:48
Function defined on a grid.
Definition: assembled_potential_operator.hpp:34
BEMPP_DEPRECATED void setPreconditioner(const Preconditioner< ResultType > &preconditioner)
Define a preconditioner.
Definition: default_iterative_solver.cpp:221
void initializeSolver(const Teuchos::RCP< Teuchos::ParameterList > &paramList)
Initialize a Belos iterative solver.
Definition: default_iterative_solver.cpp:228
This class holds the solution of a block operator system together with various information about the ...
Definition: blocked_solution.hpp:41