hegvd_scratchpad_size¶
Computes size of scratchpad memory required for hegvd function.
hegvd_scratchpad_sizesupports 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
1or2or3. 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::novecorjob::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::upperoruplo::lower.If
upper_lower = uplo::upper, a and b store the upper triangular part ofAandB.If
upper_lower = uplo::lower, a and b store the lower triangular part ofAandB.- n
The order of the matrices
AandB(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