00001 SUBROUTINE STFTTR( TRANSR, UPLO, N, ARF, A, LDA, INFO )
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012 CHARACTER TRANSR, UPLO
00013 INTEGER INFO, N, LDA
00014
00015
00016 REAL A( 0: LDA-1, 0: * ), ARF( 0: * )
00017
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
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131
00132
00133
00134
00135
00136
00137
00138
00139
00140
00141
00142
00143
00144
00145
00146
00147
00148
00149
00150
00151 LOGICAL LOWER, NISODD, NORMALTRANSR
00152 INTEGER N1, N2, K, NT, NX2, NP1X2
00153 INTEGER I, J, L, IJ
00154
00155
00156 LOGICAL LSAME
00157 EXTERNAL LSAME
00158
00159
00160 EXTERNAL XERBLA
00161
00162
00163 INTRINSIC MAX, MOD
00164
00165
00166
00167
00168
00169 INFO = 0
00170 NORMALTRANSR = LSAME( TRANSR, 'N' )
00171 LOWER = LSAME( UPLO, 'L' )
00172 IF( .NOT.NORMALTRANSR .AND. .NOT.LSAME( TRANSR, 'T' ) ) THEN
00173 INFO = -1
00174 ELSE IF( .NOT.LOWER .AND. .NOT.LSAME( UPLO, 'U' ) ) THEN
00175 INFO = -2
00176 ELSE IF( N.LT.0 ) THEN
00177 INFO = -3
00178 ELSE IF( LDA.LT.MAX( 1, N ) ) THEN
00179 INFO = -6
00180 END IF
00181 IF( INFO.NE.0 ) THEN
00182 CALL XERBLA( 'STFTTR', -INFO )
00183 RETURN
00184 END IF
00185
00186
00187
00188 IF( N.LE.1 ) THEN
00189 IF( N.EQ.1 ) THEN
00190 A( 0, 0 ) = ARF( 0 )
00191 END IF
00192 RETURN
00193 END IF
00194
00195
00196
00197 NT = N*( N+1 ) / 2
00198
00199
00200
00201 IF( LOWER ) THEN
00202 N2 = N / 2
00203 N1 = N - N2
00204 ELSE
00205 N1 = N / 2
00206 N2 = N - N1
00207 END IF
00208
00209
00210
00211
00212
00213 IF( MOD( N, 2 ).EQ.0 ) THEN
00214 K = N / 2
00215 NISODD = .FALSE.
00216 IF( .NOT.LOWER )
00217 + NP1X2 = N + N + 2
00218 ELSE
00219 NISODD = .TRUE.
00220 IF( .NOT.LOWER )
00221 + NX2 = N + N
00222 END IF
00223
00224 IF( NISODD ) THEN
00225
00226
00227
00228 IF( NORMALTRANSR ) THEN
00229
00230
00231
00232 IF( LOWER ) THEN
00233
00234
00235
00236 IJ = 0
00237 DO J = 0, N2
00238 DO I = N1, N2 + J
00239 A( N2+J, I ) = ARF( IJ )
00240 IJ = IJ + 1
00241 END DO
00242 DO I = J, N - 1
00243 A( I, J ) = ARF( IJ )
00244 IJ = IJ + 1
00245 END DO
00246 END DO
00247
00248 ELSE
00249
00250
00251
00252 IJ = NT - N
00253 DO J = N - 1, N1, -1
00254 DO I = 0, J
00255 A( I, J ) = ARF( IJ )
00256 IJ = IJ + 1
00257 END DO
00258 DO L = J - N1, N1 - 1
00259 A( J-N1, L ) = ARF( IJ )
00260 IJ = IJ + 1
00261 END DO
00262 IJ = IJ - NX2
00263 END DO
00264
00265 END IF
00266
00267 ELSE
00268
00269
00270
00271 IF( LOWER ) THEN
00272
00273
00274
00275 IJ = 0
00276 DO J = 0, N2 - 1
00277 DO I = 0, J
00278 A( J, I ) = ARF( IJ )
00279 IJ = IJ + 1
00280 END DO
00281 DO I = N1 + J, N - 1
00282 A( I, N1+J ) = ARF( IJ )
00283 IJ = IJ + 1
00284 END DO
00285 END DO
00286 DO J = N2, N - 1
00287 DO I = 0, N1 - 1
00288 A( J, I ) = ARF( IJ )
00289 IJ = IJ + 1
00290 END DO
00291 END DO
00292
00293 ELSE
00294
00295
00296
00297 IJ = 0
00298 DO J = 0, N1
00299 DO I = N1, N - 1
00300 A( J, I ) = ARF( IJ )
00301 IJ = IJ + 1
00302 END DO
00303 END DO
00304 DO J = 0, N1 - 1
00305 DO I = 0, J
00306 A( I, J ) = ARF( IJ )
00307 IJ = IJ + 1
00308 END DO
00309 DO L = N2 + J, N - 1
00310 A( N2+J, L ) = ARF( IJ )
00311 IJ = IJ + 1
00312 END DO
00313 END DO
00314
00315 END IF
00316
00317 END IF
00318
00319 ELSE
00320
00321
00322
00323 IF( NORMALTRANSR ) THEN
00324
00325
00326
00327 IF( LOWER ) THEN
00328
00329
00330
00331 IJ = 0
00332 DO J = 0, K - 1
00333 DO I = K, K + J
00334 A( K+J, I ) = ARF( IJ )
00335 IJ = IJ + 1
00336 END DO
00337 DO I = J, N - 1
00338 A( I, J ) = ARF( IJ )
00339 IJ = IJ + 1
00340 END DO
00341 END DO
00342
00343 ELSE
00344
00345
00346
00347 IJ = NT - N - 1
00348 DO J = N - 1, K, -1
00349 DO I = 0, J
00350 A( I, J ) = ARF( IJ )
00351 IJ = IJ + 1
00352 END DO
00353 DO L = J - K, K - 1
00354 A( J-K, L ) = ARF( IJ )
00355 IJ = IJ + 1
00356 END DO
00357 IJ = IJ - NP1X2
00358 END DO
00359
00360 END IF
00361
00362 ELSE
00363
00364
00365
00366 IF( LOWER ) THEN
00367
00368
00369
00370 IJ = 0
00371 J = K
00372 DO I = K, N - 1
00373 A( I, J ) = ARF( IJ )
00374 IJ = IJ + 1
00375 END DO
00376 DO J = 0, K - 2
00377 DO I = 0, J
00378 A( J, I ) = ARF( IJ )
00379 IJ = IJ + 1
00380 END DO
00381 DO I = K + 1 + J, N - 1
00382 A( I, K+1+J ) = ARF( IJ )
00383 IJ = IJ + 1
00384 END DO
00385 END DO
00386 DO J = K - 1, N - 1
00387 DO I = 0, K - 1
00388 A( J, I ) = ARF( IJ )
00389 IJ = IJ + 1
00390 END DO
00391 END DO
00392
00393 ELSE
00394
00395
00396
00397 IJ = 0
00398 DO J = 0, K
00399 DO I = K, N - 1
00400 A( J, I ) = ARF( IJ )
00401 IJ = IJ + 1
00402 END DO
00403 END DO
00404 DO J = 0, K - 2
00405 DO I = 0, J
00406 A( I, J ) = ARF( IJ )
00407 IJ = IJ + 1
00408 END DO
00409 DO L = K + 1 + J, N - 1
00410 A( K+1+J, L ) = ARF( IJ )
00411 IJ = IJ + 1
00412 END DO
00413 END DO
00414
00415 DO I = 0, J
00416 A( I, J ) = ARF( IJ )
00417 IJ = IJ + 1
00418 END DO
00419
00420 END IF
00421
00422 END IF
00423
00424 END IF
00425
00426 RETURN
00427
00428
00429
00430 END