NAME

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


SYNOPSIS

  SUBROUTINE DSTEDC( COMPZ, N, D, E, Z, LDZ, WORK, LWORK, IWORK, 
 *      LIWORK, INFO)
  CHARACTER * 1 COMPZ
  INTEGER N, LDZ, LWORK, LIWORK, INFO
  INTEGER IWORK(*)
  DOUBLE PRECISION D(*), E(*), Z(LDZ,*), WORK(*)
  SUBROUTINE DSTEDC_64( COMPZ, N, D, E, Z, LDZ, WORK, LWORK, IWORK, 
 *      LIWORK, INFO)
  CHARACTER * 1 COMPZ
  INTEGER*8 N, LDZ, LWORK, LIWORK, INFO
  INTEGER*8 IWORK(*)
  DOUBLE PRECISION D(*), E(*), Z(LDZ,*), WORK(*)

F95 INTERFACE

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

C INTERFACE

#include <sunperf.h>

void dstedc(char *compz, int n, double *d, double *e, double *z, int ldz, double *work, int lwork, int *iwork, int liwork, int *info);

void dstedc_64(char *compz, long n, double *d, double *e, double *z, long ldz, double *work, long lwork, long *iwork, long liwork, long *info);


PURPOSE

dstedc computes all eigenvalues and, optionally, eigenvectors of a symmetric tridiagonal matrix using the divide and conquer method. The eigenvectors of a full or band real symmetric matrix can also be found if SSYTRD or SSPTRD or SSBTRD 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

Modified by Francoise Tisseur, University of Tennessee.