00001 SUBROUTINE SLAQR5( WANTT, WANTZ, KACC22, N, KTOP, KBOT, NSHFTS,
00002 $ SR, SI, H, LDH, ILOZ, IHIZ, Z, LDZ, V, LDV, U,
00003 $ LDU, NV, WV, LDWV, NH, WH, LDWH )
00004
00005
00006
00007
00008
00009
00010
00011 INTEGER IHIZ, ILOZ, KACC22, KBOT, KTOP, LDH, LDU, LDV,
00012 $ LDWH, LDWV, LDZ, N, NH, NSHFTS, NV
00013 LOGICAL WANTT, WANTZ
00014
00015
00016 REAL H( LDH, * ), SI( * ), SR( * ), U( LDU, * ),
00017 $ V( LDV, * ), WH( LDWH, * ), WV( LDWV, * ),
00018 $ Z( LDZ, * )
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 REAL ZERO, ONE
00144 PARAMETER ( ZERO = 0.0e0, ONE = 1.0e0 )
00145
00146
00147 REAL ALPHA, BETA, H11, H12, H21, H22, REFSUM,
00148 $ SAFMAX, SAFMIN, SCL, SMLNUM, SWAP, TST1, TST2,
00149 $ ULP
00150 INTEGER I, I2, I4, INCOL, J, J2, J4, JBOT, JCOL, JLEN,
00151 $ JROW, JTOP, K, K1, KDU, KMS, KNZ, KRCOL, KZS,
00152 $ M, M22, MBOT, MEND, MSTART, MTOP, NBMPS, NDCOL,
00153 $ NS, NU
00154 LOGICAL ACCUM, BLK22, BMP22
00155
00156
00157 REAL SLAMCH
00158 EXTERNAL SLAMCH
00159
00160
00161
00162 INTRINSIC ABS, MAX, MIN, MOD, REAL
00163
00164
00165 REAL VT( 3 )
00166
00167
00168 EXTERNAL SGEMM, SLABAD, SLACPY, SLAQR1, SLARFG, SLASET,
00169 $ STRMM
00170
00171
00172
00173
00174
00175 IF( NSHFTS.LT.2 )
00176 $ RETURN
00177
00178
00179
00180
00181 IF( KTOP.GE.KBOT )
00182 $ RETURN
00183
00184
00185
00186
00187
00188
00189 DO 10 I = 1, NSHFTS - 2, 2
00190 IF( SI( I ).NE.-SI( I+1 ) ) THEN
00191
00192 SWAP = SR( I )
00193 SR( I ) = SR( I+1 )
00194 SR( I+1 ) = SR( I+2 )
00195 SR( I+2 ) = SWAP
00196
00197 SWAP = SI( I )
00198 SI( I ) = SI( I+1 )
00199 SI( I+1 ) = SI( I+2 )
00200 SI( I+2 ) = SWAP
00201 END IF
00202 10 CONTINUE
00203
00204
00205
00206
00207
00208
00209 NS = NSHFTS - MOD( NSHFTS, 2 )
00210
00211
00212
00213 SAFMIN = SLAMCH( 'SAFE MINIMUM' )
00214 SAFMAX = ONE / SAFMIN
00215 CALL SLABAD( SAFMIN, SAFMAX )
00216 ULP = SLAMCH( 'PRECISION' )
00217 SMLNUM = SAFMIN*( REAL( N ) / ULP )
00218
00219
00220
00221
00222 ACCUM = ( KACC22.EQ.1 ) .OR. ( KACC22.EQ.2 )
00223
00224
00225
00226 BLK22 = ( NS.GT.2 ) .AND. ( KACC22.EQ.2 )
00227
00228
00229
00230 IF( KTOP+2.LE.KBOT )
00231 $ H( KTOP+2, KTOP ) = ZERO
00232
00233
00234
00235 NBMPS = NS / 2
00236
00237
00238
00239 KDU = 6*NBMPS - 3
00240
00241
00242
00243 DO 220 INCOL = 3*( 1-NBMPS ) + KTOP - 1, KBOT - 2, 3*NBMPS - 2
00244 NDCOL = INCOL + KDU
00245 IF( ACCUM )
00246 $ CALL SLASET( 'ALL', KDU, KDU, ZERO, ONE, U, LDU )
00247
00248
00249
00250
00251
00252
00253
00254
00255
00256
00257
00258
00259
00260 DO 150 KRCOL = INCOL, MIN( INCOL+3*NBMPS-3, KBOT-2 )
00261
00262
00263
00264
00265
00266
00267
00268
00269 MTOP = MAX( 1, ( ( KTOP-1 )-KRCOL+2 ) / 3+1 )
00270 MBOT = MIN( NBMPS, ( KBOT-KRCOL ) / 3 )
00271 M22 = MBOT + 1
00272 BMP22 = ( MBOT.LT.NBMPS ) .AND. ( KRCOL+3*( M22-1 ) ).EQ.
00273 $ ( KBOT-2 )
00274
00275
00276
00277
00278 DO 20 M = MTOP, MBOT
00279 K = KRCOL + 3*( M-1 )
00280 IF( K.EQ.KTOP-1 ) THEN
00281 CALL SLAQR1( 3, H( KTOP, KTOP ), LDH, SR( 2*M-1 ),
00282 $ SI( 2*M-1 ), SR( 2*M ), SI( 2*M ),
00283 $ V( 1, M ) )
00284 ALPHA = V( 1, M )
00285 CALL SLARFG( 3, ALPHA, V( 2, M ), 1, V( 1, M ) )
00286 ELSE
00287 BETA = H( K+1, K )
00288 V( 2, M ) = H( K+2, K )
00289 V( 3, M ) = H( K+3, K )
00290 CALL SLARFG( 3, BETA, V( 2, M ), 1, V( 1, M ) )
00291
00292
00293
00294
00295
00296
00297 IF( H( K+3, K ).NE.ZERO .OR. H( K+3, K+1 ).NE.
00298 $ ZERO .OR. H( K+3, K+2 ).EQ.ZERO ) THEN
00299
00300
00301
00302 H( K+1, K ) = BETA
00303 H( K+2, K ) = ZERO
00304 H( K+3, K ) = ZERO
00305 ELSE
00306
00307
00308
00309
00310
00311
00312
00313 CALL SLAQR1( 3, H( K+1, K+1 ), LDH, SR( 2*M-1 ),
00314 $ SI( 2*M-1 ), SR( 2*M ), SI( 2*M ),
00315 $ VT )
00316 ALPHA = VT( 1 )
00317 CALL SLARFG( 3, ALPHA, VT( 2 ), 1, VT( 1 ) )
00318 REFSUM = VT( 1 )*( H( K+1, K )+VT( 2 )*
00319 $ H( K+2, K ) )
00320
00321 IF( ABS( H( K+2, K )-REFSUM*VT( 2 ) )+
00322 $ ABS( REFSUM*VT( 3 ) ).GT.ULP*
00323 $ ( ABS( H( K, K ) )+ABS( H( K+1,
00324 $ K+1 ) )+ABS( H( K+2, K+2 ) ) ) ) THEN
00325
00326
00327
00328
00329
00330 H( K+1, K ) = BETA
00331 H( K+2, K ) = ZERO
00332 H( K+3, K ) = ZERO
00333 ELSE
00334
00335
00336
00337
00338
00339
00340 H( K+1, K ) = H( K+1, K ) - REFSUM
00341 H( K+2, K ) = ZERO
00342 H( K+3, K ) = ZERO
00343 V( 1, M ) = VT( 1 )
00344 V( 2, M ) = VT( 2 )
00345 V( 3, M ) = VT( 3 )
00346 END IF
00347 END IF
00348 END IF
00349 20 CONTINUE
00350
00351
00352
00353 K = KRCOL + 3*( M22-1 )
00354 IF( BMP22 ) THEN
00355 IF( K.EQ.KTOP-1 ) THEN
00356 CALL SLAQR1( 2, H( K+1, K+1 ), LDH, SR( 2*M22-1 ),
00357 $ SI( 2*M22-1 ), SR( 2*M22 ), SI( 2*M22 ),
00358 $ V( 1, M22 ) )
00359 BETA = V( 1, M22 )
00360 CALL SLARFG( 2, BETA, V( 2, M22 ), 1, V( 1, M22 ) )
00361 ELSE
00362 BETA = H( K+1, K )
00363 V( 2, M22 ) = H( K+2, K )
00364 CALL SLARFG( 2, BETA, V( 2, M22 ), 1, V( 1, M22 ) )
00365 H( K+1, K ) = BETA
00366 H( K+2, K ) = ZERO
00367 END IF
00368 END IF
00369
00370
00371
00372 IF( ACCUM ) THEN
00373 JBOT = MIN( NDCOL, KBOT )
00374 ELSE IF( WANTT ) THEN
00375 JBOT = N
00376 ELSE
00377 JBOT = KBOT
00378 END IF
00379 DO 40 J = MAX( KTOP, KRCOL ), JBOT
00380 MEND = MIN( MBOT, ( J-KRCOL+2 ) / 3 )
00381 DO 30 M = MTOP, MEND
00382 K = KRCOL + 3*( M-1 )
00383 REFSUM = V( 1, M )*( H( K+1, J )+V( 2, M )*
00384 $ H( K+2, J )+V( 3, M )*H( K+3, J ) )
00385 H( K+1, J ) = H( K+1, J ) - REFSUM
00386 H( K+2, J ) = H( K+2, J ) - REFSUM*V( 2, M )
00387 H( K+3, J ) = H( K+3, J ) - REFSUM*V( 3, M )
00388 30 CONTINUE
00389 40 CONTINUE
00390 IF( BMP22 ) THEN
00391 K = KRCOL + 3*( M22-1 )
00392 DO 50 J = MAX( K+1, KTOP ), JBOT
00393 REFSUM = V( 1, M22 )*( H( K+1, J )+V( 2, M22 )*
00394 $ H( K+2, J ) )
00395 H( K+1, J ) = H( K+1, J ) - REFSUM
00396 H( K+2, J ) = H( K+2, J ) - REFSUM*V( 2, M22 )
00397 50 CONTINUE
00398 END IF
00399
00400
00401
00402
00403
00404 IF( ACCUM ) THEN
00405 JTOP = MAX( KTOP, INCOL )
00406 ELSE IF( WANTT ) THEN
00407 JTOP = 1
00408 ELSE
00409 JTOP = KTOP
00410 END IF
00411 DO 90 M = MTOP, MBOT
00412 IF( V( 1, M ).NE.ZERO ) THEN
00413 K = KRCOL + 3*( M-1 )
00414 DO 60 J = JTOP, MIN( KBOT, K+3 )
00415 REFSUM = V( 1, M )*( H( J, K+1 )+V( 2, M )*
00416 $ H( J, K+2 )+V( 3, M )*H( J, K+3 ) )
00417 H( J, K+1 ) = H( J, K+1 ) - REFSUM
00418 H( J, K+2 ) = H( J, K+2 ) - REFSUM*V( 2, M )
00419 H( J, K+3 ) = H( J, K+3 ) - REFSUM*V( 3, M )
00420 60 CONTINUE
00421
00422 IF( ACCUM ) THEN
00423
00424
00425
00426
00427
00428 KMS = K - INCOL
00429 DO 70 J = MAX( 1, KTOP-INCOL ), KDU
00430 REFSUM = V( 1, M )*( U( J, KMS+1 )+V( 2, M )*
00431 $ U( J, KMS+2 )+V( 3, M )*U( J, KMS+3 ) )
00432 U( J, KMS+1 ) = U( J, KMS+1 ) - REFSUM
00433 U( J, KMS+2 ) = U( J, KMS+2 ) - REFSUM*V( 2, M )
00434 U( J, KMS+3 ) = U( J, KMS+3 ) - REFSUM*V( 3, M )
00435 70 CONTINUE
00436 ELSE IF( WANTZ ) THEN
00437
00438
00439
00440
00441
00442 DO 80 J = ILOZ, IHIZ
00443 REFSUM = V( 1, M )*( Z( J, K+1 )+V( 2, M )*
00444 $ Z( J, K+2 )+V( 3, M )*Z( J, K+3 ) )
00445 Z( J, K+1 ) = Z( J, K+1 ) - REFSUM
00446 Z( J, K+2 ) = Z( J, K+2 ) - REFSUM*V( 2, M )
00447 Z( J, K+3 ) = Z( J, K+3 ) - REFSUM*V( 3, M )
00448 80 CONTINUE
00449 END IF
00450 END IF
00451 90 CONTINUE
00452
00453
00454
00455 K = KRCOL + 3*( M22-1 )
00456 IF( BMP22 .AND. ( V( 1, M22 ).NE.ZERO ) ) THEN
00457 DO 100 J = JTOP, MIN( KBOT, K+3 )
00458 REFSUM = V( 1, M22 )*( H( J, K+1 )+V( 2, M22 )*
00459 $ H( J, K+2 ) )
00460 H( J, K+1 ) = H( J, K+1 ) - REFSUM
00461 H( J, K+2 ) = H( J, K+2 ) - REFSUM*V( 2, M22 )
00462 100 CONTINUE
00463
00464 IF( ACCUM ) THEN
00465 KMS = K - INCOL
00466 DO 110 J = MAX( 1, KTOP-INCOL ), KDU
00467 REFSUM = V( 1, M22 )*( U( J, KMS+1 )+V( 2, M22 )*
00468 $ U( J, KMS+2 ) )
00469 U( J, KMS+1 ) = U( J, KMS+1 ) - REFSUM
00470 U( J, KMS+2 ) = U( J, KMS+2 ) - REFSUM*V( 2, M22 )
00471 110 CONTINUE
00472 ELSE IF( WANTZ ) THEN
00473 DO 120 J = ILOZ, IHIZ
00474 REFSUM = V( 1, M22 )*( Z( J, K+1 )+V( 2, M22 )*
00475 $ Z( J, K+2 ) )
00476 Z( J, K+1 ) = Z( J, K+1 ) - REFSUM
00477 Z( J, K+2 ) = Z( J, K+2 ) - REFSUM*V( 2, M22 )
00478 120 CONTINUE
00479 END IF
00480 END IF
00481
00482
00483
00484 MSTART = MTOP
00485 IF( KRCOL+3*( MSTART-1 ).LT.KTOP )
00486 $ MSTART = MSTART + 1
00487 MEND = MBOT
00488 IF( BMP22 )
00489 $ MEND = MEND + 1
00490 IF( KRCOL.EQ.KBOT-2 )
00491 $ MEND = MEND + 1
00492 DO 130 M = MSTART, MEND
00493 K = MIN( KBOT-1, KRCOL+3*( M-1 ) )
00494
00495
00496
00497
00498
00499
00500
00501
00502
00503
00504 IF( H( K+1, K ).NE.ZERO ) THEN
00505 TST1 = ABS( H( K, K ) ) + ABS( H( K+1, K+1 ) )
00506 IF( TST1.EQ.ZERO ) THEN
00507 IF( K.GE.KTOP+1 )
00508 $ TST1 = TST1 + ABS( H( K, K-1 ) )
00509 IF( K.GE.KTOP+2 )
00510 $ TST1 = TST1 + ABS( H( K, K-2 ) )
00511 IF( K.GE.KTOP+3 )
00512 $ TST1 = TST1 + ABS( H( K, K-3 ) )
00513 IF( K.LE.KBOT-2 )
00514 $ TST1 = TST1 + ABS( H( K+2, K+1 ) )
00515 IF( K.LE.KBOT-3 )
00516 $ TST1 = TST1 + ABS( H( K+3, K+1 ) )
00517 IF( K.LE.KBOT-4 )
00518 $ TST1 = TST1 + ABS( H( K+4, K+1 ) )
00519 END IF
00520 IF( ABS( H( K+1, K ) ).LE.MAX( SMLNUM, ULP*TST1 ) )
00521 $ THEN
00522 H12 = MAX( ABS( H( K+1, K ) ), ABS( H( K, K+1 ) ) )
00523 H21 = MIN( ABS( H( K+1, K ) ), ABS( H( K, K+1 ) ) )
00524 H11 = MAX( ABS( H( K+1, K+1 ) ),
00525 $ ABS( H( K, K )-H( K+1, K+1 ) ) )
00526 H22 = MIN( ABS( H( K+1, K+1 ) ),
00527 $ ABS( H( K, K )-H( K+1, K+1 ) ) )
00528 SCL = H11 + H12
00529 TST2 = H22*( H11 / SCL )
00530
00531 IF( TST2.EQ.ZERO .OR. H21*( H12 / SCL ).LE.
00532 $ MAX( SMLNUM, ULP*TST2 ) )H( K+1, K ) = ZERO
00533 END IF
00534 END IF
00535 130 CONTINUE
00536
00537
00538
00539 MEND = MIN( NBMPS, ( KBOT-KRCOL-1 ) / 3 )
00540 DO 140 M = MTOP, MEND
00541 K = KRCOL + 3*( M-1 )
00542 REFSUM = V( 1, M )*V( 3, M )*H( K+4, K+3 )
00543 H( K+4, K+1 ) = -REFSUM
00544 H( K+4, K+2 ) = -REFSUM*V( 2, M )
00545 H( K+4, K+3 ) = H( K+4, K+3 ) - REFSUM*V( 3, M )
00546 140 CONTINUE
00547
00548
00549
00550 150 CONTINUE
00551
00552
00553
00554
00555
00556 IF( ACCUM ) THEN
00557 IF( WANTT ) THEN
00558 JTOP = 1
00559 JBOT = N
00560 ELSE
00561 JTOP = KTOP
00562 JBOT = KBOT
00563 END IF
00564 IF( ( .NOT.BLK22 ) .OR. ( INCOL.LT.KTOP ) .OR.
00565 $ ( NDCOL.GT.KBOT ) .OR. ( NS.LE.2 ) ) THEN
00566
00567
00568
00569
00570
00571
00572
00573
00574
00575
00576 K1 = MAX( 1, KTOP-INCOL )
00577 NU = ( KDU-MAX( 0, NDCOL-KBOT ) ) - K1 + 1
00578
00579
00580
00581 DO 160 JCOL = MIN( NDCOL, KBOT ) + 1, JBOT, NH
00582 JLEN = MIN( NH, JBOT-JCOL+1 )
00583 CALL SGEMM( 'C', 'N', NU, JLEN, NU, ONE, U( K1, K1 ),
00584 $ LDU, H( INCOL+K1, JCOL ), LDH, ZERO, WH,
00585 $ LDWH )
00586 CALL SLACPY( 'ALL', NU, JLEN, WH, LDWH,
00587 $ H( INCOL+K1, JCOL ), LDH )
00588 160 CONTINUE
00589
00590
00591
00592 DO 170 JROW = JTOP, MAX( KTOP, INCOL ) - 1, NV
00593 JLEN = MIN( NV, MAX( KTOP, INCOL )-JROW )
00594 CALL SGEMM( 'N', 'N', JLEN, NU, NU, ONE,
00595 $ H( JROW, INCOL+K1 ), LDH, U( K1, K1 ),
00596 $ LDU, ZERO, WV, LDWV )
00597 CALL SLACPY( 'ALL', JLEN, NU, WV, LDWV,
00598 $ H( JROW, INCOL+K1 ), LDH )
00599 170 CONTINUE
00600
00601
00602
00603 IF( WANTZ ) THEN
00604 DO 180 JROW = ILOZ, IHIZ, NV
00605 JLEN = MIN( NV, IHIZ-JROW+1 )
00606 CALL SGEMM( 'N', 'N', JLEN, NU, NU, ONE,
00607 $ Z( JROW, INCOL+K1 ), LDZ, U( K1, K1 ),
00608 $ LDU, ZERO, WV, LDWV )
00609 CALL SLACPY( 'ALL', JLEN, NU, WV, LDWV,
00610 $ Z( JROW, INCOL+K1 ), LDZ )
00611 180 CONTINUE
00612 END IF
00613 ELSE
00614
00615
00616
00617
00618
00619 I2 = ( KDU+1 ) / 2
00620 I4 = KDU
00621 J2 = I4 - I2
00622 J4 = KDU
00623
00624
00625
00626
00627
00628 KZS = ( J4-J2 ) - ( NS+1 )
00629 KNZ = NS + 1
00630
00631
00632
00633 DO 190 JCOL = MIN( NDCOL, KBOT ) + 1, JBOT, NH
00634 JLEN = MIN( NH, JBOT-JCOL+1 )
00635
00636
00637
00638
00639 CALL SLACPY( 'ALL', KNZ, JLEN, H( INCOL+1+J2, JCOL ),
00640 $ LDH, WH( KZS+1, 1 ), LDWH )
00641
00642
00643
00644 CALL SLASET( 'ALL', KZS, JLEN, ZERO, ZERO, WH, LDWH )
00645 CALL STRMM( 'L', 'U', 'C', 'N', KNZ, JLEN, ONE,
00646 $ U( J2+1, 1+KZS ), LDU, WH( KZS+1, 1 ),
00647 $ LDWH )
00648
00649
00650
00651 CALL SGEMM( 'C', 'N', I2, JLEN, J2, ONE, U, LDU,
00652 $ H( INCOL+1, JCOL ), LDH, ONE, WH, LDWH )
00653
00654
00655
00656 CALL SLACPY( 'ALL', J2, JLEN, H( INCOL+1, JCOL ), LDH,
00657 $ WH( I2+1, 1 ), LDWH )
00658
00659
00660
00661 CALL STRMM( 'L', 'L', 'C', 'N', J2, JLEN, ONE,
00662 $ U( 1, I2+1 ), LDU, WH( I2+1, 1 ), LDWH )
00663
00664
00665
00666 CALL SGEMM( 'C', 'N', I4-I2, JLEN, J4-J2, ONE,
00667 $ U( J2+1, I2+1 ), LDU,
00668 $ H( INCOL+1+J2, JCOL ), LDH, ONE,
00669 $ WH( I2+1, 1 ), LDWH )
00670
00671
00672
00673 CALL SLACPY( 'ALL', KDU, JLEN, WH, LDWH,
00674 $ H( INCOL+1, JCOL ), LDH )
00675 190 CONTINUE
00676
00677
00678
00679 DO 200 JROW = JTOP, MAX( INCOL, KTOP ) - 1, NV
00680 JLEN = MIN( NV, MAX( INCOL, KTOP )-JROW )
00681
00682
00683
00684
00685 CALL SLACPY( 'ALL', JLEN, KNZ, H( JROW, INCOL+1+J2 ),
00686 $ LDH, WV( 1, 1+KZS ), LDWV )
00687
00688
00689
00690 CALL SLASET( 'ALL', JLEN, KZS, ZERO, ZERO, WV, LDWV )
00691 CALL STRMM( 'R', 'U', 'N', 'N', JLEN, KNZ, ONE,
00692 $ U( J2+1, 1+KZS ), LDU, WV( 1, 1+KZS ),
00693 $ LDWV )
00694
00695
00696
00697 CALL SGEMM( 'N', 'N', JLEN, I2, J2, ONE,
00698 $ H( JROW, INCOL+1 ), LDH, U, LDU, ONE, WV,
00699 $ LDWV )
00700
00701
00702
00703 CALL SLACPY( 'ALL', JLEN, J2, H( JROW, INCOL+1 ), LDH,
00704 $ WV( 1, 1+I2 ), LDWV )
00705
00706
00707
00708 CALL STRMM( 'R', 'L', 'N', 'N', JLEN, I4-I2, ONE,
00709 $ U( 1, I2+1 ), LDU, WV( 1, 1+I2 ), LDWV )
00710
00711
00712
00713 CALL SGEMM( 'N', 'N', JLEN, I4-I2, J4-J2, ONE,
00714 $ H( JROW, INCOL+1+J2 ), LDH,
00715 $ U( J2+1, I2+1 ), LDU, ONE, WV( 1, 1+I2 ),
00716 $ LDWV )
00717
00718
00719
00720 CALL SLACPY( 'ALL', JLEN, KDU, WV, LDWV,
00721 $ H( JROW, INCOL+1 ), LDH )
00722 200 CONTINUE
00723
00724
00725
00726 IF( WANTZ ) THEN
00727 DO 210 JROW = ILOZ, IHIZ, NV
00728 JLEN = MIN( NV, IHIZ-JROW+1 )
00729
00730
00731
00732
00733 CALL SLACPY( 'ALL', JLEN, KNZ,
00734 $ Z( JROW, INCOL+1+J2 ), LDZ,
00735 $ WV( 1, 1+KZS ), LDWV )
00736
00737
00738
00739 CALL SLASET( 'ALL', JLEN, KZS, ZERO, ZERO, WV,
00740 $ LDWV )
00741 CALL STRMM( 'R', 'U', 'N', 'N', JLEN, KNZ, ONE,
00742 $ U( J2+1, 1+KZS ), LDU, WV( 1, 1+KZS ),
00743 $ LDWV )
00744
00745
00746
00747 CALL SGEMM( 'N', 'N', JLEN, I2, J2, ONE,
00748 $ Z( JROW, INCOL+1 ), LDZ, U, LDU, ONE,
00749 $ WV, LDWV )
00750
00751
00752
00753 CALL SLACPY( 'ALL', JLEN, J2, Z( JROW, INCOL+1 ),
00754 $ LDZ, WV( 1, 1+I2 ), LDWV )
00755
00756
00757
00758 CALL STRMM( 'R', 'L', 'N', 'N', JLEN, I4-I2, ONE,
00759 $ U( 1, I2+1 ), LDU, WV( 1, 1+I2 ),
00760 $ LDWV )
00761
00762
00763
00764 CALL SGEMM( 'N', 'N', JLEN, I4-I2, J4-J2, ONE,
00765 $ Z( JROW, INCOL+1+J2 ), LDZ,
00766 $ U( J2+1, I2+1 ), LDU, ONE,
00767 $ WV( 1, 1+I2 ), LDWV )
00768
00769
00770
00771 CALL SLACPY( 'ALL', JLEN, KDU, WV, LDWV,
00772 $ Z( JROW, INCOL+1 ), LDZ )
00773 210 CONTINUE
00774 END IF
00775 END IF
00776 END IF
00777 220 CONTINUE
00778
00779
00780
00781 END