2000-01-15 02:00:06 +00:00
|
|
|
/********************************************************************
|
|
|
|
* COPYRIGHT:
|
2001-03-21 20:09:56 +00:00
|
|
|
* Copyright (c) 1997-2001, International Business Machines Corporation and
|
2000-01-15 02:00:06 +00:00
|
|
|
* others. All Rights Reserved.
|
|
|
|
********************************************************************/
|
1999-08-16 21:50:52 +00:00
|
|
|
|
|
|
|
#include "tsputil.h"
|
|
|
|
|
|
|
|
#include <float.h> // DBL_MAX, DBL_MIN
|
|
|
|
|
|
|
|
#define CASE(id,test) case id: name = #test; if (exec) { logln(#test "---"); logln((UnicodeString)""); test(); } break;
|
|
|
|
|
|
|
|
void
|
2000-08-23 19:11:16 +00:00
|
|
|
PUtilTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
//if (exec) logln("TestSuite PUtilTest: ");
|
|
|
|
switch (index) {
|
|
|
|
|
|
|
|
CASE(0, testIEEEremainder)
|
|
|
|
CASE(1, testMaxMin)
|
|
|
|
|
|
|
|
default: name = ""; break; //needed to end loop
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
PUtilTest::testIEEEremainder()
|
|
|
|
{
|
2000-08-23 19:11:16 +00:00
|
|
|
double pinf = uprv_getInfinity();
|
|
|
|
double ninf = -uprv_getInfinity();
|
|
|
|
double nan = uprv_getNaN();
|
|
|
|
double pzero = 0.0;
|
|
|
|
double nzero = 0.0;
|
1999-08-16 21:50:52 +00:00
|
|
|
|
|
|
|
nzero *= -1;
|
|
|
|
|
|
|
|
// simple remainder checks
|
|
|
|
remainderTest(7.0, 2.5, -0.5);
|
|
|
|
remainderTest(7.0, -2.5, -0.5);
|
2000-04-05 19:45:48 +00:00
|
|
|
#ifndef OS390
|
|
|
|
// ### TODO:
|
|
|
|
// The following tests fails on S/390 with IEEE support in release builds;
|
|
|
|
// debug builds work.
|
|
|
|
// The functioning of ChoiceFormat is not affected by this bug.
|
1999-08-16 21:50:52 +00:00
|
|
|
remainderTest(-7.0, 2.5, 0.5);
|
|
|
|
remainderTest(-7.0, -2.5, 0.5);
|
2000-04-05 19:45:48 +00:00
|
|
|
#endif
|
1999-08-16 21:50:52 +00:00
|
|
|
remainderTest(5.0, 3.0, -1.0);
|
|
|
|
|
|
|
|
// this should work
|
|
|
|
//remainderTest(43.7, 2.5, 1.25);
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
// infinity and real
|
|
|
|
remainderTest(pinf, 1.0, 1.25);
|
|
|
|
remainderTest(1.0, pinf, 1.0);
|
|
|
|
remainderTest(ninf, 1.0, 1.25);
|
|
|
|
remainderTest(1.0, ninf, 1.0);
|
|
|
|
|
|
|
|
// test infinity and nan
|
|
|
|
remainderTest(ninf, pinf, 1.25);
|
|
|
|
remainderTest(ninf, nan, 1.25);
|
|
|
|
remainderTest(pinf, nan, 1.25);
|
|
|
|
|
|
|
|
// test infinity and zero
|
|
|
|
remainderTest(pinf, pzero, 1.25);
|
|
|
|
remainderTest(pinf, nzero, 1.25);
|
|
|
|
remainderTest(ninf, pzero, 1.25);
|
|
|
|
remainderTest(ninf, nzero, 1.25);
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
PUtilTest::remainderTest(double x, double y, double exp)
|
|
|
|
{
|
1999-12-28 23:57:50 +00:00
|
|
|
double result = uprv_IEEEremainder(x,y);
|
1999-08-16 21:50:52 +00:00
|
|
|
|
1999-12-28 23:57:50 +00:00
|
|
|
if( uprv_isNaN(result) &&
|
|
|
|
! ( uprv_isNaN(x) || uprv_isNaN(y))) {
|
1999-08-16 21:50:52 +00:00
|
|
|
errln(UnicodeString("FAIL: got NaN as result without NaN as argument"));
|
|
|
|
errln(UnicodeString(" IEEEremainder(") + x + ", " + y + ") is " + result + ", expected " + exp);
|
|
|
|
}
|
|
|
|
else if(result != exp)
|
|
|
|
errln(UnicodeString("FAIL: IEEEremainder(") + x + ", " + y + ") is " + result + ", expected " + exp);
|
|
|
|
else
|
|
|
|
logln(UnicodeString("OK: IEEEremainder(") + x + ", " + y + ") is " + result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
PUtilTest::testMaxMin()
|
|
|
|
{
|
1999-12-28 23:57:50 +00:00
|
|
|
double pinf = uprv_getInfinity();
|
|
|
|
double ninf = -uprv_getInfinity();
|
|
|
|
double nan = uprv_getNaN();
|
1999-08-16 21:50:52 +00:00
|
|
|
double pzero = 0.0;
|
|
|
|
double nzero = 0.0;
|
|
|
|
|
|
|
|
nzero *= -1;
|
|
|
|
|
|
|
|
// +Inf with -Inf
|
|
|
|
maxMinTest(pinf, ninf, pinf, TRUE);
|
|
|
|
maxMinTest(pinf, ninf, ninf, FALSE);
|
|
|
|
|
|
|
|
// +Inf with +0 and -0
|
|
|
|
maxMinTest(pinf, pzero, pinf, TRUE);
|
|
|
|
maxMinTest(pinf, pzero, pzero, FALSE);
|
|
|
|
maxMinTest(pinf, nzero, pinf, TRUE);
|
|
|
|
maxMinTest(pinf, nzero, nzero, FALSE);
|
|
|
|
|
|
|
|
// -Inf with +0 and -0
|
|
|
|
maxMinTest(ninf, pzero, pzero, TRUE);
|
|
|
|
maxMinTest(ninf, pzero, ninf, FALSE);
|
|
|
|
maxMinTest(ninf, nzero, nzero, TRUE);
|
|
|
|
maxMinTest(ninf, nzero, ninf, FALSE);
|
|
|
|
|
|
|
|
// NaN with +Inf and -Inf
|
|
|
|
maxMinTest(pinf, nan, nan, TRUE);
|
|
|
|
maxMinTest(pinf, nan, nan, FALSE);
|
|
|
|
maxMinTest(ninf, nan, nan, TRUE);
|
|
|
|
maxMinTest(ninf, nan, nan, FALSE);
|
|
|
|
|
|
|
|
// NaN with NaN
|
|
|
|
maxMinTest(nan, nan, nan, TRUE);
|
|
|
|
maxMinTest(nan, nan, nan, FALSE);
|
|
|
|
|
|
|
|
// NaN with +0 and -0
|
|
|
|
maxMinTest(nan, pzero, nan, TRUE);
|
|
|
|
maxMinTest(nan, pzero, nan, FALSE);
|
|
|
|
maxMinTest(nan, nzero, nan, TRUE);
|
|
|
|
maxMinTest(nan, nzero, nan, FALSE);
|
|
|
|
|
|
|
|
// +Inf with DBL_MAX and DBL_MIN
|
|
|
|
maxMinTest(pinf, DBL_MAX, pinf, TRUE);
|
|
|
|
maxMinTest(pinf, -DBL_MAX, pinf, TRUE);
|
|
|
|
maxMinTest(pinf, DBL_MIN, pinf, TRUE);
|
|
|
|
maxMinTest(pinf, -DBL_MIN, pinf, TRUE);
|
|
|
|
maxMinTest(pinf, DBL_MIN, DBL_MIN, FALSE);
|
|
|
|
maxMinTest(pinf, -DBL_MIN, -DBL_MIN, FALSE);
|
|
|
|
maxMinTest(pinf, DBL_MAX, DBL_MAX, FALSE);
|
|
|
|
maxMinTest(pinf, -DBL_MAX, -DBL_MAX, FALSE);
|
|
|
|
|
|
|
|
// -Inf with DBL_MAX and DBL_MIN
|
|
|
|
maxMinTest(ninf, DBL_MAX, DBL_MAX, TRUE);
|
|
|
|
maxMinTest(ninf, -DBL_MAX, -DBL_MAX, TRUE);
|
|
|
|
maxMinTest(ninf, DBL_MIN, DBL_MIN, TRUE);
|
|
|
|
maxMinTest(ninf, -DBL_MIN, -DBL_MIN, TRUE);
|
|
|
|
maxMinTest(ninf, DBL_MIN, ninf, FALSE);
|
|
|
|
maxMinTest(ninf, -DBL_MIN, ninf, FALSE);
|
|
|
|
maxMinTest(ninf, DBL_MAX, ninf, FALSE);
|
|
|
|
maxMinTest(ninf, -DBL_MAX, ninf, FALSE);
|
|
|
|
|
|
|
|
// +0 with DBL_MAX and DBL_MIN
|
|
|
|
maxMinTest(pzero, DBL_MAX, DBL_MAX, TRUE);
|
|
|
|
maxMinTest(pzero, -DBL_MAX, pzero, TRUE);
|
|
|
|
maxMinTest(pzero, DBL_MIN, DBL_MIN, TRUE);
|
|
|
|
maxMinTest(pzero, -DBL_MIN, pzero, TRUE);
|
|
|
|
maxMinTest(pzero, DBL_MIN, pzero, FALSE);
|
|
|
|
maxMinTest(pzero, -DBL_MIN, -DBL_MIN, FALSE);
|
|
|
|
maxMinTest(pzero, DBL_MAX, pzero, FALSE);
|
|
|
|
maxMinTest(pzero, -DBL_MAX, -DBL_MAX, FALSE);
|
|
|
|
|
|
|
|
// -0 with DBL_MAX and DBL_MIN
|
|
|
|
maxMinTest(nzero, DBL_MAX, DBL_MAX, TRUE);
|
|
|
|
maxMinTest(nzero, -DBL_MAX, nzero, TRUE);
|
|
|
|
maxMinTest(nzero, DBL_MIN, DBL_MIN, TRUE);
|
|
|
|
maxMinTest(nzero, -DBL_MIN, nzero, TRUE);
|
|
|
|
maxMinTest(nzero, DBL_MIN, nzero, FALSE);
|
|
|
|
maxMinTest(nzero, -DBL_MIN, -DBL_MIN, FALSE);
|
|
|
|
maxMinTest(nzero, DBL_MAX, nzero, FALSE);
|
|
|
|
maxMinTest(nzero, -DBL_MAX, -DBL_MAX, FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2000-05-18 22:08:39 +00:00
|
|
|
PUtilTest::maxMinTest(double a, double b, double exp, UBool max)
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
double result = 0.0;
|
|
|
|
|
|
|
|
if(max)
|
1999-12-28 23:57:50 +00:00
|
|
|
result = uprv_fmax(a, b);
|
1999-08-16 21:50:52 +00:00
|
|
|
else
|
1999-12-28 23:57:50 +00:00
|
|
|
result = uprv_fmin(a, b);
|
1999-08-16 21:50:52 +00:00
|
|
|
|
2000-05-18 22:08:39 +00:00
|
|
|
UBool nanResultOK = (uprv_isNaN(a) || uprv_isNaN(b));
|
1999-08-16 21:50:52 +00:00
|
|
|
|
1999-12-28 23:57:50 +00:00
|
|
|
if(uprv_isNaN(result) && ! nanResultOK) {
|
1999-08-16 21:50:52 +00:00
|
|
|
errln(UnicodeString("FAIL: got NaN as result without NaN as argument"));
|
|
|
|
if(max)
|
|
|
|
errln(UnicodeString(" max(") + a + ", " + b + ") is " + result + ", expected " + exp);
|
|
|
|
else
|
|
|
|
errln(UnicodeString(" min(") + a + ", " + b + ") is " + result + ", expected " + exp);
|
|
|
|
}
|
1999-12-28 23:57:50 +00:00
|
|
|
else if(result != exp && ! (uprv_isNaN(result) || uprv_isNaN(exp)))
|
1999-08-16 21:50:52 +00:00
|
|
|
if(max)
|
|
|
|
errln(UnicodeString("FAIL: max(") + a + ", " + b + ") is " + result + ", expected " + exp);
|
|
|
|
else
|
|
|
|
errln(UnicodeString("FAIL: min(") + a + ", " + b + ") is " + result + ", expected " + exp);
|
|
|
|
else
|
|
|
|
if(max)
|
|
|
|
logln(UnicodeString("OK: max(") + a + ", " + b + ") is " + result);
|
|
|
|
else
|
|
|
|
logln(UnicodeString("OK: min(") + a + ", " + b + ") is " + result);
|
|
|
|
}
|