@stdlib/number-float64-base-exponent

Return an integer corresponding to the unbiased exponent of a double-precision floating-point number.

Usage no npm install needed!

<script type="module">
  import stdlibNumberFloat64BaseExponent from 'https://cdn.skypack.dev/@stdlib/number-float64-base-exponent';
</script>

README

Exponent

NPM version Build Status Coverage Status

Return an integer corresponding to the unbiased exponent of a double-precision floating-point number.

Installation

npm install @stdlib/number-float64-base-exponent

Usage

var exponent = require( '@stdlib/number-float64-base-exponent' );

exponent( x )

Returns an integer corresponding to the unbiased exponent of a double-precision floating-point number.

var exp = exponent( 3.14e307 ); // => 2**1021 ~ 1e307
// returns 1021

exp = exponent( 3.14e-307 ); // => 2**-1019 ~ 1e-307
// returns -1019

exp = exponent( -3.14 );
// returns 1

exp = exponent( 0.0 );
// returns -1023

exp = exponent( NaN );
// returns 1024

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 exponent = require( '@stdlib/number-float64-base-exponent' );

var frac;
var exp;
var x;
var e;
var i;

// Generate random numbers and extract their exponents...
for ( i = 0; i < 100; i++ ) {
    frac = randu() * 10.0;
    exp = round( randu()*646.0 ) - 323;
    x = frac * pow( 10.0, exp );
    e = exponent( x );
    console.log( 'x: %d. unbiased exponent: %d.', x, e );
}

Notice

This package is part of stdlib, a standard library for JavaScript and Node.js, with an emphasis on numerical and scientific computing. The library provides a collection of robust, high performance libraries for mathematics, statistics, streams, utilities, and more.

For more information on the project, filing bug reports and feature requests, and guidance on how to develop stdlib, see the main project repository.

Community

Chat


License

See LICENSE.

Copyright

Copyright © 2016-2022. The Stdlib Authors.