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