openMSX
utils
hammingWindow.hh
Go to the documentation of this file.
1
#ifndef HAMMINGWINDOW_HH
2
#define HAMMINGWINDOW_HH
3
4
#include "
xrange.hh
"
5
6
#include <cassert>
7
#include <cmath>
8
#include <map>
9
#include <numbers>
10
#include <span>
11
#include <vector>
12
13
// Returns the coefficients of the 'hamming' window of length 'n'.
14
// https://en.wikipedia.org/wiki/Window_function#Hann_and_Hamming_windows
15
inline
std::span<const float>
hammingWindow
(
unsigned
n)
16
{
17
static
std::map<unsigned, std::vector<float>> cache;
18
auto
[it, inserted] = cache.try_emplace(n);
19
auto
& window = it->second;
20
21
if
(inserted) {
22
window.resize(n);
23
for
(
auto
i :
xrange
(n)) {
24
window[i] = float(0.53836 - 0.46164 * cos(2 * std::numbers::pi * i / (n - 1)));
25
}
26
return
window;
27
}
28
29
assert(window.size() == n);
30
return
window;
31
}
32
33
#endif
hammingWindow
std::span< const float > hammingWindow(unsigned n)
Definition
hammingWindow.hh:15
xrange.hh
xrange
constexpr auto xrange(T e)
Definition
xrange.hh:132
Generated on Tue Jan 21 2025 21:14:02 for openMSX by
1.9.8