1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
|
C/MEMBR ADD NAME=ORTRAN,SSI=0
subroutine ortran(nm,n,low,igh,a,ort,z)
c
integer i,j,n,kl,mm,mp,nm,igh,low,mp1
double precision a(nm,igh),ort(igh),z(nm,n)
double precision g
c!purpose
c
c this subroutine accumulates the orthogonal similarity
c transformations used in the reduction of a real general
c matrix to upper hessenberg form by orthes.
c
c!calling sequence
c
c subroutine ortran(nm,n,low,igh,a,ort,z)
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 the balancing
c subroutine balanc. if balanc has not been used,
c set low=1, igh=n;
c
c a contains information about the orthogonal trans-
c formations used in the reduction by orthes
c in its strict lower triangle;
c
c ort contains further information about the trans-
c formations used in the reduction by orthes.
c only elements low through igh are used.
c
c on output:
c
c z contains the transformation matrix produced in the
c reduction by orthes;
c
c ort has been altered.
c
c!originator
c
c this subroutine is a translation of the algol procedure ortrans,
c num. math. 16, 181-204(1970) by peters and wilkinson.
c handbook for auto. comp., vol.ii-linear algebra, 372-395(1971).
c!
c questions and comments should be directed to b. s. garbow,
c applied mathematics division, argonne national laboratory
c
c ------------------------------------------------------------------
c
c :::::::::: initialize z to identity matrix ::::::::::
do 80 i = 1, n
c
do 60 j = 1, n
60 z(i,j) = 0.0d+0
c
z(i,i) = 1.0d+0
80 continue
c
kl = igh - low - 1
if (kl .lt. 1) go to 200
c :::::::::: for mp=igh-1 step -1 until low+1 do -- ::::::::::
do 140 mm = 1, kl
mp = igh - mm
if (a(mp,mp-1) .eq. 0.0d+0) go to 140
mp1 = mp + 1
c
do 100 i = mp1, igh
100 ort(i) = a(i,mp-1)
c
do 130 j = mp, igh
g = 0.0d+0
c
do 110 i = mp, igh
110 g = g + ort(i) * z(i,j)
c :::::::::: divisor below is negative of h formed in orthes.
c double division avoids possible underflow ::::::::::
g = (g / ort(mp)) / a(mp,mp-1)
c
do 120 i = mp, igh
120 z(i,j) = z(i,j) + g * ort(i)
c
130 continue
c
140 continue
c
200 return
c :::::::::: last card of ortran ::::::::::
end
|