ldexp
Multiply a double-precision floating-point number by an integer power of two.
Usage
var ldexp = require( '@stdlib/math/base/special/ldexp' );
ldexp( frac, exp )
Multiplies a double-precision floating-point number by an integer
power of two (i.e., x = frac * 2^exp
).
var x = ldexp( 0.5, 3 ); // => 0.5 * 2^3 = 0.5 * 8
// returns 4.0
x = ldexp( 4.0, -2 ); // => 4 * 2^(-2) = 4 * (1/4)
// returns 1.0
If frac
equals positive or negative zero, NaN
, or positive or negative infinity
, the function returns a value equal to frac
.
var x = ldexp( 0.0, 20 );
// returns 0.0
x = ldexp( -0.0, 39 );
// returns -0.0
x = ldexp( NaN, -101 );
// returns NaN
x = ldexp( Infinity, 11 );
// returns Infinity
x = ldexp( -Infinity, -118 );
// returns -Infinity
Notes
- This function is the inverse of
frexp
.
Examples
var randu = require( '@stdlib/random/base/randu' );
var round = require( '@stdlib/math/base/special/round' );
var pow = require( '@stdlib/math/base/special/pow' );
var frexp = require( '@stdlib/math/base/special/frexp' );
var ldexp = require( '@stdlib/math/base/special/ldexp' );
var sign;
var frac;
var exp;
var x;
var f;
var v;
var i;
for ( i = 0; i < 100; i++ ) {
if ( randu() < 0.5 ) {
sign = -1.0;
} else {
sign = 1.0;
}
// Generate a random number:
frac = randu() * 10.0;
exp = round( randu()*616.0 ) - 308;
x = sign * frac * pow( 10.0, exp );
// Break the number into a normalized fraction and an integer power of two:
f = frexp( x );
// Reconstitute the original number:
v = ldexp( f[ 0 ], f[ 1 ] );
console.log( '%d = %d * 2^%d = %d', x, f[ 0 ], f[ 1 ], v );
}
C APIs
Usage
#include "stdlib/math/base/special/ldexp.h"
stdlib_base_ldexp( frac, exp )
Multiplies a double-precision floating-point number by an integer power of two (i.e., x = frac * 2^exp
).
double x = stdlib_base_ldexp( 0.5, 3 ); // => 0.5 * 2^3 = 0.5 * 8
// returns 4.0
The function accepts the following arguments:
- frac:
[in] double
input value. - exp:
[in] int32_t
integer power of two.
double stdlib_base_ldexp( const double frac, const int32_t exp );
Examples
#include "stdlib/math/base/special/ldexp.h"
#include <stdint.h>
#include <stdio.h>
int main( void ) {
double y;
int i;
const double frac[] = { 0.5, 5.0, 0.0, 3.5, 7.9 };
const int32_t exp[] = { 3, -2, 20, 39, 14 };
for ( i = 0; i < 5; i++ ) {
y = stdlib_base_ldexp( frac[ i ], exp[ i ] );
printf( "ldexp(%lf, %d) = %lf\n", frac[ i ], exp[ i ], y );
}
}