1 subroutine fprank(a,f,n,m,na,tol,c,sq,rank,aa,ff,h)
24 real*8 a(na,m),f(n),c(n),aa(n,m),ff(n),h(m)
26 integer i,ii,ij,i1,i2,j,jj,j1,j2,j3,k,kk,m1,nl
27 real*8 cos,fac,piv,sin,yi
28 double precision store,stor1,stor2,stor3
40 if(a(i,1).gt.tol) go to 90
56 if(piv.eq.0.) go to 30
57 call
fpgivs(piv,a(ii,1),cos,sin)
58 call
fprota(cos,sin,yi,f(ii))
62 call
fprota(cos,sin,h(j1),a(ii,j1))
66 30
if(i2.eq.0) go to 70
100 if(a(i,1).le.tol) go to 120
108 if(j1.eq.0) go to 120
111 if(a(j,1).le.tol) go to 110
121 if(a(i,1).gt.tol) go to 200
123 if(ii.eq.0) go to 200
129 if(a(j,1).le.tol) go to 130
141 if(piv.ne.0.) go to 160
142 if(j1.eq.0) go to 200
148 160 call
fpgivs(piv,aa(jj,1),cos,sin)
149 if(j1.eq.0) go to 200
154 call
fprota(cos,sin,h(j3),aa(kk,j3))
162 ff(rank) = ff(rank)/aa(rank,1)
173 store = store-stor1*stor2
180 230 ff(1) = ff(1)/aa(1,1)
181 if(rank.eq.1) go to 260
190 store = store-stor1*stor2
199 if(a(i,1).gt.tol) k = k+1
205 if(a(ij,1).le.tol) go to 270
208 store = store+stor1*stor2
217 if(a(i,1).gt.tol) go to 310
220 if(i1.eq.0) go to 300
225 store = store-stor1*stor2
227 300 fac = a(i,1)*c(i)
231 stor3 = stor3+stor1*(stor1-store-store)
subroutine fprota(cos, sin, a, b)
subroutine fprank(a, f, n, m, na, tol, c, sq, rank, aa, ff, h)
subroutine fpgivs(piv, ww, cos, sin)