00001 SUBROUTINE ZSYCONV( UPLO, WAY, N, A, LDA, IPIV, WORK, INFO )
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012 CHARACTER UPLO, WAY
00013 INTEGER INFO, LDA, N
00014
00015
00016 INTEGER IPIV( * )
00017 DOUBLE COMPLEX A( LDA, * ), WORK( * )
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072 DOUBLE COMPLEX ZERO
00073 PARAMETER ( ZERO = (0.0D+0,0.0D+0) )
00074
00075
00076 LOGICAL LSAME
00077 EXTERNAL LSAME
00078
00079
00080 EXTERNAL XERBLA
00081
00082 LOGICAL UPPER, CONVERT
00083 INTEGER I, IP, J
00084 DOUBLE COMPLEX TEMP
00085
00086
00087
00088 INFO = 0
00089 UPPER = LSAME( UPLO, 'U' )
00090 CONVERT = LSAME( WAY, 'C' )
00091 IF( .NOT.UPPER .AND. .NOT.LSAME( UPLO, 'L' ) ) THEN
00092 INFO = -1
00093 ELSE IF( .NOT.CONVERT .AND. .NOT.LSAME( WAY, 'R' ) ) THEN
00094 INFO = -2
00095 ELSE IF( N.LT.0 ) THEN
00096 INFO = -3
00097 ELSE IF( LDA.LT.MAX( 1, N ) ) THEN
00098 INFO = -5
00099
00100 END IF
00101 IF( INFO.NE.0 ) THEN
00102 CALL XERBLA( 'ZSYCONV', -INFO )
00103 RETURN
00104 END IF
00105
00106
00107
00108 IF( N.EQ.0 )
00109 $ RETURN
00110
00111 IF( UPPER ) THEN
00112
00113
00114
00115 IF ( CONVERT ) THEN
00116
00117
00118
00119
00120
00121 I=N
00122 WORK(1)=ZERO
00123 DO WHILE ( I .GT. 1 )
00124 IF( IPIV(I) .LT. 0 ) THEN
00125 WORK(I)=A(I-1,I)
00126 A(I-1,I)=ZERO
00127 I=I-1
00128 ELSE
00129 WORK(I)=ZERO
00130 ENDIF
00131 I=I-1
00132 END DO
00133
00134
00135
00136 I=N
00137 DO WHILE ( I .GE. 1 )
00138 IF( IPIV(I) .GT. 0) THEN
00139 IP=IPIV(I)
00140 IF( I .LT. N) THEN
00141 DO 12 J= I+1,N
00142 TEMP=A(IP,J)
00143 A(IP,J)=A(I,J)
00144 A(I,J)=TEMP
00145 12 CONTINUE
00146 ENDIF
00147 ELSE
00148 IP=-IPIV(I)
00149 IF( I .LT. N) THEN
00150 DO 13 J= I+1,N
00151 TEMP=A(IP,J)
00152 A(IP,J)=A(I-1,J)
00153 A(I-1,J)=TEMP
00154 13 CONTINUE
00155 ENDIF
00156 I=I-1
00157 ENDIF
00158 I=I-1
00159 END DO
00160
00161 ELSE
00162
00163
00164
00165
00166
00167 I=1
00168 DO WHILE ( I .LE. N )
00169 IF( IPIV(I) .GT. 0 ) THEN
00170 IP=IPIV(I)
00171 IF( I .LT. N) THEN
00172 DO J= I+1,N
00173 TEMP=A(IP,J)
00174 A(IP,J)=A(I,J)
00175 A(I,J)=TEMP
00176 END DO
00177 ENDIF
00178 ELSE
00179 IP=-IPIV(I)
00180 I=I+1
00181 IF( I .LT. N) THEN
00182 DO J= I+1,N
00183 TEMP=A(IP,J)
00184 A(IP,J)=A(I-1,J)
00185 A(I-1,J)=TEMP
00186 END DO
00187 ENDIF
00188 ENDIF
00189 I=I+1
00190 END DO
00191
00192
00193
00194 I=N
00195 DO WHILE ( I .GT. 1 )
00196 IF( IPIV(I) .LT. 0 ) THEN
00197 A(I-1,I)=WORK(I)
00198 I=I-1
00199 ENDIF
00200 I=I-1
00201 END DO
00202 END IF
00203
00204 ELSE
00205
00206
00207
00208 IF ( CONVERT ) THEN
00209
00210
00211
00212
00213
00214 I=1
00215 WORK(N)=ZERO
00216 DO WHILE ( I .LE. N )
00217 IF( I.LT.N .AND. IPIV(I) .LT. 0 ) THEN
00218 WORK(I)=A(I+1,I)
00219 A(I+1,I)=ZERO
00220 I=I+1
00221 ELSE
00222 WORK(I)=ZERO
00223 ENDIF
00224 I=I+1
00225 END DO
00226
00227
00228
00229 I=1
00230 DO WHILE ( I .LE. N )
00231 IF( IPIV(I) .GT. 0 ) THEN
00232 IP=IPIV(I)
00233 IF (I .GT. 1) THEN
00234 DO 22 J= 1,I-1
00235 TEMP=A(IP,J)
00236 A(IP,J)=A(I,J)
00237 A(I,J)=TEMP
00238 22 CONTINUE
00239 ENDIF
00240 ELSE
00241 IP=-IPIV(I)
00242 IF (I .GT. 1) THEN
00243 DO 23 J= 1,I-1
00244 TEMP=A(IP,J)
00245 A(IP,J)=A(I+1,J)
00246 A(I+1,J)=TEMP
00247 23 CONTINUE
00248 ENDIF
00249 I=I+1
00250 ENDIF
00251 I=I+1
00252 END DO
00253
00254 ELSE
00255
00256
00257
00258
00259
00260 I=N
00261 DO WHILE ( I .GE. 1 )
00262 IF( IPIV(I) .GT. 0 ) THEN
00263 IP=IPIV(I)
00264 IF (I .GT. 1) THEN
00265 DO J= 1,I-1
00266 TEMP=A(I,J)
00267 A(I,J)=A(IP,J)
00268 A(IP,J)=TEMP
00269 END DO
00270 ENDIF
00271 ELSE
00272 IP=-IPIV(I)
00273 I=I-1
00274 IF (I .GT. 1) THEN
00275 DO J= 1,I-1
00276 TEMP=A(I+1,J)
00277 A(I+1,J)=A(IP,J)
00278 A(IP,J)=TEMP
00279 END DO
00280 ENDIF
00281 ENDIF
00282 I=I-1
00283 END DO
00284
00285
00286
00287 I=1
00288 DO WHILE ( I .LE. N-1 )
00289 IF( IPIV(I) .LT. 0 ) THEN
00290 A(I+1,I)=WORK(I)
00291 I=I+1
00292 ENDIF
00293 I=I+1
00294 END DO
00295 END IF
00296 END IF
00297
00298 RETURN
00299
00300
00301
00302 END