DPNP C++ backend kernel library
0.20.0dev0
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
ldexp.hpp
1
//*****************************************************************************
2
// Copyright (c) 2024, 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 <sycl/sycl.hpp>
32
33
// dpctl tensor headers
34
#include "utils/math_utils.hpp"
35
#include "utils/type_utils.hpp"
36
37
namespace
dpnp::kernels::ldexp
38
{
39
template
<
typename
argT1,
typename
argT2,
typename
resT>
40
struct
LdexpFunctor
41
{
42
using
supports_sg_loadstore =
typename
std::true_type;
43
using
supports_vec =
typename
std::false_type;
44
45
resT operator()(
const
argT1 &in1,
const
argT2 &in2)
const
46
{
47
if
(((
int
)in2) == in2) {
48
return
sycl::ldexp(in1, in2);
49
}
50
51
// a separate handling for large integer values
52
if
(in2 > 0) {
53
return
std::numeric_limits<resT>::infinity();
54
}
55
return
resT(0);
56
}
57
};
58
}
// namespace dpnp::kernels::ldexp
dpnp::kernels::ldexp::LdexpFunctor
Definition
ldexp.hpp:41
kernels
elementwise_functions
ldexp.hpp
Generated by
1.12.0