forked from mihow/bpmdj
-
Notifications
You must be signed in to change notification settings - Fork 0
/
bpm-analyzer-2010.h
41 lines (35 loc) · 1.31 KB
/
bpm-analyzer-2010.h
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
33
34
35
36
37
38
39
40
41
/****
BpmDj v4.2-pl4: Free Dj Tools
Copyright (C) 2001-2012 Werner Van Belle
http://bpmdj.yellowcouch.org/
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.
This program is distributed in the hope that it will be useful,
but without any warranty; without even the implied warranty of
merchantability or fitness for a particular purpose. See the
GNU General Public License for more details.
See the authors.txt for a full list of people involved.
****/
#ifndef __loaded__bpm_analyzer_2010_h__
#define __loaded__bpm_analyzer_2010_h__
using namespace std;
#include <fftw3.h>
#include <cstdio>
#include <qstring.h>
#include "stereo-sample2.h"
#include "common.h"
#include "bpm-analyzer-impl.h"
#include "tempo-type.h"
typedef float8 fft_type;
class BpmAnalyzer2010: public BpmAnalyzerImpl
{
private:
void map_output(float4* target, int startfreq, int count, double* hcfreq, int winsize);
void spectrum_to_bark(fftw_complex* in, int window_size, double* out);
public:
BpmAnalyzer2010(stereo_sample2* audio, int n, int sample_rate, float from_tempo, float to_tempo);
virtual bool step();
};
#endif // __loaded__bpm_analyzer_2010_h__