154 SUBROUTINE dlaed9( K, KSTART, KSTOP, N, D, Q, LDQ, RHO, DLAMDA, W,
162 INTEGER INFO, K, KSTART, KSTOP, LDQ, LDS, N
166 DOUBLE PRECISION D( * ), DLAMDA( * ), Q( LDQ, * ), S( LDS, * ),
174 DOUBLE PRECISION TEMP
177 DOUBLE PRECISION , DNRM2
184 INTRINSIC max, sign, sqrt
194 ELSE IF( kstart.LT.1 .OR. kstart.GT.
max( 1, k ) )
THEN
196 ELSE IF(
max( 1, kstop ).LT.kstart .OR. kstop.GT.
max( 1, k ) )
199 ELSE IF( n.LT.k )
THEN
201 ELSE IF( ldq.LT.
max( 1, k ) )
THEN
203 ELSE IF( lds.LT.
max( 1, k ) )
THEN
207 CALL xerbla(
'DLAED9', -info )
234 dlamda( i ) =
dlamc3( dlamda( i ), dlamda( i
237 DO 20 j = kstart, kstop
246 IF( k.EQ.1 .OR. k.EQ.2 )
THEN
249 s( j, i ) = q( j, i )
257 CALL dcopy( k, w, 1, s, 1 )
261 CALL dcopy( k, q, ldq+1, w, 1 )
264 w( i ) = w( i )*( q( i, j ) / ( dlamda( i )-dlamda( j ) ) )
267 w( i ) = w( i )*( q( i, j ) / ( dlamda( i )-dlamda( j ) ) )
271 w( i ) = sign( sqrt( -w( i ) ), s( i, 1 ) )
278 q( i, j ) = w( i ) / q( i, j )
280 temp = dnrm2( k, q( 1, j ), 1 )
282 s( i, j ) = q( i, j ) / temp
subroutine dlaed9(k, kstart, kstop, n, d, q, ldq, rho, dlamda, w, s, lds, info)
DLAED9 used by DSTEDC. Finds the roots of the secular equation and updates the eigenvectors....
subroutine dlaed4(n, i, d, z, delta, rho, dlam, info)
DLAED4 used by DSTEDC. Finds a single root of the secular equation.