Go to the documentation of this file.00001 SUBROUTINE DLAED5( I, D, Z, DELTA, RHO, DLAM )
00002
00003
00004
00005
00006
00007
00008
00009 INTEGER I
00010 DOUBLE PRECISION DLAM, RHO
00011
00012
00013 DOUBLE PRECISION D( 2 ), DELTA( 2 ), Z( 2 )
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
00060
00061
00062
00063 DOUBLE PRECISION ZERO, ONE, TWO, FOUR
00064 PARAMETER ( ZERO = 0.0D0, ONE = 1.0D0, TWO = 2.0D0,
00065 $ FOUR = 4.0D0 )
00066
00067
00068 DOUBLE PRECISION B, C, DEL, TAU, TEMP, W
00069
00070
00071 INTRINSIC ABS, SQRT
00072
00073
00074
00075 DEL = D( 2 ) - D( 1 )
00076 IF( I.EQ.1 ) THEN
00077 W = ONE + TWO*RHO*( Z( 2 )*Z( 2 )-Z( 1 )*Z( 1 ) ) / DEL
00078 IF( W.GT.ZERO ) THEN
00079 B = DEL + RHO*( Z( 1 )*Z( 1 )+Z( 2 )*Z( 2 ) )
00080 C = RHO*Z( 1 )*Z( 1 )*DEL
00081
00082
00083
00084 TAU = TWO*C / ( B+SQRT( ABS( B*B-FOUR*C ) ) )
00085 DLAM = D( 1 ) + TAU
00086 DELTA( 1 ) = -Z( 1 ) / TAU
00087 DELTA( 2 ) = Z( 2 ) / ( DEL-TAU )
00088 ELSE
00089 B = -DEL + RHO*( Z( 1 )*Z( 1 )+Z( 2 )*Z( 2 ) )
00090 C = RHO*Z( 2 )*Z( 2 )*DEL
00091 IF( B.GT.ZERO ) THEN
00092 TAU = -TWO*C / ( B+SQRT( B*B+FOUR*C ) )
00093 ELSE
00094 TAU = ( B-SQRT( B*B+FOUR*C ) ) / TWO
00095 END IF
00096 DLAM = D( 2 ) + TAU
00097 DELTA( 1 ) = -Z( 1 ) / ( DEL+TAU )
00098 DELTA( 2 ) = -Z( 2 ) / TAU
00099 END IF
00100 TEMP = SQRT( DELTA( 1 )*DELTA( 1 )+DELTA( 2 )*DELTA( 2 ) )
00101 DELTA( 1 ) = DELTA( 1 ) / TEMP
00102 DELTA( 2 ) = DELTA( 2 ) / TEMP
00103 ELSE
00104
00105
00106
00107 B = -DEL + RHO*( Z( 1 )*Z( 1 )+Z( 2 )*Z( 2 ) )
00108 C = RHO*Z( 2 )*Z( 2 )*DEL
00109 IF( B.GT.ZERO ) THEN
00110 TAU = ( B+SQRT( B*B+FOUR*C ) ) / TWO
00111 ELSE
00112 TAU = TWO*C / ( -B+SQRT( B*B+FOUR*C ) )
00113 END IF
00114 DLAM = D( 2 ) + TAU
00115 DELTA( 1 ) = -Z( 1 ) / ( DEL+TAU )
00116 DELTA( 2 ) = -Z( 2 ) / TAU
00117 TEMP = SQRT( DELTA( 1 )*DELTA( 1 )+DELTA( 2 )*DELTA( 2 ) )
00118 DELTA( 1 ) = DELTA( 1 ) / TEMP
00119 DELTA( 2 ) = DELTA( 2 ) / TEMP
00120 END IF
00121 RETURN
00122
00123
00124
00125 END