home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Geek Gadgets 1
/
ADE-1.bin
/
ade-dist
/
eispack-1.0-src.tgz
/
tar.out
/
contrib
/
eispack
/
cbabk2.f
< prev
next >
Wrap
Text File
|
1996-09-28
|
3KB
|
84 lines
subroutine cbabk2(nm,n,low,igh,scale,m,zr,zi)
c
integer i,j,k,m,n,ii,nm,igh,low
double precision scale(n),zr(nm,m),zi(nm,m)
double precision s
c
c this subroutine is a translation of the algol procedure
c cbabk2, which is a complex version of balbak,
c num. math. 13, 293-304(1969) by parlett and reinsch.
c handbook for auto. comp., vol.ii-linear algebra, 315-326(1971).
c
c this subroutine forms the eigenvectors of a complex general
c matrix by back transforming those of the corresponding
c balanced matrix determined by cbal.
c
c on input
c
c nm must be set to the row dimension of two-dimensional
c array parameters as declared in the calling program
c dimension statement.
c
c n is the order of the matrix.
c
c low and igh are integers determined by cbal.
c
c scale contains information determining the permutations
c and scaling factors used by cbal.
c
c m is the number of eigenvectors to be back transformed.
c
c zr and zi contain the real and imaginary parts,
c respectively, of the eigenvectors to be
c back transformed in their first m columns.
c
c on output
c
c zr and zi contain the real and imaginary parts,
c respectively, of the transformed eigenvectors
c in their first m columns.
c
c questions and comments should be directed to burton s. garbow,
c mathematics and computer science div, argonne national laboratory
c
c this version dated august 1983.
c
c ------------------------------------------------------------------
c
if (m .eq. 0) go to 200
if (igh .eq. low) go to 120
c
do 110 i = low, igh
s = scale(i)
c .......... left hand eigenvectors are back transformed
c if the foregoing statement is replaced by
c s=1.0d0/scale(i). ..........
do 100 j = 1, m
zr(i,j) = zr(i,j) * s
zi(i,j) = zi(i,j) * s
100 continue
c
110 continue
c .......... for i=low-1 step -1 until 1,
c igh+1 step 1 until n do -- ..........
120 do 140 ii = 1, n
i = ii
if (i .ge. low .and. i .le. igh) go to 140
if (i .lt. low) i = low - ii
k = scale(i)
if (k .eq. i) go to 140
c
do 130 j = 1, m
s = zr(i,j)
zr(i,j) = zr(k,j)
zr(k,j) = s
s = zi(i,j)
zi(i,j) = zi(k,j)
zi(k,j) = s
130 continue
c
140 continue
c
200 return
end