Forked from
ogs / ogs
20055 commits behind the upstream repository.
-
Christoph Lehmann authoredChristoph Lehmann authored
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
EigenLinearSolver.cpp 5.44 KiB
/**
* \copyright
* Copyright (c) 2012-2016, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*
*/
#include "EigenLinearSolver.h"
#include <logog/include/logog.hpp>
#include "BaseLib/ConfigTree.h"
#include "EigenVector.h"
#include "EigenMatrix.h"
#include "EigenTools.h"
#include "MathLib/LinAlg/LinearSolverOptions.h"
namespace MathLib
{
// TODO change to LinearSolver
class EigenLinearSolverBase
{
public:
using Vector = EigenVector::RawVectorType;
using Matrix = EigenMatrix::RawMatrixType;
virtual ~EigenLinearSolverBase() = default;
//! Solves the linear equation system \f$ A x = b \f$ for \f$ x \f$.
virtual bool solve(Matrix &A, Vector const& b, Vector &x, EigenOption &opt) = 0;
};
namespace details
{
/// Template class for Eigen direct linear solvers
template <class T_SOLVER>
class EigenDirectLinearSolver final : public EigenLinearSolverBase
{
public:
bool solve(Matrix& A, Vector const& b, Vector& x, EigenOption& /*opt*/) override
{
INFO("-> solve");
if (!A.isCompressed()) A.makeCompressed();
_solver.compute(A);
if(_solver.info()!=Eigen::Success) {
ERR("Failed during Eigen linear solver initialization");
return false;
}
x = _solver.solve(b);
if(_solver.info()!=Eigen::Success) {
ERR("Failed during Eigen linear solve");
return false;
}
return true;
}
private:
T_SOLVER _solver;
};
/// Template class for Eigen iterative linear solvers
template <class T_SOLVER>