NAME

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


SYNOPSIS

  SUBROUTINE CSTEDC( COMPZ, N, D, E, Z, LDZ, WORK, LWORK, RWORK, 
 *      LRWORK, IWORK, LIWORK, INFO)
  CHARACTER * 1 COMPZ
  COMPLEX Z(LDZ,*), WORK(*)
  INTEGER N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER IWORK(*)
  REAL D(*), E(*), RWORK(*)
  SUBROUTINE CSTEDC_64( COMPZ, N, D, E, Z, LDZ, WORK, LWORK, RWORK, 
 *      LRWORK, IWORK, LIWORK, INFO)
  CHARACTER * 1 COMPZ
  COMPLEX Z(LDZ,*), WORK(*)
  INTEGER*8 N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER*8 IWORK(*)
  REAL 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, DIMENSION(:) :: WORK
  COMPLEX, DIMENSION(:,:) :: Z
  INTEGER :: N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER, DIMENSION(:) :: IWORK
  REAL, 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, DIMENSION(:) :: WORK
  COMPLEX, DIMENSION(:,:) :: Z
  INTEGER(8) :: N, LDZ, LWORK, LRWORK, LIWORK, INFO
  INTEGER(8), DIMENSION(:) :: IWORK
  REAL, DIMENSION(:) :: D, E, RWORK

C INTERFACE

#include <sunperf.h>

void cstedc(char compz, int n, float *d, float *e, complex *z, int ldz, complex *work, int lwork, float *rwork, int lrwork, int *iwork, int liwork, int *info);

void cstedc_64(char compz, long n, float *d, float *e, complex *z, long ldz, complex *work, long lwork, float *rwork, long lrwork, long *iwork, long liwork, long *info);


PURPOSE

cstedc 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