Teuchos Package Browser (Single Doxygen Collection)
Version of the Day
|
Namespaces | |
Impl | |
Implementation details of implementation details. | |
Classes | |
class | LinearSolver |
Interface for a method for solving linear system(s) AX=B. More... | |
class | LinearSolverFactory |
Interface for a "factory" that creates solvers. More... | |
Functions | |
template<class MV , class OP , class NormType > | |
Teuchos::RCP< LinearSolver< MV, OP, NormType > > | getLinearSolver (const std::string &packageName, const std::string &solverName) |
Get a LinearSolver instance. More... | |
template<class MV , class OP , class NormType > | |
void | registerLinearSolverFactory (const std::string &packageName, const Teuchos::RCP< LinearSolverFactory< MV, OP, NormType > > &factory) |
Called by a package to register its LinearSolverFactory. More... | |
Teuchos::RCP< LinearSolver< MV, OP, NormType > > Trilinos::Details::getLinearSolver | ( | const std::string & | packageName, |
const std::string & | solverName | ||
) |
Get a LinearSolver instance.
MV | Type of a (multi)vector, representing either the solution(s) X or the right-hand side(s) B of a linear system AX=B. For example, with Tpetra, use a Tpetra::MultiVector specialization. A multivector is a single data structure containing zero or more vectors with the same dimensions and layout. |
OP | Type of a matrix or linear operator that this Solver understands. For example, for Tpetra, use a Tpetra::Operator specialization. |
NormType | Type of the norm of the residual. See the documentation of LinearSolver for details. |
Call this function to create a LinearSolver instance from a particular package. LinearSolvers may create LinearSolvers. The run-time registration system (see registerLinearSolverFactory() below) breaks software dependencies between packages. Thus, Package A may create a LinearSolver from Package B, even if Package B depends on Package A.
packageName | [in] Name of the package from which to get the solver. Names are case sensitive. |
solverName | [in] The solver's name. Names are case sensitive. |
Definition at line 519 of file Trilinos_Details_LinearSolverFactory.hpp.
void Trilinos::Details::registerLinearSolverFactory | ( | const std::string & | packageName, |
const Teuchos::RCP< LinearSolverFactory< MV, OP, NormType > > & | factory | ||
) |
Called by a package to register its LinearSolverFactory.
registerLinearSolverFactory
MV | Type of a (multi)vector, representing either the solution(s) X or the right-hand side(s) B of a linear system AX=B. For example, with Tpetra, use a Tpetra::MultiVector specialization. A multivector is a single data structure containing zero or more vectors with the same dimensions and layout. |
OP | Type of a matrix or linear operator that the LinearSolver instances to create understand. For example, for Tpetra, use a Tpetra::Operator specialization. |
NormType | Type of the norm of the residual. See the documentation of LinearSolver for details. |
packageName | [in] Name of the package registering the factory. Package names are case sensitive. |
factory | [in] That package's factory. |
This function lets packages register themselves, so that getLinearSolver() (see above) can create solvers from that package. A package "registers itself" by doing the following:
Packages may call this function before main() runs. In fact, we prefer that they do so. This ensures that any package will be able to create solvers from that package, without users or other packages needing to know about that package. When people talk about "dependency injection" or "dependency inversion," this is what they mean.
This function is templated with the same template parameters as LinearSolverFactory. This means that it must be called for every combination of types (MV, OP) for which code will instantiate a LinearSolverFactory<MV, OP, NormType>. Thus, if the solver package wants to do this before main() runs, it needs a list of all type combination in advance. If using explicit template instantiation (ETI), you may plug this into the ETI system. We thus recommend that packages that use ETI register a LinearSolverFactory instance for each ETI type combination. For example, Ifpack2 should iterate over all enabled combinations of the four template parameters S, LO, GO, NT of Ifpack2::Preconditioner, creating a LinearSolverFactory<MV, OP, NormType> instance for each combination, with MV = Tpetra::MultiVector<S, LO, GO, NT> and OP = Tpetra::Operator<S, LO, GO, NT>. Package developers may find it useful to write a macro that does this for that package's LinearSolverFactory subclass.
If packages do not register a factory for certain type combinations that users need, users may in rare instances need to call this function themselves. Avoid doing this, because it defeats dependency inversion.
It could very well be that some packages don't implement all desired type combinations MV, OP. In that case, those packages would not register a factory for those types. Users who request solvers from those packages for forbidden type combinations would get a run-time error.
Definition at line 506 of file Trilinos_Details_LinearSolverFactory.hpp.