blob: f821f2ab639dc0c5efa02dc3a701fc1060c6393c (
plain) (
blame)
| 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
 | /* test cases for floating point comparison transformations
 * compile with -DFLOAT_TYPE=float
 *          or  -DFLOAT_TYPE=double
 *          or  -DFLOAT_TYPE="long double"
 */
#include <assert.h>
#define _GNU_SOURCE
#include <math.h>                           /* for NaNs and infinity values */
int main() {
  volatile FLOAT_TYPE a, b;
  /* negative zero */
  a = 1.0 / -(1.0 / 0.0);                                     /* negative 0 */
  b = 0.0;                                                    /* positive 0 */
  assert(!(a < b));
  assert((a <= b));
  assert(!(a > b));
  assert((a >= b));
  assert(!(a != b));
  assert((a == b));
  a = 1.0 / -(1.0 / 0.0);                                     /* negative 0 */
  b = 1.0 / -(1.0 / 0.0);                                     /* negative 0 */
  assert(!(a < b));
  assert((a <= b));
  assert(!(a > b));
  assert((a >= b));
  assert(!(a != b));
  assert((a == b));
}
 |