mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-08 15:33:02 -06:00
c21fd6f26d
This replaces the makePreconditoner() function. The main advantage is that it is extensible, making it easy to for example add new preconditioners to the factory at runtime. It supports both parallel and serial preconditioners.
92 lines
2.5 KiB
C++
92 lines
2.5 KiB
C++
/*
|
|
Copyright 2019 SINTEF Digital, Mathematics and Cybernetics.
|
|
|
|
This file is part of the Open Porous Media project (OPM).
|
|
|
|
OPM is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
OPM is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with OPM. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef OPM_PRECONDITIONERWITHUPDATE_HEADER_INCLUDED
|
|
#define OPM_PRECONDITIONERWITHUPDATE_HEADER_INCLUDED
|
|
|
|
#include <dune/istl/preconditioner.hh>
|
|
#include <memory>
|
|
|
|
namespace Dune
|
|
{
|
|
|
|
/// Interface class adding the update() method to the preconditioner interface.
|
|
template <class X, class Y>
|
|
class PreconditionerWithUpdate : public Preconditioner<X, Y>
|
|
{
|
|
public:
|
|
virtual void update() = 0;
|
|
};
|
|
|
|
template <class OriginalPreconditioner>
|
|
class DummyUpdatePreconditioner : public PreconditionerWithUpdate<typename OriginalPreconditioner::domain_type,
|
|
typename OriginalPreconditioner::range_type>
|
|
{
|
|
public:
|
|
template <class... Args>
|
|
DummyUpdatePreconditioner(Args&&... args)
|
|
: orig_precond_(std::forward<Args>(args)...)
|
|
{
|
|
}
|
|
|
|
using X = typename OriginalPreconditioner::domain_type;
|
|
using Y = typename OriginalPreconditioner::range_type;
|
|
|
|
virtual void pre(X& x, Y& b) override
|
|
{
|
|
orig_precond_.pre(x, b);
|
|
}
|
|
|
|
virtual void apply(X& v, const Y& d) override
|
|
{
|
|
orig_precond_.apply(v, d);
|
|
}
|
|
|
|
virtual void post(X& x) override
|
|
{
|
|
orig_precond_.post(x);
|
|
}
|
|
|
|
virtual SolverCategory::Category category() const override
|
|
{
|
|
return orig_precond_.category();
|
|
}
|
|
|
|
// The update() function does nothing for a wrapped preconditioner.
|
|
virtual void update() override
|
|
{
|
|
}
|
|
|
|
private:
|
|
OriginalPreconditioner orig_precond_;
|
|
};
|
|
|
|
|
|
template <class OriginalPreconditioner, class... Args>
|
|
std::shared_ptr<DummyUpdatePreconditioner<OriginalPreconditioner>>
|
|
wrapPreconditioner(Args&&... args)
|
|
{
|
|
return std::make_shared<DummyUpdatePreconditioner<OriginalPreconditioner>>(std::forward<Args>(args)...);
|
|
}
|
|
|
|
|
|
} // namespace Dune
|
|
|
|
#endif // OPM_PRECONDITIONERWITHUPDATE_HEADER_INCLUDED
|