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
32
namespace
dpnp::kernels::erfs
33
{
34
template
<
typename
OpT,
typename
ArgT,
typename
ResT>
35
struct
BaseFunctor
36
{
37
// is function constant for given ArgT
38
using
is_constant =
typename
std::false_type;
39
// constant value, if constant
40
// constexpr ResT constant_value = ResT{};
41
// is function defined for sycl::vec
42
using
supports_vec =
typename
std::false_type;
43
// do both ArgT and ResT support subgroup store/load operation
44
using
supports_sg_loadstore =
typename
std::true_type;
45
46
ResT operator()(
const
ArgT &x)
const
47
{
48
if
constexpr
(std::is_same_v<ArgT, sycl::half> &&
49
std::is_same_v<ResT, float>) {
50
// cast sycl::half to float for accuracy reasons
51
return
OpT::apply(
float
(x));
52
}
53
else
{
54
return
OpT::apply(x);
55
}
56
}
57
};
58
59
#define MACRO_DEFINE_FUNCTOR(__name__, __f_name__) \
60
struct __f_name__##Op \
61
{ \
62
template <typename Tp> \
63
static Tp apply(const Tp &x) \
64
{ \
65
return sycl::__name__(x); \
66
} \
67
}; \
68
\
69
template <typename ArgT, typename ResT> \
70
using __f_name__##Functor = BaseFunctor<__f_name__##Op, ArgT, ResT>;
71
72
MACRO_DEFINE_FUNCTOR(erf, Erf);
73
MACRO_DEFINE_FUNCTOR(erfc, Erfc);
74
}
// namespace dpnp::kernels::erfs
dpnp::kernels::erfs::BaseFunctor
Definition
erf.hpp:36
kernels
elementwise_functions
erf.hpp
Generated by
1.12.0