00001 SUBROUTINE ZUNML2( SIDE, TRANS, M, N, K, A, LDA, TAU, C, LDC,
00002 $ WORK, INFO )
00003
00004
00005
00006
00007
00008
00009
00010 CHARACTER SIDE, TRANS
00011 INTEGER INFO, K, LDA, LDC, M, N
00012
00013
00014 COMPLEX*16 A( LDA, * ), C( LDC, * ), TAU( * ), WORK( * )
00015
00016
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 COMPLEX*16 ONE
00095 PARAMETER ( ONE = ( 1.0D+0, 0.0D+0 ) )
00096
00097
00098 LOGICAL LEFT, NOTRAN
00099 INTEGER I, I1, I2, I3, IC, JC, MI, NI, NQ
00100 COMPLEX*16 AII, TAUI
00101
00102
00103 LOGICAL LSAME
00104 EXTERNAL LSAME
00105
00106
00107 EXTERNAL XERBLA, ZLACGV, ZLARF
00108
00109
00110 INTRINSIC DCONJG, MAX
00111
00112
00113
00114
00115
00116 INFO = 0
00117 LEFT = LSAME( SIDE, 'L' )
00118 NOTRAN = LSAME( TRANS, 'N' )
00119
00120
00121
00122 IF( LEFT ) THEN
00123 NQ = M
00124 ELSE
00125 NQ = N
00126 END IF
00127 IF( .NOT.LEFT .AND. .NOT.LSAME( SIDE, 'R' ) ) THEN
00128 INFO = -1
00129 ELSE IF( .NOT.NOTRAN .AND. .NOT.LSAME( TRANS, 'C' ) ) THEN
00130 INFO = -2
00131 ELSE IF( M.LT.0 ) THEN
00132 INFO = -3
00133 ELSE IF( N.LT.0 ) THEN
00134 INFO = -4
00135 ELSE IF( K.LT.0 .OR. K.GT.NQ ) THEN
00136 INFO = -5
00137 ELSE IF( LDA.LT.MAX( 1, K ) ) THEN
00138 INFO = -7
00139 ELSE IF( LDC.LT.MAX( 1, M ) ) THEN
00140 INFO = -10
00141 END IF
00142 IF( INFO.NE.0 ) THEN
00143 CALL XERBLA( 'ZUNML2', -INFO )
00144 RETURN
00145 END IF
00146
00147
00148
00149 IF( M.EQ.0 .OR. N.EQ.0 .OR. K.EQ.0 )
00150 $ RETURN
00151
00152 IF( ( LEFT .AND. NOTRAN .OR. .NOT.LEFT .AND. .NOT.NOTRAN ) ) THEN
00153 I1 = 1
00154 I2 = K
00155 I3 = 1
00156 ELSE
00157 I1 = K
00158 I2 = 1
00159 I3 = -1
00160 END IF
00161
00162 IF( LEFT ) THEN
00163 NI = N
00164 JC = 1
00165 ELSE
00166 MI = M
00167 IC = 1
00168 END IF
00169
00170 DO 10 I = I1, I2, I3
00171 IF( LEFT ) THEN
00172
00173
00174
00175 MI = M - I + 1
00176 IC = I
00177 ELSE
00178
00179
00180
00181 NI = N - I + 1
00182 JC = I
00183 END IF
00184
00185
00186
00187 IF( NOTRAN ) THEN
00188 TAUI = DCONJG( TAU( I ) )
00189 ELSE
00190 TAUI = TAU( I )
00191 END IF
00192 IF( I.LT.NQ )
00193 $ CALL ZLACGV( NQ-I, A( I, I+1 ), LDA )
00194 AII = A( I, I )
00195 A( I, I ) = ONE
00196 CALL ZLARF( SIDE, MI, NI, A( I, I ), LDA, TAUI, C( IC, JC ),
00197 $ LDC, WORK )
00198 A( I, I ) = AII
00199 IF( I.LT.NQ )
00200 $ CALL ZLACGV( NQ-I, A( I, I+1 ), LDA )
00201 10 CONTINUE
00202 RETURN
00203
00204
00205
00206 END