mirror of
https://github.com/OPM/opm-simulators.git
synced 2024-12-28 02:00:59 -06:00
Add dune ILU when using only one process
This commit is contained in:
parent
006aa14fbd
commit
8b5ab973e2
@ -167,6 +167,10 @@ struct StandardPreconditioners
|
|||||||
using M = typename F::Matrix;
|
using M = typename F::Matrix;
|
||||||
using V = typename F::Vector;
|
using V = typename F::Vector;
|
||||||
using P = PropertyTree;
|
using P = PropertyTree;
|
||||||
|
// TODO: add DuneILU with correct communicator
|
||||||
|
// F::addCreator("DuneILU", [](const O& op, const P& prm, const std::function<V()>&, std::size_t, const C& comm) {
|
||||||
|
// return wrapBlockPreconditioner<Dune::Preconditioner::SeqILU<M, V, V>>(comm, op.getmat());
|
||||||
|
// });
|
||||||
F::addCreator("ILU0", [](const O& op, const P& prm, const std::function<V()>&, std::size_t, const C& comm) {
|
F::addCreator("ILU0", [](const O& op, const P& prm, const std::function<V()>&, std::size_t, const C& comm) {
|
||||||
return createParILU(op, prm, comm, 0);
|
return createParILU(op, prm, comm, 0);
|
||||||
});
|
});
|
||||||
@ -176,6 +180,12 @@ struct StandardPreconditioners
|
|||||||
F::addCreator("ILUn", [](const O& op, const P& prm, const std::function<V()>&, std::size_t, const C& comm) {
|
F::addCreator("ILUn", [](const O& op, const P& prm, const std::function<V()>&, std::size_t, const C& comm) {
|
||||||
return createParILU(op, prm, comm, prm.get<int>("ilulevel", 0));
|
return createParILU(op, prm, comm, prm.get<int>("ilulevel", 0));
|
||||||
});
|
});
|
||||||
|
// F::addCreator("DuneILU", [](const O& op, const P& prm, const std::function<V()>&, std::size_t) {
|
||||||
|
// const double w = prm.get<double>("relaxation", 1.0);
|
||||||
|
// const int n = prm.get<int>("ilulevel", 0);
|
||||||
|
// const bool resort = prm.get<bool>("resort", false);
|
||||||
|
// return wrapBlockPreconditioner<Dune::SeqILU<M, V, V>>(op.getmat(), n, w, resort);
|
||||||
|
// });
|
||||||
F::addCreator("DILU", [](const O& op, const P& prm, const std::function<V()>&, std::size_t, const C& comm) {
|
F::addCreator("DILU", [](const O& op, const P& prm, const std::function<V()>&, std::size_t, const C& comm) {
|
||||||
DUNE_UNUSED_PARAMETER(prm);
|
DUNE_UNUSED_PARAMETER(prm);
|
||||||
return wrapBlockPreconditioner<MultithreadDILU<M, V, V>>(comm, op.getmat());
|
return wrapBlockPreconditioner<MultithreadDILU<M, V, V>>(comm, op.getmat());
|
||||||
@ -360,6 +370,12 @@ struct StandardPreconditioners<Operator,Dune::Amg::SequentialInformation>
|
|||||||
return std::make_shared<Opm::ParallelOverlappingILU0<M, V, V, C>>(
|
return std::make_shared<Opm::ParallelOverlappingILU0<M, V, V, C>>(
|
||||||
op.getmat(), 0, w, Opm::MILU_VARIANT::ILU);
|
op.getmat(), 0, w, Opm::MILU_VARIANT::ILU);
|
||||||
});
|
});
|
||||||
|
F::addCreator("DuneILU", [](const O& op, const P& prm, const std::function<V()>&, std::size_t) {
|
||||||
|
const double w = prm.get<double>("relaxation", 1.0);
|
||||||
|
const int n = prm.get<int>("ilulevel", 0);
|
||||||
|
const bool resort = prm.get<bool>("resort", false);
|
||||||
|
return wrapPreconditioner<Dune::SeqILU<M, V, V>>(op.getmat(), n, w, resort);
|
||||||
|
});
|
||||||
F::addCreator("ParOverILU0", [](const O& op, const P& prm, const std::function<V()>&, std::size_t) {
|
F::addCreator("ParOverILU0", [](const O& op, const P& prm, const std::function<V()>&, std::size_t) {
|
||||||
const double w = prm.get<double>("relaxation", 1.0);
|
const double w = prm.get<double>("relaxation", 1.0);
|
||||||
const int n = prm.get<int>("ilulevel", 0);
|
const int n = prm.get<int>("ilulevel", 0);
|
||||||
|
Loading…
Reference in New Issue
Block a user