20 #ifndef OPM_ROCSPARSEBILU0_HPP 21 #define OPM_ROCSPARSEBILU0_HPP 23 #include <opm/simulators/linalg/gpubridge/BlockedMatrix.hpp> 24 #include <opm/simulators/linalg/gpubridge/WellContributions.hpp> 26 #include <opm/simulators/linalg/gpubridge/rocm/rocsparsePreconditioner.hpp> 28 #include <rocblas/rocblas.h> 29 #include <rocsparse/rocsparse.h> 31 #include <hip/hip_version.h> 38 template <
class Scalar,
unsigned int block_size>
47 using Base::verbosity;
51 rocsparse_mat_descr descr_M, descr_L, descr_U;
52 rocsparse_mat_info ilu_info;
53 #if HIP_VERSION >= 50400000 54 rocsparse_mat_info spmv_info;
57 rocsparse_int *d_Mrows, *d_Mcols;
58 Scalar *d_Mvals, *d_t;
61 std::size_t d_bufferSize_M=0, d_bufferSize_L=0, d_bufferSize_U=0, d_bufferSize=0;
75 rocsparse_int *d_Arows,
76 rocsparse_int *d_Acols)
override;
107 void apply(
const Scalar& y,
void copy_values_to_gpu(Scalar *mVals, int *mRows, int *mCols, bool reuse)
Copy matrix A values to GPU.
Definition: rocsparseBILU0.cpp:393
bool create_preconditioner(BlockedMatrix< Scalar > *mat) override
ILU decomposition.
Definition: rocsparseBILU0.cpp:328
void copy_system_to_gpu(Scalar *mVals) override
Copy matrix A values to GPU.
Definition: rocsparseBILU0.cpp:369
Definition: amgclSolverBackend.cpp:49
void update_system_on_gpu(Scalar *, Scalar *b) override
Update GPU values after a new assembly is done.
Definition: rocsparseBILU0.cpp:406
void apply(const Scalar &y, Scalar &x, WellContributions< Scalar > &wellContribs) override
Apply preconditioner, x = prec(y) via Lz = y and Ux = z.
Definition: rocsparseBILU0.cpp:428
This class serves to eliminate the need to include the WellContributions into the matrix (with –matr...
Definition: GpuBridge.hpp:30
bool analyze_matrix()
Analysis, extract parallelism if specified.
Definition: rocsparseBILU0.cpp:124
Definition: rocsparsePreconditioner.hpp:33
This struct resembles a blocked csr matrix, like Dune::BCRSMatrix.
Definition: BlockedMatrix.hpp:28
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: rocsparseBILU0.cpp:75
This class implements a Blocked ILU0 preconditioner The decomposition is done on GPU, using exact decomposition, or ChowPatel decomposition The preconditioner is applied via two exact triangular solves.
Definition: rocsparseBILU0.hpp:39