hegvd_scratchpad_size¶
Computes size of scratchpad memory required for hegvd function.
hegvd_scratchpad_size
supports the following precisions.
T
std::complex<float>
std::complex<double>
Description
Computes the number of elements of type T the scratchpad memory to be passed to hegvd function should be able to hold. Calls to this routine must specify the template parameter explicitly.
hegvd_scratchpad_size¶
Syntax
-
template<typename
T
>
std::int64_tonemkl::lapack
::
hegvd_scratchpad_size
(cl::sycl::queue &queue, std::int64_t itype, onemkl::job jobz, onemkl::uplo upper_lower, std::int64_t n, std::int64_t lda, std::int64_t ldb)¶
Input Parameters
- queue
Device queue where calculations by hegvd function will be performed.
- itype
Must be
1
or2
or3
. Specifies the problem type to be solved:if itype
= 1
, the problem type isA*x = lambda*B*x
;if itype
= 2
, the problem type isA*B*x = lambda*x
;if itype
= 3
, the problem type isB*A*x = lambda*x
.- jobz
Must be
job::novec
orjob::vec
.If
jobz = job::novec
, then only eigenvalues are computed.If
jobz = job::vec
, then eigenvalues and eigenvectors are computed.- upper_lower
Must be
uplo::upper
oruplo::lower
.If
upper_lower = uplo::upper
, a and b store the upper triangular part ofA
andB
.If
upper_lower = uplo::lower
, a and b store the lower triangular part ofA
andB
.- n
The order of the matrices
A
andB
(0≤n
).- lda
The leading dimension of a. Currently lda is not referenced in this function.
- ldb
The leading dimension of b. Currently ldb is not referenced in this function.
Throws
- onemkl::lapack::exception
Exception is thrown in case of incorrect argument value is supplied. Position of wrong argument can be determined by get_info() method of exception object.
Return Value
The number of elements of type T the scratchpad memory to be passed to hegvd function should be able to hold.
Parent topic: LAPACK Singular Value and Eigenvalue Problem Routines