-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathWindowFunction.cpp
More file actions
32 lines (27 loc) · 985 Bytes
/
WindowFunction.cpp
File metadata and controls
32 lines (27 loc) · 985 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
/*
Vamp Tempogram Plugin
Carl Bussey, Centre for Digital Music, Queen Mary University of London
Copyright 2014 Queen Mary University of London.
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version. See the file
COPYING included with this distribution for more information.
*/
#include "WindowFunction.h"
using std::vector;
//static function
void
WindowFunction::hanning(float * window, const unsigned int &N, const bool &normalise){
float sum = 0;
for(int i = 0; i < (int)N; i++){
window[i] = 0.5*(1-cos((float)2*M_PI*i/N));
sum += window[i];
}
if (normalise){
for(int i = 0; i < (int)N; i++){
window[i] /= sum;
}
}
}