00001 SUBROUTINE ZGET10( M, N, A, LDA, B, LDB, WORK, RWORK, RESULT )
00002
00003
00004
00005
00006
00007
00008 INTEGER LDA, LDB, M, N
00009 DOUBLE PRECISION RESULT
00010
00011
00012 DOUBLE PRECISION RWORK( * )
00013 COMPLEX*16 A( LDA, * ), B( LDB, * ), 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
00053 DOUBLE PRECISION ONE, ZERO
00054 PARAMETER ( ONE = 1.0D+0, ZERO = 0.0D+0 )
00055
00056
00057 INTEGER J
00058 DOUBLE PRECISION ANORM, EPS, UNFL, WNORM
00059
00060
00061 DOUBLE PRECISION DLAMCH, DZASUM, ZLANGE
00062 EXTERNAL DLAMCH, DZASUM, ZLANGE
00063
00064
00065 EXTERNAL ZAXPY, ZCOPY
00066
00067
00068 INTRINSIC DBLE, DCMPLX, MAX, MIN
00069
00070
00071
00072
00073
00074 IF( M.LE.0 .OR. N.LE.0 ) THEN
00075 RESULT = ZERO
00076 RETURN
00077 END IF
00078
00079 UNFL = DLAMCH( 'Safe minimum' )
00080 EPS = DLAMCH( 'Precision' )
00081
00082 WNORM = ZERO
00083 DO 10 J = 1, N
00084 CALL ZCOPY( M, A( 1, J ), 1, WORK, 1 )
00085 CALL ZAXPY( M, DCMPLX( -ONE ), B( 1, J ), 1, WORK, 1 )
00086 WNORM = MAX( WNORM, DZASUM( N, WORK, 1 ) )
00087 10 CONTINUE
00088
00089 ANORM = MAX( ZLANGE( '1', M, N, A, LDA, RWORK ), UNFL )
00090
00091 IF( ANORM.GT.WNORM ) THEN
00092 RESULT = ( WNORM / ANORM ) / ( M*EPS )
00093 ELSE
00094 IF( ANORM.LT.ONE ) THEN
00095 RESULT = ( MIN( WNORM, M*ANORM ) / ANORM ) / ( M*EPS )
00096 ELSE
00097 RESULT = MIN( WNORM / ANORM, DBLE( M ) ) / ( M*EPS )
00098 END IF
00099 END IF
00100
00101 RETURN
00102
00103
00104
00105 END