diff --git a/MathLib/LinAlg/PETSc/PETScLinearSolver.cpp b/MathLib/LinAlg/PETSc/PETScLinearSolver.cpp index 065f76754273dc01274652d682a45738ef777d04..464ca35e549ef0596d12a2adfbe795d1a14fa18b 100644 --- a/MathLib/LinAlg/PETSc/PETScLinearSolver.cpp +++ b/MathLib/LinAlg/PETSc/PETScLinearSolver.cpp @@ -17,62 +17,9 @@ #include "PETScLinearSolver.h" #include "BaseLib/RunTime.h" -#include "MathLib/LinAlg/LinearSolverOptions.h" namespace MathLib { -PETScLinearSolver::PETScLinearSolver(const std::string /*prefix*/, - BaseLib::ConfigTree const* const option) -{ - // Insert options into petsc database. Default options are given in the - // string below. - std::string petsc_options = - "-ksp_type cg -pc_type bjacobi -ksp_rtol 1e-16 -ksp_max_it 10000"; - - std::string prefix; - - if (option) - { - ignoreOtherLinearSolvers(*option, "petsc"); - - //! \ogs_file_param{prj__linear_solvers__linear_solver__petsc} - if (auto const subtree = option->getConfigSubtreeOptional("petsc")) - { - if (auto const parameters = - //! \ogs_file_param{prj__linear_solvers__linear_solver__petsc__parameters} - subtree->getConfigParameterOptional<std::string>("parameters")) - { - petsc_options = *parameters; - } - - if (auto const pre = - //! \ogs_file_param{prj__linear_solvers__linear_solver__petsc__prefix} - subtree->getConfigParameterOptional<std::string>("prefix")) - { - if (!pre->empty()) - prefix = *pre + "_"; - } - } - } -#if PETSC_VERSION_LT(3, 7, 0) - PetscOptionsInsertString(petsc_options.c_str()); -#else - PetscOptionsInsertString(nullptr, petsc_options.c_str()); -#endif - - KSPCreate(PETSC_COMM_WORLD, &solver_); - - KSPGetPC(solver_, &pc_); - - if (!prefix.empty()) - { - KSPSetOptionsPrefix(solver_, prefix.c_str()); - } - - KSPSetInitialGuessNonzero(solver_, PETSC_TRUE); - KSPSetFromOptions(solver_); // set run-time options -} - PETScLinearSolver::PETScLinearSolver(std::string const& prefix, std::string const& petsc_options) { diff --git a/MathLib/LinAlg/PETSc/PETScLinearSolver.h b/MathLib/LinAlg/PETSc/PETScLinearSolver.h index 1690c95a5dc209f632575a0398d0a8cb32ade6a8..7b48d7012a3283040b57b7613f6c53275f768d03 100644 --- a/MathLib/LinAlg/PETSc/PETScLinearSolver.h +++ b/MathLib/LinAlg/PETSc/PETScLinearSolver.h @@ -16,12 +16,9 @@ #pragma once -#include <string> - #include <petscksp.h> - -#include "BaseLib/ConfigTree.h" +#include <string> #include "PETScMatrix.h" #include "PETScVector.h" @@ -38,16 +35,6 @@ namespace MathLib class PETScLinearSolver { public: - /*! - Constructor - \param prefix Name used to distinguish the options in the command - line for this solver. It can be the name of the PDE - that owns an instance of this class. - \param option Petsc options, which will be inserted into the global - petsc options database. - */ - PETScLinearSolver(const std::string prefix, - BaseLib::ConfigTree const* const option); /*! Constructor \param prefix Name used to distinguish the options in the command