DPNP C++ backend kernel library
0.20.0dev0
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
bartlett.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, RES, 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 "common.hpp"
32
#include <sycl/sycl.hpp>
33
34
namespace
dpnp::extensions::window::kernels
35
{
36
37
template
<
typename
T>
38
class
BartlettFunctor
39
{
40
private
:
41
T *res =
nullptr
;
42
const
std::size_t N;
43
44
public
:
45
BartlettFunctor
(T *res,
const
std::size_t N) : res(res), N(N) {}
46
47
void
operator()(sycl::id<1>
id
)
const
48
{
49
const
auto
i =
id
.get(0);
50
51
const
T alpha = (N - 1) / T(2);
52
res[i] = T(1) - sycl::fabs(i - alpha) / alpha;
53
}
54
};
55
56
template
<
typename
fnT,
typename
T>
57
struct
BartlettFactory
58
{
59
fnT get()
60
{
61
if
constexpr
(std::is_floating_point_v<T>) {
62
return
window_impl<T, BartlettFunctor>;
63
}
64
else
{
65
return
nullptr
;
66
}
67
}
68
};
69
70
}
// namespace dpnp::extensions::window::kernels
dpnp::extensions::window::kernels::BartlettFunctor
Definition
bartlett.hpp:39
dpnp::extensions::window::kernels::BartlettFactory
Definition
bartlett.hpp:58
extensions
window
bartlett.hpp
Generated by
1.12.0