NAME

zstedc - compute all eigenvalues and, optionally, eigenvectors of a symmetric tridiagonal matrix using the divide and conquer method


SYNOPSIS

  SUBROUTINE ZSTEDC( COMPZ, N, D, E, Z, LDZ, WORK, LWORK, RWORK, 
 *      LRWORK, IWORK, LIWORK, INFO)
  CHARACTER * 1 COMPZ
  DOUBLE COMPLEX Z(LDZ,*), WORK(*)
  INTEGER N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER IWORK(*)
  DOUBLE PRECISION D(*), E(*), RWORK(*)
  SUBROUTINE ZSTEDC_64( COMPZ, N, D, E, Z, LDZ, WORK, LWORK, RWORK, 
 *      LRWORK, IWORK, LIWORK, INFO)
  CHARACTER * 1 COMPZ
  DOUBLE COMPLEX Z(LDZ,*), WORK(*)
  INTEGER*8 N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER*8 IWORK(*)
  DOUBLE PRECISION D(*), E(*), RWORK(*)

F95 INTERFACE

  SUBROUTINE STEDC( COMPZ, [N], D, E, Z, [LDZ], [WORK], [LWORK], 
 *       RWORK, [LRWORK], IWORK, [LIWORK], [INFO])
  CHARACTER(LEN=1) :: COMPZ
  COMPLEX(8), DIMENSION(:) :: WORK
  COMPLEX(8), DIMENSION(:,:) :: Z
  INTEGER :: N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER, DIMENSION(:) :: IWORK
  REAL(8), DIMENSION(:) :: D, E, RWORK
  SUBROUTINE STEDC_64( COMPZ, [N], D, E, Z, [LDZ], [WORK], [LWORK], 
 *       RWORK, [LRWORK], IWORK, [LIWORK], [INFO])
  CHARACTER(LEN=1) :: COMPZ
  COMPLEX(8), DIMENSION(:) :: WORK
  COMPLEX(8), DIMENSION(:,:) :: Z
  INTEGER(8) :: N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER(8), DIMENSION(:) :: IWORK
  REAL(8), DIMENSION(:) :: D, E, RWORK

C INTERFACE

#include <sunperf.h>

void zstedc(char compz, int n, double *d, double *e, doublecomplex *z, int ldz, double *rwork, int lrwork, int *iwork, int liwork, int *info);

void zstedc_64(char compz, long n, double *d, double *e, doublecomplex *z, long ldz, double *rwork, long lrwork, long *iwork, long liwork, long *info);


PURPOSE

zstedc computes all eigenvalues and, optionally, eigenvectors of a symmetric tridiagonal matrix using the divide and conquer method. The eigenvectors of a full or band complex Hermitian matrix can also be found if CHETRD or CHPTRD or CHBTRD has been used to reduce this matrix to tridiagonal form.

This code 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. See SLAED3 for details.


ARGUMENTS


FURTHER DETAILS

Based on contributions by

   Jeff Rutter, Computer Science Division, University of California
   at Berkeley, USA