/usr/include/trilinos/Pike_Solver.hpp is in libtrilinos-pike-dev 12.10.1-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 | #ifndef PIKE_SOLVER_HPP
#define PIKE_SOLVER_HPP
#include "Pike_BlackBox_config.hpp"
#include "Teuchos_VerboseObject.hpp"
#include "Teuchos_Describable.hpp"
#include "Pike_StatusTest.hpp"
#include <vector>
namespace Teuchos {template<typename> class Comm;}
namespace pike {
class BlackBoxModelEvaluator;
class DataTransfer;
class SolverObserver;
/** \brief Pure virtual base class (strategy design pattern) for iterative solvers */
class Solver : public Teuchos::Describable,
public Teuchos::VerboseObject<pike::Solver> {
public:
virtual ~Solver() {}
/** \brief Optionally register a comm.
Some solvers provide the option to globally barrier between solver actions. For such solvers, set the comm with this method.
*/
virtual void registerComm(const Teuchos::RCP<const Teuchos::Comm<int> >& comm) = 0;
/** \brief Register an application/model evaluator with the solver.
Only allowed to be called before the call to completeRegistrion().
*/
virtual void registerModelEvaluator(const Teuchos::RCP<pike::BlackBoxModelEvaluator>& me) = 0;
/** \brief Register a DataTransfer with the solver.
Only allowed to be called before the call to completeRegistration().
*/
virtual void registerDataTransfer(const Teuchos::RCP<pike::DataTransfer>& dt) = 0;
/** \brief Finalizes the solver so that it can begin solving the problem.
Once this is called, the methods registerModelEvaluator() and
registerDataTransfer() can no longer be called.
*/
virtual void completeRegistration() = 0;
//! Returns the requested model evaluator.
virtual Teuchos::RCP<const pike::BlackBoxModelEvaluator> getModelEvaluator(const std::string& name) const = 0;
//! Returns all registered model evaluators.
virtual const std::vector<Teuchos::RCP<const pike::BlackBoxModelEvaluator> > getModelEvaluators() const = 0;
//! Return the requested data transfer.
virtual Teuchos::RCP<const pike::DataTransfer> getDataTransfer(const std::string& name) const = 0;
//! Return all registered data transfers.
virtual const std::vector<Teuchos::RCP<const pike::DataTransfer> > getDataTransfers() const = 0;
/** \brief Take one step of the solve iteration sequence.
@return Current SolveStatus.
*/
virtual pike::SolveStatus step() = 0;
/** \brief Initialize the system. This is typically used to
trigger one time initialization requirements in the
pike::SolverObserver::observeInitialization(). */
virtual void initialize() = 0;
//! Solve the system (step() until either converged or failed). Returns the current SolveStatus.
virtual pike::SolveStatus solve() = 0;
/** \brief Prepare to terminate the simulation. This is typically
used to trigger one time stopping requirements in the
pike::SolverObserver::observeFianlize(). */
virtual void finalize() = 0;
//! Reset the solver to reuse for another solve.
virtual void reset() = 0;
//! Returns the current SolveStatus.
virtual pike::SolveStatus getStatus() const = 0;
//! Returns the current number of iterations.
virtual int getNumberOfIterations() const = 0;
//! Register an observer with the solver.
virtual void addObserver(const Teuchos::RCP<pike::SolverObserver>& observer) = 0;
//! Returns the observers registered with the solver.
virtual std::vector<Teuchos::RCP<pike::SolverObserver> > getObservers() const = 0;
/** \brief Sets/overrides the status test to use with the solver.
Users can optionally set their own status tests via this
method. If no status test is set, then the solver will build
the status tests based on input parameters and/or defaults.
@param[in] statusTests The status test used to determine when to stop the solver.
*/
virtual void setStatusTests(const Teuchos::RCP<pike::StatusTest>& statusTests) = 0;
//! Returns the status tests.
virtual Teuchos::RCP<const pike::StatusTest> getStatusTests() const = 0;
/** \brief Returns the name of the solver. This is set by the
input parameter list. This can be used to debug hierarchical
solves.
*/
virtual std::string name() const = 0;
};
}
#endif
|