2016-11-23 11:19:15 -06:00
|
|
|
/*
|
|
|
|
|
Copyright (c) 2015-2016 Advanced Micro Devices, Inc. All rights reserved.
|
|
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
|
THE SOFTWARE.
|
|
|
|
|
*/
|
2017-01-27 09:20:14 -06:00
|
|
|
|
|
|
|
|
/* HIT_START
|
|
|
|
|
* BUILD: %t %s ../test_common.cpp
|
|
|
|
|
* RUN: %t
|
|
|
|
|
* HIT_END
|
|
|
|
|
*/
|
|
|
|
|
|
2017-01-17 14:57:51 -06:00
|
|
|
#include <hip/hip_runtime.h>
|
|
|
|
|
#include <hip/math_functions.h>
|
2016-11-23 11:19:15 -06:00
|
|
|
#include "test_common.h"
|
|
|
|
|
|
2018-03-12 11:29:03 +05:30
|
|
|
__global__ void FloatMathPrecise(hipLaunchParm lp) {
|
|
|
|
|
// int iX; //uncomment this when remqouf() is enabled again
|
2016-11-23 11:19:15 -06:00
|
|
|
float fX, fY;
|
|
|
|
|
|
|
|
|
|
acosf(1.0f);
|
|
|
|
|
acoshf(1.0f);
|
|
|
|
|
asinf(0.0f);
|
|
|
|
|
asinhf(0.0f);
|
|
|
|
|
atan2f(0.0f, 1.0f);
|
|
|
|
|
atanf(0.0f);
|
|
|
|
|
atanhf(0.0f);
|
|
|
|
|
cbrtf(0.0f);
|
|
|
|
|
fX = ceilf(0.0f);
|
|
|
|
|
fX = copysignf(1.0f, -2.0f);
|
|
|
|
|
cosf(0.0f);
|
|
|
|
|
coshf(0.0f);
|
|
|
|
|
cospif(0.0f);
|
2018-03-12 11:29:03 +05:30
|
|
|
// cyl_bessel_i0f(0.0f);
|
|
|
|
|
// cyl_bessel_i1f(0.0f);
|
2016-11-23 11:19:15 -06:00
|
|
|
erfcf(0.0f);
|
|
|
|
|
erfcinvf(2.0f);
|
|
|
|
|
erfcxf(0.0f);
|
|
|
|
|
erff(0.0f);
|
|
|
|
|
erfinvf(1.0f);
|
|
|
|
|
exp10f(0.0f);
|
|
|
|
|
exp2f(0.0f);
|
|
|
|
|
expf(0.0f);
|
|
|
|
|
expm1f(0.0f);
|
|
|
|
|
fX = fabsf(1.0f);
|
|
|
|
|
fdimf(1.0f, 0.0f);
|
|
|
|
|
fdividef(0.0f, 1.0f);
|
|
|
|
|
fX = floorf(0.0f);
|
|
|
|
|
fmaf(1.0f, 2.0f, 3.0f);
|
|
|
|
|
fX = fmaxf(0.0f, 0.0f);
|
|
|
|
|
fX = fminf(0.0f, 0.0f);
|
|
|
|
|
fmodf(0.0f, 1.0f);
|
2018-03-12 11:29:03 +05:30
|
|
|
// frexpf(0.0f, &iX);
|
2016-11-23 11:19:15 -06:00
|
|
|
hypotf(1.0f, 0.0f);
|
|
|
|
|
ilogbf(1.0f);
|
|
|
|
|
isfinite(0.0f);
|
|
|
|
|
fX = isinf(0.0f);
|
|
|
|
|
fX = isnan(0.0f);
|
|
|
|
|
j0f(0.0f);
|
|
|
|
|
j1f(0.0f);
|
|
|
|
|
jnf(-1.0f, 1.0f);
|
|
|
|
|
ldexpf(0.0f, 0);
|
2018-03-12 11:29:03 +05:30
|
|
|
// lgammaf(1.0f);
|
2016-11-23 11:19:15 -06:00
|
|
|
llrintf(0.0f);
|
|
|
|
|
llroundf(0.0f);
|
|
|
|
|
log10f(1.0f);
|
|
|
|
|
log1pf(-1.0f);
|
|
|
|
|
log2f(1.0f);
|
|
|
|
|
logbf(1.0f);
|
|
|
|
|
logf(1.0f);
|
|
|
|
|
lrintf(0.0f);
|
|
|
|
|
lroundf(0.0f);
|
2018-03-12 11:29:03 +05:30
|
|
|
// modff(0.0f, &fX);
|
2016-11-23 11:19:15 -06:00
|
|
|
fX = nanf("1");
|
|
|
|
|
fX = nearbyintf(0.0f);
|
2018-03-12 11:29:03 +05:30
|
|
|
// nextafterf(0.0f);
|
2016-11-23 11:19:15 -06:00
|
|
|
norm3df(1.0f, 0.0f, 0.0f);
|
|
|
|
|
norm4df(1.0f, 0.0f, 0.0f, 0.0f);
|
|
|
|
|
normcdff(0.0f);
|
|
|
|
|
normcdfinvf(1.0f);
|
2018-03-12 11:29:03 +05:30
|
|
|
fX = 1.0f;
|
|
|
|
|
normf(1, &fX);
|
2016-11-23 11:19:15 -06:00
|
|
|
powf(1.0f, 0.0f);
|
|
|
|
|
rcbrtf(1.0f);
|
|
|
|
|
remainderf(2.0f, 1.0f);
|
2018-03-12 11:29:03 +05:30
|
|
|
// remquof(1.0f, 2.0f, &iX);
|
2016-11-23 11:19:15 -06:00
|
|
|
rhypotf(0.0f, 1.0f);
|
|
|
|
|
fY = rintf(1.0f);
|
|
|
|
|
rnorm3df(0.0f, 0.0f, 1.0f);
|
|
|
|
|
rnorm4df(0.0f, 0.0f, 0.0f, 1.0f);
|
2018-03-12 11:29:03 +05:30
|
|
|
fX = 1.0f;
|
|
|
|
|
rnormf(1, &fX);
|
2016-11-23 11:19:15 -06:00
|
|
|
fY = roundf(0.0f);
|
|
|
|
|
rsqrtf(1.0f);
|
|
|
|
|
scalblnf(0.0f, 1);
|
|
|
|
|
scalbnf(0.0f, 1);
|
|
|
|
|
signbit(1.0f);
|
|
|
|
|
sincosf(0.0f, &fX, &fY);
|
|
|
|
|
sincospif(0.0f, &fX, &fY);
|
|
|
|
|
sinf(0.0f);
|
|
|
|
|
sinhf(0.0f);
|
|
|
|
|
sinpif(0.0f);
|
|
|
|
|
sqrtf(0.0f);
|
|
|
|
|
tanf(0.0f);
|
|
|
|
|
tanhf(0.0f);
|
|
|
|
|
tgammaf(2.0f);
|
|
|
|
|
fY = truncf(0.0f);
|
|
|
|
|
y0f(1.0f);
|
|
|
|
|
y1f(1.0f);
|
|
|
|
|
ynf(1, 1.0f);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int main() {
|
2018-03-12 11:29:03 +05:30
|
|
|
hipLaunchKernel(FloatMathPrecise, dim3(1, 1, 1), dim3(1, 1, 1), 0, 0);
|
2017-01-27 09:20:14 -06:00
|
|
|
passed();
|
2016-11-23 11:19:15 -06:00
|
|
|
}
|