DPNP C++ backend kernel library 0.20.0dev0
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// - Neither the name of the copyright holder nor the names of its contributors
13// may be used to endorse or promote products derived from this software
14// without specific prior written permission.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
26// THE POSSIBILITY OF SUCH DAMAGE.
27//*****************************************************************************
28
29#pragma once
30
31#include <type_traits>
32
33#include <sycl/sycl.hpp>
34
38#if (defined(__SPIR__) || defined(__SPIRV__)) && defined(__INTEL_LLVM_COMPILER)
39#define __SYCL_EXT_INTEL_MATH_SUPPORT
40#endif
41
42#if defined(__SYCL_EXT_INTEL_MATH_SUPPORT)
43#include <sycl/ext/intel/math.hpp>
44#else
45#include "erfcx.hpp"
46#include "erfinv.hpp"
47#endif
48
50{
51template <typename OpT, typename ArgT, typename ResT>
53{
54 // is function constant for given ArgT
55 using is_constant = typename std::false_type;
56 // constant value, if constant
57 // constexpr ResT constant_value = ResT{};
58 // is function defined for sycl::vec
59 using supports_vec = typename std::false_type;
60 // do both ArgT and ResT support subgroup store/load operation
61 using supports_sg_loadstore = typename std::true_type;
62
63 ResT operator()(const ArgT &x) const
64 {
65 if constexpr (std::is_same_v<ArgT, sycl::half> &&
66 std::is_same_v<ResT, float>) {
67 // cast sycl::half to float for accuracy reasons
68 return OpT::apply(float(x));
69 }
70 else {
71 return OpT::apply(x);
72 }
73 }
74};
75
76#define MACRO_DEFINE_FUNCTOR(__name__, __f_name__) \
77 struct __f_name__##Op \
78 { \
79 template <typename Tp> \
80 static Tp apply(const Tp &x) \
81 { \
82 return __name__(x); \
83 } \
84 }; \
85 \
86 template <typename ArgT, typename ResT> \
87 using __f_name__##Functor = BaseFunctor<__f_name__##Op, ArgT, ResT>;
88
89#if defined(__SYCL_EXT_INTEL_MATH_SUPPORT)
90using namespace sycl::ext::intel::math;
91#else
92using namespace impl;
93#endif
94
95MACRO_DEFINE_FUNCTOR(sycl::erf, Erf);
96MACRO_DEFINE_FUNCTOR(sycl::erfc, Erfc);
97MACRO_DEFINE_FUNCTOR(erfcx, Erfcx);
98MACRO_DEFINE_FUNCTOR(erfinv, Erfinv);
99MACRO_DEFINE_FUNCTOR(erfcinv, Erfcinv);
100} // namespace dpnp::kernels::erfs