173 SUBROUTINE ssygv( ITYPE, JOBZ, UPLO, N, A, LDA, B, LDB, W, WORK,
182 INTEGER INFO, ITYPE, LDA, LDB, LWORK, N
185 REAL A( LDA, * ), B( LDB, * ), W( * ), WORK( * )
192 parameter( one = 1.0e+0 )
195 LOGICAL LQUERY, UPPER, WANTZ
197 INTEGER LWKMIN, LWKOPT, NB, NEIG
202 EXTERNAL ilaenv, lsame
214 wantz = lsame( jobz,
'V' )
215 upper = lsame( uplo,
'U' )
216 lquery = ( lwork.EQ.-1 )
219 IF( itype.LT.1 .OR. itype.GT.3 )
THEN
221 ELSE IF( .NOT.( wantz .OR. lsame( jobz,
'N' ) ) )
THEN
223 ELSE IF( .NOT.( upper .OR. lsame( uplo,
'L' ) ) )
THEN
225 ELSE IF( n.LT.0 )
THEN
227 ELSE IF( lda.LT.
max( 1, n ) )
THEN
229 ELSE IF( ldb.LT.
max( 1, n ) )
THEN
234 lwkmin =
max( 1, 3*n - 1 )
235 nb = ilaenv( 1,
'SSYTRD', uplo, n, -1, -1, -1 )
236 lwkopt =
max( lwkmin, ( nb + 2 )*n )
239 IF( lwork.LT.lwkmin .AND. .NOT.lquery )
THEN
245 CALL xerbla(
'SSYGV ', -info )
247 ELSE IF( lquery )
THEN
258 CALL spotrf( uplo, n, b, ldb, info )
266 CALL ssygst( itype, uplo, n, a, lda, b, ldb, info )
267 CALL ssyev( jobz, uplo, n, a, lda, w, work, lwork, info )
276 IF( itype.EQ.1 .OR. itype.EQ.2 )
THEN
287 CALL strsm(
'Left', uplo, trans,
'Non-unit', n, neig, one,
290 ELSE IF( itype.EQ.3 )
THEN
301 CALL strmm(
'Left', uplo, trans,
'Non-unit', n, neig, one,
subroutine xerbla(srname, info)
XERBLA
subroutine spotrf(uplo, n, a, lda, info)
SPOTRF
subroutine ssygst(itype, uplo, n, a, lda, b, ldb, info)
SSYGST
subroutine ssyev(jobz, uplo, n, a, lda, w, work, lwork, info)
SSYEV computes the eigenvalues and, optionally, the left and/or right eigenvectors for SY matrices
subroutine ssygv(itype, jobz, uplo, n, a, lda, b, ldb, w, work, lwork, info)
SSYGV
subroutine strsm(side, uplo, transa, diag, m, n, alpha, a, lda, b, ldb)
STRSM
subroutine strmm(side, uplo, transa, diag, m, n, alpha, a, lda, b, ldb)
STRMM