00001 SUBROUTINE CGEBAK( JOB, SIDE, N, ILO, IHI, SCALE, M, V, LDV,
00002 $ INFO )
00003
00004
00005
00006
00007
00008
00009
00010 CHARACTER JOB, SIDE
00011 INTEGER IHI, ILO, INFO, LDV, M, N
00012
00013
00014 REAL SCALE( * )
00015 COMPLEX V( LDV, * )
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 REAL ONE
00072 PARAMETER ( ONE = 1.0E+0 )
00073
00074
00075 LOGICAL LEFTV, RIGHTV
00076 INTEGER I, II, K
00077 REAL S
00078
00079
00080 LOGICAL LSAME
00081 EXTERNAL LSAME
00082
00083
00084 EXTERNAL CSSCAL, CSWAP, XERBLA
00085
00086
00087 INTRINSIC MAX, MIN
00088
00089
00090
00091
00092
00093 RIGHTV = LSAME( SIDE, 'R' )
00094 LEFTV = LSAME( SIDE, 'L' )
00095
00096 INFO = 0
00097 IF( .NOT.LSAME( JOB, 'N' ) .AND. .NOT.LSAME( JOB, 'P' ) .AND.
00098 $ .NOT.LSAME( JOB, 'S' ) .AND. .NOT.LSAME( JOB, 'B' ) ) THEN
00099 INFO = -1
00100 ELSE IF( .NOT.RIGHTV .AND. .NOT.LEFTV ) THEN
00101 INFO = -2
00102 ELSE IF( N.LT.0 ) THEN
00103 INFO = -3
00104 ELSE IF( ILO.LT.1 .OR. ILO.GT.MAX( 1, N ) ) THEN
00105 INFO = -4
00106 ELSE IF( IHI.LT.MIN( ILO, N ) .OR. IHI.GT.N ) THEN
00107 INFO = -5
00108 ELSE IF( M.LT.0 ) THEN
00109 INFO = -7
00110 ELSE IF( LDV.LT.MAX( 1, N ) ) THEN
00111 INFO = -9
00112 END IF
00113 IF( INFO.NE.0 ) THEN
00114 CALL XERBLA( 'CGEBAK', -INFO )
00115 RETURN
00116 END IF
00117
00118
00119
00120 IF( N.EQ.0 )
00121 $ RETURN
00122 IF( M.EQ.0 )
00123 $ RETURN
00124 IF( LSAME( JOB, 'N' ) )
00125 $ RETURN
00126
00127 IF( ILO.EQ.IHI )
00128 $ GO TO 30
00129
00130
00131
00132 IF( LSAME( JOB, 'S' ) .OR. LSAME( JOB, 'B' ) ) THEN
00133
00134 IF( RIGHTV ) THEN
00135 DO 10 I = ILO, IHI
00136 S = SCALE( I )
00137 CALL CSSCAL( M, S, V( I, 1 ), LDV )
00138 10 CONTINUE
00139 END IF
00140
00141 IF( LEFTV ) THEN
00142 DO 20 I = ILO, IHI
00143 S = ONE / SCALE( I )
00144 CALL CSSCAL( M, S, V( I, 1 ), LDV )
00145 20 CONTINUE
00146 END IF
00147
00148 END IF
00149
00150
00151
00152
00153
00154
00155 30 CONTINUE
00156 IF( LSAME( JOB, 'P' ) .OR. LSAME( JOB, 'B' ) ) THEN
00157 IF( RIGHTV ) THEN
00158 DO 40 II = 1, N
00159 I = II
00160 IF( I.GE.ILO .AND. I.LE.IHI )
00161 $ GO TO 40
00162 IF( I.LT.ILO )
00163 $ I = ILO - II
00164 K = SCALE( I )
00165 IF( K.EQ.I )
00166 $ GO TO 40
00167 CALL CSWAP( M, V( I, 1 ), LDV, V( K, 1 ), LDV )
00168 40 CONTINUE
00169 END IF
00170
00171 IF( LEFTV ) THEN
00172 DO 50 II = 1, N
00173 I = II
00174 IF( I.GE.ILO .AND. I.LE.IHI )
00175 $ GO TO 50
00176 IF( I.LT.ILO )
00177 $ I = ILO - II
00178 K = SCALE( I )
00179 IF( K.EQ.I )
00180 $ GO TO 50
00181 CALL CSWAP( M, V( I, 1 ), LDV, V( K, 1 ), LDV )
00182 50 CONTINUE
00183 END IF
00184 END IF
00185
00186 RETURN
00187
00188
00189
00190 END