/* Copyright (c) 2015-2017 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. */ #include #include #include #include "device_util.h" #include "hip/hcc_detail/device_functions.h" #include "hip/hip_runtime.h" __device__ float acosf(float x) { return hc::precise_math::acosf(x); } __device__ float acoshf(float x) { return hc::precise_math::acoshf(x); } __device__ float asinf(float x) { return hc::precise_math::asinf(x); } __device__ float asinhf(float x) { return hc::precise_math::asinhf(x); } __device__ float atan2f(float y, float x) { return hc::precise_math::atan2f(y, x); } __device__ float atanf(float x) { return hc::precise_math::atanf(x); } __device__ float atanhf(float x) { return hc::precise_math::atanhf(x); } __device__ float cbrtf(float x) { return hc::precise_math::cbrtf(x); } __device__ float ceilf(float x) { return hc::precise_math::ceilf(x); } __device__ float copysignf(float x, float y) { return hc::precise_math::copysignf(x, y); } __device__ float cosf(float x) { return hc::precise_math::cosf(x); } __device__ float coshf(float x) { return hc::precise_math::coshf(x); } __device__ float cyl_bessel_i0f(float x); __device__ float cyl_bessel_i1f(float x); __device__ float erfcf(float x) { return hc::precise_math::erfcf(x); } __device__ float erfcinvf(float y) { return __hip_erfinvf(1 - y); } __device__ float erfcxf(float x) { return hc::precise_math::expf(x*x)*hc::precise_math::erfcf(x); } __device__ float erff(float x) { return hc::precise_math::erff(x); } __device__ float erfinvf(float y) { return __hip_erfinvf(y); } __device__ float exp10f(float x) { return hc::precise_math::exp10f(x); } __device__ float exp2f(float x) { return hc::precise_math::exp2f(x); } __device__ float expf(float x) { return hc::precise_math::expf(x); } __device__ float expm1f(float x) { return hc::precise_math::expm1f(x); } __device__ int abs(int x) { return x >= 0 ? x : -x; // TODO - optimize with OCML } __device__ float fabsf(float x) { return hc::precise_math::fabsf(x); } __device__ float fdimf(float x, float y) { return hc::precise_math::fdimf(x, y); } __device__ float fdividef(float x, float y) { return x/y; } __device__ float floorf(float x) { return hc::precise_math::floorf(x); } __device__ float fmaf(float x, float y, float z) { return hc::precise_math::fmaf(x, y, z); } __device__ float fmaxf(float x, float y) { return hc::precise_math::fmaxf(x, y); } __device__ float fminf(float x, float y) { return hc::precise_math::fminf(x, y); } __device__ float fmodf(float x, float y) { return hc::precise_math::fmodf(x, y); } __device__ float frexpf(float x, int *nptr) { return hc::precise_math::frexpf(x, nptr); } __device__ float hypotf(float x, float y) { return hc::precise_math::hypotf(x, y); } __device__ float ilogbf(float x) { return hc::precise_math::ilogbf(x); } __device__ int isfinite(float a) { return hc::precise_math::isfinite(a); } __device__ unsigned isinf(float a) { return hc::precise_math::isinf(a); } __device__ unsigned isnan(float a) { return hc::precise_math::isnan(a); } __device__ float j0f(float x) { return __hip_j0f(x); } __device__ float j1f(float x) { return __hip_j1f(x); } __device__ float jnf(int n, float x) { return __hip_jnf(n, x); } __device__ float ldexpf(float x, int exp) { return hc::precise_math::ldexpf(x, exp); } __device__ float lgammaf(float x) { float val = 0.0f; float y = x - 1; while(y > 0){ val += logf(y--); } return val; } __device__ long long int llrintf(float x) { int y = hc::precise_math::roundf(x); long long int z = y; return z; } __device__ long long int llroundf(float x) { int y = hc::precise_math::roundf(x); long long int z = y; return z; } __device__ float log10f(float x) { return hc::precise_math::log10f(x); } __device__ float log1pf(float x) { return hc::precise_math::log1pf(x); } __device__ float log2f(float x) { return hc::precise_math::log2f(x); } __device__ float logbf(float x) { return hc::precise_math::logbf(x); } __device__ float logf(float x) { return hc::precise_math::logf(x); } __device__ long int lrintf(float x) { int y = hc::precise_math::roundf(x); long int z = y; return z; } __device__ long int lroundf(float x) { long int y = hc::precise_math::roundf(x); return y; } __device__ float modff(float x, float *iptr) { return hc::precise_math::modff(x, iptr); } __device__ float nanf(const char* tagp) { return hc::precise_math::nanf((int)*tagp); } __device__ float nearbyintf(float x) { return hc::precise_math::nearbyintf(x); } __device__ float nextafterf(float x, float y) { return hc::precise_math::nextafter(x, y); } __device__ float norm3df(float a, float b, float c) { float x = a*a + b*b + c*c; return hc::precise_math::sqrtf(x); } __device__ float norm4df(float a, float b, float c, float d) { float x = a*a + b*b; float y = c*c + d*d; return hc::precise_math::sqrtf(x+y); } __device__ float normcdff(float y) { return ((hc::precise_math::erff(y)/1.41421356237) + 1)/2; } __device__ float normcdfinvf(float y) { return HIP_SQRT_2 * __hip_erfinvf(2*y-1); } __device__ float normf(int dim, const float *a) { float x = 0.0f; for(int i=0;i 0){ val += log(y--); } return val; } __device__ long long int llrint(double x) { long long int y = hc::precise_math::round(x); return y; } __device__ long long int llround(double x) { long long int y = hc::precise_math::round(x); return y; } __device__ double log(double x) { return hc::precise_math::log(x); } __device__ double log10(double x) { return hc::precise_math::log10(x); } __device__ double log1p(double x) { return hc::precise_math::log1p(x); } __device__ double log2(double x) { return hc::precise_math::log2(x); } __device__ double logb(double x) { return hc::precise_math::logb(x); } __device__ long int lrint(double x) { long int y = hc::precise_math::round(x); return y; } __device__ long int lround(double x) { long int y = hc::precise_math::round(x); return y; } __device__ double modf(double x, double *iptr) { return hc::precise_math::modf(x, iptr); } __device__ double nan(const char *tagp) { return hc::precise_math::nan((int)*tagp); } __device__ double nearbyint(double x) { return hc::precise_math::nearbyint(x); } __device__ double nextafter(double x, double y) { return hc::precise_math::nextafter(x, y); } __device__ double norm(int x, const double *d) { double val = 0; for(int i=0;i