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
c_FP_NAN_d
const double c_FP_NAN_d
Definition:
NaN.c:73
c_isinf_d
bool c_isinf_d(double x)
Definition:
NaN.c:85
NaN.h
c_isnan_d
bool c_isnan_d(double x)
Definition:
NaN.c:78
src
lib
support
NaN.c
Generated by
1.8.13