HPCToolkit
NaN.c
Go to the documentation of this file.
1 // -*-Mode: C++;-*- // technically C99
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL$
6 // $Id$
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 // nan := 0.0/0.0
48 // +inf := 1.0/0.0
49 // -inf := -1.0/0.0
50 
51 // ANSI/IEEE Standard 754-1985 (64-bit double precision)
52 //
53 // S (1 bit) E (11 bits) F (52 bits)
54 //
55 // * If E=2047 and F is nonzero, then V=NaN ("Not a number")
56 // * If E=2047 and F is zero and S is 1, then V=-Infinity
57 // * If E=2047 and F is zero and S is 0, then V=Infinity
58 
59 // ANSI/IEEE Standard 754-1985 (128-bit quadruple precision)
60 //
61 // S (1 bit) E (15 bits) F (112 bits)
62 
63 //************************ System Include Files ******************************
64 
65 #include <math.h> // C99: FP_NAN, isnan, isinf
66 
67 //*************************** User Include Files ****************************
68 
69 #include "NaN.h"
70 
71 //*************************** Forward Declarations ***************************
72 
73 const double c_FP_NAN_d = FP_NAN;
74 
75 //****************************************************************************
76 
77 bool
78 c_isnan_d(double x)
79 {
80  return isnan(x);
81 }
82 
83 
84 bool
85 c_isinf_d(double x)
86 {
87  return isinf(x);
88 }
89 
const double c_FP_NAN_d
Definition: NaN.c:73
bool c_isinf_d(double x)
Definition: NaN.c:85
bool c_isnan_d(double x)
Definition: NaN.c:78