diff options
-rw-r--r-- | generic/include/clc/math/log.h | 26 | ||||
-rw-r--r-- | generic/include/clc/math/log.inc | 23 | ||||
-rw-r--r-- | generic/lib/SOURCES | 1 | ||||
-rw-r--r-- | generic/lib/math/log.cl | 26 |
4 files changed, 73 insertions, 3 deletions
diff --git a/generic/include/clc/math/log.h b/generic/include/clc/math/log.h index ee272eb..5680de2 100644 --- a/generic/include/clc/math/log.h +++ b/generic/include/clc/math/log.h @@ -1,4 +1,24 @@ -#undef log +/* + * Copyright (c) 2015 Advanced Micro Devices, Inc. + * + * 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. + */ -// log(x) = log2(x) * (1/log2(e)) -#define log(val) (log2(val) * 0.693147181f) +#define __CLC_BODY <clc/math/log.inc> +#include <clc/math/gentype.inc> diff --git a/generic/include/clc/math/log.inc b/generic/include/clc/math/log.inc new file mode 100644 index 0000000..621dd08 --- /dev/null +++ b/generic/include/clc/math/log.inc @@ -0,0 +1,23 @@ +/* + * Copyright (c) 2015 Advanced Micro Devices, Inc. + * + * 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. + */ + +_CLC_OVERLOAD _CLC_DECL __CLC_GENTYPE log(__CLC_GENTYPE a); diff --git a/generic/lib/SOURCES b/generic/lib/SOURCES index 53959d5..a5ee9f8 100644 --- a/generic/lib/SOURCES +++ b/generic/lib/SOURCES @@ -91,6 +91,7 @@ math/half_sqrt.cl math/hypot.cl math/clc_ldexp.cl math/ldexp.cl +math/log.cl math/log10.cl math/log1p.cl math/log2.cl diff --git a/generic/lib/math/log.cl b/generic/lib/math/log.cl new file mode 100644 index 0000000..ec1faa1 --- /dev/null +++ b/generic/lib/math/log.cl @@ -0,0 +1,26 @@ +#include <clc/clc.h> +#include "../clcmacro.h" + +/* + *log(x) = log2(x) * (1/log2(e)) + */ + +_CLC_OVERLOAD _CLC_DEF float log(float x) +{ + return log2(x) * (1.0f / M_LOG2E_F); +} + +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, float, log, float); + +#ifdef cl_khr_fp64 + +#pragma OPENCL EXTENSION cl_khr_fp64 : enable + +_CLC_OVERLOAD _CLC_DEF double log(double x) +{ + return log2(x) * (1.0 / M_LOG2E); +} + +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, double, log, double); + +#endif // cl_khr_fp64 |