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