提交 52bcf3f5 编写于 作者: S Szabolcs Nagy

math: fix logb*.c exceptions now that ilogb raises invalid

上级 37aa7f73
#include <limits.h>
#include "libm.h" #include "libm.h"
/* /*
special cases: special cases:
logb(+-0) = -inf logb(+-0) = -inf, and raise divbyzero
logb(+-inf) = +inf logb(+-inf) = +inf
logb(nan) = nan logb(nan) = nan
these are calculated at runtime to raise fp exceptions
*/ */
double logb(double x) { double logb(double x)
int i = ilogb(x); {
if (!isfinite(x))
if (i == FP_ILOGB0)
return -1.0/fabs(x);
if (i == FP_ILOGBNAN || i == INT_MAX)
return x * x; return x * x;
return i; if (x == 0)
return -1/(x+0);
return ilogb(x);
} }
#include <limits.h>
#include "libm.h" #include "libm.h"
float logbf(float x) { float logbf(float x)
int i = ilogbf(x); {
if (!isfinite(x))
if (i == FP_ILOGB0)
return -1.0f/fabsf(x);
if (i == FP_ILOGBNAN || i == INT_MAX)
return x * x; return x * x;
return i; if (x == 0)
return -1/(x+0);
return ilogbf(x);
} }
#include <limits.h>
#include "libm.h" #include "libm.h"
#if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024 #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
long double logbl(long double x) long double logbl(long double x)
...@@ -8,12 +7,10 @@ long double logbl(long double x) ...@@ -8,12 +7,10 @@ long double logbl(long double x)
#else #else
long double logbl(long double x) long double logbl(long double x)
{ {
int i = ilogbl(x); if (!isfinite(x))
if (i == FP_ILOGB0)
return -1.0/fabsl(x);
if (i == FP_ILOGBNAN || i == INT_MAX)
return x * x; return x * x;
return i; if (x == 0)
return -1/(x+0);
return ilogbl(x);
} }
#endif #endif
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册