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