Go to the documentation of this file.00001 REAL FUNCTION CLANGE( NORM, M, N, A, LDA, WORK )
00002
00003
00004
00005
00006
00007
00008
00009 CHARACTER NORM
00010 INTEGER LDA, M, N
00011
00012
00013 REAL WORK( * )
00014 COMPLEX A( LDA, * )
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
00064
00065
00066
00067
00068
00069
00070 REAL ONE, ZERO
00071 PARAMETER ( ONE = 1.0E+0, ZERO = 0.0E+0 )
00072
00073
00074 INTEGER I, J
00075 REAL SCALE, SUM, VALUE
00076
00077
00078 LOGICAL LSAME
00079 EXTERNAL LSAME
00080
00081
00082 EXTERNAL CLASSQ
00083
00084
00085 INTRINSIC ABS, MAX, MIN, SQRT
00086
00087
00088
00089 IF( MIN( M, N ).EQ.0 ) THEN
00090 VALUE = ZERO
00091 ELSE IF( LSAME( NORM, 'M' ) ) THEN
00092
00093
00094
00095 VALUE = ZERO
00096 DO 20 J = 1, N
00097 DO 10 I = 1, M
00098 VALUE = MAX( VALUE, ABS( A( I, J ) ) )
00099 10 CONTINUE
00100 20 CONTINUE
00101 ELSE IF( ( LSAME( NORM, 'O' ) ) .OR. ( NORM.EQ.'1' ) ) THEN
00102
00103
00104
00105 VALUE = ZERO
00106 DO 40 J = 1, N
00107 SUM = ZERO
00108 DO 30 I = 1, M
00109 SUM = SUM + ABS( A( I, J ) )
00110 30 CONTINUE
00111 VALUE = MAX( VALUE, SUM )
00112 40 CONTINUE
00113 ELSE IF( LSAME( NORM, 'I' ) ) THEN
00114
00115
00116
00117 DO 50 I = 1, M
00118 WORK( I ) = ZERO
00119 50 CONTINUE
00120 DO 70 J = 1, N
00121 DO 60 I = 1, M
00122 WORK( I ) = WORK( I ) + ABS( A( I, J ) )
00123 60 CONTINUE
00124 70 CONTINUE
00125 VALUE = ZERO
00126 DO 80 I = 1, M
00127 VALUE = MAX( VALUE, WORK( I ) )
00128 80 CONTINUE
00129 ELSE IF( ( LSAME( NORM, 'F' ) ) .OR. ( LSAME( NORM, 'E' ) ) ) THEN
00130
00131
00132
00133 SCALE = ZERO
00134 SUM = ONE
00135 DO 90 J = 1, N
00136 CALL CLASSQ( M, A( 1, J ), 1, SCALE, SUM )
00137 90 CONTINUE
00138 VALUE = SCALE*SQRT( SUM )
00139 END IF
00140
00141 CLANGE = VALUE
00142 RETURN
00143
00144
00145
00146 END