/* rsm.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 rsm_(integer *nm, integer *n, doublereal *a, doublereal *
w, integer *m, doublereal *z__, doublereal *fwork, integer *iwork,
integer *ierr)
{
/* System generated locals */
integer a_dim1, a_offset, z_dim1, z_offset;
/* Local variables */
extern /* Subroutine */ int tred1_(integer *, integer *, doublereal *,
doublereal *, doublereal *, doublereal *);
static integer k1, k2, k3, k4, k5, k6, k7, k8;
extern /* Subroutine */ int trbak1_(integer *, integer *, doublereal *,
doublereal *, integer *, doublereal *), tqlrat_(integer *,
doublereal *, doublereal *, integer *), imtqlv_(integer *,
doublereal *, doublereal *, doublereal *, doublereal *, integer *,
integer *, doublereal *), tinvit_(integer *, integer *,
doublereal *, doublereal *, doublereal *, integer *, doublereal *,
integer *, doublereal *, integer *, doublereal *, doublereal *,
doublereal *, doublereal *, doublereal *);
/* THIS SUBROUTINE CALLS THE RECOMMENDED SEQUENCE OF */
/* SUBROUTINES FROM THE EIGENSYSTEM SUBROUTINE PACKAGE (EISPACK) */
/* TO FIND ALL OF THE EIGENVALUES AND SOME OF THE EIGENVECTORS */
/* OF A REAL SYMMETRIC 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. */
/* A CONTAINS THE REAL SYMMETRIC MATRIX. */
/* M THE EIGENVECTORS CORRESPONDING TO THE FIRST M EIGENVALUES */
/* ARE TO BE COMPUTED. */
/* IF M = 0 THEN NO EIGENVECTORS ARE COMPUTED. */
/* IF M = N THEN ALL OF THE EIGENVECTORS ARE COMPUTED. */
/* ON OUTPUT */
/* W CONTAINS ALL N EIGENVALUES IN ASCENDING ORDER. */
/* Z CONTAINS THE ORTHONORMAL EIGENVECTORS ASSOCIATED WITH */
/* THE FIRST M EIGENVALUES. */
/* IERR IS AN INTEGER OUTPUT VARIABLE SET EQUAL TO AN ERROR */
/* COMPLETION CODE DESCRIBED IN THE DOCUMENTATION FOR TQLRAT, */
/* IMTQLV AND TINVIT. THE NORMAL COMPLETION CODE IS ZERO. */
/* FWORK IS A TEMPORARY STORAGE ARRAY OF DIMENSION 8*N. */
/* IWORK IS AN INTEGER TEMPORARY STORAGE ARRAY OF DIMENSION N. */
/* 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 */
--iwork;
--w;
a_dim1 = *nm;
a_offset = a_dim1 + 1;
a -= a_offset;
z_dim1 = *nm;
z_offset = z_dim1 + 1;
z__ -= z_offset;
--fwork;
/* Function Body */
*ierr = *n * 10;
if (*n > *nm || *m > *nm) {
goto L50;
}
k1 = 1;
k2 = k1 + *n;
k3 = k2 + *n;
k4 = k3 + *n;
k5 = k4 + *n;
k6 = k5 + *n;
k7 = k6 + *n;
k8 = k7 + *n;
if (*m > 0) {
goto L10;
}
/* .......... FIND EIGENVALUES ONLY .......... */
tred1_(nm, n, &a[a_offset], &w[1], &fwork[k1], &fwork[k2]);
tqlrat_(n, &w[1], &fwork[k2], ierr);
goto L50;
/* .......... FIND ALL EIGENVALUES AND M EIGENVECTORS .......... */
L10:
tred1_(nm, n, &a[a_offset], &fwork[k1], &fwork[k2], &fwork[k3]);
imtqlv_(n, &fwork[k1], &fwork[k2], &fwork[k3], &w[1], &iwork[1], ierr, &
fwork[k4]);
tinvit_(nm, n, &fwork[k1], &fwork[k2], &fwork[k3], m, &w[1], &iwork[1], &
z__[z_offset], ierr, &fwork[k4], &fwork[k5], &fwork[k6], &fwork[
k7], &fwork[k8]);
trbak1_(nm, n, &a[a_offset], &fwork[k2], m, &z__[z_offset]);
L50:
return 0;
} /* rsm_ */
syntax highlighted by Code2HTML, v. 0.9.1