DPNP C++ backend kernel library
0.18.0dev0
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
heaviside.hpp
1
//*****************************************************************************
2
// Copyright (c) 2024-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 <sycl/sycl.hpp>
29
30
// dpctl tensor headers
31
#include "utils/math_utils.hpp"
32
#include "utils/type_utils.hpp"
33
34
namespace
dpnp::kernels::heaviside
35
{
36
namespace
mu_ns = dpctl::tensor::math_utils;
37
namespace
tu_ns = dpctl::tensor::type_utils;
38
39
template
<
typename
argT1,
typename
argT2,
typename
resT>
40
struct
HeavisideFunctor
41
{
42
using
supports_sg_loadstore = std::negation<
43
std::disjunction<tu_ns::is_complex<argT1>, tu_ns::is_complex<argT2>>>;
44
using
supports_vec =
typename
std::false_type;
45
46
resT operator()(
const
argT1 &in1,
const
argT2 &in2)
const
47
{
48
if
(std::isnan(in1)) {
49
return
in1;
50
}
51
else
if
(in1 == 0) {
52
return
in2;
53
}
54
return
resT(in1 > 0);
55
}
56
};
57
}
// namespace dpnp::kernels::heaviside
dpnp::kernels::heaviside::HeavisideFunctor
Definition
heaviside.hpp:41
kernels
elementwise_functions
heaviside.hpp
Generated by
1.12.0