View source code
Display the source code in std/math/exponential.d from which this
page was generated on github.
Report a bug
If you spot a problem with this page, click here to create a
Bugzilla issue.
Improve this page
Quickly fork, edit online, and submit a pull request for this page.
Requires a signed-in GitHub account. This works well for small changes.
If you'd like to make larger changes you may want to consider using
local clone.
Function std.math.exponential.ilogb
Extracts the exponent of x as a signed integral value.
int ilogb(T)
(
const T x
) pure nothrow @nogc @trusted
if (isFloatingPoint!T);
int ilogb(T)
(
const T x
) pure nothrow @nogc @safe
if (isIntegral!T && isUnsigned!T);
int ilogb(T)
(
const T x
) pure nothrow @nogc @safe
if (isIntegral!T && isSigned!T);
If x is not a special value, the result is the same as
cast(int) logb(x)
.
x | ilogb(x) | Range error? |
---|---|---|
0 | FP_ILOGB0 | yes |
±∞ | int.max | no |
NAN | FP_ILOGBNAN | no |
Example
writeln(ilogb(1)); // 0
writeln(ilogb(3)); // 1
writeln(ilogb(3.0)); // 1
writeln(ilogb(100_000_000)); // 26
writeln(ilogb(0)); // FP_ILOGB0
writeln(ilogb(0.0)); // FP_ILOGB0
writeln(ilogb(double .nan)); // FP_ILOGBNAN
writeln(ilogb(double .infinity)); // int.max
Authors
Walter Bright, Don Clugston, Conversion of CEPHES math library to D by Iain Buclaw and David Nadlinger
License
Copyright © 1999-2025 by the D Language Foundation | Page generated by ddox.