mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-16 01:31:59 -06:00
using UMFPACK for the function invDX
for better robustness. The iterative solvers require more improvement.
This commit is contained in:
parent
78a28abf91
commit
6366087efd
@ -22,7 +22,9 @@
|
|||||||
#ifndef OPM_MSWELLHELPERS_HEADER_INCLUDED
|
#ifndef OPM_MSWELLHELPERS_HEADER_INCLUDED
|
||||||
#define OPM_MSWELLHELPERS_HEADER_INCLUDED
|
#define OPM_MSWELLHELPERS_HEADER_INCLUDED
|
||||||
|
|
||||||
#include <dune/istl/solvers.hh>
|
#include <opm/common/ErrorMacros.hpp>
|
||||||
|
// #include <dune/istl/solvers.hh>
|
||||||
|
#include <dune/istl/umfpack.hh>
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
|
|
||||||
namespace Opm {
|
namespace Opm {
|
||||||
@ -44,23 +46,34 @@ namespace mswellhelpers
|
|||||||
VectorType y(x.size());
|
VectorType y(x.size());
|
||||||
y = 0.;
|
y = 0.;
|
||||||
|
|
||||||
Dune::MatrixAdapter<MatrixType, VectorType, VectorType> linearOperator(D);
|
/* Dune::MatrixAdapter<MatrixType, VectorType, VectorType> linearOperator(D);
|
||||||
|
|
||||||
// Sequential incomplete LU decomposition as the preconditioner
|
// Sequential incomplete LU decomposition as the preconditioner
|
||||||
Dune::SeqILU0<MatrixType, VectorType, VectorType> preconditioner(D, 1.0);
|
Dune::SeqILU0<MatrixType, VectorType, VectorType> preconditioner(D, 1.0);
|
||||||
|
// Dune::SeqILUn<MatrixType, VectorType, VectorType> preconditioner(D, 1, 0.92);
|
||||||
|
// Dune::SeqGS<MatrixType, VectorType, VectorType> preconditioner(D, 1, 1);
|
||||||
|
// Dune::SeqJac<MatrixType, VectorType, VectorType> preconditioner(D, 1, 1);
|
||||||
|
|
||||||
// Preconditioned BICGSTAB solver
|
// Preconditioned BICGSTAB solver
|
||||||
Dune::BiCGSTABSolver<VectorType> linsolver(linearOperator,
|
Dune::BiCGSTABSolver<VectorType> linsolver(linearOperator,
|
||||||
preconditioner,
|
preconditioner,
|
||||||
1.e-6, // desired residual reduction factor
|
// 1.e-8, // desired residual reduction factor
|
||||||
50, // maximum number of iterations
|
// 1.e-6, // desired residual reduction factor
|
||||||
0); // verbosity of the solver
|
1.e-4, // desired residual reduction factor
|
||||||
|
150, // maximum number of iterations
|
||||||
|
0); // verbosity of the solver */
|
||||||
|
|
||||||
|
Dune::UMFPack<MatrixType> linsolver(D, 0);
|
||||||
|
|
||||||
// Object storing some statistics about the solving process
|
// Object storing some statistics about the solving process
|
||||||
Dune::InverseOperatorResult statistics ;
|
Dune::InverseOperatorResult res;
|
||||||
|
|
||||||
// Solve
|
// Solve
|
||||||
linsolver.apply(y, x, statistics );
|
linsolver.apply(y, x, res);
|
||||||
|
|
||||||
|
if ( !res.converged ) {
|
||||||
|
OPM_THROW(Opm::NumericalProblem, "the invDX does not get converged! ");
|
||||||
|
}
|
||||||
|
|
||||||
return y;
|
return y;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user