We believe in a future in which the web is a preferred environment for numerical computation. To help realize this future, we've built stdlib. stdlib is a standard library, with an emphasis on numerical and scientific computation, written in JavaScript (and C) for execution in browsers and in Node.js.
The library is fully decomposable, being architected in such a way that you can swap out and mix and match APIs and functionality to cater to your exact preferences and use cases.
When you use stdlib, you can be absolutely certain that you are using the most thorough, rigorous, well-written, studied, documented, tested, measured, and high-quality code out there.
To join us in bringing numerical computing to the web, get started by checking us out on GitHub, and please consider financially supporting stdlib. We greatly appreciate your continued support!
isNonNegativeInteger
[![NPM version][npm-image]][npm-url] [![Build Status][test-image]][test-url] [![Coverage Status][coverage-image]][coverage-url]
Test if a finite [double-precision floating-point number][ieee754] is a nonnegative integer.
bash
npm install @stdlib/math-base-assert-is-nonnegative-integer
javascript
var isNonNegativeInteger = require( '@stdlib/math-base-assert-is-nonnegative-integer' );
#### isNonNegativeInteger( x )
Tests if a finite [double-precision floating-point number][ieee754] is a nonnegative integer
.
javascript
var bool = isNonNegativeInteger( 1.0 );
// returns true
bool = isNonNegativeInteger( 0.0 );
// returns true
bool = isNonNegativeInteger( -10.0 );
// returns false
number
. If provided positive infinity
, the function will return true
, when, in fact, the result is undefined. If x
can be infinite
, wrap the implementation as follows:
javascript
function check( x ) {
return (
x < Infinity &&
isNonNegativeInteger( x )
);
}
var bool = check( Infinity );
// returns false
- The function does not distinguish between positive and negative zero
.
javascript
var bool = isNonNegativeInteger( 0.0 );
// returns true
bool = isNonNegativeInteger( -0.0 );
// returns true
javascript
var isNonNegativeInteger = require( '@stdlib/math-base-assert-is-nonnegative-integer' );
var bool = isNonNegativeInteger( 5.0 );
// returns true
bool = isNonNegativeInteger( 0.0 );
// returns true
bool = isNonNegativeInteger( -1.0 );
// returns false
bool = isNonNegativeInteger( 3.14 );
// returns false
bool = isNonNegativeInteger( NaN );
// returns false
c
#include "stdlib/math/base/assert/is_nonnegative_integer.h"
#### stdlib_base_is_nonnegative_integer( x )
Tests if a finite [double-precision floating-point number][ieee754] is a nonnegative integer.
c
bool out = stdlib_base_is_nonnegative_integer( 1.0 );
// returns true
out = stdlib_base_is_nonnegative_integer( -10.0 );
// returns false
The function accepts the following arguments:
- x: [in] double
input value.
c
bool stdlib_base_is_nonnegative_integer( const double x );
c
#include "stdlib/math/base/assert/is_nonnegative_integer.h"
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
int main( void ) {
double x;
bool v;
int i;
for ( i = 0; i < 100; i++ ) {
x = ( ( (double)rand() / (double)RAND_MAX ) * 100.0 ) - 50.0;
v = stdlib_base_is_nonnegative_integer( x );
printf( "x = %lf, is_nonnegative_integer(x) = %s\n", x, ( v ) ? "true" : "false" );
}
}
@stdlib/math-base/assert/is-integer
][@stdlib/math/base/assert/is-integer]: test if a finite double-precision floating-point number is an integer.
- [@stdlib/math-base/assert/is-negative-integer
][@stdlib/math/base/assert/is-negative-integer]: test if a finite double-precision floating-point number is a negative integer.
- [@stdlib/math-base/assert/is-nonpositive-integer
][@stdlib/math/base/assert/is-nonpositive-integer]: test if a finite double-precision floating-point number is a nonpositive integer.
- [@stdlib/math-base/assert/is-positive-integer
][@stdlib/math/base/assert/is-positive-integer]: test if a finite double-precision floating-point number is a positive integer.