Go to the documentation of this file.00001 SUBROUTINE CPTT01( N, D, E, DF, EF, WORK, RESID )
00002
00003
00004
00005
00006
00007
00008 INTEGER N
00009 REAL RESID
00010
00011
00012 REAL D( * ), DF( * )
00013 COMPLEX E( * ), EF( * ), WORK( * )
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 REAL ONE, ZERO
00053 PARAMETER ( ONE = 1.0E+0, ZERO = 0.0E+0 )
00054
00055
00056 INTEGER I
00057 REAL ANORM, EPS
00058 COMPLEX DE
00059
00060
00061 REAL SLAMCH
00062 EXTERNAL SLAMCH
00063
00064
00065 INTRINSIC ABS, CONJG, MAX, REAL
00066
00067
00068
00069
00070
00071 IF( N.LE.0 ) THEN
00072 RESID = ZERO
00073 RETURN
00074 END IF
00075
00076 EPS = SLAMCH( 'Epsilon' )
00077
00078
00079
00080 WORK( 1 ) = DF( 1 ) - D( 1 )
00081 DO 10 I = 1, N - 1
00082 DE = DF( I )*EF( I )
00083 WORK( N+I ) = DE - E( I )
00084 WORK( 1+I ) = DE*CONJG( EF( I ) ) + DF( I+1 ) - D( I+1 )
00085 10 CONTINUE
00086
00087
00088
00089 IF( N.EQ.1 ) THEN
00090 ANORM = D( 1 )
00091 RESID = ABS( WORK( 1 ) )
00092 ELSE
00093 ANORM = MAX( D( 1 )+ABS( E( 1 ) ), D( N )+ABS( E( N-1 ) ) )
00094 RESID = MAX( ABS( WORK( 1 ) )+ABS( WORK( N+1 ) ),
00095 $ ABS( WORK( N ) )+ABS( WORK( 2*N-1 ) ) )
00096 DO 20 I = 2, N - 1
00097 ANORM = MAX( ANORM, D( I )+ABS( E( I ) )+ABS( E( I-1 ) ) )
00098 RESID = MAX( RESID, ABS( WORK( I ) )+ABS( WORK( N+I-1 ) )+
00099 $ ABS( WORK( N+I ) ) )
00100 20 CONTINUE
00101 END IF
00102
00103
00104
00105 IF( ANORM.LE.ZERO ) THEN
00106 IF( RESID.NE.ZERO )
00107 $ RESID = ONE / EPS
00108 ELSE
00109 RESID = ( ( RESID / REAL( N ) ) / ANORM ) / EPS
00110 END IF
00111
00112 RETURN
00113
00114
00115
00116 END