20#ifndef OPM_ROCSPARSECPR_HPP
21#define OPM_ROCSPARSECPR_HPP
25#include <opm/simulators/linalg/gpubridge/rocm/rocsparseBILU0.hpp>
26#include <opm/simulators/linalg/gpubridge/Matrix.hpp>
27#include <opm/simulators/linalg/gpubridge/CprCreation.hpp>
28#include <opm/simulators/linalg/gpubridge/rocm/rocsparseMatrix.hpp>
29#include <opm/simulators/linalg/gpubridge/rocm/rocsparsePreconditioner.hpp>
30#include <opm/simulators/linalg/gpubridge/WellContributions.hpp>
32#include <opm/simulators/linalg/gpubridge/rocm/rocsparseSolverBackend.hpp>
34namespace Opm::Accelerator {
39template <
class Scalar,
unsigned int block_size>
40class rocsparseCPR :
public rocsparsePreconditioner<Scalar, block_size>,
public CprCreation<Scalar, block_size>
42 typedef rocsparsePreconditioner<Scalar, block_size> Base;
48 using Base::verbosity;
51 std::vector<RocmMatrix<Scalar>> d_Amatrices, d_Rmatrices;
53 std::vector<RocmVector<int>> d_PcolIndices;
54 std::vector<RocmVector<Scalar>> d_invDiags;
55 std::vector<RocmVector<Scalar>> d_t, d_f;
56 std::vector<RocmVector<Scalar>> d_u;
57 std::vector<RocmVector<Scalar>> d_rs;
58 std::vector<RocmVector<Scalar>> d_weights;
59 std::unique_ptr<RocmMatrix<Scalar>> d_mat;
60 std::shared_ptr<BlockedMatrix<Scalar>> h_mat;
62 std::vector<RocmVector<Scalar>> d_coarse_y, d_coarse_x, d_yinput;
63 std::once_flag rocm_buffers_allocated;
65 std::unique_ptr<rocsparseBILU0<Scalar, block_size> > bilu0;
67 std::vector<std::shared_ptr<rocsparseBILU0<Scalar,1>>> smootherilu0s;
69 Scalar *d_tmp, *d_yamg, *d_ywell;
72 #if HIP_VERSION >= 50400000
73 rocsparse_mat_info spmv_info;
77 void init_rocm_buffers();
78 void init_rocm_buffers_fineMatrix();
81 void clear_rocm_buffers();
87 void apply_amg(
const Scalar& y,
92 void amg_cycle_gpu(
const int level,
99 rocsparseCPR(
int verbosity);
108 rocsparse_int *d_Arows,
109 rocsparse_int *d_Acols)
override;
138 void apply(
const Scalar& y,
This struct resembles a blocked csr matrix, like Dune::BCRSMatrix.
Definition BlockedMatrix.hpp:29
void update_system_on_gpu(Scalar *vals, Scalar *b) override
Update linear system to GPU.
Definition rocsparseCPR.cpp:84
bool analyze_matrix(BlockedMatrix< Scalar > *mat) override
Analysis, extract parallelism if specified.
Definition rocsparseCPR.cpp:92
bool initialize(std::shared_ptr< BlockedMatrix< Scalar > > matrix, std::shared_ptr< BlockedMatrix< Scalar > > jacMatrix, rocsparse_int *d_Arows, rocsparse_int *d_Acols) override
Initialize GPU and allocate memory.
Definition rocsparseCPR.cpp:57
void apply(const Scalar &y, Scalar &x, WellContributions< Scalar > &wellContribs) override
Apply preconditioner, x = prec(y) applies blocked ilu0 also applies amg for pressure component.
Definition rocsparseCPR.cpp:414
void copy_system_to_gpu(Scalar *b) override
Copy matrix A values to GPU.
Definition rocsparseCPR.cpp:77
bool create_preconditioner(BlockedMatrix< Scalar > *mat) override
Create AMG preconditioner and perform ILU decomposition.
Definition rocsparseCPR.cpp:132
This class serves to eliminate the need to include the WellContributions into the matrix (with –matri...
Definition WellContributions.hpp:51