00001 SUBROUTINE CGBBRD( VECT, M, N, NCC, KL, KU, AB, LDAB, D, E, Q,
00002 $ LDQ, PT, LDPT, C, LDC, WORK, RWORK, INFO )
00003
00004
00005
00006
00007
00008
00009
00010 CHARACTER VECT
00011 INTEGER INFO, KL, KU, LDAB, LDC, LDPT, LDQ, M, N, NCC
00012
00013
00014 REAL D( * ), E( * ), RWORK( * )
00015 COMPLEX AB( LDAB, * ), C( LDC, * ), PT( LDPT, * ),
00016 $ Q( LDQ, * ), WORK( * )
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 REAL ZERO
00108 PARAMETER ( ZERO = 0.0E+0 )
00109 COMPLEX CZERO, CONE
00110 PARAMETER ( CZERO = ( 0.0E+0, 0.0E+0 ),
00111 $ CONE = ( 1.0E+0, 0.0E+0 ) )
00112
00113
00114 LOGICAL WANTB, WANTC, WANTPT, WANTQ
00115 INTEGER I, INCA, J, J1, J2, KB, KB1, KK, KLM, KLU1,
00116 $ KUN, L, MINMN, ML, ML0, MU, MU0, NR, NRT
00117 REAL ABST, RC
00118 COMPLEX RA, RB, RS, T
00119
00120
00121 EXTERNAL CLARGV, CLARTG, CLARTV, CLASET, CROT, CSCAL,
00122 $ XERBLA
00123
00124
00125 INTRINSIC ABS, CONJG, MAX, MIN
00126
00127
00128 LOGICAL LSAME
00129 EXTERNAL LSAME
00130
00131
00132
00133
00134
00135 WANTB = LSAME( VECT, 'B' )
00136 WANTQ = LSAME( VECT, 'Q' ) .OR. WANTB
00137 WANTPT = LSAME( VECT, 'P' ) .OR. WANTB
00138 WANTC = NCC.GT.0
00139 KLU1 = KL + KU + 1
00140 INFO = 0
00141 IF( .NOT.WANTQ .AND. .NOT.WANTPT .AND. .NOT.LSAME( VECT, 'N' ) )
00142 $ THEN
00143 INFO = -1
00144 ELSE IF( M.LT.0 ) THEN
00145 INFO = -2
00146 ELSE IF( N.LT.0 ) THEN
00147 INFO = -3
00148 ELSE IF( NCC.LT.0 ) THEN
00149 INFO = -4
00150 ELSE IF( KL.LT.0 ) THEN
00151 INFO = -5
00152 ELSE IF( KU.LT.0 ) THEN
00153 INFO = -6
00154 ELSE IF( LDAB.LT.KLU1 ) THEN
00155 INFO = -8
00156 ELSE IF( LDQ.LT.1 .OR. WANTQ .AND. LDQ.LT.MAX( 1, M ) ) THEN
00157 INFO = -12
00158 ELSE IF( LDPT.LT.1 .OR. WANTPT .AND. LDPT.LT.MAX( 1, N ) ) THEN
00159 INFO = -14
00160 ELSE IF( LDC.LT.1 .OR. WANTC .AND. LDC.LT.MAX( 1, M ) ) THEN
00161 INFO = -16
00162 END IF
00163 IF( INFO.NE.0 ) THEN
00164 CALL XERBLA( 'CGBBRD', -INFO )
00165 RETURN
00166 END IF
00167
00168
00169
00170 IF( WANTQ )
00171 $ CALL CLASET( 'Full', M, M, CZERO, CONE, Q, LDQ )
00172 IF( WANTPT )
00173 $ CALL CLASET( 'Full', N, N, CZERO, CONE, PT, LDPT )
00174
00175
00176
00177 IF( M.EQ.0 .OR. N.EQ.0 )
00178 $ RETURN
00179
00180 MINMN = MIN( M, N )
00181
00182 IF( KL+KU.GT.1 ) THEN
00183
00184
00185
00186
00187
00188 IF( KU.GT.0 ) THEN
00189 ML0 = 1
00190 MU0 = 2
00191 ELSE
00192 ML0 = 2
00193 MU0 = 1
00194 END IF
00195
00196
00197
00198
00199
00200
00201
00202 KLM = MIN( M-1, KL )
00203 KUN = MIN( N-1, KU )
00204 KB = KLM + KUN
00205 KB1 = KB + 1
00206 INCA = KB1*LDAB
00207 NR = 0
00208 J1 = KLM + 2
00209 J2 = 1 - KUN
00210
00211 DO 90 I = 1, MINMN
00212
00213
00214
00215 ML = KLM + 1
00216 MU = KUN + 1
00217 DO 80 KK = 1, KB
00218 J1 = J1 + KB
00219 J2 = J2 + KB
00220
00221
00222
00223
00224 IF( NR.GT.0 )
00225 $ CALL CLARGV( NR, AB( KLU1, J1-KLM-1 ), INCA,
00226 $ WORK( J1 ), KB1, RWORK( J1 ), KB1 )
00227
00228
00229
00230 DO 10 L = 1, KB
00231 IF( J2-KLM+L-1.GT.N ) THEN
00232 NRT = NR - 1
00233 ELSE
00234 NRT = NR
00235 END IF
00236 IF( NRT.GT.0 )
00237 $ CALL CLARTV( NRT, AB( KLU1-L, J1-KLM+L-1 ), INCA,
00238 $ AB( KLU1-L+1, J1-KLM+L-1 ), INCA,
00239 $ RWORK( J1 ), WORK( J1 ), KB1 )
00240 10 CONTINUE
00241
00242 IF( ML.GT.ML0 ) THEN
00243 IF( ML.LE.M-I+1 ) THEN
00244
00245
00246
00247
00248 CALL CLARTG( AB( KU+ML-1, I ), AB( KU+ML, I ),
00249 $ RWORK( I+ML-1 ), WORK( I+ML-1 ), RA )
00250 AB( KU+ML-1, I ) = RA
00251 IF( I.LT.N )
00252 $ CALL CROT( MIN( KU+ML-2, N-I ),
00253 $ AB( KU+ML-2, I+1 ), LDAB-1,
00254 $ AB( KU+ML-1, I+1 ), LDAB-1,
00255 $ RWORK( I+ML-1 ), WORK( I+ML-1 ) )
00256 END IF
00257 NR = NR + 1
00258 J1 = J1 - KB1
00259 END IF
00260
00261 IF( WANTQ ) THEN
00262
00263
00264
00265 DO 20 J = J1, J2, KB1
00266 CALL CROT( M, Q( 1, J-1 ), 1, Q( 1, J ), 1,
00267 $ RWORK( J ), CONJG( WORK( J ) ) )
00268 20 CONTINUE
00269 END IF
00270
00271 IF( WANTC ) THEN
00272
00273
00274
00275 DO 30 J = J1, J2, KB1
00276 CALL CROT( NCC, C( J-1, 1 ), LDC, C( J, 1 ), LDC,
00277 $ RWORK( J ), WORK( J ) )
00278 30 CONTINUE
00279 END IF
00280
00281 IF( J2+KUN.GT.N ) THEN
00282
00283
00284
00285 NR = NR - 1
00286 J2 = J2 - KB1
00287 END IF
00288
00289 DO 40 J = J1, J2, KB1
00290
00291
00292
00293
00294 WORK( J+KUN ) = WORK( J )*AB( 1, J+KUN )
00295 AB( 1, J+KUN ) = RWORK( J )*AB( 1, J+KUN )
00296 40 CONTINUE
00297
00298
00299
00300
00301 IF( NR.GT.0 )
00302 $ CALL CLARGV( NR, AB( 1, J1+KUN-1 ), INCA,
00303 $ WORK( J1+KUN ), KB1, RWORK( J1+KUN ),
00304 $ KB1 )
00305
00306
00307
00308 DO 50 L = 1, KB
00309 IF( J2+L-1.GT.M ) THEN
00310 NRT = NR - 1
00311 ELSE
00312 NRT = NR
00313 END IF
00314 IF( NRT.GT.0 )
00315 $ CALL CLARTV( NRT, AB( L+1, J1+KUN-1 ), INCA,
00316 $ AB( L, J1+KUN ), INCA,
00317 $ RWORK( J1+KUN ), WORK( J1+KUN ), KB1 )
00318 50 CONTINUE
00319
00320 IF( ML.EQ.ML0 .AND. MU.GT.MU0 ) THEN
00321 IF( MU.LE.N-I+1 ) THEN
00322
00323
00324
00325
00326 CALL CLARTG( AB( KU-MU+3, I+MU-2 ),
00327 $ AB( KU-MU+2, I+MU-1 ),
00328 $ RWORK( I+MU-1 ), WORK( I+MU-1 ), RA )
00329 AB( KU-MU+3, I+MU-2 ) = RA
00330 CALL CROT( MIN( KL+MU-2, M-I ),
00331 $ AB( KU-MU+4, I+MU-2 ), 1,
00332 $ AB( KU-MU+3, I+MU-1 ), 1,
00333 $ RWORK( I+MU-1 ), WORK( I+MU-1 ) )
00334 END IF
00335 NR = NR + 1
00336 J1 = J1 - KB1
00337 END IF
00338
00339 IF( WANTPT ) THEN
00340
00341
00342
00343 DO 60 J = J1, J2, KB1
00344 CALL CROT( N, PT( J+KUN-1, 1 ), LDPT,
00345 $ PT( J+KUN, 1 ), LDPT, RWORK( J+KUN ),
00346 $ CONJG( WORK( J+KUN ) ) )
00347 60 CONTINUE
00348 END IF
00349
00350 IF( J2+KB.GT.M ) THEN
00351
00352
00353
00354 NR = NR - 1
00355 J2 = J2 - KB1
00356 END IF
00357
00358 DO 70 J = J1, J2, KB1
00359
00360
00361
00362
00363 WORK( J+KB ) = WORK( J+KUN )*AB( KLU1, J+KUN )
00364 AB( KLU1, J+KUN ) = RWORK( J+KUN )*AB( KLU1, J+KUN )
00365 70 CONTINUE
00366
00367 IF( ML.GT.ML0 ) THEN
00368 ML = ML - 1
00369 ELSE
00370 MU = MU - 1
00371 END IF
00372 80 CONTINUE
00373 90 CONTINUE
00374 END IF
00375
00376 IF( KU.EQ.0 .AND. KL.GT.0 ) THEN
00377
00378
00379
00380
00381
00382
00383
00384 DO 100 I = 1, MIN( M-1, N )
00385 CALL CLARTG( AB( 1, I ), AB( 2, I ), RC, RS, RA )
00386 AB( 1, I ) = RA
00387 IF( I.LT.N ) THEN
00388 AB( 2, I ) = RS*AB( 1, I+1 )
00389 AB( 1, I+1 ) = RC*AB( 1, I+1 )
00390 END IF
00391 IF( WANTQ )
00392 $ CALL CROT( M, Q( 1, I ), 1, Q( 1, I+1 ), 1, RC,
00393 $ CONJG( RS ) )
00394 IF( WANTC )
00395 $ CALL CROT( NCC, C( I, 1 ), LDC, C( I+1, 1 ), LDC, RC,
00396 $ RS )
00397 100 CONTINUE
00398 ELSE
00399
00400
00401
00402
00403 IF( KU.GT.0 .AND. M.LT.N ) THEN
00404
00405
00406
00407
00408 RB = AB( KU, M+1 )
00409 DO 110 I = M, 1, -1
00410 CALL CLARTG( AB( KU+1, I ), RB, RC, RS, RA )
00411 AB( KU+1, I ) = RA
00412 IF( I.GT.1 ) THEN
00413 RB = -CONJG( RS )*AB( KU, I )
00414 AB( KU, I ) = RC*AB( KU, I )
00415 END IF
00416 IF( WANTPT )
00417 $ CALL CROT( N, PT( I, 1 ), LDPT, PT( M+1, 1 ), LDPT,
00418 $ RC, CONJG( RS ) )
00419 110 CONTINUE
00420 END IF
00421 END IF
00422
00423
00424
00425
00426 T = AB( KU+1, 1 )
00427 DO 120 I = 1, MINMN
00428 ABST = ABS( T )
00429 D( I ) = ABST
00430 IF( ABST.NE.ZERO ) THEN
00431 T = T / ABST
00432 ELSE
00433 T = CONE
00434 END IF
00435 IF( WANTQ )
00436 $ CALL CSCAL( M, T, Q( 1, I ), 1 )
00437 IF( WANTC )
00438 $ CALL CSCAL( NCC, CONJG( T ), C( I, 1 ), LDC )
00439 IF( I.LT.MINMN ) THEN
00440 IF( KU.EQ.0 .AND. KL.EQ.0 ) THEN
00441 E( I ) = ZERO
00442 T = AB( 1, I+1 )
00443 ELSE
00444 IF( KU.EQ.0 ) THEN
00445 T = AB( 2, I )*CONJG( T )
00446 ELSE
00447 T = AB( KU, I+1 )*CONJG( T )
00448 END IF
00449 ABST = ABS( T )
00450 E( I ) = ABST
00451 IF( ABST.NE.ZERO ) THEN
00452 T = T / ABST
00453 ELSE
00454 T = CONE
00455 END IF
00456 IF( WANTPT )
00457 $ CALL CSCAL( N, T, PT( I+1, 1 ), LDPT )
00458 T = AB( KU+1, I+1 )*CONJG( T )
00459 END IF
00460 END IF
00461 120 CONTINUE
00462 RETURN
00463
00464
00465
00466 END