/* This software was developed by Bruce Hendrickson and Robert Leland   *
 * at Sandia National Laboratories under US Department of Energy        *
 * contract DE-AC04-76DP00789 and is copyrighted by Sandia Corporation. */

#include <stdio.h>
#include "structs.h"
#include "defs.h"

/* Assemble eigenvectors, return bounds, etc. */
void      mkeigvecs(scanlist, lambda, bound, index, bj, d, Sres_max,
                    alpha, beta, j, s, y, n, q)
struct scanlink *scanlist;      /* linked list of fields to do with min ritz vals */
double   *lambda;               /* ritz approximation to eigenvals of A */
double   *bound;                /* on ritz pair approximations to eig pairs of A */
int      *index;                /* the Ritz index of an eigenpair */
double   *bj;                   /* beta(j)*(last el. of corr. eigvec s of T) */
int       d;                    /* problem dimension = number of eigvecs to find */
double   *Sres_max;             /* Max value of Sres */
double   *alpha;		/* vector of Lanczos scalars */
double   *beta;			/* vector of Lanczos scalars */
int       j;			/* number of Lanczos iterations taken */
double   *s;			/* approximate eigenvector of T */
double  **y;                    /* columns of y are eigenvectors of A  */
int       n;                    /* problem size */
double  **q;                    /* columns of q are Lanczos basis vectors */
{

    int       i,k;		/* indcies */
    double    Sres;             /* how well Tevec calculated eigvec s */
    struct scanlink *curlnk;    /* for traversing the scanlist */
    void      setvec();         /* initialize a vector */
    void      scadd();          /* add scalar multiple of vector to another */
    double    Tevec();          /* calc eigenvector of T by linear recurrence */

    /* Scan for some data which is used here or later */ 
    i = d;
    curlnk = scanlist;
    while (curlnk != NULL) {
        lambda[i] = curlnk->val;
        bound[i] = bj[curlnk->indx];
        index[i] = curlnk->indx;
        curlnk = curlnk->pntr;
        i--;
    }
 
    /* Assemble the evecs from the Lanczos basis */
    for (i = 1; i <= d; i++) {
        Sres = Tevec(alpha, beta - 1, j, lambda[i], s);
        if (Sres > *Sres_max) {
            *Sres_max = Sres;
        }
        setvec(y[i], 1, n, 0.0);
        for (k = 1; k <= j; k++) {
            scadd(y[i], 1, n, s[k], q[k]);
        }
    }
}


syntax highlighted by Code2HTML, v. 0.9.1