DPNP C++ backend kernel library 0.18.0dev0
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
blackman.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
31namespace dpnp::extensions::window::kernels
32{
33
34template <typename T>
36{
37private:
38 T *data = nullptr;
39 const std::size_t N;
40
41public:
42 BlackmanFunctor(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 const T alpha = T(2) * i / (N - 1);
49 data[i] = T(0.42) - T(0.5) * sycl::cospi(alpha) +
50 T(0.08) * sycl::cospi(T(2) * alpha);
51 }
52};
53
54template <typename fnT, typename T>
56{
57 fnT get()
58 {
59 if constexpr (std::is_floating_point_v<T>) {
60 return window_impl<T, BlackmanFunctor>;
61 }
62 else {
63 return nullptr;
64 }
65 }
66};
67
68} // namespace dpnp::extensions::window::kernels