rocsolver_sgetf2_batched Interface Reference

rocsolver_sgetf2_batched Interface Reference#

HIPFORT API Reference: hipfort_rocsolver::rocsolver_sgetf2_batched Interface Reference
hipfort_rocsolver::rocsolver_sgetf2_batched Interface Reference

! More...

Public Member Functions

integer(kind(rocblas_status_success)) function rocsolver_sgetf2_batched_full_rank (handle, m, n, A, lda, ipiv, strideP, myInfo, batch_count)
 
integer(kind(rocblas_status_success)) function rocsolver_sgetf2_batched_orig (handle, m, n, A, lda, ipiv, strideP, myInfo, batch_count)
 
integer(kind(rocblas_status_success)) function rocsolver_sgetf2_batched_rank_0 (handle, m, n, A, lda, ipiv, strideP, myInfo, batch_count)
 
integer(kind(rocblas_status_success)) function rocsolver_sgetf2_batched_rank_1 (handle, m, n, A, lda, ipiv, strideP, myInfo, batch_count)
 

Detailed Description

!

GETF2_BATCHED computes the LU factorization of a batch of general m-by-n matrices using partial pivoting with row interchanges.

(This is the unblocked Level-2-BLAS version of the algorithm. An optimized internal implementation without rocBLAS calls could be executed with small and mid-size matrices if optimizations are enabled (default option). For more details see the section "tuning rocSOLVER performance" on the User's guide).

The factorization of matrix A_i in the batch has the form

    A_i = P_i  L_i  U_i

where P_i is a permutation matrix, L_i is lower triangular with unit
diagonal elements (lower trapezoidal if m > n), and U_i is upper
triangular (upper trapezoidal if m < n).

@param[in]
handle    rocblas_handle.
@param[in]
m         rocblas_int. m >= 0.\n
          The number of rows of all matrices A_i in the batch.
@param[in]
n         rocblas_int. n >= 0.\n
          The number of columns of all matrices A_i in the batch.
@param[inout]
A         array of pointers to type. Each pointer points to an array on the GPU of dimension ldan.\n
          On entry, the m-by-n matrices A_i to be factored.
          On exit, the factors L_i and U_i from the factorizations.
          The unit diagonal elements of L_i are not stored.
@param[in]
lda       rocblas_int. lda >= m.\n
          Specifies the leading dimension of matrices A_i.
@param[out]
ipiv      pointer to rocblas_int. Array on the GPU (the size depends on the value of strideP).\n
          Contains the vectors of pivot indices ipiv_i (corresponding to A_i).
          Dimension of ipiv_i is min(m,n).
          Elements of ipiv_i are 1-based indices.
          For each instance A_i in the batch and for 1 <= j <= min(m,n), the row j of the
          matrix A_i was interchanged with row ipiv_i[j].
          Matrix P_i of the factorization can be derived from ipiv_i.
@param[in]
strideP   rocblas_stride.\n
          Stride from the start of one vector ipiv_i to the next one ipiv_(i+1).
          There is no restriction for the value of strideP. Normal use case is strideP >= min(m,n).
@param[out]
info      pointer to rocblas_int. Array of batch_count integers on the GPU.\n
          If info_i = 0, successful exit for factorization of A_i.
          If info_i = j > 0, U_i is singular. U_i(j,j) is the first zero pivot.
@param[in]
batch_count rocblas_int. batch_count >= 0.\n
            Number of matrices in the batch.

Member Function/Subroutine Documentation

◆ rocsolver_sgetf2_batched_full_rank()

integer(kind(rocblas_status_success)) function hipfort_rocsolver::rocsolver_sgetf2_batched::rocsolver_sgetf2_batched_full_rank ( type(c_ptr), value  handle,
integer(c_int), value  m,
integer(c_int), value  n,
real(c_float), dimension(:,:,:), target  A,
integer(c_int), value  lda,
integer(c_int), dimension(:), target  ipiv,
integer(c_int64_t), value  strideP,
type(c_ptr), value  myInfo,
integer(c_int), value  batch_count 
)

◆ rocsolver_sgetf2_batched_orig()

integer(kind(rocblas_status_success)) function hipfort_rocsolver::rocsolver_sgetf2_batched::rocsolver_sgetf2_batched_orig ( type(c_ptr), value  handle,
integer(c_int), value  m,
integer(c_int), value  n,
type(c_ptr)  A,
integer(c_int), value  lda,
type(c_ptr), value  ipiv,
integer(c_int64_t), value  strideP,
type(c_ptr), value  myInfo,
integer(c_int), value  batch_count 
)

◆ rocsolver_sgetf2_batched_rank_0()

integer(kind(rocblas_status_success)) function hipfort_rocsolver::rocsolver_sgetf2_batched::rocsolver_sgetf2_batched_rank_0 ( type(c_ptr), value  handle,
integer(c_int), value  m,
integer(c_int), value  n,
real(c_float), target  A,
integer(c_int), value  lda,
integer(c_int), target  ipiv,
integer(c_int64_t), value  strideP,
type(c_ptr), value  myInfo,
integer(c_int), value  batch_count 
)

◆ rocsolver_sgetf2_batched_rank_1()

integer(kind(rocblas_status_success)) function hipfort_rocsolver::rocsolver_sgetf2_batched::rocsolver_sgetf2_batched_rank_1 ( type(c_ptr), value  handle,
integer(c_int), value  m,
integer(c_int), value  n,
real(c_float), dimension(:), target  A,
integer(c_int), value  lda,
integer(c_int), dimension(:), target  ipiv,
integer(c_int64_t), value  strideP,
type(c_ptr), value  myInfo,
integer(c_int), value  batch_count 
)

The documentation for this interface was generated from the following file: