00001 SUBROUTINE ZLAUUM( UPLO, N, A, LDA, INFO )
00002
00003
00004
00005
00006
00007
00008
00009 CHARACTER UPLO
00010 INTEGER INFO, LDA, N
00011
00012
00013 COMPLEX*16 A( LDA, * )
00014
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 DOUBLE PRECISION ONE
00060 PARAMETER ( ONE = 1.0D+0 )
00061 COMPLEX*16 CONE
00062 PARAMETER ( CONE = ( 1.0D+0, 0.0D+0 ) )
00063
00064
00065 LOGICAL UPPER
00066 INTEGER I, IB, NB
00067
00068
00069 LOGICAL LSAME
00070 INTEGER ILAENV
00071 EXTERNAL LSAME, ILAENV
00072
00073
00074 EXTERNAL XERBLA, ZGEMM, ZHERK, ZLAUU2, ZTRMM
00075
00076
00077 INTRINSIC MAX, MIN
00078
00079
00080
00081
00082
00083 INFO = 0
00084 UPPER = LSAME( UPLO, 'U' )
00085 IF( .NOT.UPPER .AND. .NOT.LSAME( UPLO, 'L' ) ) THEN
00086 INFO = -1
00087 ELSE IF( N.LT.0 ) THEN
00088 INFO = -2
00089 ELSE IF( LDA.LT.MAX( 1, N ) ) THEN
00090 INFO = -4
00091 END IF
00092 IF( INFO.NE.0 ) THEN
00093 CALL XERBLA( 'ZLAUUM', -INFO )
00094 RETURN
00095 END IF
00096
00097
00098
00099 IF( N.EQ.0 )
00100 $ RETURN
00101
00102
00103
00104 NB = ILAENV( 1, 'ZLAUUM', UPLO, N, -1, -1, -1 )
00105
00106 IF( NB.LE.1 .OR. NB.GE.N ) THEN
00107
00108
00109
00110 CALL ZLAUU2( UPLO, N, A, LDA, INFO )
00111 ELSE
00112
00113
00114
00115 IF( UPPER ) THEN
00116
00117
00118
00119 DO 10 I = 1, N, NB
00120 IB = MIN( NB, N-I+1 )
00121 CALL ZTRMM( 'Right', 'Upper', 'Conjugate transpose',
00122 $ 'Non-unit', I-1, IB, CONE, A( I, I ), LDA,
00123 $ A( 1, I ), LDA )
00124 CALL ZLAUU2( 'Upper', IB, A( I, I ), LDA, INFO )
00125 IF( I+IB.LE.N ) THEN
00126 CALL ZGEMM( 'No transpose', 'Conjugate transpose',
00127 $ I-1, IB, N-I-IB+1, CONE, A( 1, I+IB ),
00128 $ LDA, A( I, I+IB ), LDA, CONE, A( 1, I ),
00129 $ LDA )
00130 CALL ZHERK( 'Upper', 'No transpose', IB, N-I-IB+1,
00131 $ ONE, A( I, I+IB ), LDA, ONE, A( I, I ),
00132 $ LDA )
00133 END IF
00134 10 CONTINUE
00135 ELSE
00136
00137
00138
00139 DO 20 I = 1, N, NB
00140 IB = MIN( NB, N-I+1 )
00141 CALL ZTRMM( 'Left', 'Lower', 'Conjugate transpose',
00142 $ 'Non-unit', IB, I-1, CONE, A( I, I ), LDA,
00143 $ A( I, 1 ), LDA )
00144 CALL ZLAUU2( 'Lower', IB, A( I, I ), LDA, INFO )
00145 IF( I+IB.LE.N ) THEN
00146 CALL ZGEMM( 'Conjugate transpose', 'No transpose', IB,
00147 $ I-1, N-I-IB+1, CONE, A( I+IB, I ), LDA,
00148 $ A( I+IB, 1 ), LDA, CONE, A( I, 1 ), LDA )
00149 CALL ZHERK( 'Lower', 'Conjugate transpose', IB,
00150 $ N-I-IB+1, ONE, A( I+IB, I ), LDA, ONE,
00151 $ A( I, I ), LDA )
00152 END IF
00153 20 CONTINUE
00154 END IF
00155 END IF
00156
00157 RETURN
00158
00159
00160
00161 END