/* rsb.f -- translated by f2c (version 19961017).
You must link the resulting object file with the libraries:
-lf2c -lm (in that order)
*/
#include "f2c.h"
/* Subroutine */ int rsb_(integer *nm, integer *n, integer *mb, doublereal *a,
doublereal *w, integer *matz, doublereal *z__, doublereal *fv1,
doublereal *fv2, integer *ierr)
{
/* System generated locals */
integer a_dim1, a_offset, z_dim1, z_offset;
/* Local variables */
extern /* Subroutine */ int bandr_(integer *, integer *, integer *,
doublereal *, doublereal *, doublereal *, doublereal *, logical *,
doublereal *);
static logical tf;
extern /* Subroutine */ int tqlrat_(integer *, doublereal *, doublereal *,
integer *), tql2_(integer *, integer *, doublereal *, doublereal
*, doublereal *, integer *);
/* THIS SUBROUTINE CALLS THE RECOMMENDED SEQUENCE OF */
/* SUBROUTINES FROM THE EIGENSYSTEM SUBROUTINE PACKAGE (EISPACK) */
/* TO FIND THE EIGENVALUES AND EIGENVECTORS (IF DESIRED) */
/* OF A REAL SYMMETRIC BAND MATRIX. */
/* ON INPUT */
/* NM MUST BE SET TO THE ROW DIMENSION OF THE TWO-DIMENSIONAL */
/* ARRAY PARAMETERS AS DECLARED IN THE CALLING PROGRAM */
/* DIMENSION STATEMENT. */
/* N IS THE ORDER OF THE MATRIX A. */
/* MB IS THE HALF BAND WIDTH OF THE MATRIX, DEFINED AS THE */
/* NUMBER OF ADJACENT DIAGONALS, INCLUDING THE PRINCIPAL */
/* DIAGONAL, REQUIRED TO SPECIFY THE NON-ZERO PORTION OF THE */
/* LOWER TRIANGLE OF THE MATRIX. */
/* A CONTAINS THE LOWER TRIANGLE OF THE REAL SYMMETRIC */
/* BAND MATRIX. ITS LOWEST SUBDIAGONAL IS STORED IN THE */
/* LAST N+1-MB POSITIONS OF THE FIRST COLUMN, ITS NEXT */
/* SUBDIAGONAL IN THE LAST N+2-MB POSITIONS OF THE */
/* SECOND COLUMN, FURTHER SUBDIAGONALS SIMILARLY, AND */
/* FINALLY ITS PRINCIPAL DIAGONAL IN THE N POSITIONS */
/* OF THE LAST COLUMN. CONTENTS OF STORAGES NOT PART */
/* OF THE MATRIX ARE ARBITRARY. */
/* MATZ IS AN INTEGER VARIABLE SET EQUAL TO ZERO IF */
/* ONLY EIGENVALUES ARE DESIRED. OTHERWISE IT IS SET TO */
/* ANY NON-ZERO INTEGER FOR BOTH EIGENVALUES AND EIGENVECTORS. */
/* ON OUTPUT */
/* W CONTAINS THE EIGENVALUES IN ASCENDING ORDER. */
/* Z CONTAINS THE EIGENVECTORS IF MATZ IS NOT ZERO. */
/* IERR IS AN INTEGER OUTPUT VARIABLE SET EQUAL TO AN ERROR */
/* COMPLETION CODE DESCRIBED IN THE DOCUMENTATION FOR TQLRAT */
/* AND TQL2. THE NORMAL COMPLETION CODE IS ZERO. */
/* FV1 AND FV2 ARE TEMPORARY STORAGE ARRAYS. */
/* QUESTIONS AND COMMENTS SHOULD BE DIRECTED TO BURTON S. GARBOW, */
/* MATHEMATICS AND COMPUTER SCIENCE DIV, ARGONNE NATIONAL LABORATORY
*/
/* THIS VERSION DATED AUGUST 1983. */
/* ------------------------------------------------------------------
*/
/* Parameter adjustments */
--fv2;
--fv1;
z_dim1 = *nm;
z_offset = z_dim1 + 1;
z__ -= z_offset;
--w;
a_dim1 = *nm;
a_offset = a_dim1 + 1;
a -= a_offset;
/* Function Body */
if (*n <= *nm) {
goto L5;
}
*ierr = *n * 10;
goto L50;
L5:
if (*mb > 0) {
goto L10;
}
*ierr = *n * 12;
goto L50;
L10:
if (*mb <= *n) {
goto L15;
}
*ierr = *n * 12;
goto L50;
L15:
if (*matz != 0) {
goto L20;
}
/* .......... FIND EIGENVALUES ONLY .......... */
tf = FALSE_;
bandr_(nm, n, mb, &a[a_offset], &w[1], &fv1[1], &fv2[1], &tf, &z__[
z_offset]);
tqlrat_(n, &w[1], &fv2[1], ierr);
goto L50;
/* .......... FIND BOTH EIGENVALUES AND EIGENVECTORS .......... */
L20:
tf = TRUE_;
bandr_(nm, n, mb, &a[a_offset], &w[1], &fv1[1], &fv1[1], &tf, &z__[
z_offset]);
tql2_(nm, n, &w[1], &fv1[1], &z__[z_offset], ierr);
L50:
return 0;
} /* rsb_ */
syntax highlighted by Code2HTML, v. 0.9.1