17 #ifndef OPM_STANDARDPRECONDITIONERS_GPU_MPI_HEADER 18 #define OPM_STANDARDPRECONDITIONERS_GPU_MPI_HEADER 20 #include <dune/istl/bcrsmatrix.hh> 23 #include <opm/simulators/linalg/PreconditionerFactory.hpp> 24 #include <opm/simulators/linalg/PropertyTree.hpp> 25 #include <opm/simulators/linalg/is_gpu_operator.hpp> 28 #include <opm/simulators/linalg/gpuistl/GpuDILU.hpp> 29 #include <opm/simulators/linalg/gpuistl/GpuSeqILU0.hpp> 30 #include <opm/simulators/linalg/gpuistl/GpuJac.hpp> 31 #include <opm/simulators/linalg/gpuistl/OpmGpuILU0.hpp> 32 #include <opm/simulators/linalg/gpuistl/GpuBlockPreconditioner.hpp> 33 #include <opm/simulators/linalg/gpuistl/detail/gpu_preconditioner_utils.hpp> 38 template <
class Operator,
class Comm>
45 using V =
typename F::Vector;
49 using field_type =
typename V::field_type;
51 static constexpr
int maxblocksize = 6;
56 F::addCreator(
"ilu0", [](
const O& op,
const P& prm,
const std::function<V()>&, std::size_t,
const C& comm) {
57 const double w = prm.
get<
double>(
"relaxation", 1.0);
59 auto gpuPrec = std::make_shared<GpuILU0>(op.getmat(), w);
60 return std::make_shared<gpuistl::GpuBlockPreconditioner<V, V, C>>(gpuPrec, comm);
63 F::addCreator(
"jac", [](
const O& op,
const P& prm,
const std::function<V()>&, std::size_t,
const C& comm) {
64 const double w = prm.
get<
double>(
"relaxation", 1.0);
66 auto gpuPrec = std::make_shared<GpuJac>(op.getmat(), w);
67 return std::make_shared<gpuistl::GpuBlockPreconditioner<V, V, C>>(gpuPrec, comm);
70 F::addCreator(
"dilu", [](
const O& op, [[maybe_unused]]
const P& prm,
const std::function<V()>&, std::size_t,
const C& comm) -> PrecPtr {
71 return op.getmat().dispatchOnBlocksize([&](
auto blockSizeVal) -> PrecPtr {
72 constexpr
int blockSize = decltype(blockSizeVal)::value;
73 const auto cpuMatrix = gpuistl::detail::makeCPUMatrix<O, Dune::FieldMatrix<field_type, blockSize, blockSize>>(op);
74 const bool split_matrix = prm.get<
bool>(
"split_matrix",
true);
75 const bool tune_gpu_kernels = prm.get<
bool>(
"tune_gpu_kernels",
true);
76 const int mixed_precision_scheme = prm.get<
int>(
"mixed_precision_scheme", 0);
77 const bool reorder = prm.get<
bool>(
"reorder",
true);
78 using CPUMatrixType = std::remove_const_t<std::remove_reference_t<decltype(cpuMatrix)>>;
80 auto gpuPrec = std::make_shared<GPUDILU>(op.getmat(), cpuMatrix, split_matrix, tune_gpu_kernels, mixed_precision_scheme, reorder);
81 return std::make_shared<gpuistl::GpuBlockPreconditioner<V, V, C>>(gpuPrec, comm);
85 F::addCreator(
"opmilu0", [](
const O& op, [[maybe_unused]]
const P& prm,
const std::function<V()>&, std::size_t,
const C& comm) -> PrecPtr {
86 return op.getmat().dispatchOnBlocksize([&](
auto blockSizeVal) -> PrecPtr {
87 constexpr
int blockSize = decltype(blockSizeVal)::value;
88 const auto cpuMatrix = gpuistl::detail::makeCPUMatrix<O, Dune::FieldMatrix<field_type, blockSize, blockSize>>(op);
89 const bool split_matrix = prm.get<
bool>(
"split_matrix",
true);
90 const bool tune_gpu_kernels = prm.get<
bool>(
"tune_gpu_kernels",
true);
91 const int mixed_precision_scheme = prm.get<
int>(
"mixed_precision_scheme", 0);
92 using CPUMatrixType = std::remove_const_t<std::remove_reference_t<decltype(cpuMatrix)>>;
94 auto gpuPrec = std::make_shared<GPUILU0>(op.getmat(), cpuMatrix, split_matrix, tune_gpu_kernels, mixed_precision_scheme);
95 return std::make_shared<gpuistl::GpuBlockPreconditioner<V, V, C>>(gpuPrec, comm);
107 #endif // OPM_STANDARDPRECONDITIONERS_GPU_MPI_HEADER T get(const std::string &key) const
Retrieve property value given hierarchical property key.
Definition: PropertyTree.cpp:59
typename Operator::matrix_type Matrix
Linear algebra types.
Definition: PreconditionerFactory.hpp:67
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: blackoilbioeffectsmodules.hh:45
ILU0 preconditioner on the GPU.
Definition: OpmGpuILU0.hpp:50
DILU preconditioner on the GPU.
Definition: GpuDILU.hpp:52
Sequential ILU0 preconditioner on the GPU through the CuSparse library.
Definition: GpuSeqILU0.hpp:51
Jacobi preconditioner on the GPU.
Definition: GpuJac.hpp:46
Hierarchical collection of key/value pairs.
Definition: PropertyTree.hpp:38
Definition: StandardPreconditioners_mpi.hpp:134
This is an object factory for creating preconditioners.
Definition: OwningTwoLevelPreconditioner.hpp:43
std::shared_ptr< Dune::PreconditionerWithUpdate< Vector, Vector > > PrecPtr
The type of pointer returned by create().
Definition: PreconditionerFactory.hpp:71