mirror of
https://github.com/byteworksinc/ORCA-C.git
synced 2025-01-16 20:32:57 +00:00
6ead1d4caf
These are currently only run by the new DOIT3 test-running script. Note that these tests are designed to be applicable to most implementations of C95/C99/C11, not just ORCA/C. They do make certain assumptions not guaranteed by the standards (e.g. power of 2 types and some properties of IEEE-like FP), but in general those assumptions should be true for most 'normal' systems.
217 lines
5.8 KiB
C
217 lines
5.8 KiB
C
/*
|
|
* Test floating-point classification macros (C99).
|
|
*/
|
|
|
|
#include <float.h>
|
|
#include <math.h>
|
|
#include <stdio.h>
|
|
|
|
int main(void) {
|
|
float f;
|
|
double d;
|
|
long double ld;
|
|
|
|
// These tests assume IEEE-like floating-point behavior.
|
|
|
|
/* float tests */
|
|
|
|
f = INFINITY;
|
|
if (fpclassify(f) != FP_INFINITE)
|
|
goto Fail;
|
|
if (!isinf(f) || isfinite(f) || isnan(f) || isnormal(f))
|
|
goto Fail;
|
|
if (signbit(f) != 0)
|
|
goto Fail;
|
|
|
|
f = NAN;
|
|
if (fpclassify(f) != FP_NAN)
|
|
goto Fail;
|
|
if (isinf(f) || isfinite(f) || !isnan(f) || isnormal(f))
|
|
goto Fail;
|
|
|
|
f = 1.0;
|
|
if (fpclassify(f) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(f) || !isfinite(f) || isnan(f) || !isnormal(f))
|
|
goto Fail;
|
|
if (signbit(f) != 0)
|
|
goto Fail;
|
|
|
|
f = FLT_MIN;
|
|
if (fpclassify(f) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(f) || !isfinite(f) || isnan(f) || !isnormal(f))
|
|
goto Fail;
|
|
if (signbit(f) != 0)
|
|
goto Fail;
|
|
|
|
f = FLT_MAX;
|
|
if (fpclassify(f) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(f) || !isfinite(f) || isnan(f) || !isnormal(f))
|
|
goto Fail;
|
|
if (signbit(f) != 0)
|
|
goto Fail;
|
|
|
|
f = 0.0;
|
|
if (fpclassify(f) != FP_ZERO)
|
|
goto Fail;
|
|
if (isinf(f) || !isfinite(f) || isnan(f) || isnormal(f))
|
|
goto Fail;
|
|
if (signbit(f) != 0)
|
|
goto Fail;
|
|
|
|
f = FLT_MIN / 2.0;
|
|
if (fpclassify(f) != FP_SUBNORMAL)
|
|
goto Fail;
|
|
if (isinf(f) || !isfinite(f) || isnan(f) || isnormal(f))
|
|
goto Fail;
|
|
if (signbit(f) != 0)
|
|
goto Fail;
|
|
|
|
f = -INFINITY;
|
|
if (signbit(f) == 0)
|
|
goto Fail;
|
|
|
|
f = -1.0;
|
|
if (signbit(f) == 0)
|
|
goto Fail;
|
|
|
|
|
|
/* double tests */
|
|
|
|
d = INFINITY;
|
|
if (fpclassify(d) != FP_INFINITE)
|
|
goto Fail;
|
|
if (!isinf(d) || isfinite(d) || isnan(d) || isnormal(d))
|
|
goto Fail;
|
|
if (signbit(d) != 0)
|
|
goto Fail;
|
|
|
|
d = NAN;
|
|
if (fpclassify(d) != FP_NAN)
|
|
goto Fail;
|
|
if (isinf(d) || isfinite(d) || !isnan(d) || isnormal(d))
|
|
goto Fail;
|
|
|
|
d = 1.0;
|
|
if (fpclassify(d) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(d) || !isfinite(d) || isnan(d) || !isnormal(d))
|
|
goto Fail;
|
|
if (signbit(d) != 0)
|
|
goto Fail;
|
|
|
|
d = DBL_MIN;
|
|
if (fpclassify(d) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(d) || !isfinite(d) || isnan(d) || !isnormal(d))
|
|
goto Fail;
|
|
if (signbit(d) != 0)
|
|
goto Fail;
|
|
|
|
d = DBL_MAX;
|
|
if (fpclassify(d) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(d) || !isfinite(d) || isnan(d) || !isnormal(d))
|
|
goto Fail;
|
|
if (signbit(d) != 0)
|
|
goto Fail;
|
|
|
|
d = 0.0;
|
|
if (fpclassify(d) != FP_ZERO)
|
|
goto Fail;
|
|
if (isinf(d) || !isfinite(d) || isnan(d) || isnormal(d))
|
|
goto Fail;
|
|
if (signbit(d) != 0)
|
|
goto Fail;
|
|
|
|
d = DBL_MIN / 2.0;
|
|
if (fpclassify(d) != FP_SUBNORMAL)
|
|
goto Fail;
|
|
if (isinf(d) || !isfinite(d) || isnan(d) || isnormal(d))
|
|
goto Fail;
|
|
if (signbit(d) != 0)
|
|
goto Fail;
|
|
|
|
d = -INFINITY;
|
|
if (signbit(d) == 0)
|
|
goto Fail;
|
|
|
|
d = -1.0;
|
|
if (signbit(d) == 0)
|
|
goto Fail;
|
|
|
|
|
|
/* long double tests */
|
|
|
|
ld = INFINITY;
|
|
if (fpclassify(ld) != FP_INFINITE)
|
|
goto Fail;
|
|
if (!isinf(ld) || isfinite(ld) || isnan(ld) || isnormal(ld))
|
|
goto Fail;
|
|
if (signbit(ld) != 0)
|
|
goto Fail;
|
|
|
|
ld = NAN;
|
|
if (fpclassify(ld) != FP_NAN)
|
|
goto Fail;
|
|
if (isinf(ld) || isfinite(ld) || !isnan(ld) || isnormal(ld))
|
|
goto Fail;
|
|
|
|
ld = 1.0;
|
|
if (fpclassify(ld) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(ld) || !isfinite(ld) || isnan(ld) || !isnormal(ld))
|
|
goto Fail;
|
|
if (signbit(ld) != 0)
|
|
goto Fail;
|
|
|
|
ld = LDBL_MIN;
|
|
if (fpclassify(ld) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(ld) || !isfinite(ld) || isnan(ld) || !isnormal(ld))
|
|
goto Fail;
|
|
if (signbit(ld) != 0)
|
|
goto Fail;
|
|
|
|
ld = LDBL_MAX;
|
|
if (fpclassify(ld) != FP_NORMAL)
|
|
goto Fail;
|
|
if (isinf(ld) || !isfinite(ld) || isnan(ld) || !isnormal(ld))
|
|
goto Fail;
|
|
if (signbit(ld) != 0)
|
|
goto Fail;
|
|
|
|
ld = 0.0;
|
|
if (fpclassify(ld) != FP_ZERO)
|
|
goto Fail;
|
|
if (isinf(ld) || !isfinite(ld) || isnan(ld) || isnormal(ld))
|
|
goto Fail;
|
|
if (signbit(ld) != 0)
|
|
goto Fail;
|
|
|
|
ld = LDBL_MIN / 2.0;
|
|
if (fpclassify(ld) != FP_SUBNORMAL)
|
|
goto Fail;
|
|
if (isinf(ld) || !isfinite(ld) || isnan(ld) || isnormal(ld))
|
|
goto Fail;
|
|
if (signbit(ld) != 0)
|
|
goto Fail;
|
|
|
|
ld = -INFINITY;
|
|
if (signbit(ld) == 0)
|
|
goto Fail;
|
|
|
|
ld = -1.0;
|
|
if (signbit(ld) == 0)
|
|
goto Fail;
|
|
|
|
printf ("Passed Conformance Test c99fpclass\n");
|
|
return 0;
|
|
|
|
Fail:
|
|
printf ("Failed Conformance Test c99fpclass\n");
|
|
|
|
}
|