NAME

zhpevd - compute all the eigenvalues and, optionally, eigenvectors of a complex Hermitian matrix A in packed storage


SYNOPSIS

  SUBROUTINE ZHPEVD( JOBZ, UPLO, N, AP, W, Z, LDZ, WORK, LWORK, RWORK, 
 *      LRWORK, IWORK, LIWORK, INFO)
  CHARACTER * 1 JOBZ, UPLO
  DOUBLE COMPLEX AP(*), Z(LDZ,*), WORK(*)
  INTEGER N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER IWORK(*)
  DOUBLE PRECISION W(*), RWORK(*)
  SUBROUTINE ZHPEVD_64( JOBZ, UPLO, N, AP, W, Z, LDZ, WORK, LWORK, 
 *      RWORK, LRWORK, IWORK, LIWORK, INFO)
  CHARACTER * 1 JOBZ, UPLO
  DOUBLE COMPLEX AP(*), Z(LDZ,*), WORK(*)
  INTEGER*8 N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER*8 IWORK(*)
  DOUBLE PRECISION W(*), RWORK(*)

F95 INTERFACE

  SUBROUTINE HPEVD( JOBZ, UPLO, [N], AP, W, Z, [LDZ], WORK, [LWORK], 
 *       RWORK, [LRWORK], [IWORK], [LIWORK], [INFO])
  CHARACTER(LEN=1) :: JOBZ, UPLO
  COMPLEX(8), DIMENSION(:) :: AP, WORK
  COMPLEX(8), DIMENSION(:,:) :: Z
  INTEGER :: N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER, DIMENSION(:) :: IWORK
  REAL(8), DIMENSION(:) :: W, RWORK
  SUBROUTINE HPEVD_64( JOBZ, UPLO, [N], AP, W, Z, [LDZ], WORK, [LWORK], 
 *       RWORK, [LRWORK], [IWORK], [LIWORK], [INFO])
  CHARACTER(LEN=1) :: JOBZ, UPLO
  COMPLEX(8), DIMENSION(:) :: AP, WORK
  COMPLEX(8), DIMENSION(:,:) :: Z
  INTEGER(8) :: N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER(8), DIMENSION(:) :: IWORK
  REAL(8), DIMENSION(:) :: W, RWORK

C INTERFACE

#include <sunperf.h>

void zhpevd(char jobz, char uplo, int n, doublecomplex *ap, double *w, doublecomplex *z, int ldz, doublecomplex *work, int lwork, double *rwork, int lrwork, int *info);

void zhpevd_64(char jobz, char uplo, long n, doublecomplex *ap, double *w, doublecomplex *z, long ldz, doublecomplex *work, long lwork, double *rwork, long lrwork, long *info);


PURPOSE

zhpevd computes all the eigenvalues and, optionally, eigenvectors of a complex Hermitian matrix A in packed storage. If eigenvectors are desired, it uses a divide and conquer algorithm.

The divide and conquer algorithm makes very mild assumptions about floating point arithmetic. It will work on machines with a guard digit in add/subtract, or on those binary machines without guard digits which subtract like the Cray X-MP, Cray Y-MP, Cray C-90, or Cray-2. It could conceivably fail on hexadecimal or decimal machines without guard digits, but we know of none.


ARGUMENTS