Solved

Not A Number - quick fix

Posted on 2001-09-03
9
737 Views
Last Modified: 2007-12-19
I am using GNU C++ and Borland Builder C++

I have written a program, and discovered a fault - However I do not have the time to rewrite the whole program from the ground up as it will take too long. I wish to patch the code instead.

My program sometimes returns NaN becasue it has exceeded a boundary, my idea is to use a if statement to check to see if the return value is real number.


I believe that I need to use <math.h>

I have tried using :

if ( number == NAN)
{
Do this . .. .
 }
else
{
Do that
}

However there is a compiler error NAN not declared.

Any suggestions

Cheers

Will Ryder
0
Comment
Question by:wjryder
9 Comments
 
LVL 86

Expert Comment

by:jkr
ID: 6451051
>>if ( number == NAN)

You'd better use

if ( isnan ( number)) {
}

ans comparing doubles for equality is not a good idea. 'isnan()' is declared in 'float.h'
0
 
LVL 86

Expert Comment

by:jkr
ID: 6451063
BTW - what you are looking for is '_Nan', and it can be found in 'ymath.h'...
0
 

Author Comment

by:wjryder
ID: 6451112
perhaps using finite is better as it will also catch infinity problems

0
Best Practices: Disaster Recovery Testing

Besides backup, any IT division should have a disaster recovery plan. You will find a few tips below relating to the development of such a plan and to what issues one should pay special attention in the course of backup planning.

 

Author Comment

by:wjryder
ID: 6451115
Is this a Borland compatiable function ?

can't find it  in the help file
0
 
LVL 86

Expert Comment

by:jkr
ID: 6451127
Try to look up '_isnan()' or '_isinf()' - the functions itself are IEEE, so they should be present in any compiler with floating point support...
0
 
LVL 86

Accepted Solution

by:
jkr earned 200 total points
ID: 6451129
BTW, as you mentioned gcc also:

ISINF(3)            Linux Programmer's Manual            ISINF(3)


NAME
       isinf,  isnan,  finite - test for infinity or not-a-number
       (NaN)

SYNOPSIS
       #include <math.h>

       int isinf(double value);

       int isnan(double value);

       int finite(double value);

DESCRIPTION
       The isinf() function returns -1 if value represents  nega-
       tive  infinity,  1  if value represents positive infinity,
       and 0 otherwise.

       The isnan() function returns a non-zero value if value  is
       "not-a-number" (NaN), and 0 otherwise.

       The finite() function returns a non-zero value if value is
       neither infinite nor a "not-a-number" (NaN) value,  and  0
       otherwise.

CONFORMING TO
       BSD 4.3
0
 
LVL 14

Expert Comment

by:AlexVirochovsky
ID: 6451428
For BCB a bit other:
_isNAN(double d)
_isNANl(long double ld)
to check if given floating-point value for not a
number (NAN).

0
 
LVL 86

Expert Comment

by:jkr
ID: 6451444
Why do they have to diversify these names?

gcc: isnan()
VC:  _isnan()
BCB: _isNAN()

Hmmpf....
0
 
LVL 30

Expert Comment

by:Axter
ID: 6454636
>>Why do they have to diversify these names?

VC is using the correct nameing convension.
According to the standards, any function that is part of the implementation, should start with an underscore, and proceed with a lowercase letter.

The GCC compiler should not be using isnan() with out the underscore prefix.
And it makes no sence to me why BCB would want to have a function that starts with a lower case letter, and then go upercase in the last part of the name.
BCB is not breaking the standards, but it certainly using a stupid naming convention.
0

Featured Post

Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Errors will happen. It is a fact of life for the programmer. How and when errors are detected have a great impact on quality and cost of a product. It is better to detect errors at compile time, when possible and practical. Errors that make their wa…
In days of old, returning something by value from a function in C++ was necessarily avoided because it would, invariably, involve one or even two copies of the object being created and potentially costly calls to a copy-constructor and destructor. A…
The goal of the video will be to teach the user the difference and consequence of passing data by value vs passing data by reference in C++. An example of passing data by value as well as an example of passing data by reference will be be given. Bot…
The viewer will learn how to user default arguments when defining functions. This method of defining functions will be contrasted with the non-default-argument of defining functions.

777 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question