1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
|
//--------------------------------------------------------------------------
//
// File: nan.h
//
// Created: 18/10/2001
//
// Author: Pavel Sakov
// CSIRO Marine Research
//
// Purpose: NaN definition
//
// Description: Should cover machines with 64 bit doubles or other machines
// with GCC
//
// Revisions: None
//
//--------------------------------------------------------------------------
#if !defined ( _NAN_H )
#define _NAN_H
#if ( defined ( __GNUC__ ) && !defined ( __ICC ) ) || defined ( __BORLANDC__ )
static const double NaN = 0.0 / 0.0;
#ifdef __BORLANDC__
#define isnan _isnan
#define copysign _copysign
#endif
#elif defined ( WIN32 )
#if !defined ( _MSC_VER )
static unsigned _int64 lNaN = ( (unsigned _int64) 1 << 63 ) - 1;
#define NaN ( *(double *) &lNaN )
#else
// MSVC/C++ 6.0 reports a version 1200,
// MSVC/C++ 2003 reports a version 1300
//
#include <float.h>
#include <ymath.h>
#undef NaN
#if _MSC_VER < 1300
#define NaN _Nan._D
#else
#define NaN _Nan._Double
#endif
#define isnan _isnan
#define copysign _copysign
#endif
#else
static const long long lNaN = ( (unsigned long long) 1 << 63 ) - 1;
#define NaN ( *(double *) &lNaN )
#endif
#endif
//#if !defined(_NAN_H)
// #define _NAN_H
//
// #if defined(__GNUC__)
// static const double NaN = 0.0 / 0.0;
// #elif defined(BIG_ENDIAN) || defined(_BIG_ENDIAN)
// static const long long lNaN = 0x7fffffffffffffff;
//
// #define NaN (*(double*)&lNaN)
// #else
// static const long long lNaN = 0xfff8000000000000;
//
// #define NaN (*(double*)&lNaN)
// #endif
//
// #endif
|