00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
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
00052
00053
00054
00055
00056
00057
00058
00059 static char *rcs_id = "$Source: /home/bos/bk/kpro64-pending/libm/mips/SCCS/s.log10f.c $ $Revision: 1.5 $";
00060
00061 #ifdef _CALL_MATHERR
00062 #include <stdio.h>
00063 #include <math.h>
00064 #include <errno.h>
00065 #endif
00066
00067 #include "libm.h"
00068
00069
00070
00071
00072
00073
00074
00075
00076 #if defined(mips) && !defined(__GNUC__)
00077 extern float flog10(float);
00078 extern float log10f(float);
00079
00080 #pragma weak flog10 = __log10f
00081 #pragma weak log10f = __log10f
00082 #endif
00083
00084 #if defined(BUILD_OS_DARWIN)
00085 extern float __log10f(float);
00086 #pragma weak log10f
00087 float log10f( float x ) {
00088 return __log10f( x );
00089 }
00090 #elif defined(__GNUC__)
00091 extern float __log10f(float);
00092 float log10f(float) __attribute__ ((weak, alias ("__log10f")));
00093 #endif
00094
00095 extern const fu _logftabhi[];
00096 extern const fu _logftablo[];
00097
00098 static const fu Qnan = {QNANF};
00099
00100 static const fu Neginf = {0xff800000};
00101
00102 static const fu Inf = {0x7f800000};
00103
00104 static const fu P[] =
00105 {
00106 {0x3f800000},
00107 {0x3daaaaa9},
00108 {0x3c4dffbb},
00109 };
00110
00111 static const fu Q[] =
00112 {
00113 {0x3f800000},
00114 {0x3daaaac2},
00115 };
00116
00117 static const fu log2_lead = {0x3f317200};
00118
00119 static const fu log2_trail = {0x35bfbe8e};
00120
00121 static const fu f_one = {0x3f800000};
00122
00123 static const fu Scaleup = {0x4b000000};
00124
00125
00126
00127 static const int lim1 = {0x3f707d5f};
00128
00129
00130
00131 static const int lim2 = {0x3f88415b};
00132
00133 static const int one = {0x3f800000};
00134
00135 static const du Loge =
00136 {D(0x3fdbcb7b, 0x1526e50e)};
00137
00138
00139
00140
00141
00142
00143
00144
00145
00146
00147
00148 float
00149 __log10f( float x )
00150 {
00151 int ix;
00152 int j, m;
00153 float u, v;
00154 float result;
00155 float f, F;
00156 float l_lead, l_trail;
00157 float q;
00158 float md;
00159 double u1;
00160 #ifdef _CALL_MATHERR
00161 struct exception exstruct;
00162 #endif
00163
00164 FLT2INT(x, ix);
00165 m = (ix >> MANTWIDTH);
00166
00167 if ( (0 < m) && (m < 0xff) )
00168 {
00169
00170
00171 if ( (ix >= lim2) || (ix <= lim1) )
00172 {
00173
00174 m -= EXPBIAS;
00175 L:
00176 ix &= EXPMASK;
00177 ix |= 0x43000000;
00178 INT2FLT(ix, x);
00179
00180 j = ROUNDF(x);
00181
00182 F = j;
00183 j -= 128;
00184
00185 f = x - F;
00186
00187 md = m;
00188
00189 u = (f + f)/(x + F);
00190
00191 l_lead = md*log2_lead.f;
00192 l_trail = md*log2_trail.f;
00193
00194 l_lead += _logftabhi[j].f;
00195 l_trail += _logftablo[j].f;
00196
00197 v = u*u;
00198
00199 q = Q[1].f*(v*u);
00200
00201 result = l_lead + (u + (q + l_trail));
00202
00203 return ( result*Loge.d );
00204
00205 }
00206
00207 if ( ix == one )
00208 return ( 0.0f );
00209
00210 x = x - f_one.f;
00211
00212 u1 = x/(2.0 + x);
00213 u1 = u1 + u1;
00214 u = u1;
00215 v = u1*u1;
00216
00217 q = (P[2].f*v + P[1].f)*(v*u);
00218
00219 result = u1 + q;
00220
00221 return ( result*Loge.d );
00222 }
00223
00224 if ( x != x )
00225 {
00226
00227
00228 #ifdef _CALL_MATHERR
00229
00230 exstruct.type = DOMAIN;
00231 exstruct.name = "log10f";
00232 exstruct.arg1 = x;
00233 exstruct.retval = Qnan.f;
00234
00235 if ( matherr( &exstruct ) == 0 )
00236 {
00237 fprintf(stderr, "domain error in log10f\n");
00238 SETERRNO(EDOM);
00239 }
00240
00241 return ( exstruct.retval );
00242 #else
00243 NAN_SETERRNO(EDOM);
00244
00245 return ( Qnan.f );
00246 #endif
00247 }
00248
00249 if ( x == Inf.f )
00250 {
00251 SETERRNO(EDOM);
00252
00253 return ( Inf.f );
00254 }
00255
00256 if ( x == 0.0f )
00257 {
00258 zeroarg:
00259
00260 #ifdef _CALL_MATHERR
00261
00262 exstruct.type = OVERFLOW;
00263 exstruct.name = "log10f";
00264 exstruct.arg1 = x;
00265 exstruct.retval = Neginf.f;
00266
00267 if ( matherr( &exstruct ) == 0 )
00268 {
00269 fprintf(stderr, "overflow range error in log10f\n");
00270 SETERRNO(ERANGE);
00271 }
00272
00273 return ( exstruct.retval );
00274 #else
00275 SETERRNO(ERANGE);
00276
00277 return ( Neginf.f );
00278 #endif
00279 }
00280
00281 if ( x < 0.0f )
00282 {
00283 #ifdef _CALL_MATHERR
00284
00285 exstruct.type = DOMAIN;
00286 exstruct.name = "log10f";
00287 exstruct.arg1 = x;
00288 exstruct.retval = Qnan.f;
00289
00290 if ( matherr( &exstruct ) == 0 )
00291 {
00292 fprintf(stderr, "domain error in log10f\n");
00293 SETERRNO(EDOM);
00294 }
00295
00296 return ( exstruct.retval );
00297 #else
00298 SETERRNO(EDOM);
00299
00300 return ( Qnan.f );
00301 #endif
00302 }
00303
00304
00305
00306
00307
00308 x *= Scaleup.f;
00309
00310 if ( x == 0.0f )
00311 goto zeroarg;
00312
00313 FLT2INT(x, ix);
00314 m = (ix >> MANTWIDTH);
00315 m -= EXPBIAS;
00316 m -= 23;
00317 goto L;
00318 }
00319