View source code
							
							
						
								Display the source code in std/math.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.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(doubleAuthors
Walter Bright, Don Clugston, Conversion of CEPHES math library to D by Iain Buclaw and David Nadlinger
License
					Copyright © 1999-2018 by the D Language Foundation | Page generated by ddox.