TODAY'S HEADLINES  |   ARTICLE ARCHIVE  |   FORUMS  |   TIP BANK
 Specialized Dev Zones Research Center eBook Library .NET Java C++ Web Dev Architecture Database Security Open Source Enterprise Mobile Special Reports 10-Minute Solutions DevXtra Blogs Slideshow

 Home » Tip Bank » .NET » VB.NET » Math Processing
Language: C++
Expertise: Intermediate
Oct 2, 2009

# Portable Functions to Check for NaN and Infinity

Currently, there are no portable C/C++ functions to check for NaN (not a number) and infinity (positive or negative).

Unix provides isnan() and isinf(), while Microsoft's implementation uses _isnan() and _isinf(). Moreover, some C/C++ compilers do not provide either of these functions.

There are many requests on the web to provide compatible functions that are available on all platforms. However, it is not difficult to write these functions from scratch, using the documented properties of these two special values.

For example, NaN is the only "number" that is not equal to any other number, including itself. Here's how you can use that property to construct a new function that tests for NaN:

``````inline int my_isnan(double x)
{
return x != x;
}``````

You can write a similar function to test for infinity, differentiating between positive and negative infinities by comparing them to zero:

``````inline int my_isinf(double x)
{
if ((x == x) && ((x - x) != 0.0)) return (x < 0.0 ? -1 : 1);
else return 0;
}``````

There are other ways to write these tests; for example, the sum of an infinity and a finite value is still an infinity.

To help avoid compiler optimization issues, you can change these functions as follows:

``````inline int my_isnan1(double x)
{
volatile double temp = x;
return temp != x;
}

inline int my_isinf1(double x)
{
volatile double temp = x;
if ((temp == x) && ((temp - x) != 0.0))
return (x < 0.0 ? -1 : 1);
else return 0;
}``````
Alexander Ocher

 Submit a Tip Browse ".NET" Tips Browse All Tips
Thanks for your registration, follow us on our social networks to keep up-to-date