#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <atf-c.h>
ATF_TC_WITHOUT_HEAD(test_fpclassify);
ATF_TC_BODY(test_fpclassify, tc)
{
ATF_CHECK(fpclassify((float)0) == FP_ZERO);
ATF_CHECK(fpclassify((float)-0.0) == FP_ZERO);
ATF_CHECK(fpclassify((float)1) == FP_NORMAL);
ATF_CHECK(fpclassify((float)1000) == FP_NORMAL);
ATF_CHECK(fpclassify(HUGE_VALF) == FP_INFINITE);
ATF_CHECK(fpclassify((float)HUGE_VAL) == FP_INFINITE);
ATF_CHECK(fpclassify((float)HUGE_VALL) == FP_INFINITE);
ATF_CHECK(fpclassify(NAN) == FP_NAN);
ATF_CHECK(fpclassify((double)0) == FP_ZERO);
ATF_CHECK(fpclassify((double)-0) == FP_ZERO);
ATF_CHECK(fpclassify((double)1) == FP_NORMAL);
ATF_CHECK(fpclassify((double)1000) == FP_NORMAL);
ATF_CHECK(fpclassify(HUGE_VAL) == FP_INFINITE);
ATF_CHECK(fpclassify((double)HUGE_VALF) == FP_INFINITE);
ATF_CHECK(fpclassify((double)HUGE_VALL) == FP_INFINITE);
ATF_CHECK(fpclassify((double)NAN) == FP_NAN);
ATF_CHECK(fpclassify((long double)0) == FP_ZERO);
ATF_CHECK(fpclassify((long double)-0.0) == FP_ZERO);
ATF_CHECK(fpclassify((long double)1) == FP_NORMAL);
ATF_CHECK(fpclassify((long double)1000) == FP_NORMAL);
ATF_CHECK(fpclassify(HUGE_VALL) == FP_INFINITE);
ATF_CHECK(fpclassify((long double)HUGE_VALF) == FP_INFINITE);
ATF_CHECK(fpclassify((long double)HUGE_VAL) == FP_INFINITE);
ATF_CHECK(fpclassify((long double)NAN) == FP_NAN);
}
ATF_TP_ADD_TCS(tp)
{
ATF_TP_ADD_TC(tp, test_fpclassify);
return (atf_no_error());
}