mirror of
https://github.com/Ryujinx/SDL.git
synced 2025-01-08 23:15:33 +00:00
Use helper_ddtod function to compare atan2 infinity cases
This fixes a test failure when building on mingw32 in Release mode.
This commit is contained in:
parent
69a6efcd1b
commit
1737340978
|
@ -49,6 +49,12 @@ typedef struct
|
||||||
double expected;
|
double expected;
|
||||||
} dd_to_d;
|
} dd_to_d;
|
||||||
|
|
||||||
|
#define DD_TO_D_CASE(IDX, X, Y, E) do { \
|
||||||
|
cases[IDX].x_input = (X); \
|
||||||
|
cases[IDX].y_input = (Y); \
|
||||||
|
cases[IDX].expected = (E); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
NB: You cannot create an array of these structures containing INFINITY or NAN.
|
NB: You cannot create an array of these structures containing INFINITY or NAN.
|
||||||
On platforms such as OS/2, they are defined as 'extern const double' making them
|
On platforms such as OS/2, they are defined as 'extern const double' making them
|
||||||
|
@ -2605,29 +2611,12 @@ atan2_xZeroCases(void *args)
|
||||||
static int
|
static int
|
||||||
atan2_bothInfCases(void *args)
|
atan2_bothInfCases(void *args)
|
||||||
{
|
{
|
||||||
double result;
|
dd_to_d cases[4];
|
||||||
|
DD_TO_D_CASE(0, INFINITY, INFINITY, 1.0 * M_PI / 4.0);
|
||||||
result = SDL_atan2(INFINITY, INFINITY);
|
DD_TO_D_CASE(1, INFINITY, -INFINITY, 3.0 * M_PI / 4.0);
|
||||||
SDLTest_AssertCheck(SDL_fabs(M_PI / 4.0 - result) <= EPSILON,
|
DD_TO_D_CASE(2, -INFINITY, INFINITY, -1.0 * M_PI / 4.0);
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
DD_TO_D_CASE(3, -INFINITY, -INFINITY, -3.0 * M_PI / 4.0);
|
||||||
INFINITY, INFINITY, M_PI / 4.0, result);
|
return helper_ddtod("SDL_atan2(bothInfCases)", SDL_atan2, cases, SDL_arraysize(cases));
|
||||||
|
|
||||||
result = SDL_atan2(INFINITY, -INFINITY);
|
|
||||||
SDLTest_AssertCheck(SDL_fabs(3.0 * M_PI / 4.0 - result) <= EPSILON,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
INFINITY, -INFINITY, 3.0 * M_PI / 4.0, result);
|
|
||||||
|
|
||||||
result = SDL_atan2(-INFINITY, INFINITY);
|
|
||||||
SDLTest_AssertCheck(SDL_fabs(-M_PI / 4.0 - result) <= EPSILON,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
-INFINITY, INFINITY, -M_PI / 4.0, result);
|
|
||||||
|
|
||||||
result = SDL_atan2(-INFINITY, -INFINITY);
|
|
||||||
SDLTest_AssertCheck(SDL_fabs(-3.0 * M_PI / 4.0 - result) <= EPSILON,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
-INFINITY, -INFINITY, -3.0 * M_PI / 4.0, result);
|
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2637,29 +2626,12 @@ atan2_bothInfCases(void *args)
|
||||||
static int
|
static int
|
||||||
atan2_yInfCases(void *args)
|
atan2_yInfCases(void *args)
|
||||||
{
|
{
|
||||||
double result;
|
dd_to_d cases[4];
|
||||||
|
DD_TO_D_CASE(0, INFINITY, 1.0, 1.0 * M_PI / 2.0);
|
||||||
result = SDL_atan2(INFINITY, 1.0);
|
DD_TO_D_CASE(1, INFINITY, -1.0, 1.0 * M_PI / 2.0);
|
||||||
SDLTest_AssertCheck(SDL_fabs(M_PI / 2.0 - result) <= EPSILON,
|
DD_TO_D_CASE(2, -INFINITY, 1.0, -1.0 * M_PI / 2.0);
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
DD_TO_D_CASE(3, -INFINITY, -1.0, -1.0 * M_PI / 2.0);
|
||||||
INFINITY, 1.0, M_PI / 2.0, result);
|
return helper_ddtod("SDL_atan2(atan2_yInfCases)", SDL_atan2, cases, SDL_arraysize(cases));
|
||||||
|
|
||||||
result = SDL_atan2(INFINITY, -1.0);
|
|
||||||
SDLTest_AssertCheck(SDL_fabs(M_PI / 2.0 - result) <= EPSILON,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
INFINITY, -1.0, M_PI / 2.0, result);
|
|
||||||
|
|
||||||
result = SDL_atan2(-INFINITY, 1.0);
|
|
||||||
SDLTest_AssertCheck(SDL_fabs(-M_PI / 2.0 - result) <= EPSILON,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
-INFINITY, 1.0, -M_PI / 2.0, result);
|
|
||||||
|
|
||||||
result = SDL_atan2(-INFINITY, -1.0);
|
|
||||||
SDLTest_AssertCheck(SDL_fabs(-M_PI / 2.0 - result) <= EPSILON,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
-INFINITY, -1.0, -M_PI / 2.0, result);
|
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2671,29 +2643,12 @@ atan2_yInfCases(void *args)
|
||||||
static int
|
static int
|
||||||
atan2_xInfCases(void *args)
|
atan2_xInfCases(void *args)
|
||||||
{
|
{
|
||||||
double result;
|
dd_to_d cases[4];
|
||||||
|
DD_TO_D_CASE(0, 1.0, INFINITY, 0.0);
|
||||||
result = SDL_atan2(1.0, INFINITY);
|
DD_TO_D_CASE(1, -1.0, INFINITY, -0.0);
|
||||||
SDLTest_AssertCheck(0.0 == result,
|
DD_TO_D_CASE(2, 1.0, -INFINITY, M_PI);
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
DD_TO_D_CASE(3, -1.0, -INFINITY, -M_PI);
|
||||||
1.0, INFINITY, 0.0, result);
|
return helper_ddtod("atan2_xInfCases(atan2_yInfCases)", SDL_atan2, cases, SDL_arraysize(cases));
|
||||||
|
|
||||||
result = SDL_atan2(-1.0, INFINITY);
|
|
||||||
SDLTest_AssertCheck(-0.0 == result,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
-1.0, INFINITY, -0.0, result);
|
|
||||||
|
|
||||||
result = SDL_atan2(1.0, -INFINITY);
|
|
||||||
SDLTest_AssertCheck(SDL_fabs(M_PI - result) <= EPSILON,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
1.0, -INFINITY, M_PI, result);
|
|
||||||
|
|
||||||
result = SDL_atan2(-1.0, -INFINITY);
|
|
||||||
SDLTest_AssertCheck(SDL_fabs(-M_PI - result) <= EPSILON,
|
|
||||||
"Atan2(%f,%f), expected %f, got %f",
|
|
||||||
-1.0, -INFINITY, -M_PI, result);
|
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Miscelanious cases */
|
/* Miscelanious cases */
|
||||||
|
|
Loading…
Reference in a new issue