34 typename OriginalPreconditioner::range_type>
37 template <
class... Args>
39 : orig_precond_(std::forward<Args>(args)...)
40 , block_precond_(orig_precond_, comm)
44 using X =
typename OriginalPreconditioner::domain_type;
45 using Y =
typename OriginalPreconditioner::range_type;
47 virtual void pre(X& x, Y& b)
override
50 block_precond_.pre(x, b);
53 virtual void apply(X& v,
const Y& d)
override
56 block_precond_.apply(v, d);
59 virtual void post(X& x)
override
62 block_precond_.post(x);
65 virtual SolverCategory::Category category()
const override
67 return block_precond_.category();
71 virtual void update()
override
73 OPM_TIMEBLOCK(update);
74 orig_precond_.update();
78 OriginalPreconditioner orig_precond_;
79 BlockPreconditioner<X, Y, Comm, OriginalPreconditioner> block_precond_;
87 return std::make_shared<OwningBlockPreconditioner<OriginalPreconditioner, Comm>>(comm, std::forward<Args>(args)...);