LOGB(3M) Mathematical Library Functions LOGB(3M)

NAME


logb, logbf, logbl - radix-independent exponent

SYNOPSIS


c99 [ flag... ] file... -lm [ library... ]
#include <math.h>

double logb(double x);


float logbf(float x);


long double logbl(long double x);


cc [ flag... ] file... -lm [ library... ]
#include <math.h>

double logb(double x);


float logbf(float x);


long double logbl(long double x);


DESCRIPTION


These functions compute the exponent of x, which is the integral part
of log(r) |x|, as a signed floating point value, for non-zero x,
where r is the radix of the machine's floating-point arithmetic,
which is the value of FLT_RADIX defined in the <float.h> header.

RETURN VALUES


Upon successful completion, these functions return the exponent of x.


If x is subnormal:

o For SUSv3-conforming applications compiled with the c99
compiler driver (see standards(7)), the exponent of x as
if x were normalized is returned.

o Otherwise, if compiled with the cc compiler driver, -1022,
-126, and -16382 are returned for logb(), logbf(), and
logbl(), respectively.


If x is +-0, a pole error occurs and logb(), logbf(), and logbl()
return -HUGE_VAL, -HUGE_VALF, and -HUGE_VALL, respectively.


If x is NaN, a NaN is returned.


If x is +-Inf, +Inf is returned.

ERRORS


These functions will fail if:

Pole Error
The value of x is +-0.

If the integer expression (math_errhandling &
MATH_ERREXCEPT) is non-zero, the divide-by-zero
floating-point exception is raised.

The logb() function sets errno to EDOM if the value of
x is 0.


USAGE


An application wanting to check for exceptions should call
feclearexcept(FE_ALL_EXCEPT) before calling these functions. On
return, if fetestexcept(FE_INVALID | FE_DIVBYZERO | FE_OVERFLOW |
FE_UNDERFLOW) is non-zero, an exception has been raised. An
application should either examine the return value or check the
floating point exception flags to detect exceptions.


An application can also set errno to 0 before calling logb(). On
return, if errno is non-zero, an error has occurred. The logbf() and
logbl() functions do not set errno.

ATTRIBUTES


See attributes(7) for descriptions of the following attributes:


+----------------------------+-----------------------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+----------------------------+-----------------------------+
|Interface Stability | Standard |
+----------------------------+-----------------------------+
|MT-Level | MT-Safe |
+----------------------------+-----------------------------+

SEE ALSO


math.h(3HEAD), feclearexcept(3M), fetestexcept(3M), ilogb(3M),
matherr(3M), scalb(3M), attributes(7), standards(7)

SunOS 5.11 July 12, 2006 LOGB(3M)

tribblix@gmail.com :: GitHub :: Privacy