DPNP C++ backend kernel library 0.19.0dev6
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
erf.hpp
1//*****************************************************************************
2// Copyright (c) 2025, Intel Corporation
3// All rights reserved.
4//
5// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions are met:
7// - Redistributions of source code must retain the above copyright notice,
8// this list of conditions and the following disclaimer.
9// - Redistributions in binary form must reproduce the above copyright notice,
10// this list of conditions and the following disclaimer in the documentation
11// and/or other materials provided with the distribution.
12//
13// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
14// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
17// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23// THE POSSIBILITY OF SUCH DAMAGE.
24//*****************************************************************************
25
26#pragma once
27
28#include <type_traits>
29
30#include <sycl/sycl.hpp>
31
35#if defined(__INTEL_LLVM_COMPILER)
36#define __SYCL_EXT_INTEL_MATH_SUPPORT
37#endif
38
39#if defined(__SYCL_EXT_INTEL_MATH_SUPPORT)
40#include <sycl/ext/intel/math.hpp>
41#else
42#include <cmath>
43#endif
44
46{
47template <typename OpT, typename ArgT, typename ResT>
49{
50 // is function constant for given ArgT
51 using is_constant = typename std::false_type;
52 // constant value, if constant
53 // constexpr ResT constant_value = ResT{};
54 // is function defined for sycl::vec
55 using supports_vec = typename std::false_type;
56 // do both ArgT and ResT support subgroup store/load operation
57 using supports_sg_loadstore = typename std::true_type;
58
59 ResT operator()(const ArgT &x) const
60 {
61 if constexpr (std::is_same_v<ArgT, sycl::half> &&
62 std::is_same_v<ResT, float>) {
63 // cast sycl::half to float for accuracy reasons
64 return OpT::apply(float(x));
65 }
66 else {
67 return OpT::apply(x);
68 }
69 }
70};
71
72#define MACRO_DEFINE_FUNCTOR(__name__, __f_name__) \
73 struct __f_name__##Op \
74 { \
75 template <typename Tp> \
76 static Tp apply(const Tp &x) \
77 { \
78 return __name__(x); \
79 } \
80 }; \
81 \
82 template <typename ArgT, typename ResT> \
83 using __f_name__##Functor = BaseFunctor<__f_name__##Op, ArgT, ResT>;
84
85MACRO_DEFINE_FUNCTOR(sycl::erf, Erf);
86MACRO_DEFINE_FUNCTOR(sycl::erfc, Erfc);
87MACRO_DEFINE_FUNCTOR(
88#if defined(__SYCL_EXT_INTEL_MATH_SUPPORT)
89 sycl::ext::intel::math::erfcx,
90#else
91 std::erfc,
92#endif
93 Erfcx);
94} // namespace dpnp::kernels::erfs