eDSP  0.0.1
A cross-platform DSP library written in C++.
flat_top.hpp
Go to the documentation of this file.
1 /*
2  * eDSP, A cross-platform Digital Signal Processing library written in modern C++.
3  * Copyright (C) 2018 Mohammed Boujemaoui Boulaghmoudi, All rights reserved.
4  *
5  * This program is free software: you can redistribute it and/or modify it
6  * under the terms of the GNU General Public License as published by the Free
7  * Software Foundation, either version 3 of the License, or (at your option)
8  * any later version.
9  *
10  * This program is distributed in the hope that it will be useful, but WITHOUT
11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
13  * more details.
14  *
15  * You should have received a copy of the GNU General Public License along width
16  * this program. If not, see <http://www.gnu.org/licenses/>
17  *
18  * File: flat_top.hpp
19  * Author: Mohammed Boujemaoui
20  * Date: 27/7/2018
21  */
22 #ifndef EDSP_FLAT_TOP_HPP
23 #define EDSP_FLAT_TOP_HPP
24 
25 #include <edsp/math/numeric.hpp>
26 #include <edsp/math/constant.hpp>
27 #include <edsp/meta/iterator.hpp>
28 
29 namespace edsp { namespace windowing {
30 
45  template <typename OutputIt>
46  constexpr void flattop(OutputIt first, OutputIt last) {
47  using value_type = meta::value_type_t<OutputIt>;
48  using size_type = meta::diff_type_t<OutputIt>;
49  constexpr auto a0 = static_cast<value_type>(0.21557895);
50  constexpr auto a1 = static_cast<value_type>(0.41663158);
51  constexpr auto a2 = static_cast<value_type>(0.277263158);
52  constexpr auto a3 = static_cast<value_type>(0.083578947);
53  constexpr auto a4 = static_cast<value_type>(0.006947368);
54  const auto size = static_cast<size_type>(std::distance(first, last));
55  const auto factor = constants<value_type>::two_pi / static_cast<value_type>(size - 1);
56  for (size_type i = 0; i < size; ++i, ++first) {
57  const value_type tmp = factor * i;
58  *first = a0 - a1 * std::cos(tmp) + a2 * std::cos(2 * tmp) - a3 * std::cos(3 * tmp) + a4 * std::cos(4 * tmp);
59  }
60  }
61 
62 }} // namespace edsp::windowing
63 
64 #endif // EDSP_FLAT_TOP_HPP
constexpr void flattop(OutputIt first, OutputIt last)
Computes a Flat top window of length N and stores the result in the range, beginning at d_first...
Definition: flat_top.hpp:46
constexpr T distance(T x, T y) noexcept
Computes the distance between x and y.
Definition: numeric.hpp:328
Definition: amplifier.hpp:29