This page contains proposed changes for a future release of ROCm. Read the latest Linux release of ROCm documentation for your production environments.

hipblaszhpmvbatched Interface Reference

hipblaszhpmvbatched Interface Reference#

HIPFORT API Reference: hipfort_hipblas::hipblaszhpmvbatched Interface Reference
hipfort_hipblas::hipblaszhpmvbatched Interface Reference

BLAS Level 2 API. More...

Public Member Functions

integer(kind(hipblas_status_success)) function hipblaszhpmvbatched_ (handle, uplo, n, alpha, AP, x, incx, beta, y, incy, batchCount)
 
integer(kind(hipblas_status_success)) function hipblaszhpmvbatched_full_rank (handle, uplo, n, alpha, AP, x, incx, beta, y, incy, batchCount)
 
integer(kind(hipblas_status_success)) function hipblaszhpmvbatched_rank_0 (handle, uplo, n, alpha, AP, x, incx, beta, y, incy, batchCount)
 
integer(kind(hipblas_status_success)) function hipblaszhpmvbatched_rank_1 (handle, uplo, n, alpha, AP, x, incx, beta, y, incy, batchCount)
 

Detailed Description

BLAS Level 2 API.

hpmvBatched performs the matrix-vector operation

y_i := alpha*A_i*x_i + beta*y_i

where alpha and beta are scalars, x_i and y_i are n element vectors and A_i is an n by n Hermitian matrix, supplied in packed form (see description below), for each batch in i = [1, batchCount].

Parameters
[in]handle[hipblasHandle_t] handle to the hipblas library context queue.
[in]uplo[hipblasFillMode_t] HIPBLAS_FILL_MODE_UPPER: the upper triangular part of each Hermitian matrix A_i is supplied in AP. HIPBLAS_FILL_MODE_LOWER: the lower triangular part of each Hermitian matrix A_i is supplied in AP.
[in]n[int] the order of each matrix A_i.
[in]alphadevice pointer or host pointer to scalar alpha.
[in]APdevice pointer of device pointers storing the packed version of the specified triangular portion of each Hermitian matrix A_i. Each A_i is of at least size ((n * (n + 1)) 2). if uplo == HIPBLAS_FILL_MODE_UPPER: The upper triangular portion of each Hermitian matrix A_i is supplied. The matrix is compacted so that each AP_i contains the triangular portion column-by-column so that: AP(0) = A(0,0) AP(1) = A(0,1) AP(2) = A(1,1), etc. Ex: (HIPBLAS_FILL_MODE_UPPER; n = 3) (1, 0) (2, 1) (3, 2) (2,-1) (4, 0) (5,-1) --—> [(1,0), (2,1), (4,0), (3,2), (5,-1), (6,0)] (3,-2) (5, 1) (6, 0) if uplo == HIPBLAS_FILL_MODE_LOWER: The lower triangular portion of each Hermitian matrix A_i is supplied. The matrix is compacted so that each AP_i contains the triangular portion column-by-column so that: AP(0) = A(0,0) AP(1) = A(1,0) AP(2) = A(2,1), etc. Ex: (HIPBLAS_FILL_MODE_LOWER; n = 3) (1, 0) (2, 1) (3, 2) (2,-1) (4, 0) (5,-1) --—> [(1,0), (2,-1), (3,-2), (4,0), (5,1), (6,0)] (3,-2) (5, 1) (6, 0) Note that the imaginary part of the diagonal elements are not accessed and are assumed to be 0.
[in]xdevice array of device pointers storing each vector x_i.
[in]incx[int] specifies the increment for the elements of each x_i.
[in]betadevice pointer or host pointer to scalar beta.
[in,out]ydevice array of device pointers storing each vector y_i.
[in]incy[int] specifies the increment for the elements of y.
[in]batchCount[int] number of instances in the batch.

Member Function/Subroutine Documentation

◆ hipblaszhpmvbatched_()

integer(kind(hipblas_status_success)) function hipfort_hipblas::hipblaszhpmvbatched::hipblaszhpmvbatched_ ( type(c_ptr), value  handle,
integer(kind(hipblas_fill_mode_upper)), value  uplo,
integer(c_int), value  n,
complex(c_double_complex)  alpha,
type(c_ptr)  AP,
type(c_ptr)  x,
integer(c_int), value  incx,
complex(c_double_complex)  beta,
type(c_ptr)  y,
integer(c_int), value  incy,
integer(c_int), value  batchCount 
)

◆ hipblaszhpmvbatched_full_rank()

integer(kind(hipblas_status_success)) function hipfort_hipblas::hipblaszhpmvbatched::hipblaszhpmvbatched_full_rank ( type(c_ptr)  handle,
integer(kind(hipblas_fill_mode_upper))  uplo,
integer(c_int)  n,
complex(c_double_complex)  alpha,
type(c_ptr)  AP,
complex(c_double_complex), dimension(:,:), target  x,
integer(c_int)  incx,
complex(c_double_complex)  beta,
complex(c_double_complex), dimension(:,:), target  y,
integer(c_int)  incy,
integer(c_int)  batchCount 
)

◆ hipblaszhpmvbatched_rank_0()

integer(kind(hipblas_status_success)) function hipfort_hipblas::hipblaszhpmvbatched::hipblaszhpmvbatched_rank_0 ( type(c_ptr)  handle,
integer(kind(hipblas_fill_mode_upper))  uplo,
integer(c_int)  n,
complex(c_double_complex)  alpha,
type(c_ptr)  AP,
complex(c_double_complex), target  x,
integer(c_int)  incx,
complex(c_double_complex)  beta,
complex(c_double_complex), target  y,
integer(c_int)  incy,
integer(c_int)  batchCount 
)

◆ hipblaszhpmvbatched_rank_1()

integer(kind(hipblas_status_success)) function hipfort_hipblas::hipblaszhpmvbatched::hipblaszhpmvbatched_rank_1 ( type(c_ptr)  handle,
integer(kind(hipblas_fill_mode_upper))  uplo,
integer(c_int)  n,
complex(c_double_complex)  alpha,
type(c_ptr)  AP,
complex(c_double_complex), dimension(:), target  x,
integer(c_int)  incx,
complex(c_double_complex)  beta,
complex(c_double_complex), dimension(:), target  y,
integer(c_int)  incy,
integer(c_int)  batchCount 
)

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